ne FW_SNDING_SET_NDPA0_HEAD_PG(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
+#define FW_SNDING_SET_NDPA0_HEAD_PG_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
+#define FW_SNDING_GET_NDPA1_HEAD_PG(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
+#define FW_SNDING_SET_NDPA1_HEAD_PG(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
+#define FW_SNDING_SET_NDPA1_HEAD_PG_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
+#define FW_SNDING_GET_MU_NDPA_HEAD_PG(h2c_pkt)                                 \
+	GET_H2C_FIELD(h2c_pkt + 0XC, 0, 8)
+#define FW_SNDING_SET_MU_NDPA_HEAD_PG(h2c_pkt, value)                          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 0, 8, value)
+#define FW_SNDING_SET_MU_NDPA_HEAD_PG_NO_CLR(h2c_pkt, value)                   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 0, 8, value)
+#define FW_SNDING_GET_RPT0_HEAD_PG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0XC, 8, 8)
+#define FW_SNDING_SET_RPT0_HEAD_PG(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 8, 8, value)
+#define FW_SNDING_SET_RPT0_HEAD_PG_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 8, 8, value)
+#define FW_SNDING_GET_RPT1_HEAD_PG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0XC, 16, 8)
+#define FW_SNDING_SET_RPT1_HEAD_PG(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 16, 8, value)
+#define FW_SNDING_SET_RPT1_HEAD_PG_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 16, 8, value)
+#define FW_SNDING_GET_RPT2_HEAD_PG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0XC, 24, 8)
+#define FW_SNDING_SET_RPT2_HEAD_PG(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 24, 8, value)
+#define FW_SNDING_SET_RPT2_HEAD_PG_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 24, 8, value)
+#define FW_FWCTRL_GET_SEQ_NUM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
+#define FW_FWCTRL_SET_SEQ_NUM(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
+#define FW_FWCTRL_SET_SEQ_NUM_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
+#define FW_FWCTRL_GET_MORE_CONTENT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 1)
+#define FW_FWCTRL_SET_MORE_CONTENT(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 1, value)
+#define FW_FWCTRL_SET_MORE_CONTENT_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 1, value)
+#define FW_FWCTRL_GET_CONTENT_IDX(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 9, 7)
+#define FW_FWCTRL_SET_CONTENT_IDX(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 9, 7, value)
+#define FW_FWCTRL_SET_CONTENT_IDX_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 9, 7, value)
+#define FW_FWCTRL_GET_CLASS_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
+#define FW_FWCTRL_SET_CLASS_ID(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
+#define FW_FWCTRL_SET_CLASS_ID_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
+#define FW_FWCTRL_GET_LENGTH(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
+#define FW_FWCTRL_SET_LENGTH(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
+#define FW_FWCTRL_SET_LENGTH_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
+#define FW_FWCTRL_GET_CONTENT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 32)
+#define FW_FWCTRL_SET_CONTENT(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 32, value)
+#define FW_FWCTRL_SET_CONTENT_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 32, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_fw_offload_h2c_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_fw_offload_h2c_nic.h
new file mode 100644
index 000000000000..525be7e9d72f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_fw_offload_h2c_nic.h
@@ -0,0 +1,694 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_FWOFFLOADH2CFORMAT_H2C_C2H_NIC_H_
+#define _HAL_FWOFFLOADH2CFORMAT_H2C_C2H_NIC_H_
+#define CMD_ID_FW_OFFLOAD_H2C 0XFF
+#define CMD_ID_CH_SWITCH 0XFF
+#define CMD_ID_DUMP_PHYSICAL_EFUSE 0XFF
+#define CMD_ID_UPDATE_BEACON_PARSING_INFO 0XFF
+#define CMD_ID_CFG_PARAM 0XFF
+#define CMD_ID_UPDATE_DATAPACK 0XFF
+#define CMD_ID_RUN_DATAPACK 0XFF
+#define CMD_ID_DOWNLOAD_FLASH 0XFF
+#define CMD_ID_UPDATE_PKT 0XFF
+#define CMD_ID_GENERAL_INFO 0XFF
+#define CMD_ID_IQK 0XFF
+#define CMD_ID_PWR_TRK 0XFF
+#define CMD_ID_PSD 0XFF
+#define CMD_ID_P2PPS 0XFF
+#define CMD_ID_BT_COEX 0XFF
+#define CMD_ID_NAN_CTRL 0XFF
+#define CMD_ID_NAN_CHANNEL_PLAN_0 0XFF
+#define CMD_ID_NAN_CHANNEL_PLAN_1 0XFF
+#define CMD_ID_FW_ACCESS_TEST 0XFF
+#define CMD_ID_PHYDM_INFO 0XFF
+#define CMD_ID_FW_SNDING 0XFF
+#define CMD_ID_H2C_LOOPBACK 0XFF
+#define CMD_ID_FWCMD_LOOPBACK 0XFF
+#define CMD_ID_FW_FWCTRL 0XFF
+#define CATEGORY_H2C_CMD_HEADER 0X00
+#define CATEGORY_FW_OFFLOAD_H2C 0X01
+#define CATEGORY_CH_SWITCH 0X01
+#define CATEGORY_DUMP_PHYSICAL_EFUSE 0X01
+#define CATEGORY_UPDATE_BEACON_PARSING_INFO 0X01
+#define CATEGORY_CFG_PARAM 0X01
+#define CATEGORY_UPDATE_DATAPACK 0X01
+#define CATEGORY_RUN_DATAPACK 0X01
+#define CATEGORY_DOWNLOAD_FLASH 0X01
+#define CATEGORY_UPDATE_PKT 0X01
+#define CATEGORY_GENERAL_INFO 0X01
+#define CATEGORY_IQK 0X01
+#define CATEGORY_PWR_TRK 0X01
+#define CATEGORY_PSD 0X01
+#define CATEGORY_P2PPS 0X01
+#define CATEGORY_BT_COEX 0X01
+#define CATEGORY_NAN_CTRL 0X01
+#define CATEGORY_NAN_CHANNEL_PLAN_0 0X01
+#define CATEGORY_NAN_CHANNEL_PLAN_1 0X01
+#define CATEGORY_FW_ACCESS_TEST 0X01
+#define CATEGORY_PHYDM_INFO 0X01
+#define CATEGORY_FW_SNDING 0X01
+#define CATEGORY_H2C_LOOPBACK 0X01
+#define CATEGORY_FWCMD_LOOPBACK 0X01
+#define CATEGORY_FW_FWCTRL 0X01
+#define SUB_CMD_ID_CH_SWITCH 0X02
+#define SUB_CMD_ID_DUMP_PHYSICAL_EFUSE 0X03
+#define SUB_CMD_ID_UPDATE_BEACON_PARSING_INFO 0X05
+#define SUB_CMD_ID_CFG_PARAM 0X08
+#define SUB_CMD_ID_UPDATE_DATAPACK 0X09
+#define SUB_CMD_ID_RUN_DATAPACK 0X0A
+#define SUB_CMD_ID_DOWNLOAD_FLASH 0X0B
+#define SUB_CMD_ID_UPDATE_PKT 0X0C
+#define SUB_CMD_ID_GENERAL_INFO 0X0D
+#define SUB_CMD_ID_IQK 0X0E
+#define SUB_CMD_ID_PWR_TRK 0X0F
+#define SUB_CMD_ID_PSD 0X10
+#define SUB_CMD_ID_P2PPS 0X24
+#define SUB_CMD_ID_BT_COEX 0X60
+#define SUB_CMD_ID_NAN_CTRL 0XB2
+#define SUB_CMD_ID_NAN_CHANNEL_PLAN_0 0XB4
+#define SUB_CMD_ID_NAN_CHANNEL_PLAN_1 0XB5
+#define SUB_CMD_ID_FW_ACCESS_TEST 0X00
+#define SUB_CMD_ID_PHYDM_INFO 0X11
+#define SUB_CMD_ID_FW_SNDING 0X12
+#define SUB_CMD_ID_FW_FWCTRL 0X13
+#define SUB_CMD_ID_H2C_LOOPBACK 0X14
+#define SUB_CMD_ID_FWCMD_LOOPBACK 0X15
+#define H2C_CMD_HEADER_GET_CATEGORY(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 7)
+#define H2C_CMD_HEADER_SET_CATEGORY(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 7, value)
+#define H2C_CMD_HEADER_GET_ACK(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 7, 1)
+#define H2C_CMD_HEADER_SET_ACK(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 7, 1, value)
+#define H2C_CMD_HEADER_GET_TOTAL_LEN(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 16)
+#define H2C_CMD_HEADER_SET_TOTAL_LEN(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 16, value)
+#define H2C_CMD_HEADER_GET_SEQ_NUM(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 16)
+#define H2C_CMD_HEADER_SET_SEQ_NUM(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 16, value)
+#define FW_OFFLOAD_H2C_GET_CATEGORY(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 7)
+#define FW_OFFLOAD_H2C_SET_CATEGORY(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 7, value)
+#define FW_OFFLOAD_H2C_GET_ACK(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 7, 1)
+#define FW_OFFLOAD_H2C_SET_ACK(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 7, 1, value)
+#define FW_OFFLOAD_H2C_GET_CMD_ID(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define FW_OFFLOAD_H2C_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define FW_OFFLOAD_H2C_GET_SUB_CMD_ID(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 16)
+#define FW_OFFLOAD_H2C_SET_SUB_CMD_ID(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 16, value)
+#define FW_OFFLOAD_H2C_GET_TOTAL_LEN(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 16)
+#define FW_OFFLOAD_H2C_SET_TOTAL_LEN(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 16, value)
+#define FW_OFFLOAD_H2C_GET_SEQ_NUM(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 16)
+#define FW_OFFLOAD_H2C_SET_SEQ_NUM(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 16, value)
+#define CH_SWITCH_GET_START(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
+#define CH_SWITCH_SET_START(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
+#define CH_SWITCH_GET_DEST_CH_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
+#define CH_SWITCH_SET_DEST_CH_EN(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
+#define CH_SWITCH_GET_ABSOLUTE_TIME(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
+#define CH_SWITCH_SET_ABSOLUTE_TIME(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
+#define CH_SWITCH_GET_PERIODIC_OPT(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 2)
+#define CH_SWITCH_SET_PERIODIC_OPT(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 2, value)
+#define CH_SWITCH_GET_INFO_LOC(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
+#define CH_SWITCH_SET_INFO_LOC(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
+#define CH_SWITCH_GET_CH_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define CH_SWITCH_SET_CH_NUM(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define CH_SWITCH_GET_PRI_CH_IDX(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 4)
+#define CH_SWITCH_SET_PRI_CH_IDX(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 4, value)
+#define CH_SWITCH_GET_DEST_BW(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 28, 4)
+#define CH_SWITCH_SET_DEST_BW(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 28, 4, value)
+#define CH_SWITCH_GET_DEST_CH(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
+#define CH_SWITCH_SET_DEST_CH(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
+#define CH_SWITCH_GET_NORMAL_PERIOD(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 6)
+#define CH_SWITCH_SET_NORMAL_PERIOD(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 6, value)
+#define CH_SWITCH_GET_NORMAL_PERIOD_SEL(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 14, 2)
+#define CH_SWITCH_SET_NORMAL_PERIOD_SEL(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 14, 2, value)
+#define CH_SWITCH_GET_SLOW_PERIOD(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 6)
+#define CH_SWITCH_SET_SLOW_PERIOD(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 6, value)
+#define CH_SWITCH_GET_SLOW_PERIOD_SEL(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 22, 2)
+#define CH_SWITCH_SET_SLOW_PERIOD_SEL(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 22, 2, value)
+#define CH_SWITCH_GET_NORMAL_CYCLE(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 24, 8)
+#define CH_SWITCH_SET_NORMAL_CYCLE(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 24, 8, value)
+#define CH_SWITCH_GET_TSF_HIGH(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
+#define CH_SWITCH_SET_TSF_HIGH(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
+#define CH_SWITCH_GET_TSF_LOW(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 32)
+#define CH_SWITCH_SET_TSF_LOW(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 32, value)
+#define CH_SWITCH_GET_INFO_SIZE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 16)
+#define CH_SWITCH_SET_INFO_SIZE(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 16, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_FUNC_EN(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
+#define UPDATE_BEACON_PARSING_INFO_SET_FUNC_EN(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_SIZE_TH(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 4)
+#define UPDATE_BEACON_PARSING_INFO_SET_SIZE_TH(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 4, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_TIMEOUT(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 12, 4)
+#define UPDATE_BEACON_PARSING_INFO_SET_TIMEOUT(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 12, 4, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_0(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 32)
+#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_0(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 32, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_1(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
+#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_1(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_2(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 32)
+#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_2(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 32, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_3(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 32)
+#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_3(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 32, value)
+#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_4(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 32)
+#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_4(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 32, value)
+#define CFG_PARAM_GET_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
+#define CFG_PARAM_SET_NUM(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
+#define CFG_PARAM_GET_INIT_CASE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 1)
+#define CFG_PARAM_SET_INIT_CASE(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 1, value)
+#define CFG_PARAM_GET_LOC(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
+#define CFG_PARAM_SET_LOC(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
+#define UPDATE_DATAPACK_GET_SIZE(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
+#define UPDATE_DATAPACK_SET_SIZE(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
+#define UPDATE_DATAPACK_GET_DATAPACK_ID(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define UPDATE_DATAPACK_SET_DATAPACK_ID(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define UPDATE_DATAPACK_GET_DATAPACK_LOC(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
+#define UPDATE_DATAPACK_SET_DATAPACK_LOC(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
+#define UPDATE_DATAPACK_GET_DATAPACK_SEGMENT(h2c_pkt)                          \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
+#define UPDATE_DATAPACK_SET_DATAPACK_SEGMENT(h2c_pkt, value)                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
+#define UPDATE_DATAPACK_GET_END_SEGMENT(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 1)
+#define UPDATE_DATAPACK_SET_END_SEGMENT(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 1, value)
+#define RUN_DATAPACK_GET_DATAPACK_ID(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
+#define RUN_DATAPACK_SET_DATAPACK_ID(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
+#define DOWNLOAD_FLASH_GET_SPI_CMD(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
+#define DOWNLOAD_FLASH_SET_SPI_CMD(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
+#define DOWNLOAD_FLASH_GET_LOCATION(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 16)
+#define DOWNLOAD_FLASH_SET_LOCATION(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 16, value)
+#define DOWNLOAD_FLASH_GET_SIZE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 32)
+#define DOWNLOAD_FLASH_SET_SIZE(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 32, value)
+#define DOWNLOAD_FLASH_GET_START_ADDR(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
+#define DOWNLOAD_FLASH_SET_START_ADDR(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
+#define UPDATE_PKT_GET_SIZE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
+#define UPDATE_PKT_SET_SIZE(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
+#define UPDATE_PKT_GET_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define UPDATE_PKT_SET_ID(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define UPDATE_PKT_GET_LOC(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
+#define UPDATE_PKT_SET_LOC(h2c_pkt, value)                                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
+#define GENERAL_INFO_GET_FW_TX_BOUNDARY(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define GENERAL_INFO_SET_FW_TX_BOUNDARY(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define IQK_GET_CLEAR(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
+#define IQK_SET_CLEAR(h2c_pkt, value)                                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
+#define IQK_GET_SEGMENT_IQK(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
+#define IQK_SET_SEGMENT_IQK(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
+#define PWR_TRK_GET_ENABLE_A(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
+#define PWR_TRK_SET_ENABLE_A(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
+#define PWR_TRK_GET_ENABLE_B(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
+#define PWR_TRK_SET_ENABLE_B(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
+#define PWR_TRK_GET_ENABLE_C(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
+#define PWR_TRK_SET_ENABLE_C(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
+#define PWR_TRK_GET_ENABLE_D(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 1)
+#define PWR_TRK_SET_ENABLE_D(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 1, value)
+#define PWR_TRK_GET_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 4, 3)
+#define PWR_TRK_SET_TYPE(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 4, 3, value)
+#define PWR_TRK_GET_BBSWING_INDEX(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
+#define PWR_TRK_SET_BBSWING_INDEX(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
+#define PWR_TRK_GET_TX_PWR_INDEX_A(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
+#define PWR_TRK_SET_TX_PWR_INDEX_A(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
+#define PWR_TRK_GET_OFFSET_VALUE_A(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 8)
+#define PWR_TRK_SET_OFFSET_VALUE_A(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 8, value)
+#define PWR_TRK_GET_TSSI_VALUE_A(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 8)
+#define PWR_TRK_SET_TSSI_VALUE_A(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 8, value)
+#define PWR_TRK_GET_TX_PWR_INDEX_B(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 8)
+#define PWR_TRK_SET_TX_PWR_INDEX_B(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 8, value)
+#define PWR_TRK_GET_OFFSET_VALUE_B(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 8, 8)
+#define PWR_TRK_SET_OFFSET_VALUE_B(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 8, 8, value)
+#define PWR_TRK_GET_TSSI_VALUE_B(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 16, 8)
+#define PWR_TRK_SET_TSSI_VALUE_B(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 16, 8, value)
+#define PWR_TRK_GET_TX_PWR_INDEX_C(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 8)
+#define PWR_TRK_SET_TX_PWR_INDEX_C(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 8, value)
+#define PWR_TRK_GET_OFFSET_VALUE_C(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 8, 8)
+#define PWR_TRK_SET_OFFSET_VALUE_C(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 8, 8, value)
+#define PWR_TRK_GET_TSSI_VALUE_C(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 16, 8)
+#define PWR_TRK_SET_TSSI_VALUE_C(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 16, 8, value)
+#define PWR_TRK_GET_TX_PWR_INDEX_D(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 8)
+#define PWR_TRK_SET_TX_PWR_INDEX_D(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 8, value)
+#define PWR_TRK_GET_OFFSET_VALUE_D(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 8, 8)
+#define PWR_TRK_SET_OFFSET_VALUE_D(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 8, 8, value)
+#define PWR_TRK_GET_TSSI_VALUE_D(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 16, 8)
+#define PWR_TRK_SET_TSSI_VALUE_D(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 16, 8, value)
+#define PSD_GET_START_PSD(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
+#define PSD_SET_START_PSD(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
+#define PSD_GET_END_PSD(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 16)
+#define PSD_SET_END_PSD(h2c_pkt, value)                                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 16, value)
+#define P2PPS_GET_OFFLOAD_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
+#define P2PPS_SET_OFFLOAD_EN(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
+#define P2PPS_GET_ROLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
+#define P2PPS_SET_ROLE(h2c_pkt, value)                                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
+#define P2PPS_GET_CTWINDOW_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
+#define P2PPS_SET_CTWINDOW_EN(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
+#define P2PPS_GET_NOA_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 1)
+#define P2PPS_SET_NOA_EN(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 1, value)
+#define P2PPS_GET_NOA_SEL(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 4, 1)
+#define P2PPS_SET_NOA_SEL(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 4, 1, value)
+#define P2PPS_GET_ALLSTASLEEP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 5, 1)
+#define P2PPS_SET_ALLSTASLEEP(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 5, 1, value)
+#define P2PPS_GET_DISCOVERY(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 6, 1)
+#define P2PPS_SET_DISCOVERY(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 6, 1, value)
+#define P2PPS_GET_DISABLE_CLOSERF(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 7, 1)
+#define P2PPS_SET_DISABLE_CLOSERF(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 7, 1, value)
+#define P2PPS_GET_P2P_PORT_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
+#define P2PPS_SET_P2P_PORT_ID(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
+#define P2PPS_GET_P2P_GROUP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define P2PPS_SET_P2P_GROUP(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define P2PPS_GET_P2P_MACID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
+#define P2PPS_SET_P2P_MACID(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
+#define P2PPS_GET_CTWINDOW_LENGTH(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
+#define P2PPS_SET_CTWINDOW_LENGTH(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
+#define P2PPS_GET_NOA_DURATION_PARA(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
+#define P2PPS_SET_NOA_DURATION_PARA(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
+#define P2PPS_GET_NOA_INTERVAL_PARA(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 32)
+#define P2PPS_SET_NOA_INTERVAL_PARA(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 32, value)
+#define P2PPS_GET_NOA_START_TIME_PARA(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 32)
+#define P2PPS_SET_NOA_START_TIME_PARA(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 32, value)
+#define P2PPS_GET_NOA_COUNT_PARA(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 32)
+#define P2PPS_SET_NOA_COUNT_PARA(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 32, value)
+#define BT_COEX_GET_DATA_START(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
+#define BT_COEX_SET_DATA_START(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
+#define NAN_CTRL_GET_NAN_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 2)
+#define NAN_CTRL_SET_NAN_EN(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 2, value)
+#define NAN_CTRL_GET_WARMUP_TIMER_FLAG(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
+#define NAN_CTRL_SET_WARMUP_TIMER_FLAG(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
+#define NAN_CTRL_GET_SUPPORT_BAND(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 2)
+#define NAN_CTRL_SET_SUPPORT_BAND(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 2, value)
+#define NAN_CTRL_GET_DISABLE_2G_DISC_BCN(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 10, 1)
+#define NAN_CTRL_SET_DISABLE_2G_DISC_BCN(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 10, 1, value)
+#define NAN_CTRL_GET_DISABLE_5G_DISC_BCN(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 11, 1)
+#define NAN_CTRL_SET_DISABLE_5G_DISC_BCN(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 11, 1, value)
+#define NAN_CTRL_GET_BCN_RSVD_PAGE_OFFSET(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define NAN_CTRL_SET_BCN_RSVD_PAGE_OFFSET(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define NAN_CTRL_GET_CHANNEL_2G(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
+#define NAN_CTRL_SET_CHANNEL_2G(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
+#define NAN_CTRL_GET_CHANNEL_5G(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
+#define NAN_CTRL_SET_CHANNEL_5G(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
+#define NAN_CTRL_GET_MASTERPREFERENCE_VALUE(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 8)
+#define NAN_CTRL_SET_MASTERPREFERENCE_VALUE(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 8, value)
+#define NAN_CTRL_GET_RANDOMFACTOR_VALUE(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 8)
+#define NAN_CTRL_SET_RANDOMFACTOR_VALUE(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 8, value)
+#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_0(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
+#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_0(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
+#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_0(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
+#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_0(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
+#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_0(h2c_pkt)                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 16)
+#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_0(h2c_pkt, value)               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 16, value)
+#define NAN_CHANNEL_PLAN_0_GET_DURATION_0(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 16)
+#define NAN_CHANNEL_PLAN_0_SET_DURATION_0(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 16, value)
+#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_1(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 8)
+#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_1(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 8, value)
+#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_1(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 8, 8)
+#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_1(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 8, 8, value)
+#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_1(h2c_pkt)                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 16)
+#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_1(h2c_pkt, value)               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 16, value)
+#define NAN_CHANNEL_PLAN_0_GET_DURATION_1(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 16, 16)
+#define NAN_CHANNEL_PLAN_0_SET_DURATION_1(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 16, 16, value)
+#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_2(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 8)
+#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_2(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 8, value)
+#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_2(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 8, 8)
+#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_2(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 8, 8, value)
+#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_2(h2c_pkt)                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 16)
+#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_2(h2c_pkt, value)               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 16, value)
+#define NAN_CHANNEL_PLAN_0_GET_DURATION_2(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 16, 16)
+#define NAN_CHANNEL_PLAN_0_SET_DURATION_2(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 16, 16, value)
+#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_3(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
+#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_3(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
+#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_3(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
+#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_3(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
+#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_3(h2c_pkt)                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 16)
+#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_3(h2c_pkt, value)               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 16, value)
+#define NAN_CHANNEL_PLAN_1_GET_DURATION_3(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 16)
+#define NAN_CHANNEL_PLAN_1_SET_DURATION_3(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 16, value)
+#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_4(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 8)
+#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_4(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 8, value)
+#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_4(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 8, 8)
+#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_4(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 8, 8, value)
+#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_4(h2c_pkt)                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 16)
+#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_4(h2c_pkt, value)               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 16, value)
+#define NAN_CHANNEL_PLAN_1_GET_DURATION_4(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 16, 16)
+#define NAN_CHANNEL_PLAN_1_SET_DURATION_4(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 16, 16, value)
+#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_5(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 8)
+#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_5(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 8, value)
+#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_5(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 8, 8)
+#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_5(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 8, 8, value)
+#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_5(h2c_pkt)                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 16)
+#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_5(h2c_pkt, value)               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 16, value)
+#define NAN_CHANNEL_PLAN_1_GET_DURATION_5(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 16, 16)
+#define NAN_CHANNEL_PLAN_1_SET_DURATION_5(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 16, 16, value)
+#define FW_ACCESS_TEST_GET_ACCESS_TXFF(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_TXFF(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_RXFF(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_RXFF(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_FWFF(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_FWFF(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PHYFF(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PHYFF(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_RPT_BUF(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 4, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_RPT_BUF(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 4, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_CAM(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 5, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_CAM(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 5, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_WOW_CAM(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 6, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_WOW_CAM(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 6, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_RX_CAM(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 7, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_RX_CAM(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 7, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_BA_CAM(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_BA_CAM(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_MBSSID_CAM(h2c_pkt)                          \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 9, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_MBSSID_CAM(h2c_pkt, value)                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 9, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE0(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE0(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE1(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 17, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE1(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 17, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE2(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 18, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE2(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 18, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE3(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 19, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE3(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 19, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE4(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 20, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE4(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 20, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE5(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 21, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE5(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 21, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE6(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 22, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE6(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 22, 1, value)
+#define FW_ACCESS_TEST_GET_ACCESS_PAGE7(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 23, 1)
+#define FW_ACCESS_TEST_SET_ACCESS_PAGE7(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 23, 1, value)
+#define PHYDM_INFO_GET_REF_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
+#define PHYDM_INFO_SET_REF_TYPE(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
+#define PHYDM_INFO_GET_RF_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
+#define PHYDM_INFO_SET_RF_TYPE(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
+#define PHYDM_INFO_GET_CUT_VER(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define PHYDM_INFO_SET_CUT_VER(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define PHYDM_INFO_GET_RX_ANT_STATUS(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 4)
+#define PHYDM_INFO_SET_RX_ANT_STATUS(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 4, value)
+#define PHYDM_INFO_GET_TX_ANT_STATUS(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 28, 4)
+#define PHYDM_INFO_SET_TX_ANT_STATUS(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 28, 4, value)
+#define FW_SNDING_GET_SU0(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
+#define FW_SNDING_SET_SU0(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
+#define FW_SNDING_GET_SU1(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
+#define FW_SNDING_SET_SU1(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
+#define FW_SNDING_GET_MU(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
+#define FW_SNDING_SET_MU(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
+#define FW_SNDING_GET_PERIOD(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
+#define FW_SNDING_SET_PERIOD(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
+#define FW_SNDING_GET_NDPA0_HEAD_PG(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define FW_SNDING_SET_NDPA0_HEAD_PG(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define FW_SNDING_GET_NDPA1_HEAD_PG(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
+#define FW_SNDING_SET_NDPA1_HEAD_PG(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
+#define FW_SNDING_GET_MU_NDPA_HEAD_PG(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 0, 8)
+#define FW_SNDING_SET_MU_NDPA_HEAD_PG(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 0, 8, value)
+#define FW_SNDING_GET_RPT0_HEAD_PG(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 8, 8)
+#define FW_SNDING_SET_RPT0_HEAD_PG(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 8, 8, value)
+#define FW_SNDING_GET_RPT1_HEAD_PG(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 16, 8)
+#define FW_SNDING_SET_RPT1_HEAD_PG(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 16, 8, value)
+#define FW_SNDING_GET_RPT2_HEAD_PG(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 24, 8)
+#define FW_SNDING_SET_RPT2_HEAD_PG(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 24, 8, value)
+#define FW_FWCTRL_GET_SEQ_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
+#define FW_FWCTRL_SET_SEQ_NUM(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
+#define FW_FWCTRL_GET_MORE_CONTENT(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 1)
+#define FW_FWCTRL_SET_MORE_CONTENT(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 1, value)
+#define FW_FWCTRL_GET_CONTENT_IDX(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 9, 7)
+#define FW_FWCTRL_SET_CONTENT_IDX(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 9, 7, value)
+#define FW_FWCTRL_GET_CLASS_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
+#define FW_FWCTRL_SET_CLASS_ID(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
+#define FW_FWCTRL_GET_LENGTH(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
+#define FW_FWCTRL_SET_LENGTH(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
+#define FW_FWCTRL_GET_CONTENT(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 32)
+#define FW_FWCTRL_SET_CONTENT(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 32, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_gpio_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_gpio_cmd.h
new file mode 100644
index 000000000000..803458fc883e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_gpio_cmd.h
@@ -0,0 +1,84 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 HALMAC_GPIO_CMD
+#define HALMAC_GPIO_CMD
+
+#include "halmac_2_platform.h"
+
+/* GPIO ID */
+#define HALMAC_GPIO0		0
+#define HALMAC_GPIO1		1
+#define HALMAC_GPIO2		2
+#define HALMAC_GPIO3		3
+#define HALMAC_GPIO4		4
+#define HALMAC_GPIO5		5
+#define HALMAC_GPIO6		6
+#define HALMAC_GPIO7		7
+#define HALMAC_GPIO8		8
+#define HALMAC_GPIO9		9
+#define HALMAC_GPIO10		10
+#define HALMAC_GPIO11		11
+#define HALMAC_GPIO12		12
+#define HALMAC_GPIO13		13
+#define HALMAC_GPIO14		14
+#define HALMAC_GPIO15		15
+#define HALMAC_GPIO_NUM		16
+
+/* GPIO type */
+#define HALMAC_GPIO_IN		0
+#define HALMAC_GPIO_OUT		1
+#define HALMAC_GPIO_IN_OUT	2
+
+/* Function name */
+#define HALMAC_WL_HWPDN			0
+#define HALMAC_BT_HWPDN			1
+#define HALMAC_BT_GPIO			2
+#define HALMAC_WL_HW_EXTWOL		3
+#define HALMAC_BT_HW_EXTWOL		4
+#define HALMAC_BT_SFLASH		5
+#define HALMAC_WL_SFLASH		6
+#define HALMAC_WL_LED			7
+#define HALMAC_SDIO_INT			8
+#define HALMAC_UART0			9
+#define HALMAC_EEPROM			10
+#define HALMAC_JTAG			11
+#define HALMAC_LTE_COEX_UART		12
+#define HALMAC_3W_LTE_WL_GPIO		13
+#define HALMAC_GPIO2_3_WL_CTRL_EN	14
+#define HALMAC_GPIO13_14_WL_CTRL_EN	15
+#define HALMAC_DBG_GNT_WL_BT		16
+#define HALMAC_BT_3DDLS_A		17
+#define HALMAC_BT_3DDLS_B		18
+#define HALMAC_BT_PTA			19
+#define HALMAC_WL_PTA			20
+#define HALMAC_WL_UART			21
+#define HALMAC_WLMAC_DBG		22
+#define HALMAC_WLPHY_DBG		23
+#define HALMAC_BT_DBG			24
+#define HALMAC_WLPHY_RFE_CTRL2GPIO	25
+#define HALMAC_EXT_XTAL			26
+#define HALMAC_SW_IO			27
+
+struct halmac_gpio_pimux_list {
+	u16 func;
+	u8 id;
+	u8 type;
+	u16 offset;
+	u8 msk;
+	u8 value;
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_h2c_extra_info_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_h2c_extra_info_ap.h
new file mode 100644
index 000000000000..836298705657
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_h2c_extra_info_ap.h
@@ -0,0 +1,220 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_H2CEXTRAINFO_H2C_C2H_AP_H_
+#define _HAL_H2CEXTRAINFO_H2C_C2H_AP_H_
+#define PARAM_INFO_GET_LEN(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 8)
+#define PARAM_INFO_SET_LEN(extra_info, value)                                  \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 8, value)
+#define PARAM_INFO_SET_LEN_NO_CLR(extra_info, value)                           \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 8, value)
+#define PARAM_INFO_GET_IO_CMD(extra_info) GET_C2H_FIELD(extra_info + 0X00, 8, 7)
+#define PARAM_INFO_SET_IO_CMD(extra_info, value)                               \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 7, value)
+#define PARAM_INFO_SET_IO_CMD_NO_CLR(extra_info, value)                        \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 7, value)
+#define PARAM_INFO_GET_MSK_EN(extra_info)                                      \
+	GET_C2H_FIELD(extra_info + 0X00, 15, 1)
+#define PARAM_INFO_SET_MSK_EN(extra_info, value)                               \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 15, 1, value)
+#define PARAM_INFO_SET_MSK_EN_NO_CLR(extra_info, value)                        \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 15, 1, value)
+#define PARAM_INFO_GET_LLT_PG_BNDY(extra_info)                                 \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_LLT_PG_BNDY(extra_info, value)                          \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_SET_LLT_PG_BNDY_NO_CLR(extra_info, value)                   \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_EFUSE_RSVDPAGE_LOC(extra_info)                          \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC(extra_info, value)                   \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC_NO_CLR(extra_info, value)            \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_EFUSE_PATCH_EN(extra_info)                              \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_EFUSE_PATCH_EN(extra_info, value)                       \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_SET_EFUSE_PATCH_EN_NO_CLR(extra_info, value)                \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_RF_ADDR(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_RF_ADDR(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_SET_RF_ADDR_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_IO_ADDR(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 16)
+#define PARAM_INFO_SET_IO_ADDR(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
+#define PARAM_INFO_SET_IO_ADDR_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
+#define PARAM_INFO_GET_DELAY_VAL(extra_info)                                   \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 16)
+#define PARAM_INFO_SET_DELAY_VAL(extra_info, value)                            \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
+#define PARAM_INFO_SET_DELAY_VAL_NO_CLR(extra_info, value)                     \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
+#define PARAM_INFO_GET_RF_PATH(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 24, 8)
+#define PARAM_INFO_SET_RF_PATH(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 24, 8, value)
+#define PARAM_INFO_SET_RF_PATH_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 24, 8, value)
+#define PARAM_INFO_GET_DATA(extra_info) GET_C2H_FIELD(extra_info + 0X04, 0, 32)
+#define PARAM_INFO_SET_DATA(extra_info, value)                                 \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 32, value)
+#define PARAM_INFO_SET_DATA_NO_CLR(extra_info, value)                          \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 32, value)
+#define PARAM_INFO_GET_MASK(extra_info) GET_C2H_FIELD(extra_info + 0X08, 0, 32)
+#define PARAM_INFO_SET_MASK(extra_info, value)                                 \
+	SET_C2H_FIELD_CLR(extra_info + 0X08, 0, 32, value)
+#define PARAM_INFO_SET_MASK_NO_CLR(extra_info, value)                          \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X08, 0, 32, value)
+#define CH_INFO_GET_CH(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 8)
+#define CH_INFO_SET_CH(extra_info, value)                                      \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 8, value)
+#define CH_INFO_SET_CH_NO_CLR(extra_info, value)                               \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 8, value)
+#define CH_INFO_GET_PRI_CH_IDX(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 8, 4)
+#define CH_INFO_SET_PRI_CH_IDX(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 4, value)
+#define CH_INFO_SET_PRI_CH_IDX_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 4, value)
+#define CH_INFO_GET_BW(extra_info) GET_C2H_FIELD(extra_info + 0X00, 12, 4)
+#define CH_INFO_SET_BW(extra_info, value)                                      \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 12, 4, value)
+#define CH_INFO_SET_BW_NO_CLR(extra_info, value)                               \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 12, 4, value)
+#define CH_INFO_GET_TIMEOUT(extra_info) GET_C2H_FIELD(extra_info + 0X00, 16, 8)
+#define CH_INFO_SET_TIMEOUT(extra_info, value)                                 \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
+#define CH_INFO_SET_TIMEOUT_NO_CLR(extra_info, value)                          \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
+#define CH_INFO_GET_ACTION_ID(extra_info)                                      \
+	GET_C2H_FIELD(extra_info + 0X00, 24, 7)
+#define CH_INFO_SET_ACTION_ID(extra_info, value)                               \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 24, 7, value)
+#define CH_INFO_SET_ACTION_ID_NO_CLR(extra_info, value)                        \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 24, 7, value)
+#define CH_INFO_GET_EXTRA_INFO(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 31, 1)
+#define CH_INFO_SET_EXTRA_INFO(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 31, 1, value)
+#define CH_INFO_SET_EXTRA_INFO_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 31, 1, value)
+#define CH_EXTRA_INFO_GET_ID(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 7)
+#define CH_EXTRA_INFO_SET_ID(extra_info, value)                                \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 7, value)
+#define CH_EXTRA_INFO_SET_ID_NO_CLR(extra_info, value)                         \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 7, value)
+#define CH_EXTRA_INFO_GET_INFO(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 7, 1)
+#define CH_EXTRA_INFO_SET_INFO(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 7, 1, value)
+#define CH_EXTRA_INFO_SET_INFO_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 7, 1, value)
+#define CH_EXTRA_INFO_GET_SIZE(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 8, 8)
+#define CH_EXTRA_INFO_SET_SIZE(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 8, value)
+#define CH_EXTRA_INFO_SET_SIZE_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 8, value)
+#define CH_EXTRA_INFO_GET_DATA(extra_info)                                     \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 1)
+#define CH_EXTRA_INFO_SET_DATA(extra_info, value)                              \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 1, value)
+#define CH_EXTRA_INFO_SET_DATA_NO_CLR(extra_info, value)                       \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_L(extra_info)                       \
+	GET_C2H_FIELD(extra_info + 0X00, 0, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L(extra_info, value)                \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 16, value)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L_NO_CLR(extra_info, value)         \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_BITDATA(extra_info)                          \
+	GET_C2H_FIELD(extra_info + 0X00, 0, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BITDATA(extra_info, value)                   \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 16, value)
+#define HIOE_INSTRUCTION_INFO_SET_BITDATA_NO_CLR(extra_info, value)            \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_H(extra_info)                       \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H(extra_info, value)                \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H_NO_CLR(extra_info, value)         \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_BITMASK(extra_info)                          \
+	GET_C2H_FIELD(extra_info + 0X00, 16, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BITMASK(extra_info, value)                   \
+	SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
+#define HIOE_INSTRUCTION_INFO_SET_BITMASK_NO_CLR(extra_info, value)            \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_REG_ADDR(extra_info)                         \
+	GET_C2H_FIELD(extra_info + 0X04, 0, 22)
+#define HIOE_INSTRUCTION_INFO_SET_REG_ADDR(extra_info, value)                  \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 22, value)
+#define HIOE_INSTRUCTION_INFO_SET_REG_ADDR_NO_CLR(extra_info, value)           \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 22, value)
+#define HIOE_INSTRUCTION_INFO_GET_DELAY_VALUE(extra_info)                      \
+	GET_C2H_FIELD(extra_info + 0X04, 0, 22)
+#define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE(extra_info, value)               \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 22, value)
+#define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE_NO_CLR(extra_info, value)        \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 22, value)
+#define HIOE_INSTRUCTION_INFO_GET_MODE_SELECT(extra_info)                      \
+	GET_C2H_FIELD(extra_info + 0X04, 22, 1)
+#define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT(extra_info, value)               \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 22, 1, value)
+#define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT_NO_CLR(extra_info, value)        \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 22, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_IO_DELAY(extra_info)                         \
+	GET_C2H_FIELD(extra_info + 0X04, 23, 1)
+#define HIOE_INSTRUCTION_INFO_SET_IO_DELAY(extra_info, value)                  \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 23, 1, value)
+#define HIOE_INSTRUCTION_INFO_SET_IO_DELAY_NO_CLR(extra_info, value)           \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 23, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_BYTEMASK(extra_info)                         \
+	GET_C2H_FIELD(extra_info + 0X04, 24, 4)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEMASK(extra_info, value)                  \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 24, 4, value)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEMASK_NO_CLR(extra_info, value)           \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 24, 4, value)
+#define HIOE_INSTRUCTION_INFO_GET_RD_EN(extra_info)                            \
+	GET_C2H_FIELD(extra_info + 0X04, 28, 1)
+#define HIOE_INSTRUCTION_INFO_SET_RD_EN(extra_info, value)                     \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 28, 1, value)
+#define HIOE_INSTRUCTION_INFO_SET_RD_EN_NO_CLR(extra_info, value)              \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 28, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_WR_EN(extra_info)                            \
+	GET_C2H_FIELD(extra_info + 0X04, 29, 1)
+#define HIOE_INSTRUCTION_INFO_SET_WR_EN(extra_info, value)                     \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 29, 1, value)
+#define HIOE_INSTRUCTION_INFO_SET_WR_EN_NO_CLR(extra_info, value)              \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 29, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_RAW_R(extra_info)                            \
+	GET_C2H_FIELD(extra_info + 0X04, 30, 1)
+#define HIOE_INSTRUCTION_INFO_SET_RAW_R(extra_info, value)                     \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 30, 1, value)
+#define HIOE_INSTRUCTION_INFO_SET_RAW_R_NO_CLR(extra_info, value)              \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 30, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_RAW(extra_info)                              \
+	GET_C2H_FIELD(extra_info + 0X04, 31, 1)
+#define HIOE_INSTRUCTION_INFO_SET_RAW(extra_info, value)                       \
+	SET_C2H_FIELD_CLR(extra_info + 0X04, 31, 1, value)
+#define HIOE_INSTRUCTION_INFO_SET_RAW_NO_CLR(extra_info, value)                \
+	SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 31, 1, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_h2c_extra_info_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_h2c_extra_info_nic.h
new file mode 100644
index 000000000000..d48a683485ea
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_h2c_extra_info_nic.h
@@ -0,0 +1,171 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_H2CEXTRAINFO_H2C_C2H_NIC_H_
+#define _HAL_H2CEXTRAINFO_H2C_C2H_NIC_H_
+
+/* H2C extra info (rsvd page) usage, unit : page (128byte)*/
+/* dlfw : not include txdesc size*/
+/* update pkt : not include txdesc size*/
+/* cfg param : not include txdesc size*/
+/* scan info : not include txdesc size*/
+/* dl flash : not include txdesc size*/
+#define DLFW_RSVDPG_SIZE 2048
+#define UPDATE_PKT_RSVDPG_SIZE 2048
+#define CFG_PARAM_RSVDPG_SIZE 2048
+#define SCAN_INFO_RSVDPG_SIZE 256
+#define DL_FLASH_RSVDPG_SIZE 2048
+/* su0 snding pkt : include txdesc size */
+#define SU0_SNDING_PKT_OFFSET 0
+#define SU0_SNDING_PKT_RSVDPG_SIZE 128
+
+#define PARAM_INFO_GET_LEN(extra_info) LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 8)
+#define PARAM_INFO_SET_LEN(extra_info, value)                                  \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 8, value)
+#define PARAM_INFO_GET_IO_CMD(extra_info)                                      \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 8, 7)
+#define PARAM_INFO_SET_IO_CMD(extra_info, value)                               \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 8, 7, value)
+#define PARAM_INFO_GET_MSK_EN(extra_info)                                      \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 15, 1)
+#define PARAM_INFO_SET_MSK_EN(extra_info, value)                               \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 15, 1, value)
+#define PARAM_INFO_GET_LLT_PG_BNDY(extra_info)                                 \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_LLT_PG_BNDY(extra_info, value)                          \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_EFUSE_RSVDPAGE_LOC(extra_info)                          \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC(extra_info, value)                   \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_EFUSE_PATCH_EN(extra_info)                              \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_EFUSE_PATCH_EN(extra_info, value)                       \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_RF_ADDR(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
+#define PARAM_INFO_SET_RF_ADDR(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
+#define PARAM_INFO_GET_IO_ADDR(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
+#define PARAM_INFO_SET_IO_ADDR(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
+#define PARAM_INFO_GET_DELAY_VAL(extra_info)                                   \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
+#define PARAM_INFO_SET_DELAY_VAL(extra_info, value)                            \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
+#define PARAM_INFO_GET_RF_PATH(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 24, 8)
+#define PARAM_INFO_SET_RF_PATH(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 24, 8, value)
+#define PARAM_INFO_GET_DATA(extra_info)                                        \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 0, 32)
+#define PARAM_INFO_SET_DATA(extra_info, value)                                 \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 0, 32, value)
+#define PARAM_INFO_GET_MASK(extra_info)                                        \
+	LE_BITS_TO_4BYTE(extra_info + 0X08, 0, 32)
+#define PARAM_INFO_SET_MASK(extra_info, value)                                 \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X08, 0, 32, value)
+#define CH_INFO_GET_CH(extra_info) LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 8)
+#define CH_INFO_SET_CH(extra_info, value)                                      \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 8, value)
+#define CH_INFO_GET_PRI_CH_IDX(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 8, 4)
+#define CH_INFO_SET_PRI_CH_IDX(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 8, 4, value)
+#define CH_INFO_GET_BW(extra_info) LE_BITS_TO_4BYTE(extra_info + 0X00, 12, 4)
+#define CH_INFO_SET_BW(extra_info, value)                                      \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 12, 4, value)
+#define CH_INFO_GET_TIMEOUT(extra_info)                                        \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
+#define CH_INFO_SET_TIMEOUT(extra_info, value)                                 \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
+#define CH_INFO_GET_ACTION_ID(extra_info)                                      \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 24, 7)
+#define CH_INFO_SET_ACTION_ID(extra_info, value)                               \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 24, 7, value)
+#define CH_INFO_GET_EXTRA_INFO(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 31, 1)
+#define CH_INFO_SET_EXTRA_INFO(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 31, 1, value)
+#define CH_EXTRA_INFO_GET_ID(extra_info)                                       \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 7)
+#define CH_EXTRA_INFO_SET_ID(extra_info, value)                                \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 7, value)
+#define CH_EXTRA_INFO_GET_INFO(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 7, 1)
+#define CH_EXTRA_INFO_SET_INFO(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 7, 1, value)
+#define CH_EXTRA_INFO_GET_SIZE(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 8, 8)
+#define CH_EXTRA_INFO_SET_SIZE(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 8, 8, value)
+#define CH_EXTRA_INFO_GET_DATA(extra_info)                                     \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 1)
+#define CH_EXTRA_INFO_SET_DATA(extra_info, value)                              \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_L(extra_info)                       \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L(extra_info, value)                \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_BITDATA(extra_info)                          \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BITDATA(extra_info, value)                   \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_H(extra_info)                       \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H(extra_info, value)                \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_BITMASK(extra_info)                          \
+	LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
+#define HIOE_INSTRUCTION_INFO_SET_BITMASK(extra_info, value)                   \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
+#define HIOE_INSTRUCTION_INFO_GET_REG_ADDR(extra_info)                         \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 0, 22)
+#define HIOE_INSTRUCTION_INFO_SET_REG_ADDR(extra_info, value)                  \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 0, 22, value)
+#define HIOE_INSTRUCTION_INFO_GET_DELAY_VALUE(extra_info)                      \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 0, 22)
+#define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE(extra_info, value)               \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 0, 22, value)
+#define HIOE_INSTRUCTION_INFO_GET_MODE_SELECT(extra_info)                      \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 22, 1)
+#define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT(extra_info, value)               \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 22, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_IO_DELAY(extra_info)                         \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 23, 1)
+#define HIOE_INSTRUCTION_INFO_SET_IO_DELAY(extra_info, value)                  \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 23, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_BYTEMASK(extra_info)                         \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 24, 4)
+#define HIOE_INSTRUCTION_INFO_SET_BYTEMASK(extra_info, value)                  \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 24, 4, value)
+#define HIOE_INSTRUCTION_INFO_GET_RD_EN(extra_info)                            \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 28, 1)
+#define HIOE_INSTRUCTION_INFO_SET_RD_EN(extra_info, value)                     \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 28, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_WR_EN(extra_info)                            \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 29, 1)
+#define HIOE_INSTRUCTION_INFO_SET_WR_EN(extra_info, value)                     \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 29, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_RAW_R(extra_info)                            \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 30, 1)
+#define HIOE_INSTRUCTION_INFO_SET_RAW_R(extra_info, value)                     \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 30, 1, value)
+#define HIOE_INSTRUCTION_INFO_GET_RAW(extra_info)                              \
+	LE_BITS_TO_4BYTE(extra_info + 0X04, 31, 1)
+#define HIOE_INSTRUCTION_INFO_SET_RAW(extra_info, value)                       \
+	SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 31, 1, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_hw_cfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_hw_cfg.h
new file mode 100644
index 000000000000..8d64a830afb8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_hw_cfg.h
@@ -0,0 +1,170 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 __HALMAC__HW_CFG_H__
+#define __HALMAC__HW_CFG_H__
+
+#include <drv_conf.h>	/* CONFIG_[IC] */
+
+#ifdef CONFIG_RTL8723A
+#define HALMAC_8723A_SUPPORT	1
+#else
+#define HALMAC_8723A_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8188E
+#define HALMAC_8188E_SUPPORT	1
+#else
+#define HALMAC_8188E_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8821A
+#define HALMAC_8821A_SUPPORT	1
+#else
+#define HALMAC_8821A_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8723B
+#define HALMAC_8723B_SUPPORT	1
+#else
+#define HALMAC_8723B_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8812A
+#define HALMAC_8812A_SUPPORT	1
+#else
+#define HALMAC_8812A_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8192E
+#define HALMAC_8192E_SUPPORT	1
+#else
+#define HALMAC_8192E_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8881A
+#define HALMAC_8881A_SUPPORT	1
+#else
+#define HALMAC_8881A_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8821B
+#define HALMAC_8821B_SUPPORT	1
+#else
+#define HALMAC_8821B_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8814A
+#define HALMAC_8814A_SUPPORT	1
+#else
+#define HALMAC_8814A_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8881A
+#define HALMAC_8881A_SUPPORT	1
+#else
+#define HALMAC_8881A_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8703B
+#define HALMAC_8703B_SUPPORT	1
+#else
+#define HALMAC_8703B_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8723D
+#define HALMAC_8723D_SUPPORT	1
+#else
+#define HALMAC_8723D_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8188F
+#define HALMAC_8188F_SUPPORT	1
+#else
+#define HALMAC_8188F_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8821BMP
+#define HALMAC_8821BMP_SUPPORT	1
+#else
+#define HALMAC_8821BMP_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8814AMP
+#define HALMAC_8814AMP_SUPPORT	1
+#else
+#define HALMAC_8814AMP_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8195A
+#define HALMAC_8195A_SUPPORT	1
+#else
+#define HALMAC_8195A_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8821B
+#define HALMAC_8821B_SUPPORT	1
+#else
+#define HALMAC_8821B_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8196F
+#define HALMAC_8196F_SUPPORT	1
+#else
+#define HALMAC_8196F_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8197F
+#define HALMAC_8197F_SUPPORT	1
+#else
+#define HALMAC_8197F_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8198F
+#define HALMAC_8198F_SUPPORT	1
+#else
+#define HALMAC_8198F_SUPPORT	0
+#endif
+
+
+/* Halmac support IC version */
+
+#ifdef CONFIG_RTL8814B
+#define HALMAC_8814B_SUPPORT	1
+#else
+#define HALMAC_8814B_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8821C
+#define HALMAC_8821C_SUPPORT	1
+#else
+#define HALMAC_8821C_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8822B
+#define HALMAC_8822B_SUPPORT	1
+#else
+#define HALMAC_8822B_SUPPORT	0
+#endif
+
+#ifdef CONFIG_RTL8822C
+#define HALMAC_8822C_SUPPORT	1
+#else
+#define HALMAC_8822C_SUPPORT	0
+#endif
+
+#endif /* __HALMAC__HW_CFG_H__ */
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_intf_phy_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_intf_phy_cmd.h
new file mode 100644
index 000000000000..f44bfa11e4d9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_intf_phy_cmd.h
@@ -0,0 +1,45 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 HALMAC_INTF_PHY_CMD
+#define HALMAC_INTF_PHY_CMD
+
+/* Cut mask */
+enum halmac_intf_phy_cut {
+	HALMAC_INTF_PHY_CUT_TESTCHIP = BIT(0),
+	HALMAC_INTF_PHY_CUT_A = BIT(1),
+	HALMAC_INTF_PHY_CUT_B = BIT(2),
+	HALMAC_INTF_PHY_CUT_C = BIT(3),
+	HALMAC_INTF_PHY_CUT_D = BIT(4),
+	HALMAC_INTF_PHY_CUT_E = BIT(5),
+	HALMAC_INTF_PHY_CUT_F = BIT(6),
+	HALMAC_INTF_PHY_CUT_G = BIT(7),
+	HALMAC_INTF_PHY_CUT_ALL = 0x7FFF,
+};
+
+/* IP selection */
+enum halmac_ip_sel {
+	HALMAC_IP_INTF_PHY = 0,
+	HALMAC_IP_SEL_MAC = 1,
+	HALMAC_IP_PCIE_DBI = 2,
+	HALMAC_IP_SEL_UNDEFINE = 0x7FFF,
+};
+
+/* Platform mask */
+enum halmac_intf_phy_platform {
+	HALMAC_INTF_PHY_PLATFORM_ALL = 0x7FFF,
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_c2h_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_c2h_ap.h
new file mode 100644
index 000000000000..bb4bda13df0f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_c2h_ap.h
@@ -0,0 +1,612 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_ORIGINALC2HFORMAT_H2C_C2H_AP_H_
+#define _HAL_ORIGINALC2HFORMAT_H2C_C2H_AP_H_
+#define CMD_ID_C2H 0X00
+#define CMD_ID_DBG 0X00
+#define CMD_ID_C2H_LB 0X01
+#define CMD_ID_C2H_SND_TXBF 0X02
+#define CMD_ID_C2H_CCX_RPT 0X03
+#define CMD_ID_C2H_AP_REQ_TXRPT 0X04
+#define CMD_ID_C2H_INITIAL_RATE_COLLECTION 0X05
+#define CMD_ID_C2H_RA_RPT 0X0C
+#define CMD_ID_C2H_SPECIAL_STATISTICS 0X0D
+#define CMD_ID_C2H_RA_PARA_RPT 0X0E
+#define CMD_ID_C2H_CUR_CHANNEL 0X10
+#define CMD_ID_C2H_GPIO_WAKEUP 0X14
+#define C2H_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_SET_CMD_ID(c2h_pkt, value)                                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_SET_CMD_ID_NO_CLR(c2h_pkt, value)                                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_SET_SEQ(c2h_pkt, value)                                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_SET_SEQ_NO_CLR(c2h_pkt, value)                                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define DBG_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define DBG_SET_CMD_ID(c2h_pkt, value)                                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define DBG_SET_CMD_ID_NO_CLR(c2h_pkt, value)                                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define DBG_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define DBG_SET_SEQ(c2h_pkt, value)                                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define DBG_SET_SEQ_NO_CLR(c2h_pkt, value)                                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define DBG_GET_DBG_STR1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
+#define DBG_SET_DBG_STR1(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define DBG_SET_DBG_STR1_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define DBG_GET_DBG_STR2(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
+#define DBG_SET_DBG_STR2(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define DBG_SET_DBG_STR2_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define DBG_GET_DBG_STR3(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
+#define DBG_SET_DBG_STR3(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define DBG_SET_DBG_STR3_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define DBG_GET_DBG_STR4(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
+#define DBG_SET_DBG_STR4(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define DBG_SET_DBG_STR4_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define DBG_GET_DBG_STR5(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
+#define DBG_SET_DBG_STR5(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define DBG_SET_DBG_STR5_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define DBG_GET_DBG_STR6(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
+#define DBG_SET_DBG_STR6(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define DBG_SET_DBG_STR6_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define DBG_GET_DBG_STR7(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
+#define DBG_SET_DBG_STR7(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define DBG_SET_DBG_STR7_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define DBG_GET_DBG_STR8(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
+#define DBG_SET_DBG_STR8(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define DBG_SET_DBG_STR8_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define DBG_GET_DBG_STR9(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
+#define DBG_SET_DBG_STR9(c2h_pkt, value)                                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
+#define DBG_SET_DBG_STR9_NO_CLR(c2h_pkt, value)                                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
+#define DBG_GET_DBG_STR10(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 24, 8)
+#define DBG_SET_DBG_STR10(c2h_pkt, value)                                      \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 24, 8, value)
+#define DBG_SET_DBG_STR10_NO_CLR(c2h_pkt, value)                               \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 24, 8, value)
+#define DBG_GET_DBG_STR11(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 0, 8)
+#define DBG_SET_DBG_STR11(c2h_pkt, value)                                      \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 0, 8, value)
+#define DBG_SET_DBG_STR11_NO_CLR(c2h_pkt, value)                               \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 0, 8, value)
+#define DBG_GET_DBG_STR12(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 8, 8)
+#define DBG_SET_DBG_STR12(c2h_pkt, value)                                      \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 8, 8, value)
+#define DBG_SET_DBG_STR12_NO_CLR(c2h_pkt, value)                               \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 8, 8, value)
+#define DBG_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define DBG_SET_LEN(c2h_pkt, value)                                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define DBG_SET_LEN_NO_CLR(c2h_pkt, value)                                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define DBG_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define DBG_SET_TRIGGER(c2h_pkt, value)                                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define DBG_SET_TRIGGER_NO_CLR(c2h_pkt, value)                                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_LB_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_LB_SET_CMD_ID(c2h_pkt, value)                                      \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_LB_SET_CMD_ID_NO_CLR(c2h_pkt, value)                               \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_LB_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_LB_SET_SEQ(c2h_pkt, value)                                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_LB_SET_SEQ_NO_CLR(c2h_pkt, value)                                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_LB_GET_PAYLOAD1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 16)
+#define C2H_LB_SET_PAYLOAD1(c2h_pkt, value)                                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 16, value)
+#define C2H_LB_SET_PAYLOAD1_NO_CLR(c2h_pkt, value)                             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 16, value)
+#define C2H_LB_GET_PAYLOAD2(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 32)
+#define C2H_LB_SET_PAYLOAD2(c2h_pkt, value)                                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 32, value)
+#define C2H_LB_SET_PAYLOAD2_NO_CLR(c2h_pkt, value)                             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 32, value)
+#define C2H_LB_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_LB_SET_LEN(c2h_pkt, value)                                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_LB_SET_LEN_NO_CLR(c2h_pkt, value)                                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_LB_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_LB_SET_TRIGGER(c2h_pkt, value)                                     \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_LB_SET_TRIGGER_NO_CLR(c2h_pkt, value)                              \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_SND_TXBF_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_SND_TXBF_SET_CMD_ID(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_SND_TXBF_SET_CMD_ID_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_SND_TXBF_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_SND_TXBF_SET_SEQ(c2h_pkt, value)                                   \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_SND_TXBF_SET_SEQ_NO_CLR(c2h_pkt, value)                            \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_SND_TXBF_GET_SND_RESULT(c2h_pkt)                                   \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 16, 1)
+#define C2H_SND_TXBF_SET_SND_RESULT(c2h_pkt, value)                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 1, value)
+#define C2H_SND_TXBF_SET_SND_RESULT_NO_CLR(c2h_pkt, value)                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 1, value)
+#define C2H_SND_TXBF_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_SND_TXBF_SET_LEN(c2h_pkt, value)                                   \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_SND_TXBF_SET_LEN_NO_CLR(c2h_pkt, value)                            \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_SND_TXBF_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_SND_TXBF_SET_TRIGGER(c2h_pkt, value)                               \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_SND_TXBF_SET_TRIGGER_NO_CLR(c2h_pkt, value)                        \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_CCX_RPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_CCX_RPT_SET_CMD_ID(c2h_pkt, value)                                 \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_CCX_RPT_SET_CMD_ID_NO_CLR(c2h_pkt, value)                          \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_CCX_RPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_CCX_RPT_SET_SEQ(c2h_pkt, value)                                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_CCX_RPT_SET_SEQ_NO_CLR(c2h_pkt, value)                             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_CCX_RPT_GET_QSEL(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 5)
+#define C2H_CCX_RPT_SET_QSEL(c2h_pkt, value)                                   \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 5, value)
+#define C2H_CCX_RPT_SET_QSEL_NO_CLR(c2h_pkt, value)                            \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 5, value)
+#define C2H_CCX_RPT_GET_BMC(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 21, 1)
+#define C2H_CCX_RPT_SET_BMC(c2h_pkt, value)                                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 21, 1, value)
+#define C2H_CCX_RPT_SET_BMC_NO_CLR(c2h_pkt, value)                             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 21, 1, value)
+#define C2H_CCX_RPT_GET_LIFE_TIME_OVER(c2h_pkt)                                \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 22, 1)
+#define C2H_CCX_RPT_SET_LIFE_TIME_OVER(c2h_pkt, value)                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 22, 1, value)
+#define C2H_CCX_RPT_SET_LIFE_TIME_OVER_NO_CLR(c2h_pkt, value)                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 22, 1, value)
+#define C2H_CCX_RPT_GET_RETRY_OVER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 23, 1)
+#define C2H_CCX_RPT_SET_RETRY_OVER(c2h_pkt, value)                             \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 23, 1, value)
+#define C2H_CCX_RPT_SET_RETRY_OVER_NO_CLR(c2h_pkt, value)                      \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 23, 1, value)
+#define C2H_CCX_RPT_GET_MACID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
+#define C2H_CCX_RPT_SET_MACID(c2h_pkt, value)                                  \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_CCX_RPT_SET_MACID_NO_CLR(c2h_pkt, value)                           \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_CCX_RPT_GET_DATA_RETRY_CNT(c2h_pkt)                                \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 0, 6)
+#define C2H_CCX_RPT_SET_DATA_RETRY_CNT(c2h_pkt, value)                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 6, value)
+#define C2H_CCX_RPT_SET_DATA_RETRY_CNT_NO_CLR(c2h_pkt, value)                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 6, value)
+#define C2H_CCX_RPT_GET_QUEUE7_0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
+#define C2H_CCX_RPT_SET_QUEUE7_0(c2h_pkt, value)                               \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_CCX_RPT_SET_QUEUE7_0_NO_CLR(c2h_pkt, value)                        \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_CCX_RPT_GET_QUEUE15_8(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
+#define C2H_CCX_RPT_SET_QUEUE15_8(c2h_pkt, value)                              \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_CCX_RPT_SET_QUEUE15_8_NO_CLR(c2h_pkt, value)                       \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_CCX_RPT_GET_FINAL_DATA_RATE(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
+#define C2H_CCX_RPT_SET_FINAL_DATA_RATE(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_CCX_RPT_SET_FINAL_DATA_RATE_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_CCX_RPT_GET_SW_DEFINE_0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
+#define C2H_CCX_RPT_SET_SW_DEFINE_0(c2h_pkt, value)                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_CCX_RPT_SET_SW_DEFINE_0_NO_CLR(c2h_pkt, value)                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_CCX_RPT_GET_SW_DEFINE_1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 8, 4)
+#define C2H_CCX_RPT_SET_SW_DEFINE_1(c2h_pkt, value)                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 4, value)
+#define C2H_CCX_RPT_SET_SW_DEFINE_1_NO_CLR(c2h_pkt, value)                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 4, value)
+#define C2H_CCX_RPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_CCX_RPT_SET_LEN(c2h_pkt, value)                                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_CCX_RPT_SET_LEN_NO_CLR(c2h_pkt, value)                             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_CCX_RPT_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_CCX_RPT_SET_TRIGGER(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_CCX_RPT_SET_TRIGGER_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_CMD_ID(c2h_pkt, value)                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_CMD_ID_NO_CLR(c2h_pkt, value)                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_SEQ(c2h_pkt, value)                               \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_SEQ_NO_CLR(c2h_pkt, value)                        \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_STA1_MACID(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_STA1_MACID(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_STA1_MACID_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK1_0(c2h_pkt)                                 \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK1_0(c2h_pkt, value)                          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK1_0_NO_CLR(c2h_pkt, value)                   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK1_1(c2h_pkt)                                 \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK1_1(c2h_pkt, value)                          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK1_1_NO_CLR(c2h_pkt, value)                   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_0(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_0(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_0_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_1(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_1(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_1_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE1(c2h_pkt)                            \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE1(c2h_pkt, value)                     \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE1_NO_CLR(c2h_pkt, value)              \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_STA2_MACID(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_STA2_MACID(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_STA2_MACID_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK2_0(c2h_pkt)                                 \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK2_0(c2h_pkt, value)                          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK2_0_NO_CLR(c2h_pkt, value)                   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK2_1(c2h_pkt)                                 \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK2_1(c2h_pkt, value)                          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK2_1_NO_CLR(c2h_pkt, value)                   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_0(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_0(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_0_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_1(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_1(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_1_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE2(c2h_pkt)                            \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE2(c2h_pkt, value)                     \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE2_NO_CLR(c2h_pkt, value)              \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_LEN(c2h_pkt, value)                               \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_LEN_NO_CLR(c2h_pkt, value)                        \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TRIGGER(c2h_pkt)                                  \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_TRIGGER(c2h_pkt, value)                           \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_SET_TRIGGER_NO_CLR(c2h_pkt, value)                    \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_CMD_ID(c2h_pkt)                        \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_CMD_ID(c2h_pkt, value)                 \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_CMD_ID_NO_CLR(c2h_pkt, value)          \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_SEQ(c2h_pkt)                           \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_SEQ(c2h_pkt, value)                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_SEQ_NO_CLR(c2h_pkt, value)             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_TRYING_BITMAP(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 16, 7)
+#define C2H_INITIAL_RATE_COLLECTION_SET_TRYING_BITMAP(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 7, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_TRYING_BITMAP_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 7, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE1(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE1(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE1_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE2(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE2(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE2_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE3(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE3(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE3_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE4(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE4(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE4_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE5(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE5(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE5_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE6(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE6(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE6_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE7(c2h_pkt)                 \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE7(c2h_pkt, value)          \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE7_NO_CLR(c2h_pkt, value)   \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_LEN(c2h_pkt)                           \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_LEN(c2h_pkt, value)                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_LEN_NO_CLR(c2h_pkt, value)             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_TRIGGER(c2h_pkt)                       \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_TRIGGER(c2h_pkt, value)                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_SET_TRIGGER_NO_CLR(c2h_pkt, value)         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_RA_RPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_RA_RPT_SET_CMD_ID(c2h_pkt, value)                                  \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_RA_RPT_SET_CMD_ID_NO_CLR(c2h_pkt, value)                           \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_RA_RPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_RA_RPT_SET_SEQ(c2h_pkt, value)                                     \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_RA_RPT_SET_SEQ_NO_CLR(c2h_pkt, value)                              \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_RA_RPT_GET_RATE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
+#define C2H_RA_RPT_SET_RATE(c2h_pkt, value)                                    \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_RA_RPT_SET_RATE_NO_CLR(c2h_pkt, value)                             \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_RA_RPT_GET_MACID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
+#define C2H_RA_RPT_SET_MACID(c2h_pkt, value)                                   \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_RA_RPT_SET_MACID_NO_CLR(c2h_pkt, value)                            \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_RA_RPT_GET_USE_LDPC(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 1)
+#define C2H_RA_RPT_SET_USE_LDPC(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 1, value)
+#define C2H_RA_RPT_SET_USE_LDPC_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 1, value)
+#define C2H_RA_RPT_GET_USE_TXBF(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 1, 1)
+#define C2H_RA_RPT_SET_USE_TXBF(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 1, 1, value)
+#define C2H_RA_RPT_SET_USE_TXBF_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 1, 1, value)
+#define C2H_RA_RPT_GET_COLLISION_STATE(c2h_pkt)                                \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
+#define C2H_RA_RPT_SET_COLLISION_STATE(c2h_pkt, value)                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_RA_RPT_SET_COLLISION_STATE_NO_CLR(c2h_pkt, value)                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_RA_RPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_RA_RPT_SET_LEN(c2h_pkt, value)                                     \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_RA_RPT_SET_LEN_NO_CLR(c2h_pkt, value)                              \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_RA_RPT_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_RA_RPT_SET_TRIGGER(c2h_pkt, value)                                 \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_RA_RPT_SET_TRIGGER_NO_CLR(c2h_pkt, value)                          \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_CMD_ID(c2h_pkt)                             \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_SPECIAL_STATISTICS_SET_CMD_ID(c2h_pkt, value)                      \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_CMD_ID_NO_CLR(c2h_pkt, value)               \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_SEQ(c2h_pkt)                                \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_SPECIAL_STATISTICS_SET_SEQ(c2h_pkt, value)                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_SEQ_NO_CLR(c2h_pkt, value)                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_STATISTICS_IDX(c2h_pkt)                     \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_STATISTICS_IDX(c2h_pkt, value)              \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_STATISTICS_IDX_NO_CLR(c2h_pkt, value)       \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA0(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA0(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA0_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA1(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA1(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA1_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA2(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA2(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA2_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA3(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA3(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA3_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA4(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA4(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA4_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA5(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA5(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA5_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA6(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA6(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA6_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA7(c2h_pkt)                              \
+	GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA7(c2h_pkt, value)                       \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_DATA7_NO_CLR(c2h_pkt, value)                \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_LEN(c2h_pkt)                                \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_LEN(c2h_pkt, value)                         \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_LEN_NO_CLR(c2h_pkt, value)                  \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_TRIGGER(c2h_pkt)                            \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_SPECIAL_STATISTICS_SET_TRIGGER(c2h_pkt, value)                     \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_SET_TRIGGER_NO_CLR(c2h_pkt, value)              \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_RA_PARA_RPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_RA_PARA_RPT_SET_CMD_ID(c2h_pkt, value)                             \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_RA_PARA_RPT_SET_CMD_ID_NO_CLR(c2h_pkt, value)                      \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_RA_PARA_RPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_RA_PARA_RPT_SET_SEQ(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_RA_PARA_RPT_SET_SEQ_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_RA_PARA_RPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_RA_PARA_RPT_SET_LEN(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_RA_PARA_RPT_SET_LEN_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_RA_PARA_RPT_GET_TRIGGER(c2h_pkt)                                   \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_RA_PARA_RPT_SET_TRIGGER(c2h_pkt, value)                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_RA_PARA_RPT_SET_TRIGGER_NO_CLR(c2h_pkt, value)                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_CUR_CHANNEL_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_CUR_CHANNEL_SET_CMD_ID(c2h_pkt, value)                             \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_CUR_CHANNEL_SET_CMD_ID_NO_CLR(c2h_pkt, value)                      \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_CUR_CHANNEL_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_CUR_CHANNEL_SET_SEQ(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_CUR_CHANNEL_SET_SEQ_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_CUR_CHANNEL_GET_CHANNEL_NUM(c2h_pkt)                               \
+	GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
+#define C2H_CUR_CHANNEL_SET_CHANNEL_NUM(c2h_pkt, value)                        \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_CUR_CHANNEL_SET_CHANNEL_NUM_NO_CLR(c2h_pkt, value)                 \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_CUR_CHANNEL_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_CUR_CHANNEL_SET_LEN(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_CUR_CHANNEL_SET_LEN_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_CUR_CHANNEL_GET_TRIGGER(c2h_pkt)                                   \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_CUR_CHANNEL_SET_TRIGGER(c2h_pkt, value)                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_CUR_CHANNEL_SET_TRIGGER_NO_CLR(c2h_pkt, value)                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_GPIO_WAKEUP_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
+#define C2H_GPIO_WAKEUP_SET_CMD_ID(c2h_pkt, value)                             \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_GPIO_WAKEUP_SET_CMD_ID_NO_CLR(c2h_pkt, value)                      \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_GPIO_WAKEUP_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
+#define C2H_GPIO_WAKEUP_SET_SEQ(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_GPIO_WAKEUP_SET_SEQ_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_GPIO_WAKEUP_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
+#define C2H_GPIO_WAKEUP_SET_LEN(c2h_pkt, value)                                \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_GPIO_WAKEUP_SET_LEN_NO_CLR(c2h_pkt, value)                         \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_GPIO_WAKEUP_GET_TRIGGER(c2h_pkt)                                   \
+	GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
+#define C2H_GPIO_WAKEUP_SET_TRIGGER(c2h_pkt, value)                            \
+	SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_GPIO_WAKEUP_SET_TRIGGER_NO_CLR(c2h_pkt, value)                     \
+	SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_c2h_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_c2h_nic.h
new file mode 100644
index 000000000000..18cc2c7a09ba
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_c2h_nic.h
@@ -0,0 +1,408 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_ORIGINALC2HFORMAT_H2C_C2H_NIC_H_
+#define _HAL_ORIGINALC2HFORMAT_H2C_C2H_NIC_H_
+#define CMD_ID_C2H 0X00
+#define CMD_ID_DBG 0X00
+#define CMD_ID_C2H_LB 0X01
+#define CMD_ID_C2H_SND_TXBF 0X02
+#define CMD_ID_C2H_CCX_RPT 0X03
+#define CMD_ID_C2H_AP_REQ_TXRPT 0X04
+#define CMD_ID_C2H_INITIAL_RATE_COLLECTION 0X05
+#define CMD_ID_C2H_RA_RPT 0X0C
+#define CMD_ID_C2H_SPECIAL_STATISTICS 0X0D
+#define CMD_ID_C2H_RA_PARA_RPT 0X0E
+#define CMD_ID_C2H_CUR_CHANNEL 0X10
+#define CMD_ID_C2H_GPIO_WAKEUP 0X14
+#define C2H_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_SET_CMD_ID(c2h_pkt, value)                                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_SET_SEQ(c2h_pkt, value)                                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define DBG_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define DBG_SET_CMD_ID(c2h_pkt, value)                                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define DBG_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define DBG_SET_SEQ(c2h_pkt, value)                                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define DBG_GET_DBG_STR1(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
+#define DBG_SET_DBG_STR1(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
+#define DBG_GET_DBG_STR2(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
+#define DBG_SET_DBG_STR2(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
+#define DBG_GET_DBG_STR3(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
+#define DBG_SET_DBG_STR3(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
+#define DBG_GET_DBG_STR4(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
+#define DBG_SET_DBG_STR4(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
+#define DBG_GET_DBG_STR5(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
+#define DBG_SET_DBG_STR5(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
+#define DBG_GET_DBG_STR6(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
+#define DBG_SET_DBG_STR6(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
+#define DBG_GET_DBG_STR7(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
+#define DBG_SET_DBG_STR7(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
+#define DBG_GET_DBG_STR8(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
+#define DBG_SET_DBG_STR8(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
+#define DBG_GET_DBG_STR9(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
+#define DBG_SET_DBG_STR9(c2h_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
+#define DBG_GET_DBG_STR10(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 24, 8)
+#define DBG_SET_DBG_STR10(c2h_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 24, 8, value)
+#define DBG_GET_DBG_STR11(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 0, 8)
+#define DBG_SET_DBG_STR11(c2h_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 0, 8, value)
+#define DBG_GET_DBG_STR12(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 8, 8)
+#define DBG_SET_DBG_STR12(c2h_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 8, 8, value)
+#define DBG_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define DBG_SET_LEN(c2h_pkt, value)                                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define DBG_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define DBG_SET_TRIGGER(c2h_pkt, value)                                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_LB_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_LB_SET_CMD_ID(c2h_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_LB_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_LB_SET_SEQ(c2h_pkt, value)                                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_LB_GET_PAYLOAD1(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 16)
+#define C2H_LB_SET_PAYLOAD1(c2h_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 16, value)
+#define C2H_LB_GET_PAYLOAD2(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 32)
+#define C2H_LB_SET_PAYLOAD2(c2h_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 32, value)
+#define C2H_LB_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_LB_SET_LEN(c2h_pkt, value)                                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_LB_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_LB_SET_TRIGGER(c2h_pkt, value)                                     \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_SND_TXBF_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_SND_TXBF_SET_CMD_ID(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_SND_TXBF_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_SND_TXBF_SET_SEQ(c2h_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_SND_TXBF_GET_SND_RESULT(c2h_pkt)                                   \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 1)
+#define C2H_SND_TXBF_SET_SND_RESULT(c2h_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 1, value)
+#define C2H_SND_TXBF_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_SND_TXBF_SET_LEN(c2h_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_SND_TXBF_GET_TRIGGER(c2h_pkt)                                      \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_SND_TXBF_SET_TRIGGER(c2h_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_CCX_RPT_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_CCX_RPT_SET_CMD_ID(c2h_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_CCX_RPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_CCX_RPT_SET_SEQ(c2h_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_CCX_RPT_GET_QSEL(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 5)
+#define C2H_CCX_RPT_SET_QSEL(c2h_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 5, value)
+#define C2H_CCX_RPT_GET_BMC(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 21, 1)
+#define C2H_CCX_RPT_SET_BMC(c2h_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 21, 1, value)
+#define C2H_CCX_RPT_GET_LIFE_TIME_OVER(c2h_pkt)                                \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 22, 1)
+#define C2H_CCX_RPT_SET_LIFE_TIME_OVER(c2h_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 22, 1, value)
+#define C2H_CCX_RPT_GET_RETRY_OVER(c2h_pkt)                                    \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 23, 1)
+#define C2H_CCX_RPT_SET_RETRY_OVER(c2h_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 23, 1, value)
+#define C2H_CCX_RPT_GET_MACID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
+#define C2H_CCX_RPT_SET_MACID(c2h_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_CCX_RPT_GET_DATA_RETRY_CNT(c2h_pkt)                                \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 6)
+#define C2H_CCX_RPT_SET_DATA_RETRY_CNT(c2h_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 6, value)
+#define C2H_CCX_RPT_GET_QUEUE7_0(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
+#define C2H_CCX_RPT_SET_QUEUE7_0(c2h_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_CCX_RPT_GET_QUEUE15_8(c2h_pkt)                                     \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
+#define C2H_CCX_RPT_SET_QUEUE15_8(c2h_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_CCX_RPT_GET_FINAL_DATA_RATE(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
+#define C2H_CCX_RPT_SET_FINAL_DATA_RATE(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_CCX_RPT_GET_SW_DEFINE_0(c2h_pkt)                                   \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
+#define C2H_CCX_RPT_SET_SW_DEFINE_0(c2h_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_CCX_RPT_GET_SW_DEFINE_1(c2h_pkt)                                   \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 4)
+#define C2H_CCX_RPT_SET_SW_DEFINE_1(c2h_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 4, value)
+#define C2H_CCX_RPT_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_CCX_RPT_SET_LEN(c2h_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_CCX_RPT_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_CCX_RPT_SET_TRIGGER(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_CMD_ID(c2h_pkt)                                   \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_CMD_ID(c2h_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_SEQ(c2h_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_STA1_MACID(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_STA1_MACID(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK1_0(c2h_pkt)                                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK1_0(c2h_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK1_1(c2h_pkt)                                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK1_1(c2h_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_0(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_0(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_1(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_1(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE1(c2h_pkt)                            \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE1(c2h_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_STA2_MACID(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_STA2_MACID(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK2_0(c2h_pkt)                                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK2_0(c2h_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_OK2_1(c2h_pkt)                                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_OK2_1(c2h_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_0(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_0(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 24, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_1(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 0, 8)
+#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_1(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 0, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE2(c2h_pkt)                            \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 8, 8)
+#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE2(c2h_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 8, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_LEN(c2h_pkt)                                      \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_AP_REQ_TXRPT_SET_LEN(c2h_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_AP_REQ_TXRPT_GET_TRIGGER(c2h_pkt)                                  \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_AP_REQ_TXRPT_SET_TRIGGER(c2h_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_CMD_ID(c2h_pkt)                        \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_CMD_ID(c2h_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_SEQ(c2h_pkt)                           \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_SEQ(c2h_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_TRYING_BITMAP(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 7)
+#define C2H_INITIAL_RATE_COLLECTION_SET_TRYING_BITMAP(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 7, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE1(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE1(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE2(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE2(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE3(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE3(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE4(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE4(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE5(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE5(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE6(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE6(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE7(c2h_pkt)                 \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE7(c2h_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_LEN(c2h_pkt)                           \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_LEN(c2h_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_INITIAL_RATE_COLLECTION_GET_TRIGGER(c2h_pkt)                       \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_INITIAL_RATE_COLLECTION_SET_TRIGGER(c2h_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_RA_RPT_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_RA_RPT_SET_CMD_ID(c2h_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_RA_RPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_RA_RPT_SET_SEQ(c2h_pkt, value)                                     \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_RA_RPT_GET_RATE(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
+#define C2H_RA_RPT_SET_RATE(c2h_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_RA_RPT_GET_MACID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
+#define C2H_RA_RPT_SET_MACID(c2h_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_RA_RPT_GET_USE_LDPC(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 1)
+#define C2H_RA_RPT_SET_USE_LDPC(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 1, value)
+#define C2H_RA_RPT_GET_USE_TXBF(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 1, 1)
+#define C2H_RA_RPT_SET_USE_TXBF(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 1, 1, value)
+#define C2H_RA_RPT_GET_COLLISION_STATE(c2h_pkt)                                \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
+#define C2H_RA_RPT_SET_COLLISION_STATE(c2h_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_RA_RPT_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_RA_RPT_SET_LEN(c2h_pkt, value)                                     \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_RA_RPT_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_RA_RPT_SET_TRIGGER(c2h_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_CMD_ID(c2h_pkt)                             \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_SPECIAL_STATISTICS_SET_CMD_ID(c2h_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_SEQ(c2h_pkt)                                \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_SPECIAL_STATISTICS_SET_SEQ(c2h_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_STATISTICS_IDX(c2h_pkt)                     \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_STATISTICS_IDX(c2h_pkt, value)              \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA0(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA0(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA1(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA1(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA2(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA2(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA3(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA3(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA4(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA4(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA5(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA5(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA6(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA6(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_DATA7(c2h_pkt)                              \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_DATA7(c2h_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_LEN(c2h_pkt)                                \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_SPECIAL_STATISTICS_SET_LEN(c2h_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_SPECIAL_STATISTICS_GET_TRIGGER(c2h_pkt)                            \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_SPECIAL_STATISTICS_SET_TRIGGER(c2h_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_RA_PARA_RPT_GET_CMD_ID(c2h_pkt)                                    \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_RA_PARA_RPT_SET_CMD_ID(c2h_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_RA_PARA_RPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_RA_PARA_RPT_SET_SEQ(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_RA_PARA_RPT_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_RA_PARA_RPT_SET_LEN(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_RA_PARA_RPT_GET_TRIGGER(c2h_pkt)                                   \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_RA_PARA_RPT_SET_TRIGGER(c2h_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_CUR_CHANNEL_GET_CMD_ID(c2h_pkt)                                    \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_CUR_CHANNEL_SET_CMD_ID(c2h_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_CUR_CHANNEL_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_CUR_CHANNEL_SET_SEQ(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_CUR_CHANNEL_GET_CHANNEL_NUM(c2h_pkt)                               \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
+#define C2H_CUR_CHANNEL_SET_CHANNEL_NUM(c2h_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
+#define C2H_CUR_CHANNEL_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_CUR_CHANNEL_SET_LEN(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_CUR_CHANNEL_GET_TRIGGER(c2h_pkt)                                   \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_CUR_CHANNEL_SET_TRIGGER(c2h_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#define C2H_GPIO_WAKEUP_GET_CMD_ID(c2h_pkt)                                    \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
+#define C2H_GPIO_WAKEUP_SET_CMD_ID(c2h_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
+#define C2H_GPIO_WAKEUP_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
+#define C2H_GPIO_WAKEUP_SET_SEQ(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
+#define C2H_GPIO_WAKEUP_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
+#define C2H_GPIO_WAKEUP_SET_LEN(c2h_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
+#define C2H_GPIO_WAKEUP_GET_TRIGGER(c2h_pkt)                                   \
+	LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
+#define C2H_GPIO_WAKEUP_SET_TRIGGER(c2h_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_h2c_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_h2c_ap.h
new file mode 100644
index 000000000000..b28c9959d9c3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_h2c_ap.h
@@ -0,0 +1,1661 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_ORIGINALH2CFORMAT_H2C_C2H_AP_H_
+#define _HAL_ORIGINALH2CFORMAT_H2C_C2H_AP_H_
+#define CMD_ID_ORIGINAL_H2C 0X00
+#define CMD_ID_H2C2H_LB 0X0
+#define CMD_ID_D0_SCAN_OFFLOAD_CTRL 0X06
+#define CMD_ID_RSVD_PAGE 0X0
+#define CMD_ID_MEDIA_STATUS_RPT 0X01
+#define CMD_ID_KEEP_ALIVE 0X03
+#define CMD_ID_DISCONNECT_DECISION 0X04
+#define CMD_ID_AP_OFFLOAD 0X08
+#define CMD_ID_BCN_RSVDPAGE 0X09
+#define CMD_ID_PROBE_RSP_RSVDPAGE 0X0A
+#define CMD_ID_SINGLE_CHANNELSWITCH 0X1C
+#define CMD_ID_SINGLE_CHANNELSWITCH_V2 0X1D
+#define CMD_ID_SET_PWR_MODE 0X00
+#define CMD_ID_PS_TUNING_PARA 0X01
+#define CMD_ID_PS_TUNING_PARA_II 0X02
+#define CMD_ID_PS_LPS_PARA 0X03
+#define CMD_ID_P2P_PS_OFFLOAD 0X04
+#define CMD_ID_PS_SCAN_EN 0X05
+#define CMD_ID_SAP_PS 0X06
+#define CMD_ID_INACTIVE_PS 0X07
+#define CMD_ID_MACID_CFG 0X00
+#define CMD_ID_TXBF 0X01
+#define CMD_ID_RSSI_SETTING 0X02
+#define CMD_ID_AP_REQ_TXRPT 0X03
+#define CMD_ID_INIT_RATE_COLLECTION 0X04
+#define CMD_ID_IQK_OFFLOAD 0X05
+#define CMD_ID_MACID_CFG_3SS 0X06
+#define CMD_ID_RA_PARA_ADJUST 0X07
+#define CMD_ID_WWLAN 0X00
+#define CMD_ID_REMOTE_WAKE_CTRL 0X01
+#define CMD_ID_AOAC_GLOBAL_INFO 0X02
+#define CMD_ID_AOAC_RSVD_PAGE 0X03
+#define CMD_ID_AOAC_RSVD_PAGE2 0X04
+#define CMD_ID_D0_SCAN_OFFLOAD_INFO 0X05
+#define CMD_ID_CHANNEL_SWITCH_OFFLOAD 0X07
+#define CMD_ID_AOAC_RSVD_PAGE3 0X08
+#define CMD_ID_DBG_MSG_CTRL 0X1E
+#define CLASS_ORIGINAL_H2C 0X00
+#define CLASS_H2C2H_LB 0X07
+#define CLASS_D0_SCAN_OFFLOAD_CTRL 0X04
+#define CLASS_RSVD_PAGE 0X0
+#define CLASS_MEDIA_STATUS_RPT 0X0
+#define CLASS_KEEP_ALIVE 0X0
+#define CLASS_DISCONNECT_DECISION 0X0
+#define CLASS_AP_OFFLOAD 0X0
+#define CLASS_BCN_RSVDPAGE 0X0
+#define CLASS_PROBE_RSP_RSVDPAGE 0X0
+#define CLASS_SINGLE_CHANNELSWITCH 0X0
+#define CLASS_SINGLE_CHANNELSWITCH_V2 0X0
+#define CLASS_SET_PWR_MODE 0X01
+#define CLASS_PS_TUNING_PARA 0X01
+#define CLASS_PS_TUNING_PARA_II 0X01
+#define CLASS_PS_LPS_PARA 0X01
+#define CLASS_P2P_PS_OFFLOAD 0X01
+#define CLASS_PS_SCAN_EN 0X1
+#define CLASS_SAP_PS 0X1
+#define CLASS_INACTIVE_PS 0X1
+#define CLASS_MACID_CFG 0X2
+#define CLASS_TXBF 0X2
+#define CLASS_RSSI_SETTING 0X2
+#define CLASS_AP_REQ_TXRPT 0X2
+#define CLASS_INIT_RATE_COLLECTION 0X2
+#define CLASS_IQK_OFFLOAD 0X2
+#define CLASS_MACID_CFG_3SS 0X2
+#define CLASS_RA_PARA_ADJUST 0X02
+#define CLASS_WWLAN 0X4
+#define CLASS_REMOTE_WAKE_CTRL 0X4
+#define CLASS_AOAC_GLOBAL_INFO 0X04
+#define CLASS_AOAC_RSVD_PAGE 0X04
+#define CLASS_AOAC_RSVD_PAGE2 0X04
+#define CLASS_D0_SCAN_OFFLOAD_INFO 0X04
+#define CLASS_CHANNEL_SWITCH_OFFLOAD 0X04
+#define CLASS_AOAC_RSVD_PAGE3 0X04
+#define CLASS_DBG_MSG_CTRL 0X07
+#define ORIGINAL_H2C_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define ORIGINAL_H2C_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define ORIGINAL_H2C_SET_CMD_ID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define ORIGINAL_H2C_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define ORIGINAL_H2C_SET_CLASS(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define ORIGINAL_H2C_SET_CLASS_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define H2C2H_LB_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define H2C2H_LB_SET_CMD_ID(h2c_pkt, value)                                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define H2C2H_LB_SET_CMD_ID_NO_CLR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define H2C2H_LB_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define H2C2H_LB_SET_CLASS(h2c_pkt, value)                                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define H2C2H_LB_SET_CLASS_NO_CLR(h2c_pkt, value)                              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define H2C2H_LB_GET_SEQ(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define H2C2H_LB_SET_SEQ(h2c_pkt, value)                                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define H2C2H_LB_SET_SEQ_NO_CLR(h2c_pkt, value)                                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define H2C2H_LB_GET_PAYLOAD1(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 16)
+#define H2C2H_LB_SET_PAYLOAD1(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 16, value)
+#define H2C2H_LB_SET_PAYLOAD1_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 16, value)
+#define H2C2H_LB_GET_PAYLOAD2(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 32)
+#define H2C2H_LB_SET_PAYLOAD2(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 32, value)
+#define H2C2H_LB_SET_PAYLOAD2_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 32, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_CMD_ID(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define D0_SCAN_OFFLOAD_CTRL_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_CMD_ID_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_CLASS(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define D0_SCAN_OFFLOAD_CTRL_SET_CLASS(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_CLASS_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_D0_SCAN_FUN_EN(h2c_pkt)                       \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_D0_SCAN_FUN_EN(h2c_pkt, value)                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_D0_SCAN_FUN_EN_NO_CLR(h2c_pkt, value)         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_RTD3FUN_EN(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_RTD3FUN_EN(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_RTD3FUN_EN_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_U3_SCAN_FUN_EN(h2c_pkt)                       \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_U3_SCAN_FUN_EN(h2c_pkt, value)                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_U3_SCAN_FUN_EN_NO_CLR(h2c_pkt, value)         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_NLO_FUN_EN(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_NLO_FUN_EN(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_NLO_FUN_EN_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_IPS_DEPENDENT(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_IPS_DEPENDENT(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_IPS_DEPENDENT_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_PROBE_PACKET(h2c_pkt)                     \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 17)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_PROBE_PACKET(h2c_pkt, value)              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 17, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_PROBE_PACKET_NO_CLR(h2c_pkt, value)       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 17, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SCAN_INFO(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SCAN_INFO(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SCAN_INFO_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SSID_INFO(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SSID_INFO(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SSID_INFO_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define RSVD_PAGE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define RSVD_PAGE_SET_CMD_ID(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define RSVD_PAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define RSVD_PAGE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define RSVD_PAGE_SET_CLASS(h2c_pkt, value)                                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define RSVD_PAGE_SET_CLASS_NO_CLR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define RSVD_PAGE_GET_LOC_PROBE_RSP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define RSVD_PAGE_SET_LOC_PROBE_RSP(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define RSVD_PAGE_SET_LOC_PROBE_RSP_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define RSVD_PAGE_GET_LOC_PS_POLL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define RSVD_PAGE_SET_LOC_PS_POLL(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define RSVD_PAGE_SET_LOC_PS_POLL_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define RSVD_PAGE_GET_LOC_NULL_DATA(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define RSVD_PAGE_SET_LOC_NULL_DATA(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define RSVD_PAGE_SET_LOC_NULL_DATA_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define RSVD_PAGE_GET_LOC_QOS_NULL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define RSVD_PAGE_SET_LOC_QOS_NULL(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define RSVD_PAGE_SET_LOC_QOS_NULL_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define RSVD_PAGE_GET_LOC_BT_QOS_NULL(h2c_pkt)                                 \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define RSVD_PAGE_SET_LOC_BT_QOS_NULL(h2c_pkt, value)                          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define RSVD_PAGE_SET_LOC_BT_QOS_NULL_NO_CLR(h2c_pkt, value)                   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define RSVD_PAGE_GET_LOC_CTS2SELF(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
+#define RSVD_PAGE_SET_LOC_CTS2SELF(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define RSVD_PAGE_SET_LOC_CTS2SELF_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define RSVD_PAGE_GET_LOC_LTECOEX_QOSNULL(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
+#define RSVD_PAGE_SET_LOC_LTECOEX_QOSNULL(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define RSVD_PAGE_SET_LOC_LTECOEX_QOSNULL_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define MEDIA_STATUS_RPT_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define MEDIA_STATUS_RPT_SET_CMD_ID(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define MEDIA_STATUS_RPT_SET_CMD_ID_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define MEDIA_STATUS_RPT_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define MEDIA_STATUS_RPT_SET_CLASS(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define MEDIA_STATUS_RPT_SET_CLASS_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define MEDIA_STATUS_RPT_GET_OP_MODE(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define MEDIA_STATUS_RPT_SET_OP_MODE(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define MEDIA_STATUS_RPT_SET_OP_MODE_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define MEDIA_STATUS_RPT_GET_MACID_IN(h2c_pkt)                                 \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define MEDIA_STATUS_RPT_SET_MACID_IN(h2c_pkt, value)                          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define MEDIA_STATUS_RPT_SET_MACID_IN_NO_CLR(h2c_pkt, value)                   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define MEDIA_STATUS_RPT_GET_MACID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define MEDIA_STATUS_RPT_SET_MACID(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define MEDIA_STATUS_RPT_SET_MACID_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define MEDIA_STATUS_RPT_GET_MACID_END(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define MEDIA_STATUS_RPT_SET_MACID_END(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define MEDIA_STATUS_RPT_SET_MACID_END_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define KEEP_ALIVE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define KEEP_ALIVE_SET_CMD_ID(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define KEEP_ALIVE_SET_CMD_ID_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define KEEP_ALIVE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define KEEP_ALIVE_SET_CLASS(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define KEEP_ALIVE_SET_CLASS_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define KEEP_ALIVE_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define KEEP_ALIVE_SET_ENABLE(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define KEEP_ALIVE_SET_ENABLE_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define KEEP_ALIVE_GET_ADOPT_USER_SETTING(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define KEEP_ALIVE_SET_ADOPT_USER_SETTING(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define KEEP_ALIVE_SET_ADOPT_USER_SETTING_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define KEEP_ALIVE_GET_PKT_TYPE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define KEEP_ALIVE_SET_PKT_TYPE(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define KEEP_ALIVE_SET_PKT_TYPE_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define KEEP_ALIVE_GET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define KEEP_ALIVE_SET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define KEEP_ALIVE_SET_KEEP_ALIVE_CHECK_PERIOD_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define DISCONNECT_DECISION_GET_CMD_ID(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define DISCONNECT_DECISION_SET_CMD_ID(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define DISCONNECT_DECISION_SET_CMD_ID_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define DISCONNECT_DECISION_GET_CLASS(h2c_pkt)                                 \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define DISCONNECT_DECISION_SET_CLASS(h2c_pkt, value)                          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define DISCONNECT_DECISION_SET_CLASS_NO_CLR(h2c_pkt, value)                   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define DISCONNECT_DECISION_GET_ENABLE(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define DISCONNECT_DECISION_SET_ENABLE(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define DISCONNECT_DECISION_SET_ENABLE_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define DISCONNECT_DECISION_GET_ADOPT_USER_SETTING(h2c_pkt)                    \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define DISCONNECT_DECISION_SET_ADOPT_USER_SETTING(h2c_pkt, value)             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define DISCONNECT_DECISION_SET_ADOPT_USER_SETTING_NO_CLR(h2c_pkt, value)      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt)              \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt, value)       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_EN_NO_CLR(h2c_pkt,       \
+								value)         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define DISCONNECT_DECISION_GET_DISCONNECT_EN(h2c_pkt)                         \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
+#define DISCONNECT_DECISION_SET_DISCONNECT_EN(h2c_pkt, value)                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define DISCONNECT_DECISION_SET_DISCONNECT_EN_NO_CLR(h2c_pkt, value)           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define DISCONNECT_DECISION_GET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt)          \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define DISCONNECT_DECISION_SET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt, value)   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define DISCONNECT_DECISION_SET_DISCON_DECISION_CHECK_PERIOD_NO_CLR(h2c_pkt,   \
+								    value)     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define DISCONNECT_DECISION_GET_TRY_PKT_NUM(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define DISCONNECT_DECISION_SET_TRY_PKT_NUM(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define DISCONNECT_DECISION_SET_TRY_PKT_NUM_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt)           \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt, value)    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_LIMIT_NO_CLR(h2c_pkt,    \
+								   value)      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AP_OFFLOAD_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define AP_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AP_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AP_OFFLOAD_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define AP_OFFLOAD_SET_CLASS(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AP_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AP_OFFLOAD_GET_ON(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define AP_OFFLOAD_SET_ON(h2c_pkt, value)                                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define AP_OFFLOAD_SET_ON_NO_CLR(h2c_pkt, value)                               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define AP_OFFLOAD_GET_CFG_MIFI_PLATFORM(h2c_pkt)                              \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define AP_OFFLOAD_SET_CFG_MIFI_PLATFORM(h2c_pkt, value)                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define AP_OFFLOAD_SET_CFG_MIFI_PLATFORM_NO_CLR(h2c_pkt, value)                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define AP_OFFLOAD_GET_LINKED(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define AP_OFFLOAD_SET_LINKED(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define AP_OFFLOAD_SET_LINKED_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define AP_OFFLOAD_GET_EN_AUTO_WAKE(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
+#define AP_OFFLOAD_SET_EN_AUTO_WAKE(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define AP_OFFLOAD_SET_EN_AUTO_WAKE_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define AP_OFFLOAD_GET_WAKE_FLAG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
+#define AP_OFFLOAD_SET_WAKE_FLAG(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define AP_OFFLOAD_SET_WAKE_FLAG_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_ROOT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 1)
+#define AP_OFFLOAD_SET_HIDDEN_ROOT(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 1, value)
+#define AP_OFFLOAD_SET_HIDDEN_ROOT_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP1(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 17, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP1(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 17, 1, value)
+#define AP_OFFLOAD_SET_HIDDEN_VAP1_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 17, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP2(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 18, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP2(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 18, 1, value)
+#define AP_OFFLOAD_SET_HIDDEN_VAP2_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 18, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP3(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 19, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP3(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 19, 1, value)
+#define AP_OFFLOAD_SET_HIDDEN_VAP3_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 19, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP4(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 20, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP4(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 20, 1, value)
+#define AP_OFFLOAD_SET_HIDDEN_VAP4_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 20, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_ROOT(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 1)
+#define AP_OFFLOAD_SET_DENYANY_ROOT(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 1, value)
+#define AP_OFFLOAD_SET_DENYANY_ROOT_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP1(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 25, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP1(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 25, 1, value)
+#define AP_OFFLOAD_SET_DENYANY_VAP1_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 25, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP2(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 26, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP2(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 26, 1, value)
+#define AP_OFFLOAD_SET_DENYANY_VAP2_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 26, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP3(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 27, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP3(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 27, 1, value)
+#define AP_OFFLOAD_SET_DENYANY_VAP3_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 27, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP4(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 28, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP4(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 28, 1, value)
+#define AP_OFFLOAD_SET_DENYANY_VAP4_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 28, 1, value)
+#define AP_OFFLOAD_GET_WAIT_TBTT_CNT(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define AP_OFFLOAD_SET_WAIT_TBTT_CNT(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AP_OFFLOAD_SET_WAIT_TBTT_CNT_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AP_OFFLOAD_GET_WAKE_TIMEOUT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define AP_OFFLOAD_SET_WAKE_TIMEOUT(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define AP_OFFLOAD_SET_WAKE_TIMEOUT_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define AP_OFFLOAD_GET_LEN_IV_PAIR(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
+#define AP_OFFLOAD_SET_LEN_IV_PAIR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define AP_OFFLOAD_SET_LEN_IV_PAIR_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define AP_OFFLOAD_GET_LEN_IV_GRP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
+#define AP_OFFLOAD_SET_LEN_IV_GRP(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define AP_OFFLOAD_SET_LEN_IV_GRP_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define BCN_RSVDPAGE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define BCN_RSVDPAGE_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define BCN_RSVDPAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define BCN_RSVDPAGE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define BCN_RSVDPAGE_SET_CLASS(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define BCN_RSVDPAGE_SET_CLASS_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define BCN_RSVDPAGE_GET_LOC_ROOT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define BCN_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define BCN_RSVDPAGE_SET_LOC_ROOT_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP1(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define BCN_RSVDPAGE_SET_LOC_VAP1_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP2(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define BCN_RSVDPAGE_SET_LOC_VAP2_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP3(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define BCN_RSVDPAGE_SET_LOC_VAP3_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP4(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define BCN_RSVDPAGE_SET_LOC_VAP4_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_CMD_ID(h2c_pkt)                                 \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define PROBE_RSP_RSVDPAGE_SET_CMD_ID(h2c_pkt, value)                          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PROBE_RSP_RSVDPAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value)                   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PROBE_RSP_RSVDPAGE_GET_CLASS(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define PROBE_RSP_RSVDPAGE_SET_CLASS(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PROBE_RSP_RSVDPAGE_SET_CLASS_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_ROOT(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_ROOT_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP1(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP1_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP2(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP2_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP3(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP3_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP4(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP4_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_GET_CMD_ID(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define SINGLE_CHANNELSWITCH_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SINGLE_CHANNELSWITCH_SET_CMD_ID_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SINGLE_CHANNELSWITCH_GET_CLASS(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define SINGLE_CHANNELSWITCH_SET_CLASS(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SINGLE_CHANNELSWITCH_SET_CLASS_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SINGLE_CHANNELSWITCH_GET_CHANNEL_NUM(h2c_pkt)                          \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define SINGLE_CHANNELSWITCH_SET_CHANNEL_NUM(h2c_pkt, value)                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_SET_CHANNEL_NUM_NO_CLR(h2c_pkt, value)            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_GET_BW(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 2)
+#define SINGLE_CHANNELSWITCH_SET_BW(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 2, value)
+#define SINGLE_CHANNELSWITCH_SET_BW_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 2, value)
+#define SINGLE_CHANNELSWITCH_GET_BW40SC(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 18, 3)
+#define SINGLE_CHANNELSWITCH_SET_BW40SC(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 18, 3, value)
+#define SINGLE_CHANNELSWITCH_SET_BW40SC_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 18, 3, value)
+#define SINGLE_CHANNELSWITCH_GET_BW80SC(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 21, 3)
+#define SINGLE_CHANNELSWITCH_SET_BW80SC(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 21, 3, value)
+#define SINGLE_CHANNELSWITCH_SET_BW80SC_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 21, 3, value)
+#define SINGLE_CHANNELSWITCH_GET_RFE_TYPE(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 4)
+#define SINGLE_CHANNELSWITCH_SET_RFE_TYPE(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 4, value)
+#define SINGLE_CHANNELSWITCH_SET_RFE_TYPE_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 4, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_CMD_ID(h2c_pkt)                            \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define SINGLE_CHANNELSWITCH_V2_SET_CMD_ID(h2c_pkt, value)                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SINGLE_CHANNELSWITCH_V2_SET_CMD_ID_NO_CLR(h2c_pkt, value)              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_CLASS(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define SINGLE_CHANNELSWITCH_V2_SET_CLASS(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SINGLE_CHANNELSWITCH_V2_SET_CLASS_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_CENTRAL_CH(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define SINGLE_CHANNELSWITCH_V2_SET_CENTRAL_CH(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_V2_SET_CENTRAL_CH_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_PRIMARY_CH_IDX(h2c_pkt)                    \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 4)
+#define SINGLE_CHANNELSWITCH_V2_SET_PRIMARY_CH_IDX(h2c_pkt, value)             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 4, value)
+#define SINGLE_CHANNELSWITCH_V2_SET_PRIMARY_CH_IDX_NO_CLR(h2c_pkt, value)      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 4, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_BW(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 20, 4)
+#define SINGLE_CHANNELSWITCH_V2_SET_BW(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 20, 4, value)
+#define SINGLE_CHANNELSWITCH_V2_SET_BW_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 20, 4, value)
+#define SET_PWR_MODE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define SET_PWR_MODE_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SET_PWR_MODE_SET_CMD_ID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SET_PWR_MODE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define SET_PWR_MODE_SET_CLASS(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SET_PWR_MODE_SET_CLASS_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SET_PWR_MODE_GET_MODE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 7)
+#define SET_PWR_MODE_SET_MODE(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 7, value)
+#define SET_PWR_MODE_SET_MODE_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 7, value)
+#define SET_PWR_MODE_GET_CLK_REQUEST(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
+#define SET_PWR_MODE_SET_CLK_REQUEST(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define SET_PWR_MODE_SET_CLK_REQUEST_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define SET_PWR_MODE_GET_RLBM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 4)
+#define SET_PWR_MODE_SET_RLBM(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 4, value)
+#define SET_PWR_MODE_SET_RLBM_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 4, value)
+#define SET_PWR_MODE_GET_SMART_PS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 20, 4)
+#define SET_PWR_MODE_SET_SMART_PS(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 20, 4, value)
+#define SET_PWR_MODE_SET_SMART_PS_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 20, 4, value)
+#define SET_PWR_MODE_GET_AWAKE_INTERVAL(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define SET_PWR_MODE_SET_AWAKE_INTERVAL(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define SET_PWR_MODE_SET_AWAKE_INTERVAL_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define SET_PWR_MODE_GET_B_ALL_QUEUE_UAPSD(h2c_pkt)                            \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 1)
+#define SET_PWR_MODE_SET_B_ALL_QUEUE_UAPSD(h2c_pkt, value)                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 1, value)
+#define SET_PWR_MODE_SET_B_ALL_QUEUE_UAPSD_NO_CLR(h2c_pkt, value)              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 1, value)
+#define SET_PWR_MODE_GET_BCN_EARLY_RPT(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 2, 1)
+#define SET_PWR_MODE_SET_BCN_EARLY_RPT(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 2, 1, value)
+#define SET_PWR_MODE_SET_BCN_EARLY_RPT_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 2, 1, value)
+#define SET_PWR_MODE_GET_PORT_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 5, 3)
+#define SET_PWR_MODE_SET_PORT_ID(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 5, 3, value)
+#define SET_PWR_MODE_SET_PORT_ID_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 5, 3, value)
+#define SET_PWR_MODE_GET_PWR_STATE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define SET_PWR_MODE_SET_PWR_STATE(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define SET_PWR_MODE_SET_PWR_STATE_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define SET_PWR_MODE_GET_LOW_POWER_RX_BCN(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 16, 1)
+#define SET_PWR_MODE_SET_LOW_POWER_RX_BCN(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 1, value)
+#define SET_PWR_MODE_SET_LOW_POWER_RX_BCN_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 1, value)
+#define SET_PWR_MODE_GET_ANT_AUTO_SWITCH(h2c_pkt)                              \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 17, 1)
+#define SET_PWR_MODE_SET_ANT_AUTO_SWITCH(h2c_pkt, value)                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 17, 1, value)
+#define SET_PWR_MODE_SET_ANT_AUTO_SWITCH_NO_CLR(h2c_pkt, value)                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 17, 1, value)
+#define SET_PWR_MODE_GET_PS_ALLOW_BT_HIGH_PRIORITY(h2c_pkt)                    \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 18, 1)
+#define SET_PWR_MODE_SET_PS_ALLOW_BT_HIGH_PRIORITY(h2c_pkt, value)             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 18, 1, value)
+#define SET_PWR_MODE_SET_PS_ALLOW_BT_HIGH_PRIORITY_NO_CLR(h2c_pkt, value)      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 18, 1, value)
+#define SET_PWR_MODE_GET_PROTECT_BCN(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 19, 1)
+#define SET_PWR_MODE_SET_PROTECT_BCN(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 19, 1, value)
+#define SET_PWR_MODE_SET_PROTECT_BCN_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 19, 1, value)
+#define SET_PWR_MODE_GET_SILENCE_PERIOD(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 20, 1)
+#define SET_PWR_MODE_SET_SILENCE_PERIOD(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 20, 1, value)
+#define SET_PWR_MODE_SET_SILENCE_PERIOD_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 20, 1, value)
+#define SET_PWR_MODE_GET_FAST_BT_CONNECT(h2c_pkt)                              \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 21, 1)
+#define SET_PWR_MODE_SET_FAST_BT_CONNECT(h2c_pkt, value)                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 21, 1, value)
+#define SET_PWR_MODE_SET_FAST_BT_CONNECT_NO_CLR(h2c_pkt, value)                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 21, 1, value)
+#define SET_PWR_MODE_GET_TWO_ANTENNA_EN(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 22, 1)
+#define SET_PWR_MODE_SET_TWO_ANTENNA_EN(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 22, 1, value)
+#define SET_PWR_MODE_SET_TWO_ANTENNA_EN_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 22, 1, value)
+#define SET_PWR_MODE_GET_ADOPT_USER_SETTING(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 24, 1)
+#define SET_PWR_MODE_SET_ADOPT_USER_SETTING(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 1, value)
+#define SET_PWR_MODE_SET_ADOPT_USER_SETTING_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 1, value)
+#define SET_PWR_MODE_GET_DRV_BCN_EARLY_SHIFT(h2c_pkt)                          \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 25, 3)
+#define SET_PWR_MODE_SET_DRV_BCN_EARLY_SHIFT(h2c_pkt, value)                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 25, 3, value)
+#define SET_PWR_MODE_SET_DRV_BCN_EARLY_SHIFT_NO_CLR(h2c_pkt, value)            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 25, 3, value)
+#define SET_PWR_MODE_GET_DRV_BCN_EARLY_SHIFT2(h2c_pkt)                         \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 28, 4)
+#define SET_PWR_MODE_SET_DRV_BCN_EARLY_SHIFT2(h2c_pkt, value)                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 28, 4, value)
+#define SET_PWR_MODE_SET_DRV_BCN_EARLY_SHIFT2_NO_CLR(h2c_pkt, value)           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 28, 4, value)
+#define PS_TUNING_PARA_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define PS_TUNING_PARA_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_TUNING_PARA_SET_CMD_ID_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_TUNING_PARA_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define PS_TUNING_PARA_SET_CLASS(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_TUNING_PARA_SET_CLASS_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_TUNING_PARA_GET_BCN_TO_LIMIT(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 7)
+#define PS_TUNING_PARA_SET_BCN_TO_LIMIT(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 7, value)
+#define PS_TUNING_PARA_SET_BCN_TO_LIMIT_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 7, value)
+#define PS_TUNING_PARA_GET_DTIM_TIME_OUT(h2c_pkt)                              \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
+#define PS_TUNING_PARA_SET_DTIM_TIME_OUT(h2c_pkt, value)                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define PS_TUNING_PARA_SET_DTIM_TIME_OUT_NO_CLR(h2c_pkt, value)                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define PS_TUNING_PARA_GET_PS_TIME_OUT(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 4)
+#define PS_TUNING_PARA_SET_PS_TIME_OUT(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 4, value)
+#define PS_TUNING_PARA_SET_PS_TIME_OUT_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 4, value)
+#define PS_TUNING_PARA_GET_ADOPT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define PS_TUNING_PARA_SET_ADOPT(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define PS_TUNING_PARA_SET_ADOPT_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define PS_TUNING_PARA_II_GET_CMD_ID(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define PS_TUNING_PARA_II_SET_CMD_ID(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_TUNING_PARA_II_SET_CMD_ID_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_TUNING_PARA_II_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define PS_TUNING_PARA_II_SET_CLASS(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_TUNING_PARA_II_SET_CLASS_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_TUNING_PARA_II_GET_BCN_TO_PERIOD(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 7)
+#define PS_TUNING_PARA_II_SET_BCN_TO_PERIOD(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 7, value)
+#define PS_TUNING_PARA_II_SET_BCN_TO_PERIOD_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 7, value)
+#define PS_TUNING_PARA_II_GET_ADOPT(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
+#define PS_TUNING_PARA_II_SET_ADOPT(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define PS_TUNING_PARA_II_SET_ADOPT_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define PS_TUNING_PARA_II_GET_DRV_EARLY_IVL(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define PS_TUNING_PARA_II_SET_DRV_EARLY_IVL(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define PS_TUNING_PARA_II_SET_DRV_EARLY_IVL_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define PS_LPS_PARA_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define PS_LPS_PARA_SET_CMD_ID(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_LPS_PARA_SET_CMD_ID_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_LPS_PARA_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define PS_LPS_PARA_SET_CLASS(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_LPS_PARA_SET_CLASS_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_LPS_PARA_GET_LPS_CONTROL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define PS_LPS_PARA_SET_LPS_CONTROL(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define PS_LPS_PARA_SET_LPS_CONTROL_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define P2P_PS_OFFLOAD_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define P2P_PS_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define P2P_PS_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define P2P_PS_OFFLOAD_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define P2P_PS_OFFLOAD_SET_CLASS(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define P2P_PS_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define P2P_PS_OFFLOAD_GET_OFFLOAD_EN(h2c_pkt)                                 \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define P2P_PS_OFFLOAD_SET_OFFLOAD_EN(h2c_pkt, value)                          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define P2P_PS_OFFLOAD_SET_OFFLOAD_EN_NO_CLR(h2c_pkt, value)                   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define P2P_PS_OFFLOAD_GET_ROLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define P2P_PS_OFFLOAD_SET_ROLE(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define P2P_PS_OFFLOAD_SET_ROLE_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define P2P_PS_OFFLOAD_GET_CTWINDOW_EN(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define P2P_PS_OFFLOAD_SET_CTWINDOW_EN(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define P2P_PS_OFFLOAD_SET_CTWINDOW_EN_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define P2P_PS_OFFLOAD_GET_NOA0_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
+#define P2P_PS_OFFLOAD_SET_NOA0_EN(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define P2P_PS_OFFLOAD_SET_NOA0_EN_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define P2P_PS_OFFLOAD_GET_NOA1_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
+#define P2P_PS_OFFLOAD_SET_NOA1_EN(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define P2P_PS_OFFLOAD_SET_NOA1_EN_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define P2P_PS_OFFLOAD_GET_ALL_STA_SLEEP(h2c_pkt)                              \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 13, 1)
+#define P2P_PS_OFFLOAD_SET_ALL_STA_SLEEP(h2c_pkt, value)                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 13, 1, value)
+#define P2P_PS_OFFLOAD_SET_ALL_STA_SLEEP_NO_CLR(h2c_pkt, value)                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 13, 1, value)
+#define P2P_PS_OFFLOAD_GET_DISCOVERY(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 14, 1)
+#define P2P_PS_OFFLOAD_SET_DISCOVERY(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 14, 1, value)
+#define P2P_PS_OFFLOAD_SET_DISCOVERY_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 14, 1, value)
+#define PS_SCAN_EN_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define PS_SCAN_EN_SET_CMD_ID(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_SCAN_EN_SET_CMD_ID_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define PS_SCAN_EN_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define PS_SCAN_EN_SET_CLASS(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_SCAN_EN_SET_CLASS_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define PS_SCAN_EN_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define PS_SCAN_EN_SET_ENABLE(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define PS_SCAN_EN_SET_ENABLE_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define SAP_PS_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define SAP_PS_SET_CMD_ID(h2c_pkt, value)                                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SAP_PS_SET_CMD_ID_NO_CLR(h2c_pkt, value)                               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define SAP_PS_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define SAP_PS_SET_CLASS(h2c_pkt, value)                                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SAP_PS_SET_CLASS_NO_CLR(h2c_pkt, value)                                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define SAP_PS_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define SAP_PS_SET_ENABLE(h2c_pkt, value)                                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define SAP_PS_SET_ENABLE_NO_CLR(h2c_pkt, value)                               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define SAP_PS_GET_EN_PS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define SAP_PS_SET_EN_PS(h2c_pkt, value)                                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define SAP_PS_SET_EN_PS_NO_CLR(h2c_pkt, value)                                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define SAP_PS_GET_EN_LP_RX(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define SAP_PS_SET_EN_LP_RX(h2c_pkt, value)                                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define SAP_PS_SET_EN_LP_RX_NO_CLR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define SAP_PS_GET_MANUAL_32K(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
+#define SAP_PS_SET_MANUAL_32K(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define SAP_PS_SET_MANUAL_32K_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define SAP_PS_GET_DURATION(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define SAP_PS_SET_DURATION(h2c_pkt, value)                                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define SAP_PS_SET_DURATION_NO_CLR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define INACTIVE_PS_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define INACTIVE_PS_SET_CMD_ID(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define INACTIVE_PS_SET_CMD_ID_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define INACTIVE_PS_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define INACTIVE_PS_SET_CLASS(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define INACTIVE_PS_SET_CLASS_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define INACTIVE_PS_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define INACTIVE_PS_SET_ENABLE(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define INACTIVE_PS_SET_ENABLE_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define INACTIVE_PS_GET_IGNORE_PS_CONDITION(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define INACTIVE_PS_SET_IGNORE_PS_CONDITION(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define INACTIVE_PS_SET_IGNORE_PS_CONDITION_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define INACTIVE_PS_GET_FREQUENCY(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define INACTIVE_PS_SET_FREQUENCY(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define INACTIVE_PS_SET_FREQUENCY_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define INACTIVE_PS_GET_DURATION(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define INACTIVE_PS_SET_DURATION(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define INACTIVE_PS_SET_DURATION_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define MACID_CFG_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define MACID_CFG_SET_CMD_ID(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define MACID_CFG_SET_CMD_ID_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define MACID_CFG_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define MACID_CFG_SET_CLASS(h2c_pkt, value)                                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define MACID_CFG_SET_CLASS_NO_CLR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define MACID_CFG_GET_MAC_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define MACID_CFG_SET_MAC_ID(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define MACID_CFG_SET_MAC_ID_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define MACID_CFG_GET_RATE_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 5)
+#define MACID_CFG_SET_RATE_ID(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 5, value)
+#define MACID_CFG_SET_RATE_ID_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 5, value)
+#define MACID_CFG_GET_INIT_RATE_LV(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 21, 2)
+#define MACID_CFG_SET_INIT_RATE_LV(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 21, 2, value)
+#define MACID_CFG_SET_INIT_RATE_LV_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 21, 2, value)
+#define MACID_CFG_GET_SGI(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 23, 1)
+#define MACID_CFG_SET_SGI(h2c_pkt, value)                                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 23, 1, value)
+#define MACID_CFG_SET_SGI_NO_CLR(h2c_pkt, value)                               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 23, 1, value)
+#define MACID_CFG_GET_BW(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 2)
+#define MACID_CFG_SET_BW(h2c_pkt, value)                                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 2, value)
+#define MACID_CFG_SET_BW_NO_CLR(h2c_pkt, value)                                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 2, value)
+#define MACID_CFG_GET_LDPC_CAP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 26, 1)
+#define MACID_CFG_SET_LDPC_CAP(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 26, 1, value)
+#define MACID_CFG_SET_LDPC_CAP_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 26, 1, value)
+#define MACID_CFG_GET_NO_UPDATE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 27, 1)
+#define MACID_CFG_SET_NO_UPDATE(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 27, 1, value)
+#define MACID_CFG_SET_NO_UPDATE_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 27, 1, value)
+#define MACID_CFG_GET_WHT_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 28, 2)
+#define MACID_CFG_SET_WHT_EN(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 28, 2, value)
+#define MACID_CFG_SET_WHT_EN_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 28, 2, value)
+#define MACID_CFG_GET_DISPT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 30, 1)
+#define MACID_CFG_SET_DISPT(h2c_pkt, value)                                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 30, 1, value)
+#define MACID_CFG_SET_DISPT_NO_CLR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 30, 1, value)
+#define MACID_CFG_GET_DISRA(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 31, 1)
+#define MACID_CFG_SET_DISRA(h2c_pkt, value)                                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 31, 1, value)
+#define MACID_CFG_SET_DISRA_NO_CLR(h2c_pkt, value)                             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 31, 1, value)
+#define MACID_CFG_GET_RATE_MASK7_0(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define MACID_CFG_SET_RATE_MASK7_0(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define MACID_CFG_SET_RATE_MASK7_0_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define MACID_CFG_GET_RATE_MASK15_8(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define MACID_CFG_SET_RATE_MASK15_8(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define MACID_CFG_SET_RATE_MASK15_8_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define MACID_CFG_GET_RATE_MASK23_16(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
+#define MACID_CFG_SET_RATE_MASK23_16(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define MACID_CFG_SET_RATE_MASK23_16_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define MACID_CFG_GET_RATE_MASK31_24(h2c_pkt)                                  \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
+#define MACID_CFG_SET_RATE_MASK31_24(h2c_pkt, value)                           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define MACID_CFG_SET_RATE_MASK31_24_NO_CLR(h2c_pkt, value)                    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define TXBF_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define TXBF_SET_CMD_ID(h2c_pkt, value)                                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define TXBF_SET_CMD_ID_NO_CLR(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define TXBF_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define TXBF_SET_CLASS(h2c_pkt, value)                                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define TXBF_SET_CLASS_NO_CLR(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define TXBF_GET_NDPA0_HEAD_PAGE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define TXBF_SET_NDPA0_HEAD_PAGE(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define TXBF_SET_NDPA0_HEAD_PAGE_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define TXBF_GET_NDPA1_HEAD_PAGE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define TXBF_SET_NDPA1_HEAD_PAGE(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define TXBF_SET_NDPA1_HEAD_PAGE_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define TXBF_GET_PERIOD_0(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define TXBF_SET_PERIOD_0(h2c_pkt, value)                                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define TXBF_SET_PERIOD_0_NO_CLR(h2c_pkt, value)                               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define RSSI_SETTING_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define RSSI_SETTING_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define RSSI_SETTING_SET_CMD_ID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define RSSI_SETTING_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define RSSI_SETTING_SET_CLASS(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define RSSI_SETTING_SET_CLASS_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define RSSI_SETTING_GET_MAC_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define RSSI_SETTING_SET_MAC_ID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define RSSI_SETTING_SET_MAC_ID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define RSSI_SETTING_GET_RSSI(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 7)
+#define RSSI_SETTING_SET_RSSI(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 7, value)
+#define RSSI_SETTING_SET_RSSI_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 7, value)
+#define RSSI_SETTING_GET_RA_INFO(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define RSSI_SETTING_SET_RA_INFO(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define RSSI_SETTING_SET_RA_INFO_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AP_REQ_TXRPT_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define AP_REQ_TXRPT_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AP_REQ_TXRPT_SET_CMD_ID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AP_REQ_TXRPT_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define AP_REQ_TXRPT_SET_CLASS(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AP_REQ_TXRPT_SET_CLASS_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AP_REQ_TXRPT_GET_STA1_MACID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define AP_REQ_TXRPT_SET_STA1_MACID(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AP_REQ_TXRPT_SET_STA1_MACID_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AP_REQ_TXRPT_GET_STA2_MACID(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define AP_REQ_TXRPT_SET_STA2_MACID(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AP_REQ_TXRPT_SET_STA2_MACID_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AP_REQ_TXRPT_GET_RTY_OK_TOTAL(h2c_pkt)                                 \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 1)
+#define AP_REQ_TXRPT_SET_RTY_OK_TOTAL(h2c_pkt, value)                          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 1, value)
+#define AP_REQ_TXRPT_SET_RTY_OK_TOTAL_NO_CLR(h2c_pkt, value)                   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 1, value)
+#define AP_REQ_TXRPT_GET_RTY_CNT_MACID(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 25, 1)
+#define AP_REQ_TXRPT_SET_RTY_CNT_MACID(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 25, 1, value)
+#define AP_REQ_TXRPT_SET_RTY_CNT_MACID_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 25, 1, value)
+#define INIT_RATE_COLLECTION_GET_CMD_ID(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define INIT_RATE_COLLECTION_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define INIT_RATE_COLLECTION_SET_CMD_ID_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define INIT_RATE_COLLECTION_GET_CLASS(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define INIT_RATE_COLLECTION_SET_CLASS(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define INIT_RATE_COLLECTION_SET_CLASS_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define INIT_RATE_COLLECTION_GET_STA1_MACID(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define INIT_RATE_COLLECTION_SET_STA1_MACID(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define INIT_RATE_COLLECTION_SET_STA1_MACID_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA2_MACID(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define INIT_RATE_COLLECTION_SET_STA2_MACID(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define INIT_RATE_COLLECTION_SET_STA2_MACID_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA3_MACID(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define INIT_RATE_COLLECTION_SET_STA3_MACID(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define INIT_RATE_COLLECTION_SET_STA3_MACID_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA4_MACID(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define INIT_RATE_COLLECTION_SET_STA4_MACID(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define INIT_RATE_COLLECTION_SET_STA4_MACID_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA5_MACID(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define INIT_RATE_COLLECTION_SET_STA5_MACID(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define INIT_RATE_COLLECTION_SET_STA5_MACID_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA6_MACID(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
+#define INIT_RATE_COLLECTION_SET_STA6_MACID(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define INIT_RATE_COLLECTION_SET_STA6_MACID_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA7_MACID(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
+#define INIT_RATE_COLLECTION_SET_STA7_MACID(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define INIT_RATE_COLLECTION_SET_STA7_MACID_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define IQK_OFFLOAD_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define IQK_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define IQK_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define IQK_OFFLOAD_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define IQK_OFFLOAD_SET_CLASS(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define IQK_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define IQK_OFFLOAD_GET_CHANNEL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define IQK_OFFLOAD_SET_CHANNEL(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define IQK_OFFLOAD_SET_CHANNEL_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define IQK_OFFLOAD_GET_BWBAND(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define IQK_OFFLOAD_SET_BWBAND(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define IQK_OFFLOAD_SET_BWBAND_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define IQK_OFFLOAD_GET_EXTPALNA(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define IQK_OFFLOAD_SET_EXTPALNA(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define IQK_OFFLOAD_SET_EXTPALNA_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define MACID_CFG_3SS_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define MACID_CFG_3SS_SET_CMD_ID(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define MACID_CFG_3SS_SET_CMD_ID_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define MACID_CFG_3SS_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define MACID_CFG_3SS_SET_CLASS(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define MACID_CFG_3SS_SET_CLASS_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define MACID_CFG_3SS_GET_MACID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define MACID_CFG_3SS_SET_MACID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define MACID_CFG_3SS_SET_MACID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define MACID_CFG_3SS_GET_RATE_MASK_39_32(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define MACID_CFG_3SS_SET_RATE_MASK_39_32(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define MACID_CFG_3SS_SET_RATE_MASK_39_32_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define MACID_CFG_3SS_GET_RATE_MASK_47_40(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define MACID_CFG_3SS_SET_RATE_MASK_47_40(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define MACID_CFG_3SS_SET_RATE_MASK_47_40_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define RA_PARA_ADJUST_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define RA_PARA_ADJUST_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define RA_PARA_ADJUST_SET_CMD_ID_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define RA_PARA_ADJUST_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define RA_PARA_ADJUST_SET_CLASS(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define RA_PARA_ADJUST_SET_CLASS_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define RA_PARA_ADJUST_GET_MAC_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define RA_PARA_ADJUST_SET_MAC_ID(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define RA_PARA_ADJUST_SET_MAC_ID_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define RA_PARA_ADJUST_GET_PARAMETER_INDEX(h2c_pkt)                            \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define RA_PARA_ADJUST_SET_PARAMETER_INDEX(h2c_pkt, value)                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define RA_PARA_ADJUST_SET_PARAMETER_INDEX_NO_CLR(h2c_pkt, value)              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define RA_PARA_ADJUST_GET_RATE_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define RA_PARA_ADJUST_SET_RATE_ID(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define RA_PARA_ADJUST_SET_RATE_ID_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define RA_PARA_ADJUST_GET_VALUE_BYTE0(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define RA_PARA_ADJUST_SET_VALUE_BYTE0(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define RA_PARA_ADJUST_SET_VALUE_BYTE0_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define RA_PARA_ADJUST_GET_VALUE_BYTE1(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define RA_PARA_ADJUST_SET_VALUE_BYTE1(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define RA_PARA_ADJUST_SET_VALUE_BYTE1_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define RA_PARA_ADJUST_GET_ASK_FW_FOR_FW_PARA(h2c_pkt)                         \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
+#define RA_PARA_ADJUST_SET_ASK_FW_FOR_FW_PARA(h2c_pkt, value)                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define RA_PARA_ADJUST_SET_ASK_FW_FOR_FW_PARA_NO_CLR(h2c_pkt, value)           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define WWLAN_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define WWLAN_SET_CMD_ID(h2c_pkt, value)                                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define WWLAN_SET_CMD_ID_NO_CLR(h2c_pkt, value)                                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define WWLAN_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define WWLAN_SET_CLASS(h2c_pkt, value)                                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define WWLAN_SET_CLASS_NO_CLR(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define WWLAN_GET_FUNC_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define WWLAN_SET_FUNC_EN(h2c_pkt, value)                                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define WWLAN_SET_FUNC_EN_NO_CLR(h2c_pkt, value)                               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define WWLAN_GET_PATTERM_MAT_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define WWLAN_SET_PATTERM_MAT_EN(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define WWLAN_SET_PATTERM_MAT_EN_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define WWLAN_GET_MAGIC_PKT_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define WWLAN_SET_MAGIC_PKT_EN(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define WWLAN_SET_MAGIC_PKT_EN_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define WWLAN_GET_UNICAST_WAKEUP_EN(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
+#define WWLAN_SET_UNICAST_WAKEUP_EN(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define WWLAN_SET_UNICAST_WAKEUP_EN_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define WWLAN_GET_ALL_PKT_DROP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
+#define WWLAN_SET_ALL_PKT_DROP(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define WWLAN_SET_ALL_PKT_DROP_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define WWLAN_GET_GPIO_ACTIVE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 13, 1)
+#define WWLAN_SET_GPIO_ACTIVE(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 13, 1, value)
+#define WWLAN_SET_GPIO_ACTIVE_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 13, 1, value)
+#define WWLAN_GET_REKEY_WAKEUP_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 14, 1)
+#define WWLAN_SET_REKEY_WAKEUP_EN(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 14, 1, value)
+#define WWLAN_SET_REKEY_WAKEUP_EN_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 14, 1, value)
+#define WWLAN_GET_DEAUTH_WAKEUP_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
+#define WWLAN_SET_DEAUTH_WAKEUP_EN(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define WWLAN_SET_DEAUTH_WAKEUP_EN_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define WWLAN_GET_GPIO_NUM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 7)
+#define WWLAN_SET_GPIO_NUM(h2c_pkt, value)                                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 7, value)
+#define WWLAN_SET_GPIO_NUM_NO_CLR(h2c_pkt, value)                              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 7, value)
+#define WWLAN_GET_DATAPIN_WAKEUP_EN(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 23, 1)
+#define WWLAN_SET_DATAPIN_WAKEUP_EN(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 23, 1, value)
+#define WWLAN_SET_DATAPIN_WAKEUP_EN_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 23, 1, value)
+#define WWLAN_GET_GPIO_DURATION(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define WWLAN_SET_GPIO_DURATION(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define WWLAN_SET_GPIO_DURATION_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define WWLAN_GET_GPIO_PLUS_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 1)
+#define WWLAN_SET_GPIO_PLUS_EN(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 1, value)
+#define WWLAN_SET_GPIO_PLUS_EN_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 1, value)
+#define WWLAN_GET_GPIO_PULSE_COUNT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 1, 7)
+#define WWLAN_SET_GPIO_PULSE_COUNT(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 1, 7, value)
+#define WWLAN_SET_GPIO_PULSE_COUNT_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 1, 7, value)
+#define WWLAN_GET_DISABLE_UPHY(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 1)
+#define WWLAN_SET_DISABLE_UPHY(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 1, value)
+#define WWLAN_SET_DISABLE_UPHY_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 1, value)
+#define WWLAN_GET_HST2DEV_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 9, 1)
+#define WWLAN_SET_HST2DEV_EN(h2c_pkt, value)                                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 9, 1, value)
+#define WWLAN_SET_HST2DEV_EN_NO_CLR(h2c_pkt, value)                            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 9, 1, value)
+#define WWLAN_GET_GPIO_DURATION_MS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 10, 1)
+#define WWLAN_SET_GPIO_DURATION_MS(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 10, 1, value)
+#define WWLAN_SET_GPIO_DURATION_MS_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 10, 1, value)
+#define REMOTE_WAKE_CTRL_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define REMOTE_WAKE_CTRL_SET_CMD_ID(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define REMOTE_WAKE_CTRL_SET_CMD_ID_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define REMOTE_WAKE_CTRL_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define REMOTE_WAKE_CTRL_SET_CLASS(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define REMOTE_WAKE_CTRL_SET_CLASS_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define REMOTE_WAKE_CTRL_GET_REMOTE_WAKE_CTRL_EN(h2c_pkt)                      \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define REMOTE_WAKE_CTRL_SET_REMOTE_WAKE_CTRL_EN(h2c_pkt, value)               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define REMOTE_WAKE_CTRL_SET_REMOTE_WAKE_CTRL_EN_NO_CLR(h2c_pkt, value)        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define REMOTE_WAKE_CTRL_GET_ARP_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
+#define REMOTE_WAKE_CTRL_SET_ARP_EN(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define REMOTE_WAKE_CTRL_SET_ARP_EN_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
+#define REMOTE_WAKE_CTRL_GET_NDP_EN(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
+#define REMOTE_WAKE_CTRL_SET_NDP_EN(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define REMOTE_WAKE_CTRL_SET_NDP_EN_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
+#define REMOTE_WAKE_CTRL_GET_GTK_EN(h2c_pkt)                                   \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
+#define REMOTE_WAKE_CTRL_SET_GTK_EN(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define REMOTE_WAKE_CTRL_SET_GTK_EN_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
+#define REMOTE_WAKE_CTRL_GET_NLO_OFFLOAD_EN(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
+#define REMOTE_WAKE_CTRL_SET_NLO_OFFLOAD_EN(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define REMOTE_WAKE_CTRL_SET_NLO_OFFLOAD_EN_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
+#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V1_EN(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 13, 1)
+#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V1_EN(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 13, 1, value)
+#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V1_EN_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 13, 1, value)
+#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V2_EN(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 14, 1)
+#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V2_EN(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 14, 1, value)
+#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V2_EN_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 14, 1, value)
+#define REMOTE_WAKE_CTRL_GET_FW_UNICAST(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
+#define REMOTE_WAKE_CTRL_SET_FW_UNICAST(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define REMOTE_WAKE_CTRL_SET_FW_UNICAST_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
+#define REMOTE_WAKE_CTRL_GET_P2P_OFFLOAD_EN(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 1)
+#define REMOTE_WAKE_CTRL_SET_P2P_OFFLOAD_EN(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 1, value)
+#define REMOTE_WAKE_CTRL_SET_P2P_OFFLOAD_EN_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 1, value)
+#define REMOTE_WAKE_CTRL_GET_RUNTIME_PM_EN(h2c_pkt)                            \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 17, 1)
+#define REMOTE_WAKE_CTRL_SET_RUNTIME_PM_EN(h2c_pkt, value)                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 17, 1, value)
+#define REMOTE_WAKE_CTRL_SET_RUNTIME_PM_EN_NO_CLR(h2c_pkt, value)              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 17, 1, value)
+#define REMOTE_WAKE_CTRL_GET_NET_BIOS_DROP_EN(h2c_pkt)                         \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 18, 1)
+#define REMOTE_WAKE_CTRL_SET_NET_BIOS_DROP_EN(h2c_pkt, value)                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 18, 1, value)
+#define REMOTE_WAKE_CTRL_SET_NET_BIOS_DROP_EN_NO_CLR(h2c_pkt, value)           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 18, 1, value)
+#define REMOTE_WAKE_CTRL_GET_ARP_ACTION(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 1)
+#define REMOTE_WAKE_CTRL_SET_ARP_ACTION(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 1, value)
+#define REMOTE_WAKE_CTRL_SET_ARP_ACTION_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 1, value)
+#define REMOTE_WAKE_CTRL_GET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt)                  \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 28, 1)
+#define REMOTE_WAKE_CTRL_SET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt, value)           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 28, 1, value)
+#define REMOTE_WAKE_CTRL_SET_FW_PARSING_UNTIL_WAKEUP_NO_CLR(h2c_pkt, value)    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 28, 1, value)
+#define REMOTE_WAKE_CTRL_GET_FW_PARSING_AFTER_WAKEUP(h2c_pkt)                  \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 29, 1)
+#define REMOTE_WAKE_CTRL_SET_FW_PARSING_AFTER_WAKEUP(h2c_pkt, value)           \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 29, 1, value)
+#define REMOTE_WAKE_CTRL_SET_FW_PARSING_AFTER_WAKEUP_NO_CLR(h2c_pkt, value)    \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 29, 1, value)
+#define AOAC_GLOBAL_INFO_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define AOAC_GLOBAL_INFO_SET_CMD_ID(h2c_pkt, value)                            \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_GLOBAL_INFO_SET_CMD_ID_NO_CLR(h2c_pkt, value)                     \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_GLOBAL_INFO_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define AOAC_GLOBAL_INFO_SET_CLASS(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_GLOBAL_INFO_SET_CLASS_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_GLOBAL_INFO_GET_PAIR_WISE_ENC_ALG(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define AOAC_GLOBAL_INFO_SET_PAIR_WISE_ENC_ALG(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_GLOBAL_INFO_SET_PAIR_WISE_ENC_ALG_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_GLOBAL_INFO_GET_GROUP_ENC_ALG(h2c_pkt)                            \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define AOAC_GLOBAL_INFO_SET_GROUP_ENC_ALG(h2c_pkt, value)                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_GLOBAL_INFO_SET_GROUP_ENC_ALG_NO_CLR(h2c_pkt, value)              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define AOAC_RSVD_PAGE_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define AOAC_RSVD_PAGE_SET_CLASS(h2c_pkt, value)                               \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE_SET_CLASS_NO_CLR(h2c_pkt, value)                        \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE_GET_LOC_REMOTE_CTRL_INFO(h2c_pkt)                       \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_REMOTE_CTRL_INFO(h2c_pkt, value)                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE_SET_LOC_REMOTE_CTRL_INFO_NO_CLR(h2c_pkt, value)         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_ARP_RESPONSE(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_ARP_RESPONSE(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE_SET_LOC_ARP_RESPONSE_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt)                 \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt, value)          \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE_SET_LOC_NEIGHBOR_ADVERTISEMENT_NO_CLR(h2c_pkt, value)   \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_GTK_RSP(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_RSP(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_RSP_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_GTK_INFO(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_INFO(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_INFO_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_GTK_EXT_MEM(h2c_pkt)                            \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_EXT_MEM(h2c_pkt, value)                     \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_EXT_MEM_NO_CLR(h2c_pkt, value)              \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_NDP_INFO(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_NDP_INFO(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define AOAC_RSVD_PAGE_SET_LOC_NDP_INFO_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define AOAC_RSVD_PAGE2_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define AOAC_RSVD_PAGE2_SET_CMD_ID(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE2_SET_CMD_ID_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE2_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define AOAC_RSVD_PAGE2_SET_CLASS(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE2_SET_CLASS_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_ROUTER_SOLICATION(h2c_pkt)                     \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_ROUTER_SOLICATION(h2c_pkt, value)              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE2_SET_LOC_ROUTER_SOLICATION_NO_CLR(h2c_pkt, value)       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_BUBBLE_PACKET(h2c_pkt)                         \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_BUBBLE_PACKET(h2c_pkt, value)                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE2_SET_LOC_BUBBLE_PACKET_NO_CLR(h2c_pkt, value)           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_TEREDO_INFO(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_TEREDO_INFO(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE2_SET_LOC_TEREDO_INFO_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_REALWOW_INFO(h2c_pkt)                          \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_REALWOW_INFO(h2c_pkt, value)                   \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AOAC_RSVD_PAGE2_SET_LOC_REALWOW_INFO_NO_CLR(h2c_pkt, value)            \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_KEEP_ALIVE_PKT(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_KEEP_ALIVE_PKT(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define AOAC_RSVD_PAGE2_SET_LOC_KEEP_ALIVE_PKT_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_ACK_PATTERN(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_ACK_PATTERN(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define AOAC_RSVD_PAGE2_SET_LOC_ACK_PATTERN_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_WAKEUP_PATTERN(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_WAKEUP_PATTERN(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define AOAC_RSVD_PAGE2_SET_LOC_WAKEUP_PATTERN_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
+#define D0_SCAN_OFFLOAD_INFO_GET_CMD_ID(h2c_pkt)                               \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define D0_SCAN_OFFLOAD_INFO_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define D0_SCAN_OFFLOAD_INFO_SET_CMD_ID_NO_CLR(h2c_pkt, value)                 \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define D0_SCAN_OFFLOAD_INFO_GET_CLASS(h2c_pkt)                                \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define D0_SCAN_OFFLOAD_INFO_SET_CLASS(h2c_pkt, value)                         \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define D0_SCAN_OFFLOAD_INFO_SET_CLASS_NO_CLR(h2c_pkt, value)                  \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define D0_SCAN_OFFLOAD_INFO_GET_LOC_CHANNEL_INFO(h2c_pkt)                     \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define D0_SCAN_OFFLOAD_INFO_SET_LOC_CHANNEL_INFO(h2c_pkt, value)              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define D0_SCAN_OFFLOAD_INFO_SET_LOC_CHANNEL_INFO_NO_CLR(h2c_pkt, value)       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_CMD_ID(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_CLASS(h2c_pkt)                              \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CLASS(h2c_pkt, value)                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value)                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_CHANNEL_NUM(h2c_pkt)                        \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CHANNEL_NUM(h2c_pkt, value)                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CHANNEL_NUM_NO_CLR(h2c_pkt, value)          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_EN_RFE(h2c_pkt)                             \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define CHANNEL_SWITCH_OFFLOAD_SET_EN_RFE(h2c_pkt, value)                      \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_SET_EN_RFE_NO_CLR(h2c_pkt, value)               \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_RFE_TYPE(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
+#define CHANNEL_SWITCH_OFFLOAD_SET_RFE_TYPE(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_SET_RFE_TYPE_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE3_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define AOAC_RSVD_PAGE3_SET_CMD_ID(h2c_pkt, value)                             \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE3_SET_CMD_ID_NO_CLR(h2c_pkt, value)                      \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE3_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define AOAC_RSVD_PAGE3_SET_CLASS(h2c_pkt, value)                              \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE3_SET_CLASS_NO_CLR(h2c_pkt, value)                       \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE3_GET_LOC_NLO_INFO(h2c_pkt)                              \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
+#define AOAC_RSVD_PAGE3_SET_LOC_NLO_INFO(h2c_pkt, value)                       \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE3_SET_LOC_NLO_INFO_NO_CLR(h2c_pkt, value)                \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE3_GET_LOC_AOAC_REPORT(h2c_pkt)                           \
+	GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
+#define AOAC_RSVD_PAGE3_SET_LOC_AOAC_REPORT(h2c_pkt, value)                    \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE3_SET_LOC_AOAC_REPORT_NO_CLR(h2c_pkt, value)             \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
+#define DBG_MSG_CTRL_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
+#define DBG_MSG_CTRL_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define DBG_MSG_CTRL_SET_CMD_ID_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
+#define DBG_MSG_CTRL_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
+#define DBG_MSG_CTRL_SET_CLASS(h2c_pkt, value)                                 \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define DBG_MSG_CTRL_SET_CLASS_NO_CLR(h2c_pkt, value)                          \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
+#define DBG_MSG_CTRL_GET_FUN_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
+#define DBG_MSG_CTRL_SET_FUN_EN(h2c_pkt, value)                                \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define DBG_MSG_CTRL_SET_FUN_EN_NO_CLR(h2c_pkt, value)                         \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
+#define DBG_MSG_CTRL_GET_MODE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 4)
+#define DBG_MSG_CTRL_SET_MODE(h2c_pkt, value)                                  \
+	SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 4, value)
+#define DBG_MSG_CTRL_SET_MODE_NO_CLR(h2c_pkt, value)                           \
+	SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 4, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_h2c_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_h2c_nic.h
new file mode 100644
index 000000000000..3870ff4953c8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_original_h2c_nic.h
@@ -0,0 +1,1143 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_ORIGINALH2CFORMAT_H2C_C2H_NIC_H_
+#define _HAL_ORIGINALH2CFORMAT_H2C_C2H_NIC_H_
+#define CMD_ID_ORIGINAL_H2C 0X00
+#define CMD_ID_H2C2H_LB 0X0
+#define CMD_ID_D0_SCAN_OFFLOAD_CTRL 0X06
+#define CMD_ID_RSVD_PAGE 0X0
+#define CMD_ID_MEDIA_STATUS_RPT 0X01
+#define CMD_ID_KEEP_ALIVE 0X03
+#define CMD_ID_DISCONNECT_DECISION 0X04
+#define CMD_ID_AP_OFFLOAD 0X08
+#define CMD_ID_BCN_RSVDPAGE 0X09
+#define CMD_ID_PROBE_RSP_RSVDPAGE 0X0A
+#define CMD_ID_SINGLE_CHANNELSWITCH 0X1C
+#define CMD_ID_SINGLE_CHANNELSWITCH_V2 0X1D
+#define CMD_ID_SET_PWR_MODE 0X00
+#define CMD_ID_PS_TUNING_PARA 0X01
+#define CMD_ID_PS_TUNING_PARA_II 0X02
+#define CMD_ID_PS_LPS_PARA 0X03
+#define CMD_ID_P2P_PS_OFFLOAD 0X04
+#define CMD_ID_PS_SCAN_EN 0X05
+#define CMD_ID_SAP_PS 0X06
+#define CMD_ID_INACTIVE_PS 0X07
+#define CMD_ID_MACID_CFG 0X00
+#define CMD_ID_TXBF 0X01
+#define CMD_ID_RSSI_SETTING 0X02
+#define CMD_ID_AP_REQ_TXRPT 0X03
+#define CMD_ID_INIT_RATE_COLLECTION 0X04
+#define CMD_ID_IQK_OFFLOAD 0X05
+#define CMD_ID_MACID_CFG_3SS 0X06
+#define CMD_ID_RA_PARA_ADJUST 0X07
+#define CMD_ID_WWLAN 0X00
+#define CMD_ID_REMOTE_WAKE_CTRL 0X01
+#define CMD_ID_AOAC_GLOBAL_INFO 0X02
+#define CMD_ID_AOAC_RSVD_PAGE 0X03
+#define CMD_ID_AOAC_RSVD_PAGE2 0X04
+#define CMD_ID_D0_SCAN_OFFLOAD_INFO 0X05
+#define CMD_ID_CHANNEL_SWITCH_OFFLOAD 0X07
+#define CMD_ID_AOAC_RSVD_PAGE3 0X08
+#define CMD_ID_DBG_MSG_CTRL 0X1E
+#define CLASS_ORIGINAL_H2C 0X00
+#define CLASS_H2C2H_LB 0X07
+#define CLASS_D0_SCAN_OFFLOAD_CTRL 0X04
+#define CLASS_RSVD_PAGE 0X0
+#define CLASS_MEDIA_STATUS_RPT 0X0
+#define CLASS_KEEP_ALIVE 0X0
+#define CLASS_DISCONNECT_DECISION 0X0
+#define CLASS_AP_OFFLOAD 0X0
+#define CLASS_BCN_RSVDPAGE 0X0
+#define CLASS_PROBE_RSP_RSVDPAGE 0X0
+#define CLASS_SINGLE_CHANNELSWITCH 0X0
+#define CLASS_SINGLE_CHANNELSWITCH_V2 0X0
+#define CLASS_SET_PWR_MODE 0X01
+#define CLASS_PS_TUNING_PARA 0X01
+#define CLASS_PS_TUNING_PARA_II 0X01
+#define CLASS_PS_LPS_PARA 0X01
+#define CLASS_P2P_PS_OFFLOAD 0X01
+#define CLASS_PS_SCAN_EN 0X1
+#define CLASS_SAP_PS 0X1
+#define CLASS_INACTIVE_PS 0X1
+#define CLASS_MACID_CFG 0X2
+#define CLASS_TXBF 0X2
+#define CLASS_RSSI_SETTING 0X2
+#define CLASS_AP_REQ_TXRPT 0X2
+#define CLASS_INIT_RATE_COLLECTION 0X2
+#define CLASS_IQK_OFFLOAD 0X2
+#define CLASS_MACID_CFG_3SS 0X2
+#define CLASS_RA_PARA_ADJUST 0X02
+#define CLASS_WWLAN 0X4
+#define CLASS_REMOTE_WAKE_CTRL 0X4
+#define CLASS_AOAC_GLOBAL_INFO 0X04
+#define CLASS_AOAC_RSVD_PAGE 0X04
+#define CLASS_AOAC_RSVD_PAGE2 0X04
+#define CLASS_D0_SCAN_OFFLOAD_INFO 0X04
+#define CLASS_CHANNEL_SWITCH_OFFLOAD 0X04
+#define CLASS_AOAC_RSVD_PAGE3 0X04
+#define CLASS_DBG_MSG_CTRL 0X07
+#define ORIGINAL_H2C_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define ORIGINAL_H2C_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define ORIGINAL_H2C_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define ORIGINAL_H2C_SET_CLASS(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define H2C2H_LB_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define H2C2H_LB_SET_CMD_ID(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define H2C2H_LB_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define H2C2H_LB_SET_CLASS(h2c_pkt, value)                                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define H2C2H_LB_GET_SEQ(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define H2C2H_LB_SET_SEQ(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define H2C2H_LB_GET_PAYLOAD1(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 16)
+#define H2C2H_LB_SET_PAYLOAD1(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 16, value)
+#define H2C2H_LB_GET_PAYLOAD2(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 32)
+#define H2C2H_LB_SET_PAYLOAD2(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 32, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_CMD_ID(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define D0_SCAN_OFFLOAD_CTRL_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_CLASS(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define D0_SCAN_OFFLOAD_CTRL_SET_CLASS(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_D0_SCAN_FUN_EN(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_D0_SCAN_FUN_EN(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_RTD3FUN_EN(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_RTD3FUN_EN(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_U3_SCAN_FUN_EN(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_U3_SCAN_FUN_EN(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_NLO_FUN_EN(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_NLO_FUN_EN(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_IPS_DEPENDENT(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
+#define D0_SCAN_OFFLOAD_CTRL_SET_IPS_DEPENDENT(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_PROBE_PACKET(h2c_pkt)                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 17)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_PROBE_PACKET(h2c_pkt, value)              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 17, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SCAN_INFO(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SCAN_INFO(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SSID_INFO(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SSID_INFO(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define RSVD_PAGE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define RSVD_PAGE_SET_CMD_ID(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define RSVD_PAGE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define RSVD_PAGE_SET_CLASS(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define RSVD_PAGE_GET_LOC_PROBE_RSP(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define RSVD_PAGE_SET_LOC_PROBE_RSP(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define RSVD_PAGE_GET_LOC_PS_POLL(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define RSVD_PAGE_SET_LOC_PS_POLL(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define RSVD_PAGE_GET_LOC_NULL_DATA(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define RSVD_PAGE_SET_LOC_NULL_DATA(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define RSVD_PAGE_GET_LOC_QOS_NULL(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define RSVD_PAGE_SET_LOC_QOS_NULL(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define RSVD_PAGE_GET_LOC_BT_QOS_NULL(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define RSVD_PAGE_SET_LOC_BT_QOS_NULL(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define RSVD_PAGE_GET_LOC_CTS2SELF(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
+#define RSVD_PAGE_SET_LOC_CTS2SELF(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
+#define RSVD_PAGE_GET_LOC_LTECOEX_QOSNULL(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
+#define RSVD_PAGE_SET_LOC_LTECOEX_QOSNULL(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
+#define MEDIA_STATUS_RPT_GET_CMD_ID(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define MEDIA_STATUS_RPT_SET_CMD_ID(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define MEDIA_STATUS_RPT_GET_CLASS(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define MEDIA_STATUS_RPT_SET_CLASS(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define MEDIA_STATUS_RPT_GET_OP_MODE(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define MEDIA_STATUS_RPT_SET_OP_MODE(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define MEDIA_STATUS_RPT_GET_MACID_IN(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define MEDIA_STATUS_RPT_SET_MACID_IN(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define MEDIA_STATUS_RPT_GET_MACID(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define MEDIA_STATUS_RPT_SET_MACID(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define MEDIA_STATUS_RPT_GET_MACID_END(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define MEDIA_STATUS_RPT_SET_MACID_END(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define KEEP_ALIVE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define KEEP_ALIVE_SET_CMD_ID(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define KEEP_ALIVE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define KEEP_ALIVE_SET_CLASS(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define KEEP_ALIVE_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define KEEP_ALIVE_SET_ENABLE(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define KEEP_ALIVE_GET_ADOPT_USER_SETTING(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define KEEP_ALIVE_SET_ADOPT_USER_SETTING(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define KEEP_ALIVE_GET_PKT_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define KEEP_ALIVE_SET_PKT_TYPE(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define KEEP_ALIVE_GET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define KEEP_ALIVE_SET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define DISCONNECT_DECISION_GET_CMD_ID(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define DISCONNECT_DECISION_SET_CMD_ID(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define DISCONNECT_DECISION_GET_CLASS(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define DISCONNECT_DECISION_SET_CLASS(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define DISCONNECT_DECISION_GET_ENABLE(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define DISCONNECT_DECISION_SET_ENABLE(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define DISCONNECT_DECISION_GET_ADOPT_USER_SETTING(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define DISCONNECT_DECISION_SET_ADOPT_USER_SETTING(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt)              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt, value)       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define DISCONNECT_DECISION_GET_DISCONNECT_EN(h2c_pkt)                         \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
+#define DISCONNECT_DECISION_SET_DISCONNECT_EN(h2c_pkt, value)                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
+#define DISCONNECT_DECISION_GET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt)          \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define DISCONNECT_DECISION_SET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt, value)   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define DISCONNECT_DECISION_GET_TRY_PKT_NUM(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define DISCONNECT_DECISION_SET_TRY_PKT_NUM(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt)           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt, value)    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define AP_OFFLOAD_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define AP_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define AP_OFFLOAD_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define AP_OFFLOAD_SET_CLASS(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define AP_OFFLOAD_GET_ON(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define AP_OFFLOAD_SET_ON(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define AP_OFFLOAD_GET_CFG_MIFI_PLATFORM(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define AP_OFFLOAD_SET_CFG_MIFI_PLATFORM(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define AP_OFFLOAD_GET_LINKED(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define AP_OFFLOAD_SET_LINKED(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define AP_OFFLOAD_GET_EN_AUTO_WAKE(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
+#define AP_OFFLOAD_SET_EN_AUTO_WAKE(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
+#define AP_OFFLOAD_GET_WAKE_FLAG(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
+#define AP_OFFLOAD_SET_WAKE_FLAG(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_ROOT(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 1)
+#define AP_OFFLOAD_SET_HIDDEN_ROOT(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP1(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 17, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP1(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 17, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP2(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 18, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP2(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 18, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP3(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 19, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP3(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 19, 1, value)
+#define AP_OFFLOAD_GET_HIDDEN_VAP4(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 20, 1)
+#define AP_OFFLOAD_SET_HIDDEN_VAP4(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 20, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_ROOT(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 1)
+#define AP_OFFLOAD_SET_DENYANY_ROOT(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP1(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 25, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP1(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 25, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP2(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 26, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP2(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 26, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP3(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 27, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP3(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 27, 1, value)
+#define AP_OFFLOAD_GET_DENYANY_VAP4(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 28, 1)
+#define AP_OFFLOAD_SET_DENYANY_VAP4(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 28, 1, value)
+#define AP_OFFLOAD_GET_WAIT_TBTT_CNT(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define AP_OFFLOAD_SET_WAIT_TBTT_CNT(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define AP_OFFLOAD_GET_WAKE_TIMEOUT(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define AP_OFFLOAD_SET_WAKE_TIMEOUT(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define AP_OFFLOAD_GET_LEN_IV_PAIR(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
+#define AP_OFFLOAD_SET_LEN_IV_PAIR(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
+#define AP_OFFLOAD_GET_LEN_IV_GRP(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
+#define AP_OFFLOAD_SET_LEN_IV_GRP(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
+#define BCN_RSVDPAGE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define BCN_RSVDPAGE_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define BCN_RSVDPAGE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define BCN_RSVDPAGE_SET_CLASS(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define BCN_RSVDPAGE_GET_LOC_ROOT(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define BCN_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP1(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP2(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP3(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define BCN_RSVDPAGE_GET_LOC_VAP4(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define BCN_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_CMD_ID(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define PROBE_RSP_RSVDPAGE_SET_CMD_ID(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define PROBE_RSP_RSVDPAGE_GET_CLASS(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define PROBE_RSP_RSVDPAGE_SET_CLASS(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_ROOT(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP1(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP2(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP3(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP4(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_GET_CMD_ID(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define SINGLE_CHANNELSWITCH_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define SINGLE_CHANNELSWITCH_GET_CLASS(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define SINGLE_CHANNELSWITCH_SET_CLASS(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define SINGLE_CHANNELSWITCH_GET_CHANNEL_NUM(h2c_pkt)                          \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define SINGLE_CHANNELSWITCH_SET_CHANNEL_NUM(h2c_pkt, value)                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_GET_BW(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 2)
+#define SINGLE_CHANNELSWITCH_SET_BW(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 2, value)
+#define SINGLE_CHANNELSWITCH_GET_BW40SC(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 18, 3)
+#define SINGLE_CHANNELSWITCH_SET_BW40SC(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 18, 3, value)
+#define SINGLE_CHANNELSWITCH_GET_BW80SC(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 21, 3)
+#define SINGLE_CHANNELSWITCH_SET_BW80SC(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 21, 3, value)
+#define SINGLE_CHANNELSWITCH_GET_RFE_TYPE(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 4)
+#define SINGLE_CHANNELSWITCH_SET_RFE_TYPE(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 4, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_CMD_ID(h2c_pkt)                            \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define SINGLE_CHANNELSWITCH_V2_SET_CMD_ID(h2c_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_CLASS(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define SINGLE_CHANNELSWITCH_V2_SET_CLASS(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_CENTRAL_CH(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define SINGLE_CHANNELSWITCH_V2_SET_CENTRAL_CH(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_PRIMARY_CH_IDX(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 4)
+#define SINGLE_CHANNELSWITCH_V2_SET_PRIMARY_CH_IDX(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 4, value)
+#define SINGLE_CHANNELSWITCH_V2_GET_BW(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 20, 4)
+#define SINGLE_CHANNELSWITCH_V2_SET_BW(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 20, 4, value)
+#define SET_PWR_MODE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define SET_PWR_MODE_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define SET_PWR_MODE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define SET_PWR_MODE_SET_CLASS(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define SET_PWR_MODE_GET_MODE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 7)
+#define SET_PWR_MODE_SET_MODE(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 7, value)
+#define SET_PWR_MODE_GET_CLK_REQUEST(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
+#define SET_PWR_MODE_SET_CLK_REQUEST(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
+#define SET_PWR_MODE_GET_RLBM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 4)
+#define SET_PWR_MODE_SET_RLBM(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 4, value)
+#define SET_PWR_MODE_GET_SMART_PS(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 20, 4)
+#define SET_PWR_MODE_SET_SMART_PS(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 20, 4, value)
+#define SET_PWR_MODE_GET_AWAKE_INTERVAL(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define SET_PWR_MODE_SET_AWAKE_INTERVAL(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define SET_PWR_MODE_GET_B_ALL_QUEUE_UAPSD(h2c_pkt)                            \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 1)
+#define SET_PWR_MODE_SET_B_ALL_QUEUE_UAPSD(h2c_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 1, value)
+#define SET_PWR_MODE_GET_BCN_EARLY_RPT(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 2, 1)
+#define SET_PWR_MODE_SET_BCN_EARLY_RPT(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 2, 1, value)
+#define SET_PWR_MODE_GET_PORT_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 5, 3)
+#define SET_PWR_MODE_SET_PORT_ID(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 5, 3, value)
+#define SET_PWR_MODE_GET_PWR_STATE(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define SET_PWR_MODE_SET_PWR_STATE(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define SET_PWR_MODE_GET_LOW_POWER_RX_BCN(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 1)
+#define SET_PWR_MODE_SET_LOW_POWER_RX_BCN(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 1, value)
+#define SET_PWR_MODE_GET_ANT_AUTO_SWITCH(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 17, 1)
+#define SET_PWR_MODE_SET_ANT_AUTO_SWITCH(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 17, 1, value)
+#define SET_PWR_MODE_GET_PS_ALLOW_BT_HIGH_PRIORITY(h2c_pkt)                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 18, 1)
+#define SET_PWR_MODE_SET_PS_ALLOW_BT_HIGH_PRIORITY(h2c_pkt, value)             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 18, 1, value)
+#define SET_PWR_MODE_GET_PROTECT_BCN(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 19, 1)
+#define SET_PWR_MODE_SET_PROTECT_BCN(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 19, 1, value)
+#define SET_PWR_MODE_GET_SILENCE_PERIOD(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 20, 1)
+#define SET_PWR_MODE_SET_SILENCE_PERIOD(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 20, 1, value)
+#define SET_PWR_MODE_GET_FAST_BT_CONNECT(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 21, 1)
+#define SET_PWR_MODE_SET_FAST_BT_CONNECT(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 21, 1, value)
+#define SET_PWR_MODE_GET_TWO_ANTENNA_EN(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 22, 1)
+#define SET_PWR_MODE_SET_TWO_ANTENNA_EN(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 22, 1, value)
+#define SET_PWR_MODE_GET_ADOPT_USER_SETTING(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 1)
+#define SET_PWR_MODE_SET_ADOPT_USER_SETTING(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 1, value)
+#define SET_PWR_MODE_GET_DRV_BCN_EARLY_SHIFT(h2c_pkt)                          \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 25, 3)
+#define SET_PWR_MODE_SET_DRV_BCN_EARLY_SHIFT(h2c_pkt, value)                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 25, 3, value)
+#define SET_PWR_MODE_GET_DRV_BCN_EARLY_SHIFT2(h2c_pkt)                         \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 28, 4)
+#define SET_PWR_MODE_SET_DRV_BCN_EARLY_SHIFT2(h2c_pkt, value)                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 28, 4, value)
+#define PS_TUNING_PARA_GET_CMD_ID(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define PS_TUNING_PARA_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define PS_TUNING_PARA_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define PS_TUNING_PARA_SET_CLASS(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define PS_TUNING_PARA_GET_BCN_TO_LIMIT(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 7)
+#define PS_TUNING_PARA_SET_BCN_TO_LIMIT(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 7, value)
+#define PS_TUNING_PARA_GET_DTIM_TIME_OUT(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
+#define PS_TUNING_PARA_SET_DTIM_TIME_OUT(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
+#define PS_TUNING_PARA_GET_PS_TIME_OUT(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 4)
+#define PS_TUNING_PARA_SET_PS_TIME_OUT(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 4, value)
+#define PS_TUNING_PARA_GET_ADOPT(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define PS_TUNING_PARA_SET_ADOPT(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define PS_TUNING_PARA_II_GET_CMD_ID(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define PS_TUNING_PARA_II_SET_CMD_ID(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define PS_TUNING_PARA_II_GET_CLASS(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define PS_TUNING_PARA_II_SET_CLASS(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define PS_TUNING_PARA_II_GET_BCN_TO_PERIOD(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 7)
+#define PS_TUNING_PARA_II_SET_BCN_TO_PERIOD(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 7, value)
+#define PS_TUNING_PARA_II_GET_ADOPT(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
+#define PS_TUNING_PARA_II_SET_ADOPT(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
+#define PS_TUNING_PARA_II_GET_DRV_EARLY_IVL(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define PS_TUNING_PARA_II_SET_DRV_EARLY_IVL(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define PS_LPS_PARA_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define PS_LPS_PARA_SET_CMD_ID(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define PS_LPS_PARA_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define PS_LPS_PARA_SET_CLASS(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define PS_LPS_PARA_GET_LPS_CONTROL(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define PS_LPS_PARA_SET_LPS_CONTROL(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define P2P_PS_OFFLOAD_GET_CMD_ID(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define P2P_PS_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define P2P_PS_OFFLOAD_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define P2P_PS_OFFLOAD_SET_CLASS(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define P2P_PS_OFFLOAD_GET_OFFLOAD_EN(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define P2P_PS_OFFLOAD_SET_OFFLOAD_EN(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define P2P_PS_OFFLOAD_GET_ROLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define P2P_PS_OFFLOAD_SET_ROLE(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define P2P_PS_OFFLOAD_GET_CTWINDOW_EN(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define P2P_PS_OFFLOAD_SET_CTWINDOW_EN(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define P2P_PS_OFFLOAD_GET_NOA0_EN(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
+#define P2P_PS_OFFLOAD_SET_NOA0_EN(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
+#define P2P_PS_OFFLOAD_GET_NOA1_EN(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
+#define P2P_PS_OFFLOAD_SET_NOA1_EN(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
+#define P2P_PS_OFFLOAD_GET_ALL_STA_SLEEP(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 13, 1)
+#define P2P_PS_OFFLOAD_SET_ALL_STA_SLEEP(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 13, 1, value)
+#define P2P_PS_OFFLOAD_GET_DISCOVERY(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 14, 1)
+#define P2P_PS_OFFLOAD_SET_DISCOVERY(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 14, 1, value)
+#define PS_SCAN_EN_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define PS_SCAN_EN_SET_CMD_ID(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define PS_SCAN_EN_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define PS_SCAN_EN_SET_CLASS(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define PS_SCAN_EN_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define PS_SCAN_EN_SET_ENABLE(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define SAP_PS_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define SAP_PS_SET_CMD_ID(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define SAP_PS_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define SAP_PS_SET_CLASS(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define SAP_PS_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define SAP_PS_SET_ENABLE(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define SAP_PS_GET_EN_PS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define SAP_PS_SET_EN_PS(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define SAP_PS_GET_EN_LP_RX(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define SAP_PS_SET_EN_LP_RX(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define SAP_PS_GET_MANUAL_32K(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
+#define SAP_PS_SET_MANUAL_32K(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
+#define SAP_PS_GET_DURATION(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define SAP_PS_SET_DURATION(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define INACTIVE_PS_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define INACTIVE_PS_SET_CMD_ID(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define INACTIVE_PS_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define INACTIVE_PS_SET_CLASS(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define INACTIVE_PS_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define INACTIVE_PS_SET_ENABLE(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define INACTIVE_PS_GET_IGNORE_PS_CONDITION(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define INACTIVE_PS_SET_IGNORE_PS_CONDITION(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define INACTIVE_PS_GET_FREQUENCY(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define INACTIVE_PS_SET_FREQUENCY(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define INACTIVE_PS_GET_DURATION(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define INACTIVE_PS_SET_DURATION(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define MACID_CFG_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define MACID_CFG_SET_CMD_ID(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define MACID_CFG_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define MACID_CFG_SET_CLASS(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define MACID_CFG_GET_MAC_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define MACID_CFG_SET_MAC_ID(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define MACID_CFG_GET_RATE_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 5)
+#define MACID_CFG_SET_RATE_ID(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 5, value)
+#define MACID_CFG_GET_INIT_RATE_LV(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 21, 2)
+#define MACID_CFG_SET_INIT_RATE_LV(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 21, 2, value)
+#define MACID_CFG_GET_SGI(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 23, 1)
+#define MACID_CFG_SET_SGI(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 23, 1, value)
+#define MACID_CFG_GET_BW(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 2)
+#define MACID_CFG_SET_BW(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 2, value)
+#define MACID_CFG_GET_LDPC_CAP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 26, 1)
+#define MACID_CFG_SET_LDPC_CAP(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 26, 1, value)
+#define MACID_CFG_GET_NO_UPDATE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 27, 1)
+#define MACID_CFG_SET_NO_UPDATE(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 27, 1, value)
+#define MACID_CFG_GET_WHT_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 28, 2)
+#define MACID_CFG_SET_WHT_EN(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 28, 2, value)
+#define MACID_CFG_GET_DISPT(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 30, 1)
+#define MACID_CFG_SET_DISPT(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 30, 1, value)
+#define MACID_CFG_GET_DISRA(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 31, 1)
+#define MACID_CFG_SET_DISRA(h2c_pkt, value)                                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 31, 1, value)
+#define MACID_CFG_GET_RATE_MASK7_0(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define MACID_CFG_SET_RATE_MASK7_0(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define MACID_CFG_GET_RATE_MASK15_8(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define MACID_CFG_SET_RATE_MASK15_8(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define MACID_CFG_GET_RATE_MASK23_16(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
+#define MACID_CFG_SET_RATE_MASK23_16(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
+#define MACID_CFG_GET_RATE_MASK31_24(h2c_pkt)                                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
+#define MACID_CFG_SET_RATE_MASK31_24(h2c_pkt, value)                           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
+#define TXBF_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define TXBF_SET_CMD_ID(h2c_pkt, value)                                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define TXBF_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define TXBF_SET_CLASS(h2c_pkt, value)                                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define TXBF_GET_NDPA0_HEAD_PAGE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define TXBF_SET_NDPA0_HEAD_PAGE(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define TXBF_GET_NDPA1_HEAD_PAGE(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define TXBF_SET_NDPA1_HEAD_PAGE(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define TXBF_GET_PERIOD_0(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define TXBF_SET_PERIOD_0(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define RSSI_SETTING_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define RSSI_SETTING_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define RSSI_SETTING_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define RSSI_SETTING_SET_CLASS(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define RSSI_SETTING_GET_MAC_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define RSSI_SETTING_SET_MAC_ID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define RSSI_SETTING_GET_RSSI(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 7)
+#define RSSI_SETTING_SET_RSSI(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 7, value)
+#define RSSI_SETTING_GET_RA_INFO(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define RSSI_SETTING_SET_RA_INFO(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define AP_REQ_TXRPT_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define AP_REQ_TXRPT_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define AP_REQ_TXRPT_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define AP_REQ_TXRPT_SET_CLASS(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define AP_REQ_TXRPT_GET_STA1_MACID(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define AP_REQ_TXRPT_SET_STA1_MACID(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define AP_REQ_TXRPT_GET_STA2_MACID(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define AP_REQ_TXRPT_SET_STA2_MACID(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define AP_REQ_TXRPT_GET_RTY_OK_TOTAL(h2c_pkt)                                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 1)
+#define AP_REQ_TXRPT_SET_RTY_OK_TOTAL(h2c_pkt, value)                          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 1, value)
+#define AP_REQ_TXRPT_GET_RTY_CNT_MACID(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 25, 1)
+#define AP_REQ_TXRPT_SET_RTY_CNT_MACID(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 25, 1, value)
+#define INIT_RATE_COLLECTION_GET_CMD_ID(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define INIT_RATE_COLLECTION_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define INIT_RATE_COLLECTION_GET_CLASS(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define INIT_RATE_COLLECTION_SET_CLASS(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define INIT_RATE_COLLECTION_GET_STA1_MACID(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define INIT_RATE_COLLECTION_SET_STA1_MACID(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA2_MACID(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define INIT_RATE_COLLECTION_SET_STA2_MACID(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA3_MACID(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define INIT_RATE_COLLECTION_SET_STA3_MACID(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA4_MACID(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define INIT_RATE_COLLECTION_SET_STA4_MACID(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA5_MACID(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define INIT_RATE_COLLECTION_SET_STA5_MACID(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA6_MACID(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
+#define INIT_RATE_COLLECTION_SET_STA6_MACID(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
+#define INIT_RATE_COLLECTION_GET_STA7_MACID(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
+#define INIT_RATE_COLLECTION_SET_STA7_MACID(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
+#define IQK_OFFLOAD_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define IQK_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define IQK_OFFLOAD_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define IQK_OFFLOAD_SET_CLASS(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define IQK_OFFLOAD_GET_CHANNEL(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define IQK_OFFLOAD_SET_CHANNEL(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define IQK_OFFLOAD_GET_BWBAND(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define IQK_OFFLOAD_SET_BWBAND(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define IQK_OFFLOAD_GET_EXTPALNA(h2c_pkt)                                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define IQK_OFFLOAD_SET_EXTPALNA(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define MACID_CFG_3SS_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define MACID_CFG_3SS_SET_CMD_ID(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define MACID_CFG_3SS_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define MACID_CFG_3SS_SET_CLASS(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define MACID_CFG_3SS_GET_MACID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define MACID_CFG_3SS_SET_MACID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define MACID_CFG_3SS_GET_RATE_MASK_39_32(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define MACID_CFG_3SS_SET_RATE_MASK_39_32(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define MACID_CFG_3SS_GET_RATE_MASK_47_40(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define MACID_CFG_3SS_SET_RATE_MASK_47_40(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define RA_PARA_ADJUST_GET_CMD_ID(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define RA_PARA_ADJUST_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define RA_PARA_ADJUST_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define RA_PARA_ADJUST_SET_CLASS(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define RA_PARA_ADJUST_GET_MAC_ID(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define RA_PARA_ADJUST_SET_MAC_ID(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define RA_PARA_ADJUST_GET_PARAMETER_INDEX(h2c_pkt)                            \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define RA_PARA_ADJUST_SET_PARAMETER_INDEX(h2c_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define RA_PARA_ADJUST_GET_RATE_ID(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define RA_PARA_ADJUST_SET_RATE_ID(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define RA_PARA_ADJUST_GET_VALUE_BYTE0(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define RA_PARA_ADJUST_SET_VALUE_BYTE0(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define RA_PARA_ADJUST_GET_VALUE_BYTE1(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define RA_PARA_ADJUST_SET_VALUE_BYTE1(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define RA_PARA_ADJUST_GET_ASK_FW_FOR_FW_PARA(h2c_pkt)                         \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
+#define RA_PARA_ADJUST_SET_ASK_FW_FOR_FW_PARA(h2c_pkt, value)                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
+#define WWLAN_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define WWLAN_SET_CMD_ID(h2c_pkt, value)                                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define WWLAN_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define WWLAN_SET_CLASS(h2c_pkt, value)                                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define WWLAN_GET_FUNC_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define WWLAN_SET_FUNC_EN(h2c_pkt, value)                                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define WWLAN_GET_PATTERM_MAT_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define WWLAN_SET_PATTERM_MAT_EN(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define WWLAN_GET_MAGIC_PKT_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define WWLAN_SET_MAGIC_PKT_EN(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define WWLAN_GET_UNICAST_WAKEUP_EN(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
+#define WWLAN_SET_UNICAST_WAKEUP_EN(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
+#define WWLAN_GET_ALL_PKT_DROP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
+#define WWLAN_SET_ALL_PKT_DROP(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
+#define WWLAN_GET_GPIO_ACTIVE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 13, 1)
+#define WWLAN_SET_GPIO_ACTIVE(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 13, 1, value)
+#define WWLAN_GET_REKEY_WAKEUP_EN(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 14, 1)
+#define WWLAN_SET_REKEY_WAKEUP_EN(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 14, 1, value)
+#define WWLAN_GET_DEAUTH_WAKEUP_EN(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
+#define WWLAN_SET_DEAUTH_WAKEUP_EN(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
+#define WWLAN_GET_GPIO_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 7)
+#define WWLAN_SET_GPIO_NUM(h2c_pkt, value)                                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 7, value)
+#define WWLAN_GET_DATAPIN_WAKEUP_EN(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 23, 1)
+#define WWLAN_SET_DATAPIN_WAKEUP_EN(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 23, 1, value)
+#define WWLAN_GET_GPIO_DURATION(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define WWLAN_SET_GPIO_DURATION(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define WWLAN_GET_GPIO_PLUS_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 1)
+#define WWLAN_SET_GPIO_PLUS_EN(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 1, value)
+#define WWLAN_GET_GPIO_PULSE_COUNT(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 1, 7)
+#define WWLAN_SET_GPIO_PULSE_COUNT(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 1, 7, value)
+#define WWLAN_GET_DISABLE_UPHY(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 1)
+#define WWLAN_SET_DISABLE_UPHY(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 1, value)
+#define WWLAN_GET_HST2DEV_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 9, 1)
+#define WWLAN_SET_HST2DEV_EN(h2c_pkt, value)                                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 9, 1, value)
+#define WWLAN_GET_GPIO_DURATION_MS(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 10, 1)
+#define WWLAN_SET_GPIO_DURATION_MS(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 10, 1, value)
+#define REMOTE_WAKE_CTRL_GET_CMD_ID(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define REMOTE_WAKE_CTRL_SET_CMD_ID(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define REMOTE_WAKE_CTRL_GET_CLASS(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define REMOTE_WAKE_CTRL_SET_CLASS(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define REMOTE_WAKE_CTRL_GET_REMOTE_WAKE_CTRL_EN(h2c_pkt)                      \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define REMOTE_WAKE_CTRL_SET_REMOTE_WAKE_CTRL_EN(h2c_pkt, value)               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define REMOTE_WAKE_CTRL_GET_ARP_EN(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
+#define REMOTE_WAKE_CTRL_SET_ARP_EN(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
+#define REMOTE_WAKE_CTRL_GET_NDP_EN(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
+#define REMOTE_WAKE_CTRL_SET_NDP_EN(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
+#define REMOTE_WAKE_CTRL_GET_GTK_EN(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
+#define REMOTE_WAKE_CTRL_SET_GTK_EN(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
+#define REMOTE_WAKE_CTRL_GET_NLO_OFFLOAD_EN(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
+#define REMOTE_WAKE_CTRL_SET_NLO_OFFLOAD_EN(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
+#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V1_EN(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 13, 1)
+#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V1_EN(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 13, 1, value)
+#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V2_EN(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 14, 1)
+#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V2_EN(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 14, 1, value)
+#define REMOTE_WAKE_CTRL_GET_FW_UNICAST(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
+#define REMOTE_WAKE_CTRL_SET_FW_UNICAST(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
+#define REMOTE_WAKE_CTRL_GET_P2P_OFFLOAD_EN(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 1)
+#define REMOTE_WAKE_CTRL_SET_P2P_OFFLOAD_EN(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 1, value)
+#define REMOTE_WAKE_CTRL_GET_RUNTIME_PM_EN(h2c_pkt)                            \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 17, 1)
+#define REMOTE_WAKE_CTRL_SET_RUNTIME_PM_EN(h2c_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 17, 1, value)
+#define REMOTE_WAKE_CTRL_GET_NET_BIOS_DROP_EN(h2c_pkt)                         \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 18, 1)
+#define REMOTE_WAKE_CTRL_SET_NET_BIOS_DROP_EN(h2c_pkt, value)                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 18, 1, value)
+#define REMOTE_WAKE_CTRL_GET_ARP_ACTION(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 1)
+#define REMOTE_WAKE_CTRL_SET_ARP_ACTION(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 1, value)
+#define REMOTE_WAKE_CTRL_GET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt)                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 28, 1)
+#define REMOTE_WAKE_CTRL_SET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt, value)           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 28, 1, value)
+#define REMOTE_WAKE_CTRL_GET_FW_PARSING_AFTER_WAKEUP(h2c_pkt)                  \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 29, 1)
+#define REMOTE_WAKE_CTRL_SET_FW_PARSING_AFTER_WAKEUP(h2c_pkt, value)           \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 29, 1, value)
+#define AOAC_GLOBAL_INFO_GET_CMD_ID(h2c_pkt)                                   \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define AOAC_GLOBAL_INFO_SET_CMD_ID(h2c_pkt, value)                            \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_GLOBAL_INFO_GET_CLASS(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define AOAC_GLOBAL_INFO_SET_CLASS(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_GLOBAL_INFO_GET_PAIR_WISE_ENC_ALG(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define AOAC_GLOBAL_INFO_SET_PAIR_WISE_ENC_ALG(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_GLOBAL_INFO_GET_GROUP_ENC_ALG(h2c_pkt)                            \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define AOAC_GLOBAL_INFO_SET_GROUP_ENC_ALG(h2c_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE_GET_CMD_ID(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define AOAC_RSVD_PAGE_SET_CMD_ID(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define AOAC_RSVD_PAGE_SET_CLASS(h2c_pkt, value)                               \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE_GET_LOC_REMOTE_CTRL_INFO(h2c_pkt)                       \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_REMOTE_CTRL_INFO(h2c_pkt, value)                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_ARP_RESPONSE(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_ARP_RESPONSE(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt)                 \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt, value)          \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_GTK_RSP(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_RSP(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_GTK_INFO(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_INFO(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_GTK_EXT_MEM(h2c_pkt)                            \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_GTK_EXT_MEM(h2c_pkt, value)                     \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
+#define AOAC_RSVD_PAGE_GET_LOC_NDP_INFO(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
+#define AOAC_RSVD_PAGE_SET_LOC_NDP_INFO(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
+#define AOAC_RSVD_PAGE2_GET_CMD_ID(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define AOAC_RSVD_PAGE2_SET_CMD_ID(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE2_GET_CLASS(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define AOAC_RSVD_PAGE2_SET_CLASS(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_ROUTER_SOLICATION(h2c_pkt)                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_ROUTER_SOLICATION(h2c_pkt, value)              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_BUBBLE_PACKET(h2c_pkt)                         \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_BUBBLE_PACKET(h2c_pkt, value)                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_TEREDO_INFO(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_TEREDO_INFO(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_REALWOW_INFO(h2c_pkt)                          \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_REALWOW_INFO(h2c_pkt, value)                   \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_KEEP_ALIVE_PKT(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_KEEP_ALIVE_PKT(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_ACK_PATTERN(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_ACK_PATTERN(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
+#define AOAC_RSVD_PAGE2_GET_LOC_WAKEUP_PATTERN(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
+#define AOAC_RSVD_PAGE2_SET_LOC_WAKEUP_PATTERN(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
+#define D0_SCAN_OFFLOAD_INFO_GET_CMD_ID(h2c_pkt)                               \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define D0_SCAN_OFFLOAD_INFO_SET_CMD_ID(h2c_pkt, value)                        \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define D0_SCAN_OFFLOAD_INFO_GET_CLASS(h2c_pkt)                                \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define D0_SCAN_OFFLOAD_INFO_SET_CLASS(h2c_pkt, value)                         \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define D0_SCAN_OFFLOAD_INFO_GET_LOC_CHANNEL_INFO(h2c_pkt)                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define D0_SCAN_OFFLOAD_INFO_SET_LOC_CHANNEL_INFO(h2c_pkt, value)              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_CMD_ID(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CMD_ID(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_CLASS(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CLASS(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_CHANNEL_NUM(h2c_pkt)                        \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define CHANNEL_SWITCH_OFFLOAD_SET_CHANNEL_NUM(h2c_pkt, value)                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_EN_RFE(h2c_pkt)                             \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define CHANNEL_SWITCH_OFFLOAD_SET_EN_RFE(h2c_pkt, value)                      \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define CHANNEL_SWITCH_OFFLOAD_GET_RFE_TYPE(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
+#define CHANNEL_SWITCH_OFFLOAD_SET_RFE_TYPE(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
+#define AOAC_RSVD_PAGE3_GET_CMD_ID(h2c_pkt)                                    \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define AOAC_RSVD_PAGE3_SET_CMD_ID(h2c_pkt, value)                             \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define AOAC_RSVD_PAGE3_GET_CLASS(h2c_pkt)                                     \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define AOAC_RSVD_PAGE3_SET_CLASS(h2c_pkt, value)                              \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define AOAC_RSVD_PAGE3_GET_LOC_NLO_INFO(h2c_pkt)                              \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
+#define AOAC_RSVD_PAGE3_SET_LOC_NLO_INFO(h2c_pkt, value)                       \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
+#define AOAC_RSVD_PAGE3_GET_LOC_AOAC_REPORT(h2c_pkt)                           \
+	LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
+#define AOAC_RSVD_PAGE3_SET_LOC_AOAC_REPORT(h2c_pkt, value)                    \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
+#define DBG_MSG_CTRL_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
+#define DBG_MSG_CTRL_SET_CMD_ID(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
+#define DBG_MSG_CTRL_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
+#define DBG_MSG_CTRL_SET_CLASS(h2c_pkt, value)                                 \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
+#define DBG_MSG_CTRL_GET_FUN_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
+#define DBG_MSG_CTRL_SET_FUN_EN(h2c_pkt, value)                                \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
+#define DBG_MSG_CTRL_GET_MODE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 4)
+#define DBG_MSG_CTRL_SET_MODE(h2c_pkt, value)                                  \
+	SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 4, value)
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_pcie_reg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_pcie_reg.h
new file mode 100644
index 000000000000..a2406bea00be
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_pcie_reg.h
@@ -0,0 +1,36 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 __HALMAC_PCIE_REG_H__
+#define __HALMAC_PCIE_REG_H__
+
+/* PCIE PHY register */
+#define RAC_CTRL_PPR		0x00
+#define RAC_SET_PPR		0x20
+#define RAC_TRG_PPR		0x21
+
+/* PCIE CFG register */
+#define PCIE_L1_BACKDOOR		0x719
+#define PCIE_ASPM_CTRL			0x70F
+
+/* PCIE MAC register */
+#define LINK_CTRL2_REG_OFFSET		0xA0
+#define GEN2_CTRL_OFFSET		0x80C
+#define LINK_STATUS_REG_OFFSET		0x82
+
+#define PCIE_GEN1_SPEED			0x01
+#define PCIE_GEN2_SPEED			0x02
+
+#endif/* __HALMAC_PCIE_REG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_pwr_seq_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_pwr_seq_cmd.h
new file mode 100644
index 000000000000..23d5dbe4edee
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_pwr_seq_cmd.h
@@ -0,0 +1,111 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 HALMAC_POWER_SEQUENCE_CMD
+#define HALMAC_POWER_SEQUENCE_CMD
+
+#include "halmac_2_platform.h"
+
+#define HALMAC_PWR_POLLING_CNT 20000
+
+/*
+ * The value of cmd : 4 bits
+ */
+
+/*
+ * 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	HALMAC_PWR_CMD_READ		0x00
+/*
+ * 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	HALMAC_PWR_CMD_WRITE	0x01
+/*
+ * 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	HALMAC_PWR_CMD_POLLING	0x02
+/*
+ * offset: the value to delay
+ * msk: N/A
+ * value: the unit of delay, 0: us, 1: ms
+ */
+#define	HALMAC_PWR_CMD_DELAY	0x03
+/*
+ * offset: N/A
+ * msk: N/A
+ * value: N/A
+ */
+#define	HALMAC_PWR_CMD_END	0x04
+
+/*
+ * The value of base : 4 bits
+ */
+
+/* define the base address of each block */
+#define   HALMAC_PWR_ADDR_MAC	0x00
+#define   HALMAC_PWR_ADDR_USB	0x01
+#define   HALMAC_PWR_ADDR_PCIE	0x02
+#define   HALMAC_PWR_ADDR_SDIO	0x03
+
+/*
+ * The value of interface_msk : 4 bits
+ */
+#define	HALMAC_PWR_INTF_SDIO_MSK	BIT(0)
+#define	HALMAC_PWR_INTF_USB_MSK		BIT(1)
+#define	HALMAC_PWR_INTF_PCI_MSK		BIT(2)
+#define	HALMAC_PWR_INTF_ALL_MSK		(BIT(0) | BIT(1) | BIT(2) | BIT(3))
+
+/*
+ * The value of cut_msk : 8 bits
+ */
+#define	HALMAC_PWR_CUT_TESTCHIP_MSK		BIT(0)
+#define	HALMAC_PWR_CUT_A_MSK			BIT(1)
+#define	HALMAC_PWR_CUT_B_MSK			BIT(2)
+#define	HALMAC_PWR_CUT_C_MSK			BIT(3)
+#define	HALMAC_PWR_CUT_D_MSK			BIT(4)
+#define	HALMAC_PWR_CUT_E_MSK			BIT(5)
+#define	HALMAC_PWR_CUT_F_MSK			BIT(6)
+#define	HALMAC_PWR_CUT_G_MSK			BIT(7)
+#define	HALMAC_PWR_CUT_ALL_MSK			0xFF
+
+enum halmac_pwrseq_cmd_delay_unit {
+	HALMAC_PWR_DELAY_US,
+	HALMAC_PWR_DELAY_MS,
+};
+
+struct halmac_wlan_pwr_cfg {
+	u16 offset;
+	u8 cut_msk;
+	u8 interface_msk;
+	u8 base:4;
+	u8 cmd:4;
+	u8 msk;
+	u8 value;
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg2.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg2.h
new file mode 100644
index 000000000000..f20eaa4c69bc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg2.h
@@ -0,0 +1,6954 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 __HALMAC_COM_REG_H__
+#define __HALMAC_COM_REG_H__
+
+#include "halmac_hw_cfg.h"
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_ISO_CTRL 0x0000
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_TX_CTRL 0x10250000
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_FUNC_EN 0x0002
+#define REG_SYS_PW_CTRL 0x0004
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_CMD11_VOL_SWITCH 0x10250004
+#define REG_SDIO_DRIVING 0x10250006
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_CLK_CTRL 0x0008
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_MONITOR 0x10250008
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_EEPROM_CTRL 0x000A
+#define REG_EE_VPD 0x000C
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_MONITOR_2 0x1025000C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_SWR_CTRL1 0x0010
+#define REG_SYS_SWR_CTRL2 0x0014
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HIMR 0x10250014
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_SWR_CTRL3 0x0018
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HISR 0x10250018
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RSV_CTRL 0x001C
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_RX_REQ_LEN 0x1025001C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RF_CTRL 0x001F
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_RF0_CTRL 0x001F
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_FREE_TXPG_SEQ_V1 0x1025001F
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_AFE_LDO_CTRL 0x0020
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_FREE_TXPG 0x10250020
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_AFE_CTRL1 0x0024
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_FREE_TXPG2 0x10250024
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_AFE_CTRL2 0x0028
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_OQT_FREE_TXPG_V1 0x10250028
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPARSW_POW_MAC 0x0028
+#define REG_ANAPARLDO_POW_MAC 0x0029
+#define REG_ANAPAR_POW_MAC 0x002A
+#define REG_ANAPAR_POW_XTAL 0x002B
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_AFE_CTRL3 0x002C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPARLDO_MAC 0x002C
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_TXPKT_EMPTY 0x1025002C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_EFUSE_CTRL 0x0030
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HTSFR_INFO 0x10250030
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_LDO_EFUSE_CTRL 0x0034
+#define REG_PWR_OPTION_CTRL 0x0038
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HCPWM1_V2 0x10250038
+#define REG_SDIO_HCPWM2_V2 0x1025003A
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_CAL_TIMER 0x003C
+#define REG_ACLK_MON 0x003E
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_GPIO_MUXCFG_2 0x003F
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_GPIO_MUXCFG 0x0040
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_INDIRECT_REG_CFG 0x10250040
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_GPIO_PIN_CTRL 0x0044
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_INDIRECT_REG_DATA 0x10250044
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_GPIO_INTM 0x0048
+#define REG_LED_CFG 0x004C
+#define REG_FSIMR 0x0050
+#define REG_FSISR 0x0054
+#define REG_HSIMR 0x0058
+#define REG_HSISR 0x005C
+#define REG_GPIO_EXT_CTRL 0x0060
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_H2C 0x10250060
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PAD_CTRL1 0x0064
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_C2H 0x10250064
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_WL_BT_PWR_CTRL 0x0068
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_SDM_DEBUG 0x006C
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_GSSR 0x006C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_SDIO_CTRL 0x0070
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_SYS_CLKR 0x0070
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_HCI_OPT_CTRL 0x0074
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_AFE_CTRL4 0x0078
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_AFE_XTAL_CTRL_EXT 0x0078
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_HCI_BG_CTRL 0x0078
+#define REG_HCI_LDO_CTRL 0x007A
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_LDO_SWR_CTRL 0x007C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_8051FW_CTRL 0x0080
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MCUFW_CTRL 0x0080
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HRPWM1 0x10250080
+#define REG_SDIO_HRPWM2 0x10250082
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_MCU_TST_CFG 0x0084
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HPS_CLKR 0x10250084
+#define REG_SDIO_BUS_CTRL 0x10250085
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HSUS_CTRL 0x10250086
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_HMEBOX_E0_E1 0x0088
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_RESPONSE_TIMER 0x10250088
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_CMD_CRC 0x1025008A
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_HMEBOX_E2_E3 0x008C
+#define REG_WLLPS_CTRL 0x0090
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HSISR 0x10250090
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_HSIMR 0x10250091
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_AFE_CTRL5 0x0094
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_GPIO_DEBOUNCE_CTRL 0x0098
+#define REG_RPWM2 0x009C
+#define REG_SYSON_FSM_MON 0x00A0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_AFE_CTRL6 0x00A4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PMC_DBG_CTRL1 0x00A8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_AFE_CTRL7 0x00AC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_HIMR0 0x00B0
+#define REG_HISR0 0x00B4
+#define REG_HIMR1 0x00B8
+#define REG_HISR1 0x00BC
+#define REG_DBG_PORT_SEL 0x00C0
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_SDIO_ERR_RPT 0x102500C0
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_DIOERR_RPT 0x102500C0
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_CMD_ERRCNT 0x102500C2
+#define REG_SDIO_DATA_ERRCNT 0x102500C3
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PAD_CTRL2 0x00C4
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_CMD_ERR_CONTENT 0x102500C4
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_MEM_RMC 0x00C8
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_CRC_ERR_IDX 0x102500C9
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_DATA_CRC 0x102500CA
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_SDIO_DATA_REPLY_TIME 0x102500CB
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PMC_DBG_CTRL2 0x00CC
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_SDIO_TRANS_FIFO_STATUS 0x102500CC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BIST_CTRL 0x00D0
+#define REG_BIST_RPT 0x00D4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_MEM_CTRL 0x00D8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT)
+
+#define REG_AFE_CTRL8 0x00DC
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_WLAN_DBG 0x00DC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_SYN_RFC_CTRL 0x00DC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_USB_SIE_INTF 0x00E0
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_SYS_PINMUX 0x00E0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PCIE_MIO_INTF 0x00E4
+#define REG_PCIE_MIO_INTD 0x00E8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_WLRF1 0x00EC
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_HPON_FSM 0x00EC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SYS_CFG1 0x00F0
+#define REG_SYS_STATUS1 0x00F4
+#define REG_SYS_STATUS2 0x00F8
+#define REG_SYS_CFG2 0x00FC
+#define REG_CR 0x0100
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PG_SIZE 0x0104
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PKT_BUFF_ACCESS_CTRL 0x0106
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TSF_CLK_STATE 0x0108
+#define REG_TXDMA_PQ_MAP 0x010C
+#define REG_TRXFF_BNDY 0x0114
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_PTA_I2C_MBOX 0x0118
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT)
+
+#define REG_FF_STATUS 0x0118
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RXFF_PTR 0x011C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_RXFF_BNDY 0x011C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_FEIMR 0x0120
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FE1IMR 0x0120
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_FEISR 0x0124
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FE1ISR 0x0124
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_CPWM 0x012C
+#define REG_FWIMR 0x0130
+#define REG_FWISR 0x0134
+#define REG_FTIMR 0x0138
+#define REG_FTISR 0x013C
+#define REG_PKTBUF_DBG_CTRL 0x0140
+#define REG_PKTBUF_DBG_DATA_L 0x0144
+#define REG_PKTBUF_DBG_DATA_H 0x0148
+#define REG_CPWM2 0x014C
+#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_TC5_CTRL 0x0168
+#define REG_TC6_CTRL 0x016C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_MBIST_FAIL 0x0170
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MBIST_DRF_FAIL 0x0170
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MBIST_START_PAUSE 0x0174
+#define REG_MBIST_DONE 0x0178
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MBIST_ROM_CRC_DATA 0x017C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_MBIST_FAIL_NRML 0x017C
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MBIST_READ_BIST_RPT 0x017C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_AES_DECRPT_DATA 0x0180
+#define REG_AES_DECRPT_CFG 0x0184
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_HIOE_CTRL 0x0188
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_MACCLKFRQ 0x018C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_HIOE_CFG_FILE 0x018C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TMETER 0x0190
+#define REG_OSC_32K_CTRL 0x0194
+#define REG_32K_CAL_REG1 0x0198
+#define REG_C2HEVT 0x01A0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_C2HEVT_1 0x01A4
+#define REG_C2HEVT_2 0x01A8
+#define REG_C2HEVT_3 0x01AC
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT)
+
+#define REG_TC7_CTRL 0x01B0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_RXDESC_BUFF_RPTR 0x01B0
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT)
+
+#define REG_TC8_CTRL 0x01B4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_RXDESC_BUFF_WPTR 0x01B4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SW_DEFINED_PAGE1 0x01B8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SW_DEFINED_PAGE2 0x01BC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_MCUTST_I 0x01C0
+#define REG_MCUTST_II 0x01C4
+#define REG_FMETHR 0x01C8
+#define REG_HMETFR 0x01CC
+#define REG_HMEBOX0 0x01D0
+#define REG_HMEBOX1 0x01D4
+#define REG_HMEBOX2 0x01D8
+#define REG_HMEBOX3 0x01DC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_LLT_INIT 0x01E0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_RXDESC_BUFF_BNDY 0x01E0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_GENTST 0x01E4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_LLT_INIT_ADDR 0x01E4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_BB_ACCESS_CTRL 0x01E8
+#define REG_BB_ACCESS_DATA 0x01EC
+#define REG_HMEBOX_E0 0x01F0
+#define REG_HMEBOX_E1 0x01F4
+#define REG_HMEBOX_E2 0x01F8
+#define REG_HMEBOX_E3 0x01FC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RQPN_CTRL_HLPQ 0x0200
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_FIFOPAGE_CTRL_1 0x0200
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCN_CTRL_0 0x0200
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_FIFOPAGE_INFO 0x0204
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_FIFOPAGE_CTRL_2 0x0204
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCN_CTRL_1 0x0204
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_DWBCN0_CTRL 0x0208
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_AUTO_LLT_V1 0x0208
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TXDMA_OFFSET_CHK 0x020C
+#define REG_TXDMA_STATUS 0x0210
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RQPN_NPQ 0x0214
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TX_DMA_DBG 0x0214
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TQPNT1 0x0218
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_DMA_RQPN_INFO_PUB 0x0218
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TQPNT2 0x021C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_RQPN_CTRL_2_V1 0x021C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TDE_DEBUG 0x0220
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_TQPNT3 0x0220
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCN_CTRL_2 0x0220
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_AUTO_LLT 0x0224
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_TQPNT4 0x0224
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_DWBCN1_CTRL 0x0228
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_RQPN_CTRL_1 0x0228
+#define REG_RQPN_CTRL_2 0x022C
+#define REG_FIFOPAGE_INFO_1 0x0230
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXPKTNUM_0 0x0230
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_FIFOPAGE_INFO_2 0x0234
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXPKTNUM_1 0x0234
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_FIFOPAGE_INFO_3 0x0238
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXPKTNUM_2 0x0238
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_FIFOPAGE_INFO_4 0x023C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXPKTNUM_3 0x023C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_FIFOPAGE_INFO_5 0x0240
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TX_AGG_ALIGN 0x0240
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_H2C_HEAD 0x0244
+#define REG_H2C_TAIL 0x0248
+#define REG_H2C_READ_ADDR 0x024C
+#define REG_H2C_WR_ADDR 0x0250
+#define REG_H2C_INFO 0x0254
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_TQPNT5 0x0260
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_DMA_OQT_0 0x0260
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_TQPNT6 0x0264
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_DMA_OQT_1 0x0264
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_FIFOPAGE_INFO_6 0x0268
+#define REG_FIFOPAGE_INFO_7 0x026C
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_PGSUB_CNT 0x026C
+#define REG_PGSUB_H 0x0270
+#define REG_PGSUB_N 0x0274
+#define REG_PGSUB_L 0x0278
+#define REG_PGSUB_E 0x027C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RXDMA_AGG_PG_TH 0x0280
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RXPKT_NUM 0x0284
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_RXDMA_CTRL 0x0284
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RXDMA_STATUS 0x0288
+#define REG_RXDMA_DPR 0x028C
+#define REG_RXDMA_MODE 0x0290
+#define REG_C2H_PKT 0x0294
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FWFF_C2H 0x0298
+#define REG_FWFF_CTRL 0x029C
+#define REG_FWFF_PKT_INFO 0x02A0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_FC2H_INFO 0x02A4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FWFF_PKT_INFO2 0x02A4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RXPKTNUM 0x02B0
+#define REG_RXPKTNUM_TH 0x02B4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FW_UPD_RXDES_RDPTR 0x02B8
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_FW_MSG1 0x02E0
+#define REG_FW_MSG2 0x02E4
+#define REG_FW_MSG3 0x02E8
+#define REG_FW_MSG4 0x02EC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_CTRL 0x0300
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_CTRL 0x0300
+
+#endif
+
+#if (HALMAC_8881A_SUPPORT)
+
+#define REG_LX_CTRL1 0x0300
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_INT_MIG 0x0304
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH_CTRL 0x0304
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BCNQ_TXBD_DESA 0x0308
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HIQ_CTRL 0x0308
+#define REG_INT_MIG_V1 0x030C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MGQ_TXBD_DESA 0x0310
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0MGQ_TXBD_DESA_L 0x0310
+#define REG_P0MGQ_TXBD_DESA_H 0x0314
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_VOQ_TXBD_DESA 0x0318
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH0_TXBD_DESA_L 0x0318
+#define REG_ACH0_TXBD_DESA_H 0x031C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_VIQ_TXBD_DESA 0x0320
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH1_TXBD_DESA_L 0x0320
+#define REG_ACH1_TXBD_DESA_H 0x0324
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BEQ_TXBD_DESA 0x0328
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH2_TXBD_DESA_L 0x0328
+#define REG_ACH2_TXBD_DESA_H 0x032C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BKQ_TXBD_DESA 0x0330
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH3_TXBD_DESA_L 0x0330
+#define REG_ACH3_TXBD_DESA_H 0x0334
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RXQ_RXBD_DESA 0x0338
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0RXQ_RXBD_DESA_L 0x0338
+#define REG_P0RXQ_RXBD_DESA_H 0x033C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI0Q_TXBD_DESA 0x0340
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0BCNQ_TXBD_DESA_L 0x0340
+#define REG_P0BCNQ_TXBD_DESA_H 0x0344
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI1Q_TXBD_DESA 0x0348
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FWCMDQ_TXBD_DESA_L 0x0348
+#define REG_FWCMDQ_TXBD_DESA_H 0x034C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI2Q_TXBD_DESA 0x0350
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_HRPWM1_HCPWM1_DCPU 0x0354
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI3Q_TXBD_DESA 0x0358
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0_MPRT_BCNQ_TXBD_DESA_L 0x0358
+#define REG_P0_MPRT_BCNQ_TXBD_DESA_H 0x035C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI4Q_TXBD_DESA 0x0360
+#define REG_HI5Q_TXBD_DESA 0x0368
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0_MPRT_BCNQ_TXRXBD_NUM 0x036C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI6Q_TXBD_DESA 0x0370
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BD_RWPTR_CLR2 0x0370
+#define REG_BD_RWPTR_CLR3 0x0374
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI7Q_TXBD_DESA 0x0378
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0MGQ_RXQ_TXRXBD_NUM 0x0378
+#define REG_CHNL_DMA_CFG 0x037C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MGQ_TXBD_NUM 0x0380
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FWCMDQ_TXBD_NUM 0x0380
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RX_RXBD_NUM 0x0382
+#define REG_VOQ_TXBD_NUM 0x0384
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH0_ACH1_TXBD_NUM 0x0384
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_VIQ_TXBD_NUM 0x0386
+#define REG_BEQ_TXBD_NUM 0x0388
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH2_ACH3_TXBD_NUM 0x0388
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BKQ_TXBD_NUM 0x038A
+#define REG_HI0Q_TXBD_NUM 0x038C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI0Q_HI1Q_TXBD_NUM 0x038C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI1Q_TXBD_NUM 0x038E
+#define REG_HI2Q_TXBD_NUM 0x0390
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI2Q_HI3Q_TXBD_NUM 0x0390
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI3Q_TXBD_NUM 0x0392
+#define REG_HI4Q_TXBD_NUM 0x0394
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI4Q_HI5Q_TXBD_NUM 0x0394
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI5Q_TXBD_NUM 0x0396
+#define REG_HI6Q_TXBD_NUM 0x0398
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI6Q_HI7Q_TXBD_NUM 0x0398
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI7Q_TXBD_NUM 0x039A
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TSFTIMER_HCI 0x039C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BD_RWPTR_CLR 0x039C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BD_RWPTR_CLR1 0x039C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_VOQ_TXBD_IDX 0x03A0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH0_TXBD_IDX 0x03A0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_VIQ_TXBD_IDX 0x03A4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH1_TXBD_IDX 0x03A4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BEQ_TXBD_IDX 0x03A8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH2_TXBD_IDX 0x03A8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BKQ_TXBD_IDX 0x03AC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH3_TXBD_IDX 0x03AC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MGQ_TXBD_IDX 0x03B0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0MGQ_TXBD_IDX 0x03B0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RXQ_RXBD_IDX 0x03B4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0RXQ_RXBD_IDX 0x03B4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI0Q_TXBD_IDX 0x03B8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI0Q_TXBD_IDX 0x03B8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI1Q_TXBD_IDX 0x03BC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI1Q_TXBD_IDX 0x03BC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI2Q_TXBD_IDX 0x03C0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI2Q_TXBD_IDX 0x03C0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI3Q_TXBD_IDX 0x03C4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI3Q_TXBD_IDX 0x03C4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI4Q_TXBD_IDX 0x03C8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI4Q_TXBD_IDX 0x03C8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI5Q_TXBD_IDX 0x03CC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI5Q_TXBD_IDX 0x03CC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI6Q_TXBD_IDX 0x03D0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI6Q_TXBD_IDX 0x03D0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HI7Q_TXBD_IDX 0x03D4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI7Q_TXBD_IDX 0x03D4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DBG_SEL_V1 0x03D8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_DBGSEL_PCIE_HRPWM1_HCPWM1_V1 0x03D8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PCIE_HRPWM1_V1 0x03D9
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_HRPWM1_V1 0x03D9
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PCIE_HCPWM1_V1 0x03DA
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_HCPWM1_V1 0x03DA
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_CTRL2 0x03DB
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_CTRL2 0x03DB
+
+#endif
+
+#if (HALMAC_8881A_SUPPORT)
+
+#define REG_LX_CTRL2 0x03DB
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PCIE_HRPWM2_V1 0x03DC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_HRPWM2_V1 0x03DC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_HRPWM2_HCPWM2_V1 0x03DC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PCIE_HCPWM2_V1 0x03DE
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_HCPWM2_V1 0x03DE
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_PCIE_H2C_MSG_V1 0x03E0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_H2C_MSG_V1 0x03E0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_PCIE_C2H_MSG_V1 0x03E4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_HCI_C2H_MSG_V1 0x03E4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DBI_WDATA_V1 0x03E8
+
+#endif
+
+#if (HALMAC_8881A_SUPPORT)
+
+#define REG_LX_DMA_ISR 0x03E8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DBI_RDATA_V1 0x03EC
+
+#endif
+
+#if (HALMAC_8881A_SUPPORT)
+
+#define REG_LX_DMA_IMR 0x03EC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_DBI_FLAG_V1 0x03F0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_STUCK_FLAG_V1 0x03F0
+
+#endif
+
+#if (HALMAC_8881A_SUPPORT)
+
+#define REG_LX_DMA_DBG 0x03F0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MDIO_V1 0x03F4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT)
+
+#define REG_MDIO2_V1 0x03F8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_WDT_CFG 0x03F8
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_MIX_CFG 0x03F8
+
+#endif
+
+#if (HALMAC_8881A_SUPPORT)
+
+#define REG_BUS_MIX_CFG 0x03F8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_HCI_MIX_CFG 0x03FC
+
+#endif
+
+#if (HALMAC_8881A_SUPPORT)
+
+#define REG_BUS_MIX_CFG1 0x03FC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_Q0_INFO 0x0400
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_QUEUE_INFO1 0x0400
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_QUEUELIST_INFO0 0x0400
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_Q1_INFO 0x0404
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_QUEUE_INFO2 0x0404
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_QUEUELIST_INFO1 0x0404
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_Q2_INFO 0x0408
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_QUEUE_INFO3 0x0408
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_QUEUELIST_INFO2 0x0408
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_Q3_INFO 0x040C
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_QINFO_INDEX 0x040C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_QUEUELIST_INFO3 0x040C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MGQ_INFO 0x0410
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_QUEUE_EMPTY 0x0410
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_QUEUELIST_INFO_EMPTY 0x0410
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HIQ_INFO 0x0414
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ACQ_STOP_V1 0x0414
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_QUEUELIST_ACQ_EN 0x0414
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BCNQ_INFO 0x0418
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCNQ_BDNY_V2 0x0418
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TXPKT_EMPTY 0x041A
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_CPU_MGQ_INFO 0x041C
+#define REG_FWHW_TXQ_CTRL 0x0420
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HWSEQ_CTRL 0x0423
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DATAFB_SEL 0x0423
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BCNQ_BDNY 0x0424
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_BCNQ_BDNY_V1 0x0424
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXBDNY 0x0424
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MGQ_BDNY 0x0425
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_LIFETIME_EN 0x0426
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_FW_FREE_TAIL 0x0427
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SPEC_SIFS 0x0428
+#define REG_RETRY_LIMIT 0x042A
+#define REG_TXBF_CTRL 0x042C
+#define REG_DARFRC 0x0430
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DARFRCH 0x0434
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RARFRC 0x0438
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RARFRCH 0x043C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RRSR 0x0440
+#define REG_ARFR0 0x0444
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ARFRH0 0x0448
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ARFR1_V1 0x044C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_REG_ARFR_WT0 0x044C
+#define REG_REG_ARFR_WT1 0x0450
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ARFRH1_V1 0x0450
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_CCK_CHECK 0x0454
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_AMPDU_BURST_CTRL 0x0455
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_AMPDU_MAX_TIME_V1 0x0455
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_AMPDU_MAX_TIME 0x0456
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_BCNQ1_BDNY_V1 0x0456
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TAB_SEL 0x0456
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BCNQ1_BDNY 0x0457
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCN_INVALID_CTRL 0x0457
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_AMPDU_MAX_LENGTH 0x0458
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_AMPDU_MAX_LENGTH_HT 0x0458
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ACQ_STOP 0x045C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_WMAC_LBK_BUF_HD 0x045D
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NDPA_RATE 0x045D
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TX_HANG_CTRL 0x045E
+#define REG_NDPA_OPT_CTRL 0x045F
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_FAST_EDCA_CTRL 0x0460
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_AMPDU_MAX_LENGTH_VHT 0x0460
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RD_RESP_PKT_TH 0x0463
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_CMDQ_INFO 0x0464
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_NEW_EDCA_CTRL_V1 0x0464
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_Q4_INFO 0x0468
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACQ_STOP_V2 0x0468
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_Q5_INFO 0x046C
+#define REG_Q6_INFO 0x0470
+#define REG_Q7_INFO 0x0474
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_LBK_BUF_HD_V1 0x0478
+#define REG_MGQ_BDNY_V1 0x047A
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TXRPT_CTRL 0x047C
+#define REG_INIRTS_RATE_SEL 0x0480
+#define REG_BASIC_CFEND_RATE 0x0481
+#define REG_STBC_CFEND_RATE 0x0482
+#define REG_DATA_SC 0x0483
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MACID_SLEEP3 0x0484
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MOREDATA_V1 0x0484
+#define REG_DATA_SC1 0x0487
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MACID_SLEEP1 0x0488
+#define REG_ARFR2_V1 0x048C
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ARFRH2_V1 0x0490
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ARFR3_V1 0x0494
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ARFRH3_V1 0x0498
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ARFR4 0x049C
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ARFRH4 0x04A0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ARFR5 0x04A4
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ARFRH5 0x04A8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TXRPT_START_OFFSET 0x04AC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TRYING_CNT_TH 0x04B0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_POWER_STAGE1 0x04B4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_POWER_STAGE2 0x04B8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SW_AMPDU_BURST_MODE_CTRL 0x04BC
+#define REG_PKT_LIFE_TIME 0x04C0
+#define REG_STBC_SETTING 0x04C4
+#define REG_STBC_SETTING2 0x04C5
+#define REG_QUEUE_CTRL 0x04C6
+#define REG_SINGLE_AMPDU_CTRL 0x04C7
+#define REG_PROT_MODE_CTRL 0x04C8
+#define REG_BAR_MODE_CTRL 0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT 0x04CF
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MACID_SLEEP2 0x04D0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MACID_SLEEP_CTRL 0x04D0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MACID_SLEEP 0x04D4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MACID_SLEEP_INFO 0x04D4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HW_SEQ0 0x04D8
+#define REG_HW_SEQ1 0x04DA
+#define REG_HW_SEQ2 0x04DC
+#define REG_HW_SEQ3 0x04DE
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_CSI_SEQ 0x04DE
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_NULL_PKT_STATUS 0x04E0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_NULL_PKT_STATUS_V1 0x04E0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_PTCL_ERR_STATUS 0x04E2
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PTCL_ERR_STATUS_V1 0x04E2
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_PTCL_PKT_NUM 0x04E3
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NULL_PKT_STATUS_EXTEND 0x04E3
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_TRXRPT_MISS_CNT 0x04E3
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_VIDEO_ENHANCEMENT_FUN 0x04E4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_NULL_PKT_STATUS_V2 0x04E4
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_HQMGQ_DROP 0x04E4
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_PRECNT_CTRL 0x04E5
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_NULL_PKT_STATUS_EXTEND_V1 0x04E7
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_POLLUTE_PKT_CNT 0x04E8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_PTCL_DBG 0x04EC
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_DROP_NUM 0x04EC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PTCL_DBG_V1 0x04EC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_PTCL_TX_RPT 0x04F0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_TXOP_EXTRA_CTRL 0x04F0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BT_POLLUTE_PKTCNT 0x04F0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CPUMGQ_TIMER_CTRL2 0x04F4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PTCL_DBG_OUT 0x04F8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_DUMMY_PAGE4 0x04FC
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DUMMY_PAGE4_V1 0x04FC
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MOREDATA 0x04FE
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_DUMMY_PAGE4_1 0x04FE
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#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 0x0514
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TSFTR_SYN_OFFSET 0x0518
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FORCE_BCN_IFS_V1 0x0518
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_AGGR_BREAK_TIME 0x051A
+#define REG_SLOT 0x051B
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_EDCA_CPUMGQ_PARAM 0x051C
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NOA_ON_ERLY_TIME 0x051C
+#define REG_NOA_OFF_ERLY_TIME 0x051D
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_CPUMGQ_PAUSE 0x051E
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TX_PTCL_CTRL 0x0520
+#define REG_TXPAUSE 0x0522
+#define REG_DIS_TXREQ_CLR 0x0523
+#define REG_RD_CTRL 0x0524
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MBSSID_CTRL 0x0526
+#define REG_P2PPS_CTRL 0x0527
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PKT_LIFETIME_CTRL 0x0528
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_P2PPS_SPEC_STATE 0x052B
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_P2PPS0_SPEC_STATE 0x052B
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TXOP_LIMIT_CTRL 0x052C
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BAR_TX_CTRL 0x0530
+#define REG_P2PON_DIS_TXTIME 0x0531
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CCA_TXEN_CNT 0x0534
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_QUEUE_INCOL_THR 0x0538
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MAX_INTER_COLLISION 0x0538
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_QUEUE_INCOL_EN 0x053C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MAX_INTER_COLLISION_CNT 0x053C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TBTT_PROHIBIT 0x0540
+#define REG_P2PPS_STATE 0x0543
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RD_NAV_NXT 0x0544
+#define REG_NAV_PROT_LEN 0x0546
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_FTM_CTRL 0x0548
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FTM_PTT 0x0548
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_FTM_TSF_CNT 0x054C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FTM_TSF 0x054C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BCN_CTRL 0x0550
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BCN_CTRL1 0x0551
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_BCN_CTRL_CLINT0 0x0551
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MBID_NUM 0x0552
+#define REG_DUAL_TSF_RST 0x0553
+#define REG_MBSSID_BCN_SPACE 0x0554
+#define REG_DRVERLYINT 0x0558
+#define REG_BCNDMATIM 0x0559
+#define REG_ATIMWND 0x055A
+#define REG_USTIME_TSF 0x055C
+#define REG_BCN_MAX_ERR 0x055D
+#define REG_RXTSF_OFFSET_CCK 0x055E
+#define REG_RXTSF_OFFSET_OFDM 0x055F
+#define REG_TSFTR 0x0560
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TSFTR_1 0x0564
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TSFTR1 0x0568
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_FREERUN_CNT 0x0568
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FREERUN_CNT_1 0x056C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMWND1 0x0570
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ATIMWND1_V1 0x0570
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_TBTT_PROHIBIT_INFRA 0x0571
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_CTWND 0x0572
+#define REG_BCNIVLCUNT 0x0573
+#define REG_BCNDROPCTRL 0x0574
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_HGQ_TIMEOUT_PERIOD 0x0575
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TXCMD_TIMEOUT_PERIOD 0x0576
+#define REG_MISC_CTRL 0x0577
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_BCN_CTRL_CLINT1 0x0578
+#define REG_BCN_CTRL_CLINT2 0x0579
+#define REG_BCN_CTRL_CLINT3 0x057A
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_EXTEND_CTRL 0x057B
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_P2PPS1_SPEC_STATE 0x057C
+#define REG_P2PPS1_STATE 0x057D
+#define REG_P2PPS2_SPEC_STATE 0x057E
+#define REG_P2PPS2_STATE 0x057F
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_PS_TIMER 0x0580
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_PS_TIMER0 0x0580
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TIMER0 0x0584
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_PS_TIMER1 0x0584
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TIMER1 0x0588
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_PS_TIMER2 0x0588
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TBTT_CTN_AREA 0x058C
+#define REG_FORCE_BCN_IFS 0x058E
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TXOP_MIN 0x0590
+#define REG_PRE_BKF_TIME 0x0592
+#define REG_CROSS_TXOP_CTRL 0x0593
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_TBTT_INT_SHIFT_CLI0 0x0594
+#define REG_TBTT_INT_SHIFT_CLI1 0x0595
+#define REG_TBTT_INT_SHIFT_CLI2 0x0596
+#define REG_TBTT_INT_SHIFT_CLI3 0x0597
+#define REG_TBTT_INT_SHIFT_ENABLE 0x0598
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_RX_TBTT_SHIFT_V1 0x0598
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMWND2 0x05A0
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ATIMWND_GROUP1 0x05A0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMWND3 0x05A1
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ATIMWND_GROUP2 0x05A1
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMWND4 0x05A2
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ATIMWND_GROUP3 0x05A2
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMWND5 0x05A3
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ATIMWND_GROUP4 0x05A3
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMWND6 0x05A4
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_DTIM_COUNT_GROUP1 0x05A4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMWND7 0x05A5
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_DTIM_COUNT_GROUP2 0x05A5
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ATIMUGT 0x05A6
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_DTIM_COUNT_GROUP3 0x05A6
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_HIQ_NO_LMT_EN 0x05A7
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_DTIM_COUNT_GROUP4 0x05A7
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_DTIM_COUNTER_ROOT 0x05A8
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HIQ_NO_LMT_EN_V2 0x05A8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_DTIM_COUNTER_VAP1 0x05A9
+#define REG_DTIM_COUNTER_VAP2 0x05AA
+#define REG_DTIM_COUNTER_VAP3 0x05AB
+#define REG_DTIM_COUNTER_VAP4 0x05AC
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_MBID_BCNQ_EN 0x05AC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_DTIM_COUNTER_VAP5 0x05AD
+#define REG_DTIM_COUNTER_VAP6 0x05AE
+#define REG_DTIM_COUNTER_VAP7 0x05AF
+#define REG_DIS_ATIM 0x05B0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_EARLY_128US 0x05B1
+#define REG_P2PPS1_CTRL 0x05B2
+#define REG_P2PPS2_CTRL 0x05B3
+#define REG_TIMER0_SRC_SEL 0x05B4
+#define REG_NOA_UNIT_SEL 0x05B5
+#define REG_P2POFF_DIS_TXTIME 0x05B7
+#define REG_MBSSID_BCN_SPACE2 0x05B8
+#define REG_MBSSID_BCN_SPACE3 0x05BC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#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
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MAC_HEADER_NAV_OFFSET 0x05CA
+#define REG_DIS_NDPA_NAV_CHECK 0x05CB
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_EDCA_RANDOM_GEN 0x05CC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TXCMD_NOA_SEL 0x05CF
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXCMD_SEL 0x05CF
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_32K_CLK_SEL 0x05D0
+#define REG_EARLYINT_ADJUST 0x05D4
+#define REG_BCNERR_CNT 0x05D8
+#define REG_BCNERR_CNT_2 0x05DC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_NOA_PARAM 0x05E0
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NOA_PARAM_1 0x05E4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MU_DBG_INFO 0x05E8
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NOA_PARAM_2 0x05E8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MU_DBG_INFO_1 0x05EC
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NOA_PARAM_3 0x05EC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_NOA_SUBIE 0x05ED
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_P2P_RST 0x05F0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_SCH_DBG_SEL 0x05F0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SCHEDULER_RST 0x05F1
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MU_DBG_ERR_FLAG 0x05F2
+#define REG_TX_ERR_RECOVERY_RST 0x05F3
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SCH_DBG_VALUE 0x05F4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SCH_TXCMD 0x05F8
+#define REG_PAGE5_DUMMY 0x05FC
+#define REG_WMAC_CR 0x0600
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_FWPKT_CR 0x0601
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FW_STS_FILTER 0x0602
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_BWOPMODE 0x0603
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#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
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_H 0x0614
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_BSSID 0x0618
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID_H 0x061C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_MAR 0x0620
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MAR_H 0x0624
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MBIDCAMCFG_1 0x0628
+#define REG_MBIDCAMCFG_2 0x062C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_WMAC_DEBUG_SEL 0x062C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MCU_TEST_1 0x0630
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_TCR_TSFT_OFS 0x0630
+#define REG_UDF_THSD 0x0632
+#define REG_ZLD_NUM 0x0633
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_MCU_TEST_2 0x0634
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_STMP_THSD 0x0634
+#define REG_WMAC_TXTIMEOUT 0x0635
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT)
+
+#define REG_MCU_TEST_2_V1 0x0636
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_USTIME_EDCA 0x0638
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_ACKTO_CCK 0x0639
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_MAC_SPEC_SIFS 0x063A
+#define REG_RESP_SIFS_CCK 0x063C
+#define REG_RESP_SIFS_OFDM 0x063E
+#define REG_ACKTO 0x0640
+#define REG_CTS2TO 0x0641
+#define REG_EIFS 0x0642
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_RPFM_MAP0 0x0644
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_RPFM_MAP1 0x0646
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RPFM_MAP1_V1 0x0646
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_RPFM_CAM_CMD 0x0648
+#define REG_RPFM_CAM_RWD 0x064C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_NAV_CTRL 0x0650
+#define REG_BACAMCMD 0x0654
+#define REG_BACAMCONTENT 0x0658
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BACAMCONTENT_H 0x065C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_LBDLY 0x0660
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_BACAM_RPMEN 0x0661
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_TX_RX 0x0662
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_BITMAP_CTL 0x0663
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RXERR_RPT 0x0664
+#define REG_WMAC_TRXPTCL_CTL 0x0668
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_TRXPTCL_CTL_H 0x066C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_CAMCMD 0x0670
+#define REG_CAMWRITE 0x0674
+#define REG_CAMREAD 0x0678
+#define REG_CAMDBG 0x067C
+#define REG_SECCFG 0x0680
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RXFILTER_CATEGORY_1 0x0682
+#define REG_RXFILTER_ACTION_1 0x0683
+#define REG_RXFILTER_CATEGORY_2 0x0684
+#define REG_RXFILTER_ACTION_2 0x0685
+#define REG_RXFILTER_CATEGORY_3 0x0686
+#define REG_RXFILTER_ACTION_3 0x0687
+#define REG_RXFLTMAP3 0x0688
+#define REG_RXFLTMAP4 0x068A
+#define REG_RXFLTMAP5 0x068C
+#define REG_RXFLTMAP6 0x068E
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_WOW_CTRL 0x0690
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_NAN_RX_TSF_FILTER 0x0691
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_PS_RX_INFO 0x0692
+#define REG_WMMPS_UAPSD_TID 0x0693
+#define REG_LPNAV_CTRL 0x0694
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_WKFMCAM_NUM 0x0698
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WKFMCAM_CMD 0x0698
+#define REG_WKFMCAM_RWD 0x069C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RXFLTMAP0 0x06A0
+#define REG_RXFLTMAP1 0x06A2
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_RXFLTMAP 0x06A4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_RXFLTMAP2 0x06A4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_BCN_PSR_RPT 0x06A8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_FLC_RPC 0x06AC
+#define REG_FLC_RPCT 0x06AD
+#define REG_FLC_PTS 0x06AE
+#define REG_FLC_TRPC 0x06AF
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RXPKTMON_CTRL 0x06B0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_STATE_MON 0x06B4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ERROR_MON 0x06B8
+#define REG_SEARCH_MACID 0x06BC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_BT_COEX_TABLE 0x06C0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_COEX_TABLE2 0x06C4
+#define REG_BT_COEX_BREAK_TABLE 0x06C8
+#define REG_BT_COEX_TABLE_H 0x06CC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RXCMD_0 0x06D0
+#define REG_RXCMD_1 0x06D4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_WMAC_RESP_TXINFO 0x06D8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BBPSF_CTRL 0x06DC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_P2P_RX_BCN_NOA 0x06E0
+#define REG_ASSOCIATED_BFMER0_INFO 0x06E4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ASSOCIATED_BFMER0_INFO_H 0x06E8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_ASSOCIATED_BFMER1_INFO 0x06EC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ASSOCIATED_BFMER1_INFO_H 0x06F0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_TX_CSI_RPT_PARAM_BW20 0x06F4
+#define REG_TX_CSI_RPT_PARAM_BW40 0x06F8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TX_CSI_RPT_PARAM_BW80 0x06FC
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_CSI_RRSR_V1 0x06FC
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_CSI_PTR 0x06FC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_MACID1 0x0700
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID1_1 0x0704
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID1 0x0708
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_CFG_FORCE_LINK_L 0x0709
+#define REG_PCIE_CFG_FORCE_LINK_H 0x070A
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID1_1 0x070C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_CFG_DEFAULT_ACK_FREQUENCY 0x070C
+#define REG_PCIE_CFG_CX_NFTS 0x070D
+#define REG_PCIE_CFG_DEFAULT_ENTR_LATENCY 0x070F
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_BCN_PSR_RPT1 0x0710
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_CFG_L1_MISC_SEL 0x0711
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ASSOCIATED_BFMEE_SEL 0x0714
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ASSOCIATED_BFMEE_SEL_1 0x0714
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_SND_PTCL_CTRL 0x0718
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF 0x0718
+#define REG_PCIE_CFG_FORCE_CLKREQ_N_PAD 0x0719
+#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_ACK_NAK_LATENCY 0x071A
+#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_FLOW_CONTROL_WATCHDOG 0x071B
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_RX_CSI_RPT_INFO 0x071C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_L 0x071C
+#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_H 0x071D
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_NS_ARP_CTRL 0x0720
+#define REG_NS_ARP_INFO 0x0724
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_CFG_L1_UNIT_SEL 0x0724
+#define REG_PCIE_CFG_MIN_CLKREQ_SEL 0x0725
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_NS_ARP_IPADDR 0x0728
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BEAMFORMING_INFO_NSARP_V1 0x0728
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_WRITE_RX_CSI_RPT_INFO 0x072C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BEAMFORMING_INFO_NSARP 0x072C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_NS_ARP_IPV6_MYADDR 0x0730
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_IPV6 0x0730
+#define REG_IPV6_1 0x0734
+#define REG_IPV6_2 0x0738
+#define REG_IPV6_3 0x073C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_RTX_CTX_SUBTYPE_CFG 0x0750
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_SWAES_DIO_B63_B32 0x0754
+#define REG_WMAC_SWAES_DIO_B95_B64 0x0758
+#define REG_WMAC_SWAES_DIO_B127_B96 0x075C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_SWAES_CFG 0x0760
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_COEX_V2 0x0762
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_BT_COEX 0x0764
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_WLAN_ACT_MSK_CTRL 0x0768
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WLAN_ACT_MASK_CTRL 0x0768
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WLAN_ACT_MASK_CTRL_1 0x076C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT_STATISTICS_CTRL 0x076E
+#define REG_BT_COEX_ENH_INTF_CTRL 0x076E
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_COEX_ENHANCED_INTR_CTRL 0x076E
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT ||   \
+     HALMAC_8881A_SUPPORT)
+
+#define REG_BT_ACT_STATISTICS 0x0770
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_ACT_STATISTICS_1 0x0774
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT_STATISTICS_OTH_CTRL 0x0778
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_STATISTICS_CONTROL_REGISTER 0x0778
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT_CMD_ID 0x077C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_STATUS_REPORT_REGISTER 0x077C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT__STATUS_RPT 0x077D
+#define REG_BT_DATA 0x0780
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_INTERRUPT_CONTROL_REGISTER 0x0780
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_WLAN_RPT_ 0x0781
+#define REG_BT_ISR_CTRL 0x0783
+#define REG_WLAN_RPT_TO_CTR 0x0784
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER 0x0784
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT_ISOLATION_TABLE 0x0785
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER 0x0785
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1 0x0788
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2 0x078C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT_ISR_STA 0x078F
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_INTERRUPT_STATUS_REGISTER 0x078F
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_TDMA_TIME_AND_RPT_SAM_SET 0x0790
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_TDMA_TIME_REGISTER 0x0790
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT_CH_INFO 0x0794
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BT_ACT_REGISTER 0x0794
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_BT_STATIC_INFO_EXT 0x0795
+#define REG_LTR_IDLE_LATENCY 0x0798
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_OBFF_CTRL_BASIC 0x0798
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_LTR_ACTIVE_LATENCY 0x079C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_OBFF_CTRL2_TIMER 0x079C
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_OBFF_CTRL 0x07A0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_LTR_CTRL_BASIC 0x07A0
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_LTR_CTRL 0x07A4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_LTR_CTRL2_TIMER_THRESHOLD 0x07A4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_LTR_CTRL2 0x07A8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_LTR_IDLE_LATENCY_V1 0x07A8
+#define REG_LTR_ACTIVE_LATENCY_V1 0x07AC
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_ANTTRN_CTRL 0x07B0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER 0x07B0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_SMART_ANT_CONDITION 0x07B0
+#define REG_SMART_ANT_CTRL 0x07B4
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_1 0x07B4
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_WMAC_PKTCNT_RWD 0x07B8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_CONTROL_FRAME_REPORT 0x07B8
+
+#endif
+
+#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
+
+#define REG_WMAC_PKTCNT_CTRL 0x07BC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_CONTROL_FRAME_CNT_CTRL 0x07BC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_IQ_DUMP 0x07C0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_IQ_DUMP_1 0x07C4
+#define REG_IQ_DUMP_2 0x07C8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_FTM_CTL 0x07CC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_IQ_MDPK_FUNC 0x07CE
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_IQ_DUMP_EXT 0x07CF
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT)
+
+#define REG_OFDM_CCK_LEN_MASK 0x07D0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_OPTION_FUNCTION 0x07D0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_OPTION_FUNCTION_1 0x07D4
+#define REG_WMAC_OPTION_FUNCTION_2 0x07D8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RX_FILTER_FUNCTION 0x07DA
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NDP_SIG 0x07E0
+#define REG_TXCMD_INFO_FOR_RSP_PKT 0x07E4
+
+#endif
+
+#if (HALMAC_8814AMP_SUPPORT)
+
+#define REG_SEC_OPT 0x07E8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TXCMD_INFO_FOR_RSP_PKT_1 0x07E8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_SEC_OPT_V2 0x07EC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WSEC_OPTION 0x07EC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RTS_ADDRESS_0 0x07F0
+
+#endif
+
+#if (HALMAC_8814AMP_SUPPORT)
+
+#define REG_RTS_ADDR0 0x07F0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RTS_ADDRESS_0_1 0x07F4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RTS_ADDRESS_1 0x07F8
+
+#endif
+
+#if (HALMAC_8814AMP_SUPPORT)
+
+#define REG_RTS_ADDR1 0x07F8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RTS_ADDRESS_1_1 0x07FC
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT)
+
+#define REG__RPFM_MAP1 0x07FE
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_SYS_CFG3 0x1000
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPARSW_MAC_0 0x1010
+#define REG_ANAPARSW_MAC_1 0x1014
+#define REG_ANAPAR_MAC_0 0x1018
+#define REG_ANAPAR_MAC_1 0x101C
+#define REG_ANAPAR_MAC_2 0x1020
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ANAPAR_MAC_3 0x1024
+#define REG_ANAPAR_MAC_4 0x1028
+#define REG_ANAPAR_MAC_5 0x102C
+#define REG_ANAPAR_MAC_6 0x1030
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_SYS_CFG4 0x1034
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ANAPAR_MAC_7 0x1034
+#define REG_ANAPAR_MAC_8 0x1038
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPAR_XTAL_0 0x1040
+#define REG_ANAPAR_XTAL_1 0x1044
+#define REG_ANAPAR_XTAL_2 0x1048
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ANAPAR_XTAL_AAC 0x104C
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPAR_XTAL_3 0x104C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ANAPAR_XTAL_R_ONLY 0x1050
+#define REG_CPHY_LDO 0x1054
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPAR_XTAL_AACK_0 0x1054
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_CPHY_BG 0x1058
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPAR_XTAL_AACK_1 0x1058
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HIMR_4 0x1060
+#define REG_HISR_4 0x1064
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_ANAPAR_XTAL_MODE_DECODER 0x1064
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HIMR_5 0x1068
+#define REG_HISR_5 0x106C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_SYS_CFG5 0x1070
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HIMR_6 0x1078
+#define REG_HISR_6 0x107C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CPU_DMEM_CON 0x1080
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_BOOT_REASON 0x1088
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HIMR4 0x1090
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_DATA_CPU_CTL0 0x1090
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HISR4 0x1094
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_DATA_CPU_CTL1 0x1094
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HIMR5 0x1098
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXDMA_STOP_HIMR 0x1098
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HISR5 0x109C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TXDMA_STOP_HISR 0x109C
+#define REG_TXDMA_START_HIMR 0x10A0
+#define REG_TXDMA_START_HISR 0x10A4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_NFCPAD_CTRL 0x10A8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_HIMR2 0x10B0
+#define REG_HISR2 0x10B4
+#define REG_HIMR3 0x10B8
+#define REG_HISR3 0x10BC
+#define REG_SW_MDIO 0x10C0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_SW_FLUSH 0x10C4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_DBG_GPIO_BMUX 0x10C8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HIMR_7 0x10C8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_FPGA_TAG 0x10CC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HISR_7 0x10CC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_WL_DSS_CTRL0 0x10D0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_H2C_PKT_READADDR 0x10D0
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_WL_DSS_STATUS0 0x10D4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_H2C_PKT_WRITEADDR 0x10D4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_WL_DSS_CTRL1 0x10D8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MEM_PWR_CRTL 0x10D8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_WL_DSS_STATUS1 0x10DC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FW_DRV_HANDSHAKE 0x10DC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_FW_DBG0 0x10E0
+#define REG_FW_DBG1 0x10E4
+#define REG_FW_DBG2 0x10E8
+#define REG_FW_DBG3 0x10EC
+#define REG_FW_DBG4 0x10F0
+#define REG_FW_DBG5 0x10F4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FW_DBG6 0x10F8
+#define REG_FW_DBG7 0x10FC
+#define REG_CR_EXT 0x1100
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TC9_CTRL 0x1104
+#define REG_TC10_CTRL 0x1108
+#define REG_TC11_CTRL 0x110C
+#define REG_TC12_CTRL 0x1110
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FWFF 0x1114
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_RXFF_PTR_V1 0x1118
+#define REG_RXFF_WTR_V1 0x111C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FE2IMR 0x1120
+#define REG_FE2ISR 0x1124
+#define REG_FE3IMR 0x1128
+#define REG_FE3ISR 0x112C
+#define REG_FE4IMR 0x1130
+#define REG_FE4ISR 0x1134
+#define REG_FT1IMR 0x1138
+#define REG_FT1ISR 0x113C
+#define REG_SPWR0 0x1140
+#define REG_SPWR1 0x1144
+#define REG_SPWR2 0x1148
+#define REG_SPWR3 0x114C
+#define REG_POWSEQ 0x1150
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_TC7_CTRL_V1 0x1158
+#define REG_TC8_CTRL_V1 0x115C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_RXBCN_TBTT_INTERVAL_PORT0TO3 0x1160
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RX_BCN_TBTT_ITVL0 0x1160
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_RXBCN_TBTT_INTERVAL_PORT4 0x1164
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RX_BCN_TBTT_ITVL1 0x1164
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
+
+#define REG_FWIMR1 0x1168
+#define REG_FWISR1 0x116C
+#define REG_FWIMR2 0x1170
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_IO_WRAP_ERR_FLAG 0x1170
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
+
+#define REG_FWISR2 0x1174
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FWIMR3 0x1178
+#define REG_FWISR3 0x117C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SPEED_SENSOR 0x1180
+#define REG_SPEED_SENSOR1 0x1184
+#define REG_SPEED_SENSOR2 0x1188
+#define REG_SPEED_SENSOR3 0x118C
+#define REG_SPEED_SENSOR4 0x1190
+#define REG_SPEED_SENSOR5 0x1194
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_RXPKTBUF_1_MAX_ADDR 0x1198
+#define REG_RXFWBUF_1_MAX_ADDR 0x119C
+#define REG_IO_WRAP_ERR_FLAG_V1 0x11A0
+#define REG_RXPKTBUF_1_READ 0x11A4
+#define REG_RXPKTBUF_1_WRITE 0x11A8
+#define REG_BUFF_DBGUG 0x11AC
+#define REG_RFE_CTRL_PAD_E2 0x11B0
+#define REG_RFE_CTRL_PAD_SR 0x11B4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_EXT_QUEUE_REG 0x11C0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_H2C_PRIORITY_SEL 0x11C0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_COUNTER_CONTROL 0x11C4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_COUNTER_CTRL 0x11C4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_COUNTER_TH 0x11C8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_COUNTER_THRESHOLD 0x11C8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_COUNTER_SET 0x11CC
+#define REG_COUNTER_OVERFLOW 0x11D0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_TDE_LEN_TH 0x11D4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TXDMA_LEN_THRESHOLD 0x11D4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_RDE_LEN_TH 0x11D8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RXDMA_LEN_THRESHOLD 0x11D8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
+
+#define REG_PCIE_EXEC_TIME 0x11DC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_EXEC_TIME_THRESHOLD 0x11DC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FT2IMR 0x11E0
+#define REG_FT2ISR 0x11E4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MSG2 0x11F0
+#define REG_MSG3 0x11F4
+#define REG_MSG4 0x11F8
+#define REG_MSG5 0x11FC
+#define REG_DDMA_CH0SA 0x1200
+#define REG_DDMA_CH0DA 0x1204
+#define REG_DDMA_CH0CTRL 0x1208
+#define REG_DDMA_CH1SA 0x1210
+#define REG_DDMA_CH1DA 0x1214
+#define REG_DDMA_CH1CTRL 0x1218
+#define REG_DDMA_CH2SA 0x1220
+#define REG_DDMA_CH2DA 0x1224
+#define REG_DDMA_CH2CTRL 0x1228
+#define REG_DDMA_CH3SA 0x1230
+#define REG_DDMA_CH3DA 0x1234
+#define REG_DDMA_CH3CTRL 0x1238
+#define REG_DDMA_CH4SA 0x1240
+#define REG_DDMA_CH4DA 0x1244
+#define REG_DDMA_CH4CTRL 0x1248
+#define REG_DDMA_CH5SA 0x1250
+#define REG_DDMA_CH5DA 0x1254
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_REG_DDMA_CH5CTRL 0x1258
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DDMA_CH5CTRL 0x1258
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DDMA_INT_MSK 0x12E0
+#define REG_DDMA_CHSTATUS 0x12E8
+#define REG_DDMA_CHKSUM 0x12F0
+#define REG_DDMA_MONITOR 0x12FC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_STC_INT_CS 0x1300
+#define REG_ST_INT_CFG 0x1304
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH4_ACH5_TXBD_NUM 0x130C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_CMU_DLY_CTRL 0x1310
+#define REG_CMU_DLY_CFG 0x1314
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FWCMDQ_TXBD_IDX 0x1318
+#define REG_P0HI8Q_TXBD_IDX 0x131C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_H2CQ_TXBD_DESA 0x1320
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_H2CQ_TXBD_DESA_L 0x1320
+#define REG_H2CQ_TXBD_DESA_H 0x1324
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_H2CQ_TXBD_NUM 0x1328
+#define REG_H2CQ_TXBD_IDX 0x132C
+#define REG_H2CQ_CSR 0x1330
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI9Q_TXBD_IDX 0x1334
+#define REG_P0HI10Q_TXBD_IDX 0x1338
+#define REG_P0HI11Q_TXBD_IDX 0x133C
+#define REG_P0HI12Q_TXBD_IDX 0x1340
+#define REG_P0HI13Q_TXBD_IDX 0x1344
+#define REG_P0HI14Q_TXBD_IDX 0x1348
+#define REG_P0HI15Q_TXBD_IDX 0x134C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_AXI_EXCEPT_CS 0x1350
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CHANGE_PCIE_SPEED 0x1350
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define REG_AXI_EXCEPT_TIME 0x1354
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DEBUG_STATE1 0x1354
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI8Q_TXBD_IDX 0x1358
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DEBUG_STATE2 0x1358
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI9Q_TXBD_IDX 0x135C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_DEBUG_STATE3 0x135C
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI10Q_TXBD_IDX 0x1360
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH5_TXBD_DESA_L 0x1360
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI11Q_TXBD_IDX 0x1364
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH5_TXBD_DESA_H 0x1364
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI12Q_TXBD_IDX 0x1368
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH6_TXBD_DESA_L 0x1368
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI13Q_TXBD_IDX 0x136C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH6_TXBD_DESA_H 0x136C
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI14Q_TXBD_IDX 0x1370
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH7_TXBD_DESA_L 0x1370
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI15Q_TXBD_IDX 0x1374
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH7_TXBD_DESA_H 0x1374
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI8Q_TXBD_DESA 0x1378
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH8_TXBD_DESA_L 0x1378
+#define REG_ACH8_TXBD_DESA_H 0x137C
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_CHNL_DMA_CFG_V1 0x137C
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI9Q_TXBD_DESA 0x1380
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH9_TXBD_DESA_L 0x1380
+#define REG_ACH9_TXBD_DESA_H 0x1384
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI10Q_TXBD_DESA 0x1388
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH10_TXBD_DESA_L 0x1388
+#define REG_ACH10_TXBD_DESA_H 0x138C
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI11Q_TXBD_DESA 0x1390
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH11_TXBD_DESA_L 0x1390
+#define REG_ACH11_TXBD_DESA_H 0x1394
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI12Q_TXBD_DESA 0x1398
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH12_TXBD_DESA_L 0x1398
+#define REG_ACH12_TXBD_DESA_H 0x139C
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI13Q_TXBD_DESA 0x13A0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH13_TXBD_DESA_L 0x13A0
+#define REG_ACH13_TXBD_DESA_H 0x13A4
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI14Q_TXBD_DESA 0x13A8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HI0Q_TXBD_DESA_L 0x13A8
+#define REG_HI0Q_TXBD_DESA_H 0x13AC
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI15Q_TXBD_DESA 0x13B0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HI1Q_TXBD_DESA_L 0x13B0
+#define REG_HI1Q_TXBD_DESA_H 0x13B4
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_HISR0_V1 0x13B4
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI8Q_TXBD_NUM 0x13B8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HI2Q_TXBD_DESA_L 0x13B8
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI9Q_TXBD_NUM 0x13BA
+#define REG_HI10Q_TXBD_NUM 0x13BC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HI2Q_TXBD_DESA_H 0x13BC
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_HISR1_V1 0x13BC
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI11Q_TXBD_NUM 0x13BE
+#define REG_HI12Q_TXBD_NUM 0x13C0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HI3Q_TXBD_DESA_L 0x13C0
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI13Q_TXBD_NUM 0x13C2
+#define REG_HI14Q_TXBD_NUM 0x13C4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HI3Q_TXBD_DESA_H 0x13C4
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_HI15Q_TXBD_NUM 0x13C6
+#define REG_HIQ_DMA_STOP 0x13C8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_HI4Q_TXBD_DESA_L 0x13C8
+#define REG_HI4Q_TXBD_DESA_H 0x13CC
+#define REG_HI5Q_TXBD_DESA_L 0x13D0
+#define REG_HI5Q_TXBD_DESA_H 0x13D4
+#define REG_HI6Q_TXBD_DESA_L 0x13D8
+#define REG_HI6Q_TXBD_DESA_H 0x13DC
+#define REG_HI7Q_TXBD_DESA_L 0x13E0
+#define REG_HI7Q_TXBD_DESA_H 0x13E4
+#define REG_ACH8_ACH9_TXBD_NUM 0x13E8
+#define REG_ACH10_ACH11_TXBD_NUM 0x13EC
+#define REG_ACH12_ACH13_TXBD_NUM 0x13F0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_OLD_DEHANG 0x13F4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_ACH4_TXBD_DESA_L 0x13F8
+#define REG_ACH4_TXBD_DESA_H 0x13FC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_Q0_Q1_INFO 0x1400
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ARFR6 0x1400
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MU_OFFSET 0x1400
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_Q2_Q3_INFO 0x1404
+#define REG_Q4_Q5_INFO 0x1408
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ARFR7 0x1408
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_Q6_Q7_INFO 0x140C
+#define REG_MGQ_HIQ_INFO 0x1410
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_ARFR8 0x1410
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CMDQ_BCNQ_INFO 0x1414
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_USEREG_SETTING 0x1420
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_AESIV_SETTING 0x1424
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BF0_TIME_SETTING 0x1428
+#define REG_BF1_TIME_SETTING 0x142C
+#define REG_BF_TIMEOUT_EN 0x1430
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_RELEASE0 0x1434
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MACID_RELEASE_INFO 0x1434
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_RELEASE1 0x1438
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MACID_RELEASE_SUCCESS_INFO 0x1438
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_RELEASE2 0x143C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MACID_RELEASE_CTRL 0x143C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_RELEASE3 0x1440
+#define REG_MACID_RELEASE_SETTING 0x1444
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_FAST_EDCA_VOVI_SETTING 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING 0x144C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_DROP0 0x1450
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MACID_DROP_INFO 0x1450
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_DROP1 0x1454
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_MACID_DROP_CTRL 0x1454
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MACID_DROP2 0x1458
+#define REG_MACID_DROP3 0x145C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_R_MACID_RELEASE_SUCCESS_0 0x1460
+#define REG_R_MACID_RELEASE_SUCCESS_1 0x1464
+#define REG_R_MACID_RELEASE_SUCCESS_2 0x1468
+#define REG_R_MACID_RELEASE_SUCCESS_3 0x146C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_MGG_FIFO_CRTL 0x1470
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MGQ_FIFO_WRITE_POINTER 0x1470
+#define REG_MGQ_FIFO_READ_POINTER 0x1472
+#define REG_MGQ_FIFO_ENABLE 0x1472
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_MGG_FIFO_INT 0x1474
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MGQ_FIFO_RELEASE_INT_MASK 0x1474
+#define REG_MGQ_FIFO_RELEASE_INT_FLAG 0x1476
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_MGG_FIFO_LIFETIME 0x1478
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MGQ_FIFO_VALID_MAP 0x1478
+#define REG_MGQ_FIFO_LIFETIME 0x147A
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET 0x147C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_SHCUT_SETTING 0x1480
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PKT_TRANS 0x1480
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_SHCUT_LLC_ETH_TYPE0 0x1484
+#define REG_SHCUT_LLC_ETH_TYPE1 0x1488
+#define REG_SHCUT_LLC_OUI0 0x148C
+#define REG_SHCUT_LLC_OUI1 0x1490
+#define REG_SHCUT_LLC_OUI2 0x1494
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
+     HALMAC_8822B_SUPPORT)
+
+#define REG_SHCUT_LLC_OUI3 0x1498
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FWCMDQ_CTRL 0x14A0
+#define REG_FWCMDQ_PAGE 0x14A4
+#define REG_FWCMDQ_INFO 0x14A8
+#define REG_FWCMDQ_HOLD_PKTNUM 0x14AC
+#define REG_MU_TX_CTRL 0x14C0
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MU_TX_CTL 0x14C0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_MU_STA_GID_VLD 0x14C4
+#define REG_MU_STA_USER_POS_INFO 0x14C8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MU_STA_USER_POS_INFO_H 0x14CC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_CHNL_INFO_CTRL 0x14D0
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_MU_TRX_DBG_CNT 0x14D0
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_CHNL_IDLE_TIME 0x14D4
+#define REG_CHNL_BUSY_TIME 0x14D8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MU_TRX_DBG_CNT_V1 0x14DC
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_NEW_EDCA_CTRL 0x14F0
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
+
+#define REG_SWPS_CTRL 0x14F4
+#define REG_SWPS_PKT_TH 0x14F6
+#define REG_SWPS_TIME_TH 0x14F8
+#define REG_MACID_SWPS_EN 0x14FC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CPUMGQ_TX_TIMER 0x1500
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PORT_CTRL_SEL 0x1500
+#define REG_PORT_CTRL_CFG 0x1501
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PS_TIMER_A 0x1504
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TBTT_PROHIBIT_CFG 0x1504
+#define REG_DRVERLYINT_CFG 0x1507
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PS_TIMER_B 0x1508
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCNDMATIM_CFG 0x1508
+#define REG_CTWND_CFG 0x1509
+#define REG_BCNIVLCUNT_CFG 0x150A
+#define REG_EARLY_128US_CFG 0x150B
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PS_TIMER_C 0x150C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TSFTR_SYNC_OFFSET_CFG 0x150C
+#define REG_TSFTR_SYNC_CTRL_CFG 0x150F
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL 0x1510
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCN_SPACE_CFG 0x1510
+#define REG_EARLY_INT_ADJUST_CFG 0x1512
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CPUMGQ_TX_TIMER_EARLY 0x1514
+#define REG_PS_TIMER_A_EARLY 0x1515
+#define REG_PS_TIMER_B_EARLY 0x1516
+#define REG_PS_TIMER_C_EARLY 0x1517
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_CPUMGQ_PARAMETER 0x1518
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_SW_TBTT_TSF_INFO 0x151C
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_TSF_SYN_CTRL0 0x1520
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TSFTR_LOW 0x1520
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_TSF_SYNC_ADJ 0x1520
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_TSF_SYN_CTRL1 0x1521
+#define REG_TSF_SYN_OFFSET0 0x1522
+#define REG_TSF_SYN_OFFSET1 0x1524
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TSFTR_HIGH 0x1524
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_TSF_ADJ_VLAUE 0x1524
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_TSF_SYN_OFFSET2 0x1528
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCN_ERR_CNT_MAC 0x1528
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_TSF_ADJ_VLAUE_2 0x1528
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BCN_ERR_CNT_EDCCA 0x1529
+#define REG_BCN_ERR_CNT_CCA 0x152A
+#define REG_BCN_ERR_CNT_INVALID 0x152B
+#define REG_BCN_ERR_CNT_OTHERS 0x152C
+#define REG_RX_BCN_TIMER 0x152D
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_TSF_SYN_COMPARE_VALUE 0x1530
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_TBTT_CTN_AREA_V1 0x1530
+#define REG_BCN_MAX_ERR_V1 0x1531
+#define REG_RXTSF_OFFSET_CCK_V1 0x1532
+#define REG_RXTSF_OFFSET_OFDM_V1 0x1533
+#define REG_SUB_BCN_SPACE 0x1534
+#define REG_MBID_NUM_V1 0x1535
+#define REG_MBSSID_CTRL_V1 0x1536
+#define REG_USTIME_TSF_V1 0x1538
+#define REG_BW_CFG 0x1539
+#define REG_ATIMWND_CFG 0x153A
+#define REG_DTIM_COUNTER_CFG 0x153B
+#define REG_ATIM_DTIM_CTRL_SEL 0x153C
+#define REG_ATIMUGT_V1 0x153D
+#define REG_BCNDROPCTRL_V1 0x153E
+#define REG_DIS_ATIM_V1 0x1540
+#define REG_HIQ_NO_LMT_EN_V1 0x1544
+#define REG_P2PPS_CTRL_V1 0x1548
+#define REG_P2PPS_SPEC_STATE_V1 0x154A
+#define REG_P2PPS_STATE_V1 0x154B
+#define REG_P2PPS1_CTRL_V1 0x154C
+#define REG_P2PPS1_SPEC_STATE_V1 0x154E
+#define REG_P2PPS1_STATE_V1 0x154F
+#define REG_P2PPS2_CTRL_V1 0x1550
+#define REG_P2PPS2_SPEC_STATE_V1 0x1552
+#define REG_P2PPS2_STATE_V1 0x1553
+#define REG_P2PON_DIS_TXTIME_V1 0x1554
+#define REG_P2POFF_DIS_TXTIME_V1 0x1555
+#define REG_CHG_POWER_BCN_AREA 0x1556
+#define REG_NOA_SEL 0x1557
+#define REG_NOA_PARAM_V1 0x1558
+#define REG_NOA_PARAM_1_V1 0x155C
+#define REG_NOA_PARAM_2_V1 0x1560
+#define REG_NOA_PARAM_3_V1 0x1564
+#define REG_NOA_ON_ERLY_TIME_V1 0x1568
+#define REG_NOA_OFF_ERLY_TIME_V1 0x1569
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_P2PPS_HW_AUTO_PAUSE_CTRL 0x156C
+#define REG_P2PPS1_HW_AUTO_PAUSE_CTRL 0x1570
+#define REG_P2PPS2_HW_AUTO_PAUSE_CTRL 0x1574
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_RX_TBTT_SHIFT 0x1578
+#define REG_FREERUN_CNT_LOW 0x1580
+#define REG_FREERUN_CNT_HIGH 0x1584
+#define REG_CPUMGQ_TX_TIMER_V1 0x1588
+#define REG_PS_TIMER_0 0x158C
+#define REG_PS_TIMER_1 0x1590
+#define REG_PS_TIMER_2 0x1594
+#define REG_PS_TIMER_3 0x1598
+#define REG_PS_TIMER_4 0x159C
+#define REG_PS_TIMER_5 0x15A0
+#define REG_PS_TIMER_01_CTRL 0x15A4
+#define REG_PS_TIMER_23_CTRL 0x15A8
+#define REG_PS_TIMER_45_CTRL 0x15AC
+#define REG_CPUMGQ_FREERUN_TIMER_CTRL 0x15B0
+#define REG_CPUMGQ_PROHIBIT 0x15B4
+#define REG_TIMER_COMPARE 0x15C0
+#define REG_TIMER_COMPARE_VALUE_LOW 0x15C4
+#define REG_TIMER_COMPARE_VALUE_HIGH 0x15C8
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BCN_PSR_RPT2 0x1600
+#define REG_BCN_PSR_RPT3 0x1604
+#define REG_BCN_PSR_RPT4 0x1608
+#define REG_A1_ADDR_MASK 0x160C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_RXPSF_CTRL 0x1610
+#define REG_RXPSF_TYPE_CTRL 0x1614
+#define REG_CAM_ACCESS_CTRL 0x1618
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_CUT_AMSDU_CTRL 0x161C
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_HT_SND_REF_RATE 0x161C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID2 0x1620
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID2_H 0x1624
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID2 0x1628
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID2_H 0x162C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID3 0x1630
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID3_H 0x1634
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID3 0x1638
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID3_H 0x163C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID4 0x1640
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MACID4_H 0x1644
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT ||   \
+     HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
+     HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID4 0x1648
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_BSSID4_H 0x164C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NOA_REPORT 0x1650
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_NOA_REPORT_1 0x1654
+#define REG_NOA_REPORT_2 0x1658
+#define REG_NOA_REPORT_3 0x165C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_PWRBIT_SETTING 0x1660
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_GENERAL_OPTION 0x1664
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_FWPHYFF_RCR 0x1668
+#define REG_ADDRCAM_WRITE_CONTENT 0x166C
+#define REG_ADDRCAM_READ_CONTENT 0x1670
+#define REG_ADDRCAM_CFG 0x1674
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define REG_WMAC_CSI_FRAME_RRSR_SETTING 0x1678
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_CSI_RRSR 0x1678
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
+
+#define REG_WMAC_MU_BF_OPTION 0x167C
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_MU_BF_OPTION 0x167C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_PAUSE_BB_CLR_TH 0x167D
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822B_SUPPORT)
+
+#define REG_WMAC_MU_ARB 0x167E
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_WMAC_MULBK_BUF 0x167E
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG__WMAC_MULBK_BUF 0x167E
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_MU_OPTION 0x167F
+#define REG_WMAC_MU_BF_CTL 0x1680
+#define REG_WMAC_MU_BFRPT_PARA 0x1682
+#define REG_WMAC_ASSOCIATED_MU_BFMEE2 0x1684
+#define REG_WMAC_ASSOCIATED_MU_BFMEE3 0x1686
+#define REG_WMAC_ASSOCIATED_MU_BFMEE4 0x1688
+#define REG_WMAC_ASSOCIATED_MU_BFMEE5 0x168A
+#define REG_WMAC_ASSOCIATED_MU_BFMEE6 0x168C
+#define REG_WMAC_ASSOCIATED_MU_BFMEE7 0x168E
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_BB_STOP_RX_COUNTER 0x1690
+#define REG_WMAC_PLCP_MONITOR 0x1694
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_WMAC_DEBUG_PORT 0x1698
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_PLCP_MONITOR_MUTX 0x1698
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_WMAC_CSIDMA_CFG 0x169C
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_0 0x16A0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_0_H 0x16A4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_1 0x16A8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_1_H 0x16AC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_2 0x16B0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_2_H 0x16B4
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_3 0x16B8
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_3_H 0x16BC
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_4 0x16C0
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define REG_TRANSMIT_ADDRSS_4_H 0x16C4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1 0x1700
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1 0x1704
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1 0x1708
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_BIST_RSTN0 0x2100
+#define REG_BIST_RSTN2 0x2108
+#define REG_BIST_MODE_NRML0 0x2110
+#define REG_BIST_MODE_NRML1 0x2114
+#define REG_BIST_MODE_NRML2 0x2118
+#define REG_BIST_MODE_NRML3 0x211C
+#define REG_BIST_DONE_NRML_MAC 0x2150
+#define REG_BIST_DONE_NRML1 0x2158
+#define REG_BIST_DONE_DRF_MAC 0x2160
+#define REG_BIST_DONE_DRF 0x2164
+#define REG_BIST_DONE_DRF1 0x2168
+#define REG_BIST_FAIL_NRML_MAC 0x2170
+#define REG_BIST_FAIL_NRML 0x2174
+#define REG_BIST_FAIL_NRML1 0x2178
+#define REG_BIST_FAIL_NRML_MAC_V1 0x2180
+#define REG_BIST_FAIL_NRML_V1 0x2184
+#define REG_BIST_FAIL_NRML1_V1 0x2188
+#define REG_BIST_MISR_DATAOUT 0x2190
+#define REG_BIST_MISR_DATAOUT1 0x2194
+#define REG_BIST_MISR_DATAOUT_CPU 0x2198
+#define REG_BIST_MISR_DATAOUT_CPU1 0x219C
+#define REG_BIST_MISR_DATAOUT_CPU2 0x21A0
+#define REG_BIST_MISR_DATOUT_CPU3 0x21A4
+#define REG_DMA_RQPN_INFO_0 0x2200
+#define REG_DMA_RQPN_INFO_1 0x2204
+#define REG_DMA_RQPN_INFO_2 0x2208
+#define REG_DMA_RQPN_INFO_3 0x220C
+#define REG_DMA_RQPN_INFO_4 0x2210
+#define REG_DMA_RQPN_INFO_5 0x2214
+#define REG_DMA_RQPN_INFO_6 0x2218
+#define REG_DMA_RQPN_INFO_7 0x221C
+#define REG_DMA_RQPN_INFO_8 0x2220
+#define REG_DMA_RQPN_INFO_9 0x2224
+#define REG_DMA_RQPN_INFO_10 0x2228
+#define REG_DMA_RQPN_INFO_11 0x222C
+#define REG_DMA_RQPN_INFO_12 0x2230
+#define REG_DMA_RQPN_INFO_13 0x2234
+#define REG_DMA_RQPN_INFO_14 0x2238
+#define REG_DMA_RQPN_INFO_15 0x223C
+#define REG_DMA_RQPN_INFO_16 0x2240
+#define REG_HWAMSDU_CTL1 0x2250
+#define REG_HWAMSDU_CTL2 0x2254
+#define REG_HI8Q_TXBD_DESA_L 0x2300
+#define REG_HI8Q_TXBD_DESA_H 0x2304
+#define REG_HI9Q_TXBD_DESA_L 0x2308
+#define REG_HI9Q_TXBD_DESA_H 0x230C
+#define REG_HI10Q_TXBD_DESA_L 0x2310
+#define REG_HI10Q_TXBD_DESA_H 0x2314
+#define REG_HI11Q_TXBD_DESA_L 0x2318
+#define REG_HI11Q_TXBD_DESA_H 0x231C
+#define REG_HI12Q_TXBD_DESA_L 0x2320
+#define REG_HI12Q_TXBD_DESA_H 0x2324
+#define REG_HI13Q_TXBD_DESA_L 0x2328
+#define REG_HI13Q_TXBD_DESA_H 0x232C
+#define REG_HI14Q_TXBD_DESA_L 0x2330
+#define REG_HI14Q_TXBD_DESA_H 0x2334
+#define REG_HI15Q_TXBD_DESA_L 0x2338
+#define REG_HI15Q_TXBD_DESA_H 0x233C
+#define REG_HI16Q_TXBD_DESA_L 0x2340
+#define REG_HI16Q_TXBD_DESA_H 0x2344
+#define REG_HI17Q_TXBD_DESA_L 0x2348
+#define REG_HI17Q_TXBD_DESA_H 0x234C
+#define REG_HI18Q_TXBD_DESA_L 0x2350
+#define REG_HI18Q_TXBD_DESA_H 0x2354
+#define REG_HI19Q_TXBD_DESA_L 0x2358
+#define REG_HI19Q_TXBD_DESA_H 0x235C
+#define REG_BD_RWPTR_CLR6 0x2364
+#define REG_P0HI16Q_TXBD_IDX 0x2370
+#define REG_P0HI17Q_TXBD_IDX 0x2374
+#define REG_P0HI18Q_TXBD_IDX 0x2378
+#define REG_P0HI19Q_TXBD_IDX 0x237C
+#define REG_P0HI16Q_HI17Q_TXBD_NUM 0x2380
+#define REG_P0HI18Q_HI19Q_TXBD_NUM 0x2384
+#define REG_PCIE_HISR0 0x23B4
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_HISR2_V1 0x23B4
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_PCIE_HISR1 0x23BC
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define REG_PCIE_HISR3_V1 0x23BC
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define REG_P0HI8Q_HI9Q_TXBD_NUM 0x23C0
+#define REG_P0HI10Q_HI11Q_TXBD_NUM 0x23C4
+#define REG_P0HI12Q_HI13Q_TXBD_NUM 0x23C8
+#define REG_P0HI14Q_HI15Q_TXBD_NUM 0x23CC
+#define REG_ACH6_ACH7_TXBD_NUM 0x23F0
+#define REG_TXPAGE_INT_CTRL_0 0x3200
+#define REG_TXPAGE_INT_CTRL_1 0x3204
+#define REG_TXPAGE_INT_CTRL_2 0x3208
+#define REG_TXPAGE_INT_CTRL_3 0x320C
+#define REG_TXPAGE_INT_CTRL_4 0x3210
+#define REG_TXPAGE_INT_CTRL_5 0x3214
+#define REG_TXPAGE_INT_CTRL_6 0x3218
+#define REG_TXPAGE_INT_CTRL_7 0x321C
+#define REG_TXPAGE_INT_CTRL_8 0x3220
+#define REG_TXPAGE_INT_CTRL_9 0x3224
+#define REG_TXPAGE_INT_CTRL_10 0x3228
+#define REG_TXPAGE_INT_CTRL_11 0x322C
+#define REG_TXPAGE_INT_CTRL_12 0x3230
+#define REG_TXPAGE_INT_CTRL_13 0x3234
+#define REG_TXPAGE_INT_CTRL_14 0x3238
+#define REG_TXPAGE_INT_CTRL_15 0x323C
+#define REG_TXPAGE_INT_CTRL_16 0x3240
+#define REG_ACH4_TXBD_IDX 0x3340
+#define REG_ACH5_TXBD_IDX 0x3344
+#define REG_ACH6_TXBD_IDX 0x3348
+#define REG_ACH7_TXBD_IDX 0x334C
+#define REG_ACH8_TXBD_IDX 0x3350
+#define REG_ACH9_TXBD_IDX 0x3354
+#define REG_ACH10_TXBD_IDX 0x3358
+#define REG_ACH11_TXBD_IDX 0x335C
+#define REG_ACH12_TXBD_IDX 0x3360
+#define REG_ACH13_TXBD_IDX 0x3364
+#define REG_AC_CHANNEL0_WEIGHT 0x3368
+#define REG_AC_CHANNEL1_WEIGHT 0x3369
+#define REG_AC_CHANNEL2_WEIGHT 0x336A
+#define REG_AC_CHANNEL3_WEIGHT 0x336B
+#define REG_AC_CHANNEL4_WEIGHT 0x336C
+#define REG_AC_CHANNEL5_WEIGHT 0x336D
+#define REG_AC_CHANNEL6_WEIGHT 0x336E
+#define REG_AC_CHANNEL7_WEIGHT 0x336F
+#define REG_AC_CHANNEL8_WEIGHT 0x3370
+#define REG_AC_CHANNEL9_WEIGHT 0x3371
+#define REG_AC_CHANNEL10_WEIGHT 0x3372
+#define REG_AC_CHANNEL11_WEIGHT 0x3373
+#define REG_AC_CHANNEL12_WEIGHT 0x3374
+#define REG_AC_CHANNEL13_WEIGHT 0x3375
+#define REG_PCIE_HISR2 0x33B4
+#define REG_PCIE_HISR3 0x33BC
+
+#endif
+
+/* ----------------------------------------------------- */
+/*	*/
+/* 0xFB00h ~ 0xFCFFh	TX/RX packet buffer affress */
+/*	*/
+/* ----------------------------------------------------- */
+#define REG_RXPKTBUF_STARTADDR 0xFB00
+#define REG_TXPKTBUF_STARTADDR 0xFC00
+
+/* ----------------------------------------------------- */
+/*	*/
+/* 0xFD00h ~ 0xFDFFh	8051 CPU Local REG */
+/*	*/
+/* ----------------------------------------------------- */
+#define REG_SYS_CTRL 0xFD00
+#define REG_PONSTS_RPT1 0xFD01
+#define REG_PONSTS_RPT2 0xFD02
+#define REG_PONSTS_RPT3 0xFD03
+#define REG_PONSTS_RPT4 0xFD04 /* 0x84 */
+#define REG_PONSTS_RPT5 0xFD05 /* 0x85 */
+#define REG_8051ERRFLAG 0xFD08
+#define REG_8051ERRFLAG_MASK 0xFD09
+#define REG_TXADDRH 0xFD10 /* Tx Packet High Address */
+#define REG_RXADDRH 0xFD11 /* Rx Packet High Address */
+#define REG_TXADDRH_EXT 0xFD12
+
+#define REG_U3_STATE 0xFD48
+
+/* for MAILBOX */
+#define REG_OUTDATA0 0xFD50
+#define REG_OUTDATA1 0xFD54
+#define REG_OUTRDY 0xFD58 /* bit[0] : OutReady, bit[1] : OutEmptyIntEn */
+
+#define REG_INDATA0 0xFD60
+#define REG_INDATA1 0xFD64
+#define REG_INRDY 0xFD68 /* bit[0] : InReady, bit[1] : InRdyIntEn */
+
+/* MCU ERROR debug REG */
+#define REG_MCUERR_PCLSB 0xFD90 /* PC[7:0] */
+#define REG_MCUERR_PCMSB 0xFD91 /* PC[15:8] */
+#define REG_MCUERR_ACC 0xFD92
+#define REG_MCUERR_B 0xFD93
+#define REG_MCUERR_DPTRLSB 0xFD94 /* DPTR[7:0] */
+#define REG_MCUERR_DPTRMSB 0xFD95 /* DPTR[15:8] */
+#define REG_MCUERR_SP 0xFD96 /* SP[7:0] */
+#define REG_MCUERR_IE 0xFD97 /* IE[7:0] */
+#define REG_MCUERR_EIE 0xFD98 /* EIE[7:0] */
+#define REG_VERA_SIM 0xFD9F
+/* 0xFD99~0xFD9F are reserved.. */
+
+/* ----------------------------------------------------- */
+/*	*/
+/* 0xFE00h ~ 0xFEFFh	USB Configuration */
+/*	*/
+/* ----------------------------------------------------- */
+
+/* RTS5101 USB Register Definition */
+#define REG_USB_SETUP_DEC_INT 0xFE00
+#define REG_USB_DMACTL 0xFE01
+#define REG_USB_IRQSTAT0 0xFE02
+#define REG_USB_IRQSTAT1 0xFE03
+#define REG_USB_IRQEN0 0xFE04
+#define REG_USB_IRQEN1 0xFE05
+#define REG_USB_AUTOPTRL 0xFE06
+#define REG_USB_AUTOPTRH 0xFE07
+#define REG_USB_AUTODAT 0xFE08
+
+#define REG_USB_SCRATCH0 0xFE09
+#define REG_USB_SCRATCH1 0xFE0A
+#define REG_USB_SEEPROM 0xFE0B
+#define REG_USB_GPIO0 0xFE0C
+#define REG_USB_GPIO0DIR 0xFE0D
+#define REG_USB_CLKSEL 0xFE0E
+#define REG_USB_BOOTCTL 0xFE0F
+
+#define REG_USB_USBCTL 0xFE10
+#define REG_USB_USBSTAT 0xFE11
+#define REG_USB_DEVADDR 0xFE12
+#define REG_USB_USBTEST 0xFE13
+#define REG_USB_FNUM0 0xFE14
+#define REG_USB_FNUM1 0xFE15
+
+#define REG_USB_EP_IDX 0xFE20
+#define REG_USB_EP_CFG 0xFE21
+#define REG_USB_EP_CTL 0xFE22
+#define REG_USB_EP_STAT 0xFE23
+#define REG_USB_EP_IRQ 0xFE24
+#define REG_USB_EP_IRQEN 0xFE25
+#define REG_USB_EP_MAXPKT0 0xFE26
+#define REG_USB_EP_MAXPKT1 0xFE27
+#define REG_USB_EP_DAT 0xFE28
+#define REG_USB_EP_BC0 0xFE29
+#define REG_USB_EP_BC1 0xFE2A
+#define REG_USB_EP_TC0 0xFE2B
+#define REG_USB_EP_TC1 0xFE2C
+#define REG_USB_EP_TC2 0xFE2D
+#define REG_USB_EP_CTL2 0xFE2E
+
+#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_OPT 0xFE64
+#define REG_USB_CONFIG 0xFE65
+
+#define REG_USB_PHY_PARA1 0xFE68
+#define REG_USB_PHY_PARA2 0xFE69
+#define REG_USB_PHY_PARA3 0xFE6A
+#define REG_USB_OPT2 0xFE6C
+#define REG_USB_MAC_ADDR 0xFE70
+#define REG_USB_MANUFACTURE_SETTING 0xFE80
+#define REG_USB_PRODUCT_STRING 0xFEA0
+#define REG_USB_SERIAL_NUMBER_STRING 0xFED0
+
+#define REG_USB_ALTERNATE_SETTING 0xFE4F
+#define REG_USB_INT_BINTERVAL 0xFE6E
+#define REG_USB_GPS_EP_CONFIG 0xFE6D
+
+#endif /* __HALMAC_COM_REG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8197f.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8197f.h
new file mode 100644
index 000000000000..6be0b3ff5a26
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8197f.h
@@ -0,0 +1,700 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_HALMAC_REG_8197F_H
+#define __INC_HALMAC_REG_8197F_H
+
+#define REG_SYS_ISO_CTRL_8197F 0x0000
+#define REG_SYS_FUNC_EN_8197F 0x0002
+#define REG_SYS_PW_CTRL_8197F 0x0004
+#define REG_SYS_CLK_CTRL_8197F 0x0008
+#define REG_SYS_EEPROM_CTRL_8197F 0x000A
+#define REG_EE_VPD_8197F 0x000C
+#define REG_SYS_SWR_CTRL1_8197F 0x0010
+#define REG_SYS_SWR_CTRL2_8197F 0x0014
+#define REG_SYS_SWR_CTRL3_8197F 0x0018
+#define REG_RSV_CTRL_8197F 0x001C
+#define REG_RF0_CTRL_8197F 0x001F
+#define REG_AFE_LDO_CTRL_8197F 0x0020
+#define REG_AFE_CTRL1_8197F 0x0024
+#define REG_AFE_CTRL2_8197F 0x0028
+#define REG_AFE_CTRL3_8197F 0x002C
+#define REG_EFUSE_CTRL_8197F 0x0030
+#define REG_LDO_EFUSE_CTRL_8197F 0x0034
+#define REG_PWR_OPTION_CTRL_8197F 0x0038
+#define REG_CAL_TIMER_8197F 0x003C
+#define REG_ACLK_MON_8197F 0x003E
+#define REG_GPIO_MUXCFG_8197F 0x0040
+#define REG_GPIO_PIN_CTRL_8197F 0x0044
+#define REG_GPIO_INTM_8197F 0x0048
+#define REG_LED_CFG_8197F 0x004C
+#define REG_FSIMR_8197F 0x0050
+#define REG_FSISR_8197F 0x0054
+#define REG_HSIMR_8197F 0x0058
+#define REG_HSISR_8197F 0x005C
+#define REG_GPIO_EXT_CTRL_8197F 0x0060
+#define REG_PAD_CTRL1_8197F 0x0064
+#define REG_WL_BT_PWR_CTRL_8197F 0x0068
+#define REG_SDM_DEBUG_8197F 0x006C
+#define REG_SYS_SDIO_CTRL_8197F 0x0070
+#define REG_HCI_OPT_CTRL_8197F 0x0074
+#define REG_AFE_CTRL4_8197F 0x0078
+#define REG_LDO_SWR_CTRL_8197F 0x007C
+#define REG_MCUFW_CTRL_8197F 0x0080
+#define REG_MCU_TST_CFG_8197F 0x0084
+#define REG_HMEBOX_E0_E1_8197F 0x0088
+#define REG_HMEBOX_E2_E3_8197F 0x008C
+#define REG_WLLPS_CTRL_8197F 0x0090
+#define REG_AFE_CTRL5_8197F 0x0094
+#define REG_GPIO_DEBOUNCE_CTRL_8197F 0x0098
+#define REG_RPWM2_8197F 0x009C
+#define REG_SYSON_FSM_MON_8197F 0x00A0
+#define REG_AFE_CTRL6_8197F 0x00A4
+#define REG_PMC_DBG_CTRL1_8197F 0x00A8
+#define REG_AFE_CTRL7_8197F 0x00AC
+#define REG_HIMR0_8197F 0x00B0
+#define REG_HISR0_8197F 0x00B4
+#define REG_HIMR1_8197F 0x00B8
+#define REG_HISR1_8197F 0x00BC
+#define REG_DBG_PORT_SEL_8197F 0x00C0
+#define REG_PAD_CTRL2_8197F 0x00C4
+#define REG_PMC_DBG_CTRL2_8197F 0x00CC
+#define REG_BIST_CTRL_8197F 0x00D0
+#define REG_BIST_RPT_8197F 0x00D4
+#define REG_MEM_CTRL_8197F 0x00D8
+#define REG_AFE_CTRL8_8197F 0x00DC
+#define REG_USB_SIE_INTF_8197F 0x00E0
+#define REG_PCIE_MIO_INTF_8197F 0x00E4
+#define REG_PCIE_MIO_INTD_8197F 0x00E8
+#define REG_WLRF1_8197F 0x00EC
+#define REG_SYS_CFG1_8197F 0x00F0
+#define REG_SYS_STATUS1_8197F 0x00F4
+#define REG_SYS_STATUS2_8197F 0x00F8
+#define REG_SYS_CFG2_8197F 0x00FC
+#define REG_SYS_CFG3_8197F 0x1000
+#define REG_SYS_CFG4_8197F 0x1034
+#define REG_CPU_DMEM_CON_8197F 0x1080
+#define REG_HIMR2_8197F 0x10B0
+#define REG_HISR2_8197F 0x10B4
+#define REG_HIMR3_8197F 0x10B8
+#define REG_HISR3_8197F 0x10BC
+#define REG_SW_MDIO_8197F 0x10C0
+#define REG_SW_FLUSH_8197F 0x10C4
+#define REG_DBG_GPIO_BMUX_8197F 0x10C8
+#define REG_FPGA_TAG_8197F 0x10CC
+#define REG_WL_DSS_CTRL0_8197F 0x10D0
+#define REG_WL_DSS_CTRL1_8197F 0x10D8
+#define REG_WL_DSS_STATUS1_8197F 0x10DC
+#define REG_FW_DBG0_8197F 0x10E0
+#define REG_FW_DBG1_8197F 0x10E4
+#define REG_FW_DBG2_8197F 0x10E8
+#define REG_FW_DBG3_8197F 0x10EC
+#define REG_FW_DBG4_8197F 0x10F0
+#define REG_FW_DBG5_8197F 0x10F4
+#define REG_FW_DBG6_8197F 0x10F8
+#define REG_FW_DBG7_8197F 0x10FC
+#define REG_CR_8197F 0x0100
+#define REG_TSF_CLK_STATE_8197F 0x0108
+#define REG_TXDMA_PQ_MAP_8197F 0x010C
+#define REG_TRXFF_BNDY_8197F 0x0114
+#define REG_PTA_I2C_MBOX_8197F 0x0118
+#define REG_RXFF_BNDY_8197F 0x011C
+#define REG_FE1IMR_8197F 0x0120
+#define REG_FE1ISR_8197F 0x0124
+#define REG_CPWM_8197F 0x012C
+#define REG_FWIMR_8197F 0x0130
+#define REG_FWISR_8197F 0x0134
+#define REG_FTIMR_8197F 0x0138
+#define REG_FTISR_8197F 0x013C
+#define REG_PKTBUF_DBG_CTRL_8197F 0x0140
+#define REG_PKTBUF_DBG_DATA_L_8197F 0x0144
+#define REG_PKTBUF_DBG_DATA_H_8197F 0x0148
+#define REG_CPWM2_8197F 0x014C
+#define REG_TC0_CTRL_8197F 0x0150
+#define REG_TC1_CTRL_8197F 0x0154
+#define REG_TC2_CTRL_8197F 0x0158
+#define REG_TC3_CTRL_8197F 0x015C
+#define REG_TC4_CTRL_8197F 0x0160
+#define REG_TCUNIT_BASE_8197F 0x0164
+#define REG_TC5_CTRL_8197F 0x0168
+#define REG_TC6_CTRL_8197F 0x016C
+#define REG_MBIST_FAIL_8197F 0x0170
+#define REG_MBIST_START_PAUSE_8197F 0x0174
+#define REG_MBIST_DONE_8197F 0x0178
+#define REG_MBIST_FAIL_NRML_8197F 0x017C
+#define REG_AES_DECRPT_DATA_8197F 0x0180
+#define REG_AES_DECRPT_CFG_8197F 0x0184
+#define REG_MACCLKFRQ_8197F 0x018C
+#define REG_TMETER_8197F 0x0190
+#define REG_OSC_32K_CTRL_8197F 0x0194
+#define REG_32K_CAL_REG1_8197F 0x0198
+#define REG_C2HEVT_8197F 0x01A0
+#define REG_SW_DEFINED_PAGE1_8197F 0x01B8
+#define REG_MCUTST_I_8197F 0x01C0
+#define REG_MCUTST_II_8197F 0x01C4
+#define REG_FMETHR_8197F 0x01C8
+#define REG_HMETFR_8197F 0x01CC
+#define REG_HMEBOX0_8197F 0x01D0
+#define REG_HMEBOX1_8197F 0x01D4
+#define REG_HMEBOX2_8197F 0x01D8
+#define REG_HMEBOX3_8197F 0x01DC
+#define REG_LLT_INIT_8197F 0x01E0
+#define REG_LLT_INIT_ADDR_8197F 0x01E4
+#define REG_BB_ACCESS_CTRL_8197F 0x01E8
+#define REG_BB_ACCESS_DATA_8197F 0x01EC
+#define REG_HMEBOX_E0_8197F 0x01F0
+#define REG_HMEBOX_E1_8197F 0x01F4
+#define REG_HMEBOX_E2_8197F 0x01F8
+#define REG_HMEBOX_E3_8197F 0x01FC
+#define REG_CR_EXT_8197F 0x1100
+#define REG_FWFF_8197F 0x1114
+#define REG_RXFF_PTR_V1_8197F 0x1118
+#define REG_RXFF_WTR_V1_8197F 0x111C
+#define REG_FE2IMR_8197F 0x1120
+#define REG_FE2ISR_8197F 0x1124
+#define REG_FE3IMR_8197F 0x1128
+#define REG_FE3ISR_8197F 0x112C
+#define REG_FE4IMR_8197F 0x1130
+#define REG_FE4ISR_8197F 0x1134
+#define REG_FT1IMR_8197F 0x1138
+#define REG_FT1ISR_8197F 0x113C
+#define REG_SPWR0_8197F 0x1140
+#define REG_SPWR1_8197F 0x1144
+#define REG_SPWR2_8197F 0x1148
+#define REG_SPWR3_8197F 0x114C
+#define REG_POWSEQ_8197F 0x1150
+#define REG_TC7_CTRL_V1_8197F 0x1158
+#define REG_TC8_CTRL_V1_8197F 0x115C
+#define REG_RXBCN_TBTT_INTERVAL_PORT0TO3_8197F 0x1160
+#define REG_RXBCN_TBTT_INTERVAL_PORT4_8197F 0x1164
+#define REG_EXT_QUEUE_REG_8197F 0x11C0
+#define REG_COUNTER_CONTROL_8197F 0x11C4
+#define REG_COUNTER_TH_8197F 0x11C8
+#define REG_COUNTER_SET_8197F 0x11CC
+#define REG_COUNTER_OVERFLOW_8197F 0x11D0
+#define REG_TDE_LEN_TH_8197F 0x11D4
+#define REG_RDE_LEN_TH_8197F 0x11D8
+#define REG_PCIE_EXEC_TIME_8197F 0x11DC
+#define REG_FT2IMR_8197F 0x11E0
+#define REG_FT2ISR_8197F 0x11E4
+#define REG_MSG2_8197F 0x11F0
+#define REG_MSG3_8197F 0x11F4
+#define REG_MSG4_8197F 0x11F8
+#define REG_MSG5_8197F 0x11FC
+#define REG_FIFOPAGE_CTRL_1_8197F 0x0200
+#define REG_FIFOPAGE_CTRL_2_8197F 0x0204
+#define REG_AUTO_LLT_V1_8197F 0x0208
+#define REG_TXDMA_OFFSET_CHK_8197F 0x020C
+#define REG_TXDMA_STATUS_8197F 0x0210
+#define REG_TX_DMA_DBG_8197F 0x0214
+#define REG_TQPNT1_8197F 0x0218
+#define REG_TQPNT2_8197F 0x021C
+#define REG_TQPNT3_8197F 0x0220
+#define REG_TQPNT4_8197F 0x0224
+#define REG_RQPN_CTRL_1_8197F 0x0228
+#define REG_RQPN_CTRL_2_8197F 0x022C
+#define REG_FIFOPAGE_INFO_1_8197F 0x0230
+#define REG_FIFOPAGE_INFO_2_8197F 0x0234
+#define REG_FIFOPAGE_INFO_3_8197F 0x0238
+#define REG_FIFOPAGE_INFO_4_8197F 0x023C
+#define REG_FIFOPAGE_INFO_5_8197F 0x0240
+#define REG_H2C_HEAD_8197F 0x0244
+#define REG_H2C_TAIL_8197F 0x0248
+#define REG_H2C_READ_ADDR_8197F 0x024C
+#define REG_H2C_WR_ADDR_8197F 0x0250
+#define REG_H2C_INFO_8197F 0x0254
+#define REG_RXDMA_AGG_PG_TH_8197F 0x0280
+#define REG_RXPKT_NUM_8197F 0x0284
+#define REG_RXDMA_STATUS_8197F 0x0288
+#define REG_RXDMA_DPR_8197F 0x028C
+#define REG_RXDMA_MODE_8197F 0x0290
+#define REG_C2H_PKT_8197F 0x0294
+#define REG_FWFF_C2H_8197F 0x0298
+#define REG_FWFF_CTRL_8197F 0x029C
+#define REG_FWFF_PKT_INFO_8197F 0x02A0
+#define REG_FC2H_INFO_8197F 0x02A4
+#define REG_DDMA_CH0SA_8197F 0x1200
+#define REG_DDMA_CH0DA_8197F 0x1204
+#define REG_DDMA_CH0CTRL_8197F 0x1208
+#define REG_DDMA_CH1SA_8197F 0x1210
+#define REG_DDMA_CH1DA_8197F 0x1214
+#define REG_DDMA_CH1CTRL_8197F 0x1218
+#define REG_DDMA_CH2SA_8197F 0x1220
+#define REG_DDMA_CH2DA_8197F 0x1224
+#define REG_DDMA_CH2CTRL_8197F 0x1228
+#define REG_DDMA_CH3SA_8197F 0x1230
+#define REG_DDMA_CH3DA_8197F 0x1234
+#define REG_DDMA_CH3CTRL_8197F 0x1238
+#define REG_DDMA_CH4SA_8197F 0x1240
+#define REG_DDMA_CH4DA_8197F 0x1244
+#define REG_DDMA_CH4CTRL_8197F 0x1248
+#define REG_DDMA_CH5SA_8197F 0x1250
+#define REG_DDMA_CH5DA_8197F 0x1254
+#define REG_REG_DDMA_CH5CTRL_8197F 0x1258
+#define REG_DDMA_INT_MSK_8197F 0x12E0
+#define REG_DDMA_CHSTATUS_8197F 0x12E8
+#define REG_DDMA_CHKSUM_8197F 0x12F0
+#define REG_DDMA_MONITOR_8197F 0x12FC
+#define REG_HCI_CTRL_8197F 0x0300
+#define REG_INT_MIG_8197F 0x0304
+#define REG_BCNQ_TXBD_DESA_8197F 0x0308
+#define REG_MGQ_TXBD_DESA_8197F 0x0310
+#define REG_VOQ_TXBD_DESA_8197F 0x0318
+#define REG_VIQ_TXBD_DESA_8197F 0x0320
+#define REG_BEQ_TXBD_DESA_8197F 0x0328
+#define REG_BKQ_TXBD_DESA_8197F 0x0330
+#define REG_RXQ_RXBD_DESA_8197F 0x0338
+#define REG_HI0Q_TXBD_DESA_8197F 0x0340
+#define REG_HI1Q_TXBD_DESA_8197F 0x0348
+#define REG_HI2Q_TXBD_DESA_8197F 0x0350
+#define REG_HI3Q_TXBD_DESA_8197F 0x0358
+#define REG_HI4Q_TXBD_DESA_8197F 0x0360
+#define REG_HI5Q_TXBD_DESA_8197F 0x0368
+#define REG_HI6Q_TXBD_DESA_8197F 0x0370
+#define REG_HI7Q_TXBD_DESA_8197F 0x0378
+#define REG_MGQ_TXBD_NUM_8197F 0x0380
+#define REG_RX_RXBD_NUM_8197F 0x0382
+#define REG_VOQ_TXBD_NUM_8197F 0x0384
+#define REG_VIQ_TXBD_NUM_8197F 0x0386
+#define REG_BEQ_TXBD_NUM_8197F 0x0388
+#define REG_BKQ_TXBD_NUM_8197F 0x038A
+#define REG_HI0Q_TXBD_NUM_8197F 0x038C
+#define REG_HI1Q_TXBD_NUM_8197F 0x038E
+#define REG_HI2Q_TXBD_NUM_8197F 0x0390
+#define REG_HI3Q_TXBD_NUM_8197F 0x0392
+#define REG_HI4Q_TXBD_NUM_8197F 0x0394
+#define REG_HI5Q_TXBD_NUM_8197F 0x0396
+#define REG_HI6Q_TXBD_NUM_8197F 0x0398
+#define REG_HI7Q_TXBD_NUM_8197F 0x039A
+#define REG_TSFTIMER_HCI_8197F 0x039C
+#define REG_BD_RWPTR_CLR_8197F 0x039C
+#define REG_VOQ_TXBD_IDX_8197F 0x03A0
+#define REG_VIQ_TXBD_IDX_8197F 0x03A4
+#define REG_BEQ_TXBD_IDX_8197F 0x03A8
+#define REG_BKQ_TXBD_IDX_8197F 0x03AC
+#define REG_MGQ_TXBD_IDX_8197F 0x03B0
+#define REG_RXQ_RXBD_IDX_8197F 0x03B4
+#define REG_HI0Q_TXBD_IDX_8197F 0x03B8
+#define REG_HI1Q_TXBD_IDX_8197F 0x03BC
+#define REG_HI2Q_TXBD_IDX_8197F 0x03C0
+#define REG_HI3Q_TXBD_IDX_8197F 0x03C4
+#define REG_HI4Q_TXBD_IDX_8197F 0x03C8
+#define REG_HI5Q_TXBD_IDX_8197F 0x03CC
+#define REG_HI6Q_TXBD_IDX_8197F 0x03D0
+#define REG_HI7Q_TXBD_IDX_8197F 0x03D4
+#define REG_DBG_SEL_V1_8197F 0x03D8
+#define REG_HCI_HRPWM1_V1_8197F 0x03D9
+#define REG_HCI_HCPWM1_V1_8197F 0x03DA
+#define REG_HCI_CTRL2_8197F 0x03DB
+#define REG_HCI_HRPWM2_V1_8197F 0x03DC
+#define REG_HCI_HCPWM2_V1_8197F 0x03DE
+#define REG_HCI_H2C_MSG_V1_8197F 0x03E0
+#define REG_HCI_C2H_MSG_V1_8197F 0x03E4
+#define REG_DBI_WDATA_V1_8197F 0x03E8
+#define REG_DBI_RDATA_V1_8197F 0x03EC
+#define REG_STUCK_FLAG_V1_8197F 0x03F0
+#define REG_MDIO_V1_8197F 0x03F4
+#define REG_WDT_CFG_8197F 0x03F8
+#define REG_HCI_MIX_CFG_8197F 0x03FC
+#define REG_STC_INT_CS_8197F 0x1300
+#define REG_ST_INT_CFG_8197F 0x1304
+#define REG_CMU_DLY_CTRL_8197F 0x1310
+#define REG_CMU_DLY_CFG_8197F 0x1314
+#define REG_H2CQ_TXBD_DESA_8197F 0x1320
+#define REG_H2CQ_TXBD_NUM_8197F 0x1328
+#define REG_H2CQ_TXBD_IDX_8197F 0x132C
+#define REG_H2CQ_CSR_8197F 0x1330
+#define REG_AXI_EXCEPT_CS_8197F 0x1350
+#define REG_AXI_EXCEPT_TIME_8197F 0x1354
+#define REG_Q0_INFO_8197F 0x0400
+#define REG_Q1_INFO_8197F 0x0404
+#define REG_Q2_INFO_8197F 0x0408
+#define REG_Q3_INFO_8197F 0x040C
+#define REG_MGQ_INFO_8197F 0x0410
+#define REG_HIQ_INFO_8197F 0x0414
+#define REG_BCNQ_INFO_8197F 0x0418
+#define REG_TXPKT_EMPTY_8197F 0x041A
+#define REG_CPU_MGQ_INFO_8197F 0x041C
+#define REG_FWHW_TXQ_CTRL_8197F 0x0420
+#define REG_BCNQ_BDNY_V1_8197F 0x0424
+#define REG_LIFETIME_EN_8197F 0x0426
+#define REG_SPEC_SIFS_8197F 0x0428
+#define REG_RETRY_LIMIT_8197F 0x042A
+#define REG_TXBF_CTRL_8197F 0x042C
+#define REG_DARFRC_8197F 0x0430
+#define REG_RARFRC_8197F 0x0438
+#define REG_RRSR_8197F 0x0440
+#define REG_ARFR0_8197F 0x0444
+#define REG_ARFR1_V1_8197F 0x044C
+#define REG_CCK_CHECK_8197F 0x0454
+#define REG_AMPDU_MAX_TIME_V1_8197F 0x0455
+#define REG_BCNQ1_BDNY_V1_8197F 0x0456
+#define REG_AMPDU_MAX_LENGTH_8197F 0x0458
+#define REG_ACQ_STOP_8197F 0x045C
+#define REG_NDPA_RATE_8197F 0x045D
+#define REG_TX_HANG_CTRL_8197F 0x045E
+#define REG_NDPA_OPT_CTRL_8197F 0x045F
+#define REG_RD_RESP_PKT_TH_8197F 0x0463
+#define REG_CMDQ_INFO_8197F 0x0464
+#define REG_Q4_INFO_8197F 0x0468
+#define REG_Q5_INFO_8197F 0x046C
+#define REG_Q6_INFO_8197F 0x0470
+#define REG_Q7_INFO_8197F 0x0474
+#define REG_WMAC_LBK_BUF_HD_V1_8197F 0x0478
+#define REG_MGQ_BDNY_V1_8197F 0x047A
+#define REG_TXRPT_CTRL_8197F 0x047C
+#define REG_INIRTS_RATE_SEL_8197F 0x0480
+#define REG_BASIC_CFEND_RATE_8197F 0x0481
+#define REG_STBC_CFEND_RATE_8197F 0x0482
+#define REG_DATA_SC_8197F 0x0483
+#define REG_MACID_SLEEP3_8197F 0x0484
+#define REG_MACID_SLEEP1_8197F 0x0488
+#define REG_ARFR2_V1_8197F 0x048C
+#define REG_ARFR3_V1_8197F 0x0494
+#define REG_ARFR4_8197F 0x049C
+#define REG_ARFR5_8197F 0x04A4
+#define REG_TXRPT_START_OFFSET_8197F 0x04AC
+#define REG_POWER_STAGE1_8197F 0x04B4
+#define REG_POWER_STAGE2_8197F 0x04B8
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8197F 0x04BC
+#define REG_PKT_LIFE_TIME_8197F 0x04C0
+#define REG_STBC_SETTING_8197F 0x04C4
+#define REG_STBC_SETTING2_8197F 0x04C5
+#define REG_QUEUE_CTRL_8197F 0x04C6
+#define REG_SINGLE_AMPDU_CTRL_8197F 0x04C7
+#define REG_PROT_MODE_CTRL_8197F 0x04C8
+#define REG_BAR_MODE_CTRL_8197F 0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8197F 0x04CF
+#define REG_MACID_SLEEP2_8197F 0x04D0
+#define REG_MACID_SLEEP_8197F 0x04D4
+#define REG_HW_SEQ0_8197F 0x04D8
+#define REG_HW_SEQ1_8197F 0x04DA
+#define REG_HW_SEQ2_8197F 0x04DC
+#define REG_HW_SEQ3_8197F 0x04DE
+#define REG_NULL_PKT_STATUS_V1_8197F 0x04E0
+#define REG_PTCL_ERR_STATUS_8197F 0x04E2
+#define REG_NULL_PKT_STATUS_EXTEND_8197F 0x04E3
+#define REG_VIDEO_ENHANCEMENT_FUN_8197F 0x04E4
+#define REG_BT_POLLUTE_PKT_CNT_8197F 0x04E8
+#define REG_PTCL_DBG_8197F 0x04EC
+#define REG_TXOP_EXTRA_CTRL_8197F 0x04F0
+#define REG_CPUMGQ_TIMER_CTRL2_8197F 0x04F4
+#define REG_DUMMY_PAGE4_8197F 0x04FC
+#define REG_Q0_Q1_INFO_8197F 0x1400
+#define REG_Q2_Q3_INFO_8197F 0x1404
+#define REG_Q4_Q5_INFO_8197F 0x1408
+#define REG_Q6_Q7_INFO_8197F 0x140C
+#define REG_MGQ_HIQ_INFO_8197F 0x1410
+#define REG_CMDQ_BCNQ_INFO_8197F 0x1414
+#define REG_USEREG_SETTING_8197F 0x1420
+#define REG_AESIV_SETTING_8197F 0x1424
+#define REG_BF0_TIME_SETTING_8197F 0x1428
+#define REG_BF1_TIME_SETTING_8197F 0x142C
+#define REG_BF_TIMEOUT_EN_8197F 0x1430
+#define REG_MACID_RELEASE0_8197F 0x1434
+#define REG_MACID_RELEASE1_8197F 0x1438
+#define REG_MACID_RELEASE2_8197F 0x143C
+#define REG_MACID_RELEASE3_8197F 0x1440
+#define REG_MACID_RELEASE_SETTING_8197F 0x1444
+#define REG_FAST_EDCA_VOVI_SETTING_8197F 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING_8197F 0x144C
+#define REG_MACID_DROP0_8197F 0x1450
+#define REG_MACID_DROP1_8197F 0x1454
+#define REG_MACID_DROP2_8197F 0x1458
+#define REG_MACID_DROP3_8197F 0x145C
+#define REG_R_MACID_RELEASE_SUCCESS_0_8197F 0x1460
+#define REG_R_MACID_RELEASE_SUCCESS_1_8197F 0x1464
+#define REG_R_MACID_RELEASE_SUCCESS_2_8197F 0x1468
+#define REG_R_MACID_RELEASE_SUCCESS_3_8197F 0x146C
+#define REG_MGG_FIFO_CRTL_8197F 0x1470
+#define REG_MGG_FIFO_INT_8197F 0x1474
+#define REG_MGG_FIFO_LIFETIME_8197F 0x1478
+#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F 0x147C
+#define REG_SHCUT_SETTING_8197F 0x1480
+#define REG_SHCUT_LLC_ETH_TYPE0_8197F 0x1484
+#define REG_SHCUT_LLC_ETH_TYPE1_8197F 0x1488
+#define REG_SHCUT_LLC_OUI0_8197F 0x148C
+#define REG_SHCUT_LLC_OUI1_8197F 0x1490
+#define REG_SHCUT_LLC_OUI2_8197F 0x1494
+#define REG_SHCUT_LLC_OUI3_8197F 0x1498
+#define REG_CHNL_INFO_CTRL_8197F 0x14D0
+#define REG_CHNL_IDLE_TIME_8197F 0x14D4
+#define REG_CHNL_BUSY_TIME_8197F 0x14D8
+#define REG_EDCA_VO_PARAM_8197F 0x0500
+#define REG_EDCA_VI_PARAM_8197F 0x0504
+#define REG_EDCA_BE_PARAM_8197F 0x0508
+#define REG_EDCA_BK_PARAM_8197F 0x050C
+#define REG_BCNTCFG_8197F 0x0510
+#define REG_PIFS_8197F 0x0512
+#define REG_RDG_PIFS_8197F 0x0513
+#define REG_SIFS_8197F 0x0514
+#define REG_TSFTR_SYN_OFFSET_8197F 0x0518
+#define REG_AGGR_BREAK_TIME_8197F 0x051A
+#define REG_SLOT_8197F 0x051B
+#define REG_TX_PTCL_CTRL_8197F 0x0520
+#define REG_TXPAUSE_8197F 0x0522
+#define REG_DIS_TXREQ_CLR_8197F 0x0523
+#define REG_RD_CTRL_8197F 0x0524
+#define REG_MBSSID_CTRL_8197F 0x0526
+#define REG_P2PPS_CTRL_8197F 0x0527
+#define REG_PKT_LIFETIME_CTRL_8197F 0x0528
+#define REG_P2PPS_SPEC_STATE_8197F 0x052B
+#define REG_QUEUE_INCOL_THR_8197F 0x0538
+#define REG_QUEUE_INCOL_EN_8197F 0x053C
+#define REG_TBTT_PROHIBIT_8197F 0x0540
+#define REG_P2PPS_STATE_8197F 0x0543
+#define REG_RD_NAV_NXT_8197F 0x0544
+#define REG_NAV_PROT_LEN_8197F 0x0546
+#define REG_FTM_CTRL_8197F 0x0548
+#define REG_FTM_TSF_CNT_8197F 0x054C
+#define REG_BCN_CTRL_8197F 0x0550
+#define REG_BCN_CTRL_CLINT0_8197F 0x0551
+#define REG_MBID_NUM_8197F 0x0552
+#define REG_DUAL_TSF_RST_8197F 0x0553
+#define REG_MBSSID_BCN_SPACE_8197F 0x0554
+#define REG_DRVERLYINT_8197F 0x0558
+#define REG_BCNDMATIM_8197F 0x0559
+#define REG_ATIMWND_8197F 0x055A
+#define REG_USTIME_TSF_8197F 0x055C
+#define REG_BCN_MAX_ERR_8197F 0x055D
+#define REG_RXTSF_OFFSET_CCK_8197F 0x055E
+#define REG_RXTSF_OFFSET_OFDM_8197F 0x055F
+#define REG_TSFTR_8197F 0x0560
+#define REG_FREERUN_CNT_8197F 0x0568
+#define REG_ATIMWND1_8197F 0x0570
+#define REG_TBTT_PROHIBIT_INFRA_8197F 0x0571
+#define REG_CTWND_8197F 0x0572
+#define REG_BCNIVLCUNT_8197F 0x0573
+#define REG_BCNDROPCTRL_8197F 0x0574
+#define REG_HGQ_TIMEOUT_PERIOD_8197F 0x0575
+#define REG_TXCMD_TIMEOUT_PERIOD_8197F 0x0576
+#define REG_MISC_CTRL_8197F 0x0577
+#define REG_BCN_CTRL_CLINT1_8197F 0x0578
+#define REG_BCN_CTRL_CLINT2_8197F 0x0579
+#define REG_BCN_CTRL_CLINT3_8197F 0x057A
+#define REG_EXTEND_CTRL_8197F 0x057B
+#define REG_P2PPS1_SPEC_STATE_8197F 0x057C
+#define REG_P2PPS1_STATE_8197F 0x057D
+#define REG_P2PPS2_SPEC_STATE_8197F 0x057E
+#define REG_P2PPS2_STATE_8197F 0x057F
+#define REG_PS_TIMER0_8197F 0x0580
+#define REG_PS_TIMER1_8197F 0x0584
+#define REG_PS_TIMER2_8197F 0x0588
+#define REG_TBTT_CTN_AREA_8197F 0x058C
+#define REG_FORCE_BCN_IFS_8197F 0x058E
+#define REG_TXOP_MIN_8197F 0x0590
+#define REG_PRE_BKF_TIME_8197F 0x0592
+#define REG_CROSS_TXOP_CTRL_8197F 0x0593
+#define REG_TBTT_INT_SHIFT_CLI0_8197F 0x0594
+#define REG_TBTT_INT_SHIFT_CLI1_8197F 0x0595
+#define REG_TBTT_INT_SHIFT_CLI2_8197F 0x0596
+#define REG_TBTT_INT_SHIFT_CLI3_8197F 0x0597
+#define REG_TBTT_INT_SHIFT_ENABLE_8197F 0x0598
+#define REG_ATIMWND2_8197F 0x05A0
+#define REG_ATIMWND3_8197F 0x05A1
+#define REG_ATIMWND4_8197F 0x05A2
+#define REG_ATIMWND5_8197F 0x05A3
+#define REG_ATIMWND6_8197F 0x05A4
+#define REG_ATIMWND7_8197F 0x05A5
+#define REG_ATIMUGT_8197F 0x05A6
+#define REG_HIQ_NO_LMT_EN_8197F 0x05A7
+#define REG_DTIM_COUNTER_ROOT_8197F 0x05A8
+#define REG_DTIM_COUNTER_VAP1_8197F 0x05A9
+#define REG_DTIM_COUNTER_VAP2_8197F 0x05AA
+#define REG_DTIM_COUNTER_VAP3_8197F 0x05AB
+#define REG_DTIM_COUNTER_VAP4_8197F 0x05AC
+#define REG_DTIM_COUNTER_VAP5_8197F 0x05AD
+#define REG_DTIM_COUNTER_VAP6_8197F 0x05AE
+#define REG_DTIM_COUNTER_VAP7_8197F 0x05AF
+#define REG_DIS_ATIM_8197F 0x05B0
+#define REG_EARLY_128US_8197F 0x05B1
+#define REG_P2PPS1_CTRL_8197F 0x05B2
+#define REG_P2PPS2_CTRL_8197F 0x05B3
+#define REG_TIMER0_SRC_SEL_8197F 0x05B4
+#define REG_NOA_UNIT_SEL_8197F 0x05B5
+#define REG_P2POFF_DIS_TXTIME_8197F 0x05B7
+#define REG_MBSSID_BCN_SPACE2_8197F 0x05B8
+#define REG_MBSSID_BCN_SPACE3_8197F 0x05BC
+#define REG_ACMHWCTRL_8197F 0x05C0
+#define REG_ACMRSTCTRL_8197F 0x05C1
+#define REG_ACMAVG_8197F 0x05C2
+#define REG_VO_ADMTIME_8197F 0x05C4
+#define REG_VI_ADMTIME_8197F 0x05C6
+#define REG_BE_ADMTIME_8197F 0x05C8
+#define REG_EDCA_RANDOM_GEN_8197F 0x05CC
+#define REG_TXCMD_NOA_SEL_8197F 0x05CF
+#define REG_NOA_PARAM_8197F 0x05E0
+#define REG_P2P_RST_8197F 0x05F0
+#define REG_SCHEDULER_RST_8197F 0x05F1
+#define REG_SCH_TXCMD_8197F 0x05F8
+#define REG_PAGE5_DUMMY_8197F 0x05FC
+#define REG_CPUMGQ_TX_TIMER_8197F 0x1500
+#define REG_PS_TIMER_A_8197F 0x1504
+#define REG_PS_TIMER_B_8197F 0x1508
+#define REG_PS_TIMER_C_8197F 0x150C
+#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8197F 0x1510
+#define REG_CPUMGQ_TX_TIMER_EARLY_8197F 0x1514
+#define REG_PS_TIMER_A_EARLY_8197F 0x1515
+#define REG_PS_TIMER_B_EARLY_8197F 0x1516
+#define REG_PS_TIMER_C_EARLY_8197F 0x1517
+#define REG_WMAC_CR_8197F 0x0600
+#define REG_WMAC_FWPKT_CR_8197F 0x0601
+#define REG_BWOPMODE_8197F 0x0603
+#define REG_TCR_8197F 0x0604
+#define REG_RCR_8197F 0x0608
+#define REG_RX_PKT_LIMIT_8197F 0x060C
+#define REG_RX_DLK_TIME_8197F 0x060D
+#define REG_RX_DRVINFO_SZ_8197F 0x060F
+#define REG_MACID_8197F 0x0610
+#define REG_BSSID_8197F 0x0618
+#define REG_MAR_8197F 0x0620
+#define REG_MBIDCAMCFG_1_8197F 0x0628
+#define REG_MBIDCAMCFG_2_8197F 0x062C
+#define REG_WMAC_TCR_TSFT_OFS_8197F 0x0630
+#define REG_UDF_THSD_8197F 0x0632
+#define REG_ZLD_NUM_8197F 0x0633
+#define REG_STMP_THSD_8197F 0x0634
+#define REG_WMAC_TXTIMEOUT_8197F 0x0635
+#define REG_MCU_TEST_2_V1_8197F 0x0636
+#define REG_USTIME_EDCA_8197F 0x0638
+#define REG_MAC_SPEC_SIFS_8197F 0x063A
+#define REG_RESP_SIFS_CCK_8197F 0x063C
+#define REG_RESP_SIFS_OFDM_8197F 0x063E
+#define REG_ACKTO_8197F 0x0640
+#define REG_CTS2TO_8197F 0x0641
+#define REG_EIFS_8197F 0x0642
+#define REG_NAV_CTRL_8197F 0x0650
+#define REG_BACAMCMD_8197F 0x0654
+#define REG_BACAMCONTENT_8197F 0x0658
+#define REG_LBDLY_8197F 0x0660
+#define REG_WMAC_BACAM_RPMEN_8197F 0x0661
+#define REG_WMAC_BITMAP_CTL_8197F 0x0663
+#define REG_RXERR_RPT_8197F 0x0664
+#define REG_WMAC_TRXPTCL_CTL_8197F 0x0668
+#define REG_CAMCMD_8197F 0x0670
+#define REG_CAMWRITE_8197F 0x0674
+#define REG_CAMREAD_8197F 0x0678
+#define REG_CAMDBG_8197F 0x067C
+#define REG_SECCFG_8197F 0x0680
+#define REG_RXFILTER_CATEGORY_1_8197F 0x0682
+#define REG_RXFILTER_ACTION_1_8197F 0x0683
+#define REG_RXFILTER_CATEGORY_2_8197F 0x0684
+#define REG_RXFILTER_ACTION_2_8197F 0x0685
+#define REG_RXFILTER_CATEGORY_3_8197F 0x0686
+#define REG_RXFILTER_ACTION_3_8197F 0x0687
+#define REG_RXFLTMAP3_8197F 0x0688
+#define REG_RXFLTMAP4_8197F 0x068A
+#define REG_RXFLTMAP5_8197F 0x068C
+#define REG_RXFLTMAP6_8197F 0x068E
+#define REG_WOW_CTRL_8197F 0x0690
+#define REG_PS_RX_INFO_8197F 0x0692
+#define REG_WMMPS_UAPSD_TID_8197F 0x0693
+#define REG_LPNAV_CTRL_8197F 0x0694
+#define REG_WKFMCAM_CMD_8197F 0x0698
+#define REG_WKFMCAM_RWD_8197F 0x069C
+#define REG_RXFLTMAP0_8197F 0x06A0
+#define REG_RXFLTMAP1_8197F 0x06A2
+#define REG_RXFLTMAP_8197F 0x06A4
+#define REG_BCN_PSR_RPT_8197F 0x06A8
+#define REG_RXPKTMON_CTRL_8197F 0x06B0
+#define REG_STATE_MON_8197F 0x06B4
+#define REG_ERROR_MON_8197F 0x06B8
+#define REG_SEARCH_MACID_8197F 0x06BC
+#define REG_BT_COEX_TABLE_8197F 0x06C0
+#define REG_RXCMD_0_8197F 0x06D0
+#define REG_RXCMD_1_8197F 0x06D4
+#define REG_WMAC_RESP_TXINFO_8197F 0x06D8
+#define REG_BBPSF_CTRL_8197F 0x06DC
+#define REG_P2P_RX_BCN_NOA_8197F 0x06E0
+#define REG_ASSOCIATED_BFMER0_INFO_8197F 0x06E4
+#define REG_ASSOCIATED_BFMER1_INFO_8197F 0x06EC
+#define REG_TX_CSI_RPT_PARAM_BW20_8197F 0x06F4
+#define REG_TX_CSI_RPT_PARAM_BW40_8197F 0x06F8
+#define REG_TX_CSI_RPT_PARAM_BW80_8197F 0x06FC
+#define REG_BCN_PSR_RPT2_8197F 0x1600
+#define REG_BCN_PSR_RPT3_8197F 0x1604
+#define REG_BCN_PSR_RPT4_8197F 0x1608
+#define REG_A1_ADDR_MASK_8197F 0x160C
+#define REG_MACID2_8197F 0x1620
+#define REG_BSSID2_8197F 0x1628
+#define REG_MACID3_8197F 0x1630
+#define REG_BSSID3_8197F 0x1638
+#define REG_MACID4_8197F 0x1640
+#define REG_BSSID4_8197F 0x1648
+#define REG_NOA_REPORT_8197F 0x1650
+#define REG_PWRBIT_SETTING_8197F 0x1660
+#define REG_WMAC_MU_BF_OPTION_8197F 0x167C
+#define REG_WMAC_PAUSE_BB_CLR_TH_8197F 0x167D
+#define REG_WMAC_MU_ARB_8197F 0x167E
+#define REG_WMAC_MU_OPTION_8197F 0x167F
+#define REG_WMAC_MU_BF_CTL_8197F 0x1680
+#define REG_WMAC_MU_BFRPT_PARA_8197F 0x1682
+#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8197F 0x1684
+#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8197F 0x1686
+#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8197F 0x1688
+#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8197F 0x168A
+#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8197F 0x168C
+#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8197F 0x168E
+#define REG_TRANSMIT_ADDRSS_0_8197F 0x16A0
+#define REG_TRANSMIT_ADDRSS_1_8197F 0x16A8
+#define REG_TRANSMIT_ADDRSS_2_8197F 0x16B0
+#define REG_TRANSMIT_ADDRSS_3_8197F 0x16B8
+#define REG_TRANSMIT_ADDRSS_4_8197F 0x16C0
+#define REG_MACID1_8197F 0x0700
+#define REG_BSSID1_8197F 0x0708
+#define REG_BCN_PSR_RPT1_8197F 0x0710
+#define REG_ASSOCIATED_BFMEE_SEL_8197F 0x0714
+#define REG_SND_PTCL_CTRL_8197F 0x0718
+#define REG_RX_CSI_RPT_INFO_8197F 0x071C
+#define REG_NS_ARP_CTRL_8197F 0x0720
+#define REG_NS_ARP_INFO_8197F 0x0724
+#define REG_BEAMFORMING_INFO_NSARP_V1_8197F 0x0728
+#define REG_BEAMFORMING_INFO_NSARP_8197F 0x072C
+#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8197F 0x0750
+#define REG_WMAC_SWAES_CFG_8197F 0x0760
+#define REG_BT_COEX_V2_8197F 0x0762
+#define REG_BT_COEX_8197F 0x0764
+#define REG_WLAN_ACT_MASK_CTRL_8197F 0x0768
+#define REG_BT_COEX_ENHANCED_INTR_CTRL_8197F 0x076E
+#define REG_BT_ACT_STATISTICS_8197F 0x0770
+#define REG_BT_STATISTICS_CONTROL_REGISTER_8197F 0x0778
+#define REG_BT_STATUS_REPORT_REGISTER_8197F 0x077C
+#define REG_BT_INTERRUPT_CONTROL_REGISTER_8197F 0x0780
+#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8197F 0x0784
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8197F 0x0785
+#define REG_BT_INTERRUPT_STATUS_REGISTER_8197F 0x078F
+#define REG_BT_TDMA_TIME_REGISTER_8197F 0x0790
+#define REG_BT_ACT_REGISTER_8197F 0x0794
+#define REG_OBFF_CTRL_BASIC_8197F 0x0798
+#define REG_OBFF_CTRL2_TIMER_8197F 0x079C
+#define REG_LTR_CTRL_BASIC_8197F 0x07A0
+#define REG_LTR_CTRL2_TIMER_THRESHOLD_8197F 0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8197F 0x07A8
+#define REG_LTR_ACTIVE_LATENCY_V1_8197F 0x07AC
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8197F 0x07B0
+#define REG_WMAC_PKTCNT_RWD_8197F 0x07B8
+#define REG_WMAC_PKTCNT_CTRL_8197F 0x07BC
+#define REG_IQ_DUMP_8197F 0x07C0
+#define REG_WMAC_FTM_CTL_8197F 0x07CC
+#define REG_IQ_DUMP_EXT_8197F 0x07CF
+#define REG_OFDM_CCK_LEN_MASK_8197F 0x07D0
+#define REG_RX_FILTER_FUNCTION_8197F 0x07DA
+#define REG_NDP_SIG_8197F 0x07E0
+#define REG_TXCMD_INFO_FOR_RSP_PKT_8197F 0x07E4
+#define REG_SEC_OPT_V2_8197F 0x07EC
+#define REG_RTS_ADDRESS_0_8197F 0x07F0
+#define REG_RTS_ADDRESS_1_8197F 0x07F8
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8814b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8814b.h
new file mode 100644
index 000000000000..9fb8ff50c535
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8814b.h
@@ -0,0 +1,1058 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_HALMAC_REG_8814B_H
+#define __INC_HALMAC_REG_8814B_H
+
+#define REG_SYS_ISO_CTRL_8814B 0x0000
+#define REG_SYS_FUNC_EN_8814B 0x0002
+#define REG_SYS_PW_CTRL_8814B 0x0004
+#define REG_SYS_CLK_CTRL_8814B 0x0008
+#define REG_SYS_EEPROM_CTRL_8814B 0x000A
+#define REG_EE_VPD_8814B 0x000C
+#define REG_SYS_SWR_CTRL1_8814B 0x0010
+#define REG_SYS_SWR_CTRL2_8814B 0x0014
+#define REG_SYS_SWR_CTRL3_8814B 0x0018
+#define REG_RSV_CTRL_8814B 0x001C
+#define REG_RF_CTRL_8814B 0x001F
+#define REG_AFE_LDO_CTRL_8814B 0x0020
+#define REG_AFE_CTRL1_8814B 0x0024
+#define REG_ANAPARSW_POW_MAC_8814B 0x0028
+#define REG_ANAPARLDO_POW_MAC_8814B 0x0029
+#define REG_ANAPAR_POW_MAC_8814B 0x002A
+#define REG_ANAPAR_POW_XTAL_8814B 0x002B
+#define REG_ANAPARLDO_MAC_8814B 0x002C
+#define REG_EFUSE_CTRL_8814B 0x0030
+#define REG_LDO_EFUSE_CTRL_8814B 0x0034
+#define REG_PWR_OPTION_CTRL_8814B 0x0038
+#define REG_CAL_TIMER_8814B 0x003C
+#define REG_ACLK_MON_8814B 0x003E
+#define REG_GPIO_MUXCFG_8814B 0x0040
+#define REG_GPIO_PIN_CTRL_8814B 0x0044
+#define REG_GPIO_INTM_8814B 0x0048
+#define REG_LED_CFG_8814B 0x004C
+#define REG_FSIMR_8814B 0x0050
+#define REG_FSISR_8814B 0x0054
+#define REG_HSIMR_8814B 0x0058
+#define REG_HSISR_8814B 0x005C
+#define REG_GPIO_EXT_CTRL_8814B 0x0060
+#define REG_PAD_CTRL1_8814B 0x0064
+#define REG_WL_BT_PWR_CTRL_8814B 0x0068
+#define REG_SDM_DEBUG_8814B 0x006C
+#define REG_SYS_SDIO_CTRL_8814B 0x0070
+#define REG_HCI_OPT_CTRL_8814B 0x0074
+#define REG_AFE_CTRL4_8814B 0x0078
+#define REG_LDO_SWR_CTRL_8814B 0x007C
+#define REG_MCUFW_CTRL_8814B 0x0080
+#define REG_MCU_TST_CFG_8814B 0x0084
+#define REG_HMEBOX_E0_E1_8814B 0x0088
+#define REG_HMEBOX_E2_E3_8814B 0x008C
+#define REG_WLLPS_CTRL_8814B 0x0090
+#define REG_AFE_CTRL5_8814B 0x0094
+#define REG_GPIO_DEBOUNCE_CTRL_8814B 0x0098
+#define REG_RPWM2_8814B 0x009C
+#define REG_SYSON_FSM_MON_8814B 0x00A0
+#define REG_AFE_CTRL6_8814B 0x00A4
+#define REG_PMC_DBG_CTRL1_8814B 0x00A8
+#define REG_AFE_CTRL7_8814B 0x00AC
+#define REG_HIMR0_8814B 0x00B0
+#define REG_HISR0_8814B 0x00B4
+#define REG_HIMR1_8814B 0x00B8
+#define REG_HISR1_8814B 0x00BC
+#define REG_DBG_PORT_SEL_8814B 0x00C0
+#define REG_PAD_CTRL2_8814B 0x00C4
+#define REG_PMC_DBG_CTRL2_8814B 0x00CC
+#define REG_MEM_CTRL_8814B 0x00D8
+#define REG_SYN_RFC_CTRL_8814B 0x00DC
+#define REG_USB_SIE_INTF_8814B 0x00E0
+#define REG_PCIE_MIO_INTF_8814B 0x00E4
+#define REG_PCIE_MIO_INTD_8814B 0x00E8
+#define REG_WLRF1_8814B 0x00EC
+#define REG_SYS_CFG1_8814B 0x00F0
+#define REG_SYS_STATUS1_8814B 0x00F4
+#define REG_SYS_STATUS2_8814B 0x00F8
+#define REG_SYS_CFG2_8814B 0x00FC
+#define REG_ANAPARSW_MAC_0_8814B 0x1010
+#define REG_ANAPARSW_MAC_1_8814B 0x1014
+#define REG_ANAPAR_MAC_0_8814B 0x1018
+#define REG_ANAPAR_MAC_1_8814B 0x101C
+#define REG_ANAPAR_MAC_2_8814B 0x1020
+#define REG_ANAPAR_MAC_3_8814B 0x1024
+#define REG_ANAPAR_MAC_4_8814B 0x1028
+#define REG_ANAPAR_MAC_5_8814B 0x102C
+#define REG_ANAPAR_MAC_6_8814B 0x1030
+#define REG_ANAPAR_MAC_7_8814B 0x1034
+#define REG_ANAPAR_MAC_8_8814B 0x1038
+#define REG_ANAPAR_XTAL_0_8814B 0x1040
+#define REG_ANAPAR_XTAL_1_8814B 0x1044
+#define REG_ANAPAR_XTAL_2_8814B 0x1048
+#define REG_ANAPAR_XTAL_AAC_8814B 0x104C
+#define REG_ANAPAR_XTAL_R_ONLY_8814B 0x1050
+#define REG_CPHY_LDO_8814B 0x1054
+#define REG_CPHY_BG_8814B 0x1058
+#define REG_HIMR_4_8814B 0x1060
+#define REG_HISR_4_8814B 0x1064
+#define REG_HIMR_5_8814B 0x1068
+#define REG_HISR_5_8814B 0x106C
+#define REG_SYS_CFG5_8814B 0x1070
+#define REG_HIMR_6_8814B 0x1078
+#define REG_HISR_6_8814B 0x107C
+#define REG_CPU_DMEM_CON_8814B 0x1080
+#define REG_BOOT_REASON_8814B 0x1088
+#define REG_DATA_CPU_CTL0_8814B 0x1090
+#define REG_DATA_CPU_CTL1_8814B 0x1094
+#define REG_TXDMA_STOP_HIMR_8814B 0x1098
+#define REG_TXDMA_STOP_HISR_8814B 0x109C
+#define REG_TXDMA_START_HIMR_8814B 0x10A0
+#define REG_TXDMA_START_HISR_8814B 0x10A4
+#define REG_NFCPAD_CTRL_8814B 0x10A8
+#define REG_HIMR2_8814B 0x10B0
+#define REG_HISR2_8814B 0x10B4
+#define REG_HIMR3_8814B 0x10B8
+#define REG_HISR3_8814B 0x10BC
+#define REG_SW_MDIO_8814B 0x10C0
+#define REG_HIMR_7_8814B 0x10C8
+#define REG_HISR_7_8814B 0x10CC
+#define REG_H2C_PKT_READADDR_8814B 0x10D0
+#define REG_H2C_PKT_WRITEADDR_8814B 0x10D4
+#define REG_MEM_PWR_CRTL_8814B 0x10D8
+#define REG_FW_DRV_HANDSHAKE_8814B 0x10DC
+#define REG_FW_DBG0_8814B 0x10E0
+#define REG_FW_DBG1_8814B 0x10E4
+#define REG_FW_DBG2_8814B 0x10E8
+#define REG_FW_DBG3_8814B 0x10EC
+#define REG_FW_DBG4_8814B 0x10F0
+#define REG_FW_DBG5_8814B 0x10F4
+#define REG_FW_DBG6_8814B 0x10F8
+#define REG_FW_DBG7_8814B 0x10FC
+#define REG_CR_8814B 0x0100
+#define REG_PG_SIZE_8814B 0x0104
+#define REG_PKT_BUFF_ACCESS_CTRL_8814B 0x0106
+#define REG_TSF_CLK_STATE_8814B 0x0108
+#define REG_TXDMA_PQ_MAP_8814B 0x010C
+#define REG_TRXFF_BNDY_8814B 0x0114
+#define REG_PTA_I2C_MBOX_8814B 0x0118
+#define REG_RXFF_BNDY_8814B 0x011C
+#define REG_FE1IMR_8814B 0x0120
+#define REG_FE1ISR_8814B 0x0124
+#define REG_CPWM_8814B 0x012C
+#define REG_FWIMR_8814B 0x0130
+#define REG_FWISR_8814B 0x0134
+#define REG_FTIMR_8814B 0x0138
+#define REG_FTISR_8814B 0x013C
+#define REG_PKTBUF_DBG_CTRL_8814B 0x0140
+#define REG_PKTBUF_DBG_DATA_L_8814B 0x0144
+#define REG_PKTBUF_DBG_DATA_H_8814B 0x0148
+#define REG_CPWM2_8814B 0x014C
+#define REG_TC0_CTRL_8814B 0x0150
+#define REG_TC1_CTRL_8814B 0x0154
+#define REG_TC2_CTRL_8814B 0x0158
+#define REG_TC3_CTRL_8814B 0x015C
+#define REG_TC4_CTRL_8814B 0x0160
+#define REG_TCUNIT_BASE_8814B 0x0164
+#define REG_TC5_CTRL_8814B 0x0168
+#define REG_TC6_CTRL_8814B 0x016C
+#define REG_AES_DECRPT_DATA_8814B 0x0180
+#define REG_AES_DECRPT_CFG_8814B 0x0184
+#define REG_HIOE_CTRL_8814B 0x0188
+#define REG_HIOE_CFG_FILE_8814B 0x018C
+#define REG_TMETER_8814B 0x0190
+#define REG_OSC_32K_CTRL_8814B 0x0194
+#define REG_32K_CAL_REG1_8814B 0x0198
+#define REG_C2HEVT_8814B 0x01A0
+#define REG_C2HEVT_1_8814B 0x01A4
+#define REG_C2HEVT_2_8814B 0x01A8
+#define REG_C2HEVT_3_8814B 0x01AC
+#define REG_RXDESC_BUFF_RPTR_8814B 0x01B0
+#define REG_RXDESC_BUFF_WPTR_8814B 0x01B4
+#define REG_SW_DEFINED_PAGE1_8814B 0x01B8
+#define REG_SW_DEFINED_PAGE2_8814B 0x01BC
+#define REG_MCUTST_I_8814B 0x01C0
+#define REG_MCUTST_II_8814B 0x01C4
+#define REG_FMETHR_8814B 0x01C8
+#define REG_HMETFR_8814B 0x01CC
+#define REG_HMEBOX0_8814B 0x01D0
+#define REG_HMEBOX1_8814B 0x01D4
+#define REG_HMEBOX2_8814B 0x01D8
+#define REG_HMEBOX3_8814B 0x01DC
+#define REG_RXDESC_BUFF_BNDY_8814B 0x01E0
+#define REG_BB_ACCESS_CTRL_8814B 0x01E8
+#define REG_BB_ACCESS_DATA_8814B 0x01EC
+#define REG_HMEBOX_E0_8814B 0x01F0
+#define REG_HMEBOX_E1_8814B 0x01F4
+#define REG_HMEBOX_E2_8814B 0x01F8
+#define REG_HMEBOX_E3_8814B 0x01FC
+#define REG_CR_EXT_8814B 0x1100
+#define REG_TC9_CTRL_8814B 0x1104
+#define REG_TC10_CTRL_8814B 0x1108
+#define REG_TC11_CTRL_8814B 0x110C
+#define REG_TC12_CTRL_8814B 0x1110
+#define REG_FWFF_8814B 0x1114
+#define REG_RXFF_PTR_V1_8814B 0x1118
+#define REG_RXFF_WTR_V1_8814B 0x111C
+#define REG_FE2IMR_8814B 0x1120
+#define REG_FE2ISR_8814B 0x1124
+#define REG_FE3IMR_8814B 0x1128
+#define REG_FE3ISR_8814B 0x112C
+#define REG_FE4IMR_8814B 0x1130
+#define REG_FE4ISR_8814B 0x1134
+#define REG_FT1IMR_8814B 0x1138
+#define REG_FT1ISR_8814B 0x113C
+#define REG_SPWR0_8814B 0x1140
+#define REG_SPWR1_8814B 0x1144
+#define REG_SPWR2_8814B 0x1148
+#define REG_SPWR3_8814B 0x114C
+#define REG_POWSEQ_8814B 0x1150
+#define REG_TC7_CTRL_V1_8814B 0x1158
+#define REG_TC8_CTRL_V1_8814B 0x115C
+#define REG_RX_BCN_TBTT_ITVL0_8814B 0x1160
+#define REG_RX_BCN_TBTT_ITVL1_8814B 0x1164
+#define REG_FWIMR1_8814B 0x1168
+#define REG_FWISR1_8814B 0x116C
+#define REG_FWIMR2_8814B 0x1170
+#define REG_FWISR2_8814B 0x1174
+#define REG_FWIMR3_8814B 0x1178
+#define REG_FWISR3_8814B 0x117C
+#define REG_SPEED_SENSOR_8814B 0x1180
+#define REG_SPEED_SENSOR1_8814B 0x1184
+#define REG_SPEED_SENSOR2_8814B 0x1188
+#define REG_SPEED_SENSOR3_8814B 0x118C
+#define REG_SPEED_SENSOR4_8814B 0x1190
+#define REG_SPEED_SENSOR5_8814B 0x1194
+#define REG_RXPKTBUF_1_MAX_ADDR_8814B 0x1198
+#define REG_RXFWBUF_1_MAX_ADDR_8814B 0x119C
+#define REG_IO_WRAP_ERR_FLAG_V1_8814B 0x11A0
+#define REG_RXPKTBUF_1_READ_8814B 0x11A4
+#define REG_RXPKTBUF_1_WRITE_8814B 0x11A8
+#define REG_BUFF_DBGUG_8814B 0x11AC
+#define REG_RFE_CTRL_PAD_E2_8814B 0x11B0
+#define REG_RFE_CTRL_PAD_SR_8814B 0x11B4
+#define REG_H2C_PRIORITY_SEL_8814B 0x11C0
+#define REG_COUNTER_CTRL_8814B 0x11C4
+#define REG_COUNTER_THRESHOLD_8814B 0x11C8
+#define REG_COUNTER_SET_8814B 0x11CC
+#define REG_COUNTER_OVERFLOW_8814B 0x11D0
+#define REG_TXDMA_LEN_THRESHOLD_8814B 0x11D4
+#define REG_RXDMA_LEN_THRESHOLD_8814B 0x11D8
+#define REG_PCIE_EXEC_TIME_THRESHOLD_8814B 0x11DC
+#define REG_FT2IMR_8814B 0x11E0
+#define REG_FT2ISR_8814B 0x11E4
+#define REG_MSG2_8814B 0x11F0
+#define REG_MSG3_8814B 0x11F4
+#define REG_MSG4_8814B 0x11F8
+#define REG_MSG5_8814B 0x11FC
+#define REG_BIST_RSTN0_8814B 0x2100
+#define REG_BIST_RSTN2_8814B 0x2108
+#define REG_BIST_MODE_NRML0_8814B 0x2110
+#define REG_BIST_MODE_NRML1_8814B 0x2114
+#define REG_BIST_MODE_NRML2_8814B 0x2118
+#define REG_BIST_MODE_NRML3_8814B 0x211C
+#define REG_BIST_DONE_NRML_MAC_8814B 0x2150
+#define REG_BIST_DONE_NRML1_8814B 0x2158
+#define REG_BIST_DONE_DRF_MAC_8814B 0x2160
+#define REG_BIST_DONE_DRF_8814B 0x2164
+#define REG_BIST_DONE_DRF1_8814B 0x2168
+#define REG_BIST_FAIL_NRML_MAC_8814B 0x2170
+#define REG_BIST_FAIL_NRML_8814B 0x2174
+#define REG_BIST_FAIL_NRML1_8814B 0x2178
+#define REG_BIST_FAIL_NRML_MAC_V1_8814B 0x2180
+#define REG_BIST_FAIL_NRML_V1_8814B 0x2184
+#define REG_BIST_FAIL_NRML1_V1_8814B 0x2188
+#define REG_BIST_MISR_DATAOUT_8814B 0x2190
+#define REG_BIST_MISR_DATAOUT1_8814B 0x2194
+#define REG_BIST_MISR_DATAOUT_CPU_8814B 0x2198
+#define REG_BIST_MISR_DATAOUT_CPU1_8814B 0x219C
+#define REG_BIST_MISR_DATAOUT_CPU2_8814B 0x21A0
+#define REG_BIST_MISR_DATOUT_CPU3_8814B 0x21A4
+#define REG_BCN_CTRL_0_8814B 0x0200
+#define REG_BCN_CTRL_1_8814B 0x0204
+#define REG_AUTO_LLT_V1_8814B 0x0208
+#define REG_TXDMA_OFFSET_CHK_8814B 0x020C
+#define REG_TXDMA_STATUS_8814B 0x0210
+#define REG_TX_DMA_DBG_8814B 0x0214
+#define REG_DMA_RQPN_INFO_PUB_8814B 0x0218
+#define REG_RQPN_CTRL_2_V1_8814B 0x021C
+#define REG_BCN_CTRL_2_8814B 0x0220
+#define REG_TXPKTNUM_0_8814B 0x0230
+#define REG_TXPKTNUM_1_8814B 0x0234
+#define REG_TXPKTNUM_2_8814B 0x0238
+#define REG_TXPKTNUM_3_8814B 0x023C
+#define REG_TX_AGG_ALIGN_8814B 0x0240
+#define REG_H2C_HEAD_8814B 0x0244
+#define REG_H2C_TAIL_8814B 0x0248
+#define REG_H2C_READ_ADDR_8814B 0x024C
+#define REG_H2C_WR_ADDR_8814B 0x0250
+#define REG_H2C_INFO_8814B 0x0254
+#define REG_DMA_OQT_0_8814B 0x0260
+#define REG_DMA_OQT_1_8814B 0x0264
+#define REG_RXDMA_AGG_PG_TH_8814B 0x0280
+#define REG_RXDMA_CTRL_8814B 0x0284
+#define REG_RXDMA_STATUS_8814B 0x0288
+#define REG_RXDMA_DPR_8814B 0x028C
+#define REG_RXDMA_MODE_8814B 0x0290
+#define REG_C2H_PKT_8814B 0x0294
+#define REG_FWFF_C2H_8814B 0x0298
+#define REG_FWFF_CTRL_8814B 0x029C
+#define REG_FWFF_PKT_INFO_8814B 0x02A0
+#define REG_FWFF_PKT_INFO2_8814B 0x02A4
+#define REG_RXPKTNUM_8814B 0x02B0
+#define REG_RXPKTNUM_TH_8814B 0x02B4
+#define REG_FW_UPD_RXDES_RDPTR_8814B 0x02B8
+#define REG_DDMA_CH0SA_8814B 0x1200
+#define REG_DDMA_CH0DA_8814B 0x1204
+#define REG_DDMA_CH0CTRL_8814B 0x1208
+#define REG_DDMA_CH1SA_8814B 0x1210
+#define REG_DDMA_CH1DA_8814B 0x1214
+#define REG_DDMA_CH1CTRL_8814B 0x1218
+#define REG_DDMA_CH2SA_8814B 0x1220
+#define REG_DDMA_CH2DA_8814B 0x1224
+#define REG_DDMA_CH2CTRL_8814B 0x1228
+#define REG_DDMA_CH3SA_8814B 0x1230
+#define REG_DDMA_CH3DA_8814B 0x1234
+#define REG_DDMA_CH3CTRL_8814B 0x1238
+#define REG_DDMA_CH4SA_8814B 0x1240
+#define REG_DDMA_CH4DA_8814B 0x1244
+#define REG_DDMA_CH4CTRL_8814B 0x1248
+#define REG_DDMA_CH5SA_8814B 0x1250
+#define REG_DDMA_CH5DA_8814B 0x1254
+#define REG_DDMA_CH5CTRL_8814B 0x1258
+#define REG_DDMA_INT_MSK_8814B 0x12E0
+#define REG_DDMA_CHSTATUS_8814B 0x12E8
+#define REG_DDMA_CHKSUM_8814B 0x12F0
+#define REG_DDMA_MONITOR_8814B 0x12FC
+#define REG_DMA_RQPN_INFO_0_8814B 0x2200
+#define REG_DMA_RQPN_INFO_1_8814B 0x2204
+#define REG_DMA_RQPN_INFO_2_8814B 0x2208
+#define REG_DMA_RQPN_INFO_3_8814B 0x220C
+#define REG_DMA_RQPN_INFO_4_8814B 0x2210
+#define REG_DMA_RQPN_INFO_5_8814B 0x2214
+#define REG_DMA_RQPN_INFO_6_8814B 0x2218
+#define REG_DMA_RQPN_INFO_7_8814B 0x221C
+#define REG_DMA_RQPN_INFO_8_8814B 0x2220
+#define REG_DMA_RQPN_INFO_9_8814B 0x2224
+#define REG_DMA_RQPN_INFO_10_8814B 0x2228
+#define REG_DMA_RQPN_INFO_11_8814B 0x222C
+#define REG_DMA_RQPN_INFO_12_8814B 0x2230
+#define REG_DMA_RQPN_INFO_13_8814B 0x2234
+#define REG_DMA_RQPN_INFO_14_8814B 0x2238
+#define REG_DMA_RQPN_INFO_15_8814B 0x223C
+#define REG_DMA_RQPN_INFO_16_8814B 0x2240
+#define REG_HWAMSDU_CTL1_8814B 0x2250
+#define REG_HWAMSDU_CTL2_8814B 0x2254
+#define REG_TXPAGE_INT_CTRL_0_8814B 0x3200
+#define REG_TXPAGE_INT_CTRL_1_8814B 0x3204
+#define REG_TXPAGE_INT_CTRL_2_8814B 0x3208
+#define REG_TXPAGE_INT_CTRL_3_8814B 0x320C
+#define REG_TXPAGE_INT_CTRL_4_8814B 0x3210
+#define REG_TXPAGE_INT_CTRL_5_8814B 0x3214
+#define REG_TXPAGE_INT_CTRL_6_8814B 0x3218
+#define REG_TXPAGE_INT_CTRL_7_8814B 0x321C
+#define REG_TXPAGE_INT_CTRL_8_8814B 0x3220
+#define REG_TXPAGE_INT_CTRL_9_8814B 0x3224
+#define REG_TXPAGE_INT_CTRL_10_8814B 0x3228
+#define REG_TXPAGE_INT_CTRL_11_8814B 0x322C
+#define REG_TXPAGE_INT_CTRL_12_8814B 0x3230
+#define REG_TXPAGE_INT_CTRL_13_8814B 0x3234
+#define REG_TXPAGE_INT_CTRL_14_8814B 0x3238
+#define REG_TXPAGE_INT_CTRL_15_8814B 0x323C
+#define REG_TXPAGE_INT_CTRL_16_8814B 0x3240
+#define REG_PCIE_CTRL_8814B 0x0300
+#define REG_ACH_CTRL_8814B 0x0304
+#define REG_HIQ_CTRL_8814B 0x0308
+#define REG_INT_MIG_V1_8814B 0x030C
+#define REG_P0MGQ_TXBD_DESA_L_8814B 0x0310
+#define REG_P0MGQ_TXBD_DESA_H_8814B 0x0314
+#define REG_ACH0_TXBD_DESA_L_8814B 0x0318
+#define REG_ACH0_TXBD_DESA_H_8814B 0x031C
+#define REG_ACH1_TXBD_DESA_L_8814B 0x0320
+#define REG_ACH1_TXBD_DESA_H_8814B 0x0324
+#define REG_ACH2_TXBD_DESA_L_8814B 0x0328
+#define REG_ACH2_TXBD_DESA_H_8814B 0x032C
+#define REG_ACH3_TXBD_DESA_L_8814B 0x0330
+#define REG_ACH3_TXBD_DESA_H_8814B 0x0334
+#define REG_P0RXQ_RXBD_DESA_L_8814B 0x0338
+#define REG_P0RXQ_RXBD_DESA_H_8814B 0x033C
+#define REG_P0BCNQ_TXBD_DESA_L_8814B 0x0340
+#define REG_P0BCNQ_TXBD_DESA_H_8814B 0x0344
+#define REG_FWCMDQ_TXBD_DESA_L_8814B 0x0348
+#define REG_FWCMDQ_TXBD_DESA_H_8814B 0x034C
+#define REG_PCIE_HRPWM1_HCPWM1_DCPU_8814B 0x0354
+#define REG_P0_MPRT_BCNQ_TXBD_DESA_L_8814B 0x0358
+#define REG_P0_MPRT_BCNQ_TXBD_DESA_H_8814B 0x035C
+#define REG_P0_MPRT_BCNQ_TXRXBD_NUM_8814B 0x036C
+#define REG_BD_RWPTR_CLR2_8814B 0x0370
+#define REG_BD_RWPTR_CLR3_8814B 0x0374
+#define REG_P0MGQ_RXQ_TXRXBD_NUM_8814B 0x0378
+#define REG_CHNL_DMA_CFG_8814B 0x037C
+#define REG_FWCMDQ_TXBD_NUM_8814B 0x0380
+#define REG_ACH0_ACH1_TXBD_NUM_8814B 0x0384
+#define REG_ACH2_ACH3_TXBD_NUM_8814B 0x0388
+#define REG_P0HI0Q_HI1Q_TXBD_NUM_8814B 0x038C
+#define REG_P0HI2Q_HI3Q_TXBD_NUM_8814B 0x0390
+#define REG_P0HI4Q_HI5Q_TXBD_NUM_8814B 0x0394
+#define REG_P0HI6Q_HI7Q_TXBD_NUM_8814B 0x0398
+#define REG_BD_RWPTR_CLR1_8814B 0x039C
+#define REG_TSFTIMER_HCI_8814B 0x039C
+#define REG_ACH0_TXBD_IDX_8814B 0x03A0
+#define REG_ACH1_TXBD_IDX_8814B 0x03A4
+#define REG_ACH2_TXBD_IDX_8814B 0x03A8
+#define REG_ACH3_TXBD_IDX_8814B 0x03AC
+#define REG_P0MGQ_TXBD_IDX_8814B 0x03B0
+#define REG_P0RXQ_RXBD_IDX_8814B 0x03B4
+#define REG_P0HI0Q_TXBD_IDX_8814B 0x03B8
+#define REG_P0HI1Q_TXBD_IDX_8814B 0x03BC
+#define REG_P0HI2Q_TXBD_IDX_8814B 0x03C0
+#define REG_P0HI3Q_TXBD_IDX_8814B 0x03C4
+#define REG_P0HI4Q_TXBD_IDX_8814B 0x03C8
+#define REG_P0HI5Q_TXBD_IDX_8814B 0x03CC
+#define REG_P0HI6Q_TXBD_IDX_8814B 0x03D0
+#define REG_P0HI7Q_TXBD_IDX_8814B 0x03D4
+#define REG_DBGSEL_PCIE_HRPWM1_HCPWM1_V1_8814B 0x03D8
+#define REG_PCIE_HRPWM2_HCPWM2_V1_8814B 0x03DC
+#define REG_PCIE_H2C_MSG_V1_8814B 0x03E0
+#define REG_PCIE_C2H_MSG_V1_8814B 0x03E4
+#define REG_DBI_WDATA_V1_8814B 0x03E8
+#define REG_DBI_RDATA_V1_8814B 0x03EC
+#define REG_DBI_FLAG_V1_8814B 0x03F0
+#define REG_MDIO_V1_8814B 0x03F4
+#define REG_PCIE_MIX_CFG_8814B 0x03F8
+#define REG_HCI_MIX_CFG_8814B 0x03FC
+#define REG_STC_INT_CS_8814B 0x1300
+#define REG_ST_INT_CFG_8814B 0x1304
+#define REG_ACH4_ACH5_TXBD_NUM_8814B 0x130C
+#define REG_FWCMDQ_TXBD_IDX_8814B 0x1318
+#define REG_P0HI8Q_TXBD_IDX_8814B 0x131C
+#define REG_H2CQ_TXBD_DESA_L_8814B 0x1320
+#define REG_H2CQ_TXBD_DESA_H_8814B 0x1324
+#define REG_H2CQ_TXBD_NUM_8814B 0x1328
+#define REG_H2CQ_TXBD_IDX_8814B 0x132C
+#define REG_H2CQ_CSR_8814B 0x1330
+#define REG_P0HI9Q_TXBD_IDX_8814B 0x1334
+#define REG_P0HI10Q_TXBD_IDX_8814B 0x1338
+#define REG_P0HI11Q_TXBD_IDX_8814B 0x133C
+#define REG_P0HI12Q_TXBD_IDX_8814B 0x1340
+#define REG_P0HI13Q_TXBD_IDX_8814B 0x1344
+#define REG_P0HI14Q_TXBD_IDX_8814B 0x1348
+#define REG_P0HI15Q_TXBD_IDX_8814B 0x134C
+#define REG_CHANGE_PCIE_SPEED_8814B 0x1350
+#define REG_DEBUG_STATE1_8814B 0x1354
+#define REG_DEBUG_STATE2_8814B 0x1358
+#define REG_DEBUG_STATE3_8814B 0x135C
+#define REG_ACH5_TXBD_DESA_L_8814B 0x1360
+#define REG_ACH5_TXBD_DESA_H_8814B 0x1364
+#define REG_ACH6_TXBD_DESA_L_8814B 0x1368
+#define REG_ACH6_TXBD_DESA_H_8814B 0x136C
+#define REG_ACH7_TXBD_DESA_L_8814B 0x1370
+#define REG_ACH7_TXBD_DESA_H_8814B 0x1374
+#define REG_ACH8_TXBD_DESA_L_8814B 0x1378
+#define REG_ACH8_TXBD_DESA_H_8814B 0x137C
+#define REG_ACH9_TXBD_DESA_L_8814B 0x1380
+#define REG_ACH9_TXBD_DESA_H_8814B 0x1384
+#define REG_ACH10_TXBD_DESA_L_8814B 0x1388
+#define REG_ACH10_TXBD_DESA_H_8814B 0x138C
+#define REG_ACH11_TXBD_DESA_L_8814B 0x1390
+#define REG_ACH11_TXBD_DESA_H_8814B 0x1394
+#define REG_ACH12_TXBD_DESA_L_8814B 0x1398
+#define REG_ACH12_TXBD_DESA_H_8814B 0x139C
+#define REG_ACH13_TXBD_DESA_L_8814B 0x13A0
+#define REG_ACH13_TXBD_DESA_H_8814B 0x13A4
+#define REG_HI0Q_TXBD_DESA_L_8814B 0x13A8
+#define REG_HI0Q_TXBD_DESA_H_8814B 0x13AC
+#define REG_HI1Q_TXBD_DESA_L_8814B 0x13B0
+#define REG_HI1Q_TXBD_DESA_H_8814B 0x13B4
+#define REG_HI2Q_TXBD_DESA_L_8814B 0x13B8
+#define REG_HI2Q_TXBD_DESA_H_8814B 0x13BC
+#define REG_HI3Q_TXBD_DESA_L_8814B 0x13C0
+#define REG_HI3Q_TXBD_DESA_H_8814B 0x13C4
+#define REG_HI4Q_TXBD_DESA_L_8814B 0x13C8
+#define REG_HI4Q_TXBD_DESA_H_8814B 0x13CC
+#define REG_HI5Q_TXBD_DESA_L_8814B 0x13D0
+#define REG_HI5Q_TXBD_DESA_H_8814B 0x13D4
+#define REG_HI6Q_TXBD_DESA_L_8814B 0x13D8
+#define REG_HI6Q_TXBD_DESA_H_8814B 0x13DC
+#define REG_HI7Q_TXBD_DESA_L_8814B 0x13E0
+#define REG_HI7Q_TXBD_DESA_H_8814B 0x13E4
+#define REG_ACH8_ACH9_TXBD_NUM_8814B 0x13E8
+#define REG_ACH10_ACH11_TXBD_NUM_8814B 0x13EC
+#define REG_ACH12_ACH13_TXBD_NUM_8814B 0x13F0
+#define REG_OLD_DEHANG_8814B 0x13F4
+#define REG_ACH4_TXBD_DESA_L_8814B 0x13F8
+#define REG_ACH4_TXBD_DESA_H_8814B 0x13FC
+#define REG_HI8Q_TXBD_DESA_L_8814B 0x2300
+#define REG_HI8Q_TXBD_DESA_H_8814B 0x2304
+#define REG_HI9Q_TXBD_DESA_L_8814B 0x2308
+#define REG_HI9Q_TXBD_DESA_H_8814B 0x230C
+#define REG_HI10Q_TXBD_DESA_L_8814B 0x2310
+#define REG_HI10Q_TXBD_DESA_H_8814B 0x2314
+#define REG_HI11Q_TXBD_DESA_L_8814B 0x2318
+#define REG_HI11Q_TXBD_DESA_H_8814B 0x231C
+#define REG_HI12Q_TXBD_DESA_L_8814B 0x2320
+#define REG_HI12Q_TXBD_DESA_H_8814B 0x2324
+#define REG_HI13Q_TXBD_DESA_L_8814B 0x2328
+#define REG_HI13Q_TXBD_DESA_H_8814B 0x232C
+#define REG_HI14Q_TXBD_DESA_L_8814B 0x2330
+#define REG_HI14Q_TXBD_DESA_H_8814B 0x2334
+#define REG_HI15Q_TXBD_DESA_L_8814B 0x2338
+#define REG_HI15Q_TXBD_DESA_H_8814B 0x233C
+#define REG_HI16Q_TXBD_DESA_L_8814B 0x2340
+#define REG_HI16Q_TXBD_DESA_H_8814B 0x2344
+#define REG_HI17Q_TXBD_DESA_L_8814B 0x2348
+#define REG_HI17Q_TXBD_DESA_H_8814B 0x234C
+#define REG_HI18Q_TXBD_DESA_L_8814B 0x2350
+#define REG_HI18Q_TXBD_DESA_H_8814B 0x2354
+#define REG_HI19Q_TXBD_DESA_L_8814B 0x2358
+#define REG_HI19Q_TXBD_DESA_H_8814B 0x235C
+#define REG_BD_RWPTR_CLR6_8814B 0x2364
+#define REG_P0HI16Q_TXBD_IDX_8814B 0x2370
+#define REG_P0HI17Q_TXBD_IDX_8814B 0x2374
+#define REG_P0HI18Q_TXBD_IDX_8814B 0x2378
+#define REG_P0HI19Q_TXBD_IDX_8814B 0x237C
+#define REG_P0HI16Q_HI17Q_TXBD_NUM_8814B 0x2380
+#define REG_P0HI18Q_HI19Q_TXBD_NUM_8814B 0x2384
+#define REG_PCIE_HISR0_8814B 0x23B4
+#define REG_PCIE_HISR1_8814B 0x23BC
+#define REG_P0HI8Q_HI9Q_TXBD_NUM_8814B 0x23C0
+#define REG_P0HI10Q_HI11Q_TXBD_NUM_8814B 0x23C4
+#define REG_P0HI12Q_HI13Q_TXBD_NUM_8814B 0x23C8
+#define REG_P0HI14Q_HI15Q_TXBD_NUM_8814B 0x23CC
+#define REG_ACH6_ACH7_TXBD_NUM_8814B 0x23F0
+#define REG_ACH4_TXBD_IDX_8814B 0x3340
+#define REG_ACH5_TXBD_IDX_8814B 0x3344
+#define REG_ACH6_TXBD_IDX_8814B 0x3348
+#define REG_ACH7_TXBD_IDX_8814B 0x334C
+#define REG_ACH8_TXBD_IDX_8814B 0x3350
+#define REG_ACH9_TXBD_IDX_8814B 0x3354
+#define REG_ACH10_TXBD_IDX_8814B 0x3358
+#define REG_ACH11_TXBD_IDX_8814B 0x335C
+#define REG_ACH12_TXBD_IDX_8814B 0x3360
+#define REG_ACH13_TXBD_IDX_8814B 0x3364
+#define REG_AC_CHANNEL0_WEIGHT_8814B 0x3368
+#define REG_AC_CHANNEL1_WEIGHT_8814B 0x3369
+#define REG_AC_CHANNEL2_WEIGHT_8814B 0x336A
+#define REG_AC_CHANNEL3_WEIGHT_8814B 0x336B
+#define REG_AC_CHANNEL4_WEIGHT_8814B 0x336C
+#define REG_AC_CHANNEL5_WEIGHT_8814B 0x336D
+#define REG_AC_CHANNEL6_WEIGHT_8814B 0x336E
+#define REG_AC_CHANNEL7_WEIGHT_8814B 0x336F
+#define REG_AC_CHANNEL8_WEIGHT_8814B 0x3370
+#define REG_AC_CHANNEL9_WEIGHT_8814B 0x3371
+#define REG_AC_CHANNEL10_WEIGHT_8814B 0x3372
+#define REG_AC_CHANNEL11_WEIGHT_8814B 0x3373
+#define REG_AC_CHANNEL12_WEIGHT_8814B 0x3374
+#define REG_AC_CHANNEL13_WEIGHT_8814B 0x3375
+#define REG_PCIE_HISR2_8814B 0x33B4
+#define REG_PCIE_HISR3_8814B 0x33BC
+#define REG_QUEUELIST_INFO0_8814B 0x0400
+#define REG_QUEUELIST_INFO1_8814B 0x0404
+#define REG_QUEUELIST_INFO2_8814B 0x0408
+#define REG_QUEUELIST_INFO3_8814B 0x040C
+#define REG_QUEUELIST_INFO_EMPTY_8814B 0x0410
+#define REG_QUEUELIST_ACQ_EN_8814B 0x0414
+#define REG_BCNQ_BDNY_V2_8814B 0x0418
+#define REG_CPU_MGQ_INFO_8814B 0x041C
+#define REG_FWHW_TXQ_CTRL_8814B 0x0420
+#define REG_DATAFB_SEL_8814B 0x0423
+#define REG_TXBDNY_8814B 0x0424
+#define REG_LIFETIME_EN_8814B 0x0426
+#define REG_SPEC_SIFS_8814B 0x0428
+#define REG_RETRY_LIMIT_8814B 0x042A
+#define REG_TXBF_CTRL_8814B 0x042C
+#define REG_DARFRC_8814B 0x0430
+#define REG_DARFRCH_8814B 0x0434
+#define REG_RARFRC_8814B 0x0438
+#define REG_RARFRCH_8814B 0x043C
+#define REG_RRSR_8814B 0x0440
+#define REG_ARFR0_8814B 0x0444
+#define REG_ARFRH0_8814B 0x0448
+#define REG_REG_ARFR_WT0_8814B 0x044C
+#define REG_REG_ARFR_WT1_8814B 0x0450
+#define REG_CCK_CHECK_8814B 0x0454
+#define REG_AMPDU_MAX_TIME_V1_8814B 0x0455
+#define REG_TAB_SEL_8814B 0x0456
+#define REG_BCN_INVALID_CTRL_8814B 0x0457
+#define REG_AMPDU_MAX_LENGTH_HT_8814B 0x0458
+#define REG_NDPA_RATE_8814B 0x045D
+#define REG_TX_HANG_CTRL_8814B 0x045E
+#define REG_NDPA_OPT_CTRL_8814B 0x045F
+#define REG_AMPDU_MAX_LENGTH_VHT_8814B 0x0460
+#define REG_RD_RESP_PKT_TH_8814B 0x0463
+#define REG_NEW_EDCA_CTRL_V1_8814B 0x0464
+#define REG_ACQ_STOP_V2_8814B 0x0468
+#define REG_WMAC_LBK_BUF_HD_V1_8814B 0x0478
+#define REG_MGQ_BDNY_V1_8814B 0x047A
+#define REG_TXRPT_CTRL_8814B 0x047C
+#define REG_INIRTS_RATE_SEL_8814B 0x0480
+#define REG_BASIC_CFEND_RATE_8814B 0x0481
+#define REG_STBC_CFEND_RATE_8814B 0x0482
+#define REG_DATA_SC_8814B 0x0483
+#define REG_MOREDATA_V1_8814B 0x0484
+#define REG_DATA_SC1_8814B 0x0487
+#define REG_TXRPT_START_OFFSET_8814B 0x04AC
+#define REG_POWER_STAGE1_8814B 0x04B4
+#define REG_POWER_STAGE2_8814B 0x04B8
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8814B 0x04BC
+#define REG_PKT_LIFE_TIME_8814B 0x04C0
+#define REG_STBC_SETTING_8814B 0x04C4
+#define REG_STBC_SETTING2_8814B 0x04C5
+#define REG_QUEUE_CTRL_8814B 0x04C6
+#define REG_SINGLE_AMPDU_CTRL_8814B 0x04C7
+#define REG_PROT_MODE_CTRL_8814B 0x04C8
+#define REG_BAR_MODE_CTRL_8814B 0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8814B 0x04CF
+#define REG_MACID_SLEEP_CTRL_8814B 0x04D0
+#define REG_MACID_SLEEP_INFO_8814B 0x04D4
+#define REG_HW_SEQ0_8814B 0x04D8
+#define REG_HW_SEQ1_8814B 0x04DA
+#define REG_HW_SEQ2_8814B 0x04DC
+#define REG_HW_SEQ3_8814B 0x04DE
+#define REG_PTCL_ERR_STATUS_V1_8814B 0x04E2
+#define REG_NULL_PKT_STATUS_V2_8814B 0x04E4
+#define REG_PRECNT_CTRL_8814B 0x04E5
+#define REG_NULL_PKT_STATUS_EXTEND_V1_8814B 0x04E7
+#define REG_PTCL_DBG_V1_8814B 0x04EC
+#define REG_BT_POLLUTE_PKTCNT_8814B 0x04F0
+#define REG_CPUMGQ_TIMER_CTRL2_8814B 0x04F4
+#define REG_PTCL_DBG_OUT_8814B 0x04F8
+#define REG_DUMMY_PAGE4_V1_8814B 0x04FC
+#define REG_DUMMY_PAGE4_1_8814B 0x04FE
+#define REG_MU_OFFSET_8814B 0x1400
+#define REG_USEREG_SETTING_8814B 0x1420
+#define REG_BF0_TIME_SETTING_8814B 0x1428
+#define REG_BF1_TIME_SETTING_8814B 0x142C
+#define REG_BF_TIMEOUT_EN_8814B 0x1430
+#define REG_MACID_RELEASE_INFO_8814B 0x1434
+#define REG_MACID_RELEASE_SUCCESS_INFO_8814B 0x1438
+#define REG_MACID_RELEASE_CTRL_8814B 0x143C
+#define REG_FAST_EDCA_VOVI_SETTING_8814B 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING_8814B 0x144C
+#define REG_MACID_DROP_INFO_8814B 0x1450
+#define REG_MACID_DROP_CTRL_8814B 0x1454
+#define REG_MGQ_FIFO_WRITE_POINTER_8814B 0x1470
+#define REG_MGQ_FIFO_READ_POINTER_8814B 0x1472
+#define REG_MGQ_FIFO_ENABLE_8814B 0x1472
+#define REG_MGQ_FIFO_RELEASE_INT_MASK_8814B 0x1474
+#define REG_MGQ_FIFO_RELEASE_INT_FLAG_8814B 0x1476
+#define REG_MGQ_FIFO_VALID_MAP_8814B 0x1478
+#define REG_MGQ_FIFO_LIFETIME_8814B 0x147A
+#define REG_PKT_TRANS_8814B 0x1480
+#define REG_SHCUT_LLC_ETH_TYPE0_8814B 0x1484
+#define REG_SHCUT_LLC_ETH_TYPE1_8814B 0x1488
+#define REG_SHCUT_LLC_OUI0_8814B 0x148C
+#define REG_SHCUT_LLC_OUI1_8814B 0x1490
+#define REG_SHCUT_LLC_OUI2_8814B 0x1494
+#define REG_FWCMDQ_CTRL_8814B 0x14A0
+#define REG_FWCMDQ_PAGE_8814B 0x14A4
+#define REG_FWCMDQ_INFO_8814B 0x14A8
+#define REG_FWCMDQ_HOLD_PKTNUM_8814B 0x14AC
+#define REG_MU_TX_CTRL_8814B 0x14C0
+#define REG_MU_STA_GID_VLD_8814B 0x14C4
+#define REG_MU_STA_USER_POS_INFO_8814B 0x14C8
+#define REG_MU_STA_USER_POS_INFO_H_8814B 0x14CC
+#define REG_CHNL_INFO_CTRL_8814B 0x14D0
+#define REG_CHNL_IDLE_TIME_8814B 0x14D4
+#define REG_CHNL_BUSY_TIME_8814B 0x14D8
+#define REG_MU_TRX_DBG_CNT_V1_8814B 0x14DC
+#define REG_SWPS_CTRL_8814B 0x14F4
+#define REG_SWPS_PKT_TH_8814B 0x14F6
+#define REG_SWPS_TIME_TH_8814B 0x14F8
+#define REG_MACID_SWPS_EN_8814B 0x14FC
+#define REG_EDCA_VO_PARAM_8814B 0x0500
+#define REG_EDCA_VI_PARAM_8814B 0x0504
+#define REG_EDCA_BE_PARAM_8814B 0x0508
+#define REG_EDCA_BK_PARAM_8814B 0x050C
+#define REG_BCNTCFG_8814B 0x0510
+#define REG_PIFS_8814B 0x0512
+#define REG_RDG_PIFS_8814B 0x0513
+#define REG_SIFS_8814B 0x0514
+#define REG_FORCE_BCN_IFS_V1_8814B 0x0518
+#define REG_AGGR_BREAK_TIME_8814B 0x051A
+#define REG_SLOT_8814B 0x051B
+#define REG_EDCA_CPUMGQ_PARAM_8814B 0x051C
+#define REG_CPUMGQ_PAUSE_8814B 0x051E
+#define REG_TX_PTCL_CTRL_8814B 0x0520
+#define REG_TXPAUSE_8814B 0x0522
+#define REG_DIS_TXREQ_CLR_8814B 0x0523
+#define REG_RD_CTRL_8814B 0x0524
+#define REG_PKT_LIFETIME_CTRL_8814B 0x0528
+#define REG_TXOP_LIMIT_CTRL_8814B 0x052C
+#define REG_CCA_TXEN_CNT_8814B 0x0534
+#define REG_MAX_INTER_COLLISION_8814B 0x0538
+#define REG_MAX_INTER_COLLISION_CNT_8814B 0x053C
+#define REG_RD_NAV_NXT_8814B 0x0544
+#define REG_NAV_PROT_LEN_8814B 0x0546
+#define REG_FTM_PTT_8814B 0x0548
+#define REG_FTM_TSF_8814B 0x054C
+#define REG_HGQ_TIMEOUT_PERIOD_8814B 0x0575
+#define REG_TXCMD_TIMEOUT_PERIOD_8814B 0x0576
+#define REG_MISC_CTRL_8814B 0x0577
+#define REG_TXOP_MIN_8814B 0x0590
+#define REG_PRE_BKF_TIME_8814B 0x0592
+#define REG_CROSS_TXOP_CTRL_8814B 0x0593
+#define REG_ACMHWCTRL_8814B 0x05C0
+#define REG_ACMRSTCTRL_8814B 0x05C1
+#define REG_ACMAVG_8814B 0x05C2
+#define REG_VO_ADMTIME_8814B 0x05C4
+#define REG_VI_ADMTIME_8814B 0x05C6
+#define REG_BE_ADMTIME_8814B 0x05C8
+#define REG_MAC_HEADER_NAV_OFFSET_8814B 0x05CA
+#define REG_DIS_NDPA_NAV_CHECK_8814B 0x05CB
+#define REG_EDCA_RANDOM_GEN_8814B 0x05CC
+#define REG_TXCMD_SEL_8814B 0x05CF
+#define REG_MU_DBG_INFO_8814B 0x05E8
+#define REG_MU_DBG_INFO_1_8814B 0x05EC
+#define REG_SCH_DBG_SEL_8814B 0x05F0
+#define REG_SCHEDULER_RST_8814B 0x05F1
+#define REG_MU_DBG_ERR_FLAG_8814B 0x05F2
+#define REG_TX_ERR_RECOVERY_RST_8814B 0x05F3
+#define REG_SCH_DBG_VALUE_8814B 0x05F4
+#define REG_SCH_TXCMD_8814B 0x05F8
+#define REG_PAGE5_DUMMY_8814B 0x05FC
+#define REG_PORT_CTRL_SEL_8814B 0x1500
+#define REG_PORT_CTRL_CFG_8814B 0x1501
+#define REG_TBTT_PROHIBIT_CFG_8814B 0x1504
+#define REG_DRVERLYINT_CFG_8814B 0x1507
+#define REG_BCNDMATIM_CFG_8814B 0x1508
+#define REG_CTWND_CFG_8814B 0x1509
+#define REG_BCNIVLCUNT_CFG_8814B 0x150A
+#define REG_EARLY_128US_CFG_8814B 0x150B
+#define REG_TSFTR_SYNC_OFFSET_CFG_8814B 0x150C
+#define REG_TSFTR_SYNC_CTRL_CFG_8814B 0x150F
+#define REG_BCN_SPACE_CFG_8814B 0x1510
+#define REG_EARLY_INT_ADJUST_CFG_8814B 0x1512
+#define REG_SW_TBTT_TSF_INFO_8814B 0x151C
+#define REG_TSFTR_LOW_8814B 0x1520
+#define REG_TSFTR_HIGH_8814B 0x1524
+#define REG_BCN_ERR_CNT_MAC_8814B 0x1528
+#define REG_BCN_ERR_CNT_EDCCA_8814B 0x1529
+#define REG_BCN_ERR_CNT_CCA_8814B 0x152A
+#define REG_BCN_ERR_CNT_INVALID_8814B 0x152B
+#define REG_BCN_ERR_CNT_OTHERS_8814B 0x152C
+#define REG_RX_BCN_TIMER_8814B 0x152D
+#define REG_TBTT_CTN_AREA_V1_8814B 0x1530
+#define REG_BCN_MAX_ERR_V1_8814B 0x1531
+#define REG_RXTSF_OFFSET_CCK_V1_8814B 0x1532
+#define REG_RXTSF_OFFSET_OFDM_V1_8814B 0x1533
+#define REG_SUB_BCN_SPACE_8814B 0x1534
+#define REG_MBID_NUM_V1_8814B 0x1535
+#define REG_MBSSID_CTRL_V1_8814B 0x1536
+#define REG_USTIME_TSF_V1_8814B 0x1538
+#define REG_BW_CFG_8814B 0x1539
+#define REG_ATIMWND_CFG_8814B 0x153A
+#define REG_DTIM_COUNTER_CFG_8814B 0x153B
+#define REG_ATIM_DTIM_CTRL_SEL_8814B 0x153C
+#define REG_ATIMUGT_V1_8814B 0x153D
+#define REG_BCNDROPCTRL_V1_8814B 0x153E
+#define REG_DIS_ATIM_V1_8814B 0x1540
+#define REG_HIQ_NO_LMT_EN_V1_8814B 0x1544
+#define REG_P2PPS_CTRL_V1_8814B 0x1548
+#define REG_P2PPS_SPEC_STATE_V1_8814B 0x154A
+#define REG_P2PPS_STATE_V1_8814B 0x154B
+#define REG_P2PPS1_CTRL_V1_8814B 0x154C
+#define REG_P2PPS1_SPEC_STATE_V1_8814B 0x154E
+#define REG_P2PPS1_STATE_V1_8814B 0x154F
+#define REG_P2PPS2_CTRL_V1_8814B 0x1550
+#define REG_P2PPS2_SPEC_STATE_V1_8814B 0x1552
+#define REG_P2PPS2_STATE_V1_8814B 0x1553
+#define REG_P2PON_DIS_TXTIME_V1_8814B 0x1554
+#define REG_P2POFF_DIS_TXTIME_V1_8814B 0x1555
+#define REG_CHG_POWER_BCN_AREA_8814B 0x1556
+#define REG_NOA_SEL_8814B 0x1557
+#define REG_NOA_PARAM_V1_8814B 0x1558
+#define REG_NOA_PARAM_1_V1_8814B 0x155C
+#define REG_NOA_PARAM_2_V1_8814B 0x1560
+#define REG_NOA_PARAM_3_V1_8814B 0x1564
+#define REG_NOA_ON_ERLY_TIME_V1_8814B 0x1568
+#define REG_NOA_OFF_ERLY_TIME_V1_8814B 0x1569
+#define REG_P2PPS_HW_AUTO_PAUSE_CTRL_8814B 0x156C
+#define REG_P2PPS1_HW_AUTO_PAUSE_CTRL_8814B 0x1570
+#define REG_P2PPS2_HW_AUTO_PAUSE_CTRL_8814B 0x1574
+#define REG_RX_TBTT_SHIFT_8814B 0x1578
+#define REG_FREERUN_CNT_LOW_8814B 0x1580
+#define REG_FREERUN_CNT_HIGH_8814B 0x1584
+#define REG_CPUMGQ_TX_TIMER_V1_8814B 0x1588
+#define REG_PS_TIMER_0_8814B 0x158C
+#define REG_PS_TIMER_1_8814B 0x1590
+#define REG_PS_TIMER_2_8814B 0x1594
+#define REG_PS_TIMER_3_8814B 0x1598
+#define REG_PS_TIMER_4_8814B 0x159C
+#define REG_PS_TIMER_5_8814B 0x15A0
+#define REG_PS_TIMER_01_CTRL_8814B 0x15A4
+#define REG_PS_TIMER_23_CTRL_8814B 0x15A8
+#define REG_PS_TIMER_45_CTRL_8814B 0x15AC
+#define REG_CPUMGQ_FREERUN_TIMER_CTRL_8814B 0x15B0
+#define REG_CPUMGQ_PROHIBIT_8814B 0x15B4
+#define REG_TIMER_COMPARE_8814B 0x15C0
+#define REG_TIMER_COMPARE_VALUE_LOW_8814B 0x15C4
+#define REG_TIMER_COMPARE_VALUE_HIGH_8814B 0x15C8
+#define REG_WMAC_CR_8814B 0x0600
+#define REG_WMAC_FWPKT_CR_8814B 0x0601
+#define REG_FW_STS_FILTER_8814B 0x0602
+#define REG_TCR_8814B 0x0604
+#define REG_RCR_8814B 0x0608
+#define REG_RX_PKT_LIMIT_8814B 0x060C
+#define REG_RX_DLK_TIME_8814B 0x060D
+#define REG_RX_DRVINFO_SZ_8814B 0x060F
+#define REG_MACID_8814B 0x0610
+#define REG_MACID_H_8814B 0x0614
+#define REG_BSSID_8814B 0x0618
+#define REG_BSSID_H_8814B 0x061C
+#define REG_MAR_8814B 0x0620
+#define REG_MAR_H_8814B 0x0624
+#define REG_WMAC_DEBUG_SEL_8814B 0x062C
+#define REG_WMAC_TCR_TSFT_OFS_8814B 0x0630
+#define REG_UDF_THSD_8814B 0x0632
+#define REG_ZLD_NUM_8814B 0x0633
+#define REG_STMP_THSD_8814B 0x0634
+#define REG_WMAC_TXTIMEOUT_8814B 0x0635
+#define REG_MCU_TEST_2_V1_8814B 0x0636
+#define REG_USTIME_EDCA_8814B 0x0638
+#define REG_ACKTO_CCK_8814B 0x0639
+#define REG_MAC_SPEC_SIFS_8814B 0x063A
+#define REG_RESP_SIFS_CCK_8814B 0x063C
+#define REG_RESP_SIFS_OFDM_8814B 0x063E
+#define REG_ACKTO_8814B 0x0640
+#define REG_CTS2TO_8814B 0x0641
+#define REG_EIFS_8814B 0x0642
+#define REG_RPFM_MAP0_8814B 0x0644
+#define REG_RPFM_MAP1_V1_8814B 0x0646
+#define REG_RPFM_CAM_CMD_8814B 0x0648
+#define REG_RPFM_CAM_RWD_8814B 0x064C
+#define REG_NAV_CTRL_8814B 0x0650
+#define REG_BACAMCMD_8814B 0x0654
+#define REG_BACAMCONTENT_8814B 0x0658
+#define REG_BACAMCONTENT_H_8814B 0x065C
+#define REG_LBDLY_8814B 0x0660
+#define REG_WMAC_BACAM_RPMEN_8814B 0x0661
+#define REG_TX_RX_8814B 0x0662
+#define REG_WMAC_BITMAP_CTL_8814B 0x0663
+#define REG_RXERR_RPT_8814B 0x0664
+#define REG_WMAC_TRXPTCL_CTL_8814B 0x0668
+#define REG_WMAC_TRXPTCL_CTL_H_8814B 0x066C
+#define REG_CAMCMD_8814B 0x0670
+#define REG_CAMWRITE_8814B 0x0674
+#define REG_CAMREAD_8814B 0x0678
+#define REG_CAMDBG_8814B 0x067C
+#define REG_SECCFG_8814B 0x0680
+#define REG_RXFILTER_CATEGORY_1_8814B 0x0682
+#define REG_RXFILTER_ACTION_1_8814B 0x0683
+#define REG_RXFILTER_CATEGORY_2_8814B 0x0684
+#define REG_RXFILTER_ACTION_2_8814B 0x0685
+#define REG_RXFILTER_CATEGORY_3_8814B 0x0686
+#define REG_RXFILTER_ACTION_3_8814B 0x0687
+#define REG_RXFLTMAP3_8814B 0x0688
+#define REG_RXFLTMAP4_8814B 0x068A
+#define REG_RXFLTMAP5_8814B 0x068C
+#define REG_RXFLTMAP6_8814B 0x068E
+#define REG_WOW_CTRL_8814B 0x0690
+#define REG_NAN_RX_TSF_FILTER_8814B 0x0691
+#define REG_PS_RX_INFO_8814B 0x0692
+#define REG_WMMPS_UAPSD_TID_8814B 0x0693
+#define REG_LPNAV_CTRL_8814B 0x0694
+#define REG_WKFMCAM_CMD_8814B 0x0698
+#define REG_WKFMCAM_RWD_8814B 0x069C
+#define REG_RXFLTMAP0_8814B 0x06A0
+#define REG_RXFLTMAP1_8814B 0x06A2
+#define REG_RXFLTMAP2_8814B 0x06A4
+#define REG_BCN_PSR_RPT_8814B 0x06A8
+#define REG_FLC_RPC_8814B 0x06AC
+#define REG_FLC_RPCT_8814B 0x06AD
+#define REG_FLC_PTS_8814B 0x06AE
+#define REG_FLC_TRPC_8814B 0x06AF
+#define REG_RXPKTMON_CTRL_8814B 0x06B0
+#define REG_STATE_MON_8814B 0x06B4
+#define REG_ERROR_MON_8814B 0x06B8
+#define REG_SEARCH_MACID_8814B 0x06BC
+#define REG_BT_COEX_TABLE_8814B 0x06C0
+#define REG_BT_COEX_TABLE2_8814B 0x06C4
+#define REG_BT_COEX_BREAK_TABLE_8814B 0x06C8
+#define REG_BT_COEX_TABLE_H_8814B 0x06CC
+#define REG_RXCMD_0_8814B 0x06D0
+#define REG_RXCMD_1_8814B 0x06D4
+#define REG_WMAC_RESP_TXINFO_8814B 0x06D8
+#define REG_BBPSF_CTRL_8814B 0x06DC
+#define REG_P2P_RX_BCN_NOA_8814B 0x06E0
+#define REG_ASSOCIATED_BFMER0_INFO_8814B 0x06E4
+#define REG_ASSOCIATED_BFMER0_INFO_H_8814B 0x06E8
+#define REG_ASSOCIATED_BFMER1_INFO_8814B 0x06EC
+#define REG_ASSOCIATED_BFMER1_INFO_H_8814B 0x06F0
+#define REG_TX_CSI_RPT_PARAM_BW20_8814B 0x06F4
+#define REG_TX_CSI_RPT_PARAM_BW40_8814B 0x06F8
+#define REG_BCN_PSR_RPT2_8814B 0x1600
+#define REG_BCN_PSR_RPT3_8814B 0x1604
+#define REG_BCN_PSR_RPT4_8814B 0x1608
+#define REG_A1_ADDR_MASK_8814B 0x160C
+#define REG_RXPSF_CTRL_8814B 0x1610
+#define REG_RXPSF_TYPE_CTRL_8814B 0x1614
+#define REG_CAM_ACCESS_CTRL_8814B 0x1618
+#define REG_CUT_AMSDU_CTRL_8814B 0x161C
+#define REG_MACID2_8814B 0x1620
+#define REG_MACID2_H_8814B 0x1624
+#define REG_BSSID2_8814B 0x1628
+#define REG_BSSID2_H_8814B 0x162C
+#define REG_MACID3_8814B 0x1630
+#define REG_MACID3_H_8814B 0x1634
+#define REG_BSSID3_8814B 0x1638
+#define REG_BSSID3_H_8814B 0x163C
+#define REG_MACID4_8814B 0x1640
+#define REG_MACID4_H_8814B 0x1644
+#define REG_BSSID4_8814B 0x1648
+#define REG_BSSID4_H_8814B 0x164C
+#define REG_NOA_REPORT_8814B 0x1650
+#define REG_NOA_REPORT_1_8814B 0x1654
+#define REG_NOA_REPORT_2_8814B 0x1658
+#define REG_NOA_REPORT_3_8814B 0x165C
+#define REG_PWRBIT_SETTING_8814B 0x1660
+#define REG_GENERAL_OPTION_8814B 0x1664
+#define REG_FWPHYFF_RCR_8814B 0x1668
+#define REG_ADDRCAM_WRITE_CONTENT_8814B 0x166C
+#define REG_ADDRCAM_READ_CONTENT_8814B 0x1670
+#define REG_ADDRCAM_CFG_8814B 0x1674
+#define REG_CSI_RRSR_8814B 0x1678
+#define REG_MU_BF_OPTION_8814B 0x167C
+#define REG_WMAC_PAUSE_BB_CLR_TH_8814B 0x167D
+#define REG_WMAC_MULBK_BUF_8814B 0x167E
+#define REG_WMAC_MU_OPTION_8814B 0x167F
+#define REG_WMAC_MU_BF_CTL_8814B 0x1680
+#define REG_WMAC_MU_BFRPT_PARA_8814B 0x1682
+#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8814B 0x1684
+#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8814B 0x1686
+#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8814B 0x1688
+#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8814B 0x168A
+#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8814B 0x168C
+#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8814B 0x168E
+#define REG_WMAC_BB_STOP_RX_COUNTER_8814B 0x1690
+#define REG_WMAC_PLCP_MONITOR_8814B 0x1694
+#define REG_WMAC_DEBUG_PORT_8814B 0x1698
+#define REG_TRANSMIT_ADDRSS_0_8814B 0x16A0
+#define REG_TRANSMIT_ADDRSS_0_H_8814B 0x16A4
+#define REG_TRANSMIT_ADDRSS_1_8814B 0x16A8
+#define REG_TRANSMIT_ADDRSS_1_H_8814B 0x16AC
+#define REG_TRANSMIT_ADDRSS_2_8814B 0x16B0
+#define REG_TRANSMIT_ADDRSS_2_H_8814B 0x16B4
+#define REG_TRANSMIT_ADDRSS_3_8814B 0x16B8
+#define REG_TRANSMIT_ADDRSS_3_H_8814B 0x16BC
+#define REG_TRANSMIT_ADDRSS_4_8814B 0x16C0
+#define REG_TRANSMIT_ADDRSS_4_H_8814B 0x16C4
+#define REG_MACID1_8814B 0x0700
+#define REG_MACID1_1_8814B 0x0704
+#define REG_BSSID1_8814B 0x0708
+#define REG_BSSID1_1_8814B 0x070C
+#define REG_BCN_PSR_RPT1_8814B 0x0710
+#define REG_ASSOCIATED_BFMEE_SEL_8814B 0x0714
+#define REG_SND_PTCL_CTRL_8814B 0x0718
+#define REG_RX_CSI_RPT_INFO_8814B 0x071C
+#define REG_NS_ARP_CTRL_8814B 0x0720
+#define REG_NS_ARP_INFO_8814B 0x0724
+#define REG_BEAMFORMING_INFO_NSARP_V1_8814B 0x0728
+#define REG_BEAMFORMING_INFO_NSARP_8814B 0x072C
+#define REG_IPV6_8814B 0x0730
+#define REG_IPV6_1_8814B 0x0734
+#define REG_IPV6_2_8814B 0x0738
+#define REG_IPV6_3_8814B 0x073C
+#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8814B 0x0750
+#define REG_WMAC_SWAES_CFG_8814B 0x0760
+#define REG_BT_COEX_V2_8814B 0x0762
+#define REG_BT_COEX_8814B 0x0764
+#define REG_WLAN_ACT_MASK_CTRL_8814B 0x0768
+#define REG_WLAN_ACT_MASK_CTRL_1_8814B 0x076C
+#define REG_BT_COEX_ENHANCED_INTR_CTRL_8814B 0x076E
+#define REG_BT_ACT_STATISTICS_8814B 0x0770
+#define REG_BT_ACT_STATISTICS_1_8814B 0x0774
+#define REG_BT_STATISTICS_CONTROL_REGISTER_8814B 0x0778
+#define REG_BT_STATUS_REPORT_REGISTER_8814B 0x077C
+#define REG_BT_INTERRUPT_CONTROL_REGISTER_8814B 0x0780
+#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8814B 0x0784
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8814B 0x0785
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8814B 0x0788
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8814B 0x078C
+#define REG_BT_INTERRUPT_STATUS_REGISTER_8814B 0x078F
+#define REG_BT_TDMA_TIME_REGISTER_8814B 0x0790
+#define REG_BT_ACT_REGISTER_8814B 0x0794
+#define REG_OBFF_CTRL_BASIC_8814B 0x0798
+#define REG_OBFF_CTRL2_TIMER_8814B 0x079C
+#define REG_LTR_CTRL_BASIC_8814B 0x07A0
+#define REG_LTR_CTRL2_TIMER_THRESHOLD_8814B 0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8814B 0x07A8
+#define REG_LTR_ACTIVE_LATENCY_V1_8814B 0x07AC
+#define REG_SMART_ANT_CONDITION_8814B 0x07B0
+#define REG_SMART_ANT_CTRL_8814B 0x07B4
+#define REG_CONTROL_FRAME_REPORT_8814B 0x07B8
+#define REG_CONTROL_FRAME_CNT_CTRL_8814B 0x07BC
+#define REG_IQ_DUMP_8814B 0x07C0
+#define REG_IQ_DUMP_1_8814B 0x07C4
+#define REG_IQ_DUMP_2_8814B 0x07C8
+#define REG_WMAC_FTM_CTL_8814B 0x07CC
+#define REG_WMAC_IQ_MDPK_FUNC_8814B 0x07CE
+#define REG_WMAC_OPTION_FUNCTION_8814B 0x07D0
+#define REG_WMAC_OPTION_FUNCTION_1_8814B 0x07D4
+#define REG_WMAC_OPTION_FUNCTION_2_8814B 0x07D8
+#define REG_RX_FILTER_FUNCTION_8814B 0x07DA
+#define REG_NDP_SIG_8814B 0x07E0
+#define REG_TXCMD_INFO_FOR_RSP_PKT_8814B 0x07E4
+#define REG_TXCMD_INFO_FOR_RSP_PKT_1_8814B 0x07E8
+#define REG_WSEC_OPTION_8814B 0x07EC
+#define REG_RTS_ADDRESS_0_8814B 0x07F0
+#define REG_RTS_ADDRESS_0_1_8814B 0x07F4
+#define REG_RTS_ADDRESS_1_8814B 0x07F8
+#define REG_RTS_ADDRESS_1_1_8814B 0x07FC
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8814B 0x1700
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8814B 0x1704
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8814B 0x1708
+#define REG_PCIE_CFG_FORCE_LINK_L_8814B 0x0709
+#define REG_PCIE_CFG_FORCE_LINK_H_8814B 0x070A
+#define REG_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B 0x070C
+#define REG_PCIE_CFG_CX_NFTS_8814B 0x070D
+#define REG_PCIE_CFG_DEFAULT_ENTR_LATENCY_8814B 0x070F
+#define REG_PCIE_CFG_L1_MISC_SEL_8814B 0x0711
+#define REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF_8814B 0x0718
+#define REG_PCIE_CFG_FORCE_CLKREQ_N_PAD_8814B 0x0719
+#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_ACK_NAK_LATENCY_8814B 0x071A
+#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_FLOW_CONTROL_WATCHDOG_8814B 0x071B
+#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B 0x071C
+#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B 0x071D
+#define REG_PCIE_CFG_L1_UNIT_SEL_8814B 0x0724
+#define REG_PCIE_CFG_MIN_CLKREQ_SEL_8814B 0x0725
+#define REG_SDIO_TX_CTRL_8814B 0x10250000
+#define REG_SDIO_HIMR_8814B 0x10250014
+#define REG_SDIO_HISR_8814B 0x10250018
+#define REG_SDIO_RX_REQ_LEN_8814B 0x1025001C
+#define REG_SDIO_FREE_TXPG_SEQ_V1_8814B 0x1025001F
+#define REG_SDIO_FREE_TXPG_8814B 0x10250020
+#define REG_SDIO_FREE_TXPG2_8814B 0x10250024
+#define REG_SDIO_OQT_FREE_TXPG_V1_8814B 0x10250028
+#define REG_SDIO_HTSFR_INFO_8814B 0x10250030
+#define REG_SDIO_HCPWM1_V2_8814B 0x10250038
+#define REG_SDIO_HCPWM2_V2_8814B 0x1025003A
+#define REG_SDIO_INDIRECT_REG_CFG_8814B 0x10250040
+#define REG_SDIO_INDIRECT_REG_DATA_8814B 0x10250044
+#define REG_SDIO_H2C_8814B 0x10250060
+#define REG_SDIO_C2H_8814B 0x10250064
+#define REG_SDIO_HRPWM1_8814B 0x10250080
+#define REG_SDIO_HRPWM2_8814B 0x10250082
+#define REG_SDIO_HPS_CLKR_8814B 0x10250084
+#define REG_SDIO_BUS_CTRL_8814B 0x10250085
+#define REG_SDIO_HSUS_CTRL_8814B 0x10250086
+#define REG_SDIO_RESPONSE_TIMER_8814B 0x10250088
+#define REG_SDIO_CMD_CRC_8814B 0x1025008A
+#define REG_SDIO_HSISR_8814B 0x10250090
+#define REG_SDIO_ERR_RPT_8814B 0x102500C0
+#define REG_SDIO_CMD_ERRCNT_8814B 0x102500C2
+#define REG_SDIO_DATA_ERRCNT_8814B 0x102500C3
+#define REG_SDIO_CMD_ERR_CONTENT_8814B 0x102500C4
+#define REG_SDIO_CRC_ERR_IDX_8814B 0x102500C9
+#define REG_SDIO_DATA_CRC_8814B 0x102500CA
+#define REG_SDIO_DATA_REPLY_TIME_8814B 0x102500CB
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8821c.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8821c.h
new file mode 100644
index 000000000000..dd93baf6dcdf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8821c.h
@@ -0,0 +1,803 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_HALMAC_REG_8821C_H
+#define __INC_HALMAC_REG_8821C_H
+
+#define REG_SYS_ISO_CTRL_8821C 0x0000
+#define REG_SYS_FUNC_EN_8821C 0x0002
+#define REG_SYS_PW_CTRL_8821C 0x0004
+#define REG_SYS_CLK_CTRL_8821C 0x0008
+#define REG_SYS_EEPROM_CTRL_8821C 0x000A
+#define REG_EE_VPD_8821C 0x000C
+#define REG_SYS_SWR_CTRL1_8821C 0x0010
+#define REG_SYS_SWR_CTRL2_8821C 0x0014
+#define REG_SYS_SWR_CTRL3_8821C 0x0018
+#define REG_RSV_CTRL_8821C 0x001C
+#define REG_RF_CTRL_8821C 0x001F
+#define REG_AFE_LDO_CTRL_8821C 0x0020
+#define REG_AFE_CTRL1_8821C 0x0024
+#define REG_AFE_CTRL2_8821C 0x0028
+#define REG_AFE_CTRL3_8821C 0x002C
+#define REG_EFUSE_CTRL_8821C 0x0030
+#define REG_LDO_EFUSE_CTRL_8821C 0x0034
+#define REG_PWR_OPTION_CTRL_8821C 0x0038
+#define REG_CAL_TIMER_8821C 0x003C
+#define REG_ACLK_MON_8821C 0x003E
+#define REG_GPIO_MUXCFG_8821C 0x0040
+#define REG_GPIO_PIN_CTRL_8821C 0x0044
+#define REG_GPIO_INTM_8821C 0x0048
+#define REG_LED_CFG_8821C 0x004C
+#define REG_FSIMR_8821C 0x0050
+#define REG_FSISR_8821C 0x0054
+#define REG_HSIMR_8821C 0x0058
+#define REG_HSISR_8821C 0x005C
+#define REG_GPIO_EXT_CTRL_8821C 0x0060
+#define REG_PAD_CTRL1_8821C 0x0064
+#define REG_WL_BT_PWR_CTRL_8821C 0x0068
+#define REG_SDM_DEBUG_8821C 0x006C
+#define REG_SYS_SDIO_CTRL_8821C 0x0070
+#define REG_HCI_OPT_CTRL_8821C 0x0074
+#define REG_AFE_CTRL4_8821C 0x0078
+#define REG_LDO_SWR_CTRL_8821C 0x007C
+#define REG_MCUFW_CTRL_8821C 0x0080
+#define REG_MCU_TST_CFG_8821C 0x0084
+#define REG_HMEBOX_E0_E1_8821C 0x0088
+#define REG_HMEBOX_E2_E3_8821C 0x008C
+#define REG_WLLPS_CTRL_8821C 0x0090
+#define REG_AFE_CTRL5_8821C 0x0094
+#define REG_GPIO_DEBOUNCE_CTRL_8821C 0x0098
+#define REG_RPWM2_8821C 0x009C
+#define REG_SYSON_FSM_MON_8821C 0x00A0
+#define REG_AFE_CTRL6_8821C 0x00A4
+#define REG_PMC_DBG_CTRL1_8821C 0x00A8
+#define REG_AFE_CTRL7_8821C 0x00AC
+#define REG_HIMR0_8821C 0x00B0
+#define REG_HISR0_8821C 0x00B4
+#define REG_HIMR1_8821C 0x00B8
+#define REG_HISR1_8821C 0x00BC
+#define REG_DBG_PORT_SEL_8821C 0x00C0
+#define REG_PAD_CTRL2_8821C 0x00C4
+#define REG_PMC_DBG_CTRL2_8821C 0x00CC
+#define REG_BIST_CTRL_8821C 0x00D0
+#define REG_BIST_RPT_8821C 0x00D4
+#define REG_MEM_CTRL_8821C 0x00D8
+#define REG_AFE_CTRL8_8821C 0x00DC
+#define REG_USB_SIE_INTF_8821C 0x00E0
+#define REG_PCIE_MIO_INTF_8821C 0x00E4
+#define REG_PCIE_MIO_INTD_8821C 0x00E8
+#define REG_WLRF1_8821C 0x00EC
+#define REG_SYS_CFG1_8821C 0x00F0
+#define REG_SYS_STATUS1_8821C 0x00F4
+#define REG_SYS_STATUS2_8821C 0x00F8
+#define REG_SYS_CFG2_8821C 0x00FC
+#define REG_SYS_CFG3_8821C 0x1000
+#define REG_SYS_CFG5_8821C 0x1070
+#define REG_CPU_DMEM_CON_8821C 0x1080
+#define REG_BOOT_REASON_8821C 0x1088
+#define REG_NFCPAD_CTRL_8821C 0x10A8
+#define REG_HIMR2_8821C 0x10B0
+#define REG_HISR2_8821C 0x10B4
+#define REG_HIMR3_8821C 0x10B8
+#define REG_HISR3_8821C 0x10BC
+#define REG_SW_MDIO_8821C 0x10C0
+#define REG_H2C_PKT_READADDR_8821C 0x10D0
+#define REG_H2C_PKT_WRITEADDR_8821C 0x10D4
+#define REG_MEM_PWR_CRTL_8821C 0x10D8
+#define REG_FW_DBG6_8821C 0x10F8
+#define REG_FW_DBG7_8821C 0x10FC
+#define REG_CR_8821C 0x0100
+#define REG_PG_SIZE_8821C 0x0104
+#define REG_PKT_BUFF_ACCESS_CTRL_8821C 0x0106
+#define REG_TSF_CLK_STATE_8821C 0x0108
+#define REG_TXDMA_PQ_MAP_8821C 0x010C
+#define REG_TRXFF_BNDY_8821C 0x0114
+#define REG_PTA_I2C_MBOX_8821C 0x0118
+#define REG_RXFF_BNDY_8821C 0x011C
+#define REG_FE1IMR_8821C 0x0120
+#define REG_FE1ISR_8821C 0x0124
+#define REG_CPWM_8821C 0x012C
+#define REG_FWIMR_8821C 0x0130
+#define REG_FWISR_8821C 0x0134
+#define REG_FTIMR_8821C 0x0138
+#define REG_FTISR_8821C 0x013C
+#define REG_PKTBUF_DBG_CTRL_8821C 0x0140
+#define REG_PKTBUF_DBG_DATA_L_8821C 0x0144
+#define REG_PKTBUF_DBG_DATA_H_8821C 0x0148
+#define REG_CPWM2_8821C 0x014C
+#define REG_TC0_CTRL_8821C 0x0150
+#define REG_TC1_CTRL_8821C 0x0154
+#define REG_TC2_CTRL_8821C 0x0158
+#define REG_TC3_CTRL_8821C 0x015C
+#define REG_TC4_CTRL_8821C 0x0160
+#define REG_TCUNIT_BASE_8821C 0x0164
+#define REG_TC5_CTRL_8821C 0x0168
+#define REG_TC6_CTRL_8821C 0x016C
+#define REG_MBIST_DRF_FAIL_8821C 0x0170
+#define REG_MBIST_START_PAUSE_8821C 0x0174
+#define REG_MBIST_DONE_8821C 0x0178
+#define REG_MBIST_READ_BIST_RPT_8821C 0x017C
+#define REG_AES_DECRPT_DATA_8821C 0x0180
+#define REG_AES_DECRPT_CFG_8821C 0x0184
+#define REG_TMETER_8821C 0x0190
+#define REG_OSC_32K_CTRL_8821C 0x0194
+#define REG_32K_CAL_REG1_8821C 0x0198
+#define REG_C2HEVT_8821C 0x01A0
+#define REG_C2HEVT_1_8821C 0x01A4
+#define REG_C2HEVT_2_8821C 0x01A8
+#define REG_C2HEVT_3_8821C 0x01AC
+#define REG_SW_DEFINED_PAGE1_8821C 0x01B8
+#define REG_SW_DEFINED_PAGE2_8821C 0x01BC
+#define REG_MCUTST_I_8821C 0x01C0
+#define REG_MCUTST_II_8821C 0x01C4
+#define REG_FMETHR_8821C 0x01C8
+#define REG_HMETFR_8821C 0x01CC
+#define REG_HMEBOX0_8821C 0x01D0
+#define REG_HMEBOX1_8821C 0x01D4
+#define REG_HMEBOX2_8821C 0x01D8
+#define REG_HMEBOX3_8821C 0x01DC
+#define REG_BB_ACCESS_CTRL_8821C 0x01E8
+#define REG_BB_ACCESS_DATA_8821C 0x01EC
+#define REG_HMEBOX_E0_8821C 0x01F0
+#define REG_HMEBOX_E1_8821C 0x01F4
+#define REG_HMEBOX_E2_8821C 0x01F8
+#define REG_HMEBOX_E3_8821C 0x01FC
+#define REG_CR_EXT_8821C 0x1100
+#define REG_FWFF_8821C 0x1114
+#define REG_RXFF_PTR_V1_8821C 0x1118
+#define REG_RXFF_WTR_V1_8821C 0x111C
+#define REG_FE2IMR_8821C 0x1120
+#define REG_FE2ISR_8821C 0x1124
+#define REG_FE3IMR_8821C 0x1128
+#define REG_FE3ISR_8821C 0x112C
+#define REG_FE4IMR_8821C 0x1130
+#define REG_FE4ISR_8821C 0x1134
+#define REG_FT1IMR_8821C 0x1138
+#define REG_FT1ISR_8821C 0x113C
+#define REG_SPWR0_8821C 0x1140
+#define REG_SPWR1_8821C 0x1144
+#define REG_SPWR2_8821C 0x1148
+#define REG_SPWR3_8821C 0x114C
+#define REG_POWSEQ_8821C 0x1150
+#define REG_TC7_CTRL_V1_8821C 0x1158
+#define REG_TC8_CTRL_V1_8821C 0x115C
+#define REG_RX_BCN_TBTT_ITVL0_8821C 0x1160
+#define REG_RX_BCN_TBTT_ITVL1_8821C 0x1164
+#define REG_IO_WRAP_ERR_FLAG_8821C 0x1170
+#define REG_SPEED_SENSOR_8821C 0x1180
+#define REG_SPEED_SENSOR1_8821C 0x1184
+#define REG_SPEED_SENSOR2_8821C 0x1188
+#define REG_SPEED_SENSOR3_8821C 0x118C
+#define REG_SPEED_SENSOR4_8821C 0x1190
+#define REG_SPEED_SENSOR5_8821C 0x1194
+#define REG_COUNTER_CTRL_8821C 0x11C4
+#define REG_COUNTER_THRESHOLD_8821C 0x11C8
+#define REG_COUNTER_SET_8821C 0x11CC
+#define REG_COUNTER_OVERFLOW_8821C 0x11D0
+#define REG_TXDMA_LEN_THRESHOLD_8821C 0x11D4
+#define REG_RXDMA_LEN_THRESHOLD_8821C 0x11D8
+#define REG_PCIE_EXEC_TIME_THRESHOLD_8821C 0x11DC
+#define REG_FT2IMR_8821C 0x11E0
+#define REG_FT2ISR_8821C 0x11E4
+#define REG_MSG2_8821C 0x11F0
+#define REG_MSG3_8821C 0x11F4
+#define REG_MSG4_8821C 0x11F8
+#define REG_MSG5_8821C 0x11FC
+#define REG_FIFOPAGE_CTRL_1_8821C 0x0200
+#define REG_FIFOPAGE_CTRL_2_8821C 0x0204
+#define REG_AUTO_LLT_V1_8821C 0x0208
+#define REG_TXDMA_OFFSET_CHK_8821C 0x020C
+#define REG_TXDMA_STATUS_8821C 0x0210
+#define REG_TX_DMA_DBG_8821C 0x0214
+#define REG_TQPNT1_8821C 0x0218
+#define REG_TQPNT2_8821C 0x021C
+#define REG_TQPNT3_8821C 0x0220
+#define REG_TQPNT4_8821C 0x0224
+#define REG_RQPN_CTRL_1_8821C 0x0228
+#define REG_RQPN_CTRL_2_8821C 0x022C
+#define REG_FIFOPAGE_INFO_1_8821C 0x0230
+#define REG_FIFOPAGE_INFO_2_8821C 0x0234
+#define REG_FIFOPAGE_INFO_3_8821C 0x0238
+#define REG_FIFOPAGE_INFO_4_8821C 0x023C
+#define REG_FIFOPAGE_INFO_5_8821C 0x0240
+#define REG_H2C_HEAD_8821C 0x0244
+#define REG_H2C_TAIL_8821C 0x0248
+#define REG_H2C_READ_ADDR_8821C 0x024C
+#define REG_H2C_WR_ADDR_8821C 0x0250
+#define REG_H2C_INFO_8821C 0x0254
+#define REG_RXDMA_AGG_PG_TH_8821C 0x0280
+#define REG_RXPKT_NUM_8821C 0x0284
+#define REG_RXDMA_STATUS_8821C 0x0288
+#define REG_RXDMA_DPR_8821C 0x028C
+#define REG_RXDMA_MODE_8821C 0x0290
+#define REG_C2H_PKT_8821C 0x0294
+#define REG_FWFF_C2H_8821C 0x0298
+#define REG_FWFF_CTRL_8821C 0x029C
+#define REG_FWFF_PKT_INFO_8821C 0x02A0
+#define REG_DDMA_CH0SA_8821C 0x1200
+#define REG_DDMA_CH0DA_8821C 0x1204
+#define REG_DDMA_CH0CTRL_8821C 0x1208
+#define REG_DDMA_CH1SA_8821C 0x1210
+#define REG_DDMA_CH1DA_8821C 0x1214
+#define REG_DDMA_CH1CTRL_8821C 0x1218
+#define REG_DDMA_CH2SA_8821C 0x1220
+#define REG_DDMA_CH2DA_8821C 0x1224
+#define REG_DDMA_CH2CTRL_8821C 0x1228
+#define REG_DDMA_CH3SA_8821C 0x1230
+#define REG_DDMA_CH3DA_8821C 0x1234
+#define REG_DDMA_CH3CTRL_8821C 0x1238
+#define REG_DDMA_CH4SA_8821C 0x1240
+#define REG_DDMA_CH4DA_8821C 0x1244
+#define REG_DDMA_CH4CTRL_8821C 0x1248
+#define REG_DDMA_CH5SA_8821C 0x1250
+#define REG_DDMA_CH5DA_8821C 0x1254
+#define REG_DDMA_CH5CTRL_8821C 0x1258
+#define REG_DDMA_INT_MSK_8821C 0x12E0
+#define REG_DDMA_CHSTATUS_8821C 0x12E8
+#define REG_DDMA_CHKSUM_8821C 0x12F0
+#define REG_DDMA_MONITOR_8821C 0x12FC
+#define REG_PCIE_CTRL_8821C 0x0300
+#define REG_INT_MIG_8821C 0x0304
+#define REG_BCNQ_TXBD_DESA_8821C 0x0308
+#define REG_MGQ_TXBD_DESA_8821C 0x0310
+#define REG_VOQ_TXBD_DESA_8821C 0x0318
+#define REG_VIQ_TXBD_DESA_8821C 0x0320
+#define REG_BEQ_TXBD_DESA_8821C 0x0328
+#define REG_BKQ_TXBD_DESA_8821C 0x0330
+#define REG_RXQ_RXBD_DESA_8821C 0x0338
+#define REG_HI0Q_TXBD_DESA_8821C 0x0340
+#define REG_HI1Q_TXBD_DESA_8821C 0x0348
+#define REG_HI2Q_TXBD_DESA_8821C 0x0350
+#define REG_HI3Q_TXBD_DESA_8821C 0x0358
+#define REG_HI4Q_TXBD_DESA_8821C 0x0360
+#define REG_HI5Q_TXBD_DESA_8821C 0x0368
+#define REG_HI6Q_TXBD_DESA_8821C 0x0370
+#define REG_HI7Q_TXBD_DESA_8821C 0x0378
+#define REG_MGQ_TXBD_NUM_8821C 0x0380
+#define REG_RX_RXBD_NUM_8821C 0x0382
+#define REG_VOQ_TXBD_NUM_8821C 0x0384
+#define REG_VIQ_TXBD_NUM_8821C 0x0386
+#define REG_BEQ_TXBD_NUM_8821C 0x0388
+#define REG_BKQ_TXBD_NUM_8821C 0x038A
+#define REG_HI0Q_TXBD_NUM_8821C 0x038C
+#define REG_HI1Q_TXBD_NUM_8821C 0x038E
+#define REG_HI2Q_TXBD_NUM_8821C 0x0390
+#define REG_HI3Q_TXBD_NUM_8821C 0x0392
+#define REG_HI4Q_TXBD_NUM_8821C 0x0394
+#define REG_HI5Q_TXBD_NUM_8821C 0x0396
+#define REG_HI6Q_TXBD_NUM_8821C 0x0398
+#define REG_HI7Q_TXBD_NUM_8821C 0x039A
+#define REG_TSFTIMER_HCI_8821C 0x039C
+#define REG_BD_RWPTR_CLR_8821C 0x039C
+#define REG_VOQ_TXBD_IDX_8821C 0x03A0
+#define REG_VIQ_TXBD_IDX_8821C 0x03A4
+#define REG_BEQ_TXBD_IDX_8821C 0x03A8
+#define REG_BKQ_TXBD_IDX_8821C 0x03AC
+#define REG_MGQ_TXBD_IDX_8821C 0x03B0
+#define REG_RXQ_RXBD_IDX_8821C 0x03B4
+#define REG_HI0Q_TXBD_IDX_8821C 0x03B8
+#define REG_HI1Q_TXBD_IDX_8821C 0x03BC
+#define REG_HI2Q_TXBD_IDX_8821C 0x03C0
+#define REG_HI3Q_TXBD_IDX_8821C 0x03C4
+#define REG_HI4Q_TXBD_IDX_8821C 0x03C8
+#define REG_HI5Q_TXBD_IDX_8821C 0x03CC
+#define REG_HI6Q_TXBD_IDX_8821C 0x03D0
+#define REG_HI7Q_TXBD_IDX_8821C 0x03D4
+#define REG_DBG_SEL_V1_8821C 0x03D8
+#define REG_PCIE_HRPWM1_V1_8821C 0x03D9
+#define REG_PCIE_HCPWM1_V1_8821C 0x03DA
+#define REG_PCIE_CTRL2_8821C 0x03DB
+#define REG_PCIE_HRPWM2_V1_8821C 0x03DC
+#define REG_PCIE_HCPWM2_V1_8821C 0x03DE
+#define REG_PCIE_H2C_MSG_V1_8821C 0x03E0
+#define REG_PCIE_C2H_MSG_V1_8821C 0x03E4
+#define REG_DBI_WDATA_V1_8821C 0x03E8
+#define REG_DBI_RDATA_V1_8821C 0x03EC
+#define REG_DBI_FLAG_V1_8821C 0x03F0
+#define REG_MDIO_V1_8821C 0x03F4
+#define REG_PCIE_MIX_CFG_8821C 0x03F8
+#define REG_HCI_MIX_CFG_8821C 0x03FC
+#define REG_STC_INT_CS_8821C 0x1300
+#define REG_ST_INT_CFG_8821C 0x1304
+#define REG_CMU_DLY_CTRL_8821C 0x1310
+#define REG_CMU_DLY_CFG_8821C 0x1314
+#define REG_H2CQ_TXBD_DESA_8821C 0x1320
+#define REG_H2CQ_TXBD_NUM_8821C 0x1328
+#define REG_H2CQ_TXBD_IDX_8821C 0x132C
+#define REG_H2CQ_CSR_8821C 0x1330
+#define REG_Q0_INFO_8821C 0x0400
+#define REG_Q1_INFO_8821C 0x0404
+#define REG_Q2_INFO_8821C 0x0408
+#define REG_Q3_INFO_8821C 0x040C
+#define REG_MGQ_INFO_8821C 0x0410
+#define REG_HIQ_INFO_8821C 0x0414
+#define REG_BCNQ_INFO_8821C 0x0418
+#define REG_TXPKT_EMPTY_8821C 0x041A
+#define REG_CPU_MGQ_INFO_8821C 0x041C
+#define REG_FWHW_TXQ_CTRL_8821C 0x0420
+#define REG_DATAFB_SEL_8821C 0x0423
+#define REG_BCNQ_BDNY_V1_8821C 0x0424
+#define REG_LIFETIME_EN_8821C 0x0426
+#define REG_SPEC_SIFS_8821C 0x0428
+#define REG_RETRY_LIMIT_8821C 0x042A
+#define REG_TXBF_CTRL_8821C 0x042C
+#define REG_DARFRC_8821C 0x0430
+#define REG_DARFRCH_8821C 0x0434
+#define REG_RARFRC_8821C 0x0438
+#define REG_RARFRCH_8821C 0x043C
+#define REG_RRSR_8821C 0x0440
+#define REG_ARFR0_8821C 0x0444
+#define REG_ARFRH0_8821C 0x0448
+#define REG_ARFR1_V1_8821C 0x044C
+#define REG_ARFRH1_V1_8821C 0x0450
+#define REG_CCK_CHECK_8821C 0x0454
+#define REG_AMPDU_MAX_TIME_V1_8821C 0x0455
+#define REG_BCNQ1_BDNY_V1_8821C 0x0456
+#define REG_AMPDU_MAX_LENGTH_8821C 0x0458
+#define REG_ACQ_STOP_8821C 0x045C
+#define REG_NDPA_RATE_8821C 0x045D
+#define REG_TX_HANG_CTRL_8821C 0x045E
+#define REG_NDPA_OPT_CTRL_8821C 0x045F
+#define REG_RD_RESP_PKT_TH_8821C 0x0463
+#define REG_CMDQ_INFO_8821C 0x0464
+#define REG_Q4_INFO_8821C 0x0468
+#define REG_Q5_INFO_8821C 0x046C
+#define REG_Q6_INFO_8821C 0x0470
+#define REG_Q7_INFO_8821C 0x0474
+#define REG_WMAC_LBK_BUF_HD_V1_8821C 0x0478
+#define REG_MGQ_BDNY_V1_8821C 0x047A
+#define REG_TXRPT_CTRL_8821C 0x047C
+#define REG_INIRTS_RATE_SEL_8821C 0x0480
+#define REG_BASIC_CFEND_RATE_8821C 0x0481
+#define REG_STBC_CFEND_RATE_8821C 0x0482
+#define REG_DATA_SC_8821C 0x0483
+#define REG_MACID_SLEEP3_8821C 0x0484
+#define REG_MACID_SLEEP1_8821C 0x0488
+#define REG_ARFR2_V1_8821C 0x048C
+#define REG_ARFRH2_V1_8821C 0x0490
+#define REG_ARFR3_V1_8821C 0x0494
+#define REG_ARFRH3_V1_8821C 0x0498
+#define REG_ARFR4_8821C 0x049C
+#define REG_ARFRH4_8821C 0x04A0
+#define REG_ARFR5_8821C 0x04A4
+#define REG_ARFRH5_8821C 0x04A8
+#define REG_TXRPT_START_OFFSET_8821C 0x04AC
+#define REG_POWER_STAGE1_8821C 0x04B4
+#define REG_POWER_STAGE2_8821C 0x04B8
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8821C 0x04BC
+#define REG_PKT_LIFE_TIME_8821C 0x04C0
+#define REG_STBC_SETTING_8821C 0x04C4
+#define REG_STBC_SETTING2_8821C 0x04C5
+#define REG_QUEUE_CTRL_8821C 0x04C6
+#define REG_SINGLE_AMPDU_CTRL_8821C 0x04C7
+#define REG_PROT_MODE_CTRL_8821C 0x04C8
+#define REG_BAR_MODE_CTRL_8821C 0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8821C 0x04CF
+#define REG_MACID_SLEEP2_8821C 0x04D0
+#define REG_MACID_SLEEP_8821C 0x04D4
+#define REG_HW_SEQ0_8821C 0x04D8
+#define REG_HW_SEQ1_8821C 0x04DA
+#define REG_HW_SEQ2_8821C 0x04DC
+#define REG_HW_SEQ3_8821C 0x04DE
+#define REG_NULL_PKT_STATUS_V1_8821C 0x04E0
+#define REG_PTCL_ERR_STATUS_8821C 0x04E2
+#define REG_NULL_PKT_STATUS_EXTEND_8821C 0x04E3
+#define REG_VIDEO_ENHANCEMENT_FUN_8821C 0x04E4
+#define REG_PRECNT_CTRL_8821C 0x04E5
+#define REG_BT_POLLUTE_PKT_CNT_8821C 0x04E8
+#define REG_PTCL_DBG_8821C 0x04EC
+#define REG_CPUMGQ_TIMER_CTRL2_8821C 0x04F4
+#define REG_DUMMY_PAGE4_V1_8821C 0x04FC
+#define REG_MOREDATA_8821C 0x04FE
+#define REG_Q0_Q1_INFO_8821C 0x1400
+#define REG_Q2_Q3_INFO_8821C 0x1404
+#define REG_Q4_Q5_INFO_8821C 0x1408
+#define REG_Q6_Q7_INFO_8821C 0x140C
+#define REG_MGQ_HIQ_INFO_8821C 0x1410
+#define REG_CMDQ_BCNQ_INFO_8821C 0x1414
+#define REG_USEREG_SETTING_8821C 0x1420
+#define REG_AESIV_SETTING_8821C 0x1424
+#define REG_BF0_TIME_SETTING_8821C 0x1428
+#define REG_BF1_TIME_SETTING_8821C 0x142C
+#define REG_BF_TIMEOUT_EN_8821C 0x1430
+#define REG_MACID_RELEASE0_8821C 0x1434
+#define REG_MACID_RELEASE1_8821C 0x1438
+#define REG_MACID_RELEASE2_8821C 0x143C
+#define REG_MACID_RELEASE3_8821C 0x1440
+#define REG_MACID_RELEASE_SETTING_8821C 0x1444
+#define REG_FAST_EDCA_VOVI_SETTING_8821C 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING_8821C 0x144C
+#define REG_MACID_DROP0_8821C 0x1450
+#define REG_MACID_DROP1_8821C 0x1454
+#define REG_MACID_DROP2_8821C 0x1458
+#define REG_MACID_DROP3_8821C 0x145C
+#define REG_R_MACID_RELEASE_SUCCESS_0_8821C 0x1460
+#define REG_R_MACID_RELEASE_SUCCESS_1_8821C 0x1464
+#define REG_R_MACID_RELEASE_SUCCESS_2_8821C 0x1468
+#define REG_R_MACID_RELEASE_SUCCESS_3_8821C 0x146C
+#define REG_MGQ_FIFO_WRITE_POINTER_8821C 0x1470
+#define REG_MGQ_FIFO_READ_POINTER_8821C 0x1472
+#define REG_MGQ_FIFO_ENABLE_8821C 0x1472
+#define REG_MGQ_FIFO_RELEASE_INT_MASK_8821C 0x1474
+#define REG_MGQ_FIFO_RELEASE_INT_FLAG_8821C 0x1476
+#define REG_MGQ_FIFO_VALID_MAP_8821C 0x1478
+#define REG_MGQ_FIFO_LIFETIME_8821C 0x147A
+#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C 0x147C
+#define REG_SHCUT_SETTING_8821C 0x1480
+#define REG_SHCUT_LLC_ETH_TYPE0_8821C 0x1484
+#define REG_SHCUT_LLC_ETH_TYPE1_8821C 0x1488
+#define REG_SHCUT_LLC_OUI0_8821C 0x148C
+#define REG_SHCUT_LLC_OUI1_8821C 0x1490
+#define REG_SHCUT_LLC_OUI2_8821C 0x1494
+#define REG_MU_TX_CTL_8821C 0x14C0
+#define REG_MU_STA_GID_VLD_8821C 0x14C4
+#define REG_MU_STA_USER_POS_INFO_8821C 0x14C8
+#define REG_MU_STA_USER_POS_INFO_H_8821C 0x14CC
+#define REG_MU_TRX_DBG_CNT_8821C 0x14D0
+#define REG_EDCA_VO_PARAM_8821C 0x0500
+#define REG_EDCA_VI_PARAM_8821C 0x0504
+#define REG_EDCA_BE_PARAM_8821C 0x0508
+#define REG_EDCA_BK_PARAM_8821C 0x050C
+#define REG_BCNTCFG_8821C 0x0510
+#define REG_PIFS_8821C 0x0512
+#define REG_RDG_PIFS_8821C 0x0513
+#define REG_SIFS_8821C 0x0514
+#define REG_TSFTR_SYN_OFFSET_8821C 0x0518
+#define REG_AGGR_BREAK_TIME_8821C 0x051A
+#define REG_SLOT_8821C 0x051B
+#define REG_NOA_ON_ERLY_TIME_8821C 0x051C
+#define REG_NOA_OFF_ERLY_TIME_8821C 0x051D
+#define REG_TX_PTCL_CTRL_8821C 0x0520
+#define REG_TXPAUSE_8821C 0x0522
+#define REG_DIS_TXREQ_CLR_8821C 0x0523
+#define REG_RD_CTRL_8821C 0x0524
+#define REG_MBSSID_CTRL_8821C 0x0526
+#define REG_P2PPS_CTRL_8821C 0x0527
+#define REG_PKT_LIFETIME_CTRL_8821C 0x0528
+#define REG_P2PPS_SPEC_STATE_8821C 0x052B
+#define REG_BAR_TX_CTRL_8821C 0x0530
+#define REG_P2PON_DIS_TXTIME_8821C 0x0531
+#define REG_TBTT_PROHIBIT_8821C 0x0540
+#define REG_P2PPS_STATE_8821C 0x0543
+#define REG_RD_NAV_NXT_8821C 0x0544
+#define REG_NAV_PROT_LEN_8821C 0x0546
+#define REG_BCN_CTRL_8821C 0x0550
+#define REG_BCN_CTRL_CLINT0_8821C 0x0551
+#define REG_MBID_NUM_8821C 0x0552
+#define REG_DUAL_TSF_RST_8821C 0x0553
+#define REG_MBSSID_BCN_SPACE_8821C 0x0554
+#define REG_DRVERLYINT_8821C 0x0558
+#define REG_BCNDMATIM_8821C 0x0559
+#define REG_ATIMWND_8821C 0x055A
+#define REG_USTIME_TSF_8821C 0x055C
+#define REG_BCN_MAX_ERR_8821C 0x055D
+#define REG_RXTSF_OFFSET_CCK_8821C 0x055E
+#define REG_RXTSF_OFFSET_OFDM_8821C 0x055F
+#define REG_TSFTR_8821C 0x0560
+#define REG_TSFTR_1_8821C 0x0564
+#define REG_FREERUN_CNT_8821C 0x0568
+#define REG_FREERUN_CNT_1_8821C 0x056C
+#define REG_ATIMWND1_V1_8821C 0x0570
+#define REG_TBTT_PROHIBIT_INFRA_8821C 0x0571
+#define REG_CTWND_8821C 0x0572
+#define REG_BCNIVLCUNT_8821C 0x0573
+#define REG_BCNDROPCTRL_8821C 0x0574
+#define REG_HGQ_TIMEOUT_PERIOD_8821C 0x0575
+#define REG_TXCMD_TIMEOUT_PERIOD_8821C 0x0576
+#define REG_MISC_CTRL_8821C 0x0577
+#define REG_BCN_CTRL_CLINT1_8821C 0x0578
+#define REG_BCN_CTRL_CLINT2_8821C 0x0579
+#define REG_BCN_CTRL_CLINT3_8821C 0x057A
+#define REG_EXTEND_CTRL_8821C 0x057B
+#define REG_P2PPS1_SPEC_STATE_8821C 0x057C
+#define REG_P2PPS1_STATE_8821C 0x057D
+#define REG_P2PPS2_SPEC_STATE_8821C 0x057E
+#define REG_P2PPS2_STATE_8821C 0x057F
+#define REG_PS_TIMER0_8821C 0x0580
+#define REG_PS_TIMER1_8821C 0x0584
+#define REG_PS_TIMER2_8821C 0x0588
+#define REG_TBTT_CTN_AREA_8821C 0x058C
+#define REG_FORCE_BCN_IFS_8821C 0x058E
+#define REG_TXOP_MIN_8821C 0x0590
+#define REG_PRE_BKF_TIME_8821C 0x0592
+#define REG_CROSS_TXOP_CTRL_8821C 0x0593
+#define REG_ATIMWND2_8821C 0x05A0
+#define REG_ATIMWND3_8821C 0x05A1
+#define REG_ATIMWND4_8821C 0x05A2
+#define REG_ATIMWND5_8821C 0x05A3
+#define REG_ATIMWND6_8821C 0x05A4
+#define REG_ATIMWND7_8821C 0x05A5
+#define REG_ATIMUGT_8821C 0x05A6
+#define REG_HIQ_NO_LMT_EN_8821C 0x05A7
+#define REG_DTIM_COUNTER_ROOT_8821C 0x05A8
+#define REG_DTIM_COUNTER_VAP1_8821C 0x05A9
+#define REG_DTIM_COUNTER_VAP2_8821C 0x05AA
+#define REG_DTIM_COUNTER_VAP3_8821C 0x05AB
+#define REG_DTIM_COUNTER_VAP4_8821C 0x05AC
+#define REG_DTIM_COUNTER_VAP5_8821C 0x05AD
+#define REG_DTIM_COUNTER_VAP6_8821C 0x05AE
+#define REG_DTIM_COUNTER_VAP7_8821C 0x05AF
+#define REG_DIS_ATIM_8821C 0x05B0
+#define REG_EARLY_128US_8821C 0x05B1
+#define REG_P2PPS1_CTRL_8821C 0x05B2
+#define REG_P2PPS2_CTRL_8821C 0x05B3
+#define REG_TIMER0_SRC_SEL_8821C 0x05B4
+#define REG_NOA_UNIT_SEL_8821C 0x05B5
+#define REG_P2POFF_DIS_TXTIME_8821C 0x05B7
+#define REG_MBSSID_BCN_SPACE2_8821C 0x05B8
+#define REG_MBSSID_BCN_SPACE3_8821C 0x05BC
+#define REG_ACMHWCTRL_8821C 0x05C0
+#define REG_ACMRSTCTRL_8821C 0x05C1
+#define REG_ACMAVG_8821C 0x05C2
+#define REG_VO_ADMTIME_8821C 0x05C4
+#define REG_VI_ADMTIME_8821C 0x05C6
+#define REG_BE_ADMTIME_8821C 0x05C8
+#define REG_EDCA_RANDOM_GEN_8821C 0x05CC
+#define REG_TXCMD_NOA_SEL_8821C 0x05CF
+#define REG_NOA_PARAM_8821C 0x05E0
+#define REG_NOA_PARAM_1_8821C 0x05E4
+#define REG_NOA_PARAM_2_8821C 0x05E8
+#define REG_NOA_PARAM_3_8821C 0x05EC
+#define REG_P2P_RST_8821C 0x05F0
+#define REG_SCHEDULER_RST_8821C 0x05F1
+#define REG_SCH_TXCMD_8821C 0x05F8
+#define REG_PAGE5_DUMMY_8821C 0x05FC
+#define REG_CPUMGQ_TX_TIMER_8821C 0x1500
+#define REG_PS_TIMER_A_8821C 0x1504
+#define REG_PS_TIMER_B_8821C 0x1508
+#define REG_PS_TIMER_C_8821C 0x150C
+#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8821C 0x1510
+#define REG_CPUMGQ_TX_TIMER_EARLY_8821C 0x1514
+#define REG_PS_TIMER_A_EARLY_8821C 0x1515
+#define REG_PS_TIMER_B_EARLY_8821C 0x1516
+#define REG_PS_TIMER_C_EARLY_8821C 0x1517
+#define REG_CPUMGQ_PARAMETER_8821C 0x1518
+#define REG_WMAC_CR_8821C 0x0600
+#define REG_WMAC_FWPKT_CR_8821C 0x0601
+#define REG_FW_STS_FILTER_8821C 0x0602
+#define REG_TCR_8821C 0x0604
+#define REG_RCR_8821C 0x0608
+#define REG_RX_PKT_LIMIT_8821C 0x060C
+#define REG_RX_DLK_TIME_8821C 0x060D
+#define REG_RX_DRVINFO_SZ_8821C 0x060F
+#define REG_MACID_8821C 0x0610
+#define REG_MACID_H_8821C 0x0614
+#define REG_BSSID_8821C 0x0618
+#define REG_BSSID_H_8821C 0x061C
+#define REG_MAR_8821C 0x0620
+#define REG_MAR_H_8821C 0x0624
+#define REG_MBIDCAMCFG_1_8821C 0x0628
+#define REG_MBIDCAMCFG_2_8821C 0x062C
+#define REG_WMAC_TCR_TSFT_OFS_8821C 0x0630
+#define REG_UDF_THSD_8821C 0x0632
+#define REG_ZLD_NUM_8821C 0x0633
+#define REG_STMP_THSD_8821C 0x0634
+#define REG_WMAC_TXTIMEOUT_8821C 0x0635
+#define REG_MCU_TEST_2_V1_8821C 0x0636
+#define REG_USTIME_EDCA_8821C 0x0638
+#define REG_ACKTO_CCK_8821C 0x0639
+#define REG_MAC_SPEC_SIFS_8821C 0x063A
+#define REG_RESP_SIFS_CCK_8821C 0x063C
+#define REG_RESP_SIFS_OFDM_8821C 0x063E
+#define REG_ACKTO_8821C 0x0640
+#define REG_CTS2TO_8821C 0x0641
+#define REG_EIFS_8821C 0x0642
+#define REG_RPFM_MAP0_8821C 0x0644
+#define REG_RPFM_MAP1_V1_8821C 0x0646
+#define REG_RPFM_CAM_CMD_8821C 0x0648
+#define REG_RPFM_CAM_RWD_8821C 0x064C
+#define REG_NAV_CTRL_8821C 0x0650
+#define REG_BACAMCMD_8821C 0x0654
+#define REG_BACAMCONTENT_8821C 0x0658
+#define REG_BACAMCONTENT_H_8821C 0x065C
+#define REG_LBDLY_8821C 0x0660
+#define REG_WMAC_BACAM_RPMEN_8821C 0x0661
+#define REG_TX_RX_8821C 0x0662
+#define REG_WMAC_BITMAP_CTL_8821C 0x0663
+#define REG_RXERR_RPT_8821C 0x0664
+#define REG_WMAC_TRXPTCL_CTL_8821C 0x0668
+#define REG_WMAC_TRXPTCL_CTL_H_8821C 0x066C
+#define REG_CAMCMD_8821C 0x0670
+#define REG_CAMWRITE_8821C 0x0674
+#define REG_CAMREAD_8821C 0x0678
+#define REG_CAMDBG_8821C 0x067C
+#define REG_SECCFG_8821C 0x0680
+#define REG_RXFILTER_CATEGORY_1_8821C 0x0682
+#define REG_RXFILTER_ACTION_1_8821C 0x0683
+#define REG_RXFILTER_CATEGORY_2_8821C 0x0684
+#define REG_RXFILTER_ACTION_2_8821C 0x0685
+#define REG_RXFILTER_CATEGORY_3_8821C 0x0686
+#define REG_RXFILTER_ACTION_3_8821C 0x0687
+#define REG_RXFLTMAP3_8821C 0x0688
+#define REG_RXFLTMAP4_8821C 0x068A
+#define REG_RXFLTMAP5_8821C 0x068C
+#define REG_RXFLTMAP6_8821C 0x068E
+#define REG_WOW_CTRL_8821C 0x0690
+#define REG_NAN_RX_TSF_FILTER_8821C 0x0691
+#define REG_PS_RX_INFO_8821C 0x0692
+#define REG_WMMPS_UAPSD_TID_8821C 0x0693
+#define REG_LPNAV_CTRL_8821C 0x0694
+#define REG_WKFMCAM_CMD_8821C 0x0698
+#define REG_WKFMCAM_RWD_8821C 0x069C
+#define REG_RXFLTMAP0_8821C 0x06A0
+#define REG_RXFLTMAP1_8821C 0x06A2
+#define REG_RXFLTMAP2_8821C 0x06A4
+#define REG_BCN_PSR_RPT_8821C 0x06A8
+#define REG_FLC_RPC_8821C 0x06AC
+#define REG_FLC_RPCT_8821C 0x06AD
+#define REG_FLC_PTS_8821C 0x06AE
+#define REG_FLC_TRPC_8821C 0x06AF
+#define REG_RXPKTMON_CTRL_8821C 0x06B0
+#define REG_STATE_MON_8821C 0x06B4
+#define REG_ERROR_MON_8821C 0x06B8
+#define REG_SEARCH_MACID_8821C 0x06BC
+#define REG_BT_COEX_TABLE_8821C 0x06C0
+#define REG_BT_COEX_TABLE2_8821C 0x06C4
+#define REG_BT_COEX_BREAK_TABLE_8821C 0x06C8
+#define REG_BT_COEX_TABLE_H_8821C 0x06CC
+#define REG_RXCMD_0_8821C 0x06D0
+#define REG_RXCMD_1_8821C 0x06D4
+#define REG_WMAC_RESP_TXINFO_8821C 0x06D8
+#define REG_BBPSF_CTRL_8821C 0x06DC
+#define REG_P2P_RX_BCN_NOA_8821C 0x06E0
+#define REG_ASSOCIATED_BFMER0_INFO_8821C 0x06E4
+#define REG_ASSOCIATED_BFMER0_INFO_H_8821C 0x06E8
+#define REG_ASSOCIATED_BFMER1_INFO_8821C 0x06EC
+#define REG_ASSOCIATED_BFMER1_INFO_H_8821C 0x06F0
+#define REG_TX_CSI_RPT_PARAM_BW20_8821C 0x06F4
+#define REG_TX_CSI_RPT_PARAM_BW40_8821C 0x06F8
+#define REG_BCN_PSR_RPT2_8821C 0x1600
+#define REG_BCN_PSR_RPT3_8821C 0x1604
+#define REG_BCN_PSR_RPT4_8821C 0x1608
+#define REG_A1_ADDR_MASK_8821C 0x160C
+#define REG_MACID2_8821C 0x1620
+#define REG_MACID2_H_8821C 0x1624
+#define REG_BSSID2_8821C 0x1628
+#define REG_BSSID2_H_8821C 0x162C
+#define REG_MACID3_8821C 0x1630
+#define REG_MACID3_H_8821C 0x1634
+#define REG_BSSID3_8821C 0x1638
+#define REG_BSSID3_H_8821C 0x163C
+#define REG_MACID4_8821C 0x1640
+#define REG_MACID4_H_8821C 0x1644
+#define REG_BSSID4_8821C 0x1648
+#define REG_BSSID4_H_8821C 0x164C
+#define REG_NOA_REPORT_8821C 0x1650
+#define REG_NOA_REPORT_1_8821C 0x1654
+#define REG_NOA_REPORT_2_8821C 0x1658
+#define REG_NOA_REPORT_3_8821C 0x165C
+#define REG_PWRBIT_SETTING_8821C 0x1660
+#define REG_MU_BF_OPTION_8821C 0x167C
+#define REG_WMAC_PAUSE_BB_CLR_TH_8821C 0x167D
+#define REG_WMAC_MU_ARB_8821C 0x167E
+#define REG_WMAC_MU_OPTION_8821C 0x167F
+#define REG_WMAC_MU_BF_CTL_8821C 0x1680
+#define REG_WMAC_MU_BFRPT_PARA_8821C 0x1682
+#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8821C 0x1684
+#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8821C 0x1686
+#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8821C 0x1688
+#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8821C 0x168A
+#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8821C 0x168C
+#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8821C 0x168E
+#define REG_WMAC_BB_STOP_RX_COUNTER_8821C 0x1690
+#define REG_WMAC_PLCP_MONITOR_8821C 0x1694
+#define REG_WMAC_PLCP_MONITOR_MUTX_8821C 0x1698
+#define REG_TRANSMIT_ADDRSS_0_8821C 0x16A0
+#define REG_TRANSMIT_ADDRSS_0_H_8821C 0x16A4
+#define REG_TRANSMIT_ADDRSS_1_8821C 0x16A8
+#define REG_TRANSMIT_ADDRSS_1_H_8821C 0x16AC
+#define REG_TRANSMIT_ADDRSS_2_8821C 0x16B0
+#define REG_TRANSMIT_ADDRSS_2_H_8821C 0x16B4
+#define REG_TRANSMIT_ADDRSS_3_8821C 0x16B8
+#define REG_TRANSMIT_ADDRSS_3_H_8821C 0x16BC
+#define REG_TRANSMIT_ADDRSS_4_8821C 0x16C0
+#define REG_TRANSMIT_ADDRSS_4_H_8821C 0x16C4
+#define REG_MACID1_8821C 0x0700
+#define REG_MACID1_1_8821C 0x0704
+#define REG_BSSID1_8821C 0x0708
+#define REG_BSSID1_1_8821C 0x070C
+#define REG_BCN_PSR_RPT1_8821C 0x0710
+#define REG_ASSOCIATED_BFMEE_SEL_8821C 0x0714
+#define REG_SND_PTCL_CTRL_8821C 0x0718
+#define REG_RX_CSI_RPT_INFO_8821C 0x071C
+#define REG_NS_ARP_CTRL_8821C 0x0720
+#define REG_NS_ARP_INFO_8821C 0x0724
+#define REG_BEAMFORMING_INFO_NSARP_V1_8821C 0x0728
+#define REG_BEAMFORMING_INFO_NSARP_8821C 0x072C
+#define REG_IPV6_8821C 0x0730
+#define REG_IPV6_1_8821C 0x0734
+#define REG_IPV6_2_8821C 0x0738
+#define REG_IPV6_3_8821C 0x073C
+#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8821C 0x0750
+#define REG_WMAC_SWAES_CFG_8821C 0x0760
+#define REG_BT_COEX_V2_8821C 0x0762
+#define REG_BT_COEX_8821C 0x0764
+#define REG_WLAN_ACT_MASK_CTRL_8821C 0x0768
+#define REG_WLAN_ACT_MASK_CTRL_1_8821C 0x076C
+#define REG_BT_COEX_ENHANCED_INTR_CTRL_8821C 0x076E
+#define REG_BT_ACT_STATISTICS_8821C 0x0770
+#define REG_BT_ACT_STATISTICS_1_8821C 0x0774
+#define REG_BT_STATISTICS_CONTROL_REGISTER_8821C 0x0778
+#define REG_BT_STATUS_REPORT_REGISTER_8821C 0x077C
+#define REG_BT_INTERRUPT_CONTROL_REGISTER_8821C 0x0780
+#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8821C 0x0784
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8821C 0x0785
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8821C 0x0788
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8821C 0x078C
+#define REG_BT_INTERRUPT_STATUS_REGISTER_8821C 0x078F
+#define REG_BT_TDMA_TIME_REGISTER_8821C 0x0790
+#define REG_BT_ACT_REGISTER_8821C 0x0794
+#define REG_OBFF_CTRL_BASIC_8821C 0x0798
+#define REG_OBFF_CTRL2_TIMER_8821C 0x079C
+#define REG_LTR_CTRL_BASIC_8821C 0x07A0
+#define REG_LTR_CTRL2_TIMER_THRESHOLD_8821C 0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8821C 0x07A8
+#define REG_LTR_ACTIVE_LATENCY_V1_8821C 0x07AC
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8821C 0x07B0
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_1_8821C 0x07B4
+#define REG_WMAC_PKTCNT_RWD_8821C 0x07B8
+#define REG_WMAC_PKTCNT_CTRL_8821C 0x07BC
+#define REG_IQ_DUMP_8821C 0x07C0
+#define REG_IQ_DUMP_1_8821C 0x07C4
+#define REG_IQ_DUMP_2_8821C 0x07C8
+#define REG_WMAC_FTM_CTL_8821C 0x07CC
+#define REG_WMAC_IQ_MDPK_FUNC_8821C 0x07CE
+#define REG_WMAC_OPTION_FUNCTION_8821C 0x07D0
+#define REG_WMAC_OPTION_FUNCTION_1_8821C 0x07D4
+#define REG_WMAC_OPTION_FUNCTION_2_8821C 0x07D8
+#define REG_RX_FILTER_FUNCTION_8821C 0x07DA
+#define REG_NDP_SIG_8821C 0x07E0
+#define REG_TXCMD_INFO_FOR_RSP_PKT_8821C 0x07E4
+#define REG_TXCMD_INFO_FOR_RSP_PKT_1_8821C 0x07E8
+#define REG_WSEC_OPTION_8821C 0x07EC
+#define REG_RTS_ADDRESS_0_8821C 0x07F0
+#define REG_RTS_ADDRESS_0_1_8821C 0x07F4
+#define REG_RTS_ADDRESS_1_8821C 0x07F8
+#define REG_RTS_ADDRESS_1_1_8821C 0x07FC
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8821C 0x1700
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8821C 0x1704
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8821C 0x1708
+#define REG_SDIO_TX_CTRL_8821C 0x10250000
+#define REG_SDIO_HIMR_8821C 0x10250014
+#define REG_SDIO_HISR_8821C 0x10250018
+#define REG_SDIO_RX_REQ_LEN_8821C 0x1025001C
+#define REG_SDIO_FREE_TXPG_SEQ_V1_8821C 0x1025001F
+#define REG_SDIO_FREE_TXPG_8821C 0x10250020
+#define REG_SDIO_FREE_TXPG2_8821C 0x10250024
+#define REG_SDIO_OQT_FREE_TXPG_V1_8821C 0x10250028
+#define REG_SDIO_HTSFR_INFO_8821C 0x10250030
+#define REG_SDIO_HCPWM1_V2_8821C 0x10250038
+#define REG_SDIO_HCPWM2_V2_8821C 0x1025003A
+#define REG_SDIO_INDIRECT_REG_CFG_8821C 0x10250040
+#define REG_SDIO_INDIRECT_REG_DATA_8821C 0x10250044
+#define REG_SDIO_H2C_8821C 0x10250060
+#define REG_SDIO_C2H_8821C 0x10250064
+#define REG_SDIO_HRPWM1_8821C 0x10250080
+#define REG_SDIO_HRPWM2_8821C 0x10250082
+#define REG_SDIO_HPS_CLKR_8821C 0x10250084
+#define REG_SDIO_BUS_CTRL_8821C 0x10250085
+#define REG_SDIO_HSUS_CTRL_8821C 0x10250086
+#define REG_SDIO_RESPONSE_TIMER_8821C 0x10250088
+#define REG_SDIO_CMD_CRC_8821C 0x1025008A
+#define REG_SDIO_HSISR_8821C 0x10250090
+#define REG_SDIO_ERR_RPT_8821C 0x102500C0
+#define REG_SDIO_CMD_ERRCNT_8821C 0x102500C2
+#define REG_SDIO_DATA_ERRCNT_8821C 0x102500C3
+#define REG_SDIO_CMD_ERR_CONTENT_8821C 0x102500C4
+#define REG_SDIO_CRC_ERR_IDX_8821C 0x102500C9
+#define REG_SDIO_DATA_CRC_8821C 0x102500CA
+#define REG_SDIO_DATA_REPLY_TIME_8821C 0x102500CB
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8822b.h
new file mode 100644
index 000000000000..e06f67e198e0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8822b.h
@@ -0,0 +1,733 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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_HALMAC_REG_8822B_H
+#define __INC_HALMAC_REG_8822B_H
+
+#define REG_SYS_ISO_CTRL_8822B 0x0000
+#define REG_SYS_FUNC_EN_8822B 0x0002
+#define REG_SYS_PW_CTRL_8822B 0x0004
+#define REG_SYS_CLK_CTRL_8822B 0x0008
+#define REG_SYS_EEPROM_CTRL_8822B 0x000A
+#define REG_EE_VPD_8822B 0x000C
+#define REG_SYS_SWR_CTRL1_8822B 0x0010
+#define REG_SYS_SWR_CTRL2_8822B 0x0014
+#define REG_SYS_SWR_CTRL3_8822B 0x0018
+#define REG_RSV_CTRL_8822B 0x001C
+#define REG_RF_CTRL_8822B 0x001F
+#define REG_AFE_LDO_CTRL_8822B 0x0020
+#define REG_AFE_CTRL1_8822B 0x0024
+#define REG_AFE_CTRL2_8822B 0x0028
+#define REG_AFE_CTRL3_8822B 0x002C
+#define REG_EFUSE_CTRL_8822B 0x0030
+#define REG_LDO_EFUSE_CTRL_8822B 0x0034
+#define REG_PWR_OPTION_CTRL_8822B 0x0038
+#define REG_CAL_TIMER_8822B 0x003C
+#define REG_ACLK_MON_8822B 0x003E
+#define REG_GPIO_MUXCFG_8822B 0x0040
+#define REG_GPIO_PIN_CTRL_8822B 0x0044
+#define REG_GPIO_INTM_8822B 0x0048
+#define REG_LED_CFG_8822B 0x004C
+#define REG_FSIMR_8822B 0x0050
+#define REG_FSISR_8822B 0x0054
+#define REG_HSIMR_8822B 0x0058
+#define REG_HSISR_8822B 0x005C
+#define REG_GPIO_EXT_CTRL_8822B 0x0060
+#define REG_PAD_CTRL1_8822B 0x0064
+#define REG_WL_BT_PWR_CTRL_8822B 0x0068
+#define REG_SDM_DEBUG_8822B 0x006C
+#define REG_SYS_SDIO_CTRL_8822B 0x0070
+#define REG_HCI_OPT_CTRL_8822B 0x0074
+#define REG_AFE_CTRL4_8822B 0x0078
+#define REG_LDO_SWR_CTRL_8822B 0x007C
+#define REG_MCUFW_CTRL_8822B 0x0080
+#define REG_MCU_TST_CFG_8822B 0x0084
+#define REG_HMEBOX_E0_E1_8822B 0x0088
+#define REG_HMEBOX_E2_E3_8822B 0x008C
+#define REG_WLLPS_CTRL_8822B 0x0090
+#define REG_AFE_CTRL5_8822B 0x0094
+#define REG_GPIO_DEBOUNCE_CTRL_8822B 0x0098
+#define REG_RPWM2_8822B 0x009C
+#define REG_SYSON_FSM_MON_8822B 0x00A0
+#define REG_AFE_CTRL6_8822B 0x00A4
+#define REG_PMC_DBG_CTRL1_8822B 0x00A8
+#define REG_AFE_CTRL7_8822B 0x00AC
+#define REG_HIMR0_8822B 0x00B0
+#define REG_HISR0_8822B 0x00B4
+#define REG_HIMR1_8822B 0x00B8
+#define REG_HISR1_8822B 0x00BC
+#define REG_DBG_PORT_SEL_8822B 0x00C0
+#define REG_PAD_CTRL2_8822B 0x00C4
+#define REG_PMC_DBG_CTRL2_8822B 0x00CC
+#define REG_BIST_CTRL_8822B 0x00D0
+#define REG_BIST_RPT_8822B 0x00D4
+#define REG_MEM_CTRL_8822B 0x00D8
+#define REG_AFE_CTRL8_8822B 0x00DC
+#define REG_USB_SIE_INTF_8822B 0x00E0
+#define REG_PCIE_MIO_INTF_8822B 0x00E4
+#define REG_PCIE_MIO_INTD_8822B 0x00E8
+#define REG_WLRF1_8822B 0x00EC
+#define REG_SYS_CFG1_8822B 0x00F0
+#define REG_SYS_STATUS1_8822B 0x00F4
+#define REG_SYS_STATUS2_8822B 0x00F8
+#define REG_SYS_CFG2_8822B 0x00FC
+#define REG_SYS_CFG3_8822B 0x1000
+#define REG_SYS_CFG4_8822B 0x1034
+#define REG_SYS_CFG5_8822B 0x1070
+#define REG_CPU_DMEM_CON_8822B 0x1080
+#define REG_BOOT_REASON_8822B 0x1088
+#define REG_NFCPAD_CTRL_8822B 0x10A8
+#define REG_HIMR2_8822B 0x10B0
+#define REG_HISR2_8822B 0x10B4
+#define REG_HIMR3_8822B 0x10B8
+#define REG_HISR3_8822B 0x10BC
+#define REG_SW_MDIO_8822B 0x10C0
+#define REG_SW_FLUSH_8822B 0x10C4
+#define REG_H2C_PKT_READADDR_8822B 0x10D0
+#define REG_H2C_PKT_WRITEADDR_8822B 0x10D4
+#define REG_MEM_PWR_CRTL_8822B 0x10D8
+#define REG_FW_DBG0_8822B 0x10E0
+#define REG_FW_DBG1_8822B 0x10E4
+#define REG_FW_DBG2_8822B 0x10E8
+#define REG_FW_DBG3_8822B 0x10EC
+#define REG_FW_DBG4_8822B 0x10F0
+#define REG_FW_DBG5_8822B 0x10F4
+#define REG_FW_DBG6_8822B 0x10F8
+#define REG_FW_DBG7_8822B 0x10FC
+#define REG_CR_8822B 0x0100
+#define REG_TSF_CLK_STATE_8822B 0x0108
+#define REG_TXDMA_PQ_MAP_8822B 0x010C
+#define REG_TRXFF_BNDY_8822B 0x0114
+#define REG_PTA_I2C_MBOX_8822B 0x0118
+#define REG_RXFF_BNDY_8822B 0x011C
+#define REG_FE1IMR_8822B 0x0120
+#define REG_FE1ISR_8822B 0x0124
+#define REG_CPWM_8822B 0x012C
+#define REG_FWIMR_8822B 0x0130
+#define REG_FWISR_8822B 0x0134
+#define REG_FTIMR_8822B 0x0138
+#define REG_FTISR_8822B 0x013C
+#define REG_PKTBUF_DBG_CTRL_8822B 0x0140
+#define REG_PKTBUF_DBG_DATA_L_8822B 0x0144
+#define REG_PKTBUF_DBG_DATA_H_8822B 0x0148
+#define REG_CPWM2_8822B 0x014C
+#define REG_TC0_CTRL_8822B 0x0150
+#define REG_TC1_CTRL_8822B 0x0154
+#define REG_TC2_CTRL_8822B 0x0158
+#define REG_TC3_CTRL_8822B 0x015C
+#define REG_TC4_CTRL_8822B 0x0160
+#define REG_TCUNIT_BASE_8822B 0x0164
+#define REG_TC5_CTRL_8822B 0x0168
+#define REG_TC6_CTRL_8822B 0x016C
+#define REG_MBIST_FAIL_8822B 0x0170
+#define REG_MBIST_START_PAUSE_8822B 0x0174
+#define REG_MBIST_DONE_8822B 0x0178
+#define REG_MBIST_FAIL_NRML_8822B 0x017C
+#define REG_AES_DECRPT_DATA_8822B 0x0180
+#define REG_AES_DECRPT_CFG_8822B 0x0184
+#define REG_TMETER_8822B 0x0190
+#define REG_OSC_32K_CTRL_8822B 0x0194
+#define REG_32K_CAL_REG1_8822B 0x0198
+#define REG_C2HEVT_8822B 0x01A0
+#define REG_C2HEVT_1_8822B 0x01A4
+#define REG_C2HEVT_2_8822B 0x01A8
+#define REG_C2HEVT_3_8822B 0x01AC
+#define REG_SW_DEFINED_PAGE1_8822B 0x01B8
+#define REG_MCUTST_I_8822B 0x01C0
+#define REG_MCUTST_II_8822B 0x01C4
+#define REG_FMETHR_8822B 0x01C8
+#define REG_HMETFR_8822B 0x01CC
+#define REG_HMEBOX0_8822B 0x01D0
+#define REG_HMEBOX1_8822B 0x01D4
+#define REG_HMEBOX2_8822B 0x01D8
+#define REG_HMEBOX3_8822B 0x01DC
+#define REG_LLT_INIT_8822B 0x01E0
+#define REG_LLT_INIT_ADDR_8822B 0x01E4
+#define REG_BB_ACCESS_CTRL_8822B 0x01E8
+#define REG_BB_ACCESS_DATA_8822B 0x01EC
+#define REG_HMEBOX_E0_8822B 0x01F0
+#define REG_HMEBOX_E1_8822B 0x01F4
+#define REG_HMEBOX_E2_8822B 0x01F8
+#define REG_HMEBOX_E3_8822B 0x01FC
+#define REG_CR_EXT_8822B 0x1100
+#define REG_FWFF_8822B 0x1114
+#define REG_RXFF_PTR_V1_8822B 0x1118
+#define REG_RXFF_WTR_V1_8822B 0x111C
+#define REG_FE2IMR_8822B 0x1120
+#define REG_FE2ISR_8822B 0x1124
+#define REG_FE3IMR_8822B 0x1128
+#define REG_FE3ISR_8822B 0x112C
+#define REG_FE4IMR_8822B 0x1130
+#define REG_FE4ISR_8822B 0x1134
+#define REG_FT1IMR_8822B 0x1138
+#define REG_FT1ISR_8822B 0x113C
+#define REG_SPWR0_8822B 0x1140
+#define REG_SPWR1_8822B 0x1144
+#define REG_SPWR2_8822B 0x1148
+#define REG_SPWR3_8822B 0x114C
+#define REG_POWSEQ_8822B 0x1150
+#define REG_TC7_CTRL_V1_8822B 0x1158
+#define REG_TC8_CTRL_V1_8822B 0x115C
+#define REG_FT2IMR_8822B 0x11E0
+#define REG_FT2ISR_8822B 0x11E4
+#define REG_MSG2_8822B 0x11F0
+#define REG_MSG3_8822B 0x11F4
+#define REG_MSG4_8822B 0x11F8
+#define REG_MSG5_8822B 0x11FC
+#define REG_FIFOPAGE_CTRL_1_8822B 0x0200
+#define REG_FIFOPAGE_CTRL_2_8822B 0x0204
+#define REG_AUTO_LLT_V1_8822B 0x0208
+#define REG_TXDMA_OFFSET_CHK_8822B 0x020C
+#define REG_TXDMA_STATUS_8822B 0x0210
+#define REG_TX_DMA_DBG_8822B 0x0214
+#define REG_TQPNT1_8822B 0x0218
+#define REG_TQPNT2_8822B 0x021C
+#define REG_TQPNT3_8822B 0x0220
+#define REG_TQPNT4_8822B 0x0224
+#define REG_RQPN_CTRL_1_8822B 0x0228
+#define REG_RQPN_CTRL_2_8822B 0x022C
+#define REG_FIFOPAGE_INFO_1_8822B 0x0230
+#define REG_FIFOPAGE_INFO_2_8822B 0x0234
+#define REG_FIFOPAGE_INFO_3_8822B 0x0238
+#define REG_FIFOPAGE_INFO_4_8822B 0x023C
+#define REG_FIFOPAGE_INFO_5_8822B 0x0240
+#define REG_H2C_HEAD_8822B 0x0244
+#define REG_H2C_TAIL_8822B 0x0248
+#define REG_H2C_READ_ADDR_8822B 0x024C
+#define REG_H2C_WR_ADDR_8822B 0x0250
+#define REG_H2C_INFO_8822B 0x0254
+#define REG_RXDMA_AGG_PG_TH_8822B 0x0280
+#define REG_RXPKT_NUM_8822B 0x0284
+#define REG_RXDMA_STATUS_8822B 0x0288
+#define REG_RXDMA_DPR_8822B 0x028C
+#define REG_RXDMA_MODE_8822B 0x0290
+#define REG_C2H_PKT_8822B 0x0294
+#define REG_FWFF_C2H_8822B 0x0298
+#define REG_FWFF_CTRL_8822B 0x029C
+#define REG_FWFF_PKT_INFO_8822B 0x02A0
+#define REG_DDMA_CH0SA_8822B 0x1200
+#define REG_DDMA_CH0DA_8822B 0x1204
+#define REG_DDMA_CH0CTRL_8822B 0x1208
+#define REG_DDMA_CH1SA_8822B 0x1210
+#define REG_DDMA_CH1DA_8822B 0x1214
+#define REG_DDMA_CH1CTRL_8822B 0x1218
+#define REG_DDMA_CH2SA_8822B 0x1220
+#define REG_DDMA_CH2DA_8822B 0x1224
+#define REG_DDMA_CH2CTRL_8822B 0x1228
+#define REG_DDMA_CH3SA_8822B 0x1230
+#define REG_DDMA_CH3DA_8822B 0x1234
+#define REG_DDMA_CH3CTRL_8822B 0x1238
+#define REG_DDMA_CH4SA_8822B 0x1240
+#define REG_DDMA_CH4DA_8822B 0x1244
+#define REG_DDMA_CH4CTRL_8822B 0x1248
+#define REG_DDMA_CH5SA_8822B 0x1250
+#define REG_DDMA_CH5DA_8822B 0x1254
+#define REG_REG_DDMA_CH5CTRL_8822B 0x1258
+#define REG_DDMA_INT_MSK_8822B 0x12E0
+#define REG_DDMA_CHSTATUS_8822B 0x12E8
+#define REG_DDMA_CHKSUM_8822B 0x12F0
+#define REG_DDMA_MONITOR_8822B 0x12FC
+#define REG_PCIE_CTRL_8822B 0x0300
+#define REG_INT_MIG_8822B 0x0304
+#define REG_BCNQ_TXBD_DESA_8822B 0x0308
+#define REG_MGQ_TXBD_DESA_8822B 0x0310
+#define REG_VOQ_TXBD_DESA_8822B 0x0318
+#define REG_VIQ_TXBD_DESA_8822B 0x0320
+#define REG_BEQ_TXBD_DESA_8822B 0x0328
+#define REG_BKQ_TXBD_DESA_8822B 0x0330
+#define REG_RXQ_RXBD_DESA_8822B 0x0338
+#define REG_HI0Q_TXBD_DESA_8822B 0x0340
+#define REG_HI1Q_TXBD_DESA_8822B 0x0348
+#define REG_HI2Q_TXBD_DESA_8822B 0x0350
+#define REG_HI3Q_TXBD_DESA_8822B 0x0358
+#define REG_HI4Q_TXBD_DESA_8822B 0x0360
+#define REG_HI5Q_TXBD_DESA_8822B 0x0368
+#define REG_HI6Q_TXBD_DESA_8822B 0x0370
+#define REG_HI7Q_TXBD_DESA_8822B 0x0378
+#define REG_MGQ_TXBD_NUM_8822B 0x0380
+#define REG_RX_RXBD_NUM_8822B 0x0382
+#define REG_VOQ_TXBD_NUM_8822B 0x0384
+#define REG_VIQ_TXBD_NUM_8822B 0x0386
+#define REG_BEQ_TXBD_NUM_8822B 0x0388
+#define REG_BKQ_TXBD_NUM_8822B 0x038A
+#define REG_HI0Q_TXBD_NUM_8822B 0x038C
+#define REG_HI1Q_TXBD_NUM_8822B 0x038E
+#define REG_HI2Q_TXBD_NUM_8822B 0x0390
+#define REG_HI3Q_TXBD_NUM_8822B 0x0392
+#define REG_HI4Q_TXBD_NUM_8822B 0x0394
+#define REG_HI5Q_TXBD_NUM_8822B 0x0396
+#define REG_HI6Q_TXBD_NUM_8822B 0x0398
+#define REG_HI7Q_TXBD_NUM_8822B 0x039A
+#define REG_TSFTIMER_HCI_8822B 0x039C
+#define REG_BD_RWPTR_CLR_8822B 0x039C
+#define REG_VOQ_TXBD_IDX_8822B 0x03A0
+#define REG_VIQ_TXBD_IDX_8822B 0x03A4
+#define REG_BEQ_TXBD_IDX_8822B 0x03A8
+#define REG_BKQ_TXBD_IDX_8822B 0x03AC
+#define REG_MGQ_TXBD_IDX_8822B 0x03B0
+#define REG_RXQ_RXBD_IDX_8822B 0x03B4
+#define REG_HI0Q_TXBD_IDX_8822B 0x03B8
+#define REG_HI1Q_TXBD_IDX_8822B 0x03BC
+#define REG_HI2Q_TXBD_IDX_8822B 0x03C0
+#define REG_HI3Q_TXBD_IDX_8822B 0x03C4
+#define REG_HI4Q_TXBD_IDX_8822B 0x03C8
+#define REG_HI5Q_TXBD_IDX_8822B 0x03CC
+#define REG_HI6Q_TXBD_IDX_8822B 0x03D0
+#define REG_HI7Q_TXBD_IDX_8822B 0x03D4
+#define REG_DBG_SEL_V1_8822B 0x03D8
+#define REG_PCIE_HRPWM1_V1_8822B 0x03D9
+#define REG_PCIE_HCPWM1_V1_8822B 0x03DA
+#define REG_PCIE_CTRL2_8822B 0x03DB
+#define REG_PCIE_HRPWM2_V1_8822B 0x03DC
+#define REG_PCIE_HCPWM2_V1_8822B 0x03DE
+#define REG_PCIE_H2C_MSG_V1_8822B 0x03E0
+#define REG_PCIE_C2H_MSG_V1_8822B 0x03E4
+#define REG_DBI_WDATA_V1_8822B 0x03E8
+#define REG_DBI_RDATA_V1_8822B 0x03EC
+#define REG_DBI_FLAG_V1_8822B 0x03F0
+#define REG_MDIO_V1_8822B 0x03F4
+#define REG_PCIE_MIX_CFG_8822B 0x03F8
+#define REG_HCI_MIX_CFG_8822B 0x03FC
+#define REG_STC_INT_CS_8822B 0x1300
+#define REG_ST_INT_CFG_8822B 0x1304
+#define REG_CMU_DLY_CTRL_8822B 0x1310
+#define REG_CMU_DLY_CFG_8822B 0x1314
+#define REG_H2CQ_TXBD_DESA_8822B 0x1320
+#define REG_H2CQ_TXBD_NUM_8822B 0x1328
+#define REG_H2CQ_TXBD_IDX_8822B 0x132C
+#define REG_H2CQ_CSR_8822B 0x1330
+#define REG_CHANGE_PCIE_SPEED_8822B 0x1350
+#define REG_OLD_DEHANG_8822B 0x13F4
+#define REG_Q0_INFO_8822B 0x0400
+#define REG_Q1_INFO_8822B 0x0404
+#define REG_Q2_INFO_8822B 0x0408
+#define REG_Q3_INFO_8822B 0x040C
+#define REG_MGQ_INFO_8822B 0x0410
+#define REG_HIQ_INFO_8822B 0x0414
+#define REG_BCNQ_INFO_8822B 0x0418
+#define REG_TXPKT_EMPTY_8822B 0x041A
+#define REG_CPU_MGQ_INFO_8822B 0x041C
+#define REG_FWHW_TXQ_CTRL_8822B 0x0420
+#define REG_DATAFB_SEL_8822B 0x0423
+#define REG_BCNQ_BDNY_V1_8822B 0x0424
+#define REG_LIFETIME_EN_8822B 0x0426
+#define REG_SPEC_SIFS_8822B 0x0428
+#define REG_RETRY_LIMIT_8822B 0x042A
+#define REG_TXBF_CTRL_8822B 0x042C
+#define REG_DARFRC_8822B 0x0430
+#define REG_RARFRC_8822B 0x0438
+#define REG_RRSR_8822B 0x0440
+#define REG_ARFR0_8822B 0x0444
+#define REG_ARFR1_V1_8822B 0x044C
+#define REG_CCK_CHECK_8822B 0x0454
+#define REG_AMPDU_MAX_TIME_V1_8822B 0x0455
+#define REG_BCNQ1_BDNY_V1_8822B 0x0456
+#define REG_AMPDU_MAX_LENGTH_8822B 0x0458
+#define REG_ACQ_STOP_8822B 0x045C
+#define REG_NDPA_RATE_8822B 0x045D
+#define REG_TX_HANG_CTRL_8822B 0x045E
+#define REG_NDPA_OPT_CTRL_8822B 0x045F
+#define REG_RD_RESP_PKT_TH_8822B 0x0463
+#define REG_CMDQ_INFO_8822B 0x0464
+#define REG_Q4_INFO_8822B 0x0468
+#define REG_Q5_INFO_8822B 0x046C
+#define REG_Q6_INFO_8822B 0x0470
+#define REG_Q7_INFO_8822B 0x0474
+#define REG_WMAC_LBK_BUF_HD_V1_8822B 0x0478
+#define REG_MGQ_BDNY_V1_8822B 0x047A
+#define REG_TXRPT_CTRL_8822B 0x047C
+#define REG_INIRTS_RATE_SEL_8822B 0x0480
+#define REG_BASIC_CFEND_RATE_8822B 0x0481
+#define REG_STBC_CFEND_RATE_8822B 0x0482
+#define REG_DATA_SC_8822B 0x0483
+#define REG_MACID_SLEEP3_8822B 0x0484
+#define REG_MACID_SLEEP1_8822B 0x0488
+#define REG_ARFR2_V1_8822B 0x048C
+#define REG_ARFR3_V1_8822B 0x0494
+#define REG_ARFR4_8822B 0x049C
+#define REG_ARFR5_8822B 0x04A4
+#define REG_TXRPT_START_OFFSET_8822B 0x04AC
+#define REG_POWER_STAGE1_8822B 0x04B4
+#define REG_POWER_STAGE2_8822B 0x04B8
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8822B 0x04BC
+#define REG_PKT_LIFE_TIME_8822B 0x04C0
+#define REG_STBC_SETTING_8822B 0x04C4
+#define REG_STBC_SETTING2_8822B 0x04C5
+#define REG_QUEUE_CTRL_8822B 0x04C6
+#define REG_SINGLE_AMPDU_CTRL_8822B 0x04C7
+#define REG_PROT_MODE_CTRL_8822B 0x04C8
+#define REG_BAR_MODE_CTRL_8822B 0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8822B 0x04CF
+#define REG_MACID_SLEEP2_8822B 0x04D0
+#define REG_MACID_SLEEP_8822B 0x04D4
+#define REG_HW_SEQ0_8822B 0x04D8
+#define REG_HW_SEQ1_8822B 0x04DA
+#define REG_HW_SEQ2_8822B 0x04DC
+#define REG_HW_SEQ3_8822B 0x04DE
+#define REG_NULL_PKT_STATUS_V1_8822B 0x04E0
+#define REG_PTCL_ERR_STATUS_8822B 0x04E2
+#define REG_NULL_PKT_STATUS_EXTEND_8822B 0x04E3
+#define REG_VIDEO_ENHANCEMENT_FUN_8822B 0x04E4
+#define REG_BT_POLLUTE_PKT_CNT_8822B 0x04E8
+#define REG_PTCL_DBG_8822B 0x04EC
+#define REG_CPUMGQ_TIMER_CTRL2_8822B 0x04F4
+#define REG_DUMMY_PAGE4_V1_8822B 0x04FC
+#define REG_MOREDATA_8822B 0x04FE
+#define REG_Q0_Q1_INFO_8822B 0x1400
+#define REG_Q2_Q3_INFO_8822B 0x1404
+#define REG_Q4_Q5_INFO_8822B 0x1408
+#define REG_Q6_Q7_INFO_8822B 0x140C
+#define REG_MGQ_HIQ_INFO_8822B 0x1410
+#define REG_CMDQ_BCNQ_INFO_8822B 0x1414
+#define REG_USEREG_SETTING_8822B 0x1420
+#define REG_AESIV_SETTING_8822B 0x1424
+#define REG_BF0_TIME_SETTING_8822B 0x1428
+#define REG_BF1_TIME_SETTING_8822B 0x142C
+#define REG_BF_TIMEOUT_EN_8822B 0x1430
+#define REG_MACID_RELEASE0_8822B 0x1434
+#define REG_MACID_RELEASE1_8822B 0x1438
+#define REG_MACID_RELEASE2_8822B 0x143C
+#define REG_MACID_RELEASE3_8822B 0x1440
+#define REG_MACID_RELEASE_SETTING_8822B 0x1444
+#define REG_FAST_EDCA_VOVI_SETTING_8822B 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING_8822B 0x144C
+#define REG_MACID_DROP0_8822B 0x1450
+#define REG_MACID_DROP1_8822B 0x1454
+#define REG_MACID_DROP2_8822B 0x1458
+#define REG_MACID_DROP3_8822B 0x145C
+#define REG_R_MACID_RELEASE_SUCCESS_0_8822B 0x1460
+#define REG_R_MACID_RELEASE_SUCCESS_1_8822B 0x1464
+#define REG_R_MACID_RELEASE_SUCCESS_2_8822B 0x1468
+#define REG_R_MACID_RELEASE_SUCCESS_3_8822B 0x146C
+#define REG_MGG_FIFO_CRTL_8822B 0x1470
+#define REG_MGG_FIFO_INT_8822B 0x1474
+#define REG_MGG_FIFO_LIFETIME_8822B 0x1478
+#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B 0x147C
+#define REG_SHCUT_SETTING_8822B 0x1480
+#define REG_SHCUT_LLC_ETH_TYPE0_8822B 0x1484
+#define REG_SHCUT_LLC_ETH_TYPE1_8822B 0x1488
+#define REG_SHCUT_LLC_OUI0_8822B 0x148C
+#define REG_SHCUT_LLC_OUI1_8822B 0x1490
+#define REG_SHCUT_LLC_OUI2_8822B 0x1494
+#define REG_SHCUT_LLC_OUI3_8822B 0x1498
+#define REG_MU_TX_CTL_8822B 0x14C0
+#define REG_MU_TX_CTL_8822B 0x14C0
+#define REG_MU_STA_GID_VLD_8822B 0x14C4
+#define REG_MU_STA_GID_VLD_8822B 0x14C4
+#define REG_MU_STA_USER_POS_INFO_8822B 0x14C8
+#define REG_MU_STA_USER_POS_INFO_8822B 0x14C8
+#define REG_MU_TRX_DBG_CNT_8822B 0x14D0
+#define REG_MU_TRX_DBG_CNT_8822B 0x14D0
+#define REG_EDCA_VO_PARAM_8822B 0x0500
+#define REG_EDCA_VI_PARAM_8822B 0x0504
+#define REG_EDCA_BE_PARAM_8822B 0x0508
+#define REG_EDCA_BK_PARAM_8822B 0x050C
+#define REG_BCNTCFG_8822B 0x0510
+#define REG_PIFS_8822B 0x0512
+#define REG_RDG_PIFS_8822B 0x0513
+#define REG_SIFS_8822B 0x0514
+#define REG_TSFTR_SYN_OFFSET_8822B 0x0518
+#define REG_AGGR_BREAK_TIME_8822B 0x051A
+#define REG_SLOT_8822B 0x051B
+#define REG_TX_PTCL_CTRL_8822B 0x0520
+#define REG_TXPAUSE_8822B 0x0522
+#define REG_DIS_TXREQ_CLR_8822B 0x0523
+#define REG_RD_CTRL_8822B 0x0524
+#define REG_MBSSID_CTRL_8822B 0x0526
+#define REG_P2PPS_CTRL_8822B 0x0527
+#define REG_PKT_LIFETIME_CTRL_8822B 0x0528
+#define REG_P2PPS_SPEC_STATE_8822B 0x052B
+#define REG_TXOP_LIMIT_CTRL_8822B 0x052C
+#define REG_BAR_TX_CTRL_8822B 0x0530
+#define REG_P2PON_DIS_TXTIME_8822B 0x0531
+#define REG_QUEUE_INCOL_THR_8822B 0x0538
+#define REG_QUEUE_INCOL_EN_8822B 0x053C
+#define REG_TBTT_PROHIBIT_8822B 0x0540
+#define REG_P2PPS_STATE_8822B 0x0543
+#define REG_RD_NAV_NXT_8822B 0x0544
+#define REG_NAV_PROT_LEN_8822B 0x0546
+#define REG_BCN_CTRL_8822B 0x0550
+#define REG_BCN_CTRL_CLINT0_8822B 0x0551
+#define REG_MBID_NUM_8822B 0x0552
+#define REG_DUAL_TSF_RST_8822B 0x0553
+#define REG_MBSSID_BCN_SPACE_8822B 0x0554
+#define REG_DRVERLYINT_8822B 0x0558
+#define REG_BCNDMATIM_8822B 0x0559
+#define REG_ATIMWND_8822B 0x055A
+#define REG_USTIME_TSF_8822B 0x055C
+#define REG_BCN_MAX_ERR_8822B 0x055D
+#define REG_RXTSF_OFFSET_CCK_8822B 0x055E
+#define REG_RXTSF_OFFSET_OFDM_8822B 0x055F
+#define REG_TSFTR_8822B 0x0560
+#define REG_FREERUN_CNT_8822B 0x0568
+#define REG_ATIMWND1_V1_8822B 0x0570
+#define REG_TBTT_PROHIBIT_INFRA_8822B 0x0571
+#define REG_CTWND_8822B 0x0572
+#define REG_BCNIVLCUNT_8822B 0x0573
+#define REG_BCNDROPCTRL_8822B 0x0574
+#define REG_HGQ_TIMEOUT_PERIOD_8822B 0x0575
+#define REG_TXCMD_TIMEOUT_PERIOD_8822B 0x0576
+#define REG_MISC_CTRL_8822B 0x0577
+#define REG_BCN_CTRL_CLINT1_8822B 0x0578
+#define REG_BCN_CTRL_CLINT2_8822B 0x0579
+#define REG_BCN_CTRL_CLINT3_8822B 0x057A
+#define REG_EXTEND_CTRL_8822B 0x057B
+#define REG_P2PPS1_SPEC_STATE_8822B 0x057C
+#define REG_P2PPS1_STATE_8822B 0x057D
+#define REG_P2PPS2_SPEC_STATE_8822B 0x057E
+#define REG_P2PPS2_STATE_8822B 0x057F
+#define REG_PS_TIMER0_8822B 0x0580
+#define REG_PS_TIMER1_8822B 0x0584
+#define REG_PS_TIMER2_8822B 0x0588
+#define REG_TBTT_CTN_AREA_8822B 0x058C
+#define REG_FORCE_BCN_IFS_8822B 0x058E
+#define REG_TXOP_MIN_8822B 0x0590
+#define REG_PRE_BKF_TIME_8822B 0x0592
+#define REG_CROSS_TXOP_CTRL_8822B 0x0593
+#define REG_ATIMWND2_8822B 0x05A0
+#define REG_ATIMWND3_8822B 0x05A1
+#define REG_ATIMWND4_8822B 0x05A2
+#define REG_ATIMWND5_8822B 0x05A3
+#define REG_ATIMWND6_8822B 0x05A4
+#define REG_ATIMWND7_8822B 0x05A5
+#define REG_ATIMUGT_8822B 0x05A6
+#define REG_HIQ_NO_LMT_EN_8822B 0x05A7
+#define REG_DTIM_COUNTER_ROOT_8822B 0x05A8
+#define REG_DTIM_COUNTER_VAP1_8822B 0x05A9
+#define REG_DTIM_COUNTER_VAP2_8822B 0x05AA
+#define REG_DTIM_COUNTER_VAP3_8822B 0x05AB
+#define REG_DTIM_COUNTER_VAP4_8822B 0x05AC
+#define REG_DTIM_COUNTER_VAP5_8822B 0x05AD
+#define REG_DTIM_COUNTER_VAP6_8822B 0x05AE
+#define REG_DTIM_COUNTER_VAP7_8822B 0x05AF
+#define REG_DIS_ATIM_8822B 0x05B0
+#define REG_EARLY_128US_8822B 0x05B1
+#define REG_P2PPS1_CTRL_8822B 0x05B2
+#define REG_P2PPS2_CTRL_8822B 0x05B3
+#define REG_TIMER0_SRC_SEL_8822B 0x05B4
+#define REG_NOA_UNIT_SEL_8822B 0x05B5
+#define REG_P2POFF_DIS_TXTIME_8822B 0x05B7
+#define REG_MBSSID_BCN_SPACE2_8822B 0x05B8
+#define REG_MBSSID_BCN_SPACE3_8822B 0x05BC
+#define REG_ACMHWCTRL_8822B 0x05C0
+#define REG_ACMRSTCTRL_8822B 0x05C1
+#define REG_ACMAVG_8822B 0x05C2
+#define REG_VO_ADMTIME_8822B 0x05C4
+#define REG_VI_ADMTIME_8822B 0x05C6
+#define REG_BE_ADMTIME_8822B 0x05C8
+#define REG_EDCA_RANDOM_GEN_8822B 0x05CC
+#define REG_TXCMD_NOA_SEL_8822B 0x05CF
+#define REG_NOA_PARAM_8822B 0x05E0
+#define REG_P2P_RST_8822B 0x05F0
+#define REG_SCHEDULER_RST_8822B 0x05F1
+#define REG_SCH_TXCMD_8822B 0x05F8
+#define REG_PAGE5_DUMMY_8822B 0x05FC
+#define REG_CPUMGQ_TX_TIMER_8822B 0x1500
+#define REG_PS_TIMER_A_8822B 0x1504
+#define REG_PS_TIMER_B_8822B 0x1508
+#define REG_PS_TIMER_C_8822B 0x150C
+#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8822B 0x1510
+#define REG_CPUMGQ_TX_TIMER_EARLY_8822B 0x1514
+#define REG_PS_TIMER_A_EARLY_8822B 0x1515
+#define REG_PS_TIMER_B_EARLY_8822B 0x1516
+#define REG_PS_TIMER_C_EARLY_8822B 0x1517
+#define REG_CPUMGQ_PARAMETER_8822B 0x1518
+#define REG_WMAC_CR_8822B 0x0600
+#define REG_WMAC_FWPKT_CR_8822B 0x0601
+#define REG_BWOPMODE_8822B 0x0603
+#define REG_TCR_8822B 0x0604
+#define REG_RCR_8822B 0x0608
+#define REG_RX_PKT_LIMIT_8822B 0x060C
+#define REG_RX_DLK_TIME_8822B 0x060D
+#define REG_RX_DRVINFO_SZ_8822B 0x060F
+#define REG_MACID_8822B 0x0610
+#define REG_BSSID_8822B 0x0618
+#define REG_MAR_8822B 0x0620
+#define REG_MBIDCAMCFG_1_8822B 0x0628
+#define REG_MBIDCAMCFG_2_8822B 0x062C
+#define REG_WMAC_TCR_TSFT_OFS_8822B 0x0630
+#define REG_UDF_THSD_8822B 0x0632
+#define REG_ZLD_NUM_8822B 0x0633
+#define REG_STMP_THSD_8822B 0x0634
+#define REG_WMAC_TXTIMEOUT_8822B 0x0635
+#define REG_MCU_TEST_2_V1_8822B 0x0636
+#define REG_USTIME_EDCA_8822B 0x0638
+#define REG_MAC_SPEC_SIFS_8822B 0x063A
+#define REG_RESP_SIFS_CCK_8822B 0x063C
+#define REG_RESP_SIFS_OFDM_8822B 0x063E
+#define REG_ACKTO_8822B 0x0640
+#define REG_CTS2TO_8822B 0x0641
+#define REG_EIFS_8822B 0x0642
+#define REG_NAV_CTRL_8822B 0x0650
+#define REG_BACAMCMD_8822B 0x0654
+#define REG_BACAMCONTENT_8822B 0x0658
+#define REG_LBDLY_8822B 0x0660
+#define REG_WMAC_BACAM_RPMEN_8822B 0x0661
+#define REG_TX_RX_8822B 0x0662
+#define REG_WMAC_BITMAP_CTL_8822B 0x0663
+#define REG_RXERR_RPT_8822B 0x0664
+#define REG_WMAC_TRXPTCL_CTL_8822B 0x0668
+#define REG_CAMCMD_8822B 0x0670
+#define REG_CAMWRITE_8822B 0x0674
+#define REG_CAMREAD_8822B 0x0678
+#define REG_CAMDBG_8822B 0x067C
+#define REG_SECCFG_8822B 0x0680
+#define REG_RXFILTER_CATEGORY_1_8822B 0x0682
+#define REG_RXFILTER_ACTION_1_8822B 0x0683
+#define REG_RXFILTER_CATEGORY_2_8822B 0x0684
+#define REG_RXFILTER_ACTION_2_8822B 0x0685
+#define REG_RXFILTER_CATEGORY_3_8822B 0x0686
+#define REG_RXFILTER_ACTION_3_8822B 0x0687
+#define REG_RXFLTMAP3_8822B 0x0688
+#define REG_RXFLTMAP4_8822B 0x068A
+#define REG_RXFLTMAP5_8822B 0x068C
+#define REG_RXFLTMAP6_8822B 0x068E
+#define REG_WOW_CTRL_8822B 0x0690
+#define REG_NAN_RX_TSF_FILTER_8822B 0x0691
+#define REG_PS_RX_INFO_8822B 0x0692
+#define REG_WMMPS_UAPSD_TID_8822B 0x0693
+#define REG_LPNAV_CTRL_8822B 0x0694
+#define REG_WKFMCAM_CMD_8822B 0x0698
+#define REG_WKFMCAM_RWD_8822B 0x069C
+#define REG_RXFLTMAP0_8822B 0x06A0
+#define REG_RXFLTMAP1_8822B 0x06A2
+#define REG_RXFLTMAP2_8822B 0x06A4
+#define REG_BCN_PSR_RPT_8822B 0x06A8
+#define REG_FLC_RPC_8822B 0x06AC
+#define REG_FLC_RPCT_8822B 0x06AD
+#define REG_FLC_PTS_8822B 0x06AE
+#define REG_FLC_TRPC_8822B 0x06AF
+#define REG_RXPKTMON_CTRL_8822B 0x06B0
+#define REG_STATE_MON_8822B 0x06B4
+#define REG_ERROR_MON_8822B 0x06B8
+#define REG_SEARCH_MACID_8822B 0x06BC
+#define REG_BT_COEX_TABLE_8822B 0x06C0
+#define REG_RXCMD_0_8822B 0x06D0
+#define REG_RXCMD_1_8822B 0x06D4
+#define REG_WMAC_RESP_TXINFO_8822B 0x06D8
+#define REG_BBPSF_CTRL_8822B 0x06DC
+#define REG_P2P_RX_BCN_NOA_8822B 0x06E0
+#define REG_ASSOCIATED_BFMER0_INFO_8822B 0x06E4
+#define REG_ASSOCIATED_BFMER1_INFO_8822B 0x06EC
+#define REG_TX_CSI_RPT_PARAM_BW20_8822B 0x06F4
+#define REG_TX_CSI_RPT_PARAM_BW40_8822B 0x06F8
+#define REG_TX_CSI_RPT_PARAM_BW80_8822B 0x06FC
+#define REG_BCN_PSR_RPT2_8822B 0x1600
+#define REG_BCN_PSR_RPT3_8822B 0x1604
+#define REG_BCN_PSR_RPT4_8822B 0x1608
+#define REG_A1_ADDR_MASK_8822B 0x160C
+#define REG_MACID2_8822B 0x1620
+#define REG_BSSID2_8822B 0x1628
+#define REG_MACID3_8822B 0x1630
+#define REG_BSSID3_8822B 0x1638
+#define REG_MACID4_8822B 0x1640
+#define REG_BSSID4_8822B 0x1648
+#define REG_NOA_REPORT_8822B 0x1650
+#define REG_PWRBIT_SETTING_8822B 0x1660
+#define REG_WMAC_MU_BF_OPTION_8822B 0x167C
+#define REG_WMAC_MU_ARB_8822B 0x167E
+#define REG_WMAC_MU_OPTION_8822B 0x167F
+#define REG_WMAC_MU_BF_CTL_8822B 0x1680
+#define REG_WMAC_MU_BFRPT_PARA_8822B 0x1682
+#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8822B 0x1684
+#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8822B 0x1686
+#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8822B 0x1688
+#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8822B 0x168A
+#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8822B 0x168C
+#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8822B 0x168E
+#define REG_TRANSMIT_ADDRSS_0_8822B 0x16A0
+#define REG_TRANSMIT_ADDRSS_1_8822B 0x16A8
+#define REG_TRANSMIT_ADDRSS_2_8822B 0x16B0
+#define REG_TRANSMIT_ADDRSS_3_8822B 0x16B8
+#define REG_TRANSMIT_ADDRSS_4_8822B 0x16C0
+#define REG_MACID1_8822B 0x0700
+#define REG_BSSID1_8822B 0x0708
+#define REG_BCN_PSR_RPT1_8822B 0x0710
+#define REG_ASSOCIATED_BFMEE_SEL_8822B 0x0714
+#define REG_SND_PTCL_CTRL_8822B 0x0718
+#define REG_RX_CSI_RPT_INFO_8822B 0x071C
+#define REG_NS_ARP_CTRL_8822B 0x0720
+#define REG_NS_ARP_INFO_8822B 0x0724
+#define REG_BEAMFORMING_INFO_NSARP_V1_8822B 0x0728
+#define REG_BEAMFORMING_INFO_NSARP_8822B 0x072C
+#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8822B 0x0750
+#define REG_WMAC_SWAES_CFG_8822B 0x0760
+#define REG_BT_COEX_V2_8822B 0x0762
+#define REG_BT_COEX_8822B 0x0764
+#define REG_WLAN_ACT_MASK_CTRL_8822B 0x0768
+#define REG_BT_COEX_ENHANCED_INTR_CTRL_8822B 0x076E
+#define REG_BT_ACT_STATISTICS_8822B 0x0770
+#define REG_BT_STATISTICS_CONTROL_REGISTER_8822B 0x0778
+#define REG_BT_STATUS_REPORT_REGISTER_8822B 0x077C
+#define REG_BT_INTERRUPT_CONTROL_REGISTER_8822B 0x0780
+#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8822B 0x0784
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8822B 0x0785
+#define REG_BT_INTERRUPT_STATUS_REGISTER_8822B 0x078F
+#define REG_BT_TDMA_TIME_REGISTER_8822B 0x0790
+#define REG_BT_ACT_REGISTER_8822B 0x0794
+#define REG_OBFF_CTRL_BASIC_8822B 0x0798
+#define REG_OBFF_CTRL2_TIMER_8822B 0x079C
+#define REG_LTR_CTRL_BASIC_8822B 0x07A0
+#define REG_LTR_CTRL2_TIMER_THRESHOLD_8822B 0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8822B 0x07A8
+#define REG_LTR_ACTIVE_LATENCY_V1_8822B 0x07AC
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8822B 0x07B0
+#define REG_WMAC_PKTCNT_RWD_8822B 0x07B8
+#define REG_WMAC_PKTCNT_CTRL_8822B 0x07BC
+#define REG_IQ_DUMP_8822B 0x07C0
+#define REG_WMAC_FTM_CTL_8822B 0x07CC
+#define REG_WMAC_IQ_MDPK_FUNC_8822B 0x07CE
+#define REG_WMAC_OPTION_FUNCTION_8822B 0x07D0
+#define REG_RX_FILTER_FUNCTION_8822B 0x07DA
+#define REG_NDP_SIG_8822B 0x07E0
+#define REG_TXCMD_INFO_FOR_RSP_PKT_8822B 0x07E4
+#define REG_RTS_ADDRESS_0_8822B 0x07F0
+#define REG_RTS_ADDRESS_1_8822B 0x07F8
+#define REG__RPFM_MAP1_8822B 0x07FE
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8822B 0x1700
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8822B 0x1704
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8822B 0x1708
+#define REG_SDIO_TX_CTRL_8822B 0x10250000
+#define REG_SDIO_HIMR_8822B 0x10250014
+#define REG_SDIO_HISR_8822B 0x10250018
+#define REG_SDIO_RX_REQ_LEN_8822B 0x1025001C
+#define REG_SDIO_FREE_TXPG_SEQ_V1_8822B 0x1025001F
+#define REG_SDIO_FREE_TXPG_8822B 0x10250020
+#define REG_SDIO_FREE_TXPG2_8822B 0x10250024
+#define REG_SDIO_OQT_FREE_TXPG_V1_8822B 0x10250028
+#define REG_SDIO_HTSFR_INFO_8822B 0x10250030
+#define REG_SDIO_HCPWM1_V2_8822B 0x10250038
+#define REG_SDIO_HCPWM2_V2_8822B 0x1025003A
+#define REG_SDIO_INDIRECT_REG_CFG_8822B 0x10250040
+#define REG_SDIO_INDIRECT_REG_DATA_8822B 0x10250044
+#define REG_SDIO_H2C_8822B 0x10250060
+#define REG_SDIO_C2H_8822B 0x10250064
+#define REG_SDIO_HRPWM1_8822B 0x10250080
+#define REG_SDIO_HRPWM2_8822B 0x10250082
+#define REG_SDIO_HPS_CLKR_8822B 0x10250084
+#define REG_SDIO_BUS_CTRL_8822B 0x10250085
+#define REG_SDIO_HSUS_CTRL_8822B 0x10250086
+#define REG_SDIO_RESPONSE_TIMER_8822B 0x10250088
+#define REG_SDIO_CMD_CRC_8822B 0x1025008A
+#define REG_SDIO_HSISR_8822B 0x10250090
+#define REG_SDIO_ERR_RPT_8822B 0x102500C0
+#define REG_SDIO_CMD_ERRCNT_8822B 0x102500C2
+#define REG_SDIO_DATA_ERRCNT_8822B 0x102500C3
+#define REG_SDIO_CMD_ERR_CONTENT_8822B 0x102500C4
+#define REG_SDIO_CRC_ERR_IDX_8822B 0x102500C9
+#define REG_SDIO_DATA_CRC_8822B 0x102500CA
+#define REG_SDIO_DATA_REPLY_TIME_8822B 0x102500CB
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8822c.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8822c.h
new file mode 100644
index 000000000000..b71418f206bd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_reg_8822c.h
@@ -0,0 +1,875 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 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_HALMAC_REG_8822C_H
+#define __INC_HALMAC_REG_8822C_H
+
+#define REG_SYS_ISO_CTRL_8822C 0x0000
+#define REG_SYS_FUNC_EN_8822C 0x0002
+#define REG_SYS_PW_CTRL_8822C 0x0004
+#define REG_SYS_CLK_CTRL_8822C 0x0008
+#define REG_SYS_EEPROM_CTRL_8822C 0x000A
+#define REG_EE_VPD_8822C 0x000C
+#define REG_SYS_SWR_CTRL1_8822C 0x0010
+#define REG_SYS_SWR_CTRL2_8822C 0x0014
+#define REG_SYS_SWR_CTRL3_8822C 0x0018
+#define REG_RSV_CTRL_8822C 0x001C
+#define REG_RF_CTRL_8822C 0x001F
+#define REG_AFE_LDO_CTRL_8822C 0x0020
+#define REG_AFE_CTRL1_8822C 0x0024
+#define REG_ANAPARSW_POW_MAC_8822C 0x0028
+#define REG_ANAPARLDO_POW_MAC_8822C 0x0029
+#define REG_ANAPAR_POW_MAC_8822C 0x002A
+#define REG_ANAPAR_POW_XTAL_8822C 0x002B
+#define REG_ANAPARLDO_MAC_8822C 0x002C
+#define REG_EFUSE_CTRL_8822C 0x0030
+#define REG_LDO_EFUSE_CTRL_8822C 0x0034
+#define REG_PWR_OPTION_CTRL_8822C 0x0038
+#define REG_CAL_TIMER_8822C 0x003C
+#define REG_ACLK_MON_8822C 0x003E
+#define REG_GPIO_MUXCFG_2_8822C 0x003F
+#define REG_GPIO_MUXCFG_8822C 0x0040
+#define REG_GPIO_PIN_CTRL_8822C 0x0044
+#define REG_GPIO_INTM_8822C 0x0048
+#define REG_LED_CFG_8822C 0x004C
+#define REG_FSIMR_8822C 0x0050
+#define REG_FSISR_8822C 0x0054
+#define REG_HSIMR_8822C 0x0058
+#define REG_HSISR_8822C 0x005C
+#define REG_GPIO_EXT_CTRL_8822C 0x0060
+#define REG_PAD_CTRL1_8822C 0x0064
+#define REG_WL_BT_PWR_CTRL_8822C 0x0068
+#define REG_SDM_DEBUG_8822C 0x006C
+#define REG_SYS_SDIO_CTRL_8822C 0x0070
+#define REG_HCI_OPT_CTRL_8822C 0x0074
+#define REG_HCI_BG_CTRL_8822C 0x0078
+#define REG_HCI_LDO_CTRL_8822C 0x007A
+#define REG_LDO_SWR_CTRL_8822C 0x007C
+#define REG_MCUFW_CTRL_8822C 0x0080
+#define REG_MCU_TST_CFG_8822C 0x0084
+#define REG_HMEBOX_E0_E1_8822C 0x0088
+#define REG_HMEBOX_E2_E3_8822C 0x008C
+#define REG_WLLPS_CTRL_8822C 0x0090
+#define REG_GPIO_DEBOUNCE_CTRL_8822C 0x0098
+#define REG_RPWM2_8822C 0x009C
+#define REG_SYSON_FSM_MON_8822C 0x00A0
+#define REG_PMC_DBG_CTRL1_8822C 0x00A8
+#define REG_HIMR0_8822C 0x00B0
+#define REG_HISR0_8822C 0x00B4
+#define REG_HIMR1_8822C 0x00B8
+#define REG_HISR1_8822C 0x00BC
+#define REG_DBG_PORT_SEL_8822C 0x00C0
+#define REG_PAD_CTRL2_8822C 0x00C4
+#define REG_PMC_DBG_CTRL2_8822C 0x00CC
+#define REG_BIST_CTRL_8822C 0x00D0
+#define REG_BIST_RPT_8822C 0x00D4
+#define REG_MEM_CTRL_8822C 0x00D8
+#define REG_USB_SIE_INTF_8822C 0x00E0
+#define REG_PCIE_MIO_INTF_8822C 0x00E4
+#define REG_PCIE_MIO_INTD_8822C 0x00E8
+#define REG_WLRF1_8822C 0x00EC
+#define REG_SYS_CFG1_8822C 0x00F0
+#define REG_SYS_STATUS1_8822C 0x00F4
+#define REG_SYS_STATUS2_8822C 0x00F8
+#define REG_SYS_CFG2_8822C 0x00FC
+#define REG_SYS_CFG3_8822C 0x1000
+#define REG_ANAPARSW_MAC_0_8822C 0x1010
+#define REG_ANAPARSW_MAC_1_8822C 0x1014
+#define REG_ANAPAR_MAC_0_8822C 0x1018
+#define REG_ANAPAR_MAC_1_8822C 0x101C
+#define REG_ANAPAR_MAC_2_8822C 0x1020
+#define REG_ANAPAR_XTAL_0_8822C 0x1040
+#define REG_ANAPAR_XTAL_1_8822C 0x1044
+#define REG_ANAPAR_XTAL_2_8822C 0x1048
+#define REG_ANAPAR_XTAL_3_8822C 0x104C
+#define REG_ANAPAR_XTAL_AACK_0_8822C 0x1054
+#define REG_ANAPAR_XTAL_AACK_1_8822C 0x1058
+#define REG_ANAPAR_XTAL_MODE_DECODER_8822C 0x1064
+#define REG_SYS_CFG5_8822C 0x1070
+#define REG_CPU_DMEM_CON_8822C 0x1080
+#define REG_BOOT_REASON_8822C 0x1088
+#define REG_HIMR2_8822C 0x10B0
+#define REG_HISR2_8822C 0x10B4
+#define REG_HIMR3_8822C 0x10B8
+#define REG_HISR3_8822C 0x10BC
+#define REG_SW_MDIO_8822C 0x10C0
+#define REG_H2C_PKT_READADDR_8822C 0x10D0
+#define REG_H2C_PKT_WRITEADDR_8822C 0x10D4
+#define REG_MEM_PWR_CRTL_8822C 0x10D8
+#define REG_FW_DBG6_8822C 0x10F8
+#define REG_FW_DBG7_8822C 0x10FC
+#define REG_CR_8822C 0x0100
+#define REG_PG_SIZE_8822C 0x0104
+#define REG_PKT_BUFF_ACCESS_CTRL_8822C 0x0106
+#define REG_TSF_CLK_STATE_8822C 0x0108
+#define REG_TXDMA_PQ_MAP_8822C 0x010C
+#define REG_TRXFF_BNDY_8822C 0x0114
+#define REG_PTA_I2C_MBOX_8822C 0x0118
+#define REG_RXFF_BNDY_8822C 0x011C
+#define REG_FE1IMR_8822C 0x0120
+#define REG_FE1ISR_8822C 0x0124
+#define REG_CPWM_8822C 0x012C
+#define REG_FWIMR_8822C 0x0130
+#define REG_FWISR_8822C 0x0134
+#define REG_FTIMR_8822C 0x0138
+#define REG_FTISR_8822C 0x013C
+#define REG_PKTBUF_DBG_CTRL_8822C 0x0140
+#define REG_PKTBUF_DBG_DATA_L_8822C 0x0144
+#define REG_PKTBUF_DBG_DATA_H_8822C 0x0148
+#define REG_CPWM2_8822C 0x014C
+#define REG_TC0_CTRL_8822C 0x0150
+#define REG_TC1_CTRL_8822C 0x0154
+#define REG_TC2_CTRL_8822C 0x0158
+#define REG_TC3_CTRL_8822C 0x015C
+#define REG_TC4_CTRL_8822C 0x0160
+#define REG_TCUNIT_BASE_8822C 0x0164
+#define REG_TC5_CTRL_8822C 0x0168
+#define REG_TC6_CTRL_8822C 0x016C
+#define REG_MBIST_DRF_FAIL_8822C 0x0170
+#define REG_MBIST_START_PAUSE_8822C 0x0174
+#define REG_MBIST_DONE_8822C 0x0178
+#define REG_MBIST_READ_BIST_RPT_8822C 0x017C
+#define REG_AES_DECRPT_DATA_8822C 0x0180
+#define REG_AES_DECRPT_CFG_8822C 0x0184
+#define REG_HIOE_CTRL_8822C 0x0188
+#define REG_HIOE_CFG_FILE_8822C 0x018C
+#define REG_TMETER_8822C 0x0190
+#define REG_OSC_32K_CTRL_8822C 0x0194
+#define REG_32K_CAL_REG1_8822C 0x0198
+#define REG_C2HEVT_8822C 0x01A0
+#define REG_C2HEVT_1_8822C 0x01A4
+#define REG_C2HEVT_2_8822C 0x01A8
+#define REG_C2HEVT_3_8822C 0x01AC
+#define REG_SW_DEFINED_PAGE1_8822C 0x01B8
+#define REG_SW_DEFINED_PAGE2_8822C 0x01BC
+#define REG_MCUTST_I_8822C 0x01C0
+#define REG_MCUTST_II_8822C 0x01C4
+#define REG_FMETHR_8822C 0x01C8
+#define REG_HMETFR_8822C 0x01CC
+#define REG_HMEBOX0_8822C 0x01D0
+#define REG_HMEBOX1_8822C 0x01D4
+#define REG_HMEBOX2_8822C 0x01D8
+#define REG_HMEBOX3_8822C 0x01DC
+#define REG_BB_ACCESS_CTRL_8822C 0x01E8
+#define REG_BB_ACCESS_DATA_8822C 0x01EC
+#define REG_HMEBOX_E0_8822C 0x01F0
+#define REG_HMEBOX_E1_8822C 0x01F4
+#define REG_HMEBOX_E2_8822C 0x01F8
+#define REG_HMEBOX_E3_8822C 0x01FC
+#define REG_CR_EXT_8822C 0x1100
+#define REG_FWFF_8822C 0x1114
+#define REG_RXFF_PTR_V1_8822C 0x1118
+#define REG_RXFF_WTR_V1_8822C 0x111C
+#define REG_FE2IMR_8822C 0x1120
+#define REG_FE2ISR_8822C 0x1124
+#define REG_FE3IMR_8822C 0x1128
+#define REG_FE3ISR_8822C 0x112C
+#define REG_FE4IMR_8822C 0x1130
+#define REG_FE4ISR_8822C 0x1134
+#define REG_FT1IMR_8822C 0x1138
+#define REG_FT1ISR_8822C 0x113C
+#define REG_SPWR0_8822C 0x1140
+#define REG_SPWR1_8822C 0x1144
+#define REG_SPWR2_8822C 0x1148
+#define REG_SPWR3_8822C 0x114C
+#define REG_POWSEQ_8822C 0x1150
+#define REG_TC7_CTRL_V1_8822C 0x1158
+#define REG_TC8_CTRL_V1_8822C 0x115C
+#define REG_RX_BCN_TBTT_ITVL0_8822C 0x1160
+#define REG_RX_BCN_TBTT_ITVL1_8822C 0x1164
+#define REG_IO_WRAP_ERR_FLAG_8822C 0x1170
+#define REG_SPEED_SENSOR_8822C 0x1180
+#define REG_SPEED_SENSOR1_8822C 0x1184
+#define REG_SPEED_SENSOR2_8822C 0x1188
+#define REG_SPEED_SENSOR3_8822C 0x118C
+#define REG_SPEED_SENSOR4_8822C 0x1190
+#define REG_SPEED_SENSOR5_8822C 0x1194
+#define REG_COUNTER_CTRL_8822C 0x11C4
+#define REG_COUNTER_THRESHOLD_8822C 0x11C8
+#define REG_COUNTER_SET_8822C 0x11CC
+#define REG_COUNTER_OVERFLOW_8822C 0x11D0
+#define REG_TXDMA_LEN_THRESHOLD_8822C 0x11D4
+#define REG_RXDMA_LEN_THRESHOLD_8822C 0x11D8
+#define REG_PCIE_EXEC_TIME_THRESHOLD_8822C 0x11DC
+#define REG_FT2IMR_8822C 0x11E0
+#define REG_FT2ISR_8822C 0x11E4
+#define REG_MSG2_8822C 0x11F0
+#define REG_MSG3_8822C 0x11F4
+#define REG_MSG4_8822C 0x11F8
+#define REG_MSG5_8822C 0x11FC
+#define REG_FIFOPAGE_CTRL_1_8822C 0x0200
+#define REG_FIFOPAGE_CTRL_2_8822C 0x0204
+#define REG_AUTO_LLT_V1_8822C 0x0208
+#define REG_TXDMA_OFFSET_CHK_8822C 0x020C
+#define REG_TXDMA_STATUS_8822C 0x0210
+#define REG_TX_DMA_DBG_8822C 0x0214
+#define REG_TQPNT1_8822C 0x0218
+#define REG_TQPNT2_8822C 0x021C
+#define REG_TQPNT3_8822C 0x0220
+#define REG_TQPNT4_8822C 0x0224
+#define REG_RQPN_CTRL_1_8822C 0x0228
+#define REG_RQPN_CTRL_2_8822C 0x022C
+#define REG_FIFOPAGE_INFO_1_8822C 0x0230
+#define REG_FIFOPAGE_INFO_2_8822C 0x0234
+#define REG_FIFOPAGE_INFO_3_8822C 0x0238
+#define REG_FIFOPAGE_INFO_4_8822C 0x023C
+#define REG_FIFOPAGE_INFO_5_8822C 0x0240
+#define REG_H2C_HEAD_8822C 0x0244
+#define REG_H2C_TAIL_8822C 0x0248
+#define REG_H2C_READ_ADDR_8822C 0x024C
+#define REG_H2C_WR_ADDR_8822C 0x0250
+#define REG_H2C_INFO_8822C 0x0254
+#define REG_PGSUB_CNT_8822C 0x026C
+#define REG_PGSUB_H_8822C 0x0270
+#define REG_PGSUB_N_8822C 0x0274
+#define REG_PGSUB_L_8822C 0x0278
+#define REG_PGSUB_E_8822C 0x027C
+#define REG_RXDMA_AGG_PG_TH_8822C 0x0280
+#define REG_RXPKT_NUM_8822C 0x0284
+#define REG_RXDMA_STATUS_8822C 0x0288
+#define REG_RXDMA_DPR_8822C 0x028C
+#define REG_RXDMA_MODE_8822C 0x0290
+#define REG_C2H_PKT_8822C 0x0294
+#define REG_FWFF_C2H_8822C 0x0298
+#define REG_FWFF_CTRL_8822C 0x029C
+#define REG_FWFF_PKT_INFO_8822C 0x02A0
+#define REG_RXPKTNUM_8822C 0x02B0
+#define REG_RXPKTNUM_TH_8822C 0x02B4
+#define REG_FW_MSG1_8822C 0x02E0
+#define REG_FW_MSG2_8822C 0x02E4
+#define REG_FW_MSG3_8822C 0x02E8
+#define REG_FW_MSG4_8822C 0x02EC
+#define REG_DDMA_CH0SA_8822C 0x1200
+#define REG_DDMA_CH0DA_8822C 0x1204
+#define REG_DDMA_CH0CTRL_8822C 0x1208
+#define REG_DDMA_CH1SA_8822C 0x1210
+#define REG_DDMA_CH1DA_8822C 0x1214
+#define REG_DDMA_CH1CTRL_8822C 0x1218
+#define REG_DDMA_CH2SA_8822C 0x1220
+#define REG_DDMA_CH2DA_8822C 0x1224
+#define REG_DDMA_CH2CTRL_8822C 0x1228
+#define REG_DDMA_CH3SA_8822C 0x1230
+#define REG_DDMA_CH3DA_8822C 0x1234
+#define REG_DDMA_CH3CTRL_8822C 0x1238
+#define REG_DDMA_CH4SA_8822C 0x1240
+#define REG_DDMA_CH4DA_8822C 0x1244
+#define REG_DDMA_CH4CTRL_8822C 0x1248
+#define REG_DDMA_CH5SA_8822C 0x1250
+#define REG_DDMA_CH5DA_8822C 0x1254
+#define REG_DDMA_CH5CTRL_8822C 0x1258
+#define REG_DDMA_INT_MSK_8822C 0x12E0
+#define REG_DDMA_CHSTATUS_8822C 0x12E8
+#define REG_DDMA_CHKSUM_8822C 0x12F0
+#define REG_DDMA_MONITOR_8822C 0x12FC
+#define REG_PCIE_CTRL_8822C 0x0300
+#define REG_INT_MIG_8822C 0x0304
+#define REG_BCNQ_TXBD_DESA_8822C 0x0308
+#define REG_MGQ_TXBD_DESA_8822C 0x0310
+#define REG_VOQ_TXBD_DESA_8822C 0x0318
+#define REG_VIQ_TXBD_DESA_8822C 0x0320
+#define REG_BEQ_TXBD_DESA_8822C 0x0328
+#define REG_BKQ_TXBD_DESA_8822C 0x0330
+#define REG_RXQ_RXBD_DESA_8822C 0x0338
+#define REG_HI0Q_TXBD_DESA_8822C 0x0340
+#define REG_HI1Q_TXBD_DESA_8822C 0x0348
+#define REG_HI2Q_TXBD_DESA_8822C 0x0350
+#define REG_HI3Q_TXBD_DESA_8822C 0x0358
+#define REG_HI4Q_TXBD_DESA_8822C 0x0360
+#define REG_HI5Q_TXBD_DESA_8822C 0x0368
+#define REG_HI6Q_TXBD_DESA_8822C 0x0370
+#define REG_HI7Q_TXBD_DESA_8822C 0x0378
+#define REG_MGQ_TXBD_NUM_8822C 0x0380
+#define REG_RX_RXBD_NUM_8822C 0x0382
+#define REG_VOQ_TXBD_NUM_8822C 0x0384
+#define REG_VIQ_TXBD_NUM_8822C 0x0386
+#define REG_BEQ_TXBD_NUM_8822C 0x0388
+#define REG_BKQ_TXBD_NUM_8822C 0x038A
+#define REG_HI0Q_TXBD_NUM_8822C 0x038C
+#define REG_HI1Q_TXBD_NUM_8822C 0x038E
+#define REG_HI2Q_TXBD_NUM_8822C 0x0390
+#define REG_HI3Q_TXBD_NUM_8822C 0x0392
+#define REG_HI4Q_TXBD_NUM_8822C 0x0394
+#define REG_HI5Q_TXBD_NUM_8822C 0x0396
+#define REG_HI6Q_TXBD_NUM_8822C 0x0398
+#define REG_HI7Q_TXBD_NUM_8822C 0x039A
+#define REG_TSFTIMER_HCI_8822C 0x039C
+#define REG_BD_RWPTR_CLR_8822C 0x039C
+#define REG_VOQ_TXBD_IDX_8822C 0x03A0
+#define REG_VIQ_TXBD_IDX_8822C 0x03A4
+#define REG_BEQ_TXBD_IDX_8822C 0x03A8
+#define REG_BKQ_TXBD_IDX_8822C 0x03AC
+#define REG_MGQ_TXBD_IDX_8822C 0x03B0
+#define REG_RXQ_RXBD_IDX_8822C 0x03B4
+#define REG_HI0Q_TXBD_IDX_8822C 0x03B8
+#define REG_HI1Q_TXBD_IDX_8822C 0x03BC
+#define REG_HI2Q_TXBD_IDX_8822C 0x03C0
+#define REG_HI3Q_TXBD_IDX_8822C 0x03C4
+#define REG_HI4Q_TXBD_IDX_8822C 0x03C8
+#define REG_HI5Q_TXBD_IDX_8822C 0x03CC
+#define REG_HI6Q_TXBD_IDX_8822C 0x03D0
+#define REG_HI7Q_TXBD_IDX_8822C 0x03D4
+#define REG_DBG_SEL_V1_8822C 0x03D8
+#define REG_PCIE_HRPWM1_V1_8822C 0x03D9
+#define REG_PCIE_HCPWM1_V1_8822C 0x03DA
+#define REG_PCIE_CTRL2_8822C 0x03DB
+#define REG_PCIE_HRPWM2_V1_8822C 0x03DC
+#define REG_PCIE_HCPWM2_V1_8822C 0x03DE
+#define REG_PCIE_H2C_MSG_V1_8822C 0x03E0
+#define REG_PCIE_C2H_MSG_V1_8822C 0x03E4
+#define REG_DBI_WDATA_V1_8822C 0x03E8
+#define REG_DBI_RDATA_V1_8822C 0x03EC
+#define REG_DBI_FLAG_V1_8822C 0x03F0
+#define REG_MDIO_V1_8822C 0x03F4
+#define REG_PCIE_MIX_CFG_8822C 0x03F8
+#define REG_HCI_MIX_CFG_8822C 0x03FC
+#define REG_STC_INT_CS_8822C 0x1300
+#define REG_ST_INT_CFG_8822C 0x1304
+#define REG_H2CQ_TXBD_DESA_8822C 0x1320
+#define REG_H2CQ_TXBD_NUM_8822C 0x1328
+#define REG_H2CQ_TXBD_IDX_8822C 0x132C
+#define REG_H2CQ_CSR_8822C 0x1330
+#define REG_CHANGE_PCIE_SPEED_8822C 0x1350
+#define REG_DEBUG_STATE1_8822C 0x1354
+#define REG_DEBUG_STATE2_8822C 0x1358
+#define REG_DEBUG_STATE3_8822C 0x135C
+#define REG_CHNL_DMA_CFG_V1_8822C 0x137C
+#define REG_PCIE_HISR0_V1_8822C 0x13B4
+#define REG_PCIE_HISR1_V1_8822C 0x13BC
+#define REG_PCIE_HISR2_V1_8822C 0x23B4
+#define REG_PCIE_HISR3_V1_8822C 0x23BC
+#define REG_Q0_INFO_8822C 0x0400
+#define REG_Q1_INFO_8822C 0x0404
+#define REG_Q2_INFO_8822C 0x0408
+#define REG_Q3_INFO_8822C 0x040C
+#define REG_MGQ_INFO_8822C 0x0410
+#define REG_HIQ_INFO_8822C 0x0414
+#define REG_BCNQ_INFO_8822C 0x0418
+#define REG_TXPKT_EMPTY_8822C 0x041A
+#define REG_CPU_MGQ_INFO_8822C 0x041C
+#define REG_FWHW_TXQ_CTRL_8822C 0x0420
+#define REG_DATAFB_SEL_8822C 0x0423
+#define REG_BCNQ_BDNY_V1_8822C 0x0424
+#define REG_LIFETIME_EN_8822C 0x0426
+#define REG_SPEC_SIFS_8822C 0x0428
+#define REG_RETRY_LIMIT_8822C 0x042A
+#define REG_TXBF_CTRL_8822C 0x042C
+#define REG_DARFRC_8822C 0x0430
+#define REG_DARFRCH_8822C 0x0434
+#define REG_RARFRC_8822C 0x0438
+#define REG_RARFRCH_8822C 0x043C
+#define REG_RRSR_8822C 0x0440
+#define REG_ARFR0_8822C 0x0444
+#define REG_ARFRH0_8822C 0x0448
+#define REG_ARFR1_V1_8822C 0x044C
+#define REG_ARFRH1_V1_8822C 0x0450
+#define REG_CCK_CHECK_8822C 0x0454
+#define REG_AMPDU_MAX_TIME_V1_8822C 0x0455
+#define REG_BCNQ1_BDNY_V1_8822C 0x0456
+#define REG_AMPDU_MAX_LENGTH_HT_8822C 0x0458
+#define REG_ACQ_STOP_8822C 0x045C
+#define REG_NDPA_RATE_8822C 0x045D
+#define REG_TX_HANG_CTRL_8822C 0x045E
+#define REG_NDPA_OPT_CTRL_8822C 0x045F
+#define REG_AMPDU_MAX_LENGTH_VHT_8822C 0x0460
+#define REG_RD_RESP_PKT_TH_8822C 0x0463
+#define REG_CMDQ_INFO_8822C 0x0464
+#define REG_Q4_INFO_8822C 0x0468
+#define REG_Q5_INFO_8822C 0x046C
+#define REG_Q6_INFO_8822C 0x0470
+#define REG_Q7_INFO_8822C 0x0474
+#define REG_WMAC_LBK_BUF_HD_V1_8822C 0x0478
+#define REG_MGQ_BDNY_V1_8822C 0x047A
+#define REG_TXRPT_CTRL_8822C 0x047C
+#define REG_INIRTS_RATE_SEL_8822C 0x0480
+#define REG_BASIC_CFEND_RATE_8822C 0x0481
+#define REG_STBC_CFEND_RATE_8822C 0x0482
+#define REG_DATA_SC_8822C 0x0483
+#define REG_MACID_SLEEP3_8822C 0x0484
+#define REG_MACID_SLEEP1_8822C 0x0488
+#define REG_ARFR2_V1_8822C 0x048C
+#define REG_ARFRH2_V1_8822C 0x0490
+#define REG_ARFR3_V1_8822C 0x0494
+#define REG_ARFRH3_V1_8822C 0x0498
+#define REG_ARFR4_8822C 0x049C
+#define REG_ARFRH4_8822C 0x04A0
+#define REG_ARFR5_8822C 0x04A4
+#define REG_ARFRH5_8822C 0x04A8
+#define REG_TXRPT_START_OFFSET_8822C 0x04AC
+#define REG_POWER_STAGE1_8822C 0x04B4
+#define REG_POWER_STAGE2_8822C 0x04B8
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8822C 0x04BC
+#define REG_PKT_LIFE_TIME_8822C 0x04C0
+#define REG_STBC_SETTING_8822C 0x04C4
+#define REG_STBC_SETTING2_8822C 0x04C5
+#define REG_QUEUE_CTRL_8822C 0x04C6
+#define REG_SINGLE_AMPDU_CTRL_8822C 0x04C7
+#define REG_PROT_MODE_CTRL_8822C 0x04C8
+#define REG_BAR_MODE_CTRL_8822C 0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8822C 0x04CF
+#define REG_MACID_SLEEP2_8822C 0x04D0
+#define REG_MACID_SLEEP_8822C 0x04D4
+#define REG_HW_SEQ0_8822C 0x04D8
+#define REG_HW_SEQ1_8822C 0x04DA
+#define REG_HW_SEQ2_8822C 0x04DC
+#define REG_HW_SEQ3_8822C 0x04DE
+#define REG_NULL_PKT_STATUS_V1_8822C 0x04E0
+#define REG_PTCL_ERR_STATUS_8822C 0x04E2
+#define REG_NULL_PKT_STATUS_EXTEND_8822C 0x04E3
+#define REG_HQMGQ_DROP_8822C 0x04E4
+#define REG_PRECNT_CTRL_8822C 0x04E5
+#define REG_BT_POLLUTE_PKT_CNT_8822C 0x04E8
+#define REG_PTCL_DBG_8822C 0x04EC
+#define REG_CPUMGQ_TIMER_CTRL2_8822C 0x04F4
+#define REG_DUMMY_PAGE4_V1_8822C 0x04FC
+#define REG_MOREDATA_8822C 0x04FE
+#define REG_Q0_Q1_INFO_8822C 0x1400
+#define REG_Q2_Q3_INFO_8822C 0x1404
+#define REG_Q4_Q5_INFO_8822C 0x1408
+#define REG_Q6_Q7_INFO_8822C 0x140C
+#define REG_MGQ_HIQ_INFO_8822C 0x1410
+#define REG_CMDQ_BCNQ_INFO_8822C 0x1414
+#define REG_USEREG_SETTING_8822C 0x1420
+#define REG_AESIV_SETTING_8822C 0x1424
+#define REG_BF0_TIME_SETTING_8822C 0x1428
+#define REG_BF1_TIME_SETTING_8822C 0x142C
+#define REG_BF_TIMEOUT_EN_8822C 0x1430
+#define REG_MACID_RELEASE0_8822C 0x1434
+#define REG_MACID_RELEASE1_8822C 0x1438
+#define REG_MACID_RELEASE2_8822C 0x143C
+#define REG_MACID_RELEASE3_8822C 0x1440
+#define REG_MACID_RELEASE_SETTING_8822C 0x1444
+#define REG_FAST_EDCA_VOVI_SETTING_8822C 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING_8822C 0x144C
+#define REG_MACID_DROP0_8822C 0x1450
+#define REG_MACID_DROP1_8822C 0x1454
+#define REG_MACID_DROP2_8822C 0x1458
+#define REG_MACID_DROP3_8822C 0x145C
+#define REG_R_MACID_RELEASE_SUCCESS_0_8822C 0x1460
+#define REG_R_MACID_RELEASE_SUCCESS_1_8822C 0x1464
+#define REG_R_MACID_RELEASE_SUCCESS_2_8822C 0x1468
+#define REG_R_MACID_RELEASE_SUCCESS_3_8822C 0x146C
+#define REG_MGQ_FIFO_WRITE_POINTER_8822C 0x1470
+#define REG_MGQ_FIFO_READ_POINTER_8822C 0x1472
+#define REG_MGQ_FIFO_ENABLE_8822C 0x1472
+#define REG_MGQ_FIFO_RELEASE_INT_MASK_8822C 0x1474
+#define REG_MGQ_FIFO_RELEASE_INT_FLAG_8822C 0x1476
+#define REG_MGQ_FIFO_VALID_MAP_8822C 0x1478
+#define REG_MGQ_FIFO_LIFETIME_8822C 0x147A
+#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C 0x147C
+#define REG_SHCUT_SETTING_8822C 0x1480
+#define REG_SHCUT_LLC_ETH_TYPE0_8822C 0x1484
+#define REG_SHCUT_LLC_ETH_TYPE1_8822C 0x1488
+#define REG_SHCUT_LLC_OUI0_8822C 0x148C
+#define REG_SHCUT_LLC_OUI1_8822C 0x1490
+#define REG_SHCUT_LLC_OUI2_8822C 0x1494
+#define REG_MU_TX_CTL_8822C 0x14C0
+#define REG_MU_STA_GID_VLD_8822C 0x14C4
+#define REG_MU_STA_USER_POS_INFO_8822C 0x14C8
+#define REG_MU_STA_USER_POS_INFO_H_8822C 0x14CC
+#define REG_CHNL_INFO_CTRL_8822C 0x14D0
+#define REG_CHNL_IDLE_TIME_8822C 0x14D4
+#define REG_CHNL_BUSY_TIME_8822C 0x14D8
+#define REG_MU_TRX_DBG_CNT_V1_8822C 0x14DC
+#define REG_EDCA_VO_PARAM_8822C 0x0500
+#define REG_EDCA_VI_PARAM_8822C 0x0504
+#define REG_EDCA_BE_PARAM_8822C 0x0508
+#define REG_EDCA_BK_PARAM_8822C 0x050C
+#define REG_BCNTCFG_8822C 0x0510
+#define REG_PIFS_8822C 0x0512
+#define REG_RDG_PIFS_8822C 0x0513
+#define REG_SIFS_8822C 0x0514
+#define REG_TSFTR_SYN_OFFSET_8822C 0x0518
+#define REG_AGGR_BREAK_TIME_8822C 0x051A
+#define REG_SLOT_8822C 0x051B
+#define REG_NOA_ON_ERLY_TIME_8822C 0x051C
+#define REG_NOA_OFF_ERLY_TIME_8822C 0x051D
+#define REG_TX_PTCL_CTRL_8822C 0x0520
+#define REG_TXPAUSE_8822C 0x0522
+#define REG_DIS_TXREQ_CLR_8822C 0x0523
+#define REG_RD_CTRL_8822C 0x0524
+#define REG_MBSSID_CTRL_8822C 0x0526
+#define REG_P2PPS_CTRL_8822C 0x0527
+#define REG_PKT_LIFETIME_CTRL_8822C 0x0528
+#define REG_P2PPS_SPEC_STATE_8822C 0x052B
+#define REG_TXOP_LIMIT_CTRL_8822C 0x052C
+#define REG_BAR_TX_CTRL_8822C 0x0530
+#define REG_P2PON_DIS_TXTIME_8822C 0x0531
+#define REG_CCA_TXEN_CNT_8822C 0x0534
+#define REG_MAX_INTER_COLLISION_8822C 0x0538
+#define REG_MAX_INTER_COLLISION_CNT_8822C 0x053C
+#define REG_TBTT_PROHIBIT_8822C 0x0540
+#define REG_P2PPS_STATE_8822C 0x0543
+#define REG_RD_NAV_NXT_8822C 0x0544
+#define REG_NAV_PROT_LEN_8822C 0x0546
+#define REG_FTM_PTT_8822C 0x0548
+#define REG_FTM_TSF_8822C 0x054C
+#define REG_BCN_CTRL_8822C 0x0550
+#define REG_BCN_CTRL_CLINT0_8822C 0x0551
+#define REG_MBID_NUM_8822C 0x0552
+#define REG_DUAL_TSF_RST_8822C 0x0553
+#define REG_MBSSID_BCN_SPACE_8822C 0x0554
+#define REG_DRVERLYINT_8822C 0x0558
+#define REG_BCNDMATIM_8822C 0x0559
+#define REG_ATIMWND_8822C 0x055A
+#define REG_USTIME_TSF_8822C 0x055C
+#define REG_BCN_MAX_ERR_8822C 0x055D
+#define REG_RXTSF_OFFSET_CCK_8822C 0x055E
+#define REG_RXTSF_OFFSET_OFDM_8822C 0x055F
+#define REG_TSFTR_8822C 0x0560
+#define REG_TSFTR_1_8822C 0x0564
+#define REG_FREERUN_CNT_8822C 0x0568
+#define REG_FREERUN_CNT_1_8822C 0x056C
+#define REG_ATIMWND1_V1_8822C 0x0570
+#define REG_TBTT_PROHIBIT_INFRA_8822C 0x0571
+#define REG_CTWND_8822C 0x0572
+#define REG_BCNIVLCUNT_8822C 0x0573
+#define REG_BCNDROPCTRL_8822C 0x0574
+#define REG_HGQ_TIMEOUT_PERIOD_8822C 0x0575
+#define REG_TXCMD_TIMEOUT_PERIOD_8822C 0x0576
+#define REG_MISC_CTRL_8822C 0x0577
+#define REG_BCN_CTRL_CLINT1_8822C 0x0578
+#define REG_BCN_CTRL_CLINT2_8822C 0x0579
+#define REG_BCN_CTRL_CLINT3_8822C 0x057A
+#define REG_EXTEND_CTRL_8822C 0x057B
+#define REG_P2PPS1_SPEC_STATE_8822C 0x057C
+#define REG_P2PPS1_STATE_8822C 0x057D
+#define REG_P2PPS2_SPEC_STATE_8822C 0x057E
+#define REG_P2PPS2_STATE_8822C 0x057F
+#define REG_PS_TIMER0_8822C 0x0580
+#define REG_PS_TIMER1_8822C 0x0584
+#define REG_PS_TIMER2_8822C 0x0588
+#define REG_TBTT_CTN_AREA_8822C 0x058C
+#define REG_FORCE_BCN_IFS_8822C 0x058E
+#define REG_TXOP_MIN_8822C 0x0590
+#define REG_PRE_BKF_TIME_8822C 0x0592
+#define REG_CROSS_TXOP_CTRL_8822C 0x0593
+#define REG_RX_TBTT_SHIFT_V1_8822C 0x0598
+#define REG_ATIMWND2_8822C 0x05A0
+#define REG_ATIMWND3_8822C 0x05A1
+#define REG_ATIMWND4_8822C 0x05A2
+#define REG_ATIMWND5_8822C 0x05A3
+#define REG_ATIMWND6_8822C 0x05A4
+#define REG_ATIMWND7_8822C 0x05A5
+#define REG_ATIMUGT_8822C 0x05A6
+#define REG_HIQ_NO_LMT_EN_8822C 0x05A7
+#define REG_DTIM_COUNTER_ROOT_8822C 0x05A8
+#define REG_DTIM_COUNTER_VAP1_8822C 0x05A9
+#define REG_DTIM_COUNTER_VAP2_8822C 0x05AA
+#define REG_DTIM_COUNTER_VAP3_8822C 0x05AB
+#define REG_DTIM_COUNTER_VAP4_8822C 0x05AC
+#define REG_DTIM_COUNTER_VAP5_8822C 0x05AD
+#define REG_DTIM_COUNTER_VAP6_8822C 0x05AE
+#define REG_DTIM_COUNTER_VAP7_8822C 0x05AF
+#define REG_DIS_ATIM_8822C 0x05B0
+#define REG_EARLY_128US_8822C 0x05B1
+#define REG_P2PPS1_CTRL_8822C 0x05B2
+#define REG_P2PPS2_CTRL_8822C 0x05B3
+#define REG_TIMER0_SRC_SEL_8822C 0x05B4
+#define REG_NOA_UNIT_SEL_8822C 0x05B5
+#define REG_P2POFF_DIS_TXTIME_8822C 0x05B7
+#define REG_MBSSID_BCN_SPACE2_8822C 0x05B8
+#define REG_MBSSID_BCN_SPACE3_8822C 0x05BC
+#define REG_ACMHWCTRL_8822C 0x05C0
+#define REG_ACMRSTCTRL_8822C 0x05C1
+#define REG_ACMAVG_8822C 0x05C2
+#define REG_VO_ADMTIME_8822C 0x05C4
+#define REG_VI_ADMTIME_8822C 0x05C6
+#define REG_BE_ADMTIME_8822C 0x05C8
+#define REG_MAC_HEADER_NAV_OFFSET_8822C 0x05CA
+#define REG_DIS_NDPA_NAV_CHECK_8822C 0x05CB
+#define REG_EDCA_RANDOM_GEN_8822C 0x05CC
+#define REG_TXCMD_NOA_SEL_8822C 0x05CF
+#define REG_32K_CLK_SEL_8822C 0x05D0
+#define REG_EARLYINT_ADJUST_8822C 0x05D4
+#define REG_BCNERR_CNT_8822C 0x05D8
+#define REG_BCNERR_CNT_2_8822C 0x05DC
+#define REG_NOA_PARAM_8822C 0x05E0
+#define REG_NOA_PARAM_1_8822C 0x05E4
+#define REG_NOA_PARAM_2_8822C 0x05E8
+#define REG_NOA_PARAM_3_8822C 0x05EC
+#define REG_P2P_RST_8822C 0x05F0
+#define REG_SCHEDULER_RST_8822C 0x05F1
+#define REG_SCH_DBG_VALUE_8822C 0x05F4
+#define REG_SCH_TXCMD_8822C 0x05F8
+#define REG_PAGE5_DUMMY_8822C 0x05FC
+#define REG_CPUMGQ_TX_TIMER_8822C 0x1500
+#define REG_PS_TIMER_A_8822C 0x1504
+#define REG_PS_TIMER_B_8822C 0x1508
+#define REG_PS_TIMER_C_8822C 0x150C
+#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8822C 0x1510
+#define REG_CPUMGQ_TX_TIMER_EARLY_8822C 0x1514
+#define REG_PS_TIMER_A_EARLY_8822C 0x1515
+#define REG_PS_TIMER_B_EARLY_8822C 0x1516
+#define REG_PS_TIMER_C_EARLY_8822C 0x1517
+#define REG_CPUMGQ_PARAMETER_8822C 0x1518
+#define REG_TSF_SYNC_ADJ_8822C 0x1520
+#define REG_TSF_ADJ_VLAUE_8822C 0x1524
+#define REG_TSF_ADJ_VLAUE_2_8822C 0x1528
+#define REG_P2PPS_HW_AUTO_PAUSE_CTRL_8822C 0x156C
+#define REG_P2PPS1_HW_AUTO_PAUSE_CTRL_8822C 0x1570
+#define REG_P2PPS2_HW_AUTO_PAUSE_CTRL_8822C 0x1574
+#define REG_WMAC_CR_8822C 0x0600
+#define REG_WMAC_FWPKT_CR_8822C 0x0601
+#define REG_FW_STS_FILTER_8822C 0x0602
+#define REG_TCR_8822C 0x0604
+#define REG_RCR_8822C 0x0608
+#define REG_RX_PKT_LIMIT_8822C 0x060C
+#define REG_RX_DLK_TIME_8822C 0x060D
+#define REG_RX_DRVINFO_SZ_8822C 0x060F
+#define REG_MACID_8822C 0x0610
+#define REG_MACID_H_8822C 0x0614
+#define REG_BSSID_8822C 0x0618
+#define REG_BSSID_H_8822C 0x061C
+#define REG_MAR_8822C 0x0620
+#define REG_MAR_H_8822C 0x0624
+#define REG_MBIDCAMCFG_1_8822C 0x0628
+#define REG_MBIDCAMCFG_2_8822C 0x062C
+#define REG_WMAC_TCR_TSFT_OFS_8822C 0x0630
+#define REG_UDF_THSD_8822C 0x0632
+#define REG_ZLD_NUM_8822C 0x0633
+#define REG_STMP_THSD_8822C 0x0634
+#define REG_WMAC_TXTIMEOUT_8822C 0x0635
+#define REG_USTIME_EDCA_8822C 0x0638
+#define REG_ACKTO_CCK_8822C 0x0639
+#define REG_MAC_SPEC_SIFS_8822C 0x063A
+#define REG_RESP_SIFS_CCK_8822C 0x063C
+#define REG_RESP_SIFS_OFDM_8822C 0x063E
+#define REG_ACKTO_8822C 0x0640
+#define REG_CTS2TO_8822C 0x0641
+#define REG_EIFS_8822C 0x0642
+#define REG_RPFM_MAP0_8822C 0x0644
+#define REG_RPFM_MAP1_V1_8822C 0x0646
+#define REG_RPFM_CAM_CMD_8822C 0x0648
+#define REG_RPFM_CAM_RWD_8822C 0x064C
+#define REG_NAV_CTRL_8822C 0x0650
+#define REG_BACAMCMD_8822C 0x0654
+#define REG_BACAMCONTENT_8822C 0x0658
+#define REG_BACAMCONTENT_H_8822C 0x065C
+#define REG_LBDLY_8822C 0x0660
+#define REG_WMAC_BACAM_RPMEN_8822C 0x0661
+#define REG_TX_RX_8822C 0x0662
+#define REG_WMAC_BITMAP_CTL_8822C 0x0663
+#define REG_RXERR_RPT_8822C 0x0664
+#define REG_WMAC_TRXPTCL_CTL_8822C 0x0668
+#define REG_WMAC_TRXPTCL_CTL_H_8822C 0x066C
+#define REG_CAMCMD_8822C 0x0670
+#define REG_CAMWRITE_8822C 0x0674
+#define REG_CAMREAD_8822C 0x0678
+#define REG_CAMDBG_8822C 0x067C
+#define REG_SECCFG_8822C 0x0680
+#define REG_RXFILTER_CATEGORY_1_8822C 0x0682
+#define REG_RXFILTER_ACTION_1_8822C 0x0683
+#define REG_RXFILTER_CATEGORY_2_8822C 0x0684
+#define REG_RXFILTER_ACTION_2_8822C 0x0685
+#define REG_RXFILTER_CATEGORY_3_8822C 0x0686
+#define REG_RXFILTER_ACTION_3_8822C 0x0687
+#define REG_RXFLTMAP3_8822C 0x0688
+#define REG_RXFLTMAP4_8822C 0x068A
+#define REG_RXFLTMAP5_8822C 0x068C
+#define REG_RXFLTMAP6_8822C 0x068E
+#define REG_WOW_CTRL_8822C 0x0690
+#define REG_NAN_RX_TSF_FILTER_8822C 0x0691
+#define REG_PS_RX_INFO_8822C 0x0692
+#define REG_WMMPS_UAPSD_TID_8822C 0x0693
+#define REG_LPNAV_CTRL_8822C 0x0694
+#define REG_WKFMCAM_CMD_8822C 0x0698
+#define REG_WKFMCAM_RWD_8822C 0x069C
+#define REG_RXFLTMAP0_8822C 0x06A0
+#define REG_RXFLTMAP1_8822C 0x06A2
+#define REG_RXFLTMAP2_8822C 0x06A4
+#define REG_BCN_PSR_RPT_8822C 0x06A8
+#define REG_FLC_RPC_8822C 0x06AC
+#define REG_FLC_RPCT_8822C 0x06AD
+#define REG_FLC_PTS_8822C 0x06AE
+#define REG_FLC_TRPC_8822C 0x06AF
+#define REG_RXPKTMON_CTRL_8822C 0x06B0
+#define REG_STATE_MON_8822C 0x06B4
+#define REG_ERROR_MON_8822C 0x06B8
+#define REG_SEARCH_MACID_8822C 0x06BC
+#define REG_BT_COEX_TABLE_8822C 0x06C0
+#define REG_BT_COEX_TABLE2_8822C 0x06C4
+#define REG_BT_COEX_BREAK_TABLE_8822C 0x06C8
+#define REG_BT_COEX_TABLE_H_8822C 0x06CC
+#define REG_RXCMD_0_8822C 0x06D0
+#define REG_RXCMD_1_8822C 0x06D4
+#define REG_WMAC_RESP_TXINFO_8822C 0x06D8
+#define REG_BBPSF_CTRL_8822C 0x06DC
+#define REG_P2P_RX_BCN_NOA_8822C 0x06E0
+#define REG_ASSOCIATED_BFMER0_INFO_8822C 0x06E4
+#define REG_ASSOCIATED_BFMER0_INFO_H_8822C 0x06E8
+#define REG_ASSOCIATED_BFMER1_INFO_8822C 0x06EC
+#define REG_ASSOCIATED_BFMER1_INFO_H_8822C 0x06F0
+#define REG_TX_CSI_RPT_PARAM_BW20_8822C 0x06F4
+#define REG_TX_CSI_RPT_PARAM_BW40_8822C 0x06F8
+#define REG_CSI_PTR_8822C 0x06FC
+#define REG_BCN_PSR_RPT2_8822C 0x1600
+#define REG_BCN_PSR_RPT3_8822C 0x1604
+#define REG_BCN_PSR_RPT4_8822C 0x1608
+#define REG_A1_ADDR_MASK_8822C 0x160C
+#define REG_RXPSF_CTRL_8822C 0x1610
+#define REG_RXPSF_TYPE_CTRL_8822C 0x1614
+#define REG_CAM_ACCESS_CTRL_8822C 0x1618
+#define REG_HT_SND_REF_RATE_8822C 0x161C
+#define REG_MACID2_8822C 0x1620
+#define REG_MACID2_H_8822C 0x1624
+#define REG_BSSID2_8822C 0x1628
+#define REG_BSSID2_H_8822C 0x162C
+#define REG_MACID3_8822C 0x1630
+#define REG_MACID3_H_8822C 0x1634
+#define REG_BSSID3_8822C 0x1638
+#define REG_BSSID3_H_8822C 0x163C
+#define REG_MACID4_8822C 0x1640
+#define REG_MACID4_H_8822C 0x1644
+#define REG_BSSID4_8822C 0x1648
+#define REG_BSSID4_H_8822C 0x164C
+#define REG_NOA_REPORT_8822C 0x1650
+#define REG_NOA_REPORT_1_8822C 0x1654
+#define REG_NOA_REPORT_2_8822C 0x1658
+#define REG_NOA_REPORT_3_8822C 0x165C
+#define REG_PWRBIT_SETTING_8822C 0x1660
+#define REG_GENERAL_OPTION_8822C 0x1664
+#define REG_CSI_RRSR_8822C 0x1678
+#define REG_MU_BF_OPTION_8822C 0x167C
+#define REG_WMAC_PAUSE_BB_CLR_TH_8822C 0x167D
+#define REG__WMAC_MULBK_BUF_8822C 0x167E
+#define REG_WMAC_MU_OPTION_8822C 0x167F
+#define REG_WMAC_MU_BF_CTL_8822C 0x1680
+#define REG_WMAC_MU_BFRPT_PARA_8822C 0x1682
+#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8822C 0x1684
+#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8822C 0x1686
+#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8822C 0x1688
+#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8822C 0x168A
+#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8822C 0x168C
+#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8822C 0x168E
+#define REG_WMAC_BB_STOP_RX_COUNTER_8822C 0x1690
+#define REG_WMAC_PLCP_MONITOR_8822C 0x1694
+#define REG_WMAC_PLCP_MONITOR_MUTX_8822C 0x1698
+#define REG_WMAC_CSIDMA_CFG_8822C 0x169C
+#define REG_TRANSMIT_ADDRSS_0_8822C 0x16A0
+#define REG_TRANSMIT_ADDRSS_0_H_8822C 0x16A4
+#define REG_TRANSMIT_ADDRSS_1_8822C 0x16A8
+#define REG_TRANSMIT_ADDRSS_1_H_8822C 0x16AC
+#define REG_TRANSMIT_ADDRSS_2_8822C 0x16B0
+#define REG_TRANSMIT_ADDRSS_2_H_8822C 0x16B4
+#define REG_TRANSMIT_ADDRSS_3_8822C 0x16B8
+#define REG_TRANSMIT_ADDRSS_3_H_8822C 0x16BC
+#define REG_TRANSMIT_ADDRSS_4_8822C 0x16C0
+#define REG_TRANSMIT_ADDRSS_4_H_8822C 0x16C4
+#define REG_MACID1_8822C 0x0700
+#define REG_MACID1_1_8822C 0x0704
+#define REG_BSSID1_8822C 0x0708
+#define REG_BSSID1_1_8822C 0x070C
+#define REG_BCN_PSR_RPT1_8822C 0x0710
+#define REG_ASSOCIATED_BFMEE_SEL_8822C 0x0714
+#define REG_SND_PTCL_CTRL_8822C 0x0718
+#define REG_RX_CSI_RPT_INFO_8822C 0x071C
+#define REG_NS_ARP_CTRL_8822C 0x0720
+#define REG_NS_ARP_INFO_8822C 0x0724
+#define REG_BEAMFORMING_INFO_NSARP_V1_8822C 0x0728
+#define REG_BEAMFORMING_INFO_NSARP_8822C 0x072C
+#define REG_IPV6_8822C 0x0730
+#define REG_IPV6_1_8822C 0x0734
+#define REG_IPV6_2_8822C 0x0738
+#define REG_IPV6_3_8822C 0x073C
+#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8822C 0x0750
+#define REG_WMAC_SWAES_DIO_B63_B32_8822C 0x0754
+#define REG_WMAC_SWAES_DIO_B95_B64_8822C 0x0758
+#define REG_WMAC_SWAES_DIO_B127_B96_8822C 0x075C
+#define REG_WMAC_SWAES_CFG_8822C 0x0760
+#define REG_BT_COEX_V2_8822C 0x0762
+#define REG_BT_COEX_8822C 0x0764
+#define REG_WLAN_ACT_MASK_CTRL_8822C 0x0768
+#define REG_WLAN_ACT_MASK_CTRL_1_8822C 0x076C
+#define REG_BT_COEX_ENHANCED_INTR_CTRL_8822C 0x076E
+#define REG_BT_ACT_STATISTICS_8822C 0x0770
+#define REG_BT_ACT_STATISTICS_1_8822C 0x0774
+#define REG_BT_STATISTICS_CONTROL_REGISTER_8822C 0x0778
+#define REG_BT_STATUS_REPORT_REGISTER_8822C 0x077C
+#define REG_BT_INTERRUPT_CONTROL_REGISTER_8822C 0x0780
+#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8822C 0x0784
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8822C 0x0785
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8822C 0x0788
+#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8822C 0x078C
+#define REG_BT_INTERRUPT_STATUS_REGISTER_8822C 0x078F
+#define REG_BT_TDMA_TIME_REGISTER_8822C 0x0790
+#define REG_BT_ACT_REGISTER_8822C 0x0794
+#define REG_OBFF_CTRL_BASIC_8822C 0x0798
+#define REG_OBFF_CTRL2_TIMER_8822C 0x079C
+#define REG_LTR_CTRL_BASIC_8822C 0x07A0
+#define REG_LTR_CTRL2_TIMER_THRESHOLD_8822C 0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8822C 0x07A8
+#define REG_LTR_ACTIVE_LATENCY_V1_8822C 0x07AC
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8822C 0x07B0
+#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_1_8822C 0x07B4
+#define REG_WMAC_PKTCNT_RWD_8822C 0x07B8
+#define REG_WMAC_PKTCNT_CTRL_8822C 0x07BC
+#define REG_IQ_DUMP_8822C 0x07C0
+#define REG_IQ_DUMP_1_8822C 0x07C4
+#define REG_IQ_DUMP_2_8822C 0x07C8
+#define REG_WMAC_FTM_CTL_8822C 0x07CC
+#define REG_WMAC_IQ_MDPK_FUNC_8822C 0x07CE
+#define REG_WMAC_OPTION_FUNCTION_8822C 0x07D0
+#define REG_WMAC_OPTION_FUNCTION_1_8822C 0x07D4
+#define REG_WMAC_OPTION_FUNCTION_2_8822C 0x07D8
+#define REG_RX_FILTER_FUNCTION_8822C 0x07DA
+#define REG_NDP_SIG_8822C 0x07E0
+#define REG_TXCMD_INFO_FOR_RSP_PKT_8822C 0x07E4
+#define REG_TXCMD_INFO_FOR_RSP_PKT_1_8822C 0x07E8
+#define REG_WSEC_OPTION_8822C 0x07EC
+#define REG_RTS_ADDRESS_0_8822C 0x07F0
+#define REG_RTS_ADDRESS_0_1_8822C 0x07F4
+#define REG_RTS_ADDRESS_1_8822C 0x07F8
+#define REG_RTS_ADDRESS_1_1_8822C 0x07FC
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8822C 0x1700
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8822C 0x1704
+#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8822C 0x1708
+#define REG_SDIO_TX_CTRL_8822C 0x10250000
+#define REG_SDIO_CMD11_VOL_SWITCH_8822C 0x10250004
+#define REG_SDIO_DRIVING_8822C 0x10250006
+#define REG_SDIO_MONITOR_8822C 0x10250008
+#define REG_SDIO_MONITOR_2_8822C 0x1025000C
+#define REG_SDIO_HIMR_8822C 0x10250014
+#define REG_SDIO_HISR_8822C 0x10250018
+#define REG_SDIO_RX_REQ_LEN_8822C 0x1025001C
+#define REG_SDIO_FREE_TXPG_SEQ_V1_8822C 0x1025001F
+#define REG_SDIO_FREE_TXPG_8822C 0x10250020
+#define REG_SDIO_FREE_TXPG2_8822C 0x10250024
+#define REG_SDIO_OQT_FREE_TXPG_V1_8822C 0x10250028
+#define REG_SDIO_TXPKT_EMPTY_8822C 0x1025002C
+#define REG_SDIO_HTSFR_INFO_8822C 0x10250030
+#define REG_SDIO_HCPWM1_V2_8822C 0x10250038
+#define REG_SDIO_HCPWM2_V2_8822C 0x1025003A
+#define REG_SDIO_INDIRECT_REG_CFG_8822C 0x10250040
+#define REG_SDIO_INDIRECT_REG_DATA_8822C 0x10250044
+#define REG_SDIO_H2C_8822C 0x10250060
+#define REG_SDIO_C2H_8822C 0x10250064
+#define REG_SDIO_HRPWM1_8822C 0x10250080
+#define REG_SDIO_HRPWM2_8822C 0x10250082
+#define REG_SDIO_HPS_CLKR_8822C 0x10250084
+#define REG_SDIO_BUS_CTRL_8822C 0x10250085
+#define REG_SDIO_HSUS_CTRL_8822C 0x10250086
+#define REG_SDIO_RESPONSE_TIMER_8822C 0x10250088
+#define REG_SDIO_CMD_CRC_8822C 0x1025008A
+#define REG_SDIO_HSISR_8822C 0x10250090
+#define REG_SDIO_HSIMR_8822C 0x10250091
+#define REG_SDIO_DIOERR_RPT_8822C 0x102500C0
+#define REG_SDIO_CMD_ERRCNT_8822C 0x102500C2
+#define REG_SDIO_DATA_ERRCNT_8822C 0x102500C3
+#define REG_SDIO_CMD_ERR_CONTENT_8822C 0x102500C4
+#define REG_SDIO_CRC_ERR_IDX_8822C 0x102500C9
+#define REG_SDIO_DATA_CRC_8822C 0x102500CA
+#define REG_SDIO_TRANS_FIFO_STATUS_8822C 0x102500CC
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_bd_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_bd_nic.h
new file mode 100644
index 000000000000..dae936a0cebb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_bd_nic.h
@@ -0,0 +1,40 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_RX_BD_NIC_H_
+#define _HALMAC_RX_BD_NIC_H_
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+	HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXBD_DW0*/
+
+#define GET_RX_BD_RXFAIL(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 31, 1)
+#define GET_RX_BD_TOTALRXPKTSIZE(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 16, 13)
+#define GET_RX_BD_RXTAG(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 16, 13)
+#define GET_RX_BD_FS(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 15, 1)
+#define GET_RX_BD_LS(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 14, 1)
+#define GET_RX_BD_RXBUFFSIZE(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 0, 14)
+
+/*TXBD_DW1*/
+
+#define GET_RX_BD_PHYSICAL_ADDR_LOW(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x04, 0, 32)
+
+/*TXBD_DW2*/
+
+#define GET_RX_BD_PHYSICAL_ADDR_HIGH(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x08, 0, 32)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_ap.h
new file mode 100644
index 000000000000..1ba6b92bb6d2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_ap.h
@@ -0,0 +1,614 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_RX_DESC_AP_H_
+#define _HALMAC_RX_DESC_AP_H_
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      30)
+#define GET_RX_DESC_PHYPKTIDC(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_EVT_PKT(rxdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_SWDEC(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      27)
+#define GET_RX_DESC_PHYST(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      26)
+#define GET_RX_DESC_SHIFT(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x3,  \
+			      24)
+#define GET_RX_DESC_QOS(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      23)
+#define GET_RX_DESC_SECURITY(rxdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x7,  \
+			      20)
+#define GET_RX_DESC_DRV_INFO_SIZE(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0xf,  \
+			      16)
+#define GET_RX_DESC_ICV_ERR(rxdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      15)
+#define GET_RX_DESC_CRC32(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1,  \
+			      14)
+#define GET_RX_DESC_PKT_LEN(rxdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0,       \
+			      0x3fff, 0)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC(rxdesc)                                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      31)
+#define GET_RX_DESC_MC(rxdesc)                                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_TY_PE(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x3,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_TYPE(rxdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x3,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MF(rxdesc)                                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      27)
+#define GET_RX_DESC_MD(rxdesc)                                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      26)
+#define GET_RX_DESC_PWR(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      25)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PAM(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_A1_MATCH(rxdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_CHK_VLD(rxdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      23)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_TCP_CHKSUM_VLD(rxdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      23)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      22)
+#define GET_RX_DESC_RX_IPV(rxdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      21)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_CHKERR(rxdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      20)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_TCP_CHKSUM_ERR(rxdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      20)
+#define GET_RX_DESC_PHY_PKT_IDC(rxdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      17)
+#define GET_RX_DESC_FW_FIFO_FULL(rxdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PAGGR(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      15)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_AMPDU(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      15)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RXID_MATCH(rxdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      14)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_RXCMD_IDC(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      14)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_AMSDU(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      13)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MACID_VLD(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1,  \
+			      12)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_TID(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0xf, 8)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MACID(rxdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x7f, \
+			      0)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK(rxdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_AMSDU_CUT(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PPDU_CNT(rxdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x3,  \
+			      29)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_C2H(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_HWRSVD_V1(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x7,  \
+			      25)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_HWRSVD(rxdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0xf,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_RXMAGPKT(rxdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_WLANHD_IV_LEN(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x3f, \
+			      18)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_LAST_MSDU(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      17)
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_STATISTICS(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      17)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_IS_QOS(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_EXT_SEC_TYPE(rxdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_FRAG(rxdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0xf,  \
+			      12)
+#define GET_RX_DESC_SEQ(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2,       \
+			      0xfff, 0)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE(rxdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1,  \
+			      31)
+#define GET_RX_DESC_UNICAST_WAKE(rxdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_MATCH(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1,  \
+			      29)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_WAKE(rxdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1,  \
+			      29)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1,  \
+			      28)
+#define GET_RX_DESC_RXPAYLOAD_ID(rxdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0xf,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_DMA_AGG_NUM(rxdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0xff, \
+			      16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_BSSID_FIT_1_0(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x3,  \
+			      12)
+#define GET_RX_DESC_EOSP(rxdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1,  \
+			      11)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_BSSID_FIT(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1f, \
+			      11)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_HTC(rxdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1,  \
+			      10)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_AMPDU_END_PKT(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, 9)
+#define GET_RX_DESC_ADDRESS_CAM_VLD(rxdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, 8)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_BSSID_FIT_4_2(rxdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x7, 7)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_EOSP_V1(rxdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, 7)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_RATE(rxdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x7f, \
+			      0)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT(rxdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1f, \
+			      24)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_ADDRESS_CAM(rxdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0xff, \
+			      24)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_A1_FIT_A1(rxdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x7f, \
+			      24)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_MACID_VLD_V1(rxdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1,  \
+			      23)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MACID_RPT_BUFF(rxdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x7f, \
+			      17)
+#define GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_MACID_V1(rxdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0xff, \
+			      15)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_SCRAMBLER(rxdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x7f, \
+			      9)
+#define GET_RX_DESC_RX_EOF(rxdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 8)
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_FC_POWER(rxdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 7)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_TXRPTMID_CTL_MASK(rxdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 6)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_SWPS_RPT(rxdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 5)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_IDX(rxdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0xff, \
+			      0)
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_IDX_V1(rxdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1f, \
+			      0)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_IDX_V2(rxdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1f, \
+			      0)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL(rxdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword5,       \
+			      0xffffffff, 0)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_FREERUN_CNT(rxdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword5,       \
+			      0xffffffff, 0)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_chip.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_chip.h
new file mode 100644
index 000000000000..ac36d0a2b1e2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_chip.h
@@ -0,0 +1,611 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_RX_DESC_CHIP_H_
+#define _HALMAC_RX_DESC_CHIP_H_
+#if (HALMAC_8814A_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR_8814A(rxdesc) GET_RX_DESC_EOR(rxdesc)
+#define GET_RX_DESC_PHYPKTIDC_8814A(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
+#define GET_RX_DESC_SWDEC_8814A(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
+#define GET_RX_DESC_PHYST_8814A(rxdesc) GET_RX_DESC_PHYST(rxdesc)
+#define GET_RX_DESC_SHIFT_8814A(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
+#define GET_RX_DESC_QOS_8814A(rxdesc) GET_RX_DESC_QOS(rxdesc)
+#define GET_RX_DESC_SECURITY_8814A(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
+#define GET_RX_DESC_DRV_INFO_SIZE_8814A(rxdesc)                                \
+	GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
+#define GET_RX_DESC_ICV_ERR_8814A(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
+#define GET_RX_DESC_CRC32_8814A(rxdesc) GET_RX_DESC_CRC32(rxdesc)
+#define GET_RX_DESC_PKT_LEN_8814A(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC_8814A(rxdesc) GET_RX_DESC_BC(rxdesc)
+#define GET_RX_DESC_MC_8814A(rxdesc) GET_RX_DESC_MC(rxdesc)
+#define GET_RX_DESC_TY_PE_8814A(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
+#define GET_RX_DESC_MF_8814A(rxdesc) GET_RX_DESC_MF(rxdesc)
+#define GET_RX_DESC_MD_8814A(rxdesc) GET_RX_DESC_MD(rxdesc)
+#define GET_RX_DESC_PWR_8814A(rxdesc) GET_RX_DESC_PWR(rxdesc)
+#define GET_RX_DESC_PAM_8814A(rxdesc) GET_RX_DESC_PAM(rxdesc)
+#define GET_RX_DESC_CHK_VLD_8814A(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
+#define GET_RX_DESC_RX_IS_TCP_UDP_8814A(rxdesc)                                \
+	GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
+#define GET_RX_DESC_RX_IPV_8814A(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
+#define GET_RX_DESC_CHKERR_8814A(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
+#define GET_RX_DESC_PAGGR_8814A(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
+#define GET_RX_DESC_RXID_MATCH_8814A(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
+#define GET_RX_DESC_AMSDU_8814A(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
+#define GET_RX_DESC_MACID_VLD_8814A(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
+#define GET_RX_DESC_TID_8814A(rxdesc) GET_RX_DESC_TID(rxdesc)
+#define GET_RX_DESC_MACID_8814A(rxdesc) GET_RX_DESC_MACID(rxdesc)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK_8814A(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
+#define GET_RX_DESC_C2H_8814A(rxdesc) GET_RX_DESC_C2H(rxdesc)
+#define GET_RX_DESC_HWRSVD_8814A(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
+#define GET_RX_DESC_WLANHD_IV_LEN_8814A(rxdesc)                                \
+	GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
+#define GET_RX_DESC_RX_IS_QOS_8814A(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
+#define GET_RX_DESC_FRAG_8814A(rxdesc) GET_RX_DESC_FRAG(rxdesc)
+#define GET_RX_DESC_SEQ_8814A(rxdesc) GET_RX_DESC_SEQ(rxdesc)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE_8814A(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
+#define GET_RX_DESC_UNICAST_WAKE_8814A(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
+#define GET_RX_DESC_PATTERN_MATCH_8814A(rxdesc)                                \
+	GET_RX_DESC_PATTERN_MATCH(rxdesc)
+#define GET_RX_DESC_DMA_AGG_NUM_8814A(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_1_0_8814A(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
+#define GET_RX_DESC_EOSP_8814A(rxdesc) GET_RX_DESC_EOSP(rxdesc)
+#define GET_RX_DESC_HTC_8814A(rxdesc) GET_RX_DESC_HTC(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_4_2_8814A(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
+#define GET_RX_DESC_RX_RATE_8814A(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT_8814A(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
+#define GET_RX_DESC_MACID_RPT_BUFF_8814A(rxdesc)                               \
+	GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
+#define GET_RX_DESC_RX_PRE_NDP_VLD_8814A(rxdesc)                               \
+	GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
+#define GET_RX_DESC_RX_SCRAMBLER_8814A(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
+#define GET_RX_DESC_RX_EOF_8814A(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
+#define GET_RX_DESC_PATTERN_IDX_8814A(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL_8814A(rxdesc) GET_RX_DESC_TSFL(rxdesc)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR_8822B(rxdesc) GET_RX_DESC_EOR(rxdesc)
+#define GET_RX_DESC_PHYPKTIDC_8822B(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
+#define GET_RX_DESC_SWDEC_8822B(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
+#define GET_RX_DESC_PHYST_8822B(rxdesc) GET_RX_DESC_PHYST(rxdesc)
+#define GET_RX_DESC_SHIFT_8822B(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
+#define GET_RX_DESC_QOS_8822B(rxdesc) GET_RX_DESC_QOS(rxdesc)
+#define GET_RX_DESC_SECURITY_8822B(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
+#define GET_RX_DESC_DRV_INFO_SIZE_8822B(rxdesc)                                \
+	GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
+#define GET_RX_DESC_ICV_ERR_8822B(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
+#define GET_RX_DESC_CRC32_8822B(rxdesc) GET_RX_DESC_CRC32(rxdesc)
+#define GET_RX_DESC_PKT_LEN_8822B(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC_8822B(rxdesc) GET_RX_DESC_BC(rxdesc)
+#define GET_RX_DESC_MC_8822B(rxdesc) GET_RX_DESC_MC(rxdesc)
+#define GET_RX_DESC_TY_PE_8822B(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
+#define GET_RX_DESC_MF_8822B(rxdesc) GET_RX_DESC_MF(rxdesc)
+#define GET_RX_DESC_MD_8822B(rxdesc) GET_RX_DESC_MD(rxdesc)
+#define GET_RX_DESC_PWR_8822B(rxdesc) GET_RX_DESC_PWR(rxdesc)
+#define GET_RX_DESC_PAM_8822B(rxdesc) GET_RX_DESC_PAM(rxdesc)
+#define GET_RX_DESC_CHK_VLD_8822B(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
+#define GET_RX_DESC_RX_IS_TCP_UDP_8822B(rxdesc)                                \
+	GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
+#define GET_RX_DESC_RX_IPV_8822B(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
+#define GET_RX_DESC_CHKERR_8822B(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
+#define GET_RX_DESC_PAGGR_8822B(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
+#define GET_RX_DESC_RXID_MATCH_8822B(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
+#define GET_RX_DESC_AMSDU_8822B(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
+#define GET_RX_DESC_MACID_VLD_8822B(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
+#define GET_RX_DESC_TID_8822B(rxdesc) GET_RX_DESC_TID(rxdesc)
+#define GET_RX_DESC_MACID_8822B(rxdesc) GET_RX_DESC_MACID(rxdesc)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK_8822B(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
+#define GET_RX_DESC_PPDU_CNT_8822B(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
+#define GET_RX_DESC_C2H_8822B(rxdesc) GET_RX_DESC_C2H(rxdesc)
+#define GET_RX_DESC_HWRSVD_8822B(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
+#define GET_RX_DESC_WLANHD_IV_LEN_8822B(rxdesc)                                \
+	GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
+#define GET_RX_DESC_RX_IS_QOS_8822B(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
+#define GET_RX_DESC_FRAG_8822B(rxdesc) GET_RX_DESC_FRAG(rxdesc)
+#define GET_RX_DESC_SEQ_8822B(rxdesc) GET_RX_DESC_SEQ(rxdesc)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE_8822B(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
+#define GET_RX_DESC_UNICAST_WAKE_8822B(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
+#define GET_RX_DESC_PATTERN_MATCH_8822B(rxdesc)                                \
+	GET_RX_DESC_PATTERN_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_MATCH_8822B(rxdesc)                              \
+	GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_ID_8822B(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
+#define GET_RX_DESC_DMA_AGG_NUM_8822B(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_1_0_8822B(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
+#define GET_RX_DESC_EOSP_8822B(rxdesc) GET_RX_DESC_EOSP(rxdesc)
+#define GET_RX_DESC_HTC_8822B(rxdesc) GET_RX_DESC_HTC(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_4_2_8822B(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
+#define GET_RX_DESC_RX_RATE_8822B(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT_8822B(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
+#define GET_RX_DESC_MACID_RPT_BUFF_8822B(rxdesc)                               \
+	GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
+#define GET_RX_DESC_RX_PRE_NDP_VLD_8822B(rxdesc)                               \
+	GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
+#define GET_RX_DESC_RX_SCRAMBLER_8822B(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
+#define GET_RX_DESC_RX_EOF_8822B(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
+#define GET_RX_DESC_PATTERN_IDX_8822B(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL_8822B(rxdesc) GET_RX_DESC_TSFL(rxdesc)
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR_8197F(rxdesc) GET_RX_DESC_EOR(rxdesc)
+#define GET_RX_DESC_PHYPKTIDC_8197F(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
+#define GET_RX_DESC_SWDEC_8197F(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
+#define GET_RX_DESC_PHYST_8197F(rxdesc) GET_RX_DESC_PHYST(rxdesc)
+#define GET_RX_DESC_SHIFT_8197F(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
+#define GET_RX_DESC_QOS_8197F(rxdesc) GET_RX_DESC_QOS(rxdesc)
+#define GET_RX_DESC_SECURITY_8197F(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
+#define GET_RX_DESC_DRV_INFO_SIZE_8197F(rxdesc)                                \
+	GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
+#define GET_RX_DESC_ICV_ERR_8197F(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
+#define GET_RX_DESC_CRC32_8197F(rxdesc) GET_RX_DESC_CRC32(rxdesc)
+#define GET_RX_DESC_PKT_LEN_8197F(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC_8197F(rxdesc) GET_RX_DESC_BC(rxdesc)
+#define GET_RX_DESC_MC_8197F(rxdesc) GET_RX_DESC_MC(rxdesc)
+#define GET_RX_DESC_TY_PE_8197F(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
+#define GET_RX_DESC_MF_8197F(rxdesc) GET_RX_DESC_MF(rxdesc)
+#define GET_RX_DESC_MD_8197F(rxdesc) GET_RX_DESC_MD(rxdesc)
+#define GET_RX_DESC_PWR_8197F(rxdesc) GET_RX_DESC_PWR(rxdesc)
+#define GET_RX_DESC_PAM_8197F(rxdesc) GET_RX_DESC_PAM(rxdesc)
+#define GET_RX_DESC_CHK_VLD_8197F(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
+#define GET_RX_DESC_RX_IS_TCP_UDP_8197F(rxdesc)                                \
+	GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
+#define GET_RX_DESC_RX_IPV_8197F(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
+#define GET_RX_DESC_CHKERR_8197F(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
+#define GET_RX_DESC_PAGGR_8197F(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
+#define GET_RX_DESC_RXID_MATCH_8197F(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
+#define GET_RX_DESC_AMSDU_8197F(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
+#define GET_RX_DESC_MACID_VLD_8197F(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
+#define GET_RX_DESC_TID_8197F(rxdesc) GET_RX_DESC_TID(rxdesc)
+#define GET_RX_DESC_MACID_8197F(rxdesc) GET_RX_DESC_MACID(rxdesc)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK_8197F(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
+#define GET_RX_DESC_C2H_8197F(rxdesc) GET_RX_DESC_C2H(rxdesc)
+#define GET_RX_DESC_HWRSVD_8197F(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
+#define GET_RX_DESC_WLANHD_IV_LEN_8197F(rxdesc)                                \
+	GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
+#define GET_RX_DESC_RX_IS_QOS_8197F(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
+#define GET_RX_DESC_FRAG_8197F(rxdesc) GET_RX_DESC_FRAG(rxdesc)
+#define GET_RX_DESC_SEQ_8197F(rxdesc) GET_RX_DESC_SEQ(rxdesc)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE_8197F(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
+#define GET_RX_DESC_UNICAST_WAKE_8197F(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
+#define GET_RX_DESC_PATTERN_MATCH_8197F(rxdesc)                                \
+	GET_RX_DESC_PATTERN_MATCH(rxdesc)
+#define GET_RX_DESC_DMA_AGG_NUM_8197F(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_1_0_8197F(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
+#define GET_RX_DESC_EOSP_8197F(rxdesc) GET_RX_DESC_EOSP(rxdesc)
+#define GET_RX_DESC_HTC_8197F(rxdesc) GET_RX_DESC_HTC(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_4_2_8197F(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
+#define GET_RX_DESC_RX_RATE_8197F(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT_8197F(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
+#define GET_RX_DESC_MACID_RPT_BUFF_8197F(rxdesc)                               \
+	GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
+#define GET_RX_DESC_RX_PRE_NDP_VLD_8197F(rxdesc)                               \
+	GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
+#define GET_RX_DESC_RX_SCRAMBLER_8197F(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
+#define GET_RX_DESC_RX_EOF_8197F(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
+#define GET_RX_DESC_FC_POWER_8197F(rxdesc) GET_RX_DESC_FC_POWER(rxdesc)
+#define GET_RX_DESC_PATTERN_IDX_8197F(rxdesc) GET_RX_DESC_PATTERN_IDX_V1(rxdesc)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL_8197F(rxdesc) GET_RX_DESC_TSFL(rxdesc)
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR_8821C(rxdesc) GET_RX_DESC_EOR(rxdesc)
+#define GET_RX_DESC_PHYPKTIDC_8821C(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
+#define GET_RX_DESC_SWDEC_8821C(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
+#define GET_RX_DESC_PHYST_8821C(rxdesc) GET_RX_DESC_PHYST(rxdesc)
+#define GET_RX_DESC_SHIFT_8821C(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
+#define GET_RX_DESC_QOS_8821C(rxdesc) GET_RX_DESC_QOS(rxdesc)
+#define GET_RX_DESC_SECURITY_8821C(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
+#define GET_RX_DESC_DRV_INFO_SIZE_8821C(rxdesc)                                \
+	GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
+#define GET_RX_DESC_ICV_ERR_8821C(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
+#define GET_RX_DESC_CRC32_8821C(rxdesc) GET_RX_DESC_CRC32(rxdesc)
+#define GET_RX_DESC_PKT_LEN_8821C(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC_8821C(rxdesc) GET_RX_DESC_BC(rxdesc)
+#define GET_RX_DESC_MC_8821C(rxdesc) GET_RX_DESC_MC(rxdesc)
+#define GET_RX_DESC_TY_PE_8821C(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
+#define GET_RX_DESC_MF_8821C(rxdesc) GET_RX_DESC_MF(rxdesc)
+#define GET_RX_DESC_MD_8821C(rxdesc) GET_RX_DESC_MD(rxdesc)
+#define GET_RX_DESC_PWR_8821C(rxdesc) GET_RX_DESC_PWR(rxdesc)
+#define GET_RX_DESC_PAM_8821C(rxdesc) GET_RX_DESC_PAM(rxdesc)
+#define GET_RX_DESC_CHK_VLD_8821C(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
+#define GET_RX_DESC_RX_IS_TCP_UDP_8821C(rxdesc)                                \
+	GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
+#define GET_RX_DESC_RX_IPV_8821C(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
+#define GET_RX_DESC_CHKERR_8821C(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
+#define GET_RX_DESC_PAGGR_8821C(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
+#define GET_RX_DESC_RXID_MATCH_8821C(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
+#define GET_RX_DESC_AMSDU_8821C(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
+#define GET_RX_DESC_MACID_VLD_8821C(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
+#define GET_RX_DESC_TID_8821C(rxdesc) GET_RX_DESC_TID(rxdesc)
+#define GET_RX_DESC_MACID_8821C(rxdesc) GET_RX_DESC_MACID(rxdesc)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK_8821C(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
+#define GET_RX_DESC_PPDU_CNT_8821C(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
+#define GET_RX_DESC_C2H_8821C(rxdesc) GET_RX_DESC_C2H(rxdesc)
+#define GET_RX_DESC_HWRSVD_8821C(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
+#define GET_RX_DESC_WLANHD_IV_LEN_8821C(rxdesc)                                \
+	GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
+#define GET_RX_DESC_RX_IS_QOS_8821C(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
+#define GET_RX_DESC_FRAG_8821C(rxdesc) GET_RX_DESC_FRAG(rxdesc)
+#define GET_RX_DESC_SEQ_8821C(rxdesc) GET_RX_DESC_SEQ(rxdesc)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE_8821C(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
+#define GET_RX_DESC_UNICAST_WAKE_8821C(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
+#define GET_RX_DESC_PATTERN_MATCH_8821C(rxdesc)                                \
+	GET_RX_DESC_PATTERN_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_MATCH_8821C(rxdesc)                              \
+	GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_ID_8821C(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
+#define GET_RX_DESC_DMA_AGG_NUM_8821C(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_1_0_8821C(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
+#define GET_RX_DESC_EOSP_8821C(rxdesc) GET_RX_DESC_EOSP(rxdesc)
+#define GET_RX_DESC_HTC_8821C(rxdesc) GET_RX_DESC_HTC(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_4_2_8821C(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
+#define GET_RX_DESC_RX_RATE_8821C(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT_8821C(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
+#define GET_RX_DESC_MACID_RPT_BUFF_8821C(rxdesc)                               \
+	GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
+#define GET_RX_DESC_RX_PRE_NDP_VLD_8821C(rxdesc)                               \
+	GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
+#define GET_RX_DESC_RX_SCRAMBLER_8821C(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
+#define GET_RX_DESC_RX_EOF_8821C(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
+#define GET_RX_DESC_PATTERN_IDX_8821C(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL_8821C(rxdesc) GET_RX_DESC_TSFL(rxdesc)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EVT_PKT_8814B(rxdesc) GET_RX_DESC_EVT_PKT(rxdesc)
+#define GET_RX_DESC_SWDEC_8814B(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
+#define GET_RX_DESC_PHYST_8814B(rxdesc) GET_RX_DESC_PHYST(rxdesc)
+#define GET_RX_DESC_SHIFT_8814B(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
+#define GET_RX_DESC_QOS_8814B(rxdesc) GET_RX_DESC_QOS(rxdesc)
+#define GET_RX_DESC_SECURITY_8814B(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
+#define GET_RX_DESC_DRV_INFO_SIZE_8814B(rxdesc)                                \
+	GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
+#define GET_RX_DESC_ICV_ERR_8814B(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
+#define GET_RX_DESC_CRC32_8814B(rxdesc) GET_RX_DESC_CRC32(rxdesc)
+#define GET_RX_DESC_PKT_LEN_8814B(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC_8814B(rxdesc) GET_RX_DESC_BC(rxdesc)
+#define GET_RX_DESC_MC_8814B(rxdesc) GET_RX_DESC_MC(rxdesc)
+#define GET_RX_DESC_TYPE_8814B(rxdesc) GET_RX_DESC_TYPE(rxdesc)
+#define GET_RX_DESC_MF_8814B(rxdesc) GET_RX_DESC_MF(rxdesc)
+#define GET_RX_DESC_MD_8814B(rxdesc) GET_RX_DESC_MD(rxdesc)
+#define GET_RX_DESC_PWR_8814B(rxdesc) GET_RX_DESC_PWR(rxdesc)
+#define GET_RX_DESC_A1_MATCH_8814B(rxdesc) GET_RX_DESC_A1_MATCH(rxdesc)
+#define GET_RX_DESC_TCP_CHKSUM_VLD_8814B(rxdesc)                               \
+	GET_RX_DESC_TCP_CHKSUM_VLD(rxdesc)
+#define GET_RX_DESC_RX_IS_TCP_UDP_8814B(rxdesc)                                \
+	GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
+#define GET_RX_DESC_RX_IPV_8814B(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
+#define GET_RX_DESC_TCP_CHKSUM_ERR_8814B(rxdesc)                               \
+	GET_RX_DESC_TCP_CHKSUM_ERR(rxdesc)
+#define GET_RX_DESC_PHY_PKT_IDC_8814B(rxdesc) GET_RX_DESC_PHY_PKT_IDC(rxdesc)
+#define GET_RX_DESC_FW_FIFO_FULL_8814B(rxdesc) GET_RX_DESC_FW_FIFO_FULL(rxdesc)
+#define GET_RX_DESC_AMPDU_8814B(rxdesc) GET_RX_DESC_AMPDU(rxdesc)
+#define GET_RX_DESC_RXCMD_IDC_8814B(rxdesc) GET_RX_DESC_RXCMD_IDC(rxdesc)
+#define GET_RX_DESC_AMSDU_8814B(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
+#define GET_RX_DESC_TID_8814B(rxdesc) GET_RX_DESC_TID(rxdesc)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_AMSDU_CUT_8814B(rxdesc) GET_RX_DESC_AMSDU_CUT(rxdesc)
+#define GET_RX_DESC_PPDU_CNT_8814B(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
+#define GET_RX_DESC_C2H_8814B(rxdesc) GET_RX_DESC_C2H(rxdesc)
+#define GET_RX_DESC_WLANHD_IV_LEN_8814B(rxdesc)                                \
+	GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
+#define GET_RX_DESC_LAST_MSDU_8814B(rxdesc) GET_RX_DESC_LAST_MSDU(rxdesc)
+#define GET_RX_DESC_EXT_SEC_TYPE_8814B(rxdesc) GET_RX_DESC_EXT_SEC_TYPE(rxdesc)
+#define GET_RX_DESC_FRAG_8814B(rxdesc) GET_RX_DESC_FRAG(rxdesc)
+#define GET_RX_DESC_SEQ_8814B(rxdesc) GET_RX_DESC_SEQ(rxdesc)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE_8814B(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
+#define GET_RX_DESC_UNICAST_WAKE_8814B(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
+#define GET_RX_DESC_PATTERN_WAKE_8814B(rxdesc) GET_RX_DESC_PATTERN_WAKE(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_MATCH_8814B(rxdesc)                              \
+	GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_ID_8814B(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
+#define GET_RX_DESC_DMA_AGG_NUM_8814B(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_8814B(rxdesc) GET_RX_DESC_BSSID_FIT(rxdesc)
+#define GET_RX_DESC_HTC_8814B(rxdesc) GET_RX_DESC_HTC(rxdesc)
+#define GET_RX_DESC_AMPDU_END_PKT_8814B(rxdesc)                                \
+	GET_RX_DESC_AMPDU_END_PKT(rxdesc)
+#define GET_RX_DESC_ADDRESS_CAM_VLD_8814B(rxdesc)                              \
+	GET_RX_DESC_ADDRESS_CAM_VLD(rxdesc)
+#define GET_RX_DESC_EOSP_8814B(rxdesc) GET_RX_DESC_EOSP_V1(rxdesc)
+#define GET_RX_DESC_RX_RATE_8814B(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_ADDRESS_CAM_8814B(rxdesc) GET_RX_DESC_ADDRESS_CAM(rxdesc)
+#define GET_RX_DESC_MACID_VLD_8814B(rxdesc) GET_RX_DESC_MACID_VLD_V1(rxdesc)
+#define GET_RX_DESC_MACID_8814B(rxdesc) GET_RX_DESC_MACID_V1(rxdesc)
+#define GET_RX_DESC_SWPS_RPT_8814B(rxdesc) GET_RX_DESC_SWPS_RPT(rxdesc)
+#define GET_RX_DESC_PATTERN_IDX_8814B(rxdesc) GET_RX_DESC_PATTERN_IDX_V2(rxdesc)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_FREERUN_CNT_8814B(rxdesc) GET_RX_DESC_FREERUN_CNT(rxdesc)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR_8198F(rxdesc) GET_RX_DESC_EOR(rxdesc)
+#define GET_RX_DESC_PHYPKTIDC_8198F(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
+#define GET_RX_DESC_SWDEC_8198F(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
+#define GET_RX_DESC_PHYST_8198F(rxdesc) GET_RX_DESC_PHYST(rxdesc)
+#define GET_RX_DESC_SHIFT_8198F(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
+#define GET_RX_DESC_QOS_8198F(rxdesc) GET_RX_DESC_QOS(rxdesc)
+#define GET_RX_DESC_SECURITY_8198F(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
+#define GET_RX_DESC_DRV_INFO_SIZE_8198F(rxdesc)                                \
+	GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
+#define GET_RX_DESC_ICV_ERR_8198F(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
+#define GET_RX_DESC_CRC32_8198F(rxdesc) GET_RX_DESC_CRC32(rxdesc)
+#define GET_RX_DESC_PKT_LEN_8198F(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC_8198F(rxdesc) GET_RX_DESC_BC(rxdesc)
+#define GET_RX_DESC_MC_8198F(rxdesc) GET_RX_DESC_MC(rxdesc)
+#define GET_RX_DESC_TY_PE_8198F(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
+#define GET_RX_DESC_MF_8198F(rxdesc) GET_RX_DESC_MF(rxdesc)
+#define GET_RX_DESC_MD_8198F(rxdesc) GET_RX_DESC_MD(rxdesc)
+#define GET_RX_DESC_PWR_8198F(rxdesc) GET_RX_DESC_PWR(rxdesc)
+#define GET_RX_DESC_PAM_8198F(rxdesc) GET_RX_DESC_PAM(rxdesc)
+#define GET_RX_DESC_CHK_VLD_8198F(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
+#define GET_RX_DESC_RX_IS_TCP_UDP_8198F(rxdesc)                                \
+	GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
+#define GET_RX_DESC_RX_IPV_8198F(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
+#define GET_RX_DESC_CHKERR_8198F(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
+#define GET_RX_DESC_PAGGR_8198F(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
+#define GET_RX_DESC_RXID_MATCH_8198F(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
+#define GET_RX_DESC_AMSDU_8198F(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
+#define GET_RX_DESC_MACID_VLD_8198F(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
+#define GET_RX_DESC_TID_8198F(rxdesc) GET_RX_DESC_TID(rxdesc)
+#define GET_RX_DESC_MACID_8198F(rxdesc) GET_RX_DESC_MACID(rxdesc)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK_8198F(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
+#define GET_RX_DESC_PPDU_CNT_8198F(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
+#define GET_RX_DESC_C2H_8198F(rxdesc) GET_RX_DESC_C2H(rxdesc)
+#define GET_RX_DESC_HWRSVD_8198F(rxdesc) GET_RX_DESC_HWRSVD_V1(rxdesc)
+#define GET_RX_DESC_RXMAGPKT_8198F(rxdesc) GET_RX_DESC_RXMAGPKT(rxdesc)
+#define GET_RX_DESC_WLANHD_IV_LEN_8198F(rxdesc)                                \
+	GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
+#define GET_RX_DESC_RX_IS_QOS_8198F(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
+#define GET_RX_DESC_FRAG_8198F(rxdesc) GET_RX_DESC_FRAG(rxdesc)
+#define GET_RX_DESC_SEQ_8198F(rxdesc) GET_RX_DESC_SEQ(rxdesc)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE_8198F(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
+#define GET_RX_DESC_UNICAST_WAKE_8198F(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
+#define GET_RX_DESC_PATTERN_MATCH_8198F(rxdesc)                                \
+	GET_RX_DESC_PATTERN_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_MATCH_8198F(rxdesc)                              \
+	GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_ID_8198F(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
+#define GET_RX_DESC_DMA_AGG_NUM_8198F(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_1_0_8198F(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
+#define GET_RX_DESC_EOSP_8198F(rxdesc) GET_RX_DESC_EOSP(rxdesc)
+#define GET_RX_DESC_HTC_8198F(rxdesc) GET_RX_DESC_HTC(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_4_2_8198F(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
+#define GET_RX_DESC_RX_RATE_8198F(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT_A1_8198F(rxdesc) GET_RX_DESC_A1_FIT_A1(rxdesc)
+#define GET_RX_DESC_MACID_RPT_BUFF_8198F(rxdesc)                               \
+	GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
+#define GET_RX_DESC_RX_PRE_NDP_VLD_8198F(rxdesc)                               \
+	GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
+#define GET_RX_DESC_RX_SCRAMBLER_8198F(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
+#define GET_RX_DESC_RX_EOF_8198F(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
+#define GET_RX_DESC_FC_POWER_8198F(rxdesc) GET_RX_DESC_FC_POWER(rxdesc)
+#define GET_RX_DESC_TXRPTMID_CTL_MASK_8198F(rxdesc)                            \
+	GET_RX_DESC_TXRPTMID_CTL_MASK(rxdesc)
+#define GET_RX_DESC_SWPS_RPT_8198F(rxdesc) GET_RX_DESC_SWPS_RPT(rxdesc)
+#define GET_RX_DESC_PATTERN_IDX_8198F(rxdesc) GET_RX_DESC_PATTERN_IDX_V1(rxdesc)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL_8198F(rxdesc) GET_RX_DESC_TSFL(rxdesc)
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR_8822C(rxdesc) GET_RX_DESC_EOR(rxdesc)
+#define GET_RX_DESC_PHYPKTIDC_8822C(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
+#define GET_RX_DESC_SWDEC_8822C(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
+#define GET_RX_DESC_PHYST_8822C(rxdesc) GET_RX_DESC_PHYST(rxdesc)
+#define GET_RX_DESC_SHIFT_8822C(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
+#define GET_RX_DESC_QOS_8822C(rxdesc) GET_RX_DESC_QOS(rxdesc)
+#define GET_RX_DESC_SECURITY_8822C(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
+#define GET_RX_DESC_DRV_INFO_SIZE_8822C(rxdesc)                                \
+	GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
+#define GET_RX_DESC_ICV_ERR_8822C(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
+#define GET_RX_DESC_CRC32_8822C(rxdesc) GET_RX_DESC_CRC32(rxdesc)
+#define GET_RX_DESC_PKT_LEN_8822C(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC_8822C(rxdesc) GET_RX_DESC_BC(rxdesc)
+#define GET_RX_DESC_MC_8822C(rxdesc) GET_RX_DESC_MC(rxdesc)
+#define GET_RX_DESC_TY_PE_8822C(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
+#define GET_RX_DESC_MF_8822C(rxdesc) GET_RX_DESC_MF(rxdesc)
+#define GET_RX_DESC_MD_8822C(rxdesc) GET_RX_DESC_MD(rxdesc)
+#define GET_RX_DESC_PWR_8822C(rxdesc) GET_RX_DESC_PWR(rxdesc)
+#define GET_RX_DESC_PAM_8822C(rxdesc) GET_RX_DESC_PAM(rxdesc)
+#define GET_RX_DESC_CHK_VLD_8822C(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
+#define GET_RX_DESC_RX_IS_TCP_UDP_8822C(rxdesc)                                \
+	GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
+#define GET_RX_DESC_RX_IPV_8822C(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
+#define GET_RX_DESC_CHKERR_8822C(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
+#define GET_RX_DESC_PAGGR_8822C(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
+#define GET_RX_DESC_RXID_MATCH_8822C(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
+#define GET_RX_DESC_AMSDU_8822C(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
+#define GET_RX_DESC_MACID_VLD_8822C(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
+#define GET_RX_DESC_TID_8822C(rxdesc) GET_RX_DESC_TID(rxdesc)
+#define GET_RX_DESC_MACID_8822C(rxdesc) GET_RX_DESC_MACID(rxdesc)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK_8822C(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
+#define GET_RX_DESC_PPDU_CNT_8822C(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
+#define GET_RX_DESC_C2H_8822C(rxdesc) GET_RX_DESC_C2H(rxdesc)
+#define GET_RX_DESC_HWRSVD_8822C(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
+#define GET_RX_DESC_WLANHD_IV_LEN_8822C(rxdesc)                                \
+	GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
+#define GET_RX_DESC_RX_STATISTICS_8822C(rxdesc)                                \
+	GET_RX_DESC_RX_STATISTICS(rxdesc)
+#define GET_RX_DESC_RX_IS_QOS_8822C(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
+#define GET_RX_DESC_FRAG_8822C(rxdesc) GET_RX_DESC_FRAG(rxdesc)
+#define GET_RX_DESC_SEQ_8822C(rxdesc) GET_RX_DESC_SEQ(rxdesc)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE_8822C(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
+#define GET_RX_DESC_UNICAST_WAKE_8822C(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
+#define GET_RX_DESC_PATTERN_MATCH_8822C(rxdesc)                                \
+	GET_RX_DESC_PATTERN_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_MATCH_8822C(rxdesc)                              \
+	GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
+#define GET_RX_DESC_RXPAYLOAD_ID_8822C(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
+#define GET_RX_DESC_DMA_AGG_NUM_8822C(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_1_0_8822C(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
+#define GET_RX_DESC_EOSP_8822C(rxdesc) GET_RX_DESC_EOSP(rxdesc)
+#define GET_RX_DESC_HTC_8822C(rxdesc) GET_RX_DESC_HTC(rxdesc)
+#define GET_RX_DESC_BSSID_FIT_4_2_8822C(rxdesc)                                \
+	GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
+#define GET_RX_DESC_RX_RATE_8822C(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT_8822C(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
+#define GET_RX_DESC_MACID_RPT_BUFF_8822C(rxdesc)                               \
+	GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
+#define GET_RX_DESC_RX_PRE_NDP_VLD_8822C(rxdesc)                               \
+	GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
+#define GET_RX_DESC_RX_SCRAMBLER_8822C(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
+#define GET_RX_DESC_RX_EOF_8822C(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
+#define GET_RX_DESC_PATTERN_IDX_8822C(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL_8822C(rxdesc) GET_RX_DESC_TSFL(rxdesc)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_nic.h
new file mode 100644
index 000000000000..a3baf980feda
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_rx_desc_nic.h
@@ -0,0 +1,462 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_RX_DESC_NIC_H_
+#define _HALMAC_RX_DESC_NIC_H_
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*RXDESC_WORD0*/
+
+#define GET_RX_DESC_EOR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 30, 1)
+#define GET_RX_DESC_PHYPKTIDC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 28, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_EVT_PKT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 28, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_SWDEC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 27, 1)
+#define GET_RX_DESC_PHYST(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 26, 1)
+#define GET_RX_DESC_SHIFT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 24, 2)
+#define GET_RX_DESC_QOS(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 23, 1)
+#define GET_RX_DESC_SECURITY(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 20, 3)
+#define GET_RX_DESC_DRV_INFO_SIZE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 16, 4)
+#define GET_RX_DESC_ICV_ERR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 15, 1)
+#define GET_RX_DESC_CRC32(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 14, 1)
+#define GET_RX_DESC_PKT_LEN(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 0, 14)
+
+/*RXDESC_WORD1*/
+
+#define GET_RX_DESC_BC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 31, 1)
+#define GET_RX_DESC_MC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 30, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_TY_PE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 28, 2)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_TYPE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 28, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MF(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 27, 1)
+#define GET_RX_DESC_MD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 26, 1)
+#define GET_RX_DESC_PWR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 25, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PAM(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 24, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_A1_MATCH(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 24, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_CHK_VLD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 23, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_TCP_CHKSUM_VLD(rxdesc)                                     \
+	LE_BITS_TO_4BYTE(rxdesc + 0x04, 23, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_IS_TCP_UDP(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 22, 1)
+#define GET_RX_DESC_RX_IPV(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 21, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_CHKERR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 20, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_TCP_CHKSUM_ERR(rxdesc)                                     \
+	LE_BITS_TO_4BYTE(rxdesc + 0x04, 20, 1)
+#define GET_RX_DESC_PHY_PKT_IDC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 17, 1)
+#define GET_RX_DESC_FW_FIFO_FULL(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 16, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PAGGR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 15, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_AMPDU(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 15, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RXID_MATCH(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 14, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_RXCMD_IDC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 14, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_AMSDU(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 13, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MACID_VLD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 12, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_TID(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 8, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MACID(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 0, 7)
+
+/*RXDESC_WORD2*/
+
+#define GET_RX_DESC_FCS_OK(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 31, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_AMSDU_CUT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 31, 1)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PPDU_CNT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 29, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_C2H(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 28, 1)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_HWRSVD_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 25, 3)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_HWRSVD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 24, 4)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_RXMAGPKT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 24, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_WLANHD_IV_LEN(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 18, 6)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_LAST_MSDU(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 17, 1)
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_STATISTICS(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 17, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_IS_QOS(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 16, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_EXT_SEC_TYPE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 16, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_FRAG(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 12, 4)
+#define GET_RX_DESC_SEQ(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 0, 12)
+
+/*RXDESC_WORD3*/
+
+#define GET_RX_DESC_MAGIC_WAKE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 31, 1)
+#define GET_RX_DESC_UNICAST_WAKE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 30, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_MATCH(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 29, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_WAKE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 29, 1)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)                                    \
+	LE_BITS_TO_4BYTE(rxdesc + 0x0C, 28, 1)
+#define GET_RX_DESC_RXPAYLOAD_ID(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 24, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_DMA_AGG_NUM(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 16, 8)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_BSSID_FIT_1_0(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 12, 2)
+#define GET_RX_DESC_EOSP(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 11, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_BSSID_FIT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 11, 5)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_HTC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 10, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_AMPDU_END_PKT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 9, 1)
+#define GET_RX_DESC_ADDRESS_CAM_VLD(rxdesc)                                    \
+	LE_BITS_TO_4BYTE(rxdesc + 0x0C, 8, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_BSSID_FIT_4_2(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 7, 3)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_EOSP_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 7, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_RATE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 0, 7)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*RXDESC_WORD4*/
+
+#define GET_RX_DESC_A1_FIT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 24, 5)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_ADDRESS_CAM(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 24, 8)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_A1_FIT_A1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 24, 7)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_MACID_VLD_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 23, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_MACID_RPT_BUFF(rxdesc)                                     \
+	LE_BITS_TO_4BYTE(rxdesc + 0x10, 17, 7)
+#define GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)                                     \
+	LE_BITS_TO_4BYTE(rxdesc + 0x10, 16, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_MACID_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 15, 8)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_RX_SCRAMBLER(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 9, 7)
+#define GET_RX_DESC_RX_EOF(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 8, 1)
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_FC_POWER(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 7, 1)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_TXRPTMID_CTL_MASK(rxdesc)                                  \
+	LE_BITS_TO_4BYTE(rxdesc + 0x10, 6, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_SWPS_RPT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 5, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_IDX(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 0, 8)
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_IDX_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 0, 5)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_PATTERN_IDX_V2(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 0, 5)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*RXDESC_WORD5*/
+
+#define GET_RX_DESC_TSFL(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x14, 0, 32)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define GET_RX_DESC_FREERUN_CNT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x14, 0, 32)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_sdio_reg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_sdio_reg.h
new file mode 100644
index 000000000000..71f3de64ff9f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_sdio_reg.h
@@ -0,0 +1,55 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 __HALMAC_SDIO_REG_H__
+#define __HALMAC_SDIO_REG_H__
+
+/* SDIO CMD address mapping */
+
+#define HALMAC_SDIO_4BYTE_LEN_MASK      0x1FFF
+#define HALMAC_SDIO_LOCAL_MSK           0x0FFF
+#define HALMAC_WLAN_MAC_REG_MSK		0xFFFF
+#define	HALMAC_WLAN_IOREG_MSK		0xFFFF
+
+/* Sdio Address for SDIO Local Reg, TRX FIFO, MAC Reg */
+enum halmac_sdio_cmd_addr {
+	HALMAC_SDIO_CMD_ADDR_SDIO_REG = 0,
+	HALMAC_SDIO_CMD_ADDR_MAC_REG = 8,
+	HALMAC_SDIO_CMD_ADDR_TXFF_HIGH = 4,
+	HALMAC_SDIO_CMD_ADDR_TXFF_LOW = 6,
+	HALMAC_SDIO_CMD_ADDR_TXFF_NORMAL = 5,
+	HALMAC_SDIO_CMD_ADDR_TXFF_EXTRA = 7,
+	HALMAC_SDIO_CMD_ADDR_RXFF = 7,
+};
+
+/* IO Bus domain address mapping */
+#define SDIO_LOCAL_OFFSET		0x10250000
+#define WLAN_IOREG_OFFSET		0x10260000
+#define FW_FIFO_OFFSET			0x10270000
+#define TX_HIQ_OFFSET			0x10310000
+#define TX_MIQ_OFFSET			0x10320000
+#define TX_LOQ_OFFSET			0x10330000
+#define TX_EXQ_OFFSET			0x10350000
+#define RX_RXOFF_OFFSET			0x10340000
+
+/* Get TX WLAN FIFO information in CMD53 addr  */
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT)
+#define GET_WLAN_TXFF_DEVICE_ID(cmd53_addr) \
+			LE_BITS_TO_4BYTE((u32 *)cmd53_addr, 13, 4)
+#define GET_WLAN_TXFF_PKT_SIZE(cmd53_addr) \
+			(LE_BITS_TO_4BYTE((u32 *)cmd53_addr, 0, 13) << 2)
+#endif
+
+#endif/* __HALMAC_SDIO_REG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_state_machine.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_state_machine.h
new file mode 100644
index 000000000000..d6cce79a460d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_state_machine.h
@@ -0,0 +1,157 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 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 _HALMAC_STATE_MACHINE_H_
+#define _HALMAC_STATE_MACHINE_H_
+
+enum halmac_dlfw_state {
+	HALMAC_DLFW_NONE = 0,
+	HALMAC_DLFW_DONE = 1,
+	HALMAC_GEN_INFO_SENT = 2,
+
+	/* Data CPU firmware download framework */
+	HALMAC_DLFW_INIT = 0x11,
+	HALMAC_DLFW_START = 0x12,
+	HALMAC_DLFW_CONF_READY = 0x13,
+	HALMAC_DLFW_CPU_READY = 0x14,
+	HALMAC_DLFW_MEM_READY = 0x15,
+	HALMAC_DLFW_SW_READY = 0x16,
+	HALMAC_DLFW_OFLD_READY = 0x17,
+
+	HALMAC_DLFW_UNDEFINED = 0x7F,
+};
+
+enum halmac_gpio_cfg_state {
+	HALMAC_GPIO_CFG_STATE_IDLE = 0,
+	HALMAC_GPIO_CFG_STATE_BUSY = 1,
+	HALMAC_GPIO_CFG_STATE_UNDEFINED = 0x7F,
+};
+
+enum halmac_rsvd_pg_state {
+	HALMAC_RSVD_PG_STATE_IDLE = 0,
+	HALMAC_RSVD_PG_STATE_BUSY = 1,
+	HALMAC_RSVD_PG_STATE_UNDEFINED = 0x7F,
+};
+
+enum halmac_api_state {
+	HALMAC_API_STATE_INIT = 0,
+	HALMAC_API_STATE_HALT = 1,
+	HALMAC_API_STATE_UNDEFINED = 0x7F,
+};
+
+enum halmac_cmd_construct_state {
+	HALMAC_CMD_CNSTR_IDLE = 0,
+	HALMAC_CMD_CNSTR_BUSY = 1,
+	HALMAC_CMD_CNSTR_H2C_SENT = 2,
+	HALMAC_CMD_CNSTR_CNSTR = 3,
+	HALMAC_CMD_CNSTR_BUF_CLR = 4,
+	HALMAC_CMD_CNSTR_UNDEFINED = 0x7F,
+};
+
+enum halmac_cmd_process_status {
+	HALMAC_CMD_PROCESS_IDLE = 0x01, /* Init status */
+	HALMAC_CMD_PROCESS_SENDING = 0x02, /* Wait ack */
+	HALMAC_CMD_PROCESS_RCVD = 0x03, /* Rcvd ack */
+	HALMAC_CMD_PROCESS_DONE = 0x04, /* Event done */
+	HALMAC_CMD_PROCESS_ERROR = 0x05, /* Return code error */
+	HALMAC_CMD_PROCESS_UNDEFINE = 0x7F,
+};
+
+enum halmac_mac_power {
+	HALMAC_MAC_POWER_OFF = 0x0,
+	HALMAC_MAC_POWER_ON = 0x1,
+	HALMAC_MAC_POWER_UNDEFINE = 0x7F,
+};
+
+enum halmac_wlcpu_mode {
+	HALMAC_WLCPU_ACTIVE = 0x0,
+	HALMAC_WLCPU_ENTER_SLEEP = 0x1,
+	HALMAC_WLCPU_SLEEP = 0x2,
+	HALMAC_WLCPU_UNDEFINE = 0x7F,
+};
+
+struct halmac_efuse_state {
+	enum halmac_cmd_construct_state cmd_cnstr_state;
+	enum halmac_cmd_process_status proc_status;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_cfg_param_state {
+	enum halmac_cmd_construct_state cmd_cnstr_state;
+	enum halmac_cmd_process_status proc_status;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_scan_state {
+	enum halmac_cmd_construct_state cmd_cnstr_state;
+	enum halmac_cmd_process_status proc_status;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_update_pkt_state {
+	enum halmac_cmd_process_status proc_status;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_iqk_state {
+	enum halmac_cmd_process_status proc_status;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_pwr_tracking_state {
+	enum halmac_cmd_process_status	proc_status;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_psd_state {
+	enum halmac_cmd_process_status proc_status;
+	u16 data_size;
+	u16 seg_size;
+	u8 *data;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_fw_snding_state {
+	enum halmac_cmd_construct_state cmd_cnstr_state;
+	enum halmac_cmd_process_status proc_status;
+	u8 fw_rc;
+	u16 seq_num;
+};
+
+struct halmac_state {
+	struct halmac_efuse_state efuse_state;
+	struct halmac_cfg_param_state cfg_param_state;
+	struct halmac_scan_state scan_state;
+	struct halmac_update_pkt_state update_pkt_state;
+	struct halmac_iqk_state iqk_state;
+	struct halmac_pwr_tracking_state pwr_trk_state;
+	struct halmac_psd_state psd_state;
+	struct halmac_fw_snding_state fw_snding_state;
+	enum halmac_api_state api_state;
+	enum halmac_mac_power mac_pwr;
+	enum halmac_dlfw_state dlfw_state;
+	enum halmac_wlcpu_mode wlcpu_mode;
+	enum halmac_gpio_cfg_state gpio_cfg_state;
+	enum halmac_rsvd_pg_state rsvd_pg_state;
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_bd_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_bd_nic.h
new file mode 100644
index 000000000000..5f312cfb101b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_bd_nic.h
@@ -0,0 +1,110 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_BD_NIC_H_
+#define _HALMAC_TX_BD_NIC_H_
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+	HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXBD_DW0*/
+
+#define SET_TX_BD_OWN(txbd, value)                                             \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x00, 31, 1, value)
+#define GET_TX_BD_OWN(txbd) LE_BITS_TO_4BYTE(txbd + 0x00, 31, 1)
+#define SET_TX_BD_PSB(txbd, value)                                             \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x00, 16, 8, value)
+#define GET_TX_BD_PSB(txbd) LE_BITS_TO_4BYTE(txbd + 0x00, 16, 8)
+#define SET_TX_BD_TX_BUFF_SIZE0(txbd, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x00, 0, 16, value)
+#define GET_TX_BD_TX_BUFF_SIZE0(txbd) LE_BITS_TO_4BYTE(txbd + 0x00, 0, 16)
+
+/*TXBD_DW1*/
+
+#define SET_TX_BD_PHYSICAL_ADDR0_LOW(txbd, value)                              \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x04, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR0_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x04, 0, 32)
+
+/*TXBD_DW2*/
+
+#define SET_TX_BD_PHYSICAL_ADDR0_HIGH(txbd, value)                             \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x08, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR0_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x08, 0, 32)
+
+/*TXBD_DW4*/
+
+#define SET_TX_BD_A1(txbd, value)                                              \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x10, 31, 1, value)
+#define GET_TX_BD_A1(txbd) LE_BITS_TO_4BYTE(txbd + 0x10, 31, 1)
+#define SET_TX_BD_TX_BUFF_SIZE1(txbd, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x10, 0, 16, value)
+#define GET_TX_BD_TX_BUFF_SIZE1(txbd) LE_BITS_TO_4BYTE(txbd + 0x10, 0, 16)
+
+/*TXBD_DW5*/
+
+#define SET_TX_BD_PHYSICAL_ADDR1_LOW(txbd, value)                              \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x14, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR1_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x14, 0, 32)
+
+/*TXBD_DW6*/
+
+#define SET_TX_BD_PHYSICAL_ADDR1_HIGH(txbd, value)                             \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x18, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR1_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x18, 0, 32)
+
+/*TXBD_DW8*/
+
+#define SET_TX_BD_A2(txbd, value)                                              \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x20, 31, 1, value)
+#define GET_TX_BD_A2(txbd) LE_BITS_TO_4BYTE(txbd + 0x20, 31, 1)
+#define SET_TX_BD_TX_BUFF_SIZE2(txbd, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x20, 0, 16, value)
+#define GET_TX_BD_TX_BUFF_SIZE2(txbd) LE_BITS_TO_4BYTE(txbd + 0x20, 0, 16)
+
+/*TXBD_DW9*/
+
+#define SET_TX_BD_PHYSICAL_ADDR2_LOW(txbd, value)                              \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x24, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR2_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x24, 0, 32)
+
+/*TXBD_DW10*/
+
+#define SET_TX_BD_PHYSICAL_ADDR2_HIGH(txbd, value)                             \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x28, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR2_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x28, 0, 32)
+
+/*TXBD_DW12*/
+
+#define SET_TX_BD_A3(txbd, value)                                              \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x30, 31, 1, value)
+#define GET_TX_BD_A3(txbd) LE_BITS_TO_4BYTE(txbd + 0x30, 31, 1)
+#define SET_TX_BD_TX_BUFF_SIZE3(txbd, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x30, 0, 16, value)
+#define GET_TX_BD_TX_BUFF_SIZE3(txbd) LE_BITS_TO_4BYTE(txbd + 0x30, 0, 16)
+
+/*TXBD_DW13*/
+
+#define SET_TX_BD_PHYSICAL_ADDR3_LOW(txbd, value)                              \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x34, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR3_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x34, 0, 32)
+
+/*TXBD_DW14*/
+
+#define SET_TX_BD_PHYSICAL_ADDR3_HIGH(txbd, value)                             \
+	SET_BITS_TO_LE_4BYTE(txbd + 0x38, 0, 32, value)
+#define GET_TX_BD_PHYSICAL_ADDR3_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x38, 0, 32)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ap.h
new file mode 100644
index 000000000000..c80649210aad
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ap.h
@@ -0,0 +1,1838 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_AP_H_
+#define _HALMAC_TX_DESC_AP_H_
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_DISQSELSEQ_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 31)
+#define GET_TX_DESC_DISQSELSEQ(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_IE_END_BODY(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_IE_END_BODY_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 31)
+#define GET_TX_DESC_IE_END_BODY(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_GF(txdesc, value)                                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_GF_NO_CLR(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 30)
+#define GET_TX_DESC_GF(txdesc)                                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_AGG_EN_V1(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_AGG_EN_V1_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 30)
+#define GET_TX_DESC_AGG_EN_V1(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_NO_ACM(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_NO_ACM_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 29)
+#define GET_TX_DESC_NO_ACM(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      29)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_BK_V1(txdesc, value)                                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_BK_V1_NO_CLR(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 29)
+#define GET_TX_DESC_BK_V1(txdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      29)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 28)
+#define SET_TX_DESC_BCNPKT_TSF_CTRL_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 28)
+#define GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 27)
+#define SET_TX_DESC_AMSDU_PAD_EN_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 27)
+#define GET_TX_DESC_AMSDU_PAD_EN(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      27)
+#define SET_TX_DESC_LS(txdesc, value)                                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 26)
+#define SET_TX_DESC_LS_NO_CLR(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 26)
+#define GET_TX_DESC_LS(txdesc)                                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      26)
+#define SET_TX_DESC_HTC(txdesc, value)                                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 25)
+#define SET_TX_DESC_HTC_NO_CLR(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 25)
+#define GET_TX_DESC_HTC(txdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      25)
+#define SET_TX_DESC_BMC(txdesc, value)                                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 24)
+#define SET_TX_DESC_BMC_NO_CLR(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 24)
+#define GET_TX_DESC_BMC(txdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_PKT_OFFSET_V1(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1f, 24)
+#define SET_TX_DESC_PKT_OFFSET_V1_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1f, 24)
+#define GET_TX_DESC_PKT_OFFSET_V1(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1f, \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_OFFSET(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_OFFSET_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0xff, 16)
+#define GET_TX_DESC_OFFSET(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0xff, \
+			      16)
+#define SET_TX_DESC_TXPKTSIZE(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0xffff, 0)
+#define SET_TX_DESC_TXPKTSIZE_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0xffff, 0)
+#define GET_TX_DESC_TXPKTSIZE(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0,       \
+			      0xffff, 0)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+/*WORD1*/
+
+#define SET_TX_DESC_HW_AES_IV_V2(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_HW_AES_IV_V2_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 31)
+#define GET_TX_DESC_HW_AES_IV_V2(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_AMSDU(txdesc, value)                                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_AMSDU_NO_CLR(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 30)
+#define GET_TX_DESC_AMSDU(txdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_FTM_EN_V1(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_FTM_EN_V1_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 30)
+#define GET_TX_DESC_FTM_EN_V1(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MOREDATA(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_MOREDATA_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 29)
+#define GET_TX_DESC_MOREDATA(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      29)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_HW_AES_IV_V1(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_HW_AES_IV_V1_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 29)
+#define GET_TX_DESC_HW_AES_IV_V1(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      29)
+#define SET_TX_DESC_MHR_CP(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 25)
+#define SET_TX_DESC_MHR_CP_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 25)
+#define GET_TX_DESC_MHR_CP(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      25)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_PKT_OFFSET(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1f, 24)
+#define SET_TX_DESC_PKT_OFFSET_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 24)
+#define GET_TX_DESC_PKT_OFFSET(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
+			      24)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_SMH_EN_V1(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 24)
+#define SET_TX_DESC_SMH_EN_V1_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 24)
+#define GET_TX_DESC_SMH_EN_V1(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SEC_TYPE(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x3, 22)
+#define SET_TX_DESC_SEC_TYPE_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x3, 22)
+#define GET_TX_DESC_SEC_TYPE(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x3,  \
+			      22)
+#define SET_TX_DESC_EN_DESC_ID(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 21)
+#define SET_TX_DESC_EN_DESC_ID_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 21)
+#define GET_TX_DESC_EN_DESC_ID(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      21)
+#define SET_TX_DESC_RATE_ID(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1f, 16)
+#define SET_TX_DESC_RATE_ID_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 16)
+#define GET_TX_DESC_RATE_ID(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
+			      16)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_SMH_CAM(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_SMH_CAM_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0xff, 16)
+#define GET_TX_DESC_SMH_CAM(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0xff, \
+			      16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_PIFS(txdesc, value)                                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 15)
+#define SET_TX_DESC_PIFS_NO_CLR(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 15)
+#define GET_TX_DESC_PIFS(txdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      15)
+#define SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 14)
+#define SET_TX_DESC_LSIG_TXOP_EN_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 14)
+#define GET_TX_DESC_LSIG_TXOP_EN(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      14)
+#define SET_TX_DESC_RD_NAV_EXT(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 13)
+#define SET_TX_DESC_RD_NAV_EXT_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 13)
+#define GET_TX_DESC_RD_NAV_EXT(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      13)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_EXT_EDCA(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 13)
+#define SET_TX_DESC_EXT_EDCA_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 13)
+#define GET_TX_DESC_EXT_EDCA(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      13)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_QSEL(txdesc, value)                                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1f, 8)
+#define SET_TX_DESC_QSEL_NO_CLR(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 8)
+#define GET_TX_DESC_QSEL(txdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
+			      8)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_SPECIAL_CW(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 7)
+#define SET_TX_DESC_SPECIAL_CW_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 7)
+#define GET_TX_DESC_SPECIAL_CW(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, 7)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MACID(txdesc, value)                                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x7f, 0)
+#define SET_TX_DESC_MACID_NO_CLR(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x7f, 0)
+#define GET_TX_DESC_MACID(txdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x7f, \
+			      0)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_MACID_V1(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x7f, 0)
+#define SET_TX_DESC_MACID_V1_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x7f, 0)
+#define GET_TX_DESC_MACID_V1(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x7f, \
+			      0)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_HW_AES_IV(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_HW_AES_IV_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 31)
+#define GET_TX_DESC_HW_AES_IV(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_CHK_EN_V1(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_CHK_EN_V1_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 31)
+#define GET_TX_DESC_CHK_EN_V1(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_FTM_EN(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_FTM_EN_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 30)
+#define GET_TX_DESC_FTM_EN(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTCEL_D_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0xf, 28)
+#define SET_TX_DESC_ANTCEL_D_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0xf, 28)
+#define GET_TX_DESC_ANTCEL_D_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xf,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_DMA_PRI(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 27)
+#define SET_TX_DESC_DMA_PRI_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 27)
+#define GET_TX_DESC_DMA_PRI(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      27)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_G_ID(txdesc, value)                                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x3f, 24)
+#define SET_TX_DESC_G_ID_NO_CLR(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x3f, 24)
+#define GET_TX_DESC_G_ID(txdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x3f, \
+			      24)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_MAX_AMSDU_MODE(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x7, 24)
+#define SET_TX_DESC_MAX_AMSDU_MODE_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x7, 24)
+#define GET_TX_DESC_MAX_AMSDU_MODE(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x7,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_C_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0xf, 24)
+#define SET_TX_DESC_ANTSEL_C_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0xf, 24)
+#define GET_TX_DESC_ANTSEL_C_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xf,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_BT_NULL(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 23)
+#define SET_TX_DESC_BT_NULL_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 23)
+#define GET_TX_DESC_BT_NULL(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      23)
+#define SET_TX_DESC_AMPDU_DENSITY(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x7, 20)
+#define SET_TX_DESC_AMPDU_DENSITY_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x7, 20)
+#define GET_TX_DESC_AMPDU_DENSITY(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x7,  \
+			      20)
+#define SET_TX_DESC_SPE_RPT(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 19)
+#define SET_TX_DESC_SPE_RPT_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 19)
+#define GET_TX_DESC_SPE_RPT(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      19)
+#define SET_TX_DESC_RAW(txdesc, value)                                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 18)
+#define SET_TX_DESC_RAW_NO_CLR(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 18)
+#define GET_TX_DESC_RAW(txdesc)                                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      18)
+#define SET_TX_DESC_MOREFRAG(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 17)
+#define SET_TX_DESC_MOREFRAG_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 17)
+#define GET_TX_DESC_MOREFRAG(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      17)
+#define SET_TX_DESC_BK(txdesc, value)                                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 16)
+#define SET_TX_DESC_BK_NO_CLR(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 16)
+#define GET_TX_DESC_BK(txdesc)                                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_DMA_TXAGG_NUM_V1_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0xff, 16)
+#define GET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xff, \
+			      16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_NULL_1(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 15)
+#define SET_TX_DESC_NULL_1_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 15)
+#define GET_TX_DESC_NULL_1(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      15)
+#define SET_TX_DESC_NULL_0(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 14)
+#define SET_TX_DESC_NULL_0_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 14)
+#define GET_TX_DESC_NULL_0(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      14)
+#define SET_TX_DESC_RDG_EN(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 13)
+#define SET_TX_DESC_RDG_EN_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 13)
+#define GET_TX_DESC_RDG_EN(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      13)
+#define SET_TX_DESC_AGG_EN(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 12)
+#define SET_TX_DESC_AGG_EN_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 12)
+#define GET_TX_DESC_AGG_EN(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      12)
+#define SET_TX_DESC_CCA_RTS(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x3, 10)
+#define SET_TX_DESC_CCA_RTS_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x3, 10)
+#define GET_TX_DESC_CCA_RTS(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x3,  \
+			      10)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TRI_FRAME(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 9)
+#define SET_TX_DESC_TRI_FRAME_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 9)
+#define GET_TX_DESC_TRI_FRAME(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, 9)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_P_AID(txdesc, value)                                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1ff, 0)
+#define SET_TX_DESC_P_AID_NO_CLR(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1ff, 0)
+#define GET_TX_DESC_P_AID(txdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2,       \
+			      0x1ff, 0)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0xffff, 0)
+#define SET_TX_DESC_TXDESC_CHECKSUM_V1_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0xffff, 0)
+#define GET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2,       \
+			      0xffff, 0)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0xff, 24)
+#define SET_TX_DESC_AMPDU_MAX_TIME_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0xff, 24)
+#define GET_TX_DESC_AMPDU_MAX_TIME(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0xff, \
+			      24)
+#define SET_TX_DESC_NDPA(txdesc, value)                                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x3, 22)
+#define SET_TX_DESC_NDPA_NO_CLR(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x3, 22)
+#define GET_TX_DESC_NDPA(txdesc)                                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x3,  \
+			      22)
+#define SET_TX_DESC_MAX_AGG_NUM(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1f, 17)
+#define SET_TX_DESC_MAX_AGG_NUM_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 17)
+#define GET_TX_DESC_MAX_AGG_NUM(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
+			      17)
+#define SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 16)
+#define SET_TX_DESC_USE_MAX_TIME_EN_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 16)
+#define GET_TX_DESC_USE_MAX_TIME_EN(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_OFFLOAD_SIZE(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x7fff, 16)
+#define SET_TX_DESC_OFFLOAD_SIZE_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x7fff, 16)
+#define GET_TX_DESC_OFFLOAD_SIZE(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3,       \
+			      0x7fff, 16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_NAVUSEHDR(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 15)
+#define SET_TX_DESC_NAVUSEHDR_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 15)
+#define GET_TX_DESC_NAVUSEHDR(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1,  \
+			      15)
+#define SET_TX_DESC_CHK_EN(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 14)
+#define SET_TX_DESC_CHK_EN_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 14)
+#define GET_TX_DESC_CHK_EN(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1,  \
+			      14)
+#define SET_TX_DESC_HW_RTS_EN(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 13)
+#define SET_TX_DESC_HW_RTS_EN_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 13)
+#define GET_TX_DESC_HW_RTS_EN(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1,  \
+			      13)
+#define SET_TX_DESC_RTSEN(txdesc, value)                                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 12)
+#define SET_TX_DESC_RTSEN_NO_CLR(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 12)
+#define GET_TX_DESC_RTSEN(txdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1,  \
+			      12)
+#define SET_TX_DESC_CTS2SELF(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 11)
+#define SET_TX_DESC_CTS2SELF_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 11)
+#define GET_TX_DESC_CTS2SELF(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1,  \
+			      11)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_CHANNEL_DMA(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1f, 11)
+#define SET_TX_DESC_CHANNEL_DMA_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 11)
+#define GET_TX_DESC_CHANNEL_DMA(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
+			      11)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_DISDATAFB(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 10)
+#define SET_TX_DESC_DISDATAFB_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 10)
+#define GET_TX_DESC_DISDATAFB(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1,  \
+			      10)
+#define SET_TX_DESC_DISRTSFB(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 9)
+#define SET_TX_DESC_DISRTSFB_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 9)
+#define GET_TX_DESC_DISRTSFB(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 9)
+#define SET_TX_DESC_USE_RATE(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 8)
+#define SET_TX_DESC_USE_RATE_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 8)
+#define GET_TX_DESC_USE_RATE(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 8)
+#define SET_TX_DESC_HW_SSN_SEL(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x3, 6)
+#define SET_TX_DESC_HW_SSN_SEL_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x3, 6)
+#define GET_TX_DESC_HW_SSN_SEL(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x3, 6)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_IE_CNT(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x7, 6)
+#define SET_TX_DESC_IE_CNT_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x7, 6)
+#define GET_TX_DESC_IE_CNT(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x7, 6)
+#define SET_TX_DESC_IE_CNT_EN(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 5)
+#define SET_TX_DESC_IE_CNT_EN_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 5)
+#define GET_TX_DESC_IE_CNT_EN(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 5)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_WHEADER_LEN(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1f, 0)
+#define SET_TX_DESC_WHEADER_LEN_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 0)
+#define GET_TX_DESC_WHEADER_LEN(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
+			      0)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_WHEADER_LEN_V1(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1f, 0)
+#define SET_TX_DESC_WHEADER_LEN_V1_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 0)
+#define GET_TX_DESC_WHEADER_LEN_V1(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
+			      0)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x3, 30)
+#define SET_TX_DESC_PCTS_MASK_IDX_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x3, 30)
+#define GET_TX_DESC_PCTS_MASK_IDX(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x3,  \
+			      30)
+#define SET_TX_DESC_PCTS_EN(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_PCTS_EN_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 29)
+#define GET_TX_DESC_PCTS_EN(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1,  \
+			      29)
+#define SET_TX_DESC_RTSRATE(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1f, 24)
+#define SET_TX_DESC_RTSRATE_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1f, 24)
+#define GET_TX_DESC_RTSRATE(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1f, \
+			      24)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x3f, 18)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x3f, 18)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x3f, \
+			      18)
+#define SET_TX_DESC_RTY_LMT_EN(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1, 17)
+#define SET_TX_DESC_RTY_LMT_EN_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 17)
+#define GET_TX_DESC_RTY_LMT_EN(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1,  \
+			      17)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0xf, 13)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_NO_CLR(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0xf, 13)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0xf,  \
+			      13)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1f, 8)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_NO_CLR(txdesc, value)                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1f, 8)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1f, \
+			      8)
+#define SET_TX_DESC_TRY_RATE(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1, 7)
+#define SET_TX_DESC_TRY_RATE_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 7)
+#define GET_TX_DESC_TRY_RATE(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1, 7)
+#define SET_TX_DESC_DATARATE(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x7f, 0)
+#define SET_TX_DESC_DATARATE_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x7f, 0)
+#define GET_TX_DESC_DATARATE(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x7f, \
+			      0)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_POLLUTED_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 31)
+#define GET_TX_DESC_POLLUTED(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      31)
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_EN_V1(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_ANTSEL_EN_V1_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 30)
+#define GET_TX_DESC_ANTSEL_EN_V1(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_TXPWR_OFSET(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x7, 28)
+#define SET_TX_DESC_TXPWR_OFSET_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x7, 28)
+#define GET_TX_DESC_TXPWR_OFSET(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x7,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x3, 28)
+#define SET_TX_DESC_TXPWR_OFSET_TYPE_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 28)
+#define GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TX_ANT(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0xf, 24)
+#define SET_TX_DESC_TX_ANT_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 24)
+#define GET_TX_DESC_TX_ANT(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_DROP_ID(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x3, 24)
+#define SET_TX_DESC_DROP_ID_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 24)
+#define GET_TX_DESC_DROP_ID(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_PORT_ID(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x7, 21)
+#define SET_TX_DESC_PORT_ID_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x7, 21)
+#define GET_TX_DESC_PORT_ID(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x7,  \
+			      21)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MULTIPLE_PORT(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x7, 18)
+#define SET_TX_DESC_MULTIPLE_PORT_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x7, 18)
+#define GET_TX_DESC_MULTIPLE_PORT(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x7,  \
+			      18)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 17)
+#define SET_TX_DESC_SIGNALING_TAPKT_EN_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 17)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      17)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_RTS_SC(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0xf, 13)
+#define SET_TX_DESC_RTS_SC_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 13)
+#define GET_TX_DESC_RTS_SC(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf,  \
+			      13)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0xf, 13)
+#define SET_TX_DESC_SIGNALING_TA_PKT_SC_NO_CLR(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 13)
+#define GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf,  \
+			      13)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_RTS_SHORT(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 12)
+#define SET_TX_DESC_RTS_SHORT_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 12)
+#define GET_TX_DESC_RTS_SHORT(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      12)
+#define SET_TX_DESC_VCS_STBC(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x3, 10)
+#define SET_TX_DESC_VCS_STBC_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 10)
+#define GET_TX_DESC_VCS_STBC(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3,  \
+			      10)
+#define SET_TX_DESC_DATA_STBC(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x3, 8)
+#define SET_TX_DESC_DATA_STBC_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 8)
+#define GET_TX_DESC_DATA_STBC(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, 8)
+#define SET_TX_DESC_DATA_LDPC(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 7)
+#define SET_TX_DESC_DATA_LDPC_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 7)
+#define GET_TX_DESC_DATA_LDPC(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 7)
+#define SET_TX_DESC_DATA_BW(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x3, 5)
+#define SET_TX_DESC_DATA_BW_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 5)
+#define GET_TX_DESC_DATA_BW(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, 5)
+#define SET_TX_DESC_DATA_SHORT(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 4)
+#define SET_TX_DESC_DATA_SHORT_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 4)
+#define GET_TX_DESC_DATA_SHORT(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 4)
+#define SET_TX_DESC_DATA_SC(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0xf, 0)
+#define SET_TX_DESC_DATA_SC_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 0)
+#define GET_TX_DESC_DATA_SC(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf, 0)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANTSEL_D(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 30)
+#define SET_TX_DESC_ANTSEL_D_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 30)
+#define GET_TX_DESC_ANTSEL_D(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPD_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 30)
+#define SET_TX_DESC_ANT_MAPD_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 30)
+#define GET_TX_DESC_ANT_MAPD_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      30)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPD(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 28)
+#define SET_TX_DESC_ANT_MAPD_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 28)
+#define GET_TX_DESC_ANT_MAPD(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPC_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 28)
+#define SET_TX_DESC_ANT_MAPC_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 28)
+#define GET_TX_DESC_ANT_MAPC_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      28)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPC(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 26)
+#define SET_TX_DESC_ANT_MAPC_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 26)
+#define GET_TX_DESC_ANT_MAPC(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      26)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPB_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 26)
+#define SET_TX_DESC_ANT_MAPB_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 26)
+#define GET_TX_DESC_ANT_MAPB_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      26)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPB(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 24)
+#define SET_TX_DESC_ANT_MAPB_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 24)
+#define GET_TX_DESC_ANT_MAPB(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPA_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 24)
+#define SET_TX_DESC_ANT_MAPA_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 24)
+#define GET_TX_DESC_ANT_MAPA_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      24)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPA(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 22)
+#define SET_TX_DESC_ANT_MAPA_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 22)
+#define GET_TX_DESC_ANT_MAPA(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      22)
+#define SET_TX_DESC_ANTSEL_C(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 20)
+#define SET_TX_DESC_ANTSEL_C_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 20)
+#define GET_TX_DESC_ANTSEL_C(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      20)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_B_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0xf, 20)
+#define SET_TX_DESC_ANTSEL_B_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0xf, 20)
+#define GET_TX_DESC_ANTSEL_B_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0xf,  \
+			      20)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_B(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 18)
+#define SET_TX_DESC_ANTSEL_B_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 18)
+#define GET_TX_DESC_ANTSEL_B(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      18)
+#define SET_TX_DESC_ANTSEL_A(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 16)
+#define SET_TX_DESC_ANTSEL_A_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 16)
+#define GET_TX_DESC_ANTSEL_A(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_A_V1(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0xf, 16)
+#define SET_TX_DESC_ANTSEL_A_V1_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0xf, 16)
+#define GET_TX_DESC_ANTSEL_A_V1(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0xf,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MBSSID(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0xf, 12)
+#define SET_TX_DESC_MBSSID_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0xf, 12)
+#define GET_TX_DESC_MBSSID(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0xf,  \
+			      12)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SW_DEFINE(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0xfff, 0)
+#define SET_TX_DESC_SW_DEFINE_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0xfff, 0)
+#define GET_TX_DESC_SW_DEFINE(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6,       \
+			      0xfff, 0)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_SWPS_SEQ(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0xfff, 0)
+#define SET_TX_DESC_SWPS_SEQ_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0xfff, 0)
+#define GET_TX_DESC_SWPS_SEQ(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6,       \
+			      0xfff, 0)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xff, 24)
+#define SET_TX_DESC_DMA_TXAGG_NUM_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xff, 24)
+#define GET_TX_DESC_DMA_TXAGG_NUM(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xff, \
+			      24)
+#define SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xff, 24)
+#define SET_TX_DESC_FINAL_DATA_RATE_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xff, 24)
+#define GET_TX_DESC_FINAL_DATA_RATE(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xff, \
+			      24)
+#define SET_TX_DESC_NTX_MAP(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xf, 20)
+#define SET_TX_DESC_NTX_MAP_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xf, 20)
+#define GET_TX_DESC_NTX_MAP(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xf,  \
+			      20)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_EN(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0x1, 19)
+#define SET_TX_DESC_ANTSEL_EN_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1, 19)
+#define GET_TX_DESC_ANTSEL_EN(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1,  \
+			      19)
+#define SET_TX_DESC_MBSSID_EX(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0x7, 16)
+#define SET_TX_DESC_MBSSID_EX_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0x7, 16)
+#define GET_TX_DESC_MBSSID_EX(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x7,  \
+			      16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xffff, 0)
+#define SET_TX_DESC_TX_BUFF_SIZE_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xffff, 0)
+#define GET_TX_DESC_TX_BUFF_SIZE(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7,       \
+			      0xffff, 0)
+#define SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xffff, 0)
+#define SET_TX_DESC_TXDESC_CHECKSUM_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xffff, 0)
+#define GET_TX_DESC_TXDESC_CHECKSUM(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7,       \
+			      0xffff, 0)
+#define SET_TX_DESC_TIMESTAMP(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xffff, 0)
+#define SET_TX_DESC_TIMESTAMP_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xffff, 0)
+#define GET_TX_DESC_TIMESTAMP(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7,       \
+			      0xffff, 0)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_TXWIFI_CP_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 31)
+#define GET_TX_DESC_TXWIFI_CP(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      31)
+#define SET_TX_DESC_MAC_CP(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_MAC_CP_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 30)
+#define GET_TX_DESC_MAC_CP(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      30)
+#define SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_STW_PKTRE_DIS_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 29)
+#define GET_TX_DESC_STW_PKTRE_DIS(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      29)
+#define SET_TX_DESC_STW_RB_DIS(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 28)
+#define SET_TX_DESC_STW_RB_DIS_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 28)
+#define GET_TX_DESC_STW_RB_DIS(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      28)
+#define SET_TX_DESC_STW_RATE_DIS(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 27)
+#define SET_TX_DESC_STW_RATE_DIS_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 27)
+#define GET_TX_DESC_STW_RATE_DIS(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      27)
+#define SET_TX_DESC_STW_ANT_DIS(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 26)
+#define SET_TX_DESC_STW_ANT_DIS_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 26)
+#define GET_TX_DESC_STW_ANT_DIS(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      26)
+#define SET_TX_DESC_STW_EN(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 25)
+#define SET_TX_DESC_STW_EN_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 25)
+#define GET_TX_DESC_STW_EN(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      25)
+#define SET_TX_DESC_SMH_EN(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 24)
+#define SET_TX_DESC_SMH_EN_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 24)
+#define GET_TX_DESC_SMH_EN(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      24)
+#define SET_TX_DESC_TAILPAGE_L(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xff, 24)
+#define SET_TX_DESC_TAILPAGE_L_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xff, 24)
+#define GET_TX_DESC_TAILPAGE_L(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xff, \
+			      24)
+#define SET_TX_DESC_SDIO_DMASEQ(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_SDIO_DMASEQ_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xff, 16)
+#define GET_TX_DESC_SDIO_DMASEQ(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xff, \
+			      16)
+#define SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_NEXTHEADPAGE_L_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xff, 16)
+#define GET_TX_DESC_NEXTHEADPAGE_L(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xff, \
+			      16)
+#define SET_TX_DESC_EN_HWSEQ(txdesc, value)                                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 15)
+#define SET_TX_DESC_EN_HWSEQ_NO_CLR(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 15)
+#define GET_TX_DESC_EN_HWSEQ(txdesc)                                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      15)
+#define SET_TX_DESC_EN_HWEXSEQ(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 14)
+#define SET_TX_DESC_EN_HWEXSEQ_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 14)
+#define GET_TX_DESC_EN_HWEXSEQ(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1,  \
+			      14)
+#define SET_TX_DESC_DATA_RC(txdesc, value)                                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x3f, 8)
+#define SET_TX_DESC_DATA_RC_NO_CLR(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3f, 8)
+#define GET_TX_DESC_DATA_RC(txdesc)                                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3f, \
+			      8)
+#define SET_TX_DESC_BAR_RTY_TH(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x3, 6)
+#define SET_TX_DESC_BAR_RTY_TH_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 6)
+#define GET_TX_DESC_BAR_RTY_TH(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3, 6)
+#define SET_TX_DESC_RTS_RC(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x3f, 0)
+#define SET_TX_DESC_RTS_RC_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3f, 0)
+#define GET_TX_DESC_RTS_RC(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3f, \
+			      0)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0xf, 28)
+#define SET_TX_DESC_TAILPAGE_H_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0xf, 28)
+#define GET_TX_DESC_TAILPAGE_H(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xf,  \
+			      28)
+#define SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0xf, 24)
+#define SET_TX_DESC_NEXTHEADPAGE_H_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0xf, 24)
+#define GET_TX_DESC_NEXTHEADPAGE_H(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xf,  \
+			      24)
+#define SET_TX_DESC_SW_SEQ(txdesc, value)                                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0xfff, 12)
+#define SET_TX_DESC_SW_SEQ_NO_CLR(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0xfff, 12)
+#define GET_TX_DESC_SW_SEQ(txdesc)                                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9,       \
+			      0xfff, 12)
+#define SET_TX_DESC_TXBF_PATH(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 11)
+#define SET_TX_DESC_TXBF_PATH_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 11)
+#define GET_TX_DESC_TXBF_PATH(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1,  \
+			      11)
+#define SET_TX_DESC_PADDING_LEN(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x7ff, 0)
+#define SET_TX_DESC_PADDING_LEN_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x7ff, 0)
+#define GET_TX_DESC_PADDING_LEN(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9,       \
+			      0x7ff, 0)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0xff, 0)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_NO_CLR(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0xff, 0)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xff, \
+			      0)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*WORD10*/
+
+#define SET_TX_DESC_MU_DATARATE(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0xff, 8)
+#define SET_TX_DESC_MU_DATARATE_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0xff, 8)
+#define GET_TX_DESC_MU_DATARATE(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10,      \
+			      0xff, 8)
+#define SET_TX_DESC_MU_RC(txdesc, value)                                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0xf, 4)
+#define SET_TX_DESC_MU_RC_NO_CLR(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0xf, 4)
+#define GET_TX_DESC_MU_RC(txdesc)                                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0xf, \
+			      4)
+#define SET_TX_DESC_SND_PKT_SEL(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x3, 0)
+#define SET_TX_DESC_SND_PKT_SEL_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x3, 0)
+#define GET_TX_DESC_SND_PKT_SEL(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x3, \
+			      0)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_ap.h
new file mode 100644
index 000000000000..353571a47ecf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_ap.h
@@ -0,0 +1,1078 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_BUFFER_AP_H_
+#define _HALMAC_TX_DESC_BUFFER_AP_H_
+#if (HALMAC_8814B_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_BUFFER_RDG_EN(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_BUFFER_RDG_EN_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 31)
+#define GET_TX_DESC_BUFFER_RDG_EN(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      31)
+#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL_NO_CLR(txdesc, value)               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 30)
+#define GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc)                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      30)
+#define SET_TX_DESC_BUFFER_AGG_EN(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_BUFFER_AGG_EN_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 29)
+#define GET_TX_DESC_BUFFER_AGG_EN(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1,  \
+			      29)
+#define SET_TX_DESC_BUFFER_PKT_OFFSET(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0x1f, 24)
+#define SET_TX_DESC_BUFFER_PKT_OFFSET_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1f, 24)
+#define GET_TX_DESC_BUFFER_PKT_OFFSET(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1f, \
+			      24)
+#define SET_TX_DESC_BUFFER_OFFSET(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_BUFFER_OFFSET_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0xff, 16)
+#define GET_TX_DESC_BUFFER_OFFSET(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0xff, \
+			      16)
+#define SET_TX_DESC_BUFFER_TXPKTSIZE(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0,   \
+				  value, 0xffff, 0)
+#define SET_TX_DESC_BUFFER_TXPKTSIZE_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword0, value, 0xffff, 0)
+#define GET_TX_DESC_BUFFER_TXPKTSIZE(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0,       \
+			      0xffff, 0)
+
+/*TXDESC_WORD1*/
+
+#define SET_TX_DESC_BUFFER_USERATE(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_BUFFER_USERATE_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 31)
+#define GET_TX_DESC_BUFFER_USERATE(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      31)
+#define SET_TX_DESC_BUFFER_AMSDU(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_BUFFER_AMSDU_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 30)
+#define GET_TX_DESC_BUFFER_AMSDU(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      30)
+#define SET_TX_DESC_BUFFER_EN_HWSEQ(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_BUFFER_EN_HWSEQ_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 29)
+#define GET_TX_DESC_BUFFER_EN_HWSEQ(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      29)
+#define SET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 28)
+#define SET_TX_DESC_BUFFER_EN_HWEXSEQ_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 28)
+#define GET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      28)
+#define SET_TX_DESC_BUFFER_SW_SEQ(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0xfff, 16)
+#define SET_TX_DESC_BUFFER_SW_SEQ_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0xfff, 16)
+#define GET_TX_DESC_BUFFER_SW_SEQ(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1,       \
+			      0xfff, 16)
+#define SET_TX_DESC_BUFFER_DROP_ID(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x3, 14)
+#define SET_TX_DESC_BUFFER_DROP_ID_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x3, 14)
+#define GET_TX_DESC_BUFFER_DROP_ID(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x3,  \
+			      14)
+#define SET_TX_DESC_BUFFER_MOREDATA(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1, 13)
+#define SET_TX_DESC_BUFFER_MOREDATA_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 13)
+#define GET_TX_DESC_BUFFER_MOREDATA(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1,  \
+			      13)
+#define SET_TX_DESC_BUFFER_QSEL(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0x1f, 8)
+#define SET_TX_DESC_BUFFER_QSEL_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 8)
+#define GET_TX_DESC_BUFFER_QSEL(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
+			      8)
+#define SET_TX_DESC_BUFFER_MACID(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1,   \
+				  value, 0xff, 0)
+#define SET_TX_DESC_BUFFER_MACID_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword1, value, 0xff, 0)
+#define GET_TX_DESC_BUFFER_MACID(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0xff, \
+			      0)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_BUFFER_CHK_EN(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_BUFFER_CHK_EN_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 31)
+#define GET_TX_DESC_BUFFER_CHK_EN(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      31)
+#define SET_TX_DESC_BUFFER_DISQSELSEQ(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_BUFFER_DISQSELSEQ_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 30)
+#define GET_TX_DESC_BUFFER_DISQSELSEQ(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      30)
+#define SET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x3, 28)
+#define SET_TX_DESC_BUFFER_SND_PKT_SEL_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x3, 28)
+#define GET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x3,  \
+			      28)
+#define SET_TX_DESC_BUFFER_DMA_PRI(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x1, 27)
+#define SET_TX_DESC_BUFFER_DMA_PRI_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 27)
+#define GET_TX_DESC_BUFFER_DMA_PRI(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1,  \
+			      27)
+#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0x7, 24)
+#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE_NO_CLR(txdesc, value)                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0x7, 24)
+#define GET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc)                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x7,  \
+			      24)
+#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM_NO_CLR(txdesc, value)                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0xff, 16)
+#define GET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc)                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xff, \
+			      16)
+#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2,   \
+				  value, 0xffff, 0)
+#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM_NO_CLR(txdesc, value)               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword2, value, 0xffff, 0)
+#define GET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc)                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2,       \
+			      0xffff, 0)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x7fff, 16)
+#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE_NO_CLR(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x7fff, 16)
+#define GET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3,       \
+			      0x7fff, 16)
+#define SET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1f, 11)
+#define SET_TX_DESC_BUFFER_CHANNEL_DMA_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 11)
+#define GET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
+			      11)
+#define SET_TX_DESC_BUFFER_MBSSID(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0xf, 7)
+#define SET_TX_DESC_BUFFER_MBSSID_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0xf, 7)
+#define GET_TX_DESC_BUFFER_MBSSID(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0xf, 7)
+#define SET_TX_DESC_BUFFER_BK(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1, 6)
+#define SET_TX_DESC_BUFFER_BK_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 6)
+#define GET_TX_DESC_BUFFER_BK(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 6)
+#define SET_TX_DESC_BUFFER_WHEADER_LEN(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3,   \
+				  value, 0x1f, 0)
+#define SET_TX_DESC_BUFFER_WHEADER_LEN_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 0)
+#define GET_TX_DESC_BUFFER_WHEADER_LEN(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
+			      0)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_BUFFER_TRY_RATE(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1, 26)
+#define SET_TX_DESC_BUFFER_TRY_RATE_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 26)
+#define GET_TX_DESC_BUFFER_TRY_RATE(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1,  \
+			      26)
+#define SET_TX_DESC_BUFFER_DATA_BW(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x3, 24)
+#define SET_TX_DESC_BUFFER_DATA_BW_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x3, 24)
+#define GET_TX_DESC_BUFFER_DATA_BW(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x3,  \
+			      24)
+#define SET_TX_DESC_BUFFER_DATA_SHORT(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1, 23)
+#define SET_TX_DESC_BUFFER_DATA_SHORT_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 23)
+#define GET_TX_DESC_BUFFER_DATA_SHORT(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1,  \
+			      23)
+#define SET_TX_DESC_BUFFER_DATARATE(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x7f, 16)
+#define SET_TX_DESC_BUFFER_DATARATE_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x7f, 16)
+#define GET_TX_DESC_BUFFER_DATARATE(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x7f, \
+			      16)
+#define SET_TX_DESC_BUFFER_TXBF_PATH(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x1, 11)
+#define SET_TX_DESC_BUFFER_TXBF_PATH_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 11)
+#define GET_TX_DESC_BUFFER_TXBF_PATH(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1,  \
+			      11)
+#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4,   \
+				  value, 0x7ff, 0)
+#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET_NO_CLR(txdesc, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword4, value, 0x7ff, 0)
+#define GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4,       \
+			      0x7ff, 0)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 31)
+#define SET_TX_DESC_BUFFER_RTY_LMT_EN_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 31)
+#define GET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      31)
+#define SET_TX_DESC_BUFFER_HW_RTS_EN(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 30)
+#define SET_TX_DESC_BUFFER_HW_RTS_EN_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 30)
+#define GET_TX_DESC_BUFFER_HW_RTS_EN(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      30)
+#define SET_TX_DESC_BUFFER_RTS_EN(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 29)
+#define SET_TX_DESC_BUFFER_RTS_EN_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 29)
+#define GET_TX_DESC_BUFFER_RTS_EN(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      29)
+#define SET_TX_DESC_BUFFER_CTS2SELF(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 28)
+#define SET_TX_DESC_BUFFER_CTS2SELF_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 28)
+#define GET_TX_DESC_BUFFER_CTS2SELF(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      28)
+#define SET_TX_DESC_BUFFER_TAILPAGE_H(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0xf, 24)
+#define SET_TX_DESC_BUFFER_TAILPAGE_H_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 24)
+#define GET_TX_DESC_BUFFER_TAILPAGE_H(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf,  \
+			      24)
+#define SET_TX_DESC_BUFFER_TAILPAGE_L(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0xff, 16)
+#define SET_TX_DESC_BUFFER_TAILPAGE_L_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0xff, 16)
+#define GET_TX_DESC_BUFFER_TAILPAGE_L(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xff, \
+			      16)
+#define SET_TX_DESC_BUFFER_NAVUSEHDR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 15)
+#define SET_TX_DESC_BUFFER_NAVUSEHDR_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 15)
+#define GET_TX_DESC_BUFFER_NAVUSEHDR(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      15)
+#define SET_TX_DESC_BUFFER_BMC(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 14)
+#define SET_TX_DESC_BUFFER_BMC_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 14)
+#define GET_TX_DESC_BUFFER_BMC(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1,  \
+			      14)
+#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x3f, 8)
+#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT_NO_CLR(txdesc, value)              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3f, 8)
+#define GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc)                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3f, \
+			      8)
+#define SET_TX_DESC_BUFFER_HW_AES_IV(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 7)
+#define SET_TX_DESC_BUFFER_HW_AES_IV_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 7)
+#define GET_TX_DESC_BUFFER_HW_AES_IV(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 7)
+#define SET_TX_DESC_BUFFER_BT_NULL(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 3)
+#define SET_TX_DESC_BUFFER_BT_NULL_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 3)
+#define GET_TX_DESC_BUFFER_BT_NULL(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 3)
+#define SET_TX_DESC_BUFFER_EN_DESC_ID(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x1, 2)
+#define SET_TX_DESC_BUFFER_EN_DESC_ID_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 2)
+#define GET_TX_DESC_BUFFER_EN_DESC_ID(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 2)
+#define SET_TX_DESC_BUFFER_SECTYPE(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5,   \
+				  value, 0x3, 0)
+#define SET_TX_DESC_BUFFER_SECTYPE_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 0)
+#define GET_TX_DESC_BUFFER_SECTYPE(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, 0)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x7, 29)
+#define SET_TX_DESC_BUFFER_MULTIPLE_PORT_NO_CLR(txdesc, value)                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x7, 29)
+#define GET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc)                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x7,  \
+			      29)
+#define SET_TX_DESC_BUFFER_POLLUTED(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x1, 28)
+#define SET_TX_DESC_BUFFER_POLLUTED_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 28)
+#define GET_TX_DESC_BUFFER_POLLUTED(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1,  \
+			      28)
+#define SET_TX_DESC_BUFFER_NULL_1(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x1, 27)
+#define SET_TX_DESC_BUFFER_NULL_1_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 27)
+#define GET_TX_DESC_BUFFER_NULL_1(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1,  \
+			      27)
+#define SET_TX_DESC_BUFFER_NULL_0(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x1, 26)
+#define SET_TX_DESC_BUFFER_NULL_0_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 26)
+#define GET_TX_DESC_BUFFER_NULL_0(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1,  \
+			      26)
+#define SET_TX_DESC_BUFFER_TRI_FRAME(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x1, 25)
+#define SET_TX_DESC_BUFFER_TRI_FRAME_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 25)
+#define GET_TX_DESC_BUFFER_TRI_FRAME(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1,  \
+			      25)
+#define SET_TX_DESC_BUFFER_SPE_RPT(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x1, 24)
+#define SET_TX_DESC_BUFFER_SPE_RPT_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 24)
+#define GET_TX_DESC_BUFFER_SPE_RPT(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1,  \
+			      24)
+#define SET_TX_DESC_BUFFER_FTM_EN(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x1, 23)
+#define SET_TX_DESC_BUFFER_FTM_EN_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 23)
+#define GET_TX_DESC_BUFFER_FTM_EN(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1,  \
+			      23)
+#define SET_TX_DESC_BUFFER_MU_DATARATE(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x7f, 16)
+#define SET_TX_DESC_BUFFER_MU_DATARATE_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x7f, 16)
+#define GET_TX_DESC_BUFFER_MU_DATARATE(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x7f, \
+			      16)
+#define SET_TX_DESC_BUFFER_CCA_RTS(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 14)
+#define SET_TX_DESC_BUFFER_CCA_RTS_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 14)
+#define GET_TX_DESC_BUFFER_CCA_RTS(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      14)
+#define SET_TX_DESC_BUFFER_NDPA(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 12)
+#define SET_TX_DESC_BUFFER_NDPA_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 12)
+#define GET_TX_DESC_BUFFER_NDPA(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3,  \
+			      12)
+#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x3, 9)
+#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE_NO_CLR(txdesc, value)              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 9)
+#define GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc)                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, 9)
+#define SET_TX_DESC_BUFFER_P_AID(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6,   \
+				  value, 0x1ff, 0)
+#define SET_TX_DESC_BUFFER_P_AID_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1ff, 0)
+#define GET_TX_DESC_BUFFER_P_AID(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6,       \
+			      0x1ff, 0)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_BUFFER_SW_DEFINE(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xfff, 16)
+#define SET_TX_DESC_BUFFER_SW_DEFINE_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xfff, 16)
+#define GET_TX_DESC_BUFFER_SW_DEFINE(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7,       \
+			      0xfff, 16)
+#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0x1, 9)
+#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID_NO_CLR(txdesc, value)                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1, 9)
+#define GET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc)                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1, 9)
+#define SET_TX_DESC_BUFFER_CTRL_CNT(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0xf, 5)
+#define SET_TX_DESC_BUFFER_CTRL_CNT_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0xf, 5)
+#define GET_TX_DESC_BUFFER_CTRL_CNT(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xf, 5)
+#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc, value)                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7,   \
+				  value, 0x1f, 0)
+#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE_NO_CLR(txdesc, value)          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1f, 0)
+#define GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc)                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1f, \
+			      0)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_BUFFER_PATH_MAPA(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x3, 30)
+#define SET_TX_DESC_BUFFER_PATH_MAPA_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 30)
+#define GET_TX_DESC_BUFFER_PATH_MAPA(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3,  \
+			      30)
+#define SET_TX_DESC_BUFFER_PATH_MAPB(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x3, 28)
+#define SET_TX_DESC_BUFFER_PATH_MAPB_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 28)
+#define GET_TX_DESC_BUFFER_PATH_MAPB(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3,  \
+			      28)
+#define SET_TX_DESC_BUFFER_PATH_MAPC(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x3, 26)
+#define SET_TX_DESC_BUFFER_PATH_MAPC_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 26)
+#define GET_TX_DESC_BUFFER_PATH_MAPC(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3,  \
+			      26)
+#define SET_TX_DESC_BUFFER_PATH_MAPD(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x3, 24)
+#define SET_TX_DESC_BUFFER_PATH_MAPD_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 24)
+#define GET_TX_DESC_BUFFER_PATH_MAPD(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3,  \
+			      24)
+#define SET_TX_DESC_BUFFER_ANTSEL_A(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xf, 20)
+#define SET_TX_DESC_BUFFER_ANTSEL_A_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 20)
+#define GET_TX_DESC_BUFFER_ANTSEL_A(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf,  \
+			      20)
+#define SET_TX_DESC_BUFFER_ANTSEL_B(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xf, 16)
+#define SET_TX_DESC_BUFFER_ANTSEL_B_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 16)
+#define GET_TX_DESC_BUFFER_ANTSEL_B(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf,  \
+			      16)
+#define SET_TX_DESC_BUFFER_ANTSEL_C(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xf, 12)
+#define SET_TX_DESC_BUFFER_ANTSEL_C_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 12)
+#define GET_TX_DESC_BUFFER_ANTSEL_C(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf,  \
+			      12)
+#define SET_TX_DESC_BUFFER_ANTSEL_D(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xf, 8)
+#define SET_TX_DESC_BUFFER_ANTSEL_D_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 8)
+#define GET_TX_DESC_BUFFER_ANTSEL_D(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf, 8)
+#define SET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0xf, 4)
+#define SET_TX_DESC_BUFFER_NTX_PATH_EN_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 4)
+#define GET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf, 4)
+#define SET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x1, 3)
+#define SET_TX_DESC_BUFFER_ANTLSEL_EN_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 3)
+#define GET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, 3)
+#define SET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8,   \
+				  value, 0x7, 0)
+#define SET_TX_DESC_BUFFER_AMPDU_DENSITY_NO_CLR(txdesc, value)                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword8, value, 0x7, 0)
+#define GET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc)                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x7, 0)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_BUFFER_VCS_STBC(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x3, 30)
+#define SET_TX_DESC_BUFFER_VCS_STBC_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x3, 30)
+#define GET_TX_DESC_BUFFER_VCS_STBC(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x3,  \
+			      30)
+#define SET_TX_DESC_BUFFER_DATA_STBC(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x3, 28)
+#define SET_TX_DESC_BUFFER_DATA_STBC_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x3, 28)
+#define GET_TX_DESC_BUFFER_DATA_STBC(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x3,  \
+			      28)
+#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0xf, 24)
+#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE_NO_CLR(txdesc, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0xf, 24)
+#define GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xf,  \
+			      24)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 23)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN_NO_CLR(txdesc, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 23)
+#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1,  \
+			      23)
+#define SET_TX_DESC_BUFFER_MHR_CP(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 22)
+#define SET_TX_DESC_BUFFER_MHR_CP_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 22)
+#define GET_TX_DESC_BUFFER_MHR_CP(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1,  \
+			      22)
+#define SET_TX_DESC_BUFFER_SMH_EN(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 21)
+#define SET_TX_DESC_BUFFER_SMH_EN_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 21)
+#define GET_TX_DESC_BUFFER_SMH_EN(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1,  \
+			      21)
+#define SET_TX_DESC_BUFFER_RTSRATE(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1f, 16)
+#define SET_TX_DESC_BUFFER_RTSRATE_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1f, 16)
+#define GET_TX_DESC_BUFFER_RTSRATE(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1f, \
+			      16)
+#define SET_TX_DESC_BUFFER_SMH_CAM(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0xff, 8)
+#define SET_TX_DESC_BUFFER_SMH_CAM_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0xff, 8)
+#define GET_TX_DESC_BUFFER_SMH_CAM(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xff, \
+			      8)
+#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 7)
+#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL_NO_CLR(txdesc, value)                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 7)
+#define GET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc)                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 7)
+#define SET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 6)
+#define SET_TX_DESC_BUFFER_ARFR_HT_EN_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 6)
+#define GET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 6)
+#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 5)
+#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN_NO_CLR(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 5)
+#define GET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 5)
+#define SET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 4)
+#define SET_TX_DESC_BUFFER_ARFR_CCK_EN_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 4)
+#define GET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 4)
+#define SET_TX_DESC_BUFFER_RTS_SHORT(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 3)
+#define SET_TX_DESC_BUFFER_RTS_SHORT_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 3)
+#define GET_TX_DESC_BUFFER_RTS_SHORT(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 3)
+#define SET_TX_DESC_BUFFER_DISDATAFB(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 2)
+#define SET_TX_DESC_BUFFER_DISDATAFB_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 2)
+#define GET_TX_DESC_BUFFER_DISDATAFB(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 2)
+#define SET_TX_DESC_BUFFER_DISRTSFB(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 1)
+#define SET_TX_DESC_BUFFER_DISRTSFB_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 1)
+#define GET_TX_DESC_BUFFER_DISRTSFB(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 1)
+#define SET_TX_DESC_BUFFER_EXT_EDCA(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9,   \
+				  value, 0x1, 0)
+#define SET_TX_DESC_BUFFER_EXT_EDCA_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 0)
+#define GET_TX_DESC_BUFFER_EXT_EDCA(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 0)
+
+/*TXDESC_WORD10*/
+
+#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0xff, 24)
+#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME_NO_CLR(txdesc, value)                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0xff, 24)
+#define GET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc)                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10,      \
+			      0xff, 24)
+#define SET_TX_DESC_BUFFER_SPECIAL_CW(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 23)
+#define SET_TX_DESC_BUFFER_SPECIAL_CW_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 23)
+#define GET_TX_DESC_BUFFER_SPECIAL_CW(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      23)
+#define SET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 22)
+#define SET_TX_DESC_BUFFER_RDG_NAV_EXT_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 22)
+#define GET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      22)
+#define SET_TX_DESC_BUFFER_RAW(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 21)
+#define SET_TX_DESC_BUFFER_RAW_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 21)
+#define GET_TX_DESC_BUFFER_RAW(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      21)
+#define SET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1f, 16)
+#define SET_TX_DESC_BUFFER_MAX_AGG_NUM_NO_CLR(txdesc, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1f, 16)
+#define GET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10,      \
+			      0x1f, 16)
+#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0xff, 8)
+#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE_NO_CLR(txdesc, value)               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0xff, 8)
+#define GET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc)                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10,      \
+			      0xff, 8)
+#define SET_TX_DESC_BUFFER_GF(txdesc, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 7)
+#define SET_TX_DESC_BUFFER_GF_NO_CLR(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 7)
+#define GET_TX_DESC_BUFFER_GF(txdesc)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      7)
+#define SET_TX_DESC_BUFFER_MOREFRAG(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 6)
+#define SET_TX_DESC_BUFFER_MOREFRAG_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 6)
+#define GET_TX_DESC_BUFFER_MOREFRAG(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      6)
+#define SET_TX_DESC_BUFFER_NOACM(txdesc, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 5)
+#define SET_TX_DESC_BUFFER_NOACM_NO_CLR(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 5)
+#define GET_TX_DESC_BUFFER_NOACM(txdesc)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      5)
+#define SET_TX_DESC_BUFFER_HTC(txdesc, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 4)
+#define SET_TX_DESC_BUFFER_HTC_NO_CLR(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 4)
+#define GET_TX_DESC_BUFFER_HTC(txdesc)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      4)
+#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 3)
+#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS_NO_CLR(txdesc, value)             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 3)
+#define GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc)                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      3)
+#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x1, 2)
+#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN_NO_CLR(txdesc, value)               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 2)
+#define GET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc)                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
+			      2)
+#define SET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10,  \
+				  value, 0x3, 0)
+#define SET_TX_DESC_BUFFER_HW_SSN_SEL_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword10, value, 0x3, 0)
+#define GET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x3, \
+			      0)
+
+/*TXDESC_WORD11*/
+
+#define SET_TX_DESC_BUFFER_ADDR_CAM(txdesc, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11,  \
+				  value, 0xff, 24)
+#define SET_TX_DESC_BUFFER_ADDR_CAM_NO_CLR(txdesc, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword11, value, 0xff, 24)
+#define GET_TX_DESC_BUFFER_ADDR_CAM(txdesc)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11,      \
+			      0xff, 24)
+#define SET_TX_DESC_BUFFER_SND_TARGET(txdesc, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11,  \
+				  value, 0xff, 16)
+#define SET_TX_DESC_BUFFER_SND_TARGET_NO_CLR(txdesc, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword11, value, 0xff, 16)
+#define GET_TX_DESC_BUFFER_SND_TARGET(txdesc)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11,      \
+			      0xff, 16)
+#define SET_TX_DESC_BUFFER_DATA_LDPC(txdesc, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11,  \
+				  value, 0x1, 15)
+#define SET_TX_DESC_BUFFER_DATA_LDPC_NO_CLR(txdesc, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword11, value, 0x1, 15)
+#define GET_TX_DESC_BUFFER_DATA_LDPC(txdesc)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0x1, \
+			      15)
+#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11,  \
+				  value, 0x1, 14)
+#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN_NO_CLR(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword11, value, 0x1, 14)
+#define GET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0x1, \
+			      14)
+#define SET_TX_DESC_BUFFER_G_ID(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11,  \
+				  value, 0x3f, 8)
+#define SET_TX_DESC_BUFFER_G_ID_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword11, value, 0x3f, 8)
+#define GET_TX_DESC_BUFFER_G_ID(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11,      \
+			      0x3f, 8)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11,  \
+				  value, 0xf, 4)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC_NO_CLR(txdesc, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword11, value, 0xf, 4)
+#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0xf, \
+			      4)
+#define SET_TX_DESC_BUFFER_DATA_SC(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11,  \
+				  value, 0xf, 0)
+#define SET_TX_DESC_BUFFER_DATA_SC_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword11, value, 0xf, 0)
+#define GET_TX_DESC_BUFFER_DATA_SC(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0xf, \
+			      0)
+
+/*TXDESC_WORD12*/
+
+#define SET_TX_DESC_BUFFER_LEN1_L(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword12,  \
+				  value, 0x7f, 17)
+#define SET_TX_DESC_BUFFER_LEN1_L_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword12, value, 0x7f, 17)
+#define GET_TX_DESC_BUFFER_LEN1_L(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword12,      \
+			      0x7f, 17)
+#define SET_TX_DESC_BUFFER_LEN0(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword12,  \
+				  value, 0x1fff, 4)
+#define SET_TX_DESC_BUFFER_LEN0_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword12, value, 0x1fff, 4)
+#define GET_TX_DESC_BUFFER_LEN0(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword12,      \
+			      0x1fff, 4)
+#define SET_TX_DESC_BUFFER_PKT_NUM(txdesc, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword12,  \
+				  value, 0xf, 0)
+#define SET_TX_DESC_BUFFER_PKT_NUM_NO_CLR(txdesc, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword12, value, 0xf, 0)
+#define GET_TX_DESC_BUFFER_PKT_NUM(txdesc)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword12, 0xf, \
+			      0)
+
+/*TXDESC_WORD13*/
+
+#define SET_TX_DESC_BUFFER_LEN3(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword13,  \
+				  value, 0x1fff, 19)
+#define SET_TX_DESC_BUFFER_LEN3_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword13, value, 0x1fff, 19)
+#define GET_TX_DESC_BUFFER_LEN3(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword13,      \
+			      0x1fff, 19)
+#define SET_TX_DESC_BUFFER_LEN2(txdesc, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword13,  \
+				  value, 0x1fff, 6)
+#define SET_TX_DESC_BUFFER_LEN2_NO_CLR(txdesc, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword13, value, 0x1fff, 6)
+#define GET_TX_DESC_BUFFER_LEN2(txdesc)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword13,      \
+			      0x1fff, 6)
+#define SET_TX_DESC_BUFFER_LEN1_H(txdesc, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword13,  \
+				  value, 0x3f, 0)
+#define SET_TX_DESC_BUFFER_LEN1_H_NO_CLR(txdesc, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc)->dword13, value, 0x3f, 0)
+#define GET_TX_DESC_BUFFER_LEN1_H(txdesc)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword13,      \
+			      0x3f, 0)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_chip.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_chip.h
new file mode 100644
index 000000000000..a3e80ca4ce39
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_chip.h
@@ -0,0 +1,509 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_BUFFER_CHIP_H_
+#define _HALMAC_TX_DESC_BUFFER_CHIP_H_
+#if (HALMAC_8814B_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_BUFFER_RDG_EN_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_RDG_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_RDG_EN_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_RDG_EN(txdesc)
+#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL_8814B(txdesc, value)                \
+	SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc, value)
+#define GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL_8814B(txdesc)                       \
+	GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc)
+#define SET_TX_DESC_BUFFER_AGG_EN_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_AGG_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_AGG_EN_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_AGG_EN(txdesc)
+#define SET_TX_DESC_BUFFER_PKT_OFFSET_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_PKT_OFFSET(txdesc, value)
+#define GET_TX_DESC_BUFFER_PKT_OFFSET_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_PKT_OFFSET(txdesc)
+#define SET_TX_DESC_BUFFER_OFFSET_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_OFFSET(txdesc, value)
+#define GET_TX_DESC_BUFFER_OFFSET_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_OFFSET(txdesc)
+#define SET_TX_DESC_BUFFER_TXPKTSIZE_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_BUFFER_TXPKTSIZE_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_TXPKTSIZE(txdesc)
+
+/*TXDESC_WORD1*/
+
+#define SET_TX_DESC_BUFFER_USERATE_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_USERATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_USERATE_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_USERATE(txdesc)
+#define SET_TX_DESC_BUFFER_AMSDU_8814B(txdesc, value)                          \
+	SET_TX_DESC_BUFFER_AMSDU(txdesc, value)
+#define GET_TX_DESC_BUFFER_AMSDU_8814B(txdesc) GET_TX_DESC_BUFFER_AMSDU(txdesc)
+#define SET_TX_DESC_BUFFER_EN_HWSEQ_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_EN_HWSEQ(txdesc, value)
+#define GET_TX_DESC_BUFFER_EN_HWSEQ_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_EN_HWSEQ(txdesc)
+#define SET_TX_DESC_BUFFER_EN_HWEXSEQ_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc, value)
+#define GET_TX_DESC_BUFFER_EN_HWEXSEQ_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc)
+#define SET_TX_DESC_BUFFER_SW_SEQ_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_SW_SEQ(txdesc, value)
+#define GET_TX_DESC_BUFFER_SW_SEQ_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_SW_SEQ(txdesc)
+#define SET_TX_DESC_BUFFER_DROP_ID_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_DROP_ID(txdesc, value)
+#define GET_TX_DESC_BUFFER_DROP_ID_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_DROP_ID(txdesc)
+#define SET_TX_DESC_BUFFER_MOREDATA_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_MOREDATA(txdesc, value)
+#define GET_TX_DESC_BUFFER_MOREDATA_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_MOREDATA(txdesc)
+#define SET_TX_DESC_BUFFER_QSEL_8814B(txdesc, value)                           \
+	SET_TX_DESC_BUFFER_QSEL(txdesc, value)
+#define GET_TX_DESC_BUFFER_QSEL_8814B(txdesc) GET_TX_DESC_BUFFER_QSEL(txdesc)
+#define SET_TX_DESC_BUFFER_MACID_8814B(txdesc, value)                          \
+	SET_TX_DESC_BUFFER_MACID(txdesc, value)
+#define GET_TX_DESC_BUFFER_MACID_8814B(txdesc) GET_TX_DESC_BUFFER_MACID(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_BUFFER_CHK_EN_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_CHK_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_CHK_EN_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_CHK_EN(txdesc)
+#define SET_TX_DESC_BUFFER_DISQSELSEQ_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_DISQSELSEQ(txdesc, value)
+#define GET_TX_DESC_BUFFER_DISQSELSEQ_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_DISQSELSEQ(txdesc)
+#define SET_TX_DESC_BUFFER_SND_PKT_SEL_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc, value)
+#define GET_TX_DESC_BUFFER_SND_PKT_SEL_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc)
+#define SET_TX_DESC_BUFFER_DMA_PRI_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_DMA_PRI(txdesc, value)
+#define GET_TX_DESC_BUFFER_DMA_PRI_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_DMA_PRI(txdesc)
+#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE_8814B(txdesc, value)                 \
+	SET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc, value)
+#define GET_TX_DESC_BUFFER_MAX_AMSDU_MODE_8814B(txdesc)                        \
+	GET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc)
+#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM_8814B(txdesc, value)                  \
+	SET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc, value)
+#define GET_TX_DESC_BUFFER_DMA_TXAGG_NUM_8814B(txdesc)                         \
+	GET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc)
+#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM_8814B(txdesc, value)                \
+	SET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc, value)
+#define GET_TX_DESC_BUFFER_TXDESC_CHECKSUM_8814B(txdesc)                       \
+	GET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE_8814B(txdesc, value)                   \
+	SET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc, value)
+#define GET_TX_DESC_BUFFER_OFFLOAD_SIZE_8814B(txdesc)                          \
+	GET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc)
+#define SET_TX_DESC_BUFFER_CHANNEL_DMA_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc, value)
+#define GET_TX_DESC_BUFFER_CHANNEL_DMA_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc)
+#define SET_TX_DESC_BUFFER_MBSSID_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_MBSSID(txdesc, value)
+#define GET_TX_DESC_BUFFER_MBSSID_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_MBSSID(txdesc)
+#define SET_TX_DESC_BUFFER_BK_8814B(txdesc, value)                             \
+	SET_TX_DESC_BUFFER_BK(txdesc, value)
+#define GET_TX_DESC_BUFFER_BK_8814B(txdesc) GET_TX_DESC_BUFFER_BK(txdesc)
+#define SET_TX_DESC_BUFFER_WHEADER_LEN_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_WHEADER_LEN(txdesc, value)
+#define GET_TX_DESC_BUFFER_WHEADER_LEN_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_WHEADER_LEN(txdesc)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_BUFFER_TRY_RATE_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_TRY_RATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_TRY_RATE_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_TRY_RATE(txdesc)
+#define SET_TX_DESC_BUFFER_DATA_BW_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_DATA_BW(txdesc, value)
+#define GET_TX_DESC_BUFFER_DATA_BW_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_DATA_BW(txdesc)
+#define SET_TX_DESC_BUFFER_DATA_SHORT_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_DATA_SHORT(txdesc, value)
+#define GET_TX_DESC_BUFFER_DATA_SHORT_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_DATA_SHORT(txdesc)
+#define SET_TX_DESC_BUFFER_DATARATE_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_DATARATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_DATARATE_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_DATARATE(txdesc)
+#define SET_TX_DESC_BUFFER_TXBF_PATH_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_TXBF_PATH(txdesc, value)
+#define GET_TX_DESC_BUFFER_TXBF_PATH_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_TXBF_PATH(txdesc)
+#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET_8814B(txdesc, value)            \
+	SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc, value)
+#define GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET_8814B(txdesc)                   \
+	GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_BUFFER_RTY_LMT_EN_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_RTY_LMT_EN_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc)
+#define SET_TX_DESC_BUFFER_HW_RTS_EN_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_HW_RTS_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_HW_RTS_EN_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_HW_RTS_EN(txdesc)
+#define SET_TX_DESC_BUFFER_RTS_EN_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_RTS_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_RTS_EN_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_RTS_EN(txdesc)
+#define SET_TX_DESC_BUFFER_CTS2SELF_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_CTS2SELF(txdesc, value)
+#define GET_TX_DESC_BUFFER_CTS2SELF_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_CTS2SELF(txdesc)
+#define SET_TX_DESC_BUFFER_TAILPAGE_H_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_TAILPAGE_H(txdesc, value)
+#define GET_TX_DESC_BUFFER_TAILPAGE_H_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_TAILPAGE_H(txdesc)
+#define SET_TX_DESC_BUFFER_TAILPAGE_L_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_TAILPAGE_L(txdesc, value)
+#define GET_TX_DESC_BUFFER_TAILPAGE_L_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_TAILPAGE_L(txdesc)
+#define SET_TX_DESC_BUFFER_NAVUSEHDR_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_NAVUSEHDR(txdesc, value)
+#define GET_TX_DESC_BUFFER_NAVUSEHDR_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_NAVUSEHDR(txdesc)
+#define SET_TX_DESC_BUFFER_BMC_8814B(txdesc, value)                            \
+	SET_TX_DESC_BUFFER_BMC(txdesc, value)
+#define GET_TX_DESC_BUFFER_BMC_8814B(txdesc) GET_TX_DESC_BUFFER_BMC(txdesc)
+#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT_8814B(txdesc, value)               \
+	SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc, value)
+#define GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT_8814B(txdesc)                      \
+	GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc)
+#define SET_TX_DESC_BUFFER_HW_AES_IV_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_HW_AES_IV(txdesc, value)
+#define GET_TX_DESC_BUFFER_HW_AES_IV_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_HW_AES_IV(txdesc)
+#define SET_TX_DESC_BUFFER_BT_NULL_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_BT_NULL(txdesc, value)
+#define GET_TX_DESC_BUFFER_BT_NULL_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_BT_NULL(txdesc)
+#define SET_TX_DESC_BUFFER_EN_DESC_ID_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_EN_DESC_ID(txdesc, value)
+#define GET_TX_DESC_BUFFER_EN_DESC_ID_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_EN_DESC_ID(txdesc)
+#define SET_TX_DESC_BUFFER_SECTYPE_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_SECTYPE(txdesc, value)
+#define GET_TX_DESC_BUFFER_SECTYPE_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_SECTYPE(txdesc)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_BUFFER_MULTIPLE_PORT_8814B(txdesc, value)                  \
+	SET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc, value)
+#define GET_TX_DESC_BUFFER_MULTIPLE_PORT_8814B(txdesc)                         \
+	GET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc)
+#define SET_TX_DESC_BUFFER_POLLUTED_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_POLLUTED(txdesc, value)
+#define GET_TX_DESC_BUFFER_POLLUTED_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_POLLUTED(txdesc)
+#define SET_TX_DESC_BUFFER_NULL_1_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_NULL_1(txdesc, value)
+#define GET_TX_DESC_BUFFER_NULL_1_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_NULL_1(txdesc)
+#define SET_TX_DESC_BUFFER_NULL_0_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_NULL_0(txdesc, value)
+#define GET_TX_DESC_BUFFER_NULL_0_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_NULL_0(txdesc)
+#define SET_TX_DESC_BUFFER_TRI_FRAME_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_TRI_FRAME(txdesc, value)
+#define GET_TX_DESC_BUFFER_TRI_FRAME_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_TRI_FRAME(txdesc)
+#define SET_TX_DESC_BUFFER_SPE_RPT_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_SPE_RPT(txdesc, value)
+#define GET_TX_DESC_BUFFER_SPE_RPT_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_SPE_RPT(txdesc)
+#define SET_TX_DESC_BUFFER_FTM_EN_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_FTM_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_FTM_EN_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_FTM_EN(txdesc)
+#define SET_TX_DESC_BUFFER_MU_DATARATE_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_MU_DATARATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_MU_DATARATE_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_MU_DATARATE(txdesc)
+#define SET_TX_DESC_BUFFER_CCA_RTS_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_CCA_RTS(txdesc, value)
+#define GET_TX_DESC_BUFFER_CCA_RTS_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_CCA_RTS(txdesc)
+#define SET_TX_DESC_BUFFER_NDPA_8814B(txdesc, value)                           \
+	SET_TX_DESC_BUFFER_NDPA(txdesc, value)
+#define GET_TX_DESC_BUFFER_NDPA_8814B(txdesc) GET_TX_DESC_BUFFER_NDPA(txdesc)
+#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE_8814B(txdesc, value)               \
+	SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc, value)
+#define GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE_8814B(txdesc)                      \
+	GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc)
+#define SET_TX_DESC_BUFFER_P_AID_8814B(txdesc, value)                          \
+	SET_TX_DESC_BUFFER_P_AID(txdesc, value)
+#define GET_TX_DESC_BUFFER_P_AID_8814B(txdesc) GET_TX_DESC_BUFFER_P_AID(txdesc)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_BUFFER_SW_DEFINE_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_SW_DEFINE(txdesc, value)
+#define GET_TX_DESC_BUFFER_SW_DEFINE_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_SW_DEFINE(txdesc)
+#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID_8814B(txdesc, value)                 \
+	SET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc, value)
+#define GET_TX_DESC_BUFFER_CTRL_CNT_VALID_8814B(txdesc)                        \
+	GET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc)
+#define SET_TX_DESC_BUFFER_CTRL_CNT_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_CTRL_CNT(txdesc, value)
+#define GET_TX_DESC_BUFFER_CTRL_CNT_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_CTRL_CNT(txdesc)
+#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE_8814B(txdesc, value)           \
+	SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE_8814B(txdesc)                  \
+	GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_BUFFER_PATH_MAPA_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_PATH_MAPA(txdesc, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPA_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_PATH_MAPA(txdesc)
+#define SET_TX_DESC_BUFFER_PATH_MAPB_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_PATH_MAPB(txdesc, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPB_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_PATH_MAPB(txdesc)
+#define SET_TX_DESC_BUFFER_PATH_MAPC_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_PATH_MAPC(txdesc, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPC_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_PATH_MAPC(txdesc)
+#define SET_TX_DESC_BUFFER_PATH_MAPD_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_PATH_MAPD(txdesc, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPD_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_PATH_MAPD(txdesc)
+#define SET_TX_DESC_BUFFER_ANTSEL_A_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_ANTSEL_A(txdesc, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_A_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_ANTSEL_A(txdesc)
+#define SET_TX_DESC_BUFFER_ANTSEL_B_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_ANTSEL_B(txdesc, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_B_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_ANTSEL_B(txdesc)
+#define SET_TX_DESC_BUFFER_ANTSEL_C_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_ANTSEL_C(txdesc, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_C_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_ANTSEL_C(txdesc)
+#define SET_TX_DESC_BUFFER_ANTSEL_D_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_ANTSEL_D(txdesc, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_D_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_ANTSEL_D(txdesc)
+#define SET_TX_DESC_BUFFER_NTX_PATH_EN_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_NTX_PATH_EN_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc)
+#define SET_TX_DESC_BUFFER_ANTLSEL_EN_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_ANTLSEL_EN_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc)
+#define SET_TX_DESC_BUFFER_AMPDU_DENSITY_8814B(txdesc, value)                  \
+	SET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc, value)
+#define GET_TX_DESC_BUFFER_AMPDU_DENSITY_8814B(txdesc)                         \
+	GET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_BUFFER_VCS_STBC_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_VCS_STBC(txdesc, value)
+#define GET_TX_DESC_BUFFER_VCS_STBC_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_VCS_STBC(txdesc)
+#define SET_TX_DESC_BUFFER_DATA_STBC_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_DATA_STBC(txdesc, value)
+#define GET_TX_DESC_BUFFER_DATA_STBC_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_DATA_STBC(txdesc)
+#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE_8814B(txdesc, value)            \
+	SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE_8814B(txdesc)                   \
+	GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN_8814B(txdesc, value)            \
+	SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN_8814B(txdesc)                   \
+	GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc)
+#define SET_TX_DESC_BUFFER_MHR_CP_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_MHR_CP(txdesc, value)
+#define GET_TX_DESC_BUFFER_MHR_CP_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_MHR_CP(txdesc)
+#define SET_TX_DESC_BUFFER_SMH_EN_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_SMH_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_SMH_EN_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_SMH_EN(txdesc)
+#define SET_TX_DESC_BUFFER_RTSRATE_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_RTSRATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_RTSRATE_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_RTSRATE(txdesc)
+#define SET_TX_DESC_BUFFER_SMH_CAM_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_SMH_CAM(txdesc, value)
+#define GET_TX_DESC_BUFFER_SMH_CAM_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_SMH_CAM(txdesc)
+#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL_8814B(txdesc, value)                 \
+	SET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc, value)
+#define GET_TX_DESC_BUFFER_ARFR_TABLE_SEL_8814B(txdesc)                        \
+	GET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc)
+#define SET_TX_DESC_BUFFER_ARFR_HT_EN_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_ARFR_HT_EN_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc)
+#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN_8814B(txdesc, value)                   \
+	SET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_ARFR_OFDM_EN_8814B(txdesc)                          \
+	GET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc)
+#define SET_TX_DESC_BUFFER_ARFR_CCK_EN_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_ARFR_CCK_EN_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc)
+#define SET_TX_DESC_BUFFER_RTS_SHORT_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_RTS_SHORT(txdesc, value)
+#define GET_TX_DESC_BUFFER_RTS_SHORT_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_RTS_SHORT(txdesc)
+#define SET_TX_DESC_BUFFER_DISDATAFB_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_DISDATAFB(txdesc, value)
+#define GET_TX_DESC_BUFFER_DISDATAFB_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_DISDATAFB(txdesc)
+#define SET_TX_DESC_BUFFER_DISRTSFB_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_DISRTSFB(txdesc, value)
+#define GET_TX_DESC_BUFFER_DISRTSFB_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_DISRTSFB(txdesc)
+#define SET_TX_DESC_BUFFER_EXT_EDCA_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_EXT_EDCA(txdesc, value)
+#define GET_TX_DESC_BUFFER_EXT_EDCA_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_EXT_EDCA(txdesc)
+
+/*TXDESC_WORD10*/
+
+#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME_8814B(txdesc, value)                 \
+	SET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc, value)
+#define GET_TX_DESC_BUFFER_AMPDU_MAX_TIME_8814B(txdesc)                        \
+	GET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc)
+#define SET_TX_DESC_BUFFER_SPECIAL_CW_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_SPECIAL_CW(txdesc, value)
+#define GET_TX_DESC_BUFFER_SPECIAL_CW_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_SPECIAL_CW(txdesc)
+#define SET_TX_DESC_BUFFER_RDG_NAV_EXT_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc, value)
+#define GET_TX_DESC_BUFFER_RDG_NAV_EXT_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc)
+#define SET_TX_DESC_BUFFER_RAW_8814B(txdesc, value)                            \
+	SET_TX_DESC_BUFFER_RAW(txdesc, value)
+#define GET_TX_DESC_BUFFER_RAW_8814B(txdesc) GET_TX_DESC_BUFFER_RAW(txdesc)
+#define SET_TX_DESC_BUFFER_MAX_AGG_NUM_8814B(txdesc, value)                    \
+	SET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc, value)
+#define GET_TX_DESC_BUFFER_MAX_AGG_NUM_8814B(txdesc)                           \
+	GET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc)
+#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE_8814B(txdesc, value)                \
+	SET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc, value)
+#define GET_TX_DESC_BUFFER_FINAL_DATA_RATE_8814B(txdesc)                       \
+	GET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc)
+#define SET_TX_DESC_BUFFER_GF_8814B(txdesc, value)                             \
+	SET_TX_DESC_BUFFER_GF(txdesc, value)
+#define GET_TX_DESC_BUFFER_GF_8814B(txdesc) GET_TX_DESC_BUFFER_GF(txdesc)
+#define SET_TX_DESC_BUFFER_MOREFRAG_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_MOREFRAG(txdesc, value)
+#define GET_TX_DESC_BUFFER_MOREFRAG_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_MOREFRAG(txdesc)
+#define SET_TX_DESC_BUFFER_NOACM_8814B(txdesc, value)                          \
+	SET_TX_DESC_BUFFER_NOACM(txdesc, value)
+#define GET_TX_DESC_BUFFER_NOACM_8814B(txdesc) GET_TX_DESC_BUFFER_NOACM(txdesc)
+#define SET_TX_DESC_BUFFER_HTC_8814B(txdesc, value)                            \
+	SET_TX_DESC_BUFFER_HTC(txdesc, value)
+#define GET_TX_DESC_BUFFER_HTC_8814B(txdesc) GET_TX_DESC_BUFFER_HTC(txdesc)
+#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS_8814B(txdesc, value)              \
+	SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc, value)
+#define GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS_8814B(txdesc)                     \
+	GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc)
+#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN_8814B(txdesc, value)                \
+	SET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_USE_MAX_TIME_EN_8814B(txdesc)                       \
+	GET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc)
+#define SET_TX_DESC_BUFFER_HW_SSN_SEL_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc, value)
+#define GET_TX_DESC_BUFFER_HW_SSN_SEL_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc)
+
+/*TXDESC_WORD11*/
+
+#define SET_TX_DESC_BUFFER_ADDR_CAM_8814B(txdesc, value)                       \
+	SET_TX_DESC_BUFFER_ADDR_CAM(txdesc, value)
+#define GET_TX_DESC_BUFFER_ADDR_CAM_8814B(txdesc)                              \
+	GET_TX_DESC_BUFFER_ADDR_CAM(txdesc)
+#define SET_TX_DESC_BUFFER_SND_TARGET_8814B(txdesc, value)                     \
+	SET_TX_DESC_BUFFER_SND_TARGET(txdesc, value)
+#define GET_TX_DESC_BUFFER_SND_TARGET_8814B(txdesc)                            \
+	GET_TX_DESC_BUFFER_SND_TARGET(txdesc)
+#define SET_TX_DESC_BUFFER_DATA_LDPC_8814B(txdesc, value)                      \
+	SET_TX_DESC_BUFFER_DATA_LDPC(txdesc, value)
+#define GET_TX_DESC_BUFFER_DATA_LDPC_8814B(txdesc)                             \
+	GET_TX_DESC_BUFFER_DATA_LDPC(txdesc)
+#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN_8814B(txdesc, value)                   \
+	SET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc, value)
+#define GET_TX_DESC_BUFFER_LSIG_TXOP_EN_8814B(txdesc)                          \
+	GET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc)
+#define SET_TX_DESC_BUFFER_G_ID_8814B(txdesc, value)                           \
+	SET_TX_DESC_BUFFER_G_ID(txdesc, value)
+#define GET_TX_DESC_BUFFER_G_ID_8814B(txdesc) GET_TX_DESC_BUFFER_G_ID(txdesc)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC_8814B(txdesc, value)            \
+	SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc, value)
+#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC_8814B(txdesc)                   \
+	GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc)
+#define SET_TX_DESC_BUFFER_DATA_SC_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_DATA_SC(txdesc, value)
+#define GET_TX_DESC_BUFFER_DATA_SC_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_DATA_SC(txdesc)
+
+/*TXDESC_WORD12*/
+
+#define SET_TX_DESC_BUFFER_LEN1_L_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_LEN1_L(txdesc, value)
+#define GET_TX_DESC_BUFFER_LEN1_L_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_LEN1_L(txdesc)
+#define SET_TX_DESC_BUFFER_LEN0_8814B(txdesc, value)                           \
+	SET_TX_DESC_BUFFER_LEN0(txdesc, value)
+#define GET_TX_DESC_BUFFER_LEN0_8814B(txdesc) GET_TX_DESC_BUFFER_LEN0(txdesc)
+#define SET_TX_DESC_BUFFER_PKT_NUM_8814B(txdesc, value)                        \
+	SET_TX_DESC_BUFFER_PKT_NUM(txdesc, value)
+#define GET_TX_DESC_BUFFER_PKT_NUM_8814B(txdesc)                               \
+	GET_TX_DESC_BUFFER_PKT_NUM(txdesc)
+
+/*TXDESC_WORD13*/
+
+#define SET_TX_DESC_BUFFER_LEN3_8814B(txdesc, value)                           \
+	SET_TX_DESC_BUFFER_LEN3(txdesc, value)
+#define GET_TX_DESC_BUFFER_LEN3_8814B(txdesc) GET_TX_DESC_BUFFER_LEN3(txdesc)
+#define SET_TX_DESC_BUFFER_LEN2_8814B(txdesc, value)                           \
+	SET_TX_DESC_BUFFER_LEN2(txdesc, value)
+#define GET_TX_DESC_BUFFER_LEN2_8814B(txdesc) GET_TX_DESC_BUFFER_LEN2(txdesc)
+#define SET_TX_DESC_BUFFER_LEN1_H_8814B(txdesc, value)                         \
+	SET_TX_DESC_BUFFER_LEN1_H(txdesc, value)
+#define GET_TX_DESC_BUFFER_LEN1_H_8814B(txdesc)                                \
+	GET_TX_DESC_BUFFER_LEN1_H(txdesc)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_nic.h
new file mode 100644
index 000000000000..6274102eeef6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_buffer_nic.h
@@ -0,0 +1,491 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_BUFFER_NIC_H_
+#define _HALMAC_TX_DESC_BUFFER_NIC_H_
+#if (HALMAC_8814B_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_BUFFER_RDG_EN(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 31, 1, value)
+#define GET_TX_DESC_BUFFER_RDG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 31, 1)
+#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc, value)                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 30, 1, value)
+#define GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc)                             \
+	LE_BITS_TO_4BYTE(txdesc + 0x00, 30, 1)
+#define SET_TX_DESC_BUFFER_AGG_EN(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 29, 1, value)
+#define GET_TX_DESC_BUFFER_AGG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 29, 1)
+#define SET_TX_DESC_BUFFER_PKT_OFFSET(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 24, 5, value)
+#define GET_TX_DESC_BUFFER_PKT_OFFSET(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x00, 24, 5)
+#define SET_TX_DESC_BUFFER_OFFSET(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 16, 8, value)
+#define GET_TX_DESC_BUFFER_OFFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 16, 8)
+#define SET_TX_DESC_BUFFER_TXPKTSIZE(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 0, 16, value)
+#define GET_TX_DESC_BUFFER_TXPKTSIZE(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x00, 0, 16)
+
+/*TXDESC_WORD1*/
+
+#define SET_TX_DESC_BUFFER_USERATE(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 31, 1, value)
+#define GET_TX_DESC_BUFFER_USERATE(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x04, 31, 1)
+#define SET_TX_DESC_BUFFER_AMSDU(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 30, 1, value)
+#define GET_TX_DESC_BUFFER_AMSDU(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 30, 1)
+#define SET_TX_DESC_BUFFER_EN_HWSEQ(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 29, 1, value)
+#define GET_TX_DESC_BUFFER_EN_HWSEQ(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x04, 29, 1)
+#define SET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 28, 1, value)
+#define GET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x04, 28, 1)
+#define SET_TX_DESC_BUFFER_SW_SEQ(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 16, 12, value)
+#define GET_TX_DESC_BUFFER_SW_SEQ(txdesc)                                      \
+	LE_BITS_TO_4BYTE(txdesc + 0x04, 16, 12)
+#define SET_TX_DESC_BUFFER_DROP_ID(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 14, 2, value)
+#define GET_TX_DESC_BUFFER_DROP_ID(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x04, 14, 2)
+#define SET_TX_DESC_BUFFER_MOREDATA(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 13, 1, value)
+#define GET_TX_DESC_BUFFER_MOREDATA(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x04, 13, 1)
+#define SET_TX_DESC_BUFFER_QSEL(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 8, 5, value)
+#define GET_TX_DESC_BUFFER_QSEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 8, 5)
+#define SET_TX_DESC_BUFFER_MACID(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 0, 8, value)
+#define GET_TX_DESC_BUFFER_MACID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 0, 8)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_BUFFER_CHK_EN(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 31, 1, value)
+#define GET_TX_DESC_BUFFER_CHK_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 31, 1)
+#define SET_TX_DESC_BUFFER_DISQSELSEQ(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 30, 1, value)
+#define GET_TX_DESC_BUFFER_DISQSELSEQ(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 30, 1)
+#define SET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 28, 2, value)
+#define GET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 28, 2)
+#define SET_TX_DESC_BUFFER_DMA_PRI(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 27, 1, value)
+#define GET_TX_DESC_BUFFER_DMA_PRI(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 27, 1)
+#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc, value)                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 3, value)
+#define GET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc)                              \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 3)
+#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc, value)                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 16, 8, value)
+#define GET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc)                               \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 16, 8)
+#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc, value)                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 0, 16, value)
+#define GET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc)                             \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 0, 16)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 16, 15, value)
+#define GET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc)                                \
+	LE_BITS_TO_4BYTE(txdesc + 0x0C, 16, 15)
+#define SET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 11, 5, value)
+#define GET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x0C, 11, 5)
+#define SET_TX_DESC_BUFFER_MBSSID(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 7, 4, value)
+#define GET_TX_DESC_BUFFER_MBSSID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 7, 4)
+#define SET_TX_DESC_BUFFER_BK(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 6, 1, value)
+#define GET_TX_DESC_BUFFER_BK(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 6, 1)
+#define SET_TX_DESC_BUFFER_WHEADER_LEN(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 0, 5, value)
+#define GET_TX_DESC_BUFFER_WHEADER_LEN(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x0C, 0, 5)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_BUFFER_TRY_RATE(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 26, 1, value)
+#define GET_TX_DESC_BUFFER_TRY_RATE(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 26, 1)
+#define SET_TX_DESC_BUFFER_DATA_BW(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 24, 2, value)
+#define GET_TX_DESC_BUFFER_DATA_BW(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 24, 2)
+#define SET_TX_DESC_BUFFER_DATA_SHORT(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 23, 1, value)
+#define GET_TX_DESC_BUFFER_DATA_SHORT(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 23, 1)
+#define SET_TX_DESC_BUFFER_DATARATE(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 16, 7, value)
+#define GET_TX_DESC_BUFFER_DATARATE(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 16, 7)
+#define SET_TX_DESC_BUFFER_TXBF_PATH(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 11, 1, value)
+#define GET_TX_DESC_BUFFER_TXBF_PATH(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 11, 1)
+#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 0, 11, value)
+#define GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc)                         \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 0, 11)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 31, 1, value)
+#define GET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 31, 1)
+#define SET_TX_DESC_BUFFER_HW_RTS_EN(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 30, 1, value)
+#define GET_TX_DESC_BUFFER_HW_RTS_EN(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 30, 1)
+#define SET_TX_DESC_BUFFER_RTS_EN(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 29, 1, value)
+#define GET_TX_DESC_BUFFER_RTS_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 29, 1)
+#define SET_TX_DESC_BUFFER_CTS2SELF(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 28, 1, value)
+#define GET_TX_DESC_BUFFER_CTS2SELF(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 28, 1)
+#define SET_TX_DESC_BUFFER_TAILPAGE_H(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 24, 4, value)
+#define GET_TX_DESC_BUFFER_TAILPAGE_H(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 24, 4)
+#define SET_TX_DESC_BUFFER_TAILPAGE_L(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 16, 8, value)
+#define GET_TX_DESC_BUFFER_TAILPAGE_L(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 16, 8)
+#define SET_TX_DESC_BUFFER_NAVUSEHDR(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 15, 1, value)
+#define GET_TX_DESC_BUFFER_NAVUSEHDR(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 15, 1)
+#define SET_TX_DESC_BUFFER_BMC(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 14, 1, value)
+#define GET_TX_DESC_BUFFER_BMC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 14, 1)
+#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc, value)                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 8, 6, value)
+#define GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc)                            \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 8, 6)
+#define SET_TX_DESC_BUFFER_HW_AES_IV(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 7, 1, value)
+#define GET_TX_DESC_BUFFER_HW_AES_IV(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 7, 1)
+#define SET_TX_DESC_BUFFER_BT_NULL(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 3, 1, value)
+#define GET_TX_DESC_BUFFER_BT_NULL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 3, 1)
+#define SET_TX_DESC_BUFFER_EN_DESC_ID(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 2, 1, value)
+#define GET_TX_DESC_BUFFER_EN_DESC_ID(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 2, 1)
+#define SET_TX_DESC_BUFFER_SECTYPE(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 0, 2, value)
+#define GET_TX_DESC_BUFFER_SECTYPE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 0, 2)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc, value)                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 29, 3, value)
+#define GET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc)                               \
+	LE_BITS_TO_4BYTE(txdesc + 0x18, 29, 3)
+#define SET_TX_DESC_BUFFER_POLLUTED(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 28, 1, value)
+#define GET_TX_DESC_BUFFER_POLLUTED(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x18, 28, 1)
+#define SET_TX_DESC_BUFFER_NULL_1(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 27, 1, value)
+#define GET_TX_DESC_BUFFER_NULL_1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 27, 1)
+#define SET_TX_DESC_BUFFER_NULL_0(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 26, 1, value)
+#define GET_TX_DESC_BUFFER_NULL_0(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 26, 1)
+#define SET_TX_DESC_BUFFER_TRI_FRAME(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 25, 1, value)
+#define GET_TX_DESC_BUFFER_TRI_FRAME(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x18, 25, 1)
+#define SET_TX_DESC_BUFFER_SPE_RPT(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 24, 1, value)
+#define GET_TX_DESC_BUFFER_SPE_RPT(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x18, 24, 1)
+#define SET_TX_DESC_BUFFER_FTM_EN(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 23, 1, value)
+#define GET_TX_DESC_BUFFER_FTM_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 23, 1)
+#define SET_TX_DESC_BUFFER_MU_DATARATE(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 16, 7, value)
+#define GET_TX_DESC_BUFFER_MU_DATARATE(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x18, 16, 7)
+#define SET_TX_DESC_BUFFER_CCA_RTS(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 14, 2, value)
+#define GET_TX_DESC_BUFFER_CCA_RTS(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x18, 14, 2)
+#define SET_TX_DESC_BUFFER_NDPA(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 12, 2, value)
+#define GET_TX_DESC_BUFFER_NDPA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 12, 2)
+#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc, value)                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 9, 2, value)
+#define GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc)                            \
+	LE_BITS_TO_4BYTE(txdesc + 0x18, 9, 2)
+#define SET_TX_DESC_BUFFER_P_AID(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 0, 9, value)
+#define GET_TX_DESC_BUFFER_P_AID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 0, 9)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_BUFFER_SW_DEFINE(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 16, 12, value)
+#define GET_TX_DESC_BUFFER_SW_DEFINE(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x1C, 16, 12)
+#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc, value)                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 9, 1, value)
+#define GET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc)                              \
+	LE_BITS_TO_4BYTE(txdesc + 0x1C, 9, 1)
+#define SET_TX_DESC_BUFFER_CTRL_CNT(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 5, 4, value)
+#define GET_TX_DESC_BUFFER_CTRL_CNT(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x1C, 5, 4)
+#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc, value)                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 5, value)
+#define GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc)                        \
+	LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 5)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_BUFFER_PATH_MAPA(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 30, 2, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPA(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 30, 2)
+#define SET_TX_DESC_BUFFER_PATH_MAPB(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 28, 2, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPB(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 28, 2)
+#define SET_TX_DESC_BUFFER_PATH_MAPC(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 26, 2, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPC(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 26, 2)
+#define SET_TX_DESC_BUFFER_PATH_MAPD(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 24, 2, value)
+#define GET_TX_DESC_BUFFER_PATH_MAPD(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 24, 2)
+#define SET_TX_DESC_BUFFER_ANTSEL_A(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 20, 4, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_A(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 20, 4)
+#define SET_TX_DESC_BUFFER_ANTSEL_B(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 16, 4, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_B(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 16, 4)
+#define SET_TX_DESC_BUFFER_ANTSEL_C(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 12, 4, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_C(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 12, 4)
+#define SET_TX_DESC_BUFFER_ANTSEL_D(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 8, 4, value)
+#define GET_TX_DESC_BUFFER_ANTSEL_D(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 8, 4)
+#define SET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 4, 4, value)
+#define GET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 4, 4)
+#define SET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 3, 1, value)
+#define GET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 3, 1)
+#define SET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc, value)                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 0, 3, value)
+#define GET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc)                               \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 0, 3)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_BUFFER_VCS_STBC(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 30, 2, value)
+#define GET_TX_DESC_BUFFER_VCS_STBC(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 30, 2)
+#define SET_TX_DESC_BUFFER_DATA_STBC(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 28, 2, value)
+#define GET_TX_DESC_BUFFER_DATA_STBC(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 28, 2)
+#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 24, 4, value)
+#define GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc)                         \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 24, 4)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 23, 1, value)
+#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc)                         \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 23, 1)
+#define SET_TX_DESC_BUFFER_MHR_CP(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 22, 1, value)
+#define GET_TX_DESC_BUFFER_MHR_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 22, 1)
+#define SET_TX_DESC_BUFFER_SMH_EN(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 21, 1, value)
+#define GET_TX_DESC_BUFFER_SMH_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 21, 1)
+#define SET_TX_DESC_BUFFER_RTSRATE(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 16, 5, value)
+#define GET_TX_DESC_BUFFER_RTSRATE(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 16, 5)
+#define SET_TX_DESC_BUFFER_SMH_CAM(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 8, 8, value)
+#define GET_TX_DESC_BUFFER_SMH_CAM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 8, 8)
+#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc, value)                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 7, 1, value)
+#define GET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc)                              \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 7, 1)
+#define SET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 6, 1, value)
+#define GET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 6, 1)
+#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 5, 1, value)
+#define GET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc)                                \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 5, 1)
+#define SET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 4, 1, value)
+#define GET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 4, 1)
+#define SET_TX_DESC_BUFFER_RTS_SHORT(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 3, 1, value)
+#define GET_TX_DESC_BUFFER_RTS_SHORT(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 3, 1)
+#define SET_TX_DESC_BUFFER_DISDATAFB(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 2, 1, value)
+#define GET_TX_DESC_BUFFER_DISDATAFB(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 2, 1)
+#define SET_TX_DESC_BUFFER_DISRTSFB(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 1, 1, value)
+#define GET_TX_DESC_BUFFER_DISRTSFB(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 1, 1)
+#define SET_TX_DESC_BUFFER_EXT_EDCA(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 0, 1, value)
+#define GET_TX_DESC_BUFFER_EXT_EDCA(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 0, 1)
+
+/*TXDESC_WORD10*/
+
+#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc, value)                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 24, 8, value)
+#define GET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc)                              \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 24, 8)
+#define SET_TX_DESC_BUFFER_SPECIAL_CW(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 23, 1, value)
+#define GET_TX_DESC_BUFFER_SPECIAL_CW(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 23, 1)
+#define SET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 22, 1, value)
+#define GET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 22, 1)
+#define SET_TX_DESC_BUFFER_RAW(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 21, 1, value)
+#define GET_TX_DESC_BUFFER_RAW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 21, 1)
+#define SET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 16, 5, value)
+#define GET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 16, 5)
+#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc, value)                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 8, 8, value)
+#define GET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc)                             \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 8, 8)
+#define SET_TX_DESC_BUFFER_GF(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 7, 1, value)
+#define GET_TX_DESC_BUFFER_GF(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 7, 1)
+#define SET_TX_DESC_BUFFER_MOREFRAG(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 6, 1, value)
+#define GET_TX_DESC_BUFFER_MOREFRAG(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 6, 1)
+#define SET_TX_DESC_BUFFER_NOACM(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 5, 1, value)
+#define GET_TX_DESC_BUFFER_NOACM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 5, 1)
+#define SET_TX_DESC_BUFFER_HTC(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 4, 1, value)
+#define GET_TX_DESC_BUFFER_HTC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 4, 1)
+#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc, value)                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 3, 1, value)
+#define GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc)                           \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 3, 1)
+#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc, value)                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 2, 1, value)
+#define GET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc)                             \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 2, 1)
+#define SET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 0, 2, value)
+#define GET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x28, 0, 2)
+
+/*TXDESC_WORD11*/
+
+#define SET_TX_DESC_BUFFER_ADDR_CAM(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 24, 8, value)
+#define GET_TX_DESC_BUFFER_ADDR_CAM(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x2C, 24, 8)
+#define SET_TX_DESC_BUFFER_SND_TARGET(txdesc, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 16, 8, value)
+#define GET_TX_DESC_BUFFER_SND_TARGET(txdesc)                                  \
+	LE_BITS_TO_4BYTE(txdesc + 0x2C, 16, 8)
+#define SET_TX_DESC_BUFFER_DATA_LDPC(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 15, 1, value)
+#define GET_TX_DESC_BUFFER_DATA_LDPC(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x2C, 15, 1)
+#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 14, 1, value)
+#define GET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc)                                \
+	LE_BITS_TO_4BYTE(txdesc + 0x2C, 14, 1)
+#define SET_TX_DESC_BUFFER_G_ID(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 8, 6, value)
+#define GET_TX_DESC_BUFFER_G_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x2C, 8, 6)
+#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 4, 4, value)
+#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc)                         \
+	LE_BITS_TO_4BYTE(txdesc + 0x2C, 4, 4)
+#define SET_TX_DESC_BUFFER_DATA_SC(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 0, 4, value)
+#define GET_TX_DESC_BUFFER_DATA_SC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x2C, 0, 4)
+
+/*TXDESC_WORD12*/
+
+#define SET_TX_DESC_BUFFER_LEN1_L(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x30, 17, 7, value)
+#define GET_TX_DESC_BUFFER_LEN1_L(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x30, 17, 7)
+#define SET_TX_DESC_BUFFER_LEN0(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x30, 4, 13, value)
+#define GET_TX_DESC_BUFFER_LEN0(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x30, 4, 13)
+#define SET_TX_DESC_BUFFER_PKT_NUM(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x30, 0, 4, value)
+#define GET_TX_DESC_BUFFER_PKT_NUM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x30, 0, 4)
+
+/*TXDESC_WORD13*/
+
+#define SET_TX_DESC_BUFFER_LEN3(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x34, 19, 13, value)
+#define GET_TX_DESC_BUFFER_LEN3(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x34, 19, 13)
+#define SET_TX_DESC_BUFFER_LEN2(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x34, 6, 13, value)
+#define GET_TX_DESC_BUFFER_LEN2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x34, 6, 13)
+#define SET_TX_DESC_BUFFER_LEN1_H(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x34, 0, 6, value)
+#define GET_TX_DESC_BUFFER_LEN1_H(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x34, 0, 6)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_chip.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_chip.h
new file mode 100644
index 000000000000..514b187e1296
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_chip.h
@@ -0,0 +1,2385 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_CHIP_H_
+#define _HALMAC_TX_DESC_CHIP_H_
+#if (HALMAC_8814A_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ_8814A(txdesc, value)                            \
+	SET_TX_DESC_DISQSELSEQ(txdesc, value)
+#define GET_TX_DESC_DISQSELSEQ_8814A(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
+#define SET_TX_DESC_GF_8814A(txdesc, value) SET_TX_DESC_GF(txdesc, value)
+#define GET_TX_DESC_GF_8814A(txdesc) GET_TX_DESC_GF(txdesc)
+#define SET_TX_DESC_NO_ACM_8814A(txdesc, value)                                \
+	SET_TX_DESC_NO_ACM(txdesc, value)
+#define GET_TX_DESC_NO_ACM_8814A(txdesc) GET_TX_DESC_NO_ACM(txdesc)
+#define SET_TX_DESC_AMSDU_PAD_EN_8814A(txdesc, value)                          \
+	SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
+#define GET_TX_DESC_AMSDU_PAD_EN_8814A(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
+#define SET_TX_DESC_LS_8814A(txdesc, value) SET_TX_DESC_LS(txdesc, value)
+#define GET_TX_DESC_LS_8814A(txdesc) GET_TX_DESC_LS(txdesc)
+#define SET_TX_DESC_HTC_8814A(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
+#define GET_TX_DESC_HTC_8814A(txdesc) GET_TX_DESC_HTC(txdesc)
+#define SET_TX_DESC_BMC_8814A(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
+#define GET_TX_DESC_BMC_8814A(txdesc) GET_TX_DESC_BMC(txdesc)
+#define SET_TX_DESC_OFFSET_8814A(txdesc, value)                                \
+	SET_TX_DESC_OFFSET(txdesc, value)
+#define GET_TX_DESC_OFFSET_8814A(txdesc) GET_TX_DESC_OFFSET(txdesc)
+#define SET_TX_DESC_TXPKTSIZE_8814A(txdesc, value)                             \
+	SET_TX_DESC_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_TXPKTSIZE_8814A(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
+
+/*WORD1*/
+
+#define SET_TX_DESC_MOREDATA_8814A(txdesc, value)                              \
+	SET_TX_DESC_MOREDATA(txdesc, value)
+#define GET_TX_DESC_MOREDATA_8814A(txdesc) GET_TX_DESC_MOREDATA(txdesc)
+#define SET_TX_DESC_PKT_OFFSET_8814A(txdesc, value)                            \
+	SET_TX_DESC_PKT_OFFSET(txdesc, value)
+#define GET_TX_DESC_PKT_OFFSET_8814A(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
+#define SET_TX_DESC_SEC_TYPE_8814A(txdesc, value)                              \
+	SET_TX_DESC_SEC_TYPE(txdesc, value)
+#define GET_TX_DESC_SEC_TYPE_8814A(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
+#define SET_TX_DESC_EN_DESC_ID_8814A(txdesc, value)                            \
+	SET_TX_DESC_EN_DESC_ID(txdesc, value)
+#define GET_TX_DESC_EN_DESC_ID_8814A(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
+#define SET_TX_DESC_RATE_ID_8814A(txdesc, value)                               \
+	SET_TX_DESC_RATE_ID(txdesc, value)
+#define GET_TX_DESC_RATE_ID_8814A(txdesc) GET_TX_DESC_RATE_ID(txdesc)
+#define SET_TX_DESC_PIFS_8814A(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
+#define GET_TX_DESC_PIFS_8814A(txdesc) GET_TX_DESC_PIFS(txdesc)
+#define SET_TX_DESC_LSIG_TXOP_EN_8814A(txdesc, value)                          \
+	SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
+#define GET_TX_DESC_LSIG_TXOP_EN_8814A(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
+#define SET_TX_DESC_RD_NAV_EXT_8814A(txdesc, value)                            \
+	SET_TX_DESC_RD_NAV_EXT(txdesc, value)
+#define GET_TX_DESC_RD_NAV_EXT_8814A(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
+#define SET_TX_DESC_QSEL_8814A(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
+#define GET_TX_DESC_QSEL_8814A(txdesc) GET_TX_DESC_QSEL(txdesc)
+#define SET_TX_DESC_MACID_8814A(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
+#define GET_TX_DESC_MACID_8814A(txdesc) GET_TX_DESC_MACID(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_HW_AES_IV_8814A(txdesc, value)                             \
+	SET_TX_DESC_HW_AES_IV(txdesc, value)
+#define GET_TX_DESC_HW_AES_IV_8814A(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
+#define SET_TX_DESC_G_ID_8814A(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
+#define GET_TX_DESC_G_ID_8814A(txdesc) GET_TX_DESC_G_ID(txdesc)
+#define SET_TX_DESC_BT_NULL_8814A(txdesc, value)                               \
+	SET_TX_DESC_BT_NULL(txdesc, value)
+#define GET_TX_DESC_BT_NULL_8814A(txdesc) GET_TX_DESC_BT_NULL(txdesc)
+#define SET_TX_DESC_AMPDU_DENSITY_8814A(txdesc, value)                         \
+	SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
+#define GET_TX_DESC_AMPDU_DENSITY_8814A(txdesc)                                \
+	GET_TX_DESC_AMPDU_DENSITY(txdesc)
+#define SET_TX_DESC_SPE_RPT_8814A(txdesc, value)                               \
+	SET_TX_DESC_SPE_RPT(txdesc, value)
+#define GET_TX_DESC_SPE_RPT_8814A(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
+#define SET_TX_DESC_RAW_8814A(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
+#define GET_TX_DESC_RAW_8814A(txdesc) GET_TX_DESC_RAW(txdesc)
+#define SET_TX_DESC_MOREFRAG_8814A(txdesc, value)                              \
+	SET_TX_DESC_MOREFRAG(txdesc, value)
+#define GET_TX_DESC_MOREFRAG_8814A(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
+#define SET_TX_DESC_BK_8814A(txdesc, value) SET_TX_DESC_BK(txdesc, value)
+#define GET_TX_DESC_BK_8814A(txdesc) GET_TX_DESC_BK(txdesc)
+#define SET_TX_DESC_NULL_1_8814A(txdesc, value)                                \
+	SET_TX_DESC_NULL_1(txdesc, value)
+#define GET_TX_DESC_NULL_1_8814A(txdesc) GET_TX_DESC_NULL_1(txdesc)
+#define SET_TX_DESC_NULL_0_8814A(txdesc, value)                                \
+	SET_TX_DESC_NULL_0(txdesc, value)
+#define GET_TX_DESC_NULL_0_8814A(txdesc) GET_TX_DESC_NULL_0(txdesc)
+#define SET_TX_DESC_RDG_EN_8814A(txdesc, value)                                \
+	SET_TX_DESC_RDG_EN(txdesc, value)
+#define GET_TX_DESC_RDG_EN_8814A(txdesc) GET_TX_DESC_RDG_EN(txdesc)
+#define SET_TX_DESC_AGG_EN_8814A(txdesc, value)                                \
+	SET_TX_DESC_AGG_EN(txdesc, value)
+#define GET_TX_DESC_AGG_EN_8814A(txdesc) GET_TX_DESC_AGG_EN(txdesc)
+#define SET_TX_DESC_CCA_RTS_8814A(txdesc, value)                               \
+	SET_TX_DESC_CCA_RTS(txdesc, value)
+#define GET_TX_DESC_CCA_RTS_8814A(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
+#define SET_TX_DESC_P_AID_8814A(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
+#define GET_TX_DESC_P_AID_8814A(txdesc) GET_TX_DESC_P_AID(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME_8814A(txdesc, value)                        \
+	SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
+#define GET_TX_DESC_AMPDU_MAX_TIME_8814A(txdesc)                               \
+	GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
+#define SET_TX_DESC_NDPA_8814A(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
+#define GET_TX_DESC_NDPA_8814A(txdesc) GET_TX_DESC_NDPA(txdesc)
+#define SET_TX_DESC_MAX_AGG_NUM_8814A(txdesc, value)                           \
+	SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
+#define GET_TX_DESC_MAX_AGG_NUM_8814A(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
+#define SET_TX_DESC_USE_MAX_TIME_EN_8814A(txdesc, value)                       \
+	SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
+#define GET_TX_DESC_USE_MAX_TIME_EN_8814A(txdesc)                              \
+	GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
+#define SET_TX_DESC_NAVUSEHDR_8814A(txdesc, value)                             \
+	SET_TX_DESC_NAVUSEHDR(txdesc, value)
+#define GET_TX_DESC_NAVUSEHDR_8814A(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
+#define SET_TX_DESC_CHK_EN_8814A(txdesc, value)                                \
+	SET_TX_DESC_CHK_EN(txdesc, value)
+#define GET_TX_DESC_CHK_EN_8814A(txdesc) GET_TX_DESC_CHK_EN(txdesc)
+#define SET_TX_DESC_HW_RTS_EN_8814A(txdesc, value)                             \
+	SET_TX_DESC_HW_RTS_EN(txdesc, value)
+#define GET_TX_DESC_HW_RTS_EN_8814A(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
+#define SET_TX_DESC_RTSEN_8814A(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
+#define GET_TX_DESC_RTSEN_8814A(txdesc) GET_TX_DESC_RTSEN(txdesc)
+#define SET_TX_DESC_CTS2SELF_8814A(txdesc, value)                              \
+	SET_TX_DESC_CTS2SELF(txdesc, value)
+#define GET_TX_DESC_CTS2SELF_8814A(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
+#define SET_TX_DESC_DISDATAFB_8814A(txdesc, value)                             \
+	SET_TX_DESC_DISDATAFB(txdesc, value)
+#define GET_TX_DESC_DISDATAFB_8814A(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
+#define SET_TX_DESC_DISRTSFB_8814A(txdesc, value)                              \
+	SET_TX_DESC_DISRTSFB(txdesc, value)
+#define GET_TX_DESC_DISRTSFB_8814A(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
+#define SET_TX_DESC_USE_RATE_8814A(txdesc, value)                              \
+	SET_TX_DESC_USE_RATE(txdesc, value)
+#define GET_TX_DESC_USE_RATE_8814A(txdesc) GET_TX_DESC_USE_RATE(txdesc)
+#define SET_TX_DESC_HW_SSN_SEL_8814A(txdesc, value)                            \
+	SET_TX_DESC_HW_SSN_SEL(txdesc, value)
+#define GET_TX_DESC_HW_SSN_SEL_8814A(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
+#define SET_TX_DESC_WHEADER_LEN_8814A(txdesc, value)                           \
+	SET_TX_DESC_WHEADER_LEN(txdesc, value)
+#define GET_TX_DESC_WHEADER_LEN_8814A(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX_8814A(txdesc, value)                         \
+	SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
+#define GET_TX_DESC_PCTS_MASK_IDX_8814A(txdesc)                                \
+	GET_TX_DESC_PCTS_MASK_IDX(txdesc)
+#define SET_TX_DESC_PCTS_EN_8814A(txdesc, value)                               \
+	SET_TX_DESC_PCTS_EN(txdesc, value)
+#define GET_TX_DESC_PCTS_EN_8814A(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
+#define SET_TX_DESC_RTSRATE_8814A(txdesc, value)                               \
+	SET_TX_DESC_RTSRATE(txdesc, value)
+#define GET_TX_DESC_RTSRATE_8814A(txdesc) GET_TX_DESC_RTSRATE(txdesc)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT_8814A(txdesc, value)                      \
+	SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT_8814A(txdesc)                             \
+	GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
+#define SET_TX_DESC_RTY_LMT_EN_8814A(txdesc, value)                            \
+	SET_TX_DESC_RTY_LMT_EN(txdesc, value)
+#define GET_TX_DESC_RTY_LMT_EN_8814A(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8814A(txdesc, value)                   \
+	SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8814A(txdesc)                          \
+	GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8814A(txdesc, value)                  \
+	SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8814A(txdesc)                         \
+	GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_TRY_RATE_8814A(txdesc, value)                              \
+	SET_TX_DESC_TRY_RATE(txdesc, value)
+#define GET_TX_DESC_TRY_RATE_8814A(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
+#define SET_TX_DESC_DATARATE_8814A(txdesc, value)                              \
+	SET_TX_DESC_DATARATE(txdesc, value)
+#define GET_TX_DESC_DATARATE_8814A(txdesc) GET_TX_DESC_DATARATE(txdesc)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED_8814A(txdesc, value)                              \
+	SET_TX_DESC_POLLUTED(txdesc, value)
+#define GET_TX_DESC_POLLUTED_8814A(txdesc) GET_TX_DESC_POLLUTED(txdesc)
+#define SET_TX_DESC_TXPWR_OFSET_8814A(txdesc, value)                           \
+	SET_TX_DESC_TXPWR_OFSET(txdesc, value)
+#define GET_TX_DESC_TXPWR_OFSET_8814A(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
+#define SET_TX_DESC_TX_ANT_8814A(txdesc, value)                                \
+	SET_TX_DESC_TX_ANT(txdesc, value)
+#define GET_TX_DESC_TX_ANT_8814A(txdesc) GET_TX_DESC_TX_ANT(txdesc)
+#define SET_TX_DESC_PORT_ID_8814A(txdesc, value)                               \
+	SET_TX_DESC_PORT_ID(txdesc, value)
+#define GET_TX_DESC_PORT_ID_8814A(txdesc) GET_TX_DESC_PORT_ID(txdesc)
+#define SET_TX_DESC_SIGNALING_TAPKT_EN_8814A(txdesc, value)                    \
+	SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN_8814A(txdesc)                           \
+	GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
+#define SET_TX_DESC_RTS_SC_8814A(txdesc, value)                                \
+	SET_TX_DESC_RTS_SC(txdesc, value)
+#define GET_TX_DESC_RTS_SC_8814A(txdesc) GET_TX_DESC_RTS_SC(txdesc)
+#define SET_TX_DESC_RTS_SHORT_8814A(txdesc, value)                             \
+	SET_TX_DESC_RTS_SHORT(txdesc, value)
+#define GET_TX_DESC_RTS_SHORT_8814A(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
+#define SET_TX_DESC_VCS_STBC_8814A(txdesc, value)                              \
+	SET_TX_DESC_VCS_STBC(txdesc, value)
+#define GET_TX_DESC_VCS_STBC_8814A(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
+#define SET_TX_DESC_DATA_STBC_8814A(txdesc, value)                             \
+	SET_TX_DESC_DATA_STBC(txdesc, value)
+#define GET_TX_DESC_DATA_STBC_8814A(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
+#define SET_TX_DESC_DATA_LDPC_8814A(txdesc, value)                             \
+	SET_TX_DESC_DATA_LDPC(txdesc, value)
+#define GET_TX_DESC_DATA_LDPC_8814A(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
+#define SET_TX_DESC_DATA_BW_8814A(txdesc, value)                               \
+	SET_TX_DESC_DATA_BW(txdesc, value)
+#define GET_TX_DESC_DATA_BW_8814A(txdesc) GET_TX_DESC_DATA_BW(txdesc)
+#define SET_TX_DESC_DATA_SHORT_8814A(txdesc, value)                            \
+	SET_TX_DESC_DATA_SHORT(txdesc, value)
+#define GET_TX_DESC_DATA_SHORT_8814A(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
+#define SET_TX_DESC_DATA_SC_8814A(txdesc, value)                               \
+	SET_TX_DESC_DATA_SC(txdesc, value)
+#define GET_TX_DESC_DATA_SC_8814A(txdesc) GET_TX_DESC_DATA_SC(txdesc)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANTSEL_D_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_D(txdesc, value)
+#define GET_TX_DESC_ANTSEL_D_8814A(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
+#define SET_TX_DESC_ANT_MAPD_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPD(txdesc, value)
+#define GET_TX_DESC_ANT_MAPD_8814A(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
+#define SET_TX_DESC_ANT_MAPC_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPC(txdesc, value)
+#define GET_TX_DESC_ANT_MAPC_8814A(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
+#define SET_TX_DESC_ANT_MAPB_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPB(txdesc, value)
+#define GET_TX_DESC_ANT_MAPB_8814A(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
+#define SET_TX_DESC_ANT_MAPA_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPA(txdesc, value)
+#define GET_TX_DESC_ANT_MAPA_8814A(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
+#define SET_TX_DESC_ANTSEL_C_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_C(txdesc, value)
+#define GET_TX_DESC_ANTSEL_C_8814A(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
+#define SET_TX_DESC_ANTSEL_B_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_B(txdesc, value)
+#define GET_TX_DESC_ANTSEL_B_8814A(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
+#define SET_TX_DESC_ANTSEL_A_8814A(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_A(txdesc, value)
+#define GET_TX_DESC_ANTSEL_A_8814A(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
+#define SET_TX_DESC_MBSSID_8814A(txdesc, value)                                \
+	SET_TX_DESC_MBSSID(txdesc, value)
+#define GET_TX_DESC_MBSSID_8814A(txdesc) GET_TX_DESC_MBSSID(txdesc)
+#define SET_TX_DESC_SW_DEFINE_8814A(txdesc, value)                             \
+	SET_TX_DESC_SW_DEFINE(txdesc, value)
+#define GET_TX_DESC_SW_DEFINE_8814A(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_8814A(txdesc, value)                         \
+	SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_8814A(txdesc)                                \
+	GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
+#define SET_TX_DESC_FINAL_DATA_RATE_8814A(txdesc, value)                       \
+	SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
+#define GET_TX_DESC_FINAL_DATA_RATE_8814A(txdesc)                              \
+	GET_TX_DESC_FINAL_DATA_RATE(txdesc)
+#define SET_TX_DESC_NTX_MAP_8814A(txdesc, value)                               \
+	SET_TX_DESC_NTX_MAP(txdesc, value)
+#define GET_TX_DESC_NTX_MAP_8814A(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
+#define SET_TX_DESC_TX_BUFF_SIZE_8814A(txdesc, value)                          \
+	SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
+#define GET_TX_DESC_TX_BUFF_SIZE_8814A(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
+#define SET_TX_DESC_TXDESC_CHECKSUM_8814A(txdesc, value)                       \
+	SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_8814A(txdesc)                              \
+	GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
+#define SET_TX_DESC_TIMESTAMP_8814A(txdesc, value)                             \
+	SET_TX_DESC_TIMESTAMP(txdesc, value)
+#define GET_TX_DESC_TIMESTAMP_8814A(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP_8814A(txdesc, value)                             \
+	SET_TX_DESC_TXWIFI_CP(txdesc, value)
+#define GET_TX_DESC_TXWIFI_CP_8814A(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
+#define SET_TX_DESC_MAC_CP_8814A(txdesc, value)                                \
+	SET_TX_DESC_MAC_CP(txdesc, value)
+#define GET_TX_DESC_MAC_CP_8814A(txdesc) GET_TX_DESC_MAC_CP(txdesc)
+#define SET_TX_DESC_STW_PKTRE_DIS_8814A(txdesc, value)                         \
+	SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_PKTRE_DIS_8814A(txdesc)                                \
+	GET_TX_DESC_STW_PKTRE_DIS(txdesc)
+#define SET_TX_DESC_STW_RB_DIS_8814A(txdesc, value)                            \
+	SET_TX_DESC_STW_RB_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RB_DIS_8814A(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
+#define SET_TX_DESC_STW_RATE_DIS_8814A(txdesc, value)                          \
+	SET_TX_DESC_STW_RATE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RATE_DIS_8814A(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
+#define SET_TX_DESC_STW_ANT_DIS_8814A(txdesc, value)                           \
+	SET_TX_DESC_STW_ANT_DIS(txdesc, value)
+#define GET_TX_DESC_STW_ANT_DIS_8814A(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
+#define SET_TX_DESC_STW_EN_8814A(txdesc, value)                                \
+	SET_TX_DESC_STW_EN(txdesc, value)
+#define GET_TX_DESC_STW_EN_8814A(txdesc) GET_TX_DESC_STW_EN(txdesc)
+#define SET_TX_DESC_SMH_EN_8814A(txdesc, value)                                \
+	SET_TX_DESC_SMH_EN(txdesc, value)
+#define GET_TX_DESC_SMH_EN_8814A(txdesc) GET_TX_DESC_SMH_EN(txdesc)
+#define SET_TX_DESC_TAILPAGE_L_8814A(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_L(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_L_8814A(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
+#define SET_TX_DESC_SDIO_DMASEQ_8814A(txdesc, value)                           \
+	SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
+#define GET_TX_DESC_SDIO_DMASEQ_8814A(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_L_8814A(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_L_8814A(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
+#define SET_TX_DESC_EN_HWSEQ_8814A(txdesc, value)                              \
+	SET_TX_DESC_EN_HWSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWSEQ_8814A(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
+#define SET_TX_DESC_EN_HWEXSEQ_8814A(txdesc, value)                            \
+	SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWEXSEQ_8814A(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
+#define SET_TX_DESC_DATA_RC_8814A(txdesc, value)                               \
+	SET_TX_DESC_DATA_RC(txdesc, value)
+#define GET_TX_DESC_DATA_RC_8814A(txdesc) GET_TX_DESC_DATA_RC(txdesc)
+#define SET_TX_DESC_BAR_RTY_TH_8814A(txdesc, value)                            \
+	SET_TX_DESC_BAR_RTY_TH(txdesc, value)
+#define GET_TX_DESC_BAR_RTY_TH_8814A(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
+#define SET_TX_DESC_RTS_RC_8814A(txdesc, value)                                \
+	SET_TX_DESC_RTS_RC(txdesc, value)
+#define GET_TX_DESC_RTS_RC_8814A(txdesc) GET_TX_DESC_RTS_RC(txdesc)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H_8814A(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_H(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_H_8814A(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_H_8814A(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_H_8814A(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
+#define SET_TX_DESC_SW_SEQ_8814A(txdesc, value)                                \
+	SET_TX_DESC_SW_SEQ(txdesc, value)
+#define GET_TX_DESC_SW_SEQ_8814A(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
+#define SET_TX_DESC_TXBF_PATH_8814A(txdesc, value)                             \
+	SET_TX_DESC_TXBF_PATH(txdesc, value)
+#define GET_TX_DESC_TXBF_PATH_8814A(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
+#define SET_TX_DESC_PADDING_LEN_8814A(txdesc, value)                           \
+	SET_TX_DESC_PADDING_LEN(txdesc, value)
+#define GET_TX_DESC_PADDING_LEN_8814A(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8814A(txdesc, value)                   \
+	SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8814A(txdesc)                          \
+	GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
+
+/*WORD10*/
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ_8822B(txdesc, value)                            \
+	SET_TX_DESC_DISQSELSEQ(txdesc, value)
+#define GET_TX_DESC_DISQSELSEQ_8822B(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
+#define SET_TX_DESC_GF_8822B(txdesc, value) SET_TX_DESC_GF(txdesc, value)
+#define GET_TX_DESC_GF_8822B(txdesc) GET_TX_DESC_GF(txdesc)
+#define SET_TX_DESC_NO_ACM_8822B(txdesc, value)                                \
+	SET_TX_DESC_NO_ACM(txdesc, value)
+#define GET_TX_DESC_NO_ACM_8822B(txdesc) GET_TX_DESC_NO_ACM(txdesc)
+#define SET_TX_DESC_BCNPKT_TSF_CTRL_8822B(txdesc, value)                       \
+	SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
+#define GET_TX_DESC_BCNPKT_TSF_CTRL_8822B(txdesc)                              \
+	GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
+#define SET_TX_DESC_AMSDU_PAD_EN_8822B(txdesc, value)                          \
+	SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
+#define GET_TX_DESC_AMSDU_PAD_EN_8822B(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
+#define SET_TX_DESC_LS_8822B(txdesc, value) SET_TX_DESC_LS(txdesc, value)
+#define GET_TX_DESC_LS_8822B(txdesc) GET_TX_DESC_LS(txdesc)
+#define SET_TX_DESC_HTC_8822B(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
+#define GET_TX_DESC_HTC_8822B(txdesc) GET_TX_DESC_HTC(txdesc)
+#define SET_TX_DESC_BMC_8822B(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
+#define GET_TX_DESC_BMC_8822B(txdesc) GET_TX_DESC_BMC(txdesc)
+#define SET_TX_DESC_OFFSET_8822B(txdesc, value)                                \
+	SET_TX_DESC_OFFSET(txdesc, value)
+#define GET_TX_DESC_OFFSET_8822B(txdesc) GET_TX_DESC_OFFSET(txdesc)
+#define SET_TX_DESC_TXPKTSIZE_8822B(txdesc, value)                             \
+	SET_TX_DESC_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_TXPKTSIZE_8822B(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
+
+/*WORD1*/
+
+#define SET_TX_DESC_MOREDATA_8822B(txdesc, value)                              \
+	SET_TX_DESC_MOREDATA(txdesc, value)
+#define GET_TX_DESC_MOREDATA_8822B(txdesc) GET_TX_DESC_MOREDATA(txdesc)
+#define SET_TX_DESC_PKT_OFFSET_8822B(txdesc, value)                            \
+	SET_TX_DESC_PKT_OFFSET(txdesc, value)
+#define GET_TX_DESC_PKT_OFFSET_8822B(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
+#define SET_TX_DESC_SEC_TYPE_8822B(txdesc, value)                              \
+	SET_TX_DESC_SEC_TYPE(txdesc, value)
+#define GET_TX_DESC_SEC_TYPE_8822B(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
+#define SET_TX_DESC_EN_DESC_ID_8822B(txdesc, value)                            \
+	SET_TX_DESC_EN_DESC_ID(txdesc, value)
+#define GET_TX_DESC_EN_DESC_ID_8822B(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
+#define SET_TX_DESC_RATE_ID_8822B(txdesc, value)                               \
+	SET_TX_DESC_RATE_ID(txdesc, value)
+#define GET_TX_DESC_RATE_ID_8822B(txdesc) GET_TX_DESC_RATE_ID(txdesc)
+#define SET_TX_DESC_PIFS_8822B(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
+#define GET_TX_DESC_PIFS_8822B(txdesc) GET_TX_DESC_PIFS(txdesc)
+#define SET_TX_DESC_LSIG_TXOP_EN_8822B(txdesc, value)                          \
+	SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
+#define GET_TX_DESC_LSIG_TXOP_EN_8822B(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
+#define SET_TX_DESC_RD_NAV_EXT_8822B(txdesc, value)                            \
+	SET_TX_DESC_RD_NAV_EXT(txdesc, value)
+#define GET_TX_DESC_RD_NAV_EXT_8822B(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
+#define SET_TX_DESC_QSEL_8822B(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
+#define GET_TX_DESC_QSEL_8822B(txdesc) GET_TX_DESC_QSEL(txdesc)
+#define SET_TX_DESC_MACID_8822B(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
+#define GET_TX_DESC_MACID_8822B(txdesc) GET_TX_DESC_MACID(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_HW_AES_IV_8822B(txdesc, value)                             \
+	SET_TX_DESC_HW_AES_IV(txdesc, value)
+#define GET_TX_DESC_HW_AES_IV_8822B(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
+#define SET_TX_DESC_FTM_EN_8822B(txdesc, value)                                \
+	SET_TX_DESC_FTM_EN(txdesc, value)
+#define GET_TX_DESC_FTM_EN_8822B(txdesc) GET_TX_DESC_FTM_EN(txdesc)
+#define SET_TX_DESC_G_ID_8822B(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
+#define GET_TX_DESC_G_ID_8822B(txdesc) GET_TX_DESC_G_ID(txdesc)
+#define SET_TX_DESC_BT_NULL_8822B(txdesc, value)                               \
+	SET_TX_DESC_BT_NULL(txdesc, value)
+#define GET_TX_DESC_BT_NULL_8822B(txdesc) GET_TX_DESC_BT_NULL(txdesc)
+#define SET_TX_DESC_AMPDU_DENSITY_8822B(txdesc, value)                         \
+	SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
+#define GET_TX_DESC_AMPDU_DENSITY_8822B(txdesc)                                \
+	GET_TX_DESC_AMPDU_DENSITY(txdesc)
+#define SET_TX_DESC_SPE_RPT_8822B(txdesc, value)                               \
+	SET_TX_DESC_SPE_RPT(txdesc, value)
+#define GET_TX_DESC_SPE_RPT_8822B(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
+#define SET_TX_DESC_RAW_8822B(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
+#define GET_TX_DESC_RAW_8822B(txdesc) GET_TX_DESC_RAW(txdesc)
+#define SET_TX_DESC_MOREFRAG_8822B(txdesc, value)                              \
+	SET_TX_DESC_MOREFRAG(txdesc, value)
+#define GET_TX_DESC_MOREFRAG_8822B(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
+#define SET_TX_DESC_BK_8822B(txdesc, value) SET_TX_DESC_BK(txdesc, value)
+#define GET_TX_DESC_BK_8822B(txdesc) GET_TX_DESC_BK(txdesc)
+#define SET_TX_DESC_NULL_1_8822B(txdesc, value)                                \
+	SET_TX_DESC_NULL_1(txdesc, value)
+#define GET_TX_DESC_NULL_1_8822B(txdesc) GET_TX_DESC_NULL_1(txdesc)
+#define SET_TX_DESC_NULL_0_8822B(txdesc, value)                                \
+	SET_TX_DESC_NULL_0(txdesc, value)
+#define GET_TX_DESC_NULL_0_8822B(txdesc) GET_TX_DESC_NULL_0(txdesc)
+#define SET_TX_DESC_RDG_EN_8822B(txdesc, value)                                \
+	SET_TX_DESC_RDG_EN(txdesc, value)
+#define GET_TX_DESC_RDG_EN_8822B(txdesc) GET_TX_DESC_RDG_EN(txdesc)
+#define SET_TX_DESC_AGG_EN_8822B(txdesc, value)                                \
+	SET_TX_DESC_AGG_EN(txdesc, value)
+#define GET_TX_DESC_AGG_EN_8822B(txdesc) GET_TX_DESC_AGG_EN(txdesc)
+#define SET_TX_DESC_CCA_RTS_8822B(txdesc, value)                               \
+	SET_TX_DESC_CCA_RTS(txdesc, value)
+#define GET_TX_DESC_CCA_RTS_8822B(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
+#define SET_TX_DESC_TRI_FRAME_8822B(txdesc, value)                             \
+	SET_TX_DESC_TRI_FRAME(txdesc, value)
+#define GET_TX_DESC_TRI_FRAME_8822B(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
+#define SET_TX_DESC_P_AID_8822B(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
+#define GET_TX_DESC_P_AID_8822B(txdesc) GET_TX_DESC_P_AID(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME_8822B(txdesc, value)                        \
+	SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
+#define GET_TX_DESC_AMPDU_MAX_TIME_8822B(txdesc)                               \
+	GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
+#define SET_TX_DESC_NDPA_8822B(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
+#define GET_TX_DESC_NDPA_8822B(txdesc) GET_TX_DESC_NDPA(txdesc)
+#define SET_TX_DESC_MAX_AGG_NUM_8822B(txdesc, value)                           \
+	SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
+#define GET_TX_DESC_MAX_AGG_NUM_8822B(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
+#define SET_TX_DESC_USE_MAX_TIME_EN_8822B(txdesc, value)                       \
+	SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
+#define GET_TX_DESC_USE_MAX_TIME_EN_8822B(txdesc)                              \
+	GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
+#define SET_TX_DESC_NAVUSEHDR_8822B(txdesc, value)                             \
+	SET_TX_DESC_NAVUSEHDR(txdesc, value)
+#define GET_TX_DESC_NAVUSEHDR_8822B(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
+#define SET_TX_DESC_CHK_EN_8822B(txdesc, value)                                \
+	SET_TX_DESC_CHK_EN(txdesc, value)
+#define GET_TX_DESC_CHK_EN_8822B(txdesc) GET_TX_DESC_CHK_EN(txdesc)
+#define SET_TX_DESC_HW_RTS_EN_8822B(txdesc, value)                             \
+	SET_TX_DESC_HW_RTS_EN(txdesc, value)
+#define GET_TX_DESC_HW_RTS_EN_8822B(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
+#define SET_TX_DESC_RTSEN_8822B(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
+#define GET_TX_DESC_RTSEN_8822B(txdesc) GET_TX_DESC_RTSEN(txdesc)
+#define SET_TX_DESC_CTS2SELF_8822B(txdesc, value)                              \
+	SET_TX_DESC_CTS2SELF(txdesc, value)
+#define GET_TX_DESC_CTS2SELF_8822B(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
+#define SET_TX_DESC_DISDATAFB_8822B(txdesc, value)                             \
+	SET_TX_DESC_DISDATAFB(txdesc, value)
+#define GET_TX_DESC_DISDATAFB_8822B(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
+#define SET_TX_DESC_DISRTSFB_8822B(txdesc, value)                              \
+	SET_TX_DESC_DISRTSFB(txdesc, value)
+#define GET_TX_DESC_DISRTSFB_8822B(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
+#define SET_TX_DESC_USE_RATE_8822B(txdesc, value)                              \
+	SET_TX_DESC_USE_RATE(txdesc, value)
+#define GET_TX_DESC_USE_RATE_8822B(txdesc) GET_TX_DESC_USE_RATE(txdesc)
+#define SET_TX_DESC_HW_SSN_SEL_8822B(txdesc, value)                            \
+	SET_TX_DESC_HW_SSN_SEL(txdesc, value)
+#define GET_TX_DESC_HW_SSN_SEL_8822B(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
+#define SET_TX_DESC_WHEADER_LEN_8822B(txdesc, value)                           \
+	SET_TX_DESC_WHEADER_LEN(txdesc, value)
+#define GET_TX_DESC_WHEADER_LEN_8822B(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX_8822B(txdesc, value)                         \
+	SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
+#define GET_TX_DESC_PCTS_MASK_IDX_8822B(txdesc)                                \
+	GET_TX_DESC_PCTS_MASK_IDX(txdesc)
+#define SET_TX_DESC_PCTS_EN_8822B(txdesc, value)                               \
+	SET_TX_DESC_PCTS_EN(txdesc, value)
+#define GET_TX_DESC_PCTS_EN_8822B(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
+#define SET_TX_DESC_RTSRATE_8822B(txdesc, value)                               \
+	SET_TX_DESC_RTSRATE(txdesc, value)
+#define GET_TX_DESC_RTSRATE_8822B(txdesc) GET_TX_DESC_RTSRATE(txdesc)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT_8822B(txdesc, value)                      \
+	SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT_8822B(txdesc)                             \
+	GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
+#define SET_TX_DESC_RTY_LMT_EN_8822B(txdesc, value)                            \
+	SET_TX_DESC_RTY_LMT_EN(txdesc, value)
+#define GET_TX_DESC_RTY_LMT_EN_8822B(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8822B(txdesc, value)                   \
+	SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8822B(txdesc)                          \
+	GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(txdesc, value)                  \
+	SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(txdesc)                         \
+	GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_TRY_RATE_8822B(txdesc, value)                              \
+	SET_TX_DESC_TRY_RATE(txdesc, value)
+#define GET_TX_DESC_TRY_RATE_8822B(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
+#define SET_TX_DESC_DATARATE_8822B(txdesc, value)                              \
+	SET_TX_DESC_DATARATE(txdesc, value)
+#define GET_TX_DESC_DATARATE_8822B(txdesc) GET_TX_DESC_DATARATE(txdesc)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED_8822B(txdesc, value)                              \
+	SET_TX_DESC_POLLUTED(txdesc, value)
+#define GET_TX_DESC_POLLUTED_8822B(txdesc) GET_TX_DESC_POLLUTED(txdesc)
+#define SET_TX_DESC_TXPWR_OFSET_8822B(txdesc, value)                           \
+	SET_TX_DESC_TXPWR_OFSET(txdesc, value)
+#define GET_TX_DESC_TXPWR_OFSET_8822B(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
+#define SET_TX_DESC_TX_ANT_8822B(txdesc, value)                                \
+	SET_TX_DESC_TX_ANT(txdesc, value)
+#define GET_TX_DESC_TX_ANT_8822B(txdesc) GET_TX_DESC_TX_ANT(txdesc)
+#define SET_TX_DESC_PORT_ID_8822B(txdesc, value)                               \
+	SET_TX_DESC_PORT_ID(txdesc, value)
+#define GET_TX_DESC_PORT_ID_8822B(txdesc) GET_TX_DESC_PORT_ID(txdesc)
+#define SET_TX_DESC_MULTIPLE_PORT_8822B(txdesc, value)                         \
+	SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
+#define GET_TX_DESC_MULTIPLE_PORT_8822B(txdesc)                                \
+	GET_TX_DESC_MULTIPLE_PORT(txdesc)
+#define SET_TX_DESC_SIGNALING_TAPKT_EN_8822B(txdesc, value)                    \
+	SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN_8822B(txdesc)                           \
+	GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
+#define SET_TX_DESC_SIGNALING_TA_PKT_SC_8822B(txdesc, value)                   \
+	SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TA_PKT_SC_8822B(txdesc)                          \
+	GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)
+#define SET_TX_DESC_RTS_SHORT_8822B(txdesc, value)                             \
+	SET_TX_DESC_RTS_SHORT(txdesc, value)
+#define GET_TX_DESC_RTS_SHORT_8822B(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
+#define SET_TX_DESC_VCS_STBC_8822B(txdesc, value)                              \
+	SET_TX_DESC_VCS_STBC(txdesc, value)
+#define GET_TX_DESC_VCS_STBC_8822B(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
+#define SET_TX_DESC_DATA_STBC_8822B(txdesc, value)                             \
+	SET_TX_DESC_DATA_STBC(txdesc, value)
+#define GET_TX_DESC_DATA_STBC_8822B(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
+#define SET_TX_DESC_DATA_LDPC_8822B(txdesc, value)                             \
+	SET_TX_DESC_DATA_LDPC(txdesc, value)
+#define GET_TX_DESC_DATA_LDPC_8822B(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
+#define SET_TX_DESC_DATA_BW_8822B(txdesc, value)                               \
+	SET_TX_DESC_DATA_BW(txdesc, value)
+#define GET_TX_DESC_DATA_BW_8822B(txdesc) GET_TX_DESC_DATA_BW(txdesc)
+#define SET_TX_DESC_DATA_SHORT_8822B(txdesc, value)                            \
+	SET_TX_DESC_DATA_SHORT(txdesc, value)
+#define GET_TX_DESC_DATA_SHORT_8822B(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
+#define SET_TX_DESC_DATA_SC_8822B(txdesc, value)                               \
+	SET_TX_DESC_DATA_SC(txdesc, value)
+#define GET_TX_DESC_DATA_SC_8822B(txdesc) GET_TX_DESC_DATA_SC(txdesc)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANTSEL_D_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_D(txdesc, value)
+#define GET_TX_DESC_ANTSEL_D_8822B(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
+#define SET_TX_DESC_ANT_MAPD_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPD(txdesc, value)
+#define GET_TX_DESC_ANT_MAPD_8822B(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
+#define SET_TX_DESC_ANT_MAPC_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPC(txdesc, value)
+#define GET_TX_DESC_ANT_MAPC_8822B(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
+#define SET_TX_DESC_ANT_MAPB_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPB(txdesc, value)
+#define GET_TX_DESC_ANT_MAPB_8822B(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
+#define SET_TX_DESC_ANT_MAPA_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPA(txdesc, value)
+#define GET_TX_DESC_ANT_MAPA_8822B(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
+#define SET_TX_DESC_ANTSEL_C_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_C(txdesc, value)
+#define GET_TX_DESC_ANTSEL_C_8822B(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
+#define SET_TX_DESC_ANTSEL_B_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_B(txdesc, value)
+#define GET_TX_DESC_ANTSEL_B_8822B(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
+#define SET_TX_DESC_ANTSEL_A_8822B(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_A(txdesc, value)
+#define GET_TX_DESC_ANTSEL_A_8822B(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
+#define SET_TX_DESC_MBSSID_8822B(txdesc, value)                                \
+	SET_TX_DESC_MBSSID(txdesc, value)
+#define GET_TX_DESC_MBSSID_8822B(txdesc) GET_TX_DESC_MBSSID(txdesc)
+#define SET_TX_DESC_SW_DEFINE_8822B(txdesc, value)                             \
+	SET_TX_DESC_SW_DEFINE(txdesc, value)
+#define GET_TX_DESC_SW_DEFINE_8822B(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_8822B(txdesc, value)                         \
+	SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_8822B(txdesc)                                \
+	GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
+#define SET_TX_DESC_FINAL_DATA_RATE_8822B(txdesc, value)                       \
+	SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
+#define GET_TX_DESC_FINAL_DATA_RATE_8822B(txdesc)                              \
+	GET_TX_DESC_FINAL_DATA_RATE(txdesc)
+#define SET_TX_DESC_NTX_MAP_8822B(txdesc, value)                               \
+	SET_TX_DESC_NTX_MAP(txdesc, value)
+#define GET_TX_DESC_NTX_MAP_8822B(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
+#define SET_TX_DESC_TX_BUFF_SIZE_8822B(txdesc, value)                          \
+	SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
+#define GET_TX_DESC_TX_BUFF_SIZE_8822B(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
+#define SET_TX_DESC_TXDESC_CHECKSUM_8822B(txdesc, value)                       \
+	SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_8822B(txdesc)                              \
+	GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
+#define SET_TX_DESC_TIMESTAMP_8822B(txdesc, value)                             \
+	SET_TX_DESC_TIMESTAMP(txdesc, value)
+#define GET_TX_DESC_TIMESTAMP_8822B(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP_8822B(txdesc, value)                             \
+	SET_TX_DESC_TXWIFI_CP(txdesc, value)
+#define GET_TX_DESC_TXWIFI_CP_8822B(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
+#define SET_TX_DESC_MAC_CP_8822B(txdesc, value)                                \
+	SET_TX_DESC_MAC_CP(txdesc, value)
+#define GET_TX_DESC_MAC_CP_8822B(txdesc) GET_TX_DESC_MAC_CP(txdesc)
+#define SET_TX_DESC_STW_PKTRE_DIS_8822B(txdesc, value)                         \
+	SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_PKTRE_DIS_8822B(txdesc)                                \
+	GET_TX_DESC_STW_PKTRE_DIS(txdesc)
+#define SET_TX_DESC_STW_RB_DIS_8822B(txdesc, value)                            \
+	SET_TX_DESC_STW_RB_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RB_DIS_8822B(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
+#define SET_TX_DESC_STW_RATE_DIS_8822B(txdesc, value)                          \
+	SET_TX_DESC_STW_RATE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RATE_DIS_8822B(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
+#define SET_TX_DESC_STW_ANT_DIS_8822B(txdesc, value)                           \
+	SET_TX_DESC_STW_ANT_DIS(txdesc, value)
+#define GET_TX_DESC_STW_ANT_DIS_8822B(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
+#define SET_TX_DESC_STW_EN_8822B(txdesc, value)                                \
+	SET_TX_DESC_STW_EN(txdesc, value)
+#define GET_TX_DESC_STW_EN_8822B(txdesc) GET_TX_DESC_STW_EN(txdesc)
+#define SET_TX_DESC_SMH_EN_8822B(txdesc, value)                                \
+	SET_TX_DESC_SMH_EN(txdesc, value)
+#define GET_TX_DESC_SMH_EN_8822B(txdesc) GET_TX_DESC_SMH_EN(txdesc)
+#define SET_TX_DESC_TAILPAGE_L_8822B(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_L(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_L_8822B(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
+#define SET_TX_DESC_SDIO_DMASEQ_8822B(txdesc, value)                           \
+	SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
+#define GET_TX_DESC_SDIO_DMASEQ_8822B(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_L_8822B(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_L_8822B(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
+#define SET_TX_DESC_EN_HWSEQ_8822B(txdesc, value)                              \
+	SET_TX_DESC_EN_HWSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWSEQ_8822B(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
+#define SET_TX_DESC_EN_HWEXSEQ_8822B(txdesc, value)                            \
+	SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWEXSEQ_8822B(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
+#define SET_TX_DESC_DATA_RC_8822B(txdesc, value)                               \
+	SET_TX_DESC_DATA_RC(txdesc, value)
+#define GET_TX_DESC_DATA_RC_8822B(txdesc) GET_TX_DESC_DATA_RC(txdesc)
+#define SET_TX_DESC_BAR_RTY_TH_8822B(txdesc, value)                            \
+	SET_TX_DESC_BAR_RTY_TH(txdesc, value)
+#define GET_TX_DESC_BAR_RTY_TH_8822B(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
+#define SET_TX_DESC_RTS_RC_8822B(txdesc, value)                                \
+	SET_TX_DESC_RTS_RC(txdesc, value)
+#define GET_TX_DESC_RTS_RC_8822B(txdesc) GET_TX_DESC_RTS_RC(txdesc)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H_8822B(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_H(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_H_8822B(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_H_8822B(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_H_8822B(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
+#define SET_TX_DESC_SW_SEQ_8822B(txdesc, value)                                \
+	SET_TX_DESC_SW_SEQ(txdesc, value)
+#define GET_TX_DESC_SW_SEQ_8822B(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
+#define SET_TX_DESC_TXBF_PATH_8822B(txdesc, value)                             \
+	SET_TX_DESC_TXBF_PATH(txdesc, value)
+#define GET_TX_DESC_TXBF_PATH_8822B(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
+#define SET_TX_DESC_PADDING_LEN_8822B(txdesc, value)                           \
+	SET_TX_DESC_PADDING_LEN(txdesc, value)
+#define GET_TX_DESC_PADDING_LEN_8822B(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8822B(txdesc, value)                   \
+	SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8822B(txdesc)                          \
+	GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
+
+/*WORD10*/
+
+#define SET_TX_DESC_MU_DATARATE_8822B(txdesc, value)                           \
+	SET_TX_DESC_MU_DATARATE(txdesc, value)
+#define GET_TX_DESC_MU_DATARATE_8822B(txdesc) GET_TX_DESC_MU_DATARATE(txdesc)
+#define SET_TX_DESC_MU_RC_8822B(txdesc, value) SET_TX_DESC_MU_RC(txdesc, value)
+#define GET_TX_DESC_MU_RC_8822B(txdesc) GET_TX_DESC_MU_RC(txdesc)
+#define SET_TX_DESC_SND_PKT_SEL_8822B(txdesc, value)                           \
+	SET_TX_DESC_SND_PKT_SEL(txdesc, value)
+#define GET_TX_DESC_SND_PKT_SEL_8822B(txdesc) GET_TX_DESC_SND_PKT_SEL(txdesc)
+
+#endif
+
+#if (HALMAC_8197F_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ_8197F(txdesc, value)                            \
+	SET_TX_DESC_DISQSELSEQ(txdesc, value)
+#define GET_TX_DESC_DISQSELSEQ_8197F(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
+#define SET_TX_DESC_GF_8197F(txdesc, value) SET_TX_DESC_GF(txdesc, value)
+#define GET_TX_DESC_GF_8197F(txdesc) GET_TX_DESC_GF(txdesc)
+#define SET_TX_DESC_NO_ACM_8197F(txdesc, value)                                \
+	SET_TX_DESC_NO_ACM(txdesc, value)
+#define GET_TX_DESC_NO_ACM_8197F(txdesc) GET_TX_DESC_NO_ACM(txdesc)
+#define SET_TX_DESC_BCNPKT_TSF_CTRL_8197F(txdesc, value)                       \
+	SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
+#define GET_TX_DESC_BCNPKT_TSF_CTRL_8197F(txdesc)                              \
+	GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
+#define SET_TX_DESC_AMSDU_PAD_EN_8197F(txdesc, value)                          \
+	SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
+#define GET_TX_DESC_AMSDU_PAD_EN_8197F(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
+#define SET_TX_DESC_LS_8197F(txdesc, value) SET_TX_DESC_LS(txdesc, value)
+#define GET_TX_DESC_LS_8197F(txdesc) GET_TX_DESC_LS(txdesc)
+#define SET_TX_DESC_HTC_8197F(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
+#define GET_TX_DESC_HTC_8197F(txdesc) GET_TX_DESC_HTC(txdesc)
+#define SET_TX_DESC_BMC_8197F(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
+#define GET_TX_DESC_BMC_8197F(txdesc) GET_TX_DESC_BMC(txdesc)
+#define SET_TX_DESC_OFFSET_8197F(txdesc, value)                                \
+	SET_TX_DESC_OFFSET(txdesc, value)
+#define GET_TX_DESC_OFFSET_8197F(txdesc) GET_TX_DESC_OFFSET(txdesc)
+#define SET_TX_DESC_TXPKTSIZE_8197F(txdesc, value)                             \
+	SET_TX_DESC_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_TXPKTSIZE_8197F(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
+
+/*WORD1*/
+
+#define SET_TX_DESC_MOREDATA_8197F(txdesc, value)                              \
+	SET_TX_DESC_MOREDATA(txdesc, value)
+#define GET_TX_DESC_MOREDATA_8197F(txdesc) GET_TX_DESC_MOREDATA(txdesc)
+#define SET_TX_DESC_PKT_OFFSET_8197F(txdesc, value)                            \
+	SET_TX_DESC_PKT_OFFSET(txdesc, value)
+#define GET_TX_DESC_PKT_OFFSET_8197F(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
+#define SET_TX_DESC_SEC_TYPE_8197F(txdesc, value)                              \
+	SET_TX_DESC_SEC_TYPE(txdesc, value)
+#define GET_TX_DESC_SEC_TYPE_8197F(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
+#define SET_TX_DESC_EN_DESC_ID_8197F(txdesc, value)                            \
+	SET_TX_DESC_EN_DESC_ID(txdesc, value)
+#define GET_TX_DESC_EN_DESC_ID_8197F(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
+#define SET_TX_DESC_RATE_ID_8197F(txdesc, value)                               \
+	SET_TX_DESC_RATE_ID(txdesc, value)
+#define GET_TX_DESC_RATE_ID_8197F(txdesc) GET_TX_DESC_RATE_ID(txdesc)
+#define SET_TX_DESC_PIFS_8197F(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
+#define GET_TX_DESC_PIFS_8197F(txdesc) GET_TX_DESC_PIFS(txdesc)
+#define SET_TX_DESC_LSIG_TXOP_EN_8197F(txdesc, value)                          \
+	SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
+#define GET_TX_DESC_LSIG_TXOP_EN_8197F(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
+#define SET_TX_DESC_RD_NAV_EXT_8197F(txdesc, value)                            \
+	SET_TX_DESC_RD_NAV_EXT(txdesc, value)
+#define GET_TX_DESC_RD_NAV_EXT_8197F(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
+#define SET_TX_DESC_QSEL_8197F(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
+#define GET_TX_DESC_QSEL_8197F(txdesc) GET_TX_DESC_QSEL(txdesc)
+#define SET_TX_DESC_MACID_8197F(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
+#define GET_TX_DESC_MACID_8197F(txdesc) GET_TX_DESC_MACID(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_HW_AES_IV_8197F(txdesc, value)                             \
+	SET_TX_DESC_HW_AES_IV(txdesc, value)
+#define GET_TX_DESC_HW_AES_IV_8197F(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
+#define SET_TX_DESC_FTM_EN_8197F(txdesc, value)                                \
+	SET_TX_DESC_FTM_EN(txdesc, value)
+#define GET_TX_DESC_FTM_EN_8197F(txdesc) GET_TX_DESC_FTM_EN(txdesc)
+#define SET_TX_DESC_G_ID_8197F(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
+#define GET_TX_DESC_G_ID_8197F(txdesc) GET_TX_DESC_G_ID(txdesc)
+#define SET_TX_DESC_BT_NULL_8197F(txdesc, value)                               \
+	SET_TX_DESC_BT_NULL(txdesc, value)
+#define GET_TX_DESC_BT_NULL_8197F(txdesc) GET_TX_DESC_BT_NULL(txdesc)
+#define SET_TX_DESC_AMPDU_DENSITY_8197F(txdesc, value)                         \
+	SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
+#define GET_TX_DESC_AMPDU_DENSITY_8197F(txdesc)                                \
+	GET_TX_DESC_AMPDU_DENSITY(txdesc)
+#define SET_TX_DESC_SPE_RPT_8197F(txdesc, value)                               \
+	SET_TX_DESC_SPE_RPT(txdesc, value)
+#define GET_TX_DESC_SPE_RPT_8197F(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
+#define SET_TX_DESC_RAW_8197F(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
+#define GET_TX_DESC_RAW_8197F(txdesc) GET_TX_DESC_RAW(txdesc)
+#define SET_TX_DESC_MOREFRAG_8197F(txdesc, value)                              \
+	SET_TX_DESC_MOREFRAG(txdesc, value)
+#define GET_TX_DESC_MOREFRAG_8197F(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
+#define SET_TX_DESC_BK_8197F(txdesc, value) SET_TX_DESC_BK(txdesc, value)
+#define GET_TX_DESC_BK_8197F(txdesc) GET_TX_DESC_BK(txdesc)
+#define SET_TX_DESC_NULL_1_8197F(txdesc, value)                                \
+	SET_TX_DESC_NULL_1(txdesc, value)
+#define GET_TX_DESC_NULL_1_8197F(txdesc) GET_TX_DESC_NULL_1(txdesc)
+#define SET_TX_DESC_NULL_0_8197F(txdesc, value)                                \
+	SET_TX_DESC_NULL_0(txdesc, value)
+#define GET_TX_DESC_NULL_0_8197F(txdesc) GET_TX_DESC_NULL_0(txdesc)
+#define SET_TX_DESC_RDG_EN_8197F(txdesc, value)                                \
+	SET_TX_DESC_RDG_EN(txdesc, value)
+#define GET_TX_DESC_RDG_EN_8197F(txdesc) GET_TX_DESC_RDG_EN(txdesc)
+#define SET_TX_DESC_AGG_EN_8197F(txdesc, value)                                \
+	SET_TX_DESC_AGG_EN(txdesc, value)
+#define GET_TX_DESC_AGG_EN_8197F(txdesc) GET_TX_DESC_AGG_EN(txdesc)
+#define SET_TX_DESC_CCA_RTS_8197F(txdesc, value)                               \
+	SET_TX_DESC_CCA_RTS(txdesc, value)
+#define GET_TX_DESC_CCA_RTS_8197F(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
+#define SET_TX_DESC_TRI_FRAME_8197F(txdesc, value)                             \
+	SET_TX_DESC_TRI_FRAME(txdesc, value)
+#define GET_TX_DESC_TRI_FRAME_8197F(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
+#define SET_TX_DESC_P_AID_8197F(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
+#define GET_TX_DESC_P_AID_8197F(txdesc) GET_TX_DESC_P_AID(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME_8197F(txdesc, value)                        \
+	SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
+#define GET_TX_DESC_AMPDU_MAX_TIME_8197F(txdesc)                               \
+	GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
+#define SET_TX_DESC_NDPA_8197F(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
+#define GET_TX_DESC_NDPA_8197F(txdesc) GET_TX_DESC_NDPA(txdesc)
+#define SET_TX_DESC_MAX_AGG_NUM_8197F(txdesc, value)                           \
+	SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
+#define GET_TX_DESC_MAX_AGG_NUM_8197F(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
+#define SET_TX_DESC_USE_MAX_TIME_EN_8197F(txdesc, value)                       \
+	SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
+#define GET_TX_DESC_USE_MAX_TIME_EN_8197F(txdesc)                              \
+	GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
+#define SET_TX_DESC_NAVUSEHDR_8197F(txdesc, value)                             \
+	SET_TX_DESC_NAVUSEHDR(txdesc, value)
+#define GET_TX_DESC_NAVUSEHDR_8197F(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
+#define SET_TX_DESC_CHK_EN_8197F(txdesc, value)                                \
+	SET_TX_DESC_CHK_EN(txdesc, value)
+#define GET_TX_DESC_CHK_EN_8197F(txdesc) GET_TX_DESC_CHK_EN(txdesc)
+#define SET_TX_DESC_HW_RTS_EN_8197F(txdesc, value)                             \
+	SET_TX_DESC_HW_RTS_EN(txdesc, value)
+#define GET_TX_DESC_HW_RTS_EN_8197F(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
+#define SET_TX_DESC_RTSEN_8197F(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
+#define GET_TX_DESC_RTSEN_8197F(txdesc) GET_TX_DESC_RTSEN(txdesc)
+#define SET_TX_DESC_CTS2SELF_8197F(txdesc, value)                              \
+	SET_TX_DESC_CTS2SELF(txdesc, value)
+#define GET_TX_DESC_CTS2SELF_8197F(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
+#define SET_TX_DESC_DISDATAFB_8197F(txdesc, value)                             \
+	SET_TX_DESC_DISDATAFB(txdesc, value)
+#define GET_TX_DESC_DISDATAFB_8197F(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
+#define SET_TX_DESC_DISRTSFB_8197F(txdesc, value)                              \
+	SET_TX_DESC_DISRTSFB(txdesc, value)
+#define GET_TX_DESC_DISRTSFB_8197F(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
+#define SET_TX_DESC_USE_RATE_8197F(txdesc, value)                              \
+	SET_TX_DESC_USE_RATE(txdesc, value)
+#define GET_TX_DESC_USE_RATE_8197F(txdesc) GET_TX_DESC_USE_RATE(txdesc)
+#define SET_TX_DESC_HW_SSN_SEL_8197F(txdesc, value)                            \
+	SET_TX_DESC_HW_SSN_SEL(txdesc, value)
+#define GET_TX_DESC_HW_SSN_SEL_8197F(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
+#define SET_TX_DESC_WHEADER_LEN_8197F(txdesc, value)                           \
+	SET_TX_DESC_WHEADER_LEN(txdesc, value)
+#define GET_TX_DESC_WHEADER_LEN_8197F(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX_8197F(txdesc, value)                         \
+	SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
+#define GET_TX_DESC_PCTS_MASK_IDX_8197F(txdesc)                                \
+	GET_TX_DESC_PCTS_MASK_IDX(txdesc)
+#define SET_TX_DESC_PCTS_EN_8197F(txdesc, value)                               \
+	SET_TX_DESC_PCTS_EN(txdesc, value)
+#define GET_TX_DESC_PCTS_EN_8197F(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
+#define SET_TX_DESC_RTSRATE_8197F(txdesc, value)                               \
+	SET_TX_DESC_RTSRATE(txdesc, value)
+#define GET_TX_DESC_RTSRATE_8197F(txdesc) GET_TX_DESC_RTSRATE(txdesc)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT_8197F(txdesc, value)                      \
+	SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT_8197F(txdesc)                             \
+	GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
+#define SET_TX_DESC_RTY_LMT_EN_8197F(txdesc, value)                            \
+	SET_TX_DESC_RTY_LMT_EN(txdesc, value)
+#define GET_TX_DESC_RTY_LMT_EN_8197F(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8197F(txdesc, value)                   \
+	SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8197F(txdesc)                          \
+	GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8197F(txdesc, value)                  \
+	SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8197F(txdesc)                         \
+	GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_TRY_RATE_8197F(txdesc, value)                              \
+	SET_TX_DESC_TRY_RATE(txdesc, value)
+#define GET_TX_DESC_TRY_RATE_8197F(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
+#define SET_TX_DESC_DATARATE_8197F(txdesc, value)                              \
+	SET_TX_DESC_DATARATE(txdesc, value)
+#define GET_TX_DESC_DATARATE_8197F(txdesc) GET_TX_DESC_DATARATE(txdesc)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED_8197F(txdesc, value)                              \
+	SET_TX_DESC_POLLUTED(txdesc, value)
+#define GET_TX_DESC_POLLUTED_8197F(txdesc) GET_TX_DESC_POLLUTED(txdesc)
+#define SET_TX_DESC_TXPWR_OFSET_8197F(txdesc, value)                           \
+	SET_TX_DESC_TXPWR_OFSET(txdesc, value)
+#define GET_TX_DESC_TXPWR_OFSET_8197F(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
+#define SET_TX_DESC_TX_ANT_8197F(txdesc, value)                                \
+	SET_TX_DESC_TX_ANT(txdesc, value)
+#define GET_TX_DESC_TX_ANT_8197F(txdesc) GET_TX_DESC_TX_ANT(txdesc)
+#define SET_TX_DESC_PORT_ID_8197F(txdesc, value)                               \
+	SET_TX_DESC_PORT_ID(txdesc, value)
+#define GET_TX_DESC_PORT_ID_8197F(txdesc) GET_TX_DESC_PORT_ID(txdesc)
+#define SET_TX_DESC_MULTIPLE_PORT_8197F(txdesc, value)                         \
+	SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
+#define GET_TX_DESC_MULTIPLE_PORT_8197F(txdesc)                                \
+	GET_TX_DESC_MULTIPLE_PORT(txdesc)
+#define SET_TX_DESC_SIGNALING_TAPKT_EN_8197F(txdesc, value)                    \
+	SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN_8197F(txdesc)                           \
+	GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
+#define SET_TX_DESC_RTS_SC_8197F(txdesc, value)                                \
+	SET_TX_DESC_RTS_SC(txdesc, value)
+#define GET_TX_DESC_RTS_SC_8197F(txdesc) GET_TX_DESC_RTS_SC(txdesc)
+#define SET_TX_DESC_RTS_SHORT_8197F(txdesc, value)                             \
+	SET_TX_DESC_RTS_SHORT(txdesc, value)
+#define GET_TX_DESC_RTS_SHORT_8197F(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
+#define SET_TX_DESC_VCS_STBC_8197F(txdesc, value)                              \
+	SET_TX_DESC_VCS_STBC(txdesc, value)
+#define GET_TX_DESC_VCS_STBC_8197F(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
+#define SET_TX_DESC_DATA_STBC_8197F(txdesc, value)                             \
+	SET_TX_DESC_DATA_STBC(txdesc, value)
+#define GET_TX_DESC_DATA_STBC_8197F(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
+#define SET_TX_DESC_DATA_LDPC_8197F(txdesc, value)                             \
+	SET_TX_DESC_DATA_LDPC(txdesc, value)
+#define GET_TX_DESC_DATA_LDPC_8197F(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
+#define SET_TX_DESC_DATA_BW_8197F(txdesc, value)                               \
+	SET_TX_DESC_DATA_BW(txdesc, value)
+#define GET_TX_DESC_DATA_BW_8197F(txdesc) GET_TX_DESC_DATA_BW(txdesc)
+#define SET_TX_DESC_DATA_SHORT_8197F(txdesc, value)                            \
+	SET_TX_DESC_DATA_SHORT(txdesc, value)
+#define GET_TX_DESC_DATA_SHORT_8197F(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
+#define SET_TX_DESC_DATA_SC_8197F(txdesc, value)                               \
+	SET_TX_DESC_DATA_SC(txdesc, value)
+#define GET_TX_DESC_DATA_SC_8197F(txdesc) GET_TX_DESC_DATA_SC(txdesc)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANTSEL_D_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_D(txdesc, value)
+#define GET_TX_DESC_ANTSEL_D_8197F(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
+#define SET_TX_DESC_ANT_MAPD_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPD(txdesc, value)
+#define GET_TX_DESC_ANT_MAPD_8197F(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
+#define SET_TX_DESC_ANT_MAPC_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPC(txdesc, value)
+#define GET_TX_DESC_ANT_MAPC_8197F(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
+#define SET_TX_DESC_ANT_MAPB_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPB(txdesc, value)
+#define GET_TX_DESC_ANT_MAPB_8197F(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
+#define SET_TX_DESC_ANT_MAPA_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPA(txdesc, value)
+#define GET_TX_DESC_ANT_MAPA_8197F(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
+#define SET_TX_DESC_ANTSEL_C_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_C(txdesc, value)
+#define GET_TX_DESC_ANTSEL_C_8197F(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
+#define SET_TX_DESC_ANTSEL_B_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_B(txdesc, value)
+#define GET_TX_DESC_ANTSEL_B_8197F(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
+#define SET_TX_DESC_ANTSEL_A_8197F(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_A(txdesc, value)
+#define GET_TX_DESC_ANTSEL_A_8197F(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
+#define SET_TX_DESC_MBSSID_8197F(txdesc, value)                                \
+	SET_TX_DESC_MBSSID(txdesc, value)
+#define GET_TX_DESC_MBSSID_8197F(txdesc) GET_TX_DESC_MBSSID(txdesc)
+#define SET_TX_DESC_SW_DEFINE_8197F(txdesc, value)                             \
+	SET_TX_DESC_SW_DEFINE(txdesc, value)
+#define GET_TX_DESC_SW_DEFINE_8197F(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_8197F(txdesc, value)                         \
+	SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_8197F(txdesc)                                \
+	GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
+#define SET_TX_DESC_FINAL_DATA_RATE_8197F(txdesc, value)                       \
+	SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
+#define GET_TX_DESC_FINAL_DATA_RATE_8197F(txdesc)                              \
+	GET_TX_DESC_FINAL_DATA_RATE(txdesc)
+#define SET_TX_DESC_NTX_MAP_8197F(txdesc, value)                               \
+	SET_TX_DESC_NTX_MAP(txdesc, value)
+#define GET_TX_DESC_NTX_MAP_8197F(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
+#define SET_TX_DESC_TX_BUFF_SIZE_8197F(txdesc, value)                          \
+	SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
+#define GET_TX_DESC_TX_BUFF_SIZE_8197F(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
+#define SET_TX_DESC_TXDESC_CHECKSUM_8197F(txdesc, value)                       \
+	SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_8197F(txdesc)                              \
+	GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
+#define SET_TX_DESC_TIMESTAMP_8197F(txdesc, value)                             \
+	SET_TX_DESC_TIMESTAMP(txdesc, value)
+#define GET_TX_DESC_TIMESTAMP_8197F(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP_8197F(txdesc, value)                             \
+	SET_TX_DESC_TXWIFI_CP(txdesc, value)
+#define GET_TX_DESC_TXWIFI_CP_8197F(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
+#define SET_TX_DESC_MAC_CP_8197F(txdesc, value)                                \
+	SET_TX_DESC_MAC_CP(txdesc, value)
+#define GET_TX_DESC_MAC_CP_8197F(txdesc) GET_TX_DESC_MAC_CP(txdesc)
+#define SET_TX_DESC_STW_PKTRE_DIS_8197F(txdesc, value)                         \
+	SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_PKTRE_DIS_8197F(txdesc)                                \
+	GET_TX_DESC_STW_PKTRE_DIS(txdesc)
+#define SET_TX_DESC_STW_RB_DIS_8197F(txdesc, value)                            \
+	SET_TX_DESC_STW_RB_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RB_DIS_8197F(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
+#define SET_TX_DESC_STW_RATE_DIS_8197F(txdesc, value)                          \
+	SET_TX_DESC_STW_RATE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RATE_DIS_8197F(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
+#define SET_TX_DESC_STW_ANT_DIS_8197F(txdesc, value)                           \
+	SET_TX_DESC_STW_ANT_DIS(txdesc, value)
+#define GET_TX_DESC_STW_ANT_DIS_8197F(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
+#define SET_TX_DESC_STW_EN_8197F(txdesc, value)                                \
+	SET_TX_DESC_STW_EN(txdesc, value)
+#define GET_TX_DESC_STW_EN_8197F(txdesc) GET_TX_DESC_STW_EN(txdesc)
+#define SET_TX_DESC_SMH_EN_8197F(txdesc, value)                                \
+	SET_TX_DESC_SMH_EN(txdesc, value)
+#define GET_TX_DESC_SMH_EN_8197F(txdesc) GET_TX_DESC_SMH_EN(txdesc)
+#define SET_TX_DESC_TAILPAGE_L_8197F(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_L(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_L_8197F(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
+#define SET_TX_DESC_SDIO_DMASEQ_8197F(txdesc, value)                           \
+	SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
+#define GET_TX_DESC_SDIO_DMASEQ_8197F(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_L_8197F(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_L_8197F(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
+#define SET_TX_DESC_EN_HWSEQ_8197F(txdesc, value)                              \
+	SET_TX_DESC_EN_HWSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWSEQ_8197F(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
+#define SET_TX_DESC_EN_HWEXSEQ_8197F(txdesc, value)                            \
+	SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWEXSEQ_8197F(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
+#define SET_TX_DESC_DATA_RC_8197F(txdesc, value)                               \
+	SET_TX_DESC_DATA_RC(txdesc, value)
+#define GET_TX_DESC_DATA_RC_8197F(txdesc) GET_TX_DESC_DATA_RC(txdesc)
+#define SET_TX_DESC_BAR_RTY_TH_8197F(txdesc, value)                            \
+	SET_TX_DESC_BAR_RTY_TH(txdesc, value)
+#define GET_TX_DESC_BAR_RTY_TH_8197F(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
+#define SET_TX_DESC_RTS_RC_8197F(txdesc, value)                                \
+	SET_TX_DESC_RTS_RC(txdesc, value)
+#define GET_TX_DESC_RTS_RC_8197F(txdesc) GET_TX_DESC_RTS_RC(txdesc)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H_8197F(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_H(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_H_8197F(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_H_8197F(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_H_8197F(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
+#define SET_TX_DESC_SW_SEQ_8197F(txdesc, value)                                \
+	SET_TX_DESC_SW_SEQ(txdesc, value)
+#define GET_TX_DESC_SW_SEQ_8197F(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
+#define SET_TX_DESC_TXBF_PATH_8197F(txdesc, value)                             \
+	SET_TX_DESC_TXBF_PATH(txdesc, value)
+#define GET_TX_DESC_TXBF_PATH_8197F(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
+#define SET_TX_DESC_PADDING_LEN_8197F(txdesc, value)                           \
+	SET_TX_DESC_PADDING_LEN(txdesc, value)
+#define GET_TX_DESC_PADDING_LEN_8197F(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8197F(txdesc, value)                   \
+	SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8197F(txdesc)                          \
+	GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
+
+/*WORD10*/
+
+#endif
+
+#if (HALMAC_8821C_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ_8821C(txdesc, value)                            \
+	SET_TX_DESC_DISQSELSEQ(txdesc, value)
+#define GET_TX_DESC_DISQSELSEQ_8821C(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
+#define SET_TX_DESC_GF_8821C(txdesc, value) SET_TX_DESC_GF(txdesc, value)
+#define GET_TX_DESC_GF_8821C(txdesc) GET_TX_DESC_GF(txdesc)
+#define SET_TX_DESC_NO_ACM_8821C(txdesc, value)                                \
+	SET_TX_DESC_NO_ACM(txdesc, value)
+#define GET_TX_DESC_NO_ACM_8821C(txdesc) GET_TX_DESC_NO_ACM(txdesc)
+#define SET_TX_DESC_BCNPKT_TSF_CTRL_8821C(txdesc, value)                       \
+	SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
+#define GET_TX_DESC_BCNPKT_TSF_CTRL_8821C(txdesc)                              \
+	GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
+#define SET_TX_DESC_AMSDU_PAD_EN_8821C(txdesc, value)                          \
+	SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
+#define GET_TX_DESC_AMSDU_PAD_EN_8821C(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
+#define SET_TX_DESC_LS_8821C(txdesc, value) SET_TX_DESC_LS(txdesc, value)
+#define GET_TX_DESC_LS_8821C(txdesc) GET_TX_DESC_LS(txdesc)
+#define SET_TX_DESC_HTC_8821C(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
+#define GET_TX_DESC_HTC_8821C(txdesc) GET_TX_DESC_HTC(txdesc)
+#define SET_TX_DESC_BMC_8821C(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
+#define GET_TX_DESC_BMC_8821C(txdesc) GET_TX_DESC_BMC(txdesc)
+#define SET_TX_DESC_OFFSET_8821C(txdesc, value)                                \
+	SET_TX_DESC_OFFSET(txdesc, value)
+#define GET_TX_DESC_OFFSET_8821C(txdesc) GET_TX_DESC_OFFSET(txdesc)
+#define SET_TX_DESC_TXPKTSIZE_8821C(txdesc, value)                             \
+	SET_TX_DESC_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_TXPKTSIZE_8821C(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
+
+/*WORD1*/
+
+#define SET_TX_DESC_MOREDATA_8821C(txdesc, value)                              \
+	SET_TX_DESC_MOREDATA(txdesc, value)
+#define GET_TX_DESC_MOREDATA_8821C(txdesc) GET_TX_DESC_MOREDATA(txdesc)
+#define SET_TX_DESC_PKT_OFFSET_8821C(txdesc, value)                            \
+	SET_TX_DESC_PKT_OFFSET(txdesc, value)
+#define GET_TX_DESC_PKT_OFFSET_8821C(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
+#define SET_TX_DESC_SEC_TYPE_8821C(txdesc, value)                              \
+	SET_TX_DESC_SEC_TYPE(txdesc, value)
+#define GET_TX_DESC_SEC_TYPE_8821C(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
+#define SET_TX_DESC_EN_DESC_ID_8821C(txdesc, value)                            \
+	SET_TX_DESC_EN_DESC_ID(txdesc, value)
+#define GET_TX_DESC_EN_DESC_ID_8821C(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
+#define SET_TX_DESC_RATE_ID_8821C(txdesc, value)                               \
+	SET_TX_DESC_RATE_ID(txdesc, value)
+#define GET_TX_DESC_RATE_ID_8821C(txdesc) GET_TX_DESC_RATE_ID(txdesc)
+#define SET_TX_DESC_PIFS_8821C(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
+#define GET_TX_DESC_PIFS_8821C(txdesc) GET_TX_DESC_PIFS(txdesc)
+#define SET_TX_DESC_LSIG_TXOP_EN_8821C(txdesc, value)                          \
+	SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
+#define GET_TX_DESC_LSIG_TXOP_EN_8821C(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
+#define SET_TX_DESC_RD_NAV_EXT_8821C(txdesc, value)                            \
+	SET_TX_DESC_RD_NAV_EXT(txdesc, value)
+#define GET_TX_DESC_RD_NAV_EXT_8821C(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
+#define SET_TX_DESC_QSEL_8821C(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
+#define GET_TX_DESC_QSEL_8821C(txdesc) GET_TX_DESC_QSEL(txdesc)
+#define SET_TX_DESC_MACID_8821C(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
+#define GET_TX_DESC_MACID_8821C(txdesc) GET_TX_DESC_MACID(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_HW_AES_IV_8821C(txdesc, value)                             \
+	SET_TX_DESC_HW_AES_IV(txdesc, value)
+#define GET_TX_DESC_HW_AES_IV_8821C(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
+#define SET_TX_DESC_FTM_EN_8821C(txdesc, value)                                \
+	SET_TX_DESC_FTM_EN(txdesc, value)
+#define GET_TX_DESC_FTM_EN_8821C(txdesc) GET_TX_DESC_FTM_EN(txdesc)
+#define SET_TX_DESC_G_ID_8821C(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
+#define GET_TX_DESC_G_ID_8821C(txdesc) GET_TX_DESC_G_ID(txdesc)
+#define SET_TX_DESC_BT_NULL_8821C(txdesc, value)                               \
+	SET_TX_DESC_BT_NULL(txdesc, value)
+#define GET_TX_DESC_BT_NULL_8821C(txdesc) GET_TX_DESC_BT_NULL(txdesc)
+#define SET_TX_DESC_AMPDU_DENSITY_8821C(txdesc, value)                         \
+	SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
+#define GET_TX_DESC_AMPDU_DENSITY_8821C(txdesc)                                \
+	GET_TX_DESC_AMPDU_DENSITY(txdesc)
+#define SET_TX_DESC_SPE_RPT_8821C(txdesc, value)                               \
+	SET_TX_DESC_SPE_RPT(txdesc, value)
+#define GET_TX_DESC_SPE_RPT_8821C(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
+#define SET_TX_DESC_RAW_8821C(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
+#define GET_TX_DESC_RAW_8821C(txdesc) GET_TX_DESC_RAW(txdesc)
+#define SET_TX_DESC_MOREFRAG_8821C(txdesc, value)                              \
+	SET_TX_DESC_MOREFRAG(txdesc, value)
+#define GET_TX_DESC_MOREFRAG_8821C(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
+#define SET_TX_DESC_BK_8821C(txdesc, value) SET_TX_DESC_BK(txdesc, value)
+#define GET_TX_DESC_BK_8821C(txdesc) GET_TX_DESC_BK(txdesc)
+#define SET_TX_DESC_NULL_1_8821C(txdesc, value)                                \
+	SET_TX_DESC_NULL_1(txdesc, value)
+#define GET_TX_DESC_NULL_1_8821C(txdesc) GET_TX_DESC_NULL_1(txdesc)
+#define SET_TX_DESC_NULL_0_8821C(txdesc, value)                                \
+	SET_TX_DESC_NULL_0(txdesc, value)
+#define GET_TX_DESC_NULL_0_8821C(txdesc) GET_TX_DESC_NULL_0(txdesc)
+#define SET_TX_DESC_RDG_EN_8821C(txdesc, value)                                \
+	SET_TX_DESC_RDG_EN(txdesc, value)
+#define GET_TX_DESC_RDG_EN_8821C(txdesc) GET_TX_DESC_RDG_EN(txdesc)
+#define SET_TX_DESC_AGG_EN_8821C(txdesc, value)                                \
+	SET_TX_DESC_AGG_EN(txdesc, value)
+#define GET_TX_DESC_AGG_EN_8821C(txdesc) GET_TX_DESC_AGG_EN(txdesc)
+#define SET_TX_DESC_CCA_RTS_8821C(txdesc, value)                               \
+	SET_TX_DESC_CCA_RTS(txdesc, value)
+#define GET_TX_DESC_CCA_RTS_8821C(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
+#define SET_TX_DESC_TRI_FRAME_8821C(txdesc, value)                             \
+	SET_TX_DESC_TRI_FRAME(txdesc, value)
+#define GET_TX_DESC_TRI_FRAME_8821C(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
+#define SET_TX_DESC_P_AID_8821C(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
+#define GET_TX_DESC_P_AID_8821C(txdesc) GET_TX_DESC_P_AID(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME_8821C(txdesc, value)                        \
+	SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
+#define GET_TX_DESC_AMPDU_MAX_TIME_8821C(txdesc)                               \
+	GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
+#define SET_TX_DESC_NDPA_8821C(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
+#define GET_TX_DESC_NDPA_8821C(txdesc) GET_TX_DESC_NDPA(txdesc)
+#define SET_TX_DESC_MAX_AGG_NUM_8821C(txdesc, value)                           \
+	SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
+#define GET_TX_DESC_MAX_AGG_NUM_8821C(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
+#define SET_TX_DESC_USE_MAX_TIME_EN_8821C(txdesc, value)                       \
+	SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
+#define GET_TX_DESC_USE_MAX_TIME_EN_8821C(txdesc)                              \
+	GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
+#define SET_TX_DESC_NAVUSEHDR_8821C(txdesc, value)                             \
+	SET_TX_DESC_NAVUSEHDR(txdesc, value)
+#define GET_TX_DESC_NAVUSEHDR_8821C(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
+#define SET_TX_DESC_CHK_EN_8821C(txdesc, value)                                \
+	SET_TX_DESC_CHK_EN(txdesc, value)
+#define GET_TX_DESC_CHK_EN_8821C(txdesc) GET_TX_DESC_CHK_EN(txdesc)
+#define SET_TX_DESC_HW_RTS_EN_8821C(txdesc, value)                             \
+	SET_TX_DESC_HW_RTS_EN(txdesc, value)
+#define GET_TX_DESC_HW_RTS_EN_8821C(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
+#define SET_TX_DESC_RTSEN_8821C(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
+#define GET_TX_DESC_RTSEN_8821C(txdesc) GET_TX_DESC_RTSEN(txdesc)
+#define SET_TX_DESC_CTS2SELF_8821C(txdesc, value)                              \
+	SET_TX_DESC_CTS2SELF(txdesc, value)
+#define GET_TX_DESC_CTS2SELF_8821C(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
+#define SET_TX_DESC_DISDATAFB_8821C(txdesc, value)                             \
+	SET_TX_DESC_DISDATAFB(txdesc, value)
+#define GET_TX_DESC_DISDATAFB_8821C(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
+#define SET_TX_DESC_DISRTSFB_8821C(txdesc, value)                              \
+	SET_TX_DESC_DISRTSFB(txdesc, value)
+#define GET_TX_DESC_DISRTSFB_8821C(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
+#define SET_TX_DESC_USE_RATE_8821C(txdesc, value)                              \
+	SET_TX_DESC_USE_RATE(txdesc, value)
+#define GET_TX_DESC_USE_RATE_8821C(txdesc) GET_TX_DESC_USE_RATE(txdesc)
+#define SET_TX_DESC_HW_SSN_SEL_8821C(txdesc, value)                            \
+	SET_TX_DESC_HW_SSN_SEL(txdesc, value)
+#define GET_TX_DESC_HW_SSN_SEL_8821C(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
+#define SET_TX_DESC_WHEADER_LEN_8821C(txdesc, value)                           \
+	SET_TX_DESC_WHEADER_LEN(txdesc, value)
+#define GET_TX_DESC_WHEADER_LEN_8821C(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX_8821C(txdesc, value)                         \
+	SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
+#define GET_TX_DESC_PCTS_MASK_IDX_8821C(txdesc)                                \
+	GET_TX_DESC_PCTS_MASK_IDX(txdesc)
+#define SET_TX_DESC_PCTS_EN_8821C(txdesc, value)                               \
+	SET_TX_DESC_PCTS_EN(txdesc, value)
+#define GET_TX_DESC_PCTS_EN_8821C(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
+#define SET_TX_DESC_RTSRATE_8821C(txdesc, value)                               \
+	SET_TX_DESC_RTSRATE(txdesc, value)
+#define GET_TX_DESC_RTSRATE_8821C(txdesc) GET_TX_DESC_RTSRATE(txdesc)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT_8821C(txdesc, value)                      \
+	SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT_8821C(txdesc)                             \
+	GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
+#define SET_TX_DESC_RTY_LMT_EN_8821C(txdesc, value)                            \
+	SET_TX_DESC_RTY_LMT_EN(txdesc, value)
+#define GET_TX_DESC_RTY_LMT_EN_8821C(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8821C(txdesc, value)                   \
+	SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8821C(txdesc)                          \
+	GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8821C(txdesc, value)                  \
+	SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8821C(txdesc)                         \
+	GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_TRY_RATE_8821C(txdesc, value)                              \
+	SET_TX_DESC_TRY_RATE(txdesc, value)
+#define GET_TX_DESC_TRY_RATE_8821C(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
+#define SET_TX_DESC_DATARATE_8821C(txdesc, value)                              \
+	SET_TX_DESC_DATARATE(txdesc, value)
+#define GET_TX_DESC_DATARATE_8821C(txdesc) GET_TX_DESC_DATARATE(txdesc)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED_8821C(txdesc, value)                              \
+	SET_TX_DESC_POLLUTED(txdesc, value)
+#define GET_TX_DESC_POLLUTED_8821C(txdesc) GET_TX_DESC_POLLUTED(txdesc)
+#define SET_TX_DESC_TXPWR_OFSET_8821C(txdesc, value)                           \
+	SET_TX_DESC_TXPWR_OFSET(txdesc, value)
+#define GET_TX_DESC_TXPWR_OFSET_8821C(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
+#define SET_TX_DESC_TX_ANT_8821C(txdesc, value)                                \
+	SET_TX_DESC_TX_ANT(txdesc, value)
+#define GET_TX_DESC_TX_ANT_8821C(txdesc) GET_TX_DESC_TX_ANT(txdesc)
+#define SET_TX_DESC_PORT_ID_8821C(txdesc, value)                               \
+	SET_TX_DESC_PORT_ID(txdesc, value)
+#define GET_TX_DESC_PORT_ID_8821C(txdesc) GET_TX_DESC_PORT_ID(txdesc)
+#define SET_TX_DESC_MULTIPLE_PORT_8821C(txdesc, value)                         \
+	SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
+#define GET_TX_DESC_MULTIPLE_PORT_8821C(txdesc)                                \
+	GET_TX_DESC_MULTIPLE_PORT(txdesc)
+#define SET_TX_DESC_SIGNALING_TAPKT_EN_8821C(txdesc, value)                    \
+	SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN_8821C(txdesc)                           \
+	GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
+#define SET_TX_DESC_SIGNALING_TA_PKT_SC_8821C(txdesc, value)                   \
+	SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TA_PKT_SC_8821C(txdesc)                          \
+	GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)
+#define SET_TX_DESC_RTS_SHORT_8821C(txdesc, value)                             \
+	SET_TX_DESC_RTS_SHORT(txdesc, value)
+#define GET_TX_DESC_RTS_SHORT_8821C(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
+#define SET_TX_DESC_VCS_STBC_8821C(txdesc, value)                              \
+	SET_TX_DESC_VCS_STBC(txdesc, value)
+#define GET_TX_DESC_VCS_STBC_8821C(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
+#define SET_TX_DESC_DATA_STBC_8821C(txdesc, value)                             \
+	SET_TX_DESC_DATA_STBC(txdesc, value)
+#define GET_TX_DESC_DATA_STBC_8821C(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
+#define SET_TX_DESC_DATA_LDPC_8821C(txdesc, value)                             \
+	SET_TX_DESC_DATA_LDPC(txdesc, value)
+#define GET_TX_DESC_DATA_LDPC_8821C(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
+#define SET_TX_DESC_DATA_BW_8821C(txdesc, value)                               \
+	SET_TX_DESC_DATA_BW(txdesc, value)
+#define GET_TX_DESC_DATA_BW_8821C(txdesc) GET_TX_DESC_DATA_BW(txdesc)
+#define SET_TX_DESC_DATA_SHORT_8821C(txdesc, value)                            \
+	SET_TX_DESC_DATA_SHORT(txdesc, value)
+#define GET_TX_DESC_DATA_SHORT_8821C(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
+#define SET_TX_DESC_DATA_SC_8821C(txdesc, value)                               \
+	SET_TX_DESC_DATA_SC(txdesc, value)
+#define GET_TX_DESC_DATA_SC_8821C(txdesc) GET_TX_DESC_DATA_SC(txdesc)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANTSEL_D_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_D(txdesc, value)
+#define GET_TX_DESC_ANTSEL_D_8821C(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
+#define SET_TX_DESC_ANT_MAPD_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPD(txdesc, value)
+#define GET_TX_DESC_ANT_MAPD_8821C(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
+#define SET_TX_DESC_ANT_MAPC_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPC(txdesc, value)
+#define GET_TX_DESC_ANT_MAPC_8821C(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
+#define SET_TX_DESC_ANT_MAPB_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPB(txdesc, value)
+#define GET_TX_DESC_ANT_MAPB_8821C(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
+#define SET_TX_DESC_ANT_MAPA_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPA(txdesc, value)
+#define GET_TX_DESC_ANT_MAPA_8821C(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
+#define SET_TX_DESC_ANTSEL_C_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_C(txdesc, value)
+#define GET_TX_DESC_ANTSEL_C_8821C(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
+#define SET_TX_DESC_ANTSEL_B_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_B(txdesc, value)
+#define GET_TX_DESC_ANTSEL_B_8821C(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
+#define SET_TX_DESC_ANTSEL_A_8821C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_A(txdesc, value)
+#define GET_TX_DESC_ANTSEL_A_8821C(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
+#define SET_TX_DESC_MBSSID_8821C(txdesc, value)                                \
+	SET_TX_DESC_MBSSID(txdesc, value)
+#define GET_TX_DESC_MBSSID_8821C(txdesc) GET_TX_DESC_MBSSID(txdesc)
+#define SET_TX_DESC_SW_DEFINE_8821C(txdesc, value)                             \
+	SET_TX_DESC_SW_DEFINE(txdesc, value)
+#define GET_TX_DESC_SW_DEFINE_8821C(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_8821C(txdesc, value)                         \
+	SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_8821C(txdesc)                                \
+	GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
+#define SET_TX_DESC_FINAL_DATA_RATE_8821C(txdesc, value)                       \
+	SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
+#define GET_TX_DESC_FINAL_DATA_RATE_8821C(txdesc)                              \
+	GET_TX_DESC_FINAL_DATA_RATE(txdesc)
+#define SET_TX_DESC_NTX_MAP_8821C(txdesc, value)                               \
+	SET_TX_DESC_NTX_MAP(txdesc, value)
+#define GET_TX_DESC_NTX_MAP_8821C(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
+#define SET_TX_DESC_TX_BUFF_SIZE_8821C(txdesc, value)                          \
+	SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
+#define GET_TX_DESC_TX_BUFF_SIZE_8821C(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
+#define SET_TX_DESC_TXDESC_CHECKSUM_8821C(txdesc, value)                       \
+	SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_8821C(txdesc)                              \
+	GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
+#define SET_TX_DESC_TIMESTAMP_8821C(txdesc, value)                             \
+	SET_TX_DESC_TIMESTAMP(txdesc, value)
+#define GET_TX_DESC_TIMESTAMP_8821C(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP_8821C(txdesc, value)                             \
+	SET_TX_DESC_TXWIFI_CP(txdesc, value)
+#define GET_TX_DESC_TXWIFI_CP_8821C(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
+#define SET_TX_DESC_MAC_CP_8821C(txdesc, value)                                \
+	SET_TX_DESC_MAC_CP(txdesc, value)
+#define GET_TX_DESC_MAC_CP_8821C(txdesc) GET_TX_DESC_MAC_CP(txdesc)
+#define SET_TX_DESC_STW_PKTRE_DIS_8821C(txdesc, value)                         \
+	SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_PKTRE_DIS_8821C(txdesc)                                \
+	GET_TX_DESC_STW_PKTRE_DIS(txdesc)
+#define SET_TX_DESC_STW_RB_DIS_8821C(txdesc, value)                            \
+	SET_TX_DESC_STW_RB_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RB_DIS_8821C(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
+#define SET_TX_DESC_STW_RATE_DIS_8821C(txdesc, value)                          \
+	SET_TX_DESC_STW_RATE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RATE_DIS_8821C(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
+#define SET_TX_DESC_STW_ANT_DIS_8821C(txdesc, value)                           \
+	SET_TX_DESC_STW_ANT_DIS(txdesc, value)
+#define GET_TX_DESC_STW_ANT_DIS_8821C(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
+#define SET_TX_DESC_STW_EN_8821C(txdesc, value)                                \
+	SET_TX_DESC_STW_EN(txdesc, value)
+#define GET_TX_DESC_STW_EN_8821C(txdesc) GET_TX_DESC_STW_EN(txdesc)
+#define SET_TX_DESC_SMH_EN_8821C(txdesc, value)                                \
+	SET_TX_DESC_SMH_EN(txdesc, value)
+#define GET_TX_DESC_SMH_EN_8821C(txdesc) GET_TX_DESC_SMH_EN(txdesc)
+#define SET_TX_DESC_TAILPAGE_L_8821C(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_L(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_L_8821C(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
+#define SET_TX_DESC_SDIO_DMASEQ_8821C(txdesc, value)                           \
+	SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
+#define GET_TX_DESC_SDIO_DMASEQ_8821C(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_L_8821C(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_L_8821C(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
+#define SET_TX_DESC_EN_HWSEQ_8821C(txdesc, value)                              \
+	SET_TX_DESC_EN_HWSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWSEQ_8821C(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
+#define SET_TX_DESC_EN_HWEXSEQ_8821C(txdesc, value)                            \
+	SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWEXSEQ_8821C(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
+#define SET_TX_DESC_DATA_RC_8821C(txdesc, value)                               \
+	SET_TX_DESC_DATA_RC(txdesc, value)
+#define GET_TX_DESC_DATA_RC_8821C(txdesc) GET_TX_DESC_DATA_RC(txdesc)
+#define SET_TX_DESC_BAR_RTY_TH_8821C(txdesc, value)                            \
+	SET_TX_DESC_BAR_RTY_TH(txdesc, value)
+#define GET_TX_DESC_BAR_RTY_TH_8821C(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
+#define SET_TX_DESC_RTS_RC_8821C(txdesc, value)                                \
+	SET_TX_DESC_RTS_RC(txdesc, value)
+#define GET_TX_DESC_RTS_RC_8821C(txdesc) GET_TX_DESC_RTS_RC(txdesc)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H_8821C(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_H(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_H_8821C(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_H_8821C(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_H_8821C(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
+#define SET_TX_DESC_SW_SEQ_8821C(txdesc, value)                                \
+	SET_TX_DESC_SW_SEQ(txdesc, value)
+#define GET_TX_DESC_SW_SEQ_8821C(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
+#define SET_TX_DESC_TXBF_PATH_8821C(txdesc, value)                             \
+	SET_TX_DESC_TXBF_PATH(txdesc, value)
+#define GET_TX_DESC_TXBF_PATH_8821C(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
+#define SET_TX_DESC_PADDING_LEN_8821C(txdesc, value)                           \
+	SET_TX_DESC_PADDING_LEN(txdesc, value)
+#define GET_TX_DESC_PADDING_LEN_8821C(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8821C(txdesc, value)                   \
+	SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8821C(txdesc)                          \
+	GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
+
+/*WORD10*/
+
+#define SET_TX_DESC_MU_DATARATE_8821C(txdesc, value)                           \
+	SET_TX_DESC_MU_DATARATE(txdesc, value)
+#define GET_TX_DESC_MU_DATARATE_8821C(txdesc) GET_TX_DESC_MU_DATARATE(txdesc)
+#define SET_TX_DESC_MU_RC_8821C(txdesc, value) SET_TX_DESC_MU_RC(txdesc, value)
+#define GET_TX_DESC_MU_RC_8821C(txdesc) GET_TX_DESC_MU_RC(txdesc)
+#define SET_TX_DESC_SND_PKT_SEL_8821C(txdesc, value)                           \
+	SET_TX_DESC_SND_PKT_SEL(txdesc, value)
+#define GET_TX_DESC_SND_PKT_SEL_8821C(txdesc) GET_TX_DESC_SND_PKT_SEL(txdesc)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_IE_END_BODY_8814B(txdesc, value)                           \
+	SET_TX_DESC_IE_END_BODY(txdesc, value)
+#define GET_TX_DESC_IE_END_BODY_8814B(txdesc) GET_TX_DESC_IE_END_BODY(txdesc)
+#define SET_TX_DESC_AGG_EN_8814B(txdesc, value)                                \
+	SET_TX_DESC_AGG_EN_V1(txdesc, value)
+#define GET_TX_DESC_AGG_EN_8814B(txdesc) GET_TX_DESC_AGG_EN_V1(txdesc)
+#define SET_TX_DESC_BK_8814B(txdesc, value) SET_TX_DESC_BK_V1(txdesc, value)
+#define GET_TX_DESC_BK_8814B(txdesc) GET_TX_DESC_BK_V1(txdesc)
+#define SET_TX_DESC_PKT_OFFSET_8814B(txdesc, value)                            \
+	SET_TX_DESC_PKT_OFFSET_V1(txdesc, value)
+#define GET_TX_DESC_PKT_OFFSET_8814B(txdesc) GET_TX_DESC_PKT_OFFSET_V1(txdesc)
+#define SET_TX_DESC_OFFSET_8814B(txdesc, value)                                \
+	SET_TX_DESC_OFFSET(txdesc, value)
+#define GET_TX_DESC_OFFSET_8814B(txdesc) GET_TX_DESC_OFFSET(txdesc)
+#define SET_TX_DESC_TXPKTSIZE_8814B(txdesc, value)                             \
+	SET_TX_DESC_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_TXPKTSIZE_8814B(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
+
+/*WORD1*/
+
+#define SET_TX_DESC_AMSDU_8814B(txdesc, value) SET_TX_DESC_AMSDU(txdesc, value)
+#define GET_TX_DESC_AMSDU_8814B(txdesc) GET_TX_DESC_AMSDU(txdesc)
+#define SET_TX_DESC_HW_AES_IV_8814B(txdesc, value)                             \
+	SET_TX_DESC_HW_AES_IV_V1(txdesc, value)
+#define GET_TX_DESC_HW_AES_IV_8814B(txdesc) GET_TX_DESC_HW_AES_IV_V1(txdesc)
+#define SET_TX_DESC_MHR_CP_8814B(txdesc, value)                                \
+	SET_TX_DESC_MHR_CP(txdesc, value)
+#define GET_TX_DESC_MHR_CP_8814B(txdesc) GET_TX_DESC_MHR_CP(txdesc)
+#define SET_TX_DESC_SMH_EN_8814B(txdesc, value)                                \
+	SET_TX_DESC_SMH_EN_V1(txdesc, value)
+#define GET_TX_DESC_SMH_EN_8814B(txdesc) GET_TX_DESC_SMH_EN_V1(txdesc)
+#define SET_TX_DESC_SMH_CAM_8814B(txdesc, value)                               \
+	SET_TX_DESC_SMH_CAM(txdesc, value)
+#define GET_TX_DESC_SMH_CAM_8814B(txdesc) GET_TX_DESC_SMH_CAM(txdesc)
+#define SET_TX_DESC_EXT_EDCA_8814B(txdesc, value)                              \
+	SET_TX_DESC_EXT_EDCA(txdesc, value)
+#define GET_TX_DESC_EXT_EDCA_8814B(txdesc) GET_TX_DESC_EXT_EDCA(txdesc)
+#define SET_TX_DESC_QSEL_8814B(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
+#define GET_TX_DESC_QSEL_8814B(txdesc) GET_TX_DESC_QSEL(txdesc)
+#define SET_TX_DESC_MACID_8814B(txdesc, value)                                 \
+	SET_TX_DESC_MACID_V1(txdesc, value)
+#define GET_TX_DESC_MACID_8814B(txdesc) GET_TX_DESC_MACID_V1(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_CHK_EN_8814B(txdesc, value)                                \
+	SET_TX_DESC_CHK_EN_V1(txdesc, value)
+#define GET_TX_DESC_CHK_EN_8814B(txdesc) GET_TX_DESC_CHK_EN_V1(txdesc)
+#define SET_TX_DESC_DMA_PRI_8814B(txdesc, value)                               \
+	SET_TX_DESC_DMA_PRI(txdesc, value)
+#define GET_TX_DESC_DMA_PRI_8814B(txdesc) GET_TX_DESC_DMA_PRI(txdesc)
+#define SET_TX_DESC_MAX_AMSDU_MODE_8814B(txdesc, value)                        \
+	SET_TX_DESC_MAX_AMSDU_MODE(txdesc, value)
+#define GET_TX_DESC_MAX_AMSDU_MODE_8814B(txdesc)                               \
+	GET_TX_DESC_MAX_AMSDU_MODE(txdesc)
+#define SET_TX_DESC_DMA_TXAGG_NUM_8814B(txdesc, value)                         \
+	SET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_8814B(txdesc)                                \
+	GET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc)
+#define SET_TX_DESC_TXDESC_CHECKSUM_8814B(txdesc, value)                       \
+	SET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_8814B(txdesc)                              \
+	GET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_OFFLOAD_SIZE_8814B(txdesc, value)                          \
+	SET_TX_DESC_OFFLOAD_SIZE(txdesc, value)
+#define GET_TX_DESC_OFFLOAD_SIZE_8814B(txdesc) GET_TX_DESC_OFFLOAD_SIZE(txdesc)
+#define SET_TX_DESC_CHANNEL_DMA_8814B(txdesc, value)                           \
+	SET_TX_DESC_CHANNEL_DMA(txdesc, value)
+#define GET_TX_DESC_CHANNEL_DMA_8814B(txdesc) GET_TX_DESC_CHANNEL_DMA(txdesc)
+#define SET_TX_DESC_IE_CNT_8814B(txdesc, value)                                \
+	SET_TX_DESC_IE_CNT(txdesc, value)
+#define GET_TX_DESC_IE_CNT_8814B(txdesc) GET_TX_DESC_IE_CNT(txdesc)
+#define SET_TX_DESC_IE_CNT_EN_8814B(txdesc, value)                             \
+	SET_TX_DESC_IE_CNT_EN(txdesc, value)
+#define GET_TX_DESC_IE_CNT_EN_8814B(txdesc) GET_TX_DESC_IE_CNT_EN(txdesc)
+#define SET_TX_DESC_WHEADER_LEN_8814B(txdesc, value)                           \
+	SET_TX_DESC_WHEADER_LEN_V1(txdesc, value)
+#define GET_TX_DESC_WHEADER_LEN_8814B(txdesc) GET_TX_DESC_WHEADER_LEN_V1(txdesc)
+
+/*TXDESC_WORD4*/
+
+/*TXDESC_WORD5*/
+
+/*TXDESC_WORD6*/
+
+/*TXDESC_WORD7*/
+
+/*TXDESC_WORD8*/
+
+/*TXDESC_WORD9*/
+
+/*WORD10*/
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ_8198F(txdesc, value)                            \
+	SET_TX_DESC_DISQSELSEQ(txdesc, value)
+#define GET_TX_DESC_DISQSELSEQ_8198F(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
+#define SET_TX_DESC_GF_8198F(txdesc, value) SET_TX_DESC_GF(txdesc, value)
+#define GET_TX_DESC_GF_8198F(txdesc) GET_TX_DESC_GF(txdesc)
+#define SET_TX_DESC_NO_ACM_8198F(txdesc, value)                                \
+	SET_TX_DESC_NO_ACM(txdesc, value)
+#define GET_TX_DESC_NO_ACM_8198F(txdesc) GET_TX_DESC_NO_ACM(txdesc)
+#define SET_TX_DESC_BCNPKT_TSF_CTRL_8198F(txdesc, value)                       \
+	SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
+#define GET_TX_DESC_BCNPKT_TSF_CTRL_8198F(txdesc)                              \
+	GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
+#define SET_TX_DESC_AMSDU_PAD_EN_8198F(txdesc, value)                          \
+	SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
+#define GET_TX_DESC_AMSDU_PAD_EN_8198F(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
+#define SET_TX_DESC_LS_8198F(txdesc, value) SET_TX_DESC_LS(txdesc, value)
+#define GET_TX_DESC_LS_8198F(txdesc) GET_TX_DESC_LS(txdesc)
+#define SET_TX_DESC_HTC_8198F(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
+#define GET_TX_DESC_HTC_8198F(txdesc) GET_TX_DESC_HTC(txdesc)
+#define SET_TX_DESC_BMC_8198F(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
+#define GET_TX_DESC_BMC_8198F(txdesc) GET_TX_DESC_BMC(txdesc)
+#define SET_TX_DESC_OFFSET_8198F(txdesc, value)                                \
+	SET_TX_DESC_OFFSET(txdesc, value)
+#define GET_TX_DESC_OFFSET_8198F(txdesc) GET_TX_DESC_OFFSET(txdesc)
+#define SET_TX_DESC_TXPKTSIZE_8198F(txdesc, value)                             \
+	SET_TX_DESC_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_TXPKTSIZE_8198F(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
+
+/*WORD1*/
+
+#define SET_TX_DESC_HW_AES_IV_8198F(txdesc, value)                             \
+	SET_TX_DESC_HW_AES_IV_V2(txdesc, value)
+#define GET_TX_DESC_HW_AES_IV_8198F(txdesc) GET_TX_DESC_HW_AES_IV_V2(txdesc)
+#define SET_TX_DESC_FTM_EN_8198F(txdesc, value)                                \
+	SET_TX_DESC_FTM_EN_V1(txdesc, value)
+#define GET_TX_DESC_FTM_EN_8198F(txdesc) GET_TX_DESC_FTM_EN_V1(txdesc)
+#define SET_TX_DESC_MOREDATA_8198F(txdesc, value)                              \
+	SET_TX_DESC_MOREDATA(txdesc, value)
+#define GET_TX_DESC_MOREDATA_8198F(txdesc) GET_TX_DESC_MOREDATA(txdesc)
+#define SET_TX_DESC_PKT_OFFSET_8198F(txdesc, value)                            \
+	SET_TX_DESC_PKT_OFFSET(txdesc, value)
+#define GET_TX_DESC_PKT_OFFSET_8198F(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
+#define SET_TX_DESC_SEC_TYPE_8198F(txdesc, value)                              \
+	SET_TX_DESC_SEC_TYPE(txdesc, value)
+#define GET_TX_DESC_SEC_TYPE_8198F(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
+#define SET_TX_DESC_EN_DESC_ID_8198F(txdesc, value)                            \
+	SET_TX_DESC_EN_DESC_ID(txdesc, value)
+#define GET_TX_DESC_EN_DESC_ID_8198F(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
+#define SET_TX_DESC_RATE_ID_8198F(txdesc, value)                               \
+	SET_TX_DESC_RATE_ID(txdesc, value)
+#define GET_TX_DESC_RATE_ID_8198F(txdesc) GET_TX_DESC_RATE_ID(txdesc)
+#define SET_TX_DESC_PIFS_8198F(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
+#define GET_TX_DESC_PIFS_8198F(txdesc) GET_TX_DESC_PIFS(txdesc)
+#define SET_TX_DESC_LSIG_TXOP_EN_8198F(txdesc, value)                          \
+	SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
+#define GET_TX_DESC_LSIG_TXOP_EN_8198F(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
+#define SET_TX_DESC_RD_NAV_EXT_8198F(txdesc, value)                            \
+	SET_TX_DESC_RD_NAV_EXT(txdesc, value)
+#define GET_TX_DESC_RD_NAV_EXT_8198F(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
+#define SET_TX_DESC_QSEL_8198F(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
+#define GET_TX_DESC_QSEL_8198F(txdesc) GET_TX_DESC_QSEL(txdesc)
+#define SET_TX_DESC_SPECIAL_CW_8198F(txdesc, value)                            \
+	SET_TX_DESC_SPECIAL_CW(txdesc, value)
+#define GET_TX_DESC_SPECIAL_CW_8198F(txdesc) GET_TX_DESC_SPECIAL_CW(txdesc)
+#define SET_TX_DESC_MACID_8198F(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
+#define GET_TX_DESC_MACID_8198F(txdesc) GET_TX_DESC_MACID(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_ANTCEL_D_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANTCEL_D_V1(txdesc, value)
+#define GET_TX_DESC_ANTCEL_D_8198F(txdesc) GET_TX_DESC_ANTCEL_D_V1(txdesc)
+#define SET_TX_DESC_ANTSEL_C_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_C_V1(txdesc, value)
+#define GET_TX_DESC_ANTSEL_C_8198F(txdesc) GET_TX_DESC_ANTSEL_C_V1(txdesc)
+#define SET_TX_DESC_BT_NULL_8198F(txdesc, value)                               \
+	SET_TX_DESC_BT_NULL(txdesc, value)
+#define GET_TX_DESC_BT_NULL_8198F(txdesc) GET_TX_DESC_BT_NULL(txdesc)
+#define SET_TX_DESC_AMPDU_DENSITY_8198F(txdesc, value)                         \
+	SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
+#define GET_TX_DESC_AMPDU_DENSITY_8198F(txdesc)                                \
+	GET_TX_DESC_AMPDU_DENSITY(txdesc)
+#define SET_TX_DESC_SPE_RPT_8198F(txdesc, value)                               \
+	SET_TX_DESC_SPE_RPT(txdesc, value)
+#define GET_TX_DESC_SPE_RPT_8198F(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
+#define SET_TX_DESC_RAW_8198F(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
+#define GET_TX_DESC_RAW_8198F(txdesc) GET_TX_DESC_RAW(txdesc)
+#define SET_TX_DESC_MOREFRAG_8198F(txdesc, value)                              \
+	SET_TX_DESC_MOREFRAG(txdesc, value)
+#define GET_TX_DESC_MOREFRAG_8198F(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
+#define SET_TX_DESC_BK_8198F(txdesc, value) SET_TX_DESC_BK(txdesc, value)
+#define GET_TX_DESC_BK_8198F(txdesc) GET_TX_DESC_BK(txdesc)
+#define SET_TX_DESC_NULL_1_8198F(txdesc, value)                                \
+	SET_TX_DESC_NULL_1(txdesc, value)
+#define GET_TX_DESC_NULL_1_8198F(txdesc) GET_TX_DESC_NULL_1(txdesc)
+#define SET_TX_DESC_NULL_0_8198F(txdesc, value)                                \
+	SET_TX_DESC_NULL_0(txdesc, value)
+#define GET_TX_DESC_NULL_0_8198F(txdesc) GET_TX_DESC_NULL_0(txdesc)
+#define SET_TX_DESC_RDG_EN_8198F(txdesc, value)                                \
+	SET_TX_DESC_RDG_EN(txdesc, value)
+#define GET_TX_DESC_RDG_EN_8198F(txdesc) GET_TX_DESC_RDG_EN(txdesc)
+#define SET_TX_DESC_AGG_EN_8198F(txdesc, value)                                \
+	SET_TX_DESC_AGG_EN(txdesc, value)
+#define GET_TX_DESC_AGG_EN_8198F(txdesc) GET_TX_DESC_AGG_EN(txdesc)
+#define SET_TX_DESC_CCA_RTS_8198F(txdesc, value)                               \
+	SET_TX_DESC_CCA_RTS(txdesc, value)
+#define GET_TX_DESC_CCA_RTS_8198F(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
+#define SET_TX_DESC_TRI_FRAME_8198F(txdesc, value)                             \
+	SET_TX_DESC_TRI_FRAME(txdesc, value)
+#define GET_TX_DESC_TRI_FRAME_8198F(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
+#define SET_TX_DESC_P_AID_8198F(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
+#define GET_TX_DESC_P_AID_8198F(txdesc) GET_TX_DESC_P_AID(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME_8198F(txdesc, value)                        \
+	SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
+#define GET_TX_DESC_AMPDU_MAX_TIME_8198F(txdesc)                               \
+	GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
+#define SET_TX_DESC_NDPA_8198F(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
+#define GET_TX_DESC_NDPA_8198F(txdesc) GET_TX_DESC_NDPA(txdesc)
+#define SET_TX_DESC_MAX_AGG_NUM_8198F(txdesc, value)                           \
+	SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
+#define GET_TX_DESC_MAX_AGG_NUM_8198F(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
+#define SET_TX_DESC_USE_MAX_TIME_EN_8198F(txdesc, value)                       \
+	SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
+#define GET_TX_DESC_USE_MAX_TIME_EN_8198F(txdesc)                              \
+	GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
+#define SET_TX_DESC_NAVUSEHDR_8198F(txdesc, value)                             \
+	SET_TX_DESC_NAVUSEHDR(txdesc, value)
+#define GET_TX_DESC_NAVUSEHDR_8198F(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
+#define SET_TX_DESC_CHK_EN_8198F(txdesc, value)                                \
+	SET_TX_DESC_CHK_EN(txdesc, value)
+#define GET_TX_DESC_CHK_EN_8198F(txdesc) GET_TX_DESC_CHK_EN(txdesc)
+#define SET_TX_DESC_HW_RTS_EN_8198F(txdesc, value)                             \
+	SET_TX_DESC_HW_RTS_EN(txdesc, value)
+#define GET_TX_DESC_HW_RTS_EN_8198F(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
+#define SET_TX_DESC_RTSEN_8198F(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
+#define GET_TX_DESC_RTSEN_8198F(txdesc) GET_TX_DESC_RTSEN(txdesc)
+#define SET_TX_DESC_CTS2SELF_8198F(txdesc, value)                              \
+	SET_TX_DESC_CTS2SELF(txdesc, value)
+#define GET_TX_DESC_CTS2SELF_8198F(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
+#define SET_TX_DESC_DISDATAFB_8198F(txdesc, value)                             \
+	SET_TX_DESC_DISDATAFB(txdesc, value)
+#define GET_TX_DESC_DISDATAFB_8198F(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
+#define SET_TX_DESC_DISRTSFB_8198F(txdesc, value)                              \
+	SET_TX_DESC_DISRTSFB(txdesc, value)
+#define GET_TX_DESC_DISRTSFB_8198F(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
+#define SET_TX_DESC_USE_RATE_8198F(txdesc, value)                              \
+	SET_TX_DESC_USE_RATE(txdesc, value)
+#define GET_TX_DESC_USE_RATE_8198F(txdesc) GET_TX_DESC_USE_RATE(txdesc)
+#define SET_TX_DESC_HW_SSN_SEL_8198F(txdesc, value)                            \
+	SET_TX_DESC_HW_SSN_SEL(txdesc, value)
+#define GET_TX_DESC_HW_SSN_SEL_8198F(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
+#define SET_TX_DESC_WHEADER_LEN_8198F(txdesc, value)                           \
+	SET_TX_DESC_WHEADER_LEN(txdesc, value)
+#define GET_TX_DESC_WHEADER_LEN_8198F(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX_8198F(txdesc, value)                         \
+	SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
+#define GET_TX_DESC_PCTS_MASK_IDX_8198F(txdesc)                                \
+	GET_TX_DESC_PCTS_MASK_IDX(txdesc)
+#define SET_TX_DESC_PCTS_EN_8198F(txdesc, value)                               \
+	SET_TX_DESC_PCTS_EN(txdesc, value)
+#define GET_TX_DESC_PCTS_EN_8198F(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
+#define SET_TX_DESC_RTSRATE_8198F(txdesc, value)                               \
+	SET_TX_DESC_RTSRATE(txdesc, value)
+#define GET_TX_DESC_RTSRATE_8198F(txdesc) GET_TX_DESC_RTSRATE(txdesc)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT_8198F(txdesc, value)                      \
+	SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT_8198F(txdesc)                             \
+	GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
+#define SET_TX_DESC_RTY_LMT_EN_8198F(txdesc, value)                            \
+	SET_TX_DESC_RTY_LMT_EN(txdesc, value)
+#define GET_TX_DESC_RTY_LMT_EN_8198F(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8198F(txdesc, value)                   \
+	SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8198F(txdesc)                          \
+	GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8198F(txdesc, value)                  \
+	SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8198F(txdesc)                         \
+	GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_TRY_RATE_8198F(txdesc, value)                              \
+	SET_TX_DESC_TRY_RATE(txdesc, value)
+#define GET_TX_DESC_TRY_RATE_8198F(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
+#define SET_TX_DESC_DATARATE_8198F(txdesc, value)                              \
+	SET_TX_DESC_DATARATE(txdesc, value)
+#define GET_TX_DESC_DATARATE_8198F(txdesc) GET_TX_DESC_DATARATE(txdesc)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED_8198F(txdesc, value)                              \
+	SET_TX_DESC_POLLUTED(txdesc, value)
+#define GET_TX_DESC_POLLUTED_8198F(txdesc) GET_TX_DESC_POLLUTED(txdesc)
+#define SET_TX_DESC_TXPWR_OFSET_8198F(txdesc, value)                           \
+	SET_TX_DESC_TXPWR_OFSET(txdesc, value)
+#define GET_TX_DESC_TXPWR_OFSET_8198F(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
+#define SET_TX_DESC_DROP_ID_8198F(txdesc, value)                               \
+	SET_TX_DESC_DROP_ID(txdesc, value)
+#define GET_TX_DESC_DROP_ID_8198F(txdesc) GET_TX_DESC_DROP_ID(txdesc)
+#define SET_TX_DESC_PORT_ID_8198F(txdesc, value)                               \
+	SET_TX_DESC_PORT_ID(txdesc, value)
+#define GET_TX_DESC_PORT_ID_8198F(txdesc) GET_TX_DESC_PORT_ID(txdesc)
+#define SET_TX_DESC_MULTIPLE_PORT_8198F(txdesc, value)                         \
+	SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
+#define GET_TX_DESC_MULTIPLE_PORT_8198F(txdesc)                                \
+	GET_TX_DESC_MULTIPLE_PORT(txdesc)
+#define SET_TX_DESC_SIGNALING_TAPKT_EN_8198F(txdesc, value)                    \
+	SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN_8198F(txdesc)                           \
+	GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
+#define SET_TX_DESC_RTS_SC_8198F(txdesc, value)                                \
+	SET_TX_DESC_RTS_SC(txdesc, value)
+#define GET_TX_DESC_RTS_SC_8198F(txdesc) GET_TX_DESC_RTS_SC(txdesc)
+#define SET_TX_DESC_RTS_SHORT_8198F(txdesc, value)                             \
+	SET_TX_DESC_RTS_SHORT(txdesc, value)
+#define GET_TX_DESC_RTS_SHORT_8198F(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
+#define SET_TX_DESC_VCS_STBC_8198F(txdesc, value)                              \
+	SET_TX_DESC_VCS_STBC(txdesc, value)
+#define GET_TX_DESC_VCS_STBC_8198F(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
+#define SET_TX_DESC_DATA_STBC_8198F(txdesc, value)                             \
+	SET_TX_DESC_DATA_STBC(txdesc, value)
+#define GET_TX_DESC_DATA_STBC_8198F(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
+#define SET_TX_DESC_DATA_LDPC_8198F(txdesc, value)                             \
+	SET_TX_DESC_DATA_LDPC(txdesc, value)
+#define GET_TX_DESC_DATA_LDPC_8198F(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
+#define SET_TX_DESC_DATA_BW_8198F(txdesc, value)                               \
+	SET_TX_DESC_DATA_BW(txdesc, value)
+#define GET_TX_DESC_DATA_BW_8198F(txdesc) GET_TX_DESC_DATA_BW(txdesc)
+#define SET_TX_DESC_DATA_SHORT_8198F(txdesc, value)                            \
+	SET_TX_DESC_DATA_SHORT(txdesc, value)
+#define GET_TX_DESC_DATA_SHORT_8198F(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
+#define SET_TX_DESC_DATA_SC_8198F(txdesc, value)                               \
+	SET_TX_DESC_DATA_SC(txdesc, value)
+#define GET_TX_DESC_DATA_SC_8198F(txdesc) GET_TX_DESC_DATA_SC(txdesc)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANT_MAPD_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPD_V1(txdesc, value)
+#define GET_TX_DESC_ANT_MAPD_8198F(txdesc) GET_TX_DESC_ANT_MAPD_V1(txdesc)
+#define SET_TX_DESC_ANT_MAPC_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPC_V1(txdesc, value)
+#define GET_TX_DESC_ANT_MAPC_8198F(txdesc) GET_TX_DESC_ANT_MAPC_V1(txdesc)
+#define SET_TX_DESC_ANT_MAPB_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPB_V1(txdesc, value)
+#define GET_TX_DESC_ANT_MAPB_8198F(txdesc) GET_TX_DESC_ANT_MAPB_V1(txdesc)
+#define SET_TX_DESC_ANT_MAPA_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPA_V1(txdesc, value)
+#define GET_TX_DESC_ANT_MAPA_8198F(txdesc) GET_TX_DESC_ANT_MAPA_V1(txdesc)
+#define SET_TX_DESC_ANTSEL_B_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_B_V1(txdesc, value)
+#define GET_TX_DESC_ANTSEL_B_8198F(txdesc) GET_TX_DESC_ANTSEL_B_V1(txdesc)
+#define SET_TX_DESC_ANTSEL_A_8198F(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_A_V1(txdesc, value)
+#define GET_TX_DESC_ANTSEL_A_8198F(txdesc) GET_TX_DESC_ANTSEL_A_V1(txdesc)
+#define SET_TX_DESC_MBSSID_8198F(txdesc, value)                                \
+	SET_TX_DESC_MBSSID(txdesc, value)
+#define GET_TX_DESC_MBSSID_8198F(txdesc) GET_TX_DESC_MBSSID(txdesc)
+#define SET_TX_DESC_SWPS_SEQ_8198F(txdesc, value)                              \
+	SET_TX_DESC_SWPS_SEQ(txdesc, value)
+#define GET_TX_DESC_SWPS_SEQ_8198F(txdesc) GET_TX_DESC_SWPS_SEQ(txdesc)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_8198F(txdesc, value)                         \
+	SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_8198F(txdesc)                                \
+	GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
+#define SET_TX_DESC_FINAL_DATA_RATE_8198F(txdesc, value)                       \
+	SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
+#define GET_TX_DESC_FINAL_DATA_RATE_8198F(txdesc)                              \
+	GET_TX_DESC_FINAL_DATA_RATE(txdesc)
+#define SET_TX_DESC_NTX_MAP_8198F(txdesc, value)                               \
+	SET_TX_DESC_NTX_MAP(txdesc, value)
+#define GET_TX_DESC_NTX_MAP_8198F(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
+#define SET_TX_DESC_ANTSEL_EN_8198F(txdesc, value)                             \
+	SET_TX_DESC_ANTSEL_EN(txdesc, value)
+#define GET_TX_DESC_ANTSEL_EN_8198F(txdesc) GET_TX_DESC_ANTSEL_EN(txdesc)
+#define SET_TX_DESC_MBSSID_EX_8198F(txdesc, value)                             \
+	SET_TX_DESC_MBSSID_EX(txdesc, value)
+#define GET_TX_DESC_MBSSID_EX_8198F(txdesc) GET_TX_DESC_MBSSID_EX(txdesc)
+#define SET_TX_DESC_TX_BUFF_SIZE_8198F(txdesc, value)                          \
+	SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
+#define GET_TX_DESC_TX_BUFF_SIZE_8198F(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
+#define SET_TX_DESC_TXDESC_CHECKSUM_8198F(txdesc, value)                       \
+	SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_8198F(txdesc)                              \
+	GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
+#define SET_TX_DESC_TIMESTAMP_8198F(txdesc, value)                             \
+	SET_TX_DESC_TIMESTAMP(txdesc, value)
+#define GET_TX_DESC_TIMESTAMP_8198F(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP_8198F(txdesc, value)                             \
+	SET_TX_DESC_TXWIFI_CP(txdesc, value)
+#define GET_TX_DESC_TXWIFI_CP_8198F(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
+#define SET_TX_DESC_MAC_CP_8198F(txdesc, value)                                \
+	SET_TX_DESC_MAC_CP(txdesc, value)
+#define GET_TX_DESC_MAC_CP_8198F(txdesc) GET_TX_DESC_MAC_CP(txdesc)
+#define SET_TX_DESC_STW_PKTRE_DIS_8198F(txdesc, value)                         \
+	SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_PKTRE_DIS_8198F(txdesc)                                \
+	GET_TX_DESC_STW_PKTRE_DIS(txdesc)
+#define SET_TX_DESC_STW_RB_DIS_8198F(txdesc, value)                            \
+	SET_TX_DESC_STW_RB_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RB_DIS_8198F(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
+#define SET_TX_DESC_STW_RATE_DIS_8198F(txdesc, value)                          \
+	SET_TX_DESC_STW_RATE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RATE_DIS_8198F(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
+#define SET_TX_DESC_STW_ANT_DIS_8198F(txdesc, value)                           \
+	SET_TX_DESC_STW_ANT_DIS(txdesc, value)
+#define GET_TX_DESC_STW_ANT_DIS_8198F(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
+#define SET_TX_DESC_STW_EN_8198F(txdesc, value)                                \
+	SET_TX_DESC_STW_EN(txdesc, value)
+#define GET_TX_DESC_STW_EN_8198F(txdesc) GET_TX_DESC_STW_EN(txdesc)
+#define SET_TX_DESC_SMH_EN_8198F(txdesc, value)                                \
+	SET_TX_DESC_SMH_EN(txdesc, value)
+#define GET_TX_DESC_SMH_EN_8198F(txdesc) GET_TX_DESC_SMH_EN(txdesc)
+#define SET_TX_DESC_TAILPAGE_L_8198F(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_L(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_L_8198F(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
+#define SET_TX_DESC_SDIO_DMASEQ_8198F(txdesc, value)                           \
+	SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
+#define GET_TX_DESC_SDIO_DMASEQ_8198F(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_L_8198F(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_L_8198F(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
+#define SET_TX_DESC_EN_HWSEQ_8198F(txdesc, value)                              \
+	SET_TX_DESC_EN_HWSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWSEQ_8198F(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
+#define SET_TX_DESC_EN_HWEXSEQ_8198F(txdesc, value)                            \
+	SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWEXSEQ_8198F(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
+#define SET_TX_DESC_DATA_RC_8198F(txdesc, value)                               \
+	SET_TX_DESC_DATA_RC(txdesc, value)
+#define GET_TX_DESC_DATA_RC_8198F(txdesc) GET_TX_DESC_DATA_RC(txdesc)
+#define SET_TX_DESC_BAR_RTY_TH_8198F(txdesc, value)                            \
+	SET_TX_DESC_BAR_RTY_TH(txdesc, value)
+#define GET_TX_DESC_BAR_RTY_TH_8198F(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
+#define SET_TX_DESC_RTS_RC_8198F(txdesc, value)                                \
+	SET_TX_DESC_RTS_RC(txdesc, value)
+#define GET_TX_DESC_RTS_RC_8198F(txdesc) GET_TX_DESC_RTS_RC(txdesc)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H_8198F(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_H(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_H_8198F(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_H_8198F(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_H_8198F(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
+#define SET_TX_DESC_SW_SEQ_8198F(txdesc, value)                                \
+	SET_TX_DESC_SW_SEQ(txdesc, value)
+#define GET_TX_DESC_SW_SEQ_8198F(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
+#define SET_TX_DESC_TXBF_PATH_8198F(txdesc, value)                             \
+	SET_TX_DESC_TXBF_PATH(txdesc, value)
+#define GET_TX_DESC_TXBF_PATH_8198F(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
+#define SET_TX_DESC_PADDING_LEN_8198F(txdesc, value)                           \
+	SET_TX_DESC_PADDING_LEN(txdesc, value)
+#define GET_TX_DESC_PADDING_LEN_8198F(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8198F(txdesc, value)                   \
+	SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8198F(txdesc)                          \
+	GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
+
+/*WORD10*/
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ_8822C(txdesc, value)                            \
+	SET_TX_DESC_DISQSELSEQ(txdesc, value)
+#define GET_TX_DESC_DISQSELSEQ_8822C(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
+#define SET_TX_DESC_GF_8822C(txdesc, value) SET_TX_DESC_GF(txdesc, value)
+#define GET_TX_DESC_GF_8822C(txdesc) GET_TX_DESC_GF(txdesc)
+#define SET_TX_DESC_NO_ACM_8822C(txdesc, value)                                \
+	SET_TX_DESC_NO_ACM(txdesc, value)
+#define GET_TX_DESC_NO_ACM_8822C(txdesc) GET_TX_DESC_NO_ACM(txdesc)
+#define SET_TX_DESC_BCNPKT_TSF_CTRL_8822C(txdesc, value)                       \
+	SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
+#define GET_TX_DESC_BCNPKT_TSF_CTRL_8822C(txdesc)                              \
+	GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
+#define SET_TX_DESC_AMSDU_PAD_EN_8822C(txdesc, value)                          \
+	SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
+#define GET_TX_DESC_AMSDU_PAD_EN_8822C(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
+#define SET_TX_DESC_LS_8822C(txdesc, value) SET_TX_DESC_LS(txdesc, value)
+#define GET_TX_DESC_LS_8822C(txdesc) GET_TX_DESC_LS(txdesc)
+#define SET_TX_DESC_HTC_8822C(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
+#define GET_TX_DESC_HTC_8822C(txdesc) GET_TX_DESC_HTC(txdesc)
+#define SET_TX_DESC_BMC_8822C(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
+#define GET_TX_DESC_BMC_8822C(txdesc) GET_TX_DESC_BMC(txdesc)
+#define SET_TX_DESC_OFFSET_8822C(txdesc, value)                                \
+	SET_TX_DESC_OFFSET(txdesc, value)
+#define GET_TX_DESC_OFFSET_8822C(txdesc) GET_TX_DESC_OFFSET(txdesc)
+#define SET_TX_DESC_TXPKTSIZE_8822C(txdesc, value)                             \
+	SET_TX_DESC_TXPKTSIZE(txdesc, value)
+#define GET_TX_DESC_TXPKTSIZE_8822C(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
+
+/*WORD1*/
+
+#define SET_TX_DESC_MOREDATA_8822C(txdesc, value)                              \
+	SET_TX_DESC_MOREDATA(txdesc, value)
+#define GET_TX_DESC_MOREDATA_8822C(txdesc) GET_TX_DESC_MOREDATA(txdesc)
+#define SET_TX_DESC_PKT_OFFSET_8822C(txdesc, value)                            \
+	SET_TX_DESC_PKT_OFFSET(txdesc, value)
+#define GET_TX_DESC_PKT_OFFSET_8822C(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
+#define SET_TX_DESC_SEC_TYPE_8822C(txdesc, value)                              \
+	SET_TX_DESC_SEC_TYPE(txdesc, value)
+#define GET_TX_DESC_SEC_TYPE_8822C(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
+#define SET_TX_DESC_EN_DESC_ID_8822C(txdesc, value)                            \
+	SET_TX_DESC_EN_DESC_ID(txdesc, value)
+#define GET_TX_DESC_EN_DESC_ID_8822C(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
+#define SET_TX_DESC_RATE_ID_8822C(txdesc, value)                               \
+	SET_TX_DESC_RATE_ID(txdesc, value)
+#define GET_TX_DESC_RATE_ID_8822C(txdesc) GET_TX_DESC_RATE_ID(txdesc)
+#define SET_TX_DESC_PIFS_8822C(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
+#define GET_TX_DESC_PIFS_8822C(txdesc) GET_TX_DESC_PIFS(txdesc)
+#define SET_TX_DESC_LSIG_TXOP_EN_8822C(txdesc, value)                          \
+	SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
+#define GET_TX_DESC_LSIG_TXOP_EN_8822C(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
+#define SET_TX_DESC_RD_NAV_EXT_8822C(txdesc, value)                            \
+	SET_TX_DESC_RD_NAV_EXT(txdesc, value)
+#define GET_TX_DESC_RD_NAV_EXT_8822C(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
+#define SET_TX_DESC_QSEL_8822C(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
+#define GET_TX_DESC_QSEL_8822C(txdesc) GET_TX_DESC_QSEL(txdesc)
+#define SET_TX_DESC_MACID_8822C(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
+#define GET_TX_DESC_MACID_8822C(txdesc) GET_TX_DESC_MACID(txdesc)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_HW_AES_IV_8822C(txdesc, value)                             \
+	SET_TX_DESC_HW_AES_IV(txdesc, value)
+#define GET_TX_DESC_HW_AES_IV_8822C(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
+#define SET_TX_DESC_FTM_EN_8822C(txdesc, value)                                \
+	SET_TX_DESC_FTM_EN(txdesc, value)
+#define GET_TX_DESC_FTM_EN_8822C(txdesc) GET_TX_DESC_FTM_EN(txdesc)
+#define SET_TX_DESC_G_ID_8822C(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
+#define GET_TX_DESC_G_ID_8822C(txdesc) GET_TX_DESC_G_ID(txdesc)
+#define SET_TX_DESC_BT_NULL_8822C(txdesc, value)                               \
+	SET_TX_DESC_BT_NULL(txdesc, value)
+#define GET_TX_DESC_BT_NULL_8822C(txdesc) GET_TX_DESC_BT_NULL(txdesc)
+#define SET_TX_DESC_AMPDU_DENSITY_8822C(txdesc, value)                         \
+	SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
+#define GET_TX_DESC_AMPDU_DENSITY_8822C(txdesc)                                \
+	GET_TX_DESC_AMPDU_DENSITY(txdesc)
+#define SET_TX_DESC_SPE_RPT_8822C(txdesc, value)                               \
+	SET_TX_DESC_SPE_RPT(txdesc, value)
+#define GET_TX_DESC_SPE_RPT_8822C(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
+#define SET_TX_DESC_RAW_8822C(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
+#define GET_TX_DESC_RAW_8822C(txdesc) GET_TX_DESC_RAW(txdesc)
+#define SET_TX_DESC_MOREFRAG_8822C(txdesc, value)                              \
+	SET_TX_DESC_MOREFRAG(txdesc, value)
+#define GET_TX_DESC_MOREFRAG_8822C(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
+#define SET_TX_DESC_BK_8822C(txdesc, value) SET_TX_DESC_BK(txdesc, value)
+#define GET_TX_DESC_BK_8822C(txdesc) GET_TX_DESC_BK(txdesc)
+#define SET_TX_DESC_NULL_1_8822C(txdesc, value)                                \
+	SET_TX_DESC_NULL_1(txdesc, value)
+#define GET_TX_DESC_NULL_1_8822C(txdesc) GET_TX_DESC_NULL_1(txdesc)
+#define SET_TX_DESC_NULL_0_8822C(txdesc, value)                                \
+	SET_TX_DESC_NULL_0(txdesc, value)
+#define GET_TX_DESC_NULL_0_8822C(txdesc) GET_TX_DESC_NULL_0(txdesc)
+#define SET_TX_DESC_RDG_EN_8822C(txdesc, value)                                \
+	SET_TX_DESC_RDG_EN(txdesc, value)
+#define GET_TX_DESC_RDG_EN_8822C(txdesc) GET_TX_DESC_RDG_EN(txdesc)
+#define SET_TX_DESC_AGG_EN_8822C(txdesc, value)                                \
+	SET_TX_DESC_AGG_EN(txdesc, value)
+#define GET_TX_DESC_AGG_EN_8822C(txdesc) GET_TX_DESC_AGG_EN(txdesc)
+#define SET_TX_DESC_CCA_RTS_8822C(txdesc, value)                               \
+	SET_TX_DESC_CCA_RTS(txdesc, value)
+#define GET_TX_DESC_CCA_RTS_8822C(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
+#define SET_TX_DESC_TRI_FRAME_8822C(txdesc, value)                             \
+	SET_TX_DESC_TRI_FRAME(txdesc, value)
+#define GET_TX_DESC_TRI_FRAME_8822C(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
+#define SET_TX_DESC_P_AID_8822C(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
+#define GET_TX_DESC_P_AID_8822C(txdesc) GET_TX_DESC_P_AID(txdesc)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME_8822C(txdesc, value)                        \
+	SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
+#define GET_TX_DESC_AMPDU_MAX_TIME_8822C(txdesc)                               \
+	GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
+#define SET_TX_DESC_NDPA_8822C(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
+#define GET_TX_DESC_NDPA_8822C(txdesc) GET_TX_DESC_NDPA(txdesc)
+#define SET_TX_DESC_MAX_AGG_NUM_8822C(txdesc, value)                           \
+	SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
+#define GET_TX_DESC_MAX_AGG_NUM_8822C(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
+#define SET_TX_DESC_USE_MAX_TIME_EN_8822C(txdesc, value)                       \
+	SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
+#define GET_TX_DESC_USE_MAX_TIME_EN_8822C(txdesc)                              \
+	GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
+#define SET_TX_DESC_NAVUSEHDR_8822C(txdesc, value)                             \
+	SET_TX_DESC_NAVUSEHDR(txdesc, value)
+#define GET_TX_DESC_NAVUSEHDR_8822C(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
+#define SET_TX_DESC_CHK_EN_8822C(txdesc, value)                                \
+	SET_TX_DESC_CHK_EN(txdesc, value)
+#define GET_TX_DESC_CHK_EN_8822C(txdesc) GET_TX_DESC_CHK_EN(txdesc)
+#define SET_TX_DESC_HW_RTS_EN_8822C(txdesc, value)                             \
+	SET_TX_DESC_HW_RTS_EN(txdesc, value)
+#define GET_TX_DESC_HW_RTS_EN_8822C(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
+#define SET_TX_DESC_RTSEN_8822C(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
+#define GET_TX_DESC_RTSEN_8822C(txdesc) GET_TX_DESC_RTSEN(txdesc)
+#define SET_TX_DESC_CTS2SELF_8822C(txdesc, value)                              \
+	SET_TX_DESC_CTS2SELF(txdesc, value)
+#define GET_TX_DESC_CTS2SELF_8822C(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
+#define SET_TX_DESC_DISDATAFB_8822C(txdesc, value)                             \
+	SET_TX_DESC_DISDATAFB(txdesc, value)
+#define GET_TX_DESC_DISDATAFB_8822C(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
+#define SET_TX_DESC_DISRTSFB_8822C(txdesc, value)                              \
+	SET_TX_DESC_DISRTSFB(txdesc, value)
+#define GET_TX_DESC_DISRTSFB_8822C(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
+#define SET_TX_DESC_USE_RATE_8822C(txdesc, value)                              \
+	SET_TX_DESC_USE_RATE(txdesc, value)
+#define GET_TX_DESC_USE_RATE_8822C(txdesc) GET_TX_DESC_USE_RATE(txdesc)
+#define SET_TX_DESC_HW_SSN_SEL_8822C(txdesc, value)                            \
+	SET_TX_DESC_HW_SSN_SEL(txdesc, value)
+#define GET_TX_DESC_HW_SSN_SEL_8822C(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
+#define SET_TX_DESC_WHEADER_LEN_8822C(txdesc, value)                           \
+	SET_TX_DESC_WHEADER_LEN(txdesc, value)
+#define GET_TX_DESC_WHEADER_LEN_8822C(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX_8822C(txdesc, value)                         \
+	SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
+#define GET_TX_DESC_PCTS_MASK_IDX_8822C(txdesc)                                \
+	GET_TX_DESC_PCTS_MASK_IDX(txdesc)
+#define SET_TX_DESC_PCTS_EN_8822C(txdesc, value)                               \
+	SET_TX_DESC_PCTS_EN(txdesc, value)
+#define GET_TX_DESC_PCTS_EN_8822C(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
+#define SET_TX_DESC_RTSRATE_8822C(txdesc, value)                               \
+	SET_TX_DESC_RTSRATE(txdesc, value)
+#define GET_TX_DESC_RTSRATE_8822C(txdesc) GET_TX_DESC_RTSRATE(txdesc)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT_8822C(txdesc, value)                      \
+	SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT_8822C(txdesc)                             \
+	GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
+#define SET_TX_DESC_RTY_LMT_EN_8822C(txdesc, value)                            \
+	SET_TX_DESC_RTY_LMT_EN(txdesc, value)
+#define GET_TX_DESC_RTY_LMT_EN_8822C(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8822C(txdesc, value)                   \
+	SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8822C(txdesc)                          \
+	GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822C(txdesc, value)                  \
+	SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8822C(txdesc)                         \
+	GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
+#define SET_TX_DESC_TRY_RATE_8822C(txdesc, value)                              \
+	SET_TX_DESC_TRY_RATE(txdesc, value)
+#define GET_TX_DESC_TRY_RATE_8822C(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
+#define SET_TX_DESC_DATARATE_8822C(txdesc, value)                              \
+	SET_TX_DESC_DATARATE(txdesc, value)
+#define GET_TX_DESC_DATARATE_8822C(txdesc) GET_TX_DESC_DATARATE(txdesc)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED_8822C(txdesc, value)                              \
+	SET_TX_DESC_POLLUTED(txdesc, value)
+#define GET_TX_DESC_POLLUTED_8822C(txdesc) GET_TX_DESC_POLLUTED(txdesc)
+#define SET_TX_DESC_ANTSEL_EN_8822C(txdesc, value)                             \
+	SET_TX_DESC_ANTSEL_EN_V1(txdesc, value)
+#define GET_TX_DESC_ANTSEL_EN_8822C(txdesc) GET_TX_DESC_ANTSEL_EN_V1(txdesc)
+#define SET_TX_DESC_TXPWR_OFSET_TYPE_8822C(txdesc, value)                      \
+	SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc, value)
+#define GET_TX_DESC_TXPWR_OFSET_TYPE_8822C(txdesc)                             \
+	GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc)
+#define SET_TX_DESC_TX_ANT_8822C(txdesc, value)                                \
+	SET_TX_DESC_TX_ANT(txdesc, value)
+#define GET_TX_DESC_TX_ANT_8822C(txdesc) GET_TX_DESC_TX_ANT(txdesc)
+#define SET_TX_DESC_PORT_ID_8822C(txdesc, value)                               \
+	SET_TX_DESC_PORT_ID(txdesc, value)
+#define GET_TX_DESC_PORT_ID_8822C(txdesc) GET_TX_DESC_PORT_ID(txdesc)
+#define SET_TX_DESC_MULTIPLE_PORT_8822C(txdesc, value)                         \
+	SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
+#define GET_TX_DESC_MULTIPLE_PORT_8822C(txdesc)                                \
+	GET_TX_DESC_MULTIPLE_PORT(txdesc)
+#define SET_TX_DESC_SIGNALING_TAPKT_EN_8822C(txdesc, value)                    \
+	SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN_8822C(txdesc)                           \
+	GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
+#define SET_TX_DESC_SIGNALING_TA_PKT_SC_8822C(txdesc, value)                   \
+	SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)
+#define GET_TX_DESC_SIGNALING_TA_PKT_SC_8822C(txdesc)                          \
+	GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)
+#define SET_TX_DESC_RTS_SHORT_8822C(txdesc, value)                             \
+	SET_TX_DESC_RTS_SHORT(txdesc, value)
+#define GET_TX_DESC_RTS_SHORT_8822C(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
+#define SET_TX_DESC_VCS_STBC_8822C(txdesc, value)                              \
+	SET_TX_DESC_VCS_STBC(txdesc, value)
+#define GET_TX_DESC_VCS_STBC_8822C(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
+#define SET_TX_DESC_DATA_STBC_8822C(txdesc, value)                             \
+	SET_TX_DESC_DATA_STBC(txdesc, value)
+#define GET_TX_DESC_DATA_STBC_8822C(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
+#define SET_TX_DESC_DATA_LDPC_8822C(txdesc, value)                             \
+	SET_TX_DESC_DATA_LDPC(txdesc, value)
+#define GET_TX_DESC_DATA_LDPC_8822C(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
+#define SET_TX_DESC_DATA_BW_8822C(txdesc, value)                               \
+	SET_TX_DESC_DATA_BW(txdesc, value)
+#define GET_TX_DESC_DATA_BW_8822C(txdesc) GET_TX_DESC_DATA_BW(txdesc)
+#define SET_TX_DESC_DATA_SHORT_8822C(txdesc, value)                            \
+	SET_TX_DESC_DATA_SHORT(txdesc, value)
+#define GET_TX_DESC_DATA_SHORT_8822C(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
+#define SET_TX_DESC_DATA_SC_8822C(txdesc, value)                               \
+	SET_TX_DESC_DATA_SC(txdesc, value)
+#define GET_TX_DESC_DATA_SC_8822C(txdesc) GET_TX_DESC_DATA_SC(txdesc)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANTSEL_D_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_D(txdesc, value)
+#define GET_TX_DESC_ANTSEL_D_8822C(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
+#define SET_TX_DESC_ANT_MAPD_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPD(txdesc, value)
+#define GET_TX_DESC_ANT_MAPD_8822C(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
+#define SET_TX_DESC_ANT_MAPC_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPC(txdesc, value)
+#define GET_TX_DESC_ANT_MAPC_8822C(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
+#define SET_TX_DESC_ANT_MAPB_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPB(txdesc, value)
+#define GET_TX_DESC_ANT_MAPB_8822C(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
+#define SET_TX_DESC_ANT_MAPA_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANT_MAPA(txdesc, value)
+#define GET_TX_DESC_ANT_MAPA_8822C(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
+#define SET_TX_DESC_ANTSEL_C_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_C(txdesc, value)
+#define GET_TX_DESC_ANTSEL_C_8822C(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
+#define SET_TX_DESC_ANTSEL_B_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_B(txdesc, value)
+#define GET_TX_DESC_ANTSEL_B_8822C(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
+#define SET_TX_DESC_ANTSEL_A_8822C(txdesc, value)                              \
+	SET_TX_DESC_ANTSEL_A(txdesc, value)
+#define GET_TX_DESC_ANTSEL_A_8822C(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
+#define SET_TX_DESC_MBSSID_8822C(txdesc, value)                                \
+	SET_TX_DESC_MBSSID(txdesc, value)
+#define GET_TX_DESC_MBSSID_8822C(txdesc) GET_TX_DESC_MBSSID(txdesc)
+#define SET_TX_DESC_SW_DEFINE_8822C(txdesc, value)                             \
+	SET_TX_DESC_SW_DEFINE(txdesc, value)
+#define GET_TX_DESC_SW_DEFINE_8822C(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_8822C(txdesc, value)                         \
+	SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_8822C(txdesc)                                \
+	GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
+#define SET_TX_DESC_FINAL_DATA_RATE_8822C(txdesc, value)                       \
+	SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
+#define GET_TX_DESC_FINAL_DATA_RATE_8822C(txdesc)                              \
+	GET_TX_DESC_FINAL_DATA_RATE(txdesc)
+#define SET_TX_DESC_NTX_MAP_8822C(txdesc, value)                               \
+	SET_TX_DESC_NTX_MAP(txdesc, value)
+#define GET_TX_DESC_NTX_MAP_8822C(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
+#define SET_TX_DESC_TX_BUFF_SIZE_8822C(txdesc, value)                          \
+	SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
+#define GET_TX_DESC_TX_BUFF_SIZE_8822C(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
+#define SET_TX_DESC_TXDESC_CHECKSUM_8822C(txdesc, value)                       \
+	SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_8822C(txdesc)                              \
+	GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
+#define SET_TX_DESC_TIMESTAMP_8822C(txdesc, value)                             \
+	SET_TX_DESC_TIMESTAMP(txdesc, value)
+#define GET_TX_DESC_TIMESTAMP_8822C(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP_8822C(txdesc, value)                             \
+	SET_TX_DESC_TXWIFI_CP(txdesc, value)
+#define GET_TX_DESC_TXWIFI_CP_8822C(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
+#define SET_TX_DESC_MAC_CP_8822C(txdesc, value)                                \
+	SET_TX_DESC_MAC_CP(txdesc, value)
+#define GET_TX_DESC_MAC_CP_8822C(txdesc) GET_TX_DESC_MAC_CP(txdesc)
+#define SET_TX_DESC_STW_PKTRE_DIS_8822C(txdesc, value)                         \
+	SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_PKTRE_DIS_8822C(txdesc)                                \
+	GET_TX_DESC_STW_PKTRE_DIS(txdesc)
+#define SET_TX_DESC_STW_RB_DIS_8822C(txdesc, value)                            \
+	SET_TX_DESC_STW_RB_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RB_DIS_8822C(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
+#define SET_TX_DESC_STW_RATE_DIS_8822C(txdesc, value)                          \
+	SET_TX_DESC_STW_RATE_DIS(txdesc, value)
+#define GET_TX_DESC_STW_RATE_DIS_8822C(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
+#define SET_TX_DESC_STW_ANT_DIS_8822C(txdesc, value)                           \
+	SET_TX_DESC_STW_ANT_DIS(txdesc, value)
+#define GET_TX_DESC_STW_ANT_DIS_8822C(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
+#define SET_TX_DESC_STW_EN_8822C(txdesc, value)                                \
+	SET_TX_DESC_STW_EN(txdesc, value)
+#define GET_TX_DESC_STW_EN_8822C(txdesc) GET_TX_DESC_STW_EN(txdesc)
+#define SET_TX_DESC_SMH_EN_8822C(txdesc, value)                                \
+	SET_TX_DESC_SMH_EN(txdesc, value)
+#define GET_TX_DESC_SMH_EN_8822C(txdesc) GET_TX_DESC_SMH_EN(txdesc)
+#define SET_TX_DESC_TAILPAGE_L_8822C(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_L(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_L_8822C(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
+#define SET_TX_DESC_SDIO_DMASEQ_8822C(txdesc, value)                           \
+	SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
+#define GET_TX_DESC_SDIO_DMASEQ_8822C(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_L_8822C(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_L_8822C(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
+#define SET_TX_DESC_EN_HWSEQ_8822C(txdesc, value)                              \
+	SET_TX_DESC_EN_HWSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWSEQ_8822C(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
+#define SET_TX_DESC_EN_HWEXSEQ_8822C(txdesc, value)                            \
+	SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
+#define GET_TX_DESC_EN_HWEXSEQ_8822C(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
+#define SET_TX_DESC_DATA_RC_8822C(txdesc, value)                               \
+	SET_TX_DESC_DATA_RC(txdesc, value)
+#define GET_TX_DESC_DATA_RC_8822C(txdesc) GET_TX_DESC_DATA_RC(txdesc)
+#define SET_TX_DESC_BAR_RTY_TH_8822C(txdesc, value)                            \
+	SET_TX_DESC_BAR_RTY_TH(txdesc, value)
+#define GET_TX_DESC_BAR_RTY_TH_8822C(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
+#define SET_TX_DESC_RTS_RC_8822C(txdesc, value)                                \
+	SET_TX_DESC_RTS_RC(txdesc, value)
+#define GET_TX_DESC_RTS_RC_8822C(txdesc) GET_TX_DESC_RTS_RC(txdesc)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H_8822C(txdesc, value)                            \
+	SET_TX_DESC_TAILPAGE_H(txdesc, value)
+#define GET_TX_DESC_TAILPAGE_H_8822C(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
+#define SET_TX_DESC_NEXTHEADPAGE_H_8822C(txdesc, value)                        \
+	SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
+#define GET_TX_DESC_NEXTHEADPAGE_H_8822C(txdesc)                               \
+	GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
+#define SET_TX_DESC_SW_SEQ_8822C(txdesc, value)                                \
+	SET_TX_DESC_SW_SEQ(txdesc, value)
+#define GET_TX_DESC_SW_SEQ_8822C(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
+#define SET_TX_DESC_TXBF_PATH_8822C(txdesc, value)                             \
+	SET_TX_DESC_TXBF_PATH(txdesc, value)
+#define GET_TX_DESC_TXBF_PATH_8822C(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
+#define SET_TX_DESC_PADDING_LEN_8822C(txdesc, value)                           \
+	SET_TX_DESC_PADDING_LEN(txdesc, value)
+#define GET_TX_DESC_PADDING_LEN_8822C(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8822C(txdesc, value)                   \
+	SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8822C(txdesc)                          \
+	GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
+
+/*WORD10*/
+
+#define SET_TX_DESC_MU_DATARATE_8822C(txdesc, value)                           \
+	SET_TX_DESC_MU_DATARATE(txdesc, value)
+#define GET_TX_DESC_MU_DATARATE_8822C(txdesc) GET_TX_DESC_MU_DATARATE(txdesc)
+#define SET_TX_DESC_MU_RC_8822C(txdesc, value) SET_TX_DESC_MU_RC(txdesc, value)
+#define GET_TX_DESC_MU_RC_8822C(txdesc) GET_TX_DESC_MU_RC(txdesc)
+#define SET_TX_DESC_SND_PKT_SEL_8822C(txdesc, value)                           \
+	SET_TX_DESC_SND_PKT_SEL(txdesc, value)
+#define GET_TX_DESC_SND_PKT_SEL_8822C(txdesc) GET_TX_DESC_SND_PKT_SEL(txdesc)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_ap.h
new file mode 100644
index 000000000000..a6d215fcedaa
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_ap.h
@@ -0,0 +1,1005 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_IE_AP_H_
+#define _HALMAC_TX_DESC_IE_AP_H_
+#if (HALMAC_8814B_SUPPORT)
+
+#define IE0_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 31)
+#define IE0_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE0_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE0_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 30)
+#define IE0_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE0_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE0_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 24)
+#define IE0_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE0_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE0_GET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie)                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 19)
+#define IE0_SET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 19)
+#define IE0_SET_TX_DESC_ARFR_TABLE_SEL_NO_CLR(txdesc_ie, value)                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 19)
+#define IE0_GET_TX_DESC_ARFR_HT_EN(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 18)
+#define IE0_SET_TX_DESC_ARFR_HT_EN(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 18)
+#define IE0_SET_TX_DESC_ARFR_HT_EN_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 18)
+#define IE0_GET_TX_DESC_ARFR_OFDM_EN(txdesc_ie)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 17)
+#define IE0_SET_TX_DESC_ARFR_OFDM_EN(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 17)
+#define IE0_SET_TX_DESC_ARFR_OFDM_EN_NO_CLR(txdesc_ie, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 17)
+#define IE0_GET_TX_DESC_ARFR_CCK_EN(txdesc_ie)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 16)
+#define IE0_SET_TX_DESC_ARFR_CCK_EN(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 16)
+#define IE0_SET_TX_DESC_ARFR_CCK_EN_NO_CLR(txdesc_ie, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 16)
+#define IE0_GET_TX_DESC_HW_RTS_EN(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 9)
+#define IE0_SET_TX_DESC_HW_RTS_EN(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
+#define IE0_SET_TX_DESC_HW_RTS_EN_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
+#define IE0_GET_TX_DESC_RTS_EN(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 8)
+#define IE0_SET_TX_DESC_RTS_EN(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
+#define IE0_SET_TX_DESC_RTS_EN_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
+#define IE0_GET_TX_DESC_CTS2SELF(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 7)
+#define IE0_SET_TX_DESC_CTS2SELF(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
+#define IE0_SET_TX_DESC_CTS2SELF_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
+#define IE0_GET_TX_DESC_RTY_LMT_EN(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 6)
+#define IE0_SET_TX_DESC_RTY_LMT_EN(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
+#define IE0_SET_TX_DESC_RTY_LMT_EN_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
+#define IE0_GET_TX_DESC_RTS_SHORT(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 5)
+#define IE0_SET_TX_DESC_RTS_SHORT(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
+#define IE0_SET_TX_DESC_RTS_SHORT_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
+#define IE0_GET_TX_DESC_DISDATAFB(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 4)
+#define IE0_SET_TX_DESC_DISDATAFB(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
+#define IE0_SET_TX_DESC_DISDATAFB_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
+#define IE0_GET_TX_DESC_DISRTSFB(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 3)
+#define IE0_SET_TX_DESC_DISRTSFB(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
+#define IE0_SET_TX_DESC_DISRTSFB_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
+#define IE0_GET_TX_DESC_DATA_SHORT(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 2)
+#define IE0_SET_TX_DESC_DATA_SHORT(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE0_SET_TX_DESC_DATA_SHORT_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE0_GET_TX_DESC_TRY_RATE(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 1)
+#define IE0_SET_TX_DESC_TRY_RATE(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE0_SET_TX_DESC_TRY_RATE_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE0_GET_TX_DESC_USERATE(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 0)
+#define IE0_SET_TX_DESC_USERATE(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE0_SET_TX_DESC_USERATE_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 27)
+#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
+#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE_NO_CLR(txdesc_ie, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
+#define IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie)                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x1f, 22)
+#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie, value)                 \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1f, 22)
+#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE_NO_CLR(txdesc_ie, value)          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1f, 22)
+#define IE0_GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie)                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3f, 16)
+#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 16)
+#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT_NO_CLR(txdesc_ie, value)              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 16)
+#define IE0_GET_TX_DESC_DATA_BW(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 12)
+#define IE0_SET_TX_DESC_DATA_BW(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
+#define IE0_SET_TX_DESC_DATA_BW_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
+#define IE0_GET_TX_DESC_RTSRATE(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 7)
+#define IE0_SET_TX_DESC_RTSRATE(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 7)
+#define IE0_SET_TX_DESC_RTSRATE_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 7)
+#define IE0_GET_TX_DESC_DATARATE(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x7f, 0)
+#define IE0_SET_TX_DESC_DATARATE(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
+#define IE0_SET_TX_DESC_DATARATE_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
+#define IE1_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 31)
+#define IE1_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE1_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE1_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 30)
+#define IE1_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE1_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE1_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 24)
+#define IE1_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE1_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE1_GET_TX_DESC_AMPDU_DENSITY(txdesc_ie)                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x7, 21)
+#define IE1_SET_TX_DESC_AMPDU_DENSITY(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 21)
+#define IE1_SET_TX_DESC_AMPDU_DENSITY_NO_CLR(txdesc_ie, value)                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 21)
+#define IE1_GET_TX_DESC_MAX_AGG_NUM(txdesc_ie)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1f, 16)
+#define IE1_SET_TX_DESC_MAX_AGG_NUM(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1f, 16)
+#define IE1_SET_TX_DESC_MAX_AGG_NUM_NO_CLR(txdesc_ie, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1f, 16)
+#define IE1_GET_TX_DESC_SECTYPE(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x3, 14)
+#define IE1_SET_TX_DESC_SECTYPE(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 14)
+#define IE1_SET_TX_DESC_SECTYPE_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 14)
+#define IE1_GET_TX_DESC_MOREFRAG(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 13)
+#define IE1_SET_TX_DESC_MOREFRAG(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 13)
+#define IE1_SET_TX_DESC_MOREFRAG_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 13)
+#define IE1_GET_TX_DESC_NOACM(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 12)
+#define IE1_SET_TX_DESC_NOACM(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 12)
+#define IE1_SET_TX_DESC_NOACM_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 12)
+#define IE1_GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie)                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 11)
+#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
+#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL_NO_CLR(txdesc_ie, value)               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
+#define IE1_GET_TX_DESC_NAVUSEHDR(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 10)
+#define IE1_SET_TX_DESC_NAVUSEHDR(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
+#define IE1_SET_TX_DESC_NAVUSEHDR_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
+#define IE1_GET_TX_DESC_HTC(txdesc_ie)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 9)
+#define IE1_SET_TX_DESC_HTC(txdesc_ie, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
+#define IE1_SET_TX_DESC_HTC_NO_CLR(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
+#define IE1_GET_TX_DESC_BMC(txdesc_ie)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 8)
+#define IE1_SET_TX_DESC_BMC(txdesc_ie, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
+#define IE1_SET_TX_DESC_BMC_NO_CLR(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
+#define IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie)                           \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 7)
+#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
+#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS_NO_CLR(txdesc_ie, value)             \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
+#define IE1_GET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie)                             \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 6)
+#define IE1_SET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
+#define IE1_SET_TX_DESC_USE_MAX_TIME_EN_NO_CLR(txdesc_ie, value)               \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
+#define IE1_GET_TX_DESC_HW_SSN_SEL(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x3, 4)
+#define IE1_SET_TX_DESC_HW_SSN_SEL(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 4)
+#define IE1_SET_TX_DESC_HW_SSN_SEL_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 4)
+#define IE1_GET_TX_DESC_DISQSELSEQ(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 3)
+#define IE1_SET_TX_DESC_DISQSELSEQ(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
+#define IE1_SET_TX_DESC_DISQSELSEQ_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
+#define IE1_GET_TX_DESC_EN_HWSEQ(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 2)
+#define IE1_SET_TX_DESC_EN_HWSEQ(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE1_SET_TX_DESC_EN_HWSEQ_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE1_GET_TX_DESC_EN_HWEXSEQ(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 1)
+#define IE1_SET_TX_DESC_EN_HWEXSEQ(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE1_SET_TX_DESC_EN_HWEXSEQ_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE1_GET_TX_DESC_EN_DESC_ID(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 0)
+#define IE1_SET_TX_DESC_EN_DESC_ID(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE1_SET_TX_DESC_EN_DESC_ID_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE1_GET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie)                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xff, 24)
+#define IE1_SET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 24)
+#define IE1_SET_TX_DESC_AMPDU_MAX_TIME_NO_CLR(txdesc_ie, value)                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 24)
+#define IE1_GET_TX_DESC_P_AID(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x1ff, 15)
+#define IE1_SET_TX_DESC_P_AID(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1ff,    \
+		15)
+#define IE1_SET_TX_DESC_P_AID_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1ff,    \
+		15)
+#define IE1_GET_TX_DESC_MOREDATA(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x1, 14)
+#define IE1_SET_TX_DESC_MOREDATA(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 14)
+#define IE1_SET_TX_DESC_MOREDATA_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 14)
+#define IE1_GET_TX_DESC_SW_SEQ(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xfff, 0)
+#define IE1_SET_TX_DESC_SW_SEQ(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
+#define IE1_SET_TX_DESC_SW_SEQ_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
+#define IE2_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 31)
+#define IE2_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE2_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE2_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 30)
+#define IE2_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE2_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE2_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 24)
+#define IE2_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE2_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE2_GET_TX_DESC_ADDR_CAM(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xff, 16)
+#define IE2_SET_TX_DESC_ADDR_CAM(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xff, 16)
+#define IE2_SET_TX_DESC_ADDR_CAM_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xff, 16)
+#define IE2_GET_TX_DESC_MULTIPLE_PORT(txdesc_ie)                               \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x7, 12)
+#define IE2_SET_TX_DESC_MULTIPLE_PORT(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 12)
+#define IE2_SET_TX_DESC_MULTIPLE_PORT_NO_CLR(txdesc_ie, value)                 \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 12)
+#define IE2_GET_TX_DESC_RAW(txdesc_ie)                                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 11)
+#define IE2_SET_TX_DESC_RAW(txdesc_ie, value)                                  \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
+#define IE2_SET_TX_DESC_RAW_NO_CLR(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
+#define IE2_GET_TX_DESC_RDG_EN(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 10)
+#define IE2_SET_TX_DESC_RDG_EN(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
+#define IE2_SET_TX_DESC_RDG_EN_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
+#define IE2_GET_TX_DESC_SPECIAL_CW(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 7)
+#define IE2_SET_TX_DESC_SPECIAL_CW(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
+#define IE2_SET_TX_DESC_SPECIAL_CW_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
+#define IE2_GET_TX_DESC_POLLUTED(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 6)
+#define IE2_SET_TX_DESC_POLLUTED(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
+#define IE2_SET_TX_DESC_POLLUTED_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
+#define IE2_GET_TX_DESC_BT_NULL(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 5)
+#define IE2_SET_TX_DESC_BT_NULL(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
+#define IE2_SET_TX_DESC_BT_NULL_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
+#define IE2_GET_TX_DESC_NULL_1(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 4)
+#define IE2_SET_TX_DESC_NULL_1(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
+#define IE2_SET_TX_DESC_NULL_1_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
+#define IE2_GET_TX_DESC_NULL_0(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 3)
+#define IE2_SET_TX_DESC_NULL_0(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
+#define IE2_SET_TX_DESC_NULL_0_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
+#define IE2_GET_TX_DESC_TRI_FRAME(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 2)
+#define IE2_SET_TX_DESC_TRI_FRAME(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE2_SET_TX_DESC_TRI_FRAME_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE2_GET_TX_DESC_SPE_RPT(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 1)
+#define IE2_SET_TX_DESC_SPE_RPT(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE2_SET_TX_DESC_SPE_RPT_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE2_GET_TX_DESC_FTM_EN(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 0)
+#define IE2_SET_TX_DESC_FTM_EN(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE2_SET_TX_DESC_FTM_EN_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE2_GET_TX_DESC_MBSSID(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 27)
+#define IE2_SET_TX_DESC_MBSSID(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
+#define IE2_SET_TX_DESC_MBSSID_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
+#define IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x7ff, 16)
+#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7ff,    \
+		16)
+#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET_NO_CLR(txdesc_ie, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7ff,    \
+		16)
+#define IE2_GET_TX_DESC_RDG_NAV_EXT(txdesc_ie)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x1, 15)
+#define IE2_SET_TX_DESC_RDG_NAV_EXT(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 15)
+#define IE2_SET_TX_DESC_RDG_NAV_EXT_NO_CLR(txdesc_ie, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 15)
+#define IE2_GET_TX_DESC_DROP_ID(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 12)
+#define IE2_SET_TX_DESC_DROP_ID(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
+#define IE2_SET_TX_DESC_DROP_ID_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
+#define IE2_GET_TX_DESC_SW_DEFINE(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xfff, 0)
+#define IE2_SET_TX_DESC_SW_DEFINE(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
+#define IE2_SET_TX_DESC_SW_DEFINE_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
+#define IE3_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 31)
+#define IE3_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE3_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE3_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 30)
+#define IE3_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE3_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE3_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 24)
+#define IE3_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE3_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE3_GET_TX_DESC_DATA_SC(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 20)
+#define IE3_SET_TX_DESC_DATA_SC(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 20)
+#define IE3_SET_TX_DESC_DATA_SC_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 20)
+#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 16)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 16)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC_NO_CLR(txdesc_ie, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 16)
+#define IE3_GET_TX_DESC_CTRL_CNT(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 8)
+#define IE3_SET_TX_DESC_CTRL_CNT(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 8)
+#define IE3_SET_TX_DESC_CTRL_CNT_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 8)
+#define IE3_GET_TX_DESC_CTRL_CNT_VALID(txdesc_ie)                              \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 1)
+#define IE3_SET_TX_DESC_CTRL_CNT_VALID(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE3_SET_TX_DESC_CTRL_CNT_VALID_NO_CLR(txdesc_ie, value)                \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie)                         \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 0)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie, value)                  \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN_NO_CLR(txdesc_ie, value)           \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE3_GET_TX_DESC_G_ID(txdesc_ie)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3f, 24)
+#define IE3_SET_TX_DESC_G_ID(txdesc_ie, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 24)
+#define IE3_SET_TX_DESC_G_ID_NO_CLR(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 24)
+#define IE3_GET_TX_DESC_SND_TARGET(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xff, 16)
+#define IE3_SET_TX_DESC_SND_TARGET(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 16)
+#define IE3_SET_TX_DESC_SND_TARGET_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 16)
+#define IE3_GET_TX_DESC_CCA_RTS(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 11)
+#define IE3_SET_TX_DESC_CCA_RTS(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 11)
+#define IE3_SET_TX_DESC_CCA_RTS_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 11)
+#define IE3_GET_TX_DESC_SND_PKT_SEL(txdesc_ie)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 9)
+#define IE3_SET_TX_DESC_SND_PKT_SEL(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 9)
+#define IE3_SET_TX_DESC_SND_PKT_SEL_NO_CLR(txdesc_ie, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 9)
+#define IE3_GET_TX_DESC_NDPA(txdesc_ie)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 7)
+#define IE3_SET_TX_DESC_NDPA(txdesc_ie, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 7)
+#define IE3_SET_TX_DESC_NDPA_NO_CLR(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 7)
+#define IE3_GET_TX_DESC_MU_DATARATE(txdesc_ie)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x7f, 0)
+#define IE3_SET_TX_DESC_MU_DATARATE(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
+#define IE3_SET_TX_DESC_MU_DATARATE_NO_CLR(txdesc_ie, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
+#define IE4_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 31)
+#define IE4_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE4_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE4_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 30)
+#define IE4_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE4_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE4_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 24)
+#define IE4_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE4_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE4_GET_TX_DESC_VCS_STBC(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x3, 10)
+#define IE4_SET_TX_DESC_VCS_STBC(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 10)
+#define IE4_SET_TX_DESC_VCS_STBC_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 10)
+#define IE4_GET_TX_DESC_DATA_STBC(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x3, 8)
+#define IE4_SET_TX_DESC_DATA_STBC(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 8)
+#define IE4_SET_TX_DESC_DATA_STBC_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 8)
+#define IE4_GET_TX_DESC_DATA_LDPC(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 2)
+#define IE4_SET_TX_DESC_DATA_LDPC(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE4_SET_TX_DESC_DATA_LDPC_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
+#define IE4_GET_TX_DESC_GF(txdesc_ie)                                          \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 1)
+#define IE4_SET_TX_DESC_GF(txdesc_ie, value)                                   \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE4_SET_TX_DESC_GF_NO_CLR(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
+#define IE4_GET_TX_DESC_LSIG_TXOP_EN(txdesc_ie)                                \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 0)
+#define IE4_SET_TX_DESC_LSIG_TXOP_EN(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE4_SET_TX_DESC_LSIG_TXOP_EN_NO_CLR(txdesc_ie, value)                  \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
+#define IE4_GET_TX_DESC_PATH_MAPA(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 30)
+#define IE4_SET_TX_DESC_PATH_MAPA(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 30)
+#define IE4_SET_TX_DESC_PATH_MAPA_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 30)
+#define IE4_GET_TX_DESC_PATH_MAPB(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 28)
+#define IE4_SET_TX_DESC_PATH_MAPB(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 28)
+#define IE4_SET_TX_DESC_PATH_MAPB_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 28)
+#define IE4_GET_TX_DESC_PATH_MAPC(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 26)
+#define IE4_SET_TX_DESC_PATH_MAPC(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 26)
+#define IE4_SET_TX_DESC_PATH_MAPC_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 26)
+#define IE4_GET_TX_DESC_PATH_MAPD(txdesc_ie)                                   \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 24)
+#define IE4_SET_TX_DESC_PATH_MAPD(txdesc_ie, value)                            \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 24)
+#define IE4_SET_TX_DESC_PATH_MAPD_NO_CLR(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 24)
+#define IE4_GET_TX_DESC_ANTSEL_A(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 20)
+#define IE4_SET_TX_DESC_ANTSEL_A(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 20)
+#define IE4_SET_TX_DESC_ANTSEL_A_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 20)
+#define IE4_GET_TX_DESC_ANTSEL_B(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 16)
+#define IE4_SET_TX_DESC_ANTSEL_B(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 16)
+#define IE4_SET_TX_DESC_ANTSEL_B_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 16)
+#define IE4_GET_TX_DESC_ANTSEL_C(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 12)
+#define IE4_SET_TX_DESC_ANTSEL_C(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 12)
+#define IE4_SET_TX_DESC_ANTSEL_C_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 12)
+#define IE4_GET_TX_DESC_ANTSEL_D(txdesc_ie)                                    \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 8)
+#define IE4_SET_TX_DESC_ANTSEL_D(txdesc_ie, value)                             \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 8)
+#define IE4_SET_TX_DESC_ANTSEL_D_NO_CLR(txdesc_ie, value)                      \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 8)
+#define IE4_GET_TX_DESC_NTX_PATH_EN(txdesc_ie)                                 \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0xf, 4)
+#define IE4_SET_TX_DESC_NTX_PATH_EN(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 4)
+#define IE4_SET_TX_DESC_NTX_PATH_EN_NO_CLR(txdesc_ie, value)                   \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 4)
+#define IE4_GET_TX_DESC_ANTLSEL_EN(txdesc_ie)                                  \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x1, 3)
+#define IE4_SET_TX_DESC_ANTLSEL_EN(txdesc_ie, value)                           \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 3)
+#define IE4_SET_TX_DESC_ANTLSEL_EN_NO_CLR(txdesc_ie, value)                    \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 3)
+#define IE4_GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie)                            \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3, 0)
+#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie, value)                     \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 0)
+#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE_NO_CLR(txdesc_ie, value)              \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 0)
+#define IE5_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 31)
+#define IE5_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE5_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
+#define IE5_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1, 30)
+#define IE5_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE5_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value)                         \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
+#define IE5_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 24)
+#define IE5_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE5_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
+#define IE5_GET_TX_DESC_LEN1_L(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x7f, 17)
+#define IE5_SET_TX_DESC_LEN1_L(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7f, 17)
+#define IE5_SET_TX_DESC_LEN1_L_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7f, 17)
+#define IE5_GET_TX_DESC_LEN0(txdesc_ie)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0x1fff, 4)
+#define IE5_SET_TX_DESC_LEN0(txdesc_ie, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1fff,   \
+		4)
+#define IE5_SET_TX_DESC_LEN0_NO_CLR(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1fff,   \
+		4)
+#define IE5_GET_TX_DESC_PKT_NUM(txdesc_ie)                                     \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0,    \
+			      0xf, 0)
+#define IE5_SET_TX_DESC_PKT_NUM(txdesc_ie, value)                              \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 0)
+#define IE5_SET_TX_DESC_PKT_NUM_NO_CLR(txdesc_ie, value)                       \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 0)
+#define IE5_GET_TX_DESC_LEN3(txdesc_ie)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x1fff, 19)
+#define IE5_SET_TX_DESC_LEN3(txdesc_ie, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff,   \
+		19)
+#define IE5_SET_TX_DESC_LEN3_NO_CLR(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff,   \
+		19)
+#define IE5_GET_TX_DESC_LEN2(txdesc_ie)                                        \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x1fff, 6)
+#define IE5_SET_TX_DESC_LEN2(txdesc_ie, value)                                 \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff,   \
+		6)
+#define IE5_SET_TX_DESC_LEN2_NO_CLR(txdesc_ie, value)                          \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff,   \
+		6)
+#define IE5_GET_TX_DESC_LEN1_H(txdesc_ie)                                      \
+	HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1,    \
+			      0x3f, 0)
+#define IE5_SET_TX_DESC_LEN1_H(txdesc_ie, value)                               \
+	HALMAC_SET_DESC_FIELD_CLR(                                             \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 0)
+#define IE5_SET_TX_DESC_LEN1_H_NO_CLR(txdesc_ie, value)                        \
+	HALMAC_SET_DESC_FIELD_NO_CLR(                                          \
+		((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 0)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_chip.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_chip.h
new file mode 100644
index 000000000000..8126a0c7ac52
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_chip.h
@@ -0,0 +1,438 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_IE_CHIP_H_
+#define _HALMAC_TX_DESC_IE_CHIP_H_
+#if (HALMAC_8814B_SUPPORT)
+
+#define IE0_GET_TX_DESC_IE_END_8814B(txdesc_ie)                                \
+	IE0_GET_TX_DESC_IE_END(txdesc_ie)
+#define IE0_SET_TX_DESC_IE_END_8814B(txdesc_ie, value)                         \
+	IE0_SET_TX_DESC_IE_END(txdesc_ie, value)
+#define IE0_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE0_GET_TX_DESC_IE_UP(txdesc_ie)
+#define IE0_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value)                          \
+	IE0_SET_TX_DESC_IE_UP(txdesc_ie, value)
+#define IE0_GET_TX_DESC_IE_NUM_8814B(txdesc_ie)                                \
+	IE0_GET_TX_DESC_IE_NUM(txdesc_ie)
+#define IE0_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value)                         \
+	IE0_SET_TX_DESC_IE_NUM(txdesc_ie, value)
+#define IE0_GET_TX_DESC_ARFR_TABLE_SEL_8814B(txdesc_ie)                        \
+	IE0_GET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie)
+#define IE0_SET_TX_DESC_ARFR_TABLE_SEL_8814B(txdesc_ie, value)                 \
+	IE0_SET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie, value)
+#define IE0_GET_TX_DESC_ARFR_HT_EN_8814B(txdesc_ie)                            \
+	IE0_GET_TX_DESC_ARFR_HT_EN(txdesc_ie)
+#define IE0_SET_TX_DESC_ARFR_HT_EN_8814B(txdesc_ie, value)                     \
+	IE0_SET_TX_DESC_ARFR_HT_EN(txdesc_ie, value)
+#define IE0_GET_TX_DESC_ARFR_OFDM_EN_8814B(txdesc_ie)                          \
+	IE0_GET_TX_DESC_ARFR_OFDM_EN(txdesc_ie)
+#define IE0_SET_TX_DESC_ARFR_OFDM_EN_8814B(txdesc_ie, value)                   \
+	IE0_SET_TX_DESC_ARFR_OFDM_EN(txdesc_ie, value)
+#define IE0_GET_TX_DESC_ARFR_CCK_EN_8814B(txdesc_ie)                           \
+	IE0_GET_TX_DESC_ARFR_CCK_EN(txdesc_ie)
+#define IE0_SET_TX_DESC_ARFR_CCK_EN_8814B(txdesc_ie, value)                    \
+	IE0_SET_TX_DESC_ARFR_CCK_EN(txdesc_ie, value)
+#define IE0_GET_TX_DESC_HW_RTS_EN_8814B(txdesc_ie)                             \
+	IE0_GET_TX_DESC_HW_RTS_EN(txdesc_ie)
+#define IE0_SET_TX_DESC_HW_RTS_EN_8814B(txdesc_ie, value)                      \
+	IE0_SET_TX_DESC_HW_RTS_EN(txdesc_ie, value)
+#define IE0_GET_TX_DESC_RTS_EN_8814B(txdesc_ie)                                \
+	IE0_GET_TX_DESC_RTS_EN(txdesc_ie)
+#define IE0_SET_TX_DESC_RTS_EN_8814B(txdesc_ie, value)                         \
+	IE0_SET_TX_DESC_RTS_EN(txdesc_ie, value)
+#define IE0_GET_TX_DESC_CTS2SELF_8814B(txdesc_ie)                              \
+	IE0_GET_TX_DESC_CTS2SELF(txdesc_ie)
+#define IE0_SET_TX_DESC_CTS2SELF_8814B(txdesc_ie, value)                       \
+	IE0_SET_TX_DESC_CTS2SELF(txdesc_ie, value)
+#define IE0_GET_TX_DESC_RTY_LMT_EN_8814B(txdesc_ie)                            \
+	IE0_GET_TX_DESC_RTY_LMT_EN(txdesc_ie)
+#define IE0_SET_TX_DESC_RTY_LMT_EN_8814B(txdesc_ie, value)                     \
+	IE0_SET_TX_DESC_RTY_LMT_EN(txdesc_ie, value)
+#define IE0_GET_TX_DESC_RTS_SHORT_8814B(txdesc_ie)                             \
+	IE0_GET_TX_DESC_RTS_SHORT(txdesc_ie)
+#define IE0_SET_TX_DESC_RTS_SHORT_8814B(txdesc_ie, value)                      \
+	IE0_SET_TX_DESC_RTS_SHORT(txdesc_ie, value)
+#define IE0_GET_TX_DESC_DISDATAFB_8814B(txdesc_ie)                             \
+	IE0_GET_TX_DESC_DISDATAFB(txdesc_ie)
+#define IE0_SET_TX_DESC_DISDATAFB_8814B(txdesc_ie, value)                      \
+	IE0_SET_TX_DESC_DISDATAFB(txdesc_ie, value)
+#define IE0_GET_TX_DESC_DISRTSFB_8814B(txdesc_ie)                              \
+	IE0_GET_TX_DESC_DISRTSFB(txdesc_ie)
+#define IE0_SET_TX_DESC_DISRTSFB_8814B(txdesc_ie, value)                       \
+	IE0_SET_TX_DESC_DISRTSFB(txdesc_ie, value)
+#define IE0_GET_TX_DESC_DATA_SHORT_8814B(txdesc_ie)                            \
+	IE0_GET_TX_DESC_DATA_SHORT(txdesc_ie)
+#define IE0_SET_TX_DESC_DATA_SHORT_8814B(txdesc_ie, value)                     \
+	IE0_SET_TX_DESC_DATA_SHORT(txdesc_ie, value)
+#define IE0_GET_TX_DESC_TRY_RATE_8814B(txdesc_ie)                              \
+	IE0_GET_TX_DESC_TRY_RATE(txdesc_ie)
+#define IE0_SET_TX_DESC_TRY_RATE_8814B(txdesc_ie, value)                       \
+	IE0_SET_TX_DESC_TRY_RATE(txdesc_ie, value)
+#define IE0_GET_TX_DESC_USERATE_8814B(txdesc_ie)                               \
+	IE0_GET_TX_DESC_USERATE(txdesc_ie)
+#define IE0_SET_TX_DESC_USERATE_8814B(txdesc_ie, value)                        \
+	IE0_SET_TX_DESC_USERATE(txdesc_ie, value)
+#define IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE_8814B(txdesc_ie)                   \
+	IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie)
+#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE_8814B(txdesc_ie, value)            \
+	IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie, value)
+#define IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE_8814B(txdesc_ie)                  \
+	IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie)
+#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE_8814B(txdesc_ie, value)           \
+	IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie, value)
+#define IE0_GET_TX_DESC_RTS_DATA_RTY_LMT_8814B(txdesc_ie)                      \
+	IE0_GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie)
+#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT_8814B(txdesc_ie, value)               \
+	IE0_SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie, value)
+#define IE0_GET_TX_DESC_DATA_BW_8814B(txdesc_ie)                               \
+	IE0_GET_TX_DESC_DATA_BW(txdesc_ie)
+#define IE0_SET_TX_DESC_DATA_BW_8814B(txdesc_ie, value)                        \
+	IE0_SET_TX_DESC_DATA_BW(txdesc_ie, value)
+#define IE0_GET_TX_DESC_RTSRATE_8814B(txdesc_ie)                               \
+	IE0_GET_TX_DESC_RTSRATE(txdesc_ie)
+#define IE0_SET_TX_DESC_RTSRATE_8814B(txdesc_ie, value)                        \
+	IE0_SET_TX_DESC_RTSRATE(txdesc_ie, value)
+#define IE0_GET_TX_DESC_DATARATE_8814B(txdesc_ie)                              \
+	IE0_GET_TX_DESC_DATARATE(txdesc_ie)
+#define IE0_SET_TX_DESC_DATARATE_8814B(txdesc_ie, value)                       \
+	IE0_SET_TX_DESC_DATARATE(txdesc_ie, value)
+#define IE1_GET_TX_DESC_IE_END_8814B(txdesc_ie)                                \
+	IE1_GET_TX_DESC_IE_END(txdesc_ie)
+#define IE1_SET_TX_DESC_IE_END_8814B(txdesc_ie, value)                         \
+	IE1_SET_TX_DESC_IE_END(txdesc_ie, value)
+#define IE1_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE1_GET_TX_DESC_IE_UP(txdesc_ie)
+#define IE1_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value)                          \
+	IE1_SET_TX_DESC_IE_UP(txdesc_ie, value)
+#define IE1_GET_TX_DESC_IE_NUM_8814B(txdesc_ie)                                \
+	IE1_GET_TX_DESC_IE_NUM(txdesc_ie)
+#define IE1_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value)                         \
+	IE1_SET_TX_DESC_IE_NUM(txdesc_ie, value)
+#define IE1_GET_TX_DESC_AMPDU_DENSITY_8814B(txdesc_ie)                         \
+	IE1_GET_TX_DESC_AMPDU_DENSITY(txdesc_ie)
+#define IE1_SET_TX_DESC_AMPDU_DENSITY_8814B(txdesc_ie, value)                  \
+	IE1_SET_TX_DESC_AMPDU_DENSITY(txdesc_ie, value)
+#define IE1_GET_TX_DESC_MAX_AGG_NUM_8814B(txdesc_ie)                           \
+	IE1_GET_TX_DESC_MAX_AGG_NUM(txdesc_ie)
+#define IE1_SET_TX_DESC_MAX_AGG_NUM_8814B(txdesc_ie, value)                    \
+	IE1_SET_TX_DESC_MAX_AGG_NUM(txdesc_ie, value)
+#define IE1_GET_TX_DESC_SECTYPE_8814B(txdesc_ie)                               \
+	IE1_GET_TX_DESC_SECTYPE(txdesc_ie)
+#define IE1_SET_TX_DESC_SECTYPE_8814B(txdesc_ie, value)                        \
+	IE1_SET_TX_DESC_SECTYPE(txdesc_ie, value)
+#define IE1_GET_TX_DESC_MOREFRAG_8814B(txdesc_ie)                              \
+	IE1_GET_TX_DESC_MOREFRAG(txdesc_ie)
+#define IE1_SET_TX_DESC_MOREFRAG_8814B(txdesc_ie, value)                       \
+	IE1_SET_TX_DESC_MOREFRAG(txdesc_ie, value)
+#define IE1_GET_TX_DESC_NOACM_8814B(txdesc_ie) IE1_GET_TX_DESC_NOACM(txdesc_ie)
+#define IE1_SET_TX_DESC_NOACM_8814B(txdesc_ie, value)                          \
+	IE1_SET_TX_DESC_NOACM(txdesc_ie, value)
+#define IE1_GET_TX_DESC_BCNPKT_TSF_CTRL_8814B(txdesc_ie)                       \
+	IE1_GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie)
+#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL_8814B(txdesc_ie, value)                \
+	IE1_SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie, value)
+#define IE1_GET_TX_DESC_NAVUSEHDR_8814B(txdesc_ie)                             \
+	IE1_GET_TX_DESC_NAVUSEHDR(txdesc_ie)
+#define IE1_SET_TX_DESC_NAVUSEHDR_8814B(txdesc_ie, value)                      \
+	IE1_SET_TX_DESC_NAVUSEHDR(txdesc_ie, value)
+#define IE1_GET_TX_DESC_HTC_8814B(txdesc_ie) IE1_GET_TX_DESC_HTC(txdesc_ie)
+#define IE1_SET_TX_DESC_HTC_8814B(txdesc_ie, value)                            \
+	IE1_SET_TX_DESC_HTC(txdesc_ie, value)
+#define IE1_GET_TX_DESC_BMC_8814B(txdesc_ie) IE1_GET_TX_DESC_BMC(txdesc_ie)
+#define IE1_SET_TX_DESC_BMC_8814B(txdesc_ie, value)                            \
+	IE1_SET_TX_DESC_BMC(txdesc_ie, value)
+#define IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS_8814B(txdesc_ie)                     \
+	IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie)
+#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS_8814B(txdesc_ie, value)              \
+	IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie, value)
+#define IE1_GET_TX_DESC_USE_MAX_TIME_EN_8814B(txdesc_ie)                       \
+	IE1_GET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie)
+#define IE1_SET_TX_DESC_USE_MAX_TIME_EN_8814B(txdesc_ie, value)                \
+	IE1_SET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie, value)
+#define IE1_GET_TX_DESC_HW_SSN_SEL_8814B(txdesc_ie)                            \
+	IE1_GET_TX_DESC_HW_SSN_SEL(txdesc_ie)
+#define IE1_SET_TX_DESC_HW_SSN_SEL_8814B(txdesc_ie, value)                     \
+	IE1_SET_TX_DESC_HW_SSN_SEL(txdesc_ie, value)
+#define IE1_GET_TX_DESC_DISQSELSEQ_8814B(txdesc_ie)                            \
+	IE1_GET_TX_DESC_DISQSELSEQ(txdesc_ie)
+#define IE1_SET_TX_DESC_DISQSELSEQ_8814B(txdesc_ie, value)                     \
+	IE1_SET_TX_DESC_DISQSELSEQ(txdesc_ie, value)
+#define IE1_GET_TX_DESC_EN_HWSEQ_8814B(txdesc_ie)                              \
+	IE1_GET_TX_DESC_EN_HWSEQ(txdesc_ie)
+#define IE1_SET_TX_DESC_EN_HWSEQ_8814B(txdesc_ie, value)                       \
+	IE1_SET_TX_DESC_EN_HWSEQ(txdesc_ie, value)
+#define IE1_GET_TX_DESC_EN_HWEXSEQ_8814B(txdesc_ie)                            \
+	IE1_GET_TX_DESC_EN_HWEXSEQ(txdesc_ie)
+#define IE1_SET_TX_DESC_EN_HWEXSEQ_8814B(txdesc_ie, value)                     \
+	IE1_SET_TX_DESC_EN_HWEXSEQ(txdesc_ie, value)
+#define IE1_GET_TX_DESC_EN_DESC_ID_8814B(txdesc_ie)                            \
+	IE1_GET_TX_DESC_EN_DESC_ID(txdesc_ie)
+#define IE1_SET_TX_DESC_EN_DESC_ID_8814B(txdesc_ie, value)                     \
+	IE1_SET_TX_DESC_EN_DESC_ID(txdesc_ie, value)
+#define IE1_GET_TX_DESC_AMPDU_MAX_TIME_8814B(txdesc_ie)                        \
+	IE1_GET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie)
+#define IE1_SET_TX_DESC_AMPDU_MAX_TIME_8814B(txdesc_ie, value)                 \
+	IE1_SET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie, value)
+#define IE1_GET_TX_DESC_P_AID_8814B(txdesc_ie) IE1_GET_TX_DESC_P_AID(txdesc_ie)
+#define IE1_SET_TX_DESC_P_AID_8814B(txdesc_ie, value)                          \
+	IE1_SET_TX_DESC_P_AID(txdesc_ie, value)
+#define IE1_GET_TX_DESC_MOREDATA_8814B(txdesc_ie)                              \
+	IE1_GET_TX_DESC_MOREDATA(txdesc_ie)
+#define IE1_SET_TX_DESC_MOREDATA_8814B(txdesc_ie, value)                       \
+	IE1_SET_TX_DESC_MOREDATA(txdesc_ie, value)
+#define IE1_GET_TX_DESC_SW_SEQ_8814B(txdesc_ie)                                \
+	IE1_GET_TX_DESC_SW_SEQ(txdesc_ie)
+#define IE1_SET_TX_DESC_SW_SEQ_8814B(txdesc_ie, value)                         \
+	IE1_SET_TX_DESC_SW_SEQ(txdesc_ie, value)
+#define IE2_GET_TX_DESC_IE_END_8814B(txdesc_ie)                                \
+	IE2_GET_TX_DESC_IE_END(txdesc_ie)
+#define IE2_SET_TX_DESC_IE_END_8814B(txdesc_ie, value)                         \
+	IE2_SET_TX_DESC_IE_END(txdesc_ie, value)
+#define IE2_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE2_GET_TX_DESC_IE_UP(txdesc_ie)
+#define IE2_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value)                          \
+	IE2_SET_TX_DESC_IE_UP(txdesc_ie, value)
+#define IE2_GET_TX_DESC_IE_NUM_8814B(txdesc_ie)                                \
+	IE2_GET_TX_DESC_IE_NUM(txdesc_ie)
+#define IE2_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value)                         \
+	IE2_SET_TX_DESC_IE_NUM(txdesc_ie, value)
+#define IE2_GET_TX_DESC_ADDR_CAM_8814B(txdesc_ie)                              \
+	IE2_GET_TX_DESC_ADDR_CAM(txdesc_ie)
+#define IE2_SET_TX_DESC_ADDR_CAM_8814B(txdesc_ie, value)                       \
+	IE2_SET_TX_DESC_ADDR_CAM(txdesc_ie, value)
+#define IE2_GET_TX_DESC_MULTIPLE_PORT_8814B(txdesc_ie)                         \
+	IE2_GET_TX_DESC_MULTIPLE_PORT(txdesc_ie)
+#define IE2_SET_TX_DESC_MULTIPLE_PORT_8814B(txdesc_ie, value)                  \
+	IE2_SET_TX_DESC_MULTIPLE_PORT(txdesc_ie, value)
+#define IE2_GET_TX_DESC_RAW_8814B(txdesc_ie) IE2_GET_TX_DESC_RAW(txdesc_ie)
+#define IE2_SET_TX_DESC_RAW_8814B(txdesc_ie, value)                            \
+	IE2_SET_TX_DESC_RAW(txdesc_ie, value)
+#define IE2_GET_TX_DESC_RDG_EN_8814B(txdesc_ie)                                \
+	IE2_GET_TX_DESC_RDG_EN(txdesc_ie)
+#define IE2_SET_TX_DESC_RDG_EN_8814B(txdesc_ie, value)                         \
+	IE2_SET_TX_DESC_RDG_EN(txdesc_ie, value)
+#define IE2_GET_TX_DESC_SPECIAL_CW_8814B(txdesc_ie)                            \
+	IE2_GET_TX_DESC_SPECIAL_CW(txdesc_ie)
+#define IE2_SET_TX_DESC_SPECIAL_CW_8814B(txdesc_ie, value)                     \
+	IE2_SET_TX_DESC_SPECIAL_CW(txdesc_ie, value)
+#define IE2_GET_TX_DESC_POLLUTED_8814B(txdesc_ie)                              \
+	IE2_GET_TX_DESC_POLLUTED(txdesc_ie)
+#define IE2_SET_TX_DESC_POLLUTED_8814B(txdesc_ie, value)                       \
+	IE2_SET_TX_DESC_POLLUTED(txdesc_ie, value)
+#define IE2_GET_TX_DESC_BT_NULL_8814B(txdesc_ie)                               \
+	IE2_GET_TX_DESC_BT_NULL(txdesc_ie)
+#define IE2_SET_TX_DESC_BT_NULL_8814B(txdesc_ie, value)                        \
+	IE2_SET_TX_DESC_BT_NULL(txdesc_ie, value)
+#define IE2_GET_TX_DESC_NULL_1_8814B(txdesc_ie)                                \
+	IE2_GET_TX_DESC_NULL_1(txdesc_ie)
+#define IE2_SET_TX_DESC_NULL_1_8814B(txdesc_ie, value)                         \
+	IE2_SET_TX_DESC_NULL_1(txdesc_ie, value)
+#define IE2_GET_TX_DESC_NULL_0_8814B(txdesc_ie)                                \
+	IE2_GET_TX_DESC_NULL_0(txdesc_ie)
+#define IE2_SET_TX_DESC_NULL_0_8814B(txdesc_ie, value)                         \
+	IE2_SET_TX_DESC_NULL_0(txdesc_ie, value)
+#define IE2_GET_TX_DESC_TRI_FRAME_8814B(txdesc_ie)                             \
+	IE2_GET_TX_DESC_TRI_FRAME(txdesc_ie)
+#define IE2_SET_TX_DESC_TRI_FRAME_8814B(txdesc_ie, value)                      \
+	IE2_SET_TX_DESC_TRI_FRAME(txdesc_ie, value)
+#define IE2_GET_TX_DESC_SPE_RPT_8814B(txdesc_ie)                               \
+	IE2_GET_TX_DESC_SPE_RPT(txdesc_ie)
+#define IE2_SET_TX_DESC_SPE_RPT_8814B(txdesc_ie, value)                        \
+	IE2_SET_TX_DESC_SPE_RPT(txdesc_ie, value)
+#define IE2_GET_TX_DESC_FTM_EN_8814B(txdesc_ie)                                \
+	IE2_GET_TX_DESC_FTM_EN(txdesc_ie)
+#define IE2_SET_TX_DESC_FTM_EN_8814B(txdesc_ie, value)                         \
+	IE2_SET_TX_DESC_FTM_EN(txdesc_ie, value)
+#define IE2_GET_TX_DESC_MBSSID_8814B(txdesc_ie)                                \
+	IE2_GET_TX_DESC_MBSSID(txdesc_ie)
+#define IE2_SET_TX_DESC_MBSSID_8814B(txdesc_ie, value)                         \
+	IE2_SET_TX_DESC_MBSSID(txdesc_ie, value)
+#define IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET_8814B(txdesc_ie)                   \
+	IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie)
+#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET_8814B(txdesc_ie, value)            \
+	IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie, value)
+#define IE2_GET_TX_DESC_RDG_NAV_EXT_8814B(txdesc_ie)                           \
+	IE2_GET_TX_DESC_RDG_NAV_EXT(txdesc_ie)
+#define IE2_SET_TX_DESC_RDG_NAV_EXT_8814B(txdesc_ie, value)                    \
+	IE2_SET_TX_DESC_RDG_NAV_EXT(txdesc_ie, value)
+#define IE2_GET_TX_DESC_DROP_ID_8814B(txdesc_ie)                               \
+	IE2_GET_TX_DESC_DROP_ID(txdesc_ie)
+#define IE2_SET_TX_DESC_DROP_ID_8814B(txdesc_ie, value)                        \
+	IE2_SET_TX_DESC_DROP_ID(txdesc_ie, value)
+#define IE2_GET_TX_DESC_SW_DEFINE_8814B(txdesc_ie)                             \
+	IE2_GET_TX_DESC_SW_DEFINE(txdesc_ie)
+#define IE2_SET_TX_DESC_SW_DEFINE_8814B(txdesc_ie, value)                      \
+	IE2_SET_TX_DESC_SW_DEFINE(txdesc_ie, value)
+#define IE3_GET_TX_DESC_IE_END_8814B(txdesc_ie)                                \
+	IE3_GET_TX_DESC_IE_END(txdesc_ie)
+#define IE3_SET_TX_DESC_IE_END_8814B(txdesc_ie, value)                         \
+	IE3_SET_TX_DESC_IE_END(txdesc_ie, value)
+#define IE3_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE3_GET_TX_DESC_IE_UP(txdesc_ie)
+#define IE3_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value)                          \
+	IE3_SET_TX_DESC_IE_UP(txdesc_ie, value)
+#define IE3_GET_TX_DESC_IE_NUM_8814B(txdesc_ie)                                \
+	IE3_GET_TX_DESC_IE_NUM(txdesc_ie)
+#define IE3_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value)                         \
+	IE3_SET_TX_DESC_IE_NUM(txdesc_ie, value)
+#define IE3_GET_TX_DESC_DATA_SC_8814B(txdesc_ie)                               \
+	IE3_GET_TX_DESC_DATA_SC(txdesc_ie)
+#define IE3_SET_TX_DESC_DATA_SC_8814B(txdesc_ie, value)                        \
+	IE3_SET_TX_DESC_DATA_SC(txdesc_ie, value)
+#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC_8814B(txdesc_ie)                   \
+	IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC_8814B(txdesc_ie, value)            \
+	IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie, value)
+#define IE3_GET_TX_DESC_CTRL_CNT_8814B(txdesc_ie)                              \
+	IE3_GET_TX_DESC_CTRL_CNT(txdesc_ie)
+#define IE3_SET_TX_DESC_CTRL_CNT_8814B(txdesc_ie, value)                       \
+	IE3_SET_TX_DESC_CTRL_CNT(txdesc_ie, value)
+#define IE3_GET_TX_DESC_CTRL_CNT_VALID_8814B(txdesc_ie)                        \
+	IE3_GET_TX_DESC_CTRL_CNT_VALID(txdesc_ie)
+#define IE3_SET_TX_DESC_CTRL_CNT_VALID_8814B(txdesc_ie, value)                 \
+	IE3_SET_TX_DESC_CTRL_CNT_VALID(txdesc_ie, value)
+#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN_8814B(txdesc_ie)                   \
+	IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN_8814B(txdesc_ie, value)            \
+	IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie, value)
+#define IE3_GET_TX_DESC_G_ID_8814B(txdesc_ie) IE3_GET_TX_DESC_G_ID(txdesc_ie)
+#define IE3_SET_TX_DESC_G_ID_8814B(txdesc_ie, value)                           \
+	IE3_SET_TX_DESC_G_ID(txdesc_ie, value)
+#define IE3_GET_TX_DESC_SND_TARGET_8814B(txdesc_ie)                            \
+	IE3_GET_TX_DESC_SND_TARGET(txdesc_ie)
+#define IE3_SET_TX_DESC_SND_TARGET_8814B(txdesc_ie, value)                     \
+	IE3_SET_TX_DESC_SND_TARGET(txdesc_ie, value)
+#define IE3_GET_TX_DESC_CCA_RTS_8814B(txdesc_ie)                               \
+	IE3_GET_TX_DESC_CCA_RTS(txdesc_ie)
+#define IE3_SET_TX_DESC_CCA_RTS_8814B(txdesc_ie, value)                        \
+	IE3_SET_TX_DESC_CCA_RTS(txdesc_ie, value)
+#define IE3_GET_TX_DESC_SND_PKT_SEL_8814B(txdesc_ie)                           \
+	IE3_GET_TX_DESC_SND_PKT_SEL(txdesc_ie)
+#define IE3_SET_TX_DESC_SND_PKT_SEL_8814B(txdesc_ie, value)                    \
+	IE3_SET_TX_DESC_SND_PKT_SEL(txdesc_ie, value)
+#define IE3_GET_TX_DESC_NDPA_8814B(txdesc_ie) IE3_GET_TX_DESC_NDPA(txdesc_ie)
+#define IE3_SET_TX_DESC_NDPA_8814B(txdesc_ie, value)                           \
+	IE3_SET_TX_DESC_NDPA(txdesc_ie, value)
+#define IE3_GET_TX_DESC_MU_DATARATE_8814B(txdesc_ie)                           \
+	IE3_GET_TX_DESC_MU_DATARATE(txdesc_ie)
+#define IE3_SET_TX_DESC_MU_DATARATE_8814B(txdesc_ie, value)                    \
+	IE3_SET_TX_DESC_MU_DATARATE(txdesc_ie, value)
+#define IE4_GET_TX_DESC_IE_END_8814B(txdesc_ie)                                \
+	IE4_GET_TX_DESC_IE_END(txdesc_ie)
+#define IE4_SET_TX_DESC_IE_END_8814B(txdesc_ie, value)                         \
+	IE4_SET_TX_DESC_IE_END(txdesc_ie, value)
+#define IE4_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE4_GET_TX_DESC_IE_UP(txdesc_ie)
+#define IE4_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value)                          \
+	IE4_SET_TX_DESC_IE_UP(txdesc_ie, value)
+#define IE4_GET_TX_DESC_IE_NUM_8814B(txdesc_ie)                                \
+	IE4_GET_TX_DESC_IE_NUM(txdesc_ie)
+#define IE4_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value)                         \
+	IE4_SET_TX_DESC_IE_NUM(txdesc_ie, value)
+#define IE4_GET_TX_DESC_VCS_STBC_8814B(txdesc_ie)                              \
+	IE4_GET_TX_DESC_VCS_STBC(txdesc_ie)
+#define IE4_SET_TX_DESC_VCS_STBC_8814B(txdesc_ie, value)                       \
+	IE4_SET_TX_DESC_VCS_STBC(txdesc_ie, value)
+#define IE4_GET_TX_DESC_DATA_STBC_8814B(txdesc_ie)                             \
+	IE4_GET_TX_DESC_DATA_STBC(txdesc_ie)
+#define IE4_SET_TX_DESC_DATA_STBC_8814B(txdesc_ie, value)                      \
+	IE4_SET_TX_DESC_DATA_STBC(txdesc_ie, value)
+#define IE4_GET_TX_DESC_DATA_LDPC_8814B(txdesc_ie)                             \
+	IE4_GET_TX_DESC_DATA_LDPC(txdesc_ie)
+#define IE4_SET_TX_DESC_DATA_LDPC_8814B(txdesc_ie, value)                      \
+	IE4_SET_TX_DESC_DATA_LDPC(txdesc_ie, value)
+#define IE4_GET_TX_DESC_GF_8814B(txdesc_ie) IE4_GET_TX_DESC_GF(txdesc_ie)
+#define IE4_SET_TX_DESC_GF_8814B(txdesc_ie, value)                             \
+	IE4_SET_TX_DESC_GF(txdesc_ie, value)
+#define IE4_GET_TX_DESC_LSIG_TXOP_EN_8814B(txdesc_ie)                          \
+	IE4_GET_TX_DESC_LSIG_TXOP_EN(txdesc_ie)
+#define IE4_SET_TX_DESC_LSIG_TXOP_EN_8814B(txdesc_ie, value)                   \
+	IE4_SET_TX_DESC_LSIG_TXOP_EN(txdesc_ie, value)
+#define IE4_GET_TX_DESC_PATH_MAPA_8814B(txdesc_ie)                             \
+	IE4_GET_TX_DESC_PATH_MAPA(txdesc_ie)
+#define IE4_SET_TX_DESC_PATH_MAPA_8814B(txdesc_ie, value)                      \
+	IE4_SET_TX_DESC_PATH_MAPA(txdesc_ie, value)
+#define IE4_GET_TX_DESC_PATH_MAPB_8814B(txdesc_ie)                             \
+	IE4_GET_TX_DESC_PATH_MAPB(txdesc_ie)
+#define IE4_SET_TX_DESC_PATH_MAPB_8814B(txdesc_ie, value)                      \
+	IE4_SET_TX_DESC_PATH_MAPB(txdesc_ie, value)
+#define IE4_GET_TX_DESC_PATH_MAPC_8814B(txdesc_ie)                             \
+	IE4_GET_TX_DESC_PATH_MAPC(txdesc_ie)
+#define IE4_SET_TX_DESC_PATH_MAPC_8814B(txdesc_ie, value)                      \
+	IE4_SET_TX_DESC_PATH_MAPC(txdesc_ie, value)
+#define IE4_GET_TX_DESC_PATH_MAPD_8814B(txdesc_ie)                             \
+	IE4_GET_TX_DESC_PATH_MAPD(txdesc_ie)
+#define IE4_SET_TX_DESC_PATH_MAPD_8814B(txdesc_ie, value)                      \
+	IE4_SET_TX_DESC_PATH_MAPD(txdesc_ie, value)
+#define IE4_GET_TX_DESC_ANTSEL_A_8814B(txdesc_ie)                              \
+	IE4_GET_TX_DESC_ANTSEL_A(txdesc_ie)
+#define IE4_SET_TX_DESC_ANTSEL_A_8814B(txdesc_ie, value)                       \
+	IE4_SET_TX_DESC_ANTSEL_A(txdesc_ie, value)
+#define IE4_GET_TX_DESC_ANTSEL_B_8814B(txdesc_ie)                              \
+	IE4_GET_TX_DESC_ANTSEL_B(txdesc_ie)
+#define IE4_SET_TX_DESC_ANTSEL_B_8814B(txdesc_ie, value)                       \
+	IE4_SET_TX_DESC_ANTSEL_B(txdesc_ie, value)
+#define IE4_GET_TX_DESC_ANTSEL_C_8814B(txdesc_ie)                              \
+	IE4_GET_TX_DESC_ANTSEL_C(txdesc_ie)
+#define IE4_SET_TX_DESC_ANTSEL_C_8814B(txdesc_ie, value)                       \
+	IE4_SET_TX_DESC_ANTSEL_C(txdesc_ie, value)
+#define IE4_GET_TX_DESC_ANTSEL_D_8814B(txdesc_ie)                              \
+	IE4_GET_TX_DESC_ANTSEL_D(txdesc_ie)
+#define IE4_SET_TX_DESC_ANTSEL_D_8814B(txdesc_ie, value)                       \
+	IE4_SET_TX_DESC_ANTSEL_D(txdesc_ie, value)
+#define IE4_GET_TX_DESC_NTX_PATH_EN_8814B(txdesc_ie)                           \
+	IE4_GET_TX_DESC_NTX_PATH_EN(txdesc_ie)
+#define IE4_SET_TX_DESC_NTX_PATH_EN_8814B(txdesc_ie, value)                    \
+	IE4_SET_TX_DESC_NTX_PATH_EN(txdesc_ie, value)
+#define IE4_GET_TX_DESC_ANTLSEL_EN_8814B(txdesc_ie)                            \
+	IE4_GET_TX_DESC_ANTLSEL_EN(txdesc_ie)
+#define IE4_SET_TX_DESC_ANTLSEL_EN_8814B(txdesc_ie, value)                     \
+	IE4_SET_TX_DESC_ANTLSEL_EN(txdesc_ie, value)
+#define IE4_GET_TX_DESC_TXPWR_OFSET_TYPE_8814B(txdesc_ie)                      \
+	IE4_GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie)
+#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE_8814B(txdesc_ie, value)               \
+	IE4_SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie, value)
+#define IE5_GET_TX_DESC_IE_END_8814B(txdesc_ie)                                \
+	IE5_GET_TX_DESC_IE_END(txdesc_ie)
+#define IE5_SET_TX_DESC_IE_END_8814B(txdesc_ie, value)                         \
+	IE5_SET_TX_DESC_IE_END(txdesc_ie, value)
+#define IE5_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE5_GET_TX_DESC_IE_UP(txdesc_ie)
+#define IE5_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value)                          \
+	IE5_SET_TX_DESC_IE_UP(txdesc_ie, value)
+#define IE5_GET_TX_DESC_IE_NUM_8814B(txdesc_ie)                                \
+	IE5_GET_TX_DESC_IE_NUM(txdesc_ie)
+#define IE5_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value)                         \
+	IE5_SET_TX_DESC_IE_NUM(txdesc_ie, value)
+#define IE5_GET_TX_DESC_LEN1_L_8814B(txdesc_ie)                                \
+	IE5_GET_TX_DESC_LEN1_L(txdesc_ie)
+#define IE5_SET_TX_DESC_LEN1_L_8814B(txdesc_ie, value)                         \
+	IE5_SET_TX_DESC_LEN1_L(txdesc_ie, value)
+#define IE5_GET_TX_DESC_LEN0_8814B(txdesc_ie) IE5_GET_TX_DESC_LEN0(txdesc_ie)
+#define IE5_SET_TX_DESC_LEN0_8814B(txdesc_ie, value)                           \
+	IE5_SET_TX_DESC_LEN0(txdesc_ie, value)
+#define IE5_GET_TX_DESC_PKT_NUM_8814B(txdesc_ie)                               \
+	IE5_GET_TX_DESC_PKT_NUM(txdesc_ie)
+#define IE5_SET_TX_DESC_PKT_NUM_8814B(txdesc_ie, value)                        \
+	IE5_SET_TX_DESC_PKT_NUM(txdesc_ie, value)
+#define IE5_GET_TX_DESC_LEN3_8814B(txdesc_ie) IE5_GET_TX_DESC_LEN3(txdesc_ie)
+#define IE5_SET_TX_DESC_LEN3_8814B(txdesc_ie, value)                           \
+	IE5_SET_TX_DESC_LEN3(txdesc_ie, value)
+#define IE5_GET_TX_DESC_LEN2_8814B(txdesc_ie) IE5_GET_TX_DESC_LEN2(txdesc_ie)
+#define IE5_SET_TX_DESC_LEN2_8814B(txdesc_ie, value)                           \
+	IE5_SET_TX_DESC_LEN2(txdesc_ie, value)
+#define IE5_GET_TX_DESC_LEN1_H_8814B(txdesc_ie)                                \
+	IE5_GET_TX_DESC_LEN1_H(txdesc_ie)
+#define IE5_SET_TX_DESC_LEN1_H_8814B(txdesc_ie, value)                         \
+	IE5_SET_TX_DESC_LEN1_H(txdesc_ie, value)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_nic.h
new file mode 100644
index 000000000000..c88f8fa7be0b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_ie_nic.h
@@ -0,0 +1,450 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_IE_NIC_H_
+#define _HALMAC_TX_DESC_IE_NIC_H_
+#if (HALMAC_8814B_SUPPORT)
+
+#define IE0_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
+#define IE0_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
+#define IE0_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
+#define IE0_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
+#define IE0_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
+#define IE0_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
+#define IE0_GET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie)                              \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 19, 1)
+#define IE0_SET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie, value)                       \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 19, 1, value)
+#define IE0_GET_TX_DESC_ARFR_HT_EN(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 18, 1)
+#define IE0_SET_TX_DESC_ARFR_HT_EN(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 18, 1, value)
+#define IE0_GET_TX_DESC_ARFR_OFDM_EN(txdesc_ie)                                \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 17, 1)
+#define IE0_SET_TX_DESC_ARFR_OFDM_EN(txdesc_ie, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 17, 1, value)
+#define IE0_GET_TX_DESC_ARFR_CCK_EN(txdesc_ie)                                 \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 1)
+#define IE0_SET_TX_DESC_ARFR_CCK_EN(txdesc_ie, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 1, value)
+#define IE0_GET_TX_DESC_HW_RTS_EN(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 9, 1)
+#define IE0_SET_TX_DESC_HW_RTS_EN(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 9, 1, value)
+#define IE0_GET_TX_DESC_RTS_EN(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 1)
+#define IE0_SET_TX_DESC_RTS_EN(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 1, value)
+#define IE0_GET_TX_DESC_CTS2SELF(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 7, 1)
+#define IE0_SET_TX_DESC_CTS2SELF(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 7, 1, value)
+#define IE0_GET_TX_DESC_RTY_LMT_EN(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 6, 1)
+#define IE0_SET_TX_DESC_RTY_LMT_EN(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 6, 1, value)
+#define IE0_GET_TX_DESC_RTS_SHORT(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 5, 1)
+#define IE0_SET_TX_DESC_RTS_SHORT(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 5, 1, value)
+#define IE0_GET_TX_DESC_DISDATAFB(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 1)
+#define IE0_SET_TX_DESC_DISDATAFB(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 1, value)
+#define IE0_GET_TX_DESC_DISRTSFB(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 3, 1)
+#define IE0_SET_TX_DESC_DISRTSFB(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 3, 1, value)
+#define IE0_GET_TX_DESC_DATA_SHORT(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
+#define IE0_SET_TX_DESC_DATA_SHORT(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
+#define IE0_GET_TX_DESC_TRY_RATE(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
+#define IE0_SET_TX_DESC_TRY_RATE(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
+#define IE0_GET_TX_DESC_USERATE(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
+#define IE0_SET_TX_DESC_USERATE(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
+#define IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie)                         \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 27, 4)
+#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 27, 4, value)
+#define IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie)                        \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 22, 5)
+#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie, value)                 \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 22, 5, value)
+#define IE0_GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie)                            \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 6)
+#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie, value)                     \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 6, value)
+#define IE0_GET_TX_DESC_DATA_BW(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 12, 2)
+#define IE0_SET_TX_DESC_DATA_BW(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 12, 2, value)
+#define IE0_GET_TX_DESC_RTSRATE(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 7, 4)
+#define IE0_SET_TX_DESC_RTSRATE(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 7, 4, value)
+#define IE0_GET_TX_DESC_DATARATE(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 7)
+#define IE0_SET_TX_DESC_DATARATE(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 7, value)
+#define IE1_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
+#define IE1_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
+#define IE1_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
+#define IE1_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
+#define IE1_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
+#define IE1_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
+#define IE1_GET_TX_DESC_AMPDU_DENSITY(txdesc_ie)                               \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 21, 3)
+#define IE1_SET_TX_DESC_AMPDU_DENSITY(txdesc_ie, value)                        \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 21, 3, value)
+#define IE1_GET_TX_DESC_MAX_AGG_NUM(txdesc_ie)                                 \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 5)
+#define IE1_SET_TX_DESC_MAX_AGG_NUM(txdesc_ie, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 5, value)
+#define IE1_GET_TX_DESC_SECTYPE(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 14, 2)
+#define IE1_SET_TX_DESC_SECTYPE(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 14, 2, value)
+#define IE1_GET_TX_DESC_MOREFRAG(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 13, 1)
+#define IE1_SET_TX_DESC_MOREFRAG(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 13, 1, value)
+#define IE1_GET_TX_DESC_NOACM(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 12, 1)
+#define IE1_SET_TX_DESC_NOACM(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 12, 1, value)
+#define IE1_GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie)                             \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 11, 1)
+#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie, value)                      \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 11, 1, value)
+#define IE1_GET_TX_DESC_NAVUSEHDR(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 10, 1)
+#define IE1_SET_TX_DESC_NAVUSEHDR(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 10, 1, value)
+#define IE1_GET_TX_DESC_HTC(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 9, 1)
+#define IE1_SET_TX_DESC_HTC(txdesc_ie, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 9, 1, value)
+#define IE1_GET_TX_DESC_BMC(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 1)
+#define IE1_SET_TX_DESC_BMC(txdesc_ie, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 1, value)
+#define IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie)                           \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 7, 1)
+#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie, value)                    \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 7, 1, value)
+#define IE1_GET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie)                             \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 6, 1)
+#define IE1_SET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie, value)                      \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 6, 1, value)
+#define IE1_GET_TX_DESC_HW_SSN_SEL(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 2)
+#define IE1_SET_TX_DESC_HW_SSN_SEL(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 2, value)
+#define IE1_GET_TX_DESC_DISQSELSEQ(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 3, 1)
+#define IE1_SET_TX_DESC_DISQSELSEQ(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 3, 1, value)
+#define IE1_GET_TX_DESC_EN_HWSEQ(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
+#define IE1_SET_TX_DESC_EN_HWSEQ(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
+#define IE1_GET_TX_DESC_EN_HWEXSEQ(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
+#define IE1_SET_TX_DESC_EN_HWEXSEQ(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
+#define IE1_GET_TX_DESC_EN_DESC_ID(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
+#define IE1_SET_TX_DESC_EN_DESC_ID(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
+#define IE1_GET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie)                              \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 24, 8)
+#define IE1_SET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie, value)                       \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 24, 8, value)
+#define IE1_GET_TX_DESC_P_AID(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 15, 9)
+#define IE1_SET_TX_DESC_P_AID(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 15, 9, value)
+#define IE1_GET_TX_DESC_MOREDATA(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 14, 1)
+#define IE1_SET_TX_DESC_MOREDATA(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 14, 1, value)
+#define IE1_GET_TX_DESC_SW_SEQ(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 12)
+#define IE1_SET_TX_DESC_SW_SEQ(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 12, value)
+#define IE2_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
+#define IE2_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
+#define IE2_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
+#define IE2_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
+#define IE2_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
+#define IE2_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
+#define IE2_GET_TX_DESC_ADDR_CAM(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 8)
+#define IE2_SET_TX_DESC_ADDR_CAM(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 8, value)
+#define IE2_GET_TX_DESC_MULTIPLE_PORT(txdesc_ie)                               \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 12, 3)
+#define IE2_SET_TX_DESC_MULTIPLE_PORT(txdesc_ie, value)                        \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 12, 3, value)
+#define IE2_GET_TX_DESC_RAW(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 11, 1)
+#define IE2_SET_TX_DESC_RAW(txdesc_ie, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 11, 1, value)
+#define IE2_GET_TX_DESC_RDG_EN(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 10, 1)
+#define IE2_SET_TX_DESC_RDG_EN(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 10, 1, value)
+#define IE2_GET_TX_DESC_SPECIAL_CW(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 7, 1)
+#define IE2_SET_TX_DESC_SPECIAL_CW(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 7, 1, value)
+#define IE2_GET_TX_DESC_POLLUTED(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 6, 1)
+#define IE2_SET_TX_DESC_POLLUTED(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 6, 1, value)
+#define IE2_GET_TX_DESC_BT_NULL(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 5, 1)
+#define IE2_SET_TX_DESC_BT_NULL(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 5, 1, value)
+#define IE2_GET_TX_DESC_NULL_1(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 1)
+#define IE2_SET_TX_DESC_NULL_1(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 1, value)
+#define IE2_GET_TX_DESC_NULL_0(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 3, 1)
+#define IE2_SET_TX_DESC_NULL_0(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 3, 1, value)
+#define IE2_GET_TX_DESC_TRI_FRAME(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
+#define IE2_SET_TX_DESC_TRI_FRAME(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
+#define IE2_GET_TX_DESC_SPE_RPT(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
+#define IE2_SET_TX_DESC_SPE_RPT(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
+#define IE2_GET_TX_DESC_FTM_EN(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
+#define IE2_SET_TX_DESC_FTM_EN(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
+#define IE2_GET_TX_DESC_MBSSID(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 27, 4)
+#define IE2_SET_TX_DESC_MBSSID(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 27, 4, value)
+#define IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie)                         \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 11)
+#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 11, value)
+#define IE2_GET_TX_DESC_RDG_NAV_EXT(txdesc_ie)                                 \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 15, 1)
+#define IE2_SET_TX_DESC_RDG_NAV_EXT(txdesc_ie, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 15, 1, value)
+#define IE2_GET_TX_DESC_DROP_ID(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 12, 2)
+#define IE2_SET_TX_DESC_DROP_ID(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 12, 2, value)
+#define IE2_GET_TX_DESC_SW_DEFINE(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 12)
+#define IE2_SET_TX_DESC_SW_DEFINE(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 12, value)
+#define IE3_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
+#define IE3_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
+#define IE3_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
+#define IE3_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
+#define IE3_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
+#define IE3_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
+#define IE3_GET_TX_DESC_DATA_SC(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 20, 4)
+#define IE3_SET_TX_DESC_DATA_SC(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 20, 4, value)
+#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie)                         \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 4)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 4, value)
+#define IE3_GET_TX_DESC_CTRL_CNT(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 4)
+#define IE3_SET_TX_DESC_CTRL_CNT(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 4, value)
+#define IE3_GET_TX_DESC_CTRL_CNT_VALID(txdesc_ie)                              \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
+#define IE3_SET_TX_DESC_CTRL_CNT_VALID(txdesc_ie, value)                       \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
+#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie)                         \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
+#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie, value)                  \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
+#define IE3_GET_TX_DESC_G_ID(txdesc_ie)                                        \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 24, 6)
+#define IE3_SET_TX_DESC_G_ID(txdesc_ie, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 24, 6, value)
+#define IE3_GET_TX_DESC_SND_TARGET(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 8)
+#define IE3_SET_TX_DESC_SND_TARGET(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 8, value)
+#define IE3_GET_TX_DESC_CCA_RTS(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 11, 2)
+#define IE3_SET_TX_DESC_CCA_RTS(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 11, 2, value)
+#define IE3_GET_TX_DESC_SND_PKT_SEL(txdesc_ie)                                 \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 9, 2)
+#define IE3_SET_TX_DESC_SND_PKT_SEL(txdesc_ie, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 9, 2, value)
+#define IE3_GET_TX_DESC_NDPA(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 7, 2)
+#define IE3_SET_TX_DESC_NDPA(txdesc_ie, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 7, 2, value)
+#define IE3_GET_TX_DESC_MU_DATARATE(txdesc_ie)                                 \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 7)
+#define IE3_SET_TX_DESC_MU_DATARATE(txdesc_ie, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 7, value)
+#define IE4_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
+#define IE4_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
+#define IE4_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
+#define IE4_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
+#define IE4_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
+#define IE4_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
+#define IE4_GET_TX_DESC_VCS_STBC(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 10, 2)
+#define IE4_SET_TX_DESC_VCS_STBC(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 10, 2, value)
+#define IE4_GET_TX_DESC_DATA_STBC(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 2)
+#define IE4_SET_TX_DESC_DATA_STBC(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 2, value)
+#define IE4_GET_TX_DESC_DATA_LDPC(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
+#define IE4_SET_TX_DESC_DATA_LDPC(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
+#define IE4_GET_TX_DESC_GF(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
+#define IE4_SET_TX_DESC_GF(txdesc_ie, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
+#define IE4_GET_TX_DESC_LSIG_TXOP_EN(txdesc_ie)                                \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
+#define IE4_SET_TX_DESC_LSIG_TXOP_EN(txdesc_ie, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
+#define IE4_GET_TX_DESC_PATH_MAPA(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 30, 2)
+#define IE4_SET_TX_DESC_PATH_MAPA(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 30, 2, value)
+#define IE4_GET_TX_DESC_PATH_MAPB(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 28, 2)
+#define IE4_SET_TX_DESC_PATH_MAPB(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 28, 2, value)
+#define IE4_GET_TX_DESC_PATH_MAPC(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 26, 2)
+#define IE4_SET_TX_DESC_PATH_MAPC(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 26, 2, value)
+#define IE4_GET_TX_DESC_PATH_MAPD(txdesc_ie)                                   \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 24, 2)
+#define IE4_SET_TX_DESC_PATH_MAPD(txdesc_ie, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 24, 2, value)
+#define IE4_GET_TX_DESC_ANTSEL_A(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 20, 4)
+#define IE4_SET_TX_DESC_ANTSEL_A(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 20, 4, value)
+#define IE4_GET_TX_DESC_ANTSEL_B(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 4)
+#define IE4_SET_TX_DESC_ANTSEL_B(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 4, value)
+#define IE4_GET_TX_DESC_ANTSEL_C(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 12, 4)
+#define IE4_SET_TX_DESC_ANTSEL_C(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 12, 4, value)
+#define IE4_GET_TX_DESC_ANTSEL_D(txdesc_ie)                                    \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 8, 4)
+#define IE4_SET_TX_DESC_ANTSEL_D(txdesc_ie, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 8, 4, value)
+#define IE4_GET_TX_DESC_NTX_PATH_EN(txdesc_ie)                                 \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 4, 4)
+#define IE4_SET_TX_DESC_NTX_PATH_EN(txdesc_ie, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 4, 4, value)
+#define IE4_GET_TX_DESC_ANTLSEL_EN(txdesc_ie)                                  \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 3, 1)
+#define IE4_SET_TX_DESC_ANTLSEL_EN(txdesc_ie, value)                           \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 3, 1, value)
+#define IE4_GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie)                            \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 2)
+#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie, value)                     \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 2, value)
+#define IE5_GET_TX_DESC_IE_END(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
+#define IE5_SET_TX_DESC_IE_END(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
+#define IE5_GET_TX_DESC_IE_UP(txdesc_ie)                                       \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
+#define IE5_SET_TX_DESC_IE_UP(txdesc_ie, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
+#define IE5_GET_TX_DESC_IE_NUM(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
+#define IE5_SET_TX_DESC_IE_NUM(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
+#define IE5_GET_TX_DESC_LEN1_L(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 17, 7)
+#define IE5_SET_TX_DESC_LEN1_L(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 17, 7, value)
+#define IE5_GET_TX_DESC_LEN0(txdesc_ie)                                        \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 13)
+#define IE5_SET_TX_DESC_LEN0(txdesc_ie, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 13, value)
+#define IE5_GET_TX_DESC_PKT_NUM(txdesc_ie)                                     \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 4)
+#define IE5_SET_TX_DESC_PKT_NUM(txdesc_ie, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 4, value)
+#define IE5_GET_TX_DESC_LEN3(txdesc_ie)                                        \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 19, 13)
+#define IE5_SET_TX_DESC_LEN3(txdesc_ie, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 19, 13, value)
+#define IE5_GET_TX_DESC_LEN2(txdesc_ie)                                        \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 6, 13)
+#define IE5_SET_TX_DESC_LEN2(txdesc_ie, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 6, 13, value)
+#define IE5_GET_TX_DESC_LEN1_H(txdesc_ie)                                      \
+	LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 6)
+#define IE5_SET_TX_DESC_LEN1_H(txdesc_ie, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 6, value)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_nic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_nic.h
new file mode 100644
index 000000000000..59a614fe8c7a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_tx_desc_nic.h
@@ -0,0 +1,951 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TX_DESC_NIC_H_
+#define _HALMAC_TX_DESC_NIC_H_
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD0*/
+
+#define SET_TX_DESC_DISQSELSEQ(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 31, 1, value)
+#define GET_TX_DESC_DISQSELSEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 31, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_IE_END_BODY(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 31, 1, value)
+#define GET_TX_DESC_IE_END_BODY(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 31, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_GF(txdesc, value)                                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 30, 1, value)
+#define GET_TX_DESC_GF(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 30, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_AGG_EN_V1(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 30, 1, value)
+#define GET_TX_DESC_AGG_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 30, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_NO_ACM(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 29, 1, value)
+#define GET_TX_DESC_NO_ACM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 29, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_BK_V1(txdesc, value)                                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 29, 1, value)
+#define GET_TX_DESC_BK_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 29, 1)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 28, 1, value)
+#define GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x00, 28, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 27, 1, value)
+#define GET_TX_DESC_AMSDU_PAD_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 27, 1)
+#define SET_TX_DESC_LS(txdesc, value)                                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 26, 1, value)
+#define GET_TX_DESC_LS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 26, 1)
+#define SET_TX_DESC_HTC(txdesc, value)                                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 25, 1, value)
+#define GET_TX_DESC_HTC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 25, 1)
+#define SET_TX_DESC_BMC(txdesc, value)                                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 24, 1, value)
+#define GET_TX_DESC_BMC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 24, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_PKT_OFFSET_V1(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 24, 5, value)
+#define GET_TX_DESC_PKT_OFFSET_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 24, 5)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_OFFSET(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 16, 8, value)
+#define GET_TX_DESC_OFFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 16, 8)
+#define SET_TX_DESC_TXPKTSIZE(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 0, 16, value)
+#define GET_TX_DESC_TXPKTSIZE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 0, 16)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+/*WORD1*/
+
+#define SET_TX_DESC_HW_AES_IV_V2(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 31, 1, value)
+#define GET_TX_DESC_HW_AES_IV_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 31, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_AMSDU(txdesc, value)                                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 30, 1, value)
+#define GET_TX_DESC_AMSDU(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 30, 1)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_FTM_EN_V1(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 30, 1, value)
+#define GET_TX_DESC_FTM_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 30, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MOREDATA(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 29, 1, value)
+#define GET_TX_DESC_MOREDATA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 29, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_HW_AES_IV_V1(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 29, 1, value)
+#define GET_TX_DESC_HW_AES_IV_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 29, 1)
+#define SET_TX_DESC_MHR_CP(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 25, 1, value)
+#define GET_TX_DESC_MHR_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 25, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_PKT_OFFSET(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 24, 5, value)
+#define GET_TX_DESC_PKT_OFFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 24, 5)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_SMH_EN_V1(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 24, 1, value)
+#define GET_TX_DESC_SMH_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 24, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SEC_TYPE(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 22, 2, value)
+#define GET_TX_DESC_SEC_TYPE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 22, 2)
+#define SET_TX_DESC_EN_DESC_ID(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 21, 1, value)
+#define GET_TX_DESC_EN_DESC_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 21, 1)
+#define SET_TX_DESC_RATE_ID(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 16, 5, value)
+#define GET_TX_DESC_RATE_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 16, 5)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_SMH_CAM(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 16, 8, value)
+#define GET_TX_DESC_SMH_CAM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 16, 8)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_PIFS(txdesc, value)                                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 15, 1, value)
+#define GET_TX_DESC_PIFS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 15, 1)
+#define SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 14, 1, value)
+#define GET_TX_DESC_LSIG_TXOP_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 14, 1)
+#define SET_TX_DESC_RD_NAV_EXT(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 13, 1, value)
+#define GET_TX_DESC_RD_NAV_EXT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 13, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_EXT_EDCA(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 13, 1, value)
+#define GET_TX_DESC_EXT_EDCA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 13, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_QSEL(txdesc, value)                                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 8, 5, value)
+#define GET_TX_DESC_QSEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 8, 5)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_SPECIAL_CW(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 7, 1, value)
+#define GET_TX_DESC_SPECIAL_CW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 7, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MACID(txdesc, value)                                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 0, 7, value)
+#define GET_TX_DESC_MACID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 0, 7)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_MACID_V1(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 0, 7, value)
+#define GET_TX_DESC_MACID_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 0, 7)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD2*/
+
+#define SET_TX_DESC_HW_AES_IV(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 31, 1, value)
+#define GET_TX_DESC_HW_AES_IV(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 31, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_CHK_EN_V1(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 31, 1, value)
+#define GET_TX_DESC_CHK_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 31, 1)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_FTM_EN(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 30, 1, value)
+#define GET_TX_DESC_FTM_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 30, 1)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTCEL_D_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 28, 4, value)
+#define GET_TX_DESC_ANTCEL_D_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 28, 4)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_DMA_PRI(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 27, 1, value)
+#define GET_TX_DESC_DMA_PRI(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 27, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_G_ID(txdesc, value)                                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 6, value)
+#define GET_TX_DESC_G_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 6)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_MAX_AMSDU_MODE(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 3, value)
+#define GET_TX_DESC_MAX_AMSDU_MODE(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 3)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_C_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 4, value)
+#define GET_TX_DESC_ANTSEL_C_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_BT_NULL(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 23, 1, value)
+#define GET_TX_DESC_BT_NULL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 23, 1)
+#define SET_TX_DESC_AMPDU_DENSITY(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 20, 3, value)
+#define GET_TX_DESC_AMPDU_DENSITY(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 20, 3)
+#define SET_TX_DESC_SPE_RPT(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 19, 1, value)
+#define GET_TX_DESC_SPE_RPT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 19, 1)
+#define SET_TX_DESC_RAW(txdesc, value)                                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 18, 1, value)
+#define GET_TX_DESC_RAW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 18, 1)
+#define SET_TX_DESC_MOREFRAG(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 17, 1, value)
+#define GET_TX_DESC_MOREFRAG(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 17, 1)
+#define SET_TX_DESC_BK(txdesc, value)                                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 16, 1, value)
+#define GET_TX_DESC_BK(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 16, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 16, 8, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 16, 8)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_NULL_1(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 15, 1, value)
+#define GET_TX_DESC_NULL_1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 15, 1)
+#define SET_TX_DESC_NULL_0(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 14, 1, value)
+#define GET_TX_DESC_NULL_0(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 14, 1)
+#define SET_TX_DESC_RDG_EN(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 13, 1, value)
+#define GET_TX_DESC_RDG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 13, 1)
+#define SET_TX_DESC_AGG_EN(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 12, 1, value)
+#define GET_TX_DESC_AGG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 12, 1)
+#define SET_TX_DESC_CCA_RTS(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 10, 2, value)
+#define GET_TX_DESC_CCA_RTS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 10, 2)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TRI_FRAME(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 9, 1, value)
+#define GET_TX_DESC_TRI_FRAME(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 9, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_P_AID(txdesc, value)                                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 0, 9, value)
+#define GET_TX_DESC_P_AID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 0, 9)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 0, 16, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x08, 0, 16)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD3*/
+
+#define SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 24, 8, value)
+#define GET_TX_DESC_AMPDU_MAX_TIME(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x0C, 24, 8)
+#define SET_TX_DESC_NDPA(txdesc, value)                                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 22, 2, value)
+#define GET_TX_DESC_NDPA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 22, 2)
+#define SET_TX_DESC_MAX_AGG_NUM(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 17, 5, value)
+#define GET_TX_DESC_MAX_AGG_NUM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 17, 5)
+#define SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 16, 1, value)
+#define GET_TX_DESC_USE_MAX_TIME_EN(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x0C, 16, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_OFFLOAD_SIZE(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 16, 15, value)
+#define GET_TX_DESC_OFFLOAD_SIZE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 16, 15)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_NAVUSEHDR(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 15, 1, value)
+#define GET_TX_DESC_NAVUSEHDR(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 15, 1)
+#define SET_TX_DESC_CHK_EN(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 14, 1, value)
+#define GET_TX_DESC_CHK_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 14, 1)
+#define SET_TX_DESC_HW_RTS_EN(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 13, 1, value)
+#define GET_TX_DESC_HW_RTS_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 13, 1)
+#define SET_TX_DESC_RTSEN(txdesc, value)                                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 12, 1, value)
+#define GET_TX_DESC_RTSEN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 12, 1)
+#define SET_TX_DESC_CTS2SELF(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 11, 1, value)
+#define GET_TX_DESC_CTS2SELF(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 11, 1)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_CHANNEL_DMA(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 11, 5, value)
+#define GET_TX_DESC_CHANNEL_DMA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 11, 5)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_DISDATAFB(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 10, 1, value)
+#define GET_TX_DESC_DISDATAFB(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 10, 1)
+#define SET_TX_DESC_DISRTSFB(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 9, 1, value)
+#define GET_TX_DESC_DISRTSFB(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 9, 1)
+#define SET_TX_DESC_USE_RATE(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 8, 1, value)
+#define GET_TX_DESC_USE_RATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 8, 1)
+#define SET_TX_DESC_HW_SSN_SEL(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 6, 2, value)
+#define GET_TX_DESC_HW_SSN_SEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 6, 2)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_IE_CNT(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 6, 3, value)
+#define GET_TX_DESC_IE_CNT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 6, 3)
+#define SET_TX_DESC_IE_CNT_EN(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 5, 1, value)
+#define GET_TX_DESC_IE_CNT_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 5, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_WHEADER_LEN(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 0, 5, value)
+#define GET_TX_DESC_WHEADER_LEN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 0, 5)
+
+#endif
+
+#if (HALMAC_8814B_SUPPORT)
+
+#define SET_TX_DESC_WHEADER_LEN_V1(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 0, 5, value)
+#define GET_TX_DESC_WHEADER_LEN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 0, 5)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD4*/
+
+#define SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 30, 2, value)
+#define GET_TX_DESC_PCTS_MASK_IDX(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 30, 2)
+#define SET_TX_DESC_PCTS_EN(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 29, 1, value)
+#define GET_TX_DESC_PCTS_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 29, 1)
+#define SET_TX_DESC_RTSRATE(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 24, 5, value)
+#define GET_TX_DESC_RTSRATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 24, 5)
+#define SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 18, 6, value)
+#define GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 18, 6)
+#define SET_TX_DESC_RTY_LMT_EN(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 17, 1, value)
+#define GET_TX_DESC_RTY_LMT_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 17, 1)
+#define SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 13, 4, value)
+#define GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)                                \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 13, 4)
+#define SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)                        \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 8, 5, value)
+#define GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)                               \
+	LE_BITS_TO_4BYTE(txdesc + 0x10, 8, 5)
+#define SET_TX_DESC_TRY_RATE(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 7, 1, value)
+#define GET_TX_DESC_TRY_RATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 7, 1)
+#define SET_TX_DESC_DATARATE(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 0, 7, value)
+#define GET_TX_DESC_DATARATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 0, 7)
+
+/*TXDESC_WORD5*/
+
+#define SET_TX_DESC_POLLUTED(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 31, 1, value)
+#define GET_TX_DESC_POLLUTED(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 31, 1)
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_EN_V1(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 30, 1, value)
+#define GET_TX_DESC_ANTSEL_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 30, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_TXPWR_OFSET(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 28, 3, value)
+#define GET_TX_DESC_TXPWR_OFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 28, 3)
+
+#endif
+
+#if (HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc, value)                            \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 28, 2, value)
+#define GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc)                                   \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 28, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TX_ANT(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 24, 4, value)
+#define GET_TX_DESC_TX_ANT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 24, 4)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_DROP_ID(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 24, 2, value)
+#define GET_TX_DESC_DROP_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 24, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_PORT_ID(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 21, 3, value)
+#define GET_TX_DESC_PORT_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 21, 3)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT ||   \
+     HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MULTIPLE_PORT(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 18, 3, value)
+#define GET_TX_DESC_MULTIPLE_PORT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 18, 3)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)                          \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 17, 1, value)
+#define GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)                                 \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 17, 1)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_RTS_SC(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 13, 4, value)
+#define GET_TX_DESC_RTS_SC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 13, 4)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 13, 4, value)
+#define GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)                                \
+	LE_BITS_TO_4BYTE(txdesc + 0x14, 13, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_RTS_SHORT(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 12, 1, value)
+#define GET_TX_DESC_RTS_SHORT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 12, 1)
+#define SET_TX_DESC_VCS_STBC(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 10, 2, value)
+#define GET_TX_DESC_VCS_STBC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 10, 2)
+#define SET_TX_DESC_DATA_STBC(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 8, 2, value)
+#define GET_TX_DESC_DATA_STBC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 8, 2)
+#define SET_TX_DESC_DATA_LDPC(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 7, 1, value)
+#define GET_TX_DESC_DATA_LDPC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 7, 1)
+#define SET_TX_DESC_DATA_BW(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 5, 2, value)
+#define GET_TX_DESC_DATA_BW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 5, 2)
+#define SET_TX_DESC_DATA_SHORT(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 4, 1, value)
+#define GET_TX_DESC_DATA_SHORT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 4, 1)
+#define SET_TX_DESC_DATA_SC(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 0, 4, value)
+#define GET_TX_DESC_DATA_SC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 0, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD6*/
+
+#define SET_TX_DESC_ANTSEL_D(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 30, 2, value)
+#define GET_TX_DESC_ANTSEL_D(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 30, 2)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPD_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 30, 2, value)
+#define GET_TX_DESC_ANT_MAPD_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 30, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPD(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 28, 2, value)
+#define GET_TX_DESC_ANT_MAPD(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 28, 2)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPC_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 28, 2, value)
+#define GET_TX_DESC_ANT_MAPC_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 28, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPC(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 26, 2, value)
+#define GET_TX_DESC_ANT_MAPC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 26, 2)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPB_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 26, 2, value)
+#define GET_TX_DESC_ANT_MAPB_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 26, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPB(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 24, 2, value)
+#define GET_TX_DESC_ANT_MAPB(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 24, 2)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPA_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 24, 2, value)
+#define GET_TX_DESC_ANT_MAPA_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 24, 2)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANT_MAPA(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 22, 2, value)
+#define GET_TX_DESC_ANT_MAPA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 22, 2)
+#define SET_TX_DESC_ANTSEL_C(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 20, 2, value)
+#define GET_TX_DESC_ANTSEL_C(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 20, 2)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_B_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 20, 4, value)
+#define GET_TX_DESC_ANTSEL_B_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 20, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_B(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 18, 2, value)
+#define GET_TX_DESC_ANTSEL_B(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 18, 2)
+#define SET_TX_DESC_ANTSEL_A(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 16, 2, value)
+#define GET_TX_DESC_ANTSEL_A(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 16, 2)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_A_V1(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 16, 4, value)
+#define GET_TX_DESC_ANTSEL_A_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 16, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_MBSSID(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 12, 4, value)
+#define GET_TX_DESC_MBSSID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 12, 4)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_SW_DEFINE(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 0, 12, value)
+#define GET_TX_DESC_SW_DEFINE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 0, 12)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_SWPS_SEQ(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 0, 12, value)
+#define GET_TX_DESC_SWPS_SEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 0, 12)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*TXDESC_WORD7*/
+
+#define SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 24, 8, value)
+#define GET_TX_DESC_DMA_TXAGG_NUM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 24, 8)
+#define SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 24, 8, value)
+#define GET_TX_DESC_FINAL_DATA_RATE(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x1C, 24, 8)
+#define SET_TX_DESC_NTX_MAP(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 20, 4, value)
+#define GET_TX_DESC_NTX_MAP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 20, 4)
+
+#endif
+
+#if (HALMAC_8198F_SUPPORT)
+
+#define SET_TX_DESC_ANTSEL_EN(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 19, 1, value)
+#define GET_TX_DESC_ANTSEL_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 19, 1)
+#define SET_TX_DESC_MBSSID_EX(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 16, 3, value)
+#define GET_TX_DESC_MBSSID_EX(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 16, 3)
+
+#endif
+
+#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT ||   \
+     HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
+
+#define SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 16, value)
+#define GET_TX_DESC_TX_BUFF_SIZE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 16)
+#define SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)                             \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 16, value)
+#define GET_TX_DESC_TXDESC_CHECKSUM(txdesc)                                    \
+	LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 16)
+#define SET_TX_DESC_TIMESTAMP(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 16, value)
+#define GET_TX_DESC_TIMESTAMP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 16)
+
+/*TXDESC_WORD8*/
+
+#define SET_TX_DESC_TXWIFI_CP(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 31, 1, value)
+#define GET_TX_DESC_TXWIFI_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 31, 1)
+#define SET_TX_DESC_MAC_CP(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 30, 1, value)
+#define GET_TX_DESC_MAC_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 30, 1)
+#define SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)                               \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 29, 1, value)
+#define GET_TX_DESC_STW_PKTRE_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 29, 1)
+#define SET_TX_DESC_STW_RB_DIS(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 28, 1, value)
+#define GET_TX_DESC_STW_RB_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 28, 1)
+#define SET_TX_DESC_STW_RATE_DIS(txdesc, value)                                \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 27, 1, value)
+#define GET_TX_DESC_STW_RATE_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 27, 1)
+#define SET_TX_DESC_STW_ANT_DIS(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 26, 1, value)
+#define GET_TX_DESC_STW_ANT_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 26, 1)
+#define SET_TX_DESC_STW_EN(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 25, 1, value)
+#define GET_TX_DESC_STW_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 25, 1)
+#define SET_TX_DESC_SMH_EN(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 24, 1, value)
+#define GET_TX_DESC_SMH_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 24, 1)
+#define SET_TX_DESC_TAILPAGE_L(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 24, 8, value)
+#define GET_TX_DESC_TAILPAGE_L(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 24, 8)
+#define SET_TX_DESC_SDIO_DMASEQ(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 16, 8, value)
+#define GET_TX_DESC_SDIO_DMASEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 16, 8)
+#define SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 16, 8, value)
+#define GET_TX_DESC_NEXTHEADPAGE_L(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x20, 16, 8)
+#define SET_TX_DESC_EN_HWSEQ(txdesc, value)                                    \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 15, 1, value)
+#define GET_TX_DESC_EN_HWSEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 15, 1)
+#define SET_TX_DESC_EN_HWEXSEQ(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 14, 1, value)
+#define GET_TX_DESC_EN_HWEXSEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 14, 1)
+#define SET_TX_DESC_DATA_RC(txdesc, value)                                     \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 8, 6, value)
+#define GET_TX_DESC_DATA_RC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 8, 6)
+#define SET_TX_DESC_BAR_RTY_TH(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 6, 2, value)
+#define GET_TX_DESC_BAR_RTY_TH(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 6, 2)
+#define SET_TX_DESC_RTS_RC(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 0, 6, value)
+#define GET_TX_DESC_RTS_RC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 0, 6)
+
+/*TXDESC_WORD9*/
+
+#define SET_TX_DESC_TAILPAGE_H(txdesc, value)                                  \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 28, 4, value)
+#define GET_TX_DESC_TAILPAGE_H(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 28, 4)
+#define SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)                              \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 24, 4, value)
+#define GET_TX_DESC_NEXTHEADPAGE_H(txdesc)                                     \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 24, 4)
+#define SET_TX_DESC_SW_SEQ(txdesc, value)                                      \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 12, 12, value)
+#define GET_TX_DESC_SW_SEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 12, 12)
+#define SET_TX_DESC_TXBF_PATH(txdesc, value)                                   \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 11, 1, value)
+#define GET_TX_DESC_TXBF_PATH(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 11, 1)
+#define SET_TX_DESC_PADDING_LEN(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 0, 11, value)
+#define GET_TX_DESC_PADDING_LEN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 0, 11)
+#define SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)                         \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 0, 8, value)
+#define GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)                                \
+	LE_BITS_TO_4BYTE(txdesc + 0x24, 0, 8)
+
+#endif
+
+#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
+
+/*WORD10*/
+
+#define SET_TX_DESC_MU_DATARATE(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 8, 8, value)
+#define GET_TX_DESC_MU_DATARATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 8, 8)
+#define SET_TX_DESC_MU_RC(txdesc, value)                                       \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 4, 4, value)
+#define GET_TX_DESC_MU_RC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 4, 4)
+#define SET_TX_DESC_SND_PKT_SEL(txdesc, value)                                 \
+	SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 0, 2, value)
+#define GET_TX_DESC_SND_PKT_SEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 0, 2)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_type.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_type.h
new file mode 100644
index 000000000000..8bfa449092a2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_type.h
@@ -0,0 +1,2355 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 _HALMAC_TYPE_H_
+#define _HALMAC_TYPE_H_
+
+#include "halmac_2_platform.h"
+#include "halmac_hw_cfg.h"
+#include "halmac_fw_info.h"
+#include "halmac_intf_phy_cmd.h"
+#include "halmac_state_machine.h"
+
+#define IN
+#define OUT
+#define INOUT
+
+#define HALMAC_BCN_IE_BMP_SIZE	24 /* ID0~ID191, 192/8=24 */
+
+#ifndef HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE
+#define HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE	80
+#endif
+
+#ifndef HALMAC_MSG_LEVEL_TRACE
+#define HALMAC_MSG_LEVEL_TRACE		3
+#endif
+
+#ifndef HALMAC_MSG_LEVEL_WARNING
+#define HALMAC_MSG_LEVEL_WARNING	2
+#endif
+
+#ifndef HALMAC_MSG_LEVEL_ERR
+#define HALMAC_MSG_LEVEL_ERR		1
+#endif
+
+#ifndef HALMAC_MSG_LEVEL_NO_LOG
+#define HALMAC_MSG_LEVEL_NO_LOG		0
+#endif
+
+#ifndef HALMAC_MSG_LEVEL
+#define HALMAC_MSG_LEVEL HALMAC_MSG_LEVEL_TRACE
+#endif
+
+/* platform api */
+#define PLTFM_SDIO_CMD52_R(offset)                                             \
+	adapter->pltfm_api->SDIO_CMD52_READ(adapter->drv_adapter, offset)
+#define PLTFM_SDIO_CMD53_R8(offset)                                            \
+	adapter->pltfm_api->SDIO_CMD53_READ_8(adapter->drv_adapter, offset)
+#define PLTFM_SDIO_CMD53_R16(offset)                                           \
+	adapter->pltfm_api->SDIO_CMD53_READ_16(adapter->drv_adapter, offset)
+#define PLTFM_SDIO_CMD53_R32(offset)                                           \
+	adapter->pltfm_api->SDIO_CMD53_READ_32(adapter->drv_adapter, offset)
+#define PLTFM_SDIO_CMD53_RN(offset, size, data)                                \
+	adapter->pltfm_api->SDIO_CMD53_READ_N(adapter->drv_adapter, offset,    \
+					      size, data)
+#define PLTFM_SDIO_CMD52_W(offset, val)                                        \
+	adapter->pltfm_api->SDIO_CMD52_WRITE(adapter->drv_adapter, offset, val)
+#define PLTFM_SDIO_CMD53_W8(offset, val)                                       \
+	adapter->pltfm_api->SDIO_CMD53_WRITE_8(adapter->drv_adapter, offset,   \
+					       val)
+#define PLTFM_SDIO_CMD53_W16(offset, val)                                      \
+	adapter->pltfm_api->SDIO_CMD53_WRITE_16(adapter->drv_adapter, offset,  \
+						val)
+#define PLTFM_SDIO_CMD53_W32(offset, val)                                      \
+	adapter->pltfm_api->SDIO_CMD53_WRITE_32(adapter->drv_adapter, offset,  \
+						val)
+#define PLTFM_SDIO_CMD52_CIA_R(offset)                                         \
+	adapter->pltfm_api->SDIO_CMD52_CIA_READ(adapter->drv_adapter, offset)
+
+#define PLTFM_REG_R8(offset)                                                   \
+	adapter->pltfm_api->REG_READ_8(adapter->drv_adapter, offset)
+#define PLTFM_REG_R16(offset)                                                  \
+	adapter->pltfm_api->REG_READ_16(adapter->drv_adapter, offset)
+#define PLTFM_REG_R32(offset)                                                  \
+	adapter->pltfm_api->REG_READ_32(adapter->drv_adapter, offset)
+#define PLTFM_REG_W8(offset, val)                                              \
+	adapter->pltfm_api->REG_WRITE_8(adapter->drv_adapter, offset, val)
+#define PLTFM_REG_W16(offset, val)                                             \
+	adapter->pltfm_api->REG_WRITE_16(adapter->drv_adapter, offset, val)
+#define PLTFM_REG_W32(offset, val)                                             \
+	adapter->pltfm_api->REG_WRITE_32(adapter->drv_adapter, offset, val)
+
+#define PLTFM_SEND_RSVD_PAGE(buf, size)                                        \
+	adapter->pltfm_api->SEND_RSVD_PAGE(adapter->drv_adapter, buf, size)
+#define PLTFM_SEND_H2C_PKT(buf, size)                                          \
+	adapter->pltfm_api->SEND_H2C_PKT(adapter->drv_adapter, buf, size)
+
+#define PLTFM_FREE(buf, size)                                                  \
+	adapter->pltfm_api->RTL_FREE(adapter->drv_adapter, buf, size)
+#define PLTFM_MALLOC(size)                                                     \
+	adapter->pltfm_api->RTL_MALLOC(adapter->drv_adapter, size)
+#define PLTFM_MEMCPY(dest, src, size)                                          \
+	adapter->pltfm_api->RTL_MEMCPY(adapter->drv_adapter, dest, src, size)
+#define PLTFM_MEMSET(addr, value, size)                                        \
+	adapter->pltfm_api->RTL_MEMSET(adapter->drv_adapter, addr, value, size)
+#define PLTFM_DELAY_US(us)                                                     \
+	adapter->pltfm_api->RTL_DELAY_US(adapter->drv_adapter, us)
+
+#define PLTFM_MUTEX_INIT(mutex)                                                \
+	adapter->pltfm_api->MUTEX_INIT(adapter->drv_adapter, mutex)
+#define PLTFM_MUTEX_DEINIT(mutex)                                              \
+	adapter->pltfm_api->MUTEX_DEINIT(adapter->drv_adapter, mutex)
+#define PLTFM_MUTEX_LOCK(mutex)                                                \
+	adapter->pltfm_api->MUTEX_LOCK(adapter->drv_adapter, mutex)
+#define PLTFM_MUTEX_UNLOCK(mutex)                                              \
+	adapter->pltfm_api->MUTEX_UNLOCK(adapter->drv_adapter, mutex)
+
+#define PLTFM_EVENT_SIG(feature_id, proc_status, buf, size)                    \
+	adapter->pltfm_api->EVENT_INDICATION(adapter->drv_adapter, feature_id, \
+					     proc_status, buf, size)
+
+#if HALMAC_PLATFORM_WINDOWS
+#define PLTFM_MSG_PRINT	adapter->pltfm_api->MSG_PRINT
+#endif
+
+#define PLTFM_MSG_ALWAYS(...)                                                  \
+	adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT,   \
+				      HALMAC_DBG_ALWAYS, __VA_ARGS__)
+
+#if HALMAC_DBG_MSG_ENABLE
+
+/* Enable debug msg depends on  HALMAC_MSG_LEVEL */
+#if (HALMAC_MSG_LEVEL >= HALMAC_MSG_LEVEL_ERR)
+#define PLTFM_MSG_ERR(...)                                                     \
+	adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT,   \
+				      HALMAC_DBG_ERR, __VA_ARGS__)
+#else
+#define PLTFM_MSG_ERR(...)	do {} while (0)
+#endif
+
+#if (HALMAC_MSG_LEVEL >= HALMAC_MSG_LEVEL_WARNING)
+#define PLTFM_MSG_WARN(...)                                                    \
+	adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT,   \
+				      HALMAC_DBG_WARN, __VA_ARGS__)
+#else
+#define PLTFM_MSG_WARN(...)	do {} while (0)
+#endif
+
+#if (HALMAC_MSG_LEVEL >= HALMAC_MSG_LEVEL_TRACE)
+#define PLTFM_MSG_TRACE(...)                                                   \
+	adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT,   \
+				      HALMAC_DBG_TRACE, __VA_ARGS__)
+#else
+#define PLTFM_MSG_TRACE(...)	do {} while (0)
+#endif
+
+#else
+
+/* Disable debug msg  */
+#define PLTFM_MSG_ERR(...)	do {} while (0)
+#define PLTFM_MSG_WARN(...)	do {} while (0)
+#define PLTFM_MSG_TRACE(...)	do {} while (0)
+
+#endif
+
+#define HALMAC_REG_R8(offset) api->halmac_reg_read_8(adapter, offset)
+#define HALMAC_REG_R16(offset) api->halmac_reg_read_16(adapter, offset)
+#define HALMAC_REG_R32(offset) api->halmac_reg_read_32(adapter, offset)
+#define HALMAC_REG_W8(offset, val) api->halmac_reg_write_8(adapter, offset, val)
+#define HALMAC_REG_W16(offset, val)                                            \
+	api->halmac_reg_write_16(adapter, offset, val)
+#define HALMAC_REG_W32(offset, val)                                            \
+	api->halmac_reg_write_32(adapter, offset, val)
+#define HALMAC_REG_SDIO_RN(offset, size, data)                                 \
+	api->halmac_reg_sdio_cmd53_read_n(adapter, offset, size, data)
+
+#define HALMAC_REG_W8_CLR(offset, mask)                                        \
+	HALMAC_REG_W8(offset, HALMAC_REG_R8(offset) & ~(mask))
+#define HALMAC_REG_W16_CLR(offset, mask)                                       \
+	HALMAC_REG_W16(offset, HALMAC_REG_R16(offset) & ~(mask))
+#define HALMAC_REG_W32_CLR(offset, mask)                                       \
+	HALMAC_REG_W32(offset, HALMAC_REG_R32(offset) & ~(mask))
+
+#define HALMAC_REG_W8_SET(offset, mask)                                        \
+	HALMAC_REG_W8(offset, HALMAC_REG_R8(offset) | (mask))
+#define HALMAC_REG_W16_SET(offset, mask)                                       \
+	HALMAC_REG_W16(offset, HALMAC_REG_R16(offset) | (mask))
+#define HALMAC_REG_W32_SET(offset, mask)                                       \
+	HALMAC_REG_W32(offset, HALMAC_REG_R32(offset) | (mask))
+
+/* Swap Little-endian <-> Big-endia*/
+#define SWAP32(x)                                                              \
+	((u32)((((u32)(x) & (u32)0x000000ff) << 24) |                          \
+	       (((u32)(x) & (u32)0x0000ff00) << 8) |                           \
+	       (((u32)(x) & (u32)0x00ff0000) >> 8) |                           \
+	       (((u32)(x) & (u32)0xff000000) >> 24)))
+
+#define SWAP16(x)                                                              \
+	((u16)((((u16)(x) & (u16)0x00ff) << 8) |                               \
+	       (((u16)(x) & (u16)0xff00) >> 8)))
+
+/*1->Little endian 0->Big endian*/
+#if HALMAC_SYSTEM_ENDIAN
+#ifndef rtk_le16_to_cpu
+#define rtk_cpu_to_le32(x)              ((u32)(x))
+#define rtk_le32_to_cpu(x)              ((u32)(x))
+#define rtk_cpu_to_le16(x)              ((u16)(x))
+#define rtk_le16_to_cpu(x)              ((u16)(x))
+#define rtk_cpu_to_be32(x)              SWAP32((x))
+#define rtk_be32_to_cpu(x)              SWAP32((x))
+#define rtk_cpu_to_be16(x)              SWAP16((x))
+#define rtk_be16_to_cpu(x)              SWAP16((x))
+#endif
+#else
+#ifndef rtk_le16_to_cpu
+#define rtk_cpu_to_le32(x)              SWAP32((x))
+#define rtk_le32_to_cpu(x)              SWAP32((x))
+#define rtk_cpu_to_le16(x)              SWAP16((x))
+#define rtk_le16_to_cpu(x)              SWAP16((x))
+#define rtk_cpu_to_be32(x)              ((u32)(x))
+#define rtk_be32_to_cpu(x)              ((u32)(x))
+#define rtk_cpu_to_be16(x)              ((u16)(x))
+#define rtk_be16_to_cpu(x)              ((u16)(x))
+#endif
+#endif
+
+#define HALMAC_ALIGN(x, a)               HALMAC_ALIGN_MASK(x, (a) - 1)
+#define HALMAC_ALIGN_MASK(x, mask)       (((x) + (mask)) & ~(mask))
+
+/* #if !HALMAC_PLATFORM_WINDOWS */
+#if !((HALMAC_PLATFORM_WINDOWS == 1) && (HALMAC_PLATFORM_TESTPROGRAM == 0))
+
+/* Byte Swapping routine */
+#ifndef EF1BYTE
+#define EF1BYTE (u8)
+#endif
+
+#ifndef EF2BYTE
+#define EF2BYTE rtk_le16_to_cpu
+#endif
+
+#ifndef EF4BYTE
+#define EF4BYTE rtk_le32_to_cpu
+#endif
+
+/* Example:
+ * BIT_LEN_MASK_32(0) => 0x00000000
+ * BIT_LEN_MASK_32(1) => 0x00000001
+ * BIT_LEN_MASK_32(2) => 0x00000003
+ * BIT_LEN_MASK_32(32) => 0xFFFFFFFF
+ */
+#ifndef BIT_LEN_MASK_32
+#define BIT_LEN_MASK_32(__bitlen) (0xFFFFFFFF >> (32 - (__bitlen)))
+#endif
+
+/* Example:
+ * BIT_OFFSET_LEN_MASK_32(0, 2) => 0x00000003
+ * BIT_OFFSET_LEN_MASK_32(16, 2) => 0x00030000
+ */
+#ifndef BIT_OFFSET_LEN_MASK_32
+#define BIT_OFFSET_LEN_MASK_32(__bitoffset, __bitlen)                          \
+	(BIT_LEN_MASK_32(__bitlen) << (__bitoffset))
+#endif
+
+/* Return 4-byte value in host byte ordering from
+ * 4-byte pointer in litten-endian system
+ */
+#ifndef LE_P4BYTE_TO_HOST_4BYTE
+#define LE_P4BYTE_TO_HOST_4BYTE(__start) (EF4BYTE(*((u32 *)(__start))))
+#endif
+
+/* Translate subfield (continuous bits in little-endian) of
+ * 4-byte value in litten byte to 4-byte value in host byte ordering
+ */
+#ifndef LE_BITS_TO_4BYTE
+#define LE_BITS_TO_4BYTE(__start, __bitoffset, __bitlen)                       \
+	((LE_P4BYTE_TO_HOST_4BYTE(__start) >> (__bitoffset)) &                 \
+	 BIT_LEN_MASK_32(__bitlen))
+#endif
+
+/* Mask subfield (continuous bits in little-endian) of 4-byte
+ * value in litten byte oredering and return the result in 4-byte
+ * value in host byte ordering
+ */
+#ifndef LE_BITS_CLEARED_TO_4BYTE
+#define LE_BITS_CLEARED_TO_4BYTE(__start, __bitoffset, __bitlen)               \
+	(LE_P4BYTE_TO_HOST_4BYTE(__start) &                                    \
+	 (~BIT_OFFSET_LEN_MASK_32(__bitoffset, __bitlen)))
+#endif
+
+/* Set subfield of little-endian 4-byte value to specified value */
+#ifndef SET_BITS_TO_LE_4BYTE
+#define SET_BITS_TO_LE_4BYTE(__start, __bitoffset, __bitlen, __value)          \
+	do {                                                                   \
+		*((u32 *)(__start)) = \
+		EF4BYTE( \
+		LE_BITS_CLEARED_TO_4BYTE(__start, __bitoffset, __bitlen) |     \
+		((((u32)__value) & BIT_LEN_MASK_32(__bitlen)) << (__bitoffset))\
+		);                                                             \
+	} while (0)
+#endif
+
+#ifndef HALMAC_BIT_OFFSET_VAL_MASK_32
+#define HALMAC_BIT_OFFSET_VAL_MASK_32(__bitval, __bitoffset)                   \
+	(__bitval << (__bitoffset))
+#endif
+
+#ifndef SET_MEM_OP
+#define SET_MEM_OP(dw, value32, mask, shift)                                   \
+	(((dw) & ~((mask) << (shift))) | (((value32) & (mask)) << (shift)))
+#endif
+
+#ifndef HALMAC_SET_DESC_FIELD_CLR
+#define HALMAC_SET_DESC_FIELD_CLR(dw, value32, mask, shift)                    \
+	(dw = (rtk_cpu_to_le32(                                                \
+		 SET_MEM_OP(rtk_cpu_to_le32(dw), value32, mask, shift))))
+#endif
+
+#ifndef HALMAC_SET_DESC_FIELD_NO_CLR
+#define HALMAC_SET_DESC_FIELD_NO_CLR(dw, value32, mask, shift)                 \
+	(dw |= (rtk_cpu_to_le32(((value32) & (mask)) << (shift))))
+#endif
+
+#ifndef HALMAC_GET_DESC_FIELD
+#define HALMAC_GET_DESC_FIELD(dw, mask, shift)                                 \
+	((rtk_le32_to_cpu(dw) >> (shift)) & (mask))
+#endif
+
+#define HALMAC_SET_BD_FIELD_CLR HALMAC_SET_DESC_FIELD_CLR
+#define HALMAC_SET_BD_FIELD_NO_CLR HALMAC_SET_DESC_FIELD_NO_CLR
+#define HALMAC_GET_BD_FIELD HALMAC_GET_DESC_FIELD
+
+#ifndef GET_H2C_FIELD
+#define GET_H2C_FIELD   LE_BITS_TO_4BYTE
+#endif
+
+#ifndef SET_H2C_FIELD_CLR
+#define SET_H2C_FIELD_CLR       SET_BITS_TO_LE_4BYTE
+#endif
+
+#ifndef SET_H2C_FIELD_NO_CLR
+#define SET_H2C_FIELD_NO_CLR    SET_BITS_TO_LE_4BYTE
+#endif
+
+#ifndef GET_C2H_FIELD
+#define GET_C2H_FIELD   LE_BITS_TO_4BYTE
+#endif
+
+#ifndef SET_C2H_FIELD_CLR
+#define SET_C2H_FIELD_CLR       SET_BITS_TO_LE_4BYTE
+#endif
+
+#ifndef SET_C2H_FIELD_NO_CLR
+#define SET_C2H_FIELD_NO_CLR    SET_BITS_TO_LE_4BYTE
+#endif
+
+#endif /* #if !HALMAC_PLATFORM_WINDOWS */
+
+#ifndef BIT
+#define BIT(x)              (1 << (x))
+#endif
+
+#ifndef ARRAY_SIZE
+#define ARRAY_SIZE(arr)		(sizeof(arr) / sizeof((arr)[0]))
+#endif
+
+/* HALMAC API return status*/
+enum halmac_ret_status {
+	HALMAC_RET_SUCCESS = 0x00,
+	HALMAC_RET_NOT_SUPPORT = 0x01,
+	HALMAC_RET_SUCCESS_ENQUEUE = 0x01, /*Don't use this return code!!*/
+	HALMAC_RET_PLATFORM_API_NULL = 0x02,
+	HALMAC_RET_EFUSE_SIZE_INCORRECT = 0x03,
+	HALMAC_RET_MALLOC_FAIL = 0x04,
+	HALMAC_RET_ADAPTER_INVALID = 0x05,
+	HALMAC_RET_ITF_INCORRECT = 0x06,
+	HALMAC_RET_DLFW_FAIL = 0x07,
+	HALMAC_RET_PORT_NOT_SUPPORT = 0x08,
+	HALMAC_RET_TXAGG_OVERFLOW = 0x09,
+	HALMAC_RET_INIT_LLT_FAIL = 0x0A,
+	HALMAC_RET_POWER_STATE_INVALID = 0x0B,
+	HALMAC_RET_H2C_ACK_NOT_RECEIVED = 0x0C,
+	HALMAC_RET_DL_RSVD_PAGE_FAIL = 0x0D,
+	HALMAC_RET_EFUSE_R_FAIL = 0x0E,
+	HALMAC_RET_EFUSE_W_FAIL = 0x0F,
+	HALMAC_RET_H2C_SW_RES_FAIL = 0x10,
+	HALMAC_RET_SEND_H2C_FAIL = 0x11,
+	HALMAC_RET_PARA_NOT_SUPPORT = 0x12,
+	HALMAC_RET_PLATFORM_API_INCORRECT = 0x13,
+	HALMAC_RET_ENDIAN_ERR = 0x14,
+	HALMAC_RET_FW_SIZE_ERR = 0x15,
+	HALMAC_RET_TRX_MODE_NOT_SUPPORT = 0x16,
+	HALMAC_RET_FAIL = 0x17,
+	HALMAC_RET_CHANGE_PS_FAIL = 0x18,
+	HALMAC_RET_CFG_PARA_FAIL = 0x19,
+	HALMAC_RET_UPDATE_PROBE_FAIL = 0x1A,
+	HALMAC_RET_SCAN_FAIL = 0x1B,
+	HALMAC_RET_STOP_SCAN_FAIL = 0x1C,
+	HALMAC_RET_BCN_PARSER_CMD_FAIL = 0x1D,
+	HALMAC_RET_POWER_ON_FAIL = 0x1E,
+	HALMAC_RET_POWER_OFF_FAIL = 0x1F,
+	HALMAC_RET_RX_AGG_MODE_FAIL = 0x20,
+	HALMAC_RET_DATA_BUF_NULL = 0x21,
+	HALMAC_RET_DATA_SIZE_INCORRECT = 0x22,
+	HALMAC_RET_QSEL_INCORRECT = 0x23,
+	HALMAC_RET_DMA_MAP_INCORRECT = 0x24,
+	HALMAC_RET_SEND_ORIGINAL_H2C_FAIL = 0x25,
+	HALMAC_RET_DDMA_FAIL = 0x26,
+	HALMAC_RET_FW_CHECKSUM_FAIL = 0x27,
+	HALMAC_RET_PWRSEQ_POLLING_FAIL = 0x28,
+	HALMAC_RET_PWRSEQ_CMD_INCORRECT = 0x29,
+	HALMAC_RET_WRITE_DATA_FAIL = 0x2A,
+	HALMAC_RET_DUMP_FIFOSIZE_INCORRECT = 0x2B,
+	HALMAC_RET_NULL_POINTER = 0x2C,
+	HALMAC_RET_PROBE_NOT_FOUND = 0x2D,
+	HALMAC_RET_FW_NO_MEMORY = 0x2E,
+	HALMAC_RET_H2C_STATUS_ERR = 0x2F,
+	HALMAC_RET_GET_H2C_SPACE_ERR = 0x30,
+	HALMAC_RET_H2C_SPACE_FULL = 0x31,
+	HALMAC_RET_DATAPACK_NO_FOUND = 0x32,
+	HALMAC_RET_CANNOT_FIND_H2C_RESOURCE = 0x33,
+	HALMAC_RET_TX_DMA_ERR = 0x34,
+	HALMAC_RET_RX_DMA_ERR = 0x35,
+	HALMAC_RET_CHIP_NOT_SUPPORT = 0x36,
+	HALMAC_RET_FREE_SPACE_NOT_ENOUGH = 0x37,
+	HALMAC_RET_CH_SW_SEQ_WRONG = 0x38,
+	HALMAC_RET_CH_SW_NO_BUF = 0x39,
+	HALMAC_RET_SW_CASE_NOT_SUPPORT = 0x3A,
+	HALMAC_RET_CONVERT_SDIO_OFFSET_FAIL = 0x3B,
+	HALMAC_RET_INVALID_SOUNDING_SETTING = 0x3C,
+	HALMAC_RET_GEN_INFO_NOT_SENT = 0x3D,
+	HALMAC_RET_STATE_INCORRECT = 0x3E,
+	HALMAC_RET_H2C_BUSY = 0x3F,
+	HALMAC_RET_INVALID_FEATURE_ID = 0x40,
+	HALMAC_RET_BUFFER_TOO_SMALL = 0x41,
+	HALMAC_RET_ZERO_LEN_RSVD_PACKET = 0x42,
+	HALMAC_RET_BUSY_STATE = 0x43,
+	HALMAC_RET_ERROR_STATE = 0x44,
+	HALMAC_RET_API_INVALID = 0x45,
+	HALMAC_RET_POLLING_BCN_VALID_FAIL = 0x46,
+	HALMAC_RET_SDIO_LEAVE_SUSPEND_FAIL = 0x47,
+	HALMAC_RET_EEPROM_PARSING_FAIL = 0x48,
+	HALMAC_RET_EFUSE_NOT_ENOUGH = 0x49,
+	HALMAC_RET_WRONG_ARGUMENT = 0x4A,
+	HALMAC_RET_C2H_NOT_HANDLED = 0x4C,
+	HALMAC_RET_PARA_SENDING = 0x4D,
+	HALMAC_RET_CFG_DLFW_SIZE_FAIL = 0x4E,
+	HALMAC_RET_CFG_TXFIFO_PAGE_FAIL = 0x4F,
+	HALMAC_RET_SWITCH_CASE_ERROR = 0x50,
+	HALMAC_RET_EFUSE_BANK_INCORRECT = 0x51,
+	HALMAC_RET_SWITCH_EFUSE_BANK_FAIL = 0x52,
+	HALMAC_RET_USB_MODE_UNCHANGE = 0x53,
+	HALMAC_RET_NO_DLFW = 0x54,
+	HALMAC_RET_USB2_3_SWITCH_UNSUPPORT = 0x55,
+	HALMAC_RET_BIP_NO_SUPPORT = 0x56,
+	HALMAC_RET_ENTRY_INDEX_ERROR = 0x57,
+	HALMAC_RET_ENTRY_KEY_ID_ERROR = 0x58,
+	HALMAC_RET_DRV_DL_ERR = 0x59,
+	HALMAC_RET_OQT_NOT_ENOUGH = 0x5A,
+	HALMAC_RET_PWR_UNCHANGE = 0x5B,
+	HALMAC_RET_WRONG_INTF = 0x5C,
+	HALMAC_RET_POLLING_HIOE_REQ_FAIL = 0x5E,
+	HALMAC_RET_HIOE_CHKSUM_FAIL = 0x5F,
+	HALMAC_RET_HIOE_ERR = 0x60,
+	HALMAC_RET_FW_NO_SUPPORT = 0x60,
+	HALMAC_RET_TXFIFO_NO_EMPTY = 0x61,
+	HALMAC_RET_SDIO_CLOCK_ERR = 0x62,
+	HALMAC_RET_GET_PINMUX_ERR = 0x63,
+	HALMAC_RET_PINMUX_USED = 0x64,
+	HALMAC_RET_WRONG_GPIO = 0x65,
+	HALMAC_RET_LTECOEX_READY_FAIL = 0x66,
+	HALMAC_RET_IDMEM_CHKSUM_FAIL = 0x67,
+	HALMAC_RET_ILLEGAL_KEY_FAIL = 0x68,
+	HALMAC_RET_FW_READY_CHK_FAIL = 0x69,
+	HALMAC_RET_RSVD_PG_OVERFLOW_FAIL = 0x70,
+	HALMAC_RET_THRESHOLD_FAIL = 0x71,
+	HALMAC_RET_SDIO_MIX_MODE = 0x72,
+	HALMAC_RET_TXDESC_SET_FAIL = 0x73,
+	HALMAC_RET_WLHDR_FAIL = 0x74,
+	HALMAC_RET_WLAN_MODE_FAIL = 0x75,
+};
+
+enum halmac_chip_id {
+	HALMAC_CHIP_ID_8822B = 0,
+	HALMAC_CHIP_ID_8821C = 1,
+	HALMAC_CHIP_ID_8814B = 2,
+	HALMAC_CHIP_ID_8197F = 3,
+	HALMAC_CHIP_ID_8822C = 4,
+	HALMAC_CHIP_ID_UNDEFINE = 0x7F,
+};
+
+enum halmac_chip_ver {
+	HALMAC_CHIP_VER_A_CUT = 0x00,
+	HALMAC_CHIP_VER_B_CUT = 0x01,
+	HALMAC_CHIP_VER_C_CUT = 0x02,
+	HALMAC_CHIP_VER_D_CUT = 0x03,
+	HALMAC_CHIP_VER_E_CUT = 0x04,
+	HALMAC_CHIP_VER_F_CUT = 0x05,
+	HALMAC_CHIP_VER_TEST = 0xFF,
+	HALMAC_CHIP_VER_UNDEFINE = 0x7FFF,
+};
+
+enum halmac_network_type_select {
+	HALMAC_NETWORK_NO_LINK = 0,
+	HALMAC_NETWORK_ADHOC = 1,
+	HALMAC_NETWORK_INFRASTRUCTURE = 2,
+	HALMAC_NETWORK_AP = 3,
+	HALMAC_NETWORK_UNDEFINE = 0x7F,
+};
+
+enum halmac_transfer_mode_select {
+	HALMAC_TRNSFER_NORMAL = 0x0,
+	HALMAC_TRNSFER_LOOPBACK_DIRECT = 0xB,
+	HALMAC_TRNSFER_LOOPBACK_DELAY = 0x3,
+	HALMAC_TRNSFER_UNDEFINE = 0x7F,
+};
+
+enum halmac_dma_mapping {
+	HALMAC_DMA_MAPPING_EXTRA = 0,
+	HALMAC_DMA_MAPPING_LOW = 1,
+	HALMAC_DMA_MAPPING_NORMAL = 2,
+	HALMAC_DMA_MAPPING_HIGH = 3,
+	HALMAC_DMA_MAPPING_UNDEFINE = 0x7F,
+};
+
+enum halmac_io_size {
+	HALMAC_IO_BYTE = 0x0,
+	HALMAC_IO_WORD = 0x1,
+	HALMAC_IO_DWORD = 0x2,
+	HALMAC_IO_UNDEFINE = 0x7F,
+};
+
+#define HALMAC_MAP2_HQ		HALMAC_DMA_MAPPING_HIGH
+#define HALMAC_MAP2_NQ		HALMAC_DMA_MAPPING_NORMAL
+#define HALMAC_MAP2_LQ		HALMAC_DMA_MAPPING_LOW
+#define HALMAC_MAP2_EXQ		HALMAC_DMA_MAPPING_EXTRA
+#define HALMAC_MAP2_UNDEF	HALMAC_DMA_MAPPING_UNDEFINE
+
+enum halmac_txdesc_queue_tid {
+	HALMAC_TXDESC_QSEL_TID0 = 0,
+	HALMAC_TXDESC_QSEL_TID1 = 1,
+	HALMAC_TXDESC_QSEL_TID2 = 2,
+	HALMAC_TXDESC_QSEL_TID3 = 3,
+	HALMAC_TXDESC_QSEL_TID4 = 4,
+	HALMAC_TXDESC_QSEL_TID5 = 5,
+	HALMAC_TXDESC_QSEL_TID6 = 6,
+	HALMAC_TXDESC_QSEL_TID7 = 7,
+	HALMAC_TXDESC_QSEL_TID8 = 8,
+	HALMAC_TXDESC_QSEL_TID9 = 9,
+	HALMAC_TXDESC_QSEL_TIDA = 10,
+	HALMAC_TXDESC_QSEL_TIDB = 11,
+	HALMAC_TXDESC_QSEL_TIDC = 12,
+	HALMAC_TXDESC_QSEL_TIDD = 13,
+	HALMAC_TXDESC_QSEL_TIDE = 14,
+	HALMAC_TXDESC_QSEL_TIDF = 15,
+
+	HALMAC_TXDESC_QSEL_BEACON = 0x10,
+	HALMAC_TXDESC_QSEL_HIGH = 0x11,
+	HALMAC_TXDESC_QSEL_MGT = 0x12,
+	HALMAC_TXDESC_QSEL_H2C_CMD = 0x13,
+	HALMAC_TXDESC_QSEL_FWCMD = 0x14,
+
+	HALMAC_TXDESC_QSEL_UNDEFINE = 0x7F,
+};
+
+enum halmac_pq_map_id {
+	HALMAC_PQ_MAP_VO = 0x0,
+	HALMAC_PQ_MAP_VI = 0x1,
+	HALMAC_PQ_MAP_BE = 0x2,
+	HALMAC_PQ_MAP_BK = 0x3,
+	HALMAC_PQ_MAP_MG = 0x4,
+	HALMAC_PQ_MAP_HI = 0x5,
+	HALMAC_PQ_MAP_NUM = 0x6,
+	HALMAC_PQ_MAP_UNDEF = 0x7F,
+};
+
+enum halmac_qsel {
+	HALMAC_QSEL_VO = HALMAC_TXDESC_QSEL_TID6,
+	HALMAC_QSEL_VI = HALMAC_TXDESC_QSEL_TID4,
+	HALMAC_QSEL_BE = HALMAC_TXDESC_QSEL_TID0,
+	HALMAC_QSEL_BK = HALMAC_TXDESC_QSEL_TID1,
+	HALMAC_QSEL_VO_V2 = HALMAC_TXDESC_QSEL_TID7,
+	HALMAC_QSEL_VI_V2 = HALMAC_TXDESC_QSEL_TID5,
+	HALMAC_QSEL_BE_V2 = HALMAC_TXDESC_QSEL_TID3,
+	HALMAC_QSEL_BK_V2 = HALMAC_TXDESC_QSEL_TID2,
+	HALMAC_QSEL_TID8 = HALMAC_TXDESC_QSEL_TID8,
+	HALMAC_QSEL_TID9 = HALMAC_TXDESC_QSEL_TID9,
+	HALMAC_QSEL_TIDA = HALMAC_TXDESC_QSEL_TIDA,
+	HALMAC_QSEL_TIDB = HALMAC_TXDESC_QSEL_TIDB,
+	HALMAC_QSEL_TIDC = HALMAC_TXDESC_QSEL_TIDC,
+	HALMAC_QSEL_TIDD = HALMAC_TXDESC_QSEL_TIDD,
+	HALMAC_QSEL_TIDE = HALMAC_TXDESC_QSEL_TIDE,
+	HALMAC_QSEL_TIDF = HALMAC_TXDESC_QSEL_TIDF,
+	HALMAC_QSEL_BCN = HALMAC_TXDESC_QSEL_BEACON,
+	HALMAC_QSEL_HIGH = HALMAC_TXDESC_QSEL_HIGH,
+	HALMAC_QSEL_MGNT = HALMAC_TXDESC_QSEL_MGT,
+	HALMAC_QSEL_CMD = HALMAC_TXDESC_QSEL_H2C_CMD,
+	HALMAC_QSEL_FWCMD = HALMAC_TXDESC_QSEL_FWCMD,
+	HALMAC_QSEL_UNDEFINE = 0x7F,
+};
+
+enum halmac_acq_id {
+	HALMAC_ACQ_ID_VO = 0,
+	HALMAC_ACQ_ID_VI = 1,
+	HALMAC_ACQ_ID_BE = 2,
+	HALMAC_ACQ_ID_BK = 3,
+	HALMAC_ACQ_ID_MAX = 0x7F,
+};
+
+enum halmac_txdesc_dma_ch {
+	HALMAC_TXDESC_DMA_CH0 = 0,
+	HALMAC_TXDESC_DMA_CH1 = 1,
+	HALMAC_TXDESC_DMA_CH2 = 2,
+	HALMAC_TXDESC_DMA_CH3 = 3,
+	HALMAC_TXDESC_DMA_CH4 = 4,
+	HALMAC_TXDESC_DMA_CH5 = 5,
+	HALMAC_TXDESC_DMA_CH6 = 6,
+	HALMAC_TXDESC_DMA_CH7 = 7,
+	HALMAC_TXDESC_DMA_CH8 = 8,
+	HALMAC_TXDESC_DMA_CH9 = 9,
+	HALMAC_TXDESC_DMA_CH10 = 10,
+	HALMAC_TXDESC_DMA_CH11 = 11,
+	HALMAC_TXDESC_DMA_CH12 = 12,
+	HALMAC_TXDESC_DMA_CH13 = 13,
+	HALMAC_TXDESC_DMA_CH14 = 14,
+	HALMAC_TXDESC_DMA_CH15 = 15,
+	HALMAC_TXDESC_DMA_CH16 = 16,
+	HALMAC_TXDESC_DMA_CH17 = 17,
+	HALMAC_TXDESC_DMA_CH18 = 18,
+	HALMAC_TXDESC_DMA_CH19 = 19,
+	HALMAC_TXDESC_DMA_CH20 = 20,
+	HALMAC_TXDESC_DMA_CHMAX,
+	HALMAC_TXDESC_DMA_CHUNDEFINE = 0x7F,
+};
+
+enum halmac_dma_ch {
+	HALMAC_DMA_CH_0 = HALMAC_TXDESC_DMA_CH0,
+	HALMAC_DMA_CH_1 = HALMAC_TXDESC_DMA_CH1,
+	HALMAC_DMA_CH_2 = HALMAC_TXDESC_DMA_CH2,
+	HALMAC_DMA_CH_3 = HALMAC_TXDESC_DMA_CH3,
+	HALMAC_DMA_CH_4 = HALMAC_TXDESC_DMA_CH4,
+	HALMAC_DMA_CH_5 = HALMAC_TXDESC_DMA_CH5,
+	HALMAC_DMA_CH_6 = HALMAC_TXDESC_DMA_CH6,
+	HALMAC_DMA_CH_7 = HALMAC_TXDESC_DMA_CH7,
+	HALMAC_DMA_CH_8 = HALMAC_TXDESC_DMA_CH8,
+	HALMAC_DMA_CH_9 = HALMAC_TXDESC_DMA_CH9,
+	HALMAC_DMA_CH_10 = HALMAC_TXDESC_DMA_CH10,
+	HALMAC_DMA_CH_11 = HALMAC_TXDESC_DMA_CH11,
+	HALMAC_DMA_CH_S0 = HALMAC_TXDESC_DMA_CH12,
+	HALMAC_DMA_CH_S1 = HALMAC_TXDESC_DMA_CH13,
+	HALMAC_DMA_CH_MGQ = HALMAC_TXDESC_DMA_CH14,
+	HALMAC_DMA_CH_HIGH = HALMAC_TXDESC_DMA_CH15,
+	HALMAC_DMA_CH_FWCMD = HALMAC_TXDESC_DMA_CH16,
+	HALMAC_DMA_CH_MGQ_BAND1 = HALMAC_TXDESC_DMA_CH17,
+	HALMAC_DMA_CH_HIGH_BAND1 = HALMAC_TXDESC_DMA_CH18,
+	HALMAC_DMA_CH_BCN = HALMAC_TXDESC_DMA_CH19,
+	HALMAC_DMA_CH_H2C = HALMAC_TXDESC_DMA_CH20,
+	HALMAC_DMA_CH_MAX = HALMAC_TXDESC_DMA_CHMAX,
+	HALMAC_DMA_CH_UNDEFINE = 0x7F,
+};
+
+enum halmac_interface {
+	HALMAC_INTERFACE_PCIE = 0x0,
+	HALMAC_INTERFACE_USB = 0x1,
+	HALMAC_INTERFACE_SDIO = 0x2,
+	HALMAC_INTERFACE_AXI = 0x3,
+	HALMAC_INTERFACE_UNDEFINE = 0x7F,
+};
+
+enum halmac_rx_agg_mode {
+	HALMAC_RX_AGG_MODE_NONE = 0x0,
+	HALMAC_RX_AGG_MODE_DMA = 0x1,
+	HALMAC_RX_AGG_MODE_USB = 0x2,
+	HALMAC_RX_AGG_MODE_UNDEFINE = 0x7F,
+};
+
+struct halmac_rxagg_th {
+	u8 drv_define;
+	u8 timeout;
+	u8 size;
+	u8 size_limit_en;
+};
+
+struct halmac_rxagg_cfg {
+	enum halmac_rx_agg_mode mode;
+	struct halmac_rxagg_th threshold;
+};
+
+struct halmac_api_registry {
+	u8 rx_exp_en:1;
+	u8 la_mode_en:1;
+	u8 cfg_drv_rsvd_pg_en:1;
+	u8 sdio_cmd53_4byte_en:1;
+	u8 rsvd:4;
+};
+
+enum halmac_trx_mode {
+	HALMAC_TRX_MODE_NORMAL = 0x0,
+	HALMAC_TRX_MODE_TRXSHARE = 0x1,
+	HALMAC_TRX_MODE_WMM = 0x2,
+	HALMAC_TRX_MODE_P2P = 0x3,
+	HALMAC_TRX_MODE_LOOPBACK = 0x4,
+	HALMAC_TRX_MODE_DELAY_LOOPBACK = 0x5,
+	HALMAC_TRX_MODE_MAX = 0x6,
+	HALMAC_TRX_MODE_WMM_LINUX = 0x7E,
+	HALMAC_TRX_MODE_UNDEFINE = 0x7F,
+};
+
+enum halmac_wireless_mode {
+	HALMAC_WIRELESS_MODE_B = 0x0,
+	HALMAC_WIRELESS_MODE_G = 0x1,
+	HALMAC_WIRELESS_MODE_N = 0x2,
+	HALMAC_WIRELESS_MODE_AC = 0x3,
+	HALMAC_WIRELESS_MODE_UNDEFINE = 0x7F,
+};
+
+enum halmac_bw {
+	HALMAC_BW_20 = 0x00,
+	HALMAC_BW_40 = 0x01,
+	HALMAC_BW_80 = 0x02,
+	HALMAC_BW_160 = 0x03,
+	HALMAC_BW_5 = 0x04,
+	HALMAC_BW_10 = 0x05,
+	HALMAC_BW_MAX = 0x06,
+	HALMAC_BW_UNDEFINE = 0x7F,
+};
+
+enum halmac_efuse_read_cfg {
+	HALMAC_EFUSE_R_AUTO = 0x00,
+	HALMAC_EFUSE_R_DRV = 0x01,
+	HALMAC_EFUSE_R_FW = 0x02,
+	HALMAC_EFUSE_R_UNDEFINE = 0x7F,
+};
+
+enum halmac_dlfw_mem {
+	HALMAC_DLFW_MEM_EMEM = 0x00,
+	HALMAC_DLFW_MEM_EMEM_RSVD_PG = 0x01,
+	HALMAC_DLFW_MEM_UNDEFINE = 0x7F,
+};
+
+struct halmac_tx_desc {
+	u32 dword0;
+	u32 dword1;
+	u32 dword2;
+	u32 dword3;
+	u32 dword4;
+	u32 dword5;
+	u32 dword6;
+	u32 dword7;
+	u32 dword8;
+	u32 dword9;
+	u32 dword10;
+	u32 dword11;
+};
+
+struct halmac_rx_desc {
+	u32 dword0;
+	u32 dword1;
+	u32 dword2;
+	u32 dword3;
+	u32 dword4;
+	u32 dword5;
+};
+
+struct halmac_bcn_ie_info {
+	u8 func_en;
+	u8 size_th;
+	u8 timeout;
+	u8 ie_bmp[HALMAC_BCN_IE_BMP_SIZE];
+};
+
+enum halmac_parameter_cmd {
+	/* HALMAC_PARAMETER_CMD_LLT	= 0x1, */
+	/* HALMAC_PARAMETER_CMD_R_EFUSE = 0x2, */
+	/* HALMAC_PARAMETER_CMD_EFUSE_PATCH = 0x3, */
+	HALMAC_PARAMETER_CMD_MAC_W8 = 0x4,
+	HALMAC_PARAMETER_CMD_MAC_W16 = 0x5,
+	HALMAC_PARAMETER_CMD_MAC_W32 = 0x6,
+	HALMAC_PARAMETER_CMD_RF_W = 0x7,
+	HALMAC_PARAMETER_CMD_BB_W8 = 0x8,
+	HALMAC_PARAMETER_CMD_BB_W16 = 0x9,
+	HALMAC_PARAMETER_CMD_BB_W32 = 0XA,
+	HALMAC_PARAMETER_CMD_DELAY_US = 0X10,
+	HALMAC_PARAMETER_CMD_DELAY_MS = 0X11,
+	HALMAC_PARAMETER_CMD_END = 0XFF,
+};
+
+union halmac_parameter_content {
+	struct _MAC_REG_W {
+		u32 value;
+		u32 msk;
+		u16 offset;
+		u8 msk_en;
+	} MAC_REG_W;
+	struct _BB_REG_W {
+		u32 value;
+		u32 msk;
+		u16 offset;
+		u8 msk_en;
+	} BB_REG_W;
+	struct _RF_REG_W {
+		u32 value;
+		u32 msk;
+		u8 offset;
+		u8 msk_en;
+		u8 rf_path;
+	} RF_REG_W;
+	struct _DELAY_TIME {
+		u32 rsvd1;
+		u32 rsvd2;
+		u16 delay_time;
+		u8 rsvd3;
+	} DELAY_TIME;
+};
+
+struct halmac_phy_parameter_info {
+	enum halmac_parameter_cmd cmd_id;
+	union halmac_parameter_content content;
+};
+
+struct halmac_pg_efuse_info {
+	u8 *efuse_map;
+	u32 efuse_map_size;
+	u8 *efuse_mask;
+	u32 efuse_mask_size;
+};
+
+struct halmac_cfg_param_info {
+	u32 buf_size;
+	u8 *buf;
+	u8 *buf_wptr;
+	u32 num;
+	u32 avl_buf_size;
+	u32 offset_accum;
+	u32 value_accum;
+	enum halmac_data_type data_type;
+	u8 full_fifo_mode;
+};
+
+struct halmac_hw_cfg_info {
+	u32 efuse_size;
+	u32 eeprom_size;
+	u32 bt_efuse_size;
+	u32 tx_fifo_size;
+	u32 rx_fifo_size;
+	u32 rx_desc_fifo_size;
+	u32 page_size;
+	u16 tx_align_size;
+	u8 txdesc_size;
+	u8 rxdesc_size;
+	u8 cam_entry_num;
+	u8 chk_security_keyid;
+	u8 txdesc_ie_max_num;
+	u8 txdesc_body_size;
+	u8 ac_oqt_size;
+	u8 non_ac_oqt_size;
+	u8 acq_num;
+	u8 trx_mode;
+	u8 usb_txagg_num;
+};
+
+struct halmac_sdio_free_space {
+	u16 hiq_pg_num;
+	u16 miq_pg_num;
+	u16 lowq_pg_num;
+	u16 pubq_pg_num;
+	u16 exq_pg_num;
+	u8 ac_oqt_num;
+	u8 non_ac_oqt_num;
+	u8 ac_empty;
+	u8 *macid_map;
+	u32 macid_map_size;
+};
+
+enum hal_fifo_sel {
+	HAL_FIFO_SEL_TX,
+	HAL_FIFO_SEL_RX,
+	HAL_FIFO_SEL_RSVD_PAGE,
+	HAL_FIFO_SEL_REPORT,
+	HAL_FIFO_SEL_LLT,
+	HAL_FIFO_SEL_RXBUF_FW,
+	HAL_FIFO_SEL_RXBUF_PHY,
+	HAL_FIFO_SEL_RXDESC,
+	HAL_BUF_SECURITY_CAM,
+	HAL_BUF_WOW_CAM,
+	HAL_BUF_RX_FILTER_CAM,
+	HAL_BUF_BA_CAM,
+	HAL_BUF_MBSSID_CAM
+};
+
+enum halmac_drv_info {
+	/* No information is appended in rx_pkt */
+	HALMAC_DRV_INFO_NONE,
+	/* PHY status is appended after rx_desc */
+	HALMAC_DRV_INFO_PHY_STATUS,
+	/* PHY status and sniffer info are appended after rx_desc */
+	HALMAC_DRV_INFO_PHY_SNIFFER,
+	/* PHY status and plcp header are appended after rx_desc */
+	HALMAC_DRV_INFO_PHY_PLCP,
+	HALMAC_DRV_INFO_UNDEFINE,
+};
+
+enum halmac_pri_ch_idx {
+	HALMAC_CH_IDX_UNDEFINE = 0,
+	HALMAC_CH_IDX_1 = 1,
+	HALMAC_CH_IDX_2 = 2,
+	HALMAC_CH_IDX_3 = 3,
+	HALMAC_CH_IDX_4 = 4,
+	HALMAC_CH_IDX_MAX = 5,
+};
+
+struct halmac_ch_info {
+	enum halmac_cs_action_id action_id;
+	enum halmac_bw bw;
+	enum halmac_pri_ch_idx pri_ch_idx;
+	u8 channel;
+	u8 timeout;
+	u8 extra_info;
+};
+
+struct halmac_ch_extra_info {
+	u8 extra_info;
+	enum halmac_cs_extra_action_id extra_action_id;
+	u8 extra_info_size;
+	u8 *extra_info_data;
+};
+
+enum halmac_cs_periodic_option {
+	HALMAC_CS_PERIODIC_NONE,
+	HALMAC_CS_PERIODIC_NORMAL,
+	HALMAC_CS_PERIODIC_2_PHASE,
+	HALMAC_CS_PERIODIC_SEAMLESS,
+};
+
+struct halmac_ch_switch_option {
+	enum halmac_bw dest_bw;
+	enum halmac_cs_periodic_option periodic_option;
+	enum halmac_pri_ch_idx dest_pri_ch_idx;
+	/* u32 tsf_high; */
+	u32 tsf_low;
+	u8 switch_en;
+	u8 dest_ch_en;
+	u8 absolute_time_en;
+	u8 dest_ch;
+	u8 normal_period;
+	u8 normal_period_sel;
+	u8 normal_cycle;
+	u8 phase_2_period;
+	u8 phase_2_period_sel;
+};
+
+struct halmac_p2pps {
+	u8 offload_en:1;
+	u8 role:1;
+	u8 ctwindow_en:1;
+	u8 noa_en:1;
+	u8 noa_sel:1;
+	u8 all_sta_sleep:1;
+	u8 discovery:1;
+	u8 disable_close_rf:1;
+	u8 p2p_port_id;
+	u8 p2p_group;
+	u8 p2p_macid;
+	u8 ctwindow_length;
+	u8 rsvd3;
+	u8 rsvd4;
+	u8 rsvd5;
+	u32 noa_duration_para;
+	u32 noa_interval_para;
+	u32 noa_start_time_para;
+	u32 noa_count_para;
+};
+
+struct halmac_fw_build_time {
+	u16 year;
+	u8 month;
+	u8 date;
+	u8 hour;
+	u8 min;
+};
+
+struct halmac_fw_version {
+	u16 version;
+	u8 sub_version;
+	u8 sub_index;
+	u16 h2c_version;
+	struct halmac_fw_build_time build_time;
+};
+
+enum halmac_rf_type {
+	HALMAC_RF_1T2R = 0,
+	HALMAC_RF_2T4R = 1,
+	HALMAC_RF_2T2R = 2,
+	HALMAC_RF_2T3R = 3,
+	HALMAC_RF_1T1R = 4,
+	HALMAC_RF_2T2R_GREEN = 5,
+	HALMAC_RF_3T3R = 6,
+	HALMAC_RF_3T4R = 7,
+	HALMAC_RF_4T4R = 8,
+	HALMAC_RF_MAX_TYPE = 0xF,
+};
+
+struct halmac_general_info {
+	u8 rfe_type;
+	enum halmac_rf_type rf_type;
+	u8 tx_ant_status;
+	u8 rx_ant_status;
+};
+
+struct halmac_pwr_tracking_para {
+	u8 enable;
+	u8 tx_pwr_index;
+	u8 pwr_tracking_offset_value;
+	u8 tssi_value;
+};
+
+struct halmac_pwr_tracking_option {
+	u8 type;
+	u8 bbswing_index;
+	/* pathA, pathB, pathC, pathD */
+	struct halmac_pwr_tracking_para pwr_tracking_para[4];
+};
+
+struct halmac_fast_edca_cfg {
+	enum halmac_acq_id acq_id;
+	u8 queue_to; /* unit : 32us*/
+};
+
+enum halmac_data_rate {
+	HALMAC_CCK1,
+	HALMAC_CCK2,
+	HALMAC_CCK5_5,
+	HALMAC_CCK11,
+	HALMAC_OFDM6,
+	HALMAC_OFDM9,
+	HALMAC_OFDM12,
+	HALMAC_OFDM18,
+	HALMAC_OFDM24,
+	HALMAC_OFDM36,
+	HALMAC_OFDM48,
+	HALMAC_OFDM54,
+	HALMAC_MCS0,
+	HALMAC_MCS1,
+	HALMAC_MCS2,
+	HALMAC_MCS3,
+	HALMAC_MCS4,
+	HALMAC_MCS5,
+	HALMAC_MCS6,
+	HALMAC_MCS7,
+	HALMAC_MCS8,
+	HALMAC_MCS9,
+	HALMAC_MCS10,
+	HALMAC_MCS11,
+	HALMAC_MCS12,
+	HALMAC_MCS13,
+	HALMAC_MCS14,
+	HALMAC_MCS15,
+	HALMAC_MCS16,
+	HALMAC_MCS17,
+	HALMAC_MCS18,
+	HALMAC_MCS19,
+	HALMAC_MCS20,
+	HALMAC_MCS21,
+	HALMAC_MCS22,
+	HALMAC_MCS23,
+	HALMAC_MCS24,
+	HALMAC_MCS25,
+	HALMAC_MCS26,
+	HALMAC_MCS27,
+	HALMAC_MCS28,
+	HALMAC_MCS29,
+	HALMAC_MCS30,
+	HALMAC_MCS31,
+	HALMAC_VHT_NSS1_MCS0,
+	HALMAC_VHT_NSS1_MCS1,
+	HALMAC_VHT_NSS1_MCS2,
+	HALMAC_VHT_NSS1_MCS3,
+	HALMAC_VHT_NSS1_MCS4,
+	HALMAC_VHT_NSS1_MCS5,
+	HALMAC_VHT_NSS1_MCS6,
+	HALMAC_VHT_NSS1_MCS7,
+	HALMAC_VHT_NSS1_MCS8,
+	HALMAC_VHT_NSS1_MCS9,
+	HALMAC_VHT_NSS2_MCS0,
+	HALMAC_VHT_NSS2_MCS1,
+	HALMAC_VHT_NSS2_MCS2,
+	HALMAC_VHT_NSS2_MCS3,
+	HALMAC_VHT_NSS2_MCS4,
+	HALMAC_VHT_NSS2_MCS5,
+	HALMAC_VHT_NSS2_MCS6,
+	HALMAC_VHT_NSS2_MCS7,
+	HALMAC_VHT_NSS2_MCS8,
+	HALMAC_VHT_NSS2_MCS9,
+	HALMAC_VHT_NSS3_MCS0,
+	HALMAC_VHT_NSS3_MCS1,
+	HALMAC_VHT_NSS3_MCS2,
+	HALMAC_VHT_NSS3_MCS3,
+	HALMAC_VHT_NSS3_MCS4,
+	HALMAC_VHT_NSS3_MCS5,
+	HALMAC_VHT_NSS3_MCS6,
+	HALMAC_VHT_NSS3_MCS7,
+	HALMAC_VHT_NSS3_MCS8,
+	HALMAC_VHT_NSS3_MCS9,
+	HALMAC_VHT_NSS4_MCS0,
+	HALMAC_VHT_NSS4_MCS1,
+	HALMAC_VHT_NSS4_MCS2,
+	HALMAC_VHT_NSS4_MCS3,
+	HALMAC_VHT_NSS4_MCS4,
+	HALMAC_VHT_NSS4_MCS5,
+	HALMAC_VHT_NSS4_MCS6,
+	HALMAC_VHT_NSS4_MCS7,
+	HALMAC_VHT_NSS4_MCS8,
+	HALMAC_VHT_NSS4_MCS9,
+	 /*FPGA only*/
+	HALMAC_VHT_NSS5_MCS0,
+	HALMAC_VHT_NSS6_MCS0,
+	HALMAC_VHT_NSS7_MCS0,
+	HALMAC_VHT_NSS8_MCS0
+};
+
+enum halmac_rf_path {
+	HALMAC_RF_PATH_A,
+	HALMAC_RF_PATH_B,
+	HALMAC_RF_PATH_C,
+	HALMAC_RF_PATH_D
+};
+
+enum hal_security_type {
+	HAL_SECURITY_TYPE_NONE = 0,
+	HAL_SECURITY_TYPE_WEP40 = 1,
+	HAL_SECURITY_TYPE_WEP104 = 2,
+	HAL_SECURITY_TYPE_TKIP = 3,
+	HAL_SECURITY_TYPE_AES128 = 4,
+	HAL_SECURITY_TYPE_WAPI = 5,
+	HAL_SECURITY_TYPE_AES256 = 6,
+	HAL_SECURITY_TYPE_GCMP128 = 7,
+	HAL_SECURITY_TYPE_GCMP256 = 8,
+	HAL_SECURITY_TYPE_GCMSMS4 = 9,
+	HAL_SECURITY_TYPE_BIP = 10,
+	HAL_SECURITY_TYPE_UNDEFINE = 0x7F,
+};
+
+enum hal_intf_phy {
+	HAL_INTF_PHY_USB2 = 0,
+	HAL_INTF_PHY_USB3 = 1,
+	HAL_INTF_PHY_PCIE_GEN1 = 2,
+	HAL_INTF_PHY_PCIE_GEN2 = 3,
+	HAL_INTF_PHY_UNDEFINE = 0x7F,
+};
+
+struct halmac_cut_amsdu_cfg {
+	u8 cut_amsdu_en;
+	u8 chk_len_en;
+	u8 chk_len_def_val;
+	u8 chk_len_l_th;
+	u16 chk_len_h_th;
+};
+
+enum halmac_dbg_msg_info {
+	HALMAC_DBG_ALWAYS,
+	HALMAC_DBG_ERR,
+	HALMAC_DBG_WARN,
+	HALMAC_DBG_TRACE,
+};
+
+enum halmac_dbg_msg_type {
+	HALMAC_MSG_INIT,
+	HALMAC_MSG_EFUSE,
+	HALMAC_MSG_FW,
+	HALMAC_MSG_H2C,
+	HALMAC_MSG_PWR,
+	HALMAC_MSG_SND,
+	HALMAC_MSG_COMMON,
+	HALMAC_MSG_DBI,
+	HALMAC_MSG_MDIO,
+	HALMAC_MSG_USB,
+};
+
+enum halmac_feature_id {
+	HALMAC_FEATURE_CFG_PARA,                /* Support */
+	HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE,     /* Support */
+	HALMAC_FEATURE_DUMP_LOGICAL_EFUSE,      /* Support */
+	HALMAC_FEATURE_UPDATE_PACKET,           /* Support */
+	HALMAC_FEATURE_UPDATE_DATAPACK,
+	HALMAC_FEATURE_RUN_DATAPACK,
+	HALMAC_FEATURE_CHANNEL_SWITCH,  /* Support */
+	HALMAC_FEATURE_IQK,             /* Support */
+	HALMAC_FEATURE_POWER_TRACKING,  /* Support */
+	HALMAC_FEATURE_PSD,             /* Support */
+	HALMAC_FEATURE_FW_SNDING,       /* Support */
+	HALMAC_FEATURE_ALL,             /* Support, only for reset */
+};
+
+enum halmac_drv_rsvd_pg_num {
+	HALMAC_RSVD_PG_NUM8,	/* 1K */
+	HALMAC_RSVD_PG_NUM16,   /* 2K */
+	HALMAC_RSVD_PG_NUM24,   /* 3K */
+	HALMAC_RSVD_PG_NUM32,   /* 4K */
+	HALMAC_RSVD_PG_NUM64,   /* 8K */
+	HALMAC_RSVD_PG_NUM128,  /* 16K */
+};
+
+enum halmac_pcie_cfg {
+	HALMAC_PCIE_GEN1,
+	HALMAC_PCIE_GEN2,
+	HALMAC_PCIE_CFG_UNDEFINE,
+};
+
+enum halmac_portid {
+	HALMAC_PORTID0 = 0,
+	HALMAC_PORTID1 = 1,
+	HALMAC_PORTID2 = 2,
+	HALMAC_PORTID3 = 3,
+	HALMAC_PORTID4 = 4,
+	HALMAC_PORTID_NUM = 5,
+};
+
+struct halmac_bcn_ctrl {
+	u8 dis_rx_bssid_fit;
+	u8 en_txbcn_rpt;
+	u8 dis_tsf_udt;
+	u8 en_bcn;
+	u8 en_rxbcn_rpt;
+	u8 en_p2p_ctwin;
+	u8 en_p2p_bcn_area;
+};
+
+/* User only can use  Address[6]*/
+/* Address[0] is lowest, Address[5] is highest */
+union halmac_wlan_addr {
+	u8 addr[6];
+	struct {
+		union {
+			u32 low;
+			u8 low_byte[4];
+		};
+		union {
+			u16 high;
+			u8 high_byte[2];
+		};
+	} addr_l_h;
+};
+
+struct halmac_platform_api {
+	/* R/W register */
+	u8 (*SDIO_CMD52_READ)(void *drv_adapter, u32 offset);
+	u8 (*SDIO_CMD53_READ_8)(void *drv_adapter, u32 offset);
+	u16 (*SDIO_CMD53_READ_16)(void *drv_adapter, u32 offset);
+	u32 (*SDIO_CMD53_READ_32)(void *drv_adapter, u32 offset);
+	u8 (*SDIO_CMD53_READ_N)(void *drv_adapter, u32 offset, u32 size,
+				u8 *data);
+	void (*SDIO_CMD52_WRITE)(void *drv_adapter, u32 offset, u8 value);
+	void (*SDIO_CMD53_WRITE_8)(void *drv_adapter, u32 offset, u8 value);
+	void (*SDIO_CMD53_WRITE_16)(void *drv_adapter, u32 offset, u16 value);
+	void (*SDIO_CMD53_WRITE_32)(void *drv_adapter, u32 offset, u32 value);
+	u8 (*REG_READ_8)(void *drv_adapter, u32 offset);
+	u16 (*REG_READ_16)(void *drv_adapter, u32 offset);
+	u32 (*REG_READ_32)(void *drv_adapter, u32 offset);
+	void (*REG_WRITE_8)(void *drv_adapter, u32 offset, u8 value);
+	void (*REG_WRITE_16)(void *drv_adapter, u32 offset, u16 value);
+	void (*REG_WRITE_32)(void *drv_adapter, u32 offset, u32 value);
+	u8 (*SDIO_CMD52_CIA_READ)(void *drv_adapter, u32 offset);
+
+	/* send pBuf to reserved page, the tx_desc is not included in pBuf */
+	/* driver need to fill tx_desc with qsel = bcn */
+	u8 (*SEND_RSVD_PAGE)(void *drv_adapter, u8 *buf, u32 size);
+	/* send pBuf to h2c queue, the tx_desc is not included in pBuf */
+	/* driver need to fill tx_desc with qsel = h2c */
+	u8 (*SEND_H2C_PKT)(void *drv_adapter, u8 *buf, u32 size);
+	/* send pBuf to fw cmd queue, the tx_desc is not included in pBuf */
+	/*driver need to fill tx_desc with qsel = h2c */
+	u8 (*SEND_FWCMD)(void *drv_adapter, u8 *buf, u32 size);
+
+	u8 (*RTL_FREE)(void *drv_adapter, void *buf, u32 size);
+	void* (*RTL_MALLOC)(void *drv_adapter, u32 size);
+	u8 (*RTL_MEMCPY)(void *drv_adapter, void *dest, void *src, u32 size);
+	u8 (*RTL_MEMSET)(void *drv_adapter, void *addr, u8 value, u32 size);
+	void (*RTL_DELAY_US)(void *drv_adapter, u32 us);
+
+	u8 (*MUTEX_INIT)(void *drv_adapter, HALMAC_MUTEX *mutex);
+	u8 (*MUTEX_DEINIT)(void *drv_adapter, HALMAC_MUTEX *mutex);
+	u8 (*MUTEX_LOCK)(void *drv_adapter, HALMAC_MUTEX *mutex);
+	u8 (*MUTEX_UNLOCK)(void *drv_adapter, HALMAC_MUTEX *mutex);
+
+	u8 (*MSG_PRINT)(void *drv_adapter, u32 msg_type, u8 msg_level,
+			s8 *fmt, ...);
+	u8 (*BUFF_PRINT)(void *drv_adapter, u32 msg_type, u8 msg_level, s8 *buf,
+			 u32 size);
+
+	u8 (*EVENT_INDICATION)(void *drv_adapter,
+			       enum halmac_feature_id feature_id,
+			       enum halmac_cmd_process_status process_status,
+			       u8 *buf, u32 size);
+
+#if HALMAC_PLATFORM_TESTPROGRAM
+	struct halmisc_platform_api *halmisc_pltfm_api;
+#endif
+};
+
+enum halmac_snd_role {
+	HAL_BFER = 0,
+	HAL_BFEE = 1,
+};
+
+enum halmac_csi_seg_len {
+	HAL_CSI_SEG_4K = 0,
+	HAL_CSI_SEG_8K = 1,
+	HAL_CSI_SEG_11K = 2,
+};
+
+struct halmac_cfg_mumimo_para {
+	enum halmac_snd_role role;
+	u8 sounding_sts[6];
+	u16 grouping_bitmap;
+	u8 mu_tx_en;
+	u32 given_gid_tab[2];
+	u32 given_user_pos[4];
+};
+
+struct halmac_su_bfer_init_para {
+	u8 userid;
+	u16 paid;
+	u16 csi_para;
+	union halmac_wlan_addr bfer_address;
+};
+
+struct halmac_mu_bfee_init_para {
+	u8 userid;
+	u16 paid;
+	u32 user_position_l;	/*for gid 0~15*/
+	u32 user_position_h;	/*for gid 16~31*/
+	u32 user_position_l_1;	/*for gid 32~47*/
+	u32 user_position_h_1;	/*for gid 48~63*/
+};
+
+struct halmac_mu_bfer_init_para {
+	u16 paid;
+	u16 csi_para;
+	u16 my_aid;
+	enum halmac_csi_seg_len csi_length_sel;
+	union halmac_wlan_addr bfer_address;
+};
+
+struct halmac_ch_sw_info {
+	u8 *buf;
+	u8 *buf_wptr;
+	u8 extra_info_en;
+	u32 buf_size;
+	u32 avl_buf_size;
+	u32 total_size;
+	u32 ch_num;
+};
+
+struct halmac_event_trigger {
+	u32 phy_efuse_map : 1;
+	u32 log_efuse_map : 1;
+	u32 rsvd1 : 28;
+};
+
+struct halmac_h2c_header_info {
+	u16 sub_cmd_id;
+	u16 content_size;
+	u8 ack;
+};
+
+struct halmac_ver {
+	u8 major_ver;
+	u8 prototype_ver;
+	u8 minor_ver;
+};
+
+enum halmac_api_id {
+	/*stuff, need to be the 1st*/
+	HALMAC_API_STUFF = 0x0,
+	/*stuff, need to be the 1st*/
+	HALMAC_API_MAC_POWER_SWITCH = 0x1,
+	HALMAC_API_DOWNLOAD_FIRMWARE = 0x2,
+	HALMAC_API_CFG_MAC_ADDR = 0x3,
+	HALMAC_API_CFG_BSSID = 0x4,
+	HALMAC_API_CFG_MULTICAST_ADDR = 0x5,
+	HALMAC_API_PRE_INIT_SYSTEM_CFG = 0x6,
+	HALMAC_API_INIT_SYSTEM_CFG = 0x7,
+	HALMAC_API_INIT_TRX_CFG = 0x8,
+	HALMAC_API_CFG_RX_AGGREGATION = 0x9,
+	HALMAC_API_INIT_PROTOCOL_CFG = 0xA,
+	HALMAC_API_INIT_EDCA_CFG = 0xB,
+	HALMAC_API_CFG_OPERATION_MODE = 0xC,
+	HALMAC_API_CFG_CH_BW = 0xD,
+	HALMAC_API_CFG_BW = 0xE,
+	HALMAC_API_INIT_WMAC_CFG = 0xF,
+	HALMAC_API_INIT_MAC_CFG = 0x10,
+	HALMAC_API_INIT_SDIO_CFG = 0x11,
+	HALMAC_API_INIT_USB_CFG = 0x12,
+	HALMAC_API_INIT_PCIE_CFG = 0x13,
+	HALMAC_API_INIT_INTERFACE_CFG = 0x14,
+	HALMAC_API_DEINIT_SDIO_CFG = 0x15,
+	HALMAC_API_DEINIT_USB_CFG = 0x16,
+	HALMAC_API_DEINIT_PCIE_CFG = 0x17,
+	HALMAC_API_DEINIT_INTERFACE_CFG = 0x18,
+	HALMAC_API_GET_EFUSE_SIZE = 0x19,
+	HALMAC_API_DUMP_EFUSE_MAP = 0x1A,
+	HALMAC_API_GET_LOGICAL_EFUSE_SIZE = 0x1D,
+	HALMAC_API_DUMP_LOGICAL_EFUSE_MAP = 0x1E,
+	HALMAC_API_WRITE_LOGICAL_EFUSE = 0x1F,
+	HALMAC_API_READ_LOGICAL_EFUSE = 0x20,
+	HALMAC_API_PG_EFUSE_BY_MAP = 0x21,
+	HALMAC_API_GET_C2H_INFO = 0x22,
+	HALMAC_API_CFG_FWLPS_OPTION = 0x23,
+	HALMAC_API_CFG_FWIPS_OPTION = 0x24,
+	HALMAC_API_ENTER_WOWLAN = 0x25,
+	HALMAC_API_LEAVE_WOWLAN = 0x26,
+	HALMAC_API_ENTER_PS = 0x27,
+	HALMAC_API_LEAVE_PS = 0x28,
+	HALMAC_API_H2C_LB = 0x29,
+	HALMAC_API_DEBUG = 0x2A,
+	HALMAC_API_CFG_PARAMETER = 0x2B,
+	HALMAC_API_UPDATE_PACKET = 0x2C,
+	HALMAC_API_BCN_IE_FILTER = 0x2D,
+	HALMAC_API_REG_READ_8 = 0x2E,
+	HALMAC_API_REG_WRITE_8 = 0x2F,
+	HALMAC_API_REG_READ_16 = 0x30,
+	HALMAC_API_REG_WRITE_16 = 0x31,
+	HALMAC_API_REG_READ_32 = 0x32,
+	HALMAC_API_REG_WRITE_32 = 0x33,
+	HALMAC_API_TX_ALLOWED_SDIO = 0x34,
+	HALMAC_API_SET_BULKOUT_NUM = 0x35,
+	HALMAC_API_GET_SDIO_TX_ADDR = 0x36,
+	HALMAC_API_GET_USB_BULKOUT_ID = 0x37,
+	HALMAC_API_TIMER_2S = 0x38,
+	HALMAC_API_FILL_TXDESC_CHECKSUM = 0x39,
+	HALMAC_API_SEND_ORIGINAL_H2C = 0x3A,
+	HALMAC_API_UPDATE_DATAPACK = 0x3B,
+	HALMAC_API_RUN_DATAPACK = 0x3C,
+	HALMAC_API_CFG_DRV_INFO = 0x3D,
+	HALMAC_API_SEND_BT_COEX = 0x3E,
+	HALMAC_API_VERIFY_PLATFORM_API = 0x3F,
+	HALMAC_API_GET_FIFO_SIZE = 0x40,
+	HALMAC_API_DUMP_FIFO = 0x41,
+	HALMAC_API_CFG_TXBF = 0x42,
+	HALMAC_API_CFG_MUMIMO = 0x43,
+	HALMAC_API_CFG_SOUNDING = 0x44,
+	HALMAC_API_DEL_SOUNDING = 0x45,
+	HALMAC_API_SU_BFER_ENTRY_INIT = 0x46,
+	HALMAC_API_SU_BFEE_ENTRY_INIT = 0x47,
+	HALMAC_API_MU_BFER_ENTRY_INIT = 0x48,
+	HALMAC_API_MU_BFEE_ENTRY_INIT = 0x49,
+	HALMAC_API_SU_BFER_ENTRY_DEL = 0x4A,
+	HALMAC_API_SU_BFEE_ENTRY_DEL = 0x4B,
+	HALMAC_API_MU_BFER_ENTRY_DEL = 0x4C,
+	HALMAC_API_MU_BFEE_ENTRY_DEL = 0x4D,
+	HALMAC_API_ADD_CH_INFO = 0x4E,
+	HALMAC_API_ADD_EXTRA_CH_INFO = 0x4F,
+	HALMAC_API_CTRL_CH_SWITCH = 0x50,
+	HALMAC_API_CLEAR_CH_INFO = 0x51,
+	HALMAC_API_SEND_GENERAL_INFO = 0x52,
+	HALMAC_API_START_IQK = 0x53,
+	HALMAC_API_CTRL_PWR_TRACKING = 0x54,
+	HALMAC_API_PSD = 0x55,
+	HALMAC_API_CFG_TX_AGG_ALIGN = 0x56,
+	HALMAC_API_QUERY_STATE = 0x57,
+	HALMAC_API_RESET_FEATURE = 0x58,
+	HALMAC_API_CHECK_FW_STATUS = 0x59,
+	HALMAC_API_DUMP_FW_DMEM = 0x5A,
+	HALMAC_API_CFG_MAX_DL_SIZE = 0x5B,
+	HALMAC_API_INIT_OBJ = 0x5C,
+	HALMAC_API_DEINIT_OBJ = 0x5D,
+	HALMAC_API_CFG_LA_MODE = 0x5E,
+	HALMAC_API_GET_HW_VALUE = 0x5F,
+	HALMAC_API_SET_HW_VALUE = 0x60,
+	HALMAC_API_CFG_DRV_RSVD_PG_NUM = 0x61,
+	HALMAC_API_WRITE_EFUSE_BT = 0x63,
+	HALMAC_API_DUMP_EFUSE_MAP_BT = 0x64,
+	HALMAC_API_DL_DRV_RSVD_PG = 0x65,
+	HALMAC_API_PCIE_SWITCH = 0x66,
+	HALMAC_API_PHY_CFG = 0x67,
+	HALMAC_API_CFG_RX_FIFO_EXPANDING_MODE = 0x68,
+	HALMAC_API_CFG_CSI_RATE = 0x69,
+	HALMAC_API_P2PPS = 0x6A,
+	HALMAC_API_CFG_TX_ADDR = 0x6B,
+	HALMAC_API_CFG_NET_TYPE = 0x6C,
+	HALMAC_API_CFG_TSF_RESET = 0x6D,
+	HALMAC_API_CFG_BCN_SPACE = 0x6E,
+	HALMAC_API_CFG_BCN_CTRL = 0x6F,
+	HALMAC_API_CFG_SIDEBAND_INT = 0x70,
+	HALMAC_API_REGISTER_API = 0x71,
+	HALMAC_API_FREE_DOWNLOAD_FIRMWARE = 0x72,
+	HALMAC_API_GET_FW_VERSION = 0x73,
+	HALMAC_API_GET_EFUSE_AVAL_SIZE = 0x74,
+	HALMAC_API_CHK_TXDESC = 0x75,
+	HALMAC_API_SDIO_CMD53_4BYTE = 0x76,
+	HALMAC_API_CFG_TRANS_ADDR = 0x77,
+	HALMAC_API_INTF_INTEGRA_TUNING	= 0x78,
+	HALMAC_API_TXFIFO_IS_EMPTY = 0x79,
+	HALMAC_API_DOWNLOAD_FLASH = 0x7A,
+	HALMAC_API_READ_FLASH = 0x7B,
+	HALMAC_API_ERASE_FLASH = 0x7C,
+	HALMAC_API_CHECK_FLASH = 0x7D,
+	HALMAC_API_SDIO_HW_INFO = 0x80,
+	HALMAC_API_READ_EFUSE_BT = 0x81,
+	HALMAC_API_CFG_EFUSE_AUTO_CHECK = 0x82,
+	HALMAC_API_CFG_PINMUX_GET_FUNC = 0x83,
+	HALMAC_API_CFG_PINMUX_SET_FUNC = 0x84,
+	HALMAC_API_CFG_PINMUX_FREE_FUNC = 0x85,
+	HALMAC_API_CFG_PINMUX_WL_LED_MODE = 0x86,
+	HALMAC_API_CFG_PINMUX_WL_LED_SW_CTRL = 0x87,
+	HALMAC_API_CFG_PINMUX_SDIO_INT_POLARITY = 0x88,
+	HALMAC_API_CFG_PINMUX_GPIO_MODE = 0x89,
+	HALMAC_API_CFG_PINMUX_GPIO_OUTPUT = 0x90,
+	HALMAC_API_REG_READ_INDIRECT_32 = 0x91,
+	HALMAC_API_REG_SDIO_CMD53_READ_N = 0x92,
+	HALMAC_API_PINMUX_PIN_STATUS = 0x94,
+	HALMAC_API_OFLD_FUNC_CFG = 0x95,
+	HALMAC_API_MASK_LOGICAL_EFUSE = 0x96,
+	HALMAC_API_RX_CUT_AMSDU_CFG = 0x97,
+	HALMAC_API_FW_SNDING = 0x98,
+	HALMAC_API_ENTER_CPU_SLEEP_MODE = 0x99,
+	HALMAC_API_GET_CPU_MODE = 0x9A,
+	HALMAC_API_DRV_FWCTRL = 0x9B,
+	HALMAC_API_EN_REF_AUTOK = 0x9C,
+	HALMAC_API_MAX
+};
+
+enum halmac_la_mode {
+	HALMAC_LA_MODE_DISABLE = 0,
+	HALMAC_LA_MODE_PARTIAL = 1,
+	HALMAC_LA_MODE_FULL = 2,
+	HALMAC_LA_MODE_UNDEFINE = 0x7F,
+};
+
+enum halmac_rx_fifo_expanding_mode {
+	HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE = 0,
+	HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK = 1,
+	HALMAC_RX_FIFO_EXPANDING_MODE_2_BLOCK = 2,
+	HALMAC_RX_FIFO_EXPANDING_MODE_3_BLOCK = 3,
+	HALMAC_RX_FIFO_EXPANDING_MODE_4_BLOCK = 4,
+	HALMAC_RX_FIFO_EXPANDING_MODE_UNDEFINE = 0x7F,
+};
+
+enum halmac_sdio_cmd53_4byte_mode {
+	HALMAC_SDIO_CMD53_4BYTE_MODE_DISABLE = 0,
+	HALMAC_SDIO_CMD53_4BYTE_MODE_RW = 1,
+	HALMAC_SDIO_CMD53_4BYTE_MODE_R = 2,
+	HALMAC_SDIO_CMD53_4BYTE_MODE_W = 3,
+	HALMAC_SDIO_CMD53_4BYTE_MODE_UNDEFINE = 0x7F,
+};
+
+enum halmac_usb_mode {
+	HALMAC_USB_MODE_U2 = 1,
+	HALMAC_USB_MODE_U3 = 2,
+};
+
+enum halmac_sdio_tx_format {
+	HALMAC_SDIO_AGG_MODE = 1,
+	HALMAC_SDIO_DUMMY_BLOCK_MODE = 2,
+	HALMAC_SDIO_DUMMY_AUTO_MODE = 3,
+};
+
+enum halmac_hw_id {
+	/* Get HW value */
+	HALMAC_HW_RQPN_MAPPING = 0x00,
+	HALMAC_HW_EFUSE_SIZE = 0x01,
+	HALMAC_HW_EEPROM_SIZE = 0x02,
+	HALMAC_HW_BT_BANK_EFUSE_SIZE = 0x03,
+	HALMAC_HW_BT_BANK1_EFUSE_SIZE = 0x04,
+	HALMAC_HW_BT_BANK2_EFUSE_SIZE = 0x05,
+	HALMAC_HW_TXFIFO_SIZE = 0x06,
+	HALMAC_HW_RXFIFO_SIZE = 0x07,
+	HALMAC_HW_RSVD_PG_BNDY = 0x08,
+	HALMAC_HW_CAM_ENTRY_NUM = 0x09,
+	HALMAC_HW_IC_VERSION = 0x0A,
+	HALMAC_HW_PAGE_SIZE = 0x0B,
+	HALMAC_HW_TX_AGG_ALIGN_SIZE = 0x0C,
+	HALMAC_HW_RX_AGG_ALIGN_SIZE = 0x0D,
+	HALMAC_HW_DRV_INFO_SIZE = 0x0E,
+	HALMAC_HW_TXFF_ALLOCATION = 0x0F,
+	HALMAC_HW_RSVD_EFUSE_SIZE = 0x10,
+	HALMAC_HW_FW_HDR_SIZE = 0x11,
+	HALMAC_HW_TX_DESC_SIZE = 0x12,
+	HALMAC_HW_RX_DESC_SIZE = 0x13,
+	HALMAC_HW_FW_MAX_SIZE = 0x14,
+	HALMAC_HW_ORI_H2C_SIZE = 0x15,
+	HALMAC_HW_RSVD_DRV_PGNUM = 0x16,
+	HALMAC_HW_TX_PAGE_SIZE = 0x17,
+	HALMAC_HW_USB_TXAGG_DESC_NUM = 0x18,
+	HALMAC_HW_WLAN_EFUSE_AVAILABLE_SIZE = 0x19,
+	HALMAC_HW_HIOE_INST_START = 0x1A,
+	HALMAC_HW_HIOE_INST_END = 0x1B,
+	HALMAC_HW_AC_OQT_SIZE = 0x1C,
+	HALMAC_HW_NON_AC_OQT_SIZE = 0x1D,
+	HALMAC_HW_AC_QUEUE_NUM = 0x1E,
+	HALMAC_HW_RQPN_CH_MAPPING = 0x1F,
+	HALMAC_HW_PWR_STATE = 0x20,
+	/* Set HW value */
+	HALMAC_HW_USB_MODE = 0x60,
+	HALMAC_HW_SEQ_EN = 0x61,
+	HALMAC_HW_BANDWIDTH = 0x62,
+	HALMAC_HW_CHANNEL = 0x63,
+	HALMAC_HW_PRI_CHANNEL_IDX = 0x64,
+	HALMAC_HW_EN_BB_RF = 0x65,
+	HALMAC_HW_SDIO_TX_PAGE_THRESHOLD = 0x66,
+	HALMAC_HW_AMPDU_CONFIG = 0x67,
+	HALMAC_HW_RX_SHIFT = 0x68,
+	HALMAC_HW_TXDESC_CHECKSUM = 0x69,
+	HALMAC_HW_RX_CLK_GATE = 0x6A,
+	HALMAC_HW_RXGCK_FIFO = 0x6B,
+	HALMAC_HW_RX_IGNORE = 0x6C,
+	HALMAC_HW_SDIO_TX_FORMAT = 0x6D,
+	HALMAC_HW_FAST_EDCA = 0x6E,
+	HALMAC_HW_LDO25_EN = 0x6F,
+	HALMAC_HW_PCIE_REF_AUTOK = 0x70,
+	HALMAC_HW_ID_UNDEFINE = 0x7F,
+};
+
+enum halmac_efuse_bank {
+	HALMAC_EFUSE_BANK_WIFI = 0,
+	HALMAC_EFUSE_BANK_BT = 1,
+	HALMAC_EFUSE_BANK_BT_1 = 2,
+	HALMAC_EFUSE_BANK_BT_2 = 3,
+	HALMAC_EFUSE_BANK_MAX,
+	HALMAC_EFUSE_BANK_UNDEFINE = 0X7F,
+};
+
+enum halmac_sdio_spec_ver {
+	HALMAC_SDIO_SPEC_VER_2_00 = 0,
+	HALMAC_SDIO_SPEC_VER_3_00 = 1,
+	HALMAC_SDIO_SPEC_VER_UNDEFINE = 0X7F,
+};
+
+enum halmac_gpio_func {
+	HALMAC_GPIO_FUNC_WL_LED = 0,
+	HALMAC_GPIO_FUNC_SDIO_INT = 1,
+	HALMAC_GPIO_FUNC_SW_IO_0 = 2,
+	HALMAC_GPIO_FUNC_SW_IO_1 = 3,
+	HALMAC_GPIO_FUNC_SW_IO_2 = 4,
+	HALMAC_GPIO_FUNC_SW_IO_3 = 5,
+	HALMAC_GPIO_FUNC_SW_IO_4 = 6,
+	HALMAC_GPIO_FUNC_SW_IO_5 = 7,
+	HALMAC_GPIO_FUNC_SW_IO_6 = 8,
+	HALMAC_GPIO_FUNC_SW_IO_7 = 9,
+	HALMAC_GPIO_FUNC_SW_IO_8 = 10,
+	HALMAC_GPIO_FUNC_SW_IO_9 = 11,
+	HALMAC_GPIO_FUNC_SW_IO_10 = 12,
+	HALMAC_GPIO_FUNC_SW_IO_11 = 13,
+	HALMAC_GPIO_FUNC_SW_IO_12 = 14,
+	HALMAC_GPIO_FUNC_SW_IO_13 = 15,
+	HALMAC_GPIO_FUNC_SW_IO_14 = 16,
+	HALMAC_GPIO_FUNC_SW_IO_15 = 17,
+	HALMAC_GPIO_FUNC_UNDEFINE = 0X7F,
+};
+
+enum halmac_wlled_mode {
+	HALMAC_WLLED_MODE_TRX = 0,
+	HALMAC_WLLED_MODE_TX = 1,
+	HALMAC_WLLED_MODE_RX = 2,
+	HALMAC_WLLED_MODE_SW_CTRL = 3,
+	HALMAC_WLLED_MODE_UNDEFINE = 0X7F,
+};
+
+enum halmac_psf_fcs_chk_thr {
+	HALMAC_PSF_FCS_CHK_THR_1 = 0,
+	HALMAC_PSF_FCS_CHK_THR_4 = 1,
+	HALMAC_PSF_FCS_CHK_THR_8 = 2,
+	HALMAC_PSF_FCS_CHK_THR_12 = 3,
+	HALMAC_PSF_FCS_CHK_THR_16 = 4,
+	HALMAC_PSF_FCS_CHK_THR_20 = 5,
+	HALMAC_PSF_FCS_CHK_THR_24 = 6,
+	HALMAC_PSF_FCS_CHK_THR_28 = 7,
+};
+
+struct halmac_txff_allocation {
+	u16 tx_fifo_pg_num;
+	u16 rsvd_pg_num;
+	u16 rsvd_drv_pg_num;
+	u16 acq_pg_num;
+	u16 high_queue_pg_num;
+	u16 low_queue_pg_num;
+	u16 normal_queue_pg_num;
+	u16 extra_queue_pg_num;
+	u16 pub_queue_pg_num;
+	u16 rsvd_boundary;
+	u16 rsvd_drv_addr;
+	u16 rsvd_h2c_info_addr;
+	u16 rsvd_h2c_sta_info_addr;
+	u16 rsvd_h2cq_addr;
+	u16 rsvd_cpu_instr_addr;
+	u16 rsvd_fw_txbuf_addr;
+	u16 rsvd_csibuf_addr;
+	enum halmac_la_mode la_mode;
+	enum halmac_rx_fifo_expanding_mode rx_fifo_exp_mode;
+};
+
+struct halmac_rqpn_map {
+	enum halmac_dma_mapping dma_map_vo;
+	enum halmac_dma_mapping dma_map_vi;
+	enum halmac_dma_mapping dma_map_be;
+	enum halmac_dma_mapping dma_map_bk;
+	enum halmac_dma_mapping dma_map_mg;
+	enum halmac_dma_mapping dma_map_hi;
+};
+
+struct halmac_rqpn_ch_map {
+	enum halmac_dma_ch dma_map_vo;
+	enum halmac_dma_ch dma_map_vi;
+	enum halmac_dma_ch dma_map_be;
+	enum halmac_dma_ch dma_map_bk;
+	enum halmac_dma_ch dma_map_mg;
+	enum halmac_dma_ch dma_map_hi;
+};
+
+struct halmac_security_setting {
+	u8 tx_encryption;
+	u8 rx_decryption;
+	u8 bip_enable;
+	u8 compare_keyid;
+};
+
+struct halmac_cam_entry_info {
+	enum hal_security_type security_type;
+	u32 key[4];
+	u32 key_ext[4];
+	u8 mac_address[6];
+	u8 unicast;
+	u8 key_id;
+	u8 valid;
+};
+
+struct halmac_cam_entry_format {
+	u16 key_id : 2;
+	u16 type : 3;
+	u16 mic : 1;
+	u16 grp : 1;
+	u16 spp_mode : 1;
+	u16 rpt_md : 1;
+	u16 ext_sectype : 1;
+	u16 mgnt : 1;
+	u16 rsvd1 : 4;
+	u16 valid : 1;
+	u8 mac_address[6];
+	u32 key[4];
+	u32 rsvd[2];
+};
+
+struct halmac_tx_page_threshold_info {
+	u32	threshold;
+	enum halmac_dma_mapping dma_queue_sel;
+	u8 enable;
+};
+
+struct halmac_ampdu_config {
+	u8 max_agg_num;
+	u8 max_len_en;
+	u32 ht_max_len;
+	u32 vht_max_len;
+};
+
+struct halmac_rqpn {
+	enum halmac_trx_mode mode;
+	enum halmac_dma_mapping dma_map_vo;
+	enum halmac_dma_mapping dma_map_vi;
+	enum halmac_dma_mapping dma_map_be;
+	enum halmac_dma_mapping dma_map_bk;
+	enum halmac_dma_mapping dma_map_mg;
+	enum halmac_dma_mapping dma_map_hi;
+};
+
+struct halmac_ch_mapping {
+	enum halmac_trx_mode mode;
+	enum halmac_dma_ch dma_map_vo;
+	enum halmac_dma_ch dma_map_vi;
+	enum halmac_dma_ch dma_map_be;
+	enum halmac_dma_ch dma_map_bk;
+	enum halmac_dma_ch dma_map_mg;
+	enum halmac_dma_ch dma_map_hi;
+};
+
+struct halmac_pg_num {
+	enum halmac_trx_mode mode;
+	u16 hq_num;
+	u16 nq_num;
+	u16 lq_num;
+	u16 exq_num;
+	u16 gap_num;/*used for loopback mode*/
+};
+
+struct halmac_ch_pg_num {
+	enum halmac_trx_mode mode;
+	u16 ch_num[HALMAC_TXDESC_DMA_CH16 + 1];
+	u16 gap_num;
+};
+
+struct halmac_intf_phy_para {
+	u16 offset;
+	u16 value;
+	u16 ip_sel;
+	u16 cut;
+	u16 plaform;
+};
+
+struct halmac_iqk_para {
+	u8 clear;
+	u8 segment_iqk;
+};
+
+struct halmac_txdesc_ie_param {
+	u8 *start_offset;
+	u8 *end_offset;
+	u8 *ie_offset;
+	u8 *ie_exist;
+};
+
+struct halmac_sdio_hw_info {
+	enum halmac_sdio_spec_ver spec_ver;
+	u32 clock_speed;
+	u8 io_hi_speed_flag; /* Halmac internal use */
+	enum halmac_sdio_tx_format tx_addr_format;
+	u16 block_size;
+	u8 tx_seq;
+	u8 io_indir_flag; /* Halmac internal use */
+};
+
+struct halmac_edca_para {
+	u8 aifs;
+	u8 cw;
+	u16 txop_limit;
+};
+
+struct halmac_mac_rx_ignore_cfg {
+	u8 hdr_chk_en;
+	u8 fcs_chk_en;
+	enum halmac_psf_fcs_chk_thr fcs_chk_thr;
+};
+
+struct halmac_pinmux_info {
+	/* byte0 */
+	u8 wl_led:1;
+	u8 sdio_int:1;
+	u8 rsvd1:6;
+	/* byte1 */
+	u8 sw_io_0:1;
+	u8 sw_io_1:1;
+	u8 sw_io_2:1;
+	u8 sw_io_3:1;
+	u8 sw_io_4:1;
+	u8 sw_io_5:1;
+	u8 sw_io_6:1;
+	u8 sw_io_7:1;
+	/* byte2 */
+	u8 sw_io_8:1;
+	u8 sw_io_9:1;
+	u8 sw_io_10:1;
+	u8 sw_io_11:1;
+	u8 sw_io_12:1;
+	u8 sw_io_13:1;
+	u8 sw_io_14:1;
+	u8 sw_io_15:1;
+};
+
+struct halmac_ofld_func_info {
+	u32 halmac_malloc_max_sz;
+	u32 rsvd_pg_drv_buf_max_sz;
+};
+
+struct halmac_pltfm_cfg_info {
+	u32 malloc_size;
+	u32 rsvd_pg_size;
+};
+
+struct halmac_su_snding_info {
+	u8 su0_en;
+	u8 *su0_ndpa_pkt;
+	u32 su0_pkt_sz;
+};
+
+struct halmac_mu_snding_info {
+	u8 tmp;
+};
+
+struct halmac_h2c_info {
+	u32 buf_fs;
+	u32 buf_size;
+	u8 seq_num;
+};
+
+struct halmac_adapter {
+	enum halmac_dma_mapping pq_map[HALMAC_PQ_MAP_NUM];
+	enum halmac_dma_ch ch_map[HALMAC_PQ_MAP_NUM];
+	HALMAC_MUTEX h2c_seq_mutex;
+	HALMAC_MUTEX efuse_mutex;
+	HALMAC_MUTEX sdio_indir_mutex; /*Protect sdio indirect access */
+	struct halmac_cfg_param_info cfg_param_info;
+	struct halmac_ch_sw_info ch_sw_info;
+	struct halmac_event_trigger evnt;
+	struct halmac_hw_cfg_info hw_cfg_info;
+	struct halmac_sdio_free_space sdio_fs;
+	struct halmac_api_registry api_registry;
+	struct halmac_pinmux_info pinmux_info;
+	struct halmac_pltfm_cfg_info pltfm_info;
+	struct halmac_h2c_info h2c_info;
+	void *drv_adapter;
+	u8 *efuse_map;
+	void *halmac_api;
+	struct halmac_platform_api *pltfm_api;
+	u32 efuse_end;
+	u32 dlfw_pkt_size;
+	enum halmac_chip_id chip_id;
+	enum halmac_chip_ver chip_ver;
+	struct halmac_fw_version fw_ver;
+	struct halmac_state halmac_state;
+	enum halmac_interface intf;
+	enum halmac_trx_mode trx_mode;
+	struct halmac_txff_allocation txff_alloc;
+	u8 efuse_map_valid;
+	u8 efuse_seg_size;
+	u8 rpwm;
+	u8 bulkout_num;
+	u8 drv_info_size;
+	enum halmac_sdio_cmd53_4byte_mode sdio_cmd53_4byte;
+	struct halmac_sdio_hw_info sdio_hw_info;
+	u8 tx_desc_transfer;
+	u8 tx_desc_checksum;
+	u8 efuse_auto_check_en;
+	u8 pcie_refautok_en;
+	u8 pwr_off_flow_flag;
+
+#if HALMAC_PLATFORM_TESTPROGRAM
+	struct halmisc_adapter *halmisc_adapter;
+#endif
+};
+
+struct halmac_api {
+	enum halmac_ret_status
+	(*halmac_register_api)(struct halmac_adapter *adapter,
+			       struct halmac_api_registry *registry);
+	enum halmac_ret_status
+	(*halmac_mac_power_switch)(struct halmac_adapter *adapter,
+				   enum halmac_mac_power pwr);
+	enum halmac_ret_status
+	(*halmac_download_firmware)(struct halmac_adapter *adapter, u8 *fw_bin,
+				    u32 size);
+	enum halmac_ret_status
+	(*halmac_free_download_firmware)(struct halmac_adapter *adapter,
+					 enum halmac_dlfw_mem mem_sel,
+					 u8 *fw_bin, u32 size);
+	enum halmac_ret_status
+	(*halmac_get_fw_version)(struct halmac_adapter *adapter,
+				 struct halmac_fw_version *ver);
+	enum halmac_ret_status
+	(*halmac_cfg_mac_addr)(struct halmac_adapter *adapter,
+			       u8 port, union halmac_wlan_addr *addr);
+	enum halmac_ret_status
+	(*halmac_cfg_bssid)(struct halmac_adapter *adapter, u8 port,
+			    union halmac_wlan_addr *addr);
+	enum halmac_ret_status
+	(*halmac_cfg_multicast_addr)(struct halmac_adapter *adapter,
+				     union halmac_wlan_addr *addr);
+	enum halmac_ret_status
+	(*halmac_pre_init_system_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_init_system_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_init_trx_cfg)(struct halmac_adapter *adapter,
+			       enum halmac_trx_mode mode);
+	enum halmac_ret_status
+	(*halmac_init_h2c)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_cfg_rx_aggregation)(struct halmac_adapter *adapter,
+				     struct halmac_rxagg_cfg *cfg);
+	enum halmac_ret_status
+	(*halmac_init_protocol_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_init_edca_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_cfg_operation_mode)(struct halmac_adapter *adapter,
+				     enum halmac_wireless_mode mode);
+	enum halmac_ret_status
+	(*halmac_cfg_ch_bw)(struct halmac_adapter *adapter, u8 ch,
+			    enum halmac_pri_ch_idx idx, enum halmac_bw bw);
+	enum halmac_ret_status
+	(*halmac_cfg_bw)(struct halmac_adapter *adapter, enum halmac_bw bw);
+	enum halmac_ret_status
+	(*halmac_init_wmac_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_init_mac_cfg)(struct halmac_adapter *adapter,
+			       enum halmac_trx_mode mode);
+	enum halmac_ret_status
+	(*halmac_init_interface_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_deinit_interface_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_init_sdio_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_init_usb_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_init_pcie_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_deinit_sdio_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_deinit_usb_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_deinit_pcie_cfg)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_get_efuse_size)(struct halmac_adapter *adapter, u32 *size);
+	enum halmac_ret_status
+	(*halmac_get_efuse_available_size)(struct halmac_adapter *adapter,
+					   u32 *size);
+	enum halmac_ret_status
+	(*halmac_dump_efuse_map)(struct halmac_adapter *adapter,
+				 enum halmac_efuse_read_cfg cfg);
+	enum halmac_ret_status
+	(*halmac_dump_efuse_map_bt)(struct halmac_adapter *adapter,
+				    enum halmac_efuse_bank bank, u32 size,
+				    u8 *map);
+	enum halmac_ret_status
+	(*halmac_write_efuse_bt)(struct halmac_adapter *adapter, u32 offset,
+				 u8 value, enum halmac_efuse_bank bank);
+	enum halmac_ret_status
+	(*halmac_read_efuse_bt)(struct halmac_adapter *adapter, u32 offset,
+				u8 *value, enum halmac_efuse_bank bank);
+	enum halmac_ret_status
+	(*halmac_cfg_efuse_auto_check)(struct halmac_adapter *adapter,
+				       u8 enable);
+	enum halmac_ret_status
+	(*halmac_get_logical_efuse_size)(struct halmac_adapter *adapter,
+					 u32 *size);
+	enum halmac_ret_status
+	(*halmac_dump_logical_efuse_map)(struct halmac_adapter *adapter,
+					 enum halmac_efuse_read_cfg cfg);
+	enum halmac_ret_status
+	(*halmac_write_logical_efuse)(struct halmac_adapter *adapter,
+				      u32 offset, u8 value);
+	enum halmac_ret_status
+	(*halmac_read_logical_efuse)(struct halmac_adapter *adapter, u32 offset,
+				     u8 *value);
+	enum halmac_ret_status
+	(*halmac_pg_efuse_by_map)(struct halmac_adapter *adapter,
+				  struct halmac_pg_efuse_info *info,
+				  enum halmac_efuse_read_cfg cfg);
+	enum halmac_ret_status
+	(*halmac_mask_logical_efuse)(struct halmac_adapter *adapter,
+				     struct halmac_pg_efuse_info *info);
+	enum halmac_ret_status
+	(*halmac_get_c2h_info)(struct halmac_adapter *adapter, u8 *buf,
+			       u32 size);
+	enum halmac_ret_status
+	(*halmac_h2c_lb)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_debug)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_cfg_parameter)(struct halmac_adapter *adapter,
+				struct halmac_phy_parameter_info *info,
+				u8 full_fifo);
+	enum halmac_ret_status
+	(*halmac_update_packet)(struct halmac_adapter *adapter,
+				enum halmac_packet_id pkt_id, u8 *pkt,
+				u32 size);
+	enum halmac_ret_status
+	(*halmac_bcn_ie_filter)(struct halmac_adapter *adapter,
+				struct halmac_bcn_ie_info *info);
+	u8
+	(*halmac_reg_read_8)(struct halmac_adapter *adapter, u32 offset);
+	enum halmac_ret_status
+	(*halmac_reg_write_8)(struct halmac_adapter *adapter, u32 offset,
+			      u8 value);
+	u16
+	(*halmac_reg_read_16)(struct halmac_adapter *adapter, u32 offset);
+	enum halmac_ret_status
+	(*halmac_reg_write_16)(struct halmac_adapter *adapter, u32 offset,
+			       u16 value);
+	u32
+	(*halmac_reg_read_32)(struct halmac_adapter *adapter, u32 offset);
+	enum halmac_ret_status
+	(*halmac_reg_write_32)(struct halmac_adapter *adapter, u32 offset,
+			       u32 value);
+	u32
+	(*halmac_reg_read_indirect_32)(struct halmac_adapter *adapter,
+				       u32 offset);
+	enum halmac_ret_status
+	(*halmac_reg_sdio_cmd53_read_n)(struct halmac_adapter *adapter,
+					u32 offset, u32 size, u8 *value);
+	enum halmac_ret_status
+	(*halmac_tx_allowed_sdio)(struct halmac_adapter *adapter, u8 *buf,
+				  u32 size);
+	enum halmac_ret_status
+	(*halmac_set_bulkout_num)(struct halmac_adapter *adapter, u8 num);
+	enum halmac_ret_status
+	(*halmac_get_sdio_tx_addr)(struct halmac_adapter *adapter, u8 *buf,
+				   u32 size, u32 *cmd53_addr);
+	enum halmac_ret_status
+	(*halmac_get_usb_bulkout_id)(struct halmac_adapter *adapter, u8 *buf,
+				     u32 size, u8 *id);
+	enum halmac_ret_status
+	(*halmac_fill_txdesc_checksum)(struct halmac_adapter *adapter,
+				       u8 *txdesc);
+	enum halmac_ret_status
+	(*halmac_update_datapack)(struct halmac_adapter *adapter,
+				  enum halmac_data_type data_type,
+				  struct halmac_phy_parameter_info *info);
+	enum halmac_ret_status
+	(*halmac_run_datapack)(struct halmac_adapter *adapter,
+			       enum halmac_data_type data_type);
+	enum halmac_ret_status
+	(*halmac_cfg_drv_info)(struct halmac_adapter *adapter,
+			       enum halmac_drv_info drv_info);
+	enum halmac_ret_status
+	(*halmac_send_bt_coex)(struct halmac_adapter *adapter, u8 *buf,
+			       u32 size, u8 ack);
+	enum halmac_ret_status
+	(*halmac_verify_platform_api)(struct halmac_adapter *adapter);
+	u32
+	(*halmac_get_fifo_size)(struct halmac_adapter *adapter,
+				enum hal_fifo_sel sel);
+	enum halmac_ret_status
+	(*halmac_dump_fifo)(struct halmac_adapter *adapter,
+			    enum hal_fifo_sel sel, u32 start_addr, u32 size,
+			    u8 *data);
+	enum halmac_ret_status
+	(*halmac_cfg_txbf)(struct halmac_adapter *adapter, u8 userid,
+			   enum halmac_bw bw, u8 txbf_en);
+	enum halmac_ret_status
+	(*halmac_cfg_mumimo)(struct halmac_adapter *adapter,
+			     struct halmac_cfg_mumimo_para *param);
+	enum halmac_ret_status
+	(*halmac_cfg_sounding)(struct halmac_adapter *adapter,
+			       enum halmac_snd_role role,
+			       enum halmac_data_rate rate);
+	enum halmac_ret_status
+	(*halmac_del_sounding)(struct halmac_adapter *adapter,
+			       enum halmac_snd_role role);
+	enum halmac_ret_status
+	(*halmac_su_bfer_entry_init)(struct halmac_adapter *adapter,
+				     struct halmac_su_bfer_init_para *param);
+	enum halmac_ret_status
+	(*halmac_su_bfee_entry_init)(struct halmac_adapter *adapter, u8 userid,
+				     u16 paid);
+	enum halmac_ret_status
+	(*halmac_mu_bfer_entry_init)(struct halmac_adapter *adapter,
+				     struct halmac_mu_bfer_init_para *param);
+	enum halmac_ret_status
+	(*halmac_mu_bfee_entry_init)(struct halmac_adapter *adapter,
+				     struct halmac_mu_bfee_init_para *param);
+	enum halmac_ret_status
+	(*halmac_su_bfer_entry_del)(struct halmac_adapter *adapter, u8 userid);
+	enum halmac_ret_status
+	(*halmac_su_bfee_entry_del)(struct halmac_adapter *adapter, u8 userid);
+	enum halmac_ret_status
+	(*halmac_mu_bfer_entry_del)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_mu_bfee_entry_del)(struct halmac_adapter *adapter, u8 userid);
+	enum halmac_ret_status
+	(*halmac_add_ch_info)(struct halmac_adapter *adapter,
+			      struct halmac_ch_info *info);
+	enum halmac_ret_status
+	(*halmac_add_extra_ch_info)(struct halmac_adapter *adapter,
+				    struct halmac_ch_extra_info *info);
+	enum halmac_ret_status
+	(*halmac_ctrl_ch_switch)(struct halmac_adapter *adapter,
+				 struct halmac_ch_switch_option *opt);
+	enum halmac_ret_status
+	(*halmac_p2pps)(struct halmac_adapter *adapter,
+			struct halmac_p2pps *info);
+	enum halmac_ret_status
+	(*halmac_clear_ch_info)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_send_general_info)(struct halmac_adapter *adapter,
+				    struct halmac_general_info *info);
+	enum halmac_ret_status
+	(*halmac_start_iqk)(struct halmac_adapter *adapter,
+			    struct halmac_iqk_para *param);
+	enum halmac_ret_status
+	(*halmac_ctrl_pwr_tracking)(struct halmac_adapter *adapter,
+				    struct halmac_pwr_tracking_option *opt);
+	enum halmac_ret_status
+	(*halmac_psd)(struct halmac_adapter *adapter, u16 start_psd,
+		      u16 end_psd);
+	enum halmac_ret_status
+	(*halmac_cfg_tx_agg_align)(struct halmac_adapter *adapter, u8 enable,
+				   u16 align_size);
+	enum halmac_ret_status
+	(*halmac_query_status)(struct halmac_adapter *adapter,
+			       enum halmac_feature_id feature_id,
+			       enum halmac_cmd_process_status *proc_status,
+			       u8 *data, u32 *size);
+	enum halmac_ret_status
+	(*halmac_reset_feature)(struct halmac_adapter *adapter,
+				enum halmac_feature_id feature_id);
+	enum halmac_ret_status
+	(*halmac_check_fw_status)(struct halmac_adapter *adapter,
+				  u8 *fw_status);
+	enum halmac_ret_status
+	(*halmac_dump_fw_dmem)(struct halmac_adapter *adapter, u8 *dmem,
+			       u32 *size);
+	enum halmac_ret_status
+	(*halmac_cfg_max_dl_size)(struct halmac_adapter *adapter, u32 size);
+	enum halmac_ret_status
+	(*halmac_cfg_la_mode)(struct halmac_adapter *adapter,
+			      enum halmac_la_mode mode);
+	enum halmac_ret_status
+	(*halmac_cfg_rxff_expand_mode)(struct halmac_adapter *adapter,
+				       enum halmac_rx_fifo_expanding_mode mode);
+	enum halmac_ret_status
+	(*halmac_config_security)(struct halmac_adapter *adapter,
+				  struct halmac_security_setting *setting);
+	u8
+	(*halmac_get_used_cam_entry_num)(struct halmac_adapter *adapter,
+					 enum hal_security_type sec_type);
+	enum halmac_ret_status
+	(*halmac_write_cam)(struct halmac_adapter *adapter, u32 idx,
+			    struct halmac_cam_entry_info *info);
+	enum halmac_ret_status
+	(*halmac_read_cam_entry)(struct halmac_adapter *adapter, u32 idx,
+				 struct halmac_cam_entry_format *content);
+	enum halmac_ret_status
+	(*halmac_clear_cam_entry)(struct halmac_adapter *adapter, u32 idx);
+	enum halmac_ret_status
+	(*halmac_get_hw_value)(struct halmac_adapter *adapter,
+			       enum halmac_hw_id hw_id, void *value);
+	enum halmac_ret_status
+	(*halmac_set_hw_value)(struct halmac_adapter *adapter,
+			       enum halmac_hw_id hw_id, void *value);
+	enum halmac_ret_status
+	(*halmac_cfg_drv_rsvd_pg_num)(struct halmac_adapter *adapter,
+				      enum halmac_drv_rsvd_pg_num pg_num);
+	enum halmac_ret_status
+	(*halmac_get_chip_version)(struct halmac_adapter *adapter,
+				   struct halmac_ver *ver);
+	enum halmac_ret_status
+	(*halmac_chk_txdesc)(struct halmac_adapter *adapter, u8 *buf, u32 size);
+	enum halmac_ret_status
+	(*halmac_dl_drv_rsvd_page)(struct halmac_adapter *adapter, u8 pg_offset,
+				   u8 *buf, u32 size);
+	enum halmac_ret_status
+	(*halmac_pcie_switch)(struct halmac_adapter *adapter,
+			      enum halmac_pcie_cfg cfg);
+	enum halmac_ret_status
+	(*halmac_phy_cfg)(struct halmac_adapter *adapter,
+			  enum halmac_intf_phy_platform pltfm);
+	enum halmac_ret_status
+	(*halmac_cfg_csi_rate)(struct halmac_adapter *adapter, u8 rssi,
+			       u8 cur_rate, u8 fixrate_en, u8 *new_rate);
+	enum halmac_ret_status
+	(*halmac_sdio_cmd53_4byte)(struct halmac_adapter *adapter,
+				   enum halmac_sdio_cmd53_4byte_mode mode);
+	enum halmac_ret_status
+	(*halmac_sdio_hw_info)(struct halmac_adapter *adapter,
+			       struct halmac_sdio_hw_info *info);
+	enum halmac_ret_status
+	(*halmac_cfg_transmitter_addr)(struct halmac_adapter *adapter, u8 port,
+				       union halmac_wlan_addr *addr);
+	enum halmac_ret_status
+	(*halmac_cfg_net_type)(struct halmac_adapter *adapter, u8 port,
+			       enum halmac_network_type_select net_type);
+	enum halmac_ret_status
+	(*halmac_cfg_tsf_rst)(struct halmac_adapter *adapter, u8 port);
+	enum halmac_ret_status
+	(*halmac_cfg_bcn_space)(struct halmac_adapter *adapter, u8 port,
+				u32 bcn_space);
+	enum halmac_ret_status
+	(*halmac_rw_bcn_ctrl)(struct halmac_adapter *adapter, u8 port,
+			      u8 write_en, struct halmac_bcn_ctrl *ctrl);
+	enum halmac_ret_status
+	(*halmac_interface_integration_tuning)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_txfifo_is_empty)(struct halmac_adapter *adapter, u32 chk_num);
+	enum halmac_ret_status
+	(*halmac_download_flash)(struct halmac_adapter *adapter, u8 *fw_bin,
+				 u32 size, u32 rom_addr);
+	enum halmac_ret_status
+	(*halmac_read_flash)(struct halmac_adapter *adapter, u32 addr);
+	enum halmac_ret_status
+	(*halmac_erase_flash)(struct halmac_adapter *adapter, u8 erase_cmd,
+			      u32 addr);
+	enum halmac_ret_status
+	(*halmac_check_flash)(struct halmac_adapter *adapter, u8 *fw_bin,
+			      u32 size, u32 addr);
+	enum halmac_ret_status
+	(*halmac_cfg_edca_para)(struct halmac_adapter *adapter,
+				enum halmac_acq_id acq_id,
+				struct halmac_edca_para *param);
+	enum halmac_ret_status
+	(*halmac_pinmux_get_func)(struct halmac_adapter *adapter,
+				  enum halmac_gpio_func gpio_func, u8 *enable);
+	enum halmac_ret_status
+	(*halmac_pinmux_set_func)(struct halmac_adapter *adapter,
+				  enum halmac_gpio_func gpio_func);
+	enum halmac_ret_status
+	(*halmac_pinmux_free_func)(struct halmac_adapter *adapter,
+				   enum halmac_gpio_func gpio_func);
+	enum halmac_ret_status
+	(*halmac_pinmux_wl_led_mode)(struct halmac_adapter *adapter,
+				     enum halmac_wlled_mode mode);
+	void
+	(*halmac_pinmux_wl_led_sw_ctrl)(struct halmac_adapter *adapter, u8 on);
+	void
+	(*halmac_pinmux_sdio_int_polarity)(struct halmac_adapter *adapter,
+					   u8 low_active);
+	enum halmac_ret_status
+	(*halmac_pinmux_gpio_mode)(struct halmac_adapter *adapter, u8 gpio_id,
+				   u8 output);
+	enum halmac_ret_status
+	(*halmac_pinmux_gpio_output)(struct halmac_adapter *adapter, u8 gpio_id,
+				     u8 high);
+	enum halmac_ret_status
+	(*halmac_pinmux_pin_status)(struct halmac_adapter *adapter, u8 pin_id,
+				    u8 *high);
+	enum halmac_ret_status
+	(*halmac_ofld_func_cfg)(struct halmac_adapter *adapter,
+				struct halmac_ofld_func_info *info);
+	enum halmac_ret_status
+	(*halmac_rx_cut_amsdu_cfg)(struct halmac_adapter *adapter,
+				   struct halmac_cut_amsdu_cfg *cfg);
+	enum halmac_ret_status
+	(*halmac_fw_snding)(struct halmac_adapter *adapter,
+			    struct halmac_su_snding_info *su_info,
+			    struct halmac_mu_snding_info *mu_info, u8 period);
+	enum halmac_ret_status
+	(*halmac_get_mac_addr)(struct halmac_adapter *adapter, u8 port,
+			       union halmac_wlan_addr *addr);
+	enum halmac_ret_status
+	(*halmac_init_low_pwr)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_enter_cpu_sleep_mode)(struct halmac_adapter *adapter);
+	enum halmac_ret_status
+	(*halmac_get_cpu_mode)(struct halmac_adapter *adapter,
+			       enum halmac_wlcpu_mode *mode);
+	enum halmac_ret_status
+	(*halmac_drv_fwctrl)(struct halmac_adapter *adapter, u8 *payload,
+			     u32 size, u8 ack);
+	enum halmac_ret_status
+	(*halmac_read_efuse)(struct halmac_adapter *adapter, u32 offset,
+			     u8 *value);
+	enum halmac_ret_status
+	(*halmac_write_efuse)(struct halmac_adapter *adapter, u32 offset,
+			      u8 value);
+	VOID
+	(*halmac_en_ref_autok_pcie)(struct halmac_adapter *adapter, u8 en);
+#if HALMAC_PLATFORM_TESTPROGRAM
+	struct halmisc_api *halmisc_api;
+#endif
+};
+
+#define HALMAC_GET_API(halmac_adapter)                                         \
+	((struct halmac_api *)halmac_adapter->halmac_api)
+
+static HALMAC_INLINE enum halmac_ret_status
+halmac_fw_validate(struct halmac_adapter *adapter)
+{
+	if (adapter->halmac_state.dlfw_state != HALMAC_DLFW_DONE &&
+	    adapter->halmac_state.dlfw_state != HALMAC_GEN_INFO_SENT)
+		return HALMAC_RET_NO_DLFW;
+
+	return HALMAC_RET_SUCCESS;
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_usb_reg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_usb_reg.h
new file mode 100644
index 000000000000..b856c55ef6cf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/halmac/halmac_usb_reg.h
@@ -0,0 +1,19 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 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 __HALMAC_USB_REG_H__
+#define __HALMAC_USB_REG_H__
+
+#endif/* __HALMAC_USB_REG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/led/hal_led.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/led/hal_led.c
new file mode 100644
index 000000000000..95d3daa24315
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/led/hal_led.c
@@ -0,0 +1,254 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+
+#ifdef CONFIG_RTW_LED
+void dump_led_config(void *sel, _adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+	int i;
+
+	RTW_PRINT_SEL(sel, "strategy:%u\n", ledpriv->LedStrategy);
+#ifdef CONFIG_RTW_SW_LED
+	RTW_PRINT_SEL(sel, "bRegUseLed:%u\n", ledpriv->bRegUseLed);
+	RTW_PRINT_SEL(sel, "iface_en_mask:0x%02X\n", ledpriv->iface_en_mask);
+	for (i = 0; i < dvobj->iface_nums; i++)
+		RTW_PRINT_SEL(sel, "ctl_en_mask[%d]:0x%08X\n", i, ledpriv->ctl_en_mask[i]);
+#endif
+}
+
+void rtw_led_set_strategy(_adapter *adapter, u8 strategy)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
+
+#ifndef CONFIG_RTW_SW_LED
+	if (IS_SW_LED_STRATEGY(strategy)) {
+		RTW_WARN("CONFIG_RTW_SW_LED is not defined\n");
+		return;
+	}
+#endif
+
+#ifdef CONFIG_RTW_SW_LED
+	if (!ledpriv->bRegUseLed)
+		return;
+#endif
+
+	if (ledpriv->LedStrategy == strategy)
+		return;
+
+	if (IS_HW_LED_STRATEGY(strategy) || IS_HW_LED_STRATEGY(ledpriv->LedStrategy)) {
+		RTW_WARN("switching on/off HW_LED strategy is not supported\n");
+		return;
+	}
+
+	ledpriv->LedStrategy = strategy;
+
+#ifdef CONFIG_RTW_SW_LED
+	rtw_hal_sw_led_deinit(pri_adapter);
+#endif
+
+	rtw_led_control(pri_adapter, RTW_LED_OFF);
+}
+
+#ifdef CONFIG_RTW_SW_LED
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+void rtw_sw_led_blink_uc_trx_only(LED_DATA *led)
+{
+	_adapter *adapter = led->padapter;
+	BOOLEAN bStopBlinking = _FALSE;
+
+	if (led->BlinkingLedState == RTW_LED_ON)
+		SwLedOn(adapter, led);
+	else
+		SwLedOff(adapter, led);
+
+	switch (led->CurrLedState) {
+	case RTW_LED_ON:
+		SwLedOn(adapter, led);
+		break;
+
+	case RTW_LED_OFF:
+		SwLedOff(adapter, led);
+		break;
+
+	case LED_BLINK_TXRX:
+		led->BlinkTimes--;
+		if (led->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (adapter_to_pwrctl(adapter)->rf_pwrstate != rf_on
+			&& adapter_to_pwrctl(adapter)->rfoff_reason > RF_CHANGE_BY_PS
+		) {
+			SwLedOff(adapter, led);
+			led->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (led->bLedOn)
+				led->BlinkingLedState = RTW_LED_OFF;
+			else
+				led->BlinkingLedState = RTW_LED_ON;
+			
+			if (bStopBlinking) {
+				led->CurrLedState = RTW_LED_OFF;
+				led->bLedBlinkInProgress = _FALSE;
+			}
+			_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	default:
+		break;
+	}
+}
+
+void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl)
+{
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+	LED_DATA *led = &(ledpriv->SwLed0);
+	LED_DATA *led1 = &(ledpriv->SwLed1);
+	LED_DATA *led2 = &(ledpriv->SwLed2);
+
+	switch (ctl) {
+	case LED_CTL_UC_TX:
+	case LED_CTL_UC_RX:
+		if (led->bLedBlinkInProgress == _FALSE) {
+			led->bLedBlinkInProgress = _TRUE;
+			led->CurrLedState = LED_BLINK_TXRX;
+			led->BlinkTimes = 2;
+			if (led->bLedOn)
+				led->BlinkingLedState = RTW_LED_OFF;
+			else
+				led->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		led->CurrLedState = RTW_LED_OFF;
+		led->BlinkingLedState = RTW_LED_OFF;
+
+		if (led->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(led->BlinkTimer));
+			led->bLedBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(adapter, led);
+		SwLedOff(adapter, led1);
+		SwLedOff(adapter, led2);
+		break;
+
+	default:
+		break;
+	}
+}
+#endif /* CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY */
+
+void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl)
+{
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+
+	if (ledpriv->LedControlHandler) {
+		#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+		if (ledpriv->LedStrategy != SW_LED_MODE_UC_TRX_ONLY) {
+			if (ctl == LED_CTL_UC_TX || ctl == LED_CTL_BMC_TX) {
+				if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_TX))
+					ctl = LED_CTL_TX; /* transform specific TX ctl to general TX ctl */
+			} else if (ctl == LED_CTL_UC_RX || ctl == LED_CTL_BMC_RX) {
+				if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_RX))
+					ctl = LED_CTL_RX; /* transform specific RX ctl to general RX ctl */
+			}
+		}
+		#endif
+
+		if ((ledpriv->iface_en_mask & BIT(adapter->iface_id))
+			&& (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(ctl)))
+			ledpriv->LedControlHandler(adapter, ctl);
+	}
+}
+
+void rtw_led_tx_control(_adapter *adapter, const u8 *da)
+{
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (IS_MCAST(da))
+		rtw_led_control(adapter, LED_CTL_BMC_TX);
+	else
+		rtw_led_control(adapter, LED_CTL_UC_TX);
+#else
+	rtw_led_control(adapter, LED_CTL_TX);
+#endif
+}
+
+void rtw_led_rx_control(_adapter *adapter, const u8 *da)
+{
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (IS_MCAST(da))
+		rtw_led_control(adapter, LED_CTL_BMC_RX);
+	else
+		rtw_led_control(adapter, LED_CTL_UC_RX);
+#else
+	rtw_led_control(adapter, LED_CTL_RX);
+#endif
+}
+
+void rtw_led_set_iface_en(_adapter *adapter, u8 en)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+	if (en)
+		ledpriv->iface_en_mask |= BIT(adapter->iface_id);
+	else
+		ledpriv->iface_en_mask &= ~BIT(adapter->iface_id);
+}
+
+void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+	ledpriv->iface_en_mask = mask;
+}
+
+void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+	
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (ctl_mask & BIT(LED_CTL_TX))
+		ctl_mask |= BIT(LED_CTL_UC_TX) | BIT(LED_CTL_BMC_TX);
+	if (ctl_mask & BIT(LED_CTL_RX))
+		ctl_mask |= BIT(LED_CTL_UC_RX) | BIT(LED_CTL_BMC_RX);
+#endif
+
+	ledpriv->ctl_en_mask[adapter->iface_id] = ctl_mask;
+}
+
+void rtw_led_set_ctl_en_mask_primary(_adapter *adapter)
+{
+	rtw_led_set_ctl_en_mask(adapter, 0xFFFFFFFF);
+}
+
+void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter)
+{
+	rtw_led_set_ctl_en_mask(adapter
+		, BIT(LED_CTL_POWER_ON) | BIT(LED_CTL_POWER_OFF)
+		| BIT(LED_CTL_TX) | BIT(LED_CTL_RX)
+	);
+}
+#endif /* CONFIG_RTW_SW_LED */
+
+#endif /* CONFIG_RTW_LED */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/led/hal_usb_led.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/led/hal_usb_led.c
new file mode 100644
index 000000000000..19505b130f5e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/led/hal_usb_led.c
@@ -0,0 +1,4290 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+#ifdef CONFIG_RTW_SW_LED
+
+/*
+ *	Description:
+ *		Implementation of LED blinking behavior.
+ *		It toggle off LED and schedule corresponding timer if necessary.
+ *   */
+void
+SwLedBlink(
+	PLED_USB			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	/* Determine if we shall change LED state again. */
+	pLed->BlinkTimes--;
+	switch (pLed->CurrLedState) {
+
+	case LED_BLINK_NORMAL:
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		break;
+
+	case LED_BLINK_StartToBlink:
+		if (check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE))
+			bStopBlinking = _TRUE;
+		if (check_fwstate(pmlmepriv, _FW_LINKED) &&
+		    (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)))
+			bStopBlinking = _TRUE;
+		else if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		break;
+
+
+	default:
+		bStopBlinking = _TRUE;
+		break;
+
+	}
+
+	if (bStopBlinking) {
+		if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+			SwLedOff(padapter, pLed);
+		else if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && (pLed->bLedOn == _FALSE))
+			SwLedOn(padapter, pLed);
+		else if ((check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) &&  pLed->bLedOn == _TRUE)
+			SwLedOff(padapter, pLed);
+
+		pLed->BlinkTimes = 0;
+		pLed->bLedBlinkInProgress = _FALSE;
+	} else {
+		/* Assign LED state to toggle. */
+		if (pLed->BlinkingLedState == RTW_LED_ON)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+		/* Schedule a timer to toggle LED state. */
+		switch (pLed->CurrLedState) {
+		case LED_BLINK_NORMAL:
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			break;
+
+		case LED_BLINK_SLOWLY:
+		case LED_BLINK_StartToBlink:
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			break;
+
+		case LED_BLINK_WPS: {
+			if (pLed->BlinkingLedState == RTW_LED_ON)
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+			else
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+		}
+		break;
+
+		default:
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			break;
+		}
+	}
+}
+
+void
+SwLedBlink1(
+	PLED_USB			pLed
+)
+{
+	_adapter				*padapter = pLed->padapter;
+	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);
+	struct led_priv		*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
+	PLED_USB			pLed1 = &(ledpriv->SwLed1);
+	u8					bStopBlinking = _FALSE;
+
+	u32 uLedBlinkNoLinkInterval = LED_BLINK_NO_LINK_INTERVAL_ALPHA; /* add by ylb 20121012 for customer led for alpha */
+	if (pHalData->CustomerID == RT_CID_819x_ALPHA_Dlink)
+		uLedBlinkNoLinkInterval = LED_BLINK_NO_LINK_INTERVAL_ALPHA_500MS;
+
+	if (pHalData->CustomerID == RT_CID_819x_CAMEO)
+		pLed = &(ledpriv->SwLed1);
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+
+	if (pHalData->CustomerID == RT_CID_DEFAULT) {
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+			if (!pLed1->bSWLedCtrl) {
+				SwLedOn(padapter, pLed1);
+				pLed1->bSWLedCtrl = _TRUE;
+			} else if (!pLed1->bLedOn)
+				SwLedOn(padapter, pLed1);
+		} else {
+			if (!pLed1->bSWLedCtrl) {
+				SwLedOff(padapter, pLed1);
+				pLed1->bSWLedCtrl = _TRUE;
+			} else if (pLed1->bLedOn)
+				SwLedOff(padapter, pLed1);
+		}
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SLOWLY:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), uLedBlinkNoLinkInterval);/* change by ylb 20121012 for customer led for alpha */
+		break;
+
+	case LED_BLINK_NORMAL:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->bLedLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_NORMAL;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), uLedBlinkNoLinkInterval);
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->bLedLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_NORMAL;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), uLedBlinkNoLinkInterval);
+			}
+			pLed->BlinkTimes = 0;
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS success */
+		if (pLed->BlinkingLedState == RTW_LED_ON) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+			bStopBlinking = _FALSE;
+		} else
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->bLedLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_NORMAL;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+SwLedBlink2(
+	PLED_USB			pLed
+)
+{
+	_adapter				*padapter = pLed->padapter;
+	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
+	u8					bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				SwLedOff(padapter, pLed);
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				SwLedOff(padapter, pLed);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+SwLedBlink3(
+	PLED_USB			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		if (pLed->CurrLedState != LED_BLINK_WPS_STOP)
+			SwLedOff(padapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (!pLed->bLedOn)
+					SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+
+				if (!pLed->bLedOn)
+					SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+
+
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS success */
+		if (pLed->BlinkingLedState == RTW_LED_ON) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+			bStopBlinking = _FALSE;
+		} else
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				SwLedOn(padapter, pLed);
+			}
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		break;
+
+
+	default:
+		break;
+	}
+
+}
+
+
+void
+SwLedBlink4(
+	PLED_USB			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	PLED_USB		pLed1 = &(ledpriv->SwLed1);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	if (!pLed1->bLedWPSBlinkInProgress && pLed1->BlinkingLedState == LED_UNKNOWN) {
+		pLed1->BlinkingLedState = RTW_LED_OFF;
+		pLed1->CurrLedState = RTW_LED_OFF;
+		SwLedOff(padapter, pLed1);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SLOWLY:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_StartToBlink:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _FALSE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS authentication fail */
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		break;
+
+	case LED_BLINK_WPS_STOP_OVERLAP:	/* WPS session overlap */
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0) {
+			if (pLed->bLedOn)
+				pLed->BlinkTimes = 1;
+			else
+				bStopBlinking = _TRUE;
+		}
+
+		if (bStopBlinking) {
+			pLed->BlinkTimes = 10;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+		} else {
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_ALWAYS_ON:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				SwLedOff(padapter, pLed);
+			} else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+
+
+
+}
+
+void
+SwLedBlink5(
+	PLED_USB			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+			} else {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (!pLed->bLedOn)
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+			} else {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (!pLed->bLedOn)
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+
+
+
+}
+
+void
+SwLedBlink6(
+	PLED_USB			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+}
+
+void
+SwLedBlink7(
+	PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		if (pLed->CurrLedState != LED_BLINK_WPS_STOP)
+			SwLedOff(Adapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
+				SwLedOff(Adapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (!pLed->bLedOn)
+					SwLedOn(Adapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(Adapter, pLed);
+
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS success */
+		if (pLed->BlinkingLedState == RTW_LED_ON) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+			bStopBlinking = _FALSE;
+		} else
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
+				SwLedOff(Adapter, pLed);
+			else {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				SwLedOn(Adapter, pLed);
+			}
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		break;
+
+
+	default:
+		break;
+	}
+
+
+}
+
+void
+SwLedBlink8(
+	PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		SwLedOff(Adapter, pLed);
+	}
+
+
+}
+
+/* page added for Belkin AC950. 20120813 */
+void
+SwLedBlink9(
+	PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		SwLedOff(Adapter, pLed);
+	}
+	/* RTW_INFO("%s, pLed->CurrLedState=%d, pLed->BlinkingLedState=%d\n", __FUNCTION__, pLed->CurrLedState, pLed->BlinkingLedState); */
+
+
+	switch (pLed->CurrLedState) {
+	case RTW_LED_ON:
+		SwLedOn(Adapter, pLed);
+		break;
+
+	case RTW_LED_OFF:
+		SwLedOff(Adapter, pLed);
+		break;
+
+	case LED_BLINK_SLOWLY:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_StartToBlink:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
+				SwLedOff(Adapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->bLedLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->BlinkTimes = 0;
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS authentication fail */
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		break;
+
+	case LED_BLINK_WPS_STOP_OVERLAP:	/* WPS session overlap		 */
+		pLed->BlinkTimes--;
+		pLed->BlinkCounter--;
+		if (pLed->BlinkCounter == 0) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			pLed->CurrLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		} else {
+			if (pLed->BlinkTimes == 0) {
+				if (pLed->bLedOn)
+					pLed->BlinkTimes = 1;
+				else
+					bStopBlinking = _TRUE;
+			}
+
+			if (bStopBlinking) {
+				pLed->BlinkTimes = 10;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+			} else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_BLINK_ALWAYS_ON:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (IS_HARDWARE_TYPE_8812AU(Adapter)) {
+					pLed->BlinkingLedState = RTW_LED_ON;
+					pLed->CurrLedState = LED_BLINK_ALWAYS_ON;
+				} else {
+					pLed->bLedNoLinkBlinkInProgress = _TRUE;
+					pLed->CurrLedState = LED_BLINK_SLOWLY;
+					if (pLed->bLedOn)
+						pLed->BlinkingLedState = RTW_LED_OFF;
+					else
+						pLed->BlinkingLedState = RTW_LED_ON;
+				}
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				SwLedOff(Adapter, pLed);
+			} else {
+				if (IS_HARDWARE_TYPE_8812AU(Adapter))
+					pLed->BlinkingLedState = RTW_LED_ON;
+				else {
+					if (pLed->bLedOn)
+						pLed->BlinkingLedState = RTW_LED_OFF;
+					else
+						pLed->BlinkingLedState = RTW_LED_ON;
+				}
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_LINK_IN_PROCESS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ON_BELKIN);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_OFF_BELKIN);
+		}
+		break;
+
+	case LED_BLINK_AUTH_ERROR:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking == _FALSE) {
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_ERROR_INTERVAL_BELKIN);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_ERROR_INTERVAL_BELKIN);
+			}
+		} else {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_ERROR_INTERVAL_BELKIN);
+		}
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+/* page added for Netgear A6200V2. 20120827 */
+void
+SwLedBlink10(
+	PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		SwLedOff(Adapter, pLed);
+	}
+
+
+	switch (pLed->CurrLedState) {
+	case RTW_LED_ON:
+		SwLedOn(Adapter, pLed);
+		break;
+
+	case RTW_LED_OFF:
+		SwLedOff(Adapter, pLed);
+		break;
+
+	case LED_BLINK_SLOWLY:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_StartToBlink:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
+				SwLedOff(Adapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->BlinkTimes = 0;
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (pLed->bLedOn) {
+					pLed->BlinkingLedState = RTW_LED_OFF;
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+				} else {
+					pLed->BlinkingLedState = RTW_LED_ON;
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_SLOWLY_INTERVAL_NETGEAR + LED_BLINK_LINK_INTERVAL_NETGEAR);
+				}
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL + LED_BLINK_LINK_INTERVAL_NETGEAR);
+		}
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS authentication fail */
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		break;
+
+	case LED_BLINK_WPS_STOP_OVERLAP:	/* WPS session overlap */
+		pLed->BlinkTimes--;
+		pLed->BlinkCounter--;
+		if (pLed->BlinkCounter == 0) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			pLed->CurrLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		} else {
+			if (pLed->BlinkTimes == 0) {
+				if (pLed->bLedOn)
+					pLed->BlinkTimes = 1;
+				else
+					bStopBlinking = _TRUE;
+			}
+
+			if (bStopBlinking) {
+				pLed->BlinkTimes = 10;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+			} else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_BLINK_ALWAYS_ON:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (IS_HARDWARE_TYPE_8812AU(Adapter)) {
+					pLed->BlinkingLedState = RTW_LED_ON;
+					pLed->CurrLedState = LED_BLINK_ALWAYS_ON;
+				} else {
+					pLed->bLedNoLinkBlinkInProgress = _TRUE;
+					pLed->CurrLedState = LED_BLINK_SLOWLY;
+					if (pLed->bLedOn)
+						pLed->BlinkingLedState = RTW_LED_OFF;
+					else
+						pLed->BlinkingLedState = RTW_LED_ON;
+				}
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				SwLedOff(Adapter, pLed);
+			} else {
+				if (IS_HARDWARE_TYPE_8812AU(Adapter))
+					pLed->BlinkingLedState = RTW_LED_ON;
+				else {
+					if (pLed->bLedOn)
+						pLed->BlinkingLedState = RTW_LED_OFF;
+					else
+						pLed->BlinkingLedState = RTW_LED_ON;
+				}
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_LINK_IN_PROCESS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ON_BELKIN);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_OFF_BELKIN);
+		}
+		break;
+
+	case LED_BLINK_AUTH_ERROR:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking == _FALSE) {
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_ERROR_INTERVAL_BELKIN);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_ERROR_INTERVAL_BELKIN);
+			}
+		} else {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_ERROR_INTERVAL_BELKIN);
+		}
+		break;
+
+	default:
+		break;
+	}
+
+
+}
+
+void
+SwLedBlink11(
+	PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		SwLedOff(Adapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_TXRX:
+		if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+			SwLedOff(Adapter, pLed);
+		else {
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->BlinkTimes == 5) {
+			SwLedOn(Adapter, pLed);
+			_set_timer(&(pLed->BlinkTimer), LED_CM11_LINK_ON_INTERVEL);
+		} else {
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_CM11_BLINK_INTERVAL);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_CM11_BLINK_INTERVAL);
+			}
+		}
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking == _TRUE)
+			pLed->BlinkTimes = 5;
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS authentication fail */
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		} else {
+			pLed->CurrLedState = RTW_LED_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			SwLedOn(Adapter, pLed);
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+SwLedBlink12(
+	PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		SwLedOff(Adapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SLOWLY:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(Adapter, pLed);
+			} else {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+
+
+
+}
+
+VOID
+SwLedBlink13(
+	IN PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+	static u8	LinkBlinkCnt = 0;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		if (pLed->CurrLedState != LED_BLINK_WPS_STOP)
+			SwLedOff(Adapter, pLed);
+	}
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_LINK_IN_PROCESS:
+		if (!pLed->bLedWPSBlinkInProgress)
+			LinkBlinkCnt++;
+
+		if (LinkBlinkCnt > 15) {
+			LinkBlinkCnt = 0;
+			pLed->bLedBlinkInProgress = _FALSE;
+			break;
+		}
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 500);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 500);
+		}
+
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_ON_INTERVAL_NETGEAR);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_OFF_INTERVAL_NETGEAR);
+		}
+
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS success */
+		SwLedOff(Adapter, pLed);
+		pLed->bLedWPSBlinkInProgress = _FALSE;
+		break;
+
+	default:
+		LinkBlinkCnt = 0;
+		break;
+	}
+
+
+}
+
+VOID
+SwLedBlink14(
+	IN PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+	static u8	LinkBlinkCnt = 0;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		if (pLed->CurrLedState != LED_BLINK_WPS_STOP)
+			SwLedOff(Adapter, pLed);
+	}
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else
+				SwLedOn(Adapter, pLed);
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (pLed->bLedOn) {
+					pLed->BlinkingLedState = RTW_LED_OFF;
+					if (IS_HARDWARE_TYPE_8812AU(Adapter))
+						_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+					else
+						_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+				} else {
+					pLed->BlinkingLedState = RTW_LED_ON;
+					if (IS_HARDWARE_TYPE_8812AU(Adapter))
+						_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+					else
+						_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+				}
+			}
+		}
+
+		break;
+
+	default:
+		LinkBlinkCnt = 0;
+		break;
+	}
+
+}
+
+VOID
+SwLedBlink15(
+	IN PLED_USB			pLed
+)
+{
+	PADAPTER Adapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
+	BOOLEAN bStopBlinking = _FALSE;
+	static u8	LinkBlinkCnt = 0;
+	/* Change LED according to BlinkingLedState specified. */
+
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(Adapter, pLed);
+	} else {
+		if (pLed->CurrLedState != LED_BLINK_WPS_STOP)
+			SwLedOff(Adapter, pLed);
+	}
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_ON_INTERVAL_DLINK);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_OFF_INTERVAL_DLINK);
+		}
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS success */
+
+		if (pLed->BlinkingLedState == RTW_LED_OFF) {
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+			return;
+		}
+
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_LINKED_ON_INTERVAL_DLINK);
+		break;
+
+	case LED_BLINK_NO_LINK: {
+		static BOOLEAN		bLedOn = _TRUE;
+		if (bLedOn) {
+			bLedOn = _FALSE;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		} else {
+			bLedOn = _TRUE;
+			pLed->BlinkingLedState = RTW_LED_ON;
+		}
+		pLed->bLedBlinkInProgress = _TRUE;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL);
+	}
+	break;
+
+	case LED_BLINK_LINK_IDEL: {
+		static BOOLEAN		bLedOn = _TRUE;
+		if (bLedOn) {
+			bLedOn = _FALSE;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		} else {
+			bLedOn = _TRUE;
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+		}
+		pLed->bLedBlinkInProgress = _TRUE;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_IDEL_INTERVAL);
+	}
+	break;
+
+	case LED_BLINK_SCAN: {
+		static u8	BlinkTime = 0;
+		if (BlinkTime % 2 == 0)
+			pLed->BlinkingLedState = RTW_LED_ON;
+		else
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		BlinkTime++;
+
+		if (BlinkTime < 24) {
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			if (pLed->BlinkingLedState == RTW_LED_ON)
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_OFF_INTERVAL);
+			else
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_ON_INTERVAL);
+		} else {
+			/* if(pLed->OLDLedState ==LED_NO_LINK_BLINK) */
+			if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = LED_BLINK_NO_LINK;
+				pLed->BlinkingLedState = RTW_LED_ON;
+
+				_set_timer(&(pLed->BlinkTimer), 100);
+			}
+			BlinkTime = 0;
+		}
+	}
+	break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else
+				SwLedOn(Adapter, pLed);
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(Adapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		LinkBlinkCnt = 0;
+		break;
+	}
+
+}
+
+/*
+ *	Description:
+ *		Handler function of LED Blinking.
+ *		We dispatch acture LED blink action according to LedStrategy.
+ *   */
+void BlinkHandler(PLED_USB pLed)
+{
+	_adapter		*padapter = pLed->padapter;
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+
+	/* RTW_INFO("%s (%s:%d)\n",__FUNCTION__, current->comm, current->pid); */
+
+	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
+		/*RTW_INFO("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
+		, __func__
+		, rtw_is_drv_stopped(padapter)?"True":"False"
+		, rtw_is_surprise_removed(padapter)?"True":"False" );*/
+		return;
+	}
+
+	switch (ledpriv->LedStrategy) {
+	#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	case SW_LED_MODE_UC_TRX_ONLY:
+		rtw_sw_led_blink_uc_trx_only(pLed);
+		break;
+	#endif
+
+	case SW_LED_MODE0:
+		SwLedBlink(pLed);
+		break;
+
+	case SW_LED_MODE1:
+		SwLedBlink1(pLed);
+		break;
+
+	case SW_LED_MODE2:
+		SwLedBlink2(pLed);
+		break;
+
+	case SW_LED_MODE3:
+		SwLedBlink3(pLed);
+		break;
+
+	case SW_LED_MODE4:
+		SwLedBlink4(pLed);
+		break;
+
+	case SW_LED_MODE5:
+		SwLedBlink5(pLed);
+		break;
+
+	case SW_LED_MODE6:
+		SwLedBlink6(pLed);
+		break;
+
+	case SW_LED_MODE7:
+		SwLedBlink7(pLed);
+		break;
+
+	case SW_LED_MODE8:
+		SwLedBlink8(pLed);
+		break;
+
+	case SW_LED_MODE9:
+		SwLedBlink9(pLed);
+		break;
+
+	case SW_LED_MODE10:
+		SwLedBlink10(pLed);
+		break;
+
+	case SW_LED_MODE11:
+		SwLedBlink11(pLed);
+		break;
+
+	case SW_LED_MODE12:
+		SwLedBlink12(pLed);
+		break;
+
+	case SW_LED_MODE13:
+		SwLedBlink13(pLed);
+		break;
+
+	case SW_LED_MODE14:
+		SwLedBlink14(pLed);
+		break;
+
+	case SW_LED_MODE15:
+		SwLedBlink15(pLed);
+		break;
+
+	default:
+		/* SwLedBlink(pLed); */
+		break;
+	}
+}
+
+/*
+ *	Description:
+ *		Callback function of LED BlinkTimer,
+ *		it just schedules to corresponding BlinkWorkItem/led_blink_hdl
+ *   */
+void BlinkTimerCallback(void *data)
+{
+	PLED_USB	 pLed = (PLED_USB)data;
+	_adapter		*padapter = pLed->padapter;
+
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
+		/*RTW_INFO("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
+			, __func__
+			, rtw_is_drv_stopped(padapter)?"True":"False"
+			, rtw_is_surprise_removed(padapter)?"True":"False" );*/
+		return;
+	}
+
+#ifdef CONFIG_RTW_LED_HANDLED_BY_CMD_THREAD
+	rtw_led_blink_cmd(padapter, (PVOID)pLed);
+#else
+	_set_workitem(&(pLed->BlinkWorkItem));
+#endif
+}
+
+/*
+ *	Description:
+ *		Callback function of LED BlinkWorkItem.
+ *		We dispatch acture LED blink action according to LedStrategy.
+ *   */
+void BlinkWorkItemCallback(_workitem *work)
+{
+	PLED_USB	 pLed = container_of(work, LED_USB, BlinkWorkItem);
+	BlinkHandler(pLed);
+}
+
+static void
+SwLedControlMode0(
+	_adapter		*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	PLED_USB	pLed = &(ledpriv->SwLed1);
+
+	/* Decide led state */
+	switch (LedAction) {
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_NORMAL;
+			pLed->BlinkTimes = 2;
+
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_CTL_START_TO_LINK:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_StartToBlink;
+			pLed->BlinkTimes = 24;
+
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else
+			pLed->CurrLedState = LED_BLINK_StartToBlink;
+		break;
+
+	case LED_CTL_LINK:
+		pLed->CurrLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_NO_LINK:
+		pLed->CurrLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		SwLedOff(padapter, pLed);
+		break;
+
+	case LED_CTL_START_WPS:
+		if (pLed->bLedBlinkInProgress == _FALSE || pLed->CurrLedState == RTW_LED_ON) {
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_WPS;
+			pLed->BlinkTimes = 20;
+
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedBlinkInProgress) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		break;
+
+
+	default:
+		break;
+	}
+
+
+}
+
+/* ALPHA, added by chiyoko, 20090106 */
+static void
+SwLedControlMode1(
+	_adapter		*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv		*ledpriv = adapter_to_led(padapter);
+	PLED_USB			pLed = &(ledpriv->SwLed0);
+	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
+	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);
+
+	u32 uLedBlinkNoLinkInterval = LED_BLINK_NO_LINK_INTERVAL_ALPHA; /* add by ylb 20121012 for customer led for alpha */
+	if (pHalData->CustomerID == RT_CID_819x_ALPHA_Dlink)
+		uLedBlinkNoLinkInterval = LED_BLINK_NO_LINK_INTERVAL_ALPHA_500MS;
+
+	if (pHalData->CustomerID == RT_CID_819x_CAMEO)
+		pLed = &(ledpriv->SwLed1);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		if (pLed->bLedNoLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedNoLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SLOWLY;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), uLedBlinkNoLinkInterval);/* change by ylb 20121012 for customer led for alpha */
+		}
+		break;
+
+	case LED_CTL_LINK:
+		if (pLed->bLedLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_NORMAL;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if ((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE))
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason == RF_CHANGE_BY_IPS)
+				_set_timer(&(pLed->BlinkTimer), LED_INITIAL_INTERVAL);
+			else
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress)
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+		else
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), uLedBlinkNoLinkInterval);/* change by ylb 20121012 for customer led for alpha */
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedNoLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* Arcadyan/Sitecom , added by chiyoko, 20090216 */
+static void
+SwLedControlMode2(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_USB		pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_SITE_SURVEY:
+		if (pmlmepriv->LinkDetectInfo.bBusyTraffic)
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if ((pLed->bLedBlinkInProgress == _FALSE) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_LINK:
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = RTW_LED_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		pLed->bLedWPSBlinkInProgress = _FALSE;
+		if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		} else {
+			pLed->CurrLedState = RTW_LED_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:
+		pLed->bLedWPSBlinkInProgress = _FALSE;
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		if (!IS_LED_BLINKING(pLed)) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* COREGA, added by chiyoko, 20090316 */
+static void
+SwLedControlMode3(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_USB		pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_SITE_SURVEY:
+		if (pmlmepriv->LinkDetectInfo.bBusyTraffic)
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if ((pLed->bLedBlinkInProgress == _FALSE) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_LINK:
+		if (IS_LED_WPS_BLINKING(pLed))
+			return;
+
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		} else
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		if (!IS_LED_BLINKING(pLed)) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+
+/* Edimax-Belkin, added by chiyoko, 20090413 */
+static void
+SwLedControlMode4(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_USB		pLed = &(ledpriv->SwLed0);
+	PLED_USB		pLed1 = &(ledpriv->SwLed1);
+
+	switch (LedAction) {
+	case LED_CTL_START_TO_LINK:
+		if (pLed1->bLedWPSBlinkInProgress) {
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+			pLed1->CurrLedState = RTW_LED_OFF;
+
+			if (pLed1->bLedOn)
+				_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		if (pLed->bLedStartToLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedStartToLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_StartToBlink;
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_CTL_LINK:
+	case LED_CTL_NO_LINK:
+		/* LED1 settings */
+		if (LedAction == LED_CTL_LINK) {
+			if (pLed1->bLedWPSBlinkInProgress) {
+				pLed1->bLedWPSBlinkInProgress = _FALSE;
+				_cancel_timer_ex(&(pLed1->BlinkTimer));
+
+				pLed1->BlinkingLedState = RTW_LED_OFF;
+				pLed1->CurrLedState = RTW_LED_OFF;
+
+				if (pLed1->bLedOn)
+					_set_timer(&(pLed->BlinkTimer), 0);
+			}
+		}
+
+		if (pLed->bLedNoLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedNoLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SLOWLY;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if ((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE))
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed1->bLedWPSBlinkInProgress) {
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+			pLed1->CurrLedState = RTW_LED_OFF;
+
+			if (pLed1->bLedOn)
+				_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:	/* WPS connect success */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:		/* WPS authentication fail */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+
+		/* LED1 settings */
+		if (pLed1->bLedWPSBlinkInProgress)
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+		else
+			pLed1->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed1->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed1->bLedOn)
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed1->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL_OVERLAP:	/* WPS session overlap */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+
+		/* LED1 settings */
+		if (pLed1->bLedWPSBlinkInProgress)
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+		else
+			pLed1->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed1->CurrLedState = LED_BLINK_WPS_STOP_OVERLAP;
+		pLed1->BlinkTimes = 10;
+		if (pLed1->bLedOn)
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed1->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		if (pLed->bLedNoLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedStartToLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedStartToLinkBlinkInProgress = _FALSE;
+		}
+
+		if (pLed1->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed1->BlinkingLedState = LED_UNKNOWN;
+		SwLedOff(padapter, pLed);
+		SwLedOff(padapter, pLed1);
+		break;
+
+	case LED_CTL_CONNECTION_NO_TRANSFER:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_ALWAYS_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+
+
+/* Sercomm-Belkin, added by chiyoko, 20090415 */
+static void
+SwLedControlMode5(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	PLED_USB		pLed = &(ledpriv->SwLed0);
+
+	if (pHalData->CustomerID == RT_CID_819x_CAMEO)
+		pLed = &(ledpriv->SwLed1);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_NO_LINK:
+	case LED_CTL_LINK:	/* solid blue */
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if ((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE))
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN)
+				return;
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* WNC-Corega, added by chiyoko, 20090902 */
+static void
+SwLedControlMode6(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_USB	pLed0 = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_LINK:
+	case LED_CTL_NO_LINK:
+		_cancel_timer_ex(&(pLed0->BlinkTimer));
+		pLed0->CurrLedState = RTW_LED_ON;
+		pLed0->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed0->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_POWER_OFF:
+		SwLedOff(padapter, pLed0);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+/* Netgear, added by sinda, 2011/11/11 */
+void
+SwLedControlMode7(
+	PADAPTER			 Adapter,
+	LED_CTL_MODE		 LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_SITE_SURVEY:
+		if (pmlmepriv->LinkDetectInfo.bBusyTraffic)
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 6;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+		}
+		break;
+
+	case LED_CTL_LINK:
+		if (IS_LED_WPS_BLINKING(pLed))
+			return;
+
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		} else
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_NETGEAR);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		break;
+
+
+	case LED_CTL_STOP_WPS_FAIL:
+	case LED_CTL_STOP_WPS_FAIL_OVERLAP:	/* WPS session overlap			 */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		if (!IS_LED_BLINKING(pLed)) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+	case LED_CTL_POWER_ON:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+void
+SwLedControlMode8(
+	PADAPTER			Adapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed0 = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_LINK:
+		_cancel_timer_ex(&(pLed0->BlinkTimer));
+		pLed0->CurrLedState = RTW_LED_ON;
+		pLed0->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed0->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_NO_LINK:
+		_cancel_timer_ex(&(pLed0->BlinkTimer));
+		pLed0->CurrLedState = RTW_LED_OFF;
+		pLed0->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed0->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_POWER_OFF:
+		SwLedOff(Adapter, pLed0);
+		break;
+
+	default:
+		break;
+	}
+
+
+}
+
+/* page added for Belkin AC950, 20120813 */
+void
+SwLedControlMode9(
+	IN	PADAPTER			Adapter,
+	IN	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+	PLED_USB	pLed1 = &(ledpriv->SwLed1);
+	PLED_USB	pLed2 = &(ledpriv->SwLed2);
+	BOOLEAN  bWPSOverLap = _FALSE;
+	/* RTW_INFO("LedAction=%d\n", LedAction); */
+	switch (LedAction) {
+	case LED_CTL_START_TO_LINK:
+		if (pLed2->bLedBlinkInProgress == _FALSE) {
+			pLed2->bLedBlinkInProgress = _TRUE;
+			pLed2->BlinkingLedState = RTW_LED_ON;
+			pLed2->CurrLedState = LED_BLINK_LINK_IN_PROCESS;
+
+			_set_timer(&(pLed2->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_LINK:
+	case LED_CTL_NO_LINK:
+		/* LED1 settings */
+		if (LedAction == LED_CTL_NO_LINK) {
+			/* if(pMgntInfo->AuthStatus == AUTH_STATUS_FAILED) */
+			if (0) {
+				pLed1->CurrLedState = LED_BLINK_AUTH_ERROR;
+				if (pLed1->bLedOn)
+					pLed1->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed1->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed1->BlinkTimer), 0);
+			} else {
+				pLed1->CurrLedState = RTW_LED_OFF;
+				pLed1->BlinkingLedState = RTW_LED_OFF;
+				if (pLed1->bLedOn)
+					_set_timer(&(pLed1->BlinkTimer), 0);
+			}
+		} else {
+			pLed1->CurrLedState = RTW_LED_OFF;
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+			if (pLed1->bLedOn)
+				_set_timer(&(pLed1->BlinkTimer), 0);
+		}
+
+		/* LED2 settings */
+		if (LedAction == LED_CTL_LINK) {
+			if (Adapter->securitypriv.dot11PrivacyAlgrthm != _NO_PRIVACY_) {
+				if (pLed2->bLedBlinkInProgress == _TRUE) {
+					_cancel_timer_ex(&(pLed2->BlinkTimer));
+					pLed2->bLedBlinkInProgress = _FALSE;
+				}
+				pLed2->CurrLedState = RTW_LED_ON;
+				pLed2->bLedNoLinkBlinkInProgress = _TRUE;
+				if (!pLed2->bLedOn)
+					_set_timer(&(pLed2->BlinkTimer), 0);
+			} else {
+				if (pLed2->bLedWPSBlinkInProgress != _TRUE) {
+					pLed2->CurrLedState = RTW_LED_OFF;
+					pLed2->BlinkingLedState = RTW_LED_OFF;
+					if (pLed2->bLedOn)
+						_set_timer(&(pLed2->BlinkTimer), 0);
+				}
+			}
+		} else { /* NO_LINK */
+			if (pLed2->bLedWPSBlinkInProgress == _FALSE) {
+				pLed2->CurrLedState = RTW_LED_OFF;
+				pLed2->BlinkingLedState = RTW_LED_OFF;
+				if (pLed2->bLedOn)
+					_set_timer(&(pLed2->BlinkTimer), 0);
+			}
+		}
+
+		/* LED0 settings			 */
+		if (pLed->bLedNoLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedNoLinkBlinkInProgress = _TRUE;
+			if (IS_HARDWARE_TYPE_8812AU(Adapter)) {
+				if (LedAction == LED_CTL_LINK) {
+					pLed->BlinkingLedState = RTW_LED_ON;
+					pLed->CurrLedState = LED_BLINK_SLOWLY;
+				} else {
+					pLed->CurrLedState = LED_BLINK_SLOWLY;
+					if (pLed->bLedOn)
+						pLed->BlinkingLedState = RTW_LED_OFF;
+					else
+						pLed->BlinkingLedState = RTW_LED_ON;
+				}
+			} else {
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+			}
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		}
+
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if ((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE))
+			;
+		else { /* if(pLed->bLedScanBlinkInProgress ==FALSE) */
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		pLed2->bLedBlinkInProgress = _TRUE;
+		pLed2->BlinkingLedState = RTW_LED_ON;
+		pLed2->CurrLedState = LED_BLINK_LINK_IN_PROCESS;
+		pLed2->bLedWPSBlinkInProgress = _TRUE;
+
+		_set_timer(&(pLed2->BlinkTimer), 500);
+
+		break;
+
+	case LED_CTL_STOP_WPS:	/* WPS connect success	 */
+		/* LED2 settings */
+		if (pLed2->bLedWPSBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed2->BlinkTimer));
+			pLed2->bLedBlinkInProgress = _FALSE;
+			pLed2->bLedWPSBlinkInProgress = _FALSE;
+		}
+		pLed2->CurrLedState = RTW_LED_ON;
+		pLed2->bLedNoLinkBlinkInProgress = _TRUE;
+		if (!pLed2->bLedOn)
+			_set_timer(&(pLed2->BlinkTimer), 0);
+
+		/* LED1 settings */
+		_cancel_timer_ex(&(pLed1->BlinkTimer));
+		pLed1->CurrLedState = RTW_LED_OFF;
+		pLed1->BlinkingLedState = RTW_LED_OFF;
+		if (pLed1->bLedOn)
+			_set_timer(&(pLed1->BlinkTimer), 0);
+
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:		/* WPS authentication fail	 */
+		/* LED1 settings */
+		/* if(bWPSOverLap == _FALSE) */
+	{
+		pLed1->CurrLedState = LED_BLINK_AUTH_ERROR;
+		pLed1->BlinkTimes = 50;
+		if (pLed1->bLedOn)
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed1->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed1->BlinkTimer), 0);
+	}
+		/* else */
+		/* { */
+		/*	bWPSOverLap = _FALSE; */
+		/*	pLed1->CurrLedState = RTW_LED_OFF; */
+		/*	pLed1->BlinkingLedState = RTW_LED_OFF;  */
+		/*	_set_timer(&(pLed1->BlinkTimer), 0); */
+		/* } */
+
+		/* LED2 settings */
+	pLed2->CurrLedState = RTW_LED_OFF;
+	pLed2->BlinkingLedState = RTW_LED_OFF;
+	pLed2->bLedWPSBlinkInProgress = _FALSE;
+	if (pLed2->bLedOn)
+		_set_timer(&(pLed2->BlinkTimer), 0);
+
+	break;
+
+	case LED_CTL_STOP_WPS_FAIL_OVERLAP:	/* WPS session overlap */
+		/* LED1 settings */
+		bWPSOverLap = _TRUE;
+		pLed1->CurrLedState = LED_BLINK_WPS_STOP_OVERLAP;
+		pLed1->BlinkTimes = 10;
+		pLed1->BlinkCounter = 50;
+		if (pLed1->bLedOn)
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed1->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed1->BlinkTimer), 0);
+
+		/* LED2 settings */
+		pLed2->CurrLedState = RTW_LED_OFF;
+		pLed2->BlinkingLedState = RTW_LED_OFF;
+		pLed2->bLedWPSBlinkInProgress = _FALSE;
+		if (pLed2->bLedOn)
+			_set_timer(&(pLed2->BlinkTimer), 0);
+
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		if (pLed->bLedNoLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedStartToLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedStartToLinkBlinkInProgress = _FALSE;
+		}
+
+		if (pLed1->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+
+		pLed1->BlinkingLedState = LED_UNKNOWN;
+		SwLedOff(Adapter, pLed);
+		SwLedOff(Adapter, pLed1);
+		break;
+
+	case LED_CTL_CONNECTION_NO_TRANSFER:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_ALWAYS_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* page added for Netgear A6200V2, 20120827 */
+void
+SwLedControlMode10(
+	PADAPTER			Adapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+	PLED_USB	pLed1 = &(ledpriv->SwLed1);
+
+	switch (LedAction) {
+	case LED_CTL_START_TO_LINK:
+		if (pLed1->bLedBlinkInProgress == _FALSE) {
+			pLed1->bLedBlinkInProgress = _TRUE;
+			pLed1->BlinkingLedState = RTW_LED_ON;
+			pLed1->CurrLedState = LED_BLINK_LINK_IN_PROCESS;
+
+			_set_timer(&(pLed1->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_LINK:
+	case LED_CTL_NO_LINK:
+		if (LedAction == LED_CTL_LINK) {
+			if (pLed->bLedWPSBlinkInProgress == _TRUE || pLed1->bLedWPSBlinkInProgress == _TRUE)
+				;
+			else {
+				if (pHalData->current_band_type == BAND_ON_2_4G)
+					/* LED0 settings */
+				{
+					pLed->CurrLedState = RTW_LED_ON;
+					pLed->BlinkingLedState = RTW_LED_ON;
+					if (pLed->bLedBlinkInProgress == _TRUE) {
+						_cancel_timer_ex(&(pLed->BlinkTimer));
+						pLed->bLedBlinkInProgress = _FALSE;
+					}
+					_set_timer(&(pLed->BlinkTimer), 0);
+
+					pLed1->CurrLedState = RTW_LED_OFF;
+					pLed1->BlinkingLedState = RTW_LED_OFF;
+					_set_timer(&(pLed1->BlinkTimer), 0);
+				} else if (pHalData->current_band_type == BAND_ON_5G)
+					/* LED1 settings */
+				{
+					pLed1->CurrLedState = RTW_LED_ON;
+					pLed1->BlinkingLedState = RTW_LED_ON;
+					if (pLed1->bLedBlinkInProgress == _TRUE) {
+						_cancel_timer_ex(&(pLed1->BlinkTimer));
+						pLed1->bLedBlinkInProgress = _FALSE;
+					}
+					_set_timer(&(pLed1->BlinkTimer), 0);
+
+					pLed->CurrLedState = RTW_LED_OFF;
+					pLed->BlinkingLedState = RTW_LED_OFF;
+					_set_timer(&(pLed->BlinkTimer), 0);
+				}
+			}
+		} else if (LedAction == LED_CTL_NO_LINK) { /* TODO by page */
+			if (pLed->bLedWPSBlinkInProgress == _TRUE || pLed1->bLedWPSBlinkInProgress == _TRUE)
+				;
+			else {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					_set_timer(&(pLed->BlinkTimer), 0);
+
+				pLed1->CurrLedState = RTW_LED_OFF;
+				pLed1->BlinkingLedState = RTW_LED_OFF;
+				if (pLed1->bLedOn)
+					_set_timer(&(pLed1->BlinkTimer), 0);
+			}
+		}
+
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+			;                                                                  /* don't blink when media connect */
+		else { /* if(pLed->bLedScanBlinkInProgress ==FALSE) */
+			if (IS_LED_WPS_BLINKING(pLed) || IS_LED_WPS_BLINKING(pLed1))
+				return;
+
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 12;
+			pLed->BlinkingLedState = LED_BLINK_SCAN;
+			_set_timer(&(pLed->BlinkTimer), 0);
+
+			if (pLed1->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed1->BlinkTimer));
+				pLed1->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed1->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed1->BlinkTimer));
+				pLed1->bLedBlinkInProgress = _FALSE;
+			}
+			pLed1->bLedScanBlinkInProgress = _TRUE;
+			pLed1->CurrLedState = LED_BLINK_SCAN;
+			pLed1->BlinkTimes = 12;
+			pLed1->BlinkingLedState = LED_BLINK_SCAN;
+			_set_timer(&(pLed1->BlinkTimer), LED_BLINK_LINK_SLOWLY_INTERVAL_NETGEAR);
+
+		}
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		/* LED0 settings */
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->BlinkingLedState = LED_BLINK_WPS;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		/* LED1 settings */
+		if (pLed1->bLedBlinkInProgress == _FALSE) {
+			pLed1->bLedBlinkInProgress = _TRUE;
+			pLed1->bLedWPSBlinkInProgress = _TRUE;
+			pLed1->BlinkingLedState = LED_BLINK_WPS;
+			pLed1->CurrLedState = LED_BLINK_WPS;
+			_set_timer(&(pLed1->BlinkTimer), LED_BLINK_NORMAL_INTERVAL + LED_BLINK_LINK_INTERVAL_NETGEAR);
+		}
+
+
+		break;
+
+	case LED_CTL_STOP_WPS:	/* WPS connect success */
+		if (pHalData->current_band_type == BAND_ON_2_4G)
+			/* LED0 settings */
+		{
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+			pLed->CurrLedState = RTW_LED_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			_set_timer(&(pLed->BlinkTimer), 0);
+
+			pLed1->CurrLedState = RTW_LED_OFF;
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed1->BlinkTimer), 0);
+		} else if (pHalData->current_band_type == BAND_ON_5G)
+			/* LED1 settings */
+		{
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+			pLed1->CurrLedState = RTW_LED_ON;
+			pLed1->BlinkingLedState = RTW_LED_ON;
+			if (pLed1->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed1->BlinkTimer));
+				pLed1->bLedBlinkInProgress = _FALSE;
+			}
+			_set_timer(&(pLed1->BlinkTimer), 0);
+
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:		/* WPS authentication fail	 */
+		/* LED1 settings */
+		pLed1->bLedWPSBlinkInProgress = _FALSE;
+		pLed1->CurrLedState = RTW_LED_OFF;
+		pLed1->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed1->BlinkTimer), 0);
+
+		/* LED0 settings */
+		pLed->bLedWPSBlinkInProgress = _FALSE;
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedOn)
+			_set_timer(&(pLed->BlinkTimer), 0);
+
+		break;
+
+
+	default:
+		break;
+
+	}
+
+}
+
+/* Edimax-ASUS, added by Page, 20121221 */
+void
+SwLedControlMode11(
+	PADAPTER			Adapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_LINK:
+		if (pLed->bLedBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		pLed->bLedBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_TXRX;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		pLed->bLedWPSBlinkInProgress = _TRUE;
+		pLed->bLedBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_WPS;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		pLed->BlinkTimes = 5;
+		_set_timer(&(pLed->BlinkTimer), 0);
+
+		break;
+
+
+	case LED_CTL_STOP_WPS:
+	case LED_CTL_STOP_WPS_FAIL:
+		if (pLed->bLedBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		if (pLed->bLedNoLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(Adapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* page added for NEC */
+
+VOID
+SwLedControlMode12(
+	PADAPTER			Adapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_NO_LINK:
+	case LED_CTL_LINK:
+	case LED_CTL_SITE_SURVEY:
+
+		if (pLed->bLedNoLinkBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedNoLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SLOWLY;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(Adapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* Maddest add for NETGEAR R6100 */
+
+VOID
+SwLedControlMode13(
+	IN	PADAPTER			Adapter,
+	IN	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_LINK:
+		if (pLed->bLedWPSBlinkInProgress)
+			return;
+
+
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_OFF_INTERVAL_NETGEAR);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_ON_INTERVAL_NETGEAR);
+			}
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		} else
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed->bLedWPSBlinkInProgress = _FALSE;
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		break;
+
+
+	case LED_CTL_STOP_WPS_FAIL:
+	case LED_CTL_STOP_WPS_FAIL_OVERLAP: /* WPS session overlap */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_TO_LINK:
+		if ((pLed->bLedBlinkInProgress == _FALSE) && (pLed->bLedWPSBlinkInProgress == _FALSE)) {
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			pLed->CurrLedState = LED_BLINK_LINK_IN_PROCESS;
+
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_NO_LINK:
+
+		if (pLed->bLedWPSBlinkInProgress)
+			return;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		/* if(!IS_LED_BLINKING(pLed)) */
+		{
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+	case LED_CTL_POWER_ON:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		if (LedAction == LED_CTL_POWER_ON)
+			_set_timer(&(pLed->BlinkTimer), 0);
+		else
+			SwLedOff(Adapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+
+}
+
+/* Maddest add for DNI Buffalo */
+
+VOID
+SwLedControlMode14(
+	IN	PADAPTER			Adapter,
+	IN	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		SwLedOff(Adapter, pLed);
+		break;
+
+	case LED_CTL_POWER_ON:
+		SwLedOn(Adapter, pLed);
+		break;
+
+	case LED_CTL_LINK:
+	case LED_CTL_NO_LINK:
+		if (IS_HARDWARE_TYPE_8812AU(Adapter))
+			SwLedOn(Adapter, pLed);
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (IS_HARDWARE_TYPE_8812AU(Adapter))
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+				else
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (IS_HARDWARE_TYPE_8812AU(Adapter))
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+				else
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+}
+
+/* Maddest add for Dlink */
+
+VOID
+SwLedControlMode15(
+	IN	PADAPTER			Adapter,
+	IN	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(Adapter);
+	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
+	PLED_USB	pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_OFF_INTERVAL_NETGEAR);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_WPS_BLINK_ON_INTERVAL_NETGEAR);
+			}
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedWPSBlinkInProgress)
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		/* if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE) */
+		{
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:
+	case LED_CTL_STOP_WPS_FAIL_OVERLAP: /* WPS session overlap */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_NO_LINK:
+		if (pLed->bLedWPSBlinkInProgress)
+			return;
+
+		/*if(Adapter->securitypriv.dot11PrivacyAlgrthm > _NO_PRIVACY_)
+		{
+			if(SecIsTxKeyInstalled(Adapter, pMgntInfo->Bssid))
+			{
+			}
+			else
+			{
+				if(pMgntInfo->LEDAssocState ==LED_ASSOC_SECURITY_BEGIN)
+					return;
+			}
+		}*/
+
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		/* if(!IS_LED_BLINKING(pLed)) */
+		{
+			pLed->CurrLedState = LED_BLINK_NO_LINK;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 30);
+		}
+		break;
+
+	case LED_CTL_LINK:
+
+		if (pLed->bLedWPSBlinkInProgress)
+			return;
+
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+
+		pLed->CurrLedState = LED_BLINK_LINK_IDEL;
+		pLed->BlinkingLedState = RTW_LED_ON;
+
+		_set_timer(&(pLed->BlinkTimer), 30);
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+			return;
+
+		if (pLed->bLedWPSBlinkInProgress == _TRUE)
+			return;
+
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		pLed->CurrLedState = LED_BLINK_SCAN;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedWPSBlinkInProgress)
+			return;
+
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_TXRX;
+		pLed->BlinkTimes = 2;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		break;
+
+	default:
+		break;
+	}
+}
+
+void
+LedControlUSB(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+
+#if (MP_DRIVER == 1)
+	if (padapter->registrypriv.mp_mode == 1)
+		return;
+#endif
+
+	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
+		/*RTW_INFO("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
+		, __func__
+		, rtw_is_drv_stopped(padapter)?"True":"False"
+		, rtw_is_surprise_removed(padapter)?"True":"False" );*/
+		return;
+	}
+
+	if (ledpriv->bRegUseLed == _FALSE)
+		return;
+
+	/* if(priv->bInHctTest) */
+	/*	return; */
+
+	if ((adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on &&
+	     adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) &&
+	    (LedAction == LED_CTL_TX || LedAction == LED_CTL_RX ||
+	     LedAction == LED_CTL_SITE_SURVEY ||
+	     LedAction == LED_CTL_LINK ||
+	     LedAction == LED_CTL_NO_LINK ||
+	     LedAction == LED_CTL_POWER_ON))
+		return;
+
+	switch (ledpriv->LedStrategy) {
+	#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	case SW_LED_MODE_UC_TRX_ONLY:
+		rtw_sw_led_ctl_mode_uc_trx_only(padapter, LedAction);
+		break;
+	#endif
+
+	case SW_LED_MODE0:
+		SwLedControlMode0(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE1:
+		SwLedControlMode1(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE2:
+		SwLedControlMode2(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE3:
+		SwLedControlMode3(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE4:
+		SwLedControlMode4(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE5:
+		SwLedControlMode5(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE6:
+		SwLedControlMode6(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE7:
+		SwLedControlMode7(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE8:
+		SwLedControlMode8(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE9:
+		SwLedControlMode9(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE10:
+		SwLedControlMode10(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE11:
+		SwLedControlMode11(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE12:
+		SwLedControlMode12(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE13:
+		SwLedControlMode13(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE14:
+		SwLedControlMode14(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE15:
+		SwLedControlMode15(padapter, LedAction);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+/*
+ *	Description:
+ *		Reset status of LED_871x object.
+ *   */
+void ResetLedStatus(PLED_USB pLed)
+{
+
+	pLed->CurrLedState = RTW_LED_OFF; /* Current LED state. */
+	pLed->bLedOn = _FALSE; /* true if LED is ON, false if LED is OFF. */
+
+	pLed->bLedBlinkInProgress = _FALSE; /* true if it is blinking, false o.w.. */
+	pLed->bLedWPSBlinkInProgress = _FALSE;
+
+	pLed->BlinkTimes = 0; /* Number of times to toggle led state for blinking. */
+	pLed->BlinkCounter = 0;
+	pLed->BlinkingLedState = LED_UNKNOWN; /* Next state for blinking, either RTW_LED_ON or RTW_LED_OFF are. */
+
+	pLed->bLedNoLinkBlinkInProgress = _FALSE;
+	pLed->bLedLinkBlinkInProgress = _FALSE;
+	pLed->bLedStartToLinkBlinkInProgress = _FALSE;
+	pLed->bLedScanBlinkInProgress = _FALSE;
+}
+
+/*
+*	Description:
+*		Initialize an LED_871x object.
+*   */
+void
+InitLed(
+	_adapter			*padapter,
+	PLED_USB		pLed,
+	LED_PIN			LedPin
+)
+{
+	pLed->padapter = padapter;
+	pLed->LedPin = LedPin;
+
+	ResetLedStatus(pLed);
+	rtw_init_timer(&(pLed->BlinkTimer), padapter, BlinkTimerCallback, pLed);
+	_init_workitem(&(pLed->BlinkWorkItem), BlinkWorkItemCallback, pLed);
+}
+
+
+/*
+ *	Description:
+ *		DeInitialize an LED_871x object.
+ *   */
+void
+DeInitLed(
+	PLED_USB		pLed
+)
+{
+	_cancel_workitem_sync(&(pLed->BlinkWorkItem));
+	_cancel_timer_ex(&(pLed->BlinkTimer));
+	ResetLedStatus(pLed);
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/ap_makefile.mk b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/ap_makefile.mk
new file mode 100644
index 000000000000..d578c8e5aa27
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/ap_makefile.mk
@@ -0,0 +1,118 @@
+
+_PHYDM_FILES :=\
+	phydm/phydm.o \
+	phydm/phydm_dig.o\
+	phydm/phydm_antdiv.o\
+	phydm/phydm_soml.o\
+	phydm/phydm_smt_ant.o\
+	phydm/phydm_pathdiv.o\
+	phydm/phydm_rainfo.o\
+	phydm/phydm_dynamictxpower.o\
+	phydm/phydm_adaptivity.o\
+	phydm/phydm_debug.o\
+	phydm/phydm_interface.o\
+	phydm/phydm_phystatus.o\
+	phydm/phydm_hwconfig.o\
+	phydm/phydm_dfs.o\
+	phydm/phydm_cfotracking.o\
+	phydm/phydm_adc_sampling.o\
+	phydm/phydm_ccx.o\
+	phydm/phydm_primary_cca.o\
+	phydm/phydm_cck_pd.o\
+	phydm/phydm_rssi_monitor.o\
+	phydm/phydm_auto_dbg.o\
+	phydm/phydm_math_lib.o\
+	phydm/phydm_noisemonitor.o\
+	phydm/phydm_api.o\
+	phydm/phydm_pow_train.o\
+	phydm/txbf/phydm_hal_txbf_api.o\
+	EdcaTurboCheck.o\
+	phydm/halrf/halrf.o\
+	phydm/halrf/halphyrf_ap.o\
+	phydm/halrf/halrf_powertracking_ap.o\
+	phydm/halrf/halrf_powertracking.o\
+	phydm/halrf/halrf_kfree.o
+
+ifeq ($(CONFIG_RTL_88E_SUPPORT),y)
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8188e/halhwimg8188e_bb.o\
+		phydm/rtl8188e/halhwimg8188e_mac.o\
+		phydm/rtl8188e/halhwimg8188e_rf.o\
+		phydm/rtl8188e/phydm_regconfig8188e.o\
+		phydm/rtl8188e/hal8188erateadaptive.o\
+		phydm/rtl8188e/phydm_rtl8188e.o\
+		phydm/halrf/rtl8188e/halrf_8188e_ap.o
+	endif
+endif
+	
+ifeq ($(CONFIG_RTL_8812_SUPPORT),y)
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += ./phydm/halrf/rtl8812a/halrf_8812a_ap.o
+	endif
+endif
+	
+ifeq ($(CONFIG_WLAN_HAL_8881A),y)
+	_PHYDM_FILES += phydm/halrf/rtl8821a/halrf_iqk_8821a_ap.o
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8192EE),y)
+	_PHYDM_FILES += \
+	phydm/halrf/rtl8192e/halrf_8192e_ap.o\
+	phydm/rtl8192e/phydm_rtl8192e.o
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8814AE),y)
+	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_8814a_ap.o
+	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_iqk_8814a.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		rtl8192cd-objs += \
+		phydm/rtl8814a/halhwimg8814a_bb.o\
+		phydm/rtl8814a/halhwimg8814a_mac.o\
+		phydm/rtl8814a/halhwimg8814a_rf.o\
+		phydm/rtl8814a/phydm_regconfig8814a.o\
+		phydm/rtl8814a/phydm_rtl8814a.o			
+	endif
+endif
+	
+ifeq ($(CONFIG_WLAN_HAL_8822BE),y)
+	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_8822b.o
+	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_iqk_8822b.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8822b/halhwimg8822b_bb.o\
+		phydm/rtl8822b/halhwimg8822b_mac.o\
+		phydm/rtl8822b/halhwimg8822b_rf.o\
+		phydm/rtl8822b/phydm_regconfig8822b.o\
+		phydm/rtl8822b/phydm_hal_api8822b.o\
+		phydm/rtl8822b/phydm_rtl8822b.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8821CE),y)
+	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_8821c.o
+	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_iqk_8821c.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8821c/halhwimg8821c_bb.o\
+		phydm/rtl8821c/halhwimg8821c_mac.o\
+		phydm/rtl8821c/halhwimg8821c_rf.o\
+		phydm/rtl8821c/phydm_regconfig8821c.o\
+		phydm/rtl8821c/phydm_hal_api8821c.o
+	endif
+endif
+	
+ifeq ($(CONFIG_WLAN_HAL_8197F),y)
+		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_8197f.o
+		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_iqk_8197f.o
+		_PHYDM_FILES += efuse_97f/efuse.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8197f/halhwimg8197f_bb.o\
+		phydm/rtl8197f/halhwimg8197f_mac.o\
+		phydm/rtl8197f/halhwimg8197f_rf.o\
+		phydm/rtl8197f/phydm_hal_api8197f.o\
+		phydm/rtl8197f/phydm_regconfig8197f.o\
+		phydm/rtl8197f/phydm_rtl8197f.o
+	endif
+endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halhwimg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halhwimg.h
new file mode 100644
index 000000000000..e8f580220543
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halhwimg.h
@@ -0,0 +1,137 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#pragma once
+#ifndef __INC_HW_IMG_H
+#define __INC_HW_IMG_H
+
+/*
+ * 2011/03/15 MH Add for different IC HW image file selection. code size consideration.
+ *   */
+#if RT_PLATFORM == PLATFORM_LINUX
+
+	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		/* For 92C */
+		#define		RTL8192CE_HWIMG_SUPPORT					1
+		#define		RTL8192CE_TEST_HWIMG_SUPPORT			0
+		#define		RTL8192CU_HWIMG_SUPPORT					0
+		#define		RTL8192CU_TEST_HWIMG_SUPPORT			0
+
+		/* For 92D */
+		#define		RTL8192DE_HWIMG_SUPPORT					1
+		#define		RTL8192DE_TEST_HWIMG_SUPPORT			0
+		#define		RTL8192DU_HWIMG_SUPPORT					0
+		#define		RTL8192DU_TEST_HWIMG_SUPPORT			0
+
+		/* For 8723 */
+		#define		RTL8723E_HWIMG_SUPPORT					1
+		#define		RTL8723U_HWIMG_SUPPORT					0
+		#define		RTL8723S_HWIMG_SUPPORT					0
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+
+	#elif (DEV_BUS_TYPE == RT_USB_INTERFACE)
+		/* For 92C */
+		#define	RTL8192CE_HWIMG_SUPPORT				0
+		#define	RTL8192CE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192CU_HWIMG_SUPPORT				1
+		#define	RTL8192CU_TEST_HWIMG_SUPPORT			0
+
+		/* For 92D */
+		#define	RTL8192DE_HWIMG_SUPPORT				0
+		#define	RTL8192DE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192DU_HWIMG_SUPPORT				1
+		#define	RTL8192DU_TEST_HWIMG_SUPPORT			0
+
+		/* For 8723 */
+		#define	RTL8723E_HWIMG_SUPPORT					0
+		#define	RTL8723U_HWIMG_SUPPORT					1
+		#define	RTL8723S_HWIMG_SUPPORT					0
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+
+	#elif (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+		/* For 92C */
+		#define	RTL8192CE_HWIMG_SUPPORT				0
+		#define	RTL8192CE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192CU_HWIMG_SUPPORT				1
+		#define	RTL8192CU_TEST_HWIMG_SUPPORT			0
+
+		/* For 92D */
+		#define	RTL8192DE_HWIMG_SUPPORT				0
+		#define	RTL8192DE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192DU_HWIMG_SUPPORT				1
+		#define	RTL8192DU_TEST_HWIMG_SUPPORT			0
+
+		/* For 8723 */
+		#define	RTL8723E_HWIMG_SUPPORT					0
+		#define	RTL8723U_HWIMG_SUPPORT					0
+		#define	RTL8723S_HWIMG_SUPPORT					1
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+	#endif
+
+#else	/* PLATFORM_WINDOWS & MacOSX */
+
+	/* For 92C */
+	#define		RTL8192CE_HWIMG_SUPPORT						1
+	#define		RTL8192CE_TEST_HWIMG_SUPPORT				1
+	#define		RTL8192CU_HWIMG_SUPPORT						1
+	#define		RTL8192CU_TEST_HWIMG_SUPPORT				1
+
+	/* For 92D */
+	#define		RTL8192DE_HWIMG_SUPPORT					1
+	#define		RTL8192DE_TEST_HWIMG_SUPPORT				1
+	#define		RTL8192DU_HWIMG_SUPPORT					1
+	#define		RTL8192DU_TEST_HWIMG_SUPPORT				1
+
+	#if defined(UNDER_CE)
+		/* For 8723 */
+		#define		RTL8723E_HWIMG_SUPPORT					0
+		#define		RTL8723U_HWIMG_SUPPORT					0
+		#define		RTL8723S_HWIMG_SUPPORT					1
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+
+	#else
+
+		/* For 8723 */
+		#define		RTL8723E_HWIMG_SUPPORT					1
+		/* #define		RTL_8723E_TEST_HWIMG_SUPPORT			1 */
+		#define		RTL8723U_HWIMG_SUPPORT					1
+		/* #define		RTL_8723U_TEST_HWIMG_SUPPORT			1 */
+		#define		RTL8723S_HWIMG_SUPPORT					1
+		/* #define		RTL_8723S_TEST_HWIMG_SUPPORT			1 */
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					1
+		#define		RTL8188EU_HWIMG_SUPPORT					1
+		#define		RTL8188ES_HWIMG_SUPPORT					1
+	#endif
+
+#endif
+
+#endif /* __INC_HW_IMG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ap.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ap.c
new file mode 100644
index 000000000000..e6b07a16652e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ap.c
@@ -0,0 +1,1305 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifndef index_mapping_NUM_88E
+	#define	index_mapping_NUM_88E	15
+#endif
+
+/* #if(DM_ODM_SUPPORT_TYPE & ODM_WIN) */
+
+#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
+	do {\
+		for (_offset = 0; _offset < _size; _offset++) { \
+			\
+			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
+				\
+				if (_offset != 0)\
+					_offset--;\
+				break;\
+			} \
+		}			\
+		if (_offset >= _size)\
+			_offset = _size-1;\
+	} while (0)
+
+
+void configure_txpower_track(
+	void		*dm_void,
+	struct txpwrtrack_cfg	*config
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if RTL8812A_SUPPORT
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	/* if (IS_HARDWARE_TYPE_8812(dm->adapter)) */
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
+	/* else */
+#endif
+#endif
+
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
+#endif
+
+
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
+#endif
+
+#if RTL8197F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8197F)
+		configure_txpower_track_8197f(config);
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
+#endif
+
+
+}
+
+#if (RTL8192E_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8	thermal_value = 0, delta, delta_IQK, delta_LCK, channel, is_decrease, rf_mimo_mode;
+	u8	thermal_value_avg_count = 0;
+	u8     OFDM_min_index = 10; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur */
+	s8	OFDM_index[2], index ;
+	u32	thermal_value_avg = 0, reg0x18;
+	u32	i = 0, j = 0, rf;
+	s32	value32, CCK_index = 0, ele_A, ele_D, ele_C, X, Y;
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	rf_mimo_mode = dm->rf_type;
+	/* PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK,"%s:%d rf_mimo_mode:%d\n", __FUNCTION__, __LINE__, rf_mimo_mode); */
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+	thermal_value = (unsigned char)odm_get_rf_reg(dm, RF_PATH_A, ODM_RF_T_METER_92E, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+
+
+	switch (rf_mimo_mode) {
+	case RF_1T1R:
+		rf = 1;
+		break;
+	case RF_2T2R:
+		rf = 2;
+		break;
+	default:
+		rf = 2;
+		break;
+	}
+
+	/* Query OFDM path A default setting 	Bit[31:21] */
+	ele_D = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
+	for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
+		if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
+			OFDM_index[0] = (unsigned char)i;
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "PathA 0xC80[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[0]);
+			break;
+		}
+	}
+
+	/* Query OFDM path B default setting */
+	if (rf_mimo_mode == RF_2T2R) {
+		ele_D = phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKOFDM_D);
+		for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
+			if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
+				OFDM_index[1] = (unsigned char)i;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "PathB 0xC88[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[1]);
+				break;
+			}
+		}
+	}
+
+	/* calculate average thermal meter */
+	{
+		priv->pshare->thermal_value_avg_88xx[priv->pshare->thermal_value_avg_index_88xx] = thermal_value;
+		priv->pshare->thermal_value_avg_index_88xx++;
+		if (priv->pshare->thermal_value_avg_index_88xx == AVG_THERMAL_NUM_88XX)
+			priv->pshare->thermal_value_avg_index_88xx = 0;
+
+		for (i = 0; i < AVG_THERMAL_NUM_88XX; i++) {
+			if (priv->pshare->thermal_value_avg_88xx[i]) {
+				thermal_value_avg += priv->pshare->thermal_value_avg_88xx[i];
+				thermal_value_avg_count++;
+			}
+		}
+
+		if (thermal_value_avg_count) {
+			thermal_value = (unsigned char)(thermal_value_avg / thermal_value_avg_count);
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
+		}
+	}
+
+	/* Initialize */
+	if (!priv->pshare->thermal_value) {
+		priv->pshare->thermal_value = priv->pmib->dot11RFEntry.ther;
+		priv->pshare->thermal_value_iqk = thermal_value;
+		priv->pshare->thermal_value_lck = thermal_value;
+	}
+
+	if (thermal_value != priv->pshare->thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+
+		delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+		delta_IQK = RTL_ABS(thermal_value, priv->pshare->thermal_value_iqk);
+		delta_LCK = RTL_ABS(thermal_value, priv->pshare->thermal_value_lck);
+		is_decrease = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
+
+#ifdef _TRACKING_TABLE_FILE
+		if (priv->pshare->rf_ft_var.pwr_track_file) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
+
+			if (is_decrease) {
+				for (i = 0; i < rf; i++) {
+					OFDM_index[i] = priv->pshare->OFDM_index0[i] + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
+					OFDM_index[i] = ((OFDM_index[i] > (OFDM_TABLE_SIZE_92E- 1)) ? (OFDM_TABLE_SIZE_92E - 1) : OFDM_index[i]);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
+					CCK_index = priv->pshare->CCK_index0 + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
+					CCK_index = ((CCK_index > (CCK_TABLE_SIZE_92E - 1)) ? (CCK_TABLE_SIZE_92E - 1) : CCK_index);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> Decrese power ---> new CCK_INDEX:%d (%d + %d)\n",  CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
+				}
+			} else {
+				for (i = 0; i < rf; i++) {
+					OFDM_index[i] = priv->pshare->OFDM_index0[i] - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
+					OFDM_index[i] = ((OFDM_index[i] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[i]);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> Increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
+					CCK_index = priv->pshare->CCK_index0 - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
+					CCK_index = ((CCK_index < 0) ? 0 : CCK_index);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> Increse power ---> new CCK_INDEX:%d (%d - %d)\n", CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
+				}
+			}
+		}
+#endif /* CFG_TRACKING_TABLE_FILE */
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]);
+
+		/* Adujst OFDM Ant_A according to IQK result */
+		ele_D = (ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] & 0xFFC00000) >> 22;
+		X = priv->pshare->rege94;
+		Y = priv->pshare->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;
+
+			/* wirte new elements A, C, D to regC80 and regC94, element B is always 0 */
+			value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
+			phy_set_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, value32);
+
+			value32 = (ele_C & 0x000003C0) >> 6;
+			phy_set_bb_reg(priv, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, value32);
+
+			value32 = ((X * ele_D) >> 7) & 0x01;
+			phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), value32);
+		} else {
+			phy_set_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]);
+			phy_set_bb_reg(priv, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, 0x00);
+			phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), 0x00);
+		}
+
+		set_CCK_swing_index(priv, CCK_index);
+
+		if (rf == 2) {
+			ele_D = (ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] & 0xFFC00000) >> 22;
+			X = priv->pshare->regeb4;
+			Y = priv->pshare->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;
+
+				/* wirte new elements A, C, D to regC88 and regC9C, element B is always 0 */
+				value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
+				phy_set_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, value32);
+
+				value32 = (ele_C & 0x000003C0) >> 6;
+				phy_set_bb_reg(priv, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, value32);
+
+				value32 = ((X * ele_D) >> 7) & 0x01;
+				phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), value32);
+			} else {
+				phy_set_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]);
+				phy_set_bb_reg(priv, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, 0x00);
+				phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), 0x00);
+			}
+
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xc80 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD));
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xc88 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD));
+
+		if ((delta_IQK > 3) && (!iqk_info->rfk_forbidden)) {
+			priv->pshare->thermal_value_iqk = thermal_value;
+#ifdef MP_TEST
+#endif			if (!(*(dm->mp_mode) && (OPMODE & (WIFI_MP_CTX_BACKGROUND | WIFI_MP_CTX_PACKET))))
+
+				halrf_iqk_trigger(dm, false);
+		}
+
+		if ((delta_LCK > 8)  && (!iqk_info->rfk_forbidden)) {
+			RTL_W8(0x522, 0xff);
+			reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, BIT(15), 1);
+			delay_ms(1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, reg0x18);
+			RTL_W8(0x522, 0x0);
+			priv->pshare->thermal_value_lck = thermal_value;
+		}
+	}
+
+	/* update thermal meter value */
+	priv->pshare->thermal_value = thermal_value;
+	for (i = 0 ; i < rf ; i++)
+		priv->pshare->OFDM_index[i] = OFDM_index[i];
+	priv->pshare->CCK_index = CCK_index;
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
+}
+#endif
+
+
+
+#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series3(
+	void		*dm_void
+)
+{
+#if 1
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
+	u8			thermal_value_avg_count = 0, p = 0, i = 0;
+	u32			thermal_value_avg = 0;
+	struct rtl8192cd_priv		*priv = dm->priv;
+	struct txpwrtrack_cfg	c;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	/*4 1. The following TWO tables decide the final index of OFDM/CCK swing table.*/
+	u8			*delta_swing_table_idx_tup_a = NULL, *delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL, *delta_swing_table_idx_tdown_b = NULL;
+	u8			*delta_swing_table_idx_tup_cck_a = NULL, *delta_swing_table_idx_tdown_cck_a = NULL;
+	u8			*delta_swing_table_idx_tup_cck_b = NULL, *delta_swing_table_idx_tdown_cck_b = NULL;
+	/*for 8814 add by Yu Chen*/
+	u8			*delta_swing_table_idx_tup_c = NULL, *delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL, *delta_swing_table_idx_tdown_d = NULL;
+	u8			*delta_swing_table_idx_tup_cck_c = NULL, *delta_swing_table_idx_tdown_cck_c = NULL;
+	u8			*delta_swing_table_idx_tup_cck_d = NULL, *delta_swing_table_idx_tdown_cck_d = NULL;
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_all_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b,
+		(u8 **)&delta_swing_table_idx_tup_cck_a, (u8 **)&delta_swing_table_idx_tdown_cck_a,
+		(u8 **)&delta_swing_table_idx_tup_cck_b, (u8 **)&delta_swing_table_idx_tdown_cck_b);
+
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /*0x42: RF Reg[15:10] 88E*/
+#ifdef THER_TRIM
+	if (GET_CHIP_VER(priv) == VERSION_8197F) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"orig thermal_value=%d, ther_trim_val=%d\n", thermal_value, priv->pshare->rf_ft_var.ther_trim_val);
+
+		thermal_value += priv->pshare->rf_ft_var.ther_trim_val;
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"after thermal trim, thermal_value=%d\n", thermal_value);
+	}
+#endif
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"Readback Thermal Meter = 0x%x(%d) EEPROMthermalmeter 0x%x(%d)\n"
+		, thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
+
+	/* Initialize */
+	if (!dm->rf_calibrate_info.thermal_value)
+		dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_lck)
+		dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_iqk)
+		dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
+
+	/* calculate average thermal meter */
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {/*Calculate Average thermal_value after average enough times*/
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"thermal_value_avg=0x%x(%d)  thermal_value_avg_count = %d\n"
+			, thermal_value_avg, thermal_value_avg, thermal_value_avg_count);
+
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X(%d), EEPROMthermalmeter = 0x%X(%d)\n", thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
+	}
+
+	/*4 Calculate delta, delta_LCK, delta_IQK.*/
+	delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+	delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
+	delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
+	is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
+
+	if (delta > 29) { /* power track table index(thermal diff.) upper bound*/
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta(%d) > 29, set delta to 29\n", delta);
+		delta = 29;
+	}
+
+
+	/*4 if necessary, do LCK.*/
+	if ((delta_LCK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+#if (RTL8822B_SUPPORT != 1)
+		if (!(dm->support_ic_type & ODM_RTL8822B)) {
+		if (c.phy_lc_calibrate)
+			(*c.phy_lc_calibrate)(dm);
+	}
+#endif
+	}
+
+	if ((delta_IQK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+		if (c.do_iqk)
+			(*c.do_iqk)(dm, true, 0, 0);
+	}
+
+	if (!priv->pmib->dot11RFEntry.ther)	/*Don't do power tracking since no calibrated thermal value*/
+		return;
+
+	/*4 Do Power Tracking*/
+
+	if (thermal_value != dm->rf_calibrate_info.thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\n\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"Readback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n",
+			thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
+
+#ifdef _TRACKING_TABLE_FILE
+		if (priv->pshare->rf_ft_var.pwr_track_file) {
+			if (is_increase) {			/*thermal is higher than base*/
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_b[%d] = %d delta_swing_table_idx_tup_cck_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta], delta, delta_swing_table_idx_tup_cck_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_b[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_c[%d] = %d delta_swing_table_idx_tup_cck_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta], delta, delta_swing_table_idx_tup_cck_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_c[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_d[%d] = %d delta_swing_table_idx_tup_cck_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta], delta, delta_swing_table_idx_tup_cck_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_d[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_a[%d] = %d delta_swing_table_idx_tup_cck_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta], delta, delta_swing_table_idx_tup_cck_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_a[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+					}
+				}
+			} else {			/* thermal is lower than base*/
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_b[%d] = %d   delta_swing_table_idx_tdown_cck_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta], delta, delta_swing_table_idx_tdown_cck_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_b[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d   pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_c[%d] = %d   delta_swing_table_idx_tdown_cck_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta], delta, delta_swing_table_idx_tdown_cck_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_c[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d   pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_d[%d] = %d   delta_swing_table_idx_tdown_cck_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta], delta, delta_swing_table_idx_tdown_cck_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_d[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d   pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_a[%d] = %d   delta_swing_table_idx_tdown_cck_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta], delta, delta_swing_table_idx_tdown_cck_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_a[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d   pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+					}
+				}
+			}
+
+			if (is_increase) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> increse power --->\n");
+				if (GET_CHIP_VER(priv) == VERSION_8197F) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				}
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power --->\n");
+				if (GET_CHIP_VER(priv) == VERSION_8197F) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				}
+			}
+		}
+#endif
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n\n", __func__);
+		/*update thermal meter value*/
+		dm->rf_calibrate_info.thermal_value =  thermal_value;
+
+	}
+
+#endif
+}
+#endif
+
+/*#if (RTL8814A_SUPPORT == 1)*/
+#if (RTL8814A_SUPPORT == 1)
+
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series2(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
+	u8			thermal_value_avg_count = 0, p = 0, i = 0;
+	u32			thermal_value_avg = 0, reg0x18;
+	u32			bb_swing_reg[4] = {REG_A_TX_SCALE_JAGUAR, REG_B_TX_SCALE_JAGUAR, REG_C_TX_SCALE_JAGUAR2, REG_D_TX_SCALE_JAGUAR2};
+	s32			ele_D;
+	u32			bb_swing_idx;
+	struct rtl8192cd_priv	*priv = dm->priv;
+	struct txpwrtrack_cfg	c;
+	boolean			is_tssi_enable = false;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	u8			*delta_swing_table_idx_tup_a = NULL, *delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL, *delta_swing_table_idx_tdown_b = NULL;
+	/* for 8814 add by Yu Chen */
+	u8			*delta_swing_table_idx_tup_c = NULL, *delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL, *delta_swing_table_idx_tdown_d = NULL;
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+	configure_txpower_track(dm, &c);
+	cali_info->default_ofdm_index = priv->pshare->OFDM_index0[RF_PATH_A];
+
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+
+	if (dm->support_ic_type & ODM_RTL8814A)	/* for 8814 path C & D */
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
+
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x, pre thermal meter 0x%x, EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
+
+	/* Initialize */
+	if (!dm->rf_calibrate_info.thermal_value)
+		dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_lck)
+		dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_iqk)
+		dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
+
+	is_tssi_enable = (boolean)odm_get_rf_reg(dm, RF_PATH_A, REG_RF_TX_GAIN_OFFSET, BIT(7));	/* check TSSI enable */
+
+	/* 4 Query OFDM BB swing default setting 	Bit[31:21] */
+	for (p = RF_PATH_A ; p < c.rf_path_count ; p++) {
+		ele_D = odm_get_bb_reg(dm, bb_swing_reg[p], 0xffe00000);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[p], odm_get_bb_reg(dm, bb_swing_reg[p], MASKDWORD), ele_D);
+
+		for (bb_swing_idx = 0; bb_swing_idx < TXSCALE_TABLE_SIZE; bb_swing_idx++) {/* 4 */
+			if (ele_D == tx_scaling_table_jaguar[bb_swing_idx]) {
+				dm->rf_calibrate_info.OFDM_index[p] = (u8)bb_swing_idx;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"OFDM_index[%d]=%d\n", p, dm->rf_calibrate_info.OFDM_index[p]);
+				break;
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "kfree_offset[%d]=%d\n", p, cali_info->kfree_offset[p]);
+
+	}
+
+	/* calculate average thermal meter */
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)  /* Average times =  c.average_thermal_num */
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X, EEPROMthermalmeter = 0x%X\n", thermal_value, priv->pmib->dot11RFEntry.ther);
+	}
+
+	/* 4 Calculate delta, delta_LCK, delta_IQK. */
+	delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+	delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
+	delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
+	is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
+
+	/* 4 if necessary, do LCK. */
+	if (!(dm->support_ic_type & ODM_RTL8821)) {
+		if ((delta_LCK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+			dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, so close power tracking driver LCK*/
+#if (RTL8814A_SUPPORT != 1)
+			if (!(dm->support_ic_type & ODM_RTL8814A)) {
+				if (c.phy_lc_calibrate)
+					(*c.phy_lc_calibrate)(dm);
+			}
+#endif
+		}
+	}
+
+	if ((delta_IQK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+		panic_printk("%s(%d)\n", __FUNCTION__, __LINE__);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+		if (c.do_iqk)
+			(*c.do_iqk)(dm, true, 0, 0);
+	}
+
+	if (!priv->pmib->dot11RFEntry.ther)	/*Don't do power tracking since no calibrated thermal value*/
+		return;
+
+	/* 4 Do Power Tracking */
+
+	if (is_tssi_enable == true) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter PURE TSSI MODE**********\n");
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
+	} else if (thermal_value != dm->rf_calibrate_info.thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
+
+#ifdef _TRACKING_TABLE_FILE
+		if (priv->pshare->rf_ft_var.pwr_track_file) {
+			if (is_increase) {		/* thermal is higher than base */
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta];       /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta];       /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta];       /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+					}
+				}
+			} else {				/* thermal is lower than base */
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+					}
+				}
+			}
+
+			if (is_increase) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> increse power --->\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power --->\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			}
+		}
+#endif
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
+		/* update thermal meter value */
+		dm->rf_calibrate_info.thermal_value =  thermal_value;
+
+	}
+}
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8881A_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	unsigned char			thermal_value = 0, delta, delta_LCK, channel, is_decrease;
+	unsigned char			thermal_value_avg_count = 0;
+	unsigned int			thermal_value_avg = 0, reg0x18;
+	unsigned int			bb_swing_reg[4] = {0xc1c, 0xe1c, 0x181c, 0x1a1c};
+	int					ele_D, value32;
+	char					OFDM_index[2], index;
+	unsigned int			i = 0, j = 0, rf_path, max_rf_path = 2, rf;
+	struct rtl8192cd_priv		*priv = dm->priv;
+	unsigned char			OFDM_min_index = 7; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur and Mimic */
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+#if RTL8881A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8881A) {
+		max_rf_path = 1;
+		if ((get_bonding_type_8881A() == BOND_8881AM || get_bonding_type_8881A() == BOND_8881AN)
+		    && priv->pshare->rf_ft_var.use_intpa8881A && (*dm->band_type == ODM_BAND_2_4G))
+			OFDM_min_index = 6;		/* intPA - upper bond set to +3 dB (base: -2 dB)ot11RFEntry.phy_band_select == PHY_BAND_2G)) */
+		else
+			OFDM_min_index = 10;		/* OFDM BB Swing should be less than +1dB, which is required by Arthur and Mimic */
+	}
+#endif
+
+
+	thermal_value = (unsigned char)phy_query_rf_reg(priv, RF_PATH_A, 0x42, 0xfc00, 1); /* 0x42: RF Reg[15:10] 88E */
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+
+
+	/* 4 Query OFDM BB swing default setting 	Bit[31:21] */
+	for (rf_path = 0 ; rf_path < max_rf_path ; rf_path++) {
+		ele_D = phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], MASKDWORD), ele_D);
+		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
+			if (ele_D == ofdm_swing_table_8812[i]) {
+				OFDM_index[rf_path] = (unsigned char)i;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "OFDM_index[%d]=%d\n", rf_path, OFDM_index[rf_path]);
+				break;
+			}
+		}
+	}
+#if 0
+	/* Query OFDM path A default setting 	Bit[31:21] */
+	ele_D = phy_query_bb_reg(priv, 0xc1c, 0xffe00000);
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xc1c:0x%x ([31:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xc1c, MASKDWORD), ele_D);
+	for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
+		if (ele_D == ofdm_swing_table_8812[i]) {
+			OFDM_index[0] = (unsigned char)i;
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "OFDM_index[0]=%d\n", OFDM_index[0]);
+			break;
+		}
+	}
+	/* Query OFDM path B default setting */
+	if (rf == 2) {
+		ele_D = phy_query_bb_reg(priv, 0xe1c, 0xffe00000);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xe1c:0x%x ([32:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xe1c, MASKDWORD), ele_D);
+		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {
+			if (ele_D == ofdm_swing_table_8812[i]) {
+				OFDM_index[1] = (unsigned char)i;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "OFDM_index[1]=%d\n", OFDM_index[1]);
+				break;
+			}
+		}
+	}
+#endif
+	/* Initialize */
+	if (!priv->pshare->thermal_value) {
+		priv->pshare->thermal_value = priv->pmib->dot11RFEntry.ther;
+		priv->pshare->thermal_value_lck = thermal_value;
+	}
+
+	/* calculate average thermal meter */
+	{
+		priv->pshare->thermal_value_avg_8812[priv->pshare->thermal_value_avg_index_8812] = thermal_value;
+		priv->pshare->thermal_value_avg_index_8812++;
+		if (priv->pshare->thermal_value_avg_index_8812 == AVG_THERMAL_NUM_8812)
+			priv->pshare->thermal_value_avg_index_8812 = 0;
+
+		for (i = 0; i < AVG_THERMAL_NUM_8812; i++) {
+			if (priv->pshare->thermal_value_avg_8812[i]) {
+				thermal_value_avg += priv->pshare->thermal_value_avg_8812[i];
+				thermal_value_avg_count++;
+			}
+		}
+
+		if (thermal_value_avg_count) {
+			thermal_value = (unsigned char)(thermal_value_avg / thermal_value_avg_count);
+			/* printk("AVG Thermal Meter = 0x%x\n", thermal_value); */
+		}
+	}
+
+
+	/* 4 If necessary,  do power tracking */
+
+	if (!priv->pmib->dot11RFEntry.ther) /*Don't do power tracking since no calibrated thermal value*/
+		return;
+
+	if (thermal_value != priv->pshare->thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+		delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+		delta_LCK = RTL_ABS(thermal_value, priv->pshare->thermal_value_lck);
+		is_decrease = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
+		/* if (*dm->band_type == ODM_BAND_5G) */
+		{
+#ifdef _TRACKING_TABLE_FILE
+			if (priv->pshare->rf_ft_var.pwr_track_file) {
+				for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
+					if (is_decrease) {
+						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] + get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
+						OFDM_index[rf_path] = ((OFDM_index[rf_path] > (OFDM_TABLE_SIZE_8812 - 1)) ? (OFDM_TABLE_SIZE_8812 - 1) : OFDM_index[rf_path]);
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
+#if 0/* RTL8881A_SUPPORT */
+						if (dm->support_ic_type == ODM_RTL8881A) {
+							if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
+								if (priv->pshare->add_tx_agc) { /* tx_agc has been added */
+									add_tx_power88xx_ac(priv, 0);
+									priv->pshare->add_tx_agc = 0;
+									priv->pshare->add_tx_agc_index = 0;
+								}
+							}
+						}
+#endif
+					} else {
+
+						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] - get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
+#if 0/* RTL8881A_SUPPORT */
+						if (dm->support_ic_type == ODM_RTL8881A) {
+							if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
+								if (OFDM_index[i] < OFDM_min_index) {
+									priv->pshare->add_tx_agc_index = (OFDM_min_index - OFDM_index[i]) / 2; /* Calculate Remnant tx_agc value,  2 index for 1 tx_agc */
+									add_tx_power88xx_ac(priv, priv->pshare->add_tx_agc_index);
+									priv->pshare->add_tx_agc = 1;     /* add_tx_agc Flag = 1 */
+									OFDM_index[i] = OFDM_min_index;
+								} else {
+									if (priv->pshare->add_tx_agc) { /* tx_agc been added */
+										priv->pshare->add_tx_agc = 0;
+										priv->pshare->add_tx_agc_index = 0;
+										add_tx_power88xx_ac(priv, 0); /* minus the added TPI */
+									}
+								}
+							}
+						}
+#else
+						OFDM_index[rf_path] = ((OFDM_index[rf_path] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[rf_path]);
+#endif
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
+					}
+				}
+			}
+#endif
+			/* 4 Set new BB swing index */
+			for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
+				phy_set_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000, ofdm_swing_table_8812[(unsigned int)OFDM_index[rf_path]]);
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Readback 0x%x[31:21] = 0x%x, OFDM_index:%d\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000), OFDM_index[rf_path]);
+			}
+
+		}
+		if ((delta_LCK > 8) && (!iqk_info->rfk_forbidden)) {
+			RTL_W8(0x522, 0xff);
+			reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, BIT(15), 1);
+			delay_ms(200); /* frequency deviation */
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, reg0x18);
+#ifdef CONFIG_RTL_8812_SUPPORT
+			if (GET_CHIP_VER(priv) == VERSION_8812E)
+				update_bbrf_val8812(priv, priv->pmib->dot11RFEntry.dot11channel);
+#endif
+			RTL_W8(0x522, 0x0);
+			priv->pshare->thermal_value_lck = thermal_value;
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
+
+		/* update thermal meter value */
+		priv->pshare->thermal_value = thermal_value;
+		for (rf_path = 0; rf_path < max_rf_path; rf_path++)
+			priv->pshare->OFDM_index[rf_path] = OFDM_index[rf_path];
+	}
+}
+
+#endif
+
+
+void
+odm_txpowertracking_callback_thermal_meter(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F || dm->support_ic_type == ODM_RTL8822B
+		|| dm->support_ic_type == ODM_RTL8821C) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series3(dm);
+		return;
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)		/*use this function to do power tracking after 8814 by YuChen*/
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series2(dm);
+		return;
+	}
+#endif
+#if (RTL8881A_SUPPORT || RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8812 || dm->support_ic_type & ODM_RTL8881A) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series(dm);
+		return;
+	}
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_txpowertracking_callback_thermal_meter_92e(dm);
+		return;
+	}
+#endif
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	/* PMGNT_INFO      		mgnt_info = &adapter->mgnt_info; */
+#endif
+
+
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, offset;
+	u8			thermal_value_avg_count = 0;
+	u32			thermal_value_avg = 0;
+	/*	s32			ele_A=0, ele_D, TempCCk, X, value32;
+	 *	s32			Y, ele_C=0;
+	 *	s8			OFDM_index[2], CCK_index=0, OFDM_index_old[2]={0,0}, CCK_index_old=0, index;
+	 *	s8			deltaPowerIndex = 0; */
+	u32			i = 0;/* , j = 0; */
+	boolean		is2T = false;
+	/*	bool 		bInteralPA = false; */
+
+	u8			OFDM_max_index = 34, rf = (is2T) ? 2 : 1; /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
+	u8			indexforchannel = 0;/*get_right_chnl_place_for_iqk(hal_data->current_channel)*/
+	enum            _POWER_DEC_INC { POWER_DEC, POWER_INC };
+
+	struct txpwrtrack_cfg	c;
+
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	s8			delta_swing_table_idx[2][index_mapping_NUM_88E] = {
+		/* {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}} */
+		{0, 0, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 10, 11}, {0, 0, 1, 2, 3, 4, 4, 4, 4, 5, 7, 8, 9, 9, 10}
+	};
+	u8			thermal_threshold[2][index_mapping_NUM_88E] = {
+		/* {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}} */
+		{0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 27}, {0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 25, 25, 25}
+	};
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct rtl8192cd_priv	*priv = dm->priv;
+#endif
+
+	/* 4 2. Initilization ( 7 steps in total ) */
+
+	configure_txpower_track(dm, &c);
+
+	dm->rf_calibrate_info.txpowertracking_callback_cnt++; /* cosa add for debug */
+	dm->rf_calibrate_info.is_txpowertracking_init = true;
+
+#if (MP_DRIVER == 1)
+	dm->rf_calibrate_info.txpowertrack_control = hal_data->txpowertrack_control; /* <Kordan> We should keep updating the control variable according to HalData.
+     * <Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
+	dm->rf_calibrate_info.rega24 = 0x090e1317;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP) && defined(MP_TEST)
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		if (dm->priv->pshare->mp_txpwr_tracking == false)
+			return;
+	}
+#endif
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "===>odm_txpowertracking_callback_thermal_meter_8188e, dm->bb_swing_idx_cck_base: %d, dm->bb_swing_idx_ofdm_base: %d\n", cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base);
+	/*
+		if (!dm->rf_calibrate_info.tm_trigger) {
+			odm_set_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, BIT(17) | BIT(16), 0x3);
+			dm->rf_calibrate_info.tm_trigger = 1;
+			return;
+		}
+	*/
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	if (!thermal_value || !dm->rf_calibrate_info.txpowertrack_control)
+#else
+	if (!dm->rf_calibrate_info.txpowertrack_control)
+#endif
+		return;
+
+	/* 4 3. Initialize ThermalValues of rf_calibrate_info */
+
+	if (!dm->rf_calibrate_info.thermal_value) {
+		dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+	}
+
+	if (dm->rf_calibrate_info.is_reloadtxpowerindex)
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "reload ofdm index for band switch\n");
+
+	/* 4 4. Calculate average thermal meter */
+
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {
+		/* Give the new thermo value a weighting */
+		thermal_value_avg += (thermal_value * 4);
+
+		thermal_value = (u8)(thermal_value_avg / (thermal_value_avg_count + 4));
+		cali_info->thermal_value_delta = thermal_value - priv->pmib->dot11RFEntry.ther;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
+	}
+
+	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
+
+	delta	  = (thermal_value > dm->rf_calibrate_info.thermal_value) ? (thermal_value - dm->rf_calibrate_info.thermal_value) : (dm->rf_calibrate_info.thermal_value - thermal_value);
+	delta_LCK = (thermal_value > dm->rf_calibrate_info.thermal_value_lck) ? (thermal_value - dm->rf_calibrate_info.thermal_value_lck) : (dm->rf_calibrate_info.thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > dm->rf_calibrate_info.thermal_value_iqk) ? (thermal_value - dm->rf_calibrate_info.thermal_value_iqk) : (dm->rf_calibrate_info.thermal_value_iqk - thermal_value);
+
+	/* 4 6. If necessary, do LCK. */
+	if (!(dm->support_ic_type & ODM_RTL8821)) {
+		/*if((delta_LCK > hal_data->delta_lck) && (hal_data->delta_lck != 0))*/
+		if ((delta_LCK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+			/*Delta temperature is equal to or larger than 20 centigrade.*/
+			dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+			(*c.phy_lc_calibrate)(dm);
+		}
+	}
+
+	/* 3 7. If necessary, move the index of swing table to adjust Tx power. */
+
+	if (delta > 0 && dm->rf_calibrate_info.txpowertrack_control) {
+
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+
+		/* 4 7.1 The Final Power index = BaseIndex + power_index_offset */
+
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_INC, index_mapping_NUM_88E, delta);
+			dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
+			dm->rf_calibrate_info.delta_power_index =  delta_swing_table_idx[POWER_INC][offset];
+
+		} else {
+
+			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_DEC, index_mapping_NUM_88E, delta);
+			dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
+			dm->rf_calibrate_info.delta_power_index = (-1) * delta_swing_table_idx[POWER_DEC][offset];
+		}
+
+		if (dm->rf_calibrate_info.delta_power_index == dm->rf_calibrate_info.delta_power_index_last)
+			dm->rf_calibrate_info.power_index_offset = 0;
+		else
+			dm->rf_calibrate_info.power_index_offset = dm->rf_calibrate_info.delta_power_index - dm->rf_calibrate_info.delta_power_index_last;
+
+		for (i = 0; i < rf; i++)
+			dm->rf_calibrate_info.OFDM_index[i] = cali_info->bb_swing_idx_ofdm_base + dm->rf_calibrate_info.power_index_offset;
+		dm->rf_calibrate_info.CCK_index = cali_info->bb_swing_idx_cck_base + dm->rf_calibrate_info.power_index_offset;
+
+		cali_info->bb_swing_idx_cck = dm->rf_calibrate_info.CCK_index;
+		cali_info->bb_swing_idx_ofdm[RF_PATH_A] = dm->rf_calibrate_info.OFDM_index[RF_PATH_A];
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, dm->rf_calibrate_info.power_index_offset);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "The 'OFDM' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base, dm->rf_calibrate_info.power_index_offset);
+
+		/* 4 7.1 Handle boundary conditions of index. */
+
+
+		for (i = 0; i < rf; i++) {
+			if (dm->rf_calibrate_info.OFDM_index[i] > OFDM_max_index)
+				dm->rf_calibrate_info.OFDM_index[i] = OFDM_max_index;
+			else if (dm->rf_calibrate_info.OFDM_index[i] < 0)
+				dm->rf_calibrate_info.OFDM_index[i] = 0;
+		}
+
+		if (dm->rf_calibrate_info.CCK_index > c.swing_table_size_cck - 1)
+			dm->rf_calibrate_info.CCK_index = c.swing_table_size_cck - 1;
+		else if (dm->rf_calibrate_info.CCK_index < 0)
+			dm->rf_calibrate_info.CCK_index = 0;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"The thermal meter is unchanged or TxPowerTracking OFF: thermal_value: %d, dm->rf_calibrate_info.thermal_value: %d)\n", thermal_value, dm->rf_calibrate_info.thermal_value);
+		dm->rf_calibrate_info.power_index_offset = 0;
+	}
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.CCK_index, cali_info->bb_swing_idx_cck_base);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.OFDM_index[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base);
+
+	if (dm->rf_calibrate_info.power_index_offset != 0 && dm->rf_calibrate_info.txpowertrack_control) {
+		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
+
+		dm->rf_calibrate_info.is_tx_power_changed = true; /* Always true after Tx Power is adjusted by power tracking. */
+		/*  */
+		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
+		/* to increase TX power. Otherwise, EVM will be bad. */
+		/*  */
+		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
+		if (thermal_value > dm->rf_calibrate_info.thermal_value) {
+			/* PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK, */
+			/*	"Temperature Increasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
+			/*	dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
+		} else if (thermal_value < dm->rf_calibrate_info.thermal_value) { /* Low temperature */
+			/* PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK, */
+			/*	"Temperature Decreasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
+			/*		dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
+		}
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
+		{
+			/*				PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK,"Temperature(%d) hugher than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
+			(*c.odm_tx_pwr_track_set_pwr)(dm, TXAGC, 0, 0);
+		} else {
+			/*			PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK,"Temperature(%d) lower than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
+			(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_A, indexforchannel);
+			if (is2T)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_B, indexforchannel);
+		}
+
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;
+		cali_info->bb_swing_idx_ofdm_base = cali_info->bb_swing_idx_ofdm[RF_PATH_A];
+		dm->rf_calibrate_info.thermal_value = thermal_value;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "<===dm_TXPowerTrackingCallback_ThermalMeter_8188E\n");
+
+	dm->rf_calibrate_info.tx_powercount = 0;
+}
+
+/* 3============================================================
+ * 3 IQ Calibration
+ * 3============================================================ */
+
+void
+odm_reset_iqk_result(
+	void		*dm_void
+)
+{
+	return;
+}
+#if 1/* !(DM_ODM_SUPPORT_TYPE & ODM_AP) */
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
+{
+	u8	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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
+	};
+	u8	place = chnl;
+
+
+	if (chnl > 14) {
+		for (place = 14; place < sizeof(channel_all); place++) {
+			if (channel_all[place] == chnl)
+				return place - 13;
+		}
+	}
+	return 0;
+
+}
+#endif
+
+void
+odm_iq_calibrate(
+	struct dm_struct	*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		if ((*dm->channel != dm->pre_channel) && (!*dm->is_scan_in_process)) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
+		}
+
+		if (dm->linked_interval < 3)
+			dm->linked_interval++;
+
+		if (dm->linked_interval == 2)
+			halrf_iqk_trigger(dm, false);
+	} else
+		dm->linked_interval = 0;
+
+}
+
+void phydm_rf_init(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	odm_txpowertracking_init(dm);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
+#endif
+#endif
+
+}
+
+void phydm_rf_watchdog(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_txpowertracking_check(dm);
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_iq_calibrate(dm);
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ap.h
new file mode 100644
index 000000000000..6c6d629c7bc1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ap.h
@@ -0,0 +1,122 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PHY_RF_H__
+#define __HAL_PHY_RF_H__
+
+#include "halrf/halrf_powertracking_ap.h"
+#include "halrf/halrf_kfree.h"
+
+#if (RTL8814A_SUPPORT == 1)
+	#include "halrf/rtl8814a/halrf_iqk_8814a.h"
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#include "halrf/rtl8822b/halrf_iqk_8822b.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
+#endif
+
+enum pwrtrack_method {
+	BBSWING,
+	TXAGC,
+	MIX_MODE,
+	TSSI_MODE
+};
+
+typedef void	(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void(*func_iqk)(void *, u8, u8, u8);
+typedef void	(*func_lck)(void *);
+/* refine by YuChen for 8814A */
+typedef void	(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
+
+
+struct txpwrtrack_cfg {
+	u8		swing_table_size_cck;
+	u8		swing_table_size_ofdm;
+	u8		threshold_iqk;
+	u8		threshold_dpk;
+	u8		average_thermal_num;
+	u8		rf_path_count;
+	u32		thermal_reg_addr;
+	func_set_pwr	odm_tx_pwr_track_set_pwr;
+	func_iqk	do_iqk;
+	func_lck		phy_lc_calibrate;
+	func_swing	get_delta_swing_table;
+	func_swing8814only	get_delta_swing_table8814only;
+	func_all_swing	get_delta_all_swing_table;
+};
+
+void
+configure_txpower_track(
+	void		*dm_void,
+	struct txpwrtrack_cfg	*config
+);
+
+
+void
+odm_txpowertracking_callback_thermal_meter(
+	void		*dm_void
+);
+
+#if (RTL8192E_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_92e(
+	void		*dm_void
+);
+#endif
+
+#if (RTL8814A_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series2(
+	void		*dm_void
+);
+
+#elif ODM_IC_11AC_SERIES_SUPPORT
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series(
+	void		*dm_void
+);
+
+#elif (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series3(
+	void		*dm_void
+);
+
+#endif
+
+#define IS_CCK_RATE(_rate)				(ODM_MGN_1M == _rate || _rate == ODM_MGN_2M || _rate == ODM_MGN_5_5M || _rate == ODM_MGN_11M)
+
+#define ODM_TARGET_CHNL_NUM_2G_5G	59
+
+
+void
+odm_reset_iqk_result(
+	void		*dm_void
+);
+u8
+odm_get_right_chnl_place_for_iqk(
+	u8 chnl
+);
+
+void phydm_rf_init(void		*dm_void);
+void phydm_rf_watchdog(void		*dm_void);
+
+#endif	/*  #ifndef __HAL_PHY_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ce.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ce.c
new file mode 100644
index 000000000000..847a6853bfc5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ce.c
@@ -0,0 +1,907 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
+	do {\
+		for (_offset = 0; _offset < _size; _offset++) { \
+			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
+				if (_offset != 0)\
+					_offset--;\
+				break;\
+			} \
+		}			\
+		if (_offset >= _size)\
+			_offset = _size-1;\
+	} while (0)
+
+void configure_txpower_track(
+	void					*dm_void,
+	struct txpwrtrack_cfg	*config
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if RTL8192E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192E)
+		configure_txpower_track_8192e(config);
+#endif
+#if RTL8821A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821)
+		configure_txpower_track_8821a(config);
+#endif
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
+#endif
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
+#endif
+
+#if RTL8723B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723B)
+		configure_txpower_track_8723b(config);
+#endif
+
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
+#endif
+
+#if RTL8703B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8703B)
+		configure_txpower_track_8703b(config);
+#endif
+
+#if RTL8188F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188F)
+		configure_txpower_track_8188f(config);
+#endif
+#if RTL8723D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723D)
+		configure_txpower_track_8723d(config);
+#endif
+/* JJ ADD 20161014 */
+#if RTL8710B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8710B)
+		configure_txpower_track_8710b(config);
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
+#endif
+#if RTL8821C_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821C)
+		configure_txpower_track_8821c(config);
+#endif
+
+}
+
+/* **********************************************************************
+ * <20121113, Kordan> This function should be called when tx_agc changed.
+ * Otherwise the previous compensation is gone, because we record the
+ * delta of temperature between two TxPowerTracking watch dogs.
+ *
+ * NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
+ * need to call this function.
+ * ********************************************************************** */
+void
+odm_clear_txpowertracking_state(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
+#else
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(dm->adapter);
+#endif
+	u8			p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+	dm->rf_calibrate_info.CCK_index = 0;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+
+		cali_info->power_index_offset[p] = 0;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+
+		cali_info->absolute_ofdm_swing_idx[p] = 0;    /* Initial Mix mode power tracking*/
+		cali_info->remnant_ofdm_swing_idx[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+
+	cali_info->modify_tx_agc_flag_path_a = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_b = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_c = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_d = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->remnant_cck_swing_idx = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	cali_info->thermal_value = rtlefu->eeprom_thermalmeter;
+#else
+	cali_info->thermal_value = hal_data->eeprom_thermal_meter;
+#endif
+
+	cali_info->modify_tx_agc_value_cck = 0;			/* modify by Mingzhi.Guo */
+	cali_info->modify_tx_agc_value_ofdm = 0;		/* modify by Mingzhi.Guo */
+
+}
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct		*dm
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*dm_void
+#else
+	void	*adapter
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
+	void *adapter = dm->adapter;
+#elif !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#endif
+#endif
+
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct	dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
+	s8			diff_DPK[4] = {0};
+	u8			thermal_value_avg_count = 0;
+	u32			thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
+
+	u8			OFDM_min_index = 0;  /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
+	u8			indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	u8			power_tracking_type = 0;	/* no specify type */
+#else
+	u8			power_tracking_type = hal_data->rf_power_tracking_type;
+#endif
+	u8			xtal_offset_eanble = 0;
+	s8			thermal_value_temp = 0;
+
+	struct txpwrtrack_cfg	c = {0};
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	u8			*delta_swing_table_idx_tup_a = NULL;
+	u8			*delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL;
+	u8			*delta_swing_table_idx_tdown_b = NULL;
+	/*for 8814 add by Yu Chen*/
+	u8			*delta_swing_table_idx_tup_c = NULL;
+	u8			*delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL;
+	u8			*delta_swing_table_idx_tdown_d = NULL;
+	/*for Xtal Offset by James.Tung*/
+	s8			*delta_swing_table_xtal_up = NULL;
+	s8			*delta_swing_table_xtal_down = NULL;
+
+	/* 4 2. Initilization ( 7 steps in total ) */
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+
+	if (dm->support_ic_type & ODM_RTL8814A)	/*for 8814 path C & D*/
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B))	/*for Xtal Offset*/
+		(*c.get_delta_swing_xtal_table)(dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
+
+	cali_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
+	cali_info->is_txpowertracking_init = true;
+
+	/*cali_info->txpowertrack_control = hal_data->txpowertrack_control;
+	<Kordan> We should keep updating the control variable according to HalData.
+	<Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+	cali_info->rega24 = 0x090e1317;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	if (*(dm->mp_mode) == true)
+		cali_info->rega24 = 0x090e1317;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
+		cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"cali_info->txpowertrack_control=%d,  rtlefu->eeprom_thermalmeter %d\n", cali_info->txpowertrack_control,  rtlefu->eeprom_thermalmeter);
+#else
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"cali_info->txpowertrack_control=%d,  hal_data->eeprom_thermal_meter %d\n", cali_info->txpowertrack_control,  hal_data->eeprom_thermal_meter);
+#endif
+
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+
+	thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"thermal_value_temp(%d) = thermal_value(%d) + power_trim_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
+
+	if (thermal_value_temp > 63)
+		thermal_value = 63;
+	else if (thermal_value_temp < 0)
+		thermal_value = 0;
+	else
+		thermal_value = thermal_value_temp;
+
+	/*add log by zhao he, check c80/c94/c14/ca0 value*/
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+
+	if (!cali_info->txpowertrack_control)
+		return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	if (rtlefu->eeprom_thermalmeter == 0xff) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", rtlefu->eeprom_thermalmeter);
+		return;
+	}
+#else
+	if (hal_data->eeprom_thermal_meter == 0xff) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", hal_data->eeprom_thermal_meter);
+		return;
+	}
+#endif
+
+	/*4 3. Initialize ThermalValues of rf_calibrate_info*/
+
+	if (cali_info->is_reloadtxpowerindex)
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "reload ofdm index for band switch\n");
+
+	/*4 4. Calculate average thermal meter*/
+
+	cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
+	cali_info->thermal_value_avg_index++;
+	if (cali_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		cali_info->thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (cali_info->thermal_value_avg[i]) {
+			thermal_value_avg += cali_info->thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		cali_info->thermal_value_delta = thermal_value - rtlefu->eeprom_thermalmeter;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+		cali_info->thermal_value_delta = thermal_value - hal_data->eeprom_thermal_meter;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+	}
+
+	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
+
+	/* "delta" here is used to determine whether thermal value changes or not. */
+	delta	= (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
+	delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+
+	if (cali_info->thermal_value_iqk == 0xff) {	/*no PG, use thermal value for IQK*/
+		cali_info->thermal_value_iqk = thermal_value;
+		delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, use thermal_value for IQK\n");
+	}
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++)
+		diff_DPK[p] = (s8)thermal_value - (s8)cali_info->dpk_thermal[p];
+
+	/*4 6. If necessary, do LCK.*/
+
+	if (!(dm->support_ic_type & ODM_RTL8821)) {	/*no PG, do LCK at initial status*/
+		if (cali_info->thermal_value_lck == 0xff) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, do LCK\n");
+			cali_info->thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, so close power tracking driver LCK*/
+			if (!(dm->support_ic_type & ODM_RTL8814A) && !(dm->support_ic_type & ODM_RTL8822B) && c.phy_lc_calibrate)
+				(*c.phy_lc_calibrate)(dm);
+
+			delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
+
+		/* Wait sacn to do LCK by RF Jenyu*/
+		if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
+			/* Delta temperature is equal to or larger than 20 centigrade.*/
+			if (delta_LCK >= c.threshold_iqk) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+				cali_info->thermal_value_lck = thermal_value;
+
+				/*Use RTLCK, so close power tracking driver LCK*/
+				if (!(dm->support_ic_type & ODM_RTL8814A) && !(dm->support_ic_type & ODM_RTL8822B) && c.phy_lc_calibrate)
+					(*c.phy_lc_calibrate)(dm);
+			}
+		}
+	}
+
+	/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
+
+	if (delta > 0 && cali_info->txpowertrack_control) {
+		/* "delta" here is used to record the absolute value of differrence. */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		delta = thermal_value > rtlefu->eeprom_thermalmeter ? (thermal_value - rtlefu->eeprom_thermalmeter) : (rtlefu->eeprom_thermalmeter - thermal_value);
+#else
+		delta = thermal_value > hal_data->eeprom_thermal_meter ? (thermal_value - hal_data->eeprom_thermal_meter) : (hal_data->eeprom_thermal_meter - thermal_value);
+#endif
+#else
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+#endif
+		if (delta >= TXPWR_TRACK_TABLE_SIZE)
+			delta = TXPWR_TRACK_TABLE_SIZE - 1;
+
+		/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		if (thermal_value > rtlefu->eeprom_thermalmeter) {
+#else
+		if (thermal_value > hal_data->eeprom_thermal_meter) {
+#endif
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_b[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_c[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_d[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
+				xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
+			}
+
+		} else {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_b[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_c[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_d[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
+				xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
+			}
+
+		}
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
+
+			if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p])         /*If Thermal value changes but lookup table value still the same*/
+				cali_info->power_index_offset[p] = 0;
+			else
+				cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p];      /*Power index diff between 2 times Power Tracking*/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
+
+			cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
+			cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
+
+			cali_info->bb_swing_idx_cck = cali_info->CCK_index;
+			cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
+
+			/*************Print BB Swing base and index Offset*************/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
+
+			/*4 7.1 Handle boundary conditions of index.*/
+
+			if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
+				cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
+			else if (cali_info->OFDM_index[p] <= OFDM_min_index)
+				cali_info->OFDM_index[p] = OFDM_min_index;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"\n\n========================================================================================================\n");
+
+		if (cali_info->CCK_index > c.swing_table_size_cck - 1)
+			cali_info->CCK_index = c.swing_table_size_cck - 1;
+		else if (cali_info->CCK_index <= 0)
+			cali_info->CCK_index = 0;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
+			cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->power_index_offset[p] = 0;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
+		cali_info->CCK_index, cali_info->bb_swing_idx_cck_base);       /*Print Swing base & current*/
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
+			cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
+	}
+
+	if ((dm->support_ic_type & ODM_RTL8814A)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "power_tracking_type=%d\n", power_tracking_type);
+
+		if (power_tracking_type == 0) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+		} else if (power_tracking_type == 1) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_2G_TSSI_5G_MODE, p, 0);
+		} else if (power_tracking_type == 2) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_5G_TSSI_2G_MODE, p, 0);
+		} else if (power_tracking_type == 3) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
+		}
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
+		cali_info->power_index_offset[RF_PATH_B] != 0 ||
+		cali_info->power_index_offset[RF_PATH_C] != 0 ||
+		cali_info->power_index_offset[RF_PATH_D] != 0) &&
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		cali_info->txpowertrack_control && (rtlefu->eeprom_thermalmeter != 0xff)) {
+#else
+		cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+#endif
+		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
+
+		cali_info->is_tx_power_changed = true;	/*Always true after Tx Power is adjusted by power tracking.*/
+		/*  */
+		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
+		/* to increase TX power. Otherwise, EVM will be bad. */
+		/*  */
+		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
+		if (thermal_value > cali_info->thermal_value) {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, rtlefu->eeprom_thermalmeter, cali_info->thermal_value);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+#endif
+			}
+		} else if (thermal_value < cali_info->thermal_value) {	/*Low temperature*/
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, rtlefu->eeprom_thermalmeter, cali_info->thermal_value);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+#endif
+			}
+		}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		if (thermal_value > rtlefu->eeprom_thermalmeter)
+#else
+		if (thermal_value > hal_data->eeprom_thermal_meter)
+#endif
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
+#endif
+		{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) higher than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+		} else {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) lower than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+
+		}
+
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
+
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	}
+
+
+	if (dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (rtlefu->eeprom_thermalmeter != 0xff)) {
+#else
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+#endif
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			if (thermal_value > rtlefu->eeprom_thermalmeter) {
+#else
+			if (thermal_value > hal_data->eeprom_thermal_meter) {
+#endif
+#else
+			if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) higher than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			} else {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) lower than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
+	}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	/* Wait sacn to do IQK by RF Jenyu*/
+	if ((*dm->is_scan_in_process == false)  && (!iqk_info->rfk_forbidden)) {
+		if (!IS_HARDWARE_TYPE_8723B(adapter)) {
+			/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
+			if (delta_IQK >= c.threshold_iqk) {
+				cali_info->thermal_value_iqk = thermal_value;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+				if (!cali_info->is_iqk_in_progress)
+					(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
+			}
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
+		if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
+		if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
+
+	cali_info->tx_powercount = 0;
+}
+
+
+
+/* 3============================================================
+ * 3 IQ Calibration
+ * 3============================================================ */
+
+void
+odm_reset_iqk_result(
+	void					*dm_void
+)
+{
+	return;
+}
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
+{
+	u8	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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
+	};
+	u8	place = chnl;
+
+
+	if (chnl > 14) {
+		for (place = 14; place < sizeof(channel_all); place++) {
+			if (channel_all[place] == chnl)
+				return place - 13;
+		}
+	}
+	return 0;
+
+}
+#endif
+
+void
+odm_iq_calibrate(
+	struct dm_struct	*dm
+)
+{
+	void	*adapter = dm->adapter;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (*dm->is_fcs_mode_enable)
+		return;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	if (IS_HARDWARE_TYPE_8812AU(adapter))
+		return;
+#endif
+
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		if ((*dm->channel != dm->pre_channel) && (!*dm->is_scan_in_process)) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
+		}
+
+		if (dm->linked_interval < 3)
+			dm->linked_interval++;
+
+		if (dm->linked_interval == 2)
+			halrf_iqk_trigger(dm, false);
+	} else
+		dm->linked_interval = 0;
+}
+
+void phydm_rf_init(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	odm_txpowertracking_init(dm);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_clear_txpowertracking_state(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
+#endif
+#endif
+
+}
+
+void phydm_rf_watchdog(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_txpowertracking_check(dm);
+	/*if (dm->support_ic_type & ODM_IC_11AC_SERIES)*/
+		/*odm_iq_calibrate(dm);*/
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ce.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ce.h
new file mode 100644
index 000000000000..a4a89386f423
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_ce.h
@@ -0,0 +1,124 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HAL_PHY_RF_H__
+#define __HAL_PHY_RF_H__
+
+#include "halrf/halrf_kfree.h"
+#if (RTL8814A_SUPPORT == 1)
+	#include "halrf/rtl8814a/halrf_iqk_8814a.h"
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#include "halrf/rtl8822b/halrf_iqk_8822b.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
+#endif
+
+#include "halrf/halrf_powertracking_ce.h"
+
+
+enum spur_cal_method {
+	PLL_RESET,
+	AFE_PHASE_SEL
+};
+
+enum pwrtrack_method {
+	BBSWING,
+	TXAGC,
+	MIX_MODE,
+	TSSI_MODE,
+	MIX_2G_TSSI_5G_MODE,
+	MIX_5G_TSSI_2G_MODE
+};
+
+typedef void	(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void(*func_iqk)(void *, u8, u8, u8);
+typedef void	(*func_lck)(void *);
+typedef void	(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void(*func_swing_xtal)(void *, s8 **, s8 **);
+typedef void(*func_set_xtal)(void *);
+
+struct txpwrtrack_cfg {
+	u8		swing_table_size_cck;
+	u8		swing_table_size_ofdm;
+	u8		threshold_iqk;
+	u8		threshold_dpk;
+	u8		average_thermal_num;
+	u8		rf_path_count;
+	u32		thermal_reg_addr;
+	func_set_pwr	odm_tx_pwr_track_set_pwr;
+	func_iqk	do_iqk;
+	func_lck		phy_lc_calibrate;
+	func_swing	get_delta_swing_table;
+	func_swing8814only	get_delta_swing_table8814only;
+	func_swing_xtal			get_delta_swing_xtal_table;
+	func_set_xtal			odm_txxtaltrack_set_xtal;
+};
+
+void
+configure_txpower_track(
+	void					*dm_void,
+	struct txpwrtrack_cfg	*config
+);
+
+
+void
+odm_clear_txpowertracking_state(
+	void					*dm_void
+);
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	void					*dm_void
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void	*dm
+#else
+	void	*adapter
+#endif
+);
+
+
+
+#define ODM_TARGET_CHNL_NUM_2G_5G	59
+
+
+void
+odm_reset_iqk_result(
+	void					*dm_void
+);
+u8
+odm_get_right_chnl_place_for_iqk(
+	u8 chnl
+);
+
+void phydm_rf_init(void					*dm_void);
+void phydm_rf_watchdog(void					*dm_void);
+
+#endif	/*  #ifndef __HAL_PHY_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_win.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_win.c
new file mode 100644
index 000000000000..bb4c00045b0e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_win.c
@@ -0,0 +1,817 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
+	do {\
+		for (_offset = 0; _offset < _size; _offset++) { \
+			\
+			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
+				\
+				if (_offset != 0)\
+					_offset--;\
+				break;\
+			} \
+		}			\
+		if (_offset >= _size)\
+			_offset = _size-1;\
+	} while (0)
+
+void configure_txpower_track(
+	struct dm_struct		*dm,
+	struct txpwrtrack_cfg	*config
+)
+{
+#if RTL8192E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192E)
+		configure_txpower_track_8192e(config);
+#endif
+#if RTL8821A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821)
+		configure_txpower_track_8821a(config);
+#endif
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
+#endif
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
+#endif
+
+#if RTL8188F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188F)
+		configure_txpower_track_8188f(config);
+#endif
+
+#if RTL8723B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723B)
+		configure_txpower_track_8723b(config);
+#endif
+
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
+#endif
+
+#if RTL8703B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8703B)
+		configure_txpower_track_8703b(config);
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
+#endif
+
+#if RTL8723D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723D)
+		configure_txpower_track_8723d(config);
+#endif
+
+/* JJ ADD 20161014 */
+#if RTL8710B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8710B)
+		configure_txpower_track_8710b(config);
+#endif
+
+#if RTL8821C_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821C)
+		configure_txpower_track_8821c(config);
+#endif
+
+}
+
+/* **********************************************************************
+ * <20121113, Kordan> This function should be called when tx_agc changed.
+ * Otherwise the previous compensation is gone, because we record the
+ * delta of temperature between two TxPowerTracking watch dogs.
+ *
+ * NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
+ * need to call this function.
+ * ********************************************************************** */
+void
+odm_clear_txpowertracking_state(
+	struct dm_struct		*dm
+)
+{
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA((PADAPTER)(dm->adapter));
+	u8			p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+	cali_info->CCK_index = 0;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+
+		cali_info->power_index_offset[p] = 0;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+
+		cali_info->absolute_ofdm_swing_idx[p] = 0;    /* Initial Mix mode power tracking*/
+		cali_info->remnant_ofdm_swing_idx[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+
+	cali_info->modify_tx_agc_flag_path_a = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_b = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_c = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_d = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->remnant_cck_swing_idx = 0;
+	cali_info->thermal_value = hal_data->eeprom_thermal_meter;
+
+	cali_info->modify_tx_agc_value_cck = 0;			/* modify by Mingzhi.Guo */
+	cali_info->modify_tx_agc_value_ofdm = 0;		/* modify by Mingzhi.Guo */
+
+}
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct		*dm
+#else
+	void	*adapter
+#endif
+)
+{
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct		*dm = &hal_data->odmpriv;
+#endif
+#endif
+
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+ 	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
+	s8			diff_DPK[4] = {0};
+	u8			thermal_value_avg_count = 0;
+	u32			thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
+
+	u8			OFDM_min_index = 0;  /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
+	u8			indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
+	u8			power_tracking_type = hal_data->RfPowerTrackingType;
+	u8			xtal_offset_eanble = 0;
+	s8			thermal_value_temp = 0;
+
+	struct txpwrtrack_cfg	c;
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	u8			*delta_swing_table_idx_tup_a = NULL;
+	u8			*delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL;
+	u8			*delta_swing_table_idx_tdown_b = NULL;
+	/*for 8814 add by Yu Chen*/
+	u8			*delta_swing_table_idx_tup_c = NULL;
+	u8			*delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL;
+	u8			*delta_swing_table_idx_tdown_d = NULL;
+	/*for Xtal Offset by James.Tung*/
+	s8			*delta_swing_table_xtal_up = NULL;
+	s8			*delta_swing_table_xtal_down = NULL;
+
+	/* 4 2. Initilization ( 7 steps in total ) */
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+
+	if (dm->support_ic_type & ODM_RTL8814A)	/*for 8814 path C & D*/
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B))	/*for Xtal Offset*/
+		(*c.get_delta_swing_xtal_table)(dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
+
+
+	cali_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
+	cali_info->is_txpowertracking_init = true;
+
+	/*cali_info->txpowertrack_control = hal_data->txpowertrack_control;
+	<Kordan> We should keep updating the control variable according to HalData.
+	<Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+	cali_info->rega24 = 0x090e1317;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	if (*(dm->mp_mode) == true)
+		cali_info->rega24 = 0x090e1317;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
+		cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"cali_info->txpowertrack_control=%d,  hal_data->eeprom_thermal_meter %d\n", cali_info->txpowertrack_control,  hal_data->eeprom_thermal_meter);
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+
+	thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"thermal_value_temp(%d) = thermal_value(%d) + power_time_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
+
+	if (thermal_value_temp > 63)
+		thermal_value = 63;
+	else if (thermal_value_temp < 0)
+		thermal_value = 0;
+	else
+		thermal_value = thermal_value_temp;
+
+	/*add log by zhao he, check c80/c94/c14/ca0 value*/
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+
+	if (!cali_info->txpowertrack_control)
+		return;
+
+	if (hal_data->eeprom_thermal_meter == 0xff) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", hal_data->eeprom_thermal_meter);
+		return;
+	}
+
+	/*4 3. Initialize ThermalValues of rf_calibrate_info*/
+
+	if (cali_info->is_reloadtxpowerindex)
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "reload ofdm index for band switch\n");
+
+	/*4 4. Calculate average thermal meter*/
+
+	cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
+	cali_info->thermal_value_avg_index++;
+	if (cali_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		cali_info->thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (cali_info->thermal_value_avg[i]) {
+			thermal_value_avg += cali_info->thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+		cali_info->thermal_value_delta = thermal_value - hal_data->eeprom_thermal_meter;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, hal_data->eeprom_thermal_meter);
+	}
+
+	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
+
+	/* "delta" here is used to determine whether thermal value changes or not. */
+	delta	= (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
+	delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+
+	if (cali_info->thermal_value_iqk == 0xff) {	/*no PG, use thermal value for IQK*/
+		cali_info->thermal_value_iqk = thermal_value;
+		delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, use thermal_value for IQK\n");
+	}
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++)
+		diff_DPK[p] = (s8)thermal_value - (s8)cali_info->dpk_thermal[p];
+
+	/*4 6. If necessary, do LCK.*/
+
+	if (!(dm->support_ic_type & ODM_RTL8821)) {	/*no PG, do LCK at initial status*/
+		if (cali_info->thermal_value_lck == 0xff) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, do LCK\n");
+			cali_info->thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, so close power tracking driver LCK*/
+			if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
+				if (c.phy_lc_calibrate)
+					(*c.phy_lc_calibrate)(dm);
+			}
+
+			delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
+
+		/* Wait sacn to do LCK by RF Jenyu*/
+		if( (*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
+			/* Delta temperature is equal to or larger than 20 centigrade.*/
+			if (delta_LCK >= c.threshold_iqk) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+				cali_info->thermal_value_lck = thermal_value;
+
+				/*Use RTLCK, so close power tracking driver LCK*/
+				if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
+					if (c.phy_lc_calibrate)
+						(*c.phy_lc_calibrate)(dm);
+				}
+			}
+		}
+	}
+
+	/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
+
+	if (delta > 0 && cali_info->txpowertrack_control) {
+		/* "delta" here is used to record the absolute value of differrence. */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		delta = thermal_value > hal_data->eeprom_thermal_meter ? (thermal_value - hal_data->eeprom_thermal_meter) : (hal_data->eeprom_thermal_meter - thermal_value);
+#else
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+#endif
+		if (delta >= TXPWR_TRACK_TABLE_SIZE)
+			delta = TXPWR_TRACK_TABLE_SIZE - 1;
+
+		/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		if (thermal_value > hal_data->eeprom_thermal_meter) {
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_b[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_c[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_d[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
+
+				if (cali_info->xtal_offset_last == cali_info->xtal_offset)
+					xtal_offset_eanble = 0;
+				else
+					xtal_offset_eanble = 1;
+			}
+
+		} else {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_b[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_c[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_d[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
+
+				if (cali_info->xtal_offset_last == cali_info->xtal_offset)
+					xtal_offset_eanble = 0;
+				else
+					xtal_offset_eanble = 1;
+			}
+
+		}
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
+
+			if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p])         /*If Thermal value changes but lookup table value still the same*/
+				cali_info->power_index_offset[p] = 0;
+			else
+				cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p];      /*Power index diff between 2 times Power Tracking*/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
+
+			cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
+			cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
+
+			cali_info->bb_swing_idx_cck = cali_info->CCK_index;
+			cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
+
+			/*************Print BB Swing base and index Offset*************/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
+
+			/*4 7.1 Handle boundary conditions of index.*/
+
+			if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
+				cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
+			else if (cali_info->OFDM_index[p] <= OFDM_min_index)
+				cali_info->OFDM_index[p] = OFDM_min_index;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"\n\n========================================================================================================\n");
+
+		if (cali_info->CCK_index > c.swing_table_size_cck - 1)
+			cali_info->CCK_index = c.swing_table_size_cck - 1;
+		else if (cali_info->CCK_index <= 0)
+			cali_info->CCK_index = 0;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
+			cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->power_index_offset[p] = 0;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
+		cali_info->CCK_index, cali_info->bb_swing_idx_cck_base);       /*Print Swing base & current*/
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
+			cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
+	}
+
+	if ((dm->support_ic_type & ODM_RTL8814A)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "power_tracking_type=%d\n", power_tracking_type);
+
+		if (power_tracking_type == 0) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+		} else if (power_tracking_type == 1) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_2G_TSSI_5G_MODE, p, 0);
+		} else if (power_tracking_type == 2) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_5G_TSSI_2G_MODE, p, 0);
+		} else if (power_tracking_type == 3) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
+		}
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
+		cali_info->power_index_offset[RF_PATH_B] != 0 ||
+		cali_info->power_index_offset[RF_PATH_C] != 0 ||
+		cali_info->power_index_offset[RF_PATH_D] != 0) &&
+		cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
+
+		cali_info->is_tx_power_changed = true;	/*Always true after Tx Power is adjusted by power tracking.*/
+		/*  */
+		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
+		/* to increase TX power. Otherwise, EVM will be bad. */
+		/*  */
+		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
+		if (thermal_value > cali_info->thermal_value) {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+			}
+		} else if (thermal_value < cali_info->thermal_value) {	/*Low temperature*/
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+			}
+		}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+		if (thermal_value > hal_data->eeprom_thermal_meter)
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
+#endif
+		{
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+		} else {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+
+		}
+
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
+
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	}
+
+
+	if (dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+			if (thermal_value > hal_data->eeprom_thermal_meter) {
+#else
+			if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
+	}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	/* Wait sacn to do IQK by RF Jenyu*/
+	if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
+		if (!IS_HARDWARE_TYPE_8723B(adapter)) {
+			/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
+			if (delta_IQK >= c.threshold_iqk) {
+				cali_info->thermal_value_iqk = thermal_value;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+				if (!cali_info->is_iqk_in_progress)
+					(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
+			}
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
+		if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
+		if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
+
+	cali_info->tx_powercount = 0;
+}
+
+
+
+/* 3============================================================
+ * 3 IQ Calibration
+ * 3============================================================ */
+
+void
+odm_reset_iqk_result(
+	struct dm_struct	*dm
+)
+{
+	return;
+}
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
+{
+	u8	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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
+	};
+	u8	place = chnl;
+
+
+	if (chnl > 14) {
+		for (place = 14; place < sizeof(channel_all); place++) {
+			if (channel_all[place] == chnl)
+				return place - 13;
+		}
+	}
+	return 0;
+
+}
+#endif
+
+void
+odm_iq_calibrate(
+	struct dm_struct	*dm
+)
+{
+	void	*adapter = dm->adapter;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	
+	RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("=>%s\n" , __FUNCTION__));
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (*dm->is_fcs_mode_enable)
+		return;
+#endif
+
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("interval=%d ch=%d prech=%d scan=%s\n", dm->linked_interval,
+			*dm->channel,  dm->pre_channel, *dm->is_scan_in_process == TRUE ? "TRUE":"FALSE"));
+
+		if (*dm->channel != dm->pre_channel) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
+		}
+
+		if ((dm->linked_interval < 3) && (!*dm->is_scan_in_process))
+			dm->linked_interval++;
+
+		if (dm->linked_interval == 2)
+			PHY_IQCalibrate((PADAPTER)adapter, false);
+	} else
+		dm->linked_interval = 0;
+
+		RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("<=%s interval=%d ch=%d prech=%d scan=%s\n", __FUNCTION__, dm->linked_interval,
+			*dm->channel,  dm->pre_channel, *dm->is_scan_in_process == TRUE?"TRUE":"FALSE"));
+}
+
+void phydm_rf_init(struct dm_struct		*dm)
+{
+
+	odm_txpowertracking_init(dm);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_clear_txpowertracking_state(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
+#endif
+#endif
+
+}
+
+void phydm_rf_watchdog(struct dm_struct		*dm)
+{
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_txpowertracking_check(dm);
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_iq_calibrate(dm);
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_win.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_win.h
new file mode 100644
index 000000000000..0d36a7517b0d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halphyrf_win.h
@@ -0,0 +1,135 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PHY_RF_H__
+#define __HAL_PHY_RF_H__
+
+#if (RTL8814A_SUPPORT == 1)
+    #if RT_PLATFORM == PLATFORM_MACOSX
+        #include "rtl8814a/halrf_iqk_8814a.h"
+    #else
+        #include "halrf/rtl8814a/halrf_iqk_8814a.h"
+    #endif
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+    #if RT_PLATFORM == PLATFORM_MACOSX
+        #include "rtl8822b/halrf_iqk_8822b.h"
+        #include "../../MAC/Halmac_type.h"
+    #else
+        #include "halrf/rtl8822b/halrf_iqk_8822b.h"
+        #include "../mac/Halmac_type.h"
+    #endif
+#endif
+
+#if RT_PLATFORM == PLATFORM_MACOSX
+    #include "halrf_powertracking_win.h"
+    #include "halrf_kfree.h"
+    #include "halrf_txgapcal.h"
+#else
+    #include "halrf/halrf_powertracking_win.h"
+    #include "halrf/halrf_kfree.h"
+    #include "halrf/halrf_txgapcal.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+    #if RT_PLATFORM == PLATFORM_MACOSX
+        #include "rtl8821c/halrf_iqk_8821c.h"
+    #else
+        #include "halrf/rtl8821c/halrf_iqk_8821c.h"
+    #endif
+#endif
+
+enum spur_cal_method {
+	PLL_RESET,
+	AFE_PHASE_SEL
+};
+
+enum pwrtrack_method {
+	BBSWING,
+	TXAGC,
+	MIX_MODE,
+	TSSI_MODE,
+	MIX_2G_TSSI_5G_MODE,
+	MIX_5G_TSSI_2G_MODE
+};
+
+typedef void(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void(*func_iqk)(void *, u8, u8, u8);
+typedef void(*func_lck)(void *);
+typedef void(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void (*func_swing_xtal)(void *, s8 **, s8 **);
+typedef void (*func_set_xtal)(void *);
+typedef void(*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
+
+struct txpwrtrack_cfg {
+	u8		swing_table_size_cck;
+	u8		swing_table_size_ofdm;
+	u8		threshold_iqk;
+	u8		threshold_dpk;
+	u8		average_thermal_num;
+	u8		rf_path_count;
+	u32		thermal_reg_addr;
+	func_set_pwr	odm_tx_pwr_track_set_pwr;
+	func_iqk	do_iqk;
+	func_lck		phy_lc_calibrate;
+	func_swing	get_delta_swing_table;
+	func_swing8814only	get_delta_swing_table8814only;
+	func_swing_xtal			get_delta_swing_xtal_table;
+	func_set_xtal			odm_txxtaltrack_set_xtal;
+	func_all_swing	get_delta_all_swing_table;
+};
+
+void
+configure_txpower_track(
+	struct dm_struct		*dm,
+	struct txpwrtrack_cfg	*config
+);
+
+
+void
+odm_clear_txpowertracking_state(
+	struct dm_struct		*dm
+);
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct		*dm
+#else
+	void	*adapter
+#endif
+);
+
+
+
+#define ODM_TARGET_CHNL_NUM_2G_5G	59
+
+
+void
+odm_reset_iqk_result(
+	struct dm_struct	*dm
+);
+u8
+odm_get_right_chnl_place_for_iqk(
+	u8 chnl
+);
+
+void odm_iq_calibrate(struct dm_struct	*dm);
+void phydm_rf_init(struct dm_struct		*dm);
+void phydm_rf_watchdog(struct dm_struct		*dm);
+
+#endif	/*  #ifndef __HAL_PHY_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf.c
new file mode 100644
index 000000000000..97600143526f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf.c
@@ -0,0 +1,1575 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void halrf_basic_profile(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/* HAL RF version List */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "% HAL RF version %");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Power Tracking",
+		       HALRF_POWRTRACKING_VER);
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s %s\n", "IQK",
+					(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD)? "FW" : HALRF_IQK_VER,
+					(halrf_match_iqk_version(dm_void))? "(match)" : "(mismatch)");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "LCK", HALRF_LCK_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "DPK", HALRF_DPK_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "KFREE", HALRF_KFREE_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "TX 2G Current Calibration",
+		       HALRF_PABIASK_VER);
+
+	*_used = used;
+	*_out_len = out_len;
+#endif
+}
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void
+_iqk_page_switch(
+		void			*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (dm->support_ic_type == ODM_RTL8821C)	
+		odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	else	
+		odm_write_4byte(dm, 0x1b00, 0xf800000a);
+}
+
+u32 halrf_psd_log2base(u32 val)
+{
+	u8	j;
+	u32	tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
+	u32	result, val_fractiond_b = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
+				   174, 151, 132, 115, 100, 86, 74, 62, 51, 42,
+							   32, 23, 15, 7, 0
+							      };
+
+	if (val == 0)
+		return 0;
+
+	tmp = val;
+
+	while (1) {
+		if (tmp == 1)
+			break;
+
+		tmp = (tmp >> 1);
+		shiftcount++;
+	}
+
+
+	val_integerd_b = shiftcount + 1;
+
+	tmp2 = 1;
+	for (j = 1; j <= val_integerd_b; j++)
+		tmp2 = tmp2 * 2;
+
+	tmp = (val * 100) / tmp2;
+	tindex = tmp / 5;
+
+	if (tindex > 20)
+		tindex = 20;
+
+	val_fractiond_b = table_fraction[tindex];
+
+	result = val_integerd_b * 100 - val_fractiond_b;
+	
+	return result;
+
+
+}
+
+void phydm_get_iqk_cfir(
+	void *dm_void,
+	u8 idx,
+	u8 path,
+	boolean debug
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	
+	u8 i, ch;
+	u32 tmp;
+
+	if (debug)
+		ch = 2;
+	else
+		ch = 0;
+	odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+	if (idx == 0)
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+	else
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
+	odm_set_bb_reg(dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+	for (i = 0; i < 8; i++) {
+		odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0xe0000001 + (i * 4));
+		tmp = odm_get_bb_reg(dm, 0x1bfc, MASKDWORD);
+		iqk_info->iqk_cfir_real[ch][path][idx][i] = (tmp & 0x0fff0000) >> 16;
+		iqk_info->iqk_cfir_imag[ch][path][idx][i] = tmp & 0xfff;
+	}
+	odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0x0);
+	odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+}
+
+void
+halrf_iqk_xym_enable(
+	struct dm_struct *dm,
+	u8 xym_enable
+	)
+{
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+
+	if (xym_enable == 0)
+		iqk_info->xym_read = false;
+	else
+		iqk_info->xym_read = true;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %s\n", "xym_read = ", (iqk_info->xym_read ? "true": "false"));	
+}
+
+void
+halrf_iqk_xym_read(
+	void *dm_void,
+	u8 path,
+	u8 xym_type /*0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
+ )
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;	
+	u8 i, start, num;
+	u32 tmp1, tmp2;
+
+	if (!iqk_info->xym_read)
+		return;
+
+	if (*dm->band_width == 0) {
+		start = 3;
+		num = 4;
+	}else if (*dm->band_width == 1) { 
+		start = 2;
+		num = 6;
+	}else {
+		start = 0;
+  		num = 10;
+ 	}
+	
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+ 	tmp1 =  odm_read_4byte(dm, 0x1b1c);
+	odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
+
+ 	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+ 	tmp2 =  odm_read_4byte(dm, 0x1b1c);
+	odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
+
+	for (path = 0; path < 2; path ++) {
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		switch(xym_type){
+ 			case 0:
+				for (i = 0; i < num ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe6+start+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->rx_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+				}
+			break;
+			case 1:		
+				for (i = 0; i < num ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe6+start+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->tx_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+				}
+			break;
+			case 2:		
+				for (i = 0; i < 6 ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe0+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->gs1_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+				}
+			break;
+			case 3:		
+				for (i = 0; i < 6 ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe0+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->gs2_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+	  		}
+			break;			
+			case 4:		
+				for (i = 0; i < 6 ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe0+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->rxk1_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+	  		}
+			break;
+
+		}
+		odm_write_4byte(dm, 0x1b38, 0x20000000);
+		odm_write_4byte(dm, 0x1b00, 0xf8000008);
+		odm_write_4byte(dm, 0x1b1c, tmp1);
+		odm_write_4byte(dm, 0x1b00, 0xf800000a);
+		odm_write_4byte(dm, 0x1b1c, tmp2);
+		_iqk_page_switch(dm);
+	}
+}
+
+void halrf_iqk_xym_show(
+	struct dm_struct *dm,
+	u8 xym_type /*0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
+ )
+{
+	u8 num, path, path_num, i;		
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;	
+
+	if (dm->rf_type ==RF_1T1R)
+		path_num = 0x1;
+	else if (dm->rf_type ==RF_2T2R)
+		path_num = 0x2;
+	else
+		path_num = 0x4;
+
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		num = 4;
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		num = 6;
+	else
+		num = 10;
+		
+	for (path = 0; path < path_num; path ++) {
+		switch (xym_type){
+		case 0:
+			for (i = 0 ; i < num; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A RX-XYM ": "PATH B RX-XYM", i, iqk_info->rx_xym[path][i]);
+			break;
+		case 1:
+			for (i = 0 ; i < num; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A TX-XYM ": "PATH B TX-XYM", i, iqk_info->tx_xym[path][i]);
+			break;
+		case 2:
+			for (i = 0 ; i < 6; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A GS1-XYM ": "PATH B GS1-XYM", i, iqk_info->gs1_xym[path][i]);
+			break;
+		case 3:
+			for (i = 0 ; i < 6; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A GS2-XYM ": "PATH B GS2-XYM", i, iqk_info->gs2_xym[path][i]);
+			break;
+		case 4:			
+			for (i = 0 ; i < 6; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A RXK1-XYM ": "PATH B RXK1-XYM", i, iqk_info->rxk1_xym[path][i]);
+			break;
+		}
+	}
+}
+
+
+void
+halrf_iqk_xym_dump(
+	void *dm_void
+ )
+{
+	u32 tmp1, tmp2;
+ 	struct dm_struct	 *dm = (struct dm_struct *)dm_void;
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+ 	tmp1 =  odm_read_4byte(dm, 0x1b1c);
+ 	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+ 	tmp2 =  odm_read_4byte(dm, 0x1b1c);
+ 	/*halrf_iqk_xym_read(dm, xym_type);*/
+ 	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+ 	odm_write_4byte(dm, 0x1b1c, tmp1);
+ 	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+ 	odm_write_4byte(dm, 0x1b1c, tmp2);
+ 	_iqk_page_switch(dm);
+}
+
+void halrf_iqk_info_dump(
+	void *dm_void,
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;	
+	u8 path, num, i;
+
+	u8 rf_path, j, reload_iqk = 0;
+	u32 tmp;
+	boolean iqk_result[2][NUM][2];	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	/* IQK INFO */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s\n", "% IQK Info %");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s\n",
+		       (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" : "Driver-IQK");	
+
+	reload_iqk = (u8)odm_get_bb_reg(dm, 0x1bf0, BIT(16));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s: %s\n",
+		       "reload", (reload_iqk) ? "True" : "False");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s: %s\n",
+			"rfk_forbidden", (iqk_info->rfk_forbidden) ? "True" : "False");
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s: %s\n",
+			"segment_iqk", (iqk_info->segment_iqk) ? "True" : "False");
+#endif
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s:%d %d\n",
+			"iqk count / fail count", dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s: %d\n",
+			"channel", *dm->channel);
+
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_20");
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_40");
+	else if (*dm->band_width == CHANNEL_WIDTH_80)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_80");
+	else if (*dm->band_width == CHANNEL_WIDTH_160)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_160");
+	else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_UNKNOW");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
+		
+	tmp = odm_read_4byte(dm, 0x1bf0);
+	for(rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
+		for(j = 0; j < 2; j++)
+			iqk_result[0][rf_path][j] = (boolean)(tmp & BIT(rf_path + (j * 4)) >> (rf_path + (j * 4)));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s: 0x%08x\n","Reg0x1bf0", tmp);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_A-Tx result", (iqk_result[0][RF_PATH_A][0]) ?  "Fail" : "Pass");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_A-Rx result", (iqk_result[0][RF_PATH_A][1]) ?  "Fail" : "Pass");
+#if (RTL8822B_SUPPORT == 1) 
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_B-Tx result", (iqk_result[0][RF_PATH_B][0]) ?  "Fail" : "Pass");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_B-Rx result", (iqk_result[0][RF_PATH_B][1]) ?  "Fail" : "Pass");
+#endif
+	*_used = used;
+	*_out_len = out_len;
+
+}
+
+void halrf_get_fw_version(void	*dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	{
+		void		*adapter = dm->adapter;
+
+		rf->fw_ver = (((PADAPTER)adapter)->MgntInfo.FirmwareVersion << 16) | ((PADAPTER)adapter)->MgntInfo.FirmwareSubVersion;
+	}
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	{
+		struct rtl8192cd_priv *priv = dm->priv;
+
+		rf->fw_ver = (priv->pshare->fw_version << 16) | priv->pshare->fw_sub_version;
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	{
+		struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+		struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
+
+		rf->fw_ver = (rtlhal->fw_version << 16) | rtlhal->fw_subversion;
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE		*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+		rf->fw_ver = (hal_data->firmware_version << 16) | hal_data->firmware_sub_version;
+	}
+#endif
+}
+
+
+
+void halrf_iqk_dbg(void	*dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rf_path, j, reload_iqk = 0;
+	u8 path, num, i;
+	u32 tmp;
+	boolean iqk_result[2][NUM][2];	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	/* IQK INFO */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n", "====== IQK Info ======");
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n",
+		(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" : "Driver-IQK");
+
+	if (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) {
+		halrf_get_fw_version(dm);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: 0x%x\n",
+			"FW_VER", rf->fw_ver);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+			"IQK_VER", HALRF_IQK_VER);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"%-20s: %s\n",
+		"reload", (iqk_info->is_reload) ? "True" : "False");
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %d %d\n",
+			"iqk count / fail count", dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %d\n",
+			"channel", *dm->channel);
+
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_20");
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_40");
+	else if (*dm->band_width == CHANNEL_WIDTH_80)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_80");
+	else if (*dm->band_width == CHANNEL_WIDTH_160)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_160");
+	else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_UNKNOW");
+/*
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
+*/
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"rfk_forbidden", (iqk_info->rfk_forbidden) ? "True" : "False");
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"segment_iqk", (iqk_info->segment_iqk) ? "True" : "False");
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.iqk_progressing_time, "(ms)");
+
+	
+
+
+	tmp = odm_read_4byte(dm, 0x1bf0);
+	for(rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
+		for(j = 0; j < 2; j++)
+			iqk_result[0][rf_path][j] = (boolean)(tmp & BIT(rf_path + (j * 4)) >> (rf_path + (j * 4)));
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: 0x%08x\n", "Reg0x1bf0", tmp);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: 0x%08x\n", "Reg0x1be8", odm_read_4byte(dm, 0x1be8));
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"PATH_A-Tx result", (iqk_result[0][RF_PATH_A][0]) ?  "Fail" : "Pass");
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"PATH_A-Rx result", (iqk_result[0][RF_PATH_A][1]) ?  "Fail" : "Pass");
+#if (RTL8822B_SUPPORT == 1) 
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",		
+				"PATH_B-Tx result", (iqk_result[0][RF_PATH_B][0]) ?  "Fail" : "Pass");
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"PATH_B-Rx result", (iqk_result[0][RF_PATH_B][1]) ?  "Fail" : "Pass");
+#endif
+
+
+}
+void halrf_lck_dbg(struct dm_struct *dm)
+{
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n", "====== LCK Info ======");
+	/*PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n",
+		(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "LCK" : "RTK"));*/
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.lck_progressing_time, "(ms)");
+}
+
+void
+halrf_iqk_dbg_cfir_backup(struct dm_struct *dm)
+{
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	u8	path, idx, i;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "backup TX/RX CFIR");	
+
+	for (path = 0; path < 2; path ++) {
+		for (idx = 0; idx < 2; idx++) {
+			phydm_get_iqk_cfir(dm, idx, path, true);
+		}
+	}
+
+	for (path = 0; path < 2; path ++) {
+		for (idx = 0; idx < 2; idx++) {
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-7s %-3s CFIR_real: %-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_real[2][path][idx][i]);
+			}
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-7s %-3s CFIR_img:%-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_imag[2][path][idx][i]);
+			}
+		}
+	}
+}
+
+
+void
+halrf_iqk_dbg_cfir_backup_update(
+	struct dm_struct			*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8 i, path, idx;
+
+	if(iqk_info->iqk_cfir_real[2][0][0][0] == 0) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "CFIR is invalid");
+		return;
+	}
+	for (path = 0; path < 2; path++) {
+		for (idx = 0; idx < 2; idx++) {
+			odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+			odm_set_bb_reg(dm, 0x1b2c, MASKDWORD, 0x7);
+			odm_set_bb_reg(dm, 0x1b38, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1b3c, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1bcc, MASKDWORD, 0x00000000);
+			if (idx == 0)
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+			else
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
+			odm_set_bb_reg(dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+			for (i = 0; i < 8; i++) {
+				odm_write_4byte(dm, 0x1bd8,	((0xc0000000 >> idx) + 0x3) + (i * 4) + (iqk_info->iqk_cfir_real[2][path][idx][i] << 9));
+				odm_write_4byte(dm, 0x1bd8, ((0xc0000000 >> idx) + 0x1) + (i * 4) + (iqk_info->iqk_cfir_imag[2][path][idx][i] << 9));
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_real[2][path][idx][i]);*/
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_imag[2][path][idx][i]);*/
+			}
+		}
+		odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0x0);
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "update new CFIR");
+}
+
+
+void
+halrf_iqk_dbg_cfir_reload(
+	struct dm_struct			*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8 i, path, idx;
+
+	if(iqk_info->iqk_cfir_real[0][0][0][0] == 0) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "CFIR is invalid");
+		return;
+	}
+	for (path = 0; path < 2; path++) {
+		for (idx = 0; idx < 2; idx++) {
+			odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+			odm_set_bb_reg(dm, 0x1b2c, MASKDWORD, 0x7);
+			odm_set_bb_reg(dm, 0x1b38, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1b3c, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1bcc, MASKDWORD, 0x00000000);
+			if (idx == 0)
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+			else
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
+			odm_set_bb_reg(dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+			for (i = 0; i < 8; i++) {
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_real[0][path][idx][i]);*/
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_imag[0][path][idx][i]);*/
+				odm_write_4byte(dm, 0x1bd8,	((0xc0000000 >> idx) + 0x3) + (i * 4) + (iqk_info->iqk_cfir_real[0][path][idx][i] << 9));
+				odm_write_4byte(dm, 0x1bd8, ((0xc0000000 >> idx) + 0x1) + (i * 4) + (iqk_info->iqk_cfir_imag[0][path][idx][i] << 9));
+			}
+		}
+		odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0x0);
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "write CFIR with default value");
+}
+
+void
+halrf_iqk_dbg_cfir_write(
+	struct dm_struct			*dm,
+	u8	type,
+	u32 path,
+	u32 idx,
+	u32 i,
+	u32 data
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	if (type == 0)
+		iqk_info->iqk_cfir_real[2][path][idx][i] = data;
+	else
+		iqk_info->iqk_cfir_imag[2][path][idx][i] = data;
+}
+
+void
+halrf_iqk_dbg_cfir_backup_show(struct dm_struct *dm)
+{
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	u8	path, idx, i;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "backup TX/RX CFIR");	
+
+	for (path = 0; path < 2; path ++) {
+		for (idx = 0; idx < 2; idx++) {
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-10s %-3s CFIR_real: %-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_real[2][path][idx][i]);
+			}
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-10s %-3s CFIR_img:%-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_imag[2][path][idx][i]);
+			}
+		}
+	}
+}
+
+void
+halrf_do_imr_test(
+	void	*dm_void,
+	u8  flag_imr_test
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (flag_imr_test != 0x0)
+		switch (dm->support_ic_type) {
+#if (RTL8822B_SUPPORT == 1)
+		case ODM_RTL8822B:
+			do_imr_test_8822b(dm);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
+		case ODM_RTL8821C:
+			do_imr_test_8821c(dm);
+			break;
+#endif
+		default:
+		break;
+		}
+}
+
+void halrf_iqk_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	
+	/*dm_value[0]=0x0: backup from SRAM & show*/
+	/*dm_value[0]=0x1: write backup CFIR to SRAM*/
+	/*dm_value[0]=0x2: reload default CFIR to SRAM*/
+	/*dm_value[0]=0x3: show backup*/
+	/*dm_value[0]=0x10: write backup CFIR real part*/
+	/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/
+	/*dm_value[0]=0x11: write backup CFIR imag*/
+	/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/	
+	/*dm_value[0]=0x20 :xym_read enable*/
+	/*--> dm_value[1]:0:disable, 1:enable*/ 
+	/*if dm_value[0]=0x20 = enable, */
+	/*0x1:show rx_sym; 0x2: tx_xym; 0x3:gs1_xym; 0x4:gs2_sym; 0x5:rxk1_xym*/
+
+	if (dm_value[0] == 0x0)
+		halrf_iqk_dbg_cfir_backup(dm);
+	else if (dm_value[0] == 0x1)
+		halrf_iqk_dbg_cfir_backup_update(dm);
+	else if (dm_value[0] == 0x2)
+		halrf_iqk_dbg_cfir_reload(dm);
+	else if (dm_value[0] == 0x3)
+		halrf_iqk_dbg_cfir_backup_show(dm);
+	else if (dm_value[0] == 0x10)
+		halrf_iqk_dbg_cfir_write(dm, 0, dm_value[1], dm_value[2], dm_value[3], dm_value[4]);
+	else if (dm_value[0] == 0x11)
+		halrf_iqk_dbg_cfir_write(dm, 1, dm_value[1], dm_value[2], dm_value[3], dm_value[4]);
+	else if (dm_value[0] == 0x20)
+		halrf_iqk_xym_enable(dm, (u8)dm_value[1]);
+	else if (dm_value[0] == 0x21)
+		halrf_iqk_xym_show(dm,(u8)dm_value[1]);
+	else if (dm_value[0] == 0x30)
+		halrf_do_imr_test(dm, (u8)dm_value[1]);
+}
+
+void
+halrf_iqk_hwtx_check(
+	void *dm_void,
+	boolean		is_check
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u32 tmp_b04;
+
+	if (is_check)
+		iqk_info->is_hwtx = (boolean)odm_get_bb_reg(dm, 0xb00, BIT(8));
+	else {
+		if (iqk_info->is_hwtx) {
+			tmp_b04 = odm_read_4byte(dm, 0xb04);
+			odm_set_bb_reg(dm, 0xb04, BIT(3) | BIT (2), 0x0);
+			odm_write_4byte(dm, 0xb04, tmp_b04);
+		}
+	}
+}
+
+void
+halrf_segment_iqk_trigger(
+	void			*dm_void,
+	boolean		clear,
+	boolean		segment_iqk
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info		*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64 start_time;
+	
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if (odm_check_power_status(dm) == false)
+		return;
+#endif
+
+	if ((dm->mp_mode != NULL) && (rf->is_con_tx != NULL) && (rf->is_single_tone != NULL) && (rf->is_carrier_suppresion != NULL))
+		if (*dm->mp_mode && ((*rf->is_con_tx || *rf->is_single_tone || *rf->is_carrier_suppresion)))
+			return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (!(rf->rf_supportability & HAL_RF_IQK))
+		return;
+#endif
+
+#if DISABLE_BB_RF
+	return;
+#endif
+	if (iqk_info->rfk_forbidden)
+		return;
+
+	if (!dm->rf_calibrate_info.is_iqk_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		dm->IQK_info.segment_iqk = segment_iqk;
+
+		switch (dm->support_ic_type) {
+#if (RTL8822B_SUPPORT == 1)
+		case ODM_RTL8822B:
+			phy_iq_calibrate_8822b(dm, clear, segment_iqk);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
+		case ODM_RTL8821C:
+			phy_iq_calibrate_8821c(dm, clear, segment_iqk);
+			break;
+#endif
+#if (RTL8814B_SUPPORT == 1)
+		case ODM_RTL8814B:
+			break;
+#endif
+		default:
+			break;
+		}
+		dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(dm, start_time);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]IQK progressing_time = %lld ms\n", dm->rf_calibrate_info.iqk_progressing_time);
+
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "== Return the IQK CMD, because RFKs in Progress ==\n");
+}
+
+
+
+#endif
+
+
+
+u8 halrf_match_iqk_version(void	*dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	u32 iqk_version = 0;
+	char temp[10] = {0};
+
+	odm_move_memory(dm, temp, (PVOID)(HALRF_IQK_VER), sizeof(temp));
+	PHYDM_SSCANF(temp + 2, DCMD_HEX, &iqk_version);
+	
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if ((iqk_version >= 0x24) && (odm_get_hw_img_version(dm) >= 72))
+			return 1;
+		else if ((iqk_version <= 0x23) && (odm_get_hw_img_version(dm) <= 71))
+			return 1;
+		else
+			return 0;
+	}
+
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if ((iqk_version >= 0x18) && (odm_get_hw_img_version(dm) >= 37))
+			return 1;
+		else
+			return 0;
+	}
+
+	return 1;
+}
+
+
+
+void
+halrf_rf_lna_setting(
+	void	*dm_void,
+	enum phydm_lna_set type
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_	 *rf = &dm->rf_table;
+
+		switch (dm->support_ic_type) {
+#if (RTL8188E_SUPPORT == 1)
+		case ODM_RTL8188E:
+			halrf_rf_lna_setting_8188e(dm, type);
+			break;
+#endif
+#if (RTL8192E_SUPPORT == 1)
+		case ODM_RTL8192E:
+			halrf_rf_lna_setting_8192e(dm, type);
+			break;
+#endif
+#if (RTL8723B_SUPPORT == 1)
+		case ODM_RTL8723B:
+			halrf_rf_lna_setting_8723b(dm, type);
+			break;
+#endif
+#if (RTL8812A_SUPPORT == 1)
+		case ODM_RTL8812:
+			halrf_rf_lna_setting_8812a(dm, type);
+			break;
+#endif
+#if ((RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1))
+		case ODM_RTL8881A:
+		case ODM_RTL8821:
+			halrf_rf_lna_setting_8821a(dm, type);
+			break;
+#endif
+#if (RTL8822B_SUPPORT == 1)
+		case ODM_RTL8822B:
+			halrf_rf_lna_setting_8822b(dm, type);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
+		case ODM_RTL8821C:
+			halrf_rf_lna_setting_8821c(dm, type);
+			break;
+#endif
+		default:
+			break;
+		}
+
+	}
+
+
+void
+halrf_support_ability_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u32	dm_value[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8	i;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+		}
+	}
+	
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%s\n",
+		       "================================");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[RF Supportability]\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))Power Tracking\n",
+			       ((rf->rf_supportability & HAL_RF_TX_PWR_TRACK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "01. (( %s ))IQK\n",
+			       ((rf->rf_supportability & HAL_RF_IQK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "02. (( %s ))LCK\n",
+			       ((rf->rf_supportability & HAL_RF_LCK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "03. (( %s ))DPK\n",
+			       ((rf->rf_supportability & HAL_RF_DPK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "04. (( %s ))HAL_RF_TXGAPK\n",
+			       ((rf->rf_supportability & HAL_RF_TXGAPK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");		
+	}
+	else {
+		if (dm_value[1] == 1) { /* enable */
+			rf->rf_supportability |= BIT(dm_value[0]) ;
+		} else if (dm_value[1] == 2) /* disable */
+			rf->rf_supportability &= ~(BIT(dm_value[0])) ;
+		else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "%s\n",
+				       "[Warning!!!]  1:enable,  2:disable");
+		}
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Curr-RF_supportability =  0x%x\n",
+		       rf->rf_supportability);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%s\n",
+		       "================================");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+halrf_cmn_info_init(
+	void		*dm_void,
+enum halrf_cmninfo_init	cmn_info,
+	u32			value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	switch	(cmn_info) {
+	case	HALRF_CMNINFO_EEPROM_THERMAL_VALUE:
+		rf->eeprom_thermal = (u8)value;
+		break;
+	case	HALRF_CMNINFO_FW_VER:
+		rf->fw_ver = (u32)value;
+		break;
+	default:
+		break;
+	}
+}
+
+
+void
+halrf_cmn_info_hook(
+	void		*dm_void,
+enum halrf_cmninfo_hook cmn_info,
+	void		*value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	
+	switch	(cmn_info) {
+	case	HALRF_CMNINFO_CON_TX:
+		rf->is_con_tx = (boolean *)value;
+		break;
+	case	HALRF_CMNINFO_SINGLE_TONE:
+		rf->is_single_tone = (boolean *)value;		
+		break;
+	case	HALRF_CMNINFO_CARRIER_SUPPRESSION:
+		rf->is_carrier_suppresion = (boolean *)value;		
+		break;
+	case	HALRF_CMNINFO_MP_RATE_INDEX:
+		rf->mp_rate_index = (u8 *)value;
+		break;
+	default:
+		/*do nothing*/
+		break;
+	}
+}
+
+void
+halrf_cmn_info_set(
+	void		*dm_void,
+	u32			cmn_info,
+	u64			value
+)
+{
+	/*  */
+	/* This init variable may be changed in run time. */
+	/*  */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	
+	switch	(cmn_info) {
+		case	HALRF_CMNINFO_ABILITY:
+			rf->rf_supportability = (u32)value;
+			break;
+
+		case	HALRF_CMNINFO_DPK_EN:
+			rf->dpk_en = (u8)value;
+			break;
+		case HALRF_CMNINFO_RFK_FORBIDDEN :
+			dm->IQK_info.rfk_forbidden = (boolean)value;
+			break;
+		#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		case HALRF_CMNINFO_IQK_SEGMENT:
+			dm->IQK_info.segment_iqk = (boolean)value;
+			break;
+		#endif
+		case HALRF_CMNINFO_RATE_INDEX:
+			rf->p_rate_index = (u32)value;
+			break;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		case	HALRF_CMNINFO_MP_PSD_POINT:
+			rf->halrf_psd_data.point = (u32)value;
+			break;
+		case	HALRF_CMNINFO_MP_PSD_START_POINT:
+			rf->halrf_psd_data.start_point = (u32)value;
+			break;
+		case	HALRF_CMNINFO_MP_PSD_STOP_POINT:
+			rf->halrf_psd_data.stop_point = (u32)value;
+			break;
+		case	HALRF_CMNINFO_MP_PSD_AVERAGE:
+			rf->halrf_psd_data.average = (u32)value;
+			break;
+#endif
+		default:
+			/* do nothing */
+			break;
+	}
+}
+
+u64
+halrf_cmn_info_get(
+	void		*dm_void,
+	u32			cmn_info
+)
+{
+	/*  */
+	/* This init variable may be changed in run time. */
+	/*  */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64	return_value = 0;
+	
+	switch	(cmn_info) {
+		case	HALRF_CMNINFO_ABILITY:
+			return_value = (u32)rf->rf_supportability;
+			break;
+		case HALRF_CMNINFO_RFK_FORBIDDEN :
+			return_value = dm->IQK_info.rfk_forbidden;
+			break;
+		#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		case HALRF_CMNINFO_IQK_SEGMENT:
+			return_value = dm->IQK_info.segment_iqk;
+			break;
+		#endif
+		default:
+			/* do nothing */
+			break;
+	}
+
+	return	return_value;
+}
+
+void
+halrf_supportability_init_mp(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	switch (dm->support_ic_type) {
+	case ODM_RTL8814B:
+		#if (RTL8814B_SUPPORT == 1) 
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		#endif
+		break;
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			/*HAL_RF_TXGAPK			|*/
+			0;
+		break;
+	#endif
+
+	default:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			/*HAL_RF_TXGAPK			|*/
+			0;
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "IC = ((0x%x)), RF_Supportability Init MP = ((0x%x))\n", dm->support_ic_type, rf->rf_supportability);
+}
+
+void
+halrf_supportability_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	switch (dm->support_ic_type) {
+	case ODM_RTL8814B:
+		#if (RTL8814B_SUPPORT == 1) 
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		#endif
+		break;
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/		
+			/*HAL_RF_TXGAPK				|*/
+			0;
+		break;
+	#endif
+
+	default:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "IC = ((0x%x)), RF_Supportability Init = ((0x%x))\n", dm->support_ic_type, rf->rf_supportability);
+}
+
+void
+halrf_watchdog(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	phydm_rf_watchdog(dm);
+}
+#if 0
+void
+halrf_iqk_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+
+	switch (dm->support_ic_type) {
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		break;
+	#endif
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		_iq_calibrate_8822b_init(dm);
+		break;
+	#endif
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		break;
+	#endif
+
+	default:
+		break;
+	}
+}
+#endif
+
+
+void
+halrf_iqk_trigger(
+	void			*dm_void,
+	boolean		is_recovery
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info		*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64 start_time;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if (odm_check_power_status(dm) == false)
+		return;
+#endif
+
+	if ((dm->mp_mode != NULL) && (rf->is_con_tx != NULL) && (rf->is_single_tone != NULL) && (rf->is_carrier_suppresion != NULL))
+		if (*dm->mp_mode && ((*rf->is_con_tx || *rf->is_single_tone || *rf->is_carrier_suppresion)))
+			return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (!(rf->rf_supportability & HAL_RF_IQK))
+		return;
+#endif
+
+#if DISABLE_BB_RF
+	return;
+#endif
+
+	if (iqk_info->rfk_forbidden)
+		return;
+
+	if (!dm->rf_calibrate_info.is_iqk_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		switch (dm->support_ic_type) {
+#if (RTL8188E_SUPPORT == 1) 
+		case ODM_RTL8188E:
+			phy_iq_calibrate_8188e(dm, is_recovery);
+			break;
+#endif
+#if (RTL8188F_SUPPORT == 1) 
+		case ODM_RTL8188F:
+			phy_iq_calibrate_8188f(dm, is_recovery);
+			break;
+#endif
+#if (RTL8192E_SUPPORT == 1) 
+		case ODM_RTL8192E:
+			phy_iq_calibrate_8192e(dm, is_recovery);
+			break;
+#endif
+#if (RTL8197F_SUPPORT == 1) 
+		case ODM_RTL8197F:
+			phy_iq_calibrate_8197f(dm, is_recovery);
+			break;
+#endif
+#if (RTL8703B_SUPPORT == 1) 
+		case ODM_RTL8703B:
+			phy_iq_calibrate_8703b(dm, is_recovery);
+			break;
+#endif
+#if (RTL8710B_SUPPORT == 1) 
+		case ODM_RTL8710B:
+			phy_iq_calibrate_8710b(dm, is_recovery);
+			break;
+#endif
+#if (RTL8723B_SUPPORT == 1) 
+		case ODM_RTL8723B:
+			phy_iq_calibrate_8723b(dm, is_recovery);
+			break;
+#endif
+#if (RTL8723D_SUPPORT == 1) 
+		case ODM_RTL8723D:
+			phy_iq_calibrate_8723d(dm, is_recovery);
+			break;
+#endif
+#if (RTL8812A_SUPPORT == 1) 
+		case ODM_RTL8812:
+			phy_iq_calibrate_8812a(dm, is_recovery);
+			break;
+#endif
+#if (RTL8821A_SUPPORT == 1) 
+		case ODM_RTL8821:
+			phy_iq_calibrate_8821a(dm, is_recovery);
+			break;
+#endif
+#if (RTL8814A_SUPPORT == 1) 
+		case ODM_RTL8814A:
+			phy_iq_calibrate_8814a(dm, is_recovery);
+			break;
+#endif
+#if (RTL8822B_SUPPORT == 1) 
+		case ODM_RTL8822B:
+			phy_iq_calibrate_8822b(dm, false, false);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1) 
+		case ODM_RTL8821C:
+			phy_iq_calibrate_8821c(dm, false, false);
+			break;
+#endif
+#if (RTL8814B_SUPPORT == 1) 
+		case ODM_RTL8814B:
+			break;
+#endif
+		default:
+			break;
+		}
+		dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(dm, start_time);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]IQK progressing_time = %lld ms\n", dm->rf_calibrate_info.iqk_progressing_time);
+
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "== Return the IQK CMD, because RFKs in Progress ==\n");
+}
+
+
+
+void
+halrf_lck_trigger(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info		*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64 start_time;
+	
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if (odm_check_power_status(dm) == false)
+		return;
+#endif
+
+	if ((dm->mp_mode != NULL) && (rf->is_con_tx != NULL) && (rf->is_single_tone != NULL) && (rf->is_carrier_suppresion != NULL))
+		if (*dm->mp_mode && ((*rf->is_con_tx || *rf->is_single_tone || *rf->is_carrier_suppresion)))
+			return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (!(rf->rf_supportability & HAL_RF_LCK))
+		return;
+#endif
+
+#if DISABLE_BB_RF
+		return;
+#endif
+	if (iqk_info->rfk_forbidden)
+		return;
+	while (*dm->is_scan_in_process) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[LCK]scan is in process, bypass LCK\n");
+		return;
+	}
+
+	if (!dm->rf_calibrate_info.is_lck_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_lck_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		switch (dm->support_ic_type) {
+#if (RTL8188E_SUPPORT == 1)
+		case ODM_RTL8188E:
+			phy_lc_calibrate_8188e(dm);
+			break;
+#endif
+#if (RTL8188F_SUPPORT == 1)
+		case ODM_RTL8188F:
+			phy_lc_calibrate_8188f(dm);
+			break;
+#endif
+#if (RTL8192E_SUPPORT == 1)
+		case ODM_RTL8192E:
+			phy_lc_calibrate_8192e(dm);
+			break;
+#endif
+#if (RTL8197F_SUPPORT == 1)
+		case ODM_RTL8197F:
+			phy_lc_calibrate_8197f(dm);
+			break;
+#endif
+#if (RTL8703B_SUPPORT == 1)
+		case ODM_RTL8703B:
+			phy_lc_calibrate_8703b(dm);
+			break;
+#endif
+#if (RTL8710B_SUPPORT == 1)
+		case ODM_RTL8710B:
+			phy_lc_calibrate_8710b(dm);
+			break;
+#endif
+#if (RTL8723B_SUPPORT == 1) 
+		case ODM_RTL8723B:
+			phy_lc_calibrate_8723b(dm);
+			break;
+#endif
+#if (RTL8723D_SUPPORT == 1)
+		case ODM_RTL8723D:
+			phy_lc_calibrate_8723d(dm);
+			break;
+#endif
+#if (RTL8812A_SUPPORT == 1)
+		case ODM_RTL8812:
+			phy_lc_calibrate_8812a(dm);
+			break;
+#endif
+#if (RTL8821A_SUPPORT == 1) 
+		case ODM_RTL8821:
+			phy_lc_calibrate_8821a(dm);
+			break;
+#endif
+#if (RTL8814A_SUPPORT == 1) 
+		case ODM_RTL8814A:
+			phy_lc_calibrate_8814a(dm);
+			break;
+#endif
+#if (RTL8822B_SUPPORT == 1) 
+		case ODM_RTL8822B:
+			phy_lc_calibrate_8822b(dm);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1) 
+		case ODM_RTL8821C:
+			phy_lc_calibrate_8821c(dm);
+			break;
+#endif
+#if (RTL8814B_SUPPORT == 1) 
+		case ODM_RTL8814B:
+			break;
+#endif
+		default:
+			break;
+		}
+		dm->rf_calibrate_info.lck_progressing_time = odm_get_progressing_time(dm, start_time);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]LCK progressing_time = %lld ms\n", dm->rf_calibrate_info.lck_progressing_time);
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		halrf_lck_dbg(dm);
+#endif
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_lck_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);		
+	}else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "== Return the LCK CMD, because RFK is in Progress ==\n");
+}
+
+void
+halrf_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	PHYDM_DBG(dm, ODM_COMP_INIT, "HALRF_Init\n");
+
+	if (*dm->mp_mode == true)
+		halrf_supportability_init_mp(dm);
+	else
+		halrf_supportability_init(dm);
+
+	/*Init all RF funciton*/
+	/*iqk_init();*/
+	/*dpk_init();*/
+}
+
+
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf.h
new file mode 100644
index 000000000000..7240397263cf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf.h
@@ -0,0 +1,455 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	_HALRF_H__
+#define _HALRF_H__
+
+/*============================================================*/
+/*include files*/
+/*============================================================*/
+#include "halrf/halrf_psd.h"
+
+
+/*============================================================*/
+/*Definition */
+/*============================================================*/
+/*IQK version*/
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+#define IQK_VERSION_8188E	"0x14"
+#define IQK_VERSION_8192E	"0x01"
+#define IQK_VERSION_8723B	"0x1e"
+#define IQK_VERSION_8812A	"0x01"
+#define IQK_VERSION_8821A	"0x01"
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+#define IQK_VERSION_8188E	"0x01"
+#define IQK_VERSION_8192E	"0x01"
+#define IQK_VERSION_8723B	"0x1e"
+#define IQK_VERSION_8812A	"0x01"
+#define IQK_VERSION_8821A	"0x01"
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#define IQK_VERSION_8188E	"0x01"
+#define IQK_VERSION_8192E	"0x01"
+#define IQK_VERSION_8723B	"0x1e"
+#define IQK_VERSION_8812A	"0x01"
+#define IQK_VERSION_8821A	"0x01"
+#endif
+#define IQK_VERSION_8814A	"0x0f"
+#define IQK_VERSION_8188F	"0x01"
+#define IQK_VERSION_8197F	"0x01"
+#define IQK_VERSION_8703B	"0x05"
+#define IQK_VERSION_8710B	"0x01"
+#define IQK_VERSION_8723D	"0x02"
+#define IQK_VERSION_8822B	"0x2f"
+#define IQK_VERSION_8821C	"0x23"
+
+/*LCK version*/
+#define LCK_VERSION_8188E	"0x01"
+#define LCK_VERSION_8192E	"0x01"
+#define LCK_VERSION_8723B	"0x01"
+#define LCK_VERSION_8812A	"0x01"
+#define LCK_VERSION_8821A	"0x01"
+#define LCK_VERSION_8814A	"0x01"
+#define LCK_VERSION_8188F	"0x01"
+#define LCK_VERSION_8197F	"0x01"
+#define LCK_VERSION_8703B	"0x01"
+#define LCK_VERSION_8710B	"0x01"
+#define LCK_VERSION_8723D	"0x01"
+#define LCK_VERSION_8822B	"0x01"
+#define LCK_VERSION_8821C	"0x01"
+
+/*power tracking version*/
+#define POWERTRACKING_VERSION_8188E	"0x01"
+#define POWERTRACKING_VERSION_8192E	"0x01"
+#define POWERTRACKING_VERSION_8723B	"0x01"
+#define POWERTRACKING_VERSION_8812A	"0x01"
+#define POWERTRACKING_VERSION_8821A	"0x01"
+#define POWERTRACKING_VERSION_8814A	"0x01"
+#define POWERTRACKING_VERSION_8188F	"0x01"
+#define POWERTRACKING_VERSION_8197F	"0x01"
+#define POWERTRACKING_VERSION_8703B	"0x01"
+#define POWERTRACKING_VERSION_8710B	"0x01"
+#define POWERTRACKING_VERSION_8723D	"0x01"
+#define POWERTRACKING_VERSION_8822B	"0x01"
+#define POWERTRACKING_VERSION_8821C	"0x01"
+
+/*DPK tracking version*/
+#define DPK_VERSION_8188E	"NONE"
+#define DPK_VERSION_8192E	"NONE"
+#define DPK_VERSION_8723B	"NONE"
+#define DPK_VERSION_8812A	"NONE"
+#define DPK_VERSION_8821A	"NONE"
+#define DPK_VERSION_8814A	"NONE"
+#define DPK_VERSION_8188F	"NONE"
+#define DPK_VERSION_8197F	"NONE"
+#define DPK_VERSION_8703B	"NONE"
+#define DPK_VERSION_8710B	"NONE"
+#define DPK_VERSION_8723D	"NONE"
+#define DPK_VERSION_8822B	"NONE"
+#define DPK_VERSION_8821C	"NONE"
+
+/*Kfree tracking version*/
+#define KFREE_VERSION_8188E	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8192E	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8723B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8812A	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8821A	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8814A	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8188F	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8197F	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8703B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8710B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8723D	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8822B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8821C	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+
+/*PA Bias Calibration version*/
+#define PABIASK_VERSION_8188E	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8192E	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8723B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8812A	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8821A	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8814A	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8188F	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8197F	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8703B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8710B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8723D	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8822B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8821C	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+
+
+
+#define HALRF_IQK_VER	(dm->support_ic_type == ODM_RTL8188E)? IQK_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? IQK_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? IQK_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? IQK_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? IQK_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? IQK_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? IQK_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? IQK_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? IQK_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? IQK_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? IQK_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? IQK_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? IQK_VERSION_8821C :"unknown"
+
+
+#define HALRF_LCK_VER	(dm->support_ic_type == ODM_RTL8188E)? LCK_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? LCK_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? LCK_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? LCK_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? LCK_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? LCK_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? LCK_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? LCK_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? LCK_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? LCK_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? LCK_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? LCK_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? LCK_VERSION_8821C :"unknown"
+
+
+#define HALRF_POWRTRACKING_VER	(dm->support_ic_type == ODM_RTL8188E)? POWERTRACKING_VERSION_8188E :\
+								(dm->support_ic_type == ODM_RTL8192E)? POWERTRACKING_VERSION_8192E :\
+								(dm->support_ic_type == ODM_RTL8723B)? POWERTRACKING_VERSION_8723B :\
+								(dm->support_ic_type == ODM_RTL8812)? POWERTRACKING_VERSION_8812A :\
+								(dm->support_ic_type == ODM_RTL8821)? POWERTRACKING_VERSION_8821A :\
+								(dm->support_ic_type == ODM_RTL8814A)? POWERTRACKING_VERSION_8814A :\
+								(dm->support_ic_type == ODM_RTL8188F)? POWERTRACKING_VERSION_8188F :\
+								(dm->support_ic_type == ODM_RTL8197F)? POWERTRACKING_VERSION_8197F :\
+								(dm->support_ic_type == ODM_RTL8703B)? POWERTRACKING_VERSION_8703B :\
+								(dm->support_ic_type == ODM_RTL8710B)? POWERTRACKING_VERSION_8710B :\
+								(dm->support_ic_type == ODM_RTL8723D)? POWERTRACKING_VERSION_8723D :\
+								(dm->support_ic_type == ODM_RTL8822B)? POWERTRACKING_VERSION_8822B :\
+								(dm->support_ic_type == ODM_RTL8821C)? POWERTRACKING_VERSION_8821C :"unknown"
+
+#define HALRF_DPK_VER	(dm->support_ic_type == ODM_RTL8188E)? DPK_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? DPK_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? DPK_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? DPK_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? DPK_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? DPK_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? DPK_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? DPK_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? DPK_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? DPK_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? DPK_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? DPK_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? DPK_VERSION_8821C :"unknown"
+
+#define HALRF_KFREE_VER (dm->support_ic_type == ODM_RTL8188E)? KFREE_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? KFREE_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? KFREE_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? KFREE_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? KFREE_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? KFREE_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? KFREE_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? KFREE_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? KFREE_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? KFREE_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? KFREE_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? KFREE_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? KFREE_VERSION_8821C :"unknown"
+
+#define HALRF_PABIASK_VER	(dm->support_ic_type == ODM_RTL8188E)? PABIASK_VERSION_8188E :\
+								(dm->support_ic_type == ODM_RTL8192E)? PABIASK_VERSION_8192E :\
+								(dm->support_ic_type == ODM_RTL8723B)? PABIASK_VERSION_8723B :\
+								(dm->support_ic_type == ODM_RTL8812)? PABIASK_VERSION_8812A :\
+								(dm->support_ic_type == ODM_RTL8821)? PABIASK_VERSION_8821A :\
+								(dm->support_ic_type == ODM_RTL8814A)? PABIASK_VERSION_8814A :\
+								(dm->support_ic_type == ODM_RTL8188F)? PABIASK_VERSION_8188F :\
+								(dm->support_ic_type == ODM_RTL8197F)? PABIASK_VERSION_8197F :\
+								(dm->support_ic_type == ODM_RTL8703B)? PABIASK_VERSION_8703B :\
+								(dm->support_ic_type == ODM_RTL8710B)? PABIASK_VERSION_8710B :\
+								(dm->support_ic_type == ODM_RTL8723D)? PABIASK_VERSION_8723D :\
+								(dm->support_ic_type == ODM_RTL8822B)? PABIASK_VERSION_8822B :\
+								(dm->support_ic_type == ODM_RTL8821C)? PABIASK_VERSION_8821C :"unknown"
+
+
+
+#define IQK_THRESHOLD			8
+#define DPK_THRESHOLD			4
+
+/*===========================================================*/
+/*AGC RX High Power mode*/
+/*===========================================================*/
+#define	lna_low_gain_1		0x64
+#define	lna_low_gain_2		0x5A
+#define	lna_low_gain_3		0x58
+
+/*============================================================*/
+/* enumeration */
+/*============================================================*/
+enum halrf_ability {
+	HAL_RF_TX_PWR_TRACK	= BIT(0),
+	HAL_RF_IQK				= BIT(1),
+	HAL_RF_LCK				= BIT(2),
+	HAL_RF_DPK				= BIT(3),
+	HAL_RF_TXGAPK			= BIT(4)
+};
+
+enum halrf_cmninfo_init {
+	HALRF_CMNINFO_ABILITY = 0,
+	HALRF_CMNINFO_DPK_EN = 1,
+	HALRF_CMNINFO_EEPROM_THERMAL_VALUE,
+	HALRF_CMNINFO_FW_VER,
+	HALRF_CMNINFO_RFK_FORBIDDEN,
+	HALRF_CMNINFO_IQK_SEGMENT,
+	HALRF_CMNINFO_RATE_INDEX,
+	HALRF_CMNINFO_MP_PSD_POINT,
+	HALRF_CMNINFO_MP_PSD_START_POINT,
+	HALRF_CMNINFO_MP_PSD_STOP_POINT,
+	HALRF_CMNINFO_MP_PSD_AVERAGE
+};
+
+enum halrf_cmninfo_hook {
+	HALRF_CMNINFO_CON_TX,
+	HALRF_CMNINFO_SINGLE_TONE,
+	HALRF_CMNINFO_CARRIER_SUPPRESSION,	
+	HALRF_CMNINFO_MP_RATE_INDEX
+};
+
+enum phydm_lna_set {
+	phydm_lna_disable		= 0,
+	phydm_lna_enable		= 1,
+};
+
+
+/*============================================================*/
+/* structure */
+/*============================================================*/
+
+struct _hal_rf_ {
+	/*hook*/
+	u8		*test1;
+
+	/*update*/
+	u32		rf_supportability;
+
+	u8		eeprom_thermal;
+	u8		dpk_en;			/*Enable Function DPK OFF/ON = 0/1*/
+	boolean	dpk_done;
+	u32		fw_ver;
+
+	boolean	*is_con_tx;
+	boolean	*is_single_tone;
+	boolean	*is_carrier_suppresion;
+
+	u8		*mp_rate_index;
+	u32		p_rate_index;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct	_halrf_psd_data	halrf_psd_data;
+#endif
+};
+
+/*============================================================*/
+/* function prototype */
+/*============================================================*/
+
+void halrf_basic_profile(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+);
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void halrf_iqk_info_dump(
+	void *dm_void,
+	u32 *_used,
+	char *output,
+	u32 *_out_len
+);
+
+void
+halrf_iqk_hwtx_check(
+	void *dm_void,
+	boolean		is_check
+);
+#endif
+
+u8
+halrf_match_iqk_version(
+	void	*dm_void
+);
+
+void
+halrf_support_ability_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+halrf_cmn_info_init(
+	void		*dm_void,
+	enum halrf_cmninfo_init	cmn_info,
+	u32		value
+);
+
+void
+halrf_cmn_info_hook(
+	void		*dm_void,
+	u32		cmn_info,
+	void		*value
+);
+
+void
+halrf_cmn_info_set(
+	void		*dm_void,
+	u32			cmn_info,
+	u64			value
+);
+
+u64
+halrf_cmn_info_get(
+	void		*dm_void,
+	u32			cmn_info
+);
+
+void
+halrf_watchdog(
+	void			*dm_void
+);
+
+void
+halrf_supportability_init(
+	void		*dm_void
+);
+
+void
+halrf_init(
+	void			*dm_void
+);
+
+void
+halrf_iqk_trigger(
+	void			*dm_void,
+	boolean		is_recovery
+);
+
+void
+halrf_segment_iqk_trigger(
+	void			*dm_void,
+	boolean		clear,
+	boolean		segment_iqk
+);
+
+void
+halrf_lck_trigger(
+	void			*dm_void
+);
+
+void
+halrf_iqk_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_get_iqk_cfir(
+	void		*dm_void,
+	u8 idx,
+	u8 path,
+	boolean debug
+);
+
+void 
+halrf_iqk_xym_read(
+	void *dm_void,
+	u8 path,
+	u8 xym_type
+ );
+
+void
+halrf_rf_lna_setting(
+	void	*dm_void,
+	enum phydm_lna_set type
+);
+
+
+void
+halrf_do_imr_test(
+	void	*dm_void,
+	u8 data
+);
+
+u32
+halrf_psd_log2base(
+	u32 val
+);
+
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void halrf_iqk_dbg(void	*dm_void);
+#endif
+#endif
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_features.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_features.h
new file mode 100644
index 000000000000..c6ef3e6146b2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_features.h
@@ -0,0 +1,43 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__HALRF_FEATURES_H__
+#define __HALRF_FEATURES
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+	#define	CONFIG_HALRF_POWERTRACKING	1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	#define	CONFIG_HALRF_POWERTRACKING	1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+	#define	CONFIG_HALRF_POWERTRACKING	1
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_iqk.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_iqk.h
new file mode 100644
index 000000000000..846feb189044
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_iqk.h
@@ -0,0 +1,85 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMIQK_H__
+#define __PHYDMIQK_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define	LOK_delay 1
+#define	WBIQK_delay 10
+#define	TX_IQK 0
+#define	RX_IQK 1
+#define	TXIQK 0
+#define	RXIQK1 1
+#define	RXIQK2 2
+#define kcount_limit_80m 2
+#define kcount_limit_others 4
+#define rxiqk_gs_limit 10
+
+#define	NUM 4
+/*---------------------------End Define Parameters-------------------------------*/
+
+struct dm_iqk_info {
+	boolean		lok_fail[NUM];
+	boolean		iqk_fail[2][NUM];
+	u32		iqc_matrix[2][NUM];
+	u8      iqk_times;
+	u32		rf_reg18;
+	u32		lna_idx;
+	u8		rxiqk_step;
+	u8		tmp1bcc;
+	u8		kcount;
+	u8		rfk_ing; /*bit0:IQKing, bit1:LCKing, bit2:DPKing*/
+	boolean rfk_forbidden;	
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	u32		iqk_channel[2];
+	boolean		iqk_fail_report[2][4][2]; /*channel/path/TRX(TX:0, RX:1) */
+	u32		iqk_cfir_real[3][4][2][8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_real*/ /*channel index = 2 is just for debug*/
+	u32		iqk_cfir_imag[3][4][2][8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_imag*/ /*channel index = 2 is just for debug*/
+	u8		retry_count[2][4][3]; /* channel / path / (TXK:0, RXK1:1, RXK2:2) */
+	u8		gs_retry_count[2][4][2]; /* channel / path / (GSRXK1:0, GSRXK2:1) */
+	u8		rxiqk_fail_code[2][4]; /* channel / path 0:SRXK1 fail, 1:RXK1 fail 2:RXK2 fail */
+	u32		lok_idac[2][4];		/*channel / path*/
+	u16		rxiqk_agc[2][4];	 /*channel / path*/
+	u32		bypass_iqk[2][4];	/*channel / 0xc94/0xe94*/
+	u32		txgap_result[8]; /*txagpK result  */
+	u32		tmp_gntwl;
+	boolean		is_btg;
+	boolean		isbnd;
+	boolean is_reload;
+	boolean segment_iqk;
+	boolean is_hwtx;
+	
+	boolean	xym_read;
+	boolean trximr_enable;
+	u32		rx_xym[2][10];
+	u32		tx_xym[2][10];
+	u32		gs1_xym[2][6];
+	u32		gs2_xym[2][6];
+	u32		rxk1_xym[2][6];
+#endif
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_kfree.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_kfree.c
new file mode 100644
index 000000000000..acc705f1fe0d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_kfree.c
@@ -0,0 +1,883 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*============================================================*/
+/*include files*/
+/*============================================================*/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+/*<YuChen, 150720> Add for KFree Feature Requested by RF David.*/
+/*This is a phydm API*/
+
+void
+phydm_set_kfree_to_rf_8814a(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	boolean is_odd;
+
+	if ((data % 2) != 0) {	/*odd->positive*/
+		data = data - 1;
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(19), 1);
+		is_odd = true;
+	} else {		/*even->negative*/
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(19), 0);
+		is_odd = false;
+	}
+	PHYDM_DBG(dm, ODM_COMP_MP, "phy_ConfigKFree8814A(): RF_0x55[19]= %d\n", is_odd);
+	switch (data) {
+	case 0:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 0);
+		cali_info->kfree_offset[e_rf_path] = 0;
+		break;
+	case 2:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 0);
+		cali_info->kfree_offset[e_rf_path] = 0;
+		break;
+	case 4:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 1);
+		cali_info->kfree_offset[e_rf_path] = 1;
+		break;
+	case 6:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 1);
+		cali_info->kfree_offset[e_rf_path] = 1;
+		break;
+	case 8:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 2);
+		cali_info->kfree_offset[e_rf_path] = 2;
+		break;
+	case 10:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 2);
+		cali_info->kfree_offset[e_rf_path] = 2;
+		break;
+	case 12:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 3);
+		cali_info->kfree_offset[e_rf_path] = 3;
+		break;
+	case 14:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 3);
+		cali_info->kfree_offset[e_rf_path] = 3;
+		break;
+	case 16:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 4);
+		cali_info->kfree_offset[e_rf_path] = 4;
+		break;
+	case 18:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 4);
+		cali_info->kfree_offset[e_rf_path] = 4;
+		break;
+	case 20:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 5);
+		cali_info->kfree_offset[e_rf_path] = 5;
+		break;
+
+	default:
+		break;
+	}
+
+	if (is_odd == false) {
+		/*that means Kfree offset is negative, we need to record it.*/
+		cali_info->kfree_offset[e_rf_path] = (-1) * cali_info->kfree_offset[e_rf_path];
+		PHYDM_DBG(dm, ODM_COMP_MP, "phy_ConfigKFree8814A(): kfree_offset = %d\n", cali_info->kfree_offset[e_rf_path]);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_MP, "phy_ConfigKFree8814A(): kfree_offset = %d\n", cali_info->kfree_offset[e_rf_path]);
+
+}
+
+
+
+//
+//
+//
+void
+phydm_get_thermal_trim_offset_8821c(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_therm = 0xff;
+
+	odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_8821C, &pg_therm, false);
+
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
+
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c thermal trim flag:0x%02x\n", power_trim_info->flag);
+
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c thermal:%d\n", power_trim_info->thermal);
+}
+
+
+
+void
+phydm_get_power_trim_offset_8821c(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_power = 0xff, i;
+
+	odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET_8821C, &pg_power, false);
+
+	if (pg_power != 0xff) {
+		power_trim_info->bb_gain[0][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[1][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL2_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[2][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM1_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[3][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM2_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[4][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GH1_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[5][0] = pg_power;
+		power_trim_info->flag = power_trim_info->flag | KFREE_FLAG_ON | KFREE_FLAG_ON_2G | KFREE_FLAG_ON_5G;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c power trim flag:0x%02x\n", power_trim_info->flag);
+
+	if (power_trim_info->flag & KFREE_FLAG_ON) {
+		for (i = 0; i < KFREE_BAND_NUM; i++)
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c power_trim_data->bb_gain[%d][0]=0x%X\n", i, power_trim_info->bb_gain[i][0]);
+	}
+}
+
+
+
+void
+phydm_set_kfree_to_rf_8821c(
+	void		*dm_void,
+	u8		e_rf_path,
+	boolean		wlg_btg,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	u8	wlg, btg;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(5), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(6), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(6), 1);
+
+	if (wlg_btg == true) {
+		wlg = data & 0xf;
+		btg = (data & 0xf0) >> 4;
+
+		odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (wlg & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (wlg >> 1));
+
+		odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(19), (btg & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, 0x65, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (btg >> 1));
+	} else {
+		odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		odm_get_rf_reg(dm, e_rf_path, 0x65, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)))
+		);
+}
+
+
+
+void
+phydm_clear_kfree_to_rf_8821c(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(5), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(6), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(6), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (data >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x65, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (data >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(5), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(6), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(6), 0);
+
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		odm_get_rf_reg(dm, e_rf_path, 0x65, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)))
+		);
+}
+
+
+
+void
+phydm_get_thermal_trim_offset_8822b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_therm = 0xff;
+
+#if 0
+	u32	thermal_trim_enable = 0xff;
+
+	odm_efuse_logical_map_read(dm, 1, 0xc8, &thermal_trim_enable);
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 0xc8:0x%2x\n", thermal_trim_enable);
+
+	thermal_trim_enable = (thermal_trim_enable & BIT(5)) >> 5;
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b thermal trim Enable:%d\n", thermal_trim_enable);
+
+	if ((cali_info->reg_rf_kfree_enable == 0 && thermal_trim_enable == 1) ||
+		cali_info->reg_rf_kfree_enable == 1) {
+#endif
+
+		odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET, &pg_therm, false);
+
+		if (pg_therm != 0xff) {
+			pg_therm = pg_therm & 0x1f;
+			if ((pg_therm & BIT(0)) == 0)
+				power_trim_info->thermal = (-1 * (pg_therm >> 1));
+			else
+				power_trim_info->thermal = (pg_therm >> 1);
+
+			power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b thermal trim flag:0x%02x\n", power_trim_info->flag);
+
+		if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b thermal:%d\n", power_trim_info->thermal);
+#if 0
+	} else
+		return;
+#endif
+
+}
+
+
+
+void
+phydm_get_power_trim_offset_8822b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	u8 pg_power = 0xff, i, j;
+
+#if 0
+	u32	power_trim_enable = 0xff;
+
+	odm_efuse_logical_map_read(dm, 1, 0xc8, &power_trim_enable);
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 0xc8:0x%2x\n", power_trim_enable);
+
+	power_trim_enable = (power_trim_enable & BIT(4)) >> 4;
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b power trim Enable:%d\n", power_trim_enable);
+
+	if ((cali_info->reg_rf_kfree_enable == 0 && power_trim_enable == 1) ||
+		cali_info->reg_rf_kfree_enable == 1) {
+#endif
+
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
+
+		if (pg_power != 0xff) {
+			/*Path A*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
+
+			/*Path B*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[0][1] = ((pg_power & 0xf0) >> 4);
+
+			power_trim_info->flag |= KFREE_FLAG_ON_2G;
+			power_trim_info->flag |= KFREE_FLAG_ON;
+		}
+
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXA_OFFSET, &pg_power, false);
+		
+		if (pg_power != 0xff) {
+			/*Path A*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[1][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL2_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[2][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM1_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[3][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM2_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[4][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GH1_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[5][0] = pg_power;
+
+			/*Path B*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[1][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL2_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[2][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM1_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[3][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM2_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[4][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GH1_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[5][1] = pg_power;
+			
+			power_trim_info->flag |= KFREE_FLAG_ON_5G;
+			power_trim_info->flag |= KFREE_FLAG_ON;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b power trim flag:0x%02x\n", power_trim_info->flag);
+
+		if (!(power_trim_info->flag & KFREE_FLAG_ON))
+			return;
+
+		for (i = 0; i < KFREE_BAND_NUM; i++) {
+			for (j = 0; j < 2; j++)
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b power_trim_data->bb_gain[%d][%d]=0x%X\n", i, j, power_trim_info->bb_gain[i][j]);
+		}
+#if 0
+	} else
+		return;
+#endif
+}
+
+
+
+void
+phydm_set_pa_bias_to_rf_8822b(
+	void		*dm_void,
+	u8		e_rf_path,
+	s8		tx_pa_bias
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	u32	rf_reg_51 = 0, rf_reg_52 = 0, rf_reg_3f = 0;
+
+	rf_reg_51 = odm_get_rf_reg(dm, e_rf_path, 0x51, RFREGOFFSETMASK);
+	rf_reg_52 = odm_get_rf_reg(dm, e_rf_path, 0x52, RFREGOFFSETMASK);
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 2g rf(0x51)=0x%X rf(0x52)=0x%X path=%d\n",
+ 		rf_reg_51, rf_reg_52, e_rf_path);
+
+	/*rf3f => rf52[19:17] = rf3f[2:0] rf52[16:15] = rf3f[4:3] rf52[3:0] = rf3f[8:5]*/
+	/*rf3f => rf51[6:3] = rf3f[12:9] rf52[13] = rf3f[13]*/
+	rf_reg_3f = ((rf_reg_52 & 0xe0000) >> 17) |
+					(((rf_reg_52 & 0x18000) >> 15) << 3) |
+					((rf_reg_52 & 0xf) << 5) |
+					(((rf_reg_51 & 0x78) >> 3) << 9) |
+					(((rf_reg_52 & 0x2000) >> 13) << 13);
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 2g original tx_pa_bias=%d rf_reg_3f=0x%X path=%d\n",
+			tx_pa_bias, rf_reg_3f, e_rf_path);
+
+	tx_pa_bias = (s8)((rf_reg_3f & (BIT(12) | BIT(11) | BIT(10) | BIT(9))) >> 9) + tx_pa_bias;
+
+	if (tx_pa_bias < 0)
+		tx_pa_bias = 0;
+	else if (tx_pa_bias > 7)
+		tx_pa_bias = 7;
+
+	rf_reg_3f = ((rf_reg_3f & 0xfe1ff) | (tx_pa_bias << 9));
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 2g offset efuse 0x3d5 0x3d6 tx_pa_bias=%d rf_reg_3f=0x%X path=%d\n",
+			tx_pa_bias, rf_reg_3f, e_rf_path);
+
+	odm_set_rf_reg(dm, e_rf_path, 0xef, BIT(10), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, RFREGOFFSETMASK, 0x0);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, BIT(0), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, BIT(1), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, (BIT(1) | BIT(0)), 0x3);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0xef, BIT(10), 0x0);
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 2g tx pa bias rf_0x3f(0x%X) path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x3f, (BIT(12) | BIT(11) | BIT(10) | BIT(9))), e_rf_path);
+}
+
+
+
+void
+phydm_get_pa_bias_offset_8822b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_pa_bias = 0xff, e_rf_path = 0;
+	s8 tx_pa_bias[2] = {0};
+
+	odm_efuse_one_byte_read(dm, PPG_PA_BIAS_2G_TXA_OFFSET, &pg_pa_bias, false);
+
+	if (pg_pa_bias != 0xff) {
+		/*paht a*/
+		odm_efuse_one_byte_read(dm, PPG_PA_BIAS_2G_TXA_OFFSET, &pg_pa_bias, false);
+		pg_pa_bias = pg_pa_bias & 0xf;
+		
+		if ((pg_pa_bias & BIT(0)) == 0)
+			tx_pa_bias[0] = (-1 * (pg_pa_bias >> 1));
+		else
+			tx_pa_bias[0] = (pg_pa_bias >> 1);
+
+		/*paht b*/
+		odm_efuse_one_byte_read(dm, PPG_PA_BIAS_2G_TXB_OFFSET, &pg_pa_bias, false);
+		pg_pa_bias = pg_pa_bias & 0xf;
+		
+		if ((pg_pa_bias & BIT(0)) == 0)
+			tx_pa_bias[1] = (-1 * (pg_pa_bias >> 1));
+		else
+			tx_pa_bias[1] = (pg_pa_bias >> 1);
+
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 2g tx_patha_pa_bias:%d   tx_pathb_pa_bias:%d\n", tx_pa_bias[0], tx_pa_bias[1]);
+
+		for (e_rf_path = RF_PATH_A;  e_rf_path < 2; e_rf_path++)
+			phydm_set_pa_bias_to_rf_8822b(dm, e_rf_path, tx_pa_bias[e_rf_path]);
+
+		power_trim_info->pa_bias_flag |= PA_BIAS_FLAG_ON;
+	}
+	else
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 2g tx pa bias no pg\n");
+}
+
+
+
+void
+phydm_set_kfree_to_rf_8822b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(5), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		);
+}
+
+
+
+void
+phydm_clear_kfree_to_rf_8822b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(5), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(5), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(7), 0);
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b clear power trim 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		);
+}
+
+void
+phydm_get_thermal_trim_offset_8710b(
+void	*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &(dm->power_trim_data);
+
+	u8 pg_therm = 0xff;
+	
+	odm_efuse_one_byte_read(dm, 0x0EF, &pg_therm, false);
+	
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
+	
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
+	
+	ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b thermal trim flag:0x%02x\n", power_trim_info->flag));
+	
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b thermal:%d\n", power_trim_info->thermal));
+
+}
+
+void
+phydm_get_power_trim_offset_8710b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &(dm->power_trim_data);
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	u8 pg_power = 0xff;
+
+	odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
+
+		if (pg_power != 0xff) {
+			/*Path A*/
+			odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
+			power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
+
+			power_trim_info->flag |= KFREE_FLAG_ON_2G;
+			power_trim_info->flag |= KFREE_FLAG_ON;
+		}
+
+
+		ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b power trim flag:0x%02x\n", power_trim_info->flag));
+
+		if (power_trim_info->flag & KFREE_FLAG_ON) 
+
+		ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b power_trim_data->bb_gain[0][0]=0x%X\n",  power_trim_info->bb_gain[0][0]));
+
+}
+void
+phydm_set_kfree_to_rf_8710b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15)), ((data & 0xf) >> 1));
+
+	ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD,
+		("[kfree] 8710b 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		));
+}
+
+void
+phydm_clear_kfree_to_rf_8710b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+
+	ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD,
+		("[kfree] 8710b clear power trim 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		));
+}
+
+
+void
+phydm_set_kfree_to_rf(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phydm_set_kfree_to_rf_8814a(dm, e_rf_path, data);
+
+	if ((dm->support_ic_type & ODM_RTL8821C) && (*dm->band_type == ODM_BAND_2_4G))
+		phydm_set_kfree_to_rf_8821c(dm, e_rf_path, true, data);
+	else if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_set_kfree_to_rf_8821c(dm, e_rf_path, false, data);
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_set_kfree_to_rf_8822b(dm, e_rf_path, data);
+	if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_set_kfree_to_rf_8710b(dm, e_rf_path, data);
+}
+
+
+
+void
+phydm_clear_kfree_to_rf(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_clear_kfree_to_rf_8822b(dm, e_rf_path, 1);
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_clear_kfree_to_rf_8821c(dm, e_rf_path, 1);
+
+	if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_set_kfree_to_rf_8710b(dm, e_rf_path, data);
+}
+
+
+
+
+void
+phydm_get_thermal_trim_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL		pEfuseHal = &hal_data->EfuseHal;
+	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] dump efuse fail !!!\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_get_thermal_trim_offset_8821c(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_thermal_trim_offset_8822b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_get_thermal_trim_offset_8710b(dm_void);
+}
+
+
+
+void
+phydm_get_power_trim_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if 0 //(DM_ODM_SUPPORT_TYPE & ODM_WIN)	// 2017 MH DM Should use the same code.s
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL		pEfuseHal = &hal_data->EfuseHal;
+	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO(adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] dump efuse fail !!!\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_get_power_trim_offset_8821c(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_power_trim_offset_8822b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_get_power_trim_offset_8710b(dm_void);
+
+}
+
+
+
+void
+phydm_get_pa_bias_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL		pEfuseHal = &hal_data->EfuseHal;
+	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] dump efuse fail !!!\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_pa_bias_offset_8822b(dm_void);
+}
+
+
+
+s8
+phydm_get_thermal_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		return power_trim_info->thermal;
+	else
+		return 0;
+}
+
+
+
+void
+phydm_config_kfree(
+	void	*dm_void,
+	u8	channel_to_sw
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8			rfpath = 0, max_rf_path = 0;
+	u8			channel_idx = 0, i, j;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		max_rf_path = 4;	/*0~3*/
+	else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E | ODM_RTL8822B))
+		max_rf_path = 2;	/*0~1*/
+	else if (dm->support_ic_type & (ODM_RTL8821C| ODM_RTL8710B))
+		max_rf_path = 1;
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "===>[kfree] phy_ConfigKFree()\n");
+
+	if (cali_info->reg_rf_kfree_enable == 2) {
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phy_ConfigKFree(): reg_rf_kfree_enable == 2, Disable\n");
+		return;
+	} else if (cali_info->reg_rf_kfree_enable == 1 || cali_info->reg_rf_kfree_enable == 0) {
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phy_ConfigKFree(): reg_rf_kfree_enable == true\n");
+		/*Make sure the targetval is defined*/
+		if (!(power_trim_info->flag & KFREE_FLAG_ON)) {
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phy_ConfigKFree(): targetval not defined, Don't execute KFree Process.\n");
+			return;
+		}
+		/*if kfree_table[0] == 0xff, means no Kfree*/
+		if (dm->support_ic_type &ODM_RTL8710B)
+		  ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] power_trim_data->bb_gain[0][0]=0x%X\n", power_trim_info->bb_gain[0][0]));
+		else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E | ODM_RTL8822B |ODM_RTL8821C | ODM_RTL8814A)){
+		for (i = 0; i < KFREE_BAND_NUM; i++) {
+			for (j = 0; j < max_rf_path; j++)
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] power_trim_data->bb_gain[%d][%d]=0x%X\n", i, j, power_trim_info->bb_gain[i][j]);
+		}
+			}
+		if (*dm->band_type == ODM_BAND_2_4G && power_trim_info->flag & KFREE_FLAG_ON_2G) {
+			if (channel_to_sw >= 1 && channel_to_sw <= 14)
+				channel_idx = PHYDM_2G;
+
+			for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++) {
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phydm_kfree(): channel_to_sw=%d PATH_%d bb_gain:0x%X\n", channel_to_sw, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+				phydm_set_kfree_to_rf(dm, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+			}
+
+		} else if (*dm->band_type == ODM_BAND_5G && power_trim_info->flag & KFREE_FLAG_ON_5G) {
+			if (channel_to_sw >= 36 && channel_to_sw <= 48)
+				channel_idx = PHYDM_5GLB1;
+			if (channel_to_sw >= 52 && channel_to_sw <= 64)
+				channel_idx = PHYDM_5GLB2;
+			if (channel_to_sw >= 100 && channel_to_sw <= 120)
+				channel_idx = PHYDM_5GMB1;
+			if (channel_to_sw >= 122 && channel_to_sw <= 144)
+				channel_idx = PHYDM_5GMB2;
+			if (channel_to_sw >= 149 && channel_to_sw <= 177)
+				channel_idx = PHYDM_5GHB;
+
+			for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++) {
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phydm_kfree(): channel_to_sw=%d PATH_%d bb_gain:0x%X\n", channel_to_sw, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+				phydm_set_kfree_to_rf(dm, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+			}
+		} else {
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] Set default Register\n");
+			for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++)
+				phydm_clear_kfree_to_rf(dm, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+		}
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "<===[kfree] phy_ConfigKFree()\n");
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_kfree.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_kfree.h
new file mode 100644
index 000000000000..a5159d1ae813
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_kfree.h
@@ -0,0 +1,142 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDMKFREE_H__
+#define    __PHYDKFREE_H__
+
+#define KFREE_VERSION	"1.0"
+
+#define	KFREE_BAND_NUM		6
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_AP))
+
+#define	BB_GAIN_NUM		6
+
+#endif
+
+#define KFREE_FLAG_ON				BIT(0)
+#define KFREE_FLAG_THERMAL_K_ON		BIT(1)
+
+#define KFREE_FLAG_ON_2G				BIT(2)
+#define KFREE_FLAG_ON_5G				BIT(3)
+
+#define PA_BIAS_FLAG_ON				BIT(4)
+
+#define PPG_THERMAL_OFFSET_8821C				0x1EF
+#define PPG_BB_GAIN_2G_TXAB_OFFSET_8821C		0x1EE
+#define PPG_BB_GAIN_5GL1_TXA_OFFSET_8821C		0x1EC
+#define PPG_BB_GAIN_5GL2_TXA_OFFSET_8821C		0x1E8
+#define PPG_BB_GAIN_5GM1_TXA_OFFSET_8821C		0x1E4
+#define PPG_BB_GAIN_5GM2_TXA_OFFSET_8821C		0x1E0
+#define PPG_BB_GAIN_5GH1_TXA_OFFSET_8821C		0x1DC
+
+
+
+#define PPG_THERMAL_OFFSET				0x3EF
+#define PPG_BB_GAIN_2G_TXAB_OFFSET		0x3EE
+#define PPG_BB_GAIN_2G_TXCD_OFFSET		0x3ED
+#define PPG_BB_GAIN_5GL1_TXA_OFFSET		0x3EC
+#define PPG_BB_GAIN_5GL1_TXB_OFFSET		0x3EB
+#define PPG_BB_GAIN_5GL1_TXC_OFFSET		0x3EA
+#define PPG_BB_GAIN_5GL1_TXD_OFFSET		0x3E9
+#define PPG_BB_GAIN_5GL2_TXA_OFFSET		0x3E8
+#define PPG_BB_GAIN_5GL2_TXB_OFFSET		0x3E7
+#define PPG_BB_GAIN_5GL2_TXC_OFFSET		0x3E6
+#define PPG_BB_GAIN_5GL2_TXD_OFFSET		0x3E5
+#define PPG_BB_GAIN_5GM1_TXA_OFFSET		0x3E4
+#define PPG_BB_GAIN_5GM1_TXB_OFFSET		0x3E3
+#define PPG_BB_GAIN_5GM1_TXC_OFFSET		0x3E2
+#define PPG_BB_GAIN_5GM1_TXD_OFFSET		0x3E1
+#define PPG_BB_GAIN_5GM2_TXA_OFFSET		0x3E0
+#define PPG_BB_GAIN_5GM2_TXB_OFFSET		0x3DF
+#define PPG_BB_GAIN_5GM2_TXC_OFFSET		0x3DE
+#define PPG_BB_GAIN_5GM2_TXD_OFFSET		0x3DD
+#define PPG_BB_GAIN_5GH1_TXA_OFFSET		0x3DC
+#define PPG_BB_GAIN_5GH1_TXB_OFFSET		0x3DB
+#define PPG_BB_GAIN_5GH1_TXC_OFFSET		0x3DA
+#define PPG_BB_GAIN_5GH1_TXD_OFFSET		0x3D9
+
+#define PPG_PA_BIAS_2G_TXA_OFFSET		0x3D5
+#define PPG_PA_BIAS_2G_TXB_OFFSET		0x3D6
+
+
+
+struct odm_power_trim_data {
+	u8 flag;
+	u8 pa_bias_flag;
+	s8 bb_gain[KFREE_BAND_NUM][MAX_RF_PATH];
+	s8 thermal;
+};
+
+
+
+enum phydm_kfree_channeltosw {
+	PHYDM_2G = 0,
+	PHYDM_5GLB1 = 1,
+	PHYDM_5GLB2 = 2,
+	PHYDM_5GMB1 = 3,
+	PHYDM_5GMB2 = 4,
+	PHYDM_5GHB = 5,
+};
+
+
+
+void
+phydm_get_thermal_trim_offset(
+	void	*dm_void
+);
+
+void
+phydm_get_power_trim_offset(
+	void	*dm_void
+);
+
+void
+phydm_get_pa_bias_offset(
+	void	*dm_void
+);
+
+s8
+phydm_get_thermal_offset(
+	void	*dm_void
+);
+
+void
+phydm_clear_kfree_to_rf(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+);
+
+
+void
+phydm_config_kfree(
+	void	*dm_void,
+	u8	channel_to_sw
+);
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking.c
new file mode 100644
index 000000000000..db751bd774af
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking.c
@@ -0,0 +1,159 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+boolean
+odm_check_power_status(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	PADAPTER	adapter = (PADAPTER)dm->adapter;
+
+	RT_RF_POWER_STATE	rt_state;
+	MGNT_INFO	*mgnt_info	= &adapter->MgntInfo;
+
+	/* 2011/07/27 MH We are not testing ready~~!! We may fail to get correct value when init sequence. */
+	if (mgnt_info->init_adpt_in_progress == true) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "check_pow_status Return true, due to initadapter\n");
+		return	true;
+	}
+
+	/*  */
+	/*	2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK. */
+	/*  */
+	adapter->HalFunc.GetHwRegHandler(adapter, HW_VAR_RF_STATE, (u8 *)(&rt_state));
+	if (adapter->bDriverStopped || adapter->bDriverIsGoingToPnpSetPowerSleep || rt_state == eRfOff) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "check_pow_status Return false, due to %d/%d/%d\n",
+			adapter->bDriverStopped, adapter->bDriverIsGoingToPnpSetPowerSleep, rt_state);
+		return	false;
+	}
+#endif
+	return	true;
+	
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+halrf_update_pwr_track(
+	void		*dm_void,
+	u8		rate
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	u8			path_idx = 0;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Pwr Track Get rate=0x%x\n", rate);
+
+	dm->tx_rate = rate;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm->ra_rpt_workitem);
+#else
+	if (dm->support_ic_type == ODM_RTL8821) {
+#if (RTL8821A_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8812A; path_idx++) {
+#if (RTL8812A_SUPPORT == 1)
+			odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, path_idx, 0);
+#endif
+		}
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
+#if (RTL8723B_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8192E; path_idx++) {
+#if (RTL8192E_SUPPORT == 1)
+			odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, path_idx, 0);
+#endif
+		}
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	}
+#endif
+#else
+	odm_schedule_work_item(&dm->ra_rpt_workitem);
+#endif
+#endif
+
+}
+
+#endif
+
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+halrf_update_init_rate_work_item_callback(
+	void	*context
+)
+{
+	void	*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	u8		p = 0;
+
+	if (dm->support_ic_type == ODM_RTL8821) {
+		odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
+		/**/
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		for (p = RF_PATH_A; p < MAX_PATH_NUM_8812A; p++) {    /*DOn't know how to include &c*/
+
+			odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, p, 0);
+			/**/
+		}
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
+		odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
+		/**/
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		for (p = RF_PATH_A; p < MAX_PATH_NUM_8192E; p++) {   /*DOn't know how to include &c*/
+			odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, p, 0);
+			/**/
+		}
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+		odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
+		/**/
+	}
+}
+#endif
+
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking.h
new file mode 100644
index 000000000000..15e056b1fcbc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking.h
@@ -0,0 +1,50 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__HALRF_POWER_TRACKING_H__
+#define    __HALRF_POWER_TRACKING_H__
+
+
+boolean
+odm_check_power_status(
+	void		*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+halrf_update_pwr_track(
+	void		*dm_void,
+	u8		rate
+);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+halrf_update_init_rate_work_item_callback(
+	void	*context
+);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ap.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ap.c
new file mode 100644
index 000000000000..4e4e6a7fb30d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ap.c
@@ -0,0 +1,1158 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if !defined(_OUTSRC_COEXIST)
+/* ************************************************************
+ * Global var
+ * ************************************************************ */
+
+
+u32 ofdm_swing_table_new[OFDM_TABLE_SIZE_92D] = {
+	0x0b40002d, /* 0,  -15.0dB */
+	0x0c000030, /* 1,  -14.5dB */
+	0x0cc00033, /* 2,  -14.0dB */
+	0x0d800036, /* 3,  -13.5dB */
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB */
+	0x10000040, /* 6,  -12.0dB */
+	0x11000044, /* 7,  -11.5dB */
+	0x12000048, /* 8,  -11.0dB */
+	0x1300004c, /* 9,  -10.5dB */
+	0x14400051, /* 10, -10.0dB */
+	0x15800056, /* 11, -9.5dB */
+	0x16c0005b, /* 12, -9.0dB */
+	0x18000060, /* 13, -8.5dB */
+	0x19800066, /* 14, -8.0dB */
+	0x1b00006c, /* 15, -7.5dB */
+	0x1c800072, /* 16, -7.0dB */
+	0x1e400079, /* 17, -6.5dB */
+	0x20000080, /* 18, -6.0dB */
+	0x22000088, /* 19, -5.5dB */
+	0x24000090, /* 20, -5.0dB */
+	0x26000098, /* 21, -4.5dB */
+	0x288000a2, /* 22, -4.0dB */
+	0x2ac000ab, /* 23, -3.5dB */
+	0x2d4000b5, /* 24, -3.0dB */
+	0x300000c0, /* 25, -2.5dB */
+	0x32c000cb, /* 26, -2.0dB */
+	0x35c000d7, /* 27, -1.5dB */
+	0x390000e4, /* 28, -1.0dB */
+	0x3c8000f2, /* 29, -0.5dB */
+	0x40000100, /* 30, +0dB */
+	0x43c0010f, /* 31, +0.5dB */
+	0x47c0011f, /* 32, +1.0dB */
+	0x4c000130, /* 33, +1.5dB */
+	0x50800142, /* 34, +2.0dB */
+	0x55400155, /* 35, +2.5dB */
+	0x5a400169, /* 36, +3.0dB */
+	0x5fc0017f, /* 37, +3.5dB */
+	0x65400195, /* 38, +4.0dB */
+	0x6b8001ae, /* 39, +4.5dB */
+	0x71c001c7, /* 40, +5.0dB */
+	0x788001e2, /* 41, +5.5dB */
+	0x7f8001fe  /* 42, +6.0dB */
+};
+
+u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/* 32, +0dB */
+};
+
+
+u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB */
+};
+
+u32 ofdm_swing_table[OFDM_TABLE_SIZE_92D] = {
+	0x0b40002d, /* 0,  -15.0dB */
+	0x0c000030, /* 1,  -14.5dB */
+	0x0cc00033, /* 2,  -14.0dB */
+	0x0d800036, /* 3,  -13.5dB */
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB */
+	0x10000040, /* 6,  -12.0dB */
+	0x11000044, /* 7,  -11.5dB */
+	0x12000048, /* 8,  -11.0dB */
+	0x1300004c, /* 9,  -10.5dB */
+	0x14400051, /* 10, -10.0dB */
+	0x15800056, /* 11, -9.5dB */
+	0x16c0005b, /* 12, -9.0dB */
+	0x18000060, /* 13, -8.5dB */
+	0x19800066, /* 14, -8.0dB */
+	0x1b00006c, /* 15, -7.5dB */
+	0x1c800072, /* 16, -7.0dB */
+	0x1e400079, /* 17, -6.5dB */
+	0x20000080, /* 18, -6.0dB */
+	0x22000088, /* 19, -5.5dB */
+	0x24000090, /* 20, -5.0dB */
+	0x26000098, /* 21, -4.5dB */
+	0x288000a2, /* 22, -4.0dB */
+	0x2ac000ab, /* 23, -3.5dB */
+	0x2d4000b5, /* 24, -3.0dB */
+	0x300000c0, /* 25, -2.5dB */
+	0x32c000cb, /* 26, -2.0dB */
+	0x35c000d7, /* 27, -1.5dB */
+	0x390000e4, /* 28, -1.0dB */
+	0x3c8000f2, /* 29, -0.5dB */
+	0x40000100, /* 30, +0dB */
+	0x43c0010f, /* 31, +0.5dB */
+	0x47c0011f, /* 32, +1.0dB */
+	0x4c000130, /* 33, +1.5dB */
+	0x50800142, /* 34, +2.0dB */
+	0x55400155, /* 35, +2.5dB */
+	0x5a400169, /* 36, +3.0dB */
+	0x5fc0017f, /* 37, +3.5dB */
+	0x65400195, /* 38, +4.0dB */
+	0x6b8001ae, /* 39, +4.5dB */
+	0x71c001c7, /* 40, +5.0dB */
+	0x788001e2, /* 41, +5.5dB */
+	0x7f8001fe  /* 42, +6.0dB */
+};
+
+
+u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/* 32, +0dB */
+};
+
+
+u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB */
+};
+
+u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x16, 0x15, 0x13, 0x10, 0xD, 0x9, 0x6, 0x3, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 0  -16dB */
+	{0x18, 0x17, 0x15, 0x12, 0xE, 0xA, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 1  -15.5dB */
+	{0x1B, 0x1A, 0x18, 0x14, 0x10, 0xB, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 2  -15dB */
+	{0x1F, 0x1E, 0x1B, 0x17, 0x12, 0xD, 0x8, 0x5, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 3  -14.5dB */
+	{0x22, 0x21, 0x1E, 0x19, 0x14, 0xE, 0x9, 0x5, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 4  -14dB */
+	{0x26, 0x25, 0x22, 0x1C, 0x16, 0x10, 0xA, 0x6, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 5  -13.5dB */
+	{0x2B, 0x2A, 0x26, 0x20, 0x19, 0x12, 0xC, 0x7, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 6  -13dB */
+	{0x30, 0x2F, 0x2A, 0x24, 0x1C, 0x14, 0xD, 0x8, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 7  -12.5dB */
+	{0x36, 0x34, 0x2F, 0x28, 0x1F, 0x17, 0xF, 0x9, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 8  -12dB */
+	{0x3D, 0x3B, 0x35, 0x2D, 0x23, 0x19, 0x11, 0xA, 0x5, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 9  -11.5dB */
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0xB, 0x5, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 10  -11dB */
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0xC, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 11  -10.5dB */
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0xE, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 12  -10dB */
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0xF, 0x7, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 13  -9.5dB */
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x8, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 14  -9dB */
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x9, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 15  -8.5dB */
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0xA, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 16  -8dB */
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0xB, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 17  -7.5dB */
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0xD, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 18  -7dB */
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0xE, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 19  -6.5dB */
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x5, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}      /* 20  -6dB */
+};
+
+
+u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x16, 0x15, 0x13, 0x10, 0xD, 0x9, 0x6, 0x3, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 0  -16dB */
+	{0x18, 0x17, 0x15, 0x12, 0xE, 0xA, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 1  -15.5dB */
+	{0x1B, 0x1A, 0x18, 0x14, 0x10, 0xB, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 2  -15dB */
+	{0x1F, 0x1E, 0x1B, 0x17, 0x12, 0xD, 0x8, 0x5, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 3  -14.5dB */
+	{0x22, 0x21, 0x1E, 0x19, 0x14, 0xE, 0x9, 0x5, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 4  -14dB */
+	{0x26, 0x25, 0x22, 0x1C, 0x16, 0x10, 0xA, 0x6, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 5  -13.5dB */
+	{0x2B, 0x2A, 0x26, 0x20, 0x19, 0x12, 0xC, 0x7, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 6  -13dB */
+	{0x30, 0x2F, 0x2A, 0x24, 0x1C, 0x14, 0xD, 0x8, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 7  -12.5dB */
+	{0x36, 0x34, 0x2F, 0x28, 0x1F, 0x17, 0xF, 0x9, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 8  -12dB */
+	{0x3D, 0x3B, 0x35, 0x2D, 0x23, 0x19, 0x11, 0xA, 0x5, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 9  -11.5dB */
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0xB, 0x5, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 10  -11dB */
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0xC, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 11  -10.5dB */
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0xE, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 12  -10dB */
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0xF, 0x7, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 13  -9.5dB */
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x8, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 14  -9dB */
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x9, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 15  -8.5dB */
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0xA, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 16  -8dB */
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0xB, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 17  -7.5dB */
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0xD, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 18  -7dB */
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0xE, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 19  -6.5dB */
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x5, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}      /* 20  -6dB */
+};
+
+
+u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+
+#if 0
+u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E] = {
+	/* Index0   6  dB */ 0x7fc001ff,
+	/* Index1   5.7dB */ 0x7b4001ed,
+	/* Index2   5.4dB */ 0x774001dd,
+	/* Index3   5.1dB */ 0x734001cd,
+	/* Index4   4.8dB */ 0x6f4001bd,
+	/* Index5   4.5dB */ 0x6b8001ae,
+	/* Index6   4.2dB */ 0x67c0019f,
+	/* Index7   3.9dB */ 0x64400191,
+	/* Index8   3.6dB */ 0x60c00183,
+	/* Index9   3.3dB */ 0x5d800176,
+	/* Index10  3  dB */ 0x5a80016a,
+	/* Index11  2.7dB */ 0x5740015d,
+	/* Index12  2.4dB */ 0x54400151,
+	/* Index13  2.1dB */ 0x51800146,
+	/* Index14  1.8dB */ 0x4ec0013b,
+	/* Index15  1.5dB */ 0x4c000130,
+	/* Index16  1.2dB */ 0x49800126,
+	/* Index17  0.9dB */ 0x4700011c,
+	/* Index18  0.6dB */ 0x44800112,
+	/* Index19  0.3dB */ 0x42000108,
+	/* Index20  0  dB */ 0x40000100, /* 20 This is OFDM base index */
+	/* Index21 -0.3dB */ 0x3dc000f7,
+	/* Index22 -0.6dB */ 0x3bc000ef,
+	/* Index23 -0.9dB */ 0x39c000e7,
+	/* Index24 -1.2dB */ 0x37c000df,
+	/* Index25 -1.5dB */ 0x35c000d7,
+	/* Index26 -1.8dB */ 0x340000d0,
+	/* Index27 -2.1dB */ 0x324000c9,
+	/* Index28 -2.4dB */ 0x308000c2,
+	/* Index29 -2.7dB */ 0x2f0000bc,
+	/* Index30 -3  dB */ 0x2d4000b5,
+	/* Index31 -3.3dB */ 0x2bc000af,
+	/* Index32 -3.6dB */ 0x2a4000a9,
+	/* Index33 -3.9dB */ 0x28c000a3,
+	/* Index34 -4.2dB */ 0x2780009e,
+	/* Index35 -4.5dB */ 0x26000098,
+	/* Index36 -4.8dB */ 0x24c00093,
+	/* Index37 -5.1dB */ 0x2380008e,
+	/* Index38 -5.4dB */ 0x22400089,
+	/* Index39 -5.7dB */ 0x21400085,
+	/* Index40 -6  dB */ 0x20000080,
+	/* Index41 -6.3dB */ 0x1f00007c,
+	/* Index42 -6.6dB */ 0x1e000078,
+	/* Index43 -6.9dB */ 0x1d000074,
+	/* Index44 -7.2dB */ 0x1c000070,
+	/* Index45 -7.5dB */ 0x1b00006c,
+	/* Index46 -7.8dB */ 0x1a000068,
+	/* Index47 -8.1dB */ 0x19400065,
+	/* Index48 -8.4dB */ 0x18400061,
+	/* Index49 -8.7dB */ 0x1780005e,
+	/* Index50 -9  dB */ 0x16c0005b,
+	/* Index51 -9.3dB */ 0x16000058,
+	/* Index52 -9.6dB */ 0x15400055,
+	/* Index53 -9.9dB */ 0x14800052
+};
+u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x1C, 0x12, 0x08, 0x04},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x1B, 0x11, 0x08, 0x04},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x1A, 0x11, 0x07, 0x04},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x19, 0x10, 0x07, 0x04},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x18, 0x10, 0x07, 0x03},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x18, 0x0F, 0x07, 0x03},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x17, 0x0F, 0x06, 0x03},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x16, 0x0E, 0x06, 0x03},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x15, 0x0E, 0x06, 0x03},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x14, 0x0D, 0x06, 0x03},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x14, 0x0D, 0x06, 0x03},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x13, 0x0C, 0x05, 0x03},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x12, 0x0C, 0x05, 0x03},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x12, 0x0B, 0x05, 0x03},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x10, 0x0A, 0x05, 0x02},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x10, 0x0A, 0x04, 0x02},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x0F, 0x0A, 0x04, 0x02},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x0E, 0x09, 0x04, 0x02},
+	/* Index20  -6.0dB */    {0x1B, 0x1A, 0x17, 0x13, 0x0E, 0x09, 0x04, 0x02}, /* 20 This is CCK base index */
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x0E, 0x09, 0x04, 0x02},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x0D, 0x08, 0x04, 0x02},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x0D, 0x08, 0x04, 0x02},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x0C, 0x08, 0x03, 0x02},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x0C, 0x08, 0x03, 0x02},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x0B, 0x07, 0x03, 0x02},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x0A, 0x07, 0x03, 0x01},
+	/* Index30  -9.0dB */    {0x13, 0x12, 0x10, 0x0D, 0x0A, 0x06, 0x03, 0x01}, /* 30 This is hp CCK base index */
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x0A, 0x06, 0x03, 0x01},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x09, 0x06, 0x03, 0x01},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x09, 0x06, 0x03, 0x01},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x09, 0x06, 0x02, 0x01},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x08, 0x05, 0x02, 0x01},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x06, 0x04, 0x02, 0x01},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x06, 0x04, 0x02, 0x01},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}
+};
+u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x00, 0x00, 0x00, 0x00},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x00, 0x00, 0x00, 0x00},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x00, 0x00, 0x00, 0x00},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x00, 0x00, 0x00, 0x00},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x00, 0x00, 0x00, 0x00},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x00, 0x00, 0x00, 0x00},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x00, 0x00, 0x00, 0x00},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x00, 0x00, 0x00, 0x00},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x00, 0x00, 0x00, 0x00},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x00, 0x00, 0x00, 0x00},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x00, 0x00, 0x00, 0x00},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x00, 0x00, 0x00, 0x00},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x00, 0x00, 0x00, 0x00},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x00, 0x00, 0x00, 0x00},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x00, 0x00, 0x00, 0x00},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x00, 0x00, 0x00, 0x00},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index20  -6  dB */     {0x1B, 0x1A, 0x17, 0x13, 0x00, 0x00, 0x00, 0x00},
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x00, 0x00, 0x00, 0x00},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index30  -9  dB */    {0x13, 0x12, 0x10, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x00, 0x00, 0x00, 0x00}
+};
+#endif
+#endif
+
+
+u8 delta_swing_table_idx_2ga_p_default[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3
+	, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9
+							      };
+u8 delta_swing_table_idx_2ga_n_default[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4
+	, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11
+							      };
+
+
+#ifdef CONFIG_WLAN_HAL_8192EE
+u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E] = {
+	/* Index0   6  dB */ 0x7fc001ff,
+	/* Index1   5.7dB */ 0x7b4001ed,
+	/* Index2   5.4dB */ 0x774001dd,
+	/* Index3   5.1dB */ 0x734001cd,
+	/* Index4   4.8dB */ 0x6f4001bd,
+	/* Index5   4.5dB */ 0x6b8001ae,
+	/* Index6   4.2dB */ 0x67c0019f,
+	/* Index7   3.9dB */ 0x64400191,
+	/* Index8   3.6dB */ 0x60c00183,
+	/* Index9   3.3dB */ 0x5d800176,
+	/* Index10  3  dB */ 0x5a80016a,
+	/* Index11  2.7dB */ 0x5740015d,
+	/* Index12  2.4dB */ 0x54400151,
+	/* Index13  2.1dB */ 0x51800146,
+	/* Index14  1.8dB */ 0x4ec0013b,
+	/* Index15  1.5dB */ 0x4c000130,
+	/* Index16  1.2dB */ 0x49800126,
+	/* Index17  0.9dB */ 0x4700011c,
+	/* Index18  0.6dB */ 0x44800112,
+	/* Index19  0.3dB */ 0x42000108,
+	/* Index20  0  dB */ 0x40000100, /* 20 This is OFDM base index */
+	/* Index21 -0.3dB */ 0x3dc000f7,
+	/* Index22 -0.6dB */ 0x3bc000ef,
+	/* Index23 -0.9dB */ 0x39c000e7,
+	/* Index24 -1.2dB */ 0x37c000df,
+	/* Index25 -1.5dB */ 0x35c000d7,
+	/* Index26 -1.8dB */ 0x340000d0,
+	/* Index27 -2.1dB */ 0x324000c9,
+	/* Index28 -2.4dB */ 0x308000c2,
+	/* Index29 -2.7dB */ 0x2f0000bc,
+	/* Index30 -3  dB */ 0x2d4000b5,
+	/* Index31 -3.3dB */ 0x2bc000af,
+	/* Index32 -3.6dB */ 0x2a4000a9,
+	/* Index33 -3.9dB */ 0x28c000a3,
+	/* Index34 -4.2dB */ 0x2780009e,
+	/* Index35 -4.5dB */ 0x26000098,
+	/* Index36 -4.8dB */ 0x24c00093,
+	/* Index37 -5.1dB */ 0x2380008e,
+	/* Index38 -5.4dB */ 0x22400089,
+	/* Index39 -5.7dB */ 0x21400085,
+	/* Index40 -6  dB */ 0x20000080,
+	/* Index41 -6.3dB */ 0x1f00007c,
+	/* Index42 -6.6dB */ 0x1e000078,
+	/* Index43 -6.9dB */ 0x1d000074,
+	/* Index44 -7.2dB */ 0x1c000070,
+	/* Index45 -7.5dB */ 0x1b00006c,
+	/* Index46 -7.8dB */ 0x1a000068,
+	/* Index47 -8.1dB */ 0x19400065,
+	/* Index48 -8.4dB */ 0x18400061,
+	/* Index49 -8.7dB */ 0x1780005e,
+	/* Index50 -9  dB */ 0x16c0005b,
+	/* Index51 -9.3dB */ 0x16000058,
+	/* Index52 -9.6dB */ 0x15400055,
+	/* Index53 -9.9dB */ 0x14800052
+};
+u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x1C, 0x12, 0x08, 0x04},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x1B, 0x11, 0x08, 0x04},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x1A, 0x11, 0x07, 0x04},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x19, 0x10, 0x07, 0x04},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x18, 0x10, 0x07, 0x03},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x18, 0x0F, 0x07, 0x03},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x17, 0x0F, 0x06, 0x03},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x16, 0x0E, 0x06, 0x03},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x15, 0x0E, 0x06, 0x03},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x14, 0x0D, 0x06, 0x03},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x14, 0x0D, 0x06, 0x03},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x13, 0x0C, 0x05, 0x03},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x12, 0x0C, 0x05, 0x03},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x12, 0x0B, 0x05, 0x03},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x10, 0x0A, 0x05, 0x02},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x10, 0x0A, 0x04, 0x02},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x0F, 0x0A, 0x04, 0x02},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x0E, 0x09, 0x04, 0x02},
+	/* Index20  -6.0dB */    {0x1B, 0x1A, 0x17, 0x13, 0x0E, 0x09, 0x04, 0x02}, /* 20 This is CCK base index */
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x0E, 0x09, 0x04, 0x02},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x0D, 0x08, 0x04, 0x02},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x0D, 0x08, 0x04, 0x02},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x0C, 0x08, 0x03, 0x02},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x0C, 0x08, 0x03, 0x02},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x0B, 0x07, 0x03, 0x02},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x0A, 0x07, 0x03, 0x01},
+	/* Index30  -9.0dB */    {0x13, 0x12, 0x10, 0x0D, 0x0A, 0x06, 0x03, 0x01}, /* 30 This is hp CCK base index */
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x0A, 0x06, 0x03, 0x01},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x09, 0x06, 0x03, 0x01},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x09, 0x06, 0x03, 0x01},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x09, 0x06, 0x02, 0x01},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x08, 0x05, 0x02, 0x01},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x06, 0x04, 0x02, 0x01},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x06, 0x04, 0x02, 0x01},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}
+};
+u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x00, 0x00, 0x00, 0x00},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x00, 0x00, 0x00, 0x00},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x00, 0x00, 0x00, 0x00},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x00, 0x00, 0x00, 0x00},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x00, 0x00, 0x00, 0x00},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x00, 0x00, 0x00, 0x00},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x00, 0x00, 0x00, 0x00},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x00, 0x00, 0x00, 0x00},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x00, 0x00, 0x00, 0x00},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x00, 0x00, 0x00, 0x00},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x00, 0x00, 0x00, 0x00},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x00, 0x00, 0x00, 0x00},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x00, 0x00, 0x00, 0x00},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x00, 0x00, 0x00, 0x00},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x00, 0x00, 0x00, 0x00},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x00, 0x00, 0x00, 0x00},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index20  -6  dB */     {0x1B, 0x1A, 0x17, 0x13, 0x00, 0x00, 0x00, 0x00},
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x00, 0x00, 0x00, 0x00},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index30  -9  dB */    {0x13, 0x12, 0x10, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x00, 0x00, 0x00, 0x00}
+};
+#endif
+
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
+	0x081, /* 0,  -12.0dB */
+	0x088, /* 1,  -11.5dB */
+	0x090, /* 2,  -11.0dB */
+	0x099, /* 3,  -10.5dB */
+	0x0A2, /* 4,  -10.0dB */
+	0x0AC, /* 5,  -9.5dB */
+	0x0B6, /* 6,  -9.0dB */
+	0x0C0, /* 7,  -8.5dB */
+	0x0CC, /* 8,  -8.0dB */
+	0x0D8, /* 9,  -7.5dB */
+	0x0E5, /* 10, -7.0dB */
+	0x0F2, /* 11, -6.5dB */
+	0x101, /* 12, -6.0dB */
+	0x110, /* 13, -5.5dB */
+	0x120, /* 14, -5.0dB */
+	0x131, /* 15, -4.5dB */
+	0x143, /* 16, -4.0dB */
+	0x156, /* 17, -3.5dB */
+	0x16A, /* 18, -3.0dB */
+	0x180, /* 19, -2.5dB */
+	0x197, /* 20, -2.0dB */
+	0x1AF, /* 21, -1.5dB */
+	0x1C8, /* 22, -1.0dB */
+	0x1E3, /* 23, -0.5dB */
+	0x200, /* 24, +0  dB */
+	0x21E, /* 25, +0.5dB */
+	0x23E, /* 26, +1.0dB */
+	0x261, /* 27, +1.5dB */
+	0x285, /* 28, +2.0dB */
+	0x2AB, /* 29, +2.5dB */
+	0x2D3, /* 30, +3.0dB */
+	0x2FE, /* 31, +3.5dB */
+	0x32B, /* 32, +4.0dB */
+	0x35C, /* 33, +4.5dB */
+	0x38E, /* 34, +5.0dB */
+	0x3C4, /* 35, +5.5dB */
+	0x3FE  /* 36, +6.0dB */
+};
+#elif(ODM_IC_11AC_SERIES_SUPPORT)
+u32 ofdm_swing_table_8812[OFDM_TABLE_SIZE_8812] = {
+	0x3FE, /* 0,  (6dB) */
+	0x3C4, /* 1,  (5.5dB) */
+	0x38E, /* 2,  (5dB) */
+	0x35C, /* 3,  (4.5dB) */
+	0x32B, /* 4,  (4dB) */
+	0x2FE, /* 5,  (3.5dB) */
+	0x2D3, /* 6,  (3dB) */
+	0x2AB, /* 7,  (2.5dB) */
+	0x285, /* 8,  (2dB) */
+	0x261, /* 9,  (1.5dB */
+	0x23E, /* 10, (1dB) */
+	0x21E, /* 11, (0.5dB) */
+	0x200, /* 12, (0dB)		8814 int PA 2G default */
+	0x1E3, /* 13, (-0.5dB) */
+	0x1C8, /* 14, (-1dB) */
+	0x1AF, /* 15, (-1.5dB) */
+	0x197, /* 16, (-2dB) */
+	0x180, /* 17, (-2.5dB) */
+	0x16A, /* 18, (-3dB)		8812 / 8814 int PA 5G / 8814 ext PA 2G5G default */
+	0x156, /* 19, (-3.5dB) */
+	0x143, /* 20, (-4dB)		8812 HP default */
+	0x131, /* 21, (-4.5dB) */
+	0x120, /* 22, (-5dB) */
+	0x110, /* 23, (-5.5dB) */
+	0x101, /* 24, (-6dB) */
+	0x0F2, /* 25, (-6.5dB) */
+	0x0E5, /* 26, (-7dB) */
+	0x0D8, /* 27, (-7.5dB) */
+	0x0CC, /* 28, (-8dB) */
+	0x0C0, /* 29, (-8.5dB) */
+	0x0B6, /* 30, (-9dB) */
+	0x0AC, /* 31, (-9.5dB) */
+	0x0A2, /* 32, (-10dB) */
+	0x099, /* 33, (-10.5dB) */
+	0x090, /* 34, (-11dB) */
+	0x088, /* 35, (-11.5dB) */
+	0x081, /* 36, (-12dB) */
+	0x079, /* 37, (-12.5dB) */
+	0x072, /* 38, (-13dB) */
+	0x06c, /* 39, (-13.5dB) */
+	0x066, /* 40, (-14dB) */
+	0x060, /* 41, (-14.5dB) */
+	0x05B  /* 42, (-15dB) */
+};
+#endif
+
+u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
+	0x0CD,
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+/* JJ ADD 20161014 */
+u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
+	0x0CD,
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+
+/* #endif */
+/* 3============================================================
+ * 3 Tx Power Tracking
+ * 3============================================================ */
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_IC_11N_SERIES)))
+		return;
+#endif
+
+	odm_txpowertracking_thermal_meter_init(dm);
+}
+
+
+u8
+get_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			i = 0, bb_swing_mask = 0;
+	u32			bb_swing = 0;
+	u32			swing_table_size = 0;
+	u32			*swing_table = 0;
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+#if (RTL8197F_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8197F) {
+		bb_swing = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
+		swing_table = ofdm_swing_table_new;
+		swing_table_size = OFDM_TABLE_SIZE_92D;
+		bb_swing_mask = 22;
+	}
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8822B) {
+		bb_swing = phy_query_bb_reg(priv, REG_A_TX_SCALE_JAGUAR, 0xFFE00000);
+		swing_table = tx_scaling_table_jaguar;
+		swing_table_size = TXSCALE_TABLE_SIZE;
+		bb_swing_mask = 0;
+	}
+#endif
+
+	for (i = 0; i < swing_table_size - 1; i++) {
+		u32 table_value = swing_table[i] >> bb_swing_mask;
+
+		if (bb_swing == table_value)
+			break;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "bb_swing=0x%x bbswing_index=%d\n", bb_swing, i);
+
+
+	return i;
+}
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct rtl8192cd_priv		*priv = dm->priv;
+	u8 p;
+	u8 default_swing_index;
+#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	if ((GET_CHIP_VER(priv) == VERSION_8197F) || (GET_CHIP_VER(priv) == VERSION_8822B))
+		default_swing_index = get_swing_index(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	PMGNT_INFO	mgnt_info = &adapter->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	mgnt_info->is_txpowertracking = true;
+	hal_data->tx_powercount       = 0;
+	hal_data->is_txpowertracking_init = false;
+
+	if (*(dm->mp_mode) == false)
+		hal_data->txpowertrack_control = true;
+	PHYDM_DBG(dm, COMP_POWER_TRACKING, "mgnt_info->is_txpowertracking = %d\n", mgnt_info->is_txpowertracking);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#ifdef CONFIG_RTL8188E
+	{
+		dm->rf_calibrate_info.is_txpowertracking = true;
+		dm->rf_calibrate_info.tx_powercount = 0;
+		dm->rf_calibrate_info.is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)
+			dm->rf_calibrate_info.txpowertrack_control = true;
+
+		MSG_8192C("dm txpowertrack_control = %d\n", dm->rf_calibrate_info.txpowertrack_control);
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+		struct dm_priv	*pdmpriv = &hal_data->dmpriv;
+		
+		pdmpriv->is_txpowertracking = true;
+		pdmpriv->tx_powercount = 0;
+		pdmpriv->is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)		/* for mp driver, turn off txpwrtracking as default */
+			pdmpriv->txpowertrack_control = true;
+
+		MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
+
+	}
+#endif/* endif (CONFIG_RTL8188E==1) */
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#ifdef RTL8188E_SUPPORT
+	{
+		dm->rf_calibrate_info.is_txpowertracking = true;
+		dm->rf_calibrate_info.tx_powercount = 0;
+		dm->rf_calibrate_info.is_txpowertracking_init = false;
+		dm->rf_calibrate_info.txpowertrack_control = true;
+		dm->rf_calibrate_info.tm_trigger = 0;
+	}
+#endif
+#endif
+
+	dm->rf_calibrate_info.txpowertrack_control = true;
+	dm->rf_calibrate_info.delta_power_index = 0;
+	dm->rf_calibrate_info.delta_power_index_last = 0;
+	dm->rf_calibrate_info.power_index_offset = 0;
+	dm->rf_calibrate_info.thermal_value = 0;
+	cali_info->default_ofdm_index = 28;
+
+#if (RTL8197F_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8197F) {
+		cali_info->default_ofdm_index = (default_swing_index >= (OFDM_TABLE_SIZE_92D - 1)) ? 30 : default_swing_index;
+		cali_info->default_cck_index = 28;
+	}
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8822B) {
+		cali_info->default_ofdm_index = (default_swing_index >= (TXSCALE_TABLE_SIZE - 1)) ? 24 : default_swing_index;
+		cali_info->default_cck_index = 20;
+	}
+#endif
+
+
+#if RTL8188E_SUPPORT
+	cali_info->default_cck_index = 20;	/* -6 dB */
+#elif RTL8192E_SUPPORT
+	cali_info->default_cck_index = 8;	/* -12 dB */
+#endif
+	cali_info->bb_swing_idx_ofdm_base = cali_info->default_ofdm_index;
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	dm->rf_calibrate_info.CCK_index = cali_info->default_cck_index;
+
+	for (p = 0; p < MAX_RF_PATH; p++) {
+		dm->rf_calibrate_info.OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->kfree_offset[p] = 0;	/* for 8814 kfree*/
+	}
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "cali_info->default_ofdm_index=%d cali_info->default_cck_index=%d\n", cali_info->default_ofdm_index, cali_info->default_cck_index);
+
+	cali_info->tm_trigger = 0;
+}
+
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+)
+{
+	/*  */
+	/* For AP/ADSL use struct rtl8192cd_priv* */
+	/* For CE/NIC use struct void* */
+	/*  */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	/*  */
+	/* 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. */
+	/*  */
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_txpowertracking_check_mp(dm);
+		break;
+
+	case	ODM_CE:
+		odm_txpowertracking_check_ce(dm);
+		break;
+
+	case	ODM_AP:
+		odm_txpowertracking_check_ap(dm);
+		break;
+	}
+
+}
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+
+#if (RTL8188E_SUPPORT == 1)
+
+	/* if(!mgnt_info->is_txpowertracking || (!pdmpriv->txpowertrack_control && pdmpriv->is_ap_kdone)) */
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	if (!dm->rf_calibrate_info.tm_trigger) {	/* at least delay 1 sec */
+		/* hal_data->TxPowerCheckCnt++;	 */ /* cosa add for debug */
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+		/* DBG_8192C("Trigger 92C Thermal Meter!!\n"); */
+
+		dm->rf_calibrate_info.tm_trigger = 1;
+		return;
+
+	} else {
+		/* DBG_8192C("Schedule TxPowerTracking direct call!!\n"); */
+		odm_txpowertracking_callback_thermal_meter_8188e(adapter);
+		dm->rf_calibrate_info.tm_trigger = 0;
+	}
+#endif
+
+#endif
+}
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+
+	if (odm_check_power_status(adapter) == false)
+		return;
+
+	if (!adapter->is_slave_of_dmsp || adapter->dual_mac_smart_concurrent == false)
+		odm_txpowertracking_thermal_meter_check(adapter);
+#endif
+
+}
+
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct rtl8192cd_priv	*priv		= dm->priv;
+
+#if ((RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8881A | ODM_RTL8814A | ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8821C))
+		odm_txpowertracking_callback_thermal_meter(dm);
+	else
+#endif
+	{
+	}
+#endif
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ap.h
new file mode 100644
index 000000000000..703b876421c6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ap.h
@@ -0,0 +1,345 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDMPOWERTRACKING_H__
+#define    __PHYDMPOWERTRACKING_H__
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#ifdef RTK_AC_SUPPORT
+		#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#else
+		#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#endif
+#else
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+#endif
+
+#define		DPK_DELTA_MAPPING_NUM	13
+#define		index_mapping_HP_NUM	15
+#define		DELTA_SWINGIDX_SIZE     30
+#define		DELTA_SWINTSSI_SIZE     61
+#define		BAND_NUM				3
+#define		MAX_RF_PATH	4
+#define		TXSCALE_TABLE_SIZE		37
+#define		CCK_TABLE_SIZE_8723D		41
+/* JJ ADD 20161014 */
+#define		CCK_TABLE_SIZE_8710B		41
+
+#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 AVG_THERMAL_NUM		8
+#define iqk_matrix_reg_num	8
+/* #define IQK_MATRIX_SETTINGS_NUM	1+24+21 */
+#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+
+#if !defined(_OUTSRC_COEXIST)
+	#define	OFDM_TABLE_SIZE_92D	43
+	#define	OFDM_TABLE_SIZE	37
+	#define	CCK_TABLE_SIZE		33
+	#define	CCK_TABLE_SIZE_88F	21
+
+
+
+	/* #define	OFDM_TABLE_SIZE_92E	54 */
+	/* #define	CCK_TABLE_SIZE_92E	54 */
+	extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE_92D];
+	extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+	extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+
+	extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE_92D];
+	extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+	extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+	extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+	extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+	extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+
+#endif
+
+#define	ODM_OFDM_TABLE_SIZE	37
+#define	ODM_CCK_TABLE_SIZE		33
+/* <20140613, YuChen> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+extern u8 delta_swing_table_idx_2ga_p_default[DELTA_SWINGIDX_SIZE];
+extern u8 delta_swing_table_idx_2ga_n_default[DELTA_SWINGIDX_SIZE];
+
+static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+
+/* extern	u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E];
+ * extern	u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8];
+ * extern	u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8]; */
+
+#ifdef CONFIG_WLAN_HAL_8192EE
+	#define	OFDM_TABLE_SIZE_92E	54
+	#define	CCK_TABLE_SIZE_92E	54
+	extern	u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E];
+	extern	u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8];
+	extern	u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8];
+#endif
+
+#define	OFDM_TABLE_SIZE_8812	43
+#define	AVG_THERMAL_NUM_8812	4
+
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+	#elif(ODM_IC_11AC_SERIES_SUPPORT)
+	extern unsigned int ofdm_swing_table_8812[OFDM_TABLE_SIZE_8812];
+#endif
+
+extern u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/* JJ ADD 20161014 */
+extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+
+#define dm_check_txpowertracking	odm_txpowertracking_check
+
+struct iqk_matrix_regs_setting {
+	boolean	is_iqk_done;
+	s32		value[1][iqk_matrix_reg_num];
+};
+
+struct dm_rf_calibration_struct {
+	/* for tx power tracking */
+
+	u32	rega24; /* for TempCCK */
+	s32	rege94;
+	s32	rege9c;
+	s32	regeb4;
+	s32	regebc;
+
+	/* u8 is_txpowertracking; */
+	u8	tx_powercount;
+	boolean is_txpowertracking_init;
+	boolean is_txpowertracking;
+	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
+	u8	tm_trigger;
+	u8  	internal_pa_5g[2];	/* pathA / pathB */
+
+	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8	thermal_value;
+	u8	thermal_value_lck;
+	u8	thermal_value_iqk;
+	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8	thermal_value_dpk;
+	u8	thermal_value_avg[AVG_THERMAL_NUM];
+	u8	thermal_value_avg_index;
+	u8	thermal_value_rx_gain;
+	u8	thermal_value_crystal;
+	u8	thermal_value_dpk_store;
+	u8	thermal_value_dpk_track;
+	boolean	txpowertracking_in_progress;
+	boolean	is_dpk_enable;
+
+	boolean	is_reloadtxpowerindex;
+	u8	is_rf_pi_enable;
+	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
+
+	u8	is_cck_in_ch14;
+	u8	CCK_index;
+	u8	OFDM_index[MAX_RF_PATH];
+	s8	power_index_offset;
+	s8	delta_power_index;
+	s8	delta_power_index_last;
+	boolean is_tx_power_changed;
+
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8	delta_lck;
+	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8			bb_swing_idx_ofdm_current;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+#else
+	u8			bb_swing_idx_ofdm_base;
+#endif
+	boolean			bb_swing_flag_ofdm;
+	u8			bb_swing_idx_cck;
+	u8			bb_swing_idx_cck_current;
+	u8			bb_swing_idx_cck_base;
+	u8			default_ofdm_index;
+	u8			default_cck_index;
+	boolean			bb_swing_flag_cck;
+
+	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8			absolute_cck_swing_idx[MAX_RF_PATH];
+	s8			remnant_cck_swing_idx;
+	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
+	boolean			modify_tx_agc_flag_path_a;
+	boolean			modify_tx_agc_flag_path_b;
+	boolean			modify_tx_agc_flag_path_c;
+	boolean			modify_tx_agc_flag_path_d;
+	boolean			modify_tx_agc_flag_path_a_cck;
+
+	s8			kfree_offset[MAX_RF_PATH];
+
+	/* -------------------------------------------------------------------- */
+
+	/* for IQK */
+	u32	regc04;
+	u32	reg874;
+	u32	regc08;
+	u32	regb68;
+	u32	regb6c;
+	u32	reg870;
+	u32	reg860;
+	u32	reg864;
+
+	boolean	is_iqk_initialized;
+	boolean is_lck_in_progress;
+	boolean	is_antenna_detected;
+	boolean	is_need_iqk;
+	boolean	is_iqk_in_progress;
+	boolean	is_iqk_pa_off;
+	u8	delta_iqk;
+	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];
+	u32	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
+	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+
+	u64	iqk_start_time;
+	u64	iqk_total_progressing_time;
+	u64	iqk_progressing_time;
+	u64	lck_progressing_time;
+	u32  lok_result;
+	u8	iqk_step;
+	u8	kcount;
+	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean	is_mp_mode;
+
+	/* for APK */
+	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8	is_ap_kdone;
+	u8	is_apk_thermal_meter_ignore;
+	u8	is_dp_done;
+	u8	is_dp_path_aok;
+	u8	is_dp_path_bok;
+
+	/*Add by Yuchen for Kfree Phydm*/
+	u8			reg_rf_kfree_enable;	/*for registry*/
+	u8			rf_kfree_enable;		/*for efuse enable check*/
+	u32	tx_lok[2];
+};
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+);
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+void
+odm_txpowertracking_callback_thermal_meter92c(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_rx_gain_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_direct_call92c(
+	void		*adapter
+);
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+);
+
+#endif
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ce.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ce.c
new file mode 100644
index 000000000000..6b8402ee0a5c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ce.c
@@ -0,0 +1,761 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*============================================================	*/
+/* include files												*/
+/*============================================================	*/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ************************************************************
+ * Global var
+ * ************************************************************ */
+
+u32	ofdm_swing_table[OFDM_TABLE_SIZE] = {
+	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*/
+};
+
+u8	cck_swing_table_ch1_ch13[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 <== default */
+	{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	cck_swing_table_ch14[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  <== default*/
+	{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*/
+};
+
+
+u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
+	0x0b40002d, /* 0,  -15.0dB	*/
+	0x0c000030, /* 1,  -14.5dB*/
+	0x0cc00033, /* 2,  -14.0dB*/
+	0x0d800036, /* 3,  -13.5dB*/
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB*/
+	0x10000040, /* 6,  -12.0dB*/
+	0x11000044, /* 7,  -11.5dB*/
+	0x12000048, /* 8,  -11.0dB*/
+	0x1300004c, /* 9,  -10.5dB*/
+	0x14400051, /* 10, -10.0dB*/
+	0x15800056, /* 11, -9.5dB*/
+	0x16c0005b, /* 12, -9.0dB*/
+	0x18000060, /* 13, -8.5dB*/
+	0x19800066, /* 14, -8.0dB*/
+	0x1b00006c, /* 15, -7.5dB*/
+	0x1c800072, /* 16, -7.0dB*/
+	0x1e400079, /* 17, -6.5dB*/
+	0x20000080, /* 18, -6.0dB*/
+	0x22000088, /* 19, -5.5dB*/
+	0x24000090, /* 20, -5.0dB*/
+	0x26000098, /* 21, -4.5dB*/
+	0x288000a2, /* 22, -4.0dB*/
+	0x2ac000ab, /* 23, -3.5dB*/
+	0x2d4000b5, /* 24, -3.0dB*/
+	0x300000c0, /* 25, -2.5dB*/
+	0x32c000cb, /* 26, -2.0dB*/
+	0x35c000d7, /* 27, -1.5dB*/
+	0x390000e4, /* 28, -1.0dB*/
+	0x3c8000f2, /* 29, -0.5dB*/
+	0x40000100, /* 30, +0dB*/
+	0x43c0010f, /* 31, +0.5dB*/
+	0x47c0011f, /* 32, +1.0dB*/
+	0x4c000130, /* 33, +1.5dB*/
+	0x50800142, /* 34, +2.0dB*/
+	0x55400155, /* 35, +2.5dB*/
+	0x5a400169, /* 36, +3.0dB*/
+	0x5fc0017f, /* 37, +3.5dB*/
+	0x65400195, /* 38, +4.0dB*/
+	0x6b8001ae, /* 39, +4.5dB*/
+	0x71c001c7, /* 40, +5.0dB*/
+	0x788001e2, /* 41, +5.5dB*/
+	0x7f8001fe  /* 42, +6.0dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/*  0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/*   1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/*  2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/*   3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/*   6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/*   7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/*  8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/*   9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/*  14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/*  15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/*  16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/*  17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/*  18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/*  19, -6.5dB*/
+	{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	/*20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/*  21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/*  23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/*  24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/*  25, -3.5dB*/
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/*  26, -3.0dB*/
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/*  27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/*  28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/*  29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/*  30, -1.0dB*/
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/*  31, -0.5dB*/
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/*  32, +0dB*/
+};
+
+
+u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/*  0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/*5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/*  7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/*11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/*14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/*23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/*27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/*29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB	*/
+};
+u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
+	0x0CD,          /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+/* JJ ADD 20161014 */
+u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
+	0x0CD,          /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+
+u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
+	0x081, /* 0,  -12.0dB*/
+	0x088, /* 1,  -11.5dB*/
+	0x090, /* 2,  -11.0dB*/
+	0x099, /* 3,  -10.5dB*/
+	0x0A2, /* 4,  -10.0dB*/
+	0x0AC, /* 5,  -9.5dB*/
+	0x0B6, /* 6,  -9.0dB*/
+	0x0C0, /*7,  -8.5dB*/
+	0x0CC, /* 8,  -8.0dB*/
+	0x0D8, /* 9,  -7.5dB*/
+	0x0E5, /* 10, -7.0dB*/
+	0x0F2, /* 11, -6.5dB*/
+	0x101, /* 12, -6.0dB*/
+	0x110, /* 13, -5.5dB*/
+	0x120, /* 14, -5.0dB*/
+	0x131, /* 15, -4.5dB*/
+	0x143, /* 16, -4.0dB*/
+	0x156, /* 17, -3.5dB*/
+	0x16A, /* 18, -3.0dB*/
+	0x180, /* 19, -2.5dB*/
+	0x197, /* 20, -2.0dB*/
+	0x1AF, /* 21, -1.5dB*/
+	0x1C8, /* 22, -1.0dB*/
+	0x1E3, /* 23, -0.5dB*/
+	0x200, /* 24, +0  dB*/
+	0x21E, /* 25, +0.5dB*/
+	0x23E, /* 26, +1.0dB*/
+	0x261, /* 27, +1.5dB*/
+	0x285,/* 28, +2.0dB*/
+	0x2AB, /* 29, +2.5dB*/
+	0x2D3, /*30, +3.0dB*/
+	0x2FE, /* 31, +3.5dB*/
+	0x32B, /* 32, +4.0dB*/
+	0x35C, /* 33, +4.5dB*/
+	0x38E, /* 34, +5.0dB*/
+	0x3C4, /* 35, +5.5dB*/
+	0x3FE  /* 36, +6.0dB	*/
+};
+
+void
+odm_txpowertracking_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
+		return;
+#endif
+
+	odm_txpowertracking_thermal_meter_init(dm);
+}
+
+u8
+get_swing_index(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+#endif
+	u8			i = 0;
+	u32			bb_swing;
+	u32			swing_table_size;
+	u32			*swing_table;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B
+	    || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B
+	   ) {
+		bb_swing = odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
+
+		swing_table = ofdm_swing_table_new;
+		swing_table_size = OFDM_TABLE_SIZE;
+	} else {
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8821) {
+			bb_swing = phy_get_tx_bb_swing_8812a(adapter, hal_data->current_band_type, RF_PATH_A);
+			swing_table = tx_scaling_table_jaguar;
+			swing_table_size = TXSCALE_TABLE_SIZE;
+		} else
+#endif
+		{
+			bb_swing = 0;
+			swing_table = ofdm_swing_table;
+			swing_table_size = OFDM_TABLE_SIZE;
+		}
+	}
+
+	for (i = 0; i < swing_table_size; ++i) {
+		u32 table_value = swing_table[i];
+
+		if (table_value >= 0x100000)
+			table_value >>= 22;
+		if (bb_swing == table_value)
+			break;
+	}
+	return i;
+}
+
+u8
+get_cck_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	u8			i = 0;
+	u32			bb_cck_swing;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
+				break;
+		}
+	} else if (dm->support_ic_type == ODM_RTL8703B) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
+				break;
+		}
+	}
+
+	return i;
+}
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8 default_swing_index = get_swing_index(dm);
+	u8 default_cck_swing_index = get_cck_swing_index(dm);
+	u8			p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+
+	if (*dm->mp_mode == false)
+		hal_data->txpowertrack_control = true;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#ifdef DM_ODM_CE_MAC80211
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
+#else
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+#endif
+
+	cali_info->is_txpowertracking = true;
+	cali_info->tx_powercount = 0;
+	cali_info->is_txpowertracking_init = false;
+
+	if (*dm->mp_mode == false)
+		cali_info->txpowertrack_control = true;
+	else
+		cali_info->txpowertrack_control = false;
+
+	if (*dm->mp_mode == false)
+		cali_info->txpowertrack_control = true;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
+
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#ifdef RTL8188E_SUPPORT
+	{
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
+		cali_info->txpowertrack_control = true;
+	}
+#endif
+#endif
+
+	/* dm->rf_calibrate_info.txpowertrack_control = true; */
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	cali_info->thermal_value = rtlefu->eeprom_thermalmeter;
+	cali_info->thermal_value_iqk = rtlefu->eeprom_thermalmeter;
+	cali_info->thermal_value_lck = rtlefu->eeprom_thermalmeter;
+#else
+	cali_info->thermal_value = hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_iqk = hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_lck = hal_data->eeprom_thermal_meter;
+#endif
+
+	if (cali_info->default_bb_swing_index_flag != true) {
+		/*The index of "0 dB" in SwingTable.*/
+		if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+		    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8703B) {
+			cali_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
+			cali_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
+		} else if (dm->support_ic_type == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
+			cali_info->default_ofdm_index = 28;							/*OFDM: -1dB*/
+			cali_info->default_cck_index = 20;							/*CCK:-6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8723D) {			 /*add by zhaohe  2015-10-27*/
+			cali_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;							/*CCK:   -6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8710B) {		/* JJ ADD 20161014 */
+			cali_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;							   /*CCK:   -6dB*/
+		} else {
+			cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
+			cali_info->default_cck_index = 24;
+		}
+		cali_info->default_bb_swing_index_flag = true;
+	}
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->CCK_index = cali_info->default_cck_index;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
+	}
+	cali_info->modify_tx_agc_value_ofdm = 0;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->tm_trigger = 0;
+}
+
+
+void
+odm_txpowertracking_check(
+	void	*dm_void
+)
+{
+	/* 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. */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_txpowertracking_check_mp(dm);
+		break;
+
+	case	ODM_CE:
+		odm_txpowertracking_check_ce(dm);
+		break;
+
+	case	ODM_AP:
+		odm_txpowertracking_check_ap(dm);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+odm_txpowertracking_check_ce(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*adapter = dm->adapter;
+
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	if (!dm->rf_calibrate_info.tm_trigger) {
+		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_8188F(adapter) || IS_HARDWARE_TYPE_8192E(adapter)
+		    || IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_8814A(adapter)
+		    || IS_HARDWARE_TYPE_8703B(adapter) || IS_HARDWARE_TYPE_8723D(adapter) || IS_HARDWARE_TYPE_8822B(adapter)
+		    || IS_HARDWARE_TYPE_8821C(adapter)  || (dm->support_ic_type == ODM_RTL8710B)
+		   )/* JJ ADD 20161014 */
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW, (BIT(17) | BIT(16)), 0x03);
+		else
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_OLD, RFREGOFFSETMASK, 0x60);
+
+
+
+		dm->rf_calibrate_info.tm_trigger = 1;
+		return;
+	} else {
+		odm_txpowertracking_callback_thermal_meter(dm);
+		dm->rf_calibrate_info.tm_trigger = 0;
+	}
+
+#endif
+}
+
+void
+odm_txpowertracking_check_mp(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+
+	if (odm_check_power_status(adapter) == false) {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status, return false\n"));
+		return;
+	}
+
+	odm_txpowertracking_thermal_meter_check(adapter);
+#endif
+
+}
+
+
+void
+odm_txpowertracking_check_ap(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv	*priv		= dm->priv;
+
+	return;
+
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ce.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ce.h
new file mode 100644
index 000000000000..1fef2653d24d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_ce.h
@@ -0,0 +1,348 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMPOWERTRACKING_H__
+#define    __PHYDMPOWERTRACKING_H__
+
+#define		DPK_DELTA_MAPPING_NUM	13
+#define		index_mapping_HP_NUM	15
+#define	OFDM_TABLE_SIZE	43
+#define	CCK_TABLE_SIZE			33
+#define	CCK_TABLE_SIZE_88F	21
+#define TXSCALE_TABLE_SIZE		37
+#define CCK_TABLE_SIZE_8723D	41
+/* JJ ADD 20161014 */
+#define CCK_TABLE_SIZE_8710B	41
+
+#define TXPWR_TRACK_TABLE_SIZE	30
+#define DELTA_SWINGIDX_SIZE     30
+#define DELTA_SWINTSSI_SIZE     61
+#define BAND_NUM				4
+
+#define AVG_THERMAL_NUM		8
+#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 iqk_matrix_reg_num	8
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#else
+#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+#endif
+
+extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/* JJ ADD 20161014 */
+extern	u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+
+extern  u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+
+/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#else
+static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+#endif
+
+#define dm_check_txpowertracking	odm_txpowertracking_check
+
+struct iqk_matrix_regs_setting {
+	boolean	is_iqk_done;
+	s32		value[3][iqk_matrix_reg_num];
+	boolean	is_bw_iqk_result_saved[3];
+};
+
+struct dm_rf_calibration_struct {
+	/* for tx power tracking */
+
+	u32	rega24; /* for TempCCK */
+	s32	rege94;
+	s32	rege9c;
+	s32	regeb4;
+	s32	regebc;
+
+	u8	tx_powercount;
+	boolean is_txpowertracking_init;
+	boolean is_txpowertracking;
+	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
+	u8	tm_trigger;
+	u8  	internal_pa_5g[2];	/* pathA / pathB */
+
+	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8	thermal_value;
+	u8	thermal_value_lck;
+	u8	thermal_value_iqk;
+	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8	thermal_value_dpk;
+	u8	thermal_value_avg[AVG_THERMAL_NUM];
+	u8	thermal_value_avg_index;
+	u8	thermal_value_rx_gain;
+	u8	thermal_value_crystal;
+	u8	thermal_value_dpk_store;
+	u8	thermal_value_dpk_track;
+	boolean	txpowertracking_in_progress;
+
+	boolean	is_reloadtxpowerindex;
+	u8	is_rf_pi_enable;
+	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
+
+
+	/* ------------------------- Tx power Tracking ------------------------- */
+	u8	is_cck_in_ch14;
+	u8	CCK_index;
+	u8	OFDM_index[MAX_RF_PATH];
+	s8	power_index_offset[MAX_RF_PATH];
+	s8	delta_power_index[MAX_RF_PATH];
+	s8	delta_power_index_last[MAX_RF_PATH];
+	boolean is_tx_power_changed;
+	s8	xtal_offset;
+	s8	xtal_offset_last;
+
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8	delta_lck;
+	s8  bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
+	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	s8  delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
+	s8  delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8			bb_swing_idx_ofdm_current;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+#else
+	u8			bb_swing_idx_ofdm_base;
+#endif
+	boolean		default_bb_swing_index_flag;
+	boolean			bb_swing_flag_ofdm;
+	u8			bb_swing_idx_cck;
+	u8			bb_swing_idx_cck_current;
+	u8			bb_swing_idx_cck_base;
+	u8			default_ofdm_index;
+	u8			default_cck_index;
+	boolean			bb_swing_flag_cck;
+
+	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8			absolute_cck_swing_idx[MAX_RF_PATH];
+	s8			remnant_cck_swing_idx;
+	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
+	boolean			modify_tx_agc_flag_path_a;
+	boolean			modify_tx_agc_flag_path_b;
+	boolean			modify_tx_agc_flag_path_c;
+	boolean			modify_tx_agc_flag_path_d;
+	boolean			modify_tx_agc_flag_path_a_cck;
+
+	s8			kfree_offset[MAX_RF_PATH];
+
+	/* -------------------------------------------------------------------- */
+
+	/* for IQK */
+	u32	regc04;
+	u32	reg874;
+	u32	regc08;
+	u32	regb68;
+	u32	regb6c;
+	u32	reg870;
+	u32	reg860;
+	u32	reg864;
+
+	boolean	is_iqk_initialized;
+	boolean is_lck_in_progress;
+	boolean	is_antenna_detected;
+	boolean	is_need_iqk;
+	boolean	is_iqk_in_progress;
+	boolean is_iqk_pa_off;
+	u8	delta_iqk;
+	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];
+	u32 	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32 	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
+	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	u32	tx_iqc_8723d[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8723d[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	/* JJ ADD 20161014 */
+	u32	tx_iqc_8710b[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8710b[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+
+	u8	iqk_step;
+	u8	kcount;
+	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean	is_mp_mode;
+
+
+
+	/* <James> IQK time measurement */
+	u64	iqk_start_time;
+	u64	iqk_progressing_time;
+	u64	iqk_total_progressing_time;
+	u64 lck_progressing_time;
+
+	u32  lok_result;
+
+	/* for APK */
+	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8	is_ap_kdone;
+	u8	is_apk_thermal_meter_ignore;
+
+	/* DPK */
+	boolean is_dpk_fail;
+	u8	is_dp_done;
+	u8	is_dp_path_aok;
+	u8	is_dp_path_bok;
+
+	u32	tx_lok[2];
+	u32  dpk_tx_agc;
+	s32  dpk_gain;
+	u32  dpk_thermal[4];
+	s8 modify_tx_agc_value_ofdm;
+	s8 modify_tx_agc_value_cck;
+
+	/*Add by Yuchen for Kfree Phydm*/
+	u8			reg_rf_kfree_enable;	/*for registry*/
+	u8			rf_kfree_enable;		/*for efuse enable check*/
+
+};
+
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+void
+odm_txpowertracking_callback_thermal_meter92c(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_rx_gain_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_direct_call92c(
+	void		*adapter
+);
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+);
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_win.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_win.c
new file mode 100644
index 000000000000..5705259696c0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_win.c
@@ -0,0 +1,806 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ************************************************************
+ * Global var
+ * ************************************************************ */
+
+u32	ofdm_swing_table[OFDM_TABLE_SIZE] = {
+	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 */
+};
+
+u8	cck_swing_table_ch1_ch13[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 <== default */
+	{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	cck_swing_table_ch14[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  <== default */
+	{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 */
+};
+
+
+u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
+	0x0b40002d, /* 0,  -15.0dB */
+	0x0c000030, /* 1,  -14.5dB */
+	0x0cc00033, /* 2,  -14.0dB */
+	0x0d800036, /* 3,  -13.5dB */
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB */
+	0x10000040, /* 6,  -12.0dB */
+	0x11000044, /* 7,  -11.5dB */
+	0x12000048, /* 8,  -11.0dB */
+	0x1300004c, /* 9,  -10.5dB */
+	0x14400051, /* 10, -10.0dB */
+	0x15800056, /* 11, -9.5dB */
+	0x16c0005b, /* 12, -9.0dB */
+	0x18000060, /* 13, -8.5dB */
+	0x19800066, /* 14, -8.0dB */
+	0x1b00006c, /* 15, -7.5dB */
+	0x1c800072, /* 16, -7.0dB */
+	0x1e400079, /* 17, -6.5dB */
+	0x20000080, /* 18, -6.0dB */
+	0x22000088, /* 19, -5.5dB */
+	0x24000090, /* 20, -5.0dB */
+	0x26000098, /* 21, -4.5dB */
+	0x288000a2, /* 22, -4.0dB */
+	0x2ac000ab, /* 23, -3.5dB */
+	0x2d4000b5, /* 24, -3.0dB */
+	0x300000c0, /* 25, -2.5dB */
+	0x32c000cb, /* 26, -2.0dB */
+	0x35c000d7, /* 27, -1.5dB */
+	0x390000e4, /* 28, -1.0dB */
+	0x3c8000f2, /* 29, -0.5dB */
+	0x40000100, /* 30, +0dB */
+	0x43c0010f, /* 31, +0.5dB */
+	0x47c0011f, /* 32, +1.0dB */
+	0x4c000130, /* 33, +1.5dB */
+	0x50800142, /* 34, +2.0dB */
+	0x55400155, /* 35, +2.5dB */
+	0x5a400169, /* 36, +3.0dB */
+	0x5fc0017f, /* 37, +3.5dB */
+	0x65400195, /* 38, +4.0dB */
+	0x6b8001ae, /* 39, +4.5dB */
+	0x71c001c7, /* 40, +5.0dB */
+	0x788001e2, /* 41, +5.5dB */
+	0x7f8001fe  /* 42, +6.0dB */
+};
+
+
+u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/* 32, +0dB */
+};
+
+
+u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB */
+};
+u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
+	0x0CD,
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+/* JJ ADD 20161014 */
+u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
+	0x0CD,			 /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,		/*19*/
+	0x287,		/*20*/
+	0x2AE,		/*21*/
+	0x2D6,		/*22*/
+	0x301,		/*23*/
+	0x32F,		/*24*/
+	0x35F,		/*25*/
+	0x392,		/*26*/
+	0x3C9,		/*27*/
+	0x402,		/*28*/
+	0x43F,		/*29*/
+	0x47F,		/*30*/
+	0x4C3,		/*31*/
+	0x50C,		/*32*/
+	0x558,		/*33*/
+	0x5A9,		/*34*/
+	0x5FF,		/*35*/
+	0x65A,		/*36*/
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+
+u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
+	0x081, /* 0,  -12.0dB */
+	0x088, /* 1,  -11.5dB */
+	0x090, /* 2,  -11.0dB */
+	0x099, /* 3,  -10.5dB */
+	0x0A2, /* 4,  -10.0dB */
+	0x0AC, /* 5,  -9.5dB */
+	0x0B6, /* 6,  -9.0dB */
+	0x0C0, /* 7,  -8.5dB */
+	0x0CC, /* 8,  -8.0dB */
+	0x0D8, /* 9,  -7.5dB */
+	0x0E5, /* 10, -7.0dB */
+	0x0F2, /* 11, -6.5dB */
+	0x101, /* 12, -6.0dB */
+	0x110, /* 13, -5.5dB */
+	0x120, /* 14, -5.0dB */
+	0x131, /* 15, -4.5dB */
+	0x143, /* 16, -4.0dB */
+	0x156, /* 17, -3.5dB */
+	0x16A, /* 18, -3.0dB */
+	0x180, /* 19, -2.5dB */
+	0x197, /* 20, -2.0dB */
+	0x1AF, /* 21, -1.5dB */
+	0x1C8, /* 22, -1.0dB */
+	0x1E3, /* 23, -0.5dB */
+	0x200, /* 24, +0  dB */
+	0x21E, /* 25, +0.5dB */
+	0x23E, /* 26, +1.0dB */
+	0x261, /* 27, +1.5dB */
+	0x285, /* 28, +2.0dB */
+	0x2AB, /* 29, +2.5dB */
+	0x2D3, /* 30, +3.0dB */
+	0x2FE, /* 31, +3.5dB */
+	0x32B, /* 32, +4.0dB */
+	0x35C, /* 33, +4.5dB */
+	0x38E, /* 34, +5.0dB */
+	0x3C4, /* 35, +5.5dB */
+	0x3FE  /* 36, +6.0dB */
+};
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
+		return;
+#endif
+
+	odm_txpowertracking_thermal_meter_init(dm);
+}
+
+u8
+get_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	u8			i = 0;
+	u32			bb_swing;
+	u32			swing_table_size;
+	u32			*swing_table;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B) {
+		bb_swing = odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
+
+		swing_table = ofdm_swing_table_new;
+		swing_table_size = OFDM_TABLE_SIZE;
+	} else {
+		bb_swing = PHY_GetTxBBSwing_8812A((PADAPTER)adapter, hal_data->CurrentBandType, RF_PATH_A);
+		swing_table = tx_scaling_table_jaguar;
+		swing_table_size = TXSCALE_TABLE_SIZE;
+	}
+
+	for (i = 0; i < swing_table_size; ++i) {
+		u32 table_value = swing_table[i];
+
+		if (table_value >= 0x100000)
+			table_value >>= 22;
+		if (bb_swing == table_value)
+			break;
+	}
+	return i;
+}
+
+u8
+get_cck_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	u8			i = 0;
+	u32			bb_cck_swing;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
+				break;
+		}
+	} else if (dm->support_ic_type == ODM_RTL8703B) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
+				break;
+		}
+	}
+
+	return i;
+}
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8 default_swing_index = get_swing_index(dm);
+	u8 default_cck_swing_index = get_cck_swing_index(dm);
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	u8			p = 0;
+
+	if (*(dm->mp_mode) == false)
+		cali_info->txpowertrack_control = true;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#ifdef CONFIG_RTL8188E
+	{
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)
+			cali_info->txpowertrack_control = true;
+
+		MSG_8192C("dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+		struct dm_priv	*pdmpriv = &hal_data->dmpriv;
+
+		pdmpriv->is_txpowertracking = true;
+		pdmpriv->tx_powercount = 0;
+		pdmpriv->is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)
+			pdmpriv->txpowertrack_control = true;
+
+		MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
+
+	}
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#ifdef RTL8188E_SUPPORT
+	{
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
+		cali_info->txpowertrack_control = true;
+	}
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if (MP_DRIVER == 1)
+	cali_info->txpowertrack_control = false;
+#else
+	cali_info->txpowertrack_control = true;
+#endif
+#else
+	cali_info->txpowertrack_control = true;
+#endif
+
+	cali_info->thermal_value		= hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_iqk	= hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_lck	= hal_data->eeprom_thermal_meter;
+
+	if (cali_info->default_bb_swing_index_flag != true) {
+		/*The index of "0 dB" in SwingTable.*/
+		if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+		    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8703B) {
+			cali_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
+			cali_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
+		} else if (dm->support_ic_type == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
+			cali_info->default_ofdm_index = 28;							/*OFDM: -1dB*/
+			cali_info->default_cck_index = 20;							/*CCK:-6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8723D) {			 /*add by zhaohe  2015-10-27*/
+			cali_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;							/*CCK:   -6dB*/
+			/* JJ ADD 20161014 */
+		} else if (dm->support_ic_type == ODM_RTL8710B) {			
+			cali_info->default_ofdm_index = 28;					/*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;					/*CCK:   -6dB*/
+		} else {
+			cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
+			cali_info->default_cck_index = 24;
+		}
+		cali_info->default_bb_swing_index_flag = true;
+	}
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->CCK_index = cali_info->default_cck_index;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+	cali_info->modify_tx_agc_value_ofdm = 0;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->tm_trigger = 0;
+}
+
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+)
+{
+
+#if 0
+	/* 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. */
+#endif
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_txpowertracking_check_mp(dm);
+		break;
+
+	case	ODM_CE:
+		odm_txpowertracking_check_ce(dm);
+		break;
+
+	case	ODM_AP:
+		odm_txpowertracking_check_ap(dm);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*adapter = dm->adapter;
+#if ((RTL8188F_SUPPORT == 1))
+	rtl8192c_odm_check_txpowertracking(adapter);
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	if (!cali_info->tm_trigger) {
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+		/*DBG_8192C("Trigger 92C Thermal Meter!!\n");*/
+
+		cali_info->tm_trigger = 1;
+		return;
+
+	} else {
+		/*DBG_8192C("Schedule TxPowerTracking direct call!!\n");*/
+		odm_txpowertracking_callback_thermal_meter_8188e(adapter);
+		cali_info->tm_trigger = 0;
+	}
+#endif
+#endif
+}
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+
+	if (*dm->is_fcs_mode_enable)
+		return;
+
+	if (odm_check_power_status(dm) == false) {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status return false\n"));
+		return;
+	}
+
+	if (IS_HARDWARE_TYPE_8821B(adapter)) /* TODO: Don't Do PowerTracking*/
+		return;
+
+	odm_txpowertracking_thermal_meter_check(adapter);
+
+
+#endif
+
+}
+
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+)
+{
+	return;
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_txpowertracking_direct_call(
+	void		*adapter
+)
+{
+	HAL_DATA_TYPE		*hal_data	= GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct			*dm = &hal_data->DM_OutSrc;
+
+	odm_txpowertracking_callback_thermal_meter(adapter);
+}
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+)
+{
+	static u8			tm_trigger = 0;
+	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct	*dm = &(pHalData->DM_OutSrc);
+	struct _hal_rf_			*rf = &(dm->rf_table);
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK)) {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
+			("===>odm_txpowertracking_thermal_meter_check(),mgnt_info->is_txpowertracking is false, return!!\n"));
+		return;
+	}
+
+	if (!tm_trigger) {
+		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_8192E(adapter) ||
+		    IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8814A(adapter) || IS_HARDWARE_TYPE_8188F(adapter) || IS_HARDWARE_TYPE_8703B(adapter)
+		    || IS_HARDWARE_TYPE_8822B(adapter) || IS_HARDWARE_TYPE_8723D(adapter) || IS_HARDWARE_TYPE_8821C(adapter) || IS_HARDWARE_TYPE_8710B(adapter))/* JJ ADD 20161014 */
+			PHY_SetRFReg((PADAPTER)adapter, RF_PATH_A, RF_T_METER_88E, BIT(17) | BIT(16), 0x03);
+		else
+			PHY_SetRFReg((PADAPTER)adapter, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("Trigger Thermal Meter!!\n"));
+
+		tm_trigger = 1;
+		return;
+	} else {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("Schedule TxPowerTracking direct call!!\n"));
+		odm_txpowertracking_direct_call(adapter);
+		tm_trigger = 0;
+	}
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_win.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_win.h
new file mode 100644
index 000000000000..19b27c07cdc5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_powertracking_win.h
@@ -0,0 +1,299 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDMPOWERTRACKING_H__
+#define    __PHYDMPOWERTRACKING_H__
+
+#define	DPK_DELTA_MAPPING_NUM	13
+#define	index_mapping_HP_NUM	15
+#define	TXSCALE_TABLE_SIZE		37
+#define	OFDM_TABLE_SIZE			43
+#define	CCK_TABLE_SIZE			33
+#define	CCK_TABLE_SIZE_8723D    41
+#define	TXPWR_TRACK_TABLE_SIZE	30
+#define	DELTA_SWINGIDX_SIZE     30
+#define	DELTA_SWINTSSI_SIZE     61
+#define	BAND_NUM				3
+#define	MAX_RF_PATH	4
+#define	CCK_TABLE_SIZE_88F	21
+/* JJ ADD 20161014 */
+#define	CCK_TABLE_SIZE_8710B   41
+
+
+#define	dm_check_txpowertracking	odm_txpowertracking_check
+
+#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+#define	AVG_THERMAL_NUM		8
+#define	iqk_matrix_reg_num	8
+#define	IQK_MAC_REG_NUM		4
+#define	IQK_ADDA_REG_NUM		16
+
+#define	IQK_BB_REG_NUM		9
+
+
+extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/* JJ ADD 20161014 */
+extern	u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+
+extern  u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+
+/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+);
+
+#endif
+
+struct iqk_matrix_regs_setting {
+	boolean	is_iqk_done;
+	s32		value[3][iqk_matrix_reg_num];
+	boolean	is_bw_iqk_result_saved[3];
+};
+
+struct dm_rf_calibration_struct {
+	/* for tx power tracking */
+
+	u32	rega24; /* for TempCCK */
+	s32	rege94;
+	s32	rege9c;
+	s32	regeb4;
+	s32	regebc;
+	/* u8 is_txpowertracking; */
+	u8	tx_powercount;
+	boolean is_txpowertracking_init;
+	boolean is_txpowertracking;
+	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
+	u8	tm_trigger;
+	u8  	internal_pa_5g[2];	/* pathA / pathB */
+
+	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8	thermal_value;
+	u8	thermal_value_lck;
+	u8	thermal_value_iqk;
+	u8  thermal_value_dpk;
+	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8	thermal_value_avg[AVG_THERMAL_NUM];
+	u8	thermal_value_avg_index;
+	u8	thermal_value_rx_gain;
+
+
+	boolean	is_reloadtxpowerindex;
+	u8	is_rf_pi_enable;
+	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
+
+
+	/* ------------------------- Tx power Tracking ------------------------- */
+	u8	is_cck_in_ch14;
+	u8	CCK_index;
+	u8	OFDM_index[MAX_RF_PATH];
+	s8	power_index_offset[MAX_RF_PATH];
+	s8	delta_power_index[MAX_RF_PATH];
+	s8	delta_power_index_last[MAX_RF_PATH];
+	boolean is_tx_power_changed;
+	s8	xtal_offset;
+	s8	xtal_offset_last;
+
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8	delta_lck;
+	s8  bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
+	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	s8  delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
+	s8  delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8			bb_swing_idx_ofdm_current;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+#else
+	u8			bb_swing_idx_ofdm_base;
+#endif
+	boolean		default_bb_swing_index_flag;
+	boolean			bb_swing_flag_ofdm;
+	u8			bb_swing_idx_cck;
+	u8			bb_swing_idx_cck_current;
+	u8			bb_swing_idx_cck_base;
+	u8			default_ofdm_index;
+	u8			default_cck_index;
+	boolean			bb_swing_flag_cck;
+
+	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8			absolute_cck_swing_idx[MAX_RF_PATH];
+	s8			remnant_cck_swing_idx;
+	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
+	boolean			modify_tx_agc_flag_path_a;
+	boolean			modify_tx_agc_flag_path_b;
+	boolean			modify_tx_agc_flag_path_c;
+	boolean			modify_tx_agc_flag_path_d;
+	boolean			modify_tx_agc_flag_path_a_cck;
+
+	s8			kfree_offset[MAX_RF_PATH];
+
+	/* -------------------------------------------------------------------- */
+
+	/* for IQK */
+	u32	regc04;
+	u32	reg874;
+	u32	regc08;
+	u32	regb68;
+	u32	regb6c;
+	u32	reg870;
+	u32	reg860;
+	u32	reg864;
+
+	boolean	is_iqk_initialized;
+	boolean is_lck_in_progress;
+	boolean	is_antenna_detected;
+	boolean	is_need_iqk;
+	boolean	is_iqk_in_progress;
+	boolean	is_iqk_pa_off;
+	u8	delta_iqk;
+	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];
+	u32	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
+	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	u32	tx_iqc_8723d[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8723d[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	/* JJ ADD 20161014 */
+	u32	tx_iqc_8710b[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8710b[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+
+	u64	iqk_start_time;
+	u64	iqk_total_progressing_time;
+	u64	iqk_progressing_time;
+	u64	lck_progressing_time;
+	u32  lok_result;
+	u8	iqk_step;
+	u8	kcount;
+	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean	is_mp_mode;
+
+	/* for APK */
+	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8	is_ap_kdone;
+	u8	is_apk_thermal_meter_ignore;
+
+	/* DPK */
+	boolean is_dpk_fail;
+	u8	is_dp_done;
+	u8	is_dp_path_aok;
+	u8	is_dp_path_bok;
+
+	u32	tx_lok[2];
+	u32  dpk_tx_agc;
+	s32  dpk_gain;
+	u32  dpk_thermal[4];
+
+	s8 modify_tx_agc_value_ofdm;
+	s8 modify_tx_agc_value_cck;
+
+	/*Add by Yuchen for Kfree Phydm*/
+	u8			reg_rf_kfree_enable;	/*for registry*/
+	u8			rf_kfree_enable;		/*for efuse enable check*/
+};
+
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_psd.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_psd.c
new file mode 100644
index 000000000000..3193ebe5cdb3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_psd.c
@@ -0,0 +1,321 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#if 0
+u32 _sqrt(u64 n)
+{
+	u64	ans = 0, q = 0; 
+	s64	i;
+
+	/*for (i = sizeof(n) * 8 - 2; i > -1; i = i - 2) {*/
+	for (i = 8 * 8 - 2; i > -1; i = i - 2) {
+		q = (q << 2) | ((n & (3 << i)) >> i); 
+		if (q >= ((ans << 2) | 1)) 
+		{ 
+			q = q - ((ans << 2) | 1); 
+			ans = (ans << 1) | 1; 
+		} 
+		else 
+			ans = ans << 1; 
+	}
+	DbgPrint("ans=0x%x\n", ans);
+
+	return (u32)ans; 
+}
+#endif
+
+
+
+u64 _sqrt(u64 x)
+{
+	u64 i = 0;
+	u64 j = x / 2 + 1;
+
+	while (i <= j) {
+		u64 mid = (i + j) / 2;
+
+		u64 sq = mid * mid;
+
+		if (sq == x)
+			return mid;
+		else if (sq < x)
+			i = mid + 1;
+		else
+			j = mid - 1;
+	}
+
+	return j;
+}
+
+
+
+u32
+halrf_get_psd_data(
+	struct	dm_struct	*dm,
+	u32	point
+	)
+{
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+	u32 psd_val = 0, psd_reg, psd_report, psd_point, psd_start, i, delay_time;
+
+#if (DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+	if (psd->average == 0)
+		delay_time = 100;
+	else
+		delay_time = 0;
+#else
+	if (psd->average == 0)
+		delay_time = 1000;
+	else
+		delay_time = 100;
+#endif
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
+		psd_reg = 0x910;
+		psd_report = 0xf44;
+	} else {
+		psd_reg = 0x808;
+		psd_report = 0x8b4;
+	}
+
+	if (dm->support_ic_type & ODM_RTL8710B) {
+		psd_point = 0xeffffc00;
+		psd_start = 0x10000000;
+	} else {
+		psd_point = 0xffbffc00;
+		psd_start = 0x00400000;
+	}
+
+	psd_val = odm_get_bb_reg(dm, psd_reg, MASKDWORD);
+		
+	psd_val &= psd_point;
+	psd_val |= point;
+
+	odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
+	
+	psd_val |= psd_start;
+
+	odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
+
+	for (i = 0; i < delay_time; i++)
+		ODM_delay_us(1);
+
+	psd_val = odm_get_bb_reg(dm, psd_report, MASKDWORD);
+
+	if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8710B)) {
+		psd_val &= MASKL3BYTES;
+		psd_val = psd_val / 32;
+	} else
+		psd_val &= MASKLWORD;
+
+	return psd_val;
+}
+
+
+
+void
+halrf_psd(
+	struct	dm_struct	*dm,
+	u32	point,
+	u32	start_point,
+	u32	stop_point,
+	u32	average
+	)
+{
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+	
+	u32 i = 0, j = 0, k = 0;
+	u32 psd_reg, avg_org, point_temp, average_tmp;
+	u64 data_tatal = 0, data_temp[64] = {0};
+
+	psd->buf_size = 256;
+
+	if (average == 0)
+		average_tmp = 1;
+	else
+		average_tmp = average;
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+		psd_reg = 0x910;
+	else
+		psd_reg = 0x808;
+
+#if 0
+	dbg_print("[PSD]point=%d, start_point=%d, stop_point=%d, average=%d, average_tmp=%d, buf_size=%d\n",
+		point, start_point, stop_point, average, average_tmp, psd->buf_size);
+#endif
+
+	for (i = 0; i < psd->buf_size; i++)
+		psd->psd_data[i] = 0;
+	
+	if (dm->support_ic_type & ODM_RTL8710B)
+		avg_org = odm_get_bb_reg(dm, psd_reg, 0x30000);
+	else
+		avg_org = odm_get_bb_reg(dm, psd_reg, 0x3000);
+
+	if (average != 0)
+	{
+		if (dm->support_ic_type & ODM_RTL8710B)
+			odm_set_bb_reg(dm, psd_reg, 0x30000, 0x1);
+		else
+			odm_set_bb_reg(dm, psd_reg, 0x3000, 0x1);
+	}
+
+#if 0
+	if (avg_temp == 0)
+		avg = 1;
+	else if (avg_temp == 1)
+		avg = 8;
+	else if (avg_temp == 2)
+		avg = 16;
+	else if (avg_temp == 3)
+		avg = 32;
+#endif
+
+	i = start_point;
+	while (i < stop_point) {
+		data_tatal = 0;
+	
+		if (i >= point)
+			point_temp = i - point;
+		else
+			point_temp = i;
+		
+		for (k = 0; k < average_tmp; k++) {
+			data_temp[k] = halrf_get_psd_data(dm, point_temp);
+			data_tatal = data_tatal + (data_temp[k] * data_temp[k]);
+
+#if 0
+			if ((k % 20) == 0)
+				dbg_print("\n ");
+			
+			dbg_print("0x%x ", data_temp[k]);
+#endif
+		}
+		/*dbg_print("\n");*/
+
+		data_tatal = ((data_tatal * 100) / average_tmp);
+		psd->psd_data[j] = (u32)_sqrt(data_tatal);
+
+		i++;
+		j++;
+	}
+
+#if 0
+	for (i = 0; i < psd->buf_size; i++) {
+		if ((i % 20) == 0)
+			dbg_print("\n ");
+			
+		dbg_print("0x%x ", psd->psd_data[i]);
+	}
+	dbg_print("\n\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8710B)
+		odm_set_bb_reg(dm, psd_reg, 0x30000, avg_org);
+	else
+		odm_set_bb_reg(dm, psd_reg, 0x3000, avg_org);
+}
+
+
+
+enum rt_status
+halrf_psd_init(
+	struct	dm_struct	*dm
+	)
+{
+	enum rt_status	ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+
+	if (psd->psd_progress)
+		ret_status = RT_STATUS_PENDING;
+	else {
+		psd->psd_progress = 1;
+		halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
+		psd->psd_progress = 0;
+	}
+
+	return ret_status;
+}
+
+
+
+enum rt_status
+halrf_psd_query(
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		buf_size
+	)
+{
+	enum rt_status	ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+
+	if (psd->psd_progress)
+		ret_status = RT_STATUS_PENDING;
+	else
+		PlatformMoveMemory(outbuf, psd->psd_data, 0x400);
+
+	return ret_status;
+}
+
+
+
+enum rt_status
+halrf_psd_init_query(
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		point,
+	u32		start_point,
+	u32		stop_point,
+	u32		average,
+	u32		buf_size
+	)
+{
+	enum rt_status	ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+
+	psd->point = point;
+	psd->start_point = start_point;
+	psd->stop_point = stop_point;
+	psd->average = average;
+
+	if (psd->psd_progress)
+		ret_status = RT_STATUS_PENDING;
+	else {
+		psd->psd_progress = 1;
+		halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
+		PlatformMoveMemory(outbuf, psd->psd_data, 0x400);
+		psd->psd_progress = 0;
+	}
+
+	return ret_status;
+}
+
+#endif	/*#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_psd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_psd.h
new file mode 100644
index 000000000000..8e4b7f42fad7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_psd.h
@@ -0,0 +1,60 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HALRF_PSD_H__
+#define __HALRF_PSD_H__
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+struct _halrf_psd_data {
+	u32		point;
+	u32		start_point;
+	u32		stop_point;
+	u32		average;
+	u32		buf_size;
+	u32		psd_data[256];
+	u32		psd_progress;
+};
+
+
+
+enum rt_status
+halrf_psd_init (
+	struct	dm_struct	*dm
+	);
+
+
+
+enum rt_status
+halrf_psd_query (
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		buf_size
+);
+
+enum rt_status
+halrf_psd_init_query(
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		point,
+	u32		start_point,
+	u32		stop_point,
+	u32		average,
+	u32		buf_size
+);
+
+#endif	/*#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)*/
+#endif	/*#ifndef __HALRF_PSD_H__*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_txgapcal.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_txgapcal.c
new file mode 100644
index 000000000000..713f811ae06d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_txgapcal.c
@@ -0,0 +1,303 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+
+void odm_bub_sort(pu4Byte data, u4Byte n)
+{
+	int i, j, temp, sp;
+	
+	for (i = n - 1;i >= 0;i--) {
+		sp = 1;
+		for (j = 0;j < i;j++) {
+			if (data[j] < data[j + 1]) {
+				temp = data[j];
+				data[j] = data[j + 1];
+				data[j + 1] = temp;
+				sp = 0;
+			}
+		}
+		if (sp == 1)
+			break;          
+	}
+}
+
+
+#if (RTL8197F_SUPPORT == 1)
+
+u4Byte
+odm_tx_gain_gap_psd_8197f(
+	void	*dm_void,
+	u1Byte	rf_path,
+	u4Byte	rf56
+)
+{
+	PDM_ODM_T	dm = (PDM_ODM_T)dm_void;
+	
+	u1Byte i, j;
+	u4Byte psd_vaule[5], psd_avg_time = 5, psd_vaule_temp;
+	
+	u4Byte iqk_ctl_addr[2][6] = {{0xe30, 0xe34, 0xe50, 0xe54, 0xe38, 0xe3c},
+								{0xe50, 0xe54, 0xe30, 0xe34, 0xe58, 0xe5c}};
+	
+	u4Byte psd_finish_bit[2] = {0x04000000, 0x20000000};
+	u4Byte psd_fail_bit[2] = {0x08000000, 0x40000000};
+	
+	u4Byte psd_cntl_value[2][2] = {{0x38008c1c, 0x10008c1c},
+								   {0x38008c2c, 0x10008c2c}};
+	
+	u4Byte psd_report_addr[2] = {0xea0, 0xec0};
+	
+	odm_set_rf_reg(dm, rf_path, 0xdf, bRFRegOffsetMask, 0x00e02);
+
+	ODM_delay_us(100);
+
+	odm_set_bb_reg(dm, 0xe28, 0xffffffff, 0x0);
+	
+	odm_set_rf_reg(dm, rf_path, 0x56, 0xfff, rf56);
+	while(rf56 != (odm_get_rf_reg(dm, rf_path, 0x56, 0xfff)))
+		odm_set_rf_reg(dm, rf_path, 0x56, 0xfff, rf56);
+
+	odm_set_bb_reg(dm, 0xd94, 0xffffffff, 0x44FFBB44);
+	odm_set_bb_reg(dm, 0xe70, 0xffffffff, 0x00400040);
+	odm_set_bb_reg(dm, 0xc04, 0xffffffff, 0x6f005403);
+	odm_set_bb_reg(dm, 0xc08, 0xffffffff, 0x000804e4);
+	odm_set_bb_reg(dm, 0x874, 0xffffffff, 0x04203400);
+	odm_set_bb_reg(dm, 0xe28, 0xffffffff, 0x80800000);
+
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][0], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][1], 0xffffffff, psd_cntl_value[rf_path][1]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][2], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][3], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][4], 0xffffffff, 0x8215001F);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][5], 0xffffffff, 0x2805001F);
+	
+	odm_set_bb_reg(dm, 0xe40, 0xffffffff, 0x81007C00);
+	odm_set_bb_reg(dm, 0xe44, 0xffffffff, 0x81004800);
+	odm_set_bb_reg(dm, 0xe4c, 0xffffffff, 0x0046a8d0);
+	
+
+	for (i = 0; i < psd_avg_time; i++) {
+			
+		for(j = 0; j < 1000 ; j++) {
+			odm_set_bb_reg(dm, 0xe48, 0xffffffff, 0xfa005800);
+			odm_set_bb_reg(dm, 0xe48, 0xffffffff, 0xf8005800);
+
+			while(!odm_get_bb_reg(dm, 0xeac, psd_finish_bit[rf_path]));	/*wait finish bit*/
+
+			if (!odm_get_bb_reg(dm, 0xeac, psd_fail_bit[rf_path])) {	/*check fail bit*/
+				
+				psd_vaule[i] = odm_get_bb_reg(dm, psd_report_addr[rf_path], 0xffffffff);
+				
+				if (psd_vaule[i] > 0xffff)
+					break;
+			}
+		}
+			
+		
+
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x time=%d psd_vaule=0x%x\n",
+			odm_get_rf_reg(dm, rf_path, 0x0, 0xff),
+			rf56, odm_get_rf_reg(dm, rf_path, 0x56, 0xfff), j, psd_vaule[i]);
+	}
+
+	odm_bub_sort(psd_vaule, psd_avg_time);
+
+	psd_vaule_temp = psd_vaule[(UINT)(psd_avg_time / 2)];
+
+	odm_set_bb_reg(dm, 0xd94, 0xffffffff, 0x44BBBB44);
+	odm_set_bb_reg(dm, 0xe70, 0xffffffff, 0x80408040);
+	odm_set_bb_reg(dm, 0xc04, 0xffffffff, 0x6f005433);
+	odm_set_bb_reg(dm, 0xc08, 0xffffffff, 0x000004e4);
+	odm_set_bb_reg(dm, 0x874, 0xffffffff, 0x04003400);
+	odm_set_bb_reg(dm, 0xe28, 0xffffffff, 0x00000000);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x psd_vaule_temp=0x%x\n",
+		odm_get_rf_reg(dm, rf_path, 0x0, 0xff),
+		rf56, odm_get_rf_reg(dm, rf_path, 0x56, 0xfff), psd_vaule_temp);
+	
+	odm_set_rf_reg(dm, rf_path, 0xdf, bRFRegOffsetMask, 0x00602);
+
+	return psd_vaule_temp;
+
+}
+
+
+
+void
+odm_tx_gain_gap_calibration_8197f(
+	void	*dm_void
+)
+{
+	PDM_ODM_T	dm = (PDM_ODM_T)dm_void;
+
+	u1Byte rf_path, rf0_idx, rf0_idx_current, rf0_idx_next, i, delta_gain_retry = 3;
+	
+	s1Byte delta_gain_gap_pre, delta_gain_gap[2][11];
+	u4Byte rf56_current, rf56_next, psd_value_current, psd_value_next;
+	u4Byte psd_gap, rf56_current_temp[2][11];
+	s4Byte rf33[2][11];
+
+	memset(rf33, 0x0, sizeof(rf33));
+
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
+
+		if (rf_path == RF_PATH_A)
+			odm_set_bb_reg(dm, 0x88c, (BIT(21) | BIT(20)), 0x3);	/*disable 3-wire*/
+		else if (rf_path == RF_PATH_B)
+			odm_set_bb_reg(dm, 0x88c, (BIT(23) | BIT(22)), 0x3);	/*disable 3-wire*/
+		
+		ODM_delay_us(100);
+
+		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
+			
+			rf0_idx_current = 3 * (rf0_idx - 1) + 1;
+			odm_set_rf_reg(dm, rf_path, 0x0, 0xff, rf0_idx_current);
+			ODM_delay_us(100);
+			rf56_current_temp[rf_path][rf0_idx] = odm_get_rf_reg(dm, rf_path, 0x56, 0xfff);
+			rf56_current = rf56_current_temp[rf_path][rf0_idx];
+			
+			rf0_idx_next = 3 * rf0_idx + 1;
+			odm_set_rf_reg(dm, rf_path, 0x0, 0xff, rf0_idx_next);
+			ODM_delay_us(100);
+			rf56_next= odm_get_rf_reg(dm, rf_path, 0x56, 0xfff);
+
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56_current[%d][%d]=0x%x rf56_next[%d][%d]=0x%x\n",
+				rf_path, rf0_idx, rf56_current,  rf_path, rf0_idx, rf56_next);
+
+			if ((rf56_current >> 5) == (rf56_next >> 5)) {
+				delta_gain_gap[rf_path][rf0_idx] = 0;
+				
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56_current[11:5] == rf56_next[%d][%d][11:5]=0x%x delta_gain_gap[%d][%d]=%d\n",
+					rf_path, rf0_idx, (rf56_next >> 5), rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx]);
+
+				continue;
+			}
+
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56_current[%d][%d][11:5]=0x%x != rf56_next[%d][%d][11:5]=0x%x\n",
+					 rf_path, rf0_idx, (rf56_current >> 5), rf_path, rf0_idx, (rf56_next >> 5));
+
+			for (i = 0; i < delta_gain_retry; i++) {
+				psd_value_current = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_current);
+
+				psd_value_next = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_next - 2);
+
+				psd_gap = psd_value_next / (psd_value_current / 1000);
+
+#if 0
+				if (psd_gap > 1413)
+					delta_gain_gap[rf_path][rf0_idx] = 1;
+				else if (psd_gap > 1122)
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+				else
+					delta_gain_gap[rf_path][rf0_idx] = -1;
+#endif
+
+				if (psd_gap > 1445)
+					delta_gain_gap[rf_path][rf0_idx] = 1;
+				else if (psd_gap > 1096)
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+				else
+					delta_gain_gap[rf_path][rf0_idx] = -1;
+
+				if (i == 0)
+					delta_gain_gap_pre = delta_gain_gap[rf_path][rf0_idx];
+
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] psd_value_current=0x%x psd_value_next=0x%x psd_value_next/psd_value_current=%d delta_gain_gap[%d][%d]=%d\n",
+						 psd_value_current, psd_value_next, psd_gap, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx]);
+
+				if ((i == 0) && (delta_gain_gap[rf_path][rf0_idx] == 0))
+					break;
+
+				if (delta_gain_gap_pre != delta_gain_gap[rf_path][rf0_idx]) {
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] delta_gain_gap_pre(%d) != delta_gain_gap[%d][%d](%d) time=%d\n",
+							 delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i);
+
+					break;
+				} else {
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] delta_gain_gap_pre(%d) == delta_gain_gap[%d][%d](%d) time=%d\n",
+							 delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i);
+				}
+			}
+		}
+
+		if (rf_path == RF_PATH_A)
+			odm_set_bb_reg(dm, 0x88c, (BIT(21) | BIT(20)), 0x0);	/*enable 3-wire*/
+		else if (rf_path == RF_PATH_B)
+			odm_set_bb_reg(dm, 0x88c, (BIT(23) | BIT(22)), 0x0);	/*enable 3-wire*/
+
+		ODM_delay_us(100);
+
+	}
+
+	/*odm_set_bb_reg(dm, 0x88c, (BIT(23) | BIT(22) | BIT(21) | BIT(20)), 0x0);*/	/*enable 3-wire*/
+
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
+
+		odm_set_rf_reg(dm, rf_path, 0xef, bRFRegOffsetMask, 0x00100);
+
+		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
+			
+			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + (rf56_current_temp[rf_path][rf0_idx] & 0x1f); 
+			
+			for (i = rf0_idx; i <= 10; i++)
+				rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + delta_gain_gap[rf_path][i];
+
+			if (rf33[rf_path][rf0_idx] >= 0x1d)
+				rf33[rf_path][rf0_idx] = 0x1d;
+			else if (rf33[rf_path][rf0_idx] <= 0x2)
+				rf33[rf_path][rf0_idx] = 0x2;
+
+			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + ((rf0_idx - 1) * 0x4000) + (rf56_current_temp[rf_path][rf0_idx] & 0xfffe0);
+
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56[%d][%d]=0x%05x rf33[%d][%d]=0x%05x\n", rf_path, rf0_idx, rf56_current_temp[rf_path][rf0_idx], rf_path, rf0_idx, rf33[rf_path][rf0_idx]);
+
+			odm_set_rf_reg(dm, rf_path, 0x33, bRFRegOffsetMask, rf33[rf_path][rf0_idx]);
+		}
+		
+		odm_set_rf_reg(dm, rf_path, 0xef, bRFRegOffsetMask, 0x00000);
+	}
+
+}
+#endif
+
+
+void
+odm_tx_gain_gap_calibration(
+	void	*dm_void
+)
+{
+	PDM_ODM_T	dm = (PDM_ODM_T)dm_void;
+
+	#if (RTL8197F_SUPPORT == 1)
+		if (dm->SupportICType & ODM_RTL8197F)
+			odm_tx_gain_gap_calibration_8197f(dm_void);
+	#endif
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_txgapcal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_txgapcal.h
new file mode 100644
index 000000000000..c4041148554e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/halrf_txgapcal.h
@@ -0,0 +1,29 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+void
+odm_tx_gain_gap_calibration(
+	void	*dm_void
+);
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_8822b.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_8822b.c
new file mode 100644
index 000000000000..eb28312dc53d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_8822b.c
@@ -0,0 +1,553 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#if RT_PLATFORM==PLATFORM_MACOSX
+	#include "phydm_precomp.h"
+	#else
+	#include "../phydm_precomp.h"
+	#endif
+#else
+#include "../../phydm_precomp.h"
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+void
+halrf_rf_lna_setting_8822b(
+	struct dm_struct	*dm_void,
+	enum phydm_lna_set type
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8 path = 0x0;
+
+	for (path = 0x0; path < 2; path++)
+		if (type == phydm_lna_disable) {
+			/*S0*/
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x1);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x33, RFREGOFFSETMASK, 0x00003);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3e, RFREGOFFSETMASK, 0x00064);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3f, RFREGOFFSETMASK, 0x0afce);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x0);
+		} else if (type == phydm_lna_enable) {
+			/*S0*/
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x1);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x33, RFREGOFFSETMASK, 0x00003);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3e, RFREGOFFSETMASK, 0x00064);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3f, RFREGOFFSETMASK, 0x1afce);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x0);
+		}
+}
+
+boolean
+get_mix_mode_tx_agc_bb_swing_offset_8822b(
+	void				*dm_void,
+	enum pwrtrack_method	method,
+	u8				rf_path,
+	u8				tx_power_index_offest
+)
+{
+	struct dm_struct		*dm	=	(struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	u8	bb_swing_upper_bound = cali_info->default_ofdm_index + 10;
+	u8	bb_swing_lower_bound = 0;
+
+	s8	tx_agc_index = 0;
+	u8	tx_bb_swing_index = cali_info->default_ofdm_index;
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"Path_%d cali_info->absolute_ofdm_swing_idx[rf_path]=%d, tx_power_index_offest=%d\n",
+		rf_path, cali_info->absolute_ofdm_swing_idx[rf_path], tx_power_index_offest);
+
+	if (tx_power_index_offest > 0XF)
+		tx_power_index_offest = 0XF;
+
+	if (cali_info->absolute_ofdm_swing_idx[rf_path] >= 0 && cali_info->absolute_ofdm_swing_idx[rf_path] <= tx_power_index_offest) {
+		tx_agc_index = cali_info->absolute_ofdm_swing_idx[rf_path];
+		tx_bb_swing_index = cali_info->default_ofdm_index;
+	} else if (cali_info->absolute_ofdm_swing_idx[rf_path] > tx_power_index_offest) {
+		tx_agc_index = tx_power_index_offest;
+		cali_info->remnant_ofdm_swing_idx[rf_path] = cali_info->absolute_ofdm_swing_idx[rf_path] - tx_power_index_offest;
+		tx_bb_swing_index = cali_info->default_ofdm_index + cali_info->remnant_ofdm_swing_idx[rf_path];
+
+		if (tx_bb_swing_index > bb_swing_upper_bound)
+			tx_bb_swing_index = bb_swing_upper_bound;
+	} else {
+		tx_agc_index = 0;
+
+		if (cali_info->default_ofdm_index > (cali_info->absolute_ofdm_swing_idx[rf_path] * (-1)))
+			tx_bb_swing_index = cali_info->default_ofdm_index + cali_info->absolute_ofdm_swing_idx[rf_path];
+		else
+			tx_bb_swing_index = bb_swing_lower_bound;
+
+		if (tx_bb_swing_index <  bb_swing_lower_bound)
+			tx_bb_swing_index = bb_swing_lower_bound;
+	}
+
+	cali_info->absolute_ofdm_swing_idx[rf_path] = tx_agc_index;
+	cali_info->bb_swing_idx_ofdm[rf_path] = tx_bb_swing_index;
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"MixMode Offset Path_%d   cali_info->absolute_ofdm_swing_idx[rf_path]=%d   cali_info->bb_swing_idx_ofdm[rf_path]=%d   tx_power_index_offest=%d\n",
+		rf_path, cali_info->absolute_ofdm_swing_idx[rf_path], cali_info->bb_swing_idx_ofdm[rf_path], tx_power_index_offest);
+
+	return true;
+}
+
+
+void
+odm_tx_pwr_track_set_pwr8822b(
+	void				*dm_void,
+	enum pwrtrack_method	method,
+	u8				rf_path,
+	u8				channel_mapped_index
+)
+{
+#if 0
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	u8			channel  = *dm->channel;
+	u8			band_width  = hal_data->current_channel_bw;
+	u8			tx_power_index = 0;
+	u8			tx_rate = 0xFF;
+	enum rt_status		status = RT_STATUS_SUCCESS;
+
+	PHALMAC_PWR_TRACKING_OPTION p_pwr_tracking_opt = &(cali_info->HALMAC_PWR_TRACKING_INFO);
+
+	if (*(dm->mp_mode) == true) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+		PMPT_CONTEXT p_mpt_ctx = &(adapter->mpt_ctx);
+
+		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+		PMPT_CONTEXT p_mpt_ctx = &(adapter->mppriv.mpt_ctx);
+
+		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
+#endif
+#endif
+	} else {
+		u16	rate	 = *(dm->forced_data_rate);
+
+		if (!rate) { /*auto rate*/
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			tx_rate = ((PADAPTER)adapter)->HalFunc.GetHwRateFromMRateHandler(dm->tx_rate);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+			if (dm->number_linked_client != 0)
+				tx_rate = hw_rate_to_m_rate(dm->tx_rate);
+#endif
+		} else   /*force rate*/
+			tx_rate = (u8) rate;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Call:%s tx_rate=0x%X\n", __func__, tx_rate);
+
+	tx_power_index = phy_get_tx_power_index(adapter, (enum rf_path) rf_path, tx_rate, band_width, channel);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"type=%d   tx_power_index=%d	 cali_info->absolute_ofdm_swing_idx=%d   cali_info->default_ofdm_index=%d   rf_path=%d\n", method, tx_power_index, cali_info->absolute_ofdm_swing_idx[rf_path], cali_info->default_ofdm_index, rf_path);
+
+	p_pwr_tracking_opt->type = method;
+	p_pwr_tracking_opt->bbswing_index = cali_info->default_ofdm_index;
+	p_pwr_tracking_opt->pwr_tracking_para[rf_path].enable = 1;
+	p_pwr_tracking_opt->pwr_tracking_para[rf_path].tx_pwr_index = tx_power_index;
+	p_pwr_tracking_opt->pwr_tracking_para[rf_path].pwr_tracking_offset_value = cali_info->absolute_ofdm_swing_idx[rf_path];
+	p_pwr_tracking_opt->pwr_tracking_para[rf_path].tssi_value = 0;
+
+
+	if (rf_path == (MAX_PATH_NUM_8822B - 1)) {
+		status = hal_mac_send_power_tracking_info(&GET_HAL_MAC_INFO(adapter), p_pwr_tracking_opt);
+
+		if (status == RT_STATUS_SUCCESS) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				     "path A  0xC94=0x%X   0xC1C=0x%X\n",
+				odm_get_bb_reg(dm, 0xC94, BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25)),
+				odm_get_bb_reg(dm, 0xC1C, 0xFFE00000)
+				     );
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				     "path B  0xE94=0x%X   0xE1C=0x%X\n",
+				odm_get_bb_reg(dm, 0xE94, BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25)),
+				odm_get_bb_reg(dm, 0xE1C, 0xFFE00000)
+				     );
+		} else {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Power Tracking to FW Fail ret code = %d\n", status);
+		}
+	}
+
+#endif
+
+	struct dm_struct		*dm		= (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info	= &dm->rf_calibrate_info;
+	struct _hal_rf_	*rf = &dm->rf_table;
+	u8			tx_power_index_offest = 0;
+	u8			tx_power_index = 0;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_phy *rtlphy = &rtlpriv->phy;
+	u8			channel  = rtlphy->current_channel;
+	u8			band_width  = rtlphy->current_chan_bw;
+#else
+	struct _ADAPTER		*adapter = (PADAPTER)dm->adapter;
+	u8			channel  = *dm->channel;
+	u8			band_width  = *dm->band_width;
+#endif
+	u8			tx_rate = 0xFF;
+
+	if (*dm->mp_mode == true) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+		PMPT_CONTEXT p_mpt_ctx = &adapter->MptCtx;
+
+		tx_rate = MptToMgntRate(p_mpt_ctx->MptRateIndex);
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#ifdef CONFIG_MP_INCLUDED
+		PMPT_CONTEXT p_mpt_ctx = &adapter->mppriv.mpt_ctx;
+
+		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
+#endif
+#endif
+#endif
+	} else {
+		u16	rate	 = *dm->forced_data_rate;
+
+		if (!rate) { /*auto rate*/
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			tx_rate = ((PADAPTER)adapter)->HalFunc.GetHwRateFromMRateHandler(dm->tx_rate);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			tx_rate = dm->tx_rate;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+			if (dm->number_linked_client != 0)
+				tx_rate = hw_rate_to_m_rate(dm->tx_rate);
+			else
+				tx_rate = rf->p_rate_index;
+#endif
+		} else   /*force rate*/
+			tx_rate = (u8) rate;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Call:%s tx_rate=0x%X\n", __func__, tx_rate);
+
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"pRF->default_ofdm_index=%d   pRF->default_cck_index=%d\n", cali_info->default_ofdm_index, cali_info->default_cck_index);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"pRF->absolute_ofdm_swing_idx=%d   pRF->remnant_ofdm_swing_idx=%d   pRF->absolute_cck_swing_idx=%d   pRF->remnant_cck_swing_idx=%d   rf_path=%d\n",
+		cali_info->absolute_ofdm_swing_idx[rf_path], cali_info->remnant_ofdm_swing_idx[rf_path], cali_info->absolute_cck_swing_idx[rf_path], cali_info->remnant_cck_swing_idx, rf_path);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	tx_power_index = odm_get_tx_power_index(dm, (enum rf_path) rf_path, tx_rate, (enum channel_width)band_width, channel);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	tx_power_index = odm_get_tx_power_index(dm, (enum rf_path) rf_path, tx_rate, band_width, channel);
+#else
+	tx_power_index = config_phydm_read_txagc_8822b(dm, rf_path, 0x04); /*0x04(TX_AGC_OFDM_6M)*/
+#endif
+
+	if (tx_power_index >= 63)
+		tx_power_index = 63;
+
+	tx_power_index_offest = 63 - tx_power_index;
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"tx_power_index=%d tx_power_index_offest=%d rf_path=%d\n", tx_power_index, tx_power_index_offest, rf_path);
+
+	if (method == BBSWING) {	/*use for mp driver clean power tracking status*/
+		switch (rf_path) {
+		case RF_PATH_A:
+			odm_set_bb_reg(dm, 0xC94, (BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25)), cali_info->absolute_ofdm_swing_idx[rf_path]);
+			odm_set_bb_reg(dm, REG_A_TX_SCALE_JAGUAR, 0xFFE00000, tx_scaling_table_jaguar[cali_info->bb_swing_idx_ofdm[rf_path]]);
+			break;
+		case RF_PATH_B:
+			odm_set_bb_reg(dm, 0xE94, (BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25)), cali_info->absolute_ofdm_swing_idx[rf_path]);
+			odm_set_bb_reg(dm, REG_B_TX_SCALE_JAGUAR, 0xFFE00000, tx_scaling_table_jaguar[cali_info->bb_swing_idx_ofdm[rf_path]]);
+			break;
+
+		default:
+			break;
+		}
+	} else if (method == MIX_MODE) {
+		switch (rf_path) {
+		case RF_PATH_A:
+			get_mix_mode_tx_agc_bb_swing_offset_8822b(dm, method, rf_path, tx_power_index_offest);
+			odm_set_bb_reg(dm, 0xC94, (BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25)), cali_info->absolute_ofdm_swing_idx[rf_path]);
+			odm_set_bb_reg(dm, REG_A_TX_SCALE_JAGUAR, 0xFFE00000, tx_scaling_table_jaguar[cali_info->bb_swing_idx_ofdm[rf_path]]);
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"TXAGC(0xC94)=0x%x BBSwing(0xc1c)=0x%x BBSwingIndex=%d rf_path=%d\n",
+				odm_get_bb_reg(dm, 0xC94, (BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25))),
+				odm_get_bb_reg(dm, 0xc1c, 0xFFE00000),
+				cali_info->bb_swing_idx_ofdm[rf_path], rf_path);
+			break;
+
+		case RF_PATH_B:
+			get_mix_mode_tx_agc_bb_swing_offset_8822b(dm, method, rf_path, tx_power_index_offest);
+			odm_set_bb_reg(dm, 0xE94, (BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25)), cali_info->absolute_ofdm_swing_idx[rf_path]);
+			odm_set_bb_reg(dm, REG_B_TX_SCALE_JAGUAR, 0xFFE00000, tx_scaling_table_jaguar[cali_info->bb_swing_idx_ofdm[rf_path]]);
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"TXAGC(0xE94)=0x%x BBSwing(0xe1c)=0x%x BBSwingIndex=%d rf_path=%d\n",
+				odm_get_bb_reg(dm, 0xE94, (BIT(29) | BIT(28) | BIT(27) | BIT(26) | BIT(25))),
+				odm_get_bb_reg(dm, 0xe1c, 0xFFE00000),
+				cali_info->bb_swing_idx_ofdm[rf_path], rf_path);
+			break;
+
+		default:
+			break;
+		}
+	}
+}
+
+
+void
+get_delta_swing_table_8822b(
+	void		*dm_void,
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	u8 **temperature_up_a,
+	u8 **temperature_down_a,
+	u8 **temperature_up_b,
+	u8 **temperature_down_b,
+	u8 **temperature_up_cck_a,
+	u8 **temperature_down_cck_a,
+	u8 **temperature_up_cck_b,
+	u8 **temperature_down_cck_b
+#else
+	u8 **temperature_up_a,
+	u8 **temperature_down_a,
+	u8 **temperature_up_b,
+	u8 **temperature_down_b
+#endif
+)
+{
+	struct dm_struct		*dm		= (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info	= &(dm->rf_calibrate_info);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	u8			channel			= *(dm->channel);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_phy *rtlphy = &(rtlpriv->phy);
+	u8			channel  = rtlphy->current_channel;
+#else
+	void		*adapter			= dm->adapter;
+	u8			channel			= *dm->channel;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	*temperature_up_cck_a   = cali_info->delta_swing_table_idx_2g_cck_a_p;
+	*temperature_down_cck_a = cali_info->delta_swing_table_idx_2g_cck_a_n;
+	*temperature_up_cck_b   = cali_info->delta_swing_table_idx_2g_cck_b_p;
+	*temperature_down_cck_b = cali_info->delta_swing_table_idx_2g_cck_b_n;
+#endif
+
+	*temperature_up_a   = cali_info->delta_swing_table_idx_2ga_p;
+	*temperature_down_a = cali_info->delta_swing_table_idx_2ga_n;
+	*temperature_up_b   = cali_info->delta_swing_table_idx_2gb_p;
+	*temperature_down_b = cali_info->delta_swing_table_idx_2gb_n;
+
+	if (36 <= channel && channel <= 64) {
+		*temperature_up_a   = cali_info->delta_swing_table_idx_5ga_p[0];
+		*temperature_down_a = cali_info->delta_swing_table_idx_5ga_n[0];
+		*temperature_up_b   = cali_info->delta_swing_table_idx_5gb_p[0];
+		*temperature_down_b = cali_info->delta_swing_table_idx_5gb_n[0];
+	} else if (100 <= channel && channel <= 144)	{
+		*temperature_up_a   = cali_info->delta_swing_table_idx_5ga_p[1];
+		*temperature_down_a = cali_info->delta_swing_table_idx_5ga_n[1];
+		*temperature_up_b   = cali_info->delta_swing_table_idx_5gb_p[1];
+		*temperature_down_b = cali_info->delta_swing_table_idx_5gb_n[1];
+	} else if (149 <= channel && channel <= 177)	{
+		*temperature_up_a   = cali_info->delta_swing_table_idx_5ga_p[2];
+		*temperature_down_a = cali_info->delta_swing_table_idx_5ga_n[2];
+		*temperature_up_b   = cali_info->delta_swing_table_idx_5gb_p[2];
+		*temperature_down_b = cali_info->delta_swing_table_idx_5gb_n[2];
+	}
+}
+
+
+void
+_phy_lc_calibrate_8822b(
+	struct dm_struct	*dm
+)
+{
+	u32 lc_cal = 0, cnt = 0,tmp0xc00, tmp0xe00;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[LCK]LCK start!!!!!!!\n");
+	tmp0xc00 = odm_read_4byte(dm, 0xc00);
+	tmp0xe00 = odm_read_4byte(dm, 0xe00);
+	odm_write_4byte(dm, 0xc00, 0x4);
+	odm_write_4byte(dm, 0xe00, 0x4);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK, 0x10000);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x0, RFREGOFFSETMASK, 0x10000);
+	/*backup RF0x18*/
+	lc_cal = odm_get_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK);
+	/*disable RTK*/
+	odm_set_rf_reg(dm, RF_PATH_A, 0xc4, RFREGOFFSETMASK, 0x01402);
+	/*Start LCK*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal | 0x08000);
+	ODM_delay_ms(100);
+	for (cnt = 0; cnt < 100; cnt++) {
+		if (odm_get_rf_reg(dm, RF_PATH_A, RF_CHNLBW, 0x8000) != 0x1)
+			break;
+		ODM_delay_ms(10);
+	}
+	/*Recover channel number*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal);
+	/*enable RTK*/
+	odm_set_rf_reg(dm, RF_PATH_A, 0xc4, RFREGOFFSETMASK, 0x81402);
+	/**restore*/
+	odm_write_4byte(dm, 0xc00, tmp0xc00);
+	odm_write_4byte(dm, 0xe00, tmp0xe00);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK, 0x3ffff);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x0, RFREGOFFSETMASK, 0x3ffff);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[LCK]LCK end!!!!!!!\n");
+}
+
+/*LCK VERSION:0x1*/
+void
+phy_lc_calibrate_8822b(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	_phy_lc_calibrate_8822b(dm);
+}
+
+
+
+void configure_txpower_track_8822b(
+	struct txpwrtrack_cfg	*config
+)
+{
+	config->swing_table_size_cck = TXSCALE_TABLE_SIZE;
+	config->swing_table_size_ofdm = TXSCALE_TABLE_SIZE;
+	config->threshold_iqk = IQK_THRESHOLD;
+	config->threshold_dpk = DPK_THRESHOLD;
+	config->average_thermal_num = AVG_THERMAL_NUM_8822B;
+	config->rf_path_count = MAX_PATH_NUM_8822B;
+	config->thermal_reg_addr = RF_T_METER_8822B;
+
+	config->odm_tx_pwr_track_set_pwr = odm_tx_pwr_track_set_pwr8822b;
+	config->do_iqk = do_iqk_8822b;
+	config->phy_lc_calibrate = halrf_lck_trigger;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	config->get_delta_all_swing_table = get_delta_swing_table_8822b;
+#else
+	config->get_delta_swing_table = get_delta_swing_table_8822b;
+#endif
+}
+
+
+void phy_set_rf_path_switch_8822b(
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	struct dm_struct		*dm,
+#else
+	void	*adapter,
+#endif
+	boolean		is_main
+)
+{
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#endif
+#endif
+
+	/*BY SY Request */
+	odm_set_bb_reg(dm, 0x4C, (BIT(24) | BIT(23)), 0x2);
+
+	odm_set_bb_reg(dm, 0x974, 0xff, 0xff);
+
+	/*odm_set_bb_reg(dm, 0x1991, 0x3, 0x0);*/
+	odm_set_bb_reg(dm, 0x1990, (BIT(9) | BIT(8)), 0x0);
+
+	/*odm_set_bb_reg(dm, 0xCBE, 0x8, 0x0);*/
+	odm_set_bb_reg(dm, 0xCBC, BIT(19), 0x0);
+
+	odm_set_bb_reg(dm, 0xCB4, 0xff, 0x77);
+
+	odm_set_bb_reg(dm, 0x70, MASKBYTE3, 0x0e);
+	odm_set_bb_reg(dm, 0x1704, MASKDWORD, 0x0000ff00);
+	odm_set_bb_reg(dm, 0x1700, MASKDWORD, 0xc00f0038);
+
+	if (is_main) {
+		/*odm_set_bb_reg(dm, 0xCBD, 0x3, 0x2);		WiFi */
+		odm_set_bb_reg(dm, 0xCBC, (BIT(9) | BIT(8)), 0x2);		/*WiFi */
+	} else {
+		/*odm_set_bb_reg(dm, 0xCBD, 0x3, 0x1);	 BT*/
+		odm_set_bb_reg(dm, 0xCBC, (BIT(9) | BIT(8)), 0x1);	 /*BT*/
+	}
+}
+
+boolean
+_phy_query_rf_path_switch_8822b(
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	struct dm_struct	*dm
+#else
+	void	*adapter
+#endif
+)
+{
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#endif
+#endif
+
+	if (odm_get_bb_reg(dm, 0xCBC, (BIT(9) | BIT(8))) == 0x2)	/*WiFi */
+		return true;
+	else
+		return false;
+}
+
+
+boolean phy_query_rf_path_switch_8822b(
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	struct dm_struct		*dm
+#else
+	void	*adapter
+#endif
+)
+{
+#if DISABLE_BB_RF
+	return true;
+#endif
+
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	return _phy_query_rf_path_switch_8822b(dm);
+#else
+	return _phy_query_rf_path_switch_8822b(adapter);
+#endif
+}
+
+
+#endif	/* (RTL8822B_SUPPORT == 0)*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_8822b.h
new file mode 100644
index 000000000000..ea1c115e1eb5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_8822b.h
@@ -0,0 +1,85 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HAL_PHY_RF_8822B_H__
+#define __HAL_PHY_RF_8822B_H__
+
+#define AVG_THERMAL_NUM_8822B	4
+#define RF_T_METER_8822B		0x42
+
+void configure_txpower_track_8822b(
+	struct txpwrtrack_cfg	*config
+);
+
+void
+odm_tx_pwr_track_set_pwr8822b(
+	void				*dm_void,
+	enum pwrtrack_method	method,
+	u8				rf_path,
+	u8				channel_mapped_index
+);
+
+void
+get_delta_swing_table_8822b(
+	void		*dm_void,
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	u8 **temperature_up_a,
+	u8 **temperature_down_a,
+	u8 **temperature_up_b,
+	u8 **temperature_down_b,
+	u8 **temperature_up_cck_a,
+	u8 **temperature_down_cck_a,
+	u8 **temperature_up_cck_b,
+	u8 **temperature_down_cck_b
+#else
+	u8 **temperature_up_a,
+	u8 **temperature_down_a,
+	u8 **temperature_up_b,
+	u8 **temperature_down_b
+#endif
+);
+
+void
+phy_lc_calibrate_8822b(
+	void *dm_void
+);
+
+void
+halrf_rf_lna_setting_8822b(
+	struct dm_struct	*dm,
+	enum phydm_lna_set type
+);
+
+
+void phy_set_rf_path_switch_8822b(
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	struct dm_struct		*dm,
+#else
+	void	*adapter,
+#endif
+	boolean		is_main
+);
+
+#endif	/* #ifndef __HAL_PHY_RF_8822B_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_iqk_8822b.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_iqk_8822b.c
new file mode 100644
index 000000000000..0c4813d0a6f5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_iqk_8822b.c
@@ -0,0 +1,1811 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#if RT_PLATFORM==PLATFORM_MACOSX
+	#include "phydm_precomp.h"
+	#else
+	#include "../phydm_precomp.h"
+	#endif
+#else
+#include "../../phydm_precomp.h"
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+
+
+/*---------------------------Define Local Constant---------------------------*/
+
+
+void phydm_get_read_counter(struct dm_struct *dm)
+{
+	u32 counter = 0x0;
+
+	while (1) {
+		if ((odm_get_rf_reg(dm, RF_PATH_A, 0x8, RFREGOFFSETMASK) == 0xabcde) || (counter > 300))
+			break;
+		counter++;
+		ODM_delay_ms(1);
+	};
+	odm_set_rf_reg(dm, RF_PATH_A, 0x8, RFREGOFFSETMASK, 0x0);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]counter = %d\n", counter);
+}
+
+/*---------------------------Define Local Constant---------------------------*/
+
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+void do_iqk_8822b(
+	void		*dm_void,
+	u8		delta_thermal_index,
+	u8		thermal_value,
+	u8		threshold
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	
+	dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+	halrf_segment_iqk_trigger(dm, true, iqk_info->segment_iqk);
+}
+#else
+/*Originally config->do_iqk is hooked phy_iq_calibrate_8822b, but do_iqk_8822b and phy_iq_calibrate_8822b have different arguments*/
+void do_iqk_8822b(
+	void		*dm_void,
+	u8	delta_thermal_index,
+	u8	thermal_value,
+	u8	threshold
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	boolean		is_recovery = (boolean) delta_thermal_index;
+
+	halrf_segment_iqk_trigger(dm, true, iqk_info->segment_iqk);
+}
+#endif
+
+
+
+void
+_iqk_rf_set_check(
+	struct dm_struct	*dm,
+	u8		path,
+	u16		add,
+	u32		data
+	)
+{
+	 u32 i;
+
+	odm_set_rf_reg(dm, (enum rf_path)path, add, RFREGOFFSETMASK, data);
+
+	for (i = 0; i < 100; i++) {
+		if (odm_get_rf_reg(dm, (enum rf_path)path, add, RFREGOFFSETMASK) == data)
+			break;
+		else {
+			ODM_delay_us(10);
+			odm_set_rf_reg(dm, (enum rf_path)path, add, RFREGOFFSETMASK, data);
+		}
+	}
+}
+
+
+void
+_iqk_rf0xb0_workaround(
+	struct dm_struct	*dm
+	)
+{
+	/*add 0xb8 control for the bad phase noise after switching channel*/
+	odm_set_rf_reg(dm, (enum rf_path)0x0, 0xb8, RFREGOFFSETMASK, 0x00a00);
+	odm_set_rf_reg(dm, (enum rf_path)0x0, 0xb8, RFREGOFFSETMASK, 0x80a00);
+}
+
+void
+_iqk_fill_iqk_report_8822b(
+	void		*dm_void,
+	u8			channel
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u32		tmp1 = 0x0, tmp2 = 0x0, tmp3 = 0x0;
+	u8		i;
+
+	for (i = 0; i < SS_8822B; i++) {
+		tmp1 = tmp1 + ((iqk_info->iqk_fail_report[channel][i][TX_IQK] & 0x1) << i);
+		tmp2 = tmp2 + ((iqk_info->iqk_fail_report[channel][i][RX_IQK] & 0x1) << (i + 4));
+		tmp3 = tmp3 + ((iqk_info->rxiqk_fail_code[channel][i] & 0x3) << (i * 2 + 8));
+	}
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	odm_set_bb_reg(dm, 0x1bf0, 0x0000ffff, tmp1 | tmp2 | tmp3);
+
+	for (i = 0; i < 2; i++)
+		odm_write_4byte(dm, 0x1be8 + (i * 4), (iqk_info->rxiqk_agc[channel][(i * 2) + 1] << 16) | iqk_info->rxiqk_agc[channel][i * 2]);
+}
+
+void
+_iqk_fail_count_8822b(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8		i;
+
+	dm->n_iqk_cnt++;
+	if (odm_get_rf_reg(dm, RF_PATH_A, 0x1bf0, BIT(16)) == 1)
+		iqk_info->is_reload = true;
+	else
+		iqk_info->is_reload = false;
+
+	if (!iqk_info->is_reload) {
+		for (i = 0; i < 8; i++) {
+			if (odm_get_bb_reg(dm, 0x1bf0, BIT(i)) == 1)
+				dm->n_iqk_fail_cnt++;
+		}
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]All/Fail = %d %d\n", dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
+}
+
+void
+_iqk_iqk_fail_report_8822b(
+	struct dm_struct	*dm
+)
+{
+	u32		tmp1bf0 = 0x0;
+	u8		i;
+
+	tmp1bf0 = odm_read_4byte(dm, 0x1bf0);
+
+	for (i = 0; i < 4; i++) {
+		if (tmp1bf0 & (0x1 << i))
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK] please check S%d TXIQK\n", i);
+#else
+			panic_printk("[IQK] please check S%d TXIQK\n", i);
+#endif
+		if (tmp1bf0 & (0x1 << (i + 12)))
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK] please check S%d RXIQK\n", i);
+#else
+			panic_printk("[IQK] please check S%d RXIQK\n", i);
+#endif
+
+	}
+}
+
+
+void
+_iqk_backup_mac_bb_8822b(
+	struct dm_struct	*dm,
+	u32		*MAC_backup,
+	u32		*BB_backup,
+	u32		*backup_mac_reg,
+	u32		*backup_bb_reg
+)
+{
+	u32 i;
+	for (i = 0; i < MAC_REG_NUM_8822B; i++)
+		MAC_backup[i] = odm_read_4byte(dm, backup_mac_reg[i]);
+
+	for (i = 0; i < BB_REG_NUM_8822B; i++)
+		BB_backup[i] = odm_read_4byte(dm, backup_bb_reg[i]);
+
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]BackupMacBB Success!!!!\n"); */
+}
+
+
+void
+_iqk_backup_rf_8822b(
+	struct dm_struct	*dm,
+	u32		RF_backup[][2],
+	u32		*backup_rf_reg
+)
+{
+	u32 i;
+
+	for (i = 0; i < RF_REG_NUM_8822B; i++) {
+		RF_backup[i][RF_PATH_A] = odm_get_rf_reg(dm, RF_PATH_A, backup_rf_reg[i], RFREGOFFSETMASK);
+		RF_backup[i][RF_PATH_B] = odm_get_rf_reg(dm, RF_PATH_B, backup_rf_reg[i], RFREGOFFSETMASK);
+	}
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]BackupRF Success!!!!\n"); */
+}
+
+
+void
+_iqk_agc_bnd_int_8822b(
+	struct dm_struct	*dm
+)
+{
+	/*initialize RX AGC bnd, it must do after bbreset*/
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	odm_write_4byte(dm, 0x1b00, 0xf80a7008);
+	odm_write_4byte(dm, 0x1b00, 0xf8015008);
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	/*PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]init. rx agc bnd\n");*/
+}
+
+
+void
+_iqk_bb_reset_8822b(
+	struct dm_struct	*dm
+)
+{
+	boolean		cca_ing = false;
+	u32		count = 0;
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK, 0x10000);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x0, RFREGOFFSETMASK, 0x10000);
+	/*reset BB report*/
+	odm_set_bb_reg(dm, 0x8f8, 0x0ff00000, 0x0);
+
+	while (1) {
+		odm_write_4byte(dm, 0x8fc, 0x0);
+		odm_set_bb_reg(dm, 0x198c, 0x7, 0x7);
+		cca_ing = (boolean) odm_get_bb_reg(dm, 0xfa0, BIT(3));
+
+		if (count > 30)
+			cca_ing = false;
+
+		if (cca_ing) {
+			ODM_delay_ms(1);
+			count++;
+		} else {
+			odm_write_1byte(dm, 0x808, 0x0);	/*RX ant off*/
+			odm_set_bb_reg(dm, 0xa04, BIT(27) | BIT(26) | BIT(25) | BIT(24), 0x0);		/*CCK RX path off*/
+
+			/*BBreset*/
+			odm_set_bb_reg(dm, 0x0, BIT(16), 0x0);
+			odm_set_bb_reg(dm, 0x0, BIT(16), 0x1);
+
+			if (odm_get_bb_reg(dm, 0x660, BIT(16)))
+				odm_write_4byte(dm, 0x6b4, 0x89000006);
+			/*PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]BBreset!!!!\n");*/
+			break;
+		}
+	}
+}
+
+void
+_iqk_afe_setting_8822b(
+	struct dm_struct	*dm,
+	boolean		do_iqk
+)
+{
+	if (do_iqk) {
+		odm_write_4byte(dm, 0xc60, 0x50000000);
+		odm_write_4byte(dm, 0xc60, 0x70070040);
+		odm_write_4byte(dm, 0xe60, 0x50000000);
+		odm_write_4byte(dm, 0xe60, 0x70070040);
+		odm_write_4byte(dm, 0xc58, 0xd8000402);
+		odm_write_4byte(dm, 0xc5c, 0xd1000120);
+		odm_write_4byte(dm, 0xc6c, 0x00000a15);
+		odm_write_4byte(dm, 0xe58, 0xd8000402);
+		odm_write_4byte(dm, 0xe5c, 0xd1000120);
+		odm_write_4byte(dm, 0xe6c, 0x00000a15);
+		_iqk_bb_reset_8822b(dm);
+		/*		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]AFE setting for IQK mode!!!!\n"); */
+	} else {
+		odm_write_4byte(dm, 0xc60, 0x50000000);
+		odm_write_4byte(dm, 0xc60, 0x70038040);
+		odm_write_4byte(dm, 0xe60, 0x50000000);
+		odm_write_4byte(dm, 0xe60, 0x70038040);
+		odm_write_4byte(dm, 0xc58, 0xd8020402);
+		odm_write_4byte(dm, 0xc5c, 0xde000120);
+		odm_write_4byte(dm, 0xc6c, 0x0000122a);
+		odm_write_4byte(dm, 0xe58, 0xd8020402);
+		odm_write_4byte(dm, 0xe5c, 0xde000120);
+		odm_write_4byte(dm, 0xe6c, 0x0000122a);
+		/*		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]AFE setting for Normal mode!!!!\n"); */
+	}
+	/*0x9a4[31]=0: Select da clock*/
+	odm_set_bb_reg(dm, 0x9a4, BIT(31), 0x0);
+}
+
+void
+_iqk_restore_mac_bb_8822b(
+	struct dm_struct		*dm,
+	u32		*MAC_backup,
+	u32		*BB_backup,
+	u32		*backup_mac_reg,
+	u32		*backup_bb_reg
+)
+{
+	u32 i;
+
+	for (i = 0; i < MAC_REG_NUM_8822B; i++)
+		odm_write_4byte(dm, backup_mac_reg[i], MAC_backup[i]);
+	for (i = 0; i < BB_REG_NUM_8822B; i++)
+		odm_write_4byte(dm, backup_bb_reg[i], BB_backup[i]);
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]RestoreMacBB Success!!!!\n"); */
+}
+
+void
+_iqk_restore_rf_8822b(
+	struct dm_struct			*dm,
+	u32			*backup_rf_reg,
+	u32			RF_backup[][2]
+)
+{
+	u32 i;
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_B, 0xef, RFREGOFFSETMASK, 0x0);
+	/*0xdf[4]=0*/
+	_iqk_rf_set_check(dm, RF_PATH_A, 0xdf, RF_backup[0][RF_PATH_A] & (~BIT(4)));
+	_iqk_rf_set_check(dm, RF_PATH_B, 0xdf, RF_backup[0][RF_PATH_B] & (~BIT(4)));
+	
+	/*odm_set_rf_reg(dm, RF_PATH_A, 0xdf, RFREGOFFSETMASK, RF_backup[0][RF_PATH_A] & (~BIT(4)));*/
+	/*odm_set_rf_reg(dm, RF_PATH_B, 0xdf, RFREGOFFSETMASK, RF_backup[0][RF_PATH_B] & (~BIT(4)));*/
+
+	for (i = 1; i < RF_REG_NUM_8822B; i++) {
+		odm_set_rf_reg(dm, RF_PATH_A, backup_rf_reg[i], RFREGOFFSETMASK, RF_backup[i][RF_PATH_A]);
+		odm_set_rf_reg(dm, RF_PATH_B, backup_rf_reg[i], RFREGOFFSETMASK, RF_backup[i][RF_PATH_B]);
+	}
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]RestoreRF Success!!!!\n"); */
+
+}
+
+
+void
+_iqk_backup_iqk_8822b(
+	struct dm_struct			*dm,
+	u8				step,
+	u8				path
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8		i, j, k;
+
+	switch (step) {
+	case 0:
+		iqk_info->iqk_channel[1] = iqk_info->iqk_channel[0];
+		for (i = 0; i < 2; i++) {
+			iqk_info->lok_idac[1][i] = iqk_info->lok_idac[0][i];
+			iqk_info->rxiqk_agc[1][i] = iqk_info->rxiqk_agc[0][i];
+			iqk_info->bypass_iqk[1][i] = iqk_info->bypass_iqk[0][i];
+			iqk_info->rxiqk_fail_code[1][i] = iqk_info->rxiqk_fail_code[0][i];
+			for (j = 0; j < 2; j++) {
+				iqk_info->iqk_fail_report[1][i][j] = iqk_info->iqk_fail_report[0][i][j];
+				for (k = 0; k < 8; k++) {
+					iqk_info->iqk_cfir_real[1][i][j][k] = iqk_info->iqk_cfir_real[0][i][j][k];
+					iqk_info->iqk_cfir_imag[1][i][j][k] = iqk_info->iqk_cfir_imag[0][i][j][k];
+				}
+			}
+		}
+
+		for (i = 0; i < 4; i++) {
+			iqk_info->rxiqk_fail_code[0][i] = 0x0;
+			iqk_info->rxiqk_agc[0][i] = 0x0;
+			for (j = 0; j < 2; j++) {
+				iqk_info->iqk_fail_report[0][i][j] = true;
+				iqk_info->gs_retry_count[0][i][j] = 0x0;
+			}
+			for (j = 0; j < 3; j++)
+				iqk_info->retry_count[0][i][j] = 0x0;
+		}
+		/*backup channel*/
+		iqk_info->iqk_channel[0] = iqk_info->rf_reg18;
+		break;
+	case 1: /*LOK backup*/
+			iqk_info->lok_idac[0][path] = odm_get_rf_reg(dm, (enum rf_path)path, 0x58, RFREGOFFSETMASK);
+		break;
+	case 2:	/*TXIQK backup*/
+	case 3: /*RXIQK backup*/	
+		phydm_get_iqk_cfir(dm, (step-2), path, false);
+		break;
+	}
+}
+
+void
+_iqk_reload_iqk_setting_8822b(
+	struct dm_struct			*dm,
+	u8				channel,
+	u8				reload_idx  /*1: reload TX, 2: reload LO, TX, RX*/
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8 i, path, idx;
+	u16 iqk_apply[2] = {0xc94, 0xe94};
+	u32 tmp;
+
+	for (path = 0; path < 2; path++) {
+		if (reload_idx == 2) {
+			/*odm_set_rf_reg(dm, (enum rf_path)path, 0xdf, BIT(4), 0x1);*/
+			tmp = odm_get_rf_reg(dm, (enum rf_path)path, 0xdf, RFREGOFFSETMASK) | BIT(4);
+			_iqk_rf_set_check(dm, (enum rf_path)path, 0xdf, tmp);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x58, RFREGOFFSETMASK, iqk_info->lok_idac[channel][path]);
+		}
+
+		for (idx = 0; idx < reload_idx; idx++) {
+			odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+			odm_set_bb_reg(dm, 0x1b2c, MASKDWORD, 0x7);
+			odm_set_bb_reg(dm, 0x1b38, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1b3c, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1bcc, MASKDWORD, 0x00000000);
+			if (idx == 0)
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+			else
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
+			odm_set_bb_reg(dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+			for (i = 0; i < 8; i++) {
+				odm_write_4byte(dm, 0x1bd8,	((0xc0000000 >> idx) + 0x3) + (i * 4) + (iqk_info->iqk_cfir_real[channel][path][idx][i] << 9));
+				odm_write_4byte(dm, 0x1bd8, ((0xc0000000 >> idx) + 0x1) + (i * 4) + (iqk_info->iqk_cfir_imag[channel][path][idx][i] << 9));
+			}
+			if (idx == 0)
+				odm_set_bb_reg(dm, iqk_apply[path], BIT(0), ~(iqk_info->iqk_fail_report[channel][path][idx]));
+			else
+				odm_set_bb_reg(dm, iqk_apply[path], BIT(10), ~(iqk_info->iqk_fail_report[channel][path][idx]));
+		}
+		odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0x0);
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+	}
+}
+
+boolean
+_iqk_reload_iqk_8822b(
+	struct dm_struct			*dm,
+	boolean			reset
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8 i;
+	iqk_info->is_reload = false;
+
+	if (reset) {
+		for (i = 0; i < 2; i++)
+			iqk_info->iqk_channel[i] = 0x0;
+	} else {
+		iqk_info->rf_reg18 = odm_get_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK);
+
+		for (i = 0; i < 2; i++) {
+			if (iqk_info->rf_reg18 == iqk_info->iqk_channel[i]) {
+				_iqk_reload_iqk_setting_8822b(dm, i, 2);
+				_iqk_fill_iqk_report_8822b(dm, i);
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]reload IQK result before!!!!\n");
+				 iqk_info->is_reload = true;
+			}
+		}
+	}
+	/*report*/
+	odm_set_bb_reg(dm, 0x1bf0, BIT(16), (u8) iqk_info->is_reload);
+	return  iqk_info->is_reload;
+}
+
+
+void
+_iqk_rfe_setting_8822b(
+	struct dm_struct	*dm,
+	boolean		ext_pa_on
+)
+{
+	if (ext_pa_on) {
+		/*RFE setting*/
+		odm_write_4byte(dm, 0xcb0, 0x77777777);
+		odm_write_4byte(dm, 0xcb4, 0x00007777);
+		odm_write_4byte(dm, 0xcbc, 0x0000083B);
+		odm_write_4byte(dm, 0xeb0, 0x77777777);
+		odm_write_4byte(dm, 0xeb4, 0x00007777);
+		odm_write_4byte(dm, 0xebc, 0x0000083B);
+		/*odm_write_4byte(dm, 0x1990, 0x00000c30);*/
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]external PA on!!!!\n");
+	} else {
+		/*RFE setting*/
+		odm_write_4byte(dm, 0xcb0, 0x77777777);
+		odm_write_4byte(dm, 0xcb4, 0x00007777);
+		odm_write_4byte(dm, 0xcbc, 0x00000100);
+		odm_write_4byte(dm, 0xeb0, 0x77777777);
+		odm_write_4byte(dm, 0xeb4, 0x00007777);
+		odm_write_4byte(dm, 0xebc, 0x00000100);
+		/*odm_write_4byte(dm, 0x1990, 0x00000c30);*/
+		/*		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]external PA off!!!!\n");*/
+	}
+}
+
+
+void
+_iqk_rf_setting_8822b(
+	struct dm_struct	*dm
+)
+{
+	u8 path;
+	u32 tmp;
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	odm_write_4byte(dm, 0x1bb8, 0x00000000);
+
+	for (path = 0; path < 2; path++) {
+		/*0xdf:B11 = 1,B4 = 0, B1 = 1*/
+		tmp = odm_get_rf_reg(dm, (enum rf_path)path, 0xdf, RFREGOFFSETMASK);
+		tmp = (tmp & (~BIT(4))) | BIT(1) | BIT(11);
+		_iqk_rf_set_check(dm, (enum rf_path)path, 0xdf, tmp);
+		/*odm_set_rf_reg(dm, (enum rf_path)path, 0xdf, RFREGOFFSETMASK, tmp);*/
+
+		/*release 0x56 TXBB*/
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x65, RFREGOFFSETMASK, 0x09000);
+
+		if (*dm->band_type == ODM_BAND_5G) {
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x1);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x33, RFREGOFFSETMASK, 0x00026);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3e, RFREGOFFSETMASK, 0x00037);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3f, RFREGOFFSETMASK, 0xdefce);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x0);
+		} else {
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x1);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x33, RFREGOFFSETMASK, 0x00026);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3e, RFREGOFFSETMASK, 0x00037);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0x3f, RFREGOFFSETMASK, 0x5efce);
+			odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(19), 0x0);
+		}
+	}
+}
+
+
+
+void
+_iqk_configure_macbb_8822b(
+	struct dm_struct		*dm
+)
+{
+	/*MACBB register setting*/
+	odm_write_1byte(dm, 0x522, 0x7f);
+	odm_set_bb_reg(dm, 0x550, BIT(11) | BIT(3), 0x0);
+	odm_set_bb_reg(dm, 0x90c, BIT(15), 0x1);			/*0x90c[15]=1: dac_buf reset selection*/
+	/*0xc94[0]=1, 0xe94[0]=1: Let tx from IQK*/
+	odm_set_bb_reg(dm, 0xc94, BIT(0), 0x1);
+	odm_set_bb_reg(dm, 0xe94, BIT(0), 0x1);
+	odm_set_bb_reg(dm, 0xc94, (BIT(11) | BIT(10)), 0x1);
+	odm_set_bb_reg(dm, 0xe94, (BIT(11) | BIT(10)), 0x1);
+	/* 3-wire off*/
+	odm_write_4byte(dm, 0xc00, 0x00000004);
+	odm_write_4byte(dm, 0xe00, 0x00000004);
+	/*disable PMAC*/
+	odm_set_bb_reg(dm, 0xb00, BIT(8), 0x0);
+	/*disable CCK block*/
+	odm_set_bb_reg(dm, 0x808, BIT(28), 0x0);
+	/*disable OFDM CCA*/
+	odm_set_bb_reg(dm, 0x838, BIT(3) | BIT(2) | BIT(1), 0x7);
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]Set MACBB setting for IQK!!!!\n");*/
+
+}
+
+void
+_iqk_lok_setting_8822b(
+	struct dm_struct	*dm,
+
+	u8 path
+)
+{
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+	odm_write_4byte(dm, 0x1bcc, 0x9);
+	odm_write_1byte(dm, 0x1b23, 0x00);
+
+	switch (*dm->band_type) {
+	case ODM_BAND_2_4G:
+		odm_write_1byte(dm, 0x1b2b, 0x00);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x50df2);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xadc00);
+		/* WE_LUT_TX_LOK*/
+		odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(4), 0x1);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x33, BIT(1) | BIT(0), 0x0);
+		break;
+	case ODM_BAND_5G:
+		odm_write_1byte(dm, 0x1b2b, 0x80);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x5086c);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xa9c00);
+		/* WE_LUT_TX_LOK*/
+		odm_set_rf_reg(dm, (enum rf_path)path, 0xef, BIT(4), 0x1);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x33, BIT(1) | BIT(0), 0x1);
+		break;
+	}
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]Set LOK setting!!!!\n");*/
+}
+
+
+void
+_iqk_txk_setting_8822b(
+	struct dm_struct	*dm,
+	u8 path
+)
+{
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+	odm_write_4byte(dm, 0x1bcc, 0x9);
+	odm_write_4byte(dm, 0x1b20, 0x01440008);
+
+	if (path == 0x0)
+		odm_write_4byte(dm, 0x1b00, 0xf800000a);
+	else
+		odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	odm_write_4byte(dm, 0x1bcc, 0x3f);
+
+	switch (*dm->band_type) {
+	case ODM_BAND_2_4G:
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x50df2);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xadc00);
+		odm_write_1byte(dm, 0x1b2b, 0x00);
+		break;
+	case ODM_BAND_5G:
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x500ef);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xa9c00);
+		odm_write_1byte(dm, 0x1b2b, 0x80);
+		break;
+	}
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]Set TXK setting!!!!\n");*/
+
+}
+
+
+void
+_iqk_rxk1_setting_8822b(
+	struct dm_struct	*dm,
+	u8 path
+)
+{
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+
+	switch (*dm->band_type) {
+	case ODM_BAND_2_4G:
+		odm_write_1byte(dm, 0x1bcc, 0x9);
+		odm_write_1byte(dm, 0x1b2b, 0x00);
+		odm_write_4byte(dm, 0x1b20, 0x01450008);
+		odm_write_4byte(dm, 0x1b24, 0x01460c88);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x510e0);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xacc00);
+		break;
+	case ODM_BAND_5G:
+		odm_write_1byte(dm, 0x1bcc, 0x09);
+		odm_write_1byte(dm, 0x1b2b, 0x80);
+		odm_write_4byte(dm, 0x1b20, 0x00850008);
+		odm_write_4byte(dm, 0x1b24, 0x00460048);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x510e0);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xadc00);
+		break;
+	}
+	/*PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]Set RXK setting!!!!\n");*/
+
+}
+
+
+void
+_iqk_rxk2_setting_8822b(
+	struct dm_struct	*dm,
+	u8 path,
+	boolean is_gs
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+
+	switch (*dm->band_type) {
+	case ODM_BAND_2_4G:
+		if (is_gs)
+			iqk_info->tmp1bcc = 0x12;
+		odm_write_1byte(dm, 0x1bcc, iqk_info->tmp1bcc);
+		odm_write_1byte(dm, 0x1b2b, 0x00);
+		odm_write_4byte(dm, 0x1b20, 0x01450008);
+		odm_write_4byte(dm, 0x1b24, 0x01460848);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x510e0);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xa9c00);
+		break;
+	case ODM_BAND_5G:
+		if (is_gs) {
+			if (path == RF_PATH_A)
+				iqk_info->tmp1bcc = 0x12;
+			else
+				iqk_info->tmp1bcc = 0x09;
+		}
+			odm_write_1byte(dm, 0x1bcc, iqk_info->tmp1bcc);
+		odm_write_1byte(dm, 0x1b2b, 0x80);
+		odm_write_4byte(dm, 0x1b20, 0x00850008);
+		odm_write_4byte(dm, 0x1b24, 0x00460848);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK, 0x51060);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8f, RFREGOFFSETMASK, 0xa9c00);
+		break;
+	}
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]Set RXK setting!!!!\n");*/
+
+}
+
+
+void
+halrf_iqk_set_rf0x8(
+	struct dm_struct	*dm,
+	u8	path
+)
+{
+	u16 c = 0x0;
+
+	while (c < 30000) {
+		odm_set_rf_reg(dm, (enum rf_path)path, 0xef, RFREGOFFSETMASK, 0x0);
+		odm_set_rf_reg(dm, (enum rf_path)path, 0x8, RFREGOFFSETMASK, 0x0);
+		if (odm_get_rf_reg(dm, (enum rf_path)path, 0x8, RFREGOFFSETMASK) == 0x0)
+			break;
+		c++;
+	}
+}
+
+void
+halrf_iqk_check_if_reload(
+	struct dm_struct	*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	iqk_info->is_reload = (boolean)odm_get_bb_reg(dm, 0x1bf0, BIT(16));
+}
+
+
+boolean
+_iqk_check_cal_8822b(
+	struct	dm_struct	*dm,
+	u8	path,
+	u8	cmd
+)
+{
+	boolean	notready = true, fail = true;
+	u32	delay_count = 0x0;
+
+	while (notready) {
+		if (odm_get_rf_reg(dm, (enum rf_path)path, 0x8, RFREGOFFSETMASK) == 0x12345) {
+			if (cmd == 0x0)/*LOK*/
+				fail = false;
+			else
+				fail = (boolean) odm_get_bb_reg(dm, 0x1b08, BIT(26));
+			notready = false;
+		} else {
+			ODM_delay_ms(1);
+			delay_count++;
+		}
+
+		if (delay_count >= 50) {
+			fail = true;
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]IQK timeout!!!\n");
+			break;
+		}
+	}
+	halrf_iqk_set_rf0x8(dm, path);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]delay count = 0x%x!!!\n", delay_count);
+	return fail;
+}
+
+
+boolean
+_iqk_rx_iqk_gain_search_fail_8822b(
+	struct dm_struct			*dm,
+	u8		path,
+	u8		step
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	boolean	fail = true;
+	u32	IQK_CMD = 0x0, rf_reg0, tmp, bb_idx;
+	u8	IQMUX[4] = {0x9, 0x12, 0x1b, 0x24};
+	u8	idx;
+
+
+	if (step == RXIQK1) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]============ S%d RXIQK GainSearch ============\n", path);
+		IQK_CMD = 0xf8000208 | (1 << (path + 4));
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]S%d GS%d_Trigger = 0x%x\n", path, step, IQK_CMD);
+		odm_write_4byte(dm, 0x1b00, IQK_CMD);
+		odm_write_4byte(dm, 0x1b00, IQK_CMD + 0x1);
+		ODM_delay_ms(GS_delay_8822B);
+		fail = _iqk_check_cal_8822b(dm, path, 0x1);
+	} else if (step == RXIQK2) {
+		for (idx = 0; idx < 4; idx++) {
+			if (iqk_info->tmp1bcc == IQMUX[idx])
+				break;
+		}
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		odm_write_4byte(dm, 0x1bcc, iqk_info->tmp1bcc);
+
+		IQK_CMD = 0xf8000308 | (1 << (path + 4));
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]S%d GS%d_Trigger = 0x%x\n", path, step, IQK_CMD);
+		odm_write_4byte(dm, 0x1b00, IQK_CMD);
+		odm_write_4byte(dm, 0x1b00, IQK_CMD + 0x1);
+		ODM_delay_ms(GS_delay_8822B);
+		fail = _iqk_check_cal_8822b(dm, path, 0x1);
+
+		rf_reg0 = odm_get_rf_reg(dm, (enum rf_path)path, 0x0, RFREGOFFSETMASK);
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]S%d ==> RF0x0 = 0x%x, tmp1bcc = 0x%x, idx = %d, 0x1b3c = 0x%x\n", path, rf_reg0, iqk_info->tmp1bcc, idx, odm_read_4byte(dm, 0x1b3c));
+		tmp = (rf_reg0 & 0x1fe0) >> 5;
+		iqk_info->lna_idx = tmp >> 5;
+		bb_idx = tmp & 0x1f;
+
+		if (bb_idx == 0x1) {
+			if (iqk_info->lna_idx != 0x0)
+				iqk_info->lna_idx--;
+			else if (idx != 3)
+				idx++;
+			else
+				iqk_info->isbnd = true;
+			fail = true;
+		} else if (bb_idx == 0xa) {
+			if (idx != 0)
+				idx--;
+			else if (iqk_info->lna_idx != 0x7)
+				iqk_info->lna_idx++;
+			else
+				iqk_info->isbnd = true;
+			fail = true;
+		} else
+			fail = false;
+
+		if (iqk_info->isbnd == true)
+			fail = false;
+
+		iqk_info->tmp1bcc = IQMUX[idx];
+
+		if (fail) {
+			odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+			odm_write_4byte(dm, 0x1b24, (odm_read_4byte(dm, 0x1b24) & 0xffffe3ff) | (iqk_info->lna_idx << 10));
+		}
+	}
+	return fail;
+}
+
+boolean
+_lok_one_shot_8822b(
+	void		*dm_void,
+	u8			path
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8	delay_count = 0;
+	boolean	LOK_notready = false;
+	u32	LOK_temp = 0;
+	u32	IQK_CMD = 0x0;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]==========S%d LOK ==========\n", path);
+	IQK_CMD = 0xf8000008 | (1 << (4 + path));
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]LOK_Trigger = 0x%x\n", IQK_CMD);
+	odm_write_4byte(dm, 0x1b00, IQK_CMD);
+	odm_write_4byte(dm, 0x1b00, IQK_CMD + 1);
+	/*LOK: CMD ID = 0	{0xf8000018, 0xf8000028}*/
+	/*LOK: CMD ID = 0	{0xf8000019, 0xf8000029}*/
+	ODM_delay_ms(LOK_delay_8822B);
+	LOK_notready = _iqk_check_cal_8822b(dm, path, 0x0);
+	if (!LOK_notready)
+		_iqk_backup_iqk_8822b(dm, 0x1, path);
+	if (ODM_COMP_CALIBRATION) {
+		if (!LOK_notready) {
+			LOK_temp = odm_get_rf_reg(dm, (enum rf_path)path, 0x58, RFREGOFFSETMASK);
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]0x58 = 0x%x\n", LOK_temp);
+		} else
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]==>S%d LOK Fail!!!\n", path);
+	}
+	iqk_info->lok_fail[path] = LOK_notready;
+	return LOK_notready;
+}
+
+
+
+
+boolean
+_iqk_one_shot_8822b(
+	void		*dm_void,
+	u8		path,
+	u8		idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8		delay_count = 0;
+	boolean		notready = true, fail = true;
+	u32		IQK_CMD = 0x0;
+	u16		iqk_apply[2]	= {0xc94, 0xe94};
+
+	if (idx == TXIQK)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]============ S%d WBTXIQK ============\n", path);
+	else if (idx == RXIQK1)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]============ S%d WBRXIQK STEP1============\n", path);
+	else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]============ S%d WBRXIQK STEP2============\n", path);
+
+	if (idx == TXIQK) {
+		IQK_CMD = 0xf8000008 | ((*dm->band_width + 4) << 8) | (1 << (path + 4));
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]TXK_Trigger = 0x%x\n", IQK_CMD);
+		/*{0xf8000418, 0xf800042a} ==> 20 WBTXK (CMD = 4)*/
+		/*{0xf8000518, 0xf800052a} ==> 40 WBTXK (CMD = 5)*/
+		/*{0xf8000618, 0xf800062a} ==> 80 WBTXK (CMD = 6)*/
+	} else if (idx == RXIQK1) {
+		if (*dm->band_width == 2)
+			IQK_CMD = 0xf8000808 | (1 << (path + 4));
+		else
+			IQK_CMD = 0xf8000708 | (1 << (path + 4));
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]RXK1_Trigger = 0x%x\n", IQK_CMD);
+		/*{0xf8000718, 0xf800072a} ==> 20 WBTXK (CMD = 7)*/
+		/*{0xf8000718, 0xf800072a} ==> 40 WBTXK (CMD = 7)*/
+		/*{0xf8000818, 0xf800082a} ==> 80 WBTXK (CMD = 8)*/
+	} else if (idx == RXIQK2) {
+		IQK_CMD = 0xf8000008 | ((*dm->band_width + 9) << 8) | (1 << (path + 4));
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]RXK2_Trigger = 0x%x\n", IQK_CMD);
+		/*{0xf8000918, 0xf800092a} ==> 20 WBRXK (CMD = 9)*/
+		/*{0xf8000a18, 0xf8000a2a} ==> 40 WBRXK (CMD = 10)*/
+		/*{0xf8000b18, 0xf8000b2a} ==> 80 WBRXK (CMD = 11)*/
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		odm_write_4byte(dm, 0x1b24, (odm_read_4byte(dm, 0x1b24) & 0xffffe3ff) | ((iqk_info->lna_idx & 0x7) << 10));
+	}
+	odm_write_4byte(dm, 0x1b00, IQK_CMD);
+	odm_write_4byte(dm, 0x1b00, IQK_CMD + 0x1);
+	ODM_delay_ms(WBIQK_delay_8822B);
+	fail = _iqk_check_cal_8822b(dm, path, 0x1);
+
+	if (dm->debug_components & ODM_COMP_CALIBRATION) {
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]S%d ==> 0x1b00 = 0x%x, 0x1b08 = 0x%x\n", path, odm_read_4byte(dm, 0x1b00), odm_read_4byte(dm, 0x1b08));
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]S%d ==> delay_count = 0x%x\n", path, delay_count);
+		if (idx != TXIQK)
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]S%d ==> RF0x0 = 0x%x, RF0x56 = 0x%x\n", path, odm_get_rf_reg(dm, (enum rf_path)path, 0x0, RFREGOFFSETMASK),
+				odm_get_rf_reg(dm, (enum rf_path)path, 0x56, RFREGOFFSETMASK));
+	}
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+
+	if (idx == TXIQK) {
+		if (fail)
+			odm_set_bb_reg(dm, iqk_apply[path], BIT(0), 0x0);
+		else	
+			_iqk_backup_iqk_8822b(dm, 0x2, path);
+	}
+
+	if (idx == RXIQK2) {
+		iqk_info->rxiqk_agc[0][path] =
+			(u16)(((odm_get_rf_reg(dm, (enum rf_path)path, 0x0, RFREGOFFSETMASK) >> 5) & 0xff) |
+			      (iqk_info->tmp1bcc << 8));
+
+		odm_write_4byte(dm, 0x1b38, 0x20000000);
+
+		if (fail)
+			odm_set_bb_reg(dm, iqk_apply[path], (BIT(11) | BIT(10)), 0x0);
+		else
+			_iqk_backup_iqk_8822b(dm, 0x3, path);
+	}
+
+	if (idx == TXIQK)
+		iqk_info->iqk_fail_report[0][path][TXIQK] = fail;
+	else
+		iqk_info->iqk_fail_report[0][path][RXIQK] = fail;
+
+	return fail;
+}
+
+
+boolean
+_iqk_rx_iqk_by_path_8822b(
+	void		*dm_void,
+	u8		path
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	boolean		KFAIL = true, gonext;
+
+#if 1
+	switch (iqk_info->rxiqk_step) {
+	case 1:		/*gain search_RXK1*/
+		_iqk_rxk1_setting_8822b(dm, path);
+		gonext = false;
+		while (1) {
+			KFAIL = _iqk_rx_iqk_gain_search_fail_8822b(dm, path, RXIQK1);
+			if (KFAIL && (iqk_info->gs_retry_count[0][path][0] < 2))
+				iqk_info->gs_retry_count[0][path][0]++;
+			else if (KFAIL) {
+				iqk_info->rxiqk_fail_code[0][path] = 0;
+				iqk_info->rxiqk_step = 5;
+				gonext = true;
+			} else {
+				iqk_info->rxiqk_step++;
+				gonext = true;
+			}
+			if (gonext)
+				break;
+		}
+		halrf_iqk_xym_read(dm, path, 0x2);
+		break;
+	case 2:		/*gain search_RXK2*/
+		_iqk_rxk2_setting_8822b(dm, path, true);
+		iqk_info->isbnd = false;
+		while (1) {
+			KFAIL = _iqk_rx_iqk_gain_search_fail_8822b(dm, path, RXIQK2);
+			if (KFAIL && (iqk_info->gs_retry_count[0][path][1] < rxiqk_gs_limit))
+				iqk_info->gs_retry_count[0][path][1]++;
+			else {
+				iqk_info->rxiqk_step++;
+				break;
+			}
+		}
+		halrf_iqk_xym_read(dm, path, 0x3);
+		break;
+	case 3:		/*RXK1*/
+		_iqk_rxk1_setting_8822b(dm, path);
+		gonext = false;
+		while (1) {
+			KFAIL = _iqk_one_shot_8822b(dm, path, RXIQK1);
+			if (KFAIL && (iqk_info->retry_count[0][path][RXIQK1] < 2))
+				iqk_info->retry_count[0][path][RXIQK1]++;
+			else if (KFAIL) {
+				iqk_info->rxiqk_fail_code[0][path] = 1;
+				iqk_info->rxiqk_step = 5;
+				gonext = true;
+			} else {
+				iqk_info->rxiqk_step++;
+				gonext = true;
+			}
+			if (gonext)
+				break;
+		}
+		halrf_iqk_xym_read(dm, path, 0x4);
+		break;
+	case 4:		/*RXK2*/
+		_iqk_rxk2_setting_8822b(dm, path, false);
+		gonext = false;
+		while (1) {
+			KFAIL = _iqk_one_shot_8822b(dm, path,	RXIQK2);
+			if (KFAIL && (iqk_info->retry_count[0][path][RXIQK2] < 2))
+				iqk_info->retry_count[0][path][RXIQK2]++;
+			else if (KFAIL) {
+				iqk_info->rxiqk_fail_code[0][path] = 2;
+				iqk_info->rxiqk_step = 5;
+				gonext = true;
+			} else {
+				iqk_info->rxiqk_step++;
+				gonext = true;
+			}
+			if (gonext)
+				break;
+		}
+		halrf_iqk_xym_read(dm, path, 0x0);
+		break;
+	}
+	return KFAIL;
+#endif
+}
+
+
+void
+_iqk_iqk_by_path_8822b(
+	void		*dm_void,
+	boolean		segment_iqk
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	boolean		KFAIL = true;
+	u8		i, kcount_limit;
+
+	/*	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]iqk_step = 0x%x\n", dm->rf_calibrate_info.iqk_step); */
+
+	if (*dm->band_width == 2)
+		kcount_limit = kcount_limit_80m;
+	else
+		kcount_limit = kcount_limit_others;
+
+	while (1) {
+#if 1
+	switch (dm->rf_calibrate_info.iqk_step) {
+	case 1:		/*S0 LOK*/
+#if 1
+		_iqk_lok_setting_8822b(dm, RF_PATH_A);
+		_lok_one_shot_8822b(dm, RF_PATH_A);
+#endif
+		dm->rf_calibrate_info.iqk_step++;
+		break;
+	case 2:		/*S1 LOK*/
+#if 1
+		_iqk_lok_setting_8822b(dm, RF_PATH_B);
+		_lok_one_shot_8822b(dm, RF_PATH_B);
+#endif
+		dm->rf_calibrate_info.iqk_step++;
+		break;
+	case 3:		/*S0 TXIQK*/
+#if 1
+		_iqk_txk_setting_8822b(dm, RF_PATH_A);
+		KFAIL = _iqk_one_shot_8822b(dm, RF_PATH_A, TXIQK);
+			iqk_info->kcount++;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]S0TXK KFail = 0x%x\n", KFAIL);
+
+		if (KFAIL && (iqk_info->retry_count[0][RF_PATH_A][TXIQK] < 3))
+			iqk_info->retry_count[0][RF_PATH_A][TXIQK]++;
+		else
+#endif
+			dm->rf_calibrate_info.iqk_step++;
+		halrf_iqk_xym_read(dm, RF_PATH_A, 0x1);
+		break;
+	case 4:		/*S1 TXIQK*/
+#if 1
+		_iqk_txk_setting_8822b(dm, RF_PATH_B);
+		KFAIL = _iqk_one_shot_8822b(dm, RF_PATH_B,	TXIQK);
+			iqk_info->kcount++;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]S1TXK KFail = 0x%x\n", KFAIL);
+		if (KFAIL && iqk_info->retry_count[0][RF_PATH_B][TXIQK] < 3)
+			iqk_info->retry_count[0][RF_PATH_B][TXIQK]++;
+		else
+#endif
+			dm->rf_calibrate_info.iqk_step++;
+		halrf_iqk_xym_read(dm, RF_PATH_B, 0x1);
+		break;
+	case 5:		/*S0 RXIQK*/
+			while (1) {
+		KFAIL = _iqk_rx_iqk_by_path_8822b(dm, RF_PATH_A);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]S0RXK KFail = 0x%x\n", KFAIL);
+		if (iqk_info->rxiqk_step == 5) {
+			dm->rf_calibrate_info.iqk_step++;
+			iqk_info->rxiqk_step = 1;
+			if (KFAIL)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]S0RXK fail code: %d!!!\n", iqk_info->rxiqk_fail_code[0][RF_PATH_A]);
+					break;
+				}
+		}
+			iqk_info->kcount++;
+		break;
+	case 6:		/*S1 RXIQK*/
+			while (1) {
+		KFAIL = _iqk_rx_iqk_by_path_8822b(dm, RF_PATH_B);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]S1RXK KFail = 0x%x\n", KFAIL);
+		if (iqk_info->rxiqk_step == 5) {
+			dm->rf_calibrate_info.iqk_step++;
+			iqk_info->rxiqk_step = 1;
+			if (KFAIL)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]S1RXK fail code: %d!!!\n", iqk_info->rxiqk_fail_code[0][RF_PATH_B]);
+					break;
+				}
+		}
+			iqk_info->kcount++;
+		break;
+	}
+
+	if (dm->rf_calibrate_info.iqk_step == 7) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]==========LOK summary ==========\n");
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]PathA_LOK_notready = %d, PathB_LOK1_notready = %d\n",
+			iqk_info->lok_fail[RF_PATH_A], iqk_info->lok_fail[RF_PATH_B]);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]==========IQK summary ==========\n");
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]PathA_TXIQK_fail = %d, PathB_TXIQK_fail = %d\n",
+			iqk_info->iqk_fail_report[0][RF_PATH_A][TXIQK], iqk_info->iqk_fail_report[0][RF_PATH_B][TXIQK]);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]PathA_RXIQK_fail = %d, PathB_RXIQK_fail = %d\n",
+			iqk_info->iqk_fail_report[0][RF_PATH_A][RXIQK], iqk_info->iqk_fail_report[0][RF_PATH_B][RXIQK]);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]PathA_TXIQK_retry = %d, PathB_TXIQK_retry = %d\n",
+			iqk_info->retry_count[0][RF_PATH_A][TXIQK], iqk_info->retry_count[0][RF_PATH_B][TXIQK]);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]PathA_RXK1_retry = %d, PathA_RXK2_retry = %d, PathB_RXK1_retry = %d, PathB_RXK2_retry = %d\n",
+			iqk_info->retry_count[0][RF_PATH_A][RXIQK1], iqk_info->retry_count[0][RF_PATH_A][RXIQK2],
+			iqk_info->retry_count[0][RF_PATH_B][RXIQK1], iqk_info->retry_count[0][RF_PATH_B][RXIQK2]);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]PathA_GS1_retry = %d, PathA_GS2_retry = %d, PathB_GS1_retry = %d, PathB_GS2_retry = %d\n",
+			iqk_info->gs_retry_count[0][RF_PATH_A][0], iqk_info->gs_retry_count[0][RF_PATH_A][1],
+			iqk_info->gs_retry_count[0][RF_PATH_B][0], iqk_info->gs_retry_count[0][RF_PATH_B][1]);
+		for (i = 0; i < 2; i++) {
+			odm_write_4byte(dm, 0x1b00, 0xf8000008 | i << 1);
+			odm_write_4byte(dm, 0x1b2c, 0x7);
+			odm_write_4byte(dm, 0x1bcc, 0x0);
+			odm_write_4byte(dm, 0x1b38, 0x20000000);
+		}
+			break;
+	}
+
+		if (segment_iqk && (iqk_info->kcount == kcount_limit))
+			break;
+#endif
+}
+}
+
+void
+_iqk_start_iqk_8822b(
+	struct dm_struct		*dm,
+	boolean			segment_iqk
+)
+{
+	u32 tmp;
+
+	/*GNT_WL = 1*/
+	tmp = odm_get_rf_reg(dm, RF_PATH_A, 0x1, RFREGOFFSETMASK);
+	tmp = tmp | BIT(5) | BIT(0);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x1, RFREGOFFSETMASK, tmp);
+
+	tmp = odm_get_rf_reg(dm, RF_PATH_B, 0x1, RFREGOFFSETMASK);
+	tmp = tmp | BIT(5) | BIT(0);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x1, RFREGOFFSETMASK, tmp);
+
+	_iqk_iqk_by_path_8822b(dm, segment_iqk);
+
+
+}
+
+void
+_iq_calibrate_8822b_init(
+	struct	dm_struct	*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8	i, j, k, m;
+	static boolean firstrun = true;
+
+	if (firstrun) {
+		firstrun = false;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]=====>PHY_IQCalibrate_8822B_Init\n");
+
+		for (i = 0; i < SS_8822B; i++) {
+			for (j = 0; j < 2; j++) {
+				iqk_info->lok_fail[i] = true;
+				iqk_info->iqk_fail[j][i] = true;
+				iqk_info->iqc_matrix[j][i] = 0x20000000;
+			}
+		}
+
+		for (i = 0; i < 2; i++) {
+			iqk_info->iqk_channel[i] = 0x0;
+
+			for (j = 0; j < SS_8822B; j++) {
+				iqk_info->lok_idac[i][j] = 0x0;
+				iqk_info->rxiqk_agc[i][j] = 0x0;
+				iqk_info->bypass_iqk[i][j] = 0x0;
+
+				for (k = 0; k < 2; k++) {
+					iqk_info->iqk_fail_report[i][j][k] = true;
+					for (m = 0; m < 8; m++) {
+						iqk_info->iqk_cfir_real[i][j][k][m] = 0x0;
+						iqk_info->iqk_cfir_imag[i][j][k][m] = 0x0;
+					}
+				}
+
+				for (k = 0; k < 3; k++)
+					iqk_info->retry_count[i][j][k] = 0x0;
+
+			}
+		}
+	}
+	/*parameters init.*/
+	/*cu_distance (IQK result variation)=111*/
+	odm_write_4byte(dm, 0x1b10, 0x88011c00);
+}
+
+
+
+boolean
+_iqk_rximr_rxk1_test_8822b(
+	struct dm_struct			*dm,
+	u8		path,
+	u32      tone_index
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	boolean		fail = true;
+	u32	IQK_CMD ;
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+	odm_write_4byte(dm, 0x1b20, (odm_read_4byte(dm, 0x1b20) & 0x000fffff) | ((tone_index & 0xfff)<<20));
+	odm_write_4byte(dm, 0x1b24, (odm_read_4byte(dm, 0x1b24) & 0x000fffff) | ((tone_index & 0xfff)<<20));
+
+	IQK_CMD = 0xf8000208 | (1 << (path + 4));
+	odm_write_4byte(dm, 0x1b00, IQK_CMD);
+	odm_write_4byte(dm, 0x1b00, IQK_CMD + 0x1);
+	
+	ODM_delay_ms(GS_delay_8822B);
+	fail = _iqk_check_cal_8822b(dm, path, 0x1);
+	return fail;
+}
+
+u32
+_iqk_tximr_selfcheck_8822b(
+	void *dm_void,
+	u8 tone_index,
+	u8 path
+)
+{
+	u32 tx_ini_power_H[2], tx_ini_power_L[2];
+	u32 tmp1, tmp2, tmp3, tmp4, tmp5;
+	u32 IQK_CMD;
+	u32 tximr = 0x0;
+	u8  i;
+
+	struct dm_struct	 *dm = (struct dm_struct *)dm_void;
+/*backup*/
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+	odm_write_4byte(dm, 0x1bc8, 0x80000000);
+	odm_write_4byte(dm, 0x8f8, 0x41400080);
+	tmp1 = odm_read_4byte(dm, 0x1b0c);
+	tmp2 = odm_read_4byte(dm, 0x1b14);
+	tmp3 = odm_read_4byte(dm, 0x1b1c);
+	tmp4 = odm_read_4byte(dm, 0x1b20);
+	tmp5 = odm_read_4byte(dm, 0x1b24);
+/*setup*/
+	odm_write_4byte(dm, 0x1b0c, 0x00003000);
+	odm_write_4byte(dm, 0x1b1c, 0xA2193C32);
+	odm_write_1byte(dm, 0x1b15, 0x00);
+	odm_write_4byte(dm, 0x1b20, (u32)(tone_index << 20 | 0x00040008));
+	odm_write_4byte(dm, 0x1b24, (u32)(tone_index << 20 | 0x00060008));
+	odm_write_4byte(dm, 0x1b2c, 0x07);
+	odm_write_4byte(dm, 0x1b38, 0x20000000);
+	odm_write_4byte(dm, 0x1b3c, 0x20000000);
+/* ======derive pwr1========*/
+	for (i = 0; i < 2; i++) {
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		if (i == 0)
+			odm_write_4byte(dm, 0x1bcc, 0x0f);
+		else
+			odm_write_4byte(dm, 0x1bcc, 0x09);
+/* One Shot*/
+	IQK_CMD = 0x00000800;
+	odm_write_4byte(dm, 0x1b34, IQK_CMD+1);
+	odm_write_4byte(dm, 0x1b34, IQK_CMD);
+	ODM_delay_ms(1);
+	odm_write_4byte(dm, 0x1bd4, 0x00040001);
+	tx_ini_power_H[i] = odm_read_4byte(dm, 0x1bfc);
+	odm_write_4byte(dm, 0x1bd4, 0x000C0001);
+	tx_ini_power_L[i] = odm_read_4byte(dm, 0x1bfc);
+	}
+/*restore*/
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+	odm_write_4byte(dm, 0x1b0c, tmp1);
+	odm_write_4byte(dm, 0x1b14, tmp2);
+	odm_write_4byte(dm, 0x1b1c, tmp3);
+	odm_write_4byte(dm, 0x1b20, tmp4);
+	odm_write_4byte(dm, 0x1b24, tmp5);
+
+	if (tx_ini_power_H[1] == tx_ini_power_H[0])
+		tximr = (3*(halrf_psd_log2base(tx_ini_power_L[0] << 2) - halrf_psd_log2base(tx_ini_power_L[1])))/100;
+	else
+		tximr = 0;
+	return tximr;
+}
+
+void
+_iqk_start_tximr_test_8822b(
+	struct	dm_struct	*dm,
+	u8 imr_limit
+	)
+{
+	boolean KFAIL;
+	u8 path, i, tone_index;
+	u32     imr_result;
+
+	for (path = 0; path < 2; path++) {
+		_iqk_txk_setting_8822b(dm, path);
+		KFAIL = _iqk_one_shot_8822b(dm, path, TXIQK);
+		for (i = 0x0; i < imr_limit; i++) {
+			tone_index = (u8)(0x08|i<<4);
+			imr_result = _iqk_tximr_selfcheck_8822b(dm, tone_index, path);
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]path=%x, toneindex = %x, TXIMR = %d\n", path, tone_index, imr_result);
+		}
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "\n");
+	}
+}
+
+u32
+_iqk_rximr_selfcheck_8822b(
+	void *dm_void,
+	u32 tone_index,
+	u8 path,
+	u32 tmp1b38
+)
+{
+	u32 rx_ini_power_H[2], rx_ini_power_L[2];/*[0]: psd tone; [1]: image tone*/
+	u32 tmp1, tmp2, tmp3, tmp4, tmp5;
+	u32 IQK_CMD, tmp1bcc;
+	u8 i, num_k1, rximr_step, count = 0x0;
+	u32 rximr = 0x0;
+	boolean KFAIL = true;
+
+	struct dm_struct	 *dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+
+	/*backup*/
+	odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+	tmp1 = odm_read_4byte(dm, 0x1b0c);
+	tmp2 = odm_read_4byte(dm, 0x1b14);
+	tmp3 = odm_read_4byte(dm, 0x1b1c);
+	tmp4 = odm_read_4byte(dm, 0x1b20);
+	tmp5 = odm_read_4byte(dm, 0x1b24);
+
+	odm_write_4byte(dm, 0x1b0c, 0x00001000);
+	odm_write_1byte(dm, 0x1b15, 0x00);
+	odm_write_4byte(dm, 0x1b1c, 0x82193d31);
+	odm_write_4byte(dm, 0x1b20, (u32)(tone_index << 20 | 0x00040008));
+	odm_write_4byte(dm, 0x1b24, (u32)(tone_index << 20 | 0x00060048));
+	odm_write_4byte(dm, 0x1b2c, 0x07);
+	odm_write_4byte(dm, 0x1b38, tmp1b38);
+	odm_write_4byte(dm, 0x1b3c, 0x20000000);
+
+	for (i = 0; i < 2; i++) {
+		if (i == 0)
+			odm_write_4byte(dm, 0x1b1c, 0x82193d31);
+		else
+			odm_write_4byte(dm, 0x1b1c, 0xa2193d31);
+		IQK_CMD = 0x00000800;
+		odm_write_4byte(dm, 0x1b34, IQK_CMD + 1);
+		odm_write_4byte(dm, 0x1b34, IQK_CMD);
+		ODM_delay_ms(2);
+		odm_write_1byte(dm, 0x1bd6, 0xb);
+		while (count < 100) {
+			count++;
+			if(odm_get_bb_reg(dm, 0x1bfc, BIT(1)) == 1)
+				break;
+			else
+				ODM_delay_ms(1);
+		}
+		if (1) {
+			odm_write_1byte(dm, 0x1bd6, 0x5);
+			rx_ini_power_H[i] = odm_read_4byte(dm, 0x1bfc);
+			odm_write_1byte(dm, 0x1bd6, 0xe);
+			rx_ini_power_L[i] = odm_read_4byte(dm, 0x1bfc);
+		} else {
+			rx_ini_power_H[i] = 0x0;
+			rx_ini_power_L[i] = 0x0;
+		}
+
+	}
+		/*restore*/
+	odm_write_4byte(dm, 0x1b0c, tmp1);
+	odm_write_4byte(dm, 0x1b14, tmp2);
+	odm_write_4byte(dm, 0x1b1c, tmp3);
+	odm_write_4byte(dm, 0x1b20, tmp4);
+	odm_write_4byte(dm, 0x1b24, tmp5);
+	for (i = 0 ; i < 2; i++)
+		rx_ini_power_H[i] = (rx_ini_power_H[i] & 0xf8000000)>>27;
+
+	if (rx_ini_power_H[0] != rx_ini_power_H[1]) {
+		switch (rx_ini_power_H[0]) {
+		case 1:
+			rx_ini_power_L[0] = (u32)((rx_ini_power_L[0]>>1) | 0x80000000);
+			rx_ini_power_L[1] = (u32)rx_ini_power_L[1]>>1;
+			break;
+		case 2:
+			rx_ini_power_L[0] = (u32)((rx_ini_power_L[0]>>2) | 0x80000000);
+			rx_ini_power_L[1] = (u32)rx_ini_power_L[1]>>2;
+			break;
+		case 3:
+			rx_ini_power_L[0] = (u32)((rx_ini_power_L[0]>>2) | 0xc0000000);
+			rx_ini_power_L[1] = (u32)rx_ini_power_L[1]>>2;
+			break;
+		case 4:
+			rx_ini_power_L[0] = (u32)((rx_ini_power_L[0]>>3) | 0x80000000);
+			rx_ini_power_L[1] = (u32)rx_ini_power_L[1]>>3;
+			break;
+		case 5:
+			rx_ini_power_L[0] = (u32)((rx_ini_power_L[0]>>3) | 0xa0000000);
+			rx_ini_power_L[1] = (u32)rx_ini_power_L[1]>>3;
+			break;
+		case 6:
+			rx_ini_power_L[0] = (u32)((rx_ini_power_L[0]>>3) | 0xc0000000);
+			rx_ini_power_L[1] = (u32)rx_ini_power_L[1]>>3;
+			break;
+		case 7:
+			rx_ini_power_L[0] = (u32)((rx_ini_power_L[0]>>3) | 0xe0000000);
+			rx_ini_power_L[1] = (u32)rx_ini_power_L[1]>>3;
+			break;
+		default:
+			break;
+		}
+	}
+	rximr = (u32)(3*((halrf_psd_log2base(rx_ini_power_L[0]/100) - halrf_psd_log2base(rx_ini_power_L[1]/100)))/100);
+	return rximr;
+}
+
+
+void
+_iqk_rximr_test_8822b(
+	struct	dm_struct	*dm,
+	u8 path,
+	u8 imr_limit
+	)
+{
+	struct	dm_iqk_info	*iqk_info = &dm->IQK_info;
+	boolean	kfail;
+	u8	i, step, count, side;
+	u32     imr_result = 0, tone_index;
+	u32     temp = 0, temp1b38[2][15];
+	char *freq[15]= {"1.25MHz", "3.75MHz", "6.25MHz", "8.75MHz", "11.25MHz",
+					"13.75MHz", "16.25MHz", "18.75MHz", "21.25MHz", "23.75MHz",
+					"26.25MHz", "28.75MHz", "31.25MHz", "33.75MHz", "36.25MHz"};
+
+	for (step = 1; step < 5; step++) {
+		count = 0;
+		switch (step) {
+			case 1:		/*gain search_RXK1*/
+				_iqk_rxk1_setting_8822b(dm, path);
+				while (count < 3) {
+					kfail = _iqk_rx_iqk_gain_search_fail_8822b(dm, path, RXIQK1);
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]path = %x, kfail = %x\n", path, kfail);
+					if (kfail) {
+						count++;
+						if (count == 3)
+							step = 5;
+					} else {
+						break;
+					}
+				}
+				break;
+			case 2:		/*gain search_RXK2*/
+				_iqk_rxk2_setting_8822b(dm, path, true);
+				iqk_info->isbnd = false;
+				while (count < 8) {
+					kfail = _iqk_rx_iqk_gain_search_fail_8822b(dm, path, RXIQK2);
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]path = %x, kfail = %x\n", path, kfail);
+					if (kfail) {
+						count++;
+						if (count == 8)
+							step = 5;
+					} else {
+						break;
+					}
+				}
+				break;
+			case 3: /*get RXK1 IQC*/
+				odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+				temp = odm_read_4byte(dm, 0x1b1c);
+				for (side =0; side < 2; side++) {
+					for (i = 0; i < imr_limit; i++) {
+						if (side ==0)
+							tone_index = 0xff8 -(i<<4);
+						else							
+							tone_index = 0x08 | (i<<4);
+						while (count < 3) {
+							_iqk_rxk1_setting_8822b(dm, path);
+							kfail = _iqk_rximr_rxk1_test_8822b(dm, path, tone_index);
+							PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]path = %x, kfail = %x\n", path, kfail);
+							if (kfail) {
+								count++;
+								if (count == 3) {
+									step = 5;
+									temp1b38[side][i] = 0x20000000;
+									PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]path = %x, toneindex = %x rxk1 fail\n", path, tone_index);
+								}
+							} else {
+								odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);						
+								odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
+								odm_write_4byte(dm, 0x1b14, 0xe5);
+								odm_write_4byte(dm, 0x1b14, 0x0);
+								temp1b38[side][i] = odm_read_4byte(dm, 0x1b38);
+								PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]path = 0x%x, tone_idx = 0x%x, tmp1b38 = 0x%x\n", path, tone_index, temp1b38[side][i]);
+								break;
+							}				
+						}
+					}
+				}
+				break;
+			case 4: /*get RX IMR*/
+				for (side =0; side < 2; side++) {
+					for (i = 0x0; i < imr_limit; i++) {
+						if (side ==0)
+							tone_index = 0xff8 -(i<<4);
+						else							
+							tone_index = 0x08 | (i<<4);
+						_iqk_rxk2_setting_8822b(dm, path, false);
+						imr_result = _iqk_rximr_selfcheck_8822b(dm, tone_index, path, temp1b38[side][i]);
+						PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]tone_idx = 0x%5x, freq = %s%10s, RXIMR = %5d dB\n", tone_index, (side ==0)?"-":" ", freq[i], imr_result);
+					}
+					odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+					odm_write_4byte(dm, 0x1b1c, temp);
+					odm_write_4byte(dm, 0x1b38, 0x20000000);
+				}
+				break;
+		}
+	}
+}
+
+
+void
+_iqk_start_rximr_test_8822b(
+	struct	dm_struct	*dm,
+	u8 imr_limit
+	)
+{
+	u8 path;
+
+	for (path = 0; path < 2; path++)
+		_iqk_rximr_test_8822b(dm, path, imr_limit);
+}
+
+void
+_iqk_start_imr_test_8822b(
+	void		*dm_void
+	)
+{
+	u8		imr_limit;
+
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+
+	if (*dm->band_width == 2)
+		imr_limit = 0xf;
+	else if (*dm->band_width == 1)
+		imr_limit = 0x8;
+	else
+		imr_limit = 0x4;
+//	_iqk_start_tximr_test_8822b(dm, imr_limit);
+	_iqk_start_rximr_test_8822b(dm, imr_limit);
+}
+
+
+void
+_phy_iq_calibrate_8822b(
+	struct dm_struct		*dm,
+	boolean			reset,
+	boolean			segment_iqk
+)
+{
+	u32	MAC_backup[MAC_REG_NUM_8822B], BB_backup[BB_REG_NUM_8822B], RF_backup[RF_REG_NUM_8822B][SS_8822B];
+	u32	backup_mac_reg[MAC_REG_NUM_8822B] = {0x520, 0x550};
+	u32	backup_bb_reg[BB_REG_NUM_8822B] = {0x808, 0x90c, 0xc00, 0xcb0, 0xcb4, 0xcbc, 0xe00, 0xeb0, 0xeb4, 0xebc, 0x1990, 0x9a4, 0xa04, 0xb00, 0x838};
+	u32	backup_rf_reg[RF_REG_NUM_8822B] = {0xdf, 0x8f, 0x65, 0x0, 0x1};
+	boolean is_mp = false;
+
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	if (*dm->mp_mode)
+		is_mp = true;
+
+	if (!is_mp)
+		if (_iqk_reload_iqk_8822b(dm, reset))
+			return;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]==========IQK strat!!!!!==========\n");
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]band_type = %s, band_width = %d, ExtPA2G = %d, ext_pa_5g = %d\n", (*dm->band_type == ODM_BAND_5G) ? "5G" : "2G", *dm->band_width, dm->ext_pa, dm->ext_pa_5g);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]Interface = %d, cut_version = %x\n", dm->support_interface, dm->cut_version);
+
+	iqk_info->iqk_times++;
+	iqk_info->kcount = 0;
+	dm->rf_calibrate_info.iqk_step = 1;
+	iqk_info->rxiqk_step = 1;
+
+	_iqk_backup_iqk_8822b(dm, 0x0, 0x0);
+	_iqk_backup_mac_bb_8822b(dm, MAC_backup, BB_backup, backup_mac_reg, backup_bb_reg);
+	_iqk_backup_rf_8822b(dm, RF_backup, backup_rf_reg);
+#if 0
+	_iqk_configure_macbb_8822b(dm);
+	_iqk_afe_setting_8822b(dm, true);
+	_iqk_rfe_setting_8822b(dm, false);
+	_iqk_agc_bnd_int_8822b(dm);
+	_iqk_rf_setting_8822b(dm);
+#endif
+
+	while (1) {
+		_iqk_configure_macbb_8822b(dm);
+		_iqk_afe_setting_8822b(dm, true);
+		_iqk_rfe_setting_8822b(dm, false);
+		_iqk_agc_bnd_int_8822b(dm);
+		_iqk_rf_setting_8822b(dm);
+		_iqk_start_iqk_8822b(dm, segment_iqk);
+		_iqk_afe_setting_8822b(dm, false);
+		_iqk_restore_mac_bb_8822b(dm, MAC_backup, BB_backup, backup_mac_reg, backup_bb_reg);
+		_iqk_restore_rf_8822b(dm, backup_rf_reg, RF_backup);
+		if (dm->rf_calibrate_info.iqk_step == 7)
+			break;
+		iqk_info->kcount = 0;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]delay 50ms!!!\n");
+		ODM_delay_ms(50);
+	};
+	if (segment_iqk)
+		_iqk_reload_iqk_setting_8822b(dm, 0x0, 0x1);
+#if 0
+	_iqk_afe_setting_8822b(dm, false);
+	_iqk_restore_mac_bb_8822b(dm, MAC_backup, BB_backup, backup_mac_reg, backup_bb_reg);
+	_iqk_restore_rf_8822b(dm, backup_rf_reg, RF_backup);
+#endif
+	_iqk_fill_iqk_report_8822b(dm, 0);
+	_iqk_rf0xb0_workaround(dm);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]==========IQK end!!!!!==========\n");
+}
+
+
+void
+_phy_iq_calibrate_by_fw_8822b(
+	void		*dm_void,
+	u8		clear,
+	u8		segment_iqk
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;	
+	enum hal_status		status = HAL_STATUS_FAILURE;
+	
+	if (*dm->mp_mode)
+		clear = 0x1;
+//	else if (dm->is_linked)
+//		segment_iqk = 0x1;
+
+	iqk_info->iqk_times++;
+	status = odm_iq_calibrate_by_fw(dm, clear, segment_iqk);
+
+	if (status == HAL_STATUS_SUCCESS)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]FWIQK OK!!!\n");
+	else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]FWIQK fail!!!\n");
+}
+
+/*IQK_version:0x2f, NCTL:0x8*/
+/*1.disable CCK block and OFDM CCA block while IQKing*/
+void
+phy_iq_calibrate_8822b(
+	void		*dm_void,
+	boolean		clear,
+	boolean		segment_iqk
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	if (*dm->mp_mode)
+		halrf_iqk_hwtx_check(dm, true);
+	/*FW IQK*/
+	if (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) {
+		_phy_iq_calibrate_by_fw_8822b(dm, clear, (u8)(segment_iqk));
+		phydm_get_read_counter(dm);
+		halrf_iqk_check_if_reload(dm);
+	} else {
+		_iq_calibrate_8822b_init(dm);
+		_phy_iq_calibrate_8822b(dm, clear, segment_iqk);
+	}
+	_iqk_fail_count_8822b(dm);
+	if (*dm->mp_mode)
+		halrf_iqk_hwtx_check(dm, false);
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	_iqk_iqk_fail_report_8822b(dm);
+#endif
+	halrf_iqk_dbg(dm);
+}
+
+void
+_phy_imr_measure(
+	struct dm_struct		*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u32	MAC_backup[MAC_REG_NUM_8822B], BB_backup[BB_REG_NUM_8822B], RF_backup[RF_REG_NUM_8822B][SS_8822B];
+	u32	backup_mac_reg[MAC_REG_NUM_8822B] = {0x520, 0x550};
+	u32	backup_bb_reg[BB_REG_NUM_8822B] = {0x808, 0x90c, 0xc00, 0xcb0, 0xcb4, 0xcbc, 0xe00, 0xeb0, 0xeb4, 0xebc, 0x1990, 0x9a4, 0xa04, 0xb00};
+	u32	backup_rf_reg[RF_REG_NUM_8822B] = {0xdf, 0x8f, 0x65, 0x0, 0x1};
+
+	_iqk_backup_iqk_8822b(dm, 0x0, 0x0);
+	_iqk_backup_mac_bb_8822b(dm, MAC_backup, BB_backup, backup_mac_reg, backup_bb_reg);
+	_iqk_backup_rf_8822b(dm, RF_backup, backup_rf_reg);
+	_iqk_configure_macbb_8822b(dm);
+	_iqk_afe_setting_8822b(dm, true);
+	_iqk_rfe_setting_8822b(dm, false);
+	_iqk_agc_bnd_int_8822b(dm);
+	_iqk_rf_setting_8822b(dm);
+
+	_iqk_start_imr_test_8822b(dm);
+
+	_iqk_afe_setting_8822b(dm, false);
+	_iqk_restore_mac_bb_8822b(dm, MAC_backup, BB_backup, backup_mac_reg, backup_bb_reg);
+	_iqk_restore_rf_8822b(dm, backup_rf_reg, RF_backup);
+}
+
+void
+do_imr_test_8822b(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]  ************IMR Test *****************\n");
+	_phy_imr_measure(dm);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[IQK]  **********End IMR Test *******************\n");
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_iqk_8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_iqk_8822b.h
new file mode 100644
index 000000000000..3ec83e33acf5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/halrf/rtl8822b/halrf_iqk_8822b.h
@@ -0,0 +1,78 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_IQK_8822B_H__
+#define    __PHYDM_IQK_8822B_H__
+
+#if (RTL8822B_SUPPORT == 1)
+/*--------------------------Define Parameters-------------------------------*/
+#define	MAC_REG_NUM_8822B 2
+#define BB_REG_NUM_8822B 15
+#define	RF_REG_NUM_8822B 5
+#define	LOK_delay_8822B 2
+#define	GS_delay_8822B 2
+#define	WBIQK_delay_8822B 2
+
+#define TXIQK 0
+#define RXIQK 1
+#define SS_8822B 2
+/*---------------------------End Define Parameters-------------------------------*/
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+void
+do_iqk_8822b(
+	void	*dm_void,
+	u8		delta_thermal_index,
+	u8		thermal_value,
+	u8		threshold
+);
+#else
+void
+do_iqk_8822b(
+	void		*dm_void,
+	u8		delta_thermal_index,
+	u8		thermal_value,
+	u8		threshold
+);
+#endif
+
+void
+phy_iq_calibrate_8822b(
+	void		*dm_void,
+	boolean		clear,
+	boolean		segment_iqk
+);
+
+void
+do_imr_test_8822b(
+	void		*dm_void
+);
+
+#else	/* (RTL8822B_SUPPORT == 0)*/
+
+#define phy_iq_calibrate_8822b(_pdm_void, clear, segment_iqk)
+
+#endif	/* RTL8822B_SUPPORT */
+
+#endif	/* #ifndef __PHYDM_IQK_8822B_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/mp_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/mp_precomp.h
new file mode 100644
index 000000000000..897adc13ffca
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/mp_precomp.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.c
new file mode 100644
index 000000000000..77c044ae99e3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.c
@@ -0,0 +1,3092 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+const u16 phy_rate_table[] = {	/*20M*/
+	1, 2, 5, 11,
+	6, 9, 12, 18, 24, 36, 48, 54,
+	6, 13, 19, 26, 39, 52, 58, 65,		/*MCS0~7*/
+	13, 26, 39, 52, 78, 104, 117, 130		/*MCS8~15*/
+};
+
+void
+phydm_traffic_load_decision(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		bit_shift_num = 0;
+
+	/*---TP & Trafic-load calculation---*/
+
+	if (dm->last_tx_ok_cnt > *dm->num_tx_bytes_unicast)
+		dm->last_tx_ok_cnt = *dm->num_tx_bytes_unicast;
+
+	if (dm->last_rx_ok_cnt > *dm->num_rx_bytes_unicast)
+		dm->last_rx_ok_cnt = *dm->num_rx_bytes_unicast;
+
+	dm->cur_tx_ok_cnt = *dm->num_tx_bytes_unicast - dm->last_tx_ok_cnt;
+	dm->cur_rx_ok_cnt = *dm->num_rx_bytes_unicast - dm->last_rx_ok_cnt;
+	dm->last_tx_ok_cnt = *dm->num_tx_bytes_unicast;
+	dm->last_rx_ok_cnt = *dm->num_rx_bytes_unicast;
+
+	bit_shift_num = 17 + (PHYDM_WATCH_DOG_PERIOD - 1); /*AP:  <<3(8bit), >>20(10^6,M), >>0(1sec)*/
+													/*WIN&CE:  <<3(8bit), >>20(10^6,M), >>1(2sec)*/
+
+	dm->tx_tp = ((dm->tx_tp) >> 1) + (u32)(((dm->cur_tx_ok_cnt) >> bit_shift_num) >> 1);
+	dm->rx_tp = ((dm->rx_tp) >> 1) + (u32)(((dm->cur_rx_ok_cnt) >> bit_shift_num) >> 1);
+
+	dm->total_tp = dm->tx_tp + dm->rx_tp;
+
+	/*[Calculate TX/RX state]*/
+	if (dm->tx_tp > (dm->rx_tp << 1))
+		dm->txrx_state_all = TX_STATE;
+	else if (dm->rx_tp > (dm->tx_tp << 1))
+		dm->txrx_state_all = RX_STATE;
+	else
+		dm->txrx_state_all = BI_DIRECTION_STATE;
+
+	/*[Calculate consecutive idlel time]*/
+	if (dm->total_tp == 0)
+		dm->consecutive_idlel_time += PHYDM_WATCH_DOG_PERIOD;
+	else
+		dm->consecutive_idlel_time = 0;
+
+	/*[Traffic load decision]*/
+	dm->pre_traffic_load = dm->traffic_load;
+
+	if (dm->cur_tx_ok_cnt > 1875000 || dm->cur_rx_ok_cnt > 1875000) {		/* ( 1.875M * 8bit ) / 2sec= 7.5M bits /sec )*/
+
+		dm->traffic_load = TRAFFIC_HIGH;
+		/**/
+	} else if (dm->cur_tx_ok_cnt > 500000 || dm->cur_rx_ok_cnt > 500000) { /*( 0.5M * 8bit ) / 2sec =  2M bits /sec )*/
+
+		dm->traffic_load = TRAFFIC_MID;
+		/**/
+	} else if (dm->cur_tx_ok_cnt > 100000 || dm->cur_rx_ok_cnt > 100000)  { /*( 0.1M * 8bit ) / 2sec =  0.4M bits /sec )*/
+
+		dm->traffic_load = TRAFFIC_LOW;
+		/**/
+	} else {
+		dm->traffic_load = TRAFFIC_ULTRA_LOW;
+		/**/
+	}
+
+	/*
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "cur_tx_ok_cnt = %d, cur_rx_ok_cnt = %d, last_tx_ok_cnt = %d, last_rx_ok_cnt = %d\n",
+		dm->cur_tx_ok_cnt, dm->cur_rx_ok_cnt, dm->last_tx_ok_cnt, dm->last_rx_ok_cnt);
+
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "tx_tp = %d, rx_tp = %d\n",
+		dm->tx_tp, dm->rx_tp);
+	*/
+		
+}
+
+void
+phydm_init_cck_setting(
+	struct dm_struct		*dm
+)
+{
+#if (RTL8192E_SUPPORT == 1)
+	u32 value_824, value_82c;
+#endif
+
+	dm->is_cck_high_power = (boolean) odm_get_bb_reg(dm, ODM_REG(CCK_RPT_FORMAT, dm), ODM_BIT(CCK_RPT_FORMAT, dm));
+
+	phydm_config_cck_rx_antenna_init(dm);
+	phydm_config_cck_rx_path(dm, BB_PATH_A);
+
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+		/* 0x824[9] = 0x82C[9] = 0xA80[7]  those registers setting should be equal or CCK RSSI report may be incorrect */
+		value_824 = odm_get_bb_reg(dm, 0x824, BIT(9));
+		value_82c = odm_get_bb_reg(dm, 0x82c, BIT(9));
+
+		if (value_824 != value_82c)
+			odm_set_bb_reg(dm, 0x82c, BIT(9), value_824);
+		odm_set_bb_reg(dm, 0xa80, BIT(7), value_824);
+		dm->cck_agc_report_type = (boolean)value_824;
+
+		PHYDM_DBG(dm, ODM_COMP_INIT, "cck_agc_report_type = (( %d )), ext_lna_gain = (( %d ))\n", dm->cck_agc_report_type, dm->ext_lna_gain);
+	}
+#endif
+
+#if ((RTL8703B_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+		dm->cck_agc_report_type = odm_get_bb_reg(dm, 0x950, BIT(11)) ? 1 : 0; /*1: 4bit LNA, 0: 3bit LNA */
+
+		if (dm->cck_agc_report_type != 1) {
+			pr_debug("[Warning] 8703B/8723D/8710B CCK should be 4bit LNA, ie. 0x950[11] = 1\n");
+			/**/
+		}
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) {
+		dm->cck_new_agc = odm_get_bb_reg(dm, 0xa9c, BIT(17)) ? true : false;          /*1: new agc  0: old agc*/
+		if (dm->cck_new_agc == 0 && dm->default_rf_set_8821c == SWITCH_TO_BTG)
+			dm->cck_agc_report_type = 1;
+	}
+#endif
+
+#if ((RTL8723D_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8723D | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8710B))
+		dm->cck_new_agc = odm_get_bb_reg(dm, 0xa9c, BIT(17)) ? true : false;          /*1: new agc  0: old agc*/
+	else
+#endif
+	{
+		dm->cck_new_agc = false;
+		/**/
+	}
+
+	phydm_get_cck_rssi_table_from_reg(dm);
+
+}
+
+void
+phydm_init_hw_info_by_rfe(
+	struct dm_struct		*dm
+)
+{
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_init_hw_info_by_rfe_type_8822b(dm);
+#endif
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_init_hw_info_by_rfe_type_8821c(dm);
+#endif
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_init_hw_info_by_rfe_type_8197f(dm);
+#endif
+}
+
+void
+phydm_common_info_self_init(
+	struct dm_struct		*dm
+)
+{
+	phydm_init_cck_setting(dm);
+	dm->rf_path_rx_enable = (u8) odm_get_bb_reg(dm, ODM_REG(BB_RX_PATH, dm), ODM_BIT(BB_RX_PATH, dm));
+#if (DM_ODM_SUPPORT_TYPE != ODM_CE)
+	dm->is_net_closed = &dm->BOOLEAN_temp;
+
+	phydm_init_debug_setting(dm);
+#endif
+	phydm_init_trx_antenna_setting(dm);
+	phydm_init_soft_ml_setting(dm);
+
+	dm->phydm_sys_up_time = 0;
+
+	if (dm->support_ic_type & ODM_IC_1SS)
+		dm->num_rf_path = 1;
+	else if (dm->support_ic_type & ODM_IC_2SS)
+		dm->num_rf_path = 2;
+	else if (dm->support_ic_type & ODM_IC_3SS)
+		dm->num_rf_path = 3;
+	else if (dm->support_ic_type & ODM_IC_4SS)
+		dm->num_rf_path = 4;
+	else
+		dm->num_rf_path = 1;
+
+	dm->tx_rate = 0xFF;
+	dm->rssi_min_by_path = 0xFF;
+
+	dm->number_linked_client = 0;
+	dm->pre_number_linked_client = 0;
+	dm->number_active_client = 0;
+	dm->pre_number_active_client = 0;
+
+	dm->last_tx_ok_cnt = 0;
+	dm->last_rx_ok_cnt = 0;
+	dm->tx_tp = 0;
+	dm->rx_tp = 0;
+	dm->total_tp = 0;
+	dm->traffic_load = TRAFFIC_LOW;
+
+	dm->nbi_set_result = 0;
+	dm->is_init_hw_info_by_rfe = false;
+	dm->pre_dbg_priority = BB_DBGPORT_RELEASE;
+	dm->tp_active_th = 5;
+	dm->disable_phydm_watchdog = 0;
+
+	dm->u8_dummy = 0xf;
+	dm->u16_dummy = 0xffff;
+	dm->u32_dummy = 0xffffffff;
+	
+	/*odm_memory_set(dm, &(dm->pause_lv_table.lv_dig), 0, sizeof(struct phydm_pause_lv));*/
+	dm->pause_lv_table.lv_cckpd = PHYDM_PAUSE_RELEASE;
+	dm->pause_lv_table.lv_dig = PHYDM_PAUSE_RELEASE;
+
+}
+
+void
+phydm_cmn_sta_info_update(
+	void	*dm_void,
+	u8	macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA_MASK, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA_MASK, "MACID=%d\n", sta->mac_id);
+
+	/*[Calculate TX/RX state]*/
+	if (sta->tx_moving_average_tp > (sta->rx_moving_average_tp << 1))
+		ra->txrx_state= TX_STATE;
+	else if (sta->rx_moving_average_tp > (sta->tx_moving_average_tp << 1))
+		ra->txrx_state = RX_STATE;
+	else
+		ra->txrx_state = BI_DIRECTION_STATE;
+
+	 ra->is_noisy = dm->noisy_decision;
+
+}
+
+void
+phydm_common_info_self_update(
+	struct dm_struct		*dm
+)
+{
+	u8	sta_cnt = 0, num_active_client = 0;
+	u32	i, one_entry_macid = 0;
+	u32	ma_rx_tp = 0;
+	struct cmn_sta_info	*sta;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+	PADAPTER	adapter =  (PADAPTER)dm->adapter;
+
+	PMGNT_INFO	mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+
+	sta = dm->phydm_sta_info[0];
+	if (mgnt_info->mAssoc) {
+		sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
+		for (i = 0; i < 6; i++)
+			sta->mac_addr[i] = mgnt_info->Bssid[i];
+	} else if (GetFirstClientPort(adapter)) {
+		//void	*client_adapter = GetFirstClientPort(adapter);
+		struct _ADAPTER	*client_adapter = GetFirstClientPort(adapter);
+
+		sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
+		for (i = 0; i < 6; i++)
+			sta->mac_addr[i] = client_adapter->MgntInfo.Bssid[i];
+	} else {
+		sta->dm_ctrl = sta->dm_ctrl & (~STA_DM_CTRL_ACTIVE);
+		for (i = 0; i < 6; i++)
+			sta->mac_addr[i] = 0;
+	}
+
+	/* STA mode is linked to AP */
+	if (is_sta_active(sta) && !ACTING_AS_AP(adapter))
+		dm->bsta_state = true;
+	else
+		dm->bsta_state = false;
+#endif
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
+			sta_cnt++;
+			
+			if (sta_cnt == 1)
+				one_entry_macid = i;
+
+			phydm_cmn_sta_info_update(dm, (u8)i);
+			#if (BEAMFORMING_SUPPORT == 1)
+			//phydm_get_txbf_device_num(dm, (u8)i);
+			#endif
+
+			ma_rx_tp = sta->rx_moving_average_tp + sta->tx_moving_average_tp;
+			PHYDM_DBG(dm, DBG_COMMON_FLOW, "TP[%d]: ((%d )) bit/sec\n", i, ma_rx_tp);
+
+			if (ma_rx_tp > ACTIVE_TP_THRESHOLD)
+				num_active_client++;
+		}
+	}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	dm->is_linked = (sta_cnt != 0) ? true : false;
+#endif
+
+	if (sta_cnt == 1) {
+		dm->is_one_entry_only = true;
+		dm->one_entry_macid = one_entry_macid;
+		dm->one_entry_tp = ma_rx_tp;
+
+		dm->tp_active_occur = 0;
+
+		PHYDM_DBG(dm, DBG_COMMON_FLOW, "one_entry_tp=((%d)), pre_one_entry_tp=((%d))\n",
+			dm->one_entry_tp, dm->pre_one_entry_tp);
+
+		if ((dm->one_entry_tp > dm->pre_one_entry_tp) && (dm->pre_one_entry_tp <= 2)) {
+			if ((dm->one_entry_tp - dm->pre_one_entry_tp) > dm->tp_active_th)
+				dm->tp_active_occur = 1;
+		}
+		dm->pre_one_entry_tp = dm->one_entry_tp;
+	} else
+		dm->is_one_entry_only = false;
+
+	dm->pre_number_linked_client = dm->number_linked_client;
+	dm->pre_number_active_client = dm->number_active_client;
+
+	dm->number_linked_client = sta_cnt;
+	dm->number_active_client = num_active_client;
+
+	/*Traffic load information update*/
+	phydm_traffic_load_decision(dm);
+
+	dm->phydm_sys_up_time += PHYDM_WATCH_DOG_PERIOD;
+
+	dm->is_dfs_band = phydm_is_dfs_band(dm);
+	dm->phy_dbg_info.show_phy_sts_cnt = 0;
+
+}
+
+void
+phydm_common_info_self_reset(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	dm->phy_dbg_info.num_qry_beacon_pkt = 0;
+#endif
+}
+
+void *
+phydm_get_structure(
+	struct dm_struct		*dm,
+	u8			structure_type
+)
+
+{
+	void	*structure = NULL;
+#if RTL8195A_SUPPORT
+	switch (structure_type) {
+	case	PHYDM_FALSEALMCNT:
+		structure = &false_alm_cnt;
+		break;
+
+	case	PHYDM_CFOTRACK:
+		structure = &dm_cfo_track;
+		break;
+
+	case	PHYDM_ADAPTIVITY:
+		structure = &dm->adaptivity;
+		break;
+
+	default:
+		break;
+	}
+
+#else
+	switch (structure_type) {
+	case	PHYDM_FALSEALMCNT:
+		structure = &dm->false_alm_cnt;
+		break;
+
+	case	PHYDM_CFOTRACK:
+		structure = &dm->dm_cfo_track;
+		break;
+
+	case	PHYDM_ADAPTIVITY:
+		structure = &dm->adaptivity;
+		break;
+
+	case	PHYDM_DFS:
+		structure = &dm->dfs;
+		break;
+
+	default:
+		break;
+	}
+
+#endif
+	return	structure;
+}
+
+void
+phydm_hw_setting(
+	struct dm_struct		*dm
+)
+{
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821)
+		odm_hw_setting_8821a(dm);
+#endif
+
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phydm_hwsetting_8814a(dm);
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_hwsetting_8822b(dm);
+#endif
+
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8812)
+		phydm_hwsetting_8812a(dm);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_hwsetting_8197f(dm);
+#endif
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+u64
+phydm_supportability_init_win(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	/*---------------N Series--------------------*/
+	#if (RTL8188E_SUPPORT == 1)	
+	case	ODM_RTL8188E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8192E_SUPPORT == 1)
+	case	ODM_RTL8192E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8723B_SUPPORT == 1)
+	case	ODM_RTL8723B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR		|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8703B_SUPPORT == 1)
+	case	ODM_RTL8703B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8723D_SUPPORT == 1)
+	case	ODM_RTL8723D:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/* ODM_BB_PWR_TRAIN	| */
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8710B_SUPPORT == 1)
+	case	ODM_RTL8710B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8188F_SUPPORT == 1)
+	case	ODM_RTL8188F:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	/*---------------AC Series-------------------*/
+
+	#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+	case	ODM_RTL8812:
+	case	ODM_RTL8821:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_DYNAMIC_TXPWR	|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8814A_SUPPORT == 1) 
+	case ODM_RTL8814A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_DYNAMIC_TXPWR	|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_ADAPTIVE_SOML;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	return support_ability;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+u64
+phydm_supportability_init_ce(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	/*---------------N Series--------------------*/
+	#if (RTL8188E_SUPPORT == 1)	
+	case	ODM_RTL8188E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8192E_SUPPORT == 1)
+	case	ODM_RTL8192E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8723B_SUPPORT == 1)
+	case	ODM_RTL8723B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8703B_SUPPORT == 1)
+	case	ODM_RTL8703B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8723D_SUPPORT == 1)
+	case	ODM_RTL8723D:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/* ODM_BB_PWR_TRAIN	| */	
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8710B_SUPPORT == 1)
+	case	ODM_RTL8710B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8188F_SUPPORT == 1)
+	case	ODM_RTL8188F:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+		
+	/*---------------AC Series-------------------*/
+
+	#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+	case	ODM_RTL8812:
+	case	ODM_RTL8821:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8814A_SUPPORT == 1) 
+	case ODM_RTL8814A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	return support_ability;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+u64
+phydm_supportability_init_ap(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	/*---------------N Series--------------------*/
+	#if (RTL8188E_SUPPORT == 1)	
+	case	ODM_RTL8188E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8192E_SUPPORT == 1)
+	case	ODM_RTL8192E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8723B_SUPPORT == 1)
+	case	ODM_RTL8723B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+		
+	#if ((RTL8198F_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+	case	ODM_RTL8198F:
+	case	ODM_RTL8197F:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ADAPTIVE_SOML	|
+			ODM_BB_ENV_MONITOR		|
+			ODM_BB_LNA_SAT_CHK		|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+	
+	/*---------------AC Series-------------------*/
+
+	#if (RTL8881A_SUPPORT == 1)
+	case	ODM_RTL8881A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8814A_SUPPORT == 1) 
+	case ODM_RTL8814A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			/*ODM_BB_ADAPTIVE_SOML	|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR	;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+		break;
+	#endif
+
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	#if 0
+	/*[Config Antenna Diveristy]*/
+	if (*(dm->enable_antdiv))
+		support_ability |= ODM_BB_ANT_DIV;
+	
+	/*[Config Adaptivity]*/
+	if (*(dm->enable_adaptivity))
+		support_ability |= ODM_BB_ADAPTIVITY;
+	#endif
+
+	return support_ability;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+u64
+phydm_supportability_init_iot(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	#if (RTL8710B_SUPPORT == 1)
+	case	ODM_RTL8710B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8195A_SUPPORT == 1)
+	case	ODM_RTL8195A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	return support_ability;
+}
+#endif
+
+void
+phydm_fwoffload_ability_init(
+	struct dm_struct		*dm,
+	enum phydm_offload_ability	offload_ability
+)
+{
+	switch (offload_ability) {
+	case	PHYDM_PHY_PARAM_OFFLOAD:
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+			dm->fw_offload_ability |= PHYDM_PHY_PARAM_OFFLOAD;
+		break;
+
+	case	PHYDM_RF_IQK_OFFLOAD:
+		dm->fw_offload_ability |= PHYDM_RF_IQK_OFFLOAD;
+		break;
+
+	default:
+		PHYDM_DBG(dm, ODM_COMP_INIT, "fwofflad, wrong init type!!\n");
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"fw_offload_ability = %x\n", dm->fw_offload_ability);
+
+}
+void
+phydm_fwoffload_ability_clear(
+	struct dm_struct		*dm,
+	enum phydm_offload_ability	offload_ability
+)
+{
+	switch (offload_ability) {
+	case	PHYDM_PHY_PARAM_OFFLOAD:
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+			dm->fw_offload_ability &= (~PHYDM_PHY_PARAM_OFFLOAD);
+		break;
+
+	case	PHYDM_RF_IQK_OFFLOAD:
+		dm->fw_offload_ability &= (~PHYDM_RF_IQK_OFFLOAD);
+		break;
+
+	default:
+		PHYDM_DBG(dm, ODM_COMP_INIT, "fwofflad, wrong init type!!\n");
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"fw_offload_ability = %x\n", dm->fw_offload_ability);
+
+}
+
+void
+phydm_supportability_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64	support_ability;
+	
+	if (*dm->mp_mode == true) {
+		support_ability = 0;
+
+		/**/
+	} else {
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+		support_ability = phydm_supportability_init_win(dm);
+		#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+		support_ability = phydm_supportability_init_ap(dm);
+		#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE))
+		support_ability = phydm_supportability_init_ce(dm);
+		#elif(DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+		support_ability = phydm_supportability_init_iot(dm);
+		#endif
+
+		/*[Config Antenna Diveristy]*/
+		if (IS_FUNC_EN(dm->enable_antdiv))
+			support_ability |= ODM_BB_ANT_DIV;
+
+		/*[Config Adaptive SOML]*/
+		if (IS_FUNC_EN(dm->en_adap_soml))
+			support_ability |= ODM_BB_ADAPTIVE_SOML;
+
+		/*[Config Adaptivity]*/
+		if (IS_FUNC_EN(dm->enable_adaptivity))
+			support_ability |= ODM_BB_ADAPTIVITY;
+	}
+	odm_cmn_info_init(dm, ODM_CMNINFO_ABILITY, support_ability);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "IC = ((0x%x)), Supportability Init = ((0x%llx))\n", dm->support_ic_type, dm->support_ability);
+}
+
+void
+phydm_rfe_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	PHYDM_DBG(dm, ODM_COMP_INIT, "RFE_Init\n");
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		phydm_rfe_8822b_init(dm);
+		/**/
+	}
+#endif
+}
+
+void
+phydm_dm_early_init(
+	struct dm_struct	*dm
+)
+{
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	halrf_init(dm);
+	#endif
+}
+
+void
+odm_dm_init(
+	struct dm_struct		*dm
+)
+{
+	halrf_init(dm);
+	phydm_supportability_init(dm);
+	phydm_rfe_init(dm);
+	phydm_common_info_self_init(dm);
+	phydm_rx_phy_status_init(dm);
+	phydm_auto_dbg_engine_init(dm);
+	phydm_dig_init(dm);
+	phydm_cck_pd_init(dm);
+	phydm_env_monitor_init(dm);
+	phydm_adaptivity_init(dm);
+	phydm_ra_info_init(dm);
+	phydm_rssi_monitor_init(dm);
+	phydm_cfo_tracking_init(dm);
+	phydm_rf_init(dm);
+	phydm_dc_cancellation(dm);
+#ifdef PHYDM_TXA_CALIBRATION
+	phydm_txcurrentcalibration(dm);
+	phydm_get_pa_bias_offset(dm);
+#endif
+	odm_antenna_diversity_init(dm);
+	phydm_adaptive_soml_init(dm);
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_init(dm);
+#endif
+	phydm_path_diversity_init(dm);
+	phydm_pow_train_init(dm);
+	phydm_dynamic_tx_power_init(dm);
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	adc_smp_init(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_beamforming_init(dm);
+#endif
+#if (RTL8188E_SUPPORT == 1)
+	odm_ra_info_init_all(dm);
+#endif
+
+	phydm_primary_cca_init(dm);
+
+	#ifdef CONFIG_PSD_TOOL
+	phydm_psd_init(dm);
+	#endif
+	
+	#ifdef CONFIG_SMART_ANTENNA
+	phydm_smt_ant_init(dm);
+	#endif
+
+}
+
+void
+odm_dm_reset(
+	struct dm_struct		*dm
+)
+{
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	odm_ant_div_reset(dm);
+	phydm_set_edcca_threshold_api(dm, dig_t->cur_ig_value);
+}
+
+void
+phydm_support_ability_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			pre_support_ability, one = 1;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	pre_support_ability = dm->support_ability;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%s\n",
+		       "================================");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[Supportability] PhyDM Selection\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))DIG\n",
+			       ((dm->support_ability & ODM_BB_DIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "01. (( %s ))RA_MASK\n",
+			       ((dm->support_ability & ODM_BB_RA_MASK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "02. (( %s ))DYN_TXPWR\n",
+			       ((dm->support_ability & ODM_BB_DYNAMIC_TXPWR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "03. (( %s ))FA_CNT\n",
+			       ((dm->support_ability & ODM_BB_FA_CNT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "04. (( %s ))RSSI_MNTR\n",
+			       ((dm->support_ability & ODM_BB_RSSI_MONITOR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "05. (( %s ))CCK_PD\n",
+			       ((dm->support_ability & ODM_BB_CCK_PD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "06. (( %s ))ANT_DIV\n",
+			       ((dm->support_ability & ODM_BB_ANT_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "07. (( %s ))SMT_ANT\n",
+			       ((dm->support_ability & ODM_BB_SMT_ANT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "08. (( %s ))PWR_TRAIN\n",
+			       ((dm->support_ability & ODM_BB_PWR_TRAIN) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "09. (( %s ))RA\n",
+			       ((dm->support_ability & ODM_BB_RATE_ADAPTIVE) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "10. (( %s ))PATH_DIV\n",
+			       ((dm->support_ability & ODM_BB_PATH_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "11. (( %s ))DFS\n",
+			       ((dm->support_ability & ODM_BB_DFS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "12. (( %s ))DYN_ARFR\n",
+			       ((dm->support_ability & ODM_BB_DYNAMIC_ARFR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "13. (( %s ))ADAPTIVITY\n",
+			       ((dm->support_ability & ODM_BB_ADAPTIVITY) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "14. (( %s ))CFO_TRACK\n",
+			       ((dm->support_ability & ODM_BB_CFO_TRACKING) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "15. (( %s ))ENV_MONITOR\n",
+			       ((dm->support_ability & ODM_BB_ENV_MONITOR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "16. (( %s ))PRI_CCA\n",
+			       ((dm->support_ability & ODM_BB_PRIMARY_CCA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "17. (( %s ))ADPTV_SOML\n",
+			       ((dm->support_ability & ODM_BB_ADAPTIVE_SOML) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "18. (( %s ))NA_SAT_CHK\n",
+			       ((dm->support_ability & ODM_BB_LNA_SAT_CHK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "19. (( %s ))DYN_RX_PATH\n",
+			       ((dm->support_ability & ODM_BB_DYNAMIC_RX_PATH) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[Supportability] PhyDM offload ability\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))PHY PARAM OFFLOAD\n",
+			       ((dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "01. (( %s ))RF IQK OFFLOAD\n",
+			       ((dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+
+	}
+	/*
+	else if(dm_value[0] == 101)
+	{
+		dm->support_ability = 0 ;
+		dbg_print("Disable all support_ability components\n");
+		PDM_SNPF((output+used, out_len-used,"%s\n", "Disable all support_ability components"));
+	}
+	*/
+	else {
+		if (dm_value[1] == 1) { /* enable */
+			dm->support_ability |= (one << dm_value[0]);
+			if (BIT(dm_value[0]) & ODM_BB_PATH_DIV)
+				phydm_path_diversity_init(dm);
+		} else if (dm_value[1] == 2)	/* disable */
+			dm->support_ability &= ~(one << dm_value[0]);
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "%s\n",
+				       "[Warning!!!]  1:enable,  2:disable");
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "pre-support_ability  =  0x%llx\n",
+		         pre_support_ability);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Curr-support_ability =  0x%llx\n",
+		       dm->support_ability);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%s\n",
+		       "================================");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_watchdog_lps_32k(
+	struct dm_struct		*dm
+)
+{
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
+
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_dig_lps_32k(dm);
+	phydm_common_info_self_reset(dm);
+}
+
+void
+phydm_watchdog_lps(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
+
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_basic_dbg_message(dm);
+	phydm_receiver_blocking(dm);
+	odm_false_alarm_counter_statistics(dm);
+	phydm_dig_by_rssi_lps(dm);
+	phydm_cck_pd_th(dm);
+	phydm_adaptivity(dm);
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	odm_antenna_diversity(dm); /*enable AntDiv in PS mode, request from SD4 Jeff*/
+	#endif
+	phydm_common_info_self_reset(dm);
+#endif
+}
+
+void
+phydm_watchdog_mp(
+	struct dm_struct		*dm
+)
+{
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_caller(dm);
+#endif
+}
+
+void
+phydm_pause_dm_watchdog(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+
+	if (pause_type == PHYDM_PAUSE) {
+		dm->disable_phydm_watchdog = 1;
+		PHYDM_DBG(dm, ODM_COMP_API, "PHYDM Stop\n");
+	} else {
+		dm->disable_phydm_watchdog = 0;
+		PHYDM_DBG(dm, ODM_COMP_API, "PHYDM Start\n");
+	}
+}
+
+u8
+phydm_pause_func(
+	void						*dm_void,
+	enum phydm_func_idx	pause_func,
+	enum phydm_pause_type	pause_type,
+	enum phydm_pause_level	pause_lv,
+	u8						val_lehgth,
+	u32						*val_buf
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	s8	*pause_lv_pre = &dm->s8_dummy;
+	u32	*bkp_val = &dm->u32_dummy;
+	u32	ori_val[5] = {0};
+	u64	pause_func_bitmap = (u64)BIT(pause_func);
+	u8	i;
+
+
+
+	PHYDM_DBG(dm, ODM_COMP_API, "[%s][%s] LV=%d, Len=%d\n", __func__, 
+		((pause_type == PHYDM_PAUSE) ? "Pause" : "Resume"),  pause_lv, val_lehgth);
+
+	if (pause_lv >= PHYDM_PAUSE_MAX_NUM) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] Wrong LV=%d\n", pause_lv);
+		return PAUSE_FAIL;
+	}
+
+	if (pause_func == F00_DIG) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[DIG]\n");
+
+		if (val_lehgth != 1) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 1\n");
+			return PAUSE_FAIL;
+		}
+		
+		ori_val[0] = (u32)(dm->dm_dig_table.cur_ig_value); /*0xc50*/
+		pause_lv_pre = &dm->pause_lv_table.lv_dig;
+		bkp_val = (u32*)(&dm->dm_dig_table.rvrt_val);
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_dig_val; /*function pointer hook*/
+	
+	} else
+	
+#ifdef PHYDM_SUPPORT_CCKPD
+	if (pause_func == F05_CCK_PD) {
+		
+		PHYDM_DBG(dm, ODM_COMP_API, "[CCK_PD]\n");
+
+		if (val_lehgth != 2) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 2\n");
+			return PAUSE_FAIL;
+		}
+		
+		ori_val[0] = dm->dm_cckpd_table.cur_cck_cca_thres; /*0xa0a*/
+		ori_val[1] = dm->dm_cckpd_table.cck_cca_th_aaa;	/*0xaaa*/
+		pause_lv_pre = &dm->pause_lv_table.lv_cckpd;
+		bkp_val = &dm->dm_cckpd_table.rvrt_val[0];
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_cckpd_val; /*function pointer hook*/
+		
+	} else 
+#endif
+
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	if (pause_func == F06_ANT_DIV) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[AntDiv]\n");
+
+		if (val_lehgth != 1) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 1\n");
+			return PAUSE_FAIL;
+		}
+		
+		ori_val[0] = (u32)(dm->dm_fat_table.rx_idle_ant); /*default antenna*/
+		pause_lv_pre = &dm->pause_lv_table.lv_antdiv;
+		bkp_val = (u32*)(&dm->dm_fat_table.rvrt_val);
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_antdiv_val; /*function pointer hook*/
+	
+	} else
+#endif
+
+	if (pause_func == F13_ADPTVTY) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Adaptivity]\n");
+
+		if (val_lehgth != 2) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 2\n");
+			return PAUSE_FAIL;
+		}
+
+		ori_val[0] = (u32)(dm->adaptivity.th_l2h);	/*th_l2h*/
+		ori_val[1] = (u32)(dm->adaptivity.th_h2l);	/*th_h2l*/
+		pause_lv_pre = &dm->pause_lv_table.lv_adapt;
+		bkp_val = (u32 *)(&dm->adaptivity.rvrt_val);
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_edcca_val; /*function pointer hook*/
+
+	} else
+
+	{
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] error func idx\n");
+		return PAUSE_FAIL;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_API, "Pause_LV{new , pre} = {%d ,%d}\n", pause_lv, *pause_lv_pre);
+
+	if ((pause_type == PHYDM_PAUSE) || (pause_type == PHYDM_PAUSE_NO_SET)) {
+		if (pause_lv <= *pause_lv_pre) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[PAUSE FAIL] Pre_LV >= Curr_LV\n");
+			return PAUSE_FAIL;
+		}
+
+		if (!(dm->pause_ability & pause_func_bitmap)) {
+			for (i = 0; i < val_lehgth; i ++)
+				bkp_val[i] = ori_val[i];
+		}
+
+		dm->pause_ability |= pause_func_bitmap;
+		PHYDM_DBG(dm, ODM_COMP_API, "pause_ability=0x%llx\n", dm->pause_ability);
+
+		if (pause_type == PHYDM_PAUSE) {
+			for (i = 0; i < val_lehgth; i ++) {
+				PHYDM_DBG(dm, ODM_COMP_API, "[PAUSE SUCCESS] val_idx[%d]{New, Ori}={0x%x, 0x%x}\n",i, val_buf[i], bkp_val[i]);
+				/**/
+			}
+			dm->phydm_func_handler.pause_phydm_handler(dm, val_buf, val_lehgth);
+		} else {
+			for (i = 0; i < val_lehgth; i ++) {
+				PHYDM_DBG(dm, ODM_COMP_API, "[PAUSE NO Set: SUCCESS] val_idx[%d]{Ori}={0x%x}\n",i, bkp_val[i]);
+				/**/
+			}
+		}
+
+		*pause_lv_pre = pause_lv;
+		return PAUSE_SUCCESS;
+
+	} else if (pause_type == PHYDM_RESUME) {
+		dm->pause_ability &= ~pause_func_bitmap;
+		PHYDM_DBG(dm, ODM_COMP_API, "pause_ability=0x%llx\n", dm->pause_ability);
+		
+		*pause_lv_pre = PHYDM_PAUSE_RELEASE;
+		
+		for (i = 0; i < val_lehgth; i ++) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[RESUME] val_idx[%d]={0x%x}\n", i, bkp_val[i]);
+		}
+		
+		dm->phydm_func_handler.pause_phydm_handler(dm, bkp_val, val_lehgth);
+		
+		return PAUSE_SUCCESS;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] error pause_type\n");
+		return PAUSE_FAIL;
+	}
+	
+}
+
+void
+phydm_pause_func_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i;
+	u8		val_length = 0;
+	u32		val_buf[5] = {0};
+	u8		set_result = 0;
+	enum phydm_func_idx	func = (enum phydm_func_idx)0;
+	enum phydm_pause_type	pause_type = (enum phydm_pause_type)0;
+	enum phydm_pause_level	pause_lv = (enum phydm_pause_level)0;
+	
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "{Func} {1:pause, 2:Resume} {lv} Val[5:0]\n");
+		
+	} else {
+		for (i = 0; i < 10; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+			}
+		}
+
+		func = (enum phydm_func_idx)var1[0];
+		pause_type = (enum phydm_pause_type)var1[1];
+		pause_lv = (enum phydm_pause_level)var1[2];
+	
+
+		for (i = 0; i < 5; i++) {
+			val_buf[i] = var1[3 + i];
+		}
+
+		if (func == F00_DIG) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[DIG]\n");
+			val_length = 1;
+			
+		} else if (func == F05_CCK_PD) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[CCK_PD]\n");
+			val_length = 2;
+		} else if (func == F06_ANT_DIV) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Ant_Div]\n");
+			val_length = 1;
+		} else if (func == F13_ADPTVTY) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Adaptivity]\n");
+			val_length = 2;
+		} else {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Set Function Error]\n");
+			val_length = 0;
+		}
+
+		if (val_length != 0) {
+			
+			PDM_SNPF(out_len, used, output + used, out_len - used, "{%s, lv=%d} val = %d, %d}\n", 
+				       ((pause_type == PHYDM_PAUSE) ? "Pause" : "Resume"),
+				       pause_lv, var1[3], var1[4]);
+			
+			set_result= phydm_pause_func(dm, func, pause_type, pause_lv, val_length, val_buf);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "set_result = %d\n", 
+			set_result);
+	}
+
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+u8
+phydm_stop_dm_watchdog_check(
+	void					*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+
+	if (dm->disable_phydm_watchdog == 1) {
+		PHYDM_DBG(dm, DBG_COMMON_FLOW, "Disable phydm\n");
+		return true;
+	} else
+		return false;
+	
+}
+
+/*
+ * 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
+phydm_watchdog(
+	struct dm_struct		*dm
+)
+{
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
+
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_basic_dbg_message(dm);
+	phydm_auto_dbg_engine(dm);
+	phydm_receiver_blocking(dm);
+	
+	if (phydm_stop_dm_watchdog_check(dm) == true)
+		return;
+
+	phydm_hw_setting(dm);
+	
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0)
+		phydm_tdma_dig_timer_check(dm);
+	else 
+	#endif
+	{
+		odm_false_alarm_counter_statistics(dm);
+		phydm_noisy_detection(dm);
+		phydm_dig(dm);
+		phydm_cck_pd_th(dm);
+	}
+
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+	phydm_update_power_training_state(dm);
+#endif
+	phydm_adaptivity(dm);
+	phydm_ra_info_watchdog(dm);
+	odm_path_diversity(dm);
+	phydm_cfo_tracking(dm);
+	/* odm_dynamic_tx_power(dm); */
+	phydm_dynamic_tx_power(dm);
+	odm_antenna_diversity(dm);
+	phydm_adaptive_soml(dm);
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_beamforming_watchdog(dm);
+#endif
+
+	halrf_watchdog(dm);
+	phydm_primary_cca(dm);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	odm_dtc(dm);
+#endif
+
+	phydm_env_mntr_watchdog(dm);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_watchdog(dm);
+#endif
+
+	phydm_common_info_self_reset(dm);
+
+}
+
+
+/*
+ * Init /.. Fixed HW value. Only init time.
+ *   */
+void
+odm_cmn_info_init(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	u64			value
+)
+{
+	/*  */
+	/* This section is used for init value */
+	/*  */
+	switch	(cmn_info) {
+	/*  */
+	/* Fixed ODM value. */
+	/*  */
+	case	ODM_CMNINFO_ABILITY:
+		dm->support_ability = (u64)value;
+		break;
+
+	case	ODM_CMNINFO_RF_TYPE:
+		dm->rf_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_PLATFORM:
+		dm->support_platform = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_INTERFACE:
+		dm->support_interface = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_MP_TEST_CHIP:
+		dm->is_mp_chip = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_IC_TYPE:
+		dm->support_ic_type = (u32)value;
+		break;
+
+	case	ODM_CMNINFO_CUT_VER:
+		dm->cut_version = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_FAB_VER:
+		dm->fab_version = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_RFE_TYPE:
+		#if (RTL8821C_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8821C)
+			dm->rfe_type_expand = (u8)value; /**/
+		else
+		#endif
+			dm->rfe_type = (u8)value;
+		phydm_init_hw_info_by_rfe(dm);
+		break;
+
+	case    ODM_CMNINFO_RF_ANTENNA_TYPE:
+		dm->ant_div_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH:
+		dm->with_extenal_ant_switch = (u8)value;
+		break;
+
+	case    ODM_CMNINFO_BE_FIX_TX_ANT:
+		dm->dm_fat_table.b_fix_tx_ant = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BOARD_TYPE:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->board_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_PACKAGE_TYPE:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->package_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_EXT_LNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_lna = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_5G_EXT_LNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_lna_5g = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_EXT_PA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_pa = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_5G_EXT_PA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_pa_5g = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_GPA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_gpa = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_APA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_apa = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_GLNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_glna = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_ALNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_alna = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_EXT_TRSW:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_trsw = (u8)value;
+		break;
+	case	ODM_CMNINFO_EXT_LNA_GAIN:
+		dm->ext_lna_gain = (u8)value;
+		break;
+	case	ODM_CMNINFO_PATCH_ID:
+		dm->iot_table.win_patch_id = (u8)value;
+		break;
+	case	ODM_CMNINFO_BINHCT_TEST:
+		dm->is_in_hct_test = (boolean)value;
+		break;
+	case	ODM_CMNINFO_BWIFI_TEST:
+		dm->wifi_test = (u8)value;
+		break;
+	case	ODM_CMNINFO_SMART_CONCURRENT:
+		dm->is_dual_mac_smart_concurrent = (boolean)value;
+		break;
+	case	ODM_CMNINFO_DOMAIN_CODE_2G:
+		dm->odm_regulation_2_4g = (u8)value;
+		break;
+	case	ODM_CMNINFO_DOMAIN_CODE_5G:
+		dm->odm_regulation_5g = (u8)value;
+		break;
+#if (DM_ODM_SUPPORT_TYPE &  (ODM_AP))
+	case	ODM_CMNINFO_CONFIG_BB_RF:
+		dm->config_bbrf = (boolean)value;
+		break;
+#endif
+	case	ODM_CMNINFO_IQKPAOFF:
+		dm->rf_calibrate_info.is_iqk_pa_off = (boolean)value;
+		break;
+	case	ODM_CMNINFO_REGRFKFREEENABLE:
+		dm->rf_calibrate_info.reg_rf_kfree_enable = (u8)value;
+		break;
+	case	ODM_CMNINFO_RFKFREEENABLE:
+		dm->rf_calibrate_info.rf_kfree_enable = (u8)value;
+		break;
+	case	ODM_CMNINFO_NORMAL_RX_PATH_CHANGE:
+		dm->normal_rx_path = (u8)value;
+		break;
+	case	ODM_CMNINFO_EFUSE0X3D8:
+		dm->efuse0x3d8 = (u8)value;
+		break;
+	case	ODM_CMNINFO_EFUSE0X3D7:
+		dm->efuse0x3d7 = (u8)value;
+		break;
+	case	ODM_CMNINFO_ADVANCE_OTA:
+		dm->p_advance_ota = (u8)value;
+		break;
+		
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	case	ODM_CMNINFO_DFS_REGION_DOMAIN:
+		dm->dfs_region_domain = (u8)value;
+		break;
+#endif
+	case	ODM_CMNINFO_SOFT_AP_SPECIAL_SETTING:
+		dm->soft_ap_special_setting = (u32)value;
+		break;
+
+	case	ODM_CMNINFO_DPK_EN:
+		/*dm->dpk_en = (u1Byte)value;*/
+		halrf_cmn_info_set(dm, HALRF_CMNINFO_DPK_EN, (u64)value);
+		break;
+
+	case	ODM_CMNINFO_HP_HWID:
+		dm->hp_hw_id = (boolean)value;
+		break;
+	/* To remove the compiler warning, must add an empty default statement to handle the other values. */
+	default:
+		/* do nothing */
+		break;
+
+	}
+
+}
+
+
+void
+odm_cmn_info_hook(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	void			*value
+)
+{
+	/*  */
+	/* Hook call by reference pointer. */
+	/*  */
+	switch	(cmn_info) {
+	/*  */
+	/* Dynamic call by reference pointer. */
+	/*  */
+	case	ODM_CMNINFO_TX_UNI:
+		dm->num_tx_bytes_unicast = (u64 *)value;
+		break;
+
+	case	ODM_CMNINFO_RX_UNI:
+		dm->num_rx_bytes_unicast = (u64 *)value;
+		break;
+
+	case	ODM_CMNINFO_BAND:
+		dm->band_type = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_CHNL_OFFSET:
+		dm->sec_ch_offset = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_MODE:
+		dm->security = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_BW:
+		dm->band_width = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_CHNL:
+		dm->channel = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_SCAN:
+		dm->is_scan_in_process = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_POWER_SAVING:
+		dm->is_power_saving = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_ONE_PATH_CCA:
+		dm->one_path_cca = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_DRV_STOP:
+		dm->is_driver_stopped = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_PNP_IN:
+		dm->is_driver_is_going_to_pnp_set_power_sleep = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_INIT_ON:
+		dm->pinit_adpt_in_progress = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_ANT_TEST:
+		dm->antenna_test = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_NET_CLOSED:
+		dm->is_net_closed = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_FORCED_RATE:
+		dm->forced_data_rate = (u16 *)value;
+		break;
+	case ODM_CMNINFO_ANT_DIV:
+		dm->enable_antdiv = (u8 *)value;
+		break;
+
+	case ODM_CMNINFO_ADAPTIVE_SOML:
+		dm->en_adap_soml = (u8 *)value;
+		break;
+
+	case ODM_CMNINFO_ADAPTIVITY:
+		dm->enable_adaptivity = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_P2P_LINK:
+		dm->dm_dig_table.is_p2p_in_process = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_IS1ANTENNA:
+		dm->is_1_antenna = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_RFDEFAULTPATH:
+		dm->rf_default_path = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_FCS_MODE:
+		dm->is_fcs_mode_enable = (boolean *)value;
+		break;
+	/*add by YuChen for beamforming PhyDM*/
+	case	ODM_CMNINFO_HUBUSBMODE:
+		dm->hub_usb_mode = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS:
+		dm->is_fw_dw_rsvd_page_in_progress = (boolean *)value;
+		break;
+	case	ODM_CMNINFO_TX_TP:
+		dm->current_tx_tp = (u32 *)value;
+		break;
+	case	ODM_CMNINFO_RX_TP:
+		dm->current_rx_tp = (u32 *)value;
+		break;
+	case	ODM_CMNINFO_SOUNDING_SEQ:
+		dm->sounding_seq = (u8 *)value;
+		break;
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	case	ODM_CMNINFO_DFS_MASTER_ENABLE:
+		dm->dfs_master_enabled = (u8 *)value;
+		break;
+#endif
+	case	ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC:
+		dm->dm_fat_table.p_force_tx_ant_by_desc = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA:
+		dm->dm_fat_table.p_default_s0_s1 = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_SOFT_AP_MODE:
+		dm->soft_ap_mode = (u32 *)value;
+		break;
+	case ODM_CMNINFO_MP_MODE:
+		dm->mp_mode = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_INTERRUPT_MASK:
+		dm->interrupt_mask = (u32 *)value;
+		break;
+	case ODM_CMNINFO_BB_OPERATION_MODE:
+		dm->bb_op_mode = (u8 *)value;
+		break;
+	case ODM_CMNINFO_BF_ANTDIV_DECISION:
+		dm->dm_fat_table.is_no_csi_feedback = (boolean *)value;
+		break;
+
+	default:
+		/*do nothing*/
+		break;
+
+	}
+
+}
+/*
+ * Update band/CHannel/.. The values are dynamic but non-per-packet.
+ *   */
+void
+odm_cmn_info_update(
+	struct dm_struct		*dm,
+	u32			cmn_info,
+	u64			value
+)
+{
+	/*  */
+	/* This init variable may be changed in run time. */
+	/*  */
+	switch	(cmn_info) {
+	case ODM_CMNINFO_LINK_IN_PROGRESS:
+		dm->is_link_in_process = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_ABILITY:
+		dm->support_ability = (u64)value;
+		break;
+
+	case	ODM_CMNINFO_RF_TYPE:
+		dm->rf_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_WIFI_DIRECT:
+		dm->is_wifi_direct = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_WIFI_DISPLAY:
+		dm->is_wifi_display = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_LINK:
+		dm->is_linked = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_CMW500LINK:
+		dm->iot_table.is_linked_cmw500 = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_STATION_STATE:
+		dm->bsta_state = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_RSSI_MIN:
+		dm->rssi_min = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_RSSI_MIN_BY_PATH:
+		dm->rssi_min_by_path = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_DBG_COMP:
+		dm->debug_components = (u64)value;
+		break;
+
+	case	ODM_CMNINFO_DBG_LEVEL:
+		dm->debug_level = (u32)value;
+		break;
+
+#ifdef ODM_CONFIG_BT_COEXIST
+	/* The following is for BT HS mode and BT coexist mechanism. */
+	case ODM_CMNINFO_BT_ENABLED:
+		dm->bt_info_table.is_bt_enabled = (boolean)value;
+		break;
+
+	case ODM_CMNINFO_BT_HS_CONNECT_PROCESS:
+		dm->bt_info_table.is_bt_connect_process = (boolean)value;
+		break;
+
+	case ODM_CMNINFO_BT_HS_RSSI:
+		dm->bt_info_table.bt_hs_rssi = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BT_OPERATION:
+		dm->bt_info_table.is_bt_hs_operation = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_BT_LIMITED_DIG:
+		dm->bt_info_table.is_bt_limited_dig = (boolean)value;
+		break;
+#endif
+
+	case	ODM_CMNINFO_AP_TOTAL_NUM:
+		dm->ap_total_num = (u8)value;
+		break;
+
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	case	ODM_CMNINFO_DFS_REGION_DOMAIN:
+		dm->dfs_region_domain = (u8)value;
+		break;
+#endif
+
+	case	ODM_CMNINFO_BT_CONTINUOUS_TURN:
+		dm->is_bt_continuous_turn = (boolean)value;
+		break;
+
+#if 0
+	case	ODM_CMNINFO_OP_MODE:
+		dm->op_mode = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BAND:
+		dm->band_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_CHNL_OFFSET:
+		dm->sec_ch_offset = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_MODE:
+		dm->security = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BW:
+		dm->band_width = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_CHNL:
+		dm->channel = (u8)value;
+		break;
+#endif
+	default:
+		/* do nothing */
+		break;
+	}
+
+
+}
+
+u32
+phydm_cmn_info_query(
+	struct dm_struct		*dm,
+	enum phydm_info_query		info_type
+)
+{
+	struct phydm_fa_struct		*fa_t = &dm->false_alm_cnt;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+
+	switch (info_type) {
+	/*=== [FA Relative] ===========================================*/
+	case PHYDM_INFO_FA_OFDM:
+		return fa_t->cnt_ofdm_fail;
+
+	case PHYDM_INFO_FA_CCK:
+		return fa_t->cnt_cck_fail;
+
+	case PHYDM_INFO_FA_TOTAL:
+		return fa_t->cnt_all;
+
+	case PHYDM_INFO_CCA_OFDM:
+		return fa_t->cnt_ofdm_cca;
+
+	case PHYDM_INFO_CCA_CCK:
+		return fa_t->cnt_cck_cca;
+
+	case PHYDM_INFO_CCA_ALL:
+		return fa_t->cnt_cca_all;
+
+	case PHYDM_INFO_CRC32_OK_VHT:
+		return fa_t->cnt_vht_crc32_ok;
+
+	case PHYDM_INFO_CRC32_OK_HT:
+		return fa_t->cnt_ht_crc32_ok;
+
+	case PHYDM_INFO_CRC32_OK_LEGACY:
+		return fa_t->cnt_ofdm_crc32_ok;
+
+	case PHYDM_INFO_CRC32_OK_CCK:
+		return fa_t->cnt_cck_crc32_ok;
+
+	case PHYDM_INFO_CRC32_ERROR_VHT:
+		return fa_t->cnt_vht_crc32_error;
+
+	case PHYDM_INFO_CRC32_ERROR_HT:
+		return fa_t->cnt_ht_crc32_error;
+
+	case PHYDM_INFO_CRC32_ERROR_LEGACY:
+		return fa_t->cnt_ofdm_crc32_error;
+
+	case PHYDM_INFO_CRC32_ERROR_CCK:
+		return fa_t->cnt_cck_crc32_error;
+
+	case PHYDM_INFO_EDCCA_FLAG:
+		return fa_t->edcca_flag;
+
+	case PHYDM_INFO_OFDM_ENABLE:
+		return fa_t->ofdm_block_enable;
+
+	case PHYDM_INFO_CCK_ENABLE:
+		return fa_t->cck_block_enable;
+
+	case PHYDM_INFO_DBG_PORT_0:
+		return fa_t->dbg_port0;
+				
+	case PHYDM_INFO_CRC32_OK_HT_AGG:
+		return fa_t->cnt_ht_crc32_ok_agg;
+		
+	case PHYDM_INFO_CRC32_ERROR_HT_AGG:
+		return fa_t->cnt_ht_crc32_error_agg;
+		
+	/*=== [DIG] ================================================*/	
+	
+	case PHYDM_INFO_CURR_IGI:
+		return dig_t->cur_ig_value;
+
+	/*=== [RSSI] ===============================================*/
+	case PHYDM_INFO_RSSI_MIN:
+		return (u32)dm->rssi_min;
+		
+	case PHYDM_INFO_RSSI_MAX:
+		return (u32)dm->rssi_max;
+
+	case PHYDM_INFO_CLM_RATIO :
+		return (u32)ccx_info->clm_ratio;
+	case PHYDM_INFO_NHM_RATIO :
+		return (u32)ccx_info->nhm_ratio;
+	default:
+		return 0xffffffff;
+
+	}
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_init_all_work_items(struct dm_struct	*dm)
+{
+	void		*adapter = dm->adapter;
+#if USE_WORKITEM
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	odm_initialize_work_item(dm,
+			 &dm->dm_drp_table.phydm_dynamic_rx_path_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_dynamic_rx_path_workitem_callback,
+				 (void *)adapter,
+				 "DynamicRxPathWorkitem");
+
+#endif
+
+#ifdef CONFIG_ADAPTIVE_SOML
+	odm_initialize_work_item(dm,
+			 &dm->dm_soml_table.phydm_adaptive_soml_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_adaptive_soml_workitem_callback,
+				 (void *)adapter,
+				 "AdaptiveSOMLWorkitem");
+#endif
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	odm_initialize_work_item(dm,
+		 &dm->dm_swat_table.phydm_sw_antenna_switch_workitem,
+			 (RT_WORKITEM_CALL_BACK)odm_sw_antdiv_workitem_callback,
+				 (void *)adapter,
+				 "AntennaSwitchWorkitem");
+#endif
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	odm_initialize_work_item(dm,
+			 &dm->dm_sat_table.hl_smart_antenna_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_beam_switch_workitem_callback,
+				 (void *)adapter,
+				 "hl_smart_ant_workitem");
+
+	odm_initialize_work_item(dm,
+		 &dm->dm_sat_table.hl_smart_antenna_decision_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_beam_decision_workitem_callback,
+				 (void *)adapter,
+				 "hl_smart_ant_decision_workitem");
+#endif
+
+	odm_initialize_work_item(
+		dm,
+		&dm->path_div_switch_workitem,
+		(RT_WORKITEM_CALL_BACK)odm_path_div_chk_ant_switch_workitem_callback,
+		(void *)adapter,
+		"SWAS_WorkItem");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->cck_path_diversity_workitem,
+		(RT_WORKITEM_CALL_BACK)odm_cck_tx_path_diversity_work_item_callback,
+		(void *)adapter,
+		"CCKTXPathDiversityWorkItem");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->ra_rpt_workitem,
+		(RT_WORKITEM_CALL_BACK)halrf_update_init_rate_work_item_callback,
+		(void *)adapter,
+		"ra_rpt_workitem");
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+	odm_initialize_work_item(
+		dm,
+		&dm->fast_ant_training_workitem,
+		(RT_WORKITEM_CALL_BACK)odm_fast_ant_training_work_item_callback,
+		(void *)adapter,
+		"fast_ant_training_workitem");
+#endif
+
+#endif /*#if USE_WORKITEM*/
+
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_enter_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_enter_work_item_callback,
+		(void *)adapter,
+		"txbf_enter_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_leave_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_leave_work_item_callback,
+		(void *)adapter,
+		"txbf_leave_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_fw_ndpa_work_item_callback,
+		(void *)adapter,
+		"txbf_fw_ndpa_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_clk_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_clk_work_item_callback,
+		(void *)adapter,
+		"txbf_clk_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_rate_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_rate_work_item_callback,
+		(void *)adapter,
+		"txbf_rate_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_status_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_status_work_item_callback,
+		(void *)adapter,
+		"txbf_status_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_reset_tx_path_work_item_callback,
+		(void *)adapter,
+		"txbf_reset_tx_path_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_get_tx_rate_work_item_callback,
+		(void *)adapter,
+		"txbf_get_tx_rate_work_item");
+#endif
+
+	odm_initialize_work_item(
+		dm,
+		&dm->adaptivity.phydm_pause_edcca_work_item,
+		(RT_WORKITEM_CALL_BACK)phydm_pause_edcca_work_item_callback,
+		(void *)adapter,
+		"phydm_pause_edcca_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->adaptivity.phydm_resume_edcca_work_item,
+		(RT_WORKITEM_CALL_BACK)phydm_resume_edcca_work_item_callback,
+		(void *)adapter,
+		"phydm_resume_edcca_work_item");
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	odm_initialize_work_item(
+		dm,
+		&dm->adcsmp.adc_smp_work_item,
+		(RT_WORKITEM_CALL_BACK)adc_smp_work_item_callback,
+		(void *)adapter,
+		"adc_smp_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->adcsmp.adc_smp_work_item_1,
+		(RT_WORKITEM_CALL_BACK)adc_smp_work_item_callback,
+		(void *)adapter,
+		"adc_smp_work_item_1");
+#endif
+
+}
+
+void
+odm_free_all_work_items(struct dm_struct	*dm)
+{
+#if USE_WORKITEM
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	odm_free_work_item(&dm->dm_swat_table.phydm_sw_antenna_switch_workitem);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	odm_free_work_item(&dm->dm_drp_table.phydm_dynamic_rx_path_workitem);
+#endif
+
+#ifdef CONFIG_ADAPTIVE_SOML
+	odm_free_work_item(&dm->dm_soml_table.phydm_adaptive_soml_workitem);
+#endif
+
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	odm_free_work_item(&dm->dm_sat_table.hl_smart_antenna_workitem);
+	odm_free_work_item(&dm->dm_sat_table.hl_smart_antenna_decision_workitem);
+#endif
+
+	odm_free_work_item(&dm->path_div_switch_workitem);
+	odm_free_work_item(&dm->cck_path_diversity_workitem);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+	odm_free_work_item(&dm->fast_ant_training_workitem);
+#endif
+	odm_free_work_item(&dm->ra_rpt_workitem);
+	/*odm_free_work_item((&dm->sbdcnt_workitem));*/
+#endif
+
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_enter_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_leave_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_clk_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_rate_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_status_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item));
+#endif
+
+	odm_free_work_item((&dm->adaptivity.phydm_pause_edcca_work_item));
+	odm_free_work_item((&dm->adaptivity.phydm_resume_edcca_work_item));
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	odm_free_work_item((&dm->adcsmp.adc_smp_work_item));
+	odm_free_work_item((&dm->adcsmp.adc_smp_work_item_1));
+#endif
+
+}
+#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+void
+odm_init_all_timers(
+	struct dm_struct	*dm
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	odm_ant_div_timers(dm, INIT_ANTDIV_TIMMER);
+#endif
+
+	phydm_adaptive_soml_timers(dm, INIT_SOML_TIMMER);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_timers(dm, INIT_LNA_SAT_CHK_TIMMER);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_timers(dm, INIT_DRP_TIMMER);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_initialize_timer(dm, &dm->path_div_switch_timer,
+		(void *)odm_path_div_chk_ant_switch_callback, NULL, "PathDivTimer");
+	odm_initialize_timer(dm, &dm->cck_path_diversity_timer,
+		(void *)odm_cck_tx_path_diversity_callback, NULL, "cck_path_diversity_timer");
+	odm_initialize_timer(dm, &dm->sbdcnt_timer,
+			     (void *)phydm_sbd_callback, NULL, "SbdTimer");
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_initialize_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer,
+		(void *)hal_com_txbf_fw_ndpa_timer_callback, NULL, "txbf_fw_ndpa_timer");
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_initialize_timer(dm, &dm->beamforming_info.beamforming_timer,
+		(void *)beamforming_sw_timer_callback, NULL, "beamforming_timer");
+#endif
+#endif
+}
+
+void
+odm_cancel_all_timers(
+	struct dm_struct	*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	/* 2012/01/12 MH Temp BSOD fix. We need to find NIC allocate mem fail reason in win7*/
+	if (dm->adapter == NULL)
+		return;	
+#endif
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	odm_ant_div_timers(dm, CANCEL_ANTDIV_TIMMER);
+#endif
+
+	phydm_adaptive_soml_timers(dm, CANCEL_SOML_TIMMER);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_timers(dm, CANCEL_LNA_SAT_CHK_TIMMER);
+#endif
+
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_timers(dm, CANCEL_DRP_TIMMER);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_cancel_timer(dm, &dm->path_div_switch_timer);
+	odm_cancel_timer(dm, &dm->cck_path_diversity_timer);
+	odm_cancel_timer(dm, &dm->sbdcnt_timer);
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_cancel_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_cancel_timer(dm, &dm->beamforming_info.beamforming_timer);
+#endif
+#endif
+
+}
+
+
+void
+odm_release_all_timers(
+	struct dm_struct	*dm
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	odm_ant_div_timers(dm, RELEASE_ANTDIV_TIMMER);
+#endif
+	phydm_adaptive_soml_timers(dm, RELEASE_SOML_TIMMER);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_timers(dm, RELEASE_LNA_SAT_CHK_TIMMER);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_timers(dm, RELEASE_DRP_TIMMER);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_release_timer(dm, &dm->path_div_switch_timer);
+	odm_release_timer(dm, &dm->cck_path_diversity_timer);
+	odm_release_timer(dm, &dm->sbdcnt_timer);
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_release_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_release_timer(dm, &dm->beamforming_info.beamforming_timer);
+#endif
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+void
+odm_init_all_threads(
+	struct dm_struct	*dm
+)
+{
+#ifdef TPT_THREAD
+	k_tpt_task_init(dm->priv);
+#endif
+}
+
+void
+odm_stop_all_threads(
+	struct dm_struct	*dm
+)
+{
+#ifdef TPT_THREAD
+	k_tpt_task_stop(dm->priv);
+#endif
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+/* Justin: According to the current RRSI to adjust Response Frame TX power, 2012/11/05 */
+void odm_dtc(struct dm_struct *dm)
+{
+#ifdef CONFIG_DM_RESP_TXAGC
+#define DTC_BASE            35	/* RSSI higher than this value, start to decade TX power */
+#define DTC_DWN_BASE       (DTC_BASE-5)	/* RSSI lower than this value, start to increase TX power */
+
+	/* RSSI vs TX power step mapping: decade TX power */
+	static const u8 dtc_table_down[] = {
+		DTC_BASE,
+		(DTC_BASE + 5),
+		(DTC_BASE + 10),
+		(DTC_BASE + 15),
+		(DTC_BASE + 20),
+		(DTC_BASE + 25)
+	};
+
+	/* RSSI vs TX power step mapping: increase TX power */
+	static const u8 dtc_table_up[] = {
+		DTC_DWN_BASE,
+		(DTC_DWN_BASE - 5),
+		(DTC_DWN_BASE - 10),
+		(DTC_DWN_BASE - 15),
+		(DTC_DWN_BASE - 15),
+		(DTC_DWN_BASE - 20),
+		(DTC_DWN_BASE - 20),
+		(DTC_DWN_BASE - 25),
+		(DTC_DWN_BASE - 25),
+		(DTC_DWN_BASE - 30),
+		(DTC_DWN_BASE - 35)
+	};
+
+	u8 i;
+	u8 dtc_steps = 0;
+	u8 sign;
+	u8 resp_txagc = 0;
+
+#if 0
+	/* As DIG is disabled, DTC is also disable */
+	if (!(dm->support_ability & ODM_XXXXXX))
+		return;
+#endif
+
+	if (dm->rssi_min > DTC_BASE) {
+		/* need to decade the CTS TX power */
+		sign = 1;
+		for (i = 0; i < ARRAY_SIZE(dtc_table_down); i++) {
+			if ((dtc_table_down[i] >= dm->rssi_min) || (dtc_steps >= 6))
+				break;
+			else
+				dtc_steps++;
+		}
+	}
+#if 0
+	else if (dm->rssi_min > DTC_DWN_BASE) {
+		/* needs to increase the CTS TX power */
+		sign = 0;
+		dtc_steps = 1;
+		for (i = 0; i < ARRAY_SIZE(dtc_table_up); i++) {
+			if ((dtc_table_up[i] <= dm->rssi_min) || (dtc_steps >= 10))
+				break;
+			else
+				dtc_steps++;
+		}
+	}
+#endif
+	else {
+		sign = 0;
+		dtc_steps = 0;
+	}
+
+	resp_txagc = dtc_steps | (sign << 4);
+	resp_txagc = resp_txagc | (resp_txagc << 5);
+	odm_write_1byte(dm, 0x06d9, resp_txagc);
+
+	PHYDM_DBG(dm, ODM_COMP_PWR_TRAIN, "%s rssi_min:%u, set RESP_TXAGC to %s %u\n",
+		__func__, dm->rssi_min, sign ? "minus" : "plus", dtc_steps);
+#endif /* CONFIG_RESP_TXAGC_ADJUST */
+}
+
+#endif /* #if (DM_ODM_SUPPORT_TYPE == ODM_CE) */
+
+
+/*<20170126, BB-Kevin>8188F D-CUT DC cancellation and 8821C*/
+void
+phydm_dc_cancellation(
+	struct dm_struct	*dm
+
+)
+{	
+#ifdef PHYDM_DC_CANCELLATION
+	u32		offset_i_hex[PHYDM_MAX_RF_PATH] = {0};
+	u32		offset_q_hex[PHYDM_MAX_RF_PATH] = {0};
+	u32		reg_value32[PHYDM_MAX_RF_PATH] = {0};
+	u8		path = RF_PATH_A;
+
+	if (!(dm->support_ic_type & ODM_DC_CANCELLATION_SUPPORT))
+		return;
+
+	if ((dm->support_ic_type & ODM_RTL8188F) && (dm->cut_version < ODM_CUT_D))
+		return;
+
+	/*DC_Estimation (only for 2x2 ic now) */
+
+	for (path = RF_PATH_A; path < PHYDM_MAX_RF_PATH; path++) {
+		if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
+			if (!phydm_set_bb_dbg_port(dm,
+				BB_DBGPORT_PRIORITY_2, 0x235)) {/*set debug port to 0x235*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					"[DC Cancellation] Set Debug port Fail");
+				return;
+			}
+		} else if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B)) {
+			if (!phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_2, 0x200)) {
+				/*set debug port to 0x200*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					"[DC Cancellation] Set Debug port Fail");
+				return;
+			}
+			phydm_bb_dbg_port_header_sel(dm, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				if (!phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_2, 0x202)) {
+					/*set debug port to 0x200*/
+					PHYDM_DBG(dm, ODM_COMP_API,
+						"[DC Cancellation] Set Debug port Fail");
+					return;
+				}
+				phydm_bb_dbg_port_header_sel(dm, 0x0);
+			}
+		}
+	
+		odm_write_dig(dm, 0x7E);
+	
+		if (dm->support_ic_type & ODM_IC_11N_SERIES)
+			odm_set_bb_reg(dm, 0x88c, BIT(21)|BIT(20), 0x3);
+		else {
+			odm_set_bb_reg(dm, 0xc00, BIT(1)|BIT(0), 0x0);
+			if (dm->rf_type > RF_1T1R)
+				odm_set_bb_reg(dm, 0xe00, BIT(1)|BIT(0), 0x0);
+		}
+		odm_set_bb_reg(dm, 0xa78, MASKBYTE1, 0x0); /*disable CCK DCNF*/
+	
+		PHYDM_DBG(dm, ODM_COMP_API, "DC cancellation Begin!!!");
+	
+		phydm_stop_ck320(dm, true);	/*stop ck320*/
+
+		/* the same debug port both for path-a and path-b*/
+		reg_value32[path] = phydm_get_bb_dbg_port_value(dm);
+
+		phydm_stop_ck320(dm, false);	/*start ck320*/
+
+		if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			odm_set_bb_reg(dm, 0x88c, BIT(21)|BIT(20), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0xc00, BIT(1)|BIT(0), 0x3);
+			odm_set_bb_reg(dm, 0xe00, BIT(1)|BIT(0), 0x3);
+		}
+		odm_write_dig(dm, 0x20);
+		phydm_release_bb_dbg_port(dm);
+
+		PHYDM_DBG(dm, ODM_COMP_API, "DC cancellation OK!!!");
+	}
+		
+	/*DC_Cancellation*/
+	odm_set_bb_reg(dm, 0xa9c, BIT(20), 0x1); /*DC compensation to CCK data path*/
+	if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
+		offset_i_hex[0] = (reg_value32[0] & 0xffc0000) >> 18;
+		offset_q_hex[0] = (reg_value32[0] & 0x3ff00) >> 8;
+
+		/*Before filling into registers, offset should be multiplexed (-1)*/
+		offset_i_hex[0] = (offset_i_hex[0] >= 0x200) ? (0x400 - offset_i_hex[1]) : (0x1ff - offset_i_hex[1]);
+		offset_q_hex[0] = (offset_q_hex[0] >= 0x200) ? (0x400 - offset_q_hex[1]) : (0x1ff - offset_q_hex[1]);
+
+		odm_set_bb_reg(dm, 0x950, 0x1ff, offset_i_hex[1]);
+		odm_set_bb_reg(dm, 0x950, 0x1ff0000, offset_q_hex[1]);
+	} else if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B)) {
+	
+		/* Path-a */
+		offset_i_hex[0] = (reg_value32[0] & 0xffc00) >> 10;
+		offset_q_hex[0] = reg_value32[0] & 0x3ff;
+
+		/*Before filling into registers, offset should be multiplexed (-1)*/
+		offset_i_hex[0] = 0x400 - offset_i_hex[0];
+		offset_q_hex[0] = 0x400 - offset_q_hex[0];
+
+		odm_set_bb_reg(dm, 0xc10, 0x3c000000, ((0x3c0 & offset_i_hex[0]) >> 6));
+		odm_set_bb_reg(dm, 0xc10, 0xfc00, (0x3f & offset_i_hex[0]));
+		odm_set_bb_reg(dm, 0xc14, 0x3c000000, ((0x3c0 & offset_q_hex[0]) >> 6));
+		odm_set_bb_reg(dm, 0xc14, 0xfc00, (0x3f & offset_q_hex[0]));
+
+		/* Path-b */
+		if (dm->rf_type > RF_1T1R) {
+			
+			offset_i_hex[1] = (reg_value32[1] & 0xffc00) >> 10;
+			offset_q_hex[1] = reg_value32[1] & 0x3ff;
+
+		/*Before filling into registers, offset should be multiplexed (-1)*/
+			offset_i_hex[1] = 0x400 - offset_i_hex[1];
+			offset_q_hex[1] = 0x400 - offset_q_hex[1];
+
+			odm_set_bb_reg(dm, 0xe10, 0x3c000000, ((0x3c0 & offset_i_hex[1]) >> 6));
+			odm_set_bb_reg(dm, 0xe10, 0xfc00, (0x3f & offset_i_hex[1]));
+			odm_set_bb_reg(dm, 0xe14, 0x3c000000, ((0x3c0 & offset_q_hex[1]) >> 6));
+			odm_set_bb_reg(dm, 0xe14, 0xfc00, (0x3f & offset_q_hex[1]));
+		}
+	}
+#endif
+}
+
+void
+phydm_receiver_blocking(
+	void *dm_void
+)
+{
+#ifdef CONFIG_RECEIVER_BLOCKING
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	channel = *dm->channel;
+	u8	bw = *dm->band_width;
+	u32	bb_regf0 = odm_get_bb_reg(dm, 0xf0, MASKDWORD);
+
+	if (!(dm->support_ic_type & ODM_RECEIVER_BLOCKING_SUPPORT))
+		return;
+
+	if ((dm->support_ic_type & ODM_RTL8188E && ((bb_regf0 & 0xf000) >> 12) < 8) ||
+		dm->support_ic_type & ODM_RTL8192E) { /*8188E_T version*/
+		if (dm->consecutive_idlel_time > 10 && *dm->mp_mode == false && dm->adaptivity_enable == true) {
+			if ((bw == CHANNEL_WIDTH_20) && (channel == 1)) {
+				phydm_nbi_setting(dm, FUNC_ENABLE, channel, 20, 2410, PHYDM_DONT_CARE);
+				dm->is_receiver_blocking_en = true;
+			} else if ((bw == CHANNEL_WIDTH_20) && (channel == 13)) {
+				phydm_nbi_setting(dm, FUNC_ENABLE, channel, 20, 2473, PHYDM_DONT_CARE);
+				dm->is_receiver_blocking_en = true;
+			} else if (dm->is_receiver_blocking_en && channel != 1 && channel != 13) {
+				phydm_nbi_enable(dm, FUNC_DISABLE);
+				odm_set_bb_reg(dm, 0xc40, 0x1f000000, 0x1f);
+				dm->is_receiver_blocking_en = false;
+			}
+			return;
+		}
+	} else if ((dm->support_ic_type & ODM_RTL8188E && ((bb_regf0 & 0xf000) >> 12) >= 8)) { /*8188E_S version*/
+		if (dm->consecutive_idlel_time > 10 && *dm->mp_mode == false && dm->adaptivity_enable == true) {
+			if ((bw == CHANNEL_WIDTH_20) && (channel == 13)) {
+				phydm_nbi_setting(dm, FUNC_ENABLE, channel, 20, 2473, PHYDM_DONT_CARE);
+				dm->is_receiver_blocking_en = true;
+			} else if (dm->is_receiver_blocking_en && channel != 13) {
+				phydm_nbi_enable(dm, FUNC_DISABLE);
+				odm_set_bb_reg(dm, 0xc40, 0x1f000000, 0x1f);
+				dm->is_receiver_blocking_en = false;
+			}
+			return;
+		}
+	}
+
+	if (dm->is_receiver_blocking_en) {
+		phydm_nbi_enable(dm, FUNC_DISABLE);
+		odm_set_bb_reg(dm, 0xc40, 0x1f000000, 0x1f);
+		dm->is_receiver_blocking_en = false;
+	}
+
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.h
new file mode 100644
index 000000000000..602b663c06bb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.h
@@ -0,0 +1,1237 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__HALDMOUTSRC_H__
+#define __HALDMOUTSRC_H__
+
+/*============================================================*/
+/*include files*/
+/*============================================================*/
+/*PHYDM header*/
+#include "phydm_pre_define.h"
+#include "phydm_dig.h"
+#include "phydm_pathdiv.h"
+#include "phydm_antdiv.h"
+#include "phydm_soml.h"
+#include "phydm_smt_ant.h"
+#include "phydm_antdect.h"
+#include "phydm_rainfo.h"
+#include "phydm_dynamictxpower.h"
+#include "phydm_cfotracking.h"
+#include "phydm_adaptivity.h"
+#include "phydm_dfs.h"
+#include "phydm_ccx.h"
+#include "txbf/phydm_hal_txbf_api.h"
+#include "phydm_adc_sampling.h"
+#include "phydm_dynamic_rx_path.h"
+#include "phydm_psd.h"
+#include "phydm_primary_cca.h"
+#include "phydm_cck_pd.h"
+#include "phydm_rssi_monitor.h"
+#include "phydm_auto_dbg.h"
+#include "phydm_math_lib.h"
+#include "phydm_noisemonitor.h"
+#include "phydm_api.h"
+#include "phydm_pow_train.h"
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
+	#include "phydm_beamforming.h"
+#endif
+
+/* reg naming transfer */
+#include "phydm_regtable.h"
+
+/*HALRF header*/
+#include "halrf/halrf_iqk.h"
+#include "halrf/halrf.h"
+#include "halrf/halrf_powertracking.h"
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	#include "halrf/halphyrf_ap.h"
+#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	#include "halrf/halphyrf_ce.h"
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	#include "halrf/halphyrf_win.h"
+#endif
+
+extern const u16 phy_rate_table[28];
+
+/*============================================================*/
+/*Definition */
+/*============================================================*/
+
+/* Traffic load decision */
+#define	TRAFFIC_ULTRA_LOW	1
+#define	TRAFFIC_LOW			2
+#define	TRAFFIC_MID			3
+#define	TRAFFIC_HIGH			4
+
+#define	NONE			0
+
+#define MAX_2(_x_, _y_)	(((_x_)>(_y_))? (_x_) : (_y_))
+#define MIN_2(_x_, _y_)	(((_x_)<(_y_))? (_x_) : (_y_))
+#define DIFF_2(_x_,_y_)	((_x_ >= _y_) ? (_x_ - _y_) : (_y_ - _x_))
+
+#define BYTE_2_DWORD(B3, B2, B1, B0)	((B3 << 24) | (B2 << 16) | (B1 << 8) | B0)
+#define BIT_2_BYTE(B3, B2, B1, B0)	((B3 << 3) | (B2 << 2) | (B1 << 1) | B0)
+
+/*For cmn sta info*/
+#define is_sta_active(sta)	((sta) && (sta->dm_ctrl & STA_DM_CTRL_ACTIVE))
+
+#define IS_FUNC_EN(name)	((name) && (*name))
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define PHYDM_WATCH_DOG_PERIOD	1 /*second*/
+#else
+	#define PHYDM_WATCH_DOG_PERIOD	2 /*second*/
+#endif
+
+/*============================================================*/
+/*structure and define*/
+/*============================================================*/
+
+#define		dm_type_by_fw			0
+#define		dm_type_by_driver		1
+
+struct phydm_phystatus_statistic {
+	
+	/*[CCK]*/
+	u32		rssi_cck_sum;
+	u32		rssi_cck_cnt;
+	/*[OFDM]*/	
+	u32		rssi_ofdm_sum;
+	u32		rssi_ofdm_cnt;
+	u32		evm_ofdm_sum;
+	u32		snr_ofdm_sum;
+	/*[1SS]*/
+	u32		rssi_1ss_cnt;
+	u32		rssi_1ss_sum;
+	u32		evm_1ss_sum;
+	u32		snr_1ss_sum;
+	/*[2SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	u32		rssi_2ss_cnt;
+	u32		rssi_2ss_sum[2];
+	u32		evm_2ss_sum[2];
+	u32		snr_2ss_sum[2];
+	#endif
+	/*[3SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	u32		rssi_3ss_cnt;
+	u32		rssi_3ss_sum[3];
+	u32		evm_3ss_sum[3];
+	u32		snr_3ss_sum[3];
+	#endif
+	/*[4SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	u32		rssi_4ss_cnt;
+	u32		rssi_4ss_sum[4];
+	u32		evm_4ss_sum[4];	
+	u32		snr_4ss_sum[4];
+	#endif
+};
+
+struct phydm_phystatus_avg {
+	
+	/*[CCK]*/
+	u8		rssi_cck_avg;
+	/*[OFDM]*/
+	u8		rssi_ofdm_avg;
+	u8		evm_ofdm_avg;
+	u8		snr_ofdm_avg;
+	/*[1SS]*/
+	u8		rssi_1ss_avg;
+	u8		evm_1ss_avg;
+	u8		snr_1ss_avg;
+	/*[2SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	u8		rssi_2ss_avg[2];
+	u8		evm_2ss_avg[2];
+	u8		snr_2ss_avg[2];
+	#endif
+	/*[3SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	u8		rssi_3ss_avg[3];
+	u8		evm_3ss_avg[3];
+	u8		snr_3ss_avg[3];
+	#endif
+	/*[4SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	u8		rssi_4ss_avg[4];
+	u8		evm_4ss_avg[4];	
+	u8		snr_4ss_avg[4];
+	#endif
+};
+
+struct odm_phy_dbg_info {
+	/*ODM Write,debug info*/
+	
+	u32		num_qry_phy_status_cck;
+	u32		num_qry_phy_status_ofdm;
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+	u32		num_qry_mu_pkt;
+	u32		num_qry_bf_pkt;
+	u32		num_qry_mu_vht_pkt[VHT_RATE_NUM];
+	boolean	is_ldpc_pkt;
+	boolean	is_stbc_pkt;
+	u8		num_of_ppdu[4];
+	u8		gid_num[4];
+#endif
+	u8		num_qry_beacon_pkt;
+	u8		show_phy_sts_all_pkt;	/*Show phy status witch not match BSSID*/
+	u16		show_phy_sts_max_cnt;	/*show number of phy-status row data per PHYDM watchdog*/
+	u16		show_phy_sts_cnt;
+	/* Others */
+	/*s32		rx_evm[4];*/
+	/*s8		rx_snr_db[4];*/
+
+	u16		num_qry_legacy_pkt[LEGACY_RATE_NUM];
+	u16		num_qry_ht_pkt[HT_RATE_NUM];
+	u16		num_qry_pkt_sc_20m[LOW_BW_RATE_NUM];	/*for 20M SC*/
+	boolean	ht_pkt_not_zero;
+	boolean	low_bw_20_occur;
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+	u16		num_qry_vht_pkt[VHT_RATE_NUM];
+	u16		num_qry_pkt_sc_40m[LOW_BW_RATE_NUM];	/*for 40M SC*/
+	boolean	vht_pkt_not_zero;
+	boolean	low_bw_40_occur;
+	#endif
+	struct phydm_phystatus_statistic	phystatus_statistic_info;
+	struct phydm_phystatus_avg	phystatus_statistic_avg;
+};
+
+enum odm_cmninfo {
+	/*Fixed value*/
+	/*-----------HOOK BEFORE REG INIT-----------*/
+	ODM_CMNINFO_PLATFORM = 0,
+	ODM_CMNINFO_ABILITY,
+	ODM_CMNINFO_INTERFACE,
+	ODM_CMNINFO_MP_TEST_CHIP,
+	ODM_CMNINFO_IC_TYPE,
+	ODM_CMNINFO_CUT_VER,
+	ODM_CMNINFO_FAB_VER,
+	ODM_CMNINFO_RF_TYPE,
+	ODM_CMNINFO_RFE_TYPE,
+	ODM_CMNINFO_DPK_EN,
+	ODM_CMNINFO_BOARD_TYPE,
+	ODM_CMNINFO_PACKAGE_TYPE,
+	ODM_CMNINFO_EXT_LNA,
+	ODM_CMNINFO_5G_EXT_LNA,
+	ODM_CMNINFO_EXT_PA,
+	ODM_CMNINFO_5G_EXT_PA,
+	ODM_CMNINFO_GPA,
+	ODM_CMNINFO_APA,
+	ODM_CMNINFO_GLNA,
+	ODM_CMNINFO_ALNA,
+	ODM_CMNINFO_EXT_TRSW,
+	ODM_CMNINFO_EXT_LNA_GAIN,
+	ODM_CMNINFO_PATCH_ID,
+	ODM_CMNINFO_BINHCT_TEST,
+	ODM_CMNINFO_BWIFI_TEST,
+	ODM_CMNINFO_SMART_CONCURRENT,
+	ODM_CMNINFO_CONFIG_BB_RF,
+	ODM_CMNINFO_DOMAIN_CODE_2G,
+	ODM_CMNINFO_DOMAIN_CODE_5G,
+	ODM_CMNINFO_IQKPAOFF,
+	ODM_CMNINFO_HUBUSBMODE,
+	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS,
+	ODM_CMNINFO_TX_TP,
+	ODM_CMNINFO_RX_TP,
+	ODM_CMNINFO_SOUNDING_SEQ,
+	ODM_CMNINFO_REGRFKFREEENABLE,
+	ODM_CMNINFO_RFKFREEENABLE,
+	ODM_CMNINFO_NORMAL_RX_PATH_CHANGE,
+	ODM_CMNINFO_EFUSE0X3D8,
+	ODM_CMNINFO_EFUSE0X3D7,
+	ODM_CMNINFO_SOFT_AP_SPECIAL_SETTING,
+	ODM_CMNINFO_ADVANCE_OTA,
+	ODM_CMNINFO_HP_HWID,
+	/*-----------HOOK BEFORE REG INIT-----------*/
+
+	/*Dynamic value:*/
+
+	/*--------- POINTER REFERENCE-----------*/
+	ODM_CMNINFO_TX_UNI,
+	ODM_CMNINFO_RX_UNI,
+	ODM_CMNINFO_BAND,
+	ODM_CMNINFO_SEC_CHNL_OFFSET,
+	ODM_CMNINFO_SEC_MODE,
+	ODM_CMNINFO_BW,
+	ODM_CMNINFO_CHNL,
+	ODM_CMNINFO_FORCED_RATE,
+	ODM_CMNINFO_ANT_DIV,
+	ODM_CMNINFO_ADAPTIVE_SOML,
+	ODM_CMNINFO_ADAPTIVITY,
+	ODM_CMNINFO_SCAN,
+	ODM_CMNINFO_POWER_SAVING,
+	ODM_CMNINFO_ONE_PATH_CCA,
+	ODM_CMNINFO_DRV_STOP,
+	ODM_CMNINFO_PNP_IN,
+	ODM_CMNINFO_INIT_ON,
+	ODM_CMNINFO_ANT_TEST,
+	ODM_CMNINFO_NET_CLOSED,
+	ODM_CMNINFO_P2P_LINK,
+	ODM_CMNINFO_FCS_MODE,
+	ODM_CMNINFO_IS1ANTENNA,
+	ODM_CMNINFO_RFDEFAULTPATH,
+	ODM_CMNINFO_DFS_MASTER_ENABLE,
+	ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC,
+	ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA,
+	ODM_CMNINFO_SOFT_AP_MODE,
+	ODM_CMNINFO_MP_MODE,
+	ODM_CMNINFO_INTERRUPT_MASK,
+	ODM_CMNINFO_BB_OPERATION_MODE,
+	ODM_CMNINFO_BF_ANTDIV_DECISION,
+	/*--------- POINTER REFERENCE-----------*/
+
+	/*------------CALL BY VALUE-------------*/
+	ODM_CMNINFO_WIFI_DIRECT,
+	ODM_CMNINFO_WIFI_DISPLAY,
+	ODM_CMNINFO_LINK_IN_PROGRESS,
+	ODM_CMNINFO_LINK,
+	ODM_CMNINFO_CMW500LINK,
+	ODM_CMNINFO_STATION_STATE,
+	ODM_CMNINFO_RSSI_MIN,
+	ODM_CMNINFO_RSSI_MIN_BY_PATH,
+	ODM_CMNINFO_DBG_COMP,
+	ODM_CMNINFO_DBG_LEVEL,
+	ODM_CMNINFO_RA_THRESHOLD_HIGH,	/*to be removed*/
+	ODM_CMNINFO_RA_THRESHOLD_LOW,	/*to be removed*/
+	ODM_CMNINFO_RF_ANTENNA_TYPE,
+	ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH,
+	ODM_CMNINFO_BE_FIX_TX_ANT,
+	ODM_CMNINFO_BT_ENABLED,
+	ODM_CMNINFO_BT_HS_CONNECT_PROCESS,
+	ODM_CMNINFO_BT_HS_RSSI,
+	ODM_CMNINFO_BT_OPERATION,
+	ODM_CMNINFO_BT_LIMITED_DIG,
+	ODM_CMNINFO_AP_TOTAL_NUM,
+	ODM_CMNINFO_POWER_TRAINING,
+	ODM_CMNINFO_DFS_REGION_DOMAIN,
+	ODM_CMNINFO_BT_CONTINUOUS_TURN,
+	/*------------CALL BY VALUE-------------*/
+
+	/*Dynamic ptr array hook itms.*/
+	ODM_CMNINFO_STA_STATUS,
+	ODM_CMNINFO_MAX,
+
+};
+
+enum phydm_rfe_bb_source_sel {
+	PAPE_2G	= 0,
+	PAPE_5G	= 1,
+	LNA0N_2G	= 2,
+	LNAON_5G	= 3,
+	TRSW		= 4,
+	TRSW_B		= 5,
+	GNT_BT		= 6,
+	ZERO		= 7,
+	ANTSEL_0	= 8,
+	ANTSEL_1	= 9,
+	ANTSEL_2	= 0xa,
+	ANTSEL_3	= 0xb,
+	ANTSEL_4	= 0xc,
+	ANTSEL_5	= 0xd,
+	ANTSEL_6	= 0xe,
+	ANTSEL_7	= 0xf
+};
+
+enum phydm_info_query {
+	PHYDM_INFO_FA_OFDM,
+	PHYDM_INFO_FA_CCK,
+	PHYDM_INFO_FA_TOTAL,
+	PHYDM_INFO_CCA_OFDM,
+	PHYDM_INFO_CCA_CCK,
+	PHYDM_INFO_CCA_ALL,
+	PHYDM_INFO_CRC32_OK_VHT,
+	PHYDM_INFO_CRC32_OK_HT,
+	PHYDM_INFO_CRC32_OK_LEGACY,
+	PHYDM_INFO_CRC32_OK_CCK,
+	PHYDM_INFO_CRC32_ERROR_VHT,
+	PHYDM_INFO_CRC32_ERROR_HT,
+	PHYDM_INFO_CRC32_ERROR_LEGACY,
+	PHYDM_INFO_CRC32_ERROR_CCK,
+	PHYDM_INFO_EDCCA_FLAG,
+	PHYDM_INFO_OFDM_ENABLE,
+	PHYDM_INFO_CCK_ENABLE,
+	PHYDM_INFO_CRC32_OK_HT_AGG,
+	PHYDM_INFO_CRC32_ERROR_HT_AGG,
+	PHYDM_INFO_DBG_PORT_0,
+	PHYDM_INFO_CURR_IGI,
+	PHYDM_INFO_RSSI_MIN,
+	PHYDM_INFO_RSSI_MAX,
+	PHYDM_INFO_CLM_RATIO,
+	PHYDM_INFO_NHM_RATIO,
+};
+
+enum phydm_api {
+	PHYDM_API_NBI			= 1,
+	PHYDM_API_CSI_MASK,
+
+};
+
+enum phydm_func_idx { /*F_XXX = PHYDM XXX function*/
+
+	F00_DIG			= 0,
+	F01_RA_MASK		= 1,
+	F02_DYN_TXPWR		= 2,
+	F03_FA_CNT			= 3,
+	F04_RSSI_MNTR		= 4,
+	F05_CCK_PD			= 5,
+	F06_ANT_DIV		= 6,
+	F07_SMT_ANT		= 7,
+	F08_PWR_TRAIN		= 8,
+	F09_RA				= 9,
+	F10_PATH_DIV		= 10,
+	F11_DFS			= 11,
+	F12_DYN_ARFR		= 12,
+	F13_ADPTVTY		= 13,
+	F14_CFO_TRK		= 14,
+	F15_ENV_MNTR		= 15,
+	F16_PRI_CCA		= 16,
+	F17_ADPTV_SOML	= 17,
+	F18_LNA_SAT_CHK	= 18,
+	F19_DYN_RX_PATH	= 19
+};
+
+/*=[PHYDM supportability]==========================================*/
+enum odm_ability {
+	ODM_BB_DIG				= BIT(F00_DIG),
+	ODM_BB_RA_MASK			= BIT(F01_RA_MASK),
+	ODM_BB_DYNAMIC_TXPWR	= BIT(F02_DYN_TXPWR),
+	ODM_BB_FA_CNT				= BIT(F03_FA_CNT),
+	ODM_BB_RSSI_MONITOR		= BIT(F04_RSSI_MNTR),
+	ODM_BB_CCK_PD				= BIT(F05_CCK_PD),
+	ODM_BB_ANT_DIV			= BIT(F06_ANT_DIV),
+	ODM_BB_SMT_ANT			= BIT(F07_SMT_ANT),
+	ODM_BB_PWR_TRAIN			= BIT(F08_PWR_TRAIN),
+	ODM_BB_RATE_ADAPTIVE		= BIT(F09_RA),
+	ODM_BB_PATH_DIV			= BIT(F10_PATH_DIV),
+	ODM_BB_DFS				= BIT(F11_DFS),
+	ODM_BB_DYNAMIC_ARFR		= BIT(F12_DYN_ARFR),
+	ODM_BB_ADAPTIVITY			= BIT(F13_ADPTVTY),
+	ODM_BB_CFO_TRACKING		= BIT(F14_CFO_TRK),
+	ODM_BB_ENV_MONITOR		= BIT(F15_ENV_MNTR),
+	ODM_BB_PRIMARY_CCA		= BIT(F16_PRI_CCA),
+	ODM_BB_ADAPTIVE_SOML		= BIT(F17_ADPTV_SOML),
+	ODM_BB_LNA_SAT_CHK		= BIT(F18_LNA_SAT_CHK),
+	ODM_BB_DYNAMIC_RX_PATH	= BIT(F19_DYN_RX_PATH)
+};
+
+/*=[PHYDM Debug Component]=====================================*/
+enum phydm_dbg_comp {
+	/*BB Driver Functions*/
+	DBG_DIG			= BIT(F00_DIG),
+	DBG_RA_MASK		= BIT(F01_RA_MASK),
+	DBG_DYN_TXPWR	= BIT(F02_DYN_TXPWR),
+	DBG_FA_CNT		= BIT(F03_FA_CNT),
+	DBG_RSSI_MNTR		= BIT(F04_RSSI_MNTR),
+	DBG_CCKPD			= BIT(F05_CCK_PD),
+	DBG_ANT_DIV		= BIT(F06_ANT_DIV),
+	DBG_SMT_ANT		= BIT(F07_SMT_ANT),
+	DBG_PWR_TRAIN		= BIT(F08_PWR_TRAIN),
+	DBG_RA				= BIT(F09_RA),
+	DBG_PATH_DIV		= BIT(F10_PATH_DIV),
+	DBG_DFS			= BIT(F11_DFS),
+	DBG_DYN_ARFR		= BIT(F12_DYN_ARFR),
+	DBG_ADPTVTY		= BIT(F13_ADPTVTY),
+	DBG_CFO_TRK		= BIT(F14_CFO_TRK), 
+	DBG_ENV_MNTR		= BIT(F15_ENV_MNTR),
+	DBG_PRI_CCA		= BIT(F16_PRI_CCA),
+	DBG_ADPTV_SOML	= BIT(F17_ADPTV_SOML),
+	DBG_LNA_SAT_CHK	= BIT(F18_LNA_SAT_CHK),
+	DBG_DYN_RX_PATH	= BIT(F19_DYN_RX_PATH),
+	/*Neet to re-arrange*/
+	DBG_PHY_STATUS	= BIT(20),
+	DBG_TMP			= BIT(21),
+	DBG_FW_TRACE		= BIT(22),
+	DBG_TXBF			= BIT(23),
+	DBG_COMMON_FLOW	= BIT(24),
+	ODM_COMP_TX_PWR_TRACK	= BIT(25),
+	ODM_COMP_CALIBRATION		= BIT(26),
+	ODM_COMP_MP		= BIT(27),
+	ODM_PHY_CONFIG	= BIT(28),
+	ODM_COMP_INIT		= BIT(29),
+	ODM_COMP_COMMON	= BIT(30),
+	ODM_COMP_API		= BIT(31)
+};
+
+/*=========================================================*/
+
+/*ODM_CMNINFO_ONE_PATH_CCA*/
+enum odm_cca_path {
+	ODM_CCA_2R		= 0,
+	ODM_CCA_1R_A		= 1,
+	ODM_CCA_1R_B		= 2,
+};
+
+enum phy_reg_pg_type {
+	PHY_REG_PG_RELATIVE_VALUE	= 0,
+	PHY_REG_PG_EXACT_VALUE		= 1
+};
+
+enum phydm_offload_ability {
+	PHYDM_PHY_PARAM_OFFLOAD = BIT(0),
+	PHYDM_RF_IQK_OFFLOAD = BIT(1),
+};
+
+struct phydm_pause_lv {
+	s8	lv_dig;
+	s8	lv_cckpd;
+	s8	lv_antdiv;
+	s8	lv_adapt;
+};
+
+struct phydm_func_poiner {
+	void	(*pause_phydm_handler)(void	 *dm_void, u32 *val_buf, u8 val_len);
+};
+
+struct pkt_process_info {
+	u8	phystatus_smp_mode_en; /*send phystatus every sampling time*/
+	u8	pre_ppdu_cnt;
+	u8	lna_idx;
+	u8	vga_idx;
+};
+
+#ifdef ODM_CONFIG_BT_COEXIST
+struct	phydm_bt_info {
+	boolean		is_bt_enabled;			/*BT is enabled*/
+	boolean		is_bt_connect_process;	/*BT HS is under connection progress.*/
+	u8			bt_hs_rssi;				/*BT HS mode wifi rssi value.*/
+	boolean		is_bt_hs_operation;		/*BT HS mode is under progress*/
+	boolean		is_bt_limited_dig;		/*BT is busy.*/
+};
+#endif
+
+struct	phydm_iot_center {
+	boolean		is_linked_cmw500;
+	u8			win_patch_id;		/*Customer ID*/
+	u32			phydm_patch_id;
+
+};
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	#if (RT_PLATFORM != PLATFORM_LINUX)
+		typedef
+	#endif
+
+	struct dm_struct
+#else/*for AP, CE Team*/
+	struct dm_struct
+#endif
+{
+	/*Add for different team use temporarily*/
+	void		*adapter;		/*For CE/NIC team*/
+	struct rtl8192cd_priv	*priv;			/*For AP team*/
+	/*WHen you use adapter or priv pointer, you must make sure the pointer is ready.*/
+	boolean		odm_ready;
+	enum phy_reg_pg_type	phy_reg_pg_value_type;
+	u8			phy_reg_pg_version;
+	u64			support_ability;	/*PHYDM function Supportability*/
+	u64			pause_ability;	/*PHYDM function pause Supportability*/
+	u64			debug_components;
+	u8			cmn_dbg_msg_period;
+	u8			cmn_dbg_msg_cnt;
+	u32			fw_debug_components;
+	u32			debug_level;
+	u32			num_qry_phy_status_all;		/*CCK + OFDM*/
+	u32			last_num_qry_phy_status_all;
+	u32			rx_pwdb_ave;
+	boolean		is_init_hw_info_by_rfe;
+
+	/*------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
+	boolean		is_cck_high_power;
+	u8			rf_path_rx_enable;
+	/*------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
+
+	/* COMMON INFORMATION */
+
+	/*Init value*/
+	/*-----------HOOK BEFORE REG INIT-----------*/
+
+	u8			support_platform;/*PHYDM Platform info WIN/AP/CE = 1/2/3 */
+	u8			normal_rx_path;	
+	boolean		brxagcswitch; /* for rx AGC table switch in Microsoft case */
+	u8			support_interface;/*PHYDM PCIE/USB/SDIO = 1/2/3*/
+	u32			support_ic_type;	/*PHYDM supported IC*/
+	u8			cut_version;		/*cut version TestChip/A-cut/B-cut... = 0/1/2/3/...*/
+	u8			fab_version;		/*Fab version TSMC/UMC = 0/1*/
+	u8			rf_type;			/*RF type 4T4R/3T3R/2T2R/1T2R/1T1R/...*/
+	u8			rfe_type;
+	u8			board_type;
+	u8			package_type;
+	u16			type_glna;
+	u16			type_gpa;
+	u16			type_alna;
+	u16			type_apa;
+	u8			ext_lna;			/*with 2G external LNA  NO/Yes = 0/1*/
+	u8			ext_lna_5g;		/*with 5G external LNA  NO/Yes = 0/1*/
+	u8			ext_pa;			/*with 2G external PNA  NO/Yes = 0/1*/
+	u8			ext_pa_5g;		/*with 5G external PNA  NO/Yes = 0/1*/
+	u8 			efuse0x3d7;		/*with Efuse number*/
+	u8 			efuse0x3d8;
+	u8			ext_trsw;		/*with external TRSW  NO/Yes = 0/1*/
+	u8			ext_lna_gain;	/*gain of external lna*/
+	boolean		is_in_hct_test;
+	u8			wifi_test;
+	boolean		is_dual_mac_smart_concurrent;
+	u32			bk_support_ability; /*SD4 only*/
+	u8			with_extenal_ant_switch;
+	/*cck agc relative*/
+	boolean		cck_new_agc;
+	s8			cck_lna_gain_table[8];
+	/*-------------------------------------*/
+	u32			phydm_sys_up_time;
+	u8			num_rf_path; /*ex: 8821C=1, 8192E=2, 8814B=4*/
+	u32			soft_ap_special_setting;
+	s8			s8_dummy;
+	u8			u8_dummy;
+	u16			u16_dummy;
+	u32			u32_dummy;
+	u8			rfe_hwsetting_band;
+	u8			p_advance_ota;
+	boolean		hp_hw_id;
+	boolean		BOOLEAN_temp;
+	boolean		is_dfs_band;
+	u8			is_receiver_blocking_en;
+	u16			fw_offload_ability;
+/*-----------HOOK BEFORE REG INIT-----------*/
+/*===========================================================*/	
+/*====[ CALL BY Reference ]=========================================*/
+/*===========================================================*/	
+
+	u64			*num_tx_bytes_unicast;	/*TX Unicast byte count*/
+	u64			*num_rx_bytes_unicast;	/*RX Unicast byte count*/
+	u8			*band_type;				/*Frequence band 2.4G/5G = 0/1*/
+	u8			*sec_ch_offset;			/*Secondary channel offset don't_care/below/above = 0/1/2*/
+	u8			*security;					/*security mode Open/WEP/AES/TKIP = 0/1/2/3*/
+	u8			*band_width;				/*BW info 20M/40M/80M = 0/1/2*/
+	u8			*channel;					/*central channel number*/
+	boolean		*is_scan_in_process;		/*Common info for status*/
+	boolean		*is_power_saving;
+	u8			*one_path_cca;			/*CCA path 2-path/path-A/path-B = 0/1/2; using enum odm_cca_path.*/
+	u8			*antenna_test;
+	boolean		*is_net_closed;
+	boolean		*is_fcs_mode_enable;
+	/*--------- For 8723B IQK-------------------------------------*/
+	boolean		*is_1_antenna;
+	u8			*rf_default_path;	/* 0:S1, 1:S0 */
+	/*-----------------------------------------------------------*/
+
+	u16			*forced_data_rate;
+	u8			*enable_antdiv;
+	u8			*en_adap_soml;
+	u8			*enable_adaptivity;
+	u8			*hub_usb_mode;		/*1: USB 2.0, 2: USB 3.0*/
+	boolean			*is_fw_dw_rsvd_page_in_progress;
+	u32			*current_tx_tp;
+	u32			*current_rx_tp;
+	u8			*sounding_seq;
+	u32			*soft_ap_mode;
+	u8			*mp_mode;
+	u32			*interrupt_mask;
+	u8			*bb_op_mode;
+/*===========================================================*/	
+/*====[ CALL BY VALUE ]===========================================*/
+/*===========================================================*/	
+
+	u8			disable_phydm_watchdog;
+	boolean		is_link_in_process;
+	boolean		is_wifi_direct;
+	boolean		is_wifi_display;
+	boolean		is_linked;
+	boolean		bsta_state;
+	u8			rssi_min;
+	u8			pre_rssi_min;
+	u8			rssi_max;
+	u8			rssi_min_by_path;
+	boolean		is_mp_chip;
+	boolean		is_one_entry_only;
+	u32			one_entry_macid;
+	u32			one_entry_tp;
+	u32			pre_one_entry_tp;
+	u8			pre_number_linked_client;
+	u8			number_linked_client;
+	u8			pre_number_active_client;
+	u8			number_active_client;
+	boolean		is_disable_phy_api;
+	u8			rssi_a;
+	u8			rssi_b;
+	u8			rssi_c;
+	u8			rssi_d;
+	u64			rssi_trsw;
+	u64			rssi_trsw_h;
+	u64			rssi_trsw_l;
+	u64			rssi_trsw_iso;
+	u8			tx_ant_status;
+	u8			rx_ant_status;
+	u8			cck_lna_idx;
+	u8			cck_vga_idx;
+	u8			curr_station_id;
+	u8			ofdm_agc_idx[4];
+	u8			rx_rate;
+	u8			rate_ss;
+	u8			tx_rate;
+	u8			linked_interval;
+	u8			pre_channel;
+	u32			txagc_offset_value_a;
+	boolean		is_txagc_offset_positive_a;
+	u32			txagc_offset_value_b;
+	boolean		is_txagc_offset_positive_b;
+	/*[traffic]*/
+	u8			traffic_load;
+	u8			pre_traffic_load;
+	u32			tx_tp;	/*Mbps*/
+	u32			rx_tp;	/*Mbps*/
+	u32			total_tp;/*Mbps*/
+	u8			txrx_state_all;	/*0: tx, 1:rx, 2:bi-direction*/
+	u64			cur_tx_ok_cnt;
+	u64			cur_rx_ok_cnt;
+	u64			last_tx_ok_cnt;
+	u64			last_rx_ok_cnt;
+	u16			consecutive_idlel_time;	/*unit: second*/
+	/*---------------------------*/
+	boolean		is_bb_swing_offset_positive_a;
+	boolean		is_bb_swing_offset_positive_b;
+
+	/*[DIG]*/
+	boolean		MPDIG_2G;				/*off MPDIG*/
+	u8			times_2g;	/*for MP DIG*/
+
+	/*[TDMA-DIG]*/
+	u8			tdma_dig_timer_ms;
+	u8			tdma_dig_state_number;
+	u8			tdma_dig_low_upper_bond;
+	u8			fix_expire_to_zero;
+	boolean		original_dig_restore;
+	/*---------------------------*/
+
+	/*[AntDiv]*/
+	u8			ant_div_type;
+	u8			antdiv_rssi;
+	u8			fat_comb_a;
+	u8			fat_comb_b;
+	u8			antdiv_intvl;
+	u8			ant_type;
+	u8			pre_ant_type;
+	u8			antdiv_period;
+	u8			evm_antdiv_period;
+	u8			antdiv_select;
+	u8			antdiv_train_num;/*training time for each antenna in EVM method*/
+	u8			stop_antdiv_rssi_th;
+	u16			stop_antdiv_tp_diff_th;
+	u16			stop_antdiv_tp_th;
+	u8			antdiv_tp_period;
+	u16			tp_active_th;
+	u8			tp_active_occur;
+	u8			path_select;
+	u8			antdiv_evm_en;
+	u8			bdc_holdstate;
+	/*---------------------------*/
+	
+	u8			ndpa_period;
+	boolean		h2c_rarpt_connect;
+	boolean		cck_agc_report_type;
+	u8			print_agc;
+	u8			la_mode;
+	/*---8821C Antenna and RF Set BTG/WLG/WLA Select---------------*/
+	u8			current_rf_set_8821c;
+	u8			default_rf_set_8821c;
+	u8			current_ant_num_8821c;
+	u8			default_ant_num_8821c;
+	u8			rfe_type_expand;
+	/*-----------------------------------------------------------*/
+	/*---For Adaptivtiy---------------------------------------------*/
+	s8			TH_L2H_default;
+	s8			th_edcca_hl_diff_default;
+	s8			th_l2h_ini;
+	s8			th_edcca_hl_diff;
+	s8			th_l2h_ini_mode2;
+	s8			th_edcca_hl_diff_mode2;
+	boolean		carrier_sense_enable;
+	boolean		adaptivity_flag;	/*Limit IGI upper bound for Adaptivity*/
+	u8			dc_backoff;
+	boolean		adaptivity_enable;
+	u8			ap_total_num;
+	boolean		edcca_enable;
+	u8			odm_regulation_2_4g;
+	u8			odm_regulation_5g;
+	/*-----------------------------------------------------------*/
+	
+	u8			pre_dbg_priority;
+	u8			nbi_set_result;
+	u8			c2h_cmd_start;
+	u8			fw_debug_trace[60];
+	u8			pre_c2h_seq;
+	boolean		fw_buff_is_enpty;
+	u32			data_frame_num;
+
+	/*--- for noise detection ---------------------------------------*/
+	boolean		is_noisy_state;
+	boolean		noisy_decision; /*b_noisy*/
+	boolean		pre_b_noisy;
+	u32			noisy_decision_smooth;
+	u8			lna_sat_chk_cnt;
+	u8			lna_sat_chk_duty_cycle;
+	u32			lna_sat_chk_period_ms;
+	boolean		is_disable_lna_sat_chk;
+	boolean		is_disable_gain_table_switch;
+	/*-----------------------------------------------------------*/
+	
+	boolean		is_disable_dym_ecs;
+	boolean		is_disable_dym_ant_weighting;
+	struct sta_info	*odm_sta_info[ODM_ASSOCIATE_ENTRY_NUM];/*odm_sta_info, 2012/01/12 MH For MP, we need to reduce one array pointer for default port.??*/
+	struct cmn_sta_info	*phydm_sta_info[ODM_ASSOCIATE_ENTRY_NUM];
+	u8			phydm_macid_table[ODM_ASSOCIATE_ENTRY_NUM];
+
+#if (RATE_ADAPTIVE_SUPPORT == 1)
+	u16			currmin_rpt_time;
+	struct _odm_ra_info_   ra_info[ODM_ASSOCIATE_ENTRY_NUM];
+	/*Use mac_id as array index. STA mac_id=0, VWiFi Client mac_id={1, ODM_ASSOCIATE_ENTRY_NUM-1} //YJ,add,120119*/
+#endif
+	boolean		ra_support88e;	/*2012/02/14 MH Add to share 88E ra with other SW team.We need to colelct all support abilit to a proper area.*/
+	boolean		*is_driver_stopped;
+	boolean		*is_driver_is_going_to_pnp_set_power_sleep;
+	boolean		*pinit_adpt_in_progress;
+	boolean		is_user_assign_level;
+	u8			RSSI_BT;			/*come from BT*/
+
+	/*---PSD Relative ---------------------------------------------*/
+	boolean		is_psd_in_process;
+	boolean		is_psd_active;
+	/*-----------------------------------------------------------*/
+	
+	boolean		bsomlenabled;		/* for dynamic SoML control */
+	boolean		bhtstfdisabled;		/* for dynamic HTSTF gain control	*/
+	boolean		disrxhpsoml;			/* for dynamic RxHP control with SoML on/off */
+	u32			n_iqk_cnt;
+	u32			n_iqk_ok_cnt;
+	u32			n_iqk_fail_cnt;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	boolean		config_bbrf;
+#endif
+	boolean		is_disable_power_training;
+	boolean		is_bt_continuous_turn;
+	u8			dynamic_tx_high_power_lvl;
+	u8			last_dtp_lvl;
+	u8			min_power_index;
+	u32			tx_agc_ofdm_18_6;
+	u8			rx_pkt_type;
+
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	u8			dfs_region_domain;
+	u8			*dfs_master_enabled;
+	/*---phydm_radar_detect_with_dbg_parm start --------------------*/
+	u8			radar_detect_dbg_parm_en;
+	u32			radar_detect_reg_918;
+	u32			radar_detect_reg_91c;
+	u32			radar_detect_reg_920;
+	u32			radar_detect_reg_924;
+	/*-----------------------------------------------------------*/
+#endif
+
+/*=== PHYDM Timer ========================================== (start)*/
+
+	struct phydm_timer_list	mpt_dig_timer;	/*MPT DIG timer*/
+	struct phydm_timer_list	path_div_switch_timer;
+	struct phydm_timer_list	cck_path_diversity_timer;	/*2011.09.27 add for path Diversity*/
+	struct phydm_timer_list	fast_ant_training_timer;
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	struct phydm_timer_list	evm_fast_ant_training_timer;
+#endif
+	struct phydm_timer_list	sbdcnt_timer;
+
+
+/*=== PHYDM Workitem ======================================= (start)*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	path_div_switch_workitem;
+	RT_WORK_ITEM	cck_path_diversity_workitem;
+	RT_WORK_ITEM	fast_ant_training_workitem;
+	RT_WORK_ITEM	ra_rpt_workitem;
+	RT_WORK_ITEM	sbdcnt_workitem;
+#endif
+#endif
+
+
+/*=== PHYDM Structure ======================================== (start)*/
+	struct	phydm_func_poiner			phydm_func_handler;
+	struct	phydm_iot_center				iot_table;
+
+#ifdef ODM_CONFIG_BT_COEXIST
+	struct	phydm_bt_info				bt_info_table;
+#endif
+
+	struct	pkt_process_info				pkt_proc_struct;
+	struct phydm_adaptivity_struct			adaptivity;
+	struct _DFS_STATISTICS				dfs;
+
+	struct odm_noise_monitor			noise_level;
+
+	struct odm_phy_dbg_info				phy_dbg_info;
+
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct adaptive_soml					dm_soml_table;
+#endif
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct _BF_DIV_COEX_					dm_bdc_table;
+	#endif
+
+	#if (defined(CONFIG_HL_SMART_ANTENNA))
+	struct smt_ant_honbo					dm_sat_table;
+	#endif
+#endif
+
+#if (defined(CONFIG_SMART_ANTENNA))
+	struct smt_ant						smtant_table;
+#endif
+
+	struct phydm_fat_struct				dm_fat_table;
+	struct phydm_dig_struct				dm_dig_table;
+	struct phydm_lna_sat_info_struct		dm_lna_sat_info;
+
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct phydm_cckpd_struct				dm_cckpd_table;
+#endif
+	
+#ifdef PHYDM_PRIMARY_CCA
+	struct phydm_pricca_struct				dm_pri_cca;
+#endif
+
+	struct ra_table			dm_ra_table;
+	struct phydm_fa_struct					false_alm_cnt;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct				false_alm_cnt_acc;
+#endif
+	struct sw_antenna_switch				dm_swat_table;
+	struct phydm_cfo_track_struct			dm_cfo_track;
+	struct ccx_info						dm_ccx_info;
+	struct _hal_rf_						rf_table; 		/*for HALRF function*/
+	struct dm_rf_calibration_struct		rf_calibrate_info;
+	struct odm_power_trim_data			power_trim_data;	
+#if (RTL8822B_SUPPORT == 1)
+	struct drp_rtl8822b_struct				phydm_rtl8822b;
+#endif
+
+#ifdef CONFIG_PSD_TOOL
+	struct psd_info					dm_psd_table;
+#endif
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	struct rt_adcsmp					adcsmp;
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	struct _DYNAMIC_RX_PATH_			dm_drp_table;
+#endif
+
+	struct dm_iqk_info				IQK_info;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct _path_div_parameter_define_		path_iqk;
+#endif
+
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct _ODM_PATH_DIVERSITY_			dm_path_div;
+#endif
+
+#if (defined(CONFIG_ANT_DETECTION))
+	struct _ANT_DETECTED_INFO			ant_detected_info;	/* Antenna detected information for RSSI tool*/
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	struct _RT_BEAMFORMING_INFO 		beamforming_info;
+#endif
+#endif
+#ifdef PHYDM_AUTO_DEGBUG
+	struct	phydm_auto_dbg_struc			auto_dbg_table;
+#endif
+
+	struct	phydm_pause_lv				pause_lv_table;	
+	struct	phydm_api_stuc 				api_table;
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+	struct	phydm_pow_train_stuc			pow_train_table;
+#endif
+/*==========================================================*/
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#if (RT_PLATFORM != PLATFORM_LINUX)
+}dm_struct;		/*DM_Dynamic_Mechanism_Structure*/
+#else
+};
+#endif
+
+#else	/*for AP,CE Team*/
+};
+#endif
+
+enum phydm_adv_ota {
+	PHYDM_PATHB_1RCCA = BIT(0),
+	PHYDM_HP_OTA_SETTING_A = BIT(1),
+	PHYDM_HP_OTA_SETTING_B = BIT(2),
+	PHYDM_ASUS_OTA_SETTING = BIT(3),
+	PHYDM_ASUS_OTA_SETTING_CCK_PATH = BIT(4),
+	PHYDM_HP_OTA_SETTING_CCK_PATH = BIT(5),
+	PHYDM_LENOVO_OTA_SETTING_NBI_CSI = BIT(6),
+
+};
+
+enum phydm_bb_op_mode {
+	PHYDM_PERFORMANCE_MODE = 0,	/*Service one device*/
+	PHYDM_BALANCE_MODE = 1,		/*Service more than one device*/
+};
+
+enum phydm_structure_type {
+	PHYDM_FALSEALMCNT,
+	PHYDM_CFOTRACK,
+	PHYDM_ADAPTIVITY,
+	PHYDM_DFS,
+	PHYDM_ROMINFO,
+
+};
+
+enum odm_bb_config_type {
+	CONFIG_BB_PHY_REG,
+	CONFIG_BB_AGC_TAB,
+	CONFIG_BB_AGC_TAB_2G,
+	CONFIG_BB_AGC_TAB_5G,
+	CONFIG_BB_PHY_REG_PG,
+	CONFIG_BB_PHY_REG_MP,
+	CONFIG_BB_AGC_TAB_DIFF,
+};
+
+enum odm_rf_config_type {
+	CONFIG_RF_RADIO,
+	CONFIG_RF_TXPWR_LMT,
+};
+
+enum odm_fw_config_type {
+	CONFIG_FW_NIC,
+	CONFIG_FW_NIC_2,
+	CONFIG_FW_AP,
+	CONFIG_FW_AP_2,
+	CONFIG_FW_MP,
+	CONFIG_FW_WOWLAN,
+	CONFIG_FW_WOWLAN_2,
+	CONFIG_FW_AP_WOWLAN,
+	CONFIG_FW_BT,
+};
+
+/*status code*/
+#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
+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,
+};
+#endif	/*end of enum rt_status definition*/
+
+void
+phydm_watchdog_lps(
+	struct dm_struct	*dm
+);
+
+void
+phydm_watchdog_lps_32k(
+	struct dm_struct	*dm
+);
+
+void
+phydm_txcurrentcalibration(
+	struct dm_struct	*dm
+);	
+
+void
+phydm_dm_early_init(
+	struct dm_struct	*dm
+);
+
+void
+odm_dm_init(
+	struct dm_struct	*dm
+);
+
+void
+odm_dm_reset(
+	struct dm_struct	*dm
+);
+
+void
+phydm_fwoffload_ability_init(
+	struct dm_struct	*dm,
+	enum phydm_offload_ability	offload_ability
+);
+
+void
+phydm_fwoffload_ability_clear(
+	struct dm_struct	*dm,
+	enum phydm_offload_ability	offload_ability
+);
+
+void
+phydm_support_ability_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_pause_dm_watchdog(
+	void					*dm_void,
+	enum phydm_pause_type	pause_type
+);
+
+void
+phydm_watchdog(
+	struct dm_struct	*dm
+);
+
+void
+phydm_watchdog_mp(
+	struct dm_struct	*dm
+);
+
+u8
+phydm_pause_func(
+	void					*dm_void,
+	enum phydm_func_idx	pause_func,	
+	enum phydm_pause_type	pause_type,
+	enum phydm_pause_level	pause_lv,
+	u8						val_lehgth,
+	u32						*val_buf
+	
+);
+
+void
+phydm_pause_func_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+void
+odm_cmn_info_init(
+	struct dm_struct	*dm,
+	enum odm_cmninfo		cmn_info,
+	u64						value
+);
+
+void
+odm_cmn_info_hook(
+	struct dm_struct	*dm,
+	enum odm_cmninfo		cmn_info,
+	void						*value
+);
+
+void
+odm_cmn_info_update(
+	struct dm_struct	*dm,
+	u32						cmn_info,
+	u64						value
+);
+
+u32
+phydm_cmn_info_query(
+	struct dm_struct	*dm,
+	enum phydm_info_query	info_type
+);
+
+void
+odm_init_all_timers(
+	struct dm_struct	*dm
+);
+
+void
+odm_cancel_all_timers(
+	struct dm_struct	*dm
+);
+
+void
+odm_release_all_timers(
+	struct dm_struct	*dm
+);
+
+void *
+phydm_get_structure(
+	struct dm_struct	*dm,
+	u8			structure_type
+);
+
+void
+phydm_dc_cancellation(
+	struct	dm_struct	*dm
+);
+
+void
+phydm_receiver_blocking(
+	void *dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void 
+odm_init_all_work_items(
+	struct dm_struct	*dm
+);
+void 
+odm_free_all_work_items(
+	struct dm_struct	*dm
+);
+#endif	/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void 
+odm_dtc(
+	struct dm_struct	*dm
+);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+void
+odm_init_all_threads(
+	struct dm_struct	*dm
+);
+
+void
+odm_stop_all_threads(
+	struct dm_struct	*dm
+);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.mk b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.mk
new file mode 100644
index 000000000000..1b9ade78a68f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm.mk
@@ -0,0 +1,166 @@
+EXTRA_CFLAGS += -I$(src)/hal/phydm
+
+_PHYDM_FILES := hal/phydm/phydm_debug.o	\
+								hal/phydm/phydm_antdiv.o\
+								hal/phydm/phydm_soml.o\
+								hal/phydm/phydm_smt_ant.o\
+								hal/phydm/phydm_antdect.o\
+								hal/phydm/phydm_interface.o\
+								hal/phydm/phydm_phystatus.o\
+								hal/phydm/phydm_hwconfig.o\
+								hal/phydm/phydm.o\
+								hal/phydm/phydm_dig.o\
+								hal/phydm/phydm_pathdiv.o\
+								hal/phydm/phydm_rainfo.o\
+								hal/phydm/phydm_dynamictxpower.o\
+								hal/phydm/phydm_adaptivity.o\
+								hal/phydm/phydm_cfotracking.o\
+								hal/phydm/phydm_noisemonitor.o\
+								hal/phydm/phydm_beamforming.o\
+								hal/phydm/phydm_dfs.o\
+								hal/phydm/txbf/halcomtxbf.o\
+								hal/phydm/txbf/haltxbfinterface.o\
+								hal/phydm/txbf/phydm_hal_txbf_api.o\
+								hal/phydm/phydm_adc_sampling.o\
+								hal/phydm/phydm_ccx.o\
+								hal/phydm/phydm_psd.o\
+								hal/phydm/phydm_primary_cca.o\
+								hal/phydm/phydm_cck_pd.o\
+								hal/phydm/phydm_rssi_monitor.o\
+								hal/phydm/phydm_auto_dbg.o\
+								hal/phydm/phydm_math_lib.o\
+								hal/phydm/phydm_api.o\
+								hal/phydm/phydm_pow_train.o\
+								hal/phydm/halrf/halrf.o\
+								hal/phydm/halrf/halphyrf_ce.o\
+								hal/phydm/halrf/halrf_powertracking_ce.o\
+								hal/phydm/halrf/halrf_powertracking.o\
+								hal/phydm/halrf/halrf_kfree.o
+		
+ifeq ($(CONFIG_RTL8188E), y)
+RTL871X = rtl8188e
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8188e_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8188e_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8188e_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8188e_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8188e.o\
+								hal/phydm/$(RTL871X)/hal8188erateadaptive.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8188e.o
+endif
+
+ifeq ($(CONFIG_RTL8192E), y)
+RTL871X = rtl8192e
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8192e_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8192e_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8192e_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8192e_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8192e.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8192e.o
+endif
+
+
+ifeq ($(CONFIG_RTL8812A), y)
+RTL871X = rtl8812a
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8812a_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8812a_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8812a_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8812a_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8812a.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8812a.o\
+								hal/phydm/txbf/haltxbfjaguar.o
+endif
+
+ifeq ($(CONFIG_RTL8821A), y)
+RTL871X = rtl8821a
+_PHYDM_FILES += hal/phydm/rtl8821a/halhwimg8821a_mac.o\
+								hal/phydm/rtl8821a/halhwimg8821a_bb.o\
+								hal/phydm/rtl8821a/halhwimg8821a_rf.o\
+								hal/phydm/halrf/rtl8812a/halrf_8812a_ce.o\
+								hal/phydm/halrf/rtl8821a/halrf_8821a_ce.o\
+								hal/phydm/rtl8821a/phydm_regconfig8821a.o\
+								hal/phydm/rtl8821a/phydm_rtl8821a.o\
+								hal/phydm/halrf/rtl8821a/halrf_iqk_8821a_ce.o\
+								hal/phydm/txbf/haltxbfjaguar.o
+endif
+
+
+ifeq ($(CONFIG_RTL8723B), y)
+RTL871X = rtl8723b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8723b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_rf.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_mp.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8723b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8723b_ce.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8723b.o
+endif
+
+
+ifeq ($(CONFIG_RTL8814A), y)
+RTL871X = rtl8814a
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8814a_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8814a_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8814a_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8814a.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8814a.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8814a_ce.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8814a.o\
+								hal/phydm/txbf/haltxbf8814a.o
+endif
+
+
+ifeq ($(CONFIG_RTL8723C), y)
+RTL871X = rtl8703b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8703b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8703b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8703b_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8703b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8703b.o
+endif
+
+ifeq ($(CONFIG_RTL8723D), y)
+RTL871X = rtl8723d
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8723d_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8723d_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8723d_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8723d.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8723d.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8723d.o
+endif
+
+
+ifeq ($(CONFIG_RTL8188F), y)
+RTL871X = rtl8188f
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8188f_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8188f_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8188f_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8188f.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8188f.o \
+								hal/phydm/$(RTL871X)/phydm_rtl8188f.o
+endif
+
+ifeq ($(CONFIG_RTL8822B), y)
+RTL871X = rtl8822b
+_PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8822b_bb.o \
+								hal/phydm/$(RTL871X)/halhwimg8822b_mac.o \
+								hal/phydm/$(RTL871X)/halhwimg8822b_rf.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_8822b.o \
+								hal/phydm/$(RTL871X)/phydm_hal_api8822b.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8822b.o \
+								hal/phydm/$(RTL871X)/phydm_regconfig8822b.o \
+								hal/phydm/$(RTL871X)/phydm_rtl8822b.o
+
+_PHYDM_FILES +=	hal/phydm/txbf/haltxbf8822b.o
+endif
+
+
+ifeq ($(CONFIG_RTL8821C), y)
+RTL871X = rtl8821c
+_PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8821c_bb.o \
+								hal/phydm/$(RTL871X)/halhwimg8821c_mac.o \
+								hal/phydm/$(RTL871X)/halhwimg8821c_rf.o \
+								hal/phydm/$(RTL871X)/phydm_hal_api8821c.o \
+								hal/phydm/$(RTL871X)/phydm_regconfig8821c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8821c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8821c.o
+endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_acs.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_acs.c
new file mode 100644
index 000000000000..de49bb3aebd4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_acs.c
@@ -0,0 +1,1152 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+u8
+odm_get_auto_channel_select_result(
+	void			*dm_void,
+	u8			band
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct acs_info					*acs = &dm->dm_acs;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (band == ODM_BAND_2_4G) {
+		PHYDM_DBG(dm, ODM_COMP_API, "clean_CH_2g=%d\n", acs->clean_channel_2g);
+		return (u8)acs->clean_channel_2g;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "clean_CH_5g=%d\n", acs->clean_channel_5g);
+		return (u8)acs->clean_channel_5g;
+	}
+#else
+	return (u8)acs->clean_channel_2g;
+#endif
+
+}
+
+void
+odm_auto_channel_select_init(
+	void			*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct acs_info						*acs = &dm->dm_acs;
+	u8						i;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	if (acs->is_force_acs_result)
+		return;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	acs->clean_channel_2g = 1;
+	acs->clean_channel_5g = 36;
+
+	for (i = 0; i < ODM_MAX_CHANNEL_2G; ++i) {
+		acs->channel_info_2g[0][i] = 0;
+		acs->channel_info_2g[1][i] = 0;
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		for (i = 0; i < ODM_MAX_CHANNEL_5G; ++i) {
+			acs->channel_info_5g[0][i] = 0;
+			acs->channel_info_5g[1][i] = 0;
+		}
+	}
+#endif
+}
+
+void
+odm_auto_channel_select_reset(
+	void			*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct acs_info						*acs = &dm->dm_acs;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	if (acs->is_force_acs_result)
+		return;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	ccx_info->nhm_period = 0x1388;	/*20ms*/
+	phydm_nhm_setting(dm, SET_NHM_SETTING);
+	phydm_nhm_trigger(dm);
+#endif
+}
+
+void
+odm_auto_channel_select(
+	void			*dm_void,
+	u8			channel
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct acs_info						*acs = &dm->dm_acs;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u8						channel_idx = 0, search_idx = 0;
+	u8						noisy_nhm_th = 0x52;
+	u8						i, noisy_nhm_th_index, low_pwr_cnt = 0;
+	u16						max_score = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR)) {
+		PHYDM_DBG(dm, DBG_DIG, "Return: Not support\n");
+		return;
+	}
+
+	if (acs->is_force_acs_result) {
+		PHYDM_DBG(dm, DBG_DIG, "Force clean CH{2G,5G}={%d,%d}\n",
+			acs->clean_channel_2g, acs->clean_channel_5g);
+		return;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_API, "CH=%d\n", channel);
+
+	phydm_get_nhm_result(dm);
+	noisy_nhm_th_index = (noisy_nhm_th - ccx_info->nhm_th[0]) << 2;
+
+	for (i = 0; i <= 11; i++) {
+		if (i <= noisy_nhm_th_index)
+			low_pwr_cnt += ccx_info->nhm_result[i];
+	}
+
+	ccx_info->nhm_period = 0x2710;
+	phydm_nhm_setting(dm, SET_NHM_SETTING);
+
+	if (channel >= 1 && channel <= 14) {
+		channel_idx = channel - 1;
+		acs->channel_info_2g[1][channel_idx]++;
+
+		if (acs->channel_info_2g[1][channel_idx] >= 2)
+			acs->channel_info_2g[0][channel_idx] = (acs->channel_info_2g[0][channel_idx] >> 1) +
+				(acs->channel_info_2g[0][channel_idx] >> 2) + (low_pwr_cnt >> 2);
+		else
+			acs->channel_info_2g[0][channel_idx] = low_pwr_cnt;
+
+		PHYDM_DBG(dm, ODM_COMP_API, "low_pwr_cnt = %d\n", low_pwr_cnt);
+		PHYDM_DBG(dm, ODM_COMP_API, "CH_Info[0][%d]=%d, CH_Info[1][%d]=%d\n", channel_idx, acs->channel_info_2g[0][channel_idx], channel_idx, acs->channel_info_2g[1][channel_idx]);
+
+		for (search_idx = 0; search_idx < ODM_MAX_CHANNEL_2G; search_idx++) {
+			if (acs->channel_info_2g[1][search_idx] != 0 && acs->channel_info_2g[0][search_idx] >= max_score) {
+				max_score = acs->channel_info_2g[0][search_idx];
+				acs->clean_channel_2g = search_idx + 1;
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_API, "clean_CH_2g=%d, max_score=%d\n",
+				acs->clean_channel_2g, max_score);
+
+	} else if (channel >= 36) {
+		/* Need to do */
+		acs->clean_channel_5g = channel;
+	}
+#endif
+}
+
+boolean
+phydm_acs_check(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv		*priv = dm->priv;
+
+	if ((priv->auto_channel != 0) && (priv->auto_channel != 2)) /* if struct acs_info running, do not do FA/CCA counter read */
+		return true;
+	else
+		return false;
+#else
+	return false;
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+void
+phydm_auto_channel_select_setting_ap(
+	void   *dm_void,
+	u32  setting,             /* 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING */
+	u32  acs_step
+)
+{
+	struct dm_struct           *dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv       *priv           = dm->priv;
+	struct acs_info                    *acs         = &dm->dm_acs;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	/* 3 Store Default setting */
+	if (setting == STORE_DEFAULT_NHM_SETTING) {
+		PHYDM_DBG(dm, ODM_COMP_API, "STORE_DEFAULT_NHM_SETTING\n");
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {  /* store reg0x990, reg0x994, reg0x998, reg0x99c, Reg0x9a0 */
+			acs->reg0x990 = odm_read_4byte(dm, ODM_REG_CCX_PERIOD_11AC);                /* reg0x990 */
+			acs->reg0x994 = odm_read_4byte(dm, ODM_REG_NHM_TH9_TH10_11AC);           /* reg0x994 */
+			acs->reg0x998 = odm_read_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC);       /* reg0x998 */
+			acs->reg0x99c = odm_read_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC);       /* Reg0x99c */
+			acs->reg0x9a0 = odm_read_1byte(dm, ODM_REG_NHM_TH8_11AC);                   /* Reg0x9a0, u8 */
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			acs->reg0x890 = odm_read_4byte(dm, ODM_REG_NHM_TH9_TH10_11N);             /* reg0x890 */
+			acs->reg0x894 = odm_read_4byte(dm, ODM_REG_CCX_PERIOD_11N);                  /* reg0x894 */
+			acs->reg0x898 = odm_read_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N);         /* reg0x898 */
+			acs->reg0x89c = odm_read_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N);         /* Reg0x89c */
+			acs->reg0xe28 = odm_read_1byte(dm, ODM_REG_NHM_TH8_11N);                     /* Reg0xe28, u8 */
+		}
+	}
+
+	/* 3 Restore Default setting */
+	else if (setting == RESTORE_DEFAULT_NHM_SETTING) {
+		PHYDM_DBG(dm, ODM_COMP_API, "RESTORE_DEFAULT_NHM_SETTING\n");
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {  /* store reg0x990, reg0x994, reg0x998, reg0x99c, Reg0x9a0 */
+			odm_write_4byte(dm, ODM_REG_CCX_PERIOD_11AC,          acs->reg0x990);
+			odm_write_4byte(dm, ODM_REG_NHM_TH9_TH10_11AC,     acs->reg0x994);
+			odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, acs->reg0x998);
+			odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, acs->reg0x99c);
+			odm_write_1byte(dm, ODM_REG_NHM_TH8_11AC,             acs->reg0x9a0);
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			odm_write_4byte(dm, ODM_REG_NHM_TH9_TH10_11N,     acs->reg0x890);
+			odm_write_4byte(dm, ODM_REG_CCX_PERIOD_11AC,          acs->reg0x894);
+			odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N, acs->reg0x898);
+			odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N, acs->reg0x89c);
+			odm_write_1byte(dm, ODM_REG_NHM_TH8_11N,             acs->reg0xe28);
+		}
+	}
+
+	/* 3 struct acs_info setting */
+	else if (setting == ACS_NHM_SETTING) {
+		PHYDM_DBG(dm, ODM_COMP_API, "ACS_NHM_SETTING\n");
+		u16  period;
+		period = 0x61a8;
+		acs->acs_step = acs_step;
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			/* 4 Set NHM period, 0x990[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms */
+			odm_write_2byte(dm, ODM_REG_CCX_PERIOD_11AC + 2, period);
+			/* 4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0 */
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(8) | BIT(9) | BIT(10), 3);
+
+			if (acs->acs_step == 0) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xe50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x82786e64);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff8c);
+				odm_write_1byte(dm, ODM_REG_NHM_TH8_11AC, 0xff);
+				odm_write_2byte(dm, ODM_REG_NHM_TH9_TH10_11AC + 2, 0xffff);
+
+			} else if (acs->acs_step == 1) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xe50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x5a50463c);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff64);
+
+			}
+
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			/* 4 Set NHM period, 0x894[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms */
+			odm_write_2byte(dm, ODM_REG_CCX_PERIOD_11AC + 2, period);
+			/* 4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0 */
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(8) | BIT(9) | BIT(10), 3);
+
+			if (acs->acs_step == 0) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xc58, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x82786e64);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff8c);
+				odm_write_1byte(dm, ODM_REG_NHM_TH8_11N, 0xff);
+				odm_write_2byte(dm, ODM_REG_NHM_TH9_TH10_11N + 2, 0xffff);
+
+			} else if (acs->acs_step == 1) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xc58, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x5a50463c);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff64);
+
+			}
+		}
+	}
+
+}
+
+void
+phydm_get_nhm_statistics_ap(
+	void       *dm_void,
+	u32      idx,                /* @ 2G, Real channel number = idx+1 */
+	u32      acs_step
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv     *priv    = dm->priv;
+	struct acs_info                  *acs    = &dm->dm_acs;
+	u32                value32 = 0;
+	u8                i;
+
+	acs->acs_step = acs_step;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/* 4 Check if NHM result is ready */
+		for (i = 0; i < 20; i++) {
+			ODM_delay_ms(1);
+			if (odm_get_bb_reg(dm, REG_FPGA0_PSD_REPORT, BIT(17)))
+				break;
+		}
+
+		/* 4 Get NHM Statistics */
+		if (acs->acs_step == 1) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
+
+			acs->nhm_cnt[idx][9] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][8] = (value32 & MASKBYTE0);
+
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11N);   /* ODM_REG_NHM_CNT3_TO_CNT0_11N */
+
+			acs->nhm_cnt[idx][7] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][6] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][5] = (value32 & MASKBYTE1) >> 8;
+
+		} else if (acs->acs_step == 2) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11N);  /* ODM_REG_NHM_CNT3_TO_CNT0_11N */
+
+			acs->nhm_cnt[idx][4] = odm_read_1byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
+			acs->nhm_cnt[idx][3] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][2] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][1] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][0] = (value32 & MASKBYTE0);
+		}
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		/* 4 Check if NHM result is ready */
+		for (i = 0; i < 20; i++) {
+			ODM_delay_ms(1);
+			if (odm_get_bb_reg(dm, ODM_REG_NHM_DUR_READY_11AC, BIT(16)))
+				break;
+		}
+
+		if (acs->acs_step == 1) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
+
+			acs->nhm_cnt[idx][9] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][8] = (value32 & MASKBYTE0);
+
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11AC);    /* ODM_REG_NHM_CNT3_TO_CNT0_11AC */
+
+			acs->nhm_cnt[idx][7] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][6] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][5] = (value32 & MASKBYTE1) >> 8;
+
+		} else if (acs->acs_step == 2) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11AC);     /* ODM_REG_NHM_CNT3_TO_CNT0_11AC */
+
+			acs->nhm_cnt[idx][4] = odm_read_1byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
+			acs->nhm_cnt[idx][3] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][2] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][1] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][0] = (value32 & MASKBYTE0);
+		}
+	}
+
+}
+
+
+/* #define ACS_DEBUG_INFO */ /* acs debug default off */
+#if 0
+int phydm_AutoChannelSelectAP(
+	void   *dm_void,
+	u32  ACS_Type,                      /*  0: RXCount_Type, 1:NHM_Type */
+	u32  available_chnl_num        /*  amount of all channels */
+)
+{
+	struct dm_struct               *dm = (struct dm_struct *)dm_void;
+	struct acs_info                    *acs    = &dm->dm_acs;
+	struct rtl8192cd_priv			*priv    = dm->priv;
+
+	static u32           score2G[MAX_2G_CHANNEL_NUM], score5G[MAX_5G_CHANNEL_NUM];
+	u32                  score[MAX_BSS_NUM], use_nhm = 0;
+	u32                  minScore = 0xffffffff;
+	u32                  tmpScore, tmpIdx = 0;
+	u32                  traffic_check = 0;
+	u32                  fa_count_weighting = 1;
+	int                     i, j, idx = 0, idx_2G_end = -1, idx_5G_begin = -1, minChan = 0;
+	struct bss_desc *pBss = NULL;
+
+#ifdef _DEBUG_RTL8192CD_
+	char tmpbuf[400];
+	int len = 0;
+#endif
+
+	memset(score2G, '\0', sizeof(score2G));
+	memset(score5G, '\0', sizeof(score5G));
+
+	for (i = 0; i < priv->available_chnl_num; i++) {
+		if (priv->available_chnl[i] <= 14)
+			idx_2G_end = i;
+		else
+			break;
+	}
+
+	for (i = 0; i < priv->available_chnl_num; i++) {
+		if (priv->available_chnl[i] > 14) {
+			idx_5G_begin = i;
+			break;
+		}
+	}
+
+	/*  DELETE */
+#ifndef CONFIG_RTL_NEW_AUTOCH
+	for (i = 0; i < priv->site_survey->count; i++) {
+		pBss = &priv->site_survey->bss[i];
+		for (idx = 0; idx < priv->available_chnl_num; idx++) {
+			if (pBss->channel == priv->available_chnl[idx]) {
+				if (pBss->channel <= 14)
+					setChannelScore(idx, score2G, 0, MAX_2G_CHANNEL_NUM - 1);
+				else
+					score5G[idx - idx_5G_begin] += 5;
+				break;
+			}
+		}
+	}
+#endif
+
+	if (idx_2G_end >= 0)
+		for (i = 0; i <= idx_2G_end; i++)
+			score[i] = score2G[i];
+	if (idx_5G_begin >= 0)
+		for (i = idx_5G_begin; i < priv->available_chnl_num; i++)
+			score[i] = score5G[i - idx_5G_begin];
+
+#ifdef CONFIG_RTL_NEW_AUTOCH
+	{
+		u32 y, ch_begin = 0, ch_end = priv->available_chnl_num;
+
+		u32 do_ap_check = 1, ap_ratio = 0;
+
+		if (idx_2G_end >= 0)
+			ch_end = idx_2G_end + 1;
+		if (idx_5G_begin >= 0)
+			ch_begin = idx_5G_begin;
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("1. init: chnl[%d] 20M_rx[%d] 40M_rx[%d] fa_cnt[%d] score[%d]\n",
+			       priv->available_chnl[y],
+			       priv->chnl_ss_mac_rx_count[y],
+			       priv->chnl_ss_mac_rx_count_40M[y],
+			       priv->chnl_ss_fa_count[y],
+			       score[y]);
+		printk("\n");
+#endif
+
+#if defined(CONFIG_RTL_88E_SUPPORT) || defined(CONFIG_WLAN_HAL_8192EE)
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E) && priv->pmib->dot11RFEntry.acs_type) {
+			u32 tmp_score[MAX_BSS_NUM];
+			memcpy(tmp_score, score, sizeof(score));
+			if (find_clean_channel(priv, ch_begin, ch_end, tmp_score)) {
+				/* memcpy(score, tmp_score, sizeof(score)); */
+#ifdef _DEBUG_RTL8192CD_
+				printk("!! Found clean channel, select minimum FA channel\n");
+#endif
+				goto USE_CLN_CH;
+			}
+#ifdef _DEBUG_RTL8192CD_
+			printk("!! Not found clean channel, use NHM algorithm\n");
+#endif
+			use_nhm = 1;
+USE_CLN_CH:
+			for (y = ch_begin; y < ch_end; y++) {
+				for (i = 0; i <= 9; i++) {
+					u32 val32 = priv->nhm_cnt[y][i];
+					for (j = 0; j < i; j++)
+						val32 *= 3;
+					score[y] += val32;
+				}
+
+#ifdef _DEBUG_RTL8192CD_
+				printk("nhm_cnt_%d: H<-[ %3d %3d %3d %3d %3d %3d %3d %3d %3d %3d]->L, score: %d\n",
+				       y + 1, priv->nhm_cnt[y][9], priv->nhm_cnt[y][8], priv->nhm_cnt[y][7],
+				       priv->nhm_cnt[y][6], priv->nhm_cnt[y][5], priv->nhm_cnt[y][4],
+				       priv->nhm_cnt[y][3], priv->nhm_cnt[y][2], priv->nhm_cnt[y][1],
+				       priv->nhm_cnt[y][0], score[y]);
+#endif
+			}
+
+			if (!use_nhm)
+				memcpy(score, tmp_score, sizeof(score));
+
+			goto choose_ch;
+		}
+#endif
+
+		/*  For each channel, weighting behind channels with MAC RX counter */
+		/* For each channel, weighting the channel with FA counter */
+
+		for (y = ch_begin; y < ch_end; y++) {
+			score[y] += 8 * priv->chnl_ss_mac_rx_count[y];
+			if (priv->chnl_ss_mac_rx_count[y] > 30)
+				do_ap_check = 0;
+			if (priv->chnl_ss_mac_rx_count[y] > MAC_RX_COUNT_THRESHOLD)
+				traffic_check = 1;
+
+#ifdef RTK_5G_SUPPORT
+			if (*dm->band_type == ODM_BAND_2_4G)
+#endif
+			{
+				if ((int)(y - 4) >= (int)ch_begin)
+					score[y - 4] += 2 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y - 3) >= (int)ch_begin)
+					score[y - 3] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y - 2) >= (int)ch_begin)
+					score[y - 2] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y - 1) >= (int)ch_begin)
+					score[y - 1] += 10 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 1) < (int)ch_end)
+					score[y + 1] += 10 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 2) < (int)ch_end)
+					score[y + 2] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 3) < (int)ch_end)
+					score[y + 3] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 4) < (int)ch_end)
+					score[y + 4] += 2 * priv->chnl_ss_mac_rx_count[y];
+			}
+
+			/* this is for CH_LOAD caculation */
+			if (priv->chnl_ss_cca_count[y] > priv->chnl_ss_fa_count[y])
+				priv->chnl_ss_cca_count[y] -= priv->chnl_ss_fa_count[y];
+			else
+				priv->chnl_ss_cca_count[y] = 0;
+		}
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("2. after 20M check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+#endif
+
+		for (y = ch_begin; y < ch_end; y++) {
+			if (priv->chnl_ss_mac_rx_count_40M[y]) {
+				score[y] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+				if (priv->chnl_ss_mac_rx_count_40M[y] > 30)
+					do_ap_check = 0;
+				if (priv->chnl_ss_mac_rx_count_40M[y] > MAC_RX_COUNT_THRESHOLD)
+					traffic_check = 1;
+
+#ifdef RTK_5G_SUPPORT
+				if (*dm->band_type == ODM_BAND_2_4G)
+#endif
+				{
+					if ((int)(y - 6) >= (int)ch_begin)
+						score[y - 6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 5) >= (int)ch_begin)
+						score[y - 5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 4) >= (int)ch_begin)
+						score[y - 4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 3) >= (int)ch_begin)
+						score[y - 3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 2) >= (int)ch_begin)
+						score[y - 2] += (5 * priv->chnl_ss_mac_rx_count_40M[y]) / 2;
+					if ((int)(y - 1) >= (int)ch_begin)
+						score[y - 1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 1) < (int)ch_end)
+						score[y + 1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 2) < (int)ch_end)
+						score[y + 2] += (5 * priv->chnl_ss_mac_rx_count_40M[y]) / 2;
+					if ((int)(y + 3) < (int)ch_end)
+						score[y + 3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 4) < (int)ch_end)
+						score[y + 4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 5) < (int)ch_end)
+						score[y + 5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 6) < (int)ch_end)
+						score[y + 6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
+				}
+			}
+		}
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("3. after 40M check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+		printk("4. do_ap_check=%d traffic_check=%d\n", do_ap_check, traffic_check);
+		printk("\n");
+#endif
+
+		if (traffic_check == 0)
+			fa_count_weighting = 5;
+		else
+			fa_count_weighting = 1;
+
+		for (y = ch_begin; y < ch_end; y++)
+			score[y] += fa_count_weighting * priv->chnl_ss_fa_count[y];
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("5. after fa check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+#endif
+
+		if (do_ap_check) {
+			for (i = 0; i < priv->site_survey->count; i++) {
+				pBss = &priv->site_survey->bss[i];
+				for (y = ch_begin; y < ch_end; y++) {
+					if (pBss->channel == priv->available_chnl[y]) {
+						if (pBss->channel <= 14) {
+#ifdef ACS_DEBUG_INFO/* for debug */
+							printk("\n");
+							printk("chnl[%d] has ap rssi=%d bw[0x%02x]\n",
+							       pBss->channel, pBss->rssi, pBss->t_stamp[1]);
+							printk("\n");
+#endif
+							if (pBss->rssi > 60)
+								ap_ratio = 4;
+							else if (pBss->rssi > 35)
+								ap_ratio = 2;
+							else
+								ap_ratio = 1;
+
+							if ((pBss->t_stamp[1] & 0x6) == 0) {
+								score[y] += 50 * ap_ratio;
+								if ((int)(y - 4) >= (int)ch_begin)
+									score[y - 4] += 10 * ap_ratio;
+								if ((int)(y - 3) >= (int)ch_begin)
+									score[y - 3] += 20 * ap_ratio;
+								if ((int)(y - 2) >= (int)ch_begin)
+									score[y - 2] += 30 * ap_ratio;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 40 * ap_ratio;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 40 * ap_ratio;
+								if ((int)(y + 2) < (int)ch_end)
+									score[y + 2] += 30 * ap_ratio;
+								if ((int)(y + 3) < (int)ch_end)
+									score[y + 3] += 20 * ap_ratio;
+								if ((int)(y + 4) < (int)ch_end)
+									score[y + 4] += 10 * ap_ratio;
+							} else if ((pBss->t_stamp[1] & 0x4) == 0) {
+								score[y] += 50 * ap_ratio;
+								if ((int)(y - 3) >= (int)ch_begin)
+									score[y - 3] += 20 * ap_ratio;
+								if ((int)(y - 2) >= (int)ch_begin)
+									score[y - 2] += 30 * ap_ratio;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 40 * ap_ratio;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 50 * ap_ratio;
+								if ((int)(y + 2) < (int)ch_end)
+									score[y + 2] += 50 * ap_ratio;
+								if ((int)(y + 3) < (int)ch_end)
+									score[y + 3] += 50 * ap_ratio;
+								if ((int)(y + 4) < (int)ch_end)
+									score[y + 4] += 50 * ap_ratio;
+								if ((int)(y + 5) < (int)ch_end)
+									score[y + 5] += 40 * ap_ratio;
+								if ((int)(y + 6) < (int)ch_end)
+									score[y + 6] += 30 * ap_ratio;
+								if ((int)(y + 7) < (int)ch_end)
+									score[y + 7] += 20 * ap_ratio;
+							} else {
+								score[y] += 50 * ap_ratio;
+								if ((int)(y - 7) >= (int)ch_begin)
+									score[y - 7] += 20 * ap_ratio;
+								if ((int)(y - 6) >= (int)ch_begin)
+									score[y - 6] += 30 * ap_ratio;
+								if ((int)(y - 5) >= (int)ch_begin)
+									score[y - 5] += 40 * ap_ratio;
+								if ((int)(y - 4) >= (int)ch_begin)
+									score[y - 4] += 50 * ap_ratio;
+								if ((int)(y - 3) >= (int)ch_begin)
+									score[y - 3] += 50 * ap_ratio;
+								if ((int)(y - 2) >= (int)ch_begin)
+									score[y - 2] += 50 * ap_ratio;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 50 * ap_ratio;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 40 * ap_ratio;
+								if ((int)(y + 2) < (int)ch_end)
+									score[y + 2] += 30 * ap_ratio;
+								if ((int)(y + 3) < (int)ch_end)
+									score[y + 3] += 20 * ap_ratio;
+							}
+						} else {
+							if ((pBss->t_stamp[1] & 0x6) == 0)
+								score[y] += 500;
+							else if ((pBss->t_stamp[1] & 0x4) == 0) {
+								score[y] += 500;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 500;
+							} else {
+								score[y] += 500;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 500;
+							}
+						}
+						break;
+					}
+				}
+			}
+		}
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("6. after ap check: chnl[%d]:%d\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+#endif
+
+#ifdef SS_CH_LOAD_PROC
+
+		/*  caculate noise level -- suggested by wilson */
+		for (y = ch_begin; y < ch_end; y++)  {
+			int fa_lv = 0, cca_lv = 0;
+			if (priv->chnl_ss_fa_count[y] > 1000)
+				fa_lv = 100;
+			else if (priv->chnl_ss_fa_count[y] > 500)
+				fa_lv = 34 * (priv->chnl_ss_fa_count[y] - 500) / 500 + 66;
+			else if (priv->chnl_ss_fa_count[y] > 200)
+				fa_lv = 33 * (priv->chnl_ss_fa_count[y] - 200) / 300 + 33;
+			else if (priv->chnl_ss_fa_count[y] > 100)
+				fa_lv = 18 * (priv->chnl_ss_fa_count[y] - 100) / 100 + 15;
+			else
+				fa_lv = 15 * priv->chnl_ss_fa_count[y] / 100;
+			if (priv->chnl_ss_cca_count[y] > 400)
+				cca_lv = 100;
+			else if (priv->chnl_ss_cca_count[y] > 200)
+				cca_lv = 34 * (priv->chnl_ss_cca_count[y] - 200) / 200 + 66;
+			else if (priv->chnl_ss_cca_count[y] > 80)
+				cca_lv = 33 * (priv->chnl_ss_cca_count[y] - 80) / 120 + 33;
+			else if (priv->chnl_ss_cca_count[y] > 40)
+				cca_lv = 18 * (priv->chnl_ss_cca_count[y] - 40) / 40 + 15;
+			else
+				cca_lv = 15 * priv->chnl_ss_cca_count[y] / 40;
+
+			priv->chnl_ss_load[y] = (((fa_lv > cca_lv) ? fa_lv : cca_lv) * 75 + ((score[y] > 100) ? 100 : score[y]) * 25) / 100;
+
+			DEBUG_INFO("ch:%d f=%d (%d), c=%d (%d), fl=%d, cl=%d, sc=%d, cu=%d\n",
+				   priv->available_chnl[y],
+				   priv->chnl_ss_fa_count[y], fa_thd,
+				   priv->chnl_ss_cca_count[y], cca_thd,
+				   fa_lv,
+				   cca_lv,
+				   score[y],
+				   priv->chnl_ss_load[y]);
+
+		}
+#endif
+	}
+#endif
+
+choose_ch:
+
+#ifdef DFS
+	/*  heavy weighted DFS channel */
+	if (idx_5G_begin >= 0) {
+		for (i = idx_5G_begin; i < priv->available_chnl_num; i++) {
+			if (!priv->pmib->dot11DFSEntry.disable_DFS && is_DFS_channel(priv->available_chnl[i])
+			    && (score[i] != 0xffffffff))
+				score[i] += 1600;
+		}
+	}
+#endif
+
+
+	/* prevent Auto channel selecting wrong channel in 40M mode----------------- */
+	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
+	    && priv->pshare->is_40m_bw) {
+#if 0
+		if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 1) {
+			/* Upper Primary channel, cannot select the two lowest channels */
+			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
+				score[0] = 0xffffffff;
+				score[1] = 0xffffffff;
+				score[2] = 0xffffffff;
+				score[3] = 0xffffffff;
+				score[4] = 0xffffffff;
+
+				score[13] = 0xffffffff;
+				score[12] = 0xffffffff;
+				score[11] = 0xffffffff;
+			}
+
+			/*			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) { */
+			/*				score[idx_5G_begin] = 0xffffffff; */
+			/*				score[idx_5G_begin + 1] = 0xffffffff; */
+			/*			} */
+		} else if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 2) {
+			/* Lower Primary channel, cannot select the two highest channels */
+			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
+				score[0] = 0xffffffff;
+				score[1] = 0xffffffff;
+				score[2] = 0xffffffff;
+
+				score[13] = 0xffffffff;
+				score[12] = 0xffffffff;
+				score[11] = 0xffffffff;
+				score[10] = 0xffffffff;
+				score[9] = 0xffffffff;
+			}
+
+			/*			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) { */
+			/*				score[priv->available_chnl_num - 2] = 0xffffffff; */
+			/*				score[priv->available_chnl_num - 1] = 0xffffffff; */
+			/*			} */
+		}
+#endif
+		for (i = 0; i <= idx_2G_end; ++i)
+			if (priv->available_chnl[i] == 14)
+				score[i] = 0xffffffff;		/*  mask chan14 */
+
+#ifdef RTK_5G_SUPPORT
+		if (idx_5G_begin >= 0) {
+			for (i = idx_5G_begin; i < priv->available_chnl_num; i++) {
+				int ch = priv->available_chnl[i];
+				if (priv->available_chnl[i] > 144)
+					--ch;
+				if ((ch % 4) || ch == 140 || ch == 164)	/* mask ch 140, ch 165, ch 184... */
+					score[i] = 0xffffffff;
+			}
+		}
+#endif
+
+
+	}
+
+	if (priv->pmib->dot11RFEntry.disable_ch1213) {
+		for (i = 0; i <= idx_2G_end; ++i) {
+			int ch = priv->available_chnl[i];
+			if ((ch == 12) || (ch == 13))
+				score[i] = 0xffffffff;
+		}
+	}
+
+	if (((priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_GLOBAL) ||
+	     (priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_WORLD_WIDE)) &&
+	    (idx_2G_end >= 11) && (idx_2G_end < 14)) {
+		score[13] = 0xffffffff;	/*  mask chan14 */
+		score[12] = 0xffffffff; /*  mask chan13 */
+		score[11] = 0xffffffff; /*  mask chan12 */
+	}
+
+	/* ------------------------------------------------------------------ */
+
+#ifdef _DEBUG_RTL8192CD_
+	for (i = 0; i < priv->available_chnl_num; i++)
+		len += sprintf(tmpbuf + len, "ch%d:%u ", priv->available_chnl[i], score[i]);
+	strcat(tmpbuf, "\n");
+	panic_printk("%s", tmpbuf);
+
+#endif
+
+	if ((*dm->band_type == ODM_BAND_5G)
+	    && (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80)) {
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (is80MChannel(priv->available_chnl, priv->available_chnl_num, priv->available_chnl[i])) {
+				tmpScore = 0;
+				for (j = 0; j < 4; j++) {
+					if ((tmpScore != 0xffffffff) && (score[i + j] != 0xffffffff))
+						tmpScore += score[i + j];
+					else
+						tmpScore = 0xffffffff;
+				}
+				tmpScore = tmpScore / 4;
+				if (minScore > tmpScore) {
+					minScore = tmpScore;
+
+					tmpScore = 0xffffffff;
+					for (j = 0; j < 4; j++) {
+						if (score[i + j] < tmpScore) {
+							tmpScore = score[i + j];
+							tmpIdx = i + j;
+						}
+					}
+
+					idx = tmpIdx;
+				}
+				i += 3;
+			}
+		}
+		if (minScore == 0xffffffff) {
+			/*  there is no 80M channels */
+			priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
+			for (i = 0; i < priv->available_chnl_num; i++) {
+				if (score[i] < minScore) {
+					minScore = score[i];
+					idx = i;
+				}
+			}
+		}
+	} else if ((*dm->band_type == ODM_BAND_5G)
+		&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40)) {
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (is40MChannel(priv->available_chnl, priv->available_chnl_num, priv->available_chnl[i])) {
+				tmpScore = 0;
+				for (j = 0; j < 2; j++) {
+					if ((tmpScore != 0xffffffff) && (score[i + j] != 0xffffffff))
+						tmpScore += score[i + j];
+					else
+						tmpScore = 0xffffffff;
+				}
+				tmpScore = tmpScore / 2;
+				if (minScore > tmpScore) {
+					minScore = tmpScore;
+
+					tmpScore = 0xffffffff;
+					for (j = 0; j < 2; j++) {
+						if (score[i + j] < tmpScore) {
+							tmpScore = score[i + j];
+							tmpIdx = i + j;
+						}
+					}
+
+					idx = tmpIdx;
+				}
+				i += 1;
+			}
+		}
+		if (minScore == 0xffffffff) {
+			/*  there is no 40M channels */
+			priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
+			for (i = 0; i < priv->available_chnl_num; i++) {
+				if (score[i] < minScore) {
+					minScore = score[i];
+					idx = i;
+				}
+			}
+		}
+	} else if ((*dm->band_type == ODM_BAND_2_4G)
+		&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40)
+		   && (priv->available_chnl_num >= 8)) {
+		u32 groupScore[14];
+
+		memset(groupScore, 0xff, sizeof(groupScore));
+		for (i = 0; i < priv->available_chnl_num - 4; i++) {
+			if (score[i] != 0xffffffff && score[i + 4] != 0xffffffff) {
+				groupScore[i] = score[i] + score[i + 4];
+				DEBUG_INFO("groupScore, ch %d,%d: %d\n", i + 1, i + 5, groupScore[i]);
+				if (groupScore[i] < minScore) {
+#ifdef AUTOCH_SS_SPEEDUP
+					if (priv->pmib->miscEntry.autoch_1611_enable) {
+						if (priv->available_chnl[i] == 1 || priv->available_chnl[i] == 6 || priv->available_chnl[i] == 11) {
+							minScore = groupScore[i];
+							idx = i;
+						}
+					} else
+#endif
+					{
+						minScore = groupScore[i];
+						idx = i;
+					}
+				}
+			}
+		}
+
+		if (score[idx] < score[idx + 4]) {
+			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+		} else {
+			idx = idx + 4;
+			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+		}
+	} else {
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (score[i] < minScore) {
+#ifdef AUTOCH_SS_SPEEDUP
+				if (priv->pmib->miscEntry.autoch_1611_enable) {
+					if (priv->available_chnl[i] == 1 || priv->available_chnl[i] == 6 || priv->available_chnl[i] == 11) {
+						minScore = score[i];
+						idx = i;
+					}
+				} else
+#endif
+				{
+					minScore = score[i];
+					idx = i;
+				}
+			}
+		}
+	}
+
+	if (IS_A_CUT_8881A(priv) &&
+	    (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80)) {
+		if ((priv->available_chnl[idx] == 36) ||
+		    (priv->available_chnl[idx] == 52) ||
+		    (priv->available_chnl[idx] == 100) ||
+		    (priv->available_chnl[idx] == 116) ||
+		    (priv->available_chnl[idx] == 132) ||
+		    (priv->available_chnl[idx] == 149) ||
+		    (priv->available_chnl[idx] == 165))
+			idx++;
+		else if ((priv->available_chnl[idx] == 48) ||
+			 (priv->available_chnl[idx] == 64) ||
+			 (priv->available_chnl[idx] == 112) ||
+			 (priv->available_chnl[idx] == 128) ||
+			 (priv->available_chnl[idx] == 144) ||
+			 (priv->available_chnl[idx] == 161) ||
+			 (priv->available_chnl[idx] == 177))
+			idx--;
+	}
+
+	minChan = priv->available_chnl[idx];
+
+	/*  skip channel 14 if don't support ofdm */
+	if ((priv->pmib->dot11RFEntry.disable_ch14_ofdm) &&
+	    (minChan == 14)) {
+		score[idx] = 0xffffffff;
+
+		minScore = 0xffffffff;
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (score[i] < minScore) {
+				minScore = score[i];
+				idx = i;
+			}
+		}
+		minChan = priv->available_chnl[idx];
+	}
+
+#if 0
+	/* Check if selected channel available for 80M/40M BW or NOT ? */
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80) {
+			if (!is80MChannel(priv->available_chnl, priv->available_chnl_num, minChan)) {
+				/* priv->pmib->dot11n_config_entry.dot11nUse40M = CHANNEL_WIDTH_40; */
+				priv->pshare->is_40m_bw = CHANNEL_WIDTH_40;
+			}
+		}
+
+		if (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40) {
+			if (!is40MChannel(priv->available_chnl, priv->available_chnl_num, minChan)) {
+				/* priv->pmib->dot11n_config_entry.dot11nUse40M = CHANNEL_WIDTH_20; */
+				priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
+			}
+		}
+	}
+#endif
+
+#ifdef CONFIG_RTL_NEW_AUTOCH
+	RTL_W32(RXERR_RPT, RXERR_RPT_RST);
+#endif
+
+	/*  auto adjust contro-sideband */
+	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
+	    && (priv->pshare->is_40m_bw == 1 || priv->pshare->is_40m_bw == 2)) {
+#ifdef RTK_5G_SUPPORT
+		if (*dm->band_type == ODM_BAND_5G) {
+			if ((minChan > 144) ? ((minChan - 1) % 8) : (minChan % 8)) {
+				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+			} else {
+				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+			}
+
+		} else
+#endif
+		{
+#if 0
+#ifdef CONFIG_RTL_NEW_AUTOCH
+			unsigned int ch_max;
+
+			if (priv->available_chnl[idx_2G_end] >= 13)
+				ch_max = 13;
+			else
+				ch_max = priv->available_chnl[idx_2G_end];
+
+			if ((minChan >= 5) && (minChan <= (ch_max - 5))) {
+				if (score[minChan + 4] > score[minChan - 4]) { /*  what if some channels were cancelled? */
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+				} else {
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+				}
+			} else
+#endif
+			{
+				if (minChan < 5) {
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+				} else if (minChan > 7) {
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+				}
+			}
+#endif
+		}
+	}
+	/* ----------------------- */
+
+#if defined(__ECOS) && defined(CONFIG_SDIO_HCI)
+	panic_printk("Auto channel choose ch:%d\n", minChan);
+#else
+#ifdef _DEBUG_RTL8192CD_
+	panic_printk("Auto channel choose ch:%d\n", minChan);
+#endif
+#endif
+#ifdef ACS_DEBUG_INFO/* for debug */
+	printk("7. minChan:%d 2nd_offset:%d\n", minChan, priv->pshare->offset_2nd_chan);
+#endif
+
+	return minChan;
+}
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_acs.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_acs.h
new file mode 100644
index 000000000000..61bdeccc0e3a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_acs.h
@@ -0,0 +1,115 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMACS_H__
+#define    __PHYDMACS_H__
+
+#define ACS_VERSION	"1.1"	/*20150729 by YuChen*/
+#define CLM_VERSION "1.0"
+
+#define ODM_MAX_CHANNEL_2G			14
+#define ODM_MAX_CHANNEL_5G			24
+
+/* For phydm_auto_channel_select_setting_ap() */
+#define STORE_DEFAULT_NHM_SETTING               0
+#define RESTORE_DEFAULT_NHM_SETTING             1
+#define ACS_NHM_SETTING                         2
+
+struct acs_info {
+	boolean		is_force_acs_result;
+	u8		clean_channel_2g;
+	u8		clean_channel_5g;
+	u16		channel_info_2g[2][ODM_MAX_CHANNEL_2G];		/* Channel_Info[1]: channel score, Channel_Info[2]:Channel_Scan_Times */
+	u16		channel_info_5g[2][ODM_MAX_CHANNEL_5G];
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	u8              acs_step;
+	/* NHM count 0-11 */
+	u8              nhm_cnt[14][11];
+
+	/* AC-Series, for storing previous setting */
+	u32              reg0x990;
+	u32              reg0x994;
+	u32              reg0x998;
+	u32              reg0x99c;
+	u8              reg0x9a0;   /* u8 */
+
+	/* N-Series, for storing previous setting */
+	u32              reg0x890;
+	u32              reg0x894;
+	u32              reg0x898;
+	u32              reg0x89c;
+	u8              reg0xe28;   /* u8 */
+#endif
+
+};
+
+
+void
+odm_auto_channel_select_init(
+	void			*dm_void
+);
+
+void
+odm_auto_channel_select_reset(
+	void			*dm_void
+);
+
+void
+odm_auto_channel_select(
+	void			*dm_void,
+	u8			channel
+);
+
+u8
+odm_get_auto_channel_select_result(
+	void			*dm_void,
+	u8			band
+);
+
+boolean
+phydm_acs_check(
+	void	*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+void
+phydm_auto_channel_select_setting_ap(
+	void   *dm_void,
+	u32  setting,             /* 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING */
+	u32  acs_step
+);
+
+void
+phydm_get_nhm_statistics_ap(
+	void       *dm_void,
+	u32      idx,                /* @ 2G, Real channel number = idx+1 */
+	u32      acs_step
+);
+
+#endif  /* #if ( DM_ODM_SUPPORT_TYPE & ODM_AP ) */
+
+#endif  /* #ifndef	__PHYDMACS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adaptivity.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adaptivity.c
new file mode 100644
index 000000000000..fafe2d5b45b2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adaptivity.c
@@ -0,0 +1,1005 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	#if WPP_SOFTWARE_TRACE
+		#include "PhyDM_Adaptivity.tmh"
+	#endif
+#endif
+
+void
+phydm_dig_up_bound_lmt_en(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVITY) ||
+		(!dm->adaptivity_flag) ||
+		(!dm->is_linked) ||
+		(!dm->adaptivity_enable)
+	) {
+		adaptivity->igi_up_bound_lmt_cnt = 0;
+		adaptivity->igi_lmt_en = false;	
+		return;
+	}
+
+	if (dm->total_tp > 1) {
+		adaptivity->igi_lmt_en = true;			
+		adaptivity->igi_up_bound_lmt_cnt = adaptivity->igi_up_bound_lmt_val;
+		PHYDM_DBG(dm, DBG_ADPTVTY, "TP >1, Start limit IGI upper bound\n");
+	} else {
+		if (adaptivity->igi_up_bound_lmt_cnt == 0)
+			adaptivity->igi_lmt_en = false;
+		else
+			adaptivity->igi_up_bound_lmt_cnt--;
+	}
+
+	PHYDM_DBG(dm, DBG_ADPTVTY, "IGI_lmt_cnt = %d\n", adaptivity->igi_up_bound_lmt_cnt);
+}
+
+void
+phydm_check_adaptivity(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVITY)) {
+		dm->adaptivity_enable = false;
+		return;
+	}
+	
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (dm->ap_total_num > adaptivity->ap_num_th) {
+		dm->adaptivity_enable = false;
+		PHYDM_DBG(dm, DBG_ADPTVTY, "AP total num > %d!!, disable adaptivity\n", adaptivity->ap_num_th);
+		return;
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (adaptivity->dynamic_link_adaptivity) {
+		if (dm->is_linked && adaptivity->is_check == false) {
+			phydm_check_environment(dm);
+		} else if (!dm->is_linked)
+			adaptivity->is_check = false;
+
+		return;
+	}
+#endif
+	
+	dm->adaptivity_enable = true;
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+boolean
+phydm_check_channel_plan(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter	= dm->adapter;
+	PMGNT_INFO		mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+
+	if (mgnt_info->RegEnableAdaptivity == 2) {
+		if (dm->carrier_sense_enable == false) {		/*check domain Code for adaptivity or CarrierSense*/
+			if ((*dm->band_type == ODM_BAND_5G) &&
+				!(dm->odm_regulation_5g == REGULATION_ETSI || dm->odm_regulation_5g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity skip 5G domain code : %d\n", dm->odm_regulation_5g);
+				dm->adaptivity_enable = false;
+				return true;
+			} else if ((*dm->band_type == ODM_BAND_2_4G) &&
+				!(dm->odm_regulation_2_4g == REGULATION_ETSI || dm->odm_regulation_2_4g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity skip 2.4G domain code : %d\n", dm->odm_regulation_2_4g);
+				dm->adaptivity_enable = false;
+				return true;
+
+			} else if ((*dm->band_type != ODM_BAND_2_4G) && (*dm->band_type != ODM_BAND_5G)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity neither 2G nor 5G band, return\n");
+				dm->adaptivity_enable = false;
+				return true;
+			}
+		} else {
+			if ((*dm->band_type == ODM_BAND_5G) &&
+				!(dm->odm_regulation_5g == REGULATION_MKK || dm->odm_regulation_5g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "CarrierSense skip 5G domain code : %d\n", dm->odm_regulation_5g);
+				dm->adaptivity_enable = false;
+				return true;
+			}
+
+			else if ((*dm->band_type == ODM_BAND_2_4G) &&
+				!(dm->odm_regulation_2_4g == REGULATION_MKK  || dm->odm_regulation_2_4g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "CarrierSense skip 2.4G domain code : %d\n", dm->odm_regulation_2_4g);
+				dm->adaptivity_enable = false;
+				return true;
+
+			} else if ((*dm->band_type != ODM_BAND_2_4G) && (*dm->band_type != ODM_BAND_5G)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "CarrierSense neither 2G nor 5G band, return\n");
+				dm->adaptivity_enable = false;
+				return true;
+			}
+		}
+	}
+
+	return false;
+
+}
+#endif
+
+void
+phydm_set_edcca_threshold(
+	void	*dm_void,
+	s8	H2L,
+	s8	L2H
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)((u8)L2H | (u8)H2L << 16));
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_set_bb_reg(dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)((u8)L2H | (u8)H2L << 8));
+#endif
+
+}
+
+void
+phydm_set_lna(
+	void				*dm_void,
+	enum phydm_set_lna	type
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E)) {
+		if (type == phydm_disable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x37f82);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x37f82);
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		} else if (type == phydm_enable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x77f82);	/*back to normal*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x77f82);
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		}
+	} else if (dm->support_ic_type & ODM_RTL8723B) {
+		if (type == phydm_disable_lna) {
+			/*S0*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0001f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xe6137);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			/*S1*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x43, 0xfffff, 0x3008d);	/*select Rx mode and disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x0);
+		} else if (type == phydm_enable_lna) {
+			/*S0*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0001f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xe6177);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			/*S1*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x43, 0xfffff, 0x300bd);	/*select Rx mode and disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x0);
+		}
+
+	} else if (dm->support_ic_type & ODM_RTL8812) {
+		if (type == phydm_disable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		} else if (type == phydm_enable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		}
+	} else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
+		if (type == phydm_disable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0002f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xfb09b);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+		} else if (type == phydm_enable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0002f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xfb0bb);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+		}
+	}
+}
+
+
+
+void
+phydm_set_trx_mux(
+	void				*dm_void,
+	enum phydm_trx_mux_type	tx_mode,
+	enum phydm_trx_mux_type	rx_mode
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N, BIT(3) | BIT(2) | BIT(1), tx_mode);			/*set TXmod to standby mode to remove outside noise affect*/
+		odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N, BIT(22) | BIT(21) | BIT(20), rx_mode);		/*set RXmod to standby mode to remove outside noise affect*/
+		if (dm->rf_type > RF_1T1R) {
+			odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT(3) | BIT(2) | BIT(1), tx_mode);		/*set TXmod to standby mode to remove outside noise affect*/
+			odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT(22) | BIT(21) | BIT(20), rx_mode);	/*set RXmod to standby mode to remove outside noise affect*/
+		}
+	}
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(11) | BIT(10) | BIT(9) | BIT(8), tx_mode);				/*set TXmod to standby mode to remove outside noise affect*/
+		odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(7) | BIT(6) | BIT(5) | BIT(4), rx_mode);				/*set RXmod to standby mode to remove outside noise affect*/
+		if (dm->rf_type > RF_1T1R) {
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC_B, BIT(11) | BIT(10) | BIT(9) | BIT(8), tx_mode);		/*set TXmod to standby mode to remove outside noise affect*/
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC_B, BIT(7) | BIT(6) | BIT(5) | BIT(4), rx_mode);			/*set RXmod to standby mode to remove outside noise affect*/
+		}
+	}
+#endif
+
+}
+
+void
+phydm_mac_edcca_state(
+	void					*dm_void,
+	enum phydm_mac_edcca_type		state
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (state == phydm_ignore_edcca) {
+		odm_set_mac_reg(dm, REG_TX_PTCL_CTRL, BIT(15), 1);	/*ignore EDCCA	reg520[15]=1*/
+		/*		odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 0);			*/ /*reg524[11]=0*/
+	} else {	/*don't set MAC ignore EDCCA signal*/
+		odm_set_mac_reg(dm, REG_TX_PTCL_CTRL, BIT(15), 0);	/*don't ignore EDCCA	 reg520[15]=0*/
+		/*		odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 1);			*/ /*reg524[11]=1	*/
+	}
+	PHYDM_DBG(dm, DBG_ADPTVTY, "EDCCA enable state = %d\n", state);
+
+}
+
+void
+phydm_search_pwdb_lower_bound(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u32			value32 = 0, reg_value32 = 0;
+	u8			cnt, try_count = 0;
+	u8			tx_edcca1 = 0;
+	boolean			is_adjust = true;
+	s8			th_l2h_dmc, th_h2l_dmc, igi_target = 0x32;
+	s8			diff;
+	u8			IGI = adaptivity->igi_base + 30 + (u8)dm->th_l2h_ini - (u8)dm->th_edcca_hl_diff;
+
+	if (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
+		phydm_set_lna(dm, phydm_disable_lna);
+
+	diff = igi_target - (s8)IGI;
+	th_l2h_dmc = dm->th_l2h_ini + diff;
+	if (th_l2h_dmc > 10)
+		th_l2h_dmc = 10;
+
+	th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+	phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+	ODM_delay_ms(30);
+
+	while (is_adjust) {
+		/*check CCA status*/
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, 0x0)) {/*set debug port to 0x0*/
+			reg_value32 = phydm_get_bb_dbg_port_value(dm);
+
+			while (reg_value32 & BIT(3) && try_count < 3) {
+				ODM_delay_ms(3);
+				try_count = try_count + 1;
+				reg_value32 = phydm_get_bb_dbg_port_value(dm);
+			}
+			phydm_release_bb_dbg_port(dm);
+			try_count = 0;
+		}
+
+		/*count EDCCA signal = 1 times*/
+		for (cnt = 0; cnt < 20; cnt++) {
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, adaptivity->adaptivity_dbg_port)) {
+				value32 = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+			}
+
+			if (value32 & BIT(30) && (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E)))
+				tx_edcca1 = tx_edcca1 + 1;
+			else if (value32 & BIT(29))
+				tx_edcca1 = tx_edcca1 + 1;
+		}
+
+		if (tx_edcca1 > 1) {
+			IGI = IGI - 1;
+			th_l2h_dmc = th_l2h_dmc + 1;
+			if (th_l2h_dmc > 10)
+				th_l2h_dmc = 10;
+
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+			phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+			tx_edcca1 = 0;
+			if (th_l2h_dmc == 10)
+				is_adjust = false;
+
+		} else
+			is_adjust = false;
+
+	}
+
+	adaptivity->adapt_igi_up = IGI - dm->dc_backoff;
+	adaptivity->h2l_lb = th_h2l_dmc + dm->dc_backoff;
+	adaptivity->l2h_lb = th_l2h_dmc + dm->dc_backoff;
+
+	if (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
+		phydm_set_lna(dm, phydm_enable_lna);
+
+	phydm_set_edcca_threshold(dm, 0x7f, 0x7f);				/*resume to no link state*/
+}
+
+boolean
+phydm_re_search_condition(
+	void				*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u8			adaptivity_igi_upper = adaptivity->adapt_igi_up + dm->dc_backoff;
+	/*s8		TH_L2H_dmc, IGI_target = 0x32;*/
+	/*s8		diff;*/
+
+	/*TH_L2H_dmc = 10;*/
+
+	/*diff = TH_L2H_dmc - dm->TH_L2H_ini;*/
+	/*lowest_IGI_upper = IGI_target - diff;*/
+	/*if ((adaptivity_igi_upper - lowest_IGI_upper) <= 5)*/
+
+	if (adaptivity_igi_upper <= 0x26)
+		return true;
+	else
+		return false;
+}
+
+void
+phydm_adaptivity_info_init(
+	void				*dm_void,
+	enum phydm_adapinfo	cmn_info,
+	u32				value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	switch (cmn_info)	{
+	case PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE:
+		dm->carrier_sense_enable = (boolean)value;
+		break;
+
+	case PHYDM_ADAPINFO_DCBACKOFF:
+		dm->dc_backoff = (u8)value;
+		break;
+
+	case PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY:
+		adaptivity->dynamic_link_adaptivity = (boolean)value;
+		break;
+
+	case PHYDM_ADAPINFO_TH_L2H_INI:
+		dm->th_l2h_ini = (s8)value;
+		break;
+
+	case PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF:
+		dm->th_edcca_hl_diff = (s8)value;
+		break;
+
+	case PHYDM_ADAPINFO_AP_NUM_TH:
+		adaptivity->ap_num_th = (u8)value;
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+void
+phydm_adaptivity_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	s8	igi_target = 0x32;
+	/*struct phydm_dig_struct* dig_t = &dm->dm_dig_table;*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_WIN))
+
+	if (dm->carrier_sense_enable == false) {
+		if (dm->th_l2h_ini == 0)
+			phydm_set_l2h_th_ini(dm);
+	} else
+		dm->th_l2h_ini = 0xa;
+
+	if (dm->th_edcca_hl_diff == 0)
+		dm->th_edcca_hl_diff = 7;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	if (dm->wifi_test == true || *dm->mp_mode == true)
+#else
+	if ((dm->wifi_test & RT_WIFI_LOGO) == true)
+#endif
+		dm->edcca_enable = false;		/*even no adaptivity, we still enable EDCCA, AP side use mib control*/
+	else
+		dm->edcca_enable = true;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	if (dm->carrier_sense_enable) {
+		dm->th_l2h_ini = 0xa;
+		dm->th_edcca_hl_diff = 7;
+	} else {
+		dm->th_l2h_ini = dm->TH_L2H_default;	/*set by mib*/
+		dm->th_edcca_hl_diff = dm->th_edcca_hl_diff_default;
+	}
+
+	if (priv->pshare->rf_ft_var.adaptivity_enable == 2)
+		adaptivity->dynamic_link_adaptivity = true;
+	else
+		adaptivity->dynamic_link_adaptivity = false;
+
+#endif
+
+	adaptivity->adapt_igi_up = 0;
+	dm->adaptivity_enable = false;	/*use this flag to decide enable or disable*/
+
+	dm->th_l2h_ini_mode2 = 20;
+	dm->th_edcca_hl_diff_mode2 = 8;
+	adaptivity->debug_mode = false;
+	adaptivity->th_l2h_ini_backup = dm->th_l2h_ini;
+	adaptivity->th_edcca_hl_diff_backup = dm->th_edcca_hl_diff;
+
+	adaptivity->igi_base = 0x32;
+	adaptivity->igi_target = 0x1c;
+	adaptivity->h2l_lb = 0;
+	adaptivity->l2h_lb = 0;
+	adaptivity->is_check = false;
+	adaptivity->adajust_igi_level = 0;
+	adaptivity->is_stop_edcca = false;
+	adaptivity->backup_h2l = 0;
+	adaptivity->backup_l2h = 0;
+	adaptivity->adaptivity_dbg_port = (dm->support_ic_type & ODM_IC_11N_SERIES) ? 0x208 : 0x209;
+
+	phydm_mac_edcca_state(dm, phydm_dont_ignore_edcca);
+
+	if (dm->support_ic_type & ODM_IC_11N_GAIN_IDX_EDCCA) {
+		/*odm_set_bb_reg(dm, ODM_REG_EDCCA_DOWN_OPT_11N, BIT(12) | BIT(11) | BIT(10), 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
+		if (dm->support_ic_type & ODM_RTL8197F) {
+			odm_set_bb_reg(dm, ODM_REG_PAGE_B1_97F, BIT(30), 0x1);								/*set to page B1*/
+			odm_set_bb_reg(dm, ODM_REG_EDCCA_DCNF_97F, BIT(27) | BIT(26), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+			odm_set_bb_reg(dm, ODM_REG_PAGE_B1_97F, BIT(30), 0x0);
+		} else
+			odm_set_bb_reg(dm, ODM_REG_EDCCA_DCNF_11N, BIT(21) | BIT(20), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+	}
+#if (RTL8195A_SUPPORT == 0)
+	if (dm->support_ic_type & ODM_IC_11AC_GAIN_IDX_EDCCA) {		/*8814a no need to find pwdB lower bound, maybe*/
+		/*odm_set_bb_reg(dm, ODM_REG_EDCCA_DOWN_OPT, BIT(30) | BIT(29) | BIT(28), 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
+		odm_set_bb_reg(dm, ODM_REG_ACBB_EDCCA_ENHANCE, BIT(29) | BIT(28), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+	}
+
+	if (!(dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA))) {
+		phydm_search_pwdb_lower_bound(dm);
+		if (phydm_re_search_condition(dm))
+			phydm_search_pwdb_lower_bound(dm);
+	} else
+		phydm_set_edcca_threshold(dm, 0x7f, 0x7f);				/*resume to no link state*/
+#endif
+	/*forgetting factor setting*/
+	phydm_set_forgetting_factor(dm);
+
+	/*pwdb mode setting with 0: mean, 1:max*/
+	phydm_set_pwdb_mode(dm);
+
+	/*we need to consider PwdB upper bound for 8814 later IC*/
+	adaptivity->adajust_igi_level = (u8)((dm->th_l2h_ini + igi_target) - pwdb_upper_bound + dfir_loss);	/*IGI = L2H - PwdB - dfir_loss*/
+
+	/*Check this later on Windows*/
+	/*phydm_set_edcca_threshold_api(dm, dig_t->cur_ig_value);*/
+
+	dm->adaptivity_flag = (dm->support_ic_type & ODM_IC_GAIN_IDX_EDCCA) ? false : true;
+	
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	adaptivity->igi_up_bound_lmt_val = 180;
+#else
+	adaptivity->igi_up_bound_lmt_val = 90;
+#endif
+	adaptivity->igi_up_bound_lmt_cnt = 0;
+	adaptivity->igi_lmt_en = false;
+
+}
+
+
+void
+phydm_adaptivity(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct			*dig_t = &dm->dm_dig_table;
+	u8			igi = dig_t->cur_ig_value;
+	s8			th_l2h_dmc, th_h2l_dmc;
+	s8			diff = 0, igi_target = 0x32;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PADAPTER    adapter	= (PADAPTER)dm->adapter;
+	u32			is_fw_current_in_ps_mode = false;
+	u8			disable_ap_adapt_setting;
+
+	adapter->HalFunc.GetHwRegHandler(adapter, HW_VAR_FW_PSMODE_STATUS, (u8 *)(&is_fw_current_in_ps_mode));
+
+	/*Disable EDCCA mode while under LPS mode, added by Roger, 2012.09.14.*/
+	if (is_fw_current_in_ps_mode)
+		return;
+#endif
+
+	if (!dm->edcca_enable || adaptivity->is_stop_edcca) {
+		PHYDM_DBG(dm, DBG_ADPTVTY, "Disable EDCCA!!!\n");
+		return;
+	}
+
+	phydm_check_adaptivity(dm);	/*Check adaptivity enable*/
+	phydm_dig_up_bound_lmt_en(dm);
+
+	if ((!(dm->support_ability & ODM_BB_ADAPTIVITY)) && adaptivity->debug_mode == false) {
+		PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity disable, enable EDCCA mode!!!\n");
+		dm->th_l2h_ini = dm->th_l2h_ini_mode2;
+		dm->th_edcca_hl_diff = dm->th_edcca_hl_diff_mode2;
+	}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	else if (adaptivity->debug_mode == false) {
+		disable_ap_adapt_setting = false;
+		if (dm->soft_ap_mode != NULL) {
+			if (*dm->soft_ap_mode != 0 && (dm->soft_ap_special_setting & BIT(0)))
+				disable_ap_adapt_setting = true;
+			PHYDM_DBG(dm, DBG_ADPTVTY, "soft_ap_setting = %x, soft_ap = %d, dis_ap_adapt = %d\n", 
+				dm->soft_ap_special_setting, *dm->soft_ap_mode, disable_ap_adapt_setting);
+		}
+		if (phydm_check_channel_plan(dm) || (dm->ap_total_num > adaptivity->ap_num_th) || disable_ap_adapt_setting) {
+			dm->th_l2h_ini = dm->th_l2h_ini_mode2;
+			dm->th_edcca_hl_diff = dm->th_edcca_hl_diff_mode2;
+		} else {
+			dm->th_l2h_ini = adaptivity->th_l2h_ini_backup;
+			dm->th_edcca_hl_diff = adaptivity->th_edcca_hl_diff_backup;
+		}
+	}
+#endif
+	else if (adaptivity->debug_mode == true) {
+		dm->th_l2h_ini = adaptivity->th_l2h_ini_debug;
+		dm->th_edcca_hl_diff = 7;
+		adaptivity->adajust_igi_level = (u8)((dm->th_l2h_ini + igi_target) - pwdb_upper_bound + dfir_loss);	/*IGI = L2H - PwdB - dfir_loss*/
+	}
+	PHYDM_DBG(dm, DBG_ADPTVTY, "odm_Adaptivity() =====>\n");
+	PHYDM_DBG(dm, DBG_ADPTVTY, "igi_base=0x%x, th_l2h_ini = %d, th_edcca_hl_diff = %d\n",
+		adaptivity->igi_base, dm->th_l2h_ini, dm->th_edcca_hl_diff);
+#if (RTL8195A_SUPPORT == 0)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		/*fix AC series when enable EDCCA hang issue*/
+		odm_set_bb_reg(dm, 0x800, BIT(10), 1);	/*ADC_mask disable*/
+		odm_set_bb_reg(dm, 0x800, BIT(10), 0);	/*ADC_mask enable*/
+	}
+#endif
+
+	igi_target = adaptivity->igi_base;
+	adaptivity->igi_target = (u8) igi_target;
+
+	PHYDM_DBG(dm, DBG_ADPTVTY, "band_width=%s, igi_target=0x%x, dynamic_link_adaptivity = %d\n",
+		(*dm->band_width == CHANNEL_WIDTH_80) ? "80M" : ((*dm->band_width == CHANNEL_WIDTH_40) ? "40M" : "20M"), igi_target, adaptivity->dynamic_link_adaptivity);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "adajust_igi_level= 0x%x, adaptivity_flag = %d, adaptivity_enable = %d\n",
+		adaptivity->adajust_igi_level, dm->adaptivity_flag, dm->adaptivity_enable);
+
+	if (adaptivity->dynamic_link_adaptivity && (!dm->is_linked) && !dm->adaptivity_enable) {
+		phydm_set_edcca_threshold(dm, 0x7f, 0x7f);
+		PHYDM_DBG(dm, DBG_ADPTVTY, "In DynamicLink mode(noisy) and No link, Turn off EDCCA!!\n");
+		return;
+	}
+
+	if (dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+		if ((adaptivity->adajust_igi_level > igi) && dm->adaptivity_enable)
+			diff = adaptivity->adajust_igi_level - igi;
+		else if (dm->adaptivity_enable == false)
+			diff = 0x3e - igi;
+
+		th_l2h_dmc = dm->th_l2h_ini - diff + igi_target;
+		th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+	}
+#if (RTL8195A_SUPPORT == 0)
+	else	{
+		diff = igi_target - (s8)igi;
+		th_l2h_dmc = dm->th_l2h_ini + diff;
+		if (th_l2h_dmc > 10 && dm->adaptivity_enable)
+			th_l2h_dmc = 10;
+
+		th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+
+		/*replace lower bound to prevent EDCCA always equal 1*/
+		if (th_h2l_dmc < adaptivity->h2l_lb)
+			th_h2l_dmc = adaptivity->h2l_lb;
+		if (th_l2h_dmc < adaptivity->l2h_lb)
+			th_l2h_dmc = adaptivity->l2h_lb;
+	}
+#endif
+	adaptivity->th_l2h = th_l2h_dmc;
+	adaptivity->th_h2l = th_h2l_dmc;
+	PHYDM_DBG(dm, DBG_ADPTVTY, "IGI=0x%x, th_l2h_dmc = %d, th_h2l_dmc = %d\n", igi, th_l2h_dmc, th_h2l_dmc);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "adapt_igi_up=0x%x, h2l_lb = 0x%x, l2h_lb = 0x%x\n", adaptivity->adapt_igi_up, adaptivity->h2l_lb, adaptivity->l2h_lb);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "debug_mode = %d\n", adaptivity->debug_mode);
+	phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+
+	if (dm->adaptivity_enable == true)
+		odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 1);
+
+	return;
+}
+
+/*This API is for solving USB can't Tx problem due to USB3.0 interference in 2.4G*/
+void
+phydm_pause_edcca(
+	void	*dm_void,
+	boolean	is_pasue_edcca
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8	IGI = dig_t->cur_ig_value;
+	s8	diff = 0;
+
+	if (is_pasue_edcca) {
+		adaptivity->is_stop_edcca = true;
+
+		if (dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+			if (adaptivity->adajust_igi_level > IGI)
+				diff = adaptivity->adajust_igi_level - IGI;
+
+			adaptivity->backup_l2h = dm->th_l2h_ini - diff + adaptivity->igi_target;
+			adaptivity->backup_h2l = adaptivity->backup_l2h - dm->th_edcca_hl_diff;
+		}
+#if (RTL8195A_SUPPORT == 0)
+		else {
+			diff = adaptivity->igi_target - (s8)IGI;
+			adaptivity->backup_l2h = dm->th_l2h_ini + diff;
+			if (adaptivity->backup_l2h > 10)
+				adaptivity->backup_l2h = 10;
+
+			adaptivity->backup_h2l = adaptivity->backup_l2h - dm->th_edcca_hl_diff;
+
+			/*replace lower bound to prevent EDCCA always equal 1*/
+			if (adaptivity->backup_h2l < adaptivity->h2l_lb)
+				adaptivity->backup_h2l = adaptivity->h2l_lb;
+			if (adaptivity->backup_l2h < adaptivity->l2h_lb)
+				adaptivity->backup_l2h = adaptivity->l2h_lb;
+		}
+#endif
+		PHYDM_DBG(dm, DBG_ADPTVTY, "pauseEDCCA : L2Hbak = 0x%x, H2Lbak = 0x%x, IGI = 0x%x\n", adaptivity->backup_l2h, adaptivity->backup_h2l, IGI);
+
+		/*Disable EDCCA*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (odm_is_work_item_scheduled(&adaptivity->phydm_pause_edcca_work_item) == false)
+			odm_schedule_work_item(&adaptivity->phydm_pause_edcca_work_item);
+#else
+		phydm_pause_edcca_work_item_callback(dm);
+#endif
+
+	} else {
+		adaptivity->is_stop_edcca = false;
+		PHYDM_DBG(dm, DBG_ADPTVTY, "resumeEDCCA : L2Hbak = 0x%x, H2Lbak = 0x%x, IGI = 0x%x\n", adaptivity->backup_l2h, adaptivity->backup_h2l, IGI);
+		/*Resume EDCCA*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (odm_is_work_item_scheduled(&adaptivity->phydm_resume_edcca_work_item) == false)
+			odm_schedule_work_item(&adaptivity->phydm_resume_edcca_work_item);
+#else
+		phydm_resume_edcca_work_item_callback(dm);
+#endif
+
+	}
+
+}
+
+
+void
+phydm_pause_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)(0x7f | 0x7f << 16));
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_set_bb_reg(dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)(0x7f | 0x7f << 8));
+#endif
+
+}
+
+void
+phydm_resume_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)((u8)adaptivity->backup_l2h | (u8)adaptivity->backup_h2l << 16));
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_set_bb_reg(dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)((u8)adaptivity->backup_l2h | (u8)adaptivity->backup_h2l << 8));
+#endif
+
+}
+
+
+void
+phydm_set_edcca_threshold_api(
+	void	*dm_void,
+	u8	IGI
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	s8			th_l2h_dmc, th_h2l_dmc;
+	s8			diff = 0, igi_target = 0x32;
+
+	if (dm->support_ability & ODM_BB_ADAPTIVITY) {
+		if (dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+			if (adaptivity->adajust_igi_level > IGI)
+				diff = adaptivity->adajust_igi_level - IGI;
+
+			th_l2h_dmc = dm->th_l2h_ini - diff + igi_target;
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+		}
+#if (RTL8195A_SUPPORT == 0)
+		else	{
+			diff = igi_target - (s8)IGI;
+			th_l2h_dmc = dm->th_l2h_ini + diff;
+			if (th_l2h_dmc > 10)
+				th_l2h_dmc = 10;
+
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+
+			/*replace lower bound to prevent EDCCA always equal 1*/
+			if (th_h2l_dmc < adaptivity->h2l_lb)
+				th_h2l_dmc = adaptivity->h2l_lb;
+			if (th_l2h_dmc < adaptivity->l2h_lb)
+				th_l2h_dmc = adaptivity->l2h_lb;
+		}
+#endif
+		PHYDM_DBG(dm, DBG_ADPTVTY, "API :IGI=0x%x, th_l2h_dmc = %d, th_h2l_dmc = %d\n", IGI, th_l2h_dmc, th_h2l_dmc);
+		PHYDM_DBG(dm, DBG_ADPTVTY, "API :adapt_igi_up=0x%x, h2l_lb = 0x%x, l2h_lb = 0x%x\n", adaptivity->adapt_igi_up, adaptivity->h2l_lb, adaptivity->l2h_lb);
+
+		phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+	}
+}
+
+void
+phydm_adaptivity_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 reg_value32;
+	s8 h2l_diff = 0;
+
+	if (dm_value[0] == PHYDM_ADAPT_DEBUG) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Adaptivity Debug Mode ===>\n");
+		adaptivity->debug_mode = true;
+		adaptivity->th_l2h_ini_debug = (s8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "th_l2h_ini_debug = %d\n",
+			       adaptivity->th_l2h_ini_debug);
+	} else if (dm_value[0] == PHYDM_ADAPT_RESUME) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "===> Adaptivity Resume\n");
+		adaptivity->debug_mode = false;
+	} else if (dm_value[0] == PHYDM_EDCCA_TH_PAUSE) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "EDCCA Threshold Pause\n");
+		dm->edcca_enable = false;
+	} else if (dm_value[0] == PHYDM_EDCCA_RESUME) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "EDCCA Resume\n");
+		dm->edcca_enable = true;
+	} else if (dm_value[0] == PHYDM_ADAPT_MSG) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "debug_mode = %s, th_l2h_ini = %d\n",
+			       (adaptivity->debug_mode ? "TRUE" : "FALSE"),
+			       dm->th_l2h_ini);
+		if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			reg_value32 = odm_get_bb_reg(dm, 0xc4c, MASKDWORD);
+			h2l_diff = (s8)(0x000000ff & reg_value32) - (s8)((0x00ff0000 & reg_value32)>>16);
+		}
+#if (RTL8195A_SUPPORT == 0)
+		else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			reg_value32 = odm_get_bb_reg(dm, 0x8a4, MASKDWORD);
+			h2l_diff = (s8)(0x000000ff & reg_value32) - (s8)((0x0000ff00 & reg_value32)>>8);
+		}
+#endif
+		if (h2l_diff == 7)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "adaptivity is enabled\n");
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "adaptivity is disabled\n");
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_set_l2h_th_ini(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
+			dm->th_l2h_ini = 0xf2;
+		else
+			dm->th_l2h_ini = 0xef;
+	} else
+		dm->th_l2h_ini = 0xf5;
+}
+
+void
+phydm_set_forgetting_factor(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
+		odm_set_bb_reg(dm, 0x8a0, BIT(1) | BIT(0), 0);
+}
+
+void
+phydm_set_pwdb_mode(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ability & ODM_BB_ADAPTIVITY) {
+		if (dm->support_ic_type & ODM_RTL8822B)
+			odm_set_bb_reg(dm, 0x8dc, BIT(5), 0x1);
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0xce8, BIT(13), 0x1);
+	} else {
+		if (dm->support_ic_type & ODM_RTL8822B)
+			odm_set_bb_reg(dm, 0x8dc, BIT(5), 0x0);
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0xce8, BIT(13), 0x0);
+	}
+}
+
+void
+phydm_set_edcca_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (val_len != 2) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][adaptivity]Need val_len = 2\n");
+		return;
+	}
+	if (dm->pause_ability & BIT(F13_ADPTVTY))
+		dm->adaptivity.is_stop_edcca = true;
+	else
+		dm->adaptivity.is_stop_edcca = false;
+
+	phydm_set_edcca_threshold(dm, (s8)val_buf[1], (s8)val_buf[0]);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adaptivity.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adaptivity.h
new file mode 100644
index 000000000000..f1edb5c12344
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adaptivity.h
@@ -0,0 +1,217 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDMADAPTIVITY_H__
+#define    __PHYDMADAPTIVITY_H__
+
+#define ADAPTIVITY_VERSION	"9.5.7"	/*20170627 changed by Kevin, move adapt_igi_up from phydm.h to phydm_adaptivity.h*/
+
+#define pwdb_upper_bound	7
+#define dfir_loss	7
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+enum phydm_regulation_type {
+	REGULATION_FCC		= 0,
+	REGULATION_MKK		= 1,
+	REGULATION_ETSI		= 2,
+	REGULATION_WW		= 3,
+	MAX_REGULATION_NUM	= 4
+};
+#endif
+
+enum phydm_adapinfo {
+	PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE = 0,
+	PHYDM_ADAPINFO_DCBACKOFF,
+	PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY,
+	PHYDM_ADAPINFO_TH_L2H_INI,
+	PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF,
+	PHYDM_ADAPINFO_AP_NUM_TH
+};
+
+enum phydm_set_lna {
+	phydm_disable_lna		= 0,
+	phydm_enable_lna		= 1,
+};
+
+enum phydm_trx_mux_type {
+	phydm_shutdown			= 0,
+	phydm_standby_mode		= 1,
+	phydm_tx_mode			= 2,
+	phydm_rx_mode			= 3
+};
+
+enum phydm_mac_edcca_type {
+	phydm_ignore_edcca			= 0,
+	phydm_dont_ignore_edcca		= 1
+};
+
+enum phydm_adaptivity_mode {
+	PHYDM_ADAPT_MSG			= 0,
+	PHYDM_ADAPT_DEBUG		= 1,
+	PHYDM_ADAPT_RESUME		= 2,
+	PHYDM_EDCCA_TH_PAUSE	= 3,
+	PHYDM_EDCCA_RESUME		= 4
+};
+
+struct phydm_adaptivity_struct {
+	s8			th_l2h_ini_backup;
+	s8			th_edcca_hl_diff_backup;
+	s8			igi_base;
+	u8			igi_target;
+	s8			h2l_lb;
+	s8			l2h_lb;
+	boolean		is_check;
+	boolean		dynamic_link_adaptivity;
+	u8			ap_num_th;
+	u8			adajust_igi_level;
+	s8			backup_l2h;
+	s8			backup_h2l;
+	boolean			is_stop_edcca;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_WORK_ITEM	phydm_pause_edcca_work_item;
+	RT_WORK_ITEM	phydm_resume_edcca_work_item;
+#endif
+	u32			adaptivity_dbg_port; /*N:0x208, AC:0x209*/
+	u8			debug_mode;
+	s8			th_l2h_ini_debug;
+	u16			igi_up_bound_lmt_cnt;	/*When igi_up_bound_lmt_cnt !=0, limit IGI upper bound to "adapt_igi_up"*/
+	u16			igi_up_bound_lmt_val;	/*max value of igi_up_bound_lmt_cnt*/
+	boolean		igi_lmt_en;
+	u8			adapt_igi_up;
+	s8			rvrt_val[2];
+	s8			th_l2h;
+	s8			th_h2l;
+};
+
+void
+phydm_pause_edcca(
+	void	*dm_void,
+	boolean	is_pasue_edcca
+);
+
+void
+phydm_check_environment(
+	void					*dm_void
+);
+
+void
+phydm_mac_edcca_state(
+	void					*dm_void,
+	enum phydm_mac_edcca_type		state
+);
+
+void
+phydm_set_edcca_threshold(
+	void		*dm_void,
+	s8		H2L,
+	s8		L2H
+);
+
+void
+phydm_set_trx_mux(
+	void			*dm_void,
+	enum phydm_trx_mux_type			tx_mode,
+	enum phydm_trx_mux_type			rx_mode
+);
+
+void
+phydm_search_pwdb_lower_bound(
+	void					*dm_void
+);
+
+void
+phydm_adaptivity_info_init(
+	void			*dm_void,
+	enum phydm_adapinfo	cmn_info,
+	u32				value
+);
+
+void
+phydm_adaptivity_init(
+	void					*dm_void
+);
+
+void
+phydm_adaptivity(
+	void			*dm_void
+);
+
+void
+phydm_set_edcca_threshold_api(
+	void	*dm_void,
+	u8	IGI
+);
+
+void
+phydm_pause_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+phydm_resume_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+phydm_adaptivity_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_set_l2h_th_ini(
+	void		*dm_void
+);
+
+void
+phydm_set_forgetting_factor(
+	void		*dm_void
+);
+
+void
+phydm_set_pwdb_mode(
+	void		*dm_void
+);
+
+void
+phydm_set_edcca_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adc_sampling.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adc_sampling.c
new file mode 100644
index 000000000000..55bb013e21bc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adc_sampling.c
@@ -0,0 +1,790 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#if ((RTL8197F_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
+		#include "rtl8197f/Hal8197FPhyReg.h"
+		#include "WlanHAL/HalMac88XX/halmac_reg2.h"
+	#else
+		#include "WlanHAL/HalHeader/HalComReg.h"
+	#endif
+#endif
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#if WPP_SOFTWARE_TRACE
+	#include "phydm_adc_sampling.tmh"
+#endif
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+boolean
+phydm_la_buffer_allocate(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+#endif
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	boolean	ret = true;
+
+	pr_debug("[LA mode BufferAllocate]\n");
+
+	if (adc_smp_buf->length == 0) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (PlatformAllocateMemoryWithZero(adapter, (void **)&adc_smp_buf->octet, adc_smp_buf->buffer_size) != RT_STATUS_SUCCESS)
+			ret = false;
+#else
+		odm_allocate_memory(dm, (void **)&adc_smp_buf->octet, adc_smp_buf->buffer_size);
+
+		if (!adc_smp_buf->octet)
+			ret = false;
+#endif
+
+		if (ret)
+			adc_smp_buf->length = adc_smp_buf->buffer_size;
+	}
+
+	return ret;
+}
+#endif
+
+void
+phydm_la_get_tx_pkt_buf(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	u32				i = 0, value32, data_l = 0, data_h = 0;
+	u32				addr, finish_addr;
+	u32				end_addr = (adc_smp_buf->start_pos  + adc_smp_buf->buffer_size) - 1;	/*end_addr = 0x3ffff;*/
+	boolean				is_round_up;
+	static u32			page = 0xFF;
+	u32				smp_cnt = 0, smp_number = 0, addr_8byte = 0;
+	u8				backup_dma = 0;
+
+	odm_memory_set(dm, adc_smp_buf->octet, 0, adc_smp_buf->length);
+	odm_write_1byte(dm, 0x0106, 0x69);
+
+	pr_debug("GetTxPktBuf\n");
+
+	value32 = odm_read_4byte(dm, 0x7c0);
+	is_round_up = (boolean)((value32 & BIT(31)) >> 31);
+	finish_addr = (value32 & 0x7FFF0000) >> 16;	/*Reg7C0[30:16]: finish addr (unit: 8byte)*/
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		odm_set_bb_reg(dm, 0x7c0, BIT(0), 0x0);
+		
+		/*Stop DMA*/
+		backup_dma = odm_get_mac_reg(dm, 0x300, MASKLWORD);
+		odm_set_mac_reg(dm, 0x300, 0x7fff, 0x7fff);
+
+		/*move LA mode content from IMEM to TxPktBuffer
+			Source : OCPBASE_IMEM 0x00000000
+			Destination : OCPBASE_TXBUF 0x18780000
+			Length : 64K*/
+		GET_HAL_INTERFACE(dm->priv)->init_ddma_handler(dm->priv, OCPBASE_IMEM, OCPBASE_TXBUF, 0x10000);
+	}
+	#endif
+	#endif
+
+	if (is_round_up) {
+		addr = (finish_addr + 1) << 3;
+		pr_debug("is_round_up = ((%d)), finish_addr=((0x%x)), 0x7c0=((0x%x))\n", is_round_up, finish_addr, value32);
+		smp_number = ((adc_smp_buf->buffer_size) >> 3);	/*Byte to 8Byte (64bit)*/
+	} else	 {
+		addr = adc_smp_buf->start_pos;
+		addr_8byte = addr >> 3;
+		
+		if (addr_8byte > finish_addr)
+			smp_number = addr_8byte - finish_addr;
+		else
+			smp_number = finish_addr - addr_8byte;
+
+		pr_debug("is_round_up = ((%d)), finish_addr=((0x%x * 8Byte)), Start_Addr = ((0x%x * 8Byte)), smp_number = ((%d))\n", is_round_up, finish_addr, addr_8byte, smp_number);
+
+	}
+	/*
+	dbg_print("is_round_up = %d, finish_addr=0x%x, value32=0x%x\n", is_round_up, finish_addr, value32);
+	dbg_print("end_addr = %x, adc_smp_buf->start_pos = 0x%x, adc_smp_buf->buffer_size = 0x%x\n", end_addr, adc_smp_buf->start_pos, adc_smp_buf->buffer_size);
+	*/
+
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		for (addr = 0x0, i = 0; addr < end_addr; addr += 8, i += 2) {	/*64K byte*/
+			if ((addr & 0xfff) == 0)
+				odm_set_bb_reg(dm, 0x0140, MASKLWORD, 0x780 + (addr >> 12));
+			data_l = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff), MASKDWORD);
+			data_h = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff) + 4, MASKDWORD);
+
+			pr_debug("%08x%08x\n", data_h, data_l);
+		}
+	} else {
+	
+		i = 0;
+		while (addr != (finish_addr << 3)) {
+			if (page != (addr >> 12)) {
+				/*Reg140=0x780+(addr>>12), addr=0x30~0x3F, total 16 pages*/
+				page = (addr >> 12);
+			}
+			odm_set_bb_reg(dm, 0x0140, MASKLWORD, 0x780 + page);
+
+			/*pDataL = 0x8000+(addr&0xfff);*/
+			data_l = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff), MASKDWORD);
+			data_h = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff) + 4, MASKDWORD);
+
+			#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+			adc_smp_buf->octet[i] = data_h;
+			adc_smp_buf->octet[i + 1] = data_l;
+			#endif
+
+		#if DBG /*WIN driver check build*/
+			pr_debug("%08x%08x\n", data_h, data_l);
+		#else	/*WIN driver free build*/
+			#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("%08x%08x\n", adc_smp_buf->octet[i], adc_smp_buf->octet[i + 1]));
+			#endif
+		#endif
+
+			i = i + 2;
+
+			if ((addr + 8) >= end_addr)
+				addr = adc_smp_buf->start_pos;
+			else
+				addr = addr + 8;
+
+			smp_cnt++;
+			if (smp_cnt >= (smp_number - 1))
+				break;
+		}
+		pr_debug("smp_cnt = ((%d))\n", smp_cnt);
+		
+		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("smp_cnt = ((%d))\n", smp_cnt));
+		#endif
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		odm_set_mac_reg(dm, 0x300, 0x7fff, backup_dma);	/*Resume DMA*/
+	#endif
+	#endif
+}
+
+void
+phydm_la_mode_set_mac_iq_dump(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+	u32			reg_value;
+
+	odm_write_1byte(dm, 0x7c0, 0);		/*clear all 0x7c0*/
+	odm_set_mac_reg(dm, 0x7c0, BIT(0), 1);  /*Enable LA mode HW block*/
+
+	if (adc_smp->la_trig_mode == PHYDM_MAC_TRIG) {
+		adc_smp->is_bb_trigger = 0;
+		odm_set_mac_reg(dm, 0x7c0, BIT(2), 1); /*polling bit for MAC mode*/
+		odm_set_mac_reg(dm, 0x7c0, BIT(4) | BIT(3), adc_smp->la_trigger_edge); /*trigger mode for MAC*/
+
+		pr_debug("[MAC_trig] ref_mask = ((0x%x)), ref_value = ((0x%x)), dbg_port = ((0x%x))\n", adc_smp->la_mac_mask_or_hdr_sel, adc_smp->la_trig_sig_sel, adc_smp->la_dbg_port);
+		/*[Set MAC Debug Port]*/
+		odm_set_mac_reg(dm, 0xF4, BIT(16), 1);
+		odm_set_mac_reg(dm, 0x38, 0xff0000, adc_smp->la_dbg_port);
+		odm_set_mac_reg(dm, 0x7c4, MASKDWORD, adc_smp->la_mac_mask_or_hdr_sel);
+		odm_set_mac_reg(dm, 0x7c8, MASKDWORD, adc_smp->la_trig_sig_sel);
+
+	} else {
+		adc_smp->is_bb_trigger = 1;
+		odm_set_mac_reg(dm, 0x7c0, BIT(1), 1); /*polling bit for BB ADC mode*/
+
+		if (adc_smp->la_trig_mode == PHYDM_ADC_MAC_TRIG) {
+			odm_set_mac_reg(dm, 0x7c0, BIT(3), 1); /*polling bit for MAC trigger event*/
+			odm_set_mac_reg(dm, 0x7c0, BIT(7) | BIT(6), adc_smp->la_trig_sig_sel);
+
+			if (adc_smp->la_trig_sig_sel == ADCSMP_TRIG_REG)
+				odm_set_mac_reg(dm, 0x7c0, BIT(5), 1); /* manual trigger 0x7C0[5] = 0->1*/
+		}
+	}
+
+	reg_value = odm_get_bb_reg(dm, 0x7c0, 0xff);
+	pr_debug("4. [Set MAC IQ dump] 0x7c0[7:0] = ((0x%x))\n", reg_value);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("4. [Set MAC IQ dump] 0x7c0[7:0] = ((0x%x))\n", reg_value));
+#endif
+
+}
+
+void
+phydm_adc_smp_start(
+	void			*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp				*adc_smp = &dm->adcsmp;
+	u8					tmp_u1b;
+	u8					while_cnt = 0;
+	u8					polling_ok = false, target_polling_bit;
+
+	phydm_la_mode_bb_setting(dm);
+	phydm_la_mode_set_trigger_time(dm, adc_smp->la_trigger_time);
+
+	if (dm->support_ic_type & ODM_RTL8197F)
+		odm_set_bb_reg(dm, 0xd00, BIT(26), 0x1);
+	else {	/*for 8814A and 8822B?*/
+		odm_write_1byte(dm, 0x8b4, 0x80);
+		/* odm_set_bb_reg(dm, 0x8b4, BIT(7), 1); */
+	}
+
+	phydm_la_mode_set_mac_iq_dump(dm);
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	watchdog_stop(dm->priv);
+	#endif
+
+	target_polling_bit = (adc_smp->is_bb_trigger) ? BIT(1) : BIT(2);
+	do { /*Polling time always use 100ms, when it exceed 2s, break while loop*/
+		tmp_u1b = odm_read_1byte(dm, 0x7c0);
+
+		if (adc_smp->adc_smp_state != ADCSMP_STATE_SET) {
+			pr_debug("[state Error] adc_smp_state != ADCSMP_STATE_SET\n");
+			break;
+
+		} else if (tmp_u1b & target_polling_bit) {
+			ODM_delay_ms(100);
+			while_cnt = while_cnt + 1;
+			continue;
+		} else {
+			pr_debug("[LA Query OK] polling_bit=((0x%x))\n", target_polling_bit);
+			polling_ok = true;
+			break;
+		}
+	} while (while_cnt < 20);
+
+	if (adc_smp->adc_smp_state == ADCSMP_STATE_SET) {
+		if (polling_ok)
+			phydm_la_get_tx_pkt_buf(dm);
+		else
+			pr_debug("[Polling timeout]\n");
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	watchdog_resume(dm->priv);
+	#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (adc_smp->adc_smp_state == ADCSMP_STATE_SET)
+		adc_smp->adc_smp_state = ADCSMP_STATE_QUERY;
+#endif
+
+	pr_debug("[LA mode] LA_pattern_count = ((%d))\n", adc_smp->la_count);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("[LA mode] la_count = ((%d))\n", adc_smp->la_count));
+#endif
+
+
+	adc_smp_stop(dm);
+
+	if (adc_smp->la_count == 0) {
+		pr_debug("LA Dump finished ---------->\n\n\n");
+		phydm_release_bb_dbg_port(dm);
+		
+		if ((dm->support_ic_type & ODM_RTL8821C) && (dm->cut_version >= ODM_CUT_B))
+			odm_set_bb_reg(dm, 0x95c, BIT(23), 0);
+
+	} else {
+		adc_smp->la_count--;
+		pr_debug("LA Dump more ---------->\n\n\n");
+		adc_smp_set(dm, adc_smp->la_trig_mode, adc_smp->la_trig_sig_sel, adc_smp->la_dma_type, adc_smp->la_trigger_time, 0);
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+void
+adc_smp_work_item_callback(
+	void	*context
+)
+{
+	void			*adapter = (void *)context;
+	PHAL_DATA_TYPE		hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+
+	pr_debug("[WorkItem Call back] LA_State=((%d))\n", adc_smp->adc_smp_state);
+	phydm_adc_smp_start(dm);
+}
+#endif
+
+void
+adc_smp_set(
+	void	*dm_void,
+	u8	trig_mode,
+	u32	trig_sig_sel,
+	u8	dma_data_sig_sel,
+	u32	trigger_time,
+	u16	polling_time
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	boolean				is_set_success = true;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+
+	adc_smp->la_trig_mode = trig_mode;
+	adc_smp->la_trig_sig_sel = trig_sig_sel;
+	adc_smp->la_dma_type = dma_data_sig_sel;
+	adc_smp->la_trigger_time = trigger_time;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (adc_smp->adc_smp_state != ADCSMP_STATE_IDLE)
+		is_set_success = false;
+	else if (adc_smp->adc_smp_buf.length == 0)
+		is_set_success = phydm_la_buffer_allocate(dm);
+#endif
+
+	if (is_set_success) {
+		adc_smp->adc_smp_state = ADCSMP_STATE_SET;
+
+		pr_debug("[LA Set Success] LA_State=((%d))\n", adc_smp->adc_smp_state);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+		pr_debug("ADCSmp_work_item_index = ((%d))\n", adc_smp->la_work_item_index);
+		if (adc_smp->la_work_item_index != 0) {
+			odm_schedule_work_item(&adc_smp->adc_smp_work_item_1);
+			adc_smp->la_work_item_index = 0;
+		} else {
+			odm_schedule_work_item(&adc_smp->adc_smp_work_item);
+			adc_smp->la_work_item_index = 1;
+		}
+#else
+		phydm_adc_smp_start(dm);
+#endif
+	} else
+		pr_debug("[LA Set Fail] LA_State=((%d))\n", adc_smp->adc_smp_state);
+
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+enum rt_status
+adc_smp_query(
+	void				*dm_void,
+	ULONG				information_buffer_length,
+	void				*information_buffer,
+	PULONG				bytes_written
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	enum rt_status			ret_status = RT_STATUS_SUCCESS;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	pr_debug("[%s] LA_State=((%d))", __func__, adc_smp->adc_smp_state);
+
+	if (information_buffer_length != adc_smp_buf->buffer_size)	{
+		*bytes_written = 0;
+		ret_status = RT_STATUS_RESOURCE;
+	} else if (adc_smp_buf->length != adc_smp_buf->buffer_size) {
+		*bytes_written = 0;
+		ret_status = RT_STATUS_RESOURCE;
+	} else if (adc_smp->adc_smp_state != ADCSMP_STATE_QUERY) {
+		*bytes_written = 0;
+		ret_status = RT_STATUS_PENDING;
+	} else {
+		odm_move_memory(dm, information_buffer, adc_smp_buf->octet, adc_smp_buf->buffer_size);
+		*bytes_written = adc_smp_buf->buffer_size;
+
+		adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
+	}
+
+	pr_debug("Return status %d\n", ret_status);
+
+	return ret_status;
+}
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+void
+adc_smp_query(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		*pused
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	u32 used = *pused;
+	u32 i;
+	/* struct timespec t; */
+	/* rtw_get_current_timespec(&t); */
+
+	pr_debug("%s adc_smp_state %d", __func__, adc_smp->adc_smp_state);
+
+	for (i = 0; i < (adc_smp_buf->length >> 2) - 2; i += 2) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%08x%08x\n", adc_smp_buf->octet[i],
+			       adc_smp_buf->octet[i + 1]);
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n");
+	/* PDM_SNPF((output+used, out_len-used, "\n[%lu.%06lu]\n", t.tv_sec, t.tv_nsec)); */
+	*pused = used;
+}
+
+s32
+adc_smp_get_sample_counts(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	return (adc_smp_buf->length >> 2) - 2;
+}
+
+s32
+adc_smp_query_single_data(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		index
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	u32 used = 0;
+
+	/* dbg_print("%s adc_smp_state %d\n", __func__, adc_smp->adc_smp_state); */
+	if (adc_smp->adc_smp_state != ADCSMP_STATE_QUERY) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"Error: la data is not ready yet ...\n");
+		return -1;
+	}
+
+	if (index < ((adc_smp_buf->length >> 2) - 2)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%08x%08x\n",
+			       adc_smp_buf->octet[index],
+			       adc_smp_buf->octet[index + 1]);
+	}
+	return 0;
+}
+
+#endif
+
+void
+adc_smp_stop(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+
+	adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
+	pr_debug("[LA_Stop] LA_state = ((%d))\n", adc_smp->adc_smp_state);
+}
+
+void
+adc_smp_init(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
+
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		adc_smp_buf->start_pos = 0x30000;
+		adc_smp_buf->buffer_size = 0x10000;
+	} else if (dm->support_ic_type & ODM_RTL8822B) {
+		adc_smp_buf->start_pos = 0x20000;
+		adc_smp_buf->buffer_size = 0x20000;
+	} else if (dm->support_ic_type & ODM_RTL8197F) {
+		adc_smp_buf->start_pos = 0x00000;
+		adc_smp_buf->buffer_size = 0x10000;
+	} else if (dm->support_ic_type & ODM_RTL8821C) {
+		adc_smp_buf->start_pos = 0x8000;
+		adc_smp_buf->buffer_size = 0x8000;
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+adc_smp_de_init(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	adc_smp_stop(dm);
+
+	if (adc_smp_buf->length != 0x0) {
+		odm_free_memory(dm, adc_smp_buf->octet, adc_smp_buf->length);
+		adc_smp_buf->length = 0x0;
+	}
+}
+
+#endif
+
+
+void
+phydm_la_mode_bb_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+
+	u8	trig_mode = adc_smp->la_trig_mode;
+	u32	trig_sig_sel = adc_smp->la_trig_sig_sel;
+	u32	dbg_port = adc_smp->la_dbg_port;
+	u8	is_trigger_edge = adc_smp->la_trigger_edge;
+	u8	sampling_rate = adc_smp->la_smp_rate;
+	u8	la_dma_type = adc_smp->la_dma_type;
+	u32	dbg_port_header_sel = 0;
+
+	pr_debug("1. [BB Setting] trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
+		trig_mode, dbg_port, is_trigger_edge, sampling_rate, trig_sig_sel, la_dma_type);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("1. [LA mode bb_setting]trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
+		trig_mode, dbg_port, is_trigger_edge, sampling_rate, trig_sig_sel, la_dma_type));
+#endif
+
+	if (trig_mode == PHYDM_MAC_TRIG)
+		trig_sig_sel = 0; /*ignore this setting*/
+
+	/*set BB debug port*/
+	if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, dbg_port)) {
+		pr_debug("Set dbg_port((0x%x)) success\n", dbg_port);
+	}
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (trig_mode == PHYDM_ADC_RF0_TRIG)
+			dbg_port_header_sel = 9;	/*DBGOUT_RFC_a[31:0]*/
+		else if (trig_mode == PHYDM_ADC_RF1_TRIG)
+			dbg_port_header_sel = 8;	/*DBGOUT_RFC_b[31:0]*/
+		else if ((trig_mode == PHYDM_ADC_BB_TRIG) || (trig_mode == PHYDM_ADC_MAC_TRIG)) {
+			
+			if (adc_smp->la_mac_mask_or_hdr_sel <= 0xf) {
+				dbg_port_header_sel = adc_smp->la_mac_mask_or_hdr_sel;
+			} else {
+				dbg_port_header_sel = 0;
+			}
+		}
+
+		phydm_bb_dbg_port_header_sel(dm, dbg_port_header_sel);
+
+		odm_set_bb_reg(dm, 0x95c, 0xf00, la_dma_type);	/*0x95C[11:8]*/
+		odm_set_bb_reg(dm, 0x95C, 0x1f, trig_sig_sel);	/*0x95C[4:0], BB debug port bit*/
+		odm_set_bb_reg(dm, 0x95C, BIT(31), is_trigger_edge); /*0: posedge, 1: negedge*/
+		odm_set_bb_reg(dm, 0x95c, 0xe0, sampling_rate);
+		/*	(0:) '80MHz'
+			(1:) '40MHz'
+			(2:) '20MHz'
+			(3:) '10MHz'
+			(4:) '5MHz'
+			(5:) '2.5MHz'
+			(6:) '1.25MHz'
+			(7:) '160MHz (for BW160 ic)'
+		*/
+		if ((dm->support_ic_type & ODM_RTL8821C) && (dm->cut_version >= ODM_CUT_B)) {
+			odm_set_bb_reg(dm, 0x95c, BIT(23), 1);
+		}
+	} else {
+		odm_set_bb_reg(dm, 0x9a0, 0xf00, la_dma_type);	/*0x9A0[11:8]*/
+		odm_set_bb_reg(dm, 0x9a0, 0x1f, trig_sig_sel);	/*0x9A0[4:0], BB debug port bit*/
+		odm_set_bb_reg(dm, 0x9A0, BIT(31), is_trigger_edge); /*0: posedge, 1: negedge*/
+		odm_set_bb_reg(dm, 0x9A0, 0xe0, sampling_rate);
+		/*	(0:) '80MHz'
+			(1:) '40MHz'
+			(2:) '20MHz'
+			(3:) '10MHz'
+			(4:) '5MHz'
+			(5:) '2.5MHz'
+			(6:) '1.25MHz'
+			(7:) '160MHz (for BW160 ic)'
+		*/
+	}
+}
+
+void
+phydm_la_mode_set_trigger_time(
+	void		*dm_void,
+	u32		trigger_time_mu_sec
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			trigger_time_unit_num;
+	u32			time_unit = 0;
+
+	if (trigger_time_mu_sec < 128) {
+		time_unit = 0; /*unit: 1mu sec*/
+	} else if (trigger_time_mu_sec < 256) {
+		time_unit = 1; /*unit: 2mu sec*/
+	} else if (trigger_time_mu_sec < 512) {
+		time_unit = 2; /*unit: 4mu sec*/
+	} else if (trigger_time_mu_sec < 1024) {
+		time_unit = 3; /*unit: 8mu sec*/
+	} else if (trigger_time_mu_sec < 2048) {
+		time_unit = 4; /*unit: 16mu sec*/
+	} else if (trigger_time_mu_sec < 4096) {
+		time_unit = 5; /*unit: 32mu sec*/
+	} else if (trigger_time_mu_sec < 8192) {
+		time_unit = 6; /*unit: 64mu sec*/
+	}
+
+	trigger_time_unit_num = (u8)(trigger_time_mu_sec >> time_unit);
+
+	pr_debug("2. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n", trigger_time_unit_num, time_unit);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("3. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n", trigger_time_unit_num, time_unit));
+#endif
+
+	odm_set_mac_reg(dm, 0x7cc, BIT(20) | BIT(19) | BIT(18), time_unit);
+	odm_set_mac_reg(dm, 0x7c0, 0x7f00, (trigger_time_unit_num & 0x7f));
+
+}
+
+
+void
+phydm_lamode_trigger_setting(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp	*adc_smp = &dm->adcsmp;
+	u8		trig_mode, dma_data_sig_sel;
+	u32		trig_sig_sel;
+	boolean		is_enable_la_mode;
+	u32		trigger_time_mu_sec;
+	char 		help[] = "-h";
+	u32			var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & PHYDM_IC_SUPPORT_LA_MODE) {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+		is_enable_la_mode = (boolean)var1[0];
+		/*dbg_print("echo cmd input_num = %d\n", input_num);*/
+
+		if ((strcmp(input[1], help) == 0)) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "{En} {0:BB,1:BB_MAC,2:RF0,3:RF1,4:MAC} \n {BB:dbg_port[bit],BB_MAC:0-ok/1-fail/2-cca,MAC:ref} {DMA type} {TrigTime} \n {DbgPort_head/ref_mask} {dbg_port} {0:P_Edge, 1:N_Edge} {SpRate:0-80M,1-40M,2-20M} {Capture num}\n");
+			/**/
+		} else if ((is_enable_la_mode == 1)) {
+			PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
+
+			trig_mode = (u8)var1[1];
+
+			if (trig_mode == PHYDM_MAC_TRIG)
+				PHYDM_SSCANF(input[3], DCMD_HEX, &var1[2]);
+			else
+				PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+			trig_sig_sel = var1[2];
+
+			PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
+			PHYDM_SSCANF(input[5], DCMD_DECIMAL, &var1[4]);
+			PHYDM_SSCANF(input[6], DCMD_HEX, &var1[5]);
+			PHYDM_SSCANF(input[7], DCMD_HEX, &var1[6]);
+			PHYDM_SSCANF(input[8], DCMD_DECIMAL, &var1[7]);
+			PHYDM_SSCANF(input[9], DCMD_DECIMAL, &var1[8]);
+			PHYDM_SSCANF(input[10], DCMD_DECIMAL, &var1[9]);
+
+			dma_data_sig_sel = (u8)var1[3];
+			trigger_time_mu_sec = var1[4]; /*unit: us*/
+
+			adc_smp->la_mac_mask_or_hdr_sel = var1[5];
+			adc_smp->la_dbg_port = var1[6];
+			adc_smp->la_trigger_edge = (u8) var1[7];
+			adc_smp->la_smp_rate = (u8)(var1[8] & 0x7);
+			adc_smp->la_count = var1[9];
+
+
+			pr_debug("echo lamode %d %d %d %d %d %d %x %d %d %d\n", var1[0], var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], var1[7], var1[8], var1[9]);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("echo lamode %d %d %d %d %d %d %x %d %d %d\n", var1[0], var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], var1[7], var1[8], var1[9]));
+#endif
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "a.En= ((1)),  b.mode = ((%d)), c.Trig_Sel = ((0x%x)), d.Dma_type = ((%d))\n",
+				       trig_mode, trig_sig_sel,
+				       dma_data_sig_sel);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "e.Trig_Time = ((%dus)), f.Dbg_head/mac_ref_mask = ((0x%x)), g.dbg_port = ((0x%x))\n",
+				       trigger_time_mu_sec,
+				       adc_smp->la_mac_mask_or_hdr_sel,
+				       adc_smp->la_dbg_port);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "h.Trig_edge = ((%d)), i.smp rate = ((%d MHz)), j.Cap_num = ((%d))\n",
+				       adc_smp->la_trigger_edge,
+				       (80 >> adc_smp->la_smp_rate),
+				       adc_smp->la_count);
+
+			adc_smp_set(dm, trig_mode, trig_sig_sel, dma_data_sig_sel, trigger_time_mu_sec, 0);
+
+		} else {
+			adc_smp_stop(dm);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Disable LA mode\n");
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif	/*endif PHYDM_LA_MODE_SUPPORT == 1*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adc_sampling.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adc_sampling.h
new file mode 100644
index 000000000000..9e9fc5911143
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_adc_sampling.h
@@ -0,0 +1,172 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __INC_ADCSMP_H
+#define __INC_ADCSMP_H
+
+#define DYNAMIC_LA_MODE	"2.0"  /*2017.02.06  Dino */
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+
+struct rt_adcsmp_string {
+	u32		*octet;
+	u32		length;
+	u32		buffer_size;
+	u32		start_pos;
+};
+
+
+enum rt_adcsmp_trig_sel {
+	PHYDM_ADC_BB_TRIG	= 0,
+	PHYDM_ADC_MAC_TRIG	= 1,
+	PHYDM_ADC_RF0_TRIG	= 2,
+	PHYDM_ADC_RF1_TRIG	= 3,
+	PHYDM_MAC_TRIG		= 4
+};
+
+
+enum rt_adcsmp_trig_sig_sel {
+	ADCSMP_TRIG_CRCOK	= 0,
+	ADCSMP_TRIG_CRCFAIL	= 1,
+	ADCSMP_TRIG_CCA		= 2,
+	ADCSMP_TRIG_REG		= 3
+};
+
+
+enum rt_adcsmp_state {
+	ADCSMP_STATE_IDLE		= 0,
+	ADCSMP_STATE_SET		= 1,
+	ADCSMP_STATE_QUERY	=	2
+};
+
+
+struct rt_adcsmp {
+	struct rt_adcsmp_string		adc_smp_buf;
+	enum rt_adcsmp_state		adc_smp_state;
+	u8					la_trig_mode;
+	u32					la_trig_sig_sel;
+	u8					la_dma_type;
+	u32					la_trigger_time;
+	u32					la_mac_mask_or_hdr_sel; /*1.BB mode: for debug port header sel; 2.MAC mode: for reference mask*/
+	u32					la_dbg_port;
+	u8					la_trigger_edge;
+	u8					la_smp_rate;
+	u32					la_count;
+	u8					is_bb_trigger;
+	u8					la_work_item_index;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_WORK_ITEM	adc_smp_work_item;
+	RT_WORK_ITEM	adc_smp_work_item_1;
+#endif
+};
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+void
+adc_smp_work_item_callback(
+	void	*context
+);
+#endif
+
+void
+adc_smp_set(
+	void	*dm_void,
+	u8	trig_mode,
+	u32	trig_sig_sel,
+	u8	dma_data_sig_sel,
+	u32	trigger_time,
+	u16	polling_time
+);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+enum rt_status
+adc_smp_query(
+	void	*dm_void,
+	ULONG	information_buffer_length,
+	void	*information_buffer,
+	PULONG	bytes_written
+);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+void
+adc_smp_query(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		*pused
+);
+
+s32
+adc_smp_get_sample_counts(
+	void		*dm_void
+);
+
+s32
+adc_smp_query_single_data(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		index
+);
+
+#endif
+void
+adc_smp_stop(
+	void	*dm_void
+);
+
+void
+adc_smp_init(
+	void	*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+adc_smp_de_init(
+	void			*dm_void
+);
+#endif
+
+void
+phydm_la_mode_bb_setting(
+	void		*dm_void
+);
+
+void
+phydm_la_mode_set_trigger_time(
+	void		*dm_void,
+	u32		trigger_time_mu_sec
+);
+
+void
+phydm_lamode_trigger_setting(
+	void		*dm_void,
+	char			input[][16],
+	u32		*_used,
+	char			*output,
+	u32		*_out_len,
+	u32		input_num
+);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdect.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdect.c
new file mode 100644
index 000000000000..1d96aa952555
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdect.c
@@ -0,0 +1,843 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* #if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE)) */
+#if (defined(CONFIG_ANT_DETECTION))
+
+/* IS_ANT_DETECT_SUPPORT_SINGLE_TONE(adapter)
+ * IS_ANT_DETECT_SUPPORT_RSSI(adapter)
+ * IS_ANT_DETECT_SUPPORT_PSD(adapter) */
+
+/* 1 [1. Single Tone method] =================================================== */
+
+/*
+ * Description:
+ *	Set Single/Dual Antenna default setting for products that do not do detection in advance.
+ *
+ * Added by Joseph, 2012.03.22
+ *   */
+void
+odm_single_dual_antenna_default_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	void	*adapter	 =  dm->adapter;
+
+	u8 bt_ant_num = BT_GetPgAntNum(adapter);
+	/* Set default antenna A and B status */
+	if (bt_ant_num == 2) {
+		dm_swat_table->ANTA_ON = true;
+		dm_swat_table->ANTB_ON = true;
+
+	} else if (bt_ant_num == 1) {
+		/* Set antenna A as default */
+		dm_swat_table->ANTA_ON = true;
+		dm_swat_table->ANTB_ON = false;
+
+	} else
+		RT_ASSERT(false, ("Incorrect antenna number!!\n"));
+}
+
+
+/* 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.
+ *
+ * Added by Roger, 2011.12.15
+ *   */
+boolean
+odm_single_dual_antenna_detection(
+	void		*dm_void,
+	u8			mode
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter	 =  dm->adapter;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	u32		current_channel, rf_loop_reg;
+	u8		n;
+	u32		reg88c, regc08, reg874, regc50, reg948, regb2c, reg92c, reg930, reg064, afe_rrx_wait_cca;
+	u8		initial_gain = 0x5a;
+	u32		PSD_report_tmp;
+	u32		ant_a_report = 0x0, ant_b_report = 0x0, ant_0_report = 0x0;
+	boolean		is_result = true;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection()============>\n");
+
+
+	if (!(dm->support_ic_type & ODM_RTL8723B))
+		return is_result;
+
+	/* Retrieve antenna detection registry info, added by Roger, 2012.11.27. */
+	if (!IS_ANT_DETECT_SUPPORT_SINGLE_TONE(((PADAPTER)adapter)))
+		return is_result;
+
+	/* 1 Backup Current RF/BB Settings */
+
+	current_channel = odm_get_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
+	rf_loop_reg = odm_get_rf_reg(dm, RF_PATH_A, 0x00, RFREGOFFSETMASK);
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		reg92c = odm_get_bb_reg(dm, REG_DPDT_CONTROL, MASKDWORD);
+		reg930 = odm_get_bb_reg(dm, rfe_ctrl_anta_src, MASKDWORD);
+		reg948 = odm_get_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
+		regb2c = odm_get_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD);
+		reg064 = odm_get_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29));
+		odm_set_bb_reg(dm, REG_DPDT_CONTROL, 0x3, 0x1);
+		odm_set_bb_reg(dm, rfe_ctrl_anta_src, 0xff, 0x77);
+		odm_set_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), 0x1);  /* dbg 7 */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0x3c0, 0x0);/* dbg 8 */
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x0);
+	}
+
+	ODM_delay_us(10);
+
+	/* Store A path Register 88c, c08, 874, c50 */
+	reg88c = odm_get_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD);
+	regc08 = odm_get_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD);
+	reg874 = odm_get_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD);
+	regc50 = odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
+
+	/* Store AFE Registers */
+	if (dm->support_ic_type & ODM_RTL8723B)
+		afe_rrx_wait_cca = odm_get_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD);
+
+	/* Set PSD 128 pts */
+	odm_set_bb_reg(dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0); /* 128 pts */
+
+	/* To SET CH1 to do */
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK, 0x7401);     /* channel 1 */
+
+	/* AFE all on step */
+	if (dm->support_ic_type & ODM_RTL8723B)
+		odm_set_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD, 0x01c00016);
+
+	/* 3 wire Disable */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, 0xCCF000C0);
+
+	/* BB IQK setting */
+	odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800E4);
+	odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x22208000);
+
+	/* IQK setting tone@ 4.34Mhz */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x10008C1C);
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
+
+	/* Page B init */
+	odm_set_bb_reg(dm, REG_CONFIG_ANT_A, MASKDWORD, 0x00080000);
+	odm_set_bb_reg(dm, REG_CONFIG_ANT_A, MASKDWORD, 0x0f600000);
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x10008c1f);
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82150016);
+		odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28150016);
+	}
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x001028d0);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, 0x7f, initial_gain);
+
+	/* IQK Single tone start */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+
+	ODM_delay_us(10000);
+
+	/* PSD report of antenna A */
+	PSD_report_tmp = 0x0;
+	for (n = 0; n < 2; n++) {
+		PSD_report_tmp = phydm_get_psd_data(dm, 14, initial_gain);
+		if (PSD_report_tmp > ant_a_report)
+			ant_a_report = PSD_report_tmp;
+	}
+
+	/* change to Antenna B */
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		/* odm_set_bb_reg(dm, REG_DPDT_CONTROL, 0x3, 0x2); */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
+	}
+
+	ODM_delay_us(10);
+
+	/* PSD report of antenna B */
+	PSD_report_tmp = 0x0;
+	for (n = 0; n < 2; n++) {
+		PSD_report_tmp = phydm_get_psd_data(dm, 14, initial_gain);
+		if (PSD_report_tmp > ant_b_report)
+			ant_b_report = PSD_report_tmp;
+	}
+
+	/* Close IQK Single Tone function */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+
+	/* 1 Return to antanna A */
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		/* external DPDT */
+		odm_set_bb_reg(dm, REG_DPDT_CONTROL, MASKDWORD, reg92c);
+
+		/* internal S0/S1 */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
+		odm_set_bb_reg(dm, rfe_ctrl_anta_src, MASKDWORD, reg930);
+		odm_set_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), reg064);
+	}
+
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, reg88c);
+	odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, regc08);
+	odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, reg874);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, 0x7F, 0x40);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD, regc50);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, current_channel);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x00, RFREGOFFSETMASK, rf_loop_reg);
+
+	/* Reload AFE Registers */
+	if (dm->support_ic_type & ODM_RTL8723B)
+		odm_set_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD, afe_rrx_wait_cca);
+
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "psd_report_A[%d]= %d\n", 2416, ant_a_report);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "psd_report_B[%d]= %d\n", 2416, ant_b_report);
+
+		/* 2 Test ant B based on ant A is ON */
+		if ((ant_a_report >= 100) && (ant_b_report >= 100) && (ant_a_report <= 135) && (ant_b_report <= 135)) {
+			u8 TH1 = 2, TH2 = 6;
+
+			if ((ant_a_report - ant_b_report < TH1) || (ant_b_report - ant_a_report < TH1)) {
+				dm_swat_table->ANTA_ON = true;
+				dm_swat_table->ANTB_ON = true;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection(): Dual Antenna\n");
+			} else if (((ant_a_report - ant_b_report >= TH1) && (ant_a_report - ant_b_report <= TH2)) ||
+				((ant_b_report - ant_a_report >= TH1) && (ant_b_report - ant_a_report <= TH2))) {
+				dm_swat_table->ANTA_ON = false;
+				dm_swat_table->ANTB_ON = false;
+				is_result = false;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection(): Need to check again\n");
+			} else {
+				dm_swat_table->ANTA_ON = true;
+				dm_swat_table->ANTB_ON = false;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection(): Single Antenna\n");
+			}
+			dm->ant_detected_info.is_ant_detected = true;
+			dm->ant_detected_info.db_for_ant_a = ant_a_report;
+			dm->ant_detected_info.db_for_ant_b = ant_b_report;
+			dm->ant_detected_info.db_for_ant_o = ant_0_report;
+
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "return false!!\n");
+			is_result = false;
+		}
+	}
+	return is_result;
+
+}
+
+
+
+/* 1 [2. Scan AP RSSI method] ================================================== */
+
+
+
+
+boolean
+odm_sw_ant_div_check_before_link(
+	void		*dm_void
+)
+{
+#if (RT_MEM_SIZE_LEVEL != RT_MEM_SIZE_MINIMUM)
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	//PMGNT_INFO		mgnt_info = &adapter->MgntInfo;
+	PMGNT_INFO		mgnt_info = &(((PADAPTER)(adapter))->MgntInfo);
+	struct sw_antenna_switch			*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	s8			score = 0;
+	PRT_WLAN_BSS	p_tmp_bss_desc, p_test_bss_desc;
+	u8			power_target_L = 9, power_target_H = 16;
+	u8			tmp_power_diff = 0, power_diff = 0, avg_power_diff = 0, max_power_diff = 0, min_power_diff = 0xff;
+	u16			index, counter = 0;
+	static u8		scan_channel;
+	u32			tmp_swas_no_link_bk_reg948;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "ANTA_ON = (( %d )) , ANTB_ON = (( %d ))\n", dm->dm_swat_table.ANTA_ON, dm->dm_swat_table.ANTB_ON);
+
+	/* if(HP id) */
+	{
+		if (dm->dm_swat_table.rssi_ant_dect_result == true && dm->support_ic_type == ODM_RTL8723B) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "8723B RSSI-based Antenna Detection is done\n");
+			return false;
+		}
+
+		if (dm->support_ic_type == ODM_RTL8723B) {
+			if (dm_swat_table->swas_no_link_bk_reg948 == 0xff)
+				dm_swat_table->swas_no_link_bk_reg948 = odm_read_4byte(dm, REG_S0_S1_PATH_SWITCH);
+		}
+	}
+
+	if (dm->adapter == NULL) { /* For BSOD when plug/unplug fast.  //By YJ,120413 */
+		/* The ODM structure is not initialized. */
+		return false;
+	}
+
+	/* Retrieve antenna detection registry info, added by Roger, 2012.11.27. */
+	if (!IS_ANT_DETECT_SUPPORT_RSSI(((PADAPTER)adapter)))
+		return false;
+	else
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Antenna Detection: RSSI method\n");
+
+	/* Since driver is going to set BB register, it shall check if there is another thread controlling BB/RF. */
+	odm_acquire_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+	if (hal_data->eRFPowerState != eRfOn || mgnt_info->RFChangeInProgress || mgnt_info->bMediaConnect) {
+		odm_release_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			"odm_sw_ant_div_check_before_link(): rf_change_in_progress(%x), e_rf_power_state(%x)\n",
+			mgnt_info->RFChangeInProgress, hal_data->eRFPowerState);
+
+		dm_swat_table->swas_no_link_state = 0;
+
+		return false;
+	} else
+		odm_release_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->swas_no_link_state = %d\n", dm_swat_table->swas_no_link_state);
+	/* 1 Run AntDiv mechanism "Before Link" part. */
+	if (dm_swat_table->swas_no_link_state == 0) {
+		/* 1 Prepare to do Scan again to check current antenna state. */
+
+		/* Set check state to next step. */
+		dm_swat_table->swas_no_link_state = 1;
+
+		/* Copy Current Scan list. */
+		mgnt_info->tmpNumBssDesc = mgnt_info->NumBssDesc;
+		PlatformMoveMemory((void *)mgnt_info->tmpbssDesc, (void *)mgnt_info->bssDesc, sizeof(RT_WLAN_BSS) * MAX_BSS_DESC);
+
+		/* Go back to scan function again. */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Scan one more time\n");
+		mgnt_info->ScanStep = 0;
+		mgnt_info->bScanAntDetect = true;
+		scan_channel = odm_sw_ant_div_select_scan_chnl(adapter);
+
+
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
+			if (fat_tab->rx_idle_ant == MAIN_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
+			else
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			if (scan_channel == 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					"odm_sw_ant_div_check_before_link(): No AP List Avaiable, Using ant(%s)\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "AUX_ANT" : "MAIN_ANT");
+
+				if (IS_5G_WIRELESS_MODE(mgnt_info->dot11CurrentWirelessMode)) {
+					dm_swat_table->ant_5g = fat_tab->rx_idle_ant;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_5g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+				} else {
+					dm_swat_table->ant_2g = fat_tab->rx_idle_ant;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_2g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+				}
+				return false;
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				"odm_sw_ant_div_check_before_link: Change to %s for testing.\n", ((fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+		} else if (dm->support_ic_type & (ODM_RTL8723B)) {
+			/*Switch Antenna to another one.*/
+
+			tmp_swas_no_link_bk_reg948 = odm_read_4byte(dm, REG_S0_S1_PATH_SWITCH);
+
+			if ((dm_swat_table->cur_antenna == MAIN_ANT) && (tmp_swas_no_link_bk_reg948 == 0x200)) {
+				odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
+				odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
+				dm_swat_table->cur_antenna = AUX_ANT;
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Reg[948]= (( %x )) was in wrong state\n", tmp_swas_no_link_bk_reg948);
+				return false;
+			}
+			ODM_delay_us(10);
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Change to (( %s-ant))  for testing.\n", (dm_swat_table->cur_antenna == MAIN_ANT) ? "MAIN" : "AUX");
+		}
+
+		odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
+		PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
+
+		return true;
+	} else { /* dm_swat_table->swas_no_link_state == 1 */
+		/* 1 ScanComple() is called after antenna swiched. */
+		/* 1 Check scan result and determine which antenna is going */
+		/* 1 to be used. */
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, " tmp_num_bss_desc= (( %d ))\n", mgnt_info->tmpNumBssDesc); /* debug for Dino */
+
+		for (index = 0; index < mgnt_info->tmpNumBssDesc; index++) {
+			p_tmp_bss_desc = &mgnt_info->tmpbssDesc[index]; /* Antenna 1 */
+			p_test_bss_desc = &mgnt_info->bssDesc[index]; /* Antenna 2 */
+
+			if (PlatformCompareMemory(p_test_bss_desc->bdBssIdBuf, p_tmp_bss_desc->bdBssIdBuf, 6) != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): ERROR!! This shall not happen.\n");
+				continue;
+			}
+
+			if (dm->support_ic_type != ODM_RTL8723B) {
+				if (p_tmp_bss_desc->ChannelNumber == scan_channel) {
+					if (p_tmp_bss_desc->RecvSignalPower > p_test_bss_desc->RecvSignalPower) {
+						PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Compare scan entry: score++\n");
+						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+
+						score++;
+						PlatformMoveMemory(p_test_bss_desc, p_tmp_bss_desc, sizeof(RT_WLAN_BSS));
+					} else if (p_tmp_bss_desc->RecvSignalPower < p_test_bss_desc->RecvSignalPower) {
+						PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Compare scan entry: score--\n");
+						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						score--;
+					} else {
+						if (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp < 5000) {
+							RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
+							PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+							PHYDM_DBG(dm, DBG_ANT_DIV, "The 2nd Antenna didn't get this AP\n\n");
+						}
+					}
+				}
+			} else { /* 8723B */
+				if (p_tmp_bss_desc->ChannelNumber == scan_channel) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "channel_number == scan_channel->(( %d ))\n", p_tmp_bss_desc->ChannelNumber);
+
+					if (p_tmp_bss_desc->RecvSignalPower > p_test_bss_desc->RecvSignalPower) { /* Pow(Ant1) > Pow(Ant2) */
+						counter++;
+						tmp_power_diff = (u8)(p_tmp_bss_desc->RecvSignalPower - p_test_bss_desc->RecvSignalPower);
+						power_diff = power_diff + tmp_power_diff;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
+
+						/* PHYDM_DBG(dm,DBG_ANT_DIV, "tmp_power_diff: (( %d)),max_power_diff: (( %d)),min_power_diff: (( %d))\n", tmp_power_diff,max_power_diff,min_power_diff); */
+						if (tmp_power_diff > max_power_diff)
+							max_power_diff = tmp_power_diff;
+						if (tmp_power_diff < min_power_diff)
+							min_power_diff = tmp_power_diff;
+						/* PHYDM_DBG(dm,DBG_ANT_DIV, "max_power_diff: (( %d)),min_power_diff: (( %d))\n",max_power_diff,min_power_diff); */
+
+						PlatformMoveMemory(p_test_bss_desc, p_tmp_bss_desc, sizeof(RT_WLAN_BSS));
+					} else if (p_test_bss_desc->RecvSignalPower > p_tmp_bss_desc->RecvSignalPower) { /* Pow(Ant1) < Pow(Ant2) */
+						counter++;
+						tmp_power_diff = (u8)(p_test_bss_desc->RecvSignalPower - p_tmp_bss_desc->RecvSignalPower);
+						power_diff = power_diff + tmp_power_diff;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
+						if (tmp_power_diff > max_power_diff)
+							max_power_diff = tmp_power_diff;
+						if (tmp_power_diff < min_power_diff)
+							min_power_diff = tmp_power_diff;
+					} else { /* Pow(Ant1) = Pow(Ant2) */
+						if (p_test_bss_desc->bdTstamp > p_tmp_bss_desc->bdTstamp) { /* Stamp(Ant1) < Stamp(Ant2) */
+							PHYDM_DBG(dm, DBG_ANT_DIV, "time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000);
+							if (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp > 5000) {
+								counter++;
+								PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+								PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+								PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
+								min_power_diff = 0;
+							}
+						} else
+							PHYDM_DBG(dm, DBG_ANT_DIV, "[Error !!!]: Time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000);
+					}
+				}
+			}
+		}
+
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
+			if (mgnt_info->NumBssDesc != 0 && score < 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					"odm_sw_ant_div_check_before_link(): Using ant(%s)\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					"odm_sw_ant_div_check_before_link(): Remain ant(%s)\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "AUX_ANT" : "MAIN_ANT");
+
+				if (fat_tab->rx_idle_ant == MAIN_ANT)
+					odm_update_rx_idle_ant(dm, AUX_ANT);
+				else
+					odm_update_rx_idle_ant(dm, MAIN_ANT);
+			}
+
+			if (IS_5G_WIRELESS_MODE(mgnt_info->dot11CurrentWirelessMode)) {
+				dm_swat_table->ant_5g = fat_tab->rx_idle_ant;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_5g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+			} else {
+				dm_swat_table->ant_2g = fat_tab->rx_idle_ant;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_2g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+			}
+		} else if (dm->support_ic_type == ODM_RTL8723B) {
+			if (counter == 0) {
+				if (dm->dm_swat_table.pre_aux_fail_detec == false) {
+					dm->dm_swat_table.pre_aux_fail_detec = true;
+					dm->dm_swat_table.rssi_ant_dect_result = false;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter=(( 0 )) , [[ Cannot find any AP with Aux-ant ]] ->  Scan Target-channel again\n");
+
+					/* 3 [ Scan again ] */
+					odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
+					PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
+					return true;
+				} else { /* pre_aux_fail_detec == true */
+					/* 2 [ Single Antenna ] */
+					dm->dm_swat_table.pre_aux_fail_detec = false;
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter=(( 0 )) , [[  Still cannot find any AP ]]\n");
+					PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+				}
+				dm->dm_swat_table.aux_fail_detec_counter++;
+			} else {
+				dm->dm_swat_table.pre_aux_fail_detec = false;
+
+				if (counter == 3) {
+					avg_power_diff = ((power_diff - max_power_diff - min_power_diff) >> 1) + ((max_power_diff + min_power_diff) >> 2);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ counter==3 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff);
+				} else if (counter >= 4) {
+					avg_power_diff = (power_diff - max_power_diff - min_power_diff) / (counter - 2);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ counter>=4 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff);
+
+				} else { /* counter==1,2 */
+					avg_power_diff = power_diff / counter;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "avg_power_diff: (( %d )) , counter: (( %d )) ,  power_diff: (( %d ))\n", avg_power_diff, counter, power_diff);
+				}
+
+				/* 2 [ Retry ] */
+				if ((avg_power_diff >= power_target_L) && (avg_power_diff <= power_target_H)) {
+					dm->dm_swat_table.retry_counter++;
+
+					if (dm->dm_swat_table.retry_counter <= 3) {
+						dm->dm_swat_table.rssi_ant_dect_result = false;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[[ Low confidence result ]] avg_power_diff= (( %d ))  ->  Scan Target-channel again ]]\n", avg_power_diff);
+
+						/* 3 [ Scan again ] */
+						odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
+						PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
+						return true;
+					} else {
+						dm->dm_swat_table.rssi_ant_dect_result = true;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[[ Still Low confidence result ]]  (( retry_counter > 3 ))\n");
+						PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+					}
+
+				}
+				/* 2 [ Dual Antenna ] */
+				else if ((mgnt_info->NumBssDesc != 0) && (avg_power_diff < power_target_L)) {
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					if (dm->dm_swat_table.ANTB_ON == false) {
+						dm->dm_swat_table.ANTA_ON = true;
+						dm->dm_swat_table.ANTB_ON = true;
+					}
+					PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Dual antenna\n");
+					dm->dm_swat_table.dual_ant_counter++;
+
+					/* set bt coexDM from 1ant coexDM to 2ant coexDM */
+					BT_SetBtCoexAntNum(adapter, BT_COEX_ANT_TYPE_DETECTED, 2);
+
+					/* 3 [ Init antenna diversity ] */
+					dm->support_ability |= ODM_BB_ANT_DIV;
+					odm_ant_div_init(dm);
+				}
+				/* 2 [ Single Antenna ] */
+				else if (avg_power_diff > power_target_H) {
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					if (dm->dm_swat_table.ANTB_ON == true) {
+						dm->dm_swat_table.ANTA_ON = true;
+						dm->dm_swat_table.ANTB_ON = false;
+						/* bt_set_bt_coex_ant_num(adapter, BT_COEX_ANT_TYPE_DETECTED, 1); */
+					}
+					PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+					dm->dm_swat_table.single_ant_counter++;
+				}
+			}
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "is_result=(( %d ))\n",dm->dm_swat_table.rssi_ant_dect_result); */
+			PHYDM_DBG(dm, DBG_ANT_DIV, "dual_ant_counter = (( %d )), single_ant_counter = (( %d )) , retry_counter = (( %d )) , aux_fail_detec_counter = (( %d ))\n\n\n",
+				dm->dm_swat_table.dual_ant_counter, dm->dm_swat_table.single_ant_counter, dm->dm_swat_table.retry_counter, dm->dm_swat_table.aux_fail_detec_counter);
+
+			/* 2 recover the antenna setting */
+
+			if (dm->dm_swat_table.ANTB_ON == false)
+				odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, (dm_swat_table->swas_no_link_bk_reg948));
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "is_result=(( %d )), Recover  Reg[948]= (( %x ))\n\n", dm->dm_swat_table.rssi_ant_dect_result, dm_swat_table->swas_no_link_bk_reg948);
+
+
+		}
+
+		/* Check state reset to default and wait for next time. */
+		dm_swat_table->swas_no_link_state = 0;
+		mgnt_info->bScanAntDetect = false;
+
+		return false;
+	}
+
+#else
+	return	false;
+#endif
+
+	return false;
+}
+
+
+
+
+
+
+/* 1 [3. PSD method] ========================================================== */
+void
+odm_single_dual_antenna_detection_psd(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	channel_ori;
+	u8	initial_gain = 0x36;
+	u8	tone_idx;
+	u8	tone_lenth_1 = 7, tone_lenth_2 = 4;
+	u16	tone_idx_1[7] = {88, 104, 120, 8, 24, 40, 56};
+	u16	tone_idx_2[4] = {8, 24, 40, 56};
+	u32	psd_report_main[11] = {0}, psd_report_aux[11] = {0};
+	/* u8	tone_lenth_1=4, tone_lenth_2=2; */
+	/* u16	tone_idx_1[4]={88, 120, 24, 56}; */
+	/* u16	tone_idx_2[2]={ 24,  56}; */
+	/* u32	psd_report_main[6]={0}, psd_report_aux[6]={0}; */
+
+	u32	PSD_report_temp, max_psd_report_main = 0, max_psd_report_aux = 0;
+	u32	PSD_power_threshold;
+	u32	main_psd_result = 0, aux_psd_result = 0;
+	u32	regc50, reg948, regb2c, regc14, reg908;
+	u32	i = 0, test_num = 8;
+
+
+	if (dm->support_ic_type != ODM_RTL8723B)
+		return;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection_psd()============>\n");
+
+	/* 2 [ Backup Current RF/BB Settings ] */
+
+	channel_ori = odm_get_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
+	reg948 = odm_get_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
+	regb2c =  odm_get_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD);
+	regc50 = odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
+	regc14 = odm_get_bb_reg(dm, 0xc14, MASKDWORD);
+	reg908 = odm_get_bb_reg(dm, 0x908, MASKDWORD);
+
+	/* 2 [ setting for doing PSD function (CH4)] */
+	odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT(24), 0); /* disable whole CCK block */
+	odm_write_1byte(dm, REG_TXPAUSE, 0xFF); /* Turn off TX  ->  Pause TX Queue */
+	odm_set_bb_reg(dm, 0xC14, MASKDWORD, 0x0); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
+
+	/* PHYTXON while loop */
+	odm_set_bb_reg(dm, 0x908, MASKDWORD, 0x803);
+	while (odm_get_bb_reg(dm, 0xdf4, BIT(6))) {
+		i++;
+		if (i > 1000000) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Wait in %s() more than %d times!\n", __FUNCTION__, i);
+			break;
+		}
+	}
+
+	odm_set_bb_reg(dm, 0xc50, 0x7f, initial_gain);
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     /* Set RF to CH4 & 40M */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+	odm_set_bb_reg(dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0);  /* 128 pt	 */ /* Set PSD 128 ptss */
+	ODM_delay_us(3000);
+
+
+	/* 2 [ Doing PSD Function in (CH4)] */
+
+	/* Antenna A */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Main-ant   (CH4)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x200);
+	ODM_delay_us(10);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "dbg\n");
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_1; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_1[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
+			psd_report_main[tone_idx] += PSD_report_temp;
+		}
+	}
+	/* Antenna B */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Aux-ant   (CH4)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x280);
+	ODM_delay_us(10);
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_1; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_1[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
+			psd_report_aux[tone_idx] += PSD_report_temp;
+		}
+	}
+	/* 2 [ Doing PSD Function in (CH8)] */
+
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0);	/* 3 wire enable    88c[23:20]=0x0 */
+	ODM_delay_us(3000);
+
+	odm_set_bb_reg(dm, 0xc50, 0x7f, initial_gain);
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     /* Set RF to CH8 & 40M */
+
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+	ODM_delay_us(3000);
+
+	/* Antenna A */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Main-ant   (CH8)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x200);
+	ODM_delay_us(10);
+
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_2; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_2[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
+			psd_report_main[tone_lenth_1 + tone_idx] += PSD_report_temp;
+		}
+	}
+
+	/* Antenna B */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Aux-ant   (CH8)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x280);
+	ODM_delay_us(10);
+
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_2; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_2[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
+			psd_report_aux[tone_lenth_1 + tone_idx] += PSD_report_temp;
+		}
+	}
+
+	/* 2 [ Calculate Result ] */
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\nMain PSD Result: (ALL)\n");
+	for (tone_idx = 0; tone_idx < (tone_lenth_1 + tone_lenth_2); tone_idx++) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Tone-%d]: %d,\n", (tone_idx + 1), psd_report_main[tone_idx]);
+		main_psd_result += psd_report_main[tone_idx];
+		if (psd_report_main[tone_idx] > max_psd_report_main)
+			max_psd_report_main = psd_report_main[tone_idx];
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "--------------------------- \nTotal_Main= (( %d ))\n", main_psd_result);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "MAX_Main = (( %d ))\n", max_psd_report_main);
+
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\nAux PSD Result: (ALL)\n");
+	for (tone_idx = 0; tone_idx < (tone_lenth_1 + tone_lenth_2); tone_idx++) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Tone-%d]: %d,\n", (tone_idx + 1), psd_report_aux[tone_idx]);
+		aux_psd_result += psd_report_aux[tone_idx];
+		if (psd_report_aux[tone_idx] > max_psd_report_aux)
+			max_psd_report_aux = psd_report_aux[tone_idx];
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "--------------------------- \nTotal_Aux= (( %d ))\n", aux_psd_result);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "MAX_Aux = (( %d ))\n\n", max_psd_report_aux);
+
+	/* main_psd_result=main_psd_result-max_psd_report_main; */
+	/* aux_psd_result=aux_psd_result-max_psd_report_aux; */
+	PSD_power_threshold = (main_psd_result * 7) >> 3;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Main_result, Aux_result ] = [ %d , %d ], PSD_power_threshold=(( %d ))\n", main_psd_result, aux_psd_result, PSD_power_threshold);
+
+	/* 3 [ Dual Antenna ] */
+	if (aux_psd_result >= PSD_power_threshold) {
+		if (dm->dm_swat_table.ANTB_ON == false) {
+			dm->dm_swat_table.ANTA_ON = true;
+			dm->dm_swat_table.ANTB_ON = true;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Dual antenna\n");
+
+		/* set bt coexDM from 1ant coexDM to 2ant coexDM */
+		/* bt_set_bt_coex_ant_num(adapter, BT_COEX_ANT_TYPE_DETECTED, 2); */
+
+		/* Init antenna diversity */
+		dm->support_ability |= ODM_BB_ANT_DIV;
+		odm_ant_div_init(dm);
+	}
+	/* 3 [ Single Antenna ] */
+	else {
+		if (dm->dm_swat_table.ANTB_ON == true) {
+			dm->dm_swat_table.ANTA_ON = true;
+			dm->dm_swat_table.ANTB_ON = false;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+	}
+
+	/* 2 [ Recover all parameters ] */
+
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, channel_ori);
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0);	/* 3 wire enable    88c[23:20]=0x0 */
+	odm_set_bb_reg(dm, 0xc50, 0x7f, regc50);
+
+	odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
+	odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
+
+	odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT(24), 1); /* enable whole CCK block */
+	odm_write_1byte(dm, REG_TXPAUSE, 0x0); /* Turn on TX	 */ /* Resume TX Queue */
+	odm_set_bb_reg(dm, 0xC14, MASKDWORD, regc14); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn on CCA] */
+	odm_set_bb_reg(dm, 0x908, MASKDWORD, reg908);
+
+	return;
+
+}
+
+#endif
+void
+odm_sw_ant_detect_init(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_ANT_DETECTION))
+#if (RTL8723B_SUPPORT == 1)
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+
+	if (dm->support_ic_type != ODM_RTL8723B)
+		return;
+
+	/* dm_swat_table->pre_antenna = MAIN_ANT; */
+	/* dm_swat_table->cur_antenna = MAIN_ANT; */
+	dm_swat_table->swas_no_link_state = 0;
+	dm_swat_table->pre_aux_fail_detec = false;
+	dm_swat_table->swas_no_link_bk_reg948 = 0xff;
+
+	#ifdef CONFIG_PSD_TOOL
+	phydm_psd_init(dm);
+	#endif
+#endif
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdect.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdect.h
new file mode 100644
index 000000000000..bf85c9bb63ce
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdect.h
@@ -0,0 +1,100 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMANTDECT_H__
+#define    __PHYDMANTDECT_H__
+
+#define ANTDECT_VERSION	"2.1"	/*2015.07.29 by YuChen*/
+
+#if (defined(CONFIG_ANT_DETECTION))
+/* #if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE)) */
+/* 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*/
+
+#define	MAX_ANTENNA_DETECTION_CNT	10
+
+
+struct _ANT_DETECTED_INFO {
+	boolean			is_ant_detected;
+	u32			db_for_ant_a;
+	u32			db_for_ant_b;
+	u32			db_for_ant_o;
+};
+
+
+enum dm_swas {
+	antenna_a = 1,
+	antenna_b = 2,
+	antenna_max = 3,
+};
+
+
+
+/* 1 [1. Single Tone method] =================================================== */
+
+
+
+void
+odm_single_dual_antenna_default_setting(
+	void		*dm_void
+);
+
+boolean
+odm_single_dual_antenna_detection(
+	void		*dm_void,
+	u8			mode
+);
+
+/* 1 [2. Scan AP RSSI method] ================================================== */
+
+#define sw_ant_div_check_before_link	odm_sw_ant_div_check_before_link
+
+boolean
+odm_sw_ant_div_check_before_link(
+	void		*dm_void
+);
+
+
+
+
+/* 1 [3. PSD method] ========================================================== */
+
+
+void
+odm_single_dual_antenna_detection_psd(
+	void		*dm_void
+);
+
+#endif
+
+void
+odm_sw_ant_detect_init(
+	void		*dm_void
+);
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdiv.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdiv.c
new file mode 100644
index 000000000000..ffa3ec41f2c7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdiv.c
@@ -0,0 +1,4702 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ******************************************************
+ * when antenna test utility is on or some testing need to disable antenna diversity
+ * call this function to disable all ODM related mechanisms which will switch antenna.
+ * ****************************************************** */
+void
+odm_stop_antenna_switch_dm(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	/* disable ODM antenna diversity */
+	dm->support_ability &= ~ODM_BB_ANT_DIV;
+	odm_ant_div_on_off(dm, ANTDIV_OFF);
+	odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "STOP Antenna Diversity\n");
+}
+
+void
+phydm_enable_antenna_diversity(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	dm->support_ability |= ODM_BB_ANT_DIV;
+	dm->antdiv_select = 0;
+	PHYDM_DBG(dm, DBG_ANT_DIV, "AntDiv is enabled & Re-Init AntDiv\n");
+	odm_antenna_diversity_init(dm);
+}
+
+void
+odm_set_ant_config(
+	void	*dm_void,
+	u8		ant_setting	/* 0=A, 1=B, 2=C, .... */
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (ant_setting == 0)		/* ant A*/
+			odm_set_bb_reg(dm, 0x948, MASKDWORD, 0x00000000);
+		else if (ant_setting == 1)
+			odm_set_bb_reg(dm, 0x948, MASKDWORD, 0x00000280);
+	} else if (dm->support_ic_type == ODM_RTL8723D) {
+		if (ant_setting == 0)		/* ant A*/
+			odm_set_bb_reg(dm, 0x948, MASKLWORD, 0x0000);
+		else if (ant_setting == 1)
+			odm_set_bb_reg(dm, 0x948, MASKLWORD, 0x0280);
+	}
+}
+
+/* ****************************************************** */
+
+
+void
+odm_sw_ant_div_rest_after_link(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	u32	i;
+
+	if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+		dm_swat_table->try_flag = SWAW_STEP_INIT;
+		dm_swat_table->rssi_trying = 0;
+		dm_swat_table->double_chk_flag = 0;
+		fat_tab->rx_idle_ant = MAIN_ANT;
+
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
+			phydm_antdiv_reset_statistic(dm, i);
+	}
+	
+#endif	
+}
+
+void
+odm_ant_div_on_off(
+	void		*dm_void,
+	u8		swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	if (fat_tab->ant_div_on_off != swch) {
+		if (dm->ant_div_type == S0S1_SW_ANTDIV)
+			return;
+
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) N-Series HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+			odm_set_bb_reg(dm, 0xc50, BIT(7), swch);
+			odm_set_bb_reg(dm, 0xa00, BIT(15), swch);
+
+#if (RTL8723D_SUPPORT == 1)
+			/*Mingzhi 2017-05-08*/
+			if (dm->support_ic_type == ODM_RTL8723D) {
+				if (swch == ANTDIV_ON) {
+					odm_set_bb_reg(dm, 0xce0, BIT(1), 1);
+					odm_set_bb_reg(dm, 0x948, BIT(6), 1);          /*1:HW ctrl  0:SW ctrl*/
+					}
+				else{
+					odm_set_bb_reg(dm, 0xce0, BIT(1), 0);
+					odm_set_bb_reg(dm, 0x948, BIT(6), 0);          /*1:HW ctrl  0:SW ctrl*/
+				}
+			}			
+#endif
+
+		} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) AC-Series HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+			if (dm->support_ic_type & ODM_RTL8812) {
+				odm_set_bb_reg(dm, 0xc50, BIT(7), swch); /* OFDM AntDiv function block enable */
+				odm_set_bb_reg(dm, 0xa00, BIT(15), swch); /* CCK AntDiv function block enable */
+			} else {
+				odm_set_bb_reg(dm, 0x8D4, BIT(24), swch); /* OFDM AntDiv function block enable */
+
+				if ((dm->cut_version >= ODM_CUT_C) && (dm->support_ic_type == ODM_RTL8821) && (dm->ant_div_type != S0S1_SW_ANTDIV)) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) CCK HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+					odm_set_bb_reg(dm, 0x800, BIT(25), swch);
+					odm_set_bb_reg(dm, 0xA00, BIT(15), swch); /* CCK AntDiv function block enable */
+				} else if (dm->support_ic_type == ODM_RTL8821C) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) CCK HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+					odm_set_bb_reg(dm, 0x800, BIT(25), swch);
+					odm_set_bb_reg(dm, 0xA00, BIT(15), swch); /* CCK AntDiv function block enable */
+				}
+			}
+		}
+	}
+	fat_tab->ant_div_on_off = swch;
+
+}
+
+void
+odm_tx_by_tx_desc_or_reg(
+	void		*dm_void,
+	u8			swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u8 enable;
+
+	if (fat_tab->b_fix_tx_ant == NO_FIX_TX_ANT)
+		enable = (swch == TX_BY_DESC) ? 1 : 0;
+	else
+		enable = 0;/*Force TX by Reg*/
+
+	if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT)
+			odm_set_bb_reg(dm, 0x80c, BIT(21), enable);
+		else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT)
+			odm_set_bb_reg(dm, 0x900, BIT(18), enable);
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv] TX_Ant_BY (( %s ))\n", (enable == TX_BY_DESC) ? "DESC" : "REG");
+	}
+}
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+void
+phydm_antdiv_reset_statistic(
+	void	*dm_void,
+	u32	macid
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	fat_tab->main_ant_sum[macid] = 0;
+	fat_tab->aux_ant_sum[macid] = 0;
+	fat_tab->main_ant_cnt[macid] = 0;
+	fat_tab->aux_ant_cnt[macid] = 0;
+	fat_tab->main_ant_sum_cck[macid] = 0;
+	fat_tab->aux_ant_sum_cck[macid] = 0;
+	fat_tab->main_ant_cnt_cck[macid] = 0;
+	fat_tab->aux_ant_cnt_cck[macid] = 0;
+}
+
+void
+phydm_fast_training_enable(
+	void		*dm_void,
+	u8			swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			enable;
+
+	if (swch == FAT_ON)
+		enable = 1;
+	else
+		enable = 0;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Fast ant Training_en = ((%d))\n", enable);
+
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		odm_set_bb_reg(dm, 0xe08, BIT(16), enable);	/*enable fast training*/
+		/**/
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, 0xB34, BIT(28), enable);	/*enable fast training (path-A)*/
+		/*odm_set_bb_reg(dm, 0xB34, BIT(29), enable);*/	/*enable fast training (path-B)*/
+	} else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8822B)) {
+		odm_set_bb_reg(dm, 0x900, BIT(19), enable);	/*enable fast training */
+		/**/
+	}
+}
+
+void
+phydm_keep_rx_ack_ant_by_tx_ant_time(
+	void		*dm_void,
+	u32		time
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	/* Timming issue: keep Rx ant after tx for ACK ( time x 3.2 mu sec)*/
+	if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+		odm_set_bb_reg(dm, 0xE20, BIT(23) | BIT(22) | BIT(21) | BIT(20), time);
+		/**/
+	} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+		odm_set_bb_reg(dm, 0x818, BIT(23) | BIT(22) | BIT(21) | BIT(20), time);
+		/**/
+	}
+}
+
+void
+odm_update_rx_idle_ant(
+	void		*dm_void,
+	u8		ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	u32			default_ant, optional_ant, value32, default_tx_ant;
+
+	if (fat_tab->rx_idle_ant != ant) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] rx_idle_ant =%s\n", (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+		if (!(dm->support_ic_type & ODM_RTL8723B))
+			fat_tab->rx_idle_ant = ant;
+
+		if (ant == MAIN_ANT) {
+			default_ant   =  ANT1_2G;
+			optional_ant =  ANT2_2G;
+		} else {
+			default_ant  =   ANT2_2G;
+			optional_ant =  ANT1_2G;
+		}
+
+		if (fat_tab->b_fix_tx_ant != NO_FIX_TX_ANT)
+			default_tx_ant = (fat_tab->b_fix_tx_ant == FIX_TX_AT_MAIN) ? 0 : 1;
+		else
+			default_tx_ant = default_ant;
+
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+			if (dm->support_ic_type == ODM_RTL8192E) {
+				odm_set_bb_reg(dm, 0xB38, BIT(5) | BIT(4) | BIT(3), default_ant); /* Default RX */
+				odm_set_bb_reg(dm, 0xB38, BIT(8) | BIT(7) | BIT(6), optional_ant); /* Optional RX */
+				odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant); /* Default TX */
+			}
+#if (RTL8723B_SUPPORT == 1)
+			else if (dm->support_ic_type == ODM_RTL8723B) {
+				value32 = odm_get_bb_reg(dm, 0x948, 0xFFF);
+
+				if (value32 != 0x280)
+					odm_update_rx_idle_ant_8723b(dm, ant, default_ant, optional_ant);
+				else
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to 0x948 = 0x280\n");
+			}
+#endif
+
+#if (RTL8723D_SUPPORT == 1)         /*Mingzhi 2017-05-08*/
+			else if (dm->support_ic_type == ODM_RTL8723D) {
+					phydm_set_tx_ant_pwr_8723d(dm, ant);
+					odm_update_rx_idle_ant_8723d(dm, ant, default_ant, optional_ant);
+
+			}
+#endif
+
+			else { /*8188E & 8188F*/
+/*
+				if (dm->support_ic_type == ODM_RTL8723D) {
+#if (RTL8723D_SUPPORT == 1)
+					phydm_set_tx_ant_pwr_8723d(dm, ant);
+#endif
+				}
+*/
+#if (RTL8188F_SUPPORT == 1)
+				if (dm->support_ic_type == ODM_RTL8188F) {
+					phydm_update_rx_idle_antenna_8188F(dm, default_ant);
+					/**/
+				}
+#endif
+
+				odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);		/*Default RX*/
+				odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);	/*Optional RX*/
+				odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_tx_ant);	/*Default TX*/
+			}
+		} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+			u16	value16 = odm_read_2byte(dm, ODM_REG_TRMUX_11AC + 2);
+			/*  */
+			/* 2014/01/14 MH/Luke.Lee Add direct write for register 0xc0a to prevnt */
+			/* incorrect 0xc08 bit0-15 .We still not know why it is changed. */
+			/*  */
+			value16 &= ~(BIT(11) | BIT(10) | BIT(9) | BIT(8) | BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3));
+			value16 |= ((u16)default_ant << 3);
+			value16 |= ((u16)optional_ant << 6);
+			value16 |= ((u16)default_ant << 9);
+			odm_write_2byte(dm, ODM_REG_TRMUX_11AC + 2, value16);
+#if 0
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(21) | BIT20 | BIT19, default_ant);	 /* Default RX */
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(24) | BIT23 | BIT22, optional_ant); /* Optional RX */
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(27) | BIT26 | BIT25, default_ant);	 /* Default TX */
+#endif
+		}
+
+		if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A)) {
+			odm_set_mac_reg(dm, 0x6D8, 0x7, default_tx_ant);		/*PathA Resp Tx*/
+			/**/
+		} else if (dm->support_ic_type == ODM_RTL8188E) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(7) | BIT(6), default_tx_ant);		/*PathA Resp Tx*/
+			/**/
+		} else {
+			odm_set_mac_reg(dm, 0x6D8, BIT(10) | BIT(9) | BIT(8), default_tx_ant);	/*PathA Resp Tx*/
+			/**/
+		}
+
+	} else { /* fat_tab->rx_idle_ant == ant */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Stay in Ori-ant ]  rx_idle_ant =%s\n", (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+		fat_tab->rx_idle_ant = ant;
+	}
+}
+
+void
+phydm_set_antdiv_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (val_len != 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][antdiv]Need val_len=1\n");
+		return;
+	}
+	
+	odm_update_rx_idle_ant(dm, (u8)(*val_buf));
+}
+
+void
+odm_update_tx_ant(
+	void		*dm_void,
+	u8		ant,
+	u32		mac_id
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u8	tx_ant;
+
+	if (fat_tab->b_fix_tx_ant != NO_FIX_TX_ANT)
+		ant = (fat_tab->b_fix_tx_ant == FIX_TX_AT_MAIN) ? MAIN_ANT : AUX_ANT;
+
+	if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+		tx_ant = ant;
+	else {
+		if (ant == MAIN_ANT)
+			tx_ant = ANT1_2G;
+		else
+			tx_ant = ANT2_2G;
+	}
+
+	fat_tab->antsel_a[mac_id] = tx_ant & BIT(0);
+	fat_tab->antsel_b[mac_id] = (tx_ant & BIT(1)) >> 1;
+	fat_tab->antsel_c[mac_id] = (tx_ant & BIT(2)) >> 2;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[Set TX-DESC value]: mac_id:(( %d )),  tx_ant = (( %s ))\n", mac_id, (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+	/* PHYDM_DBG(dm,DBG_ANT_DIV,"antsel_tr_mux=(( 3'b%d%d%d ))\n",fat_tab->antsel_c[mac_id] , fat_tab->antsel_b[mac_id] , fat_tab->antsel_a[mac_id] ); */
+
+}
+
+#ifdef BEAMFORMING_SUPPORT
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_bdc_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n[ BDC Initialization......]\n");
+	dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+	dm_bdc_table->bdc_mode = BDC_MODE_NULL;
+	dm_bdc_table->bdc_try_flag = 0;
+	dm_bdc_table->bd_ccoex_type_wbfer = 0;
+	dm->bdc_holdstate = 0xff;
+
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, 0xd7c, 0x0FFFFFFF, 0x1081008);
+		odm_set_bb_reg(dm, 0xd80, 0x0FFFFFFF, 0);
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		odm_set_bb_reg(dm, 0x9b0, 0x0FFFFFFF, 0x1081008);     /* 0x9b0[30:0] = 01081008 */
+		odm_set_bb_reg(dm, 0x9b4, 0x0FFFFFFF, 0);                 /* 0x9b4[31:0] = 00000000 */
+	}
+
+}
+
+
+void
+odm_CSI_on_off(
+	void		*dm_void,
+	u8			CSI_en
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (CSI_en == CSI_ON) {
+		if (dm->support_ic_type == ODM_RTL8192E)
+			odm_set_mac_reg(dm, 0xd84, BIT(11), 1);  /* 0xd84[11]=1 */
+		else if (dm->support_ic_type == ODM_RTL8812)
+			odm_set_mac_reg(dm, 0x9b0, BIT(31), 1);  /* 0x9b0[31]=1 */
+
+	} else if (CSI_en == CSI_OFF) {
+		if (dm->support_ic_type == ODM_RTL8192E)
+			odm_set_mac_reg(dm, 0xd84, BIT(11), 0);  /* 0xd84[11]=0 */
+		else if (dm->support_ic_type == ODM_RTL8812)
+			odm_set_mac_reg(dm, 0x9b0, BIT(31), 0);  /* 0x9b0[31]=0 */
+	}
+}
+
+void
+odm_bd_ccoex_type_with_bfer_client(
+	void		*dm_void,
+	u8			swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+	u8     bd_ccoex_type_wbfer;
+
+	if (swch == DIVON_CSIOFF) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[BDCcoexType: 1] {DIV,CSI} ={1,0}\n");
+		bd_ccoex_type_wbfer = 1;
+
+		if (bd_ccoex_type_wbfer != dm_bdc_table->bd_ccoex_type_wbfer) {
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+			odm_CSI_on_off(dm, CSI_OFF);
+			dm_bdc_table->bd_ccoex_type_wbfer = 1;
+		}
+	} else if (swch == DIVOFF_CSION) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[BDCcoexType: 2] {DIV,CSI} ={0,1}\n");
+		bd_ccoex_type_wbfer = 2;
+
+		if (bd_ccoex_type_wbfer != dm_bdc_table->bd_ccoex_type_wbfer) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_CSI_on_off(dm, CSI_ON);
+			dm_bdc_table->bd_ccoex_type_wbfer = 2;
+		}
+	}
+}
+
+void
+odm_bf_ant_div_mode_arbitration(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_			*dm_bdc_table = &dm->dm_bdc_table;
+	u8			current_bdc_mode;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n");
+
+	/* 2 mode 1 */
+	if ((dm_bdc_table->num_txbfee_client != 0) && (dm_bdc_table->num_txbfer_client == 0)) {
+		current_bdc_mode = BDC_MODE_1;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_1;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			dm_bdc_table->bdc_rx_idle_update_counter = 1;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode1 ))\n");
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode1 ))\n");
+	}
+	/* 2 mode 2 */
+	else if ((dm_bdc_table->num_txbfee_client == 0) && (dm_bdc_table->num_txbfer_client != 0)) {
+		current_bdc_mode = BDC_MODE_2;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_2;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			dm_bdc_table->bdc_try_flag = 0;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode2 ))\n");
+
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode2 ))\n");
+	}
+	/* 2 mode 3 */
+	else if ((dm_bdc_table->num_txbfee_client != 0) && (dm_bdc_table->num_txbfer_client != 0)) {
+		current_bdc_mode = BDC_MODE_3;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_3;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->bdc_rx_idle_update_counter = 1;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode3 ))\n");
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode3 ))\n");
+	}
+	/* 2 mode 4 */
+	else if ((dm_bdc_table->num_txbfee_client == 0) && (dm_bdc_table->num_txbfer_client == 0)) {
+		current_bdc_mode = BDC_MODE_4;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_4;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode4 ))\n");
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode4 ))\n");
+	}
+#endif
+
+}
+
+void
+odm_div_train_state_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n*****[S T A R T ]*****  [2-0. DIV_TRAIN_STATE]\n");
+	dm_bdc_table->bdc_try_counter = 2;
+	dm_bdc_table->bdc_try_flag = 1;
+	dm_bdc_table->BDC_state = bdc_bfer_train_state;
+	odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+}
+
+void
+odm_bd_ccoex_bfee_rx_div_arbitration(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_    *dm_bdc_table = &dm->dm_bdc_table;
+	boolean stop_bf_flag;
+	u8	bdc_active_mode;
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***{ num_BFee,  num_BFer, num_client}  = (( %d  ,  %d  ,  %d))\n", dm_bdc_table->num_txbfee_client, dm_bdc_table->num_txbfer_client, dm_bdc_table->num_client);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***{ num_BF_tars,  num_DIV_tars }  = ((  %d  ,  %d ))\n", dm_bdc_table->num_bf_tar, dm_bdc_table->num_div_tar);
+
+	/* 2 [ MIB control ] */
+	if (dm->bdc_holdstate == 2) {
+		odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+		dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ BF STATE]\n");
+		return;
+	} else if (dm->bdc_holdstate == 1) {
+		dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+		odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ DIV STATE]\n");
+		return;
+	}
+
+	/* ------------------------------------------------------------ */
+
+
+
+	/* 2 mode 2 & 3 */
+	if (dm_bdc_table->bdc_mode == BDC_MODE_2 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n{ Try_flag,  Try_counter } = {  %d , %d  }\n", dm_bdc_table->bdc_try_flag, dm_bdc_table->bdc_try_counter);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "BDCcoexType = (( %d ))\n\n", dm_bdc_table->bd_ccoex_type_wbfer);
+
+		/* All Client have Bfer-Cap------------------------------- */
+		if (dm_bdc_table->num_txbfer_client == dm_bdc_table->num_client) { /* BFer STA Only?: yes */
+			PHYDM_DBG(dm, DBG_ANT_DIV, "BFer STA only?  (( Yes ))\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+			return;
+		} else
+			PHYDM_DBG(dm, DBG_ANT_DIV, "BFer STA only?  (( No ))\n");
+		/*  */
+		if (dm_bdc_table->is_all_bf_sta_idle == false && dm_bdc_table->is_all_div_sta_idle == true) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "All DIV-STA are idle, but BF-STA not\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = bdc_bfer_train_state;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+			return;
+		} else if (dm_bdc_table->is_all_bf_sta_idle == true && dm_bdc_table->is_all_div_sta_idle == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "All BF-STA are idle, but DIV-STA not\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			return;
+		}
+
+		/* Select active mode-------------------------------------- */
+		if (dm_bdc_table->num_bf_tar == 0) { /* Selsect_1,  Selsect_2 */
+			if (dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode (( 1 ))\n");
+				dm_bdc_table->bdc_active_mode = 1;
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode  (( 2 ))\n");
+				dm_bdc_table->bdc_active_mode = 2;
+			}
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			return;
+		} else { /* num_bf_tar > 0 */
+			if (dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode (( 3 ))\n");
+				dm_bdc_table->bdc_active_mode = 3;
+				dm_bdc_table->bdc_try_flag = 0;
+				dm_bdc_table->BDC_state = bdc_bfer_train_state;
+				odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+				return;
+			} else { /* Selsect_4 */
+				bdc_active_mode = 4;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode (( 4 ))\n");
+
+				if (bdc_active_mode != dm_bdc_table->bdc_active_mode) {
+					dm_bdc_table->bdc_active_mode = 4;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "Change to active mode (( 4 ))  &  return!!!\n");
+					return;
+				}
+			}
+		}
+
+#if 1
+		if (dm->bdc_holdstate == 0xff) {
+			dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ DIV STATE]\n");
+			return;
+		}
+#endif
+
+		/* Does Client number changed ? ------------------------------- */
+		if (dm_bdc_table->num_client != dm_bdc_table->pre_num_client) {
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[  The number of client has been changed !!!]   return to (( BDC_DIV_TRAIN_STATE ))\n");
+		}
+		dm_bdc_table->pre_num_client = dm_bdc_table->num_client;
+
+		if (dm_bdc_table->bdc_try_flag == 0) {
+			/* 2 DIV_TRAIN_STATE (mode 2-0) */
+			if (dm_bdc_table->BDC_state == BDC_DIV_TRAIN_STATE)
+				odm_div_train_state_setting(dm);
+			/* 2 BFer_TRAIN_STATE (mode 2-1) */
+			else if (dm_bdc_table->BDC_state == bdc_bfer_train_state) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-1. BFer_TRAIN_STATE ]*****\n");
+
+				/* if(dm_bdc_table->num_bf_tar==0) */
+				/* { */
+				/*	PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( No )),   [ bdc_bfer_train_state ] >> [BDC_DIV_TRAIN_STATE]\n"); */
+				/*	odm_div_train_state_setting( dm); */
+				/* } */
+				/* else */ /* num_bf_tar != 0 */
+				/* { */
+				dm_bdc_table->bdc_try_counter = 2;
+				dm_bdc_table->bdc_try_flag = 1;
+				dm_bdc_table->BDC_state = BDC_DECISION_STATE;
+				odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+				PHYDM_DBG(dm, DBG_ANT_DIV, "BF_tars exist?  : (( Yes )),   [ bdc_bfer_train_state ] >> [BDC_DECISION_STATE]\n");
+				/* } */
+			}
+			/* 2 DECISION_STATE (mode 2-2) */
+			else if (dm_bdc_table->BDC_state == BDC_DECISION_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-2. DECISION_STATE]*****\n");
+				/* if(dm_bdc_table->num_bf_tar==0) */
+				/* { */
+				/*	ODM_AntDiv_Printk(("BF_tars exist?  : (( No )),   [ DECISION_STATE ] >> [BDC_DIV_TRAIN_STATE]\n")); */
+				/*	odm_div_train_state_setting( dm); */
+				/* } */
+				/* else */ /* num_bf_tar != 0 */
+				/* { */
+				if (dm_bdc_table->BF_pass == false || dm_bdc_table->DIV_pass == false)
+					stop_bf_flag = true;
+				else
+					stop_bf_flag = false;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "BF_tars exist?  : (( Yes )),  {BF_pass, DIV_pass, stop_bf_flag }  = { %d, %d, %d }\n", dm_bdc_table->BF_pass, dm_bdc_table->DIV_pass, stop_bf_flag);
+
+				if (stop_bf_flag == true) { /* DIV_en */
+					dm_bdc_table->bdc_hold_counter = 10; /* 20 */
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+					dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ stop_bf_flag= ((true)),   BDC_DECISION_STATE ] >> [BDC_DIV_HOLD_STATE]\n");
+				} else { /* BF_en */
+					dm_bdc_table->bdc_hold_counter = 10; /* 20 */
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+					dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[stop_bf_flag= ((false)),   BDC_DECISION_STATE ] >> [BDC_BF_HOLD_STATE]\n");
+				}
+				/* } */
+			}
+			/* 2 BF-HOLD_STATE (mode 2-3) */
+			else if (dm_bdc_table->BDC_state == BDC_BF_HOLD_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-3. BF_HOLD_STATE ]*****\n");
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "bdc_hold_counter = (( %d ))\n", dm_bdc_table->bdc_hold_counter);
+
+				if (dm_bdc_table->bdc_hold_counter == 1) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n");
+					odm_div_train_state_setting(dm);
+				} else {
+					dm_bdc_table->bdc_hold_counter--;
+
+					/* if(dm_bdc_table->num_bf_tar==0) */
+					/* { */
+					/*	PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( No )),   [ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n"); */
+					/*	odm_div_train_state_setting( dm); */
+					/* } */
+					/* else */ /* num_bf_tar != 0 */
+					/* { */
+					/* PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( Yes ))\n"); */
+					dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_BF_HOLD_STATE ] >> [BDC_BF_HOLD_STATE]\n");
+					/* } */
+				}
+
+			}
+			/* 2 DIV-HOLD_STATE (mode 2-4) */
+			else if (dm_bdc_table->BDC_state == BDC_DIV_HOLD_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-4. DIV_HOLD_STATE ]*****\n");
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "bdc_hold_counter = (( %d ))\n", dm_bdc_table->bdc_hold_counter);
+
+				if (dm_bdc_table->bdc_hold_counter == 1) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n");
+					odm_div_train_state_setting(dm);
+				} else {
+					dm_bdc_table->bdc_hold_counter--;
+					dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_HOLD_STATE]\n");
+				}
+
+			}
+
+		} else if (dm_bdc_table->bdc_try_flag == 1) {
+			/* 2 Set Training counter */
+			if (dm_bdc_table->bdc_try_counter > 1) {
+				dm_bdc_table->bdc_try_counter--;
+				if (dm_bdc_table->bdc_try_counter == 1)
+					dm_bdc_table->bdc_try_flag = 0;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Training !!\n");
+				/* return ; */
+			}
+
+		}
+
+	}
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n[end]\n");
+
+#endif /* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+
+
+
+
+
+
+}
+
+#endif
+#endif /* #ifdef BEAMFORMING_SUPPORT */
+
+
+#if (RTL8188E_SUPPORT == 1)
+
+
+void
+odm_rx_hw_ant_div_init_88e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	value32;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_set_bb_reg(dm, ODM_REG_IGI_A_11N, BIT(7), 0); /* disable HW AntDiv */
+		odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);  /* 1:CG, 0:CS */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188E AntDiv_Init =>  ant_div_type=[CGCS_RX_HW_ANTDIV]\n");
+
+	/* MAC setting */
+	value32 = odm_get_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
+	odm_set_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	/* Pin Settings */
+	odm_set_bb_reg(dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 1);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);	/* regb2c[31]=1'b1	 */ /* output at CG only */
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
+	/* CCK Settings */
+	odm_set_bb_reg(dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+	odm_set_bb_reg(dm, ODM_REG_ANT_MAPPING1_11N, 0xFFFF, 0x0001);	/* antenna mapping table */
+
+	fat_tab->enable_ctrl_frame_antdiv = 1;
+}
+
+void
+odm_trx_hw_ant_div_init_88e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	value32;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_set_bb_reg(dm, ODM_REG_IGI_A_11N, BIT(7), 0); /* disable HW AntDiv */
+		odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(5) | BIT4 | BIT3, 0); /* Default RX   (0/1) */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188E AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV (SPDT)]\n");
+
+	/* MAC setting */
+	value32 = odm_get_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
+	odm_set_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	/* Pin Settings */
+	odm_set_bb_reg(dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 0);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);	/* regb2c[31]=1'b1	 */ /* output at CG only */
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
+	/* CCK Settings */
+	odm_set_bb_reg(dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+	/* antenna mapping table */
+	if (!dm->is_mp_chip) { /* testchip */
+		odm_set_bb_reg(dm, ODM_REG_RX_DEFAULT_A_11N, BIT(10) | BIT(9) | BIT(8), 1);	/* Reg858[10:8]=3'b001 */
+		odm_set_bb_reg(dm, ODM_REG_RX_DEFAULT_A_11N, BIT(13) | BIT(12) | BIT(11), 2);	/* Reg858[13:11]=3'b010 */
+	} else /* MPchip */
+		odm_set_bb_reg(dm, ODM_REG_ANT_MAPPING1_11N, MASKDWORD, 0x0201);	/*Reg914=3'b010, Reg915=3'b001*/
+
+	fat_tab->enable_ctrl_frame_antdiv = 1;
+}
+
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+void
+odm_smart_hw_ant_div_init_88e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	value32, i;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n");
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "dm->ant_div_type: %d\n", dm->ant_div_type);
+		return;
+	}
+#endif
+
+	fat_tab->train_idx = 0;
+	fat_tab->fat_state = FAT_PREPARE_STATE;
+
+	dm->fat_comb_a = 5;
+	dm->antdiv_intvl = 0x64; /* 100ms */
+
+	for (i = 0; i < 6; i++)
+		fat_tab->bssid[i] = 0;
+	for (i = 0; i < (dm->fat_comb_a) ; i++) {
+		fat_tab->ant_sum_rssi[i] = 0;
+		fat_tab->ant_rssi_cnt[i] = 0;
+		fat_tab->ant_ave_rssi[i] = 0;
+	}
+
+	/* MAC setting */
+	value32 = odm_get_mac_reg(dm, 0x4c, MASKDWORD);
+	odm_set_mac_reg(dm, 0x4c, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	value32 = odm_get_mac_reg(dm,  0x7B4, MASKDWORD);
+	odm_set_mac_reg(dm, 0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17))); /* Reg7B4[16]=1 enable antenna training, Reg7B4[17]=1 enable A2 match */
+	/* value32 = platform_efio_read_4byte(adapter, 0x7B4); */
+	/* platform_efio_write_4byte(adapter, 0x7b4, value32|BIT(18));	 */ /* append MACID in reponse packet */
+
+	/* Match MAC ADDR */
+	odm_set_mac_reg(dm, 0x7b4, 0xFFFF, 0);
+	odm_set_mac_reg(dm, 0x7b0, MASKDWORD, 0);
+
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, 0x864, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, 0xb2c, BIT(22), 0);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, 0xb2c, BIT(31), 0);	/* regb2c[31]=1'b1	 */ /* output at CS only */
+	odm_set_bb_reg(dm, 0xca4, MASKDWORD, 0x000000a0);
+
+	/* antenna mapping table */
+	if (dm->fat_comb_a == 2) {
+		if (!dm->is_mp_chip) { /* testchip */
+			odm_set_bb_reg(dm, 0x858, BIT(10) | BIT(9) | BIT(8), 1);	/* Reg858[10:8]=3'b001 */
+			odm_set_bb_reg(dm, 0x858, BIT(13) | BIT(12) | BIT(11), 2);	/* Reg858[13:11]=3'b010 */
+		} else { /* MPchip */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE0, 1);
+			odm_set_bb_reg(dm, 0x914, MASKBYTE1, 2);
+		}
+	} else {
+		if (!dm->is_mp_chip) { /* testchip */
+			odm_set_bb_reg(dm, 0x858, BIT(10) | BIT(9) | BIT(8), 0);	/* Reg858[10:8]=3'b000 */
+			odm_set_bb_reg(dm, 0x858, BIT(13) | BIT(12) | BIT(11), 1);	/* Reg858[13:11]=3'b001 */
+			odm_set_bb_reg(dm, 0x878, BIT(16), 0);
+			odm_set_bb_reg(dm, 0x858, BIT(15) | BIT(14), 2);	/* (Reg878[0],Reg858[14:15])=3'b010 */
+			odm_set_bb_reg(dm, 0x878, BIT(19) | BIT(18) | BIT(17), 3); /* Reg878[3:1]=3b'011 */
+			odm_set_bb_reg(dm, 0x878, BIT(22) | BIT(21) | BIT(20), 4); /* Reg878[6:4]=3b'100 */
+			odm_set_bb_reg(dm, 0x878, BIT(25) | BIT(24) | BIT(23), 5); /* Reg878[9:7]=3b'101 */
+			odm_set_bb_reg(dm, 0x878, BIT(28) | BIT(27) | BIT(26), 6); /* Reg878[12:10]=3b'110 */
+			odm_set_bb_reg(dm, 0x878, BIT(31) | BIT(30) | BIT(29), 7); /* Reg878[15:13]=3b'111 */
+		} else { /* MPchip */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE0, 4);     /* 0: 3b'000 */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE1, 2);     /* 1: 3b'001 */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE2, 0);     /* 2: 3b'010 */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE3, 1);     /* 3: 3b'011 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE0, 3);     /* 4: 3b'100 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE1, 5);     /* 5: 3b'101 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE2, 6);     /* 6: 3b'110 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE3, 255); /* 7: 3b'111 */
+		}
+	}
+
+	/* Default ant setting when no fast training */
+	odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), 0);	/* Default RX */
+	odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), 1);	/* Optional RX */
+	odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), 0); /* Default TX */
+
+	/* Enter Traing state */
+	odm_set_bb_reg(dm, 0x864, BIT(2) | BIT(1) | BIT(0), (dm->fat_comb_a - 1));	/* reg864[2:0]=3'd6	 */ /* ant combination=reg864[2:0]+1 */
+
+	/* SW Control */
+	/* phy_set_bb_reg(adapter, 0x864, BIT10, 1); */
+	/* phy_set_bb_reg(adapter, 0x870, BIT9, 1); */
+	/* phy_set_bb_reg(adapter, 0x870, BIT8, 1); */
+	/* phy_set_bb_reg(adapter, 0x864, BIT11, 1); */
+	/* phy_set_bb_reg(adapter, 0x860, BIT9, 0); */
+	/* phy_set_bb_reg(adapter, 0x860, BIT8, 0); */
+}
+#endif
+
+#endif /* #if (RTL8188E_SUPPORT == 1) */
+
+
+#if (RTL8192E_SUPPORT == 1)
+void
+odm_rx_hw_ant_div_init_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		odm_set_bb_reg(dm, 0xc50, BIT(8), 0); /* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
+		odm_set_bb_reg(dm, 0xc50, BIT(9), 1);  /* 1:CG, 0:CS */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8192E AntDiv_Init =>  ant_div_type=[CGCS_RX_HW_ANTDIV]\n");
+
+	/* Pin Settings */
+	odm_set_bb_reg(dm, 0x870, BIT(8), 0);/* reg870[8]=1'b0,     */ /* "antsel" is controled by HWs */
+	odm_set_bb_reg(dm, 0xc50, BIT(8), 1); /* regc50[8]=1'b1   */ /* " CS/CG switching" is controled by HWs */
+
+	/* Mapping table */
+	odm_set_bb_reg(dm, 0x914, 0xFFFF, 0x0100); /* antenna mapping table */
+
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF000, 0x0); /* bias */
+
+	/* CCK Settings */
+	odm_set_bb_reg(dm, 0xa04, 0xF000000, 0); /* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, 0xb34, BIT(30), 0); /* (92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, 0xa74, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, 0xa0c, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+
+}
+
+void
+odm_trx_hw_ant_div_init_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		odm_set_bb_reg(dm, 0xc50, BIT(8), 0); /* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
+		odm_set_bb_reg(dm, 0xc50, BIT(9), 1);  /* 1:CG, 0:CS */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8192E AntDiv_Init =>  ant_div_type=[ Only for DIR605, CG_TRX_HW_ANTDIV]\n");
+
+	/* 3 --RFE pin setting--------- */
+	/* [MAC] */
+	odm_set_mac_reg(dm, 0x38, BIT(11), 1);            /* DBG PAD Driving control (GPIO 8) */
+	odm_set_mac_reg(dm, 0x4c, BIT(23), 0);            /* path-A, RFE_CTRL_3 */
+	odm_set_mac_reg(dm, 0x4c, BIT(29), 1);            /* path-A, RFE_CTRL_8 */
+	/* [BB] */
+	odm_set_bb_reg(dm, 0x944, BIT(3), 1);              /* RFE_buffer */
+	odm_set_bb_reg(dm, 0x944, BIT(8), 1);
+	odm_set_bb_reg(dm, 0x940, BIT(7) | BIT(6), 0x0); /* r_rfe_path_sel_   (RFE_CTRL_3) */
+	odm_set_bb_reg(dm, 0x940, BIT(17) | BIT(16), 0x0); /* r_rfe_path_sel_   (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, 0x944, BIT(31), 0);     /* RFE_buffer */
+	odm_set_bb_reg(dm, 0x92C, BIT(3), 0);     /* rfe_inv  (RFE_CTRL_3) */
+	odm_set_bb_reg(dm, 0x92C, BIT(8), 1);     /* rfe_inv  (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, 0x930, 0xF000, 0x8);           /* path-A, RFE_CTRL_3 */
+	odm_set_bb_reg(dm, 0x934, 0xF, 0x8);           /* path-A, RFE_CTRL_8 */
+	/* 3 ------------------------- */
+
+	/* Pin Settings */
+	odm_set_bb_reg(dm, 0xC50, BIT(8), 0);	/* path-A  	 */ /* disable CS/CG switch */
+
+#if 0
+	/* Let it follows PHY_REG for bit9 setting */
+	if (dm->priv->pshare->rf_ft_var.use_ext_pa || dm->priv->pshare->rf_ft_var.use_ext_lna)
+		odm_set_bb_reg(dm, 0xC50, BIT(9), 1);	/* path-A 	output at CS */
+	else
+		odm_set_bb_reg(dm, 0xC50, BIT(9), 0);	/* path-A 	output at CG ->normal power */
+#endif
+
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);	/* path-A*/	/* antsel antselb by HW */
+	odm_set_bb_reg(dm, 0xB38, BIT(10), 0);	/* path-A	*/	/* antsel2 by HW */
+
+	/* Mapping table */
+	odm_set_bb_reg(dm, 0x914, 0xFFFF, 0x0100); /* antenna mapping table */
+
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF000, 0x0); /* bias */
+
+	/* CCK Settings */
+	odm_set_bb_reg(dm, 0xa04, 0xF000000, 0); /* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, 0xb34, BIT(30), 0); /* (92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, 0xa74, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, 0xa0c, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+}
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+void
+odm_smart_hw_ant_div_init_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8192E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n");
+}
+#endif
+
+#endif /* #if (RTL8192E_SUPPORT == 1) */
+
+#if (RTL8723D_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8723d(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[8723D] AntDiv_Init =>  ant_div_type=[S0S1_HW_TRX_AntDiv]\n");
+
+	/*BT Coexistence*/
+	/*keep antsel_map when GNT_BT = 1*/
+	odm_set_bb_reg(dm, 0x864, BIT(12), 1);
+	/* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	odm_set_bb_reg(dm, 0x874, BIT(23), 0);
+	/* Disable hw antsw & fast_train.antsw when BT TX/RX */
+	odm_set_bb_reg(dm, 0xE64, 0xFFFF0000, 0x000c);
+
+
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);
+	/*PTA setting: WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL)*/
+	/*odm_set_bb_reg(dm, 0x948, BIT6, 0);*/
+	/*odm_set_bb_reg(dm, 0x948, BIT8, 0);*/
+	/*GNT_WL tx*/
+	odm_set_bb_reg(dm, 0x950, BIT(29), 0);
+
+
+	/*Mapping Table*/
+	odm_set_bb_reg(dm, 0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0x914, MASKBYTE1, 3);
+	/* odm_set_bb_reg(dm, 0x864, BIT5|BIT4|BIT3, 0); */
+	/* odm_set_bb_reg(dm, 0x864, BIT8|BIT7|BIT6, 1); */
+
+	/* Set WLBB_SEL_RF_ON 1 if RXFIR_PWDB > 0xCcc[3:0] */
+	odm_set_bb_reg(dm, 0xCcc, BIT(12), 0);
+	/* Low-to-High threshold for WLBB_SEL_RF_ON when OFDM enable */
+	odm_set_bb_reg(dm, 0xCcc, 0x0F, 0x01);
+	/* High-to-Low threshold for WLBB_SEL_RF_ON when OFDM enable */
+	odm_set_bb_reg(dm, 0xCcc, 0xF0, 0x0);
+	/* b Low-to-High threshold for WLBB_SEL_RF_ON when OFDM disable ( only CCK ) */
+	odm_set_bb_reg(dm, 0xAbc, 0xFF, 0x06);
+	/* High-to-Low threshold for WLBB_SEL_RF_ON when OFDM disable ( only CCK ) */
+	odm_set_bb_reg(dm, 0xAbc, 0xFF00, 0x00);
+
+
+	/*OFDM HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF, 0xa0);
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF000, 0x00);
+	odm_set_bb_reg(dm, 0xC5C, BIT(20) | BIT(19) | BIT(18), 0x04);
+
+	/*CCK HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1);
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1);
+	odm_set_bb_reg(dm, 0xAA8, BIT(8), 0);
+
+	odm_set_bb_reg(dm, 0xA0C, 0x0F, 0xf);
+	odm_set_bb_reg(dm, 0xA14, 0x1F, 0x8);
+	odm_set_bb_reg(dm, 0xA10, BIT(13), 0x1);
+	odm_set_bb_reg(dm, 0xA74, BIT(8), 0x0);
+	odm_set_bb_reg(dm, 0xB34, BIT(30), 0x1);
+
+	/*disable antenna training	*/
+	odm_set_bb_reg(dm, 0xE08, BIT(16), 0);
+	odm_set_bb_reg(dm, 0xc50, BIT(8), 0);
+
+}
+/*Mingzhi 2017-05-08*/
+
+void
+odm_update_rx_idle_ant_8723d(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	void		*adapter = dm->adapter;
+	u8			count = 0;
+	
+
+/*	odm_set_bb_reg(dm, 0x948, BIT(6), 0x1);	*/
+	odm_set_bb_reg(dm, 0x948, BIT(7), default_ant);
+	odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);      /*Default RX*/
+	odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);     /*Optional RX*/
+	odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant);    /*Default TX*/
+	fat_tab->rx_idle_ant = ant;
+
+}
+
+void
+phydm_set_tx_ant_pwr_8723d(
+	void			*dm_void,
+	u8			ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	PADAPTER    adapter = (PADAPTER)dm->adapter;
+
+	fat_tab->rx_idle_ant = ant;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	adapter->HalFunc.SetTxPowerLevelHandler(adapter, *dm->channel);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	rtw_hal_set_tx_power_level(adapter, *dm->channel);
+#endif
+
+}
+#endif
+
+#if (RTL8723B_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8723b(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8723B AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV(DPDT)]\n");
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0x914, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF, 0xa0); /* thershold */
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF000, 0x00); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0x864, BIT(12), 0); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x874, BIT(23), 0); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	/* Output Pin Settings */
+	odm_set_bb_reg(dm, 0x870, BIT(8), 0);
+
+	odm_set_bb_reg(dm, 0x948, BIT(6), 0); /* WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL) */
+	odm_set_bb_reg(dm, 0x948, BIT(7), 0);
+
+	odm_set_mac_reg(dm, 0x40, BIT(3), 1);
+	odm_set_mac_reg(dm, 0x38, BIT(11), 1);
+	odm_set_mac_reg(dm, 0x4C,  BIT(24) | BIT(23), 2); /* select DPDT_P and DPDT_N as output pin */
+
+	odm_set_bb_reg(dm, 0x944, BIT(0) | BIT(1), 3); /* in/out */
+	odm_set_bb_reg(dm, 0x944, BIT(31), 0);
+
+	odm_set_bb_reg(dm, 0x92C, BIT(1), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0x92C, BIT(0), 1); /* DPDT_N inverse */
+
+	odm_set_bb_reg(dm, 0x930, 0xF0, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0x930, 0xF, 8); /* DPDT_N = ANTSEL[0] */
+
+	/* 2 [--For HW Bug setting] */
+	if (dm->ant_type == ODM_AUTO_ANT)
+		odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+}
+
+
+
+void
+odm_s0s1_sw_ant_div_init_8723b(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8723B AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0x914, MASKBYTE1, 1);
+
+	/* Output Pin Settings */
+	/* odm_set_bb_reg(dm, 0x948, BIT6, 0x1); */
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);
+
+	fat_tab->is_become_linked  = false;
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+
+	/* 2 [--For HW Bug setting] */
+	odm_set_bb_reg(dm, 0x80C, BIT(21), 0); /* TX ant  by Reg */
+
+}
+
+void
+odm_update_rx_idle_ant_8723b(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	PADAPTER    adapter = (PADAPTER)dm->adapter;
+	u8			count = 0;
+	/*u8			u1_temp;*/
+	/*u8			h2c_parameter;*/
+
+	if ((!dm->is_linked) && (dm->ant_type == ODM_AUTO_ANT)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to no link\n");
+		return;
+	}
+
+#if 0
+	/* Send H2C command to FW */
+	/* Enable wifi calibration */
+	h2c_parameter = true;
+	odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+
+	/* Check if H2C command sucess or not (0x1e6) */
+	u1_temp = odm_read_1byte(dm, 0x1e6);
+	while ((u1_temp != 0x1) && (count < 100)) {
+		ODM_delay_us(10);
+		u1_temp = odm_read_1byte(dm, 0x1e6);
+		count++;
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: H2C command status = %d, count = %d\n", u1_temp, count);
+
+	if (u1_temp == 0x1) {
+		/* Check if BT is doing IQK (0x1e7) */
+		count = 0;
+		u1_temp = odm_read_1byte(dm, 0x1e7);
+		while ((!(u1_temp & BIT(0)))  && (count < 100)) {
+			ODM_delay_us(50);
+			u1_temp = odm_read_1byte(dm, 0x1e7);
+			count++;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: BT IQK status = %d, count = %d\n", u1_temp, count);
+
+		if (u1_temp & BIT(0)) {
+			odm_set_bb_reg(dm, 0x948, BIT(6), 0x1);
+			odm_set_bb_reg(dm, 0x948, BIT(9), default_ant);
+			odm_set_bb_reg(dm, 0x864, BIT(5) | BIT4 | BIT3, default_ant);	/* Default RX */
+			odm_set_bb_reg(dm, 0x864, BIT(8) | BIT7 | BIT6, optional_ant);	/* Optional RX */
+			odm_set_bb_reg(dm, 0x860, BIT(14) | BIT13 | BIT12, default_ant); /* Default TX */
+			fat_tab->rx_idle_ant = ant;
+
+			/* Set TX AGC by S0/S1 */
+			/* Need to consider Linux driver */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			adapter->hal_func.set_tx_power_level_handler(adapter, *dm->channel);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+			rtw_hal_set_tx_power_level(adapter, *dm->channel);
+#endif
+
+			/* Set IQC by S0/S1 */
+			odm_set_iqc_by_rfpath(dm, default_ant);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n");
+		} else
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to BT IQK\n");
+	} else
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to H2C command fail\n");
+
+	/* Send H2C command to FW */
+	/* Disable wifi calibration */
+	h2c_parameter = false;
+	odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+#else
+
+	odm_set_bb_reg(dm, 0x948, BIT(6), 0x1);
+	odm_set_bb_reg(dm, 0x948, BIT(9), default_ant);
+	odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);      /*Default RX*/
+	odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);     /*Optional RX*/
+	odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant);    /*Default TX*/
+	fat_tab->rx_idle_ant = ant;
+
+	/* Set TX AGC by S0/S1 */
+	/* Need to consider Linux driver */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	adapter->HalFunc.SetTxPowerLevelHandler(adapter, *dm->channel);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	rtw_hal_set_tx_power_level(adapter, *dm->channel);
+#endif
+
+	/* Set IQC by S0/S1 */
+	odm_set_iqc_by_rfpath(dm, default_ant);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n");
+
+#endif
+}
+
+boolean
+phydm_is_bt_enable_8723b(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			bt_state;
+	/*u32			reg75;*/
+
+	/*reg75 = odm_get_bb_reg(dm, 0x74, BIT8);*/
+	/*odm_set_bb_reg(dm, 0x74, BIT8, 0x0);*/
+	odm_set_bb_reg(dm, 0xa0, BIT(24) | BIT(25) | BIT(26), 0x5);
+	bt_state = odm_get_bb_reg(dm, 0xa0, (BIT(3) | BIT(2) | BIT(1) | BIT(0)));
+	/*odm_set_bb_reg(dm, 0x74, BIT8, reg75);*/
+
+	if ((bt_state == 4) || (bt_state == 7) || (bt_state == 9) || (bt_state == 13))
+		return true;
+	else
+		return false;
+}
+#endif /* #if (RTL8723B_SUPPORT == 1) */
+
+#if (RTL8821A_SUPPORT == 1)
+
+void
+odm_trx_hw_ant_div_init_8821a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (DPDT)]\n");
+
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+}
+
+void
+odm_s0s1_sw_ant_div_init_8821a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821A AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0);
+
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+	dm_swat_table->cur_antenna = MAIN_ANT;
+	dm_swat_table->pre_antenna = MAIN_ANT;
+	dm_swat_table->swas_no_link_state = 0;
+
+}
+#endif /* #if (RTL8821A_SUPPORT == 1) */
+
+#if (RTL8821C_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8821c(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821C AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (DPDT)]\n");
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	/* Timming issue */
+	odm_set_bb_reg(dm, 0x818, BIT(23) | BIT(22) | BIT(21) | BIT(20), 0); /*keep antidx after tx for ACK ( unit x 3.2 mu sec)*/
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+}
+
+void
+phydm_s0s1_sw_ant_div_init_8821c(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821C AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x00); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0);
+
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+	dm_swat_table->cur_antenna = MAIN_ANT;
+	dm_swat_table->pre_antenna = MAIN_ANT;
+	dm_swat_table->swas_no_link_state = 0;
+
+}
+#endif /* #if (RTL8821C_SUPPORT == 1) */
+
+
+#if (RTL8881A_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8881a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8881A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (SPDT)]\n");
+
+	/* Output Pin Settings */
+	/* [SPDT related] */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+	odm_set_mac_reg(dm, 0x4C, BIT(26), 0);
+	odm_set_bb_reg(dm, 0xCB4, BIT(31), 0); /* delay buffer */
+	odm_set_bb_reg(dm, 0xCB4, BIT(22), 0);
+	odm_set_bb_reg(dm, 0xCB4, BIT(24), 1);
+	odm_set_bb_reg(dm, 0xCB0, 0xF00, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB0, 0xF0000, 8); /* DPDT_N = ANTSEL[0] */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x0); /* bias */
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	/* 2 [--For HW Bug setting] */
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0); /* TX ant  by Reg */ /* A-cut bug */
+}
+
+#endif /* #if (RTL8881A_SUPPORT == 1) */
+
+
+#if (RTL8812A_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8812a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8812A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (SPDT)]\n");
+
+	/* 3 */ /* 3 --RFE pin setting--------- */
+	/* [BB] */
+	odm_set_bb_reg(dm, 0x900, BIT(10) | BIT(9) | BIT(8), 0x0);	 /* disable SW switch */
+	odm_set_bb_reg(dm, 0x900, BIT(17) | BIT(16), 0x0);
+	odm_set_bb_reg(dm, 0x974, BIT(7) | BIT(6), 0x3);   /* in/out */
+	odm_set_bb_reg(dm, 0xCB4, BIT(31), 0); /* delay buffer */
+	odm_set_bb_reg(dm, 0xCB4, BIT(26), 0);
+	odm_set_bb_reg(dm, 0xCB4, BIT(27), 1);
+	odm_set_bb_reg(dm, 0xCB0, 0xF000000, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB0, 0xF0000000, 8); /* DPDT_N = ANTSEL[0] */
+	/* 3 ------------------------- */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x0); /* bias */
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	/* 2 [--For HW Bug setting] */
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0); /* TX ant  by Reg */ /* A-cut bug */
+
+}
+
+#endif /* #if (RTL8812A_SUPPORT == 1) */
+
+#if (RTL8188F_SUPPORT == 1)
+void
+odm_s0s1_sw_ant_div_init_8188f(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188F AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+
+	/*GPIO setting*/
+	/*odm_set_mac_reg(dm, 0x64, BIT(18), 0); */
+	/*odm_set_mac_reg(dm, 0x44, BIT(28)|BIT(27), 0);*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(20) | BIT(19), 0x3);*/	/*enable_output for P_GPIO[4:3]*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(12)|BIT(11), 0);*/ /*output value*/
+	/*odm_set_mac_reg(dm, 0x40, BIT(1)|BIT(0), 0);*/		/*GPIO function*/
+
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB)
+			odm_set_mac_reg(dm, 0x44, BIT(20) | BIT(19), 0x3);	/*enable_output for P_GPIO[4:3]*/
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			odm_set_mac_reg(dm, 0x44, BIT(18), 0x1);	/*enable_output for P_GPIO[2]*/
+	}
+	
+	fat_tab->is_become_linked  = false;
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+}
+
+void
+phydm_update_rx_idle_antenna_8188F(
+	void	*dm_void,
+	u32	default_ant
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		codeword;
+
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB) {
+			if (default_ant == ANT1_2G)
+				codeword = 1; /*2'b01*/
+			else
+				codeword = 2;/*2'b10*/
+			odm_set_mac_reg(dm, 0x44, (BIT(12) | BIT(11)), codeword); /*GPIO[4:3] output value*/
+		} else if (dm->support_interface == ODM_ITRF_SDIO) {
+			if (default_ant == ANT1_2G) {
+				codeword = 0; /*1'b0*/
+				odm_set_bb_reg(dm, 0x870, BIT(9)|BIT(8), 0x3);
+				odm_set_bb_reg(dm, 0x860, BIT(9)|BIT(8), 0x1);
+			} else {
+				codeword = 1;/*1'b1*/
+				odm_set_bb_reg(dm, 0x870, BIT(9)|BIT(8), 0x3);
+				odm_set_bb_reg(dm, 0x860, BIT(9)|BIT(8), 0x2);
+			}
+			odm_set_mac_reg(dm, 0x44, BIT(10), codeword); /*GPIO[2] output value*/
+		}	
+	}
+}
+#endif
+
+
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+void
+phydm_evm_sw_antdiv_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	/*EVM enhance AntDiv method init----------------------------------------------------------------------*/
+	fat_tab->evm_method_enable = 0;
+	fat_tab->fat_state = NORMAL_STATE_MIAN;
+	fat_tab->fat_state_cnt = 0;
+	fat_tab->pre_antdiv_rssi = 0;
+
+	dm->antdiv_intvl = 30;
+	dm->antdiv_train_num = 2;
+	odm_set_bb_reg(dm, 0x910, 0x3f, 0xf);
+	dm->antdiv_evm_en = 1;
+	/*dm->antdiv_period=1;*/
+	dm->evm_antdiv_period = 3;
+	dm->stop_antdiv_rssi_th = 3;
+	dm->stop_antdiv_tp_th = 80;
+	dm->antdiv_tp_period = 3;
+	dm->stop_antdiv_tp_diff_th = 5;
+}
+
+void
+odm_evm_fast_ant_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	fat_tab->evm_method_enable = 0;
+	odm_ant_div_on_off(dm, ANTDIV_ON);
+	fat_tab->fat_state = NORMAL_STATE_MIAN;
+	fat_tab->fat_state_cnt = 0;
+	dm->antdiv_period = 0;
+	odm_set_mac_reg(dm, 0x608, BIT(8), 0);
+}
+
+
+void
+odm_evm_enhance_ant_div(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	main_rssi, aux_rssi ;
+	u32	main_crc_utility = 0, aux_crc_utility = 0, utility_ratio = 1;
+	u32	main_evm, aux_evm, diff_rssi = 0, diff_EVM = 0;
+	u32	main_2ss_evm[2], aux_2ss_evm[2];
+	u32	main_1ss_evm, aux_1ss_evm;
+	u32	main_2ss_evm_sum, aux_2ss_evm_sum;
+	u8	score_EVM = 0, score_CRC = 0;
+	u8	rssi_larger_ant = 0;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u32	value32, i;
+	boolean main_above1 = false, aux_above1 = false;
+	boolean force_antenna = false;
+	struct cmn_sta_info	*sta;
+	u32	antdiv_tp_main_avg, antdiv_tp_aux_avg;
+	u8	curr_rssi, rssi_diff;
+	u32	tp_diff;
+	u8	tp_diff_return = 0, tp_return = 0, rssi_return = 0;
+	u8	target_ant_evm_1ss, target_ant_evm_2ss;
+	u8	decision_evm_ss;
+	u8	next_ant;
+
+	fat_tab->target_ant_enhance = 0xFF;
+
+	if ((dm->support_ic_type & ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC)) {
+		if (dm->is_one_entry_only) {
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "[One Client only]\n"); */
+			i = dm->one_entry_macid;
+			sta = dm->phydm_sta_info[i];
+
+			main_rssi = (fat_tab->main_ant_cnt[i] != 0) ? (fat_tab->main_ant_sum[i] / fat_tab->main_ant_cnt[i]) : 0;
+			aux_rssi = (fat_tab->aux_ant_cnt[i] != 0) ? (fat_tab->aux_ant_sum[i] / fat_tab->aux_ant_cnt[i]) : 0;
+
+			if ((main_rssi == 0 && aux_rssi != 0 && aux_rssi >= FORCE_RSSI_DIFF) || (main_rssi != 0 && aux_rssi == 0 && main_rssi >= FORCE_RSSI_DIFF))
+				diff_rssi = FORCE_RSSI_DIFF;
+			else if (main_rssi != 0 && aux_rssi != 0)
+				diff_rssi = (main_rssi >= aux_rssi) ? (main_rssi - aux_rssi) : (aux_rssi - main_rssi);
+
+			if (main_rssi >= aux_rssi)
+				rssi_larger_ant = MAIN_ANT;
+			else
+				rssi_larger_ant = AUX_ANT;
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Main_Cnt=(( %d )), main_rssi=(( %d ))\n", fat_tab->main_ant_cnt[i], main_rssi);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Aux_Cnt=(( %d )), aux_rssi=(( %d ))\n", fat_tab->aux_ant_cnt[i], aux_rssi);
+
+			if (((main_rssi >= evm_rssi_th_high || aux_rssi >= evm_rssi_th_high) || (fat_tab->evm_method_enable == 1))
+			/* && (diff_rssi <= FORCE_RSSI_DIFF + 1) */
+			) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "> TH_H || evm_method_enable==1\n");
+
+				if (((main_rssi >= evm_rssi_th_low) || (aux_rssi >= evm_rssi_th_low))) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "> TH_L, fat_state_cnt =((%d))\n", fat_tab->fat_state_cnt);
+
+					/*Traning state: 0(alt) 1(ori) 2(alt) 3(ori)============================================================*/
+					if (fat_tab->fat_state_cnt < ((dm->antdiv_train_num)<<1)) {
+						if (fat_tab->fat_state_cnt == 0) {
+							/*Reset EVM 1SS Method */
+							fat_tab->main_ant_evm_sum[i] = 0;
+							fat_tab->aux_ant_evm_sum[i] = 0;
+							fat_tab->main_ant_evm_cnt[i] = 0;
+							fat_tab->aux_ant_evm_cnt[i] = 0;
+							/*Reset EVM 2SS Method */
+							fat_tab->main_ant_evm_2ss_sum[i][0] = 0;
+							fat_tab->main_ant_evm_2ss_sum[i][1] = 0;
+							fat_tab->aux_ant_evm_2ss_sum[i][0] = 0;
+							fat_tab->aux_ant_evm_2ss_sum[i][1] = 0;
+							fat_tab->main_ant_evm_2ss_cnt[i] = 0;
+							fat_tab->aux_ant_evm_2ss_cnt[i] = 0;
+							#if 0
+							/*Reset TP Method */
+							fat_tab->antdiv_tp_main = 0;
+							fat_tab->antdiv_tp_aux = 0;
+							fat_tab->antdiv_tp_main_cnt = 0;
+							fat_tab->antdiv_tp_aux_cnt = 0;
+							#endif
+							/*Reset CRC Method */
+							fat_tab->main_crc32_ok_cnt = 0;
+							fat_tab->main_crc32_fail_cnt = 0;
+							fat_tab->aux_crc32_ok_cnt = 0;
+							fat_tab->aux_crc32_fail_cnt = 0;
+
+							#ifdef SKIP_EVM_ANTDIV_TRAINING_PATCH
+							if ((*dm->band_width == CHANNEL_WIDTH_20) && (sta->mimo_type == RF_2T2R)) {
+								/*1. Skip training: RSSI*/
+								/*PHYDM_DBG(pDM_Odm,DBG_ANT_DIV, "TargetAnt_enhance=((%d)), RxIdleAnt=((%d))\n", pDM_FatTable->TargetAnt_enhance, pDM_FatTable->RxIdleAnt);*/
+								curr_rssi = (u8)((fat_tab->rx_idle_ant == MAIN_ANT) ? main_rssi : aux_rssi);
+								rssi_diff = (curr_rssi > fat_tab->pre_antdiv_rssi) ? (curr_rssi - fat_tab->pre_antdiv_rssi) : (fat_tab->pre_antdiv_rssi - curr_rssi);
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[1] rssi_return, curr_rssi=((%d)), pre_rssi=((%d))\n", curr_rssi, fat_tab->pre_antdiv_rssi);
+
+								fat_tab->pre_antdiv_rssi = curr_rssi;
+								if ((rssi_diff < (dm->stop_antdiv_rssi_th)) && (curr_rssi != 0))
+									rssi_return = 1;
+
+								/*2. Skip training: TP Diff*/
+								tp_diff = (dm->rx_tp > fat_tab->pre_antdiv_tp) ? (dm->rx_tp  - fat_tab->pre_antdiv_tp) : (fat_tab->pre_antdiv_tp - dm->rx_tp);
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[2] tp_diff_return, curr_tp=((%d)), pre_tp=((%d))\n", dm->rx_tp, fat_tab->pre_antdiv_tp);
+								fat_tab->pre_antdiv_tp = dm->rx_tp;
+								if ((tp_diff < (u32)(dm->stop_antdiv_tp_diff_th)  && (dm->rx_tp != 0)))
+									tp_diff_return = 1;
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[3] tp_return, curr_rx_tp=((%d))\n", dm->rx_tp);
+								/*3. Skip training: TP*/
+								if (dm->rx_tp >= (u32)(dm->stop_antdiv_tp_th))
+									tp_return = 1;
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[4] Return {rssi, tp_diff, tp} = {%d, %d, %d}\n", rssi_return, tp_diff_return, tp_return);
+								/*4. Joint Return Decision*/
+								if (tp_return) {
+									if (tp_diff_return || rssi_diff) {
+										PHYDM_DBG(dm, DBG_ANT_DIV, "***Return EVM SW AntDiv\n");
+										return;
+									}
+								}
+							}
+							#endif
+
+							fat_tab->evm_method_enable = 1;
+							odm_ant_div_on_off(dm, ANTDIV_OFF);
+							dm->antdiv_period = dm->evm_antdiv_period;
+							odm_set_mac_reg(dm, 0x608, BIT(8), 1); /*RCR accepts CRC32-Error packets*/
+
+						}
+
+
+					fat_tab->fat_state_cnt++;
+					next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+					odm_update_rx_idle_ant(dm, next_ant);
+					odm_set_timer(dm, &dm->evm_fast_ant_training_timer, dm->antdiv_intvl); //ms
+
+					}
+					/*Decision state: 4==============================================================*/
+					else {
+						fat_tab->fat_state_cnt = 0;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[Decisoin state ]\n");
+
+						/* 3 [CRC32 statistic] */
+						#if 0
+						if ((fat_tab->main_crc32_ok_cnt > ((fat_tab->aux_crc32_ok_cnt) << 1)) || ((diff_rssi >= 40) && (rssi_larger_ant == MAIN_ANT))) {
+							fat_tab->target_ant_crc32 = MAIN_ANT;
+							force_antenna = true;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "CRC32 Force Main\n");
+						} else if ((fat_tab->aux_crc32_ok_cnt > ((fat_tab->main_crc32_ok_cnt) << 1)) || ((diff_rssi >= 40) && (rssi_larger_ant == AUX_ANT))) {
+							fat_tab->target_ant_crc32 = AUX_ANT;
+							force_antenna = true;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "CRC32 Force Aux\n");
+						} else
+						#endif
+						{
+							if (fat_tab->main_crc32_fail_cnt <= 5)
+								fat_tab->main_crc32_fail_cnt = 5;
+
+							if (fat_tab->aux_crc32_fail_cnt <= 5)
+								fat_tab->aux_crc32_fail_cnt = 5;
+
+							if (fat_tab->main_crc32_ok_cnt > fat_tab->main_crc32_fail_cnt)
+								main_above1 = true;
+
+							if (fat_tab->aux_crc32_ok_cnt > fat_tab->aux_crc32_fail_cnt)
+								aux_above1 = true;
+
+							if (main_above1 == true && aux_above1 == false) {
+								force_antenna = true;
+								fat_tab->target_ant_crc32 = MAIN_ANT;
+							} else if (main_above1 == false && aux_above1 == true) {
+								force_antenna = true;
+								fat_tab->target_ant_crc32 = AUX_ANT;
+							} else if (main_above1 == true && aux_above1 == true) {
+								main_crc_utility = ((fat_tab->main_crc32_ok_cnt) << 7) / fat_tab->main_crc32_fail_cnt;
+								aux_crc_utility = ((fat_tab->aux_crc32_ok_cnt) << 7) / fat_tab->aux_crc32_fail_cnt;
+								fat_tab->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (fat_tab->pre_target_ant_enhance) : ((main_crc_utility >= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
+
+								if (main_crc_utility != 0 && aux_crc_utility != 0) {
+									if (main_crc_utility >= aux_crc_utility)
+										utility_ratio = (main_crc_utility << 1) / aux_crc_utility;
+									else
+										utility_ratio = (aux_crc_utility << 1) / main_crc_utility;
+								}
+							} else if (main_above1 == false && aux_above1 == false) {
+								if (fat_tab->main_crc32_ok_cnt == 0)
+									fat_tab->main_crc32_ok_cnt = 1;
+								if (fat_tab->aux_crc32_ok_cnt == 0)
+									fat_tab->aux_crc32_ok_cnt = 1;
+
+								main_crc_utility = ((fat_tab->main_crc32_fail_cnt) << 7) / fat_tab->main_crc32_ok_cnt;
+								aux_crc_utility = ((fat_tab->aux_crc32_fail_cnt) << 7) / fat_tab->aux_crc32_ok_cnt;
+								fat_tab->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (fat_tab->pre_target_ant_enhance) : ((main_crc_utility <= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
+
+								if (main_crc_utility != 0 && aux_crc_utility != 0) {
+									if (main_crc_utility >= aux_crc_utility)
+										utility_ratio = (main_crc_utility << 1) / (aux_crc_utility);
+									else
+										utility_ratio = (aux_crc_utility << 1) / (main_crc_utility);
+								}
+							}
+						}
+						odm_set_mac_reg(dm, 0x608, BIT(8), 0);/* NOT Accept CRC32 Error packets. */
+						PHYDM_DBG(dm, DBG_ANT_DIV, "MAIN_CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", fat_tab->main_crc32_ok_cnt, fat_tab->main_crc32_fail_cnt, main_crc_utility);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "AUX__CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", fat_tab->aux_crc32_ok_cnt, fat_tab->aux_crc32_fail_cnt, aux_crc_utility);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***1.TargetAnt_CRC32 = ((%s))\n", (fat_tab->target_ant_crc32 == MAIN_ANT)?"MAIN_ANT":"AUX_ANT");
+
+						/* 3 [EVM statistic] */
+						/*1SS EVM*/
+						main_1ss_evm = (fat_tab->main_ant_evm_cnt[i] != 0) ? (fat_tab->main_ant_evm_sum[i] / fat_tab->main_ant_evm_cnt[i]) : 0;
+						aux_1ss_evm = (fat_tab->aux_ant_evm_cnt[i] != 0) ? (fat_tab->aux_ant_evm_sum[i] / fat_tab->aux_ant_evm_cnt[i]) : 0;
+						target_ant_evm_1ss = (main_1ss_evm == aux_1ss_evm) ? (fat_tab->pre_target_ant_enhance) : ((main_1ss_evm >= aux_1ss_evm) ? MAIN_ANT : AUX_ANT);
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main1ss_EVM= ((  %d ))\n", fat_tab->main_ant_evm_cnt[i], main_1ss_evm);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_1ss_EVM = ((  %d ))\n", fat_tab->main_ant_evm_cnt[i], aux_1ss_evm);
+
+						/*2SS EVM*/
+						main_2ss_evm[0] = (fat_tab->main_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->main_ant_evm_2ss_sum[i][0] / fat_tab->main_ant_evm_2ss_cnt[i]) : 0;
+						main_2ss_evm[1] = (fat_tab->main_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->main_ant_evm_2ss_sum[i][1] / fat_tab->main_ant_evm_2ss_cnt[i]) : 0;
+						main_2ss_evm_sum = main_2ss_evm[0] + main_2ss_evm[1];
+
+						aux_2ss_evm[0] = (fat_tab->aux_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->aux_ant_evm_2ss_sum[i][0] / fat_tab->aux_ant_evm_2ss_cnt[i]) : 0;
+						aux_2ss_evm[1] = (fat_tab->aux_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->aux_ant_evm_2ss_sum[i][1] / fat_tab->aux_ant_evm_2ss_cnt[i]) : 0;
+						aux_2ss_evm_sum = aux_2ss_evm[0] + aux_2ss_evm[1];
+
+						target_ant_evm_2ss = (main_2ss_evm_sum == aux_2ss_evm_sum) ? (fat_tab->pre_target_ant_enhance) : ((main_2ss_evm_sum >= aux_2ss_evm_sum) ? MAIN_ANT : AUX_ANT);
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
+							fat_tab->main_ant_evm_2ss_cnt[i], main_2ss_evm[0], main_2ss_evm[1], main_2ss_evm_sum);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
+							fat_tab->aux_ant_evm_2ss_cnt[i], aux_2ss_evm[0], aux_2ss_evm[1], aux_2ss_evm_sum);
+
+						if ((main_2ss_evm_sum + aux_2ss_evm_sum) != 0) {
+							decision_evm_ss = 2;
+							main_evm = main_2ss_evm_sum;
+							aux_evm = aux_2ss_evm_sum;
+							fat_tab->target_ant_evm = target_ant_evm_2ss;
+						} else {
+							decision_evm_ss = 1;
+							main_evm = main_1ss_evm;
+							aux_evm = aux_1ss_evm;
+							fat_tab->target_ant_evm = target_ant_evm_1ss;
+						}
+
+						if ((main_evm == 0 || aux_evm == 0))
+							diff_EVM = 100;
+						else if (main_evm >= aux_evm)
+							diff_EVM = main_evm - aux_evm;
+						else
+							diff_EVM = aux_evm - main_evm;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***2.TargetAnt_EVM((%d-ss)) = ((%s))\n", decision_evm_ss, (fat_tab->target_ant_evm == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+
+						//3 [TP statistic]
+						antdiv_tp_main_avg = (fat_tab->antdiv_tp_main_cnt != 0) ? (fat_tab->antdiv_tp_main / fat_tab->antdiv_tp_main_cnt) : 0;
+						antdiv_tp_aux_avg = (fat_tab->antdiv_tp_aux_cnt != 0) ? (fat_tab->antdiv_tp_aux / fat_tab->antdiv_tp_aux_cnt) : 0;
+						fat_tab->target_ant_tp = (antdiv_tp_main_avg == antdiv_tp_aux_avg) ? (fat_tab->pre_target_ant_enhance) : ((antdiv_tp_main_avg >= antdiv_tp_aux_avg) ? MAIN_ANT : AUX_ANT);
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main_TP = ((%d))\n", fat_tab->antdiv_tp_main_cnt, antdiv_tp_main_avg);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_TP = ((%d))\n", fat_tab->antdiv_tp_aux_cnt, antdiv_tp_aux_avg);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***3.TargetAnt_TP = ((%s))\n", (fat_tab->target_ant_tp == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+						/*Reset TP Method */
+						fat_tab->antdiv_tp_main = 0;
+						fat_tab->antdiv_tp_aux = 0;
+						fat_tab->antdiv_tp_main_cnt = 0;
+						fat_tab->antdiv_tp_aux_cnt = 0;
+
+						/* 2 [ Decision state ] */
+						if (fat_tab->target_ant_evm == fat_tab->target_ant_crc32) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 1, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+
+							if ((utility_ratio < 2 && force_antenna == false) && diff_EVM <= 30)
+								fat_tab->target_ant_enhance = fat_tab->pre_target_ant_enhance;
+							else
+								fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
+						}
+						#if 0
+						else if ((diff_EVM <= 50 && (utility_ratio > 4 && force_antenna == false)) || (force_antenna == true)) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 2, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
+						}
+						#endif
+						else if (diff_EVM >= 20) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 3, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
+						} else if (utility_ratio >= 6 && force_antenna == false) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 4, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
+						} else {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 5, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+
+							if (force_antenna == true)
+								score_CRC = 2;
+							else if (utility_ratio >= 5) /*>2.5*/
+								score_CRC = 2;
+							else if (utility_ratio >= 4) /*>2*/
+								score_CRC = 1;
+							else
+								score_CRC = 0;
+
+							if (diff_EVM >= 15)
+								score_EVM = 3;
+							else if (diff_EVM >= 10)
+								score_EVM = 2;
+							else if (diff_EVM >= 5)
+								score_EVM = 1;
+							else
+								score_EVM = 0;
+
+							if (score_CRC > score_EVM)
+								fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
+							else if (score_CRC < score_EVM)
+								fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
+							else
+								fat_tab->target_ant_enhance = fat_tab->pre_target_ant_enhance;
+						}
+						fat_tab->pre_target_ant_enhance = fat_tab->target_ant_enhance;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "*** 4.TargetAnt_enhance = (( %s ))******\n", (fat_tab->target_ant_enhance == MAIN_ANT)?"MAIN_ANT":"AUX_ANT");
+
+
+					}
+				} else { /* RSSI< = evm_rssi_th_low */
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ <TH_L: escape from > TH_L ]\n");
+					odm_evm_fast_ant_reset(dm);
+				}
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[escape from> TH_H || evm_method_enable==1]\n");
+				odm_evm_fast_ant_reset(dm);
+			}
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[multi-Client]\n");
+			odm_evm_fast_ant_reset(dm);
+		}
+	}
+}
+
+void
+odm_evm_fast_ant_training_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******AntDiv_Callback******\n");
+	odm_hw_ant_div(dm);
+}
+#endif
+
+void
+odm_hw_ant_div(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	i, min_max_rssi = 0xFF,  ant_div_max_rssi = 0, max_rssi = 0, local_max_rssi;
+	u32	main_rssi, aux_rssi, mian_cnt, aux_cnt;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u8	rx_idle_ant = fat_tab->rx_idle_ant, target_ant = 7;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct cmn_sta_info	*sta;
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct _BF_DIV_COEX_    *dm_bdc_table = &dm->dm_bdc_table;
+	u32	TH1 = 500000;
+	u32	TH2 = 10000000;
+	u32	ma_rx_temp, degrade_TP_temp, improve_TP_temp;
+	u8	monitor_rssi_threshold = 30;
+
+	dm_bdc_table->BF_pass = true;
+	dm_bdc_table->DIV_pass = true;
+	dm_bdc_table->is_all_div_sta_idle = true;
+	dm_bdc_table->is_all_bf_sta_idle = true;
+	dm_bdc_table->num_bf_tar = 0 ;
+	dm_bdc_table->num_div_tar = 0;
+	dm_bdc_table->num_client = 0;
+#endif
+#endif
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_update_rx_idle_ant(dm, MAIN_ANT);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			dm->antdiv_period = 0;
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+			/*odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);*/
+
+			/* if(dm->support_ic_type == ODM_RTL8821 ) */
+			/* odm_set_bb_reg(dm, 0x800, BIT(25), 0); */ /* CCK AntDiv function disable */
+
+			/* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+			/* else if(dm->support_ic_type == ODM_RTL8881A) */
+			/* odm_set_bb_reg(dm, 0x800, BIT(25), 0); */ /* CCK AntDiv function disable */
+			/* #endif */
+
+			/* else if(dm->support_ic_type == ODM_RTL8723B ||dm->support_ic_type == ODM_RTL8812) */
+			/* odm_set_bb_reg(dm, 0xA00, BIT(15), 0); */ /* CCK AntDiv function disable */
+
+			fat_tab->is_become_linked = dm->is_linked;
+
+			if (dm->support_ic_type == ODM_RTL8723B && dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+				odm_set_bb_reg(dm, 0x930, 0xF0, 8); /* DPDT_P = ANTSEL[0]   */ /* for 8723B AntDiv function patch.  BB  Dino  130412 */
+				odm_set_bb_reg(dm, 0x930, 0xF, 8); /* DPDT_N = ANTSEL[0] */
+			}
+
+			/* 2 BDC Init */
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+			odm_bdc_init(dm);
+#endif
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+			odm_evm_fast_ant_reset(dm);
+#endif
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	if (dm->antdiv_evm_en == 1) {
+		odm_evm_enhance_ant_div(dm);
+		if (fat_tab->fat_state_cnt != 0)
+			return;
+	} else
+		odm_evm_fast_ant_reset(dm);
+#endif
+
+	/* 2 BDC mode Arbitration */
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (dm->antdiv_evm_en == 0 || fat_tab->evm_method_enable == 0)
+		odm_bf_ant_div_mode_arbitration(dm);
+#endif
+#endif
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
+			/* 2 Caculate RSSI per Antenna */
+			if ((fat_tab->main_ant_cnt[i] != 0) || (fat_tab->aux_ant_cnt[i] != 0)) {
+				mian_cnt = fat_tab->main_ant_cnt[i];
+				aux_cnt = fat_tab->aux_ant_cnt[i];
+				main_rssi = (mian_cnt != 0) ? (fat_tab->main_ant_sum[i] / mian_cnt) : 0;
+				aux_rssi = (aux_cnt != 0) ? (fat_tab->aux_ant_sum[i] / aux_cnt) : 0;
+				target_ant = (mian_cnt == aux_cnt) ? fat_tab->rx_idle_ant : ((mian_cnt >= aux_cnt) ? MAIN_ANT : AUX_ANT); /*Use counter number for OFDM*/
+
+			} else {	/*CCK only case*/
+				mian_cnt = fat_tab->main_ant_cnt_cck[i];
+				aux_cnt = fat_tab->aux_ant_cnt_cck[i];
+				main_rssi = (mian_cnt != 0) ? (fat_tab->main_ant_sum_cck[i] / mian_cnt) : 0;
+				aux_rssi = (aux_cnt != 0) ? (fat_tab->aux_ant_sum_cck[i] / aux_cnt) : 0;
+				target_ant = (main_rssi == aux_rssi) ? fat_tab->rx_idle_ant : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT); /*Use RSSI for CCK only case*/
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] : Main_Cnt = (( %d ))  ,  CCK_Main_Cnt = (( %d )) ,  main_rssi= ((  %d ))\n", i, fat_tab->main_ant_cnt[i], fat_tab->main_ant_cnt_cck[i], main_rssi);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] : Aux_Cnt   = (( %d ))  , CCK_Aux_Cnt   = (( %d )) ,  aux_rssi = ((  %d ))\n", i, fat_tab->aux_ant_cnt[i], fat_tab->aux_ant_cnt_cck[i], aux_rssi);
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "*** MAC ID:[ %d ] , target_ant = (( %s ))\n", i ,( target_ant ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"); */
+
+			local_max_rssi = (main_rssi > aux_rssi) ? main_rssi : aux_rssi;
+			/* 2 Select max_rssi for DIG */
+			if ((local_max_rssi > ant_div_max_rssi) && (local_max_rssi < 40))
+				ant_div_max_rssi = local_max_rssi;
+			if (local_max_rssi > max_rssi)
+				max_rssi = local_max_rssi;
+
+			/* 2 Select RX Idle Antenna */
+			if ((local_max_rssi != 0) && (local_max_rssi < min_max_rssi)) {
+				rx_idle_ant = target_ant;
+				min_max_rssi = local_max_rssi;
+			}
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+			if (dm->antdiv_evm_en == 1) {
+				if (fat_tab->target_ant_enhance != 0xFF) {
+					target_ant = fat_tab->target_ant_enhance;
+					rx_idle_ant = fat_tab->target_ant_enhance;
+				}
+			}
+#endif
+
+			/* 2 Select TX Antenna */
+			if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+				if (dm_bdc_table->w_bfee_client[i] == 0)
+#endif
+#endif
+				{
+					odm_update_tx_ant(dm, target_ant, i);
+				}
+			}
+
+			/* ------------------------------------------------------------ */
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+			dm_bdc_table->num_client++;
+
+			if (dm_bdc_table->bdc_mode == BDC_MODE_2 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+				/* 2 Byte counter */
+
+				ma_rx_temp = sta->rx_moving_average_tp; /* RX  TP   ( bit /sec) */
+
+				if (dm_bdc_table->BDC_state == bdc_bfer_train_state)
+					dm_bdc_table->MA_rx_TP_DIV[i] =  ma_rx_temp ;
+				else
+					dm_bdc_table->MA_rx_TP[i] = ma_rx_temp ;
+
+				if ((ma_rx_temp < TH2)   && (ma_rx_temp > TH1) && (local_max_rssi <= monitor_rssi_threshold)) {
+					if (dm_bdc_table->w_bfer_client[i] == 1) { /* Bfer_Target */
+						dm_bdc_table->num_bf_tar++;
+
+						if (dm_bdc_table->BDC_state == BDC_DECISION_STATE && dm_bdc_table->bdc_try_flag == 0) {
+							improve_TP_temp = (dm_bdc_table->MA_rx_TP_DIV[i] * 9) >> 3 ; /* * 1.125 */
+							dm_bdc_table->BF_pass = (dm_bdc_table->MA_rx_TP[i] > improve_TP_temp) ? true : false;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { MA_rx_TP,improve_TP_temp, MA_rx_TP_DIV,  BF_pass}={ %d,  %d, %d , %d }\n", i, dm_bdc_table->MA_rx_TP[i], improve_TP_temp, dm_bdc_table->MA_rx_TP_DIV[i], dm_bdc_table->BF_pass);
+						}
+					} else { /* DIV_Target */
+						dm_bdc_table->num_div_tar++;
+
+						if (dm_bdc_table->BDC_state == BDC_DECISION_STATE && dm_bdc_table->bdc_try_flag == 0) {
+							degrade_TP_temp = (dm_bdc_table->MA_rx_TP_DIV[i] * 5) >> 3; /* * 0.625 */
+							dm_bdc_table->DIV_pass = (dm_bdc_table->MA_rx_TP[i] > degrade_TP_temp) ? true : false;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { MA_rx_TP, degrade_TP_temp, MA_rx_TP_DIV,  DIV_pass}=\n{ %d,  %d, %d , %d }\n", i, dm_bdc_table->MA_rx_TP[i], degrade_TP_temp, dm_bdc_table->MA_rx_TP_DIV[i], dm_bdc_table->DIV_pass);
+						}
+					}
+				}
+
+				if (ma_rx_temp > TH1) {
+					if (dm_bdc_table->w_bfer_client[i] == 1) /* Bfer_Target */
+						dm_bdc_table->is_all_bf_sta_idle = false;
+					else/* DIV_Target */
+						dm_bdc_table->is_all_div_sta_idle = false;
+				}
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { BFmeeCap, BFmerCap}  = { %d , %d }\n", i, dm_bdc_table->w_bfee_client[i], dm_bdc_table->w_bfer_client[i]);
+
+				if (dm_bdc_table->BDC_state == bdc_bfer_train_state)
+					PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :    MA_rx_TP_DIV = (( %d ))\n", i, dm_bdc_table->MA_rx_TP_DIV[i]);
+
+				else
+					PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :    MA_rx_TP = (( %d ))\n", i, dm_bdc_table->MA_rx_TP[i]);
+
+			}
+#endif
+#endif
+
+		}
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		if (dm_bdc_table->bdc_try_flag == 0)
+#endif
+#endif
+		{
+			phydm_antdiv_reset_statistic(dm, i);
+		}
+	}
+
+
+
+	/* 2 Set RX Idle Antenna & TX Antenna(Because of HW Bug ) */
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** rx_idle_ant = (( %s ))\n", (rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (dm_bdc_table->bdc_mode == BDC_MODE_1 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "*** bdc_rx_idle_update_counter = (( %d ))\n", dm_bdc_table->bdc_rx_idle_update_counter);
+
+		if (dm_bdc_table->bdc_rx_idle_update_counter == 1) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "***Update RxIdle Antenna!!!\n");
+			dm_bdc_table->bdc_rx_idle_update_counter = 30;
+			odm_update_rx_idle_ant(dm, rx_idle_ant);
+		} else {
+			dm_bdc_table->bdc_rx_idle_update_counter--;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "***NOT update RxIdle Antenna because of BF  ( need to fix TX-ant)\n");
+		}
+	} else
+#endif
+#endif
+		odm_update_rx_idle_ant(dm, rx_idle_ant);
+#else
+
+	odm_update_rx_idle_ant(dm, rx_idle_ant);
+
+#endif/* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+
+
+
+	/* 2 BDC Main Algorithm */
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (dm->antdiv_evm_en == 0 || fat_tab->evm_method_enable == 0)
+		odm_bd_ccoex_bfee_rx_div_arbitration(dm);
+
+	dm_bdc_table->num_txbfee_client = 0;
+	dm_bdc_table->num_txbfer_client = 0;
+#endif
+#endif
+
+	if (ant_div_max_rssi == 0)
+		dig_t->ant_div_rssi_max = dm->rssi_min;
+	else
+		dig_t->ant_div_rssi_max = ant_div_max_rssi;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***AntDiv End***\n\n");
+}
+
+
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+
+void
+odm_s0s1_sw_ant_div_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table	= &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab		= &dm->dm_fat_table;
+
+	fat_tab->is_become_linked  = false;
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_s0s1_sw_ant_div_reset(): fat_tab->is_become_linked = %d\n", fat_tab->is_become_linked);
+}
+
+void
+odm_s0s1_sw_ant_div(
+	void			*dm_void,
+	u8			step
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch			*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	u32			i, min_max_rssi = 0xFF, local_max_rssi, local_min_rssi;
+	u32			main_rssi, aux_rssi;
+	u8			high_traffic_train_time_u = 0x32, high_traffic_train_time_l = 0, train_time_temp;
+	u8			low_traffic_train_time_u = 200, low_traffic_train_time_l = 0;
+	u8			rx_idle_ant = dm_swat_table->pre_antenna, target_ant, next_ant = 0;
+	struct cmn_sta_info		*entry = NULL;
+	u32			value32;
+	u32			main_ant_sum = 0;
+	u32			aux_ant_sum = 0;
+	u32			main_ant_cnt = 0;
+	u32			aux_ant_cnt = 0;
+
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+		if (fat_tab->is_become_linked == true) {
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			if (dm->support_ic_type == ODM_RTL8723B) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Set REG 948[9:6]=0x0\n");
+				odm_set_bb_reg(dm, 0x948, (BIT(9) | BIT(8) | BIT(7) | BIT(6)), 0x0);
+			}
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+
+			if (dm->support_ic_type == ODM_RTL8723B) {
+				value32 = odm_get_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3));
+
+#if (RTL8723B_SUPPORT == 1)
+				if (value32 == 0x0)
+					odm_update_rx_idle_ant_8723b(dm, MAIN_ANT, ANT1_2G, ANT2_2G);
+				else if (value32 == 0x1)
+					odm_update_rx_idle_ant_8723b(dm, AUX_ANT, ANT2_2G, ANT1_2G);
+#endif
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "8723B: First link! Force antenna to  %s\n", (value32 == 0x0 ? "MAIN" : "AUX"));
+			}
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%d] { try_flag=(( %d )), step=(( %d )), double_chk_flag = (( %d )) }\n",
+		__LINE__, dm_swat_table->try_flag, step, dm_swat_table->double_chk_flag);
+
+	/* Handling step mismatch condition. */
+	/* Peak step is not finished at last time. Recover the variable and check again. */
+	if (step != dm_swat_table->try_flag) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[step != try_flag]    Need to Reset After Link\n");
+		odm_sw_ant_div_rest_after_link(dm);
+	}
+
+	if (dm_swat_table->try_flag == SWAW_STEP_INIT) {
+		dm_swat_table->try_flag = SWAW_STEP_PEEK;
+		dm_swat_table->train_time_flag = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[set try_flag = 0]  Prepare for peek!\n\n");
+		return;
+
+	} else {
+		/* 1 Normal state (Begin Trying) */
+		if (dm_swat_table->try_flag == SWAW_STEP_PEEK) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "TxOkCnt=(( %llu )), RxOkCnt=(( %llu )), traffic_load = (%d))\n", dm->cur_tx_ok_cnt, dm->cur_rx_ok_cnt, dm->traffic_load);
+
+			if (dm->traffic_load == TRAFFIC_HIGH) {
+				train_time_temp = dm_swat_table->train_time ;
+
+				if (dm_swat_table->train_time_flag == 3) {
+					high_traffic_train_time_l = 0xa;
+
+					if (train_time_temp <= 16)
+						train_time_temp = high_traffic_train_time_l;
+					else
+						train_time_temp -= 16;
+
+				} else if (dm_swat_table->train_time_flag == 2) {
+					train_time_temp -= 8;
+					high_traffic_train_time_l = 0xf;
+				} else if (dm_swat_table->train_time_flag == 1) {
+					train_time_temp -= 4;
+					high_traffic_train_time_l = 0x1e;
+				} else if (dm_swat_table->train_time_flag == 0) {
+					train_time_temp += 8;
+					high_traffic_train_time_l = 0x28;
+				}
+				
+				if (dm->support_ic_type == ODM_RTL8188F) {
+					if (dm->support_interface == ODM_ITRF_SDIO)
+						high_traffic_train_time_l += 0xa;
+				}
+
+				/* PHYDM_DBG(dm,DBG_ANT_DIV, "*** train_time_temp = ((%d))\n",train_time_temp); */
+
+				/* -- */
+				if (train_time_temp > high_traffic_train_time_u)
+					train_time_temp = high_traffic_train_time_u;
+
+				else if (train_time_temp < high_traffic_train_time_l)
+					train_time_temp = high_traffic_train_time_l;
+
+				dm_swat_table->train_time = train_time_temp; /*10ms~200ms*/
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "train_time_flag=((%d)), train_time=((%d))\n", dm_swat_table->train_time_flag, dm_swat_table->train_time);
+
+			} else if ((dm->traffic_load == TRAFFIC_MID) || (dm->traffic_load == TRAFFIC_LOW)) {
+				train_time_temp = dm_swat_table->train_time ;
+
+				if (dm_swat_table->train_time_flag == 3) {
+					low_traffic_train_time_l = 10;
+					if (train_time_temp < 50)
+						train_time_temp = low_traffic_train_time_l;
+					else
+						train_time_temp -= 50;
+				} else if (dm_swat_table->train_time_flag == 2) {
+					train_time_temp -= 30;
+					low_traffic_train_time_l = 36;
+				} else if (dm_swat_table->train_time_flag == 1) {
+					train_time_temp -= 10;
+					low_traffic_train_time_l = 40;
+				} else {
+					train_time_temp += 10;
+					low_traffic_train_time_l = 50;
+				}
+
+				if (dm->support_ic_type == ODM_RTL8188F) {
+					if (dm->support_interface == ODM_ITRF_SDIO)
+						low_traffic_train_time_l += 10;
+				}
+
+				/* -- */
+				if (train_time_temp >= low_traffic_train_time_u)
+					train_time_temp = low_traffic_train_time_u;
+
+				else if (train_time_temp <= low_traffic_train_time_l)
+					train_time_temp = low_traffic_train_time_l;
+
+				dm_swat_table->train_time = train_time_temp; /*10ms~200ms*/
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "train_time_flag=((%d)) , train_time=((%d))\n", dm_swat_table->train_time_flag, dm_swat_table->train_time);
+
+			} else {
+				dm_swat_table->train_time = 0xc8; /*200ms*/
+
+			}
+
+			/* ----------------- */
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Current min_max_rssi is ((%d))\n", fat_tab->min_max_rssi);
+
+			/* ---reset index--- */
+			if (dm_swat_table->reset_idx >= RSSI_CHECK_RESET_PERIOD) {
+				fat_tab->min_max_rssi = 0;
+				dm_swat_table->reset_idx = 0;
+			}
+			PHYDM_DBG(dm, DBG_ANT_DIV, "reset_idx = (( %d ))\n", dm_swat_table->reset_idx);
+
+			dm_swat_table->reset_idx++;
+
+			/* ---double check flag--- */
+			if ((fat_tab->min_max_rssi > RSSI_CHECK_THRESHOLD) && (dm_swat_table->double_chk_flag == 0)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, " min_max_rssi is ((%d)), and > %d\n",
+					fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
+
+				dm_swat_table->double_chk_flag = 1;
+				dm_swat_table->try_flag = SWAW_STEP_DETERMINE;
+				dm_swat_table->rssi_trying = 0;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Test the current ant for (( %d )) ms again\n", dm_swat_table->train_time);
+				odm_update_rx_idle_ant(dm, fat_tab->rx_idle_ant);
+				odm_set_timer(dm,
+					      &dm_swat_table->phydm_sw_antenna_switch_timer,
+					      dm_swat_table->train_time); /*ms*/
+				return;
+			}
+
+			next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+
+			dm_swat_table->try_flag = SWAW_STEP_DETERMINE;
+
+			if (dm_swat_table->reset_idx <= 1)
+				dm_swat_table->rssi_trying = 2;
+			else
+				dm_swat_table->rssi_trying = 1;
+
+			odm_s0s1_sw_ant_div_by_ctrl_frame(dm, SWAW_STEP_PEEK);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[set try_flag=1]  Normal state:  Begin Trying!!\n");
+
+		} else if ((dm_swat_table->try_flag == SWAW_STEP_DETERMINE) && (dm_swat_table->double_chk_flag == 0)) {
+			next_ant = (fat_tab->rx_idle_ant  == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+			dm_swat_table->rssi_trying--;
+		}
+
+		/* 1 Decision state */
+		if ((dm_swat_table->try_flag == SWAW_STEP_DETERMINE) && (dm_swat_table->rssi_trying == 0)) {
+			boolean is_by_ctrl_frame = false;
+			u64	pkt_cnt_total = 0;
+
+			for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+				entry = dm->phydm_sta_info[i];
+				if (is_sta_active(entry)) {
+					/* 2 Caculate RSSI per Antenna */
+					#if 0
+					main_ant_sum = (u32)fat_tab->main_ant_sum[i] + (u32)fat_tab->main_ant_sum_cck[i];
+					aux_ant_sum = (u32)fat_tab->aux_ant_sum[i] + (u32)fat_tab->aux_ant_sum_cck[i];
+					main_ant_cnt = (u32)fat_tab->main_ant_cnt[i] + (u32)fat_tab->main_ant_cnt_cck[i];
+					aux_ant_cnt = (u32)fat_tab->aux_ant_cnt[i] + (u32)fat_tab->aux_ant_cnt_cck[i];
+
+					main_rssi = (main_ant_cnt != 0) ? (main_ant_sum / main_ant_cnt) : 0;
+					aux_rssi = (aux_ant_cnt != 0) ? (aux_ant_sum / aux_ant_cnt) : 0;
+
+					if (fat_tab->main_ant_cnt[i] <= 1 && fat_tab->main_ant_cnt_cck[i] >= 1)
+						main_rssi = 0;
+
+					if (fat_tab->aux_ant_cnt[i] <= 1 && fat_tab->aux_ant_cnt_cck[i] >= 1)
+						aux_rssi = 0;
+					#endif
+					if ((fat_tab->main_ant_cnt[i] != 0) || (fat_tab->aux_ant_cnt[i] != 0)) {
+						main_ant_cnt = (u32)fat_tab->main_ant_cnt[i];
+						aux_ant_cnt = (u32)fat_tab->aux_ant_cnt[i];
+						main_rssi = (main_ant_cnt != 0) ? (fat_tab->main_ant_sum[i] / main_ant_cnt) : 0;
+						aux_rssi = (aux_ant_cnt != 0) ? (fat_tab->aux_ant_sum[i] / aux_ant_cnt) : 0;
+						if (dm_swat_table->pre_antenna == MAIN_ANT) {
+							target_ant = ((aux_ant_cnt > main_ant_cnt) && (aux_rssi >= main_rssi)) ? AUX_ANT : dm_swat_table->pre_antenna;
+						} else {
+							target_ant = ((main_ant_cnt > aux_ant_cnt) && (main_rssi >= aux_rssi)) ? MAIN_ANT : dm_swat_table->pre_antenna;
+						}
+
+					} else {	/*CCK only case*/
+						main_ant_cnt = fat_tab->main_ant_cnt_cck[i];
+						aux_ant_cnt = fat_tab->aux_ant_cnt_cck[i];
+						main_rssi = (main_ant_cnt != 0) ? (fat_tab->main_ant_sum_cck[i] / main_ant_cnt) : 0;
+						aux_rssi = (aux_ant_cnt != 0) ? (fat_tab->aux_ant_sum_cck[i] / aux_ant_cnt) : 0;
+						target_ant = (main_rssi == aux_rssi) ? fat_tab->rx_idle_ant : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT); /*Use RSSI for CCK only case*/
+					}
+					#if 0
+					target_ant = (main_rssi == aux_rssi) ? dm_swat_table->pre_antenna : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT);
+					#endif
+					local_max_rssi = (main_rssi >= aux_rssi) ? main_rssi : aux_rssi;
+					local_min_rssi = (main_rssi >= aux_rssi) ? aux_rssi : main_rssi;
+
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  CCK_counter_main = (( %d ))  , CCK_counter_aux= ((  %d ))\n", fat_tab->main_ant_cnt_cck[i], fat_tab->aux_ant_cnt_cck[i]);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  OFDM_counter_main = (( %d ))  , OFDM_counter_aux= ((  %d ))\n", fat_tab->main_ant_cnt[i], fat_tab->aux_ant_cnt[i]);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  Main_Cnt = (( %d ))  , main_rssi= ((  %d ))\n", main_ant_cnt, main_rssi);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  Aux_Cnt   = (( %d ))  , aux_rssi = ((  %d ))\n", aux_ant_cnt, aux_rssi);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "*** MAC ID:[ %d ] , target_ant = (( %s ))\n", i, (target_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+					/* 2 Select RX Idle Antenna */
+
+					if (local_max_rssi != 0 && local_max_rssi < min_max_rssi) {
+						rx_idle_ant = target_ant;
+						min_max_rssi = local_max_rssi;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "*** local_max_rssi-local_min_rssi = ((%d))\n", (local_max_rssi - local_min_rssi));
+
+						if ((local_max_rssi - local_min_rssi) > 8) {
+							if (local_min_rssi != 0)
+								dm_swat_table->train_time_flag = 3;
+							else {
+								if (min_max_rssi > RSSI_CHECK_THRESHOLD)
+									dm_swat_table->train_time_flag = 0;
+								else
+									dm_swat_table->train_time_flag = 3;
+							}
+						} else if ((local_max_rssi - local_min_rssi) > 5)
+							dm_swat_table->train_time_flag = 2;
+						else if ((local_max_rssi - local_min_rssi) > 2)
+							dm_swat_table->train_time_flag = 1;
+						else
+							dm_swat_table->train_time_flag = 0;
+
+					}
+
+					/* 2 Select TX Antenna */
+					if (target_ant == MAIN_ANT)
+						fat_tab->antsel_a[i] = ANT1_2G;
+					else
+						fat_tab->antsel_a[i] = ANT2_2G;
+
+				}
+				phydm_antdiv_reset_statistic(dm, i);
+				pkt_cnt_total += (main_ant_cnt + aux_ant_cnt);
+			}
+
+			if (dm_swat_table->is_sw_ant_div_by_ctrl_frame) {
+				odm_s0s1_sw_ant_div_by_ctrl_frame(dm, SWAW_STEP_DETERMINE);
+				is_by_ctrl_frame = true;
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Control frame packet counter = %d, data frame packet counter = %llu\n",
+				dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame, pkt_cnt_total);
+
+			if (min_max_rssi == 0xff || ((pkt_cnt_total < (dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame >> 1)) && dm->phy_dbg_info.num_qry_beacon_pkt < 2)) {
+				min_max_rssi = 0;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Check RSSI of control frame because min_max_rssi == 0xff\n");
+				PHYDM_DBG(dm, DBG_ANT_DIV, "is_by_ctrl_frame = %d\n", is_by_ctrl_frame);
+
+				if (is_by_ctrl_frame) {
+					main_rssi = (fat_tab->main_ant_ctrl_frame_cnt != 0) ? (fat_tab->main_ant_ctrl_frame_sum / fat_tab->main_ant_ctrl_frame_cnt) : 0;
+					aux_rssi = (fat_tab->aux_ant_ctrl_frame_cnt != 0) ? (fat_tab->aux_ant_ctrl_frame_sum / fat_tab->aux_ant_ctrl_frame_cnt) : 0;
+
+					if (fat_tab->main_ant_ctrl_frame_cnt <= 1 && fat_tab->cck_ctrl_frame_cnt_main >= 1)
+						main_rssi = 0;
+
+					if (fat_tab->aux_ant_ctrl_frame_cnt <= 1 && fat_tab->cck_ctrl_frame_cnt_aux >= 1)
+						aux_rssi = 0;
+
+					if (main_rssi != 0 || aux_rssi != 0) {
+						rx_idle_ant = (main_rssi == aux_rssi) ? dm_swat_table->pre_antenna : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT);
+						local_max_rssi = (main_rssi >= aux_rssi) ? main_rssi : aux_rssi;
+						local_min_rssi = (main_rssi >= aux_rssi) ? aux_rssi : main_rssi;
+
+						if ((local_max_rssi - local_min_rssi) > 8)
+							dm_swat_table->train_time_flag = 3;
+						else if ((local_max_rssi - local_min_rssi) > 5)
+							dm_swat_table->train_time_flag = 2;
+						else if ((local_max_rssi - local_min_rssi) > 2)
+							dm_swat_table->train_time_flag = 1;
+						else
+							dm_swat_table->train_time_flag = 0;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Control frame: main_rssi = %d, aux_rssi = %d\n", main_rssi, aux_rssi);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "rx_idle_ant decided by control frame = %s\n", (rx_idle_ant == MAIN_ANT ? "MAIN" : "AUX"));
+					}
+				}
+			}
+
+			fat_tab->min_max_rssi = min_max_rssi;
+			dm_swat_table->try_flag = SWAW_STEP_PEEK;
+
+			if (dm_swat_table->double_chk_flag == 1) {
+				dm_swat_table->double_chk_flag = 0;
+
+				if (fat_tab->min_max_rssi > RSSI_CHECK_THRESHOLD) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [Double check] min_max_rssi ((%d)) > %d again!!\n",
+						fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
+
+					odm_update_rx_idle_ant(dm, rx_idle_ant);
+
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[reset try_flag = 0] Training accomplished !!!]\n\n\n");
+					return;
+				} else {
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [Double check] min_max_rssi ((%d)) <= %d !!\n",
+						fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
+
+					next_ant = (fat_tab->rx_idle_ant  == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+					dm_swat_table->try_flag = SWAW_STEP_PEEK;
+					dm_swat_table->reset_idx = RSSI_CHECK_RESET_PERIOD;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[set try_flag=0]  Normal state:  Need to tryg again!!\n\n\n");
+					return;
+				}
+			} else {
+				if (fat_tab->min_max_rssi < RSSI_CHECK_THRESHOLD)
+					dm_swat_table->reset_idx = RSSI_CHECK_RESET_PERIOD;
+
+				dm_swat_table->pre_antenna = rx_idle_ant;
+				odm_update_rx_idle_ant(dm, rx_idle_ant);
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[reset try_flag = 0] Training accomplished !!!]\n\n\n");
+				return;
+			}
+
+		}
+
+	}
+
+	/* 1 4.Change TRX antenna */
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "rssi_trying = (( %d )),    ant: (( %s )) >>> (( %s ))\n",
+		dm_swat_table->rssi_trying, (fat_tab->rx_idle_ant  == MAIN_ANT ? "MAIN" : "AUX"), (next_ant == MAIN_ANT ? "MAIN" : "AUX"));
+
+	odm_update_rx_idle_ant(dm, next_ant);
+
+	/* 1 5.Reset Statistics */
+
+	fat_tab->rx_idle_ant  = next_ant;
+
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_SDIO) {
+			ODM_delay_us(200);
+			
+			if (fat_tab->rx_idle_ant == MAIN_ANT) {
+				fat_tab->main_ant_sum[0] = 0;
+				fat_tab->main_ant_cnt[0] = 0;
+				fat_tab->main_ant_sum_cck[0] = 0;
+				fat_tab->main_ant_cnt_cck[0] = 0;	
+			} else {
+				fat_tab->aux_ant_sum[0] = 0;
+				fat_tab->aux_ant_cnt[0] = 0;
+				fat_tab->aux_ant_sum_cck[0] = 0;
+				fat_tab->aux_ant_cnt_cck[0] = 0;	
+			}	
+		}	
+	}
+
+	/* 1 6.Set next timer   (Trying state) */
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, " Test ((%s)) ant for (( %d )) ms\n", (next_ant == MAIN_ANT ? "MAIN" : "AUX"), dm_swat_table->train_time);
+	odm_set_timer(dm, &dm_swat_table->phydm_sw_antenna_switch_timer,
+		      dm_swat_table->train_time); /*ms*/
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_sw_antdiv_callback(
+	struct phydm_timer_list		*timer
+)
+{
+	void		*adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct sw_antenna_switch			*dm_swat_table = &hal_data->DM_OutSrc.dm_swat_table;
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm_swat_table->phydm_sw_antenna_switch_workitem);
+#else
+	{
+		/* dbg_print("SW_antdiv_Callback"); */
+		odm_s0s1_sw_ant_div(&hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
+	}
+#endif
+#else
+	odm_schedule_work_item(&dm_swat_table->phydm_sw_antenna_switch_workitem);
+#endif
+}
+void
+odm_sw_antdiv_workitem_callback(
+	void            *context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	/* dbg_print("SW_antdiv_Workitem_Callback"); */
+	odm_s0s1_sw_ant_div(&hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
+}
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+odm_sw_antdiv_workitem_callback(
+	void	*context
+)
+{
+	void *
+	adapter = (void *)context;
+	HAL_DATA_TYPE
+	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	/*dbg_print("SW_antdiv_Workitem_Callback");*/
+	odm_s0s1_sw_ant_div(&hal_data->odmpriv, SWAW_STEP_DETERMINE);
+}
+
+void
+odm_sw_antdiv_callback(void *function_context)
+{
+	struct dm_struct	*dm = (struct dm_struct *)function_context;
+	void	*padapter = dm->adapter;
+	if (*(dm->is_net_closed) == true)
+		return;
+
+#if 0 /* Can't do I/O in timer callback*/
+	odm_s0s1_sw_ant_div(dm, SWAW_STEP_DETERMINE);
+#else
+	rtw_run_in_thread_cmd(padapter, odm_sw_antdiv_workitem_callback, padapter);
+#endif
+}
+
+
+#endif
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame(
+	void			*dm_void,
+	u8			step
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch	*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	switch (step) {
+	case SWAW_STEP_PEEK:
+		dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame = 0;
+		dm_swat_table->is_sw_ant_div_by_ctrl_frame = true;
+		fat_tab->main_ant_ctrl_frame_cnt = 0;
+		fat_tab->aux_ant_ctrl_frame_cnt = 0;
+		fat_tab->main_ant_ctrl_frame_sum = 0;
+		fat_tab->aux_ant_ctrl_frame_sum = 0;
+		fat_tab->cck_ctrl_frame_cnt_main = 0;
+		fat_tab->cck_ctrl_frame_cnt_aux = 0;
+		fat_tab->ofdm_ctrl_frame_cnt_main = 0;
+		fat_tab->ofdm_ctrl_frame_cnt_aux = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_S0S1_SwAntDivForAPMode(): Start peek and reset counter\n");
+		break;
+	case SWAW_STEP_DETERMINE:
+		dm_swat_table->is_sw_ant_div_by_ctrl_frame = false;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_S0S1_SwAntDivForAPMode(): Stop peek\n");
+		break;
+	default:
+		dm_swat_table->is_sw_ant_div_by_ctrl_frame = false;
+		break;
+	}
+}
+
+void
+odm_antsel_statistics_of_ctrl_frame(
+	void			*dm_void,
+	u8			antsel_tr_mux,
+	u32			rx_pwdb_all
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	if (antsel_tr_mux == ANT1_2G) {
+		fat_tab->main_ant_ctrl_frame_sum += rx_pwdb_all;
+		fat_tab->main_ant_ctrl_frame_cnt++;
+	} else {
+		fat_tab->aux_ant_ctrl_frame_sum += rx_pwdb_all;
+		fat_tab->aux_ant_ctrl_frame_cnt++;
+	}
+}
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+	/*	struct phydm_phyinfo_struct*		phy_info, */
+	/*	struct phydm_perpkt_info_struct*		pktinfo */
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct	*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct	*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct sw_antenna_switch	*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type != S0S1_SW_ANTDIV)
+		return;
+
+	/* In try state */
+	if (!dm_swat_table->is_sw_ant_div_by_ctrl_frame)
+		return;
+
+	/* No HW error and match receiver address */
+	if (!pktinfo->is_to_self)
+		return;
+
+	dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame++;
+
+	if (pktinfo->is_cck_rate) {
+		fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
+
+		if (fat_tab->antsel_rx_keep_0 == ANT1_2G)
+			fat_tab->cck_ctrl_frame_cnt_main++;
+		else
+			fat_tab->cck_ctrl_frame_cnt_aux++;
+
+		odm_antsel_statistics_of_ctrl_frame(dm, fat_tab->antsel_rx_keep_0, phy_info->rx_mimo_signal_strength[RF_PATH_A]);
+	} else {
+		fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
+		
+		if (fat_tab->antsel_rx_keep_0 == ANT1_2G)
+			fat_tab->ofdm_ctrl_frame_cnt_main++;
+		else
+			fat_tab->ofdm_ctrl_frame_cnt_aux++;
+
+		odm_antsel_statistics_of_ctrl_frame(dm, fat_tab->antsel_rx_keep_0, phy_info->rx_pwdb_all);
+	}
+}
+
+#endif /* #if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) */
+
+
+
+
+void
+odm_set_next_mac_addr_target(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	struct cmn_sta_info	*entry;
+	u32			value32, i;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_set_next_mac_addr_target() ==>\n");
+
+	if (dm->is_linked) {
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+			if ((fat_tab->train_idx + 1) == ODM_ASSOCIATE_ENTRY_NUM)
+				fat_tab->train_idx = 0;
+			else
+				fat_tab->train_idx++;
+
+			entry = dm->phydm_sta_info[fat_tab->train_idx];
+
+			if (is_sta_active(entry)) {
+				/*Match MAC ADDR*/
+				value32 = (entry->mac_addr[5] << 8) | entry->mac_addr[4];
+
+				odm_set_mac_reg(dm, 0x7b4, 0xFFFF, value32);/*0x7b4~0x7b5*/
+
+				value32 = (entry->mac_addr[3] << 24) | (entry->mac_addr[2] << 16) | (entry->mac_addr[1] << 8) | entry->mac_addr[0];
+
+				odm_set_mac_reg(dm, 0x7b0, MASKDWORD, value32);/*0x7b0~0x7b3*/
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "fat_tab->train_idx=%d\n", fat_tab->train_idx);
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Training MAC addr = %x:%x:%x:%x:%x:%x\n",
+					entry->mac_addr[5], entry->mac_addr[4], entry->mac_addr[3], entry->mac_addr[2], entry->mac_addr[1], entry->mac_addr[0]);
+
+				break;
+			}
+		}
+	}
+
+}
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+
+void
+odm_fast_ant_training(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	u32	max_rssi_path_a = 0, pckcnt_path_a = 0;
+	u8	i, target_ant_path_a = 0;
+	boolean	is_pkt_filter_macth_path_a = false;
+#if (RTL8192E_SUPPORT == 1)
+	u32	max_rssi_path_b = 0, pckcnt_path_b = 0;
+	u8	target_ant_path_b = 0;
+	boolean	is_pkt_filter_macth_path_b = false;
+#endif
+
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			phydm_fast_training_enable(dm, FAT_OFF);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked!!!]\n");
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+
+	if (dm->support_ic_type == ODM_RTL8188E)
+		odm_set_bb_reg(dm, 0x864, BIT(2) | BIT(1) | BIT(0), ((dm->fat_comb_a) - 1));
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, 0xB38, BIT(2) | BIT(1) | BIT(0), ((dm->fat_comb_a) - 1));	   /* path-A  */ /* ant combination=regB38[2:0]+1 */
+		odm_set_bb_reg(dm, 0xB38, BIT(18) | BIT(17) | BIT(16), ((dm->fat_comb_b) - 1));  /* path-B  */ /* ant combination=regB38[18:16]+1 */
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "==>odm_fast_ant_training()\n");
+
+	/* 1 TRAINING STATE */
+	if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		/* 2 Caculate RSSI per Antenna */
+
+		/* 3 [path-A]--------------------------- */
+		for (i = 0; i < (dm->fat_comb_a); i++) { /* i : antenna index */
+			if (fat_tab->ant_rssi_cnt[i] == 0)
+				fat_tab->ant_ave_rssi[i] = 0;
+			else {
+				fat_tab->ant_ave_rssi[i] = fat_tab->ant_sum_rssi[i] / fat_tab->ant_rssi_cnt[i];
+				is_pkt_filter_macth_path_a = true;
+			}
+
+			if (fat_tab->ant_ave_rssi[i] > max_rssi_path_a) {
+				max_rssi_path_a = fat_tab->ant_ave_rssi[i];
+				pckcnt_path_a = fat_tab->ant_rssi_cnt[i];
+				target_ant_path_a =  i ;
+			} else if (fat_tab->ant_ave_rssi[i] == max_rssi_path_a) {
+				if ((fat_tab->ant_rssi_cnt[i])   >   pckcnt_path_a) {
+					max_rssi_path_a = fat_tab->ant_ave_rssi[i];
+					pckcnt_path_a = fat_tab->ant_rssi_cnt[i];
+					target_ant_path_a = i ;
+				}
+			}
+
+			PHYDM_DBG("*** ant-index : [ %d ],      counter = (( %d )),     Avg RSSI = (( %d ))\n", i, fat_tab->ant_rssi_cnt[i],  fat_tab->ant_ave_rssi[i]);
+		}
+
+
+#if 0
+#if (RTL8192E_SUPPORT == 1)
+		/* 3 [path-B]--------------------------- */
+		for (i = 0; i < (dm->fat_comb_b); i++) {
+			if (fat_tab->antRSSIcnt_pathB[i] == 0)
+				fat_tab->antAveRSSI_pathB[i] = 0;
+			else { /*  (ant_rssi_cnt[i] != 0) */
+				fat_tab->antAveRSSI_pathB[i] = fat_tab->antSumRSSI_pathB[i] / fat_tab->antRSSIcnt_pathB[i];
+				is_pkt_filter_macth_path_b = true;
+			}
+			if (fat_tab->antAveRSSI_pathB[i] > max_rssi_path_b) {
+				max_rssi_path_b = fat_tab->antAveRSSI_pathB[i];
+				pckcnt_path_b = fat_tab->antRSSIcnt_pathB[i];
+				target_ant_path_b = (u8) i;
+			}
+			if (fat_tab->antAveRSSI_pathB[i] == max_rssi_path_b) {
+				if (fat_tab->antRSSIcnt_pathB > pckcnt_path_b) {
+					max_rssi_path_b = fat_tab->antAveRSSI_pathB[i];
+					target_ant_path_b = (u8) i;
+				}
+			}
+			if (dm->fat_print_rssi == 1) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "***{path-B}: Sum RSSI[%d] = (( %d )),      cnt RSSI [%d] = (( %d )),     Avg RSSI[%d] = (( %d ))\n",
+					i, fat_tab->antSumRSSI_pathB[i], i, fat_tab->antRSSIcnt_pathB[i], i, fat_tab->antAveRSSI_pathB[i]);
+			}
+		}
+#endif
+#endif
+
+		/* 1 DECISION STATE */
+
+		/* 2 Select TRX Antenna */
+
+		phydm_fast_training_enable(dm, FAT_OFF);
+
+		/* 3 [path-A]--------------------------- */
+		if (is_pkt_filter_macth_path_a  == false) {
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "{path-A}: None Packet is matched\n"); */
+			PHYDM_DBG(dm, DBG_ANT_DIV, "{path-A}: None Packet is matched\n");
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+		} else {
+			PHYDM_DBG("target_ant_path_a = (( %d )) , max_rssi_path_a = (( %d ))\n", target_ant_path_a, max_rssi_path_a);
+
+			/* 3 [ update RX-optional ant ]        Default RX is Omni, Optional RX is the best decision by FAT */
+			if (dm->support_ic_type == ODM_RTL8188E)
+				odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), target_ant_path_a);
+			else if (dm->support_ic_type == ODM_RTL8192E)
+				odm_set_bb_reg(dm, 0xB38, BIT(8) | BIT(7) | BIT(6), target_ant_path_a); /* Optional RX [pth-A] */
+
+			/* 3 [ update TX ant ] */
+			odm_update_tx_ant(dm, target_ant_path_a, (fat_tab->train_idx));
+
+			if (target_ant_path_a == 0)
+				odm_ant_div_on_off(dm, ANTDIV_OFF);
+		}
+#if 0
+#if (RTL8192E_SUPPORT == 1)
+		/* 3 [path-B]--------------------------- */
+		if (is_pkt_filter_macth_path_b == false) {
+			if (dm->fat_print_rssi == 1)
+				PHYDM_DBG(dm, DBG_ANT_DIV, "***[%d]{path-B}: None Packet is matched\n\n\n", __LINE__);
+		} else {
+			if (dm->fat_print_rssi == 1) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					" ***target_ant_path_b = (( %d )) *** max_rssi = (( %d ))***\n\n\n", target_ant_path_b, max_rssi_path_b);
+			}
+			odm_set_bb_reg(dm, 0xB38, BIT(21) | BIT20 | BIT19, target_ant_path_b);	/* Default RX is Omni, Optional RX is the best decision by FAT */
+			odm_set_bb_reg(dm, 0x80c, BIT(21), 1); /* Reg80c[21]=1'b1		//from TX Info */
+
+			fat_tab->antsel_pathB[fat_tab->train_idx] = target_ant_path_b;
+		}
+#endif
+#endif
+
+		/* 2 Reset counter */
+		for (i = 0; i < (dm->fat_comb_a); i++) {
+			fat_tab->ant_sum_rssi[i] = 0;
+			fat_tab->ant_rssi_cnt[i] = 0;
+		}
+		/*
+		#if (RTL8192E_SUPPORT == 1)
+		for(i=0; i<=(dm->fat_comb_b); i++)
+		{
+			fat_tab->antSumRSSI_pathB[i] = 0;
+			fat_tab->antRSSIcnt_pathB[i] = 0;
+		}
+		#endif
+		*/
+
+		fat_tab->fat_state = FAT_PREPARE_STATE;
+		return;
+	}
+
+	/* 1 NORMAL STATE */
+	if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Start Prepare state ]\n");
+
+		odm_set_next_mac_addr_target(dm);
+
+		/* 2 Prepare Training */
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+		phydm_fast_training_enable(dm, FAT_ON);
+		odm_ant_div_on_off(dm, ANTDIV_ON);		/* enable HW AntDiv */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Start Training state]\n");
+
+		odm_set_timer(dm, &dm->fast_ant_training_timer, dm->antdiv_intvl); /* ms */
+	}
+
+}
+
+void
+odm_fast_ant_training_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (*(dm->is_net_closed) == true)
+		return;
+#endif
+
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm->fast_ant_training_workitem);
+#else
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******odm_fast_ant_training_callback******\n");
+	odm_fast_ant_training(dm);
+#endif
+}
+
+void
+odm_fast_ant_training_work_item_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******odm_fast_ant_training_work_item_callback******\n");
+	odm_fast_ant_training(dm);
+}
+
+#endif
+
+void
+odm_ant_div_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	struct sw_antenna_switch			*dm_swat_table = &dm->dm_swat_table;
+
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]   Not Support Antenna Diversity Function\n");
+		return;
+	}
+	/* --- */
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_2G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[2G AntDiv Init]: Only Support 2G Antenna Diversity Function\n");
+		if (!(dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
+			return;
+	} else	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_5G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[5G AntDiv Init]: Only Support 5G Antenna Diversity Function\n");
+		if (!(dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
+			return;
+	} else	if (fat_tab->ant_div_2g_5g == (ODM_ANTDIV_2G | ODM_ANTDIV_5G))
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[2G & 5G AntDiv Init]:Support Both 2G & 5G Antenna Diversity Function\n");
+
+#endif
+	/* --- */
+
+	/* 2 [--General---] */
+	dm->antdiv_period = 0;
+
+	fat_tab->is_become_linked = false;
+	fat_tab->ant_div_on_off = 0xff;
+
+	/* 3       -   AP   - */
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	odm_bdc_init(dm);
+#endif
+#endif
+
+	/* 3     -   WIN   - */
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	dm_swat_table->ant_5g = MAIN_ANT;
+	dm_swat_table->ant_2g = MAIN_ANT;
+#endif
+
+	/* 2 [---Set MAIN_ANT as default antenna if Auto-ant enable---] */
+	odm_ant_div_on_off(dm, ANTDIV_OFF);
+
+	dm->ant_type = ODM_AUTO_ANT;
+
+	fat_tab->rx_idle_ant = 0xff; /*to make RX-idle-antenna will be updated absolutly*/
+	odm_update_rx_idle_ant(dm, MAIN_ANT);
+	phydm_keep_rx_ack_ant_by_tx_ant_time(dm, 0);  /* Timming issue: keep Rx ant after tx for ACK ( 5 x 3.2 mu = 16mu sec)*/
+
+	/* 2 [---Set TX Antenna---] */
+	if (fat_tab->p_force_tx_ant_by_desc == NULL) {
+	fat_tab->force_tx_ant_by_desc = 0;
+	fat_tab->p_force_tx_ant_by_desc = &fat_tab->force_tx_ant_by_desc;
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "p_force_tx_ant_by_desc = %d\n", *fat_tab->p_force_tx_ant_by_desc);
+
+	if (*fat_tab->p_force_tx_ant_by_desc == true)
+		odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	else
+	odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+
+
+	/* 2 [--88E---] */
+	if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		/* dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
+
+		if ((dm->ant_div_type != CGCS_RX_HW_ANTDIV)  && (dm->ant_div_type != CG_TRX_HW_ANTDIV) && (dm->ant_div_type != CG_TRX_SMART_ANTDIV)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]  88E Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_rx_hw_ant_div_init_88e(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_88e(dm);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_smart_hw_ant_div_init_88e(dm);
+#endif
+#endif
+	}
+
+	/* 2 [--92E---] */
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		/* dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
+
+		if ((dm->ant_div_type != CGCS_RX_HW_ANTDIV) && (dm->ant_div_type != CG_TRX_HW_ANTDIV)   && (dm->ant_div_type != CG_TRX_SMART_ANTDIV)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]  8192E Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_rx_hw_ant_div_init_92e(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_92e(dm);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_smart_hw_ant_div_init_92e(dm);
+#endif
+
+	}
+#endif
+
+	/* 2 [--8723B---] */
+#if (RTL8723B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type != S0S1_SW_ANTDIV && dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8723B  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		if (dm->ant_div_type == S0S1_SW_ANTDIV)
+			odm_s0s1_sw_ant_div_init_8723b(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_8723b(dm);
+	}
+#endif
+	/*2 [--8723D---]*/
+#if (RTL8723D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		if (fat_tab->p_default_s0_s1 == NULL) {
+			fat_tab->default_s0_s1 = 1;
+			fat_tab->p_default_s0_s1 = &fat_tab->default_s0_s1;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "default_s0_s1 = %d\n", *fat_tab->p_default_s0_s1);
+
+		if (*fat_tab->p_default_s0_s1 == true)
+			odm_update_rx_idle_ant(dm, MAIN_ANT);
+		else
+			odm_update_rx_idle_ant(dm, AUX_ANT);
+
+		if (dm->ant_div_type == S0S1_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_8723d(dm);
+		else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8723D  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+	}
+#endif
+	/* 2 [--8811A 8821A---] */
+#if (RTL8821A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		dm->ant_div_type = HL_SW_SMART_ANT_TYPE1;
+
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+			odm_trx_hw_ant_div_init_8821a(dm);
+			phydm_hl_smart_ant_type1_init_8821a(dm);
+		} else
+		#endif
+		{
+			#ifdef ODM_CONFIG_BT_COEXIST
+			dm->ant_div_type = S0S1_SW_ANTDIV;
+			#else
+			dm->ant_div_type = CG_TRX_HW_ANTDIV;
+			#endif
+
+			if (dm->ant_div_type != CG_TRX_HW_ANTDIV && dm->ant_div_type != S0S1_SW_ANTDIV) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8821A & 8811A  Not Supprrt This AntDiv type\n");
+				dm->support_ability &= ~(ODM_BB_ANT_DIV);
+				return;
+			}
+			if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_trx_hw_ant_div_init_8821a(dm);
+			else if (dm->ant_div_type == S0S1_SW_ANTDIV)
+				odm_s0s1_sw_ant_div_init_8821a(dm);
+		}
+	}
+#endif
+
+	/* 2 [--8821C---] */
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		if (dm->ant_div_type != S0S1_SW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8821C  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+		phydm_s0s1_sw_ant_div_init_8821c(dm);
+		odm_trx_hw_ant_div_init_8821c(dm);
+	}
+#endif
+
+	/* 2 [--8881A---] */
+#if (RTL8881A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8881A) {
+		/* dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+			odm_trx_hw_ant_div_init_8881a(dm);
+			/**/
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8881A  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		odm_trx_hw_ant_div_init_8881a(dm);
+	}
+#endif
+
+	/* 2 [--8812---] */
+#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8812) {
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8812A  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+		odm_trx_hw_ant_div_init_8812a(dm);
+	}
+#endif
+
+	/*[--8188F---]*/
+#if (RTL8188F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8188F) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		odm_s0s1_sw_ant_div_init_8188f(dm);
+	}
+#endif
+
+	/*[--8822B---]*/
+#if (RTL8822B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		dm->ant_div_type = HL_SW_SMART_ANT_TYPE2;
+
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE2)
+			phydm_hl_smart_ant_type2_init_8822b(dm);
+		#endif
+	}
+#endif
+
+	/*
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** support_ic_type=[%lu]\n",dm->support_ic_type);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** AntDiv support_ability=[%lu]\n",(dm->support_ability & ODM_BB_ANT_DIV)>>6);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** AntDiv type=[%d]\n",dm->ant_div_type);
+	*/
+}
+
+void
+odm_ant_div(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter	= dm->adapter;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+
+	if (dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "tp_active_occur=((%d)), evm_method_enable=((%d))\n",
+		dm->tp_active_occur, fat_tab->evm_method_enable);
+
+		if ((dm->tp_active_occur == 1) && (fat_tab->evm_method_enable == 1)) {
+			fat_tab->idx_ant_div_counter_5g = dm->antdiv_period;
+			fat_tab->idx_ant_div_counter_2g = dm->antdiv_period;
+		}
+	}
+#endif
+
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (fat_tab->idx_ant_div_counter_5g <  dm->antdiv_period) {
+			fat_tab->idx_ant_div_counter_5g++;
+			return;
+		} else
+			fat_tab->idx_ant_div_counter_5g = 0;
+	} else	if (*dm->band_type == ODM_BAND_2_4G) {
+		if (fat_tab->idx_ant_div_counter_2g <  dm->antdiv_period) {
+			fat_tab->idx_ant_div_counter_2g++;
+			return;
+		} else
+			fat_tab->idx_ant_div_counter_2g = 0;
+	}
+
+	/* ---------- */
+
+	/* ---------- */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN || DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+	if (fat_tab->enable_ctrl_frame_antdiv) {
+		if ((dm->data_frame_num <= 10) && (dm->is_linked))
+			fat_tab->use_ctrl_frame_antdiv = 1;
+		else
+			fat_tab->use_ctrl_frame_antdiv = 0;
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "use_ctrl_frame_antdiv = (( %d )), data_frame_num = (( %d ))\n", fat_tab->use_ctrl_frame_antdiv, dm->data_frame_num);
+		dm->data_frame_num = 0;
+	}
+
+	{
+#if (BEAMFORMING_SUPPORT == 1)
+
+		enum beamforming_cap		beamform_cap = phydm_get_beamform_cap(dm);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "is_bt_continuous_turn = ((%d))\n", dm->is_bt_continuous_turn);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv Beam Cap ]   cap= ((%d))\n", beamform_cap);
+		if (!dm->is_bt_continuous_turn) {
+			if ((beamform_cap & BEAMFORMEE_CAP) && (!(*fat_tab->is_no_csi_feedback))) { /* BFmee On  &&   Div On->Div Off */
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv : OFF ]   BFmee ==1; cap= ((%d))\n", beamform_cap);
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv BF]   is_no_csi_feedback= ((%d))\n", *(fat_tab->is_no_csi_feedback));
+				if (fat_tab->fix_ant_bfee == 0) {
+					odm_ant_div_on_off(dm, ANTDIV_OFF);
+					fat_tab->fix_ant_bfee = 1;
+				}
+				return;
+			} else { /* BFmee Off   &&   Div Off->Div On */
+				if ((fat_tab->fix_ant_bfee == 1)  &&  dm->is_linked) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv : ON ]   BFmee ==0; cap=((%d))\n", beamform_cap);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv BF]   is_no_csi_feedback= ((%d))\n", *(fat_tab->is_no_csi_feedback));
+					if (dm->ant_div_type != S0S1_SW_ANTDIV)
+						odm_ant_div_on_off(dm, ANTDIV_ON);
+
+					fat_tab->fix_ant_bfee = 0;
+				}
+			}
+		} else {
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+		}
+#endif
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	/* ----------just for fool proof */
+
+	if (dm->antdiv_rssi)
+		dm->debug_components |= DBG_ANT_DIV;
+	else
+		dm->debug_components &= ~DBG_ANT_DIV;
+
+	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_2G) {
+		/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 2G AntDiv Running ]\n"); */
+		if (!(dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
+			return;
+	} else if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_5G) {
+		/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 5G AntDiv Running ]\n"); */
+		if (!(dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
+			return;
+	}
+	/* else 	if(fat_tab->ant_div_2g_5g == (ODM_ANTDIV_2G|ODM_ANTDIV_5G)) */
+	/* { */
+	/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 2G & 5G AntDiv Running ]\n"); */
+	/* } */
+#endif
+
+	/* ---------- */
+
+	if (dm->antdiv_select == 1)
+		dm->ant_type = ODM_FIX_MAIN_ANT;
+	else if (dm->antdiv_select == 2)
+		dm->ant_type = ODM_FIX_AUX_ANT;
+	else { /* if (dm->antdiv_select==0) */
+		dm->ant_type = ODM_AUTO_ANT;
+
+		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		/*Stop Antenna diversity for CMW500 testing case*/
+		if (dm->consecutive_idlel_time >= 10) {
+			dm->ant_type = ODM_FIX_MAIN_ANT;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv: OFF] No TP case, consecutive_idlel_time=((%d))\n", dm->consecutive_idlel_time);
+		}
+		#endif
+	}
+
+	/* PHYDM_DBG(dm, DBG_ANT_DIV,"ant_type= (( %d )) , pre_ant_type= (( %d ))\n",dm->ant_type,dm->pre_ant_type); */
+
+	if (dm->ant_type != ODM_AUTO_ANT) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Fix Antenna at (( %s ))\n", (dm->ant_type == ODM_FIX_MAIN_ANT) ? "MAIN" : "AUX");
+
+		if (dm->ant_type != dm->pre_ant_type) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+
+			if (dm->ant_type == ODM_FIX_MAIN_ANT)
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			else if (dm->ant_type == ODM_FIX_AUX_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
+		}
+		dm->pre_ant_type = dm->ant_type;
+		return;
+	} else {
+		if (dm->ant_type != dm->pre_ant_type) {
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+		}
+		dm->pre_ant_type = dm->ant_type;
+	}
+
+
+	/* 3 ----------------------------------------------------------------------------------------------------------- */
+	/* 2 [--88E---] */
+	if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV || dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_fast_ant_training(dm);
+#endif
+
+#endif
+
+	}
+	/* 2 [--92E---] */
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV || dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_fast_ant_training(dm);
+#endif
+
+	}
+#endif
+
+#if (RTL8723B_SUPPORT == 1)
+	/* 2 [--8723B---] */
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		if (phydm_is_bt_enable_8723b(dm)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[BT is enable!!!]\n");
+			if (fat_tab->is_become_linked == true) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Set REG 948[9:6]=0x0\n");
+				if (dm->support_ic_type == ODM_RTL8723B)
+					odm_set_bb_reg(dm, 0x948, BIT(9) | BIT(8) | BIT(7) | BIT(6), 0x0);
+
+				fat_tab->is_become_linked = false;
+			}
+		} else {
+			if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+				odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+#endif
+			} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_hw_ant_div(dm);
+		}
+	}
+#endif
+	/*8723D*/
+#if (RTL8723D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		odm_hw_ant_div(dm);
+		/**/
+	}
+#endif
+
+	/* 2 [--8821A---] */
+#if (RTL8821A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+			if (sat_tab->fix_beam_pattern_en != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, " [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n", sat_tab->fix_beam_pattern_codeword);
+				/*return;*/
+			} else {
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] ant_div_type = HL_SW_SMART_ANT_TYPE1\n");*/
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
+			}
+
+		} else
+		#endif
+		{
+			#ifdef ODM_CONFIG_BT_COEXIST
+			if (!dm->bt_info_table.is_bt_enabled) { /*BT disabled*/
+				if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+					dm->ant_div_type = CG_TRX_HW_ANTDIV;
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [S0S1_SW_ANTDIV]  ->  [CG_TRX_HW_ANTDIV]\n");
+					/*odm_set_bb_reg(dm, 0x8D4, BIT24, 1); */
+					if (fat_tab->is_become_linked == true)
+						odm_ant_div_on_off(dm, ANTDIV_ON);
+				}
+
+			} else { /*BT enabled*/
+
+				if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+					dm->ant_div_type = S0S1_SW_ANTDIV;
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [CG_TRX_HW_ANTDIV]  ->  [S0S1_SW_ANTDIV]\n");
+					/*odm_set_bb_reg(dm, 0x8D4, BIT24, 0);*/
+					odm_ant_div_on_off(dm, ANTDIV_OFF);
+				}
+			}
+			#endif
+
+			if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+				#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+				odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+				#endif
+			} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_hw_ant_div(dm);
+		}
+	}
+#endif
+
+	/* 2 [--8821C---] */
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		if (!dm->is_bt_continuous_turn) {
+			dm->ant_div_type = S0S1_SW_ANTDIV;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "is_bt_continuous_turn = ((%d))   ==> SW AntDiv\n", dm->is_bt_continuous_turn);
+
+		} else {
+			dm->ant_div_type = CG_TRX_HW_ANTDIV;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "is_bt_continuous_turn = ((%d))   ==> HW AntDiv\n", dm->is_bt_continuous_turn);
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+		}
+
+		if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+			odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+#endif
+		} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+	}
+#endif
+
+	/* 2 [--8881A---] */
+#if (RTL8881A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8881A)
+		odm_hw_ant_div(dm);
+#endif
+
+	/* 2 [--8812A---] */
+#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8812)
+		odm_hw_ant_div(dm);
+#endif
+
+#if (RTL8188F_SUPPORT == 1)
+	/* [--8188F---]*/
+	else if (dm->support_ic_type == ODM_RTL8188F)	{
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+#endif
+	}
+#endif
+
+	/* [--8822B---]*/
+#if (RTL8822B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) {
+			if (sat_tab->fix_beam_pattern_en != 0)
+				PHYDM_DBG(dm, DBG_ANT_DIV, " [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n", sat_tab->fix_beam_pattern_codeword);
+			else
+				phydm_fast_ant_training_hl_smart_antenna_type2(dm);
+		}
+		#endif
+	}
+#endif
+
+
+}
+
+
+void
+odm_antsel_statistics(
+	void			*dm_void,
+	void			*phy_info_void,
+	u8			antsel_tr_mux,
+	u32			mac_id,
+	u32			utility,
+	u8			method,
+	u8			is_cck_rate
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	struct phydm_phyinfo_struct	*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+
+	if (method == RSSI_METHOD) {
+		if (is_cck_rate) {
+			if (antsel_tr_mux == ANT1_2G) {
+				if (fat_tab->main_ant_sum_cck[mac_id] > 65435) /*to prevent u16 overflow, max(RSSI)=100, 65435+100 = 65535 (u16)*/
+					return;
+
+				fat_tab->main_ant_sum_cck[mac_id] += (u16)utility;
+				fat_tab->main_ant_cnt_cck[mac_id]++;
+			} else {
+				if (fat_tab->aux_ant_sum_cck[mac_id] > 65435)
+					return;
+
+				fat_tab->aux_ant_sum_cck[mac_id] += (u16)utility;
+				fat_tab->aux_ant_cnt_cck[mac_id]++;
+			}
+
+		} else { /*ofdm rate*/
+
+			if (antsel_tr_mux == ANT1_2G) {
+				if (fat_tab->main_ant_sum[mac_id] > 65435)
+					return;
+
+				fat_tab->main_ant_sum[mac_id] += (u16)utility;
+				fat_tab->main_ant_cnt[mac_id]++;
+			} else {
+				if (fat_tab->aux_ant_sum[mac_id] > 65435)
+					return;
+
+				fat_tab->aux_ant_sum[mac_id] += (u16)utility;
+				fat_tab->aux_ant_cnt[mac_id]++;
+			}
+		}
+	}
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	else if (method == EVM_METHOD) {
+		if (dm->rate_ss == 1) {
+			if (antsel_tr_mux == ANT1_2G) {
+				fat_tab->main_ant_evm_sum[mac_id] += ((phy_info->rx_mimo_evm_dbm[0])<<5);
+				fat_tab->main_ant_evm_cnt[mac_id]++;
+			} else {
+				fat_tab->aux_ant_evm_sum[mac_id] += ((phy_info->rx_mimo_evm_dbm[0])<<5);
+				fat_tab->aux_ant_evm_cnt[mac_id]++;
+			}
+
+		} else {/*>= 2SS*/
+
+			if (antsel_tr_mux == ANT1_2G) {
+				fat_tab->main_ant_evm_2ss_sum[mac_id][0] += (phy_info->rx_mimo_evm_dbm[0]<<5);
+				fat_tab->main_ant_evm_2ss_sum[mac_id][1] += (phy_info->rx_mimo_evm_dbm[1]<<5);
+				fat_tab->main_ant_evm_2ss_cnt[mac_id]++;
+
+			} else {
+				fat_tab->aux_ant_evm_2ss_sum[mac_id][0] += (phy_info->rx_mimo_evm_dbm[0]<<5);
+				fat_tab->aux_ant_evm_2ss_sum[mac_id][1] += (phy_info->rx_mimo_evm_dbm[1]<<5);
+				fat_tab->aux_ant_evm_2ss_cnt[mac_id]++;
+			}
+		}
+
+	} else if (method == CRC32_METHOD) {
+		if (antsel_tr_mux == ANT1_2G) {
+			fat_tab->main_crc32_ok_cnt += utility;
+			fat_tab->main_crc32_fail_cnt++;
+		} else {
+			fat_tab->aux_crc32_ok_cnt += utility;
+			fat_tab->aux_crc32_fail_cnt++;
+		}
+
+	} else if (method == TP_METHOD) {
+		if (((utility <= ODM_RATEMCS15) && (utility >= ODM_RATEMCS0)) &&
+			(fat_tab->fat_state_cnt <= dm->antdiv_tp_period)
+		) {
+			if (antsel_tr_mux == ANT1_2G) {
+				fat_tab->antdiv_tp_main += (phy_rate_table[utility])<<5;
+				fat_tab->antdiv_tp_main_cnt++;
+			} else {
+				fat_tab->antdiv_tp_aux += (phy_rate_table[utility])<<5;
+				fat_tab->antdiv_tp_aux_cnt++;
+			}
+		}
+	}
+#endif
+}
+
+void
+odm_process_rssi_for_ant_div(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct			*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct				*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	u32			beam_tmp;
+	u8			next_ant;
+	u8			train_pkt_number;
+#endif
+	u8			rx_power_ant0 = phy_info->rx_mimo_signal_strength[0];
+	u8			rx_power_ant1 = phy_info->rx_mimo_signal_strength[1];
+	u8			rx_evm_ant0 = phy_info->rx_mimo_signal_quality[0];
+	u8			rx_evm_ant1 = phy_info->rx_mimo_signal_quality[1];
+	u8			rssi_avg;
+
+	if ((dm->support_ic_type & ODM_IC_2SS) && (!pktinfo->is_cck_rate)) {
+		if (rx_power_ant1 < 100)
+			rssi_avg = (u8)odm_convert_to_db((odm_convert_to_linear(rx_power_ant0) + odm_convert_to_linear(rx_power_ant1))>>1); /*averaged PWDB*/
+		
+	} else {
+		rx_power_ant0 = (u8)phy_info->rx_pwdb_all;
+		rssi_avg = rx_power_ant0;
+	}
+	
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+	if ((dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) && (fat_tab->fat_state == FAT_TRAINING_STATE))
+		phydm_process_rssi_for_hb_smtant_type2(dm, phy_info, pktinfo, rssi_avg);	/*for 8822B*/
+	else
+#endif
+
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+#ifdef CONFIG_FAT_PATCH
+	if ((dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) && (fat_tab->fat_state == FAT_TRAINING_STATE)) {
+		/*[Beacon]*/
+		if (pktinfo->is_packet_beacon) {
+			sat_tab->beacon_counter++;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "MatchBSSID_beacon_counter = ((%d))\n", sat_tab->beacon_counter);
+
+			if (sat_tab->beacon_counter >= sat_tab->pre_beacon_counter + 2) {
+				if (sat_tab->ant_num > 1) {
+					next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+					odm_update_rx_idle_ant(dm, next_ant);
+				}
+
+				sat_tab->update_beam_idx++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
+					sat_tab->pre_beacon_counter, sat_tab->pkt_counter, sat_tab->update_beam_idx);
+
+				sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+				sat_tab->pkt_counter = 0;
+			}
+		}
+		/*[data]*/
+		else if (pktinfo->is_packet_to_self) {
+			if (sat_tab->pkt_skip_statistic_en == 0) {
+				/*
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, fat_tab->hw_antsw_occur, sat_tab->fast_training_beam_num, rx_power_ant0);
+				*/
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ID[%d][pkt_cnt = %d]: {ANT, Beam} = {%d, %d}, RSSI = ((%d))\n",
+					pktinfo->station_id, sat_tab->pkt_counter, fat_tab->antsel_rx_keep_0, sat_tab->fast_training_beam_num, rx_power_ant0);
+
+				sat_tab->pkt_rssi_sum[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num] += rx_power_ant0;
+				sat_tab->pkt_rssi_cnt[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num]++;
+				sat_tab->pkt_counter++;
+
+				#if 1
+				train_pkt_number = sat_tab->beam_train_cnt[fat_tab->rx_idle_ant - 1][sat_tab->fast_training_beam_num];
+				#else
+				train_pkt_number =  sat_tab->per_beam_training_pkt_num;
+				#endif
+
+				/*Swich Antenna erery N pkts*/
+				if (sat_tab->pkt_counter == train_pkt_number) {
+					if (sat_tab->ant_num > 1) {
+						PHYDM_DBG(dm, DBG_ANT_DIV, "packet enugh ((%d ))pkts ---> Switch antenna\n", train_pkt_number);
+						next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+						odm_update_rx_idle_ant(dm, next_ant);
+					}
+
+					sat_tab->update_beam_idx++;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), update_beam_idx_counter = ((%d))\n",
+						sat_tab->pre_beacon_counter, sat_tab->update_beam_idx);
+
+					sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+					sat_tab->pkt_counter = 0;
+				}
+			}
+		}
+
+		/*Swich Beam after switch "sat_tab->ant_num" antennas*/
+		if (sat_tab->update_beam_idx == sat_tab->ant_num) {
+			sat_tab->update_beam_idx = 0;
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+
+			if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+				fat_tab->fat_state = FAT_DECISION_STATE;
+
+				#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
+				#else
+				odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+				#endif
+
+
+			} else {
+				sat_tab->fast_training_beam_num++;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Update Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+				phydm_set_all_ant_same_beam_num(dm);
+
+				fat_tab->fat_state = FAT_TRAINING_STATE;
+			}
+		}
+
+	}
+#else
+
+	if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+		if ((dm->support_ic_type & ODM_HL_SMART_ANT_TYPE1_SUPPORT) &&
+		    (pktinfo->is_packet_to_self)   &&
+		    (fat_tab->fat_state == FAT_TRAINING_STATE)
+		   ) {
+			if (sat_tab->pkt_skip_statistic_en == 0) {
+				/*
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, fat_tab->hw_antsw_occur, sat_tab->fast_training_beam_num, rx_power_ant0);
+				*/
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), is_packet_to_self = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, pktinfo->is_packet_to_self, sat_tab->fast_training_beam_num, rx_power_ant0);
+
+
+				sat_tab->pkt_rssi_sum[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num] += rx_power_ant0;
+				sat_tab->pkt_rssi_cnt[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num]++;
+				sat_tab->pkt_counter++;
+
+				/*swich beam every N pkt*/
+				if ((sat_tab->pkt_counter) >= (sat_tab->per_beam_training_pkt_num)) {
+					sat_tab->pkt_counter = 0;
+					beam_tmp = sat_tab->fast_training_beam_num;
+
+					if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+						fat_tab->fat_state = FAT_DECISION_STATE;
+
+						#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+						odm_fast_ant_training_hl_smart_antenna_type1(dm);
+						#else
+						odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+						#endif
+
+
+					} else {
+						sat_tab->fast_training_beam_num++;
+						phydm_set_all_ant_same_beam_num(dm);
+
+						fat_tab->fat_state = FAT_TRAINING_STATE;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Update  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+					}
+				}
+			}
+		}
+	}
+#endif
+	else
+#endif
+		if (dm->ant_div_type == CG_TRX_SMART_ANTDIV) {
+			if ((dm->support_ic_type & ODM_SMART_ANT_SUPPORT) && (pktinfo->is_packet_to_self)   && (fat_tab->fat_state == FAT_TRAINING_STATE)) { /* (pktinfo->is_packet_match_bssid && (!pktinfo->is_packet_beacon)) */
+				u8	antsel_tr_mux;
+				antsel_tr_mux = (fat_tab->antsel_rx_keep_2 << 2) | (fat_tab->antsel_rx_keep_1 << 1) | fat_tab->antsel_rx_keep_0;
+				fat_tab->ant_sum_rssi[antsel_tr_mux] += rx_power_ant0;
+				fat_tab->ant_rssi_cnt[antsel_tr_mux]++;
+			}
+		} else { /* ant_div_type != CG_TRX_SMART_ANTDIV */
+			if ((dm->support_ic_type & ODM_ANTDIV_SUPPORT) && (pktinfo->is_packet_to_self || fat_tab->use_ctrl_frame_antdiv)) {
+				if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+					if (pktinfo->is_cck_rate || (dm->support_ic_type == ODM_RTL8188F))
+						fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
+
+						odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_power_ant0, RSSI_METHOD, pktinfo->is_cck_rate);
+
+				} else {
+					
+					odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_power_ant0, RSSI_METHOD, pktinfo->is_cck_rate);
+
+					#ifdef ODM_EVM_ENHANCE_ANTDIV
+					if (dm->support_ic_type == ODM_RTL8192E) {
+						if (!pktinfo->is_cck_rate) {
+							odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_evm_ant0, EVM_METHOD, pktinfo->is_cck_rate);
+							odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_evm_ant0, TP_METHOD, pktinfo->is_cck_rate);
+						}
+
+					}
+					#endif
+				}
+			}
+		}
+	/* PHYDM_DBG(dm,DBG_ANT_DIV,"is_cck_rate=%d, pwdb_all=%d\n",pktinfo->is_cck_rate, phy_info->rx_pwdb_all); */
+	/* PHYDM_DBG(dm,DBG_ANT_DIV,"antsel_tr_mux=3'b%d%d%d\n",fat_tab->antsel_rx_keep_2, fat_tab->antsel_rx_keep_1, fat_tab->antsel_rx_keep_0); */
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+odm_set_tx_ant_by_tx_info(
+	void			*dm_void,
+	u8			*desc,
+	u8			mac_id
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+		return;
+
+
+	if (dm->support_ic_type == ODM_RTL8723B) {
+#if (RTL8723B_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8723B(desc, fat_tab->antsel_a[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8723B] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8821) {
+#if (RTL8821A_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8812(desc, fat_tab->antsel_a[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8821A] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_88E(desc, fat_tab->antsel_a[mac_id]);
+		SET_TX_DESC_ANTSEL_B_88E(desc, fat_tab->antsel_b[mac_id]);
+		SET_TX_DESC_ANTSEL_C_88E(desc, fat_tab->antsel_c[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8188E] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8821C) {
+#if (RTL8821C_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8821C(desc, fat_tab->antsel_a[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8821C] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	}
+}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_set_tx_ant_by_tx_info(
+	struct	rtl8192cd_priv		*priv,
+	struct	tx_desc	*pdesc,
+	unsigned short			aid
+)
+{
+	struct dm_struct	*dm = GET_PDM_ODM(priv);/*&(priv->pshare->_dmODM);*/
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+		return;
+
+	if (dm->support_ic_type == ODM_RTL8881A) {
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);	*/
+		pdesc->Dword6 &= set_desc(~(BIT(18) | BIT(17) | BIT(16)));
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8192E******\n",__FUNCTION__,__LINE__);	*/
+		pdesc->Dword6 &= set_desc(~(BIT(18) | BIT(17) | BIT(16)));
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8188E******\n",__FUNCTION__,__LINE__);*/
+		pdesc->Dword2 &= set_desc(~BIT(24));
+		pdesc->Dword2 &= set_desc(~BIT(25));
+		pdesc->Dword7 &= set_desc(~BIT(29));
+
+		pdesc->Dword2 |= set_desc(fat_tab->antsel_a[aid] << 24);
+		pdesc->Dword2 |= set_desc(fat_tab->antsel_b[aid] << 25);
+		pdesc->Dword7 |= set_desc(fat_tab->antsel_c[aid] << 29);
+
+
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		/*[path-A]*/
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);*/
+
+		pdesc->Dword6 &= set_desc(~BIT(16));
+		pdesc->Dword6 &= set_desc(~BIT(17));
+		pdesc->Dword6 &= set_desc(~BIT(18));
+
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_b[aid] << 17);
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_c[aid] << 18);
+
+	}
+}
+
+
+#if 1 /*def CONFIG_WLAN_HAL*/
+void
+odm_set_tx_ant_by_tx_info_hal(
+	struct	rtl8192cd_priv		*priv,
+	void	*pdesc_data,
+	u16					aid
+)
+{
+	struct dm_struct	*dm = GET_PDM_ODM(priv);/*&(priv->pshare->_dmODM);*/
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	PTX_DESC_DATA_88XX	pdescdata = (PTX_DESC_DATA_88XX)pdesc_data;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+		return;
+
+	if (dm->support_ic_type & (ODM_RTL8881A | ODM_RTL8192E | ODM_RTL8814A)) {
+		/*panic_printk("[%s] [%d] ******odm_set_tx_ant_by_tx_info_hal******\n",__FUNCTION__,__LINE__);*/
+		pdescdata->ant_sel = 1;
+		pdescdata->ant_sel_a = fat_tab->antsel_a[aid];
+	}
+}
+#endif	/*#ifdef CONFIG_WLAN_HAL*/
+
+#endif
+
+
+void
+odm_ant_div_config(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "WIN Config Antenna Diversity\n");
+	/*
+	if(dm->support_ic_type==ODM_RTL8723B)
+	{
+		if((!dm->dm_swat_table.ANTA_ON || !dm->dm_swat_table.ANTB_ON))
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	}
+	*/
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		dm->ant_div_type = S0S1_TRX_HW_ANTDIV;
+		/**/
+	}
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "CE Config Antenna Diversity\n");
+
+	if (dm->support_ic_type == ODM_RTL8723B)
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+
+
+
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "AP Config Antenna Diversity\n");
+
+	/* 2 [ NOT_SUPPORT_ANTDIV ] */
+#if (defined(CONFIG_NOT_SUPPORT_ANTDIV))
+	dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Disable AntDiv function] : Not Support 2.4G & 5G Antenna Diversity\n");
+
+	/* 2 [ 2G&5G_SUPPORT_ANTDIV ] */
+#elif (defined(CONFIG_2G5G_SUPPORT_ANTDIV))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Enable AntDiv function] : 2.4G & 5G Support Antenna Diversity Simultaneously\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_2G | ODM_ANTDIV_5G);
+
+	if (dm->support_ic_type & ODM_ANTDIV_SUPPORT)
+		dm->support_ability |= ODM_BB_ANT_DIV;
+	if (*dm->band_type == ODM_BAND_5G) {
+#if (defined(CONFIG_5G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+		panic_printk("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_TRX_DIVERSITY) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+		panic_printk("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	} else if (*dm->band_type == ODM_BAND_2_4G) {
+#if (defined(CONFIG_2G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_TRX_DIVERSITY) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	}
+
+	/* 2 [ 5G_SUPPORT_ANTDIV ] */
+#elif (defined(CONFIG_5G_SUPPORT_ANTDIV))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n");
+	panic_printk("[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_5G);
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC)
+			dm->support_ability |= ODM_BB_ANT_DIV;
+#if (defined(CONFIG_5G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+		panic_printk("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_TRX_DIVERSITY))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		panic_printk("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	} else if (*dm->band_type == ODM_BAND_2_4G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Not Support 2G ant_div_type\n");
+		dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	}
+
+	/* 2 [ 2G_SUPPORT_ANTDIV ] */
+#elif (defined(CONFIG_2G_SUPPORT_ANTDIV))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Enable AntDiv function] : Only 2.4G Support Antenna Diversity\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_2G);
+	if (*dm->band_type == ODM_BAND_2_4G) {
+		if (dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC)
+			dm->support_ability |= ODM_BB_ANT_DIV;
+#if (defined(CONFIG_2G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_TRX_DIVERSITY))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	} else if (*dm->band_type == ODM_BAND_5G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Not Support 5G ant_div_type\n");
+		dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	}
+#endif
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv Config Info] AntDiv_SupportAbility = (( %x ))\n", ((dm->support_ability & ODM_BB_ANT_DIV) ? 1 : 0));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv Config Info] be_fix_tx_ant = ((%d))\n", dm->dm_fat_table.b_fix_tx_ant);
+
+}
+
+
+void
+odm_ant_div_timers(
+	void		*dm_void,
+	u8		state
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (state == INIT_ANTDIV_TIMMER) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_initialize_timer(dm,
+				     &dm->dm_swat_table.phydm_sw_antenna_switch_timer,
+				     (void *)odm_sw_antdiv_callback, NULL,
+				     "phydm_sw_antenna_switch_timer");
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_initialize_timer(dm, &dm->fast_ant_training_timer,
+			(void *)odm_fast_ant_training_callback, NULL, "fast_ant_training_timer");
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+		odm_initialize_timer(dm, &dm->evm_fast_ant_training_timer,
+			(void *)odm_evm_fast_ant_training_callback, NULL, "evm_fast_ant_training_timer");
+#endif
+	} else if (state == CANCEL_ANTDIV_TIMMER) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_cancel_timer(dm,
+				 &dm->dm_swat_table.phydm_sw_antenna_switch_timer);
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_cancel_timer(dm, &dm->fast_ant_training_timer);
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+		odm_cancel_timer(dm, &dm->evm_fast_ant_training_timer);
+#endif
+	} else if (state == RELEASE_ANTDIV_TIMMER) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_release_timer(dm,
+				  &dm->dm_swat_table.phydm_sw_antenna_switch_timer);
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_release_timer(dm, &dm->fast_ant_training_timer);
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+		odm_release_timer(dm, &dm->evm_fast_ant_training_timer);
+#endif
+	}
+
+}
+
+void
+phydm_antdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	/*struct phydm_fat_struct*			fat_tab = &dm->dm_fat_table;*/
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm_value[0] == 1) { /*fixed or auto antenna*/
+
+		if (dm_value[1] == 0) {
+			dm->ant_type = ODM_AUTO_ANT;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "AntDiv: Auto\n");
+		} else if (dm_value[1] == 1) {
+			dm->ant_type = ODM_FIX_MAIN_ANT;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "AntDiv: Fix Main\n");
+		} else if (dm_value[1] == 2) {
+			dm->ant_type = ODM_FIX_AUX_ANT;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "AntDiv: Fix Aux\n");
+		}
+
+		if (dm->ant_type != ODM_AUTO_ANT) {
+			odm_stop_antenna_switch_dm(dm);
+			if (dm->ant_type == ODM_FIX_MAIN_ANT)
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			else if (dm->ant_type == ODM_FIX_AUX_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
+		} else {
+			phydm_enable_antenna_diversity(dm);
+		}
+		dm->pre_ant_type = dm->ant_type;
+	} else if (dm_value[0] == 2) { /*dynamic period for AntDiv*/
+
+		dm->antdiv_period = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "AntDiv_period = ((%d))\n", dm->antdiv_period);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
+
+void
+odm_ant_div_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_s0s1_sw_ant_div_reset(dm);
+#endif
+	}
+
+}
+
+void
+odm_antenna_diversity_init(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if 0
+	if (*(dm->mp_mode) == true)
+		return;
+#endif
+
+	odm_ant_div_config(dm);
+	odm_ant_div_init(dm);
+#endif
+}
+
+void
+odm_antenna_diversity(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (*dm->mp_mode == true)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]   Not Support Antenna Diversity Function\n");
+		return;
+	}
+
+	if (dm->pause_ability & ODM_BB_ANT_DIV) {
+		
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Return: Pause AntDIv in LV=%d\n", dm->pause_lv_table.lv_antdiv);
+		return;
+	}
+
+	odm_ant_div(dm);
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdiv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdiv.h
new file mode 100644
index 000000000000..0918afcd8f95
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_antdiv.h
@@ -0,0 +1,617 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMANTDIV_H__
+#define    __PHYDMANTDIV_H__
+
+/*#define ANTDIV_VERSION	"2.0"  //2014.11.04*/
+/*#define ANTDIV_VERSION	"2.1"  //2015.01.13  Dino*/
+/*#define ANTDIV_VERSION	"2.2"  2015.01.16  Dino*/
+/*#define ANTDIV_VERSION	"3.1"  2015.07.29  YuChen, remove 92c 92d 8723a*/
+/*#define ANTDIV_VERSION	"3.2"  2015.08.11  Stanley, disable antenna diversity when BT is enable for 8723B*/
+/*#define ANTDIV_VERSION	"3.3"  2015.08.12  Stanley. 8723B does not need to check the antenna is control by BT,
+							because antenna diversity only works when BT is disable or radio off*/
+/*#define ANTDIV_VERSION	"3.4"  2015.08.28  Dino  1.Add 8821A Smart Antenna 2. Add 8188F SW S0S1 Antenna Diversity*/
+/*#define ANTDIV_VERSION	"3.5"  2015.10.07  Stanley  Always check antenna detection result from BT-coex. for 8723B, not from PHYDM*/
+/*#define ANTDIV_VERSION	"3.6"*/  /*2015.11.16  Stanley  */
+/*#define ANTDIV_VERSION	"3.7"*/  /*2015.11.20  Dino Add SmartAnt FAT Patch */
+/*#define ANTDIV_VERSION	"3.8"  2015.12.21  Dino, Add SmartAnt dynamic training packet num */
+/*#define ANTDIV_VERSION	"3.9"  2016.01.05  Dino, Add SmartAnt cmd for converting single & two smtant, and add cmd for adjust truth table */
+#define ANTDIV_VERSION	"4.0"  /*2017.05.25  Mark, Add SW antenna diversity for 8821c because HW transient issue */
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define	ANTDIV_INIT		0xff
+#define	MAIN_ANT	1		/*ant A or ant Main   or S1*/
+#define	AUX_ANT		2		/*AntB or ant Aux   or S0*/
+#define	MAX_ANT		3		/* 3 for AP using*/
+
+#define ANT1_2G 0 /* = ANT2_5G	for 8723D  BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */
+#define ANT2_2G 1 /* = ANT1_5G	for 8723D  BTG S0  RX S0S1 diversity for 8723D, TX fixed at S1 */
+/*smart antenna*/
+#define SUPPORT_RF_PATH_NUM 4
+#define SUPPORT_BEAM_PATTERN_NUM 4
+#define NUM_ANTENNA_8821A	2
+
+#define SUPPORT_BEAM_SET_PATTERN_NUM		16
+
+#define	NO_FIX_TX_ANT		0
+#define	FIX_TX_AT_MAIN	1
+#define	FIX_AUX_AT_MAIN	2
+
+/* Antenna Diversty Control type */
+#define	ODM_AUTO_ANT		0
+#define	ODM_FIX_MAIN_ANT	1
+#define	ODM_FIX_AUX_ANT	2
+
+#define ODM_N_ANTDIV_SUPPORT		(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A)
+#define ODM_AC_ANTDIV_SUPPORT	(ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)
+#define ODM_ANTDIV_SUPPORT		(ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)
+#define ODM_SMART_ANT_SUPPORT	(ODM_RTL8188E | ODM_RTL8192E)
+#define ODM_HL_SMART_ANT_TYPE1_SUPPORT		(ODM_RTL8821 | ODM_RTL8822B)
+
+#define ODM_ANTDIV_2G_SUPPORT_IC			(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D)
+#define ODM_ANTDIV_5G_SUPPORT_IC			(ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C)
+
+#define ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC	(ODM_RTL8192E)
+
+#define ODM_ANTDIV_2G	BIT(0)
+#define ODM_ANTDIV_5G	BIT(1)
+
+#define ANTDIV_ON	1
+#define ANTDIV_OFF	0
+
+#define FAT_ON	1
+#define FAT_OFF	0
+
+#define TX_BY_DESC	1
+#define TX_BY_REG	0
+
+#define RSSI_METHOD	0
+#define EVM_METHOD		1
+#define CRC32_METHOD	2
+#define TP_METHOD		3
+
+#define INIT_ANTDIV_TIMMER		0
+#define CANCEL_ANTDIV_TIMMER	1
+#define RELEASE_ANTDIV_TIMMER	2
+
+#define CRC32_FAIL	1
+#define CRC32_OK	0
+
+#define evm_rssi_th_high	25
+#define evm_rssi_th_low	20
+
+#define NORMAL_STATE_MIAN	1
+#define NORMAL_STATE_AUX	2
+#define TRAINING_STATE		3
+
+#define FORCE_RSSI_DIFF 10
+
+#define CSI_ON	1
+#define CSI_OFF	0
+
+#define DIVON_CSIOFF 1
+#define DIVOFF_CSION 2
+
+#define BDC_DIV_TRAIN_STATE	0
+#define bdc_bfer_train_state	1
+#define BDC_DECISION_STATE		2
+#define BDC_BF_HOLD_STATE		3
+#define BDC_DIV_HOLD_STATE		4
+
+#define BDC_MODE_1 1
+#define BDC_MODE_2 2
+#define BDC_MODE_3 3
+#define BDC_MODE_4 4
+#define BDC_MODE_NULL 0xff
+
+/*SW S0S1 antenna diversity*/
+#define SWAW_STEP_INIT			0xff
+#define SWAW_STEP_PEEK		0
+#define SWAW_STEP_DETERMINE	1
+
+#define RSSI_CHECK_RESET_PERIOD	10
+#define RSSI_CHECK_THRESHOLD		50
+
+/*Hong Lin Smart antenna*/
+#define HL_SMTANT_2WIRE_DATA_LEN 24
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+struct sw_antenna_switch {
+	u8		double_chk_flag;	/*If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than check this antenna again*/
+	u8		try_flag;
+	s32		pre_rssi;
+	u8		cur_antenna;
+	u8		pre_antenna;
+	u8		rssi_trying;
+	u8		reset_idx;
+	u8		train_time;
+	u8		train_time_flag; /*base on RSSI difference between two antennas*/
+	struct phydm_timer_list	phydm_sw_antenna_switch_timer;
+	u32		pkt_cnt_sw_ant_div_by_ctrl_frame;
+	boolean		is_sw_ant_div_by_ctrl_frame;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	phydm_sw_antenna_switch_workitem;
+#endif
+#endif
+
+	/* AntDect (Before link Antenna Switch check) need to be moved*/
+	u16		single_ant_counter;
+	u16		dual_ant_counter;
+	u16		aux_fail_detec_counter;
+	u16		retry_counter;
+	u8		swas_no_link_state;
+	u32		swas_no_link_bk_reg948;
+	boolean		ANTA_ON;	/*To indicate ant A is or not*/
+	boolean		ANTB_ON;	/*To indicate ant B is on or not*/
+	boolean		pre_aux_fail_detec;
+	boolean		rssi_ant_dect_result;
+	u8		ant_5g;
+	u8		ant_2g;
+
+
+};
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+struct _BF_DIV_COEX_ {
+	boolean w_bfer_client[ODM_ASSOCIATE_ENTRY_NUM];
+	boolean w_bfee_client[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
+
+	u8  bd_ccoex_type_wbfer;
+	u8 num_txbfee_client;
+	u8 num_txbfer_client;
+	u8 bdc_try_counter;
+	u8 bdc_hold_counter;
+	u8 bdc_mode;
+	u8 bdc_active_mode;
+	u8 BDC_state;
+	u8 bdc_rx_idle_update_counter;
+	u8 num_client;
+	u8 pre_num_client;
+	u8 num_bf_tar;
+	u8 num_div_tar;
+
+	boolean is_all_div_sta_idle;
+	boolean is_all_bf_sta_idle;
+	boolean bdc_try_flag;
+	boolean BF_pass;
+	boolean DIV_pass;
+};
+#endif
+#endif
+
+
+struct phydm_fat_struct {
+	u8	bssid[6];
+	u8	antsel_rx_keep_0;
+	u8	antsel_rx_keep_1;
+	u8	antsel_rx_keep_2;
+	u8	antsel_rx_keep_3;
+	u32	ant_sum_rssi[7];
+	u32	ant_rssi_cnt[7];
+	u32	ant_ave_rssi[7];
+	u8	fat_state;
+	u8	fat_state_cnt;
+	u32	train_idx;
+	u8	antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	rx_idle_ant;
+	u8	rvrt_val;
+	u8	ant_div_on_off;
+	boolean	is_become_linked;
+	u32	min_max_rssi;
+	u8	idx_ant_div_counter_2g;
+	u8	idx_ant_div_counter_5g;
+	u8	ant_div_2g_5g;
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	/*For 1SS RX phy rate*/
+	u32	main_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	main_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+
+	/*For 2SS RX phy rate*/
+	u32	main_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];	/*2SS with A1+B*/
+	u32	aux_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];	/*2SS with A2+B*/
+	u32	main_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+
+	boolean	evm_method_enable;
+	u8	target_ant_evm;
+	u8	target_ant_crc32;
+	u8	target_ant_tp;
+	u8	target_ant_enhance;
+	u8	pre_target_ant_enhance;
+	u16	main_mpdu_ok_cnt;
+	u16	aux_mpdu_ok_cnt;
+
+	u32	crc32_ok_cnt;
+	u32	crc32_fail_cnt;
+	u32	main_crc32_ok_cnt;
+	u32	aux_crc32_ok_cnt;
+	u32	main_crc32_fail_cnt;
+	u32	aux_crc32_fail_cnt;
+
+	u32	antdiv_tp_main;
+	u32	antdiv_tp_aux;
+	u32	antdiv_tp_main_cnt;
+	u32	antdiv_tp_aux_cnt;
+
+	u8	pre_antdiv_rssi;
+	u8	pre_antdiv_tp;
+#endif
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u32    cck_ctrl_frame_cnt_main;
+	u32    cck_ctrl_frame_cnt_aux;
+	u32    ofdm_ctrl_frame_cnt_main;
+	u32    ofdm_ctrl_frame_cnt_aux;
+	u32	main_ant_ctrl_frame_sum;
+	u32	aux_ant_ctrl_frame_sum;
+	u32	main_ant_ctrl_frame_cnt;
+	u32	aux_ant_ctrl_frame_cnt;
+#endif
+	u8	b_fix_tx_ant;
+	boolean	fix_ant_bfee;
+	boolean	enable_ctrl_frame_antdiv;
+	boolean	use_ctrl_frame_antdiv;
+	boolean	*is_no_csi_feedback;
+	u8	hw_antsw_occur;
+	u8	*p_force_tx_ant_by_desc;
+	u8	force_tx_ant_by_desc; /*A temp value, will hook to driver team's outer parameter later*/
+	u8    *p_default_s0_s1;
+	u8    default_s0_s1;
+};
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+enum fat_state /*Fast antenna training*/
+{
+	FAT_BEFORE_LINK_STATE	= 0,
+	FAT_PREPARE_STATE			= 1,
+	FAT_TRAINING_STATE		= 2,
+	FAT_DECISION_STATE		= 3
+};
+
+enum ant_div_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,
+	S0S1_SW_ANTDIV          = 0x06, /*8723B intrnal switch S0 S1*/
+	S0S1_TRX_HW_ANTDIV     = 0x07, /*TRX S0S1 diversity for 8723D*/
+	HL_SW_SMART_ANT_TYPE1	= 0x10, /*Hong-Lin Smart antenna use for 8821AE which is a 2 ant. entitys, and each ant. is equipped with 4 antenna patterns*/
+	HL_SW_SMART_ANT_TYPE2	= 0x11 /*Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/
+};
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+
+void
+odm_stop_antenna_switch_dm(
+	void	*dm_void
+);
+
+void
+phydm_enable_antenna_diversity(
+	void			*dm_void
+);
+
+void
+odm_set_ant_config(
+	void	*dm_void,
+	u8		ant_setting	/* 0=A, 1=B, 2=C, .... */
+);
+
+
+#define sw_ant_div_rest_after_link	odm_sw_ant_div_rest_after_link
+
+void odm_sw_ant_div_rest_after_link(
+	void	*dm_void
+);
+
+void
+odm_ant_div_on_off(
+	void		*dm_void,
+	u8		swch
+);
+
+void
+odm_tx_by_tx_desc_or_reg(
+	void		*dm_void,
+	u8		swch
+);
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+
+void
+phydm_antdiv_reset_statistic(
+	void	*dm_void,
+	u32	macid
+);
+
+void
+odm_update_rx_idle_ant(
+	void		*dm_void,
+	u8		ant
+);
+
+void
+phydm_set_antdiv_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+#if (RTL8723B_SUPPORT == 1)
+void
+odm_update_rx_idle_ant_8723b(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+);
+#endif
+
+#if (RTL8188F_SUPPORT == 1)
+void
+phydm_update_rx_idle_antenna_8188F(
+	void	*dm_void,
+	u32	default_ant
+);
+#endif
+
+#if (RTL8723D_SUPPORT == 1)
+
+void
+phydm_set_tx_ant_pwr_8723d(
+	void			*dm_void,
+	u8			ant
+);
+
+void
+odm_update_rx_idle_ant_8723d(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+);
+
+#endif
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_sw_antdiv_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_sw_antdiv_workitem_callback(
+	void	*context
+);
+
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+odm_sw_antdiv_workitem_callback(
+	void	*context
+);
+
+void
+odm_sw_antdiv_callback(
+	void		*function_context
+);
+
+#endif
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame(
+	void			*dm_void,
+	u8			step
+);
+
+void
+odm_antsel_statistics_of_ctrl_frame(
+	void			*dm_void,
+	u8			antsel_tr_mux,
+	u32			rx_pwdb_all
+);
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
+	void				*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void
+);
+
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+void
+phydm_evm_sw_antdiv_init(
+	void		*dm_void
+);
+
+void
+odm_evm_fast_ant_training_callback(
+	void		*dm_void
+);
+#endif
+
+void
+odm_hw_ant_div(
+	void		*dm_void
+);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+void
+odm_fast_ant_training(
+	void		*dm_void
+);
+
+void
+odm_fast_ant_training_callback(
+	void		*dm_void
+);
+
+void
+odm_fast_ant_training_work_item_callback(
+	void		*dm_void
+);
+#endif
+
+void
+odm_ant_div_init(
+	void		*dm_void
+);
+
+void
+odm_ant_div(
+	void		*dm_void
+);
+
+void
+odm_antsel_statistics(
+	void			*dm_void,
+	void			*phy_info_void,
+	u8			antsel_tr_mux,
+	u32			mac_id,
+	u32			utility,
+	u8			method,
+	u8			is_cck_rate
+);
+
+void
+odm_process_rssi_for_ant_div(
+	void		*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void
+);
+
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+odm_set_tx_ant_by_tx_info(
+	void			*dm_void,
+	u8			*desc,
+	u8			mac_id
+);
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+struct tx_desc; /*declared tx_desc here or compile error happened when enabled 8822B*/
+
+void
+odm_set_tx_ant_by_tx_info(
+	struct	rtl8192cd_priv		*priv,
+	struct	tx_desc			*pdesc,
+	unsigned short			aid
+);
+
+#if 1/*def def CONFIG_WLAN_HAL*/
+void
+odm_set_tx_ant_by_tx_info_hal(
+	struct	rtl8192cd_priv		*priv,
+	void	*pdesc_data,
+	u16		aid
+);
+#endif	/*#ifdef CONFIG_WLAN_HAL*/
+#endif
+
+
+void
+odm_ant_div_config(
+	void		*dm_void
+);
+
+void
+odm_ant_div_timers(
+	void		*dm_void,
+	u8		state
+);
+
+void
+phydm_antdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
+
+void
+odm_ant_div_reset(
+	void		*dm_void
+);
+
+void
+odm_antenna_diversity_init(
+	void		*dm_void
+);
+
+void
+odm_antenna_diversity(
+	void		*dm_void
+);
+
+#endif /*#ifndef	__ODMANTDIV_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_api.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_api.c
new file mode 100644
index 000000000000..9b959b443889
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_api.c
@@ -0,0 +1,1424 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_dynamic_ant_weighting(
+	void		*dm_void
+)
+{
+struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+	#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8197F))
+		phydm_dynamic_ant_weighting_8197f(dm);
+	#endif
+
+	#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8812)) {
+		phydm_dynamic_ant_weighting_8812a(dm);
+	}
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8822B)) {
+		phydm_dynamic_ant_weighting_8822b(dm);
+	}
+	#endif
+#endif
+}
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void
+phydm_dyn_ant_weight_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "echo dis_dym_ant_weighting {0/1}\n");
+
+	} else {
+	
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 1) {
+			dm->is_disable_dym_ant_weighting = 1;
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Disable dyn-ant-weighting\n");
+		} else {
+			dm->is_disable_dym_ant_weighting = 0;
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Enable dyn-ant-weighting\n");
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
+
+void
+phydm_iq_gen_en(
+	void		*dm_void
+)
+{
+#ifdef  PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	i;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		for (i = RF_PATH_A; i <= RF_PATH_B; i++) {
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x1); /*RF mode table write enable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x33, 0xF, 3); /*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3E, 0xfffff, 0x00036); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3F, 0xfffff, 0x5AFCE); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x0); /*RF mode table write disable*/
+		}
+	}
+	#endif
+#endif
+}
+
+void
+phydm_dis_cdd(
+	void		*dm_void
+)
+{
+#ifdef  PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x808, 0x3ffff00, 0);
+		odm_set_bb_reg(dm, 0x9ac, 0x1fff, 0);
+		odm_set_bb_reg(dm, 0x9ac, BIT(13), 1);
+	}
+	#endif
+#endif
+}
+
+void
+phydm_pathb_q_matrix_rotate_en(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		phydm_iq_gen_en(dm);
+
+		#ifdef PHYDM_COMMON_API_SUPPORT
+		if (phydm_api_trx_mode(dm, BB_PATH_AB, BB_PATH_AB, true) == false)
+			return;
+		#endif
+
+		phydm_dis_cdd(dm);
+		odm_set_bb_reg(dm, 0x195c, MASKDWORD, 0x40000);	/*Set Q matrix r_v11 =1*/
+		phydm_pathb_q_matrix_rotate(dm, 0);
+		odm_set_bb_reg(dm, 0x191c, BIT(7), 1);		/*Set Q matrix enable*/
+	}
+	#endif
+#endif
+}
+
+void
+phydm_pathb_q_matrix_rotate(
+	void		*dm_void,
+	u16		phase_idx
+)
+{
+#ifdef  PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32	phase_table_0[12] = {0x40000, 0x376CF, 0x20000, 0x00000, 0xFE0000, 0xFC8930, 
+						0xFC0000, 0xFC8930, 0xFDFFFF, 0x000000, 0x020000, 0x0376CF};
+	u32	phase_table_1[12] = {0x00000, 0x1FFFF, 0x376CF, 0x40000, 0x0376CF, 0x01FFFF, 
+						0x000000, 0xFDFFFF, 0xFC8930, 0xFC0000, 0xFC8930, 0xFDFFFF};
+
+	if (phase_idx >= 12) {
+		PHYDM_DBG(dm, ODM_COMP_API, "Phase Set Error: %d\n", phase_idx);
+		return;
+	}
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x1954, 0xffffff, phase_table_0[phase_idx]); /*Set Q matrix r_v21*/
+		odm_set_bb_reg(dm, 0x1950, 0xffffff, phase_table_1[phase_idx]);
+	}
+	#endif
+#endif
+}
+
+void
+phydm_init_trx_antenna_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	
+	if (dm->support_ic_type & (ODM_RTL8814A)) {
+		u8	rx_ant = 0, tx_ant = 0;
+
+		rx_ant = (u8)odm_get_bb_reg(dm, ODM_REG(BB_RX_PATH, dm), ODM_BIT(BB_RX_PATH, dm));
+		tx_ant = (u8)odm_get_bb_reg(dm, ODM_REG(BB_TX_PATH, dm), ODM_BIT(BB_TX_PATH, dm));
+		dm->tx_ant_status = (tx_ant & 0xf);
+		dm->rx_ant_status = (rx_ant & 0xf);
+	} else if (dm->support_ic_type & (ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B)) {/* JJ ADD 20161014 */
+		dm->tx_ant_status = 0x1;
+		dm->rx_ant_status = 0x1;
+
+	}
+}
+
+void
+phydm_config_ofdm_tx_path(
+	void			*dm_void,
+	u32			path
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if ((RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1))
+	u8	ofdm_tx_path = 0x33;
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+		if (path == BB_PATH_A) {
+			odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x81121111);
+			/**/
+		} else if (path == BB_PATH_B) {
+			odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x82221222);
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x83321333);
+			/**/
+		}
+
+
+	}
+#endif
+
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8812)) {
+		if (path == BB_PATH_A) {
+			ofdm_tx_path = 0x11;
+			/**/
+		} else if (path == BB_PATH_B) {
+			ofdm_tx_path = 0x22;
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			ofdm_tx_path = 0x33;
+			/**/
+		}
+
+		odm_set_bb_reg(dm, 0x80c, 0xff00, ofdm_tx_path);
+	}
+#endif
+}
+
+void
+phydm_config_ofdm_rx_path(
+	void			*dm_void,
+	u32			path
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	ofdm_rx_path = 0;
+
+
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+#if (RTL8192E_SUPPORT == 1)
+		if (path == BB_PATH_A) {
+			ofdm_rx_path = 1;
+			/**/
+		} else if (path == BB_PATH_B) {
+			ofdm_rx_path = 2;
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			ofdm_rx_path = 3;
+			/**/
+		}
+
+		odm_set_bb_reg(dm, 0xC04, 0xff, (((ofdm_rx_path) << 4) | ofdm_rx_path));
+		odm_set_bb_reg(dm, 0xD04, 0xf, ofdm_rx_path);
+#endif
+	}
+#if (RTL8812A_SUPPORT || RTL8822B_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8822B)) {
+		if (path == BB_PATH_A) {
+			ofdm_rx_path = 1;
+			/**/
+		} else if (path == BB_PATH_B) {
+			ofdm_rx_path = 2;
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			ofdm_rx_path = 3;
+			/**/
+		}
+
+		odm_set_bb_reg(dm, 0x808, MASKBYTE0, ((ofdm_rx_path << 4) | ofdm_rx_path));
+	}
+#endif
+}
+
+void
+phydm_config_cck_rx_antenna_init(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	/*CCK 2R CCA parameters*/
+	odm_set_bb_reg(dm, 0xa00, BIT(15), 0x0); /*Disable antenna diversity*/
+	odm_set_bb_reg(dm, 0xa70, BIT(7), 0); /*Concurrent CCA at LSB & USB*/
+	odm_set_bb_reg(dm, 0xa74, BIT(8), 0); /*RX path diversity enable*/
+	odm_set_bb_reg(dm, 0xa14, BIT(7), 0); /*r_en_mrc_antsel*/
+	odm_set_bb_reg(dm, 0xa20, (BIT(5) | BIT(4)), 1); /*MBC weighting*/
+
+	if (dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F)) {
+		odm_set_bb_reg(dm, 0xa08, BIT(28), 1); /*r_cck_2nd_sel_eco*/
+		/**/
+	} else if (dm->support_ic_type & ODM_RTL8814A) {
+		odm_set_bb_reg(dm, 0xa84, BIT(28), 1); /*2R CCA only*/
+		/**/
+	}
+#endif
+}
+
+void
+phydm_config_cck_rx_path(
+	void		*dm_void,
+	enum bb_path			path
+)
+{
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	path_div_select = 0;
+	u8	cck_path[2] = {0};
+	u8	en_2R_path = 0;
+	u8	en_2R_mrc = 0;
+	u8	i = 0, j =0; 
+	u8	num_enable_path = 0;
+	u8	cck_mrc_max_path = 2;
+	
+	for (i = 0; i < 4; i++) {
+		if (path & BIT(i)) { /*ex: PHYDM_ABCD*/
+			num_enable_path++;
+			cck_path[j] = i;
+			j++;
+		}
+		if (num_enable_path >= cck_mrc_max_path)
+			break;
+	}
+
+	if (num_enable_path > 1) {
+		path_div_select = 1;
+		en_2R_path = 1;
+		en_2R_mrc = 1;
+	} else {
+		path_div_select = 0;
+		en_2R_path = 0;
+		en_2R_mrc = 0;
+	}
+		
+	odm_set_bb_reg(dm, 0xa04, (BIT(27) | BIT(26)), cck_path[0]);	/*CCK_1 input signal path*/
+	odm_set_bb_reg(dm, 0xa04, (BIT(25) | BIT(24)), cck_path[1]);	/*CCK_2 input signal path*/
+	odm_set_bb_reg(dm, 0xa74, BIT(8), path_div_select);	/*enable Rx path diversity*/
+	odm_set_bb_reg(dm, 0xa2c, BIT(18), en_2R_path);	/*enable 2R Rx path*/
+	odm_set_bb_reg(dm, 0xa2c, BIT(22), en_2R_mrc);	/*enable 2R MRC*/
+	
+#endif
+}
+
+void
+phydm_config_cck_tx_path(
+	void		*dm_void,
+	enum	bb_path	path
+)
+{
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (path == BB_PATH_A)
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0x8);
+	else if (path == BB_PATH_B)
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0x4);
+	else if (path == BB_PATH_AB)
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0xc);
+#endif
+}
+
+void
+phydm_config_trx_path(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/*
+	dm_value[0]: 0:CCK, 1:OFDM
+	dm_value[1]: 1:TX, 2:RX
+	dm_value[2]: 1:path_A, 2:path_B, 3:path_AB
+	*/
+	
+	/* CCK */
+	if (dm_value[0] == 0) {
+		if (dm_value[1] == 1) { /*TX*/
+			if (dm_value[2] == 1)
+				phydm_config_cck_tx_path(dm, BB_PATH_A);
+			else if (dm_value[2] == 2)
+				phydm_config_cck_tx_path(dm, BB_PATH_B);
+			else if (dm_value[2] == 3)
+				phydm_config_cck_tx_path(dm, BB_PATH_AB);
+		} else if (dm_value[1] == 2) { /*RX*/
+
+			phydm_config_cck_rx_antenna_init(dm);
+
+			if (dm_value[2] == 1)
+				phydm_config_cck_rx_path(dm, BB_PATH_A);
+			else  if (dm_value[2] == 2)
+				phydm_config_cck_rx_path(dm, BB_PATH_B);
+			else  if (dm_value[2] == 3) {
+				phydm_config_cck_rx_path(dm, BB_PATH_AB);
+			}
+		}
+	}
+	/* OFDM */
+	else if (dm_value[0] == 1) {
+		if (dm_value[1] == 1) { /*TX*/
+			phydm_config_ofdm_tx_path(dm, dm_value[2]);
+			/**/
+		} else if (dm_value[1] == 2) { /*RX*/
+			phydm_config_ofdm_rx_path(dm, dm_value[2]);
+			/**/
+		}
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"PHYDM Set path [%s] [%s] = [%s%s%s%s]\n",
+			(dm_value[0] == 1) ? "OFDM" : "CCK",
+			(dm_value[1] == 1) ? "TX" : "RX",
+			(dm_value[2] & 0x1) ? "A" : "",
+			(dm_value[2] & 0x2) ? "B" : "",
+			(dm_value[2] & 0x4) ? "C" : "",
+			(dm_value[2] & 0x8) ? "D" : ""
+			);
+
+}
+
+void
+phydm_tx_2path(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
+		phydm_api_trx_mode(dm, BB_PATH_AB, (enum bb_path)dm->rx_ant_status, true);
+	}
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) {
+		phydm_config_cck_tx_path(dm, BB_PATH_AB);
+		phydm_config_ofdm_tx_path(dm, BB_PATH_AB);
+	}
+#endif
+}
+
+void
+phydm_stop_3_wire(
+	void		*dm_void,
+	u8		set_type
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (set_type == PHYDM_SET) {
+		/*[Stop 3-wires]*/
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, 0xc00, 0xf, 0x4);/*	hardware 3-wire off */
+			odm_set_bb_reg(dm, 0xe00, 0xf, 0x4);/*	hardware 3-wire off */
+		} else {
+			odm_set_bb_reg(dm, 0x88c, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+		}
+		
+	} else {  /*if (set_type == PHYDM_REVERT)*/
+		
+		/*[Start 3-wires]*/
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, 0xc00, 0xf, 0x7);/*	hardware 3-wire on */
+			odm_set_bb_reg(dm, 0xe00, 0xf, 0x7);/*	hardware 3-wire on */
+		} else {
+			odm_set_bb_reg(dm, 0x88c, 0xf00000, 0x0);	/* 3 wire enable 88c[23:20]=0x0 */
+		}
+	}
+}
+
+u8
+phydm_stop_ic_trx(
+	void		*dm_void,
+	u8		set_type
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	phydm_api_stuc 	*api = &dm->api_table;
+	u32		i;
+	u8		trx_idle_success = false;
+	u32		dbg_port_value = 0;
+
+	if (set_type == PHYDM_SET) {
+		/*[Stop TRX]---------------------------------------------------------------------*/
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, 0x0) == false) /*set debug port to 0x0*/
+			return PHYDM_SET_FAIL;
+		
+		for (i = 0; i<10000; i++) {
+			dbg_port_value = phydm_get_bb_dbg_port_value(dm);
+			if ((dbg_port_value & (BIT(17) | BIT(3))) == 0)	/* PHYTXON && CCA_all */ {
+				PHYDM_DBG(dm, ODM_COMP_API, "PSD wait for ((%d)) times\n", i);
+				
+				trx_idle_success = true;
+				break;
+			}
+		}
+		phydm_release_bb_dbg_port(dm);
+		
+		if (trx_idle_success) {
+			api->tx_queue_bitmap = (u8)odm_get_bb_reg(dm, 0x520, 0xff0000);
+			
+			odm_set_bb_reg(dm, 0x520, 0xff0000, 0xff); /*pause all TX queue*/
+			
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				odm_set_bb_reg(dm, 0x808, BIT(28), 0); /*disable CCK block*/
+				odm_set_bb_reg(dm, 0x838, BIT(1), 1); /*disable OFDM RX CCA*/
+			} else {
+				/*TBD*/
+				odm_set_bb_reg(dm, 0x800, BIT(24), 0); /* disable whole CCK block */
+
+
+				api->rx_iqc_reg_1 = odm_get_bb_reg(dm, 0xc14, MASKDWORD);
+				api->rx_iqc_reg_2 = odm_get_bb_reg(dm, 0xc1c, MASKDWORD);
+				
+				odm_set_bb_reg(dm, 0xc14, MASKDWORD, 0x0); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
+				odm_set_bb_reg(dm, 0xc1c, MASKDWORD, 0x0);
+			}
+				
+		} else {
+			return PHYDM_SET_FAIL;
+		}
+		
+		return PHYDM_SET_SUCCESS;
+		
+	} else {  /*if (set_type == PHYDM_REVERT)*/
+
+		odm_set_bb_reg(dm, 0x520, 0xff0000, (u32)(api->tx_queue_bitmap)); /*Release all TX queue*/
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, 0x808, BIT(28), 1); /*enable CCK block*/
+			odm_set_bb_reg(dm, 0x838, BIT(1), 0); /*enable OFDM RX CCA*/
+		} else {
+			/*TBD*/
+			odm_set_bb_reg(dm, 0x800, BIT(24), 1); /* enable whole CCK block */
+			
+			odm_set_bb_reg(dm, 0xc14, MASKDWORD, api->rx_iqc_reg_1); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
+			odm_set_bb_reg(dm, 0xc1c, MASKDWORD, api->rx_iqc_reg_2);
+		}
+
+		return PHYDM_SET_SUCCESS;
+	}
+	
+}
+
+void
+phydm_set_ext_switch(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			ext_ant_switch =  dm_value[0];
+
+#if (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
+		/*Output Pin Settings*/
+		odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /*select DPDT_P and DPDT_N as output pin*/
+		odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /*by WLAN control*/
+
+		odm_set_bb_reg(dm, 0xCB4, 0xFF, 77); /*DPDT_N = 1b'0*/  /*DPDT_P = 1b'0*/
+
+		if (ext_ant_switch == MAIN_ANT) {
+			odm_set_bb_reg(dm, 0xCB4, (BIT(29) | BIT(28)), 1);
+			PHYDM_DBG(dm, ODM_COMP_API, "***8821A set ant switch = 2b'01 (Main)\n");
+		} else if (ext_ant_switch == AUX_ANT) {
+			odm_set_bb_reg(dm, 0xCB4, BIT(29) | BIT(28), 2);
+			PHYDM_DBG(dm, ODM_COMP_API, "***8821A set ant switch = 2b'10 (Aux)\n");
+		}
+	}
+#endif
+}
+
+void
+phydm_csi_mask_enable(
+	void		*dm_void,
+	u32		enable
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = 0;
+
+	reg_value = (enable == FUNC_ENABLE) ? 1 : 0;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xD2C, BIT(28), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable CSI Mask:  Reg 0xD2C[28] = ((0x%x))\n", reg_value);
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x874, BIT(0), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable CSI Mask:  Reg 0x874[0] = ((0x%x))\n", reg_value);
+	}
+
+}
+
+void
+phydm_clean_all_csi_mask(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xD40, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0xD44, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0xD48, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0xD4c, MASKDWORD, 0);
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x880, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x884, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x888, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x88c, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x890, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x894, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x898, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x89c, MASKDWORD, 0);
+	}
+}
+
+void
+phydm_set_csi_mask_reg(
+	void		*dm_void,
+	u32		tone_idx_tmp,
+	u8		tone_direction
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		byte_offset, bit_offset;
+	u32		target_reg;
+	u8		reg_tmp_value;
+	u32		tone_num = 64;
+	u32		tone_num_shift = 0;
+	u32		csi_mask_reg_p = 0, csi_mask_reg_n = 0;
+
+	/* calculate real tone idx*/
+	if ((tone_idx_tmp % 10) >= 5)
+		tone_idx_tmp += 10;
+
+	tone_idx_tmp = (tone_idx_tmp / 10);
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		tone_num = 64;
+		csi_mask_reg_p = 0xD40;
+		csi_mask_reg_n = 0xD48;
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		tone_num = 128;
+		csi_mask_reg_p = 0x880;
+		csi_mask_reg_n = 0x890;
+	}
+
+	if (tone_direction == FREQ_POSITIVE) {
+		if (tone_idx_tmp >= (tone_num - 1))
+			tone_idx_tmp = (tone_num - 1);
+
+		byte_offset = (u8)(tone_idx_tmp >> 3);
+		bit_offset = (u8)(tone_idx_tmp & 0x7);
+		target_reg = csi_mask_reg_p + byte_offset;
+
+	} else {
+		tone_num_shift = tone_num;
+
+		if (tone_idx_tmp >= tone_num)
+			tone_idx_tmp = tone_num;
+
+		tone_idx_tmp = tone_num - tone_idx_tmp;
+
+		byte_offset = (u8)(tone_idx_tmp >> 3);
+		bit_offset = (u8)(tone_idx_tmp & 0x7);
+		target_reg = csi_mask_reg_n + byte_offset;
+	}
+
+	reg_tmp_value = odm_read_1byte(dm, target_reg);
+	PHYDM_DBG(dm, ODM_COMP_API, "Pre Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n", (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value);
+	reg_tmp_value |= BIT(bit_offset);
+	odm_write_1byte(dm, target_reg, reg_tmp_value);
+	PHYDM_DBG(dm, ODM_COMP_API, "New Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n", (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value);
+}
+
+void
+phydm_set_nbi_reg(
+	void		*dm_void,
+	u32		tone_idx_tmp,
+	u32		bw
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32	nbi_table_128[NBI_TABLE_SIZE_128] = {25, 55, 85, 115, 135, 155, 185, 205, 225, 245,		/*1~10*/		/*tone_idx X 10*/
+		     265, 285, 305, 335, 355, 375, 395, 415, 435, 455,	/*11~20*/
+					     485, 505, 525, 555, 585, 615, 635
+						};				/*21~27*/
+
+	u32	nbi_table_256[NBI_TABLE_SIZE_256] = { 25,   55,   85, 115, 135, 155, 175, 195, 225, 245,	/*1~10*/
+		265, 285, 305, 325, 345, 365, 385, 405, 425, 445,	/*11~20*/
+		465, 485, 505, 525, 545, 565, 585, 605, 625, 645,	/*21~30*/
+		665, 695, 715, 735, 755, 775, 795, 815, 835, 855,	/*31~40*/
+		875, 895, 915, 935, 955, 975, 995, 1015, 1035, 1055,	/*41~50*/
+		      1085, 1105, 1125, 1145, 1175, 1195, 1225, 1255, 1275
+						};	/*51~59*/
+
+	u32	reg_idx = 0;
+	u32	i;
+	u8	nbi_table_idx = FFT_128_TYPE;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+
+		nbi_table_idx = FFT_128_TYPE;
+	else if (dm->support_ic_type & ODM_IC_11AC_1_SERIES)
+
+		nbi_table_idx = FFT_256_TYPE;
+	else if (dm->support_ic_type & ODM_IC_11AC_2_SERIES) {
+		if (bw == 80)
+			nbi_table_idx = FFT_256_TYPE;
+		else /*20M, 40M*/
+			nbi_table_idx = FFT_128_TYPE;
+	}
+
+	if (nbi_table_idx == FFT_128_TYPE) {
+		for (i = 0; i < NBI_TABLE_SIZE_128; i++) {
+			if (tone_idx_tmp < nbi_table_128[i]) {
+				reg_idx = i + 1;
+				break;
+			}
+		}
+
+	} else if (nbi_table_idx == FFT_256_TYPE) {
+		for (i = 0; i < NBI_TABLE_SIZE_256; i++) {
+			if (tone_idx_tmp < nbi_table_256[i]) {
+				reg_idx = i + 1;
+				break;
+			}
+		}
+	}
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xc40, 0x1f000000, reg_idx);
+		PHYDM_DBG(dm, ODM_COMP_API, "Set tone idx:  Reg0xC40[28:24] = ((0x%x))\n", reg_idx);
+		/**/
+	} else {
+		odm_set_bb_reg(dm, 0x87c, 0xfc000, reg_idx);
+		PHYDM_DBG(dm, ODM_COMP_API, "Set tone idx: Reg0x87C[19:14] = ((0x%x))\n", reg_idx);
+		/**/
+	}
+}
+
+
+void
+phydm_nbi_enable(
+	void		*dm_void,
+	u32		enable
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = 0;
+
+	reg_value = (enable == FUNC_ENABLE) ? 1 : 0;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xc40, BIT(9), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable NBI Reg0xC40[9] = ((0x%x))\n", reg_value);
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (dm->support_ic_type & (ODM_RTL8822B|ODM_RTL8821C)) {
+			odm_set_bb_reg(dm, 0x87c, BIT(13), reg_value);
+			odm_set_bb_reg(dm, 0xc20, BIT(28), reg_value);
+			if (dm->rf_type > RF_1T1R)
+				odm_set_bb_reg(dm, 0xe20, BIT(28), reg_value);
+		} else
+			odm_set_bb_reg(dm, 0x87c, BIT(13), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable NBI Reg0x87C[13] = ((0x%x))\n", reg_value);
+	}
+}
+
+u8
+phydm_calculate_fc(
+	void		*dm_void,
+	u32		channel,
+	u32		bw,
+	u32		second_ch,
+	u32		*fc_in
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		fc = *fc_in;
+	u32		start_ch_per_40m[NUM_START_CH_40M] = {36, 44, 52, 60, 100, 108, 116, 124, 132, 140, 149, 157, 165, 173};
+	u32		start_ch_per_80m[NUM_START_CH_80M] = {36, 52, 100, 116, 132, 149, 165};
+	u32		*start_ch = &start_ch_per_40m[0];
+	u32		num_start_channel = NUM_START_CH_40M;
+	u32		channel_offset = 0;
+	u32		i;
+
+	/*2.4G*/
+	if (channel <= 14 && channel > 0) {
+		if (bw == 80)
+			return	PHYDM_SET_FAIL;
+
+		fc = 2412 + (channel - 1) * 5;
+
+		if (bw == 40 && (second_ch == PHYDM_ABOVE)) {
+			if (channel >= 10) {
+				PHYDM_DBG(dm, ODM_COMP_API, "CH = ((%d)), Scnd_CH = ((%d)) Error setting\n", channel, second_ch);
+				return	PHYDM_SET_FAIL;
+			}
+			fc += 10;
+		} else if (bw == 40 && (second_ch == PHYDM_BELOW)) {
+			if (channel <= 2) {
+				PHYDM_DBG(dm, ODM_COMP_API, "CH = ((%d)), Scnd_CH = ((%d)) Error setting\n", channel, second_ch);
+				return	PHYDM_SET_FAIL;
+			}
+			fc -= 10;
+		}
+	}
+	/*5G*/
+	else if (channel >= 36 && channel <= 177) {
+		if (bw != 20) {
+			if (bw == 40) {
+				num_start_channel = NUM_START_CH_40M;
+				start_ch = &start_ch_per_40m[0];
+				channel_offset = CH_OFFSET_40M;
+			} else if (bw == 80) {
+				num_start_channel = NUM_START_CH_80M;
+				start_ch = &start_ch_per_80m[0];
+				channel_offset = CH_OFFSET_80M;
+			}
+
+			for (i = 0; i < (num_start_channel - 1); i++) {
+				if (channel < start_ch[i + 1]) {
+					channel = start_ch[i] + channel_offset;
+					break;
+				}
+			}
+			PHYDM_DBG(dm, ODM_COMP_API, "Mod_CH = ((%d))\n", channel);
+		}
+
+		fc = 5180 + (channel - 36) * 5;
+
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "CH = ((%d)) Error setting\n", channel);
+		return	PHYDM_SET_FAIL;
+	}
+
+	*fc_in = fc;
+
+	return PHYDM_SET_SUCCESS;
+}
+
+
+u8
+phydm_calculate_intf_distance(
+	void		*dm_void,
+	u32		bw,
+	u32		fc,
+	u32		f_interference,
+	u32		*tone_idx_tmp_in
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		bw_up, bw_low;
+	u32		int_distance;
+	u32		tone_idx_tmp;
+	u8		set_result = PHYDM_SET_NO_NEED;
+
+	bw_up = fc + bw / 2;
+	bw_low = fc - bw / 2;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "[f_l, fc, fh] = [ %d, %d, %d ], f_int = ((%d))\n", bw_low, fc, bw_up, f_interference);
+
+	if ((f_interference >= bw_low) && (f_interference <= bw_up)) {
+		int_distance = (fc >= f_interference) ? (fc - f_interference) : (f_interference - fc);
+		tone_idx_tmp = (int_distance << 5); /* =10*(int_distance /0.3125) */
+		PHYDM_DBG(dm, ODM_COMP_API, "int_distance = ((%d MHz)) Mhz, tone_idx_tmp = ((%d.%d))\n", int_distance, (tone_idx_tmp / 10), (tone_idx_tmp % 10));
+		*tone_idx_tmp_in = tone_idx_tmp;
+		set_result = PHYDM_SET_SUCCESS;
+	}
+
+	return	set_result;
+
+}
+
+
+u8
+phydm_csi_mask_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		second_ch
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		fc = 2412;
+	u8		tone_direction;
+	u32		tone_idx_tmp;
+	u8		set_result = PHYDM_SET_SUCCESS;
+
+	if (enable == FUNC_DISABLE) {
+		set_result = PHYDM_SET_SUCCESS;
+		phydm_clean_all_csi_mask(dm);
+
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Set CSI MASK_] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			channel, bw, f_interference, (((bw == 20) || (channel > 14)) ? "Don't care" : (second_ch == PHYDM_ABOVE) ? "H" : "L"));
+
+		/*calculate fc*/
+		if (phydm_calculate_fc(dm, channel, bw, second_ch, &fc) == PHYDM_SET_FAIL)
+			set_result = PHYDM_SET_FAIL;
+
+		else {
+			/*calculate interference distance*/
+			if (phydm_calculate_intf_distance(dm, bw, fc, f_interference, &tone_idx_tmp) == PHYDM_SET_SUCCESS) {
+				tone_direction = (f_interference >= fc) ? FREQ_POSITIVE : FREQ_NEGATIVE;
+				phydm_set_csi_mask_reg(dm, tone_idx_tmp, tone_direction);
+				set_result = PHYDM_SET_SUCCESS;
+			} else
+				set_result = PHYDM_SET_NO_NEED;
+		}
+	}
+
+	if (set_result == PHYDM_SET_SUCCESS)
+		phydm_csi_mask_enable(dm, enable);
+	else
+		phydm_csi_mask_enable(dm, FUNC_DISABLE);
+
+	return	set_result;
+}
+
+u8
+phydm_nbi_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		second_ch
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		fc = 2412;
+	u32		tone_idx_tmp;
+	u8		set_result = PHYDM_SET_SUCCESS;
+
+	if (enable == FUNC_DISABLE)
+		set_result = PHYDM_SET_SUCCESS;
+
+	else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Set NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			channel, bw, f_interference, (((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "Don't care" : (second_ch == PHYDM_ABOVE) ? "H" : "L"));
+
+		/*calculate fc*/
+		if (phydm_calculate_fc(dm, channel, bw, second_ch, &fc) == PHYDM_SET_FAIL)
+			set_result = PHYDM_SET_FAIL;
+
+		else {
+			/*calculate interference distance*/
+			if (phydm_calculate_intf_distance(dm, bw, fc, f_interference, &tone_idx_tmp) == PHYDM_SET_SUCCESS) {
+				phydm_set_nbi_reg(dm, tone_idx_tmp, bw);
+				set_result = PHYDM_SET_SUCCESS;
+			} else
+				set_result = PHYDM_SET_NO_NEED;
+		}
+	}
+
+	if (set_result == PHYDM_SET_SUCCESS)
+		phydm_nbi_enable(dm, enable);
+	else
+		phydm_nbi_enable(dm, FUNC_DISABLE);
+
+	return	set_result;
+}
+
+void
+phydm_api_debug(
+	void		*dm_void,
+	u32		function_map,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			channel =  dm_value[1];
+	u32			bw =  dm_value[2];
+	u32			f_interference =  dm_value[3];
+	u32			second_ch =  dm_value[4];
+	u8			set_result = 0;
+
+	/*PHYDM_API_NBI*/
+	/*-------------------------------------------------------------------------------------------------------------------------------*/
+	if (function_map == PHYDM_API_NBI) {
+		if (dm_value[0] == 100) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[HELP-NBI]  EN(on=1, off=2)   CH   BW(20/40/80)  f_intf(Mhz)    Scnd_CH(L=1, H=2)\n");
+			return;
+
+		} else if (dm_value[0] == FUNC_ENABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Enable NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+				       channel, bw, f_interference,
+				       ((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "Don't care" : ((second_ch == PHYDM_ABOVE) ? "H" : "L"));
+			set_result = phydm_nbi_setting(dm, FUNC_ENABLE, channel, bw, f_interference, second_ch);
+
+		} else if (dm_value[0] == FUNC_DISABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "[Disable NBI]\n");
+			set_result = phydm_nbi_setting(dm, FUNC_DISABLE, channel, bw, f_interference, second_ch);
+
+		} else
+
+			set_result = PHYDM_SET_FAIL;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[NBI set result: %s]\n",
+			       (set_result == PHYDM_SET_SUCCESS) ? "Success" : ((set_result == PHYDM_SET_NO_NEED) ? "No need" : "Error"));
+
+	}
+
+	/*PHYDM_CSI_MASK*/
+	/*-------------------------------------------------------------------------------------------------------------------------------*/
+	else if (function_map == PHYDM_API_CSI_MASK) {
+		if (dm_value[0] == 100) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[HELP-CSI MASK]  EN(on=1, off=2)   CH   BW(20/40/80)  f_intf(Mhz)    Scnd_CH(L=1, H=2)\n");
+			return;
+
+		} else if (dm_value[0] == FUNC_ENABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Enable CSI MASK] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+				       channel, bw, f_interference,
+				       (channel > 14) ? "Don't care" : (((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "H" : "L"));
+			set_result = phydm_csi_mask_setting(dm,	FUNC_ENABLE, channel, bw, f_interference, second_ch);
+
+		} else if (dm_value[0] == FUNC_DISABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "[Disable CSI MASK]\n");
+			set_result = phydm_csi_mask_setting(dm, FUNC_DISABLE, channel, bw, f_interference, second_ch);
+
+		} else
+
+			set_result = PHYDM_SET_FAIL;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[CSI MASK set result: %s]\n",
+			       (set_result == PHYDM_SET_SUCCESS) ? "Success" : ((set_result == PHYDM_SET_NO_NEED) ? "No need" : "Error"));
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_stop_ck320(
+	void			*dm_void,
+	u8			enable
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = enable ? 1 : 0;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x8b4, BIT(6), reg_value);
+		/**/
+	} else { 
+
+		if (dm->support_ic_type & ODM_IC_N_2SS) {	/*N-2SS*/
+			odm_set_bb_reg(dm, 0x87c, BIT(29), reg_value);
+			/**/
+		} else {	/*N-1SS*/
+			odm_set_bb_reg(dm, 0x87c, BIT(31), reg_value);
+			/**/
+		}
+	}
+}
+
+boolean
+phydm_set_bb_txagc_offset(
+	void			*dm_void,
+	s8			power_offset, 	/*(unit: dB)*/
+	u8			add_half_db		/*(+0.5 dB)*/
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	s8		power_idx = power_offset * 2;
+	boolean		set_success = false;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "power_offset=%d, add_half_db =%d\n", power_offset, add_half_db);
+
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (power_offset > -16 || power_offset < 15) {
+			if (add_half_db)
+				power_idx += 1;
+
+			power_idx &= 0x3f;
+
+			PHYDM_DBG(dm, ODM_COMP_API, "Reg_idx =0x%x\n", power_idx);
+			odm_set_bb_reg(dm, 0x8b4, 0x3f, power_idx);
+			set_success = true;
+		} else {
+			pr_debug("[Warning] TX AGC Offset Setting error!");
+		}
+	}
+	#endif
+	
+	#if	ODM_IC_11N_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (power_offset > -8 || power_offset < 7) {
+			if (add_half_db)
+				power_idx += 1;
+
+			power_idx &= 0x1f;
+			
+			PHYDM_DBG(dm, ODM_COMP_API, "Reg_idx =0x%x\n", power_idx);
+			odm_set_bb_reg(dm, 0x80c, 0x1f00, power_idx);
+			odm_set_bb_reg(dm, 0x80c, 0x3e000, power_idx);
+			set_success = true;
+		} else {
+			pr_debug("[Warning] TX AGC Offset Setting error!");
+		}
+	}
+	#endif
+	
+	return	set_success;
+}
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+boolean
+phydm_api_set_txagc(
+	void				*dm_void,
+	u32				power_index,
+	enum rf_path		path,
+	u8				hw_rate,
+	boolean			is_single_rate
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	boolean		ret = false;
+	u8	i;
+
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+		if (is_single_rate) {
+			
+			#if (RTL8822B_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8822B)
+				ret = phydm_write_txagc_1byte_8822b(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (RTL8821C_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8821C)
+				ret = phydm_write_txagc_1byte_8821c(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+			set_current_tx_agc(dm->priv, path, hw_rate, (u8)power_index);
+			#endif
+
+		} else {
+			#if (RTL8822B_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8822B)
+				ret = config_phydm_write_txagc_8822b(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (RTL8821C_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8821C)
+				ret = config_phydm_write_txagc_8821c(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+			for (i = 0; i < 4; i++)
+				set_current_tx_agc(dm->priv, path, (hw_rate + i), (u8)power_index);
+			#endif
+		}
+	}
+#endif
+
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_write_txagc_8197f(dm, power_index, path, hw_rate);
+#endif
+
+	return ret;
+}
+
+u8
+phydm_api_get_txagc(
+	void				*dm_void,
+	enum rf_path		path,
+	u8				hw_rate
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	ret = 0;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_read_txagc_8822b(dm, path, hw_rate);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_read_txagc_8197f(dm, path, hw_rate);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C)
+		ret = config_phydm_read_txagc_8821c(dm, path, hw_rate);
+#endif
+
+	return ret;
+}
+
+
+boolean
+phydm_api_switch_bw_channel(
+	void					*dm_void,
+	u8					central_ch,
+	u8					primary_ch_idx,
+	enum channel_width	bandwidth
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;	
+	boolean		ret = false;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_switch_channel_bw_8822b(dm, central_ch, primary_ch_idx, bandwidth);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_switch_channel_bw_8197f(dm, central_ch, primary_ch_idx, bandwidth);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C)
+		ret = config_phydm_switch_channel_bw_8821c(dm, central_ch, primary_ch_idx, bandwidth);
+#endif
+
+	return ret;
+}
+
+boolean
+phydm_api_trx_mode(
+	void				*dm_void,
+	enum bb_path	tx_path,
+	enum bb_path	rx_path,
+	boolean			is_tx2_path
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	boolean		ret = false;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_trx_mode_8822b(dm, tx_path, rx_path, is_tx2_path);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_trx_mode_8197f(dm, tx_path, rx_path, is_tx2_path);
+#endif
+
+	return ret;
+}
+#endif
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_normal_driver_rx_sniffer(
+	struct dm_struct			*dm,
+	u8				*desc,
+	PRT_RFD_STATUS		rt_rfd_status,
+	u8				*drv_info,
+	u8				phy_status
+)
+{
+#if (defined(CONFIG_PHYDM_RX_SNIFFER_PARSING))
+	u32		*msg;
+	u16		seq_num;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	if (rt_rfd_status->packet_report_type != NORMAL_RX)
+		return;
+
+	if (!dm->is_linked) {
+		if (rt_rfd_status->is_hw_error)
+			return;
+	}
+
+	if (!(fat_tab->fat_state == FAT_TRAINING_STATE))
+		return;
+
+	if (phy_status == true) {
+		if ((dm->rx_pkt_type == type_block_ack) || (dm->rx_pkt_type == type_rts) || (dm->rx_pkt_type == type_cts))
+			seq_num = 0;
+		else
+			seq_num = rt_rfd_status->seq_num;
+
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, "%04d , %01s, rate=0x%02x, L=%04d , %s , %s",
+				seq_num,
+				/*rt_rfd_status->mac_id,*/
+			((rt_rfd_status->is_crc) ? "C" : (rt_rfd_status->is_ampdu) ? "A" : "_"),
+				rt_rfd_status->data_rate,
+				rt_rfd_status->length,
+			((rt_rfd_status->band_width == 0) ? "20M" : ((rt_rfd_status->band_width == 1) ? "40M" : "80M")),
+				((rt_rfd_status->is_ldpc) ? "LDP" : "BCC"));
+
+		if (dm->rx_pkt_type == type_asoc_req) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "AS_REQ");
+			/**/
+		} else if (dm->rx_pkt_type == type_asoc_rsp) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "AS_RSP");
+			/**/
+		} else if (dm->rx_pkt_type == type_probe_req) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "PR_REQ");
+			/**/
+		} else if (dm->rx_pkt_type == type_probe_rsp) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "PR_RSP");
+			/**/
+		} else if (dm->rx_pkt_type == type_deauth) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "DEAUTH");
+			/**/
+		} else if (dm->rx_pkt_type == type_beacon) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "BEACON");
+			/**/
+		} else if (dm->rx_pkt_type == type_block_ack_req) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "BA_REQ");
+			/**/
+		} else if (dm->rx_pkt_type == type_rts) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__RTS_");
+			/**/
+		} else if (dm->rx_pkt_type == type_cts) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__CTS_");
+			/**/
+		} else if (dm->rx_pkt_type == type_ack) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__ACK_");
+			/**/
+		} else if (dm->rx_pkt_type == type_block_ack) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__BA__");
+			/**/
+		} else if (dm->rx_pkt_type == type_data) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "_DATA_");
+			/**/
+		} else if (dm->rx_pkt_type == type_data_ack) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "Data_Ack");
+			/**/
+		} else if (dm->rx_pkt_type == type_qos_data) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "QoS_Data");
+			/**/
+		} else {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [0x%x]", dm->rx_pkt_type);
+			/**/
+		}
+
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [RSSI=%d,%d,%d,%d ]",
+				dm->rssi_a,
+				dm->rssi_b,
+				dm->rssi_c,
+				dm->rssi_d);
+
+		msg = (u32 *)drv_info;
+
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , P-STS[28:0]=%08x-%08x-%08x-%08x-%08x-%08x-%08x\n",
+			msg[6], msg[5], msg[4], msg[3], msg[2], msg[1], msg[1]);
+	} else {
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, "%04d , %01s, rate=0x%02x, L=%04d , %s , %s\n",
+				rt_rfd_status->seq_num,
+				/*rt_rfd_status->mac_id,*/
+			((rt_rfd_status->is_crc) ? "C" : (rt_rfd_status->is_ampdu) ? "A" : "_"),
+				rt_rfd_status->data_rate,
+				rt_rfd_status->length,
+			((rt_rfd_status->band_width == 0) ? "20M" : ((rt_rfd_status->band_width == 1) ? "40M" : "80M")),
+				((rt_rfd_status->is_ldpc) ? "LDP" : "BCC"));
+	}
+
+
+#endif
+}
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_api.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_api.h
new file mode 100644
index 000000000000..69ac53358dcf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_api.h
@@ -0,0 +1,250 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_API_H__
+#define    __PHYDM_API_H__
+
+#define PHYDM_API_VERSION	"1.0"		/* 2017.07.10  Dino, Add phydm_api.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+#define	FUNC_ENABLE 1
+#define	FUNC_DISABLE 2
+
+/*NBI API------------------------------------*/
+#define	NBI_TABLE_SIZE_128	27
+#define	NBI_TABLE_SIZE_256	59
+
+#define	NUM_START_CH_80M	7
+#define	NUM_START_CH_40M	14
+
+#define	CH_OFFSET_40M		2
+#define	CH_OFFSET_80M		6
+
+#define	FFT_128_TYPE	1
+#define	FFT_256_TYPE	2
+
+#define	FREQ_POSITIVE	1
+#define	FREQ_NEGATIVE	2
+/*------------------------------------------------*/
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+struct phydm_api_stuc {
+	u32	rx_iqc_reg_1;	/*N-mode: for pathA REG0xc14*/
+	u32	rx_iqc_reg_2;	/*N-mode: for pathB REG0xc1c*/
+	u8	tx_queue_bitmap;/*REG0x520[23:16]*/
+
+};
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_dynamic_ant_weighting(
+	void		*dm_void
+);
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void
+phydm_dyn_ant_weight_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+#endif
+
+void
+phydm_pathb_q_matrix_rotate_en(
+	void		*dm_void
+);
+
+void
+phydm_pathb_q_matrix_rotate(
+	void		*dm_void,
+	u16		phase_idx
+);
+
+void
+phydm_init_trx_antenna_setting(
+	void		*dm_void
+);
+
+void
+phydm_config_ofdm_rx_path(
+	void		*dm_void,
+	u32		path
+);
+
+void
+phydm_config_cck_rx_path(
+	void		*dm_void,
+	enum bb_path	path
+);
+
+void
+phydm_config_cck_rx_antenna_init(
+	void		*dm_void
+);
+
+void
+phydm_config_trx_path(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_tx_2path(
+	void		*dm_void
+);
+
+void
+phydm_stop_3_wire(
+	void		*dm_void,
+	u8		set_type
+);
+
+u8
+phydm_stop_ic_trx(
+	void		*dm_void,
+	u8		set_type
+);
+
+void
+phydm_set_ext_switch(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_nbi_enable(
+	void		*dm_void,
+	u32		enable
+);
+
+u8
+phydm_csi_mask_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		Second_ch
+);
+
+u8
+phydm_nbi_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		second_ch
+);
+
+
+void
+phydm_api_debug(
+	void		*dm_void,
+	u32		function_map,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_stop_ck320(
+	void			*dm_void,
+	u8			enable
+);
+
+boolean
+phydm_set_bb_txagc_offset(
+	void			*dm_void,
+	s8			power_offset,
+	u8			add_half_db
+);
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+
+boolean
+phydm_api_set_txagc(
+	void				*dm_void,
+	u32				power_index,
+	enum rf_path		path,
+	u8				hw_rate,
+	boolean			is_single_rate
+);
+
+u8
+phydm_api_get_txagc(
+	void				*dm_void,
+	enum rf_path		path,
+	u8				hw_rate
+);
+
+boolean
+phydm_api_switch_bw_channel(
+	void					*dm_void,
+	u8					central_ch,
+	u8					primary_ch_idx,
+	enum channel_width	bandwidth
+);
+
+boolean
+phydm_api_trx_mode(
+	void				*dm_void,
+	enum bb_path	tx_path,
+	enum bb_path	rx_path,
+	boolean			is_tx2_path
+);
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_auto_dbg.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_auto_dbg.c
new file mode 100644
index 000000000000..b9076619d8f1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_auto_dbg.c
@@ -0,0 +1,682 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef PHYDM_AUTO_DEGBUG
+
+void
+phydm_check_hang_reset(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+
+	atd_t->dbg_step = 0;
+	atd_t->auto_dbg_type = AUTO_DBG_STOP;
+	phydm_pause_dm_watchdog(dm, PHYDM_RESUME);
+	dm->debug_components &= (~ODM_COMP_API);
+}
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+void
+phydm_auto_check_hang_engine_n(
+	void			*dm_void
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+	struct	n_dbgport_803	dbgport_803 = {0};
+	u32		value32_tmp = 0, value32_tmp_2 = 0;
+	u8		i;
+	u32		curr_dbg_port_val[DBGPORT_CHK_NUM];
+	u16		curr_ofdm_t_cnt;
+	u16		curr_ofdm_r_cnt;
+	u16		curr_cck_t_cnt;
+	u16		curr_cck_r_cnt;
+	u16		curr_ofdm_crc_error_cnt;
+	u16		curr_cck_crc_error_cnt;
+	u16		diff_ofdm_t_cnt;
+	u16		diff_ofdm_r_cnt;
+	u16		diff_cck_t_cnt;
+	u16		diff_cck_r_cnt;
+	u16		diff_ofdm_crc_error_cnt;
+	u16		diff_cck_crc_error_cnt;
+	u8		rf_mode;
+
+
+	if (atd_t->auto_dbg_type == AUTO_DBG_STOP)
+		return;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		phydm_check_hang_reset(dm);
+		return;
+	}
+
+	if (atd_t->dbg_step == 0) {
+		pr_debug("dbg_step=0\n\n");
+		
+		/*Reset all packet counter*/
+		odm_set_bb_reg(dm, 0xf14, BIT(16), 1);
+		odm_set_bb_reg(dm, 0xf14, BIT(16), 0);
+
+
+
+	} else if (atd_t->dbg_step == 1)  {
+		pr_debug("dbg_step=1\n\n");
+
+		/*Check packet counter Register*/
+		atd_t->ofdm_t_cnt = (u16)odm_get_bb_reg(dm, 0x9cc, MASKHWORD);
+		atd_t->ofdm_r_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKLWORD);
+		atd_t->ofdm_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKHWORD);
+		
+		atd_t->cck_t_cnt = (u16)odm_get_bb_reg(dm, 0x9d0, MASKHWORD);;
+		atd_t->cck_r_cnt = (u16)odm_get_bb_reg(dm, 0xfa0, MASKHWORD);
+		atd_t->cck_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf84, 0x3fff);	
+
+
+		/*Check Debug Port*/
+		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
+			
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, (u32)atd_t->dbg_port_table[i])) {
+				atd_t->dbg_port_val[i] = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+			}
+		}
+	
+	} else if (atd_t->dbg_step == 2)  {
+		pr_debug("dbg_step=2\n\n");
+
+		/*Check packet counter Register*/
+		curr_ofdm_t_cnt = (u16)odm_get_bb_reg(dm, 0x9cc, MASKHWORD);
+		curr_ofdm_r_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKLWORD);
+		curr_ofdm_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKHWORD);
+		
+		curr_cck_t_cnt = (u16)odm_get_bb_reg(dm, 0x9d0, MASKHWORD);;
+		curr_cck_r_cnt = (u16)odm_get_bb_reg(dm, 0xfa0, MASKHWORD);
+		curr_cck_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf84, 0x3fff);	
+
+		/*Check Debug Port*/
+		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
+			
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, (u32)atd_t->dbg_port_table[i])) {
+				curr_dbg_port_val[i] = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+			}
+		}
+	
+		/*=== Make check hang decision ================================*/
+		pr_debug("Check Hang Decision\n\n");
+
+		/* ----- Check RF Register -----------------------------------*/
+		for (i = 0; i < dm->num_rf_path; i++) {
+		
+			rf_mode = (u8)odm_get_rf_reg(dm, i, 0x0, 0xf0000);
+				
+			pr_debug("RF0x0[%d] = 0x%x\n", i, rf_mode);
+
+			if (rf_mode > 3) {
+				pr_debug("Incorrect RF mode\n");
+				pr_debug("ReasonCode:RHN-1\n");
+
+				
+			}
+		}
+
+		value32_tmp = odm_get_rf_reg(dm, 0, 0xb0, 0xf0000);
+			
+		if (dm->support_ic_type == ODM_RTL8188E) {
+			if (value32_tmp != 0xff8c8) {
+				pr_debug("ReasonCode:RHN-3\n");
+			}
+		}
+
+		/* ----- Check BB Register -----------------------------------*/
+		
+		/*BB mode table*/
+		value32_tmp = odm_get_bb_reg(dm, 0x824, 0xe);
+		value32_tmp_2 = odm_get_bb_reg(dm, 0x82c, 0xe);
+		pr_debug("BB TX mode table {A, B}= {%d, %d}\n", value32_tmp, value32_tmp_2);
+
+		if ((value32_tmp > 3) || (value32_tmp_2 > 3)) {
+			
+			pr_debug("ReasonCode:RHN-2\n");
+		}
+
+		value32_tmp = odm_get_bb_reg(dm, 0x824, 0x700000);
+		value32_tmp_2 = odm_get_bb_reg(dm, 0x82c, 0x700000);
+		pr_debug("BB RX mode table {A, B}= {%d, %d}\n", value32_tmp, value32_tmp_2);
+
+		if ((value32_tmp > 3) || (value32_tmp_2 > 3)) {
+			
+			pr_debug("ReasonCode:RHN-2\n");
+		}
+		
+
+		/*BB HW Block*/
+		value32_tmp = odm_get_bb_reg(dm, 0x800, MASKDWORD);
+		
+		if (!(value32_tmp & BIT(24))) {
+			pr_debug("Reg0x800[24] = 0, CCK BLK is disabled\n");
+			pr_debug("ReasonCode: THN-3\n");
+		}
+		
+		if (!(value32_tmp & BIT(25))) {
+			pr_debug("Reg0x800[24] = 0, OFDM BLK is disabled\n");
+			pr_debug("ReasonCode:THN-3\n");
+		}
+
+		/*BB Continue TX*/
+		value32_tmp = odm_get_bb_reg(dm, 0xd00, 0x70000000);
+		pr_debug("Continue TX=%d\n", value32_tmp);
+		if (value32_tmp != 0) {
+			pr_debug("ReasonCode: THN-4\n");
+		}
+		
+
+		/* ----- Check Packet Counter --------------------------------*/
+		diff_ofdm_t_cnt = curr_ofdm_t_cnt - atd_t->ofdm_t_cnt;
+		diff_ofdm_r_cnt = curr_ofdm_r_cnt - atd_t->ofdm_r_cnt;
+		diff_ofdm_crc_error_cnt = curr_ofdm_crc_error_cnt - atd_t->ofdm_crc_error_cnt;
+		
+		diff_cck_t_cnt = curr_cck_t_cnt - atd_t->cck_t_cnt;
+		diff_cck_r_cnt = curr_cck_r_cnt - atd_t->cck_r_cnt;
+		diff_cck_crc_error_cnt = curr_cck_crc_error_cnt - atd_t->cck_crc_error_cnt;
+
+		pr_debug("OFDM[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			atd_t->ofdm_t_cnt, atd_t->ofdm_r_cnt, atd_t->ofdm_crc_error_cnt);
+		pr_debug("OFDM[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			curr_ofdm_t_cnt, curr_ofdm_r_cnt, curr_ofdm_crc_error_cnt);
+		pr_debug("OFDM_diff {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			diff_ofdm_t_cnt, diff_ofdm_r_cnt, diff_ofdm_crc_error_cnt);
+
+		pr_debug("CCK[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			atd_t->cck_t_cnt, atd_t->cck_r_cnt, atd_t->cck_crc_error_cnt);
+		pr_debug("CCK[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			curr_cck_t_cnt, curr_cck_r_cnt, curr_cck_crc_error_cnt);
+		pr_debug("CCK_diff {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			diff_cck_t_cnt, diff_cck_r_cnt, diff_cck_crc_error_cnt);
+
+		/* ----- Check Dbg Port --------------------------------*/
+
+		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
+			pr_debug("Dbg_port=((0x%x))\n", atd_t->dbg_port_table[i]);
+			pr_debug("Val{pre, curr}={0x%x, 0x%x}\n", atd_t->dbg_port_val[i], curr_dbg_port_val[i]);
+
+			if ((atd_t->dbg_port_table[i]) == 0) {
+				if (atd_t->dbg_port_val[i] == curr_dbg_port_val[i]) {
+					
+					pr_debug("BB state hang\n");
+					pr_debug("ReasonCode:\n");
+				}
+
+			} else if (atd_t->dbg_port_table[i] == 0x803) {
+				if (atd_t->dbg_port_val[i] == curr_dbg_port_val[i]) {
+					//dbgport_803 = (struct n_dbgport_803 )(atd_t->dbg_port_val[i]);
+
+					odm_move_memory(dm, &dbgport_803,
+							  &atd_t->dbg_port_val[i],
+							sizeof(struct n_dbgport_803));
+
+					pr_debug("RSTB{BB, GLB, OFDM}={%d, %d, %d}\n", dbgport_803.bb_rst_b, dbgport_803.glb_rst_b, dbgport_803.ofdm_rst_b);
+					pr_debug("{ofdm_tx_en, cck_tx_en, phy_tx_on}={%d, %d, %d}\n", dbgport_803.ofdm_tx_en, dbgport_803.cck_tx_en, dbgport_803.phy_tx_on);
+					pr_debug("CCA_PP{OFDM, CCK}={%d, %d}\n", dbgport_803.ofdm_cca_pp, dbgport_803.cck_cca_pp);
+
+					if (dbgport_803.phy_tx_on)
+						pr_debug("Maybe TX Hang\n");
+					else if (dbgport_803.ofdm_cca_pp || dbgport_803.cck_cca_pp)
+						pr_debug("Maybe RX Hang\n");	
+				}
+
+			} else if (atd_t->dbg_port_table[i] == 0x208) {
+				if ((atd_t->dbg_port_val[i] & BIT(30)) && (curr_dbg_port_val[i] & BIT(30))) {
+					
+					pr_debug("EDCCA Pause TX\n");
+					pr_debug("ReasonCode: THN-2\n");
+				}
+
+			} else if (atd_t->dbg_port_table[i] == 0xab0) {
+				if (((atd_t->dbg_port_val[i] & 0xffffff) == 0) || 
+					((curr_dbg_port_val[i] & 0xffffff) == 0)) {
+					
+					pr_debug("Wrong L-SIG formate\n");
+					pr_debug("ReasonCode: THN-1\n");
+				}
+			}
+		}
+		
+		phydm_check_hang_reset(dm);
+	}
+
+	atd_t->dbg_step++;
+	
+}
+
+void
+phydm_bb_auto_check_hang_start_n(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32	value32 = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		return;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, 
+		       "PHYDM auto check hang (N-series) is started, Please check the system log\n");
+
+	dm->debug_components |= ODM_COMP_API;
+	atd_t->auto_dbg_type = AUTO_DBG_CHECK_HANG;
+	atd_t->dbg_step = 0;
+	
+
+	phydm_pause_dm_watchdog(dm, PHYDM_PAUSE);
+
+
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_bb_rx_hang_info_n(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32	value32 = 0;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		return;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "not support now\n");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif	
+
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+void
+phydm_bb_rx_hang_info_ac(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32	value32 = 0;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		return;
+
+	value32 = odm_get_bb_reg(dm, 0xF80, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		         "\r\n %-35s = 0x%x", "rptreg of sc/bw/ht/...",
+		       value32);
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, 0x198c, BIT(2) | BIT(1) | BIT(0), 7);
+
+	/* dbg_port = basic state machine */
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x000);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "basic state machine",
+			       value32);
+	}
+
+	/* dbg_port = state machine */
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x007);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "state machine", value32);
+	}
+
+	/* dbg_port = CCA-related*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x204);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "CCA-related", value32);
+	}
+
+
+	/* dbg_port = edcca/rxd*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x278);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "edcca/rxd", value32);
+	}
+
+	/* dbg_port = rx_state/mux_state/ADC_MASK_OFDM*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x290);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x",
+			       "rx_state/mux_state/ADC_MASK_OFDM", value32);
+	}
+
+	/* dbg_port = bf-related*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B2);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "bf-related", value32);
+	}
+
+	/* dbg_port = bf-related*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B8);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "bf-related", value32);
+	}
+
+	/* dbg_port = txon/rxd*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA03);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "txon/rxd", value32);
+	}
+
+	/* dbg_port = l_rate/l_length*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0B);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "l_rate/l_length",
+			       value32);
+	}
+
+	/* dbg_port = rxd/rxd_hit*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0D);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rxd/rxd_hit", value32);
+	}
+
+	/* dbg_port = dis_cca*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAA0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "dis_cca", value32);
+	}
+
+
+	/* dbg_port = tx*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAB0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "tx", value32);
+	}
+
+	/* dbg_port = rx plcp*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD1);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD2);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD3);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
+
+void
+phydm_auto_dbg_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Show dbg port: {1} {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Auto check hang: {1} {2}\n");
+		return;
+	} else if (var1[0] == 1) {
+		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
+
+		if (var1[1] == 1) {
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+				phydm_bb_rx_hang_info_ac(dm, &used, output, &out_len);
+				#else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+				#endif
+			} else {
+				#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+				phydm_bb_rx_hang_info_n(dm, &used, output, &out_len);
+				#else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+				#endif
+			}
+		} else if (var1[1] == 2) {
+		
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+			} else {
+				#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+				phydm_bb_auto_check_hang_start_n(dm, &used, output, &out_len);
+				#else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+				#endif
+			}
+		}
+	} 
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif
+
+void
+phydm_auto_dbg_engine(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_AUTO_DEGBUG
+	u32	value32 = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+
+	if (atd_t->auto_dbg_type == AUTO_DBG_STOP)
+		return;
+
+	pr_debug("%s ======>\n", __func__);
+	
+	if (atd_t->auto_dbg_type == AUTO_DBG_CHECK_HANG) {
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			pr_debug("Not Support\n");
+		} else {
+			#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+			phydm_auto_check_hang_engine_n(dm);
+			#else
+			pr_debug("Not Support\n");
+			#endif
+		}
+
+	} else if (atd_t->auto_dbg_type == AUTO_DBG_CHECK_RA) {
+	
+		pr_debug("Not Support\n");
+
+	}
+#endif
+}
+
+void
+phydm_auto_dbg_engine_init(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_AUTO_DEGBUG
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+	u16 dbg_port_table[DBGPORT_CHK_NUM] = {0x0, 0x803, 0x208, 0xab0, 0xab1, 0xab2};
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>n", __func__);
+
+	odm_move_memory(dm, &atd_t->dbg_port_table[0],
+			  &dbg_port_table[0], (DBGPORT_CHK_NUM * 2));
+
+	phydm_check_hang_reset(dm);
+#endif
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_auto_dbg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_auto_dbg.h
new file mode 100644
index 000000000000..d6ea5b3c27db
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_auto_dbg.h
@@ -0,0 +1,124 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_AUTO_DBG_H__
+#define    __PHYDM_AUTO_DBG_H__
+
+#define AUTO_DBG_VERSION	"1.0"		/* 2017.05.015  Dino, Add phydm_auto_dbg.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define	AUTO_CHK_HANG_STEP_MAX	3
+#define	DBGPORT_CHK_NUM			6
+
+#ifdef PHYDM_AUTO_DEGBUG
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+enum auto_dbg_type_e{
+	AUTO_DBG_STOP 		= 0,
+	AUTO_DBG_CHECK_HANG 	= 1,
+	AUTO_DBG_CHECK_RA	= 2,
+	AUTO_DBG_CHECK_DIG	= 3	
+};
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+struct n_dbgport_803 {
+	/*BYTE 3*/
+	u8 bb_rst_b: 1;
+	u8 glb_rst_b: 1;
+	u8 zero_1bit_1:1;
+	u8 ofdm_rst_b: 1;
+	u8 cck_txpe: 1;
+	u8 ofdm_txpe: 1;
+	u8 phy_tx_on: 1;
+	u8 tdrdy: 1;
+	/*BYTE 2*/
+	u8 txd:8;
+	/*BYTE 1*/
+	u8 cck_cca_pp: 1; 
+	u8 ofdm_cca_pp: 1;
+	u8 rx_rst: 1;
+	u8 rdrdy: 1;
+	u8 rxd_7_4: 4;
+	/*BYTE 0*/
+	u8 rxd_3_0: 4;
+	u8 ofdm_tx_en: 1; 
+	u8 cck_tx_en: 1;
+	u8 zero_1bit_2:1;
+	u8 clk_80m: 1;
+};
+
+struct phydm_auto_dbg_struc {
+	enum	auto_dbg_type_e	auto_dbg_type;
+	u8		dbg_step;
+	u16		dbg_port_table[DBGPORT_CHK_NUM];
+	u32		dbg_port_val[DBGPORT_CHK_NUM];
+	u16		ofdm_t_cnt;
+	u16		ofdm_r_cnt;
+	u16		cck_t_cnt;
+	u16		cck_r_cnt;
+	u16		ofdm_crc_error_cnt;
+	u16		cck_crc_error_cnt;
+
+};
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+
+void
+phydm_auto_dbg_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+#endif
+
+void
+phydm_auto_dbg_engine(
+	void			*dm_void
+);
+
+void
+phydm_auto_dbg_engine_init(
+	void		*dm_void
+);
+#endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_beamforming.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_beamforming.c
new file mode 100644
index 000000000000..4b84d1b5735f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_beamforming.c
@@ -0,0 +1,2049 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#if WPP_SOFTWARE_TRACE
+		#include "phydm_beamforming.tmh"
+	#endif
+#endif
+
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+phydm_get_txbf_device_num(
+	void	*dm_void,
+	u8	macid
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*For BDC*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = dm->phydm_sta_info[macid];
+	struct bf_cmn_info		*bf = NULL;
+	struct _BF_DIV_COEX_		*dm_bdc_table = &dm->dm_bdc_table;
+	u8	act_as_bfer = 0;
+	u8	act_as_bfee = 0;
+	
+	if (is_sta_active(sta)) {
+		bf = &(sta->bf_info);
+	} else {
+		PHYDM_DBG(dm, DBG_TXBF, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+
+	 if (sta->support_wireless_set & WIRELESS_VHT) {
+		if (bf->vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMEE_ENABLE)
+			act_as_bfer = 1;
+
+		if (bf->vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMER_ENABLE)
+			act_as_bfee = 1;
+		
+	} else if (sta->support_wireless_set & WIRELESS_HT) {
+		if (bf->ht_beamform_cap & BEAMFORMING_HT_BEAMFORMEE_ENABLE)
+			act_as_bfer = 1;
+
+		if (bf->ht_beamform_cap & BEAMFORMING_HT_BEAMFORMER_ENABLE)
+			act_as_bfee = 1;
+
+	}
+
+	if (act_as_bfer)) { /* Our Device act as BFer */
+		dm_bdc_table->w_bfee_client[macid] = true; 
+		dm_bdc_table->num_txbfee_client++;
+	} else
+		dm_bdc_table->w_bfee_client[macid] = false; 
+	
+	if (act_as_bfee)) { /* Our Device act as BFee */
+		dm_bdc_table->w_bfer_client[macid] = true; 
+		dm_bdc_table->num_txbfer_client++;
+	} else
+		dm_bdc_table->w_bfer_client[macid] = false; 
+
+#endif
+#endif
+}
+
+struct _RT_BEAMFORM_STAINFO *
+phydm_sta_info_init(
+	struct dm_struct		*dm,
+	u16			sta_idx
+)
+{
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORM_STAINFO		*entry = &beam_info->beamform_sta_info;
+	struct sta_info					*sta = dm->odm_sta_info[sta_idx];
+	struct cmn_sta_info				*cmn_sta = dm->phydm_sta_info[sta_idx];
+	//void					*adapter = dm->adapter;
+	PADAPTER				adapter = (PADAPTER)dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PMGNT_INFO					p_MgntInfo = &((adapter)->MgntInfo);
+	PRT_HIGH_THROUGHPUT		p_ht_info = GET_HT_INFO(p_MgntInfo);
+	PRT_VERY_HIGH_THROUGHPUT	p_vht_info = GET_VHT_INFO(p_MgntInfo);
+#endif
+
+	if (!is_sta_active(cmn_sta)) {
+		
+		PHYDM_DBG(dm, DBG_TXBF, "%s => sta_info(mac_id:%d) failed\n", __func__, sta_idx);
+		#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		rtw_warn_on(1);
+		#endif
+		
+		return entry;
+	}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
+	odm_move_memory(dm, (PVOID)(entry->my_mac_addr), (PVOID)(adapter->CurrentAddress), 6);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	odm_move_memory(dm, entry->my_mac_addr, adapter_mac_addr(sta->padapter), 6);
+#endif
+
+	entry->aid = cmn_sta->aid;
+	entry->ra = cmn_sta->mac_addr;
+	entry->mac_id = cmn_sta->mac_id;
+	entry->bw = cmn_sta->bw_mode;
+	entry->cur_beamform = cmn_sta->bf_info.ht_beamform_cap;
+	entry->ht_beamform_cap = cmn_sta->bf_info.ht_beamform_cap;
+	
+#if	ODM_IC_11AC_SERIES_SUPPORT
+	if (cmn_sta->support_wireless_set & WIRELESS_VHT) {
+		entry->cur_beamform_vht = cmn_sta->bf_info.vht_beamform_cap;
+		entry->vht_beamform_cap = cmn_sta->bf_info.vht_beamform_cap;
+	}
+#endif
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) /*To Be Removed */	
+	entry->ht_beamform_cap = p_ht_info->HtBeamformCap;		/*To Be Removed*/
+	entry->vht_beamform_cap = p_vht_info->VhtBeamformCap;	/*To Be Removed*/
+	
+	if (sta_idx == 0) { /*client mode*/
+		#if	ODM_IC_11AC_SERIES_SUPPORT
+		if (cmn_sta->support_wireless_set & WIRELESS_VHT)
+			entry->cur_beamform_vht = p_vht_info->VhtCurBeamform;
+		#endif
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_TXBF, "wireless_set = 0x%x, staidx = %d\n", cmn_sta->support_wireless_set, sta_idx);
+	PHYDM_DBG(dm, DBG_TXBF, "entry->cur_beamform = 0x%x, entry->cur_beamform_vht = 0x%x\n", entry->cur_beamform, entry->cur_beamform_vht);
+	return entry;
+
+}
+void phydm_sta_info_update(
+	struct dm_struct			*dm,
+	u16				sta_idx,
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry
+)
+{
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+
+	if (!is_sta_active(sta))
+		return;
+
+	sta->bf_info.p_aid = beamform_entry->p_aid;
+	sta->bf_info.g_id = beamform_entry->g_id;
+}
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_bfee_entry_by_addr(
+	void		*dm_void,
+	u8		*RA,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used && (eq_mac_addr(RA, beam_info->beamformee_entry[i].mac_addr))) {
+			*idx = i;
+			return &beam_info->beamformee_entry[i];
+		}
+	}
+
+	return NULL;
+}
+
+struct _RT_BEAMFORMER_ENTRY *
+phydm_beamforming_get_bfer_entry_by_addr(
+	void	*dm_void,
+	u8	*TA,
+	u8	*idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		i = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
+		if (beam_info->beamformer_entry[i].is_used && (eq_mac_addr(TA, beam_info->beamformer_entry[i].mac_addr))) {
+			*idx = i;
+			return &beam_info->beamformer_entry[i];
+		}
+	}
+
+	return NULL;
+}
+
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_entry_by_mac_id(
+	void		*dm_void,
+	u8		mac_id,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used && (mac_id == beam_info->beamformee_entry[i].mac_id)) {
+			*idx = i;
+			return &beam_info->beamformee_entry[i];
+		}
+	}
+
+	return NULL;
+}
+
+
+enum beamforming_cap
+phydm_beamforming_get_entry_beam_cap_by_mac_id(
+	void		*dm_void,
+	u8		mac_id
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	enum beamforming_cap			beamform_entry_cap = BEAMFORMING_CAP_NONE;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used && (mac_id == beam_info->beamformee_entry[i].mac_id)) {
+			beamform_entry_cap =  beam_info->beamformee_entry[i].beamform_entry_cap;
+			i = BEAMFORMEE_ENTRY_NUM;
+		}
+	}
+
+	return beamform_entry_cap;
+}
+
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_free_bfee_entry(
+	void		*dm_void,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used == false) {
+			*idx = i;
+			return &beam_info->beamformee_entry[i];
+		}
+	}
+	return NULL;
+}
+
+struct _RT_BEAMFORMER_ENTRY *
+phydm_beamforming_get_free_bfer_entry(
+	void		*dm_void,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s ===>\n", __func__);
+
+	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
+		if (beam_info->beamformer_entry[i].is_used == false) {
+			*idx = i;
+			return &beam_info->beamformer_entry[i];
+		}
+	}
+	return NULL;
+}
+
+/*
+ * Description: Get the first entry index of MU Beamformee.
+ *
+ * Return value: index of the first MU sta.
+ *
+ * 2015.05.25. Created by tynli.
+ *
+ */
+u8
+phydm_beamforming_get_first_mu_bfee_entry_idx(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u8					idx = 0xFF;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	boolean					is_found = false;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].is_mu_sta) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] idx=%d!\n", __func__, idx);
+			is_found = true;
+			break;
+		}
+	}
+
+	if (!is_found)
+		idx = 0xFF;
+
+	return idx;
+}
+
+
+/*Add SU BFee and MU BFee*/
+struct _RT_BEAMFORMEE_ENTRY *
+beamforming_add_bfee_entry(
+	void					*dm_void,
+	struct _RT_BEAMFORM_STAINFO	*sta,
+	enum beamforming_cap		beamform_cap,
+	u8					num_of_sounding_dim,
+	u8					comp_steering_num_of_bfer,
+	u8					*idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY	*entry = phydm_beamforming_get_free_bfee_entry(dm, idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (entry != NULL) {
+		entry->is_used = true;
+		entry->aid = sta->aid;
+		entry->mac_id = sta->mac_id;
+		entry->sound_bw = sta->bw;
+		odm_move_memory(dm, entry->my_mac_addr, sta->my_mac_addr, 6);
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) {
+			/*BSSID[44:47] xor BSSID[40:43]*/
+			u16 bssid = ((sta->my_mac_addr[5] & 0xf0) >> 4) ^ (sta->my_mac_addr[5] & 0xf);
+			/*(dec(A) + dec(B)*32) mod 512*/
+			entry->p_aid = (sta->aid + bssid * 32) & 0x1ff;
+			entry->g_id = 63;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: BFee P_AID addressed to STA=%d\n", __func__, entry->p_aid);
+		} else if (phydm_acting_determine(dm, phydm_acting_as_ibss)) {
+			/*ad hoc mode*/
+			entry->p_aid = 0;
+			entry->g_id = 63;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: BFee P_AID as IBSS=%d\n", __func__, entry->p_aid);
+		} else {
+			/*client mode*/
+			entry->p_aid =  sta->ra[5];
+			/*BSSID[39:47]*/
+			entry->p_aid = (entry->p_aid << 1) | (sta->ra[4] >> 7);
+			entry->g_id = 0;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: BFee P_AID addressed to AP=0x%X\n", __func__, entry->p_aid);
+		}
+		cp_mac_addr(entry->mac_addr, sta->ra);
+		entry->is_txbf = false;
+		entry->is_sound = false;
+		entry->sound_period = 400;
+		entry->beamform_entry_cap = beamform_cap;
+		entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+
+		/*		entry->log_seq = 0xff;				Move to beamforming_add_bfer_entry*/
+		/*		entry->log_retry_cnt = 0;			Move to beamforming_add_bfer_entry*/
+		/*		entry->LogSuccessCnt = 0;		Move to beamforming_add_bfer_entry*/
+
+		entry->log_status_fail_cnt = 0;
+
+		entry->num_of_sounding_dim = num_of_sounding_dim;
+		entry->comp_steering_num_of_bfer = comp_steering_num_of_bfer;
+
+		if (beamform_cap & BEAMFORMER_CAP_VHT_MU) {
+			dm->beamforming_info.beamformee_mu_cnt += 1;
+			entry->is_mu_sta = true;
+			dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(dm);
+		} else if (beamform_cap & (BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP_HT_EXPLICIT)) {
+			dm->beamforming_info.beamformee_su_cnt += 1;
+			entry->is_mu_sta = false;
+		}
+
+		return entry;
+	} else
+		return NULL;
+}
+
+/*Add SU BFee and MU BFer*/
+struct _RT_BEAMFORMER_ENTRY *
+beamforming_add_bfer_entry(
+	void					*dm_void,
+	struct _RT_BEAMFORM_STAINFO	*sta,
+	enum beamforming_cap		beamform_cap,
+	u8					num_of_sounding_dim,
+	u8					*idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMER_ENTRY	*entry = phydm_beamforming_get_free_bfer_entry(dm, idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (entry != NULL) {
+		entry->is_used = true;
+		odm_move_memory(dm, entry->my_mac_addr, sta->my_mac_addr, 6);
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) {
+			/*BSSID[44:47] xor BSSID[40:43]*/
+			u16 bssid = ((sta->my_mac_addr[5] & 0xf0) >> 4) ^ (sta->my_mac_addr[5] & 0xf);
+
+			entry->p_aid = (sta->aid + bssid * 32) & 0x1ff;
+			entry->g_id = 63;
+			/*(dec(A) + dec(B)*32) mod 512*/
+		} else if (phydm_acting_determine(dm, phydm_acting_as_ibss)) {
+			entry->p_aid = 0;
+			entry->g_id = 63;
+		} else {
+			entry->p_aid =  sta->ra[5];
+			/*BSSID[39:47]*/
+			entry->p_aid = (entry->p_aid << 1) | (sta->ra[4] >> 7);
+			entry->g_id = 0;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: P_AID addressed to AP=0x%X\n", __func__, entry->p_aid);
+		}
+
+		cp_mac_addr(entry->mac_addr, sta->ra);
+		entry->beamform_entry_cap = beamform_cap;
+
+		entry->pre_log_seq = 0;	/*Modified by Jeffery @2015-04-13*/
+		entry->log_seq = 0;		/*Modified by Jeffery @2014-10-29*/
+		entry->log_retry_cnt = 0;	/*Modified by Jeffery @2014-10-29*/
+		entry->log_success = 0;	/*log_success is NOT needed to be accumulated, so  LogSuccessCnt->log_success, 2015-04-13, Jeffery*/
+		entry->clock_reset_times = 0;	/*Modified by Jeffery @2015-04-13*/
+
+		entry->num_of_sounding_dim = num_of_sounding_dim;
+
+		if (beamform_cap & BEAMFORMEE_CAP_VHT_MU) {
+			dm->beamforming_info.beamformer_mu_cnt += 1;
+			entry->is_mu_ap = true;
+			entry->aid = sta->aid;
+		} else if (beamform_cap & (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP_HT_EXPLICIT)) {
+			dm->beamforming_info.beamformer_su_cnt += 1;
+			entry->is_mu_ap = false;
+		}
+
+		return entry;
+	} else
+		return NULL;
+}
+
+#if 0
+boolean
+beamforming_remove_entry(
+	void			*adapter,
+	u8		*RA,
+	u8		*idx
+)
+{
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct				*dm = &hal_data->DM_OutSrc;
+
+	struct _RT_BEAMFORMER_ENTRY	*bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, RA, idx);
+	struct _RT_BEAMFORMEE_ENTRY	*entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, idx);
+	boolean ret = false;
+
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s Start!\n", __func__));
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, bfer_entry=0x%x\n", __func__, bfer_entry));
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, entry=0x%x\n", __func__, entry));
+
+	if (entry != NULL) {
+		entry->is_used = false;
+		entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		/*entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;*/
+		entry->is_beamforming_in_progress = false;
+		ret = true;
+	}
+	if (bfer_entry != NULL) {
+		bfer_entry->is_used = false;
+		bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		ret = true;
+	}
+	return ret;
+
+}
+#endif
+
+/* Used for beamforming_start_v1 */
+void
+phydm_beamforming_ndpa_rate(
+	void		*dm_void,
+	enum channel_width	BW,
+	u8			rate
+)
+{
+	u16			ndpa_rate = rate;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (ndpa_rate == 0) {
+		if (dm->rssi_min > 30) /* link RSSI > 30% */
+			ndpa_rate = ODM_RATE24M;
+		else
+			ndpa_rate = ODM_RATE6M;
+	}
+
+	if (ndpa_rate < ODM_RATEMCS0)
+		BW = (enum channel_width)CHANNEL_WIDTH_20;
+
+	ndpa_rate = (ndpa_rate << 8) | BW;
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
+
+}
+
+
+/* Used for beamforming_start_sw and  beamforming_start_fw */
+void
+phydm_beamforming_dym_ndpa_rate(
+	void		*dm_void
+)
+{
+	u16			ndpa_rate = ODM_RATE6M, BW;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	ndpa_rate = ODM_RATE6M;
+	BW = CHANNEL_WIDTH_20;
+
+	ndpa_rate = ndpa_rate << 8 | BW;
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, NDPA rate = 0x%X\n", __func__, ndpa_rate);
+}
+
+/*
+*	SW Sounding : SW Timer unit 1ms
+*				 HW Timer unit (1/32000) s  32k is clock.
+*	FW Sounding : FW Timer unit 10ms
+*/
+void
+beamforming_dym_period(
+	void		*dm_void,
+	u8          status
+)
+{
+	u8					idx;
+	boolean					is_change_period = false;
+	u16					sound_period_sw, sound_period_fw;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO		*sound_info = &beam_info->sounding_info;
+
+	struct _RT_BEAMFORMEE_ENTRY	*entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	/* 3 TODO  per-client throughput caculation. */
+
+	if ((*dm->current_tx_tp + *dm->current_rx_tp > 2) && ((entry->log_status_fail_cnt <= 20) || status)) {
+		sound_period_sw = 40;	/* 40ms */
+		sound_period_fw = 40;	/* From  H2C cmd, unit = 10ms */
+	} else {
+		sound_period_sw = 4000;/* 4s */
+		sound_period_fw = 400;
+	}
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]sound_period_sw=%d, sound_period_fw=%d\n",	__func__, sound_period_sw, sound_period_fw);
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		beamform_entry = beam_info->beamformee_entry + idx;
+
+		if (beamform_entry->default_csi_cnt > 20) {
+			/*Modified by David*/
+			sound_period_sw = 4000;
+			sound_period_fw = 400;
+		}
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] period = %d\n", __func__, sound_period_sw);
+		if ((beamform_entry->beamform_entry_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) == 0)
+			continue;
+
+		if (sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || sound_info->sound_mode == SOUNDING_FW_HT_TIMER) {
+			if (beamform_entry->sound_period != sound_period_fw) {
+				beamform_entry->sound_period = sound_period_fw;
+				is_change_period = true;		/*Only FW sounding need to send H2C packet to change sound period. */
+			}
+		} else if (beamform_entry->sound_period != sound_period_sw)
+			beamform_entry->sound_period = sound_period_sw;
+	}
+
+	if (is_change_period)
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+}
+
+
+
+
+boolean
+beamforming_send_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW,
+	u8			q_idx
+)
+{
+	boolean		ret = true;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (q_idx == BEACON_QUEUE)
+		ret = send_fw_ht_ndpa_packet(dm, RA, BW);
+	else
+		ret = send_sw_ht_ndpa_packet(dm, RA, BW);
+
+	return ret;
+}
+
+
+
+boolean
+beamforming_send_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW,
+	u8			q_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	boolean					ret = true;
+
+	hal_com_txbf_set(dm, TXBF_SET_GET_TX_RATE, NULL);
+
+	if ((beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7) && (beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9) && (!beam_info->snding3ss))
+		PHYDM_DBG(dm, DBG_TXBF, "@%s: 3SS VHT 789 don't sounding\n", __func__);
+
+	else  {
+		if (q_idx == BEACON_QUEUE) /* Send to reserved page => FW NDPA */
+			ret = send_fw_vht_ndpa_packet(dm, RA, AID, BW);
+		else {
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+			beam_info->is_mu_sounding = true;
+			ret = send_sw_vht_mu_ndpa_packet(dm, BW);
+#else
+			beam_info->is_mu_sounding = false;
+			ret = send_sw_vht_ndpa_packet(dm, RA, AID, BW);
+#endif
+#else
+			beam_info->is_mu_sounding = false;
+			ret = send_sw_vht_ndpa_packet(dm, RA, AID, BW);
+#endif
+		}
+	}
+	return ret;
+}
+
+
+enum beamforming_notify_state
+phydm_beamfomring_is_sounding(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	u8					*idx
+)
+{
+	enum beamforming_notify_state	is_sounding = BEAMFORMING_NOTIFY_NONE;
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8 i;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	/*if(( Beamforming_GetBeamCap(beam_info) & BEAMFORMER_CAP) == 0)*/
+	/*is_sounding = BEAMFORMING_NOTIFY_RESET;*/
+	if (beam_oid_info.sound_oid_mode == sounding_stop_all_timer) {
+		is_sounding = BEAMFORMING_NOTIFY_RESET;
+		goto out;
+	}
+
+		for (i = 0 ; i < BEAMFORMEE_ENTRY_NUM ; i++) {
+			PHYDM_DBG(dm, DBG_TXBF, "@%s: BFee Entry %d is_used=%d, is_sound=%d\n", __func__, i, beam_info->beamformee_entry[i].is_used, beam_info->beamformee_entry[i].is_sound);
+			if (beam_info->beamformee_entry[i].is_used && (!beam_info->beamformee_entry[i].is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF, "%s: Add BFee entry %d\n", __func__, i);
+				*idx = i;
+				if (beam_info->beamformee_entry[i].is_mu_sta)
+					is_sounding = BEAMFORMEE_NOTIFY_ADD_MU;
+				else
+					is_sounding = BEAMFORMEE_NOTIFY_ADD_SU;
+			}
+
+			if ((!beam_info->beamformee_entry[i].is_used) && beam_info->beamformee_entry[i].is_sound) {
+				PHYDM_DBG(dm, DBG_TXBF, "%s: Delete BFee entry %d\n", __func__, i);
+				*idx = i;
+				if (beam_info->beamformee_entry[i].is_mu_sta)
+					is_sounding = BEAMFORMEE_NOTIFY_DELETE_MU;
+				else
+					is_sounding = BEAMFORMEE_NOTIFY_DELETE_SU;
+			}
+		}
+
+out:
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, is_sounding = %d\n", __func__, is_sounding);
+	return is_sounding;
+}
+
+
+/* This function is unused */
+u8
+phydm_beamforming_sounding_idx(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO		*beam_info
+)
+{
+	u8					idx = 0;
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (beam_oid_info.sound_oid_mode == SOUNDING_SW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_SW_VHT_TIMER ||
+	    beam_oid_info.sound_oid_mode == SOUNDING_HW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_VHT_TIMER)
+		idx = beam_oid_info.sound_oid_idx;
+	else {
+		u8	i;
+		for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+			if (beam_info->beamformee_entry[i].is_used && (!beam_info->beamformee_entry[i].is_sound)) {
+				idx = i;
+				break;
+			}
+		}
+	}
+
+	return idx;
+}
+
+
+enum sounding_mode
+phydm_beamforming_sounding_mode(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	u8					idx
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			support_interface = dm->support_interface;
+
+	struct _RT_BEAMFORMEE_ENTRY		beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	enum sounding_mode				mode = beam_oid_info.sound_oid_mode;
+
+	if (beam_oid_info.sound_oid_mode == SOUNDING_SW_VHT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_VHT_TIMER) {
+		if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			mode = beam_oid_info.sound_oid_mode;
+		else
+			mode = sounding_stop_all_timer;
+	} else if (beam_oid_info.sound_oid_mode == SOUNDING_SW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_HT_TIMER) {
+		if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+			mode = beam_oid_info.sound_oid_mode;
+		else
+			mode = sounding_stop_all_timer;
+	} else if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_VHT_SU) {
+		if ((support_interface == ODM_ITRF_USB) && !(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
+			mode = SOUNDING_FW_VHT_TIMER;
+		else
+			mode = SOUNDING_SW_VHT_TIMER;
+	} else if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT) {
+		if ((support_interface == ODM_ITRF_USB) && !(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
+			mode = SOUNDING_FW_HT_TIMER;
+		else
+			mode = SOUNDING_SW_HT_TIMER;
+	} else
+		mode = sounding_stop_all_timer;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] support_interface=%d, mode=%d\n", __func__, support_interface, mode);
+
+	return mode;
+}
+
+
+u16
+phydm_beamforming_sounding_time(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	enum sounding_mode			mode,
+	u8					idx
+)
+{
+	u16						sounding_time = 0xffff;
+	struct _RT_BEAMFORMEE_ENTRY		beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_HW_VHT_TIMER)
+		sounding_time = beam_oid_info.sound_oid_period * 32;
+	else if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_SW_VHT_TIMER)
+		/*Modified by David*/
+		sounding_time = beam_entry.sound_period;	/*beam_oid_info.sound_oid_period;*/
+	else
+		sounding_time = beam_entry.sound_period;
+
+	return sounding_time;
+}
+
+
+enum channel_width
+phydm_beamforming_sounding_bw(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	enum sounding_mode			mode,
+	u8					idx
+)
+{
+	enum channel_width				sounding_bw = CHANNEL_WIDTH_20;
+	struct _RT_BEAMFORMEE_ENTRY		beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	if (mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_HW_VHT_TIMER)
+		sounding_bw = beam_oid_info.sound_oid_bw;
+	else if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_SW_VHT_TIMER)
+		/*Modified by David*/
+		sounding_bw = beam_entry.sound_bw;		/*beam_oid_info.sound_oid_bw;*/
+	else
+		sounding_bw = beam_entry.sound_bw;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s, sounding_bw=0x%X\n", __func__, sounding_bw);
+
+	return sounding_bw;
+}
+
+
+boolean
+phydm_beamforming_select_beam_entry(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	struct _RT_SOUNDING_INFO		*sound_info = &beam_info->sounding_info;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+
+	/*entry.is_sound is different between first and latter NDPA, and should not be used as BFee entry selection*/
+	/*BTW, latter modification should sync to the selection mechanism of AP/ADSL instead of the fixed sound_idx.*/
+	sound_info->sound_idx = phydm_beamforming_sounding_idx(dm, beam_info);
+	/*sound_info->sound_idx = 0;*/
+
+	if (sound_info->sound_idx < BEAMFORMEE_ENTRY_NUM)
+		sound_info->sound_mode = phydm_beamforming_sounding_mode(dm, beam_info, sound_info->sound_idx);
+	else
+		sound_info->sound_mode = sounding_stop_all_timer;
+
+	if (sounding_stop_all_timer == sound_info->sound_mode) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] Return because of sounding_stop_all_timer\n", __func__);
+		return false;
+	} else {
+		sound_info->sound_bw = phydm_beamforming_sounding_bw(dm, beam_info, sound_info->sound_mode, sound_info->sound_idx);
+		sound_info->sound_period = phydm_beamforming_sounding_time(dm, beam_info, sound_info->sound_mode, sound_info->sound_idx);
+		return true;
+	}
+}
+
+/*SU BFee Entry Only*/
+boolean
+phydm_beamforming_start_period(
+	void				*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	boolean						ret = true;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO			*sound_info = &beam_info->sounding_info;
+
+	phydm_beamforming_dym_ndpa_rate(dm);
+
+	phydm_beamforming_select_beam_entry(dm, beam_info);		/* Modified */
+
+	if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+		odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);
+	else if (sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
+		sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER) {
+		HAL_HW_TIMER_TYPE timer_type = HAL_TIMER_TXBF;
+		u32	val = (sound_info->sound_period | (timer_type << 16));
+
+		/* HW timer stop: All IC has the same setting */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
+		/* odm_write_1byte(dm, 0x15F, 0); */
+		/* HW timer init: All IC has the same setting, but 92E & 8812A only write 2 bytes */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_INIT, (u8 *)(&val));
+		/* odm_write_1byte(dm, 0x164, 1); */
+		/* odm_write_4byte(dm, 0x15C, val); */
+		/* HW timer start: All IC has the same setting */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_START, (u8 *)(&timer_type));
+		/* odm_write_1byte(dm, 0x15F, 0x5); */
+	} else if (sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || sound_info->sound_mode == SOUNDING_FW_HT_TIMER)
+		ret = beamforming_start_fw(dm, sound_info->sound_idx);
+	else
+		ret = false;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] sound_idx=%d, sound_mode=%d, sound_bw=%d, sound_period=%d\n", __func__,
+		sound_info->sound_idx, sound_info->sound_mode, sound_info->sound_bw, sound_info->sound_period);
+
+	return ret;
+}
+
+/* Used after beamforming_leave, and will clear the setting of the "already deleted" entry
+ *SU BFee Entry Only*/
+void
+phydm_beamforming_end_period_sw(
+	void				*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	/*void					*adapter = dm->adapter;*/
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO			*sound_info = &beam_info->sounding_info;
+
+	HAL_HW_TIMER_TYPE timer_type = HAL_TIMER_TXBF;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+		odm_cancel_timer(dm, &beam_info->beamforming_timer);
+	else if (sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
+		sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER)
+		/*HW timer stop: All IC has the same setting*/
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
+	/*odm_write_1byte(dm, 0x15F, 0);*/
+}
+
+void
+phydm_beamforming_end_period_fw(
+	void				*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	u8				idx = 0;
+
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]\n", __func__);
+}
+
+
+/*SU BFee Entry Only*/
+void
+phydm_beamforming_clear_entry_sw(
+	void			*dm_void,
+	boolean				is_delete,
+	u8				delete_idx
+)
+{
+	u8						idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+
+	if (is_delete) {
+		if (delete_idx < BEAMFORMEE_ENTRY_NUM) {
+			beamform_entry = beam_info->beamformee_entry + delete_idx;
+			if (!((!beamform_entry->is_used) && beamform_entry->is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF, "[%s] SW delete_idx is wrong!!!!!\n", __func__);
+				return;
+			}
+		}
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] SW delete BFee entry %d\n", __func__, delete_idx);
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING) {
+			beamform_entry->is_beamforming_in_progress = false;
+			beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		} else if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			beamform_entry->beamform_entry_state  = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&delete_idx);
+		}
+		beamform_entry->is_sound = false;
+		return;
+	}
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		beamform_entry = beam_info->beamformee_entry + idx;
+
+		/*Used after is_sounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
+		/*This function is mainly used in case "beam_oid_info.sound_oid_mode == sounding_stop_all_timer".*/
+		/*However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
+
+		if (!beamform_entry->is_sound)
+			continue;
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] SW reset BFee entry %d\n", __func__, idx);
+		/*
+		*	If End procedure is
+		*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
+		*	After C2H packet return , status bit will be set to zero.
+		*
+		*	2. After C2H packet, then reset state to initialized and clear status bit.
+		*/
+
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+			phydm_beamforming_end_sw(dm, 0);
+		else if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			beamform_entry->beamform_entry_state  = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
+		}
+
+		beamform_entry->is_sound = false;
+	}
+}
+
+void
+phydm_beamforming_clear_entry_fw(
+	void			*dm_void,
+	boolean				is_delete,
+	u8				delete_idx
+)
+{
+	u8						idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+
+	if (is_delete) {
+		if (delete_idx < BEAMFORMEE_ENTRY_NUM) {
+			beamform_entry = beam_info->beamformee_entry + delete_idx;
+
+			if (!((!beamform_entry->is_used) && beamform_entry->is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF, "[%s] FW delete_idx is wrong!!!!!\n", __func__);
+				return;
+			}
+		}
+		PHYDM_DBG(dm, DBG_TXBF, "%s: FW delete BFee entry %d\n", __func__, delete_idx);
+		beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		beamform_entry->is_sound = false;
+	} else {
+		for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+			beamform_entry = beam_info->beamformee_entry + idx;
+
+			/*Used after is_sounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
+			/*This function is mainly used in case "beam_oid_info.sound_oid_mode == sounding_stop_all_timer".*/
+			/*However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
+
+			if (beamform_entry->is_sound) {
+				PHYDM_DBG(dm, DBG_TXBF, "[%s]FW reset BFee entry %d\n", __func__, idx);
+				/*
+				*	If End procedure is
+				*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
+				*	After C2H packet return , status bit will be set to zero.
+				*
+				*	2. After C2H packet, then reset state to initialized and clear status bit.
+				*/
+
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+				beamform_entry->is_sound = false;
+			}
+		}
+	}
+}
+
+/*
+*	Called :
+*	1. Add and delete entry : beamforming_enter/beamforming_leave
+*	2. FW trigger :  Beamforming_SetTxBFen
+*	3. Set OID_RT_BEAMFORMING_PERIOD : beamforming_control_v2
+*/
+void
+phydm_beamforming_notify(
+	void			*dm_void
+)
+{
+	u8						idx = BEAMFORMEE_ENTRY_NUM;
+	enum beamforming_notify_state	is_sounding = BEAMFORMING_NOTIFY_NONE;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO			*sound_info = &beam_info->sounding_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	is_sounding = phydm_beamfomring_is_sounding(dm, beam_info, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s, Before notify, is_sounding=%d, idx=%d\n", __func__, is_sounding, idx);
+	PHYDM_DBG(dm, DBG_TXBF, "%s: beam_info->beamformee_su_cnt = %d\n", __func__, beam_info->beamformee_su_cnt);
+
+
+	switch (is_sounding) {
+	case BEAMFORMEE_NOTIFY_ADD_SU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_ADD_SU\n", __func__);
+		phydm_beamforming_start_period(dm);
+		break;
+
+	case BEAMFORMEE_NOTIFY_DELETE_SU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_DELETE_SU\n", __func__);
+		if (sound_info->sound_mode == SOUNDING_FW_HT_TIMER || sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
+			phydm_beamforming_clear_entry_fw(dm, true, idx);
+			if (beam_info->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
+				phydm_beamforming_end_period_fw(dm);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: No BFee left\n", __func__);
+			}
+		} else {
+			phydm_beamforming_clear_entry_sw(dm, true, idx);
+			if (beam_info->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
+				phydm_beamforming_end_period_sw(dm);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: No BFee left\n", __func__);
+			}
+		}
+		break;
+
+	case BEAMFORMEE_NOTIFY_ADD_MU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_ADD_MU\n", __func__);
+		if (beam_info->beamformee_mu_cnt == 2) {
+			/*if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+				odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);*/
+			odm_set_timer(dm, &beam_info->beamforming_timer, 1000); /*Do MU sounding every 1sec*/
+		} else
+			PHYDM_DBG(dm, DBG_TXBF, "%s: Less or larger than 2 MU STAs, not to set timer\n", __func__);
+		break;
+
+	case BEAMFORMEE_NOTIFY_DELETE_MU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_DELETE_MU\n", __func__);
+		if (beam_info->beamformee_mu_cnt == 1) {
+			/*if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)*/{
+				odm_cancel_timer(dm, &beam_info->beamforming_timer);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: Less than 2 MU STAs, stop sounding\n", __func__);
+			}
+		}
+		break;
+
+	case BEAMFORMING_NOTIFY_RESET:
+		if (sound_info->sound_mode == SOUNDING_FW_HT_TIMER || sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
+			phydm_beamforming_clear_entry_fw(dm, false, idx);
+			phydm_beamforming_end_period_fw(dm);
+		} else {
+			phydm_beamforming_clear_entry_sw(dm, false, idx);
+			phydm_beamforming_end_period_sw(dm);
+		}
+
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+
+
+boolean
+beamforming_init_entry(
+	void		*dm_void,
+	u16		sta_idx,
+	u8			*bfer_bfee_idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info				*cmn_sta = dm->phydm_sta_info[sta_idx];
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	struct _RT_BEAMFORMER_ENTRY		*beamformer_entry = NULL;
+	struct _RT_BEAMFORM_STAINFO		*sta = NULL;
+	enum beamforming_cap			beamform_cap = BEAMFORMING_CAP_NONE;
+	u8						bfer_idx = 0xF, bfee_idx = 0xF;
+	u8						num_of_sounding_dim = 0, comp_steering_num_of_bfer = 0;
+
+	sta = phydm_sta_info_init(dm, sta_idx);
+
+	/*The current setting does not support Beaforming*/
+	if (BEAMFORMING_CAP_NONE == sta->ht_beamform_cap && BEAMFORMING_CAP_NONE == sta->vht_beamform_cap) {
+		PHYDM_DBG(dm, DBG_TXBF, "The configuration disabled Beamforming! Skip...\n");
+		return false;
+	}
+
+	if (!(cmn_sta->support_wireless_set & (WIRELESS_VHT | WIRELESS_HT)))
+		return false;
+	else {
+		if (cmn_sta->support_wireless_set & WIRELESS_HT) {/*HT*/
+			if (TEST_FLAG(sta->cur_beamform, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {/*We are Beamformee because the STA is Beamformer*/
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_HT_EXPLICIT);
+			num_of_sounding_dim = (sta->cur_beamform & BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP) >> 6;
+			}
+			/*We are Beamformer because the STA is Beamformee*/
+			if (TEST_FLAG(sta->cur_beamform, BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
+				TEST_FLAG(sta->ht_beamform_cap, BEAMFORMING_HT_BEAMFORMER_TEST)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_HT_EXPLICIT);
+			comp_steering_num_of_bfer = (sta->cur_beamform & BEAMFORMING_HT_BEAMFORMER_STEER_NUM) >> 4;
+			}
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] HT cur_beamform=0x%X, beamform_cap=0x%X\n", __func__, sta->cur_beamform, beamform_cap);
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] HT num_of_sounding_dim=%d, comp_steering_num_of_bfer=%d\n", __func__, num_of_sounding_dim, comp_steering_num_of_bfer);
+		}
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+		if (cmn_sta->support_wireless_set & WIRELESS_VHT) {	/*VHT*/
+
+		/* We are Beamformee because the STA is SU Beamformer*/
+		if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_VHT_SU);
+			num_of_sounding_dim = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
+		}
+		/* We are Beamformer because the STA is SU Beamformee*/
+		if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) ||
+				TEST_FLAG(sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_VHT_SU);
+			comp_steering_num_of_bfer = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
+		}
+		/* We are Beamformee because the STA is MU Beamformer*/
+		if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_VHT_MU);
+			num_of_sounding_dim = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
+		}
+		/* We are Beamformer because the STA is MU Beamformee*/
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) { /* Only AP mode supports to act an MU beamformer */
+			if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE) ||
+					TEST_FLAG(sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
+				beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_VHT_MU);
+				comp_steering_num_of_bfer = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
+			}
+		}
+		PHYDM_DBG(dm, DBG_TXBF, "[%s]VHT cur_beamform_vht=0x%X, beamform_cap=0x%X\n", __func__, sta->cur_beamform_vht, beamform_cap);
+		PHYDM_DBG(dm, DBG_TXBF, "[%s]VHT num_of_sounding_dim=0x%X, comp_steering_num_of_bfer=0x%X\n", __func__, num_of_sounding_dim, comp_steering_num_of_bfer);
+
+		}
+#endif
+	}
+
+
+	if (beamform_cap == BEAMFORMING_CAP_NONE)
+		return false;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Self BF Entry Cap = 0x%02X\n", __func__, beamform_cap);
+
+	/*We are BFee, so the entry is BFer*/
+	if (beamform_cap & (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP_HT_EXPLICIT)) {
+		beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, sta->ra, &bfer_idx);
+
+		if (beamformer_entry == NULL) {
+			beamformer_entry = beamforming_add_bfer_entry(dm, sta, beamform_cap, num_of_sounding_dim, &bfer_idx);
+			if (beamformer_entry == NULL)
+				PHYDM_DBG(dm, DBG_TXBF, "[%s]Not enough BFer entry!!!!!\n", __func__);
+		}
+	}
+
+	/*We are BFer, so the entry is BFee*/
+	if (beamform_cap & (BEAMFORMER_CAP_VHT_MU | BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP_HT_EXPLICIT)) {
+		beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, sta->ra, &bfee_idx);
+
+		/*如果BFeeIdx = 0xF 則代表目前entry當中沒有相同的MACID在內*/
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] Get BFee entry 0x%X by address\n", __func__, bfee_idx);
+		if (beamform_entry == NULL) {
+			beamform_entry = beamforming_add_bfee_entry(dm, sta, beamform_cap, num_of_sounding_dim, comp_steering_num_of_bfer, &bfee_idx);
+			PHYDM_DBG(dm, DBG_TXBF, "[%s]: sta->AID=%d, sta->mac_id=%d\n", __func__, sta->aid, sta->mac_id);
+
+			PHYDM_DBG(dm, DBG_TXBF, "[%s]: Add BFee entry %d\n", __func__, bfee_idx);
+
+			if (beamform_entry == NULL)
+				return false;
+			else
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+		} else {
+			/*Entry has been created. If entry is initialing or progressing then errors occur.*/
+			if (beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED &&
+			    beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED)
+				return false;
+			else
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+		}
+		beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+		phydm_sta_info_update(dm, sta_idx, beamform_entry);
+	}
+
+	*bfer_bfee_idx = (bfer_idx << 4) | bfee_idx;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End: bfer_idx=0x%X, bfee_idx=0x%X, bfer_bfee_idx=0x%X\n", __func__, bfer_idx, bfee_idx, *bfer_bfee_idx);
+
+	return true;
+}
+
+
+void
+beamforming_deinit_entry(
+	void		*dm_void,
+	u8			*RA
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	u8				idx = 0;
+
+	struct _RT_BEAMFORMER_ENTRY	*bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, RA, &idx);
+	struct _RT_BEAMFORMEE_ENTRY	*bfee_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	boolean ret = false;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n",  __func__);
+
+	if (bfee_entry != NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, bfee_entry\n", __func__);
+		bfee_entry->is_used = false;
+		bfee_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		bfee_entry->is_beamforming_in_progress = false;
+		if (bfee_entry->is_mu_sta) {
+			dm->beamforming_info.beamformee_mu_cnt -= 1;
+			dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(dm);
+		} else
+			dm->beamforming_info.beamformee_su_cnt -= 1;
+		ret = true;
+	}
+
+	if (bfer_entry != NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, bfer_entry\n", __func__);
+		bfer_entry->is_used = false;
+		bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		if (bfer_entry->is_mu_ap)
+			dm->beamforming_info.beamformer_mu_cnt -= 1;
+		else
+			dm->beamforming_info.beamformer_su_cnt -= 1;
+		ret = true;
+	}
+
+	if (ret == true)
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_LEAVE, (u8 *)&idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, idx = 0x%X\n", __func__, idx);
+}
+
+
+boolean
+beamforming_start_v1(
+	void		*dm_void,
+	u8			*RA,
+	boolean			mode,
+	enum channel_width	BW,
+	u8			rate
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u8					idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	boolean					ret = true;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	if (entry->is_used == false) {
+		entry->is_beamforming_in_progress = false;
+		return false;
+	} else {
+		if (entry->is_beamforming_in_progress)
+			return false;
+
+		entry->is_beamforming_in_progress = true;
+
+		if (mode == 1) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
+				entry->is_beamforming_in_progress = false;
+				return false;
+			}
+		} else if (mode == 0) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
+				entry->is_beamforming_in_progress = false;
+				return false;
+			}
+		}
+
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			entry->is_beamforming_in_progress = false;
+			return false;
+		} else {
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+			entry->is_sound = true;
+		}
+	}
+
+	entry->sound_bw = BW;
+	beam_info->beamformee_cur_idx = idx;
+	phydm_beamforming_ndpa_rate(dm, BW, rate);
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
+
+	if (mode == 1)
+		ret = beamforming_send_ht_ndpa_packet(dm, RA, BW, NORMAL_QUEUE);
+	else
+		ret = beamforming_send_vht_ndpa_packet(dm, RA, entry->aid, BW, NORMAL_QUEUE);
+
+	if (ret == false) {
+		beamforming_leave(dm, RA);
+		entry->is_beamforming_in_progress = false;
+		return false;
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s  idx %d\n", __func__, idx);
+	return true;
+}
+
+
+boolean
+beamforming_start_sw(
+	void		*dm_void,
+	u8			idx,
+	u8			mode,
+	enum channel_width	BW
+)
+{
+	u8					*ra = NULL;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	boolean					ret = true;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+	u8				i, poll_sta_cnt = 0;
+	boolean				is_get_first_bfee = false;
+#endif
+#endif
+
+	if (beam_info->is_mu_sounding) {
+		beam_info->is_mu_sounding_in_progress = true;
+		entry = &beam_info->beamformee_entry[idx];
+		ra = entry->mac_addr;
+
+	} else {
+		entry = &beam_info->beamformee_entry[idx];
+
+		if (entry->is_used == false) {
+			PHYDM_DBG(dm, DBG_TXBF, "Skip Beamforming, no entry for idx =%d\n", idx);
+			entry->is_beamforming_in_progress = false;
+			return false;
+		}
+
+		if (entry->is_beamforming_in_progress) {
+			PHYDM_DBG(dm, DBG_TXBF, "is_beamforming_in_progress, skip...\n");
+			return false;
+		}
+
+		entry->is_beamforming_in_progress = true;
+		ra = entry->mac_addr;
+
+		if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_AUTO_HT_TIMER) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
+				entry->is_beamforming_in_progress = false;
+				PHYDM_DBG(dm, DBG_TXBF, "%s Return by not support BEAMFORMER_CAP_HT_EXPLICIT <==\n", __func__);
+				return false;
+			}
+		} else if (mode == SOUNDING_SW_VHT_TIMER || mode == SOUNDING_HW_VHT_TIMER || mode == SOUNDING_AUTO_VHT_TIMER) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
+				entry->is_beamforming_in_progress = false;
+				PHYDM_DBG(dm, DBG_TXBF, "%s Return by not support BEAMFORMER_CAP_VHT_SU <==\n", __func__);
+				return false;
+			}
+		}
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			entry->is_beamforming_in_progress = false;
+			PHYDM_DBG(dm, DBG_TXBF, "%s Return by incorrect beamform_entry_state(%d) <==\n", __func__, entry->beamform_entry_state);
+			return false;
+		} else {
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+			entry->is_sound = true;
+		}
+
+		beam_info->beamformee_cur_idx = idx;
+	}
+
+	/*2014.12.22 Luke: Need to be checked*/
+	/*GET_TXBF_INFO(adapter)->fTxbfSet(adapter, TXBF_SET_SOUNDING_STATUS, (u8*)&idx);*/
+
+	if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_AUTO_HT_TIMER)
+		ret = beamforming_send_ht_ndpa_packet(dm, ra, BW, NORMAL_QUEUE);
+	else
+		ret = beamforming_send_vht_ndpa_packet(dm, ra, entry->aid, BW, NORMAL_QUEUE);
+
+	if (ret == false) {
+		beamforming_leave(dm, ra);
+		entry->is_beamforming_in_progress = false;
+		return false;
+	}
+
+
+	/*--------------------------
+	 * Send BF Report Poll for MU BF
+	--------------------------*/
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+	if (beam_info->beamformee_mu_cnt <= 1)
+		goto out;
+
+	/* More than 1 MU STA*/
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		entry = &beam_info->beamformee_entry[i];
+		if (!entry->is_mu_sta)
+			continue;
+
+		if (!is_get_first_bfee) {
+			is_get_first_bfee = true;
+			continue;
+		}
+
+		poll_sta_cnt++;
+		if (poll_sta_cnt == (beam_info->beamformee_mu_cnt - 1))/* The last STA*/
+			send_sw_vht_bf_report_poll(dm, entry->mac_addr, true);
+		else
+			send_sw_vht_bf_report_poll(dm, entry->mac_addr, false);
+	}
+out:
+#endif
+#endif
+	return true;
+}
+
+
+boolean
+beamforming_start_fw(
+	void		*dm_void,
+	u8			idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	entry = &beam_info->beamformee_entry[idx];
+	if (entry->is_used == false) {
+		PHYDM_DBG(dm, DBG_TXBF, "Skip Beamforming, no entry for idx =%d\n", idx);
+		return false;
+	}
+
+	entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+	entry->is_sound = true;
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End, idx=0x%X\n", __func__, idx);
+	return true;
+}
+
+void
+beamforming_check_sounding_success(
+	void			*dm_void,
+	boolean			status
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
+
+	PHYDM_DBG(dm, DBG_TXBF, "[David]@%s Start!\n", __func__);
+
+	if (status == 1) {
+		if (entry->log_status_fail_cnt == 21)
+			beamforming_dym_period(dm, status);
+		entry->log_status_fail_cnt = 0;
+	} else if (entry->log_status_fail_cnt <= 20) {
+		entry->log_status_fail_cnt++;
+		PHYDM_DBG(dm, DBG_TXBF, "%s log_status_fail_cnt %d\n", __func__, entry->log_status_fail_cnt);
+	}
+	if (entry->log_status_fail_cnt > 20) {
+		entry->log_status_fail_cnt = 21;
+		PHYDM_DBG(dm, DBG_TXBF, "%s log_status_fail_cnt > 20, Stop SOUNDING\n", __func__);
+		beamforming_dym_period(dm, status);
+	}
+}
+
+void
+phydm_beamforming_end_sw(
+	void		*dm_void,
+	boolean			status
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
+
+	if (beam_info->is_mu_sounding) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s: MU sounding done\n", __func__);
+		beam_info->is_mu_sounding_in_progress = false;
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+				 (u8 *)&beam_info->beamformee_cur_idx);
+	} else {
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSING) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] BeamformStatus %d\n", __func__, entry->beamform_entry_state);
+			return;
+		}
+
+		if ((beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7) && (beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9) && (!beam_info->snding3ss)) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] VHT3SS 7,8,9, do not apply V matrix.\n", __func__);
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+					 (u8 *)&beam_info->beamformee_cur_idx);
+		} else if (status == 1) {
+			entry->log_status_fail_cnt = 0;
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+					 (u8 *)&beam_info->beamformee_cur_idx);
+		} else {
+			entry->log_status_fail_cnt++;
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_TX_PATH_RESET,
+					 (u8 *)&beam_info->beamformee_cur_idx);
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] log_status_fail_cnt %d\n", __func__, entry->log_status_fail_cnt);
+		}
+
+		if (entry->log_status_fail_cnt > 50) {
+			PHYDM_DBG(dm, DBG_TXBF, "%s log_status_fail_cnt > 50, Stop SOUNDING\n", __func__);
+			entry->is_sound = false;
+			beamforming_deinit_entry(dm, entry->mac_addr);
+
+			/*Modified by David - Every action of deleting entry should follow by Notify*/
+			phydm_beamforming_notify(dm);
+		}
+
+		entry->is_beamforming_in_progress = false;
+	}
+	PHYDM_DBG(dm, DBG_TXBF, "%s: status=%d\n", __func__, status);
+}
+
+
+void
+beamforming_timer_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void			*dm_void
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void            *context
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void					*adapter = (void *)context;
+	PHAL_DATA_TYPE				hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct					*dm = &hal_data->odmpriv;
+#endif
+	boolean						ret = false;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY		*entry = &(beam_info->beamformee_entry[beam_info->beamformee_cur_idx]);
+	struct _RT_SOUNDING_INFO			*sound_info = &(beam_info->sounding_info);
+	boolean					is_beamforming_in_progress;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (beam_info->is_mu_sounding)
+		is_beamforming_in_progress = beam_info->is_mu_sounding_in_progress;
+	else
+		is_beamforming_in_progress = entry->is_beamforming_in_progress;
+
+	if (is_beamforming_in_progress) {
+		PHYDM_DBG(dm, DBG_TXBF, "is_beamforming_in_progress, reset it\n");
+		phydm_beamforming_end_sw(dm, 0);
+	}
+
+	ret = phydm_beamforming_select_beam_entry(dm, beam_info);
+#if (SUPPORT_MU_BF == 1)
+	if (ret && beam_info->beamformee_mu_cnt > 1)
+		ret = 1;
+	else
+		ret = 0;
+#endif
+	if (ret)
+		ret = beamforming_start_sw(dm, sound_info->sound_idx, sound_info->sound_mode, sound_info->sound_bw);
+	else
+		PHYDM_DBG(dm, DBG_TXBF, "%s, Error value return from BeamformingStart_V2\n", __func__);
+
+	if ((beam_info->beamformee_su_cnt != 0) || (beam_info->beamformee_mu_cnt > 1)) {
+		if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+			odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);
+		else {
+			u32	val = (sound_info->sound_period << 16) | HAL_TIMER_TXBF;
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_RESTART, (u8 *)(&val));
+		}
+	}
+}
+
+
+void
+beamforming_sw_timer_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct phydm_timer_list		*timer
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void *function_context
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+	beamforming_timer_callback(dm);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct	*dm = (struct dm_struct *)function_context;
+	void	*adapter = dm->adapter;
+
+	if (*(dm->is_net_closed) == true)
+		return;
+	rtw_run_in_thread_cmd(adapter, beamforming_timer_callback, adapter);
+#endif
+
+}
+
+
+void
+phydm_beamforming_init(
+	void			*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMING_OID_INFO	*beam_oid_info = &beam_info->beamforming_oid_info;
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	
+	#ifdef BEAMFORMING_VERSION_1
+	if (hal_data->beamforming_version != BEAMFORMING_VERSION_1) {
+		return;
+	}
+	#endif
+	#endif
+
+	beam_oid_info->sound_oid_mode = SOUNDING_STOP_OID_TIMER;
+	PHYDM_DBG(dm, DBG_TXBF, "%s mode (%d)\n", __func__, beam_oid_info->sound_oid_mode);
+
+	beam_info->beamformee_su_cnt = 0;
+	beam_info->beamformer_su_cnt = 0;
+	beam_info->beamformee_mu_cnt = 0;
+	beam_info->beamformer_mu_cnt = 0;
+	beam_info->beamformee_mu_reg_maping = 0;
+	beam_info->mu_ap_index = 0;
+	beam_info->is_mu_sounding = false;
+	beam_info->first_mu_bfee_index = 0xFF;
+	beam_info->apply_v_matrix = true;
+	beam_info->snding3ss = false;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	beam_info->source_adapter = dm->adapter;
+#endif
+	hal_com_txbf_beamform_init(dm);
+}
+
+
+boolean
+phydm_acting_determine(
+	void			*dm_void,
+	enum phydm_acting_type	type
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean		ret = false;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PADAPTER    adapter = (PADAPTER)dm->beamforming_info.source_adapter;
+#else
+	struct _ADAPTER	*adapter = dm->adapter;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	if (type == phydm_acting_as_ap)
+		ret = ACTING_AS_AP(adapter);
+	else if (type == phydm_acting_as_ibss)
+		ret = ACTING_AS_IBSS(((PADAPTER)(adapter)));
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	struct mlme_priv			*pmlmepriv = &adapter->mlmepriv;
+
+	if (type == phydm_acting_as_ap)
+		ret = check_fwstate(pmlmepriv, WIFI_AP_STATE);
+	else if (type == phydm_acting_as_ibss)
+		ret = check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
+#endif
+
+	return ret;
+
+}
+
+void
+beamforming_enter(
+	void			*dm_void,
+	u16		sta_idx
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			bfer_bfee_idx = 0xff;
+
+	if (beamforming_init_entry(dm, sta_idx, &bfer_bfee_idx))
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_ENTER, (u8 *)&bfer_bfee_idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End!\n", __func__);
+}
+
+
+void
+beamforming_leave(
+	void			*dm_void,
+	u8			*RA
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (RA != NULL) {
+		beamforming_deinit_entry(dm, RA);
+		phydm_beamforming_notify(dm);
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End!!\n", __func__);
+}
+
+#if 0
+/* Nobody calls this function */
+void
+phydm_beamforming_set_txbf_en(
+	void		*dm_void,
+	u8			mac_id,
+	boolean			is_txbf
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u8					idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	entry = phydm_beamforming_get_entry_by_mac_id(dm, mac_id, &idx);
+
+	if (entry == NULL)
+		return;
+	else
+		entry->is_txbf = is_txbf;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s mac_id %d TxBF %d\n", __func__, entry->mac_id, entry->is_txbf);
+
+	phydm_beamforming_notify(dm);
+}
+#endif
+
+enum beamforming_cap
+phydm_beamforming_get_beam_cap(
+	void						*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	u8					i;
+	boolean				is_self_beamformer = false;
+	boolean				is_self_beamformee = false;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	enum beamforming_cap		beamform_cap = BEAMFORMING_CAP_NONE;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		beamformee_entry = beam_info->beamformee_entry[i];
+
+		if (beamformee_entry.is_used) {
+			is_self_beamformer = true;
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] BFee entry %d is_used=true\n", __func__, i);
+			break;
+		}
+	}
+
+	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
+		beamformer_entry = beam_info->beamformer_entry[i];
+
+		if (beamformer_entry.is_used) {
+			is_self_beamformee = true;
+			PHYDM_DBG(dm, DBG_TXBF, "[%s]: BFer entry %d is_used=true\n", __func__, i);
+			break;
+		}
+	}
+
+	if (is_self_beamformer)
+		beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP);
+	if (is_self_beamformee)
+		beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP);
+
+	return beamform_cap;
+}
+
+
+boolean
+beamforming_control_v1(
+	void			*dm_void,
+	u8			*RA,
+	u8			AID,
+	u8			mode,
+	enum channel_width	BW,
+	u8			rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean		ret = true;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	PHYDM_DBG(dm, DBG_TXBF, "AID (%d), mode (%d), BW (%d)\n", AID, mode, BW);
+
+	switch (mode) {
+	case 0:
+		ret = beamforming_start_v1(dm, RA, 0, BW, rate);
+		break;
+	case 1:
+		ret = beamforming_start_v1(dm, RA, 1, BW, rate);
+		break;
+	case 2:
+		phydm_beamforming_ndpa_rate(dm, BW, rate);
+		ret = beamforming_send_vht_ndpa_packet(dm, RA, AID, BW, NORMAL_QUEUE);
+		break;
+	case 3:
+		phydm_beamforming_ndpa_rate(dm, BW, rate);
+		ret = beamforming_send_ht_ndpa_packet(dm, RA, BW, NORMAL_QUEUE);
+		break;
+	}
+	return ret;
+}
+
+/*Only OID uses this function*/
+boolean
+phydm_beamforming_control_v2(
+	void		*dm_void,
+	u8			idx,
+	u8			mode,
+	enum channel_width	BW,
+	u16			period
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info =  &dm->beamforming_info;
+	struct _RT_BEAMFORMING_OID_INFO	*beam_oid_info = &beam_info->beamforming_oid_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+	PHYDM_DBG(dm, DBG_TXBF, "idx (%d), mode (%d), BW (%d), period (%d)\n", idx, mode, BW, period);
+
+	beam_oid_info->sound_oid_idx = idx;
+	beam_oid_info->sound_oid_mode = (enum sounding_mode) mode;
+	beam_oid_info->sound_oid_bw = BW;
+	beam_oid_info->sound_oid_period = period;
+
+	phydm_beamforming_notify(dm);
+
+	return true;
+}
+
+
+void
+phydm_beamforming_watchdog(
+	void		*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (beam_info->beamformee_su_cnt == 0)
+		return;
+
+	beamforming_dym_period(dm, 0);
+}
+enum beamforming_cap
+phydm_get_beamform_cap(
+	void			*dm_void
+)
+{
+	struct dm_struct                    *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info                     *sta = NULL;
+	struct bf_cmn_info                      *bf_info = NULL;
+	struct _RT_BEAMFORMING_INFO             *beam_info = &dm->beamforming_info;
+	void                         *adapter = dm->adapter;
+	enum beamforming_cap                     beamform_cap = BEAMFORMING_CAP_NONE;
+	u8                                       macid;
+	u8                                       ht_curbeamformcap = 0;
+	u16                                      vht_curbeamformcap = 0;
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PMGNT_INFO                              p_MgntInfo = &(((PADAPTER)(adapter))->MgntInfo);
+	PRT_VERY_HIGH_THROUGHPUT                p_vht_info = GET_VHT_INFO(p_MgntInfo);
+	PRT_HIGH_THROUGHPUT                     p_ht_info  = GET_HT_INFO(p_MgntInfo);
+
+	ht_curbeamformcap = p_ht_info->HtCurBeamform;
+	vht_curbeamformcap = p_vht_info->VhtCurBeamform;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s] WIN ht_curcap = %d ; vht_curcap = %d\n", __func__, ht_curbeamformcap, vht_curbeamformcap);
+
+	if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) /*We are Beamformee because the STA is Beamformer*/
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP));
+
+	/*We are Beamformer because the STA is Beamformee*/
+	if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP));
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+
+	/* We are Beamformee because the STA is SU Beamformer*/
+	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP));
+
+	/* We are Beamformer because the STA is SU Beamformee*/
+	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP));
+
+	/* We are Beamformee because the STA is MU Beamformer*/
+	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP));
+	#endif
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+
+		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		sta = dm->phydm_sta_info[macid];
+
+		if (!is_sta_active(sta))
+			continue;
+
+		bf_info = &sta->bf_info;
+		vht_curbeamformcap = bf_info->vht_beamform_cap;
+		ht_curbeamformcap  = bf_info->ht_beamform_cap;
+
+		if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) /*We are Beamformee because the STA is Beamformer*/
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP));
+
+		/*We are Beamformer because the STA is Beamformee*/
+		if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP));
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+		/* We are Beamformee because the STA is SU Beamformer*/
+		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP));
+
+		/* We are Beamformer because the STA is SU Beamformee*/
+		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP));
+
+		/* We are Beamformee because the STA is MU Beamformer*/
+		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP));
+	#endif
+}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s] CE ht_curcap = %d ; vht_curcap = %d\n", __func__, ht_curbeamformcap, vht_curbeamformcap);
+
+#endif
+
+return beamform_cap;
+
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_beamforming.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_beamforming.h
new file mode 100644
index 000000000000..9537a0a5f9de
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_beamforming.h
@@ -0,0 +1,411 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __INC_PHYDM_BEAMFORMING_H
+#define __INC_PHYDM_BEAMFORMING_H
+
+#ifndef BEAMFORMING_SUPPORT
+	#define	BEAMFORMING_SUPPORT		0
+#endif
+
+/*Beamforming Related*/
+#include "txbf/halcomtxbf.h"
+#include "txbf/haltxbfjaguar.h"
+#include "txbf/haltxbf8192e.h"
+#include "txbf/haltxbf8814a.h"
+#include "txbf/haltxbf8822b.h"
+#include "txbf/haltxbfinterface.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+#define eq_mac_addr(a,b)						( ((a)[0]==(b)[0] && (a)[1]==(b)[1] && (a)[2]==(b)[2] && (a)[3]==(b)[3] && (a)[4]==(b)[4] && (a)[5]==(b)[5]) ? 1:0 )
+#define cp_mac_addr(des,src)					((des)[0]=(src)[0],(des)[1]=(src)[1],(des)[2]=(src)[2],(des)[3]=(src)[3],(des)[4]=(src)[4],(des)[5]=(src)[5])
+
+#endif
+
+#define MAX_BEAMFORMEE_SU	2
+#define MAX_BEAMFORMER_SU	2
+#if (RTL8822B_SUPPORT == 1)
+	#define MAX_BEAMFORMEE_MU	6
+	#define MAX_BEAMFORMER_MU	1
+#else
+	#define MAX_BEAMFORMEE_MU	0
+	#define MAX_BEAMFORMER_MU	0
+#endif
+
+#define BEAMFORMEE_ENTRY_NUM		(MAX_BEAMFORMEE_SU + MAX_BEAMFORMEE_MU)
+#define BEAMFORMER_ENTRY_NUM		(MAX_BEAMFORMER_SU + MAX_BEAMFORMER_MU)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	/*for different naming between WIN and CE*/
+	#define BEACON_QUEUE	BCN_QUEUE_INX
+	#define NORMAL_QUEUE	MGT_QUEUE_INX
+	#define RT_DISABLE_FUNC RTW_DISABLE_FUNC
+	#define RT_ENABLE_FUNC RTW_ENABLE_FUNC
+#endif
+
+enum beamforming_entry_state {
+	BEAMFORMING_ENTRY_STATE_UNINITIALIZE,
+	BEAMFORMING_ENTRY_STATE_INITIALIZEING,
+	BEAMFORMING_ENTRY_STATE_INITIALIZED,
+	BEAMFORMING_ENTRY_STATE_PROGRESSING,
+	BEAMFORMING_ENTRY_STATE_PROGRESSED
+};
+
+
+enum beamforming_notify_state {
+	BEAMFORMING_NOTIFY_NONE,
+	BEAMFORMING_NOTIFY_ADD,
+	BEAMFORMING_NOTIFY_DELETE,
+	BEAMFORMEE_NOTIFY_ADD_SU,
+	BEAMFORMEE_NOTIFY_DELETE_SU,
+	BEAMFORMEE_NOTIFY_ADD_MU,
+	BEAMFORMEE_NOTIFY_DELETE_MU,
+	BEAMFORMING_NOTIFY_RESET
+};
+
+enum beamforming_cap {
+	BEAMFORMING_CAP_NONE = 0x0,
+	BEAMFORMER_CAP_HT_EXPLICIT = BIT(1),
+	BEAMFORMEE_CAP_HT_EXPLICIT = BIT(2),
+	BEAMFORMER_CAP_VHT_SU = BIT(5),			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_SU = BIT(6),			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP_VHT_MU = BIT(7),			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_MU = BIT(8),			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP = BIT(9),
+	BEAMFORMEE_CAP = BIT(10),
+};
+
+
+enum sounding_mode {
+	SOUNDING_SW_VHT_TIMER = 0x0,
+	SOUNDING_SW_HT_TIMER = 0x1,
+	sounding_stop_all_timer = 0x2,
+	SOUNDING_HW_VHT_TIMER = 0x3,
+	SOUNDING_HW_HT_TIMER = 0x4,
+	SOUNDING_STOP_OID_TIMER = 0x5,
+	SOUNDING_AUTO_VHT_TIMER = 0x6,
+	SOUNDING_AUTO_HT_TIMER = 0x7,
+	SOUNDING_FW_VHT_TIMER = 0x8,
+	SOUNDING_FW_HT_TIMER = 0x9,
+};
+
+struct _RT_BEAMFORM_STAINFO {
+	u8						*ra;
+	u16						aid;
+	u16						mac_id;
+	u8						my_mac_addr[6];
+	/*WIRELESS_MODE				wireless_mode;*/
+	enum channel_width				bw;
+	enum beamforming_cap			beamform_cap;
+	u8						ht_beamform_cap;
+	u16						vht_beamform_cap;
+	u8						cur_beamform;
+	u16						cur_beamform_vht;
+};
+
+
+struct _RT_BEAMFORMEE_ENTRY {
+	boolean is_used;
+	boolean	is_txbf;
+	boolean is_sound;
+	u16	aid;				/*Used to construct AID field of NDPA packet.*/
+	u16	mac_id;				/*Used to Set Reg42C in IBSS mode. */
+	u16	p_aid;				/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u8	g_id;				/*Used to fill Tx DESC*/
+	u8	my_mac_addr[6];
+	u8	mac_addr[6];			/*Used to fill Reg6E4 to fill Mac address of CSI report frame.*/
+	enum channel_width			sound_bw;		/*Sounding band_width*/
+	u16					sound_period;
+	enum beamforming_cap			beamform_entry_cap;
+	enum beamforming_entry_state	beamform_entry_state;
+	boolean						is_beamforming_in_progress;
+	/*u8	log_seq;									// Move to _RT_BEAMFORMER_ENTRY*/
+	/*u16	log_retry_cnt:3;		// 0~4				// Move to _RT_BEAMFORMER_ENTRY*/
+	/*u16	LogSuccessCnt:2;		// 0~2				// Move to _RT_BEAMFORMER_ENTRY*/
+	u16	log_status_fail_cnt:5;	/* 0~21 */
+	u16	default_csi_cnt:5;		/* 0~21 */
+	u8	csi_matrix[327];
+	u16	csi_matrix_len;
+	u8	num_of_sounding_dim;
+	u8	comp_steering_num_of_bfer;
+	u8	su_reg_index;
+	/*For MU-MIMO*/
+	boolean	is_mu_sta;
+	u8	mu_reg_index;
+	u8	gid_valid[8];
+	u8	user_position[16];
+};
+
+struct _RT_BEAMFORMER_ENTRY {
+	boolean			is_used;
+	/*P_AID of BFer entry is probably not used*/
+	u16				p_aid;					/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u8				g_id;
+	u8				my_mac_addr[6];
+	u8				mac_addr[6];
+	enum beamforming_cap		beamform_entry_cap;
+	u8				num_of_sounding_dim;
+	u8				clock_reset_times;		/*Modified by Jeffery @2015-04-10*/
+	u8				pre_log_seq;				/*Modified by Jeffery @2015-03-30*/
+	u8				log_seq;					/*Modified by Jeffery @2014-10-29*/
+	u16				log_retry_cnt:3;			/*Modified by Jeffery @2014-10-29*/
+	u16				log_success:2;			/*Modified by Jeffery @2014-10-29*/
+	u8				su_reg_index;
+	/*For MU-MIMO*/
+	boolean				is_mu_ap;
+	u8				gid_valid[8];
+	u8				user_position[16];
+	u16				aid;
+};
+
+struct _RT_SOUNDING_INFO {
+	u8			sound_idx;
+	enum channel_width	sound_bw;
+	enum sounding_mode	sound_mode;
+	u16			sound_period;
+};
+
+
+
+struct _RT_BEAMFORMING_OID_INFO {
+	u8			sound_oid_idx;
+	enum channel_width	sound_oid_bw;
+	enum sounding_mode	sound_oid_mode;
+	u16			sound_oid_period;
+};
+
+
+struct _RT_BEAMFORMING_INFO {
+	enum beamforming_cap			beamform_cap;
+	struct _RT_BEAMFORMEE_ENTRY		beamformee_entry[BEAMFORMEE_ENTRY_NUM];
+	struct _RT_BEAMFORMER_ENTRY		beamformer_entry[BEAMFORMER_ENTRY_NUM];
+	struct _RT_BEAMFORM_STAINFO		beamform_sta_info;
+	u8					beamformee_cur_idx;
+	struct phydm_timer_list					beamforming_timer;
+	struct phydm_timer_list					mu_timer;
+	struct _RT_SOUNDING_INFO			sounding_info;
+	struct _RT_BEAMFORMING_OID_INFO	beamforming_oid_info;
+	struct _HAL_TXBF_INFO			txbf_info;
+	u8					sounding_sequence;
+	u8					beamformee_su_cnt;
+	u8					beamformer_su_cnt;
+	u32					beamformee_su_reg_maping;
+	u32					beamformer_su_reg_maping;
+	/*For MU-MINO*/
+	u8					beamformee_mu_cnt;
+	u8					beamformer_mu_cnt;
+	u32					beamformee_mu_reg_maping;
+	u8					mu_ap_index;
+	boolean					is_mu_sounding;
+	u8					first_mu_bfee_index;
+	boolean					is_mu_sounding_in_progress;
+	boolean					dbg_disable_mu_tx;
+	boolean					apply_v_matrix;
+	boolean					snding3ss;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void				*source_adapter;
+#endif
+	/* Control register */
+	u32					reg_mu_tx_ctrl;		/* For USB/SDIO interfaces aync I/O */
+	u8					tx_bf_data_rate;
+	u8					last_usb_hub;
+};
+
+
+void
+phydm_get_txbf_device_num(
+	void	*dm_void,
+	u8	macid
+);
+
+struct _RT_NDPA_STA_INFO {
+	u16	aid:12;
+	u16	feedback_type:1;
+	u16	nc_index:3;
+};
+
+enum phydm_acting_type {
+	phydm_acting_as_ibss = 0,
+	phydm_acting_as_ap = 1
+};
+
+
+enum beamforming_cap
+phydm_beamforming_get_entry_beam_cap_by_mac_id(
+	void	*dm_void,
+	u8	mac_id
+);
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_bfee_entry_by_addr(
+	void		*dm_void,
+	u8		*RA,
+	u8		*idx
+);
+
+struct _RT_BEAMFORMER_ENTRY *
+phydm_beamforming_get_bfer_entry_by_addr(
+	void	*dm_void,
+	u8	*TA,
+	u8	*idx
+);
+
+void
+phydm_beamforming_notify(
+	void	*dm_void
+);
+
+boolean
+phydm_acting_determine(
+	void		*dm_void,
+	enum phydm_acting_type	type
+);
+
+void
+beamforming_enter(
+	void		*dm_void,
+	u16	sta_idx
+);
+
+void
+beamforming_leave(
+	void		*dm_void,
+	u8			*RA
+);
+
+boolean
+beamforming_start_fw(
+	void			*dm_void,
+	u8			idx
+);
+
+void
+beamforming_check_sounding_success(
+	void			*dm_void,
+	boolean			status
+);
+
+void
+phydm_beamforming_end_sw(
+	void		*dm_void,
+	boolean			status
+);
+
+void
+beamforming_timer_callback(
+	void			*dm_void
+);
+
+void
+phydm_beamforming_init(
+	void		*dm_void
+);
+
+
+
+enum beamforming_cap
+phydm_beamforming_get_beam_cap(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+);
+
+enum beamforming_cap
+phydm_get_beamform_cap(
+	void			*dm_void
+);
+
+boolean
+beamforming_control_v1(
+	void			*dm_void,
+	u8			*RA,
+	u8			AID,
+	u8			mode,
+	enum channel_width	BW,
+	u8			rate
+);
+
+
+boolean
+phydm_beamforming_control_v2(
+	void		*dm_void,
+	u8			idx,
+	u8			mode,
+	enum channel_width	BW,
+	u16			period
+);
+
+void
+phydm_beamforming_watchdog(
+	void		*dm_void
+);
+
+void
+beamforming_sw_timer_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct phydm_timer_list		*timer
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void *function_context
+#endif
+);
+
+boolean
+beamforming_send_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW,
+	u8			q_idx
+);
+
+
+boolean
+beamforming_send_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW,
+	u8			q_idx
+);
+
+#else
+#define beamforming_gid_paid(adapter, tcb)
+#define	phydm_acting_determine(dm, type)	false
+#define beamforming_enter(dm, sta_idx)
+#define beamforming_leave(dm, RA)
+#define beamforming_end_fw(dm)
+#define beamforming_control_v1(dm, RA, AID, mode, BW, rate)		true
+#define beamforming_control_v2(dm, idx, mode, BW, period)		true
+#define phydm_beamforming_end_sw(dm, _status)
+#define beamforming_timer_callback(dm)
+#define phydm_beamforming_init(dm)
+#define phydm_beamforming_control_v2(dm, _idx, _mode, _BW, _period)	false
+#define beamforming_watchdog(dm)
+#define phydm_beamforming_watchdog(dm)
+
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cck_pd.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cck_pd.c
new file mode 100644
index 000000000000..87b41dad9fb6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cck_pd.c
@@ -0,0 +1,471 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+ 
+#ifdef PHYDM_SUPPORT_CCKPD
+
+void
+phydm_write_cck_cca_th_new_cs_ratio(
+	void			*dm_void,
+	u8			cca_th,
+	u8			cca_th_aaa
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "[New] pd_th=0x%x, cs_ratio=0x%x\n\n", cca_th, cca_th_aaa);
+
+	if (cckpd_t->cur_cck_cca_thres != cca_th) {
+		
+		cckpd_t->cur_cck_cca_thres = cca_th;
+		odm_set_bb_reg(dm, 0xa08, 0xf0000, cca_th);
+		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+		
+	}
+
+	if (cckpd_t->cck_cca_th_aaa != cca_th_aaa) {
+		
+		cckpd_t->cck_cca_th_aaa = cca_th_aaa;
+		odm_set_bb_reg(dm, 0xaa8, 0x1f0000, cca_th_aaa);
+		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+	}
+	
+}
+
+void
+phydm_write_cck_cca_th(
+	void			*dm_void,
+	u8			cca_th
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "New cck_cca_th=((0x%x))\n\n", cca_th);
+
+	if (cckpd_t->cur_cck_cca_thres != cca_th) {
+		
+		odm_write_1byte(dm, ODM_REG(CCK_CCA, dm), cca_th);
+		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+	}
+	cckpd_t->cur_cck_cca_thres = cca_th;
+}
+
+void
+phydm_set_cckpd_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+
+	if (val_len != 2) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][CCKPD]Need val_len=2\n");
+		return;
+	}
+	
+	/*val_buf[0]: 0xa0a*/
+	/*val_buf[1]: 0xaaa*/
+	
+	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC) {
+		phydm_write_cck_cca_th_new_cs_ratio(dm, (u8)val_buf[0], (u8)val_buf[1]);
+	} else {
+		phydm_write_cck_cca_th(dm, (u8)val_buf[0]);
+	}
+
+}
+
+boolean
+phydm_stop_cck_pd_th(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT))) {
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Not Support\n");
+
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+		#ifdef MCR_WIRELESS_EXTEND
+		phydm_write_cck_cca_th(dm, 0x43);
+		#endif
+		#endif
+		
+		return true;
+	}
+
+	if (dm->pause_ability & ODM_BB_CCK_PD) {
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: Pause CCKPD in LV=%d\n", dm->pause_lv_table.lv_cckpd);
+		return true;
+	}
+
+	#if 0/*(DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))*/
+	if (dm->ext_lna)
+		return true;
+	#endif
+
+	return false;
+	
+}
+
+void
+phydm_cckpd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	u8	cur_cck_cca_th= cckpd_t->cur_cck_cca_thres;
+
+	if (dm->is_linked) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+
+		/*Add hp_hw_id condition due to 22B LPS power consumption issue and [PCIE-1596]*/
+		if (dm->hp_hw_id && (dm->traffic_load == TRAFFIC_ULTRA_LOW))
+			cur_cck_cca_th = 0x40;
+		else if (dm->rssi_min > 35)
+			cur_cck_cca_th = 0xcd;
+		else if (dm->rssi_min > 20) {
+			
+			if (cckpd_t->cck_fa_ma > 500)
+				cur_cck_cca_th = 0xcd;
+			else if (cckpd_t->cck_fa_ma < 250)
+				cur_cck_cca_th = 0x83;
+			
+		} else {
+			if((dm->p_advance_ota & PHYDM_ASUS_OTA_SETTING) && (cckpd_t->cck_fa_ma > 200))
+				cur_cck_cca_th = 0xc3; /*for ASUS OTA test*/
+			else
+				cur_cck_cca_th = 0x83;
+		}
+		
+#else	/*ODM_AP*/
+		if (dig_t->cur_ig_value > 0x32)
+			cur_cck_cca_th = 0xed;
+		else if (dig_t->cur_ig_value > 0x2a)
+			cur_cck_cca_th = 0xdd;
+		else if (dig_t->cur_ig_value > 0x24)
+			cur_cck_cca_th = 0xcd;
+		else 
+			cur_cck_cca_th = 0x83;
+		
+#endif
+	} else {
+	
+		if (cckpd_t->cck_fa_ma > 1000)
+			cur_cck_cca_th = 0x83;
+		else if (cckpd_t->cck_fa_ma < 500)
+			cur_cck_cca_th = 0x40;
+	}
+
+	phydm_write_cck_cca_th(dm, cur_cck_cca_th);
+	/*PHYDM_DBG(dm, DBG_CCKPD, "New cck_cca_th=((0x%x))\n\n", cur_cck_cca_th);*/
+
+}
+
+void
+phydm_cckpd_new_cs_ratio(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	u8	pd_th = 0, cs_ration = 0, cs_2r_offset = 0;
+	u8	igi_curr = dig_t->cur_ig_value;
+	u8	en_2rcca;
+	boolean is_update = true;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	en_2rcca = (u8)(odm_get_bb_reg(dm, 0xa2c, BIT(18)) && odm_get_bb_reg(dm, 0xa2c, BIT(22)));
+
+	if (dm->is_linked) {
+		
+		if ((igi_curr > 0x38) && (dm->rssi_min > 32)) {
+			cs_ration = dig_t->aaa_default + AAA_BASE + AAA_STEP * 2;
+			cs_2r_offset = 5;
+			pd_th = 0xd;
+		} else if ((igi_curr > 0x2a) && (dm->rssi_min > 32)) {
+			cs_ration = dig_t->aaa_default + AAA_BASE + AAA_STEP;
+			cs_2r_offset = 4;
+			pd_th = 0xd;
+		} else if ((igi_curr > 0x24) || (dm->rssi_min > 24 && dm->rssi_min <= 30)) {
+			cs_ration = dig_t->aaa_default + AAA_BASE;
+			cs_2r_offset = 3;
+			pd_th = 0xd;
+		} else if ((igi_curr <= 0x24) || (dm->rssi_min < 22)) {
+			
+			if (cckpd_t->cck_fa_ma > 1000) {
+				cs_ration = dig_t->aaa_default + AAA_STEP;
+				cs_2r_offset = 1;
+				pd_th = 0x7;
+			} else if (cckpd_t->cck_fa_ma < 500) {
+				cs_ration = dig_t->aaa_default;
+				pd_th = 0x3;
+			} else {
+				is_update = false;
+				cs_ration = cckpd_t->cck_cca_th_aaa;
+				pd_th = cckpd_t->cur_cck_cca_thres;
+			}
+		}
+	} else {
+	
+		if (cckpd_t->cck_fa_ma > 1000) {
+			cs_ration = dig_t->aaa_default + AAA_STEP;
+			cs_2r_offset = 1;
+			pd_th = 0x7;
+		} else if (cckpd_t->cck_fa_ma < 500) {
+			cs_ration = dig_t->aaa_default;
+			pd_th = 0x3;
+		} else {
+			is_update = false;
+			cs_ration = cckpd_t->cck_cca_th_aaa;
+			pd_th = cckpd_t->cur_cck_cca_thres;
+		}
+	}
+	
+	if (en_2rcca)
+		cs_ration = (cs_ration >= cs_2r_offset) ? (cs_ration - cs_2r_offset) : 0;
+
+	PHYDM_DBG(dm, DBG_CCKPD, 
+	"[New] cs_ratio=0x%x, pd_th=0x%x\n", cs_ration, pd_th);
+
+	if (is_update) {
+		cckpd_t->cur_cck_cca_thres = pd_th;
+		cckpd_t->cck_cca_th_aaa = cs_ration;
+		odm_set_bb_reg(dm, 0xa08, 0xf0000, pd_th);
+		odm_set_bb_reg(dm, 0xaa8, 0x1f0000, cs_ration);
+	}
+	/*phydm_write_cck_cca_th_new_cs_ratio(dm, pd_th, cs_ration);*/
+}
+
+#endif
+
+void
+phydm_cck_pd_th(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct		*fa_t= &dm->false_alm_cnt;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	u32	cnt_cck_fail_tmp = fa_t->cnt_cck_fail;
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct	*fa_acc_t = &dm->false_alm_cnt_acc;
+	#endif
+	
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	if (phydm_stop_cck_pd_th(dm) == true)
+		return;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	cnt_cck_fail_tmp = (dm->original_dig_restore) ? (fa_t->cnt_cck_fail) : (fa_acc_t->cnt_cck_fail_1sec);
+#endif
+	
+	if (cckpd_t->cck_fa_ma == CCK_FA_MA_RESET)
+		cckpd_t->cck_fa_ma = cnt_cck_fail_tmp;
+	else {
+		cckpd_t->cck_fa_ma = ((cckpd_t->cck_fa_ma << 1) +
+									cckpd_t->cck_fa_ma + cnt_cck_fail_tmp) >> 2;
+	}
+	
+	PHYDM_DBG(dm, DBG_CCKPD, "CCK FA=%d\n", cckpd_t->cck_fa_ma);
+
+	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC)
+		phydm_cckpd_new_cs_ratio(dm);
+	else
+		phydm_cckpd(dm);
+	
+#endif
+}
+
+void
+odm_pause_cck_packet_detection(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type,
+	enum phydm_pause_level		pause_lv,
+	u8					cck_pd_th
+)
+{
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	s8	max_level;
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	if ((cckpd_t->pause_bitmap == 0) &&
+		(!(dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT)))) {
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: not support\n");
+		return;
+	}
+
+	if (pause_lv >= PHYDM_PAUSE_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: Wrong LV !\n");
+		return;
+	}
+	PHYDM_DBG(dm, DBG_CCKPD, "Set pause{Type, LV, val} = {%d, %d, 0x%x}\n", 
+		pause_type, pause_lv, cck_pd_th);
+
+	PHYDM_DBG(dm, DBG_CCKPD, "pause LV=0x%x\n", cckpd_t->pause_bitmap);
+
+	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
+		PHYDM_DBG(dm, DBG_CCKPD, "pause val[%d]=0x%x\n", 
+										i, cckpd_t->pause_cckpd_value[i]);
+	}
+
+	switch (pause_type) {
+	case PHYDM_PAUSE:
+	{
+		/* Disable CCK PD */
+		dm->support_ability &= ~ODM_BB_CCK_PD;
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Pause CCK PD th\n");
+
+		/* Backup original CCK PD threshold decided by CCK PD mechanism */
+		if (cckpd_t->pause_bitmap == 0) {
+			
+			cckpd_t->cckpd_bkp = cckpd_t->cur_cck_cca_thres;
+			
+			PHYDM_DBG(dm, DBG_CCKPD, "cckpd_bkp=0x%x\n", 
+				cckpd_t->cckpd_bkp);
+		}
+
+		cckpd_t->pause_bitmap |= BIT(pause_lv); /* Update pause level */
+		cckpd_t->pause_cckpd_value[pause_lv] = cck_pd_th; 
+
+		/* Write new CCK PD threshold */
+		if (BIT(pause_lv + 1) > cckpd_t->pause_bitmap) {
+			PHYDM_DBG(dm, DBG_CCKPD, "> ori pause LV=0x%x\n", 
+				cckpd_t->pause_bitmap);
+			
+			phydm_write_cck_cca_th(dm, cck_pd_th);
+		}
+		break;
+	}
+	case PHYDM_RESUME:
+	{
+		/* check if the level is illegal or not */
+		if ((cckpd_t->pause_bitmap & (BIT(pause_lv))) != 0) {
+			
+			cckpd_t->pause_bitmap &= (~(BIT(pause_lv)));
+			cckpd_t->pause_cckpd_value[pause_lv] = 0;
+			PHYDM_DBG(dm, DBG_CCKPD, "Resume CCK PD\n");
+		} else {
+		
+			PHYDM_DBG(dm, DBG_CCKPD, "Wrong resume LV\n");
+			break;
+		}
+
+		/* Resume CCKPD */
+		if (cckpd_t->pause_bitmap == 0) {
+			
+			PHYDM_DBG(dm, DBG_CCKPD, "Revert bkp_CCKPD=0x%x\n", 
+														cckpd_t->cckpd_bkp);
+			
+			phydm_write_cck_cca_th(dm, cckpd_t->cckpd_bkp);
+			dm->support_ability |= ODM_BB_CCK_PD;/* Enable CCKPD */
+			break;
+		}
+
+		if (BIT(pause_lv) <= cckpd_t->pause_bitmap)
+			break;
+
+		/* Calculate the maximum level now */
+		for (max_level = (pause_lv - 1); max_level >= 0; max_level--) {
+			if (cckpd_t->pause_bitmap & BIT(max_level))
+				break;
+		}
+
+		/* write CCKPD of lower level */
+		phydm_write_cck_cca_th(dm, cckpd_t->pause_cckpd_value[max_level]);
+		PHYDM_DBG(dm, DBG_CCKPD, "Write CCKPD=0x%x for max_LV=%d\n",
+			cckpd_t->pause_cckpd_value[max_level], max_level);
+		break;
+	}
+	default:
+		PHYDM_DBG(dm, DBG_CCKPD, "Wrong  type\n");
+		break;
+	}
+
+	PHYDM_DBG(dm, DBG_CCKPD, "New pause bitmap=0x%x\n", 
+													cckpd_t->pause_bitmap);
+	
+	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
+		PHYDM_DBG(dm, DBG_CCKPD, "pause val[%d]=0x%x\n", 
+										i, cckpd_t->pause_cckpd_value[i]);
+	}
+#endif
+}
+
+void
+phydm_cck_pd_init(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct		*cckpd_t = &dm->dm_cckpd_table;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+
+	cckpd_t->cur_cck_cca_thres = 0;
+	cckpd_t->cck_cca_th_aaa = 0;
+	
+	cckpd_t->pause_bitmap = 0;
+
+	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC) {
+		dig_t->aaa_default = odm_read_1byte(dm, 0xaaa) & 0x1f;
+		dig_t->a0a_default = (u8)odm_get_bb_reg(dm, R_0xa08, 0xff0000);
+		cckpd_t->cck_cca_th_aaa = dig_t->aaa_default;
+		cckpd_t->cur_cck_cca_thres = dig_t->a0a_default;
+	} else {
+		dig_t->a0a_default = (u8)odm_get_bb_reg(dm, R_0xa08, 0xff0000);
+		cckpd_t->cur_cck_cca_thres = dig_t->a0a_default;
+	}
+
+	odm_memory_set(dm, cckpd_t->pause_cckpd_value, 0, PHYDM_PAUSE_MAX_NUM);
+#endif
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cck_pd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cck_pd.h
new file mode 100644
index 000000000000..e56f76892d4e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cck_pd.h
@@ -0,0 +1,94 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_CCK_PD_H__
+#define    __PHYDM_CCK_PD_H__
+
+#define CCK_PD_VERSION	"1.0"		/* 2017.05.09  Dino, Add phydm_cck_pd.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+#define	AAA_BASE	4
+#define	AAA_STEP	2
+
+#define	CCK_FA_MA_RESET	0xffffffff
+
+#define	EXTEND_CCK_CCATH_AAA_IC	(ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8723D |ODM_RTL8710B)
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+#ifdef PHYDM_SUPPORT_CCKPD
+struct phydm_cckpd_struct {
+	u8		cur_cck_cca_thres; /*0xA0A*/
+	u8		cck_cca_th_aaa; /*0xAAA*/
+	u32		cck_fa_ma;
+	u8		cckpd_bkp;
+	u32		rvrt_val[2];
+	u8		pause_bitmap;/*will be removed*/
+	u8		pause_lv;
+	u8		pause_cckpd_value[PHYDM_PAUSE_MAX_NUM]; /*will be removed*/
+};
+#endif
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_set_cckpd_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+void
+phydm_cck_pd_th(
+	void		*dm_void
+);
+
+void
+odm_pause_cck_packet_detection(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type,
+	enum phydm_pause_level		pause_level,
+	u8					cck_pd_threshold
+);
+
+void
+phydm_cck_pd_init(
+	void		*dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_ccx.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_ccx.c
new file mode 100644
index 000000000000..8335b1d616d3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_ccx.c
@@ -0,0 +1,2081 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_ccx_hw_restart(
+	void			*dm_void
+)/*Will Restart NHM/CLM/FAHM simultaneously*/
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32	reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? R_0x994 : R_0x890;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	odm_set_bb_reg(dm, reg1, 0x7, 0x0); /*disable NHM,CLM, FAHM*/
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x994, BIT(8), 0x0);
+		odm_set_bb_reg(dm, R_0x994, BIT(8), 0x1);
+
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0x890, BIT(8), 0x0);
+		odm_set_bb_reg(dm, R_0x890, BIT(8), 0x1);
+	}
+}
+
+#ifdef FAHM_SUPPORT
+
+u16
+phydm_hw_divider(
+	void	*dm_void,
+	u16	numerator,
+	u16	denumerator
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16	result = DEVIDER_ERROR;
+	u32	tmp_u32 = ((numerator << 16) | denumerator);
+	u32	reg_devider_input;
+	u32	reg_devider_rpt;
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg_devider_input =  0x1cbc;
+		reg_devider_rpt = 0x1f98;
+	} else {
+		reg_devider_input =  0x980;
+		reg_devider_rpt = 0x9f0;
+	}
+
+	odm_set_bb_reg(dm, reg_devider_input, MASKDWORD, tmp_u32);
+
+	for (i = 0; i < 10; i++) {
+		ODM_delay_ms(1);
+		if (odm_get_bb_reg(dm, reg_devider_rpt, BIT(24))) { /*Chk HW rpt is ready*/
+			
+			result = (u16)odm_get_bb_reg(dm, reg_devider_rpt, MASKBYTE2);
+			break;
+		}
+	}
+	return	result;
+}
+
+void
+phydm_fahm_trigger(
+	void		*dm_void,
+	u16		trigger_period	/*unit (4us)*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u32		fahm_reg1;
+	u32		fahm_reg2;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x1cf8, 0xffff00, trigger_period);
+		
+		fahm_reg1 =  0x994;
+	} else {
+	
+		odm_set_bb_reg(dm, R_0x978, 0xff000000, (trigger_period & 0xff));		
+		odm_set_bb_reg(dm, R_0x97c, 0xff, (trigger_period & 0xff00)>>8);
+		
+		fahm_reg1 =  0x890;
+	}
+
+	odm_set_bb_reg(dm, fahm_reg1, BIT(2), 0);
+	odm_set_bb_reg(dm, fahm_reg1, BIT(2), 1);
+}
+
+void
+phydm_fahm_set_valid_cnt(
+	void		*dm_void,
+	u8		numerator_sel,
+	u8		denumerator_sel
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u32		fahm_reg1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if ((ccx_info->fahm_nume_sel == numerator_sel) && 
+		(ccx_info->fahm_denum_sel == denumerator_sel)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "no need to update\n");
+		return;
+	}
+
+	ccx_info->fahm_nume_sel = numerator_sel;
+	ccx_info->fahm_denum_sel = denumerator_sel;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		fahm_reg1 =  0x994;
+	} else {
+		fahm_reg1 =  0x890;
+	}
+
+	odm_set_bb_reg(dm, fahm_reg1, 0xe0, numerator_sel);
+	odm_set_bb_reg(dm, fahm_reg1, 0x7000, denumerator_sel);
+}
+
+void
+phydm_fahm_get_result(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u16		fahm_rpt_cnt[12];	/*packet count*/
+	u16		fahm_rpt[12];		/*percentage*/
+	u16		fahm_denumerator;	/*packet count*/
+	u32		reg_rpt, reg_rpt_2;
+	u32		reg_val_tmp;
+	boolean	is_ready = false;
+	u8		i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg_rpt =  0x1f80;
+		reg_rpt_2 = 0x1f98;
+	} else {
+		reg_rpt =  0x9d8;
+		reg_rpt_2 = 0x9f0;
+	}
+
+	for (i = 0; i < 3; i++) {
+		
+		if (odm_get_bb_reg(dm, reg_rpt_2, BIT(31))) { /*Chk HW rpt is ready*/
+			
+			is_ready = true;
+			break;
+		}
+		ODM_delay_ms(1);
+	}
+
+	if (is_ready == false)
+		return;
+
+	/*Get Denumerator*/
+	fahm_denumerator = (u16)odm_get_bb_reg(dm, reg_rpt_2, MASKLWORD);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Reg[0x%x] fahm_denmrtr = %d\n", reg_rpt_2, fahm_denumerator);
+	
+
+	/*Get nemerator*/
+	for (i = 0; i<6; i++) {
+		reg_val_tmp = odm_get_bb_reg(dm, reg_rpt + (i<<2), MASKDWORD);
+		
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Reg[0x%x] fahm_denmrtr = %d\n", reg_rpt + (i*4), reg_val_tmp);
+		
+		fahm_rpt_cnt[i*2] = (u16)(reg_val_tmp & MASKLWORD);
+		fahm_rpt_cnt[i*2 +1] = (u16)((reg_val_tmp & MASKHWORD)>>16);
+	}
+
+	for (i = 0; i<12; i++) {
+		fahm_rpt[i] = phydm_hw_divider(dm, fahm_rpt_cnt[i], fahm_denumerator);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RPT_cnt[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
+		  fahm_rpt_cnt[11], fahm_rpt_cnt[10], fahm_rpt_cnt[9],
+		  fahm_rpt_cnt[8], fahm_rpt_cnt[7], fahm_rpt_cnt[6], 
+		  fahm_rpt_cnt[5], fahm_rpt_cnt[4], fahm_rpt_cnt[3],
+		  fahm_rpt_cnt[2], fahm_rpt_cnt[1], fahm_rpt_cnt[0]);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RPT[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
+		  fahm_rpt[11], fahm_rpt[10], fahm_rpt[9], fahm_rpt[8],
+		  fahm_rpt[7], fahm_rpt[6], 
+		  fahm_rpt[5], fahm_rpt[4], fahm_rpt[3], fahm_rpt[2],
+		  fahm_rpt[1], fahm_rpt[0]);
+	
+}
+
+void
+phydm_fahm_set_th_by_igi(
+	void		*dm_void,
+	u8		igi
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u8	fahm_th[11];
+	u8	rssi_th[11];	/*in RSSI scale*/
+	u8	th_gap = 2 * IGI_TO_NHM_TH_MULTIPLIER;	/*beacuse unit is 0.5dB for FAHM*/
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if (ccx_info->env_mntr_igi == igi) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "No need to update FAHM_th, IGI=0x%x\n", ccx_info->env_mntr_igi);
+		return;
+	}
+
+	ccx_info->env_mntr_igi = igi;	/*bkp IGI*/
+
+	if (igi >= CCA_CAP) 
+		fahm_th[0] = (igi - CCA_CAP) * IGI_TO_NHM_TH_MULTIPLIER;
+	else
+		fahm_th[0] = 0;
+	
+	rssi_th[0] = igi -10 - CCA_CAP;
+	
+	for (i = 1; i <= 10; i++) {
+		fahm_th[i] = fahm_th[0] + th_gap * i;
+		rssi_th[i] = rssi_th[0] +  (i<<1);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RSSI_th[10:0]=[%d, %d, %d, (IGI)%d, %d, %d, %d, %d, %d, %d, %d]\n",
+		  rssi_th[10], rssi_th[9], rssi_th[8], rssi_th[7], rssi_th[6],
+		  rssi_th[5], rssi_th[4], rssi_th[3], rssi_th[2], rssi_th[1],
+		  rssi_th[0]);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		odm_set_bb_reg(dm, R_0x1c38, 0xffffff00, ((fahm_th[2]<<24) |(fahm_th[1]<<16) | (fahm_th[0]<<8)));
+		odm_set_bb_reg(dm, R_0x1c78, 0xffffff00, ((fahm_th[5]<<24) |(fahm_th[4]<<16) | (fahm_th[3]<<8)));
+		odm_set_bb_reg(dm, R_0x1c7c, 0xffffff00, ((fahm_th[7]<<24) |(fahm_th[6]<<16)));
+		odm_set_bb_reg(dm, R_0x1cb8, 0xffffff00, ((fahm_th[10]<<24) |(fahm_th[9]<<16) | (fahm_th[8]<<8)));
+	} else {
+		odm_set_bb_reg(dm, R_0x970, MASKDWORD, ((fahm_th[3]<<24) |(fahm_th[2]<<16) | (fahm_th[1]<<8) | fahm_th[0]));
+		odm_set_bb_reg(dm, R_0x974, MASKDWORD, ((fahm_th[7]<<24) |(fahm_th[6]<<16) | (fahm_th[5]<<8) | fahm_th[4]));
+		odm_set_bb_reg(dm, R_0x978, MASKDWORD, ((fahm_th[10]<<16) | (fahm_th[9]<<8) | fahm_th[8]));
+	}	
+}
+
+void
+phydm_fahm_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u32	fahm_reg1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x\n", dm->dm_dig_table.cur_ig_value);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		fahm_reg1 =  0x994;
+	} else {
+		fahm_reg1 =  0x890;
+	}
+
+	ccx_info->fahm_period = 65535;
+	
+	odm_set_bb_reg(dm, fahm_reg1, 0x6, 3);	/*FAHM HW block enable*/
+	
+	phydm_fahm_set_valid_cnt(dm, FAHM_INCLD_FA, (FAHM_INCLD_FA| FAHM_INCLD_CRC_OK |FAHM_INCLD_CRC_ER));
+	phydm_fahm_set_th_by_igi(dm, dm->dm_dig_table.cur_ig_value);
+}
+
+void
+phydm_fahm_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx_info = &dm->dm_ccx_info;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i;
+
+	for (i = 0; i < 2; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+	}
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "{1: trigger, 2:get result}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "{3: MNTR mode sel} {1: driver, 2. FW}\n");
+		return;
+	} else if (var1[0] == 1) { /* Set & trigger CLM */
+		
+		phydm_fahm_set_th_by_igi(dm, dm->dm_dig_table.cur_ig_value);
+		phydm_fahm_trigger(dm, ccx_info->fahm_period);
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Monitor FAHM for %d * 4us\n",
+			       ccx_info->fahm_period);
+		
+	} else if (var1[0] == 2) { /* Get CLM results */
+
+		phydm_fahm_get_result(dm);
+		PDM_SNPF(out_len, used, output + used, out_len - used,"FAHM_result=%d us\n",
+			       (ccx_info->clm_result<<2));
+
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Error\n");
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif /*#ifdef FAHM_SUPPORT*/
+
+#ifdef NHM_SUPPORT
+
+void
+phydm_nhm_racing_release(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	value32;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "lv:(%d)->(0)\n", ccx->nhm_set_lv);
+	
+	ccx->nhm_ongoing = false;
+	ccx->nhm_set_lv = NHM_RELEASE;
+
+	if (!((ccx->nhm_app == NHM_BACKGROUND) || (ccx->nhm_app == NHM_ACS)))
+		phydm_pause_func(dm, F00_DIG, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, 1, &value32);
+	
+	ccx->nhm_app = NHM_BACKGROUND;
+}
+
+u8
+phydm_nhm_racing_ctrl(
+	void			*dm_void,
+	enum phydm_nhm_level	 nhm_lv
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u8	set_result = PHYDM_SET_SUCCESS;
+	/*acquire to control NHM API*/
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_ongoing=%d, lv:(%d)->(%d)\n", 
+		  ccx->nhm_ongoing, ccx->nhm_set_lv, nhm_lv);
+	if (ccx->nhm_ongoing) {
+		if (nhm_lv <= ccx->nhm_set_lv) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			phydm_ccx_hw_restart(dm);
+			ccx->nhm_ongoing = false;
+		}
+	}
+	
+	if (set_result)
+		ccx->nhm_set_lv = nhm_lv;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm racing success=%d\n", set_result);
+	return set_result;
+}
+
+
+void
+phydm_nhm_trigger(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	nhm_reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? 0x994 : 0x890;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	
+	/*Trigger NHM*/
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 0);
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 1);
+	ccx->nhm_trigger_time = dm->phydm_sys_up_time;
+	ccx->nhm_rpt_stamp++;
+	ccx->nhm_ongoing = true;
+}
+
+boolean
+phydm_nhm_check_rdy(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	boolean	is_ready = false;
+	u32		reg1 = 0, reg1_bit = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 =  0xfb4;
+		reg1_bit = 16;
+	} else {
+		reg1 =  0x8b4;
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			reg1_bit = 25;	
+		} else {
+			reg1_bit = 17;
+		}
+	}
+
+	if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit)))
+		is_ready = true;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM rdy=%d\n", is_ready);
+	return is_ready;
+}
+
+void
+phydm_nhm_get_utility(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	
+	if (ccx->nhm_rpt_sum >= ccx->nhm_result[0])
+		ccx->nhm_ratio = (u8)(((ccx->nhm_rpt_sum - ccx->nhm_result[0]) * 100) >> 8);
+	else {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[warning] nhm_rpt_sum invalid\n");
+		ccx->nhm_ratio = 0;
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_ratio=%d\n", ccx->nhm_ratio);
+}
+
+boolean
+phydm_nhm_get_result(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx = &dm->dm_ccx_info;
+	u32			value32;
+	u8			i;
+	u32	nhm_reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? 0x994 : 0x890;
+	u16	nhm_rpt_sum_tmp = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 0);
+
+	if (phydm_nhm_check_rdy(dm) == false) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM report Fail\n");
+		phydm_nhm_racing_release(dm);
+		return false;
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		value32 = odm_read_4byte(dm, 0xfa8);
+		odm_move_memory(dm, &ccx->nhm_result[0], &value32, 4);
+
+		value32 = odm_read_4byte(dm, 0xfac);
+		odm_move_memory(dm, &ccx->nhm_result[4], &value32, 4);
+
+		value32 = odm_read_4byte(dm, 0xfb0);
+		odm_move_memory(dm, &ccx->nhm_result[8], &value32, 4);
+
+		/*Get NHM duration*/
+		value32 = odm_read_4byte(dm, 0xfb4);
+		ccx->nhm_duration = (u16)(value32 & MASKLWORD);
+	} else {
+		value32 = odm_read_4byte(dm, 0x8d8);
+		odm_move_memory(dm, &ccx->nhm_result[0], &value32, 4);
+
+		value32 = odm_read_4byte(dm, 0x8dc);
+		odm_move_memory(dm, &ccx->nhm_result[4], &value32, 4);
+
+		value32 = odm_get_bb_reg(dm, R_0x8d0, 0xffff0000);
+		odm_move_memory(dm, &ccx->nhm_result[8], &value32, 2);
+
+		value32 = odm_read_4byte(dm, 0x8d4);
+		/*odm_move_memory(dm, &ccx->nhm_result[10], (&value32 + 2), 2);*/
+		ccx->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
+		
+		/*Get NHM duration*/
+		ccx->nhm_duration = (u16)(value32 & MASKLWORD);
+	}
+
+	/* sum all nhm_result */	
+	if (ccx->nhm_period >= 65530) {
+		value32 = (ccx->nhm_duration * 100) >> 16;
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM valid time = %d, valid: %d percent\n", ccx->nhm_duration, value32);
+	}
+
+	for (i = 0; i < NHM_RPT_NUM; i++)
+		nhm_rpt_sum_tmp += (u16)ccx->nhm_result[i];
+
+	ccx->nhm_rpt_sum = (u8)nhm_rpt_sum_tmp;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM_Rpt[%d](H->L)[%d %d %d %d %d %d %d %d %d %d %d %d]\n",
+		ccx->nhm_rpt_stamp,
+		ccx->nhm_result[11], ccx->nhm_result[10], ccx->nhm_result[9],
+		ccx->nhm_result[8], ccx->nhm_result[7], ccx->nhm_result[6],
+		ccx->nhm_result[5], ccx->nhm_result[4], ccx->nhm_result[3],
+		ccx->nhm_result[2], ccx->nhm_result[1], ccx->nhm_result[0]);
+
+	phydm_nhm_racing_release(dm);
+
+	if (nhm_rpt_sum_tmp > 255) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[Warning] Invalid NHM RPT, total=%d\n",
+			  nhm_rpt_sum_tmp);
+		return false;
+	}
+
+	return true;
+}
+
+void
+phydm_nhm_set_th_reg(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	u32	reg1 = 0,  reg2 = 0, reg3 = 0, reg4 = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = 0x994;
+		reg2 = 0x998;
+		reg3 = 0x99c;
+		reg4 = 0x9a0;
+	} else {
+		reg1 = 0x890;
+		reg2 = 0x898;
+		reg3 = 0x89c;
+		reg4 = 0xe28;
+	}
+	
+	/*Set NHM threshold*/ /*Unit: PWdB U(8,1)*/
+	pdm_set_reg(dm, reg2, MASKDWORD, BYTE_2_DWORD(ccx->nhm_th[3], ccx->nhm_th[2], ccx->nhm_th[1], ccx->nhm_th[0]));
+	pdm_set_reg(dm, reg3, MASKDWORD, BYTE_2_DWORD(ccx->nhm_th[7], ccx->nhm_th[6], ccx->nhm_th[5], ccx->nhm_th[4]));
+	pdm_set_reg(dm, reg4, MASKBYTE0, ccx->nhm_th[8]);
+	pdm_set_reg(dm, reg1, 0xffff0000, BYTE_2_DWORD(0, 0, ccx->nhm_th[10], ccx->nhm_th[9]));
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Update NHM_th[H->L]=[%d %d %d %d %d %d %d %d %d %d %d]\n",
+		ccx->nhm_th[10], ccx->nhm_th[9], ccx->nhm_th[8],ccx->nhm_th[7], 
+		ccx->nhm_th[6], ccx->nhm_th[5],ccx->nhm_th[4], ccx->nhm_th[3], 
+		ccx->nhm_th[2], ccx->nhm_th[1], ccx->nhm_th[0]);
+}
+
+boolean
+phydm_nhm_th_update_chk(
+	void		*dm_void,
+	enum nhm_application	nhm_app,
+	u8	*nhm_th,
+	u32	*igi_new
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	boolean	is_update = false;
+	u8	igi_curr = dm->dm_dig_table.cur_ig_value;
+	u8	nhm_igi_th_11k_low[NHM_TH_NUM] = {0x12, 0x15, 0x18, 0x1b, 0x1e, 0x23, 0x28, 0x2c, 0x78, 0x78, 0x78};
+	u8	nhm_igi_th_11k_high[NHM_TH_NUM] = {0x1e, 0x23, 0x28, 0x2d, 0x32, 0x37, 0x78, 0x78, 0x78, 0x78, 0x78};
+	u8	nhm_igi_th_xbox[NHM_TH_NUM] = {0x1a, 0x2c, 0x2e, 0x30, 0x32, 0x34, 0x36, 0x38, 0x3a, 0x3c, 0x3d};
+	u8	i;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "App=%d, nhm_igi=0x%x, igi_curr=0x%x\n", nhm_app, ccx->nhm_igi, igi_curr);
+
+	if (igi_curr < 0x10)/* Protect for invalid IGI*/
+		return	false;
+
+	switch (nhm_app) {
+
+	case NHM_BACKGROUND:	/*Get IGI form driver parameter(cur_ig_value)*/
+	case NHM_ACS:
+		if ((ccx->nhm_igi != igi_curr) || (ccx->nhm_app != nhm_app)) {
+			is_update = true;
+			*igi_new = (u32)igi_curr;
+			nhm_th[0] = (u8)IGI_2_NHM_TH(igi_curr - CCA_CAP);
+			for (i = 1; i <= 10; i++)
+				nhm_th[i] = nhm_th[0] + IGI_2_NHM_TH(2 * i);
+		}
+		break;
+		
+	case IEEE_11K_HIGH:
+		is_update = true;
+		*igi_new = 0x2c;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_11k_high[i]);
+		break;
+		
+	case IEEE_11K_LOW:
+		is_update = true;
+		*igi_new = 0x20;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_11k_low[i]);
+		break;
+		
+	case INTEL_XBOX:
+		is_update = true;
+		*igi_new = 0x36;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_xbox[i]);
+		break;
+		
+	case NHM_DBG:	/*Get IGI form register*/
+		igi_curr = (u8)odm_get_bb_reg(dm, R_0xc50, MASKBYTE0);
+		if ((ccx->nhm_igi != igi_curr) || (ccx->nhm_app != nhm_app)) {
+			is_update = true;
+			*igi_new = (u32)igi_curr;
+			nhm_th[0] = (u8)IGI_2_NHM_TH(igi_curr - CCA_CAP);
+			for (i = 1; i <= 10; i++)
+				nhm_th[i] = nhm_th[0] + IGI_2_NHM_TH(2 * i);
+		}
+		break;
+	}
+
+	if (is_update) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[Update NHM_TH] igi_RSSI=%d\n", 
+			  IGI_2_RSSI(*igi_new));
+		
+		for (i = 0; i < NHM_TH_NUM; i++) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM_th[%d](RSSI) = %d\n",
+				  i, NTH_TH_2_RSSI(nhm_th[i]));
+		}
+	} else {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "No need to update NHM_TH\n");
+	}
+	return is_update;
+}
+
+void
+phydm_nhm_set(
+	void		*dm_void,
+	enum nhm_inexclude_txon_all	include_tx,
+	enum nhm_inexclude_cca_all	include_cca,
+	enum nhm_divider_opt_all	divi_opt,
+	enum nhm_application		nhm_app,
+	u16		period
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	u8	nhm_th[NHM_TH_NUM] = {0};
+	u8	i = 0;
+	u32	igi = 0x20;
+	u32	reg1 = 0, reg2 = 0;
+	u32	val_tmp = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "incld{tx, cca}={%d, %d}, divi_opt=%d, period=%d\n",
+		  include_tx, include_cca, divi_opt, period);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = 0x994;
+		reg2 = 0x990;
+	} else {
+		reg1 = 0x890;
+		reg2 = 0x894;
+	}
+
+	/*Set disable_ignore_cca, disable_ignore_txon, ccx_en*/
+	if ((include_tx != ccx->nhm_include_txon) ||
+		(include_cca != ccx->nhm_include_cca) ||
+		(divi_opt != ccx->nhm_divider_opt)) {
+
+		val_tmp = (u32)BIT_2_BYTE(divi_opt, include_tx, include_cca, 1);
+		pdm_set_reg(dm, reg1, 0xf00, val_tmp);
+
+		ccx->nhm_include_txon = include_tx;
+		ccx->nhm_include_cca = include_cca;
+		ccx->nhm_divider_opt = divi_opt;
+		/*
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "val_tmp=%d, incld{tx, cca}={%d, %d}, divi_opt=%d, period=%d\n",
+		  val_tmp, include_tx, include_cca, divi_opt, period);
+
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "0x994=0x%x\n", odm_get_bb_reg(dm, 0x994, 0xf00));
+		*/
+		
+	}
+	
+	/*Set NHM period*/
+	if (period != ccx->nhm_period) {
+		pdm_set_reg(dm, reg2, MASKHWORD, period);
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Update NHM period ((%d)) -> ((%d))\n",
+			  ccx->nhm_period, period);
+
+		ccx->nhm_period = period;
+	}
+
+	/*Set NHM threshold*/
+	if (phydm_nhm_th_update_chk(dm, nhm_app, &(nhm_th[0]), &igi)) {
+
+		/*Pause IGI*/
+		if ((nhm_app == NHM_BACKGROUND) || (nhm_app == NHM_ACS)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "DIG Free Run\n");
+		} else if (phydm_pause_func(dm, F00_DIG, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, 1, &igi) == PAUSE_FAIL) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pause DIG Fail\n");
+			return;
+		} else {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pause DIG=0x%x\n", igi);
+		}
+		ccx->nhm_app = nhm_app;
+		ccx->nhm_igi = (u8)igi;
+		odm_move_memory(dm, &ccx->nhm_th[0], &nhm_th, NHM_TH_NUM);
+
+		/*Set NHM th*/
+		phydm_nhm_set_th_reg(dm);
+	}
+}
+
+u8
+phydm_nhm_mntr_set(
+	void			*dm_void,
+	struct nhm_para_info	*nhm_para
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16	nhm_time = 0;	/*unit: 4us*/
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (nhm_para->mntr_time == 0)
+		return PHYDM_SET_FAIL;
+
+	if (nhm_para->nhm_lv >= NHM_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Wrong LV=%d\n", nhm_para->nhm_lv);
+		return PHYDM_SET_FAIL;
+	}
+
+	if (phydm_nhm_racing_ctrl(dm, nhm_para->nhm_lv) == PHYDM_SET_FAIL)
+		return PHYDM_SET_FAIL;
+		
+	if (nhm_para->mntr_time >= 262)
+		nhm_time = NHM_PERIOD_MAX;
+	else
+		nhm_time = nhm_para->mntr_time * MS_TO_4US_RATIO;
+
+	phydm_nhm_set(dm, nhm_para->incld_txon, nhm_para->incld_cca, nhm_para->div_opt, nhm_para->nhm_app, nhm_time);
+	
+	return PHYDM_SET_SUCCESS;
+}
+
+/*Environment Monitor*/
+boolean
+phydm_nhm_mntr_chk(
+	void	*dm_void,
+	u16	monitor_time		/*unit ms*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	struct nhm_para_info	nhm_para = {0};
+	boolean			nhm_chk_result = false;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (ccx->nhm_manual_ctrl) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM in manual ctrl\n");
+		return nhm_chk_result;
+	}
+
+	if (ccx->nhm_app != NHM_BACKGROUND && 
+	   ((ccx->nhm_trigger_time + MAX_ENV_MNTR_TIME) > dm->phydm_sys_up_time)) {
+	   
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_app=%d, trigger_time %d, sys_time=%d\n", 
+			  ccx->nhm_app, ccx->nhm_trigger_time, dm->phydm_sys_up_time);
+		
+		return nhm_chk_result;
+	}
+	
+	/*[NHM get result & calculate Utility----------------------------*/	
+	if (phydm_nhm_get_result(dm)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM_rpt success\n");
+		phydm_nhm_get_utility(dm);
+	}
+
+	/*[NHM trigger]-------------------------------------------------*/
+	nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+	nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+	nhm_para.div_opt = NHM_CNT_ALL;
+	nhm_para.nhm_app = NHM_BACKGROUND;
+	nhm_para.nhm_lv	= NHM_LV_1;
+	nhm_para.mntr_time = monitor_time;
+	
+	nhm_chk_result = phydm_nhm_mntr_set(dm, &nhm_para);
+		
+	return nhm_chk_result;
+}
+
+void
+phydm_nhm_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "cur_igi=0x%x\n", dm->dm_dig_table.cur_ig_value);
+
+	ccx->nhm_app = NHM_BACKGROUND;
+	ccx->nhm_igi = 0xff;
+
+	/*Set NHM threshold*/
+	ccx->nhm_ongoing = false;
+	ccx->nhm_set_lv = NHM_RELEASE;
+
+	if (phydm_nhm_th_update_chk(dm, ccx->nhm_app, &(ccx->nhm_th[0]), (u32*)(&ccx->nhm_igi))) {
+		phydm_nhm_set_th_reg(dm);
+	}
+	ccx->nhm_period = 0;
+	
+	ccx->nhm_include_cca = NHM_CCA_INIT;
+	ccx->nhm_include_txon = NHM_TXON_INIT;
+	ccx->nhm_divider_opt = NHM_CNT_INIT;
+	
+	ccx->nhm_manual_ctrl = 0;
+	ccx->nhm_rpt_stamp = 0;
+}
+
+void
+phydm_nhm_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	struct nhm_para_info	nhm_para;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	boolean		nhm_rpt_success = true;
+	u8		i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+	
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "NHM Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "NHM Adv-Trigger: {2} {Include TXON} {Include CCA}\n{0:Cnt_all, 1:Cnt valid} {App} {LV} {0~262ms}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "NHM Get Result: {100}\n");
+	} else if (var1[0] == 100) { /*Get NHM results*/
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "IGI=0x%x, rpt_stamp=%d\n", ccx->nhm_igi, ccx->nhm_rpt_stamp);
+
+		nhm_rpt_success = phydm_nhm_get_result(dm);
+
+		if (nhm_rpt_success) {
+			for (i = 0; i <= 11; i++) {
+				PDM_SNPF(out_len, used, output + used, out_len - used, "nhm_rpt[%d] = %d (%d percent)\n",
+				 	i, ccx->nhm_result[i],
+					 (((ccx->nhm_result[i] * 100) + 128) >> 8));
+			}
+		} else {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Get NHM_rpt Fail\n");
+		}
+		ccx->nhm_manual_ctrl = 0;
+				
+	} else {	/* NMH trigger */
+	
+		ccx->nhm_manual_ctrl = 1;
+
+		if (var1[0] == 1) {
+			nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+			nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+			nhm_para.div_opt = NHM_CNT_ALL;
+			nhm_para.nhm_app = NHM_DBG;
+			nhm_para.nhm_lv = NHM_LV_4;
+			nhm_para.mntr_time = 262;
+		} else {
+			for (i = 1; i < 7; i++) {
+				if (input[i + 1]) {
+					PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				}
+			}
+			nhm_para.incld_txon = (enum nhm_inexclude_txon_all)var1[1];
+			nhm_para.incld_cca = (enum nhm_inexclude_cca_all)var1[2];
+			nhm_para.div_opt = (enum nhm_divider_opt_all)var1[3];
+			nhm_para.nhm_app = (enum nhm_application)var1[4];
+			nhm_para.nhm_lv = (enum phydm_nhm_level)var1[5];
+			nhm_para.mntr_time = (u16)var1[6];
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, " txon=%d, cca=%d, dev=%d, app=%d, lv=%d, time=%d ms\n",
+			nhm_para.incld_txon, nhm_para.incld_cca, 
+			nhm_para.div_opt, nhm_para.nhm_app, nhm_para.nhm_lv,
+			nhm_para.mntr_time);
+		
+		if (phydm_nhm_mntr_set(dm, &nhm_para) == PHYDM_SET_SUCCESS) {
+			phydm_nhm_trigger(dm);
+		}
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "IGI=0x%x, rpt_stamp=%d\n", 
+			ccx->nhm_igi, ccx->nhm_rpt_stamp);
+		
+		for (i = 0; i <= 10; i++) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "NHM_th[%d] RSSI = %d\n",
+				 i, NTH_TH_2_RSSI(ccx->nhm_th[i]));
+		}
+	}
+		
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif	/*#ifdef NHM_SUPPORT*/
+
+#if 1
+
+void
+phydm_set_nhm_th_by_igi(
+	void			*dm_void,
+	u8				igi
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u8	th_gap = 2 * IGI_TO_NHM_TH_MULTIPLIER;
+	u8	i;
+
+	ccx_info->echo_igi = igi;
+	ccx_info->nhm_th[0] = (ccx_info->echo_igi - CCA_CAP) * IGI_TO_NHM_TH_MULTIPLIER;
+	for (i = 1; i <= 10; i++)
+		ccx_info->nhm_th[i] = ccx_info->nhm_th[0] + th_gap * i;
+}
+
+
+
+void
+phydm_nhm_setting(
+	void		*dm_void,
+	u8	nhm_setting
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx_info = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x\n", ccx_info->echo_igi);
+	
+	if (nhm_setting == SET_NHM_SETTING) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+		"NHM_th[H->L]=[0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x]\n",
+		ccx_info->nhm_th[10], ccx_info->nhm_th[9], ccx_info->nhm_th[8],
+		ccx_info->nhm_th[7], ccx_info->nhm_th[6], ccx_info->nhm_th[5],
+		ccx_info->nhm_th[4], ccx_info->nhm_th[3], ccx_info->nhm_th[2],
+		ccx_info->nhm_th[1], ccx_info->nhm_th[0]);
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (nhm_setting == SET_NHM_SETTING) {
+			/*Set inexclude_cca, inexclude_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9), ccx_info->nhm_include_cca);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10), ccx_info->nhm_include_txon);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(11), ccx_info->nhm_divider_opt);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD, ccx_info->nhm_period);
+
+			/*Set NHM threshold*/ /*Unit: PWdB U(8,1)*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0, ccx_info->nhm_th[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1, ccx_info->nhm_th[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2, ccx_info->nhm_th[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3, ccx_info->nhm_th[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0, ccx_info->nhm_th[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1, ccx_info->nhm_th[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2, ccx_info->nhm_th[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3, ccx_info->nhm_th[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0, ccx_info->nhm_th[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2, ccx_info->nhm_th[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3, ccx_info->nhm_th[10]);
+
+			/*CCX EN*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(8), CCX_EN);
+
+		} else if (nhm_setting == STORE_NHM_SETTING) {
+			/*Store pervious disable_ignore_cca, disable_ignore_txon*/
+			ccx_info->nhm_inexclude_cca_restore = (enum nhm_inexclude_cca_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9));
+			ccx_info->nhm_inexclude_txon_restore = (enum nhm_inexclude_txon_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10));
+
+			/*Store pervious NHM period*/
+			ccx_info->nhm_period_restore = (u16)odm_get_bb_reg(dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD);
+
+			/*Store NHM threshold*/
+			ccx_info->nhm_th_restore[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0);
+			ccx_info->nhm_th_restore[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1);
+			ccx_info->nhm_th_restore[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2);
+			ccx_info->nhm_th_restore[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3);
+			ccx_info->nhm_th_restore[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0);
+			ccx_info->nhm_th_restore[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1);
+			ccx_info->nhm_th_restore[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2);
+			ccx_info->nhm_th_restore[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3);
+			ccx_info->nhm_th_restore[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0);
+			ccx_info->nhm_th_restore[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2);
+			ccx_info->nhm_th_restore[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3);
+		} else if (nhm_setting == RESTORE_NHM_SETTING) {
+			/*Set disable_ignore_cca, disable_ignore_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9), ccx_info->nhm_inexclude_cca_restore);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10), ccx_info->nhm_inexclude_txon_restore);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD, ccx_info->nhm_period);
+
+			/*Set NHM threshold*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0, ccx_info->nhm_th_restore[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1, ccx_info->nhm_th_restore[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2, ccx_info->nhm_th_restore[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3, ccx_info->nhm_th_restore[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0, ccx_info->nhm_th_restore[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1, ccx_info->nhm_th_restore[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2, ccx_info->nhm_th_restore[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3, ccx_info->nhm_th_restore[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0, ccx_info->nhm_th_restore[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2, ccx_info->nhm_th_restore[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3, ccx_info->nhm_th_restore[10]);
+		} else
+			return;
+	}
+
+	else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (nhm_setting == SET_NHM_SETTING) {
+			/*Set disable_ignore_cca, disable_ignore_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9), ccx_info->nhm_include_cca);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10), ccx_info->nhm_include_txon);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(11), ccx_info->nhm_divider_opt);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD, ccx_info->nhm_period);
+
+			/*Set NHM threshold*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0, ccx_info->nhm_th[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1, ccx_info->nhm_th[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2, ccx_info->nhm_th[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3, ccx_info->nhm_th[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0, ccx_info->nhm_th[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1, ccx_info->nhm_th[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2, ccx_info->nhm_th[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3, ccx_info->nhm_th[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0, ccx_info->nhm_th[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2, ccx_info->nhm_th[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3, ccx_info->nhm_th[10]);
+
+			/*CCX EN*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(8), CCX_EN);
+		} else if (nhm_setting == STORE_NHM_SETTING) {
+			/*Store pervious disable_ignore_cca, disable_ignore_txon*/
+			ccx_info->nhm_inexclude_cca_restore = (enum nhm_inexclude_cca_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9));
+			ccx_info->nhm_inexclude_txon_restore = (enum nhm_inexclude_txon_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10));
+
+			/*Store pervious NHM period*/
+			ccx_info->nhm_period_restore = (u16)odm_get_bb_reg(dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD);
+
+			/*Store NHM threshold*/
+			ccx_info->nhm_th_restore[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0);
+			ccx_info->nhm_th_restore[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1);
+			ccx_info->nhm_th_restore[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2);
+			ccx_info->nhm_th_restore[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3);
+			ccx_info->nhm_th_restore[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0);
+			ccx_info->nhm_th_restore[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1);
+			ccx_info->nhm_th_restore[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2);
+			ccx_info->nhm_th_restore[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3);
+			ccx_info->nhm_th_restore[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0);
+			ccx_info->nhm_th_restore[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2);
+			ccx_info->nhm_th_restore[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3);
+
+		} else if (nhm_setting == RESTORE_NHM_SETTING) {
+			/*Set disable_ignore_cca, disable_ignore_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9), ccx_info->nhm_inexclude_cca_restore);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10), ccx_info->nhm_inexclude_txon_restore);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD, ccx_info->nhm_period_restore);
+
+			/*Set NHM threshold*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0, ccx_info->nhm_th_restore[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1, ccx_info->nhm_th_restore[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2, ccx_info->nhm_th_restore[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3, ccx_info->nhm_th_restore[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0, ccx_info->nhm_th_restore[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1, ccx_info->nhm_th_restore[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2, ccx_info->nhm_th_restore[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3, ccx_info->nhm_th_restore[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0, ccx_info->nhm_th_restore[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2, ccx_info->nhm_th_restore[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3, ccx_info->nhm_th_restore[10]);
+		} else
+			return;
+
+	}
+}
+
+void
+phydm_get_nhm_result(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u32			value32;
+	u8			i;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11AC);
+		ccx_info->nhm_result[0] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[1] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[2] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[3] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
+		ccx_info->nhm_result[4] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[5] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[6] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[7] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT11_TO_CNT8_11AC);
+		ccx_info->nhm_result[8] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[9] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		/*Get NHM duration*/
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_DUR_READY_11AC);
+		ccx_info->nhm_duration = (u16)(value32 & MASKLWORD);
+
+	}
+
+	else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11N);
+		ccx_info->nhm_result[0] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[1] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[2] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[3] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
+		ccx_info->nhm_result[4] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[5] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[6] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[7] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT9_TO_CNT8_11N);
+		ccx_info->nhm_result[8] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[9] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT10_TO_CNT11_11N);
+		ccx_info->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		/*Get NHM duration*/
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT10_TO_CNT11_11N);
+		ccx_info->nhm_duration = (u16)(value32 & MASKLWORD);
+
+	}
+
+	/* sum all nhm_result */
+	ccx_info->nhm_rpt_sum = 0;
+	for (i = 0; i <= 11; i++)
+		ccx_info->nhm_rpt_sum += ccx_info->nhm_result[i];
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+	"NHM_result=(H->L)[%d %d %d %d (igi) %d %d %d %d %d %d %d %d]\n",
+		ccx_info->nhm_result[11], ccx_info->nhm_result[10], ccx_info->nhm_result[9],
+		ccx_info->nhm_result[8], ccx_info->nhm_result[7], ccx_info->nhm_result[6],
+		ccx_info->nhm_result[5], ccx_info->nhm_result[4], ccx_info->nhm_result[3],
+		ccx_info->nhm_result[2], ccx_info->nhm_result[1], ccx_info->nhm_result[0]);
+
+}
+
+boolean
+phydm_check_nhm_rdy(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			i;
+	boolean			is_ready = false;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (odm_get_bb_reg(dm, ODM_REG_NHM_DUR_READY_11AC, BIT(16)))
+			is_ready = 1;
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			if (odm_get_bb_reg(dm, R_0x8b4, BIT(25)))
+				is_ready = 1;
+		} else {
+			if (odm_get_bb_reg(dm, R_0x8b4, BIT(17)))
+				is_ready = 1;
+		}
+	}
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM rdy=%d\n", is_ready);
+	return is_ready;
+}
+
+void
+phydm_ccx_monitor_trigger(
+	void			*dm_void,
+	u16			monitor_time		/*unit ms*/
+)
+{
+	u8			nhm_th[11], i, igi;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u16 	monitor_time_4us = 0;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if (monitor_time == 0)
+		return;
+
+	if (monitor_time >= 262)
+		monitor_time_4us = 65534;
+	else
+		monitor_time_4us = monitor_time * MS_TO_4US_RATIO;
+
+	/* check if NHM threshold is changed */
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		nhm_th[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0);
+		nhm_th[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1);
+		nhm_th[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2);
+		nhm_th[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3);
+		nhm_th[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0);
+		nhm_th[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1);
+		nhm_th[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2);
+		nhm_th[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3);
+		nhm_th[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0);
+		nhm_th[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2);
+		nhm_th[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3);
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		
+		nhm_th[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0);
+		nhm_th[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1);
+		nhm_th[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2);
+		nhm_th[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3);
+		nhm_th[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0);
+		nhm_th[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1);
+		nhm_th[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2);
+		nhm_th[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3);
+		nhm_th[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0);
+		nhm_th[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2);
+		nhm_th[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3);
+	}
+
+	for (i = 0; i <= 10; i++) {
+		
+		if (nhm_th[i] != ccx_info->nhm_th[i]) {	
+			PHYDM_DBG(dm, DBG_ENV_MNTR,
+				"nhm_th[%d] != ccx_info->nhm_th[%d]!!\n", i, i);
+		}
+	}
+	/*[NHM]*/
+	igi = (u8)odm_get_bb_reg(dm, R_0xc50, MASKBYTE0);
+	phydm_set_nhm_th_by_igi(dm, igi);
+
+	ccx_info->nhm_period = monitor_time_4us;
+	ccx_info->nhm_include_cca = NHM_EXCLUDE_CCA;
+	ccx_info->nhm_include_txon = NHM_EXCLUDE_TXON;
+	ccx_info->nhm_divider_opt = NHM_CNT_ALL;
+
+	phydm_nhm_setting(dm, SET_NHM_SETTING);
+	phydm_nhm_trigger(dm);
+
+	/*[CLM]*/
+	ccx_info->clm_period = monitor_time_4us;
+	
+	if (ccx_info->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		phydm_clm_setting(dm, ccx_info->clm_period);
+		phydm_clm_trigger(dm);
+	} else if (ccx_info->clm_mntr_mode == CLM_FW_MNTR){
+		phydm_clm_h2c(dm, monitor_time_4us, true);
+	}
+
+}
+
+void
+phydm_ccx_monitor_result(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u32					clm_result_tmp = 0;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "%s ======>\n", __func__);
+
+	if (phydm_check_nhm_rdy(dm)) {
+		phydm_get_nhm_result(dm);
+
+		if (ccx_info->nhm_rpt_sum != 0)
+			ccx_info->nhm_ratio  = (u8)(((ccx_info->nhm_rpt_sum - ccx_info->nhm_result[0])*100) >> 8);
+	}
+
+	if (ccx_info->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		
+		if (!phydm_clm_check_rdy(dm))
+			goto out;
+
+		phydm_clm_get_result(dm);
+
+		if (ccx_info->clm_period != 0) {
+			if (ccx_info->clm_period == 64000)
+				ccx_info->clm_ratio = (u8)(((ccx_info->clm_result >> 6) + 5) /10);
+			else if (ccx_info->clm_period == 65535) {
+				clm_result_tmp = (u32)(ccx_info->clm_result * 100);
+				ccx_info->clm_ratio = (u8)((clm_result_tmp + (1<<15)) >> 16);
+			} else
+				ccx_info->clm_ratio = (u8)((ccx_info->clm_result*100) / ccx_info->clm_period);
+		}
+
+	} else {
+		if (ccx_info->clm_fw_result_cnt != 0)
+			ccx_info->clm_ratio = (u8)(ccx_info->clm_fw_result_acc /ccx_info->clm_fw_result_cnt);
+		else
+			ccx_info->clm_ratio = 0;
+
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+			ccx_info->clm_fw_result_acc, ccx_info->clm_fw_result_cnt);
+		
+		ccx_info->clm_fw_result_acc = 0;
+		ccx_info->clm_fw_result_cnt = 0;
+	}
+
+out:
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x, nhm_ratio=%d, clm_ratio=%d\n\n",
+		ccx_info->echo_igi, ccx_info->nhm_ratio, ccx_info->clm_ratio);
+		
+}
+
+
+#endif
+
+
+#ifdef CLM_SUPPORT
+
+void
+phydm_clm_racing_release(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	value32;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "lv:(%d)->(0)\n", ccx->clm_set_lv);
+	
+	ccx->clm_ongoing = false;
+	ccx->clm_set_lv = CLM_RELEASE;
+	ccx->clm_app = CLM_BACKGROUND;
+}
+
+u8
+phydm_clm_racing_ctrl(
+	void			*dm_void,
+	enum phydm_nhm_level	 clm_lv
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u8	set_result = PHYDM_SET_SUCCESS;
+	/*acquire to control CLM API*/
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_ongoing=%d, lv:(%d)->(%d)\n", 
+		  ccx->clm_ongoing, ccx->clm_set_lv, clm_lv);
+	if (ccx->clm_ongoing) {
+		if (clm_lv <= ccx->clm_set_lv) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			phydm_ccx_hw_restart(dm);
+			ccx->clm_ongoing = false;
+		}
+	}
+	
+	if (set_result)
+		ccx->clm_set_lv = clm_lv;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm racing success=%d\n", set_result);
+	return set_result;
+}
+
+
+void
+phydm_clm_c2h_report_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u8	clm_report = cmd_buf[0];
+	u8	clm_report_idx = cmd_buf[1];
+
+	if (cmd_len >=12)
+		return;
+	
+	ccx_info->clm_fw_result_acc += clm_report;
+	ccx_info->clm_fw_result_cnt++;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%d] clm_report= %d\n", ccx_info->clm_fw_result_cnt, clm_report);
+	
+}
+
+void
+phydm_clm_h2c(
+	void	*dm_void,
+	u16	obs_time,
+	u8	fw_clm_en
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8		h2c_val[H2C_MAX_LENGTH] = {0};
+	u8		i = 0;
+	u8		obs_time_idx = 0;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "obs_time_index=%d *4 us\n", obs_time);
+
+	for (i =1; i<=16; i++) {
+		if (obs_time & BIT(16 -i)) {
+			obs_time_idx = 16-i;
+			break;
+		}
+	}
+	
+	/*
+	obs_time =(2^16 -1) ~ (2^15)  => obs_time_idx = 15  (65535 ~ 32768)
+	obs_time =(2^15 -1) ~ (2^14)  => obs_time_idx = 14
+	...
+	...
+	...
+	obs_time =(2^1 -1) ~ (2^0)  => obs_time_idx = 0
+
+	*/
+
+	h2c_val[0] = obs_time_idx | (((fw_clm_en) ? 1 : 0)<< 7);
+	h2c_val[1] = CLM_MAX_REPORT_TIME;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "PHYDM h2c[0x4d]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_FW_CLM_MNTR, H2C_MAX_LENGTH, h2c_val);
+
+}
+
+void
+phydm_clm_setting(
+	void			*dm_void,
+	u16			clm_period	/*4us sample 1 time*/
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+
+	if (ccx->clm_period != clm_period) {
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, R_0x990, MASKLWORD, clm_period);
+
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			odm_set_bb_reg(dm, R_0x894, MASKLWORD, clm_period);
+		}
+
+		ccx->clm_period = clm_period;
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Update CLM period ((%d)) -> ((%d))\n",
+			  ccx->clm_period, clm_period);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Set CLM period=%d * 4us\n", ccx->clm_period);
+
+}
+
+void
+phydm_clm_trigger(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? R_0x994 : R_0x890;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x0);
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x1);
+
+	ccx->clm_trigger_time = dm->phydm_sys_up_time;
+	ccx->clm_rpt_stamp++;
+	ccx->clm_ongoing = true;
+}
+
+boolean
+phydm_clm_check_rdy(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean			is_ready = false;
+	u32			reg1 = 0, reg1_bit = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = ODM_REG_CLM_RESULT_11AC;
+		reg1_bit = 16;
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			reg1 = R_0x8b4;
+			reg1_bit = 24;
+		} else {
+			reg1 = R_0x8b4;
+			reg1_bit = 16;
+		}
+	}
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM rdy=%d\n", is_ready);
+	return is_ready;
+}
+
+void
+phydm_clm_get_utility(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	clm_result_tmp;
+
+	if (ccx->clm_period == 0) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[warning] clm_period = 0\n");
+		ccx->clm_ratio = 0;
+	} else if (ccx->clm_period >= 65530) {
+		clm_result_tmp = (u32)(ccx->clm_result * 100);
+		ccx->clm_ratio = (u8)((clm_result_tmp + (1<<15)) >> 16);
+	} else
+		ccx->clm_ratio = (u8)((ccx->clm_result*100) / ccx->clm_period);
+}
+
+boolean
+phydm_clm_get_result(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u32	reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? R_0x994 : R_0x890;
+
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x0);
+	if (phydm_clm_check_rdy(dm) == false) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM report Fail\n");
+		phydm_clm_racing_release(dm);
+		return false;
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		ccx_info->clm_result = (u16)odm_get_bb_reg(dm, R_0xfa4, MASKLWORD);
+	else if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		ccx_info->clm_result = (u16)odm_get_bb_reg(dm, R_0x8d0, MASKLWORD);
+
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM result = %d *4 us\n", ccx_info->clm_result);
+	phydm_clm_racing_release(dm);
+	return true;
+}
+
+void
+phydm_clm_mntr_fw(
+	void	*dm_void,
+	u16	monitor_time	/*unit ms*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32			clm_result_tmp = 0;
+
+	/*[Get CLM report]*/
+	if (ccx->clm_fw_result_cnt != 0)
+		ccx->clm_ratio = (u8)(ccx->clm_fw_result_acc /ccx->clm_fw_result_cnt);
+	else
+		ccx->clm_ratio = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+		ccx->clm_fw_result_acc, ccx->clm_fw_result_cnt);
+	
+	ccx->clm_fw_result_acc = 0;
+	ccx->clm_fw_result_cnt = 0;
+	
+
+	/*[CLM trigger]*/
+	if (monitor_time >= 262)
+		ccx->clm_period = 65535;
+	else
+		ccx->clm_period = monitor_time * MS_TO_4US_RATIO;
+	
+	phydm_clm_h2c(dm, monitor_time, true);
+
+}
+
+u8
+phydm_clm_mntr_set(
+	void	*dm_void,
+	struct	clm_para_info	*clm_para
+)
+{
+	/*Driver Monitor CLM*/
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u16			clm_period = 0;
+
+	
+	if (clm_para->mntr_time == 0)
+		return PHYDM_SET_FAIL;
+
+	if (clm_para->clm_lv >= CLM_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[WARNING] Wrong LV=%d\n", clm_para->clm_lv);
+		return PHYDM_SET_FAIL;
+	}
+
+	if (phydm_clm_racing_ctrl(dm, clm_para->clm_lv) == PHYDM_SET_FAIL)
+		return PHYDM_SET_FAIL;
+	
+	if (clm_para->mntr_time >= 262)
+		clm_period = CLM_PERIOD_MAX;
+	else
+		clm_period = clm_para->mntr_time * MS_TO_4US_RATIO;
+
+	ccx->clm_app = clm_para->clm_app;
+	phydm_clm_setting(dm, clm_period);
+	
+	return PHYDM_SET_SUCCESS;
+}
+
+boolean
+phydm_clm_mntr_chk(
+	void	*dm_void,
+	u16	monitor_time	/*unit ms*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	struct clm_para_info	clm_para = {0};
+	u32			clm_result_tmp = 0;
+	boolean			clm_chk_result = false;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+
+	if (ccx->clm_manual_ctrl) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM in manual ctrl\n");
+		return clm_chk_result;
+	}
+
+	if ((ccx->clm_app != CLM_BACKGROUND) &&
+	    (ccx->clm_trigger_time + MAX_ENV_MNTR_TIME) > dm->phydm_sys_up_time) {
+	   
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "trigger_time %d, sys_time=%d\n", 
+			  ccx->clm_trigger_time, dm->phydm_sys_up_time);
+		
+		return clm_chk_result;
+	}
+	
+	clm_para.clm_app = CLM_BACKGROUND;
+	clm_para.clm_lv	= CLM_LV_1;
+	clm_para.mntr_time = monitor_time;
+	
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		
+		/*[Get CLM report]*/
+		if (phydm_clm_get_result(dm)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM_rpt success\n");
+			phydm_clm_get_utility(dm);
+		}
+
+		/*[CLM trigger]-------------------------------------------------*/
+		if (phydm_clm_mntr_set(dm, &clm_para) == PHYDM_SET_SUCCESS) {
+			clm_chk_result = true;
+		}
+	} else {
+		phydm_clm_mntr_fw(dm, monitor_time);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_ratio=%d\n", ccx->clm_ratio);
+	return clm_chk_result;
+}
+
+void
+phydm_set_clm_mntr_mode(
+	void			*dm_void,
+	enum clm_monitor_mode mode
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+
+	if (ccx_info->clm_mntr_mode != mode) {
+		
+		ccx_info->clm_mntr_mode = mode;
+		phydm_ccx_hw_restart(dm);
+
+		if (mode == CLM_DRIVER_MNTR)
+			phydm_clm_h2c(dm,0, 0);
+	}
+}
+
+void
+phydm_clm_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	
+	ccx->clm_ongoing = false;
+	ccx->clm_manual_ctrl = 0;
+	ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+	ccx->clm_period = 0;
+	ccx->clm_rpt_stamp = 0;
+	phydm_clm_setting(dm, 65535);
+}
+
+void
+phydm_clm_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	struct clm_para_info	clm_para = {0};
+	u32		i;
+
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+	}
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM Driver Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM Driver Adv-Trigger: {2} {app} {LV} {0~262ms}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM FW Trigger: {3}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM Get Result: {100}\n");
+	} else if (var1[0] == 100) { /* Get CLM results */
+
+		if (phydm_clm_get_result(dm)) {
+			phydm_clm_get_utility(dm);
+		}
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "clm_rpt_stamp=%d\n",
+			 ccx->clm_rpt_stamp);
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "clm_ratio:((%d percent)) = (%d us/ %d us)\n",
+			ccx->clm_ratio, ccx->clm_result<<2, ccx->clm_period<<2);
+		
+		ccx->clm_manual_ctrl = 0;
+		
+	} else { /* Set & trigger CLM */
+		ccx->clm_manual_ctrl = 1;
+		
+		if (var1[0] == 1) {
+			clm_para.clm_app = CLM_BACKGROUND;
+			clm_para.clm_lv	= CLM_LV_4;
+			clm_para.mntr_time = 262;
+			ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+			
+		} else if (var1[0] == 2) {
+			clm_para.clm_app = (enum clm_application )var1[1];
+			clm_para.clm_lv	= (enum phydm_clm_level )var1[2];
+			ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+			clm_para.mntr_time = (u16)var1[3];
+			
+		} else if (var1[0] == 3) {
+			clm_para.clm_app = CLM_BACKGROUND;
+			clm_para.clm_lv	= CLM_LV_4;
+			ccx->clm_mntr_mode = CLM_FW_MNTR;
+			clm_para.mntr_time = 262;
+		}
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "app=%d, lv=%d, mode=%s, time=%d ms\n",
+			  clm_para.clm_app, clm_para.clm_lv, 
+			  ((ccx->clm_mntr_mode == CLM_FW_MNTR) ? "FW" : "driver"),
+			  clm_para.mntr_time);
+		
+		if (phydm_clm_mntr_set(dm, &clm_para) == PHYDM_SET_SUCCESS) {
+			phydm_clm_trigger(dm);
+			/**/
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "clm_rpt_stamp=%d\n",
+			 ccx->clm_rpt_stamp);
+		
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif	/*#ifdef CLM_SUPPORT*/
+
+u8
+phydm_env_mntr_trigger(
+	void			*dm_void,
+	struct	nhm_para_info	*nhm_para,
+	struct	clm_para_info	*clm_para,
+	struct	env_trig_rpt	*trig_rpt
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	boolean			nhm_set_ok = false;
+	boolean			clm_set_ok = false;
+	u8			trigger_result = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	/*[NHM]*/
+	nhm_set_ok = phydm_nhm_mntr_set(dm, nhm_para);
+	
+	/*[CLM]*/
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		clm_set_ok = phydm_clm_mntr_set(dm, clm_para);
+	} else if (ccx->clm_mntr_mode == CLM_FW_MNTR){
+		phydm_clm_h2c(dm, CLM_PERIOD_MAX, true);
+		trigger_result |= CLM_SUCCESS;
+	}
+
+	if (nhm_set_ok) {
+		phydm_nhm_trigger(dm);
+		trigger_result |= NHM_SUCCESS;
+	}
+	
+	if (clm_set_ok) {
+		phydm_clm_trigger(dm);
+		trigger_result |= CLM_SUCCESS;
+	}
+
+	trig_rpt->nhm_rpt_stamp = ccx->nhm_rpt_stamp;
+	trig_rpt->clm_rpt_stamp = ccx->clm_rpt_stamp;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_rpt_stamp=%d, clm_rpt_stamp=%d,\n\n",
+		  trig_rpt->nhm_rpt_stamp, trig_rpt->clm_rpt_stamp);
+
+	return trigger_result;
+#endif
+}
+
+u8
+phydm_env_mntr_result(
+	void			*dm_void,
+	struct	env_mntr_rpt	*rpt
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u8			env_mntr_rpt = 0;
+	u32			clm_result_tmp = 0;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	/*Get NHM result*/
+	if (phydm_nhm_get_result(dm)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM_rpt success\n");
+		phydm_nhm_get_utility(dm);
+		rpt->nhm_ratio = ccx->nhm_ratio;
+		env_mntr_rpt |= NHM_SUCCESS;
+		odm_move_memory(dm, &rpt->nhm_result[0], &ccx->nhm_result[0], NHM_RPT_NUM);
+	} else {
+		rpt->nhm_ratio = ENV_MNTR_FAIL;
+	}
+	
+	/*Get CLM result*/
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		
+		if (phydm_clm_get_result(dm)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM_rpt success\n");
+			phydm_clm_get_utility(dm);
+			env_mntr_rpt |= CLM_SUCCESS;
+			rpt->clm_ratio = ccx->clm_ratio;
+		} else {
+			rpt->clm_ratio = ENV_MNTR_FAIL;
+		}
+
+	} else {
+		if (ccx->clm_fw_result_cnt != 0)
+			ccx->clm_ratio = (u8)(ccx->clm_fw_result_acc /ccx->clm_fw_result_cnt);
+		else
+			ccx->clm_ratio = 0;
+
+		rpt->clm_ratio = ccx->clm_ratio;
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+			ccx->clm_fw_result_acc, ccx->clm_fw_result_cnt);
+		
+		ccx->clm_fw_result_acc = 0;
+		ccx->clm_fw_result_cnt = 0;
+		env_mntr_rpt |= CLM_SUCCESS;
+	}
+
+	rpt->nhm_rpt_stamp = ccx->nhm_rpt_stamp;
+	rpt->clm_rpt_stamp = ccx->clm_rpt_stamp;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x, nhm_ratio=%d, clm_ratio=%d, nhm_rpt_stamp=%d, clm_rpt_stamp=%d\n\n",
+		ccx->nhm_igi, rpt->nhm_ratio, rpt->clm_ratio, rpt->nhm_rpt_stamp, rpt->clm_rpt_stamp);
+	
+	return env_mntr_rpt;
+#endif
+}
+
+/*Environment Monitor*/
+void
+phydm_env_mntr_watchdog(
+	void	*dm_void
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	boolean			nhm_chk_ok = false;
+	boolean			clm_chk_ok = false;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	nhm_chk_ok = phydm_nhm_mntr_chk(dm, 262);/*monitor 262ms*/
+	clm_chk_ok = phydm_clm_mntr_chk(dm, 262); /*monitor 262ms*/
+
+	if (nhm_chk_ok)
+		phydm_nhm_trigger(dm);
+	
+	if (clm_chk_ok)
+		phydm_clm_trigger(dm);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Summary: nhm_ratio=((%d)) clm_ratio=((%d))\n\n",
+		  ccx->nhm_ratio, ccx->clm_ratio);
+#endif
+}
+
+
+void
+phydm_env_monitor_init(
+	void			*dm_void
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	
+	phydm_ccx_hw_restart(dm);
+	phydm_nhm_init(dm);
+	phydm_clm_init(dm);
+#endif
+}
+
+void
+phydm_env_mntr_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	struct clm_para_info	clm_para = {0};
+	struct nhm_para_info	nhm_para = {0};
+	struct env_mntr_rpt	rpt = {0};
+	struct env_trig_rpt	trig_rpt = {0};
+	u8		set_result;
+	u8		i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Get Result: {100}\n");
+	} else if (var1[0] == 100) { /* Get CLM results */
+
+		set_result = phydm_env_mntr_result(dm, &rpt);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Set Result=%d\n nhm_ratio=%d clm_ratio=%d\n nhm_rpt_stamp=%d, clm_rpt_stamp=%d, \n", 
+			set_result, rpt.nhm_ratio, rpt.clm_ratio, rpt.nhm_rpt_stamp, rpt.clm_rpt_stamp);
+
+		for (i = 0; i <= 11; i++) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "nhm_rpt[%d] = %d (%d percent)\n",
+			 	i, rpt.nhm_result[i],
+				 (((rpt.nhm_result[i] * 100) + 128) >> 8));
+		}
+		
+	} else { /* Set & trigger CLM */
+		/*nhm para*/
+		nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+		nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+		nhm_para.div_opt = NHM_CNT_ALL;
+		nhm_para.nhm_app = NHM_ACS;
+		nhm_para.nhm_lv	= NHM_LV_2;
+		nhm_para.mntr_time = 262;
+		
+		/*clm para*/
+		clm_para.clm_app = CLM_ACS;
+		clm_para.clm_lv	= CLM_LV_2;
+		clm_para.mntr_time = 262;
+
+		set_result = phydm_env_mntr_trigger(dm, &nhm_para, &clm_para, &trig_rpt);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Set Result=%d, nhm_rpt_stamp=%d, clm_rpt_stamp=%d\n", 
+			set_result, trig_rpt.nhm_rpt_stamp, trig_rpt.clm_rpt_stamp);
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_ccx.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_ccx.h
new file mode 100644
index 000000000000..f55f6f8b40de
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_ccx.h
@@ -0,0 +1,384 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMCCX_H__
+#define	__PHYDMCCX_H__
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define CCX_EN 1
+
+#define	MAX_ENV_MNTR_TIME	8	/*second*/
+#define	IGI_TO_NHM_TH_MULTIPLIER 2
+#define	MS_TO_4US_RATIO		250
+#define	CCA_CAP			14
+#define	CLM_MAX_REPORT_TIME	10
+#define	DEVIDER_ERROR		0xffff
+#define CLM_PERIOD_MAX		65535
+#define NHM_PERIOD_MAX		65534
+#define	NHM_TH_NUM		11	/*threshold number of NHM*/
+#define	NHM_RPT_NUM		12
+
+#define	IGI_2_NHM_TH(igi)	((igi) << 1)/*NHM_threshold = IGI * 2*/
+#define	NTH_TH_2_RSSI(th)	((th >> 1) - 10)
+
+/*FAHM*/
+#define	FAHM_INCLD_FA		BIT(0)
+#define	FAHM_INCLD_CRC_OK	BIT(1)
+#define	FAHM_INCLD_CRC_ER	BIT(2)
+
+#define NHM_SUCCESS		BIT(0)
+#define CLM_SUCCESS		BIT(1)
+#define FAHM_SUCCESS		BIT(2)
+#define	ENV_MNTR_FAIL		0xff
+
+/* 1 ============================================================
+ * 1 enumrate
+ * 1 ============================================================ */
+enum phydm_clm_level {
+	CLM_RELEASE 		= 0,
+	CLM_LV_1		= 1,	/* Low Priority function */
+	CLM_LV_2		= 2,	/* Middle Priority function */
+	CLM_LV_3		= 3,	/* High priority function (ex: Check hang function) */
+	CLM_LV_4		= 4,	/* Debug function (the highest priority) */
+	CLM_MAX_NUM 		= 5
+};
+
+enum phydm_nhm_level {
+	NHM_RELEASE 		= 0,
+	NHM_LV_1		= 1,	/* Low Priority function */
+	NHM_LV_2		= 2,	/* Middle Priority function */
+	NHM_LV_3		= 3,	/* High priority function (ex: Check hang function) */
+	NHM_LV_4		= 4,	/* Debug function (the highest priority) */
+	NHM_MAX_NUM 		= 5
+};
+
+enum nhm_divider_opt_all {
+	NHM_CNT_ALL		= 0,	/*nhm SUM report <= 255*/
+	NHM_VALID		= 1,	/*nhm SUM report = 255*/
+	NHM_CNT_INIT
+};
+
+enum nhm_setting {
+	SET_NHM_SETTING,
+	STORE_NHM_SETTING,
+	RESTORE_NHM_SETTING
+};
+
+enum nhm_inexclude_cca_all {
+	NHM_EXCLUDE_CCA		= 0,
+	NHM_INCLUDE_CCA		= 1,
+	NHM_CCA_INIT
+};
+
+enum nhm_inexclude_txon_all {
+	NHM_EXCLUDE_TXON	= 0,
+	NHM_INCLUDE_TXON	= 1,
+	NHM_TXON_INIT
+};
+
+enum nhm_application {
+	NHM_BACKGROUND		= 0,/*default*/
+	NHM_ACS			= 1,
+	IEEE_11K_HIGH		= 2,
+	IEEE_11K_LOW		= 3,
+	INTEL_XBOX		= 4,
+	NHM_DBG			= 5, /*manual trigger*/
+};
+
+enum clm_application {
+	CLM_BACKGROUND		= 0,/*default*/
+	CLM_ACS			= 1,
+};
+
+enum clm_monitor_mode {
+	CLM_DRIVER_MNTR		= 1,
+	CLM_FW_MNTR		= 2
+};
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+struct env_trig_rpt {
+	u8			nhm_rpt_stamp;
+	u8			clm_rpt_stamp;
+};
+
+
+struct env_mntr_rpt {
+	u8			nhm_ratio;
+	u8			nhm_result[NHM_RPT_NUM];
+	u8			clm_ratio;
+	u8			nhm_rpt_stamp;
+	u8			clm_rpt_stamp;
+};
+
+struct nhm_para_info {
+	enum nhm_inexclude_txon_all	incld_txon;	/*Include TX on*/
+	enum nhm_inexclude_cca_all	incld_cca;	/*Include CCA*/
+	enum nhm_divider_opt_all	div_opt;	/*divider option*/
+	enum nhm_application		nhm_app;
+	enum phydm_nhm_level 		nhm_lv;
+	u16				mntr_time;	/*0~262 unit ms*/
+	
+};
+
+struct clm_para_info {
+	enum clm_application		clm_app;
+	enum phydm_clm_level 		clm_lv;
+	u16				mntr_time;	/*0~262 unit ms*/
+};
+
+struct ccx_info {
+	u32			nhm_trigger_time;
+	u32			clm_trigger_time;
+#ifdef NHM_SUPPORT
+	enum nhm_application		nhm_app;
+	enum nhm_inexclude_txon_all	nhm_include_txon;
+	enum nhm_inexclude_cca_all	nhm_include_cca;
+	enum nhm_divider_opt_all 	nhm_divider_opt;
+	/*Report*/
+	u8			nhm_th[NHM_TH_NUM];
+	u8			nhm_result[NHM_RPT_NUM];
+	u16			nhm_period;	/* 4us per unit */
+	u8			nhm_igi;
+	u8			nhm_manual_ctrl;
+	u8			nhm_ratio;	/*1% per nuit, it means the interference igi can't overcome.*/
+	u8			nhm_rpt_sum;
+	u16			nhm_duration;	/*Real time of NHM_VALID */
+	u8			nhm_set_lv;
+	boolean			nhm_ongoing;
+	u8			nhm_rpt_stamp;
+#endif
+#ifdef CLM_SUPPORT
+	enum clm_application	clm_app;
+	u8			clm_manual_ctrl;
+	u8			clm_set_lv;
+	boolean			clm_ongoing;
+	u16			clm_period;	/* 4us per unit */
+	u16			clm_result;
+	u8			clm_ratio;
+	u32			clm_fw_result_acc;
+	u8			clm_fw_result_cnt;
+	enum clm_monitor_mode	clm_mntr_mode;
+	u8			clm_rpt_stamp;
+#endif
+#ifdef FAHM_SUPPORT
+	boolean			fahm_ongoing;
+	u8			env_mntr_igi;
+	u8			fahm_nume_sel;	/*fahm_numerator_sel: select {FA, CRCOK, CRC_fail} */
+	u8			fahm_denum_sel;	/*fahm_denumerator_sel: select {FA, CRCOK, CRC_fail} */
+	u16			fahm_period;	/*unit: 4us*/
+#endif
+#if 1	/*Will remove*/
+	/*Previous Settings*/
+	enum nhm_inexclude_txon_all	nhm_inexclude_txon_restore;
+	enum nhm_inexclude_cca_all	nhm_inexclude_cca_restore;
+	u8			nhm_th_restore[NHM_TH_NUM];
+	u16			nhm_period_restore;/* 4us per unit */
+	u8			echo_igi;	/* nhm_result comes from this igi */
+#endif
+};
+
+/* 1 ============================================================
+ * 1 structure
+ * 1 ============================================================ */
+
+void
+phydm_get_nhm_result(
+	void			*dm_void
+);
+
+void
+phydm_set_nhm_th_by_igi(
+	void			*dm_void,
+	u8			igi
+);
+
+void
+phydm_nhm_setting(
+	void			*dm_void,
+	u8			nhm_setting
+);
+
+void
+phydm_ccx_monitor_trigger(
+	void			*dm_void,
+	u16			monitor_time
+);
+
+void
+phydm_ccx_monitor_result(
+	void			*dm_void
+);
+
+
+#ifdef FAHM_SUPPORT
+
+void
+phydm_fahm_init(
+	void			*dm_void
+);
+
+void
+phydm_fahm_dbg(
+	void			*dm_void,
+	char			input[][16],
+	u32			*_used,
+	char			*output,
+	u32			*_out_len,
+	u32			input_num
+);
+
+#endif
+
+
+/*NHM*/
+#ifdef NHM_SUPPORT
+void
+phydm_nhm_trigger(
+	void			*dm_void
+);
+
+void
+phydm_nhm_init(
+	void			*dm_void
+);
+
+void
+phydm_nhm_dbg(
+	void			*dm_void,
+	char			input[][16],
+	u32			*_used,
+	char			*output,
+	u32			*_out_len,
+	u32			input_num
+);
+#endif
+
+/*CLM*/
+#ifdef CLM_SUPPORT
+void
+phydm_clm_c2h_report_handler(
+	void			*dm_void,
+	u8			*cmd_buf,
+	u8			cmd_len
+);
+
+void
+phydm_clm_h2c(
+	void	*dm_void,
+	u16	obs_time,
+	u8	fw_clm_en
+);
+
+
+void
+phydm_clm_setting(
+	void			*dm_void,
+	u16			clm_period
+);
+
+void
+phydm_clm_trigger(
+	void			*dm_void
+);
+
+boolean
+phydm_clm_check_rdy(
+	void			*dm_void
+);
+
+void
+phydm_clm_get_utility(
+	void		*dm_void
+);
+
+boolean
+phydm_clm_get_result(
+	void			*dm_void
+);
+
+u8
+phydm_clm_mntr_set(
+	void	*dm_void,
+	struct	clm_para_info	*clm_para
+);
+
+void
+phydm_set_clm_mntr_mode(
+	void			*dm_void,
+	enum clm_monitor_mode 	mode
+);
+
+void
+phydm_clm_dbg(
+	void			*dm_void,
+	char			input[][16],
+	u32			*_used,
+	char			*output,
+	u32			*_out_len,
+	u32			input_num
+);
+#endif
+
+u8
+phydm_env_mntr_trigger(
+	void			*dm_void,
+	struct	nhm_para_info	*nhm_para,
+	struct	clm_para_info	*clm_para,
+	struct	env_trig_rpt	*rpt
+);
+
+u8
+phydm_env_mntr_result(
+	void			*dm_void,
+	struct	env_mntr_rpt	*rpt
+);
+
+void
+phydm_env_mntr_watchdog(
+	void	*dm_void
+);
+
+
+void
+phydm_env_monitor_init(
+	void			*dm_void
+);
+
+void
+phydm_env_mntr_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cfotracking.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cfotracking.c
new file mode 100644
index 000000000000..abef19b394db
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cfotracking.c
@@ -0,0 +1,371 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_set_crystal_cap(
+	void					*dm_void,
+	u8					crystal_cap
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	if (cfo_track->crystal_cap == crystal_cap)
+		return;
+
+	crystal_cap = crystal_cap & 0x3F;
+	cfo_track->crystal_cap = crystal_cap;
+
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8188F)) {
+		#if (RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
+		/* write 0x24[22:17] = 0x24[16:11] = crystal_cap */
+		odm_set_bb_reg(dm, REG_AFE_XTAL_CTRL, 0x007ff800, (crystal_cap | (crystal_cap << 6)));
+		#endif
+	}
+	#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type & ODM_RTL8812) {
+	
+		/* write 0x2C[30:25] = 0x2C[24:19] = crystal_cap */
+		odm_set_bb_reg(dm, REG_MAC_PHY_CTRL, 0x7FF80000, (crystal_cap | (crystal_cap << 6)));
+		
+	} 
+	#endif
+	#if (RTL8703B_SUPPORT == 1) || (RTL8723B_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8723D_SUPPORT == 1)
+	else if ((dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723B | ODM_RTL8192E | ODM_RTL8821 | ODM_RTL8723D))) {
+	
+		/* 0x2C[23:18] = 0x2C[17:12] = crystal_cap */
+		odm_set_bb_reg(dm, REG_MAC_PHY_CTRL, 0x00FFF000, (crystal_cap | (crystal_cap << 6)));
+		
+	}
+	#endif
+	#if (RTL8814A_SUPPORT == 1)	
+	else if (dm->support_ic_type & ODM_RTL8814A) {
+	
+		/* write 0x2C[26:21] = 0x2C[20:15] = crystal_cap */
+		odm_set_bb_reg(dm, REG_MAC_PHY_CTRL, 0x07FF8000, (crystal_cap | (crystal_cap << 6)));
+		
+	}
+	#endif
+	#if (RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
+	else if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8197F)) {
+	
+		/* write 0x24[30:25] = 0x28[6:1] = crystal_cap */
+		odm_set_bb_reg(dm, REG_AFE_XTAL_CTRL, 0x7e000000, crystal_cap);
+		odm_set_bb_reg(dm, REG_AFE_PLL_CTRL, 0x7e, crystal_cap);
+		
+	}
+	#endif
+	#if (RTL8710B_SUPPORT == 1)
+	else if (dm->support_ic_type & (ODM_RTL8710B)) {
+	
+		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)		
+		/* write 0x60[29:24] = 0x60[23:18] = crystal_cap */
+		HAL_SetSYSOnReg((PADAPTER)dm->adapter, REG_SYS_XTAL_CTRL0, 0x3FFC0000, (crystal_cap | (crystal_cap << 6)));
+		#endif
+	}
+	#endif
+	PHYDM_DBG(dm, DBG_CFO_TRK, "Set rystal_cap = 0x%x\n", cfo_track->crystal_cap);
+
+}
+
+u8
+phydm_get_default_crytaltal_cap(
+	void					*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8						crystal_cap = 0x20;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefuse = rtl_efuse(rtlpriv);
+
+	crystal_cap = rtlefuse->crystalcap;
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	crystal_cap = hal_data->crystal_cap;
+#else
+	struct rtl8192cd_priv	*priv	= dm->priv;
+
+	if (priv->pmib->dot11RFEntry.xcap > 0)
+		crystal_cap = priv->pmib->dot11RFEntry.xcap;
+#endif
+
+	crystal_cap = crystal_cap & 0x3f;
+
+	return crystal_cap;
+}
+
+void
+phydm_set_atc_status(
+	void					*dm_void,
+	boolean					atc_status
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	if (cfo_track->is_atc_status == atc_status)
+		return;
+
+	odm_set_bb_reg(dm, ODM_REG(BB_ATC, dm), ODM_BIT(BB_ATC, dm), atc_status);
+	cfo_track->is_atc_status = atc_status;
+}
+
+boolean
+phydm_get_atc_status(
+	void					*dm_void
+)
+{
+	boolean						atc_status;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	atc_status = (boolean)odm_get_bb_reg(dm, ODM_REG(BB_ATC, dm), ODM_BIT(BB_ATC, dm));
+	return atc_status;
+}
+
+void
+phydm_cfo_tracking_reset(
+	void					*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	PHYDM_DBG(dm, DBG_CFO_TRK, "%s ======>\n", __func__);
+
+	cfo_track->def_x_cap = phydm_get_default_crytaltal_cap(dm);
+	cfo_track->is_adjust = true;
+
+	if (cfo_track->crystal_cap > cfo_track->def_x_cap) {
+		
+		phydm_set_crystal_cap(dm, cfo_track->crystal_cap - 1);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "approch to Init-val (0x%x)\n", cfo_track->crystal_cap);
+		
+	} else if (cfo_track->crystal_cap < cfo_track->def_x_cap) {
+	
+		phydm_set_crystal_cap(dm, cfo_track->crystal_cap + 1);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "approch to init-val 0x%x\n", cfo_track->crystal_cap);
+	}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_set_atc_status(dm, true);
+#endif
+}
+
+void
+phydm_cfo_tracking_init(
+	void					*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	cfo_track->def_x_cap = cfo_track->crystal_cap = phydm_get_default_crytaltal_cap(dm);
+	cfo_track->is_atc_status = phydm_get_atc_status(dm);
+	cfo_track->is_adjust = true;
+	PHYDM_DBG(dm, DBG_CFO_TRK, "ODM_CfoTracking_init()=========>\n");
+	PHYDM_DBG(dm, DBG_CFO_TRK, "ODM_CfoTracking_init(): is_atc_status = %d, crystal_cap = 0x%x\n", cfo_track->is_atc_status, cfo_track->def_x_cap);
+
+#if RTL8822B_SUPPORT
+	/* Crystal cap. control by WiFi */
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, 0x10, 0x40, 0x1);
+#endif
+
+#if RTL8821C_SUPPORT
+	/* Crystal cap. control by WiFi */
+	if (dm->support_ic_type & ODM_RTL8821C)
+		odm_set_bb_reg(dm, 0x10, 0x40, 0x1);
+#endif
+}
+
+void
+phydm_cfo_tracking(
+	void					*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	s32						cfo_avg = 0, cfo_path_sum = 0;	/*avg among each path*/
+	u32						cfo_rpt_sum, cfo_khz_avg[4] = {0};
+	s8						crystal_cap = cfo_track->crystal_cap;
+	u8						i, valid_path_cnt = 0;
+
+	if (!(dm->support_ability & ODM_BB_CFO_TRACKING)) {
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_CFO_TRK, "%s ======>\n", __func__);
+
+	if (!dm->is_linked || !dm->is_one_entry_only) {
+		phydm_cfo_tracking_reset(dm);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "is_linked = %d, one_entry_only = %d\n",
+			dm->is_linked, dm->is_one_entry_only);
+		
+	} else {
+		
+		/* No new packet */
+		if (cfo_track->packet_count == cfo_track->packet_count_pre) {
+			PHYDM_DBG(dm, DBG_CFO_TRK, "Pkt cnt doesn't change\n");
+			return;
+		}
+		cfo_track->packet_count_pre = cfo_track->packet_count;
+
+		/*Calculate CFO */
+		for (i = 0; i < dm->num_rf_path; i++) {
+			if (cfo_track->CFO_cnt[i] == 0)
+				continue;
+
+			valid_path_cnt++;
+			cfo_rpt_sum = (u32)CFO_HW_RPT_2_KHZ(((cfo_track->CFO_tail[i] < 0) ? (0 - cfo_track->CFO_tail[i]) :  cfo_track->CFO_tail[i]));
+			cfo_khz_avg[i] = cfo_rpt_sum / cfo_track->CFO_cnt[i];
+
+			PHYDM_DBG(dm, DBG_CFO_TRK, "[Path-%d] CFO_sum = (( %d )), cnt = (( %d )) , CFO_avg= (( %s%d )) kHz\n",
+				i, cfo_rpt_sum, cfo_track->CFO_cnt[i], ((cfo_track->CFO_tail[i] < 0) ? "-" : " "), cfo_khz_avg[i]);
+		}
+
+		for (i = 0; i < valid_path_cnt; i++) {
+			if (cfo_track->CFO_tail[i] < 0) {
+				cfo_path_sum += (0 - (s32)cfo_khz_avg[i]);
+			} else
+				cfo_path_sum += (s32)cfo_khz_avg[i];
+		}
+
+		if (valid_path_cnt >= 2)
+			cfo_avg = cfo_path_sum / valid_path_cnt;
+		else
+			cfo_avg = cfo_path_sum;
+
+		cfo_track->CFO_ave_pre = cfo_avg;
+
+		PHYDM_DBG(dm, DBG_CFO_TRK, "path_cnt = ((%d)), CFO_avg_path=((%d kHz))\n", valid_path_cnt, cfo_avg);
+
+		/*reset counter*/
+		for (i = 0; i < dm->num_rf_path; i++) {
+			cfo_track->CFO_tail[i] = 0;
+			cfo_track->CFO_cnt[i] = 0;
+		}
+
+		/* To adjust crystal cap or not */
+		if (cfo_track->is_adjust == false) {
+			if (cfo_avg > CFO_TRK_ENABLE_TH || cfo_avg < (-CFO_TRK_ENABLE_TH))
+				cfo_track->is_adjust = true;
+		} else {
+			if (cfo_avg < CFO_TRK_STOP_TH && cfo_avg > (-CFO_TRK_STOP_TH))
+				cfo_track->is_adjust = false;
+		}
+
+		#ifdef ODM_CONFIG_BT_COEXIST
+		/*BT case: Disable CFO tracking */
+		if (dm->bt_info_table.is_bt_enabled) {
+			cfo_track->is_adjust = false;
+			phydm_set_crystal_cap(dm, cfo_track->def_x_cap);
+			PHYDM_DBG(dm, DBG_CFO_TRK, "Disable CFO tracking for BT\n");
+		}
+		#endif
+		
+		/*Adjust Crystal Cap. */
+		if (cfo_track->is_adjust) {
+			if (cfo_avg > CFO_TRK_STOP_TH)
+				crystal_cap += 1;
+			else if (cfo_avg < (-CFO_TRK_STOP_TH))
+				crystal_cap -=1;
+
+			if (crystal_cap > 0x3f)
+				crystal_cap = 0x3f;
+			else if (crystal_cap < 0)
+				crystal_cap = 0;
+
+			phydm_set_crystal_cap(dm, (u8)crystal_cap);
+		}
+		
+		PHYDM_DBG(dm, DBG_CFO_TRK, "Crystal cap{Current, Default}={0x%x, 0x%x}\n\n",
+			cfo_track->crystal_cap, cfo_track->def_x_cap);
+
+		/* Dynamic ATC switch */
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			if (cfo_avg < CFO_TH_ATC && cfo_avg > -CFO_TH_ATC) {
+				phydm_set_atc_status(dm, false);
+				PHYDM_DBG(dm, DBG_CFO_TRK, "Disable ATC\n");
+			} else {
+				phydm_set_atc_status(dm, true);
+				PHYDM_DBG(dm, DBG_CFO_TRK, "Enable ATC\n");
+			}
+		}
+		#endif
+	}
+}
+
+void
+phydm_parsing_cfo(
+	void			*dm_void,
+	void			*pktinfo_void,
+	s8			*pcfotail,
+	u8			num_ss
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_perpkt_info_struct		*pktinfo = (struct phydm_perpkt_info_struct *)pktinfo_void;
+	struct phydm_cfo_track_struct			*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	u8					i;
+
+	if (!(dm->support_ability & ODM_BB_CFO_TRACKING))
+		return;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (pktinfo->is_packet_match_bssid)
+#else
+	if (pktinfo->station_id != 0)
+#endif
+	{
+		if (num_ss > dm->num_rf_path) /*For fool proof*/
+			num_ss = dm->num_rf_path;
+
+		/*PHYDM_DBG(dm, DBG_CFO_TRK, "num_ss = ((%d)),  dm->num_rf_path = ((%d))\n", num_ss,  dm->num_rf_path);*/
+
+
+		/* 3 Update CFO report for path-A & path-B */
+		/* Only paht-A and path-B have CFO tail and short CFO */
+		for (i = 0; i < num_ss; i++) {
+			cfo_track->CFO_tail[i] += pcfotail[i];
+			cfo_track->CFO_cnt[i]++;
+			/*PHYDM_DBG(dm, DBG_CFO_TRK, "[ID %d][path %d][rate 0x%x] CFO_tail = ((%d)), CFO_tail_sum = ((%d)), CFO_cnt = ((%d))\n",
+				pktinfo->station_id, i, pktinfo->data_rate, pcfotail[i], cfo_track->CFO_tail[i], cfo_track->CFO_cnt[i]);
+			*/
+		}
+
+		/* 3 Update packet counter */
+		if (cfo_track->packet_count == 0xffffffff)
+			cfo_track->packet_count = 0;
+		else
+			cfo_track->packet_count++;
+	}
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cfotracking.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cfotracking.h
new file mode 100644
index 000000000000..9324489946f4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_cfotracking.h
@@ -0,0 +1,71 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMCFOTRACK_H__
+#define    __PHYDMCFOTRACK_H__
+
+#define CFO_TRACKING_VERSION	"1.4" /*2015.10.01	Stanley, Modify for 8822B*/
+
+#define		CFO_TRK_ENABLE_TH			20	/* (kHz)  enable CFO Tracking threshold*/
+#define		CFO_TRK_STOP_TH			10	/* (kHz)  disable CFO Tracking threshold*/
+#define		CFO_TH_ATC					80	/* kHz */
+
+struct phydm_cfo_track_struct {
+	boolean		is_atc_status;
+	boolean		is_adjust;	/*already modify crystal cap*/
+	u8			crystal_cap;
+	u8			def_x_cap;
+	s32			CFO_tail[4];
+	u32			CFO_cnt[4];
+	s32			CFO_ave_pre;
+	u32			packet_count;
+	u32			packet_count_pre;
+};
+
+void
+phydm_set_crystal_cap(
+	void					*dm_void,
+	u8					crystal_cap
+);
+
+void
+phydm_cfo_tracking_init(
+	void					*dm_void
+);
+
+void
+phydm_cfo_tracking(
+	void					*dm_void
+);
+
+void
+phydm_parsing_cfo(
+	void					*dm_void,
+	void					*pktinfo_void,
+	s8					*pcfotail,
+	u8					num_ss
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_debug.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_debug.c
new file mode 100644
index 000000000000..3599e65fc4f0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_debug.c
@@ -0,0 +1,3786 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_init_debug_setting(
+	struct dm_struct		*dm
+)
+{
+	dm->debug_level = ODM_DBG_TRACE;
+
+	dm->fw_debug_components = 0;
+	dm->debug_components =
+		\
+#if DBG
+		/*BB Functions*/
+		/*									DBG_DIG						|*/
+		/*									DBG_RA_MASK					|*/
+		/*									DBG_DYN_TXPWR					|*/
+		/*									DBG_FA_CNT						|*/
+		/*									DBG_RSSI_MNTR					|*/
+		/*									DBG_CCKPD						|*/
+		/*									DBG_ANT_DIV					|*/
+		/*									DBG_SMT_ANT					|*/
+		/*									DBG_PWR_TRAIN					|*/
+		/*									DBG_RA							|*/
+		/*									DBG_PATH_DIV					|*/
+		/*									DBG_DFS						|*/
+		/*									DBG_DYN_ARFR					|*/
+		/*									DBG_ADPTVTY					|*/
+		/*									DBG_CFO_TRK					|*/
+		/*									DBG_ENV_MNTR					|*/
+		/*									DBG_PRI_CCA					|*/
+		/*									DBG_ADPTV_SOML					|*/
+		/*									DBG_LNA_SAT_CHK				|*/
+		/*									DBG_DYN_RX_PATH				|*/
+		/*									DBG_PHY_STATUS					|*/
+		/*									DBG_TMP						|*/
+		/*									DBG_FW_TRACE					|*/
+		/*									DBG_TXBF						|*/
+		/*									DBG_COMMON_FLOW				|*/
+		/*									ODM_COMP_TX_PWR_TRACK		|*/
+		/*									ODM_COMP_CALIBRATION			|*/
+		/*									ODM_COMP_MP					|*/
+		/*									ODM_PHY_CONFIG					|*/
+		/*									ODM_COMP_INIT					|*/
+		/*									ODM_COMP_COMMON				|*/
+		/*									ODM_COMP_API					|*/
+
+
+#endif
+		0;
+
+	dm->fw_buff_is_enpty = true;
+	dm->pre_c2h_seq = 0;
+	dm->c2h_cmd_start = 0;
+	dm->cmn_dbg_msg_cnt = PHYDM_WATCH_DOG_PERIOD;
+	dm->cmn_dbg_msg_period = PHYDM_WATCH_DOG_PERIOD;
+}
+
+void
+phydm_bb_dbg_port_header_sel(
+	void			*dm_void,
+	u32			header_idx
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		odm_set_bb_reg(dm, 0x8f8, (BIT(25) | BIT(24) | BIT(23) | BIT(22)), header_idx);
+		
+		/*
+		header_idx:
+			(0:) '{ofdm_dbg[31:0]}'
+			(1:) '{cca,crc32_fail,dbg_ofdm[29:0]}'
+			(2:) '{vbon,crc32_fail,dbg_ofdm[29:0]}'
+			(3:) '{cca,crc32_ok,dbg_ofdm[29:0]}'
+			(4:) '{vbon,crc32_ok,dbg_ofdm[29:0]}'
+			(5:) '{dbg_iqk_anta}'
+			(6:) '{cca,ofdm_crc_ok,dbg_dp_anta[29:0]}'
+			(7:) '{dbg_iqk_antb}'
+			(8:) '{DBGOUT_RFC_b[31:0]}'
+			(9:) '{DBGOUT_RFC_a[31:0]}'
+			(a:) '{dbg_ofdm}'
+			(b:) '{dbg_cck}'
+		*/
+	}
+}
+
+void
+phydm_bb_dbg_port_clock_en(
+	void			*dm_void,
+	u8			enable
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = 0;
+	
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814A | ODM_RTL8814B)) {
+		
+		reg_value = enable ? 0x7 : 0;
+		odm_set_bb_reg(dm, 0x198c, 0x7, reg_value); /*enable/disable debug port clock, for power saving*/
+	}
+}
+
+u8
+phydm_set_bb_dbg_port(
+	void			*dm_void,
+	u8			curr_dbg_priority,
+	u32			debug_port
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	dbg_port_result = false;
+
+	if (curr_dbg_priority > dm->pre_dbg_priority) {
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			
+			phydm_bb_dbg_port_clock_en(dm, true);
+			
+			odm_set_bb_reg(dm, 0x8fc, MASKDWORD, debug_port);
+			/**/
+		} else /*if (dm->support_ic_type & ODM_IC_11N_SERIES)*/ {
+			odm_set_bb_reg(dm, 0x908, MASKDWORD, debug_port);
+			/**/
+		}
+		PHYDM_DBG(dm, ODM_COMP_API, "DbgPort ((0x%x)) set success, Cur_priority=((%d)), Pre_priority=((%d))\n", debug_port, curr_dbg_priority, dm->pre_dbg_priority);
+		dm->pre_dbg_priority = curr_dbg_priority;
+		dbg_port_result = true;
+	}
+		
+	return dbg_port_result;
+}
+
+void
+phydm_release_bb_dbg_port(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	phydm_bb_dbg_port_clock_en(dm, false);
+	phydm_bb_dbg_port_header_sel(dm, 0);
+
+	dm->pre_dbg_priority = BB_DBGPORT_RELEASE;
+	PHYDM_DBG(dm, ODM_COMP_API, "Release BB dbg_port\n");
+}
+
+u32
+phydm_get_bb_dbg_port_value(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	dbg_port_value = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		dbg_port_value = odm_get_bb_reg(dm, 0xfa0, MASKDWORD);
+		/**/
+	} else /*if (dm->support_ic_type & ODM_IC_11N_SERIES)*/ {
+		dbg_port_value = odm_get_bb_reg(dm, 0xdf4, MASKDWORD);
+		/**/
+	}
+	PHYDM_DBG(dm, ODM_COMP_API, "dbg_port_value = 0x%x\n", dbg_port_value);
+	return	dbg_port_value;
+}
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+
+void
+phydm_bb_debug_info_n_series(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	u32	value32 = 0, value32_1 = 0;
+	u8	rf_gain_a = 0, rf_gain_b = 0, rf_gain_c = 0, rf_gain_d = 0;
+	u8	rx_snr_a = 0, rx_snr_b = 0, rx_snr_c = 0, rx_snr_d = 0;
+
+	s8    rxevm_0 = 0, rxevm_1 = 0;
+	s32	short_cfo_a = 0, short_cfo_b = 0, long_cfo_a = 0, long_cfo_b = 0;
+	s32	scfo_a = 0, scfo_b = 0, avg_cfo_a = 0, avg_cfo_b = 0;
+	s32	cfo_end_a = 0, cfo_end_b = 0, acq_cfo_a = 0, acq_cfo_b = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s\n", "BB Report Info");
+
+	/*AGC result*/
+	value32 = odm_get_bb_reg(dm, 0xdd0, MASKDWORD);
+	rf_gain_a = (u8)(value32 & 0x3f);
+	rf_gain_a = rf_gain_a << 1;
+
+	rf_gain_b = (u8)((value32 >> 8) & 0x3f);
+	rf_gain_b = rf_gain_b << 1;
+
+	rf_gain_c = (u8)((value32 >> 16) & 0x3f);
+	rf_gain_c = rf_gain_c << 1;
+
+	rf_gain_d = (u8)((value32 >> 24) & 0x3f);
+	rf_gain_d = rf_gain_d << 1;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d",
+		       "OFDM RX RF Gain(A/B/C/D)", rf_gain_a, rf_gain_b,
+		       rf_gain_c, rf_gain_d);
+
+	/*SNR report*/
+	value32 = odm_get_bb_reg(dm, 0xdd4, MASKDWORD);
+	rx_snr_a = (u8)(value32 & 0xff);
+	rx_snr_a = rx_snr_a >> 1;
+
+	rx_snr_b = (u8)((value32 >> 8) & 0xff);
+	rx_snr_b = rx_snr_b >> 1;
+
+	rx_snr_c = (u8)((value32 >> 16) & 0xff);
+	rx_snr_c = rx_snr_c >> 1;
+
+	rx_snr_d = (u8)((value32 >> 24) & 0xff);
+	rx_snr_d = rx_snr_d >> 1;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)",
+		       rx_snr_a, rx_snr_b, rx_snr_c, rx_snr_d);
+
+	/* PostFFT related info*/
+	value32 = odm_get_bb_reg(dm, 0xdd8, MASKDWORD);
+
+	rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_0 /= 2;
+	if (rxevm_0 < -63)
+		rxevm_0 = 0;
+
+	rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+	rxevm_1 /= 2;
+	if (rxevm_1 < -63)
+		rxevm_1 = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "RXEVM (1ss/2ss)", rxevm_0,
+		       rxevm_1);
+
+	/*CFO Report Info*/
+	odm_set_bb_reg(dm, 0xd00, BIT(26), 1);
+
+	/*Short CFO*/
+	value32 = odm_get_bb_reg(dm, 0xdac, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xdb0, MASKDWORD);
+
+	short_cfo_b = (s32)(value32 & 0xfff);			/*S(12,11)*/
+	short_cfo_a = (s32)((value32 & 0x0fff0000) >> 16);
+
+	long_cfo_b = (s32)(value32_1 & 0x1fff);		/*S(13,12)*/
+	long_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+
+	/*SFO 2's to dec*/
+	if (short_cfo_a > 2047)
+		short_cfo_a = short_cfo_a - 4096;
+	if (short_cfo_b > 2047)
+		short_cfo_b = short_cfo_b - 4096;
+
+	short_cfo_a = (short_cfo_a * 312500) / 2048;
+	short_cfo_b = (short_cfo_b * 312500) / 2048;
+
+	/*LFO 2's to dec*/
+
+	if (long_cfo_a > 4095)
+		long_cfo_a = long_cfo_a - 8192;
+
+	if (long_cfo_b > 4095)
+		long_cfo_b = long_cfo_b - 8192;
+
+	long_cfo_a = long_cfo_a * 312500 / 4096;
+	long_cfo_b = long_cfo_b * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "CFO Report Info");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "Short CFO(Hz) <A/B>",
+		       short_cfo_a, short_cfo_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "Long CFO(Hz) <A/B>",
+		       long_cfo_a, long_cfo_b);
+
+	/*SCFO*/
+	value32 = odm_get_bb_reg(dm, 0xdb8, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xdb4, MASKDWORD);
+
+	scfo_b = (s32)(value32 & 0x7ff);			/*S(11,10)*/
+	scfo_a = (s32)((value32 & 0x07ff0000) >> 16);
+
+	if (scfo_a > 1023)
+		scfo_a = scfo_a - 2048;
+
+	if (scfo_b > 1023)
+		scfo_b = scfo_b - 2048;
+
+	scfo_a = scfo_a * 312500 / 1024;
+	scfo_b = scfo_b * 312500 / 1024;
+
+	avg_cfo_b = (s32)(value32_1 & 0x1fff);	/*S(13,12)*/
+	avg_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+
+	if (avg_cfo_a > 4095)
+		avg_cfo_a = avg_cfo_a - 8192;
+
+	if (avg_cfo_b > 4095)
+		avg_cfo_b = avg_cfo_b - 8192;
+
+	avg_cfo_a = avg_cfo_a * 312500 / 4096;
+	avg_cfo_b = avg_cfo_b * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "value SCFO(Hz) <A/B>", scfo_a,
+		       scfo_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "Avg CFO(Hz) <A/B>", avg_cfo_a,
+		       avg_cfo_b);
+
+	value32 = odm_get_bb_reg(dm, 0xdbc, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xde0, MASKDWORD);
+
+	cfo_end_b = (s32)(value32 & 0x1fff);		/*S(13,12)*/
+	cfo_end_a = (s32)((value32 & 0x1fff0000) >> 16);
+
+	if (cfo_end_a > 4095)
+		cfo_end_a = cfo_end_a - 8192;
+
+	if (cfo_end_b > 4095)
+		cfo_end_b = cfo_end_b - 8192;
+
+	cfo_end_a = cfo_end_a * 312500 / 4096;
+	cfo_end_b = cfo_end_b * 312500 / 4096;
+
+	acq_cfo_b = (s32)(value32_1 & 0x1fff);	/*S(13,12)*/
+	acq_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+
+	if (acq_cfo_a > 4095)
+		acq_cfo_a = acq_cfo_a - 8192;
+
+	if (acq_cfo_b > 4095)
+		acq_cfo_b = acq_cfo_b - 8192;
+
+	acq_cfo_a = acq_cfo_a * 312500 / 4096;
+	acq_cfo_b = acq_cfo_b * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "End CFO(Hz) <A/B>", cfo_end_a,
+		       cfo_end_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "ACQ CFO(Hz) <A/B>", acq_cfo_a,
+		       acq_cfo_b);
+
+}
+
+
+void
+phydm_bb_debug_info(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	char *tmp_string = NULL;
+
+	u8	rx_ht_bw, rx_vht_bw, rxsc, rx_ht, rx_bw;
+	static u8 v_rx_bw ;
+	u32	value32, value32_1, value32_2, value32_3;
+	s32	sfo_a, sfo_b, sfo_c, sfo_d;
+	s32	lfo_a, lfo_b, lfo_c, lfo_d;
+	static u8	MCSS, tail, parity, rsv, vrsv, idx, smooth, htsound, agg, stbc, vstbc, fec, fecext, sgi, sgiext, htltf, vgid, v_nsts, vtxops, vrsv2, vbrsv, bf, vbcrc;
+	static u16	h_length, htcrc8, length;
+	static u16 vpaid;
+	static u16	v_length, vhtcrc8, v_mcss, v_tail, vb_tail;
+	static u8	hmcss, hrx_bw;
+
+	u8    pwdb;
+	s8    rxevm_0, rxevm_1, rxevm_2 ;
+	u8    rf_gain_path_a, rf_gain_path_b, rf_gain_path_c, rf_gain_path_d;
+	u8    rx_snr_path_a, rx_snr_path_b, rx_snr_path_c, rx_snr_path_d;
+	s32    sig_power;
+
+	const char *L_rate[8] = {"6M", "9M", "12M", "18M", "24M", "36M", "48M", "54M"};
+
+#if 0
+	const double evm_comp_20M = 0.579919469776867; /* 10*log10(64.0/56.0) */
+	const double evm_comp_40M = 0.503051183113957; /* 10*log10(128.0/114.0) */
+	const double evm_comp_80M = 0.244245993314183; /* 10*log10(256.0/242.0) */
+	const double evm_comp_160M = 0.244245993314183; /* 10*log10(512.0/484.0) */
+#endif
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		phydm_bb_debug_info_n_series(dm, &used, output, &out_len);
+		return;
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s\n", "BB Report Info");
+
+	/*BW & mode Detection*/
+
+	value32 = odm_get_bb_reg(dm, 0xf80, MASKDWORD);
+	value32_2 = value32;
+	rx_ht_bw = (u8)(value32 & 0x1);
+	rx_vht_bw = (u8)((value32 >> 1) & 0x3);
+	rxsc = (u8)(value32 & 0x78);
+	value32_1 = (value32 & 0x180) >> 7;
+	rx_ht = (u8)(value32_1);
+
+	rx_bw = 0;
+
+	if (rx_ht == 2) {
+		if (rx_vht_bw == 0)
+			tmp_string = "20M";
+		else if (rx_vht_bw == 1)
+			tmp_string = "40M";
+		else
+			tmp_string = "80M";
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s %s %s", "mode", "VHT", tmp_string);
+		rx_bw = rx_vht_bw;
+	} else if (rx_ht == 1) {
+		if (rx_ht_bw == 0)
+			tmp_string = "20M";
+		else if (rx_ht_bw == 1)
+			tmp_string = "40M";
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s %s %s", "mode", "HT", tmp_string);
+		rx_bw = rx_ht_bw;
+	} else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s %s", "mode", "Legacy");
+
+	if (rx_ht != 0) {
+		if (rxsc == 0)
+			tmp_string = "duplicate/full bw";
+		else if (rxsc == 1)
+			tmp_string = "usc20-1";
+		else if (rxsc == 2)
+			tmp_string = "lsc20-1";
+		else if (rxsc == 3)
+			tmp_string = "usc20-2";
+		else if (rxsc == 4)
+			tmp_string = "lsc20-2";
+		else if (rxsc == 9)
+			tmp_string = "usc40";
+		else if (rxsc == 10)
+			tmp_string = "lsc40";
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s", tmp_string);
+	}
+
+	/* RX signal power and AGC related info*/
+
+	value32 = odm_get_bb_reg(dm, 0xF90, MASKDWORD);
+	pwdb = (u8)((value32 & MASKBYTE1) >> 8);
+	pwdb = pwdb >> 1;
+	sig_power = -110 + pwdb;
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "OFDM RX Signal Power(dB)",
+		       sig_power);
+
+	value32 = odm_get_bb_reg(dm, 0xd14, MASKDWORD);
+	rx_snr_path_a = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_a = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_a *= 2;
+	value32 = odm_get_bb_reg(dm, 0xd54, MASKDWORD);
+	rx_snr_path_b = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_b = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_b *= 2;
+	value32 = odm_get_bb_reg(dm, 0xd94, MASKDWORD);
+	rx_snr_path_c = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_c = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_c *= 2;
+	value32 = odm_get_bb_reg(dm, 0xdd4, MASKDWORD);
+	rx_snr_path_d = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_d = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_d *= 2;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d",
+		       "OFDM RX RF Gain(A/B/C/D)", rf_gain_path_a,
+		       rf_gain_path_b, rf_gain_path_c, rf_gain_path_d);
+
+
+	/* RX counter related info*/
+
+	value32 = odm_get_bb_reg(dm, 0xF08, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "OFDM CCA counter",
+		       ((value32 & 0xFFFF0000) >> 16));
+
+	value32 = odm_get_bb_reg(dm, 0xFD0, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "OFDM SBD Fail counter",
+		       value32 & 0xFFFF);
+
+	value32 = odm_get_bb_reg(dm, 0xFC4, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d",
+		       "VHT SIGA/SIGB CRC8 Fail counter", value32 & 0xFFFF,
+		       ((value32 & 0xFFFF0000) >> 16));
+
+	value32 = odm_get_bb_reg(dm, 0xFCC, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "CCK CCA counter", value32 & 0xFFFF);
+
+	value32 = odm_get_bb_reg(dm, 0xFBC, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d",
+		       "LSIG (parity Fail/rate Illegal) counter",
+		       value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16));
+
+	value32_1 = odm_get_bb_reg(dm, 0xFC8, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xFC0, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d",
+		       "HT/VHT MCS NOT SUPPORT counter",
+		       ((value32_2 & 0xFFFF0000) >> 16), value32_1 & 0xFFFF);
+
+	/* PostFFT related info*/
+	value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+	rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_0 /= 2;
+	if (rxevm_0 < -63)
+		rxevm_0 = 0;
+
+	rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+	rxevm_1 /= 2;
+	value32 = odm_get_bb_reg(dm, 0xF88, MASKDWORD);
+	rxevm_2 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_2 /= 2;
+
+	if (rxevm_1 < -63)
+		rxevm_1 = 0;
+	if (rxevm_2 < -63)
+		rxevm_2 = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d", "RXEVM (1ss/2ss/3ss)",
+		       rxevm_0, rxevm_1, rxevm_2);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)",
+		       rx_snr_path_a, rx_snr_path_b, rx_snr_path_c,
+		       rx_snr_path_d);
+
+	value32 = odm_get_bb_reg(dm, 0xF8C, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "CSI_1st /CSI_2nd",
+		       value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16));
+
+	/*BW & mode Detection*/
+
+	/*Reset Page F counter*/
+	odm_set_bb_reg(dm, 0xB58, BIT(0), 1);
+	odm_set_bb_reg(dm, 0xB58, BIT(0), 0);
+
+	/*CFO Report Info*/
+	/*Short CFO*/
+	value32 = odm_get_bb_reg(dm, 0xd0c, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd4c, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd8c, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xdcc, MASKDWORD);
+
+	sfo_a = (s32)(value32 & 0xfff);
+	sfo_b = (s32)(value32_1 & 0xfff);
+	sfo_c = (s32)(value32_2 & 0xfff);
+	sfo_d = (s32)(value32_3 & 0xfff);
+
+	lfo_a = (s32)(value32 >> 16);
+	lfo_b = (s32)(value32_1 >> 16);
+	lfo_c = (s32)(value32_2 >> 16);
+	lfo_d = (s32)(value32_3 >> 16);
+
+	/*SFO 2's to dec*/
+	if (sfo_a > 2047)
+		sfo_a = sfo_a - 4096;
+	sfo_a = (sfo_a * 312500) / 2048;
+	if (sfo_b > 2047)
+		sfo_b = sfo_b - 4096;
+	sfo_b = (sfo_b * 312500) / 2048;
+	if (sfo_c > 2047)
+		sfo_c = sfo_c - 4096;
+	sfo_c = (sfo_c * 312500) / 2048;
+	if (sfo_d > 2047)
+		sfo_d = sfo_d - 4096;
+	sfo_d = (sfo_d * 312500) / 2048;
+
+	/*LFO 2's to dec*/
+
+	if (lfo_a > 4095)
+		lfo_a = lfo_a - 8192;
+
+	if (lfo_b > 4095)
+		lfo_b = lfo_b - 8192;
+
+	if (lfo_c > 4095)
+		lfo_c = lfo_c - 8192;
+
+	if (lfo_d > 4095)
+		lfo_d = lfo_d - 8192;
+	lfo_a = lfo_a * 312500 / 4096;
+	lfo_b = lfo_b * 312500 / 4096;
+	lfo_c = lfo_c * 312500 / 4096;
+	lfo_d = lfo_d * 312500 / 4096;
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "CFO Report Info");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "Short CFO(Hz) <A/B/C/D>", sfo_a, sfo_b, sfo_c, sfo_d);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "Long CFO(Hz) <A/B/C/D>", lfo_a, lfo_b, lfo_c, lfo_d);
+
+	/*SCFO*/
+	value32 = odm_get_bb_reg(dm, 0xd10, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd50, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd90, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xdd0, MASKDWORD);
+
+	sfo_a = (s32)(value32 & 0x7ff);
+	sfo_b = (s32)(value32_1 & 0x7ff);
+	sfo_c = (s32)(value32_2 & 0x7ff);
+	sfo_d = (s32)(value32_3 & 0x7ff);
+
+	if (sfo_a > 1023)
+		sfo_a = sfo_a - 2048;
+
+	if (sfo_b > 2047)
+		sfo_b = sfo_b - 4096;
+
+	if (sfo_c > 2047)
+		sfo_c = sfo_c - 4096;
+
+	if (sfo_d > 2047)
+		sfo_d = sfo_d - 4096;
+
+	sfo_a = sfo_a * 312500 / 1024;
+	sfo_b = sfo_b * 312500 / 1024;
+	sfo_c = sfo_c * 312500 / 1024;
+	sfo_d = sfo_d * 312500 / 1024;
+
+	lfo_a = (s32)(value32 >> 16);
+	lfo_b = (s32)(value32_1 >> 16);
+	lfo_c = (s32)(value32_2 >> 16);
+	lfo_d = (s32)(value32_3 >> 16);
+
+	if (lfo_a > 4095)
+		lfo_a = lfo_a - 8192;
+
+	if (lfo_b > 4095)
+		lfo_b = lfo_b - 8192;
+
+	if (lfo_c > 4095)
+		lfo_c = lfo_c - 8192;
+
+	if (lfo_d > 4095)
+		lfo_d = lfo_d - 8192;
+	lfo_a = lfo_a * 312500 / 4096;
+	lfo_b = lfo_b * 312500 / 4096;
+	lfo_c = lfo_c * 312500 / 4096;
+	lfo_d = lfo_d * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "value SCFO(Hz) <A/B/C/D>", sfo_a, sfo_b, sfo_c, sfo_d);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "ACQ CFO(Hz) <A/B/C/D>", lfo_a, lfo_b, lfo_c, lfo_d);
+
+	value32 = odm_get_bb_reg(dm, 0xd14, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd54, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd94, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xdd4, MASKDWORD);
+
+	lfo_a = (s32)(value32 >> 16);
+	lfo_b = (s32)(value32_1 >> 16);
+	lfo_c = (s32)(value32_2 >> 16);
+	lfo_d = (s32)(value32_3 >> 16);
+
+	if (lfo_a > 4095)
+		lfo_a = lfo_a - 8192;
+
+	if (lfo_b > 4095)
+		lfo_b = lfo_b - 8192;
+
+	if (lfo_c > 4095)
+		lfo_c = lfo_c - 8192;
+
+	if (lfo_d > 4095)
+		lfo_d = lfo_d - 8192;
+
+	lfo_a = lfo_a * 312500 / 4096;
+	lfo_b = lfo_b * 312500 / 4096;
+	lfo_c = lfo_c * 312500 / 4096;
+	lfo_d = lfo_d * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "End CFO(Hz) <A/B/C/D>", lfo_a, lfo_b, lfo_c, lfo_d);
+
+	value32 = odm_get_bb_reg(dm, 0xf20, MASKDWORD);  /*L SIG*/
+
+	tail = (u8)((value32 & 0xfc0000) >> 16);
+	parity = (u8)((value32 & 0x20000) >> 16);
+	length = (u16)((value32 & 0x1ffe00) >> 8);
+	rsv = (u8)(value32 & 0x10);
+	MCSS = (u8)(value32 & 0x0f);
+
+	switch (MCSS) {
+	case 0x0b:
+		idx = 0;
+		break;
+	case 0x0f:
+		idx = 1;
+		break;
+	case 0x0a:
+		idx = 2;
+		break;
+	case 0x0e:
+		idx = 3;
+		break;
+	case 0x09:
+		idx = 4;
+		break;
+	case 0x08:
+		idx = 5;
+		break;
+	case 0x0c:
+		idx = 6;
+		break;
+	default:
+		idx = 6;
+		break;
+
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "L-SIG");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s : %s", "rate", L_rate[idx]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x", "Rsv/length/parity", rsv,
+		       rx_bw, length);
+
+	value32 = odm_get_bb_reg(dm, 0xf2c, MASKDWORD);  /*HT SIG*/
+	if (rx_ht == 1) {
+		hmcss = (u8)(value32 & 0x7F);
+		hrx_bw = (u8)(value32 & 0x80);
+		h_length = (u16)((value32 >> 8) & 0xffff);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "HT-SIG1");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x", "MCS/BW/length", hmcss,
+		       hrx_bw, h_length);
+
+	value32 = odm_get_bb_reg(dm, 0xf30, MASKDWORD);  /*HT SIG*/
+
+	if (rx_ht == 1) {
+		smooth = (u8)(value32 & 0x01);
+		htsound = (u8)(value32 & 0x02);
+		rsv = (u8)(value32 & 0x04);
+		agg = (u8)(value32 & 0x08);
+		stbc = (u8)(value32 & 0x30);
+		fec = (u8)(value32 & 0x40);
+		sgi = (u8)(value32 & 0x80);
+		htltf = (u8)((value32 & 0x300) >> 8);
+		htcrc8 = (u16)((value32 & 0x3fc00) >> 8);
+		tail = (u8)((value32 & 0xfc0000) >> 16);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "HT-SIG2");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x / %x / %x",
+		       "Smooth/NoSound/Rsv/Aggregate/STBC/LDPC", smooth,
+		       htsound, rsv, agg, stbc, fec);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x",
+		       "SGI/E-HT-LTFs/CRC/tail", sgi, htltf, htcrc8, tail);
+
+	value32 = odm_get_bb_reg(dm, 0xf2c, MASKDWORD);  /*VHT SIG A1*/
+	if (rx_ht == 2) {
+		/* value32 = odm_get_bb_reg(dm, 0xf2c,MASKDWORD);*/
+		v_rx_bw = (u8)(value32 & 0x03);
+		vrsv = (u8)(value32 & 0x04);
+		vstbc = (u8)(value32 & 0x08);
+		vgid = (u8)((value32 & 0x3f0) >> 4);
+		v_nsts = (u8)(((value32 & 0x1c00) >> 8) + 1);
+		vpaid = (u16)(value32 & 0x3fe);
+		vtxops = (u8)((value32 & 0x400000) >> 20);
+		vrsv2 = (u8)((value32 & 0x800000) >> 20);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "VHT-SIG-A1");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x / %x",
+		       "BW/Rsv1/STBC/GID/Nsts/PAID/TXOPPS/Rsv2", v_rx_bw,
+		       vrsv, vstbc, vgid, v_nsts, vpaid, vtxops, vrsv2);
+
+	value32 = odm_get_bb_reg(dm, 0xf30, MASKDWORD);  /*VHT SIG*/
+
+	if (rx_ht == 2) {
+		/*value32 = odm_get_bb_reg(dm, 0xf30,MASKDWORD); */  /*VHT SIG*/
+
+		/* sgi=(u8)(value32&0x01); */
+		sgiext = (u8)(value32 & 0x03);
+		/* fec = (u8)(value32&0x04); */
+		fecext = (u8)(value32 & 0x0C);
+
+		v_mcss = (u8)(value32 & 0xf0);
+		bf = (u8)((value32 & 0x100) >> 8);
+		vrsv = (u8)((value32 & 0x200) >> 8);
+		vhtcrc8 = (u16)((value32 & 0x3fc00) >> 8);
+		v_tail = (u8)((value32 & 0xfc0000) >> 16);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "VHT-SIG-A2");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x",
+		       "SGI/FEC/MCS/BF/Rsv/CRC/tail", sgiext, fecext, v_mcss,
+		       bf, vrsv, vhtcrc8, v_tail);
+
+	value32 = odm_get_bb_reg(dm, 0xf34, MASKDWORD);  /*VHT SIG*/
+	{
+		v_length = (u16)(value32 & 0x1fffff);
+		vbrsv = (u8)((value32 & 0x600000) >> 20);
+		vb_tail = (u16)((value32 & 0x1f800000) >> 20);
+		vbcrc = (u8)((value32 & 0x80000000) >> 28);
+
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "VHT-SIG-B");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x",
+		       "length/Rsv/tail/CRC", v_length, vbrsv, vb_tail, vbcrc);
+
+	/*for Condition number*/
+	if (dm->support_ic_type & ODM_RTL8822B) {
+		s32	condition_num = 0;
+		char *factor = NULL;
+
+		odm_set_bb_reg(dm, 0x1988, BIT(22), 0x1);	/*enable report condition number*/
+
+		condition_num = odm_get_bb_reg(dm, 0xf84, MASKDWORD);
+		condition_num = (condition_num & 0x3ffff) >> 4;
+
+		if (*dm->band_width == CHANNEL_WIDTH_80)
+			factor = "256/234";
+		else if (*dm->band_width == CHANNEL_WIDTH_40)
+			factor = "128/108";
+		else if (*dm->band_width == CHANNEL_WIDTH_20) {
+			if (rx_ht != 2 || rx_ht != 1)
+				factor = "64/52";	/*HT or VHT*/
+			else
+				factor = "64/48";	/*legacy*/
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = %d (factor = %s)",
+			       "Condition number", condition_num, factor);
+
+	}
+	*_used = used;
+	*_out_len = out_len;
+
+}
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+void phydm_sbd_check(
+	struct dm_struct					*dm
+)
+{
+	static u32	pkt_cnt = 0;
+	static boolean sbd_state = 0;
+	u32	sym_count, count, value32;
+
+	if (sbd_state == 0) {
+		pkt_cnt++;
+		if (pkt_cnt % 5 == 0) { /*read SBD conter once every 5 packets*/
+			odm_set_timer(dm, &dm->sbdcnt_timer, 0); /*ms*/
+			sbd_state = 1;
+		}
+	} else { /*read counter*/
+		value32 = odm_get_bb_reg(dm, 0xF98, MASKDWORD);
+		sym_count = (value32 & 0x7C000000) >> 26;
+		count = (value32 & 0x3F00000) >> 20;
+		pr_debug("#SBD#    sym_count   %d   count   %d\n", sym_count, count);
+		sbd_state = 0;
+	}
+}
+#endif
+
+void phydm_sbd_callback(
+	struct phydm_timer_list		*timer
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	void		*adapter = timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	#if USE_WORKITEM
+	odm_schedule_work_item(&dm->sbdcnt_workitem);
+	#else
+	phydm_sbd_check(dm);
+	#endif
+#endif
+}
+
+void phydm_sbd_workitem_callback(
+	void            *context
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	void	*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	phydm_sbd_check(dm);
+#endif
+}
+#endif
+
+void
+phydm_reset_rx_rate_distribution(
+	struct dm_struct	*dm
+)
+{
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+
+	odm_memory_set(dm, &dbg->num_qry_legacy_pkt[0], 0,
+		       (LEGACY_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_ht_pkt[0], 0,
+		       (HT_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_pkt_sc_20m[0], 0,
+		       (LOW_BW_RATE_NUM * 2));
+	
+	dbg->ht_pkt_not_zero = false;
+	dbg->low_bw_20_occur = false;
+	
+#if	ODM_IC_11AC_SERIES_SUPPORT
+	odm_memory_set(dm, &dbg->num_qry_vht_pkt[0], 0,
+		       (VHT_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_pkt_sc_40m[0], 0,
+		       (LOW_BW_RATE_NUM * 2));
+	
+	dbg->vht_pkt_not_zero = false;
+	dbg->low_bw_40_occur = false;
+#endif
+}
+
+void
+phydm_rx_rate_distribution
+(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+	u8	i = 0, j = 0;
+	u8	rate_num = dm->num_rf_path, rate_ss_shift = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[RxRate Cnt] =============>\n");
+
+	/*======CCK=============================================================*/
+	if (*dm->channel <= 14) {
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* CCK = {%d, %d, %d, %d}\n",
+			dbg->num_qry_legacy_pkt[0],
+			dbg->num_qry_legacy_pkt[1],
+			dbg->num_qry_legacy_pkt[2],
+			dbg->num_qry_legacy_pkt[3]
+			);
+	}
+	/*======OFDM============================================================*/
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* OFDM = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+		dbg->num_qry_legacy_pkt[4], dbg->num_qry_legacy_pkt[5],
+		dbg->num_qry_legacy_pkt[6], dbg->num_qry_legacy_pkt[7],
+		dbg->num_qry_legacy_pkt[8], dbg->num_qry_legacy_pkt[9],
+		dbg->num_qry_legacy_pkt[10], dbg->num_qry_legacy_pkt[11]);
+
+	/*======HT==============================================================*/
+	if (dbg->ht_pkt_not_zero) {
+		
+		for (i = 0; i < rate_num; i++) {
+			
+			rate_ss_shift = (i << 3);
+			
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "* HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+				(rate_ss_shift), (rate_ss_shift+7),
+				dbg->num_qry_ht_pkt[rate_ss_shift + 0], dbg->num_qry_ht_pkt[rate_ss_shift + 1],
+				dbg->num_qry_ht_pkt[rate_ss_shift + 2], dbg->num_qry_ht_pkt[rate_ss_shift + 3],
+				dbg->num_qry_ht_pkt[rate_ss_shift + 4], dbg->num_qry_ht_pkt[rate_ss_shift + 5],
+				dbg->num_qry_ht_pkt[rate_ss_shift + 6], dbg->num_qry_ht_pkt[rate_ss_shift + 7]);
+		}
+
+		if (dbg->low_bw_20_occur) {
+			for (i = 0; i < rate_num; i++) {
+				
+				rate_ss_shift = (i << 3);
+				
+				PHYDM_DBG(dm, ODM_COMP_COMMON, "* [Low BW 20M] HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+					(rate_ss_shift), (rate_ss_shift+7),
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 0], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 1],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 2], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 3],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 4], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 5],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 6], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 7]);
+			}
+		}	
+	}
+
+
+	
+#if	ODM_IC_11AC_SERIES_SUPPORT
+	/*======VHT=============================================================*/
+	if (dbg->vht_pkt_not_zero) {
+		for (i = 0; i < rate_num; i++) {
+			rate_ss_shift = 10 * i;
+	
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "* VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+				(i + 1),
+				dbg->num_qry_vht_pkt[rate_ss_shift + 0], dbg->num_qry_vht_pkt[rate_ss_shift + 1],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 2], dbg->num_qry_vht_pkt[rate_ss_shift + 3],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 4], dbg->num_qry_vht_pkt[rate_ss_shift + 5],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 6], dbg->num_qry_vht_pkt[rate_ss_shift + 7],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 8], dbg->num_qry_vht_pkt[rate_ss_shift + 9]);
+		}
+
+		if (dbg->low_bw_20_occur) {
+			for (i = 0; i < rate_num; i++) {
+				rate_ss_shift = 10 * i;
+				
+				PHYDM_DBG(dm, ODM_COMP_COMMON, "*[Low BW 20M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+					(i + 1),
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 0], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 1],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 2], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 3],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 4], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 5],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 6], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 7],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 8], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 9]);
+			}
+		}
+
+		if (dbg->low_bw_40_occur) {
+			for (i = 0; i < rate_num; i++) {
+				rate_ss_shift = 10 * i;
+				
+				PHYDM_DBG(dm, ODM_COMP_COMMON, "*[Low BW 40M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+					(i + 1),
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 0], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 1],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 2], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 3],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 4], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 5],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 6], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 7],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 8], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 9]);
+			}
+		}
+	}
+#endif
+	
+}
+
+void
+phydm_get_avg_phystatus_val
+(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_phystatus_statistic		*dbg_statistic = &dm->phy_dbg_info.phystatus_statistic_info;
+	struct phydm_phystatus_avg		*dbg_avg = &dm->phy_dbg_info.phystatus_statistic_avg;
+	
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[Avg PHY Statistic] ==============>\n");
+
+	phydm_reset_phystatus_avg(dm);
+
+	/*CCK*/
+	dbg_avg->rssi_cck_avg = (u8)((dbg_statistic->rssi_cck_cnt != 0) ? (dbg_statistic->rssi_cck_sum/dbg_statistic->rssi_cck_cnt) : 0);
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* cck Cnt= ((%d)) RSSI:{%d}\n", dbg_statistic->rssi_cck_cnt, dbg_avg->rssi_cck_avg);
+	
+	/*OFDM*/
+	if (dbg_statistic->rssi_ofdm_cnt != 0) {
+		dbg_avg->rssi_ofdm_avg = (u8)(dbg_statistic->rssi_ofdm_sum/dbg_statistic->rssi_ofdm_cnt);
+		dbg_avg->evm_ofdm_avg = (u8)(dbg_statistic->evm_ofdm_sum/dbg_statistic->rssi_ofdm_cnt);
+		dbg_avg->snr_ofdm_avg = (u8)(dbg_statistic->snr_ofdm_sum/dbg_statistic->rssi_ofdm_cnt);
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* ofdm Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
+		dbg_statistic->rssi_ofdm_cnt, dbg_avg->rssi_ofdm_avg, dbg_avg->evm_ofdm_avg, dbg_avg->snr_ofdm_avg);
+	
+	if (dbg_statistic->rssi_1ss_cnt != 0) {
+		dbg_avg->rssi_1ss_avg = (u8)(dbg_statistic->rssi_1ss_sum/dbg_statistic->rssi_1ss_cnt);
+		dbg_avg->evm_1ss_avg = (u8)(dbg_statistic->evm_1ss_sum/dbg_statistic->rssi_1ss_cnt);
+		dbg_avg->snr_1ss_avg = (u8)(dbg_statistic->snr_1ss_sum/dbg_statistic->rssi_1ss_cnt);
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* 1-ss Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
+		dbg_statistic->rssi_1ss_cnt, dbg_avg->rssi_1ss_avg, dbg_avg->evm_1ss_avg, dbg_avg->snr_1ss_avg);
+
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {
+		if (dbg_statistic->rssi_2ss_cnt != 0) {
+			dbg_avg->rssi_2ss_avg[0] = (u8)(dbg_statistic->rssi_2ss_sum[0] /dbg_statistic->rssi_2ss_cnt);
+			dbg_avg->rssi_2ss_avg[1] = (u8)(dbg_statistic->rssi_2ss_sum[1] /dbg_statistic->rssi_2ss_cnt);
+			
+			dbg_avg->evm_2ss_avg[0] = (u8)(dbg_statistic->evm_2ss_sum[0] /dbg_statistic->rssi_2ss_cnt);
+			dbg_avg->evm_2ss_avg[1] = (u8)(dbg_statistic->evm_2ss_sum[1] /dbg_statistic->rssi_2ss_cnt);
+			
+			dbg_avg->snr_2ss_avg[0] = (u8)(dbg_statistic->snr_2ss_sum[0] /dbg_statistic->rssi_2ss_cnt);
+			dbg_avg->snr_2ss_avg[1] = (u8)(dbg_statistic->snr_2ss_sum[1] /dbg_statistic->rssi_2ss_cnt);
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* 2-ss Cnt= ((%d)) RSSI:{%d, %d}, EVM:{%d, %d}, SNR:{%d, %d}\n",
+			dbg_statistic->rssi_2ss_cnt, 
+			dbg_avg->rssi_2ss_avg[0], dbg_avg->rssi_2ss_avg[1], 
+			dbg_avg->evm_2ss_avg[0], dbg_avg->evm_2ss_avg[1], 
+			dbg_avg->snr_2ss_avg[0], dbg_avg->snr_2ss_avg[1]);
+	}
+	#endif
+
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
+		if (dbg_statistic->rssi_3ss_cnt != 0) {
+			dbg_avg->rssi_3ss_avg[0] = (u8)(dbg_statistic->rssi_3ss_sum[0] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->rssi_3ss_avg[1] = (u8)(dbg_statistic->rssi_3ss_sum[1] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->rssi_3ss_avg[2] = (u8)(dbg_statistic->rssi_3ss_sum[2] /dbg_statistic->rssi_3ss_cnt);
+			
+			dbg_avg->evm_3ss_avg[0] = (u8)(dbg_statistic->evm_3ss_sum[0] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->evm_3ss_avg[1] = (u8)(dbg_statistic->evm_3ss_sum[1] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->evm_3ss_avg[2] = (u8)(dbg_statistic->evm_3ss_sum[2] /dbg_statistic->rssi_3ss_cnt);
+
+			dbg_avg->snr_3ss_avg[0] = (u8)(dbg_statistic->snr_3ss_sum[0] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->snr_3ss_avg[1] = (u8)(dbg_statistic->snr_3ss_sum[1] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->snr_3ss_avg[2] = (u8)(dbg_statistic->snr_3ss_sum[2] /dbg_statistic->rssi_3ss_cnt);
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* 3-ss Cnt= ((%d)) RSSI:{%d, %d, %d} EVM:{%d, %d, %d} SNR:{%d, %d, %d}\n",
+			dbg_statistic->rssi_3ss_cnt, 
+			dbg_avg->rssi_3ss_avg[0], dbg_avg->rssi_3ss_avg[1], dbg_avg->rssi_3ss_avg[2],
+			dbg_avg->evm_3ss_avg[0], dbg_avg->evm_3ss_avg[1], dbg_avg->evm_3ss_avg[2],
+			dbg_avg->snr_3ss_avg[0], dbg_avg->snr_3ss_avg[1], dbg_avg->snr_3ss_avg[2]);
+	}
+	#endif
+
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+		if (dbg_statistic->rssi_4ss_cnt != 0) {
+			dbg_avg->rssi_4ss_avg[0] = (u8)(dbg_statistic->rssi_4ss_sum[0] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[1] = (u8)(dbg_statistic->rssi_4ss_sum[1] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[2] = (u8)(dbg_statistic->rssi_4ss_sum[2] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[3] = (u8)(dbg_statistic->rssi_4ss_sum[3] /dbg_statistic->rssi_4ss_cnt);
+
+			dbg_avg->evm_4ss_avg[0] = (u8)(dbg_statistic->evm_4ss_sum[0] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[1] = (u8)(dbg_statistic->evm_4ss_sum[1] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[2] = (u8)(dbg_statistic->evm_4ss_sum[2] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[3] = (u8)(dbg_statistic->evm_4ss_sum[3] /dbg_statistic->rssi_4ss_cnt);
+
+			dbg_avg->snr_4ss_avg[0] = (u8)(dbg_statistic->snr_4ss_sum[0] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[1] = (u8)(dbg_statistic->snr_4ss_sum[1] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[2] = (u8)(dbg_statistic->snr_4ss_sum[2] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[3] = (u8)(dbg_statistic->snr_4ss_sum[3] /dbg_statistic->rssi_4ss_cnt);
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* 4-ss Cnt= ((%d)) RSSI:{%d, %d, %d, %d} EVM:{%d, %d, %d, %d} SNR:{%d, %d, %d, %d}\n",
+			dbg_statistic->rssi_4ss_cnt, 
+			dbg_avg->rssi_4ss_avg[0], dbg_avg->rssi_4ss_avg[1], dbg_avg->rssi_4ss_avg[2], dbg_avg->rssi_4ss_avg[3],
+			dbg_avg->evm_4ss_avg[0], dbg_avg->evm_4ss_avg[1], dbg_avg->evm_4ss_avg[2], dbg_avg->evm_4ss_avg[3],
+			dbg_avg->snr_4ss_avg[0], dbg_avg->snr_4ss_avg[1], dbg_avg->snr_4ss_avg[2], dbg_avg->snr_4ss_avg[3]);
+	}
+	#endif
+
+	
+
+}
+
+void
+phydm_get_phy_statistic(
+	void		*dm_void
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	phydm_rx_rate_distribution(dm);
+	phydm_reset_rx_rate_distribution(dm);
+	
+	phydm_get_avg_phystatus_val(dm);
+	phydm_reset_phystatus_statistic(dm);
+};
+
+void
+phydm_basic_dbg_message
+(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct ra_table	*ra_tab = &dm->dm_ra_table;
+	u16	macid, phydm_macid, client_cnt = 0;
+	struct cmn_sta_info	*entry = NULL;
+	s32	tmp_val = 0;
+	u8	tmp_val_u1 = 0;
+
+	if (!(dm->debug_components & ODM_COMP_COMMON))
+		return;
+
+	if (dm->cmn_dbg_msg_cnt < dm->cmn_dbg_msg_period) {
+		dm->cmn_dbg_msg_cnt += PHYDM_WATCH_DOG_PERIOD;
+		return;
+	} else {
+		dm->cmn_dbg_msg_cnt = PHYDM_WATCH_DOG_PERIOD;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[PHYDM Common MSG] System up time: ((%d sec))----->\n", dm->phydm_sys_up_time);
+
+	if (dm->is_linked) {
+		PHYDM_DBG(dm, ODM_COMP_COMMON,
+			  "ID=((%d)), BW=((%d)), fc=((CH-%d))\n", dm->curr_station_id, 20<<*dm->band_width, *dm->channel);
+
+		if ((*dm->channel <= 14) && (*dm->band_width == CHANNEL_WIDTH_40)) {
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "Primary CCA at ((%s SB))\n",
+				((*dm->sec_ch_offset == SECOND_CH_AT_LSB)?"U":"L"));
+		}
+
+		if ((dm->support_ic_type & PHYSTS_2ND_TYPE_IC) || dm->rx_rate > ODM_RATE11M) {
+			
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "[AGC Idx] {0x%x, 0x%x, 0x%x, 0x%x}\n",
+				dm->ofdm_agc_idx[0], dm->ofdm_agc_idx[1], dm->ofdm_agc_idx[2], dm->ofdm_agc_idx[3]);
+		} else {
+		
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "[CCK AGC Idx] {LNA, VGA}={0x%x, 0x%x}\n",
+				dm->cck_lna_idx, dm->cck_vga_idx);
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "RSSI:{%d, %d, %d, %d}, RxRate:",
+			(dm->rssi_a == 0xff) ? 0 : dm->rssi_a,
+			(dm->rssi_b == 0xff) ? 0 : dm->rssi_b,
+			(dm->rssi_c == 0xff) ? 0 : dm->rssi_c,
+			(dm->rssi_d == 0xff) ? 0 : dm->rssi_d);
+
+		phydm_print_rate(dm, dm->rx_rate, ODM_COMP_COMMON);
+
+		phydm_get_phy_statistic(dm);
+
+		/*Print TX rate*/
+		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+			entry = dm->phydm_sta_info[macid];
+			if (!is_sta_active(entry)) {
+				continue;
+			}
+
+			phydm_macid = (dm->phydm_macid_table[macid]);
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "TxRate[%d]:", macid);
+			phydm_print_rate(dm, entry->ra_info.curr_tx_rate, ODM_COMP_COMMON);
+
+			client_cnt++;
+
+			if (client_cnt >= dm->number_linked_client)
+				break;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "TP {Tx, Rx, Total} = {%d, %d, %d}Mbps, Traffic_Load=(%d))\n",
+			dm->tx_tp, dm->rx_tp, dm->total_tp, dm->traffic_load);
+
+		tmp_val_u1 = (cfo_track->crystal_cap > cfo_track->def_x_cap) ? (cfo_track->crystal_cap - cfo_track->def_x_cap) : (cfo_track->def_x_cap - cfo_track->crystal_cap);
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "CFO_avg = ((%d kHz)) , CFO_tracking = ((%s%d))\n",
+			cfo_track->CFO_ave_pre, ((cfo_track->crystal_cap > cfo_track->def_x_cap) ? "+" : "-"), tmp_val_u1);
+
+		/* Condition number */
+	#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			tmp_val = phydm_get_condition_number_8822B(dm);
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "Condi_Num=((%d))\n", tmp_val);
+		}
+	#endif
+
+	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		/*STBC or LDPC pkt*/
+		if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC)
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "Coding: LDPC=((%s)), STBC=((%s))\n", (dm->phy_dbg_info.is_ldpc_pkt) ? "Y" : "N", (dm->phy_dbg_info.is_stbc_pkt) ? "Y" : "N");
+	#endif
+	} else
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "No Link !!!\n");
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all);
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all);
+
+	#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), CRC8_fail = (( %d )), Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d ))\n",
+			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail);
+	}
+	#endif
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "is_linked = %d, Num_client = %d, rssi_min = %d, IGI = 0x%x, bNoisy=%d\n\n",
+		dm->is_linked, dm->number_linked_client, dm->rssi_min, dig_t->cur_ig_value, dm->noisy_decision);
+}
+
+
+void phydm_basic_profile(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	char  *cut = NULL;
+	char *ic_type = NULL;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32	date = 0;
+	char	*commit_by = NULL;
+	u32	release_ver = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "% Basic Profile %");
+
+	if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		ic_type = "RTL8188E";
+		date = RELEASE_DATE_8188E;
+		commit_by = COMMIT_BY_8188E;
+		release_ver = RELEASE_VERSION_8188E;
+#endif
+	}
+#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8812) {
+		ic_type = "RTL8812A";
+		date = RELEASE_DATE_8812A;
+		commit_by = COMMIT_BY_8812A;
+		release_ver = RELEASE_VERSION_8812A;
+	}
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821) {
+		ic_type = "RTL8821A";
+		date = RELEASE_DATE_8821A;
+		commit_by = COMMIT_BY_8821A;
+		release_ver = RELEASE_VERSION_8821A;
+	}
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		ic_type = "RTL8192E";
+		date = RELEASE_DATE_8192E;
+		commit_by = COMMIT_BY_8192E;
+		release_ver = RELEASE_VERSION_8192E;
+	}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		ic_type = "RTL8723B";
+		date = RELEASE_DATE_8723B;
+		commit_by = COMMIT_BY_8723B;
+		release_ver = RELEASE_VERSION_8723B;
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8814A) {
+		ic_type = "RTL8814A";
+		date = RELEASE_DATE_8814A;
+		commit_by = COMMIT_BY_8814A;
+		release_ver = RELEASE_VERSION_8814A;
+	}
+#endif
+#if (RTL8881A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8881A) {
+		ic_type = "RTL8881A";
+		/**/
+	}
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		ic_type = "RTL8822B";
+		date = RELEASE_DATE_8822B;
+		commit_by = COMMIT_BY_8822B;
+		release_ver = RELEASE_VERSION_8822B;
+	}
+#endif
+#if (RTL8197F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8197F) {
+		ic_type = "RTL8197F";
+		date = RELEASE_DATE_8197F;
+		commit_by = COMMIT_BY_8197F;
+		release_ver = RELEASE_VERSION_8197F;
+	}
+#endif
+
+#if (RTL8703B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8703B) {
+		ic_type = "RTL8703B";
+		date = RELEASE_DATE_8703B;
+		commit_by = COMMIT_BY_8703B;
+		release_ver = RELEASE_VERSION_8703B;
+
+	}
+#endif
+#if (RTL8195A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8195A) {
+		ic_type = "RTL8195A";
+		/**/
+	}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8188F) {
+		ic_type = "RTL8188F";
+		date = RELEASE_DATE_8188F;
+		commit_by = COMMIT_BY_8188F;
+		release_ver = RELEASE_VERSION_8188F;
+	}
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		ic_type = "RTL8723D";
+		date = RELEASE_DATE_8723D;
+		commit_by = COMMIT_BY_8723D;
+		release_ver = RELEASE_VERSION_8723D;
+		/**/
+	}
+#endif
+
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8710B) {
+		ic_type = "RTL8710B";
+		date = RELEASE_DATE_8710B;
+		commit_by = COMMIT_BY_8710B;
+		release_ver = RELEASE_VERSION_8710B;
+		/**/
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		ic_type = "RTL8821C";
+		date = RELEASE_DATE_8821C;
+		commit_by = COMMIT_BY_8821C;
+		release_ver = RELEASE_VERSION_8821C;
+	}
+#endif
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s (MP Chip: %s)\n", "IC type", ic_type,
+		       dm->is_mp_chip ? "Yes" : "No");
+
+	if (dm->cut_version == ODM_CUT_A)
+		cut = "A";
+	else if (dm->cut_version == ODM_CUT_B)
+		cut = "B";
+	else if (dm->cut_version == ODM_CUT_C)
+		cut = "C";
+	else if (dm->cut_version == ODM_CUT_D)
+		cut = "D";
+	else if (dm->cut_version == ODM_CUT_E)
+		cut = "E";
+	else if (dm->cut_version == ODM_CUT_F)
+		cut = "F";
+	else if (dm->cut_version == ODM_CUT_I)
+		cut = "I";
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "RFE type", dm->rfe_type);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Cut Ver", cut);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "PHY Para Ver",
+		       odm_get_hw_img_version(dm));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "PHY Para Commit date", date);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "PHY Para Commit by", commit_by);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "PHY Para Release Ver", release_ver);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	{
+		void		*adapter = dm->adapter;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       ((PADAPTER)adapter)->MgntInfo.FirmwareVersion,
+			       ((PADAPTER)adapter)->MgntInfo.FirmwareSubVersion);
+	}
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	{
+		struct rtl8192cd_priv *priv = dm->priv;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       priv->pshare->fw_version,
+			       priv->pshare->fw_sub_version);
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	{
+		struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+		struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       rtlhal->fw_version, rtlhal->fw_subversion);
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       hal_data->firmware_version,
+			       hal_data->firmware_sub_version);
+	}
+#endif
+	/* 1 PHY DM version List */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "% PHYDM version %");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Code base", PHYDM_CODE_BASE);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Release Date", PHYDM_RELEASE_DATE);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Adaptivity", ADAPTIVITY_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "DIG", DIG_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "CFO Tracking", CFO_TRACKING_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "AntDiv", ANTDIV_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Dynamic TxPower",
+		       DYNAMIC_TXPWR_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "RA Info", RAINFO_VERSION);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "AntDetect", ANTDECT_VERSION);
+#endif
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "PathDiv", PATHDIV_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "LA mode", DYNAMIC_LA_MODE);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Primary CCA", PRIMARYCCA_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "DFS", DFS_VERSION);
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %s\n", "PHY config 8822B",
+			       PHY_CONFIG_VERSION_8822B);
+
+#endif
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %s\n", "PHY config 8197F",
+			       PHY_CONFIG_VERSION_8197F);
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+	
+	/* RF Function version List */
+	halrf_basic_profile(dm_void, &used, output, &out_len);
+
+#endif /*#if CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+void
+phydm_fw_trace_en_h2c(
+	void		*dm_void,
+	boolean		enable,
+	u32		fw_debug_component,
+	u32		monitor_mode,
+	u32		macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			h2c_parameter[7] = {0};
+	u8			cmd_length;
+
+	if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+		h2c_parameter[0] = enable;
+		h2c_parameter[1] = (u8)(fw_debug_component & MASKBYTE0);
+		h2c_parameter[2] = (u8)((fw_debug_component & MASKBYTE1) >> 8);
+		h2c_parameter[3] = (u8)((fw_debug_component & MASKBYTE2) >> 16);
+		h2c_parameter[4] = (u8)((fw_debug_component & MASKBYTE3) >> 24);
+		h2c_parameter[5] = (u8)monitor_mode;
+		h2c_parameter[6] = (u8)macid;
+		cmd_length = 7;
+
+	} else {
+		h2c_parameter[0] = enable;
+		h2c_parameter[1] = (u8)monitor_mode;
+		h2c_parameter[2] = (u8)macid;
+		cmd_length = 3;
+	}
+
+
+	PHYDM_DBG(dm, DBG_FW_TRACE, "---->\n");
+	if (monitor_mode == 0)
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[H2C] FW_debug_en: (( %d ))\n", enable);
+	else
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[H2C] FW_debug_en: (( %d )), mode: (( %d )), macid: (( %d ))\n", enable, monitor_mode, macid);
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_FW_TRACE_EN, cmd_length, h2c_parameter);
+}
+
+void
+phydm_get_per_path_txagc(
+	void			*dm_void,
+	u8			path,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			rate_idx;
+	u8			txagc;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+	if (((dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) && (path <= RF_PATH_B)) ||
+		((dm->support_ic_type & (ODM_RTL8821C)) && (path <= RF_PATH_A))) {
+		for (rate_idx = 0; rate_idx <= 0x53; rate_idx++) {
+			if (rate_idx == ODM_RATE1M)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "  %-35s\n",
+					       "CCK====>");
+			else if (rate_idx == ODM_RATE6M)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "OFDM====>");
+			else if (rate_idx == ODM_RATEMCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 1ss====>");
+			else if (rate_idx == ODM_RATEMCS8)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 2ss====>");
+			else if (rate_idx == ODM_RATEMCS16)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 3ss====>");
+			else if (rate_idx == ODM_RATEMCS24)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 4ss====>");
+			else if (rate_idx == ODM_RATEVHTSS1MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 1ss====>");
+			else if (rate_idx == ODM_RATEVHTSS2MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 2ss====>");
+			else if (rate_idx == ODM_RATEVHTSS3MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 3ss====>");
+			else if (rate_idx == ODM_RATEVHTSS4MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 4ss====>");
+
+			txagc = phydm_api_get_txagc(dm, (enum rf_path) path, rate_idx);
+			if (config_phydm_read_txagc_check(txagc))
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "  0x%02x    ",
+					       txagc);
+			else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "  0x%s    ",
+					       "xx");
+		}
+	}
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+
+}
+
+
+void
+phydm_get_txagc(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	/* path-A */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "path-A====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_A, &used, output, &out_len);
+
+	/* path-B */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\n%-35s\n", "path-B====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_B, &used, output, &out_len);
+
+	/* path-C */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\n%-35s\n", "path-C====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_C, &used, output, &out_len);
+
+	/* path-D */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\n%-35s\n", "path-D====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_D, &used, output, &out_len);
+
+	*_used = used;
+	*_out_len = out_len;
+
+}
+
+void
+phydm_set_txagc(
+	void			*dm_void,
+	u32			*const dm_value,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u8	i;
+	u32	power_index;
+	boolean	status = true;
+
+	/*dm_value[1] = path*/
+	/*dm_value[2] = hw_rate*/
+	/*dm_value[3] = power_index*/
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+	if ((dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)) == 0)
+		return;
+	
+	if (dm_value[1] >= dm->num_rf_path) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %s%d   %s%x%s\n", "Write path-",
+			       (dm_value[1] & 0x1), "rate index-0x",
+			       (dm_value[2] & 0x7f), " fail");
+	} else if ((u8)dm_value[2] != 0xff) {
+		if (phydm_api_set_txagc(dm, dm_value[3], (enum rf_path) dm_value[1], (u8)dm_value[2], true))
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s%x%s%x\n",
+				       "Write path-", dm_value[1],
+				       "rate index-0x", dm_value[2], " = 0x",
+				       dm_value[3]);
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s%x%s\n",
+				       "Write path-", (dm_value[1] & 0x1),
+				       "rate index-0x", (dm_value[2] & 0x7f),
+				       " fail");
+	} else {
+		power_index = (dm_value[3] & 0x3f);
+
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+			power_index = (power_index << 24) | (power_index << 16) | (power_index << 8) | (power_index);
+
+			for (i = 0; i < ODM_RATEVHTSS2MCS9; i += 4)
+				status = (status & phydm_api_set_txagc(dm, power_index, (enum rf_path) dm_value[1], i, false));
+		} else if (dm->support_ic_type & ODM_RTL8197F) {
+			for (i = 0; i <= ODM_RATEMCS15; i++)
+				status = (status & phydm_api_set_txagc(dm, power_index, (enum rf_path) dm_value[1], i, false));
+		}
+
+		if (status)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s%x\n",
+				       "Write all TXAGC of path-",
+				       dm_value[1], " = 0x", dm_value[3]);
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s\n",
+				       "Write all TXAGC of path-",
+				       dm_value[1], " fail");
+	}
+
+#endif
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_debug_trace(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			pre_debug_components, one = 1;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			dm_value[10] = {0};
+
+	u8	i;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+		}
+	}
+
+	pre_debug_components = dm->debug_components;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n================================\n");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "[DBG MSG] Component Selection\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "================================\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "00. (( %s ))DIG\n",
+			       ((dm->debug_components & DBG_DIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "01. (( %s ))RA_MASK\n",
+			       ((dm->debug_components & DBG_RA_MASK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "02. (( %s ))DYN_TXPWR\n",
+			       ((dm->debug_components & DBG_DYN_TXPWR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "03. (( %s ))FA_CNT\n",
+			       ((dm->debug_components & DBG_FA_CNT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "04. (( %s ))RSSI_MNTR\n",
+			       ((dm->debug_components & DBG_RSSI_MNTR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "05. (( %s ))CCKPD\n",
+			       ((dm->debug_components & DBG_CCKPD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "06. (( %s ))ANT_DIV\n",
+			       ((dm->debug_components & DBG_ANT_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "07. (( %s ))SMT_ANT\n",
+			       ((dm->debug_components & DBG_SMT_ANT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "08. (( %s ))PWR_TRAIN\n",
+			       ((dm->debug_components & F08_PWR_TRAIN) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "09. (( %s ))RA\n",
+			       ((dm->debug_components & DBG_RA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "10. (( %s ))PATH_DIV\n",
+			       ((dm->debug_components & DBG_PATH_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "11. (( %s ))DFS\n",
+			       ((dm->debug_components & DBG_DFS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "12. (( %s ))DYN_ARFR\n",
+			       ((dm->debug_components & DBG_DYN_ARFR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "13. (( %s ))ADAPTIVITY\n",
+			       ((dm->debug_components & DBG_ADPTVTY) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "14. (( %s ))CFO_TRK\n",
+			       ((dm->debug_components & DBG_CFO_TRK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "15. (( %s ))ENV_MNTR\n",
+			       ((dm->debug_components & DBG_ENV_MNTR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "16. (( %s ))PRI_CCA\n",
+			       ((dm->debug_components & DBG_PRI_CCA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "17. (( %s ))ADPTV_SOML\n",
+			       ((dm->debug_components & DBG_ADPTV_SOML) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "18. (( %s ))LNA_SAT_CHK\n",
+			       ((dm->debug_components & DBG_LNA_SAT_CHK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "19. (( %s ))DRP\n",
+			       ((dm->debug_components & DBG_DYN_RX_PATH) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "20. (( %s ))PHY_STATUS\n",
+			       ((dm->debug_components & DBG_PHY_STATUS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "21. (( %s ))TMP\n",
+			       ((dm->debug_components & DBG_TMP) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "22. (( %s ))FW_DBG_TRACE\n",
+			       ((dm->debug_components & DBG_FW_TRACE) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "23. (( %s ))TXBF\n",
+			       ((dm->debug_components & DBG_TXBF) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "24. (( %s ))COMMON_FLOW\n",
+			       ((dm->debug_components & DBG_COMMON_FLOW) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "25. (( %s ))TX_PWR_TRK\n",
+			       ((dm->debug_components & ODM_COMP_TX_PWR_TRACK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "26. (( %s ))CALIBRATION\n",
+			       ((dm->debug_components & ODM_COMP_CALIBRATION) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "27. (( %s ))MP\n",
+			       ((dm->debug_components & ODM_COMP_MP) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "28. (( %s ))PHY_CONFIG\n",
+			       ((dm->debug_components & ODM_PHY_CONFIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "29. (( %s ))INIT\n",
+			       ((dm->debug_components & ODM_COMP_INIT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "30. (( %s ))COMMON\n",
+			       ((dm->debug_components & ODM_COMP_COMMON) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "31. (( %s ))API\n",
+			       ((dm->debug_components & ODM_COMP_API) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "================================\n");
+
+	} else if (dm_value[0] == 101) {
+		dm->debug_components = 0;
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Disable all debug components\n");
+	} else {
+		if (dm_value[1] == 1)   /*enable*/
+			dm->debug_components |= (one << dm_value[0]);
+		else if (dm_value[1] == 2)   /*disable*/
+			dm->debug_components &= ~(one << dm_value[0]);
+		else
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Warning]  1:on,  2:off\n");
+
+		if ((BIT(dm_value[0]) == DBG_PHY_STATUS) && (dm_value[1] == 1)) {
+
+			dm->phy_dbg_info.show_phy_sts_all_pkt = (u8)dm_value[2];
+			dm->phy_dbg_info.show_phy_sts_max_cnt = (u16)dm_value[3];
+
+			PDM_SNPF(out_len, used, output + used, out_len - used, "show_phy_sts_all_pkt=%d, show_phy_sts_max=%d\n\n",
+				dm->phy_dbg_info.show_phy_sts_all_pkt,
+				dm->phy_dbg_info.show_phy_sts_max_cnt);
+
+		} else if ((BIT(dm_value[0]) == ODM_COMP_COMMON) && (dm_value[1] == 1)) {
+			dm->cmn_dbg_msg_period = (u8)dm_value[2];
+
+			if (dm->cmn_dbg_msg_period < PHYDM_WATCH_DOG_PERIOD)
+				dm->cmn_dbg_msg_period = PHYDM_WATCH_DOG_PERIOD;
+
+			PDM_SNPF(out_len, used, output + used, out_len - used, "cmn_dbg_msg_period=%d\n",
+				dm->cmn_dbg_msg_period);
+		}
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "pre-DbgComponents = 0x%llx\n", pre_debug_components);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Curr-DbgComponents = 0x%llx\n", dm->debug_components);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "================================\n");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_fw_debug_trace(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			pre_fw_debug_components, one = 1;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	pre_fw_debug_components = dm->fw_debug_components;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%s\n",
+		       "================================");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "[FW Debug Component]");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))RA\n",
+			       ((dm->fw_debug_components & PHYDM_FW_COMP_RA) ? ("V") : (".")));
+
+		if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "01. (( %s ))MU\n",
+				       ((dm->fw_debug_components & PHYDM_FW_COMP_MU) ? ("V") : (".")));
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "02. (( %s ))path Div\n",
+				       ((dm->fw_debug_components & PHYDM_FW_COMP_PATH_DIV) ? ("V") : (".")));
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "03. (( %s ))Power training\n",
+				       ((dm->fw_debug_components & PHYDM_FW_COMP_PT) ? ("V") : (".")));
+		}
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+
+	} else {
+		if (dm_value[0] == 101) {
+			dm->fw_debug_components = 0;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "%s\n",
+				       "Clear all fw debug components");
+		} else {
+			if (dm_value[1] == 1)   /*enable*/
+				dm->fw_debug_components |= (one << dm_value[0]);
+			else if (dm_value[1] == 2)   /*disable*/
+				dm->fw_debug_components &= ~(one << dm_value[0]);
+			else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "%s\n",
+					       "[Warning!!!]  1:enable,  2:disable");
+		}
+
+		if (dm->fw_debug_components == 0) {
+			dm->debug_components &= ~DBG_FW_TRACE;
+			phydm_fw_trace_en_h2c(dm, false, dm->fw_debug_components, dm_value[2], dm_value[3]); /*H2C to enable C2H Msg*/
+		} else {
+			dm->debug_components |= DBG_FW_TRACE;
+			phydm_fw_trace_en_h2c(dm, true, dm->fw_debug_components, dm_value[2], dm_value[3]); /*H2C to enable C2H Msg*/
+		}
+	}
+}
+
+void
+phydm_dump_bb_reg(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			addr = 0;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+
+	/* BB Reg, For Nseries IC we only need to dump page8 to pageF using 3 digits*/
+	for (addr = 0x800; addr < 0xfff; addr += 4) {
+		if (dm->support_ic_type & ODM_IC_11N_SERIES)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%03x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+		else
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8814A | ODM_RTL8821C)) {
+		if (dm->rf_type > RF_2T2R) {
+			for (addr = 0x1800; addr < 0x18ff; addr += 4)
+				PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+							 "0x%04x 0x%08x\n",
+							 addr,
+							 odm_get_bb_reg(dm, addr, MASKDWORD));
+		}
+
+		if (dm->rf_type > RF_3T3R) {
+			for (addr = 0x1a00; addr < 0x1aff; addr += 4)
+				PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+							 "0x%04x 0x%08x\n",
+							 addr,
+							 odm_get_bb_reg(dm, addr, MASKDWORD));
+		}
+
+		for (addr = 0x1900; addr < 0x19ff; addr += 4)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+		for (addr = 0x1c00; addr < 0x1cff; addr += 4)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+		for (addr = 0x1f00; addr < 0x1fff; addr += 4)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_dump_all_reg(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			addr = 0;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	/* dump MAC register */
+	PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+				 "MAC==========\n");
+	for (addr = 0; addr < 0x7ff; addr += 4)
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "0x%04x 0x%08x\n",
+					 addr,
+					 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+	for (addr = 0x1000; addr < 0x17ff; addr += 4)
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "0x%04x 0x%08x\n",
+					 addr,
+					 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+	/* dump BB register */
+	PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+				 "BB==========\n");
+	phydm_dump_bb_reg(dm, &used, output, &out_len);
+
+	/* dump RF register */
+	PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+				 "RF-A==========\n");
+	for (addr = 0; addr < 0xFF; addr++)
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "0x%02x 0x%05x\n",
+					 addr,
+					 odm_get_rf_reg(dm, RF_PATH_A, addr, RFREGOFFSETMASK));
+
+	if (dm->rf_type > RF_1T1R) {
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "RF-B==========\n");
+		for (addr = 0; addr < 0xFF; addr++)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+						 "0x%02x 0x%05x\n", addr,
+						 odm_get_rf_reg(dm, RF_PATH_B, addr, RFREGOFFSETMASK));
+	}
+
+	if (dm->rf_type > RF_2T2R) {
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "RF-C==========\n");
+		for (addr = 0; addr < 0xFF; addr++)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+						 "0x%02x 0x%05x\n", addr,
+						 odm_get_rf_reg(dm, RF_PATH_C, addr, RFREGOFFSETMASK));
+	}
+
+	if (dm->rf_type > RF_3T3R) {
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "RF-D==========\n");
+		for (addr = 0; addr < 0xFF; addr++)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+						 "0x%02x 0x%05x\n", addr,
+						 odm_get_rf_reg(dm, RF_PATH_D, addr, RFREGOFFSETMASK));
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_enable_big_jump(
+	struct dm_struct	*dm,
+	boolean		state
+)
+{
+#if (RTL8822B_SUPPORT == 1)
+	struct phydm_dig_struct			*dig_t = &dm->dm_dig_table;
+
+	if (state == false) {
+		dm->dm_dig_table.enable_adjust_big_jump = false;
+		odm_set_bb_reg(dm, 0x8c8, 0xfe, ((dig_t->big_jump_step3 << 5) | (dig_t->big_jump_step2 << 3) | dig_t->big_jump_step1));
+	} else
+		dm->dm_dig_table.enable_adjust_big_jump = true;
+#endif
+}
+
+#if (RTL8822B_SUPPORT == 1 | RTL8821C_SUPPORT == 1 | RTL8814B_SUPPORT == 1)
+
+void
+phydm_show_rx_rate(
+	struct dm_struct			*dm,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "=====Rx SU rate Statistics=====\n");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS0 = %d, 1SS MCS1 = %d, 1SS MCS2 = %d, 1SS MCS 3 = %d\n",
+		       dm->phy_dbg_info.num_qry_vht_pkt[0],
+		       dm->phy_dbg_info.num_qry_vht_pkt[1],
+		       dm->phy_dbg_info.num_qry_vht_pkt[2],
+		       dm->phy_dbg_info.num_qry_vht_pkt[3]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS4 = %d, 1SS MCS5 = %d, 1SS MCS6 = %d, 1SS MCS 7 = %d\n",
+		       dm->phy_dbg_info.num_qry_vht_pkt[4],
+		       dm->phy_dbg_info.num_qry_vht_pkt[5],
+		       dm->phy_dbg_info.num_qry_vht_pkt[6],
+		       dm->phy_dbg_info.num_qry_vht_pkt[7]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS8 = %d, 1SS MCS9 = %d\n",
+		       dm->phy_dbg_info.num_qry_vht_pkt[8],
+		       dm->phy_dbg_info.num_qry_vht_pkt[9]);
+			   
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {			   
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS0 = %d, 2SS MCS1 = %d, 2SS MCS2 = %d, 2SS MCS 3 = %d\n",
+				   dm->phy_dbg_info.num_qry_vht_pkt[10],
+				   dm->phy_dbg_info.num_qry_vht_pkt[11],
+				   dm->phy_dbg_info.num_qry_vht_pkt[12],
+				   dm->phy_dbg_info.num_qry_vht_pkt[13]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS4 = %d, 2SS MCS5 = %d, 2SS MCS6 = %d, 2SS MCS 7 = %d\n",
+				   dm->phy_dbg_info.num_qry_vht_pkt[14],
+				   dm->phy_dbg_info.num_qry_vht_pkt[15],
+				   dm->phy_dbg_info.num_qry_vht_pkt[16],
+				   dm->phy_dbg_info.num_qry_vht_pkt[17]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS8 = %d, 2SS MCS9 = %d\n",
+				   dm->phy_dbg_info.num_qry_vht_pkt[18],
+				   dm->phy_dbg_info.num_qry_vht_pkt[19]);
+	}
+#endif
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "=====Rx MU rate Statistics=====\n");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS0 = %d, 1SS MCS1 = %d, 1SS MCS2 = %d, 1SS MCS 3 = %d\n",
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[0],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[1],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[2],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[3]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS4 = %d, 1SS MCS5 = %d, 1SS MCS6 = %d, 1SS MCS 7 = %d\n",
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[4],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[5],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[6],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[7]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS8 = %d, 1SS MCS9 = %d\n",
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[8],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[9]);
+			   
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {			   
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS0 = %d, 2SS MCS1 = %d, 2SS MCS2 = %d, 2SS MCS 3 = %d\n",
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[10],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[11],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[12],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[13]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS4 = %d, 2SS MCS5 = %d, 2SS MCS6 = %d, 2SS MCS 7 = %d\n",
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[14],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[15],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[16],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[17]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS8 = %d, 2SS MCS9 = %d\n",
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[18],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[19]);
+	}
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif
+
+void
+phydm_per_tone_evm(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		i, j;
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		var1[4] = {0};
+	u32		value32, tone_num, round;
+	s8		rxevm_0, rxevm_1;
+	s32		avg_num, evm_tone_0[256] = {0}, evm_tone_1[256] = {0};
+	s32		rxevm_sum_0, rxevm_sum_1;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		pr_debug("n series not support yet !\n");
+		return;
+	}
+
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+	}
+	avg_num = var1[0];
+	round = var1[1];
+
+	if (dm->is_linked) {
+		pr_debug("ID=((%d)), BW=((%d)), fc=((CH-%d))\n", dm->curr_station_id,
+		          20<<*dm->band_width, *dm->channel);
+		pr_debug("avg_num =((%d)), round =((%d))\n", avg_num, round);
+		#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+		watchdog_stop(dm->priv);
+		#endif
+		for (j = 0; j < round; j++) {
+			pr_debug("\nround((%d))\n", (j + 1));
+		if (*dm->band_width == CHANNEL_WIDTH_20) {
+			for (tone_num = 228; tone_num <= 255; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone((-%-3d)) RXEVM (1ss/2ss) =%d , %d\n", (256 - tone_num), evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+
+			for (tone_num = 1; tone_num <= 28; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(( %-3d)) RXEVM (1ss/2ss) =%d , %d\n", tone_num, evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+		} else if (*dm->band_width == CHANNEL_WIDTH_40) {
+			for (tone_num = 198; tone_num <= 254; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone((-%-3d)) RXEVM (1ss/2ss) =%d , %d\n", (256 - tone_num), evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+
+			for (tone_num = 2; tone_num <= 58; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(( %-3d)) RXEVM (1ss/2ss) =%d , %d\n", tone_num, evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+		} else if (*dm->band_width == CHANNEL_WIDTH_80) {
+			for (tone_num = 134; tone_num <= 254; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone((-%-3d)) RXEVM (1ss/2ss) =%d , %d\n", (256 - tone_num), evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+
+			for (tone_num = 2; tone_num <= 122; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(( %-3d)) RXEVM (1ss/2ss) =%d , %d\n", tone_num, evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+			}
+		}
+	} else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+		               "No Link !!\n");
+
+}
+
+void
+phydm_api_adjust(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+	boolean	is_enable_dbg_mode;
+	u8 central_ch, primary_ch_idx;
+	enum channel_width	bandwidth;
+	
+#ifdef PHYDM_COMMON_API_SUPPORT
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{en} {ch_num} {prm_ch 1/2/3/4/9/10} {0:20M, 1:40M, 2:80M}\n");
+		goto out;
+
+	}
+
+	if ((dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "This IC doesn't support PHYDM API function\n");
+		/**/
+		goto out;
+	}
+
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+	}
+
+	is_enable_dbg_mode = (boolean)var1[0];
+	central_ch = (u8) var1[1];
+	primary_ch_idx = (u8) var1[2];
+	bandwidth = (enum channel_width)var1[3];
+
+	if (is_enable_dbg_mode) {
+		dm->is_disable_phy_api = false;
+		phydm_api_switch_bw_channel(dm, central_ch, primary_ch_idx, bandwidth);
+		dm->is_disable_phy_api = true;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "central_ch = %d, primary_ch_idx = %d, bandwidth = %d\n",
+			       central_ch, primary_ch_idx, bandwidth);
+	} else {
+		dm->is_disable_phy_api = false;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Disable API debug mode\n");
+	}
+out:
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "This IC doesn't support PHYDM API function\n");
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_parameter_adjust(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "1. X_cap = ((0x%x))\n",
+			       cfo_track->crystal_cap);
+
+	} else {
+	
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 0) {
+			PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
+			phydm_set_crystal_cap(dm, (u8)var1[1]);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "X_cap = ((0x%x))\n",
+				       cfo_track->crystal_cap);
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+struct phydm_command {
+	char name[16];
+	u8 id;
+};
+
+enum PHYDM_CMD_ID {
+	PHYDM_HELP,
+	PHYDM_DEMO,
+	PHYDM_DIG,
+	PHYDM_RA,
+	PHYDM_PROFILE,
+	PHYDM_ANTDIV,
+	PHYDM_PATHDIV,
+	PHYDM_DEBUG,
+	PHYDM_FW_DEBUG,
+	PHYDM_SUPPORT_ABILITY,
+	PHYDM_RF_SUPPORTABILITY,
+	PHYDM_RF_PROFILE,
+	PHYDM_RF_IQK_INFO,
+	PHYDM_IQK,
+	PHYDM_IQK_DEBUG,
+	PHYDM_GET_TXAGC,
+	PHYDM_SET_TXAGC,
+	PHYDM_SMART_ANT,
+	PHYDM_API,
+	PHYDM_TRX_PATH,
+	PHYDM_LA_MODE,
+	PHYDM_DUMP_REG,
+	PHYDM_AUTO_DBG,
+	PHYDM_BIG_JUMP,
+	PHYDM_SHOW_RXRATE,
+	PHYDM_NBI_EN,
+	PHYDM_CSI_MASK_EN,
+	PHYDM_DFS_DEBUG,
+	PHYDM_NHM,
+	PHYDM_CLM,
+	PHYDM_FAHM,
+	PHYDM_ENV_MNTR,
+	PHYDM_BB_INFO,
+	PHYDM_TXBF,
+	PHYDM_H2C,
+	PHYDM_ANT_SWITCH,
+	PHYDM_DYNAMIC_RA_PATH,
+	PHYDM_ADAPTIVE_SOML,
+	PHYDM_PSD,
+	PHYDM_DEBUG_PORT,
+	PHYDM_DIS_HTSTF_CONTROL,
+	PHYDM_TUNE_PARAMETER,
+	PHYDM_ADAPTIVITY_DEBUG,
+	PHYDM_DIS_DYM_ANT_WEIGHTING,
+	PHYDM_FORECE_PT_STATE,
+	PHYDM_DIS_RXHP_CTR,
+	PHYDM_STA_INFO,
+	PHYDM_PAUSE_FUNC,
+	PHYDM_PER_TONE_EVM
+};
+
+struct phydm_command phy_dm_ary[] = {
+	{"-h", PHYDM_HELP},		/*do not move this element to other position*/
+	{"demo", PHYDM_DEMO},	/*do not move this element to other position*/
+	{"dig", PHYDM_DIG},	
+	{"ra", PHYDM_RA},
+	{"profile", PHYDM_PROFILE},
+	{"antdiv", PHYDM_ANTDIV},
+	{"pathdiv", PHYDM_PATHDIV},
+	{"dbg", PHYDM_DEBUG},
+	{"fw_dbg", PHYDM_FW_DEBUG},
+	{"ability", PHYDM_SUPPORT_ABILITY},
+	{"rf_ability", PHYDM_RF_SUPPORTABILITY},
+	{"rf_profile", PHYDM_RF_PROFILE},
+	{"iqk_info", PHYDM_RF_IQK_INFO},
+	{"iqk", PHYDM_IQK},
+	{"iqk_dbg", PHYDM_IQK_DEBUG},
+	{"get_txagc", PHYDM_GET_TXAGC},
+	{"set_txagc", PHYDM_SET_TXAGC},
+	{"smtant", PHYDM_SMART_ANT},
+	{"api", PHYDM_API},
+	{"trxpath", PHYDM_TRX_PATH},
+	{"lamode", PHYDM_LA_MODE},
+	{"dumpreg", PHYDM_DUMP_REG},
+	{"auto_dbg", PHYDM_AUTO_DBG},
+	{"bigjump", PHYDM_BIG_JUMP},
+	{"rxrate", PHYDM_SHOW_RXRATE},
+	{"nbi", PHYDM_NBI_EN},
+	{"csi_mask", PHYDM_CSI_MASK_EN},
+	{"dfs", PHYDM_DFS_DEBUG},
+	{"nhm", PHYDM_NHM},
+	{"clm", PHYDM_CLM},
+	{"fahm", PHYDM_FAHM},
+	{"env_mntr", PHYDM_ENV_MNTR},	
+	{"bbinfo", PHYDM_BB_INFO},
+	{"txbf", PHYDM_TXBF},
+	{"h2c", PHYDM_H2C},
+	{"ant_switch", PHYDM_ANT_SWITCH},
+	{"drp", PHYDM_DYNAMIC_RA_PATH},
+	{"soml", PHYDM_ADAPTIVE_SOML},
+	{"psd", PHYDM_PSD},
+	{"dbgport", PHYDM_DEBUG_PORT},
+	{"dis_htstf", PHYDM_DIS_HTSTF_CONTROL},
+	{"tune_para", PHYDM_TUNE_PARAMETER},
+	{"adapt_debug", PHYDM_ADAPTIVITY_DEBUG},
+	{"dis_dym_ant_wgt", PHYDM_DIS_DYM_ANT_WEIGHTING},
+	{"force_pt_state", PHYDM_FORECE_PT_STATE},
+	{"dis_drxhp", PHYDM_DIS_RXHP_CTR},
+	{"sta_info", PHYDM_STA_INFO},
+	{"pause", PHYDM_PAUSE_FUNC},
+	{"evm", PHYDM_PER_TONE_EVM}
+};
+
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+
+void
+phydm_cmd_parser(
+	struct dm_struct	*dm,
+	char		input[][MAX_ARGV],
+	u32	input_num,
+	u8	flag,
+	char		*output,
+	u32	out_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	u32 used = 0;
+	u8 id = 0;
+	int var1[10] = {0};
+	int i, input_idx = 0, phydm_ary_size = sizeof(phy_dm_ary) / sizeof(struct phydm_command);
+	char help[] = "-h";
+
+	if (flag == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "GET, nothing to print\n");
+		return;
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n");
+
+	/* Parsing Cmd ID */
+	if (input_num) {
+		for (i = 0; i < phydm_ary_size; i++) {
+			if (strcmp(phy_dm_ary[i].name, input[0]) == 0) {
+				id = phy_dm_ary[i].id;
+				break;
+			}
+		}
+		if (i == phydm_ary_size) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "SET, command not found!\n");
+			return;
+		}
+	}
+
+	switch (id) {
+	case PHYDM_HELP:
+	{
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BB cmd ==>\n");
+		for (i = 0; i < phydm_ary_size - 2; i++) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %-5d: %s\n", i, phy_dm_ary[i + 2].name);
+			/**/
+		}
+	}
+	break;
+
+	case PHYDM_DEMO: { /*echo demo 10 0x3a z abcde >cmd*/
+		u32 directory = 0;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+		char char_temp;
+#else
+		u32 char_temp = ' ';
+#endif
+
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &directory);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Decimal value = %d\n", directory);
+		PHYDM_SSCANF(input[2], DCMD_HEX, &directory);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Hex value = 0x%x\n", directory);
+		PHYDM_SSCANF(input[3], DCMD_CHAR, &char_temp);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Char = %c\n", char_temp);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "String = %s\n", input[4]);
+	}
+	break;
+	
+	case PHYDM_DIG:
+
+		phydm_dig_debug(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_RA:
+		phydm_ra_debug(dm, &input[0], &used, output, &out_len);
+		break;
+
+	case PHYDM_ANTDIV:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+
+				/*PDM_SNPF((output+used, out_len-used, "new SET, PATHDIV_var[%d]= (( %d ))\n", i, var1[i]));*/
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			/*PDM_SNPF((output+used, out_len-used, "odm_PATHDIV_debug\n"));*/
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+			phydm_antdiv_debug(dm, (u32 *)var1, &used, output, &out_len);
+#endif
+		}
+
+		break;
+
+	case PHYDM_PATHDIV:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+
+				/*PDM_SNPF((output+used, out_len-used, "new SET, PATHDIV_var[%d]= (( %d ))\n", i, var1[i]));*/
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			/*PDM_SNPF((output+used, out_len-used, "odm_PATHDIV_debug\n"));*/
+#if (defined(CONFIG_PATH_DIVERSITY))
+			odm_pathdiv_debug(dm, (u32 *)var1, &used, output, &out_len);
+#endif
+		}
+
+		break;
+
+	case PHYDM_DEBUG:
+
+		phydm_debug_trace(dm, &input[0], &used, output, &out_len);
+
+		break;
+
+	case PHYDM_FW_DEBUG:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_fw_debug_trace(dm, (u32 *)var1, &used, output, &out_len);
+
+		break;
+
+	case PHYDM_SUPPORT_ABILITY:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+
+				/*PDM_SNPF((output+used, out_len-used, "new SET, support ablity_var[%d]= (( %d ))\n", i, var1[i]));*/
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			/*PDM_SNPF((output+used, out_len-used, "support ablity\n"));*/
+			phydm_support_ability_debug(dm, (u32 *)var1, &used, output, &out_len);
+		}
+
+		break;
+
+	case PHYDM_RF_SUPPORTABILITY:
+		halrf_support_ability_debug(dm, &input[0], &used, output, &out_len);
+		break;
+
+	case PHYDM_RF_PROFILE:
+		halrf_basic_profile(dm, &used, output, &out_len);
+		break;
+		
+	case PHYDM_RF_IQK_INFO:
+		#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+			halrf_iqk_info_dump(dm, &used, output, &out_len);
+		#endif
+		break;
+
+	case PHYDM_IQK:
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "TRX IQK Trigger\n");
+		halrf_iqk_trigger(dm, false);
+
+		#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+			halrf_iqk_info_dump(dm, &used, output, &out_len);
+		#endif
+		
+		break;
+		
+	case PHYDM_IQK_DEBUG:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+			if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+				halrf_iqk_debug(dm, (u32 *)var1, &used, output, &out_len);
+			#endif
+		}
+		break;
+		
+	case PHYDM_SMART_ANT:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		phydm_hl_smart_ant_debug_type2(dm, &input[0], &used, output, &out_len, input_num);
+		#elif (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
+		phydm_hl_smart_ant_debug(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+	
+	#endif
+
+	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+		phydm_cumitek_smt_ant_debug(dm, &input[0], &used, output, &out_len, input_num);
+	#endif
+		}
+
+		break;
+
+	case PHYDM_API:
+		phydm_api_adjust(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_PROFILE:
+		phydm_basic_profile(dm, &used, output, &out_len);
+		break;
+
+	case PHYDM_GET_TXAGC:
+		phydm_get_txagc(dm, &used, output, &out_len);
+		break;
+
+	case PHYDM_SET_TXAGC:
+	{
+		boolean		is_enable_dbg_mode;
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if ((strcmp(input[1], help) == 0)) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "{En} {pathA~D(0~3)} {rate_idx(Hex), All_rate:0xff} {txagc_idx (Hex)}\n");
+			/**/
+
+		} else {
+			is_enable_dbg_mode = (boolean)var1[0];
+			if (is_enable_dbg_mode) {
+				dm->is_disable_phy_api = false;
+				phydm_set_txagc(dm, (u32 *)var1, &used, output, &out_len);
+				dm->is_disable_phy_api = true;
+			} else {
+				dm->is_disable_phy_api = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Disable API debug mode\n");
+			}
+		}
+	}
+	break;
+
+	case PHYDM_TRX_PATH:
+
+		for (i = 0; i < 4; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
+			u8		tx_path, rx_path;
+			boolean		is_enable_dbg_mode, is_tx2_path;
+
+			is_enable_dbg_mode = (boolean)var1[0];
+			tx_path = (u8) var1[1];
+			rx_path = (u8) var1[2];
+			is_tx2_path = (boolean) var1[3];
+
+			if (is_enable_dbg_mode) {
+				dm->is_disable_phy_api = false;
+				phydm_api_trx_mode(dm, (enum bb_path) tx_path, (enum bb_path) rx_path, is_tx2_path);
+				dm->is_disable_phy_api = true;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "tx_path = 0x%x, rx_path = 0x%x, is_tx2_path = %d\n",
+					       tx_path, rx_path, is_tx2_path);
+			} else {
+				dm->is_disable_phy_api = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Disable API debug mode\n");
+			}
+		} else
+#endif
+			phydm_config_trx_path(dm, (u32 *)var1, &used, output, &out_len);
+
+		break;
+
+	case PHYDM_LA_MODE:
+
+		#if (PHYDM_LA_MODE_SUPPORT == 1)
+		phydm_lamode_trigger_setting(dm, &input[0], &used, output, &out_len, input_num);
+		#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "This IC doesn't support LA mode\n");
+		#endif
+
+		break;
+
+	case PHYDM_DUMP_REG:
+	{
+		u8	type = 0;
+
+		if (input[1]) {
+			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+			type = (u8)var1[0];
+		}
+
+		if (type == 0)
+			phydm_dump_bb_reg(dm, &used, output, &out_len);
+		else if (type == 1)
+			phydm_dump_all_reg(dm, &used, output, &out_len);
+	}
+	break;
+
+	case PHYDM_BIG_JUMP:
+	{
+#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			if (input[1]) {
+				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+				phydm_enable_big_jump(dm, (boolean)(var1[0]));
+			} else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "unknown command!\n");
+		} else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "The command is only for 8822B!\n");
+#endif
+		break;
+	}
+
+	case PHYDM_AUTO_DBG:
+		#ifdef PHYDM_AUTO_DEGBUG
+		phydm_auto_dbg_console(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	case PHYDM_SHOW_RXRATE:
+	{
+#if (RTL8822B_SUPPORT == 1 | RTL8821C_SUPPORT == 1 | RTL8814B_SUPPORT == 1)
+		u8	rate_idx;
+		if ((dm->support_ic_type & PHYDM_IC_SUPPORT_MU_BFEE) == 0)
+			break;
+
+		if (input[1])
+			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 1)
+			phydm_show_rx_rate(dm, &used, output, &out_len);
+		else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "Reset Rx rate counter\n");
+
+			for (rate_idx = 0; rate_idx < VHT_RATE_NUM; rate_idx++) {
+				dm->phy_dbg_info.num_qry_vht_pkt[rate_idx] = 0;
+				dm->phy_dbg_info.num_qry_mu_vht_pkt[rate_idx] = 0;
+			}
+		}
+#endif
+		break;
+	}
+
+	case PHYDM_NBI_EN:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			phydm_api_debug(dm, PHYDM_API_NBI, (u32 *)var1, &used, output, &out_len);
+			/**/
+		}
+
+
+		break;
+
+	case PHYDM_CSI_MASK_EN:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			phydm_api_debug(dm, PHYDM_API_CSI_MASK, (u32 *)var1, &used, output, &out_len);
+			/**/
+		}
+
+
+		break;
+
+	case PHYDM_DFS_DEBUG:
+	{
+#ifdef CONFIG_PHYDM_DFS_MASTER
+		u32 var[4] = {0};
+
+		for (i = 0; i < 4; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_dfs_debug(dm, var, &used, output, &out_len);
+#endif
+		break;
+	}
+
+	case PHYDM_NHM:
+		#ifdef NHM_SUPPORT
+		phydm_nhm_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	case PHYDM_CLM:
+		#ifdef CLM_SUPPORT
+		phydm_clm_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	#ifdef FAHM_SUPPORT
+	case PHYDM_FAHM:
+		phydm_fahm_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+	#endif
+
+	case PHYDM_ENV_MNTR:
+		phydm_env_mntr_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+	
+
+	case PHYDM_BB_INFO:
+	{
+		s32 value32 = 0;
+
+		phydm_bb_debug_info(dm, &used, output, &out_len);
+
+		if (dm->support_ic_type & ODM_RTL8822B && input[1]) {
+			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+			odm_set_bb_reg(dm, 0x1988, 0x003fff00, var1[0]);
+			value32 = odm_get_bb_reg(dm, 0xf84, MASKDWORD);
+			value32 = (value32 & 0xff000000) >> 24;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n %-35s = condition num = %d, subcarriers = %d\n",
+				       "Over condition num subcarrier",
+				       var1[0], value32);
+			odm_set_bb_reg(dm, 0x1988, BIT(22), 0x0);	/*disable report condition number*/
+		}
+	}
+	break;
+
+	case PHYDM_TXBF:
+	{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+		struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+		if (var1[0] == 0) {
+			beamforming_info->apply_v_matrix = false;
+			beamforming_info->snding3ss = true;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n dont apply V matrix and 3SS 789 snding\n");
+		} else if (var1[0] == 1) {
+			beamforming_info->apply_v_matrix = true;
+			beamforming_info->snding3ss = true;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n apply V matrix and 3SS 789 snding\n");
+		} else if (var1[0] == 2) {
+			beamforming_info->apply_v_matrix = true;
+			beamforming_info->snding3ss = false;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n default txbf setting\n");
+		} else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "\r\n unknown cmd!!\n");
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n no TxBF !!\n");
+#endif
+#endif
+	}
+		break;
+
+	case PHYDM_H2C:
+
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_h2C_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+
+		break;
+
+	case PHYDM_ANT_SWITCH:
+
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+#if (RTL8821A_SUPPORT == 1)
+			phydm_set_ext_switch(dm, (u32 *)var1, &used, output, &out_len);
+#else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Not Support IC");
+#endif
+		}
+
+
+		break;
+
+	case PHYDM_DYNAMIC_RA_PATH:
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_drp_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Not Support IC");
+#endif
+
+		break;
+
+	case PHYDM_ADAPTIVE_SOML:
+
+#ifdef CONFIG_ADAPTIVE_SOML
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_soml_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Not Support IC");
+#endif
+
+		break;
+
+	case PHYDM_PSD:
+
+		#ifdef CONFIG_PSD_TOOL
+		phydm_psd_debug(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+
+		break;
+		
+	case PHYDM_DEBUG_PORT:
+		{
+			u32	dbg_port_value;
+
+			PHYDM_SSCANF(input[1], DCMD_HEX, &var1[0]);
+
+			dm->debug_components |= ODM_COMP_API;
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, var1[0])) {/*set debug port to 0x0*/
+
+				dbg_port_value = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+				
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dbg Port[0x%x] = ((0x%x))\n",
+					       var1[0], dbg_port_value);
+			}
+			dm->debug_components &= (~ODM_COMP_API);
+		}
+		break;
+		
+	case PHYDM_DIS_HTSTF_CONTROL:
+		{
+			if (input[1])
+				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+			if (var1[0] == 1) {
+				
+				/* setting being false is for debug */
+				dm->bhtstfdisabled = true;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic HT-STF Gain Control is Disable\n");
+			}
+			else {
+				
+				/* default setting should be true, always be dynamic control*/
+				dm->bhtstfdisabled = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic HT-STF Gain Control is Enable\n");
+			}
+		}
+		break;
+		
+	case PHYDM_TUNE_PARAMETER:
+		phydm_parameter_adjust(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_ADAPTIVITY_DEBUG:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_adaptivity_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+		break;
+
+	case PHYDM_DIS_DYM_ANT_WEIGHTING:	
+		#ifdef DYN_ANT_WEIGHTING_SUPPORT
+		phydm_dyn_ant_weight_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	case PHYDM_FORECE_PT_STATE:
+		{
+		#ifdef PHYDM_POWER_TRAINING_SUPPORT	
+			phydm_pow_train_debug(dm, &input[0], &used, output, &out_len, input_num);
+		#else
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Pow training: Not Support\n");
+		#endif
+		
+		break;
+		}
+
+	case PHYDM_DIS_RXHP_CTR:
+		{
+			if (input[1])
+				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+			if (var1[0] == 1) {
+				/* the setting being on is at debug mode to disconnect RxHP seeting with SoML on/odd */
+				dm->disrxhpsoml = true;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic RxHP Control with SoML on/off is Disable\n");
+			}
+			else if (var1[0] == 0) {
+				/* default setting, RxHP setting will follow SoML on/off setting */
+				dm->disrxhpsoml = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic RxHP Control with SoML on/off is Enable\n");
+			}
+			else {
+				dm->disrxhpsoml = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Default Setting, Dynamic RxHP Control with SoML on/off is Enable\n");
+			}
+		}
+		break;
+		
+	case PHYDM_STA_INFO:
+		phydm_show_sta_info(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_PAUSE_FUNC:
+		phydm_pause_func_console(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_PER_TONE_EVM:
+		phydm_per_tone_evm(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	default:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "SET, unknown command!\n");
+		break;
+
+	}
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+#ifdef __ECOS
+char *strsep(char **s, const char *ct)
+{
+	char *sbegin = *s;
+	char *end;
+
+	if (sbegin == NULL)
+		return NULL;
+
+	end = strpbrk(sbegin, ct);
+	if (end)
+		*end++ = '\0';
+	*s = end;
+	return sbegin;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+s32
+phydm_cmd(
+	struct dm_struct	*dm,
+	char		*input,
+	u32	in_len,
+	u8	flag,
+	char	*output,
+	u32	out_len
+)
+{
+	char *token;
+	u32	argc = 0;
+	char		argv[MAX_ARGC][MAX_ARGV];
+
+	do {
+		token = strsep(&input, ", ");
+		if (token) {
+			strcpy(argv[argc], token);
+			argc++;
+		} else
+			break;
+	} while (argc < MAX_ARGC);
+
+	if (argc == 1)
+		argv[0][strlen(argv[0]) - 1] = '\0';
+
+	phydm_cmd_parser(dm, argv, argc, flag, output, out_len);
+
+	return 0;
+}
+#endif
+
+
+void
+phydm_fw_trace_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	/*u8	debug_trace_11byte[60];*/
+	u8		freg_num, c2h_seq, buf_0 = 0;
+
+
+	if (!(dm->support_ic_type & PHYDM_IC_3081_SERIES))
+		return;
+
+	if ((cmd_len > 12) || (cmd_len == 0)) {
+		pr_debug("[Warning] Error C2H cmd_len=%d\n", cmd_len);
+		return;
+	}
+
+	buf_0 = cmd_buf[0];
+	freg_num = (buf_0 & 0xf);
+	c2h_seq = (buf_0 & 0xf0) >> 4;
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] freg_num = (( %d )), c2h_seq = (( %d ))\n", freg_num,c2h_seq );*/
+
+	/*strncpy(debug_trace_11byte,&cmd_buf[1],(cmd_len-1));*/
+	/*debug_trace_11byte[cmd_len-1] = '\0';*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] %s\n", debug_trace_11byte);*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] cmd_len = (( %d ))\n", cmd_len);*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] c2h_cmd_start  = (( %d ))\n", dm->c2h_cmd_start);*/
+
+
+
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"pre_seq = (( %d )), current_seq = (( %d ))\n", dm->pre_c2h_seq, c2h_seq);*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"fw_buff_is_enpty = (( %d ))\n", dm->fw_buff_is_enpty);*/
+
+	if ((c2h_seq != dm->pre_c2h_seq)  &&  dm->fw_buff_is_enpty == false) {
+		dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW Dbg Queue Overflow] %s\n", dm->fw_debug_trace);
+		dm->c2h_cmd_start = 0;
+	}
+
+	if ((cmd_len - 1) > (60 - dm->c2h_cmd_start)) {
+		dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW Dbg Queue error: wrong C2H length] %s\n", dm->fw_debug_trace);
+		dm->c2h_cmd_start = 0;
+		return;
+	}
+
+	strncpy((char *)&dm->fw_debug_trace[dm->c2h_cmd_start],
+		(char *)&cmd_buf[1], (cmd_len - 1));
+	dm->c2h_cmd_start += (cmd_len - 1);
+	dm->fw_buff_is_enpty = false;
+
+	if (freg_num == 0 || dm->c2h_cmd_start >= 60) {
+		if (dm->c2h_cmd_start < 60)
+			dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		else
+			dm->fw_debug_trace[59] = '\0';
+
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s\n", dm->fw_debug_trace);
+		/*dbg_print("[FW DBG Msg] %s\n", dm->fw_debug_trace);*/
+		dm->c2h_cmd_start = 0;
+		dm->fw_buff_is_enpty = true;
+	}
+
+	dm->pre_c2h_seq = c2h_seq;
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+void
+phydm_fw_trace_handler_code(
+	void	*dm_void,
+	u8	*buffer,
+	u8	cmd_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	function = buffer[0];
+	u8	dbg_num = buffer[1];
+	u16	content_0 = (((u16)buffer[3]) << 8) | ((u16)buffer[2]);
+	u16	content_1 = (((u16)buffer[5]) << 8) | ((u16)buffer[4]);
+	u16	content_2 = (((u16)buffer[7]) << 8) | ((u16)buffer[6]);
+	u16	content_3 = (((u16)buffer[9]) << 8) | ((u16)buffer[8]);
+	u16	content_4 = (((u16)buffer[11]) << 8) | ((u16)buffer[10]);
+
+	if (cmd_len > 12)
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW Msg] Invalid cmd length (( %d )) >12\n", cmd_len);
+
+	/* PHYDM_DBG(dm, DBG_FW_TRACE,"[FW Msg] Func=((%d)),  num=((%d)), ct_0=((%d)), ct_1=((%d)), ct_2=((%d)), ct_3=((%d)), ct_4=((%d))\n", */
+	/*	function, dbg_num, content_0, content_1, content_2, content_3, content_4); */
+
+	/*--------------------------------------------*/
+#ifdef CONFIG_RA_FW_DBG_CODE
+	if (function == RATE_DECISION) {
+		if (dbg_num == 0) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RA_CNT=((%d))  Max_device=((%d))--------------------------->\n", content_1, content_2);
+			else if (content_0 == 2)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Check RA macid= ((%d)), MediaStatus=((%d)), Dis_RA=((%d)),  try_bit=((0x%x))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Check RA  total=((%d)),  drop=((0x%x)), TXRPT_TRY_bit=((%x)), bNoisy=((%x))\n", content_1, content_2, content_3, content_4);
+		} else if (dbg_num == 1) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RTY[0,1,2,3]=[ %d , %d , %d , %d ]\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 2) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RTY[4]=[ %d ], drop=(( %d )), total=(( %d )), current_rate=((0x %x ))", content_1, content_2, content_3, content_4);
+				phydm_print_rate(dm, (u8)content_4, DBG_FW_TRACE);
+			} else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] penality_idx=(( %d ))\n", content_1);
+			else if (content_0 == 4)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RSSI=(( %d )), ra_stage = (( %d ))\n", content_1, content_2);
+		} else if (dbg_num == 3) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( DOWN ))  total=((%d)),  total>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 2)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( UP ))  total_acc=((%d)),  total_acc>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( UP )) ((rate Down Hold))  RA_CNT=((%d))\n", content_1);
+			else if (content_0 == 4)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( UP )) ((tota_accl<5 skip))  RA_CNT=((%d))\n", content_1);
+			else if (content_0 == 8)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( Reset Tx Rpt )) RA_CNT=((%d))\n", content_1);
+		} else if (dbg_num == 4) {
+			if (content_0 == 3) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RER_CNT   PCR_ori =(( %d )),  ratio_ori =(( %d )), pcr_updown_bitmap =(( 0x%x )), pcr_var_diff =(( %d ))\n", content_1, content_2, content_3, content_4);
+				/**/
+			} else if (content_0 == 4) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] pcr_shift_value =(( %s%d )), rate_down_threshold =(( %d )), rate_up_threshold =(( %d ))\n", ((content_1) ? "+" : "-"), content_2, content_3, content_4);
+				/**/
+			} else if (content_0 == 5) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] pcr_mean =(( %d )), PCR_VAR =(( %d )), offset =(( %d )), decision_offset_p =(( %d ))\n", content_1, content_2, content_3, content_4);
+				/**/
+			}
+		} else if (dbg_num == 5) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] (( UP))  Nsc=(( %d )), N_High=(( %d )), RateUp_Waiting=(( %d )), RateUp_Fail=(( %d ))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 2)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((DOWN))  Nsc=(( %d )), N_Low=(( %d ))\n", content_1, content_2);
+			else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((HOLD))  Nsc=((%d)), N_High=((%d)), N_Low=((%d)), Reset_CNT=((%d))\n", content_1, content_2, content_3, content_4);
+		} else if (dbg_num == 0x60) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((AP RPT))  macid=((%d)), BUPDATE[macid]=((%d))\n", content_1, content_2);
+			else if (content_0 == 4)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((AP RPT))  pass=((%d)), rty_num=((%d)), drop=((%d)), total=((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 5)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((AP RPT))  PASS=((%d)), RTY_NUM=((%d)), DROP=((%d)), TOTAL=((%d))\n", content_1, content_2, content_3, content_4);
+		}
+	} else if (function == INIT_RA_TABLE) {
+		if (dbg_num == 3)
+			PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][INIT_RA_INFO] Ra_init, RA_SKIP_CNT = (( %d ))\n", content_0);
+ 	} else if (function == RATE_UP) {
+		if (dbg_num == 2) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateUp]  ((Highest rate->return)), macid=((%d))  Nsc=((%d))\n", content_1, content_2);
+		} else if (dbg_num == 5) {
+			if (content_0 == 0)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateUp]  ((rate UP)), up_rate_tmp=((0x%x)), rate_idx=((0x%x)), SGI_en=((%d)),  SGI=((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateUp]  ((rate UP)), rate_1=((0x%x)), rate_2=((0x%x)), BW=((%d)), Try_Bit=((%d))\n", content_1, content_2, content_3, content_4);
+		}
+	} else if (function == RATE_DOWN) {
+		if (dbg_num == 5) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateDownStep]  ((rate Down)), macid=((%d)), rate1=((0x%x)),  rate2=((0x%x)), BW=((%d))\n", content_1, content_2, content_3, content_4);
+		}
+	} else if (function == TRY_DONE) {
+		if (dbg_num == 1) {
+			if (content_0 == 1) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][Try Done]  ((try succsess )) macid=((%d)), Try_Done_cnt=((%d))\n", content_1, content_2);
+				/**/
+			}
+		} else if (dbg_num == 2) {
+			if (content_0 == 1) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][Try Done]  ((try)) macid=((%d)), Try_Done_cnt=((%d)),  rate_2=((%d)),  try_succes=((%d))\n", content_1, content_2, content_3, content_4);
+				/**/
+			}
+		}
+	} else if (function == RA_H2C) {
+		if (dbg_num == 1) {
+			if (content_0 == 0) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][H2C=0x49]  fw_trace_en=((%d)), mode =((%d)),  macid=((%d))\n", content_1, content_2, content_3);
+				/**/
+			}
+		}
+	} else if (function == F_RATE_AP_RPT) {
+		if (dbg_num == 1) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  ((1)), SPE_STATIS=((0x%x))---------->\n", content_3);
+		} else if (dbg_num == 2) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  RTY_all=((%d))\n", content_1);
+		} else if (dbg_num == 3) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID1[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2);
+		} else if (dbg_num == 4) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID2[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2);
+		} else if (dbg_num == 5) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID1[%d], PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2);
+		} else if (dbg_num == 6) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID2[%d],, PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2);
+		}
+	} else if (function == DBC_FW_CLM) {
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][CLM][%d, %d] = {%d, %d, %d, %d}\n", dbg_num, content_0, content_1, content_2, content_3, content_4);
+	} else {
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n", function, dbg_num, content_0, content_1, content_2, content_3, content_4);
+	}
+#else
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n", function, dbg_num, content_0, content_1, content_2, content_3, content_4);
+#endif
+	/*--------------------------------------------*/
+
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+void
+phydm_fw_trace_handler_8051(
+	void	*dm_void,
+	u8	*buffer,
+	u8	cmd_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if 0
+	if (cmd_len >= 3)
+		cmd_buf[cmd_len - 1] = '\0';
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s\n", &(cmd_buf[3]));
+#else
+
+	int i = 0;
+	u8	extend_c2h_sub_id = 0, extend_c2h_dbg_len = 0, extend_c2h_dbg_seq = 0;
+	u8	fw_debug_trace[128];
+	u8	*extend_c2h_dbg_content = 0;
+
+	if (cmd_len > 127)
+		return;
+
+	extend_c2h_sub_id = buffer[0];
+	extend_c2h_dbg_len = buffer[1];
+	extend_c2h_dbg_content = buffer + 2; /*DbgSeq+DbgContent  for show HEX*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISP(FC2H, C2H_Summary, ("[Extend C2H packet], Extend_c2hSubId=0x%x, extend_c2h_dbg_len=%d\n",
+				    extend_c2h_sub_id, extend_c2h_dbg_len));
+
+	RT_DISP_DATA(FC2H, C2H_Summary, "[Extend C2H packet], Content Hex:", extend_c2h_dbg_content, cmd_len - 2);
+#endif
+
+go_backfor_aggre_dbg_pkt:
+	i = 0;
+	extend_c2h_dbg_seq = buffer[2];
+	extend_c2h_dbg_content = buffer + 3;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISP(FC2H, C2H_Summary, ("[RTKFW, SEQ= %d] :", extend_c2h_dbg_seq));
+#endif
+
+	for (; ; i++) {
+		fw_debug_trace[i] = extend_c2h_dbg_content[i];
+		if (extend_c2h_dbg_content[i + 1] == '\0') {
+			fw_debug_trace[i + 1] = '\0';
+			PHYDM_DBG(dm, DBG_FW_TRACE,
+				  "[FW DBG Msg] %s", &fw_debug_trace[0]);
+			break;
+		} else if (extend_c2h_dbg_content[i] == '\n') {
+			fw_debug_trace[i + 1] = '\0';
+			PHYDM_DBG(dm, DBG_FW_TRACE,
+				  "[FW DBG Msg] %s", &fw_debug_trace[0]);
+			buffer = extend_c2h_dbg_content + i + 3;
+			goto go_backfor_aggre_dbg_pkt;
+		}
+	}
+
+
+#endif
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_debug.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_debug.h
new file mode 100644
index 000000000000..67e190e93967
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_debug.h
@@ -0,0 +1,392 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__ODM_DBG_H__
+#define __ODM_DBG_H__
+
+/*#define DEBUG_VERSION	"1.1"*/  /*2015.07.29 YuChen*/
+/*#define DEBUG_VERSION	"1.2"*/  /*2015.08.28 Dino*/
+/*#define DEBUG_VERSION	"1.3"*/  /*2016.04.28 YuChen*/
+#define DEBUG_VERSION	"1.4"  /*2017.03.13 Dino*/
+
+/* -----------------------------------------------------------------------------
+ *	Define the debug levels
+ *
+ *	1.	DBG_TRACE and DBG_LOUD are used for normal cases.
+ *	So that, they can help SW engineer to develope 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
+
+/*FW DBG MSG*/
+#define	RATE_DECISION	1
+#define	INIT_RA_TABLE	2
+#define	RATE_UP		4
+#define	RATE_DOWN		8
+#define	TRY_DONE		16
+#define	RA_H2C			32
+#define	F_RATE_AP_RPT	64
+#define	DBC_FW_CLM	9		
+
+/* -----------------------------------------------------------------------------
+ * Define the tracing components
+ *
+ * -----------------------------------------------------------------------------
+ *BB FW Functions*/
+#define	PHYDM_FW_COMP_RA			BIT(0)
+#define	PHYDM_FW_COMP_MU			BIT(1)
+#define	PHYDM_FW_COMP_PATH_DIV		BIT(2)
+#define	PHYDM_FW_COMP_PT				BIT(3)
+
+/*------------------------Export Marco Definition---------------------------*/
+
+#define	config_phydm_read_txagc_check(data)		(data != INVALID_TXAGC_DATA)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	extern	VOID DCMD_Printf(const char *pMsg);
+
+	#define	pr_debug				DbgPrint
+	#define	dcmd_printf				DCMD_Printf
+	#define	dcmd_scanf				DCMD_Scanf
+	#define	RT_PRINTK				pr_debug
+	#define	PRINT_MAX_SIZE		512
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#undef pr_debug
+	#define pr_debug	printk
+	#define RT_PRINTK(fmt, args...)	pr_debug(fmt, ## args)
+	#define	RT_DISP(dbgtype, dbgflag, printstr)
+	#define RT_TRACE(adapter, comp, drv_level, fmt, args...)	\
+		RTW_INFO(fmt, ## args)
+#else
+	#define pr_debug	panic_printk
+	/*#define RT_PRINTK(fmt, args...)	pr_debug("%s(): " fmt, __FUNCTION__, ## args);*/
+	#define RT_PRINTK(fmt, args...)	pr_debug(fmt, ## args)
+#endif
+
+#ifndef ASSERT
+	#define ASSERT(expr)
+#endif
+
+#if DBG
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+#define PHYDM_DBG(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & (dm->debug_components)) {          \
+			pr_debug("[PHYDM] ");			\
+			RT_PRINTK(fmt, ## args);				\
+		}						\
+	} while (0)
+
+#define PHYDM_DBG_F(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			RT_PRINTK(fmt, ## args);				\
+		}						\
+	} while (0)
+
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)		\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			int __i;				\
+			u8 *__ptr = (u8 *)addr;			\
+			pr_debug("[PHYDM] ");			\
+			pr_debug(title_str);			\
+			pr_debug(" ");				\
+			for (__i = 0; __i < 6; __i++)		\
+				pr_debug("%02X%s", __ptr[__i], (__i == 5) ? "" : "-");\
+			pr_debug("\n");				\
+		}						\
+	} while (0)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+static __inline void PHYDM_DBG(PDM_ODM_T dm, int comp, char *fmt, ...)
+{
+
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->debug_components) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		DbgPrint("Failed (%d) to print message to buffer\n", rt_status);
+		return;
+	}
+
+	DbgPrint("[PHYDM] %s", buf);
+}
+
+static __inline void PHYDM_DBG_F(PDM_ODM_T dm, int comp, char *fmt, ...)
+{
+
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->debug_components) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		/*DbgPrint("DM Print Fail\n");*/
+		return;
+	}
+
+	DbgPrint("%s", buf);
+}
+
+#define PHYDM_PRINT_ADDR(p_dm, comp, title_str, ptr)							 do {\
+		if ((comp) & p_dm->debug_components) { \
+			\
+			int __i;																\
+			u8 *__ptr = (u8 *)ptr;											\
+			pr_debug("[PHYDM] ");													\
+			pr_debug(title_str);													\
+			pr_debug(" ");														\
+			for (__i = 0; __i < 6; __i++)												\
+				pr_debug("%02X%s", __ptr[__i], (__i == 5) ? "" : "-");						\
+			pr_debug("\n");														\
+		}	\
+	} while (0)
+
+#else
+#define PHYDM_DBG(dm, comp, fmt, args...)                                      \
+	do {								\
+		if ((comp) & (dm->debug_components)) {                         \
+			RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+				 DBG_DMESG, "[PHYDM] " fmt, ##args);           \
+		}												\
+	} while (0)
+
+#define PHYDM_DBG_F(dm, comp, fmt, args...)                                    \
+	do {								\
+		if ((comp) & dm->debug_components) {                           \
+			RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+				 DBG_DMESG, fmt, ##args);                      \
+		}	\
+	} while (0)
+
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)                            \
+	do {								\
+		if ((comp) & dm->debug_components) {                           \
+			RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+				 DBG_DMESG, "[PHYDM] " title_str "%pM\n",      \
+				 addr);                                        \
+		}							\
+	} while (0)
+#endif
+
+#define ODM_RT_TRACE(dm, comp, level, fmt)
+
+#else
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+static	__inline	void	PHYDM_DBG(struct dm_struct	*dm, int comp, char *fmt, ...)
+{}
+static __inline void PHYDM_DBG_F(struct dm_struct	*dm, int comp, char *fmt, ...)
+{}
+#else
+#define PHYDM_DBG(dm, comp, fmt)
+#define PHYDM_DBG_F(dm, comp, fmt)
+#endif
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, ptr)
+#define ODM_RT_TRACE(dm, comp, level, fmt)
+#endif
+
+#define	BB_DBGPORT_PRIORITY_3	3	/*Debug function (the highest priority)*/
+#define	BB_DBGPORT_PRIORITY_2	2	/*Check hang function & Strong function*/
+#define	BB_DBGPORT_PRIORITY_1	1	/*Watch dog function*/
+#define	BB_DBGPORT_RELEASE		0	/*Init value (the lowest priority)*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#define	PHYDM_DBGPRINT		0
+#define	PHYDM_SSCANF(x, y, z)	dcmd_scanf(x, y, z)
+#define	PHYDM_VAST_INFO_SNPRINTF	PDM_SNPF
+#if (PHYDM_DBGPRINT == 1)
+#define	PDM_SNPF(msg)	\
+	do {\
+		rsprintf msg;\
+		pr_debug("%s", output);\
+	} while (0)
+#else
+
+static __inline void PDM_SNPF(u32	out_len, u32 used, char * buff, int len, char *fmt, ...)
+{
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		/*DbgPrint("DM Print Fail\n");*/
+		return;
+	}
+
+	DCMD_Printf(buf);
+}
+
+#endif	/*#if (PHYDM_DBGPRINT == 1)*/
+#else	/*(DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))*/
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE) || defined(__OSK__)
+	#define	PHYDM_DBGPRINT		0
+	#else
+	#define	PHYDM_DBGPRINT		1
+	#endif
+#define	MAX_ARGC				20
+#define	MAX_ARGV				16
+#define	DCMD_DECIMAL			"%d"
+#define	DCMD_CHAR				"%c"
+#define	DCMD_HEX				"%x"
+
+#define	PHYDM_SSCANF(x, y, z)	sscanf(x, y, z)
+
+#define	PHYDM_VAST_INFO_SNPRINTF(out_len, used, buff, len, fmt, args...)	\
+	do {								\
+		RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+			DBG_DMESG, fmt, ##args);		\
+	} while (0)
+
+#if (PHYDM_DBGPRINT == 1)
+#define	PDM_SNPF(out_len, used, buff, len, fmt, args...)		\
+	do {								\
+		snprintf(buff, len, fmt, ##args);			\
+		pr_debug("%s", output);					\
+	} while (0)
+#else
+#define	PDM_SNPF(out_len, used, buff, len, fmt, args...)		\
+	do {								\
+		if (out_len > used)					\
+			used += snprintf(buff, len, fmt, ##args);	\
+	} while (0)
+#endif
+#endif
+
+void phydm_init_debug_setting(struct dm_struct *dm);
+
+void phydm_bb_dbg_port_header_sel(void *dm_void, u32 header_idx);
+
+u8 phydm_set_bb_dbg_port(void *dm_void, u8 curr_dbg_priority, u32 debug_port);
+
+void phydm_release_bb_dbg_port(void *dm_void);
+
+u32 phydm_get_bb_dbg_port_value(void *dm_void);
+
+void phydm_reset_rx_rate_distribution(struct dm_struct *dm);
+
+void phydm_rx_rate_distribution(void *dm_void);
+
+void phydm_get_avg_phystatus_val(void *dm_void);
+
+void phydm_get_phy_statistic(void *dm_void);
+
+void phydm_basic_dbg_message(void *dm_void);
+
+void phydm_basic_profile(void *dm_void, u32 *_used, char *output,
+			 u32 *_out_len);
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+s32 phydm_cmd(struct dm_struct *dm, char *input, u32 in_len, u8 flag,
+	      char *output, u32 out_len);
+#endif
+void phydm_cmd_parser(struct dm_struct *dm, char input[][16], u32 input_num,
+		      u8 flag, char *output, u32 out_len);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phydm_sbd_check(
+	struct	dm_struct	*dm
+);
+
+void phydm_sbd_callback(
+	struct phydm_timer_list		*timer
+);
+
+void phydm_sbd_workitem_callback(
+	void	*context
+);
+#endif
+
+void phydm_fw_trace_en_h2c(void *dm_void, boolean enable,
+			   u32 fw_debug_component, u32 monitor_mode, u32 macid);
+
+void phydm_fw_trace_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+void phydm_fw_trace_handler_code(void *dm_void, u8 *buffer, u8 cmd_len);
+
+void phydm_fw_trace_handler_8051(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+#endif /* __ODM_DBG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dfs.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dfs.c
new file mode 100644
index 000000000000..2ca538d6db43
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dfs.c
@@ -0,0 +1,689 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*
+============================================================
+ include files
+============================================================
+*/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if defined(CONFIG_PHYDM_DFS_MASTER)
+
+boolean phydm_dfs_is_meteorology_channel(void *dm_void){
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	
+	u8 c_channel = *dm->channel;
+	u8 band_width = *dm->band_width;
+	
+	return ( (band_width == CHANNEL_WIDTH_80 && (c_channel) >= 116 && (c_channel) <= 128) || 
+	  (band_width == CHANNEL_WIDTH_40 && (c_channel) >= 116 && (c_channel) <= 128) ||
+	  (band_width == CHANNEL_WIDTH_20 && (c_channel) >= 120 && (c_channel) <= 128) );
+}
+
+void phydm_radar_detect_reset(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+	odm_set_bb_reg(dm, 0x924, BIT(15), 1);
+}
+
+void phydm_radar_detect_disable(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+	PHYDM_DBG(dm, DBG_DFS, "\n");
+}
+
+static void phydm_radar_detect_with_dbg_parm(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_set_bb_reg(dm, 0x918, MASKDWORD, dm->radar_detect_reg_918);
+	odm_set_bb_reg(dm, 0x91c, MASKDWORD, dm->radar_detect_reg_91c);
+	odm_set_bb_reg(dm, 0x920, MASKDWORD, dm->radar_detect_reg_920);
+	odm_set_bb_reg(dm, 0x924, MASKDWORD, dm->radar_detect_reg_924);
+}
+
+/* Init radar detection parameters, called after ch, bw is set */
+void phydm_radar_detect_enable(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	u8 region_domain = dm->dfs_region_domain;
+	u8 c_channel = *dm->channel;
+	u8 band_width = *dm->band_width;
+	u8 enable = 0;
+
+	PHYDM_DBG(dm, DBG_DFS, "test, region_domain = %d\n", region_domain);
+	if (region_domain == PHYDM_DFS_DOMAIN_UNKNOWN) {
+		PHYDM_DBG(dm, DBG_DFS, "PHYDM_DFS_DOMAIN_UNKNOWN\n");
+		goto exit;
+	}
+
+	if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8812 | ODM_RTL8881A)) {
+		odm_set_bb_reg(dm, 0x814, 0x3fffffff, 0x04cc4d10);
+		odm_set_bb_reg(dm, 0x834, MASKBYTE0, 0x06);
+
+		if (dm->radar_detect_dbg_parm_en) {
+			phydm_radar_detect_with_dbg_parm(dm);
+			enable = 1;
+			goto exit;
+		}
+
+		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c17ecdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0fa21a20);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0f69204);
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67234);
+
+			if (c_channel >= 52 && c_channel <= 64) {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16ecdf);
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0f141a20);
+			} else {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16acdf);
+				if (band_width == CHANNEL_WIDTH_20)
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64721a20);
+				else
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68721a20);
+			}
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16acdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67231);
+			if (band_width == CHANNEL_WIDTH_20)
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64741a20);
+			else
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68741a20);
+
+		} else {
+			/* not supported */
+			PHYDM_DBG(dm, DBG_DFS, "Unsupported dfs_region_domain:%d\n", region_domain);
+			goto exit;
+		}
+
+	} else if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
+		odm_set_bb_reg(dm, 0x814, 0x3fffffff, 0x04cc4d10);
+		odm_set_bb_reg(dm, 0x834, MASKBYTE0, 0x06);
+
+		/* 8822B only, when BW = 20M, DFIR output is 40Mhz, but DFS input is 80MMHz, so it need to upgrade to 80MHz */
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+			if (band_width == CHANNEL_WIDTH_20)
+				odm_set_bb_reg(dm, 0x1984, BIT(26), 1);
+			else
+				odm_set_bb_reg(dm, 0x1984, BIT(26), 0);
+		}
+
+		if (dm->radar_detect_dbg_parm_en) {
+			phydm_radar_detect_with_dbg_parm(dm);
+			enable = 1;
+			goto exit;
+		}
+
+		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16acdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0fa21a20);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0f57204);
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67234);
+
+			if (c_channel >= 52 && c_channel <= 64) {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16ecdf);
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0f141a20);
+			} else {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c166cdf);
+				if (band_width == CHANNEL_WIDTH_20)
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64721a20);
+				else
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68721a20);
+			}
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c166cdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67231);
+			if (band_width == CHANNEL_WIDTH_20)
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64741a20);
+			else
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68741a20);
+
+		} else {
+			/* not supported */
+			PHYDM_DBG(dm, DBG_DFS, "Unsupported dfs_region_domain:%d\n", region_domain);
+			goto exit;
+		}
+	} else {
+		/* not supported IC type*/
+		PHYDM_DBG(dm, DBG_DFS, "Unsupported IC type:%d\n", dm->support_ic_type);
+		goto exit;
+	}
+
+	enable = 1;
+
+	dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, 0x91c, 0x000000ff);
+	dfs->pwdb_th = (u8)odm_get_bb_reg(dm, 0x918, 0x00001f00);
+	dfs->peak_th = (u8)odm_get_bb_reg(dm, 0x918, 0x00030000);
+	dfs->short_pulse_cnt_th = (u8)odm_get_bb_reg(dm, 0x920, 0x000f0000);
+	dfs->long_pulse_cnt_th = (u8)odm_get_bb_reg(dm, 0x920, 0x00f00000);
+	dfs->peak_window = (u8)odm_get_bb_reg(dm, 0x920, 0x00000300);
+	dfs->nb2wb_th = (u8)odm_get_bb_reg(dm, 0x920, 0x0000e000);
+
+	phydm_dfs_parameter_init(dm);
+
+exit:
+	if (enable) {
+		phydm_radar_detect_reset(dm);
+		PHYDM_DBG(dm, DBG_DFS, "on cch:%u, bw:%u\n", c_channel, band_width);
+	} else
+		phydm_radar_detect_disable(dm);
+}
+
+void phydm_dfs_parameter_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+
+	u8 i;
+	
+	dfs->fa_mask_th = 30;
+	dfs->det_print = 1;
+	dfs->det_print2 = 0;
+	dfs->st_l2h_min = 0x20;
+	dfs->st_l2h_max = 0x4e;
+	dfs->pwdb_scalar_factor = 12;
+	dfs->pwdb_th = 8;
+	for (i = 0 ; i < 5 ; i++) {
+		dfs->pulse_flag_hist[i] = 0;
+		dfs->radar_det_mask_hist[i] = 0;
+		dfs->fa_inc_hist[i] = 0;
+	}
+
+}
+
+void phydm_dfs_dynamic_setting(
+	void *dm_void
+){
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+
+	u8 peak_th_cur=0, short_pulse_cnt_th_cur=0, long_pulse_cnt_th_cur=0, three_peak_opt_cur=0, three_peak_th2_cur=0;
+	u8 peak_window_cur=0, nb2wb_th_cur=0;
+	u8 region_domain = dm->dfs_region_domain;
+	u8 c_channel = *dm->channel;
+	
+	if (dm->rx_tp <= 2) {
+		dfs->idle_mode = 1;
+		if(dfs->force_TP_mode)
+			dfs->idle_mode = 0;
+	} else{
+		dfs->idle_mode = 0;
+	}
+
+	if ((dfs->idle_mode == 1)) { /*idle (no traffic)*/
+		peak_th_cur = 3;
+		short_pulse_cnt_th_cur = 6;
+		long_pulse_cnt_th_cur = 13;
+		peak_window_cur = 2;
+		nb2wb_th_cur = 6;
+		three_peak_opt_cur = 1;
+		three_peak_th2_cur = 2;
+		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			if ((c_channel >= 52) && (c_channel <= 64)) {
+				short_pulse_cnt_th_cur = 14;
+				long_pulse_cnt_th_cur = 15;
+				nb2wb_th_cur = 3;
+				three_peak_th2_cur = 0;                
+			} else {
+				short_pulse_cnt_th_cur = 6;
+				nb2wb_th_cur = 3;
+				three_peak_th2_cur = 0;
+				long_pulse_cnt_th_cur = 10;
+			}
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			three_peak_th2_cur = 0;
+		} else if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			long_pulse_cnt_th_cur = 15;
+			if (phydm_dfs_is_meteorology_channel(dm)) {/*need to add check cac end condition*/
+				peak_th_cur = 2;
+				nb2wb_th_cur = 3;
+				three_peak_opt_cur = 1;
+				three_peak_th2_cur = 0;	
+				short_pulse_cnt_th_cur = 7;
+			} else {
+				three_peak_opt_cur = 1;
+				three_peak_th2_cur = 0;	
+				short_pulse_cnt_th_cur = 7;
+				nb2wb_th_cur = 3;
+			}
+		} else	/*default: FCC*/
+			three_peak_th2_cur = 0;
+
+	} else { /*in service (with TP)*/
+		peak_th_cur = 2;
+		short_pulse_cnt_th_cur = 6;
+		long_pulse_cnt_th_cur = 9;
+		peak_window_cur = 2;
+		nb2wb_th_cur = 3;
+		three_peak_opt_cur = 1;
+		three_peak_th2_cur = 2;
+		if(region_domain == PHYDM_DFS_DOMAIN_MKK){
+			if ((c_channel >= 52) && (c_channel <= 64)) {
+				long_pulse_cnt_th_cur = 15;
+				short_pulse_cnt_th_cur = 5; /*for high duty cycle*/
+				three_peak_th2_cur = 0;			
+			}
+			else {
+				three_peak_opt_cur = 0;
+				three_peak_th2_cur = 0;
+				long_pulse_cnt_th_cur = 8;
+			}
+		}		
+		else if(region_domain == PHYDM_DFS_DOMAIN_FCC){
+		}
+		else if(region_domain == PHYDM_DFS_DOMAIN_ETSI){
+			long_pulse_cnt_th_cur = 15;
+			short_pulse_cnt_th_cur = 5;
+			three_peak_opt_cur = 0;
+		}
+	}
+
+}
+
+
+boolean
+phydm_radar_detect_dm_check(
+	void *dm_void
+){
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	u8 region_domain = dm->dfs_region_domain, index = 0;
+
+	u16 i = 0, k = 0, fa_count_cur = 0, fa_count_inc = 0, total_fa_in_hist = 0, pre_post_now_acc_fa_in_hist = 0, max_fa_in_hist = 0, vht_crc_ok_cnt_cur = 0;
+	u16 vht_crc_ok_cnt_inc = 0, ht_crc_ok_cnt_cur = 0, ht_crc_ok_cnt_inc = 0, leg_crc_ok_cnt_cur = 0, leg_crc_ok_cnt_inc = 0;
+	u16 total_crc_ok_cnt_inc = 0, short_pulse_cnt_cur = 0, short_pulse_cnt_inc = 0, long_pulse_cnt_cur = 0, long_pulse_cnt_inc = 0, total_pulse_count_inc = 0;
+	u32 regf98_value = 0, reg918_value = 0, reg91c_value = 0, reg920_value = 0, reg924_value = 0;
+	boolean tri_short_pulse = 0, tri_long_pulse = 0, radar_type = 0, fault_flag_det = 0, fault_flag_psd = 0, fa_flag = 0, radar_detected = 0;
+	u8 st_l2h_new = 0, fa_mask_th = 0, sum = 0;
+	u8 c_channel = *dm->channel;
+		
+	/*Get FA count during past 100ms*/
+	fa_count_cur = (u16)odm_get_bb_reg(dm, 0xf48, 0x0000ffff);
+	
+	if (dfs->fa_count_pre == 0)
+		fa_count_inc = 0;
+	else if (fa_count_cur >= dfs->fa_count_pre)
+		fa_count_inc = fa_count_cur - dfs->fa_count_pre;
+	else
+		fa_count_inc = fa_count_cur;
+	dfs->fa_count_pre = fa_count_cur;
+
+	dfs->fa_inc_hist[dfs->mask_idx] = fa_count_inc;
+	
+	for (i=0; i<5; i++) {		
+		total_fa_in_hist = total_fa_in_hist + dfs->fa_inc_hist[i];		
+		if (dfs->fa_inc_hist[i] > max_fa_in_hist)			
+			max_fa_in_hist = dfs->fa_inc_hist[i];	
+	}	
+	if (dfs->mask_idx >= 2)		
+		index = dfs->mask_idx - 2;
+	else		
+		index = 5 + dfs->mask_idx - 2;	
+	if (index == 0)		
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] + dfs->fa_inc_hist[index+1] + dfs->fa_inc_hist[4];	
+	else if (index == 4)		
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] + dfs->fa_inc_hist[0] + dfs->fa_inc_hist[index-1];	
+	else		
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] + dfs->fa_inc_hist[index+1] + dfs->fa_inc_hist[index-1];
+		
+	/*Get VHT CRC32 ok count during past 100ms*/
+	vht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, 0xf0c, 0x00003fff);
+	if (vht_crc_ok_cnt_cur >= dfs->vht_crc_ok_cnt_pre)
+		vht_crc_ok_cnt_inc = vht_crc_ok_cnt_cur - dfs->vht_crc_ok_cnt_pre;
+	else
+		vht_crc_ok_cnt_inc = vht_crc_ok_cnt_cur;
+	dfs->vht_crc_ok_cnt_pre = vht_crc_ok_cnt_cur;
+
+	/*Get HT CRC32 ok count during past 100ms*/
+	ht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, 0xf10, 0x00003fff);
+	if (ht_crc_ok_cnt_cur >= dfs->ht_crc_ok_cnt_pre)
+		ht_crc_ok_cnt_inc = ht_crc_ok_cnt_cur - dfs->ht_crc_ok_cnt_pre;
+	else
+		ht_crc_ok_cnt_inc = ht_crc_ok_cnt_cur;
+	dfs->ht_crc_ok_cnt_pre = ht_crc_ok_cnt_cur;
+
+	/*Get Legacy CRC32 ok count during past 100ms*/
+	leg_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, 0xf14, 0x00003fff);
+	if (leg_crc_ok_cnt_cur >= dfs->leg_crc_ok_cnt_pre)
+		leg_crc_ok_cnt_inc = leg_crc_ok_cnt_cur - dfs->leg_crc_ok_cnt_pre;
+	else
+		leg_crc_ok_cnt_inc = leg_crc_ok_cnt_cur;
+	dfs->leg_crc_ok_cnt_pre = leg_crc_ok_cnt_cur;
+
+	if ((vht_crc_ok_cnt_cur == 0x3fff) ||
+		(ht_crc_ok_cnt_cur == 0x3fff) ||
+		(leg_crc_ok_cnt_cur == 0x3fff)) {
+		odm_set_bb_reg(dm, 0xb58, BIT(0), 1);
+		odm_set_bb_reg(dm, 0xb58, BIT(0), 0);
+	}
+
+	total_crc_ok_cnt_inc = vht_crc_ok_cnt_inc + ht_crc_ok_cnt_inc + leg_crc_ok_cnt_inc;
+
+	/*Get short pulse count, need carefully handle the counter overflow*/
+	regf98_value = odm_get_bb_reg(dm, 0xf98, 0xffffffff);
+	short_pulse_cnt_cur = (u16)(regf98_value & 0x000000ff);
+	if (short_pulse_cnt_cur >= dfs->short_pulse_cnt_pre)
+		short_pulse_cnt_inc = short_pulse_cnt_cur - dfs->short_pulse_cnt_pre;
+	else
+		short_pulse_cnt_inc = short_pulse_cnt_cur;
+	dfs->short_pulse_cnt_pre = short_pulse_cnt_cur;
+
+	/*Get long pulse count, need carefully handle the counter overflow*/
+	long_pulse_cnt_cur = (u16)((regf98_value & 0x0000ff00) >> 8);
+	if (long_pulse_cnt_cur >= dfs->long_pulse_cnt_pre)
+		long_pulse_cnt_inc = long_pulse_cnt_cur - dfs->long_pulse_cnt_pre;
+	else
+		long_pulse_cnt_inc = long_pulse_cnt_cur;
+	dfs->long_pulse_cnt_pre = long_pulse_cnt_cur;
+
+	total_pulse_count_inc = short_pulse_cnt_inc + long_pulse_cnt_inc;
+
+	if (dfs->det_print){
+		PHYDM_DBG(dm, DBG_DFS, "=====================================================================\n");
+		PHYDM_DBG(dm, DBG_DFS, "Total_CRC_OK_cnt_inc[%d] VHT_CRC_ok_cnt_inc[%d] HT_CRC_ok_cnt_inc[%d] LEG_CRC_ok_cnt_inc[%d] FA_count_inc[%d]\n",
+			total_crc_ok_cnt_inc, vht_crc_ok_cnt_inc, ht_crc_ok_cnt_inc, leg_crc_ok_cnt_inc, fa_count_inc);
+		PHYDM_DBG(dm, DBG_DFS, "Init_Gain[%x] 0x91c[%x] 0xf98[%08x] short_pulse_cnt_inc[%d] long_pulse_cnt_inc[%d]\n",
+			dfs->igi_cur, dfs->st_l2h_cur, regf98_value, short_pulse_cnt_inc, long_pulse_cnt_inc);
+		PHYDM_DBG(dm, DBG_DFS, "Throughput: %dMbps\n", dm->rx_tp);
+		reg918_value = odm_get_bb_reg(dm, 0x918, 0xffffffff);
+		reg91c_value = odm_get_bb_reg(dm, 0x91c, 0xffffffff);
+		reg920_value = odm_get_bb_reg(dm, 0x920, 0xffffffff);
+		reg924_value = odm_get_bb_reg(dm, 0x924, 0xffffffff);
+		PHYDM_DBG(dm, DBG_DFS, "0x918[%08x] 0x91c[%08x] 0x920[%08x] 0x924[%08x]\n", reg918_value, reg91c_value, reg920_value, reg924_value);
+		PHYDM_DBG(dm, DBG_DFS, "dfs_regdomain = %d, dbg_mode = %d, idle_mode = %d\n", region_domain, dfs->dbg_mode, dfs->idle_mode);
+	}
+	tri_short_pulse = (regf98_value & BIT(17))? 1 : 0;
+	tri_long_pulse = (regf98_value & BIT(19))? 1 : 0;
+
+	if(tri_short_pulse)
+		radar_type = 0;
+	else if(tri_long_pulse)
+		radar_type = 1;
+
+	if (tri_short_pulse) {
+		odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+		odm_set_bb_reg(dm, 0x924, BIT(15), 1);
+	}
+	if (tri_long_pulse) {
+		odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+		odm_set_bb_reg(dm, 0x924, BIT(15), 1);
+		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {	
+			if ((c_channel >= 52) && (c_channel <= 64)) {
+				tri_long_pulse = 0;
+			}
+		}
+		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			tri_long_pulse = 0;
+		}
+	}
+
+	st_l2h_new = dfs->st_l2h_cur;
+	dfs->pulse_flag_hist[dfs->mask_idx] = tri_short_pulse | tri_long_pulse;
+
+	/* PSD(not ready) */
+
+	fault_flag_det = 0;
+	fault_flag_psd = 0;
+	fa_flag = 0;
+	if(region_domain == PHYDM_DFS_DOMAIN_ETSI){
+		fa_mask_th = dfs->fa_mask_th + 20;		
+	}
+	else{
+		fa_mask_th = dfs->fa_mask_th;		
+	}
+	if (max_fa_in_hist >= fa_mask_th || total_fa_in_hist >= fa_mask_th || pre_post_now_acc_fa_in_hist >= fa_mask_th || (dfs->igi_cur >= 0x30)){		
+		st_l2h_new = dfs->st_l2h_max;
+		dfs->radar_det_mask_hist[index] = 1;		
+		if (dfs->pulse_flag_hist[index] == 1){			
+			dfs->pulse_flag_hist[index] = 0;			
+			if (dfs->det_print2){
+				PHYDM_DBG(dm, DBG_DFS, "Radar is masked : FA mask\n");
+			}
+		}
+		fa_flag = 1;
+	} else {
+		dfs->radar_det_mask_hist[index] = 0;
+	}
+
+	if (dfs->det_print) {
+		PHYDM_DBG(dm, DBG_DFS, "mask_idx: %d\n", dfs->mask_idx);
+		PHYDM_DBG(dm, DBG_DFS, "radar_det_mask_hist: ");
+		for (i=0; i<5; i++)
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->radar_det_mask_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS, "pulse_flag_hist: ");
+		for (i=0; i<5; i++)
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->pulse_flag_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS, "fa_inc_hist: ");
+		for (i=0; i<5; i++)			
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->fa_inc_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS,
+			"\nfa_mask_th: %d max_fa_in_hist: %d total_fa_in_hist: %d pre_post_now_acc_fa_in_hist: %d ", fa_mask_th, max_fa_in_hist, total_fa_in_hist, pre_post_now_acc_fa_in_hist);
+	}
+
+	sum = 0;
+	for (k=0; k<5; k++) {
+		if (dfs->radar_det_mask_hist[k] == 1)
+			sum++;
+	}
+
+	if (dfs->mask_hist_checked <= 5)
+		dfs->mask_hist_checked++;
+
+	if ((dfs->mask_hist_checked >= 5) && dfs->pulse_flag_hist[index])
+	{
+		if (sum <= 2) 
+		{
+			radar_detected = 1 ;
+			PHYDM_DBG(dm, DBG_DFS, "Detected type %d radar signal!\n", radar_type);
+		}
+		else {
+			fault_flag_det = 1;
+			if (dfs->det_print2){
+				PHYDM_DBG(dm, DBG_DFS, "Radar is masked : mask_hist large than thd\n");
+			}
+		}
+	}
+
+	dfs->mask_idx++;
+	if (dfs->mask_idx == 5)
+		dfs->mask_idx = 0;
+
+	if ((fault_flag_det == 0) && (fault_flag_psd == 0) && (fa_flag ==0)) {		
+		if (dfs->igi_cur < 0x30) {
+			st_l2h_new = dfs->st_l2h_min;
+		}
+	}
+	
+	if ((st_l2h_new != dfs->st_l2h_cur)) {
+		if (st_l2h_new < dfs->st_l2h_min) {			
+			dfs->st_l2h_cur = dfs->st_l2h_min;			
+		}
+		else if (st_l2h_new > dfs->st_l2h_max)
+			dfs->st_l2h_cur = dfs->st_l2h_max;
+		else
+			dfs->st_l2h_cur = st_l2h_new;
+		odm_set_bb_reg(dm, 0x91c, 0xff, dfs->st_l2h_cur);
+
+		dfs->pwdb_th = ((int)dfs->st_l2h_cur - (int)dfs->igi_cur)/2 + dfs->pwdb_scalar_factor;
+		dfs->pwdb_th = MAX_2(dfs->pwdb_th, (int)dfs->pwdb_th); /*limit the pwdb value to absoulte lower bound 8*/
+		dfs->pwdb_th = MIN_2(dfs->pwdb_th, 0x1f);    /*limit the pwdb value to absoulte upper bound 0x1f*/
+		odm_set_bb_reg(dm, 0x918, 0x00001f00, dfs->pwdb_th);
+	}
+
+	if (dfs->det_print) {
+		PHYDM_DBG(dm, DBG_DFS,
+			"fault_flag_det[%d], fault_flag_psd[%d], DFS_detected [%d]\n", fault_flag_det, fault_flag_psd, radar_detected);
+	}
+
+	return radar_detected;
+
+}
+
+boolean phydm_radar_detect(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	boolean enable_DFS = false;
+	boolean radar_detected = false;
+
+	dfs->igi_cur = (u8)odm_get_bb_reg(dm, 0xc50, 0x0000007f);
+
+	dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, 0x91c, 0x000000ff);
+
+	/* dynamic pwdb calibration */
+	if (dfs->igi_pre != dfs->igi_cur) {
+		dfs->pwdb_th = ((int)dfs->st_l2h_cur - (int)dfs->igi_cur)/2 + dfs->pwdb_scalar_factor;
+		dfs->pwdb_th = MAX_2(dfs->pwdb_th_cur, (int)dfs->pwdb_th); /* limit the pwdb value to absoulte lower bound 0xa */
+		dfs->pwdb_th = MIN_2(dfs->pwdb_th_cur, 0x1f);    /* limit the pwdb value to absoulte upper bound 0x1f */
+		odm_set_bb_reg(dm,  0x918, 0x00001f00, dfs->pwdb_th);
+	}
+
+	dfs->igi_pre = dfs->igi_cur;
+
+	phydm_dfs_dynamic_setting(dm);
+	radar_detected = phydm_radar_detect_dm_check(dm);
+
+	if (odm_get_bb_reg(dm, 0x924, BIT(15)))
+		enable_DFS = true;
+
+	if (enable_DFS && radar_detected) {
+		PHYDM_DBG(dm, DBG_DFS, "Radar detect: enable_DFS:%d, radar_detected:%d\n", enable_DFS, radar_detected);
+		phydm_radar_detect_reset(dm);
+                if (dfs->dbg_mode == 1){
+			PHYDM_DBG(dm, DBG_DFS, "Radar is detected in DFS dbg mode.\n");
+			radar_detected = 0;
+		}
+	}
+
+	return enable_DFS && radar_detected;
+}
+
+
+void
+phydm_dfs_debug(
+	void		*dm_void,
+	u32		*const argv,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	dfs->dbg_mode = (boolean)argv[0];
+	dfs->force_TP_mode = (boolean)argv[1];
+	dfs->det_print = (boolean)argv[2];
+	dfs->det_print2 = (boolean)argv[3];
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "dbg_mode: %d, force_TP_mode: %d, det_print: %d, det_print2: %d\n",
+		       dfs->dbg_mode, dfs->force_TP_mode, dfs->det_print,
+		       dfs->det_print2);
+	
+	/*switch (argv[0]) {
+	case 1:
+#if defined(CONFIG_PHYDM_DFS_MASTER)
+		 set dbg parameters for radar detection instead of the default value 
+		if (argv[1] == 1) {
+			dm->radar_detect_reg_918 = argv[2];
+			dm->radar_detect_reg_91c = argv[3];
+			dm->radar_detect_reg_920 = argv[4];
+			dm->radar_detect_reg_924 = argv[5];
+			dm->radar_detect_dbg_parm_en = 1;
+
+			PDM_SNPF((output + used, out_len - used, "Radar detection with dbg parameter\n"));
+			PDM_SNPF((output + used, out_len - used, "reg918:0x%08X\n", dm->radar_detect_reg_918));
+			PDM_SNPF((output + used, out_len - used, "reg91c:0x%08X\n", dm->radar_detect_reg_91c));
+			PDM_SNPF((output + used, out_len - used, "reg920:0x%08X\n", dm->radar_detect_reg_920));
+			PDM_SNPF((output + used, out_len - used, "reg924:0x%08X\n", dm->radar_detect_reg_924));
+		} else {
+			dm->radar_detect_dbg_parm_en = 0;
+			PDM_SNPF((output + used, out_len - used, "Radar detection with default parameter\n"));
+		}
+		phydm_radar_detect_enable(dm);
+#endif  defined(CONFIG_PHYDM_DFS_MASTER) 
+
+		break;
+	default:
+		break;
+	}*/
+}
+
+
+
+#endif /* defined(CONFIG_PHYDM_DFS_MASTER) */
+
+boolean
+phydm_is_dfs_band(
+	void		*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (((*dm->channel >= 52) && (*dm->channel <= 64)) ||
+		((*dm->channel >= 100) && (*dm->channel <= 140)))
+		return true;
+	else
+		return false;
+}
+
+boolean
+phydm_dfs_master_enabled(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	return *dm->dfs_master_enabled ? true : false;
+#else
+	return false;
+#endif
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dfs.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dfs.h
new file mode 100644
index 000000000000..c46da1203186
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dfs.h
@@ -0,0 +1,118 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __PHYDM_DFS_H__
+#define __PHYDM_DFS_H__
+
+#define DFS_VERSION	"1.1"
+
+/* ============================================================
+  Definition
+ ============================================================
+*/
+
+/*
+============================================================
+1  structure
+ ============================================================
+*/
+
+struct _DFS_STATISTICS {
+	u8			mask_idx;
+	u8			igi_cur;
+	u8			igi_pre;
+	u8			st_l2h_cur;
+	u16			fa_count_pre;
+	u16			fa_inc_hist[5];	
+	u16			vht_crc_ok_cnt_pre;
+	u16			ht_crc_ok_cnt_pre;
+	u16			leg_crc_ok_cnt_pre;
+	u16			short_pulse_cnt_pre;
+	u16			long_pulse_cnt_pre;
+	u8			pwdb_th;
+	u8			pwdb_th_cur;
+	u8			pwdb_scalar_factor;	
+	u8			peak_th;
+	u8			short_pulse_cnt_th;
+	u8			long_pulse_cnt_th;
+	u8			peak_window;
+	u8			nb2wb_th;
+	u8			fa_mask_th;
+	u8			det_flag_offset;
+	u8			st_l2h_max;
+	u8			st_l2h_min;
+	u8			mask_hist_checked;
+	boolean		pulse_flag_hist[5];
+	boolean		radar_det_mask_hist[5];
+	boolean		idle_mode;
+	boolean		force_TP_mode;
+	boolean		dbg_mode;
+	boolean		det_print;
+	boolean		det_print2;
+};
+
+
+/* ============================================================
+  enumeration
+ ============================================================
+*/
+
+enum phydm_dfs_region_domain {
+	PHYDM_DFS_DOMAIN_UNKNOWN = 0,
+	PHYDM_DFS_DOMAIN_FCC = 1,
+	PHYDM_DFS_DOMAIN_MKK = 2,
+	PHYDM_DFS_DOMAIN_ETSI = 3,
+};
+
+/*
+============================================================
+  function prototype
+============================================================
+*/
+#if defined(CONFIG_PHYDM_DFS_MASTER)
+void phydm_radar_detect_reset(void *dm_void);
+void phydm_radar_detect_disable(void *dm_void);
+void phydm_radar_detect_enable(void *dm_void);
+boolean phydm_radar_detect(void *dm_void);
+void phydm_dfs_parameter_init(void *dm_void);
+void phydm_dfs_debug(void *dm_void, u32 *const argv, u32 *_used, char *output, u32 *_out_len);
+#endif /* defined(CONFIG_PHYDM_DFS_MASTER) */
+
+boolean 
+phydm_dfs_is_meteorology_channel(
+	void		*dm_void
+);
+
+boolean
+phydm_is_dfs_band(
+	void		*dm_void
+);
+
+boolean
+phydm_dfs_master_enabled(
+	void		*dm_void
+);
+
+#endif /*#ifndef __PHYDM_DFS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dig.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dig.c
new file mode 100644
index 000000000000..25786fc2c4f6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dig.c
@@ -0,0 +1,1868 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+boolean
+phydm_dig_go_up_check(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+	u8		cur_ig_value = dig_t->cur_ig_value;
+	u8		max_cover_bond;
+	u8		rx_gain_range_max = dig_t->rx_gain_range_max;
+	u8		i = 0, j = 0;
+	u8		total_nhm_cnt = ccx_info->nhm_rpt_sum;
+	u32		dig_cover_cnt = 0;
+	u32		over_dig_cover_cnt = 0;
+	boolean		ret = true;
+
+	if (*dm->bb_op_mode == PHYDM_PERFORMANCE_MODE)
+		return ret;
+
+	max_cover_bond = DIG_MAX_BALANCE_MODE - dig_t->dig_upcheck_initial_value;
+
+	if (cur_ig_value < max_cover_bond - 6)
+		dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_0;
+	else if (cur_ig_value <= DIG_MAX_BALANCE_MODE)
+		dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_1;
+	else	/* cur_ig_value > DM_DIG_MAX_AP, foolproof */
+		dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_2;
+	
+
+	PHYDM_DBG(dm, DBG_DIG, "check_lv = %d, max_cover_bond = 0x%x\n",
+			dig_t->dig_go_up_check_level,
+			max_cover_bond);
+
+	if (total_nhm_cnt == 0)
+		return true;
+
+	if (dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_0) {
+		for (i = 3; i<=11; i++)
+			dig_cover_cnt += ccx_info->nhm_result[i];
+		ret = ((dig_t->dig_level0_ratio_reciprocal * dig_cover_cnt) >= total_nhm_cnt) ? true : false;
+	} else if (dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_1) {
+		
+		/* search index */
+		for (i = 0; i<=10; i++) {
+			if ((max_cover_bond * 2) == ccx_info->nhm_th[i]) {
+				for(j =(i+1); j <= 11; j++)
+					over_dig_cover_cnt += ccx_info->nhm_result[j];
+				break;
+			}
+		}
+		ret = (dig_t->dig_level1_ratio_reciprocal * over_dig_cover_cnt < total_nhm_cnt) ? true : false;
+
+		if (!ret) {
+			/* update dig_t->rx_gain_range_max */
+			dig_t->rx_gain_range_max = (rx_gain_range_max >= max_cover_bond - 6) ? (max_cover_bond - 6) : rx_gain_range_max;
+
+			PHYDM_DBG(dm, DBG_DIG,
+				"Noise pwr over DIG can filter, lock rx_gain_range_max to 0x%x\n",
+				dig_t->rx_gain_range_max);
+		}
+	} else if (dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_2) {
+		/* cur_ig_value > DM_DIG_MAX_AP, foolproof */
+		ret = true;
+	}
+
+	return ret;
+}
+
+void
+odm_fa_threshold_check(
+	void			*dm_void,
+	boolean			is_dfs_band,
+	boolean			is_performance
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+
+	if (dig_t->is_dbg_fa_th) {
+		
+		PHYDM_DBG(dm, DBG_DIG, "Manual Fix FA_th\n");
+	
+	} else if (dm->is_linked && (is_performance || is_dfs_band)) {
+		if (dm->rssi_min < 20) {	/*[PHYDM-252]*/
+			dig_t->fa_th[0] = 500;
+			dig_t->fa_th[1] = 750;
+			dig_t->fa_th[2] = 1000;
+		} else if (((dm->rx_tp >> 2) > dm->tx_tp) && /*Test RX TP*/
+			(dm->rx_tp < 10) && (dm->rx_tp > 1)) {	/*RXTP = 1 ~ 10Mbps*/
+			dig_t->fa_th[0] = 125;
+			dig_t->fa_th[1] = 250;
+			dig_t->fa_th[2] = 500;
+		} else {
+			dig_t->fa_th[0] = 250;
+			dig_t->fa_th[1] = 500;
+			dig_t->fa_th[2] = 750;
+		}
+	} else {
+		if (is_dfs_band) {	/* For DFS band and no link */
+			
+			dig_t->fa_th[0] = 250;
+			dig_t->fa_th[1] = 1000;
+			dig_t->fa_th[2] = 2000;
+		} else {
+			dig_t->fa_th[0] = 2000;
+			dig_t->fa_th[1] = 4000;
+			dig_t->fa_th[2] = 5000;
+		}
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "FA_th={%d,%d,%d}\n",
+		dig_t->fa_th[0], dig_t->fa_th[1], dig_t->fa_th[2]);
+
+}
+
+void
+phydm_set_big_jump_step(
+	void			*dm_void,
+	u8			current_igi
+)
+{
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8		step1[8] = {24, 30, 40, 50, 60, 70, 80, 90};
+	u8		i;
+
+	if (dig_t->enable_adjust_big_jump == 0)
+		return;
+
+	for (i = 0; i <= dig_t->big_jump_step1; i++) {
+		if ((current_igi + step1[i]) > dig_t->big_jump_lmt[dig_t->agc_table_idx]) {
+			if (i != 0)
+				i = i - 1;
+			break;
+		} else if (i == dig_t->big_jump_step1)
+			break;
+	}
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, 0x8c8, 0xe, i);
+	else if (dm->support_ic_type & ODM_RTL8197F)
+		odm_set_bb_reg(dm, ODM_REG_BB_AGC_SET_2_11N, 0xe, i);
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"phydm_set_big_jump_step(): bigjump = %d (ori = 0x%x), LMT=0x%x\n",
+		i, dig_t->big_jump_step1, dig_t->big_jump_lmt[dig_t->agc_table_idx]);
+#endif
+}
+
+void
+odm_write_dig(
+	void			*dm_void,
+	u8			current_igi
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	PHYDM_DBG(dm, DBG_DIG, "odm_write_dig===>\n");
+
+	/* 1 Check IGI by upper bound */
+	if (adaptivity->igi_lmt_en && 
+		(current_igi > adaptivity->adapt_igi_up) && dm->is_linked) {
+		
+		current_igi = adaptivity->adapt_igi_up;
+
+		PHYDM_DBG(dm, DBG_DIG,
+			"Force to Adaptivity Upper bound=((0x%x))\n", current_igi);
+	}
+
+	if (dig_t->cur_ig_value != current_igi) {
+		#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+		/* Modify big jump step for 8822B and 8197F */
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F))
+			phydm_set_big_jump_step(dm, current_igi);
+		#endif
+
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		/* Set IGI value of CCK for new CCK AGC */
+		if (dm->cck_new_agc && (dm->support_ic_type & PHYSTS_2ND_TYPE_IC))
+			odm_set_bb_reg(dm, 0xa0c, 0x3f00, (current_igi >> 1));
+		#endif
+
+		/*Add by YuChen for USB IO too slow issue*/
+		if (dm->support_ic_type &
+			(ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+			if ((dm->support_ability & ODM_BB_ADAPTIVITY) &&
+				(current_igi < dig_t->cur_ig_value)) {
+				dig_t->cur_ig_value = current_igi;
+				phydm_adaptivity(dm);
+			}
+		} else {
+			if ((dm->support_ability & ODM_BB_ADAPTIVITY) &&
+				(current_igi > dig_t->cur_ig_value)) {
+				dig_t->cur_ig_value = current_igi;
+				phydm_adaptivity(dm);
+			}
+		}
+
+		/* Set IGI value */
+		odm_set_bb_reg(dm, ODM_REG(IGI_A, dm), ODM_BIT(IGI, dm), current_igi);
+
+		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS)
+			odm_set_bb_reg(dm, ODM_REG(IGI_B, dm), ODM_BIT(IGI, dm), current_igi);
+		#endif
+
+		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+			odm_set_bb_reg(dm, ODM_REG(IGI_C, dm), ODM_BIT(IGI, dm), current_igi);
+			odm_set_bb_reg(dm, ODM_REG(IGI_D, dm), ODM_BIT(IGI, dm), current_igi);
+		}
+		#endif
+		
+		dig_t->cur_ig_value = current_igi;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "New_igi=((0x%x))\n\n", current_igi);
+}
+
+void
+phydm_set_dig_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (val_len != 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][DIG]Need val_len=1\n");
+		return;
+	}
+	
+	odm_write_dig(dm, (u8)(*val_buf));
+}
+
+void
+odm_pause_dig(
+	void					*dm_void,
+	enum phydm_pause_type		type,
+	enum phydm_pause_level		lv,
+	u8				igi_input
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	rpt = false;
+	u32	igi = (u32)igi_input;
+
+	PHYDM_DBG(dm, DBG_DIG, "[%s]type = %s, LV = %d, igi = 0x%x\n",
+		  __func__,
+		 ((type == PHYDM_PAUSE) ? "Pause" : ((type == PHYDM_RESUME) ? "Resume" : "PauseNoSet")),
+		  lv, igi);
+
+	switch (type) {
+	
+	case PHYDM_PAUSE:
+	case PHYDM_PAUSE_NO_SET:
+	{
+		rpt = phydm_pause_func(dm, F00_DIG, PHYDM_PAUSE, lv, 1, &igi);
+		break;
+	}
+	
+	case PHYDM_RESUME:
+	{
+		rpt = phydm_pause_func(dm, F00_DIG, PHYDM_RESUME, lv, 1, &igi);
+		break;
+	}
+	default:
+		PHYDM_DBG(dm, DBG_DIG, "Wrong type\n");
+		break;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "pause_result=%d\n", rpt);
+}
+
+
+boolean
+odm_dig_abort(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter	= dm->adapter;
+#endif
+
+	/* support_ability */
+	if ((!(dm->support_ability & ODM_BB_FA_CNT)) ||
+		(!(dm->support_ability & ODM_BB_DIG)) ||
+		*dm->is_scan_in_process) {
+		PHYDM_DBG(dm, DBG_DIG, "Not Support\n");
+		return true;
+	}
+
+	if (dm->pause_ability & ODM_BB_DIG) {
+		
+		PHYDM_DBG(dm, DBG_DIG, "Return: Pause DIG in LV=%d\n", dm->pause_lv_table.lv_dig);
+		return true;
+	}
+	
+	if (dig_t->is_ignore_dig) {
+		dig_t->is_ignore_dig = false;
+		PHYDM_DBG(dm, DBG_DIG, "Return: Ignore DIG\n");
+		return true;
+	}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if OS_WIN_FROM_WIN7(OS_VERSION)
+	if (IsAPModeExist(adapter) && ((PADAPTER)(adapter))->bInHctTest) {
+		PHYDM_DBG(dm, DBG_DIG, " Return: Is AP mode or In HCT Test\n");
+		return true;
+	}
+#endif
+#endif
+
+	return false;
+}
+
+void
+phydm_dig_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct phydm_fa_struct	*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+#endif
+	u32			ret_value = 0;
+	u8			i;
+
+	dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+	dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
+	dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+
+	dig_t->is_ignore_dig = false;
+	dig_t->cur_ig_value = (u8) odm_get_bb_reg(dm, ODM_REG(IGI_A, dm), ODM_BIT(IGI, dm));
+	dig_t->is_media_connect = false;
+
+	dig_t->fa_th[0] = 250;
+	dig_t->fa_th[1] = 500;
+	dig_t->fa_th[2] = 750;
+	dig_t->is_dbg_fa_th = false;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	/* For RTL8881A */
+	false_alm_cnt->cnt_ofdm_fail_pre = 0;
+#endif
+
+	odm_memory_set(dm, dig_t->pause_dig_value, 0, PHYDM_PAUSE_MAX_NUM);
+	dig_t->pause_lv_bitmap = 0;
+
+	dig_t->rx_gain_range_max = DIG_MAX_BALANCE_MODE;
+	dig_t->rx_gain_range_min = dig_t->cur_ig_value;
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	dig_t->enable_adjust_big_jump = 1;
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret_value = odm_get_bb_reg(dm, 0x8c8, MASKLWORD);
+	else if (dm->support_ic_type & ODM_RTL8197F)
+		ret_value = odm_get_bb_reg(dm, 0xc74, MASKLWORD);
+
+	dig_t->big_jump_step1 = (u8)(ret_value & 0xe) >> 1;
+	dig_t->big_jump_step2 = (u8)(ret_value & 0x30) >> 4;
+	dig_t->big_jump_step3 = (u8)(ret_value & 0xc0) >> 6;
+
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
+		for (i = 0; i < sizeof(dig_t->big_jump_lmt); i++) {
+			if (dig_t->big_jump_lmt[i] == 0)
+				dig_t->big_jump_lmt[i] = 0x64;		/* Set -10dBm as default value */
+		}
+	}
+#endif
+
+	dm->pre_rssi_min = 0;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	dm->original_dig_restore = 1;
+#endif
+}
+
+boolean
+phydm_dig_performance_mode_decision(
+	struct dm_struct		*dm
+)
+{
+	boolean	is_performance = true;
+
+#ifdef PHYDM_DIG_MODE_DECISION_SUPPORT
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+
+	switch (dig_t->dig_mode_decision) {
+	case PHYDM_DIG_PERFORAMNCE_MODE:
+		is_performance = true;
+		break;
+	case PHYDM_DIG_COVERAGE_MODE:
+		is_performance = false;
+		break;
+	default:
+		is_performance = true;
+		break;
+	}
+#endif
+
+	return is_performance;
+}
+
+void
+phydm_dig_abs_boundary_decision(
+	struct dm_struct		*dm,
+	boolean	is_performance,
+	boolean	is_dfs_band
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+
+	if (!dm->is_linked) {
+		dig_t->dm_dig_max = DIG_MAX_COVERAGR;
+		dig_t->dm_dig_min = DIG_MIN_COVERAGE;
+	} else if (is_dfs_band == true) {
+		if (*dm->band_width == CHANNEL_WIDTH_20)
+			dig_t->dm_dig_min = DIG_MIN_DFS + 2;
+		else
+			dig_t->dm_dig_min = DIG_MIN_DFS;
+
+		dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+		dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+
+	} else if (!is_performance) {
+		dig_t->dm_dig_max = DIG_MAX_COVERAGR;
+		dig_t->dm_dig_min = DIG_MIN_COVERAGE;
+		#if (DIG_HW == 1)
+		dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
+		#else
+		dig_t->dig_max_of_min = DIG_MAX_OF_MIN_COVERAGE;
+		#endif
+	} else {
+		if (*dm->bb_op_mode == PHYDM_BALANCE_MODE) {	/*service > 2 devices*/
+			dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+			#if (DIG_HW == 1)
+			dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
+			#else
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+			#endif
+		} else if (*dm->bb_op_mode == PHYDM_PERFORMANCE_MODE) {	/*service 1 devices*/
+			dig_t->dm_dig_max = DIG_MAX_PERFORMANCE_MODE;
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_PERFORMANCE_MODE;
+		}
+
+		if (dm->support_ic_type &
+			(ODM_RTL8814A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8822B))
+			dig_t->dm_dig_min = 0x1c;
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			dig_t->dm_dig_min = 0x1e;		/*For HW setting*/
+		else
+			dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"Abs-bound{Max, Min}={0x%x, 0x%x}, Max_of_min =  0x%x\n",
+		dig_t->dm_dig_max,
+		dig_t->dm_dig_min,
+		dig_t->dig_max_of_min);
+
+}
+
+void
+phydm_dig_dym_boundary_decision(
+	struct dm_struct		*dm,
+	boolean	is_performance
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8 offset = 15, tmp_max = 0;
+	u8 max_of_rssi_min = 0;
+
+	PHYDM_DBG(dm, DBG_DIG,
+			"Offset=((%d))\n", offset);
+
+	/* DIG lower bound */
+	if (dm->rssi_min > dig_t->dig_max_of_min)
+		dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+	else if (dm->rssi_min < dig_t->dm_dig_min)
+		dig_t->rx_gain_range_min = dig_t->dm_dig_min;
+	else
+		dig_t->rx_gain_range_min = dm->rssi_min;
+
+	/* DIG upper bound */
+	tmp_max = dig_t->rx_gain_range_min + offset;
+	if (dig_t->rx_gain_range_min != dm->rssi_min) {
+		max_of_rssi_min = dm->rssi_min + offset;
+		if (tmp_max > max_of_rssi_min)
+			tmp_max = max_of_rssi_min;
+	}
+
+	if (tmp_max > dig_t->dm_dig_max)
+		dig_t->rx_gain_range_max = dig_t->dm_dig_max;
+	else
+		dig_t->rx_gain_range_max = tmp_max;
+
+	/* 1 Force Lower Bound for AntDiv */
+	if (dm->is_one_entry_only != 0)
+		goto out;
+
+	if ((dm->support_ic_type & ODM_ANTDIV_SUPPORT) && (dm->support_ability & ODM_BB_ANT_DIV)) {
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV || dm->ant_div_type == CG_TRX_SMART_ANTDIV) {
+			if (dig_t->ant_div_rssi_max > dig_t->dig_max_of_min)
+				dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+			else
+				dig_t->rx_gain_range_min = (u8)dig_t->ant_div_rssi_max;
+			
+			PHYDM_DBG(dm, DBG_DIG,
+				"AntDiv: Force Dyn-Min = 0x%x, RSSI_max = 0x%x\n",
+				dig_t->rx_gain_range_min, dig_t->ant_div_rssi_max);
+		}
+	}
+
+out:
+	PHYDM_DBG(dm, DBG_DIG,
+		"Dym-bound{Max, Min}={0x%x, 0x%x}\n",
+		dig_t->rx_gain_range_max, dig_t->rx_gain_range_min);
+}
+
+void
+phydm_dig_abnormal_case(
+	struct dm_struct		*dm,
+	u8	current_igi,
+	boolean	is_performance,
+	boolean	is_dfs_band
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	boolean	first_connect = false, first_dis_connect = false;
+
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	/* Modify DIG lower bound, deal with abnormal case */
+	if (!dm->is_linked && is_dfs_band && is_performance) {
+		dig_t->rx_gain_range_max = DIG_MAX_DFS;
+		PHYDM_DBG(dm, DBG_DIG,
+			"DFS band: Force max to 0x%x before link\n", dig_t->rx_gain_range_max);
+	}
+
+	if (is_dfs_band)
+		dig_t->rx_gain_range_min = dig_t->dm_dig_min;
+
+	/* Abnormal lower bound case */
+	if (dig_t->rx_gain_range_min > dig_t->rx_gain_range_max)
+		dig_t->rx_gain_range_min = dig_t->rx_gain_range_max;
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"Abnoraml checked {Max, Min}={0x%x, 0x%x}\n",
+		dig_t->rx_gain_range_max, dig_t->rx_gain_range_min);
+
+}
+
+u8
+phydm_dig_current_igi_by_fa_th(
+	struct dm_struct		*dm,
+	u8			current_igi,
+	u32			false_alm_cnt,
+	u8			*step_size
+)
+{
+	boolean	dig_go_up_check = true;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	
+	dig_go_up_check = phydm_dig_go_up_check(dm);
+
+	if ((false_alm_cnt > dig_t->fa_th[2]) && dig_go_up_check)
+		current_igi = current_igi + step_size[0];
+	else if ((false_alm_cnt > dig_t->fa_th[1]) && dig_go_up_check)
+		current_igi = current_igi + step_size[1];
+	else if (false_alm_cnt < dig_t->fa_th[0])
+		current_igi = current_igi - step_size[2];
+
+	return current_igi;
+
+}
+
+u8
+phydm_dig_igi_start_value(
+	struct dm_struct		*dm,
+	boolean	is_performance,
+	u8		current_igi,
+	u32		false_alm_cnt,
+	boolean	is_dfs_band
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8		step_size[3] = {0};
+	boolean	first_connect = false, first_dis_connect = false;
+
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	if (dm->is_linked) {
+		if (dm->pre_rssi_min <= dm->rssi_min) {
+			step_size[0] = 2;
+			step_size[1] = 1;
+			step_size[2] = 2;
+		} else {
+			step_size[0] = 4;
+			step_size[1] = 2;
+			step_size[2] = 2;
+		}
+		dm->pre_rssi_min = dm->rssi_min;
+	} else {
+		step_size[0] = 2;
+		step_size[1] = 1;
+		step_size[2] = 2;
+	}
+	
+	PHYDM_DBG(dm, DBG_DIG,
+		"step_size = {-%d,  +%d, +%d}\n", step_size[2], step_size[1], step_size[0]);
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"rssi_min = %d, pre_rssi_min = %d\n", dm->rssi_min, dm->pre_rssi_min);
+
+	if (dm->is_linked && is_performance) {
+		/* 2 After link */
+		PHYDM_DBG(dm, DBG_DIG, "Adjust IGI after link\n");
+
+		if (first_connect && is_performance) {
+			if (is_dfs_band) {
+				if (dm->rssi_min > DIG_MAX_DFS)
+					current_igi = DIG_MAX_DFS;
+				else
+					current_igi = dm->rssi_min;
+				PHYDM_DBG(dm, DBG_DIG,
+					"DFS band: one shot IGI to 0x%x most\n", dig_t->rx_gain_range_max);
+			} else
+				current_igi = dig_t->rx_gain_range_min;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				odm_config_bb_with_header_file(dm, CONFIG_BB_AGC_TAB_DIFF);
+#endif
+#endif
+			PHYDM_DBG(dm, DBG_DIG,
+				"First connect case: IGI does on-shot to 0x%x\n", current_igi);
+		} else {
+			/* 4 Abnormal # beacon case */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))		
+			if ((dm->phy_dbg_info.num_qry_beacon_pkt < 5) &&
+				(false_alm_cnt < DM_DIG_FA_TH1) && (dm->bsta_state)) {
+				if (dm->support_ic_type != ODM_RTL8723D) {
+					dig_t->rx_gain_range_min = 0x1c;
+					current_igi = dig_t->rx_gain_range_min;
+					PHYDM_DBG(dm, DBG_DIG,
+						"Abnormal #beacon (%d) case: IGI does one-shot to 0x%x\n",
+						dm->phy_dbg_info.num_qry_beacon_pkt, current_igi);
+				}
+			} else
+#endif
+				current_igi = phydm_dig_current_igi_by_fa_th(dm,
+						current_igi, false_alm_cnt, step_size);
+		}
+	} else {
+		/* 2 Before link */
+		PHYDM_DBG(dm, DBG_DIG, "Adjust IGI before link\n");
+
+		if (first_dis_connect) {
+			current_igi = dig_t->dm_dig_min;
+			PHYDM_DBG(dm, DBG_DIG, "First disconnect case: IGI does on-shot to lower bound\n");
+		} else {
+			PHYDM_DBG(dm, DBG_DIG,
+				"Pre_IGI=((0x%x)), FA=((%d))\n", current_igi, false_alm_cnt);
+
+			current_igi = phydm_dig_current_igi_by_fa_th(dm,
+						current_igi, false_alm_cnt, step_size);
+		}
+	}
+
+	return current_igi;
+
+}
+
+void
+phydm_dig(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct		*falm_cnt = &dm->false_alm_cnt;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
+#endif
+	boolean		first_connect, first_dis_connect;
+	u8			current_igi = dig_t->cur_ig_value;
+	u32			false_alm_cnt= falm_cnt->cnt_all;
+	boolean		is_dfs_band = false, is_performance = true;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0) {
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+		
+		current_igi = dig_t->cur_ig_value_tdma;
+		false_alm_cnt = falm_cnt_acc->cnt_all_1sec;
+	}
+#endif
+
+	if (odm_dig_abort(dm) == true) {
+		dig_t->cur_ig_value = (u8)odm_get_bb_reg(dm, 0xc50, 0x7f);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "%s Start===>\n", __func__);
+
+	/* 1 Update status */
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"is_linked = %d, RSSI = %d, 1stConnect = %d, 1stDisconnect = %d\n",
+		dm->is_linked, dm->rssi_min, first_connect, first_dis_connect);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP | ODM_CE))
+	/* Modify lower bound for DFS band */
+	if (dm->is_dfs_band) {
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+		if (phydm_dfs_master_enabled(dm))
+		#endif
+			is_dfs_band = true;
+		
+		PHYDM_DBG(dm, DBG_DIG, "In DFS band\n");
+	}
+#endif
+
+	is_performance = phydm_dig_performance_mode_decision(dm);
+	PHYDM_DBG(dm, DBG_DIG,
+		"DIG ((%s)) mode\n", (is_performance ? "Performance" : "Coverage"));
+
+	/* Boundary Decision */
+	phydm_dig_abs_boundary_decision(dm, is_performance, is_dfs_band);
+
+	/*init dym boundary*/
+	dig_t->rx_gain_range_max = dig_t->dig_max_of_min;	/*if no link, always stay at lower bound*/
+	dig_t->rx_gain_range_min = dig_t->dm_dig_min;
+
+	/* Adjust boundary by RSSI */
+	if (dm->is_linked)
+		phydm_dig_dym_boundary_decision(dm, is_performance);
+
+	/*Abnormal case check*/
+	phydm_dig_abnormal_case(dm, current_igi, is_performance, is_dfs_band);
+
+	/* False alarm threshold decision */
+	odm_fa_threshold_check(dm, is_dfs_band, is_performance);
+
+	/* 1 Adjust initial gain by false alarm */
+	current_igi = phydm_dig_igi_start_value(dm,
+		is_performance, current_igi, false_alm_cnt, is_dfs_band);
+
+	/* 1 Check initial gain by upper/lower bound */
+	if (current_igi < dig_t->rx_gain_range_min)
+		current_igi = dig_t->rx_gain_range_min;
+
+	if (current_igi > dig_t->rx_gain_range_max)
+		current_igi = dig_t->rx_gain_range_max;
+
+	PHYDM_DBG(dm, DBG_DIG, "New_IGI=((0x%x))\n", current_igi);
+
+	/* 1 Update status */
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0) {
+		dig_t->cur_ig_value_tdma = current_igi;
+		/*It is possible fa_acc_1sec_tsf >= */
+		/*1sec while tdma_dig_state == 0*/
+		if (dig_t->tdma_dig_state != 0)
+			odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+	} else
+#endif 
+		odm_write_dig(dm, current_igi);
+
+	dig_t->is_media_connect = dm->is_linked;
+	
+	PHYDM_DBG(dm, DBG_DIG, "DIG end\n");
+}
+
+void
+phydm_dig_lps_32k(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	current_igi = dm->rssi_min;
+
+
+	odm_write_dig(dm, current_igi);
+}
+
+void
+phydm_dig_by_rssi_lps(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct	*falm_cnt;
+
+	u8	rssi_lower = DIG_MIN_LPS; /* 0x1E or 0x1C */
+	u8	current_igi = dm->rssi_min;
+
+	falm_cnt = &dm->false_alm_cnt;
+	if (odm_dig_abort(dm) == true)
+		return;
+
+	current_igi = current_igi + RSSI_OFFSET_DIG_LPS;
+	PHYDM_DBG(dm, DBG_DIG, "%s==>\n", __func__);
+
+	/* Using FW PS mode to make IGI */
+	/* Adjust by  FA in LPS MODE */
+	if (falm_cnt->cnt_all > DM_DIG_FA_TH2_LPS)
+		current_igi = current_igi + 4;
+	else if (falm_cnt->cnt_all > DM_DIG_FA_TH1_LPS)
+		current_igi = current_igi + 2;
+	else if (falm_cnt->cnt_all < DM_DIG_FA_TH0_LPS)
+		current_igi = current_igi - 2;
+
+
+	/* Lower bound checking */
+
+	/* RSSI Lower bound check */
+	if ((dm->rssi_min - 10) > DIG_MIN_LPS)
+		rssi_lower = (dm->rssi_min - 10);
+	else
+		rssi_lower = DIG_MIN_LPS;
+
+	/* Upper and Lower Bound checking */
+	if (current_igi > DIG_MAX_LPS)
+		current_igi = DIG_MAX_LPS;
+	else if (current_igi < rssi_lower)
+		current_igi = rssi_lower;
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"%s falm_cnt->cnt_all = %d\n", __func__,
+		falm_cnt->cnt_all);
+	PHYDM_DBG(dm, DBG_DIG,
+		"%s dm->rssi_min = %d\n", __func__,
+		dm->rssi_min);
+	PHYDM_DBG(dm, DBG_DIG,
+		"%s current_igi = 0x%x\n", __func__,
+		current_igi);
+
+	/* odm_write_dig(dm, dig_t->cur_ig_value); */
+	odm_write_dig(dm, current_igi);
+#endif
+}
+
+/* 3============================================================
+ * 3 FASLE ALARM CHECK
+ * 3============================================================ */
+void
+phydm_false_alarm_counter_reg_reset(
+	void					*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
+#endif
+	u32	false_alm_cnt;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0) {
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+
+		false_alm_cnt = falm_cnt_acc->cnt_all_1sec;
+	} else 
+#endif
+	{
+		false_alm_cnt = falm_cnt->cnt_all;
+	}
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/*reset false alarm counter registers*/
+		odm_set_bb_reg(dm, 0xC0C, BIT(31), 1);
+		odm_set_bb_reg(dm, 0xC0C, BIT(31), 0);
+		odm_set_bb_reg(dm, 0xD00, BIT(27), 1);
+		odm_set_bb_reg(dm, 0xD00, BIT(27), 0);
+
+		/*update ofdm counter*/
+		/*update page C counter*/
+		odm_set_bb_reg(dm, 0xD00, BIT(31), 0);
+		/*update page D counter*/
+		odm_set_bb_reg(dm, 0xD00, BIT(31), 0);
+
+		/*reset CCK CCA counter*/
+		odm_set_bb_reg(dm, 0xA2C, BIT(13) | BIT(12), 0);
+		odm_set_bb_reg(dm, 0xA2C, BIT(13) | BIT(12), 2);
+
+		/*reset CCK FA counter*/
+		odm_set_bb_reg(dm, 0xA2C, BIT(15) | BIT(14), 0);
+		odm_set_bb_reg(dm, 0xA2C, BIT(15) | BIT(14), 2);
+
+		/*reset CRC32 counter*/
+		odm_set_bb_reg(dm, 0xF14, BIT(16), 1);
+		odm_set_bb_reg(dm, 0xF14, BIT(16), 0);
+	}
+#endif	/* #if (ODM_IC_11N_SERIES_SUPPORT == 1) */
+
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	#if (RTL8881A_SUPPORT == 1)
+			/* Reset FA counter by enable/disable OFDM */
+			if (false_alm_cnt->cnt_ofdm_fail_pre >= 0x7fff) {
+				/* reset OFDM */
+				odm_set_bb_reg(dm, 0x808, BIT(29), 0);
+				odm_set_bb_reg(dm, 0x808, BIT(29), 1);
+				false_alm_cnt->cnt_ofdm_fail_pre = 0;
+				PHYDM_DBG(dm, DBG_FA_CNT, "Reset FA_cnt\n");
+			}
+	#endif	/* #if (RTL8881A_SUPPORT == 1) */
+			/* reset OFDM FA countner */
+			odm_set_bb_reg(dm, 0x9A4, BIT(17), 1);
+			odm_set_bb_reg(dm, 0x9A4, BIT(17), 0);
+
+			/* reset CCK FA counter */
+			odm_set_bb_reg(dm, 0xA2C, BIT(15), 0);
+			odm_set_bb_reg(dm, 0xA2C, BIT(15), 1);
+
+			/* reset CCA counter */
+			odm_set_bb_reg(dm, 0xB58, BIT(0), 1);
+			odm_set_bb_reg(dm, 0xB58, BIT(0), 0);
+		}
+#endif	/* #if (ODM_IC_11AC_SERIES_SUPPORT == 1) */
+}
+
+void
+phydm_false_alarm_counter_reg_hold(
+	void					*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/*hold ofdm counter*/
+		/*hold page C counter*/
+		odm_set_bb_reg(dm, 0xC00, BIT(31), 1);
+		/*hold page D counter*/
+		odm_set_bb_reg(dm, 0xD00, BIT(31), 1);
+
+		//hold cck counter
+		odm_set_bb_reg(dm, 0xA2C, BIT(12), 1);
+		odm_set_bb_reg(dm, 0xA2C, BIT(14), 1);
+	}
+}
+
+void
+odm_false_alarm_counter_statistics(
+	void		*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct	*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u32						ret_value;
+
+	if (!(dm->support_ability & ODM_BB_FA_CNT))
+		return;
+
+	PHYDM_DBG(dm, DBG_FA_CNT, "FA_Counter()======>\n");
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/* hold ofdm & cck counter */
+		phydm_false_alarm_counter_reg_hold(dm);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE1_11N, MASKDWORD);
+		false_alm_cnt->cnt_fast_fsync = (ret_value & 0xffff);
+		false_alm_cnt->cnt_sb_search_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE2_11N, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_cca = (ret_value & 0xffff);
+		false_alm_cnt->cnt_parity_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE3_11N, MASKDWORD);
+		false_alm_cnt->cnt_rate_illegal = (ret_value & 0xffff);
+		false_alm_cnt->cnt_crc8_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE4_11N, MASKDWORD);
+		false_alm_cnt->cnt_mcs_fail = (ret_value & 0xffff);
+
+		false_alm_cnt->cnt_ofdm_fail =
+			false_alm_cnt->cnt_parity_fail + false_alm_cnt->cnt_rate_illegal +
+			false_alm_cnt->cnt_crc8_fail + false_alm_cnt->cnt_mcs_fail +
+			false_alm_cnt->cnt_fast_fsync + false_alm_cnt->cnt_sb_search_fail;
+
+		/* read CCK CRC32 counter */
+		false_alm_cnt->cnt_cck_crc32_error = odm_get_bb_reg(dm, ODM_REG_CCK_CRC32_ERROR_CNT_11N, MASKDWORD);
+		false_alm_cnt->cnt_cck_crc32_ok = odm_get_bb_reg(dm, ODM_REG_CCK_CRC32_OK_CNT_11N, MASKDWORD);
+
+		/* read OFDM CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_CRC32_CNT_11N, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ofdm_crc32_ok = ret_value & 0xffff;
+
+		/* read HT CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11N, MASKDWORD);
+		false_alm_cnt->cnt_ht_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ht_crc32_ok = ret_value & 0xffff;
+
+		/* read VHT CRC32 counter */
+		false_alm_cnt->cnt_vht_crc32_error = 0;
+		false_alm_cnt->cnt_vht_crc32_ok = 0;
+		
+#if (RTL8723D_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8723D) {
+			/* read HT CRC32 agg counter */
+			ret_value = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11N_AGG, MASKDWORD);
+			false_alm_cnt->cnt_ht_crc32_error_agg = (ret_value & 0xffff0000) >> 16;
+			false_alm_cnt->cnt_ht_crc32_ok_agg= ret_value & 0xffff;
+		}
+#endif
+		
+#if (RTL8188E_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8188E) {
+			ret_value = odm_get_bb_reg(dm, ODM_REG_SC_CNT_11N, MASKDWORD);
+			false_alm_cnt->cnt_bw_lsc = (ret_value & 0xffff);
+			false_alm_cnt->cnt_bw_usc = ((ret_value & 0xffff0000) >> 16);
+		}
+#endif
+
+		{
+			ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_FA_LSB_11N, MASKBYTE0);
+			false_alm_cnt->cnt_cck_fail = ret_value;
+
+			ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_FA_MSB_11N, MASKBYTE3);
+			false_alm_cnt->cnt_cck_fail += (ret_value & 0xff) << 8;
+
+			ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CCA_CNT_11N, MASKDWORD);
+			false_alm_cnt->cnt_cck_cca = ((ret_value & 0xFF) << 8) | ((ret_value & 0xFF00) >> 8);
+		}
+
+		false_alm_cnt->cnt_all_pre = false_alm_cnt->cnt_all;
+
+		false_alm_cnt->time_fa_all = (false_alm_cnt->cnt_fast_fsync + false_alm_cnt->cnt_sb_search_fail) * 12 +
+					  (false_alm_cnt->cnt_parity_fail + false_alm_cnt->cnt_rate_illegal) * 28 +
+					  false_alm_cnt->cnt_crc8_fail * 36 +
+					  false_alm_cnt->cnt_mcs_fail * 32 +
+					  false_alm_cnt->cnt_cck_fail * 80;
+
+		false_alm_cnt->cnt_all = (false_alm_cnt->cnt_fast_fsync +
+					  false_alm_cnt->cnt_sb_search_fail +
+					  false_alm_cnt->cnt_parity_fail +
+					  false_alm_cnt->cnt_rate_illegal +
+					  false_alm_cnt->cnt_crc8_fail +
+					  false_alm_cnt->cnt_mcs_fail +
+					  false_alm_cnt->cnt_cck_fail);
+
+		false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_ofdm_cca + false_alm_cnt->cnt_cck_cca;
+
+		PHYDM_DBG(dm, DBG_FA_CNT,
+			"[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), CRC8_fail = (( %d )), Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d ))\n",
+			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail);
+		
+	}
+#endif
+
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		u32 cck_enable;
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE1_11AC, MASKDWORD);
+		false_alm_cnt->cnt_fast_fsync = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE2_11AC, MASKDWORD);
+		false_alm_cnt->cnt_sb_search_fail = (ret_value & 0xffff);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE3_11AC, MASKDWORD);
+		false_alm_cnt->cnt_parity_fail = (ret_value & 0xffff);
+		false_alm_cnt->cnt_rate_illegal = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE4_11AC, MASKDWORD);
+		false_alm_cnt->cnt_crc8_fail = (ret_value & 0xffff);
+		false_alm_cnt->cnt_mcs_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE5_11AC, MASKDWORD);
+		false_alm_cnt->cnt_crc8_fail_vht = (ret_value & 0xffff);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE6_11AC, MASKDWORD);
+		false_alm_cnt->cnt_mcs_fail_vht = (ret_value & 0xffff);
+
+		/* read OFDM FA counter */
+		false_alm_cnt->cnt_ofdm_fail = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_11AC, MASKLWORD);
+
+		/* Read CCK FA counter */
+		false_alm_cnt->cnt_cck_fail = odm_get_bb_reg(dm, ODM_REG_CCK_FA_11AC, MASKLWORD);
+
+		/* read CCK/OFDM CCA counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CCA_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_cca = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_cck_cca = ret_value & 0xffff;
+
+		/* read CCK CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_cck_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_cck_crc32_ok = ret_value & 0xffff;
+
+		/* read OFDM CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ofdm_crc32_ok = ret_value & 0xffff;
+
+		/* read HT CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_ht_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ht_crc32_ok = ret_value & 0xffff;
+
+		/* read VHT CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_VHT_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_vht_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_vht_crc32_ok = ret_value & 0xffff;
+
+#if (RTL8881A_SUPPORT == 1)
+		/* For 8881A */
+		if (dm->support_ic_type == ODM_RTL8881A) {
+			u32 cnt_ofdm_fail_temp = 0;
+
+			if (false_alm_cnt->cnt_ofdm_fail >= false_alm_cnt->cnt_ofdm_fail_pre) {
+				cnt_ofdm_fail_temp = false_alm_cnt->cnt_ofdm_fail_pre;
+				false_alm_cnt->cnt_ofdm_fail_pre = false_alm_cnt->cnt_ofdm_fail;
+				false_alm_cnt->cnt_ofdm_fail = false_alm_cnt->cnt_ofdm_fail - cnt_ofdm_fail_temp;
+			} else
+				false_alm_cnt->cnt_ofdm_fail_pre = false_alm_cnt->cnt_ofdm_fail;
+			PHYDM_DBG(dm, DBG_FA_CNT, "odm_false_alarm_counter_statistics(): cnt_ofdm_fail=%d\n",	false_alm_cnt->cnt_ofdm_fail_pre);
+			PHYDM_DBG(dm, DBG_FA_CNT, "odm_false_alarm_counter_statistics(): cnt_ofdm_fail_pre=%d\n",	cnt_ofdm_fail_temp);
+		}
+#endif
+		cck_enable =  odm_get_bb_reg(dm, ODM_REG_BB_RX_PATH_11AC, BIT(28));
+		if (cck_enable) { /* if(*dm->band_type == ODM_BAND_2_4G) */
+			false_alm_cnt->cnt_all = false_alm_cnt->cnt_ofdm_fail + false_alm_cnt->cnt_cck_fail;
+			false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_cck_cca + false_alm_cnt->cnt_ofdm_cca;
+		} else {
+			false_alm_cnt->cnt_all = false_alm_cnt->cnt_ofdm_fail;
+			false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_ofdm_cca;
+		}
+	}
+#endif
+
+	if (dm->support_ic_type != ODM_RTL8723D) {
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, 0x0)) {/*set debug port to 0x0*/
+			false_alm_cnt->dbg_port0 = phydm_get_bb_dbg_port_value(dm);
+			phydm_release_bb_dbg_port(dm);
+		}
+
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, adaptivity->adaptivity_dbg_port)) {
+			if (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E))
+				false_alm_cnt->edcca_flag = (boolean)((phydm_get_bb_dbg_port_value(dm) & BIT(30)) >> 30);
+			else
+				false_alm_cnt->edcca_flag = (boolean)((phydm_get_bb_dbg_port_value(dm) & BIT(29)) >> 29);
+			phydm_release_bb_dbg_port(dm);
+		}
+	} else {
+		false_alm_cnt->edcca_flag = (boolean)(odm_get_bb_reg(dm, 0x9a0, BIT(29)));
+	}
+
+	phydm_false_alarm_counter_reg_reset(dm_void);
+
+	false_alm_cnt->time_fa_all = (false_alm_cnt->cnt_fast_fsync + false_alm_cnt->cnt_sb_search_fail) * 12 +
+					  (false_alm_cnt->cnt_parity_fail + false_alm_cnt->cnt_rate_illegal) * 28 +
+					  (false_alm_cnt->cnt_crc8_fail + false_alm_cnt->cnt_crc8_fail_vht + false_alm_cnt->cnt_mcs_fail_vht) * 36 +
+					  false_alm_cnt->cnt_mcs_fail * 32 +
+					  false_alm_cnt->cnt_cck_fail * 80;
+
+	false_alm_cnt->cnt_crc32_error_all = false_alm_cnt->cnt_vht_crc32_error + false_alm_cnt->cnt_ht_crc32_error + false_alm_cnt->cnt_ofdm_crc32_error + false_alm_cnt->cnt_cck_crc32_error;
+	false_alm_cnt->cnt_crc32_ok_all = false_alm_cnt->cnt_vht_crc32_ok + false_alm_cnt->cnt_ht_crc32_ok + false_alm_cnt->cnt_ofdm_crc32_ok + false_alm_cnt->cnt_cck_crc32_ok;
+
+	PHYDM_DBG(dm, DBG_FA_CNT,
+			"[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), HT_CRC8_fail = (( %d )), HT_Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d )), VHT_CRC8_fail = (( %d )), VHT_Mcs_fail = (( %d ))\n",
+			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail, false_alm_cnt->cnt_crc8_fail_vht, false_alm_cnt->cnt_mcs_fail_vht);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all);
+
+	PHYDM_DBG(dm, DBG_FA_CNT, "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all);
+
+	PHYDM_DBG(dm, DBG_FA_CNT, "[CCK]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_cck_crc32_error, false_alm_cnt->cnt_cck_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[OFDM]CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_ofdm_crc32_error, false_alm_cnt->cnt_ofdm_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[ HT ]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_ht_crc32_error, false_alm_cnt->cnt_ht_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[VHT]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_vht_crc32_error, false_alm_cnt->cnt_vht_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[TOTAL]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_crc32_error_all, false_alm_cnt->cnt_crc32_ok_all);
+	PHYDM_DBG(dm, DBG_FA_CNT, "FA_Cnt: Dbg port 0x0 = 0x%x, EDCCA = %d\n\n", false_alm_cnt->dbg_port0, false_alm_cnt->edcca_flag);
+}
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+void
+phydm_set_tdma_dig_timer(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32	delta_time_us = dm->tdma_dig_timer_ms * 1000;
+	struct phydm_dig_struct	*dig_t;
+	u32	timeout;
+	u32	current_time_stamp, diff_time_stamp, regb0;
+	
+	dig_t = &dm->dm_dig_table;
+	/*some IC has no FREERUN_CUNT register, like 92E*/
+	if (dm->support_ic_type & ODM_RTL8197F)
+		current_time_stamp = odm_get_bb_reg(dm, 0x568, bMaskDWord);
+	else
+		return;
+
+	timeout = current_time_stamp + delta_time_us;
+
+	diff_time_stamp = current_time_stamp - dig_t->cur_timestamp;
+	dig_t->pre_timestamp = dig_t->cur_timestamp;
+	dig_t->cur_timestamp = current_time_stamp;
+
+	/*HIMR0, it shows HW interrupt mask*/
+	regb0 = odm_get_bb_reg(dm, 0xb0, bMaskDWord);
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"Set next tdma_dig_timer\n");
+	PHYDM_DBG(dm, DBG_DIG,
+		"current_time_stamp=%d, delta_time_us=%d, timeout=%d, diff_time_stamp=%d, Reg0xb0 = 0x%x\n",
+		current_time_stamp,
+		delta_time_us,
+		timeout,
+		diff_time_stamp,
+		regb0);
+
+	if (dm->support_ic_type & ODM_RTL8197F)		/*REG_PS_TIMER2*/
+		odm_set_bb_reg(dm, 0x588, bMaskDWord, timeout);
+	else {
+		PHYDM_DBG(dm, DBG_DIG,
+					"NOT 97F, TDMA-DIG timer does NOT start!\n");
+		return;
+	}
+}
+
+void
+phydm_tdma_dig_timer_check(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t;
+
+	dig_t = &dm->dm_dig_table;
+	
+	PHYDM_DBG(dm, DBG_DIG,
+				"tdma_dig_cnt=%d, pre_tdma_dig_cnt=%d\n",
+				dig_t->tdma_dig_cnt,
+				dig_t->pre_tdma_dig_cnt);
+
+	if ((dig_t->tdma_dig_cnt == 0) ||
+		(dig_t->tdma_dig_cnt == dig_t->pre_tdma_dig_cnt)) {
+		if (dm->support_ability & ODM_BB_DIG) {
+			/*if interrupt mask info is got.*/
+			/*Reg0xb0 is no longer needed*/
+			/*regb0 = odm_get_bb_reg(dm, 0xb0, bMaskDWord);*/
+			PHYDM_DBG(dm, DBG_DIG,
+						"Check fail, IntMask[0]=0x%x, restart tdma_dig_timer !!!\n",
+						*dm->interrupt_mask);
+
+			phydm_tdma_dig_add_interrupt_mask_handler(dm);
+			phydm_enable_rx_related_interrupt_handler(dm);
+			phydm_set_tdma_dig_timer(dm);
+		}
+	} else
+		PHYDM_DBG(dm, DBG_DIG,
+					"Check pass, update pre_tdma_dig_cnt\n");
+
+	dig_t->pre_tdma_dig_cnt = dig_t->tdma_dig_cnt;
+}
+
+/*different IC/team may use different timer for tdma-dig*/
+void
+phydm_tdma_dig_add_interrupt_mask_handler(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE == (ODM_AP))
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_add_interrupt_mask_handler(dm, HAL_INT_TYPE_PSTIMEOUT2);	/*HAL_INT_TYPE_PSTIMEOUT2*/
+#elif (DM_ODM_SUPPORT_TYPE == (ODM_WIN))
+#elif (DM_ODM_SUPPORT_TYPE == (ODM_CE))
+#endif
+}
+
+void
+phydm_tdma_dig(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm;
+	struct phydm_dig_struct	*dig_t;
+	struct phydm_fa_struct *falm_cnt;
+	u32	reg_c50;
+	
+	dm = (struct dm_struct *)dm_void;
+	dig_t = &dm->dm_dig_table;
+	falm_cnt = &dm->false_alm_cnt;
+	reg_c50 = odm_get_bb_reg(dm, 0xc50, MASKBYTE0);
+
+	dig_t->tdma_dig_state =
+		dig_t->tdma_dig_cnt % dm->tdma_dig_state_number;
+
+	PHYDM_DBG(dm, DBG_DIG,
+				"tdma_dig_state=%d, regc50=0x%x\n",
+				dig_t->tdma_dig_state,
+				reg_c50);
+
+	dig_t->tdma_dig_cnt++;
+
+	if (dig_t->tdma_dig_state == 1) {
+		// update IGI from tdma_dig_state == 0
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+
+		odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+		phydm_tdma_false_alarm_counter_check(dm);
+		PHYDM_DBG(dm, DBG_DIG,
+			"tdma_dig_state=%d, reset FA counter !!!\n",
+			dig_t->tdma_dig_state);
+
+	} else if (dig_t->tdma_dig_state == 0) {
+		/* update dig_t->CurIGValue,*/
+		/* it may different from dig_t->cur_ig_value_tdma */
+		/* TDMA IGI upperbond @ L-state = */
+		/* rf_ft_var.tdma_dig_low_upper_bond = 0x26 */
+
+		if (dig_t->cur_ig_value >= dm->tdma_dig_low_upper_bond)
+			dig_t->low_ig_value = dm->tdma_dig_low_upper_bond;
+		else
+			dig_t->low_ig_value = dig_t->cur_ig_value;
+
+		odm_write_dig(dm, dig_t->low_ig_value);
+		phydm_tdma_false_alarm_counter_check(dm);
+	} else
+		phydm_tdma_false_alarm_counter_check(dm);
+}
+
+/*============================================================*/
+/*FASLE ALARM CHECK*/
+/*============================================================*/
+
+void
+phydm_tdma_false_alarm_counter_check(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm;
+	struct phydm_fa_struct	*falm_cnt;
+	struct phydm_fa_acc_struct	*falm_cnt_acc;
+	struct phydm_dig_struct	*dig_t;
+	boolean	rssi_dump_en = 0;
+	u32 timestamp;
+	u8 tdma_dig_state_number;
+
+	dm = (struct dm_struct *)dm_void;
+	falm_cnt = &dm->false_alm_cnt;
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+	dig_t = &dm->dm_dig_table;
+
+	if (dig_t->tdma_dig_state == 1)
+		phydm_false_alarm_counter_reset(dm);
+		/* Reset FalseAlarmCounterStatistics */
+		/* fa_acc_1sec_tsf = fa_acc_1sec_tsf, keep */
+		/* fa_end_tsf = fa_start_tsf = TSF */
+	else {
+		odm_false_alarm_counter_statistics(dm);
+		if (dm->support_ic_type & ODM_RTL8197F)		/*REG_FREERUN_CNT*/
+			timestamp = odm_get_bb_reg(dm, 0x568, bMaskDWord);
+		else {
+			PHYDM_DBG(dm, DBG_DIG,
+						"Caution! NOT 97F! TDMA-DIG timer does NOT start!!!\n");
+			return;
+		}
+		dig_t->fa_end_timestamp = timestamp;
+		dig_t->fa_acc_1sec_timestamp +=
+			(dig_t->fa_end_timestamp - dig_t->fa_start_timestamp);
+
+		/*prevent dumb*/
+		if (dm->tdma_dig_state_number == 1)
+			dm->tdma_dig_state_number = 2;
+
+		tdma_dig_state_number = dm->tdma_dig_state_number;
+		dig_t->sec_factor =
+			tdma_dig_state_number / (tdma_dig_state_number - 1);
+
+		/*1sec = 1000000us*/
+		if (dig_t->fa_acc_1sec_timestamp >= (u32)(1000000 / dig_t->sec_factor)) {
+			rssi_dump_en = 1;
+			phydm_false_alarm_counter_acc(dm, rssi_dump_en);
+			PHYDM_DBG(dm, DBG_DIG,
+						"sec_factor = %u, total FA = %u, is_linked=%u\n",
+						dig_t->sec_factor,
+						falm_cnt_acc->cnt_all,
+						dm->is_linked);
+
+			phydm_noisy_detection(dm);
+			phydm_cck_pd_th(dm);
+			phydm_dig(dm);
+			phydm_false_alarm_counter_acc_reset(dm);
+
+			/* Reset FalseAlarmCounterStatistics */
+			/* fa_end_tsf = fa_start_tsf = TSF, keep */
+			/* fa_acc_1sec_tsf = 0 */
+			phydm_false_alarm_counter_reset(dm);
+		} else
+			phydm_false_alarm_counter_acc(dm, rssi_dump_en);
+	}
+}
+
+void
+phydm_false_alarm_counter_acc(
+	void		*dm_void,
+	boolean		rssi_dump_en
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct			*falm_cnt;
+	struct phydm_fa_acc_struct		*falm_cnt_acc;
+	struct phydm_dig_struct	*dig_t;
+	
+	falm_cnt = &dm->false_alm_cnt;
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+	dig_t = &dm->dm_dig_table;
+
+	falm_cnt_acc->cnt_parity_fail += falm_cnt->cnt_parity_fail;
+	falm_cnt_acc->cnt_rate_illegal += falm_cnt->cnt_rate_illegal;
+	falm_cnt_acc->cnt_crc8_fail += falm_cnt->cnt_crc8_fail;
+	falm_cnt_acc->cnt_mcs_fail += falm_cnt->cnt_mcs_fail;
+	falm_cnt_acc->cnt_ofdm_fail += falm_cnt->cnt_ofdm_fail;
+	falm_cnt_acc->cnt_cck_fail += falm_cnt->cnt_cck_fail;
+	falm_cnt_acc->cnt_all += falm_cnt->cnt_all;
+	falm_cnt_acc->cnt_fast_fsync += falm_cnt->cnt_fast_fsync;
+	falm_cnt_acc->cnt_sb_search_fail += falm_cnt->cnt_sb_search_fail;
+	falm_cnt_acc->cnt_ofdm_cca += falm_cnt->cnt_ofdm_cca;
+	falm_cnt_acc->cnt_cck_cca += falm_cnt->cnt_cck_cca;
+	falm_cnt_acc->cnt_cca_all += falm_cnt->cnt_cca_all;
+	falm_cnt_acc->cnt_cck_crc32_error += falm_cnt->cnt_cck_crc32_error;
+	falm_cnt_acc->cnt_cck_crc32_ok += falm_cnt->cnt_cck_crc32_ok;
+	falm_cnt_acc->cnt_ofdm_crc32_error += falm_cnt->cnt_ofdm_crc32_error;
+	falm_cnt_acc->cnt_ofdm_crc32_ok += falm_cnt->cnt_ofdm_crc32_ok;
+	falm_cnt_acc->cnt_ht_crc32_error += falm_cnt->cnt_ht_crc32_error;
+	falm_cnt_acc->cnt_ht_crc32_ok += falm_cnt->cnt_ht_crc32_ok;
+	falm_cnt_acc->cnt_vht_crc32_error += falm_cnt->cnt_vht_crc32_error;
+	falm_cnt_acc->cnt_vht_crc32_ok += falm_cnt->cnt_vht_crc32_ok;
+	falm_cnt_acc->cnt_crc32_error_all += falm_cnt->cnt_crc32_error_all;
+	falm_cnt_acc->cnt_crc32_ok_all += falm_cnt->cnt_crc32_ok_all;
+
+	if (rssi_dump_en == 1) {
+		falm_cnt_acc->cnt_all_1sec =
+			falm_cnt_acc->cnt_all * dig_t->sec_factor;
+		falm_cnt_acc->cnt_cca_all_1sec =
+			falm_cnt_acc->cnt_cca_all * dig_t->sec_factor;
+		falm_cnt_acc->cnt_cck_fail_1sec =
+			falm_cnt_acc->cnt_cck_fail * dig_t->sec_factor;
+	}
+}
+
+void
+phydm_false_alarm_counter_acc_reset(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_acc_struct *falm_cnt_acc;
+
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+
+	/* Cnt_all_for_rssi_dump & Cnt_CCA_all_for_rssi_dump */
+	/* do NOT need to be reset */
+	odm_memory_set(dm, falm_cnt_acc, 0, sizeof(falm_cnt_acc));
+}
+
+void
+phydm_false_alarm_counter_reset(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt;
+	struct phydm_dig_struct	*dig_t;
+	u32	timestamp;
+
+	falm_cnt = &dm->false_alm_cnt;
+	dig_t = &dm->dm_dig_table;
+
+	memset(falm_cnt, 0, sizeof(dm->false_alm_cnt));
+	phydm_false_alarm_counter_reg_reset(dm);
+
+	if (dig_t->tdma_dig_state != 1)
+		dig_t->fa_acc_1sec_timestamp = 0;
+	else
+		dig_t->fa_acc_1sec_timestamp = dig_t->fa_acc_1sec_timestamp;
+
+	/*REG_FREERUN_CNT*/
+	timestamp = odm_get_bb_reg(dm, 0x568, bMaskDWord);
+	dig_t->fa_start_timestamp = timestamp;
+	dig_t->fa_end_timestamp = timestamp;
+}
+
+#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+void
+phydm_lna_sat_chk_init(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __FUNCTION__);
+
+	lna_info->check_time = 0;
+	lna_info->sat_cnt_acc_patha = 0;
+	lna_info->sat_cnt_acc_pathb = 0;
+	lna_info->cur_sat_status = 0;
+	lna_info->pre_sat_status = 0;
+	lna_info->cur_timer_check_cnt = 0;
+	lna_info->pre_timer_check_cnt = 0;
+}
+
+void
+phydm_set_ofdm_agc_tab(
+	void	*dm_void,
+	u8		tab_sel
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	/* table sel:0/2, 1 is used for CCK */
+	if (tab_sel == OFDM_AGC_TAB_0)
+		odm_set_bb_reg(dm, 0xc70, 0x1e00, OFDM_AGC_TAB_0);
+	else if (tab_sel == OFDM_AGC_TAB_2)
+		odm_set_bb_reg(dm, 0xc70, 0x1e00, OFDM_AGC_TAB_2);
+	else
+		odm_set_bb_reg(dm, 0xc70, 0x1e00, OFDM_AGC_TAB_0);
+}
+
+u8
+phydm_get_ofdm_agc_tab(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	return (u1Byte)odm_get_bb_reg(dm, 0xc70, 0x1e00);
+}
+
+void
+phydm_lna_sat_chk(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	u1Byte			igi_rssi_min, rssi_min = dm->rssi_min;
+	u4Byte			sat_status_patha, sat_status_pathb;
+	u1Byte			igi_restore = dig_t->cur_ig_value;
+	u1Byte			i, lna_sat_chk_cnt = dm->lna_sat_chk_cnt;
+	u4Byte			lna_sat_cnt_thd = 0;
+	u1Byte			agc_tab;
+	u4Byte			max_check_time = 0;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __FUNCTION__);
+
+	if (!(dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"support ability is disabled, return.\n");
+		return;
+	}
+
+	if (dm->is_disable_lna_sat_chk) {
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"is_disable_lna_sat_chk=%d, return.\n", dm->is_disable_lna_sat_chk);
+		return;
+	}
+
+	//func_start = ODM_GetBBReg(pDM_Odm, 0x560, bMaskDWord);
+
+	// move igi to target pin of rssi_min
+	if ((rssi_min == 0) || (rssi_min == 0xff)) {
+		// adapt agc table 0
+		phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		phydm_lna_sat_chk_init(dm);
+		return;
+	} else if (rssi_min % 2 != 0)
+		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI - 1;
+	else
+		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI;
+
+	if ((dm->lna_sat_chk_period_ms > 0) && (dm->lna_sat_chk_period_ms <= ONE_SEC_MS))
+		max_check_time = lna_sat_chk_cnt*(ONE_SEC_MS/(dm->lna_sat_chk_period_ms))*5;
+	else
+		max_check_time = lna_sat_chk_cnt * 5;
+
+	lna_sat_cnt_thd = (max_check_time * dm->lna_sat_chk_duty_cycle)/100;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		"check_time=%d, rssi_min=%d, igi_rssi_min=0x%x\nlna_sat_chk_cnt=%d, lna_sat_chk_period_ms=%d, max_check_time=%d, lna_sat_cnt_thd=%d\n",
+		lna_info->check_time,
+		rssi_min,
+		igi_rssi_min,
+		lna_sat_chk_cnt,
+		dm->lna_sat_chk_period_ms,
+		max_check_time,
+		lna_sat_cnt_thd);
+
+	odm_write_dig(dm, igi_rssi_min);
+
+	// adapt agc table 0 check saturation status
+	phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+	// open rf power detection ckt & set detection range
+	odm_set_rf_reg(dm, RF_PATH_A, 0x86, 0x1f, 0x10);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x86, 0x1f, 0x10);
+
+	// check saturation status
+	for (i = 0; i < lna_sat_chk_cnt; i++) {
+		sat_status_patha = odm_get_rf_reg(dm, RF_PATH_A, 0xae, 0xc0000);
+		sat_status_pathb = odm_get_rf_reg(dm, RF_PATH_B, 0xae, 0xc0000);
+		if (sat_status_patha != 0)
+			lna_info->sat_cnt_acc_patha++;
+		if (sat_status_pathb != 0)
+			lna_info->sat_cnt_acc_pathb++;
+
+		if ((lna_info->sat_cnt_acc_patha >= lna_sat_cnt_thd) ||
+			(lna_info->sat_cnt_acc_pathb >= lna_sat_cnt_thd)) {
+			lna_info->cur_sat_status = 1;
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"cur_sat_status=%d, check_time=%d\n",
+			lna_info->cur_sat_status,
+			lna_info->check_time);
+			break;
+		} else
+			lna_info->cur_sat_status = 0;
+	}
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		"cur_sat_status=%d, pre_sat_status=%d, sat_cnt_acc_patha=%d, sat_cnt_acc_pathb=%d\n",
+		lna_info->cur_sat_status,
+		lna_info->pre_sat_status,
+		lna_info->sat_cnt_acc_patha,
+		lna_info->sat_cnt_acc_pathb);
+
+	// agc table decision
+	if (lna_info->cur_sat_status) {
+		if (!dm->is_disable_gain_table_switch)
+			phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_2);
+		lna_info->check_time = 0;
+		lna_info->sat_cnt_acc_patha = 0;
+		lna_info->sat_cnt_acc_pathb = 0;
+		lna_info->pre_sat_status = lna_info->cur_sat_status;
+
+	} else if (lna_info->check_time <= (max_check_time - 1)) {
+		if (lna_info->pre_sat_status && (!dm->is_disable_gain_table_switch))
+			phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_2);
+		lna_info->check_time++;
+
+	} else if (lna_info->check_time == max_check_time) {
+		if (!dm->is_disable_gain_table_switch && (lna_info->pre_sat_status == 1))
+			phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		lna_info->check_time = 0;
+		lna_info->sat_cnt_acc_patha = 0;
+		lna_info->sat_cnt_acc_pathb = 0;
+		lna_info->pre_sat_status = lna_info->cur_sat_status;
+	}
+
+	agc_tab = phydm_get_ofdm_agc_tab(dm);
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "use AGC tab %d\n", agc_tab);
+	//func_end = ODM_GetBBReg(pDM_Odm, 0x560, bMaskDWord);
+
+	//PHYDM_DBG(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("function process time=%d\n",
+	//	func_end - func_start));
+
+	// restore previous igi
+	odm_write_dig(dm, igi_restore);
+	lna_info->cur_timer_check_cnt++;
+	odm_set_timer(dm, &lna_info->phydm_lna_sat_chk_timer, dm->lna_sat_chk_period_ms);
+}
+
+void
+phydm_lna_sat_chk_callback(
+	void		*dm_void
+
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __FUNCTION__);
+	phydm_lna_sat_chk(dm);
+}
+
+void
+phydm_lna_sat_chk_timers(
+	void		*dm_void,
+	u8			state
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	if (state == INIT_LNA_SAT_CHK_TIMMER) {
+		odm_initialize_timer(dm,
+				     &lna_info->phydm_lna_sat_chk_timer,
+				     (void *)phydm_lna_sat_chk_callback, NULL,
+				     "phydm_lna_sat_chk_timer");
+	} else if (state == CANCEL_LNA_SAT_CHK_TIMMER) {
+		odm_cancel_timer(dm, &lna_info->phydm_lna_sat_chk_timer);
+	} else if (state == RELEASE_LNA_SAT_CHK_TIMMER) {
+		odm_release_timer(dm, &lna_info->phydm_lna_sat_chk_timer);
+	}
+}
+
+void
+phydm_lna_sat_chk_watchdog(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	u1Byte rssi_min = dm->rssi_min;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __FUNCTION__);
+
+	if (!(dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"support ability is disabled, return.\n");
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "pre_timer_check_cnt=%d, cur_timer_check_cnt=%d\n",
+		lna_info->pre_timer_check_cnt,
+		lna_info->cur_timer_check_cnt);
+
+	if (dm->is_disable_lna_sat_chk) {
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"is_disable_lna_sat_chk=%d, return.\n", dm->is_disable_lna_sat_chk);
+		return;
+	}
+
+	if ((dm->support_ic_type & ODM_RTL8197F) == 0) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"SupportICType != ODM_RTL8197F, return.\n");
+		return;
+	}
+
+	if ((rssi_min == 0) || (rssi_min == 0xff)) {
+		// adapt agc table 0
+		phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"rssi_min=%d, return.\n", rssi_min);
+		return;
+	}
+
+	if (lna_info->cur_timer_check_cnt == lna_info->pre_timer_check_cnt) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "Timer check fail, restart timer.\n");
+		phydm_lna_sat_chk(dm);
+	} else {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "Timer check pass.\n");
+	}
+	lna_info->pre_timer_check_cnt = lna_info->cur_timer_check_cnt;
+}
+#endif	/*#if (PHYDM_LNA_SAT_CHK_SUPPORT == 1)*/
+
+void
+phydm_dig_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	char		help[] = "-h";
+	char		monitor[] = "-m";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+
+	if ((strcmp(input[1], help) == 0))
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{0} fa[0] fa[1] fa[2]\n");
+	else if ((strcmp(input[1], monitor) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Read DIG fa_th[0:2]= {%d, %d, %d}\n", 
+			       dig_t->fa_th[0], dig_t->fa_th[1],
+			       dig_t->fa_th[2]);
+
+	} else {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		for (i = 1; i < 10; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+
+		if (var1[0] == 0) {
+			dig_t->is_dbg_fa_th = true;
+			dig_t->fa_th[0] =  (u16)var1[1];
+			dig_t->fa_th[1] =  (u16)var1[2];
+			dig_t->fa_th[2] =  (u16)var1[3];
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "Set DIG fa_th[0:2]= {%d, %d, %d}\n", 
+				       dig_t->fa_th[0], dig_t->fa_th[1],
+				       dig_t->fa_th[2]);
+		} else
+			dig_t->is_dbg_fa_th = false;
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dig.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dig.h
new file mode 100644
index 000000000000..553093e3f901
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dig.h
@@ -0,0 +1,363 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMDIG_H__
+#define	__PHYDMDIG_H__
+
+/*#define DIG_VERSION	"1.4"*/		/* 2017.04.18  YuChen. refine DIG code structure*/
+/*#define DIG_VERSION	"2.0"*/		/* 2017.05.09  Dino. Move CCKPD to new files*/
+/*#define DIG_VERSION	"2.1"*/		/* 2017.06.01  YuChen. Refine DFS condition*/
+#define DIG_VERSION	"2.2"		/* 2017.06.13  YuChen. Remove MP dig*/
+
+#define DIG_HW		0
+
+/*--------------------Define ---------------------------------------*/
+
+/*=== [DIG Boundary] ========================================*/
+/*DIG coverage mode*/
+#define		DIG_MAX_COVERAGR				0x26
+#define		DIG_MIN_COVERAGE				0x1c
+#define		DIG_MAX_OF_MIN_COVERAGE		0x22
+/*DIG performance mode*/
+#if (DIG_HW == 1)
+#define		DIG_MAX_BALANCE_MODE		0x32
+#else
+#define		DIG_MAX_BALANCE_MODE		0x3e
+#endif
+#define		DIG_MAX_OF_MIN_BALANCE_MODE		0x2a
+
+#define		DIG_MAX_PERFORMANCE_MODE		0x5a
+#define		DIG_MAX_OF_MIN_PERFORMANCE_MODE		0x40	/*from 3E -> 2A, refine by YuChen 2017/04/18*/
+
+#define		DIG_MIN_PERFORMANCE			0x20
+
+/*DIG DFS function*/
+#define		DIG_MAX_DFS					0x28
+#define		DIG_MIN_DFS					0x20
+
+/*DIG LPS function*/
+#define		DIG_MAX_LPS					0x3e
+#define		DIG_MIN_LPS					0x20
+
+/*=== [DIG FA Threshold] ======================================*/
+
+/*Normal*/
+#define		DM_DIG_FA_TH0					500
+#define		DM_DIG_FA_TH1					750
+
+/*LPS*/
+#define		DM_DIG_FA_TH0_LPS			4	/* -> 4 lps */
+#define		DM_DIG_FA_TH1_LPS			15	/* -> 15 lps */
+#define		DM_DIG_FA_TH2_LPS			30	/* -> 30 lps */
+
+#define		RSSI_OFFSET_DIG_LPS			5
+
+/*LNA saturation check*/
+#define OFDM_AGC_TAB_0			0
+#define	OFDM_AGC_TAB_2			2
+#define	DIFF_RSSI_TO_IGI		10
+#define	ONE_SEC_MS				1000
+
+/*--------------------Enum-----------------------------------*/
+enum dig_goupcheck_level {
+	DIG_GOUPCHECK_LEVEL_0,
+	DIG_GOUPCHECK_LEVEL_1,
+	DIG_GOUPCHECK_LEVEL_2
+};
+
+enum phydm_dig_mode {
+	PHYDM_DIG_PERFORAMNCE_MODE	= 0,
+	PHYDM_DIG_COVERAGE_MODE	= 1,
+};
+
+enum lna_sat_timer_state {
+	INIT_LNA_SAT_CHK_TIMMER,
+	CANCEL_LNA_SAT_CHK_TIMMER,
+	RELEASE_LNA_SAT_CHK_TIMMER
+};
+/*--------------------Define Struct-----------------------------------*/
+
+struct phydm_dig_struct {
+	boolean	is_ignore_dig; /*for old pause function*/
+	boolean	is_dbg_fa_th;
+	u8		dig_mode_decision;
+	u8		cur_ig_value;
+	u8		rvrt_val;
+	u8		igi_backup;
+	u8		rx_gain_range_max;	/*dig_dynamic_max*/
+	u8		rx_gain_range_min;	/*dig_dynamic_min*/
+	u8		dm_dig_max;			/*Absolutly upper bound*/
+	u8		dm_dig_min;			/*Absolutly lower bound*/
+	u8		dig_max_of_min;		/*Absolutly max of min*/
+	boolean	is_media_connect;
+	u32		ant_div_rssi_max;
+	u8		*is_p2p_in_process;
+	u8		pause_lv_bitmap; /*bit-map of pause level*/
+	u8		pause_dig_value[PHYDM_PAUSE_MAX_NUM];
+	enum dig_goupcheck_level		dig_go_up_check_level;
+	u8		aaa_default;
+	u8		a0a_default;
+	u16		fa_th[3];
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	u8		rf_gain_idx;
+	u8		agc_table_idx;
+	u8		big_jump_lmt[16];
+	u8		enable_adjust_big_jump:1;
+	u8		big_jump_step1:3;
+	u8		big_jump_step2:2;
+	u8		big_jump_step3:2;
+#endif
+	u8		dig_upcheck_initial_value;
+	u8		dig_level0_ratio_reciprocal;
+	u8		dig_level1_ratio_reciprocal;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	u8		cur_ig_value_tdma;
+	u8		low_ig_value;
+	u8		tdma_dig_state;	/*To distinguish which state is now.(L-sate or H-state)*/
+	u8		tdma_dig_cnt;	/*for phydm_tdma_dig_timer_check use*/
+	u8		pre_tdma_dig_cnt;
+	u8		sec_factor;
+	u32		cur_timestamp;
+	u32		pre_timestamp;
+	u32		fa_start_timestamp;
+	u32		fa_end_timestamp;
+	u32		fa_acc_1sec_timestamp;
+#endif	
+};
+
+struct phydm_fa_struct {
+	u32		cnt_parity_fail;
+	u32		cnt_rate_illegal;
+	u32		cnt_crc8_fail;
+	u32		cnt_crc8_fail_vht;
+	u32		cnt_mcs_fail;
+	u32		cnt_mcs_fail_vht;
+	u32		cnt_ofdm_fail;
+	u32		cnt_ofdm_fail_pre;	/* For RTL8881A */
+	u32		cnt_cck_fail;
+	u32		cnt_all;
+	u32		cnt_all_pre;
+	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;
+	u32		cnt_bw_lsc;
+	u32		cnt_cck_crc32_error;
+	u32		cnt_cck_crc32_ok;
+	u32		cnt_ofdm_crc32_error;
+	u32		cnt_ofdm_crc32_ok;
+	u32		cnt_ht_crc32_error;
+	u32		cnt_ht_crc32_ok;
+	u32		cnt_ht_crc32_error_agg;
+	u32		cnt_ht_crc32_ok_agg;
+	u32		cnt_vht_crc32_error;
+	u32		cnt_vht_crc32_ok;
+	u32		cnt_crc32_error_all;
+	u32		cnt_crc32_ok_all;
+	u32		time_fa_all;
+	boolean	cck_block_enable;
+	boolean	ofdm_block_enable;
+	u32		dbg_port0;
+	boolean	edcca_flag;
+};
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+struct phydm_fa_acc_struct {
+	u32		cnt_parity_fail;
+	u32		cnt_rate_illegal;
+	u32		cnt_crc8_fail;
+	u32		cnt_mcs_fail;
+	u32		cnt_ofdm_fail;
+	u32		cnt_ofdm_fail_pre;	/*For RTL8881A*/
+	u32		cnt_cck_fail;
+	u32		cnt_all;
+	u32		cnt_all_pre;
+	u32		cnt_fast_fsync;
+	u32		cnt_sb_search_fail;
+	u32		cnt_ofdm_cca;
+	u32		cnt_cck_cca;
+	u32		cnt_cca_all;
+	u32		cnt_cck_crc32_error;
+	u32		cnt_cck_crc32_ok;
+	u32		cnt_ofdm_crc32_error;
+	u32		cnt_ofdm_crc32_ok;
+	u32		cnt_ht_crc32_error;
+	u32		cnt_ht_crc32_ok;
+	u32		cnt_vht_crc32_error;
+	u32		cnt_vht_crc32_ok;
+	u32		cnt_crc32_error_all;
+	u32		cnt_crc32_ok_all;
+	u32		cnt_all_1sec;
+	u32		cnt_cca_all_1sec;
+	u32		cnt_cck_fail_1sec;
+};
+
+#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+struct phydm_lna_sat_info_struct {
+	u32			sat_cnt_acc_patha;
+	u32			sat_cnt_acc_pathb;
+	u32			check_time;
+	boolean		pre_sat_status;
+	boolean		cur_sat_status;
+	struct phydm_timer_list	phydm_lna_sat_chk_timer;
+	u32			cur_timer_check_cnt;
+	u32			pre_timer_check_cnt;
+};
+
+/*--------------------Function declaration-----------------------------*/
+void
+odm_write_dig(
+	void					*dm_void,
+	u8					current_igi
+);
+
+void
+phydm_set_dig_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+void
+odm_pause_dig(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type,
+	enum phydm_pause_level		pause_level,
+	u8					igi_value
+);
+
+void
+phydm_dig_init(
+	void					*dm_void
+);
+
+void
+phydm_dig(
+	void					*dm_void
+);
+
+void
+phydm_dig_lps_32k(
+	void		*dm_void
+);
+
+void
+phydm_dig_by_rssi_lps(
+	void					*dm_void
+);
+
+void
+odm_false_alarm_counter_statistics(
+	void					*dm_void
+);
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+void
+phydm_set_tdma_dig_timer(
+	void					*dm_void
+);
+
+void
+phydm_tdma_dig_timer_check(
+	void					*dm_void
+);
+
+void
+phydm_tdma_dig(
+	void		*dm_void
+);
+
+void
+phydm_tdma_false_alarm_counter_check(
+	void		*dm_void
+);
+
+void
+phydm_tdma_dig_add_interrupt_mask_handler(
+	void		*dm_void
+);
+
+void
+phydm_false_alarm_counter_reset(
+	void		*dm_void
+);
+
+void
+phydm_false_alarm_counter_acc(
+	void		*dm_void,
+	boolean		rssi_dump_en
+	);
+
+void
+phydm_false_alarm_counter_acc_reset(
+	void		*dm_void
+	);
+
+#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+void
+phydm_set_ofdm_agc_tab(
+	void	*dm_void,
+	u8		tab_sel
+);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+u8
+phydm_get_ofdm_agc_tab(
+	void	*dm_void
+);
+
+void
+phydm_lna_sat_chk(
+	void		*dm_void
+);
+
+void
+phydm_lna_sat_chk_timers(
+	void		*dm_void,
+	u8			state
+);
+
+void
+phydm_lna_sat_chk_watchdog(
+	void		*dm_void
+);
+
+#endif	/*#if (PHYDM_LNA_SAT_CHK_SUPPORT == 1)*/
+
+void
+phydm_dig_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamic_rx_path.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamic_rx_path.c
new file mode 100644
index 000000000000..b5b90b0cef3c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamic_rx_path.c
@@ -0,0 +1,352 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+
+void
+phydm_process_phy_status_for_dynamic_rx_path(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct		*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct		*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(dm->dm_drp_table);
+}
+
+void
+phydm_drp_get_statistic(
+	void			*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_						*p_dm_drp_table = &(dm->dm_drp_table);
+	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+
+	odm_false_alarm_counter_statistics(dm);
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all);
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all);
+}
+
+void
+phydm_dynamic_rx_path(
+	void			*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(dm->dm_drp_table);
+	u8		training_set_timmer_en;
+	u8		curr_drp_state;
+	u32		rx_ok_cal;
+	u32		RSSI = 0;
+	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_RX_PATH)) {
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Return Init]   Not Support Dynamic RX PAth\n");
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "Current drp_state = ((%d))\n", p_dm_drp_table->drp_state);
+
+	curr_drp_state = p_dm_drp_table->drp_state;
+
+	if (p_dm_drp_table->drp_state == DRP_INIT_STATE) {
+
+		phydm_drp_get_statistic(dm);
+
+		if (false_alm_cnt->cnt_crc32_ok_all > 20) {	/*Signal + Interference*/
+			PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Stop DRP Training] cnt_crc32_ok_all = ((%d))\n", false_alm_cnt->cnt_crc32_ok_all);
+			p_dm_drp_table->drp_state  = DRP_INIT_STATE;
+			training_set_timmer_en = false;
+		} else {/*Interference only*/
+			PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Start DRP Training] cnt_crc32_ok_all = ((%d))\n", false_alm_cnt->cnt_crc32_ok_all);
+			p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_0;
+			p_dm_drp_table->curr_rx_path = BB_PATH_AB;
+			training_set_timmer_en = true;
+		}
+
+	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_0) {
+
+		phydm_drp_get_statistic(dm);
+
+		p_dm_drp_table->curr_cca_all_cnt_0 = false_alm_cnt->cnt_cca_all;
+		p_dm_drp_table->curr_fa_all_cnt_0 = false_alm_cnt->cnt_all;
+
+		p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_1;
+		p_dm_drp_table->curr_rx_path = BB_PATH_B;
+		training_set_timmer_en = true;
+
+	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_1) {
+
+		phydm_drp_get_statistic(dm);
+
+		p_dm_drp_table->curr_cca_all_cnt_1 = false_alm_cnt->cnt_cca_all;
+		p_dm_drp_table->curr_fa_all_cnt_1 = false_alm_cnt->cnt_all;
+
+#if 1
+		p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
+#else
+
+		if (*(dm->mp_mode)) {
+			rx_ok_cal = dm->phy_dbg_info.num_qry_phy_status_cck + dm->phy_dbg_info.num_qry_phy_status_ofdm;
+			RSSI = (rx_ok_cal != 0) ? dm->rx_pwdb_ave / rx_ok_cal : 0;
+			PHYDM_DBG(dm, DBG_DYN_RX_PATH, "MP RSSI = ((%d))\n", RSSI);
+		}
+
+		if (RSSI > p_dm_drp_table->rssi_threshold)
+
+			p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
+
+		else  {
+
+			p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_2;
+			p_dm_drp_table->curr_rx_path = BB_PATH_A;
+			training_set_timmer_en = true;
+		}
+#endif
+	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_2) {
+
+		phydm_drp_get_statistic(dm);
+
+		p_dm_drp_table->curr_cca_all_cnt_2 = false_alm_cnt->cnt_cca_all;
+		p_dm_drp_table->curr_fa_all_cnt_2 = false_alm_cnt->cnt_all;
+		p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
+	}
+
+	if (p_dm_drp_table->drp_state == DRP_DECISION_STATE) {
+
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "Current drp_state = ((%d))\n", p_dm_drp_table->drp_state);
+
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[0] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_0, p_dm_drp_table->curr_fa_all_cnt_0);
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[1] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_1, p_dm_drp_table->curr_fa_all_cnt_1);
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[2] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_2, p_dm_drp_table->curr_fa_all_cnt_2);
+
+		if (p_dm_drp_table->curr_fa_all_cnt_1 < p_dm_drp_table->curr_fa_all_cnt_0) {
+
+			if ((p_dm_drp_table->curr_fa_all_cnt_0 - p_dm_drp_table->curr_fa_all_cnt_1) > p_dm_drp_table->fa_diff_threshold)
+				p_dm_drp_table->curr_rx_path = BB_PATH_B;
+			else
+				p_dm_drp_table->curr_rx_path = BB_PATH_AB;
+		} else
+			p_dm_drp_table->curr_rx_path = BB_PATH_AB;
+
+		phydm_config_ofdm_rx_path(dm, p_dm_drp_table->curr_rx_path);
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Training Result]  curr_rx_path = ((%s%s)),\n",
+			((p_dm_drp_table->curr_rx_path & BB_PATH_A)  ? "A"  : " "), ((p_dm_drp_table->curr_rx_path & BB_PATH_B)  ? "B"  : " "));
+
+		p_dm_drp_table->drp_state = DRP_INIT_STATE;
+		training_set_timmer_en = false;
+	}
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "DRP_state: ((%d)) -> ((%d))\n", curr_drp_state, p_dm_drp_table->drp_state);
+
+	if (training_set_timmer_en) {
+
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Training en]  curr_rx_path = ((%s%s)), training_time = ((%d ms))\n",
+			((p_dm_drp_table->curr_rx_path & BB_PATH_A)  ? "A"  : " "), ((p_dm_drp_table->curr_rx_path & BB_PATH_B)  ? "B"  : " "), p_dm_drp_table->training_time);
+
+		phydm_config_ofdm_rx_path(dm, p_dm_drp_table->curr_rx_path);
+		odm_set_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer), p_dm_drp_table->training_time); /*ms*/
+	} else
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "DRP period end\n\n", curr_drp_state, p_dm_drp_table->drp_state);
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_dynamic_rx_path_callback(
+	struct phydm_timer_list		*timer
+)
+{
+	void		*adapter = (void *)timer->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &(hal_data->DM_OutSrc);
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table = &(dm->dm_drp_table);
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&(p_dm_drp_table->phydm_dynamic_rx_path_workitem));
+#else
+	{
+		/* dbg_print("phydm_dynamic_rx_path\n"); */
+		phydm_dynamic_rx_path(dm);
+	}
+#endif
+#else
+	odm_schedule_work_item(&(p_dm_drp_table->phydm_dynamic_rx_path_workitem));
+#endif
+}
+
+void
+phydm_dynamic_rx_path_workitem_callback(
+	void		*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &(hal_data->DM_OutSrc);
+
+	/* dbg_print("phydm_dynamic_rx_path\n"); */
+	phydm_dynamic_rx_path(dm);
+}
+#else if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+phydm_dynamic_rx_path_callback(
+	void *function_context
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)function_context;
+	void	*padapter = dm->adapter;
+
+	if (*(dm->is_net_closed) == true)
+		return;
+
+#if 0 /* Can't do I/O in timer callback*/
+	odm_s0s1_sw_ant_div(dm, SWAW_STEP_DETERMINE);
+#else
+	/*rtw_run_in_thread_cmd(padapter, odm_sw_antdiv_workitem_callback, padapter);*/
+#endif
+}
+
+#endif
+
+void
+phydm_dynamic_rx_path_timers(
+	void		*dm_void,
+	u8		state
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table	= &(dm->dm_drp_table);
+
+	if (state == INIT_DRP_TIMMER) {
+
+		odm_initialize_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer),
+			(void *)phydm_dynamic_rx_path_callback, NULL, "phydm_sw_antenna_switch_timer");
+	} else if (state == CANCEL_DRP_TIMMER)
+
+		odm_cancel_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer));
+
+	else if (state == RELEASE_DRP_TIMMER)
+
+		odm_release_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer));
+
+}
+
+void
+phydm_dynamic_rx_path_init(
+	void			*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(dm->dm_drp_table);
+	boolean			ret_value;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_RX_PATH)) {
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Return]   Not Support Dynamic RX PAth\n");
+		return;
+	}
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "phydm_dynamic_rx_path_init\n");
+
+	p_dm_drp_table->drp_state = DRP_INIT_STATE;
+	p_dm_drp_table->rssi_threshold = DRP_RSSI_TH;
+	p_dm_drp_table->fa_count_thresold = 50;
+	p_dm_drp_table->fa_diff_threshold = 50;
+	p_dm_drp_table->training_time = 100; /*ms*/
+	p_dm_drp_table->drp_skip_counter = 0;
+	p_dm_drp_table->drp_period  = 0;
+	p_dm_drp_table->drp_init_finished = true;
+
+	ret_value = phydm_api_trx_mode(dm, (enum bb_path)BB_PATH_AB, (enum bb_path)BB_PATH_AB, true);
+
+}
+
+void
+phydm_drp_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table = &(dm->dm_drp_table);
+
+	switch (dm_value[0])	{
+
+	case DRP_TRAINING_TIME:
+		p_dm_drp_table->training_time = (u16)dm_value[1];
+		break;
+	case DRP_TRAINING_PERIOD:
+		p_dm_drp_table->drp_period = (u8)dm_value[1];
+		break;
+	case DRP_RSSI_THRESHOLD:
+		p_dm_drp_table->rssi_threshold = (u8)dm_value[1];
+		break;
+	case DRP_FA_THRESHOLD:
+		p_dm_drp_table->fa_count_thresold = dm_value[1];
+		break;
+	case DRP_FA_DIFF_THRESHOLD:
+		p_dm_drp_table->fa_diff_threshold = dm_value[1];
+		break;
+	default:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[DRP] unknown command\n");
+		break;
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_dynamic_rx_path_caller(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table	= &(dm->dm_drp_table);
+
+	if (p_dm_drp_table->drp_skip_counter <  p_dm_drp_table->drp_period)
+		p_dm_drp_table->drp_skip_counter++;
+	else
+		p_dm_drp_table->drp_skip_counter = 0;
+
+	if (p_dm_drp_table->drp_skip_counter != 0)
+		return;
+
+	if (p_dm_drp_table->drp_init_finished != true)
+		return;
+
+	phydm_dynamic_rx_path(dm);
+
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamic_rx_path.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamic_rx_path.h
new file mode 100644
index 000000000000..4d0b14238594
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamic_rx_path.h
@@ -0,0 +1,151 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMDYMICRXPATH_H__
+#define    __PHYDMDYMICRXPATH_H__
+
+#define DYNAMIC_RX_PATH_VERSION	"1.0"  /*2016.07.15  Dino */
+
+
+#define	DRP_RSSI_TH	35
+
+#define INIT_DRP_TIMMER		0
+#define CANCEL_DRP_TIMMER		1
+#define RELEASE_DRP_TIMMER		2
+
+#if (RTL8822B_SUPPORT == 1)
+struct drp_rtl8822b_struct {
+	enum bb_path	path_judge;
+	u16	path_a_cck_fa;
+	u16	path_b_cck_fa;
+	
+};
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+
+enum drp_state {
+	DRP_INIT_STATE				= 0,
+	DRP_TRAINING_STATE_0	= 1,
+	DRP_TRAINING_STATE_1		= 2,
+	DRP_TRAINING_STATE_2		= 3,
+	DRP_DECISION_STATE		= 4
+};
+
+enum adjustable_value {
+	DRP_TRAINING_TIME		= 0,
+	DRP_TRAINING_PERIOD	= 1,
+	DRP_RSSI_THRESHOLD	= 2,
+	DRP_FA_THRESHOLD		= 3,
+	DRP_FA_DIFF_THRESHOLD = 4
+};
+
+struct _DYNAMIC_RX_PATH_ {
+	u8			curr_rx_path;
+	u8			drp_state;
+	u16			training_time;
+	u8			rssi_threshold;
+	u32			fa_count_thresold;
+	u32			fa_diff_threshold;
+	u32			curr_cca_all_cnt_0;
+	u32			curr_fa_all_cnt_0;
+	u32			curr_cca_all_cnt_1;
+	u32			curr_fa_all_cnt_1;
+	u32			curr_cca_all_cnt_2;
+	u32			curr_fa_all_cnt_2;
+	u8			drp_skip_counter;
+	u8			drp_period;
+	u8			drp_init_finished;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	phydm_dynamic_rx_path_workitem;
+#endif
+#endif
+	struct phydm_timer_list		phydm_dynamic_rx_path_timer;
+
+};
+
+
+
+void
+phydm_process_phy_status_for_dynamic_rx_path(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+);
+
+void
+phydm_dynamic_rx_path(
+	void			*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_dynamic_rx_path_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+phydm_dynamic_rx_path_workitem_callback(
+	void		*context
+);
+
+#else if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+phydm_dynamic_rx_path_callback(
+	void *function_context
+);
+
+#endif
+
+void
+phydm_dynamic_rx_path_timers(
+	void		*dm_void,
+	u8		state
+);
+
+void
+phydm_dynamic_rx_path_init(
+	void			*dm_void
+);
+
+void
+phydm_drp_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+void
+phydm_dynamic_rx_path_caller(
+	void			*dm_void
+);
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamictxpower.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamictxpower.c
new file mode 100644
index 000000000000..1b68fc6d52f2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamictxpower.c
@@ -0,0 +1,712 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* *********************Power training init************************ */
+void phydm_pow_train_init(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	PMGNT_INFO			mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	/* This is for power training init @ 11N serious */	
+	#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (RT_GetInterfaceSelection((PADAPTER)adapter) == INTF_SEL1_USB_High_Power) {
+		odm_dynamic_tx_power_save_power_index(dm);
+	}
+	#else
+
+		/* so 92c pci do not need dynamic tx power? vivi check it later */
+	#endif
+#endif
+
+}
+
+void
+odm_dynamic_tx_power_save_power_index(
+	void					*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8		index;
+	u32		power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	/* Save PT index, but nothing used?? */
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	for (index = 0; index < 6; index++)
+		hal_data->PowerIndex_backup[index] = PlatformEFIORead1Byte((PADAPTER)adapter, power_index_reg[index]);
+
+
+#endif
+#endif
+}
+
+void
+odm_dynamic_tx_power_restore_power_index(
+	void					*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			index;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	u32			power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
+
+	for (index = 0; index < 6; index++)
+		PlatformEFIOWrite1Byte(adapter, power_index_reg[index], hal_data->PowerIndex_backup[index]);
+
+
+
+#endif
+}
+
+void
+odm_dynamic_tx_power_write_power_index(
+	void					*dm_void,
+	u8		value)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			index;
+	u32			power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
+
+	for (index = 0; index < 6; index++)
+		/* platform_efio_write_1byte(adapter, power_index_reg[index], value); */
+		odm_write_1byte(dm, power_index_reg[index], value);
+
+}
+
+/* ************************************************************ */
+
+#ifdef CONFIG_DYNAMIC_TX_TWR
+
+boolean
+phydm_check_rates(
+	void				*dm_void,
+	u8				rate_idx
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		check_rate_bitmap0 = 0x08080808; /* check CCK11M, OFDM54M, MCS7, MCS15*/
+	u32		check_rate_bitmap1 = 0x80200808; /* check MCS23, MCS31, VHT1SS M9, VHT2SS M9*/
+	u32		check_rate_bitmap2 = 0x00080200; /* check VHT3SS M9, VHT4SS M9*/
+	u32		bitmap_result;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0xfffff000;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
+
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0x003ff000;
+		check_rate_bitmap0 &= 0x000fffff;
+	}
+#endif
+
+	
+	if (rate_idx >= 64)
+		bitmap_result = BIT(rate_idx-64) & check_rate_bitmap2;
+	else if (rate_idx >= 32)
+		bitmap_result = BIT(rate_idx-32) & check_rate_bitmap1;
+	else if (rate_idx <= 31)
+		bitmap_result = BIT(rate_idx) & check_rate_bitmap0;
+
+	if (bitmap_result!=0)
+		return true;
+	else
+		return false;
+}
+
+enum rf_path
+phydm_check_paths(
+	void				*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	enum rf_path					max_path;
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		max_path = RF_PATH_B;
+#endif
+
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F) 
+		max_path = RF_PATH_B;
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) 
+		max_path = RF_PATH_A;
+#endif
+	return max_path;
+}
+
+u8
+phydm_search_min_power_index(
+	void				*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	enum rf_path		path;
+	enum rf_path		max_path;
+	u8		min_gain_index = 0x3f;
+	u8		gain_index;
+	u8		rate_idx;
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "phydm_search_min_power_index\n");
+	max_path = phydm_check_paths(dm);
+	for (path = 0; path <= max_path; path++)
+		for (rate_idx = 0; rate_idx < 84; rate_idx++)
+			if (phydm_check_rates(dm, rate_idx)) {
+				gain_index = phydm_api_get_txagc(dm, path, rate_idx);
+				PHYDM_DBG(dm, DBG_DYN_TXPWR, "Support Rate: ((%d)) -> Gain index: ((%d))\n", rate_idx, gain_index);
+				if (gain_index < min_gain_index)
+					min_gain_index = gain_index;
+			}
+	
+	return min_gain_index;
+}
+
+
+void
+phydm_dynamic_tx_power_init(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	dm->last_dtp_lvl = tx_high_pwr_level_normal;
+	dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
+	dm->min_power_index = phydm_search_min_power_index(dm);
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "DTP init: Min Gain index: ((%d))\n", dm->min_power_index);
+}
+
+u8
+phydm_pwr_lvl_check(
+	void					*dm_void,
+	u8					input_rssi
+)
+{
+	if (input_rssi >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
+		return tx_high_pwr_level_level2;
+		/**/
+	} else if (input_rssi >= TX_POWER_NEAR_FIELD_THRESH_LVL1) {
+		return tx_high_pwr_level_level1;
+		/**/
+	} else if (input_rssi < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
+		return tx_high_pwr_level_normal;
+		/**/
+	}
+	else {
+		return tx_high_pwr_level_normal;
+	}
+}
+
+void
+phydm_dynamic_response_power(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	now_pwr_lvl;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	if (dm->last_dtp_lvl != dm->dynamic_tx_high_power_lvl) {
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "Response Power update_DTP_lv: ((%d)) -> ((%d))\n", dm->last_dtp_lvl, dm->dynamic_tx_high_power_lvl);
+		dm->last_dtp_lvl = dm->dynamic_tx_high_power_lvl;
+		now_pwr_lvl = dm->dynamic_tx_high_power_lvl;
+		if (now_pwr_lvl == tx_high_pwr_level_level2 || now_pwr_lvl == tx_high_pwr_level_level1) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT(19) | BIT(18), 1); /* Resp TXAGC offset = -3dB*/
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Response Power Set TX power: level 1\n");
+		} else if (now_pwr_lvl == tx_high_pwr_level_normal) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT(19) | BIT(18), 0); /* Resp TXAGC offset = 0dB*/
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Response Power Set TX power: normal\n");
+		}
+	}
+}
+
+void
+phydm_dtp_fill_cmninfo(
+	void					*dm_void,
+	u8					macid,
+	u8					dtp_lvl
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dtp_info 				*dtp= NULL;
+	dtp = &dm->phydm_sta_info[macid]->dtp_stat;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	if (dtp_lvl == tx_high_pwr_level_level2)
+		dtp->dyn_tx_power = PHYDM_OFFSET_MINUS_7DB;
+	else if (dtp_lvl == tx_high_pwr_level_level1)
+		dtp->dyn_tx_power = PHYDM_OFFSET_MINUS_3DB;
+	else
+		dtp->dyn_tx_power = PHYDM_OFFSET_ZERO;
+	
+}
+
+void
+phydm_dtp_per_sta(
+	void					*dm_void,
+	u8					macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct dtp_info				*dtp = NULL;
+	struct rssi_info				*rssi = NULL;
+	if (is_sta_active(sta)) {
+		dtp = &sta->dtp_stat;
+		rssi = &sta->rssi_stat;
+		dtp->sta_tx_high_power_lvl = phydm_pwr_lvl_check(dm,rssi->rssi);
+		if (dtp->sta_tx_high_power_lvl != dtp->sta_last_dtp_lvl) {
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "STA=%d : update_DTP_lv: ((%d)) -> ((%d))\n", macid, dm->last_dtp_lvl, dm->dynamic_tx_high_power_lvl);
+			dm->last_dtp_lvl = dm->dynamic_tx_high_power_lvl;
+			phydm_dtp_fill_cmninfo(dm, macid, dm->dynamic_tx_high_power_lvl);
+		}
+	}
+}
+
+
+#else
+void
+phydm_dynamic_tx_power_init(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	PMGNT_INFO			mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+
+	/*if (!IS_HARDWARE_TYPE_8814A(adapter)) {*/
+	/*	PHYDM_DBG(dm,DBG_DYN_TXPWR, */
+	/*	("DynamicTxPowerEnable=%d\n", mgnt_info->is_dynamic_tx_power_enable));*/
+	/*	return;*/
+	/*} else*/
+	{
+		mgnt_info->bDynamicTxPowerEnable = true;
+		PHYDM_DBG(dm, DBG_DYN_TXPWR,
+			"DynamicTxPowerEnable=%d\n", mgnt_info->bDynamicTxPowerEnable);
+	}
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (RT_GetInterfaceSelection((PADAPTER)adapter) == INTF_SEL1_USB_High_Power) {
+		mgnt_info->bDynamicTxPowerEnable = true;
+	} else
+#else
+	/* so 92c pci do not need dynamic tx power? vivi check it later */
+	mgnt_info->bDynamicTxPowerEnable = false;
+#endif
+
+
+		hal_data->LastDTPLvl = tx_high_pwr_level_normal;
+	hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+	dm->last_dtp_lvl = tx_high_pwr_level_normal;
+	dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
+	dm->tx_agc_ofdm_18_6 = odm_get_bb_reg(dm, 0xC24, MASKDWORD); /*TXAGC {18M 12M 9M 6M}*/
+
+#endif
+
+}
+
+
+
+void
+odm_dynamic_tx_power_nic_ce(
+	void					*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+#if (RTL8821A_SUPPORT == 1)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			val;
+	u8			rssi_tmp = dm->rssi_min;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+
+	if (rssi_tmp >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
+		dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_level2;
+		/**/
+	} else if (rssi_tmp >= TX_POWER_NEAR_FIELD_THRESH_LVL1) {
+		dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_level1;
+		/**/
+	} else if (rssi_tmp < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
+		dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
+		/**/
+	}
+
+	if (dm->last_dtp_lvl == dm->dynamic_tx_high_power_lvl)
+		return;
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "update_DTP_lv: ((%d)) -> ((%d))\n", dm->last_dtp_lvl, dm->dynamic_tx_high_power_lvl);
+
+	dm->last_dtp_lvl = dm->dynamic_tx_high_power_lvl;
+
+	if (dm->support_ic_type & (ODM_RTL8821)) {
+		if (dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_level2) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT19 | BIT18, 1); /* Resp TXAGC offset = -3dB*/
+
+			val = dm->tx_agc_ofdm_18_6 & 0xff;
+			if (val >= 0x20)
+				val -= 0x16;
+
+			odm_set_bb_reg(dm, 0xC24, 0xff, val);
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Set TX power: level 2\n");
+		} else if (dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_level1) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT19 | BIT18, 1); /* Resp TXAGC offset = -3dB*/
+
+			val = dm->tx_agc_ofdm_18_6 & 0xff;
+			if (val >= 0x20)
+				val -= 0x10;
+
+			odm_set_bb_reg(dm, 0xC24, 0xff, val);
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Set TX power: level 1\n");
+		} else if (dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_normal) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT19 | BIT18, 0); /* Resp TXAGC offset = 0dB*/
+			odm_set_bb_reg(dm, 0xC24, MASKDWORD, dm->tx_agc_ofdm_18_6);
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Set TX power: normal\n");
+		}
+	}
+
+#endif
+#endif
+}
+
+
+void
+odm_dynamic_tx_power(
+	void					*dm_void
+)
+{
+	/*  */
+	/* For AP/ADSL use struct rtl8192cd_priv* */
+	/* For CE/NIC use struct void* */
+	/*  */
+	/* struct void*		adapter = dm->adapter;
+	*	struct rtl8192cd_priv*	priv		= dm->priv; */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	/*  */
+	/* 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. */
+	/*  */
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_dynamic_tx_power_nic(dm);
+		break;
+	case	ODM_CE:
+		odm_dynamic_tx_power_nic_ce(dm);
+		break;
+	default:
+		break;
+	}
+
+
+}
+
+
+void
+odm_dynamic_tx_power_nic(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+	if (dm->support_ic_type == ODM_RTL8814A)
+		odm_dynamic_tx_power_8814a(dm);
+	else if (dm->support_ic_type & ODM_RTL8821) {
+		void		*adapter	 =  dm->adapter;
+		PMGNT_INFO		mgnt_info = GetDefaultMgntInfo((PADAPTER)adapter);
+
+		if (mgnt_info->RegRspPwr == 1)	{
+			if (dm->rssi_min > 60)
+				odm_set_mac_reg(dm, ODM_REG_RESP_TX_11AC, BIT(20) | BIT19 | BIT18, 1); /*Resp TXAGC offset = -3dB*/
+			else if (dm->rssi_min < 55)
+				odm_set_mac_reg(dm, ODM_REG_RESP_TX_11AC, BIT(20) | BIT19 | BIT18, 0); /*Resp TXAGC offset = 0dB*/
+		}
+	}
+#endif
+}
+
+
+void
+odm_dynamic_tx_power_8821(
+	void			*dm_void,
+	u8			*desc,
+	u8			mac_id
+)
+{
+#if (RTL8821A_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*entry;
+	u8			reg0xc56_byte;
+	u8			txpwr_offset = 0;
+
+	entry = dm->phydm_sta_info[mac_id];
+
+	reg0xc56_byte = odm_read_1byte(dm, 0xc56);
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "reg0xc56_byte=%d\n", reg0xc56_byte);
+
+	if (entry[mac_id].rssi_stat.rssi > 85) {
+		/* Avoid TXAGC error after TX power offset is applied.
+		For example: Reg0xc56=0x6, if txpwr_offset=3( reduce 11dB )
+		Total power = 6-11= -5( overflow!! ), PA may be burned !
+		so txpwr_offset should be adjusted by Reg0xc56*/
+
+		if (reg0xc56_byte < 7)
+			txpwr_offset = 1;
+		else if (reg0xc56_byte < 11)
+			txpwr_offset = 2;
+		else
+			txpwr_offset = 3;
+
+		SET_TX_DESC_TX_POWER_OFFSET_8812(desc, txpwr_offset);
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "odm_dynamic_tx_power_8821: RSSI=%d, txpwr_offset=%d\n", entry[mac_id].rssi_stat.rssi, txpwr_offset);
+
+	} else {
+		SET_TX_DESC_TX_POWER_OFFSET_8812(desc, txpwr_offset);
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "odm_dynamic_tx_power_8821: RSSI=%d, txpwr_offset=%d\n", entry[mac_id].rssi_stat.rssi, txpwr_offset);
+
+	}
+#endif	/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+#endif	/*#if (RTL8821A_SUPPORT==1)*/
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_dynamic_tx_power_8814a(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	PMGNT_INFO			mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	s32				undecorated_smoothed_pwdb = dm->rssi_min;
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		"TxLevel=%d mgnt_info->iot_action=%x mgnt_info->is_dynamic_tx_power_enable=%d\n",
+		hal_data->DynamicTxHighPowerLvl, mgnt_info->IOTAction, mgnt_info->bDynamicTxPowerEnable);
+
+	/*STA not connected and AP not connected*/
+	if ((!mgnt_info->bMediaConnect) && (hal_data->EntryMinUndecoratedSmoothedPWDB == 0)) {
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "Not connected to any reset power lvl\n");
+		hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+		return;
+	}
+
+
+	if (!mgnt_info->bDynamicTxPowerEnable || mgnt_info->IOTAction & HT_IOT_ACT_DISABLE_HIGH_POWER)
+		hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+	else {
+
+		/*Should we separate as 2.4G/5G band?*/
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "rssi_tmp = %d\n", undecorated_smoothed_pwdb);
+
+		if (undecorated_smoothed_pwdb >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
+			hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_level2;
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "tx_high_pwr_level_level1 (TxPwr=0x0)\n");
+		} else if ((undecorated_smoothed_pwdb < (TX_POWER_NEAR_FIELD_THRESH_LVL2 - 3)) &&
+			(undecorated_smoothed_pwdb >= TX_POWER_NEAR_FIELD_THRESH_LVL1)) {
+			hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_level1;
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "tx_high_pwr_level_level1 (TxPwr=0x10)\n");
+		} else if (undecorated_smoothed_pwdb < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
+			hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "tx_high_pwr_level_normal\n");
+		}
+	}
+
+
+	if (hal_data->DynamicTxHighPowerLvl != hal_data->LastDTPLvl) {
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "odm_dynamic_tx_power_8814a() channel = %d\n", hal_data->CurrentChannel);
+		odm_set_tx_power_level8814(adapter, hal_data->CurrentChannel, hal_data->DynamicTxHighPowerLvl);
+	}
+
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		"odm_dynamic_tx_power_8814a() channel = %d  TXpower lvl=%d/%d\n",
+		hal_data->CurrentChannel, hal_data->LastDTPLvl, hal_data->DynamicTxHighPowerLvl);
+
+	hal_data->LastDTPLvl = hal_data->DynamicTxHighPowerLvl;
+
+}
+
+
+
+/**/
+/*For normal driver we always use the FW method to configure TX power index to reduce I/O transaction.*/
+/**/
+/**/
+void
+odm_set_tx_power_level8814(
+	void		*adapter,
+	u8			channel,
+	u8			pwr_lvl
+)
+{
+#if (DEV_BUS_TYPE == RT_USB_INTERFACE)
+	u32			i, j, k = 0;
+	u32			value[264] = {0};
+	u32			path = 0, power_index, txagc_table_wd = 0x00801000;
+
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+
+	u8	jaguar2_rates[][4] = { {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M},
+		{MGN_6M, MGN_9M, MGN_12M, MGN_18M},
+		{MGN_24M, MGN_36M, MGN_48M, MGN_54M},
+		{MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3},
+		{MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7},
+		{MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11},
+		{MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15},
+		{MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19},
+		{MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23},
+		{MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3},
+		{MGN_VHT1SS_MCS4, MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7},
+		{MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9, MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1},
+		{MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4, MGN_VHT2SS_MCS5},
+		{MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9},
+		{MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3},
+		{MGN_VHT3SS_MCS4, MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7},
+		{MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9, 0, 0}
+	};
+
+	for (path = RF_PATH_A; path <= RF_PATH_D; ++path) {
+		u8	usb_host = UsbModeQueryHubUsbType((PADAPTER)adapter);
+		u8	usb_rfset = UsbModeQueryRfSet((PADAPTER)adapter);
+		u8	usb_rf_type = RT_GetRFType((PADAPTER)adapter);
+
+		for (i = 0; i <= 16; i++) {
+			for (j = 0; j <= 3; j++) {
+				if (jaguar2_rates[i][j] == 0)
+					continue;
+
+				txagc_table_wd =  0x00801000;
+				power_index = (u32) PHY_GetTxPowerIndex((PADAPTER)adapter, (u8)path, jaguar2_rates[i][j], hal_data->CurrentChannelBW, channel);
+
+				/*for Query bus type to recude tx power.*/
+				if (usb_host != USB_MODE_U3 && usb_rfset == 1 && IS_HARDWARE_TYPE_8814AU(adapter) && usb_rf_type == RF_3T3R) {
+					if (channel <= 14) {
+						if (power_index >= 16)
+							power_index -= 16;
+						else
+							power_index = 0;
+					} else
+						power_index = 0;
+				}
+
+				if (pwr_lvl == tx_high_pwr_level_level1) {
+					if (power_index >= 0x10)
+						power_index -= 0x10;
+					else
+						power_index = 0;
+				} else if (pwr_lvl == tx_high_pwr_level_level2)
+					power_index = 0;
+
+				txagc_table_wd |= (path << 8) | MRateToHwRate(jaguar2_rates[i][j]) | (power_index << 24);
+
+				PHY_SetTxPowerIndexShadow((PADAPTER)adapter, (u8)power_index, (u8)path, jaguar2_rates[i][j]);
+
+				value[k++] = txagc_table_wd;
+			}
+		}
+	}
+
+	if (((PADAPTER)adapter)->MgntInfo.bScanInProgress == false &&  ((PADAPTER)adapter)->MgntInfo.RegFWOffload == 2)
+		HalDownloadTxPowerLevel8814((PADAPTER)adapter, value);
+#endif
+}
+#endif
+
+#endif /* #ifdef CONFIG_DYNAMIC_TX_TWR */
+
+void
+phydm_dynamic_tx_power(
+	void					*dm_void
+)
+{
+#ifdef CONFIG_DYNAMIC_TX_TWR
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = NULL;
+	u8		i;
+	u8		cnt = 0;
+	u8		rssi_min = dm->rssi_min;
+	u8		rssi_tmp;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	/* Response Power */
+	dm->dynamic_tx_high_power_lvl = phydm_pwr_lvl_check(dm, rssi_min);
+	phydm_dynamic_response_power(dm);
+	/* Per STA Tx power */
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		phydm_dtp_per_sta(dm, i);
+		cnt++;
+		if (cnt >= dm->number_linked_client)
+			break;
+	}
+#endif
+}
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamictxpower.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamictxpower.h
new file mode 100644
index 000000000000..4698cb25107d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_dynamictxpower.h
@@ -0,0 +1,134 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMDYNAMICTXPOWER_H__
+#define    __PHYDMDYNAMICTXPOWER_H__
+
+/*#define DYNAMIC_TXPWR_VERSION	"1.0"*/
+/*#define DYNAMIC_TXPWR_VERSION	"1.3" */ /*2015.08.26, Add 8814 Dynamic TX power*/
+#define DYNAMIC_TXPWR_VERSION	"1.4" /*2015.11.06, Add CE 8821A Dynamic TX power*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	60
+	#define		TX_POWER_NEAR_FIELD_THRESH_AP	0x3F
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	67
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	60
+#endif
+
+#define		tx_high_pwr_level_normal		0
+#define		tx_high_pwr_level_level1		1
+#define		tx_high_pwr_level_level2		2
+
+#define		tx_high_pwr_level_bt1			3
+#define		tx_high_pwr_level_bt2			4
+#define		tx_high_pwr_level_15			5
+#define		tx_high_pwr_level_35			6
+#define		tx_high_pwr_level_50			7
+#define		tx_high_pwr_level_70			8
+#define		tx_high_pwr_level_100			9
+
+enum phydm_dtp_power_offset {
+	PHYDM_OFFSET_ZERO = 0,
+	PHYDM_OFFSET_MINUS_3DB = 1, 
+	PHYDM_OFFSET_MINUS_7DB = 2,
+	PHYDM_OFFSET_MINUS_11DB = 3,
+	PHYDM_OFFSET_ADD_3DB = 4,
+	PHYDM_OFFSET_ADD_6DB = 5
+};
+
+void
+phydm_pow_train_init(
+	void					*dm_void
+);
+
+void
+phydm_dynamic_tx_power(
+	void					*dm_void
+);
+
+void
+odm_dynamic_tx_power_restore_power_index(
+	void					*dm_void
+);
+
+void
+odm_dynamic_tx_power_nic(
+	void					*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+odm_dynamic_tx_power_save_power_index(
+	void					*dm_void
+);
+
+void
+odm_dynamic_tx_power_write_power_index(
+	void					*dm_void,
+	u8		value);
+
+void
+odm_dynamic_tx_power_8821(
+	void					*dm_void,
+	u8					*desc,
+	u8					mac_id
+);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_dynamic_tx_power_8814a(
+	void					*dm_void
+);
+
+
+void
+odm_set_tx_power_level8814(
+	void		*adapter,
+	u8			channel,
+	u8			pwr_lvl
+);
+#endif
+#endif
+
+void
+odm_dynamic_tx_power(
+	void					*dm_void
+);
+
+void
+phydm_dynamic_tx_power(
+	void					*dm_void
+);
+
+void
+phydm_dynamic_tx_power_init(
+	void					*dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features.h
new file mode 100644
index 000000000000..771070327ba5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features.h
@@ -0,0 +1,52 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_FEATURES_H__
+#define __PHYDM_FEATURES_H__
+
+#define ODM_DC_CANCELLATION_SUPPORT		(ODM_RTL8188F | ODM_RTL8710B)
+#define ODM_RECEIVER_BLOCKING_SUPPORT	(ODM_RTL8188E | ODM_RTL8192E)
+
+#if ((RTL8814A_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+	#define PHYDM_LA_MODE_SUPPORT			1
+#else
+	#define PHYDM_LA_MODE_SUPPORT			0
+#endif
+
+/*20170103 YuChen add for FW API*/
+#define PHYDM_FW_API_ENABLE_8822B			1
+#define PHYDM_FW_API_FUNC_ENABLE_8822B		1
+#define PHYDM_FW_API_ENABLE_8821C			1
+#define PHYDM_FW_API_FUNC_ENABLE_8821C		1
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#include	"phydm_features_win.h"
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#include	"phydm_features_ce.h"
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#include	"phydm_features_ap.h"
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_ap.h
new file mode 100644
index 000000000000..f986e8faaf0d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_ap.h
@@ -0,0 +1,131 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDM_FEATURES_AP_H__
+#define __PHYDM_FEATURES_AP_H__
+
+#if (RTL8822B_SUPPORT == 1 || RTL8812A_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	/*#define PHYDM_TDMA_DIG_SUPPORT*/
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	#define PHYDM_LNA_SAT_CHK_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_POWER_TRAINING_SUPPORT*/
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#define PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
+	#define	PHYDM_PRIMARY_CCA
+#endif
+
+#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	/*#define	CONFIG_ADAPTIVE_SOML*/
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8821A_SUPPORT == 1 || RTL8881A_SUPPORT == 1 || RTL8192E_SUPPORT == 1 || RTL8723B_SUPPORT == 1)
+	/*#define	CONFIG_RA_FW_DBG_CODE*/
+#endif
+
+/* #define CONFIG_DYNAMIC_TX_TWR */
+#define PHYDM_DIG_MODE_DECISION_SUPPORT
+/*#define	CONFIG_PSD_TOOL*/
+#define PHYDM_SUPPORT_CCKPD
+#define RA_MASK_PHYDMLIZE_AP
+/* #define	CONFIG_RA_DBG_CMD*/
+/*#define	CONFIG_PATH_DIVERSITY*/
+/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+#define	CONFIG_RA_DYNAMIC_RATE_ID
+#define	CONFIG_BB_TXBF_API
+/*#define	ODM_CONFIG_BT_COEXIST*/
+/*#define	PHYDM_3RD_REFORM_RA_MASK*/
+#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+#if !defined(CONFIG_DISABLE_PHYDM_DEBUG_FUNCTION)
+	#define CONFIG_PHYDM_DEBUG_FUNCTION
+#endif
+
+/* [ Configure Antenna Diversity ] */
+#if defined(CONFIG_RTL_8881A_ANT_SWITCH) || defined(CONFIG_SLOT_0_ANT_SWITCH) || defined(CONFIG_SLOT_1_ANT_SWITCH)
+	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
+	#define ODM_EVM_ENHANCE_ANTDIV
+	#define SKIP_EVM_ANTDIV_TRAINING_PATCH
+
+	/*----------*/
+
+	#if (!defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A) && !defined(CONFIG_2G_CGCS_RX_DIVERSITY) && !defined(CONFIG_2G_CG_TRX_DIVERSITY) && !defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		#define CONFIG_NO_2G_DIVERSITY
+	#endif
+
+	#ifdef CONFIG_NO_5G_DIVERSITY_8881A
+		#define CONFIG_NO_5G_DIVERSITY
+	#elif defined(CONFIG_5G_CGCS_RX_DIVERSITY_8881A)
+		#define CONFIG_5G_CGCS_RX_DIVERSITY
+	#elif defined(CONFIG_5G_CG_TRX_DIVERSITY_8881A)
+		#define CONFIG_5G_CG_TRX_DIVERSITY
+	#elif defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A)
+		#define CONFIG_2G5G_CG_TRX_DIVERSITY
+	#endif
+	#if (!defined(CONFIG_NO_5G_DIVERSITY) && !defined(CONFIG_5G_CGCS_RX_DIVERSITY) && !defined(CONFIG_5G_CG_TRX_DIVERSITY) && !defined(CONFIG_2G5G_CG_TRX_DIVERSITY) && !defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
+		#define CONFIG_NO_5G_DIVERSITY
+	#endif
+	/*----------*/
+	#if (defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY))
+		#define CONFIG_NOT_SUPPORT_ANTDIV
+	#elif (!defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY))
+		#define CONFIG_2G_SUPPORT_ANTDIV
+	#elif (defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY))
+		#define CONFIG_5G_SUPPORT_ANTDIV
+	#elif ((!defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY)) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY))
+			#define CONFIG_2G5G_SUPPORT_ANTDIV
+	#endif
+		/*----------*/
+#endif /*Antenna Diveristy*/
+
+/*[SmartAntenna]*/
+/*#define	CONFIG_SMART_ANTENNA*/
+#ifdef CONFIG_SMART_ANTENNA
+	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+#endif
+/* --------------------------------------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_ce.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_ce.h
new file mode 100644
index 000000000000..a9e4e4e397ab
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_ce.h
@@ -0,0 +1,132 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_FEATURES_CE_H__
+#define __PHYDM_FEATURES_CE_H__
+
+#if (RTL8822B_SUPPORT == 1 || RTL8812A_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+/*#define PHYDM_TDMA_DIG_SUPPORT*/
+/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+
+#if (RTL8822B_SUPPORT == 1)
+	#define PHYDM_POWER_TRAINING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#define PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+	#define	PHYDM_PRIMARY_CCA
+#endif
+
+#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define	CONFIG_ADAPTIVE_SOML
+#endif
+
+
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#endif
+
+#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	#define	CONFIG_RECEIVER_BLOCKING
+#endif
+
+/* #define CONFIG_DYNAMIC_TX_TWR */
+#define PHYDM_SUPPORT_CCKPD
+#define RA_MASK_PHYDMLIZE_CE
+
+/*Antenna Diversity*/
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+		#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1)
+			#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		#endif
+
+		#if (RTL8821A_SUPPORT == 1)
+			/*#define CONFIG_HL_SMART_ANTENNA_TYPE1*/
+		#endif
+
+		#if (RTL8822B_SUPPORT == 1)
+			/*#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
+		#endif
+	#endif
+#endif
+
+/*[SmartAntenna]*/
+/*#define	CONFIG_SMART_ANTENNA*/
+#ifdef CONFIG_SMART_ANTENNA
+	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+#endif
+/* --------------------------------------------------*/
+
+#ifdef CONFIG_DFS_MASTER
+	#define CONFIG_PHYDM_DFS_MASTER
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8821A_SUPPORT == 1 || RTL8881A_SUPPORT == 1 || RTL8192E_SUPPORT == 1 || RTL8723B_SUPPORT == 1)
+	/*#define	CONFIG_RA_FW_DBG_CODE*/
+#endif
+
+/*#define PHYDM_DIG_MODE_DECISION_SUPPORT*/
+#define	CONFIG_PSD_TOOL
+/*#define	CONFIG_RA_DBG_CMD*/
+/*#define	CONFIG_ANT_DETECTION*/
+/*#define	CONFIG_PATH_DIVERSITY*/
+/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+#define	CONFIG_BB_TXBF_API
+#define	CONFIG_PHYDM_DEBUG_FUNCTION
+
+#ifdef CONFIG_BT_COEXIST
+	#define	ODM_CONFIG_BT_COEXIST
+#endif
+#define	PHYDM_3RD_REFORM_RA_MASK
+#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+/*#define	PHYDM_AUTO_DEGBUG*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_win.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_win.h
new file mode 100644
index 000000000000..47b8befc5949
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_features_win.h
@@ -0,0 +1,120 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDM_FEATURES_WIN_H__
+#define __PHYDM_FEATURES_WIN_H__
+
+#if (RTL8822B_SUPPORT == 1 || RTL8812A_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+/*#define PHYDM_TDMA_DIG_SUPPORT*/
+/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+
+#if (RTL8822B_SUPPORT == 1)
+	#define	PHYDM_POWER_TRAINING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#define	PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	#define	PHYDM_PRIMARY_CCA
+#endif
+
+#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	/*#define	CONFIG_ADAPTIVE_SOML*/
+#endif
+
+
+/*Antenna Diversity*/
+#define	CONFIG_PHYDM_ANTENNA_DIVERSITY
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+	#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1)
+		#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	#endif
+
+	/* --[SmtAnt]-----------------------------------------*/
+	#if (RTL8821A_SUPPORT == 1)
+		/*#define	CONFIG_HL_SMART_ANTENNA_TYPE1*/
+		#define	CONFIG_FAT_PATCH
+	#endif
+	
+	#if (RTL8822B_SUPPORT == 1)
+		/*#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
+	#endif
+	
+	#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1) || defined(CONFIG_HL_SMART_ANTENNA_TYPE2))
+		#define	CONFIG_HL_SMART_ANTENNA
+	#endif
+
+	/* --------------------------------------------------*/
+
+#endif
+
+/*[SmartAntenna]*/
+#define	CONFIG_SMART_ANTENNA
+#ifdef CONFIG_SMART_ANTENNA
+		/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+#endif
+	/* --------------------------------------------------*/
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#endif
+
+#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	#define	CONFIG_RECEIVER_BLOCKING
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8821A_SUPPORT == 1 || RTL8881A_SUPPORT == 1 || RTL8192E_SUPPORT == 1 || RTL8723B_SUPPORT == 1)
+	#define	CONFIG_RA_FW_DBG_CODE
+#endif
+
+/* #define CONFIG_DYNAMIC_TX_TWR */
+/*#define PHYDM_DIG_MODE_DECISION_SUPPORT	*/
+#define	CONFIG_PSD_TOOL
+#define	PHYDM_SUPPORT_CCKPD
+#define	RA_MASK_PHYDMLIZE_WIN
+/*#define	CONFIG_PATH_DIVERSITY*/
+/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+#define CONFIG_ANT_DETECTION
+/*#define	CONFIG_RA_DBG_CMD*/
+#define	CONFIG_BB_TXBF_API
+#define	ODM_CONFIG_BT_COEXIST
+#define	PHYDM_3RD_REFORM_RA_MASK
+#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
+#define	CONFIG_PHYDM_DFS_MASTER
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+#define	PHYDM_AUTO_DEGBUG
+#define CONFIG_PHYDM_DEBUG_FUNCTION
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_hwconfig.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_hwconfig.c
new file mode 100644
index 000000000000..9e4a6fdb1c7a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_hwconfig.c
@@ -0,0 +1,1025 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#define READ_AND_CONFIG_MP(ic, txt) (odm_read_and_config_mp_##ic##txt(dm))
+#define READ_AND_CONFIG_TC(ic, txt) (odm_read_and_config_tc_##ic##txt(dm))
+
+
+#if (PHYDM_TESTCHIP_SUPPORT == 1)
+#define READ_AND_CONFIG(ic, txt) do {\
+		if (dm->is_mp_chip)\
+			READ_AND_CONFIG_MP(ic, txt);\
+		else\
+			READ_AND_CONFIG_TC(ic, txt);\
+	} while (0)
+#else
+#define READ_AND_CONFIG     READ_AND_CONFIG_MP
+#endif
+
+#define GET_VERSION_MP(ic, txt)		(odm_get_version_mp_##ic##txt())
+#define GET_VERSION_TC(ic, txt)		(odm_get_version_tc_##ic##txt())
+
+#if (PHYDM_TESTCHIP_SUPPORT == 1)
+	#define GET_VERSION(ic, txt) (dm->is_mp_chip ? GET_VERSION_MP(ic, txt) : GET_VERSION_TC(ic, txt))
+#else
+	#define GET_VERSION(ic, txt) GET_VERSION_MP(ic, txt)
+#endif
+
+enum hal_status
+odm_config_rf_with_header_file(
+	struct dm_struct		*dm,
+	enum odm_rf_config_type		config_type,
+	u8			e_rf_path
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PMGNT_INFO		mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+#endif
+	enum hal_status	result = HAL_STATUS_SUCCESS;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"===>odm_config_rf_with_header_file (%s)\n", (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		dm->support_platform, dm->support_interface, dm->board_type);
+
+	/* 1 AP doesn't use PHYDM power tracking table in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8812a, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8812a, _radiob);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+			HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+			if ((hal_data->EEPROMSVID == 0x17AA && hal_data->EEPROMSMID == 0xA811) ||
+			    (hal_data->EEPROMSVID == 0x10EC && hal_data->EEPROMSMID == 0xA812) ||
+			    (hal_data->EEPROMSVID == 0x10EC && hal_data->EEPROMSMID == 0x8812))
+				READ_AND_CONFIG_MP(8812a, _txpwr_lmt_hm812a03);
+			else
+#endif
+				READ_AND_CONFIG_MP(8812a, _txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8821a, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			if (dm->support_interface == ODM_ITRF_USB) {
+				if (dm->ext_pa_5g || dm->ext_lna_5g)
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8811a_u_fem);
+				else
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8811a_u_ipa);
+			} else {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+				if (mgnt_info->CustomerID == RT_CID_8821AE_ASUS_MB)
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a_sar_8mm);
+				else if (mgnt_info->CustomerID == RT_CID_ASUS_NB)
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a_sar_5mm);
+				else
+#endif
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a);
+			}
+		}
+	}
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8192e, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8192e, _radiob);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)	/*Refine by Vincent Lan for 5mm SAR pwr limit*/
+			HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+			if ((hal_data->EEPROMSVID == 0x11AD && hal_data->EEPROMSMID == 0x8192) ||
+			    (hal_data->EEPROMSVID == 0x11AD && hal_data->EEPROMSMID == 0x8193))
+				READ_AND_CONFIG_MP(8192e, _txpwr_lmt_8192e_sar_5mm);
+			else
+#endif
+				READ_AND_CONFIG_MP(8192e, _txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8723d, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8723d, _txpwr_lmt);
+	}
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8710b, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8710b, _txpwr_lmt);
+	}
+#endif
+
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+	/* 1 All platforms support */
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8188e, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8188e, _txpwr_lmt);
+	}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (config_type == CONFIG_RF_RADIO)
+			READ_AND_CONFIG_MP(8723b, _radioa);
+		else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8723b, _txpwr_lmt);
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8814a, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8814a, _radiob);
+			else if (e_rf_path == RF_PATH_C)
+				READ_AND_CONFIG_MP(8814a, _radioc);
+			else if (e_rf_path == RF_PATH_D)
+				READ_AND_CONFIG_MP(8814a, _radiod);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type0);
+			else if (dm->rfe_type == 1)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type1);				
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type2);		
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type3);		
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type5);		
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type8);
+			else
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8703b, _radioa);
+		}
+	}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8188f, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8188f, _txpwr_lmt);
+	}
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8822b, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8822b, _radiob);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type5);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type3);
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type4);
+			else if (dm->rfe_type == 12)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type12);
+			else if (dm->rfe_type == 15)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type15);
+			else if (dm->rfe_type == 16)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type16);
+			else if (dm->rfe_type == 17)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type17);
+			else
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt);
+
+		}
+	}
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8197f, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8197f, _radiob);
+		}
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG(8821c, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG(8821c, _txpwr_lmt);
+	}
+#endif
+
+	if (config_type == CONFIG_RF_RADIO) {
+		if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+			result = phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_END,
+							0,
+							0,
+							0,
+							(enum rf_path)0,
+							0);
+			PHYDM_DBG(dm, ODM_COMP_INIT,
+				"rf param offload end!result = %d", result);
+		}
+	}
+
+	return result;
+}
+
+enum hal_status
+odm_config_rf_with_tx_pwr_track_header_file(
+	struct dm_struct		*dm
+)
+{
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"===>odm_config_rf_with_tx_pwr_track_header_file (%s)\n", (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		dm->support_platform, dm->support_interface, dm->board_type);
+
+
+	/* 1 AP doesn't use PHYDM power tracking table in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if RTL8821A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8821a, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8821a, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8821a, _txpowertrack_sdio);
+	}
+#endif
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8812) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8812a, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB) {
+			if (dm->rfe_type == 3 && dm->is_mp_chip)
+				READ_AND_CONFIG_MP(8812a, _txpowertrack_rfe3);
+			else
+				READ_AND_CONFIG_MP(8812a, _txpowertrack_usb);
+		}
+
+	}
+#endif
+#if RTL8192E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8192e, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8192e, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8192e, _txpowertrack_sdio);
+	}
+#endif
+#if RTL8723D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8723d, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8723d, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8723d, _txpowertrack_sdio);
+
+		READ_AND_CONFIG_MP(8723d, _txxtaltrack);
+	}
+#endif
+/* JJ ADD 20161014 */
+#if RTL8710B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		if (dm->package_type == 1)
+			READ_AND_CONFIG_MP(8710b, _txpowertrack_qfn48m_smic);
+		else if (dm->package_type == 5)
+			READ_AND_CONFIG_MP(8710b, _txpowertrack_qfn48m_umc);
+		
+		READ_AND_CONFIG_MP(8710b, _txxtaltrack);
+	}
+#endif
+
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (odm_get_mac_reg(dm, 0xF0, 0xF000) >= 8) {		/*if 0xF0[15:12] >= 8, SMIC*/
+			if (dm->support_interface == ODM_ITRF_PCIE)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_pcie_icut);
+			else if (dm->support_interface == ODM_ITRF_USB)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_usb_icut);
+			else if (dm->support_interface == ODM_ITRF_SDIO)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_sdio_icut);
+		} else {	/*else 0xF0[15:12] < 8, TSMC*/
+			if (dm->support_interface == ODM_ITRF_PCIE)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_pcie);
+			else if (dm->support_interface == ODM_ITRF_USB)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_usb);
+			else if (dm->support_interface == ODM_ITRF_SDIO)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_sdio);
+		}
+
+	}
+#endif
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+	/* 1 All platforms support */
+#if RTL8723B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8723b, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8723b, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8723b, _txpowertrack_sdio);
+	}
+#endif
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A) {
+		if (dm->rfe_type == 0)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type0);
+		else if (dm->rfe_type == 2)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type2);
+		else if (dm->rfe_type == 5)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type5);
+		else if (dm->rfe_type == 7)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type7);
+		else if (dm->rfe_type == 8)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type8);
+		else
+			READ_AND_CONFIG_MP(8814a, _txpowertrack);
+
+		READ_AND_CONFIG_MP(8814a, _txpowertssi);
+	}
+#endif
+#if RTL8703B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8703B) {
+		if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8703b, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8703b, _txpowertrack_sdio);
+
+		READ_AND_CONFIG_MP(8703b, _txxtaltrack);
+	}
+#endif
+
+#if RTL8188F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8188f, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8188f, _txpowertrack_sdio);
+	}
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (dm->rfe_type == 0)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type0);
+		else if (dm->rfe_type == 1)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type1);
+		else if (dm->rfe_type == 2)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type2);
+		else if ((dm->rfe_type == 3) || (dm->rfe_type == 5))
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type3_type5);
+		else if (dm->rfe_type == 4)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type4);
+		else if (dm->rfe_type == 6)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type6);
+		else if (dm->rfe_type == 7)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type7);
+		else if (dm->rfe_type == 8)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type8);
+		else if (dm->rfe_type == 9)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type9);
+		else if (dm->rfe_type == 10)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type10);
+		else if (dm->rfe_type == 11)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type11);
+		else if (dm->rfe_type == 12)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type12);
+		else if (dm->rfe_type == 13)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type13);
+		else if (dm->rfe_type == 14)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type14);
+		else if (dm->rfe_type == 15)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type15);
+		else if (dm->rfe_type == 16)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type16);
+		else if (dm->rfe_type == 17)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type17);
+		else
+			READ_AND_CONFIG_MP(8822b, _txpowertrack);
+	}
+#endif
+
+#if RTL8197F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (dm->rfe_type == 0)
+			READ_AND_CONFIG_MP(8197f, _txpowertrack_type0);
+		else if (dm->rfe_type == 1)
+			READ_AND_CONFIG_MP(8197f, _txpowertrack_type1);
+		else
+			READ_AND_CONFIG_MP(8197f, _txpowertrack);
+	}
+#endif
+
+#if RTL8821C_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (dm->rfe_type == 0x5)
+			READ_AND_CONFIG(8821c, _txpowertrack_type0x28);
+		else if (dm->rfe_type == 0x4)
+			READ_AND_CONFIG(8821c, _txpowertrack_type0x20);
+		else
+			READ_AND_CONFIG(8821c, _txpowertrack);
+	}
+#endif
+
+	return HAL_STATUS_SUCCESS;
+}
+
+enum hal_status
+odm_config_bb_with_header_file(
+	struct dm_struct		*dm,
+	enum odm_bb_config_type		config_type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PMGNT_INFO		mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+#endif
+	enum hal_status	result = HAL_STATUS_SUCCESS;
+
+	/* 1 AP doesn't use PHYDM initialization in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8812a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8812a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 3 && dm->is_mp_chip)
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_asus);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			else if (mgnt_info->CustomerID == RT_CID_WNC_NEC && dm->is_mp_chip)
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_nec);
+#if RT_PLATFORM == PLATFORM_MACOSX
+			/*{1827}{1024} for BUFFALO power by rate table. Isaiah 2013-11-29*/
+			else if (mgnt_info->CustomerID == RT_CID_DNI_BUFFALO)
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_dni);
+			/* TP-Link T4UH, Isaiah 2015-03-16*/
+			else if (mgnt_info->CustomerID == RT_CID_TPLINK_HPWR) {
+				pr_debug("RT_CID_TPLINK_HPWR:: _PHY_REG_PG_TPLINK\n");
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_tplink);
+			}
+#endif
+#endif
+			else
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg);
+		} else if (config_type == CONFIG_BB_PHY_REG_MP)
+			READ_AND_CONFIG_MP(8812a, _phy_reg_mp);
+		else if (config_type == CONFIG_BB_AGC_TAB_DIFF) {
+			dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
+			/*AGC_TAB DIFF dont support FW offload*/
+			if ((*dm->channel >= 36)  && (*dm->channel  <= 64))
+				AGC_DIFF_CONFIG_MP(8812a, lb);
+			else if (*dm->channel >= 100)
+				AGC_DIFF_CONFIG_MP(8812a, hb);
+		}
+	}
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8821a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8821a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+			HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+			if ((hal_data->EEPROMSVID == 0x1043 && hal_data->EEPROMSMID == 0x207F))
+				READ_AND_CONFIG_MP(8821a, _phy_reg_pg_e202_sa);
+			else
+#endif
+#if (RT_PLATFORM == PLATFORM_MACOSX)
+				/*{1827}{1022} for BUFFALO power by rate table. Isaiah 2013-10-18*/
+				if (mgnt_info->CustomerID == RT_CID_DNI_BUFFALO) {
+					/*{1024} for BUFFALO power by rate table. (JP/US)*/
+					if (mgnt_info->ChannelPlan == RT_CHANNEL_DOMAIN_US_2G_CANADA_5G)
+						READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_us);
+					else
+						READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_jp);
+				} else
+#endif
+#endif
+					READ_AND_CONFIG_MP(8821a, _phy_reg_pg);
+		}
+	}
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8192e, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8192e, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8192e, _phy_reg_pg);
+	}
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8723d, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8723d, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8723d, _phy_reg_pg);
+	}
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8710b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8710b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8710b, _phy_reg_pg);
+	}
+#endif
+
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+
+	/* 1 All platforms support */
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8188e, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8188e, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8188e, _phy_reg_pg);
+	}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8723b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8723b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8723b, _phy_reg_pg);
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8814a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8814a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type0);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type2);				
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type3);		
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type4);		
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type5);		
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type8);
+			else
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg);
+		}
+		else if (config_type == CONFIG_BB_PHY_REG_MP)
+			READ_AND_CONFIG_MP(8814a, _phy_reg_mp);
+	}
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8703b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8703b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8703b, _phy_reg_pg);
+	}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8188f, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8188f, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8188f, _phy_reg_pg);
+	}
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8822b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8822b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type3);
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type4);
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type5);
+			else if (dm->rfe_type == 12)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type12);
+			else if (dm->rfe_type == 15)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type15);
+			else if (dm->rfe_type == 16)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type16);
+			else if (dm->rfe_type == 17)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type17);
+			else
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg);
+		}
+	}
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (config_type == CONFIG_BB_PHY_REG) {
+			READ_AND_CONFIG_MP(8197f, _phy_reg);
+			if (dm->cut_version == ODM_CUT_A)
+				phydm_phypara_a_cut(dm);
+		} else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8197f, _agc_tab);
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG(8821c, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB) {
+			READ_AND_CONFIG(8821c, _agc_tab);
+			/* According to RFEtype, choosing correct AGC table*/
+			if (dm->default_rf_set_8821c == SWITCH_TO_BTG)
+				AGC_DIFF_CONFIG_MP(8821c, btg);
+		} else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 0x5)
+				READ_AND_CONFIG(8821c, _phy_reg_pg_type0x28);
+			else
+				READ_AND_CONFIG(8821c, _phy_reg_pg);
+		} else if (config_type == CONFIG_BB_AGC_TAB_DIFF) {
+			dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
+			/*AGC_TAB DIFF dont support FW offload*/
+			if (dm->current_rf_set_8821c == SWITCH_TO_BTG)
+				AGC_DIFF_CONFIG_MP(8821c, btg);
+			else if (dm->current_rf_set_8821c == SWITCH_TO_WLG)
+				AGC_DIFF_CONFIG_MP(8821c, wlg);
+		} else if (config_type == CONFIG_BB_PHY_REG_MP)
+			READ_AND_CONFIG(8821c, _phy_reg_mp);
+	}
+#endif
+
+#if (RTL8195A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195A) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG(8195a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG(8195a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG(8195a, _phy_reg_pg);
+	}
+#endif
+
+	if (config_type == CONFIG_BB_PHY_REG || config_type == CONFIG_BB_AGC_TAB)
+		if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+			result = phydm_set_reg_by_fw(dm,
+								PHYDM_HALMAC_CMD_END,
+								0,
+								0,
+								0,
+								(enum rf_path)0,
+								0);
+			PHYDM_DBG(dm, ODM_COMP_INIT,
+				"phy param offload end!result = %d", result);
+		}
+
+	return result;
+}
+
+enum hal_status
+odm_config_mac_with_header_file(
+	struct dm_struct	*dm
+)
+{
+	enum hal_status	result = HAL_STATUS_SUCCESS;
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"===>odm_config_mac_with_header_file (%s)\n", (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		dm->support_platform, dm->support_interface, dm->board_type);
+
+	/* 1 AP doesn't use PHYDM initialization in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812)
+		READ_AND_CONFIG_MP(8812a, _mac_reg);
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821)
+		READ_AND_CONFIG_MP(8821a, _mac_reg);
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E)
+		READ_AND_CONFIG_MP(8192e, _mac_reg);
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D)
+		READ_AND_CONFIG_MP(8723d, _mac_reg);
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B)
+		READ_AND_CONFIG_MP(8710b, _mac_reg);
+#endif
+
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+	/* 1 All platforms support */
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		READ_AND_CONFIG_MP(8188e, _mac_reg);
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B)
+		READ_AND_CONFIG_MP(8723b, _mac_reg);
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A)
+		READ_AND_CONFIG_MP(8814a, _mac_reg);
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B)
+		READ_AND_CONFIG_MP(8703b, _mac_reg);
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F)
+		READ_AND_CONFIG_MP(8188f, _mac_reg);
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B)
+		READ_AND_CONFIG_MP(8822b, _mac_reg);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F)
+		READ_AND_CONFIG_MP(8197f, _mac_reg);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		READ_AND_CONFIG(8821c, _mac_reg);
+#endif
+
+#if (RTL8195A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195A)
+		READ_AND_CONFIG_MP(8195a, _mac_reg);
+#endif
+
+	if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+		result = phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_END,
+							0,
+							0,
+							0,
+							(enum rf_path)0,
+							0);
+		PHYDM_DBG(dm, ODM_COMP_INIT,
+			"mac param offload end!result = %d", result);
+	}
+
+	return result;
+}
+
+u32
+odm_get_hw_img_version(
+	struct dm_struct	*dm
+)
+{
+	u32  version = 0;
+
+	/* 1 AP doesn't use PHYDM initialization in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821)
+		version = GET_VERSION_MP(8821a, _mac_reg);
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E)
+		version = GET_VERSION_MP(8192e, _mac_reg);
+#endif
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812)
+		version = GET_VERSION_MP(8812a, _mac_reg);
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D)
+		version = GET_VERSION_MP(8723d, _mac_reg);
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B)
+		version = GET_VERSION_MP(8710b, _mac_reg);
+#endif
+
+#endif /* (DM_ODM_SUPPORT_TYPE != ODM_AP) */
+
+	/*1 All platforms support*/
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		version = GET_VERSION_MP(8188e, _mac_reg);
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B)
+		version = GET_VERSION_MP(8723b, _mac_reg);
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A)
+		version = GET_VERSION_MP(8814a, _mac_reg);
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B)
+		version = GET_VERSION_MP(8703b, _mac_reg);
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F)
+		version = GET_VERSION_MP(8188f, _mac_reg);
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B)
+		version = GET_VERSION_MP(8822b, _mac_reg);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F)
+		version = GET_VERSION_MP(8197f, _mac_reg);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		version = GET_VERSION(8821c, _mac_reg);
+#endif
+
+	return version;
+}
+
+
+u32
+query_phydm_trx_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_trx_capability_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_stbc_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_stbc_capability_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_ldpc_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_ldpc_capability_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_txbf_parameters(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_txbf_parameters_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_txbf_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_txbf_capability_8821c(dm);
+#endif
+
+	return value32;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_hwconfig.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_hwconfig.h
new file mode 100644
index 000000000000..a695f695fb95
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_hwconfig.h
@@ -0,0 +1,103 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__HALHWOUTSRC_H__
+#define __HALHWOUTSRC_H__
+
+
+/*--------------------------Define -------------------------------------------*/
+#define AGC_DIFF_CONFIG_MP(ic, band) (odm_read_and_config_mp_##ic##_agc_tab_diff(dm, array_mp_##ic##_agc_tab_diff_##band, \
+		      sizeof(array_mp_##ic##_agc_tab_diff_##band)/sizeof(u32)))
+#define AGC_DIFF_CONFIG_TC(ic, band) (odm_read_and_config_tc_##ic##_agc_tab_diff(dm, array_tc_##ic##_agc_tab_diff_##band, \
+		      sizeof(array_tc_##ic##_agc_tab_diff_##band)/sizeof(u32)))
+
+#define AGC_DIFF_CONFIG(ic, band) do {\
+		if (dm->is_mp_chip)\
+			AGC_DIFF_CONFIG_MP(ic, band);\
+		else\
+			AGC_DIFF_CONFIG_TC(ic, band);\
+	} while (0)
+
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+enum hal_status
+odm_config_rf_with_tx_pwr_track_header_file(
+	struct dm_struct		*dm
+);
+
+enum hal_status
+odm_config_rf_with_header_file(
+	struct dm_struct		*dm,
+	enum odm_rf_config_type		config_type,
+	u8						e_rf_path
+);
+
+enum hal_status
+odm_config_bb_with_header_file(
+	struct dm_struct	*dm,
+	enum odm_bb_config_type		config_type
+);
+
+enum hal_status
+odm_config_mac_with_header_file(
+	struct dm_struct	*dm
+);
+
+u32
+odm_get_hw_img_version(
+	struct dm_struct	*dm
+);
+
+
+u32
+query_phydm_trx_capability(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_stbc_capability(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_ldpc_capability(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_txbf_parameters(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_txbf_capability(
+	struct dm_struct					*dm
+);
+
+#endif /*#ifndef	__HALHWOUTSRC_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_interface.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_interface.c
new file mode 100644
index 000000000000..e12bac9b9745
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_interface.c
@@ -0,0 +1,1412 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/*
+ * ODM IO Relative API.
+ *   */
+
+u8
+odm_read_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	return	RTL_R8(reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_read_byte(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	return rtw_read8(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	return	PlatformEFIORead1Byte(adapter, reg_addr);
+#endif
+
+}
+
+
+u16
+odm_read_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	return	RTL_R16(reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_read_word(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	return rtw_read16(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	return	PlatformEFIORead2Byte(adapter, reg_addr);
+#endif
+
+}
+
+
+u32
+odm_read_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	return	RTL_R32(reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_read_dword(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	return rtw_read32(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	return	PlatformEFIORead4Byte(adapter, reg_addr);
+#endif
+
+}
+
+
+void
+odm_write_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u8			data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	RTL_W8(reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_write_byte(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	rtw_write8(adapter, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformEFIOWrite1Byte(adapter, reg_addr, data);
+#endif
+
+}
+
+
+void
+odm_write_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u16			data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	RTL_W16(reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_write_word(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	rtw_write16(adapter, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformEFIOWrite2Byte(adapter, reg_addr, data);
+#endif
+
+}
+
+
+void
+odm_write_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u32			data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	RTL_W32(reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_write_dword(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	rtw_write32(adapter, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformEFIOWrite4Byte(adapter, reg_addr, data);
+#endif
+
+}
+
+
+void
+odm_set_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	phy_set_bb_reg(dm->priv, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetBBReg((PADAPTER)dm->adapter, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_set_bbreg(rtlpriv->hw, reg_addr, bit_mask, data);
+#else
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
+#endif
+}
+
+
+u32
+odm_get_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return phy_query_bb_reg(dm->priv, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_QueryMacReg((PADAPTER)dm->adapter, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_get_bbreg(rtlpriv->hw, reg_addr, bit_mask);
+#else
+	return phy_query_mac_reg(dm->adapter, reg_addr, bit_mask);
+#endif
+}
+
+
+void
+odm_set_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	phy_set_bb_reg(dm->priv, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetBBReg((PADAPTER)dm->adapter, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_set_bbreg(rtlpriv->hw, reg_addr, bit_mask, data);
+#else
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
+#endif
+}
+
+
+u32
+odm_get_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return phy_query_bb_reg(dm->priv, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_QueryBBReg((PADAPTER)dm->adapter, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_get_bbreg(rtlpriv->hw, reg_addr, bit_mask);
+#else
+	return phy_query_bb_reg(dm->adapter, reg_addr, bit_mask);
+#endif
+}
+
+
+void
+odm_set_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask,
+	u32				data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	phy_set_rf_reg(dm->priv, e_rf_path, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetRFReg((PADAPTER)dm->adapter, e_rf_path, reg_addr, bit_mask, data);
+	ODM_delay_us(2);
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_set_rfreg(rtlpriv->hw, e_rf_path, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	phy_set_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask, data);
+#endif
+}
+
+u32
+odm_get_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return phy_query_rf_reg(dm->priv, e_rf_path, reg_addr, bit_mask, 1);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_QueryRFReg((PADAPTER)dm->adapter, e_rf_path, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_get_rfreg(rtlpriv->hw, e_rf_path, reg_addr, bit_mask);
+#else
+	return phy_query_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask);
+#endif
+}
+
+enum hal_status
+phydm_set_reg_by_fw(
+	struct dm_struct			*dm,
+	enum phydm_halmac_param	config_type,
+	u32	offset,
+	u32	data,
+	u32	mask,
+	enum rf_path	e_rf_path,
+	u32 delay_time
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	return HAL_MAC_Config_PHY_WriteNByte(dm,
+									config_type,
+									offset,
+									data,
+									mask,
+									e_rf_path,
+									delay_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "Not support for CE MAC80211 driver!\n");
+#else
+	return rtw_phydm_cfg_phy_para(dm,
+							config_type,
+							offset,
+							data,
+							mask,
+							e_rf_path,
+							delay_time);
+#endif
+#endif
+
+}
+
+
+/*
+ * ODM Memory relative API.
+ *   */
+void
+odm_allocate_memory(
+	struct dm_struct	*dm,
+	void **ptr,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	*ptr = kmalloc(length, GFP_ATOMIC);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	*ptr = kmalloc(length, GFP_ATOMIC);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	*ptr = rtw_zvmalloc(length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformAllocateMemory(adapter, ptr, length);
+#endif
+}
+
+/* length could be ignored, used to detect memory leakage. */
+void
+odm_free_memory(
+	struct dm_struct	*dm,
+	void		*ptr,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	kfree(ptr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	kfree(ptr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_vmfree(ptr, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	/* struct void*    adapter = dm->adapter; */
+	PlatformFreeMemory(ptr, length);
+#endif
+}
+
+void
+odm_move_memory(
+	struct dm_struct	*dm,
+	void		*dest,
+	void		*src,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	memcpy(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	memcpy(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_rtw_memcpy(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformMoveMemory(dest, src, length);
+#endif
+}
+
+void odm_memory_set(
+	struct dm_struct	*dm,
+	void		*pbuf,
+	s8		value,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	memset(pbuf, value, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	memset(pbuf, value, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_rtw_memset(pbuf, value, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformFillMemory(pbuf, length, value);
+#endif
+}
+s32 odm_compare_memory(
+	struct dm_struct		*dm,
+	void           *buf1,
+	void           *buf2,
+	u32          length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return memcmp(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	return memcmp(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return _rtw_memcmp(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PlatformCompareMemory(buf1, buf2, length);
+#endif
+}
+
+
+
+/*
+ * ODM MISC relative API.
+ *   */
+void
+odm_acquire_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	rtl_odm_acquirespinlock(rtlpriv, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void *adapter = dm->adapter;
+	rtw_odm_acquirespinlock(adapter, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformAcquireSpinLock(adapter, type);
+#endif
+}
+void
+odm_release_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	rtl_odm_releasespinlock(rtlpriv, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void *adapter = dm->adapter;
+	rtw_odm_releasespinlock(adapter, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformReleaseSpinLock(adapter, type);
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+/*
+ * Work item relative API. FOr MP driver only~!
+ *   */
+void
+odm_initialize_work_item(
+	struct dm_struct					*dm,
+	PRT_WORK_ITEM				p_rt_work_item,
+	RT_WORKITEM_CALL_BACK		rt_work_item_callback,
+	void						*context,
+	const char					*sz_id
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformInitializeWorkItem(adapter, p_rt_work_item, rt_work_item_callback, context, sz_id);
+#endif
+}
+
+
+void
+odm_start_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStartWorkItem(p_rt_work_item);
+#endif
+}
+
+
+void
+odm_stop_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStopWorkItem(p_rt_work_item);
+#endif
+}
+
+
+void
+odm_free_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformFreeWorkItem(p_rt_work_item);
+#endif
+}
+
+
+void
+odm_schedule_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformScheduleWorkItem(p_rt_work_item);
+#endif
+}
+
+
+boolean
+odm_is_work_item_scheduled(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PlatformIsWorkItemScheduled(p_rt_work_item);
+#endif
+}
+#endif
+
+
+/*
+ * ODM Timer relative API.
+ *   */
+
+void
+ODM_delay_ms(u32	ms)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_ms(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	mdelay(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_mdelay_os(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	delay_ms(ms);
+#endif
+}
+
+void
+ODM_delay_us(u32	us)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_us(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	udelay(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_udelay_os(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStallExecution(us);
+#endif
+}
+
+void
+ODM_sleep_ms(u32	ms)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_ms(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	msleep(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_msleep_os(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	delay_ms(ms);
+#endif
+}
+
+void
+ODM_sleep_us(u32	us)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_us(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	usleep_range(us, us + 1);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_usleep_os(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStallExecution(us);
+#endif
+}
+
+void
+odm_set_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer,
+	u32			ms_delay
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	mod_timer(timer, jiffies + RTL_MILISECONDS_TO_JIFFIES(ms_delay));
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	mod_timer(timer, jiffies + msecs_to_jiffies(ms_delay));
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_set_timer(timer, ms_delay); /* ms */
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformSetTimer(adapter, timer, ms_delay);
+#endif
+
+}
+
+void
+odm_initialize_timer(
+	struct dm_struct			*dm,
+	struct phydm_timer_list			*timer,
+	void	*call_back_func,
+	void				*context,
+	const char			*sz_id
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	init_timer(timer);
+	timer->function = call_back_func;
+	timer->data = (unsigned long)dm;
+	/*mod_timer(timer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	*/
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	init_timer(timer);
+	timer->function = call_back_func;
+	timer->data = (unsigned long)dm;
+	/*mod_timer(timer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	*/
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	struct _ADAPTER *adapter = dm->adapter;
+
+	_init_timer(timer, adapter->pnetdev, call_back_func, dm);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void *adapter = dm->adapter;
+
+	PlatformInitializeTimer(adapter, timer, (RT_TIMER_CALL_BACK)call_back_func, context, sz_id);
+#endif
+}
+
+
+void
+odm_cancel_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	del_timer(timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	del_timer(timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_cancel_timer_ex(timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void *adapter = dm->adapter;
+	PlatformCancelTimer(adapter, timer);
+#endif
+}
+
+
+void
+odm_release_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+	void *adapter = dm->adapter;
+
+	/* <20120301, Kordan> If the initilization fails, InitializeAdapterXxx will return regardless of InitHalDm.
+	 * Hence, uninitialized timers cause BSOD when the driver releases resources since the init fail. */
+	if (timer == 0) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "=====>odm_release_timer(), The timer is NULL! Please check it!\n");
+		return;
+	}
+
+	PlatformReleaseTimer(adapter, timer);
+#endif
+}
+
+
+u8
+phydm_trans_h2c_id(
+	struct dm_struct	*dm,
+	u8		phydm_h2c_id
+)
+{
+	u8 platform_h2c_id = phydm_h2c_id;
+
+	switch (phydm_h2c_id) {
+	/* 1 [0] */
+	case ODM_H2C_RSSI_REPORT:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type == ODM_RTL8188E)
+			platform_h2c_id = H2C_88E_RSSI_REPORT;
+		else if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_8814A_RSSI_REPORT;
+		else
+			platform_h2c_id = H2C_RSSI_REPORT;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+		platform_h2c_id = H2C_RSSI_SETTING;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
+			platform_h2c_id = H2C_88XX_RSSI_REPORT;
+		else
+#endif
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				platform_h2c_id = H2C_8812_RSSI_REPORT;
+			else
+#endif
+			{}
+#endif
+
+		break;
+
+	/* 1 [3] */
+	case ODM_H2C_WIFI_CALIBRATION:
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		platform_h2c_id = H2C_WIFI_CALIBRATION;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (RTL8723B_SUPPORT == 1)
+		platform_h2c_id = H2C_8723B_BT_WLAN_CALIBRATION;
+#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#endif
+		break;
+
+
+	/* 1 [4] */
+	case ODM_H2C_IQ_CALIBRATION:
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		platform_h2c_id = H2C_IQ_CALIBRATION;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		platform_h2c_id = H2C_8812_IQ_CALIBRATION;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#endif
+
+		break;
+	/* 1 [5] */
+	case ODM_H2C_RA_PARA_ADJUST:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B))
+			platform_h2c_id = H2C_8814A_RA_PARA_ADJUST;
+		else
+			platform_h2c_id = H2C_RA_PARA_ADJUST;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
+#elif ((RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
+		platform_h2c_id = H2C_RA_PARA_ADJUST;
+#elif (RTL8192E_SUPPORT == 1)
+		platform_h2c_id = H2C_8192E_RA_PARA_ADJUST;
+#elif (RTL8723B_SUPPORT == 1)
+		platform_h2c_id = H2C_8723B_RA_PARA_ADJUST;
+#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
+			platform_h2c_id = H2C_88XX_RA_PARA_ADJUST;
+		else
+#endif
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
+			else
+#endif
+			{}
+#endif
+
+		break;
+
+
+	/* 1 [6] */
+	case PHYDM_H2C_DYNAMIC_TX_PATH:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_8814A_DYNAMIC_TX_PATH;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (RTL8814A_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_DYNAMIC_TX_PATH;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (RTL8814A_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_88XX_DYNAMIC_TX_PATH;
+#endif
+
+#endif
+
+		break;
+
+	/* [7]*/
+	case PHYDM_H2C_FW_TRACE_EN:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B))
+			platform_h2c_id = H2C_8814A_FW_TRACE_EN;
+		else
+			platform_h2c_id = H2C_FW_TRACE_EN;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+		platform_h2c_id = 0x49;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
+			platform_h2c_id  = H2C_88XX_FW_TRACE_EN;
+		else
+#endif
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				platform_h2c_id = H2C_8812_FW_TRACE_EN;
+			else
+#endif
+			{}
+
+#endif
+
+		break;
+
+	case PHYDM_H2C_TXBF:
+#if ((RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1))
+		platform_h2c_id  = 0x41;	/*H2C_TxBF*/
+#endif
+		break;
+
+	case PHYDM_H2C_MU:
+#if (RTL8822B_SUPPORT == 1)
+		platform_h2c_id  = 0x4a;	/*H2C_MU*/
+#endif
+		break;
+
+	default:
+		platform_h2c_id = phydm_h2c_id;
+		break;
+	}
+
+	return platform_h2c_id;
+
+}
+
+/*ODM FW relative API.*/
+
+void
+odm_fill_h2c_cmd(
+	struct dm_struct		*dm,
+	u8			phydm_h2c_id,
+	u32			cmd_len,
+	u8			*cmd_buffer
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+#else
+	PADAPTER	adapter = (PADAPTER)dm->adapter;
+#endif
+	u8		h2c_id = phydm_trans_h2c_id(dm, phydm_h2c_id);
+
+	PHYDM_DBG(dm, DBG_RA, "[H2C]  h2c_id=((0x%x))\n", h2c_id);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	if (dm->support_ic_type == ODM_RTL8188E)	{
+		if (!dm->ra_support88e)
+			FillH2CCmd88E(adapter, h2c_id, cmd_len, cmd_buffer);
+	} else if (dm->support_ic_type == ODM_RTL8814A)
+		FillH2CCmd8814A(adapter, h2c_id, cmd_len, cmd_buffer);
+	else if (dm->support_ic_type == ODM_RTL8822B)
+		FillH2CCmd8822B(adapter, h2c_id, cmd_len, cmd_buffer);
+	else
+		FillH2CCmd(adapter, h2c_id, cmd_len, cmd_buffer);
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+	#ifdef DM_ODM_CE_MAC80211
+	rtlpriv->cfg->ops->fill_h2c_cmd(rtlpriv->hw, h2c_id,cmd_len, cmd_buffer);
+	#else
+	rtw_hal_fill_h2c_cmd(adapter, h2c_id, cmd_len, cmd_buffer);
+	#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812) {
+		fill_h2c_cmd8812(dm->priv, h2c_id, cmd_len, cmd_buffer);
+	} else
+	#endif
+	{
+		GET_HAL_INTERFACE(dm->priv)->fill_h2c_cmd_handler(dm->priv, h2c_id, cmd_len, cmd_buffer);
+	}
+#endif
+}
+
+u8
+phydm_c2H_content_parsing(
+	void			*dm_void,
+	u8			c2h_cmd_id,
+	u8			c2h_cmd_len,
+	u8			*tmp_buf
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+#endif
+	u8	extend_c2h_sub_id = 0;
+	u8	find_c2h_cmd = true;
+	
+	if ((c2h_cmd_len > 12) || (c2h_cmd_len == 0)) {
+		pr_debug("[Warning] Error C2H ID=%d, len=%d\n", c2h_cmd_id, c2h_cmd_len);
+		
+		find_c2h_cmd = false;
+		return find_c2h_cmd;
+	}
+	
+	switch (c2h_cmd_id) {
+	case PHYDM_C2H_DBG:
+		phydm_fw_trace_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_RA_RPT:
+		phydm_c2h_ra_report_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_RA_PARA_RPT:
+		odm_c2h_ra_para_report_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_DYNAMIC_TX_PATH_RPT:
+		if (dm->support_ic_type & (ODM_RTL8814A))
+			phydm_c2h_dtp_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_IQK_FINISH:
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+		if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821)) {
+			RT_TRACE(COMP_MP, DBG_LOUD, ("== FW IQK Finish ==\n"));
+			odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+			dm->rf_calibrate_info.is_iqk_in_progress = false;
+			odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+			dm->rf_calibrate_info.iqk_progressing_time = 0;
+			dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(dm, dm->rf_calibrate_info.iqk_start_time);
+		}
+
+#endif
+		break;
+
+	case PHYDM_C2H_CLM_MONITOR:
+		phydm_clm_c2h_report_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_DBG_CODE:
+		phydm_fw_trace_handler_code(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_EXTEND:
+		extend_c2h_sub_id = tmp_buf[0];
+		if (extend_c2h_sub_id == PHYDM_EXTEND_C2H_DBG_PRINT)
+			phydm_fw_trace_handler_8051(dm, tmp_buf, c2h_cmd_len);
+
+		break;
+
+	default:
+		find_c2h_cmd = false;
+		break;
+	}
+
+	return find_c2h_cmd;
+
+}
+
+u64
+odm_get_current_time(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return (u64)rtw_get_current_time();
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	return jiffies;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return rtw_get_current_time();
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return  PlatformGetCurrentTime();
+#endif
+}
+
+u64
+odm_get_progressing_time(
+	struct dm_struct		*dm,
+	u64			start_time
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return rtw_get_passing_time_ms((u32)start_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	return jiffies_to_msecs(jiffies - start_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return rtw_get_passing_time_ms((systime)start_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return ((PlatformGetCurrentTime() - start_time) >> 10);
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE)) && !defined(DM_ODM_CE_MAC80211)
+
+void
+phydm_set_hw_reg_handler_interface (
+	struct dm_struct		*dm,
+	u8				RegName,
+	u8				*val
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
+	struct _ADAPTER *adapter = (PADAPTER)dm->adapter;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	((PADAPTER)adapter)->HalFunc.SetHwRegHandler(adapter, RegName, val);
+#else
+	adapter->hal_func.set_hw_reg_handler(adapter, RegName, val);
+#endif
+
+#endif
+
+}
+
+void
+phydm_get_hal_def_var_handler_interface (
+	struct dm_struct		*dm,
+	enum _HAL_DEF_VARIABLE		e_variable,
+	void						*value
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
+	struct _ADAPTER *adapter = (PADAPTER)dm->adapter;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	adapter->HalFunc.GetHalDefVarHandler(adapter, e_variable, value);
+#else
+	adapter->hal_func.get_hal_def_var_handler(adapter, e_variable, value);
+#endif
+
+#endif
+}
+
+#endif
+
+void
+odm_set_tx_power_index_by_rate_section (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				channel,
+	u8				rate_section
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetTxPowerIndexByRateSection((PADAPTER)dm->adapter, path, channel, rate_section);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	phy_set_tx_power_index_by_rs((PADAPTER)dm->adapter, channel, path, rate_section);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	phy_set_tx_power_index_by_rate_section(dm->adapter, path, channel, rate_section);
+#endif
+}
+
+
+u8
+odm_get_tx_power_index (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				tx_rate,
+	u8				band_width,
+	u8				channel
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_GetTxPowerIndex((PADAPTER)dm->adapter, path, tx_rate, (CHANNEL_WIDTH)band_width, channel);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+
+	return phy_get_tx_power_index(adapter, (enum rf_path)path, tx_rate, band_width, channel);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return phy_get_tx_power_index(dm->adapter, path, tx_rate, band_width, channel);
+#endif
+}
+
+
+
+u8
+odm_efuse_one_byte_read(
+	struct dm_struct	*dm,
+	u16			addr,
+	u8			*data,
+	boolean		b_pseu_do_test
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return (u8)EFUSE_OneByteRead((PADAPTER)dm->adapter, addr, data, b_pseu_do_test);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+
+	return rtl_efuse_onebyte_read(adapter, addr, data, b_pseu_do_test);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return efuse_onebyte_read(dm->adapter, addr, data, b_pseu_do_test);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	/*ReadEFuseByte(dm->priv, addr, data);*/
+	/*return true;*/
+#endif
+}
+
+
+
+void
+odm_efuse_logical_map_read(
+	struct	dm_struct	*dm,
+	u8	type,
+	u16	offset,
+	u32	*data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	EFUSE_ShadowRead((PADAPTER)dm->adapter, type, offset, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+
+	rtl_efuse_logical_map_read(adapter, type, offset, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	efuse_logical_map_read(dm->adapter, type, offset, data);
+#endif
+}
+
+enum hal_status
+odm_iq_calibrate_by_fw(
+	struct dm_struct	*dm,
+	u8 clear,
+	u8 segment
+	)
+{
+	enum hal_status iqk_result = HAL_STATUS_FAILURE;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct _ADAPTER *adapter = (PADAPTER)dm->adapter;
+	
+	if (HAL_MAC_FWIQK_Trigger(&GET_HAL_MAC_INFO(adapter), clear, segment) == 0)
+		iqk_result = HAL_STATUS_SUCCESS;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+	iqk_result = rtl_phydm_fw_iqk(adapter, clear, segment);
+#else
+	iqk_result = rtw_phydm_fw_iqk(dm, clear, segment);
+#endif
+#endif
+	return iqk_result;
+}
+
+void
+odm_cmn_info_ptr_array_hook(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	u16			index,
+	void			*value
+)
+{
+	switch	(cmn_info) {
+	/*Dynamic call by reference pointer.	*/
+	case	ODM_CMNINFO_STA_STATUS:
+		dm->odm_sta_info[index] = (struct sta_info *)value;
+		break;
+	/* To remove the compiler warning, must add an empty default statement to handle the other values. */
+	default:
+		/* do nothing */
+		break;
+	}
+
+}
+
+void
+phydm_cmn_sta_info_hook(
+	struct dm_struct		*dm,
+	u8			mac_id,
+	struct cmn_sta_info *pcmn_sta_info
+)
+{
+	dm->phydm_sta_info[mac_id] = pcmn_sta_info;
+
+	if (is_sta_active(pcmn_sta_info))
+		dm->phydm_macid_table[pcmn_sta_info->mac_id] = mac_id;
+}
+
+void
+phydm_macid2sta_idx_table(
+	struct dm_struct	*dm,
+	u8			entry_idx,
+	struct cmn_sta_info	*pcmn_sta_info
+)
+{
+	if (is_sta_active(pcmn_sta_info))
+		dm->phydm_macid_table[pcmn_sta_info->mac_id] = entry_idx;
+}
+
+void
+phydm_add_interrupt_mask_handler(
+	struct dm_struct		*dm,
+	u8							interrupt_type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	#if IS_EXIST_PCI || IS_EXIST_EMBEDDED
+	GET_HAL_INTERFACE(priv)->AddInterruptMaskHandler(priv, interrupt_type);
+	#endif
+	
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#endif
+}
+
+void
+phydm_enable_rx_related_interrupt_handler(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	#if IS_EXIST_PCI || IS_EXIST_EMBEDDED
+	GET_HAL_INTERFACE(priv)->EnableRxRelatedInterruptHandler(priv);
+	#endif
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#endif
+}
+
+#if 0
+boolean
+phydm_get_txbf_en(
+	struct dm_struct		*dm,
+	u16							mac_id,
+	u8							i
+)
+{
+	boolean txbf_en = false;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && !defined(DM_ODM_CE_MAC80211)
+
+	#ifdef CONFIG_BEAMFORMING
+	enum beamforming_cap beamform_cap;
+	void *adapter = dm->adapter;
+	#if (BEAMFORMING_SUPPORT == 1)
+	beamform_cap =
+	phydm_beamforming_get_entry_beam_cap_by_mac_id(dm, mac_id);
+	#else/*for drv beamforming*/
+	beamform_cap =
+	beamforming_get_entry_beam_cap_by_mac_id(&adapter->mlmepriv, mac_id);
+	#endif
+	if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
+		txbf_en = true;
+	else
+		txbf_en = false;
+	#endif /*#ifdef CONFIG_BEAMFORMING*/
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	#if (BEAMFORMING_SUPPORT == 1)
+	u8 idx = 0xff;
+	boolean act_bfer = false;
+	BEAMFORMING_CAP beamform_cap = BEAMFORMING_CAP_NONE;
+	PRT_BEAMFORMING_ENTRY	entry = NULL;
+	struct rtl8192cd_priv *priv			= dm->priv;
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+
+	dm_bdc_table->num_txbfee_client = 0;
+	dm_bdc_table->num_txbfer_client = 0;
+	#endif
+	#endif
+
+	#if (BEAMFORMING_SUPPORT == 1)
+	beamform_cap = Beamforming_GetEntryBeamCapByMacId(priv, mac_id);
+	entry = Beamforming_GetEntryByMacId(priv, mac_id, &idx);
+	if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) {
+		if (entry->Sounding_En)
+			txbf_en = true;
+		else
+			txbf_en = false;
+		act_bfer = true;
+	}
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*BDC*/
+	if (act_bfer == true) {
+		dm_bdc_table->w_bfee_client[i] = true; /* AP act as BFer */
+		dm_bdc_table->num_txbfee_client++;
+	} else
+		dm_bdc_table->w_bfee_client[i] = false; /* AP act as BFer */
+	
+	if (beamform_cap & (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP_VHT_SU)) {
+		dm_bdc_table->w_bfer_client[i] = true; /* AP act as BFee */
+		dm_bdc_table->num_txbfer_client++;
+	} else
+		dm_bdc_table->w_bfer_client[i] = false; /* AP act as BFer */
+
+	#endif
+	#endif
+
+#endif
+	return txbf_en;
+
+}
+#endif
+
+void
+phydm_iqk_wait(
+	struct dm_struct		*dm,
+	u32		timeout
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "Not support for CE MAC80211 driver!\n");
+#else
+	void		*adapter = dm->adapter;
+
+	rtl8812_iqk_wait(adapter, timeout);
+#endif
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_interface.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_interface.h
new file mode 100644
index 000000000000..04ff7d4cec1d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_interface.h
@@ -0,0 +1,526 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__ODM_INTERFACE_H__
+#define __ODM_INTERFACE_H__
+
+#define INTERFACE_VERSION	"1.2"		/*2017.05.03  YuChen add phy param offload HAL MAC API*/
+
+#define pdm_set_reg	odm_set_bb_reg
+
+/*=========== Constant/Structure/Enum/... Define*/
+
+enum phydm_h2c_cmd {
+	PHYDM_H2C_RA_MASK		= 0x40,
+	PHYDM_H2C_TXBF			= 0x41,
+	ODM_H2C_RSSI_REPORT		= 0x42,
+	ODM_H2C_IQ_CALIBRATION	= 0x45,
+	PHYDM_RA_MASK_ABOVE_3SS = 0x46,
+	ODM_H2C_RA_PARA_ADJUST	= 0x47,
+	PHYDM_H2C_DYNAMIC_TX_PATH = 0x48,
+	PHYDM_H2C_FW_TRACE_EN	= 0x49,
+	ODM_H2C_WIFI_CALIBRATION	= 0x6d,
+	PHYDM_H2C_MU				= 0x4a,
+	PHYDM_H2C_FW_GENERAL_INIT = 0x4c,
+	PHYDM_H2C_FW_CLM_MNTR = 0x4d,
+	ODM_MAX_H2CCMD
+};
+
+enum phydm_c2h_evt {
+	PHYDM_C2H_DBG = 0,
+	PHYDM_C2H_LB = 1,
+	PHYDM_C2H_XBF = 2,
+	PHYDM_C2H_TX_REPORT = 3,
+	PHYDM_C2H_INFO = 9,
+	PHYDM_C2H_BT_MP = 11,
+	PHYDM_C2H_RA_RPT = 12,
+	PHYDM_C2H_RA_PARA_RPT = 14,
+	PHYDM_C2H_DYNAMIC_TX_PATH_RPT = 15,
+	PHYDM_C2H_IQK_FINISH = 17, /*0x11*/
+	PHYDM_C2H_CLM_MONITOR = 0x2a,
+	PHYDM_C2H_DBG_CODE = 0xFE,
+	PHYDM_C2H_EXTEND = 0xFF,
+};
+
+enum phydm_extend_c2h_evt {
+	PHYDM_EXTEND_C2H_DBG_PRINT = 0
+
+};
+
+enum phydm_halmac_param {
+	PHYDM_HALMAC_CMD_MAC_W8 = 0,
+	PHYDM_HALMAC_CMD_MAC_W16 = 1,
+	PHYDM_HALMAC_CMD_MAC_W32 = 2,
+	PHYDM_HALMAC_CMD_BB_W8,
+	PHYDM_HALMAC_CMD_BB_W16,
+	PHYDM_HALMAC_CMD_BB_W32,
+	PHYDM_HALMAC_CMD_RF_W,
+	PHYDM_HALMAC_CMD_DELAY_US,
+	PHYDM_HALMAC_CMD_DELAY_MS,
+	PHYDM_HALMAC_CMD_END = 0XFF,
+};
+
+/*=========== Macro Define*/
+
+#define _reg_all(_name)			ODM_##_name
+#define _reg_ic(_name, _ic)		ODM_##_name##_ic
+#define _bit_all(_name)			BIT_##_name
+#define _bit_ic(_name, _ic)		BIT_##_name##_ic
+
+/* _cat: implemented by Token-Pasting Operator. */
+#if 0
+#define _cat(_name, _ic_type, _func)								\
+	(\
+	 _func##_all(_name)										\
+	)
+#endif
+
+/*===================================
+
+#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
+
+#ifdef __ECOS
+#define _rtk_cat(_name, _ic_type, _func)		\
+	(\
+	 ((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) :		\
+	 _func##_11AC(_name)	\
+	)
+#else
+
+#define _cat(_name, _ic_type, _func)									\
+	(\
+	 ((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) :		\
+	 _func##_11AC(_name)									\
+	)
+#endif
+/*
+ * only sample code
+ *#define _cat(_name, _ic_type, _func)									\
+ *	(															\
+ *		((_ic_type) & ODM_RTL8188E) ? _func##_ic(_name, _8188E) :		\
+ *		_func##_ic(_name, _8195)									\
+ *	)
+ */
+
+/* _name: name of register or bit.
+ * Example: "ODM_REG(R_A_AGC_CORE1, dm)"
+ * gets "ODM_R_A_AGC_CORE1" or "ODM_R_A_AGC_CORE1_8192C", depends on support_ic_type. */
+#ifdef __ECOS
+	#define ODM_REG(_name, _pdm_odm)	_rtk_cat(_name, _pdm_odm->support_ic_type, _reg)
+	#define ODM_BIT(_name, _pdm_odm)	_rtk_cat(_name, _pdm_odm->support_ic_type, _bit)
+#else
+	#define ODM_REG(_name, _pdm_odm)	_cat(_name, _pdm_odm->support_ic_type, _reg)
+	#define ODM_BIT(_name, _pdm_odm)	_cat(_name, _pdm_odm->support_ic_type, _bit)
+#endif
+
+/*
+ * =========== Extern Variable ??? It should be forbidden.
+ *   */
+
+
+/*
+ * =========== EXtern Function Prototype
+ *   */
+
+
+u8
+odm_read_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+);
+
+u16
+odm_read_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+);
+
+u32
+odm_read_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+);
+
+void
+odm_write_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u8			data
+);
+
+void
+odm_write_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u16			data
+);
+
+void
+odm_write_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u32			data
+);
+
+void
+odm_set_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+);
+
+u32
+odm_get_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+);
+
+void
+odm_set_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+);
+
+u32
+odm_get_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+);
+
+void
+odm_set_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask,
+	u32				data
+);
+
+u32
+odm_get_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask
+);
+
+
+/*
+ * Memory Relative Function.
+ *   */
+void
+odm_allocate_memory(
+	struct dm_struct	*dm,
+	void **ptr,
+	u32		length
+);
+void
+odm_free_memory(
+	struct dm_struct	*dm,
+	void		*ptr,
+	u32		length
+);
+
+void
+odm_move_memory(
+	struct dm_struct	*dm,
+	void		*dest,
+	void		*src,
+	u32		length
+);
+
+s32 odm_compare_memory(
+	struct dm_struct	*dm,
+	void           *buf1,
+	void           *buf2,
+	u32          length
+);
+
+void odm_memory_set(
+	struct dm_struct	*dm,
+	void	*pbuf,
+	s8	value,
+	u32	length
+);
+
+/*
+ * ODM MISC-spin lock relative API.
+ *   */
+void
+odm_acquire_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+);
+
+void
+odm_release_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+/*
+ * ODM MISC-workitem relative API.
+ *   */
+void
+odm_initialize_work_item(
+	struct dm_struct					*dm,
+	PRT_WORK_ITEM				p_rt_work_item,
+	RT_WORKITEM_CALL_BACK		rt_work_item_callback,
+	void						*context,
+	const char					*sz_id
+);
+
+void
+odm_start_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+void
+odm_stop_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+void
+odm_free_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+void
+odm_schedule_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+boolean
+odm_is_work_item_scheduled(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+#endif
+
+/*
+ * ODM Timer relative API.
+ *   */
+void
+ODM_delay_ms(u32	ms);
+
+void
+ODM_delay_us(u32	us);
+
+void
+ODM_sleep_ms(u32	ms);
+
+void
+ODM_sleep_us(u32	us);
+
+void
+odm_set_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer,
+	u32			ms_delay
+);
+
+void
+odm_initialize_timer(
+	struct dm_struct			*dm,
+	struct phydm_timer_list			*timer,
+	void	*call_back_func,
+	void				*context,
+	const char			*sz_id
+);
+
+void
+odm_cancel_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_release_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+);
+
+/*ODM FW relative API.*/
+
+
+enum hal_status
+phydm_set_reg_by_fw(
+	struct dm_struct			*dm,
+	enum phydm_halmac_param	config_type,
+	u32	offset,
+	u32	data,
+	u32	mask,
+	enum rf_path	e_rf_path,
+	u32 delay_time
+);
+
+void
+odm_fill_h2c_cmd(
+	struct dm_struct		*dm,
+	u8			element_id,
+	u32			cmd_len,
+	u8			*cmd_buffer
+);
+
+u8
+phydm_c2H_content_parsing(
+	void			*dm_void,
+	u8			c2h_cmd_id,
+	u8			c2h_cmd_len,
+	u8			*tmp_buf
+);
+
+u64
+odm_get_current_time(
+	struct dm_struct		*dm
+);
+u64
+odm_get_progressing_time(
+	struct dm_struct		*dm,
+	u64			start_time
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE)) && !defined(DM_ODM_CE_MAC80211)
+
+void
+phydm_set_hw_reg_handler_interface (
+	struct dm_struct		*dm,
+	u8				reg_Name,
+	u8				*val
+	);
+
+void
+phydm_get_hal_def_var_handler_interface (
+	struct dm_struct		*dm,
+	enum _HAL_DEF_VARIABLE		e_variable,
+	void						*value
+	);
+
+#endif
+
+void
+odm_set_tx_power_index_by_rate_section (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				channel,
+	u8				rate_section
+);
+
+u8
+odm_get_tx_power_index (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				tx_rate,
+	u8				band_width,
+	u8				channel
+);
+
+u8
+odm_efuse_one_byte_read(
+	struct dm_struct	*dm,
+	u16			addr,
+	u8			*data,
+	boolean		b_pseu_do_test
+);
+
+void
+odm_efuse_logical_map_read(
+	struct	dm_struct	*dm,
+	u8	type,
+	u16	offset,
+	u32	*data
+);
+
+enum hal_status
+odm_iq_calibrate_by_fw(
+	struct dm_struct	*dm,
+	u8 clear,
+	u8 segment
+);
+
+void
+odm_cmn_info_ptr_array_hook(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	u16			index,
+	void			*value
+);
+
+void
+phydm_cmn_sta_info_hook(
+	struct dm_struct		*dm,
+	u8			index,
+	struct cmn_sta_info *pcmn_sta_info
+);
+
+void
+phydm_macid2sta_idx_table(
+	struct dm_struct	*dm,
+	u8			entry_idx,
+	struct cmn_sta_info	*pcmn_sta_info
+);
+
+void
+phydm_add_interrupt_mask_handler(
+	struct dm_struct		*dm,
+	u8							interrupt_type
+);
+
+void
+phydm_enable_rx_related_interrupt_handler(
+	struct dm_struct		*dm
+);
+
+#if 0
+boolean
+phydm_get_txbf_en(
+	struct dm_struct		*dm,
+	u16		mac_id,
+	u8		i
+);
+#endif
+
+void
+phydm_iqk_wait(
+	struct dm_struct		*dm,
+	u32		timeout
+);
+#endif /* __ODM_INTERFACE_H__ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_math_lib.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_math_lib.c
new file mode 100644
index 000000000000..16480f6c025c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_math_lib.c
@@ -0,0 +1,179 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+const u16 db_invert_table[12][8] = {
+	{	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}
+};
+
+
+/*Y = 10*log(X)*/
+s32
+odm_pwdb_conversion(
+	s32 X,
+	u32 total_bit,
+	u32 decimal_bit
+)
+{
+	s32 Y, integer = 0, decimal = 0;
+	u32 i;
+
+	if (X == 0)
+		X = 1; /* log2(x), x can't be 0 */
+
+	for (i = (total_bit - 1); i > 0; i--) {
+		if (X & BIT(i)) {
+			integer = i;
+			if (i > 0)
+				decimal = (X & BIT(i - 1)) ? 2 : 0; /* decimal is 0.5dB*3=1.5dB~=2dB */
+			break;
+		}
+	}
+
+	Y = 3 * (integer - decimal_bit) + decimal; /* 10*log(x)=3*log2(x), */
+
+	return Y;
+}
+
+s32
+odm_sign_conversion(
+	s32 value,
+	u32 total_bit
+)
+{
+	if (value & BIT(total_bit - 1))
+		value -= BIT(total_bit);
+	
+	return value;
+}
+
+void
+phydm_seq_sorting(
+	void	*dm_void,
+	u32	*value,
+	u32	*rank_idx,
+	u32	*idx_out,
+	u8	seq_length
+)
+{
+	u8		i = 0, j = 0;
+	u32		tmp_a, tmp_b;
+	u32		tmp_idx_a, tmp_idx_b;
+
+	for (i = 0; i < seq_length; i++) {
+		rank_idx[i] = i;
+		/**/
+	}
+
+	for (i = 0; i < (seq_length - 1); i++) {
+		for (j = 0; j < (seq_length - 1 - i); j++) {
+			tmp_a = value[j];
+			tmp_b = value[j + 1];
+
+			tmp_idx_a = rank_idx[j];
+			tmp_idx_b = rank_idx[j + 1];
+
+			if (tmp_a < tmp_b) {
+				value[j] = tmp_b;
+				value[j + 1] = tmp_a;
+
+				rank_idx[j] = tmp_idx_b;
+				rank_idx[j + 1] = tmp_idx_a;
+			}
+		}
+	}
+
+	for (i = 0; i < seq_length; i++) {
+		idx_out[rank_idx[i]] = i + 1;
+		/**/
+	}
+}
+
+u32
+odm_convert_to_db(
+	u32	value)
+{
+	u8 i;
+	u8 j;
+	u32 dB;
+
+	value = value & 0xFFFF;
+
+	for (i = 0; i < 12; i++) {
+		if (value <= db_invert_table[i][7])
+			break;
+	}
+
+	if (i >= 12) {
+		return 96;	/* maximum 96 dB */
+	}
+
+	for (j = 0; j < 8; j++) {
+		if (value <= db_invert_table[i][j])
+			break;
+	}
+
+	dB = (i << 3) + j + 1;
+
+	return dB;
+}
+
+u32
+odm_convert_to_linear(
+	u32	value)
+{
+	u8 i;
+	u8 j;
+	u32 linear;
+
+	/* 1dB~96dB */
+
+	value = value & 0xFF;
+
+	i = (u8)((value - 1) >> 3);
+	j = (u8)(value - 1) - (i << 3);
+
+	linear = db_invert_table[i][j];
+
+	return linear;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_math_lib.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_math_lib.h
new file mode 100644
index 000000000000..80124f9e52fc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_math_lib.h
@@ -0,0 +1,87 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_MATH_LIB_H__
+#define    __PHYDM_MATH_LIB_H__
+
+#define AUTO_MATH_LIB_VERSION	"1.0"		/* 2017.06.06*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+s32
+odm_pwdb_conversion(
+	s32 X,
+	u32 total_bit,
+	u32 decimal_bit
+);
+
+s32
+odm_sign_conversion(
+	s32 value,
+	u32 total_bit
+);
+
+void
+phydm_seq_sorting(
+	void	*dm_void,
+	u32	*value,
+	u32	*rank_idx,
+	u32	*idx_out,
+	u8	seq_length
+);
+
+u32 
+odm_convert_to_db(
+	u32	 value
+);
+
+u32
+odm_convert_to_linear(
+	u32	value
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_noisemonitor.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_noisemonitor.c
new file mode 100644
index 000000000000..1034167cfbd0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_noisemonitor.c
@@ -0,0 +1,427 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* *************************************************
+ * This function is for inband noise test utility only
+ * To obtain the inband noise level(dbm), do the following.
+ * 1. disable DIG and Power Saving
+ * 2. Set initial gain = 0x1a
+ * 3. Stop updating idle time pwer report (for driver read)
+ *	- 0x80c[25]
+ *
+ * ************************************************* */
+
+#define VALID_CNT				5
+
+void phydm_set_noise_data_sum(struct noise_level *noise_data, u8 max_rf_path)
+{
+	u8 rf_path;
+
+	for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+		if (noise_data->valid_cnt[rf_path])
+			noise_data->sum[rf_path] /= noise_data->valid_cnt[rf_path];
+		else
+			noise_data->sum[rf_path]  = 0;
+	}
+}
+
+s16 odm_inband_noise_monitor_n_series(struct dm_struct	*dm, u8 is_pause_dig, u8 igi_value, u32 max_time)
+{
+	u32				tmp4b;
+	u8				max_rf_path = 0, rf_path;
+	u8				reg_c50, reg_c58, valid_done = 0;
+	struct noise_level		noise_data;
+	u64	start  = 0, func_start = 0,	func_end = 0;
+
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
+
+	if ((dm->rf_type == RF_1T2R) || (dm->rf_type == RF_2T2R))
+		max_rf_path = 2;
+	else
+		max_rf_path = 1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "odm_DebugControlInbandNoise_Nseries() ==>\n");
+
+	odm_memory_set(dm, &noise_data, 0, sizeof(struct noise_level));
+	/* step 1. Disable DIG && Set initial gain. */
+
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	/* step 3. Get noise power level */
+	start = odm_get_current_time(dm);
+	while (1) {
+		/* Stop updating idle time pwer report (for driver read) */
+		odm_set_bb_reg(dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 1);
+
+		/* Read Noise Floor Report */
+		tmp4b = odm_get_bb_reg(dm, 0x8f8, MASKDWORD);
+
+		/* update idle time pwer report per 5us */
+		odm_set_bb_reg(dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 0);
+
+		ODM_delay_us(5);
+
+		noise_data.value[RF_PATH_A] = (u8)(tmp4b & 0xff);
+		noise_data.value[RF_PATH_B]  = (u8)((tmp4b & 0xff00) >> 8);
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			noise_data.sval[rf_path] = (s8)noise_data.value[rf_path];
+			noise_data.sval[rf_path] /= 2;
+		}
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			if (noise_data.valid_cnt[rf_path] >= VALID_CNT)
+				continue;
+
+			noise_data.valid_cnt[rf_path]++;
+			noise_data.sum[rf_path] += noise_data.sval[rf_path];
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "rf_path:%d Valid sval = %d\n", rf_path, noise_data.sval[rf_path]);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d,\n", noise_data.sum[rf_path]);
+			if (noise_data.valid_cnt[rf_path] == VALID_CNT)
+				valid_done++;
+		}
+		if ((valid_done == max_rf_path) || (odm_get_progressing_time(dm, start) > max_time)) {
+			phydm_set_noise_data_sum(&noise_data, max_rf_path);
+			break;
+		}
+	}
+	reg_c50 = (u8)odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKBYTE0);
+	reg_c50 &= ~BIT(7);
+	dm->noise_level.noise[RF_PATH_A] = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
+	dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_A];
+
+	if (max_rf_path == 2) {
+		reg_c58 = (u8)odm_get_bb_reg(dm, REG_OFDM_0_XB_AGC_CORE1, MASKBYTE0);
+		reg_c58 &= ~BIT(7);
+		dm->noise_level.noise[RF_PATH_B] = (s8)(-110 + reg_c58 + noise_data.sum[RF_PATH_B]);
+		dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_B];
+	}
+	dm->noise_level.noise_all /= max_rf_path;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "noise_a = %d, noise_b = %d, noise_all = %d\n",
+		dm->noise_level.noise[RF_PATH_A], dm->noise_level.noise[RF_PATH_B],
+		dm->noise_level.noise_all);
+
+	/* step 4. Recover the Dig */
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
+	func_end = odm_get_progressing_time(dm, func_start);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "end\n");
+	return dm->noise_level.noise_all;
+
+}
+
+
+s16
+phydm_idle_noise_measurement_ac(
+	struct dm_struct	*dm,
+	u8	is_pause_dig,
+	u8	igi_value,
+	u32	max_time
+	)
+{
+	u32				tmp4b;
+	u8				max_rf_path = 0, rf_path;
+	u8				reg_c50, reg_e50, valid_done = 0;
+	u64				start  = 0, func_start = 0, func_end = 0;
+	struct noise_level	noise_data;
+
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
+
+	if ((dm->rf_type == RF_1T2R) || (dm->rf_type == RF_2T2R))
+		max_rf_path = 2;
+	else
+		max_rf_path = 1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "phydm_idle_noise_measurement_ac==>\n");
+
+	odm_memory_set(dm, &noise_data, 0, sizeof(struct noise_level));
+
+	/*Step 1. Disable DIG && Set initial gain.*/
+
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	/*Step 2. Get noise power level*/
+	start = odm_get_current_time(dm);
+
+	while (1) {
+		/*Stop updating idle time pwer report (for driver read)*/
+		odm_set_bb_reg(dm, 0x9e4, BIT(30), 0x1);
+
+		/*Read Noise Floor Report*/
+		tmp4b = odm_get_bb_reg(dm, 0xff0, MASKDWORD);
+
+		/*update idle time pwer report per 5us*/
+		odm_set_bb_reg(dm, 0x9e4, BIT(30), 0x0);
+
+		ODM_delay_us(5);
+
+		noise_data.value[RF_PATH_A] = (u8)(tmp4b & 0xff);
+		noise_data.value[RF_PATH_B] = (u8)((tmp4b & 0xff00) >> 8);
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			noise_data.sval[rf_path] = (s8)noise_data.value[rf_path];
+			noise_data.sval[rf_path] = noise_data.sval[rf_path] >> 1;
+		}
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			if (noise_data.valid_cnt[rf_path] >= VALID_CNT)
+				continue;
+
+			noise_data.valid_cnt[rf_path]++;
+			noise_data.sum[rf_path] += noise_data.sval[rf_path];
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Path:%d Valid sval = %d\n", rf_path, noise_data.sval[rf_path]);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d\n", noise_data.sum[rf_path]);
+			if (noise_data.valid_cnt[rf_path] == VALID_CNT)
+				valid_done++;
+		}
+
+		if ((valid_done == max_rf_path) || (odm_get_progressing_time(dm, start) > max_time)) {
+			phydm_set_noise_data_sum(&noise_data, max_rf_path);
+			break;
+		}
+	}
+	reg_c50 = (u8)odm_get_bb_reg(dm, 0xc50, MASKBYTE0);
+	reg_c50 &= ~BIT(7);
+	dm->noise_level.noise[RF_PATH_A] = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
+	dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_A];
+
+	if (max_rf_path == 2) {
+		reg_e50 = (u8)odm_get_bb_reg(dm, 0xe50, MASKBYTE0);
+		reg_e50 &= ~BIT(7);
+		dm->noise_level.noise[RF_PATH_B] = (s8)(-110 + reg_e50 + noise_data.sum[RF_PATH_B]);
+		dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_B];
+	}
+	dm->noise_level.noise_all /= max_rf_path;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "noise_a = %d, noise_b = %d, noise_all = %d\n",
+		dm->noise_level.noise[RF_PATH_A], dm->noise_level.noise[RF_PATH_B],
+		dm->noise_level.noise_all);
+
+	/*Step 3. Recover the Dig*/
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
+	func_end = odm_get_progressing_time(dm, func_start);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "end\n");
+	return dm->noise_level.noise_all;
+
+}
+
+
+s16
+odm_inband_noise_monitor_ac_series(
+	struct dm_struct	*dm,
+	u8 is_pause_dig,
+	u8 igi_value,
+	u32 max_time
+	)
+{
+	s32          rxi_buf_anta, rxq_buf_anta; /*rxi_buf_antb, rxq_buf_antb;*/
+	s32	        value32, pwdb_A = 0, sval, noise, sum = 0;
+	boolean	        pd_flag;
+	u8		valid_cnt = 0;
+	u64	start = 0, func_start = 0, func_end = 0;
+
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+		return phydm_idle_noise_measurement_ac(dm, is_pause_dig, igi_value, max_time);
+
+	if (!(dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A)))
+		return 0;
+
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "odm_inband_noise_monitor_ac_series() ==>\n");
+
+	/* step 1. Disable DIG && Set initial gain. */
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	/* step 3. Get noise power level */
+	start = odm_get_current_time(dm);
+
+	/* step 3. Get noise power level */
+	while (1) {
+		/*Set IGI=0x1C */
+		odm_write_dig(dm, 0x1C);
+		/*stop CK320&CK88 */
+		odm_set_bb_reg(dm, 0x8B4, BIT(6), 1);
+		/*Read path-A */
+		odm_set_bb_reg(dm, 0x8FC, MASKDWORD, 0x200); /*set debug port*/
+		value32 = odm_get_bb_reg(dm, 0xFA0, MASKDWORD); /*read debug port*/
+
+		rxi_buf_anta = (value32 & 0xFFC00) >> 10; /*rxi_buf_anta=RegFA0[19:10]*/
+		rxq_buf_anta = value32 & 0x3FF; /*rxq_buf_anta=RegFA0[19:10]*/
+
+		pd_flag = (boolean)((value32 & BIT(31)) >> 31);
+
+		/*Not in packet detection period or Tx state */
+		if ((!pd_flag) || (rxi_buf_anta != 0x200)) {
+			/*sign conversion*/
+			rxi_buf_anta = odm_sign_conversion(rxi_buf_anta, 10);
+			rxq_buf_anta = odm_sign_conversion(rxq_buf_anta, 10);
+
+			pwdb_A = odm_pwdb_conversion(rxi_buf_anta * rxi_buf_anta + rxq_buf_anta * rxq_buf_anta, 20, 18); /*S(10,9)*S(10,9)=S(20,18)*/
+
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pwdb_A= %d dB, rxi_buf_anta= 0x%x, rxq_buf_anta= 0x%x\n", pwdb_A, rxi_buf_anta & 0x3FF, rxq_buf_anta & 0x3FF);
+		}
+		/*Start CK320&CK88*/
+		odm_set_bb_reg(dm, 0x8B4, BIT(6), 0);
+		/*BB Reset*/
+		odm_write_1byte(dm, 0x02, odm_read_1byte(dm, 0x02) & (~BIT(0)));
+		odm_write_1byte(dm, 0x02, odm_read_1byte(dm, 0x02) | BIT(0));
+		/*PMAC Reset*/
+		odm_write_1byte(dm, 0xB03, odm_read_1byte(dm, 0xB03) & (~BIT(0)));
+		odm_write_1byte(dm, 0xB03, odm_read_1byte(dm, 0xB03) | BIT(0));
+		/*CCK Reset*/
+		if (odm_read_1byte(dm, 0x80B) & BIT(4)) {
+			odm_write_1byte(dm, 0x80B, odm_read_1byte(dm, 0x80B) & (~BIT(4)));
+			odm_write_1byte(dm, 0x80B, odm_read_1byte(dm, 0x80B) | BIT(4));
+		}
+
+		sval = pwdb_A;
+
+		if ((sval < 0 && sval >= -27) && (valid_cnt < VALID_CNT)){
+			valid_cnt++;
+			sum += sval;
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Valid sval = %d\n", sval);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d,\n", sum);
+			if ((valid_cnt >= VALID_CNT) || (odm_get_progressing_time(dm, start) > max_time)) {
+				sum /= VALID_CNT;
+				PHYDM_DBG(dm, DBG_ENV_MNTR, "After divided, sum = %d\n", sum);
+				break;
+			}
+		}
+	}
+
+	/*ADC backoff is 12dB,*/
+	/*Ptarget=0x1C-110=-82dBm*/
+	noise = sum + 12 + 0x1C - 110;
+
+	/*Offset*/
+	noise = noise - 3;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "noise = %d\n", noise);
+	dm->noise_level.noise_all = (s16)noise;
+
+	/* step 4. Recover the Dig*/
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	func_end = odm_get_progressing_time(dm, func_start);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "odm_inband_noise_monitor_ac_series() <==\n");
+
+	return dm->noise_level.noise_all;
+}
+
+
+
+s16
+odm_inband_noise_monitor(
+	void *dm_void,
+	u8 is_pause_dig,
+	u8 igi_value,
+	u32 max_time
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	igi_value = 0x32;	/*since HW ability is about +15~-35, we fix IGI = -60 for maximum coverage*/
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		return odm_inband_noise_monitor_ac_series(dm, is_pause_dig, igi_value, max_time);
+	else
+		return odm_inband_noise_monitor_n_series(dm, is_pause_dig, igi_value, max_time);
+}
+
+void
+phydm_noisy_detection(
+	void *dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32  total_fa_cnt, total_cca_cnt;
+	u32  score = 0, i, score_smooth;
+
+	total_cca_cnt = dm->false_alm_cnt.cnt_cca_all;
+	total_fa_cnt  = dm->false_alm_cnt.cnt_all;
+
+#if 0
+	if (total_fa_cnt * 16 >= total_cca_cnt * 14)    /*  87.5 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 12) /*  75 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 10) /*  56.25 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 8) /*  50 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 7) /*  43.75 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 6) /*  37.5 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 5) /*  31.25% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 4) /*  25% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 3) /*  18.75% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 2) /*  12.5% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 1) /*  6.25% */
+		;
+#endif
+	for (i = 0; i <= 16; i++) {
+		if (total_fa_cnt * 16 >= total_cca_cnt * (16 - i)) {
+			score = 16 - i;
+			break;
+		}
+	}
+
+	/* noisy_decision_smooth = noisy_decision_smooth>>1 + (score<<3)>>1; */
+	dm->noisy_decision_smooth = (dm->noisy_decision_smooth >> 1) + (score << 2);
+
+	/* Round the noisy_decision_smooth: +"3" comes from (2^3)/2-1 */
+	score_smooth = (total_cca_cnt >= 300) ? ((dm->noisy_decision_smooth + 3) >> 3) : 0;
+
+	dm->noisy_decision = (score_smooth >= 3) ? 1 : 0;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		"[NoisyDetection] CCA_cnt=%d,FA_cnt=%d, noisy_dec_smooth=%d, score=%d, score_smooth=%d, noisy_dec=%d\n",
+		total_cca_cnt, total_fa_cnt, dm->noisy_decision_smooth, score, score_smooth, dm->noisy_decision);
+
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_noisemonitor.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_noisemonitor.h
new file mode 100644
index 000000000000..d7101ad1e8e9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_noisemonitor.h
@@ -0,0 +1,55 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef	__ODMNOISEMONITOR_H__
+#define __ODMNOISEMONITOR_H__
+
+#define	ODM_MAX_CHANNEL_NUM					38/* 14+24 */
+struct noise_level {
+	u8				value[PHYDM_MAX_RF_PATH];
+	s8				sval[PHYDM_MAX_RF_PATH];
+	s32				sum[PHYDM_MAX_RF_PATH];
+	u8				valid[PHYDM_MAX_RF_PATH];
+	u8				valid_cnt[PHYDM_MAX_RF_PATH];
+};
+
+
+struct odm_noise_monitor {
+	s8			noise[PHYDM_MAX_RF_PATH];
+	s16			noise_all;
+};
+
+s16 odm_inband_noise_monitor(
+	void *dm_void,
+	u8 is_pause_dig,
+	u8 igi_value,
+	u32 max_time
+);
+
+void
+phydm_noisy_detection(
+	void *dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pathdiv.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pathdiv.c
new file mode 100644
index 000000000000..5550ab40c81a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pathdiv.c
@@ -0,0 +1,709 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (defined(CONFIG_PATH_DIVERSITY))
+#if RTL8814A_SUPPORT
+
+void
+phydm_dtp_fix_tx_path(
+	void	*dm_void,
+	u8	path
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+	u8			i, num_enable_path = 0;
+
+	if (path == dm_path_div->pre_tx_path)
+		return;
+	else
+		dm_path_div->pre_tx_path = path;
+
+	odm_set_bb_reg(dm, 0x93c, BIT(18) | BIT(19), 3);
+
+	for (i = 0; i < 4; i++) {
+		if (path & BIT(i))
+			num_enable_path++;
+	}
+	PHYDM_DBG(dm, DBG_PATH_DIV, " number of turn-on path : (( %d ))\n", num_enable_path);
+
+	if (num_enable_path == 1) {
+		odm_set_bb_reg(dm, 0x93c, 0xf00000, path);
+
+		if (path == BB_PATH_A) { /* 1-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+		} else 	if (path == BB_PATH_B) { /* 1-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+		} else 	if (path == BB_PATH_C) { /* 1-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( C ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 0);
+
+		} else 	if (path == BB_PATH_D) { /* 1-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( D ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 0);
+		}
+
+	} else	if (num_enable_path == 2) {
+		odm_set_bb_reg(dm, 0x93c, 0xf00000, path);
+		odm_set_bb_reg(dm, 0x940, 0xf0, path);
+
+		if (path == (BB_PATH_AB)) { /* 2-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A B ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 1);
+		} else 	if (path == BB_PATH_AC) { /* 2-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A C ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+		} else 	if (path == BB_PATH_AD) { /* 2-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 1);
+		} else 	if (path == BB_PATH_BC) { /* 2-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B C ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+		} else 	if (path == BB_PATH_BD) { /* 2-5 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 1);
+		} else 	if (path == BB_PATH_CD) { /* 2-6 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( C D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 1);
+		}
+
+	} else	if (num_enable_path == 3) {
+		odm_set_bb_reg(dm, 0x93c, 0xf00000, path);
+		odm_set_bb_reg(dm, 0x940, 0xf0, path);
+		odm_set_bb_reg(dm, 0x940, 0xf0000, path);
+
+		if (path == BB_PATH_ABC) { /* 3-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A B C))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(23) | BIT(22), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(25) | BIT(24), 2);
+		} else 	if (path == BB_PATH_ABD) { /* 3-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A B D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(23) | BIT(22), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(27) | BIT(26), 2);
+
+		} else 	if (path == BB_PATH_ACD) { /* 3-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A C D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(25) | BIT(24), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(27) | BIT(26), 2);
+		} else 	if (path == BB_PATH_BCD) { /* 3-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B C D))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(23) | BIT(22), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(25) | BIT(24), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(27) | BIT(26), 2);
+		}
+	} else	if (num_enable_path == 4)
+		PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path ((A  B C D))\n");
+
+}
+
+void
+phydm_find_default_path(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+	u32	rssi_avg_a = 0, rssi_avg_b = 0, rssi_avg_c = 0, rssi_avg_d = 0, rssi_avg_bcd = 0;
+	u32	rssi_total_a = 0, rssi_total_b = 0, rssi_total_c = 0, rssi_total_d = 0;
+
+	/* 2 Default path Selection By RSSI */
+
+	rssi_avg_a = (dm_path_div->path_a_cnt_all > 0) ? (dm_path_div->path_a_sum_all / dm_path_div->path_a_cnt_all) : 0 ;
+	rssi_avg_b = (dm_path_div->path_b_cnt_all > 0) ? (dm_path_div->path_b_sum_all / dm_path_div->path_b_cnt_all) : 0 ;
+	rssi_avg_c = (dm_path_div->path_c_cnt_all > 0) ? (dm_path_div->path_c_sum_all / dm_path_div->path_c_cnt_all) : 0 ;
+	rssi_avg_d = (dm_path_div->path_d_cnt_all > 0) ? (dm_path_div->path_d_sum_all / dm_path_div->path_d_cnt_all) : 0 ;
+
+
+	dm_path_div->path_a_sum_all = 0;
+	dm_path_div->path_a_cnt_all = 0;
+	dm_path_div->path_b_sum_all = 0;
+	dm_path_div->path_b_cnt_all = 0;
+	dm_path_div->path_c_sum_all = 0;
+	dm_path_div->path_c_cnt_all = 0;
+	dm_path_div->path_d_sum_all = 0;
+	dm_path_div->path_d_cnt_all = 0;
+
+	if (dm_path_div->use_path_a_as_default_ant == 1) {
+		rssi_avg_bcd = (rssi_avg_b + rssi_avg_c + rssi_avg_d) / 3;
+
+		if ((rssi_avg_a + ANT_DECT_RSSI_TH) > rssi_avg_bcd) {
+			dm_path_div->is_path_a_exist = true;
+			dm_path_div->default_path = PATH_A;
+		} else
+			dm_path_div->is_path_a_exist = false;
+	} else {
+		if ((rssi_avg_a >= rssi_avg_b) && (rssi_avg_a >= rssi_avg_c) && (rssi_avg_a >= rssi_avg_d))
+			dm_path_div->default_path = PATH_A;
+		else if ((rssi_avg_b >= rssi_avg_c) && (rssi_avg_b >= rssi_avg_d))
+			dm_path_div->default_path = PATH_B;
+		else if (rssi_avg_c >= rssi_avg_d)
+			dm_path_div->default_path = PATH_C;
+		else
+			dm_path_div->default_path = PATH_D;
+	}
+
+
+}
+
+
+void
+phydm_candidate_dtp_update(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+
+	dm_path_div->num_candidate = 3;
+
+	if (dm_path_div->use_path_a_as_default_ant == 1) {
+		if (dm_path_div->num_tx_path == 3) {
+			if (dm_path_div->is_path_a_exist) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_ACD;
+			} else { /* use path BCD */
+				dm_path_div->num_candidate = 1;
+				phydm_dtp_fix_tx_path(dm, BB_PATH_BCD);
+				return;
+			}
+		} else	if (dm_path_div->num_tx_path == 2) {
+			if (dm_path_div->is_path_a_exist) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AB;
+				dm_path_div->ant_candidate_2 =  BB_PATH_AC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_AD;
+			} else {
+				dm_path_div->ant_candidate_1 =  BB_PATH_BC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+			}
+		}
+	} else {
+		/* 2 3 TX mode */
+		if (dm_path_div->num_tx_path == 3) { /* choose 3 ant form 4 */
+			if (dm_path_div->default_path == PATH_A) { /* choose 2 ant form 3 */
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_ACD;
+			} else if (dm_path_div->default_path == PATH_B) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
+			} else if (dm_path_div->default_path == PATH_C) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ACD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
+			} else if (dm_path_div->default_path == PATH_D) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ACD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
+			}
+		}
+
+		/* 2 2 TX mode */
+		else if (dm_path_div->num_tx_path == 2) { /* choose 2 ant form 4 */
+			if (dm_path_div->default_path == PATH_A) { /* choose 2 ant form 3 */
+				dm_path_div->ant_candidate_1 =  BB_PATH_AB;
+				dm_path_div->ant_candidate_2 =  BB_PATH_AC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_AD;
+			} else if (dm_path_div->default_path == PATH_B) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AB;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BD;
+			} else if (dm_path_div->default_path == PATH_C) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+			} else if (dm_path_div->default_path == PATH_D) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AD;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+			}
+		}
+	}
+}
+
+
+void
+phydm_dynamic_tx_path(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+
+	struct sta_info	*entry;
+	u32	i;
+	u8	num_client = 0;
+	u8	h2c_parameter[6] = {0};
+
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_PATH_DIV, "DTP_8814 [No Link!!!]\n");
+
+		if (dm_path_div->is_become_linked == true) {
+			PHYDM_DBG(dm, DBG_PATH_DIV, " [Be disconnected]----->\n");
+			dm_path_div->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (dm_path_div->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_PATH_DIV, " [Be Linked !!!]----->\n");
+			dm_path_div->is_become_linked = dm->is_linked;
+		}
+	}
+
+	/* 2 [period CTRL] */
+	if (dm_path_div->dtp_period >= 2)
+		dm_path_div->dtp_period = 0;
+	else {
+		/* PHYDM_DBG(dm,DBG_PATH_DIV, "Phydm_Dynamic_Tx_Path_8814A()  Stay = (( %d ))\n",dm_path_div->dtp_period); */
+		dm_path_div->dtp_period++;
+		return;
+	}
+
+
+	/* 2 [Fix path] */
+	if (dm->path_select != PHYDM_AUTO_PATH)
+		return;
+
+	/* 2 [Check Bfer] */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if (BEAMFORMING_SUPPORT == 1)
+	{
+		enum beamforming_cap		beamform_cap = (dm->beamforming_info.beamform_cap);
+
+		if (beamform_cap & BEAMFORMER_CAP) { /* BFmer On  &&   Div On->Div Off */
+			if (dm_path_div->fix_path_bfer == 0) {
+				PHYDM_DBG(dm, DBG_PATH_DIV, "[ PathDiv : OFF ]   BFmer ==1\n");
+				dm_path_div->fix_path_bfer = 1 ;
+			}
+			return;
+		} else { /* BFmer Off   &&   Div Off->Div On */
+			if (dm_path_div->fix_path_bfer == 1) {
+				PHYDM_DBG(dm, DBG_PATH_DIV, "[ PathDiv : ON ]   BFmer ==0\n");
+				dm_path_div->fix_path_bfer = 0;
+			}
+		}
+	}
+#endif
+#endif
+
+	if (dm_path_div->use_path_a_as_default_ant == 1) {
+		phydm_find_default_path(dm);
+		phydm_candidate_dtp_update(dm);
+	} else {
+		if (dm_path_div->phydm_dtp_state == PHYDM_DTP_INIT) {
+			phydm_find_default_path(dm);
+			phydm_candidate_dtp_update(dm);
+			dm_path_div->phydm_dtp_state = PHYDM_DTP_RUNNING_1;
+		}
+
+		else	if (dm_path_div->phydm_dtp_state == PHYDM_DTP_RUNNING_1) {
+			dm_path_div->dtp_check_patha_counter++;
+
+			if (dm_path_div->dtp_check_patha_counter >= NUM_RESET_DTP_PERIOD) {
+				dm_path_div->dtp_check_patha_counter = 0;
+				dm_path_div->phydm_dtp_state = PHYDM_DTP_INIT;
+			}
+#if 0
+			/* 2 Search space update */
+			else {
+				/* 1.  find the worst candidate */
+
+
+				/* 2. repalce the worst candidate */
+			}
+#endif
+		}
+	}
+
+	/* 2 Dynamic path Selection H2C */
+
+	if (dm_path_div->num_candidate == 1)
+		return;
+	else {
+		h2c_parameter[0] =  dm_path_div->num_candidate;
+		h2c_parameter[1] =  dm_path_div->num_tx_path;
+		h2c_parameter[2] =  dm_path_div->ant_candidate_1;
+		h2c_parameter[3] =  dm_path_div->ant_candidate_2;
+		h2c_parameter[4] =  dm_path_div->ant_candidate_3;
+
+		odm_fill_h2c_cmd(dm, PHYDM_H2C_DYNAMIC_TX_PATH, 6, h2c_parameter);
+	}
+
+}
+
+
+
+void
+phydm_dynamic_tx_path_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div  = &dm->dm_path_div;
+	void		*adapter = dm->adapter;
+	u8			search_space_2[NUM_CHOOSE2_FROM4] = {BB_PATH_AB, BB_PATH_AC, BB_PATH_AD, BB_PATH_BC, BB_PATH_BD, BB_PATH_CD };
+	u8			search_space_3[NUM_CHOOSE3_FROM4] = {BB_PATH_BCD, BB_PATH_ACD,  BB_PATH_ABD, BB_PATH_ABC};
+
+#if ((DM_ODM_SUPPORT_TYPE == ODM_WIN) && USB_SWITCH_SUPPORT)
+	dm_path_div->is_u3_mode = (*dm->hub_usb_mode == 2) ? 1 : 0;
+	PHYDM_DBG(dm, DBG_PATH_DIV, "[WIN USB] is_u3_mode = (( %d ))\n", dm_path_div->is_u3_mode);
+#else
+	dm_path_div->is_u3_mode = 1;
+#endif
+	PHYDM_DBG(dm, DBG_PATH_DIV, "Dynamic TX path Init 8814\n");
+
+	memcpy(&dm_path_div->search_space_2[0], &search_space_2[0],
+	       NUM_CHOOSE2_FROM4);
+	memcpy(&dm_path_div->search_space_3[0], &search_space_3[0],
+	       NUM_CHOOSE3_FROM4);
+
+	dm_path_div->use_path_a_as_default_ant = 1;
+	dm_path_div->phydm_dtp_state = PHYDM_DTP_INIT;
+	dm->path_select = PHYDM_AUTO_PATH;
+	dm_path_div->phydm_path_div_type = PHYDM_4R_PATH_DIV;
+
+
+	if (dm_path_div->is_u3_mode) {
+		dm_path_div->num_tx_path = 3;
+		phydm_dtp_fix_tx_path(dm, BB_PATH_BCD);/* 3TX  Set Init TX path*/
+
+	} else {
+		dm_path_div->num_tx_path = 2;
+		phydm_dtp_fix_tx_path(dm, BB_PATH_BC);/* 2TX // Set Init TX path*/
+	}
+
+}
+
+
+void
+phydm_process_rssi_for_path_div(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct		*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct	*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct _ODM_PATH_DIVERSITY_			*dm_path_div  = &dm->dm_path_div;
+
+	if (!(pktinfo->is_packet_to_self || pktinfo->is_packet_match_bssid))
+		return;
+
+	if (pktinfo->data_rate <= ODM_RATE11M)
+		return;
+
+	if (dm_path_div->phydm_path_div_type == PHYDM_4R_PATH_DIV) {
+#if RTL8814A_SUPPORT
+		if (dm->support_ic_type & ODM_RTL8814A) {
+			dm_path_div->path_a_sum_all += phy_info->rx_mimo_signal_strength[0];
+			dm_path_div->path_a_cnt_all++;
+
+			dm_path_div->path_b_sum_all += phy_info->rx_mimo_signal_strength[1];
+			dm_path_div->path_b_cnt_all++;
+
+			dm_path_div->path_c_sum_all += phy_info->rx_mimo_signal_strength[2];
+			dm_path_div->path_c_cnt_all++;
+
+			dm_path_div->path_d_sum_all += phy_info->rx_mimo_signal_strength[3];
+			dm_path_div->path_d_cnt_all++;
+		}
+#endif
+	} else {
+		dm_path_div->path_a_sum[pktinfo->station_id] += phy_info->rx_mimo_signal_strength[0];
+		dm_path_div->path_a_cnt[pktinfo->station_id]++;
+
+		dm_path_div->path_b_sum[pktinfo->station_id] += phy_info->rx_mimo_signal_strength[1];
+		dm_path_div->path_b_cnt[pktinfo->station_id]++;
+	}
+}
+
+#endif /* #if RTL8814A_SUPPORT */
+
+void
+odm_pathdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_			*dm_path_div  = &dm->dm_path_div;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	dm->path_select = (dm_value[0] & 0xf);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Path_select = (( 0x%x ))\n", dm->path_select);
+
+	/* 2 [Fix path] */
+	if (dm->path_select != PHYDM_AUTO_PATH) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"Trun on path  [%s%s%s%s]\n",
+				((dm->path_select) & 0x1) ? "A" : "",
+				((dm->path_select) & 0x2) ? "B" : "",
+				((dm->path_select) & 0x4) ? "C" : "",
+				((dm->path_select) & 0x8) ? "D" : "");
+
+		phydm_dtp_fix_tx_path(dm, dm->path_select);
+	} else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "Auto path");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif /*  #if(defined(CONFIG_PATH_DIVERSITY)) */
+
+void
+phydm_c2h_dtp_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8	cmd_len
+)
+{
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div  = &dm->dm_path_div;
+
+	u8  macid = cmd_buf[0];
+	u8  target = cmd_buf[1];
+	u8  nsc_1 = cmd_buf[2];
+	u8  nsc_2 = cmd_buf[3];
+	u8  nsc_3 = cmd_buf[4];
+
+	PHYDM_DBG(dm, DBG_PATH_DIV, "Target_candidate = (( %d ))\n", target);
+	/*
+	if( (nsc_1 >= nsc_2) &&  (nsc_1 >= nsc_3))
+	{
+		phydm_dtp_fix_tx_path(dm, dm_path_div->ant_candidate_1);
+	}
+	else	if( nsc_2 >= nsc_3)
+	{
+		phydm_dtp_fix_tx_path(dm, dm_path_div->ant_candidate_2);
+	}
+	else
+	{
+		phydm_dtp_fix_tx_path(dm, dm_path_div->ant_candidate_3);
+	}
+	*/
+#endif
+}
+
+void
+odm_path_diversity(
+	void	*dm_void
+)
+{
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_PATH_DIV)) {
+		PHYDM_DBG(dm, DBG_PATH_DIV, "Return: Not Support PathDiv\n");
+		return;
+	}
+
+#if RTL8812A_SUPPORT
+
+	if (dm->support_ic_type & ODM_RTL8812)
+		odm_path_diversity_8812a(dm);
+	else
+#endif
+
+#if RTL8814A_SUPPORT
+		if (dm->support_ic_type & ODM_RTL8814A)
+			phydm_dynamic_tx_path(dm);
+		else
+#endif
+		{}
+#endif
+}
+
+void
+phydm_path_diversity_init(
+	void	*dm_void
+)
+{
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	/*dm->support_ability |= ODM_BB_PATH_DIV;*/
+
+	if (*dm->mp_mode == true)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PATH_DIV)) {
+		PHYDM_DBG(dm, DBG_PATH_DIV, "Return: Not Support PathDiv\n");
+		return;
+	}
+
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type & ODM_RTL8812)
+		odm_path_diversity_init_8812a(dm);
+	else
+#endif
+
+#if RTL8814A_SUPPORT
+		if (dm->support_ic_type & ODM_RTL8814A)
+			phydm_dynamic_tx_path_init(dm);
+		else
+#endif
+		{}
+#endif
+}
+
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+/*
+ * 2011/12/02 MH Copy from MP oursrc for temporarily test.
+ *   */
+
+void
+odm_path_div_chk_ant_switch_callback(
+	struct phydm_timer_list		*timer
+)
+{
+}
+
+void
+odm_path_div_chk_ant_switch_workitem_callback(
+	void            *context
+)
+{
+}
+
+void
+odm_cck_tx_path_diversity_callback(
+	struct phydm_timer_list		*timer
+)
+{
+}
+
+void
+odm_cck_tx_path_diversity_work_item_callback(
+	void            *context
+)
+{
+}
+u8
+odm_sw_ant_div_select_scan_chnl(
+	void	*adapter
+)
+{
+	return	0;
+}
+void
+odm_sw_ant_div_construct_scan_chnl(
+	void	*adapter,
+	u8		scan_chnl
+)
+{
+}
+
+#endif	/*  #if (DM_ODM_SUPPORT_TYPE == ODM_WIN) */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pathdiv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pathdiv.h
new file mode 100644
index 000000000000..29e20789ddc9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pathdiv.h
@@ -0,0 +1,304 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMPATHDIV_H__
+#define    __PHYDMPATHDIV_H__
+/*#define PATHDIV_VERSION "2.0" //2014.11.04*/
+#define PATHDIV_VERSION	"3.1" /*2015.07.29 by YuChen*/
+
+#if (defined(CONFIG_PATH_DIVERSITY))
+#define USE_PATH_A_AS_DEFAULT_ANT   /* for 8814 dynamic TX path selection */
+
+#define	NUM_RESET_DTP_PERIOD 5
+#define	ANT_DECT_RSSI_TH 3
+
+#define PATH_A 1
+#define PATH_B 2
+#define PATH_C 3
+#define PATH_D 4
+
+#define PHYDM_AUTO_PATH	0
+#define PHYDM_FIX_PATH		1
+
+#define NUM_CHOOSE2_FROM4 6
+#define NUM_CHOOSE3_FROM4 4
+
+enum phydm_dtp_state {
+	PHYDM_DTP_INIT = 1,
+	PHYDM_DTP_RUNNING_1
+
+};
+
+enum phydm_path_div_type {
+	PHYDM_2R_PATH_DIV = 1,
+	PHYDM_4R_PATH_DIV = 2
+};
+
+void
+phydm_process_rssi_for_path_div(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+);
+
+struct _ODM_PATH_DIVERSITY_ {
+	u8	resp_tx_path;
+	u8	path_sel[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	path_a_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	path_b_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	path_a_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	path_b_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	phydm_path_div_type;
+#if RTL8814A_SUPPORT
+
+	u32	path_a_sum_all;
+	u32	path_b_sum_all;
+	u32	path_c_sum_all;
+	u32	path_d_sum_all;
+
+	u32	path_a_cnt_all;
+	u32	path_b_cnt_all;
+	u32	path_c_cnt_all;
+	u32	path_d_cnt_all;
+
+	u8	dtp_period;
+	boolean	is_become_linked;
+	boolean	is_u3_mode;
+	u8	num_tx_path;
+	u8	default_path;
+	u8	num_candidate;
+	u8	ant_candidate_1;
+	u8	ant_candidate_2;
+	u8	ant_candidate_3;
+	u8     phydm_dtp_state;
+	u8	dtp_check_patha_counter;
+	boolean	fix_path_bfer;
+	u8	search_space_2[NUM_CHOOSE2_FROM4];
+	u8	search_space_3[NUM_CHOOSE3_FROM4];
+
+	u8	pre_tx_path;
+	u8	use_path_a_as_default_ant;
+	boolean is_path_a_exist;
+
+#endif
+};
+
+
+#endif /* #if(defined(CONFIG_PATH_DIVERSITY)) */
+
+void
+phydm_c2h_dtp_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8	cmd_len
+);
+
+void
+phydm_path_diversity_init(
+	void	*dm_void
+);
+
+void
+odm_path_diversity(
+	void	*dm_void
+);
+
+void
+odm_pathdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+
+
+/* 1 [OLD IC]-------------------------------------------------------------------------------- */
+
+
+
+
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+/* #define   PATHDIV_ENABLE	 1 */
+#define dm_path_div_rssi_check	odm_path_div_chk_per_pkt_rssi
+#define path_div_check_before_link8192c	odm_path_diversity_before_link92c
+
+
+
+
+struct _path_div_parameter_define_ {
+	u32 org_5g_rege30;
+	u32 org_5g_regc14;
+	u32 org_5g_regca0;
+	u32 swt_5g_rege30;
+	u32 swt_5g_regc14;
+	u32 swt_5g_regca0;
+	/* for 2G IQK information */
+	u32 org_2g_regc80;
+	u32 org_2g_regc4c;
+	u32 org_2g_regc94;
+	u32 org_2g_regc14;
+	u32 org_2g_regca0;
+
+	u32 swt_2g_regc80;
+	u32 swt_2g_regc4c;
+	u32 swt_2g_regc94;
+	u32 swt_2g_regc14;
+	u32 swt_2g_regca0;
+};
+
+void
+odm_path_diversity_init_92c(
+	void	*adapter
+);
+
+void
+odm_2t_path_diversity_init_92c(
+	void	*adapter
+);
+
+void
+odm_1t_path_diversity_init_92c(
+	void	*adapter
+);
+
+boolean
+odm_is_connected_92c(
+	void	*adapter
+);
+
+boolean
+odm_path_diversity_before_link92c(
+	/* struct void*	adapter */
+	struct dm_struct		*dm
+);
+
+void
+odm_path_diversity_after_link_92c(
+	void	*adapter
+);
+
+void
+odm_set_resp_path_92c(
+	void	*adapter,
+	u8	default_resp_path
+);
+
+void
+odm_ofdm_tx_path_diversity_92c(
+	void	*adapter
+);
+
+void
+odm_cck_tx_path_diversity_92c(
+	void	*adapter
+);
+
+void
+odm_reset_path_diversity_92c(
+	void	*adapter
+);
+
+void
+odm_cck_tx_path_diversity_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_cck_tx_path_diversity_work_item_callback(
+	void            *context
+);
+
+void
+odm_path_div_chk_ant_switch_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_path_div_chk_ant_switch_workitem_callback(
+	void            *context
+);
+
+
+void
+odm_path_div_chk_ant_switch(
+	struct dm_struct    *dm
+);
+
+void
+odm_cck_path_diversity_chk_per_pkt_rssi(
+	void		*adapter,
+	boolean			is_def_port,
+	boolean			is_match_bssid,
+	struct _WLAN_STA	*entry,
+	PRT_RFD			rfd,
+	u8			*desc
+);
+
+void
+odm_path_div_chk_per_pkt_rssi(
+	void		*adapter,
+	boolean			is_def_port,
+	boolean			is_match_bssid,
+	struct _WLAN_STA	*entry,
+	PRT_RFD			rfd
+);
+
+void
+odm_path_div_rest_after_link(
+	struct dm_struct		*dm
+);
+
+void
+odm_fill_tx_path_in_txdesc(
+	void	*adapter,
+	PRT_TCB		tcb,
+	u8		*desc
+);
+
+void
+odm_path_div_init_92d(
+	struct dm_struct	*dm
+);
+
+u8
+odm_sw_ant_div_select_scan_chnl(
+	void	*adapter
+);
+
+void
+odm_sw_ant_div_construct_scan_chnl(
+	void	*adapter,
+	u8		scan_chnl
+);
+
+#endif       /* #if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) */
+
+
+#endif		 /* #ifndef  __ODMPATHDIV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_phystatus.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_phystatus.c
new file mode 100644
index 000000000000..8661ff22d8ed
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_phystatus.c
@@ -0,0 +1,2554 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_rx_statistic_cal(
+	struct dm_struct				*phydm,
+	struct phydm_phyinfo_struct			*phy_info,
+	u8									*phy_status_inf,
+	struct phydm_perpkt_info_struct				*pktinfo
+)
+{
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+	struct phy_status_rpt_jaguar2_type1	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type1 *)phy_status_inf;
+	u8		phy_status_type = (*phy_status_inf & 0xf);
+#endif
+	u8									date_rate = (pktinfo->data_rate & 0x7f);
+	u8		bw_idx = phy_info->band_width ;
+
+	if (date_rate <= ODM_RATE54M) {
+		phydm->phy_dbg_info.num_qry_legacy_pkt[date_rate]++;
+		/**/
+	} else if (date_rate <= ODM_RATEMCS31) {
+		phydm->phy_dbg_info.ht_pkt_not_zero = true;
+
+		if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+			if ((bw_idx == *phydm->band_width)) {
+				
+				phydm->phy_dbg_info.num_qry_ht_pkt[date_rate - ODM_RATEMCS0]++;
+
+			} else if (bw_idx == CHANNEL_WIDTH_20) {
+			
+				phydm->phy_dbg_info.num_qry_pkt_sc_20m[date_rate - ODM_RATEMCS0]++;
+				phydm->phy_dbg_info.low_bw_20_occur = true;
+			}
+		} else {
+			phydm->phy_dbg_info.num_qry_ht_pkt[date_rate - ODM_RATEMCS0]++;
+		}
+	}
+	#if ODM_IC_11AC_SERIES_SUPPORT
+	else if (date_rate <= ODM_RATEVHTSS4MCS9) {
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		if ((phy_status_type == 1) && 
+			(phy_sta_rpt->gid != 0) && 
+			(phy_sta_rpt->gid != 63) && 
+			(phydm->support_ic_type & PHYSTS_2ND_TYPE_IC)) {
+			phydm->phy_dbg_info.num_qry_mu_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
+			if (pktinfo->ppdu_cnt < 4) {
+				phydm->phy_dbg_info.num_of_ppdu[pktinfo->ppdu_cnt] = date_rate | BIT(7);
+				phydm->phy_dbg_info.gid_num[pktinfo->ppdu_cnt] = phy_sta_rpt->gid;
+			}
+		} else
+		#endif
+		{
+			phydm->phy_dbg_info.vht_pkt_not_zero = true;
+			
+			if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+				if ((bw_idx == *phydm->band_width)) {
+					phydm->phy_dbg_info.num_qry_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
+
+				} else if (bw_idx == CHANNEL_WIDTH_20) {
+					phydm->phy_dbg_info.num_qry_pkt_sc_20m[date_rate - ODM_RATEVHTSS1MCS0]++;
+					phydm->phy_dbg_info.low_bw_20_occur = true;
+				} else /*if (bw_idx == CHANNEL_WIDTH_40)*/ {
+					phydm->phy_dbg_info.num_qry_pkt_sc_40m[date_rate - ODM_RATEVHTSS1MCS0]++;
+					phydm->phy_dbg_info.low_bw_40_occur = true;
+				}
+			} else {
+				phydm->phy_dbg_info.num_qry_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
+			}
+
+			#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+			if (pktinfo->ppdu_cnt < 4) {
+				phydm->phy_dbg_info.num_of_ppdu[pktinfo->ppdu_cnt] = date_rate;
+				phydm->phy_dbg_info.gid_num[pktinfo->ppdu_cnt] = phy_sta_rpt->gid;
+			}
+			#endif
+		}
+	}
+	#endif
+}
+
+void
+phydm_reset_phystatus_avg(
+	struct dm_struct	*dm
+)
+{
+	struct phydm_phystatus_avg		*dbg_avg = &dm->phy_dbg_info.phystatus_statistic_avg;
+
+	odm_memory_set(dm, &dbg_avg->rssi_cck_avg, 0,
+		       sizeof(struct phydm_phystatus_avg));
+}
+
+void
+phydm_reset_phystatus_statistic(
+	struct dm_struct	*dm
+)
+{
+	struct phydm_phystatus_statistic		*dbg_statistic = &dm->phy_dbg_info.phystatus_statistic_info;
+
+	odm_memory_set(dm, &dbg_statistic->rssi_cck_sum, 0,
+		       sizeof(struct phydm_phystatus_statistic));
+}
+
+void
+phydm_avg_phystatus_index(
+	struct dm_struct			*dm,
+	struct phydm_phyinfo_struct		*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	struct phydm_phystatus_statistic		*dbg_statistic = &dm->phy_dbg_info.phystatus_statistic_info;
+
+	if (pktinfo->data_rate <= ODM_RATE11M) {
+		/*RSSI*/
+		dbg_statistic->rssi_cck_sum += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_cck_cnt++;
+	} else if (pktinfo->data_rate <= ODM_RATE54M) {
+		/*evm*/
+		dbg_statistic->evm_ofdm_sum += phy_info->rx_mimo_evm_dbm[0];
+
+		/*SNR*/
+		dbg_statistic->snr_ofdm_sum += phy_info->rx_snr[0];
+
+		/*RSSI*/
+		dbg_statistic->rssi_ofdm_sum += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_ofdm_cnt++;
+	} else if (pktinfo->rate_ss == 1) {
+		/*evm*/
+		dbg_statistic->evm_1ss_sum += phy_info->rx_mimo_evm_dbm[0];
+
+		/*SNR*/
+		dbg_statistic->snr_1ss_sum += phy_info->rx_snr[0];
+
+		dbg_statistic->rssi_1ss_sum += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_1ss_cnt++;
+	} else if (pktinfo->rate_ss == 2) {
+		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		/*evm*/
+		dbg_statistic->evm_2ss_sum[0] += phy_info->rx_mimo_evm_dbm[0];
+		dbg_statistic->evm_2ss_sum[1] += phy_info->rx_mimo_evm_dbm[1];
+
+		/*SNR*/
+		dbg_statistic->snr_2ss_sum[0] += phy_info->rx_snr[0];
+		dbg_statistic->snr_2ss_sum[1] += phy_info->rx_snr[1];
+
+		/*RSSI*/
+		dbg_statistic->rssi_2ss_sum[0] += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_2ss_sum[1] += phy_info->rx_mimo_signal_strength[1];
+		dbg_statistic->rssi_2ss_cnt++;
+		#endif
+	} else if (pktinfo->rate_ss == 3) {
+		#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+		/*evm*/
+		dbg_statistic->evm_3ss_sum[0] += phy_info->rx_mimo_evm_dbm[0];
+		dbg_statistic->evm_3ss_sum[1] += phy_info->rx_mimo_evm_dbm[1];
+		dbg_statistic->evm_3ss_sum[2] += phy_info->rx_mimo_evm_dbm[2];
+
+		/*SNR*/
+		dbg_statistic->snr_3ss_sum[0] += phy_info->rx_snr[0];
+		dbg_statistic->snr_3ss_sum[1] += phy_info->rx_snr[1];
+		dbg_statistic->snr_3ss_sum[2] += phy_info->rx_snr[2];
+
+		/*RSSI*/
+		dbg_statistic->rssi_3ss_sum[0] += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_3ss_sum[1] += phy_info->rx_mimo_signal_strength[1];
+		dbg_statistic->rssi_3ss_sum[2] += phy_info->rx_mimo_signal_strength[2];
+		dbg_statistic->rssi_3ss_cnt++;
+		#endif
+	} else if (pktinfo->rate_ss == 4) {
+		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		/*evm*/
+		dbg_statistic->evm_4ss_sum[0] += phy_info->rx_mimo_evm_dbm[0];
+		dbg_statistic->evm_4ss_sum[1] += phy_info->rx_mimo_evm_dbm[1];
+		dbg_statistic->evm_4ss_sum[2] += phy_info->rx_mimo_evm_dbm[2];
+		dbg_statistic->evm_4ss_sum[3] += phy_info->rx_mimo_evm_dbm[3];
+
+		/*SNR*/
+		dbg_statistic->snr_4ss_sum[0] += phy_info->rx_snr[0];
+		dbg_statistic->snr_4ss_sum[1] += phy_info->rx_snr[1];
+		dbg_statistic->snr_4ss_sum[2] += phy_info->rx_snr[2];
+		dbg_statistic->snr_4ss_sum[3] += phy_info->rx_snr[3];
+
+		/*RSSI*/
+		dbg_statistic->rssi_4ss_sum[0] += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_4ss_sum[1] += phy_info->rx_mimo_signal_strength[1];
+		dbg_statistic->rssi_4ss_sum[2] += phy_info->rx_mimo_signal_strength[2];
+		dbg_statistic->rssi_4ss_sum[3] += phy_info->rx_mimo_signal_strength[3];
+		dbg_statistic->rssi_4ss_cnt++;
+		#endif
+	}
+}
+
+u8 phydm_get_signal_quality(
+	struct phydm_phyinfo_struct *phy_info,
+	struct dm_struct *dm,
+	struct phy_status_rpt_8192cd *phy_sta_rpt
+	)
+{
+	u8 sq_rpt;
+	u8 result = 0;
+
+	if (phy_info->rx_pwdb_all > 40 && !dm->is_in_hct_test)
+		result = 100;
+	else {
+		sq_rpt = phy_sta_rpt->cck_sig_qual_ofdm_pwdb_all;
+
+		if (sq_rpt > 64)
+			result = 0;
+		else if (sq_rpt < 20)
+			result = 100;
+		else
+			result = ((64 - sq_rpt) * 100) / 44;
+
+	}
+
+	return result;
+}
+
+u8
+phydm_query_rx_pwr_percentage(
+	s8		ant_power
+)
+{
+	if ((ant_power <= -100) || (ant_power >= 20))
+		return	0;
+	else if (ant_power >= 0)
+		return	100;
+	else
+		return 100 + ant_power;
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+s32
+phydm_signal_scale_mapping_92c_series(
+	struct dm_struct *dm,
+	s32 curr_sig
+)
+{
+	s32 ret_sig = 0;
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	if (dm->support_interface  == ODM_ITRF_PCIE) {
+		/* step 1. Scale mapping. */
+		if (curr_sig >= 61 && curr_sig <= 100)
+			ret_sig = 90 + ((curr_sig - 60) / 4);
+		else if (curr_sig >= 41 && curr_sig <= 60)
+			ret_sig = 78 + ((curr_sig - 40) / 2);
+		else if (curr_sig >= 31 && curr_sig <= 40)
+			ret_sig = 66 + (curr_sig - 30);
+		else if (curr_sig >= 21 && curr_sig <= 30)
+			ret_sig = 54 + (curr_sig - 20);
+		else if (curr_sig >= 5 && curr_sig <= 20)
+			ret_sig = 42 + (((curr_sig - 5) * 2) / 3);
+		else if (curr_sig == 4)
+			ret_sig = 36;
+		else if (curr_sig == 3)
+			ret_sig = 27;
+		else if (curr_sig == 2)
+			ret_sig = 18;
+		else if (curr_sig == 1)
+			ret_sig = 9;
+		else
+			ret_sig = curr_sig;
+	}
+#endif
+
+#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
+	if ((dm->support_interface  == ODM_ITRF_USB) || (dm->support_interface  == ODM_ITRF_SDIO)) {
+		if (curr_sig >= 51 && curr_sig <= 100)
+			ret_sig = 100;
+		else if (curr_sig >= 41 && curr_sig <= 50)
+			ret_sig = 80 + ((curr_sig - 40) * 2);
+		else if (curr_sig >= 31 && curr_sig <= 40)
+			ret_sig = 66 + (curr_sig - 30);
+		else if (curr_sig >= 21 && curr_sig <= 30)
+			ret_sig = 54 + (curr_sig - 20);
+		else if (curr_sig >= 10 && curr_sig <= 20)
+			ret_sig = 42 + (((curr_sig - 10) * 2) / 3);
+		else if (curr_sig >= 5 && curr_sig <= 9)
+			ret_sig = 22 + (((curr_sig - 5) * 3) / 2);
+		else if (curr_sig >= 1 && curr_sig <= 4)
+			ret_sig = 6 + (((curr_sig - 1) * 3) / 2);
+		else
+			ret_sig = curr_sig;
+	}
+
+#endif
+	return ret_sig;
+}
+
+s32
+phydm_signal_scale_mapping(
+	struct dm_struct *dm,
+	s32 curr_sig
+)
+{
+	#ifdef CONFIG_SIGNAL_SCALE_MAPPING
+		return phydm_signal_scale_mapping_92c_series(dm, curr_sig);
+	#else
+		return curr_sig;
+	#endif
+
+}
+#endif
+
+void
+phydm_process_signal_strength(
+	struct dm_struct				*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	u8		avg_rssi = 0, tmp_rssi = 0, best_rssi = 0, second_rssi = 0;
+	u8		i;
+
+	/* 2015/01 Sean, use the best two RSSI only, suggested by Ynlin and ChenYu.*/
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		
+		tmp_rssi = phy_info->rx_mimo_signal_strength[i];
+
+		/*Get the best two RSSI*/
+		if (tmp_rssi > best_rssi && tmp_rssi > second_rssi) {
+			second_rssi = best_rssi;
+			best_rssi = tmp_rssi;
+		} else if (tmp_rssi > second_rssi && tmp_rssi <= best_rssi)
+			second_rssi = tmp_rssi;
+	}
+
+	if (best_rssi == 0)
+		return;
+
+	avg_rssi = (pktinfo->rate_ss == 1) ? best_rssi : ((best_rssi + second_rssi) >> 1);
+
+	if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		
+		/* Update signal strength to UI, and phy_info->rx_pwdb_all is the maximum RSSI of all path */
+		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, phy_info->rx_pwdb_all, false, false);
+		#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, phy_info->rx_pwdb_all));
+		#endif
+
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+
+		/*UI BSS List signal strength(in percentage), make it good looking, from 0~100.*/
+		/*It is assigned to the BSS List in GetValueFromBeaconOrProbeRsp().*/
+		if (pktinfo->is_cck_rate) {
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			/*2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/
+			phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, phy_info->rx_pwdb_all, false, true);
+			#else
+			phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, phy_info->rx_pwdb_all));/*pwdb_all;*/
+			#endif
+		} else {
+		
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/
+			phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, avg_rssi, false, false);
+			#else
+			phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, avg_rssi));
+			#endif
+		}
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+	#if	ODM_IC_11N_SERIES_SUPPORT
+
+		/* UI BSS List signal strength(in percentage), make it good looking, from 0~100. */
+		/* It is assigned to the BSS List in GetValueFromBeaconOrProbeRsp(). */
+		if (pktinfo->is_cck_rate) {
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/ */
+			phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, phy_info->rx_pwdb_all, true, true);
+			#else
+			phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, phy_info->rx_pwdb_all));/*pwdb_all;*/
+			#endif
+		} else {
+						
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+				/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/ */
+				phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, avg_rssi, true, false);
+			#else
+				phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, avg_rssi));
+			#endif
+		}
+	#endif
+	}
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+static u8 phydm_sq_patch_rt_cid_819x_lenovo(
+	struct dm_struct	*dm,
+	u8		is_cck_rate,
+	u8		pwdb_all,
+	u8		path,
+	u8		RSSI
+)
+{
+	u8	sq = 0;
+
+	if (is_cck_rate) {
+		if (IS_HARDWARE_TYPE_8192E(dm->adapter)) {
+			/*  */
+			/* <Roger_Notes> Expected signal strength and bars indication at Lenovo lab. 2013.04.11 */
+			/* 802.11n, 802.11b, 802.11g only at channel 6 */
+			/*  */
+			/*		Attenuation (dB)	OS Signal Bars	RSSI by Xirrus (dBm) */
+			/*			50				5			-49 */
+			/*			55				5			-49 */
+			/*			60				5			-50 */
+			/*			65				5			-51 */
+			/*			70				5			-52 */
+			/*			75				5			-54 */
+			/*			80				5			-55 */
+			/*			85				4			-60 */
+			/*			90				3			-63 */
+			/*			95				3			-65 */
+			/*			100				2			-67 */
+			/*			102				2			-67 */
+			/*			104				1			-70 */
+			/*  */
+
+			if (pwdb_all >= 50)
+				sq = 100;
+			else if (pwdb_all >= 35 && pwdb_all < 50)
+				sq = 80;
+			else if (pwdb_all >= 31 && pwdb_all < 35)
+				sq = 60;
+			else if (pwdb_all >= 22 && pwdb_all < 31)
+				sq = 40;
+			else if (pwdb_all >= 18 && pwdb_all < 22)
+				sq = 20;
+			else
+				sq = 10;
+		} else {
+			if (pwdb_all >= 50)
+				sq = 100;
+			else if (pwdb_all >= 35 && pwdb_all < 50)
+				sq = 80;
+			else if (pwdb_all >= 22 && pwdb_all < 35)
+				sq = 60;
+			else if (pwdb_all >= 18 && pwdb_all < 22)
+				sq = 40;
+			else
+				sq = 10;
+		}
+
+	} else {
+		/* OFDM rate */
+
+		if (IS_HARDWARE_TYPE_8192E(dm->adapter)) {
+			if (RSSI >= 45)
+				sq = 100;
+			else if (RSSI >= 22 && RSSI < 45)
+				sq = 80;
+			else if (RSSI >= 18 && RSSI < 22)
+				sq = 40;
+			else
+				sq = 20;
+		} else {
+			if (RSSI >= 45)
+				sq = 100;
+			else if (RSSI >= 22 && RSSI < 45)
+				sq = 80;
+			else if (RSSI >= 18 && RSSI < 22)
+				sq = 40;
+			else
+				sq = 20;
+		}
+	}
+
+	RT_TRACE(COMP_DBG, DBG_TRACE, ("is_cck_rate(%#d), pwdb_all(%#d), RSSI(%#d), sq(%#d)\n", is_cck_rate, pwdb_all, RSSI, sq));
+
+
+	return sq;
+}
+
+static u8 phydm_sq_patch_rt_cid_819x_acer(
+	struct dm_struct	*dm,
+	u8		is_cck_rate,
+	u8		pwdb_all,
+	u8		path,
+	u8		RSSI
+)
+{
+	u8	sq = 0;
+
+	if (is_cck_rate) {
+		RT_TRACE(COMP_DBG, DBG_WARNING, ("odm_SQ_process_patch_RT_Acer\n"));
+
+#if OS_WIN_FROM_WIN8(OS_VERSION)
+
+		if (pwdb_all >= 50)
+			sq = 100;
+		else if (pwdb_all >= 35 && pwdb_all < 50)
+			sq = 80;
+		else if (pwdb_all >= 30 && pwdb_all < 35)
+			sq = 60;
+		else if (pwdb_all >= 25 && pwdb_all < 30)
+			sq = 40;
+		else if (pwdb_all >= 20 && pwdb_all < 25)
+			sq = 20;
+		else
+			sq = 10;
+#else
+		if (pwdb_all >= 50)
+			sq = 100;
+		else if (pwdb_all >= 35 && pwdb_all < 50)
+			sq = 80;
+		else if (pwdb_all >= 30 && pwdb_all < 35)
+			sq = 60;
+		else if (pwdb_all >= 25 && pwdb_all < 30)
+			sq = 40;
+		else if (pwdb_all >= 20 && pwdb_all < 25)
+			sq = 20;
+		else
+			sq = 10;
+
+		if (pwdb_all == 0) /* Abnormal case, do not indicate the value above 20 on Win7 */
+			sq = 20;
+#endif
+
+
+
+	} else {
+		/* OFDM rate */
+
+		if (IS_HARDWARE_TYPE_8192E(dm->adapter)) {
+			if (RSSI >= 45)
+				sq = 100;
+			else if (RSSI >= 22 && RSSI < 45)
+				sq = 80;
+			else if (RSSI >= 18 && RSSI < 22)
+				sq = 40;
+			else
+				sq = 20;
+		} else {
+			if (RSSI >= 35)
+				sq = 100;
+			else if (RSSI >= 30 && RSSI < 35)
+				sq = 80;
+			else if (RSSI >= 25 && RSSI < 30)
+				sq = 40;
+			else
+				sq = 20;
+		}
+	}
+
+	RT_TRACE(COMP_DBG, DBG_LOUD, ("is_cck_rate(%#d), pwdb_all(%#d), RSSI(%#d), sq(%#d)\n", is_cck_rate, pwdb_all, RSSI, sq));
+
+
+	return sq;
+}
+#endif
+
+static u8
+phydm_evm_db_to_percentage(
+	s8 value
+)
+{
+	/*  */
+	/* -33dB~0dB to 0%~99% */
+	/*  */
+	s8 ret_val;
+
+	ret_val = value;
+	ret_val /= 2;
+
+	/*dbg_print("value=%d\n", value);*/
+	/*ODM_RT_DISP(FRX, RX_PHY_SQ, ("EVMdbToPercentage92C value=%d / %x\n", ret_val, ret_val));*/
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	if (ret_val >= 0)
+		ret_val = 0;
+
+	if (ret_val <= -40)
+		ret_val = -40;
+
+	ret_val = 0 - ret_val;
+	ret_val *= 3;
+#else
+	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;
+#endif
+
+	return (u8)ret_val;
+}
+
+static u8
+phydm_evm_dbm_jaguar_series(
+	s8 value
+)
+{
+	s8 ret_val = value;
+
+	/* -33dB~0dB to 33dB ~ 0dB */
+	if (ret_val == -128)
+		ret_val = 127;
+	else if (ret_val < 0)
+		ret_val = 0 - ret_val;
+
+	ret_val  = ret_val >> 1;
+	return (u8)ret_val;
+}
+
+static s16
+phydm_cfo(
+	s8 value
+)
+{
+	s16  ret_val;
+
+	if (value < 0) {
+		ret_val = 0 - value;
+		ret_val = (ret_val << 1) + (ret_val >> 1) ;  /* *2.5~=312.5/2^7 */
+		ret_val = ret_val | BIT(12);  /* set bit12 as 1 for negative cfo */
+	} else {
+		ret_val = value;
+		ret_val = (ret_val << 1) + (ret_val >> 1) ; /* *2.5~=312.5/2^7 */
+	}
+	return ret_val;
+}
+
+s8
+phydm_cck_rssi_convert(
+	struct dm_struct	*dm,
+	u16		lna_idx,
+	u8		vga_idx
+)
+{
+	return (dm->cck_lna_gain_table[lna_idx] - (vga_idx << 1));
+}
+
+void
+phydm_get_cck_rssi_table_from_reg(
+	struct dm_struct	*dm
+)
+{
+	u8	used_lna_idx_tmp;
+	u32	reg_0xa80 = 0x7431, reg_0xabc = 0xcbe5edfd; /*example: {-53, -43, -33, -27, -19, -13, -3, 1}*/ /*{0xCB, 0xD5, 0xDF, 0xE5, 0xED, 0xF3, 0xFD, 0x2}*/
+	u8	i;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "CCK LNA Gain table init\n");
+
+	if (!(dm->support_ic_type & (ODM_RTL8197F)))
+		return;
+
+	reg_0xa80 = odm_get_bb_reg(dm, 0xa80, 0xFFFF);
+	reg_0xabc = odm_get_bb_reg(dm, 0xabc, MASKDWORD);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "reg_0xa80 = 0x%x\n", reg_0xa80);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "reg_0xabc = 0x%x\n", reg_0xabc);
+
+	for (i = 0; i <= 3; i++) {
+		used_lna_idx_tmp = (u8)((reg_0xa80 >> (4*i)) & 0x7);
+		dm->cck_lna_gain_table[used_lna_idx_tmp] = (s8)((reg_0xabc >> (8*i)) & 0xff);
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "cck_lna_gain_table = {%d,%d,%d,%d,%d,%d,%d,%d}\n",
+		dm->cck_lna_gain_table[0],
+		dm->cck_lna_gain_table[1],
+		dm->cck_lna_gain_table[2],
+		dm->cck_lna_gain_table[3],
+		dm->cck_lna_gain_table[4],
+		dm->cck_lna_gain_table[5],
+		dm->cck_lna_gain_table[6],
+		dm->cck_lna_gain_table[7]);
+
+}
+
+u8
+phydm_rate_to_num_ss(
+	struct dm_struct		*dm,
+	u8			data_rate
+)
+{
+	u8	num_ss = 1;
+
+	if (data_rate  <= ODM_RATE54M)
+		num_ss = 1;
+	else if (data_rate  <= ODM_RATEMCS31)
+		num_ss = ((data_rate  - ODM_RATEMCS0) >> 3) + 1;
+	else if (data_rate  <= ODM_RATEVHTSS1MCS9)
+		num_ss = 1;
+	else if (data_rate  <= ODM_RATEVHTSS2MCS9)
+		num_ss = 2;
+	else if (data_rate  <= ODM_RATEVHTSS3MCS9)
+		num_ss = 3;
+	else if (data_rate  <= ODM_RATEVHTSS4MCS9)
+		num_ss = 4;
+
+	return num_ss;
+}
+
+
+
+#if (RTL8703B_SUPPORT == 1)
+s8
+phydm_cck_rssi_8703B(
+	u16	LNA_idx,
+	u8	VGA_idx
+)
+{
+	s8	rx_pwr_all = 0x00;
+
+	switch (LNA_idx) {
+	case 0xf:
+		rx_pwr_all = -48 - (2 * VGA_idx);
+		break;
+	case 0xb:
+		rx_pwr_all = -42 - (2 * VGA_idx); /*TBD*/
+		break;
+	case 0xa:
+		rx_pwr_all = -36 - (2 * VGA_idx);
+		break;
+	case 8:
+		rx_pwr_all = -32 - (2 * VGA_idx);
+		break;
+	case 7:
+		rx_pwr_all = -19 - (2 * VGA_idx);
+		break;
+	case 4:
+		rx_pwr_all = -6 - (2 * VGA_idx);
+		break;
+	case 0:
+		rx_pwr_all = -2 - (2 * VGA_idx);
+		break;
+	default:
+		/*rx_pwr_all = -53+(2*(31-VGA_idx));*/
+		/*dbg_print("wrong LNA index\n");*/
+		break;
+
+	}
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8195A_SUPPORT == 1)
+s8
+phydm_cck_rssi_8195a(
+	struct dm_struct	*dm,
+	u16		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {0, -8, -15, -22, -29, -36, -45, -54};
+	s8	lna_gain_table_1[8] = {0, -8, -15, -22, -29, -36, -45, -54};/*use 8195A to calibrate this table. 2016.06.24, Dino*/
+
+	if (dm->cck_agc_report_type == 0)
+		lna_gain = lna_gain_table_0[LNA_idx];
+	else
+		lna_gain = lna_gain_table_1[LNA_idx];
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+s8
+phydm_cck_rssi_8192e(
+	struct dm_struct	*dm,
+	u16		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {15, 9, -10, -21, -23, -27, -43, -44};
+	s8	lna_gain_table_1[8] = {24, 18, 13, -4, -11, -18, -31, -36};/*use 8192EU to calibrate this table. 2015.12.15, Dino*/
+
+	if (dm->cck_agc_report_type == 0)
+		lna_gain = lna_gain_table_0[LNA_idx];
+	else
+		lna_gain = lna_gain_table_1[LNA_idx];
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+s8
+phydm_cck_rssi_8188e(
+	struct dm_struct	*dm,
+	u16		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {17, -1, -13, -29, -32, -35, -38, -41};/*only use lna0/1/2/3/7*/
+	s8	lna_gain_table_1[8] = {29, 20, 12, 3, -6, -15, -24, -33}; /*only use lna3 /7*/
+
+	if (dm->cut_version >= ODM_CUT_I) /*SMIC*/
+		lna_gain = lna_gain_table_0[LNA_idx];
+	else	 /*TSMC*/
+		lna_gain = lna_gain_table_1[LNA_idx];
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+s8
+phydm_cck_rssi_8821c(
+	struct dm_struct	*dm,
+	u8		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {22, 8, -6, -22, -31, -40, -46, -52};/*only use lna2/3/5/7*/
+	s8	lna_gain_table_1[16] = {10, 6, 2, -2, -6, -10, -14, -17,
+		-20, -24, -28, -31, -34, -37, -40, -44}; /*only use lna4/8/C/F*/
+
+	if (dm->cck_agc_report_type == 0)
+		lna_gain = lna_gain_table_0[LNA_idx];
+	else
+		lna_gain = lna_gain_table_1[LNA_idx];
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+void
+phydm_rx_phy_status92c_series_parsing(
+	struct dm_struct					*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	u8						*phy_status_inf,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	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				rf_rx_num = 0;
+	u8				LNA_idx = 0;
+	u8				VGA_idx = 0;
+	u8				cck_agc_rpt;
+	u8				stream_rxevm_tmp = 0;
+	u8				sq;
+	struct phy_status_rpt_8192cd *phy_sta_rpt = (struct phy_status_rpt_8192cd *)phy_status_inf;
+
+	if (pktinfo->is_to_self)
+		dm->curr_station_id = pktinfo->station_id;
+
+	if (pktinfo->is_cck_rate) {
+		
+		cck_agc_rpt = phy_sta_rpt->cck_agc_rpt_ofdm_cfosho_a;
+
+		if (dm->support_ic_type & (ODM_RTL8703B)) {
+#if (RTL8703B_SUPPORT == 1)
+			if (dm->cck_agc_report_type == 1) {  /*4 bit LNA*/
+
+				u8 cck_agc_rpt_b = (phy_sta_rpt->cck_rpt_b_ofdm_cfosho_b & BIT(7)) ? 1 : 0;
+
+				LNA_idx = (cck_agc_rpt_b << 3) | ((cck_agc_rpt & 0xE0) >> 5);
+				VGA_idx = (cck_agc_rpt & 0x1F);
+
+				rx_pwr_all = phydm_cck_rssi_8703B(LNA_idx, VGA_idx);
+			}
+#endif
+		} else { /*3 bit LNA*/
+
+			LNA_idx = ((cck_agc_rpt & 0xE0) >> 5);
+			VGA_idx = (cck_agc_rpt & 0x1F);
+
+			if (dm->support_ic_type & (ODM_RTL8188E)) {
+#if (RTL8188E_SUPPORT == 1)
+				rx_pwr_all = phydm_cck_rssi_8188e(dm, LNA_idx, VGA_idx);
+				/**/
+#endif
+			}
+#if (RTL8192E_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8192E)) {
+				rx_pwr_all = phydm_cck_rssi_8192e(dm, LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8723B)) {
+				rx_pwr_all = odm_CCKRSSI_8723B(LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8188F)) {
+				rx_pwr_all = odm_CCKRSSI_8188F(LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+#if (RTL8195A_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8195A)) {
+				rx_pwr_all = phydm_cck_rssi_8195a(LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+		}
+
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "ext_lna_gain (( %d )), LNA_idx: (( 0x%x )), VGA_idx: (( 0x%x )), rx_pwr_all: (( %d ))\n",
+			dm->ext_lna_gain, LNA_idx, VGA_idx, rx_pwr_all);
+
+		if (dm->board_type & ODM_BOARD_EXT_LNA)
+			rx_pwr_all -= dm->ext_lna_gain;
+
+		pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+		if (pktinfo->is_to_self) {
+			dm->cck_lna_idx = LNA_idx;
+			dm->cck_vga_idx = VGA_idx;
+		}
+		
+		phy_info->rx_pwdb_all = pwdb_all;
+		phy_info->bt_rx_rssi_percentage = pwdb_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+		
+		/* (3) Get Signal Quality (EVM) */
+		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO)
+			sq = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+		else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER)
+			sq = phydm_sq_patch_rt_cid_819x_acer(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+		else
+		#endif
+			sq = phydm_get_signal_quality(phy_info, dm, phy_sta_rpt);
+
+		/* dbg_print("cck sq = %d\n", sq); */
+		phy_info->signal_quality = sq;
+		phy_info->rx_mimo_signal_quality[RF_PATH_A] = sq;
+		phy_info->rx_mimo_signal_quality[RF_PATH_B] = -1;
+		
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			if (i == 0)
+				phy_info->rx_mimo_signal_strength[0] = pwdb_all;
+			else
+				phy_info->rx_mimo_signal_strength[i] = 0;
+		}
+	} else { /* 2 is OFDM rate */
+
+		/*  */
+		/* (1)Get RSSI for HT rate */
+		/*  */
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH_N; i++) {
+			
+			if (dm->rf_path_rx_enable & BIT(i))
+				rf_rx_num++;
+
+			rx_pwr[i] = ((phy_sta_rpt->path_agc[i].gain & 0x3F) * 2) - 110;
+
+			if (pktinfo->is_to_self) {
+				dm->ofdm_agc_idx[i] = (phy_sta_rpt->path_agc[i].gain & 0x3F);
+				/**/
+			}
+
+			phy_info->rx_pwr[i] = rx_pwr[i];
+			RSSI = phydm_query_rx_pwr_percentage(rx_pwr[i]);
+			total_rssi += RSSI;
+			/* RT_DISP(FRX, RX_PHY_SS, ("RF-%d RXPWR=%x RSSI=%d\n", i, rx_pwr[i], RSSI)); */
+
+			phy_info->rx_mimo_signal_strength[i] = (u8) RSSI;
+
+			/* Get Rx snr value in DB */
+			phy_info->rx_snr[i] = (s8)(phy_sta_rpt->path_rxsnr[i] / 2);
+
+			/* Record Signal Strength for next packet */
+
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			if (i == RF_PATH_A) {
+				if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+					phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, i, RSSI);
+				} else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER)
+					phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_acer(dm, pktinfo->is_cck_rate, pwdb_all, 0, RSSI);
+			}
+			#endif
+		}
+
+		/* (2)PWDB, Average PWDB calculated by hardware (for rate adaptive) */
+		rx_pwr_all = (((phy_sta_rpt->cck_sig_qual_ofdm_pwdb_all) >> 1) & 0x7f) - 110;
+
+		pwdb_all_bt = pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+		phy_info->rx_pwdb_all = pwdb_all;
+		phy_info->bt_rx_rssi_percentage = pwdb_all_bt;
+		phy_info->rx_power = rx_pwr_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+			/* do nothing */
+		} else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER) {
+			/* do nothing */
+		} else {
+#endif
+		/* (3)EVM of HT rate */
+
+		if (pktinfo->data_rate >= ODM_RATEMCS8 && pktinfo->data_rate <= ODM_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 = phydm_evm_db_to_percentage((phy_sta_rpt->stream_rxevm[i]));	/* dbm */
+
+			if (i == RF_PATH_A) /* Fill value in RFD, Get the first spatial stream only */
+				phy_info->signal_quality = (u8)(EVM & 0xff);
+
+			phy_info->rx_mimo_signal_quality[i] = (u8)(EVM & 0xff);
+
+			if (phy_sta_rpt->stream_rxevm[i] < 0)
+				stream_rxevm_tmp = (u8)(0 - (phy_sta_rpt->stream_rxevm[i]));
+
+			if (stream_rxevm_tmp == 64)
+				stream_rxevm_tmp = 0;
+
+			phy_info->rx_mimo_evm_dbm[i] = stream_rxevm_tmp;
+
+		}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		}
+#endif
+
+		phydm_parsing_cfo(dm, pktinfo, phy_sta_rpt->path_cfotail, pktinfo->rate_ss);
+
+	}
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->ant_sel;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->ant_sel_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antsel_rx_keep_2;
+#endif
+
+}
+#endif
+
+#if	ODM_IC_11AC_SERIES_SUPPORT
+
+void
+phydm_rx_phy_bw_jaguar_series_parsing(
+	struct phydm_phyinfo_struct			*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo,
+	struct phy_status_rpt_8812		*phy_sta_rpt
+)
+{
+	if (pktinfo->data_rate <= ODM_RATE54M) {
+		switch (phy_sta_rpt->r_RFMOD) {
+		case 1:
+			if (phy_sta_rpt->sub_chnl == 0)
+				phy_info->band_width = 1;
+			else
+				phy_info->band_width = 0;
+			break;
+
+		case 2:
+			if (phy_sta_rpt->sub_chnl == 0)
+				phy_info->band_width = 2;
+			else if (phy_sta_rpt->sub_chnl == 9 || phy_sta_rpt->sub_chnl == 10)
+				phy_info->band_width = 1;
+			else
+				phy_info->band_width = 0;
+			break;
+
+		default:
+		case 0:
+			phy_info->band_width = 0;
+			break;
+		}
+	}
+
+}
+
+void
+phydm_rx_phy_status_jaguar_series_parsing(
+	struct dm_struct		*dm,
+	struct phydm_phyinfo_struct	*phy_info,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct		*pktinfo
+)
+{
+	u8					i, max_spatial_stream;
+	s8					rx_pwr[4], rx_pwr_all = 0;
+	u8					EVM = 0, evm_dbm, pwdb_all = 0, pwdb_all_bt;
+	u8					RSSI, avg_rssi = 0;
+	u8					rf_rx_num = 0;
+	u8					cck_highpwr = 0;
+	u8					LNA_idx, VGA_idx;
+	struct phy_status_rpt_8812 *phy_sta_rpt = (struct phy_status_rpt_8812 *)phy_status_inf;
+	struct phydm_fat_struct					*fat_tab = &dm->dm_fat_table;
+
+	phydm_rx_phy_bw_jaguar_series_parsing(phy_info, pktinfo, phy_sta_rpt);
+
+	if (pktinfo->is_to_self)
+		dm->curr_station_id = pktinfo->station_id;
+	else
+		dm->curr_station_id = 0xff;
+
+
+
+	if (pktinfo->is_cck_rate) {
+		u8 cck_agc_rpt;
+
+		/*(1)Hardware does not provide RSSI for CCK*/
+		/*(2)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
+
+		/*if(hal_data->e_rf_power_state == e_rf_on)*/
+		cck_highpwr = dm->is_cck_high_power;
+		/*else*/
+		/*cck_highpwr = false;*/
+
+		cck_agc_rpt = phy_sta_rpt->cfosho[0];
+		LNA_idx = ((cck_agc_rpt & 0xE0) >> 5);
+		VGA_idx = (cck_agc_rpt & 0x1F);
+
+		if (dm->support_ic_type == ODM_RTL8812) {
+			switch (LNA_idx) {
+			case 7:
+				if (VGA_idx <= 27)
+					rx_pwr_all = -100 + 2 * (27 - VGA_idx); /*VGA_idx = 27~2*/
+				else
+					rx_pwr_all = -100;
+				break;
+			case 6:
+				rx_pwr_all = -48 + 2 * (2 - VGA_idx); /*VGA_idx = 2~0*/
+				break;
+			case 5:
+				rx_pwr_all = -42 + 2 * (7 - VGA_idx); /*VGA_idx = 7~5*/
+				break;
+			case 4:
+				rx_pwr_all = -36 + 2 * (7 - VGA_idx); /*VGA_idx = 7~4*/
+				break;
+			case 3:
+				/*rx_pwr_all = -28 + 2*(7-VGA_idx); VGA_idx = 7~0*/
+				rx_pwr_all = -24 + 2 * (7 - VGA_idx); /*VGA_idx = 7~0*/
+				break;
+			case 2:
+				if (cck_highpwr)
+					rx_pwr_all = -12 + 2 * (5 - VGA_idx); /*VGA_idx = 5~0*/
+				else
+					rx_pwr_all = -6 + 2 * (5 - VGA_idx);
+				break;
+			case 1:
+				rx_pwr_all = 8 - 2 * VGA_idx;
+				break;
+			case 0:
+				rx_pwr_all = 14 - 2 * VGA_idx;
+				break;
+			default:
+				/*dbg_print("CCK Exception default\n");*/
+				break;
+			}
+			rx_pwr_all += 6;
+			pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+			if (cck_highpwr == false) {
+				if (pwdb_all >= 80)
+					pwdb_all = ((pwdb_all - 80) << 1) + ((pwdb_all - 80) >> 1) + 80;
+				else if ((pwdb_all <= 78) && (pwdb_all >= 20))
+					pwdb_all += 3;
+				if (pwdb_all > 100)
+					pwdb_all = 100;
+			}
+		} else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
+			s8 pout = -6;
+
+			switch (LNA_idx) {
+			case 5:
+				rx_pwr_all = pout - 32 - (2 * VGA_idx);
+				break;
+			case 4:
+				rx_pwr_all = pout - 24 - (2 * VGA_idx);
+				break;
+			case 2:
+				rx_pwr_all = pout - 11 - (2 * VGA_idx);
+				break;
+			case 1:
+				rx_pwr_all = pout + 5 - (2 * VGA_idx);
+				break;
+			case 0:
+				rx_pwr_all = pout + 21 - (2 * VGA_idx);
+				break;
+			}
+			pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+		} else if (dm->support_ic_type == ODM_RTL8814A) {
+			s8 pout = -6;
+
+			switch (LNA_idx) {
+			/*CCK only use LNA: 2, 3, 5, 7*/
+			case 7:
+				rx_pwr_all = pout - 32 - (2 * VGA_idx);
+				break;
+			case 5:
+				rx_pwr_all = pout - 22 - (2 * VGA_idx);
+				break;
+			case 3:
+				rx_pwr_all = pout - 2 - (2 * VGA_idx);
+				break;
+			case 2:
+				rx_pwr_all = pout + 5 - (2 * VGA_idx);
+				break;
+			/*case 6:*/
+			/*rx_pwr_all = pout -26 - (2*VGA_idx);*/
+			/*break;*/
+			/*case 4:*/
+			/*rx_pwr_all = pout - 8 - (2*VGA_idx);*/
+			/*break;*/
+			/*case 1:*/
+			/*rx_pwr_all = pout + 21 - (2*VGA_idx);*/
+			/*break;*/
+			/*case 0:*/
+			/*rx_pwr_all = pout + 10 - (2*VGA_idx);*/
+			/*	break; */
+			default:
+				/* dbg_print("CCK Exception default\n"); */
+				break;
+			}
+			pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+		}
+
+		dm->cck_lna_idx = LNA_idx;
+		dm->cck_vga_idx = VGA_idx;
+		phy_info->rx_pwdb_all = pwdb_all;
+		/* if(pktinfo->station_id == 0) */
+		/* { */
+		/*	dbg_print("CCK: LNA_idx = %d, VGA_idx = %d, phy_info->rx_pwdb_all = %d\n", */
+		/*		LNA_idx, VGA_idx, phy_info->rx_pwdb_all); */
+		/* } */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		phy_info->bt_rx_rssi_percentage = pwdb_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+#endif
+		/*(3) Get Signal Quality (EVM)*/
+		/*if (pktinfo->is_packet_match_bssid)*/
+		{
+			u8	sq, sq_rpt;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO)
+				sq = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+			else 
+#endif
+			if (phy_info->rx_pwdb_all > 40 && !dm->is_in_hct_test)
+				sq = 100;
+			else {
+				sq_rpt = phy_sta_rpt->pwdb_all;
+
+				if (sq_rpt > 64)
+					sq = 0;
+				else if (sq_rpt < 20)
+					sq = 100;
+				else
+					sq = ((64 - sq_rpt) * 100) / 44;
+			}
+
+			/* dbg_print("cck sq = %d\n", sq); */
+			phy_info->signal_quality = sq;
+			phy_info->rx_mimo_signal_quality[RF_PATH_A] = sq;
+		}
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			if (i == 0)
+				phy_info->rx_mimo_signal_strength[0] = pwdb_all;
+			else
+				phy_info->rx_mimo_signal_strength[i] = 0;
+		}
+	} else {
+		/*is OFDM rate*/
+		fat_tab->hw_antsw_occur = phy_sta_rpt->hw_antsw_occur;
+
+		/*(1)Get RSSI for OFDM rate*/
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			/*2008/01/30 MH we will judge RF RX path now.*/
+			/* dbg_print("dm->rf_path_rx_enable = %x\n", dm->rf_path_rx_enable); */
+			if (dm->rf_path_rx_enable & BIT(i))
+				rf_rx_num++;
+			/* else */
+			/* continue; */
+			/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
+			/* if((dm->support_ic_type & (ODM_RTL8812|ODM_RTL8821)) && (!dm->is_mp_chip)) */
+			if (i < RF_PATH_C) {
+				rx_pwr[i] = (phy_sta_rpt->gain_trsw[i] & 0x7F) - 110;
+
+				if (pktinfo->is_to_self)
+					dm->ofdm_agc_idx[i] = phy_sta_rpt->gain_trsw[i];
+
+			} else
+				rx_pwr[i] = (phy_sta_rpt->gain_trsw_cd[i - 2] & 0x7F) - 110;
+			/* else */
+			/*rx_pwr[i] = ((phy_sta_rpt->gain_trsw[i]& 0x3F)*2) - 110;  OLD FORMULA*/
+
+			phy_info->rx_pwr[i] = rx_pwr[i];
+
+			/* Translate DBM to percentage. */
+			RSSI = phydm_query_rx_pwr_percentage(rx_pwr[i]);
+
+			phy_info->rx_mimo_signal_strength[i] = (u8) RSSI;
+
+
+			/*Get Rx snr value in DB*/
+			if (i < RF_PATH_C)
+				phy_info->rx_snr[i] = phy_sta_rpt->rxsnr[i] / 2;
+			else if (dm->support_ic_type & (ODM_RTL8814A))
+				phy_info->rx_snr[i] = phy_sta_rpt->csi_current[i - 2] / 2;
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+			/*(2) CFO_short  & CFO_tail*/
+			if (i < RF_PATH_C) {
+				phy_info->cfo_short[i] = phydm_cfo((phy_sta_rpt->cfosho[i]));
+				phy_info->cfo_tail[i] = phydm_cfo((phy_sta_rpt->cfotail[i]));
+			}
+#endif
+			/* Record Signal Strength for next packet */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			if (pktinfo->is_packet_match_bssid && (i == RF_PATH_A)) {
+				if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+					phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, i, RSSI);
+				}
+			}
+#endif
+		}
+
+		/*(3)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
+
+		/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
+		if ((dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)) && (!dm->is_mp_chip))
+			rx_pwr_all = (phy_sta_rpt->pwdb_all & 0x7f) - 110;
+		else
+			rx_pwr_all = (((phy_sta_rpt->pwdb_all) >> 1) & 0x7f) - 110;	 /*OLD FORMULA*/
+
+		pwdb_all_bt = pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+		phy_info->rx_pwdb_all = pwdb_all;
+		/*PHYDM_DBG(dm,DBG_RSSI_MNTR, "ODM OFDM RSSI=%d\n",phy_info->rx_pwdb_all);*/
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		phy_info->bt_rx_rssi_percentage = pwdb_all_bt;
+		phy_info->rx_power = rx_pwr_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+			/*do nothing*/
+		} else {
+#endif
+		/*(4)EVM of OFDM rate*/
+
+		if ((pktinfo->data_rate >= ODM_RATEMCS8) &&
+			(pktinfo->data_rate <= ODM_RATEMCS15))
+			max_spatial_stream = 2;
+		else if ((pktinfo->data_rate >= ODM_RATEVHTSS2MCS0) &&
+			 (pktinfo->data_rate <= ODM_RATEVHTSS2MCS9))
+			max_spatial_stream = 2;
+		else if ((pktinfo->data_rate >= ODM_RATEMCS16) &&
+			 (pktinfo->data_rate <= ODM_RATEMCS23))
+			max_spatial_stream = 3;
+		else if ((pktinfo->data_rate >= ODM_RATEVHTSS3MCS0) &&
+			 (pktinfo->data_rate <= ODM_RATEVHTSS3MCS9))
+			max_spatial_stream = 3;
+		else
+			max_spatial_stream = 1;
+
+		/*if (pktinfo->is_packet_match_bssid) */
+			/*dbg_print("pktinfo->data_rate = %d\n", pktinfo->data_rate);*/
+
+		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.*/
+
+			if (pktinfo->data_rate >= ODM_RATE6M && pktinfo->data_rate <= ODM_RATE54M) {
+				if (i == RF_PATH_A) {
+					EVM = phydm_evm_db_to_percentage((phy_sta_rpt->sigevm));	/*dbm*/
+					EVM += 20;
+					if (EVM > 100)
+						EVM = 100;
+				}
+			} else {
+				if (i < RF_PATH_C) {
+					if (phy_sta_rpt->rxevm[i] == -128)
+						phy_sta_rpt->rxevm[i] = -25;
+					EVM = phydm_evm_db_to_percentage((phy_sta_rpt->rxevm[i]));	/*dbm*/
+				} else {
+					if (phy_sta_rpt->rxevm_cd[i - 2] == -128)
+						phy_sta_rpt->rxevm_cd[i - 2] = -25;
+					EVM = phydm_evm_db_to_percentage((phy_sta_rpt->rxevm_cd[i - 2]));	/*dbm*/
+				}
+			}
+
+			if (i < RF_PATH_C)
+				evm_dbm = phydm_evm_dbm_jaguar_series(phy_sta_rpt->rxevm[i]);
+			else
+				evm_dbm = phydm_evm_dbm_jaguar_series(phy_sta_rpt->rxevm_cd[i - 2]);
+			/*RT_DISP(FRX, RX_PHY_SQ, ("RXRATE=%x RXEVM=%x EVM=%s%d\n",*/
+			/*pktinfo->data_rate, phy_sta_rpt->rxevm[i], "%", EVM));*/
+
+			if (i == RF_PATH_A) {
+				/*Fill value in RFD, Get the first spatial stream only*/
+				phy_info->signal_quality = EVM;
+			}
+			phy_info->rx_mimo_signal_quality[i] = EVM;
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+			phy_info->rx_mimo_evm_dbm[i] = evm_dbm;
+#endif
+		}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		}
+#endif
+
+		phydm_parsing_cfo(dm, pktinfo, phy_sta_rpt->cfotail, pktinfo->rate_ss);
+
+	}
+	/* dbg_print("is_cck_rate= %d, phy_info->signal_strength=%d % PWDB_AL=%d rf_rx_num=%d\n", is_cck_rate, phy_info->signal_strength, pwdb_all, rf_rx_num); */
+
+	dm->rx_pwdb_ave = dm->rx_pwdb_ave + phy_info->rx_pwdb_all;
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->antidx_anta;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->antidx_antb;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antidx_antc;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sta_rpt->antidx_antd;
+#endif
+
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antidx_anta = ((%d)), MatchBSSID =  ((%d))\n", pktinfo->station_id, phy_sta_rpt->antidx_anta, pktinfo->is_packet_match_bssid);*/
+
+
+	/*		dbg_print("phy_sta_rpt->antidx_anta = %d, phy_sta_rpt->antidx_antb = %d\n",*/
+	/*			phy_sta_rpt->antidx_anta, phy_sta_rpt->antidx_antb);*/
+	/*		dbg_print("----------------------------\n");*/
+	/*		dbg_print("pktinfo->station_id=%d, pktinfo->data_rate=0x%x\n",pktinfo->station_id, pktinfo->data_rate);*/
+	/*		dbg_print("phy_sta_rpt->r_RFMOD = %d\n", phy_sta_rpt->r_RFMOD);*/
+	/*		dbg_print("phy_sta_rpt->gain_trsw[0]=0x%x, phy_sta_rpt->gain_trsw[1]=0x%x\n",*/
+	/*				phy_sta_rpt->gain_trsw[0],phy_sta_rpt->gain_trsw[1]);*/
+	/*		dbg_print("phy_sta_rpt->gain_trsw[2]=0x%x, phy_sta_rpt->gain_trsw[3]=0x%x\n",*/
+	/*				phy_sta_rpt->gain_trsw_cd[0],phy_sta_rpt->gain_trsw_cd[1]);*/
+	/*		dbg_print("phy_sta_rpt->pwdb_all = 0x%x, phy_info->rx_pwdb_all = %d\n", phy_sta_rpt->pwdb_all, phy_info->rx_pwdb_all);*/
+	/*		dbg_print("phy_sta_rpt->cfotail[i] = 0x%x, phy_sta_rpt->CFO_tail[i] = 0x%x\n", phy_sta_rpt->cfotail[0], phy_sta_rpt->cfotail[1]);*/
+	/*		dbg_print("phy_sta_rpt->rxevm[0] = %d, phy_sta_rpt->rxevm[1] = %d\n", phy_sta_rpt->rxevm[0], phy_sta_rpt->rxevm[1]);*/
+	/*		dbg_print("phy_sta_rpt->rxevm[2] = %d, phy_sta_rpt->rxevm[3] = %d\n", phy_sta_rpt->rxevm_cd[0], phy_sta_rpt->rxevm_cd[1]);*/
+	/*		dbg_print("phy_info->rx_mimo_signal_strength[0]=%d, phy_info->rx_mimo_signal_strength[1]=%d, rx_pwdb_all=%d\n",*/
+	/*				phy_info->rx_mimo_signal_strength[0], phy_info->rx_mimo_signal_strength[1], phy_info->rx_pwdb_all);*/
+	/*		dbg_print("phy_info->rx_mimo_signal_strength[2]=%d, phy_info->rx_mimo_signal_strength[3]=%d\n",*/
+	/*				phy_info->rx_mimo_signal_strength[2], phy_info->rx_mimo_signal_strength[3]);*/
+	/*		dbg_print("ppPhyInfo->rx_mimo_signal_quality[0]=%d, phy_info->rx_mimo_signal_quality[1]=%d\n",*/
+	/*				phy_info->rx_mimo_signal_quality[0], phy_info->rx_mimo_signal_quality[1]);*/
+	/*		dbg_print("ppPhyInfo->rx_mimo_signal_quality[2]=%d, phy_info->rx_mimo_signal_quality[3]=%d\n",*/
+	/*				phy_info->rx_mimo_signal_quality[2], phy_info->rx_mimo_signal_quality[3]);*/
+
+}
+
+#endif
+
+void
+phydm_reset_rssi_for_dm(
+	struct dm_struct	*dm,
+	u8		station_id
+)
+{
+	struct cmn_sta_info		*sta;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+#endif
+	sta = dm->phydm_sta_info[station_id];
+
+	if (!is_sta_active(sta)) {
+		/**/
+		return;
+	}
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "Reset RSSI for macid = (( %d ))\n", station_id);
+
+
+	sta->rssi_stat.rssi_cck = -1;
+	sta->rssi_stat.rssi_ofdm = -1;
+	sta->rssi_stat.rssi = -1;
+	sta->rssi_stat.ofdm_pkt_cnt = 0;
+	sta->rssi_stat.cck_pkt_cnt = 0;
+	sta->rssi_stat.cck_sum_power = 0;
+	sta->rssi_stat.is_send_rssi = RA_RSSI_STATE_INIT;
+	sta->rssi_stat.packet_map = 0;
+	sta->rssi_stat.valid_bit = 0;
+}
+
+void
+phydm_process_rssi_for_dm(
+	struct dm_struct					*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	s32			rssi_ave;
+	s8			undecorated_smoothed_pwdb, undecorated_smoothed_cck, undecorated_smoothed_ofdm;
+	u8			i;
+	u8			rssi_max, rssi_min;
+	u32			weighting = 0;
+	u8			send_rssi_2_fw = 0;
+	struct cmn_sta_info		*sta;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+#endif
+
+	if (pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
+		return;
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(dm, phy_info, pktinfo);
+#endif
+
+	sta = dm->phydm_sta_info[pktinfo->station_id];
+
+	if (!is_sta_active(sta)) {
+		return;
+		/**/
+	}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if ((dm->support_ability & ODM_BB_ANT_DIV) &&
+	    (fat_tab->enable_ctrl_frame_antdiv)
+	   ) {
+		if (pktinfo->is_packet_match_bssid)
+			dm->data_frame_num++;
+
+		if ((fat_tab->use_ctrl_frame_antdiv)) {
+			if (!pktinfo->is_to_self)/*data frame + CTRL frame*/
+				return;
+		} else {
+			if ((!pktinfo->is_packet_match_bssid))/*data frame only*/
+				return;
+		}
+	} else
+#endif
+	{
+		if ((!pktinfo->is_packet_match_bssid))/*data frame only*/
+			return;
+	}
+
+	if (pktinfo->is_packet_beacon)
+		dm->phy_dbg_info.num_qry_beacon_pkt++;
+
+	/* --------------Statistic for antenna/path diversity------------------ */
+	if (dm->support_ability & ODM_BB_ANT_DIV) {
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+		odm_process_rssi_for_ant_div(dm, phy_info, pktinfo);
+#endif
+	}
+#if (defined(CONFIG_PATH_DIVERSITY))
+	else if (dm->support_ability & ODM_BB_PATH_DIV)
+		phydm_process_rssi_for_path_div(dm, phy_info, pktinfo);
+#endif
+	/* -----------------Smart Antenna Debug Message------------------ */
+
+	undecorated_smoothed_cck =  sta->rssi_stat.rssi_cck;
+	undecorated_smoothed_ofdm = sta->rssi_stat.rssi_ofdm;
+	undecorated_smoothed_pwdb = sta->rssi_stat.rssi;
+
+	if (pktinfo->is_packet_to_self || pktinfo->is_packet_beacon) {
+		if (!pktinfo->is_cck_rate) { /* ofdm rate */
+#if (RTL8814A_SUPPORT == 1)
+			if (dm->support_ic_type & (ODM_RTL8814A)) {
+				u8 rx_count = 0;
+				u32 rssi_linear = 0;
+
+				if (dm->rx_ant_status & BB_PATH_A) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_A]);
+				}
+
+				if (dm->rx_ant_status & BB_PATH_B) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_B]);
+				}
+
+				if (dm->rx_ant_status & BB_PATH_C) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_C]);
+				}
+
+				if (dm->rx_ant_status & BB_PATH_D) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_D]);
+				}
+
+				/* Calculate average RSSI */
+				switch (rx_count) {
+				case 2:
+					rssi_linear = (rssi_linear >> 1);
+					break;
+				case 3:
+					rssi_linear = ((rssi_linear) + (rssi_linear << 1) + (rssi_linear << 3)) >> 5;	/* rssi_linear/3 ~ rssi_linear*11/32 */
+					break;
+				case 4:
+					rssi_linear = (rssi_linear >> 2);
+					break;
+				}
+				rssi_ave = odm_convert_to_db(rssi_linear);
+			} else
+#endif
+			{
+				if (phy_info->rx_mimo_signal_strength[RF_PATH_B] == 0) {
+					rssi_ave = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+				} else {
+					/*dbg_print("rfd->status.rx_mimo_signal_strength[0] = %d, rfd->status.rx_mimo_signal_strength[1] = %d\n",*/
+					/*rfd->status.rx_mimo_signal_strength[0], rfd->status.rx_mimo_signal_strength[1]);*/
+
+					if (phy_info->rx_mimo_signal_strength[RF_PATH_A] > phy_info->rx_mimo_signal_strength[RF_PATH_B]) {
+						rssi_max = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+						rssi_min = phy_info->rx_mimo_signal_strength[RF_PATH_B];
+					} else {
+						rssi_max = phy_info->rx_mimo_signal_strength[RF_PATH_B];
+						rssi_min = phy_info->rx_mimo_signal_strength[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 (undecorated_smoothed_ofdm <= 0) {	/* initialize */
+				undecorated_smoothed_ofdm = (s8)phy_info->rx_pwdb_all;
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "OFDM_INIT: (( %d ))\n", undecorated_smoothed_ofdm);
+			} else {
+				if (phy_info->rx_pwdb_all > (u32)undecorated_smoothed_ofdm) {
+					undecorated_smoothed_ofdm =
+						(s8)((((undecorated_smoothed_ofdm)*(RX_SMOOTH_FACTOR - 1)) +
+						(rssi_ave)) / (RX_SMOOTH_FACTOR));
+					undecorated_smoothed_ofdm = undecorated_smoothed_ofdm + 1;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "OFDM_1: (( %d ))\n", undecorated_smoothed_ofdm);
+				} else {
+					undecorated_smoothed_ofdm =
+						(s8)((((undecorated_smoothed_ofdm)*(RX_SMOOTH_FACTOR - 1)) +
+						(rssi_ave)) / (RX_SMOOTH_FACTOR));
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "OFDM_2: (( %d ))\n", undecorated_smoothed_ofdm);
+				}
+			}
+			if (sta->rssi_stat.ofdm_pkt_cnt != 64) {
+				i = 63;
+				sta->rssi_stat.ofdm_pkt_cnt -= (u8)(((sta->rssi_stat.packet_map >> i) & BIT(0)) - 1);
+			}
+			sta->rssi_stat.packet_map = (sta->rssi_stat.packet_map << 1) | BIT(0);
+
+		} else {
+			rssi_ave = phy_info->rx_pwdb_all;
+
+			if (sta->rssi_stat.cck_pkt_cnt <= 63)
+				sta->rssi_stat.cck_pkt_cnt++;
+
+			/* 1 Process CCK RSSI */
+			if (undecorated_smoothed_cck <= 0) {	/* initialize */
+				undecorated_smoothed_cck = (s8)phy_info->rx_pwdb_all;
+				sta->rssi_stat.cck_sum_power = (u16)phy_info->rx_pwdb_all ; /*reset*/
+				sta->rssi_stat.cck_pkt_cnt = 1; /*reset*/
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_INIT: (( %d ))\n", undecorated_smoothed_cck);
+			} else if (sta->rssi_stat.cck_pkt_cnt <= CCK_RSSI_INIT_COUNT) {
+				sta->rssi_stat.cck_sum_power = sta->rssi_stat.cck_sum_power + (u16)phy_info->rx_pwdb_all;
+				undecorated_smoothed_cck = sta->rssi_stat.cck_sum_power / sta->rssi_stat.cck_pkt_cnt;
+
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_0: (( %d )), SumPow = (( %d )), cck_pkt = (( %d ))\n",
+					undecorated_smoothed_cck, sta->rssi_stat.cck_sum_power, sta->rssi_stat.cck_pkt_cnt);
+			} else {
+				if (phy_info->rx_pwdb_all > (u32)undecorated_smoothed_cck) {
+					undecorated_smoothed_cck =
+						(s8)((((undecorated_smoothed_cck)*(RX_SMOOTH_FACTOR - 1)) +
+						(phy_info->rx_pwdb_all)) / (RX_SMOOTH_FACTOR));
+					undecorated_smoothed_cck = undecorated_smoothed_cck + 1;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_1: (( %d ))\n", undecorated_smoothed_cck);
+				} else {
+					undecorated_smoothed_cck =
+						(s8)((((undecorated_smoothed_cck)*(RX_SMOOTH_FACTOR - 1)) +
+						(phy_info->rx_pwdb_all)) / (RX_SMOOTH_FACTOR));
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_2: (( %d ))\n", undecorated_smoothed_cck);
+				}
+			}
+			i = 63;
+			sta->rssi_stat.ofdm_pkt_cnt -= (u8)((sta->rssi_stat.packet_map >> i) & BIT(0));
+			sta->rssi_stat.packet_map = sta->rssi_stat.packet_map << 1;
+		}
+
+		/* if(entry) */
+
+		/* 2011.07.28 LukeLee: modified to prevent unstable CCK RSSI */
+		if (sta->rssi_stat.ofdm_pkt_cnt == 64) { /* speed up when all packets are OFDM*/
+			undecorated_smoothed_pwdb = undecorated_smoothed_ofdm;
+			PHYDM_DBG(dm, DBG_RSSI_MNTR, "PWDB_0[%d] = (( %d ))\n", pktinfo->station_id, undecorated_smoothed_cck);
+		} else {
+			if (sta->rssi_stat.valid_bit < 64)
+				sta->rssi_stat.valid_bit++;
+
+			if (sta->rssi_stat.valid_bit == 64) {
+				weighting = ((sta->rssi_stat.ofdm_pkt_cnt) > 4) ? 64 : (sta->rssi_stat.ofdm_pkt_cnt << 4);
+				undecorated_smoothed_pwdb = (s8)((weighting * undecorated_smoothed_ofdm + (64 - weighting) * undecorated_smoothed_cck) >> 6);
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "PWDB_1[%d] = (( %d )), W = (( %d ))\n", pktinfo->station_id, undecorated_smoothed_cck, weighting);
+			} else {
+				if (sta->rssi_stat.valid_bit != 0)
+					undecorated_smoothed_pwdb =
+					(sta->rssi_stat.ofdm_pkt_cnt * undecorated_smoothed_ofdm + (sta->rssi_stat.valid_bit - sta->rssi_stat.ofdm_pkt_cnt) * undecorated_smoothed_cck) / sta->rssi_stat.valid_bit;
+				else
+					undecorated_smoothed_pwdb = 0;
+
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "PWDB_2[%d] = (( %d )), ofdm_pkt = (( %d )), Valid_Bit = (( %d ))\n",
+					pktinfo->station_id, undecorated_smoothed_cck, sta->rssi_stat.ofdm_pkt_cnt, sta->rssi_stat.valid_bit);
+			}
+		}
+
+
+		if ((sta->rssi_stat.ofdm_pkt_cnt >= 1 || sta->rssi_stat.cck_pkt_cnt >= 5) && (sta->rssi_stat.is_send_rssi == RA_RSSI_STATE_INIT)) {
+			send_rssi_2_fw = 1;
+			sta->rssi_stat.is_send_rssi = RA_RSSI_STATE_SEND;
+		}
+
+		sta->rssi_stat.rssi_cck = undecorated_smoothed_cck;
+		sta->rssi_stat.rssi_ofdm = undecorated_smoothed_ofdm;
+		sta->rssi_stat.rssi = undecorated_smoothed_pwdb;
+
+
+
+		if (send_rssi_2_fw) { /* Trigger init rate by RSSI */
+
+			if (sta->rssi_stat.ofdm_pkt_cnt != 0)
+				sta->rssi_stat.rssi = undecorated_smoothed_ofdm;
+
+			PHYDM_DBG(dm, DBG_RSSI_MNTR,
+				"[Send to FW] PWDB = (( %d )), ofdm_pkt = (( %d )), cck_pkt = (( %d ))\n",
+				undecorated_smoothed_pwdb, sta->rssi_stat.ofdm_pkt_cnt, sta->rssi_stat.cck_pkt_cnt);
+
+		}
+
+		/* dbg_print("ofdm_pkt=%d, weighting=%d\n", ofdm_pkt_cnt, weighting); */
+		/* dbg_print("undecorated_smoothed_ofdm=%d, undecorated_smoothed_pwdb=%d, undecorated_smoothed_cck=%d\n", */
+		/*	undecorated_smoothed_ofdm, undecorated_smoothed_pwdb, undecorated_smoothed_cck); */
+
+
+	}
+}
+
+/*
+ * Endianness before calling this API
+ *   */
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+/* For 8822B only!! need to move to FW finally */
+/*==============================================*/
+
+boolean
+phydm_query_is_mu_api(
+	struct dm_struct					*phydm,
+	u8							ppdu_idx,
+	u8							*p_data_rate,
+	u8							*p_gid
+)
+{
+	u8	data_rate = 0, gid = 0;
+	boolean is_mu = false;
+
+	data_rate = phydm->phy_dbg_info.num_of_ppdu[ppdu_idx];
+	gid = phydm->phy_dbg_info.gid_num[ppdu_idx];
+
+	if (data_rate & BIT(7)) {
+		is_mu = true;
+		data_rate = data_rate & ~(BIT(7));
+	} else
+		is_mu = false;
+
+	*p_data_rate = data_rate;
+	*p_gid = gid;
+
+	return is_mu;
+
+}
+
+void
+phydm_reset_phy_info(
+	struct dm_struct					*phydm,
+	struct phydm_phyinfo_struct			*phy_info
+)
+{
+	phy_info->rx_pwdb_all = 0;
+	phy_info->signal_quality = 0;
+	phy_info->band_width = 0;
+	phy_info->rx_count = 0;
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_quality, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_strength, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_snr, 0, 4);
+
+	phy_info->rx_power = -110;
+	phy_info->recv_signal_power = -110;
+	phy_info->bt_rx_rssi_percentage = 0;
+	phy_info->signal_strength = 0;
+	phy_info->channel = 0;
+	phy_info->is_mu_packet = 0;
+	phy_info->is_beamformed = 0;
+	phy_info->rxsc = 0;
+	odm_memory_set(phydm, phy_info->rx_pwr, -110, 4);
+	odm_memory_set(phydm, phy_info->cfo_short, 0, 8);
+	odm_memory_set(phydm, phy_info->cfo_tail, 0, 8);
+
+	odm_memory_set(phydm, phy_info->rx_mimo_evm_dbm, 0, 4);
+}
+
+void
+phydm_print_phy_status_jarguar2(
+	struct 	dm_struct			*dm,
+	u8								*phy_status_inf,
+	struct 	phydm_perpkt_info_struct	*pktinfo,
+	struct 	phydm_phyinfo_struct		*phy_info,
+	u8		phy_status_page_num
+)
+{
+	struct phy_status_rpt_jaguar2_type0	*rpt0 = (struct phy_status_rpt_jaguar2_type0 *)phy_status_inf;
+	struct phy_status_rpt_jaguar2_type1	*rpt = (struct phy_status_rpt_jaguar2_type1 *)phy_status_inf;
+	struct phy_status_rpt_jaguar2_type2	*rpt2 = (struct phy_status_rpt_jaguar2_type2 *)phy_status_inf;
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+	u32	phy_status[PHY_STATUS_JRGUAR2_DW_LEN] = {0};
+	u8	i;
+
+	odm_move_memory(dm, phy_status, phy_status_inf, (PHY_STATUS_JRGUAR2_DW_LEN<<2));
+
+	if (!(dm->debug_components & DBG_PHY_STATUS))
+		return;
+
+	if (dbg->show_phy_sts_all_pkt == 0) {
+		if (!pktinfo->is_packet_match_bssid)
+		{
+			return;
+		}
+	}
+
+	dbg->show_phy_sts_cnt++;
+	/*dbg_print("cnt=%d, max=%d\n", dbg->show_phy_sts_cnt, dbg->show_phy_sts_max_cnt);*/
+	
+	if (dbg->show_phy_sts_max_cnt != SHOW_PHY_STATUS_UNLIMITED) {
+		if (dbg->show_phy_sts_cnt > dbg->show_phy_sts_max_cnt) {
+			return;
+		}
+	}
+		
+	pr_debug("Phy Status Rpt: OFDM_%d\n", phy_status_page_num);
+	pr_debug("StaID=%d, RxRate = 0x%x match_bssid=%d\n", pktinfo->station_id, pktinfo->data_rate, pktinfo->is_packet_match_bssid);
+
+	for (i = 0; i < PHY_STATUS_JRGUAR2_DW_LEN; i++) {
+		pr_debug("Offset[%d:%d] = 0x%x\n", ((4 * i) + 3), (4*i), phy_status[i]);
+	}
+
+	if (phy_status_page_num == 0) {
+		pr_debug("[0] TRSW=%d, MP_gain_idx=%d, pwdb=%d\n", rpt0->trsw, rpt0->gain, rpt0->pwdb);
+		pr_debug("[4] band=%d, CH=%d, agc_table = %d, rxsc = %d\n", rpt0->band, rpt0->channel, rpt0->agc_table, rpt0->rxsc);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, LSIG_len=%d\n", 
+			rpt0->antidx_d, rpt0->antidx_c, rpt0->antidx_b, rpt0->antidx_a, rpt0->length);
+		pr_debug("[12] lna_h=%d, bb_power=%d, lna_l=%d, vga=%d, sq=%d\n", 
+			rpt0->lna_h, rpt0->bb_power, rpt0->lna_l, rpt0->vga, rpt0->signal_quality);
+		
+	} else if (phy_status_page_num == 1) {
+		pr_debug("[0] pwdb[D:A]={%d, %d, %d, %d}\n", 
+			rpt->pwdb[3], rpt->pwdb[2], rpt->pwdb[1], rpt->pwdb[0]);
+		pr_debug("[4] BF: %d, ldpc=%d, stbc=%d, g_bt=%d, antsw=%d, band=%d, CH=%d, rxsc[ht, l]={%d, %d}\n",  
+			rpt->beamformed, rpt->ldpc, rpt->stbc,  rpt->gnt_bt, 
+			rpt->hw_antsw_occu, rpt->band, rpt->channel, rpt->ht_rxsc, rpt->l_rxsc);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, LSIG_len=%d\n", 
+			rpt->antidx_d, rpt->antidx_c, rpt->antidx_b, rpt->antidx_a, rpt->lsig_length);
+		pr_debug("[12] rf_mode=%d, NBI=%d, Intf_pos=%d, GID=%d, PAID=%d\n", 
+			rpt->rf_mode, rpt->nb_intf_flag, 
+			(rpt->intf_pos + (rpt->intf_pos_msb<<8)), rpt->gid, 
+			(rpt->paid + (rpt->paid_msb<<8)));
+		pr_debug("[16] EVM[D:A]={%d, %d, %d, %d}\n", rpt->rxevm[3], rpt->rxevm[2], rpt->rxevm[1], rpt->rxevm[0]);
+		pr_debug("[20] CFO[D:A]={%d, %d, %d, %d}\n", rpt->cfo_tail[3], rpt->cfo_tail[2], rpt->cfo_tail[1], rpt->cfo_tail[0]);
+		pr_debug("[24] SNR[D:A]={%d, %d, %d, %d}\n\n", rpt->rxsnr[3], rpt->rxsnr[2], rpt->rxsnr[1], rpt->rxsnr[0]);
+
+	} else if (phy_status_page_num == 2) {
+		
+		pr_debug("[0] pwdb[D:A]={%d, %d, %d, %d}\n", 
+			rpt2->pwdb[3], rpt2->pwdb[2], rpt2->pwdb[1], rpt2->pwdb[0]);
+		pr_debug("[4] BF: %d, ldpc=%d, stbc=%d, g_bt=%d, antsw=%d, band=%d, CH=%d, rxsc[ht, l]={%d, %d}\n",  
+			rpt2->beamformed, rpt2->ldpc, rpt2->stbc,  rpt2->gnt_bt, 
+			rpt2->hw_antsw_occu, rpt2->band, rpt2->channel, rpt2->ht_rxsc, rpt2->l_rxsc);
+		pr_debug("[8] AgcTab[D:A]={%d, %d, %d, %d}, cnt_pw2cca=%d, shift_l_map=%d\n", 
+			rpt2->agc_table_d, rpt2->agc_table_c, rpt2->agc_table_b, rpt2->agc_table_a, 
+			rpt2->cnt_pw2cca, rpt2->shift_l_map);
+		pr_debug("[12] (TRSW|Gain)[D:A]={%d %d, %d %d, %d %d, %d %d}, cnt_cca2agc_rdy=%d\n", 
+			rpt2->trsw_d, rpt2->gain_d, rpt2->trsw_c, rpt2->gain_c, 
+			rpt2->trsw_b,rpt2->gain_b, rpt2->trsw_a, rpt2->gain_a, rpt2->cnt_cca2agc_rdy);
+		pr_debug("[16] AAGC step[D:A]={%d, %d, %d, %d} HT AAGC gain[D:A]={%d, %d, %d, %d}\n", 
+			rpt2->aagc_step_d, rpt2->aagc_step_c, rpt2->aagc_step_b, rpt2->aagc_step_a,
+			rpt2->ht_aagc_gain[3], rpt2->ht_aagc_gain[2], rpt2->ht_aagc_gain[1], rpt2->ht_aagc_gain[0]);
+		pr_debug("[20] DAGC gain[D:A]={%d, %d, %d, %d}\n", rpt2->dagc_gain[3], 
+			rpt2->dagc_gain[2], rpt2->dagc_gain[1], rpt2->dagc_gain[0]);
+		pr_debug("[24] syn_cnt: %d, Cnt=%d\n\n", rpt2->syn_count, rpt2->counter);
+	}
+
+}
+
+void
+phydm_set_per_path_phy_info(
+	u8							rx_path,
+	s8							rx_pwr,
+	s8							rx_evm,
+	s8							cfo_tail,
+	s8							rx_snr,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	u8			evm_dbm = 0;
+	u8			evm_percentage = 0;
+
+	/* SNR is S(8,1), EVM is S(8,1), CFO is S(8,7) */
+
+	if (rx_evm < 0) {
+		/* Calculate EVM in dBm */
+		evm_dbm = ((u8)(0 - rx_evm) >> 1);
+
+		if (evm_dbm == 64)
+			evm_dbm = 0; /*if 1SS rate, evm_dbm [2nd stream] =64*/
+
+		if (evm_dbm != 0) {
+			/* Convert EVM to 0%~100% percentage */
+			if (evm_dbm >= 34)
+				evm_percentage = 100;
+			else
+				evm_percentage = (evm_dbm << 1) + (evm_dbm);
+		}
+	}
+
+	phy_info->rx_pwr[rx_path] = rx_pwr;
+	
+	phy_info->cfo_tail[rx_path] = (cfo_tail * 5) >> 1; /* CFO(kHz) = CFO_tail * 312.5(kHz) / 2^7 ~= CFO tail * 5/2 (kHz)*/
+	phy_info->rx_mimo_evm_dbm[rx_path] = evm_dbm;
+	phy_info->rx_mimo_signal_strength[rx_path] = phydm_query_rx_pwr_percentage(rx_pwr);
+	phy_info->rx_mimo_signal_quality[rx_path] = evm_percentage;
+	phy_info->rx_snr[rx_path] = rx_snr >> 1;
+
+#if 0
+	/* if (pktinfo->is_packet_match_bssid) */
+	{
+		dbg_print("path (%d)--------\n", rx_path);
+		dbg_print("rx_pwr = %d, Signal strength = %d\n", phy_info->rx_pwr[rx_path], phy_info->rx_mimo_signal_strength[rx_path]);
+		dbg_print("evm_dbm = %d, Signal quality = %d\n", phy_info->rx_mimo_evm_dbm[rx_path], phy_info->rx_mimo_signal_quality[rx_path]);
+		dbg_print("CFO = %d, SNR = %d\n", phy_info->cfo_tail[rx_path], phy_info->rx_snr[rx_path]);
+	}
+#endif
+}
+
+void
+phydm_set_common_phy_info(
+	s8							rx_power,
+	u8							channel,
+	boolean						is_beamformed,
+	boolean						is_mu_packet,
+	u8							bandwidth,
+	u8							signal_quality,
+	u8							rxsc,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	phy_info->rx_power = rx_power;											/* RSSI in dB */
+	phy_info->recv_signal_power = rx_power;										/* RSSI in dB */
+	phy_info->channel = channel;												/* channel number */
+	phy_info->is_beamformed = is_beamformed;									/* apply BF */
+	phy_info->is_mu_packet = is_mu_packet;										/* MU packet */
+	phy_info->rxsc = rxsc;
+
+	phy_info->rx_pwdb_all = phydm_query_rx_pwr_percentage(rx_power);				/* RSSI in percentage */
+	phy_info->signal_quality = signal_quality;										/* signal quality */
+	phy_info->band_width = bandwidth;											/* bandwidth */
+
+#if 0
+	/* if (pktinfo->is_packet_match_bssid) */
+	{
+		dbg_print("rx_pwdb_all = %d, rx_power = %d, recv_signal_power = %d\n", phy_info->rx_pwdb_all, phy_info->rx_power, phy_info->recv_signal_power);
+		dbg_print("signal_quality = %d\n", phy_info->signal_quality);
+		dbg_print("is_beamformed = %d, is_mu_packet = %d, rx_count = %d\n", phy_info->is_beamformed, phy_info->is_mu_packet, phy_info->rx_count + 1);
+		dbg_print("channel = %d, rxsc = %d, band_width = %d\n", channel, rxsc, bandwidth);
+	}
+#endif
+}
+
+void
+phydm_get_rx_phy_status_type0(
+	struct dm_struct		*dm,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	/* type 0 is used for cck packet */
+	struct phy_status_rpt_jaguar2_type0	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type0 *)phy_status_inf;
+	u8							sq = 0;
+	s8							rx_power = phy_sta_rpt->pwdb - 110;
+
+
+	if (dm->support_ic_type & ODM_RTL8723D) {
+#if (RTL8723D_SUPPORT == 1)
+		rx_power = phy_sta_rpt->pwdb - 97;
+#endif
+	}
+/*#if (RTL8710B_SUPPORT == 1)*/
+	/*if (dm->support_ic_type & ODM_RTL8710B)*/
+		/*rx_power = phy_sta_rpt->pwdb - 97;*/
+/*#endif*/
+
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type & ODM_RTL8821C) {
+		if (phy_sta_rpt->pwdb >= -57)
+			rx_power = phy_sta_rpt->pwdb - 100;
+		else
+			rx_power = phy_sta_rpt->pwdb - 102;
+	}
+#endif
+
+	if (pktinfo->is_to_self) {
+		dm->ofdm_agc_idx[0] = phy_sta_rpt->pwdb;
+		dm->ofdm_agc_idx[1] = 0;
+		dm->ofdm_agc_idx[2] = 0;
+		dm->ofdm_agc_idx[3] = 0;
+	}
+
+
+	/* Calculate Signal Quality*/
+	if (pktinfo->is_packet_match_bssid) {
+		if (phy_sta_rpt->signal_quality >= 64)
+			sq = 0;
+		else if (phy_sta_rpt->signal_quality <= 20)
+			sq = 100;
+		else {
+			/* mapping to 2~99% */
+			sq = 64 - phy_sta_rpt->signal_quality;
+			sq = ((sq << 3) + sq) >> 2;
+		}
+	}
+
+	/* Modify CCK PWDB if old AGC */
+	if (dm->cck_new_agc == false) {
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8197F)
+			rx_power = phydm_cck_rssi_convert(dm, phy_sta_rpt->lna_l, phy_sta_rpt->vga);
+		else
+		#endif
+		{
+			u8	lna_idx, vga_idx;
+
+			lna_idx = ((phy_sta_rpt->lna_h << 3) | phy_sta_rpt->lna_l);
+			vga_idx = phy_sta_rpt->vga;
+
+			#if (RTL8723D_SUPPORT == 1)
+			if (dm->support_ic_type & ODM_RTL8723D)
+				rx_power = odm_cckrssi_8723d(lna_idx, vga_idx);
+			#endif
+
+			#if (RTL8710B_SUPPORT == 1)
+			if (dm->support_ic_type & ODM_RTL8710B)
+				rx_power = odm_cckrssi_8710b(lna_idx, vga_idx);
+			#endif
+
+			#if (RTL8822B_SUPPORT == 1)
+			/* Need to do !! */
+			/*if (dm->support_ic_type & ODM_RTL8822B) */
+			/*rx_power = odm_CCKRSSI_8822B(LNA_idx, VGA_idx);*/
+			#endif
+
+			#if (RTL8821C_SUPPORT == 1)
+				if (dm->support_ic_type & ODM_RTL8821C)
+					rx_power = phydm_cck_rssi_8821c(dm, lna_idx, vga_idx);
+			#endif
+		}
+
+	}
+
+	/* Confirm CCK RSSI */
+	#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		u8	bb_pwr_th_l = 5; /* round( 31*0.15 ) */
+		u8	bb_pwr_th_h = 27; /* round( 31*0.85 ) */
+
+		if ((phy_sta_rpt->bb_power < bb_pwr_th_l) || (phy_sta_rpt->bb_power > bb_pwr_th_h))
+			rx_power = 0; /* Error RSSI for CCK ; set 100*/
+	}
+	#endif
+
+	/*CCK no STBC and LDPC*/
+	dm->phy_dbg_info.is_ldpc_pkt = false;
+	dm->phy_dbg_info.is_stbc_pkt = false;
+
+	/* Update Common information */
+	phydm_set_common_phy_info(rx_power, phy_sta_rpt->channel, false,
+		  false, CHANNEL_WIDTH_20, sq, phy_sta_rpt->rxsc, phy_info);
+
+	/* Update CCK pwdb */
+	phydm_set_per_path_phy_info(RF_PATH_A, rx_power, 0, 0, 0, phy_info);					/* Update per-path information */
+
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sta_rpt->antidx_d;
+	
+}
+
+void
+phydm_get_rx_phy_status_type1(
+	struct dm_struct		*dm,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	/* type 1 is used for ofdm packet */
+	struct phy_status_rpt_jaguar2_type1	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type1 *)phy_status_inf;
+	s8		rx_pwr_db = -120;
+	s8		rx_path_pwr_db;
+	u8		i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
+	boolean	is_mu;
+
+	/* Update per-path information */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			rx_count++;
+
+			if (rx_count > dm->num_rf_path)
+				break;
+
+			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO sq) */
+			/* EVM report is reported by stream, not path */
+			rx_path_pwr_db = phy_sta_rpt->pwdb[i] - 110;					/* per-path pwdb in dB domain */
+
+			if (pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = phy_sta_rpt->pwdb[i];
+
+			phydm_set_per_path_phy_info(i, rx_path_pwr_db, phy_sta_rpt->rxevm[rx_count - 1],
+				phy_sta_rpt->cfo_tail[i], phy_sta_rpt->rxsnr[i], phy_info);
+
+			/* search maximum pwdb */
+			if (rx_path_pwr_db > rx_pwr_db)
+				rx_pwr_db = rx_path_pwr_db;
+		}
+	}
+
+	/* mapping RX counter from 1~4 to 0~3 */
+	if (rx_count > 0)
+		phy_info->rx_count = rx_count - 1;
+
+	/* Check if MU packet or not */
+	if ((phy_sta_rpt->gid != 0) && (phy_sta_rpt->gid != 63)) {
+		is_mu = true;
+		dm->phy_dbg_info.num_qry_mu_pkt++;
+	} else
+		is_mu = false;
+
+	/* count BF packet */
+	dm->phy_dbg_info.num_qry_bf_pkt = dm->phy_dbg_info.num_qry_bf_pkt + phy_sta_rpt->beamformed;
+
+	/*STBC or LDPC pkt*/
+	dm->phy_dbg_info.is_ldpc_pkt = phy_sta_rpt->ldpc;
+	dm->phy_dbg_info.is_stbc_pkt = phy_sta_rpt->stbc;
+
+	/* Check sub-channel */
+	if ((pktinfo->data_rate > ODM_RATE11M) && (pktinfo->data_rate < ODM_RATEMCS0))
+		rxsc = phy_sta_rpt->l_rxsc;
+	else
+		rxsc = phy_sta_rpt->ht_rxsc;
+
+	/* Check RX bandwidth */
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if ((rxsc >= 1) && (rxsc <= 8))
+			bw = CHANNEL_WIDTH_20;
+		else if ((rxsc >= 9) && (rxsc <= 12))
+			bw = CHANNEL_WIDTH_40;
+		else if (rxsc >= 13)
+			bw = CHANNEL_WIDTH_80;
+		else
+			bw = phy_sta_rpt->rf_mode;
+		
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (phy_sta_rpt->rf_mode == 0)
+			bw = CHANNEL_WIDTH_20;
+		else if ((rxsc == 1) || (rxsc == 2))
+			bw = CHANNEL_WIDTH_20;
+		else
+			bw = CHANNEL_WIDTH_40;
+	}
+
+	/* Update packet information */
+	phydm_set_common_phy_info(rx_pwr_db, phy_sta_rpt->channel, (boolean)phy_sta_rpt->beamformed,
+		is_mu, bw, phy_info->rx_mimo_signal_quality[0], rxsc, phy_info);
+
+	phydm_parsing_cfo(dm, pktinfo, phy_sta_rpt->cfo_tail, pktinfo->rate_ss);
+
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sta_rpt->antidx_d;
+	#endif
+}
+
+void
+phydm_get_rx_phy_status_type2(
+	struct dm_struct		*dm,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	struct phy_status_rpt_jaguar2_type2	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type2 *)phy_status_inf;
+	s8	rx_pwr_db_max = -120;
+	s8	rx_path_pwr_db;
+	u8	i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
+	
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			
+			rx_count++;
+			
+			if (rx_count > dm->num_rf_path)
+				break;
+
+			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO sq) */
+			#if (RTL8197F_SUPPORT == 1)
+			if ((dm->support_ic_type & ODM_RTL8197F) && (phy_sta_rpt->pwdb[i] == 0x7f)) { /*for 97f workaround*/
+
+				if (i == RF_PATH_A) {
+					rx_path_pwr_db = (phy_sta_rpt->gain_a) << 1;
+					rx_path_pwr_db = rx_path_pwr_db - 110;
+				} else if (i == RF_PATH_B) {
+					rx_path_pwr_db = (phy_sta_rpt->gain_b) << 1;
+					rx_path_pwr_db = rx_path_pwr_db - 110;
+				} else
+					rx_path_pwr_db = 0;
+			} else
+			#endif
+				rx_path_pwr_db = phy_sta_rpt->pwdb[i] - 110;	/*unit: (dBm)*/
+
+			phydm_set_per_path_phy_info(i, rx_path_pwr_db, 0, 0, 0, phy_info);
+
+			if (rx_path_pwr_db > rx_pwr_db_max	 /* search maximum pwdb */)
+				rx_pwr_db_max = rx_path_pwr_db;
+		}
+	}
+
+	/* mapping RX counter from 1~4 to 0~3 */
+	if (rx_count > 0)
+		phy_info->rx_count = rx_count - 1;
+
+	/* Check RX sub-channel */
+	if ((pktinfo->data_rate > ODM_RATE11M) && (pktinfo->data_rate < ODM_RATEMCS0))
+		rxsc = phy_sta_rpt->l_rxsc;
+	else
+		rxsc = phy_sta_rpt->ht_rxsc;
+
+	/*STBC or LDPC pkt*/
+	dm->phy_dbg_info.is_ldpc_pkt = phy_sta_rpt->ldpc;
+	dm->phy_dbg_info.is_stbc_pkt = phy_sta_rpt->stbc;
+
+	/* Check RX bandwidth */
+	/* the BW information of sc=0 is useless, because there is no information of RF mode*/
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if ((rxsc >= 1) && (rxsc <= 8))
+			bw = CHANNEL_WIDTH_20;
+		else if ((rxsc >= 9) && (rxsc <= 12))
+			bw = CHANNEL_WIDTH_40;
+		else if (rxsc >= 13)
+			bw = CHANNEL_WIDTH_80;
+
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (rxsc == 3)
+			bw = CHANNEL_WIDTH_40;
+		else if ((rxsc == 1) || (rxsc == 2))
+			bw = CHANNEL_WIDTH_20;
+	}
+
+	/* Update packet information */
+	phydm_set_common_phy_info(rx_pwr_db_max, phy_sta_rpt->channel, (boolean)phy_sta_rpt->beamformed,
+				  false, bw, 0, rxsc, phy_info);
+}
+
+void
+phydm_process_rssi_for_dm_new_type(
+	struct dm_struct			*dm,
+	struct phydm_phyinfo_struct		*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	s32				rssi_pre;
+	u32				rssi_linear = 0;
+	s16				rssi_avg_db = 0;
+	u8				i;
+	struct cmn_sta_info	*sta;
+
+	if (pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
+		return;
+
+	sta = dm->phydm_sta_info[pktinfo->station_id];
+
+	if (!is_sta_active(sta))
+		return;
+
+	if ((!pktinfo->is_packet_match_bssid))/*data frame only*/
+		return;
+
+	if (pktinfo->is_packet_beacon)
+		dm->phy_dbg_info.num_qry_beacon_pkt++;
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	if (dm->support_ability & ODM_BB_ANT_DIV)
+		odm_process_rssi_for_ant_div(dm, phy_info, pktinfo);
+#endif
+
+#ifdef CONFIG_ADAPTIVE_SOML
+phydm_rx_qam_for_soml(dm, pktinfo);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_process_phy_status_for_dynamic_rx_path(dm, phy_info, pktinfo);
+#endif
+
+	if (pktinfo->is_packet_to_self || pktinfo->is_packet_beacon) {
+		rssi_pre = sta->rssi_stat.rssi;
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			if (phy_info->rx_mimo_signal_strength[i] != 0)
+				rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[i]);
+		}
+
+		switch (phy_info->rx_count + 1) {
+		case 2:
+			rssi_linear = (rssi_linear >> 1);
+			break;
+		case 3:
+			rssi_linear = ((rssi_linear) + (rssi_linear << 1) + (rssi_linear << 3)) >> 5;	/* rssi_linear/3 ~ rssi_linear*11/32 */
+			break;
+		case 4:
+			rssi_linear = (rssi_linear >> 2);
+			break;
+		}
+		
+		rssi_avg_db = (s16)odm_convert_to_db(rssi_linear);
+
+		if (rssi_pre <= 0) {
+			sta->rssi_stat.rssi_acc = (s16)(phy_info->rx_pwdb_all << RSSI_MA_FACTOR);
+			sta->rssi_stat.rssi = (s8)(phy_info->rx_pwdb_all);
+		} else {
+			sta->rssi_stat.rssi_acc = sta->rssi_stat.rssi_acc - (sta->rssi_stat.rssi_acc >> RSSI_MA_FACTOR) + rssi_avg_db;
+			sta->rssi_stat.rssi = (s8)((sta->rssi_stat.rssi_acc + (1 << (RSSI_MA_FACTOR - 1))) >> RSSI_MA_FACTOR);
+		}
+
+		#if 0
+		if (pktinfo->is_packet_match_bssid) {
+			PHYDM_DBG(dm, DBG_TMP, "RSSI[%d]{A,B,Avg}=%d, %d, %d\n", 
+				pktinfo->station_id, phy_info->rx_mimo_signal_strength[0], 
+				phy_info->rx_mimo_signal_strength[1], rssi_ave);
+			PHYDM_DBG(dm, DBG_TMP, "{new, old}=%d, %d\n", sta->rssi_stat.rssi, rssi_pre);
+		}
+		#endif
+		
+		if (pktinfo->is_cck_rate)
+			sta->rssi_stat.rssi_cck = (s8)rssi_avg_db;
+		else
+			sta->rssi_stat.rssi_ofdm = (s8)rssi_avg_db;
+
+
+	}
+}
+
+void
+phydm_rx_phy_status_new_type(
+	void							*dm_void,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct		*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#ifdef PHYDM_PHYSTAUS_SMP_MODE
+	struct pkt_process_info			*pkt_process = &dm->pkt_proc_struct;
+#endif
+	u8		phy_status_type = (*phy_status_inf & 0xf);
+
+#ifdef PHYDM_PHYSTAUS_SMP_MODE
+	if (pkt_process->phystatus_smp_mode_en && phy_status_type != 0) {
+		if (pkt_process->pre_ppdu_cnt == pktinfo->ppdu_cnt)
+			return;
+
+		pkt_process->pre_ppdu_cnt = pktinfo->ppdu_cnt;
+	}
+#endif
+	
+	phydm_reset_phy_info(dm, phy_info); /* Memory reset */
+	
+	/* Phy status parsing */
+	switch (phy_status_type) {
+	case 0:	/*CCK*/
+		phydm_get_rx_phy_status_type0(dm, phy_status_inf, pktinfo, phy_info);
+		break;
+	case 1:
+		phydm_get_rx_phy_status_type1(dm, phy_status_inf, pktinfo, phy_info);
+		break;
+	case 2:
+		phydm_get_rx_phy_status_type2(dm, phy_status_inf, pktinfo, phy_info);
+		break;
+	default:
+		break;
+	}
+	
+	#if (RTL8822B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_print_phy_status_jarguar2(dm, phy_status_inf, pktinfo, phy_info, phy_status_type);
+	#endif
+	
+}
+/*==============================================*/
+#endif
+
+void
+odm_phy_status_query(
+	struct dm_struct		*dm,
+	struct phydm_phyinfo_struct	*phy_info,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo
+)
+{
+	pktinfo->is_cck_rate = (pktinfo->data_rate <= ODM_RATE11M) ? true : false;
+	pktinfo->rate_ss = phydm_rate_to_num_ss(dm, pktinfo->data_rate);
+	dm->rate_ss = pktinfo->rate_ss;	/*For AP EVM SW antenna diversity use*/
+
+	if (pktinfo->is_cck_rate)
+		dm->phy_dbg_info.num_qry_phy_status_cck++;
+	else
+		dm->phy_dbg_info.num_qry_phy_status_ofdm++;
+	
+	/*Reset phy_info*/
+	odm_memory_set(dm, phy_info->rx_mimo_signal_strength, 0, 4);
+	odm_memory_set(dm, phy_info->rx_mimo_signal_quality, 0, 4);
+	
+	if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		phydm_rx_phy_status_new_type(dm, phy_status_inf, pktinfo, phy_info);
+		phydm_process_rssi_for_dm_new_type(dm, phy_info, pktinfo);
+		#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		#if	ODM_IC_11AC_SERIES_SUPPORT
+		phydm_rx_phy_status_jaguar_series_parsing(dm, phy_info, phy_status_inf, pktinfo);
+		phydm_process_rssi_for_dm(dm, phy_info, pktinfo);
+		#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		#if	ODM_IC_11N_SERIES_SUPPORT
+		phydm_rx_phy_status92c_series_parsing(dm, phy_info, phy_status_inf, pktinfo);
+		phydm_process_rssi_for_dm(dm, phy_info, pktinfo);
+		#endif
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_process_signal_strength(dm, phy_info, pktinfo);
+	#endif
+
+	if (pktinfo->is_packet_match_bssid) {
+		
+		dm->rx_rate = pktinfo->data_rate;
+		dm->rssi_a = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+		dm->rssi_b = phy_info->rx_mimo_signal_strength[RF_PATH_B];
+		dm->rssi_c = phy_info->rx_mimo_signal_strength[RF_PATH_C];
+		dm->rssi_d = phy_info->rx_mimo_signal_strength[RF_PATH_D];
+		
+		phydm_avg_phystatus_index(dm, phy_info, pktinfo);
+		phydm_rx_statistic_cal(dm, phy_info, phy_status_inf, pktinfo);
+	}
+}
+
+void
+phydm_rx_phy_status_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+#ifdef PHYDM_PHYSTAUS_SMP_MODE	
+	struct pkt_process_info			*pkt_process = &dm->pkt_proc_struct;
+
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		pkt_process->phystatus_smp_mode_en = 1;
+		pkt_process->pre_ppdu_cnt = 0xff;
+
+		odm_set_mac_reg(dm, 0x60f, BIT(7), 1); /*phystatus sampling mode enable*/
+
+		odm_set_bb_reg(dm, 0x9e4, 0x3ff, 0x0); /*First update timming*/
+		odm_set_bb_reg(dm, 0x9e4, 0xfc00, 0x0); /*Update Sampling time*/
+	}
+#endif
+
+	dbg->show_phy_sts_all_pkt = 0;
+	dbg->show_phy_sts_max_cnt = 1;
+	dbg->show_phy_sts_cnt = 0;
+	
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_phystatus.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_phystatus.h
new file mode 100644
index 000000000000..453d75bc639e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_phystatus.h
@@ -0,0 +1,1083 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_PHYSTATUS_H__
+#define	__PHYDM_PHYSTATUS_H__
+
+
+/*--------------------------Define -------------------------------------------*/
+#define	CCK_RSSI_INIT_COUNT 5
+
+#define	RA_RSSI_STATE_INIT	0
+#define	RA_RSSI_STATE_SEND	1
+#define	RA_RSSI_STATE_HOLD	2
+
+#define	CFO_HW_RPT_2_KHZ(val) ((val<<1) + (val>>1))
+/* (X* 312.5 Khz)>>7 ~=  X*2.5 Khz= (X<<1 + X>>1)Khz  */
+
+#define	IGI_2_RSSI(igi)	(igi - 10)
+
+#define	PHY_STATUS_JRGUAR2_DW_LEN		7	/* 7*4 = 28 Byte */
+#define	SHOW_PHY_STATUS_UNLIMITED		0
+#define	RSSI_MA_FACTOR					4
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+__PACK struct phy_rx_agc_info {
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8	gain: 7, trsw: 1;
+#else
+	u8	trsw: 1, gain: 7;
+#endif
+};
+
+__PACK struct phy_status_rpt_8192cd {
+	struct phy_rx_agc_info path_agc[2];
+	u8	ch_corr[2];
+	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;
+	s8	path_cfotail[2];
+	u8	pcts_mask[2];
+	s8	stream_rxevm[2];
+	u8	path_rxsnr[2];
+	u8	noise_power_db_lsb;
+	u8	rsvd_2[3];
+	u8	stream_csi[2];
+	u8	stream_target_csi[2];
+	s8	sig_evm;
+	u8	rsvd_3;
+
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	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_8812 {
+	/*	DWORD 0*/
+	u8			gain_trsw[2];							/*path-A and path-B {TRSW, gain[6:0] }*/
+	u8			chl_num_LSB;							/*channel number[7:0]*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			chl_num_MSB: 2;							/*channel number[9:8]*/
+	u8			sub_chnl: 4;								/*sub-channel location[3:0]*/
+	u8			r_RFMOD: 2;								/*RF mode[1:0]*/
+#else	/*_BIG_ENDIAN_	*/
+	u8			r_RFMOD: 2;
+	u8			sub_chnl: 4;
+	u8			chl_num_MSB: 2;
+#endif
+
+	/*	DWORD 1*/
+	u8			pwdb_all;								/*CCK signal quality / OFDM pwdb all*/
+	s8			cfosho[2];		/*DW1 byte 1 DW1 byte2	CCK AGC report and CCK_BB_Power / OFDM path-A and path-B short CFO*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	/*this should be checked again because the definition of 8812 and 8814 is different*/
+	/*	u8			r_cck_rx_enable_pathc:2;					cck rx enable pathc[1:0]*/
+	/*	u8			cck_rx_path:4;							cck rx path[3:0]*/
+	u8			resvd_0: 6;
+	u8			bt_RF_ch_MSB: 2;						/*8812A:2'b0			8814A: bt rf channel keep[7:6]*/
+#else	/*_BIG_ENDIAN_*/
+	u8			bt_RF_ch_MSB: 2;
+	u8			resvd_0: 6;
+#endif
+
+	/*	DWORD 2*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			ant_div_sw_a: 1;							/*8812A: ant_div_sw_a    8814A: 1'b0*/
+	u8			ant_div_sw_b: 1;							/*8812A: ant_div_sw_b    8814A: 1'b0*/
+	u8			bt_RF_ch_LSB: 6;						/*8812A: 6'b0                   8814A: bt rf channel keep[5:0]*/
+#else	/*_BIG_ENDIAN_	*/
+	u8			bt_RF_ch_LSB: 6;
+	u8			ant_div_sw_b: 1;
+	u8			ant_div_sw_a: 1;
+#endif
+	s8			cfotail[2];		   /*DW2 byte 1 DW2 byte 2	path-A and path-B CFO tail*/
+	u8			PCTS_MSK_RPT_0;						/*PCTS mask report[7:0]*/
+	u8			PCTS_MSK_RPT_1;						/*PCTS mask report[15:8]*/
+
+	/*	DWORD 3*/
+	s8			rxevm[2];	         /*DW3 byte 1 DW3 byte 2	stream 1 and stream 2 RX EVM*/
+	s8			rxsnr[2];	         /*DW3 byte 3 DW4 byte 0	path-A and path-B RX SNR*/
+
+	/*	DWORD 4*/
+	u8			PCTS_MSK_RPT_2;						/*PCTS mask report[23:16]*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			PCTS_MSK_RPT_3: 6;						/*PCTS mask report[29:24]*/
+	u8			pcts_rpt_valid: 1;							/*pcts_rpt_valid*/
+	u8			resvd_1: 1;								/*1'b0*/
+#else	/*_BIG_ENDIAN_*/
+	u8			resvd_1: 1;
+	u8			pcts_rpt_valid: 1;
+	u8			PCTS_MSK_RPT_3: 6;
+#endif
+	s8			rxevm_cd[2];	   /*DW 4 byte 3 DW5 byte 0  8812A: 16'b0	8814A: stream 3 and stream 4 RX EVM*/
+
+	/*	DWORD 5*/
+	u8			csi_current[2];	   /*DW5 byte 1 DW5 byte 2	8812A: stream 1 and 2 CSI	8814A:  path-C and path-D RX SNR*/
+	u8			gain_trsw_cd[2];	   /*DW5 byte 3 DW6 byte 0	path-C and path-D {TRSW, gain[6:0] }*/
+
+	/*	DWORD 6*/
+	s8			sigevm;									/*signal field EVM*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			antidx_antc: 3;							/*8812A: 3'b0		8814A: antidx_antc[2:0]*/
+	u8			antidx_antd: 3;							/*8812A: 3'b0		8814A: antidx_antd[2:0]*/
+	u8			dpdt_ctrl_keep: 1;						/*8812A: 1'b0		8814A: dpdt_ctrl_keep*/
+	u8			GNT_BT_keep: 1;							/*8812A: 1'b0		8814A: GNT_BT_keep*/
+#else	/*_BIG_ENDIAN_*/
+	u8			GNT_BT_keep: 1;
+	u8			dpdt_ctrl_keep: 1;
+	u8			antidx_antd: 3;
+	u8			antidx_antc: 3;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			antidx_anta: 3;							/*antidx_anta[2:0]*/
+	u8			antidx_antb: 3;							/*antidx_antb[2:0]*/
+	u8			hw_antsw_occur: 2;								/*1'b0*/
+#else	/*_BIG_ENDIAN_*/
+	u8			hw_antsw_occur: 2;
+	u8			antidx_antb: 3;
+	u8			antidx_anta: 3;
+#endif
+};
+
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+
+__PACK struct phy_status_rpt_jaguar2_type0 {
+	/* DW0 */
+	u8		page_num;
+	u8		pwdb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		gain: 6;
+	u8		rsvd_0: 1;
+	u8		trsw: 1;
+#else
+	u8		trsw: 1;
+	u8		rsvd_0: 1;
+	u8		gain: 6;
+#endif
+	u8		rsvd_1;
+
+	/* DW1 */
+	u8		rsvd_2;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rxsc: 4;
+	u8		agc_table: 4;
+#else
+	u8		agc_table: 4;
+	u8		rxsc: 4;
+#endif
+	u8		channel;
+	u8		band;
+
+	/* DW2 */
+	u16		length;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 3;
+	u8		antidx_b: 3;
+	u8		rsvd_3: 2;
+	u8		antidx_c: 3;
+	u8		antidx_d: 3;
+	u8		rsvd_4:2;
+#else
+	u8		rsvd_3: 2;
+	u8		antidx_b: 3;
+	u8		antidx_a: 3;
+	u8		rsvd_4:2;
+	u8		antidx_d: 3;
+	u8		antidx_c: 3;
+#endif
+
+	/* DW3 */
+	u8		signal_quality;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga:5;
+	u8		lna_l:3;
+	u8		bb_power:6;
+	u8		rsvd_9:1;
+	u8		lna_h:1;
+#else
+	u8		lna_l:3;
+	u8		vga:5;
+	u8		lna_h:1;
+	u8		rsvd_9:1;
+	u8		bb_power:6;
+#endif
+	u8		rsvd_5;
+
+	/* DW4 */
+	u32		rsvd_6;
+
+	/* DW5 */
+	u32		rsvd_7;
+
+	/* DW6 */
+	u32		rsvd_8;
+};
+
+__PACK struct phy_status_rpt_jaguar2_type1 {
+	/* DW0 and DW1 */
+	u8		page_num;
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 */
+	u16		lsig_length;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 3;
+	u8		antidx_b: 3;
+	u8		rsvd_1: 2;
+	u8		antidx_c: 3;
+	u8		antidx_d: 3;
+	u8		rsvd_2: 2;
+#else
+	u8		rsvd_1: 2;
+	u8		antidx_b: 3;
+	u8		antidx_a: 3;
+	u8		rsvd_2: 2;
+	u8		antidx_d: 3;
+	u8		antidx_c: 3;
+#endif
+
+	/* DW3 */
+	u8		paid;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		paid_msb: 1;
+	u8		gid: 6;
+	u8		rsvd_3: 1;
+#else
+	u8		rsvd_3: 1;
+	u8		gid: 6;
+	u8		paid_msb: 1;
+#endif
+	u8		intf_pos;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		intf_pos_msb: 1;
+	u8		rsvd_4: 2;
+	u8		nb_intf_flag: 1;
+	u8		rf_mode: 2;
+	u8		rsvd_5: 2;
+#else
+	u8		rsvd_5: 2;
+	u8		rf_mode: 2;
+	u8		nb_intf_flag: 1;
+	u8		rsvd_4: 2;
+	u8		intf_pos_msb: 1;
+#endif
+
+	/* DW4 */
+	s8		rxevm[4];			/* s(8,1) */
+
+	/* DW5 */
+	s8		cfo_tail[4];			/* s(8,7) */
+
+	/* DW6 */
+	s8		rxsnr[4];			/* s(8,1) */
+};
+
+__PACK struct phy_status_rpt_jaguar2_type2 {
+	/* DW0 ane DW1 */
+	u8		page_num;
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		shift_l_map: 6;
+	u8		rsvd_1: 2;
+#else
+	u8		rsvd_1: 2;
+	u8		shift_l_map: 6;
+#endif
+	u8		cnt_pw2cca;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		agc_table_a: 4;
+	u8		agc_table_b: 4;
+	u8		agc_table_c: 4;
+	u8		agc_table_d: 4;
+#else
+	u8		agc_table_b: 4;
+	u8		agc_table_a: 4;
+	u8		agc_table_d: 4;
+	u8		agc_table_c: 4;
+#endif
+
+	/* DW3 ~ DW6*/
+	u8		cnt_cca2agc_rdy;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		gain_a: 6;
+	u8		rsvd_2: 1;
+	u8		trsw_a: 1;
+	u8		gain_b: 6;
+	u8		rsvd_3: 1;
+	u8		trsw_b: 1;
+	u8		gain_c: 6;
+	u8		rsvd_4: 1;
+	u8		trsw_c: 1;
+	u8		gain_d: 6;
+	u8		rsvd_5: 1;
+	u8		trsw_d: 1;
+	u8		aagc_step_a: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_d: 2;
+#else
+	u8		trsw_a: 1;
+	u8		rsvd_2: 1;
+	u8		gain_a: 6;
+	u8		trsw_b: 1;
+	u8		rsvd_3: 1;
+	u8		gain_b: 6;
+	u8		trsw_c: 1;
+	u8		rsvd_4: 1;
+	u8		gain_c: 6;
+	u8		trsw_d: 1;
+	u8		rsvd_5: 1;
+	u8		gain_d: 6;
+	u8		aagc_step_d: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_a: 2;
+#endif
+	u8		ht_aagc_gain[4];
+	u8		dagc_gain[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		counter: 6;
+	u8		rsvd_6: 2;
+	u8		syn_count: 5;
+	u8		rsvd_7:3;
+#else
+	u8		rsvd_6: 2;
+	u8		counter: 6;
+	u8		rsvd_7:3;
+	u8		syn_count: 5;
+#endif
+};
+#endif
+
+/*==============================================*/
+#if (CONFIG_PHYSTS_3RD_TYPE)
+__PACK struct _phy_status_rpt_jaguar3_type0 {
+	/* DW0 : Offset 0 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb_a;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		gain_a: 6;
+	u8		rsvd_0: 1;
+	u8		trsw: 1;
+#else
+	u8		trsw: 1;
+	u8		rsvd_0: 1;
+	u8		gain_a: 6;
+#endif
+
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		agc_table_b:4;
+	u8		agc_table_c:4;
+#else
+	u8		agc_table_c:4;
+	u8		agc_table_b:4;
+#endif
+
+	/* DW1 : Offset 4 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rsvd_1: 4;
+	u8		agc_table_d: 4;
+#else
+	u8		agc_table_d: 4;
+	u8		rsvd_1: 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		agc_table_a: 4;
+#else
+	u8		agc_table_a: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band:2;
+	u8		rsvd_2_1: 1;
+	u8		hw_antsw_occur_keep_cck:1;
+	u8		gnt_bt_keep_cck:1;
+	u8		rsvd_2_2:3;
+#else
+	u8		rsvd_2_2:3;
+	u8		gnt_bt_keep_cck:1;
+	u8		hw_antsw_occur_keep_cck:1;
+	u8		rsvd_2_1: 1;
+	u8		band:2;
+#endif
+
+	/* DW2 : Offset 8 */
+	u16		length;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+
+	/* DW3 : Offset 12 */
+	u8		signal_quality;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_a:5;
+	u8		lna_l_a:3;
+	u8		bb_power_a:6;
+	u8		rsvd_3_1:1;
+	u8		lna_h_a:1;
+#else
+	u8		lna_l_a:3;
+	u8		vga_a:5;
+	u8		lna_h_a:1;
+	u8		rsvd_3_1:1;
+	u8		bb_power_a:6;
+#endif
+	u8		rsvd_3_2;
+
+	/* DW4 : Offset 16 */
+	u8		pwdb_b;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_b:5;
+	u8		lna_l_b:3;
+	u8		bb_power_b:6;
+	u8		rsvd_4_1:1;
+	u8		lna_h_b:1;
+	u8		gain_b: 6;
+	u8		rsvd_4_2:2;
+#else
+	u8		lna_l_b:3;
+	u8		vga_b:5;
+	u8		lna_h_b:1;
+	u8		rsvd_4_1:1;
+	u8		bb_power_b:6;
+	u8		rsvd_4_2:2;
+	u8		gain_b: 6;
+#endif
+
+	/* DW5 : Offset 20 */
+	u8		pwdb_c;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_c:5;
+	u8		lna_l_c:3;
+	u8		bb_power_c:6;
+	u8		rsvd_5_1:1;
+	u8		lna_h_c:1;
+	u8		gain_c: 6;
+	u8		rsvd_5_2:2;
+#else
+	u8		lna_l_c:3;
+	u8		vga_c:5;
+	u8		lna_h_c:1;
+	u8		rsvd_5_1:1;
+	u8		bb_power_c:6;
+	u8		rsvd_5_2:2;
+	u8		gain_c: 6;
+#endif
+
+	/* DW6 : Offset 24 */
+	u8		pwdb_d;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_d:5;
+	u8		lna_l_d:3;
+	u8		bb_power_d:6;
+	u8		rsvd_6_1:1;
+	u8		lna_h_d:1;
+	u8		gain_d: 6;
+	u8		rsvd_6_2:2;
+#else
+	u8		lna_l_d:3;
+	u8		vga_d:5;
+	u8		lna_h_d:1;
+	u8		rsvd_6_1:1;
+	u8		bb_power_d:6;
+	u8		rsvd_6_2:2;
+	u8		gain_d: 6;
+#endif
+};
+
+__PACK struct _phy_status_rpt_jaguar3_type1 {
+	/* DW0 : Offset 0 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_pri_msb:2;
+#else
+	u8		channel_pri_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb_a;
+	u8		pwdb_b;
+	u8		pwdb_c;
+
+	/* DW1 : Offset 4 */
+	u8		pwdb_d;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_pri_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 2;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		rsvd_0: 2;
+	u8		band: 2;
+#endif
+
+	/* DW2 : Offset 8 */
+	u8		channel_sec_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		channel_sec_msb:2;
+	u8		rsvd_1: 2;
+	u8		hw_antsw_occur_a:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_d:1;
+#else
+	u8		hw_antsw_occur_d:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_a:1;
+	u8		rsvd_1: 2;
+	u8		channel_sec_msb:2;
+
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+
+	/* DW3 : Offset 12 */
+	u8		paid;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		paid_msb: 1;
+	u8		gid: 6;
+	u8		rsvd_3: 1;
+#else
+	u8		rsvd_3: 1;
+	u8		gid: 6;
+	u8		paid_msb: 1;
+#endif
+	u16		rsvd_4;
+/*
+	u8		rsvd_4;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rsvd_5: 6;
+	u8		rf_mode: 2;
+#else
+	u8		rf_mode: 2;
+	u8		rsvd_5: 6;
+#endif
+*/
+	/* DW4 */
+	s8		rxevm[4];			/* s(8,1) */
+
+	/* DW5 */
+	s8		cfo_tail[4];			/* s(8,7) */
+
+	/* DW6 */
+	s8		rxsnr[4];			/* s(8,1) */
+};
+__PACK struct _phy_status_rpt_jaguar3_type2_type3 {
+	/* Type2 is primary channel & type3 is secondary channel */
+	/* DW0 ane DW1 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		shift_l_map: 6;
+	u8		rsvd_1: 2;
+#else
+	u8		rsvd_1: 2;
+	u8		shift_l_map: 6;
+#endif
+	s8		pwed_th;	/* dynamic energy threshold S(8,2) */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		agc_table_a: 4;
+	u8		agc_table_b: 4;
+	u8		agc_table_c: 4;
+	u8		agc_table_d: 4;
+#else
+	u8		agc_table_b: 4;
+	u8		agc_table_a: 4;
+	u8		agc_table_d: 4;
+	u8		agc_table_c: 4;
+#endif
+
+	/* DW3 ~ DW6*/
+	u8		cnt_cca2agc_rdy; /* Time(ns) = cnt_cca2agc_ready*25 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		mp_gain_a: 6;
+	u8		mp_gain_b_lsb: 2;
+	u8		mp_gain_b_msb: 4;
+	u8		mp_gain_c_lsb: 4;
+	u8		mp_gain_c_msb: 2;
+	u8		avg_noise_pwr_lsb: 4;
+	u8		rsvd_3:2;
+	/* u8		r_rfmod:2; */
+	u8		mp_gain_d: 6;
+	u8		is_freq_select_fading: 1;
+	u8		rsvd_2: 1;
+	u8		aagc_step_a: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_d: 2;
+#else
+	u8		mp_gain_b_lsb: 2;
+	u8		mp_gain_a: 6;
+	u8		mp_gain_c_lsb: 4;
+	u8		mp_gain_b_msb: 4;
+	u8		rsvd_3:2;
+	/* u8		r_rfmod:2; */
+	u8		avg_noise_pwr_lsb: 4;
+	u8		mp_gain_c_msb: 2;
+	u8		rsvd_2: 1;
+	u8		is_freq_select_fading: 1;
+	u8		mp_gain_d: 6;
+	u8		aagc_step_d: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_a: 2;
+#endif
+	u8		ht_aagc_gain[4];
+	u8		dagc_gain[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		counter: 6;
+	u8		syn_count_lsb: 2;
+	u8		syn_count_msb: 3;
+	u8		avg_noise_pwr_msb:5;
+#else
+	u8		syn_count_lsb: 2;
+	u8		counter: 6;
+	u8		avg_noise_pwr_msb:5;
+	u8		syn_count_msb: 3;
+#endif
+};
+
+__PACK struct _phy_status_rpt_jaguar3_type4 {
+	/* smart antenna */
+	/* DW0 ane DW1 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 ~ DW3 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		bad_tone_cnt_min_eign_0:4;
+	u8		bad_tone_cnt_cn_excess_0:4;
+	u8		training_done_a:1;
+	u8		training_done_b:1;
+	u8		training_done_c:1;
+	u8		training_done_d:1;
+	u8		hw_antsw_occur_a:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_d:1;
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		bad_tone_cnt_cn_excess_0:4;
+	u8		bad_tone_cnt_min_eign_0:4;
+	u8		hw_antsw_occur_d:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_a:1;
+	u8		training_done_d:1;
+	u8		training_done_c:1;
+	u8		training_done_b:1;
+	u8		training_done_a:1;
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+	u8		tx_pkt_cnt;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		bad_tone_cnt_min_eign_1:4;
+	u8		bad_tone_cnt_cn_excess_1:4;
+	u8		avg_cond_num_0:7;
+	u8		avg_cond_num_1_lsb:1;
+	u8		avg_cond_num_1_msb:6;
+	u8		rsvd_1:2;
+#else
+	u8		bad_tone_cnt_cn_excess_1:4;
+	u8		bad_tone_cnt_min_eign_1:4;
+	u8		avg_cond_num_1_lsb:1;
+	u8		avg_cond_num_0:7;
+	u8		rsvd_1:2;
+	u8		avg_cond_num_1_msb:6;
+#endif
+
+	/* DW4 */
+	s8		rxevm[4];			/* s(8,1) */
+
+	/* DW5 */
+	u8		eigenvalue[4];			/* eigenvalue or eigenvalue of seg0 (in dB) */
+
+	/* DW6 */
+	s8		rxsnr[4];			/* s(8,1) */
+};
+
+__PACK struct _phy_status_rpt_jaguar2_type5 {
+	/* smart antenna */
+	/* DW0 ane DW1 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+	/* DW2 ~ DW5 */
+	u8		rsvd_1;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rsvd_2:4;
+	u8		hw_antsw_occur_a:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_d:1;
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		hw_antsw_occur_d:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_a:1;
+	u8		rsvd_2:4;
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+	u8		tx_pkt_cnt;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		inf_pos_0_A_flg:1;
+	u8		inf_pos_1_A_flg:1;
+	u8		inf_pos_0_B_flg:1;
+	u8		inf_pos_1_B_flg:1;
+	u8		inf_pos_0_C_flg:1;
+	u8		inf_pos_1_C_flg:1;
+	u8		inf_pos_0_D_flg:1;
+	u8		inf_pos_1_D_flg:1;
+#else
+	u8		inf_pos_1_D_flg:1;
+	u8		inf_pos_0_D_flg:1;
+	u8		inf_pos_1_C_flg:1;
+	u8		inf_pos_0_C_flg:1;
+	u8		inf_pos_1_B_flg:1;
+	u8		inf_pos_0_B_flg:1;
+	u8		inf_pos_1_A_flg:1;
+	u8		inf_pos_0_A_flg:1;
+#endif
+	u8		rsvd_3;
+	u8		rsvd_4;
+	u8		inf_pos_0_a;
+	u8		inf_pos_1_a;
+	u8		inf_pos_0_b;
+	u8		inf_pos_1_b;
+	u8		inf_pos_0_c;
+	u8		inf_pos_1_c;
+	u8		inf_pos_0_d;
+	u8		inf_pos_1_d;
+};
+#endif /*#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)*/
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+
+void
+phydm_rx_phy_status_new_type(
+	void						*dm_void,
+	u8						*phy_status_inf,
+	struct phydm_perpkt_info_struct			*pktinfo,
+	struct phydm_phyinfo_struct			*phy_info
+);
+
+boolean
+phydm_query_is_mu_api(
+	struct dm_struct			*phydm,
+	u8								ppdu_idx,
+	u8								*p_data_rate,
+	u8								*p_gid
+);
+#endif
+
+void
+phydm_reset_phystatus_avg(
+	struct dm_struct	*dm
+);
+
+void
+phydm_reset_phystatus_statistic(
+	struct dm_struct	*dm
+);
+
+void
+phydm_reset_rssi_for_dm(
+	struct dm_struct	*dm,
+	u8		station_id
+);
+
+void
+phydm_get_cck_rssi_table_from_reg(
+	struct dm_struct	*dm
+);
+
+u8
+phydm_rate_to_num_ss(
+	struct dm_struct		*dm,
+	u8			data_rate
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_normal_driver_rx_sniffer(
+	struct dm_struct			*dm,
+	u8				*desc,
+	PRT_RFD_STATUS		rt_rfd_status,
+	u8				*drv_info,
+	u8				phy_status
+);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+s32
+phydm_signal_scale_mapping(
+	struct dm_struct *dm,
+	s32 curr_sig
+);
+#endif
+
+void
+odm_phy_status_query(
+	struct dm_struct					*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	u8						*phy_status_inf,
+	struct phydm_perpkt_info_struct			*pktinfo
+);
+
+void
+phydm_rx_phy_status_init(
+	void			*dm_void
+);
+
+#endif /*#ifndef	__HALHWOUTSRC_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pow_train.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pow_train.c
new file mode 100644
index 000000000000..477f5d13fc3e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pow_train.c
@@ -0,0 +1,228 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+void
+phydm_reset_pt_para(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc	*pow_train_t = &dm->pow_train_table;
+
+	pow_train_t->pow_train_score = 0;
+	dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+	dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+}
+
+void
+phydm_update_power_training_state(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc	*pow_train_t = &dm->pow_train_table;
+	struct phydm_fa_struct			*fa_cnt = &dm->false_alm_cnt;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+	u32	pt_score_tmp = 0;
+	u32 crc_ok_cnt;
+	u32 cca_all_cnt;
+
+
+	/*is_disable_power_training is the key to H2C to disable/enable power training*/
+	/*if is_disable_power_training == 1, it will use largest power*/
+	if (!(dm->support_ability & ODM_BB_PWR_TRAIN)) {
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_PWR_TRAIN, "%s ======>\n", __FUNCTION__);
+
+	if (pow_train_t->force_power_training_state == DISABLE_POW_TRAIN) {
+		
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Disable PT\n");
+		return;
+
+	} else if (pow_train_t->force_power_training_state == ENABLE_POW_TRAIN) {
+	
+		dm->is_disable_power_training = false;
+		phydm_reset_pt_para(dm);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Enable PT\n");
+		return;
+
+	} else if (pow_train_t->force_power_training_state == DYNAMIC_POW_TRAIN) {
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Dynamic PT\n");
+
+		if (!dm->is_linked) {
+			dm->is_disable_power_training = true;
+			pow_train_t->pow_train_score = 0;
+			dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+			dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "PT is disabled due to no link.\n");
+			return;
+		}
+
+		/* First connect */
+		if ((dm->is_linked) && (!dig_t->is_media_connect)) {
+			pow_train_t->pow_train_score = 0;
+			dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+			dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "(PT)First Connect\n");
+			return;
+		}
+
+		/* Compute score */
+		crc_ok_cnt = dm->phy_dbg_info.num_qry_phy_status_ofdm + dm->phy_dbg_info.num_qry_phy_status_cck;
+		cca_all_cnt = fa_cnt->cnt_cca_all;
+
+		if (crc_ok_cnt < cca_all_cnt) {
+			/* crc_ok <= (2/3)*cca */
+			if ((crc_ok_cnt + (crc_ok_cnt >> 1)) <= cca_all_cnt)
+				pt_score_tmp = DISABLE_PT_SCORE;
+
+			/* crc_ok <= (4/5)*cca */
+			else if ((crc_ok_cnt + (crc_ok_cnt >> 2)) <= cca_all_cnt)
+				pt_score_tmp = KEEP_PRE_PT_SCORE;
+
+			/* crc_ok > (4/5)*cca */
+			else
+				pt_score_tmp = ENABLE_PT_SCORE;
+		} else {
+			pt_score_tmp = ENABLE_PT_SCORE;
+		}
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "crc_ok_cnt = %d, cnt_cca_all = %d\n",
+				crc_ok_cnt, cca_all_cnt);
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "num_qry_phy_status_ofdm = %d, num_qry_phy_status_cck = %d\n",
+			dm->phy_dbg_info.num_qry_phy_status_ofdm, dm->phy_dbg_info.num_qry_phy_status_cck);
+		
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "pt_score_tmp = %d\n", pt_score_tmp);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "pt_score_tmp = 0(DISABLE), 1(KEEP), 2(ENABLE)\n");
+
+		/* smoothing */
+		pow_train_t->pow_train_score = (pt_score_tmp << 4) + (pow_train_t->pow_train_score >> 1) + (pow_train_t->pow_train_score >> 2);
+		pt_score_tmp = (pow_train_t->pow_train_score + 32) >> 6;
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "pow_train_score = %d, score after smoothing = %d\n",
+				pow_train_t->pow_train_score, pt_score_tmp);
+
+		/* mode decision */
+		if (pt_score_tmp == ENABLE_PT_SCORE) {
+			
+			dm->is_disable_power_training = false;
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "Enable power training under dynamic.\n");
+			
+		} else if (pt_score_tmp == DISABLE_PT_SCORE) {
+		
+			dm->is_disable_power_training = true;
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "Disable PT due to noisy.\n");
+		}
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Final, score = %d, is_disable_power_training = %d\n",
+			pt_score_tmp, dm->is_disable_power_training);
+
+		dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+		dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+	} else {
+	
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "PT is disabled due to unknown pt state.\n");
+		return;
+	}
+}
+
+void
+phydm_pow_train_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc	*pow_train_t = &dm->pow_train_table;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "0: Dynamic state\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "1: Enable PT\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "2: Disable PT\n");
+		
+	} else {
+		for (i = 0; i < 10; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+			}
+		}
+
+		if (var1[0] == 0) {
+			pow_train_t->force_power_training_state = DYNAMIC_POW_TRAIN;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Dynamic state\n");
+		} else if (var1[0] == 1) {
+			pow_train_t->force_power_training_state = ENABLE_POW_TRAIN;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Enable PT\n");
+		} else if (var1[0] == 2) {
+			pow_train_t->force_power_training_state = DISABLE_POW_TRAIN;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Disable PT\n");
+		} else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Set Error\n");
+		}		
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif
+
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pow_train.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pow_train.h
new file mode 100644
index 000000000000..0b4e9387438d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pow_train.h
@@ -0,0 +1,86 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_POW_TRAIN_H__
+#define    __PHYDM_POW_TRAIN_H__
+
+#define POW_TRAIN_VERSION	"1.0"		/* 2017.07.0141  Dino, Add phydm_pow_train.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+struct phydm_pow_train_stuc {
+	u8		force_power_training_state;
+	u32		pow_train_score;
+};
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+enum pow_train_state {
+	DYNAMIC_POW_TRAIN = 0,
+	ENABLE_POW_TRAIN = 1,
+	DISABLE_POW_TRAIN = 2
+};
+
+enum power_training_score {
+	DISABLE_PT_SCORE = 0,
+	KEEP_PRE_PT_SCORE = 1,
+	ENABLE_PT_SCORE = 2
+};
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_update_power_training_state(
+	void		*dm_void
+);
+
+void
+phydm_pow_train_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pre_define.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pre_define.h
new file mode 100644
index 000000000000..91dc0c11700d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_pre_define.h
@@ -0,0 +1,747 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDMPREDEFINE_H__
+#define    __PHYDMPREDEFINE_H__
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define PHYDM_CODE_BASE		"PHYDM_V024"
+#define PHYDM_RELEASE_DATE		"20171213"
+
+/*PHYDM API status*/
+#define	PHYDM_SET_FAIL		0
+#define	PHYDM_SET_SUCCESS	1
+#define	PHYDM_SET_NO_NEED	3
+
+/*PHYDM Set/Revert*/
+#define	PHYDM_SET				1
+#define	PHYDM_REVERT			2
+
+/* Max path of IC */
+/*N-IC*/
+#define MAX_PATH_NUM_8188E		1
+#define MAX_PATH_NUM_8188F		1
+#define MAX_PATH_NUM_8710B		1
+#define MAX_PATH_NUM_8723B		1
+#define MAX_PATH_NUM_8723D		1
+#define MAX_PATH_NUM_8703B		1
+#define MAX_PATH_NUM_8192E		2
+#define MAX_PATH_NUM_8192F		2
+#define MAX_PATH_NUM_8197F		2
+#define MAX_PATH_NUM_8198F		4
+/*AC-IC*/
+#define MAX_PATH_NUM_8821A		1
+#define MAX_PATH_NUM_8881A		1
+#define MAX_PATH_NUM_8821C		1
+#define MAX_PATH_NUM_8195B		1
+#define MAX_PATH_NUM_8812A		2
+#define MAX_PATH_NUM_8822B		2
+#define MAX_PATH_NUM_8822C		2
+#define MAX_PATH_NUM_8814A		4
+#define MAX_PATH_NUM_8814B		4
+#define MAX_PATH_NUM_8814C		4
+
+/* Max RF path */
+#define PHYDM_MAX_RF_PATH_N		2	/*For old N-series IC*/
+#define PHYDM_MAX_RF_PATH			4
+
+/* number of entry */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	#ifdef DM_ODM_CE_MAC80211
+		/* defined in wifi.h (32+1) */
+	#else
+		#define	ASSOCIATE_ENTRY_NUM					MACID_NUM_SW_LIMIT  /* Max size of asoc_entry[].*/
+	#endif
+	#define	ODM_ASSOCIATE_ENTRY_NUM				ASSOCIATE_ENTRY_NUM
+#elif(DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	#define ASSOCIATE_ENTRY_NUM					NUM_STAT
+	#define	ODM_ASSOCIATE_ENTRY_NUM				(ASSOCIATE_ENTRY_NUM+1)
+#else
+	#define ODM_ASSOCIATE_ENTRY_NUM				((ASSOCIATE_ENTRY_NUM*3)+1)
+#endif
+
+/* -----MGN rate--------------------------------- */
+
+enum ODM_MGN_RATE {
+	ODM_MGN_1M		= 0x02,
+	ODM_MGN_2M		= 0x04,
+	ODM_MGN_5_5M		= 0x0B,
+	ODM_MGN_6M		= 0x0C,
+	ODM_MGN_9M		= 0x12,
+	ODM_MGN_11M		= 0x16,
+	ODM_MGN_12M		= 0x18,
+	ODM_MGN_18M		= 0x24,
+	ODM_MGN_24M		= 0x30,
+	ODM_MGN_36M		= 0x48,
+	ODM_MGN_48M		= 0x60,
+	ODM_MGN_54M		= 0x6C,
+	ODM_MGN_MCS32	= 0x7F,
+	ODM_MGN_MCS0		= 0x80,
+	ODM_MGN_MCS1,
+	ODM_MGN_MCS2,
+	ODM_MGN_MCS3,
+	ODM_MGN_MCS4,
+	ODM_MGN_MCS5,
+	ODM_MGN_MCS6,
+	ODM_MGN_MCS7		= 0x87,
+	ODM_MGN_MCS8,
+	ODM_MGN_MCS9,
+	ODM_MGN_MCS10,
+	ODM_MGN_MCS11,
+	ODM_MGN_MCS12,
+	ODM_MGN_MCS13,
+	ODM_MGN_MCS14,
+	ODM_MGN_MCS15,
+	ODM_MGN_MCS16	= 0x90,
+	ODM_MGN_MCS17,
+	ODM_MGN_MCS18,
+	ODM_MGN_MCS19,
+	ODM_MGN_MCS20,
+	ODM_MGN_MCS21,
+	ODM_MGN_MCS22,
+	ODM_MGN_MCS23,
+	ODM_MGN_MCS24	= 0x98,
+	ODM_MGN_MCS25,
+	ODM_MGN_MCS26,
+	ODM_MGN_MCS27,
+	ODM_MGN_MCS28,
+	ODM_MGN_MCS29,
+	ODM_MGN_MCS30,
+	ODM_MGN_MCS31,
+	ODM_MGN_VHT1SS_MCS0	= 0xa0,
+	ODM_MGN_VHT1SS_MCS1,
+	ODM_MGN_VHT1SS_MCS2,
+	ODM_MGN_VHT1SS_MCS3,
+	ODM_MGN_VHT1SS_MCS4,
+	ODM_MGN_VHT1SS_MCS5,
+	ODM_MGN_VHT1SS_MCS6,
+	ODM_MGN_VHT1SS_MCS7,
+	ODM_MGN_VHT1SS_MCS8,
+	ODM_MGN_VHT1SS_MCS9,
+	ODM_MGN_VHT2SS_MCS0	= 0xaa,
+	ODM_MGN_VHT2SS_MCS1	= 0xab,
+	ODM_MGN_VHT2SS_MCS2,
+	ODM_MGN_VHT2SS_MCS3,
+	ODM_MGN_VHT2SS_MCS4,
+	ODM_MGN_VHT2SS_MCS5	= 0xaf,
+	ODM_MGN_VHT2SS_MCS6	= 0xb0,
+	ODM_MGN_VHT2SS_MCS7,
+	ODM_MGN_VHT2SS_MCS8,
+	ODM_MGN_VHT2SS_MCS9	= 0xb3,
+	ODM_MGN_VHT3SS_MCS0	= 0xb4,
+	ODM_MGN_VHT3SS_MCS1,
+	ODM_MGN_VHT3SS_MCS2,
+	ODM_MGN_VHT3SS_MCS3,
+	ODM_MGN_VHT3SS_MCS4,
+	ODM_MGN_VHT3SS_MCS5,
+	ODM_MGN_VHT3SS_MCS6,
+	ODM_MGN_VHT3SS_MCS7	= 0xbb,
+	ODM_MGN_VHT3SS_MCS8	= 0xbc,
+	ODM_MGN_VHT3SS_MCS9	= 0xbd,
+	ODM_MGN_VHT4SS_MCS0	= 0xbe,
+	ODM_MGN_VHT4SS_MCS1,
+	ODM_MGN_VHT4SS_MCS2,
+	ODM_MGN_VHT4SS_MCS3,
+	ODM_MGN_VHT4SS_MCS4,
+	ODM_MGN_VHT4SS_MCS5,
+	ODM_MGN_VHT4SS_MCS6,
+	ODM_MGN_VHT4SS_MCS7,
+	ODM_MGN_VHT4SS_MCS8,
+	ODM_MGN_VHT4SS_MCS9	= 0xc7,
+	ODM_MGN_UNKNOWN
+};
+
+#define	ODM_MGN_MCS0_SG		0xc0
+#define	ODM_MGN_MCS1_SG		0xc1
+#define	ODM_MGN_MCS2_SG		0xc2
+#define	ODM_MGN_MCS3_SG		0xc3
+#define	ODM_MGN_MCS4_SG		0xc4
+#define	ODM_MGN_MCS5_SG		0xc5
+#define	ODM_MGN_MCS6_SG		0xc6
+#define	ODM_MGN_MCS7_SG		0xc7
+#define	ODM_MGN_MCS8_SG		0xc8
+#define	ODM_MGN_MCS9_SG		0xc9
+#define	ODM_MGN_MCS10_SG		0xca
+#define	ODM_MGN_MCS11_SG		0xcb
+#define	ODM_MGN_MCS12_SG		0xcc
+#define	ODM_MGN_MCS13_SG		0xcd
+#define	ODM_MGN_MCS14_SG		0xce
+#define	ODM_MGN_MCS15_SG		0xcf
+
+/* -----DESC rate--------------------------------- */
+
+#define ODM_RATEMCS15_SG		0x1c
+#define ODM_RATEMCS32			0x20
+
+
+enum phydm_ctrl_info_rate {
+	ODM_RATE1M			= 0x00,
+	ODM_RATE2M			= 0x01,
+	ODM_RATE5_5M			= 0x02,
+	ODM_RATE11M			= 0x03,
+/* OFDM Rates, TxHT = 0 */
+	ODM_RATE6M			= 0x04,
+	ODM_RATE9M			= 0x05,
+	ODM_RATE12M			= 0x06,
+	ODM_RATE18M			= 0x07,
+	ODM_RATE24M			= 0x08,
+	ODM_RATE36M			= 0x09,
+	ODM_RATE48M			= 0x0A,
+	ODM_RATE54M			= 0x0B,
+/* MCS Rates, TxHT = 1 */
+	ODM_RATEMCS0			= 0x0C,
+	ODM_RATEMCS1			= 0x0D,
+	ODM_RATEMCS2			= 0x0E,
+	ODM_RATEMCS3			= 0x0F,
+	ODM_RATEMCS4			= 0x10,
+	ODM_RATEMCS5			= 0x11,
+	ODM_RATEMCS6			= 0x12,
+	ODM_RATEMCS7			= 0x13,
+	ODM_RATEMCS8			= 0x14,
+	ODM_RATEMCS9			= 0x15,
+	ODM_RATEMCS10			= 0x16,
+	ODM_RATEMCS11			= 0x17,
+	ODM_RATEMCS12			= 0x18,
+	ODM_RATEMCS13			= 0x19,
+	ODM_RATEMCS14			= 0x1A,
+	ODM_RATEMCS15			= 0x1B,
+	ODM_RATEMCS16			= 0x1C,
+	ODM_RATEMCS17			= 0x1D,
+	ODM_RATEMCS18			= 0x1E,
+	ODM_RATEMCS19			= 0x1F,
+	ODM_RATEMCS20			= 0x20,
+	ODM_RATEMCS21			= 0x21,
+	ODM_RATEMCS22			= 0x22,
+	ODM_RATEMCS23			= 0x23,
+	ODM_RATEMCS24			= 0x24,
+	ODM_RATEMCS25			= 0x25,
+	ODM_RATEMCS26			= 0x26,
+	ODM_RATEMCS27			= 0x27,
+	ODM_RATEMCS28			= 0x28,
+	ODM_RATEMCS29			= 0x29,
+	ODM_RATEMCS30			= 0x2A,
+	ODM_RATEMCS31			= 0x2B,
+	ODM_RATEVHTSS1MCS0	= 0x2C,
+	ODM_RATEVHTSS1MCS1	= 0x2D,
+	ODM_RATEVHTSS1MCS2	= 0x2E,
+	ODM_RATEVHTSS1MCS3	= 0x2F,
+	ODM_RATEVHTSS1MCS4	= 0x30,
+	ODM_RATEVHTSS1MCS5	= 0x31,
+	ODM_RATEVHTSS1MCS6	= 0x32,
+	ODM_RATEVHTSS1MCS7	= 0x33,
+	ODM_RATEVHTSS1MCS8	= 0x34,
+	ODM_RATEVHTSS1MCS9	= 0x35,
+	ODM_RATEVHTSS2MCS0	= 0x36,
+	ODM_RATEVHTSS2MCS1	= 0x37,
+	ODM_RATEVHTSS2MCS2	= 0x38,
+	ODM_RATEVHTSS2MCS3	= 0x39,
+	ODM_RATEVHTSS2MCS4	= 0x3A,
+	ODM_RATEVHTSS2MCS5	= 0x3B,
+	ODM_RATEVHTSS2MCS6	= 0x3C,
+	ODM_RATEVHTSS2MCS7	= 0x3D,
+	ODM_RATEVHTSS2MCS8	= 0x3E,
+	ODM_RATEVHTSS2MCS9	= 0x3F,
+	ODM_RATEVHTSS3MCS0	= 0x40,
+	ODM_RATEVHTSS3MCS1	= 0x41,
+	ODM_RATEVHTSS3MCS2	= 0x42,
+	ODM_RATEVHTSS3MCS3	= 0x43,
+	ODM_RATEVHTSS3MCS4	= 0x44,
+	ODM_RATEVHTSS3MCS5	= 0x45,
+	ODM_RATEVHTSS3MCS6	= 0x46,
+	ODM_RATEVHTSS3MCS7	= 0x47,
+	ODM_RATEVHTSS3MCS8	= 0x48,
+	ODM_RATEVHTSS3MCS9	= 0x49,
+	ODM_RATEVHTSS4MCS0	= 0x4A,
+	ODM_RATEVHTSS4MCS1	= 0x4B,
+	ODM_RATEVHTSS4MCS2	= 0x4C,
+	ODM_RATEVHTSS4MCS3	= 0x4D,
+	ODM_RATEVHTSS4MCS4	= 0x4E,
+	ODM_RATEVHTSS4MCS5	= 0x4F,
+	ODM_RATEVHTSS4MCS6	= 0x50,
+	ODM_RATEVHTSS4MCS7	= 0x51,
+	ODM_RATEVHTSS4MCS8	= 0x52,
+	ODM_RATEVHTSS4MCS9	= 0x53,
+};
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
+#else
+	#if (RTL8192E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEMCS15+1)
+	#elif (RTL8723B_SUPPORT == 1) || (RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEMCS7+1)
+	#elif (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS1MCS9+1)
+	#elif (RTL8812A_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS2MCS9+1)
+	#elif (RTL8814A_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS3MCS9+1)
+	#else
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
+	#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define CONFIG_SFW_SUPPORTED
+#endif
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+/*	ODM_CMNINFO_INTERFACE */
+enum odm_interface {
+	ODM_ITRF_PCIE	=	0x1,
+	ODM_ITRF_USB	=	0x2,
+	ODM_ITRF_SDIO	=	0x4,
+	ODM_ITRF_ALL	=	0x7,
+};
+
+
+/*========[Run time IC flag] ===============================================================================]*/
+
+enum phydm_ic {
+	ODM_RTL8188E	=	BIT(0),
+	ODM_RTL8812	=	BIT(1),
+	ODM_RTL8821	=	BIT(2),
+	ODM_RTL8192E	=	BIT(3),
+	ODM_RTL8723B	=	BIT(4),
+	ODM_RTL8814A	=	BIT(5),
+	ODM_RTL8881A	=	BIT(6),
+	ODM_RTL8822B	=	BIT(7),
+	ODM_RTL8703B	=	BIT(8),
+	ODM_RTL8195A	=	BIT(9),
+	ODM_RTL8188F	=	BIT(10),
+	ODM_RTL8723D	=	BIT(11),
+	ODM_RTL8197F	=	BIT(12),
+	ODM_RTL8821C	=	BIT(13),
+	ODM_RTL8814B	=	BIT(14),
+	ODM_RTL8198F	=	BIT(15),
+	ODM_RTL8710B	=	BIT(16),
+	ODM_RTL8192F	=	BIT(17),
+	ODM_RTL8822C	=	BIT(18),
+	ODM_RTL8195B	=	BIT(19)
+};
+
+#define ODM_IC_N_1SS	(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8723B | ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8195A | ODM_RTL8710B)
+#define ODM_IC_N_2SS	(ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8192F)
+#define ODM_IC_N_3SS	0
+#define ODM_IC_N_4SS	(ODM_RTL8198F)
+
+#define ODM_IC_AC_1SS	(ODM_RTL8881A | ODM_RTL8821 | ODM_RTL8821C | ODM_RTL8195B)
+#define ODM_IC_AC_2SS	(ODM_RTL8812 | ODM_RTL8822B | ODM_RTL8822C)
+#define ODM_IC_AC_3SS	0
+#define ODM_IC_AC_4SS	(ODM_RTL8814A | ODM_RTL8814B)
+
+/*====the following macro DO NOT need to update when adding a new IC======= */
+#define ODM_IC_1SS	(ODM_IC_N_1SS | ODM_IC_AC_1SS)
+#define ODM_IC_2SS	(ODM_IC_N_2SS | ODM_IC_AC_2SS)
+#define ODM_IC_3SS	(ODM_IC_N_3SS | ODM_IC_AC_3SS)
+#define ODM_IC_4SS	(ODM_IC_N_4SS | ODM_IC_AC_4SS)
+
+#define PHYDM_IC_ABOVE_1SS	(ODM_IC_1SS | ODM_IC_2SS | ODM_IC_3SS | ODM_IC_4SS)
+#define PHYDM_IC_ABOVE_2SS	(ODM_IC_2SS | ODM_IC_3SS | ODM_IC_4SS)
+#define PHYDM_IC_ABOVE_3SS	(ODM_IC_3SS | ODM_IC_4SS)
+#define PHYDM_IC_ABOVE_4SS	ODM_IC_4SS
+
+#define ODM_IC_11N_SERIES		(ODM_IC_N_1SS | ODM_IC_N_2SS | ODM_IC_N_3SS | ODM_IC_N_4SS)
+#define ODM_IC_11AC_SERIES		(ODM_IC_AC_1SS | ODM_IC_AC_2SS | ODM_IC_AC_3SS | ODM_IC_AC_4SS)
+/*====================================================*/
+
+#define ODM_IC_11AC_1_SERIES			(ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)
+#define ODM_IC_11AC_2_SERIES			(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8195B)
+/*[EDCCA]*/
+#define ODM_IC_11N_GAIN_IDX_EDCCA	(ODM_RTL8195A | ODM_RTL8703B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8197F | ODM_RTL8710B)
+#define ODM_IC_11AC_GAIN_IDX_EDCCA	(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)
+#define ODM_IC_GAIN_IDX_EDCCA			(ODM_IC_11N_GAIN_IDX_EDCCA | ODM_IC_11AC_GAIN_IDX_EDCCA)
+/*[Phy status type]*/
+#define PHYSTS_2ND_TYPE_IC				(ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B | ODM_RTL8195B)
+#define PHYSTS_3RD_TYPE_IC				(ODM_RTL8198F | ODM_RTL8814B)
+/*[FW Type]*/
+#define PHYDM_IC_8051_SERIES			(ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8703B | ODM_RTL8188F)
+#define PHYDM_IC_3081_SERIES			(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F)
+/*[LA mode]*/
+#define PHYDM_IC_SUPPORT_LA_MODE		(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F)
+/*[BF]*/
+#define ODM_IC_TXBF_SUPPORT			(ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8881A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F)
+#define PHYDM_IC_SUPPORT_MU_BFEE		(ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814B | ODM_RTL8195B | ODM_RTL8198F)
+#define PHYDM_IC_SUPPORT_MU_BFER		(ODM_RTL8822B | ODM_RTL8814B | ODM_RTL8198F)
+
+
+/*========[Compile time IC flag] ===============================================================================]*/
+/*========[AC/N Support] ===========================*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	#ifdef RTK_AC_SUPPORT
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#else
+	#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#endif
+
+	#define ODM_IC_11N_SERIES_SUPPORT			1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#define ODM_IC_11N_SERIES_SUPPORT			1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#define ODM_IC_11N_SERIES_SUPPORT			1
+
+#else /*ODM_CE*/
+
+	#if ((RTL8188E_SUPPORT == 1) || \
+	(RTL8723B_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8195A_SUPPORT == 1) || (RTL8703B_SUPPORT == 1) || \
+	(RTL8188F_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
+		#define ODM_IC_11N_SERIES_SUPPORT			1
+		#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#else
+		#define ODM_IC_11N_SERIES_SUPPORT			0
+		#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#endif
+#endif
+
+/*===IC SS Compile Flag, prepare for code size reduction==============*/
+#if ((RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8723B_SUPPORT == 1) || (RTL8703B_SUPPORT == 1) ||\
+	(RTL8723D_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) ||\
+	(RTL8195A_SUPPORT == 1) || (RTL8710B_SUPPORT == 1) || (RTL8195B_SUPPORT == 1))
+	
+	#define PHYDM_COMPILE_IC_1SS
+#endif
+
+#if ((RTL8192E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
+	#define PHYDM_COMPILE_IC_2SS
+#endif
+
+/*#define PHYDM_COMPILE_IC_3SS*/
+
+#if ((RTL8814B_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8198F_SUPPORT == 1))
+	#define PHYDM_COMPILE_IC_4SS
+#endif
+
+/*==[ABOVE N-SS COMPILE FLAG]=============================*/
+#if (defined(PHYDM_COMPILE_IC_1SS) || defined(PHYDM_COMPILE_IC_2SS) || defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_1SS
+#endif
+
+#if (defined(PHYDM_COMPILE_IC_2SS) || defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_2SS
+#endif
+
+#if (defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_3SS
+#endif
+
+#if (defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_4SS
+#endif
+
+/*========[New Phy-Status Support] =========================================================================]*/
+#if (RTL8824B_SUPPORT == 1)
+	#define CONFIG_PHYSTS_3RD_TYPE		1
+#else
+	#define CONFIG_PHYSTS_3RD_TYPE		0
+#endif
+	
+#if ((RTL8197F_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8710B_SUPPORT == 1) )
+	#define ODM_PHY_STATUS_NEW_TYPE_SUPPORT			1
+#else
+	#define ODM_PHY_STATUS_NEW_TYPE_SUPPORT			0
+#endif
+
+/*==================================================================================================]*/
+
+#if ((RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+#define PHYDM_COMMON_API_SUPPORT
+#endif
+
+
+#define	CCK_RATE_NUM		4
+#define	OFDM_RATE_NUM	8
+
+#define	LEGACY_RATE_NUM	12
+
+#define	HT_RATE_NUM_4SS		32
+#define	VHT_RATE_NUM_4SS		40
+
+#define	HT_RATE_NUM_3SS		24
+#define	VHT_RATE_NUM_3SS		30
+
+#define	HT_RATE_NUM_2SS		16
+#define	VHT_RATE_NUM_2SS		20
+
+#define	HT_RATE_NUM_1SS		8
+#define	VHT_RATE_NUM_1SS		10
+
+#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	#define	HT_RATE_NUM		HT_RATE_NUM_4SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_4SS
+#elif (defined(PHYDM_COMPILE_ABOVE_3SS))
+	#define	HT_RATE_NUM		HT_RATE_NUM_3SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_3SS
+#elif (defined(PHYDM_COMPILE_ABOVE_2SS))
+	#define	HT_RATE_NUM		HT_RATE_NUM_2SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_2SS
+#else
+	#define	HT_RATE_NUM		HT_RATE_NUM_1SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_1SS
+#endif
+
+#define	LOW_BW_RATE_NUM	VHT_RATE_NUM
+
+
+/* ODM_CMNINFO_CUT_VER */
+enum odm_cut_version {
+	ODM_CUT_A		=	0,
+	ODM_CUT_B		=	1,
+	ODM_CUT_C		=	2,
+	ODM_CUT_D		=	3,
+	ODM_CUT_E		=	4,
+	ODM_CUT_F		=	5,
+	ODM_CUT_G		=	6,
+	ODM_CUT_H		=	7,
+	ODM_CUT_I		=	8,
+	ODM_CUT_J		=	9,
+	ODM_CUT_K		=	10,
+	ODM_CUT_TEST	=	15,
+};
+
+/* ODM_CMNINFO_FAB_VER */
+enum odm_fab {
+	ODM_TSMC	=	0,
+	ODM_UMC	=	1,
+};
+
+/* 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 */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+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),
+};
+#else
+enum odm_wireless_mode {
+	ODM_WM_UNKNOWN	= 0x00,/*0x0*/
+	ODM_WM_A			= BIT(0), /* 0x1*/
+	ODM_WM_B			= BIT(1), /* 0x2*/
+	ODM_WM_G			= BIT(2),/* 0x4*/
+	ODM_WM_AUTO		= BIT(3),/* 0x8*/
+	ODM_WM_N24G		= BIT(4),/* 0x10*/
+	ODM_WM_N5G		= BIT(5),/* 0x20*/
+	ODM_WM_AC_5G		= BIT(6),/* 0x40*/
+	ODM_WM_AC_24G	= BIT(7),/* 0x80*/
+	ODM_WM_AC_ONLY	= BIT(8),/* 0x100*/
+	ODM_WM_MAX		= BIT(11)/* 0x800*/
+
+};
+#endif
+
+/* ODM_CMNINFO_BAND */
+enum odm_band_type {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	ODM_BAND_2_4G	= BIT(0),
+	ODM_BAND_5G		= BIT(1),
+#else
+	ODM_BAND_2_4G = 0,
+	ODM_BAND_5G,
+	ODM_BAND_ON_BOTH,
+	ODM_BANDMAX
+#endif
+};
+
+
+/* ODM_CMNINFO_SEC_CHNL_OFFSET */
+enum phydm_sec_chnl_offset {
+	PHYDM_DONT_CARE	= 0,
+	PHYDM_BELOW		= 1,
+	PHYDM_ABOVE		= 2
+};
+
+/* ODM_CMNINFO_SEC_MODE */
+enum odm_security {
+	ODM_SEC_OPEN			= 0,
+	ODM_SEC_WEP40		= 1,
+	ODM_SEC_TKIP			= 2,
+	ODM_SEC_RESERVE		= 3,
+	ODM_SEC_AESCCMP		= 4,
+	ODM_SEC_WEP104		= 5,
+	ODM_WEP_WPA_MIXED    = 6, /* WEP + WPA */
+	ODM_SEC_SMS4			= 7,
+};
+
+/* ODM_CMNINFO_CHNL */
+
+/* ODM_CMNINFO_BOARD_TYPE */
+enum odm_board_type {
+	ODM_BOARD_DEFAULT 	= 0,	  /* The DEFAULT case. */
+	ODM_BOARD_MINICARD  = BIT(0), /* 0 = non-mini card, 1= mini card. */
+	ODM_BOARD_SLIM      = BIT(1), /* 0 = non-slim card, 1 = slim card */
+	ODM_BOARD_BT        = BIT(2), /* 0 = without BT card, 1 = with BT */
+	ODM_BOARD_EXT_PA    = BIT(3), /* 0 = no 2G ext-PA, 1 = existing 2G ext-PA */
+	ODM_BOARD_EXT_LNA   = BIT(4), /* 0 = no 2G ext-LNA, 1 = existing 2G ext-LNA */
+	ODM_BOARD_EXT_TRSW  = BIT(5), /* 0 = no ext-TRSW, 1 = existing ext-TRSW */
+	ODM_BOARD_EXT_PA_5G	= BIT(6), /* 0 = no 5G ext-PA, 1 = existing 5G ext-PA */
+	ODM_BOARD_EXT_LNA_5G = BIT(7), /* 0 = no 5G ext-LNA, 1 = existing 5G ext-LNA */
+};
+
+enum odm_package_type {
+	ODM_PACKAGE_DEFAULT	 = 0,
+	ODM_PACKAGE_QFN68        = BIT(0),
+	ODM_PACKAGE_TFBGA90      = BIT(1),
+	ODM_PACKAGE_TFBGA79      = BIT(2),
+};
+
+enum odm_type_gpa {
+	TYPE_GPA0 = 0x0000,
+	TYPE_GPA1 = 0x0055,
+	TYPE_GPA2 = 0x00AA,
+	TYPE_GPA3 = 0x00FF,
+	TYPE_GPA4 = 0x5500,
+	TYPE_GPA5 = 0x5555,
+	TYPE_GPA6 = 0x55AA,
+	TYPE_GPA7 = 0x55FF,
+	TYPE_GPA8 = 0xAA00,
+	TYPE_GPA9 = 0xAA55,
+	TYPE_GPA10 = 0xAAAA,
+	TYPE_GPA11 = 0xAAFF,
+	TYPE_GPA12 = 0xFF00,
+	TYPE_GPA13 = 0xFF55,
+	TYPE_GPA14 = 0xFFAA,
+	TYPE_GPA15 = 0xFFFF,
+};
+
+enum odm_type_apa {
+	TYPE_APA0 = 0x0000,
+	TYPE_APA1 = 0x0055,
+	TYPE_APA2 = 0x00AA,
+	TYPE_APA3 = 0x00FF,
+	TYPE_APA4 = 0x5500,
+	TYPE_APA5 = 0x5555,
+	TYPE_APA6 = 0x55AA,
+	TYPE_APA7 = 0x55FF,
+	TYPE_APA8 = 0xAA00,
+	TYPE_APA9 = 0xAA55,
+	TYPE_APA10 = 0xAAAA,
+	TYPE_APA11 = 0xAAFF,
+	TYPE_APA12 = 0xFF00,
+	TYPE_APA13 = 0xFF55,
+	TYPE_APA14 = 0xFFAA,
+	TYPE_APA15 = 0xFFFF,
+};
+
+enum odm_type_glna {
+	TYPE_GLNA0 = 0x0000,
+	TYPE_GLNA1 = 0x0055,
+	TYPE_GLNA2 = 0x00AA,
+	TYPE_GLNA3 = 0x00FF,
+	TYPE_GLNA4 = 0x5500,
+	TYPE_GLNA5 = 0x5555,
+	TYPE_GLNA6 = 0x55AA,
+	TYPE_GLNA7 = 0x55FF,
+	TYPE_GLNA8 = 0xAA00,
+	TYPE_GLNA9 = 0xAA55,
+	TYPE_GLNA10 = 0xAAAA,
+	TYPE_GLNA11 = 0xAAFF,
+	TYPE_GLNA12 = 0xFF00,
+	TYPE_GLNA13 = 0xFF55,
+	TYPE_GLNA14 = 0xFFAA,
+	TYPE_GLNA15 = 0xFFFF,
+};
+
+enum odm_type_alna {
+	TYPE_ALNA0 = 0x0000,
+	TYPE_ALNA1 = 0x0055,
+	TYPE_ALNA2 = 0x00AA,
+	TYPE_ALNA3 = 0x00FF,
+	TYPE_ALNA4 = 0x5500,
+	TYPE_ALNA5 = 0x5555,
+	TYPE_ALNA6 = 0x55AA,
+	TYPE_ALNA7 = 0x55FF,
+	TYPE_ALNA8 = 0xAA00,
+	TYPE_ALNA9 = 0xAA55,
+	TYPE_ALNA10 = 0xAAAA,
+	TYPE_ALNA11 = 0xAAFF,
+	TYPE_ALNA12 = 0xFF00,
+	TYPE_ALNA13 = 0xFF55,
+	TYPE_ALNA14 = 0xFFAA,
+	TYPE_ALNA15 = 0xFFFF,
+};
+
+#define	PAUSE_FAIL		0
+#define	PAUSE_SUCCESS	1
+
+enum odm_parameter_init {
+	ODM_PRE_SETTING = 0,
+	ODM_POST_SETTING = 1,
+	ODM_INIT_FW_SETTING
+};
+
+
+enum phydm_pause_type {
+	PHYDM_PAUSE = 1,			/*Pause & Set new value*/
+	PHYDM_PAUSE_NO_SET = 2,	/*Pause & Stay in current value*/
+	PHYDM_RESUME = 3
+};
+
+enum phydm_pause_level {
+	PHYDM_PAUSE_RELEASE = -1,
+	PHYDM_PAUSE_LEVEL_0 = 0,	/* Low Priority function */
+	PHYDM_PAUSE_LEVEL_1 = 1,	/* Middle Priority function */
+	PHYDM_PAUSE_LEVEL_2 = 2,	/* High priority function (ex: Check hang function) */
+	PHYDM_PAUSE_LEVEL_3 = 3,	/* Debug function (the highest priority) */
+	PHYDM_PAUSE_MAX_NUM = 4
+};
+
+enum phydm_dis_hw_fun {
+	HW_FUN_DIS = 0,		/*Disable a cetain HW function & backup the original value*/
+	HW_FUN_RESUME = 1		/*Revert */
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_precomp.h
new file mode 100644
index 000000000000..69f8a7acde22
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_precomp.h
@@ -0,0 +1,405 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__ODM_PRECOMP_H__
+#define __ODM_PRECOMP_H__
+
+#include "phydm_types.h"
+#include "phydm_features.h"
+#include "halrf/halrf_features.h"
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#include "Precomp.h"		/* We need to include mp_precomp.h due to batch file setting. */
+#else
+	#define		TEST_FALG___		1
+#endif
+
+/* 2 Config Flags and Structs - defined by each ODM type */
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#include "../8192cd_cfg.h"
+	#include "../odm_inc.h"
+
+	#include "../8192cd.h"
+	#include "../8192cd_util.h"
+	#ifdef _BIG_ENDIAN_
+		#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_BIG
+	#else
+		#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
+	#endif
+
+	#include "../8192cd_headers.h"
+	#include "../8192cd_debug.h"
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#ifdef DM_ODM_CE_MAC80211
+		#include "../wifi.h"
+		#include "rtl_phydm.h"
+	#endif
+	#define __PACK
+	#define __WLAN_ATTRIB_PACK__
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#include "mp_precomp.h"
+	#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
+	#define __PACK
+	#define __WLAN_ATTRIB_PACK__
+#endif
+
+/* 2 OutSrc Header Files */
+
+#include "phydm.h"
+#include "phydm_hwconfig.h"
+#include "phydm_phystatus.h"
+#include "phydm_debug.h"
+#include "phydm_regdefine11ac.h"
+#include "phydm_regdefine11n.h"
+#include "phydm_interface.h"
+#include "phydm_reg.h"
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && !defined(DM_ODM_CE_MAC80211)
+
+void
+phy_set_tx_power_limit(
+	struct dm_struct	*dm,
+	u8	*regulation,
+	u8	*band,
+	u8	*bandwidth,
+	u8	*rate_section,
+	u8	*rf_path,
+	u8	*channel,
+	u8	*power_limit
+);
+
+enum hal_status
+rtw_phydm_fw_iqk(
+	struct dm_struct	*dm,
+	u8 clear,
+	u8 segment
+);
+
+enum hal_status
+rtw_phydm_cfg_phy_para(
+	struct dm_struct	*dm,
+	enum phydm_halmac_param config_type,
+	u32 offset,
+	u32 data,
+	u32 mask,
+	enum rf_path e_rf_path,
+	u32 delay_time
+);
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#define RTL8703B_SUPPORT		0
+	#define RTL8188F_SUPPORT		0
+	#define RTL8723D_SUPPORT		0
+#endif
+
+/* JJ ADD 20161014 */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_AP|ODM_IOT))
+#define RTL8710B_SUPPORT		0
+#endif
+
+#if RTL8188E_SUPPORT == 1
+	#define RTL8188E_T_SUPPORT 1
+	#ifdef CONFIG_SFW_SUPPORTED
+		#define RTL8188E_S_SUPPORT 1
+	#else
+		#define RTL8188E_S_SUPPORT 0
+	#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#define	RTL8195B_SUPPORT 0	/*Just for PHYDM API development*/
+#define	RTL8198F_SUPPORT 0	/*Just for PHYDM API development*/
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+	#include "rtl8188e/hal8188erateadaptive.h" /* for  RA,Power training */
+	#include "rtl8188e/halhwimg8188e_mac.h"
+	#include "rtl8188e/halhwimg8188e_rf.h"
+	#include "rtl8188e/halhwimg8188e_bb.h"
+	#include "rtl8188e/phydm_regconfig8188e.h"
+	#include "rtl8188e/phydm_rtl8188e.h"
+	#include "rtl8188e/hal8188ereg.h"
+	#include "rtl8188e/version_rtl8188e.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8188e_hal.h"
+		#include "halrf/rtl8188e/halrf_8188e_ce.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8188e/halrf_8188e_win.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8188e/halrf_8188e_ap.h"
+	#endif
+#endif /* 88E END */
+
+#if (RTL8192E_SUPPORT == 1)
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8192e/halrf_8192e_win.h" /*FOR_8192E_IQK*/
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8192e/halrf_8192e_ap.h" /*FOR_8192E_IQK*/
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8192e/halrf_8192e_ce.h" /*FOR_8192E_IQK*/
+	#endif
+
+	#include "rtl8192e/phydm_rtl8192e.h" /* FOR_8192E_IQK */
+	#include "rtl8192e/version_rtl8192e.h"
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+		#include "rtl8192e/halhwimg8192e_bb.h"
+		#include "rtl8192e/halhwimg8192e_mac.h"
+		#include "rtl8192e/halhwimg8192e_rf.h"
+		#include "rtl8192e/phydm_regconfig8192e.h"
+		#include "rtl8192e/hal8192ereg.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8192e_hal.h"
+	#endif
+#endif /* 92E END */
+
+#if (RTL8812A_SUPPORT == 1)
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8812a/halrf_8812a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8812a/halrf_8812a_ap.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8812a/halrf_8812a_ce.h"
+	#endif
+
+	/* #include "halrf/rtl8812a/halrf_8812a.h"  */ /* FOR_8812_IQK */
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+		#include "rtl8812a/halhwimg8812a_bb.h"
+		#include "rtl8812a/halhwimg8812a_mac.h"
+		#include "rtl8812a/halhwimg8812a_rf.h"
+		#include "rtl8812a/phydm_regconfig8812a.h"
+		#include "rtl8812a/phydm_rtl8812a.h"
+	#endif
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8812a_hal.h"
+	#endif
+	#include "rtl8812a/version_rtl8812a.h"
+
+#endif /* 8812 END */
+
+#if (RTL8814A_SUPPORT == 1)
+
+	#include "rtl8814a/halhwimg8814a_mac.h"
+	#include "rtl8814a/halhwimg8814a_rf.h"
+	#include "rtl8814a/halhwimg8814a_bb.h"
+	#include "rtl8814a/version_rtl8814a.h"
+	#include "rtl8814a/phydm_rtl8814a.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8814a/halrf_8814a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8814a/halrf_8814a_ce.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8814a/halrf_8814a_ap.h"
+	#endif
+	#include "rtl8814a/phydm_regconfig8814a.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8814a_hal.h"
+		#include "halrf/rtl8814a/halrf_iqk_8814a.h"
+	#endif
+#endif /* 8814 END */
+
+#if (RTL8881A_SUPPORT == 1)/* FOR_8881_IQK */
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8821a/halrf_iqk_8821a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8821a/halrf_iqk_8821a_ce.h"
+	#else
+		#include "halrf/rtl8821a/halrf_iqk_8821a_ap.h"
+	#endif
+	/* #include "rtl8881a/HalHWImg8881A_BB.h" */
+	/* #include "rtl8881a/HalHWImg8881A_MAC.h" */
+	/* #include "rtl8881a/HalHWImg8881A_RF.h" */
+	/* #include "rtl8881a/odm_RegConfig8881A.h" */
+#endif
+
+#if (RTL8723B_SUPPORT == 1)
+	#include "rtl8723b/halhwimg8723b_mac.h"
+	#include "rtl8723b/halhwimg8723b_rf.h"
+	#include "rtl8723b/halhwimg8723b_bb.h"
+	#include "rtl8723b/phydm_regconfig8723b.h"
+	#include "rtl8723b/phydm_rtl8723b.h"
+	#include "rtl8723b/hal8723breg.h"
+	#include "rtl8723b/version_rtl8723b.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8723b/halrf_8723b_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8723b/halrf_8723b_ce.h"
+		#include "rtl8723b/halhwimg8723b_mp.h"
+		#include "rtl8723b_hal.h"
+	#else
+		#include "halrf/rtl8723b/halrf_8723b_ap.h"
+	#endif
+#endif
+
+#if (RTL8821A_SUPPORT == 1)
+	#include "rtl8821a/halhwimg8821a_mac.h"
+	#include "rtl8821a/halhwimg8821a_rf.h"
+	#include "rtl8821a/halhwimg8821a_bb.h"
+	#include "rtl8821a/phydm_regconfig8821a.h"
+	#include "rtl8821a/phydm_rtl8821a.h"
+	#include "rtl8821a/version_rtl8821a.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8821a/halrf_8821a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8821a/halrf_8821a_ce.h"
+		#include "halrf/rtl8821a/halrf_iqk_8821a_ce.h"/*for IQK*/
+		#include "halrf/rtl8812a/halrf_8812a_ce.h"/*for IQK,LCK,Power-tracking*/
+		#include "rtl8812a_hal.h"
+	#else
+	#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#include "../halmac/halmac_reg2.h"
+#endif
+
+
+#if (RTL8822B_SUPPORT == 1)
+	#include "rtl8822b/halhwimg8822b_mac.h"
+	#include "rtl8822b/halhwimg8822b_rf.h"
+	#include "rtl8822b/halhwimg8822b_bb.h"
+	#include "rtl8822b/phydm_regconfig8822b.h"
+	#include "halrf/rtl8822b/halrf_8822b.h"
+	#include "rtl8822b/phydm_rtl8822b.h"
+	#include "rtl8822b/phydm_hal_api8822b.h"
+	#include "rtl8822b/version_rtl8822b.h"
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#ifdef DM_ODM_CE_MAC80211
+			#include "../halmac/halmac_reg_8822b.h"
+		#else
+			#include <hal_data.h>		/* struct HAL_DATA_TYPE */
+			#include <rtl8822b_hal.h>	/* RX_SMOOTH_FACTOR, reg definition and etc.*/
+		#endif
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#endif
+
+#endif
+
+#if (RTL8703B_SUPPORT == 1)
+	#include "rtl8703b/phydm_regconfig8703b.h"
+	#include "rtl8703b/halhwimg8703b_mac.h"
+	#include "rtl8703b/halhwimg8703b_rf.h"
+	#include "rtl8703b/halhwimg8703b_bb.h"
+	#include "halrf/rtl8703b/halrf_8703b.h"
+	#include "rtl8703b/version_rtl8703b.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8703b_hal.h"
+	#endif
+#endif
+
+#if (RTL8188F_SUPPORT == 1)
+	#include "rtl8188f/halhwimg8188f_mac.h"
+	#include "rtl8188f/halhwimg8188f_rf.h"
+	#include "rtl8188f/halhwimg8188f_bb.h"
+	#include "rtl8188f/hal8188freg.h"
+	#include "rtl8188f/phydm_rtl8188f.h"
+	#include "rtl8188f/phydm_regconfig8188f.h"
+	#include "halrf/rtl8188f/halrf_8188f.h" /* for IQK,LCK,Power-tracking */
+	#include "rtl8188f/version_rtl8188f.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8188f_hal.h"
+	#endif
+#endif
+
+#if (RTL8723D_SUPPORT == 1)
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+
+		#include "rtl8723d/halhwimg8723d_bb.h"
+		#include "rtl8723d/halhwimg8723d_mac.h"
+		#include "rtl8723d/halhwimg8723d_rf.h"
+		#include "rtl8723d/phydm_regconfig8723d.h"
+		#include "rtl8723d/hal8723dreg.h"
+		#include "rtl8723d/phydm_rtl8723d.h"
+		#include "halrf/rtl8723d/halrf_8723d.h"
+		#include "rtl8723d/version_rtl8723d.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8723d_hal.h"
+	#endif
+#endif /* 8723D End */
+
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+
+		#include "rtl8710b/halhwimg8710b_bb.h"
+		#include "rtl8710b/halhwimg8710b_mac.h"
+		#include "rtl8710b/halhwimg8710b_rf.h"
+		#include "rtl8710b/phydm_regconfig8710b.h"
+		#include "rtl8710b/hal8710breg.h"
+		#include "rtl8710b/phydm_rtl8710b.h"
+		#include "halrf/rtl8710b/halrf_8710b.h"
+		#include "rtl8710b/version_rtl8710b.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8710b_hal.h"
+	#endif
+#endif /* 8710B End */
+
+#if (RTL8197F_SUPPORT == 1)
+	#include "rtl8197f/halhwimg8197f_mac.h"
+	#include "rtl8197f/halhwimg8197f_rf.h"
+	#include "rtl8197f/halhwimg8197f_bb.h"
+	#include "rtl8197f/phydm_hal_api8197f.h"
+	#include "rtl8197f/version_rtl8197f.h"
+	#include "rtl8197f/phydm_rtl8197f.h"
+	#include "rtl8197f/phydm_regconfig8197f.h"
+	#include "halrf/rtl8197f/halrf_8197f.h"
+	#include "halrf/rtl8197f/halrf_iqk_8197f.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	#include "rtl8821c/phydm_hal_api8821c.h"
+	#include "rtl8821c/halhwimg8821c_mac.h"
+	#include "rtl8821c/halhwimg8821c_rf.h"
+	#include "rtl8821c/halhwimg8821c_bb.h"
+	#include "rtl8821c/phydm_regconfig8821c.h"
+	#include "halrf/rtl8821c/halrf_8821c.h"
+	#include "rtl8821c/version_rtl8821c.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8821c_hal.h"
+	#endif
+#endif
+
+#if (RTL8195B_SUPPORT == 1)
+	#include "rtl8195b/phydm_hal_api8195b.h"
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	#include "rtl8198f/phydm_hal_api8198F.h"
+#endif
+
+#endif /* __ODM_PRECOMP_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_primary_cca.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_primary_cca.c
new file mode 100644
index 000000000000..71677bed8407
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_primary_cca.c
@@ -0,0 +1,730 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+#ifdef PHYDM_PRIMARY_CCA
+
+void
+phydm_write_dynamic_cca(
+	void			*dm_void,
+	u8			curr_mf_state
+	
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct	*primary_cca = &dm->dm_pri_cca;
+
+	if (primary_cca->mf_state == curr_mf_state)
+		return;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (curr_mf_state == MF_USC_LSC) {
+			odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), MF_USC_LSC);
+			odm_set_bb_reg(dm, 0xc84, 0xf0000000, primary_cca->cca_th_40m_bkp); /*40M OFDM MF CCA threshold*/
+		} else {
+			odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), curr_mf_state);
+			odm_set_bb_reg(dm, 0xc84, 0xf0000000, 0); /*40M OFDM MF CCA threshold*/
+		}
+	}
+
+	primary_cca->mf_state = curr_mf_state;
+	PHYDM_DBG(dm, DBG_PRI_CCA,
+			"Set CCA at ((%s SB)), 0xc6c[8:7]=((%d))\n", ((curr_mf_state == MF_USC_LSC)?"D":((curr_mf_state == MF_LSC)?"L":"U")), curr_mf_state);
+}
+
+void
+phydm_primary_cca_reset(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct	*primary_cca = &dm->dm_pri_cca;
+
+	PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA] Reset\n");
+	primary_cca->mf_state = 0xff;
+	primary_cca->pre_bw = (enum channel_width)0xff;
+	phydm_write_dynamic_cca(dm, MF_USC_LSC);
+}
+
+void
+phydm_primary_cca_11n(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct	*primary_cca = &dm->dm_pri_cca;
+	enum channel_width	curr_bw = (enum channel_width)*dm->band_width;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+	
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA][No Link!!!]\n");
+
+		if (primary_cca->pri_cca_is_become_linked == true) {
+			phydm_primary_cca_reset(dm);
+			primary_cca->pri_cca_is_become_linked = dm->is_linked;
+		}
+		return;
+		
+	} else {
+		if (primary_cca->pri_cca_is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA][Linked !!!]\n");
+			primary_cca->pri_cca_is_become_linked = dm->is_linked;
+		}
+	}
+	
+	if (curr_bw != primary_cca->pre_bw) {
+		PHYDM_DBG(dm, DBG_PRI_CCA, "[Primary CCA] start ==>\n");
+		primary_cca->pre_bw = curr_bw;
+
+		if (curr_bw == CHANNEL_WIDTH_40) {
+			
+			if (*dm->sec_ch_offset == SECOND_CH_AT_LSB) {/* Primary CH @ upper sideband*/
+				
+				PHYDM_DBG(dm, DBG_PRI_CCA, "BW40M, Primary CH at USB\n");
+				phydm_write_dynamic_cca(dm, MF_USC);
+				
+			} else {	/*Primary CH @ lower sideband*/
+				
+				PHYDM_DBG(dm, DBG_PRI_CCA, "BW40M, Primary CH at LSB\n");
+				phydm_write_dynamic_cca(dm, MF_LSC);
+			}
+		} else {
+		
+			PHYDM_DBG(dm, DBG_PRI_CCA, "Not BW40M, USB + LSB\n");
+			phydm_primary_cca_reset(dm);
+		}
+	}
+}
+
+#if 0
+#if (RTL8188E_SUPPORT == 1)
+void
+odm_dynamic_primary_cca_8188e(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sta_info	*entry;
+	struct cmn_sta_info	*sta;
+	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+	struct phydm_pricca_struct		*primary_cca = &(dm->dm_pri_cca);
+	boolean		client_40mhz = false, client_tmp = false;      /* connected client BW */
+	boolean		is_connected = false;		/* connected or not */
+	u8	client_40mhz_pre = 0;
+	u32	counter = 0;
+	u8	delay = 1;
+	u64		cur_tx_ok_cnt;
+	u64		cur_rx_ok_cnt;
+	u8		sec_ch_offset = *(dm->sec_ch_offset);
+	u8		i;
+
+	if (!dm->is_linked)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	if (*(dm->band_width) == CHANNEL_WIDTH_20) {	/*curr bw*/
+		odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 0);
+		return;
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) || (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		sec_ch_offset = sec_ch_offset % 2 + 1; /* NIC's definition is reverse to AP   1:secondary below,  2: secondary above */
+	#endif
+	
+	PHYDM_DBG(dm, DBG_PRI_CCA, "Second CH Offset = %d\n", sec_ch_offset);
+
+	/* 3 Check Current WLAN Traffic */
+	cur_tx_ok_cnt = dm->tx_tp;
+	cur_rx_ok_cnt = dm->rx_tp;
+
+	/* ==================Debug Message==================== */
+	PHYDM_DBG(dm, DBG_PRI_CCA, "TP = %llu\n", cur_tx_ok_cnt + cur_rx_ok_cnt);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "is_BW40 = %d\n", *(dm->band_width));
+	PHYDM_DBG(dm, DBG_PRI_CCA, "BW_LSC = %d\n", false_alm_cnt->cnt_bw_lsc);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "BW_USC = %d\n", false_alm_cnt->cnt_bw_usc);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "CCA OFDM = %d\n", false_alm_cnt->cnt_ofdm_cca);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "CCA CCK = %d\n", false_alm_cnt->cnt_cck_cca);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "OFDM FA = %d\n", false_alm_cnt->cnt_ofdm_fail);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "CCK FA = %d\n", false_alm_cnt->cnt_cck_fail);
+	/* ================================================ */
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (ACTING_AS_AP(dm->adapter))   /* primary cca process only do at AP mode */
+#endif
+	{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		PHYDM_DBG(dm, DBG_PRI_CCA, "ACTING as AP mode=%d\n", ACTING_AS_AP(dm->adapter));
+		/* 3 To get entry's connection and BW infomation status. */
+		for (i = 0; i < ASSOCIATE_ENTRY_NUM; i++) {
+			if (IsAPModeExist(dm->adapter) && GetFirstExtAdapter(dm->adapter) != NULL)
+				entry = AsocEntry_EnumStation(GetFirstExtAdapter(dm->adapter), i);
+			else
+				entry = AsocEntry_EnumStation(GetDefaultAdapter(dm->adapter), i);
+			if (entry != NULL) {
+				client_tmp = entry->BandWidth;   /* client BW */
+				PHYDM_DBG(dm, DBG_PRI_CCA, "Client_BW=%d\n", client_tmp);
+				if (client_tmp > client_40mhz)
+					client_40mhz = client_tmp;     /* 40M/20M coexist => 40M priority is High */
+
+				if (entry->bAssociated) {
+					is_connected = true;  /* client is connected or not */
+					break;
+				}
+			} else
+				break;
+		}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		/* 3 To get entry's connection and BW infomation status. */
+
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+			sta = dm->phydm_sta_info[i];
+			if (is_sta_active(sta)) {
+				client_tmp = sta->bw_mode;
+				if (client_tmp > client_40mhz)
+					client_40mhz = client_tmp;     /* 40M/20M coexist => 40M priority is High */
+
+				is_connected = true;
+			}
+		}
+#endif
+		PHYDM_DBG(dm, DBG_PRI_CCA, "is_connected=%d\n", is_connected);
+		PHYDM_DBG(dm, DBG_PRI_CCA, "Is Client 40MHz=%d\n", client_40mhz);
+		/* 1 Monitor whether the interference exists or not */
+		if (primary_cca->monitor_flag == 1) {
+			if (sec_ch_offset == 1) {    /* secondary channel is below the primary channel */
+				if ((false_alm_cnt->cnt_ofdm_cca > 500) && (false_alm_cnt->cnt_bw_lsc > false_alm_cnt->cnt_bw_usc + 500)) {
+					if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1) {
+						primary_cca->intf_type = 1;
+						primary_cca->pri_cca_flag = 1;
+						odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT7, 2); /* USC MF */
+						if (primary_cca->dup_rts_flag == 1)
+							primary_cca->dup_rts_flag = 0;
+					} else {
+						primary_cca->intf_type = 2;
+						if (primary_cca->dup_rts_flag == 0)
+							primary_cca->dup_rts_flag = 1;
+					}
+
+				} else { /* interferecne disappear */
+					primary_cca->dup_rts_flag = 0;
+					primary_cca->intf_flag = 0;
+					primary_cca->intf_type = 0;
+				}
+			} else if (sec_ch_offset == 2) { /* secondary channel is above the primary channel */
+				if ((false_alm_cnt->cnt_ofdm_cca > 500) && (false_alm_cnt->cnt_bw_usc > false_alm_cnt->cnt_bw_lsc + 500)) {
+					if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1) {
+						primary_cca->intf_type = 1;
+						primary_cca->pri_cca_flag = 1;
+						odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT7, 1); /* LSC MF */
+						if (primary_cca->dup_rts_flag == 1)
+							primary_cca->dup_rts_flag = 0;
+					} else {
+						primary_cca->intf_type = 2;
+						if (primary_cca->dup_rts_flag == 0)
+							primary_cca->dup_rts_flag = 1;
+					}
+
+				} else { /* interferecne disappear */
+					primary_cca->dup_rts_flag = 0;
+					primary_cca->intf_flag = 0;
+					primary_cca->intf_type = 0;
+				}
+
+
+			}
+			primary_cca->monitor_flag = 0;
+		}
+
+		/* 1 Dynamic Primary CCA Main Function */
+		if (primary_cca->monitor_flag == 0) {
+			if (*(dm->band_width) == CHANNEL_WIDTH_40) {		/* if RFBW==40M mode which require to process primary cca */
+				/* 2 STA is NOT Connected */
+				if (!is_connected) {
+					PHYDM_DBG(dm, DBG_PRI_CCA, "STA NOT Connected!!!!\n");
+
+					if (primary_cca->pri_cca_flag == 1) {	/* reset primary cca when STA is disconnected */
+						primary_cca->pri_cca_flag = 0;
+						odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 0);
+					}
+					if (primary_cca->dup_rts_flag == 1)		/* reset Duplicate RTS when STA is disconnected */
+						primary_cca->dup_rts_flag = 0;
+
+					if (sec_ch_offset == 1) { /* secondary channel is below the primary channel */
+						if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_lsc * 5 > false_alm_cnt->cnt_bw_usc * 9)) {
+							primary_cca->intf_flag = 1;    /* secondary channel interference is detected!!! */
+							if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+								primary_cca->intf_type = 1;   	/* interference is shift */
+							else
+								primary_cca->intf_type = 2;   	/* interference is in-band */
+						} else {
+							primary_cca->intf_flag = 0;
+							primary_cca->intf_type = 0;
+						}
+					} else if (sec_ch_offset == 2) { /* secondary channel is above the primary channel */
+						if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_usc * 5 > false_alm_cnt->cnt_bw_lsc * 9)) {
+							primary_cca->intf_flag = 1;    /* secondary channel interference is detected!!! */
+							if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+								primary_cca->intf_type = 1;   	/* interference is shift */
+							else
+								primary_cca->intf_type = 2;   	/* interference is in-band */
+						} else {
+							primary_cca->intf_flag = 0;
+							primary_cca->intf_type = 0;
+						}
+					}
+					PHYDM_DBG(dm, DBG_PRI_CCA, "primary_cca=%d\n", primary_cca->pri_cca_flag);
+					PHYDM_DBG(dm, DBG_PRI_CCA, "Intf_Type=%d\n", primary_cca->intf_type);
+				}
+				/* 2 STA is Connected */
+				else {
+					if (client_40mhz == 0)		/* 3 */ { /* client BW = 20MHz */
+						if (primary_cca->pri_cca_flag == 0) {
+							primary_cca->pri_cca_flag = 1;
+							if (sec_ch_offset == 1)
+								odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 2);
+							else if (sec_ch_offset == 2)
+								odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 1);
+						}
+						PHYDM_DBG(dm, DBG_PRI_CCA, "STA Connected 20M!!! primary_cca=%d\n", primary_cca->pri_cca_flag);
+					} else		/* 3 */ { /* client BW = 40MHz */
+						if (primary_cca->intf_flag == 1) { /* interference is detected!! */
+							if (primary_cca->intf_type == 1) {
+								if (primary_cca->pri_cca_flag != 1) {
+									primary_cca->pri_cca_flag = 1;
+									if (sec_ch_offset == 1)
+										odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 2);
+									else if (sec_ch_offset == 2)
+										odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 1);
+								}
+							} else if (primary_cca->intf_type == 2) {
+								if (primary_cca->dup_rts_flag != 1)
+									primary_cca->dup_rts_flag = 1;
+							}
+						} else { /* if intf_flag==0 */
+							if ((cur_tx_ok_cnt + cur_rx_ok_cnt) < 1) { /* idle mode or TP traffic is very low */
+								if (sec_ch_offset == 1) {
+									if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_lsc * 5 > false_alm_cnt->cnt_bw_usc * 9)) {
+										primary_cca->intf_flag = 1;
+										if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+											primary_cca->intf_type = 1;   	/* interference is shift */
+										else
+											primary_cca->intf_type = 2;   	/* interference is in-band */
+									}
+								} else if (sec_ch_offset == 2) {
+									if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_usc * 5 > false_alm_cnt->cnt_bw_lsc * 9)) {
+										primary_cca->intf_flag = 1;
+										if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+											primary_cca->intf_type = 1;   	/* interference is shift */
+										else
+											primary_cca->intf_type = 2;   	/* interference is in-band */
+									}
+
+								}
+							} else { /* TP Traffic is High */
+								if (sec_ch_offset == 1) {
+									if (false_alm_cnt->cnt_bw_lsc > (false_alm_cnt->cnt_bw_usc + 500)) {
+										if (delay == 0) { /* add delay to avoid interference occurring abruptly, jump one time */
+											primary_cca->intf_flag = 1;
+											if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+												primary_cca->intf_type = 1;   	/* interference is shift */
+											else
+												primary_cca->intf_type = 2;   	/* interference is in-band */
+											delay = 1;
+										} else
+											delay = 0;
+									}
+								} else if (sec_ch_offset == 2) {
+									if (false_alm_cnt->cnt_bw_usc > (false_alm_cnt->cnt_bw_lsc + 500)) {
+										if (delay == 0) { /* add delay to avoid interference occurring abruptly */
+											primary_cca->intf_flag = 1;
+											if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+												primary_cca->intf_type = 1;   	/* interference is shift */
+											else
+												primary_cca->intf_type = 2;   	/* interference is in-band */
+											delay = 1;
+										} else
+											delay = 0;
+									}
+								}
+							}
+						}
+						PHYDM_DBG(dm, DBG_PRI_CCA, "Primary CCA=%d\n", primary_cca->pri_cca_flag);
+						PHYDM_DBG(dm, DBG_PRI_CCA, "Duplicate RTS=%d\n", primary_cca->dup_rts_flag);
+					}
+
+				} /* end of connected */
+			}
+		}
+		/* 1 Dynamic Primary CCA Monitor counter */
+		if ((primary_cca->pri_cca_flag == 1) || (primary_cca->dup_rts_flag == 1)) {
+			if (client_40mhz == 0) {  /* client=20M no need to monitor primary cca flag */
+				client_40mhz_pre = client_40mhz;
+				return;
+			}
+			counter++;
+			PHYDM_DBG(dm, DBG_PRI_CCA, "counter=%d\n", counter);
+			if ((counter == 30) || ((client_40mhz - client_40mhz_pre) == 1)) { /* Every 60 sec to monitor one time */
+				primary_cca->monitor_flag = 1;     /* monitor flag is triggered!!!!! */
+				if (primary_cca->pri_cca_flag == 1) {
+					primary_cca->pri_cca_flag = 0;
+					odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 0);
+				}
+				counter = 0;
+			}
+		}
+	}
+
+	client_40mhz_pre = client_40mhz;
+}
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_dynamic_primary_cca_mp_8192e(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	PADAPTER        adapter = (PADAPTER)dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	struct phydm_fa_struct		*false_alm_cnt = &(dm->false_alm_cnt);
+	struct phydm_pricca_struct		*primary_cca = &(dm->dm_pri_cca);
+	u64			OFDM_CCA, OFDM_FA, bw_usc_cnt, bw_lsc_cnt;
+	u8			sec_ch_offset;
+	static u8		count_down = PRI_CCA_MONITOR_TIME;
+
+	if (!dm->is_linked)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	OFDM_CCA = false_alm_cnt->cnt_ofdm_cca;
+	OFDM_FA = false_alm_cnt->cnt_ofdm_fail;
+	bw_usc_cnt = false_alm_cnt->cnt_bw_usc;
+	bw_lsc_cnt = false_alm_cnt->cnt_bw_lsc;
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: OFDM CCA=%d\n", OFDM_CCA);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: OFDM FA=%d\n", OFDM_FA);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: BW_USC=%d\n", bw_usc_cnt);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: BW_LSC=%d\n", bw_lsc_cnt);
+	sec_ch_offset = *(dm->sec_ch_offset);		/* NIC: 2: sec is below,  1: sec is above */
+
+	
+	if (IsAPModeExist(adapter)) {
+		phydm_write_dynamic_cca(dm, MF_USC_LSC);
+		return;
+	}
+
+	if (*(dm->band_width) != CHANNEL_WIDTH_40)
+		return;
+
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Cont Down= %d\n", count_down);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Primary_CCA_flag=%d\n", primary_cca->pri_cca_flag);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Intf_Type=%d\n", primary_cca->intf_type);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Intf_flag=%d\n", primary_cca->intf_flag);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Duplicate RTS Flag=%d\n", primary_cca->dup_rts_flag);
+
+	if (primary_cca->pri_cca_flag == 0) {
+		if (sec_ch_offset == SECOND_CH_AT_LSB) {  /* Primary channel is above   NOTE: duplicate CTS can remove this condition */
+
+			if ((OFDM_CCA > OFDMCCA_TH) && (bw_lsc_cnt > (bw_usc_cnt + bw_ind_bias))
+			    && (OFDM_FA > (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 1;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_USC);
+				primary_cca->pri_cca_flag = 1;
+			} else if ((OFDM_CCA > OFDMCCA_TH) && (bw_lsc_cnt > (bw_usc_cnt + bw_ind_bias))
+				&& (OFDM_FA < (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 2;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_USC);
+				primary_cca->pri_cca_flag = 1;
+				primary_cca->dup_rts_flag = 1;
+				hal_data->RTSEN = 1;
+			} else {
+				primary_cca->intf_type = 0;
+				primary_cca->intf_flag = 0;
+				phydm_write_dynamic_cca(dm, MF_USC_LSC);
+				hal_data->RTSEN = 0;
+				primary_cca->dup_rts_flag = 0;
+			}
+
+		} else if (sec_ch_offset == SECOND_CH_AT_USB) {
+			if ((OFDM_CCA > OFDMCCA_TH) && (bw_usc_cnt > (bw_lsc_cnt + bw_ind_bias))
+			    && (OFDM_FA > (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 1;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_LSC);
+				primary_cca->pri_cca_flag = 1;
+			} else if ((OFDM_CCA > OFDMCCA_TH) && (bw_usc_cnt > (bw_lsc_cnt + bw_ind_bias))
+				&& (OFDM_FA < (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 2;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_LSC);
+				primary_cca->pri_cca_flag = 1;
+				primary_cca->dup_rts_flag = 1;
+				hal_data->RTSEN = 1;
+			} else {
+				primary_cca->intf_type = 0;
+				primary_cca->intf_flag = 0;
+				phydm_write_dynamic_cca(dm, MF_USC_LSC);
+				hal_data->RTSEN = 0;
+				primary_cca->dup_rts_flag = 0;
+			}
+
+		}
+
+	} else {	/* primary_cca->pri_cca_flag==1 */
+
+		count_down--;
+		if (count_down == 0) {
+			count_down = PRI_CCA_MONITOR_TIME;
+			primary_cca->pri_cca_flag = 0;
+			phydm_write_dynamic_cca(dm, MF_USC_LSC);   /* default */
+			hal_data->RTSEN = 0;
+			primary_cca->dup_rts_flag = 0;
+			primary_cca->intf_type = 0;
+			primary_cca->intf_flag = 0;
+		}
+
+	}
+}
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_intf_detection(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct		*false_alm_cnt = &(dm->false_alm_cnt);
+	struct phydm_pricca_struct			*primary_cca = &(dm->dm_pri_cca);
+
+	if ((false_alm_cnt->cnt_ofdm_cca > OFDMCCA_TH)
+	    && (false_alm_cnt->cnt_bw_lsc > (false_alm_cnt->cnt_bw_usc + bw_ind_bias))) {
+		primary_cca->intf_flag = 1;
+		primary_cca->ch_offset = 1;  /* 1:LSC, 2:USC */
+		if (false_alm_cnt->cnt_ofdm_fail > (false_alm_cnt->cnt_ofdm_cca >> 1))
+			primary_cca->intf_type = 1;
+		else
+			primary_cca->intf_type = 2;
+	} else if ((false_alm_cnt->cnt_ofdm_cca > OFDMCCA_TH)
+		&& (false_alm_cnt->cnt_bw_usc > (false_alm_cnt->cnt_bw_lsc + bw_ind_bias))) {
+		primary_cca->intf_flag = 1;
+		primary_cca->ch_offset = 2;  /* 1:LSC, 2:USC */
+		if (false_alm_cnt->cnt_ofdm_fail > (false_alm_cnt->cnt_ofdm_cca >> 1))
+			primary_cca->intf_type = 1;
+		else
+			primary_cca->intf_type = 2;
+	} else {
+		primary_cca->intf_flag = 0;
+		primary_cca->intf_type = 0;
+		primary_cca->ch_offset = 0;
+	}
+
+}
+
+void
+odm_dynamic_primary_cca_ap_8192e(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct		*primary_cca = &(dm->dm_pri_cca);
+	u8		i;
+	static u32	count_down = PRI_CCA_MONITOR_TIME;
+	u8		STA_BW = false, STA_BW_pre = false, STA_BW_TMP = false;
+	boolean		is_connected = false;
+	u8		sec_ch_offset;
+	u8		cur_mf_state;
+	struct cmn_sta_info	*entry;
+
+	if (!dm->is_linked)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	sec_ch_offset = *(dm->sec_ch_offset);		/* AP: 1: sec is below,  2: sec is above */
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		entry = dm->phydm_sta_info[i];
+		if (is_sta_active(entry)) {
+			STA_BW_TMP = entry->bw_mode;
+			if (STA_BW_TMP > STA_BW)
+				STA_BW = STA_BW_TMP;
+			is_connected = true;
+		}
+	}
+
+	if (*(dm->band_width) == CHANNEL_WIDTH_40) {
+		
+		if (primary_cca->pri_cca_flag == 0) {
+			if (is_connected) {
+				if (STA_BW == CHANNEL_WIDTH_20) { /* 2 STA BW=20M */
+					primary_cca->pri_cca_flag = 1;
+					if (sec_ch_offset == 1) {
+						cur_mf_state = MF_USC;
+						phydm_write_dynamic_cca(dm, cur_mf_state);
+					} else if (sec_ch_offset == 2) {
+						cur_mf_state = MF_USC;
+						phydm_write_dynamic_cca(dm, cur_mf_state);
+					}
+				} else {     			/* 2  STA BW=40M */
+					if (primary_cca->intf_flag == 0)
+						odm_intf_detection(dm);
+					else {	/* intf_flag = 1 */
+						if (primary_cca->intf_type == 1) {
+							if (primary_cca->ch_offset == 1) {
+								cur_mf_state = MF_USC;
+								if (sec_ch_offset == 1)  /* AP,  1: primary is above  2: primary is below */
+									phydm_write_dynamic_cca(dm, cur_mf_state);
+							} else if (primary_cca->ch_offset == 2) {
+								cur_mf_state = MF_LSC;
+								if (sec_ch_offset == 2)
+									phydm_write_dynamic_cca(dm, cur_mf_state);
+							}
+						} else if (primary_cca->intf_type == 2)
+							PHYDM_DBG(dm, DBG_PRI_CCA, "92E: primary_cca->intf_type = 2\n");
+					}
+				}
+
+			} else		/* disconnected  interference detection */
+				odm_intf_detection(dm); /* end of disconnected */
+
+
+		} else {	/* primary_cca->pri_cca_flag == 1 */
+
+			if (STA_BW == 0) {
+				STA_BW_pre = STA_BW;
+				return;
+			}
+
+			count_down--;
+			if ((count_down == 0) || ((STA_BW & STA_BW_pre) != 1)) {
+				count_down = PRI_CCA_MONITOR_TIME;
+				primary_cca->pri_cca_flag = 0;
+				primary_cca->intf_type = 0;
+				primary_cca->intf_flag = 0;
+				cur_mf_state = MF_USC_LSC;
+				phydm_write_dynamic_cca(dm, cur_mf_state); /* default */
+			}
+		}
+		STA_BW_pre = STA_BW;
+
+	} else {
+		/* 2 Reset */
+		phydm_primary_cca_init(dm);
+		cur_mf_state = MF_USC_LSC;
+		phydm_write_dynamic_cca(dm, cur_mf_state);
+		count_down = PRI_CCA_MONITOR_TIME;
+	}
+
+}
+#endif
+
+
+#endif /* RTL8192E_SUPPORT == 1 */
+#endif
+
+
+#endif
+
+boolean
+odm_dynamic_primary_cca_dup_rts(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_PRIMARY_CCA
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct		*primary_cca = &dm->dm_pri_cca;
+
+	return	primary_cca->dup_rts_flag;
+#else
+	return	0;	
+#endif
+}
+
+void
+phydm_primary_cca_init(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_PRIMARY_CCA
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct		*primary_cca = &dm->dm_pri_cca;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA] Init ==>\n");
+	#if (RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1)
+	primary_cca->dup_rts_flag = 0;
+	primary_cca->intf_flag = 0;
+	primary_cca->intf_type = 0;
+	primary_cca->monitor_flag = 0;
+	primary_cca->pri_cca_flag = 0;
+	primary_cca->ch_offset = 0;
+	#endif
+	primary_cca->mf_state = 0xff;
+	primary_cca->pre_bw = (enum channel_width)0xff;
+	
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		primary_cca->cca_th_40m_bkp = (u8)odm_get_bb_reg(dm, 0xc84, 0xf0000000);
+#endif
+}
+
+void
+phydm_primary_cca(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_PRIMARY_CCA
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ic_type & ODM_IC_11N_SERIES))
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	phydm_primary_cca_11n(dm);
+
+#endif
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_primary_cca.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_primary_cca.h
new file mode 100644
index 000000000000..c619de5a5c57
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_primary_cca.h
@@ -0,0 +1,126 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_PRIMARYCCA_H__
+#define	__PHYDM_PRIMARYCCA_H__
+
+#define PRIMARYCCA_VERSION	"1.0"  /*2017.03.23, Dino*/
+
+/*============================================================*/
+/*Definition */
+/*============================================================*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#define	SECOND_CH_AT_LSB	2	/*primary CH @ MSB,  SD4: HAL_PRIME_CHNL_OFFSET_UPPER*/
+#define	SECOND_CH_AT_USB	1	/*primary CH @ LSB,   SD4: HAL_PRIME_CHNL_OFFSET_LOWER*/
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#define	SECOND_CH_AT_LSB	2	/*primary CH @ MSB,  SD7: HAL_PRIME_CHNL_OFFSET_UPPER*/
+#define	SECOND_CH_AT_USB	1	/*primary CH @ LSB,   SD7: HAL_PRIME_CHNL_OFFSET_LOWER*/
+#else /*if (DM_ODM_SUPPORT_TYPE == ODM_AP)*/
+#define	SECOND_CH_AT_LSB	1	/*primary CH @ MSB,  SD8: HT_2NDCH_OFFSET_BELOW*/
+#define	SECOND_CH_AT_USB	2	/*primary CH @ LSB,   SD8: HT_2NDCH_OFFSET_ABOVE*/
+#endif
+
+#define	OFDMCCA_TH	500
+#define	bw_ind_bias		500
+#define	PRI_CCA_MONITOR_TIME	30
+
+#ifdef PHYDM_PRIMARY_CCA
+
+/*============================================================*/
+/*structure and define*/
+/*============================================================*/
+enum	primary_cca_ch_position {  /*N-series REG0xc6c[8:7]*/
+	MF_USC_LSC = 0,
+	MF_LSC = 1,
+	MF_USC = 2
+};
+
+struct phydm_pricca_struct {
+	#if (RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1)
+	u8	pri_cca_flag;
+	u8	intf_flag;
+	u8	intf_type;
+	u8	monitor_flag;
+	u8	ch_offset;
+	#endif
+	u8	dup_rts_flag;
+	u8	cca_th_40m_bkp; /*c84[31:28]*/
+	enum channel_width	pre_bw;
+	u8	pri_cca_is_become_linked;
+	u8	mf_state;
+};
+
+/*============================================================*/
+/*function prototype*/
+/*============================================================*/
+
+#if 0
+#if (RTL8192E_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_dynamic_primary_cca_mp_8192e(
+	void			*dm_void
+);
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_dynamic_primary_cca_ap_8192e(
+	void			*dm_void
+);
+#endif
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+
+void
+odm_dynamic_primary_cca_8188e(
+	void			*dm_void
+);
+#endif
+#endif
+
+#endif /*#ifdef PHYDM_PRIMARY_CCA*/
+
+
+boolean
+odm_dynamic_primary_cca_dup_rts(
+	void			*dm_void
+);
+
+void
+phydm_primary_cca_init(
+	void			*dm_void
+);
+
+void
+phydm_primary_cca(
+	void			*dm_void
+);
+
+
+#endif /*#ifndef	__PHYDM_PRIMARYCCA_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_psd.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_psd.c
new file mode 100644
index 000000000000..8717acae076e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_psd.c
@@ -0,0 +1,402 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+//============================================================
+// include files
+//============================================================
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef CONFIG_PSD_TOOL
+
+u32
+phydm_get_psd_data(
+	void			*dm_void,
+	u32			psd_tone_idx,
+	u32			igi
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u32		psd_report = 0;
+	
+	odm_set_bb_reg(dm, dm_psd_table->psd_reg, 0x3ff, psd_tone_idx);
+	
+	odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(22), 1); /*PSD trigger start*/
+	ODM_delay_us(10);
+	odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(22), 0); /*PSD trigger stop*/
+
+	psd_report = odm_get_bb_reg(dm, dm_psd_table->psd_report_reg, 0xffff);
+	psd_report = odm_convert_to_db(psd_report) + igi;
+
+	return psd_report;
+}
+
+u8		psd_result_cali_tone_8821[7]= {21, 28, 33, 93, 98, 105, 127};
+u8		psd_result_cali_val_8821[7] = {67,69,71,72,71,69,67};	
+
+void
+phydm_psd(
+	void		*dm_void,
+	u32		igi,
+	u16		start_point,
+	u16		stop_point
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u32		i = 0, mod_tone_idx;
+	u32		t = 0;
+	u16		fft_max_half_bw;
+	u32		psd_igi_a_reg;
+	u32		psd_igi_b_reg;
+	u16		psd_fc_channel = dm_psd_table->psd_fc_channel;
+	u8		ag_rf_mode_reg = 0;
+	u8		rf_reg18_9_8 = 0;
+	u32		psd_result_tmp = 0;
+	u8		psd_result = 0;
+	u8		psd_result_cali_tone[7] = {0};
+	u8		psd_result_cali_val[7] = {0};
+	u8		noise_table_idx = 0;
+	u8		set_result;
+
+	if (dm->support_ic_type == ODM_RTL8821) {
+		odm_move_memory(dm, psd_result_cali_tone, psd_result_cali_tone_8821, 7);
+		odm_move_memory(dm, psd_result_cali_val, psd_result_cali_val_8821, 7);
+	}
+	
+	dm_psd_table->psd_in_progress = 1;
+
+	/*[Stop DIG]*/
+	dm->support_ability &= ~(ODM_BB_DIG);
+	dm->support_ability &= ~(ODM_BB_FA_CNT);
+
+
+
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD Start =>\n");
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		psd_igi_a_reg = 0xc50;
+		psd_igi_b_reg = 0xe50;
+	} else {
+		psd_igi_a_reg = 0xc50;
+		psd_igi_b_reg = 0xc58;
+	}
+	
+	/*[back up IGI]*/
+	dm_psd_table->initial_gain_backup = odm_get_bb_reg(dm, psd_igi_a_reg, 0xff);
+	odm_set_bb_reg(dm, psd_igi_a_reg, 0xff, 0x6e); /*IGI target at 0dBm & make it can't CCA*/
+	odm_set_bb_reg(dm, psd_igi_b_reg, 0xff, 0x6e); /*IGI target at 0dBm & make it can't CCA*/
+	ODM_delay_us(10);
+	
+	if (phydm_stop_ic_trx(dm, PHYDM_SET) == PHYDM_SET_FAIL) {
+		PHYDM_DBG(dm, ODM_COMP_API, "STOP_TRX_FAIL\n");
+		return;
+	}
+
+	/*[Set IGI]*/
+	odm_set_bb_reg(dm, psd_igi_a_reg, 0xff, igi);
+	odm_set_bb_reg(dm, psd_igi_b_reg, 0xff, igi);
+	
+	/*[Backup RF Reg]*/
+	dm_psd_table->rf_0x18_bkp = odm_get_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK);
+	dm_psd_table->rf_0x18_bkp_b = odm_get_rf_reg(dm, RF_PATH_B, 0x18, RFREGOFFSETMASK);
+
+	if (psd_fc_channel > 14) {
+		
+		rf_reg18_9_8 = 1;
+		
+		if (36 <= psd_fc_channel && psd_fc_channel <= 64) 
+			ag_rf_mode_reg = 0x1;
+		else if (100 <= psd_fc_channel && psd_fc_channel <= 140) 
+			ag_rf_mode_reg = 0x3; 
+		else if (140 < psd_fc_channel) 
+			ag_rf_mode_reg = 0x5; 
+	}
+
+	/* RF path-a */
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0xff, psd_fc_channel);     /* Set RF fc*/
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0x300, rf_reg18_9_8);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0xc00, dm_psd_table->psd_bw_rf_reg);     /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0xf0000, ag_rf_mode_reg);     /* Set RF ag fc mode*/
+
+	/* RF path-b */
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0xff, psd_fc_channel);     /* Set RF fc*/
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0x300, rf_reg18_9_8);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0xc00, dm_psd_table->psd_bw_rf_reg);     /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0xf0000, ag_rf_mode_reg);     /* Set RF ag fc mode*/
+
+	PHYDM_DBG(dm, ODM_COMP_API, "0xc50=((0x%x))\n", odm_get_bb_reg(dm, 0xc50, MASKDWORD));
+	/*PHYDM_DBG(dm, ODM_COMP_API, "RF0x0=((0x%x))\n", odm_get_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK));*/
+	PHYDM_DBG(dm, ODM_COMP_API, "RF0x18=((0x%x))\n", odm_get_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK));
+	
+	/*[Stop 3-wires]*/
+	phydm_stop_3_wire(dm, PHYDM_SET);
+	
+	ODM_delay_us(10);
+
+	if (stop_point > (dm_psd_table->fft_smp_point-1))
+		stop_point = (dm_psd_table->fft_smp_point-1);	
+
+	if (start_point > (dm_psd_table->fft_smp_point-1))
+		start_point = (dm_psd_table->fft_smp_point-1);
+
+	if (start_point > stop_point)
+		stop_point = start_point;
+
+
+	for (i = start_point; i <= stop_point; i++ ) {
+		fft_max_half_bw = (dm_psd_table->fft_smp_point)>>1;
+
+		if (i < fft_max_half_bw) {
+			mod_tone_idx = i + fft_max_half_bw;
+		} else {
+			mod_tone_idx = i - fft_max_half_bw;
+		}
+		
+		psd_result_tmp = 0;
+		for (t = 0; t < dm_psd_table->sw_avg_time; t++) {
+			psd_result_tmp += phydm_get_psd_data(dm, mod_tone_idx, igi);
+			/**/
+		}
+		psd_result = (u8)((psd_result_tmp/dm_psd_table->sw_avg_time)) - dm_psd_table->psd_pwr_common_offset;
+
+		if( dm_psd_table->fft_smp_point == 128 && (dm_psd_table->noise_k_en)) {
+			if (i > psd_result_cali_tone[noise_table_idx]) {
+				noise_table_idx ++;
+			}
+
+			if (noise_table_idx > 6)
+				noise_table_idx = 6;
+
+			if (psd_result >= psd_result_cali_val[noise_table_idx])
+				psd_result = psd_result - psd_result_cali_val[noise_table_idx];
+			else
+				psd_result = 0;
+			
+
+			dm_psd_table->psd_result[i] = psd_result;
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_API, "[%d] N_cali = %d, PSD = %d\n", mod_tone_idx, psd_result_cali_val[noise_table_idx],  psd_result);
+
+	}
+
+	/*[Start 3-wires]*/
+	phydm_stop_3_wire(dm, PHYDM_REVERT);
+	
+	ODM_delay_us(10);
+
+	/*[Revert Reg]*/
+	set_result = phydm_stop_ic_trx(dm, PHYDM_REVERT);
+	
+	odm_set_bb_reg(dm, psd_igi_a_reg, 0xff, dm_psd_table->initial_gain_backup);
+	odm_set_bb_reg(dm, psd_igi_b_reg, 0xff, dm_psd_table->initial_gain_backup);
+	
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, dm_psd_table->rf_0x18_bkp);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, RFREGOFFSETMASK, dm_psd_table->rf_0x18_bkp_b);
+	
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD finished\n\n");
+	
+	dm->support_ability |= ODM_BB_DIG;
+	dm->support_ability |= ODM_BB_FA_CNT;
+	dm_psd_table->psd_in_progress = 0;
+	
+
+}
+
+void
+phydm_psd_para_setting(
+	void		*dm_void,
+	u8		sw_avg_time,
+	u8		hw_avg_time,	
+	u8		i_q_setting,
+	u16		fft_smp_point,
+	u8		ant_sel,
+	u8		psd_input,
+	u8		channel,
+	u8		noise_k_en
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u8		fft_smp_point_idx = 0;
+
+	dm_psd_table->fft_smp_point = fft_smp_point;
+
+	if (sw_avg_time == 0)
+		sw_avg_time = 1;
+	
+	dm_psd_table->sw_avg_time = sw_avg_time;
+	dm_psd_table->psd_fc_channel = channel;
+	dm_psd_table->noise_k_en = noise_k_en;
+		
+	if (fft_smp_point == 128)
+		fft_smp_point_idx = 0;
+	else if (fft_smp_point == 256)
+		fft_smp_point_idx = 1;
+	else if (fft_smp_point == 512)
+		fft_smp_point_idx = 2;
+	else if (fft_smp_point == 1024)
+		fft_smp_point_idx = 3;
+		
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		odm_set_bb_reg(dm, 0x910, BIT(11) | BIT(10), i_q_setting);
+		odm_set_bb_reg(dm, 0x910, BIT(13) | BIT(12), hw_avg_time);
+		odm_set_bb_reg(dm, 0x910, BIT(15) | BIT(14), fft_smp_point_idx);
+		odm_set_bb_reg(dm, 0x910, BIT(17) | BIT(16), ant_sel);
+		odm_set_bb_reg(dm, 0x910, BIT(23), psd_input);
+#if 0
+	} else {	/*ODM_IC_11N_SERIES*/
+#endif
+	}
+
+	/*bw = (*dm->band_width); //ODM_BW20M */
+	/*channel = *(dm->channel);*/
+	
+	
+
+
+}
+
+void
+phydm_psd_init(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD para init\n");
+
+	dm_psd_table->psd_in_progress = false;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		dm_psd_table->psd_reg = 0x910;
+		dm_psd_table->psd_report_reg = 0xF44;
+
+		if (ODM_IC_11AC_2_SERIES)
+			dm_psd_table->psd_bw_rf_reg = 1;	/*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		else
+			dm_psd_table->psd_bw_rf_reg = 2;	/*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		
+	} else {
+		dm_psd_table->psd_reg = 0x808;
+		dm_psd_table->psd_report_reg = 0x8B4;
+		dm_psd_table->psd_bw_rf_reg = 2; /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+	}
+
+	if (dm->support_ic_type == ODM_RTL8812)
+		dm_psd_table->psd_pwr_common_offset = 0;
+	else if (dm->support_ic_type == ODM_RTL8821)
+		dm_psd_table->psd_pwr_common_offset = 0;
+	else
+		dm_psd_table->psd_pwr_common_offset = 0;
+
+	phydm_psd_para_setting(dm, 1, 2, 3, 128, 0, 0, 7, 0);
+	/*phydm_psd(dm, 0x3c, 0, 127);*/			/* target at -50dBm */
+
+
+}
+
+void
+phydm_psd_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{0} {sw_avg} {hw_avg 0:3} {1:I,2:Q,3:IQ} {fft_point: 128*(1:4)} {path_sel 0~3} {0:ADC, 1:RXIQC} {CH} {noise_k}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {IGI(hex)} {start_point} {stop_point}\n");
+		goto out;
+	}
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if (var1[0] == 0) {
+		for (i = 1; i < 10; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+			}
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "sw_avg_time=((%d)), hw_avg_time=((%d)), IQ=((%d)), fft=((%d)), path=((%d)), input =((%d)) ch=((%d)), noise_k=((%d))\n",
+					
+					var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], (u8)var1[7], (u8)var1[8]);
+		phydm_psd_para_setting(dm, (u8)var1[1], (u8)var1[2], (u8)var1[3], (u16)var1[4], (u8)var1[5], (u8)var1[6], (u8)var1[7], (u8)var1[8]);
+
+	} else if (var1[0] == 1) {
+		PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
+		PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+		PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "IGI=((0x%x)), start_point=((%d)), stop_point=((%d))\n",
+			       var1[1], var1[2], var1[3]);
+		dm->debug_components |= ODM_COMP_API;
+		phydm_psd(dm, var1[1], (u16)var1[2], (u16)var1[3]);
+		dm->debug_components &= (~ODM_COMP_API);
+	}
+
+out:
+	*_used = used;
+	*_out_len = out_len;
+	
+}
+
+u8
+phydm_get_psd_result_table(
+	void		*dm_void,
+	int 		index
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u8 		temp_result = 0;
+
+	if(index<128)
+		temp_result = dm_psd_table->psd_result[index];
+
+	return temp_result;
+	
+}
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_psd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_psd.h
new file mode 100644
index 000000000000..df232780fbc2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_psd.h
@@ -0,0 +1,102 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMPSD_H__
+#define    __PHYDMPSD_H__
+
+/*#define PSD_VERSION	"1.0"*/  /*2016.09.22  Dino*/
+#define PSD_VERSION	"1.1"  /*2016.10.07  Dino, Add Option for PSD Tone index Selection */
+
+#ifdef CONFIG_PSD_TOOL
+
+
+struct psd_info {
+	u8	psd_in_progress;
+	u32	psd_reg;
+	u32	psd_report_reg;
+	u8	psd_pwr_common_offset;
+	u16	sw_avg_time;
+	u16	fft_smp_point;
+	u32	initial_gain_backup;
+	u32	rf_0x18_bkp;
+	u32	rf_0x18_bkp_b;
+	u16	psd_fc_channel;
+	u32	psd_bw_rf_reg;
+	u8	psd_result[128];
+	u8	noise_k_en;
+};
+
+u32
+phydm_get_psd_data(
+	void			*dm_void,
+	u32			psd_tone_idx,
+	u32			igi
+);
+
+void
+phydm_psd_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+void
+phydm_psd(
+	void		*dm_void,
+	u32		igi,
+	u16		start_point,
+	u16		stop_point
+);
+
+void
+phydm_psd_para_setting(
+	void		*dm_void,
+	u8		sw_avg_time,
+	u8		hw_avg_time,
+	u8		i_q_setting,
+	u16		fft_smp_point,
+	u8		ant_sel,
+	u8		psd_input,
+	u8		channel,
+	u8		noise_k_en
+);
+
+void
+phydm_psd_init(
+	void		*dm_void
+);
+
+u8
+phydm_get_psd_result_table(
+	void		*dm_void,
+	int		index
+);
+
+#endif
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rainfo.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rainfo.c
new file mode 100644
index 000000000000..73af1a290569
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rainfo.c
@@ -0,0 +1,2441 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_h2C_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			h2c_parameter[H2C_MAX_LENGTH] = {0};
+	u8			phydm_h2c_id = (u8)dm_value[0];
+	u8			i;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Phydm Send H2C_ID (( 0x%x))\n", phydm_h2c_id);
+	for (i = 0; i < H2C_MAX_LENGTH; i++) {
+		h2c_parameter[i] = (u8)dm_value[i + 1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "H2C: Byte[%d] = ((0x%x))\n", i,
+			       h2c_parameter[i]);
+	}
+
+	odm_fill_h2c_cmd(dm, phydm_h2c_id, H2C_MAX_LENGTH, h2c_parameter);
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_fw_fix_rate(
+	void		*dm_void,
+	u8		en, 
+	u8		macid, 
+	u8		bw, 
+	u8		rate
+	
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	reg_u32_tmp;
+
+	if (dm->support_ic_type & PHYDM_IC_8051_SERIES) {
+		
+		reg_u32_tmp = (bw << 24) | (rate << 16) | (macid << 8) | en;
+		odm_set_bb_reg(dm, 0x4a0, MASKDWORD, reg_u32_tmp);
+			
+	} else {
+	
+		if (en == 1)
+			reg_u32_tmp = (0x60 << 24) | (macid << 16) | (bw << 8) | rate;
+		else
+			reg_u32_tmp = 0x40000000;
+			
+		odm_set_bb_reg(dm, 0x450, MASKDWORD, reg_u32_tmp);
+	}
+	if (en == 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "FW fix TX rate[id =%d], %dM, Rate(%d)=", macid, (20 << bw), rate);
+		phydm_print_rate(dm, rate, ODM_COMP_API);
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "Auto Rate\n");
+	}
+}
+
+void
+phydm_ra_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	char	help[] = "-h";
+	u32	var1[5] = {0};
+	u8	i = 0;
+	u32	reg_u32_tmp;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+	}
+	
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {0:-,1:+} {ofst}: set offset\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {100}: show offset\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{2} {en} {macid} {bw} {rate}: fw fix rate\n");
+		
+	} else if (var1[0] == 1) { /*Adjust PCR offset*/
+
+		if (var1[1] == 100) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Get] RA_ofst=((%s%d))\n", 
+				       ((ra_tab->RA_threshold_offset == 0) ? " " : ((ra_tab->RA_offset_direction) ? "+" : "-")),
+				       ra_tab->RA_threshold_offset);
+
+		} else if (var1[1] == 0) {
+			ra_tab->RA_offset_direction = 0;
+			ra_tab->RA_threshold_offset = (u8)var1[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Set] RA_ofst=((-%d))\n",
+				       ra_tab->RA_threshold_offset);
+		} else if (var1[1] == 1) {
+			ra_tab->RA_offset_direction = 1;
+			ra_tab->RA_threshold_offset = (u8)var1[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Set] RA_ofst=((+%d))\n",
+				       ra_tab->RA_threshold_offset);
+		}
+		
+	} else if (var1[0] == 2) { /*FW fix rate*/
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, 
+			       "[FW fix TX Rate] {en, macid,bw,rate}={%d, %d, %d, 0x%x}",
+			       var1[1], var1[2], var1[3], var1[4]);
+		
+		phydm_fw_fix_rate(dm, (u8)var1[1], (u8)var1[2], (u8)var1[3], (u8)var1[4]);
+		
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[Set] Error\n");
+		/**/
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+
+void
+odm_c2h_ra_para_report_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (defined(CONFIG_RA_DBG_CMD))
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+#endif
+
+	u8	para_idx = cmd_buf[0]; /*Retry Penalty, NH, NL*/
+#if (defined(CONFIG_RA_DBG_CMD))
+	u8	rate_type_start = cmd_buf[1];
+	u8	rate_type_length = cmd_len - 2;
+#endif
+	u8	i;
+
+
+	PHYDM_DBG(dm, DBG_RA, "[ From FW C2H RA Para ]  cmd_buf[0]= (( %d ))\n", cmd_buf[0]);
+
+#if (defined(CONFIG_RA_DBG_CMD))
+	if (para_idx == RADBG_RTY_PENALTY) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |RTY Penality index|\n");
+
+		for (i = 0 ; i < (rate_type_length) ; i++) {
+			if (ra_tab->is_ra_dbg_init)
+				ra_tab->RTY_P_default[rate_type_start + i] = cmd_buf[2 + i];
+
+			ra_tab->RTY_P[rate_type_start + i] = cmd_buf[2 + i];
+			PHYDM_DBG(dm, DBG_RA, "%8d  %15d\n", (rate_type_start + i), ra_tab->RTY_P[rate_type_start + i]);
+		}
+
+	} else	if (para_idx == RADBG_N_HIGH) {
+		/**/
+		PHYDM_DBG(dm, DBG_RA, " |rate index|    |N-High|\n");
+
+
+	} else if (para_idx == RADBG_N_LOW) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |N-Low|\n");
+		/**/
+	} else if (para_idx == RADBG_RATE_UP_RTY_RATIO) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |rate Up RTY Ratio|\n");
+
+		for (i = 0; i < (rate_type_length); i++) {
+			if (ra_tab->is_ra_dbg_init)
+				ra_tab->RATE_UP_RTY_RATIO_default[rate_type_start + i] = cmd_buf[2 + i];
+
+			ra_tab->RATE_UP_RTY_RATIO[rate_type_start + i] = cmd_buf[2 + i];
+			PHYDM_DBG(dm, DBG_RA, "%8d  %15d\n", (rate_type_start + i), ra_tab->RATE_UP_RTY_RATIO[rate_type_start + i]);
+		}
+	} else	 if (para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |rate Down RTY Ratio|\n");
+
+		for (i = 0; i < (rate_type_length); i++) {
+			if (ra_tab->is_ra_dbg_init)
+				ra_tab->RATE_DOWN_RTY_RATIO_default[rate_type_start + i] = cmd_buf[2 + i];
+
+			ra_tab->RATE_DOWN_RTY_RATIO[rate_type_start + i] = cmd_buf[2 + i];
+			PHYDM_DBG(dm, DBG_RA, "%8d  %15d\n", (rate_type_start + i), ra_tab->RATE_DOWN_RTY_RATIO[rate_type_start + i]);
+		}
+	} else
+#endif
+		if (para_idx == RADBG_DEBUG_MONITOR1) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+			if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "RSSI =", cmd_buf[1]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "rate =", cmd_buf[2] & 0x7f);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "SGI =", (cmd_buf[2] & 0x80) >> 7);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "BW =", cmd_buf[3]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "BW_max =", cmd_buf[4]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "multi_rate0 =", cmd_buf[5]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "multi_rate1 =", cmd_buf[6]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "DISRA =",	cmd_buf[7]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "VHT_EN =", cmd_buf[8]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "SGI_support =",	cmd_buf[9]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "try_ness =", cmd_buf[10]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "pre_rate =", cmd_buf[11]);
+			} else {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "RSSI =", cmd_buf[1]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %x\n", "BW =", cmd_buf[2]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "DISRA =", cmd_buf[3]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "VHT_EN =", cmd_buf[4]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Hightest rate =", cmd_buf[5]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "Lowest rate =", cmd_buf[6]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "SGI_support =", cmd_buf[7]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Rate_ID =",	cmd_buf[8]);
+			}
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+		} else	 if (para_idx == RADBG_DEBUG_MONITOR2) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+			if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "rate_id =", cmd_buf[1]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "highest_rate =", cmd_buf[2]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "lowest_rate =", cmd_buf[3]);
+
+				for (i = 4; i <= 11; i++)
+					PHYDM_DBG(dm, DBG_FW_TRACE, "RAMASK =  0x%x\n", cmd_buf[i]);
+			} else {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %x%x  %x%x  %x%x  %x%x\n", "RA Mask:",
+					cmd_buf[8], cmd_buf[7], cmd_buf[6], cmd_buf[5], cmd_buf[4], cmd_buf[3], cmd_buf[2], cmd_buf[1]);
+			}
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+		} else	 if (para_idx == RADBG_DEBUG_MONITOR3) {
+			for (i = 0; i < (cmd_len - 1); i++)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "content[%d] = %d\n", i, cmd_buf[1 + i]);
+		} else	 if (para_idx == RADBG_DEBUG_MONITOR4)
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  {%d.%d}\n", "RA version =", cmd_buf[1], cmd_buf[2]);
+		else if (para_idx == RADBG_DEBUG_MONITOR5) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "Current rate =", cmd_buf[1]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Retry ratio =", cmd_buf[2]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "rate down ratio =", cmd_buf[3]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "highest rate =", cmd_buf[4]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  {0x%x 0x%x}\n", "Muti-try =", cmd_buf[5], cmd_buf[6]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x%x%x%x%x\n", "RA mask =", cmd_buf[11], cmd_buf[10], cmd_buf[9], cmd_buf[8], cmd_buf[7]);
+		}
+}
+
+void
+phydm_ra_dynamic_retry_count(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_ARFR))
+		return;
+
+	/*PHYDM_DBG(dm, DBG_RA, "dm->pre_b_noisy = %d\n", dm->pre_b_noisy );*/
+	if (dm->pre_b_noisy != dm->noisy_decision) {
+		if (dm->noisy_decision) {
+			PHYDM_DBG(dm, DBG_DYN_ARFR, "Noisy Env. RA fallback\n");
+			odm_set_mac_reg(dm, 0x430, MASKDWORD, 0x0);
+			odm_set_mac_reg(dm, 0x434, MASKDWORD, 0x04030201);
+		} else {
+			PHYDM_DBG(dm, DBG_DYN_ARFR, "Clean Env. RA fallback\n");
+			odm_set_mac_reg(dm, 0x430, MASKDWORD, 0x01000000);
+			odm_set_mac_reg(dm, 0x434, MASKDWORD, 0x06050402);
+		}
+		dm->pre_b_noisy = dm->noisy_decision;
+	}
+}
+
+void
+phydm_print_rate(
+	void	*dm_void,
+	u8	rate,
+	u32	dbg_component
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		legacy_table[12] = {1, 2, 5, 11, 6, 9, 12, 18, 24, 36, 48, 54};
+	u8		rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8		vht_en = (rate_idx >= ODM_RATEVHTSS1MCS0) ? 1 : 0;
+	u8		b_sgi = (rate & 0x80) >> 7;
+
+	PHYDM_DBG_F(dm, dbg_component, "( %s%s%s%s%d%s%s)\n",
+		((rate_idx >= ODM_RATEVHTSS1MCS0) && (rate_idx <= ODM_RATEVHTSS1MCS9)) ? "VHT 1ss  " : "",
+		((rate_idx >= ODM_RATEVHTSS2MCS0) && (rate_idx <= ODM_RATEVHTSS2MCS9)) ? "VHT 2ss " : "",
+		((rate_idx >= ODM_RATEVHTSS3MCS0) && (rate_idx <= ODM_RATEVHTSS3MCS9)) ? "VHT 3ss " : "",
+			(rate_idx >= ODM_RATEMCS0) ? "MCS " : "",
+		(vht_en) ? ((rate_idx - ODM_RATEVHTSS1MCS0) % 10) : ((rate_idx >= ODM_RATEMCS0) ? (rate_idx - ODM_RATEMCS0) : ((rate_idx <= ODM_RATE54M) ? legacy_table[rate_idx] : 0)),
+			(b_sgi) ? "-S" : "  ",
+			(rate_idx >= ODM_RATEMCS0) ? "" : "M");
+}
+
+void
+phydm_c2h_ra_report_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8   cmd_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8	macid = cmd_buf[1];
+	u8	rate = cmd_buf[0];
+	u8	curr_ra_ratio = 0xff;
+	u8	curr_bw = 0xff;
+	u8	rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8	rate_order;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+
+	if (cmd_len >= 7) {
+		curr_ra_ratio = cmd_buf[5];
+		curr_bw = cmd_buf[6];
+		PHYDM_DBG(dm, DBG_RA, "RA retry ratio: [%d]:", curr_ra_ratio);
+			/**/
+	}
+	
+	if (cmd_buf[3] != 0) {
+		if (cmd_buf[3] == 0xff) {
+			PHYDM_DBG(dm, DBG_RA, "FW Level: Fix rate[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 1) {
+			PHYDM_DBG(dm, DBG_RA, "Try Success[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 2) {
+			PHYDM_DBG(dm, DBG_RA, "Try Fail & Try Again[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 3) {
+			PHYDM_DBG(dm, DBG_RA, "rate Back[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 4) {
+			PHYDM_DBG(dm, DBG_RA, "start rate by RSSI[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 5) {
+			PHYDM_DBG(dm, DBG_RA, "Try rate[%d]:", macid);
+			/**/
+		}
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "Tx rate Update[%d]:", macid);
+	phydm_print_rate(dm, rate, DBG_RA);
+	
+	if (macid >= 128) {
+		u8 gid_index = macid - 128;
+		ra_tab->mu1_rate[gid_index] = rate;
+	}
+	
+	/*ra_tab->link_tx_rate[macid] = rate;*/
+		
+	if (is_sta_active(sta)) {
+		sta->ra_info.curr_tx_rate = rate;
+		sta->ra_info.curr_tx_bw = (enum channel_width)curr_bw;
+		sta->ra_info.curr_retry_ratio= curr_ra_ratio;
+
+		/*if (sta->ra_info.curr_tx_bw <  sta->ra_info.ra_bw_mode)*/
+	}
+
+	/*trigger power training*/
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+
+	rate_order = phydm_rate_order_compute(dm, rate_idx);
+
+	if ((dm->is_one_entry_only) ||
+		((rate_order > ra_tab->highest_client_tx_order) && (ra_tab->power_tracking_flag == 1))
+		) {
+		halrf_update_pwr_track(dm, rate_idx);
+		ra_tab->power_tracking_flag = 0;
+	}
+
+#endif
+
+	/*trigger dynamic rate ID*/
+/*#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))*/	/*dino will refine here later*/
+#if 0
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E))
+		phydm_update_rate_id(dm, rate, macid);
+#endif
+
+}
+
+void
+odm_ra_post_action_on_assoc(
+	void	*dm_void
+)
+{
+#if 0
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	dm->h2c_rarpt_connect = 1;
+	phydm_rssi_monitor_check(dm);
+	dm->h2c_rarpt_connect = 0;
+#endif
+}
+
+void
+phydm_modify_RA_PCR_threshold(
+	void		*dm_void,
+	u8		RA_offset_direction,
+	u8		RA_threshold_offset
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->RA_offset_direction = RA_offset_direction;
+	ra_tab->RA_threshold_offset = RA_threshold_offset;
+	PHYDM_DBG(dm, DBG_RA_MASK, "Set RA_threshold_offset = (( %s%d ))\n", ((RA_threshold_offset == 0) ? " " : ((RA_offset_direction) ? "+" : "-")), RA_threshold_offset);
+}
+
+#if 0 /*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+void
+odm_refresh_rate_adaptive_mask_mp(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct ra_table					*ra_tab = &dm->dm_ra_table;
+	void				*adapter	 =  dm->adapter;
+	void				*target_adapter = NULL;
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA(adapter);
+	PMGNT_INFO				mgnt_info = GetDefaultMgntInfo(adapter);
+	void			*loop_adapter = GetDefaultAdapter(adapter);
+	PMGNT_INFO					p_loop_mgnt_info = &loop_adapter->MgntInfo;
+	HAL_DATA_TYPE				*loop_hal_data = GET_HAL_DATA(loop_adapter);
+	
+	u32		i;
+	struct sta_info *entry;
+	u8		ratr_state_new;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+
+	if (adapter->bDriverStopped) {
+		PHYDM_DBG(dm, DBG_RA_MASK, "driver is going to unload\n");
+		return;
+	}
+
+	if (!hal_data->bUseRAMask) {
+		PHYDM_DBG(dm, DBG_RA_MASK, "driver does not control rate adaptive mask\n");
+		return;
+	}
+
+	/* if default port is connected, update RA table for default port (infrastructure mode only) */
+	/* Need to consider other ports for P2P cases*/
+
+	while(loop_adapter){
+		p_loop_mgnt_info = &loop_adapter->MgntInfo;
+		loop_hal_data = GET_HAL_DATA(loop_adapter);
+	
+		if (p_loop_mgnt_info->mAssoc && (!ACTING_AS_AP(loop_adapter))) {
+			odm_refresh_ldpc_rts_mp(loop_adapter, dm, p_loop_mgnt_info->mMacId, p_loop_mgnt_info->IOTPeer, loop_hal_data->UndecoratedSmoothedPWDB);
+		/*PHYDM_DBG(dm, DBG_RA_MASK, "Infrasture mode\n");*/
+
+			ratr_state_new = phydm_rssi_lv_dec(dm, loop_hal_data->UndecoratedSmoothedPWDB, p_loop_mgnt_info->Ratr_State);
+
+			if ((p_loop_mgnt_info->Ratr_State != ratr_state_new) || (ra_tab->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+				ra_tab->up_ramask_cnt = 0;
+				PHYDM_PRINT_ADDR(dm, DBG_RA_MASK, ("Target AP addr :"), p_loop_mgnt_info->Bssid);
+				PHYDM_DBG(dm, DBG_RA_MASK, "Update RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n\n",
+					mgnt_info->Ratr_State, ratr_state_new, loop_hal_data->UndecoratedSmoothedPWDB);
+
+				p_loop_mgnt_info->Ratr_State = ratr_state_new;
+				adapter->HalFunc.UpdateHalRAMaskHandler(loop_adapter, p_loop_mgnt_info->mMacId, NULL);
+			} else {
+				PHYDM_DBG(dm, DBG_RA_MASK, "Stay in RA level  = (( %d ))\n\n", ratr_state_new);
+				/**/
+			}
+		}
+
+		loop_adapter = GetNextExtAdapter(loop_adapter);
+	}
+
+	/*  */
+	/* The following part configure AP/VWifi/IBSS rate adaptive mask. */
+	/*  */
+
+	if (mgnt_info->mIbss)	/* Target: AP/IBSS peer. */
+		target_adapter = GetDefaultAdapter(adapter);
+	else
+		target_adapter = GetFirstAPAdapter(adapter);
+
+	/* if extension port (softap) is started, updaet RA table for more than one clients associate */
+	if (target_adapter != NULL) {
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+			entry = AsocEntry_EnumStation(target_adapter, i);
+
+			if (is_sta_active((&GET_STA_INFO(entry)))) {
+				odm_refresh_ldpc_rts_mp(target_adapter, dm, GET_STA_INFO(entry).mac_id, entry->IOTPeer, GET_STA_INFO(entry).rssi_stat.rssi);
+
+				ratr_state_new = phydm_rssi_lv_dec(dm, GET_STA_INFO(entry).rssi_stat.rssi, GET_STA_INFO(entry).ra_info.rssi_level);
+
+				if ((GET_STA_INFO(entry).ra_info.rssi_level != ratr_state_new) || (ra_tab->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+					ra_tab->up_ramask_cnt = 0;
+					PHYDM_PRINT_ADDR(dm, DBG_RA_MASK, ("Target AP addr :"), GET_STA_INFO(entry).mac_addr);
+					PHYDM_DBG(dm, DBG_RA_MASK, "Update Tx RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n",
+						GET_STA_INFO(entry).ra_info.rssi_level, ratr_state_new,  GET_STA_INFO(entry).rssi_stat.rssi);
+
+					GET_STA_INFO(entry).ra_info.rssi_level = ratr_state_new;
+					adapter->HalFunc.UpdateHalRAMaskHandler(target_adapter, GET_STA_INFO(entry).mac_id, entry);
+				} else {
+					PHYDM_DBG(dm, DBG_RA_MASK, "Stay in RA level  = (( %d ))\n\n", ratr_state_new);
+					/**/
+				}
+
+			}
+		}
+	}
+}
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_refresh_rate_adaptive_mask_ap(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	struct rtl8192cd_priv *priv = dm->priv;
+	struct aid_obj *aidarray;
+	u32		i;
+	struct sta_info *entry;
+	struct cmn_sta_info	*sta;
+	u8		ratr_state_new;
+
+	if (priv->up_time % 2)
+		return;
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		entry = dm->odm_sta_info[i];
+		sta = dm->phydm_sta_info[i];
+
+		if (is_sta_active(sta)) {
+			#if defined(UNIVERSAL_REPEATER) || defined(MBSSID)
+			aidarray = container_of(entry, struct aid_obj, station);
+			priv = aidarray->priv;
+			#endif
+
+			if (!priv->pmib->dot11StationConfigEntry.autoRate)
+				continue;
+
+			ratr_state_new = phydm_rssi_lv_dec(dm, (u32)sta->rssi_stat.rssi, sta->ra_info.rssi_level);
+
+			if ((sta->ra_info.rssi_level != ratr_state_new) || (ra_tab->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+				ra_tab->up_ramask_cnt = 0;
+				PHYDM_PRINT_ADDR(dm, DBG_RA_MASK, "Target AP addr :", sta->mac_addr);
+				PHYDM_DBG(dm, DBG_RA_MASK, "Update Tx RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n", sta->ra_info.rssi_level, ratr_state_new, sta->rssi_stat.rssi);
+
+				sta->ra_info.rssi_level = ratr_state_new;
+				phydm_gen_ramask_h2c_AP(dm, priv, entry, sta->ra_info.rssi_level);
+			} else {
+				PHYDM_DBG(dm, DBG_RA_MASK, "Stay in RA level  = (( %d ))\n\n", ratr_state_new);
+				/**/
+			}
+		}
+	}
+}
+#endif
+
+void
+phydm_rate_adaptive_mask_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PADAPTER		adapter	= (PADAPTER)dm->adapter;
+	PMGNT_INFO		mgnt_info = &(adapter->MgntInfo);
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+
+
+	if (mgnt_info->DM_Type == dm_type_by_driver)
+		hal_data->bUseRAMask = true;
+	else
+		hal_data->bUseRAMask = false;
+
+#endif
+
+	ra_t->ldpc_thres = 35;
+	ra_t->up_ramask_cnt = 0;
+	ra_t->up_ramask_cnt_tmp = 0;
+
+}
+
+void
+phydm_refresh_rate_adaptive_mask(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+
+	if (!(dm->support_ability & ODM_BB_RA_MASK)) {
+		PHYDM_DBG(dm, DBG_RA_MASK, "Return: Not support\n");
+		return;
+	}
+
+	if (!dm->is_linked)
+		return;
+
+	ra_t->up_ramask_cnt++;
+	/*ra_t->up_ramask_cnt_tmp++;*/
+	
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	odm_refresh_rate_adaptive_mask_ap(dm);
+
+#else
+
+	phydm_ra_mask_watchdog(dm);
+
+#endif
+	
+}
+
+void
+phydm_show_sta_info(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = NULL;
+	struct ra_sta_info			*ra = NULL;
+	#ifdef CONFIG_BEAMFORMING
+	struct bf_cmn_info		*bf = NULL;
+	#endif
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i, macid_start, macid_end;
+	u8		tatal_sta_num = 0;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "All STA: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "STA[macid]: {2} {macid}\n");
+		return;
+	} else if (var1[0] == 1) {
+		macid_start = 0;
+		macid_end = ODM_ASSOCIATE_ENTRY_NUM;
+	} else if (var1[0] == 2) {
+		macid_start = var1[1];
+		macid_end = var1[1];
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Warning input value!\n");
+		return;
+	}
+		
+	for (i = macid_start; i < macid_end; i++) {
+		
+		sta = dm->phydm_sta_info[i];
+
+
+		if (!is_sta_active(sta))
+			continue;
+
+		ra = &sta->ra_info;
+		#ifdef CONFIG_BEAMFORMING
+		bf = &sta->bf_info;
+		#endif
+
+		tatal_sta_num++;
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "==[MACID: %d]============>\n", sta->mac_id);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "AID:%d\n", sta->aid);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "ADDR:%x-%x-%x-%x-%x-%x\n", 
+			       sta->mac_addr[5], sta->mac_addr[4],
+			       sta->mac_addr[3], sta->mac_addr[2],
+			       sta->mac_addr[1], sta->mac_addr[0]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "DM_ctrl:0x%x\n", sta->dm_ctrl);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BW:%d, MIMO_Type:0x%x\n", sta->bw_mode,
+			       sta->mimo_type);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "STBC_en:%d, LDPC_en=%d\n", sta->stbc_en,
+			       sta->ldpc_en);
+
+		/*[RSSI Info]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "RSSI{All, OFDM, CCK}={%d, %d, %d}\n", 
+			       sta->rssi_stat.rssi, sta->rssi_stat.rssi_ofdm,
+			       sta->rssi_stat.rssi_cck);
+
+		/*[RA Info]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Rate_ID:%d, RSSI_LV:%d, ra_bw:%d, SGI_en:%d\n",
+			       
+			       ra->rate_id, ra->rssi_level, ra->ra_bw_mode,
+			       ra->is_support_sgi);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "VHT_en:%d, Wireless_set=0x%x, sm_ps=%d\n", 
+			       ra->is_vht_enable, sta->support_wireless_set,
+			       sta->sm_ps);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Dis{RA, PT}={%d, %d}, TxRx:%d, Noisy:%d\n", 
+			       ra->disable_ra, ra->disable_pt, ra->txrx_state,
+			       ra->is_noisy);
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "TX{Rate, BW}={0x%x, %d}, RTY:%d\n", 
+			       ra->curr_tx_rate, ra->curr_tx_bw,
+			       ra->curr_retry_ratio);
+	
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "RA_Mask:0x%llx\n", ra->ramask);
+		
+		/*[TP]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "TP{TX,RX}={%d, %d}\n", 
+			       sta->tx_moving_average_tp,
+			       sta->rx_moving_average_tp);
+
+		#ifdef CONFIG_BEAMFORMING
+		/*[Beamforming]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BF CAP{HT,VHT}={0x%x, 0x%x}\n", 
+			       bf->ht_beamform_cap, bf->vht_beamform_cap);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BF {p_aid,g_id}={0x%x, 0x%x}\n\n", 
+			       bf->p_aid, bf->g_id);
+		#endif
+	}
+
+	if (tatal_sta_num == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "No Linked STA\n");
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#ifdef	PHYDM_3RD_REFORM_RA_MASK
+
+u8
+phydm_get_tx_stream_num(
+	void		*dm_void,
+	enum 	rf_type	mimo_type
+	
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	tx_num = 1;
+
+	if (mimo_type == RF_1T1R || mimo_type == RF_1T2R)
+		tx_num = 1;
+	else if (mimo_type == RF_2T2R || mimo_type == RF_2T3R  || mimo_type == RF_2T4R)
+		tx_num = 2;
+	else if (mimo_type == RF_3T3R || mimo_type == RF_3T4R)
+		tx_num = 3;
+	else if (mimo_type == RF_4T4R)
+		tx_num = 4;
+	else {
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] no mimo_type is found\n");
+	}
+	return tx_num;
+}
+
+u64
+phydm_get_bb_mod_ra_mask(
+	void		*dm_void,
+	u8		macid
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info			*ra = NULL;
+	enum channel_width		bw = (enum channel_width)0;
+	enum wireless_set			wireless_mode = (enum wireless_set)0;
+	u8		tx_stream_num = 1;
+	u8		rssi_lv = 0;
+	u64		ra_mask_bitmap = 0;
+	
+	if (is_sta_active(sta)) {
+		
+		ra = &sta->ra_info;
+		bw = ra->ra_bw_mode;
+		wireless_mode = sta->support_wireless_set;
+		tx_stream_num = phydm_get_tx_stream_num(dm, sta->mimo_type);
+		rssi_lv = ra->rssi_level;
+		ra_mask_bitmap = ra->ramask;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid sta_info\n", __func__);
+		return 0;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "macid=%d ori_RA_Mask= 0x%llx\n", sta->mac_id, ra_mask_bitmap);
+	PHYDM_DBG(dm, DBG_RA, "wireless_mode=0x%x, tx_stream_num=%d, BW=%d, MimoPs=%d, rssi_lv=%d\n",
+		wireless_mode, tx_stream_num, bw, sta->sm_ps, rssi_lv);
+	
+	if (sta->sm_ps == SM_PS_STATIC) /*mimo_ps_enable*/
+		tx_stream_num = 1;
+
+
+	/*[Modify RA Mask by Wireless Mode]*/
+
+	if (wireless_mode == WIRELESS_CCK)								/*B mode*/
+		ra_mask_bitmap &= 0x0000000f;
+	else if (wireless_mode == WIRELESS_OFDM)							/*G mode*/
+		ra_mask_bitmap &= 0x00000ff0;
+	else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM))			/*BG mode*/
+		ra_mask_bitmap &= 0x00000ff5;
+	else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {
+																	/*N_2G*/
+		if (tx_stream_num == 1) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x000ff015;
+			else
+				ra_mask_bitmap &= 0x000ff005;
+		} else if (tx_stream_num == 2) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x0ffff015;
+			else
+				ra_mask_bitmap &= 0x0ffff005;
+		} else if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0xffffff015;
+	} else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_HT)) {		/*N_5G*/
+	
+		if (tx_stream_num == 1) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x000ff030;
+			else
+				ra_mask_bitmap &= 0x000ff010;
+		} else if (tx_stream_num == 2) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x0ffff030;
+			else
+				ra_mask_bitmap &= 0x0ffff010;
+		} else if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0xffffff010;
+	} else if (wireless_mode ==  (WIRELESS_CCK |WIRELESS_OFDM | WIRELESS_VHT)) {
+																	/*AC_2G*/
+		if (tx_stream_num == 1)
+			ra_mask_bitmap &= 0x003ff015;
+		else if (tx_stream_num == 2)
+			ra_mask_bitmap &= 0xfffff015;
+		else if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0x3fffffff010;
+		
+
+		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
+			ra_mask_bitmap &= 0x1ff7fdfffff;
+		}
+	} else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_VHT)) {		/*AC_5G*/
+	
+		if (tx_stream_num == 1)
+			ra_mask_bitmap &= 0x003ff010;
+		else if (tx_stream_num == 2)
+			ra_mask_bitmap &= 0xfffff010;
+		else  if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0x3fffffff010;
+
+		if (bw == CHANNEL_WIDTH_20) /* AC 20MHz doesn't support MCS9 */
+			ra_mask_bitmap &= 0x1ff7fdfffff;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] No RA mask is found\n");
+		/**/
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "Mod by mode=0x%llx\n", ra_mask_bitmap);
+
+	
+	/*[Modify RA Mask by RSSI level]*/
+	if (wireless_mode != WIRELESS_CCK) {
+		if (rssi_lv == 0)
+			ra_mask_bitmap &= 0xffffffffffffffff;
+		else if (rssi_lv == 1)
+			ra_mask_bitmap &= 0xfffffffffffffff0;
+		else if (rssi_lv == 2)
+			ra_mask_bitmap &= 0xffffffffffffefe0;
+		else if (rssi_lv == 3)
+			ra_mask_bitmap &= 0xffffffffffffcfc0;
+		else if (rssi_lv == 4)
+			ra_mask_bitmap &= 0xffffffffffff8f80;
+		else if (rssi_lv >= 5)
+			ra_mask_bitmap &= 0xffffffffffff0f00;
+
+	}
+	PHYDM_DBG(dm, DBG_RA, "Mod by RSSI=0x%llx\n", ra_mask_bitmap);
+
+	return ra_mask_bitmap;
+}
+
+u8
+phydm_get_rate_id(
+	void			*dm_void,
+	u8			macid
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info			*ra =NULL;
+	enum channel_width		bw = (enum channel_width)0;
+	enum wireless_set			wireless_mode = (enum wireless_set)0;
+	u8	tx_stream_num = 1;
+	u8	rate_id_idx = PHYDM_BGN_20M_1SS;
+
+	if (is_sta_active(sta)) {
+		
+		ra = &sta->ra_info;
+		bw = ra->ra_bw_mode;
+		wireless_mode = sta->support_wireless_set;
+		tx_stream_num = phydm_get_tx_stream_num(dm, sta->mimo_type);
+
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s: invalid sta_info\n", __func__);
+		return 0;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "macid=%d, wireless_set=0x%x, tx_stream_num=%d, BW=0x%x\n",
+			sta->mac_id, wireless_mode, tx_stream_num, bw);
+
+	if (wireless_mode == WIRELESS_CCK)								/*B mode*/
+		rate_id_idx = PHYDM_B_20M;
+	else if (wireless_mode ==  WIRELESS_OFDM)						/*G mode*/
+		rate_id_idx = PHYDM_G;
+	else if (wireless_mode ==  (WIRELESS_CCK | WIRELESS_OFDM))			/*BG mode*/
+		rate_id_idx = PHYDM_BG;
+	else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_HT)) {		/*GN mode*/
+	
+		if (tx_stream_num == 1)
+			rate_id_idx = PHYDM_GN_N1SS;
+		else if (tx_stream_num == 2)
+			rate_id_idx = PHYDM_GN_N2SS;
+		else if (tx_stream_num == 3)
+			rate_id_idx = PHYDM_ARFR5_N_3SS;
+	} else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {	/*BGN mode*/
+	
+
+		if (bw == CHANNEL_WIDTH_40) {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_BGN_40M_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_BGN_40M_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+
+		} else {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_BGN_20M_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_BGN_20M_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+		}
+	} else if (wireless_mode == (WIRELESS_OFDM | WIRELESS_VHT)) {	/*AC mode*/
+	
+		if (tx_stream_num == 1)
+			rate_id_idx = PHYDM_ARFR1_AC_1SS;
+		else if (tx_stream_num == 2)
+			rate_id_idx = PHYDM_ARFR0_AC_2SS;
+		else if (tx_stream_num == 3)
+			rate_id_idx = PHYDM_ARFR4_AC_3SS;
+	} else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_VHT)) {	/*AC 2.4G mode*/
+	
+		if (bw >= CHANNEL_WIDTH_80) {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_ARFR1_AC_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_ARFR0_AC_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		} else {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_ARFR2_AC_2G_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_ARFR3_AC_2G_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		}
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] No rate_id is found\n");
+		rate_id_idx = 0;
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "Rate_ID=((0x%x))\n", rate_id_idx);
+
+	return rate_id_idx;
+}
+
+void
+phydm_ra_h2c(
+	void	*dm_void,
+	u8	macid,
+	u8	dis_ra,
+	u8	dis_pt,
+	u8	no_update_bw,
+	u8	init_ra_lv,
+	u64	ra_mask
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+	u8		h2c_val[H2C_MAX_LENGTH] = {0};
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA, "MACID=%d\n", sta->mac_id);
+
+	if (dm->is_disable_power_training == true)
+		dis_pt = true;
+	else if (dm->is_disable_power_training == false)
+		dis_pt = false;
+
+	h2c_val[0] = sta->mac_id;
+	h2c_val[1] = (ra->rate_id & 0x1f) | ((init_ra_lv & 0x3) << 5) | (ra->is_support_sgi << 7);
+	h2c_val[2] = (u8)((ra->ra_bw_mode) | (((sta->ldpc_en) ? 1 : 0) << 2) | 
+					((no_update_bw & 0x1) << 3) | (ra->is_vht_enable << 4) | 
+					((dis_pt & 0x1) << 6) | ((dis_ra & 0x1) << 7));
+	
+	h2c_val[3] = (u8)(ra_mask & 0xff);
+	h2c_val[4] = (u8)((ra_mask & 0xff00) >> 8);
+	h2c_val[5] = (u8)((ra_mask & 0xff0000) >> 16);
+	h2c_val[6] = (u8)((ra_mask & 0xff000000) >> 24);
+
+	PHYDM_DBG(dm, DBG_RA, "PHYDM h2c[0x40]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_RA_MASK, H2C_MAX_LENGTH, h2c_val);
+
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
+		
+		h2c_val[3] = (u8)((ra_mask >> 32) & 0x000000ff);
+		h2c_val[4] = (u8)(((ra_mask >> 32) & 0x0000ff00) >> 8);
+		h2c_val[5] = (u8)(((ra_mask >> 32) & 0x00ff0000) >> 16);
+		h2c_val[6] = (u8)(((ra_mask >> 32) & 0xff000000) >> 24);
+
+		PHYDM_DBG(dm, DBG_RA, "PHYDM h2c[0x46]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+		
+		odm_fill_h2c_cmd(dm, PHYDM_RA_MASK_ABOVE_3SS, 5, h2c_val);
+	}
+	#endif
+}
+
+void
+phydm_ra_registed(
+	void	*dm_void,
+	u8	macid,
+	u8	rssi_from_assoc
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+	u8	init_ra_lv;
+	u64	ra_mask;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA_MASK, "[Warning] %s invalid sta_info\n", __func__);
+		PHYDM_DBG(dm, DBG_RA_MASK, "MACID=%d\n", macid);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA_MASK, "MACID=%d, rssi_from_assoc=%d\n", 
+		sta->mac_id, rssi_from_assoc);
+
+	#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		ra->rate_id = phydm_get_rate_id_88e(dm, macid);
+	else
+	#endif
+	{
+		ra->rate_id = phydm_get_rate_id(dm, macid);
+	}
+	
+	/*ra->is_vht_enable = (sta->support_wireless_set | WIRELESS_VHT) ? 1 : 0;*/
+	/*ra->disable_ra = 0;*/
+	/*ra->disable_pt = 0;*/
+	ra_mask = phydm_get_bb_mod_ra_mask(dm, macid);
+
+
+	if (rssi_from_assoc > 40)
+		init_ra_lv = 3;
+	else if (rssi_from_assoc > 20)
+		init_ra_lv = 2;
+	else
+		init_ra_lv = 1;
+
+	if (ra_t->record_ra_info)
+		ra_t->record_ra_info(dm, macid, sta, ra_mask);
+
+	#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		/*Driver RA*/
+		odm_ra_update_rate_info_8188e(dm, macid, ra->rate_id, (u32)ra_mask, ra->is_support_sgi);
+	else
+	#endif
+	{
+		/*FW RA*/
+		phydm_ra_h2c(dm, macid, ra->disable_ra, ra->disable_pt, 0, init_ra_lv, ra_mask);
+	}
+
+	
+
+}
+
+void
+phydm_ra_offline(
+	void	*dm_void,
+	u8	macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA, "MACID=%d\n", sta->mac_id);
+
+	odm_memory_set(dm, &ra->rate_id, 0, sizeof(struct ra_sta_info));
+	ra->disable_ra = 1;
+	ra->disable_pt = 1;
+
+	if (ra_t->record_ra_info)
+		ra_t->record_ra_info(dm, macid, sta, 0);
+
+	if (dm->support_ic_type != ODM_RTL8188E)
+		phydm_ra_h2c(dm, macid, ra->disable_ra, ra->disable_pt, 0, 0, 0);
+}
+
+void
+phydm_ra_mask_watchdog(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = NULL;
+	struct ra_sta_info				*ra = NULL;
+	u8		macid;
+	u64		ra_mask;
+	u8		rssi_lv_new;
+
+	if (!(dm->support_ability & ODM_BB_RA_MASK))
+		return;
+	
+	if (((!dm->is_linked)) || (dm->phydm_sys_up_time % 2) == 1)
+		return;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+	
+	ra_t->up_ramask_cnt++;
+
+	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		
+		sta = dm->phydm_sta_info[macid];
+		
+		if (!is_sta_active(sta))
+			continue;
+
+		ra = &sta->ra_info;
+
+		if (ra->disable_ra)
+			continue;
+
+
+		/*to be modified*/
+		#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		if ((dm->support_ic_type == ODM_RTL8812) ||
+			((dm->support_ic_type == ODM_RTL8821) && (dm->cut_version == ODM_CUT_A))
+			) {
+			
+			if (sta->rssi_stat.rssi < ra_t->ldpc_thres) {
+				
+				#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+				set_ra_ldpc_8812(sta, true);		/*LDPC TX enable*/
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+					{
+						MgntSet_TX_LDPC(macid, true);
+					}
+				#endif
+				PHYDM_DBG(dm, DBG_RA_MASK, "RSSI=%d, ldpc_en =TRUE\n", sta->rssi_stat.rssi);
+				
+			} else if (sta->rssi_stat.rssi > (ra_t->ldpc_thres + 3)) {
+				#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+				set_ra_ldpc_8812(sta, false);	/*LDPC TX disable*/
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+					{
+						MgntSet_TX_LDPC(macid, false);
+					}
+				#endif
+				PHYDM_DBG(dm, DBG_RA_MASK, "RSSI=%d, ldpc_en =FALSE\n", sta->rssi_stat.rssi);
+			}	
+		}
+		#endif
+
+		rssi_lv_new = phydm_rssi_lv_dec(dm, (u32)sta->rssi_stat.rssi, ra->rssi_level);
+
+		if ((ra->rssi_level != rssi_lv_new) || 
+			(ra_t->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+			PHYDM_DBG(dm, DBG_RA_MASK, "RSSI LV:((%d))->((%d))\n", ra->rssi_level, rssi_lv_new);
+			
+			ra->rssi_level = rssi_lv_new;
+			ra_t->up_ramask_cnt = 0;
+			
+			ra_mask = phydm_get_bb_mod_ra_mask(dm, macid);
+
+			if (ra_t->record_ra_info)
+				ra_t->record_ra_info(dm, macid, sta, ra_mask);
+
+			#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8188E)
+				/*Driver RA*/
+				odm_ra_update_rate_info_8188e(dm, macid, ra->rate_id, (u32)ra_mask, ra->is_support_sgi);
+			else
+			#endif
+			{
+				/*FW RA*/
+				phydm_ra_h2c(dm, macid, ra->disable_ra, ra->disable_pt, 1, 0, ra_mask);
+			}
+		}
+	}
+
+}
+#endif
+
+u8
+phydm_vht_en_mapping(
+	void			*dm_void,
+	u32			wireless_mode
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			vht_en_out = 0;
+
+	if ((wireless_mode == PHYDM_WIRELESS_MODE_AC_5G) ||
+	    (wireless_mode == PHYDM_WIRELESS_MODE_AC_24G) ||
+	    (wireless_mode == PHYDM_WIRELESS_MODE_AC_ONLY)
+	   ) {
+		vht_en_out = 1;
+		/**/
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "wireless_mode= (( 0x%x )), VHT_EN= (( %d ))\n", wireless_mode, vht_en_out);
+	return vht_en_out;
+}
+
+u8
+phydm_rate_id_mapping(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			bw
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			rate_id_idx = 0;
+
+	PHYDM_DBG(dm, DBG_RA, "wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x ))\n",
+			wireless_mode, rf_type, bw);
+
+
+	switch (wireless_mode) {
+	case PHYDM_WIRELESS_MODE_N_24G:
+	{
+		if (bw == CHANNEL_WIDTH_40) {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_BGN_40M_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_BGN_40M_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+
+		} else {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_BGN_20M_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_BGN_20M_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+		}
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_N_5G:
+	{
+		if (rf_type == RF_1T1R)
+			rate_id_idx = PHYDM_GN_N1SS;
+		else if (rf_type == RF_2T2R)
+			rate_id_idx = PHYDM_GN_N2SS;
+		else
+			rate_id_idx = PHYDM_ARFR5_N_3SS;
+	}
+
+	break;
+
+	case PHYDM_WIRELESS_MODE_G:
+		rate_id_idx = PHYDM_BG;
+		break;
+
+	case PHYDM_WIRELESS_MODE_A:
+		rate_id_idx = PHYDM_G;
+		break;
+
+	case PHYDM_WIRELESS_MODE_B:
+		rate_id_idx = PHYDM_B_20M;
+		break;
+
+
+	case PHYDM_WIRELESS_MODE_AC_5G:
+	case PHYDM_WIRELESS_MODE_AC_ONLY:
+	{
+		if (rf_type == RF_1T1R)
+			rate_id_idx = PHYDM_ARFR1_AC_1SS;
+		else if (rf_type == RF_2T2R)
+			rate_id_idx = PHYDM_ARFR0_AC_2SS;
+		else
+			rate_id_idx = PHYDM_ARFR4_AC_3SS;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_AC_24G:
+	{
+		/*Becareful to set "Lowest rate" while using PHYDM_ARFR4_AC_3SS in 2.4G/5G*/
+		if (bw >= CHANNEL_WIDTH_80) {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_ARFR1_AC_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_ARFR0_AC_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		} else {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_ARFR2_AC_2G_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_ARFR3_AC_2G_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		}
+	}
+	break;
+
+	default:
+		rate_id_idx = 0;
+		break;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "RA rate ID = (( 0x%x ))\n", rate_id_idx);
+
+	return rate_id_idx;
+}
+
+void
+phydm_update_hal_ra_mask(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			bw,
+	u8			mimo_ps_enable,
+	u8			disable_cck_rate,
+	u32			*ratr_bitmap_msb_in,
+	u32			*ratr_bitmap_lsb_in,
+	u8			tx_rate_level
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			ratr_bitmap = *ratr_bitmap_lsb_in, ratr_bitmap_msb = *ratr_bitmap_msb_in;
+
+	/*PHYDM_DBG(dm, DBG_RA_MASK, "phydm_rf_type = (( %x )), rf_type = (( %x ))\n", phydm_rf_type, rf_type);*/
+	PHYDM_DBG(dm, DBG_RA_MASK, "Platfoem original RA Mask = (( 0x %x | %x ))\n", ratr_bitmap_msb, ratr_bitmap);
+
+	switch (wireless_mode) {
+	case PHYDM_WIRELESS_MODE_B:
+	{
+		ratr_bitmap &= 0x0000000f;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_G:
+	{
+		ratr_bitmap &= 0x00000ff5;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_A:
+	{
+		ratr_bitmap &= 0x00000ff0;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_N_24G:
+	case PHYDM_WIRELESS_MODE_N_5G:
+	{
+		if (mimo_ps_enable)
+			rf_type = RF_1T1R;
+
+		if (rf_type == RF_1T1R) {
+			if (bw == CHANNEL_WIDTH_40)
+				ratr_bitmap &= 0x000ff015;
+			else
+				ratr_bitmap &= 0x000ff005;
+		} else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R) {
+			if (bw == CHANNEL_WIDTH_40)
+				ratr_bitmap &= 0x0ffff015;
+			else
+				ratr_bitmap &= 0x0ffff005;
+		} else { /*3T*/
+
+			ratr_bitmap &= 0xfffff015;
+			ratr_bitmap_msb &= 0xf;
+		}
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_AC_24G:
+	{
+		if (rf_type == RF_1T1R)
+			ratr_bitmap &= 0x003ff015;
+		else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R)
+			ratr_bitmap &= 0xfffff015;
+		else {/*3T*/
+
+			ratr_bitmap &= 0xfffff010;
+			ratr_bitmap_msb &= 0x3ff;
+		}
+
+		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
+			ratr_bitmap &= 0x7fdfffff;
+			ratr_bitmap_msb &= 0x1ff;
+		}
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_AC_5G:
+	{
+		if (rf_type == RF_1T1R)
+			ratr_bitmap &= 0x003ff010;
+		else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R)
+			ratr_bitmap &= 0xfffff010;
+		else {/*3T*/
+
+			ratr_bitmap &= 0xfffff010;
+			ratr_bitmap_msb &= 0x3ff;
+		}
+
+		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
+			ratr_bitmap &= 0x7fdfffff;
+			ratr_bitmap_msb &= 0x1ff;
+		}
+	}
+	break;
+
+	default:
+		break;
+	}
+
+	if (wireless_mode != PHYDM_WIRELESS_MODE_B) {
+		if (tx_rate_level == 0)
+			ratr_bitmap &=  0xffffffff;
+		else if (tx_rate_level == 1)
+			ratr_bitmap &=  0xfffffff0;
+		else if (tx_rate_level == 2)
+			ratr_bitmap &=  0xffffefe0;
+		else if (tx_rate_level == 3)
+			ratr_bitmap &=  0xffffcfc0;
+		else if (tx_rate_level == 4)
+			ratr_bitmap &=  0xffff8f80;
+		else if (tx_rate_level >= 5)
+			ratr_bitmap &=  0xffff0f00;
+
+	}
+
+	if (disable_cck_rate)
+		ratr_bitmap &= 0xfffffff0;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x )), MimoPs_en = (( %d )), tx_rate_level= (( 0x%x ))\n",
+		wireless_mode, rf_type, bw, mimo_ps_enable, tx_rate_level);
+
+	/*PHYDM_DBG(dm, DBG_RA_MASK, "111 Phydm modified RA Mask = (( 0x %x | %x ))\n", ratr_bitmap_msb, ratr_bitmap);*/
+
+	*ratr_bitmap_lsb_in = ratr_bitmap;
+	*ratr_bitmap_msb_in = ratr_bitmap_msb;
+	PHYDM_DBG(dm, DBG_RA_MASK, "Phydm modified RA Mask = (( 0x %x | %x ))\n", *ratr_bitmap_msb_in, *ratr_bitmap_lsb_in);
+
+}
+
+u8
+phydm_rssi_lv_dec(
+	void			*dm_void,
+	u32			rssi,
+	u8			ratr_state
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	rssi_lv_table[RA_FLOOR_TABLE_SIZE] = {20, 34, 38, 42, 46, 50, 100}; /*MCS0 ~ MCS4 , VHT1SS MCS0 ~ MCS4 , G 6M~24M*/
+	u8	new_rssi_lv = 0;
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "curr RA level=(%d), Table_ori=[%d, %d, %d, %d, %d, %d]\n",
+		ratr_state, rssi_lv_table[0], rssi_lv_table[1], rssi_lv_table[2], rssi_lv_table[3], rssi_lv_table[4], rssi_lv_table[5]);
+
+	for (i = 0; i < RA_FLOOR_TABLE_SIZE; i++) {
+		if (i >= (ratr_state))
+			rssi_lv_table[i] += RA_FLOOR_UP_GAP;
+	}
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "RSSI=(%d), Table_mod=[%d, %d, %d, %d, %d, %d]\n",
+		rssi, rssi_lv_table[0], rssi_lv_table[1], rssi_lv_table[2], rssi_lv_table[3], rssi_lv_table[4], rssi_lv_table[5]);
+
+	for (i = 0; i < RA_FLOOR_TABLE_SIZE; i++) {
+		if (rssi < rssi_lv_table[i]) {
+			new_rssi_lv = i;
+			break;
+		}
+	}
+	return	new_rssi_lv;
+}
+
+u8
+phydm_rate_order_compute(
+	void	*dm_void,
+	u8	rate_idx
+)
+{
+	u8		rate_order = 0;
+
+	if (rate_idx >= ODM_RATEVHTSS4MCS0) {
+		rate_idx -= ODM_RATEVHTSS4MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEVHTSS3MCS0) {
+		rate_idx -= ODM_RATEVHTSS3MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEVHTSS2MCS0) {
+		rate_idx -= ODM_RATEVHTSS2MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEVHTSS1MCS0) {
+		rate_idx -= ODM_RATEVHTSS1MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEMCS24) {
+		rate_idx -= ODM_RATEMCS24;
+		/**/
+	} else if (rate_idx >= ODM_RATEMCS16) {
+		rate_idx -= ODM_RATEMCS16;
+		/**/
+	} else if (rate_idx >= ODM_RATEMCS8) {
+		rate_idx -= ODM_RATEMCS8;
+		/**/
+	}
+	rate_order = rate_idx;
+
+	return rate_order;
+
+}
+
+u8
+phydm_rate2ss(
+	void	*dm_void,
+	u8	rate_idx
+)
+{
+	u8		ret = 0xff;
+	u8		i,j;
+	u8		search_idx;
+	u32		ss_mapping_tab[4][3] = {{0x00000000, 0x003ff000, 0x000ff000},
+								{0x00000000, 0xffc00000, 0x0ff00000},
+								{0x000003ff, 0x0000000f, 0xf0000000},
+								{0x000ffc00, 0x00000ff0, 0x00000000}};
+	if (rate_idx < 32) {
+		search_idx = rate_idx;
+		j = 0;
+	} else if (rate_idx < 64) {
+		search_idx = rate_idx - 32;
+		j = 1;
+	} else {
+		search_idx = rate_idx -64;
+		j = 2;
+	}
+	for (i = 0; i<4; i++)
+		if (ss_mapping_tab[i][j] & BIT(search_idx))
+			ret = i;
+	return ret;
+}
+
+u8
+phydm_rate2plcp(
+	void	*dm_void,
+	u8	rate_idx
+)
+{
+	u8		rate2ss = 0;
+	u8		vht_en = 0;
+	u8		ltftime = 0;
+	u8		plcptime = 0xff;
+
+	if (rate_idx < ODM_RATE6M) {
+		plcptime = 192;
+		/* CCK PLCP = 192us (long preamble) */
+	} else if (rate_idx < ODM_RATEMCS0) {
+		plcptime = 20;
+		/* LegOFDM PLCP = 20us */
+	} else {
+		if (rate_idx < ODM_RATEVHTSS1MCS0)
+			plcptime = 32;
+		/* HT mode PLCP = 20us + 12us + 4us x Nss */
+		else
+			plcptime = 36;
+		/* VHT mode PLCP = 20us + 16us + 4us x Nss */		
+		rate2ss = phydm_rate2ss(dm_void, rate_idx);
+		if (rate2ss == 0xff)
+			return 0xff;
+		else
+			ltftime = (rate2ss + 1) * 4;
+		plcptime += ltftime;
+		/**/
+	}
+	return plcptime;
+
+}
+
+u8
+phydm_get_plcp(
+	void	*dm_void,
+	u16	macid
+)
+{
+	u8		plcp_time = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = NULL;
+	struct ra_sta_info				*ra = NULL;
+	sta = dm->phydm_sta_info[macid];
+	ra = &sta->ra_info;
+	plcp_time = phydm_rate2plcp(dm, ra->curr_tx_rate);
+	return plcp_time;
+}
+
+
+void
+phydm_ra_common_info_update(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = NULL;
+	u16		macid;
+	u8		rate_order_tmp;
+	u8		cnt = 0;
+
+	ra_tab->highest_client_tx_order = 0;
+	ra_tab->power_tracking_flag = 1;
+
+	if (!dm->number_linked_client)
+		return;
+
+	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		sta = dm->phydm_sta_info[macid];
+
+		if (is_sta_active(sta)) {
+			rate_order_tmp = phydm_rate_order_compute(dm, (sta->ra_info.curr_tx_rate & 0x7f));
+
+			if (rate_order_tmp >= (ra_tab->highest_client_tx_order)) {
+				ra_tab->highest_client_tx_order = rate_order_tmp;
+				ra_tab->highest_client_tx_rate_order = macid;
+			}
+
+			cnt++;
+
+			if (cnt == dm->number_linked_client)
+				break;
+		}
+	}
+	PHYDM_DBG(dm, DBG_RA, "MACID[%d], Highest Tx order Update for power traking: %d\n", (ra_tab->highest_client_tx_rate_order), (ra_tab->highest_client_tx_order));
+}
+
+void
+phydm_ra_info_watchdog(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	phydm_ra_common_info_update(dm);
+	#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+	phydm_ra_dynamic_retry_limit(dm);
+	#endif
+	phydm_ra_dynamic_retry_count(dm);
+	phydm_refresh_rate_adaptive_mask(dm);
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_refresh_basic_rate_mask(dm);
+	#endif
+}
+
+void
+phydm_ra_info_init(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->highest_client_tx_rate_order = 0;
+	ra_tab->highest_client_tx_order = 0;
+	ra_tab->RA_threshold_offset = 0;
+	ra_tab->RA_offset_direction = 0;
+	
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		u32	ret_value;
+
+		ret_value = odm_get_bb_reg(dm, 0x4c8, MASKBYTE2);
+		odm_set_bb_reg(dm, 0x4cc, MASKBYTE3, (ret_value - 1));
+	}
+#endif
+	
+	#ifdef CONFIG_RA_DYNAMIC_RTY_LIMIT
+	phydm_ra_dynamic_retry_limit_init(dm);
+	#endif
+
+	#ifdef CONFIG_RA_DYNAMIC_RATE_ID
+	phydm_ra_dynamic_rate_id_init(dm);
+	#endif
+
+	#ifdef CONFIG_RA_DBG_CMD
+	odm_ra_para_adjust_init(dm);
+	#endif
+
+	phydm_rate_adaptive_mask_init(dm);
+	
+}
+
+u8
+odm_find_rts_rate(
+	void			*dm_void,
+	u8			tx_rate,
+	boolean		is_erp_protect
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	rts_ini_rate = ODM_RATE6M;
+
+	if (is_erp_protect) /* use CCK rate as RTS*/
+		rts_ini_rate = ODM_RATE1M;
+	else {
+		switch (tx_rate) {
+		case ODM_RATEVHTSS3MCS9:
+		case ODM_RATEVHTSS3MCS8:
+		case ODM_RATEVHTSS3MCS7:
+		case ODM_RATEVHTSS3MCS6:
+		case ODM_RATEVHTSS3MCS5:
+		case ODM_RATEVHTSS3MCS4:
+		case ODM_RATEVHTSS3MCS3:
+		case ODM_RATEVHTSS2MCS9:
+		case ODM_RATEVHTSS2MCS8:
+		case ODM_RATEVHTSS2MCS7:
+		case ODM_RATEVHTSS2MCS6:
+		case ODM_RATEVHTSS2MCS5:
+		case ODM_RATEVHTSS2MCS4:
+		case ODM_RATEVHTSS2MCS3:
+		case ODM_RATEVHTSS1MCS9:
+		case ODM_RATEVHTSS1MCS8:
+		case ODM_RATEVHTSS1MCS7:
+		case ODM_RATEVHTSS1MCS6:
+		case ODM_RATEVHTSS1MCS5:
+		case ODM_RATEVHTSS1MCS4:
+		case ODM_RATEVHTSS1MCS3:
+		case ODM_RATEMCS15:
+		case ODM_RATEMCS14:
+		case ODM_RATEMCS13:
+		case ODM_RATEMCS12:
+		case ODM_RATEMCS11:
+		case ODM_RATEMCS7:
+		case ODM_RATEMCS6:
+		case ODM_RATEMCS5:
+		case ODM_RATEMCS4:
+		case ODM_RATEMCS3:
+		case ODM_RATE54M:
+		case ODM_RATE48M:
+		case ODM_RATE36M:
+		case ODM_RATE24M:
+			rts_ini_rate = ODM_RATE24M;
+			break;
+		case ODM_RATEVHTSS3MCS2:
+		case ODM_RATEVHTSS3MCS1:
+		case ODM_RATEVHTSS2MCS2:
+		case ODM_RATEVHTSS2MCS1:
+		case ODM_RATEVHTSS1MCS2:
+		case ODM_RATEVHTSS1MCS1:
+		case ODM_RATEMCS10:
+		case ODM_RATEMCS9:
+		case ODM_RATEMCS2:
+		case ODM_RATEMCS1:
+		case ODM_RATE18M:
+		case ODM_RATE12M:
+			rts_ini_rate = ODM_RATE12M;
+			break;
+		case ODM_RATEVHTSS3MCS0:
+		case ODM_RATEVHTSS2MCS0:
+		case ODM_RATEVHTSS1MCS0:
+		case ODM_RATEMCS8:
+		case ODM_RATEMCS0:
+		case ODM_RATE9M:
+		case ODM_RATE6M:
+			rts_ini_rate = ODM_RATE6M;
+			break;
+		case ODM_RATE11M:
+		case ODM_RATE5_5M:
+		case ODM_RATE2M:
+		case ODM_RATE1M:
+			rts_ini_rate = ODM_RATE1M;
+			break;
+		default:
+			rts_ini_rate = ODM_RATE6M;
+			break;
+		}
+	}
+
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (rts_ini_rate < ODM_RATE6M)
+			rts_ini_rate = ODM_RATE6M;
+	}
+	return rts_ini_rate;
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_refresh_basic_rate_mask(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter	 =  dm->adapter;
+	static u8		stage = 0;
+	u8			cur_stage = 0;
+	OCTET_STRING	os_rate_set;
+	PMGNT_INFO		mgnt_info = GetDefaultMgntInfo(((PADAPTER)adapter));
+	u8			rate_set[5] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M, MGN_6M};
+
+	if (dm->support_ic_type != ODM_RTL8812 && dm->support_ic_type != ODM_RTL8821)
+		return;
+
+	if (dm->is_linked == false)	/* unlink Default port information */
+		cur_stage = 0;
+	else if (dm->rssi_min < 40)	/* link RSSI  < 40% */
+		cur_stage = 1;
+	else if (dm->rssi_min > 45)	/* link RSSI > 45% */
+		cur_stage = 3;
+	else
+		cur_stage = 2;					/* link  25% <= RSSI <= 30% */
+
+	if (cur_stage != stage) {
+		if (cur_stage == 1) {
+			FillOctetString(os_rate_set, rate_set, 5);
+			FilterSupportRate(mgnt_info->mBrates, &os_rate_set, false);
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_BASIC_RATE, (u8 *)&os_rate_set);
+		} else if (cur_stage == 3 && (stage == 1 || stage == 2))
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_BASIC_RATE, (u8 *)(&mgnt_info->mBrates));
+	}
+
+	stage = cur_stage;
+}
+
+#if 0
+void
+odm_refresh_ldpc_rts_mp(
+	void			*adapter,
+	struct dm_struct			*dm,
+	u8				m_mac_id,
+	u8				iot_peer,
+	s32				undecorated_smoothed_pwdb
+)
+{
+	boolean					is_ctl_ldpc = false;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+
+	if (dm->support_ic_type != ODM_RTL8821 && dm->support_ic_type != ODM_RTL8812)
+		return;
+
+	if ((dm->support_ic_type == ODM_RTL8821) && (dm->cut_version == ODM_CUT_A))
+		is_ctl_ldpc = true;
+	else if (dm->support_ic_type == ODM_RTL8812 &&
+		 iot_peer == HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP)
+		is_ctl_ldpc = true;
+
+	if (is_ctl_ldpc) {
+		if (undecorated_smoothed_pwdb < (ra_t->ldpc_thres - 5))
+			MgntSet_TX_LDPC(m_mac_id, true);
+		else if (undecorated_smoothed_pwdb > ra_t->ldpc_thres)
+			MgntSet_TX_LDPC(m_mac_id, false);
+	}
+}
+#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+void
+phydm_gen_ramask_h2c_AP(
+	void			*dm_void,
+	struct rtl8192cd_priv *priv,
+	struct sta_info *entry,
+	u8			rssi_level
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type == ODM_RTL8812) {
+		#if (RTL8812A_SUPPORT == 1)
+		UpdateHalRAMask8812(priv, entry, rssi_level);
+		/**/
+		#endif
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+		#if (RTL8188E_SUPPORT == 1)
+		#ifdef TXREPORT
+		add_RATid(priv, entry);
+		/**/
+		#endif
+		#endif
+	} else {
+		#ifdef CONFIG_WLAN_HAL
+		GET_HAL_INTERFACE(priv)->UpdateHalRAMaskHandler(priv, entry, rssi_level);
+		#endif
+	} 
+}
+
+#endif
+
+#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+
+void
+phydm_retry_limit_table_bound(
+	void	*dm_void,
+	u8	*retry_limit,
+	u8	offset
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+
+	if (*retry_limit >  offset) {
+		*retry_limit -= offset;
+
+		if (*retry_limit < ra_tab->retrylimit_low)
+			*retry_limit = ra_tab->retrylimit_low;
+		else if (*retry_limit > ra_tab->retrylimit_high)
+			*retry_limit = ra_tab->retrylimit_high;
+	} else
+		*retry_limit = ra_tab->retrylimit_low;
+}
+
+void
+phydm_reset_retry_limit_table(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8			i;
+
+	u8 per_rate_retrylimit_table_20M[ODM_RATEMCS15 + 1] = {
+		1, 1, 2, 4,					/*CCK*/
+		2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
+		2, 4, 6, 8, 12, 18, 20, 22,		/*20M HT-1SS*/
+		2, 4, 6, 8, 12, 18, 20, 22		/*20M HT-2SS*/
+	};
+	u8 per_rate_retrylimit_table_40M[ODM_RATEMCS15 + 1] = {
+		1, 1, 2, 4,					/*CCK*/
+		2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
+		4, 8, 12, 16, 24, 32, 32, 32,		/*40M HT-1SS*/
+		4, 8, 12, 16, 24, 32, 32, 32		/*40M HT-2SS*/
+	};
+
+	memcpy(&ra_tab->per_rate_retrylimit_20M[0],
+	       &per_rate_retrylimit_table_20M[0], ODM_NUM_RATE_IDX);
+	memcpy(&ra_tab->per_rate_retrylimit_40M[0],
+	       &per_rate_retrylimit_table_40M[0], ODM_NUM_RATE_IDX);
+
+	for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
+		phydm_retry_limit_table_bound(dm,
+					      &ra_tab->per_rate_retrylimit_20M[i],
+					      0);
+		phydm_retry_limit_table_bound(dm,
+					      &ra_tab->per_rate_retrylimit_40M[i],
+					      0);
+	}
+}
+
+void
+phydm_ra_dynamic_retry_limit_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->retry_descend_num = RA_RETRY_DESCEND_NUM;
+	ra_tab->retrylimit_low = RA_RETRY_LIMIT_LOW;
+	ra_tab->retrylimit_high = RA_RETRY_LIMIT_HIGH;
+
+	phydm_reset_retry_limit_table(dm);
+
+}
+
+void
+phydm_ra_dynamic_retry_limit(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8	i, retry_offset;
+	u32	ma_rx_tp;
+
+
+	if (dm->pre_number_active_client == dm->number_active_client) {
+		PHYDM_DBG(dm, DBG_RA, " pre_number_active_client ==  number_active_client\n");
+		return;
+
+	} else {
+		if (dm->number_active_client == 1) {
+			phydm_reset_retry_limit_table(dm);
+			PHYDM_DBG(dm, DBG_RA, "one client only->reset to default value\n");
+		} else {
+			retry_offset = dm->number_active_client * ra_tab->retry_descend_num;
+
+			for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
+				phydm_retry_limit_table_bound(dm,
+							      &ra_tab->per_rate_retrylimit_20M[i],
+							      retry_offset);
+				phydm_retry_limit_table_bound(dm,
+							      &ra_tab->per_rate_retrylimit_40M[i],
+							      retry_offset);
+			}
+		}
+	}
+}
+#endif
+
+#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))
+void
+phydm_ra_dynamic_rate_id_on_assoc(
+	void	*dm_void,
+	u8	wireless_mode,
+	u8	init_rate_id
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_RA, "[ON ASSOC] rf_mode = ((0x%x)), wireless_mode = ((0x%x)), init_rate_id = ((0x%x))\n", dm->rf_type, wireless_mode, init_rate_id);
+
+	if ((dm->rf_type == RF_2T2R) || (dm->rf_type == RF_2T3R) || (dm->rf_type == RF_2T4R)) {
+		if ((dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) &&
+		    (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G))
+		   ) {
+			PHYDM_DBG(dm, DBG_RA, "[ON ASSOC] set N-2SS ARFR5 table\n");
+			odm_set_mac_reg(dm, 0x4a4, MASKDWORD, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
+			odm_set_mac_reg(dm, 0x4a8, MASKDWORD, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
+		} else if ((dm->support_ic_type & (ODM_RTL8812)) &&
+			(wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY))
+			  ) {
+			PHYDM_DBG(dm, DBG_RA, "[ON ASSOC] set AC-2SS ARFR0 table\n");
+			odm_set_mac_reg(dm, 0x444, MASKDWORD, 0x0fff);	/*AC-2SS, ARFR0, rate_id = 0x9*/
+			odm_set_mac_reg(dm, 0x448, MASKDWORD, 0xff01f000);		/*AC-2SS, ARFR0, rate_id = 0x9*/
+		}
+	}
+
+}
+
+void
+phydm_ra_dynamic_rate_id_init(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) {
+		odm_set_mac_reg(dm, 0x4a4, MASKDWORD, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
+		odm_set_mac_reg(dm, 0x4a8, MASKDWORD, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
+
+		odm_set_mac_reg(dm, 0x444, MASKDWORD, 0x0fff);		/*AC-2SS, ARFR0, rate_id = 0x9*/
+		odm_set_mac_reg(dm, 0x448, MASKDWORD, 0xff01f000);	/*AC-2SS, ARFR0, rate_id = 0x9*/
+	}
+}
+
+void
+phydm_update_rate_id(
+	void	*dm_void,
+	u8	rate,
+	u8	platform_macid
+)
+{
+#if 0
+
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8		current_tx_ss;
+	u8		rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8		wireless_mode;
+	u8		phydm_macid;
+	struct sta_info	*entry;
+	struct cmn_sta_info	*sta;
+
+
+#if	0
+	if (rate_idx >= ODM_RATEVHTSS2MCS0) {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( VHT2SS-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEVHTSS2MCS0));
+		/*dummy for SD4 check patch*/
+	} else if (rate_idx >= ODM_RATEVHTSS1MCS0) {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( VHT1SS-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEVHTSS1MCS0));
+		/*dummy for SD4 check patch*/
+	} else if (rate_idx >= ODM_RATEMCS0) {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( HT-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEMCS0));
+		/*dummy for SD4 check patch*/
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( HT-MCS%d ))\n", platform_macid, rate_idx);
+		/*dummy for SD4 check patch*/
+	}
+#endif
+
+	phydm_macid = dm->phydm_macid_table[platform_macid];
+	entry = dm->odm_sta_info[phydm_macid];
+	sta = dm->phydm_sta_info[phydm_macid];
+
+	if (is_sta_active(sta)) {
+		wireless_mode = entry->wireless_mode;
+
+		if ((dm->rf_type  == RF_2T2R) || (dm->rf_type  == RF_2T3R) || (dm->rf_type  == RF_2T4R)) {
+			if (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G)) { /*N mode*/
+				if (rate_idx >= ODM_RATEMCS8 && rate_idx <= ODM_RATEMCS15) { /*2SS mode*/
+
+					sta->ra_info.rate_id  = ARFR_5_RATE_ID;
+					PHYDM_DBG(dm, DBG_RA, "ARFR_5\n");
+				}
+			} else if (wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY)) {/*AC mode*/
+				if (rate_idx >= ODM_RATEVHTSS2MCS0 && rate_idx <= ODM_RATEVHTSS2MCS9) {/*2SS mode*/
+
+					sta->ra_info.rate_id  = ARFR_0_RATE_ID;
+					PHYDM_DBG(dm, DBG_RA, "ARFR_0\n");
+				}
+			} else
+				sta->ra_info.rate_id  = ARFR_0_RATE_ID;
+
+			PHYDM_DBG(dm, DBG_RA, "UPdate_RateID[%d]: (( 0x%x ))\n", platform_macid, sta->ra_info.rate_id);
+		}
+	}
+#endif
+}
+
+#endif
+
+#if (defined(CONFIG_RA_DBG_CMD))
+void
+odm_ra_para_adjust_send_h2c(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			h2c_parameter[6] = {0};
+
+	h2c_parameter[0] = RA_FIRST_MACID;
+
+	if (ra_tab->ra_para_feedback_req) { /*h2c_parameter[5]=1 ; ask FW for all RA parameters*/
+		PHYDM_DBG(dm, DBG_RA, "[H2C] Ask FW for RA parameter\n");
+		h2c_parameter[5] |= BIT(1); /*ask FW to report RA parameters*/
+		h2c_parameter[1] = ra_tab->para_idx; /*ra_tab->para_idx;*/
+		ra_tab->ra_para_feedback_req = 0;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[H2C] Send H2C to FW for modifying RA parameter\n");
+
+		h2c_parameter[1] =  ra_tab->para_idx;
+		h2c_parameter[2] =  ra_tab->rate_idx;
+		/* [8 bit]*/
+		if (ra_tab->para_idx == RADBG_RTY_PENALTY || ra_tab->para_idx == RADBG_RATE_UP_RTY_RATIO || ra_tab->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
+			h2c_parameter[3] = ra_tab->value;
+			h2c_parameter[4] = 0;
+		}
+		/* [16 bit]*/
+		else {
+			h2c_parameter[3] = (u8)(((ra_tab->value_16) & 0xf0) >> 4); /*byte1*/
+			h2c_parameter[4] = (u8)((ra_tab->value_16) & 0x0f);	/*byte0*/
+		}
+	}
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[1] = 0x%x\n", h2c_parameter[1]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[2] = 0x%x\n", h2c_parameter[2]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[3] = 0x%x\n", h2c_parameter[3]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[4] = 0x%x\n", h2c_parameter[4]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[5] = 0x%x\n", h2c_parameter[5]);
+
+	odm_fill_h2c_cmd(dm, ODM_H2C_RA_PARA_ADJUST, 6, h2c_parameter);
+
+}
+
+
+void
+odm_ra_para_adjust(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			rate_idx = ra_tab->rate_idx;
+	u8			value = ra_tab->value;
+	u8			pre_value = 0xff;
+
+	if (ra_tab->para_idx == RADBG_RTY_PENALTY) {
+		pre_value = ra_tab->RTY_P[rate_idx];
+		ra_tab->RTY_P[rate_idx] = value;
+		ra_tab->RTY_P_modify_note[rate_idx] = 1;
+	} else if (ra_tab->para_idx == RADBG_N_HIGH) {
+	} else if (ra_tab->para_idx == RADBG_N_LOW) {
+	} else if (ra_tab->para_idx == RADBG_RATE_UP_RTY_RATIO) {
+		pre_value = ra_tab->RATE_UP_RTY_RATIO[rate_idx];
+		ra_tab->RATE_UP_RTY_RATIO[rate_idx] = value;
+		ra_tab->RATE_UP_RTY_RATIO_modify_note[rate_idx] = 1;
+	} else if (ra_tab->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
+		pre_value = ra_tab->RATE_DOWN_RTY_RATIO[rate_idx];
+		ra_tab->RATE_DOWN_RTY_RATIO[rate_idx] = value;
+		ra_tab->RATE_DOWN_RTY_RATIO_modify_note[rate_idx] = 1;
+	}
+	PHYDM_DBG(dm, DBG_RA, "Change RA Papa[%d], rate[ %d ],   ((%d))  ->  ((%d))\n", ra_tab->para_idx, rate_idx, pre_value, value);
+	odm_ra_para_adjust_send_h2c(dm);
+}
+
+void
+phydm_ra_print_msg(
+	void		*dm_void,
+	u8		*value,
+	u8		*value_default,
+	u8		*modify_note
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u32 i;
+
+	PHYDM_DBG(dm, DBG_RA, " |rate index| |Current-value| |Default-value| |Modify?|\n");
+	for (i = 0 ; i <= (ra_tab->rate_length); i++) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+		PHYDM_DBG(dm, DBG_RA, "     [ %d ]  %20d  %25d  %20s\n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  "));
+#else
+		PHYDM_DBG(dm, DBG_RA, "     [ %d ]  %10d  %14d  %14s\n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  "));
+#endif
+	}
+
+}
+
+void
+odm_RA_debug(
+	void		*dm_void,
+	u32		*const dm_value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->is_ra_dbg_init = false;
+
+	if (dm_value[0] == 100) { /*1 Print RA Parameters*/
+		u8	default_pointer_value;
+		u8	*pvalue;
+		u8	*pvalue_default;
+		u8	*pmodify_note;
+
+		pvalue = pvalue_default = pmodify_note = &default_pointer_value;
+
+		PHYDM_DBG(dm, DBG_RA, "\n------------------------------------------------------------------------------------\n");
+
+		if (dm_value[1] == RADBG_RTY_PENALTY) { /* [1]*/
+			PHYDM_DBG(dm, DBG_RA, " [1] RTY_PENALTY\n");
+			pvalue		=	&ra_tab->RTY_P[0];
+			pvalue_default	=	&ra_tab->RTY_P_default[0];
+			pmodify_note	=	(u8 *)&ra_tab->RTY_P_modify_note[0];
+		} else if (dm_value[1] == RADBG_N_HIGH)   /* [2]*/
+			PHYDM_DBG(dm, DBG_RA, " [2] N_HIGH\n");
+
+		else if (dm_value[1] == RADBG_N_LOW)   /*[3]*/
+			PHYDM_DBG(dm, DBG_RA, " [3] N_LOW\n");
+
+		else if (dm_value[1] == RADBG_RATE_UP_RTY_RATIO) { /* [8]*/
+			PHYDM_DBG(dm, DBG_RA, " [8] RATE_UP_RTY_RATIO\n");
+			pvalue		=	&ra_tab->RATE_UP_RTY_RATIO[0];
+			pvalue_default	=	&ra_tab->RATE_UP_RTY_RATIO_default[0];
+			pmodify_note	=	(u8 *)&ra_tab->RATE_UP_RTY_RATIO_modify_note[0];
+		} else if (dm_value[1] == RADBG_RATE_DOWN_RTY_RATIO) { /* [9]*/
+			PHYDM_DBG(dm, DBG_RA, " [9] RATE_DOWN_RTY_RATIO\n");
+			pvalue		=	&ra_tab->RATE_DOWN_RTY_RATIO[0];
+			pvalue_default	=	&ra_tab->RATE_DOWN_RTY_RATIO_default[0];
+			pmodify_note	=	(u8 *)&ra_tab->RATE_DOWN_RTY_RATIO_modify_note[0];
+		}
+
+		phydm_ra_print_msg(dm, pvalue, pvalue_default, pmodify_note);
+		PHYDM_DBG(dm, DBG_RA, "\n------------------------------------------------------------------------------------\n\n");
+
+	} else if (dm_value[0] == 101) {
+		ra_tab->para_idx = (u8)dm_value[1];
+
+		ra_tab->ra_para_feedback_req = 1;
+		odm_ra_para_adjust_send_h2c(dm);
+	} else {
+		ra_tab->para_idx = (u8)dm_value[0];
+		ra_tab->rate_idx  = (u8)dm_value[1];
+		ra_tab->value = (u8)dm_value[2];
+
+		odm_ra_para_adjust(dm);
+	}
+}
+
+void
+odm_ra_para_adjust_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			i;
+	u8			ra_para_pool_u8[3] = { RADBG_RTY_PENALTY,  RADBG_RATE_UP_RTY_RATIO, RADBG_RATE_DOWN_RTY_RATIO};
+	u8			rate_size_ht_1ss = 20, rate_size_ht_2ss = 28, rate_size_ht_3ss = 36;	 /*4+8+8+8+8 =36*/
+	u8			rate_size_vht_1ss = 10, rate_size_vht_2ss = 20, rate_size_vht_3ss = 30;	 /*10 + 10 +10 =30*/
+#if 0
+	/* RTY_PENALTY		=	1,   u8 */
+	/* N_HIGH 				=	2, */
+	/* N_LOW				=	3, */
+	/* RATE_UP_TABLE		=	4, */
+	/* RATE_DOWN_TABLE	=	5, */
+	/* TRYING_NECESSARY	=	6, */
+	/* DROPING_NECESSARY =	7, */
+	/* RATE_UP_RTY_RATIO	=	8,  u8 */
+	/* RATE_DOWN_RTY_RATIO=	9,  u8 */
+	/* ALL_PARA		=	0xff */
+
+#endif
+	PHYDM_DBG(dm, DBG_RA, "odm_ra_para_adjust_init\n");
+
+/* JJ ADD 20161014 */
+	if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8195A | ODM_RTL8703B | ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8723D | ODM_RTL8710B))
+		ra_tab->rate_length = rate_size_ht_1ss;
+	else if (dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F))
+		ra_tab->rate_length = rate_size_ht_2ss;
+	else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8821C))
+		ra_tab->rate_length = rate_size_ht_1ss + rate_size_vht_1ss;
+	else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8822B))
+		ra_tab->rate_length = rate_size_ht_2ss + rate_size_vht_2ss;
+	else if (dm->support_ic_type == ODM_RTL8814A)
+		ra_tab->rate_length = rate_size_ht_3ss + rate_size_vht_3ss;
+	else
+		ra_tab->rate_length = rate_size_ht_1ss;
+
+	ra_tab->is_ra_dbg_init = true;
+	for (i = 0; i < 3; i++) {
+		ra_tab->ra_para_feedback_req = 1;
+		ra_tab->para_idx	=	ra_para_pool_u8[i];
+		odm_ra_para_adjust_send_h2c(dm);
+	}
+}
+
+#endif /*#if (defined(CONFIG_RA_DBG_CMD))*/
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rainfo.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rainfo.h
new file mode 100644
index 000000000000..8c26012b2fd9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rainfo.h
@@ -0,0 +1,453 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMRAINFO_H__
+#define    __PHYDMRAINFO_H__
+
+/*#define RAINFO_VERSION	"2.0"*/  /*2014.11.04*/
+/*#define RAINFO_VERSION	"3.0"*/  /*2015.01.13 Dino*/
+/*#define RAINFO_VERSION	"3.1"*/  /*2015.01.14 Dino*/
+/*#define RAINFO_VERSION	"3.3"*/  /*2015.07.29 YuChen*/
+/*#define RAINFO_VERSION	"3.4"*/  /*2015.12.15 Stanley*/
+/*#define RAINFO_VERSION	"4.0"*/  /*2016.03.24 Dino, Add more RA mask state and Phydm-lize partial ra mask function  */
+/*#define RAINFO_VERSION	"4.1"*/  /*2016.04.20 Dino, Add new function to adjust PCR RA threshold  */
+/*#define RAINFO_VERSION	"4.2"*/  /*2016.05.17 Dino, Add H2C debug cmd  */
+/*#define RAINFO_VERSION	"4.3"*/  /*2016.07.11 Dino, Fix RA hang in CCK 1M problem  */
+#define RAINFO_VERSION	"5.0"  /*2017.04.20 Dino, the 3rd PHYDM reform*/
+
+#define	FORCED_UPDATE_RAMASK_PERIOD	5
+
+#define	H2C_MAX_LENGTH	7
+
+#define	RA_FLOOR_UP_GAP		3
+#define	RA_FLOOR_TABLE_SIZE	7
+
+#define	ACTIVE_TP_THRESHOLD	1
+#define	RA_RETRY_DESCEND_NUM	2
+#define	RA_RETRY_LIMIT_LOW	4
+#define	RA_RETRY_LIMIT_HIGH	32
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define		RA_FIRST_MACID	1
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define	RA_FIRST_MACID	0
+	#define	WIN_DEFAULT_PORT_MACID	0
+	#define	WIN_BT_PORT_MACID	2
+#else /*if (DM_ODM_SUPPORT_TYPE == ODM_CE)*/
+	#define		RA_FIRST_MACID	0
+#endif
+
+
+enum phydm_ra_dbg_para {
+	RADBG_PCR_TH_OFFSET		=	0,
+	RADBG_RTY_PENALTY		=	1,
+	RADBG_N_HIGH				=	2,
+	RADBG_N_LOW				=	3,
+	RADBG_TRATE_UP_TABLE		=	4,
+	RADBG_TRATE_DOWN_TABLE	=	5,
+	RADBG_TRYING_NECESSARY	=	6,
+	RADBG_TDROPING_NECESSARY =	7,
+	RADBG_RATE_UP_RTY_RATIO	=	8,
+	RADBG_RATE_DOWN_RTY_RATIO =	9, /* u8 */
+
+	RADBG_DEBUG_MONITOR1 = 0xc,
+	RADBG_DEBUG_MONITOR2 = 0xd,
+	RADBG_DEBUG_MONITOR3 = 0xe,
+	RADBG_DEBUG_MONITOR4 = 0xf,
+	RADBG_DEBUG_MONITOR5 = 0x10,
+	NUM_RA_PARA
+};
+
+enum phydm_wireless_mode {
+	PHYDM_WIRELESS_MODE_UNKNOWN = 0x00,
+	PHYDM_WIRELESS_MODE_A		= 0x01,
+	PHYDM_WIRELESS_MODE_B		= 0x02,
+	PHYDM_WIRELESS_MODE_G		= 0x04,
+	PHYDM_WIRELESS_MODE_AUTO	= 0x08,
+	PHYDM_WIRELESS_MODE_N_24G	= 0x10,
+	PHYDM_WIRELESS_MODE_N_5G	= 0x20,
+	PHYDM_WIRELESS_MODE_AC_5G	= 0x40,
+	PHYDM_WIRELESS_MODE_AC_24G	= 0x80,
+	PHYDM_WIRELESS_MODE_AC_ONLY	= 0x100,
+	PHYDM_WIRELESS_MODE_MAX		= 0x800,
+	PHYDM_WIRELESS_MODE_ALL		= 0xFFFF
+};
+
+enum phydm_rateid_idx {
+	PHYDM_BGN_40M_2SS	= 0,
+	PHYDM_BGN_40M_1SS	= 1,
+	PHYDM_BGN_20M_2SS	= 2,
+	PHYDM_BGN_20M_1SS	= 3,
+	PHYDM_GN_N2SS			= 4,
+	PHYDM_GN_N1SS			= 5,
+	PHYDM_BG				= 6,
+	PHYDM_G				= 7,
+	PHYDM_B_20M			= 8,
+	PHYDM_ARFR0_AC_2SS	= 9,
+	PHYDM_ARFR1_AC_1SS	= 10,
+	PHYDM_ARFR2_AC_2G_1SS	= 11,
+	PHYDM_ARFR3_AC_2G_2SS	= 12,
+	PHYDM_ARFR4_AC_3SS	= 13,
+	PHYDM_ARFR5_N_3SS		= 14
+};
+
+#if (RATE_ADAPTIVE_SUPPORT == 1)/* 88E RA */
+struct _odm_ra_info_ {
+	u8 rate_id;
+	u32 rate_mask;
+	u32 ra_use_rate;
+	u8 rate_sgi;
+	u8 rssi_sta_ra;
+	u8 pre_rssi_sta_ra;
+	u8 sgi_enable;
+	u8 decision_rate;
+	u8 pre_rate;
+	u8 highest_rate;
+	u8 lowest_rate;
+	u32 nsc_up;
+	u32 nsc_down;
+	u16 RTY[5];
+	u32 TOTAL;
+	u16 DROP;
+	u8 active;
+	u16 rpt_time;
+	u8 ra_waiting_counter;
+	u8 ra_pending_counter;
+	u8 ra_drop_after_down;
+#if 1 /* POWER_TRAINING_ACTIVE == 1 */ /* For compile  pass only~! */
+	u8 pt_active;  /* on or off */
+	u8 pt_try_state;  /* 0 trying state, 1 for decision state */
+	u8 pt_stage;  /* 0~6 */
+	u8 pt_stop_count; /* Stop PT counter */
+	u8 pt_pre_rate;  /* if rate change do PT */
+	u8 pt_pre_rssi; /* if RSSI change 5% do PT */
+	u8 pt_mode_ss;  /* decide whitch rate should do PT */
+	u8 ra_stage;  /* StageRA, decide how many times RA will be done between PT */
+	u8 pt_smooth_factor;
+#endif
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP) &&	((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
+	u8 rate_down_counter;
+	u8 rate_up_counter;
+	u8 rate_direction;
+	u8 bounding_type;
+	u8 bounding_counter;
+	u8 bounding_learning_time;
+	u8 rate_down_start_time;
+#endif
+};
+#endif
+
+
+struct ra_table {
+	u8		firstconnect;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	boolean		PT_collision_pre;
+#endif
+
+#if (defined(CONFIG_RA_DBG_CMD))
+	boolean		is_ra_dbg_init;
+
+	u8	RTY_P[ODM_NUM_RATE_IDX];
+	u8	RTY_P_default[ODM_NUM_RATE_IDX];
+	boolean	RTY_P_modify_note[ODM_NUM_RATE_IDX];
+
+	u8	RATE_UP_RTY_RATIO[ODM_NUM_RATE_IDX];
+	u8	RATE_UP_RTY_RATIO_default[ODM_NUM_RATE_IDX];
+	boolean	RATE_UP_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
+
+	u8	RATE_DOWN_RTY_RATIO[ODM_NUM_RATE_IDX];
+	u8	RATE_DOWN_RTY_RATIO_default[ODM_NUM_RATE_IDX];
+	boolean	RATE_DOWN_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
+
+	boolean ra_para_feedback_req;
+
+	u8   para_idx;
+	u8	rate_idx;
+	u8	value;
+	u16	value_16;
+	u8	rate_length;
+#endif
+	/*u8	link_tx_rate[ODM_ASSOCIATE_ENTRY_NUM];*/
+	u8	mu1_rate[30];
+	u8	highest_client_tx_order;
+	u16	highest_client_tx_rate_order;
+	u8	power_tracking_flag;
+	u8	RA_threshold_offset;
+	u8	RA_offset_direction;
+	u8	up_ramask_cnt; /*force update_ra_mask counter*/
+	u8	up_ramask_cnt_tmp; /*Just for debug, should be removed latter*/
+
+#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+	u8	per_rate_retrylimit_20M[ODM_NUM_RATE_IDX];
+	u8	per_rate_retrylimit_40M[ODM_NUM_RATE_IDX];
+	u8	retry_descend_num;
+	u8	retrylimit_low;
+	u8	retrylimit_high;
+#endif
+	u8	ldpc_thres;			/* if RSSI > ldpc_thres => switch from LPDC to BCC */
+
+	void (*record_ra_info)(void *dm_void, u8 macid, struct cmn_sta_info *sta, u64 ra_mask);
+};
+
+void
+phydm_h2C_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+#if (defined(CONFIG_RA_DBG_CMD))
+
+void
+odm_RA_debug(
+	void		*dm_void,
+	u32		*const dm_value
+);
+
+void
+odm_ra_para_adjust_init(
+	void		*dm_void
+);
+
+#endif
+
+void
+phydm_ra_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+odm_c2h_ra_para_report_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+);
+
+void
+odm_ra_para_adjust(
+	void		*dm_void
+);
+
+void
+phydm_ra_dynamic_retry_count(
+	void	*dm_void
+);
+
+void
+phydm_ra_dynamic_retry_limit(
+	void	*dm_void
+);
+
+void
+phydm_print_rate(
+	void	*dm_void,
+	u8	rate,
+	u32	dbg_component
+);
+
+void
+phydm_c2h_ra_report_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8   cmd_len
+);
+
+u8
+phydm_rate_order_compute(
+	void	*dm_void,
+	u8	rate_idx
+);
+
+void
+phydm_ra_info_watchdog(
+	void	*dm_void
+);
+
+void
+phydm_ra_info_init(
+	void	*dm_void
+);
+
+void
+phydm_modify_RA_PCR_threshold(
+	void		*dm_void,
+	u8		RA_offset_direction,
+	u8		RA_threshold_offset
+);
+
+u8
+phydm_vht_en_mapping(
+	void			*dm_void,
+	u32			wireless_mode
+);
+
+u8
+phydm_rate_id_mapping(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			bw
+);
+
+void
+phydm_update_hal_ra_mask(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			BW,
+	u8			mimo_ps_enable,
+	u8			disable_cck_rate,
+	u32			*ratr_bitmap_msb_in,
+	u32			*ratr_bitmap_in,
+	u8			tx_rate_level
+);
+
+void
+phydm_refresh_rate_adaptive_mask(
+	void		*dm_void
+);
+
+u8
+phydm_rssi_lv_dec(
+	void			*dm_void,
+	u32			rssi,
+	u8			ratr_state
+);
+
+void
+odm_ra_post_action_on_assoc(
+	void	*dm
+);
+
+u8
+odm_find_rts_rate(
+	void		*dm_void,
+	u8			tx_rate,
+	boolean			is_erp_protect
+);
+
+void
+phydm_show_sta_info(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+u8
+phydm_get_plcp(
+	void	*dm_void,
+	u16	macid
+);
+
+#ifdef	PHYDM_3RD_REFORM_RA_MASK
+
+void
+phydm_ra_registed(
+	void	*dm_void,
+	u8	macid,
+	u8	rssi_from_assoc
+);
+
+void
+phydm_ra_offline(
+	void	*dm_void,
+	u8	macid
+);
+
+
+void
+phydm_ra_mask_watchdog(
+	void	*dm_void
+);
+
+#endif
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_refresh_basic_rate_mask(
+	void		*dm_void
+);
+
+void
+odm_update_init_rate_work_item_callback(
+	void	*context
+);
+
+void
+odm_refresh_ldpc_rts_mp(
+	void			*adapter,
+	struct dm_struct			*dm,
+	u8				m_mac_id,
+	u8				iot_peer,
+	s32				undecorated_smoothed_pwdb
+);
+
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+void
+phydm_gen_ramask_h2c_AP(
+	void			*dm_void,
+	struct rtl8192cd_priv *priv,
+	struct sta_info *entry,
+	u8			rssi_level
+);
+
+#endif/*#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))*/
+
+
+#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))
+void
+phydm_ra_dynamic_rate_id_on_assoc(
+	void	*dm_void,
+	u8	wireless_mode,
+	u8	init_rate_id
+);
+
+void
+phydm_ra_dynamic_rate_id_init(
+	void	*dm_void
+);
+
+void
+phydm_update_rate_id(
+	void	*dm_void,
+	u8	rate,
+	u8	platform_macid
+);
+
+#endif
+
+#endif /*#ifndef	__ODMRAINFO_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_reg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_reg.h
new file mode 100644
index 000000000000..e6302ebe2732
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_reg.h
@@ -0,0 +1,217 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+/* ************************************************************
+ * 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	RF_T_METER_OLD				0x24
+#define	RF_T_METER_NEW				0x42
+
+#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
+
+/* LTE_COEX */
+#define REG_LTECOEX_CTRL			0x07C0
+#define REG_LTECOEX_WRITE_DATA		0x07C4
+#define REG_LTECOEX_READ_DATA		0x07C8
+#define REG_LTECOEX_PATH_CONTROL	0x70
+
+/* 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
+#define	ODM_RF_T_METER				0x24
+#define	ODM_RF_T_METER_92D			0x42
+#define	ODM_RF_T_METER_88E			0x42
+#define	ODM_RF_T_METER_92E			0x42
+#define	ODM_RF_T_METER_8812			0x42
+#define	REG_RF_TX_GAIN_OFFSET				0x55
+
+/* 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
+ *   */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	/* TX AGC */
+	#define		REG_TX_AGC_A_CCK_11_CCK_1_JAGUAR	0xc20
+	#define		REG_TX_AGC_A_OFDM18_OFDM6_JAGUAR	0xc24
+	#define		REG_TX_AGC_A_OFDM54_OFDM24_JAGUAR	0xc28
+	#define		REG_TX_AGC_A_MCS3_MCS0_JAGUAR	0xc2c
+	#define		REG_TX_AGC_A_MCS7_MCS4_JAGUAR	0xc30
+	#define		REG_TX_AGC_A_MCS11_MCS8_JAGUAR	0xc34
+	#define		REG_TX_AGC_A_MCS15_MCS12_JAGUAR	0xc38
+	#define		REG_TX_AGC_A_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0xc3c
+	#define		REG_TX_AGC_A_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0xc40
+	#define		REG_TX_AGC_A_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0xc44
+	#define		REG_TX_AGC_A_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0xc48
+	#define		REG_TX_AGC_A_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0xc4c
+	#if defined(CONFIG_WLAN_HAL_8814AE)
+		#define		REG_TX_AGC_A_MCS19_MCS16_JAGUAR	0xcd8
+		#define		REG_TX_AGC_A_MCS23_MCS20_JAGUAR	0xcdc
+		#define		REG_TX_AGC_A_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0xce0
+		#define		REG_TX_AGC_A_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0xce4
+		#define		REG_TX_AGC_A_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0xce8
+	#endif
+	#define		REG_TX_AGC_B_CCK_11_CCK_1_JAGUAR	0xe20
+	#define		REG_TX_AGC_B_OFDM18_OFDM6_JAGUAR	0xe24
+	#define		REG_TX_AGC_B_OFDM54_OFDM24_JAGUAR	0xe28
+	#define		REG_TX_AGC_B_MCS3_MCS0_JAGUAR	0xe2c
+	#define		REG_TX_AGC_B_MCS7_MCS4_JAGUAR	0xe30
+	#define		REG_TX_AGC_B_MCS11_MCS8_JAGUAR	0xe34
+	#define		REG_TX_AGC_B_MCS15_MCS12_JAGUAR	0xe38
+	#define		REG_TX_AGC_B_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0xe3c
+	#define		REG_TX_AGC_B_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0xe40
+	#define		REG_TX_AGC_B_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0xe44
+	#define		REG_TX_AGC_B_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0xe48
+	#define		REG_TX_AGC_B_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0xe4c
+	#if defined(CONFIG_WLAN_HAL_8814AE)
+		#define		REG_TX_AGC_B_MCS19_MCS16_JAGUAR	0xed8
+		#define		REG_TX_AGC_B_MCS23_MCS20_JAGUAR	0xedc
+		#define		REG_TX_AGC_B_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0xee0
+		#define		REG_TX_AGC_B_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0xee4
+		#define		REG_TX_AGC_B_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0xee8
+		#define		REG_TX_AGC_C_CCK_11_CCK_1_JAGUAR	0x1820
+		#define		REG_TX_AGC_C_OFDM18_OFDM6_JAGUAR	0x1824
+		#define		REG_TX_AGC_C_OFDM54_OFDM24_JAGUAR	0x1828
+		#define		REG_TX_AGC_C_MCS3_MCS0_JAGUAR	0x182c
+		#define		REG_TX_AGC_C_MCS7_MCS4_JAGUAR	0x1830
+		#define		REG_TX_AGC_C_MCS11_MCS8_JAGUAR	0x1834
+		#define		REG_TX_AGC_C_MCS15_MCS12_JAGUAR	0x1838
+		#define		REG_TX_AGC_C_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0x183c
+		#define		REG_TX_AGC_C_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0x1840
+		#define		REG_TX_AGC_C_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0x1844
+		#define		REG_TX_AGC_C_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0x1848
+		#define		REG_TX_AGC_C_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0x184c
+		#define		REG_TX_AGC_C_MCS19_MCS16_JAGUAR	0x18d8
+		#define		REG_TX_AGC_C_MCS23_MCS20_JAGUAR	0x18dc
+		#define		REG_TX_AGC_C_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0x18e0
+		#define		REG_TX_AGC_C_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0x18e4
+		#define		REG_TX_AGC_C_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0x18e8
+		#define		REG_TX_AGC_D_CCK_11_CCK_1_JAGUAR	0x1a20
+		#define		REG_TX_AGC_D_OFDM18_OFDM6_JAGUAR	0x1a24
+		#define		REG_TX_AGC_D_OFDM54_OFDM24_JAGUAR	0x1a28
+		#define		REG_TX_AGC_D_MCS3_MCS0_JAGUAR	0x1a2c
+		#define		REG_TX_AGC_D_MCS7_MCS4_JAGUAR	0x1a30
+		#define		REG_TX_AGC_D_MCS11_MCS8_JAGUAR	0x1a34
+		#define		REG_TX_AGC_D_MCS15_MCS12_JAGUAR	0x1a38
+		#define		REG_TX_AGC_D_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0x1a3c
+		#define		REG_TX_AGC_D_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0x1a40
+		#define		REG_TX_AGC_D_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0x1a44
+		#define		REG_TX_AGC_D_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0x1a48
+		#define		REG_TX_AGC_D_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0x1a4c
+		#define		REG_TX_AGC_D_MCS19_MCS16_JAGUAR	0x1ad8
+		#define		REG_TX_AGC_D_MCS23_MCS20_JAGUAR	0x1adc
+		#define		REG_TX_AGC_D_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0x1ae0
+		#define		REG_TX_AGC_D_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0x1ae4
+		#define		REG_TX_AGC_D_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0x1ae8
+	#endif
+
+	#define		is_tx_agc_byte0_jaguar	0xff
+	#define		is_tx_agc_byte1_jaguar	0xff00
+	#define		is_tx_agc_byte2_jaguar	0xff0000
+	#define		is_tx_agc_byte3_jaguar	0xff000000
+#endif
+
+#define	BIT_FA_RESET					BIT(0)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regdefine11ac.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regdefine11ac.h
new file mode 100644
index 000000000000..6a213e22a69b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regdefine11ac.h
@@ -0,0 +1,103 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__ODM_REGDEFINE11AC_H__
+#define __ODM_REGDEFINE11AC_H__
+
+/* 2 RF REG LIST */
+
+
+
+/* 2 BB REG LIST
+ * PAGE 8 */
+#define	ODM_REG_CCK_RPT_FORMAT_11AC	0x804
+#define	ODM_REG_BB_RX_PATH_11AC			0x808
+#define	ODM_REG_BB_TX_PATH_11AC			0x80c
+#define	ODM_REG_BB_ATC_11AC				0x860
+#define	ODM_REG_EDCCA_POWER_CAL		0x8dc
+#define	ODM_REG_DBG_RPT_11AC			0x8fc
+/* PAGE 9 */
+#define	ODM_REG_EDCCA_DOWN_OPT			0x900
+#define	ODM_REG_ACBB_EDCCA_ENHANCE		0x944
+#define	odm_adc_trigger_jaguar2			0x95C	/*ADC sample mode*/
+#define	ODM_REG_OFDM_FA_RST_11AC		0x9A4
+#define	ODM_REG_CCX_PERIOD_11AC			0x990
+#define	ODM_REG_NHM_TH9_TH10_11AC		0x994
+#define	ODM_REG_CLM_11AC					0x994
+#define	ODM_REG_NHM_TH3_TO_TH0_11AC	0x998
+#define	ODM_REG_NHM_TH7_TO_TH4_11AC	0x99c
+#define	ODM_REG_NHM_TH8_11AC			0x9a0
+#define	ODM_REG_NHM_9E8_11AC			0x9e8
+#define	ODM_REG_CSI_CONTENT_VALUE		0x9b4
+/* PAGE A */
+#define	ODM_REG_CCK_CCA_11AC			0xA0A
+#define	ODM_REG_CCK_FA_RST_11AC			0xA2C
+#define	ODM_REG_CCK_FA_11AC				0xA5C
+/* PAGE B */
+#define	ODM_REG_RST_RPT_11AC				0xB58
+/* PAGE C */
+#define	ODM_REG_TRMUX_11AC				0xC08
+#define	ODM_REG_IGI_A_11AC				0xC50
+/* PAGE E */
+#define	ODM_REG_IGI_B_11AC				0xE50
+#define	ODM_REG_TRMUX_11AC_B			0xE08
+/* PAGE F */
+#define	ODM_REG_CCK_CRC32_CNT_11AC		0xF04
+#define	ODM_REG_CCK_CCA_CNT_11AC		0xF08
+#define	ODM_REG_VHT_CRC32_CNT_11AC		0xF0c
+#define	ODM_REG_HT_CRC32_CNT_11AC		0xF10
+#define	ODM_REG_OFDM_CRC32_CNT_11AC	0xF14
+#define	ODM_REG_OFDM_FA_11AC			0xF48
+#define	ODM_REG_OFDM_FA_TYPE1_11AC		0xFCC
+#define	ODM_REG_OFDM_FA_TYPE2_11AC		0xFD0
+#define	ODM_REG_OFDM_FA_TYPE3_11AC		0xFBC
+#define	ODM_REG_OFDM_FA_TYPE4_11AC		0xFC0
+#define	ODM_REG_OFDM_FA_TYPE5_11AC		0xFC4
+#define	ODM_REG_OFDM_FA_TYPE6_11AC		0xFC8
+#define	ODM_REG_RPT_11AC					0xfa0
+#define	ODM_REG_CLM_RESULT_11AC			0xfa4
+#define	ODM_REG_NHM_CNT_11AC			0xfa8
+#define ODM_REG_NHM_DUR_READY_11AC      0xfb4
+
+#define	ODM_REG_NHM_CNT7_TO_CNT4_11AC   0xfac
+#define	ODM_REG_NHM_CNT11_TO_CNT8_11AC  0xfb0
+/* PAGE 18 */
+#define	ODM_REG_IGI_C_11AC				0x1850
+/* PAGE 1A */
+#define	ODM_REG_IGI_D_11AC				0x1A50
+
+/* 2 MAC REG LIST */
+#define	ODM_REG_RESP_TX_11AC				0x6D8
+
+
+
+/* DIG Related */
+#define	ODM_BIT_IGI_11AC					0x0000007F
+#define	ODM_BIT_CCK_RPT_FORMAT_11AC		BIT(16)
+#define	ODM_BIT_BB_RX_PATH_11AC			0xF
+#define	ODM_BIT_BB_TX_PATH_11AC			0xF
+#define	ODM_BIT_BB_ATC_11AC				BIT(14)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regdefine11n.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regdefine11n.h
new file mode 100644
index 000000000000..1d8326dbf88e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regdefine11n.h
@@ -0,0 +1,219 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#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_CCK_RPT_FORMAT_11N_B	0x82C
+#define	ODM_REG_RX_DEFAULT_A_11N		0x858
+#define	ODM_REG_RX_DEFAULT_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
+#define	ODM_REG_CCX_PERIOD_11N			0x894
+#define	ODM_REG_NHM_TH9_TH10_11N		0x890
+#define	ODM_REG_CLM_11N					0x890
+#define	ODM_REG_NHM_TH3_TO_TH0_11N		0x898
+#define	ODM_REG_NHM_TH7_TO_TH4_11N		0x89c
+#define ODM_REG_NHM_TH8_11N				0xe28
+#define	ODM_REG_CLM_READY_11N			0x8b4
+#define	ODM_REG_CLM_RESULT_11N			0x8d0
+#define	ODM_REG_NHM_CNT_11N				0x8d8
+
+/* For struct acs_info, Jeffery, 2014-12-26 */
+#define	ODM_REG_NHM_CNT7_TO_CNT4_11N		0x8dc
+#define	ODM_REG_NHM_CNT9_TO_CNT8_11N		0x8d0
+#define	ODM_REG_NHM_CNT10_TO_CNT11_11N	0x8d4
+
+/* PAGE 9 */
+#define	ODM_REG_BB_CTRL_PAGE9_11N		0x900
+#define	ODM_REG_DBG_RPT_11N				0x908
+#define	ODM_REG_BB_TX_PATH_11N			0x90c
+#define	ODM_REG_ANT_MAPPING1_11N		0x914
+#define	ODM_REG_ANT_MAPPING2_11N		0x918
+#define	ODM_REG_EDCCA_DOWN_OPT_11N	0x948
+#define	ODM_REG_RX_DFIR_MOD_97F			0x948
+#define	ODM_REG_SOML_97F					0x998
+
+/* PAGE A */
+#define	ODM_REG_CCK_ANTDIV_PARA1_11N	0xA00
+#define	ODM_REG_CCK_ANT_SEL_11N			0xA04
+#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
+#define	ODM_REG_RXCK_RFMOD				0xBB0
+#define	ODM_REG_EDCCA_DCNF_97F			0xBC0
+
+/* PAGE C */
+#define	ODM_REG_OFDM_FA_HOLDC_11N		0xC00
+#define	ODM_REG_BB_RX_PATH_11N			0xC04
+#define	ODM_REG_TRMUX_11N				0xC08
+#define	ODM_REG_OFDM_FA_RSTC_11N		0xC0C
+#define	ODM_REG_DOWNSAM_FACTOR_11N	0xC10
+#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_L1SBD_PD_CH_11N			0XC6C
+#define	ODM_REG_BB_PWR_SAV2_11N		0xC70
+#define	ODM_REG_BB_AGC_SET_2_11N		0xc74
+#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_SMALL_BANDWIDTH_11N	0xCE4
+#define	ODM_REG_OFDM_FA_TYPE1_11N		0xCF0
+/* PAGE D */
+#define	ODM_REG_OFDM_FA_RSTD_11N		0xD00
+#define	ODM_REG_BB_RX_ANT_11N			0xD04
+#define	ODM_REG_BB_ATC_11N				0xD2C
+#define	ODM_REG_OFDM_FA_TYPE2_11N		0xDA0
+#define	ODM_REG_OFDM_FA_TYPE3_11N		0xDA4
+#define	ODM_REG_OFDM_FA_TYPE4_11N		0xDA8
+#define	ODM_REG_RPT_11N					0xDF4
+/* 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_EDCCA_DCNF_11N			0xE24
+#define	ODM_REG_TAP_UPD_97F				0xE24
+#define	ODM_REG_FPGA0_IQK_11N			0xE28
+#define	ODM_REG_PAGE_B1_97F				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
+/* PAGE F */
+#define	ODM_REG_PAGE_F_RST_11N			0xF14
+#define	ODM_REG_IGI_C_11N					0xF84
+#define	ODM_REG_IGI_D_11N				0xF88
+#define	ODM_REG_CCK_CRC32_ERROR_CNT_11N	0xF84
+#define	ODM_REG_CCK_CRC32_OK_CNT_11N		0xF88
+#define	ODM_REG_HT_CRC32_CNT_11N		0xF90
+#define	ODM_REG_OFDM_CRC32_CNT_11N		0xF94
+#define	ODM_REG_HT_CRC32_CNT_11N_AGG	0xFB8
+
+/* 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
+#define	ODM_BIT_CCK_RPT_FORMAT_11N		BIT(9)
+#define	ODM_BIT_BB_RX_PATH_11N			0xF
+#define	ODM_BIT_BB_TX_PATH_11N			0xF
+#define	ODM_BIT_BB_ATC_11N				BIT(11)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regtable.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regtable.h
new file mode 100644
index 000000000000..70be07136614
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_regtable.h
@@ -0,0 +1,563 @@
+#define R_0x0 0x0
+#define R_0x00 0x00
+#define R_0x0140 0x0140
+#define R_0x040 0x040
+#define R_0x10 0x10
+#define R_0x1080 0x1080
+#define R_0x14c0 0x14c0
+#define R_0x14c4 0x14c4
+#define R_0x14c8 0x14c8
+#define R_0x14cc 0x14cc
+#define R_0x1518 0x1518
+#define R_0x1684 0x1684
+#define R_0x1688 0x1688
+#define R_0x168c 0x168c
+#define R_0x1700 0x1700
+#define R_0x1704 0x1704
+#define R_0x1800 0x1800
+#define R_0x183c 0x183c
+#define R_0x1840 0x1840
+#define R_0x1844 0x1844
+#define R_0x1848 0x1848
+#define R_0x188c 0x188c
+#define R_0x1894 0x1894
+#define R_0x18ac 0x18ac
+#define R_0x1900 0x1900
+#define R_0x1904 0x1904
+#define R_0x1908 0x1908
+#define R_0x1918 0x1918
+#define R_0x191c 0x191c
+#define R_0x1928 0x1928
+#define R_0x1950 0x1950
+#define R_0x1954 0x1954
+#define R_0x195c 0x195c
+#define R_0x1984 0x1984
+#define R_0x1988 0x1988
+#define R_0x198c 0x198c
+#define R_0x1990 0x1990
+#define R_0x1991 0x1991
+#define R_0x1998 0x1998
+#define R_0x19a8 0x19a8
+#define R_0x19d4 0x19d4
+#define R_0x19d8 0x19d8
+#define R_0x19e0 0x19e0
+#define R_0x19f0 0x19f0
+#define R_0x19f8 0x19f8
+#define R_0x1a00 0x1a00
+#define R_0x1a04 0x1a04
+#define R_0x1a24 0x1a24
+#define R_0x1a28 0x1a28
+#define R_0x1a2c 0x1a2c
+#define R_0x1a5c 0x1a5c
+#define R_0x1a84 0x1a84
+#define R_0x1a8c 0x1a8c
+#define R_0x1a94 0x1a94
+#define R_0x1aac 0x1aac
+#define R_0x1abc 0x1abc
+#define R_0x1ac0 0x1ac0
+#define R_0x1b00 0x1b00
+#define R_0x1b08 0x1b08
+#define R_0x1b0c 0x1b0c
+#define R_0x1b2c 0x1b2c
+#define R_0x1b38 0x1b38
+#define R_0x1b3c 0x1b3c
+#define R_0x1b8c 0x1b8c
+#define R_0x1b98 0x1b98
+#define R_0x1bc8 0x1bc8
+#define R_0x1bcc 0x1bcc
+#define R_0x1bd0 0x1bd0
+#define R_0x1bd4 0x1bd4
+#define R_0x1bd8 0x1bd8
+#define R_0x1bf0 0x1bf0
+#define R_0x1bfc 0x1bfc
+#define R_0x1c28 0x1c28
+#define R_0x1c38 0x1c38
+#define R_0x1c3c 0x1c3c
+#define R_0x1c68 0x1c68
+#define R_0x1c74 0x1c74
+#define R_0x1c78 0x1c78
+#define R_0x1c7c 0x1c7c
+#define R_0x1c90 0x1c90
+#define R_0x1c94 0x1c94
+#define R_0x1c98 0x1c98
+#define R_0x1c9c 0x1c9c
+#define R_0x1ca0 0x1ca0
+#define R_0x1cb8 0x1cb8
+#define R_0x1cf8 0x1cf8
+#define R_0x1d70 0x1d70
+#define R_0x1e2c 0x1e2c
+#define R_0x1e5c 0x1e5c
+#define R_0x1eb4 0x1eb4
+#define R_0x2c04 0x2c04
+#define R_0x2c08 0x2c08
+#define R_0x2c10 0x2c10
+#define R_0x2c14 0x2c14
+#define R_0x2d00 0x2d00
+#define R_0x2d04 0x2d04
+#define R_0x2d08 0x2d08
+#define R_0x2d10 0x2d10
+#define R_0x2d20 0x2d20
+#define R_0x2de8 0x2de8
+#define R_0x300 0x300
+#define R_0x38 0x38
+#define R_0x40 0x40
+#define R_0x4000 0x4000
+#define R_0x4008 0x4008
+#define R_0x4018 0x4018
+#define R_0x401c 0x401c
+#define R_0x4028 0x4028
+#define R_0x4100 0x4100
+#define R_0x413c 0x413c
+#define R_0x4140 0x4140
+#define R_0x4144 0x4144
+#define R_0x4148 0x4148
+#define R_0x430 0x430
+#define R_0x434 0x434
+#define R_0x44 0x44
+#define R_0x444 0x444
+#define R_0x448 0x448
+#define R_0x450 0x450
+#define R_0x454 0x454
+#define R_0x49c 0x49c
+#define R_0x4a0 0x4a0
+#define R_0x4a4 0x4a4
+#define R_0x4a8 0x4a8
+#define R_0x4c 0x4c
+#define R_0x4c8 0x4c8
+#define R_0x4cc 0x4cc
+#define R_0x5000 0x5000
+#define R_0x5008 0x5008
+#define R_0x5018 0x5018
+#define R_0x501c 0x501c
+#define R_0x5028 0x5028
+#define R_0x5100 0x5100
+#define R_0x5108 0x5108
+#define R_0x5118 0x5118
+#define R_0x511c 0x511c
+#define R_0x5128 0x5128
+#define R_0x520 0x520
+#define R_0x5200 0x5200
+#define R_0x522 0x522
+#define R_0x523c 0x523c
+#define R_0x5240 0x5240
+#define R_0x5244 0x5244
+#define R_0x5248 0x5248
+#define R_0x5300 0x5300
+#define R_0x533c 0x533c
+#define R_0x5340 0x5340
+#define R_0x5344 0x5344
+#define R_0x5348 0x5348
+#define R_0x550 0x550
+#define R_0x551 0x551
+#define R_0x568 0x568
+#define R_0x588 0x588
+#define R_0x604 0x604
+#define R_0x608 0x608
+#define R_0x60f 0x60f
+#define R_0x64 0x64
+#define R_0x66 0x66
+#define R_0x660 0x660
+#define R_0x668 0x668
+#define R_0x688 0x688
+#define R_0x6a0 0x6a0
+#define R_0x6d8 0x6d8
+#define R_0x6dc 0x6dc
+#define R_0x70 0x70
+#define R_0x74 0x74
+#define R_0x764 0x764
+#define R_0x7b0 0x7b0
+#define R_0x7b4 0x7b4
+#define R_0x7c0 0x7c0
+#define R_0x7c4 0x7c4
+#define R_0x7c8 0x7c8
+#define R_0x7cc 0x7cc
+#define R_0x7f0 0x7f0
+#define R_0x7f4 0x7f4
+#define R_0x7f8 0x7f8
+#define R_0x7fc 0x7fc
+#define R_0x800 0x800
+#define R_0x804 0x804
+#define R_0x808 0x808
+#define R_0x80c 0x80c
+#define R_0x810 0x810
+#define R_0x814 0x814
+#define R_0x818 0x818
+#define R_0x820 0x820
+#define R_0x824 0x824
+#define R_0x828 0x828
+#define R_0x82c 0x82c
+#define R_0x830 0x830
+#define R_0x834 0x834
+#define R_0x838 0x838
+#define R_0x83c 0x83c
+#define R_0x840 0x840
+#define R_0x848 0x848
+#define R_0x850 0x850
+#define R_0x854 0x854
+#define R_0x858 0x858
+#define R_0x860 0x860
+#define R_0x864 0x864
+#define R_0x86c 0x86c
+#define R_0x870 0x870
+#define R_0x874 0x874
+#define R_0x878 0x878
+#define R_0x87c 0x87c
+#define R_0x880 0x880
+#define R_0x884 0x884
+#define R_0x888 0x888
+#define R_0x88c 0x88c
+#define R_0x890 0x890
+#define R_0x894 0x894
+#define R_0x898 0x898
+#define R_0x89c 0x89c
+#define R_0x8a0 0x8a0
+#define R_0x8a4 0x8a4
+#define R_0x8ac 0x8ac
+#define R_0x8b4 0x8b4
+#define R_0x8c4 0x8c4
+#define R_0x8c8 0x8c8
+#define R_0x8cc 0x8cc
+#define R_0x8d0 0x8d0
+#define R_0x8d4 0x8d4
+#define R_0x8d8 0x8d8
+#define R_0x8dc 0x8dc
+#define R_0x8f0 0x8f0
+#define R_0x8f8 0x8f8
+#define R_0x8fc 0x8fc
+#define R_0x900 0x900
+#define R_0x908 0x908
+#define R_0x90c 0x90c
+#define R_0x910 0x910
+#define R_0x914 0x914
+#define R_0x918 0x918
+#define R_0x91c 0x91c
+#define R_0x920 0x920
+#define R_0x924 0x924
+#define R_0x92c 0x92c
+#define R_0x930 0x930
+#define R_0x934 0x934
+#define R_0x938 0x938
+#define R_0x93c 0x93c
+#define R_0x940 0x940
+#define R_0x944 0x944
+#define R_0x948 0x948
+#define R_0x94c 0x94c
+#define R_0x950 0x950
+#define R_0x958 0x958
+#define R_0x95c 0x95c
+#define R_0x970 0x970
+#define R_0x974 0x974
+#define R_0x978 0x978
+#define R_0x97c 0x97c
+#define R_0x98c 0x98c
+#define R_0x990 0x990
+#define R_0x994 0x994
+#define R_0x998 0x998
+#define R_0x9a0 0x9a0
+#define R_0x9a4 0x9a4
+#define R_0x9ac 0x9ac
+#define R_0x9b0 0x9b0
+#define R_0x9b4 0x9b4
+#define R_0x9cc 0x9cc
+#define R_0x9d0 0x9d0
+#define R_0x9e4 0x9e4
+#define R_0xa0 0xa0
+#define R_0xa00 0xa00
+#define R_0xa04 0xa04
+#define R_0xa08 0xa08
+#define R_0xa0c 0xa0c
+#define R_0xa10 0xa10
+#define R_0xa14 0xa14
+#define R_0xa20 0xa20
+#define R_0xa24 0xa24
+#define R_0xa28 0xa28
+#define R_0xa2c 0xa2c
+#define R_0xa70 0xa70
+#define R_0xa74 0xa74
+#define R_0xa78 0xa78
+#define R_0xa8 0xa8
+#define R_0xa80 0xa80
+#define R_0xa84 0xa84
+#define R_0xa9c 0xa9c
+#define R_0xaa8 0xaa8
+#define R_0xaac 0xaac
+#define R_0xab4 0xab4
+#define R_0xabc 0xabc
+#define R_0xac8 0xac8
+#define R_0xacc 0xacc
+#define R_0xad0 0xad0
+#define R_0xb0 0xb0
+#define R_0xb00 0xb00
+#define R_0xb04 0xb04
+#define R_0xb07 0xb07
+#define R_0xb08 0xb08
+#define R_0xb0c 0xb0c
+#define R_0xb10 0xb10
+#define R_0xb14 0xb14
+#define R_0xb18 0xb18
+#define R_0xb1c 0xb1c
+#define R_0xb20 0xb20
+#define R_0xb24 0xb24
+#define R_0xb28 0xb28
+#define R_0xb2b 0xb2b
+#define R_0xb2c 0xb2c
+#define R_0xb30 0xb30
+#define R_0xb34 0xb34
+#define R_0xb38 0xb38
+#define R_0xb3c 0xb3c
+#define R_0xb40 0xb40
+#define R_0xb44 0xb44
+#define R_0xb48 0xb48
+#define R_0xb54 0xb54
+#define R_0xb58 0xb58
+#define R_0xb60 0xb60
+#define R_0xb64 0xb64
+#define R_0xb68 0xb68
+#define R_0xb6a 0xb6a
+#define R_0xb6c 0xb6c
+#define R_0xb6e 0xb6e
+#define R_0xb70 0xb70
+#define R_0xb74 0xb74
+#define R_0xb77 0xb77
+#define R_0xb78 0xb78
+#define R_0xb7c 0xb7c
+#define R_0xb80 0xb80
+#define R_0xb84 0xb84
+#define R_0xb88 0xb88
+#define R_0xb8c 0xb8c
+#define R_0xb90 0xb90
+#define R_0xb94 0xb94
+#define R_0xb98 0xb98
+#define R_0xb9b 0xb9b
+#define R_0xb9c 0xb9c
+#define R_0xba0 0xba0
+#define R_0xba4 0xba4
+#define R_0xba8 0xba8
+#define R_0xbac 0xbac
+#define R_0xbad 0xbad
+#define R_0xbc0 0xbc0
+#define R_0xbc4 0xbc4
+#define R_0xbc8 0xbc8
+#define R_0xbcc 0xbcc
+#define R_0xbd8 0xbd8
+#define R_0xbdc 0xbdc
+#define R_0xbe0 0xbe0
+#define R_0xbe4 0xbe4
+#define R_0xbe8 0xbe8
+#define R_0xbec 0xbec
+#define R_0xbf0 0xbf0
+#define R_0xbf4 0xbf4
+#define R_0xbf8 0xbf8
+#define R_0xc00 0xc00
+#define R_0xc04 0xc04
+#define R_0xc08 0xc08
+#define R_0xc0c 0xc0c
+#define R_0xc10 0xc10
+#define R_0xc14 0xc14
+#define R_0xc1c 0xc1c
+#define R_0xc20 0xc20
+#define R_0xc24 0xc24
+#define R_0xc30 0xc30
+#define R_0xc38 0xc38
+#define R_0xc3c 0xc3c
+#define R_0xc40 0xc40
+#define R_0xc44 0xc44
+#define R_0xc4c 0xc4c
+#define R_0xc50 0xc50
+#define R_0xc54 0xc54
+#define R_0xc58 0xc58
+#define R_0xc5c 0xc5c
+#define R_0xc6c 0xc6c
+#define R_0xc70 0xc70
+#define R_0xc74 0xc74
+#define R_0xc78 0xc78
+#define R_0xc7c 0xc7c
+#define R_0xc80 0xc80
+#define R_0xc84 0xc84
+#define R_0xc88 0xc88
+#define R_0xc8c 0xc8c
+#define R_0xc90 0xc90
+#define R_0xc94 0xc94
+#define R_0xc9c 0xc9c
+#define R_0xca0 0xca0
+#define R_0xca4 0xca4
+#define R_0xca8 0xca8
+#define R_0xcac 0xcac
+#define R_0xcb0 0xcb0
+#define R_0xcb4 0xcb4
+#define R_0xcb8 0xcb8
+#define R_0xcbc 0xcbc
+#define R_0xcbd 0xcbd
+#define R_0xcbe 0xcbe
+#define R_0xcc4 0xcc4
+#define R_0xcc8 0xcc8
+#define R_0xccc 0xccc
+#define R_0xcd0 0xcd0
+#define R_0xcd4 0xcd4
+#define R_0xcd8 0xcd8
+#define R_0xce0 0xce0
+#define R_0xce4 0xce4
+#define R_0xce8 0xce8
+#define R_0xd00 0xd00
+#define R_0xd04 0xd04
+#define R_0xd0c 0xd0c
+#define R_0xd10 0xd10
+#define R_0xd14 0xd14
+#define R_0xd2c 0xd2c
+#define R_0xd30 0xd30
+#define R_0xd40 0xd40
+#define R_0xd44 0xd44
+#define R_0xd48 0xd48
+#define R_0xd4c 0xd4c
+#define R_0xd50 0xd50
+#define R_0xd54 0xd54
+#define R_0xd5c 0xd5c
+#define R_0xd6c 0xd6c
+#define R_0xd7c 0xd7c
+#define R_0xd80 0xd80
+#define R_0xd84 0xd84
+#define R_0xd8c 0xd8c
+#define R_0xd90 0xd90
+#define R_0xd94 0xd94
+#define R_0xdac 0xdac
+#define R_0xdb0 0xdb0
+#define R_0xdb4 0xdb4
+#define R_0xdb8 0xdb8
+#define R_0xdbc 0xdbc
+#define R_0xdcc 0xdcc
+#define R_0xdd0 0xdd0
+#define R_0xdd4 0xdd4
+#define R_0xdd8 0xdd8
+#define R_0xde0 0xde0
+#define R_0xdec 0xdec
+#define R_0xdf4 0xdf4
+#define R_0xe00 0xe00
+#define R_0xe04 0xe04
+#define R_0xe08 0xe08
+#define R_0xe10 0xe10
+#define R_0xe14 0xe14
+#define R_0xe1c 0xe1c
+#define R_0xe20 0xe20
+#define R_0xe24 0xe24
+#define R_0xe28 0xe28
+#define R_0xe30 0xe30
+#define R_0xe34 0xe34
+#define R_0xe38 0xe38
+#define R_0xe3c 0xe3c
+#define R_0xe40 0xe40
+#define R_0xe44 0xe44
+#define R_0xe48 0xe48
+#define R_0xe4c 0xe4c
+#define R_0xe50 0xe50
+#define R_0xe54 0xe54
+#define R_0xe5c 0xe5c
+#define R_0xe64 0xe64
+#define R_0xe70 0xe70
+#define R_0xe80 0xe80
+#define R_0xe84 0xe84
+#define R_0xe8c 0xe8c
+#define R_0xe90 0xe90
+#define R_0xe94 0xe94
+#define R_0xe98 0xe98
+#define R_0xe9c 0xe9c
+#define R_0xea0 0xea0
+#define R_0xea4 0xea4
+#define R_0xea8 0xea8
+#define R_0xeac 0xeac
+#define R_0xeb0 0xeb0
+#define R_0xeb4 0xeb4
+#define R_0xeb8 0xeb8
+#define R_0xebc 0xebc
+#define R_0xec0 0xec0
+#define R_0xec4 0xec4
+#define R_0xec8 0xec8
+#define R_0xecc 0xecc
+#define R_0xed4 0xed4
+#define R_0xee8 0xee8
+#define R_0xf0 0xf0
+#define R_0xf08 0xf08
+#define R_0xf0c 0xf0c
+#define R_0xf10 0xf10
+#define R_0xf14 0xf14
+#define R_0xf20 0xf20
+#define R_0xf2c 0xf2c
+#define R_0xf30 0xf30
+#define R_0xf34 0xf34
+#define R_0xf4 0xf4
+#define R_0xf44 0xf44
+#define R_0xf48 0xf48
+#define R_0xf4c 0xf4c
+#define R_0xf80 0xf80
+#define R_0xf84 0xf84
+#define R_0xf88 0xf88
+#define R_0xf8c 0xf8c
+#define R_0xf90 0xf90
+#define R_0xf94 0xf94
+#define R_0xf98 0xf98
+#define R_0xfa0 0xfa0
+#define R_0xfa4 0xfa4
+#define R_0xfbc 0xfbc
+#define R_0xfc0 0xfc0
+#define R_0xfc4 0xfc4
+#define R_0xfc8 0xfc8
+#define R_0xfcc 0xfcc
+#define R_0xfd0 0xfd0
+#define R_0xff0 0xff0
+#define RF_0x0 0x0
+#define RF_0x00 0x00
+#define RF_0x08 0x08
+#define RF_0x0c 0x0c
+#define RF_0x0d 0x0d
+#define RF_0x1 0x1
+#define RF_0x18 0x18
+#define RF_0x1bf0 0x1bf0
+#define RF_0x2 0x2
+#define RF_0x3 0x3
+#define RF_0x30 0x30
+#define RF_0x31 0x31
+#define RF_0x32 0x32
+#define RF_0x33 0x33
+#define RF_0x35 0x35
+#define RF_0x3e 0x3e
+#define RF_0x3f 0x3f
+#define RF_0x4 0x4
+#define RF_0x42 0x42
+#define RF_0x43 0x43
+#define RF_0x51 0x51
+#define RF_0x52 0x52
+#define RF_0x54 0x54
+#define RF_0x55 0x55
+#define RF_0x56 0x56
+#define RF_0x58 0x58
+#define RF_0x5c 0x5c
+#define RF_0x61 0x61
+#define RF_0x64 0x64
+#define RF_0x65 0x65
+#define RF_0x66 0x66
+#define RF_0x75 0x75
+#define RF_0x76 0x76
+#define RF_0x78 0x78
+#define RF_0x7f 0x7f
+#define RF_0x8 0x8
+#define RF_0x80 0x80
+#define RF_0x81 0x81
+#define RF_0x86 0x86
+#define RF_0x8d 0x8d
+#define RF_0x8f 0x8f
+#define RF_0xae 0xae
+#define RF_0xb0 0xb0
+#define RF_0xb8 0xb8
+#define RF_0xbc 0xbc
+#define RF_0xbe 0xbe
+#define RF_0xc4 0xc4
+#define RF_0xc9 0xc9
+#define RF_0xca 0xca
+#define RF_0xcc 0xcc
+#define RF_0xd 0xd
+#define RF_0xdd 0xdd
+#define RF_0xde 0xde
+#define RF_0xdf 0xdf
+#define RF_0xed 0xed
+#define RF_0xee 0xee
+#define RF_0xef 0xef
+#define RF_0xf5 0xf5
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rssi_monitor.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rssi_monitor.c
new file mode 100644
index 000000000000..d6bcb02ab840
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rssi_monitor.c
@@ -0,0 +1,450 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+ 
+#ifdef PHYDM_SUPPORT_RSSI_MONITOR
+
+#ifdef PHYDM_3RD_REFORM_RSSI_MONOTOR
+void
+phydm_rssi_monitor_h2c(
+	void	*dm_void,
+	u8	macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+	u8		h2c_val[H2C_MAX_LENGTH] = {0};
+	u8		stbc_en, ldpc_en;
+	u8		bf_en = 0;
+	u8		is_rx, is_tx;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+	
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "MACID=%d\n", sta->mac_id);
+
+	is_rx = (ra->txrx_state == RX_STATE) ? 1 : 0;
+	is_tx = (ra->txrx_state == TX_STATE) ? 1 : 0;
+	stbc_en = (sta->stbc_en) ? 1 : 0;
+	ldpc_en = (sta->ldpc_en) ? 1 : 0;
+
+	#ifdef CONFIG_BEAMFORMING
+	if ((sta->bf_info.ht_beamform_cap & BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
+		(sta->bf_info.vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) {
+		bf_en = 1;
+	}
+	#endif
+
+	if (ra_t->RA_threshold_offset != 0) {
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "RA_th_ofst = (( %s%d ))\n",
+			((ra_t->RA_offset_direction) ? "+" : "-"), ra_t->RA_threshold_offset);
+	}
+
+	h2c_val[0] = sta->mac_id;
+	h2c_val[1] = 0;
+	h2c_val[2] = sta->rssi_stat.rssi;
+	h2c_val[3] = is_rx | (stbc_en << 1) | ((dm->noisy_decision & 0x1) << 2) |  (bf_en << 6);
+	h2c_val[4] = (ra_t->RA_threshold_offset & 0x7f) | ((ra_t->RA_offset_direction & 0x1) << 7);
+	h2c_val[5] = 0;
+	h2c_val[6] = 0;
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "PHYDM h2c[0x42]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+
+	#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		odm_ra_set_rssi_8188e(dm, (u8)(sta->mac_id & 0xFF), sta->rssi_stat.rssi & 0x7F);
+	else
+	#endif 
+	{
+		odm_fill_h2c_cmd(dm, ODM_H2C_RSSI_REPORT, H2C_MAX_LENGTH, h2c_val);
+	}
+}
+
+void
+phydm_calculate_rssi_min_max(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta;
+	s8	rssi_max_tmp = 0, rssi_min_tmp = 100;
+	u8	i;
+	u8	sta_cnt = 0;
+
+	if (!dm->is_linked)
+		return;
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
+			sta_cnt++;
+
+			if (sta->rssi_stat.rssi < rssi_min_tmp)
+				rssi_min_tmp = sta->rssi_stat.rssi;
+
+			if (sta->rssi_stat.rssi > rssi_max_tmp)
+				rssi_max_tmp = sta->rssi_stat.rssi;
+
+			/*[Send RSSI to FW]*/
+			if (sta->ra_info.disable_ra == false)
+				phydm_rssi_monitor_h2c(dm, i);
+
+			if (sta_cnt == dm->number_linked_client)
+				break;
+		}
+	}
+
+	dm->rssi_max = (u8)rssi_max_tmp;
+	dm->rssi_min = (u8)rssi_min_tmp;
+
+}
+#endif
+
+
+#if 0/*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+s32
+phydm_find_minimum_rssi(
+	struct dm_struct	*dm,
+	void			*adapter,
+	boolean					*is_link_temp
+
+)
+{
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	PMGNT_INFO		mgnt_info = &adapter->MgntInfo;
+	boolean			act_as_ap = ACTING_AS_AP(adapter);
+
+	/* 1.Determine the minimum RSSI */
+	if ((!mgnt_info->bMediaConnect) ||
+	    (act_as_ap && (hal_data->EntryMinUndecoratedSmoothedPWDB == 0))) {/* We should check AP mode and Entry info.into consideration, revised by Roger, 2013.10.18*/
+
+		hal_data->MinUndecoratedPWDBForDM = 0;
+		*is_link_temp = false;
+
+	} else
+		*is_link_temp = true;
+
+
+	if (mgnt_info->bMediaConnect) {	/* Default port*/
+
+		if (act_as_ap || mgnt_info->mIbss) {
+			hal_data->MinUndecoratedPWDBForDM = hal_data->EntryMinUndecoratedSmoothedPWDB;
+			/**/
+		} else {
+			hal_data->MinUndecoratedPWDBForDM = GET_DEFAULT_RSSI(mgnt_info);
+			/**/
+		}
+	} else { /* associated entry pwdb*/
+		hal_data->MinUndecoratedPWDBForDM = hal_data->EntryMinUndecoratedSmoothedPWDB;
+		/**/
+	}
+
+	return hal_data->MinUndecoratedPWDBForDM;
+}
+
+void
+odm_rssi_monitor_check_mp(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			h2c_parameter[H2C_0X42_LENGTH] = {0};
+	u32			i;
+	boolean			is_ext_ra_info = true;
+	u8			cmdlen = H2C_0X42_LENGTH;
+	u8			tx_bf_en = 0, stbc_en = 0;
+
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	struct sta_info		*entry = NULL;
+	s32			tmp_entry_max_pwdb = 0, tmp_entry_min_pwdb = 0xff;
+	PMGNT_INFO		mgnt_info = &adapter->MgntInfo;
+	PMGNT_INFO		p_default_mgnt_info = &adapter->MgntInfo;
+	u64			cur_tx_ok_cnt = 0, cur_rx_ok_cnt = 0;
+#if (BEAMFORMING_SUPPORT == 1)
+#ifndef BEAMFORMING_VERSION_1
+	enum beamforming_cap beamform_cap = BEAMFORMING_CAP_NONE;
+#endif
+#endif
+	void	*loop_adapter = GetDefaultAdapter(adapter);
+
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		is_ext_ra_info = false;
+		cmdlen = 3;
+	}
+
+	while (loop_adapter) {
+		if (loop_adapter != NULL) {
+			mgnt_info = &loop_adapter->MgntInfo;
+			cur_tx_ok_cnt = loop_adapter->TxStats.NumTxBytesUnicast - mgnt_info->lastTxOkCnt;
+			cur_rx_ok_cnt = loop_adapter->RxStats.NumRxBytesUnicast - mgnt_info->lastRxOkCnt;
+			mgnt_info->lastTxOkCnt = cur_tx_ok_cnt;
+			mgnt_info->lastRxOkCnt = cur_rx_ok_cnt;
+		}
+
+		for (i = 0; i < ASSOCIATE_ENTRY_NUM; i++) {
+			if (IsAPModeExist(loop_adapter)) {
+				if (GetFirstExtAdapter(loop_adapter) != NULL &&
+				    GetFirstExtAdapter(loop_adapter) == loop_adapter)
+				entry = AsocEntry_EnumStation(loop_adapter, i);
+				else if (GetFirstGOPort(loop_adapter) != NULL &&
+					 IsFirstGoAdapter(loop_adapter))
+				entry = AsocEntry_EnumStation(loop_adapter, i);
+			} else {
+				if (GetDefaultAdapter(loop_adapter) == loop_adapter)
+					entry = AsocEntry_EnumStation(loop_adapter, i);
+			}
+
+			if (entry != NULL) {
+				if (entry->bAssociated) {
+					RT_DISP_ADDR(FDM, DM_PWDB, ("entry->mac_addr ="), GET_STA_INFO(entry).mac_addr);
+					RT_DISP(FDM, DM_PWDB, ("entry->rssi = 0x%x(%d)\n",
+						GET_STA_INFO(entry).rssi_stat.rssi, GET_STA_INFO(entry).rssi_stat.rssi));
+
+					/* 2 BF_en */
+#if (BEAMFORMING_SUPPORT == 1)
+#ifndef BEAMFORMING_VERSION_1
+					beamform_cap = phydm_beamforming_get_entry_beam_cap_by_mac_id(dm, GET_STA_INFO(entry).mac_id);
+					if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
+						tx_bf_en = 1;
+#else
+					if (Beamform_GetSupportBeamformerCap(GetDefaultAdapter(adapter), entry))
+						tx_bf_en = 1;
+#endif
+#endif
+					/* 2 STBC_en */
+					if ((IS_WIRELESS_MODE_AC(adapter) && TEST_FLAG(entry->VHTInfo.STBC, STBC_VHT_ENABLE_TX)) ||
+						TEST_FLAG(entry->HTInfo.STBC, STBC_HT_ENABLE_TX))
+						stbc_en = 1;
+
+					if (GET_STA_INFO(entry).rssi_stat.rssi < tmp_entry_min_pwdb)
+						tmp_entry_min_pwdb = GET_STA_INFO(entry).rssi_stat.rssi;
+					if (GET_STA_INFO(entry).rssi_stat.rssi > tmp_entry_max_pwdb)
+						tmp_entry_max_pwdb = GET_STA_INFO(entry).rssi_stat.rssi;
+
+					h2c_parameter[4] = (ra_tab->RA_threshold_offset & 0x7f) | (ra_tab->RA_offset_direction << 7);
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "RA_threshold_offset = (( %s%d ))\n", ((ra_tab->RA_threshold_offset == 0) ? " " : ((ra_tab->RA_offset_direction) ? "+" : "-")), ra_tab->RA_threshold_offset);
+
+					if (is_ext_ra_info) {
+						if (cur_rx_ok_cnt > (cur_tx_ok_cnt * 6))
+							h2c_parameter[3] |= RAINFO_BE_RX_STATE;
+
+						if (tx_bf_en)
+							h2c_parameter[3] |= RAINFO_BF_STATE;
+						else {
+							if (stbc_en)
+								h2c_parameter[3] |= RAINFO_STBC_STATE;
+						}
+
+						if (dm->noisy_decision)
+							h2c_parameter[3] |= RAINFO_NOISY_STATE;
+						else
+							h2c_parameter[3] &= (~RAINFO_NOISY_STATE);
+
+						if (dm->h2c_rarpt_connect) {
+							h2c_parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
+							PHYDM_DBG(dm, DBG_RSSI_MNTR, "h2c_rarpt_connect = (( %d ))\n", dm->h2c_rarpt_connect);
+						}
+
+					}
+
+					h2c_parameter[2] = (u8)(GET_STA_INFO(entry).rssi_stat.rssi & 0xFF);
+					/* h2c_parameter[1] = 0x20;*/ /* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1 */
+					h2c_parameter[0] = (GET_STA_INFO(entry).mac_id);
+
+					odm_fill_h2c_cmd(dm, ODM_H2C_RSSI_REPORT, cmdlen, h2c_parameter);
+				}
+			} else
+				break;
+		}
+
+		loop_adapter = GetNextExtAdapter(loop_adapter);
+	}
+
+
+	/*Default port*/
+	if (tmp_entry_max_pwdb != 0) {	/* If associated entry is found */
+		hal_data->EntryMaxUndecoratedSmoothedPWDB = tmp_entry_max_pwdb;
+		RT_DISP(FDM, DM_PWDB, ("EntryMaxPWDB = 0x%x(%d)\n",	tmp_entry_max_pwdb, tmp_entry_max_pwdb));
+	} else
+		hal_data->EntryMaxUndecoratedSmoothedPWDB = 0;
+
+	if (tmp_entry_min_pwdb != 0xff) { /* If associated entry is found */
+		hal_data->EntryMinUndecoratedSmoothedPWDB = tmp_entry_min_pwdb;
+		RT_DISP(FDM, DM_PWDB, ("EntryMinPWDB = 0x%x(%d)\n", tmp_entry_min_pwdb, tmp_entry_min_pwdb));
+
+	} else
+		hal_data->EntryMinUndecoratedSmoothedPWDB = 0;
+
+	/* Default porti sent RSSI to FW */
+	if (hal_data->bUseRAMask) {
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "1 RA First Link, RSSI[%d] = ((%d)) , ra_rpt_linked = ((%d))\n",
+			WIN_DEFAULT_PORT_MACID, GET_DEFAULT_RSSI(mgnt_info), hal_data->ra_rpt_linked);
+		if (GET_DEFAULT_RSSI(mgnt_info) > 0) {
+			PRT_HIGH_THROUGHPUT			p_ht_info = GET_HT_INFO(p_default_mgnt_info);
+			PRT_VERY_HIGH_THROUGHPUT	p_vht_info = GET_VHT_INFO(p_default_mgnt_info);
+
+			/* BF_en*/
+#if (BEAMFORMING_SUPPORT == 1)
+#ifndef BEAMFORMING_VERSION_1
+			beamform_cap = phydm_beamforming_get_entry_beam_cap_by_mac_id(dm, p_default_mgnt_info->m_mac_id);
+
+			if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
+				tx_bf_en = 1;
+#else
+			if (Beamform_GetSupportBeamformerCap(GetDefaultAdapter(adapter), NULL))
+				tx_bf_en = 1;
+#endif
+#endif
+
+			/* STBC_en*/
+			if ((IS_WIRELESS_MODE_AC(adapter) && TEST_FLAG(p_vht_info->VhtCurStbc, STBC_VHT_ENABLE_TX)) ||
+			    TEST_FLAG(p_ht_info->HtCurStbc, STBC_HT_ENABLE_TX))
+				stbc_en = 1;
+
+			h2c_parameter[4] = (ra_tab->RA_threshold_offset & 0x7f) | (ra_tab->RA_offset_direction << 7);
+			PHYDM_DBG(dm, DBG_RSSI_MNTR, "RA_threshold_offset = (( %s%d ))\n", ((ra_tab->RA_threshold_offset == 0) ? " " : ((ra_tab->RA_offset_direction) ? "+" : "-")), ra_tab->RA_threshold_offset);
+
+			if (is_ext_ra_info) {
+				if (tx_bf_en)
+					h2c_parameter[3] |= RAINFO_BF_STATE;
+				else {
+					if (stbc_en)
+						h2c_parameter[3] |= RAINFO_STBC_STATE;
+				}
+
+				if (dm->h2c_rarpt_connect) {
+					h2c_parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "h2c_rarpt_connect = (( %d ))\n", dm->h2c_rarpt_connect);
+				}
+
+
+				if (dm->noisy_decision == 1) {
+					h2c_parameter[3] |= RAINFO_NOISY_STATE;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "[RSSIMonitorCheckMP] Send H2C to FW\n");
+				} else
+					h2c_parameter[3] &= (~RAINFO_NOISY_STATE);
+
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "[RSSIMonitorCheckMP] h2c_parameter=%x\n", h2c_parameter[3]);
+			}
+
+			h2c_parameter[2] = (u8)(GET_DEFAULT_RSSI(mgnt_info) & 0xFF);
+			/*h2c_parameter[1] = 0x20;*/	/* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1*/
+			h2c_parameter[0] = WIN_DEFAULT_PORT_MACID;		/* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1*/
+
+			odm_fill_h2c_cmd(dm, ODM_H2C_RSSI_REPORT, cmdlen, h2c_parameter);
+		}
+	
+	} else
+		PlatformEFIOWrite1Byte(adapter, 0x4fe, (u8)GET_DEFAULT_RSSI(mgnt_info));
+
+	{
+		void *loop_adapter = GetDefaultAdapter(adapter);
+		boolean		default_pointer_value, *is_link_temp = &default_pointer_value;
+		s32	global_rssi_min = 0xFF, local_rssi_min;
+		boolean		is_link = false;
+
+		while (loop_adapter) {
+			local_rssi_min = phydm_find_minimum_rssi(dm, loop_adapter, is_link_temp);
+			/* dbg_print("hal_data->is_linked=%d, local_rssi_min=%d\n", hal_data->is_linked, local_rssi_min); */
+
+			if (*is_link_temp)
+				is_link = true;
+
+			if ((local_rssi_min < global_rssi_min) && (*is_link_temp))
+				global_rssi_min = local_rssi_min;
+
+			loop_adapter = GetNextExtAdapter(loop_adapter);
+		}
+
+		hal_data->bLinked = is_link;
+
+		dm->is_linked = is_link;
+		dm->rssi_min = (u8)((is_link) ? global_rssi_min : 0);
+
+	}
+
+
+}
+
+#endif
+
+void
+phydm_rssi_monitor_check(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_RSSI_MONITOR))
+		return;
+
+	if ((dm->phydm_sys_up_time % 2) == 1) /*for AP watchdog period = 1 sec*/
+		return;
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
+
+
+	phydm_calculate_rssi_min_max(dm);
+
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "RSSI {max, min} = {%d, %d}\n",
+		dm->rssi_max, dm->rssi_min);
+
+}
+
+void
+phydm_rssi_monitor_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->firstconnect = false;
+	dm->rssi_max = 0;
+	dm->rssi_min = 0;
+
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rssi_monitor.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rssi_monitor.h
new file mode 100644
index 000000000000..15c9e0a6e7d3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_rssi_monitor.h
@@ -0,0 +1,75 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_RSSI_MONITOR_H__
+#define    __PHYDM_RSSI_MONITOR_H__
+
+#define RSSI_MONITOR_VERSION	"1.0"		/* 2017.05.011  Dino, Add phydm_rssi_monitor.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define	H2C_0X42_LENGTH	5
+
+#define RAINFO_BE_RX_STATE				BIT(0)	/* 1:RX*/ /* ULDL */
+#define RAINFO_STBC_STATE				BIT(1)
+#define RAINFO_NOISY_STATE 			BIT(2)	/* set by Noisy_Detection */
+/*#define RAINFO_SHURTCUT_STATE			BIT(3)*/
+/*#define RAINFO_SHURTCUT_FLAG			BIT(4)*/
+#define RAINFO_INIT_RSSI_RATE_STATE	BIT(5)
+#define RAINFO_BF_STATE				BIT(6)
+#define RAINFO_BE_TX_STATE 			BIT(7)	/* 1:TX */
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_rssi_monitor_check(
+	void		*dm_void
+);
+
+void
+phydm_rssi_monitor_init(
+	void		*dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_smt_ant.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_smt_ant.c
new file mode 100644
index 000000000000..323a95341e23
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_smt_ant.c
@@ -0,0 +1,2228 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ******************************************************
+ * when antenna test utility is on or some testing need to disable antenna diversity
+ * call this function to disable all ODM related mechanisms which will switch antenna.
+ * ****************************************************** */
+#if (defined(CONFIG_SMART_ANTENNA))
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+void
+phydm_cumitek_smt_ant_mapping_table_8822b(
+	void		*dm_void,
+	u8		*table_path_a,
+	u8		*table_path_b
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		path_a_0to3_idx = 0;
+	u32		path_b_0to3_idx = 0;
+	u32		path_a_4to7_idx = 0;
+	u32		path_b_4to7_idx = 0;
+	
+	path_a_0to3_idx = ((table_path_a[3] & 0xf) << 24) | ((table_path_a[2] & 0xf) << 16) 
+						| ((table_path_a[1] & 0xf) << 8) | (table_path_a[0] & 0xf);
+
+	path_b_0to3_idx = ((table_path_b[3] & 0xf) << 28) | ((table_path_b[2] & 0xf) << 20) 
+						| ((table_path_b[1] & 0xf) << 12) | ((table_path_b[0] & 0xf) << 4);
+
+	path_a_4to7_idx = ((table_path_a[7] & 0xf) << 24) | ((table_path_a[6] & 0xf) << 16) 
+						| ((table_path_a[5] & 0xf) << 8) | (table_path_a[4] & 0xf);
+
+	path_b_4to7_idx = ((table_path_b[7] & 0xf) << 28) | ((table_path_b[6] & 0xf) << 20) 
+						| ((table_path_b[5] & 0xf) << 12) | ((table_path_b[4] & 0xf) << 4);
+
+
+	/*PHYDM_DBG(dm, DBG_SMT_ANT, "mapping table{A, B} = {0x%x, 0x%x}\n", path_a_0to3_idx, path_b_0to3_idx);*/
+
+	/*pathA*/
+	odm_set_bb_reg(dm, 0xca4, MASKDWORD, path_a_0to3_idx); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xca8, MASKDWORD, path_a_4to7_idx); /*ant map 2*/
+
+	/*pathB*/
+	odm_set_bb_reg(dm, 0xea4, MASKDWORD, path_b_0to3_idx); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xea8, MASKDWORD, path_b_4to7_idx); /*ant map 2*/
+
+}
+
+
+void
+phydm_cumitek_smt_ant_init_8822b(
+	void		*dm_void
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant				*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek		*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32		value32;
+
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[8822B Cumitek SmtAnt Int]\n");
+
+	/*========= MAC GPIO setting =================================*/
+	
+	/* Pin, pin_name, RFE_CTRL_NUM*/
+	
+	/* A0, 55, 5G_TRSW, 3*/
+	/* A1, 52, 5G_TRSW, 0*/
+	/* A2, 25, 5G_TRSW, 8*/
+	
+	/* B0, 16, 5G_TRSW, 4*/
+	/* B1, 13, 5G_TRSW, 11*/
+	/* B2, 24, 5G_TRSW, 9*/
+
+	/*for RFE_CTRL 8 & 9*/
+	odm_set_mac_reg(dm, 0x4c, BIT(24) | BIT(23), 2);
+	odm_set_mac_reg(dm, 0x44, BIT(27) | BIT(26), 0);
+
+	/*for RFE_CTRL 0*/
+	odm_set_mac_reg(dm, 0x4c, BIT(25), 0);
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1);
+
+	/*for RFE_CTRL 2 & 3*/
+	odm_set_mac_reg(dm, 0x4c, BIT(26), 0);
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1);
+
+	/*for RFE_CTRL 11*/
+	odm_set_mac_reg(dm, 0x40, BIT(3), 1);
+
+
+	/*0x604[25]=1 : 2bit mode for pathA&B&C&D*/
+	/*0x604[25]=0 : 3bit mode for pathA&B*/
+	smtant_table->tx_desc_mode = 0;
+	odm_set_mac_reg(dm, 0x604, BIT(25), (u32)smtant_table->tx_desc_mode);
+
+	/*========= BB RFE setting =================================*/
+	#if 0
+	/*path A*/
+	odm_set_bb_reg(dm, 0x1990, BIT(3), 0);		/*RFE_CTRL_3*/ /*A_0*/
+	odm_set_bb_reg(dm, 0xcbc, BIT(3), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xcb0, 0xf000, 8);
+
+	odm_set_bb_reg(dm, 0x1990, BIT(0), 0);		/*RFE_CTRL_0*/ /*A_1*/
+	odm_set_bb_reg(dm, 0xcbc, BIT(0), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xcb0, 0xf, 0x9);
+	
+	odm_set_bb_reg(dm, 0x1990, BIT(8), 0);		/*RFE_CTRL_8*/ /*A_2*/
+	odm_set_bb_reg(dm, 0xcbc, BIT(8), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xcb4, 0xf, 0xa);
+	
+
+	/*path B*/
+	odm_set_bb_reg(dm, 0x1990, BIT(4), 1);		/*RFE_CTRL_4*/	/*B_0*/
+	odm_set_bb_reg(dm, 0xdbc, BIT(4), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xdb0, 0xf0000, 0xb);
+	
+	odm_set_bb_reg(dm, 0x1990, BIT(11), 1);	/*RFE_CTRL_11*/	/*B_1*/
+	odm_set_bb_reg(dm, 0xdbc, BIT(11), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xdb4, 0xf000, 0xc);
+	
+	odm_set_bb_reg(dm, 0x1990, BIT(9), 1);		/*RFE_CTRL_9*/	/*B_2*/
+	odm_set_bb_reg(dm, 0xdbc, BIT(9), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xdb4, 0xf0, 0xd);
+	#endif
+	/*========= BB SmtAnt setting =================================*/
+	odm_set_mac_reg(dm, 0x6d8, BIT(22) | BIT(21), 2); /*resp tx by register*/
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+	odm_set_bb_reg(dm, 0x804, BIT(4), 0); /*lathch antsel*/
+	odm_set_bb_reg(dm, 0x818, 0xf00000, 0); /*keep tx by rx*/
+	odm_set_bb_reg(dm, 0x900, BIT(19), 0); /*fast train*/
+	odm_set_bb_reg(dm, 0x900, BIT(18), 1); /*1: by TXDESC*/
+
+	/*pathA*/
+	odm_set_bb_reg(dm, 0xca4, MASKDWORD, 0x03020100); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xca8, MASKDWORD, 0x07060504); /*ant map 2*/
+	odm_set_bb_reg(dm, 0xcac, BIT(9), 0); /*keep antsel map by GNT_BT*/
+
+	/*pathB*/
+	odm_set_bb_reg(dm, 0xea4, MASKDWORD, 0x30201000); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xea8, MASKDWORD, 0x70605040); /*ant map 2*/
+	odm_set_bb_reg(dm, 0xeac, BIT(9), 0); /*keep antsel map by GNT_BT*/
+}
+
+void
+phydm_cumitek_smt_ant_init_8197f(
+	void		*dm_void
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32		value32;
+
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[8197F Cumitek SmtAnt Int]\n");
+
+	/*GPIO setting*/
+
+
+}
+
+void
+phydm_cumitek_smt_tx_ant_update(
+	void		*dm_void,
+	u8		tx_ant_idx_path_a,
+	u8		tx_ant_idx_path_b,
+	u32		mac_id
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[Cumitek] Set TX-ANT[%d] = (( A:0x%x ,  B:0x%x ))\n",
+		mac_id, tx_ant_idx_path_a, tx_ant_idx_path_b);
+
+	/*path-A*/
+	cumi_smtant_table->tx_ant_idx[0][mac_id] = tx_ant_idx_path_a; /*fill this value into TXDESC*/
+	
+	/*path-B*/	
+	cumi_smtant_table->tx_ant_idx[1][mac_id] = tx_ant_idx_path_b; /*fill this value into TXDESC*/
+}
+
+void
+phydm_cumitek_smt_rx_default_ant_update(
+	void		*dm_void,
+	u8		rx_ant_idx_path_a,
+	u8		rx_ant_idx_path_b
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[Cumitek] Set RX-ANT = (( A:0x%x, B:0x%x ))\n",
+		rx_ant_idx_path_a, rx_ant_idx_path_b);
+
+	/*path-A*/
+	if (cumi_smtant_table->rx_default_ant_idx[0] != rx_ant_idx_path_a) {
+		
+		#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			
+			odm_set_bb_reg(dm, 0xc08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_a); /*default RX antenna*/
+			odm_set_mac_reg(dm, 0x6d8, BIT(2) | BIT(1) | BIT(0), rx_ant_idx_path_a); /*default response TX antenna*/
+		}
+		#endif
+		
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
+		}
+		#endif
+
+		cumi_smtant_table->rx_default_ant_idx[0] = rx_ant_idx_path_a;
+	}
+
+	/*path-B*/
+	if (cumi_smtant_table->rx_default_ant_idx[1] != rx_ant_idx_path_b) {
+		
+		#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			
+			odm_set_bb_reg(dm, 0xe08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_b); /*default antenna*/
+			odm_set_mac_reg(dm, 0x6d8, BIT(5) | BIT(4) | BIT(3), rx_ant_idx_path_b); /*default response TX antenna*/
+		}
+		#endif
+		
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
+		}
+		#endif
+
+		cumi_smtant_table->rx_default_ant_idx[1] = rx_ant_idx_path_b;
+	}
+	
+}
+
+void
+phydm_cumitek_smt_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	char			help[] = "-h";
+	u32			dm_value[10] = {0};
+	u8			i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &dm_value[0]);
+
+	if (strcmp(input[1], help) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {PathA rx_ant_idx} {pathB rx_ant_idx}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{2} {PathA tx_ant_idx} {pathB tx_ant_idx} {macid}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{3} {PathA mapping table} {PathB mapping table}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{4} {txdesc_mode 0:3bit, 1:2bit}\n");
+
+	} else if (dm_value[0] == 1) { /*fix rx_idle pattern*/
+	
+		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &dm_value[1]);
+		PHYDM_SSCANF(input[3], DCMD_DECIMAL, &dm_value[2]);
+
+		phydm_cumitek_smt_rx_default_ant_update(dm, (u8)dm_value[1], (u8)dm_value[2]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "RX Ant{A, B}={%d, %d}\n", dm_value[1],
+			       dm_value[2]);
+		
+	} else if (dm_value[0] == 2) { /*fix tx pattern*/ 
+
+
+		for (i = 1; i < 4; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "STA[%d] TX Ant{A, B}={%d, %d}\n",dm_value[3],
+			       dm_value[1], dm_value[2]);
+		phydm_cumitek_smt_tx_ant_update(dm, (u8)dm_value[1], (u8)dm_value[2], (u8)dm_value[3]);
+
+	} else if (dm_value[0] == 3) {
+		u8 table_path_a[8] = {0};
+		u8 table_path_b[8] = {0};
+
+		for (i = 1; i < 4; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Set Path-AB mapping table={%d, %d}\n",
+			       dm_value[1], dm_value[2]);
+
+		for (i = 0; i <8; i++) {
+			table_path_a[i] = (u8)((dm_value[1] >> (4 * i)) & 0xf);
+			table_path_b[i] = (u8)((dm_value[2] >> (4 * i)) & 0xf);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Ant_Table_A[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n",
+			       
+			       table_path_a[7], table_path_a[6],
+			       table_path_a[5], table_path_a[4],
+			       table_path_a[3], table_path_a[2],
+			       table_path_a[1], table_path_a[0]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Ant_Table_B[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n",
+			       
+			       table_path_b[7], table_path_b[6],
+			       table_path_b[5], table_path_b[4],
+			       table_path_b[3], table_path_b[2],
+			       table_path_b[1], table_path_b[0]);
+
+		phydm_cumitek_smt_ant_mapping_table_8822b(dm,
+							  &table_path_a[0],
+							  &table_path_b[0]);
+	}else if (dm_value[0] == 4) {
+		smtant_table->tx_desc_mode = (u8)dm_value[1];
+		odm_set_mac_reg(dm, 0x604, BIT(25), (u32)smtant_table->tx_desc_mode);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+
+#if (RTL8822B_SUPPORT == 1)
+void
+phydm_hl_smart_ant_type2_init_8822b(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	u8	j;
+	u8	rfu_codeword_table_init_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] = {
+			{1, 1},/*0*/
+			{1, 2},
+			{2, 1},
+			{2, 2},
+			{4, 0},
+			{5, 0},
+			{6, 0},
+			{7, 0},
+			{8, 0},/*8*/
+			{9, 0},
+			{0xa, 0},
+			{0xb, 0},
+			{0xc, 0},
+			{0xd, 0},
+			{0xe, 0},
+			{0xf, 0}
+		}; 
+	u8	rfu_codeword_table_init_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] ={
+		#if 1
+			{9, 1},/*0*/
+			{9, 9},
+			{1, 9},
+			{9, 6},
+			{2, 1},
+			{2, 9},
+			{9, 2},
+			{2, 2},/*8*/
+			{6, 1},
+			{6, 9},
+			{2, 9},
+			{2, 2},
+			{6, 2},
+			{6, 6},
+			{2, 6},
+			{1, 1}
+		#else
+			{1, 1},/*0*/
+			{9, 1},
+			{9, 9},
+			{1, 9},
+			{1, 2},
+			{9, 2},
+			{9, 6},
+			{1, 6},
+			{2, 1},/*8*/
+			{6, 1},
+			{6, 9},
+			{2, 9},
+			{2, 2},
+			{6, 2},
+			{6, 6},
+			{2, 6}
+		#endif
+		}; 		
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***RTK 8822B SmartAnt_Init: Hong-Bo SmrtAnt Type2]\n");
+
+	/* ---------------------------------------- */
+	/* GPIO 0-1 for Beam control */
+	/* reg0x66[2:0]=0 */
+	/* reg0x44[25:24] = 0 */
+	/* reg0x44[23:16]  enable_output for P_GPIO[7:0] */
+	/* reg0x44[15:8]  output_value for P_GPIO[7:0] */
+	/* reg0x40[1:0] = 0  GPIO function */
+	/* ------------------------------------------ */
+
+	odm_move_memory(dm, sat_tab->rfu_codeword_table_2g, rfu_codeword_table_init_2g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
+	odm_move_memory(dm, sat_tab->rfu_codeword_table_5g, rfu_codeword_table_init_5g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
+
+	/*GPIO setting*/
+	odm_set_mac_reg(dm, 0x64, (BIT(18) | BIT(17) | BIT(16)), 0);
+	odm_set_mac_reg(dm, 0x44, BIT(25) | BIT(24), 0);	/*config P_GPIO[3:2] to data port*/
+	odm_set_mac_reg(dm, 0x44, BIT(17) | BIT(16), 0x3);	/*enable_output for P_GPIO[3:2]*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(9)|BIT(8), 0);*/ /*P_GPIO[3:2] output value*/
+	odm_set_mac_reg(dm, 0x40, BIT(1) | BIT(0), 0);		/*GPIO function*/
+
+	/*Hong_lin smart antenna HW setting*/
+	sat_tab->rfu_protocol_type = 2;
+	sat_tab->rfu_protocol_delay_time = 45;
+	
+	sat_tab->rfu_codeword_total_bit_num  = 16;/*max=32bit*/
+	sat_tab->rfu_each_ant_bit_num = 4;
+	
+	sat_tab->total_beam_set_num = 4;
+	sat_tab->total_beam_set_num_2g = 4;
+	sat_tab->total_beam_set_num_5g = 8;
+
+#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#elif DEV_BUS_TYPE == RT_USB_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#endif
+	sat_tab->pkt_skip_statistic_en = 0;
+
+	sat_tab->ant_num = 2;
+	sat_tab->ant_num_total = MAX_PATH_NUM_8822B;
+	sat_tab->first_train_ant = MAIN_ANT;
+
+
+
+	sat_tab->fix_beam_pattern_en  = 0;
+	sat_tab->decision_holding_period = 0;
+
+	/*beam training setting*/
+	sat_tab->pkt_counter = 0;
+	sat_tab->per_beam_training_pkt_num = 10;
+
+	/*set default beam*/
+	sat_tab->fast_training_beam_num = 0;
+	sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+
+	for (j = 0; j < SUPPORT_BEAM_SET_PATTERN_NUM; j++) {
+		
+		sat_tab->beam_set_avg_rssi_pre[j] = 0;
+		sat_tab->beam_set_train_val_diff[j] = 0;
+		sat_tab->beam_set_train_cnt[j] = 0;
+	}
+	phydm_set_rfu_beam_pattern_type2(dm);
+	fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+	
+}
+#endif
+
+
+u32
+phydm_construct_hb_rfu_codeword_type2(
+	void		*dm_void,
+	u32		beam_set_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo		*sat_tab = &dm->dm_sat_table;
+	u32		sync_codeword = 0x7f;
+	u32		codeword = 0;
+	u32		data_tmp = 0;
+	u32		i;
+
+	for (i = 0; i < sat_tab->ant_num_total; i++) {
+		if (*dm->band_type == ODM_BAND_5G)
+			data_tmp = sat_tab->rfu_codeword_table_5g[beam_set_idx][i];
+		else
+			data_tmp = sat_tab->rfu_codeword_table_2g[beam_set_idx][i];
+			
+		codeword |= (data_tmp << (i * sat_tab->rfu_each_ant_bit_num));
+	}
+
+	codeword = (codeword<<8) | sync_codeword;
+	
+	return codeword;
+}
+
+void
+phydm_update_beam_pattern_type2(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u8			i;
+	boolean			beam_ctrl_signal;
+	u32			one = 0x1;
+	u32			reg44_tmp_p, reg44_tmp_n, reg44_ori;
+	u8			devide_num = 4;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Set codeword = ((0x%x))\n", codeword);
+
+	reg44_ori = odm_get_mac_reg(dm, 0x44, MASKDWORD);
+	reg44_tmp_p = reg44_ori;
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_ori =0x%x\n", reg44_ori);*/
+
+	/*devide_num = (sat_tab->rfu_protocol_type == 2) ? 8 : 4;*/
+
+	for (i = 0; i <= (codeword_length - 1); i++) {
+		beam_ctrl_signal = (boolean)((codeword & BIT(i)) >> i);
+		
+		#if 1
+		if (dm->debug_components & DBG_ANT_DIV) {
+			if (i == (codeword_length - 1)) {
+				pr_debug("%d ]\n", beam_ctrl_signal);
+				/**/
+			} else if (i == 0) {
+				pr_debug("Start sending codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
+				/**/
+			} else if ((i % devide_num) == (devide_num-1)) {
+				pr_debug("%d  |  ", beam_ctrl_signal);
+				/**/
+			} else {
+				pr_debug("%d ", beam_ctrl_signal);
+				/**/
+			}
+		}
+		#endif
+		
+		if (dm->support_ic_type == ODM_RTL8821) {
+			#if (RTL8821A_SUPPORT == 1)
+			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*clean bit 10 & 11*/
+			reg44_tmp_p |= ((1 << 11) | (beam_ctrl_signal << 10));
+			reg44_tmp_n = reg44_ori & (~(BIT(11) | BIT(10)));
+
+			/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n);*/
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+			#endif
+		}
+		#if (RTL8822B_SUPPORT == 1)
+		else if (dm->support_ic_type == ODM_RTL8822B) {
+			if (sat_tab->rfu_protocol_type == 2) {
+				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*clean bit 8*/
+				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*get new clk high/low, exclusive-or*/
+
+	
+				reg44_tmp_p |= (beam_ctrl_signal << 8);
+				
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(sat_tab->rfu_protocol_delay_time);
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal);*/
+				
+			} else {
+				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*clean bit 9 & 8*/
+				reg44_tmp_p |= ((1 << 9) | (beam_ctrl_signal << 8));
+				reg44_tmp_n = reg44_ori & (~(BIT(9) | BIT(8)));
+
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n); */
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(10);
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+				ODM_delay_us(10);
+			}
+		}
+		#endif
+	}
+}
+
+void
+phydm_update_rx_idle_beam_type2(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	u32			i;
+
+	sat_tab->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(dm, sat_tab->rx_idle_beam_set_idx);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-Beam ] BeamSet idx = ((%d))\n", sat_tab->rx_idle_beam_set_idx);
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+#endif
+
+	sat_tab->pre_codeword = sat_tab->update_beam_codeword;
+}
+
+
+void
+phydm_hl_smart_ant_debug_type2(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			one = 0x1;
+	u32			codeword_length = sat_tab->rfu_codeword_total_bit_num;
+	u32			beam_ctrl_signal, i;
+	u8			devide_num = 4;
+	char			help[] = "-h";
+	u32			dm_value[10] = {0};
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &dm_value[0]);
+	PHYDM_SSCANF(input[2], DCMD_DECIMAL, &dm_value[1]);
+	PHYDM_SSCANF(input[3], DCMD_DECIMAL, &dm_value[2]);
+	PHYDM_SSCANF(input[4], DCMD_DECIMAL, &dm_value[3]);
+	PHYDM_SSCANF(input[5], DCMD_DECIMAL, &dm_value[4]);
+
+
+	if (strcmp(input[1], help) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 1 {fix_en} {codeword(Hex)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 3 {Fix_training_num_en} {Per_beam_training_pkt_num} {Decision_holding_period}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 5 {0:show, 1:2G, 2:5G} {beam_num} {idxA(Hex)} {idxB(Hex)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 7 {0:show, 1:2G, 2:5G} {total_beam_set_num}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 8 {0:show, 1:set} {RFU delay time(us)}\n");
+
+	} else if (dm_value[0] == 1) { /*fix beam pattern*/
+
+		sat_tab->fix_beam_pattern_en = dm_value[1];
+
+		if (sat_tab->fix_beam_pattern_en == 1) {
+			PHYDM_SSCANF(input[3], DCMD_HEX, &dm_value[2]);
+			sat_tab->fix_beam_pattern_codeword = dm_value[2];
+
+			if (sat_tab->fix_beam_pattern_codeword  > (one << codeword_length)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
+					sat_tab->fix_beam_pattern_codeword, codeword_length);
+				
+				(sat_tab->fix_beam_pattern_codeword) &= 0xffffff;
+				
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Auto modify to (0x%x)\n", sat_tab->fix_beam_pattern_codeword);
+			}
+
+			sat_tab->update_beam_codeword = sat_tab->fix_beam_pattern_codeword;
+
+			/*---------------------------------------------------------*/
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Fix Beam Pattern\n");
+			
+			/*devide_num = (sat_tab->rfu_protocol_type == 2) ? 8 : 4;*/
+			
+			for (i = 0; i <= (codeword_length - 1); i++) {
+				beam_ctrl_signal = (boolean)((sat_tab->update_beam_codeword & BIT(i)) >> i);
+
+				if (i == (codeword_length - 1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "%d]\n",
+						       beam_ctrl_signal);
+					/**/
+				} else if (i == 0) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "Send Codeword[1:%d] to RFU -> [%d",
+						       sat_tab->rfu_codeword_total_bit_num,
+						       beam_ctrl_signal);
+					/**/
+				} else if ((i % devide_num) == (devide_num-1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d|",
+						       beam_ctrl_signal);
+					/**/
+				} else {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d",
+						       beam_ctrl_signal);
+					/**/
+				}
+			}
+			/*---------------------------------------------------------*/
+
+
+			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+			#else
+			odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+			/*odm_stall_execution(1);*/
+			#endif
+		} else if (sat_tab->fix_beam_pattern_en == 0)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Smart Antenna: Enable\n");
+
+	} else if (dm_value[0] == 2) { /*set latch time*/
+
+		sat_tab->latch_time = dm_value[1];
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ]  latch_time =0x%x\n", sat_tab->latch_time);
+	} else if (dm_value[0] == 3) {
+		sat_tab->fix_training_num_en = dm_value[1];
+
+		if (sat_tab->fix_training_num_en == 1) {
+			sat_tab->per_beam_training_pkt_num = (u8)dm_value[2];
+			sat_tab->decision_holding_period = (u8)dm_value[3];
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmtAnt] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
+				       sat_tab->fix_training_num_en,
+				       sat_tab->per_beam_training_pkt_num,
+				       sat_tab->decision_holding_period);
+
+		} else if (sat_tab->fix_training_num_en == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n");
+			/**/
+		}
+	} else if (dm_value[0] == 4) {
+		#if 0
+		if (dm_value[1] == 1) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = MAIN_ANT;
+
+		} else if (dm_value[1] == 2) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = AUX_ANT;
+
+		} else if (dm_value[1] == 3) {
+			sat_tab->ant_num = 2;
+			sat_tab->first_train_ant = MAIN_ANT;
+		}
+
+		PDM_SNPF((output + used, out_len - used, "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
+			sat_tab->ant_num, (sat_tab->first_train_ant - 1)));
+		#endif
+	} else if (dm_value[0] == 5) {	/*set beam set table*/
+
+		PHYDM_SSCANF(input[4], DCMD_HEX, &dm_value[3]);
+		PHYDM_SSCANF(input[5], DCMD_HEX, &dm_value[4]);
+
+		if (dm_value[1] == 1) { /*2G*/
+			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
+				sat_tab->rfu_codeword_table_2g[dm_value[2] ][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_2g[dm_value[2] ][1] = (u8)dm_value[4];
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Set 2G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       dm_value[2], dm_value[3],
+					       dm_value[4]);
+			}
+			
+		} else if (dm_value[1] == 2) { /*5G*/
+			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][1] = (u8)dm_value[4];
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       dm_value[2], dm_value[3],
+					       dm_value[4]);
+			}
+		} else  if (dm_value[1] == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmtAnt] 2G Beam Table==============>\n");
+			for (i = 0; i < sat_tab->total_beam_set_num_2g; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "2G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       i,
+					       sat_tab->rfu_codeword_table_2g[i][0],
+					       sat_tab->rfu_codeword_table_2g[i][1]);
+			}
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmtAnt] 5G Beam Table==============>\n");
+			for (i = 0; i < sat_tab->total_beam_set_num_5g; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       i,
+					       sat_tab->rfu_codeword_table_5g[i][0],
+					       sat_tab->rfu_codeword_table_5g[i][1]);
+			}
+		}
+
+	} else if (dm_value[0] == 6) {
+		#if 0
+		if (dm_value[1] == 0) {
+			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][1] = (u8)dm_value[4];
+				PDM_SNPF((output + used, out_len - used, "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",dm_value[2], dm_value[3], dm_value[4]));
+			}
+		} else {
+			for (i = 0; i < sat_tab->total_beam_set_num_5g; i++) {
+				PDM_SNPF((output + used, out_len - used, "[SmtAnt] Read 5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					i, sat_tab->rfu_codeword_table_5g[i][0], sat_tab->rfu_codeword_table_5g[i][1]));
+			}
+		}
+		#endif
+	} else if (dm_value[0] == 7) {
+		if (dm_value[1] == 1) {
+			sat_tab->total_beam_set_num_2g = (u8)(dm_value[2]);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] total_beam_set_num_2g = ((%d))\n",
+				       sat_tab->total_beam_set_num_2g);
+
+		} else if (dm_value[1] == 2) {
+			sat_tab->total_beam_set_num_5g = (u8)(dm_value[2]);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] total_beam_set_num_5g = ((%d))\n",
+				       sat_tab->total_beam_set_num_5g);
+		} else if (dm_value[1] == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Show total_beam_set_num{2g,5g} = {%d,%d}\n",
+				       
+				       sat_tab->total_beam_set_num_2g,
+				       sat_tab->total_beam_set_num_5g);
+		}
+
+	} else if (dm_value[0] == 8) {
+			if (dm_value[1] == 1) {
+				sat_tab->rfu_protocol_delay_time = (u16)(dm_value[2]);
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Set rfu_protocol_delay_time = ((%d))\n",
+					       sat_tab->rfu_protocol_delay_time);
+			} else if (dm_value[1] == 0) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Read rfu_protocol_delay_time = ((%d))\n",
+					       sat_tab->rfu_protocol_delay_time);
+			}
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_set_rfu_beam_pattern_type2(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+
+	if (dm->ant_div_type != HL_SW_SMART_ANT_TYPE2)
+		return;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Training beam_set index = (( 0x%x ))\n", sat_tab->fast_training_beam_num);
+	sat_tab->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(dm, sat_tab->fast_training_beam_num);
+
+	#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+	#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+	#endif
+}
+
+void
+phydm_fast_ant_training_hl_smart_antenna_type2(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct		*fat_tab	 = &dm->dm_fat_table;
+	struct sw_antenna_switch				*dm_swat_table = &dm->dm_swat_table;
+	u32		codeword = 0;
+	u8		i = 0, j=0;
+	u8		avg_rssi_tmp;
+	u8		avg_rssi_tmp_ma;
+	u8		max_beam_ant_rssi = 0;
+	u8		rssi_target_beam = 0, target_beam_max_rssi = 0;
+	u8		evm1ss_target_beam = 0, evm2ss_target_beam = 0;
+	u32		target_beam_max_evm1ss = 0, target_beam_max_evm2ss = 0;
+	u32		beam_tmp;
+	u8		per_beam_val_diff_tmp = 0, training_pkt_num_offset;
+	u32		avg_evm2ss[2] = {0}, avg_evm2ss_sum = 0;
+	u32		avg_evm1ss = 0;
+	u32		beam_path_evm_2ss_cnt_all = 0; /*sum of all 2SS-pattern cnt*/
+	u32		beam_path_evm_1ss_cnt_all = 0; /*sum of all 1SS-pattern cnt*/
+	u8		decision_type;
+
+	if (!dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			sat_tab->decision_holding_period = 0;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Link->no Link\n");
+			fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+
+			fat_tab->fat_state = FAT_PREPARE_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+
+			/*sat_tab->fast_training_beam_num = 0;*/
+			/*phydm_set_rfu_beam_pattern_type2(dm);*/
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "HL Smart ant Training: state (( %d ))\n", fat_tab->fat_state);*/
+
+	/* [DECISION STATE] */
+	/*=======================================================================================*/
+	if (fat_tab->fat_state == FAT_DECISION_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 3. In Decision state]\n");
+
+		/*compute target beam in each antenna*/
+
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			/*[Decision1: RSSI]-------------------------------------------------------------------*/
+			if (sat_tab->statistic_pkt_cnt[j] == 0) {	/*if new RSSI = 0 -> MA_RSSI-=2*/
+				avg_rssi_tmp = sat_tab->beam_set_avg_rssi_pre[j];
+				avg_rssi_tmp = (avg_rssi_tmp >= 2) ? (avg_rssi_tmp - 2) : avg_rssi_tmp;
+				avg_rssi_tmp_ma = avg_rssi_tmp;
+			} else {
+				avg_rssi_tmp = (u8)((sat_tab->beam_set_rssi_avg_sum[j]) / (sat_tab->statistic_pkt_cnt[j]));
+				avg_rssi_tmp_ma = (avg_rssi_tmp + sat_tab->beam_set_avg_rssi_pre[j]) >> 1;
+			}
+
+			sat_tab->beam_set_avg_rssi_pre[j] = avg_rssi_tmp;
+
+			if (avg_rssi_tmp > target_beam_max_rssi) {
+				rssi_target_beam = j;
+				target_beam_max_rssi = avg_rssi_tmp;
+			}
+
+			/*[Decision2: EVM 2ss]-------------------------------------------------------------------*/
+			if (sat_tab->beam_path_evm_2ss_cnt[j] != 0) {
+				avg_evm2ss[0] =  sat_tab->beam_path_evm_2ss_sum[j][0] / sat_tab->beam_path_evm_2ss_cnt[j];
+				avg_evm2ss[1] =  sat_tab->beam_path_evm_2ss_sum[j][1] / sat_tab->beam_path_evm_2ss_cnt[j];
+				avg_evm2ss_sum = avg_evm2ss[0] + avg_evm2ss[1];
+				beam_path_evm_2ss_cnt_all += sat_tab->beam_path_evm_2ss_cnt[j];
+
+				sat_tab->beam_set_avg_evm_2ss_pre[j] = (u8)avg_evm2ss_sum;
+			}
+
+			if (avg_evm2ss_sum > target_beam_max_evm2ss) {
+				evm2ss_target_beam = j;
+				target_beam_max_evm2ss = avg_evm2ss_sum;
+			}
+
+			/*[Decision3: EVM 1ss]-------------------------------------------------------------------*/
+			if (sat_tab->beam_path_evm_1ss_cnt[j] != 0) {
+				avg_evm1ss =  sat_tab->beam_path_evm_1ss_sum[j] / sat_tab->beam_path_evm_1ss_cnt[j];
+				beam_path_evm_1ss_cnt_all += sat_tab->beam_path_evm_1ss_cnt[j];
+
+				sat_tab->beam_set_avg_evm_1ss_pre[j] = (u8)avg_evm1ss;
+			}
+				
+			if (avg_evm1ss > target_beam_max_evm1ss) {
+				evm1ss_target_beam = j;
+				target_beam_max_evm1ss = avg_evm1ss;
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Beam[%d] Pkt_cnt=(( %d )), avg{MA,rssi}={%d, %d}, EVM1={%d}, EVM2={%d, %d, %d}\n",
+				j, sat_tab->statistic_pkt_cnt[j], avg_rssi_tmp_ma, avg_rssi_tmp, avg_evm1ss, avg_evm2ss[0], avg_evm2ss[1], avg_evm2ss_sum);
+
+			/*reset counter value*/
+			sat_tab->beam_set_rssi_avg_sum[j] = 0;
+			sat_tab->beam_path_rssi_sum[j][0] = 0;
+			sat_tab->beam_path_rssi_sum[j][1] = 0;
+			sat_tab->statistic_pkt_cnt[j] = 0;
+			
+			sat_tab->beam_path_evm_2ss_sum[j][0] = 0;
+			sat_tab->beam_path_evm_2ss_sum[j][1] = 0;
+			sat_tab->beam_path_evm_2ss_cnt[j] = 0;
+			
+			sat_tab->beam_path_evm_1ss_sum[j] = 0;
+			sat_tab->beam_path_evm_1ss_cnt[j] = 0;
+		}
+		
+		/*[Joint Decision]-------------------------------------------------------------------*/
+		PHYDM_DBG(dm, DBG_ANT_DIV, "--->1.[RSSI]      Target Beam(( %d )) RSSI_max=((%d))\n", rssi_target_beam, target_beam_max_rssi);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "--->2.[Evm2SS] Target Beam(( %d )) EVM2SS_max=((%d))\n", evm2ss_target_beam, target_beam_max_evm2ss);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "--->3.[Evm1SS] Target Beam(( %d )) EVM1SS_max=((%d))\n", evm1ss_target_beam, target_beam_max_evm1ss);
+
+		if (target_beam_max_rssi <= 10) {
+			sat_tab->rx_idle_beam_set_idx = rssi_target_beam;
+			decision_type = 1;
+		} else {
+			if (beam_path_evm_2ss_cnt_all != 0) {
+				sat_tab->rx_idle_beam_set_idx = evm2ss_target_beam;
+				decision_type = 2;
+			} else if (beam_path_evm_1ss_cnt_all != 0) {
+				sat_tab->rx_idle_beam_set_idx = evm1ss_target_beam;
+				decision_type = 3;
+			} else {
+				sat_tab->rx_idle_beam_set_idx = rssi_target_beam;
+				decision_type = 1;
+			}
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "---> Decision_type=((%d)), Final Target Beam(( %d ))\n", decision_type, sat_tab->rx_idle_beam_set_idx);
+
+		/*Calculate packet counter offset*/
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			if (decision_type == 1) {
+				per_beam_val_diff_tmp = target_beam_max_rssi - sat_tab->beam_set_avg_rssi_pre[j];
+				
+			} else if (decision_type == 2) {
+				per_beam_val_diff_tmp = ((u8)target_beam_max_evm2ss - sat_tab->beam_set_avg_evm_2ss_pre[j]) >> 1;
+			} else if (decision_type == 3) {
+				per_beam_val_diff_tmp = (u8)target_beam_max_evm1ss - sat_tab->beam_set_avg_evm_1ss_pre[j];
+			}
+			sat_tab->beam_set_train_val_diff[j] = per_beam_val_diff_tmp;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Beam_Set[%d]: diff= ((%d))\n", j, per_beam_val_diff_tmp);
+		}
+
+		/*set beam in each antenna*/
+		phydm_update_rx_idle_beam_type2(dm);
+		fat_tab->fat_state = FAT_PREPARE_STATE;
+
+	}
+	/* [TRAINING STATE] */
+	else if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2. In Training state]\n");
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "curr_beam_idx = (( %d )), pre_beam_idx = (( %d ))\n",
+			sat_tab->fast_training_beam_num, sat_tab->pre_fast_training_beam_num);
+
+		if (sat_tab->fast_training_beam_num > sat_tab->pre_fast_training_beam_num)
+
+			sat_tab->force_update_beam_en = 0;
+
+		else {
+			sat_tab->force_update_beam_en = 1;
+
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+			if (sat_tab->fast_training_beam_num >= ((u32)sat_tab->total_beam_set_num - 1)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n", sat_tab->fast_training_beam_num);
+				fat_tab->fat_state = FAT_DECISION_STATE;
+				phydm_fast_ant_training_hl_smart_antenna_type2(dm);
+
+			} else {
+				sat_tab->fast_training_beam_num++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+				phydm_set_rfu_beam_pattern_type2(dm);
+				fat_tab->fat_state = FAT_TRAINING_STATE;
+
+			}
+		}
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Update Pre_Beam =(( %d ))\n", sat_tab->pre_fast_training_beam_num);
+	}
+	/*  [Prepare state] */
+	/*=======================================================================================*/
+	else if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n\n[ 1. In Prepare state]\n");
+
+		if (dm->pre_traffic_load == (dm->traffic_load)) {
+			if (sat_tab->decision_holding_period != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Holding_period = (( %d )), return!!!\n", sat_tab->decision_holding_period);
+				sat_tab->decision_holding_period--;
+				return;
+			}
+		}
+
+		/* Set training packet number*/
+		if (sat_tab->fix_training_num_en == 0) {
+			switch (dm->traffic_load) {
+			case TRAFFIC_HIGH:
+				sat_tab->per_beam_training_pkt_num = 8;
+				sat_tab->decision_holding_period = 2;
+				break;
+			case TRAFFIC_MID:
+				sat_tab->per_beam_training_pkt_num = 6;
+				sat_tab->decision_holding_period = 3;
+				break;
+			case TRAFFIC_LOW:
+				sat_tab->per_beam_training_pkt_num = 3; /*ping 60000*/
+				sat_tab->decision_holding_period = 4;
+				break;
+			case TRAFFIC_ULTRA_LOW:
+				sat_tab->per_beam_training_pkt_num = 1;
+				sat_tab->decision_holding_period = 6;
+				break;
+			default:
+				break;
+			}
+		}
+		
+		PHYDM_DBG(dm, DBG_ANT_DIV, "TrafficLoad = (( %d )), Fix_beam = (( %d )), per_beam_training_pkt_num = (( %d )), decision_holding_period = ((%d))\n",
+			dm->traffic_load, sat_tab->fix_training_num_en, sat_tab->per_beam_training_pkt_num, sat_tab->decision_holding_period);
+
+		/*Beam_set number*/
+		if (*dm->band_type == ODM_BAND_5G) {
+			sat_tab->total_beam_set_num = sat_tab->total_beam_set_num_5g;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "5G beam_set num = ((%d))\n", sat_tab->total_beam_set_num);
+		} else {
+			sat_tab->total_beam_set_num = sat_tab->total_beam_set_num_2g;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "2G beam_set num = ((%d))\n", sat_tab->total_beam_set_num);
+		}
+
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			training_pkt_num_offset = sat_tab->beam_set_train_val_diff[j];
+
+			if ((sat_tab->per_beam_training_pkt_num) > training_pkt_num_offset)
+				sat_tab->beam_set_train_cnt[j] = sat_tab->per_beam_training_pkt_num - training_pkt_num_offset;
+			else
+				sat_tab->beam_set_train_cnt[j] = 1;
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Beam_Set[ %d ] training_pkt_offset = ((%d)), training_pkt_num = ((%d))\n",
+				j, sat_tab->beam_set_train_val_diff[j], sat_tab->beam_set_train_cnt[j]);
+		}
+		
+		sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+		sat_tab->update_beam_idx = 0;
+		sat_tab->pkt_counter = 0;
+		
+		sat_tab->fast_training_beam_num = 0;
+		phydm_set_rfu_beam_pattern_type2(dm);
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+phydm_beam_switch_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	sat_tab->pkt_skip_statistic_en = 1;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n", sat_tab->pkt_skip_statistic_en);
+
+	phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	/*odm_stall_execution(sat_tab->latch_time);*/
+	sat_tab->pkt_skip_statistic_en = 0;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n", sat_tab->pkt_skip_statistic_en, sat_tab->latch_time);
+}
+
+void
+phydm_beam_decision_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam decision Workitem Callback\n");
+	phydm_fast_ant_training_hl_smart_antenna_type2(dm);
+}
+#endif
+
+void
+phydm_process_rssi_for_hb_smtant_type2(
+	void		*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void,
+	u8		rssi_avg	
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct			*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct				*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	u8		train_pkt_number;
+	u32		beam_tmp;
+	u8		rx_power_ant0 = phy_info->rx_mimo_signal_strength[0];
+	u8		rx_power_ant1 = phy_info->rx_mimo_signal_strength[1];
+	u8		rx_evm_ant0 = phy_info->rx_mimo_evm_dbm[0];
+	u8		rx_evm_ant1 = phy_info->rx_mimo_evm_dbm[1];
+
+	/*[Beacon]*/
+	if (pktinfo->is_packet_beacon) {
+		sat_tab->beacon_counter++;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "MatchBSSID_beacon_counter = ((%d))\n", sat_tab->beacon_counter);
+
+		if (sat_tab->beacon_counter >= sat_tab->pre_beacon_counter + 2) {
+			sat_tab->update_beam_idx++;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
+				sat_tab->pre_beacon_counter, sat_tab->pkt_counter, sat_tab->update_beam_idx);
+			
+			sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+			sat_tab->pkt_counter = 0;
+		}
+	}
+	/*[data]*/
+	else if (pktinfo->is_packet_to_self) {
+		if (sat_tab->pkt_skip_statistic_en == 0) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "ID[%d] pkt_cnt=((%d)): Beam_set = ((%d)), RSSI{A,B,avg} = {%d, %d, %d}\n",
+				pktinfo->station_id, sat_tab->pkt_counter,  sat_tab->fast_training_beam_num, rx_power_ant0, rx_power_ant1, rssi_avg);
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Rate_ss = ((%d)), EVM{A,B} = {%d, %d}, RX Rate =", pktinfo->rate_ss,  rx_evm_ant0, rx_evm_ant1);
+			phydm_print_rate(dm, dm->rx_rate, DBG_ANT_DIV);
+
+
+			if (sat_tab->pkt_counter >= 1)  /*packet skip count*/
+			{
+				sat_tab->beam_set_rssi_avg_sum[sat_tab->fast_training_beam_num] += rssi_avg;
+				sat_tab->statistic_pkt_cnt[sat_tab->fast_training_beam_num]++;
+				
+				sat_tab->beam_path_rssi_sum[sat_tab->fast_training_beam_num][0] += rx_power_ant0;
+				sat_tab->beam_path_rssi_sum[sat_tab->fast_training_beam_num][1] += rx_power_ant1;
+
+				if (pktinfo->rate_ss == 2) {
+					sat_tab->beam_path_evm_2ss_sum[sat_tab->fast_training_beam_num][0] += rx_evm_ant0;
+					sat_tab->beam_path_evm_2ss_sum[sat_tab->fast_training_beam_num][1] += rx_evm_ant1;
+					sat_tab->beam_path_evm_2ss_cnt[sat_tab->fast_training_beam_num]++;
+				} else {
+					sat_tab->beam_path_evm_1ss_sum[sat_tab->fast_training_beam_num] += rx_evm_ant0;
+					sat_tab->beam_path_evm_1ss_cnt[sat_tab->fast_training_beam_num]++;
+				}
+			}
+			
+			sat_tab->pkt_counter++;
+
+			train_pkt_number = sat_tab->beam_set_train_cnt[sat_tab->fast_training_beam_num];
+
+			if (sat_tab->pkt_counter >= train_pkt_number) {
+				sat_tab->update_beam_idx++;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), Update_new_beam = ((%d))\n",
+					sat_tab->pre_beacon_counter, sat_tab->update_beam_idx);
+				
+				sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+				sat_tab->pkt_counter = 0;
+			}
+		}
+	}
+
+	if (sat_tab->update_beam_idx > 0) {
+		
+		sat_tab->update_beam_idx = 0;
+
+		if (sat_tab->fast_training_beam_num >= ((u32)sat_tab->total_beam_set_num - 1)) {
+			fat_tab->fat_state = FAT_DECISION_STATE;
+
+			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			phydm_fast_ant_training_hl_smart_antenna_type2(dm); /*go to make decision*/
+			#else
+			odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+			#endif
+
+
+		} else {
+			beam_tmp = sat_tab->fast_training_beam_num;
+			sat_tab->fast_training_beam_num++;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Update Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+			phydm_set_rfu_beam_pattern_type2(dm);
+			sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+
+			fat_tab->fat_state = FAT_TRAINING_STATE;
+		}
+	}
+	
+}
+#endif
+
+#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
+
+void
+phydm_hl_smart_ant_type1_init_8821a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	u32			value32;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821A SmartAnt_Init => ant_div_type=[Hong-Lin Smart ant Type1]\n");
+
+#if 0
+	/* ---------------------------------------- */
+	/* GPIO 2-3 for Beam control */
+	/* reg0x66[2]=0 */
+	/* reg0x44[27:26] = 0 */
+	/* reg0x44[23:16]  enable_output for P_GPIO[7:0] */
+	/* reg0x44[15:8]  output_value for P_GPIO[7:0] */
+	/* reg0x40[1:0] = 0  GPIO function */
+	/* ------------------------------------------ */
+#endif
+
+	/*GPIO setting*/
+	odm_set_mac_reg(dm, 0x64, BIT(18), 0);
+	odm_set_mac_reg(dm, 0x44, BIT(27) | BIT(26), 0);
+	odm_set_mac_reg(dm, 0x44, BIT(19) | BIT(18), 0x3);	/*enable_output for P_GPIO[3:2]*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(11)|BIT(10), 0);*/ /*output value*/
+	odm_set_mac_reg(dm, 0x40, BIT(1) | BIT(0), 0);		/*GPIO function*/
+
+	/*Hong_lin smart antenna HW setting*/
+	sat_tab->rfu_codeword_total_bit_num  = 24;/*max=32*/
+	sat_tab->rfu_each_ant_bit_num = 4;
+	sat_tab->beam_patten_num_each_ant = 4;
+
+#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#elif DEV_BUS_TYPE == RT_USB_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#endif
+	sat_tab->pkt_skip_statistic_en = 0;
+
+	sat_tab->ant_num = 1;/*max=8*/
+	sat_tab->ant_num_total = NUM_ANTENNA_8821A;
+	sat_tab->first_train_ant = MAIN_ANT;
+
+	sat_tab->rfu_codeword_table[0] = 0x0;
+	sat_tab->rfu_codeword_table[1] = 0x4;
+	sat_tab->rfu_codeword_table[2] = 0x8;
+	sat_tab->rfu_codeword_table[3] = 0xc;
+
+	sat_tab->rfu_codeword_table_5g[0] = 0x1;
+	sat_tab->rfu_codeword_table_5g[1] = 0x2;
+	sat_tab->rfu_codeword_table_5g[2] = 0x4;
+	sat_tab->rfu_codeword_table_5g[3] = 0x8;
+
+	sat_tab->fix_beam_pattern_en  = 0;
+	sat_tab->decision_holding_period = 0;
+
+	/*beam training setting*/
+	sat_tab->pkt_counter = 0;
+	sat_tab->per_beam_training_pkt_num = 10;
+
+	/*set default beam*/
+	sat_tab->fast_training_beam_num = 0;
+	sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+	phydm_set_all_ant_same_beam_num(dm);
+
+	fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+
+	odm_set_bb_reg(dm, 0xCA4, MASKDWORD, 0x01000100);
+	odm_set_bb_reg(dm, 0xCA8, MASKDWORD, 0x01000100);
+
+	/*[BB] FAT setting*/
+	odm_set_bb_reg(dm, 0xc08, BIT(18) | BIT(17) | BIT(16), sat_tab->ant_num);
+	odm_set_bb_reg(dm, 0xc08, BIT(31), 0); /*increase ant num every FAT period 0:+1, 1+2*/
+	odm_set_bb_reg(dm, 0x8c4, BIT(2) | BIT(1), 1); /*change cca antenna timming threshold if no CCA occurred: 0:200ms / 1:100ms / 2:no use / 3: 300*/
+	odm_set_bb_reg(dm, 0x8c4, BIT(0), 1); /*FAT_watchdog_en*/
+
+	value32 = odm_get_mac_reg(dm,  0x7B4, MASKDWORD);
+	odm_set_mac_reg(dm, 0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17)));	/*Reg7B4[16]=1 enable antenna training */
+	/*Reg7B4[17]=1 enable  match MAC addr*/
+	odm_set_mac_reg(dm, 0x7b4, 0xFFFF, 0);/*Match MAC ADDR*/
+	odm_set_mac_reg(dm, 0x7b0, MASKDWORD, 0);
+
+}
+
+u32
+phydm_construct_hl_beam_codeword(
+	void		*dm_void,
+	u32		*beam_pattern_idx,
+	u32		ant_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo		*sat_tab = &dm->dm_sat_table;
+	u32		codeword = 0;
+	u32		data_tmp;
+	u32		i;
+	u32		break_counter = 0;
+
+	if (ant_num < 8) {
+		for (i = 0; i < (sat_tab->ant_num_total); i++) {
+			/*PHYDM_DBG(dm,DBG_ANT_DIV, "beam_pattern_num[%x] = %x\n",i,beam_pattern_num[i] );*/
+			if ((i < (sat_tab->first_train_ant - 1)) || (break_counter >= (sat_tab->ant_num))) {
+				data_tmp = 0;
+				/**/
+			} else {
+				break_counter++;
+
+				if (beam_pattern_idx[i] == 0) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[0];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[0];
+
+				} else if (beam_pattern_idx[i] == 1) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[1];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[1];
+
+				} else if (beam_pattern_idx[i] == 2) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[2];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[2];
+
+				} else if (beam_pattern_idx[i] == 3) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[3];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[3];
+				}
+			}
+
+
+			codeword |= (data_tmp << (i * 4));
+
+		}
+	}
+
+	return codeword;
+}
+
+void
+phydm_update_beam_pattern(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u8			i;
+	boolean			beam_ctrl_signal;
+	u32			one = 0x1;
+	u32			reg44_tmp_p, reg44_tmp_n, reg44_ori;
+	u8			devide_num = 4;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Set Beam Pattern =0x%x\n", codeword);
+
+	reg44_ori = odm_get_mac_reg(dm, 0x44, MASKDWORD);
+	reg44_tmp_p = reg44_ori;
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_ori =0x%x\n", reg44_ori);*/
+
+	devide_num = (sat_tab->rfu_protocol_type == 2) ? 6 : 4;
+
+	for (i = 0; i <= (codeword_length - 1); i++) {
+		beam_ctrl_signal = (boolean)((codeword & BIT(i)) >> i);
+
+		if (dm->debug_components & DBG_ANT_DIV) {
+			if (i == (codeword_length - 1)) {
+				pr_debug("%d ]\n", beam_ctrl_signal);
+				/**/
+			} else if (i == 0) {
+				pr_debug("Send codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
+				/**/
+			} else if ((i % devide_num) == (devide_num-1)) {
+				pr_debug("%d  |  ", beam_ctrl_signal);
+				/**/
+			} else {
+				pr_debug("%d ", beam_ctrl_signal);
+				/**/
+			}
+		}
+
+		if (dm->support_ic_type == ODM_RTL8821) {
+			#if (RTL8821A_SUPPORT == 1)
+			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*clean bit 10 & 11*/
+			reg44_tmp_p |= ((1 << 11) | (beam_ctrl_signal << 10));
+			reg44_tmp_n = reg44_ori & (~(BIT(11) | BIT(10)));
+
+			/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n);*/
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+			#endif
+		}
+		#if (RTL8822B_SUPPORT == 1)
+		else if (dm->support_ic_type == ODM_RTL8822B) {
+			if (sat_tab->rfu_protocol_type == 2) {
+				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*clean bit 8*/
+				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*get new clk high/low, exclusive-or*/
+
+	
+				reg44_tmp_p |= (beam_ctrl_signal << 8);
+				
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(10);
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal);*/
+				
+			} else {
+				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*clean bit 9 & 8*/
+				reg44_tmp_p |= ((1 << 9) | (beam_ctrl_signal << 8));
+				reg44_tmp_n = reg44_ori & (~(BIT(9) | BIT(8)));
+
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n); */
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(10);
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+				ODM_delay_us(10);
+			}
+		}
+		#endif
+	}
+}
+
+void
+phydm_update_rx_idle_beam(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u32			i;
+
+	sat_tab->update_beam_codeword = phydm_construct_hl_beam_codeword(dm,
+									       &sat_tab->rx_idle_beam[0],
+									       sat_tab->ant_num);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Set target beam_pattern codeword = (( 0x%x ))\n", sat_tab->update_beam_codeword);
+
+	for (i = 0; i < (sat_tab->ant_num); i++) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-Beam ] RxIdleBeam[%d] =%d\n", i, sat_tab->rx_idle_beam[i]);
+		/**/
+	}
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+#endif
+
+	sat_tab->pre_codeword = sat_tab->update_beam_codeword;
+}
+
+void
+phydm_hl_smart_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			one = 0x1;
+	u32			codeword_length = sat_tab->rfu_codeword_total_bit_num;
+	u32			beam_ctrl_signal, i;
+	u8			devide_num = 4;
+
+	if (dm_value[0] == 1) { /*fix beam pattern*/
+
+		sat_tab->fix_beam_pattern_en = dm_value[1];
+
+		if (sat_tab->fix_beam_pattern_en == 1) {
+			sat_tab->fix_beam_pattern_codeword = dm_value[2];
+
+			if (sat_tab->fix_beam_pattern_codeword  > (one << codeword_length)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
+					sat_tab->fix_beam_pattern_codeword, codeword_length);
+				
+				(sat_tab->fix_beam_pattern_codeword) &= 0xffffff;
+				
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Auto modify to (0x%x)\n", sat_tab->fix_beam_pattern_codeword);
+			}
+
+			sat_tab->update_beam_codeword = sat_tab->fix_beam_pattern_codeword;
+
+			/*---------------------------------------------------------*/
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Fix Beam Pattern\n");
+			
+			devide_num = (sat_tab->rfu_protocol_type == 2) ? 6 : 4;
+			
+			for (i = 0; i <= (codeword_length - 1); i++) {
+				beam_ctrl_signal = (boolean)((sat_tab->update_beam_codeword & BIT(i)) >> i);
+
+				if (i == (codeword_length - 1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "%d]\n",
+						       beam_ctrl_signal);
+					/**/
+				} else if (i == 0) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "Send Codeword[1:24] to RFU -> [%d",
+						       beam_ctrl_signal);
+					/**/
+				} else if ((i % devide_num) == (devide_num-1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d|",
+						       beam_ctrl_signal);
+					/**/
+				} else {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d",
+						       beam_ctrl_signal);
+					/**/
+				}
+			}
+			/*---------------------------------------------------------*/
+
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+			odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+			/*odm_stall_execution(1);*/
+#endif
+		} else if (sat_tab->fix_beam_pattern_en == 0)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Smart Antenna: Enable\n");
+
+	} else if (dm_value[0] == 2) { /*set latch time*/
+
+		sat_tab->latch_time = dm_value[1];
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ]  latch_time =0x%x\n", sat_tab->latch_time);
+	} else if (dm_value[0] == 3) {
+		sat_tab->fix_training_num_en = dm_value[1];
+
+		if (sat_tab->fix_training_num_en == 1) {
+			sat_tab->per_beam_training_pkt_num = (u8)dm_value[2];
+			sat_tab->decision_holding_period = (u8)dm_value[3];
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmartAnt][Dbg] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
+				       sat_tab->fix_training_num_en,
+				       sat_tab->per_beam_training_pkt_num,
+				       sat_tab->decision_holding_period);
+
+		} else if (sat_tab->fix_training_num_en == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n");
+			/**/
+		}
+	} else if (dm_value[0] == 4) {
+		if (dm_value[1] == 1) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = MAIN_ANT;
+
+		} else if (dm_value[1] == 2) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = AUX_ANT;
+
+		} else if (dm_value[1] == 3) {
+			sat_tab->ant_num = 2;
+			sat_tab->first_train_ant = MAIN_ANT;
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
+			       sat_tab->ant_num,
+			       (sat_tab->first_train_ant - 1));
+	} else if (dm_value[0] == 5) {
+		if (dm_value[1] <= 3) {
+			sat_tab->rfu_codeword_table[dm_value[1]] = dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+					"[ SmartAnt ] Set Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					dm_value[1], dm_value[2]);
+		} else {
+			for (i = 0; i < 4; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[ SmartAnt ] Show Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					       i,
+					       sat_tab->rfu_codeword_table[i]);
+			}
+		}
+	} else if (dm_value[0] == 6) {
+		if (dm_value[1] <= 3) {
+			sat_tab->rfu_codeword_table_5g[dm_value[1]] = dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+					"[ SmartAnt ] Set Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					dm_value[1], dm_value[2]);
+		} else {
+			for (i = 0; i < 4; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[ SmartAnt ] Show Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					       i,
+					       sat_tab->rfu_codeword_table_5g[i]);
+			}
+		}
+	} else if (dm_value[0] == 7) {
+		if (dm_value[1] <= 4) {
+			sat_tab->beam_patten_num_each_ant = dm_value[1];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Set Beam number = (( %d ))\n",
+				       sat_tab->beam_patten_num_each_ant);
+		} else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Show Beam number = (( %d ))\n",
+				       sat_tab->beam_patten_num_each_ant);
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+void
+phydm_set_all_ant_same_beam_num(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+
+	if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) { /*2ant for 8821A*/
+
+		sat_tab->rx_idle_beam[0] = sat_tab->fast_training_beam_num;
+		sat_tab->rx_idle_beam[1] = sat_tab->fast_training_beam_num;
+	}
+
+	sat_tab->update_beam_codeword = phydm_construct_hl_beam_codeword(dm,
+									       &sat_tab->rx_idle_beam[0],
+									       sat_tab->ant_num);
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Set all ant beam_pattern: codeword = (( 0x%x ))\n", sat_tab->update_beam_codeword);
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+#endif
+}
+
+void
+odm_fast_ant_training_hl_smart_antenna_type1(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo		*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct		*fat_tab	 = &dm->dm_fat_table;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	u32		codeword = 0, i, j;
+	u32		target_ant;
+	u32		avg_rssi_tmp, avg_rssi_tmp_ma;
+	u32		target_ant_beam_max_rssi[SUPPORT_RF_PATH_NUM] = {0};
+	u32		max_beam_ant_rssi = 0;
+	u32		target_ant_beam[SUPPORT_RF_PATH_NUM] = {0};
+	u32		beam_tmp;
+	u8		next_ant;
+	u32		rssi_sorting_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u32		rank_idx_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u32		rank_idx_out[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u8		per_beam_rssi_diff_tmp = 0, training_pkt_num_offset;
+	u32		break_counter = 0;
+	u32		used_ant;
+
+
+	if (!dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Link->no Link\n");
+			fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+
+			fat_tab->fat_state = FAT_PREPARE_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+
+			/*sat_tab->fast_training_beam_num = 0;*/
+			/*phydm_set_all_ant_same_beam_num(dm);*/
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "HL Smart ant Training: state (( %d ))\n", fat_tab->fat_state);*/
+
+	/* [DECISION STATE] */
+	/*=======================================================================================*/
+	if (fat_tab->fat_state == FAT_DECISION_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 3. In Decision state]\n");
+		phydm_fast_training_enable(dm, FAT_OFF);
+
+		break_counter = 0;
+		/*compute target beam in each antenna*/
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				if (sat_tab->pkt_rssi_cnt[i][j] == 0) {
+					avg_rssi_tmp = sat_tab->pkt_rssi_pre[i][j];
+					avg_rssi_tmp = (avg_rssi_tmp >= 2) ? (avg_rssi_tmp - 2) : avg_rssi_tmp;
+					avg_rssi_tmp_ma = avg_rssi_tmp;
+				} else {
+					avg_rssi_tmp = (sat_tab->pkt_rssi_sum[i][j]) / (sat_tab->pkt_rssi_cnt[i][j]);
+					avg_rssi_tmp_ma = (avg_rssi_tmp + sat_tab->pkt_rssi_pre[i][j]) >> 1;
+				}
+
+				rssi_sorting_seq[j] = avg_rssi_tmp;
+				sat_tab->pkt_rssi_pre[i][j] = avg_rssi_tmp;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ant[%d], Beam[%d]: pkt_cnt=(( %d )), avg_rssi_MA=(( %d )), avg_rssi=(( %d ))\n",
+					i, j, sat_tab->pkt_rssi_cnt[i][j], avg_rssi_tmp_ma, avg_rssi_tmp);
+
+				if (avg_rssi_tmp > target_ant_beam_max_rssi[i]) {
+					target_ant_beam[i] = j;
+					target_ant_beam_max_rssi[i] = avg_rssi_tmp;
+				}
+
+				/*reset counter value*/
+				sat_tab->pkt_rssi_sum[i][j] = 0;
+				sat_tab->pkt_rssi_cnt[i][j] = 0;
+
+			}
+			sat_tab->rx_idle_beam[i] = target_ant_beam[i];
+			PHYDM_DBG(dm, DBG_ANT_DIV, "---------> Target of ant[%d]: Beam_num-(( %d )) RSSI= ((%d))\n",
+				i,  target_ant_beam[i], target_ant_beam_max_rssi[i]);
+
+			/*sorting*/
+			/*
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Pre]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]);
+			*/
+
+			/*phydm_seq_sorting(dm, &rssi_sorting_seq[0], &rank_idx_seq[0], &rank_idx_out[0], SUPPORT_BEAM_PATTERN_NUM);*/
+
+			/*
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rank_idx_seq = [%d, %d, %d, %d]\n", rank_idx_seq[0], rank_idx_seq[1], rank_idx_seq[2], rank_idx_seq[3]);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rank_idx_out = [%d, %d, %d, %d]\n", rank_idx_out[0], rank_idx_out[1], rank_idx_out[2], rank_idx_out[3]);
+			*/
+
+			if (target_ant_beam_max_rssi[i] > max_beam_ant_rssi) {
+				target_ant = i;
+				max_beam_ant_rssi = target_ant_beam_max_rssi[i];
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "Target of ant = (( %d )) max_beam_ant_rssi = (( %d ))\n",
+					target_ant,  max_beam_ant_rssi);*/
+			}
+			break_counter++;
+			if (break_counter >= (sat_tab->ant_num))
+				break;
+		}
+
+#ifdef CONFIG_FAT_PATCH
+		break_counter = 0;
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				per_beam_rssi_diff_tmp = (u8)(max_beam_ant_rssi - sat_tab->pkt_rssi_pre[i][j]);
+				sat_tab->beam_train_rssi_diff[i][j] = per_beam_rssi_diff_tmp;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ant[%d], Beam[%d]: RSSI_diff= ((%d))\n",
+						i,  j, per_beam_rssi_diff_tmp);
+			}
+			break_counter++;
+			if (break_counter >= (sat_tab->ant_num))
+				break;
+		}
+#endif
+
+		if (target_ant == 0)
+			target_ant = MAIN_ANT;
+		else if (target_ant == 1)
+			target_ant = AUX_ANT;
+
+		if (sat_tab->ant_num > 1) {
+			/* [ update RX ant ]*/
+			odm_update_rx_idle_ant(dm, (u8)target_ant);
+
+			/* [ update TX ant ]*/
+			odm_update_tx_ant(dm, (u8)target_ant, (fat_tab->train_idx));
+		}
+
+		/*set beam in each antenna*/
+		phydm_update_rx_idle_beam(dm);
+
+		odm_ant_div_on_off(dm, ANTDIV_ON);
+		fat_tab->fat_state = FAT_PREPARE_STATE;
+		return;
+
+	}
+	/* [TRAINING STATE] */
+	else if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2. In Training state]\n");
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "fat_beam_n = (( %d )), pre_fat_beam_n = (( %d ))\n",
+			sat_tab->fast_training_beam_num, sat_tab->pre_fast_training_beam_num);
+
+		if (sat_tab->fast_training_beam_num > sat_tab->pre_fast_training_beam_num)
+
+			sat_tab->force_update_beam_en = 0;
+
+		else {
+			sat_tab->force_update_beam_en = 1;
+
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+			if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n", sat_tab->fast_training_beam_num);
+				fat_tab->fat_state = FAT_DECISION_STATE;
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
+
+			} else {
+				sat_tab->fast_training_beam_num++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+				phydm_set_all_ant_same_beam_num(dm);
+				fat_tab->fat_state = FAT_TRAINING_STATE;
+
+			}
+		}
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[prepare state] Update Pre_Beam =(( %d ))\n", sat_tab->pre_fast_training_beam_num);
+	}
+	/*  [Prepare state] */
+	/*=======================================================================================*/
+	else if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n\n[ 1. In Prepare state]\n");
+
+		if (dm->pre_traffic_load == (dm->traffic_load)) {
+			if (sat_tab->decision_holding_period != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Holding_period = (( %d )), return!!!\n", sat_tab->decision_holding_period);
+				sat_tab->decision_holding_period--;
+				return;
+			}
+		}
+
+
+		/* Set training packet number*/
+		if (sat_tab->fix_training_num_en == 0) {
+			switch (dm->traffic_load) {
+			case TRAFFIC_HIGH:
+				sat_tab->per_beam_training_pkt_num = 8;
+				sat_tab->decision_holding_period = 2;
+				break;
+			case TRAFFIC_MID:
+				sat_tab->per_beam_training_pkt_num = 6;
+				sat_tab->decision_holding_period = 3;
+				break;
+			case TRAFFIC_LOW:
+				sat_tab->per_beam_training_pkt_num = 3; /*ping 60000*/
+				sat_tab->decision_holding_period = 4;
+				break;
+			case TRAFFIC_ULTRA_LOW:
+				sat_tab->per_beam_training_pkt_num = 1;
+				sat_tab->decision_holding_period = 6;
+				break;
+			default:
+				break;
+			}
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Fix_training_en = (( %d )), training_pkt_num_base = (( %d )), holding_period = ((%d))\n",
+			sat_tab->fix_training_num_en, sat_tab->per_beam_training_pkt_num, sat_tab->decision_holding_period);
+
+
+#ifdef CONFIG_FAT_PATCH
+		break_counter = 0;
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				per_beam_rssi_diff_tmp = sat_tab->beam_train_rssi_diff[i][j];
+				training_pkt_num_offset = per_beam_rssi_diff_tmp;
+
+				if ((sat_tab->per_beam_training_pkt_num) > training_pkt_num_offset)
+					sat_tab->beam_train_cnt[i][j] = sat_tab->per_beam_training_pkt_num - training_pkt_num_offset;
+				else
+					sat_tab->beam_train_cnt[i][j] = 1;
+
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ant[%d]: Beam_num-(( %d ))  training_pkt_num = ((%d))\n",
+					i,  j, sat_tab->beam_train_cnt[i][j]);
+			}
+			break_counter++;
+			if (break_counter >= (sat_tab->ant_num))
+				break;
+		}
+
+
+		phydm_fast_training_enable(dm, FAT_OFF);
+		sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+		sat_tab->update_beam_idx = 0;
+
+		if (*dm->band_type == ODM_BAND_5G) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Set 5G ant\n");
+			/*used_ant = (sat_tab->first_train_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;*/
+			used_ant = sat_tab->first_train_ant;
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Set 2.4G ant\n");
+			used_ant = sat_tab->first_train_ant;
+		}
+
+		odm_update_rx_idle_ant(dm, (u8)used_ant);
+
+#else
+		/* Set training MAC addr. of target */
+		odm_set_next_mac_addr_target(dm);
+		phydm_fast_training_enable(dm, FAT_ON);
+#endif
+
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		sat_tab->pkt_counter = 0;
+		sat_tab->fast_training_beam_num = 0;
+		phydm_set_all_ant_same_beam_num(dm);
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+phydm_beam_switch_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	sat_tab->pkt_skip_statistic_en = 1;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n", sat_tab->pkt_skip_statistic_en);
+
+	phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	/*odm_stall_execution(sat_tab->latch_time);*/
+	sat_tab->pkt_skip_statistic_en = 0;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n", sat_tab->pkt_skip_statistic_en, sat_tab->latch_time);
+}
+
+void
+phydm_beam_decision_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam decision Workitem Callback\n");
+	odm_fast_ant_training_hl_smart_antenna_type1(dm);
+}
+#endif
+
+
+#endif /*#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1*/
+
+
+#endif/*#ifdef CONFIG_HL_SMART_ANTENNA*/
+
+
+
+void
+phydm_smt_ant_config(
+	void		*dm_void
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant				*smtant_table = &dm->smtant_table;
+
+	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+	
+		dm->support_ability |= ODM_BB_SMT_ANT;
+		smtant_table->smt_ant_vendor = SMTANT_CUMITEK;
+		smtant_table->smt_ant_type = 1;
+		#if (RTL8822B_SUPPORT == 1)
+		dm->rfe_type = SMTANT_TMP_RFE_TYPE;
+		#endif
+	#elif (defined(CONFIG_HL_SMART_ANTENNA))
+	
+		dm->support_ability |= ODM_BB_SMT_ANT;
+		smtant_table->smt_ant_vendor = SMTANT_HON_BO;
+		
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		smtant_table->smt_ant_type = 1;
+		#endif
+		
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		smtant_table->smt_ant_type = 2;
+		#endif
+	#endif
+
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[SmtAnt Config] Vendor=((%d)), Smt_ant_type =((%d))\n",
+		smtant_table->smt_ant_vendor, smtant_table->smt_ant_type);
+}
+#endif
+
+
+void
+phydm_smt_ant_init(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_SMART_ANTENNA))
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant				*smtant_table = &dm->smtant_table;
+	
+	phydm_smt_ant_config(dm);
+	
+
+	if (smtant_table->smt_ant_vendor == SMTANT_CUMITEK) {
+		
+		#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+		#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			phydm_cumitek_smt_ant_init_8822b(dm);
+			/**/
+		}
+		#endif
+		
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
+			phydm_cumitek_smt_ant_init_8197f(dm);
+			/**/
+		}
+		#endif
+		#endif /*#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))*/
+		
+	} else if (smtant_table->smt_ant_vendor == SMTANT_HON_BO) {
+		#if (defined(CONFIG_HL_SMART_ANTENNA))
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		if (dm->support_ic_type == ODM_RTL8821) {
+			phydm_hl_smart_ant_type1_init_8821a(dm);
+			/**/
+		}
+		#endif
+		
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			phydm_hl_smart_ant_type2_init_8822b(dm);
+			/**/
+		}
+		#endif
+		#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+	}
+#endif	
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_smt_ant.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_smt_ant.h
new file mode 100644
index 000000000000..d2f88e16c77f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_smt_ant.h
@@ -0,0 +1,249 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMSMTANT_H__
+#define    __PHYDMSMTANT_H__
+
+/*#define SMT_ANT_VERSION	"1.1"*/ /*2017.03.13*/
+/*#define SMT_ANT_VERSION	"1.2"*/ /*2017.03.28*/
+#define SMT_ANT_VERSION	"2.0" /* Add Cumitek SmtAnt 2017.05.25*/
+
+#define	SMTANT_RTK		1
+#define	SMTANT_HON_BO	2
+#define	SMTANT_CUMITEK	3
+
+#if (defined(CONFIG_SMART_ANTENNA))
+
+
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+struct smt_ant_cumitek {
+	u8	tx_ant_idx[2][ODM_ASSOCIATE_ENTRY_NUM]; /*[pathA~B] [MACID 0~128]*/
+	u8	rx_default_ant_idx[2]; /*[pathA~B]*/
+};
+#endif
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+struct smt_ant_honbo {
+	u32	latch_time;
+	boolean	pkt_skip_statistic_en;
+	u32	fix_beam_pattern_en;
+	u32	fix_training_num_en;
+	u32	fix_beam_pattern_codeword;
+	u32	update_beam_codeword;
+	u32	ant_num; /*number of "used" smart beam antenna*/
+	u32	ant_num_total;/*number of "total" smart beam antenna*/
+	u32	first_train_ant; /*decide witch antenna to train first*/
+
+	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+	u32	pkt_rssi_pre[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];/*rssi of each path with a certain beam pattern*/
+	u8	beam_train_rssi_diff[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
+	u8	beam_train_cnt[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
+	u32	rfu_codeword_table[4]; /*2G beam truth table*/
+	u32	rfu_codeword_table_5g[4]; /*5G beam truth table*/
+	u32	beam_patten_num_each_ant;/*number of  beam can be switched in each antenna*/
+	u32	rx_idle_beam[SUPPORT_RF_PATH_NUM];
+	u32	pkt_rssi_sum[8][SUPPORT_BEAM_PATTERN_NUM];
+	u32	pkt_rssi_cnt[8][SUPPORT_BEAM_PATTERN_NUM];
+	#endif
+	
+	u32	fast_training_beam_num;/*current training beam_set index*/
+	u32	pre_fast_training_beam_num;/*pre training beam_set index*/
+	u32	rfu_codeword_total_bit_num; /* total bit number of RFU protocol*/
+	u32	rfu_each_ant_bit_num; /* bit number of RFU protocol for each ant*/
+	u8	per_beam_training_pkt_num;
+	u8	decision_holding_period;
+	
+	
+	u32	pre_codeword;
+	boolean	force_update_beam_en;
+	u32	beacon_counter;
+	u32	pre_beacon_counter;
+	u8	pkt_counter;		/*packet number that each beam-set should be colected in training state*/
+	u8	update_beam_idx;	/*the index announce that the beam can be updated*/
+	u8	rfu_protocol_type;
+	u16	rfu_protocol_delay_time;
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_WORK_ITEM	hl_smart_antenna_workitem;
+	RT_WORK_ITEM	hl_smart_antenna_decision_workitem;
+	#endif
+
+
+	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+	u8	beam_set_avg_rssi_pre[SUPPORT_BEAM_SET_PATTERN_NUM];		/*avg pre_rssi of each beam set*/
+	u8	beam_set_train_val_diff[SUPPORT_BEAM_SET_PATTERN_NUM];	/*rssi of a beam pattern set, ex: a set = {ant1_beam=1, ant2_beam=3}*/
+	u8	beam_set_train_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];			/*training pkt num of each beam set*/
+	u32	beam_set_rssi_avg_sum[SUPPORT_BEAM_SET_PATTERN_NUM];			/*RSSI_sum of avg(pathA,pathB) for each beam-set)*/
+	u32	beam_path_rssi_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*RSSI_sum of each path for each beam-set)*/
+
+	u8	beam_set_avg_evm_2ss_pre[SUPPORT_BEAM_SET_PATTERN_NUM];	
+	u32	beam_path_evm_2ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*2SS evm_sum of each path for each beam-set)*/
+	u32	beam_path_evm_2ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
+
+	u8	beam_set_avg_evm_1ss_pre[SUPPORT_BEAM_SET_PATTERN_NUM];
+	u32	beam_path_evm_1ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM];/*1SS evm_sum of each path for each beam-set)*/
+	u32	beam_path_evm_1ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
+	
+	u32	statistic_pkt_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];				/*statistic_pkt_cnt for SmtAnt make decision*/
+	
+	u8	total_beam_set_num;	/*number of  beam set can be switched*/
+	u8	total_beam_set_num_2g;/*number of  beam set can be switched in 2G*/
+	u8	total_beam_set_num_5g;/*number of  beam set can be switched in 5G*/
+
+	u8	rfu_codeword_table_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*2G beam truth table*/
+	u8	rfu_codeword_table_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*5G beam truth table*/
+	u8	rx_idle_beam_set_idx;	/*the filanl decsion result*/
+	#endif
+	
+
+};
+#endif /*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+
+struct smt_ant {
+	u8	smt_ant_vendor;
+	u8	smt_ant_type;
+	u8	tx_desc_mode; /*0:3 bit mode, 1:2 bit mode*/
+	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+	struct	smt_ant_cumitek	cumi_smtant_table;
+	#endif
+};
+
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+void
+phydm_cumitek_smt_tx_ant_update(
+	void		*dm_void,
+	u8		tx_ant_idx_path_a,
+	u8		tx_ant_idx_path_b,
+	u32		mac_id
+);
+
+void
+phydm_cumitek_smt_rx_default_ant_update(
+	void		*dm_void,
+	u8		rx_ant_idx_path_a,
+	u8		rx_ant_idx_path_b
+);
+
+void
+phydm_cumitek_smt_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
+
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_beam_switch_workitem_callback(
+	void	*context
+);
+
+void
+phydm_beam_decision_workitem_callback(
+	void	*context
+);
+#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+
+
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+void
+phydm_hl_smart_ant_type2_init_8822b(
+	void		*dm_void
+);
+
+void
+phydm_update_beam_pattern_type2(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+);
+
+void
+phydm_set_rfu_beam_pattern_type2(
+	void		*dm_void
+);
+
+void
+phydm_hl_smart_ant_debug_type2(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+void
+phydm_process_rssi_for_hb_smtant_type2(
+	void		*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void,
+	u8		rssi_avg	
+);
+
+#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE2))*/
+
+
+#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
+
+void
+phydm_update_beam_pattern(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+);
+
+void
+phydm_set_all_ant_same_beam_num(
+	void		*dm_void
+);
+
+void
+phydm_hl_smart_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))*/
+#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+#endif/*#if (defined(CONFIG_SMART_ANTENNA))*/
+
+void
+phydm_smt_ant_init(
+	void		*dm_void
+);
+
+#endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_soml.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_soml.c
new file mode 100644
index 000000000000..d4706eccd221
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_soml.c
@@ -0,0 +1,862 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_dynamicsoftmletting(
+	void		*dm_void
+)
+{
+	struct dm_struct            *dm = (struct dm_struct *)dm_void;
+	u32 ret_val;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (*dm->mp_mode == false) {
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			if ((!dm->is_linked)|(dm->iot_table.is_linked_cmw500))
+				return;
+
+			if (true == dm->bsomlenabled) {
+				PHYDM_DBG(dm, ODM_COMP_API, "PHYDM_DynamicSoftMLSetting(): SoML has been enable, skip dynamic SoML switch\n");
+				return; 		
+			}
+
+			ret_val = odm_get_bb_reg(dm, 0xf8c, MASKBYTE0);
+			PHYDM_DBG(dm, ODM_COMP_API, "PHYDM_DynamicSoftMLSetting(): Read 0xF8C = 0x%08X\n", ret_val);
+
+			if (ret_val < 0x16) {
+				PHYDM_DBG(dm, ODM_COMP_API, "PHYDM_DynamicSoftMLSetting(): 0xF8C(== 0x%08X) < 0x16, enable SoML\n", ret_val);
+				phydm_somlrxhp_setting(dm, true);
+				/*odm_set_bb_reg(dm, 0x19a8, MASKDWORD, 0xc10a0000);*/
+				dm->bsomlenabled = true;
+			}
+		}
+	}
+#endif
+
+}
+
+#ifdef CONFIG_ADAPTIVE_SOML
+void
+phydm_soml_on_off(
+	void		*dm_void,
+	u8		swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if (swch == SOML_ON) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "(( Turn on )) SOML\n");
+
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_somlrxhp_setting(dm, true);
+		else if (dm->support_ic_type == ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0x998, BIT(6), swch);
+
+	} else if (swch == SOML_OFF) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "(( Turn off )) SOML\n");
+
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_somlrxhp_setting(dm, false);
+		else if (dm->support_ic_type == ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0x998, BIT(6), swch);
+	}
+	dm_soml_table->soml_on_off = swch;
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_adaptive_soml_callback(
+	struct phydm_timer_list		*timer
+)
+{
+	void		*adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm_soml_table->phydm_adaptive_soml_workitem);
+#else
+	{
+		/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_callback\n");*/
+		phydm_adsl(dm);
+	}
+#endif
+#else
+	odm_schedule_work_item(&dm_soml_table->phydm_adaptive_soml_workitem);
+#endif
+}
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void		*context
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_workitem_callback\n");*/
+	phydm_adsl(dm);
+#endif
+}
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void
+phydm_adaptive_soml_callback(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	void	*padapter = dm->adapter;
+	if (*(dm->is_net_closed) == true)
+		return;
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_adsl(dm);
+	else {
+		/* Can't do I/O in timer callback*/
+		rtw_run_in_thread_cmd(padapter, phydm_adaptive_soml_workitem_callback, padapter);
+	}
+}
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void	*context
+)
+{
+	void *	adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->odmpriv;
+
+	/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_workitem_callback\n");*/
+	phydm_adsl(dm);
+}
+
+#else
+
+void
+phydm_adaptive_soml_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "******SOML_Callback******\n");
+	phydm_adsl(dm);
+
+}
+#endif
+
+void
+phydm_rx_qam_for_soml(
+	void		*dm_void,
+	void		*pkt_info_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml				*dm_soml_table = &dm->dm_soml_table;
+	struct phydm_perpkt_info_struct	*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	u8								date_rate = (pktinfo->data_rate & 0x7f);
+
+	if (dm_soml_table->soml_state_cnt < ((dm_soml_table->soml_train_num)<<1)) {
+		if (dm_soml_table->soml_on_off == SOML_ON)
+			return;
+		else if (dm_soml_table->soml_on_off == SOML_OFF) {
+			if ((date_rate >= ODM_RATEMCS8) && (date_rate <= ODM_RATEMCS10))
+				dm_soml_table->num_ht_qam[BPSK_QPSK]++;
+
+			else if ((date_rate >= ODM_RATEMCS11) && (date_rate <= ODM_RATEMCS12))
+				dm_soml_table->num_ht_qam[QAM16]++;
+
+			else if ((date_rate >= ODM_RATEMCS13) && (date_rate <= ODM_RATEMCS15))
+				dm_soml_table->num_ht_qam[QAM64]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS0) && (date_rate <= ODM_RATEVHTSS2MCS2))
+				dm_soml_table->num_vht_qam[BPSK_QPSK]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS3) && (date_rate <= ODM_RATEVHTSS2MCS4))
+				dm_soml_table->num_vht_qam[QAM16]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS5) && (date_rate <= ODM_RATEVHTSS2MCS5))
+				dm_soml_table->num_vht_qam[QAM64]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS8) && (date_rate <= ODM_RATEVHTSS2MCS9))
+				dm_soml_table->num_vht_qam[QAM256]++;
+		}
+	}
+}
+
+void
+phydm_soml_reset_rx_rate(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+	u8	order;
+
+	for (order = 0; order < HT_ORDER_TYPE; order++)
+		dm_soml_table->num_ht_qam[order] = 0;
+
+	for (order = 0; order < VHT_ORDER_TYPE; order++)
+		dm_soml_table->num_vht_qam[order] = 0;
+}
+
+void
+phydm_soml_cfo_process(
+	void		*dm_void,
+	s32		*diff_a,
+	s32		*diff_b
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+	u32	value32, value32_1, value32_2, value32_3;
+	s32	cfo_acq_a, cfo_acq_b, cfo_end_a, cfo_end_b;
+	s32	cfo_diff_a, cfo_diff_b;
+
+	value32 = odm_get_bb_reg(dm, 0xd10, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd14, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd50, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xd54, MASKDWORD);
+
+	cfo_acq_a = (s32)((value32 & 0x1fff0000) >> 16);
+	cfo_end_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+	cfo_acq_b = (s32)((value32_2 & 0x1fff0000) >> 16);
+	cfo_end_b = (s32)((value32_3 & 0x1fff0000) >> 16);
+
+	*diff_a = ((cfo_acq_a >= cfo_end_a) ? (cfo_acq_a - cfo_end_a) : (cfo_end_a - cfo_acq_a));
+	*diff_b = ((cfo_acq_b >= cfo_end_b) ? (cfo_acq_b - cfo_end_b) : (cfo_end_b - cfo_acq_b));
+
+	*diff_a =  ((*diff_a * 312) + (*diff_a >> 1)) >> 12;  /* 312.5/2^12 */
+	*diff_b = ((*diff_b * 312) + (*diff_b >> 1)) >> 12; /* 312.5/2^12 */
+
+}
+
+void
+phydm_soml_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm_value[0] == 1) { /*Turn on/off SOML*/
+		dm_soml_table->soml_select = (u8)dm_value[1];
+
+	} else if (dm_value[0] == 2) { /*training number for SOML*/
+
+		dm_soml_table->soml_train_num = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_train_num = ((%d))\n",
+			       dm_soml_table->soml_train_num);
+	} else if (dm_value[0] == 3) { /*training interval for SOML*/
+
+		dm_soml_table->soml_intvl = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_intvl = ((%d))\n",
+			       dm_soml_table->soml_intvl);
+	} else if (dm_value[0] == 4) { /*function period for SOML*/
+
+		dm_soml_table->soml_period = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_period = ((%d))\n",
+			       dm_soml_table->soml_period);
+	} else if (dm_value[0] == 5) { /*delay_time for SOML*/
+
+		dm_soml_table->soml_delay_time = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_delay_time = ((%d))\n",
+			       dm_soml_table->soml_delay_time);
+	} else if (dm_value[0] == 6) { /* for SOML Rx QAM distribution th*/
+		if (dm_value[1] == 256) {
+			dm_soml_table->qam256_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "qam256_dist_th = ((%d))\n",
+				       dm_soml_table->qam256_dist_th);
+		} else if (dm_value[1] == 64) {
+			dm_soml_table->qam64_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "qam64_dist_th = ((%d))\n",
+				       dm_soml_table->qam64_dist_th);
+		} else if (dm_value[1] == 16) {
+			dm_soml_table->qam16_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "qam16_dist_th = ((%d))\n",
+				       dm_soml_table->qam16_dist_th);
+		} else if (dm_value[1] == 4) {
+			dm_soml_table->bpsk_qpsk_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "bpsk_qpsk_dist_th = ((%d))\n",
+				       dm_soml_table->bpsk_qpsk_dist_th);
+		}
+	} else if (dm_value[0] == 7) { /* for SOML cfo th*/
+		if (dm_value[1] == 256) {
+			dm_soml_table->cfo_qam256_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qam256_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qam256_th);
+		} else if (dm_value[1] == 64) {
+			dm_soml_table->cfo_qam64_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qam64_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qam64_th);
+		} else if (dm_value[1] == 16) {
+			dm_soml_table->cfo_qam16_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qam16_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qam16_th);
+		} else if (dm_value[1] == 4) {
+			dm_soml_table->cfo_qpsk_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qpsk_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qpsk_th);
+		}
+	} else if (dm_value[0] == 100) { /*show parameters*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_select = ((%d))\n",
+			       dm_soml_table->soml_select);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_train_num = ((%d))\n",
+			       dm_soml_table->soml_train_num);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_intvl = ((%d))\n",
+			       dm_soml_table->soml_intvl);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_period = ((%d))\n",
+			       dm_soml_table->soml_period);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_delay_time = ((%d))\n\n",
+			       dm_soml_table->soml_delay_time);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "qam256_dist_th = ((%d)),  qam64_dist_th = ((%d)), ",
+			       dm_soml_table->qam256_dist_th,
+			       dm_soml_table->qam64_dist_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "qam16_dist_th = ((%d)),  bpsk_qpsk_dist_th = ((%d))\n",
+			       dm_soml_table->qam16_dist_th,
+			       dm_soml_table->bpsk_qpsk_dist_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "cfo_qam256_th = ((%d KHz)),  cfo_qam64_th = ((%d KHz)), ",
+			       dm_soml_table->cfo_qam256_th,
+			       dm_soml_table->cfo_qam64_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "cfo_qam16_th = ((%d KHz)),  cfo_qpsk_th  = ((%d KHz))\n",
+			       dm_soml_table->cfo_qam16_th,
+			       dm_soml_table->cfo_qpsk_th);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_soml_statistics(
+	void		*dm_void,
+	u8		on_off_state
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	u8	i;
+	u32	num_bytes_diff;
+
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (on_off_state == SOML_ON) {
+			for (i = 0; i < HT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_ht_bytes[i] - dm_soml_table->pre_num_ht_bytes[i];
+				dm_soml_table->num_ht_bytes_on[i] += num_bytes_diff;
+				dm_soml_table->pre_num_ht_bytes[i] = dm_soml_table->num_ht_bytes[i];
+			}
+		} else if (on_off_state == SOML_OFF) {
+			for (i = 0; i < HT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_ht_bytes[i] - dm_soml_table->pre_num_ht_bytes[i];
+				dm_soml_table->num_ht_bytes_off[i] += num_bytes_diff;
+				dm_soml_table->pre_num_ht_bytes[i] = dm_soml_table->num_ht_bytes[i];
+			}
+		}
+	} else if (dm->support_ic_type == ODM_RTL8822B) {
+		if (on_off_state == SOML_ON) {
+			for (i = 0; i < VHT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_vht_bytes[i] - dm_soml_table->pre_num_vht_bytes[i];
+				dm_soml_table->num_vht_bytes_on[i] += num_bytes_diff;
+				dm_soml_table->pre_num_vht_bytes[i] = dm_soml_table->num_vht_bytes[i];
+			}
+		} else if (on_off_state == SOML_OFF) {
+			for (i = 0; i < VHT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_vht_bytes[i] - dm_soml_table->pre_num_vht_bytes[i];
+				dm_soml_table->num_vht_bytes_off[i] += num_bytes_diff;
+				dm_soml_table->pre_num_vht_bytes[i] = dm_soml_table->num_vht_bytes[i];
+			}
+		}
+	}
+}
+
+void
+phydm_adsl(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml		*dm_soml_table = &dm->dm_soml_table;
+
+	u8	i;
+	u8	next_on_off;
+	u8	rate_num = 1, rate_ss_shift = 0;
+	u32	byte_total_on = 0, byte_total_off = 0, num_total_qam = 0;
+	u32	ht_reset[HT_RATE_IDX] = {0}, vht_reset[VHT_RATE_IDX] = {0};
+	u8	size = sizeof(ht_reset[0]);
+
+	if (dm->support_ic_type & ODM_IC_4SS)
+		rate_num = 4;
+	else if (dm->support_ic_type & ODM_IC_3SS)
+		rate_num = 3;
+	else if (dm->support_ic_type & ODM_IC_2SS)
+		rate_num = 2;
+
+	if ((dm->support_ic_type & ODM_ADAPTIVE_SOML_SUPPORT_IC)) {
+		if (TRUE) {
+			if ((dm->rssi_min >= SOML_RSSI_TH_HIGH) || (dm_soml_table->is_soml_method_enable == 1)) {
+				PHYDM_DBG(dm, DBG_ADPTV_SOML, "> TH_H || is_soml_method_enable==1\n");
+				PHYDM_DBG(dm, DBG_ADPTV_SOML, "soml_state_cnt =((%d)),  soml_on_off =((%s))\n", dm_soml_table->soml_state_cnt, (dm_soml_table->soml_on_off == SOML_ON) ? "SOML_ON" : "SOML_OFF");
+				/*Traning state: 0(alt) 1(ori) 2(alt) 3(ori)============================================================*/
+				if (dm_soml_table->soml_state_cnt < ((dm_soml_table->soml_train_num)<<1)) {
+					if (dm_soml_table->soml_state_cnt == 0) {
+						if (dm->support_ic_type == ODM_RTL8197F) {
+							odm_move_memory(dm, dm_soml_table->num_ht_bytes, ht_reset, HT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_ht_bytes_on, ht_reset, HT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_ht_bytes_off, ht_reset, HT_RATE_IDX*size);
+						} else if (dm->support_ic_type == ODM_RTL8822B) {
+							odm_move_memory(dm, dm_soml_table->num_vht_bytes, vht_reset, VHT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_vht_bytes_on, vht_reset, VHT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_vht_bytes_off, vht_reset, VHT_RATE_IDX*size);
+							dm_soml_table->cfo_counter++;
+							phydm_soml_cfo_process(dm,
+									       &dm_soml_table->cfo_diff_a,
+									       &dm_soml_table->cfo_diff_b);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n", dm_soml_table->cfo_counter, dm_soml_table->cfo_diff_a, dm_soml_table->cfo_diff_b);
+							dm_soml_table->cfo_diff_sum_a += dm_soml_table->cfo_diff_a;
+							dm_soml_table->cfo_diff_sum_b += dm_soml_table->cfo_diff_b;
+						}
+
+						dm_soml_table->is_soml_method_enable = 1;
+						dm_soml_table->soml_state_cnt++;
+						next_on_off = (dm_soml_table->soml_on_off == SOML_ON) ? SOML_ON : SOML_OFF;
+						phydm_soml_on_off(dm, next_on_off);
+						odm_set_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer, dm_soml_table->soml_delay_time); /*ms*/
+					} else if ((dm_soml_table->soml_state_cnt % 2) != 0) {
+						dm_soml_table->soml_state_cnt++;
+						if (dm->support_ic_type == ODM_RTL8197F)
+							odm_move_memory(dm, dm_soml_table->pre_num_ht_bytes, dm_soml_table->num_ht_bytes, HT_RATE_IDX*size);
+						else if (dm->support_ic_type == ODM_RTL8822B) {
+							odm_move_memory(dm, dm_soml_table->pre_num_vht_bytes, dm_soml_table->num_vht_bytes, VHT_RATE_IDX*size);
+							dm_soml_table->cfo_counter++;
+							phydm_soml_cfo_process(dm,
+									       &dm_soml_table->cfo_diff_a,
+									       &dm_soml_table->cfo_diff_b);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n", dm_soml_table->cfo_counter, dm_soml_table->cfo_diff_a, dm_soml_table->cfo_diff_b);
+							dm_soml_table->cfo_diff_sum_a += dm_soml_table->cfo_diff_a;
+							dm_soml_table->cfo_diff_sum_b += dm_soml_table->cfo_diff_b;
+						}
+						odm_set_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer, dm_soml_table->soml_intvl); /*ms*/
+					} else if ((dm_soml_table->soml_state_cnt % 2) == 0) {
+						if (dm->support_ic_type == ODM_RTL8822B) {
+							dm_soml_table->cfo_counter++;
+							phydm_soml_cfo_process(dm,
+									       &dm_soml_table->cfo_diff_a,
+									       &dm_soml_table->cfo_diff_b);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n", dm_soml_table->cfo_counter, dm_soml_table->cfo_diff_a, dm_soml_table->cfo_diff_b);
+							dm_soml_table->cfo_diff_sum_a += dm_soml_table->cfo_diff_a;
+							dm_soml_table->cfo_diff_sum_b += dm_soml_table->cfo_diff_b;
+						}
+						dm_soml_table->soml_state_cnt++;
+						phydm_soml_statistics(dm, dm_soml_table->soml_on_off);
+						next_on_off = (dm_soml_table->soml_on_off == SOML_ON) ? SOML_OFF : SOML_ON;
+						phydm_soml_on_off(dm, next_on_off);
+						odm_set_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer, dm_soml_table->soml_delay_time); /*ms*/
+					}
+				}
+				/*Decision state: ==============================================================*/
+				else {
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[Decisoin state ]\n");
+					phydm_soml_statistics(dm, dm_soml_table->soml_on_off);
+					dm_soml_table->cfo_diff_avg_a = (dm_soml_table->cfo_counter != 0) ? (dm_soml_table->cfo_diff_sum_a  / dm_soml_table->cfo_counter) : 0;
+					dm_soml_table->cfo_diff_avg_b = (dm_soml_table->cfo_counter != 0) ? (dm_soml_table->cfo_diff_sum_b / dm_soml_table->cfo_counter) : 0;
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ cfo_diff_avg_a = %d KHz; cfo_diff_avg_b = %d KHz]\n", dm_soml_table->cfo_diff_avg_a, dm_soml_table->cfo_diff_avg_b);
+
+					/* [Search 1st and 2ed rate by counter] */
+					if (dm->support_ic_type == ODM_RTL8197F) {
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = (i << 3);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "*num_ht_bytes_on  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+								(rate_ss_shift), (rate_ss_shift+7),
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 0], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 1],
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 2], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 3],
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 4], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 5],
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 6], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 7]);
+						}
+
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = (i << 3);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "*num_ht_bytes_off  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+								(rate_ss_shift), (rate_ss_shift+7),
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 0], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 1],
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 2], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 3],
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 4], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 5],
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 6], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 7]);
+						}
+
+						for (i = 0; i < HT_RATE_IDX; i++) {
+							byte_total_on += dm_soml_table->num_ht_bytes_on[i];
+							byte_total_off += dm_soml_table->num_ht_bytes_off[i];
+						}
+
+					} else if (dm->support_ic_type == ODM_RTL8822B) {
+						for (i = 0; i < VHT_ORDER_TYPE; i++)
+							num_total_qam += dm_soml_table->num_vht_qam[i];
+
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ ((2SS)) BPSK_QPSK_count = %d ; 16QAM_count = %d ; 64QAM_count = %d ; 256QAM_count = %d ; num_total_qam = %d]\n", dm_soml_table->num_vht_qam[BPSK_QPSK], dm_soml_table->num_vht_qam[QAM16], dm_soml_table->num_vht_qam[QAM64], dm_soml_table->num_vht_qam[QAM256], num_total_qam);
+						if (((dm_soml_table->num_vht_qam[QAM256] * 100) > (num_total_qam * dm_soml_table->qam256_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qam256_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qam256_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  QAM256_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->qam256_dist_th, dm_soml_table->cfo_qam256_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						} else if (((dm_soml_table->num_vht_qam[QAM64] * 100) > (num_total_qam * dm_soml_table->qam64_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qam64_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qam64_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  QAM64_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->qam64_dist_th, dm_soml_table->cfo_qam64_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						} else if (((dm_soml_table->num_vht_qam[QAM16] * 100) > (num_total_qam * dm_soml_table->qam16_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qam16_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qam16_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  QAM16_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->qam16_dist_th, dm_soml_table->cfo_qam16_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						} else if (((dm_soml_table->num_vht_qam[BPSK_QPSK] * 100) > (num_total_qam * dm_soml_table->bpsk_qpsk_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qpsk_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qpsk_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  BPSK_QPSK_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->bpsk_qpsk_dist_th, dm_soml_table->cfo_qpsk_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						}
+
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = 10 * i;
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  num_vht_bytes_on  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d} ]\n",
+								(i + 1),
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 0], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 1],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 2], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 3],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 4], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 5],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 6], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 7],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 8], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 9]);
+						}
+
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = 10 * i;
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  num_vht_bytes_off  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d} ]\n",
+								(i + 1),
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 0], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 1],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 2], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 3],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 4], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 5],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 6], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 7],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 8], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 9]);
+						}
+
+						for (i = 0; i < VHT_RATE_IDX; i++) {
+							byte_total_on += dm_soml_table->num_vht_bytes_on[i];
+							byte_total_off += dm_soml_table->num_vht_bytes_off[i];
+						}
+
+					}
+
+					/* [Decision] */
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  byte_total_on = %d ; byte_total_off = %d ]\n", byte_total_on, byte_total_off);
+					if (byte_total_on > byte_total_off) {
+						next_on_off = SOML_ON;
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ byte_total_on > byte_total_off ==> SOML_ON ]\n");
+					} else if (byte_total_on < byte_total_off) {
+						next_on_off = SOML_OFF;
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ byte_total_on < byte_total_off ==> SOML_OFF ]\n");
+					} else {
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ stay at soml_last_state ]\n");
+						next_on_off = dm_soml_table->soml_last_state;
+					}
+
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+					phydm_soml_on_off(dm, next_on_off);
+					dm_soml_table->soml_last_state = next_on_off;
+				}
+			} else {
+				PHYDM_DBG(dm, DBG_ADPTV_SOML, "[escape from > TH_H || is_soml_method_enable==1]\n");
+				phydm_adaptive_soml_reset(dm);
+				phydm_soml_on_off(dm, SOML_ON);
+			}
+		} else {
+			PHYDM_DBG(dm, DBG_ADPTV_SOML, "[number_active_client != 1]\n");
+			phydm_adaptive_soml_reset(dm);
+			phydm_soml_on_off(dm, SOML_OFF);
+		}
+	}
+}
+
+void
+phydm_adaptive_soml_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	dm_soml_table->soml_state_cnt = 0;
+	dm_soml_table->is_soml_method_enable = 0;
+	dm_soml_table->soml_counter = 0;
+}
+
+#endif /* end of CONFIG_ADAPTIVE_SOML*/
+
+void
+phydm_soml_bytes_acq(
+	void		*dm_void,
+	u8		rate_id,
+	u32		length
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if ((rate_id >= ODM_RATEMCS0) && (rate_id <= ODM_RATEMCS31))
+		dm_soml_table->num_ht_bytes[rate_id - ODM_RATEMCS0] += length;
+	else if ((rate_id >= ODM_RATEVHTSS1MCS0) && (rate_id <= ODM_RATEVHTSS4MCS9))
+		dm_soml_table->num_vht_bytes[rate_id - ODM_RATEVHTSS1MCS0] += length;
+
+#endif
+}
+
+void
+phydm_adaptive_soml_timers(
+	void		*dm_void,
+	u8		state
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if (state == INIT_SOML_TIMMER) {
+		odm_initialize_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer,
+			(void *)phydm_adaptive_soml_callback, NULL, "phydm_adaptive_soml_timer");
+	} else if (state == CANCEL_SOML_TIMMER) {
+		odm_cancel_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer);
+	} else if (state == RELEASE_SOML_TIMMER) {
+		odm_release_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer);
+	}
+#endif
+}
+
+void
+phydm_adaptive_soml_init(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+#if 0
+	if (!(dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[Return]   Not Support Adaptive SOML\n");
+		return;
+	}
+#endif
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "phydm_adaptive_soml_init\n");
+
+	dm_soml_table->soml_state_cnt = 0;
+	dm_soml_table->soml_delay_time = 40;
+	dm_soml_table->soml_intvl = 150;
+	dm_soml_table->soml_train_num = 4;
+	dm_soml_table->is_soml_method_enable = 0;
+	dm_soml_table->soml_counter = 0;
+	dm_soml_table->soml_period = 1;
+	dm_soml_table->soml_select = 0;
+	dm_soml_table->cfo_counter = 0;
+	dm_soml_table->cfo_diff_sum_a = 0;
+	dm_soml_table->cfo_diff_sum_b = 0;
+
+	dm_soml_table->cfo_qpsk_th = 94;
+	dm_soml_table->cfo_qam16_th  = 38;
+	dm_soml_table->cfo_qam64_th = 17;
+	dm_soml_table->cfo_qam256_th = 7;
+
+	dm_soml_table->bpsk_qpsk_dist_th = 20;
+	dm_soml_table->qam16_dist_th = 20;
+	dm_soml_table->qam64_dist_th = 20;
+	dm_soml_table->qam256_dist_th = 20;
+
+	if (dm->support_ic_type == ODM_RTL8197F)
+		odm_set_bb_reg(dm, 0x998, BIT(25), 1);
+#endif
+}
+
+void
+phydm_adaptive_soml(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			"[Return!!!]   Not Support Adaptive SOML Function\n");
+		return;
+	}
+
+	if (dm_soml_table->soml_counter <  dm_soml_table->soml_period) {
+		dm_soml_table->soml_counter++;
+		return;
+	}
+	dm_soml_table->soml_counter = 0;
+	dm_soml_table->soml_state_cnt = 0;
+	dm_soml_table->cfo_counter = 0;
+	dm_soml_table->cfo_diff_sum_a = 0;
+	dm_soml_table->cfo_diff_sum_b = 0;
+
+	phydm_soml_reset_rx_rate(dm);
+
+	if (dm_soml_table->soml_select == 0) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Adaptive SOML Training !!!]\n");
+	} else if (dm_soml_table->soml_select == 1) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Stop Adaptive SOML !!!]\n");
+		phydm_soml_on_off(dm, SOML_ON);
+		return;
+	} else if (dm_soml_table->soml_select == 2) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Stop Adaptive SOML !!!]\n");
+		phydm_soml_on_off(dm, SOML_OFF);
+		return;
+	}
+
+	phydm_adsl(dm);
+
+#endif
+}
+
+void
+phydm_enable_adaptive_soml(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[%s][Return!!!]  enable Adaptive SOML\n", __func__);
+	dm->support_ability |= ODM_BB_ADAPTIVE_SOML;
+	phydm_soml_on_off(dm, SOML_ON);
+#endif
+}
+
+void
+phydm_stop_adaptive_soml(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[%s][Return!!!]  Stop Adaptive SOML\n", __func__);
+	dm->support_ability &= ~ODM_BB_ADAPTIVE_SOML;
+	phydm_soml_on_off(dm, SOML_ON);
+	
+#endif
+}
+
+void
+phydm_adaptive_soml_para_set(
+	void		*dm_void,
+	u8		train_num,
+	u8		intvl,
+	u8		period,
+	u8		delay_time
+	
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	dm_soml_table->soml_train_num = train_num;
+	dm_soml_table->soml_intvl = intvl;
+	dm_soml_table->soml_period = period;
+	dm_soml_table->soml_delay_time = delay_time;
+#endif
+}
+
+void
+phydm_init_soft_ml_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+#if (RTL8822B_SUPPORT == 1)
+	if (*dm->mp_mode == false) {
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			/*odm_set_bb_reg(dm, 0x19a8, MASKDWORD, 0xd10a0000);*/
+			phydm_somlrxhp_setting(dm, true);
+			dm->bsomlenabled = true;
+		}
+	}
+#endif
+#if (RTL8821C_SUPPORT == 1)
+	if (*dm->mp_mode == false) {
+		if (dm->support_ic_type & ODM_RTL8821C)
+			odm_set_bb_reg(dm, 0x19a8, BIT(31)|BIT(30)|BIT(29)|BIT(28), 0xd);
+	}
+#endif
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_soml.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_soml.h
new file mode 100644
index 000000000000..7f3c1fb5d10f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_soml.h
@@ -0,0 +1,254 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef	__PHYDMSOML_H__
+#define    __PHYDMSOML_H__
+
+#define ADAPTIVE_SOML_VERSION	"1.0"
+
+#define ODM_ADAPTIVE_SOML_SUPPORT_IC	(ODM_RTL8822B | ODM_RTL8197F)
+
+#define INIT_SOML_TIMMER			0
+#define CANCEL_SOML_TIMMER			1
+#define RELEASE_SOML_TIMMER		2
+
+#define SOML_RSSI_TH_HIGH	25
+#define SOML_RSSI_TH_LOW	20
+
+#define HT_RATE_IDX			32
+#define VHT_RATE_IDX		40
+
+#define HT_ORDER_TYPE		3
+#define VHT_ORDER_TYPE		4
+
+/*
+#define CFO_QPSK_TH			20
+#define CFO_QAM16_TH		20
+#define CFO_QAM64_TH		20
+#define CFO_QAM256_TH		20
+
+#define BPSK_QPSK_DIST		20
+#define QAM16_DIST			30
+#define QAM64_DIST			30
+#define QAM256_DIST			20
+*/
+#define HT_TYPE		1
+#define VHT_TYPE		2
+
+#define SOML_ON		1
+#define SOML_OFF		0
+
+#ifdef CONFIG_ADAPTIVE_SOML
+
+struct adaptive_soml {
+	boolean		is_soml_method_enable;
+	u8			soml_on_off;
+	u8			soml_state_cnt;
+	u8			soml_delay_time;
+	u8			soml_intvl;
+	u8			soml_train_num;
+	u8			soml_counter;
+	u8			soml_period;
+	u8			soml_select;
+	u8			soml_last_state;
+	u8			cfo_qpsk_th;
+	u8			cfo_qam16_th;
+	u8			cfo_qam64_th;
+	u8			cfo_qam256_th;
+	u8			bpsk_qpsk_dist_th;
+	u8			qam16_dist_th;
+	u8			qam64_dist_th;
+	u8			qam256_dist_th;
+	u8			cfo_counter;
+	s32			cfo_diff_a;
+	s32			cfo_diff_b;
+	s32			cfo_diff_sum_a;
+	s32			cfo_diff_sum_b;
+	s32			cfo_diff_avg_a;
+	s32			cfo_diff_avg_b;
+	u32			num_ht_qam[HT_ORDER_TYPE];
+	u32			num_ht_bytes[HT_RATE_IDX];
+	u32			pre_num_ht_bytes[HT_RATE_IDX];
+	u32			num_ht_bytes_on[HT_RATE_IDX];
+	u32			num_ht_bytes_off[HT_RATE_IDX];
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+	u32			num_vht_qam[VHT_ORDER_TYPE];
+	u32			num_qry_mu_vht_pkt[VHT_RATE_IDX];
+	u32			num_vht_bytes[VHT_RATE_IDX];
+	u32			pre_num_vht_bytes[VHT_RATE_IDX];
+	u32			num_vht_bytes_on[VHT_RATE_IDX];
+	u32			num_vht_bytes_off[VHT_RATE_IDX];
+	#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	phydm_adaptive_soml_workitem;
+#endif
+#endif
+	struct phydm_timer_list		phydm_adaptive_soml_timer;
+
+};
+
+enum qam_order {
+	BPSK_QPSK	= 0,
+	QAM16		= 1,
+	QAM64		= 2,
+	QAM256		= 3
+};
+
+void
+phydm_dynamicsoftmletting(
+	void		*dm_void
+);
+
+void
+phydm_soml_on_off(
+	void		*dm_void,
+	u8		swch
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_adaptive_soml_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void		*context
+);
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void
+phydm_adaptive_soml_callback(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void		*context
+);
+
+#else
+void
+phydm_adaptive_soml_callback(
+	void		*dm_void
+);
+
+#endif
+
+void
+phydm_rx_qam_for_soml(
+	void		*dm_void,
+	void		*pkt_info_void
+);
+
+void
+phydm_soml_reset_rx_rate(
+	void		*dm_void
+);
+
+void
+phydm_soml_cfo_process(
+	void		*dm_void,
+	s32		*diff_a,
+	s32		*diff_b
+);
+
+void
+phydm_soml_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+void
+phydm_soml_statistics(
+	void		*dm_void,
+	u8		on_off_state
+
+);
+
+void
+phydm_adsl(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml_reset(
+	void		*dm_void
+);
+
+#endif
+void
+phydm_soml_bytes_acq(
+	void		*dm_void,
+	u8		rate_id,
+	u32		length
+);
+
+void
+phydm_adaptive_soml_timers(
+	void		*dm_void,
+	u8		state
+);
+
+void
+phydm_adaptive_soml_init(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml(
+	void		*dm_void
+);
+
+void
+phydm_enable_adaptive_soml(
+	void		*dm_void
+);
+
+void
+phydm_stop_adaptive_soml(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml_para_set(
+	void		*dm_void,
+	u8		train_num,
+	u8		intvl,
+	u8		period,
+	u8		delay_time
+	
+);
+
+void
+phydm_init_soft_ml_setting(
+	void		*dm_void
+);
+
+#endif /*#ifndef	__PHYDMSOML_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_types.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_types.h
new file mode 100644
index 000000000000..d1248e44ccdc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/phydm_types.h
@@ -0,0 +1,260 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __ODM_TYPES_H__
+#define __ODM_TYPES_H__
+
+
+/*Define Different SW team support*/
+#define	ODM_AP			0x01	/*BIT(0)*/
+#define	ODM_CE			0x04	/*BIT(2)*/
+#define	ODM_WIN		0x08	/*BIT(3)*/
+#define	ODM_ADSL		0x10	/*BIT(4)*/		/*already combine with ODM_AP, and is nouse now*/
+#define	ODM_IOT		0x20	/*BIT(5)*/
+
+/*For FW API*/
+#define	__iram_odm_func__
+
+/*Deifne HW endian support*/
+#define	ODM_ENDIAN_BIG	0
+#define	ODM_ENDIAN_LITTLE	1
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&(GET_HAL_DATA(__padapter))->DM_OutSrc))
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&(GET_HAL_DATA(__padapter))->odmpriv))
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&__padapter->pshare->_dmODM))
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
+	#define	RT_PCI_INTERFACE				1
+	#define	RT_USB_INTERFACE				2
+	#define	RT_SDIO_INTERFACE				3
+#endif
+
+enum hal_status {
+	HAL_STATUS_SUCCESS,
+	HAL_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,*/
+};
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
+
+#define		VISTA_USB_RX_REVISE			0
+
+/*
+ * Declare for ODM spin lock defintion temporarily fro compile pass.
+ *   */
+enum rt_spinlock_type {
+	RT_TX_SPINLOCK = 1,
+	RT_RX_SPINLOCK = 2,
+	RT_RM_SPINLOCK = 3,
+	RT_CAM_SPINLOCK = 4,
+	RT_SCAN_SPINLOCK = 5,
+	RT_LOG_SPINLOCK = 7,
+	RT_BW_SPINLOCK = 8,
+	RT_CHNLOP_SPINLOCK = 9,
+	RT_RF_OPERATE_SPINLOCK = 10,
+	RT_INITIAL_SPINLOCK = 11,
+	RT_RF_STATE_SPINLOCK = 12, /* For RF state. Added by Bruce, 2007-10-30. */
+#if VISTA_USB_RX_REVISE
+	RT_USBRX_CONTEXT_SPINLOCK = 13,
+	RT_USBRX_POSTPROC_SPINLOCK = 14, /* protect data of adapter->IndicateW/ IndicateR */
+#endif
+	/* Shall we define Ndis 6.2 SpinLock Here ? */
+	RT_PORT_SPINLOCK = 16,
+	RT_VNIC_SPINLOCK = 17,
+	RT_HVL_SPINLOCK = 18,
+	RT_H2C_SPINLOCK = 20, /* For H2C cmd. Added by tynli. 2009.11.09. */
+
+	rt_bt_data_spinlock = 25,
+
+	RT_WAPI_OPTION_SPINLOCK = 26,
+	RT_WAPI_RX_SPINLOCK = 27,
+
+	/* add for 92D CCK control issue */
+	RT_CCK_PAGEA_SPINLOCK = 28,
+	RT_BUFFER_SPINLOCK = 29,
+	RT_CHANNEL_AND_BANDWIDTH_SPINLOCK = 30,
+	RT_GEN_TEMP_BUF_SPINLOCK = 31,
+	RT_AWB_SPINLOCK = 32,
+	RT_FW_PS_SPINLOCK = 33,
+	RT_HW_TIMER_SPIN_LOCK = 34,
+	RT_MPT_WI_SPINLOCK = 35,
+	RT_P2P_SPIN_LOCK = 36,	/* Protect P2P context */
+	RT_DBG_SPIN_LOCK = 37,
+	RT_IQK_SPINLOCK = 38,
+	RT_PENDED_OID_SPINLOCK = 39,
+	RT_CHNLLIST_SPINLOCK = 40,
+	RT_INDIC_SPINLOCK = 41,	/* protect indication */
+	RT_RFD_SPINLOCK = 42,
+	RT_SYNC_IO_CNT_SPINLOCK = 43,
+	RT_LAST_SPINLOCK,
+};
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define sta_info 	_RT_WLAN_STA
+	#define	__func__		__FUNCTION__
+	#define	PHYDM_TESTCHIP_SUPPORT	TESTCHIP_SUPPORT
+	#define MASKH3BYTES			0xffffff00
+	#define SUCCESS	0
+	#define FAIL	(-1)
+
+	#define	u8 		u1Byte
+	#define	s8 		s1Byte
+
+	#define	u16		u2Byte
+	#define	s16		s2Byte
+
+	#define	u32 	u4Byte
+	#define	s32 		s4Byte
+
+	#define	u64		u8Byte
+	#define	s64		s8Byte
+
+	#define	phydm_timer_list	_RT_TIMER
+	
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#include "../typedef.h"
+
+	#ifdef CONFIG_PCI_HCI
+		#define DEV_BUS_TYPE		RT_PCI_INTERFACE
+	#endif
+
+	#if (defined(TESTCHIP_SUPPORT))
+		#define	PHYDM_TESTCHIP_SUPPORT 1
+	#else
+		#define	PHYDM_TESTCHIP_SUPPORT 0
+	#endif
+
+	#define	sta_info stat_info
+	#define	boolean	bool
+
+	#define	phydm_timer_list	timer_list
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+
+	#include <asm/byteorder.h>
+
+	#define DEV_BUS_TYPE	RT_PCI_INTERFACE
+
+	#if defined(__LITTLE_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_LITTLE
+	#elif defined(__BIG_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_BIG
+	#else
+		#error
+	#endif
+
+	/* define useless flag to avoid compile warning */
+	#define	USE_WORKITEM 0
+	#define	FOR_BRAZIL_PRETEST 0
+	#define	FPGA_TWO_MAC_VERIFICATION	0
+	#define	RTL8881A_SUPPORT	0
+	#define	PHYDM_TESTCHIP_SUPPORT 0
+
+
+	#define RATE_ADAPTIVE_SUPPORT			0
+	#define POWER_TRAINING_ACTIVE			0
+
+	#define sta_info	rtl_sta_info
+	#define	boolean		bool
+	#define	phydm_timer_list	rtw_timer_list
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#include <drv_types.h>
+
+	#ifdef CONFIG_USB_HCI
+		#define DEV_BUS_TYPE	RT_USB_INTERFACE
+	#elif defined(CONFIG_PCI_HCI)
+		#define DEV_BUS_TYPE	RT_PCI_INTERFACE
+	#elif defined(CONFIG_SDIO_HCI)
+		#define DEV_BUS_TYPE	RT_SDIO_INTERFACE
+	#elif defined(CONFIG_GSPI_HCI)
+		#define DEV_BUS_TYPE	RT_SDIO_INTERFACE
+	#endif
+
+
+	#if defined(CONFIG_LITTLE_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_LITTLE
+	#elif defined (CONFIG_BIG_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_BIG
+	#endif
+
+	#define	boolean	bool
+
+	#define SET_TX_DESC_ANTSEL_A_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+8, 24, 1, __value)
+	#define SET_TX_DESC_ANTSEL_B_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+8, 25, 1, __value)
+	#define SET_TX_DESC_ANTSEL_C_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+28, 29, 1, __value)
+
+	/* define useless flag to avoid compile warning */
+	#define	USE_WORKITEM 0
+	#define	FOR_BRAZIL_PRETEST 0
+	#define	FPGA_TWO_MAC_VERIFICATION	0
+	#define	RTL8881A_SUPPORT	0
+
+	#if (defined(TESTCHIP_SUPPORT))
+		#define	PHYDM_TESTCHIP_SUPPORT 1
+	#else
+		#define	PHYDM_TESTCHIP_SUPPORT 0
+	#endif
+
+	#define	phydm_timer_list	rtw_timer_list
+#endif
+
+#define READ_NEXT_PAIR(v1, v2, i) do { if (i+2 >= array_len) break; i += 2; v1 = array[i]; v2 = array[i+1]; } while (0)
+#define COND_ELSE  2
+#define COND_ENDIF 3
+
+#define	MASKBYTE0		0xff
+#define	MASKBYTE1		0xff00
+#define	MASKBYTE2		0xff0000
+#define	MASKBYTE3		0xff000000
+#define	MASKHWORD		0xffff0000
+#define	MASKLWORD		0x0000ffff
+#define	MASKDWORD		0xffffffff
+#define	MASK7BITS		0x7f
+#define	MASK12BITS		0xfff
+#define	MASKH4BITS		0xf0000000
+#define	MASK20BITS		0xfffff
+#define	MASKOFDM_D		0xffc00000
+#define	MASKCCK			0x3f3f3f3f
+#define RFREGOFFSETMASK	0xfffff
+#define MASKH3BYTES		0xffffff00
+#define MASKL3BYTES		0x00ffffff
+#define MASKBYTE2HIGHNIBBLE		0x00f00000
+#define MASKBYTE3LOWNIBBLE		0x0f000000
+#define	MASKL3BYTES			0x00ffffff
+#define RFREGOFFSETMASK	0xfffff
+
+#endif /* __ODM_TYPES_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_bb.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_bb.c
new file mode 100644
index 000000000000..9c7369624415
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_bb.c
@@ -0,0 +1,12062 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: R3 1.0*/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8822B_SUPPORT == 1)
+static boolean
+check_positive(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2,
+	const u32	condition3,
+	const u32	condition4
+)
+{
+	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
+
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
+
+	u32	driver1 = cut_version_for_para << 24 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
+			pkg_type_for_para << 12 |
+			(dm->support_interface & 0x0F) << 8  |
+			dm->rfe_type;
+
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
+
+	u32	driver3 = 0;
+
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Platform, Interface) = (0x%X, 0x%X)\n", dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(RFE, Package) = (0x%X, 0x%X)\n", dm->rfe_type, dm->package_type);
+
+
+	/*============== value Defined Check ===============*/
+	/*cut version [27:24] need to do value check*/
+	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
+		return false;
+
+	/*pkg type [15:12] need to do value check*/
+	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
+		return false;
+
+	/*interface [11:8] need to do value check*/
+	if (((cond1 & 0x00000F00) != 0) && ((cond1 & 0x00000F00) != (driver1 & 0x00000F00)))
+		return false;
+	/*=============== Bit Defined Check ================*/
+	/* We don't care [31:28] */
+
+	cond1 &= 0x000000FF;
+	driver1 &= 0x000000FF;
+
+	if (cond1 == driver1)
+		return true;
+	else
+		return false;
+}
+static boolean
+check_negative(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2
+)
+{
+	return true;
+}
+
+/******************************************************************************
+*                           agc_tab.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_agc_tab[] = {
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFE000003,
+		0x81C, 0xFD020003,
+		0x81C, 0xFC040003,
+		0x81C, 0xFB060003,
+		0x81C, 0xFA080003,
+		0x81C, 0xF90A0003,
+		0x81C, 0xF80C0003,
+		0x81C, 0xF70E0003,
+		0x81C, 0xF6100003,
+		0x81C, 0xF5120003,
+		0x81C, 0xF4140003,
+		0x81C, 0xF3160003,
+		0x81C, 0xF2180003,
+		0x81C, 0xF11A0003,
+		0x81C, 0xF01C0003,
+		0x81C, 0xEF1E0003,
+		0x81C, 0xEE200003,
+		0x81C, 0xED220003,
+		0x81C, 0xEC240003,
+		0x81C, 0xEB260003,
+		0x81C, 0xEA280003,
+		0x81C, 0xE92A0003,
+		0x81C, 0xE82C0003,
+		0x81C, 0xE72E0003,
+		0x81C, 0xE6300003,
+		0x81C, 0xE5320003,
+		0x81C, 0xC8340003,
+		0x81C, 0xC7360003,
+		0x81C, 0xC6380003,
+		0x81C, 0xC53A0003,
+		0x81C, 0xC43C0003,
+		0x81C, 0xC33E0003,
+		0x81C, 0xC2400003,
+		0x81C, 0xC1420003,
+		0x81C, 0xC0440003,
+		0x81C, 0xA3460003,
+		0x81C, 0xA2480003,
+		0x81C, 0xA14A0003,
+		0x81C, 0xA04C0003,
+		0x81C, 0x824E0003,
+		0x81C, 0x81500003,
+		0x81C, 0x80520003,
+		0x81C, 0x64540003,
+		0x81C, 0x63560003,
+		0x81C, 0x62580003,
+		0x81C, 0x445A0003,
+		0x81C, 0x435C0003,
+		0x81C, 0x425E0003,
+		0x81C, 0x41600003,
+		0x81C, 0x40620003,
+		0x81C, 0x05640003,
+		0x81C, 0x04660003,
+		0x81C, 0x03680003,
+		0x81C, 0x026A0003,
+		0x81C, 0x016C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xF5000003,
+		0x81C, 0xF4020003,
+		0x81C, 0xF3040003,
+		0x81C, 0xF2060003,
+		0x81C, 0xF1080003,
+		0x81C, 0xF00A0003,
+		0x81C, 0xEF0C0003,
+		0x81C, 0xEE0E0003,
+		0x81C, 0xED100003,
+		0x81C, 0xEC120003,
+		0x81C, 0xEB140003,
+		0x81C, 0xEA160003,
+		0x81C, 0xE9180003,
+		0x81C, 0xE81A0003,
+		0x81C, 0xE71C0003,
+		0x81C, 0xE61E0003,
+		0x81C, 0xE5200003,
+		0x81C, 0xE4220003,
+		0x81C, 0xE3240003,
+		0x81C, 0xE2260003,
+		0x81C, 0xE1280003,
+		0x81C, 0xE02A0003,
+		0x81C, 0xC32C0003,
+		0x81C, 0xC22E0003,
+		0x81C, 0xC1300003,
+		0x81C, 0xC0320003,
+		0x81C, 0xA4340003,
+		0x81C, 0xA3360003,
+		0x81C, 0xA2380003,
+		0x81C, 0xA13A0003,
+		0x81C, 0xA03C0003,
+		0x81C, 0x823E0003,
+		0x81C, 0x81400003,
+		0x81C, 0x80420003,
+		0x81C, 0x64440003,
+		0x81C, 0x63460003,
+		0x81C, 0x62480003,
+		0x81C, 0x614A0003,
+		0x81C, 0x604C0003,
+		0x81C, 0x454E0003,
+		0x81C, 0x44500003,
+		0x81C, 0x43520003,
+		0x81C, 0x42540003,
+		0x81C, 0x41560003,
+		0x81C, 0x40580003,
+		0x81C, 0x055A0003,
+		0x81C, 0x045C0003,
+		0x81C, 0x035E0003,
+		0x81C, 0x02600003,
+		0x81C, 0x01620003,
+		0x81C, 0x00640003,
+		0x81C, 0x00660003,
+		0x81C, 0x00680003,
+		0x81C, 0x006A0003,
+		0x81C, 0x006C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFD000003,
+		0x81C, 0xFC020003,
+		0x81C, 0xFB040003,
+		0x81C, 0xFA060003,
+		0x81C, 0xF9080003,
+		0x81C, 0xF80A0003,
+		0x81C, 0xF70C0003,
+		0x81C, 0xF60E0003,
+		0x81C, 0xF5100003,
+		0x81C, 0xF4120003,
+		0x81C, 0xF3140003,
+		0x81C, 0xF2160003,
+		0x81C, 0xF1180003,
+		0x81C, 0xF01A0003,
+		0x81C, 0xEF1C0003,
+		0x81C, 0xEE1E0003,
+		0x81C, 0xED200003,
+		0x81C, 0xEC220003,
+		0x81C, 0xEB240003,
+		0x81C, 0xEA260003,
+		0x81C, 0xE9280003,
+		0x81C, 0xE82A0003,
+		0x81C, 0xE72C0003,
+		0x81C, 0xE62E0003,
+		0x81C, 0xE5300003,
+		0x81C, 0xC8320003,
+		0x81C, 0xC7340003,
+		0x81C, 0xC6360003,
+		0x81C, 0xC5380003,
+		0x81C, 0xC43A0003,
+		0x81C, 0xC33C0003,
+		0x81C, 0xC23E0003,
+		0x81C, 0xC1400003,
+		0x81C, 0xC0420003,
+		0x81C, 0xA5440003,
+		0x81C, 0xA4460003,
+		0x81C, 0xA3480003,
+		0x81C, 0xA24A0003,
+		0x81C, 0xA14C0003,
+		0x81C, 0x834E0003,
+		0x81C, 0x82500003,
+		0x81C, 0x81520003,
+		0x81C, 0x80540003,
+		0x81C, 0x65560003,
+		0x81C, 0x64580003,
+		0x81C, 0x635A0003,
+		0x81C, 0x625C0003,
+		0x81C, 0x435E0003,
+		0x81C, 0x42600003,
+		0x81C, 0x41620003,
+		0x81C, 0x40640003,
+		0x81C, 0x06660003,
+		0x81C, 0x05680003,
+		0x81C, 0x046A0003,
+		0x81C, 0x036C0003,
+		0x81C, 0x026E0003,
+		0x81C, 0x01700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFD000003,
+		0x81C, 0xFC020003,
+		0x81C, 0xFB040003,
+		0x81C, 0xFA060003,
+		0x81C, 0xF9080003,
+		0x81C, 0xF80A0003,
+		0x81C, 0xF70C0003,
+		0x81C, 0xF60E0003,
+		0x81C, 0xF5100003,
+		0x81C, 0xF4120003,
+		0x81C, 0xF3140003,
+		0x81C, 0xF2160003,
+		0x81C, 0xF1180003,
+		0x81C, 0xF01A0003,
+		0x81C, 0xEF1C0003,
+		0x81C, 0xEE1E0003,
+		0x81C, 0xED200003,
+		0x81C, 0xEC220003,
+		0x81C, 0xEB240003,
+		0x81C, 0xEA260003,
+		0x81C, 0xE9280003,
+		0x81C, 0xE82A0003,
+		0x81C, 0xE72C0003,
+		0x81C, 0xE62E0003,
+		0x81C, 0xE5300003,
+		0x81C, 0xC8320003,
+		0x81C, 0xC7340003,
+		0x81C, 0xC6360003,
+		0x81C, 0xC5380003,
+		0x81C, 0xC43A0003,
+		0x81C, 0xC33C0003,
+		0x81C, 0xC23E0003,
+		0x81C, 0xC1400003,
+		0x81C, 0xC0420003,
+		0x81C, 0xA5440003,
+		0x81C, 0xA4460003,
+		0x81C, 0xA3480003,
+		0x81C, 0xA24A0003,
+		0x81C, 0xA14C0003,
+		0x81C, 0x834E0003,
+		0x81C, 0x82500003,
+		0x81C, 0x81520003,
+		0x81C, 0x80540003,
+		0x81C, 0x65560003,
+		0x81C, 0x64580003,
+		0x81C, 0x635A0003,
+		0x81C, 0x625C0003,
+		0x81C, 0x435E0003,
+		0x81C, 0x42600003,
+		0x81C, 0x41620003,
+		0x81C, 0x40640003,
+		0x81C, 0x06660003,
+		0x81C, 0x05680003,
+		0x81C, 0x046A0003,
+		0x81C, 0x036C0003,
+		0x81C, 0x026E0003,
+		0x81C, 0x01700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xDC000003,
+		0x81C, 0xDB020003,
+		0x81C, 0xDA040003,
+		0x81C, 0xD9060003,
+		0x81C, 0xD8080003,
+		0x81C, 0xD70A0003,
+		0x81C, 0xD60C0003,
+		0x81C, 0xD50E0003,
+		0x81C, 0xD4100003,
+		0x81C, 0xD3120003,
+		0x81C, 0xD2140003,
+		0x81C, 0xD1160003,
+		0x81C, 0xD0180003,
+		0x81C, 0xB41A0003,
+		0x81C, 0xB31C0003,
+		0x81C, 0xB21E0003,
+		0x81C, 0xB1200003,
+		0x81C, 0xB0220003,
+		0x81C, 0xAF240003,
+		0x81C, 0xAE260003,
+		0x81C, 0xAD280003,
+		0x81C, 0xAC2A0003,
+		0x81C, 0xAB2C0003,
+		0x81C, 0x8C2E0003,
+		0x81C, 0x8B300003,
+		0x81C, 0x8A320003,
+		0x81C, 0x89340003,
+		0x81C, 0x88360003,
+		0x81C, 0x87380003,
+		0x81C, 0x863A0003,
+		0x81C, 0x853C0003,
+		0x81C, 0x693E0003,
+		0x81C, 0x68400003,
+		0x81C, 0x67420003,
+		0x81C, 0x66440003,
+		0x81C, 0x65460003,
+		0x81C, 0x48480003,
+		0x81C, 0x474A0003,
+		0x81C, 0x464C0003,
+		0x81C, 0x454E0003,
+		0x81C, 0x44500003,
+		0x81C, 0x43520003,
+		0x81C, 0x27540003,
+		0x81C, 0x26560003,
+		0x81C, 0x25580003,
+		0x81C, 0x245A0003,
+		0x81C, 0x235C0003,
+		0x81C, 0x045E0003,
+		0x81C, 0x03600003,
+		0x81C, 0x02620003,
+		0x81C, 0x01640003,
+		0x81C, 0x00660003,
+		0x81C, 0x00680003,
+		0x81C, 0x006A0003,
+		0x81C, 0x006C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFD000003,
+		0x81C, 0xFC020003,
+		0x81C, 0xFB040003,
+		0x81C, 0xFA060003,
+		0x81C, 0xF9080003,
+		0x81C, 0xF80A0003,
+		0x81C, 0xF70C0003,
+		0x81C, 0xF60E0003,
+		0x81C, 0xF5100003,
+		0x81C, 0xF4120003,
+		0x81C, 0xF3140003,
+		0x81C, 0xF2160003,
+		0x81C, 0xF1180003,
+		0x81C, 0xF01A0003,
+		0x81C, 0xEF1C0003,
+		0x81C, 0xEE1E0003,
+		0x81C, 0xED200003,
+		0x81C, 0xEC220003,
+		0x81C, 0xEB240003,
+		0x81C, 0xEA260003,
+		0x81C, 0xE9280003,
+		0x81C, 0xE82A0003,
+		0x81C, 0xE72C0003,
+		0x81C, 0xE62E0003,
+		0x81C, 0xE5300003,
+		0x81C, 0xC8320003,
+		0x81C, 0xC7340003,
+		0x81C, 0xC6360003,
+		0x81C, 0xC5380003,
+		0x81C, 0xC43A0003,
+		0x81C, 0xC33C0003,
+		0x81C, 0xC23E0003,
+		0x81C, 0xC1400003,
+		0x81C, 0xC0420003,
+		0x81C, 0xA5440003,
+		0x81C, 0xA4460003,
+		0x81C, 0xA3480003,
+		0x81C, 0xA24A0003,
+		0x81C, 0xA14C0003,
+		0x81C, 0x834E0003,
+		0x81C, 0x82500003,
+		0x81C, 0x81520003,
+		0x81C, 0x80540003,
+		0x81C, 0x65560003,
+		0x81C, 0x64580003,
+		0x81C, 0x635A0003,
+		0x81C, 0x625C0003,
+		0x81C, 0x435E0003,
+		0x81C, 0x42600003,
+		0x81C, 0x41620003,
+		0x81C, 0x40640003,
+		0x81C, 0x06660003,
+		0x81C, 0x05680003,
+		0x81C, 0x046A0003,
+		0x81C, 0x036C0003,
+		0x81C, 0x026E0003,
+		0x81C, 0x01700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xF5000003,
+		0x81C, 0xF4020003,
+		0x81C, 0xF3040003,
+		0x81C, 0xF2060003,
+		0x81C, 0xF1080003,
+		0x81C, 0xF00A0003,
+		0x81C, 0xEF0C0003,
+		0x81C, 0xEE0E0003,
+		0x81C, 0xED100003,
+		0x81C, 0xEC120003,
+		0x81C, 0xEB140003,
+		0x81C, 0xEA160003,
+		0x81C, 0xE9180003,
+		0x81C, 0xE81A0003,
+		0x81C, 0xE71C0003,
+		0x81C, 0xE61E0003,
+		0x81C, 0xE5200003,
+		0x81C, 0xE4220003,
+		0x81C, 0xE3240003,
+		0x81C, 0xE2260003,
+		0x81C, 0xE1280003,
+		0x81C, 0xE02A0003,
+		0x81C, 0xC32C0003,
+		0x81C, 0xC22E0003,
+		0x81C, 0xC1300003,
+		0x81C, 0xC0320003,
+		0x81C, 0xA4340003,
+		0x81C, 0xA3360003,
+		0x81C, 0xA2380003,
+		0x81C, 0xA13A0003,
+		0x81C, 0xA03C0003,
+		0x81C, 0x823E0003,
+		0x81C, 0x81400003,
+		0x81C, 0x80420003,
+		0x81C, 0x64440003,
+		0x81C, 0x63460003,
+		0x81C, 0x62480003,
+		0x81C, 0x614A0003,
+		0x81C, 0x604C0003,
+		0x81C, 0x454E0003,
+		0x81C, 0x44500003,
+		0x81C, 0x43520003,
+		0x81C, 0x42540003,
+		0x81C, 0x41560003,
+		0x81C, 0x40580003,
+		0x81C, 0x055A0003,
+		0x81C, 0x045C0003,
+		0x81C, 0x035E0003,
+		0x81C, 0x02600003,
+		0x81C, 0x01620003,
+		0x81C, 0x00640003,
+		0x81C, 0x00660003,
+		0x81C, 0x00680003,
+		0x81C, 0x006A0003,
+		0x81C, 0x006C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xF5000003,
+		0x81C, 0xF4020003,
+		0x81C, 0xF3040003,
+		0x81C, 0xF2060003,
+		0x81C, 0xF1080003,
+		0x81C, 0xF00A0003,
+		0x81C, 0xEF0C0003,
+		0x81C, 0xEE0E0003,
+		0x81C, 0xED100003,
+		0x81C, 0xEC120003,
+		0x81C, 0xEB140003,
+		0x81C, 0xEA160003,
+		0x81C, 0xE9180003,
+		0x81C, 0xE81A0003,
+		0x81C, 0xE71C0003,
+		0x81C, 0xE61E0003,
+		0x81C, 0xE5200003,
+		0x81C, 0xE4220003,
+		0x81C, 0xE3240003,
+		0x81C, 0xE2260003,
+		0x81C, 0xE1280003,
+		0x81C, 0xE02A0003,
+		0x81C, 0xC32C0003,
+		0x81C, 0xC22E0003,
+		0x81C, 0xC1300003,
+		0x81C, 0xC0320003,
+		0x81C, 0xA4340003,
+		0x81C, 0xA3360003,
+		0x81C, 0xA2380003,
+		0x81C, 0xA13A0003,
+		0x81C, 0xA03C0003,
+		0x81C, 0x823E0003,
+		0x81C, 0x81400003,
+		0x81C, 0x80420003,
+		0x81C, 0x64440003,
+		0x81C, 0x63460003,
+		0x81C, 0x62480003,
+		0x81C, 0x614A0003,
+		0x81C, 0x604C0003,
+		0x81C, 0x454E0003,
+		0x81C, 0x44500003,
+		0x81C, 0x43520003,
+		0x81C, 0x42540003,
+		0x81C, 0x41560003,
+		0x81C, 0x40580003,
+		0x81C, 0x055A0003,
+		0x81C, 0x045C0003,
+		0x81C, 0x035E0003,
+		0x81C, 0x02600003,
+		0x81C, 0x01620003,
+		0x81C, 0x00640003,
+		0x81C, 0x00660003,
+		0x81C, 0x00680003,
+		0x81C, 0x006A0003,
+		0x81C, 0x006C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFE000003,
+		0x81C, 0xFD020003,
+		0x81C, 0xFC040003,
+		0x81C, 0xFB060003,
+		0x81C, 0xFA080003,
+		0x81C, 0xF90A0003,
+		0x81C, 0xF80C0003,
+		0x81C, 0xF70E0003,
+		0x81C, 0xF6100003,
+		0x81C, 0xF5120003,
+		0x81C, 0xF4140003,
+		0x81C, 0xF3160003,
+		0x81C, 0xF2180003,
+		0x81C, 0xF11A0003,
+		0x81C, 0xF01C0003,
+		0x81C, 0xEF1E0003,
+		0x81C, 0xEE200003,
+		0x81C, 0xED220003,
+		0x81C, 0xEC240003,
+		0x81C, 0xEB260003,
+		0x81C, 0xEA280003,
+		0x81C, 0xE92A0003,
+		0x81C, 0xE82C0003,
+		0x81C, 0xE72E0003,
+		0x81C, 0xE6300003,
+		0x81C, 0xE5320003,
+		0x81C, 0xC8340003,
+		0x81C, 0xC7360003,
+		0x81C, 0xC6380003,
+		0x81C, 0xC53A0003,
+		0x81C, 0xC43C0003,
+		0x81C, 0xC33E0003,
+		0x81C, 0xC2400003,
+		0x81C, 0xC1420003,
+		0x81C, 0xC0440003,
+		0x81C, 0xA3460003,
+		0x81C, 0xA2480003,
+		0x81C, 0xA14A0003,
+		0x81C, 0xA04C0003,
+		0x81C, 0x824E0003,
+		0x81C, 0x81500003,
+		0x81C, 0x80520003,
+		0x81C, 0x64540003,
+		0x81C, 0x63560003,
+		0x81C, 0x62580003,
+		0x81C, 0x445A0003,
+		0x81C, 0x435C0003,
+		0x81C, 0x425E0003,
+		0x81C, 0x41600003,
+		0x81C, 0x40620003,
+		0x81C, 0x05640003,
+		0x81C, 0x04660003,
+		0x81C, 0x03680003,
+		0x81C, 0x026A0003,
+		0x81C, 0x016C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xF5000003,
+		0x81C, 0xF4020003,
+		0x81C, 0xF3040003,
+		0x81C, 0xF2060003,
+		0x81C, 0xF1080003,
+		0x81C, 0xF00A0003,
+		0x81C, 0xEF0C0003,
+		0x81C, 0xEE0E0003,
+		0x81C, 0xED100003,
+		0x81C, 0xEC120003,
+		0x81C, 0xEB140003,
+		0x81C, 0xEA160003,
+		0x81C, 0xE9180003,
+		0x81C, 0xE81A0003,
+		0x81C, 0xE71C0003,
+		0x81C, 0xE61E0003,
+		0x81C, 0xE5200003,
+		0x81C, 0xE4220003,
+		0x81C, 0xE3240003,
+		0x81C, 0xE2260003,
+		0x81C, 0xE1280003,
+		0x81C, 0xE02A0003,
+		0x81C, 0xC32C0003,
+		0x81C, 0xC22E0003,
+		0x81C, 0xC1300003,
+		0x81C, 0xC0320003,
+		0x81C, 0xA4340003,
+		0x81C, 0xA3360003,
+		0x81C, 0xA2380003,
+		0x81C, 0xA13A0003,
+		0x81C, 0xA03C0003,
+		0x81C, 0x823E0003,
+		0x81C, 0x81400003,
+		0x81C, 0x80420003,
+		0x81C, 0x64440003,
+		0x81C, 0x63460003,
+		0x81C, 0x62480003,
+		0x81C, 0x614A0003,
+		0x81C, 0x604C0003,
+		0x81C, 0x454E0003,
+		0x81C, 0x44500003,
+		0x81C, 0x43520003,
+		0x81C, 0x42540003,
+		0x81C, 0x41560003,
+		0x81C, 0x40580003,
+		0x81C, 0x055A0003,
+		0x81C, 0x045C0003,
+		0x81C, 0x035E0003,
+		0x81C, 0x02600003,
+		0x81C, 0x01620003,
+		0x81C, 0x00640003,
+		0x81C, 0x00660003,
+		0x81C, 0x00680003,
+		0x81C, 0x006A0003,
+		0x81C, 0x006C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFE000003,
+		0x81C, 0xFD020003,
+		0x81C, 0xFC040003,
+		0x81C, 0xFB060003,
+		0x81C, 0xFA080003,
+		0x81C, 0xF90A0003,
+		0x81C, 0xF80C0003,
+		0x81C, 0xF70E0003,
+		0x81C, 0xF6100003,
+		0x81C, 0xF5120003,
+		0x81C, 0xF4140003,
+		0x81C, 0xF3160003,
+		0x81C, 0xF2180003,
+		0x81C, 0xF11A0003,
+		0x81C, 0xF01C0003,
+		0x81C, 0xEF1E0003,
+		0x81C, 0xEE200003,
+		0x81C, 0xED220003,
+		0x81C, 0xEC240003,
+		0x81C, 0xEB260003,
+		0x81C, 0xEA280003,
+		0x81C, 0xE92A0003,
+		0x81C, 0xE82C0003,
+		0x81C, 0xE72E0003,
+		0x81C, 0xE6300003,
+		0x81C, 0xE5320003,
+		0x81C, 0xC8340003,
+		0x81C, 0xC7360003,
+		0x81C, 0xC6380003,
+		0x81C, 0xC53A0003,
+		0x81C, 0xC43C0003,
+		0x81C, 0xC33E0003,
+		0x81C, 0xC2400003,
+		0x81C, 0xC1420003,
+		0x81C, 0xC0440003,
+		0x81C, 0xA3460003,
+		0x81C, 0xA2480003,
+		0x81C, 0xA14A0003,
+		0x81C, 0xA04C0003,
+		0x81C, 0x824E0003,
+		0x81C, 0x81500003,
+		0x81C, 0x80520003,
+		0x81C, 0x64540003,
+		0x81C, 0x63560003,
+		0x81C, 0x62580003,
+		0x81C, 0x445A0003,
+		0x81C, 0x435C0003,
+		0x81C, 0x425E0003,
+		0x81C, 0x41600003,
+		0x81C, 0x40620003,
+		0x81C, 0x05640003,
+		0x81C, 0x04660003,
+		0x81C, 0x03680003,
+		0x81C, 0x026A0003,
+		0x81C, 0x016C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xF5000003,
+		0x81C, 0xF4020003,
+		0x81C, 0xF3040003,
+		0x81C, 0xF2060003,
+		0x81C, 0xF1080003,
+		0x81C, 0xF00A0003,
+		0x81C, 0xEF0C0003,
+		0x81C, 0xEE0E0003,
+		0x81C, 0xED100003,
+		0x81C, 0xEC120003,
+		0x81C, 0xEB140003,
+		0x81C, 0xEA160003,
+		0x81C, 0xE9180003,
+		0x81C, 0xE81A0003,
+		0x81C, 0xE71C0003,
+		0x81C, 0xE61E0003,
+		0x81C, 0xE5200003,
+		0x81C, 0xE4220003,
+		0x81C, 0xE3240003,
+		0x81C, 0xE2260003,
+		0x81C, 0xE1280003,
+		0x81C, 0xE02A0003,
+		0x81C, 0xC32C0003,
+		0x81C, 0xC22E0003,
+		0x81C, 0xC1300003,
+		0x81C, 0xC0320003,
+		0x81C, 0xA4340003,
+		0x81C, 0xA3360003,
+		0x81C, 0xA2380003,
+		0x81C, 0xA13A0003,
+		0x81C, 0xA03C0003,
+		0x81C, 0x823E0003,
+		0x81C, 0x81400003,
+		0x81C, 0x80420003,
+		0x81C, 0x64440003,
+		0x81C, 0x63460003,
+		0x81C, 0x62480003,
+		0x81C, 0x614A0003,
+		0x81C, 0x604C0003,
+		0x81C, 0x454E0003,
+		0x81C, 0x44500003,
+		0x81C, 0x43520003,
+		0x81C, 0x42540003,
+		0x81C, 0x41560003,
+		0x81C, 0x40580003,
+		0x81C, 0x055A0003,
+		0x81C, 0x045C0003,
+		0x81C, 0x035E0003,
+		0x81C, 0x02600003,
+		0x81C, 0x01620003,
+		0x81C, 0x00640003,
+		0x81C, 0x00660003,
+		0x81C, 0x00680003,
+		0x81C, 0x006A0003,
+		0x81C, 0x006C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFD000003,
+		0x81C, 0xFC020003,
+		0x81C, 0xFB040003,
+		0x81C, 0xFA060003,
+		0x81C, 0xF9080003,
+		0x81C, 0xF80A0003,
+		0x81C, 0xF70C0003,
+		0x81C, 0xF60E0003,
+		0x81C, 0xF5100003,
+		0x81C, 0xF4120003,
+		0x81C, 0xF3140003,
+		0x81C, 0xF2160003,
+		0x81C, 0xF1180003,
+		0x81C, 0xF01A0003,
+		0x81C, 0xEF1C0003,
+		0x81C, 0xEE1E0003,
+		0x81C, 0xED200003,
+		0x81C, 0xEC220003,
+		0x81C, 0xEB240003,
+		0x81C, 0xEA260003,
+		0x81C, 0xE9280003,
+		0x81C, 0xE82A0003,
+		0x81C, 0xE72C0003,
+		0x81C, 0xE62E0003,
+		0x81C, 0xE5300003,
+		0x81C, 0xC8320003,
+		0x81C, 0xC7340003,
+		0x81C, 0xC6360003,
+		0x81C, 0xC5380003,
+		0x81C, 0xC43A0003,
+		0x81C, 0xC33C0003,
+		0x81C, 0xC23E0003,
+		0x81C, 0xC1400003,
+		0x81C, 0xC0420003,
+		0x81C, 0xA5440003,
+		0x81C, 0xA4460003,
+		0x81C, 0xA3480003,
+		0x81C, 0xA24A0003,
+		0x81C, 0xA14C0003,
+		0x81C, 0x834E0003,
+		0x81C, 0x82500003,
+		0x81C, 0x81520003,
+		0x81C, 0x80540003,
+		0x81C, 0x65560003,
+		0x81C, 0x64580003,
+		0x81C, 0x635A0003,
+		0x81C, 0x625C0003,
+		0x81C, 0x435E0003,
+		0x81C, 0x42600003,
+		0x81C, 0x41620003,
+		0x81C, 0x40640003,
+		0x81C, 0x06660003,
+		0x81C, 0x05680003,
+		0x81C, 0x046A0003,
+		0x81C, 0x036C0003,
+		0x81C, 0x026E0003,
+		0x81C, 0x01700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFE000003,
+		0x81C, 0xFD020003,
+		0x81C, 0xFC040003,
+		0x81C, 0xFB060003,
+		0x81C, 0xFA080003,
+		0x81C, 0xF90A0003,
+		0x81C, 0xF80C0003,
+		0x81C, 0xF70E0003,
+		0x81C, 0xF6100003,
+		0x81C, 0xF5120003,
+		0x81C, 0xF4140003,
+		0x81C, 0xF3160003,
+		0x81C, 0xF2180003,
+		0x81C, 0xF11A0003,
+		0x81C, 0xF01C0003,
+		0x81C, 0xEF1E0003,
+		0x81C, 0xEE200003,
+		0x81C, 0xED220003,
+		0x81C, 0xEC240003,
+		0x81C, 0xEB260003,
+		0x81C, 0xEA280003,
+		0x81C, 0xE92A0003,
+		0x81C, 0xE82C0003,
+		0x81C, 0xE72E0003,
+		0x81C, 0xE6300003,
+		0x81C, 0xE5320003,
+		0x81C, 0xC8340003,
+		0x81C, 0xC7360003,
+		0x81C, 0xC6380003,
+		0x81C, 0xC53A0003,
+		0x81C, 0xC43C0003,
+		0x81C, 0xC33E0003,
+		0x81C, 0xC2400003,
+		0x81C, 0xC1420003,
+		0x81C, 0xC0440003,
+		0x81C, 0xA3460003,
+		0x81C, 0xA2480003,
+		0x81C, 0xA14A0003,
+		0x81C, 0xA04C0003,
+		0x81C, 0x824E0003,
+		0x81C, 0x81500003,
+		0x81C, 0x80520003,
+		0x81C, 0x64540003,
+		0x81C, 0x63560003,
+		0x81C, 0x62580003,
+		0x81C, 0x445A0003,
+		0x81C, 0x435C0003,
+		0x81C, 0x425E0003,
+		0x81C, 0x41600003,
+		0x81C, 0x40620003,
+		0x81C, 0x05640003,
+		0x81C, 0x04660003,
+		0x81C, 0x03680003,
+		0x81C, 0x026A0003,
+		0x81C, 0x016C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFE000003,
+		0x81C, 0xFD020003,
+		0x81C, 0xFC040003,
+		0x81C, 0xFB060003,
+		0x81C, 0xFA080003,
+		0x81C, 0xF90A0003,
+		0x81C, 0xF80C0003,
+		0x81C, 0xF70E0003,
+		0x81C, 0xF6100003,
+		0x81C, 0xF5120003,
+		0x81C, 0xF4140003,
+		0x81C, 0xF3160003,
+		0x81C, 0xF2180003,
+		0x81C, 0xF11A0003,
+		0x81C, 0xF01C0003,
+		0x81C, 0xEF1E0003,
+		0x81C, 0xEE200003,
+		0x81C, 0xED220003,
+		0x81C, 0xEC240003,
+		0x81C, 0xEB260003,
+		0x81C, 0xEA280003,
+		0x81C, 0xE92A0003,
+		0x81C, 0xE82C0003,
+		0x81C, 0xE72E0003,
+		0x81C, 0xE6300003,
+		0x81C, 0xE5320003,
+		0x81C, 0xC8340003,
+		0x81C, 0xC7360003,
+		0x81C, 0xC6380003,
+		0x81C, 0xC53A0003,
+		0x81C, 0xC43C0003,
+		0x81C, 0xC33E0003,
+		0x81C, 0xC2400003,
+		0x81C, 0xC1420003,
+		0x81C, 0xC0440003,
+		0x81C, 0xA3460003,
+		0x81C, 0xA2480003,
+		0x81C, 0xA14A0003,
+		0x81C, 0xA04C0003,
+		0x81C, 0x824E0003,
+		0x81C, 0x81500003,
+		0x81C, 0x80520003,
+		0x81C, 0x64540003,
+		0x81C, 0x63560003,
+		0x81C, 0x62580003,
+		0x81C, 0x445A0003,
+		0x81C, 0x435C0003,
+		0x81C, 0x425E0003,
+		0x81C, 0x41600003,
+		0x81C, 0x40620003,
+		0x81C, 0x05640003,
+		0x81C, 0x04660003,
+		0x81C, 0x03680003,
+		0x81C, 0x026A0003,
+		0x81C, 0x016C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFC000003,
+		0x81C, 0xFB020003,
+		0x81C, 0xFA040003,
+		0x81C, 0xF9060003,
+		0x81C, 0xF8080003,
+		0x81C, 0xF70A0003,
+		0x81C, 0xF60C0003,
+		0x81C, 0xF50E0003,
+		0x81C, 0xF4100003,
+		0x81C, 0xF3120003,
+		0x81C, 0xF2140003,
+		0x81C, 0xF1160003,
+		0x81C, 0xF0180003,
+		0x81C, 0xEF1A0003,
+		0x81C, 0xEE1C0003,
+		0x81C, 0xED1E0003,
+		0x81C, 0xEC200003,
+		0x81C, 0xEB220003,
+		0x81C, 0xEA240003,
+		0x81C, 0xE9260003,
+		0x81C, 0xE8280003,
+		0x81C, 0xE72A0003,
+		0x81C, 0xE62C0003,
+		0x81C, 0xE52E0003,
+		0x81C, 0xC8300003,
+		0x81C, 0xC7320003,
+		0x81C, 0xC6340003,
+		0x81C, 0xC5360003,
+		0x81C, 0xC4380003,
+		0x81C, 0xC33A0003,
+		0x81C, 0xC23C0003,
+		0x81C, 0xC13E0003,
+		0x81C, 0xA4400003,
+		0x81C, 0xA3420003,
+		0x81C, 0xA2440003,
+		0x81C, 0xA1460003,
+		0x81C, 0xA0480003,
+		0x81C, 0x684A0003,
+		0x81C, 0x674C0003,
+		0x81C, 0x664E0003,
+		0x81C, 0x65500003,
+		0x81C, 0x64520003,
+		0x81C, 0x63540003,
+		0x81C, 0x44560003,
+		0x81C, 0x43580003,
+		0x81C, 0x425A0003,
+		0x81C, 0x415C0003,
+		0x81C, 0x405E0003,
+		0x81C, 0x23600003,
+		0x81C, 0x22620003,
+		0x81C, 0x21640003,
+		0x81C, 0x03660003,
+		0x81C, 0x02680003,
+		0x81C, 0x016A0003,
+		0x81C, 0x006C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFD000003,
+		0x81C, 0xFC020003,
+		0x81C, 0xFB040003,
+		0x81C, 0xFA060003,
+		0x81C, 0xF9080003,
+		0x81C, 0xF80A0003,
+		0x81C, 0xF70C0003,
+		0x81C, 0xF60E0003,
+		0x81C, 0xF5100003,
+		0x81C, 0xF4120003,
+		0x81C, 0xF3140003,
+		0x81C, 0xF2160003,
+		0x81C, 0xF1180003,
+		0x81C, 0xF01A0003,
+		0x81C, 0xEF1C0003,
+		0x81C, 0xEE1E0003,
+		0x81C, 0xED200003,
+		0x81C, 0xEC220003,
+		0x81C, 0xEB240003,
+		0x81C, 0xEA260003,
+		0x81C, 0xE9280003,
+		0x81C, 0xE82A0003,
+		0x81C, 0xE72C0003,
+		0x81C, 0xE62E0003,
+		0x81C, 0xE5300003,
+		0x81C, 0xC8320003,
+		0x81C, 0xC7340003,
+		0x81C, 0xC6360003,
+		0x81C, 0xC5380003,
+		0x81C, 0xC43A0003,
+		0x81C, 0xC33C0003,
+		0x81C, 0xC23E0003,
+		0x81C, 0xC1400003,
+		0x81C, 0xC0420003,
+		0x81C, 0xA5440003,
+		0x81C, 0xA4460003,
+		0x81C, 0xA3480003,
+		0x81C, 0xA24A0003,
+		0x81C, 0xA14C0003,
+		0x81C, 0x834E0003,
+		0x81C, 0x82500003,
+		0x81C, 0x81520003,
+		0x81C, 0x80540003,
+		0x81C, 0x65560003,
+		0x81C, 0x64580003,
+		0x81C, 0x635A0003,
+		0x81C, 0x625C0003,
+		0x81C, 0x435E0003,
+		0x81C, 0x42600003,
+		0x81C, 0x41620003,
+		0x81C, 0x40640003,
+		0x81C, 0x06660003,
+		0x81C, 0x05680003,
+		0x81C, 0x046A0003,
+		0x81C, 0x036C0003,
+		0x81C, 0x026E0003,
+		0x81C, 0x01700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFF000003,
+		0x81C, 0xFE000003,
+		0x81C, 0xFD020003,
+		0x81C, 0xFC040003,
+		0x81C, 0xFB060003,
+		0x81C, 0xFA080003,
+		0x81C, 0xF90A0003,
+		0x81C, 0xF80C0003,
+		0x81C, 0xF70E0003,
+		0x81C, 0xF6100003,
+		0x81C, 0xF5120003,
+		0x81C, 0xF4140003,
+		0x81C, 0xF3160003,
+		0x81C, 0xF2180003,
+		0x81C, 0xF11A0003,
+		0x81C, 0xF01C0003,
+		0x81C, 0xEF1E0003,
+		0x81C, 0xEE200003,
+		0x81C, 0xED220003,
+		0x81C, 0xEC240003,
+		0x81C, 0xEB260003,
+		0x81C, 0xEA280003,
+		0x81C, 0xE92A0003,
+		0x81C, 0xE82C0003,
+		0x81C, 0xE72E0003,
+		0x81C, 0xE6300003,
+		0x81C, 0xE5320003,
+		0x81C, 0xC8340003,
+		0x81C, 0xC7360003,
+		0x81C, 0xC6380003,
+		0x81C, 0xC53A0003,
+		0x81C, 0xC43C0003,
+		0x81C, 0xC33E0003,
+		0x81C, 0xC2400003,
+		0x81C, 0xC1420003,
+		0x81C, 0xC0440003,
+		0x81C, 0xA3460003,
+		0x81C, 0xA2480003,
+		0x81C, 0xA14A0003,
+		0x81C, 0xA04C0003,
+		0x81C, 0x824E0003,
+		0x81C, 0x81500003,
+		0x81C, 0x80520003,
+		0x81C, 0x64540003,
+		0x81C, 0x63560003,
+		0x81C, 0x62580003,
+		0x81C, 0x445A0003,
+		0x81C, 0x435C0003,
+		0x81C, 0x425E0003,
+		0x81C, 0x41600003,
+		0x81C, 0x40620003,
+		0x81C, 0x05640003,
+		0x81C, 0x04660003,
+		0x81C, 0x03680003,
+		0x81C, 0x026A0003,
+		0x81C, 0x016C0003,
+		0x81C, 0x006E0003,
+		0x81C, 0x00700003,
+		0x81C, 0x00720003,
+		0x81C, 0x00740003,
+		0x81C, 0x00760003,
+		0x81C, 0x00780003,
+		0x81C, 0x007A0003,
+		0x81C, 0x007C0003,
+		0x81C, 0x007E0003,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000103,
+		0x81C, 0xFC020103,
+		0x81C, 0xFB040103,
+		0x81C, 0xFA060103,
+		0x81C, 0xF9080103,
+		0x81C, 0xF80A0103,
+		0x81C, 0xF70C0103,
+		0x81C, 0xF60E0103,
+		0x81C, 0xF5100103,
+		0x81C, 0xF4120103,
+		0x81C, 0xF3140103,
+		0x81C, 0xF2160103,
+		0x81C, 0xF1180103,
+		0x81C, 0xF01A0103,
+		0x81C, 0xEE1C0103,
+		0x81C, 0xED1E0103,
+		0x81C, 0xEC200103,
+		0x81C, 0xEB220103,
+		0x81C, 0xEA240103,
+		0x81C, 0xE9260103,
+		0x81C, 0xE8280103,
+		0x81C, 0xE72A0103,
+		0x81C, 0xE62C0103,
+		0x81C, 0xE52E0103,
+		0x81C, 0xE4300103,
+		0x81C, 0xE3320103,
+		0x81C, 0xE2340103,
+		0x81C, 0xC5360103,
+		0x81C, 0xC4380103,
+		0x81C, 0xC33A0103,
+		0x81C, 0xC23C0103,
+		0x81C, 0xA53E0103,
+		0x81C, 0xA4400103,
+		0x81C, 0xA3420103,
+		0x81C, 0xA2440103,
+		0x81C, 0xA1460103,
+		0x81C, 0x83480103,
+		0x81C, 0x824A0103,
+		0x81C, 0x814C0103,
+		0x81C, 0x804E0103,
+		0x81C, 0x63500103,
+		0x81C, 0x62520103,
+		0x81C, 0x61540103,
+		0x81C, 0x43560103,
+		0x81C, 0x42580103,
+		0x81C, 0x415A0103,
+		0x81C, 0x405C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000103,
+		0x81C, 0xF7020103,
+		0x81C, 0xF6040103,
+		0x81C, 0xF5060103,
+		0x81C, 0xF4080103,
+		0x81C, 0xF30A0103,
+		0x81C, 0xF20C0103,
+		0x81C, 0xF10E0103,
+		0x81C, 0xF0100103,
+		0x81C, 0xEF120103,
+		0x81C, 0xEE140103,
+		0x81C, 0xED160103,
+		0x81C, 0xEC180103,
+		0x81C, 0xEB1A0103,
+		0x81C, 0xEA1C0103,
+		0x81C, 0xE91E0103,
+		0x81C, 0xE8200103,
+		0x81C, 0xE7220103,
+		0x81C, 0xE6240103,
+		0x81C, 0xE5260103,
+		0x81C, 0xE4280103,
+		0x81C, 0xE32A0103,
+		0x81C, 0xC32C0103,
+		0x81C, 0xC22E0103,
+		0x81C, 0xC1300103,
+		0x81C, 0xC0320103,
+		0x81C, 0xA3340103,
+		0x81C, 0xA2360103,
+		0x81C, 0xA1380103,
+		0x81C, 0xA03A0103,
+		0x81C, 0x823C0103,
+		0x81C, 0x813E0103,
+		0x81C, 0x80400103,
+		0x81C, 0x63420103,
+		0x81C, 0x62440103,
+		0x81C, 0x61460103,
+		0x81C, 0x60480103,
+		0x81C, 0x424A0103,
+		0x81C, 0x414C0103,
+		0x81C, 0x404E0103,
+		0x81C, 0x06500103,
+		0x81C, 0x05520103,
+		0x81C, 0x04540103,
+		0x81C, 0x03560103,
+		0x81C, 0x02580103,
+		0x81C, 0x015A0103,
+		0x81C, 0x005C0103,
+		0x81C, 0x005E0103,
+		0x81C, 0x00600103,
+		0x81C, 0x00620103,
+		0x81C, 0x00640103,
+		0x81C, 0x00660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000103,
+		0x81C, 0xF7020103,
+		0x81C, 0xF6040103,
+		0x81C, 0xF5060103,
+		0x81C, 0xF4080103,
+		0x81C, 0xF30A0103,
+		0x81C, 0xF20C0103,
+		0x81C, 0xF10E0103,
+		0x81C, 0xF0100103,
+		0x81C, 0xEF120103,
+		0x81C, 0xEE140103,
+		0x81C, 0xED160103,
+		0x81C, 0xEC180103,
+		0x81C, 0xEB1A0103,
+		0x81C, 0xEA1C0103,
+		0x81C, 0xE91E0103,
+		0x81C, 0xE8200103,
+		0x81C, 0xE7220103,
+		0x81C, 0xE6240103,
+		0x81C, 0xE5260103,
+		0x81C, 0xE4280103,
+		0x81C, 0xE32A0103,
+		0x81C, 0xC32C0103,
+		0x81C, 0xC22E0103,
+		0x81C, 0xC1300103,
+		0x81C, 0xC0320103,
+		0x81C, 0xA3340103,
+		0x81C, 0xA2360103,
+		0x81C, 0xA1380103,
+		0x81C, 0xA03A0103,
+		0x81C, 0x823C0103,
+		0x81C, 0x813E0103,
+		0x81C, 0x80400103,
+		0x81C, 0x63420103,
+		0x81C, 0x62440103,
+		0x81C, 0x61460103,
+		0x81C, 0x60480103,
+		0x81C, 0x424A0103,
+		0x81C, 0x414C0103,
+		0x81C, 0x404E0103,
+		0x81C, 0x22500103,
+		0x81C, 0x21520103,
+		0x81C, 0x20540103,
+		0x81C, 0x03560103,
+		0x81C, 0x02580103,
+		0x81C, 0x015A0103,
+		0x81C, 0x005C0103,
+		0x81C, 0x005E0103,
+		0x81C, 0x00600103,
+		0x81C, 0x00620103,
+		0x81C, 0x00640103,
+		0x81C, 0x00660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFE000103,
+		0x81C, 0xFD020103,
+		0x81C, 0xFC040103,
+		0x81C, 0xFB060103,
+		0x81C, 0xFA080103,
+		0x81C, 0xF90A0103,
+		0x81C, 0xF80C0103,
+		0x81C, 0xF70E0103,
+		0x81C, 0xF6100103,
+		0x81C, 0xF5120103,
+		0x81C, 0xF4140103,
+		0x81C, 0xF3160103,
+		0x81C, 0xF2180103,
+		0x81C, 0xF11A0103,
+		0x81C, 0xF01C0103,
+		0x81C, 0xEF1E0103,
+		0x81C, 0xEE200103,
+		0x81C, 0xED220103,
+		0x81C, 0xEC240103,
+		0x81C, 0xEB260103,
+		0x81C, 0xEA280103,
+		0x81C, 0xE92A0103,
+		0x81C, 0xE82C0103,
+		0x81C, 0xE72E0103,
+		0x81C, 0xE6300103,
+		0x81C, 0xE5320103,
+		0x81C, 0xE4340103,
+		0x81C, 0xE3360103,
+		0x81C, 0xC6380103,
+		0x81C, 0xC53A0103,
+		0x81C, 0xC43C0103,
+		0x81C, 0xC33E0103,
+		0x81C, 0xA5400103,
+		0x81C, 0xA4420103,
+		0x81C, 0xA3440103,
+		0x81C, 0xA2460103,
+		0x81C, 0xA1480103,
+		0x81C, 0xA04A0103,
+		0x81C, 0x824C0103,
+		0x81C, 0x814E0103,
+		0x81C, 0x80500103,
+		0x81C, 0x64520103,
+		0x81C, 0x63540103,
+		0x81C, 0x62560103,
+		0x81C, 0x61580103,
+		0x81C, 0x605A0103,
+		0x81C, 0x235C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000103,
+		0x81C, 0xF7020103,
+		0x81C, 0xF6040103,
+		0x81C, 0xF5060103,
+		0x81C, 0xF4080103,
+		0x81C, 0xF30A0103,
+		0x81C, 0xF20C0103,
+		0x81C, 0xF10E0103,
+		0x81C, 0xF0100103,
+		0x81C, 0xEF120103,
+		0x81C, 0xEE140103,
+		0x81C, 0xED160103,
+		0x81C, 0xEC180103,
+		0x81C, 0xEB1A0103,
+		0x81C, 0xEA1C0103,
+		0x81C, 0xE91E0103,
+		0x81C, 0xE8200103,
+		0x81C, 0xE7220103,
+		0x81C, 0xE6240103,
+		0x81C, 0xE5260103,
+		0x81C, 0xE4280103,
+		0x81C, 0xE32A0103,
+		0x81C, 0xC32C0103,
+		0x81C, 0xC22E0103,
+		0x81C, 0xC1300103,
+		0x81C, 0xC0320103,
+		0x81C, 0xA3340103,
+		0x81C, 0xA2360103,
+		0x81C, 0xA1380103,
+		0x81C, 0xA03A0103,
+		0x81C, 0x823C0103,
+		0x81C, 0x813E0103,
+		0x81C, 0x80400103,
+		0x81C, 0x63420103,
+		0x81C, 0x62440103,
+		0x81C, 0x61460103,
+		0x81C, 0x60480103,
+		0x81C, 0x424A0103,
+		0x81C, 0x414C0103,
+		0x81C, 0x404E0103,
+		0x81C, 0x22500103,
+		0x81C, 0x21520103,
+		0x81C, 0x20540103,
+		0x81C, 0x03560103,
+		0x81C, 0x02580103,
+		0x81C, 0x015A0103,
+		0x81C, 0x005C0103,
+		0x81C, 0x005E0103,
+		0x81C, 0x00600103,
+		0x81C, 0x00620103,
+		0x81C, 0x00640103,
+		0x81C, 0x00660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000103,
+		0x81C, 0xFC020103,
+		0x81C, 0xFB040103,
+		0x81C, 0xFA060103,
+		0x81C, 0xF9080103,
+		0x81C, 0xF80A0103,
+		0x81C, 0xF70C0103,
+		0x81C, 0xF60E0103,
+		0x81C, 0xF5100103,
+		0x81C, 0xF4120103,
+		0x81C, 0xF3140103,
+		0x81C, 0xF2160103,
+		0x81C, 0xF1180103,
+		0x81C, 0xF01A0103,
+		0x81C, 0xEF1C0103,
+		0x81C, 0xEE1E0103,
+		0x81C, 0xED200103,
+		0x81C, 0xEC220103,
+		0x81C, 0xEB240103,
+		0x81C, 0xEA260103,
+		0x81C, 0xE9280103,
+		0x81C, 0xE82A0103,
+		0x81C, 0xE72C0103,
+		0x81C, 0xE62E0103,
+		0x81C, 0xE5300103,
+		0x81C, 0xE4320103,
+		0x81C, 0xE3340103,
+		0x81C, 0xE2360103,
+		0x81C, 0xC5380103,
+		0x81C, 0xC43A0103,
+		0x81C, 0xC33C0103,
+		0x81C, 0xC23E0103,
+		0x81C, 0xA5400103,
+		0x81C, 0xA4420103,
+		0x81C, 0xA3440103,
+		0x81C, 0xA2460103,
+		0x81C, 0xA1480103,
+		0x81C, 0x834A0103,
+		0x81C, 0x824C0103,
+		0x81C, 0x814E0103,
+		0x81C, 0x64500103,
+		0x81C, 0x63520103,
+		0x81C, 0x62540103,
+		0x81C, 0x61560103,
+		0x81C, 0x42580103,
+		0x81C, 0x415A0103,
+		0x81C, 0x405C0103,
+		0x81C, 0x065E0103,
+		0x81C, 0x05600103,
+		0x81C, 0x04620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFA000103,
+		0x81C, 0xF9020103,
+		0x81C, 0xF8040103,
+		0x81C, 0xF7060103,
+		0x81C, 0xF6080103,
+		0x81C, 0xF50A0103,
+		0x81C, 0xF40C0103,
+		0x81C, 0xF30E0103,
+		0x81C, 0xF2100103,
+		0x81C, 0xF1120103,
+		0x81C, 0xF0140103,
+		0x81C, 0xEF160103,
+		0x81C, 0xEE180103,
+		0x81C, 0xED1A0103,
+		0x81C, 0xEC1C0103,
+		0x81C, 0xEB1E0103,
+		0x81C, 0xEA200103,
+		0x81C, 0xE9220103,
+		0x81C, 0xE8240103,
+		0x81C, 0xE7260103,
+		0x81C, 0xE6280103,
+		0x81C, 0xE52A0103,
+		0x81C, 0xC42C0103,
+		0x81C, 0xC32E0103,
+		0x81C, 0xC2300103,
+		0x81C, 0xC1320103,
+		0x81C, 0xA4340103,
+		0x81C, 0xA3360103,
+		0x81C, 0xA2380103,
+		0x81C, 0xA13A0103,
+		0x81C, 0x833C0103,
+		0x81C, 0x823E0103,
+		0x81C, 0x81400103,
+		0x81C, 0x63420103,
+		0x81C, 0x62440103,
+		0x81C, 0x61460103,
+		0x81C, 0x60480103,
+		0x81C, 0x424A0103,
+		0x81C, 0x414C0103,
+		0x81C, 0x404E0103,
+		0x81C, 0x22500103,
+		0x81C, 0x21520103,
+		0x81C, 0x20540103,
+		0x81C, 0x03560103,
+		0x81C, 0x02580103,
+		0x81C, 0x015A0103,
+		0x81C, 0x005C0103,
+		0x81C, 0x005E0103,
+		0x81C, 0x00600103,
+		0x81C, 0x00620103,
+		0x81C, 0x00640103,
+		0x81C, 0x00660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000103,
+		0x81C, 0xF7020103,
+		0x81C, 0xF6040103,
+		0x81C, 0xF5060103,
+		0x81C, 0xF4080103,
+		0x81C, 0xF30A0103,
+		0x81C, 0xF20C0103,
+		0x81C, 0xF10E0103,
+		0x81C, 0xF0100103,
+		0x81C, 0xEF120103,
+		0x81C, 0xEE140103,
+		0x81C, 0xED160103,
+		0x81C, 0xEC180103,
+		0x81C, 0xEB1A0103,
+		0x81C, 0xEA1C0103,
+		0x81C, 0xE91E0103,
+		0x81C, 0xE8200103,
+		0x81C, 0xE7220103,
+		0x81C, 0xE6240103,
+		0x81C, 0xE5260103,
+		0x81C, 0xE4280103,
+		0x81C, 0xE32A0103,
+		0x81C, 0xE22C0103,
+		0x81C, 0xC32E0103,
+		0x81C, 0xC2300103,
+		0x81C, 0xC1320103,
+		0x81C, 0xA3340103,
+		0x81C, 0xA2360103,
+		0x81C, 0xA1380103,
+		0x81C, 0xA03A0103,
+		0x81C, 0x823C0103,
+		0x81C, 0x813E0103,
+		0x81C, 0x80400103,
+		0x81C, 0x64420103,
+		0x81C, 0x63440103,
+		0x81C, 0x62460103,
+		0x81C, 0x61480103,
+		0x81C, 0x434A0103,
+		0x81C, 0x424C0103,
+		0x81C, 0x414E0103,
+		0x81C, 0x40500103,
+		0x81C, 0x22520103,
+		0x81C, 0x21540103,
+		0x81C, 0x20560103,
+		0x81C, 0x04580103,
+		0x81C, 0x035A0103,
+		0x81C, 0x025C0103,
+		0x81C, 0x015E0103,
+		0x81C, 0x00600103,
+		0x81C, 0x00620103,
+		0x81C, 0x00640103,
+		0x81C, 0x00660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000103,
+		0x81C, 0xFC020103,
+		0x81C, 0xFB040103,
+		0x81C, 0xFA060103,
+		0x81C, 0xF9080103,
+		0x81C, 0xF80A0103,
+		0x81C, 0xF70C0103,
+		0x81C, 0xF60E0103,
+		0x81C, 0xF5100103,
+		0x81C, 0xF4120103,
+		0x81C, 0xF3140103,
+		0x81C, 0xF2160103,
+		0x81C, 0xF1180103,
+		0x81C, 0xF01A0103,
+		0x81C, 0xEF1C0103,
+		0x81C, 0xEE1E0103,
+		0x81C, 0xED200103,
+		0x81C, 0xEC220103,
+		0x81C, 0xEB240103,
+		0x81C, 0xEA260103,
+		0x81C, 0xE9280103,
+		0x81C, 0xE82A0103,
+		0x81C, 0xE72C0103,
+		0x81C, 0xE62E0103,
+		0x81C, 0xE5300103,
+		0x81C, 0xE4320103,
+		0x81C, 0xE3340103,
+		0x81C, 0xC6360103,
+		0x81C, 0xC5380103,
+		0x81C, 0xC43A0103,
+		0x81C, 0xC33C0103,
+		0x81C, 0xC23E0103,
+		0x81C, 0xA5400103,
+		0x81C, 0xA4420103,
+		0x81C, 0xA3440103,
+		0x81C, 0xA2460103,
+		0x81C, 0xA1480103,
+		0x81C, 0x834A0103,
+		0x81C, 0x824C0103,
+		0x81C, 0x814E0103,
+		0x81C, 0x63500103,
+		0x81C, 0x62520103,
+		0x81C, 0x61540103,
+		0x81C, 0x43560103,
+		0x81C, 0x42580103,
+		0x81C, 0x245A0103,
+		0x81C, 0x235C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x04620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000103,
+		0x81C, 0xF7020103,
+		0x81C, 0xF6040103,
+		0x81C, 0xF5060103,
+		0x81C, 0xF4080103,
+		0x81C, 0xF30A0103,
+		0x81C, 0xF20C0103,
+		0x81C, 0xF10E0103,
+		0x81C, 0xF0100103,
+		0x81C, 0xEF120103,
+		0x81C, 0xEE140103,
+		0x81C, 0xED160103,
+		0x81C, 0xEC180103,
+		0x81C, 0xEB1A0103,
+		0x81C, 0xEA1C0103,
+		0x81C, 0xE91E0103,
+		0x81C, 0xE8200103,
+		0x81C, 0xE7220103,
+		0x81C, 0xE6240103,
+		0x81C, 0xE5260103,
+		0x81C, 0xE4280103,
+		0x81C, 0xE32A0103,
+		0x81C, 0xE22C0103,
+		0x81C, 0xC32E0103,
+		0x81C, 0xC2300103,
+		0x81C, 0xC1320103,
+		0x81C, 0xA3340103,
+		0x81C, 0xA2360103,
+		0x81C, 0xA1380103,
+		0x81C, 0xA03A0103,
+		0x81C, 0x823C0103,
+		0x81C, 0x813E0103,
+		0x81C, 0x80400103,
+		0x81C, 0x64420103,
+		0x81C, 0x63440103,
+		0x81C, 0x62460103,
+		0x81C, 0x61480103,
+		0x81C, 0x434A0103,
+		0x81C, 0x424C0103,
+		0x81C, 0x414E0103,
+		0x81C, 0x40500103,
+		0x81C, 0x22520103,
+		0x81C, 0x21540103,
+		0x81C, 0x20560103,
+		0x81C, 0x04580103,
+		0x81C, 0x035A0103,
+		0x81C, 0x025C0103,
+		0x81C, 0x015E0103,
+		0x81C, 0x00600103,
+		0x81C, 0x00620103,
+		0x81C, 0x00640103,
+		0x81C, 0x00660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000103,
+		0x81C, 0xFC020103,
+		0x81C, 0xFB040103,
+		0x81C, 0xFA060103,
+		0x81C, 0xF9080103,
+		0x81C, 0xF80A0103,
+		0x81C, 0xF70C0103,
+		0x81C, 0xF60E0103,
+		0x81C, 0xF5100103,
+		0x81C, 0xF4120103,
+		0x81C, 0xF3140103,
+		0x81C, 0xF2160103,
+		0x81C, 0xF1180103,
+		0x81C, 0xF01A0103,
+		0x81C, 0xEE1C0103,
+		0x81C, 0xED1E0103,
+		0x81C, 0xEC200103,
+		0x81C, 0xEB220103,
+		0x81C, 0xEA240103,
+		0x81C, 0xE9260103,
+		0x81C, 0xE8280103,
+		0x81C, 0xE72A0103,
+		0x81C, 0xE62C0103,
+		0x81C, 0xE52E0103,
+		0x81C, 0xE4300103,
+		0x81C, 0xE3320103,
+		0x81C, 0xE2340103,
+		0x81C, 0xC5360103,
+		0x81C, 0xC4380103,
+		0x81C, 0xC33A0103,
+		0x81C, 0xC23C0103,
+		0x81C, 0xA53E0103,
+		0x81C, 0xA4400103,
+		0x81C, 0xA3420103,
+		0x81C, 0xA2440103,
+		0x81C, 0xA1460103,
+		0x81C, 0x83480103,
+		0x81C, 0x824A0103,
+		0x81C, 0x814C0103,
+		0x81C, 0x804E0103,
+		0x81C, 0x63500103,
+		0x81C, 0x62520103,
+		0x81C, 0x61540103,
+		0x81C, 0x43560103,
+		0x81C, 0x42580103,
+		0x81C, 0x415A0103,
+		0x81C, 0x405C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000103,
+		0x81C, 0xF8020103,
+		0x81C, 0xF7040103,
+		0x81C, 0xF6060103,
+		0x81C, 0xF5080103,
+		0x81C, 0xF40A0103,
+		0x81C, 0xF30C0103,
+		0x81C, 0xF20E0103,
+		0x81C, 0xF1100103,
+		0x81C, 0xF0120103,
+		0x81C, 0xEF140103,
+		0x81C, 0xEE160103,
+		0x81C, 0xED180103,
+		0x81C, 0xEC1A0103,
+		0x81C, 0xEB1C0103,
+		0x81C, 0xEA1E0103,
+		0x81C, 0xE9200103,
+		0x81C, 0xE8220103,
+		0x81C, 0xE7240103,
+		0x81C, 0xE6260103,
+		0x81C, 0xE5280103,
+		0x81C, 0xE42A0103,
+		0x81C, 0xE32C0103,
+		0x81C, 0xC32E0103,
+		0x81C, 0xC2300103,
+		0x81C, 0xC1320103,
+		0x81C, 0xA4340103,
+		0x81C, 0xA3360103,
+		0x81C, 0xA2380103,
+		0x81C, 0xA13A0103,
+		0x81C, 0xA03C0103,
+		0x81C, 0x823E0103,
+		0x81C, 0x81400103,
+		0x81C, 0x80420103,
+		0x81C, 0x63440103,
+		0x81C, 0x62460103,
+		0x81C, 0x61480103,
+		0x81C, 0x604A0103,
+		0x81C, 0x244C0103,
+		0x81C, 0x234E0103,
+		0x81C, 0x22500103,
+		0x81C, 0x21520103,
+		0x81C, 0x20540103,
+		0x81C, 0x05560103,
+		0x81C, 0x04580103,
+		0x81C, 0x035A0103,
+		0x81C, 0x025C0103,
+		0x81C, 0x015E0103,
+		0x81C, 0x00600103,
+		0x81C, 0x00620103,
+		0x81C, 0x00640103,
+		0x81C, 0x00660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFE000103,
+		0x81C, 0xFD020103,
+		0x81C, 0xFC040103,
+		0x81C, 0xFB060103,
+		0x81C, 0xFA080103,
+		0x81C, 0xF90A0103,
+		0x81C, 0xF80C0103,
+		0x81C, 0xF70E0103,
+		0x81C, 0xF6100103,
+		0x81C, 0xF5120103,
+		0x81C, 0xF4140103,
+		0x81C, 0xF3160103,
+		0x81C, 0xF2180103,
+		0x81C, 0xF11A0103,
+		0x81C, 0xF01C0103,
+		0x81C, 0xEF1E0103,
+		0x81C, 0xEE200103,
+		0x81C, 0xED220103,
+		0x81C, 0xEC240103,
+		0x81C, 0xEB260103,
+		0x81C, 0xEA280103,
+		0x81C, 0xE92A0103,
+		0x81C, 0xE82C0103,
+		0x81C, 0xE72E0103,
+		0x81C, 0xE6300103,
+		0x81C, 0xE5320103,
+		0x81C, 0xE4340103,
+		0x81C, 0xE3360103,
+		0x81C, 0xC6380103,
+		0x81C, 0xC53A0103,
+		0x81C, 0xC43C0103,
+		0x81C, 0xC33E0103,
+		0x81C, 0xA5400103,
+		0x81C, 0xA4420103,
+		0x81C, 0xA3440103,
+		0x81C, 0xA2460103,
+		0x81C, 0xA1480103,
+		0x81C, 0xA04A0103,
+		0x81C, 0x824C0103,
+		0x81C, 0x814E0103,
+		0x81C, 0x80500103,
+		0x81C, 0x64520103,
+		0x81C, 0x63540103,
+		0x81C, 0x62560103,
+		0x81C, 0x61580103,
+		0x81C, 0x605A0103,
+		0x81C, 0x235C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000103,
+		0x81C, 0xFC020103,
+		0x81C, 0xFB040103,
+		0x81C, 0xFA060103,
+		0x81C, 0xF9080103,
+		0x81C, 0xF80A0103,
+		0x81C, 0xF70C0103,
+		0x81C, 0xF60E0103,
+		0x81C, 0xF5100103,
+		0x81C, 0xF4120103,
+		0x81C, 0xF3140103,
+		0x81C, 0xF2160103,
+		0x81C, 0xF1180103,
+		0x81C, 0xF01A0103,
+		0x81C, 0xEE1C0103,
+		0x81C, 0xED1E0103,
+		0x81C, 0xEC200103,
+		0x81C, 0xEB220103,
+		0x81C, 0xEA240103,
+		0x81C, 0xE9260103,
+		0x81C, 0xE8280103,
+		0x81C, 0xE72A0103,
+		0x81C, 0xE62C0103,
+		0x81C, 0xE52E0103,
+		0x81C, 0xE4300103,
+		0x81C, 0xE3320103,
+		0x81C, 0xE2340103,
+		0x81C, 0xC5360103,
+		0x81C, 0xC4380103,
+		0x81C, 0xC33A0103,
+		0x81C, 0xC23C0103,
+		0x81C, 0xA53E0103,
+		0x81C, 0xA4400103,
+		0x81C, 0xA3420103,
+		0x81C, 0xA2440103,
+		0x81C, 0xA1460103,
+		0x81C, 0x83480103,
+		0x81C, 0x824A0103,
+		0x81C, 0x814C0103,
+		0x81C, 0x804E0103,
+		0x81C, 0x63500103,
+		0x81C, 0x62520103,
+		0x81C, 0x61540103,
+		0x81C, 0x43560103,
+		0x81C, 0x42580103,
+		0x81C, 0x415A0103,
+		0x81C, 0x405C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000103,
+		0x81C, 0xFC020103,
+		0x81C, 0xFB040103,
+		0x81C, 0xFA060103,
+		0x81C, 0xF9080103,
+		0x81C, 0xF80A0103,
+		0x81C, 0xF70C0103,
+		0x81C, 0xF60E0103,
+		0x81C, 0xF5100103,
+		0x81C, 0xF4120103,
+		0x81C, 0xF3140103,
+		0x81C, 0xF2160103,
+		0x81C, 0xF1180103,
+		0x81C, 0xF01A0103,
+		0x81C, 0xEE1C0103,
+		0x81C, 0xED1E0103,
+		0x81C, 0xEC200103,
+		0x81C, 0xEB220103,
+		0x81C, 0xEA240103,
+		0x81C, 0xE9260103,
+		0x81C, 0xE8280103,
+		0x81C, 0xE72A0103,
+		0x81C, 0xE62C0103,
+		0x81C, 0xE52E0103,
+		0x81C, 0xE4300103,
+		0x81C, 0xE3320103,
+		0x81C, 0xE2340103,
+		0x81C, 0xC5360103,
+		0x81C, 0xC4380103,
+		0x81C, 0xC33A0103,
+		0x81C, 0xC23C0103,
+		0x81C, 0xA53E0103,
+		0x81C, 0xA4400103,
+		0x81C, 0xA3420103,
+		0x81C, 0xA2440103,
+		0x81C, 0xA1460103,
+		0x81C, 0x83480103,
+		0x81C, 0x824A0103,
+		0x81C, 0x814C0103,
+		0x81C, 0x804E0103,
+		0x81C, 0x63500103,
+		0x81C, 0x62520103,
+		0x81C, 0x61540103,
+		0x81C, 0x43560103,
+		0x81C, 0x42580103,
+		0x81C, 0x415A0103,
+		0x81C, 0x405C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000103,
+		0x81C, 0xFB020103,
+		0x81C, 0xFA040103,
+		0x81C, 0xF9060103,
+		0x81C, 0xF8080103,
+		0x81C, 0xF70A0103,
+		0x81C, 0xF60C0103,
+		0x81C, 0xF50E0103,
+		0x81C, 0xF4100103,
+		0x81C, 0xF3120103,
+		0x81C, 0xF2140103,
+		0x81C, 0xF1160103,
+		0x81C, 0xF0180103,
+		0x81C, 0xEF1A0103,
+		0x81C, 0xEE1C0103,
+		0x81C, 0xED1E0103,
+		0x81C, 0xEC200103,
+		0x81C, 0xEB220103,
+		0x81C, 0xEA240103,
+		0x81C, 0xE9260103,
+		0x81C, 0xE8280103,
+		0x81C, 0xE72A0103,
+		0x81C, 0xE62C0103,
+		0x81C, 0xE52E0103,
+		0x81C, 0xE4300103,
+		0x81C, 0xE3320103,
+		0x81C, 0xE2340103,
+		0x81C, 0xE1360103,
+		0x81C, 0xC3380103,
+		0x81C, 0xC23A0103,
+		0x81C, 0xC13C0103,
+		0x81C, 0xC03E0103,
+		0x81C, 0xA4400103,
+		0x81C, 0xA3420103,
+		0x81C, 0xA2440103,
+		0x81C, 0xA1460103,
+		0x81C, 0x82480103,
+		0x81C, 0x814A0103,
+		0x81C, 0x804C0103,
+		0x81C, 0x634E0103,
+		0x81C, 0x62500103,
+		0x81C, 0x61520103,
+		0x81C, 0x42540103,
+		0x81C, 0x41560103,
+		0x81C, 0x24580103,
+		0x81C, 0x235A0103,
+		0x81C, 0x225C0103,
+		0x81C, 0x215E0103,
+		0x81C, 0x20600103,
+		0x81C, 0x03620103,
+		0x81C, 0x02640103,
+		0x81C, 0x01660103,
+		0x81C, 0x00680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFE000103,
+		0x81C, 0xFD020103,
+		0x81C, 0xFC040103,
+		0x81C, 0xFB060103,
+		0x81C, 0xFA080103,
+		0x81C, 0xF90A0103,
+		0x81C, 0xF80C0103,
+		0x81C, 0xF70E0103,
+		0x81C, 0xF6100103,
+		0x81C, 0xF5120103,
+		0x81C, 0xF4140103,
+		0x81C, 0xF3160103,
+		0x81C, 0xF2180103,
+		0x81C, 0xF11A0103,
+		0x81C, 0xF01C0103,
+		0x81C, 0xEF1E0103,
+		0x81C, 0xEE200103,
+		0x81C, 0xED220103,
+		0x81C, 0xEC240103,
+		0x81C, 0xEB260103,
+		0x81C, 0xEA280103,
+		0x81C, 0xE92A0103,
+		0x81C, 0xE82C0103,
+		0x81C, 0xE72E0103,
+		0x81C, 0xE6300103,
+		0x81C, 0xE5320103,
+		0x81C, 0xE4340103,
+		0x81C, 0xE3360103,
+		0x81C, 0xC6380103,
+		0x81C, 0xC53A0103,
+		0x81C, 0xC43C0103,
+		0x81C, 0xC33E0103,
+		0x81C, 0xA5400103,
+		0x81C, 0xA4420103,
+		0x81C, 0xA3440103,
+		0x81C, 0xA2460103,
+		0x81C, 0xA1480103,
+		0x81C, 0xA04A0103,
+		0x81C, 0x824C0103,
+		0x81C, 0x814E0103,
+		0x81C, 0x80500103,
+		0x81C, 0x64520103,
+		0x81C, 0x63540103,
+		0x81C, 0x62560103,
+		0x81C, 0x61580103,
+		0x81C, 0x605A0103,
+		0x81C, 0x235C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFE000103,
+		0x81C, 0xFD020103,
+		0x81C, 0xFC040103,
+		0x81C, 0xFB060103,
+		0x81C, 0xFA080103,
+		0x81C, 0xF90A0103,
+		0x81C, 0xF80C0103,
+		0x81C, 0xF70E0103,
+		0x81C, 0xF6100103,
+		0x81C, 0xF5120103,
+		0x81C, 0xF4140103,
+		0x81C, 0xF3160103,
+		0x81C, 0xF2180103,
+		0x81C, 0xF11A0103,
+		0x81C, 0xF01C0103,
+		0x81C, 0xEF1E0103,
+		0x81C, 0xEE200103,
+		0x81C, 0xED220103,
+		0x81C, 0xEC240103,
+		0x81C, 0xEB260103,
+		0x81C, 0xEA280103,
+		0x81C, 0xE92A0103,
+		0x81C, 0xE82C0103,
+		0x81C, 0xE72E0103,
+		0x81C, 0xE6300103,
+		0x81C, 0xE5320103,
+		0x81C, 0xE4340103,
+		0x81C, 0xE3360103,
+		0x81C, 0xC6380103,
+		0x81C, 0xC53A0103,
+		0x81C, 0xC43C0103,
+		0x81C, 0xC33E0103,
+		0x81C, 0xA5400103,
+		0x81C, 0xA4420103,
+		0x81C, 0xA3440103,
+		0x81C, 0xA2460103,
+		0x81C, 0xA1480103,
+		0x81C, 0xA04A0103,
+		0x81C, 0x824C0103,
+		0x81C, 0x814E0103,
+		0x81C, 0x80500103,
+		0x81C, 0x64520103,
+		0x81C, 0x63540103,
+		0x81C, 0x62560103,
+		0x81C, 0x61580103,
+		0x81C, 0x605A0103,
+		0x81C, 0x235C0103,
+		0x81C, 0x225E0103,
+		0x81C, 0x21600103,
+		0x81C, 0x20620103,
+		0x81C, 0x03640103,
+		0x81C, 0x02660103,
+		0x81C, 0x01680103,
+		0x81C, 0x006A0103,
+		0x81C, 0x006C0103,
+		0x81C, 0x006E0103,
+		0x81C, 0x00700103,
+		0x81C, 0x00720103,
+		0x81C, 0x00740103,
+		0x81C, 0x00760103,
+		0x81C, 0x00780103,
+		0x81C, 0x007A0103,
+		0x81C, 0x007C0103,
+		0x81C, 0x007E0103,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEE1A0203,
+		0x81C, 0xED1C0203,
+		0x81C, 0xEC1E0203,
+		0x81C, 0xEB200203,
+		0x81C, 0xEA220203,
+		0x81C, 0xE9240203,
+		0x81C, 0xE8260203,
+		0x81C, 0xE7280203,
+		0x81C, 0xE62A0203,
+		0x81C, 0xE52C0203,
+		0x81C, 0xE42E0203,
+		0x81C, 0xE3300203,
+		0x81C, 0xE2320203,
+		0x81C, 0xC6340203,
+		0x81C, 0xC5360203,
+		0x81C, 0xC4380203,
+		0x81C, 0xC33A0203,
+		0x81C, 0xA63C0203,
+		0x81C, 0xA53E0203,
+		0x81C, 0xA4400203,
+		0x81C, 0xA3420203,
+		0x81C, 0xA2440203,
+		0x81C, 0xA1460203,
+		0x81C, 0x83480203,
+		0x81C, 0x824A0203,
+		0x81C, 0x814C0203,
+		0x81C, 0x804E0203,
+		0x81C, 0x63500203,
+		0x81C, 0x62520203,
+		0x81C, 0x61540203,
+		0x81C, 0x42560203,
+		0x81C, 0x41580203,
+		0x81C, 0x405A0203,
+		0x81C, 0x225C0203,
+		0x81C, 0x215E0203,
+		0x81C, 0x20600203,
+		0x81C, 0x04620203,
+		0x81C, 0x03640203,
+		0x81C, 0x02660203,
+		0x81C, 0x01680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000203,
+		0x81C, 0xF6020203,
+		0x81C, 0xF5040203,
+		0x81C, 0xF4060203,
+		0x81C, 0xF3080203,
+		0x81C, 0xF20A0203,
+		0x81C, 0xF10C0203,
+		0x81C, 0xF00E0203,
+		0x81C, 0xEF100203,
+		0x81C, 0xEE120203,
+		0x81C, 0xED140203,
+		0x81C, 0xEC160203,
+		0x81C, 0xEB180203,
+		0x81C, 0xEA1A0203,
+		0x81C, 0xE91C0203,
+		0x81C, 0xE81E0203,
+		0x81C, 0xE7200203,
+		0x81C, 0xE6220203,
+		0x81C, 0xE5240203,
+		0x81C, 0xE4260203,
+		0x81C, 0xE3280203,
+		0x81C, 0xC42A0203,
+		0x81C, 0xC32C0203,
+		0x81C, 0xC22E0203,
+		0x81C, 0xC1300203,
+		0x81C, 0xC0320203,
+		0x81C, 0xA3340203,
+		0x81C, 0xA2360203,
+		0x81C, 0xA1380203,
+		0x81C, 0xA03A0203,
+		0x81C, 0x823C0203,
+		0x81C, 0x813E0203,
+		0x81C, 0x80400203,
+		0x81C, 0x63420203,
+		0x81C, 0x62440203,
+		0x81C, 0x61460203,
+		0x81C, 0x60480203,
+		0x81C, 0x424A0203,
+		0x81C, 0x414C0203,
+		0x81C, 0x404E0203,
+		0x81C, 0x06500203,
+		0x81C, 0x05520203,
+		0x81C, 0x04540203,
+		0x81C, 0x03560203,
+		0x81C, 0x02580203,
+		0x81C, 0x015A0203,
+		0x81C, 0x005C0203,
+		0x81C, 0x005E0203,
+		0x81C, 0x00600203,
+		0x81C, 0x00620203,
+		0x81C, 0x00640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000203,
+		0x81C, 0xF6020203,
+		0x81C, 0xF5040203,
+		0x81C, 0xF4060203,
+		0x81C, 0xF3080203,
+		0x81C, 0xF20A0203,
+		0x81C, 0xF10C0203,
+		0x81C, 0xF00E0203,
+		0x81C, 0xEF100203,
+		0x81C, 0xEE120203,
+		0x81C, 0xED140203,
+		0x81C, 0xEC160203,
+		0x81C, 0xEB180203,
+		0x81C, 0xEA1A0203,
+		0x81C, 0xE91C0203,
+		0x81C, 0xE81E0203,
+		0x81C, 0xE7200203,
+		0x81C, 0xE6220203,
+		0x81C, 0xE5240203,
+		0x81C, 0xE4260203,
+		0x81C, 0xE3280203,
+		0x81C, 0xC42A0203,
+		0x81C, 0xC32C0203,
+		0x81C, 0xC22E0203,
+		0x81C, 0xC1300203,
+		0x81C, 0xC0320203,
+		0x81C, 0xA3340203,
+		0x81C, 0xA2360203,
+		0x81C, 0xA1380203,
+		0x81C, 0xA03A0203,
+		0x81C, 0x823C0203,
+		0x81C, 0x813E0203,
+		0x81C, 0x80400203,
+		0x81C, 0x64420203,
+		0x81C, 0x63440203,
+		0x81C, 0x62460203,
+		0x81C, 0x61480203,
+		0x81C, 0x604A0203,
+		0x81C, 0x414C0203,
+		0x81C, 0x404E0203,
+		0x81C, 0x22500203,
+		0x81C, 0x21520203,
+		0x81C, 0x20540203,
+		0x81C, 0x03560203,
+		0x81C, 0x02580203,
+		0x81C, 0x015A0203,
+		0x81C, 0x005C0203,
+		0x81C, 0x005E0203,
+		0x81C, 0x00600203,
+		0x81C, 0x00620203,
+		0x81C, 0x00640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEF1A0203,
+		0x81C, 0xEE1C0203,
+		0x81C, 0xED1E0203,
+		0x81C, 0xEC200203,
+		0x81C, 0xEB220203,
+		0x81C, 0xEA240203,
+		0x81C, 0xE9260203,
+		0x81C, 0xE8280203,
+		0x81C, 0xE72A0203,
+		0x81C, 0xE62C0203,
+		0x81C, 0xE52E0203,
+		0x81C, 0xE4300203,
+		0x81C, 0xE3320203,
+		0x81C, 0xE2340203,
+		0x81C, 0xC6360203,
+		0x81C, 0xC5380203,
+		0x81C, 0xC43A0203,
+		0x81C, 0xC33C0203,
+		0x81C, 0xA63E0203,
+		0x81C, 0xA5400203,
+		0x81C, 0xA4420203,
+		0x81C, 0xA3440203,
+		0x81C, 0xA2460203,
+		0x81C, 0xA1480203,
+		0x81C, 0x834A0203,
+		0x81C, 0x824C0203,
+		0x81C, 0x814E0203,
+		0x81C, 0x64500203,
+		0x81C, 0x63520203,
+		0x81C, 0x62540203,
+		0x81C, 0x61560203,
+		0x81C, 0x60580203,
+		0x81C, 0x405A0203,
+		0x81C, 0x215C0203,
+		0x81C, 0x205E0203,
+		0x81C, 0x03600203,
+		0x81C, 0x02620203,
+		0x81C, 0x01640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000203,
+		0x81C, 0xF6020203,
+		0x81C, 0xF5040203,
+		0x81C, 0xF4060203,
+		0x81C, 0xF3080203,
+		0x81C, 0xF20A0203,
+		0x81C, 0xF10C0203,
+		0x81C, 0xF00E0203,
+		0x81C, 0xEF100203,
+		0x81C, 0xEE120203,
+		0x81C, 0xED140203,
+		0x81C, 0xEC160203,
+		0x81C, 0xEB180203,
+		0x81C, 0xEA1A0203,
+		0x81C, 0xE91C0203,
+		0x81C, 0xE81E0203,
+		0x81C, 0xE7200203,
+		0x81C, 0xE6220203,
+		0x81C, 0xE5240203,
+		0x81C, 0xE4260203,
+		0x81C, 0xE3280203,
+		0x81C, 0xC42A0203,
+		0x81C, 0xC32C0203,
+		0x81C, 0xC22E0203,
+		0x81C, 0xC1300203,
+		0x81C, 0xC0320203,
+		0x81C, 0xA3340203,
+		0x81C, 0xA2360203,
+		0x81C, 0xA1380203,
+		0x81C, 0xA03A0203,
+		0x81C, 0x823C0203,
+		0x81C, 0x813E0203,
+		0x81C, 0x80400203,
+		0x81C, 0x64420203,
+		0x81C, 0x63440203,
+		0x81C, 0x62460203,
+		0x81C, 0x61480203,
+		0x81C, 0x604A0203,
+		0x81C, 0x414C0203,
+		0x81C, 0x404E0203,
+		0x81C, 0x22500203,
+		0x81C, 0x21520203,
+		0x81C, 0x20540203,
+		0x81C, 0x03560203,
+		0x81C, 0x02580203,
+		0x81C, 0x015A0203,
+		0x81C, 0x005C0203,
+		0x81C, 0x005E0203,
+		0x81C, 0x00600203,
+		0x81C, 0x00620203,
+		0x81C, 0x00640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEF1A0203,
+		0x81C, 0xEE1C0203,
+		0x81C, 0xED1E0203,
+		0x81C, 0xEC200203,
+		0x81C, 0xEB220203,
+		0x81C, 0xEA240203,
+		0x81C, 0xE9260203,
+		0x81C, 0xE8280203,
+		0x81C, 0xE72A0203,
+		0x81C, 0xE62C0203,
+		0x81C, 0xE52E0203,
+		0x81C, 0xE4300203,
+		0x81C, 0xE3320203,
+		0x81C, 0xE2340203,
+		0x81C, 0xE1360203,
+		0x81C, 0xC5380203,
+		0x81C, 0xC43A0203,
+		0x81C, 0xC33C0203,
+		0x81C, 0xC23E0203,
+		0x81C, 0xC1400203,
+		0x81C, 0xA3420203,
+		0x81C, 0xA2440203,
+		0x81C, 0xA1460203,
+		0x81C, 0xA0480203,
+		0x81C, 0x834A0203,
+		0x81C, 0x824C0203,
+		0x81C, 0x814E0203,
+		0x81C, 0x64500203,
+		0x81C, 0x63520203,
+		0x81C, 0x62540203,
+		0x81C, 0x61560203,
+		0x81C, 0x25580203,
+		0x81C, 0x245A0203,
+		0x81C, 0x235C0203,
+		0x81C, 0x225E0203,
+		0x81C, 0x21600203,
+		0x81C, 0x04620203,
+		0x81C, 0x03640203,
+		0x81C, 0x02660203,
+		0x81C, 0x01680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000203,
+		0x81C, 0xF8020203,
+		0x81C, 0xF7040203,
+		0x81C, 0xF6060203,
+		0x81C, 0xF5080203,
+		0x81C, 0xF40A0203,
+		0x81C, 0xF30C0203,
+		0x81C, 0xF20E0203,
+		0x81C, 0xF1100203,
+		0x81C, 0xF0120203,
+		0x81C, 0xEF140203,
+		0x81C, 0xEE160203,
+		0x81C, 0xED180203,
+		0x81C, 0xEC1A0203,
+		0x81C, 0xEB1C0203,
+		0x81C, 0xEA1E0203,
+		0x81C, 0xE9200203,
+		0x81C, 0xE8220203,
+		0x81C, 0xE7240203,
+		0x81C, 0xE6260203,
+		0x81C, 0xE5280203,
+		0x81C, 0xC42A0203,
+		0x81C, 0xC32C0203,
+		0x81C, 0xC22E0203,
+		0x81C, 0xC1300203,
+		0x81C, 0xC0320203,
+		0x81C, 0xA3340203,
+		0x81C, 0xA2360203,
+		0x81C, 0xA1380203,
+		0x81C, 0xA03A0203,
+		0x81C, 0x823C0203,
+		0x81C, 0x813E0203,
+		0x81C, 0x80400203,
+		0x81C, 0x64420203,
+		0x81C, 0x63440203,
+		0x81C, 0x62460203,
+		0x81C, 0x61480203,
+		0x81C, 0x604A0203,
+		0x81C, 0x414C0203,
+		0x81C, 0x404E0203,
+		0x81C, 0x22500203,
+		0x81C, 0x21520203,
+		0x81C, 0x20540203,
+		0x81C, 0x03560203,
+		0x81C, 0x02580203,
+		0x81C, 0x015A0203,
+		0x81C, 0x005C0203,
+		0x81C, 0x005E0203,
+		0x81C, 0x00600203,
+		0x81C, 0x00620203,
+		0x81C, 0x00640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000203,
+		0x81C, 0xF7020203,
+		0x81C, 0xF6040203,
+		0x81C, 0xF5060203,
+		0x81C, 0xF4080203,
+		0x81C, 0xF30A0203,
+		0x81C, 0xF20C0203,
+		0x81C, 0xF10E0203,
+		0x81C, 0xF0100203,
+		0x81C, 0xEF120203,
+		0x81C, 0xEE140203,
+		0x81C, 0xED160203,
+		0x81C, 0xEC180203,
+		0x81C, 0xEB1A0203,
+		0x81C, 0xEA1C0203,
+		0x81C, 0xE91E0203,
+		0x81C, 0xE8200203,
+		0x81C, 0xE7220203,
+		0x81C, 0xE6240203,
+		0x81C, 0xE5260203,
+		0x81C, 0xE4280203,
+		0x81C, 0xE32A0203,
+		0x81C, 0xC42C0203,
+		0x81C, 0xC32E0203,
+		0x81C, 0xC2300203,
+		0x81C, 0xC1320203,
+		0x81C, 0xA3340203,
+		0x81C, 0xA2360203,
+		0x81C, 0xA1380203,
+		0x81C, 0xA03A0203,
+		0x81C, 0x823C0203,
+		0x81C, 0x813E0203,
+		0x81C, 0x80400203,
+		0x81C, 0x65420203,
+		0x81C, 0x64440203,
+		0x81C, 0x63460203,
+		0x81C, 0x62480203,
+		0x81C, 0x614A0203,
+		0x81C, 0x424C0203,
+		0x81C, 0x414E0203,
+		0x81C, 0x40500203,
+		0x81C, 0x22520203,
+		0x81C, 0x21540203,
+		0x81C, 0x20560203,
+		0x81C, 0x04580203,
+		0x81C, 0x035A0203,
+		0x81C, 0x025C0203,
+		0x81C, 0x015E0203,
+		0x81C, 0x00600203,
+		0x81C, 0x00620203,
+		0x81C, 0x00640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000203,
+		0x81C, 0xFA020203,
+		0x81C, 0xF9040203,
+		0x81C, 0xF8060203,
+		0x81C, 0xF7080203,
+		0x81C, 0xF60A0203,
+		0x81C, 0xF50C0203,
+		0x81C, 0xF40E0203,
+		0x81C, 0xF3100203,
+		0x81C, 0xF2120203,
+		0x81C, 0xF1140203,
+		0x81C, 0xF0160203,
+		0x81C, 0xEF180203,
+		0x81C, 0xEE1A0203,
+		0x81C, 0xED1C0203,
+		0x81C, 0xEC1E0203,
+		0x81C, 0xEB200203,
+		0x81C, 0xEA220203,
+		0x81C, 0xE9240203,
+		0x81C, 0xE8260203,
+		0x81C, 0xE7280203,
+		0x81C, 0xE62A0203,
+		0x81C, 0xE52C0203,
+		0x81C, 0xE42E0203,
+		0x81C, 0xE3300203,
+		0x81C, 0xE2320203,
+		0x81C, 0xC6340203,
+		0x81C, 0xC5360203,
+		0x81C, 0xC4380203,
+		0x81C, 0xC33A0203,
+		0x81C, 0xC23C0203,
+		0x81C, 0xC13E0203,
+		0x81C, 0xC0400203,
+		0x81C, 0xA3420203,
+		0x81C, 0xA2440203,
+		0x81C, 0xA1460203,
+		0x81C, 0xA0480203,
+		0x81C, 0x824A0203,
+		0x81C, 0x814C0203,
+		0x81C, 0x804E0203,
+		0x81C, 0x63500203,
+		0x81C, 0x62520203,
+		0x81C, 0x61540203,
+		0x81C, 0x60560203,
+		0x81C, 0x24580203,
+		0x81C, 0x235A0203,
+		0x81C, 0x225C0203,
+		0x81C, 0x215E0203,
+		0x81C, 0x20600203,
+		0x81C, 0x03620203,
+		0x81C, 0x02640203,
+		0x81C, 0x01660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000203,
+		0x81C, 0xF7020203,
+		0x81C, 0xF6040203,
+		0x81C, 0xF5060203,
+		0x81C, 0xF4080203,
+		0x81C, 0xF30A0203,
+		0x81C, 0xF20C0203,
+		0x81C, 0xF10E0203,
+		0x81C, 0xF0100203,
+		0x81C, 0xEF120203,
+		0x81C, 0xEE140203,
+		0x81C, 0xED160203,
+		0x81C, 0xEC180203,
+		0x81C, 0xEB1A0203,
+		0x81C, 0xEA1C0203,
+		0x81C, 0xE91E0203,
+		0x81C, 0xE8200203,
+		0x81C, 0xE7220203,
+		0x81C, 0xE6240203,
+		0x81C, 0xE5260203,
+		0x81C, 0xE4280203,
+		0x81C, 0xE32A0203,
+		0x81C, 0xC42C0203,
+		0x81C, 0xC32E0203,
+		0x81C, 0xC2300203,
+		0x81C, 0xC1320203,
+		0x81C, 0xA3340203,
+		0x81C, 0xA2360203,
+		0x81C, 0xA1380203,
+		0x81C, 0xA03A0203,
+		0x81C, 0x823C0203,
+		0x81C, 0x813E0203,
+		0x81C, 0x80400203,
+		0x81C, 0x65420203,
+		0x81C, 0x64440203,
+		0x81C, 0x63460203,
+		0x81C, 0x62480203,
+		0x81C, 0x614A0203,
+		0x81C, 0x424C0203,
+		0x81C, 0x414E0203,
+		0x81C, 0x40500203,
+		0x81C, 0x22520203,
+		0x81C, 0x21540203,
+		0x81C, 0x20560203,
+		0x81C, 0x04580203,
+		0x81C, 0x035A0203,
+		0x81C, 0x025C0203,
+		0x81C, 0x015E0203,
+		0x81C, 0x00600203,
+		0x81C, 0x00620203,
+		0x81C, 0x00640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEE1A0203,
+		0x81C, 0xED1C0203,
+		0x81C, 0xEC1E0203,
+		0x81C, 0xEB200203,
+		0x81C, 0xEA220203,
+		0x81C, 0xE9240203,
+		0x81C, 0xE8260203,
+		0x81C, 0xE7280203,
+		0x81C, 0xE62A0203,
+		0x81C, 0xE52C0203,
+		0x81C, 0xE42E0203,
+		0x81C, 0xE3300203,
+		0x81C, 0xE2320203,
+		0x81C, 0xC6340203,
+		0x81C, 0xC5360203,
+		0x81C, 0xC4380203,
+		0x81C, 0xC33A0203,
+		0x81C, 0xA63C0203,
+		0x81C, 0xA53E0203,
+		0x81C, 0xA4400203,
+		0x81C, 0xA3420203,
+		0x81C, 0xA2440203,
+		0x81C, 0xA1460203,
+		0x81C, 0x83480203,
+		0x81C, 0x824A0203,
+		0x81C, 0x814C0203,
+		0x81C, 0x804E0203,
+		0x81C, 0x63500203,
+		0x81C, 0x62520203,
+		0x81C, 0x61540203,
+		0x81C, 0x42560203,
+		0x81C, 0x41580203,
+		0x81C, 0x405A0203,
+		0x81C, 0x225C0203,
+		0x81C, 0x215E0203,
+		0x81C, 0x20600203,
+		0x81C, 0x04620203,
+		0x81C, 0x03640203,
+		0x81C, 0x02660203,
+		0x81C, 0x01680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000203,
+		0x81C, 0xF8020203,
+		0x81C, 0xF7040203,
+		0x81C, 0xF6060203,
+		0x81C, 0xF5080203,
+		0x81C, 0xF40A0203,
+		0x81C, 0xF30C0203,
+		0x81C, 0xF20E0203,
+		0x81C, 0xF1100203,
+		0x81C, 0xF0120203,
+		0x81C, 0xEF140203,
+		0x81C, 0xEE160203,
+		0x81C, 0xED180203,
+		0x81C, 0xEC1A0203,
+		0x81C, 0xEB1C0203,
+		0x81C, 0xEA1E0203,
+		0x81C, 0xE9200203,
+		0x81C, 0xE8220203,
+		0x81C, 0xE7240203,
+		0x81C, 0xE6260203,
+		0x81C, 0xE5280203,
+		0x81C, 0xE42A0203,
+		0x81C, 0xC42C0203,
+		0x81C, 0xC32E0203,
+		0x81C, 0xC2300203,
+		0x81C, 0xC1320203,
+		0x81C, 0xA3340203,
+		0x81C, 0xA2360203,
+		0x81C, 0xA1380203,
+		0x81C, 0xA03A0203,
+		0x81C, 0x823C0203,
+		0x81C, 0x813E0203,
+		0x81C, 0x80400203,
+		0x81C, 0x64420203,
+		0x81C, 0x63440203,
+		0x81C, 0x62460203,
+		0x81C, 0x61480203,
+		0x81C, 0x604A0203,
+		0x81C, 0x244C0203,
+		0x81C, 0x234E0203,
+		0x81C, 0x22500203,
+		0x81C, 0x21520203,
+		0x81C, 0x20540203,
+		0x81C, 0x05560203,
+		0x81C, 0x04580203,
+		0x81C, 0x035A0203,
+		0x81C, 0x025C0203,
+		0x81C, 0x015E0203,
+		0x81C, 0x00600203,
+		0x81C, 0x00620203,
+		0x81C, 0x00640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEF1A0203,
+		0x81C, 0xEE1C0203,
+		0x81C, 0xED1E0203,
+		0x81C, 0xEC200203,
+		0x81C, 0xEB220203,
+		0x81C, 0xEA240203,
+		0x81C, 0xE9260203,
+		0x81C, 0xE8280203,
+		0x81C, 0xE72A0203,
+		0x81C, 0xE62C0203,
+		0x81C, 0xE52E0203,
+		0x81C, 0xE4300203,
+		0x81C, 0xE3320203,
+		0x81C, 0xE2340203,
+		0x81C, 0xC6360203,
+		0x81C, 0xC5380203,
+		0x81C, 0xC43A0203,
+		0x81C, 0xC33C0203,
+		0x81C, 0xA63E0203,
+		0x81C, 0xA5400203,
+		0x81C, 0xA4420203,
+		0x81C, 0xA3440203,
+		0x81C, 0xA2460203,
+		0x81C, 0xA1480203,
+		0x81C, 0x834A0203,
+		0x81C, 0x824C0203,
+		0x81C, 0x814E0203,
+		0x81C, 0x64500203,
+		0x81C, 0x63520203,
+		0x81C, 0x62540203,
+		0x81C, 0x61560203,
+		0x81C, 0x60580203,
+		0x81C, 0x405A0203,
+		0x81C, 0x215C0203,
+		0x81C, 0x205E0203,
+		0x81C, 0x03600203,
+		0x81C, 0x02620203,
+		0x81C, 0x01640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEE1A0203,
+		0x81C, 0xED1C0203,
+		0x81C, 0xEC1E0203,
+		0x81C, 0xEB200203,
+		0x81C, 0xEA220203,
+		0x81C, 0xE9240203,
+		0x81C, 0xE8260203,
+		0x81C, 0xE7280203,
+		0x81C, 0xE62A0203,
+		0x81C, 0xE52C0203,
+		0x81C, 0xE42E0203,
+		0x81C, 0xE3300203,
+		0x81C, 0xE2320203,
+		0x81C, 0xC6340203,
+		0x81C, 0xC5360203,
+		0x81C, 0xC4380203,
+		0x81C, 0xC33A0203,
+		0x81C, 0xA63C0203,
+		0x81C, 0xA53E0203,
+		0x81C, 0xA4400203,
+		0x81C, 0xA3420203,
+		0x81C, 0xA2440203,
+		0x81C, 0xA1460203,
+		0x81C, 0x83480203,
+		0x81C, 0x824A0203,
+		0x81C, 0x814C0203,
+		0x81C, 0x804E0203,
+		0x81C, 0x63500203,
+		0x81C, 0x62520203,
+		0x81C, 0x61540203,
+		0x81C, 0x42560203,
+		0x81C, 0x41580203,
+		0x81C, 0x405A0203,
+		0x81C, 0x225C0203,
+		0x81C, 0x215E0203,
+		0x81C, 0x20600203,
+		0x81C, 0x04620203,
+		0x81C, 0x03640203,
+		0x81C, 0x02660203,
+		0x81C, 0x01680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEE1A0203,
+		0x81C, 0xED1C0203,
+		0x81C, 0xEC1E0203,
+		0x81C, 0xEB200203,
+		0x81C, 0xEA220203,
+		0x81C, 0xE9240203,
+		0x81C, 0xE8260203,
+		0x81C, 0xE7280203,
+		0x81C, 0xE62A0203,
+		0x81C, 0xE52C0203,
+		0x81C, 0xE42E0203,
+		0x81C, 0xE3300203,
+		0x81C, 0xE2320203,
+		0x81C, 0xC6340203,
+		0x81C, 0xC5360203,
+		0x81C, 0xC4380203,
+		0x81C, 0xC33A0203,
+		0x81C, 0xA63C0203,
+		0x81C, 0xA53E0203,
+		0x81C, 0xA4400203,
+		0x81C, 0xA3420203,
+		0x81C, 0xA2440203,
+		0x81C, 0xA1460203,
+		0x81C, 0x83480203,
+		0x81C, 0x824A0203,
+		0x81C, 0x814C0203,
+		0x81C, 0x804E0203,
+		0x81C, 0x63500203,
+		0x81C, 0x62520203,
+		0x81C, 0x61540203,
+		0x81C, 0x42560203,
+		0x81C, 0x41580203,
+		0x81C, 0x405A0203,
+		0x81C, 0x225C0203,
+		0x81C, 0x215E0203,
+		0x81C, 0x20600203,
+		0x81C, 0x04620203,
+		0x81C, 0x03640203,
+		0x81C, 0x02660203,
+		0x81C, 0x01680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEF1A0203,
+		0x81C, 0xEE1C0203,
+		0x81C, 0xED1E0203,
+		0x81C, 0xEC200203,
+		0x81C, 0xEB220203,
+		0x81C, 0xEA240203,
+		0x81C, 0xE9260203,
+		0x81C, 0xE8280203,
+		0x81C, 0xE72A0203,
+		0x81C, 0xE62C0203,
+		0x81C, 0xE52E0203,
+		0x81C, 0xE4300203,
+		0x81C, 0xE3320203,
+		0x81C, 0xE2340203,
+		0x81C, 0xE1360203,
+		0x81C, 0xE0380203,
+		0x81C, 0xC33A0203,
+		0x81C, 0xC23C0203,
+		0x81C, 0xC13E0203,
+		0x81C, 0xA3400203,
+		0x81C, 0xA2420203,
+		0x81C, 0xA1440203,
+		0x81C, 0xA0460203,
+		0x81C, 0x83480203,
+		0x81C, 0x824A0203,
+		0x81C, 0x814C0203,
+		0x81C, 0x644E0203,
+		0x81C, 0x63500203,
+		0x81C, 0x62520203,
+		0x81C, 0x61540203,
+		0x81C, 0x42560203,
+		0x81C, 0x41580203,
+		0x81C, 0x235A0203,
+		0x81C, 0x225C0203,
+		0x81C, 0x215E0203,
+		0x81C, 0x04600203,
+		0x81C, 0x03620203,
+		0x81C, 0x02640203,
+		0x81C, 0x01660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000203,
+		0x81C, 0xFB020203,
+		0x81C, 0xFA040203,
+		0x81C, 0xF9060203,
+		0x81C, 0xF8080203,
+		0x81C, 0xF70A0203,
+		0x81C, 0xF60C0203,
+		0x81C, 0xF50E0203,
+		0x81C, 0xF4100203,
+		0x81C, 0xF3120203,
+		0x81C, 0xF2140203,
+		0x81C, 0xF1160203,
+		0x81C, 0xF0180203,
+		0x81C, 0xEF1A0203,
+		0x81C, 0xEE1C0203,
+		0x81C, 0xED1E0203,
+		0x81C, 0xEC200203,
+		0x81C, 0xEB220203,
+		0x81C, 0xEA240203,
+		0x81C, 0xE9260203,
+		0x81C, 0xE8280203,
+		0x81C, 0xE72A0203,
+		0x81C, 0xE62C0203,
+		0x81C, 0xE52E0203,
+		0x81C, 0xE4300203,
+		0x81C, 0xE3320203,
+		0x81C, 0xE2340203,
+		0x81C, 0xC6360203,
+		0x81C, 0xC5380203,
+		0x81C, 0xC43A0203,
+		0x81C, 0xC33C0203,
+		0x81C, 0xA63E0203,
+		0x81C, 0xA5400203,
+		0x81C, 0xA4420203,
+		0x81C, 0xA3440203,
+		0x81C, 0xA2460203,
+		0x81C, 0xA1480203,
+		0x81C, 0x834A0203,
+		0x81C, 0x824C0203,
+		0x81C, 0x814E0203,
+		0x81C, 0x64500203,
+		0x81C, 0x63520203,
+		0x81C, 0x62540203,
+		0x81C, 0x61560203,
+		0x81C, 0x60580203,
+		0x81C, 0x405A0203,
+		0x81C, 0x215C0203,
+		0x81C, 0x205E0203,
+		0x81C, 0x03600203,
+		0x81C, 0x02620203,
+		0x81C, 0x01640203,
+		0x81C, 0x00660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFD000203,
+		0x81C, 0xFC020203,
+		0x81C, 0xFB040203,
+		0x81C, 0xFA060203,
+		0x81C, 0xF9080203,
+		0x81C, 0xF80A0203,
+		0x81C, 0xF70C0203,
+		0x81C, 0xF60E0203,
+		0x81C, 0xF5100203,
+		0x81C, 0xF4120203,
+		0x81C, 0xF3140203,
+		0x81C, 0xF2160203,
+		0x81C, 0xF1180203,
+		0x81C, 0xF01A0203,
+		0x81C, 0xEF1C0203,
+		0x81C, 0xEE1E0203,
+		0x81C, 0xED200203,
+		0x81C, 0xEC220203,
+		0x81C, 0xEB240203,
+		0x81C, 0xEA260203,
+		0x81C, 0xE9280203,
+		0x81C, 0xE82A0203,
+		0x81C, 0xE72C0203,
+		0x81C, 0xE62E0203,
+		0x81C, 0xE5300203,
+		0x81C, 0xE4320203,
+		0x81C, 0xE3340203,
+		0x81C, 0xC6360203,
+		0x81C, 0xC5380203,
+		0x81C, 0xC43A0203,
+		0x81C, 0xC33C0203,
+		0x81C, 0xA63E0203,
+		0x81C, 0xA5400203,
+		0x81C, 0xA4420203,
+		0x81C, 0xA3440203,
+		0x81C, 0xA2460203,
+		0x81C, 0xA1480203,
+		0x81C, 0x834A0203,
+		0x81C, 0x824C0203,
+		0x81C, 0x814E0203,
+		0x81C, 0x64500203,
+		0x81C, 0x63520203,
+		0x81C, 0x62540203,
+		0x81C, 0x61560203,
+		0x81C, 0x60580203,
+		0x81C, 0x235A0203,
+		0x81C, 0x225C0203,
+		0x81C, 0x215E0203,
+		0x81C, 0x20600203,
+		0x81C, 0x03620203,
+		0x81C, 0x02640203,
+		0x81C, 0x01660203,
+		0x81C, 0x00680203,
+		0x81C, 0x006A0203,
+		0x81C, 0x006C0203,
+		0x81C, 0x006E0203,
+		0x81C, 0x00700203,
+		0x81C, 0x00720203,
+		0x81C, 0x00740203,
+		0x81C, 0x00760203,
+		0x81C, 0x00780203,
+		0x81C, 0x007A0203,
+		0x81C, 0x007C0203,
+		0x81C, 0x007E0203,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000303,
+		0x81C, 0xFB020303,
+		0x81C, 0xFA040303,
+		0x81C, 0xF9060303,
+		0x81C, 0xF8080303,
+		0x81C, 0xF70A0303,
+		0x81C, 0xF60C0303,
+		0x81C, 0xF50E0303,
+		0x81C, 0xF4100303,
+		0x81C, 0xF3120303,
+		0x81C, 0xF2140303,
+		0x81C, 0xF1160303,
+		0x81C, 0xEF180303,
+		0x81C, 0xEE1A0303,
+		0x81C, 0xED1C0303,
+		0x81C, 0xEC1E0303,
+		0x81C, 0xEB200303,
+		0x81C, 0xEA220303,
+		0x81C, 0xE9240303,
+		0x81C, 0xE8260303,
+		0x81C, 0xE7280303,
+		0x81C, 0xE62A0303,
+		0x81C, 0xE52C0303,
+		0x81C, 0xE42E0303,
+		0x81C, 0xE3300303,
+		0x81C, 0xE2320303,
+		0x81C, 0xC6340303,
+		0x81C, 0xC5360303,
+		0x81C, 0xC4380303,
+		0x81C, 0xC33A0303,
+		0x81C, 0xA63C0303,
+		0x81C, 0xA53E0303,
+		0x81C, 0xA4400303,
+		0x81C, 0xA3420303,
+		0x81C, 0xA2440303,
+		0x81C, 0xA1460303,
+		0x81C, 0x83480303,
+		0x81C, 0x824A0303,
+		0x81C, 0x814C0303,
+		0x81C, 0x804E0303,
+		0x81C, 0x63500303,
+		0x81C, 0x62520303,
+		0x81C, 0x61540303,
+		0x81C, 0x42560303,
+		0x81C, 0x41580303,
+		0x81C, 0x405A0303,
+		0x81C, 0x225C0303,
+		0x81C, 0x215E0303,
+		0x81C, 0x20600303,
+		0x81C, 0x04620303,
+		0x81C, 0x03640303,
+		0x81C, 0x02660303,
+		0x81C, 0x01680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000303,
+		0x81C, 0xF6020303,
+		0x81C, 0xF5040303,
+		0x81C, 0xF4060303,
+		0x81C, 0xF3080303,
+		0x81C, 0xF20A0303,
+		0x81C, 0xF10C0303,
+		0x81C, 0xF00E0303,
+		0x81C, 0xEF100303,
+		0x81C, 0xEE120303,
+		0x81C, 0xED140303,
+		0x81C, 0xEC160303,
+		0x81C, 0xEB180303,
+		0x81C, 0xEA1A0303,
+		0x81C, 0xE91C0303,
+		0x81C, 0xCA1E0303,
+		0x81C, 0xC9200303,
+		0x81C, 0xC8220303,
+		0x81C, 0xC7240303,
+		0x81C, 0xC6260303,
+		0x81C, 0xC5280303,
+		0x81C, 0xC42A0303,
+		0x81C, 0xC32C0303,
+		0x81C, 0xC22E0303,
+		0x81C, 0xC1300303,
+		0x81C, 0xA4320303,
+		0x81C, 0xA3340303,
+		0x81C, 0xA2360303,
+		0x81C, 0xA1380303,
+		0x81C, 0xA03A0303,
+		0x81C, 0x823C0303,
+		0x81C, 0x813E0303,
+		0x81C, 0x80400303,
+		0x81C, 0x64420303,
+		0x81C, 0x63440303,
+		0x81C, 0x62460303,
+		0x81C, 0x61480303,
+		0x81C, 0x604A0303,
+		0x81C, 0x414C0303,
+		0x81C, 0x404E0303,
+		0x81C, 0x06500303,
+		0x81C, 0x05520303,
+		0x81C, 0x04540303,
+		0x81C, 0x03560303,
+		0x81C, 0x02580303,
+		0x81C, 0x015A0303,
+		0x81C, 0x005C0303,
+		0x81C, 0x005E0303,
+		0x81C, 0x00600303,
+		0x81C, 0x00620303,
+		0x81C, 0x00640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000303,
+		0x81C, 0xF6020303,
+		0x81C, 0xF5040303,
+		0x81C, 0xF4060303,
+		0x81C, 0xF3080303,
+		0x81C, 0xF20A0303,
+		0x81C, 0xF10C0303,
+		0x81C, 0xF00E0303,
+		0x81C, 0xEF100303,
+		0x81C, 0xEE120303,
+		0x81C, 0xED140303,
+		0x81C, 0xEC160303,
+		0x81C, 0xEB180303,
+		0x81C, 0xEA1A0303,
+		0x81C, 0xE91C0303,
+		0x81C, 0xCA1E0303,
+		0x81C, 0xC9200303,
+		0x81C, 0xC8220303,
+		0x81C, 0xC7240303,
+		0x81C, 0xC6260303,
+		0x81C, 0xC5280303,
+		0x81C, 0xC42A0303,
+		0x81C, 0xC32C0303,
+		0x81C, 0xC22E0303,
+		0x81C, 0xC1300303,
+		0x81C, 0xA4320303,
+		0x81C, 0xA3340303,
+		0x81C, 0xA2360303,
+		0x81C, 0xA1380303,
+		0x81C, 0xA03A0303,
+		0x81C, 0x823C0303,
+		0x81C, 0x813E0303,
+		0x81C, 0x80400303,
+		0x81C, 0x64420303,
+		0x81C, 0x63440303,
+		0x81C, 0x62460303,
+		0x81C, 0x61480303,
+		0x81C, 0x604A0303,
+		0x81C, 0x414C0303,
+		0x81C, 0x404E0303,
+		0x81C, 0x22500303,
+		0x81C, 0x21520303,
+		0x81C, 0x20540303,
+		0x81C, 0x03560303,
+		0x81C, 0x02580303,
+		0x81C, 0x015A0303,
+		0x81C, 0x005C0303,
+		0x81C, 0x005E0303,
+		0x81C, 0x00600303,
+		0x81C, 0x00620303,
+		0x81C, 0x00640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000303,
+		0x81C, 0xFB020303,
+		0x81C, 0xFA040303,
+		0x81C, 0xF9060303,
+		0x81C, 0xF8080303,
+		0x81C, 0xF70A0303,
+		0x81C, 0xF60C0303,
+		0x81C, 0xF50E0303,
+		0x81C, 0xF4100303,
+		0x81C, 0xF3120303,
+		0x81C, 0xF2140303,
+		0x81C, 0xF1160303,
+		0x81C, 0xF0180303,
+		0x81C, 0xEF1A0303,
+		0x81C, 0xEE1C0303,
+		0x81C, 0xED1E0303,
+		0x81C, 0xEC200303,
+		0x81C, 0xEB220303,
+		0x81C, 0xEA240303,
+		0x81C, 0xE9260303,
+		0x81C, 0xE8280303,
+		0x81C, 0xE72A0303,
+		0x81C, 0xE62C0303,
+		0x81C, 0xE52E0303,
+		0x81C, 0xE4300303,
+		0x81C, 0xE3320303,
+		0x81C, 0xE2340303,
+		0x81C, 0xC6360303,
+		0x81C, 0xC5380303,
+		0x81C, 0xC43A0303,
+		0x81C, 0xC33C0303,
+		0x81C, 0xA63E0303,
+		0x81C, 0xA5400303,
+		0x81C, 0xA4420303,
+		0x81C, 0xA3440303,
+		0x81C, 0xA2460303,
+		0x81C, 0x84480303,
+		0x81C, 0x834A0303,
+		0x81C, 0x824C0303,
+		0x81C, 0x814E0303,
+		0x81C, 0x80500303,
+		0x81C, 0x63520303,
+		0x81C, 0x62540303,
+		0x81C, 0x61560303,
+		0x81C, 0x60580303,
+		0x81C, 0x225A0303,
+		0x81C, 0x055C0303,
+		0x81C, 0x045E0303,
+		0x81C, 0x03600303,
+		0x81C, 0x02620303,
+		0x81C, 0x01640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000303,
+		0x81C, 0xF6020303,
+		0x81C, 0xF5040303,
+		0x81C, 0xF4060303,
+		0x81C, 0xF3080303,
+		0x81C, 0xF20A0303,
+		0x81C, 0xF10C0303,
+		0x81C, 0xF00E0303,
+		0x81C, 0xEF100303,
+		0x81C, 0xEE120303,
+		0x81C, 0xED140303,
+		0x81C, 0xEC160303,
+		0x81C, 0xEB180303,
+		0x81C, 0xEA1A0303,
+		0x81C, 0xE91C0303,
+		0x81C, 0xCA1E0303,
+		0x81C, 0xC9200303,
+		0x81C, 0xC8220303,
+		0x81C, 0xC7240303,
+		0x81C, 0xC6260303,
+		0x81C, 0xC5280303,
+		0x81C, 0xC42A0303,
+		0x81C, 0xC32C0303,
+		0x81C, 0xC22E0303,
+		0x81C, 0xC1300303,
+		0x81C, 0xA4320303,
+		0x81C, 0xA3340303,
+		0x81C, 0xA2360303,
+		0x81C, 0xA1380303,
+		0x81C, 0xA03A0303,
+		0x81C, 0x823C0303,
+		0x81C, 0x813E0303,
+		0x81C, 0x80400303,
+		0x81C, 0x64420303,
+		0x81C, 0x63440303,
+		0x81C, 0x62460303,
+		0x81C, 0x61480303,
+		0x81C, 0x604A0303,
+		0x81C, 0x414C0303,
+		0x81C, 0x404E0303,
+		0x81C, 0x22500303,
+		0x81C, 0x21520303,
+		0x81C, 0x20540303,
+		0x81C, 0x03560303,
+		0x81C, 0x02580303,
+		0x81C, 0x015A0303,
+		0x81C, 0x005C0303,
+		0x81C, 0x005E0303,
+		0x81C, 0x00600303,
+		0x81C, 0x00620303,
+		0x81C, 0x00640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000303,
+		0x81C, 0xFA020303,
+		0x81C, 0xF9040303,
+		0x81C, 0xF8060303,
+		0x81C, 0xF7080303,
+		0x81C, 0xF60A0303,
+		0x81C, 0xF50C0303,
+		0x81C, 0xF40E0303,
+		0x81C, 0xF3100303,
+		0x81C, 0xF2120303,
+		0x81C, 0xF1140303,
+		0x81C, 0xF0160303,
+		0x81C, 0xEF180303,
+		0x81C, 0xEE1A0303,
+		0x81C, 0xED1C0303,
+		0x81C, 0xEC1E0303,
+		0x81C, 0xEB200303,
+		0x81C, 0xEA220303,
+		0x81C, 0xE9240303,
+		0x81C, 0xE8260303,
+		0x81C, 0xE7280303,
+		0x81C, 0xE62A0303,
+		0x81C, 0xE52C0303,
+		0x81C, 0xE42E0303,
+		0x81C, 0xE3300303,
+		0x81C, 0xE2320303,
+		0x81C, 0xE1340303,
+		0x81C, 0xC5360303,
+		0x81C, 0xC4380303,
+		0x81C, 0xC33A0303,
+		0x81C, 0xC23C0303,
+		0x81C, 0xC13E0303,
+		0x81C, 0xA4400303,
+		0x81C, 0xA3420303,
+		0x81C, 0xA2440303,
+		0x81C, 0xA1460303,
+		0x81C, 0x83480303,
+		0x81C, 0x824A0303,
+		0x81C, 0x814C0303,
+		0x81C, 0x804E0303,
+		0x81C, 0x64500303,
+		0x81C, 0x63520303,
+		0x81C, 0x62540303,
+		0x81C, 0x61560303,
+		0x81C, 0x60580303,
+		0x81C, 0x235A0303,
+		0x81C, 0x225C0303,
+		0x81C, 0x215E0303,
+		0x81C, 0x20600303,
+		0x81C, 0x04620303,
+		0x81C, 0x03640303,
+		0x81C, 0x02660303,
+		0x81C, 0x01680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000303,
+		0x81C, 0xF8020303,
+		0x81C, 0xF7040303,
+		0x81C, 0xF6060303,
+		0x81C, 0xF5080303,
+		0x81C, 0xF40A0303,
+		0x81C, 0xF30C0303,
+		0x81C, 0xF20E0303,
+		0x81C, 0xF1100303,
+		0x81C, 0xF0120303,
+		0x81C, 0xEF140303,
+		0x81C, 0xEE160303,
+		0x81C, 0xED180303,
+		0x81C, 0xEC1A0303,
+		0x81C, 0xEB1C0303,
+		0x81C, 0xEA1E0303,
+		0x81C, 0xC9200303,
+		0x81C, 0xC8220303,
+		0x81C, 0xC7240303,
+		0x81C, 0xC6260303,
+		0x81C, 0xC5280303,
+		0x81C, 0xC42A0303,
+		0x81C, 0xC32C0303,
+		0x81C, 0xC22E0303,
+		0x81C, 0xC1300303,
+		0x81C, 0xC0320303,
+		0x81C, 0xA3340303,
+		0x81C, 0xA2360303,
+		0x81C, 0xA1380303,
+		0x81C, 0xA03A0303,
+		0x81C, 0x823C0303,
+		0x81C, 0x813E0303,
+		0x81C, 0x80400303,
+		0x81C, 0x64420303,
+		0x81C, 0x63440303,
+		0x81C, 0x62460303,
+		0x81C, 0x61480303,
+		0x81C, 0x604A0303,
+		0x81C, 0x414C0303,
+		0x81C, 0x404E0303,
+		0x81C, 0x22500303,
+		0x81C, 0x21520303,
+		0x81C, 0x20540303,
+		0x81C, 0x03560303,
+		0x81C, 0x02580303,
+		0x81C, 0x015A0303,
+		0x81C, 0x005C0303,
+		0x81C, 0x005E0303,
+		0x81C, 0x00600303,
+		0x81C, 0x00620303,
+		0x81C, 0x00640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000303,
+		0x81C, 0xF7020303,
+		0x81C, 0xF6040303,
+		0x81C, 0xF5060303,
+		0x81C, 0xF4080303,
+		0x81C, 0xF30A0303,
+		0x81C, 0xF20C0303,
+		0x81C, 0xF10E0303,
+		0x81C, 0xF0100303,
+		0x81C, 0xEF120303,
+		0x81C, 0xEE140303,
+		0x81C, 0xED160303,
+		0x81C, 0xEC180303,
+		0x81C, 0xEB1A0303,
+		0x81C, 0xEA1C0303,
+		0x81C, 0xE91E0303,
+		0x81C, 0xCA200303,
+		0x81C, 0xC9220303,
+		0x81C, 0xC8240303,
+		0x81C, 0xC7260303,
+		0x81C, 0xC6280303,
+		0x81C, 0xC52A0303,
+		0x81C, 0xC42C0303,
+		0x81C, 0xC32E0303,
+		0x81C, 0xC2300303,
+		0x81C, 0xC1320303,
+		0x81C, 0xA3340303,
+		0x81C, 0xA2360303,
+		0x81C, 0xA1380303,
+		0x81C, 0xA03A0303,
+		0x81C, 0x823C0303,
+		0x81C, 0x813E0303,
+		0x81C, 0x80400303,
+		0x81C, 0x65420303,
+		0x81C, 0x64440303,
+		0x81C, 0x63460303,
+		0x81C, 0x62480303,
+		0x81C, 0x614A0303,
+		0x81C, 0x424C0303,
+		0x81C, 0x414E0303,
+		0x81C, 0x40500303,
+		0x81C, 0x22520303,
+		0x81C, 0x21540303,
+		0x81C, 0x20560303,
+		0x81C, 0x04580303,
+		0x81C, 0x035A0303,
+		0x81C, 0x025C0303,
+		0x81C, 0x015E0303,
+		0x81C, 0x00600303,
+		0x81C, 0x00620303,
+		0x81C, 0x00640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000303,
+		0x81C, 0xFA020303,
+		0x81C, 0xF9040303,
+		0x81C, 0xF8060303,
+		0x81C, 0xF7080303,
+		0x81C, 0xF60A0303,
+		0x81C, 0xF50C0303,
+		0x81C, 0xF40E0303,
+		0x81C, 0xF3100303,
+		0x81C, 0xF2120303,
+		0x81C, 0xF1140303,
+		0x81C, 0xF0160303,
+		0x81C, 0xEF180303,
+		0x81C, 0xEE1A0303,
+		0x81C, 0xED1C0303,
+		0x81C, 0xEC1E0303,
+		0x81C, 0xEB200303,
+		0x81C, 0xEA220303,
+		0x81C, 0xE9240303,
+		0x81C, 0xE8260303,
+		0x81C, 0xE7280303,
+		0x81C, 0xE62A0303,
+		0x81C, 0xE52C0303,
+		0x81C, 0xE42E0303,
+		0x81C, 0xE3300303,
+		0x81C, 0xE2320303,
+		0x81C, 0xC6340303,
+		0x81C, 0xC5360303,
+		0x81C, 0xC4380303,
+		0x81C, 0xC33A0303,
+		0x81C, 0xC23C0303,
+		0x81C, 0xC13E0303,
+		0x81C, 0xA4400303,
+		0x81C, 0xA3420303,
+		0x81C, 0xA2440303,
+		0x81C, 0xA1460303,
+		0x81C, 0x83480303,
+		0x81C, 0x824A0303,
+		0x81C, 0x814C0303,
+		0x81C, 0x804E0303,
+		0x81C, 0x63500303,
+		0x81C, 0x62520303,
+		0x81C, 0x43540303,
+		0x81C, 0x42560303,
+		0x81C, 0x41580303,
+		0x81C, 0x235A0303,
+		0x81C, 0x225C0303,
+		0x81C, 0x215E0303,
+		0x81C, 0x20600303,
+		0x81C, 0x04620303,
+		0x81C, 0x03640303,
+		0x81C, 0x02660303,
+		0x81C, 0x01680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000303,
+		0x81C, 0xF7020303,
+		0x81C, 0xF6040303,
+		0x81C, 0xF5060303,
+		0x81C, 0xF4080303,
+		0x81C, 0xF30A0303,
+		0x81C, 0xF20C0303,
+		0x81C, 0xF10E0303,
+		0x81C, 0xF0100303,
+		0x81C, 0xEF120303,
+		0x81C, 0xEE140303,
+		0x81C, 0xED160303,
+		0x81C, 0xEC180303,
+		0x81C, 0xEB1A0303,
+		0x81C, 0xEA1C0303,
+		0x81C, 0xE91E0303,
+		0x81C, 0xCA200303,
+		0x81C, 0xC9220303,
+		0x81C, 0xC8240303,
+		0x81C, 0xC7260303,
+		0x81C, 0xC6280303,
+		0x81C, 0xC52A0303,
+		0x81C, 0xC42C0303,
+		0x81C, 0xC32E0303,
+		0x81C, 0xC2300303,
+		0x81C, 0xC1320303,
+		0x81C, 0xA3340303,
+		0x81C, 0xA2360303,
+		0x81C, 0xA1380303,
+		0x81C, 0xA03A0303,
+		0x81C, 0x823C0303,
+		0x81C, 0x813E0303,
+		0x81C, 0x80400303,
+		0x81C, 0x65420303,
+		0x81C, 0x64440303,
+		0x81C, 0x63460303,
+		0x81C, 0x62480303,
+		0x81C, 0x614A0303,
+		0x81C, 0x424C0303,
+		0x81C, 0x414E0303,
+		0x81C, 0x40500303,
+		0x81C, 0x22520303,
+		0x81C, 0x21540303,
+		0x81C, 0x20560303,
+		0x81C, 0x04580303,
+		0x81C, 0x035A0303,
+		0x81C, 0x025C0303,
+		0x81C, 0x015E0303,
+		0x81C, 0x00600303,
+		0x81C, 0x00620303,
+		0x81C, 0x00640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000303,
+		0x81C, 0xFB020303,
+		0x81C, 0xFA040303,
+		0x81C, 0xF9060303,
+		0x81C, 0xF8080303,
+		0x81C, 0xF70A0303,
+		0x81C, 0xF60C0303,
+		0x81C, 0xF50E0303,
+		0x81C, 0xF4100303,
+		0x81C, 0xF3120303,
+		0x81C, 0xF2140303,
+		0x81C, 0xF1160303,
+		0x81C, 0xEF180303,
+		0x81C, 0xEE1A0303,
+		0x81C, 0xED1C0303,
+		0x81C, 0xEC1E0303,
+		0x81C, 0xEB200303,
+		0x81C, 0xEA220303,
+		0x81C, 0xE9240303,
+		0x81C, 0xE8260303,
+		0x81C, 0xE7280303,
+		0x81C, 0xE62A0303,
+		0x81C, 0xE52C0303,
+		0x81C, 0xE42E0303,
+		0x81C, 0xE3300303,
+		0x81C, 0xE2320303,
+		0x81C, 0xC6340303,
+		0x81C, 0xC5360303,
+		0x81C, 0xC4380303,
+		0x81C, 0xC33A0303,
+		0x81C, 0xA63C0303,
+		0x81C, 0xA53E0303,
+		0x81C, 0xA4400303,
+		0x81C, 0xA3420303,
+		0x81C, 0xA2440303,
+		0x81C, 0xA1460303,
+		0x81C, 0x83480303,
+		0x81C, 0x824A0303,
+		0x81C, 0x814C0303,
+		0x81C, 0x804E0303,
+		0x81C, 0x63500303,
+		0x81C, 0x62520303,
+		0x81C, 0x61540303,
+		0x81C, 0x42560303,
+		0x81C, 0x41580303,
+		0x81C, 0x405A0303,
+		0x81C, 0x225C0303,
+		0x81C, 0x215E0303,
+		0x81C, 0x20600303,
+		0x81C, 0x04620303,
+		0x81C, 0x03640303,
+		0x81C, 0x02660303,
+		0x81C, 0x01680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000303,
+		0x81C, 0xF7020303,
+		0x81C, 0xF6040303,
+		0x81C, 0xF5060303,
+		0x81C, 0xF4080303,
+		0x81C, 0xF30A0303,
+		0x81C, 0xF20C0303,
+		0x81C, 0xF10E0303,
+		0x81C, 0xF0100303,
+		0x81C, 0xEF120303,
+		0x81C, 0xEE140303,
+		0x81C, 0xED160303,
+		0x81C, 0xEC180303,
+		0x81C, 0xEB1A0303,
+		0x81C, 0xEA1C0303,
+		0x81C, 0xE91E0303,
+		0x81C, 0xCA200303,
+		0x81C, 0xC9220303,
+		0x81C, 0xC8240303,
+		0x81C, 0xC7260303,
+		0x81C, 0xC6280303,
+		0x81C, 0xC52A0303,
+		0x81C, 0xC42C0303,
+		0x81C, 0xC32E0303,
+		0x81C, 0xC2300303,
+		0x81C, 0xC1320303,
+		0x81C, 0xA3340303,
+		0x81C, 0xA2360303,
+		0x81C, 0xA1380303,
+		0x81C, 0xA03A0303,
+		0x81C, 0x823C0303,
+		0x81C, 0x813E0303,
+		0x81C, 0x80400303,
+		0x81C, 0x64420303,
+		0x81C, 0x63440303,
+		0x81C, 0x62460303,
+		0x81C, 0x61480303,
+		0x81C, 0x604A0303,
+		0x81C, 0x234C0303,
+		0x81C, 0x224E0303,
+		0x81C, 0x21500303,
+		0x81C, 0x20520303,
+		0x81C, 0x06540303,
+		0x81C, 0x05560303,
+		0x81C, 0x04580303,
+		0x81C, 0x035A0303,
+		0x81C, 0x025C0303,
+		0x81C, 0x015E0303,
+		0x81C, 0x00600303,
+		0x81C, 0x00620303,
+		0x81C, 0x00640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000303,
+		0x81C, 0xFB020303,
+		0x81C, 0xFA040303,
+		0x81C, 0xF9060303,
+		0x81C, 0xF8080303,
+		0x81C, 0xF70A0303,
+		0x81C, 0xF60C0303,
+		0x81C, 0xF50E0303,
+		0x81C, 0xF4100303,
+		0x81C, 0xF3120303,
+		0x81C, 0xF2140303,
+		0x81C, 0xF1160303,
+		0x81C, 0xF0180303,
+		0x81C, 0xEF1A0303,
+		0x81C, 0xEE1C0303,
+		0x81C, 0xED1E0303,
+		0x81C, 0xEC200303,
+		0x81C, 0xEB220303,
+		0x81C, 0xEA240303,
+		0x81C, 0xE9260303,
+		0x81C, 0xE8280303,
+		0x81C, 0xE72A0303,
+		0x81C, 0xE62C0303,
+		0x81C, 0xE52E0303,
+		0x81C, 0xE4300303,
+		0x81C, 0xE3320303,
+		0x81C, 0xE2340303,
+		0x81C, 0xC6360303,
+		0x81C, 0xC5380303,
+		0x81C, 0xC43A0303,
+		0x81C, 0xC33C0303,
+		0x81C, 0xA63E0303,
+		0x81C, 0xA5400303,
+		0x81C, 0xA4420303,
+		0x81C, 0xA3440303,
+		0x81C, 0xA2460303,
+		0x81C, 0x84480303,
+		0x81C, 0x834A0303,
+		0x81C, 0x824C0303,
+		0x81C, 0x814E0303,
+		0x81C, 0x80500303,
+		0x81C, 0x63520303,
+		0x81C, 0x62540303,
+		0x81C, 0x61560303,
+		0x81C, 0x60580303,
+		0x81C, 0x225A0303,
+		0x81C, 0x055C0303,
+		0x81C, 0x045E0303,
+		0x81C, 0x03600303,
+		0x81C, 0x02620303,
+		0x81C, 0x01640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000303,
+		0x81C, 0xFA020303,
+		0x81C, 0xF9040303,
+		0x81C, 0xF8060303,
+		0x81C, 0xF7080303,
+		0x81C, 0xF60A0303,
+		0x81C, 0xF50C0303,
+		0x81C, 0xF40E0303,
+		0x81C, 0xF3100303,
+		0x81C, 0xF2120303,
+		0x81C, 0xF1140303,
+		0x81C, 0xEF160303,
+		0x81C, 0xEE180303,
+		0x81C, 0xED1A0303,
+		0x81C, 0xEC1C0303,
+		0x81C, 0xEB1E0303,
+		0x81C, 0xEA200303,
+		0x81C, 0xE9220303,
+		0x81C, 0xE8240303,
+		0x81C, 0xE7260303,
+		0x81C, 0xE6280303,
+		0x81C, 0xE52A0303,
+		0x81C, 0xE42C0303,
+		0x81C, 0xE32E0303,
+		0x81C, 0xE2300303,
+		0x81C, 0xE1320303,
+		0x81C, 0xC6340303,
+		0x81C, 0xC5360303,
+		0x81C, 0xC4380303,
+		0x81C, 0xC33A0303,
+		0x81C, 0xA63C0303,
+		0x81C, 0xA53E0303,
+		0x81C, 0xA4400303,
+		0x81C, 0xA3420303,
+		0x81C, 0xA2440303,
+		0x81C, 0xA1460303,
+		0x81C, 0x83480303,
+		0x81C, 0x824A0303,
+		0x81C, 0x814C0303,
+		0x81C, 0x804E0303,
+		0x81C, 0x63500303,
+		0x81C, 0x62520303,
+		0x81C, 0x61540303,
+		0x81C, 0x42560303,
+		0x81C, 0x41580303,
+		0x81C, 0x405A0303,
+		0x81C, 0x225C0303,
+		0x81C, 0x215E0303,
+		0x81C, 0x20600303,
+		0x81C, 0x04620303,
+		0x81C, 0x03640303,
+		0x81C, 0x02660303,
+		0x81C, 0x01680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000303,
+		0x81C, 0xFA020303,
+		0x81C, 0xF9040303,
+		0x81C, 0xF8060303,
+		0x81C, 0xF7080303,
+		0x81C, 0xF60A0303,
+		0x81C, 0xF50C0303,
+		0x81C, 0xF40E0303,
+		0x81C, 0xF3100303,
+		0x81C, 0xF2120303,
+		0x81C, 0xF1140303,
+		0x81C, 0xEF160303,
+		0x81C, 0xEE180303,
+		0x81C, 0xED1A0303,
+		0x81C, 0xEC1C0303,
+		0x81C, 0xEB1E0303,
+		0x81C, 0xEA200303,
+		0x81C, 0xE9220303,
+		0x81C, 0xE8240303,
+		0x81C, 0xE7260303,
+		0x81C, 0xE6280303,
+		0x81C, 0xE52A0303,
+		0x81C, 0xE42C0303,
+		0x81C, 0xE32E0303,
+		0x81C, 0xE2300303,
+		0x81C, 0xE1320303,
+		0x81C, 0xC6340303,
+		0x81C, 0xC5360303,
+		0x81C, 0xC4380303,
+		0x81C, 0xC33A0303,
+		0x81C, 0xA63C0303,
+		0x81C, 0xA53E0303,
+		0x81C, 0xA4400303,
+		0x81C, 0xA3420303,
+		0x81C, 0xA2440303,
+		0x81C, 0xA1460303,
+		0x81C, 0x83480303,
+		0x81C, 0x824A0303,
+		0x81C, 0x814C0303,
+		0x81C, 0x804E0303,
+		0x81C, 0x63500303,
+		0x81C, 0x62520303,
+		0x81C, 0x61540303,
+		0x81C, 0x42560303,
+		0x81C, 0x41580303,
+		0x81C, 0x405A0303,
+		0x81C, 0x225C0303,
+		0x81C, 0x215E0303,
+		0x81C, 0x20600303,
+		0x81C, 0x04620303,
+		0x81C, 0x03640303,
+		0x81C, 0x02660303,
+		0x81C, 0x01680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000303,
+		0x81C, 0xFA020303,
+		0x81C, 0xF9040303,
+		0x81C, 0xF8060303,
+		0x81C, 0xF7080303,
+		0x81C, 0xF60A0303,
+		0x81C, 0xF50C0303,
+		0x81C, 0xF40E0303,
+		0x81C, 0xF3100303,
+		0x81C, 0xF2120303,
+		0x81C, 0xF1140303,
+		0x81C, 0xF0160303,
+		0x81C, 0xEF180303,
+		0x81C, 0xEE1A0303,
+		0x81C, 0xED1C0303,
+		0x81C, 0xEC1E0303,
+		0x81C, 0xEB200303,
+		0x81C, 0xEA220303,
+		0x81C, 0xE9240303,
+		0x81C, 0xE8260303,
+		0x81C, 0xE7280303,
+		0x81C, 0xE62A0303,
+		0x81C, 0xE52C0303,
+		0x81C, 0xE42E0303,
+		0x81C, 0xE3300303,
+		0x81C, 0xE2320303,
+		0x81C, 0xE1340303,
+		0x81C, 0xE0360303,
+		0x81C, 0xC3380303,
+		0x81C, 0xC23A0303,
+		0x81C, 0xC13C0303,
+		0x81C, 0xC03E0303,
+		0x81C, 0xA3400303,
+		0x81C, 0xA2420303,
+		0x81C, 0xA1440303,
+		0x81C, 0xA0460303,
+		0x81C, 0x83480303,
+		0x81C, 0x824A0303,
+		0x81C, 0x814C0303,
+		0x81C, 0x644E0303,
+		0x81C, 0x63500303,
+		0x81C, 0x62520303,
+		0x81C, 0x61540303,
+		0x81C, 0x24560303,
+		0x81C, 0x23580303,
+		0x81C, 0x225A0303,
+		0x81C, 0x215C0303,
+		0x81C, 0x055E0303,
+		0x81C, 0x04600303,
+		0x81C, 0x03620303,
+		0x81C, 0x02640303,
+		0x81C, 0x01660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000303,
+		0x81C, 0xFB020303,
+		0x81C, 0xFA040303,
+		0x81C, 0xF9060303,
+		0x81C, 0xF8080303,
+		0x81C, 0xF70A0303,
+		0x81C, 0xF60C0303,
+		0x81C, 0xF50E0303,
+		0x81C, 0xF4100303,
+		0x81C, 0xF3120303,
+		0x81C, 0xF2140303,
+		0x81C, 0xF1160303,
+		0x81C, 0xF0180303,
+		0x81C, 0xEF1A0303,
+		0x81C, 0xEE1C0303,
+		0x81C, 0xED1E0303,
+		0x81C, 0xEC200303,
+		0x81C, 0xEB220303,
+		0x81C, 0xEA240303,
+		0x81C, 0xE9260303,
+		0x81C, 0xE8280303,
+		0x81C, 0xE72A0303,
+		0x81C, 0xE62C0303,
+		0x81C, 0xE52E0303,
+		0x81C, 0xE4300303,
+		0x81C, 0xE3320303,
+		0x81C, 0xE2340303,
+		0x81C, 0xC6360303,
+		0x81C, 0xC5380303,
+		0x81C, 0xC43A0303,
+		0x81C, 0xC33C0303,
+		0x81C, 0xA63E0303,
+		0x81C, 0xA5400303,
+		0x81C, 0xA4420303,
+		0x81C, 0xA3440303,
+		0x81C, 0xA2460303,
+		0x81C, 0x84480303,
+		0x81C, 0x834A0303,
+		0x81C, 0x824C0303,
+		0x81C, 0x814E0303,
+		0x81C, 0x80500303,
+		0x81C, 0x63520303,
+		0x81C, 0x62540303,
+		0x81C, 0x61560303,
+		0x81C, 0x60580303,
+		0x81C, 0x225A0303,
+		0x81C, 0x055C0303,
+		0x81C, 0x045E0303,
+		0x81C, 0x03600303,
+		0x81C, 0x02620303,
+		0x81C, 0x01640303,
+		0x81C, 0x00660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFC000303,
+		0x81C, 0xFB020303,
+		0x81C, 0xFA040303,
+		0x81C, 0xF9060303,
+		0x81C, 0xF8080303,
+		0x81C, 0xF70A0303,
+		0x81C, 0xF60C0303,
+		0x81C, 0xF50E0303,
+		0x81C, 0xF4100303,
+		0x81C, 0xF3120303,
+		0x81C, 0xF2140303,
+		0x81C, 0xF1160303,
+		0x81C, 0xF0180303,
+		0x81C, 0xEF1A0303,
+		0x81C, 0xEE1C0303,
+		0x81C, 0xED1E0303,
+		0x81C, 0xEC200303,
+		0x81C, 0xEB220303,
+		0x81C, 0xEA240303,
+		0x81C, 0xE9260303,
+		0x81C, 0xE8280303,
+		0x81C, 0xE72A0303,
+		0x81C, 0xE62C0303,
+		0x81C, 0xE52E0303,
+		0x81C, 0xE4300303,
+		0x81C, 0xE3320303,
+		0x81C, 0xE2340303,
+		0x81C, 0xC6360303,
+		0x81C, 0xC5380303,
+		0x81C, 0xC43A0303,
+		0x81C, 0xC33C0303,
+		0x81C, 0xA63E0303,
+		0x81C, 0xA5400303,
+		0x81C, 0xA4420303,
+		0x81C, 0xA3440303,
+		0x81C, 0xA2460303,
+		0x81C, 0x84480303,
+		0x81C, 0x834A0303,
+		0x81C, 0x824C0303,
+		0x81C, 0x814E0303,
+		0x81C, 0x80500303,
+		0x81C, 0x63520303,
+		0x81C, 0x62540303,
+		0x81C, 0x61560303,
+		0x81C, 0x60580303,
+		0x81C, 0x235A0303,
+		0x81C, 0x225C0303,
+		0x81C, 0x215E0303,
+		0x81C, 0x20600303,
+		0x81C, 0x03620303,
+		0x81C, 0x02640303,
+		0x81C, 0x01660303,
+		0x81C, 0x00680303,
+		0x81C, 0x006A0303,
+		0x81C, 0x006C0303,
+		0x81C, 0x006E0303,
+		0x81C, 0x00700303,
+		0x81C, 0x00720303,
+		0x81C, 0x00740303,
+		0x81C, 0x00760303,
+		0x81C, 0x00780303,
+		0x81C, 0x007A0303,
+		0x81C, 0x007C0303,
+		0x81C, 0x007E0303,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xF5000403,
+		0x81C, 0xF4020403,
+		0x81C, 0xF3040403,
+		0x81C, 0xF2060403,
+		0x81C, 0xF1080403,
+		0x81C, 0xF00A0403,
+		0x81C, 0xEF0C0403,
+		0x81C, 0xEE0E0403,
+		0x81C, 0xED100403,
+		0x81C, 0xEC120403,
+		0x81C, 0xEB140403,
+		0x81C, 0xEA160403,
+		0x81C, 0xE9180403,
+		0x81C, 0xE81A0403,
+		0x81C, 0xE71C0403,
+		0x81C, 0xE61E0403,
+		0x81C, 0xE5200403,
+		0x81C, 0xE4220403,
+		0x81C, 0xE3240403,
+		0x81C, 0xE2260403,
+		0x81C, 0xE1280403,
+		0x81C, 0xE02A0403,
+		0x81C, 0xC32C0403,
+		0x81C, 0xC22E0403,
+		0x81C, 0xC1300403,
+		0x81C, 0xC0320403,
+		0x81C, 0xA4340403,
+		0x81C, 0xA3360403,
+		0x81C, 0xA2380403,
+		0x81C, 0xA13A0403,
+		0x81C, 0xA03C0403,
+		0x81C, 0x823E0403,
+		0x81C, 0x81400403,
+		0x81C, 0x80420403,
+		0x81C, 0x64440403,
+		0x81C, 0x63460403,
+		0x81C, 0x62480403,
+		0x81C, 0x614A0403,
+		0x81C, 0x604C0403,
+		0x81C, 0x454E0403,
+		0x81C, 0x44500403,
+		0x81C, 0x43520403,
+		0x81C, 0x42540403,
+		0x81C, 0x41560403,
+		0x81C, 0x40580403,
+		0x81C, 0x055A0403,
+		0x81C, 0x045C0403,
+		0x81C, 0x035E0403,
+		0x81C, 0x02600403,
+		0x81C, 0x01620403,
+		0x81C, 0x00640403,
+		0x81C, 0x00660403,
+		0x81C, 0x00680403,
+		0x81C, 0x006A0403,
+		0x81C, 0x006C0403,
+		0x81C, 0x006E0403,
+		0x81C, 0x00700403,
+		0x81C, 0x00720403,
+		0x81C, 0x00740403,
+		0x81C, 0x00760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xF6000403,
+		0x81C, 0xF5020403,
+		0x81C, 0xF4040403,
+		0x81C, 0xF3060403,
+		0x81C, 0xF2080403,
+		0x81C, 0xF10A0403,
+		0x81C, 0xF00C0403,
+		0x81C, 0xEF0E0403,
+		0x81C, 0xD6100403,
+		0x81C, 0xD5120403,
+		0x81C, 0xD4140403,
+		0x81C, 0xD3160403,
+		0x81C, 0xD2180403,
+		0x81C, 0xD11A0403,
+		0x81C, 0xD01C0403,
+		0x81C, 0xCF1E0403,
+		0x81C, 0x95200403,
+		0x81C, 0x94220403,
+		0x81C, 0x93240403,
+		0x81C, 0x92260403,
+		0x81C, 0x91280403,
+		0x81C, 0x902A0403,
+		0x81C, 0x8F2C0403,
+		0x81C, 0x8E2E0403,
+		0x81C, 0x8D300403,
+		0x81C, 0x8C320403,
+		0x81C, 0x8B340403,
+		0x81C, 0x8A360403,
+		0x81C, 0x89380403,
+		0x81C, 0x883A0403,
+		0x81C, 0x873C0403,
+		0x81C, 0x863E0403,
+		0x81C, 0x68400403,
+		0x81C, 0x67420403,
+		0x81C, 0x66440403,
+		0x81C, 0x65460403,
+		0x81C, 0x64480403,
+		0x81C, 0x634A0403,
+		0x81C, 0x484C0403,
+		0x81C, 0x474E0403,
+		0x81C, 0x46500403,
+		0x81C, 0x45520403,
+		0x81C, 0x44540403,
+		0x81C, 0x27560403,
+		0x81C, 0x26580403,
+		0x81C, 0x255A0403,
+		0x81C, 0x245C0403,
+		0x81C, 0x235E0403,
+		0x81C, 0x04600403,
+		0x81C, 0x03620403,
+		0x81C, 0x02640403,
+		0x81C, 0x01660403,
+		0x81C, 0x00680403,
+		0x81C, 0x006A0403,
+		0x81C, 0x006C0403,
+		0x81C, 0x006E0403,
+		0x81C, 0x00700403,
+		0x81C, 0x00720403,
+		0x81C, 0x00740403,
+		0x81C, 0x00760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xF5000403,
+		0x81C, 0xF4020403,
+		0x81C, 0xF3040403,
+		0x81C, 0xF2060403,
+		0x81C, 0xF1080403,
+		0x81C, 0xF00A0403,
+		0x81C, 0xEF0C0403,
+		0x81C, 0xEE0E0403,
+		0x81C, 0xED100403,
+		0x81C, 0xEC120403,
+		0x81C, 0xEB140403,
+		0x81C, 0xEA160403,
+		0x81C, 0xE9180403,
+		0x81C, 0xE81A0403,
+		0x81C, 0xE71C0403,
+		0x81C, 0xE61E0403,
+		0x81C, 0xE5200403,
+		0x81C, 0xE4220403,
+		0x81C, 0xE3240403,
+		0x81C, 0xE2260403,
+		0x81C, 0xE1280403,
+		0x81C, 0xE02A0403,
+		0x81C, 0xC32C0403,
+		0x81C, 0xC22E0403,
+		0x81C, 0xC1300403,
+		0x81C, 0xC0320403,
+		0x81C, 0xA4340403,
+		0x81C, 0xA3360403,
+		0x81C, 0xA2380403,
+		0x81C, 0xA13A0403,
+		0x81C, 0xA03C0403,
+		0x81C, 0x823E0403,
+		0x81C, 0x81400403,
+		0x81C, 0x80420403,
+		0x81C, 0x64440403,
+		0x81C, 0x63460403,
+		0x81C, 0x62480403,
+		0x81C, 0x614A0403,
+		0x81C, 0x604C0403,
+		0x81C, 0x454E0403,
+		0x81C, 0x44500403,
+		0x81C, 0x43520403,
+		0x81C, 0x42540403,
+		0x81C, 0x41560403,
+		0x81C, 0x40580403,
+		0x81C, 0x055A0403,
+		0x81C, 0x045C0403,
+		0x81C, 0x035E0403,
+		0x81C, 0x02600403,
+		0x81C, 0x01620403,
+		0x81C, 0x00640403,
+		0x81C, 0x00660403,
+		0x81C, 0x00680403,
+		0x81C, 0x006A0403,
+		0x81C, 0x006C0403,
+		0x81C, 0x006E0403,
+		0x81C, 0x00700403,
+		0x81C, 0x00720403,
+		0x81C, 0x00740403,
+		0x81C, 0x00760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xF5000403,
+		0x81C, 0xF4020403,
+		0x81C, 0xF3040403,
+		0x81C, 0xF2060403,
+		0x81C, 0xF1080403,
+		0x81C, 0xF00A0403,
+		0x81C, 0xEF0C0403,
+		0x81C, 0xEE0E0403,
+		0x81C, 0xED100403,
+		0x81C, 0xEC120403,
+		0x81C, 0xEB140403,
+		0x81C, 0xEA160403,
+		0x81C, 0xE9180403,
+		0x81C, 0xE81A0403,
+		0x81C, 0xE71C0403,
+		0x81C, 0xE61E0403,
+		0x81C, 0xE5200403,
+		0x81C, 0xE4220403,
+		0x81C, 0xE3240403,
+		0x81C, 0xE2260403,
+		0x81C, 0xE1280403,
+		0x81C, 0xE02A0403,
+		0x81C, 0xC32C0403,
+		0x81C, 0xC22E0403,
+		0x81C, 0xC1300403,
+		0x81C, 0xC0320403,
+		0x81C, 0xA4340403,
+		0x81C, 0xA3360403,
+		0x81C, 0xA2380403,
+		0x81C, 0xA13A0403,
+		0x81C, 0xA03C0403,
+		0x81C, 0x823E0403,
+		0x81C, 0x81400403,
+		0x81C, 0x80420403,
+		0x81C, 0x64440403,
+		0x81C, 0x63460403,
+		0x81C, 0x62480403,
+		0x81C, 0x614A0403,
+		0x81C, 0x604C0403,
+		0x81C, 0x454E0403,
+		0x81C, 0x44500403,
+		0x81C, 0x43520403,
+		0x81C, 0x42540403,
+		0x81C, 0x41560403,
+		0x81C, 0x40580403,
+		0x81C, 0x055A0403,
+		0x81C, 0x045C0403,
+		0x81C, 0x035E0403,
+		0x81C, 0x02600403,
+		0x81C, 0x01620403,
+		0x81C, 0x00640403,
+		0x81C, 0x00660403,
+		0x81C, 0x00680403,
+		0x81C, 0x006A0403,
+		0x81C, 0x006C0403,
+		0x81C, 0x006E0403,
+		0x81C, 0x00700403,
+		0x81C, 0x00720403,
+		0x81C, 0x00740403,
+		0x81C, 0x00760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xF5000403,
+		0x81C, 0xF4020403,
+		0x81C, 0xF3040403,
+		0x81C, 0xF2060403,
+		0x81C, 0xF1080403,
+		0x81C, 0xF00A0403,
+		0x81C, 0xEF0C0403,
+		0x81C, 0xEE0E0403,
+		0x81C, 0xED100403,
+		0x81C, 0xEC120403,
+		0x81C, 0xEB140403,
+		0x81C, 0xEA160403,
+		0x81C, 0xE9180403,
+		0x81C, 0xE81A0403,
+		0x81C, 0xE71C0403,
+		0x81C, 0xE61E0403,
+		0x81C, 0xE5200403,
+		0x81C, 0xE4220403,
+		0x81C, 0xE3240403,
+		0x81C, 0xE2260403,
+		0x81C, 0xE1280403,
+		0x81C, 0xE02A0403,
+		0x81C, 0xC32C0403,
+		0x81C, 0xC22E0403,
+		0x81C, 0xC1300403,
+		0x81C, 0xC0320403,
+		0x81C, 0xA4340403,
+		0x81C, 0xA3360403,
+		0x81C, 0xA2380403,
+		0x81C, 0xA13A0403,
+		0x81C, 0xA03C0403,
+		0x81C, 0x823E0403,
+		0x81C, 0x81400403,
+		0x81C, 0x80420403,
+		0x81C, 0x64440403,
+		0x81C, 0x63460403,
+		0x81C, 0x62480403,
+		0x81C, 0x614A0403,
+		0x81C, 0x604C0403,
+		0x81C, 0x454E0403,
+		0x81C, 0x44500403,
+		0x81C, 0x43520403,
+		0x81C, 0x42540403,
+		0x81C, 0x41560403,
+		0x81C, 0x40580403,
+		0x81C, 0x055A0403,
+		0x81C, 0x045C0403,
+		0x81C, 0x035E0403,
+		0x81C, 0x02600403,
+		0x81C, 0x01620403,
+		0x81C, 0x00640403,
+		0x81C, 0x00660403,
+		0x81C, 0x00680403,
+		0x81C, 0x006A0403,
+		0x81C, 0x006C0403,
+		0x81C, 0x006E0403,
+		0x81C, 0x00700403,
+		0x81C, 0x00720403,
+		0x81C, 0x00740403,
+		0x81C, 0x00760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xF5000403,
+		0x81C, 0xF4020403,
+		0x81C, 0xF3040403,
+		0x81C, 0xF2060403,
+		0x81C, 0xF1080403,
+		0x81C, 0xF00A0403,
+		0x81C, 0xEF0C0403,
+		0x81C, 0xEE0E0403,
+		0x81C, 0xED100403,
+		0x81C, 0xEC120403,
+		0x81C, 0xEB140403,
+		0x81C, 0xEA160403,
+		0x81C, 0xE9180403,
+		0x81C, 0xE81A0403,
+		0x81C, 0xE71C0403,
+		0x81C, 0xE61E0403,
+		0x81C, 0xE5200403,
+		0x81C, 0xE4220403,
+		0x81C, 0xE3240403,
+		0x81C, 0xE2260403,
+		0x81C, 0xE1280403,
+		0x81C, 0xE02A0403,
+		0x81C, 0xC32C0403,
+		0x81C, 0xC22E0403,
+		0x81C, 0xC1300403,
+		0x81C, 0xC0320403,
+		0x81C, 0xA4340403,
+		0x81C, 0xA3360403,
+		0x81C, 0xA2380403,
+		0x81C, 0xA13A0403,
+		0x81C, 0xA03C0403,
+		0x81C, 0x823E0403,
+		0x81C, 0x81400403,
+		0x81C, 0x80420403,
+		0x81C, 0x64440403,
+		0x81C, 0x63460403,
+		0x81C, 0x62480403,
+		0x81C, 0x614A0403,
+		0x81C, 0x604C0403,
+		0x81C, 0x454E0403,
+		0x81C, 0x44500403,
+		0x81C, 0x43520403,
+		0x81C, 0x42540403,
+		0x81C, 0x41560403,
+		0x81C, 0x40580403,
+		0x81C, 0x055A0403,
+		0x81C, 0x045C0403,
+		0x81C, 0x035E0403,
+		0x81C, 0x02600403,
+		0x81C, 0x01620403,
+		0x81C, 0x00640403,
+		0x81C, 0x00660403,
+		0x81C, 0x00680403,
+		0x81C, 0x006A0403,
+		0x81C, 0x006C0403,
+		0x81C, 0x006E0403,
+		0x81C, 0x00700403,
+		0x81C, 0x00720403,
+		0x81C, 0x00740403,
+		0x81C, 0x00760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF000403,
+		0x81C, 0xFF020403,
+		0x81C, 0xFE040403,
+		0x81C, 0xFD060403,
+		0x81C, 0xFC080403,
+		0x81C, 0xFB0A0403,
+		0x81C, 0xFA0C0403,
+		0x81C, 0xF90E0403,
+		0x81C, 0xF8100403,
+		0x81C, 0xF7120403,
+		0x81C, 0xF6140403,
+		0x81C, 0xF5160403,
+		0x81C, 0xF4180403,
+		0x81C, 0xF31A0403,
+		0x81C, 0xF21C0403,
+		0x81C, 0xD51E0403,
+		0x81C, 0xD4200403,
+		0x81C, 0xD3220403,
+		0x81C, 0xD2240403,
+		0x81C, 0xB6260403,
+		0x81C, 0xB5280403,
+		0x81C, 0xB42A0403,
+		0x81C, 0xB32C0403,
+		0x81C, 0xB22E0403,
+		0x81C, 0xB1300403,
+		0x81C, 0xB0320403,
+		0x81C, 0xAF340403,
+		0x81C, 0xAE360403,
+		0x81C, 0xAD380403,
+		0x81C, 0xAC3A0403,
+		0x81C, 0xAB3C0403,
+		0x81C, 0xAA3E0403,
+		0x81C, 0xA9400403,
+		0x81C, 0xA8420403,
+		0x81C, 0xA7440403,
+		0x81C, 0xA6460403,
+		0x81C, 0xA5480403,
+		0x81C, 0xA44A0403,
+		0x81C, 0xA34C0403,
+		0x81C, 0x854E0403,
+		0x81C, 0x84500403,
+		0x81C, 0x83520403,
+		0x81C, 0x82540403,
+		0x81C, 0x81560403,
+		0x81C, 0x80580403,
+		0x81C, 0x485A0403,
+		0x81C, 0x475C0403,
+		0x81C, 0x465E0403,
+		0x81C, 0x45600403,
+		0x81C, 0x44620403,
+		0x81C, 0x0A640403,
+		0x81C, 0x09660403,
+		0x81C, 0x08680403,
+		0x81C, 0x076A0403,
+		0x81C, 0x066C0403,
+		0x81C, 0x056E0403,
+		0x81C, 0x04700403,
+		0x81C, 0x03720403,
+		0x81C, 0x02740403,
+		0x81C, 0x01760403,
+		0x81C, 0x00780403,
+		0x81C, 0x007A0403,
+		0x81C, 0x007C0403,
+		0x81C, 0x007E0403,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000503,
+		0x81C, 0xFC020503,
+		0x81C, 0xFB040503,
+		0x81C, 0xFA060503,
+		0x81C, 0xF9080503,
+		0x81C, 0xF80A0503,
+		0x81C, 0xF70C0503,
+		0x81C, 0xF60E0503,
+		0x81C, 0xF5100503,
+		0x81C, 0xF4120503,
+		0x81C, 0xF3140503,
+		0x81C, 0xF2160503,
+		0x81C, 0xF1180503,
+		0x81C, 0xF01A0503,
+		0x81C, 0xEE1C0503,
+		0x81C, 0xED1E0503,
+		0x81C, 0xEC200503,
+		0x81C, 0xEB220503,
+		0x81C, 0xEA240503,
+		0x81C, 0xE9260503,
+		0x81C, 0xE8280503,
+		0x81C, 0xE72A0503,
+		0x81C, 0xE62C0503,
+		0x81C, 0xE52E0503,
+		0x81C, 0xE4300503,
+		0x81C, 0xE3320503,
+		0x81C, 0xE2340503,
+		0x81C, 0xC5360503,
+		0x81C, 0xC4380503,
+		0x81C, 0xC33A0503,
+		0x81C, 0xC23C0503,
+		0x81C, 0xA53E0503,
+		0x81C, 0xA4400503,
+		0x81C, 0xA3420503,
+		0x81C, 0xA2440503,
+		0x81C, 0xA1460503,
+		0x81C, 0x83480503,
+		0x81C, 0x824A0503,
+		0x81C, 0x814C0503,
+		0x81C, 0x804E0503,
+		0x81C, 0x63500503,
+		0x81C, 0x62520503,
+		0x81C, 0x61540503,
+		0x81C, 0x43560503,
+		0x81C, 0x42580503,
+		0x81C, 0x415A0503,
+		0x81C, 0x405C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x20620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBE000503,
+		0x81C, 0xBD020503,
+		0x81C, 0xBC040503,
+		0x81C, 0xBB060503,
+		0x81C, 0xBA080503,
+		0x81C, 0xB90A0503,
+		0x81C, 0xB80C0503,
+		0x81C, 0xB70E0503,
+		0x81C, 0xB6100503,
+		0x81C, 0xB5120503,
+		0x81C, 0xB4140503,
+		0x81C, 0xB3160503,
+		0x81C, 0xB2180503,
+		0x81C, 0xB11A0503,
+		0x81C, 0xB01C0503,
+		0x81C, 0xAF1E0503,
+		0x81C, 0xAE200503,
+		0x81C, 0xAD220503,
+		0x81C, 0xAC240503,
+		0x81C, 0xAB260503,
+		0x81C, 0x8D280503,
+		0x81C, 0x8C2A0503,
+		0x81C, 0x8B2C0503,
+		0x81C, 0x8A2E0503,
+		0x81C, 0x89300503,
+		0x81C, 0x88320503,
+		0x81C, 0x6A340503,
+		0x81C, 0x69360503,
+		0x81C, 0x68380503,
+		0x81C, 0x673A0503,
+		0x81C, 0x663C0503,
+		0x81C, 0x653E0503,
+		0x81C, 0x64400503,
+		0x81C, 0x63420503,
+		0x81C, 0x62440503,
+		0x81C, 0x61460503,
+		0x81C, 0x60480503,
+		0x81C, 0x424A0503,
+		0x81C, 0x414C0503,
+		0x81C, 0x404E0503,
+		0x81C, 0x06500503,
+		0x81C, 0x05520503,
+		0x81C, 0x04540503,
+		0x81C, 0x03560503,
+		0x81C, 0x02580503,
+		0x81C, 0x015A0503,
+		0x81C, 0x005C0503,
+		0x81C, 0x005E0503,
+		0x81C, 0x00600503,
+		0x81C, 0x00620503,
+		0x81C, 0x00640503,
+		0x81C, 0x00660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007C0503,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000503,
+		0x81C, 0xF7020503,
+		0x81C, 0xF6040503,
+		0x81C, 0xF5060503,
+		0x81C, 0xF4080503,
+		0x81C, 0xF30A0503,
+		0x81C, 0xF20C0503,
+		0x81C, 0xF10E0503,
+		0x81C, 0xF0100503,
+		0x81C, 0xEF120503,
+		0x81C, 0xEE140503,
+		0x81C, 0xED160503,
+		0x81C, 0xEC180503,
+		0x81C, 0xEB1A0503,
+		0x81C, 0xEA1C0503,
+		0x81C, 0xE91E0503,
+		0x81C, 0xE8200503,
+		0x81C, 0xE7220503,
+		0x81C, 0xE6240503,
+		0x81C, 0xE5260503,
+		0x81C, 0xE4280503,
+		0x81C, 0xE32A0503,
+		0x81C, 0xC32C0503,
+		0x81C, 0xC22E0503,
+		0x81C, 0xC1300503,
+		0x81C, 0xC0320503,
+		0x81C, 0xA3340503,
+		0x81C, 0xA2360503,
+		0x81C, 0xA1380503,
+		0x81C, 0xA03A0503,
+		0x81C, 0x823C0503,
+		0x81C, 0x813E0503,
+		0x81C, 0x80400503,
+		0x81C, 0x63420503,
+		0x81C, 0x62440503,
+		0x81C, 0x61460503,
+		0x81C, 0x60480503,
+		0x81C, 0x424A0503,
+		0x81C, 0x414C0503,
+		0x81C, 0x404E0503,
+		0x81C, 0x22500503,
+		0x81C, 0x21520503,
+		0x81C, 0x20540503,
+		0x81C, 0x03560503,
+		0x81C, 0x02580503,
+		0x81C, 0x015A0503,
+		0x81C, 0x005C0503,
+		0x81C, 0x005E0503,
+		0x81C, 0x00600503,
+		0x81C, 0x00620503,
+		0x81C, 0x00640503,
+		0x81C, 0x00660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFE000503,
+		0x81C, 0xFD020503,
+		0x81C, 0xFC040503,
+		0x81C, 0xFB060503,
+		0x81C, 0xFA080503,
+		0x81C, 0xF90A0503,
+		0x81C, 0xF80C0503,
+		0x81C, 0xF70E0503,
+		0x81C, 0xF6100503,
+		0x81C, 0xF5120503,
+		0x81C, 0xF4140503,
+		0x81C, 0xF3160503,
+		0x81C, 0xF2180503,
+		0x81C, 0xF11A0503,
+		0x81C, 0xF01C0503,
+		0x81C, 0xEF1E0503,
+		0x81C, 0xEE200503,
+		0x81C, 0xED220503,
+		0x81C, 0xEC240503,
+		0x81C, 0xEB260503,
+		0x81C, 0xEA280503,
+		0x81C, 0xE92A0503,
+		0x81C, 0xE82C0503,
+		0x81C, 0xE72E0503,
+		0x81C, 0xE6300503,
+		0x81C, 0xE5320503,
+		0x81C, 0xE4340503,
+		0x81C, 0xE3360503,
+		0x81C, 0xC6380503,
+		0x81C, 0xC53A0503,
+		0x81C, 0xC43C0503,
+		0x81C, 0xC33E0503,
+		0x81C, 0xA5400503,
+		0x81C, 0xA4420503,
+		0x81C, 0xA3440503,
+		0x81C, 0xA2460503,
+		0x81C, 0xA1480503,
+		0x81C, 0xA04A0503,
+		0x81C, 0x824C0503,
+		0x81C, 0x814E0503,
+		0x81C, 0x80500503,
+		0x81C, 0x64520503,
+		0x81C, 0x63540503,
+		0x81C, 0x62560503,
+		0x81C, 0x61580503,
+		0x81C, 0x605A0503,
+		0x81C, 0x235C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x20620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000503,
+		0x81C, 0xF7020503,
+		0x81C, 0xF6040503,
+		0x81C, 0xF5060503,
+		0x81C, 0xF4080503,
+		0x81C, 0xF30A0503,
+		0x81C, 0xF20C0503,
+		0x81C, 0xF10E0503,
+		0x81C, 0xF0100503,
+		0x81C, 0xEF120503,
+		0x81C, 0xEE140503,
+		0x81C, 0xED160503,
+		0x81C, 0xEC180503,
+		0x81C, 0xEB1A0503,
+		0x81C, 0xEA1C0503,
+		0x81C, 0xE91E0503,
+		0x81C, 0xE8200503,
+		0x81C, 0xE7220503,
+		0x81C, 0xE6240503,
+		0x81C, 0xE5260503,
+		0x81C, 0xE4280503,
+		0x81C, 0xE32A0503,
+		0x81C, 0xC32C0503,
+		0x81C, 0xC22E0503,
+		0x81C, 0xC1300503,
+		0x81C, 0xC0320503,
+		0x81C, 0xA3340503,
+		0x81C, 0xA2360503,
+		0x81C, 0xA1380503,
+		0x81C, 0xA03A0503,
+		0x81C, 0x823C0503,
+		0x81C, 0x813E0503,
+		0x81C, 0x80400503,
+		0x81C, 0x63420503,
+		0x81C, 0x62440503,
+		0x81C, 0x61460503,
+		0x81C, 0x60480503,
+		0x81C, 0x424A0503,
+		0x81C, 0x414C0503,
+		0x81C, 0x404E0503,
+		0x81C, 0x22500503,
+		0x81C, 0x21520503,
+		0x81C, 0x20540503,
+		0x81C, 0x03560503,
+		0x81C, 0x02580503,
+		0x81C, 0x015A0503,
+		0x81C, 0x005C0503,
+		0x81C, 0x005E0503,
+		0x81C, 0x00600503,
+		0x81C, 0x00620503,
+		0x81C, 0x00640503,
+		0x81C, 0x00660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000503,
+		0x81C, 0xFC020503,
+		0x81C, 0xFB040503,
+		0x81C, 0xFA060503,
+		0x81C, 0xF9080503,
+		0x81C, 0xF80A0503,
+		0x81C, 0xF70C0503,
+		0x81C, 0xF60E0503,
+		0x81C, 0xF5100503,
+		0x81C, 0xF4120503,
+		0x81C, 0xF3140503,
+		0x81C, 0xF2160503,
+		0x81C, 0xF1180503,
+		0x81C, 0xF01A0503,
+		0x81C, 0xEF1C0503,
+		0x81C, 0xEE1E0503,
+		0x81C, 0xED200503,
+		0x81C, 0xEC220503,
+		0x81C, 0xEB240503,
+		0x81C, 0xEA260503,
+		0x81C, 0xE9280503,
+		0x81C, 0xE82A0503,
+		0x81C, 0xE72C0503,
+		0x81C, 0xE62E0503,
+		0x81C, 0xE5300503,
+		0x81C, 0xE4320503,
+		0x81C, 0xE3340503,
+		0x81C, 0xE2360503,
+		0x81C, 0xC5380503,
+		0x81C, 0xC43A0503,
+		0x81C, 0xC33C0503,
+		0x81C, 0xC23E0503,
+		0x81C, 0xA5400503,
+		0x81C, 0xA4420503,
+		0x81C, 0xA3440503,
+		0x81C, 0xA2460503,
+		0x81C, 0xA1480503,
+		0x81C, 0x834A0503,
+		0x81C, 0x824C0503,
+		0x81C, 0x814E0503,
+		0x81C, 0x64500503,
+		0x81C, 0x63520503,
+		0x81C, 0x62540503,
+		0x81C, 0x61560503,
+		0x81C, 0x42580503,
+		0x81C, 0x415A0503,
+		0x81C, 0x405C0503,
+		0x81C, 0x065E0503,
+		0x81C, 0x05600503,
+		0x81C, 0x04620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFA000503,
+		0x81C, 0xF9020503,
+		0x81C, 0xF8040503,
+		0x81C, 0xF7060503,
+		0x81C, 0xF6080503,
+		0x81C, 0xF50A0503,
+		0x81C, 0xF40C0503,
+		0x81C, 0xF30E0503,
+		0x81C, 0xF2100503,
+		0x81C, 0xF1120503,
+		0x81C, 0xF0140503,
+		0x81C, 0xEF160503,
+		0x81C, 0xEE180503,
+		0x81C, 0xED1A0503,
+		0x81C, 0xEC1C0503,
+		0x81C, 0xEB1E0503,
+		0x81C, 0xEA200503,
+		0x81C, 0xE9220503,
+		0x81C, 0xE8240503,
+		0x81C, 0xE7260503,
+		0x81C, 0xE6280503,
+		0x81C, 0xE52A0503,
+		0x81C, 0xC42C0503,
+		0x81C, 0xC32E0503,
+		0x81C, 0xC2300503,
+		0x81C, 0xC1320503,
+		0x81C, 0xA4340503,
+		0x81C, 0xA3360503,
+		0x81C, 0xA2380503,
+		0x81C, 0xA13A0503,
+		0x81C, 0x833C0503,
+		0x81C, 0x823E0503,
+		0x81C, 0x81400503,
+		0x81C, 0x63420503,
+		0x81C, 0x62440503,
+		0x81C, 0x61460503,
+		0x81C, 0x60480503,
+		0x81C, 0x424A0503,
+		0x81C, 0x414C0503,
+		0x81C, 0x404E0503,
+		0x81C, 0x22500503,
+		0x81C, 0x21520503,
+		0x81C, 0x20540503,
+		0x81C, 0x03560503,
+		0x81C, 0x02580503,
+		0x81C, 0x015A0503,
+		0x81C, 0x005C0503,
+		0x81C, 0x005E0503,
+		0x81C, 0x00600503,
+		0x81C, 0x00620503,
+		0x81C, 0x00640503,
+		0x81C, 0x00660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBF000503,
+		0x81C, 0xBE020503,
+		0x81C, 0xBD040503,
+		0x81C, 0xBC060503,
+		0x81C, 0xBB080503,
+		0x81C, 0xBA0A0503,
+		0x81C, 0xB90C0503,
+		0x81C, 0xB80E0503,
+		0x81C, 0xB7100503,
+		0x81C, 0xB6120503,
+		0x81C, 0xB5140503,
+		0x81C, 0xB4160503,
+		0x81C, 0xB3180503,
+		0x81C, 0xB21A0503,
+		0x81C, 0xB11C0503,
+		0x81C, 0xB01E0503,
+		0x81C, 0xAF200503,
+		0x81C, 0xAE220503,
+		0x81C, 0xAD240503,
+		0x81C, 0xAC260503,
+		0x81C, 0xAB280503,
+		0x81C, 0x8D2A0503,
+		0x81C, 0x8C2C0503,
+		0x81C, 0x8B2E0503,
+		0x81C, 0x8A300503,
+		0x81C, 0x89320503,
+		0x81C, 0x88340503,
+		0x81C, 0x6A360503,
+		0x81C, 0x69380503,
+		0x81C, 0x683A0503,
+		0x81C, 0x673C0503,
+		0x81C, 0x663E0503,
+		0x81C, 0x65400503,
+		0x81C, 0x64420503,
+		0x81C, 0x63440503,
+		0x81C, 0x62460503,
+		0x81C, 0x61480503,
+		0x81C, 0x604A0503,
+		0x81C, 0x424C0503,
+		0x81C, 0x414E0503,
+		0x81C, 0x40500503,
+		0x81C, 0x06520503,
+		0x81C, 0x05540503,
+		0x81C, 0x04560503,
+		0x81C, 0x03580503,
+		0x81C, 0x025A0503,
+		0x81C, 0x015C0503,
+		0x81C, 0x005E0503,
+		0x81C, 0x00600503,
+		0x81C, 0x00620503,
+		0x81C, 0x00640503,
+		0x81C, 0x00660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000503,
+		0x81C, 0xFC020503,
+		0x81C, 0xFB040503,
+		0x81C, 0xFA060503,
+		0x81C, 0xF9080503,
+		0x81C, 0xF80A0503,
+		0x81C, 0xF70C0503,
+		0x81C, 0xF60E0503,
+		0x81C, 0xF5100503,
+		0x81C, 0xF4120503,
+		0x81C, 0xF3140503,
+		0x81C, 0xF2160503,
+		0x81C, 0xF1180503,
+		0x81C, 0xF01A0503,
+		0x81C, 0xEF1C0503,
+		0x81C, 0xEE1E0503,
+		0x81C, 0xED200503,
+		0x81C, 0xEC220503,
+		0x81C, 0xEB240503,
+		0x81C, 0xEA260503,
+		0x81C, 0xE9280503,
+		0x81C, 0xE82A0503,
+		0x81C, 0xE72C0503,
+		0x81C, 0xE62E0503,
+		0x81C, 0xE5300503,
+		0x81C, 0xE4320503,
+		0x81C, 0xE3340503,
+		0x81C, 0xC6360503,
+		0x81C, 0xC5380503,
+		0x81C, 0xC43A0503,
+		0x81C, 0xC33C0503,
+		0x81C, 0xC23E0503,
+		0x81C, 0xA5400503,
+		0x81C, 0xA4420503,
+		0x81C, 0xA3440503,
+		0x81C, 0xA2460503,
+		0x81C, 0xA1480503,
+		0x81C, 0x834A0503,
+		0x81C, 0x824C0503,
+		0x81C, 0x814E0503,
+		0x81C, 0x63500503,
+		0x81C, 0x62520503,
+		0x81C, 0x61540503,
+		0x81C, 0x43560503,
+		0x81C, 0x42580503,
+		0x81C, 0x245A0503,
+		0x81C, 0x235C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x04620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000503,
+		0x81C, 0xF7020503,
+		0x81C, 0xF6040503,
+		0x81C, 0xF5060503,
+		0x81C, 0xF4080503,
+		0x81C, 0xF30A0503,
+		0x81C, 0xF20C0503,
+		0x81C, 0xF10E0503,
+		0x81C, 0xF0100503,
+		0x81C, 0xEF120503,
+		0x81C, 0xEE140503,
+		0x81C, 0xED160503,
+		0x81C, 0xEC180503,
+		0x81C, 0xEB1A0503,
+		0x81C, 0xEA1C0503,
+		0x81C, 0xE91E0503,
+		0x81C, 0xE8200503,
+		0x81C, 0xE7220503,
+		0x81C, 0xE6240503,
+		0x81C, 0xE5260503,
+		0x81C, 0xE4280503,
+		0x81C, 0xE32A0503,
+		0x81C, 0xE22C0503,
+		0x81C, 0xC32E0503,
+		0x81C, 0xC2300503,
+		0x81C, 0xC1320503,
+		0x81C, 0xA3340503,
+		0x81C, 0xA2360503,
+		0x81C, 0xA1380503,
+		0x81C, 0xA03A0503,
+		0x81C, 0x823C0503,
+		0x81C, 0x813E0503,
+		0x81C, 0x80400503,
+		0x81C, 0x64420503,
+		0x81C, 0x63440503,
+		0x81C, 0x62460503,
+		0x81C, 0x61480503,
+		0x81C, 0x434A0503,
+		0x81C, 0x424C0503,
+		0x81C, 0x414E0503,
+		0x81C, 0x40500503,
+		0x81C, 0x22520503,
+		0x81C, 0x21540503,
+		0x81C, 0x20560503,
+		0x81C, 0x04580503,
+		0x81C, 0x035A0503,
+		0x81C, 0x025C0503,
+		0x81C, 0x015E0503,
+		0x81C, 0x00600503,
+		0x81C, 0x00620503,
+		0x81C, 0x00640503,
+		0x81C, 0x00660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000503,
+		0x81C, 0xFC020503,
+		0x81C, 0xFB040503,
+		0x81C, 0xFA060503,
+		0x81C, 0xF9080503,
+		0x81C, 0xF80A0503,
+		0x81C, 0xF70C0503,
+		0x81C, 0xF60E0503,
+		0x81C, 0xF5100503,
+		0x81C, 0xF4120503,
+		0x81C, 0xF3140503,
+		0x81C, 0xF2160503,
+		0x81C, 0xF1180503,
+		0x81C, 0xF01A0503,
+		0x81C, 0xEE1C0503,
+		0x81C, 0xED1E0503,
+		0x81C, 0xEC200503,
+		0x81C, 0xEB220503,
+		0x81C, 0xEA240503,
+		0x81C, 0xE9260503,
+		0x81C, 0xE8280503,
+		0x81C, 0xE72A0503,
+		0x81C, 0xE62C0503,
+		0x81C, 0xE52E0503,
+		0x81C, 0xE4300503,
+		0x81C, 0xE3320503,
+		0x81C, 0xE2340503,
+		0x81C, 0xC5360503,
+		0x81C, 0xC4380503,
+		0x81C, 0xC33A0503,
+		0x81C, 0xC23C0503,
+		0x81C, 0xA53E0503,
+		0x81C, 0xA4400503,
+		0x81C, 0xA3420503,
+		0x81C, 0xA2440503,
+		0x81C, 0xA1460503,
+		0x81C, 0x83480503,
+		0x81C, 0x824A0503,
+		0x81C, 0x814C0503,
+		0x81C, 0x804E0503,
+		0x81C, 0x63500503,
+		0x81C, 0x62520503,
+		0x81C, 0x61540503,
+		0x81C, 0x43560503,
+		0x81C, 0x42580503,
+		0x81C, 0x415A0503,
+		0x81C, 0x405C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x20620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000503,
+		0x81C, 0xF8020503,
+		0x81C, 0xF7040503,
+		0x81C, 0xF6060503,
+		0x81C, 0xF5080503,
+		0x81C, 0xF40A0503,
+		0x81C, 0xF30C0503,
+		0x81C, 0xF20E0503,
+		0x81C, 0xF1100503,
+		0x81C, 0xF0120503,
+		0x81C, 0xEF140503,
+		0x81C, 0xEE160503,
+		0x81C, 0xED180503,
+		0x81C, 0xEC1A0503,
+		0x81C, 0xEB1C0503,
+		0x81C, 0xEA1E0503,
+		0x81C, 0xE9200503,
+		0x81C, 0xE8220503,
+		0x81C, 0xE7240503,
+		0x81C, 0xE6260503,
+		0x81C, 0xE5280503,
+		0x81C, 0xE42A0503,
+		0x81C, 0xE32C0503,
+		0x81C, 0xC32E0503,
+		0x81C, 0xC2300503,
+		0x81C, 0xC1320503,
+		0x81C, 0xA4340503,
+		0x81C, 0xA3360503,
+		0x81C, 0xA2380503,
+		0x81C, 0xA13A0503,
+		0x81C, 0xA03C0503,
+		0x81C, 0x823E0503,
+		0x81C, 0x81400503,
+		0x81C, 0x80420503,
+		0x81C, 0x63440503,
+		0x81C, 0x62460503,
+		0x81C, 0x61480503,
+		0x81C, 0x604A0503,
+		0x81C, 0x244C0503,
+		0x81C, 0x234E0503,
+		0x81C, 0x22500503,
+		0x81C, 0x21520503,
+		0x81C, 0x20540503,
+		0x81C, 0x05560503,
+		0x81C, 0x04580503,
+		0x81C, 0x035A0503,
+		0x81C, 0x025C0503,
+		0x81C, 0x015E0503,
+		0x81C, 0x00600503,
+		0x81C, 0x00620503,
+		0x81C, 0x00640503,
+		0x81C, 0x00660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFE000503,
+		0x81C, 0xFD020503,
+		0x81C, 0xFC040503,
+		0x81C, 0xFB060503,
+		0x81C, 0xFA080503,
+		0x81C, 0xF90A0503,
+		0x81C, 0xF80C0503,
+		0x81C, 0xF70E0503,
+		0x81C, 0xF6100503,
+		0x81C, 0xF5120503,
+		0x81C, 0xF4140503,
+		0x81C, 0xF3160503,
+		0x81C, 0xF2180503,
+		0x81C, 0xF11A0503,
+		0x81C, 0xF01C0503,
+		0x81C, 0xEF1E0503,
+		0x81C, 0xEE200503,
+		0x81C, 0xED220503,
+		0x81C, 0xEC240503,
+		0x81C, 0xEB260503,
+		0x81C, 0xEA280503,
+		0x81C, 0xE92A0503,
+		0x81C, 0xE82C0503,
+		0x81C, 0xE72E0503,
+		0x81C, 0xE6300503,
+		0x81C, 0xE5320503,
+		0x81C, 0xE4340503,
+		0x81C, 0xE3360503,
+		0x81C, 0xC6380503,
+		0x81C, 0xC53A0503,
+		0x81C, 0xC43C0503,
+		0x81C, 0xC33E0503,
+		0x81C, 0xA5400503,
+		0x81C, 0xA4420503,
+		0x81C, 0xA3440503,
+		0x81C, 0xA2460503,
+		0x81C, 0xA1480503,
+		0x81C, 0xA04A0503,
+		0x81C, 0x824C0503,
+		0x81C, 0x814E0503,
+		0x81C, 0x80500503,
+		0x81C, 0x64520503,
+		0x81C, 0x63540503,
+		0x81C, 0x62560503,
+		0x81C, 0x61580503,
+		0x81C, 0x605A0503,
+		0x81C, 0x235C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x20620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000503,
+		0x81C, 0xFC020503,
+		0x81C, 0xFB040503,
+		0x81C, 0xFA060503,
+		0x81C, 0xF9080503,
+		0x81C, 0xF80A0503,
+		0x81C, 0xF70C0503,
+		0x81C, 0xF60E0503,
+		0x81C, 0xF5100503,
+		0x81C, 0xF4120503,
+		0x81C, 0xF3140503,
+		0x81C, 0xF2160503,
+		0x81C, 0xF1180503,
+		0x81C, 0xF01A0503,
+		0x81C, 0xEE1C0503,
+		0x81C, 0xED1E0503,
+		0x81C, 0xEC200503,
+		0x81C, 0xEB220503,
+		0x81C, 0xEA240503,
+		0x81C, 0xE9260503,
+		0x81C, 0xE8280503,
+		0x81C, 0xE72A0503,
+		0x81C, 0xE62C0503,
+		0x81C, 0xE52E0503,
+		0x81C, 0xE4300503,
+		0x81C, 0xE3320503,
+		0x81C, 0xE2340503,
+		0x81C, 0xC5360503,
+		0x81C, 0xC4380503,
+		0x81C, 0xC33A0503,
+		0x81C, 0xC23C0503,
+		0x81C, 0xA53E0503,
+		0x81C, 0xA4400503,
+		0x81C, 0xA3420503,
+		0x81C, 0xA2440503,
+		0x81C, 0xA1460503,
+		0x81C, 0x83480503,
+		0x81C, 0x824A0503,
+		0x81C, 0x814C0503,
+		0x81C, 0x804E0503,
+		0x81C, 0x63500503,
+		0x81C, 0x62520503,
+		0x81C, 0x61540503,
+		0x81C, 0x43560503,
+		0x81C, 0x42580503,
+		0x81C, 0x415A0503,
+		0x81C, 0x405C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x20620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFD000503,
+		0x81C, 0xFC020503,
+		0x81C, 0xFB040503,
+		0x81C, 0xFA060503,
+		0x81C, 0xF9080503,
+		0x81C, 0xF80A0503,
+		0x81C, 0xF70C0503,
+		0x81C, 0xF60E0503,
+		0x81C, 0xF5100503,
+		0x81C, 0xF4120503,
+		0x81C, 0xF3140503,
+		0x81C, 0xF2160503,
+		0x81C, 0xF1180503,
+		0x81C, 0xF01A0503,
+		0x81C, 0xEE1C0503,
+		0x81C, 0xED1E0503,
+		0x81C, 0xEC200503,
+		0x81C, 0xEB220503,
+		0x81C, 0xEA240503,
+		0x81C, 0xE9260503,
+		0x81C, 0xE8280503,
+		0x81C, 0xE72A0503,
+		0x81C, 0xE62C0503,
+		0x81C, 0xE52E0503,
+		0x81C, 0xE4300503,
+		0x81C, 0xE3320503,
+		0x81C, 0xE2340503,
+		0x81C, 0xC5360503,
+		0x81C, 0xC4380503,
+		0x81C, 0xC33A0503,
+		0x81C, 0xC23C0503,
+		0x81C, 0xA53E0503,
+		0x81C, 0xA4400503,
+		0x81C, 0xA3420503,
+		0x81C, 0xA2440503,
+		0x81C, 0xA1460503,
+		0x81C, 0x83480503,
+		0x81C, 0x824A0503,
+		0x81C, 0x814C0503,
+		0x81C, 0x804E0503,
+		0x81C, 0x63500503,
+		0x81C, 0x62520503,
+		0x81C, 0x61540503,
+		0x81C, 0x43560503,
+		0x81C, 0x42580503,
+		0x81C, 0x415A0503,
+		0x81C, 0x405C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x20620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBF000503,
+		0x81C, 0xBF020503,
+		0x81C, 0xBF040503,
+		0x81C, 0xBF060503,
+		0x81C, 0xBF080503,
+		0x81C, 0xBF0A0503,
+		0x81C, 0xBE0C0503,
+		0x81C, 0xBD0E0503,
+		0x81C, 0xBC100503,
+		0x81C, 0xBB120503,
+		0x81C, 0xBA140503,
+		0x81C, 0xB9160503,
+		0x81C, 0xB8180503,
+		0x81C, 0xB71A0503,
+		0x81C, 0xB61C0503,
+		0x81C, 0xB51E0503,
+		0x81C, 0xB2200503,
+		0x81C, 0xB3220503,
+		0x81C, 0xB2240503,
+		0x81C, 0xB1260503,
+		0x81C, 0xB0280503,
+		0x81C, 0xAF2A0503,
+		0x81C, 0xAE2C0503,
+		0x81C, 0xAD2E0503,
+		0x81C, 0xAC300503,
+		0x81C, 0xAB320503,
+		0x81C, 0xAA340503,
+		0x81C, 0xC6360503,
+		0x81C, 0xC5380503,
+		0x81C, 0xC43A0503,
+		0x81C, 0xC33C0503,
+		0x81C, 0x883E0503,
+		0x81C, 0x87400503,
+		0x81C, 0x86420503,
+		0x81C, 0x85440503,
+		0x81C, 0x84460503,
+		0x81C, 0x83480503,
+		0x81C, 0x674A0503,
+		0x81C, 0x664C0503,
+		0x81C, 0x654E0503,
+		0x81C, 0x64500503,
+		0x81C, 0x27520503,
+		0x81C, 0x26540503,
+		0x81C, 0x25560503,
+		0x81C, 0x24580503,
+		0x81C, 0x235A0503,
+		0x81C, 0x225C0503,
+		0x81C, 0x215E0503,
+		0x81C, 0x20600503,
+		0x81C, 0x03620503,
+		0x81C, 0x02640503,
+		0x81C, 0x01660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFE000403,
+		0x81C, 0xFD000503,
+		0x81C, 0xFC020503,
+		0x81C, 0xFB040503,
+		0x81C, 0xFA060503,
+		0x81C, 0xF9080503,
+		0x81C, 0xF80A0503,
+		0x81C, 0xF70C0503,
+		0x81C, 0xF60E0503,
+		0x81C, 0xF5100503,
+		0x81C, 0xF4120503,
+		0x81C, 0xF3140503,
+		0x81C, 0xF2160503,
+		0x81C, 0xF1180503,
+		0x81C, 0xF01A0503,
+		0x81C, 0xEF1C0503,
+		0x81C, 0xEE1E0503,
+		0x81C, 0xED200503,
+		0x81C, 0xEC220503,
+		0x81C, 0xEB240503,
+		0x81C, 0xEA260503,
+		0x81C, 0xE9280503,
+		0x81C, 0xE82A0503,
+		0x81C, 0xE72C0503,
+		0x81C, 0xE62E0503,
+		0x81C, 0xE5300503,
+		0x81C, 0xE4320503,
+		0x81C, 0xE3340503,
+		0x81C, 0xC6360503,
+		0x81C, 0xC5380503,
+		0x81C, 0xC43A0503,
+		0x81C, 0xC33C0503,
+		0x81C, 0xA53E0503,
+		0x81C, 0xA4400503,
+		0x81C, 0xA3420503,
+		0x81C, 0xA2440503,
+		0x81C, 0xA1460503,
+		0x81C, 0xA0480503,
+		0x81C, 0x824A0503,
+		0x81C, 0x814C0503,
+		0x81C, 0x804E0503,
+		0x81C, 0x64500503,
+		0x81C, 0x63520503,
+		0x81C, 0x62540503,
+		0x81C, 0x61560503,
+		0x81C, 0x60580503,
+		0x81C, 0x235A0503,
+		0x81C, 0x225C0503,
+		0x81C, 0x215E0503,
+		0x81C, 0x20600503,
+		0x81C, 0x03620503,
+		0x81C, 0x02640503,
+		0x81C, 0x01660503,
+		0x81C, 0x00680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFE000503,
+		0x81C, 0xFD020503,
+		0x81C, 0xFC040503,
+		0x81C, 0xFB060503,
+		0x81C, 0xFA080503,
+		0x81C, 0xF90A0503,
+		0x81C, 0xF80C0503,
+		0x81C, 0xF70E0503,
+		0x81C, 0xF6100503,
+		0x81C, 0xF5120503,
+		0x81C, 0xF4140503,
+		0x81C, 0xF3160503,
+		0x81C, 0xF2180503,
+		0x81C, 0xF11A0503,
+		0x81C, 0xF01C0503,
+		0x81C, 0xEF1E0503,
+		0x81C, 0xEE200503,
+		0x81C, 0xED220503,
+		0x81C, 0xEC240503,
+		0x81C, 0xEB260503,
+		0x81C, 0xEA280503,
+		0x81C, 0xE92A0503,
+		0x81C, 0xE82C0503,
+		0x81C, 0xE72E0503,
+		0x81C, 0xE6300503,
+		0x81C, 0xE5320503,
+		0x81C, 0xE4340503,
+		0x81C, 0xE3360503,
+		0x81C, 0xC6380503,
+		0x81C, 0xC53A0503,
+		0x81C, 0xC43C0503,
+		0x81C, 0xC33E0503,
+		0x81C, 0xA5400503,
+		0x81C, 0xA4420503,
+		0x81C, 0xA3440503,
+		0x81C, 0xA2460503,
+		0x81C, 0xA1480503,
+		0x81C, 0xA04A0503,
+		0x81C, 0x824C0503,
+		0x81C, 0x814E0503,
+		0x81C, 0x80500503,
+		0x81C, 0x64520503,
+		0x81C, 0x63540503,
+		0x81C, 0x62560503,
+		0x81C, 0x61580503,
+		0x81C, 0x605A0503,
+		0x81C, 0x235C0503,
+		0x81C, 0x225E0503,
+		0x81C, 0x21600503,
+		0x81C, 0x20620503,
+		0x81C, 0x03640503,
+		0x81C, 0x02660503,
+		0x81C, 0x01680503,
+		0x81C, 0x006A0503,
+		0x81C, 0x006C0503,
+		0x81C, 0x006E0503,
+		0x81C, 0x00700503,
+		0x81C, 0x00720503,
+		0x81C, 0x00740503,
+		0x81C, 0x00760503,
+		0x81C, 0x00780503,
+		0x81C, 0x007A0503,
+		0x81C, 0x007C0503,
+		0x81C, 0x007E0503,
+		0x81C, 0x007E0503,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000603,
+		0x81C, 0xFB020603,
+		0x81C, 0xFA040603,
+		0x81C, 0xF9060603,
+		0x81C, 0xF8080603,
+		0x81C, 0xF70A0603,
+		0x81C, 0xF60C0603,
+		0x81C, 0xF50E0603,
+		0x81C, 0xF4100603,
+		0x81C, 0xF3120603,
+		0x81C, 0xF2140603,
+		0x81C, 0xF1160603,
+		0x81C, 0xF0180603,
+		0x81C, 0xEE1A0603,
+		0x81C, 0xED1C0603,
+		0x81C, 0xEC1E0603,
+		0x81C, 0xEB200603,
+		0x81C, 0xEA220603,
+		0x81C, 0xE9240603,
+		0x81C, 0xE8260603,
+		0x81C, 0xE7280603,
+		0x81C, 0xE62A0603,
+		0x81C, 0xE52C0603,
+		0x81C, 0xE42E0603,
+		0x81C, 0xE3300603,
+		0x81C, 0xE2320603,
+		0x81C, 0xC6340603,
+		0x81C, 0xC5360603,
+		0x81C, 0xC4380603,
+		0x81C, 0xC33A0603,
+		0x81C, 0xA63C0603,
+		0x81C, 0xA53E0603,
+		0x81C, 0xA4400603,
+		0x81C, 0xA3420603,
+		0x81C, 0xA2440603,
+		0x81C, 0xA1460603,
+		0x81C, 0x83480603,
+		0x81C, 0x824A0603,
+		0x81C, 0x814C0603,
+		0x81C, 0x804E0603,
+		0x81C, 0x63500603,
+		0x81C, 0x62520603,
+		0x81C, 0x61540603,
+		0x81C, 0x42560603,
+		0x81C, 0x41580603,
+		0x81C, 0x405A0603,
+		0x81C, 0x225C0603,
+		0x81C, 0x215E0603,
+		0x81C, 0x20600603,
+		0x81C, 0x04620603,
+		0x81C, 0x03640603,
+		0x81C, 0x02660603,
+		0x81C, 0x01680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBD000603,
+		0x81C, 0xBC020603,
+		0x81C, 0xBB040603,
+		0x81C, 0xBA060603,
+		0x81C, 0xB9080603,
+		0x81C, 0xB80A0603,
+		0x81C, 0xB70C0603,
+		0x81C, 0xB60E0603,
+		0x81C, 0xB5100603,
+		0x81C, 0xB4120603,
+		0x81C, 0xB3140603,
+		0x81C, 0xB2160603,
+		0x81C, 0xB1180603,
+		0x81C, 0xB01A0603,
+		0x81C, 0xAF1C0603,
+		0x81C, 0xAE1E0603,
+		0x81C, 0xAD200603,
+		0x81C, 0x8F220603,
+		0x81C, 0x8E240603,
+		0x81C, 0x8D260603,
+		0x81C, 0x8C280603,
+		0x81C, 0x8B2A0603,
+		0x81C, 0x8A2C0603,
+		0x81C, 0x892E0603,
+		0x81C, 0x88300603,
+		0x81C, 0x6B320603,
+		0x81C, 0x6A340603,
+		0x81C, 0x69360603,
+		0x81C, 0x68380603,
+		0x81C, 0x673A0603,
+		0x81C, 0x663C0603,
+		0x81C, 0x653E0603,
+		0x81C, 0x64400603,
+		0x81C, 0x63420603,
+		0x81C, 0x62440603,
+		0x81C, 0x61460603,
+		0x81C, 0x60480603,
+		0x81C, 0x424A0603,
+		0x81C, 0x414C0603,
+		0x81C, 0x404E0603,
+		0x81C, 0x06500603,
+		0x81C, 0x05520603,
+		0x81C, 0x04540603,
+		0x81C, 0x03560603,
+		0x81C, 0x02580603,
+		0x81C, 0x015A0603,
+		0x81C, 0x005C0603,
+		0x81C, 0x005E0603,
+		0x81C, 0x00600603,
+		0x81C, 0x00620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007C0603,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000603,
+		0x81C, 0xF6020603,
+		0x81C, 0xF5040603,
+		0x81C, 0xF4060603,
+		0x81C, 0xF3080603,
+		0x81C, 0xF20A0603,
+		0x81C, 0xF10C0603,
+		0x81C, 0xF00E0603,
+		0x81C, 0xEF100603,
+		0x81C, 0xEE120603,
+		0x81C, 0xED140603,
+		0x81C, 0xEC160603,
+		0x81C, 0xEB180603,
+		0x81C, 0xEA1A0603,
+		0x81C, 0xE91C0603,
+		0x81C, 0xE81E0603,
+		0x81C, 0xE7200603,
+		0x81C, 0xE6220603,
+		0x81C, 0xE5240603,
+		0x81C, 0xE4260603,
+		0x81C, 0xE3280603,
+		0x81C, 0xC42A0603,
+		0x81C, 0xC32C0603,
+		0x81C, 0xC22E0603,
+		0x81C, 0xC1300603,
+		0x81C, 0xC0320603,
+		0x81C, 0xA3340603,
+		0x81C, 0xA2360603,
+		0x81C, 0xA1380603,
+		0x81C, 0xA03A0603,
+		0x81C, 0x823C0603,
+		0x81C, 0x813E0603,
+		0x81C, 0x80400603,
+		0x81C, 0x64420603,
+		0x81C, 0x63440603,
+		0x81C, 0x62460603,
+		0x81C, 0x61480603,
+		0x81C, 0x604A0603,
+		0x81C, 0x414C0603,
+		0x81C, 0x404E0603,
+		0x81C, 0x22500603,
+		0x81C, 0x21520603,
+		0x81C, 0x20540603,
+		0x81C, 0x03560603,
+		0x81C, 0x02580603,
+		0x81C, 0x015A0603,
+		0x81C, 0x005C0603,
+		0x81C, 0x005E0603,
+		0x81C, 0x00600603,
+		0x81C, 0x00620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000603,
+		0x81C, 0xFB020603,
+		0x81C, 0xFA040603,
+		0x81C, 0xF9060603,
+		0x81C, 0xF8080603,
+		0x81C, 0xF70A0603,
+		0x81C, 0xF60C0603,
+		0x81C, 0xF50E0603,
+		0x81C, 0xF4100603,
+		0x81C, 0xF3120603,
+		0x81C, 0xF2140603,
+		0x81C, 0xF1160603,
+		0x81C, 0xF0180603,
+		0x81C, 0xEF1A0603,
+		0x81C, 0xEE1C0603,
+		0x81C, 0xED1E0603,
+		0x81C, 0xEC200603,
+		0x81C, 0xEB220603,
+		0x81C, 0xEA240603,
+		0x81C, 0xE9260603,
+		0x81C, 0xE8280603,
+		0x81C, 0xE72A0603,
+		0x81C, 0xE62C0603,
+		0x81C, 0xE52E0603,
+		0x81C, 0xE4300603,
+		0x81C, 0xE3320603,
+		0x81C, 0xE2340603,
+		0x81C, 0xC6360603,
+		0x81C, 0xC5380603,
+		0x81C, 0xC43A0603,
+		0x81C, 0xC33C0603,
+		0x81C, 0xA63E0603,
+		0x81C, 0xA5400603,
+		0x81C, 0xA4420603,
+		0x81C, 0xA3440603,
+		0x81C, 0xA2460603,
+		0x81C, 0xA1480603,
+		0x81C, 0x834A0603,
+		0x81C, 0x824C0603,
+		0x81C, 0x814E0603,
+		0x81C, 0x64500603,
+		0x81C, 0x63520603,
+		0x81C, 0x62540603,
+		0x81C, 0x61560603,
+		0x81C, 0x60580603,
+		0x81C, 0x405A0603,
+		0x81C, 0x215C0603,
+		0x81C, 0x205E0603,
+		0x81C, 0x03600603,
+		0x81C, 0x02620603,
+		0x81C, 0x01640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000603,
+		0x81C, 0xF6020603,
+		0x81C, 0xF5040603,
+		0x81C, 0xF4060603,
+		0x81C, 0xF3080603,
+		0x81C, 0xF20A0603,
+		0x81C, 0xF10C0603,
+		0x81C, 0xF00E0603,
+		0x81C, 0xEF100603,
+		0x81C, 0xEE120603,
+		0x81C, 0xED140603,
+		0x81C, 0xEC160603,
+		0x81C, 0xEB180603,
+		0x81C, 0xEA1A0603,
+		0x81C, 0xE91C0603,
+		0x81C, 0xE81E0603,
+		0x81C, 0xE7200603,
+		0x81C, 0xE6220603,
+		0x81C, 0xE5240603,
+		0x81C, 0xE4260603,
+		0x81C, 0xE3280603,
+		0x81C, 0xC42A0603,
+		0x81C, 0xC32C0603,
+		0x81C, 0xC22E0603,
+		0x81C, 0xC1300603,
+		0x81C, 0xC0320603,
+		0x81C, 0xA3340603,
+		0x81C, 0xA2360603,
+		0x81C, 0xA1380603,
+		0x81C, 0xA03A0603,
+		0x81C, 0x823C0603,
+		0x81C, 0x813E0603,
+		0x81C, 0x80400603,
+		0x81C, 0x64420603,
+		0x81C, 0x63440603,
+		0x81C, 0x62460603,
+		0x81C, 0x61480603,
+		0x81C, 0x604A0603,
+		0x81C, 0x414C0603,
+		0x81C, 0x404E0603,
+		0x81C, 0x22500603,
+		0x81C, 0x21520603,
+		0x81C, 0x20540603,
+		0x81C, 0x03560603,
+		0x81C, 0x02580603,
+		0x81C, 0x015A0603,
+		0x81C, 0x005C0603,
+		0x81C, 0x005E0603,
+		0x81C, 0x00600603,
+		0x81C, 0x00620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000603,
+		0x81C, 0xFB020603,
+		0x81C, 0xFA040603,
+		0x81C, 0xF9060603,
+		0x81C, 0xF8080603,
+		0x81C, 0xF70A0603,
+		0x81C, 0xF60C0603,
+		0x81C, 0xF50E0603,
+		0x81C, 0xF4100603,
+		0x81C, 0xF3120603,
+		0x81C, 0xF2140603,
+		0x81C, 0xF1160603,
+		0x81C, 0xF0180603,
+		0x81C, 0xEF1A0603,
+		0x81C, 0xEE1C0603,
+		0x81C, 0xED1E0603,
+		0x81C, 0xEC200603,
+		0x81C, 0xEB220603,
+		0x81C, 0xEA240603,
+		0x81C, 0xE9260603,
+		0x81C, 0xE8280603,
+		0x81C, 0xE72A0603,
+		0x81C, 0xE62C0603,
+		0x81C, 0xE52E0603,
+		0x81C, 0xE4300603,
+		0x81C, 0xE3320603,
+		0x81C, 0xE2340603,
+		0x81C, 0xE1360603,
+		0x81C, 0xC5380603,
+		0x81C, 0xC43A0603,
+		0x81C, 0xC33C0603,
+		0x81C, 0xC23E0603,
+		0x81C, 0xC1400603,
+		0x81C, 0xA3420603,
+		0x81C, 0xA2440603,
+		0x81C, 0xA1460603,
+		0x81C, 0xA0480603,
+		0x81C, 0x834A0603,
+		0x81C, 0x824C0603,
+		0x81C, 0x814E0603,
+		0x81C, 0x64500603,
+		0x81C, 0x63520603,
+		0x81C, 0x62540603,
+		0x81C, 0x61560603,
+		0x81C, 0x25580603,
+		0x81C, 0x245A0603,
+		0x81C, 0x235C0603,
+		0x81C, 0x225E0603,
+		0x81C, 0x21600603,
+		0x81C, 0x04620603,
+		0x81C, 0x03640603,
+		0x81C, 0x02660603,
+		0x81C, 0x01680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000603,
+		0x81C, 0xF8020603,
+		0x81C, 0xF7040603,
+		0x81C, 0xF6060603,
+		0x81C, 0xF5080603,
+		0x81C, 0xF40A0603,
+		0x81C, 0xF30C0603,
+		0x81C, 0xF20E0603,
+		0x81C, 0xF1100603,
+		0x81C, 0xF0120603,
+		0x81C, 0xEF140603,
+		0x81C, 0xEE160603,
+		0x81C, 0xED180603,
+		0x81C, 0xEC1A0603,
+		0x81C, 0xEB1C0603,
+		0x81C, 0xEA1E0603,
+		0x81C, 0xE9200603,
+		0x81C, 0xE8220603,
+		0x81C, 0xE7240603,
+		0x81C, 0xE6260603,
+		0x81C, 0xE5280603,
+		0x81C, 0xC42A0603,
+		0x81C, 0xC32C0603,
+		0x81C, 0xC22E0603,
+		0x81C, 0xC1300603,
+		0x81C, 0xC0320603,
+		0x81C, 0xA3340603,
+		0x81C, 0xA2360603,
+		0x81C, 0xA1380603,
+		0x81C, 0xA03A0603,
+		0x81C, 0x823C0603,
+		0x81C, 0x813E0603,
+		0x81C, 0x80400603,
+		0x81C, 0x64420603,
+		0x81C, 0x63440603,
+		0x81C, 0x62460603,
+		0x81C, 0x61480603,
+		0x81C, 0x604A0603,
+		0x81C, 0x414C0603,
+		0x81C, 0x404E0603,
+		0x81C, 0x22500603,
+		0x81C, 0x21520603,
+		0x81C, 0x20540603,
+		0x81C, 0x03560603,
+		0x81C, 0x02580603,
+		0x81C, 0x015A0603,
+		0x81C, 0x005C0603,
+		0x81C, 0x005E0603,
+		0x81C, 0x00600603,
+		0x81C, 0x00620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBE000603,
+		0x81C, 0xBD020603,
+		0x81C, 0xBC040603,
+		0x81C, 0xBB060603,
+		0x81C, 0xBA080603,
+		0x81C, 0xB90A0603,
+		0x81C, 0xB80C0603,
+		0x81C, 0xB70E0603,
+		0x81C, 0xB6100603,
+		0x81C, 0xB5120603,
+		0x81C, 0xB4140603,
+		0x81C, 0xB3160603,
+		0x81C, 0xB2180603,
+		0x81C, 0xB11A0603,
+		0x81C, 0xB01C0603,
+		0x81C, 0xAF1E0603,
+		0x81C, 0xAE200603,
+		0x81C, 0xAD220603,
+		0x81C, 0x8F240603,
+		0x81C, 0x8E260603,
+		0x81C, 0x8D280603,
+		0x81C, 0x8C2A0603,
+		0x81C, 0x8B2C0603,
+		0x81C, 0x8A2E0603,
+		0x81C, 0x89300603,
+		0x81C, 0x88320603,
+		0x81C, 0x6B340603,
+		0x81C, 0x6A360603,
+		0x81C, 0x69380603,
+		0x81C, 0x683A0603,
+		0x81C, 0x673C0603,
+		0x81C, 0x663E0603,
+		0x81C, 0x65400603,
+		0x81C, 0x64420603,
+		0x81C, 0x63440603,
+		0x81C, 0x62460603,
+		0x81C, 0x61480603,
+		0x81C, 0x604A0603,
+		0x81C, 0x424C0603,
+		0x81C, 0x414E0603,
+		0x81C, 0x40500603,
+		0x81C, 0x06520603,
+		0x81C, 0x05540603,
+		0x81C, 0x04560603,
+		0x81C, 0x03580603,
+		0x81C, 0x025A0603,
+		0x81C, 0x015C0603,
+		0x81C, 0x005E0603,
+		0x81C, 0x00600603,
+		0x81C, 0x00620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000603,
+		0x81C, 0xFA020603,
+		0x81C, 0xF9040603,
+		0x81C, 0xF8060603,
+		0x81C, 0xF7080603,
+		0x81C, 0xF60A0603,
+		0x81C, 0xF50C0603,
+		0x81C, 0xF40E0603,
+		0x81C, 0xF3100603,
+		0x81C, 0xF2120603,
+		0x81C, 0xF1140603,
+		0x81C, 0xF0160603,
+		0x81C, 0xEF180603,
+		0x81C, 0xEE1A0603,
+		0x81C, 0xED1C0603,
+		0x81C, 0xEC1E0603,
+		0x81C, 0xEB200603,
+		0x81C, 0xEA220603,
+		0x81C, 0xE9240603,
+		0x81C, 0xE8260603,
+		0x81C, 0xE7280603,
+		0x81C, 0xE62A0603,
+		0x81C, 0xE52C0603,
+		0x81C, 0xE42E0603,
+		0x81C, 0xE3300603,
+		0x81C, 0xE2320603,
+		0x81C, 0xC6340603,
+		0x81C, 0xC5360603,
+		0x81C, 0xC4380603,
+		0x81C, 0xC33A0603,
+		0x81C, 0xC23C0603,
+		0x81C, 0xC13E0603,
+		0x81C, 0xC0400603,
+		0x81C, 0xA3420603,
+		0x81C, 0xA2440603,
+		0x81C, 0xA1460603,
+		0x81C, 0xA0480603,
+		0x81C, 0x824A0603,
+		0x81C, 0x814C0603,
+		0x81C, 0x804E0603,
+		0x81C, 0x63500603,
+		0x81C, 0x62520603,
+		0x81C, 0x61540603,
+		0x81C, 0x60560603,
+		0x81C, 0x24580603,
+		0x81C, 0x235A0603,
+		0x81C, 0x225C0603,
+		0x81C, 0x215E0603,
+		0x81C, 0x20600603,
+		0x81C, 0x03620603,
+		0x81C, 0x02640603,
+		0x81C, 0x01660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000603,
+		0x81C, 0xF7020603,
+		0x81C, 0xF6040603,
+		0x81C, 0xF5060603,
+		0x81C, 0xF4080603,
+		0x81C, 0xF30A0603,
+		0x81C, 0xF20C0603,
+		0x81C, 0xF10E0603,
+		0x81C, 0xF0100603,
+		0x81C, 0xEF120603,
+		0x81C, 0xEE140603,
+		0x81C, 0xED160603,
+		0x81C, 0xEC180603,
+		0x81C, 0xEB1A0603,
+		0x81C, 0xEA1C0603,
+		0x81C, 0xE91E0603,
+		0x81C, 0xE8200603,
+		0x81C, 0xE7220603,
+		0x81C, 0xE6240603,
+		0x81C, 0xE5260603,
+		0x81C, 0xE4280603,
+		0x81C, 0xE32A0603,
+		0x81C, 0xC42C0603,
+		0x81C, 0xC32E0603,
+		0x81C, 0xC2300603,
+		0x81C, 0xC1320603,
+		0x81C, 0xA3340603,
+		0x81C, 0xA2360603,
+		0x81C, 0xA1380603,
+		0x81C, 0xA03A0603,
+		0x81C, 0x823C0603,
+		0x81C, 0x813E0603,
+		0x81C, 0x80400603,
+		0x81C, 0x65420603,
+		0x81C, 0x64440603,
+		0x81C, 0x63460603,
+		0x81C, 0x62480603,
+		0x81C, 0x614A0603,
+		0x81C, 0x424C0603,
+		0x81C, 0x414E0603,
+		0x81C, 0x40500603,
+		0x81C, 0x22520603,
+		0x81C, 0x21540603,
+		0x81C, 0x20560603,
+		0x81C, 0x04580603,
+		0x81C, 0x035A0603,
+		0x81C, 0x025C0603,
+		0x81C, 0x015E0603,
+		0x81C, 0x00600603,
+		0x81C, 0x00620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000603,
+		0x81C, 0xFB020603,
+		0x81C, 0xFA040603,
+		0x81C, 0xF9060603,
+		0x81C, 0xF8080603,
+		0x81C, 0xF70A0603,
+		0x81C, 0xF60C0603,
+		0x81C, 0xF50E0603,
+		0x81C, 0xF4100603,
+		0x81C, 0xF3120603,
+		0x81C, 0xF2140603,
+		0x81C, 0xF1160603,
+		0x81C, 0xF0180603,
+		0x81C, 0xEE1A0603,
+		0x81C, 0xED1C0603,
+		0x81C, 0xEC1E0603,
+		0x81C, 0xEB200603,
+		0x81C, 0xEA220603,
+		0x81C, 0xE9240603,
+		0x81C, 0xE8260603,
+		0x81C, 0xE7280603,
+		0x81C, 0xE62A0603,
+		0x81C, 0xE52C0603,
+		0x81C, 0xE42E0603,
+		0x81C, 0xE3300603,
+		0x81C, 0xE2320603,
+		0x81C, 0xC6340603,
+		0x81C, 0xC5360603,
+		0x81C, 0xC4380603,
+		0x81C, 0xC33A0603,
+		0x81C, 0xA63C0603,
+		0x81C, 0xA53E0603,
+		0x81C, 0xA4400603,
+		0x81C, 0xA3420603,
+		0x81C, 0xA2440603,
+		0x81C, 0xA1460603,
+		0x81C, 0x83480603,
+		0x81C, 0x824A0603,
+		0x81C, 0x814C0603,
+		0x81C, 0x804E0603,
+		0x81C, 0x63500603,
+		0x81C, 0x62520603,
+		0x81C, 0x61540603,
+		0x81C, 0x42560603,
+		0x81C, 0x41580603,
+		0x81C, 0x405A0603,
+		0x81C, 0x225C0603,
+		0x81C, 0x215E0603,
+		0x81C, 0x20600603,
+		0x81C, 0x04620603,
+		0x81C, 0x03640603,
+		0x81C, 0x02660603,
+		0x81C, 0x01680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000603,
+		0x81C, 0xF8020603,
+		0x81C, 0xF7040603,
+		0x81C, 0xF6060603,
+		0x81C, 0xF5080603,
+		0x81C, 0xF40A0603,
+		0x81C, 0xF30C0603,
+		0x81C, 0xF20E0603,
+		0x81C, 0xF1100603,
+		0x81C, 0xF0120603,
+		0x81C, 0xEF140603,
+		0x81C, 0xEE160603,
+		0x81C, 0xED180603,
+		0x81C, 0xEC1A0603,
+		0x81C, 0xEB1C0603,
+		0x81C, 0xEA1E0603,
+		0x81C, 0xE9200603,
+		0x81C, 0xE8220603,
+		0x81C, 0xE7240603,
+		0x81C, 0xE6260603,
+		0x81C, 0xE5280603,
+		0x81C, 0xE42A0603,
+		0x81C, 0xC42C0603,
+		0x81C, 0xC32E0603,
+		0x81C, 0xC2300603,
+		0x81C, 0xC1320603,
+		0x81C, 0xA3340603,
+		0x81C, 0xA2360603,
+		0x81C, 0xA1380603,
+		0x81C, 0xA03A0603,
+		0x81C, 0x823C0603,
+		0x81C, 0x813E0603,
+		0x81C, 0x80400603,
+		0x81C, 0x64420603,
+		0x81C, 0x63440603,
+		0x81C, 0x62460603,
+		0x81C, 0x61480603,
+		0x81C, 0x604A0603,
+		0x81C, 0x244C0603,
+		0x81C, 0x234E0603,
+		0x81C, 0x22500603,
+		0x81C, 0x21520603,
+		0x81C, 0x20540603,
+		0x81C, 0x05560603,
+		0x81C, 0x04580603,
+		0x81C, 0x035A0603,
+		0x81C, 0x025C0603,
+		0x81C, 0x015E0603,
+		0x81C, 0x00600603,
+		0x81C, 0x00620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000603,
+		0x81C, 0xFB020603,
+		0x81C, 0xFA040603,
+		0x81C, 0xF9060603,
+		0x81C, 0xF8080603,
+		0x81C, 0xF70A0603,
+		0x81C, 0xF60C0603,
+		0x81C, 0xF50E0603,
+		0x81C, 0xF4100603,
+		0x81C, 0xF3120603,
+		0x81C, 0xF2140603,
+		0x81C, 0xF1160603,
+		0x81C, 0xF0180603,
+		0x81C, 0xEF1A0603,
+		0x81C, 0xEE1C0603,
+		0x81C, 0xED1E0603,
+		0x81C, 0xEC200603,
+		0x81C, 0xEB220603,
+		0x81C, 0xEA240603,
+		0x81C, 0xE9260603,
+		0x81C, 0xE8280603,
+		0x81C, 0xE72A0603,
+		0x81C, 0xE62C0603,
+		0x81C, 0xE52E0603,
+		0x81C, 0xE4300603,
+		0x81C, 0xE3320603,
+		0x81C, 0xE2340603,
+		0x81C, 0xC6360603,
+		0x81C, 0xC5380603,
+		0x81C, 0xC43A0603,
+		0x81C, 0xC33C0603,
+		0x81C, 0xA63E0603,
+		0x81C, 0xA5400603,
+		0x81C, 0xA4420603,
+		0x81C, 0xA3440603,
+		0x81C, 0xA2460603,
+		0x81C, 0xA1480603,
+		0x81C, 0x834A0603,
+		0x81C, 0x824C0603,
+		0x81C, 0x814E0603,
+		0x81C, 0x64500603,
+		0x81C, 0x63520603,
+		0x81C, 0x62540603,
+		0x81C, 0x61560603,
+		0x81C, 0x60580603,
+		0x81C, 0x405A0603,
+		0x81C, 0x215C0603,
+		0x81C, 0x205E0603,
+		0x81C, 0x03600603,
+		0x81C, 0x02620603,
+		0x81C, 0x01640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000603,
+		0x81C, 0xFB020603,
+		0x81C, 0xFA040603,
+		0x81C, 0xF9060603,
+		0x81C, 0xF8080603,
+		0x81C, 0xF70A0603,
+		0x81C, 0xF60C0603,
+		0x81C, 0xF50E0603,
+		0x81C, 0xF4100603,
+		0x81C, 0xF3120603,
+		0x81C, 0xF2140603,
+		0x81C, 0xF1160603,
+		0x81C, 0xF0180603,
+		0x81C, 0xEE1A0603,
+		0x81C, 0xED1C0603,
+		0x81C, 0xEC1E0603,
+		0x81C, 0xEB200603,
+		0x81C, 0xEA220603,
+		0x81C, 0xE9240603,
+		0x81C, 0xE8260603,
+		0x81C, 0xE7280603,
+		0x81C, 0xE62A0603,
+		0x81C, 0xE52C0603,
+		0x81C, 0xE42E0603,
+		0x81C, 0xE3300603,
+		0x81C, 0xE2320603,
+		0x81C, 0xC6340603,
+		0x81C, 0xC5360603,
+		0x81C, 0xC4380603,
+		0x81C, 0xC33A0603,
+		0x81C, 0xA63C0603,
+		0x81C, 0xA53E0603,
+		0x81C, 0xA4400603,
+		0x81C, 0xA3420603,
+		0x81C, 0xA2440603,
+		0x81C, 0xA1460603,
+		0x81C, 0x83480603,
+		0x81C, 0x824A0603,
+		0x81C, 0x814C0603,
+		0x81C, 0x804E0603,
+		0x81C, 0x63500603,
+		0x81C, 0x62520603,
+		0x81C, 0x61540603,
+		0x81C, 0x42560603,
+		0x81C, 0x41580603,
+		0x81C, 0x405A0603,
+		0x81C, 0x225C0603,
+		0x81C, 0x215E0603,
+		0x81C, 0x20600603,
+		0x81C, 0x04620603,
+		0x81C, 0x03640603,
+		0x81C, 0x02660603,
+		0x81C, 0x01680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000603,
+		0x81C, 0xFB020603,
+		0x81C, 0xFA040603,
+		0x81C, 0xF9060603,
+		0x81C, 0xF8080603,
+		0x81C, 0xF70A0603,
+		0x81C, 0xF60C0603,
+		0x81C, 0xF50E0603,
+		0x81C, 0xF4100603,
+		0x81C, 0xF3120603,
+		0x81C, 0xF2140603,
+		0x81C, 0xF1160603,
+		0x81C, 0xF0180603,
+		0x81C, 0xEE1A0603,
+		0x81C, 0xED1C0603,
+		0x81C, 0xEC1E0603,
+		0x81C, 0xEB200603,
+		0x81C, 0xEA220603,
+		0x81C, 0xE9240603,
+		0x81C, 0xE8260603,
+		0x81C, 0xE7280603,
+		0x81C, 0xE62A0603,
+		0x81C, 0xE52C0603,
+		0x81C, 0xE42E0603,
+		0x81C, 0xE3300603,
+		0x81C, 0xE2320603,
+		0x81C, 0xC6340603,
+		0x81C, 0xC5360603,
+		0x81C, 0xC4380603,
+		0x81C, 0xC33A0603,
+		0x81C, 0xA63C0603,
+		0x81C, 0xA53E0603,
+		0x81C, 0xA4400603,
+		0x81C, 0xA3420603,
+		0x81C, 0xA2440603,
+		0x81C, 0xA1460603,
+		0x81C, 0x83480603,
+		0x81C, 0x824A0603,
+		0x81C, 0x814C0603,
+		0x81C, 0x804E0603,
+		0x81C, 0x63500603,
+		0x81C, 0x62520603,
+		0x81C, 0x61540603,
+		0x81C, 0x42560603,
+		0x81C, 0x41580603,
+		0x81C, 0x405A0603,
+		0x81C, 0x225C0603,
+		0x81C, 0x215E0603,
+		0x81C, 0x20600603,
+		0x81C, 0x04620603,
+		0x81C, 0x03640603,
+		0x81C, 0x02660603,
+		0x81C, 0x01680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBF000603,
+		0x81C, 0xBF020603,
+		0x81C, 0xBF040603,
+		0x81C, 0xBF060603,
+		0x81C, 0xBF080603,
+		0x81C, 0xBE0A0603,
+		0x81C, 0xBD0C0603,
+		0x81C, 0xBC0E0603,
+		0x81C, 0xBB100603,
+		0x81C, 0xBA120603,
+		0x81C, 0xB9140603,
+		0x81C, 0xB8160603,
+		0x81C, 0xB7180603,
+		0x81C, 0xB61A0603,
+		0x81C, 0xB51C0603,
+		0x81C, 0xB41E0603,
+		0x81C, 0xB1200603,
+		0x81C, 0xB2220603,
+		0x81C, 0xB1240603,
+		0x81C, 0xB0260603,
+		0x81C, 0xAF280603,
+		0x81C, 0xAE2A0603,
+		0x81C, 0xAD2C0603,
+		0x81C, 0xAC2E0603,
+		0x81C, 0xAB300603,
+		0x81C, 0xAA320603,
+		0x81C, 0xC6340603,
+		0x81C, 0xC5360603,
+		0x81C, 0xC4380603,
+		0x81C, 0xC33A0603,
+		0x81C, 0x883C0603,
+		0x81C, 0x873E0603,
+		0x81C, 0x86400603,
+		0x81C, 0x85420603,
+		0x81C, 0x84440603,
+		0x81C, 0x83460603,
+		0x81C, 0x67480603,
+		0x81C, 0x664A0603,
+		0x81C, 0x654C0603,
+		0x81C, 0x644E0603,
+		0x81C, 0x27500603,
+		0x81C, 0x26520603,
+		0x81C, 0x25540603,
+		0x81C, 0x24560603,
+		0x81C, 0x23580603,
+		0x81C, 0x225A0603,
+		0x81C, 0x215C0603,
+		0x81C, 0x205E0603,
+		0x81C, 0x03600603,
+		0x81C, 0x02620603,
+		0x81C, 0x01640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000403,
+		0x81C, 0xFB000603,
+		0x81C, 0xFA020603,
+		0x81C, 0xF9040603,
+		0x81C, 0xF8060603,
+		0x81C, 0xF7080603,
+		0x81C, 0xF60A0603,
+		0x81C, 0xF50C0603,
+		0x81C, 0xF40E0603,
+		0x81C, 0xF3100603,
+		0x81C, 0xF2120603,
+		0x81C, 0xF1140603,
+		0x81C, 0xF0160603,
+		0x81C, 0xEF180603,
+		0x81C, 0xEE1A0603,
+		0x81C, 0xED1C0603,
+		0x81C, 0xEC1E0603,
+		0x81C, 0xEB200603,
+		0x81C, 0xEA220603,
+		0x81C, 0xE9240603,
+		0x81C, 0xE8260603,
+		0x81C, 0xE7280603,
+		0x81C, 0xE62A0603,
+		0x81C, 0xE52C0603,
+		0x81C, 0xE42E0603,
+		0x81C, 0xE3300603,
+		0x81C, 0xE2320603,
+		0x81C, 0xC6340603,
+		0x81C, 0xC5360603,
+		0x81C, 0xC4380603,
+		0x81C, 0xC33A0603,
+		0x81C, 0xA63C0603,
+		0x81C, 0xA53E0603,
+		0x81C, 0xA4400603,
+		0x81C, 0xA3420603,
+		0x81C, 0xA2440603,
+		0x81C, 0xA1460603,
+		0x81C, 0x83480603,
+		0x81C, 0x824A0603,
+		0x81C, 0x814C0603,
+		0x81C, 0x644E0603,
+		0x81C, 0x63500603,
+		0x81C, 0x62520603,
+		0x81C, 0x61540603,
+		0x81C, 0x60560603,
+		0x81C, 0x40580603,
+		0x81C, 0x215A0603,
+		0x81C, 0x205C0603,
+		0x81C, 0x035E0603,
+		0x81C, 0x02600603,
+		0x81C, 0x01620603,
+		0x81C, 0x00640603,
+		0x81C, 0x00660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFD000603,
+		0x81C, 0xFC020603,
+		0x81C, 0xFB040603,
+		0x81C, 0xFA060603,
+		0x81C, 0xF9080603,
+		0x81C, 0xF80A0603,
+		0x81C, 0xF70C0603,
+		0x81C, 0xF60E0603,
+		0x81C, 0xF5100603,
+		0x81C, 0xF4120603,
+		0x81C, 0xF3140603,
+		0x81C, 0xF2160603,
+		0x81C, 0xF1180603,
+		0x81C, 0xF01A0603,
+		0x81C, 0xEF1C0603,
+		0x81C, 0xEE1E0603,
+		0x81C, 0xED200603,
+		0x81C, 0xEC220603,
+		0x81C, 0xEB240603,
+		0x81C, 0xEA260603,
+		0x81C, 0xE9280603,
+		0x81C, 0xE82A0603,
+		0x81C, 0xE72C0603,
+		0x81C, 0xE62E0603,
+		0x81C, 0xE5300603,
+		0x81C, 0xE4320603,
+		0x81C, 0xE3340603,
+		0x81C, 0xC6360603,
+		0x81C, 0xC5380603,
+		0x81C, 0xC43A0603,
+		0x81C, 0xC33C0603,
+		0x81C, 0xA63E0603,
+		0x81C, 0xA5400603,
+		0x81C, 0xA4420603,
+		0x81C, 0xA3440603,
+		0x81C, 0xA2460603,
+		0x81C, 0xA1480603,
+		0x81C, 0x834A0603,
+		0x81C, 0x824C0603,
+		0x81C, 0x814E0603,
+		0x81C, 0x64500603,
+		0x81C, 0x63520603,
+		0x81C, 0x62540603,
+		0x81C, 0x61560603,
+		0x81C, 0x60580603,
+		0x81C, 0x235A0603,
+		0x81C, 0x225C0603,
+		0x81C, 0x215E0603,
+		0x81C, 0x20600603,
+		0x81C, 0x03620603,
+		0x81C, 0x02640603,
+		0x81C, 0x01660603,
+		0x81C, 0x00680603,
+		0x81C, 0x006A0603,
+		0x81C, 0x006C0603,
+		0x81C, 0x006E0603,
+		0x81C, 0x00700603,
+		0x81C, 0x00720603,
+		0x81C, 0x00740603,
+		0x81C, 0x00760603,
+		0x81C, 0x00780603,
+		0x81C, 0x007A0603,
+		0x81C, 0x007C0603,
+		0x81C, 0x007E0603,
+		0x81C, 0x007E0603,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000703,
+		0x81C, 0xFB020703,
+		0x81C, 0xFA040703,
+		0x81C, 0xF9060703,
+		0x81C, 0xF8080703,
+		0x81C, 0xF70A0703,
+		0x81C, 0xF60C0703,
+		0x81C, 0xF50E0703,
+		0x81C, 0xF4100703,
+		0x81C, 0xF3120703,
+		0x81C, 0xF2140703,
+		0x81C, 0xF1160703,
+		0x81C, 0xEF180703,
+		0x81C, 0xEE1A0703,
+		0x81C, 0xED1C0703,
+		0x81C, 0xEC1E0703,
+		0x81C, 0xEB200703,
+		0x81C, 0xEA220703,
+		0x81C, 0xE9240703,
+		0x81C, 0xE8260703,
+		0x81C, 0xE7280703,
+		0x81C, 0xE62A0703,
+		0x81C, 0xE52C0703,
+		0x81C, 0xE42E0703,
+		0x81C, 0xE3300703,
+		0x81C, 0xE2320703,
+		0x81C, 0xC6340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0xA63C0703,
+		0x81C, 0xA53E0703,
+		0x81C, 0xA4400703,
+		0x81C, 0xA3420703,
+		0x81C, 0xA2440703,
+		0x81C, 0xA1460703,
+		0x81C, 0x83480703,
+		0x81C, 0x824A0703,
+		0x81C, 0x814C0703,
+		0x81C, 0x804E0703,
+		0x81C, 0x63500703,
+		0x81C, 0x62520703,
+		0x81C, 0x61540703,
+		0x81C, 0x42560703,
+		0x81C, 0x41580703,
+		0x81C, 0x405A0703,
+		0x81C, 0x225C0703,
+		0x81C, 0x215E0703,
+		0x81C, 0x20600703,
+		0x81C, 0x04620703,
+		0x81C, 0x03640703,
+		0x81C, 0x02660703,
+		0x81C, 0x01680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBD000703,
+		0x81C, 0xBC020703,
+		0x81C, 0xBB040703,
+		0x81C, 0xBA060703,
+		0x81C, 0xB9080703,
+		0x81C, 0xB80A0703,
+		0x81C, 0xB70C0703,
+		0x81C, 0xB60E0703,
+		0x81C, 0xB5100703,
+		0x81C, 0xB4120703,
+		0x81C, 0xB3140703,
+		0x81C, 0xB2160703,
+		0x81C, 0xB1180703,
+		0x81C, 0xB01A0703,
+		0x81C, 0xAF1C0703,
+		0x81C, 0xAE1E0703,
+		0x81C, 0xAD200703,
+		0x81C, 0xAC220703,
+		0x81C, 0x8E240703,
+		0x81C, 0x8D260703,
+		0x81C, 0x8C280703,
+		0x81C, 0x6F2A0703,
+		0x81C, 0x6E2C0703,
+		0x81C, 0x6D2E0703,
+		0x81C, 0x6C300703,
+		0x81C, 0x6B320703,
+		0x81C, 0x6A340703,
+		0x81C, 0x69360703,
+		0x81C, 0x68380703,
+		0x81C, 0x673A0703,
+		0x81C, 0x663C0703,
+		0x81C, 0x653E0703,
+		0x81C, 0x64400703,
+		0x81C, 0x63420703,
+		0x81C, 0x62440703,
+		0x81C, 0x61460703,
+		0x81C, 0x60480703,
+		0x81C, 0x424A0703,
+		0x81C, 0x414C0703,
+		0x81C, 0x404E0703,
+		0x81C, 0x06500703,
+		0x81C, 0x05520703,
+		0x81C, 0x04540703,
+		0x81C, 0x03560703,
+		0x81C, 0x02580703,
+		0x81C, 0x015A0703,
+		0x81C, 0x005C0703,
+		0x81C, 0x005E0703,
+		0x81C, 0x00600703,
+		0x81C, 0x00620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007C0703,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000703,
+		0x81C, 0xF6020703,
+		0x81C, 0xF5040703,
+		0x81C, 0xF4060703,
+		0x81C, 0xF3080703,
+		0x81C, 0xF20A0703,
+		0x81C, 0xF10C0703,
+		0x81C, 0xF00E0703,
+		0x81C, 0xEF100703,
+		0x81C, 0xEE120703,
+		0x81C, 0xED140703,
+		0x81C, 0xEC160703,
+		0x81C, 0xEB180703,
+		0x81C, 0xEA1A0703,
+		0x81C, 0xE91C0703,
+		0x81C, 0xCA1E0703,
+		0x81C, 0xC9200703,
+		0x81C, 0xC8220703,
+		0x81C, 0xC7240703,
+		0x81C, 0xC6260703,
+		0x81C, 0xC5280703,
+		0x81C, 0xC42A0703,
+		0x81C, 0xC32C0703,
+		0x81C, 0xC22E0703,
+		0x81C, 0xC1300703,
+		0x81C, 0xA4320703,
+		0x81C, 0xA3340703,
+		0x81C, 0xA2360703,
+		0x81C, 0xA1380703,
+		0x81C, 0xA03A0703,
+		0x81C, 0x823C0703,
+		0x81C, 0x813E0703,
+		0x81C, 0x80400703,
+		0x81C, 0x64420703,
+		0x81C, 0x63440703,
+		0x81C, 0x62460703,
+		0x81C, 0x61480703,
+		0x81C, 0x604A0703,
+		0x81C, 0x414C0703,
+		0x81C, 0x404E0703,
+		0x81C, 0x22500703,
+		0x81C, 0x21520703,
+		0x81C, 0x20540703,
+		0x81C, 0x03560703,
+		0x81C, 0x02580703,
+		0x81C, 0x015A0703,
+		0x81C, 0x005C0703,
+		0x81C, 0x005E0703,
+		0x81C, 0x00600703,
+		0x81C, 0x00620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000703,
+		0x81C, 0xFB020703,
+		0x81C, 0xFA040703,
+		0x81C, 0xF9060703,
+		0x81C, 0xF8080703,
+		0x81C, 0xF70A0703,
+		0x81C, 0xF60C0703,
+		0x81C, 0xF50E0703,
+		0x81C, 0xF4100703,
+		0x81C, 0xF3120703,
+		0x81C, 0xF2140703,
+		0x81C, 0xF1160703,
+		0x81C, 0xF0180703,
+		0x81C, 0xEF1A0703,
+		0x81C, 0xEE1C0703,
+		0x81C, 0xED1E0703,
+		0x81C, 0xEC200703,
+		0x81C, 0xEB220703,
+		0x81C, 0xEA240703,
+		0x81C, 0xE9260703,
+		0x81C, 0xE8280703,
+		0x81C, 0xE72A0703,
+		0x81C, 0xE62C0703,
+		0x81C, 0xE52E0703,
+		0x81C, 0xE4300703,
+		0x81C, 0xE3320703,
+		0x81C, 0xE2340703,
+		0x81C, 0xC6360703,
+		0x81C, 0xC5380703,
+		0x81C, 0xC43A0703,
+		0x81C, 0xC33C0703,
+		0x81C, 0xA63E0703,
+		0x81C, 0xA5400703,
+		0x81C, 0xA4420703,
+		0x81C, 0xA3440703,
+		0x81C, 0xA2460703,
+		0x81C, 0x84480703,
+		0x81C, 0x834A0703,
+		0x81C, 0x824C0703,
+		0x81C, 0x814E0703,
+		0x81C, 0x80500703,
+		0x81C, 0x63520703,
+		0x81C, 0x62540703,
+		0x81C, 0x61560703,
+		0x81C, 0x60580703,
+		0x81C, 0x225A0703,
+		0x81C, 0x055C0703,
+		0x81C, 0x045E0703,
+		0x81C, 0x03600703,
+		0x81C, 0x02620703,
+		0x81C, 0x01640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF7000703,
+		0x81C, 0xF6020703,
+		0x81C, 0xF5040703,
+		0x81C, 0xF4060703,
+		0x81C, 0xF3080703,
+		0x81C, 0xF20A0703,
+		0x81C, 0xF10C0703,
+		0x81C, 0xF00E0703,
+		0x81C, 0xEF100703,
+		0x81C, 0xEE120703,
+		0x81C, 0xED140703,
+		0x81C, 0xEC160703,
+		0x81C, 0xEB180703,
+		0x81C, 0xEA1A0703,
+		0x81C, 0xE91C0703,
+		0x81C, 0xCA1E0703,
+		0x81C, 0xC9200703,
+		0x81C, 0xC8220703,
+		0x81C, 0xC7240703,
+		0x81C, 0xC6260703,
+		0x81C, 0xC5280703,
+		0x81C, 0xC42A0703,
+		0x81C, 0xC32C0703,
+		0x81C, 0xC22E0703,
+		0x81C, 0xC1300703,
+		0x81C, 0xA4320703,
+		0x81C, 0xA3340703,
+		0x81C, 0xA2360703,
+		0x81C, 0xA1380703,
+		0x81C, 0xA03A0703,
+		0x81C, 0x823C0703,
+		0x81C, 0x813E0703,
+		0x81C, 0x80400703,
+		0x81C, 0x64420703,
+		0x81C, 0x63440703,
+		0x81C, 0x62460703,
+		0x81C, 0x61480703,
+		0x81C, 0x604A0703,
+		0x81C, 0x414C0703,
+		0x81C, 0x404E0703,
+		0x81C, 0x22500703,
+		0x81C, 0x21520703,
+		0x81C, 0x20540703,
+		0x81C, 0x03560703,
+		0x81C, 0x02580703,
+		0x81C, 0x015A0703,
+		0x81C, 0x005C0703,
+		0x81C, 0x005E0703,
+		0x81C, 0x00600703,
+		0x81C, 0x00620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000703,
+		0x81C, 0xFA020703,
+		0x81C, 0xF9040703,
+		0x81C, 0xF8060703,
+		0x81C, 0xF7080703,
+		0x81C, 0xF60A0703,
+		0x81C, 0xF50C0703,
+		0x81C, 0xF40E0703,
+		0x81C, 0xF3100703,
+		0x81C, 0xF2120703,
+		0x81C, 0xF1140703,
+		0x81C, 0xF0160703,
+		0x81C, 0xEF180703,
+		0x81C, 0xEE1A0703,
+		0x81C, 0xED1C0703,
+		0x81C, 0xEC1E0703,
+		0x81C, 0xEB200703,
+		0x81C, 0xEA220703,
+		0x81C, 0xE9240703,
+		0x81C, 0xE8260703,
+		0x81C, 0xE7280703,
+		0x81C, 0xE62A0703,
+		0x81C, 0xE52C0703,
+		0x81C, 0xE42E0703,
+		0x81C, 0xE3300703,
+		0x81C, 0xE2320703,
+		0x81C, 0xE1340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0xC23C0703,
+		0x81C, 0xC13E0703,
+		0x81C, 0xA4400703,
+		0x81C, 0xA3420703,
+		0x81C, 0xA2440703,
+		0x81C, 0xA1460703,
+		0x81C, 0x83480703,
+		0x81C, 0x824A0703,
+		0x81C, 0x814C0703,
+		0x81C, 0x804E0703,
+		0x81C, 0x64500703,
+		0x81C, 0x63520703,
+		0x81C, 0x62540703,
+		0x81C, 0x61560703,
+		0x81C, 0x60580703,
+		0x81C, 0x235A0703,
+		0x81C, 0x225C0703,
+		0x81C, 0x215E0703,
+		0x81C, 0x20600703,
+		0x81C, 0x04620703,
+		0x81C, 0x03640703,
+		0x81C, 0x02660703,
+		0x81C, 0x01680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF9000703,
+		0x81C, 0xF8020703,
+		0x81C, 0xF7040703,
+		0x81C, 0xF6060703,
+		0x81C, 0xF5080703,
+		0x81C, 0xF40A0703,
+		0x81C, 0xF30C0703,
+		0x81C, 0xF20E0703,
+		0x81C, 0xF1100703,
+		0x81C, 0xF0120703,
+		0x81C, 0xEF140703,
+		0x81C, 0xEE160703,
+		0x81C, 0xED180703,
+		0x81C, 0xEC1A0703,
+		0x81C, 0xEB1C0703,
+		0x81C, 0xEA1E0703,
+		0x81C, 0xC9200703,
+		0x81C, 0xC8220703,
+		0x81C, 0xC7240703,
+		0x81C, 0xC6260703,
+		0x81C, 0xC5280703,
+		0x81C, 0xC42A0703,
+		0x81C, 0xC32C0703,
+		0x81C, 0xC22E0703,
+		0x81C, 0xC1300703,
+		0x81C, 0xC0320703,
+		0x81C, 0xA3340703,
+		0x81C, 0xA2360703,
+		0x81C, 0xA1380703,
+		0x81C, 0xA03A0703,
+		0x81C, 0x823C0703,
+		0x81C, 0x813E0703,
+		0x81C, 0x80400703,
+		0x81C, 0x64420703,
+		0x81C, 0x63440703,
+		0x81C, 0x62460703,
+		0x81C, 0x61480703,
+		0x81C, 0x604A0703,
+		0x81C, 0x414C0703,
+		0x81C, 0x404E0703,
+		0x81C, 0x22500703,
+		0x81C, 0x21520703,
+		0x81C, 0x20540703,
+		0x81C, 0x03560703,
+		0x81C, 0x02580703,
+		0x81C, 0x015A0703,
+		0x81C, 0x005C0703,
+		0x81C, 0x005E0703,
+		0x81C, 0x00600703,
+		0x81C, 0x00620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBE000703,
+		0x81C, 0xBD020703,
+		0x81C, 0xBC040703,
+		0x81C, 0xBB060703,
+		0x81C, 0xBA080703,
+		0x81C, 0xB90A0703,
+		0x81C, 0xB80C0703,
+		0x81C, 0xB70E0703,
+		0x81C, 0xB6100703,
+		0x81C, 0xB5120703,
+		0x81C, 0xB4140703,
+		0x81C, 0xB3160703,
+		0x81C, 0xB2180703,
+		0x81C, 0xB11A0703,
+		0x81C, 0xB01C0703,
+		0x81C, 0xAF1E0703,
+		0x81C, 0xAE200703,
+		0x81C, 0xAD220703,
+		0x81C, 0xAC240703,
+		0x81C, 0x8E260703,
+		0x81C, 0x8D280703,
+		0x81C, 0x8C2A0703,
+		0x81C, 0x6F2C0703,
+		0x81C, 0x6E2E0703,
+		0x81C, 0x6D300703,
+		0x81C, 0x6C320703,
+		0x81C, 0x6B340703,
+		0x81C, 0x6A360703,
+		0x81C, 0x69380703,
+		0x81C, 0x683A0703,
+		0x81C, 0x673C0703,
+		0x81C, 0x663E0703,
+		0x81C, 0x65400703,
+		0x81C, 0x64420703,
+		0x81C, 0x63440703,
+		0x81C, 0x62460703,
+		0x81C, 0x61480703,
+		0x81C, 0x604A0703,
+		0x81C, 0x424C0703,
+		0x81C, 0x414E0703,
+		0x81C, 0x40500703,
+		0x81C, 0x06520703,
+		0x81C, 0x05540703,
+		0x81C, 0x04560703,
+		0x81C, 0x03580703,
+		0x81C, 0x025A0703,
+		0x81C, 0x015C0703,
+		0x81C, 0x005E0703,
+		0x81C, 0x00600703,
+		0x81C, 0x00620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000008,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000703,
+		0x81C, 0xFA020703,
+		0x81C, 0xF9040703,
+		0x81C, 0xF8060703,
+		0x81C, 0xF7080703,
+		0x81C, 0xF60A0703,
+		0x81C, 0xF50C0703,
+		0x81C, 0xF40E0703,
+		0x81C, 0xF3100703,
+		0x81C, 0xF2120703,
+		0x81C, 0xF1140703,
+		0x81C, 0xF0160703,
+		0x81C, 0xEF180703,
+		0x81C, 0xEE1A0703,
+		0x81C, 0xED1C0703,
+		0x81C, 0xEC1E0703,
+		0x81C, 0xEB200703,
+		0x81C, 0xEA220703,
+		0x81C, 0xE9240703,
+		0x81C, 0xE8260703,
+		0x81C, 0xE7280703,
+		0x81C, 0xE62A0703,
+		0x81C, 0xE52C0703,
+		0x81C, 0xE42E0703,
+		0x81C, 0xE3300703,
+		0x81C, 0xE2320703,
+		0x81C, 0xC6340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0xC23C0703,
+		0x81C, 0xC13E0703,
+		0x81C, 0xA4400703,
+		0x81C, 0xA3420703,
+		0x81C, 0xA2440703,
+		0x81C, 0xA1460703,
+		0x81C, 0x83480703,
+		0x81C, 0x824A0703,
+		0x81C, 0x814C0703,
+		0x81C, 0x804E0703,
+		0x81C, 0x63500703,
+		0x81C, 0x62520703,
+		0x81C, 0x43540703,
+		0x81C, 0x42560703,
+		0x81C, 0x41580703,
+		0x81C, 0x235A0703,
+		0x81C, 0x225C0703,
+		0x81C, 0x215E0703,
+		0x81C, 0x20600703,
+		0x81C, 0x04620703,
+		0x81C, 0x03640703,
+		0x81C, 0x02660703,
+		0x81C, 0x01680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000009,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000703,
+		0x81C, 0xF7020703,
+		0x81C, 0xF6040703,
+		0x81C, 0xF5060703,
+		0x81C, 0xF4080703,
+		0x81C, 0xF30A0703,
+		0x81C, 0xF20C0703,
+		0x81C, 0xF10E0703,
+		0x81C, 0xF0100703,
+		0x81C, 0xEF120703,
+		0x81C, 0xEE140703,
+		0x81C, 0xED160703,
+		0x81C, 0xEC180703,
+		0x81C, 0xEB1A0703,
+		0x81C, 0xEA1C0703,
+		0x81C, 0xE91E0703,
+		0x81C, 0xCA200703,
+		0x81C, 0xC9220703,
+		0x81C, 0xC8240703,
+		0x81C, 0xC7260703,
+		0x81C, 0xC6280703,
+		0x81C, 0xC52A0703,
+		0x81C, 0xC42C0703,
+		0x81C, 0xC32E0703,
+		0x81C, 0xC2300703,
+		0x81C, 0xC1320703,
+		0x81C, 0xA3340703,
+		0x81C, 0xA2360703,
+		0x81C, 0xA1380703,
+		0x81C, 0xA03A0703,
+		0x81C, 0x823C0703,
+		0x81C, 0x813E0703,
+		0x81C, 0x80400703,
+		0x81C, 0x65420703,
+		0x81C, 0x64440703,
+		0x81C, 0x63460703,
+		0x81C, 0x62480703,
+		0x81C, 0x614A0703,
+		0x81C, 0x424C0703,
+		0x81C, 0x414E0703,
+		0x81C, 0x40500703,
+		0x81C, 0x22520703,
+		0x81C, 0x21540703,
+		0x81C, 0x20560703,
+		0x81C, 0x04580703,
+		0x81C, 0x035A0703,
+		0x81C, 0x025C0703,
+		0x81C, 0x015E0703,
+		0x81C, 0x00600703,
+		0x81C, 0x00620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x9000000a,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000703,
+		0x81C, 0xFB020703,
+		0x81C, 0xFA040703,
+		0x81C, 0xF9060703,
+		0x81C, 0xF8080703,
+		0x81C, 0xF70A0703,
+		0x81C, 0xF60C0703,
+		0x81C, 0xF50E0703,
+		0x81C, 0xF4100703,
+		0x81C, 0xF3120703,
+		0x81C, 0xF2140703,
+		0x81C, 0xF1160703,
+		0x81C, 0xEF180703,
+		0x81C, 0xEE1A0703,
+		0x81C, 0xED1C0703,
+		0x81C, 0xEC1E0703,
+		0x81C, 0xEB200703,
+		0x81C, 0xEA220703,
+		0x81C, 0xE9240703,
+		0x81C, 0xE8260703,
+		0x81C, 0xE7280703,
+		0x81C, 0xE62A0703,
+		0x81C, 0xE52C0703,
+		0x81C, 0xE42E0703,
+		0x81C, 0xE3300703,
+		0x81C, 0xE2320703,
+		0x81C, 0xC6340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0xA63C0703,
+		0x81C, 0xA53E0703,
+		0x81C, 0xA4400703,
+		0x81C, 0xA3420703,
+		0x81C, 0xA2440703,
+		0x81C, 0xA1460703,
+		0x81C, 0x83480703,
+		0x81C, 0x824A0703,
+		0x81C, 0x814C0703,
+		0x81C, 0x804E0703,
+		0x81C, 0x63500703,
+		0x81C, 0x62520703,
+		0x81C, 0x61540703,
+		0x81C, 0x42560703,
+		0x81C, 0x41580703,
+		0x81C, 0x405A0703,
+		0x81C, 0x225C0703,
+		0x81C, 0x215E0703,
+		0x81C, 0x20600703,
+		0x81C, 0x04620703,
+		0x81C, 0x03640703,
+		0x81C, 0x02660703,
+		0x81C, 0x01680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x9000000b,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xF8000703,
+		0x81C, 0xF7020703,
+		0x81C, 0xF6040703,
+		0x81C, 0xF5060703,
+		0x81C, 0xF4080703,
+		0x81C, 0xF30A0703,
+		0x81C, 0xF20C0703,
+		0x81C, 0xF10E0703,
+		0x81C, 0xF0100703,
+		0x81C, 0xEF120703,
+		0x81C, 0xEE140703,
+		0x81C, 0xED160703,
+		0x81C, 0xEC180703,
+		0x81C, 0xEB1A0703,
+		0x81C, 0xEA1C0703,
+		0x81C, 0xE91E0703,
+		0x81C, 0xCA200703,
+		0x81C, 0xC9220703,
+		0x81C, 0xC8240703,
+		0x81C, 0xC7260703,
+		0x81C, 0xC6280703,
+		0x81C, 0xC52A0703,
+		0x81C, 0xC42C0703,
+		0x81C, 0xC32E0703,
+		0x81C, 0xC2300703,
+		0x81C, 0xC1320703,
+		0x81C, 0xA3340703,
+		0x81C, 0xA2360703,
+		0x81C, 0xA1380703,
+		0x81C, 0xA03A0703,
+		0x81C, 0x823C0703,
+		0x81C, 0x813E0703,
+		0x81C, 0x80400703,
+		0x81C, 0x64420703,
+		0x81C, 0x63440703,
+		0x81C, 0x62460703,
+		0x81C, 0x61480703,
+		0x81C, 0x604A0703,
+		0x81C, 0x234C0703,
+		0x81C, 0x224E0703,
+		0x81C, 0x21500703,
+		0x81C, 0x20520703,
+		0x81C, 0x06540703,
+		0x81C, 0x05560703,
+		0x81C, 0x04580703,
+		0x81C, 0x035A0703,
+		0x81C, 0x025C0703,
+		0x81C, 0x015E0703,
+		0x81C, 0x00600703,
+		0x81C, 0x00620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x9000000c,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000703,
+		0x81C, 0xFB020703,
+		0x81C, 0xFA040703,
+		0x81C, 0xF9060703,
+		0x81C, 0xF8080703,
+		0x81C, 0xF70A0703,
+		0x81C, 0xF60C0703,
+		0x81C, 0xF50E0703,
+		0x81C, 0xF4100703,
+		0x81C, 0xF3120703,
+		0x81C, 0xF2140703,
+		0x81C, 0xF1160703,
+		0x81C, 0xF0180703,
+		0x81C, 0xEF1A0703,
+		0x81C, 0xEE1C0703,
+		0x81C, 0xED1E0703,
+		0x81C, 0xEC200703,
+		0x81C, 0xEB220703,
+		0x81C, 0xEA240703,
+		0x81C, 0xE9260703,
+		0x81C, 0xE8280703,
+		0x81C, 0xE72A0703,
+		0x81C, 0xE62C0703,
+		0x81C, 0xE52E0703,
+		0x81C, 0xE4300703,
+		0x81C, 0xE3320703,
+		0x81C, 0xE2340703,
+		0x81C, 0xC6360703,
+		0x81C, 0xC5380703,
+		0x81C, 0xC43A0703,
+		0x81C, 0xC33C0703,
+		0x81C, 0xA63E0703,
+		0x81C, 0xA5400703,
+		0x81C, 0xA4420703,
+		0x81C, 0xA3440703,
+		0x81C, 0xA2460703,
+		0x81C, 0x84480703,
+		0x81C, 0x834A0703,
+		0x81C, 0x824C0703,
+		0x81C, 0x814E0703,
+		0x81C, 0x80500703,
+		0x81C, 0x63520703,
+		0x81C, 0x62540703,
+		0x81C, 0x61560703,
+		0x81C, 0x60580703,
+		0x81C, 0x225A0703,
+		0x81C, 0x055C0703,
+		0x81C, 0x045E0703,
+		0x81C, 0x03600703,
+		0x81C, 0x02620703,
+		0x81C, 0x01640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000703,
+		0x81C, 0xFA020703,
+		0x81C, 0xF9040703,
+		0x81C, 0xF8060703,
+		0x81C, 0xF7080703,
+		0x81C, 0xF60A0703,
+		0x81C, 0xF50C0703,
+		0x81C, 0xF40E0703,
+		0x81C, 0xF3100703,
+		0x81C, 0xF2120703,
+		0x81C, 0xF1140703,
+		0x81C, 0xEF160703,
+		0x81C, 0xEE180703,
+		0x81C, 0xED1A0703,
+		0x81C, 0xEC1C0703,
+		0x81C, 0xEB1E0703,
+		0x81C, 0xEA200703,
+		0x81C, 0xE9220703,
+		0x81C, 0xE8240703,
+		0x81C, 0xE7260703,
+		0x81C, 0xE6280703,
+		0x81C, 0xE52A0703,
+		0x81C, 0xE42C0703,
+		0x81C, 0xE32E0703,
+		0x81C, 0xE2300703,
+		0x81C, 0xE1320703,
+		0x81C, 0xC6340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0xA63C0703,
+		0x81C, 0xA53E0703,
+		0x81C, 0xA4400703,
+		0x81C, 0xA3420703,
+		0x81C, 0xA2440703,
+		0x81C, 0xA1460703,
+		0x81C, 0x83480703,
+		0x81C, 0x824A0703,
+		0x81C, 0x814C0703,
+		0x81C, 0x804E0703,
+		0x81C, 0x63500703,
+		0x81C, 0x62520703,
+		0x81C, 0x61540703,
+		0x81C, 0x42560703,
+		0x81C, 0x41580703,
+		0x81C, 0x405A0703,
+		0x81C, 0x225C0703,
+		0x81C, 0x215E0703,
+		0x81C, 0x20600703,
+		0x81C, 0x04620703,
+		0x81C, 0x03640703,
+		0x81C, 0x02660703,
+		0x81C, 0x01680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFB000703,
+		0x81C, 0xFA020703,
+		0x81C, 0xF9040703,
+		0x81C, 0xF8060703,
+		0x81C, 0xF7080703,
+		0x81C, 0xF60A0703,
+		0x81C, 0xF50C0703,
+		0x81C, 0xF40E0703,
+		0x81C, 0xF3100703,
+		0x81C, 0xF2120703,
+		0x81C, 0xF1140703,
+		0x81C, 0xEF160703,
+		0x81C, 0xEE180703,
+		0x81C, 0xED1A0703,
+		0x81C, 0xEC1C0703,
+		0x81C, 0xEB1E0703,
+		0x81C, 0xEA200703,
+		0x81C, 0xE9220703,
+		0x81C, 0xE8240703,
+		0x81C, 0xE7260703,
+		0x81C, 0xE6280703,
+		0x81C, 0xE52A0703,
+		0x81C, 0xE42C0703,
+		0x81C, 0xE32E0703,
+		0x81C, 0xE2300703,
+		0x81C, 0xE1320703,
+		0x81C, 0xC6340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0xA63C0703,
+		0x81C, 0xA53E0703,
+		0x81C, 0xA4400703,
+		0x81C, 0xA3420703,
+		0x81C, 0xA2440703,
+		0x81C, 0xA1460703,
+		0x81C, 0x83480703,
+		0x81C, 0x824A0703,
+		0x81C, 0x814C0703,
+		0x81C, 0x804E0703,
+		0x81C, 0x63500703,
+		0x81C, 0x62520703,
+		0x81C, 0x61540703,
+		0x81C, 0x42560703,
+		0x81C, 0x41580703,
+		0x81C, 0x405A0703,
+		0x81C, 0x225C0703,
+		0x81C, 0x215E0703,
+		0x81C, 0x20600703,
+		0x81C, 0x04620703,
+		0x81C, 0x03640703,
+		0x81C, 0x02660703,
+		0x81C, 0x01680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x9000000f,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xBF000703,
+		0x81C, 0xBF020703,
+		0x81C, 0xBF040703,
+		0x81C, 0xBF060703,
+		0x81C, 0xBF080703,
+		0x81C, 0xBE0A0703,
+		0x81C, 0xBD0C0703,
+		0x81C, 0xBC0E0703,
+		0x81C, 0xBB100703,
+		0x81C, 0xBA120703,
+		0x81C, 0xB9140703,
+		0x81C, 0xB8160703,
+		0x81C, 0xB7180703,
+		0x81C, 0xB61A0703,
+		0x81C, 0xB51C0703,
+		0x81C, 0xB41E0703,
+		0x81C, 0xB1200703,
+		0x81C, 0xB2220703,
+		0x81C, 0xB1240703,
+		0x81C, 0xB0260703,
+		0x81C, 0xAF280703,
+		0x81C, 0xAE2A0703,
+		0x81C, 0xAD2C0703,
+		0x81C, 0xAC2E0703,
+		0x81C, 0xAB300703,
+		0x81C, 0xAA320703,
+		0x81C, 0xC6340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0x883C0703,
+		0x81C, 0x873E0703,
+		0x81C, 0x86400703,
+		0x81C, 0x85420703,
+		0x81C, 0x84440703,
+		0x81C, 0x83460703,
+		0x81C, 0x67480703,
+		0x81C, 0x664A0703,
+		0x81C, 0x654C0703,
+		0x81C, 0x644E0703,
+		0x81C, 0x27500703,
+		0x81C, 0x26520703,
+		0x81C, 0x25540703,
+		0x81C, 0x24560703,
+		0x81C, 0x23580703,
+		0x81C, 0x225A0703,
+		0x81C, 0x215C0703,
+		0x81C, 0x205E0703,
+		0x81C, 0x03600703,
+		0x81C, 0x02620703,
+		0x81C, 0x01640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0x90000010,	0x00000000,	0x40000000,	0x00000000,
+		0x81C, 0xFC000403,
+		0x81C, 0xFB000703,
+		0x81C, 0xFA020703,
+		0x81C, 0xF9040703,
+		0x81C, 0xF8060703,
+		0x81C, 0xF7080703,
+		0x81C, 0xF60A0703,
+		0x81C, 0xF50C0703,
+		0x81C, 0xF40E0703,
+		0x81C, 0xF3100703,
+		0x81C, 0xF2120703,
+		0x81C, 0xF1140703,
+		0x81C, 0xF0160703,
+		0x81C, 0xEF180703,
+		0x81C, 0xEE1A0703,
+		0x81C, 0xED1C0703,
+		0x81C, 0xEC1E0703,
+		0x81C, 0xEB200703,
+		0x81C, 0xEA220703,
+		0x81C, 0xE9240703,
+		0x81C, 0xE8260703,
+		0x81C, 0xE7280703,
+		0x81C, 0xE62A0703,
+		0x81C, 0xE52C0703,
+		0x81C, 0xE42E0703,
+		0x81C, 0xE3300703,
+		0x81C, 0xE2320703,
+		0x81C, 0xC6340703,
+		0x81C, 0xC5360703,
+		0x81C, 0xC4380703,
+		0x81C, 0xC33A0703,
+		0x81C, 0xA63C0703,
+		0x81C, 0xA53E0703,
+		0x81C, 0xA4400703,
+		0x81C, 0xA3420703,
+		0x81C, 0xA2440703,
+		0x81C, 0x84460703,
+		0x81C, 0x83480703,
+		0x81C, 0x824A0703,
+		0x81C, 0x814C0703,
+		0x81C, 0x804E0703,
+		0x81C, 0x63500703,
+		0x81C, 0x62520703,
+		0x81C, 0x61540703,
+		0x81C, 0x60560703,
+		0x81C, 0x22580703,
+		0x81C, 0x055A0703,
+		0x81C, 0x045C0703,
+		0x81C, 0x035E0703,
+		0x81C, 0x02600703,
+		0x81C, 0x01620703,
+		0x81C, 0x00640703,
+		0x81C, 0x00660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+	0xA0000000,	0x00000000,
+		0x81C, 0xFC000703,
+		0x81C, 0xFB020703,
+		0x81C, 0xFA040703,
+		0x81C, 0xF9060703,
+		0x81C, 0xF8080703,
+		0x81C, 0xF70A0703,
+		0x81C, 0xF60C0703,
+		0x81C, 0xF50E0703,
+		0x81C, 0xF4100703,
+		0x81C, 0xF3120703,
+		0x81C, 0xF2140703,
+		0x81C, 0xF1160703,
+		0x81C, 0xF0180703,
+		0x81C, 0xEF1A0703,
+		0x81C, 0xEE1C0703,
+		0x81C, 0xED1E0703,
+		0x81C, 0xEC200703,
+		0x81C, 0xEB220703,
+		0x81C, 0xEA240703,
+		0x81C, 0xE9260703,
+		0x81C, 0xE8280703,
+		0x81C, 0xE72A0703,
+		0x81C, 0xE62C0703,
+		0x81C, 0xE52E0703,
+		0x81C, 0xE4300703,
+		0x81C, 0xE3320703,
+		0x81C, 0xE2340703,
+		0x81C, 0xC6360703,
+		0x81C, 0xC5380703,
+		0x81C, 0xC43A0703,
+		0x81C, 0xC33C0703,
+		0x81C, 0xA63E0703,
+		0x81C, 0xA5400703,
+		0x81C, 0xA4420703,
+		0x81C, 0xA3440703,
+		0x81C, 0xA2460703,
+		0x81C, 0x84480703,
+		0x81C, 0x834A0703,
+		0x81C, 0x824C0703,
+		0x81C, 0x814E0703,
+		0x81C, 0x80500703,
+		0x81C, 0x63520703,
+		0x81C, 0x62540703,
+		0x81C, 0x61560703,
+		0x81C, 0x60580703,
+		0x81C, 0x235A0703,
+		0x81C, 0x225C0703,
+		0x81C, 0x215E0703,
+		0x81C, 0x20600703,
+		0x81C, 0x03620703,
+		0x81C, 0x02640703,
+		0x81C, 0x01660703,
+		0x81C, 0x00680703,
+		0x81C, 0x006A0703,
+		0x81C, 0x006C0703,
+		0x81C, 0x006E0703,
+		0x81C, 0x00700703,
+		0x81C, 0x00720703,
+		0x81C, 0x00740703,
+		0x81C, 0x00760703,
+		0x81C, 0x00780703,
+		0x81C, 0x007A0703,
+		0x81C, 0x007C0703,
+		0x81C, 0x007E0703,
+		0x81C, 0x007E0703,
+	0xB0000000,	0x00000000,
+	0x80000000,	0x00000000,	0x40000000,	0x00000000,
+		0xC50, 0x00000022,
+		0xC50, 0x00000020,
+		0xE50, 0x00000022,
+		0xE50, 0x00000020,
+	0x9000000d,	0x00000000,	0x40000000,	0x00000000,
+		0xC50, 0x00000022,
+		0xC50, 0x00000020,
+		0xE50, 0x00000022,
+		0xE50, 0x00000020,
+	0x9000000e,	0x00000000,	0x40000000,	0x00000000,
+		0xC50, 0x00000022,
+		0xC50, 0x00000020,
+		0xE50, 0x00000022,
+		0xE50, 0x00000020,
+	0xA0000000,	0x00000000,
+		0xC50, 0x00000022,
+		0xC50, 0x00000020,
+		0xE50, 0x00000022,
+		0xE50, 0x00000020,
+	0xB0000000,	0x00000000,
+
+};
+
+void
+odm_read_and_config_mp_8822b_agc_tab(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8822b_agc_tab)/sizeof(u32);
+	u32	*array = array_mp_8822b_agc_tab;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_agc_tab\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_bb_agc_8822b(dm, v1, MASKDWORD, v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8822b_agc_tab(void)
+{
+		return 104;
+}
+
+/******************************************************************************
+*                           phy_reg.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg[] = {
+		0x800, 0x9020D010,
+		0x804, 0x800181A0,
+		0x808, 0x0E028233,
+		0x80C, 0x10000013,
+		0x810, 0x22101243,
+		0x814, 0x020C3D11,
+		0x818, 0x84A10385,
+		0x81C, 0x1E1E081F,
+		0x820, 0x0001AAAA,
+		0x824, 0x00030FE0,
+		0x828, 0x0000CCCC,
+		0x82C, 0x75CB7010,
+		0x830, 0x79A0EAAA,
+		0x834, 0x072E6986,
+		0x838, 0x87766441,
+		0x83C, 0x9194B2B7,
+		0x840, 0x171750E0,
+		0x844, 0x4D3D7CDB,
+		0x848, 0x4AD0408B,
+		0x84C, 0x6AFBF7A5,
+		0x850, 0x28A74706,
+		0x854, 0x0001520C,
+		0x858, 0x4060C000,
+		0x85C, 0x74010160,
+		0x860, 0x68A7C321,
+		0x864, 0x79F27432,
+		0x868, 0x8CA7A314,
+		0x86C, 0x778C2878,
+		0x870, 0x77777777,
+		0x874, 0x27612C2E,
+		0x878, 0xC0003152,
+		0x87C, 0x5C8FC000,
+		0x880, 0x00000000,
+		0x884, 0x00000000,
+		0x888, 0x00000000,
+		0x88C, 0x00000000,
+		0x890, 0x00000000,
+		0x894, 0x00000000,
+		0x898, 0x00000000,
+		0x89C, 0x00000000,
+		0x8A0, 0x00000013,
+		0x8A4, 0x7F7F7F7F,
+		0x8A8, 0x2202033E,
+		0x8AC, 0xF00F000A,
+		0x8B0, 0x00000600,
+		0x8B4, 0x000FC080,
+		0x8B8, 0xEC0057F7,
+		0x8BC, 0xACB520A3,
+		0x8C0, 0xFFE04020,
+		0x8C4, 0x47C00000,
+		0x8C8, 0x000251A5,
+		0x8CC, 0x08108492,
+		0x8D0, 0x0000B800,
+		0x8D4, 0x860308A0,
+		0x8D8, 0x29095612,
+		0x8DC, 0x00000000,
+		0x8E0, 0x32D16777,
+		0x8E4, 0x4C098935,
+		0x8E8, 0xFFFFC42C,
+		0x8EC, 0x99999999,
+		0x8F0, 0x00009999,
+		0x8F4, 0x00D80FA1,
+		0x8F8, 0x40000080,
+		0x8FC, 0x00000130,
+		0x900, 0x00800000,
+		0x904, 0x00000000,
+		0x908, 0x00000000,
+		0x90C, 0xD3000000,
+		0x910, 0x0000FC00,
+		0x914, 0xC6380000,
+		0x918, 0x1C1028C0,
+		0x91C, 0x64B11A1C,
+		0x920, 0xE0767233,
+		0x924, 0x855A2500,
+		0x928, 0x4AB0E4E4,
+		0x92C, 0xFFFEB200,
+		0x930, 0xFFFFFFFE,
+		0x934, 0x001FFFFF,
+		0x938, 0x00008480,
+		0x93C, 0xE41C0642,
+		0x940, 0x0E470430,
+		0x944, 0x00000000,
+		0x948, 0xAC000000,
+		0x94C, 0x10000083,
+		0x950, 0x32010080,
+		0x954, 0x84510080,
+		0x958, 0x00000001,
+		0x95C, 0x04248000,
+		0x960, 0x00000000,
+		0x964, 0x00000000,
+		0x968, 0x00000000,
+		0x96C, 0x00000000,
+		0x970, 0x00001FFF,
+		0x974, 0x44000FFF,
+		0x978, 0x00000000,
+		0x97C, 0x00000000,
+		0x980, 0x00000000,
+		0x984, 0x00000000,
+		0x988, 0x00000000,
+		0x98C, 0x43440000,
+		0x990, 0x27100000,
+		0x994, 0xFFFF0100,
+		0x998, 0xFFFFFF5C,
+		0x99C, 0xFFFFFFFF,
+		0x9A0, 0x000000FF,
+		0x9A4, 0x80000088,
+		0x9A8, 0x0C2F0000,
+		0x9AC, 0x01560000,
+		0x9B0, 0x70000000,
+		0x9B4, 0x00000000,
+		0x9B8, 0x00000000,
+		0x9BC, 0x00000000,
+		0x9C0, 0x00000000,
+		0x9C4, 0x00000000,
+		0x9C8, 0x00000000,
+		0x9CC, 0x00000000,
+		0x9D0, 0x00000000,
+		0x9D4, 0x00000000,
+		0x9D8, 0x00000000,
+		0x9DC, 0x00000000,
+		0x9E0, 0x00000000,
+		0x9E4, 0x02000402,
+		0x9E8, 0x000022D4,
+		0x9EC, 0x00000000,
+		0x9F0, 0x00010080,
+		0x9F4, 0x00000000,
+		0x9F8, 0x00000000,
+		0x9FC, 0xEFFFF7F7,
+		0xA00, 0x00D047C8,
+		0xA04, 0x81FF800C,
+		0xA08, 0x8C838300,
+		0xA0C, 0x2E20100F,
+		0xA10, 0x9500BB78,
+		0xA14, 0x1114D028,
+		0xA18, 0x00881117,
+		0xA1C, 0x89140F00,
+		0xA20, 0x84880000,
+		0xA24, 0x384F6577,
+		0xA28, 0x00001525,
+		0xA2C, 0x00920000,
+		0xA70, 0x101FFF00,
+		0xA74, 0x00000148,
+		0xA78, 0x00000900,
+		0xA7C, 0x225B0606,
+		0xA80, 0x218675B2,
+		0xA84, 0x80208C00,
+		0xA88, 0x040C0000,
+		0xA8C, 0x12345678,
+		0xA90, 0xABCDEF00,
+		0xA94, 0x001B1B89,
+		0xA98, 0x030A0000,
+		0xA9C, 0x00060000,
+		0xAA0, 0x00000000,
+		0xAA4, 0x0004000F,
+		0xAA8, 0x00000200,
+		0xB00, 0xE1000440,
+		0xB04, 0x00800000,
+		0xB08, 0xFF02030B,
+		0xB0C, 0x01EAA406,
+		0xB10, 0x00030690,
+		0xB14, 0x006000FA,
+		0xB18, 0x00000002,
+		0xB1C, 0x00000002,
+		0xB20, 0x4B00001F,
+		0xB24, 0x4E8E3E40,
+		0xB28, 0x03020100,
+		0xB2C, 0x07060504,
+		0xB30, 0x0B0A0908,
+		0xB34, 0x0F0E0D0C,
+		0xB38, 0x13121110,
+		0xB3C, 0x0000003A,
+		0xB40, 0x00000000,
+		0xB44, 0x80000000,
+		0xB48, 0x3F0000FA,
+		0xB4C, 0x88C80020,
+		0xB50, 0x00000000,
+		0xB54, 0x00004241,
+		0xB58, 0xE0008208,
+		0xB5C, 0x41EFFFF9,
+		0xB60, 0x00000000,
+		0xB64, 0x00200063,
+		0xB68, 0x0000003A,
+		0xB6C, 0x00000102,
+		0xB70, 0x4E6D1870,
+		0xB74, 0x03020100,
+		0xB78, 0x07060504,
+		0xB7C, 0x0B0A0908,
+		0xB80, 0x0F0E0D0C,
+		0xB84, 0x13121110,
+		0xB88, 0x00000000,
+		0xB8C, 0x00000000,
+		0xC00, 0x00000007,
+		0xC04, 0x00000020,
+		0xC08, 0x60403231,
+		0xC0C, 0x00012345,
+		0xC10, 0x00000100,
+		0xC14, 0x01000000,
+		0xC18, 0x00000000,
+		0xC1C, 0x40040053,
+		0xC20, 0x40020103,
+		0xC24, 0x00000000,
+		0xC28, 0x00000000,
+		0xC2C, 0x00000000,
+		0xC30, 0x00000000,
+		0xC34, 0x00000000,
+		0xC38, 0x00000000,
+		0xC3C, 0x00000000,
+		0xC40, 0x00000000,
+		0xC44, 0x00000000,
+		0xC48, 0x00000000,
+		0xC4C, 0x00000000,
+		0xC50, 0x00000020,
+		0xC54, 0x00000000,
+		0xC58, 0xD8020402,
+		0xC5C, 0xDE000120,
+		0xC68, 0x5979993F,
+		0xC6C, 0x0000122A,
+		0xC70, 0x99795979,
+		0xC74, 0x99795979,
+		0xC78, 0x99799979,
+		0xC7C, 0x99791979,
+		0xC80, 0x19791979,
+		0xC84, 0x19791979,
+		0xC88, 0x00000000,
+		0xC8C, 0x07000000,
+		0xC94, 0x01000100,
+		0xC98, 0x201C8000,
+		0xC9C, 0x00000000,
+		0xCA0, 0x0000A555,
+		0xCA4, 0x08040201,
+		0xCA8, 0x80402010,
+		0xCAC, 0x00000000,
+		0xCB0, 0x77777777,
+		0xCB4, 0x00007777,
+		0xCB8, 0x00000000,
+		0xCBC, 0x00000000,
+		0xCC0, 0x00000000,
+		0xCC4, 0x00000000,
+		0xCC8, 0x00000000,
+		0xCCC, 0x00000000,
+		0xCD0, 0x00000000,
+		0xCD4, 0x00000000,
+		0xCD8, 0x00000000,
+		0xCDC, 0x00000000,
+		0xCE0, 0x00000000,
+		0xCE4, 0x00000000,
+		0xCE8, 0x00000000,
+		0xCEC, 0x00000000,
+		0xE00, 0x00000007,
+		0xE04, 0x00000020,
+		0xE08, 0x60403231,
+		0xE0C, 0x00012345,
+		0xE10, 0x00000100,
+		0xE14, 0x01000000,
+		0xE18, 0x00000000,
+		0xE1C, 0x40040053,
+		0xE20, 0x40020103,
+		0xE24, 0x00000000,
+		0xE28, 0x00000000,
+		0xE2C, 0x00000000,
+		0xE30, 0x00000000,
+		0xE34, 0x00000000,
+		0xE38, 0x00000000,
+		0xE3C, 0x00000000,
+		0xE40, 0x00000000,
+		0xE44, 0x00000000,
+		0xE48, 0x00000000,
+		0xE4C, 0x00000000,
+		0xE50, 0x00000020,
+		0xE54, 0x00000000,
+		0xE58, 0xD8120402,
+		0xE5C, 0xDE000120,
+		0xE68, 0x5979993F,
+		0xE6C, 0x0000122A,
+		0xE70, 0x99795979,
+		0xE74, 0x99795979,
+		0xE78, 0x99799979,
+		0xE7C, 0x99791979,
+		0xE80, 0x19791979,
+		0xE84, 0x19791979,
+		0xE88, 0x00000000,
+		0xE8C, 0x07000000,
+		0xE94, 0x01000100,
+		0xE98, 0x201C8000,
+		0xE9C, 0x00000000,
+		0xEA0, 0x0000A555,
+		0xEA4, 0x08040201,
+		0xEA8, 0x80402010,
+		0xEAC, 0x00000000,
+		0xEB0, 0x77777777,
+		0xEB4, 0x00007777,
+		0xEB8, 0x00000000,
+		0xEBC, 0x00000000,
+		0xEC0, 0x00000000,
+		0xEC4, 0x00000000,
+		0xEC8, 0x00000000,
+		0xECC, 0x00000000,
+		0xED0, 0x00000000,
+		0xED4, 0x00000000,
+		0xED8, 0x00000000,
+		0xEDC, 0x00000000,
+		0xEE0, 0x00000000,
+		0xEE4, 0x00000000,
+		0xEE8, 0x00000000,
+		0xEEC, 0x00000000,
+		0x1900, 0x00000000,
+		0x1904, 0x00238000,
+		0x1908, 0x00000000,
+		0x190C, 0x00000000,
+		0x1910, 0x00000000,
+		0x1914, 0x00000000,
+		0x1918, 0x00000000,
+		0x191C, 0x00000000,
+		0x1920, 0x00000000,
+		0x1924, 0x00000000,
+		0x1928, 0x00000000,
+		0x192C, 0x00000000,
+		0x1930, 0x00000000,
+		0x1934, 0x00000000,
+		0x1938, 0x00000000,
+		0x193C, 0x00000000,
+		0x1940, 0x00000000,
+		0x1944, 0x00000000,
+		0x1948, 0x00000000,
+		0x194C, 0x00000000,
+		0x1950, 0x00000000,
+		0x1954, 0x00000000,
+		0x1958, 0x00000000,
+		0x195C, 0x00000000,
+		0x1960, 0x00000000,
+		0x1964, 0x00000000,
+		0x1968, 0x00000000,
+		0x196C, 0x00000000,
+		0x1970, 0x00000000,
+		0x1974, 0x00000000,
+		0x1978, 0x00000000,
+		0x197C, 0x00000000,
+		0x1980, 0x00000000,
+		0x1984, 0x03000000,
+		0x1988, 0x21401E88,
+		0x198C, 0x00004000,
+		0x1990, 0x00000000,
+		0x1994, 0x00000000,
+		0x1998, 0x00000053,
+		0x199C, 0x00000000,
+		0x19A0, 0x00000000,
+		0x19A4, 0x00000000,
+		0x19A8, 0x00000000,
+		0x19AC, 0x0E47E47F,
+		0x19B0, 0x00000000,
+		0x19B4, 0x0E47E47F,
+		0x19B8, 0x00000000,
+		0x19BC, 0x00000000,
+		0x19C0, 0x00000000,
+		0x19C4, 0x00000000,
+		0x19C8, 0x00000000,
+		0x19CC, 0x00000000,
+		0x19D0, 0x00000000,
+		0x19D4, 0xAAAAAAAA,
+		0x19D8, 0x00000AAA,
+		0x19DC, 0x133E0F37,
+		0x19E0, 0x00000000,
+		0x19E4, 0x00000000,
+		0x19E8, 0x00000000,
+		0x19EC, 0x00000000,
+		0x19F0, 0x00000000,
+		0x19F4, 0x00000000,
+		0x19F8, 0x01A00000,
+		0x19FC, 0x00000000,
+		0x1C00, 0x00000100,
+		0x1C04, 0x01000000,
+		0x1C08, 0x00000100,
+		0x1C0C, 0x01000000,
+		0x1C10, 0x00000100,
+		0x1C14, 0x01000000,
+		0x1C18, 0x00000100,
+		0x1C1C, 0x01000000,
+		0x1C20, 0x00000100,
+		0x1C24, 0x01000000,
+		0x1C28, 0x00000100,
+		0x1C2C, 0x01000000,
+		0x1C30, 0x00000100,
+		0x1C34, 0x01000000,
+		0x1C38, 0x00000000,
+		0x1C3C, 0x00000000,
+		0x1C40, 0x000C0100,
+		0x1C44, 0x000000F3,
+		0x1C48, 0x1A8249A8,
+		0x1C4C, 0x1461C826,
+		0x1C50, 0x0001469E,
+		0x1C54, 0x58D158D1,
+		0x1C58, 0x04490088,
+		0x1C5C, 0x04004400,
+		0x1C60, 0x00000000,
+		0x1C64, 0x04004400,
+		0x1C68, 0x00000100,
+		0x1C6C, 0x01000000,
+		0x1C70, 0x00000100,
+		0x1C74, 0x01000000,
+		0x1C78, 0x00000000,
+		0x1C7C, 0x00000010,
+		0x1C80, 0x5FFF5FFF,
+		0x1C84, 0x5FFF5FFF,
+		0x1C88, 0x5FFF5FFF,
+		0x1C8C, 0x5FFF5FFF,
+		0x1C90, 0x5FFF5FFF,
+		0x1C94, 0x5FFF5FFF,
+		0x1C98, 0x5FFF5FFF,
+		0x1C9C, 0x5FFF5FFF,
+		0x1CA0, 0x00000100,
+		0x1CA4, 0x01000000,
+		0x1CA8, 0x00000100,
+		0x1CAC, 0x5FFF5FFF,
+		0x1CB0, 0x00000100,
+		0x1CB4, 0x01000000,
+		0x1CB8, 0x00000000,
+		0x1CBC, 0x00000000,
+		0x1CC0, 0x00000100,
+		0x1CC4, 0x01000000,
+		0x1CC8, 0x00000100,
+		0x1CCC, 0x01000000,
+		0x1CD0, 0x00000100,
+		0x1CD4, 0x01000000,
+		0x1CD8, 0x00000100,
+		0x1CDC, 0x01000000,
+		0x1CE0, 0x00000100,
+		0x1CE4, 0x01000000,
+		0x1CE8, 0x00000100,
+		0x1CEC, 0x01000000,
+		0x1CF0, 0x00000100,
+		0x1CF4, 0x01000000,
+		0x1CF8, 0x00000000,
+		0x1CFC, 0x00000000,
+		0xC60, 0x70038040,
+		0xC60, 0x70038040,
+		0xC60, 0x70146040,
+		0xC60, 0x70246040,
+		0xC60, 0x70346040,
+		0xC60, 0x70446040,
+		0xC60, 0x70532040,
+		0xC60, 0x70646040,
+		0xC60, 0x70738040,
+		0xC60, 0x70838040,
+		0xC60, 0x70938040,
+		0xC60, 0x70A38040,
+		0xC60, 0x70B36040,
+		0xC60, 0x70C06040,
+		0xC60, 0x70D06040,
+		0xC60, 0x70E76040,
+		0xC60, 0x70F06040,
+		0xE60, 0x70038040,
+		0xE60, 0x70038040,
+		0xE60, 0x70146040,
+		0xE60, 0x70246040,
+		0xE60, 0x70346040,
+		0xE60, 0x70446040,
+		0xE60, 0x70532040,
+		0xE60, 0x70646040,
+		0xE60, 0x70738040,
+		0xE60, 0x70838040,
+		0xE60, 0x70938040,
+		0xE60, 0x70A38040,
+		0xE60, 0x70B36040,
+		0xE60, 0x70C06040,
+		0xE60, 0x70D06040,
+		0xE60, 0x70E76040,
+		0xE60, 0x70F06040,
+		0xC64, 0x00800000,
+		0xC64, 0x08800001,
+		0xC64, 0x00800002,
+		0xC64, 0x00800003,
+		0xC64, 0x00800004,
+		0xC64, 0x00800005,
+		0xC64, 0x00800006,
+		0xC64, 0x08800007,
+		0xC64, 0x00004000,
+		0xE64, 0x00800000,
+		0xE64, 0x08800001,
+		0xE64, 0x00800002,
+		0xE64, 0x00800003,
+		0xE64, 0x00800004,
+		0xE64, 0x00800005,
+		0xE64, 0x00800006,
+		0xE64, 0x08800007,
+		0xE64, 0x00004000,
+		0x1B00, 0xF8000008,
+		0x1B00, 0xF80A7008,
+		0x1B00, 0xF8015008,
+		0x1B00, 0xF8000008,
+		0x1B04, 0xE24629D2,
+		0x1B08, 0x00000080,
+		0x1B0C, 0x00000000,
+		0x1B10, 0x00011C00,
+		0x1B14, 0x00000000,
+		0x1B18, 0x00292903,
+		0x1B1C, 0xA2193C32,
+		0x1B20, 0x01840008,
+		0x1B24, 0x01860008,
+		0x1B28, 0x80060300,
+		0x1B2C, 0x00000003,
+		0x1B30, 0x20000000,
+		0x1B34, 0x00000800,
+		0x1B3C, 0x20000000,
+		0x1BC0, 0x01000000,
+		0x1BCC, 0x00000000,
+		0x1B00, 0xF800000A,
+		0x1B1C, 0xA2193C32,
+		0x1B20, 0x01840008,
+		0x1B24, 0x01860008,
+		0x1B28, 0x80060300,
+		0x1B2C, 0x00000003,
+		0x1B30, 0x20000000,
+		0x1B34, 0x00000800,
+		0x1B3C, 0x20000000,
+		0x1BC0, 0x01000000,
+		0x1BCC, 0x00000000,
+		0x1B00, 0xF8000000,
+		0x1B80, 0x00000007,
+		0x1B80, 0x090A0005,
+		0x1B80, 0x090A0007,
+		0x1B80, 0x0FFE0015,
+		0x1B80, 0x0FFE0017,
+		0x1B80, 0x00220025,
+		0x1B80, 0x00220027,
+		0x1B80, 0x00040035,
+		0x1B80, 0x00040037,
+		0x1B80, 0x05C00045,
+		0x1B80, 0x05C00047,
+		0x1B80, 0x00070055,
+		0x1B80, 0x00070057,
+		0x1B80, 0x64000065,
+		0x1B80, 0x64000067,
+		0x1B80, 0x00020075,
+		0x1B80, 0x00020077,
+		0x1B80, 0x00080085,
+		0x1B80, 0x00080087,
+		0x1B80, 0x80000095,
+		0x1B80, 0x80000097,
+		0x1B80, 0x090800A5,
+		0x1B80, 0x090800A7,
+		0x1B80, 0x0F0200B5,
+		0x1B80, 0x0F0200B7,
+		0x1B80, 0x002200C5,
+		0x1B80, 0x002200C7,
+		0x1B80, 0x000400D5,
+		0x1B80, 0x000400D7,
+		0x1B80, 0x05C000E5,
+		0x1B80, 0x05C000E7,
+		0x1B80, 0x000700F5,
+		0x1B80, 0x000700F7,
+		0x1B80, 0x64020105,
+		0x1B80, 0x64020107,
+		0x1B80, 0x00020115,
+		0x1B80, 0x00020117,
+		0x1B80, 0x00040125,
+		0x1B80, 0x00040127,
+		0x1B80, 0x4A000135,
+		0x1B80, 0x4A000137,
+		0x1B80, 0x4B040145,
+		0x1B80, 0x4B040147,
+		0x1B80, 0x85030155,
+		0x1B80, 0x85030157,
+		0x1B80, 0x40090165,
+		0x1B80, 0x40090167,
+		0x1B80, 0xE0280175,
+		0x1B80, 0xE0280177,
+		0x1B80, 0x4B050185,
+		0x1B80, 0x4B050187,
+		0x1B80, 0x86030195,
+		0x1B80, 0x86030197,
+		0x1B80, 0x400B01A5,
+		0x1B80, 0x400B01A7,
+		0x1B80, 0xE02801B5,
+		0x1B80, 0xE02801B7,
+		0x1B80, 0x4B0001C5,
+		0x1B80, 0x4B0001C7,
+		0x1B80, 0x000701D5,
+		0x1B80, 0x000701D7,
+		0x1B80, 0x4C0001E5,
+		0x1B80, 0x4C0001E7,
+		0x1B80, 0x000401F5,
+		0x1B80, 0x000401F7,
+		0x1B80, 0x4D040205,
+		0x1B80, 0x4D040207,
+		0x1B80, 0x2EF00215,
+		0x1B80, 0x2EF00217,
+		0x1B80, 0x00000225,
+		0x1B80, 0x00000227,
+		0x1B80, 0x20810235,
+		0x1B80, 0x20810237,
+		0x1B80, 0x23450245,
+		0x1B80, 0x23450247,
+		0x1B80, 0x4D000255,
+		0x1B80, 0x4D000257,
+		0x1B80, 0x00040265,
+		0x1B80, 0x00040267,
+		0x1B80, 0x30000275,
+		0x1B80, 0x30000277,
+		0x1B80, 0xE1D80285,
+		0x1B80, 0xE1D80287,
+		0x1B80, 0xF0110295,
+		0x1B80, 0xF0110297,
+		0x1B80, 0xF11102A5,
+		0x1B80, 0xF11102A7,
+		0x1B80, 0xF21102B5,
+		0x1B80, 0xF21102B7,
+		0x1B80, 0xF31102C5,
+		0x1B80, 0xF31102C7,
+		0x1B80, 0xF41102D5,
+		0x1B80, 0xF41102D7,
+		0x1B80, 0xF51102E5,
+		0x1B80, 0xF51102E7,
+		0x1B80, 0xF61102F5,
+		0x1B80, 0xF61102F7,
+		0x1B80, 0xF7110305,
+		0x1B80, 0xF7110307,
+		0x1B80, 0xF8110315,
+		0x1B80, 0xF8110317,
+		0x1B80, 0xF9110325,
+		0x1B80, 0xF9110327,
+		0x1B80, 0xFA110335,
+		0x1B80, 0xFA110337,
+		0x1B80, 0xFB110345,
+		0x1B80, 0xFB110347,
+		0x1B80, 0xFC110355,
+		0x1B80, 0xFC110357,
+		0x1B80, 0xFD110365,
+		0x1B80, 0xFD110367,
+		0x1B80, 0xFE110375,
+		0x1B80, 0xFE110377,
+		0x1B80, 0xFF110385,
+		0x1B80, 0xFF110387,
+		0x1B80, 0x00010395,
+		0x1B80, 0x00010397,
+		0x1B80, 0x305103A5,
+		0x1B80, 0x305103A7,
+		0x1B80, 0x306903B5,
+		0x1B80, 0x306903B7,
+		0x1B80, 0x30B403C5,
+		0x1B80, 0x30B403C7,
+		0x1B80, 0x30B703D5,
+		0x1B80, 0x30B703D7,
+		0x1B80, 0x306B03E5,
+		0x1B80, 0x306B03E7,
+		0x1B80, 0x307603F5,
+		0x1B80, 0x307603F7,
+		0x1B80, 0x30810405,
+		0x1B80, 0x30810407,
+		0x1B80, 0x30C10415,
+		0x1B80, 0x30C10417,
+		0x1B80, 0x30BB0425,
+		0x1B80, 0x30BB0427,
+		0x1B80, 0x30CF0435,
+		0x1B80, 0x30CF0437,
+		0x1B80, 0x30DA0445,
+		0x1B80, 0x30DA0447,
+		0x1B80, 0x30E50455,
+		0x1B80, 0x30E50457,
+		0x1B80, 0x304A0465,
+		0x1B80, 0x304A0467,
+		0x1B80, 0x31140475,
+		0x1B80, 0x31140477,
+		0x1B80, 0x31250485,
+		0x1B80, 0x31250487,
+		0x1B80, 0x313A0495,
+		0x1B80, 0x313A0497,
+		0x1B80, 0x4D0404A5,
+		0x1B80, 0x4D0404A7,
+		0x1B80, 0x2EF004B5,
+		0x1B80, 0x2EF004B7,
+		0x1B80, 0x000004C5,
+		0x1B80, 0x000004C7,
+		0x1B80, 0x208104D5,
+		0x1B80, 0x208104D7,
+		0x1B80, 0xA3B504E5,
+		0x1B80, 0xA3B504E7,
+		0x1B80, 0x4D0004F5,
+		0x1B80, 0x4D0004F7,
+		0x1B80, 0x30000505,
+		0x1B80, 0x30000507,
+		0x1B80, 0xE1650515,
+		0x1B80, 0xE1650517,
+		0x1B80, 0x4D040525,
+		0x1B80, 0x4D040527,
+		0x1B80, 0x20800535,
+		0x1B80, 0x20800537,
+		0x1B80, 0x00000545,
+		0x1B80, 0x00000547,
+		0x1B80, 0x4D000555,
+		0x1B80, 0x4D000557,
+		0x1B80, 0x55070565,
+		0x1B80, 0x55070567,
+		0x1B80, 0xE15D0575,
+		0x1B80, 0xE15D0577,
+		0x1B80, 0xE15D0585,
+		0x1B80, 0xE15D0587,
+		0x1B80, 0x4D040595,
+		0x1B80, 0x4D040597,
+		0x1B80, 0x208805A5,
+		0x1B80, 0x208805A7,
+		0x1B80, 0x020005B5,
+		0x1B80, 0x020005B7,
+		0x1B80, 0x4D0005C5,
+		0x1B80, 0x4D0005C7,
+		0x1B80, 0x550F05D5,
+		0x1B80, 0x550F05D7,
+		0x1B80, 0xE15D05E5,
+		0x1B80, 0xE15D05E7,
+		0x1B80, 0x4F0205F5,
+		0x1B80, 0x4F0205F7,
+		0x1B80, 0x4E000605,
+		0x1B80, 0x4E000607,
+		0x1B80, 0x53020615,
+		0x1B80, 0x53020617,
+		0x1B80, 0x52010625,
+		0x1B80, 0x52010627,
+		0x1B80, 0xE1610635,
+		0x1B80, 0xE1610637,
+		0x1B80, 0x4D080645,
+		0x1B80, 0x4D080647,
+		0x1B80, 0x57100655,
+		0x1B80, 0x57100657,
+		0x1B80, 0x57000665,
+		0x1B80, 0x57000667,
+		0x1B80, 0x4D000675,
+		0x1B80, 0x4D000677,
+		0x1B80, 0x00010685,
+		0x1B80, 0x00010687,
+		0x1B80, 0xE1650695,
+		0x1B80, 0xE1650697,
+		0x1B80, 0x000106A5,
+		0x1B80, 0x000106A7,
+		0x1B80, 0x308B06B5,
+		0x1B80, 0x308B06B7,
+		0x1B80, 0x002306C5,
+		0x1B80, 0x002306C7,
+		0x1B80, 0xE1CB06D5,
+		0x1B80, 0xE1CB06D7,
+		0x1B80, 0x000206E5,
+		0x1B80, 0x000206E7,
+		0x1B80, 0x54E906F5,
+		0x1B80, 0x54E906F7,
+		0x1B80, 0x0BA60705,
+		0x1B80, 0x0BA60707,
+		0x1B80, 0x00230715,
+		0x1B80, 0x00230717,
+		0x1B80, 0xE1CB0725,
+		0x1B80, 0xE1CB0727,
+		0x1B80, 0x00020735,
+		0x1B80, 0x00020737,
+		0x1B80, 0x4D300745,
+		0x1B80, 0x4D300747,
+		0x1B80, 0x30A40755,
+		0x1B80, 0x30A40757,
+		0x1B80, 0x30870765,
+		0x1B80, 0x30870767,
+		0x1B80, 0x00220775,
+		0x1B80, 0x00220777,
+		0x1B80, 0xE1CB0785,
+		0x1B80, 0xE1CB0787,
+		0x1B80, 0x00020795,
+		0x1B80, 0x00020797,
+		0x1B80, 0x54E807A5,
+		0x1B80, 0x54E807A7,
+		0x1B80, 0x0BA607B5,
+		0x1B80, 0x0BA607B7,
+		0x1B80, 0x002207C5,
+		0x1B80, 0x002207C7,
+		0x1B80, 0xE1CB07D5,
+		0x1B80, 0xE1CB07D7,
+		0x1B80, 0x000207E5,
+		0x1B80, 0x000207E7,
+		0x1B80, 0x4D3007F5,
+		0x1B80, 0x4D3007F7,
+		0x1B80, 0x30A40805,
+		0x1B80, 0x30A40807,
+		0x1B80, 0x63F10815,
+		0x1B80, 0x63F10817,
+		0x1B80, 0xE1650825,
+		0x1B80, 0xE1650827,
+		0x1B80, 0xE1CB0835,
+		0x1B80, 0xE1CB0837,
+		0x1B80, 0x63F40845,
+		0x1B80, 0x63F40847,
+		0x1B80, 0xE1650855,
+		0x1B80, 0xE1650857,
+		0x1B80, 0xE1CB0865,
+		0x1B80, 0xE1CB0867,
+		0x1B80, 0x0BA80875,
+		0x1B80, 0x0BA80877,
+		0x1B80, 0x63F80885,
+		0x1B80, 0x63F80887,
+		0x1B80, 0xE1650895,
+		0x1B80, 0xE1650897,
+		0x1B80, 0xE1CB08A5,
+		0x1B80, 0xE1CB08A7,
+		0x1B80, 0x0BA908B5,
+		0x1B80, 0x0BA908B7,
+		0x1B80, 0x63FC08C5,
+		0x1B80, 0x63FC08C7,
+		0x1B80, 0xE16508D5,
+		0x1B80, 0xE16508D7,
+		0x1B80, 0xE1CB08E5,
+		0x1B80, 0xE1CB08E7,
+		0x1B80, 0x63FF08F5,
+		0x1B80, 0x63FF08F7,
+		0x1B80, 0xE1650905,
+		0x1B80, 0xE1650907,
+		0x1B80, 0xE1CB0915,
+		0x1B80, 0xE1CB0917,
+		0x1B80, 0x63000925,
+		0x1B80, 0x63000927,
+		0x1B80, 0xE1650935,
+		0x1B80, 0xE1650937,
+		0x1B80, 0xE1CB0945,
+		0x1B80, 0xE1CB0947,
+		0x1B80, 0x63030955,
+		0x1B80, 0x63030957,
+		0x1B80, 0xE1650965,
+		0x1B80, 0xE1650967,
+		0x1B80, 0xE1CB0975,
+		0x1B80, 0xE1CB0977,
+		0x1B80, 0xF4D40985,
+		0x1B80, 0xF4D40987,
+		0x1B80, 0x63070995,
+		0x1B80, 0x63070997,
+		0x1B80, 0xE16509A5,
+		0x1B80, 0xE16509A7,
+		0x1B80, 0xE1CB09B5,
+		0x1B80, 0xE1CB09B7,
+		0x1B80, 0xF5DB09C5,
+		0x1B80, 0xF5DB09C7,
+		0x1B80, 0x630B09D5,
+		0x1B80, 0x630B09D7,
+		0x1B80, 0xE16509E5,
+		0x1B80, 0xE16509E7,
+		0x1B80, 0xE1CB09F5,
+		0x1B80, 0xE1CB09F7,
+		0x1B80, 0x630E0A05,
+		0x1B80, 0x630E0A07,
+		0x1B80, 0xE1650A15,
+		0x1B80, 0xE1650A17,
+		0x1B80, 0xE1CB0A25,
+		0x1B80, 0xE1CB0A27,
+		0x1B80, 0x4D300A35,
+		0x1B80, 0x4D300A37,
+		0x1B80, 0x55010A45,
+		0x1B80, 0x55010A47,
+		0x1B80, 0x57040A55,
+		0x1B80, 0x57040A57,
+		0x1B80, 0x57000A65,
+		0x1B80, 0x57000A67,
+		0x1B80, 0x96000A75,
+		0x1B80, 0x96000A77,
+		0x1B80, 0x57080A85,
+		0x1B80, 0x57080A87,
+		0x1B80, 0x57000A95,
+		0x1B80, 0x57000A97,
+		0x1B80, 0x95000AA5,
+		0x1B80, 0x95000AA7,
+		0x1B80, 0x4D000AB5,
+		0x1B80, 0x4D000AB7,
+		0x1B80, 0x6C070AC5,
+		0x1B80, 0x6C070AC7,
+		0x1B80, 0x7B200AD5,
+		0x1B80, 0x7B200AD7,
+		0x1B80, 0x7A000AE5,
+		0x1B80, 0x7A000AE7,
+		0x1B80, 0x79000AF5,
+		0x1B80, 0x79000AF7,
+		0x1B80, 0x7F200B05,
+		0x1B80, 0x7F200B07,
+		0x1B80, 0x7E000B15,
+		0x1B80, 0x7E000B17,
+		0x1B80, 0x7D000B25,
+		0x1B80, 0x7D000B27,
+		0x1B80, 0x00010B35,
+		0x1B80, 0x00010B37,
+		0x1B80, 0x62850B45,
+		0x1B80, 0x62850B47,
+		0x1B80, 0xE1650B55,
+		0x1B80, 0xE1650B57,
+		0x1B80, 0x00010B65,
+		0x1B80, 0x00010B67,
+		0x1B80, 0x5C320B75,
+		0x1B80, 0x5C320B77,
+		0x1B80, 0xE1C70B85,
+		0x1B80, 0xE1C70B87,
+		0x1B80, 0xE1930B95,
+		0x1B80, 0xE1930B97,
+		0x1B80, 0x00010BA5,
+		0x1B80, 0x00010BA7,
+		0x1B80, 0x5C320BB5,
+		0x1B80, 0x5C320BB7,
+		0x1B80, 0x63F40BC5,
+		0x1B80, 0x63F40BC7,
+		0x1B80, 0x62850BD5,
+		0x1B80, 0x62850BD7,
+		0x1B80, 0x0BB00BE5,
+		0x1B80, 0x0BB00BE7,
+		0x1B80, 0xE1650BF5,
+		0x1B80, 0xE1650BF7,
+		0x1B80, 0xE1CB0C05,
+		0x1B80, 0xE1CB0C07,
+		0x1B80, 0x5C320C15,
+		0x1B80, 0x5C320C17,
+		0x1B80, 0x63FC0C25,
+		0x1B80, 0x63FC0C27,
+		0x1B80, 0x62850C35,
+		0x1B80, 0x62850C37,
+		0x1B80, 0x0BB10C45,
+		0x1B80, 0x0BB10C47,
+		0x1B80, 0xE1650C55,
+		0x1B80, 0xE1650C57,
+		0x1B80, 0xE1CB0C65,
+		0x1B80, 0xE1CB0C67,
+		0x1B80, 0x63030C75,
+		0x1B80, 0x63030C77,
+		0x1B80, 0xE1650C85,
+		0x1B80, 0xE1650C87,
+		0x1B80, 0xE1CB0C95,
+		0x1B80, 0xE1CB0C97,
+		0x1B80, 0xF7040CA5,
+		0x1B80, 0xF7040CA7,
+		0x1B80, 0x630B0CB5,
+		0x1B80, 0x630B0CB7,
+		0x1B80, 0xE1650CC5,
+		0x1B80, 0xE1650CC7,
+		0x1B80, 0xE1CB0CD5,
+		0x1B80, 0xE1CB0CD7,
+		0x1B80, 0x00010CE5,
+		0x1B80, 0x00010CE7,
+		0x1B80, 0x30F30CF5,
+		0x1B80, 0x30F30CF7,
+		0x1B80, 0x00230D05,
+		0x1B80, 0x00230D07,
+		0x1B80, 0xE1D00D15,
+		0x1B80, 0xE1D00D17,
+		0x1B80, 0x00020D25,
+		0x1B80, 0x00020D27,
+		0x1B80, 0x54E90D35,
+		0x1B80, 0x54E90D37,
+		0x1B80, 0x0BA60D45,
+		0x1B80, 0x0BA60D47,
+		0x1B80, 0x00230D55,
+		0x1B80, 0x00230D57,
+		0x1B80, 0xE1D00D65,
+		0x1B80, 0xE1D00D67,
+		0x1B80, 0x00020D75,
+		0x1B80, 0x00020D77,
+		0x1B80, 0x4D100D85,
+		0x1B80, 0x4D100D87,
+		0x1B80, 0x30A40D95,
+		0x1B80, 0x30A40D97,
+		0x1B80, 0x30ED0DA5,
+		0x1B80, 0x30ED0DA7,
+		0x1B80, 0x00220DB5,
+		0x1B80, 0x00220DB7,
+		0x1B80, 0xE1D00DC5,
+		0x1B80, 0xE1D00DC7,
+		0x1B80, 0x00020DD5,
+		0x1B80, 0x00020DD7,
+		0x1B80, 0x54E80DE5,
+		0x1B80, 0x54E80DE7,
+		0x1B80, 0x0BA60DF5,
+		0x1B80, 0x0BA60DF7,
+		0x1B80, 0x00220E05,
+		0x1B80, 0x00220E07,
+		0x1B80, 0xE1D00E15,
+		0x1B80, 0xE1D00E17,
+		0x1B80, 0x00020E25,
+		0x1B80, 0x00020E27,
+		0x1B80, 0x4D100E35,
+		0x1B80, 0x4D100E37,
+		0x1B80, 0x30A40E45,
+		0x1B80, 0x30A40E47,
+		0x1B80, 0x5C320E55,
+		0x1B80, 0x5C320E57,
+		0x1B80, 0x54F00E65,
+		0x1B80, 0x54F00E67,
+		0x1B80, 0x67F10E75,
+		0x1B80, 0x67F10E77,
+		0x1B80, 0xE1930E85,
+		0x1B80, 0xE1930E87,
+		0x1B80, 0xE1D00E95,
+		0x1B80, 0xE1D00E97,
+		0x1B80, 0x67F40EA5,
+		0x1B80, 0x67F40EA7,
+		0x1B80, 0xE1930EB5,
+		0x1B80, 0xE1930EB7,
+		0x1B80, 0xE1D00EC5,
+		0x1B80, 0xE1D00EC7,
+		0x1B80, 0x5C320ED5,
+		0x1B80, 0x5C320ED7,
+		0x1B80, 0x54F10EE5,
+		0x1B80, 0x54F10EE7,
+		0x1B80, 0x0BA80EF5,
+		0x1B80, 0x0BA80EF7,
+		0x1B80, 0x67F80F05,
+		0x1B80, 0x67F80F07,
+		0x1B80, 0xE1930F15,
+		0x1B80, 0xE1930F17,
+		0x1B80, 0xE1D00F25,
+		0x1B80, 0xE1D00F27,
+		0x1B80, 0x5C320F35,
+		0x1B80, 0x5C320F37,
+		0x1B80, 0x54F10F45,
+		0x1B80, 0x54F10F47,
+		0x1B80, 0x0BA90F55,
+		0x1B80, 0x0BA90F57,
+		0x1B80, 0x67FC0F65,
+		0x1B80, 0x67FC0F67,
+		0x1B80, 0xE1930F75,
+		0x1B80, 0xE1930F77,
+		0x1B80, 0xE1D00F85,
+		0x1B80, 0xE1D00F87,
+		0x1B80, 0x67FF0F95,
+		0x1B80, 0x67FF0F97,
+		0x1B80, 0xE1930FA5,
+		0x1B80, 0xE1930FA7,
+		0x1B80, 0xE1D00FB5,
+		0x1B80, 0xE1D00FB7,
+		0x1B80, 0x5C320FC5,
+		0x1B80, 0x5C320FC7,
+		0x1B80, 0x54F20FD5,
+		0x1B80, 0x54F20FD7,
+		0x1B80, 0x67000FE5,
+		0x1B80, 0x67000FE7,
+		0x1B80, 0xE1930FF5,
+		0x1B80, 0xE1930FF7,
+		0x1B80, 0xE1D01005,
+		0x1B80, 0xE1D01007,
+		0x1B80, 0x67031015,
+		0x1B80, 0x67031017,
+		0x1B80, 0xE1931025,
+		0x1B80, 0xE1931027,
+		0x1B80, 0xE1D01035,
+		0x1B80, 0xE1D01037,
+		0x1B80, 0xF9CC1045,
+		0x1B80, 0xF9CC1047,
+		0x1B80, 0x67071055,
+		0x1B80, 0x67071057,
+		0x1B80, 0xE1931065,
+		0x1B80, 0xE1931067,
+		0x1B80, 0xE1D01075,
+		0x1B80, 0xE1D01077,
+		0x1B80, 0xFAD31085,
+		0x1B80, 0xFAD31087,
+		0x1B80, 0x5C321095,
+		0x1B80, 0x5C321097,
+		0x1B80, 0x54F310A5,
+		0x1B80, 0x54F310A7,
+		0x1B80, 0x670B10B5,
+		0x1B80, 0x670B10B7,
+		0x1B80, 0xE19310C5,
+		0x1B80, 0xE19310C7,
+		0x1B80, 0xE1D010D5,
+		0x1B80, 0xE1D010D7,
+		0x1B80, 0x670E10E5,
+		0x1B80, 0x670E10E7,
+		0x1B80, 0xE19310F5,
+		0x1B80, 0xE19310F7,
+		0x1B80, 0xE1D01105,
+		0x1B80, 0xE1D01107,
+		0x1B80, 0x4D101115,
+		0x1B80, 0x4D101117,
+		0x1B80, 0x30A41125,
+		0x1B80, 0x30A41127,
+		0x1B80, 0x00011135,
+		0x1B80, 0x00011137,
+		0x1B80, 0x6C001145,
+		0x1B80, 0x6C001147,
+		0x1B80, 0x00061155,
+		0x1B80, 0x00061157,
+		0x1B80, 0x53001165,
+		0x1B80, 0x53001167,
+		0x1B80, 0x57F71175,
+		0x1B80, 0x57F71177,
+		0x1B80, 0x58211185,
+		0x1B80, 0x58211187,
+		0x1B80, 0x592E1195,
+		0x1B80, 0x592E1197,
+		0x1B80, 0x5A3811A5,
+		0x1B80, 0x5A3811A7,
+		0x1B80, 0x5B4111B5,
+		0x1B80, 0x5B4111B7,
+		0x1B80, 0x000711C5,
+		0x1B80, 0x000711C7,
+		0x1B80, 0x5C0011D5,
+		0x1B80, 0x5C0011D7,
+		0x1B80, 0x4B0011E5,
+		0x1B80, 0x4B0011E7,
+		0x1B80, 0x4E8F11F5,
+		0x1B80, 0x4E8F11F7,
+		0x1B80, 0x4F151205,
+		0x1B80, 0x4F151207,
+		0x1B80, 0x00041215,
+		0x1B80, 0x00041217,
+		0x1B80, 0xE1B51225,
+		0x1B80, 0xE1B51227,
+		0x1B80, 0xAB001235,
+		0x1B80, 0xAB001237,
+		0x1B80, 0x00011245,
+		0x1B80, 0x00011247,
+		0x1B80, 0x6C001255,
+		0x1B80, 0x6C001257,
+		0x1B80, 0x00061265,
+		0x1B80, 0x00061267,
+		0x1B80, 0x53001275,
+		0x1B80, 0x53001277,
+		0x1B80, 0x57F71285,
+		0x1B80, 0x57F71287,
+		0x1B80, 0x58211295,
+		0x1B80, 0x58211297,
+		0x1B80, 0x592E12A5,
+		0x1B80, 0x592E12A7,
+		0x1B80, 0x5A3812B5,
+		0x1B80, 0x5A3812B7,
+		0x1B80, 0x5B4112C5,
+		0x1B80, 0x5B4112C7,
+		0x1B80, 0x000712D5,
+		0x1B80, 0x000712D7,
+		0x1B80, 0x5C0012E5,
+		0x1B80, 0x5C0012E7,
+		0x1B80, 0x4B4012F5,
+		0x1B80, 0x4B4012F7,
+		0x1B80, 0x4E971305,
+		0x1B80, 0x4E971307,
+		0x1B80, 0x4F111315,
+		0x1B80, 0x4F111317,
+		0x1B80, 0x00041325,
+		0x1B80, 0x00041327,
+		0x1B80, 0xE1B51335,
+		0x1B80, 0xE1B51337,
+		0x1B80, 0xAB001345,
+		0x1B80, 0xAB001347,
+		0x1B80, 0x8B001355,
+		0x1B80, 0x8B001357,
+		0x1B80, 0xAB001365,
+		0x1B80, 0xAB001367,
+		0x1B80, 0x8A191375,
+		0x1B80, 0x8A191377,
+		0x1B80, 0x301D1385,
+		0x1B80, 0x301D1387,
+		0x1B80, 0x00011395,
+		0x1B80, 0x00011397,
+		0x1B80, 0x6C0113A5,
+		0x1B80, 0x6C0113A7,
+		0x1B80, 0x000613B5,
+		0x1B80, 0x000613B7,
+		0x1B80, 0x530113C5,
+		0x1B80, 0x530113C7,
+		0x1B80, 0x57F713D5,
+		0x1B80, 0x57F713D7,
+		0x1B80, 0x582113E5,
+		0x1B80, 0x582113E7,
+		0x1B80, 0x592E13F5,
+		0x1B80, 0x592E13F7,
+		0x1B80, 0x5A381405,
+		0x1B80, 0x5A381407,
+		0x1B80, 0x5B411415,
+		0x1B80, 0x5B411417,
+		0x1B80, 0x00071425,
+		0x1B80, 0x00071427,
+		0x1B80, 0x5C001435,
+		0x1B80, 0x5C001437,
+		0x1B80, 0x4B001445,
+		0x1B80, 0x4B001447,
+		0x1B80, 0x4E871455,
+		0x1B80, 0x4E871457,
+		0x1B80, 0x4F111465,
+		0x1B80, 0x4F111467,
+		0x1B80, 0x00041475,
+		0x1B80, 0x00041477,
+		0x1B80, 0xE1B51485,
+		0x1B80, 0xE1B51487,
+		0x1B80, 0xAB001495,
+		0x1B80, 0xAB001497,
+		0x1B80, 0x000614A5,
+		0x1B80, 0x000614A7,
+		0x1B80, 0x577714B5,
+		0x1B80, 0x577714B7,
+		0x1B80, 0x000714C5,
+		0x1B80, 0x000714C7,
+		0x1B80, 0x4E8614D5,
+		0x1B80, 0x4E8614D7,
+		0x1B80, 0x000414E5,
+		0x1B80, 0x000414E7,
+		0x1B80, 0x000114F5,
+		0x1B80, 0x000114F7,
+		0x1B80, 0x00011505,
+		0x1B80, 0x00011507,
+		0x1B80, 0x7B241515,
+		0x1B80, 0x7B241517,
+		0x1B80, 0x7A401525,
+		0x1B80, 0x7A401527,
+		0x1B80, 0x79001535,
+		0x1B80, 0x79001537,
+		0x1B80, 0x55031545,
+		0x1B80, 0x55031547,
+		0x1B80, 0x315D1555,
+		0x1B80, 0x315D1557,
+		0x1B80, 0x7B1C1565,
+		0x1B80, 0x7B1C1567,
+		0x1B80, 0x7A401575,
+		0x1B80, 0x7A401577,
+		0x1B80, 0x550B1585,
+		0x1B80, 0x550B1587,
+		0x1B80, 0x315D1595,
+		0x1B80, 0x315D1597,
+		0x1B80, 0x7B2015A5,
+		0x1B80, 0x7B2015A7,
+		0x1B80, 0x7A0015B5,
+		0x1B80, 0x7A0015B7,
+		0x1B80, 0x551315C5,
+		0x1B80, 0x551315C7,
+		0x1B80, 0x740115D5,
+		0x1B80, 0x740115D7,
+		0x1B80, 0x740015E5,
+		0x1B80, 0x740015E7,
+		0x1B80, 0x8E0015F5,
+		0x1B80, 0x8E0015F7,
+		0x1B80, 0x00011605,
+		0x1B80, 0x00011607,
+		0x1B80, 0x57021615,
+		0x1B80, 0x57021617,
+		0x1B80, 0x57001625,
+		0x1B80, 0x57001627,
+		0x1B80, 0x97001635,
+		0x1B80, 0x97001637,
+		0x1B80, 0x00011645,
+		0x1B80, 0x00011647,
+		0x1B80, 0x4F781655,
+		0x1B80, 0x4F781657,
+		0x1B80, 0x53881665,
+		0x1B80, 0x53881667,
+		0x1B80, 0xE1731675,
+		0x1B80, 0xE1731677,
+		0x1B80, 0x54801685,
+		0x1B80, 0x54801687,
+		0x1B80, 0x54001695,
+		0x1B80, 0x54001697,
+		0x1B80, 0xE17316A5,
+		0x1B80, 0xE17316A7,
+		0x1B80, 0x548116B5,
+		0x1B80, 0x548116B7,
+		0x1B80, 0x540016C5,
+		0x1B80, 0x540016C7,
+		0x1B80, 0xE17316D5,
+		0x1B80, 0xE17316D7,
+		0x1B80, 0x548216E5,
+		0x1B80, 0x548216E7,
+		0x1B80, 0x540016F5,
+		0x1B80, 0x540016F7,
+		0x1B80, 0xE17E1705,
+		0x1B80, 0xE17E1707,
+		0x1B80, 0xBF1D1715,
+		0x1B80, 0xBF1D1717,
+		0x1B80, 0x301D1725,
+		0x1B80, 0x301D1727,
+		0x1B80, 0xE1511735,
+		0x1B80, 0xE1511737,
+		0x1B80, 0xE1561745,
+		0x1B80, 0xE1561747,
+		0x1B80, 0xE15A1755,
+		0x1B80, 0xE15A1757,
+		0x1B80, 0xE1611765,
+		0x1B80, 0xE1611767,
+		0x1B80, 0xE1C71775,
+		0x1B80, 0xE1C71777,
+		0x1B80, 0x55131785,
+		0x1B80, 0x55131787,
+		0x1B80, 0xE15D1795,
+		0x1B80, 0xE15D1797,
+		0x1B80, 0x551517A5,
+		0x1B80, 0x551517A7,
+		0x1B80, 0xE16117B5,
+		0x1B80, 0xE16117B7,
+		0x1B80, 0xE1C717C5,
+		0x1B80, 0xE1C717C7,
+		0x1B80, 0x000117D5,
+		0x1B80, 0x000117D7,
+		0x1B80, 0x54BF17E5,
+		0x1B80, 0x54BF17E7,
+		0x1B80, 0x54C017F5,
+		0x1B80, 0x54C017F7,
+		0x1B80, 0x54A31805,
+		0x1B80, 0x54A31807,
+		0x1B80, 0x54C11815,
+		0x1B80, 0x54C11817,
+		0x1B80, 0x54A41825,
+		0x1B80, 0x54A41827,
+		0x1B80, 0x4C181835,
+		0x1B80, 0x4C181837,
+		0x1B80, 0xBF071845,
+		0x1B80, 0xBF071847,
+		0x1B80, 0x54C21855,
+		0x1B80, 0x54C21857,
+		0x1B80, 0x54A41865,
+		0x1B80, 0x54A41867,
+		0x1B80, 0xBF041875,
+		0x1B80, 0xBF041877,
+		0x1B80, 0x54C11885,
+		0x1B80, 0x54C11887,
+		0x1B80, 0x54A31895,
+		0x1B80, 0x54A31897,
+		0x1B80, 0xBF0118A5,
+		0x1B80, 0xBF0118A7,
+		0x1B80, 0xE1D518B5,
+		0x1B80, 0xE1D518B7,
+		0x1B80, 0x54DF18C5,
+		0x1B80, 0x54DF18C7,
+		0x1B80, 0x000118D5,
+		0x1B80, 0x000118D7,
+		0x1B80, 0x54BF18E5,
+		0x1B80, 0x54BF18E7,
+		0x1B80, 0x54E518F5,
+		0x1B80, 0x54E518F7,
+		0x1B80, 0x050A1905,
+		0x1B80, 0x050A1907,
+		0x1B80, 0x54DF1915,
+		0x1B80, 0x54DF1917,
+		0x1B80, 0x00011925,
+		0x1B80, 0x00011927,
+		0x1B80, 0x7F201935,
+		0x1B80, 0x7F201937,
+		0x1B80, 0x7E001945,
+		0x1B80, 0x7E001947,
+		0x1B80, 0x7D001955,
+		0x1B80, 0x7D001957,
+		0x1B80, 0x55011965,
+		0x1B80, 0x55011967,
+		0x1B80, 0x5C311975,
+		0x1B80, 0x5C311977,
+		0x1B80, 0xE15D1985,
+		0x1B80, 0xE15D1987,
+		0x1B80, 0xE1611995,
+		0x1B80, 0xE1611997,
+		0x1B80, 0x548019A5,
+		0x1B80, 0x548019A7,
+		0x1B80, 0x540019B5,
+		0x1B80, 0x540019B7,
+		0x1B80, 0xE15D19C5,
+		0x1B80, 0xE15D19C7,
+		0x1B80, 0xE16119D5,
+		0x1B80, 0xE16119D7,
+		0x1B80, 0x548119E5,
+		0x1B80, 0x548119E7,
+		0x1B80, 0x540019F5,
+		0x1B80, 0x540019F7,
+		0x1B80, 0xE15D1A05,
+		0x1B80, 0xE15D1A07,
+		0x1B80, 0xE1611A15,
+		0x1B80, 0xE1611A17,
+		0x1B80, 0x54821A25,
+		0x1B80, 0x54821A27,
+		0x1B80, 0x54001A35,
+		0x1B80, 0x54001A37,
+		0x1B80, 0xE17E1A45,
+		0x1B80, 0xE17E1A47,
+		0x1B80, 0xBFE91A55,
+		0x1B80, 0xBFE91A57,
+		0x1B80, 0x301D1A65,
+		0x1B80, 0x301D1A67,
+		0x1B80, 0x00231A75,
+		0x1B80, 0x00231A77,
+		0x1B80, 0x7B201A85,
+		0x1B80, 0x7B201A87,
+		0x1B80, 0x7A001A95,
+		0x1B80, 0x7A001A97,
+		0x1B80, 0x79001AA5,
+		0x1B80, 0x79001AA7,
+		0x1B80, 0xE1CB1AB5,
+		0x1B80, 0xE1CB1AB7,
+		0x1B80, 0x00021AC5,
+		0x1B80, 0x00021AC7,
+		0x1B80, 0x00011AD5,
+		0x1B80, 0x00011AD7,
+		0x1B80, 0x00221AE5,
+		0x1B80, 0x00221AE7,
+		0x1B80, 0x7B201AF5,
+		0x1B80, 0x7B201AF7,
+		0x1B80, 0x7A001B05,
+		0x1B80, 0x7A001B07,
+		0x1B80, 0x79001B15,
+		0x1B80, 0x79001B17,
+		0x1B80, 0xE1CB1B25,
+		0x1B80, 0xE1CB1B27,
+		0x1B80, 0x00021B35,
+		0x1B80, 0x00021B37,
+		0x1B80, 0x00011B45,
+		0x1B80, 0x00011B47,
+		0x1B80, 0x74021B55,
+		0x1B80, 0x74021B57,
+		0x1B80, 0x003F1B65,
+		0x1B80, 0x003F1B67,
+		0x1B80, 0x74001B75,
+		0x1B80, 0x74001B77,
+		0x1B80, 0x00021B85,
+		0x1B80, 0x00021B87,
+		0x1B80, 0x00011B95,
+		0x1B80, 0x00011B97,
+		0x1B80, 0x4D041BA5,
+		0x1B80, 0x4D041BA7,
+		0x1B80, 0x2EF81BB5,
+		0x1B80, 0x2EF81BB7,
+		0x1B80, 0x00001BC5,
+		0x1B80, 0x00001BC7,
+		0x1B80, 0x23301BD5,
+		0x1B80, 0x23301BD7,
+		0x1B80, 0x00241BE5,
+		0x1B80, 0x00241BE7,
+		0x1B80, 0x23E01BF5,
+		0x1B80, 0x23E01BF7,
+		0x1B80, 0x003F1C05,
+		0x1B80, 0x003F1C07,
+		0x1B80, 0x23FC1C15,
+		0x1B80, 0x23FC1C17,
+		0x1B80, 0xBFCE1C25,
+		0x1B80, 0xBFCE1C27,
+		0x1B80, 0x2EF01C35,
+		0x1B80, 0x2EF01C37,
+		0x1B80, 0x00001C45,
+		0x1B80, 0x00001C47,
+		0x1B80, 0x4D001C55,
+		0x1B80, 0x4D001C57,
+		0x1B80, 0x00011C65,
+		0x1B80, 0x00011C67,
+		0x1B80, 0x549F1C75,
+		0x1B80, 0x549F1C77,
+		0x1B80, 0x54FF1C85,
+		0x1B80, 0x54FF1C87,
+		0x1B80, 0x54001C95,
+		0x1B80, 0x54001C97,
+		0x1B80, 0x00011CA5,
+		0x1B80, 0x00011CA7,
+		0x1B80, 0x5C311CB5,
+		0x1B80, 0x5C311CB7,
+		0x1B80, 0x07141CC5,
+		0x1B80, 0x07141CC7,
+		0x1B80, 0x54001CD5,
+		0x1B80, 0x54001CD7,
+		0x1B80, 0x5C321CE5,
+		0x1B80, 0x5C321CE7,
+		0x1B80, 0x00011CF5,
+		0x1B80, 0x00011CF7,
+		0x1B80, 0x5C321D05,
+		0x1B80, 0x5C321D07,
+		0x1B80, 0x07141D15,
+		0x1B80, 0x07141D17,
+		0x1B80, 0x54001D25,
+		0x1B80, 0x54001D27,
+		0x1B80, 0x5C311D35,
+		0x1B80, 0x5C311D37,
+		0x1B80, 0x00011D45,
+		0x1B80, 0x00011D47,
+		0x1B80, 0x4C981D55,
+		0x1B80, 0x4C981D57,
+		0x1B80, 0x4C181D65,
+		0x1B80, 0x4C181D67,
+		0x1B80, 0x00011D75,
+		0x1B80, 0x00011D77,
+		0x1B80, 0x5C321D85,
+		0x1B80, 0x5C321D87,
+		0x1B80, 0x62841D95,
+		0x1B80, 0x62841D97,
+		0x1B80, 0x66861DA5,
+		0x1B80, 0x66861DA7,
+		0x1B80, 0x6C031DB5,
+		0x1B80, 0x6C031DB7,
+		0x1B80, 0x7B201DC5,
+		0x1B80, 0x7B201DC7,
+		0x1B80, 0x7A001DD5,
+		0x1B80, 0x7A001DD7,
+		0x1B80, 0x79001DE5,
+		0x1B80, 0x79001DE7,
+		0x1B80, 0x7F201DF5,
+		0x1B80, 0x7F201DF7,
+		0x1B80, 0x7E001E05,
+		0x1B80, 0x7E001E07,
+		0x1B80, 0x7D001E15,
+		0x1B80, 0x7D001E17,
+		0x1B80, 0x09011E25,
+		0x1B80, 0x09011E27,
+		0x1B80, 0x0C011E35,
+		0x1B80, 0x0C011E37,
+		0x1B80, 0x0BA61E45,
+		0x1B80, 0x0BA61E47,
+		0x1B80, 0x00011E55,
+		0x1B80, 0x00011E57,
+		0x1B80, 0x00000006,
+		0x1B80, 0x00000002,
+
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_bb_phy_8822b(dm, v1, MASKDWORD, v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8822b_phy_reg(void)
+{
+		return 104;
+}
+
+/******************************************************************************
+*                           phy_reg_pg.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x38404244,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x30323436,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x38404244,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x38404244,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x30323436,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x38404244,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x30323436,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x42442628,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x38404244,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x30323436,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x38404244,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x38404244,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x30323436,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x38404244,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x30323436,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x42442628,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type12.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type12[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x36384042,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x36384042,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x30323436,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x22242628,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x30323436,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x30323436,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x34361820,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x26283032,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x18202224,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x30323436,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x22242628,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x30323436,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x22242628,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x30323436,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x22242628,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x34361820,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x26283032,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x18202224
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type12(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type12)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type12;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type12\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type15.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type15[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x36384042,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x36384042,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x24262830,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x32343638,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x36382022,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x28303234,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x20222426,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x24262830,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x32343638,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x36382022,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x28303234,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x20222426
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type15(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type15)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type15;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type15\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type16.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type16[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x36384042,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x36384042,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x24262830,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x32343638,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x36382022,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x28303234,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x20222426,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x24262830,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x32343638,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x36382022,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x28303234,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x20222426
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type16(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type16)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type16;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type16\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type17.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type17[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x36384042,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x36384042,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x24262830,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x32343638,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x36382022,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x28303234,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x20222426,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x24262830,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x32343638,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x36382022,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x28303234,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x20222426
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type17(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type17)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type17;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type17\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type2.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type2[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x36384042,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x36384042,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x40424446,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x38404244,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x30323436,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x38404244,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x30323436,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x38404244,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x30323436,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x42442628,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x34363840,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x40424446,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x38404244,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x30323436,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x38404244,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x30323436,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x38404244,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x30323436,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x42442628,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x34363840,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x26283032
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type2(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type2)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type2;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type2\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type3.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type3[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x36384042,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x36384042,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x24262830,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x32343638,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x36382022,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x28303234,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x20222426,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x24262830,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x32343638,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x36382022,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x28303234,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x20222426
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type3(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type3)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type3;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type3\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type4.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type4[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x38404244,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x42444648,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x40424446,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x32343638,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x40424446,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x40424446,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x44462830,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x36384042,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x38404244,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x42444648,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x40424446,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x32343638,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x40424446,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x40424446,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x44462830,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x36384042,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x28303234,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x40424446,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x38404244,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x30323436,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x38404244,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x30323436,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x38404244,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x30323436,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x42442628,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x34363840,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x40424446,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x38404244,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x30323436,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x38404244,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x30323436,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x38404244,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x30323436,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x42442628,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x34363840,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x26283032
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type4(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type4)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type4;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type4\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+/******************************************************************************
+*                           phy_reg_pg_type5.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_phy_reg_pg_type5[] = {
+	0, 0, 0, 0x00000c20, 0xffffffff, 0x32343638,
+	0, 0, 0, 0x00000c24, 0xffffffff, 0x36384042,
+	0, 0, 0, 0x00000c28, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000c2c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c30, 0xffffffff, 0x26283032,
+	0, 0, 1, 0x00000c34, 0xffffffff, 0x34363840,
+	0, 0, 1, 0x00000c38, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c3c, 0xffffffff, 0x34363840,
+	0, 0, 0, 0x00000c40, 0xffffffff, 0x26283032,
+	0, 0, 0, 0x00000c44, 0xffffffff, 0x38402224,
+	0, 0, 1, 0x00000c48, 0xffffffff, 0x30323436,
+	0, 0, 1, 0x00000c4c, 0xffffffff, 0x22242628,
+	0, 1, 0, 0x00000e20, 0xffffffff, 0x32343638,
+	0, 1, 0, 0x00000e24, 0xffffffff, 0x36384042,
+	0, 1, 0, 0x00000e28, 0xffffffff, 0x28303234,
+	0, 1, 0, 0x00000e2c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e30, 0xffffffff, 0x26283032,
+	0, 1, 1, 0x00000e34, 0xffffffff, 0x34363840,
+	0, 1, 1, 0x00000e38, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e3c, 0xffffffff, 0x34363840,
+	0, 1, 0, 0x00000e40, 0xffffffff, 0x26283032,
+	0, 1, 0, 0x00000e44, 0xffffffff, 0x38402224,
+	0, 1, 1, 0x00000e48, 0xffffffff, 0x30323436,
+	0, 1, 1, 0x00000e4c, 0xffffffff, 0x22242628,
+	1, 0, 0, 0x00000c24, 0xffffffff, 0x34363840,
+	1, 0, 0, 0x00000c28, 0xffffffff, 0x26283032,
+	1, 0, 0, 0x00000c2c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c30, 0xffffffff, 0x24262830,
+	1, 0, 1, 0x00000c34, 0xffffffff, 0x32343638,
+	1, 0, 1, 0x00000c38, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c3c, 0xffffffff, 0x32343638,
+	1, 0, 0, 0x00000c40, 0xffffffff, 0x24262830,
+	1, 0, 0, 0x00000c44, 0xffffffff, 0x36382022,
+	1, 0, 1, 0x00000c48, 0xffffffff, 0x28303234,
+	1, 0, 1, 0x00000c4c, 0xffffffff, 0x20222426,
+	1, 1, 0, 0x00000e24, 0xffffffff, 0x34363840,
+	1, 1, 0, 0x00000e28, 0xffffffff, 0x26283032,
+	1, 1, 0, 0x00000e2c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e30, 0xffffffff, 0x24262830,
+	1, 1, 1, 0x00000e34, 0xffffffff, 0x32343638,
+	1, 1, 1, 0x00000e38, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e3c, 0xffffffff, 0x32343638,
+	1, 1, 0, 0x00000e40, 0xffffffff, 0x24262830,
+	1, 1, 0, 0x00000e44, 0xffffffff, 0x36382022,
+	1, 1, 1, 0x00000e48, 0xffffffff, 0x28303234,
+	1, 1, 1, 0x00000e4c, 0xffffffff, 0x20222426
+};
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type5(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8822b_phy_reg_pg_type5)/sizeof(u32);
+	u32	*array = array_mp_8822b_phy_reg_pg_type5;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_phy_reg_pg_type5\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8822b(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_bb.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_bb.h
new file mode 100644
index 000000000000..f5e2f487bf7c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_bb.h
@@ -0,0 +1,144 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: R3 1.0*/
+#if (RTL8822B_SUPPORT == 1)
+#ifndef __INC_MP_BB_HW_IMG_8822B_H
+#define __INC_MP_BB_HW_IMG_8822B_H
+
+
+/******************************************************************************
+*                           agc_tab.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_agc_tab(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_agc_tab(void);
+
+/******************************************************************************
+*                           phy_reg.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg(void);
+
+/******************************************************************************
+*                           phy_reg_pg.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type12.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type12(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type12(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type15.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type15(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type15(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type16.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type16(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type16(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type17.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type17(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type17(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type2.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type2(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type2(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type3.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type3(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type3(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type4.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type4(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type4(void);
+
+/******************************************************************************
+*                           phy_reg_pg_type5.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_phy_reg_pg_type5(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_phy_reg_pg_type5(void);
+
+#endif
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_mac.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_mac.c
new file mode 100644
index 000000000000..6dde9860e5f7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_mac.c
@@ -0,0 +1,302 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: R3 1.0*/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8822B_SUPPORT == 1)
+static boolean
+check_positive(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2,
+	const u32	condition3,
+	const u32	condition4
+)
+{
+	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
+
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
+
+	u32	driver1 = cut_version_for_para << 24 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
+			pkg_type_for_para << 12 |
+			(dm->support_interface & 0x0F) << 8  |
+			dm->rfe_type;
+
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
+
+	u32	driver3 = 0;
+
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Platform, Interface) = (0x%X, 0x%X)\n", dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(RFE, Package) = (0x%X, 0x%X)\n", dm->rfe_type, dm->package_type);
+
+
+	/*============== value Defined Check ===============*/
+	/*cut version [27:24] need to do value check*/
+	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
+		return false;
+
+	/*pkg type [15:12] need to do value check*/
+	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
+		return false;
+
+	/*interface [11:8] need to do value check*/
+	if (((cond1 & 0x00000F00) != 0) && ((cond1 & 0x00000F00) != (driver1 & 0x00000F00)))
+		return false;
+	/*=============== Bit Defined Check ================*/
+	/* We don't care [31:28] */
+
+	cond1 &= 0x000000FF;
+	driver1 &= 0x000000FF;
+
+	if (cond1 == driver1)
+		return true;
+	else
+		return false;
+}
+static boolean
+check_negative(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2
+)
+{
+	return true;
+}
+
+/******************************************************************************
+*                           mac_reg.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_mac_reg[] = {
+		0x029, 0x000000F9,
+		0x420, 0x00000080,
+		0x421, 0x0000001F,
+		0x428, 0x0000000A,
+		0x429, 0x00000010,
+		0x430, 0x00000000,
+		0x431, 0x00000000,
+		0x432, 0x00000000,
+		0x433, 0x00000001,
+		0x434, 0x00000004,
+		0x435, 0x00000005,
+		0x436, 0x00000007,
+		0x437, 0x00000008,
+		0x43C, 0x00000004,
+		0x43D, 0x00000005,
+		0x43E, 0x00000007,
+		0x43F, 0x00000008,
+		0x440, 0x0000005D,
+		0x441, 0x00000001,
+		0x442, 0x00000000,
+		0x444, 0x00000010,
+		0x445, 0x000000F0,
+		0x446, 0x00000001,
+		0x447, 0x000000FE,
+		0x448, 0x00000000,
+		0x449, 0x00000000,
+		0x44A, 0x00000000,
+		0x44B, 0x00000040,
+		0x44C, 0x00000010,
+		0x44D, 0x000000F0,
+		0x44E, 0x0000003F,
+		0x44F, 0x00000000,
+		0x450, 0x00000000,
+		0x451, 0x00000000,
+		0x452, 0x00000000,
+		0x453, 0x00000040,
+		0x455, 0x00000070,
+		0x45E, 0x00000004,
+		0x49C, 0x00000010,
+		0x49D, 0x000000F0,
+		0x49E, 0x00000000,
+		0x49F, 0x00000006,
+		0x4A0, 0x000000E0,
+		0x4A1, 0x00000003,
+		0x4A2, 0x00000000,
+		0x4A3, 0x00000040,
+		0x4A4, 0x00000015,
+		0x4A5, 0x000000F0,
+		0x4A6, 0x00000000,
+		0x4A7, 0x00000006,
+		0x4A8, 0x000000E0,
+		0x4A9, 0x00000000,
+		0x4AA, 0x00000000,
+		0x4AB, 0x00000000,
+		0x7DA, 0x00000008,
+		0x1448, 0x00000006,
+		0x144A, 0x00000006,
+		0x144C, 0x00000006,
+		0x144E, 0x00000006,
+		0x4C8, 0x000000FF,
+		0x4C9, 0x00000008,
+		0x4CA, 0x00000020,
+		0x4CB, 0x00000020,
+		0x4CC, 0x000000FF,
+		0x4CD, 0x000000FF,
+		0x4CE, 0x00000001,
+		0x4CF, 0x00000008,
+		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,
+		0x516, 0x0000000A,
+		0x521, 0x0000002F,
+		0x525, 0x0000004F,
+		0x551, 0x00000010,
+		0x559, 0x00000002,
+		0x55C, 0x00000050,
+		0x55D, 0x000000FF,
+		0x577, 0x0000000B,
+		0x5BE, 0x00000064,
+		0x605, 0x00000030,
+		0x608, 0x0000000E,
+		0x609, 0x00000022,
+		0x60C, 0x00000018,
+		0x6A0, 0x000000FF,
+		0x6A1, 0x000000FF,
+		0x6A2, 0x000000FF,
+		0x6A3, 0x000000FF,
+		0x6A4, 0x000000FF,
+		0x6A5, 0x000000FF,
+		0x6DE, 0x00000084,
+		0x620, 0x000000FF,
+		0x621, 0x000000FF,
+		0x622, 0x000000FF,
+		0x623, 0x000000FF,
+		0x624, 0x000000FF,
+		0x625, 0x000000FF,
+		0x626, 0x000000FF,
+		0x627, 0x000000FF,
+		0x638, 0x00000050,
+		0x63C, 0x0000000A,
+		0x63D, 0x0000000A,
+		0x63E, 0x0000000E,
+		0x63F, 0x0000000E,
+		0x640, 0x00000040,
+		0x642, 0x00000040,
+		0x643, 0x00000000,
+		0x652, 0x000000C8,
+		0x66E, 0x00000005,
+		0x718, 0x00000040,
+		0x7D4, 0x00000098,
+
+};
+
+void
+odm_read_and_config_mp_8822b_mac_reg(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8822b_mac_reg)/sizeof(u32);
+	u32	*array = array_mp_8822b_mac_reg;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_mac_reg\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_mac_8822b(dm, v1, (u8)v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8822b_mac_reg(void)
+{
+		return 104;
+}
+
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_mac.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_mac.h
new file mode 100644
index 000000000000..9b5b1b0b18b1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_mac.h
@@ -0,0 +1,44 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: R3 1.0*/
+#if (RTL8822B_SUPPORT == 1)
+#ifndef __INC_MP_MAC_HW_IMG_8822B_H
+#define __INC_MP_MAC_HW_IMG_8822B_H
+
+
+/******************************************************************************
+*                           mac_reg.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_mac_reg(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_mac_reg(void);
+
+#endif
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_rf.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_rf.c
new file mode 100644
index 000000000000..e0b63b6b4e1b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_rf.c
@@ -0,0 +1,16319 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: R3 1.0*/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8822B_SUPPORT == 1)
+static boolean
+check_positive(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2,
+	const u32	condition3,
+	const u32	condition4
+)
+{
+	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
+
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
+
+	u32	driver1 = cut_version_for_para << 24 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
+			pkg_type_for_para << 12 |
+			(dm->support_interface & 0x0F) << 8  |
+			dm->rfe_type;
+
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
+
+	u32	driver3 = 0;
+
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Platform, Interface) = (0x%X, 0x%X)\n", dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(RFE, Package) = (0x%X, 0x%X)\n", dm->rfe_type, dm->package_type);
+
+
+	/*============== value Defined Check ===============*/
+	/*cut version [27:24] need to do value check*/
+	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
+		return false;
+
+	/*pkg type [15:12] need to do value check*/
+	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
+		return false;
+
+	/*interface [11:8] need to do value check*/
+	if (((cond1 & 0x00000F00) != 0) && ((cond1 & 0x00000F00) != (driver1 & 0x00000F00)))
+		return false;
+	/*=============== Bit Defined Check ================*/
+	/* We don't care [31:28] */
+
+	cond1 &= 0x000000FF;
+	driver1 &= 0x000000FF;
+
+	if (cond1 == driver1)
+		return true;
+	else
+		return false;
+}
+static boolean
+check_negative(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2
+)
+{
+	return true;
+}
+
+/******************************************************************************
+*                           radioa.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_radioa[] = {
+		0x000, 0x00030000,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0xA0000000,	0x00000000,
+		0x001, 0x00040029,
+	0xB0000000,	0x00000000,
+		0x018, 0x00010D24,
+		0x0EF, 0x00080000,
+		0x033, 0x00000002,
+		0x03E, 0x0000003F,
+	0x8300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000D0F4E,
+	0xA0000000,	0x00000000,
+		0x03F, 0x000C0F4E,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000001,
+		0x03E, 0x00000034,
+		0x03F, 0x0004080E,
+		0x0EF, 0x00080000,
+		0x0DF, 0x00002449,
+		0x033, 0x00000024,
+		0x03E, 0x0000003F,
+		0x03F, 0x00060FDE,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00080000,
+		0x033, 0x00000025,
+		0x03E, 0x00000037,
+		0x03F, 0x0007EFCE,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00080000,
+		0x033, 0x00000026,
+		0x03E, 0x00000037,
+		0x03F, 0x000DEFCE,
+		0x0EF, 0x00000000,
+		0x07F, 0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FB0F8,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0xA0000000,	0x00000000,
+		0x0B0, 0x000FF0F8,
+	0xB0000000,	0x00000000,
+		0x0B1, 0x0007DBE4,
+		0x0B2, 0x000225D1,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x0007C330,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0xA0000000,	0x00000000,
+		0x0B3, 0x000FC760,
+	0xB0000000,	0x00000000,
+		0x0B4, 0x00099DD0,
+		0x0B5, 0x000400FC,
+		0x0B6, 0x000187F0,
+		0x0B7, 0x00030018,
+		0x0B8, 0x00080800,
+		0x0B9, 0x00000000,
+		0x0BA, 0x00008000,
+		0x0BB, 0x00000000,
+		0x0BC, 0x00040030,
+		0x0BD, 0x00000000,
+		0x0BE, 0x00000000,
+		0x0BF, 0x00000000,
+		0x0C0, 0x00000000,
+		0x0C1, 0x00000000,
+		0x0C2, 0x00000000,
+		0x0C3, 0x00000000,
+		0x0C4, 0x00002402,
+		0x0C5, 0x00000009,
+		0x0C6, 0x00040299,
+		0x0C7, 0x00055555,
+		0x0C8, 0x0000C16C,
+		0x0C9, 0x0001C146,
+		0x0CA, 0x00000000,
+		0x0CB, 0x00000000,
+		0x0CC, 0x00000000,
+		0x0CD, 0x00000000,
+		0x0CE, 0x00090C00,
+		0x0CF, 0x0006D200,
+		0x0DF, 0x00000009,
+		0x018, 0x00010524,
+		0x089, 0x00000207,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FE186,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FE186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FE186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0xA0000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0xB0000000,	0x00000000,
+		0x08B, 0x00061E3C,
+		0x08C, 0x000112C7,
+		0x08D, 0x000F4988,
+		0x08E, 0x00064D40,
+		0x0EF, 0x00020000,
+		0x033, 0x00000007,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004000,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000DFF86,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000DFF86,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0xA0000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000006,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004080,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x00000005,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004084,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0xA0000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x00000004,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004190,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004190,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004190,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004190,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004190,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004108,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004190,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004190,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x00000003,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004998,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004998,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004998,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004998,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004998,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x0000490C,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004998,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004998,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x00000002,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005840,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005840,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005840,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005840,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005840,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005E00,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005840,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00005840,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x00000001,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000058C2,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000058C2,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000058C2,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000058C2,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000058C2,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005862,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000058C2,
+	0xA0000000,	0x00000000,
+		0x03E, 0x000058C2,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x00000000,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005930,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005930,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005930,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005930,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005930,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005948,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00005930,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00005930,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000F,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004000,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000DFF86,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000DFF86,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0xA0000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0xB0000000,	0x00000000,
+		0x033, 0x0000000E,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000D,
+		0x03E, 0x000040C8,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000C,
+		0x03E, 0x00004190,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000B,
+		0x03E, 0x00004998,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000A,
+		0x03E, 0x00005840,
+		0x03F, 0x000C3186,
+		0x033, 0x00000009,
+		0x03E, 0x000058C2,
+		0x03F, 0x000C3186,
+		0x033, 0x00000008,
+		0x03E, 0x00005930,
+		0x03F, 0x000C3186,
+		0x033, 0x00000017,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004000,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000DFF86,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C0006,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0xA0000000,	0x00000000,
+		0x03F, 0x000C3186,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000016,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+		0x033, 0x00000015,
+		0x03E, 0x000040C8,
+		0x03F, 0x000C3186,
+		0x033, 0x00000014,
+		0x03E, 0x00004190,
+		0x03F, 0x000C3186,
+		0x033, 0x00000013,
+		0x03E, 0x00004998,
+		0x03F, 0x000C3186,
+		0x033, 0x00000012,
+		0x03E, 0x00005840,
+		0x03F, 0x000C3186,
+		0x033, 0x00000011,
+		0x03E, 0x000058C2,
+		0x03F, 0x000C3186,
+		0x033, 0x00000010,
+		0x03E, 0x00005930,
+		0x03F, 0x000C3186,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00004000,
+		0x033, 0x00000000,
+		0x03F, 0x0000000A,
+		0x033, 0x00000001,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000006,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0xA0000000,	0x00000000,
+		0x03F, 0x00000005,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000002,
+		0x03F, 0x00000000,
+		0x0EF, 0x00000000,
+		0x018, 0x00000401,
+		0x084, 0x00001209,
+		0x086, 0x000001A0,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0xA0000000,	0x00000000,
+		0x087, 0x000E8180,
+	0xB0000000,	0x00000000,
+		0x088, 0x00070020,
+		0x0DE, 0x00000010,
+		0x0EF, 0x00008000,
+		0x033, 0x0000000F,
+		0x03F, 0x0000003C,
+		0x033, 0x0000000E,
+		0x03F, 0x00000038,
+		0x033, 0x0000000D,
+		0x03F, 0x00000030,
+		0x033, 0x0000000C,
+		0x03F, 0x00000028,
+		0x033, 0x0000000B,
+		0x03F, 0x00000020,
+		0x033, 0x0000000A,
+		0x03F, 0x00000018,
+		0x033, 0x00000009,
+		0x03F, 0x00000010,
+		0x033, 0x00000008,
+		0x03F, 0x00000008,
+		0x033, 0x00000007,
+		0x03F, 0x0000003C,
+		0x033, 0x00000006,
+		0x03F, 0x00000038,
+		0x033, 0x00000005,
+		0x03F, 0x00000030,
+		0x033, 0x00000004,
+		0x03F, 0x00000028,
+		0x033, 0x00000003,
+		0x03F, 0x00000020,
+		0x033, 0x00000002,
+		0x03F, 0x00000018,
+		0x033, 0x00000001,
+		0x03F, 0x00000010,
+		0x033, 0x00000000,
+		0x03F, 0x00000008,
+		0x0EF, 0x00000000,
+		0x0B8, 0x00080A00,
+		0x0FE, 0x00000000,
+		0x0B0, 0x000FF0FA,
+		0x0FE, 0x00000000,
+		0x0FE, 0x00000000,
+		0x0CA, 0x00080000,
+		0x0FE, 0x00000000,
+		0x0C9, 0x0001C141,
+		0x0FE, 0x00000000,
+		0x0FE, 0x00000000,
+		0x0B0, 0x000FF0F8,
+		0x018, 0x00018D24,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0x018, 0x00010D24,
+		0x01B, 0x00075A40,
+		0x0EE, 0x00000002,
+		0x033, 0x00000000,
+		0x03F, 0x00000004,
+		0x033, 0x00000001,
+		0x03F, 0x00000004,
+		0x033, 0x00000002,
+		0x03F, 0x00000004,
+		0x033, 0x00000003,
+		0x03F, 0x00000004,
+		0x033, 0x00000004,
+		0x03F, 0x00000004,
+		0x033, 0x00000005,
+		0x03F, 0x00000006,
+		0x033, 0x00000006,
+		0x03F, 0x00000004,
+		0x033, 0x00000007,
+		0x03F, 0x00000000,
+		0x0EE, 0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D301,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0xA0000000,	0x00000000,
+		0x061, 0x0005D3D0,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+		0x0EF, 0x00000000,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+		0x0EF, 0x00000000,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000002A6,
+		0x030, 0x000012A6,
+		0x030, 0x000022A6,
+		0x030, 0x000032A6,
+		0x030, 0x000042A6,
+		0x030, 0x000052A6,
+		0x030, 0x000062A6,
+		0x030, 0x000072A6,
+		0x030, 0x000082A6,
+		0x030, 0x000092A6,
+		0x030, 0x0000A2A6,
+		0x030, 0x0000B2A6,
+		0x0EF, 0x00000000,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000303,
+		0x030, 0x00001303,
+		0x030, 0x00002303,
+		0x030, 0x00003303,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+		0x0EF, 0x00000000,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000002A6,
+		0x030, 0x000012A6,
+		0x030, 0x000022A6,
+		0x030, 0x000032A6,
+		0x030, 0x000042A6,
+		0x030, 0x000052A6,
+		0x030, 0x000062A6,
+		0x030, 0x000072A6,
+		0x030, 0x000082A6,
+		0x030, 0x000092A6,
+		0x030, 0x0000A2A6,
+		0x030, 0x0000B2A6,
+		0x0EF, 0x00000000,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000003A3,
+		0x030, 0x000013A3,
+		0x030, 0x000023A3,
+		0x030, 0x000033A3,
+		0x030, 0x00004355,
+		0x030, 0x00005355,
+		0x030, 0x00006355,
+		0x030, 0x00007355,
+		0x030, 0x00008315,
+		0x030, 0x00009315,
+		0x030, 0x0000A315,
+		0x030, 0x0000B315,
+		0x0EF, 0x00000000,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+		0x0EF, 0x00000000,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+		0x0EF, 0x00000000,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000384,
+		0x030, 0x00001384,
+		0x030, 0x00002384,
+		0x030, 0x00003384,
+		0x030, 0x00004425,
+		0x030, 0x00005425,
+		0x030, 0x00006425,
+		0x030, 0x00007425,
+		0x030, 0x000084A6,
+		0x030, 0x000094A6,
+		0x030, 0x0000A4A6,
+		0x030, 0x0000B4A6,
+		0x0EF, 0x00000000,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000463,
+		0x030, 0x00001463,
+		0x030, 0x00002463,
+		0x030, 0x00003463,
+		0x030, 0x00004545,
+		0x030, 0x00005545,
+		0x030, 0x00006545,
+		0x030, 0x00007545,
+		0x030, 0x00008565,
+		0x030, 0x00009565,
+		0x030, 0x0000A565,
+		0x030, 0x0000B565,
+		0x0EF, 0x00000000,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+		0x0EF, 0x00000000,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+		0x0EF, 0x00000000,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000443,
+		0x030, 0x00001443,
+		0x030, 0x00002443,
+		0x030, 0x00003443,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+		0x0EF, 0x00000000,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000443,
+		0x030, 0x00001443,
+		0x030, 0x00002443,
+		0x030, 0x00003443,
+		0x030, 0x00004483,
+		0x030, 0x00005483,
+		0x030, 0x00006483,
+		0x030, 0x00007483,
+		0x030, 0x000084A4,
+		0x030, 0x000094A4,
+		0x030, 0x0000A4A4,
+		0x030, 0x0000B4A4,
+		0x0EF, 0x00000000,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000361,
+		0x030, 0x00001361,
+		0x030, 0x00002361,
+		0x030, 0x00003361,
+		0x030, 0x00004443,
+		0x030, 0x00005443,
+		0x030, 0x00006443,
+		0x030, 0x00007443,
+		0x030, 0x00008424,
+		0x030, 0x00009424,
+		0x030, 0x0000A424,
+		0x030, 0x0000B424,
+		0x0EF, 0x00000000,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000334,
+		0x030, 0x00001334,
+		0x030, 0x00002334,
+		0x030, 0x00003334,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+		0x0EF, 0x00000000,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x00000403,
+		0x030, 0x00001403,
+		0x030, 0x00002403,
+		0x030, 0x00003403,
+		0x030, 0x000044A2,
+		0x030, 0x000054A2,
+		0x030, 0x000064A2,
+		0x030, 0x000074A2,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+		0x0EF, 0x00000000,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000003A3,
+		0x030, 0x000013A3,
+		0x030, 0x000023A3,
+		0x030, 0x000033A3,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+		0x0EF, 0x00000000,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000004A0,
+		0x030, 0x000014A0,
+		0x030, 0x000024A0,
+		0x030, 0x000034A0,
+		0x030, 0x000044A0,
+		0x030, 0x000054A0,
+		0x030, 0x000064A0,
+		0x030, 0x000074A0,
+		0x030, 0x000084A0,
+		0x030, 0x000094A0,
+		0x030, 0x0000A4A0,
+		0x030, 0x0000B4A0,
+		0x0EF, 0x00000000,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000002A1,
+		0x030, 0x000012A1,
+		0x030, 0x000022A1,
+		0x030, 0x000032A1,
+		0x030, 0x000042A1,
+		0x030, 0x000052A1,
+		0x030, 0x000062A1,
+		0x030, 0x000072A1,
+		0x030, 0x000082A1,
+		0x030, 0x000092A1,
+		0x030, 0x0000A2A1,
+		0x030, 0x0000B2A1,
+		0x0EF, 0x00000000,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000003A0,
+		0x030, 0x000013A0,
+		0x030, 0x000023A0,
+		0x030, 0x000033A0,
+		0x030, 0x000043A1,
+		0x030, 0x000053A1,
+		0x030, 0x000063A1,
+		0x030, 0x000073A1,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+		0x0EF, 0x00000000,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000002A1,
+		0x030, 0x000012A1,
+		0x030, 0x000022A1,
+		0x030, 0x000032A1,
+		0x030, 0x000042A1,
+		0x030, 0x000052A1,
+		0x030, 0x000062A1,
+		0x030, 0x000072A1,
+		0x030, 0x000082A1,
+		0x030, 0x000092A1,
+		0x030, 0x0000A2A1,
+		0x030, 0x0000B2A1,
+		0x0EF, 0x00000000,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000003A0,
+		0x030, 0x000013A0,
+		0x030, 0x000023A0,
+		0x030, 0x000033A0,
+		0x030, 0x00004430,
+		0x030, 0x00005430,
+		0x030, 0x00006430,
+		0x030, 0x00007430,
+		0x030, 0x00008372,
+		0x030, 0x00009372,
+		0x030, 0x0000A372,
+		0x030, 0x0000B372,
+		0x0EF, 0x00000000,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000004A0,
+		0x030, 0x000014A0,
+		0x030, 0x000024A0,
+		0x030, 0x000034A0,
+		0x030, 0x000044A0,
+		0x030, 0x000054A0,
+		0x030, 0x000064A0,
+		0x030, 0x000074A0,
+		0x030, 0x000084A0,
+		0x030, 0x000094A0,
+		0x030, 0x0000A4A0,
+		0x030, 0x0000B4A0,
+		0x0EF, 0x00000000,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000004A0,
+		0x030, 0x000014A0,
+		0x030, 0x000024A0,
+		0x030, 0x000034A0,
+		0x030, 0x000044A0,
+		0x030, 0x000054A0,
+		0x030, 0x000064A0,
+		0x030, 0x000074A0,
+		0x030, 0x000084A0,
+		0x030, 0x000094A0,
+		0x030, 0x0000A4A0,
+		0x030, 0x0000B4A0,
+		0x0EF, 0x00000000,
+	0xA0000000,	0x00000000,
+		0x0EF, 0x00000200,
+		0x030, 0x000003D0,
+		0x030, 0x000013D0,
+		0x030, 0x000023D0,
+		0x030, 0x000033D0,
+		0x030, 0x000043D0,
+		0x030, 0x000053D0,
+		0x030, 0x000063D0,
+		0x030, 0x000073D0,
+		0x030, 0x000083D0,
+		0x030, 0x000093D0,
+		0x030, 0x0000A3D0,
+		0x030, 0x0000B3D0,
+		0x0EF, 0x00000000,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A3,
+		0x030, 0x000013A3,
+		0x030, 0x000023A3,
+		0x030, 0x000033A3,
+		0x030, 0x000043A3,
+		0x030, 0x000053A3,
+		0x030, 0x000063A3,
+		0x030, 0x000073A3,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0xA0000000,	0x00000000,
+		0x0EF, 0x00000080,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000777,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000776,
+		0x030, 0x00001455,
+		0x030, 0x00002335,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000660,
+		0x030, 0x00001443,
+		0x030, 0x00002221,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000767,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000765,
+		0x030, 0x00001632,
+		0x030, 0x00002451,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000777,
+		0x030, 0x00001454,
+		0x030, 0x00002224,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000777,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000777,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000775,
+		0x030, 0x00001422,
+		0x030, 0x00002210,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000775,
+		0x030, 0x00001343,
+		0x030, 0x00002210,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0xA0000000,	0x00000000,
+		0x0EF, 0x00000040,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000800,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x0000002E,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x0000002E,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x0000042B,
+		0x033, 0x00000021,
+		0x03F, 0x0000082A,
+		0x033, 0x00000022,
+		0x03F, 0x00000849,
+		0x033, 0x00000023,
+		0x03F, 0x0000084C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4C,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000026,
+		0x03F, 0x00000CAC,
+		0x033, 0x00000027,
+		0x03F, 0x00000CED,
+		0x033, 0x00000028,
+		0x03F, 0x00000CF0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000021,
+		0x03F, 0x00000C29,
+		0x033, 0x00000022,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000023,
+		0x03F, 0x00000C69,
+		0x033, 0x00000024,
+		0x03F, 0x00000CA8,
+		0x033, 0x00000025,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000026,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000028,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF7,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000CE5,
+		0x033, 0x00000026,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000028,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF4,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C0B,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0E,
+		0x033, 0x00000022,
+		0x03F, 0x00000C2B,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2E,
+		0x033, 0x00000024,
+		0x03F, 0x00000C89,
+		0x033, 0x00000025,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000026,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000028,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF7,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x0000086A,
+		0x033, 0x00000025,
+		0x03F, 0x0000086D,
+		0x033, 0x00000026,
+		0x03F, 0x00000870,
+		0x033, 0x00000027,
+		0x03F, 0x00000891,
+		0x033, 0x00000028,
+		0x03F, 0x00000894,
+		0x033, 0x00000029,
+		0x03F, 0x000008B5,
+		0x033, 0x0000002A,
+		0x03F, 0x000008F5,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x00000068,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x0000042B,
+		0x033, 0x00000021,
+		0x03F, 0x0000082A,
+		0x033, 0x00000022,
+		0x03F, 0x00000849,
+		0x033, 0x00000023,
+		0x03F, 0x0000084C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4C,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000028,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF4,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x00000068,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x0000042B,
+		0x033, 0x00000021,
+		0x03F, 0x0000082A,
+		0x033, 0x00000022,
+		0x03F, 0x00000849,
+		0x033, 0x00000023,
+		0x03F, 0x0000084C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4C,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000028,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF4,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x0000002E,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000067,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000068,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x0000002E,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x0000042A,
+		0x033, 0x00000061,
+		0x03F, 0x00000829,
+		0x033, 0x00000062,
+		0x03F, 0x00000848,
+		0x033, 0x00000063,
+		0x03F, 0x0000084B,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAC,
+		0x033, 0x00000067,
+		0x03F, 0x00000CED,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF0,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x0000080B,
+		0x033, 0x00000061,
+		0x03F, 0x0000080E,
+		0x033, 0x00000062,
+		0x03F, 0x00000848,
+		0x033, 0x00000063,
+		0x03F, 0x00000869,
+		0x033, 0x00000064,
+		0x03F, 0x000008A9,
+		0x033, 0x00000065,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000066,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x00000068,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000CE5,
+		0x033, 0x00000066,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000068,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF4,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C10,
+		0x033, 0x00000063,
+		0x03F, 0x00000C4A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4D,
+		0x033, 0x00000065,
+		0x03F, 0x00000CC9,
+		0x033, 0x00000066,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x0000086A,
+		0x033, 0x00000065,
+		0x03F, 0x0000086D,
+		0x033, 0x00000066,
+		0x03F, 0x00000870,
+		0x033, 0x00000067,
+		0x03F, 0x00000891,
+		0x033, 0x00000068,
+		0x03F, 0x00000894,
+		0x033, 0x00000069,
+		0x03F, 0x000008B5,
+		0x033, 0x0000006A,
+		0x03F, 0x000008F5,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000067,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000068,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000067,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000068,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x00000068,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x0000042C,
+		0x033, 0x00000061,
+		0x03F, 0x0000082B,
+		0x033, 0x00000062,
+		0x03F, 0x0000084A,
+		0x033, 0x00000063,
+		0x03F, 0x0000084D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4D,
+		0x033, 0x00000065,
+		0x03F, 0x00000C8B,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8E,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEC,
+		0x033, 0x00000068,
+		0x03F, 0x00000CEF,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF5,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x00000068,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x0000042C,
+		0x033, 0x00000061,
+		0x03F, 0x0000082B,
+		0x033, 0x00000062,
+		0x03F, 0x0000084A,
+		0x033, 0x00000063,
+		0x03F, 0x0000084D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4D,
+		0x033, 0x00000065,
+		0x03F, 0x00000C8B,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8E,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEC,
+		0x033, 0x00000068,
+		0x03F, 0x00000CEF,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF5,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002B,
+		0x033, 0x000000A5,
+		0x03F, 0x0000002E,
+		0x033, 0x000000A6,
+		0x03F, 0x00000031,
+		0x033, 0x000000A7,
+		0x03F, 0x00000034,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x000000D1,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAF,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CD1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002B,
+		0x033, 0x000000A5,
+		0x03F, 0x0000002E,
+		0x033, 0x000000A6,
+		0x03F, 0x00000031,
+		0x033, 0x000000A7,
+		0x03F, 0x00000034,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x000000D1,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CAC,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CED,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CF0,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C0A,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0D,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C2A,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2D,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C6A,
+		0x033, 0x000000A5,
+		0x03F, 0x00000CE8,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CEB,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEE,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CF1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF4,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF7,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000CE5,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CE8,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEB,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEE,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF1,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF4,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000824,
+		0x033, 0x000000A1,
+		0x03F, 0x00000827,
+		0x033, 0x000000A2,
+		0x03F, 0x0000082A,
+		0x033, 0x000000A3,
+		0x03F, 0x0000082D,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C68,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6B,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CCA,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CCD,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C08,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0B,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0E,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2B,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2E,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C31,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CCA,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CCD,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000086A,
+		0x033, 0x000000A5,
+		0x03F, 0x0000086D,
+		0x033, 0x000000A6,
+		0x03F, 0x00000870,
+		0x033, 0x000000A7,
+		0x03F, 0x00000891,
+		0x033, 0x000000A8,
+		0x03F, 0x00000894,
+		0x033, 0x000000A9,
+		0x03F, 0x000008B5,
+		0x033, 0x000000AA,
+		0x03F, 0x000008F5,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAF,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CD1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAF,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CD1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x00000047,
+		0x033, 0x000000A5,
+		0x03F, 0x0000004A,
+		0x033, 0x000000A6,
+		0x03F, 0x0000004D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000050,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x00000094,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x0000042A,
+		0x033, 0x000000A1,
+		0x03F, 0x00000829,
+		0x033, 0x000000A2,
+		0x03F, 0x00000848,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084B,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4C,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEB,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEE,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF1,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF4,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x00000047,
+		0x033, 0x000000A5,
+		0x03F, 0x0000004A,
+		0x033, 0x000000A6,
+		0x03F, 0x0000004D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000050,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x00000094,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x0000042A,
+		0x033, 0x000000A1,
+		0x03F, 0x00000829,
+		0x033, 0x000000A2,
+		0x03F, 0x00000848,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084B,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4C,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEB,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEE,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF1,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF4,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0xA0000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000400,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x000008BB,
+		0x033, 0x00000001,
+		0x03F, 0x000008BB,
+		0x033, 0x00000002,
+		0x03F, 0x000008BB,
+		0x033, 0x00000003,
+		0x03F, 0x000008BB,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000047C,
+		0x033, 0x00000001,
+		0x03F, 0x0000047C,
+		0x033, 0x00000002,
+		0x03F, 0x0000047C,
+		0x033, 0x00000003,
+		0x03F, 0x0000047C,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x000004BB,
+		0x033, 0x00000001,
+		0x03F, 0x000004BB,
+		0x033, 0x00000002,
+		0x03F, 0x000004BB,
+		0x033, 0x00000003,
+		0x03F, 0x000004BB,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000100,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00001726,
+		0x033, 0x00000001,
+		0x03F, 0x00001726,
+		0x033, 0x00000002,
+		0x03F, 0x00001726,
+		0x033, 0x00000003,
+		0x03F, 0x00001726,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000F34,
+		0x033, 0x00000001,
+		0x03F, 0x00000F34,
+		0x033, 0x00000002,
+		0x03F, 0x00000F34,
+		0x033, 0x00000003,
+		0x03F, 0x00000F34,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0xA0000000,	0x00000000,
+		0x081, 0x0000F000,
+		0x087, 0x00016040,
+		0x051, 0x00000C00,
+		0x052, 0x0007C241,
+		0x053, 0x0001C069,
+		0x054, 0x00078032,
+		0x057, 0x0000CE0A,
+		0x058, 0x00058750,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000800,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000002,
+		0x033, 0x00000001,
+		0x03F, 0x00000005,
+		0x033, 0x00000002,
+		0x03F, 0x00000008,
+		0x033, 0x00000003,
+		0x03F, 0x0000000B,
+		0x033, 0x00000004,
+		0x03F, 0x0000000E,
+		0x033, 0x00000005,
+		0x03F, 0x0000002B,
+		0x033, 0x00000006,
+		0x03F, 0x0000002E,
+		0x033, 0x00000007,
+		0x03F, 0x00000031,
+		0x033, 0x00000008,
+		0x03F, 0x0000006E,
+		0x033, 0x00000009,
+		0x03F, 0x00000071,
+		0x033, 0x0000000A,
+		0x03F, 0x00000074,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0005142C,
+		0x033, 0x00000001,
+		0x03F, 0x0005144B,
+		0x033, 0x00000002,
+		0x03F, 0x0005144E,
+		0x033, 0x00000003,
+		0x03F, 0x00051C69,
+		0x033, 0x00000004,
+		0x03F, 0x00051C6C,
+		0x033, 0x00000005,
+		0x03F, 0x00051C6F,
+		0x033, 0x00000006,
+		0x03F, 0x00051CEB,
+		0x033, 0x00000007,
+		0x03F, 0x00051CEE,
+		0x033, 0x00000008,
+		0x03F, 0x00051CF1,
+		0x033, 0x00000009,
+		0x03F, 0x00051CF4,
+		0x033, 0x0000000A,
+		0x03F, 0x00051CF7,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000010,
+		0x033, 0x00000000,
+		0x008, 0x0009C060,
+		0x033, 0x00000001,
+		0x008, 0x0009C060,
+		0x0EF, 0x00000000,
+		0x033, 0x000000A2,
+		0x0EF, 0x00080000,
+		0x03E, 0x0000593F,
+	0x8300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000D0F4F,
+	0xA0000000,	0x00000000,
+		0x03F, 0x000C0F4F,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x033, 0x000000A3,
+		0x0EF, 0x00080000,
+		0x03E, 0x00005934,
+		0x03F, 0x0005AFCF,
+		0x0EF, 0x00000000,
+	0x83000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0CE, 0x00094400,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0CE, 0x00094400,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0CE, 0x00094400,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0CE, 0x00094400,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x0CE, 0x00094400,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x0CE, 0x00094400,
+	0xA0000000,	0x00000000,
+		0x0CE, 0x00094C00,
+	0xB0000000,	0x00000000,
+	0x83000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0CF, 0x00072F00,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0CF, 0x00072F00,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0CF, 0x00072F00,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0CF, 0x00072F00,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x0CF, 0x00064700,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x0CF, 0x00072F00,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x0CF, 0x00072F00,
+	0xA0000000,	0x00000000,
+		0x0CF, 0x00064700,
+	0xB0000000,	0x00000000,
+	0x83000002,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000004,
+		0x033, 0x00000000,
+		0x03F, 0x00000056,
+		0x033, 0x00000001,
+		0x03F, 0x000000D6,
+		0x0EF, 0x00000000,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000004,
+		0x033, 0x00000000,
+		0x03F, 0x00000056,
+		0x033, 0x00000001,
+		0x03F, 0x000000D6,
+		0x0EF, 0x00000000,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000004,
+		0x033, 0x00000000,
+		0x03F, 0x00000056,
+		0x033, 0x00000001,
+		0x03F, 0x000000D6,
+		0x0EF, 0x00000000,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000004,
+		0x033, 0x00000000,
+		0x03F, 0x00000056,
+		0x033, 0x00000001,
+		0x03F, 0x000000D6,
+		0x0EF, 0x00000000,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000004,
+		0x033, 0x00000000,
+		0x03F, 0x00000096,
+		0x033, 0x00000001,
+		0x03F, 0x000000D6,
+		0x0EF, 0x00000000,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000004,
+		0x033, 0x00000000,
+		0x03F, 0x00000056,
+		0x033, 0x00000001,
+		0x03F, 0x00000056,
+		0x0EF, 0x00000000,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000004,
+		0x033, 0x00000000,
+		0x03F, 0x00000056,
+		0x033, 0x00000001,
+		0x03F, 0x000000D6,
+		0x0EF, 0x00000000,
+	0xA0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000096,
+		0x033, 0x00000001,
+		0x03F, 0x000000D6,
+		0x0EF, 0x00000000,
+	0xB0000000,	0x00000000,
+		0x0B0, 0x000FF0FC,
+		0x0C4, 0x00081402,
+		0x0CC, 0x00082000,
+
+};
+
+void
+odm_read_and_config_mp_8822b_radioa(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8822b_radioa)/sizeof(u32);
+	u32	*array = array_mp_8822b_radioa;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_radioa\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_rf_radio_a_8822b(dm, v1, v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8822b_radioa(void)
+{
+		return 104;
+}
+
+/******************************************************************************
+*                           radiob.TXT
+******************************************************************************/
+
+u32 array_mp_8822b_radiob[] = {
+		0x000, 0x00030000,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x00040029,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x001, 0x0004002D,
+	0xA0000000,	0x00000000,
+		0x001, 0x00040029,
+	0xB0000000,	0x00000000,
+		0x018, 0x00010D24,
+		0x0EF, 0x00080000,
+		0x033, 0x00000002,
+		0x03E, 0x0000003F,
+	0x8300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000D0F4E,
+	0xA0000000,	0x00000000,
+		0x03F, 0x000C0F4E,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000001,
+		0x03E, 0x00000034,
+		0x03F, 0x0004080E,
+		0x0EF, 0x00080000,
+		0x0DF, 0x00002449,
+		0x033, 0x00000024,
+		0x03E, 0x0000003F,
+		0x03F, 0x00060FDE,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00080000,
+		0x033, 0x00000025,
+		0x03E, 0x00000037,
+		0x03F, 0x0007EFCE,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00080000,
+		0x033, 0x00000026,
+		0x03E, 0x00000037,
+		0x03F, 0x000DEFCE,
+		0x0EF, 0x00000000,
+		0x0DF, 0x00000009,
+		0x018, 0x00010524,
+		0x089, 0x00000207,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FE186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FE186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0xA0000000,	0x00000000,
+		0x08A, 0x000FF186,
+	0xB0000000,	0x00000000,
+		0x08B, 0x00061E3C,
+		0x08C, 0x000112C7,
+		0x08D, 0x000F4988,
+		0x08E, 0x00064D40,
+		0x0EF, 0x00020000,
+		0x033, 0x00000007,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000006,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+		0x033, 0x00000005,
+		0x03E, 0x000040C8,
+		0x03F, 0x000C3186,
+		0x033, 0x00000004,
+		0x03E, 0x00004190,
+		0x03F, 0x000C3186,
+		0x033, 0x00000003,
+		0x03E, 0x00004998,
+		0x03F, 0x000C3186,
+		0x033, 0x00000002,
+		0x03E, 0x00005840,
+		0x03F, 0x000C3186,
+		0x033, 0x00000001,
+		0x03E, 0x000058C2,
+		0x03F, 0x000C3186,
+		0x033, 0x00000000,
+		0x03E, 0x00005930,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000F,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0xB0000000,	0x00000000,
+		0x033, 0x0000000E,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000D,
+	0x8300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040D0,
+	0xA0000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000C,
+		0x03E, 0x00004190,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000B,
+		0x03E, 0x00004998,
+		0x03F, 0x000C3186,
+		0x033, 0x0000000A,
+		0x03E, 0x00005840,
+		0x03F, 0x000C3186,
+		0x033, 0x00000009,
+		0x03E, 0x000058C2,
+		0x03F, 0x000C3186,
+		0x033, 0x00000008,
+		0x03E, 0x00005930,
+		0x03F, 0x000C3186,
+		0x033, 0x00000017,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000DFF86,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000DFF86,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C0006,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x00004040,
+		0x03F, 0x000C3186,
+	0xA0000000,	0x00000000,
+		0x03E, 0x00004000,
+		0x03F, 0x000C3186,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000016,
+		0x03E, 0x00004080,
+		0x03F, 0x000C3186,
+		0x033, 0x00000015,
+	0x8300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03E, 0x000040D0,
+	0xA0000000,	0x00000000,
+		0x03E, 0x000040C8,
+	0xB0000000,	0x00000000,
+		0x03F, 0x000C3186,
+		0x033, 0x00000014,
+		0x03E, 0x00004190,
+		0x03F, 0x000C3186,
+		0x033, 0x00000013,
+		0x03E, 0x00004998,
+		0x03F, 0x000C3186,
+		0x033, 0x00000012,
+		0x03E, 0x00005840,
+		0x03F, 0x000C3186,
+		0x033, 0x00000011,
+		0x03E, 0x000058C2,
+		0x03F, 0x000C3186,
+		0x033, 0x00000010,
+		0x03E, 0x00005930,
+		0x03F, 0x000C3186,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00004000,
+		0x033, 0x00000000,
+		0x03F, 0x0000000A,
+		0x033, 0x00000001,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000002,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000005,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x00000000,
+	0xA0000000,	0x00000000,
+		0x03F, 0x00000005,
+	0xB0000000,	0x00000000,
+		0x033, 0x00000002,
+		0x03F, 0x00000000,
+		0x0EF, 0x00000000,
+		0x018, 0x00000401,
+		0x084, 0x00001209,
+		0x086, 0x000001A0,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x087, 0x00068080,
+	0xA0000000,	0x00000000,
+		0x087, 0x000E8180,
+	0xB0000000,	0x00000000,
+		0x088, 0x00070020,
+		0x0DE, 0x00000010,
+		0x0EF, 0x00008000,
+		0x033, 0x0000000F,
+		0x03F, 0x0000003C,
+		0x033, 0x0000000E,
+		0x03F, 0x00000038,
+		0x033, 0x0000000D,
+		0x03F, 0x00000030,
+		0x033, 0x0000000C,
+		0x03F, 0x00000028,
+		0x033, 0x0000000B,
+		0x03F, 0x00000020,
+		0x033, 0x0000000A,
+		0x03F, 0x00000018,
+		0x033, 0x00000009,
+		0x03F, 0x00000010,
+		0x033, 0x00000008,
+		0x03F, 0x00000008,
+		0x033, 0x00000007,
+		0x03F, 0x0000003C,
+		0x033, 0x00000006,
+		0x03F, 0x00000038,
+		0x033, 0x00000005,
+		0x03F, 0x00000030,
+		0x033, 0x00000004,
+		0x03F, 0x00000028,
+		0x033, 0x00000003,
+		0x03F, 0x00000020,
+		0x033, 0x00000002,
+		0x03F, 0x00000018,
+		0x033, 0x00000001,
+		0x03F, 0x00000010,
+		0x033, 0x00000000,
+		0x03F, 0x00000008,
+		0x0EF, 0x00000000,
+		0x018, 0x00018D24,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0x018, 0x00010D24,
+		0x01B, 0x00075A40,
+		0x0EE, 0x00000002,
+		0x033, 0x00000000,
+		0x03F, 0x00000004,
+		0x033, 0x00000001,
+		0x03F, 0x00000004,
+		0x033, 0x00000002,
+		0x03F, 0x00000004,
+		0x033, 0x00000003,
+		0x03F, 0x00000004,
+		0x033, 0x00000004,
+		0x03F, 0x00000004,
+		0x033, 0x00000005,
+		0x03F, 0x00000006,
+		0x033, 0x00000006,
+		0x03F, 0x00000004,
+		0x033, 0x00000007,
+		0x03F, 0x00000000,
+		0x0EE, 0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D3D1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000062,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D2A1,
+		0x062, 0x0000D3A2,
+		0x063, 0x00000002,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x061, 0x0005D4A0,
+		0x062, 0x0000D203,
+		0x063, 0x00000062,
+	0xA0000000,	0x00000000,
+		0x061, 0x0005D3D0,
+		0x062, 0x0000D303,
+		0x063, 0x00000002,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000200,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A3,
+		0x030, 0x000053A3,
+		0x030, 0x000063A3,
+		0x030, 0x000073A3,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000002A6,
+		0x030, 0x000012A6,
+		0x030, 0x000022A6,
+		0x030, 0x000032A6,
+		0x030, 0x000042A6,
+		0x030, 0x000052A6,
+		0x030, 0x000062A6,
+		0x030, 0x000072A6,
+		0x030, 0x000082A6,
+		0x030, 0x000092A6,
+		0x030, 0x0000A2A6,
+		0x030, 0x0000B2A6,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000303,
+		0x030, 0x00001303,
+		0x030, 0x00002303,
+		0x030, 0x00003303,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000002A6,
+		0x030, 0x000012A6,
+		0x030, 0x000022A6,
+		0x030, 0x000032A6,
+		0x030, 0x000042A6,
+		0x030, 0x000052A6,
+		0x030, 0x000062A6,
+		0x030, 0x000072A6,
+		0x030, 0x000082A6,
+		0x030, 0x000092A6,
+		0x030, 0x0000A2A6,
+		0x030, 0x0000B2A6,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A4,
+		0x030, 0x000014A4,
+		0x030, 0x000024A4,
+		0x030, 0x000034A4,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x000083A5,
+		0x030, 0x000093A5,
+		0x030, 0x0000A3A5,
+		0x030, 0x0000B3A5,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000002F4,
+		0x030, 0x000012F4,
+		0x030, 0x000022F4,
+		0x030, 0x000032F4,
+		0x030, 0x00004365,
+		0x030, 0x00005365,
+		0x030, 0x00006365,
+		0x030, 0x00007365,
+		0x030, 0x000082A4,
+		0x030, 0x000092A4,
+		0x030, 0x0000A2A4,
+		0x030, 0x0000B2A4,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000382,
+		0x030, 0x00001382,
+		0x030, 0x00002382,
+		0x030, 0x00003382,
+		0x030, 0x00004445,
+		0x030, 0x00005445,
+		0x030, 0x00006445,
+		0x030, 0x00007445,
+		0x030, 0x00008425,
+		0x030, 0x00009425,
+		0x030, 0x0000A425,
+		0x030, 0x0000B425,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A3,
+		0x030, 0x000053A3,
+		0x030, 0x000063A3,
+		0x030, 0x000073A3,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A3,
+		0x030, 0x000014A3,
+		0x030, 0x000024A3,
+		0x030, 0x000034A3,
+		0x030, 0x000044A3,
+		0x030, 0x000054A3,
+		0x030, 0x000064A3,
+		0x030, 0x000074A3,
+		0x030, 0x000084A3,
+		0x030, 0x000094A3,
+		0x030, 0x0000A4A3,
+		0x030, 0x0000B4A3,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000443,
+		0x030, 0x00001443,
+		0x030, 0x00002443,
+		0x030, 0x00003443,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000343,
+		0x030, 0x00001343,
+		0x030, 0x00002343,
+		0x030, 0x00003343,
+		0x030, 0x00004483,
+		0x030, 0x00005483,
+		0x030, 0x00006483,
+		0x030, 0x00007483,
+		0x030, 0x000083A4,
+		0x030, 0x000093A4,
+		0x030, 0x0000A3A4,
+		0x030, 0x0000B3A4,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x00004423,
+		0x030, 0x00005423,
+		0x030, 0x00006423,
+		0x030, 0x00007423,
+		0x030, 0x00008324,
+		0x030, 0x00009324,
+		0x030, 0x0000A324,
+		0x030, 0x0000B324,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000303,
+		0x030, 0x00001303,
+		0x030, 0x00002303,
+		0x030, 0x00003303,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000403,
+		0x030, 0x00001403,
+		0x030, 0x00002403,
+		0x030, 0x00003403,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A3,
+		0x030, 0x000013A3,
+		0x030, 0x000023A3,
+		0x030, 0x000033A3,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x00008365,
+		0x030, 0x00009365,
+		0x030, 0x0000A365,
+		0x030, 0x0000B365,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A0,
+		0x030, 0x000014A0,
+		0x030, 0x000024A0,
+		0x030, 0x000034A0,
+		0x030, 0x000044A0,
+		0x030, 0x000054A0,
+		0x030, 0x000064A0,
+		0x030, 0x000074A0,
+		0x030, 0x000084A0,
+		0x030, 0x000094A0,
+		0x030, 0x0000A4A0,
+		0x030, 0x0000B4A0,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000002A1,
+		0x030, 0x000012A1,
+		0x030, 0x000022A1,
+		0x030, 0x000032A1,
+		0x030, 0x000042A1,
+		0x030, 0x000052A1,
+		0x030, 0x000062A1,
+		0x030, 0x000072A1,
+		0x030, 0x000082A1,
+		0x030, 0x000092A1,
+		0x030, 0x0000A2A1,
+		0x030, 0x0000B2A1,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A0,
+		0x030, 0x000014A0,
+		0x030, 0x000024A0,
+		0x030, 0x000034A0,
+		0x030, 0x000043A1,
+		0x030, 0x000053A1,
+		0x030, 0x000063A1,
+		0x030, 0x000073A1,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000002A1,
+		0x030, 0x000012A1,
+		0x030, 0x000022A1,
+		0x030, 0x000032A1,
+		0x030, 0x000042A1,
+		0x030, 0x000052A1,
+		0x030, 0x000062A1,
+		0x030, 0x000072A1,
+		0x030, 0x000082A1,
+		0x030, 0x000092A1,
+		0x030, 0x0000A2A1,
+		0x030, 0x0000B2A1,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A1,
+		0x030, 0x000014A1,
+		0x030, 0x000024A1,
+		0x030, 0x000034A1,
+		0x030, 0x000043A1,
+		0x030, 0x000053A1,
+		0x030, 0x000063A1,
+		0x030, 0x000073A1,
+		0x030, 0x000083A1,
+		0x030, 0x000093A1,
+		0x030, 0x0000A3A1,
+		0x030, 0x0000B3A1,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A0,
+		0x030, 0x000014A0,
+		0x030, 0x000024A0,
+		0x030, 0x000034A0,
+		0x030, 0x000044A0,
+		0x030, 0x000054A0,
+		0x030, 0x000064A0,
+		0x030, 0x000074A0,
+		0x030, 0x000084A0,
+		0x030, 0x000094A0,
+		0x030, 0x0000A4A0,
+		0x030, 0x0000B4A0,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000004A0,
+		0x030, 0x000014A0,
+		0x030, 0x000024A0,
+		0x030, 0x000034A0,
+		0x030, 0x000044A0,
+		0x030, 0x000054A0,
+		0x030, 0x000064A0,
+		0x030, 0x000074A0,
+		0x030, 0x000084A0,
+		0x030, 0x000094A0,
+		0x030, 0x0000A4A0,
+		0x030, 0x0000B4A0,
+	0xA0000000,	0x00000000,
+		0x030, 0x000002D0,
+		0x030, 0x000012D0,
+		0x030, 0x000022D0,
+		0x030, 0x000032D0,
+		0x030, 0x000042D0,
+		0x030, 0x000052D0,
+		0x030, 0x000062D0,
+		0x030, 0x000072D0,
+		0x030, 0x000082D0,
+		0x030, 0x000092D0,
+		0x030, 0x0000A2D0,
+		0x030, 0x0000B2D0,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000080,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A3,
+		0x030, 0x000013A3,
+		0x030, 0x000023A3,
+		0x030, 0x000033A3,
+		0x030, 0x000043A4,
+		0x030, 0x000053A4,
+		0x030, 0x000063A4,
+		0x030, 0x000073A4,
+		0x030, 0x000083A3,
+		0x030, 0x000093A3,
+		0x030, 0x0000A3A3,
+		0x030, 0x0000B3A3,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000203,
+		0x030, 0x00001203,
+		0x030, 0x00002203,
+		0x030, 0x00003203,
+		0x030, 0x00004203,
+		0x030, 0x00005203,
+		0x030, 0x00006203,
+		0x030, 0x00007203,
+		0x030, 0x00008203,
+		0x030, 0x00009203,
+		0x030, 0x0000A203,
+		0x030, 0x0000B203,
+	0xA0000000,	0x00000000,
+		0x030, 0x000003A2,
+		0x030, 0x000013A2,
+		0x030, 0x000023A2,
+		0x030, 0x000033A2,
+		0x030, 0x000043A2,
+		0x030, 0x000053A2,
+		0x030, 0x000063A2,
+		0x030, 0x000073A2,
+		0x030, 0x000083A2,
+		0x030, 0x000093A2,
+		0x030, 0x0000A3A2,
+		0x030, 0x0000B3A2,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000040,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000777,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000764,
+		0x030, 0x00001452,
+		0x030, 0x00002220,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000660,
+		0x030, 0x00001341,
+		0x030, 0x00002220,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000767,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000765,
+		0x030, 0x00001632,
+		0x030, 0x00002451,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000777,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000776,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000777,
+		0x030, 0x00001442,
+		0x030, 0x00002222,
+		0x030, 0x00004777,
+		0x030, 0x00005777,
+		0x030, 0x00006777,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000775,
+		0x030, 0x00001422,
+		0x030, 0x00002210,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000775,
+		0x030, 0x00001222,
+		0x030, 0x00002210,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x030, 0x00000645,
+		0x030, 0x00001333,
+		0x030, 0x00002011,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0xA0000000,	0x00000000,
+		0x030, 0x00000764,
+		0x030, 0x00001632,
+		0x030, 0x00002421,
+		0x030, 0x00004000,
+		0x030, 0x00005000,
+		0x030, 0x00006000,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000800,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x0000002E,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x0000002E,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x0000042C,
+		0x033, 0x00000021,
+		0x03F, 0x0000082B,
+		0x033, 0x00000022,
+		0x03F, 0x0000084A,
+		0x033, 0x00000023,
+		0x03F, 0x0000084D,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4E,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6E,
+		0x033, 0x00000026,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000027,
+		0x03F, 0x00000CED,
+		0x033, 0x00000028,
+		0x03F, 0x00000CF0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000828,
+		0x033, 0x00000021,
+		0x03F, 0x0000082B,
+		0x033, 0x00000022,
+		0x03F, 0x00000868,
+		0x033, 0x00000023,
+		0x03F, 0x00000889,
+		0x033, 0x00000024,
+		0x03F, 0x000008AA,
+		0x033, 0x00000025,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000026,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000028,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF7,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000CE5,
+		0x033, 0x00000026,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000028,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF4,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C25,
+		0x033, 0x00000021,
+		0x03F, 0x00000C28,
+		0x033, 0x00000022,
+		0x03F, 0x00000C2B,
+		0x033, 0x00000023,
+		0x03F, 0x00000C68,
+		0x033, 0x00000024,
+		0x03F, 0x00000C6B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6E,
+		0x033, 0x00000026,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000028,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF7,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000CEA,
+		0x033, 0x00000027,
+		0x03F, 0x00000CED,
+		0x033, 0x00000028,
+		0x03F, 0x00000CF0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000429,
+		0x033, 0x00000021,
+		0x03F, 0x00000828,
+		0x033, 0x00000022,
+		0x03F, 0x00000847,
+		0x033, 0x00000023,
+		0x03F, 0x0000084A,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000025,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF6,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x00000068,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x0000042B,
+		0x033, 0x00000021,
+		0x03F, 0x0000082A,
+		0x033, 0x00000022,
+		0x03F, 0x00000849,
+		0x033, 0x00000023,
+		0x03F, 0x0000084C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4C,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000028,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF4,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000005,
+		0x033, 0x00000021,
+		0x03F, 0x00000008,
+		0x033, 0x00000022,
+		0x03F, 0x0000000B,
+		0x033, 0x00000023,
+		0x03F, 0x0000000E,
+		0x033, 0x00000024,
+		0x03F, 0x0000002B,
+		0x033, 0x00000025,
+		0x03F, 0x00000068,
+		0x033, 0x00000026,
+		0x03F, 0x0000006B,
+		0x033, 0x00000027,
+		0x03F, 0x0000006E,
+		0x033, 0x00000028,
+		0x03F, 0x00000071,
+		0x033, 0x00000029,
+		0x03F, 0x00000074,
+		0x033, 0x0000002A,
+		0x03F, 0x00000077,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x0000042B,
+		0x033, 0x00000021,
+		0x03F, 0x0000082A,
+		0x033, 0x00000022,
+		0x03F, 0x00000849,
+		0x033, 0x00000023,
+		0x03F, 0x0000084C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C4C,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000028,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF4,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000007,
+		0x033, 0x00000021,
+		0x03F, 0x0000000A,
+		0x033, 0x00000022,
+		0x03F, 0x0000000D,
+		0x033, 0x00000023,
+		0x03F, 0x0000002A,
+		0x033, 0x00000024,
+		0x03F, 0x0000002D,
+		0x033, 0x00000025,
+		0x03F, 0x00000030,
+		0x033, 0x00000026,
+		0x03F, 0x0000006D,
+		0x033, 0x00000027,
+		0x03F, 0x00000070,
+		0x033, 0x00000028,
+		0x03F, 0x000000ED,
+		0x033, 0x00000029,
+		0x03F, 0x000000F0,
+		0x033, 0x0000002A,
+		0x03F, 0x000000F3,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000020,
+		0x03F, 0x00000C09,
+		0x033, 0x00000021,
+		0x03F, 0x00000C0C,
+		0x033, 0x00000022,
+		0x03F, 0x00000C0F,
+		0x033, 0x00000023,
+		0x03F, 0x00000C2C,
+		0x033, 0x00000024,
+		0x03F, 0x00000C2F,
+		0x033, 0x00000025,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000026,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000027,
+		0x03F, 0x00000C90,
+		0x033, 0x00000028,
+		0x03F, 0x00000CD0,
+		0x033, 0x00000029,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000002A,
+		0x03F, 0x00000CF5,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x0000002E,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000067,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000068,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x0000002E,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x0000042A,
+		0x033, 0x00000061,
+		0x03F, 0x00000829,
+		0x033, 0x00000062,
+		0x03F, 0x00000848,
+		0x033, 0x00000063,
+		0x03F, 0x0000084B,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAC,
+		0x033, 0x00000067,
+		0x03F, 0x00000CED,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF0,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000842,
+		0x033, 0x00000061,
+		0x03F, 0x00000845,
+		0x033, 0x00000062,
+		0x03F, 0x00000866,
+		0x033, 0x00000063,
+		0x03F, 0x000008A6,
+		0x033, 0x00000064,
+		0x03F, 0x000008C8,
+		0x033, 0x00000065,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000066,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x00000068,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000CE5,
+		0x033, 0x00000066,
+		0x03F, 0x00000CE8,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000068,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF1,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF4,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C10,
+		0x033, 0x00000063,
+		0x03F, 0x00000C4A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4D,
+		0x033, 0x00000065,
+		0x03F, 0x00000CC9,
+		0x033, 0x00000066,
+		0x03F, 0x00000CEB,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEE,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C8A,
+		0x033, 0x00000066,
+		0x03F, 0x00000CEA,
+		0x033, 0x00000067,
+		0x03F, 0x00000CED,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF0,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000067,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000068,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000429,
+		0x033, 0x00000061,
+		0x03F, 0x00000828,
+		0x033, 0x00000062,
+		0x03F, 0x00000847,
+		0x033, 0x00000063,
+		0x03F, 0x0000084A,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4B,
+		0x033, 0x00000065,
+		0x03F, 0x00000C6C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8D,
+		0x033, 0x00000067,
+		0x03F, 0x00000CAF,
+		0x033, 0x00000068,
+		0x03F, 0x00000CD1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF3,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF6,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x00000068,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x0000042C,
+		0x033, 0x00000061,
+		0x03F, 0x0000082B,
+		0x033, 0x00000062,
+		0x03F, 0x0000084A,
+		0x033, 0x00000063,
+		0x03F, 0x0000084D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4E,
+		0x033, 0x00000065,
+		0x03F, 0x00000C8C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8F,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEC,
+		0x033, 0x00000068,
+		0x03F, 0x00000CEF,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF5,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000005,
+		0x033, 0x00000061,
+		0x03F, 0x00000008,
+		0x033, 0x00000062,
+		0x03F, 0x0000000B,
+		0x033, 0x00000063,
+		0x03F, 0x0000000E,
+		0x033, 0x00000064,
+		0x03F, 0x0000002B,
+		0x033, 0x00000065,
+		0x03F, 0x00000068,
+		0x033, 0x00000066,
+		0x03F, 0x0000006B,
+		0x033, 0x00000067,
+		0x03F, 0x0000006E,
+		0x033, 0x00000068,
+		0x03F, 0x00000071,
+		0x033, 0x00000069,
+		0x03F, 0x00000074,
+		0x033, 0x0000006A,
+		0x03F, 0x00000077,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x0000042C,
+		0x033, 0x00000061,
+		0x03F, 0x0000082B,
+		0x033, 0x00000062,
+		0x03F, 0x0000084A,
+		0x033, 0x00000063,
+		0x03F, 0x0000084D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C4E,
+		0x033, 0x00000065,
+		0x03F, 0x00000C8C,
+		0x033, 0x00000066,
+		0x03F, 0x00000C8F,
+		0x033, 0x00000067,
+		0x03F, 0x00000CEC,
+		0x033, 0x00000068,
+		0x03F, 0x00000CEF,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF2,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF5,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000007,
+		0x033, 0x00000061,
+		0x03F, 0x0000000A,
+		0x033, 0x00000062,
+		0x03F, 0x0000000D,
+		0x033, 0x00000063,
+		0x03F, 0x0000002A,
+		0x033, 0x00000064,
+		0x03F, 0x0000002D,
+		0x033, 0x00000065,
+		0x03F, 0x00000030,
+		0x033, 0x00000066,
+		0x03F, 0x0000006D,
+		0x033, 0x00000067,
+		0x03F, 0x00000070,
+		0x033, 0x00000068,
+		0x03F, 0x000000ED,
+		0x033, 0x00000069,
+		0x03F, 0x000000F0,
+		0x033, 0x0000006A,
+		0x03F, 0x000000F3,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000060,
+		0x03F, 0x00000C0A,
+		0x033, 0x00000061,
+		0x03F, 0x00000C0D,
+		0x033, 0x00000062,
+		0x03F, 0x00000C2A,
+		0x033, 0x00000063,
+		0x03F, 0x00000C2D,
+		0x033, 0x00000064,
+		0x03F, 0x00000C6A,
+		0x033, 0x00000065,
+		0x03F, 0x00000CAA,
+		0x033, 0x00000066,
+		0x03F, 0x00000CAD,
+		0x033, 0x00000067,
+		0x03F, 0x00000CB0,
+		0x033, 0x00000068,
+		0x03F, 0x00000CF1,
+		0x033, 0x00000069,
+		0x03F, 0x00000CF4,
+		0x033, 0x0000006A,
+		0x03F, 0x00000CF7,
+	0xB0000000,	0x00000000,
+	0x83000000,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x93000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x93000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002B,
+		0x033, 0x000000A5,
+		0x03F, 0x0000002E,
+		0x033, 0x000000A6,
+		0x03F, 0x00000031,
+		0x033, 0x000000A7,
+		0x03F, 0x00000034,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x000000D1,
+	0x93000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAF,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CD1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002B,
+		0x033, 0x000000A5,
+		0x03F, 0x0000002E,
+		0x033, 0x000000A6,
+		0x03F, 0x00000031,
+		0x033, 0x000000A7,
+		0x03F, 0x00000034,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x000000D1,
+	0x93000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x0000042A,
+		0x033, 0x000000A1,
+		0x03F, 0x00000829,
+		0x033, 0x000000A2,
+		0x03F, 0x00000848,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084B,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4C,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CAC,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CED,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CF0,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x93000008,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000826,
+		0x033, 0x000000A1,
+		0x03F, 0x00000829,
+		0x033, 0x000000A2,
+		0x03F, 0x0000082C,
+		0x033, 0x000000A3,
+		0x03F, 0x0000082F,
+		0x033, 0x000000A4,
+		0x03F, 0x0000086C,
+		0x033, 0x000000A5,
+		0x03F, 0x00000CE8,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CEB,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEE,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CF1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF4,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF7,
+	0x93000009,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000a,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000CE5,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CE8,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEB,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEE,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF1,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF4,
+	0x9300000d,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x0000080A,
+		0x033, 0x000000A1,
+		0x03F, 0x0000080D,
+		0x033, 0x000000A2,
+		0x03F, 0x00000810,
+		0x033, 0x000000A3,
+		0x03F, 0x00000868,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C68,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6B,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CAB,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAE,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000e,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C08,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0B,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0E,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2B,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2E,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C31,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CAB,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAE,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000CEA,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CED,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CF0,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x93000010,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAF,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CD1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x93000011,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000429,
+		0x033, 0x000000A1,
+		0x03F, 0x00000828,
+		0x033, 0x000000A2,
+		0x03F, 0x00000847,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084A,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4B,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C6C,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CAF,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CD1,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF3,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF6,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x90000002,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x00000047,
+		0x033, 0x000000A5,
+		0x03F, 0x0000004A,
+		0x033, 0x000000A6,
+		0x03F, 0x0000004D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000050,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x00000094,
+	0x90000003,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x0000042A,
+		0x033, 0x000000A1,
+		0x03F, 0x00000829,
+		0x033, 0x000000A2,
+		0x03F, 0x00000848,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084B,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4C,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEC,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000005,
+		0x033, 0x000000A1,
+		0x03F, 0x00000008,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000B,
+		0x033, 0x000000A3,
+		0x03F, 0x0000000E,
+		0x033, 0x000000A4,
+		0x03F, 0x00000047,
+		0x033, 0x000000A5,
+		0x03F, 0x0000004A,
+		0x033, 0x000000A6,
+		0x03F, 0x0000004D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000050,
+		0x033, 0x000000A8,
+		0x03F, 0x00000053,
+		0x033, 0x000000A9,
+		0x03F, 0x00000056,
+		0x033, 0x000000AA,
+		0x03F, 0x00000094,
+	0x90000005,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x0000042A,
+		0x033, 0x000000A1,
+		0x03F, 0x00000829,
+		0x033, 0x000000A2,
+		0x03F, 0x00000848,
+		0x033, 0x000000A3,
+		0x03F, 0x0000084B,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C4C,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000CEC,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000007,
+		0x033, 0x000000A1,
+		0x03F, 0x0000000A,
+		0x033, 0x000000A2,
+		0x03F, 0x0000000D,
+		0x033, 0x000000A3,
+		0x03F, 0x0000002A,
+		0x033, 0x000000A4,
+		0x03F, 0x0000002D,
+		0x033, 0x000000A5,
+		0x03F, 0x00000030,
+		0x033, 0x000000A6,
+		0x03F, 0x0000006D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000070,
+		0x033, 0x000000A8,
+		0x03F, 0x000000ED,
+		0x033, 0x000000A9,
+		0x03F, 0x000000F0,
+		0x033, 0x000000AA,
+		0x03F, 0x000000F3,
+	0xA0000000,	0x00000000,
+		0x033, 0x000000A0,
+		0x03F, 0x00000C09,
+		0x033, 0x000000A1,
+		0x03F, 0x00000C0C,
+		0x033, 0x000000A2,
+		0x03F, 0x00000C0F,
+		0x033, 0x000000A3,
+		0x03F, 0x00000C2C,
+		0x033, 0x000000A4,
+		0x03F, 0x00000C2F,
+		0x033, 0x000000A5,
+		0x03F, 0x00000C8A,
+		0x033, 0x000000A6,
+		0x03F, 0x00000C8D,
+		0x033, 0x000000A7,
+		0x03F, 0x00000C90,
+		0x033, 0x000000A8,
+		0x03F, 0x00000CEF,
+		0x033, 0x000000A9,
+		0x03F, 0x00000CF2,
+		0x033, 0x000000AA,
+		0x03F, 0x00000CF5,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000400,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x000004FB,
+		0x033, 0x00000001,
+		0x03F, 0x000004FB,
+		0x033, 0x00000002,
+		0x03F, 0x000004FB,
+		0x033, 0x00000003,
+		0x03F, 0x000004FB,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0000265A,
+		0x033, 0x00000001,
+		0x03F, 0x0000265A,
+		0x033, 0x00000002,
+		0x03F, 0x0000265A,
+		0x033, 0x00000003,
+		0x03F, 0x0000265A,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x000004BB,
+		0x033, 0x00000001,
+		0x03F, 0x000004BB,
+		0x033, 0x00000002,
+		0x03F, 0x000004BB,
+		0x033, 0x00000003,
+		0x03F, 0x000004BB,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00000100,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000745,
+		0x033, 0x00000001,
+		0x03F, 0x00000745,
+		0x033, 0x00000002,
+		0x03F, 0x00000745,
+		0x033, 0x00000003,
+		0x03F, 0x00000745,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000F34,
+		0x033, 0x00000001,
+		0x03F, 0x00000F34,
+		0x033, 0x00000002,
+		0x03F, 0x00000F34,
+		0x033, 0x00000003,
+		0x03F, 0x00000F34,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x081, 0x0000F400,
+		0x087, 0x00016040,
+		0x051, 0x00000808,
+		0x052, 0x00098002,
+		0x053, 0x0000FA47,
+		0x054, 0x00058032,
+		0x056, 0x00051000,
+		0x057, 0x0000CE0A,
+		0x058, 0x00082030,
+	0xA0000000,	0x00000000,
+		0x081, 0x0000F000,
+		0x087, 0x00016040,
+		0x051, 0x00000C00,
+		0x052, 0x0007C241,
+		0x053, 0x0001C069,
+		0x054, 0x00078032,
+		0x057, 0x0000CE0A,
+		0x058, 0x00058750,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000800,
+	0x83000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x93000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000002,
+		0x033, 0x00000001,
+		0x03F, 0x00000005,
+		0x033, 0x00000002,
+		0x03F, 0x00000008,
+		0x033, 0x00000003,
+		0x03F, 0x0000000B,
+		0x033, 0x00000004,
+		0x03F, 0x0000000E,
+		0x033, 0x00000005,
+		0x03F, 0x0000002B,
+		0x033, 0x00000006,
+		0x03F, 0x0000002E,
+		0x033, 0x00000007,
+		0x03F, 0x00000031,
+		0x033, 0x00000008,
+		0x03F, 0x0000006E,
+		0x033, 0x00000009,
+		0x03F, 0x00000071,
+		0x033, 0x0000000A,
+		0x03F, 0x00000074,
+	0x93000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x93000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x9300000b,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x9300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0005142C,
+		0x033, 0x00000001,
+		0x03F, 0x0005142F,
+		0x033, 0x00000002,
+		0x03F, 0x00051432,
+		0x033, 0x00000003,
+		0x03F, 0x00051CA5,
+		0x033, 0x00000004,
+		0x03F, 0x00051CA8,
+		0x033, 0x00000005,
+		0x03F, 0x00051CAB,
+		0x033, 0x00000006,
+		0x03F, 0x00051CEB,
+		0x033, 0x00000007,
+		0x03F, 0x00051CEE,
+		0x033, 0x00000008,
+		0x03F, 0x00051CF1,
+		0x033, 0x00000009,
+		0x03F, 0x00051CF4,
+		0x033, 0x0000000A,
+		0x03F, 0x00051CF7,
+	0x9300000f,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0005142C,
+		0x033, 0x00000001,
+		0x03F, 0x0005144B,
+		0x033, 0x00000002,
+		0x03F, 0x00051868,
+		0x033, 0x00000003,
+		0x03F, 0x0005186B,
+		0x033, 0x00000004,
+		0x03F, 0x0005186E,
+		0x033, 0x00000005,
+		0x03F, 0x00051871,
+		0x033, 0x00000006,
+		0x03F, 0x00051874,
+		0x033, 0x00000007,
+		0x03F, 0x00051895,
+		0x033, 0x00000008,
+		0x03F, 0x000518B6,
+		0x033, 0x00000009,
+		0x03F, 0x000518F6,
+		0x033, 0x0000000A,
+		0x03F, 0x00051CF7,
+	0x90000001,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x90000004,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x90000006,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0x90000007,	0x00000000,	0x40000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x00000003,
+		0x033, 0x00000001,
+		0x03F, 0x00000006,
+		0x033, 0x00000002,
+		0x03F, 0x00000009,
+		0x033, 0x00000003,
+		0x03F, 0x00000026,
+		0x033, 0x00000004,
+		0x03F, 0x00000029,
+		0x033, 0x00000005,
+		0x03F, 0x0000002C,
+		0x033, 0x00000006,
+		0x03F, 0x0000002F,
+		0x033, 0x00000007,
+		0x03F, 0x00000033,
+		0x033, 0x00000008,
+		0x03F, 0x00000036,
+		0x033, 0x00000009,
+		0x03F, 0x00000039,
+		0x033, 0x0000000A,
+		0x03F, 0x0000003C,
+	0xA0000000,	0x00000000,
+		0x033, 0x00000000,
+		0x03F, 0x0005142C,
+		0x033, 0x00000001,
+		0x03F, 0x0005142F,
+		0x033, 0x00000002,
+		0x03F, 0x00051432,
+		0x033, 0x00000003,
+		0x03F, 0x00051C87,
+		0x033, 0x00000004,
+		0x03F, 0x00051C8A,
+		0x033, 0x00000005,
+		0x03F, 0x00051C8D,
+		0x033, 0x00000006,
+		0x03F, 0x00051CEB,
+		0x033, 0x00000007,
+		0x03F, 0x00051CEE,
+		0x033, 0x00000008,
+		0x03F, 0x00051CF1,
+		0x033, 0x00000009,
+		0x03F, 0x00051CF4,
+		0x033, 0x0000000A,
+		0x03F, 0x00051CF7,
+	0xB0000000,	0x00000000,
+	0x8300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x0EF, 0x00000000,
+	0xA0000000,	0x00000000,
+		0x0EF, 0x00000000,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000010,
+		0x033, 0x00000000,
+		0x008, 0x0009C060,
+		0x033, 0x00000001,
+		0x008, 0x0009C060,
+		0x0EF, 0x00000000,
+		0x033, 0x000000A2,
+		0x0EF, 0x00080000,
+		0x03E, 0x0000593F,
+	0x8300000c,	0x00000000,	0x40000000,	0x00000000,
+		0x03F, 0x000D0F4F,
+	0xA0000000,	0x00000000,
+		0x03F, 0x000C0F4F,
+	0xB0000000,	0x00000000,
+		0x0EF, 0x00000000,
+		0x033, 0x000000A3,
+		0x0EF, 0x00080000,
+		0x03E, 0x00005934,
+		0x03F, 0x0005AFCF,
+		0x0EF, 0x00000000,
+
+};
+
+void
+odm_read_and_config_mp_8822b_radiob(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8822b_radiob)/sizeof(u32);
+	u32	*array = array_mp_8822b_radiob;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_radiob\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_rf_radio_b_8822b(dm, v1, v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8822b_radiob(void)
+{
+		return 104;
+}
+
+/******************************************************************************
+*                           txpowertrack.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+	{0, 1, 2, 2, 3, 3, 4, 4, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 19, 19, 19, 19, 19},
+	{0, 1, 2, 2, 3, 4, 5, 6, 6, 7, 8, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 18, 18, 18, 18, 18},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 6, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 15, 15, 16, 16, 17, 17, 17, 17, 17, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 3, 4, 5, 6, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 15, 15, 15},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+	{0, 1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 20, 20, 20, 20},
+	{0, 1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 7, 8, 9, 9, 10, 11, 11, 12, 13, 14, 15, 16, 16, 17, 17, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 4, 5, 5, 6, 6, 7, 8, 8, 9, 10, 11, 12, 12, 13, 14, 15, 15, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type0.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type0_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type0_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 14, 15, 15, 15, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type0_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type0_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type0_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type0_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type0_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type0_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type0_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type0_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type0_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type0_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type0(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type0_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type1.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type1_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+	{0, 1, 2, 2, 3, 3, 4, 4, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type1_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 19, 19, 19, 19, 19},
+	{0, 1, 2, 2, 3, 4, 5, 6, 6, 7, 8, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 18, 18, 18, 18, 18},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 6, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 15, 15, 16, 16, 17, 17, 17, 17, 17, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type1_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 3, 4, 5, 6, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 15, 15, 15},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+	{0, 1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type1_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 20, 20, 20, 20},
+	{0, 1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 7, 8, 9, 9, 10, 11, 11, 12, 13, 14, 15, 16, 16, 17, 17, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 4, 5, 5, 6, 6, 7, 8, 8, 9, 10, 11, 12, 12, 13, 14, 15, 15, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type1_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type1_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type1_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type1_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type1_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type1_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type1_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type1_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type1(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type1_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type10.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type10_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type10_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 14, 15, 15, 15, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type10_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type10_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type10_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type10_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type10_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type10_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type10_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type10_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type10_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type10_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type10(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type10_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type11.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type11_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type11_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 14, 15, 15, 15, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type11_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type11_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type11_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type11_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type11_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type11_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type11_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type11_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type11_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type11_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type11(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type11_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type12.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type12_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type12_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type12_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type12_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type12_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type12_8822b[]    = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type12_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type12_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type12_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type12_8822b[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type12_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type12_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type12(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type12_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type13.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type13_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type13_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 14, 15, 15, 15, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type13_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type13_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type13_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type13_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type13_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type13_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type13_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type13_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type13_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type13_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type13(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type13_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type14.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type14_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type14_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 14, 15, 15, 15, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type14_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type14_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type14_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type14_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type14_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type14_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type14_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type14_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type14_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type14_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type14(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type14_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type15.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type15_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type15_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type15_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type15_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type15_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type15_8822b[]    = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type15_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type15_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type15_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type15_8822b[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type15_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type15_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type15(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type15_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type16.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type16_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type16_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type16_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type16_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type16_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type16_8822b[]    = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type16_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type16_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type16_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type16_8822b[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type16_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type16_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type16(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type16_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type17.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type17_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type17_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type17_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type17_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type17_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type17_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type17_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type17_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type17_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type17_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type17_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type17_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type17(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type17_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type2.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type2_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type2_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type2_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type2_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type2_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type2_8822b[]    = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type2_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type2_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type2_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type2_8822b[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type2_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type2_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type2(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type2_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type3_type5.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type3_type5_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type3_type5_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type3_type5_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type3_type5_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type3_type5_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type3_type5_8822b[]    = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type3_type5_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type3_type5_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type3_type5_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type3_type5_8822b[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type3_type5_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type3_type5_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type3_type5(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type3_type5_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type4.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type4_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type4_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type4_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 20, 20, 21, 22},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type4_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 23},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type4_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type4_8822b[]    = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type4_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type4_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type4_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type4_8822b[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type4_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type4_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type4(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type4_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type6.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type6_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 5, 6, 7, 7, 8, 9, 9, 10, 10, 11, 12, 12, 13, 14, 14, 15, 15, 16, 16, 16, 16, 16, 16, 16},
+	{0, 1, 2, 3, 4, 4, 5, 5, 6, 7, 8, 9, 10, 11, 12, 12, 13, 13, 14, 15, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type6_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 19, 19, 19, 19, 19},
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 9, 9, 11, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 20, 21, 21, 21, 21, 21, 21},
+	{0, 1, 2, 3, 4, 5, 6, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 20, 20, 21, 21, 21},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type6_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 3, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 12, 13, 14, 14, 15, 15, 16, 16, 16, 17, 17, 17, 17, 17},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 6, 7, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 14, 15, 15, 16, 16, 16, 16, 16, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type6_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 13, 14, 15, 15, 16, 17, 18, 19, 20, 20, 21, 21, 21, 21, 21},
+	{0, 1, 2, 2, 3, 4, 4, 5, 7, 7, 8, 9, 10, 11, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 19, 19, 20, 20, 21, 21},
+	{0, 1, 2, 3, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 19, 20, 20, 20, 20, 20},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type6_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type6_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type6_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type6_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type6_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type6_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type6_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type6_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type6(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type6_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type7.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type7_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 14, 14, 14, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 5, 6, 7, 7, 8, 9, 9, 10, 10, 11, 12, 12, 13, 14, 14, 15, 15, 16, 16, 16, 16, 16, 16, 16},
+	{0, 1, 2, 3, 4, 4, 5, 5, 6, 7, 8, 9, 10, 11, 12, 12, 13, 13, 14, 15, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type7_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10, 11, 11, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 19, 19, 19, 19, 19},
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 9, 9, 11, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 20, 21, 21, 21, 21, 21, 21},
+	{0, 1, 2, 3, 4, 5, 6, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 20, 20, 21, 21, 21},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type7_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 3, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 12, 13, 14, 14, 15, 15, 16, 16, 16, 17, 17, 17, 17, 17},
+	{0, 1, 2, 2, 3, 4, 5, 5, 6, 6, 7, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 14, 15, 15, 16, 16, 16, 16, 16, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type7_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 13, 14, 15, 15, 16, 17, 18, 19, 20, 20, 21, 21, 21, 21, 21},
+	{0, 1, 2, 2, 3, 4, 4, 5, 7, 7, 8, 9, 10, 11, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 19, 19, 20, 20, 21, 21},
+	{0, 1, 2, 3, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 14, 15, 16, 17, 17, 18, 19, 19, 20, 20, 20, 20, 20},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type7_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type7_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type7_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type7_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type7_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type7_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type7_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type7_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type7(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type7_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type8.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type8_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type8_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type8_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type8_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 16, 17},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type8_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type8_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type8_8822b[]    = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type8_8822b[]    = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type8_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type8_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type8_8822b[] = {0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 11, 12};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type8_8822b[] = {0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type8(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type8_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpowertrack_type9.TXT
+******************************************************************************/
+
+u8 delta_swingidx_mp_5gb_n_txpwrtrk_type9_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 15, 15},
+};
+u8 delta_swingidx_mp_5gb_p_txpwrtrk_type9_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 12, 13, 14, 14, 15, 15, 15, 16, 16},
+};
+u8 delta_swingidx_mp_5ga_n_txpwrtrk_type9_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14},
+};
+u8 delta_swingidx_mp_5ga_p_txpwrtrk_type9_8822b[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 13, 14, 14, 15, 15},
+	{0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 12, 13, 13, 14, 14, 15, 15, 15},
+};
+u8 delta_swingidx_mp_2gb_n_txpwrtrk_type9_8822b[]    = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2gb_p_txpwrtrk_type9_8822b[]    = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 17, 18, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2ga_n_txpwrtrk_type9_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2ga_p_txpwrtrk_type9_8822b[]    = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type9_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17};
+u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type9_8822b[] = {0, 1, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type9_8822b[] = {0, 1, 2, 3, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 15, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type9_8822b[] = {0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 22, 22};
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type9(
+	struct dm_struct	 *dm
+)
+{
+	struct dm_rf_calibration_struct  *cali_info = &dm->rf_calibrate_info;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822b\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, delta_swingidx_mp_2ga_p_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, delta_swingidx_mp_2ga_n_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, delta_swingidx_mp_2gb_p_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, delta_swingidx_mp_2gb_n_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, delta_swingidx_mp_2g_cck_a_p_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, delta_swingidx_mp_2g_cck_a_n_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, delta_swingidx_mp_2g_cck_b_p_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, delta_swingidx_mp_2g_cck_b_n_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, delta_swingidx_mp_5ga_p_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, delta_swingidx_mp_5ga_n_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, delta_swingidx_mp_5gb_p_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, delta_swingidx_mp_5gb_n_txpwrtrk_type9_8822b, DELTA_SWINGIDX_SIZE*3);
+}
+
+/******************************************************************************
+*                           txpwr_lmt.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "26",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"FCC", "5G", "20M", "HT", "1T", "40", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"FCC", "5G", "20M", "HT", "1T", "44", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"FCC", "5G", "20M", "HT", "1T", "48", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"FCC", "5G", "20M", "HT", "1T", "52", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"FCC", "5G", "20M", "HT", "1T", "56", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"FCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"FCC", "5G", "20M", "HT", "1T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"FCC", "5G", "20M", "HT", "1T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "104", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"FCC", "5G", "20M", "HT", "1T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"FCC", "5G", "20M", "HT", "2T", "40", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"FCC", "5G", "20M", "HT", "2T", "44", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"FCC", "5G", "20M", "HT", "2T", "48", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"FCC", "5G", "20M", "HT", "2T", "52", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"FCC", "5G", "20M", "HT", "2T", "56", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"FCC", "5G", "20M", "HT", "2T", "60", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"FCC", "5G", "20M", "HT", "2T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"FCC", "5G", "20M", "HT", "2T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "104", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"FCC", "5G", "20M", "HT", "2T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"FCC", "5G", "40M", "HT", "1T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"FCC", "5G", "40M", "HT", "1T", "102", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"FCC", "5G", "40M", "HT", "1T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "20",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"FCC", "5G", "40M", "HT", "2T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"FCC", "5G", "40M", "HT", "2T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"FCC", "5G", "40M", "HT", "2T", "62", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"FCC", "5G", "40M", "HT", "2T", "102", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"FCC", "5G", "40M", "HT", "2T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type12.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type12[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "26",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"FCC", "5G", "20M", "HT", "1T", "40", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"FCC", "5G", "20M", "HT", "1T", "44", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"FCC", "5G", "20M", "HT", "1T", "48", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"FCC", "5G", "20M", "HT", "1T", "52", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"FCC", "5G", "20M", "HT", "1T", "56", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"FCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"FCC", "5G", "20M", "HT", "1T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"FCC", "5G", "20M", "HT", "1T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "104", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"FCC", "5G", "20M", "HT", "1T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"FCC", "5G", "20M", "HT", "2T", "40", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"FCC", "5G", "20M", "HT", "2T", "44", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"FCC", "5G", "20M", "HT", "2T", "48", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"FCC", "5G", "20M", "HT", "2T", "52", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"FCC", "5G", "20M", "HT", "2T", "56", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"FCC", "5G", "20M", "HT", "2T", "60", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"FCC", "5G", "20M", "HT", "2T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"FCC", "5G", "20M", "HT", "2T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "104", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"FCC", "5G", "20M", "HT", "2T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"FCC", "5G", "40M", "HT", "1T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"FCC", "5G", "40M", "HT", "1T", "102", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"FCC", "5G", "40M", "HT", "1T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "20",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"FCC", "5G", "40M", "HT", "2T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"FCC", "5G", "40M", "HT", "2T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"FCC", "5G", "40M", "HT", "2T", "62", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"FCC", "5G", "40M", "HT", "2T", "102", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"FCC", "5G", "40M", "HT", "2T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type12(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type12)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type12;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type12)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type12;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type12\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type15.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type15[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "26",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"FCC", "5G", "20M", "HT", "1T", "40", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"FCC", "5G", "20M", "HT", "1T", "44", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"FCC", "5G", "20M", "HT", "1T", "48", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"FCC", "5G", "20M", "HT", "1T", "52", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"FCC", "5G", "20M", "HT", "1T", "56", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"FCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"FCC", "5G", "20M", "HT", "1T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"FCC", "5G", "20M", "HT", "1T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "104", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"FCC", "5G", "20M", "HT", "1T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"FCC", "5G", "20M", "HT", "2T", "40", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"FCC", "5G", "20M", "HT", "2T", "44", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"FCC", "5G", "20M", "HT", "2T", "48", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"FCC", "5G", "20M", "HT", "2T", "52", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"FCC", "5G", "20M", "HT", "2T", "56", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"FCC", "5G", "20M", "HT", "2T", "60", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"FCC", "5G", "20M", "HT", "2T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"FCC", "5G", "20M", "HT", "2T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "104", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"FCC", "5G", "20M", "HT", "2T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"FCC", "5G", "40M", "HT", "1T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"FCC", "5G", "40M", "HT", "1T", "102", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"FCC", "5G", "40M", "HT", "1T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "20",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"FCC", "5G", "40M", "HT", "2T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"FCC", "5G", "40M", "HT", "2T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"FCC", "5G", "40M", "HT", "2T", "62", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"FCC", "5G", "40M", "HT", "2T", "102", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"FCC", "5G", "40M", "HT", "2T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type15(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type15)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type15;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type15)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type15;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type15\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type16.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type16[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "26",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"FCC", "5G", "20M", "HT", "1T", "40", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"FCC", "5G", "20M", "HT", "1T", "44", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"FCC", "5G", "20M", "HT", "1T", "48", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"FCC", "5G", "20M", "HT", "1T", "52", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"FCC", "5G", "20M", "HT", "1T", "56", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"FCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"FCC", "5G", "20M", "HT", "1T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"FCC", "5G", "20M", "HT", "1T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "104", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"FCC", "5G", "20M", "HT", "1T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"FCC", "5G", "20M", "HT", "2T", "40", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"FCC", "5G", "20M", "HT", "2T", "44", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"FCC", "5G", "20M", "HT", "2T", "48", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"FCC", "5G", "20M", "HT", "2T", "52", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"FCC", "5G", "20M", "HT", "2T", "56", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"FCC", "5G", "20M", "HT", "2T", "60", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"FCC", "5G", "20M", "HT", "2T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"FCC", "5G", "20M", "HT", "2T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "104", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"FCC", "5G", "20M", "HT", "2T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"FCC", "5G", "40M", "HT", "1T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"FCC", "5G", "40M", "HT", "1T", "102", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"FCC", "5G", "40M", "HT", "1T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "20",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"FCC", "5G", "40M", "HT", "2T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"FCC", "5G", "40M", "HT", "2T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"FCC", "5G", "40M", "HT", "2T", "62", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"FCC", "5G", "40M", "HT", "2T", "102", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"FCC", "5G", "40M", "HT", "2T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type16(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type16)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type16;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type16)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type16;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type16\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type17.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type17[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "31",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "01", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "31",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "02", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "31",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "03", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "31",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "04", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "05", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "06", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "07", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "08", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "37",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "09", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "37",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "10", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "37",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "11", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "29",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"KCC", "2.4G", "20M", "CCK", "1T", "12", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "24",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"KCC", "2.4G", "20M", "CCK", "1T", "13", "35",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "31",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "01", "35",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "31",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "02", "35",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "31",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "03", "35",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "31",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "27",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "27",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "27",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "-1",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "31",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "31",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "31",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "31",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "25",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "-5",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"KCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "01", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "02", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "03", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "04", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "25",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "08", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "26",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "09", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "25",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "10", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "25",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "11", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "25",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "12", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "-5",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "25",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "13", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"KCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "21",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "21",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "21",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "21",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "21",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "21",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "21",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "-2",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "29",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"KCC", "2.4G", "40M", "HT", "1T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "21",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "03", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "21",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "04", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "21",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "05", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "21",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "21",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "07", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "21",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "08", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "21",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "09", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "10", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "-2",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"KCC", "2.4G", "40M", "HT", "2T", "11", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "20",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "26",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "36", "29",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "21",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "27",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "40", "29",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "20",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "27",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "44", "29",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "20",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "27",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "48", "29",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "21",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "20",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"KCC", "5G", "20M", "OFDM", "1T", "52", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "21",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "20",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"KCC", "5G", "20M", "OFDM", "1T", "56", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "24",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "20",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"KCC", "5G", "20M", "OFDM", "1T", "60", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "24",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "20",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"KCC", "5G", "20M", "OFDM", "1T", "64", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "112", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "116", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "120", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "124", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "25",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "128", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "21",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "132", "29",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "21",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "136", "29",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "21",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "19",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "140", "29",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "21",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "10",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"KCC", "5G", "20M", "OFDM", "1T", "144", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "24",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "10",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"KCC", "5G", "20M", "OFDM", "1T", "149", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "23",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "10",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"KCC", "5G", "20M", "OFDM", "1T", "153", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "23",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "11",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"KCC", "5G", "20M", "OFDM", "1T", "157", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "22",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "11",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"KCC", "5G", "20M", "OFDM", "1T", "161", "31",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "22",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "11",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"KCC", "5G", "20M", "OFDM", "1T", "165", "31",
+	"FCC", "5G", "20M", "HT", "1T", "36", "20",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "24",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"KCC", "5G", "20M", "HT", "1T", "36", "27",
+	"FCC", "5G", "20M", "HT", "1T", "40", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "24",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"KCC", "5G", "20M", "HT", "1T", "40", "27",
+	"FCC", "5G", "20M", "HT", "1T", "44", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "24",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"KCC", "5G", "20M", "HT", "1T", "44", "27",
+	"FCC", "5G", "20M", "HT", "1T", "48", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "24",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"KCC", "5G", "20M", "HT", "1T", "48", "27",
+	"FCC", "5G", "20M", "HT", "1T", "52", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "17",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"KCC", "5G", "20M", "HT", "1T", "52", "27",
+	"FCC", "5G", "20M", "HT", "1T", "56", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "17",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"KCC", "5G", "20M", "HT", "1T", "56", "27",
+	"FCC", "5G", "20M", "HT", "1T", "60", "24",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "17",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"KCC", "5G", "20M", "HT", "1T", "60", "27",
+	"FCC", "5G", "20M", "HT", "1T", "64", "24",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "17",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"KCC", "5G", "20M", "HT", "1T", "64", "26",
+	"FCC", "5G", "20M", "HT", "1T", "100", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "19",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"KCC", "5G", "20M", "HT", "1T", "100", "28",
+	"FCC", "5G", "20M", "HT", "1T", "104", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "19",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"KCC", "5G", "20M", "HT", "1T", "104", "28",
+	"FCC", "5G", "20M", "HT", "1T", "108", "27",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "19",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"KCC", "5G", "20M", "HT", "1T", "108", "28",
+	"FCC", "5G", "20M", "HT", "1T", "112", "27",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "19",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"KCC", "5G", "20M", "HT", "1T", "112", "27",
+	"FCC", "5G", "20M", "HT", "1T", "116", "27",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "19",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"KCC", "5G", "20M", "HT", "1T", "116", "27",
+	"FCC", "5G", "20M", "HT", "1T", "120", "27",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "19",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"KCC", "5G", "20M", "HT", "1T", "120", "27",
+	"FCC", "5G", "20M", "HT", "1T", "124", "27",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "19",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"KCC", "5G", "20M", "HT", "1T", "124", "27",
+	"FCC", "5G", "20M", "HT", "1T", "128", "27",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "19",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"KCC", "5G", "20M", "HT", "1T", "128", "27",
+	"FCC", "5G", "20M", "HT", "1T", "132", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "19",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"KCC", "5G", "20M", "HT", "1T", "132", "25",
+	"FCC", "5G", "20M", "HT", "1T", "136", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "18",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"KCC", "5G", "20M", "HT", "1T", "136", "25",
+	"FCC", "5G", "20M", "HT", "1T", "140", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "17",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"KCC", "5G", "20M", "HT", "1T", "140", "25",
+	"FCC", "5G", "20M", "HT", "1T", "144", "21",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "8",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"KCC", "5G", "20M", "HT", "1T", "144", "28",
+	"FCC", "5G", "20M", "HT", "1T", "149", "25",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "8",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"KCC", "5G", "20M", "HT", "1T", "149", "28",
+	"FCC", "5G", "20M", "HT", "1T", "153", "25",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "8",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"KCC", "5G", "20M", "HT", "1T", "153", "28",
+	"FCC", "5G", "20M", "HT", "1T", "157", "25",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "10",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"KCC", "5G", "20M", "HT", "1T", "157", "28",
+	"FCC", "5G", "20M", "HT", "1T", "161", "24",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "10",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"KCC", "5G", "20M", "HT", "1T", "161", "27",
+	"FCC", "5G", "20M", "HT", "1T", "165", "24",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "10",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"KCC", "5G", "20M", "HT", "1T", "165", "27",
+	"FCC", "5G", "20M", "HT", "2T", "36", "18",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "21",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"KCC", "5G", "20M", "HT", "2T", "36", "25",
+	"FCC", "5G", "20M", "HT", "2T", "40", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "24",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"KCC", "5G", "20M", "HT", "2T", "40", "24",
+	"FCC", "5G", "20M", "HT", "2T", "44", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "24",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"KCC", "5G", "20M", "HT", "2T", "44", "24",
+	"FCC", "5G", "20M", "HT", "2T", "48", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "24",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"KCC", "5G", "20M", "HT", "2T", "48", "24",
+	"FCC", "5G", "20M", "HT", "2T", "52", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "17",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"KCC", "5G", "20M", "HT", "2T", "52", "28",
+	"FCC", "5G", "20M", "HT", "2T", "56", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "17",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"KCC", "5G", "20M", "HT", "2T", "56", "27",
+	"FCC", "5G", "20M", "HT", "2T", "60", "24",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "17",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"KCC", "5G", "20M", "HT", "2T", "60", "27",
+	"FCC", "5G", "20M", "HT", "2T", "64", "24",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "17",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"KCC", "5G", "20M", "HT", "2T", "64", "27",
+	"FCC", "5G", "20M", "HT", "2T", "100", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "19",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"KCC", "5G", "20M", "HT", "2T", "100", "27",
+	"FCC", "5G", "20M", "HT", "2T", "104", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "19",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"KCC", "5G", "20M", "HT", "2T", "104", "27",
+	"FCC", "5G", "20M", "HT", "2T", "108", "27",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "19",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"KCC", "5G", "20M", "HT", "2T", "108", "27",
+	"FCC", "5G", "20M", "HT", "2T", "112", "27",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "19",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"KCC", "5G", "20M", "HT", "2T", "112", "26",
+	"FCC", "5G", "20M", "HT", "2T", "116", "27",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "19",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"KCC", "5G", "20M", "HT", "2T", "116", "26",
+	"FCC", "5G", "20M", "HT", "2T", "120", "27",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "19",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"KCC", "5G", "20M", "HT", "2T", "120", "26",
+	"FCC", "5G", "20M", "HT", "2T", "124", "27",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "19",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"KCC", "5G", "20M", "HT", "2T", "124", "26",
+	"FCC", "5G", "20M", "HT", "2T", "128", "27",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "19",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"KCC", "5G", "20M", "HT", "2T", "128", "26",
+	"FCC", "5G", "20M", "HT", "2T", "132", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "19",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"KCC", "5G", "20M", "HT", "2T", "132", "26",
+	"FCC", "5G", "20M", "HT", "2T", "136", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "18",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"KCC", "5G", "20M", "HT", "2T", "136", "26",
+	"FCC", "5G", "20M", "HT", "2T", "140", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "17",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"KCC", "5G", "20M", "HT", "2T", "140", "26",
+	"FCC", "5G", "20M", "HT", "2T", "144", "21",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "8",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"KCC", "5G", "20M", "HT", "2T", "144", "26",
+	"FCC", "5G", "20M", "HT", "2T", "149", "25",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "8",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"KCC", "5G", "20M", "HT", "2T", "149", "26",
+	"FCC", "5G", "20M", "HT", "2T", "153", "25",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "8",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"KCC", "5G", "20M", "HT", "2T", "153", "26",
+	"FCC", "5G", "20M", "HT", "2T", "157", "25",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "10",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"KCC", "5G", "20M", "HT", "2T", "157", "26",
+	"FCC", "5G", "20M", "HT", "2T", "161", "24",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "10",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"KCC", "5G", "20M", "HT", "2T", "161", "26",
+	"FCC", "5G", "20M", "HT", "2T", "165", "24",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "10",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"KCC", "5G", "20M", "HT", "2T", "165", "26",
+	"FCC", "5G", "40M", "HT", "1T", "38", "19",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "26",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"KCC", "5G", "40M", "HT", "1T", "38", "27",
+	"FCC", "5G", "40M", "HT", "1T", "46", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "26",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"KCC", "5G", "40M", "HT", "1T", "46", "27",
+	"FCC", "5G", "40M", "HT", "1T", "54", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "18",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"KCC", "5G", "40M", "HT", "1T", "54", "28",
+	"FCC", "5G", "40M", "HT", "1T", "62", "20",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "18",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"KCC", "5G", "40M", "HT", "1T", "62", "28",
+	"FCC", "5G", "40M", "HT", "1T", "102", "15",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "20",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"KCC", "5G", "40M", "HT", "1T", "102", "28",
+	"FCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "20",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"KCC", "5G", "40M", "HT", "1T", "110", "26",
+	"FCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "20",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"KCC", "5G", "40M", "HT", "1T", "118", "26",
+	"FCC", "5G", "40M", "HT", "1T", "126", "28",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "20",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"KCC", "5G", "40M", "HT", "1T", "126", "25",
+	"FCC", "5G", "40M", "HT", "1T", "134", "28",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "19",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"KCC", "5G", "40M", "HT", "1T", "134", "25",
+	"FCC", "5G", "40M", "HT", "1T", "142", "28",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "9",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"KCC", "5G", "40M", "HT", "1T", "142", "25",
+	"FCC", "5G", "40M", "HT", "1T", "151", "29",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "9",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"KCC", "5G", "40M", "HT", "1T", "151", "27",
+	"FCC", "5G", "40M", "HT", "1T", "159", "29",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "10",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"KCC", "5G", "40M", "HT", "1T", "159", "26",
+	"FCC", "5G", "40M", "HT", "2T", "38", "19",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "24",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"KCC", "5G", "40M", "HT", "2T", "38", "25",
+	"FCC", "5G", "40M", "HT", "2T", "46", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "26",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"KCC", "5G", "40M", "HT", "2T", "46", "25",
+	"FCC", "5G", "40M", "HT", "2T", "54", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "18",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"KCC", "5G", "40M", "HT", "2T", "54", "26",
+	"FCC", "5G", "40M", "HT", "2T", "62", "20",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "18",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"KCC", "5G", "40M", "HT", "2T", "62", "26",
+	"FCC", "5G", "40M", "HT", "2T", "102", "15",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"KCC", "5G", "40M", "HT", "2T", "102", "27",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"KCC", "5G", "40M", "HT", "2T", "110", "25",
+	"FCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"KCC", "5G", "40M", "HT", "2T", "118", "25",
+	"FCC", "5G", "40M", "HT", "2T", "126", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"KCC", "5G", "40M", "HT", "2T", "126", "24",
+	"FCC", "5G", "40M", "HT", "2T", "134", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "19",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"KCC", "5G", "40M", "HT", "2T", "134", "24",
+	"FCC", "5G", "40M", "HT", "2T", "142", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "9",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"KCC", "5G", "40M", "HT", "2T", "142", "24",
+	"FCC", "5G", "40M", "HT", "2T", "151", "29",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "9",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"KCC", "5G", "40M", "HT", "2T", "151", "25",
+	"FCC", "5G", "40M", "HT", "2T", "159", "29",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "10",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"KCC", "5G", "40M", "HT", "2T", "159", "24",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "17",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "26",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"KCC", "5G", "80M", "VHT", "1T", "42", "26",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"KCC", "5G", "80M", "VHT", "1T", "58", "25",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "16",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "21",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"KCC", "5G", "80M", "VHT", "1T", "106", "26",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "16",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "17",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"KCC", "5G", "80M", "VHT", "1T", "122", "24",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "29",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "17",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"KCC", "5G", "80M", "VHT", "1T", "138", "25",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "28",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "9",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"KCC", "5G", "80M", "VHT", "1T", "155", "25",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "17",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "23",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"KCC", "5G", "80M", "VHT", "2T", "42", "23",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"KCC", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "16",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "21",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"KCC", "5G", "80M", "VHT", "2T", "106", "26",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "16",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "17",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"KCC", "5G", "80M", "VHT", "2T", "122", "24",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "29",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "17",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"KCC", "5G", "80M", "VHT", "2T", "138", "24",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "28",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "9",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63",
+	"KCC", "5G", "80M", "VHT", "2T", "155", "24"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type17(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type17)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type17;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type17)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type17;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type17\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type2.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type2[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "36",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "36",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"FCC", "5G", "20M", "HT", "1T", "40", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"FCC", "5G", "20M", "HT", "1T", "44", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"FCC", "5G", "20M", "HT", "1T", "48", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"FCC", "5G", "20M", "HT", "1T", "52", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"FCC", "5G", "20M", "HT", "1T", "56", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"FCC", "5G", "20M", "HT", "1T", "60", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"FCC", "5G", "20M", "HT", "1T", "64", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"FCC", "5G", "20M", "HT", "1T", "100", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "104", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"FCC", "5G", "20M", "HT", "1T", "149", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"FCC", "5G", "20M", "HT", "2T", "40", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"FCC", "5G", "20M", "HT", "2T", "44", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"FCC", "5G", "20M", "HT", "2T", "48", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"FCC", "5G", "20M", "HT", "2T", "52", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"FCC", "5G", "20M", "HT", "2T", "56", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"FCC", "5G", "20M", "HT", "2T", "60", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"FCC", "5G", "20M", "HT", "2T", "64", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"FCC", "5G", "20M", "HT", "2T", "100", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "104", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"FCC", "5G", "20M", "HT", "2T", "149", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "28",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"FCC", "5G", "40M", "HT", "1T", "46", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"FCC", "5G", "40M", "HT", "1T", "102", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"FCC", "5G", "40M", "HT", "1T", "151", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "26",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"FCC", "5G", "40M", "HT", "2T", "46", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"FCC", "5G", "40M", "HT", "2T", "54", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"FCC", "5G", "40M", "HT", "2T", "62", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"FCC", "5G", "40M", "HT", "2T", "102", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"FCC", "5G", "40M", "HT", "2T", "151", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "26",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "26",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "26",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "36",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "36",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "36",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "24",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "24",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "26",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "36",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "36",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "36",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type2(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type2)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type2;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type2)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type2;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type2\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type3.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type3[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "26",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"FCC", "5G", "20M", "HT", "1T", "40", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"FCC", "5G", "20M", "HT", "1T", "44", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"FCC", "5G", "20M", "HT", "1T", "48", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"FCC", "5G", "20M", "HT", "1T", "52", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"FCC", "5G", "20M", "HT", "1T", "56", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"FCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"FCC", "5G", "20M", "HT", "1T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"FCC", "5G", "20M", "HT", "1T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "104", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"FCC", "5G", "20M", "HT", "1T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"FCC", "5G", "20M", "HT", "2T", "40", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"FCC", "5G", "20M", "HT", "2T", "44", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"FCC", "5G", "20M", "HT", "2T", "48", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"FCC", "5G", "20M", "HT", "2T", "52", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"FCC", "5G", "20M", "HT", "2T", "56", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"FCC", "5G", "20M", "HT", "2T", "60", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"FCC", "5G", "20M", "HT", "2T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"FCC", "5G", "20M", "HT", "2T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "104", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"FCC", "5G", "20M", "HT", "2T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"FCC", "5G", "40M", "HT", "1T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"FCC", "5G", "40M", "HT", "1T", "102", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"FCC", "5G", "40M", "HT", "1T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "20",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"FCC", "5G", "40M", "HT", "2T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"FCC", "5G", "40M", "HT", "2T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"FCC", "5G", "40M", "HT", "2T", "62", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"FCC", "5G", "40M", "HT", "2T", "102", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"FCC", "5G", "40M", "HT", "2T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type3(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type3)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type3;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type3)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type3;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type3\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type4.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type4[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "38",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "36",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "38",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "40",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "40",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "40",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "40",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "40",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "38",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "36",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "36",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "38",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "40",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "40",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "40",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "40",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "40",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "38",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "36",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "34",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "36",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "36",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "38",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "38",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "38",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "36",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "36",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "34",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "36",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "38",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "36",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "34",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "32",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "32",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "36",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "38",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "36",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"FCC", "5G", "20M", "HT", "1T", "40", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"FCC", "5G", "20M", "HT", "1T", "44", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"FCC", "5G", "20M", "HT", "1T", "48", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"FCC", "5G", "20M", "HT", "1T", "52", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"FCC", "5G", "20M", "HT", "1T", "56", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"FCC", "5G", "20M", "HT", "1T", "60", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"FCC", "5G", "20M", "HT", "1T", "64", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"FCC", "5G", "20M", "HT", "1T", "100", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "104", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"FCC", "5G", "20M", "HT", "1T", "149", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "38",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"FCC", "5G", "20M", "HT", "2T", "40", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"FCC", "5G", "20M", "HT", "2T", "44", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"FCC", "5G", "20M", "HT", "2T", "48", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"FCC", "5G", "20M", "HT", "2T", "52", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"FCC", "5G", "20M", "HT", "2T", "56", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"FCC", "5G", "20M", "HT", "2T", "60", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"FCC", "5G", "20M", "HT", "2T", "64", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"FCC", "5G", "20M", "HT", "2T", "100", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "104", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "36",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"FCC", "5G", "20M", "HT", "2T", "149", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "38",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "28",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"FCC", "5G", "40M", "HT", "1T", "46", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"FCC", "5G", "40M", "HT", "1T", "102", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"FCC", "5G", "40M", "HT", "1T", "151", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "36",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "26",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"FCC", "5G", "40M", "HT", "2T", "46", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"FCC", "5G", "40M", "HT", "2T", "54", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"FCC", "5G", "40M", "HT", "2T", "62", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"FCC", "5G", "40M", "HT", "2T", "102", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"FCC", "5G", "40M", "HT", "2T", "151", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "36",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "26",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "26",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "26",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "36",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "36",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "36",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "24",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "24",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "26",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "36",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "36",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "36",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type4(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type4)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type4;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type4)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type4;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type4\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+/******************************************************************************
+*                           txpwr_lmt_type5.TXT
+******************************************************************************/
+
+const char *array_mp_8822b_txpwr_lmt_type5[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "01", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "01", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "02", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "02", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "03", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "03", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "04", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "04", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "05", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "05", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "06", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "06", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "07", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "07", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "08", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "08", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "09", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "09", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "10", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "10", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"KCC", "2.4G", "20M", "CCK", "1T", "11", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "11", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"IC", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"KCC", "2.4G", "20M", "CCK", "1T", "12", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "12", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"IC", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"KCC", "2.4G", "20M", "CCK", "1T", "13", "34",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "13", "28",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "13", "20",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"IC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"KCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ACMA", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"CHILE", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "01", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "01", "26",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "02", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "03", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "03", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "09", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "09", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "10", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "11", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "12", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "12", "22",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"IC", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "13", "34",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "13", "14",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"IC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"KCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ACMA", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"CHILE", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "01", "26",
+	"KCC", "2.4G", "20M", "HT", "1T", "01", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "01", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "01", "26",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "02", "30",
+	"KCC", "2.4G", "20M", "HT", "1T", "02", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "02", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "03", "32",
+	"KCC", "2.4G", "20M", "HT", "1T", "03", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "03", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "03", "32",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "04", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "04", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "04", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "05", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "05", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "05", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "06", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "06", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "06", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "07", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "07", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "07", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"KCC", "2.4G", "20M", "HT", "1T", "08", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "08", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "08", "34",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "09", "32",
+	"KCC", "2.4G", "20M", "HT", "1T", "09", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "09", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "09", "32",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "10", "30",
+	"KCC", "2.4G", "20M", "HT", "1T", "10", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "10", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "11", "26",
+	"KCC", "2.4G", "20M", "HT", "1T", "11", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "11", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "11", "26",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "12", "20",
+	"KCC", "2.4G", "20M", "HT", "1T", "12", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "12", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "12", "20",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "34",
+	"IC", "2.4G", "20M", "HT", "1T", "13", "14",
+	"KCC", "2.4G", "20M", "HT", "1T", "13", "34",
+	"ACMA", "2.4G", "20M", "HT", "1T", "13", "30",
+	"CHILE", "2.4G", "20M", "HT", "1T", "13", "14",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"IC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"KCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ACMA", "2.4G", "20M", "HT", "1T", "14", "63",
+	"CHILE", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "01", "26",
+	"KCC", "2.4G", "20M", "HT", "2T", "01", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "01", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "01", "26",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"KCC", "2.4G", "20M", "HT", "2T", "02", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "02", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "02", "28",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "03", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "03", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "04", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "04", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "05", "32",
+	"KCC", "2.4G", "20M", "HT", "2T", "05", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "05", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "05", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "06", "32",
+	"KCC", "2.4G", "20M", "HT", "2T", "06", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "06", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "06", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "07", "32",
+	"KCC", "2.4G", "20M", "HT", "2T", "07", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "07", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "07", "32",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "08", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "08", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "09", "30",
+	"KCC", "2.4G", "20M", "HT", "2T", "09", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "09", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"KCC", "2.4G", "20M", "HT", "2T", "10", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "10", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "10", "28",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "11", "26",
+	"KCC", "2.4G", "20M", "HT", "2T", "11", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "11", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "11", "26",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "12", "20",
+	"KCC", "2.4G", "20M", "HT", "2T", "12", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "12", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "12", "20",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "18",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"IC", "2.4G", "20M", "HT", "2T", "13", "14",
+	"KCC", "2.4G", "20M", "HT", "2T", "13", "34",
+	"ACMA", "2.4G", "20M", "HT", "2T", "13", "18",
+	"CHILE", "2.4G", "20M", "HT", "2T", "13", "14",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"IC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"KCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ACMA", "2.4G", "20M", "HT", "2T", "14", "63",
+	"CHILE", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"IC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ACMA", "2.4G", "40M", "HT", "1T", "01", "63",
+	"CHILE", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"IC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ACMA", "2.4G", "40M", "HT", "1T", "02", "63",
+	"CHILE", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"KCC", "2.4G", "40M", "HT", "1T", "03", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "03", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "03", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"KCC", "2.4G", "40M", "HT", "1T", "04", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "04", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "04", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "05", "30",
+	"KCC", "2.4G", "40M", "HT", "1T", "05", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "05", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "05", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "06", "32",
+	"KCC", "2.4G", "40M", "HT", "1T", "06", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "06", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "06", "32",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "07", "30",
+	"KCC", "2.4G", "40M", "HT", "1T", "07", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "07", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "07", "30",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"KCC", "2.4G", "40M", "HT", "1T", "08", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "08", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "08", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"KCC", "2.4G", "40M", "HT", "1T", "09", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "09", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "09", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "10", "20",
+	"KCC", "2.4G", "40M", "HT", "1T", "10", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "10", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "10", "20",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "34",
+	"IC", "2.4G", "40M", "HT", "1T", "11", "14",
+	"KCC", "2.4G", "40M", "HT", "1T", "11", "34",
+	"ACMA", "2.4G", "40M", "HT", "1T", "11", "30",
+	"CHILE", "2.4G", "40M", "HT", "1T", "11", "14",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "63",
+	"IC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ACMA", "2.4G", "40M", "HT", "1T", "12", "63",
+	"CHILE", "2.4G", "40M", "HT", "1T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "63",
+	"IC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ACMA", "2.4G", "40M", "HT", "1T", "13", "63",
+	"CHILE", "2.4G", "40M", "HT", "1T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"IC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"KCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ACMA", "2.4G", "40M", "HT", "1T", "14", "63",
+	"CHILE", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"IC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ACMA", "2.4G", "40M", "HT", "2T", "01", "63",
+	"CHILE", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"IC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ACMA", "2.4G", "40M", "HT", "2T", "02", "63",
+	"CHILE", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "03", "24",
+	"KCC", "2.4G", "40M", "HT", "2T", "03", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "03", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "03", "24",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "04", "24",
+	"KCC", "2.4G", "40M", "HT", "2T", "04", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "04", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "04", "24",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"KCC", "2.4G", "40M", "HT", "2T", "05", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "05", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "05", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "06", "28",
+	"KCC", "2.4G", "40M", "HT", "2T", "06", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "06", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "06", "28",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"KCC", "2.4G", "40M", "HT", "2T", "07", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "07", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "07", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"KCC", "2.4G", "40M", "HT", "2T", "08", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "08", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "08", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"KCC", "2.4G", "40M", "HT", "2T", "09", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "09", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "09", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "10", "20",
+	"KCC", "2.4G", "40M", "HT", "2T", "10", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "10", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "10", "20",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "18",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "30",
+	"IC", "2.4G", "40M", "HT", "2T", "11", "14",
+	"KCC", "2.4G", "40M", "HT", "2T", "11", "34",
+	"ACMA", "2.4G", "40M", "HT", "2T", "11", "18",
+	"CHILE", "2.4G", "40M", "HT", "2T", "11", "14",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "63",
+	"IC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ACMA", "2.4G", "40M", "HT", "2T", "12", "63",
+	"CHILE", "2.4G", "40M", "HT", "2T", "12", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "63",
+	"IC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ACMA", "2.4G", "40M", "HT", "2T", "13", "63",
+	"CHILE", "2.4G", "40M", "HT", "2T", "13", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"IC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"KCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ACMA", "2.4G", "40M", "HT", "2T", "14", "63",
+	"CHILE", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "30",
+	"IC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "36", "18",
+	"ACMA", "5G", "20M", "OFDM", "1T", "36", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "36", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "30",
+	"IC", "5G", "20M", "OFDM", "1T", "40", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "40", "24",
+	"ACMA", "5G", "20M", "OFDM", "1T", "40", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "40", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "30",
+	"IC", "5G", "20M", "OFDM", "1T", "44", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "44", "24",
+	"ACMA", "5G", "20M", "OFDM", "1T", "44", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "44", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "30",
+	"IC", "5G", "20M", "OFDM", "1T", "48", "30",
+	"KCC", "5G", "20M", "OFDM", "1T", "48", "18",
+	"ACMA", "5G", "20M", "OFDM", "1T", "48", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "48", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "28",
+	"IC", "5G", "20M", "OFDM", "1T", "52", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "52", "10",
+	"ACMA", "5G", "20M", "OFDM", "1T", "52", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "52", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "28",
+	"IC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "56", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "56", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "56", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "28",
+	"IC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "60", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "60", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "28",
+	"IC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"KCC", "5G", "20M", "OFDM", "1T", "64", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "64", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "64", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "26",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "100", "26",
+	"KCC", "5G", "20M", "OFDM", "1T", "100", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "100", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "100", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "104", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "104", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "104", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "104", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "104", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "108", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "108", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "112", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "112", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "112", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "116", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "116", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "116", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "120", "-63",
+	"KCC", "5G", "20M", "OFDM", "1T", "120", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "120", "-63",
+	"CHILE", "5G", "20M", "OFDM", "1T", "120", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "124", "-63",
+	"KCC", "5G", "20M", "OFDM", "1T", "124", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "124", "-63",
+	"CHILE", "5G", "20M", "OFDM", "1T", "124", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "128", "-63",
+	"KCC", "5G", "20M", "OFDM", "1T", "128", "-63",
+	"ACMA", "5G", "20M", "OFDM", "1T", "128", "-63",
+	"CHILE", "5G", "20M", "OFDM", "1T", "128", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "132", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "132", "-63",
+	"ACMA", "5G", "20M", "OFDM", "1T", "132", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "132", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "136", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "136", "-63",
+	"ACMA", "5G", "20M", "OFDM", "1T", "136", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "136", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"IC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"KCC", "5G", "20M", "OFDM", "1T", "140", "-63",
+	"ACMA", "5G", "20M", "OFDM", "1T", "140", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "140", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "144", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "144", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "144", "63",
+	"IC", "5G", "20M", "OFDM", "1T", "144", "28",
+	"KCC", "5G", "20M", "OFDM", "1T", "144", "-63",
+	"ACMA", "5G", "20M", "OFDM", "1T", "144", "-63",
+	"CHILE", "5G", "20M", "OFDM", "1T", "144", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"IC", "5G", "20M", "OFDM", "1T", "149", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "149", "26",
+	"ACMA", "5G", "20M", "OFDM", "1T", "149", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "149", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"IC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "153", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "153", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "153", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"IC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "157", "32",
+	"ACMA", "5G", "20M", "OFDM", "1T", "157", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "157", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"IC", "5G", "20M", "OFDM", "1T", "161", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "161", "30",
+	"ACMA", "5G", "20M", "OFDM", "1T", "161", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "161", "30",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "63",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"IC", "5G", "20M", "OFDM", "1T", "165", "32",
+	"KCC", "5G", "20M", "OFDM", "1T", "165", "-63",
+	"ACMA", "5G", "20M", "OFDM", "1T", "165", "32",
+	"CHILE", "5G", "20M", "OFDM", "1T", "165", "30",
+	"FCC", "5G", "20M", "HT", "1T", "36", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "28",
+	"IC", "5G", "20M", "HT", "1T", "36", "30",
+	"KCC", "5G", "20M", "HT", "1T", "36", "18",
+	"ACMA", "5G", "20M", "HT", "1T", "36", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "36", "30",
+	"FCC", "5G", "20M", "HT", "1T", "40", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "28",
+	"IC", "5G", "20M", "HT", "1T", "40", "30",
+	"KCC", "5G", "20M", "HT", "1T", "40", "24",
+	"ACMA", "5G", "20M", "HT", "1T", "40", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "40", "30",
+	"FCC", "5G", "20M", "HT", "1T", "44", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "28",
+	"IC", "5G", "20M", "HT", "1T", "44", "30",
+	"KCC", "5G", "20M", "HT", "1T", "44", "24",
+	"ACMA", "5G", "20M", "HT", "1T", "44", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "44", "30",
+	"FCC", "5G", "20M", "HT", "1T", "48", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "28",
+	"IC", "5G", "20M", "HT", "1T", "48", "30",
+	"KCC", "5G", "20M", "HT", "1T", "48", "18",
+	"ACMA", "5G", "20M", "HT", "1T", "48", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "48", "30",
+	"FCC", "5G", "20M", "HT", "1T", "52", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "28",
+	"IC", "5G", "20M", "HT", "1T", "52", "32",
+	"KCC", "5G", "20M", "HT", "1T", "52", "4",
+	"ACMA", "5G", "20M", "HT", "1T", "52", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "52", "30",
+	"FCC", "5G", "20M", "HT", "1T", "56", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "28",
+	"IC", "5G", "20M", "HT", "1T", "56", "32",
+	"KCC", "5G", "20M", "HT", "1T", "56", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "56", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "56", "30",
+	"FCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "28",
+	"IC", "5G", "20M", "HT", "1T", "60", "32",
+	"KCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "60", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "60", "30",
+	"FCC", "5G", "20M", "HT", "1T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "28",
+	"IC", "5G", "20M", "HT", "1T", "64", "28",
+	"KCC", "5G", "20M", "HT", "1T", "64", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "64", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "64", "30",
+	"FCC", "5G", "20M", "HT", "1T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"IC", "5G", "20M", "HT", "1T", "100", "26",
+	"KCC", "5G", "20M", "HT", "1T", "100", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "100", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "100", "30",
+	"FCC", "5G", "20M", "HT", "1T", "104", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "104", "32",
+	"MKK", "5G", "20M", "HT", "1T", "104", "32",
+	"IC", "5G", "20M", "HT", "1T", "104", "32",
+	"KCC", "5G", "20M", "HT", "1T", "104", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "104", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "104", "30",
+	"FCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"IC", "5G", "20M", "HT", "1T", "108", "32",
+	"KCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "108", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "108", "30",
+	"FCC", "5G", "20M", "HT", "1T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"IC", "5G", "20M", "HT", "1T", "112", "32",
+	"KCC", "5G", "20M", "HT", "1T", "112", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "112", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "112", "30",
+	"FCC", "5G", "20M", "HT", "1T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"IC", "5G", "20M", "HT", "1T", "116", "32",
+	"KCC", "5G", "20M", "HT", "1T", "116", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "116", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "116", "30",
+	"FCC", "5G", "20M", "HT", "1T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"IC", "5G", "20M", "HT", "1T", "120", "-63",
+	"KCC", "5G", "20M", "HT", "1T", "120", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "120", "-63",
+	"CHILE", "5G", "20M", "HT", "1T", "120", "30",
+	"FCC", "5G", "20M", "HT", "1T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"IC", "5G", "20M", "HT", "1T", "124", "-63",
+	"KCC", "5G", "20M", "HT", "1T", "124", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "124", "-63",
+	"CHILE", "5G", "20M", "HT", "1T", "124", "30",
+	"FCC", "5G", "20M", "HT", "1T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"IC", "5G", "20M", "HT", "1T", "128", "-63",
+	"KCC", "5G", "20M", "HT", "1T", "128", "-63",
+	"ACMA", "5G", "20M", "HT", "1T", "128", "-63",
+	"CHILE", "5G", "20M", "HT", "1T", "128", "30",
+	"FCC", "5G", "20M", "HT", "1T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"IC", "5G", "20M", "HT", "1T", "132", "32",
+	"KCC", "5G", "20M", "HT", "1T", "132", "-63",
+	"ACMA", "5G", "20M", "HT", "1T", "132", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "132", "30",
+	"FCC", "5G", "20M", "HT", "1T", "136", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"IC", "5G", "20M", "HT", "1T", "136", "32",
+	"KCC", "5G", "20M", "HT", "1T", "136", "-63",
+	"ACMA", "5G", "20M", "HT", "1T", "136", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "136", "30",
+	"FCC", "5G", "20M", "HT", "1T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"IC", "5G", "20M", "HT", "1T", "140", "26",
+	"KCC", "5G", "20M", "HT", "1T", "140", "-63",
+	"ACMA", "5G", "20M", "HT", "1T", "140", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "140", "30",
+	"FCC", "5G", "20M", "HT", "1T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "1T", "144", "63",
+	"MKK", "5G", "20M", "HT", "1T", "144", "63",
+	"IC", "5G", "20M", "HT", "1T", "144", "26",
+	"KCC", "5G", "20M", "HT", "1T", "144", "-63",
+	"ACMA", "5G", "20M", "HT", "1T", "144", "-63",
+	"CHILE", "5G", "20M", "HT", "1T", "144", "30",
+	"FCC", "5G", "20M", "HT", "1T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "63",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"IC", "5G", "20M", "HT", "1T", "149", "32",
+	"KCC", "5G", "20M", "HT", "1T", "149", "24",
+	"ACMA", "5G", "20M", "HT", "1T", "149", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "149", "30",
+	"FCC", "5G", "20M", "HT", "1T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "63",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"IC", "5G", "20M", "HT", "1T", "153", "32",
+	"KCC", "5G", "20M", "HT", "1T", "153", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "153", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "153", "30",
+	"FCC", "5G", "20M", "HT", "1T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "63",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"IC", "5G", "20M", "HT", "1T", "157", "32",
+	"KCC", "5G", "20M", "HT", "1T", "157", "32",
+	"ACMA", "5G", "20M", "HT", "1T", "157", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "157", "30",
+	"FCC", "5G", "20M", "HT", "1T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "63",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"IC", "5G", "20M", "HT", "1T", "161", "32",
+	"KCC", "5G", "20M", "HT", "1T", "161", "30",
+	"ACMA", "5G", "20M", "HT", "1T", "161", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "161", "30",
+	"FCC", "5G", "20M", "HT", "1T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "63",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"IC", "5G", "20M", "HT", "1T", "165", "32",
+	"KCC", "5G", "20M", "HT", "1T", "165", "-63",
+	"ACMA", "5G", "20M", "HT", "1T", "165", "32",
+	"CHILE", "5G", "20M", "HT", "1T", "165", "30",
+	"FCC", "5G", "20M", "HT", "2T", "36", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "20",
+	"MKK", "5G", "20M", "HT", "2T", "36", "22",
+	"IC", "5G", "20M", "HT", "2T", "36", "18",
+	"KCC", "5G", "20M", "HT", "2T", "36", "18",
+	"ACMA", "5G", "20M", "HT", "2T", "36", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "36", "18",
+	"FCC", "5G", "20M", "HT", "2T", "40", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "20",
+	"MKK", "5G", "20M", "HT", "2T", "40", "22",
+	"IC", "5G", "20M", "HT", "2T", "40", "18",
+	"KCC", "5G", "20M", "HT", "2T", "40", "18",
+	"ACMA", "5G", "20M", "HT", "2T", "40", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "40", "18",
+	"FCC", "5G", "20M", "HT", "2T", "44", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "20",
+	"MKK", "5G", "20M", "HT", "2T", "44", "22",
+	"IC", "5G", "20M", "HT", "2T", "44", "18",
+	"KCC", "5G", "20M", "HT", "2T", "44", "18",
+	"ACMA", "5G", "20M", "HT", "2T", "44", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "44", "18",
+	"FCC", "5G", "20M", "HT", "2T", "48", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "20",
+	"MKK", "5G", "20M", "HT", "2T", "48", "22",
+	"IC", "5G", "20M", "HT", "2T", "48", "18",
+	"KCC", "5G", "20M", "HT", "2T", "48", "18",
+	"ACMA", "5G", "20M", "HT", "2T", "48", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "48", "18",
+	"FCC", "5G", "20M", "HT", "2T", "52", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "20",
+	"MKK", "5G", "20M", "HT", "2T", "52", "22",
+	"IC", "5G", "20M", "HT", "2T", "52", "20",
+	"KCC", "5G", "20M", "HT", "2T", "52", "4",
+	"ACMA", "5G", "20M", "HT", "2T", "52", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "52", "18",
+	"FCC", "5G", "20M", "HT", "2T", "56", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "20",
+	"MKK", "5G", "20M", "HT", "2T", "56", "22",
+	"IC", "5G", "20M", "HT", "2T", "56", "20",
+	"KCC", "5G", "20M", "HT", "2T", "56", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "56", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "56", "18",
+	"FCC", "5G", "20M", "HT", "2T", "60", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "20",
+	"MKK", "5G", "20M", "HT", "2T", "60", "22",
+	"IC", "5G", "20M", "HT", "2T", "60", "20",
+	"KCC", "5G", "20M", "HT", "2T", "60", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "60", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "60", "18",
+	"FCC", "5G", "20M", "HT", "2T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "20",
+	"MKK", "5G", "20M", "HT", "2T", "64", "22",
+	"IC", "5G", "20M", "HT", "2T", "64", "20",
+	"KCC", "5G", "20M", "HT", "2T", "64", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "64", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "64", "18",
+	"FCC", "5G", "20M", "HT", "2T", "100", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "20",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"IC", "5G", "20M", "HT", "2T", "100", "26",
+	"KCC", "5G", "20M", "HT", "2T", "100", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "100", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "100", "18",
+	"FCC", "5G", "20M", "HT", "2T", "104", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "104", "20",
+	"MKK", "5G", "20M", "HT", "2T", "104", "30",
+	"IC", "5G", "20M", "HT", "2T", "104", "30",
+	"KCC", "5G", "20M", "HT", "2T", "104", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "104", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "104", "18",
+	"FCC", "5G", "20M", "HT", "2T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "20",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"IC", "5G", "20M", "HT", "2T", "108", "32",
+	"KCC", "5G", "20M", "HT", "2T", "108", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "108", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "108", "18",
+	"FCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "20",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"IC", "5G", "20M", "HT", "2T", "112", "32",
+	"KCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "112", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "112", "18",
+	"FCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "20",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"IC", "5G", "20M", "HT", "2T", "116", "32",
+	"KCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "116", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "116", "18",
+	"FCC", "5G", "20M", "HT", "2T", "120", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "20",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"IC", "5G", "20M", "HT", "2T", "120", "-63",
+	"KCC", "5G", "20M", "HT", "2T", "120", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "120", "-63",
+	"CHILE", "5G", "20M", "HT", "2T", "120", "18",
+	"FCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "20",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"IC", "5G", "20M", "HT", "2T", "124", "-63",
+	"KCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ACMA", "5G", "20M", "HT", "2T", "124", "-63",
+	"CHILE", "5G", "20M", "HT", "2T", "124", "18",
+	"FCC", "5G", "20M", "HT", "2T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "20",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"IC", "5G", "20M", "HT", "2T", "128", "-63",
+	"KCC", "5G", "20M", "HT", "2T", "128", "-63",
+	"ACMA", "5G", "20M", "HT", "2T", "128", "-63",
+	"CHILE", "5G", "20M", "HT", "2T", "128", "18",
+	"FCC", "5G", "20M", "HT", "2T", "132", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "20",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"IC", "5G", "20M", "HT", "2T", "132", "32",
+	"KCC", "5G", "20M", "HT", "2T", "132", "-63",
+	"ACMA", "5G", "20M", "HT", "2T", "132", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "132", "18",
+	"FCC", "5G", "20M", "HT", "2T", "136", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "20",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"IC", "5G", "20M", "HT", "2T", "136", "30",
+	"KCC", "5G", "20M", "HT", "2T", "136", "-63",
+	"ACMA", "5G", "20M", "HT", "2T", "136", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "136", "18",
+	"FCC", "5G", "20M", "HT", "2T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "20",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"IC", "5G", "20M", "HT", "2T", "140", "26",
+	"KCC", "5G", "20M", "HT", "2T", "140", "-63",
+	"ACMA", "5G", "20M", "HT", "2T", "140", "20",
+	"CHILE", "5G", "20M", "HT", "2T", "140", "18",
+	"FCC", "5G", "20M", "HT", "2T", "144", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "144", "63",
+	"MKK", "5G", "20M", "HT", "2T", "144", "63",
+	"IC", "5G", "20M", "HT", "2T", "144", "26",
+	"KCC", "5G", "20M", "HT", "2T", "144", "-63",
+	"ACMA", "5G", "20M", "HT", "2T", "144", "-63",
+	"CHILE", "5G", "20M", "HT", "2T", "144", "18",
+	"FCC", "5G", "20M", "HT", "2T", "149", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "63",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"IC", "5G", "20M", "HT", "2T", "149", "32",
+	"KCC", "5G", "20M", "HT", "2T", "149", "24",
+	"ACMA", "5G", "20M", "HT", "2T", "149", "32",
+	"CHILE", "5G", "20M", "HT", "2T", "149", "18",
+	"FCC", "5G", "20M", "HT", "2T", "153", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "63",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"IC", "5G", "20M", "HT", "2T", "153", "32",
+	"KCC", "5G", "20M", "HT", "2T", "153", "30",
+	"ACMA", "5G", "20M", "HT", "2T", "153", "32",
+	"CHILE", "5G", "20M", "HT", "2T", "153", "18",
+	"FCC", "5G", "20M", "HT", "2T", "157", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "63",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"IC", "5G", "20M", "HT", "2T", "157", "32",
+	"KCC", "5G", "20M", "HT", "2T", "157", "30",
+	"ACMA", "5G", "20M", "HT", "2T", "157", "32",
+	"CHILE", "5G", "20M", "HT", "2T", "157", "18",
+	"FCC", "5G", "20M", "HT", "2T", "161", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "63",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"IC", "5G", "20M", "HT", "2T", "161", "32",
+	"KCC", "5G", "20M", "HT", "2T", "161", "30",
+	"ACMA", "5G", "20M", "HT", "2T", "161", "32",
+	"CHILE", "5G", "20M", "HT", "2T", "161", "18",
+	"FCC", "5G", "20M", "HT", "2T", "165", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "63",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"IC", "5G", "20M", "HT", "2T", "165", "32",
+	"KCC", "5G", "20M", "HT", "2T", "165", "-63",
+	"ACMA", "5G", "20M", "HT", "2T", "165", "32",
+	"CHILE", "5G", "20M", "HT", "2T", "165", "18",
+	"FCC", "5G", "40M", "HT", "1T", "38", "22",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "30",
+	"MKK", "5G", "40M", "HT", "1T", "38", "30",
+	"IC", "5G", "40M", "HT", "1T", "38", "22",
+	"KCC", "5G", "40M", "HT", "1T", "38", "18",
+	"ACMA", "5G", "40M", "HT", "1T", "38", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "38", "22",
+	"FCC", "5G", "40M", "HT", "1T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "30",
+	"MKK", "5G", "40M", "HT", "1T", "46", "30",
+	"IC", "5G", "40M", "HT", "1T", "46", "30",
+	"KCC", "5G", "40M", "HT", "1T", "46", "18",
+	"ACMA", "5G", "40M", "HT", "1T", "46", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "46", "30",
+	"FCC", "5G", "40M", "HT", "1T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "30",
+	"MKK", "5G", "40M", "HT", "1T", "54", "30",
+	"IC", "5G", "40M", "HT", "1T", "54", "30",
+	"KCC", "5G", "40M", "HT", "1T", "54", "16",
+	"ACMA", "5G", "40M", "HT", "1T", "54", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "54", "30",
+	"FCC", "5G", "40M", "HT", "1T", "62", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "30",
+	"MKK", "5G", "40M", "HT", "1T", "62", "30",
+	"IC", "5G", "40M", "HT", "1T", "62", "24",
+	"KCC", "5G", "40M", "HT", "1T", "62", "30",
+	"ACMA", "5G", "40M", "HT", "1T", "62", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "62", "22",
+	"FCC", "5G", "40M", "HT", "1T", "102", "24",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "30",
+	"MKK", "5G", "40M", "HT", "1T", "102", "30",
+	"IC", "5G", "40M", "HT", "1T", "102", "24",
+	"KCC", "5G", "40M", "HT", "1T", "102", "26",
+	"ACMA", "5G", "40M", "HT", "1T", "102", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "102", "30",
+	"FCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "30",
+	"MKK", "5G", "40M", "HT", "1T", "110", "30",
+	"IC", "5G", "40M", "HT", "1T", "110", "30",
+	"KCC", "5G", "40M", "HT", "1T", "110", "30",
+	"ACMA", "5G", "40M", "HT", "1T", "110", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "110", "30",
+	"FCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "30",
+	"MKK", "5G", "40M", "HT", "1T", "118", "30",
+	"IC", "5G", "40M", "HT", "1T", "118", "-63",
+	"KCC", "5G", "40M", "HT", "1T", "118", "30",
+	"ACMA", "5G", "40M", "HT", "1T", "118", "-63",
+	"CHILE", "5G", "40M", "HT", "1T", "118", "30",
+	"FCC", "5G", "40M", "HT", "1T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "30",
+	"MKK", "5G", "40M", "HT", "1T", "126", "30",
+	"IC", "5G", "40M", "HT", "1T", "126", "-63",
+	"KCC", "5G", "40M", "HT", "1T", "126", "-63",
+	"ACMA", "5G", "40M", "HT", "1T", "126", "-63",
+	"CHILE", "5G", "40M", "HT", "1T", "126", "30",
+	"FCC", "5G", "40M", "HT", "1T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "30",
+	"MKK", "5G", "40M", "HT", "1T", "134", "30",
+	"IC", "5G", "40M", "HT", "1T", "134", "30",
+	"KCC", "5G", "40M", "HT", "1T", "134", "-63",
+	"ACMA", "5G", "40M", "HT", "1T", "134", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "134", "30",
+	"FCC", "5G", "40M", "HT", "1T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "142", "63",
+	"MKK", "5G", "40M", "HT", "1T", "142", "63",
+	"IC", "5G", "40M", "HT", "1T", "142", "30",
+	"KCC", "5G", "40M", "HT", "1T", "142", "-63",
+	"ACMA", "5G", "40M", "HT", "1T", "142", "-63",
+	"CHILE", "5G", "40M", "HT", "1T", "142", "30",
+	"FCC", "5G", "40M", "HT", "1T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "63",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"IC", "5G", "40M", "HT", "1T", "151", "30",
+	"KCC", "5G", "40M", "HT", "1T", "151", "20",
+	"ACMA", "5G", "40M", "HT", "1T", "151", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "151", "30",
+	"FCC", "5G", "40M", "HT", "1T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "63",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"IC", "5G", "40M", "HT", "1T", "159", "30",
+	"KCC", "5G", "40M", "HT", "1T", "159", "24",
+	"ACMA", "5G", "40M", "HT", "1T", "159", "30",
+	"CHILE", "5G", "40M", "HT", "1T", "159", "30",
+	"FCC", "5G", "40M", "HT", "2T", "38", "20",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "20",
+	"MKK", "5G", "40M", "HT", "2T", "38", "22",
+	"IC", "5G", "40M", "HT", "2T", "38", "20",
+	"KCC", "5G", "40M", "HT", "2T", "38", "18",
+	"ACMA", "5G", "40M", "HT", "2T", "38", "20",
+	"CHILE", "5G", "40M", "HT", "2T", "38", "18",
+	"FCC", "5G", "40M", "HT", "2T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "20",
+	"MKK", "5G", "40M", "HT", "2T", "46", "22",
+	"IC", "5G", "40M", "HT", "2T", "46", "18",
+	"KCC", "5G", "40M", "HT", "2T", "46", "18",
+	"ACMA", "5G", "40M", "HT", "2T", "46", "20",
+	"CHILE", "5G", "40M", "HT", "2T", "46", "18",
+	"FCC", "5G", "40M", "HT", "2T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "20",
+	"MKK", "5G", "40M", "HT", "2T", "54", "22",
+	"IC", "5G", "40M", "HT", "2T", "54", "20",
+	"KCC", "5G", "40M", "HT", "2T", "54", "16",
+	"ACMA", "5G", "40M", "HT", "2T", "54", "20",
+	"CHILE", "5G", "40M", "HT", "2T", "54", "18",
+	"FCC", "5G", "40M", "HT", "2T", "62", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "20",
+	"MKK", "5G", "40M", "HT", "2T", "62", "22",
+	"IC", "5G", "40M", "HT", "2T", "62", "20",
+	"KCC", "5G", "40M", "HT", "2T", "62", "30",
+	"ACMA", "5G", "40M", "HT", "2T", "62", "20",
+	"CHILE", "5G", "40M", "HT", "2T", "62", "18",
+	"FCC", "5G", "40M", "HT", "2T", "102", "22",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "20",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"IC", "5G", "40M", "HT", "2T", "102", "22",
+	"KCC", "5G", "40M", "HT", "2T", "102", "26",
+	"ACMA", "5G", "40M", "HT", "2T", "102", "20",
+	"CHILE", "5G", "40M", "HT", "2T", "102", "18",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "20",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"IC", "5G", "40M", "HT", "2T", "110", "30",
+	"KCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ACMA", "5G", "40M", "HT", "2T", "110", "20",
+	"CHILE", "5G", "40M", "HT", "2T", "110", "18",
+	"FCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "20",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"IC", "5G", "40M", "HT", "2T", "118", "-63",
+	"KCC", "5G", "40M", "HT", "2T", "118", "30",
+	"ACMA", "5G", "40M", "HT", "2T", "118", "-63",
+	"CHILE", "5G", "40M", "HT", "2T", "118", "18",
+	"FCC", "5G", "40M", "HT", "2T", "126", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "20",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"IC", "5G", "40M", "HT", "2T", "126", "-63",
+	"KCC", "5G", "40M", "HT", "2T", "126", "-63",
+	"ACMA", "5G", "40M", "HT", "2T", "126", "-63",
+	"CHILE", "5G", "40M", "HT", "2T", "126", "18",
+	"FCC", "5G", "40M", "HT", "2T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "20",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"IC", "5G", "40M", "HT", "2T", "134", "30",
+	"KCC", "5G", "40M", "HT", "2T", "134", "-63",
+	"ACMA", "5G", "40M", "HT", "2T", "134", "20",
+	"CHILE", "5G", "40M", "HT", "2T", "134", "18",
+	"FCC", "5G", "40M", "HT", "2T", "142", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "142", "63",
+	"MKK", "5G", "40M", "HT", "2T", "142", "63",
+	"IC", "5G", "40M", "HT", "2T", "142", "30",
+	"KCC", "5G", "40M", "HT", "2T", "142", "-63",
+	"ACMA", "5G", "40M", "HT", "2T", "142", "-63",
+	"CHILE", "5G", "40M", "HT", "2T", "142", "18",
+	"FCC", "5G", "40M", "HT", "2T", "151", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "63",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"IC", "5G", "40M", "HT", "2T", "151", "30",
+	"KCC", "5G", "40M", "HT", "2T", "151", "20",
+	"ACMA", "5G", "40M", "HT", "2T", "151", "30",
+	"CHILE", "5G", "40M", "HT", "2T", "151", "18",
+	"FCC", "5G", "40M", "HT", "2T", "159", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "63",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"IC", "5G", "40M", "HT", "2T", "159", "30",
+	"KCC", "5G", "40M", "HT", "2T", "159", "24",
+	"ACMA", "5G", "40M", "HT", "2T", "159", "30",
+	"CHILE", "5G", "40M", "HT", "2T", "159", "18",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "28",
+	"IC", "5G", "80M", "VHT", "1T", "42", "20",
+	"KCC", "5G", "80M", "VHT", "1T", "42", "14",
+	"ACMA", "5G", "80M", "VHT", "1T", "42", "30",
+	"CHILE", "5G", "80M", "VHT", "1T", "42", "20",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "28",
+	"IC", "5G", "80M", "VHT", "1T", "58", "20",
+	"KCC", "5G", "80M", "VHT", "1T", "58", "28",
+	"ACMA", "5G", "80M", "VHT", "1T", "58", "30",
+	"CHILE", "5G", "80M", "VHT", "1T", "58", "20",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "30",
+	"IC", "5G", "80M", "VHT", "1T", "106", "20",
+	"KCC", "5G", "80M", "VHT", "1T", "106", "28",
+	"ACMA", "5G", "80M", "VHT", "1T", "106", "30",
+	"CHILE", "5G", "80M", "VHT", "1T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "30",
+	"IC", "5G", "80M", "VHT", "1T", "122", "-63",
+	"KCC", "5G", "80M", "VHT", "1T", "122", "28",
+	"ACMA", "5G", "80M", "VHT", "1T", "122", "-63",
+	"CHILE", "5G", "80M", "VHT", "1T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "138", "63",
+	"IC", "5G", "80M", "VHT", "1T", "138", "30",
+	"KCC", "5G", "80M", "VHT", "1T", "138", "-63",
+	"ACMA", "5G", "80M", "VHT", "1T", "138", "-63",
+	"CHILE", "5G", "80M", "VHT", "1T", "138", "30",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"IC", "5G", "80M", "VHT", "1T", "155", "30",
+	"KCC", "5G", "80M", "VHT", "1T", "155", "22",
+	"ACMA", "5G", "80M", "VHT", "1T", "155", "30",
+	"CHILE", "5G", "80M", "VHT", "1T", "155", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "22",
+	"IC", "5G", "80M", "VHT", "2T", "42", "18",
+	"KCC", "5G", "80M", "VHT", "2T", "42", "14",
+	"ACMA", "5G", "80M", "VHT", "2T", "42", "20",
+	"CHILE", "5G", "80M", "VHT", "2T", "42", "18",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "18",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "22",
+	"IC", "5G", "80M", "VHT", "2T", "58", "18",
+	"KCC", "5G", "80M", "VHT", "2T", "58", "28",
+	"ACMA", "5G", "80M", "VHT", "2T", "58", "20",
+	"CHILE", "5G", "80M", "VHT", "2T", "58", "18",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "20",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"IC", "5G", "80M", "VHT", "2T", "106", "20",
+	"KCC", "5G", "80M", "VHT", "2T", "106", "28",
+	"ACMA", "5G", "80M", "VHT", "2T", "106", "20",
+	"CHILE", "5G", "80M", "VHT", "2T", "106", "18",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "20",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"IC", "5G", "80M", "VHT", "2T", "122", "-63",
+	"KCC", "5G", "80M", "VHT", "2T", "122", "28",
+	"ACMA", "5G", "80M", "VHT", "2T", "122", "-63",
+	"CHILE", "5G", "80M", "VHT", "2T", "122", "18",
+	"FCC", "5G", "80M", "VHT", "2T", "138", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "138", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "138", "63",
+	"IC", "5G", "80M", "VHT", "2T", "138", "30",
+	"KCC", "5G", "80M", "VHT", "2T", "138", "-63",
+	"ACMA", "5G", "80M", "VHT", "2T", "138", "-63",
+	"CHILE", "5G", "80M", "VHT", "2T", "138", "18",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "30",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "63",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63",
+	"IC", "5G", "80M", "VHT", "2T", "155", "30",
+	"KCC", "5G", "80M", "VHT", "2T", "155", "22",
+	"ACMA", "5G", "80M", "VHT", "2T", "155", "30",
+	"CHILE", "5G", "80M", "VHT", "2T", "155", "18"
+};
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type5(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type5)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8822b_txpwr_lmt_type5;
+#else
+	u32	array_len = sizeof(array_mp_8822b_txpwr_lmt_type5)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8822b_txpwr_lmt_type5;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8822b_txpwr_lmt_type5\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8822b(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_rf.h
new file mode 100644
index 000000000000..332d723d4c99
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/halhwimg8822b_rf.h
@@ -0,0 +1,324 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: R3 1.0*/
+#if (RTL8822B_SUPPORT == 1)
+#ifndef __INC_MP_RF_HW_IMG_8822B_H
+#define __INC_MP_RF_HW_IMG_8822B_H
+
+
+/******************************************************************************
+*                           radioa.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_radioa(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_radioa(void);
+
+/******************************************************************************
+*                           radiob.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_radiob(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_radiob(void);
+
+/******************************************************************************
+*                           txpowertrack.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack(void);
+
+/******************************************************************************
+*                           txpowertrack_type0.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type0(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type0(void);
+
+/******************************************************************************
+*                           txpowertrack_type1.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type1(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type1(void);
+
+/******************************************************************************
+*                           txpowertrack_type10.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type10(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type10(void);
+
+/******************************************************************************
+*                           txpowertrack_type11.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type11(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type11(void);
+
+/******************************************************************************
+*                           txpowertrack_type12.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type12(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type12(void);
+
+/******************************************************************************
+*                           txpowertrack_type13.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type13(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type13(void);
+
+/******************************************************************************
+*                           txpowertrack_type14.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type14(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type14(void);
+
+/******************************************************************************
+*                           txpowertrack_type15.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type15(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type15(void);
+
+/******************************************************************************
+*                           txpowertrack_type16.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type16(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type16(void);
+
+/******************************************************************************
+*                           txpowertrack_type17.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type17(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type17(void);
+
+/******************************************************************************
+*                           txpowertrack_type2.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type2(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type2(void);
+
+/******************************************************************************
+*                           txpowertrack_type3_type5.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type3_type5(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type3_type5(void);
+
+/******************************************************************************
+*                           txpowertrack_type4.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type4(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type4(void);
+
+/******************************************************************************
+*                           txpowertrack_type6.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type6(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type6(void);
+
+/******************************************************************************
+*                           txpowertrack_type7.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type7(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type7(void);
+
+/******************************************************************************
+*                           txpowertrack_type8.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type8(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type8(void);
+
+/******************************************************************************
+*                           txpowertrack_type9.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpowertrack_type9(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpowertrack_type9(void);
+
+/******************************************************************************
+*                           txpwr_lmt.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type12.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type12(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type12(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type15.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type15(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type15(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type16.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type16(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type16(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type17.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type17(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type17(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type2.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type2(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type2(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type3.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type3(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type3(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type4.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type4(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type4(void);
+
+/******************************************************************************
+*                           txpwr_lmt_type5.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8822b_txpwr_lmt_type5(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8822b_txpwr_lmt_type5(void);
+
+#endif
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/mp_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/mp_precomp.h
new file mode 100644
index 000000000000..9c7ab636aaad
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/mp_precomp.h
@@ -0,0 +1,14 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_hal_api8822b.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_hal_api8822b.c
new file mode 100644
index 000000000000..148fd5376487
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_hal_api8822b.c
@@ -0,0 +1,2147 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+
+#if (RTL8822B_SUPPORT == 1)
+#if (PHYDM_FW_API_ENABLE_8822B == 1)
+/* ======================================================================== */
+/* These following functions can be used for PHY DM only*/
+
+enum channel_width	bw_8822b;
+u8	central_ch_8822b;
+u8	central_ch_8822b_drp;
+
+#if !(DM_ODM_SUPPORT_TYPE == ODM_CE)
+	u32	cca_ifem_bcut[3][4] = {
+		{0x75D97010, 0x75D97010, 0x75D97010, 0x75D97010}, /*Reg82C*/
+		{0x79a0ea2a, 0x79a0ea2a, 0x79a0ea2a, 0x79a0ea2a}, /*Reg830*/
+		{0x87766441, 0x87746341, 0x87765541, 0x87746341} /*Reg838*/
+	};
+	u32	cca_efem_bcut[3][4] = {
+		{0x75B76010, 0x75B76010, 0x75B76010, 0x75B75010}, /*Reg82C*/
+		{0x79a0ea2a, 0x79a0ea2a, 0x79a0ea2a, 0x79a0ea2a}, /*Reg830*/
+		{0x87766451, 0x87766431, 0x87766451, 0x87766431} /*Reg838*/
+	};
+#endif
+
+u32 cca_ifem_ccut[3][4] = {
+	{0x75C97010, 0x75C97010, 0x75C97010, 0x75C97010}, /*Reg82C*/
+	{0x79a0eaaa, 0x79A0EAAC, 0x79a0eaaa, 0x79a0eaaa}, /*Reg830*/
+	{0x87765541, 0x87746341, 0x87765541, 0x87746341} /*Reg838*/
+};
+u32 cca_efem_ccut[3][4] = {
+	{0x75B86010, 0x75B76010, 0x75B86010, 0x75B76010}, /*Reg82C*/
+	{0x79A0EAA8, 0x79A0EAAC, 0x79A0EAA8, 0x79a0eaaa}, /*Reg830*/
+	{0x87766451, 0x87766431, 0x87766451, 0x87766431} /*Reg838*/
+};
+u32 cca_ifem_ccut_rfetype[3][4] = {
+	{0x75da8010, 0x75da8010, 0x75da8010, 0x75da8010}, /*Reg82C*/
+	{0x79a0eaaa, 0x97A0EAAC, 0x79a0eaaa, 0x79a0eaaa}, /*Reg830*/
+	{0x87765541, 0x86666341, 0x87765561, 0x86666361} /*Reg838*/
+};
+
+__iram_odm_func__
+void
+phydm_rxagc_switch_8822b(
+		struct dm_struct		*dm,
+		boolean enable_rxagc_switch
+)
+{
+	if ((dm->rfe_type == 15) || (dm->rfe_type == 16)) {
+		PHYDM_DBG(dm, ODM_COMP_API, "Microsoft case!\n");
+
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "Not Microsoft case\n");
+		return;
+	}
+
+	if (enable_rxagc_switch == true) {
+		if ((*dm->channel >= 36) && (*dm->channel <= 64)) {
+			odm_set_bb_reg(dm, 0x958, BIT(4), 0x1);
+			odm_set_bb_reg(dm, 0xc1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x1);
+			odm_set_bb_reg(dm, 0xe1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x5);
+		} else if ((*dm->channel >= 100) && (*dm->channel <= 144)) {
+			odm_set_bb_reg(dm, 0x958, BIT(4), 0x1);
+			odm_set_bb_reg(dm, 0xc1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x2);
+			odm_set_bb_reg(dm, 0xe1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x6);
+		} else if (*dm->channel >= 149) {
+			odm_set_bb_reg(dm, 0x958, BIT(4), 0x1);
+			odm_set_bb_reg(dm, 0xc1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x3);
+			odm_set_bb_reg(dm, 0xe1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x7);
+		}
+		dm->brxagcswitch = true;
+		PHYDM_DBG(dm, ODM_COMP_API, "Microsoft case! AGC table (path-b) is switched!\n");
+
+	} else {
+		if ((*dm->channel >= 36) && (*dm->channel <= 64)) {
+			odm_set_bb_reg(dm, 0x958, BIT(4), 0x1);
+			odm_set_bb_reg(dm, 0xc1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x1);
+			odm_set_bb_reg(dm, 0xe1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x1);
+		} else if ((*dm->channel >= 100) && (*dm->channel <= 144)) {
+			odm_set_bb_reg(dm, 0x958, BIT(4), 0x1);
+			odm_set_bb_reg(dm, 0xc1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x2);
+			odm_set_bb_reg(dm, 0xe1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x2);
+		} else if (*dm->channel >= 149) {
+			odm_set_bb_reg(dm, 0x958, BIT(4), 0x1);
+			odm_set_bb_reg(dm, 0xc1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x3);
+			odm_set_bb_reg(dm, 0xe1c, (BIT(11)|BIT(10)|BIT(9)|BIT(8)), 0x3);
+		}
+		dm->brxagcswitch = false;
+		PHYDM_DBG(dm, ODM_COMP_API, "AGC table are the same on path-a and b\n");
+
+	}
+		
+}
+
+__iram_odm_func__
+void
+phydm_igi_toggle_8822b(
+	struct dm_struct				*dm
+)
+{
+	u32 igi = 0x20;
+
+	igi = odm_get_bb_reg(dm, 0xc50, 0x7f);
+	odm_set_bb_reg(dm, 0xc50, 0x7f, (igi - 2));
+	odm_set_bb_reg(dm, 0xc50, 0x7f, igi);
+	odm_set_bb_reg(dm, 0xe50, 0x7f, (igi - 2));
+	odm_set_bb_reg(dm, 0xe50, 0x7f, igi);
+}
+
+
+__iram_odm_func__
+void 
+phydm_8822b_type15_rfe(
+	struct dm_struct				*dm,
+	u8					channel
+)
+{
+	if (channel <= 14) {
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x777777);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x777777);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x77);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x77);
+		
+	} else if ((channel > 35) && (channel <= 64)) {
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x777747);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x777747);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE0, 0x57);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE0, 0x57);
+				
+	} else if (channel > 64) {
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x777747);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x777747);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE0, 0x75);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE0, 0x75);
+
+	} else
+			return;
+	
+	/* inverse or not */
+	odm_set_bb_reg(dm, 0xcbc, 0x3f, 0x0);
+	odm_set_bb_reg(dm, 0xcbc, (BIT(11) | BIT(10) | BIT(9) | BIT(8)), 0x0);
+	odm_set_bb_reg(dm, 0xebc, 0x3f, 0x0);
+	odm_set_bb_reg(dm, 0xebc, (BIT(11) | BIT(10) | BIT(9) | BIT(8)), 0x0);
+
+	
+	/* antenna switch table */
+	if (channel <= 14) {
+		if ((dm->rx_ant_status == BB_PATH_AB) || (dm->tx_ant_status == BB_PATH_AB)) {
+			/* 2TX or 2RX */
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa501);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa501);
+		} else if (dm->rx_ant_status == dm->tx_ant_status) {
+			/* TXA+RXA or TXB+RXB */
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa500);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa500);
+		} else {
+			/* TXB+RXA or TXA+RXB */
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa005);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa005);
+		}
+	} else if (channel > 35) {
+		odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa5a5);
+		odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa5a5);
+	}
+
+}
+
+__iram_odm_func__
+u32
+phydm_check_bit_mask(u32 bit_mask, u32 data_original, u32 data)
+{
+	u8 bit_shift;
+	if (bit_mask != 0xfffff) {
+		for (bit_shift = 0; bit_shift <= 19; bit_shift++) {
+			if (((bit_mask >> bit_shift) & 0x1) == 1)
+				break;
+		}
+		return ((data_original)&(~bit_mask)) | (data << bit_shift);
+	}
+
+	return data;
+}
+
+__iram_odm_func__
+void
+phydm_rfe_8822b_setting(
+	void		*dm_void,
+	u8		rfe_num,
+	u8		path_mux_sel,
+	u8		inv_en,
+	u8		source_sel
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		debug_level = dm->debug_level;/*no use, just prevent FW 3081 compile warning*/
+
+	debug_level = 5; /*no use, just prevent FW 3081 compile warning*/
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "8822B RFE[%d]:{Path=0x%x}{inv_en=%d}{source=0x%x}\n", 
+		rfe_num, path_mux_sel, inv_en, source_sel);
+
+	if(rfe_num > 11) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "[Warning] Wrong RFE num=%d}\n", rfe_num);
+		return;
+	}
+	
+	 /*[Path_mux_sel]*/
+	odm_set_bb_reg(dm, 0x1990, BIT(rfe_num), ((path_mux_sel == BB_PATH_A) ? 0 : 1));
+	 
+	/*[Inv_en]*/
+	odm_set_bb_reg(dm, 0xcbc, BIT(rfe_num), (u32)inv_en);
+	odm_set_bb_reg(dm, 0xebc, BIT(rfe_num), (u32)inv_en);
+
+	/*[Output Source Signal Selection]*/
+	if (rfe_num <= 7) {
+		odm_set_bb_reg(dm, 0xcb0, ((0xf)<<(rfe_num * 4)), (u32)source_sel);
+		odm_set_bb_reg(dm, 0xeb0, ((0xf)<<(rfe_num * 4)), (u32)source_sel);
+	} else {
+		odm_set_bb_reg(dm, 0xcb4, ((0xf)<<((rfe_num - 8) * 4)), (u32)source_sel);
+		odm_set_bb_reg(dm, 0xeb4, ((0xf)<<((rfe_num - 8) * 4)), (u32)source_sel);
+	}
+}
+
+__iram_odm_func__
+void
+phydm_rfe_8822b_init(
+	struct dm_struct	*dm
+)
+{
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "8822B RFE_Init, RFE_type=((%d))\n", dm->rfe_type);
+	
+	/* chip top mux */
+	odm_set_bb_reg(dm, 0x64, BIT(29) | BIT(28), 0x3);
+	odm_set_bb_reg(dm, 0x4c, BIT(26) | BIT(25), 0x0);
+	odm_set_bb_reg(dm, 0x40, BIT(2), 0x1);
+
+	/* from s0 or s1 */
+	odm_set_bb_reg(dm, 0x1990, 0x3f, 0x30);
+	odm_set_bb_reg(dm, 0x1990, (BIT(11) | BIT(10)), 0x3);
+
+	/* input or output */
+	odm_set_bb_reg(dm, 0x974, 0x3f, 0x3f);
+	odm_set_bb_reg(dm, 0x974, (BIT(11) | BIT(10)), 0x3);
+}
+
+__iram_odm_func__
+boolean
+phydm_rfe_8822b(
+	struct dm_struct	*dm,
+	u8						channel
+)
+{
+	boolean	is_channel_2g = (channel <= 14) ? true : false;
+	u8		rfe_type = dm->rfe_type;
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "[8822B] Update RFE PINs: CH:%d, T/RX_path:{ 0x%x, 0x%x}, cut_ver:%d, rfe_type:%d\n", 
+		channel, dm->tx_ant_status, dm->rx_ant_status, dm->cut_version, rfe_type);
+
+	if (((channel > 14) && (channel < 36)) || ((channel == 0)))
+		return false;
+
+	/* Distinguish the setting band */
+	dm->rfe_hwsetting_band = (is_channel_2g) ? 1 : 2;
+
+	/* HW Setting for each RFE type */
+	if ((rfe_type == 4) || (rfe_type == 11)) {
+		/*TRSW  = trsw_forced_BT ? 0x804[0] : (0xCB8[2] ? 0xCB8[0] : trsw_lut);	trsw_lut = TXON*/
+		/*TRSWB = trsw_forced_BT ? (~0x804[0]) : (0xCB8[2] ? 0xCB8[1] : trswb_lut);	trswb_lut = TXON*/
+		/*trsw_forced_BT = 0x804[1] ? 0 : (~GNT_WL); */
+		/*odm_set_bb_reg(dm, 0x804, (BIT(1)|BIT(0)), 0x0);*/
+		/* Default setting is in PHY parameters */
+
+		if (is_channel_2g) {
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x745774);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x745774);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x57);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x57);
+
+			/* inverse or not */
+			odm_set_bb_reg(dm, 0xcbc, 0x3f, 0x8);
+			odm_set_bb_reg(dm, 0xcbc, (BIT(11) | BIT(10)), 0x2);
+			odm_set_bb_reg(dm, 0xebc, 0x3f, 0x8);
+			odm_set_bb_reg(dm, 0xebc, (BIT(11) | BIT(10)), 0x2);
+
+			/* antenna switch table */
+			if ((dm->rx_ant_status == BB_PATH_AB) || (dm->tx_ant_status == BB_PATH_AB)) {
+				/* 2TX or 2RX */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xf050);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xf050);
+			} else if (dm->rx_ant_status == dm->tx_ant_status) {
+				/* TXA+RXA or TXB+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xf055);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xf055);
+			} else {
+				/* TXB+RXA or TXA+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xf550);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xf550);
+			}
+
+		} else {
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x477547);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x477547);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x75);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x75);
+
+			/* inverse or not */
+			odm_set_bb_reg(dm, 0xcbc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xcbc, (BIT(11) | BIT(10)), 0x0);
+			odm_set_bb_reg(dm, 0xebc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xebc, (BIT(11) | BIT(10)), 0x0);
+
+			/* antenna switch table */
+			if ((dm->rx_ant_status == BB_PATH_AB) || (dm->tx_ant_status == BB_PATH_AB)) {
+				/* 2TX or 2RX */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa501);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa501);
+			} else if (dm->rx_ant_status == dm->tx_ant_status) {
+				/* TXA+RXA or TXB+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa500);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa500);
+			} else {
+				/* TXB+RXA or TXA+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa005);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa005);
+			}
+		}
+	} else if ((rfe_type == 1) || (rfe_type == 2) || (rfe_type == 6) || (rfe_type == 7) || (rfe_type == 9)) {
+		/* eFem */
+		if ((dm->cut_version == ODM_CUT_B) && (rfe_type < 2)) {
+			if (is_channel_2g) {
+				/* signal source */
+				odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x704570);
+				odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x704570);
+				odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x45);
+				odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x45);
+			} else {
+				odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x174517);
+				odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x174517);
+				odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x45);
+				odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x45);
+			}
+
+			/* delay 400ns for PAPE */
+			odm_set_bb_reg(dm, 0x810, 0xfff00000, 0x211);
+
+			/* antenna switch table */
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa555);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa555);
+
+			/* inverse or not */
+			odm_set_bb_reg(dm, 0xcbc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xcbc, (BIT(11) | BIT(10)), 0x0);
+			odm_set_bb_reg(dm, 0xebc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xebc, (BIT(11) | BIT(10)), 0x0);
+		} else {
+			if (is_channel_2g) {
+				/* signal source */
+				odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x705770);
+				odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x705770);
+				odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x57);
+				odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x57);
+				odm_set_bb_reg(dm, 0xcb8, BIT(4), 0);
+				odm_set_bb_reg(dm, 0xeb8, BIT(4), 0);
+			} else {
+				/* signal source */
+				odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x177517);
+				odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x177517);
+				odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x75);
+				odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x75);
+				odm_set_bb_reg(dm, 0xcb8, BIT(5), 0);
+				odm_set_bb_reg(dm, 0xeb8, BIT(5), 0);
+			}
+			
+			/* inverse or not */
+			odm_set_bb_reg(dm, 0xcbc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xcbc, (BIT(11) | BIT(10)), 0x0);
+			odm_set_bb_reg(dm, 0xebc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xebc, (BIT(11) | BIT(10)), 0x0);
+
+			/* delay 400ns for PAPE */
+			/* odm_set_bb_reg(dm, 0x810, MASKBYTE3|BIT20|BIT21|BIT22|BIT23, 0x211); */
+
+			/* antenna switch table */
+			if ((dm->rx_ant_status == BB_PATH_AB) || (dm->tx_ant_status == BB_PATH_AB)) {
+				/* 2TX or 2RX */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa501);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa501);
+			} else if (dm->rx_ant_status == dm->tx_ant_status) {
+				/* TXA+RXA or TXB+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa500);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa500);
+			} else {
+				/* TXB+RXA or TXA+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa005);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa005);
+			}
+		}
+	} else if ((rfe_type == 0) || (rfe_type == 3) || (rfe_type == 5) || (rfe_type == 8) || (rfe_type == 10) || (rfe_type == 12) || (rfe_type == 13) || (rfe_type == 14) || (rfe_type == 16) || (rfe_type == 17)) {
+		/* iFEM */
+		if (is_channel_2g) {
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x745774);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x745774);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x57);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x57);
+	
+		} else {
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x477547);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x477547);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x75);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x75);
+		}
+
+		/* inverse or not */
+		odm_set_bb_reg(dm, 0xcbc, 0x3f, 0x0);
+		odm_set_bb_reg(dm, 0xcbc, (BIT(11) | BIT(10)), 0x0);
+		odm_set_bb_reg(dm, 0xebc, 0x3f, 0x0);
+		odm_set_bb_reg(dm, 0xebc, (BIT(11) | BIT(10)), 0x0);
+
+		/* antenna switch table */
+		if (is_channel_2g) {
+			if ((dm->rx_ant_status == BB_PATH_AB) || (dm->tx_ant_status == BB_PATH_AB)) {
+				/* 2TX or 2RX */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa501);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa501);
+			} else if (dm->rx_ant_status == dm->tx_ant_status) {
+				/* TXA+RXA or TXB+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa500);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa500);
+			} else {
+				/* TXB+RXA or TXA+RXB */
+				odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa005);
+				odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa005);
+			}
+		} else {
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa5a5);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa5a5);
+		}
+	} else if (rfe_type == 15) {
+		/* iFEM for Microsoft, 5G low/high band */
+		phydm_8822b_type15_rfe(dm, channel);
+	}
+	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+	else if (rfe_type == SMTANT_TMP_RFE_TYPE) {
+		/*modify from RFE_TYPE = 1*/
+	
+		if (is_channel_2g) {
+			#if 0
+			/* signal source */
+			odm_set_bb_reg(dm, 0xcb0, 0xffffff, 0x705770);
+			odm_set_bb_reg(dm, 0xeb0, 0xffffff, 0x705770);
+			odm_set_bb_reg(dm, 0xcb4, MASKBYTE1, 0x57);
+			odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x57);
+			odm_set_bb_reg(dm, 0xcb8, BIT(4), 0);
+			odm_set_bb_reg(dm, 0xeb8, BIT(4), 0);
+			
+			/* inverse or not */
+			odm_set_bb_reg(dm, 0xcbc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xcbc, (BIT(11) | BIT(10)), 0x0);
+			odm_set_bb_reg(dm, 0xebc, 0x3f, 0x0);
+			odm_set_bb_reg(dm, 0xebc, (BIT(11) | BIT(10)), 0x0);
+			
+			#endif
+		} else {
+			/* signal source */
+			#if 1
+			/*path A*/
+			odm_set_bb_reg(dm, 0x1990, BIT(3), 0);		/*RFE_CTRL_3*/ /*A_0*/
+			odm_set_bb_reg(dm, 0x1990, BIT(0), 0);		/*RFE_CTRL_0*/ /*A_1*/
+			odm_set_bb_reg(dm, 0x1990, BIT(8), 0);		/*RFE_CTRL_8*/ /*A_2*/
+
+			/*path B*/
+			odm_set_bb_reg(dm, 0x1990, BIT(4), 1);		/*RFE_CTRL_4*/ 	/*B_0*/
+			odm_set_bb_reg(dm, 0x1990, BIT(11), 1);	/*RFE_CTRL_11*/	/*B_1*/
+			odm_set_bb_reg(dm, 0x1990, BIT(9), 1); 		/*RFE_CTRL_9*/	/*B_2*/
+
+			odm_set_bb_reg(dm, 0xcb0, MASKDWORD, 0x77178519);
+			//odm_set_bb_reg(dm, 0xeb0, MASKDWORD, 0x77177517);
+			odm_set_bb_reg(dm, 0xeb0, MASKDWORD, 0x771c7517);
+			odm_set_bb_reg(dm, 0xcb4, MASKDWORD, 0x757a);
+			//odm_set_bb_reg(dm, 0xeb4, MASKBYTE1, 0x7577);
+			odm_set_bb_reg(dm, 0xeb4, MASKDWORD, 0xd5e7);
+
+			/* inverse or not */
+			odm_set_bb_reg(dm, 0xcbc, 0xfff, 0x0);
+			odm_set_bb_reg(dm, 0xebc, 0xfff, 0x0);
+			#else
+			phydm_rfe_8822b_setting(dm, 1, BB_PATH_A, 0, PAPE_5G);
+			phydm_rfe_8822b_setting(dm, 2, BB_PATH_A, 0, TRSW_B);
+			phydm_rfe_8822b_setting(dm, 5, BB_PATH_B, 0, PAPE_5G);
+			phydm_rfe_8822b_setting(dm, 10, BB_PATH_B, 0, TRSW_B);
+			#endif
+
+			odm_set_bb_reg(dm, 0xcb8, BIT(5), 0);
+			odm_set_bb_reg(dm, 0xeb8, BIT(5), 0);
+		}
+			
+		/* delay 400ns for PAPE */
+		/* odm_set_bb_reg(dm, 0x810, MASKBYTE3|BIT20|BIT21|BIT22|BIT23, 0x211); */
+
+		/* antenna switch table */
+		if ((dm->rx_ant_status == BB_PATH_AB) || (dm->tx_ant_status == BB_PATH_AB)) {
+			/* 2TX or 2RX */
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa501);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa501);
+		} else if (dm->rx_ant_status == dm->tx_ant_status) {
+			/* TXA+RXA or TXB+RXB */
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa500);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa500);
+		} else {
+			/* TXB+RXA or TXA+RXB */
+			odm_set_bb_reg(dm, 0xca0, MASKLWORD, 0xa005);
+			odm_set_bb_reg(dm, 0xea0, MASKLWORD, 0xa005);
+		}
+	}
+	#endif
+
+	return true;
+}
+
+__iram_odm_func__
+u8
+phydm_is_dfs_channel(u8 channel_num)
+{
+	if(channel_num >= 52 && channel_num <= 140)
+		return 1;
+	else
+		return 0;
+}
+
+__iram_odm_func__
+void
+phydm_ccapar_by_rfe_8822b(
+	struct dm_struct				*dm
+)
+{
+	u32	cca_ifem[3][4], cca_efem[3][4];
+	u8	col;
+	u32	reg82c, reg830, reg838;
+	boolean	is_efem_cca = false, is_ifem_cca = false, is_rfe_type = false;
+
+#if !(DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (dm->cut_version == ODM_CUT_B) {
+		odm_move_memory(dm, cca_efem, cca_efem_bcut, 12 * 4);
+		odm_move_memory(dm, cca_ifem, cca_ifem_bcut, 12 * 4);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: Update CCA parameters for Bcut\n", __func__);
+	} else
+#endif
+	{
+		odm_move_memory(dm, cca_efem, cca_efem_ccut, 12 * 4);
+	if ((dm->rfe_type == 3) || (dm->rfe_type == 5) || (dm->rfe_type == 12) || (dm->rfe_type == 15) || (dm->rfe_type == 16) || (dm->rfe_type == 17)) {
+		odm_move_memory(dm, cca_ifem, cca_ifem_ccut_rfetype, 12 * 4);
+		is_rfe_type = true;
+	} else
+		odm_move_memory(dm, cca_ifem, cca_ifem_ccut, 12 * 4);
+	
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: Update CCA parameters for Ccut\n", __func__);
+	}
+
+	if (central_ch_8822b <= 14) {
+		if ((dm->rx_ant_status == BB_PATH_A) || (dm->rx_ant_status == BB_PATH_B))
+			col = 0;	/*1R 2G*/
+		else
+			col = 1;	/*2R 2G*/
+	} else {
+		if ((dm->rx_ant_status == BB_PATH_A) || (dm->rx_ant_status == BB_PATH_B))
+			col = 2;	/*1R 5G*/
+		else
+			col = 3;	/*2R 5G*/
+	}
+
+	if ((dm->rfe_type == 1) || (dm->rfe_type == 4) || (dm->rfe_type == 6) || (dm->rfe_type == 7) || (dm->rfe_type == 11)) {
+		/*eFEM => RFE type 1 & RFE type 4 & RFE type 6 & RFE type 7 & RFE type 11*/
+		reg82c = cca_efem[0][col];
+		reg830 = cca_efem[1][col];
+		reg838 = cca_efem[2][col];
+		is_efem_cca = true;
+	} else if ((dm->rfe_type == 2) || (dm->rfe_type == 9)) {
+		/*5G eFEM, 2G iFEM => RFE type 2, 5G eFEM => RFE type 9 */
+		if (central_ch_8822b <= 14) {
+			reg82c = cca_ifem[0][col];
+			reg830 = cca_ifem[1][col];
+			reg838 = cca_ifem[2][col];
+			is_ifem_cca = true;
+		} else {
+			reg82c = cca_efem[0][col];
+			reg830 = cca_efem[1][col];
+			reg838 = cca_efem[2][col];
+			is_efem_cca = true;
+		}
+	} else {
+		/* iFEM =>RFEtype 3 & RFE type 5 & RFE type 0 & RFE type 8 & RFE type 10 & RFE type 12 & RFE type 13 & RFE type 15~17 */
+		reg82c = cca_ifem[0][col];
+		reg830 = cca_ifem[1][col];
+		reg838 = cca_ifem[2][col];
+		is_ifem_cca = true;
+	}
+
+	odm_set_bb_reg(dm, 0x82c, MASKDWORD, reg82c);
+
+	if (is_ifem_cca == true)
+		if (((dm->cut_version == ODM_CUT_B) && (col == 1 || col == 3) && (bw_8822b == CHANNEL_WIDTH_40)) ||
+			((is_rfe_type == false) && (col == 3) && (bw_8822b == CHANNEL_WIDTH_40)) ||
+			((dm->rfe_type == 5) && (col == 3)))
+			odm_set_bb_reg(dm, 0x830, MASKDWORD, 0x79a0ea28);
+		else
+			odm_set_bb_reg(dm, 0x830, MASKDWORD, reg830);
+	else
+		odm_set_bb_reg(dm, 0x830, MASKDWORD, reg830);
+
+	odm_set_bb_reg(dm, 0x838, MASKDWORD, reg838);
+
+	if ((is_efem_cca == true) && !(dm->cut_version == ODM_CUT_B))
+		odm_set_bb_reg(dm, 0x83c, MASKDWORD, 0x9194b2b9);
+
+	/* enlarge big jump size in type 16 for MS case */
+	if ((dm->rfe_type == 16) && (central_ch_8822b <= 14))
+		odm_set_bb_reg(dm, 0x8c8, BIT(3) | BIT (2) | BIT(1), 0x3);
+	
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: (Pkt%d, Intf%d, RFE%d), col = %d\n",
+		__func__, dm->package_type, dm->support_interface, dm->rfe_type, col);
+}
+
+__iram_odm_func__
+void
+phydm_rxdfirpar_by_bw_8822b(
+	struct dm_struct				*dm,
+	enum channel_width				bandwidth
+)
+{
+	if (bandwidth == CHANNEL_WIDTH_40) {
+		/* RX DFIR for BW40 */
+		odm_set_bb_reg(dm, 0x948, BIT(29) | BIT(28), 0x1);
+		odm_set_bb_reg(dm, 0x94c, BIT(29) | BIT(28), 0x0);
+		odm_set_bb_reg(dm, 0xc20, BIT(31), 0x0);
+		odm_set_bb_reg(dm, 0xe20, BIT(31), 0x0);
+	} else if (bandwidth == CHANNEL_WIDTH_80) {
+		/* RX DFIR for BW80 */
+		odm_set_bb_reg(dm, 0x948, BIT(29) | BIT(28), 0x2);
+		odm_set_bb_reg(dm, 0x94c, BIT(29) | BIT(28), 0x1);
+		odm_set_bb_reg(dm, 0xc20, BIT(31), 0x0);
+		odm_set_bb_reg(dm, 0xe20, BIT(31), 0x0);
+	} else {
+		/* RX DFIR for BW20, BW10 and BW5*/
+		odm_set_bb_reg(dm, 0x948, BIT(29) | BIT(28), 0x2);
+		odm_set_bb_reg(dm, 0x94c, BIT(29) | BIT(28), 0x2);
+		odm_set_bb_reg(dm, 0xc20, BIT(31), 0x1);
+		odm_set_bb_reg(dm, 0xe20, BIT(31), 0x1);
+	}
+	/* PHYDM_DBG(dm, ODM_PHY_CONFIG, "phydm_rxdfirpar_by_bw_8822b\n");*/
+}
+
+__iram_odm_func__
+boolean
+phydm_write_txagc_1byte_8822b(
+	struct dm_struct				*dm,
+	u32					power_index,
+	enum rf_path		path,
+	u8					hw_rate
+)
+{
+#if (PHYDM_FW_API_FUNC_ENABLE_8822B == 1)
+
+	u32	offset_txagc[2] = {0x1d00, 0x1d80};
+	u8	rate_idx = (hw_rate & 0xfc), i;
+	u8	rate_offset = (hw_rate & 0x3);
+	u32	txagc_content = 0x0;
+
+	/* For debug command only!!!! */
+
+	/* Error handling */
+	if ((path > RF_PATH_B) || (hw_rate > 0x53)) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "phydm_write_txagc_1byte_8822b(): unsupported path (%d)\n", path);
+		return false;
+	}
+
+	/* For HW limitation, We can't write TXAGC once a byte. */
+	for (i = 0; i < 4; i++) {
+		if (i != rate_offset)
+			txagc_content = txagc_content | (config_phydm_read_txagc_8822b(dm, path, rate_idx + i) << (i << 3));
+		else
+			txagc_content = txagc_content | ((power_index & 0x3f) << (i << 3));
+	}
+	odm_set_bb_reg(dm, (offset_txagc[path] + rate_idx), MASKDWORD, txagc_content);
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "phydm_write_txagc_1byte_8822b(): path-%d rate index 0x%x (0x%x) = 0x%x\n",
+		path, hw_rate, (offset_txagc[path] + hw_rate), power_index);
+	return true;
+#else
+	return false;
+#endif
+}
+
+__iram_odm_func__
+void
+phydm_init_hw_info_by_rfe_type_8822b(
+	struct dm_struct				*dm
+)
+{
+#if (PHYDM_FW_API_FUNC_ENABLE_8822B == 1)
+	u16	mask_path_a = 0x0303;
+	u16	mask_path_b = 0x0c0c;
+	/*u16	mask_path_c = 0x3030;*/
+	/*u16	mask_path_d = 0xc0c0;*/
+
+	dm->is_init_hw_info_by_rfe = false;
+
+	if ((dm->rfe_type == 1) || (dm->rfe_type == 6) || (dm->rfe_type == 7)) {
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, (ODM_BOARD_EXT_LNA | ODM_BOARD_EXT_LNA_5G | ODM_BOARD_EXT_PA | ODM_BOARD_EXT_PA_5G));
+
+		if (dm->rfe_type == 6) {
+			odm_cmn_info_init(dm, ODM_CMNINFO_GPA, (TYPE_GPA1 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_APA, (TYPE_APA1 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_GLNA, (TYPE_GLNA1 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_ALNA, (TYPE_ALNA1 & (mask_path_a | mask_path_b)));
+		} else if (dm->rfe_type == 7) {
+			odm_cmn_info_init(dm, ODM_CMNINFO_GPA, (TYPE_GPA2 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_APA, (TYPE_APA2 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_GLNA, (TYPE_GLNA2 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_ALNA, (TYPE_ALNA2 & (mask_path_a | mask_path_b)));
+		} else {
+			odm_cmn_info_init(dm, ODM_CMNINFO_GPA, (TYPE_GPA0 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_APA, (TYPE_APA0 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_GLNA, (TYPE_GLNA0 & (mask_path_a | mask_path_b)));
+			odm_cmn_info_init(dm, ODM_CMNINFO_ALNA, (TYPE_ALNA0 & (mask_path_a | mask_path_b)));
+		}
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 1);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, true);
+	} else if (dm->rfe_type == 2) {
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, (ODM_BOARD_EXT_LNA_5G | ODM_BOARD_EXT_PA_5G));
+		odm_cmn_info_init(dm, ODM_CMNINFO_APA, (TYPE_APA0 & (mask_path_a | mask_path_b)));
+		odm_cmn_info_init(dm, ODM_CMNINFO_ALNA, (TYPE_ALNA0 & (mask_path_a | mask_path_b)));
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 2);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, true);
+	} else if (dm->rfe_type == 9) {
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, (ODM_BOARD_EXT_LNA_5G));
+		odm_cmn_info_init(dm, ODM_CMNINFO_ALNA, (TYPE_ALNA0 & (mask_path_a | mask_path_b)));
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 1);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, false);
+	} else if (dm->rfe_type == 3) {
+		/* RFE type 3: 8822BS\8822BU TFBGA iFEM */
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, 0);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 2);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, false);
+	} else if (dm->rfe_type == 5) {
+		/* RFE type 5: 8822BE TFBGA iFEM */
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, ODM_BOARD_SLIM);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 2);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, false);
+	} else if (dm->rfe_type == 12) {
+		/* RFE type 12: QFN iFEM */
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, 0);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 1);
+		
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, false);
+	} else if (dm->rfe_type == 4) {
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, (ODM_BOARD_EXT_LNA | ODM_BOARD_EXT_LNA_5G | ODM_BOARD_EXT_PA | ODM_BOARD_EXT_PA_5G));
+		odm_cmn_info_init(dm, ODM_CMNINFO_GPA, (TYPE_GPA0 & (mask_path_a | mask_path_b)));
+		odm_cmn_info_init(dm, ODM_CMNINFO_APA, (TYPE_APA0 & (mask_path_a | mask_path_b)));
+		odm_cmn_info_init(dm, ODM_CMNINFO_GLNA, (TYPE_GLNA0 & (mask_path_a | mask_path_b)));
+		odm_cmn_info_init(dm, ODM_CMNINFO_ALNA, (TYPE_ALNA0 & (mask_path_a | mask_path_b)));
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 2);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, true);
+	} else if (dm->rfe_type == 11) {
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, (ODM_BOARD_EXT_LNA | ODM_BOARD_EXT_LNA_5G | ODM_BOARD_EXT_PA | ODM_BOARD_EXT_PA_5G));
+		odm_cmn_info_init(dm, ODM_CMNINFO_GPA, (TYPE_GPA1 & (mask_path_a | mask_path_b)));
+		odm_cmn_info_init(dm, ODM_CMNINFO_APA, (TYPE_APA1 & (mask_path_a | mask_path_b)));
+		odm_cmn_info_init(dm, ODM_CMNINFO_GLNA, (TYPE_GLNA1 & (mask_path_a | mask_path_b)));
+		odm_cmn_info_init(dm, ODM_CMNINFO_ALNA, (TYPE_ALNA1 & (mask_path_a | mask_path_b)));
+		
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 2);
+		
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, true);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, true);
+
+	} else if (dm->rfe_type == 8) {
+	/* RFE type 8: TFBGA iFEM AP */
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, 0);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 2);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, false);
+	} else if (dm->rfe_type == 10) {
+	/* RFE type 10: QFN iFEM AP PCIE TRSW */
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, ODM_BOARD_EXT_TRSW);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 1);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, false);
+	} else {
+	/* RFE Type 0: QFN iFEM */
+		odm_cmn_info_init(dm, ODM_CMNINFO_BOARD_TYPE, 0);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_PACKAGE_TYPE, 1);
+
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_LNA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_EXT_PA, false);
+		odm_cmn_info_init(dm, ODM_CMNINFO_5G_EXT_PA, false);
+	}
+
+	dm->is_init_hw_info_by_rfe = true;
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG,
+		"%s: RFE type (%d), Board type (0x%x), Package type (%d)\n", __func__, dm->rfe_type, dm->board_type, dm->package_type);
+	PHYDM_DBG(dm, ODM_PHY_CONFIG,
+		"%s: 5G ePA (%d), 5G eLNA (%d), 2G ePA (%d), 2G eLNA (%d)\n", __func__, dm->ext_pa_5g, dm->ext_lna_5g, dm->ext_pa, dm->ext_lna);
+	PHYDM_DBG(dm, ODM_PHY_CONFIG,
+		"%s: 5G PA type (%d), 5G LNA type (%d), 2G PA type (%d), 2G LNA type (%d)\n", __func__, dm->type_apa, dm->type_alna, dm->type_gpa, dm->type_glna);
+
+#endif	/*PHYDM_FW_API_FUNC_ENABLE_8822B == 1*/
+}
+
+__iram_odm_func__
+s32
+phydm_get_condition_number_8822B(
+	struct dm_struct				*dm
+)
+{
+	s32	ret_val;
+
+	odm_set_bb_reg(dm, 0x1988, BIT(22), 0x1);
+	ret_val = (s32)odm_get_bb_reg(dm, 0xf84, (BIT(17) | BIT(16) | MASKLWORD));
+
+	if (bw_8822b == 0) {
+		ret_val = ret_val << (8 - 4);
+		ret_val = ret_val / 234;
+	} else if (bw_8822b == 1) {
+		ret_val = ret_val << (7 - 4);
+		ret_val = ret_val / 108;
+	} else if (bw_8822b == 2) {
+		ret_val = ret_val << (6 - 4);
+		ret_val = ret_val / 52;
+	}
+
+	return ret_val;
+}
+
+/* ======================================================================== */
+
+/* ======================================================================== */
+/* These following functions can be used by driver*/
+
+__iram_odm_func__
+u32
+config_phydm_read_rf_reg_8822b(
+	struct dm_struct		*dm,
+	enum rf_path		path,
+	u32					reg_addr,
+	u32					bit_mask
+)
+{
+	u32	readback_value, direct_addr;
+	u32	offset_read_rf[2] = {0x2800, 0x2c00};
+
+	/* Error handling.*/
+	if (path > RF_PATH_B) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_read_rf_reg_8822b(): unsupported path (%d)\n", path);
+		return INVALID_RF_DATA;
+	}
+
+	/* Calculate offset */
+	reg_addr &= 0xff;
+	direct_addr = offset_read_rf[path] + (reg_addr << 2);
+
+	/* RF register only has 20bits */
+	bit_mask &= RFREGOFFSETMASK;
+
+	/* Read RF register directly */
+	readback_value = odm_get_bb_reg(dm, direct_addr, bit_mask);
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_read_rf_reg_8822b(): RF-%d 0x%x = 0x%x, bit mask = 0x%x\n",
+			path, reg_addr, readback_value, bit_mask);
+	return readback_value;
+}
+
+__iram_odm_func__
+boolean
+config_phydm_write_rf_reg_8822b(
+	struct dm_struct				*dm,
+	enum rf_path		path,
+	u32					reg_addr,
+	u32					bit_mask,
+	u32					data
+)
+{
+	u32	data_and_addr = 0, data_original = 0;
+	u32	offset_write_rf[2] = {0xc90, 0xe90};
+
+	/* Error handling.*/
+	if (path > RF_PATH_B) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_write_rf_reg_8822b(): unsupported path (%d)\n", path);
+		return false;
+	}
+
+	/* Read RF register content first */
+	reg_addr &= 0xff;
+	bit_mask = bit_mask & RFREGOFFSETMASK;
+
+	if (bit_mask != RFREGOFFSETMASK) {
+		data_original = config_phydm_read_rf_reg_8822b(dm, path, reg_addr, RFREGOFFSETMASK);
+
+		/* Error handling. RF is disabled */
+		if (config_phydm_read_rf_check_8822b(data_original) == false) {
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_write_rf_reg_8822b(): Write fail, RF is disable\n");
+			return false;
+		}
+
+		/* check bit mask */
+		data = phydm_check_bit_mask(bit_mask, data_original, data);
+	}
+
+	/* Put write addr in [27:20]  and write data in [19:00] */
+	data_and_addr = ((reg_addr << 20) | (data & 0x000fffff)) & 0x0fffffff;
+
+	/* Write operation */
+	odm_set_bb_reg(dm, offset_write_rf[path], MASKDWORD, data_and_addr);
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_write_rf_reg_8822b(): RF-%d 0x%x = 0x%x (original: 0x%x), bit mask = 0x%x\n",
+			path, reg_addr, data, data_original, bit_mask);
+	return true;
+}
+
+__iram_odm_func__
+boolean
+config_phydm_write_txagc_8822b(
+	struct dm_struct				*dm,
+	u32					power_index,
+	enum rf_path		path,
+	u8					hw_rate
+)
+{
+	u32	offset_txagc[2] = {0x1d00, 0x1d80};
+	u8	rate_idx = (hw_rate & 0xfc);
+
+	/* Input need to be HW rate index, not driver rate index!!!! */
+
+	if (dm->is_disable_phy_api) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_write_txagc_8822b(): disable PHY API for debug!!\n");
+		return true;
+	}
+
+	/* Error handling */
+	if ((path > RF_PATH_B) || (hw_rate > 0x53)) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_write_txagc_8822b(): unsupported path (%d)\n", path);
+		return false;
+	}
+
+	/* driver need to construct a 4-byte power index */
+	odm_set_bb_reg(dm, (offset_txagc[path] + rate_idx), MASKDWORD, power_index);
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_write_txagc_8822b(): path-%d rate index 0x%x (0x%x) = 0x%x\n",
+		path, hw_rate, (offset_txagc[path] + hw_rate), power_index);
+	return true;
+
+}
+
+__iram_odm_func__
+u8
+config_phydm_read_txagc_8822b(
+	struct dm_struct				*dm,
+	enum rf_path		path,
+	u8					hw_rate
+)
+{
+#if (PHYDM_FW_API_FUNC_ENABLE_8822B == 1)
+	u8	read_back_data;
+
+	/* Input need to be HW rate index, not driver rate index!!!! */
+
+	/* Error handling */
+	if ((path > RF_PATH_B) || (hw_rate > 0x53)) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_read_txagc_8822b(): unsupported path (%d)\n", path);
+		return INVALID_TXAGC_DATA;
+	}
+
+	/* Disable TX AGC report */
+	odm_set_bb_reg(dm, 0x1998, BIT(16), 0x0);							/* need to check */
+
+	/* Set data rate index (bit0~6) and path index (bit7) */
+	odm_set_bb_reg(dm, 0x1998, MASKBYTE0, (hw_rate | (path << 7)));
+
+	/* Enable TXAGC report */
+	odm_set_bb_reg(dm, 0x1998, BIT(16), 0x1);
+
+	/* Read TX AGC report */
+	read_back_data = (u8)odm_get_bb_reg(dm, 0xd30, 0x7f0000);
+
+	/* Driver have to disable TXAGC report after reading TXAGC (ref. user guide v11) */
+	odm_set_bb_reg(dm, 0x1998, BIT(16), 0x0);
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_read_txagc_8822b(): path-%d rate index 0x%x = 0x%x\n", path, hw_rate, read_back_data);
+	return read_back_data;
+#else
+	return 0;
+#endif
+}
+
+__iram_odm_func__
+void
+phydm_dynamic_spur_det_eliminate(
+	struct dm_struct				*dm
+)
+{
+#if (PHYDM_FW_API_FUNC_ENABLE_8822B == 1)
+
+	u32		freq_2g[FREQ_PT_2G_NUM] = {0xFC67, 0xFC27, 0xFFE6, 0xFFA6, 0xFC67, 0xFCE7, 0xFCA7, 0xFC67, 0xFC27, 0xFFE6, 0xFFA6, 0xFF66, 0xFF26, 0xFCE7};
+	u32		freq_5g[FREQ_PT_5G_NUM] = {0xFFC0, 0xFFC0, 0xFC81, 0xFC81, 0xFC41, 0xFC40, 0xFF80, 0xFF80, 0xFF40, 0xFD42};
+	u32		freq_2g_n1[FREQ_PT_2G_NUM] = {0}, freq_2g_p1[FREQ_PT_2G_NUM] = {0};
+	u32		freq_5g_n1[FREQ_PT_5G_NUM] = {0}, freq_5g_p1[FREQ_PT_5G_NUM] = {0};
+	u32		freq_pt_2g_final = 0, freq_pt_5g_final = 0, freq_pt_2g_b_final = 0, freq_pt_5g_b_final = 0;
+	u32		max_ret_psd_final = 0, max_ret_psd_b_final = 0;
+	u32		max_ret_psd_2nd[PSD_SMP_NUM] = {0}, max_ret_psd_b_2nd[PSD_SMP_NUM] = {0};
+	u32		psd_set[PSD_VAL_NUM] = {0}, psd_set_B[PSD_VAL_NUM] = {0};
+	u32		rank_psd_index_in[PSD_VAL_NUM] = {0}, rank_sample_index_in[PSD_SMP_NUM] = {0};
+	u32		rank_psd_index_out[PSD_VAL_NUM] = {0};
+	u32		rank_sample_index_out[PSD_SMP_NUM] = {0};
+	u32		reg_910_15_12 = 0;
+	u8		j = 0, k = 0, threshold_nbi = 0x8D, threshold_csi = 0x8D;
+	u8		idx = 0, set_result_nbi = PHYDM_SET_NO_NEED, set_result_csi = PHYDM_SET_NO_NEED;
+	boolean	s_dopsd = false, s_donbi_a = false, s_docsi = false, s_donbi_b = false;
+
+	/* Reset NBI/CSI everytime after changing channel/BW/band  */
+	odm_set_bb_reg(dm, 0x880, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x884, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x888, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x88c, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x890, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x894, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x898, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x89c, MASKDWORD, 0);
+	odm_set_bb_reg(dm, 0x874, BIT(0), 0x0);
+
+	odm_set_bb_reg(dm, 0x87c, BIT(13), 0x0);
+	odm_set_bb_reg(dm, 0xc20, BIT(28), 0x0);
+	odm_set_bb_reg(dm, 0xe20, BIT(28), 0x0);
+
+	/* 2G Channel Setting > 20M: 5, 6, 7, 8, 13; 40M: 3~11 */
+	if ((*dm->channel >= 1) && (*dm->channel <= 14)) {
+		if (*dm->band_width == CHANNEL_WIDTH_20) {
+			if (*dm->channel >= 5 && *dm->channel <= 8)
+				idx = *dm->channel - 5;
+			else if (*dm->channel == 13)
+				idx = 4;
+			else
+				idx = 16;
+		} else {
+			if (*dm->channel >= 3 && *dm->channel <= 11)
+				idx = *dm->channel + 2;
+			else
+				idx = 16;
+		}
+	} else { /* 5G Channel Setting > 20M: 153, 161; 40M: 54, 118, 151, 159; 80M: 58, 122, 155, 155 */
+		switch (*dm->channel) {
+		case 153:
+			idx = 0;
+			break;
+		case 161:
+			idx = 1;
+			break;
+		case 54:
+			idx = 2;
+			break;
+		case 118:
+			idx = 3;
+			break;
+		case 151:
+			idx = 4;
+			break;
+		case 159:
+			idx = 5;
+			break;
+		case 58:
+			idx = 6;
+			break;
+		case 122:
+			idx = 7;
+			break;
+		case 155:
+			idx = 8;
+			break;
+		default:
+			idx = 16;
+			break;
+		}
+	}
+
+	if (idx <= 16) {
+		s_dopsd = true;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Return Point] Idx Is Exceed, Not Support Dynamic Spur Detection and Eliminator\n");
+		return;
+	}
+	
+	PHYDM_DBG(dm, ODM_COMP_API, "[%s] idx = %d, BW = %d, Channel = %d\n", __func__, idx, *dm->band_width, *dm->channel);
+
+	for (k = 0; k < FREQ_PT_2G_NUM; k++) {
+		freq_2g_n1[k] = freq_2g[k] - 1;
+		freq_2g_p1[k] = freq_2g[k] + 1;
+	}
+
+	for (k = 0; k < FREQ_PT_5G_NUM; k++) {
+		freq_5g_n1[k] = freq_5g[k] - 1;
+		freq_5g_p1[k] = freq_5g[k] + 1;
+	}
+
+	if (!s_dopsd || idx > 13) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Return Point] s_dopsd is flase, Not Support Dynamic Spur Detection and Eliminator\n");
+		return;
+	}
+
+	for (k = 0; k < PSD_SMP_NUM; k++) {
+		if (k == 0) {
+			freq_pt_2g_final = freq_2g_n1[idx];
+			freq_pt_2g_b_final = freq_2g_n1[idx] | BIT(16);
+			if (idx <= 10) {
+				freq_pt_5g_final = freq_5g_n1[idx];
+				freq_pt_5g_b_final = freq_5g_n1[idx] | BIT(16);
+			}
+		} else if (k == 1) {
+			freq_pt_2g_final = freq_2g[idx];
+			freq_pt_2g_b_final = freq_2g[idx] | BIT(16);
+			if (idx <= 10) {
+				freq_pt_5g_final = freq_5g[idx];
+				freq_pt_5g_b_final = freq_5g[idx] | BIT(16);
+			}
+		} else if (k == 2) {
+			freq_pt_2g_final = freq_2g_p1[idx];
+			freq_pt_2g_b_final = freq_2g_p1[idx] | BIT(16);
+			if (idx <= 10) {
+				freq_pt_5g_final = freq_5g_p1[idx];
+				freq_pt_5g_b_final = freq_5g_p1[idx] | BIT(16);
+			}
+		}
+
+		for (j = 0; j < PSD_VAL_NUM; j++) {
+			odm_set_bb_reg(dm, 0xc00, MASKBYTE0, 0x4);/* disable 3-wire, path-A */
+			odm_set_bb_reg(dm, 0xe00, MASKBYTE0, 0x4);/* disable 3-wire, path-B */
+			reg_910_15_12 = odm_get_bb_reg(dm, 0x910, (BIT(15) | BIT(14) | BIT(13) | BIT(12)));
+
+			if (dm->rx_ant_status & BB_PATH_A) {
+				odm_set_bb_reg(dm, 0x808, MASKBYTE0, (((BB_PATH_A)<<4) | BB_PATH_A));/*path-A*/
+
+				if ((*dm->channel >= 1) && (*dm->channel <= 14))
+					odm_set_bb_reg(dm, 0x910, MASKDWORD, BIT(22) | freq_pt_2g_final);/* Start PSD */
+				else
+					odm_set_bb_reg(dm, 0x910, MASKDWORD, BIT(22) | freq_pt_5g_final);/* Start PSD */
+
+				ODM_delay_us(500);
+
+				psd_set[j] = odm_get_bb_reg(dm, 0xf44, MASKLWORD);
+
+				odm_set_bb_reg(dm, 0x910, BIT(22), 0x0);/* turn off PSD */
+			}
+
+			if (dm->rx_ant_status & BB_PATH_B) {
+				odm_set_bb_reg(dm, 0x808, MASKBYTE0, (((BB_PATH_B)<<4) | BB_PATH_B));/*path-B*/
+
+				if ((*dm->channel > 0) && (*dm->channel <= 14))
+					odm_set_bb_reg(dm, 0x910, MASKDWORD, BIT(22) | freq_pt_2g_b_final);/* Start PSD */
+				else
+					odm_set_bb_reg(dm, 0x910, MASKDWORD, BIT(22) | freq_pt_5g_b_final);/* Start PSD */
+
+				ODM_delay_us(500);
+
+				psd_set_B[j] = odm_get_bb_reg(dm, 0xf44, MASKLWORD);
+
+				odm_set_bb_reg(dm, 0x910, BIT(22), 0x0);/* turn off PSD */
+			}
+
+			odm_set_bb_reg(dm, 0xc00, MASKBYTE0, 0x7);/*eanble 3-wire*/
+			odm_set_bb_reg(dm, 0xe00, MASKBYTE0, 0x7);
+			odm_set_bb_reg(dm, 0x910, (BIT(15) | BIT(14) | BIT(13) | BIT(12)), reg_910_15_12);
+
+			odm_set_bb_reg(dm, 0x808, MASKBYTE0, (((dm->rx_ant_status)<<4) | dm->rx_ant_status));
+
+			/* Toggle IGI to let RF enter RX mode, because BB doesn't send 3-wire command when RX path is enable */
+			phydm_igi_toggle_8822b(dm);
+
+		}
+		if (dm->rx_ant_status & BB_PATH_A) {
+			phydm_seq_sorting(dm, psd_set, rank_psd_index_in, rank_psd_index_out, PSD_VAL_NUM);
+			max_ret_psd_2nd[k] = psd_set[0];
+		}
+		if (dm->rx_ant_status & BB_PATH_B) {
+			phydm_seq_sorting(dm, psd_set_B, rank_psd_index_in, rank_psd_index_out, PSD_VAL_NUM);
+			max_ret_psd_b_2nd[k] = psd_set_B[0];
+		}
+	}
+
+	if (dm->rx_ant_status & BB_PATH_A) {
+		phydm_seq_sorting(dm, max_ret_psd_2nd, rank_sample_index_in, rank_sample_index_out, PSD_SMP_NUM);
+		max_ret_psd_final = max_ret_psd_2nd[0];
+
+		if (max_ret_psd_final >= threshold_nbi)
+			s_donbi_a = true;
+		else
+			s_donbi_a = false;
+	}
+	if (dm->rx_ant_status & BB_PATH_B) {
+		phydm_seq_sorting(dm, max_ret_psd_b_2nd, rank_sample_index_in, rank_sample_index_out, PSD_SMP_NUM);
+		max_ret_psd_b_final = max_ret_psd_b_2nd[0];
+
+		if (max_ret_psd_b_final >= threshold_nbi)
+			s_donbi_b = true;
+		else
+			s_donbi_b = false;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_API, "[%s] max_ret_psd_final = %d, max_ret_psd_b_final = %d\n", __func__, max_ret_psd_final, max_ret_psd_b_final);
+
+	if ((max_ret_psd_final >= threshold_csi) || (max_ret_psd_b_final >= threshold_csi))
+		s_docsi = true;
+	else
+		s_docsi = false;
+
+	if (s_donbi_a == true || s_donbi_b == true) {
+		if (*dm->band_width == CHANNEL_WIDTH_20) {
+			if (*dm->channel == 153)
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 20, 5760, PHYDM_DONT_CARE);
+			else if (*dm->channel == 161)
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 20, 5800, PHYDM_DONT_CARE);
+			else if (*dm->channel >= 5 && *dm->channel <= 8)
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 20, 2440, PHYDM_DONT_CARE);
+			else if (*dm->channel == 13)
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 20, 2480, PHYDM_DONT_CARE);
+			else
+				set_result_nbi = PHYDM_SET_NO_NEED;
+		} else if (*dm->band_width == CHANNEL_WIDTH_40) {
+			if (*dm->channel == 54) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5280, PHYDM_DONT_CARE);
+			} else if (*dm->channel == 118) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5600, PHYDM_DONT_CARE);
+			} else if (*dm->channel == 151) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5760, PHYDM_DONT_CARE);
+			} else if (*dm->channel == 159) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5800, PHYDM_DONT_CARE);
+				/* 2.4G */
+			} else if ((*dm->channel >= 4) && (*dm->channel <= 6)) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 40, 2440, PHYDM_DONT_CARE);
+			} else if (*dm->channel == 11) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 40, 2480, PHYDM_DONT_CARE);
+			} else
+				set_result_nbi = PHYDM_SET_NO_NEED;
+		} else if (*dm->band_width == CHANNEL_WIDTH_80) {
+			if (*dm->channel == 58) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 80, 5280, PHYDM_DONT_CARE);
+			} else if (*dm->channel == 122) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 80, 5600, PHYDM_DONT_CARE);
+			} else if (*dm->channel == 155) {
+				set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 80, 5760, PHYDM_DONT_CARE);
+			} else
+				set_result_nbi = PHYDM_SET_NO_NEED;
+		} else
+			set_result_nbi = PHYDM_SET_NO_NEED;
+	}
+
+	if (s_docsi == true) {
+		if (*dm->band_width == CHANNEL_WIDTH_20) {
+			if (*dm->channel == 153)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 20, 5760, PHYDM_DONT_CARE);
+			else if (*dm->channel == 161)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 20, 5800, PHYDM_DONT_CARE);
+			else if (*dm->channel >= 5 && *dm->channel <= 8)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 20, 2440, PHYDM_DONT_CARE);
+			else if (*dm->channel == 13)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 20, 2480, PHYDM_DONT_CARE);
+			else
+				set_result_csi = PHYDM_SET_NO_NEED;
+		} else if (*dm->band_width == CHANNEL_WIDTH_40) {
+			if (*dm->channel == 54)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5280, PHYDM_DONT_CARE);
+			else if (*dm->channel == 118)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5600, PHYDM_DONT_CARE);
+			else if (*dm->channel == 151)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5760, PHYDM_DONT_CARE);
+			else if (*dm->channel == 159)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 40, 5800, PHYDM_DONT_CARE);
+			else if ((*dm->channel >= 3) && (*dm->channel <= 10))
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 40, 2440, PHYDM_DONT_CARE);
+			else if (*dm->channel == 11)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 40, 2480, PHYDM_DONT_CARE);
+			else
+				set_result_csi = PHYDM_SET_NO_NEED;
+		} else if (*dm->band_width == CHANNEL_WIDTH_80) {
+			if (*dm->channel == 58)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 80, 5280, PHYDM_DONT_CARE);
+			else if (*dm->channel == 122)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 80, 5600, PHYDM_DONT_CARE);
+			else if (*dm->channel == 155)
+				set_result_csi = phydm_csi_mask_setting(dm, FUNC_ENABLE, *dm->channel, 80, 5760, PHYDM_DONT_CARE);
+			else
+				set_result_csi = PHYDM_SET_NO_NEED;
+		} else
+			set_result_csi = PHYDM_SET_NO_NEED;
+	}
+
+#endif	/*PHYDM_SPUR_CANCELL_ENABLE_8822B == 1*/
+}
+
+__iram_odm_func__
+boolean
+config_phydm_switch_band_8822b(
+	struct dm_struct				*dm,
+	u8					central_ch
+)
+{
+	u32		rf_reg18;
+	boolean		rf_reg_status = true;
+	u32		reg_8;
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_band_8822b()======================>\n");
+
+	if (dm->is_disable_phy_api) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_band_8822b(): disable PHY API for debug!!\n");
+		return true;
+	}
+
+	rf_reg18 = config_phydm_read_rf_reg_8822b(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK);
+	rf_reg_status = rf_reg_status & config_phydm_read_rf_check_8822b(rf_reg18);
+
+	if (central_ch <= 14) {
+		/* 2.4G */
+
+		/* Enable CCK block */
+		odm_set_bb_reg(dm, 0x808, BIT(28), 0x1);
+
+		/* Disable MAC CCK check */
+		odm_set_bb_reg(dm, 0x454, BIT(7), 0x0);
+
+		/* Disable BB CCK check */
+		odm_set_bb_reg(dm, 0xa80, BIT(18), 0x0);
+
+		/*CCA Mask*/
+		odm_set_bb_reg(dm, 0x814, 0x0000FC00, 15); /*default value*/
+
+		/* RF band */
+		rf_reg18 = (rf_reg18 & (~(BIT(16) | BIT(9) | BIT(8))));
+
+		/* RxHP dynamic control */
+		/* QFN eFEM RxHP are always low at 2G */
+		reg_8 = odm_get_bb_reg(dm, 0x19a8, BIT(31));
+		
+		/* SoML on */
+		if (reg_8 == 0x1) {
+			odm_set_bb_reg(dm, 0xc04, (BIT(18)|BIT(21)), 0x0);
+			odm_set_bb_reg(dm, 0xe04, (BIT(18)|BIT(21)), 0x0);
+			if ((dm->rfe_type == 3) || (dm->rfe_type == 5) || (dm->rfe_type == 8) || (dm->rfe_type == 17)) {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108492);
+				odm_set_bb_reg(dm, 0x8d8, BIT(19), 0x0);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x1);
+			} else {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+				odm_set_bb_reg(dm, 0x8d8, BIT(19), 0x0);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+			}
+		}
+
+		/* SoML off */
+		if (reg_8 == 0x0) {
+			odm_set_bb_reg(dm, 0xc04, (BIT(18)|BIT(21)), 0x0); 
+			odm_set_bb_reg(dm, 0xe04, (BIT(18)|BIT(21)), 0x0); 
+			if ((dm->rfe_type == 1) || (dm->rfe_type == 6) || (dm->rfe_type == 7) || (dm->rfe_type == 9)) {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+				odm_set_bb_reg(dm, 0x8d8, BIT(19), 0x0);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+			} else {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108492);
+				odm_set_bb_reg(dm, 0x8d8, BIT(19), 0x0);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x1);
+			}
+		}
+
+	} else if (central_ch > 35) {
+		/* 5G */
+
+		/* Enable BB CCK check */
+		odm_set_bb_reg(dm, 0xa80, BIT(18), 0x1);
+
+		/* Enable CCK check */
+		odm_set_bb_reg(dm, 0x454, BIT(7), 0x1);
+
+		/* Disable CCK block */
+		odm_set_bb_reg(dm, 0x808, BIT(28), 0x0);
+
+		/*CCA Mask*/
+	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		odm_set_bb_reg(dm, 0x814, 0x0000FC00, 34); /*CCA mask = 13.6us*/
+	#else	
+		if ((!dm->wifi_test))
+			odm_set_bb_reg(dm, 0x814, 0x0000FC00, 34); /*CCA mask = 13.6us*/
+		else
+			odm_set_bb_reg(dm, 0x814, 0x0000FC00, 15); /*default value*/
+	#endif
+
+		/* RF band */
+		rf_reg18 = (rf_reg18 & (~(BIT(16) | BIT(9) | BIT(8))));
+		rf_reg18 = (rf_reg18 | BIT(8) | BIT(16));
+
+		/* RxHP dynamic control */
+		reg_8 = odm_get_bb_reg(dm, 0x19a8, BIT(31));
+
+		/* SoML on */
+		if (reg_8 == 0x1) {
+			odm_set_bb_reg(dm, 0xc04, (BIT(18)|BIT(21)), 0x0);
+			odm_set_bb_reg(dm, 0xe04, (BIT(18)|BIT(21)), 0x0);
+			odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+			odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+		}
+
+		/* SoML off */
+		if (reg_8 == 0x0) {
+			odm_set_bb_reg(dm, 0xc04, (BIT(18)|BIT(21)), 0x0); 
+			odm_set_bb_reg(dm, 0xe04, (BIT(18)|BIT(21)), 0x0); 
+			if ((dm->rfe_type == 1) || (dm->rfe_type == 6) || (dm->rfe_type == 7) || (dm->rfe_type == 9)) {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+				odm_set_bb_reg(dm, 0x8d8, BIT(19), 0x0);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+			} else {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108492);
+				odm_set_bb_reg(dm, 0x8d8, BIT(19), 0x0);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x1);
+			}
+		}
+	} else {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_band_8822b(): Fail to switch band (ch: %d)\n", central_ch);
+		return false;
+	}
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, rf_reg18);
+
+	if (dm->rf_type > RF_1T1R)
+		odm_set_rf_reg(dm, RF_PATH_B, 0x18, RFREGOFFSETMASK, rf_reg18);
+
+	if (phydm_rfe_8822b(dm, central_ch) == false)
+		return false;
+
+	if (rf_reg_status == false) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_band_8822b(): Fail to switch band (ch: %d), because writing RF register is fail\n", central_ch);
+		return false;
+	}
+
+	/* Dynamic spur detection by PSD and NBI/CSI mask */
+	if (*dm->mp_mode)
+		phydm_dynamic_spur_det_eliminate(dm);
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_band_8822b(): Success to switch band (ch: %d)\n", central_ch);
+	return true;
+}
+
+__iram_odm_func__
+boolean
+config_phydm_switch_channel_8822b(
+	struct dm_struct				*dm,
+	u8					central_ch
+)
+{
+	struct phydm_dig_struct		*dig_tab = &dm->dm_dig_table;
+	u32		rf_reg18 = 0, rf_reg_be = 0xff;
+	boolean		rf_reg_status = true;
+	u8		low_band[15] = {0x7, 0x6, 0x6, 0x5, 0x0, 0x0, 0x7, 0xff, 0x6, 0x5, 0x0, 0x0, 0x7, 0x6, 0x6};
+	u8		middle_band[23] = {0x6, 0x5, 0x0, 0x0, 0x7, 0x6, 0x6, 0xff, 0x0, 0x0, 0x7, 0x6, 0x6, 0x5, 0x0, 0xff, 0x7, 0x6, 0x6, 0x5, 0x0, 0x0, 0x7};
+	u8		high_band[15] = {0x5, 0x5, 0x0, 0x7, 0x7, 0x6, 0x5, 0xff, 0x0, 0x7, 0x7, 0x6, 0x5, 0x5, 0x0};
+	u8		band_index = 0;
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b()====================>\n");
+
+	if (dm->is_disable_phy_api) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b(): disable PHY API for debug!!\n");
+		return true;
+	}
+
+	central_ch_8822b = central_ch;
+	
+	/* Errir handling for wrong HW setting due to wrong channel setting */
+	if (central_ch_8822b <= 14)
+		band_index = 1;
+	else
+		band_index = 2;
+
+	if (dm->rfe_hwsetting_band != band_index)
+		phydm_rfe_8822b(dm, central_ch_8822b);
+
+	if (dm->rfe_type == 15)
+		phydm_rfe_8822b(dm, central_ch_8822b);
+
+	/* RF register setting */
+	rf_reg18 = config_phydm_read_rf_reg_8822b(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK);
+	rf_reg_status = rf_reg_status & config_phydm_read_rf_check_8822b(rf_reg18);
+	rf_reg18 = (rf_reg18 & (~(BIT(18) | BIT(17) | MASKBYTE0)));
+
+	/* Switch band and channel */
+	if (central_ch <= 14) {
+		/* 2.4G */
+
+		/* 1. RF band and channel*/
+		rf_reg18 = (rf_reg18 | central_ch);
+
+		/* 2. AGC table selection */
+		odm_set_bb_reg(dm, 0x958, 0x1f, 0x0);
+		dig_tab->agc_table_idx = 0x0;
+
+		/* 3. Set central frequency for clock offset tracking */
+		odm_set_bb_reg(dm, 0x860, 0x1ffe0000, 0x96a);
+
+		/* CCK TX filter parameters */
+
+		if (central_ch == 14) {
+			odm_set_bb_reg(dm, 0xa24, MASKDWORD, 0x00006577);
+			odm_set_bb_reg(dm, 0xa28, MASKLWORD, 0x0000);
+		} else {
+			odm_set_bb_reg(dm, 0xa24, MASKDWORD, 0x384f6577);
+			odm_set_bb_reg(dm, 0xa28, MASKLWORD, 0x1525);
+		}
+
+	} else if (central_ch > 35) {
+		/* 5G */
+
+		/* 1. RF band and channel*/
+		rf_reg18 = (rf_reg18 | central_ch);
+
+		/* 2. AGC table selection */
+		if (!((dm->rfe_type == 15) || (dm->rfe_type == 16))) {
+			if ((central_ch >= 36) && (central_ch <= 64)) {
+				odm_set_bb_reg(dm, 0x958, 0x1f, 0x1);
+				dig_tab->agc_table_idx = 0x1;
+			} else if ((central_ch >= 100) && (central_ch <= 144)) {
+				odm_set_bb_reg(dm, 0x958, 0x1f, 0x2);
+				dig_tab->agc_table_idx = 0x2;
+			} else if (central_ch >= 149) {
+				odm_set_bb_reg(dm, 0x958, 0x1f, 0x3);
+				dig_tab->agc_table_idx = 0x3;
+			} else {
+				PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b(): Fail to switch channel (AGC) (ch: %d)\n", central_ch);
+				return false;
+			}
+		} else if ((dm->rfe_type == 15) || (dm->rfe_type == 16)) {
+			if (dm->brxagcswitch)
+				phydm_rxagc_switch_8822b(dm, true);
+			else
+				phydm_rxagc_switch_8822b(dm, false);
+		}
+
+		/* 3. Set central frequency for clock offset tracking */
+		if ((central_ch >= 36) && (central_ch <= 48))
+			odm_set_bb_reg(dm, 0x860, 0x1ffe0000, 0x494);
+		else if ((central_ch >= 52) && (central_ch <= 64))
+			odm_set_bb_reg(dm, 0x860, 0x1ffe0000, 0x453);
+		else if ((central_ch >= 100) && (central_ch <= 116))
+			odm_set_bb_reg(dm, 0x860, 0x1ffe0000, 0x452);
+		else if ((central_ch >= 118) && (central_ch <= 177))
+			odm_set_bb_reg(dm, 0x860, 0x1ffe0000, 0x412);
+		else {
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b(): Fail to switch channel (fc_area) (ch: %d)\n", central_ch);
+			return false;
+		}
+
+	} else {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b(): Fail to switch channel (ch: %d)\n", central_ch);
+		return false;
+	}
+
+	/* Modify IGI for MP driver to aviod PCIE interference */
+	if (*dm->mp_mode && ((dm->rfe_type == 3) || (dm->rfe_type == 5))) {
+		if (central_ch == 14)
+			odm_write_dig(dm, 0x26);
+		else
+			odm_write_dig(dm, 0x20);
+	}
+
+	/* Modify the setting of register 0xBE to reduce phase noise */
+	if (central_ch <= 14)
+		rf_reg_be = 0x0;
+	else if ((central_ch >= 36) && (central_ch <= 64))
+		rf_reg_be = low_band[(central_ch - 36) >> 1];
+	else if ((central_ch >= 100) && (central_ch <= 144))
+		rf_reg_be = middle_band[(central_ch - 100) >> 1];
+	else if ((central_ch >= 149) && (central_ch <= 177))
+		rf_reg_be = high_band[(central_ch - 149) >> 1];
+
+	if (rf_reg_be != 0xff)
+		odm_set_rf_reg(dm, RF_PATH_A, 0xbe, (BIT(17) | BIT(16) | BIT(15)), rf_reg_be);
+	else {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b(): Fail to switch channel (ch: %d, Phase noise)\n", central_ch);
+		return false;
+	}
+
+	/* Fix channel 144 issue, ask by RFSI Alvin*/
+	/* 00 when freq < 5400;  01 when 5400<=freq<=5720; 10 when freq > 5720; 2G don't care*/
+	/* need to set 0xdf[18]=1 before writing RF18 when channel 144 */
+	if (central_ch == 144) {
+		odm_set_rf_reg(dm, RF_PATH_A, 0xdf, BIT(18), 0x1);
+		rf_reg18 = (rf_reg18 | BIT(17));
+	} else {
+		odm_set_rf_reg(dm, RF_PATH_A, 0xdf, BIT(18), 0x0);
+
+		if (central_ch > 144)
+			rf_reg18 = (rf_reg18 | BIT(18));
+		else if (central_ch >= 80)
+			rf_reg18 = (rf_reg18 | BIT(17));
+	}
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, rf_reg18);
+
+	if (dm->rf_type > RF_1T1R)
+		odm_set_rf_reg(dm, RF_PATH_B, 0x18, RFREGOFFSETMASK, rf_reg18);
+
+	if (rf_reg_status == false) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b(): Fail to switch channel (ch: %d), because writing RF register is fail\n", central_ch);
+		return false;
+	}
+
+	/* Debug for RF resister reading error during synthesizer parameters parsing */
+	odm_set_rf_reg(dm, RF_PATH_A, 0xb8, BIT(19), 0);
+	odm_set_rf_reg(dm, RF_PATH_A, 0xb8, BIT(19), 1);
+
+	phydm_igi_toggle_8822b(dm);
+	/* Dynamic spur detection by PSD and NBI/CSI mask */
+	if (*dm->mp_mode)
+		phydm_dynamic_spur_det_eliminate(dm);
+
+	phydm_ccapar_by_rfe_8822b(dm);
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_channel_8822b(): Success to switch channel (ch: %d)\n", central_ch);
+	return true;
+}
+
+__iram_odm_func__
+boolean
+config_phydm_switch_bandwidth_8822b(
+	struct dm_struct				*dm,
+	u8					primary_ch_idx,
+	enum channel_width				bandwidth
+)
+{
+	u32		rf_reg18, val32;
+	boolean		rf_reg_status = true;
+	u8		rfe_type = dm->rfe_type;
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_bandwidth_8822b()===================>\n");
+
+	if (dm->is_disable_phy_api) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_bandwidth_8822b(): disable PHY API for debug!!\n");
+		return true;
+	}
+
+	/* Error handling */
+	if ((bandwidth >= CHANNEL_WIDTH_MAX) || ((bandwidth == CHANNEL_WIDTH_40) && (primary_ch_idx > 2)) || ((bandwidth == CHANNEL_WIDTH_80) && (primary_ch_idx > 4))) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_bandwidth_8822b(): Fail to switch bandwidth (bw: %d, primary ch: %d)\n", bandwidth, primary_ch_idx);
+		return false;
+	}
+
+	bw_8822b = bandwidth;
+	rf_reg18 = config_phydm_read_rf_reg_8822b(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK);
+	rf_reg_status = rf_reg_status & config_phydm_read_rf_check_8822b(rf_reg18);
+
+	/* Switch bandwidth */
+	switch (bandwidth) {
+	case CHANNEL_WIDTH_20:
+	{
+		/* Small BW([7:6]) = 0, primary channel ([5:2]) = 0, rf mode([1:0]) = 20M */
+		/* odm_set_bb_reg(dm, 0x8ac, MASKBYTE0, CHANNEL_WIDTH_20);*/
+
+		/* ADC clock = 160M clock for BW20 */
+		/* odm_set_bb_reg(dm, 0x8ac, (BIT(9) | BIT(8)), 0x0);*/
+		/* odm_set_bb_reg(dm, 0x8ac, BIT(16), 0x1);*/
+
+		/* DAC clock = 160M clock for BW20 */
+		/* odm_set_bb_reg(dm, 0x8ac, (BIT(21) | BIT(20)), 0x0);*/
+		/* odm_set_bb_reg(dm, 0x8ac, BIT(28), 0x1);*/
+
+		val32 = odm_get_bb_reg(dm, 0x8ac, MASKDWORD);
+		val32 &= 0xFFCFFC00;
+		val32 |= (CHANNEL_WIDTH_20);
+		odm_set_bb_reg(dm, 0x8ac, MASKDWORD, val32);
+
+		/* ADC buffer clock */
+		odm_set_bb_reg(dm, 0x8c4, BIT(30), 0x1);
+
+		/* RF bandwidth */
+		rf_reg18 = (rf_reg18 | BIT(11) | BIT(10));
+
+		break;
+	}
+	case CHANNEL_WIDTH_40:
+	{
+		/* Small BW([7:6]) = 0, primary channel ([5:2]) = sub-channel, rf mode([1:0]) = 40M */
+		/* odm_set_bb_reg(dm, 0x8ac, MASKBYTE0, (((primary_ch_idx & 0xf) << 2) | CHANNEL_WIDTH_40));*/
+
+		/* CCK primary channel */
+		if (primary_ch_idx == 1)
+			odm_set_bb_reg(dm, 0xa00, BIT(4), primary_ch_idx);
+		else
+			odm_set_bb_reg(dm, 0xa00, BIT(4), 0);
+
+		/* ADC clock = 160M clock for BW40 */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(11) | BIT(10)), 0x0);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(17), 0x1);*/
+
+		/* DAC clock = 160M clock for BW20 */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(23) | BIT(22)), 0x0);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(29), 0x1);*/
+
+		val32 = odm_get_bb_reg(dm, 0x8ac, MASKDWORD);
+		val32 &= 0xFF3FF300;
+		val32 |= (((primary_ch_idx & 0xf) << 2) | CHANNEL_WIDTH_40);
+		odm_set_bb_reg(dm, 0x8ac, MASKDWORD, val32);
+
+		/* ADC buffer clock */
+		odm_set_bb_reg(dm, 0x8c4, BIT(30), 0x1);
+
+		/* RF bandwidth */
+		rf_reg18 = (rf_reg18 & (~(BIT(11) | BIT(10))));
+		rf_reg18 = (rf_reg18 | BIT(11));
+
+		break;
+	}
+	case CHANNEL_WIDTH_80:
+	{
+		/* Small BW([7:6]) = 0, primary channel ([5:2]) = sub-channel, rf mode([1:0]) = 80M */
+		/*odm_set_bb_reg(dm, 0x8ac, MASKBYTE0, (((primary_ch_idx & 0xf) << 2) | CHANNEL_WIDTH_80));*/
+
+		/* ADC clock = 160M clock for BW80 */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(13) | BIT(12)), 0x0);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(18), 0x1);*/
+
+		/* DAC clock = 160M clock for BW20 */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(25) | BIT(24)), 0x0);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(30), 0x1);*/
+
+		val32 = odm_get_bb_reg(dm, 0x8ac, MASKDWORD);
+		val32 &= 0xFCEFCF00;
+		val32 |= (((primary_ch_idx & 0xf) << 2) | CHANNEL_WIDTH_80);
+		odm_set_bb_reg(dm, 0x8ac, MASKDWORD, val32);
+
+		/* ADC buffer clock */
+		odm_set_bb_reg(dm, 0x8c4, BIT(30), 0x1);
+
+		/* RF bandwidth */
+		rf_reg18 = (rf_reg18 & (~(BIT(11) | BIT(10))));
+		rf_reg18 = (rf_reg18 | BIT(10));
+
+		/* Parameters for SD4 TP requirement */
+		if ((rfe_type == 2) || (rfe_type == 3) || (rfe_type == 17) ) {
+			odm_set_bb_reg(dm, 0x840, 0x0000f000, 0x6);
+			odm_set_bb_reg(dm, 0x8c8, BIT(10), 0x1);
+		}
+
+		break;
+	}
+	case CHANNEL_WIDTH_5:
+	{
+		/* Small BW([7:6]) = 1, primary channel ([5:2]) = 0, rf mode([1:0]) = 20M */
+		/*dm_set_bb_reg(dm, 0x8ac, MASKBYTE0, (BIT(6) | CHANNEL_WIDTH_20));*/
+
+		/* ADC clock = 40M clock */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(9) | BIT(8)), 0x2);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(16), 0x0);*/
+
+		/* DAC clock = 160M clock for BW20 */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(21) | BIT(20)), 0x2);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(28), 0x0);*/
+
+		val32 = odm_get_bb_reg(dm, 0x8ac, MASKDWORD);
+		val32 &= 0xEFEEFE00;
+		val32 |= ((BIT(6) | CHANNEL_WIDTH_20));
+		odm_set_bb_reg(dm, 0x8ac, MASKDWORD, val32);
+
+		/* ADC buffer clock */
+		odm_set_bb_reg(dm, 0x8c4, BIT(30), 0x0);
+		odm_set_bb_reg(dm, 0x8c8, BIT(31), 0x1);
+
+		/* RF bandwidth */
+		rf_reg18 = (rf_reg18 | BIT(11) | BIT(10));
+
+		break;
+	}
+	case CHANNEL_WIDTH_10:
+	{
+		/* Small BW([7:6]) = 1, primary channel ([5:2]) = 0, rf mode([1:0]) = 20M */
+		/*odm_set_bb_reg(dm, 0x8ac, MASKBYTE0, (BIT(7) | CHANNEL_WIDTH_20));*/
+
+		/* ADC clock = 80M clock */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(9) | BIT(8)), 0x3);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(16), 0x0);*/
+
+		/* DAC clock = 160M clock for BW20 */
+		/*odm_set_bb_reg(dm, 0x8ac, (BIT(21) | BIT(20)), 0x3);*/
+		/*odm_set_bb_reg(dm, 0x8ac, BIT(28), 0x0);*/
+
+		val32 = odm_get_bb_reg(dm, 0x8ac, MASKDWORD);
+		val32 &= 0xEFFEFF00;
+		val32 |= ((BIT(7) | CHANNEL_WIDTH_20));
+		odm_set_bb_reg(dm, 0x8ac, MASKDWORD, val32);
+
+		/* ADC buffer clock */
+		odm_set_bb_reg(dm, 0x8c4, BIT(30), 0x0);
+		odm_set_bb_reg(dm, 0x8c8, BIT(31), 0x1);
+
+		/* RF bandwidth */
+		rf_reg18 = (rf_reg18 | BIT(11) | BIT(10));
+
+		break;
+	}
+	default:
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_bandwidth_8822b(): Fail to switch bandwidth (bw: %d, primary ch: %d)\n", bandwidth, primary_ch_idx);
+	}
+
+	/* Write RF register */
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, rf_reg18);
+
+	if (dm->rf_type > RF_1T1R)
+		odm_set_rf_reg(dm, RF_PATH_B, 0x18, RFREGOFFSETMASK, rf_reg18);
+
+	if (rf_reg_status == false) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_bandwidth_8822b(): Fail to switch bandwidth (bw: %d, primary ch: %d), because writing RF register is fail\n", bandwidth, primary_ch_idx);
+		return false;
+	}
+
+	/* Modify RX DFIR parameters */
+	phydm_rxdfirpar_by_bw_8822b(dm, bandwidth);
+
+	/* Toggle IGI to let RF enter RX mode */
+	phydm_igi_toggle_8822b(dm);
+
+	/* Dynamic spur detection by PSD and NBI/CSI mask */
+	if (*dm->mp_mode)
+		phydm_dynamic_spur_det_eliminate(dm);
+
+	/* Modify CCA parameters */
+	phydm_ccapar_by_rfe_8822b(dm);
+
+	/* Toggle RX path to avoid RX dead zone issue */
+	odm_set_bb_reg(dm, 0x808, MASKBYTE0, 0x0);
+	odm_set_bb_reg(dm, 0x808, MASKBYTE0, (dm->rx_ant_status | (dm->rx_ant_status << 4)));
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "config_phydm_switch_bandwidth_8822b(): Success to switch bandwidth (bw: %d, primary ch: %d)\n", bandwidth, primary_ch_idx);
+	return true;
+}
+
+__iram_odm_func__
+boolean
+config_phydm_switch_channel_bw_8822b(
+	struct dm_struct				*dm,
+	u8					central_ch,
+	u8					primary_ch_idx,
+	enum channel_width				bandwidth
+)
+{
+	/* Switch band */
+	if (config_phydm_switch_band_8822b(dm, central_ch) == false)
+		return false;
+
+	/* Switch channel */
+	if (config_phydm_switch_channel_8822b(dm, central_ch) == false)
+		return false;
+
+	/* Switch bandwidth */
+	if (config_phydm_switch_bandwidth_8822b(dm, primary_ch_idx, bandwidth) == false)
+		return false;
+
+	return true;
+}
+
+__iram_odm_func__
+boolean
+config_phydm_trx_mode_8822b(
+	struct dm_struct				*dm,
+	enum bb_path			tx_path,
+	enum bb_path			rx_path,
+	boolean					is_tx2_path
+)
+{
+	u32		rf_reg33 = 0;
+	u16		counter = 0;
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s ======>\n", __func__);
+
+	if (dm->is_disable_phy_api) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "disable PHY API\n");
+		return true;
+	}
+
+	if (((tx_path & (~BB_PATH_AB)) != 0) || ((rx_path & (~BB_PATH_AB)) != 0)) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "Wrong setting: TX:0x%x, RX:0x%x\n", tx_path, rx_path);
+		return false;
+	}
+
+	/* [mode table] RF mode of path-A and path-B ===========================*/
+	/* Cannot shut down path-A, beacause synthesizer will be shut down when path-A is in shut down mode */
+	/* 3-wire setting */
+	/*0: shutdown, 1: standby, 2: TX, 3: RX */
+	
+	if ((tx_path | rx_path) & BB_PATH_A)
+		odm_set_bb_reg(dm, 0xc08, MASKLWORD, 0x3231);
+	else
+		odm_set_bb_reg(dm, 0xc08, MASKLWORD, 0x1111);
+
+	if ((tx_path | rx_path) & BB_PATH_B)
+		odm_set_bb_reg(dm, 0xe08, MASKLWORD, 0x3231);
+	else
+		odm_set_bb_reg(dm, 0xe08, MASKLWORD, 0x1111);
+
+	/*[TX Antenna Setting] ==========================================*/
+	
+	/* Set TX antenna by Nsts */
+	odm_set_bb_reg(dm, 0x93c, (BIT(19) | BIT(18)), 0x3);
+	odm_set_bb_reg(dm, 0x80c, (BIT(29) | BIT(28)), 0x1);
+
+	/* Control CCK TX path by 0xa07[7] */
+	odm_set_bb_reg(dm, 0x80c, BIT(30), 0x1);
+
+	/* TX logic map and TX path en for Nsts = 1, and CCK TX path*/
+	if (tx_path & BB_PATH_A) {
+		odm_set_bb_reg(dm, 0x93c, 0xfff00000, 0x001);
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0x8);
+	} else if (tx_path & BB_PATH_B) {
+		odm_set_bb_reg(dm, 0x93c, 0xfff00000, 0x002);
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0x4);
+	}
+
+	/* TX logic map and TX path en for Nsts = 2*/
+	/* Due to LO is stand-by while 1T at path-b in normal driver, so 0x940 is the same setting btw path-A/B*/
+	if ((tx_path == BB_PATH_A) || (tx_path == BB_PATH_B))
+		odm_set_bb_reg(dm, 0x940, 0xfff0, 0x01);
+	else
+		odm_set_bb_reg(dm, 0x940, 0xfff0, 0x43);
+
+	odm_set_bb_reg(dm, 0x80c, MASKBYTE0, ((tx_path << 4) | tx_path));/* TX path HW block enable */
+
+	/* Tx2path for 1ss */
+	if (!((tx_path == BB_PATH_A) || (tx_path == BB_PATH_B))) {
+		if (is_tx2_path || *dm->mp_mode) {
+			
+			odm_set_bb_reg(dm, 0x93c, 0xfff00000, 0x043);	/* 2Tx for OFDM */
+			odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0xc);	/* 2Tx for CCK */
+		}
+	}
+	
+	/*[RX Antenna Setting] ==========================================*/
+
+	odm_set_bb_reg(dm, 0xa2c, BIT(22), 0x0);	/*Disable MRC for CCK CCA */
+	odm_set_bb_reg(dm, 0xa2c, BIT(18), 0x0);	/*Disable MRC for CCK barker */
+
+	/* CCK RX 1st and 2nd path setting*/
+	if (rx_path & BB_PATH_A)
+		odm_set_bb_reg(dm, 0xa04, 0x0f000000, 0x0); /*00,00*/
+	else if (rx_path & BB_PATH_B)
+		odm_set_bb_reg(dm, 0xa04, 0x0f000000, 0x5);/*01,01*/
+
+	/* RX path enable */
+	odm_set_bb_reg(dm, 0x808, MASKBYTE0, ((rx_path << 4) | rx_path));
+
+	if ((rx_path == BB_PATH_A) || (rx_path == BB_PATH_B)) {
+		/* 1R */
+
+		/* Disable MRC for CCA */
+		/* odm_set_bb_reg(dm, 0xa2c, BIT22, 0x0); */
+
+		/* Disable MRC for barker */
+		/* odm_set_bb_reg(dm, 0xa2c, BIT18, 0x0); */
+
+		/* Disable CCK antenna diversity */
+		/* odm_set_bb_reg(dm, 0xa00, BIT15, 0x0); */
+
+		/* Disable Antenna weighting */
+		odm_set_bb_reg(dm, 0x1904, BIT(16), 0x0);	/*AntWgt_en*/
+		odm_set_bb_reg(dm, 0x800, BIT(28), 0x0);	/*htstf ant-wgt enable = 0*/
+		odm_set_bb_reg(dm, 0x850, BIT(23), 0x0);	/*MRC_mode  =  'original ZF eqz'*/
+	} else {
+		/* 2R */
+
+		/* Enable MRC for CCA */
+		/* odm_set_bb_reg(dm, 0xa2c, BIT22, 0x1); */
+
+		/* Enable MRC for barker */
+		/* odm_set_bb_reg(dm, 0xa2c, BIT18, 0x1); */
+
+		/* Disable CCK antenna diversity */
+		/* odm_set_bb_reg(dm, 0xa00, BIT15, 0x0); */
+
+		/* Enable Antenna weighting */
+		odm_set_bb_reg(dm, 0x1904, BIT(16), 0x1);	/*AntWgt_en*/
+		odm_set_bb_reg(dm, 0x800, BIT(28), 0x1);	/*htstf ant-wgt enable = 1*/
+		odm_set_bb_reg(dm, 0x850, BIT(23), 0x1);	/*MRC_mode =  'modified ZF eqz'*/
+	}
+
+	/* Update TXRX antenna status for PHYDM */
+	dm->tx_ant_status = (tx_path & 0x3);
+	dm->rx_ant_status = (rx_path & 0x3);
+
+	/* MP driver need to support path-B TX\RX */
+
+	while (1) {
+		counter++;
+		odm_set_rf_reg(dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x80000);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00001);
+
+		ODM_delay_us(2);
+		rf_reg33 = config_phydm_read_rf_reg_8822b(dm, RF_PATH_A, 0x33, RFREGOFFSETMASK);
+
+		if ((rf_reg33 == 0x00001) && (config_phydm_read_rf_check_8822b(rf_reg33)))
+			break;
+		else if (counter == 100) {
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "Fail to set TRx mode setting, because writing RF mode table is fail\n");
+			return false;
+		}
+	}
+
+	if (*dm->mp_mode || (*dm->antenna_test) || (dm->normal_rx_path)) {
+		/*	0xef 0x80000  0x33 0x00001  0x3e 0x00034  0x3f 0x4080e  0xef 0x00000    suggested by Lucas*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x80000);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00001);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x00034);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0x4080e);
+		odm_set_rf_reg(dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x00000);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "MP mode or Antenna test mode!! support path-B TX and RX\n");
+	} else {
+		/*	0xef 0x80000  0x33 0x00001  0x3e 0x00034  0x3f 0x4080c  0xef 0x00000 */
+		odm_set_rf_reg(dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x80000);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00001);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x00034);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0x4080c);
+		odm_set_rf_reg(dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x00000);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "Normal mode!! Do not support path-B TX and RX\n");
+	}
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x00000);
+
+	/* Toggle igi to let RF enter RX mode, because BB doesn't send 3-wire command when RX path is enable */
+	phydm_igi_toggle_8822b(dm);
+
+	/* Modify CCA parameters */
+	phydm_ccapar_by_rfe_8822b(dm);
+
+	/* HW Setting depending on RFE type & band */
+	phydm_rfe_8822b(dm, central_ch_8822b);
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "Success to set TRx mode setting (TX: 0x%x, RX: 0x%x)\n", tx_path, rx_path);
+	return true;
+}
+
+__iram_odm_func__
+boolean
+config_phydm_parameter_init_8822b(
+	struct dm_struct				*dm,
+	enum odm_parameter_init	type
+)
+{
+	if (type == ODM_PRE_SETTING) {
+		odm_set_bb_reg(dm, 0x808, (BIT(28) | BIT(29)), 0x0);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: Pre setting: disable OFDM and CCK block\n", __func__);
+	} else if (type == ODM_POST_SETTING) {
+		odm_set_bb_reg(dm, 0x808, (BIT(28) | BIT(29)), 0x3);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: Post setting: enable OFDM and CCK block\n", __func__);
+#if (PHYDM_FW_API_FUNC_ENABLE_8822B == 1)
+	} else if (type == ODM_INIT_FW_SETTING) {
+		u8	h2c_content[4] = {0};
+		
+		h2c_content[0] = dm->rfe_type;
+		h2c_content[1] = dm->rf_type;
+		h2c_content[2] = dm->cut_version;
+		h2c_content[3] = (dm->tx_ant_status << 4) | dm->rx_ant_status;
+		
+		odm_fill_h2c_cmd(dm, PHYDM_H2C_FW_GENERAL_INIT, 4, h2c_content);
+#endif
+	} else {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: Wrong type!!\n", __func__);
+		return false;
+	}
+
+	return true;
+}
+
+/* ======================================================================== */
+#endif	/*PHYDM_FW_API_ENABLE_8822B == 1*/
+#endif	/* RTL8822B_SUPPORT == 1 */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_hal_api8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_hal_api8822b.h
new file mode 100644
index 000000000000..bb70224fcdfc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_hal_api8822b.h
@@ -0,0 +1,167 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __INC_PHYDM_API_H_8822B__
+#define __INC_PHYDM_API_H_8822B__
+
+#if (RTL8822B_SUPPORT == 1)
+
+#define	PHY_CONFIG_VERSION_8822B			"28.5.34"	/*2017.01.18     (HW user guide version: R28, SW user guide version: R05, Modification: R34), remove A cut setting, refine CCK txfilter and OFDM CCA setting by YuChen*/
+
+#define	SMTANT_TMP_RFE_TYPE	100
+
+#define	INVALID_RF_DATA					0xffffffff
+#define	INVALID_TXAGC_DATA				0xff
+
+#define	PSD_VAL_NUM			5
+#define	PSD_SMP_NUM			3
+#define	FREQ_PT_2G_NUM		14
+#define	FREQ_PT_5G_NUM		10
+
+#define number_channel_interferecne		4
+
+#define	config_phydm_read_rf_check_8822b(data)			(data != INVALID_RF_DATA)
+#define	config_phydm_read_txagc_check_8822b(data)		(data != INVALID_TXAGC_DATA)
+
+void
+phydm_rxagc_switch_8822b(
+		struct dm_struct		*dm,
+		boolean enable_rxagc_swich
+);
+
+void
+phydm_rfe_8822b_init(
+	struct dm_struct	*dm
+);
+
+boolean
+phydm_rfe_8822b(
+	struct dm_struct	*dm,
+	u8						channel
+);
+
+u32
+config_phydm_read_rf_reg_8822b(
+	struct dm_struct				*dm,
+	enum rf_path		path,
+	u32					reg_addr,
+	u32					bit_mask
+);
+
+boolean
+config_phydm_write_rf_reg_8822b(
+	struct dm_struct				*dm,
+	enum rf_path		path,
+	u32					reg_addr,
+	u32					bit_mask,
+	u32					data
+);
+
+boolean
+config_phydm_write_txagc_8822b(
+	struct dm_struct				*dm,
+	u32					power_index,
+	enum rf_path		path,
+	u8					hw_rate
+);
+
+u8
+config_phydm_read_txagc_8822b(
+	struct dm_struct				*dm,
+	enum rf_path		path,
+	u8					hw_rate
+);
+
+void
+phydm_dynamic_spur_det_eliminate(
+	struct dm_struct				*dm
+);
+
+boolean
+config_phydm_switch_band_8822b(
+	struct dm_struct				*dm,
+	u8					central_ch
+);
+
+boolean
+config_phydm_switch_channel_8822b(
+	struct dm_struct				*dm,
+	u8					central_ch
+);
+
+boolean
+config_phydm_switch_bandwidth_8822b(
+	struct dm_struct				*dm,
+	u8					primary_ch_idx,
+	enum channel_width				bandwidth
+);
+
+boolean
+config_phydm_switch_channel_bw_8822b(
+	struct dm_struct				*dm,
+	u8					central_ch,
+	u8					primary_ch_idx,
+	enum channel_width				bandwidth
+);
+
+boolean
+config_phydm_trx_mode_8822b(
+	struct dm_struct				*dm,
+	enum bb_path			tx_path,
+	enum bb_path			rx_path,
+	boolean					is_tx2_path
+);
+
+boolean
+config_phydm_parameter_init_8822b(
+	struct dm_struct				*dm,
+	enum odm_parameter_init	type
+);
+
+
+/* ======================================================================== */
+/* These following functions can be used for PHY DM only*/
+
+boolean
+phydm_write_txagc_1byte_8822b(
+	struct dm_struct				*dm,
+	u32					power_index,
+	enum rf_path		path,
+	u8					hw_rate
+);
+
+void
+phydm_init_hw_info_by_rfe_type_8822b(
+	struct dm_struct				*dm
+);
+
+s32
+phydm_get_condition_number_8822B(
+	struct dm_struct				*dm
+);
+
+/* ======================================================================== */
+
+#endif	/* RTL8822B_SUPPORT == 1 */
+#endif	/*  __INC_PHYDM_API_H_8822B__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_regconfig8822b.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_regconfig8822b.c
new file mode 100644
index 000000000000..e530fe766509
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_regconfig8822b.c
@@ -0,0 +1,317 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8822B_SUPPORT == 1)
+
+void
+odm_config_rf_reg_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data,
+	enum rf_path		rf_path,
+	u32					reg_addr
+)
+{
+	if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+		if (addr == 0xffe)
+			phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_DELAY_MS,
+							reg_addr,
+							data,
+							RFREGOFFSETMASK,
+							rf_path,
+							50);
+		else if (addr == 0xfe)
+			phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_DELAY_US,
+							reg_addr,
+							data,
+							RFREGOFFSETMASK,
+							rf_path,
+							100);
+		else {	
+			phydm_set_reg_by_fw(dm,
+								PHYDM_HALMAC_CMD_RF_W,
+								reg_addr,
+								data,
+								RFREGOFFSETMASK,
+								rf_path,
+								0);
+			phydm_set_reg_by_fw(dm,
+								PHYDM_HALMAC_CMD_DELAY_US,
+								reg_addr,
+								data,
+								RFREGOFFSETMASK,
+								rf_path,
+								1);
+		}
+	} else {
+		if (addr == 0xffe) {
+#ifdef CONFIG_LONG_DELAY_ISSUE
+			ODM_sleep_ms(50);
+#else
+			ODM_delay_ms(50);
+#endif
+		} else if (addr == 0xfe) {
+#ifdef CONFIG_LONG_DELAY_ISSUE
+			ODM_sleep_us(100);
+#else
+			ODM_delay_us(100);
+#endif
+		} else {
+			odm_set_rf_reg(dm, rf_path, reg_addr, RFREGOFFSETMASK, data);
+
+			/* Add 1us delay between BB/RF register setting. */
+			ODM_delay_us(1);
+		}
+	}
+}
+
+void
+odm_config_rf_radio_a_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+)
+{
+	u32	content = 0x1000;							/* RF_Content: radioa_txt */
+	u32	maskfor_phy_set = (u32)(content & 0xE000);
+
+	odm_config_rf_reg_8822b(dm, addr, data, RF_PATH_A, addr | maskfor_phy_set);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> config_rf: [RadioA] %08X %08X\n", addr, data);
+}
+
+void
+odm_config_rf_radio_b_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+)
+{
+	u32	content = 0x1001;							/* RF_Content: radiob_txt */
+	u32	maskfor_phy_set = (u32)(content & 0xE000);
+
+	odm_config_rf_reg_8822b(dm, addr, data, RF_PATH_B, addr | maskfor_phy_set);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> config_rf: [RadioB] %08X %08X\n", addr, data);
+}
+
+void
+odm_config_mac_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u8					data
+)
+{
+	if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD)
+		phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_MAC_W8,
+							addr,
+							data,
+							0,
+							(enum rf_path)0,
+							0);
+	else
+		odm_write_1byte(dm, addr, data);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> config_mac: [MAC_REG] %08X %08X\n", addr, data);
+}
+
+void
+odm_update_agc_big_jump_lmt_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+)
+{
+	struct phydm_dig_struct	*dig_tab = &dm->dm_dig_table;
+	u8	rf_gain_idx = (u8)((data & 0xFF000000) >> 24);
+	u8	bb_gain_idx = (u8)((data & 0x00ff0000) >> 16);
+	u8	agc_table_idx = (u8)((data & 0x00000f00) >> 8);
+	static	boolean	is_limit;
+
+	if (addr != 0x81c)
+		return;
+
+	/*dbg_print("data = 0x%x, rf_gain_idx = 0x%x, bb_gain_idx = 0x%x, agc_table_idx = 0x%x\n", data, rf_gain_idx, bb_gain_idx, agc_table_idx);*/
+	/*dbg_print("rf_gain_idx = 0x%x, dig_tab->rf_gain_idx = 0x%x\n", rf_gain_idx, dig_tab->rf_gain_idx);*/
+
+	if (bb_gain_idx > 0x3c) {
+		if ((rf_gain_idx == dig_tab->rf_gain_idx) && !is_limit) {
+			is_limit = true;
+			dig_tab->big_jump_lmt[agc_table_idx] = bb_gain_idx - 2;
+			PHYDM_DBG(dm, DBG_DIG, "===> [AGC_TAB] big_jump_lmt [%d] = 0x%x\n", agc_table_idx, dig_tab->big_jump_lmt[agc_table_idx]);
+		}
+	} else
+		is_limit = false;
+
+	dig_tab->rf_gain_idx = rf_gain_idx;
+
+}
+
+void
+odm_config_bb_agc_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					bitmask,
+	u32					data
+)
+{
+	odm_update_agc_big_jump_lmt_8822b(dm, addr, data);
+
+	if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD)
+		phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_BB_W32,
+							addr,
+							data,
+							bitmask,
+							(enum rf_path)0,
+							0);
+	else
+		odm_set_bb_reg(dm, addr, bitmask, data);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> config_bb: [AGC_TAB] %08X %08X\n", addr, data);
+}
+
+void
+odm_config_bb_phy_reg_pg_8822b(
+	struct dm_struct				*dm,
+	u32					band,
+	u32					rf_path,
+	u32					tx_num,
+	u32					addr,
+	u32					bitmask,
+	u32					data
+)
+{
+	if (addr == 0xfe || addr == 0xffe) {
+#ifdef CONFIG_LONG_DELAY_ISSUE
+		ODM_sleep_ms(50);
+#else
+		ODM_delay_ms(50);
+#endif
+	} else {
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE)
+		phy_store_tx_power_by_rate(dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		PHY_StoreTxPowerByRate((PADAPTER)dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
+#endif
+
+	}
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> config_bb: [PHY_REG] %08X %08X %08X\n", addr, bitmask, data);
+}
+
+void
+odm_config_bb_phy_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					bitmask,
+	u32					data
+)
+{
+	if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+		u32 delay_time = 0;
+
+		if (addr >= 0xf9 && addr <= 0xfe) {
+			if (addr == 0xfe || addr == 0xfb)
+				delay_time = 50;
+			else if (addr == 0xfd || addr == 0xfa)
+				delay_time = 5;
+			else
+				delay_time = 1;
+
+			if (addr >= 0xfc && addr <=0xfe)
+				phydm_set_reg_by_fw(dm,
+									PHYDM_HALMAC_CMD_DELAY_MS,
+									addr,
+									data,
+									bitmask,
+									(enum rf_path)0,
+									delay_time);
+			else
+				phydm_set_reg_by_fw(dm,
+									PHYDM_HALMAC_CMD_DELAY_US,
+									addr,
+									data,
+									bitmask,
+									(enum rf_path)0,
+									delay_time);
+		} else 
+			phydm_set_reg_by_fw(dm,
+								PHYDM_HALMAC_CMD_BB_W32,
+								addr,
+								data,
+								bitmask,
+								(enum rf_path)0,
+								0);
+	} else {
+		if (addr == 0xfe)
+#ifdef CONFIG_LONG_DELAY_ISSUE
+			ODM_sleep_ms(50);
+#else
+			ODM_delay_ms(50);
+#endif
+		else if (addr == 0xfd)
+			ODM_delay_ms(5);
+		else if (addr == 0xfc)
+			ODM_delay_ms(1);
+		else if (addr == 0xfb)
+			ODM_delay_us(50);
+		else if (addr == 0xfa)
+			ODM_delay_us(5);
+		else if (addr == 0xf9)
+			ODM_delay_us(1);
+		else
+			odm_set_bb_reg(dm, addr, bitmask, data);
+	}
+	
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> config_bb: [PHY_REG] %08X %08X\n", addr, data);
+}
+
+void
+odm_config_bb_txpwr_lmt_8822b(
+	struct dm_struct				*dm,
+	u8					*regulation,
+	u8					*band,
+	u8					*bandwidth,
+	u8					*rate_section,
+	u8					*rf_path,
+	u8					*channel,
+	u8					*power_limit
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	phy_set_tx_power_limit(dm, regulation, band,
+		       bandwidth, rate_section, rf_path, channel, power_limit);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetTxPowerLimit(dm, regulation, band,
+		       bandwidth, rate_section, rf_path, channel, power_limit);
+#endif
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_regconfig8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_regconfig8822b.h
new file mode 100644
index 000000000000..3d8c6481ebc5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_regconfig8822b.h
@@ -0,0 +1,107 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __INC_ODM_REGCONFIG_H_8822B
+#define __INC_ODM_REGCONFIG_H_8822B
+
+#if (RTL8822B_SUPPORT == 1)
+
+void
+odm_config_rf_reg_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data,
+	enum rf_path		rf_path,
+	u32					reg_addr
+);
+
+void
+odm_config_rf_radio_a_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+);
+
+void
+odm_config_rf_radio_b_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+);
+
+void
+odm_config_mac_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u8					data
+);
+
+void
+odm_update_agc_big_jump_lmt_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+);
+
+void
+odm_config_bb_agc_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					bitmask,
+	u32					data
+);
+
+void
+odm_config_bb_phy_reg_pg_8822b(
+	struct dm_struct				*dm,
+	u32					band,
+	u32					rf_path,
+	u32					tx_num,
+	u32					addr,
+	u32					bitmask,
+	u32					data
+);
+
+void
+odm_config_bb_phy_8822b(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					bitmask,
+	u32					data
+);
+
+void
+odm_config_bb_txpwr_lmt_8822b(
+	struct dm_struct				*dm,
+	u8					*regulation,
+	u8					*band,
+	u8					*bandwidth,
+	u8					*rate_section,
+	u8					*rf_path,
+	u8					*channel,
+	u8					*power_limit
+);
+
+#endif
+#endif /* RTL8822B_SUPPORT == 1*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_rtl8822b.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_rtl8822b.c
new file mode 100644
index 000000000000..084286ffbde7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_rtl8822b.c
@@ -0,0 +1,515 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8822B_SUPPORT == 1)
+
+
+void
+phydm_dynamic_switch_htstf_mumimo_8822b(
+	struct dm_struct		*dm
+)
+{
+	u8		rssi_l2h = 40, rssi_h2l = 35;
+
+	/*if Pin > -60dBm, enable HT-STF gain controller, otherwise, if rssi < -65dBm, disable the controller*/
+
+	if (dm->rssi_min >= rssi_l2h)
+		odm_set_bb_reg(dm, 0x8d8, BIT(17), 0x1);
+	else if (dm->rssi_min < rssi_h2l)
+		odm_set_bb_reg(dm, 0x8d8, BIT(17), 0x0);
+
+}
+
+void
+phydm_dynamic_parameters_ota(
+	struct dm_struct		*dm
+)
+{
+	u8	rssi_l2h = 40, rssi_h2l = 35;
+
+	if ((*dm->channel <= 14) && (*dm->band_width == CHANNEL_WIDTH_20)) {
+		if (dm->rssi_min >= rssi_l2h) {
+			/*if (dm->bhtstfdisabled == false)*/
+				odm_set_bb_reg(dm, 0x8d8, BIT(17), 0x1);
+			
+			odm_set_bb_reg(dm, 0x98c, 0x7fc0000, 0x0);
+			odm_set_bb_reg(dm, 0x818, 0x7000000, 0x1);
+			odm_set_bb_reg(dm, 0xc04, BIT(18), 0x0);
+			odm_set_bb_reg(dm, 0xe04, BIT(18), 0x0);
+			if (dm->p_advance_ota & PHYDM_HP_OTA_SETTING_A) {
+				odm_set_bb_reg(dm, 0x19d8, MASKDWORD, 0x444);
+				odm_set_bb_reg(dm, 0x19d4, MASKDWORD, 0x4444aaaa);
+			} else if (dm->p_advance_ota & PHYDM_HP_OTA_SETTING_B) {
+				odm_set_bb_reg(dm, 0x19d8, MASKDWORD, 0x444);
+				odm_set_bb_reg(dm, 0x19d4, MASKDWORD, 0x444444aa);
+			}
+		} else if (dm->rssi_min < rssi_h2l) {
+			/*if (dm->bhtstfdisabled == true)*/
+				odm_set_bb_reg(dm, 0x8d8, BIT(17), 0x0);
+			
+			odm_set_bb_reg(dm, 0x98c, MASKDWORD, 0x43440000);
+			odm_set_bb_reg(dm, 0x818, 0x7000000, 0x4);
+			odm_set_bb_reg(dm, 0xc04, (BIT(18)|BIT(21)), 0x0);
+			odm_set_bb_reg(dm, 0xe04, (BIT(18)|BIT(21)), 0x0);
+			odm_set_bb_reg(dm, 0x19d8, MASKDWORD, 0xaaa);
+			odm_set_bb_reg(dm, 0x19d4, MASKDWORD, 0xaaaaaaaa);
+		}
+	} else {
+			//odm_set_bb_reg(dm, 0x8d8, BIT(17), 0x0);
+			odm_set_bb_reg(dm, 0x98c, MASKDWORD, 0x43440000);
+			odm_set_bb_reg(dm, 0x818, 0x7000000, 0x4);
+			odm_set_bb_reg(dm, 0xc04, (BIT(18)|BIT(21)), 0x0);
+			odm_set_bb_reg(dm, 0xe04, (BIT(18)|BIT(21)), 0x0);
+			odm_set_bb_reg(dm, 0x19d8, MASKDWORD, 0xaaa);
+			odm_set_bb_reg(dm, 0x19d4, MASKDWORD, 0xaaaaaaaa);
+		}
+}
+
+static
+void
+_set_tx_a_cali_value(
+	struct dm_struct		*dm,
+	enum rf_path				rf_path,
+	u8 						offset,
+	u8 						tx_a_bias_offset
+	)
+{
+	u32 modi_tx_a_value = 0;
+	u8 tmp1_byte = 0;
+	boolean is_minus = false;
+	u8 comp_value = 0;
+
+	
+		switch (offset) {
+		case 0x0:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X10124);
+			break;
+		case 0x1:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X10524);
+			break;
+		case 0x2:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X10924);
+			break;
+		case 0x3:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X10D24);
+			break;
+		case 0x4:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X30164);
+			break;
+		case 0x5:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X30564);
+			break;
+		case 0x6:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X30964);
+			break;
+		case 0x7:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X30D64);
+			break;
+		case 0x8:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X50195);
+			break;
+		case 0x9:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X50595);
+			break;
+		case 0xa:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X50995);
+			break;
+		case 0xb:
+			odm_set_rf_reg(dm, rf_path, 0x18, 0xFFFFF, 0X50D95);
+			break;
+		default:
+			PHYDM_DBG(dm, ODM_COMP_API, "Invalid TxA band offset...\n");
+			return;
+			break;
+	}
+
+	/* Get TxA value */
+	modi_tx_a_value = odm_get_rf_reg(dm, rf_path, 0x61, 0xFFFFF);
+	tmp1_byte = (u8)modi_tx_a_value&(BIT(3)|BIT(2)|BIT(1)|BIT(0));
+
+	/* check how much need to calibration */
+		switch (tx_a_bias_offset) {
+		case 0xF6:
+			is_minus = true;
+			comp_value = 3;
+			break;
+			
+		case 0xF4:
+			is_minus = true;
+			comp_value = 2;
+			break;
+			
+		case 0xF2:
+			is_minus = true;
+			comp_value = 1;
+			break;
+			
+		case 0xF3:
+			is_minus = false;
+			comp_value = 1;
+			break;
+			
+		case 0xF5:
+			is_minus = false;
+			comp_value = 2;
+			break;
+			
+		case 0xF7:
+			is_minus = false;
+			comp_value = 3;
+			break;
+			
+		case 0xF9:
+			is_minus = false;
+			comp_value = 4;
+			break;
+		
+		/* do nothing case */
+		case 0xF0:
+		default:
+			PHYDM_DBG(dm, ODM_COMP_API, "No need to do TxA bias current calibration\n");
+			return;
+			break;
+	}
+
+	/* calc correct value to calibrate */
+	if (is_minus) {
+		if (tmp1_byte >= comp_value) {
+			tmp1_byte -= comp_value;
+			//modi_tx_a_value += tmp1_byte;
+		} else {
+			tmp1_byte = 0;
+		}
+	} else {
+		tmp1_byte += comp_value;
+		if (tmp1_byte >= 7) {
+			tmp1_byte = 7;
+		}
+	}
+
+	/* Write back to RF reg */
+	odm_set_rf_reg(dm, rf_path, 0x30, 0xFFFF, (offset<<12|(modi_tx_a_value&0xFF0)|tmp1_byte));
+}
+
+static
+void
+_txa_bias_cali_4_each_path(
+	struct dm_struct		*dm,
+	u8	 rf_path,
+	u8	 efuse_value
+	)
+{
+	/* switch on set TxA bias */
+	odm_set_rf_reg(dm, rf_path, 0xEF, 0xFFFFF, 0x200);
+
+	/* Set 12 sets of TxA value */
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x0, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x1, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x2, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x3, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x4, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x5, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x6, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x7, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x8, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0x9, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0xa, efuse_value);
+	_set_tx_a_cali_value(dm, (enum rf_path)rf_path, 0xb, efuse_value);
+
+	// switch off set TxA bias
+	odm_set_rf_reg(dm, rf_path, 0xEF, 0xFFFFF, 0x0);
+}
+
+/* for 8822B PCIE D-cut patch only */
+/* Normal driver and MP driver need this patch */
+
+void
+phydm_txcurrentcalibration(
+	struct dm_struct		*dm
+	)
+{
+	u8			efuse0x3D8, efuse0x3D7;
+	u32			orig_rf0x18_path_a = 0, orig_rf0x18_path_b = 0;
+
+	if (!(dm->support_ic_type & ODM_RTL8822B))
+		return;
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "8822b 5g tx current calibration 0x3d7=0x%X 0x3d8=0x%X\n", dm->efuse0x3d7, dm->efuse0x3d8);
+
+	/* save original 0x18 value */
+	orig_rf0x18_path_a = odm_get_rf_reg(dm, RF_PATH_A, 0x18, 0xFFFFF);
+	orig_rf0x18_path_b = odm_get_rf_reg(dm, RF_PATH_B, 0x18, 0xFFFFF);
+	
+	/* define efuse content */
+		efuse0x3D8 = dm->efuse0x3d8;
+		efuse0x3D7 = dm->efuse0x3d7;
+	
+	/* check efuse content to judge whether need to calibration or not */
+	if (0xFF == efuse0x3D7) {
+		PHYDM_DBG(dm, ODM_COMP_MP, "efuse content 0x3D7 == 0xFF, No need to do TxA cali\n");
+		return;
+	}
+
+	/* write RF register for calibration */
+	_txa_bias_cali_4_each_path(dm, RF_PATH_A, efuse0x3D7);
+	_txa_bias_cali_4_each_path(dm, RF_PATH_B, efuse0x3D8);
+	
+	/* restore original 0x18 value */
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0xFFFFF, orig_rf0x18_path_a);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0xFFFFF, orig_rf0x18_path_b);
+}
+
+void
+phydm_1rcca_setting(
+	struct 	dm_struct		*dm,
+	boolean enable_1rcca
+)
+{
+	u32 reg_32;
+
+	reg_32 = odm_get_bb_reg(dm, 0xa04, 0x0f000000);
+
+	/* Enable or disable 1RCCA setting accrodding to the control from driver */
+	if (enable_1rcca == true) {
+		if (reg_32 == 0x0) {
+			odm_set_bb_reg(dm, 0x808, MASKBYTE0, 0x13); /* CCK path-a */
+		} else if (reg_32 == 0x5) {
+			odm_set_bb_reg(dm, 0x808, MASKBYTE0, 0x23); /* CCK path-b */
+		}
+	} else {
+		odm_set_bb_reg(dm, 0x808, MASKBYTE0, 0x33); /* disable 1RCCA */
+		odm_set_bb_reg(dm, 0xa04, 0x0f000000, 0x0); /* CCK default is at path-a */
+	}
+}
+
+void
+phydm_dynamic_select_cck_path_8822b(
+	struct 	dm_struct		*dm
+)
+{
+	struct phydm_fa_struct	*fa_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+	struct drp_rtl8822b_struct	*drp_8822b = &dm->phydm_rtl8822b;
+
+	if (dm->ap_total_num > 10) {
+		if (drp_8822b->path_judge & BIT(2))
+			odm_set_bb_reg(dm, 0xa04, 0x0f000000, 0x0);	/*fix CCK Path A if AP nums > 10*/
+		return;
+	}
+
+	if (drp_8822b->path_judge & BIT(2))
+		return;
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG,"phydm 8822b cck rx path selection start\n");
+
+	if (drp_8822b->path_judge & BB_PATH_A) {
+		drp_8822b->path_a_cck_fa = (u16)fa_cnt->cnt_cck_fail;
+		drp_8822b->path_judge = (enum bb_path)(drp_8822b->path_judge & ~BB_PATH_A);
+		odm_set_bb_reg(dm, 0xa04, 0x0f000000, 0x5);	/*change to path B collect CCKFA*/
+	} else if (drp_8822b->path_judge & BB_PATH_B) {
+		drp_8822b->path_b_cck_fa = (u16)fa_cnt->cnt_cck_fail;
+		drp_8822b->path_judge =(enum bb_path)(drp_8822b->path_judge & ~BB_PATH_B);
+
+		if (drp_8822b->path_a_cck_fa <= drp_8822b->path_b_cck_fa)
+			odm_set_bb_reg(dm, 0xa04, 0x0f000000, 0x0);	/*FA A<=B choose A*/
+		else
+			odm_set_bb_reg(dm, 0xa04, 0x0f000000, 0x5);	/*FA B>A choose B*/
+
+		drp_8822b->path_judge = (enum bb_path)(drp_8822b->path_judge | BIT(2));	/*it means we have already choosed cck rx path*/
+	}
+
+	PHYDM_DBG(dm, ODM_PHY_CONFIG,"path_a_fa = %d, path_b_fa = %d\n", drp_8822b->path_a_cck_fa, drp_8822b->path_b_cck_fa);
+	
+}
+
+
+void
+phydm_somlrxhp_setting(
+	struct 	dm_struct		*dm,
+	boolean switch_soml
+)
+{
+	if (switch_soml == true) {
+		odm_set_bb_reg(dm, 0x19a8, MASKDWORD, 0xd10a0000);
+	/* Following are RxHP settings for T2R as always low, workaround for OTA test, required to classify */
+		odm_set_bb_reg(dm, 0xc04, (BIT(21)|BIT(18)), 0x0);
+		odm_set_bb_reg(dm, 0xe04, (BIT(21)|BIT(18)), 0x0);
+	} else {
+		odm_set_bb_reg(dm, 0x19a8, MASKDWORD, 0x010a0000);
+		odm_set_bb_reg(dm, 0xc04, (BIT(21)|BIT(18)), 0x0);
+		odm_set_bb_reg(dm, 0xe04, (BIT(21)|BIT(18)), 0x0);
+	}
+	
+	/* Dynamic RxHP setting with SoML on/off apply on all RFE type */
+	if (!switch_soml && ((dm->rfe_type == 1) || (dm->rfe_type == 6) || (dm->rfe_type == 7) || (dm->rfe_type == 9))) {
+		odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+		odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+	}
+	
+	if (*dm->channel <= 14) {
+		if (switch_soml && (!((dm->rfe_type == 3) || (dm->rfe_type == 5) || (dm->rfe_type == 8) || (dm->rfe_type == 17)))) {
+			odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+			odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+		}
+	} else if (*dm->channel > 35) {
+		if (switch_soml == true) {
+			odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+			odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+		}
+	}
+
+#if 0		
+	if (!((dm->rfe_type == 1) || (dm->rfe_type == 6) || (dm->rfe_type == 7) || (dm->rfe_type == 9))) {
+		if (*dm->channel <= 14) {
+			/* TFBGA iFEM SoML on/off with RxHP always high-to-low */
+			if ((switch_soml == true) && (!((dm->rfe_type == 3) || (dm->rfe_type == 5)))) {
+				if (switch_soml == true) {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+				odm_set_bb_reg(dm, 0xc04, (BIT(21)|(BIT(18))), 0x0);
+				odm_set_bb_reg(dm, 0xe04, (BIT(21)|(BIT(18))), 0x0);
+				} else {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108492);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x1);
+				}
+			}
+		} else if (*dm->channel > 35) {
+			if (switch_soml == true) {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108000);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x0);
+				odm_set_bb_reg(dm, 0xc04, (BIT(21)|(BIT(18))), 0x0);
+				odm_set_bb_reg(dm, 0xe04, (BIT(21)|(BIT(18))), 0x0);
+			} else {
+				odm_set_bb_reg(dm, 0x8cc, MASKDWORD, 0x08108492);
+				odm_set_bb_reg(dm, 0x8d8, BIT(27), 0x1);
+			}	
+		}
+		PHYDM_DBG(dm, ODM_COMP_API, "Dynamic RxHP control with SoML is enable !!\n");
+	} 
+#endif
+	
+}
+
+void
+phydm_config_tx2path_8822b(
+	struct dm_struct		*dm,
+	enum wireless_set			wireless_mode,
+	boolean					is_tx2_path
+)
+{
+	if (wireless_mode == WIRELESS_CCK) {
+		if (is_tx2_path == true)
+			odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0xc);
+		else
+			odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0x8);
+	} else {
+		if (is_tx2_path == true)
+			odm_set_bb_reg(dm, 0x93c, 0xf00000, 0x3);
+		else
+			odm_set_bb_reg(dm, 0x93c, 0xf00000, 0x1);
+	}
+}
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void
+phydm_dynamic_ant_weighting_8822b(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 rssi_l2h = 43, rssi_h2l = 37;
+	u8 reg_8;
+
+	if (dm->is_disable_dym_ant_weighting)
+		return;
+
+	if (*dm->channel <= 14) {
+		if (dm->rssi_min >= rssi_l2h) {
+			odm_set_bb_reg(dm, 0x98c, 0x7fc0000, 0x0);
+
+			/*equal weighting*/
+			reg_8 = (u8)odm_get_bb_reg(dm, 0xf94, BIT(0)|BIT(1)|BIT(2));
+			PHYDM_DBG(dm, ODM_COMP_API, "Equal weighting ,rssi_min = %d\n, 0xf94[2:0] = 0x%x\n", dm->rssi_min, reg_8);
+		} else if (dm->rssi_min <= rssi_h2l) {
+			odm_set_bb_reg(dm, 0x98c, MASKDWORD, 0x43440000);
+	
+			/*fix sec_min_wgt = 1/2*/
+			reg_8 = (u8)odm_get_bb_reg(dm, 0xf94, BIT(0)|BIT(1)|BIT(2));
+			PHYDM_DBG(dm, ODM_COMP_API, "AGC weighting ,rssi_min = %d\n, 0xf94[2:0] = 0x%x\n", dm->rssi_min, reg_8);
+		}
+	} else {
+			odm_set_bb_reg(dm, 0x98c, MASKDWORD, 0x43440000);
+
+			reg_8 = (u8)odm_get_bb_reg(dm, 0xf94, BIT(0)|BIT(1)|BIT(2));
+			PHYDM_DBG(dm, ODM_COMP_API, "AGC weighting ,rssi_min = %d\n, 0xf94[2:0] = 0x%x\n", dm->rssi_min, reg_8);
+		/*fix sec_min_wgt = 1/2*/
+	}
+
+}
+#endif
+
+void
+phydm_hwsetting_8822b(
+	struct dm_struct		*dm
+)
+{
+	struct drp_rtl8822b_struct	*drp_8822b = &dm->phydm_rtl8822b;
+	u8 set_result_nbi = PHYDM_SET_NO_NEED;
+
+	if ((dm->p_advance_ota & PHYDM_HP_OTA_SETTING_A) || (dm->p_advance_ota & PHYDM_HP_OTA_SETTING_B)) {
+		phydm_dynamic_parameters_ota(dm);
+	} else {
+		if (dm->bhtstfdisabled == false)
+			phydm_dynamic_switch_htstf_mumimo_8822b(dm);
+		else
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "Default HT-STF gain control setting\n");
+	}
+
+	phydm_dynamic_ant_weighting(dm);
+
+	if (dm->p_advance_ota & PHYDM_ASUS_OTA_SETTING) {
+		if (dm->rssi_min <= 20)
+			phydm_somlrxhp_setting(dm, false);
+		else if (dm->rssi_min >= 25)
+			phydm_somlrxhp_setting(dm, true);
+	}
+
+	if ((dm->p_advance_ota & PHYDM_ASUS_OTA_SETTING_CCK_PATH) || (dm->p_advance_ota & PHYDM_HP_OTA_SETTING_CCK_PATH)) {
+		if (dm->is_linked)
+			phydm_dynamic_select_cck_path_8822b(dm);
+		else
+			drp_8822b->path_judge =(enum bb_path)(drp_8822b->path_judge | ((~ BIT(2)) | BB_PATH_A | BB_PATH_B));
+	}
+
+	if (dm->p_advance_ota & PHYDM_LENOVO_OTA_SETTING_NBI_CSI) {
+		if ((*dm->band_width == CHANNEL_WIDTH_80) && (*dm->channel == 157)) {
+			set_result_nbi = phydm_nbi_setting(dm, FUNC_ENABLE, *dm->channel, 80, 5760, PHYDM_DONT_CARE);
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "Enable NBI\n");
+		}
+	}
+}
+
+#endif	/* RTL8822B_SUPPORT == 1 */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_rtl8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_rtl8822b.h
new file mode 100644
index 000000000000..72cd54e56292
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/phydm_rtl8822b.h
@@ -0,0 +1,61 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#if (RTL8822B_SUPPORT == 1)
+#ifndef	__ODM_RTL8822B_H__
+#define __ODM_RTL8822B_H__
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void
+phydm_dynamic_ant_weighting_8822b(
+	void		*dm_void
+);
+#endif
+
+void
+phydm_1rcca_setting(
+	struct 	dm_struct		*dm,
+	boolean	enable_1rcca
+);
+
+void
+phydm_somlrxhp_setting(
+	struct 	dm_struct		*dm,
+	boolean switch_soml
+);
+
+void
+phydm_hwsetting_8822b(
+	struct dm_struct		*dm
+);
+
+void
+phydm_config_tx2path_8822b(
+	struct dm_struct		*dm,
+	enum wireless_set			wireless_mode,
+	boolean					is_tx2_path
+);
+
+#endif	/* #define __ODM_RTL8822B_H__ */
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/version_rtl8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/version_rtl8822b.h
new file mode 100644
index 000000000000..c3be6dc408ad
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/rtl8822b/version_rtl8822b.h
@@ -0,0 +1,33 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+/*RTL8822B PHY Parameters*/
+/* 
+[Caution] 
+  Since 01/Aug/2015, the commit rules will be simplified. You do not need to fill up the version.h anymore, 
+  only the maintenance supervisor fills it before formal release.
+*/
+#define	RELEASE_DATE_8822B		20171201
+#define	COMMIT_BY_8822B			"BB_JOE"
+#define	RELEASE_VERSION_8822B	104
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/halcomtxbf.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/halcomtxbf.c
new file mode 100644
index 000000000000..8de20bb66976
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/halcomtxbf.c
@@ -0,0 +1,552 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 TXBF mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+/*Beamforming halcomtxbf API create by YuChen 2015/05*/
+
+void
+hal_com_txbf_beamform_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean		is_iqgen_setting_ok = false;
+
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		is_iqgen_setting_ok = phydm_beamforming_set_iqgen_8814A(dm);
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] is_iqgen_setting_ok = %d\n", __func__, is_iqgen_setting_ok);
+	}
+}
+
+/*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
+void
+hal_com_txbf_config_gtab(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_config_gtab(dm);
+}
+
+void
+phydm_beamform_set_sounding_enter(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_enter_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_enter_work_item));
+#else
+	hal_com_txbf_enter_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_leave(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_leave_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_leave_work_item));
+#else
+	hal_com_txbf_leave_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_rate(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_rate_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_rate_work_item));
+#else
+	hal_com_txbf_rate_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_status(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_status_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_status_work_item));
+#else
+	hal_com_txbf_status_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_fw_ndpa(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (*dm->is_fw_dw_rsvd_page_in_progress)
+		odm_set_timer(dm, &(p_txbf_info->txbf_fw_ndpa_timer), 5);
+	else
+		odm_schedule_work_item(&(p_txbf_info->txbf_fw_ndpa_work_item));
+#else
+	hal_com_txbf_fw_ndpa_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_clk(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_clk_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_clk_work_item));
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*padapter = dm->adapter;
+
+	rtw_run_in_thread_cmd(padapter, hal_com_txbf_clk_work_item_callback, dm);
+#else
+	hal_com_txbf_clk_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_reset_tx_path(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_reset_tx_path_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_reset_tx_path_work_item));
+#else
+	hal_com_txbf_reset_tx_path_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_get_tx_rate(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_get_tx_rate_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_get_tx_rate_work_item));
+#else
+	hal_com_txbf_get_tx_rate_work_item_callback(dm);
+#endif
+}
+
+void
+hal_com_txbf_enter_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8			idx = p_txbf_info->txbf_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_enter(dm, idx);
+}
+
+void
+hal_com_txbf_leave_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	u8			idx = p_txbf_info->txbf_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_leave(dm, idx);
+}
+
+
+void
+hal_com_txbf_fw_ndpa_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8	idx = p_txbf_info->ndpa_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_fw_txbf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_fw_tx_bf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_fw_txbf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_fw_txbf(dm, idx);
+}
+
+void
+hal_com_txbf_clk_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & ODM_RTL8812)
+		hal_txbf_jaguar_clk_8812a(dm);
+}
+
+
+
+void
+hal_com_txbf_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8			BW = p_txbf_info->BW;
+	u8			rate = p_txbf_info->rate;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & ODM_RTL8812)
+		hal_txbf_8812a_set_ndpa_rate(dm, BW, rate);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_set_ndpa_rate(dm, BW, rate);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_set_ndpa_rate(dm, BW, rate);
+
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+hal_com_txbf_fw_ndpa_timer_callback(
+	struct phydm_timer_list		*timer
+)
+{
+
+	void		*adapter = (void *)timer->Adapter;
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (*dm->is_fw_dw_rsvd_page_in_progress)
+		odm_set_timer(dm, &(p_txbf_info->txbf_fw_ndpa_timer), 5);
+	else
+		odm_schedule_work_item(&(p_txbf_info->txbf_fw_ndpa_work_item));
+}
+#endif
+
+
+void
+hal_com_txbf_status_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	u8			idx = p_txbf_info->txbf_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_status(dm, idx);
+}
+
+void
+hal_com_txbf_reset_tx_path_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	u8			idx = p_txbf_info->txbf_idx;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_reset_tx_path(dm, idx);
+
+}
+
+void
+hal_com_txbf_get_tx_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_get_tx_rate(dm);
+}
+
+
+boolean
+hal_com_txbf_set(
+	void			*dm_void,
+	u8			set_type,
+	void			*p_in_buf
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			*p_u1_tmp = (u8 *)p_in_buf;
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] set_type = 0x%X\n", __func__, set_type);
+
+	switch (set_type) {
+	case TXBF_SET_SOUNDING_ENTER:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_enter(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_LEAVE:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_leave(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_RATE:
+		p_txbf_info->BW = p_u1_tmp[0];
+		p_txbf_info->rate = p_u1_tmp[1];
+		phydm_beamform_set_sounding_rate(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_STATUS:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_status(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_FW_NDPA:
+		p_txbf_info->ndpa_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_fw_ndpa(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_CLK:
+		phydm_beamform_set_sounding_clk(dm);
+		break;
+
+	case TXBF_SET_TX_PATH_RESET:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_reset_tx_path(dm);
+		break;
+
+	case TXBF_SET_GET_TX_RATE:
+		phydm_beamform_set_get_tx_rate(dm);
+		break;
+
+	}
+
+	return true;
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+boolean
+hal_com_txbf_get(
+	void		*adapter,
+	u8			get_type,
+	void			*p_out_buf
+)
+{
+	PHAL_DATA_TYPE		hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct			*dm = &hal_data->DM_OutSrc;
+	boolean			*p_boolean = (boolean *)p_out_buf;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (get_type == TXBF_GET_EXPLICIT_BEAMFORMEE) {
+		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(adapter))
+			*p_boolean = false;
+		else if (/*IS_HARDWARE_TYPE_8822B(adapter)	||*/
+			IS_HARDWARE_TYPE_8821B(adapter)	||
+			IS_HARDWARE_TYPE_8192E(adapter)	||
+			IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
+			*p_boolean = true;
+		else
+			*p_boolean = false;
+	} else if (get_type == TXBF_GET_EXPLICIT_BEAMFORMER) {
+		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(adapter))
+			*p_boolean = false;
+		else	if (/*IS_HARDWARE_TYPE_8822B(adapter)	||*/
+			IS_HARDWARE_TYPE_8821B(adapter)	||
+			IS_HARDWARE_TYPE_8192E(adapter)	||
+			IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter)) {
+			if (hal_data->RF_Type == RF_2T2R || hal_data->RF_Type == RF_3T3R)
+				*p_boolean = true;
+			else
+				*p_boolean = false;
+		} else
+			*p_boolean = false;
+	} else if (get_type == TXBF_GET_MU_MIMO_STA) {
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+		if (IS_HARDWARE_TYPE_8822B(adapter) || IS_HARDWARE_TYPE_8821C(adapter))
+			*p_boolean = true;
+		else
+#endif
+			*p_boolean = false;
+
+
+	} else if (get_type == TXBF_GET_MU_MIMO_AP) {
+#if (RTL8822B_SUPPORT == 1)
+		if (IS_HARDWARE_TYPE_8822B(adapter))
+			*p_boolean = true;
+		else
+#endif
+			*p_boolean = false;
+	}
+
+	return true;
+}
+#endif
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/halcomtxbf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/halcomtxbf.h
new file mode 100644
index 000000000000..2e9e5a01d5bc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/halcomtxbf.h
@@ -0,0 +1,203 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_COM_TXBF_H__
+#define __HAL_COM_TXBF_H__
+
+/*
+typedef	bool
+(*TXBF_GET)(
+	void*			adapter,
+	u8			get_type,
+	void*			p_out_buf
+	);
+
+typedef	bool
+(*TXBF_SET)(
+	void*			adapter,
+	u8			set_type,
+	void*			p_in_buf
+	);
+*/
+
+enum txbf_set_type {
+	TXBF_SET_SOUNDING_ENTER,
+	TXBF_SET_SOUNDING_LEAVE,
+	TXBF_SET_SOUNDING_RATE,
+	TXBF_SET_SOUNDING_STATUS,
+	TXBF_SET_SOUNDING_FW_NDPA,
+	TXBF_SET_SOUNDING_CLK,
+	TXBF_SET_TX_PATH_RESET,
+	TXBF_SET_GET_TX_RATE
+};
+
+
+enum txbf_get_type {
+	TXBF_GET_EXPLICIT_BEAMFORMEE,
+	TXBF_GET_EXPLICIT_BEAMFORMER,
+	TXBF_GET_MU_MIMO_STA,
+	TXBF_GET_MU_MIMO_AP
+};
+
+
+
+/* 2 HAL TXBF related */
+struct _HAL_TXBF_INFO {
+	u8				txbf_idx;
+	u8				ndpa_idx;
+	u8				BW;
+	u8				rate;
+
+	struct phydm_timer_list			txbf_fw_ndpa_timer;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_WORK_ITEM		txbf_enter_work_item;
+	RT_WORK_ITEM		txbf_leave_work_item;
+	RT_WORK_ITEM		txbf_fw_ndpa_work_item;
+	RT_WORK_ITEM		txbf_clk_work_item;
+	RT_WORK_ITEM		txbf_status_work_item;
+	RT_WORK_ITEM		txbf_rate_work_item;
+	RT_WORK_ITEM		txbf_reset_tx_path_work_item;
+	RT_WORK_ITEM		txbf_get_tx_rate_work_item;
+#endif
+
+};
+
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_com_txbf_beamform_init(
+	void			*dm_void
+);
+
+void
+hal_com_txbf_config_gtab(
+	void			*dm_void
+);
+
+void
+hal_com_txbf_enter_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_leave_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_fw_ndpa_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_clk_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_reset_tx_path_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_get_tx_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_fw_ndpa_timer_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+hal_com_txbf_status_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+boolean
+hal_com_txbf_set(
+	void			*dm_void,
+	u8			set_type,
+	void			*p_in_buf
+);
+
+boolean
+hal_com_txbf_get(
+	void		*adapter,
+	u8			get_type,
+	void			*p_out_buf
+);
+
+#else
+#define hal_com_txbf_beamform_init(dm_void)					NULL
+#define hal_com_txbf_config_gtab(dm_void)				NULL
+#define hal_com_txbf_enter_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_leave_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_fw_ndpa_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_clk_work_item_callback(_adapter)			NULL
+#define hal_com_txbf_rate_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_fw_ndpa_timer_callback(_adapter)		NULL
+#define hal_com_txbf_status_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_get(_adapter, _get_type, _pout_buf)
+
+#endif
+
+#endif	/*  #ifndef __HAL_COM_TXBF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8192e.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8192e.c
new file mode 100644
index 000000000000..cec255987400
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8192e.c
@@ -0,0 +1,401 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8192E TXBF mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (RTL8192E_SUPPORT == 1)
+
+void
+hal_txbf_8192e_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8192E, (rate << 2 | BW));
+
+}
+
+void
+hal_txbf_8192e_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
+
+	if (beam_info->beamformee_su_cnt > 0) {
+		/*Path_A*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*Select RX mode  0x30=0x18000*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
+		/*Path_B*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
+	} else {
+		/*Path_A*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
+		/*Path_B*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
+	}
+
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+
+	if (beam_info->beamformee_su_cnt > 0) {
+		odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x83321333);
+		odm_set_bb_reg(dm, 0xa04, MASKBYTE3, 0xc1);
+	} else
+		odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x81121313);
+}
+
+
+
+void
+hal_txbf_8192e_fw_txbf_cmd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	idx, period0 = 0, period1 = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (idx == 0) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum0 = 0xFE;
+				else
+					PageNum0 = 0xFF; /* stop sounding */
+				period0 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (idx == 1) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum1 = 0xFE;
+				else
+					PageNum1 = 0xFF; /* stop sounding */
+				period1 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = (period1 << 4) | period0;
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	PHYDM_DBG(dm, DBG_TXBF,
+		"[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n", __func__, PageNum0, period0, PageNum1, period1);
+}
+
+
+void
+hal_txbf_8192e_download_ndpa(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			u1b_tmp = 0, tmp_reg422 = 0, head_page;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	boolean			is_send_beacon = false;
+	u8			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;
+	/*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
+#endif
+	if (idx == 0)
+		head_page = 0xFE;
+	else
+		head_page = 0xFE;
+
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8192E+1);
+	odm_write_1byte(dm,  REG_CR_8192E+1, (u1b_tmp | BIT(0)));
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8192E+2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8192E+2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s There is an adapter is sending beacon.\n", __func__);
+		is_send_beacon = true;
+	}
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xFE/0xFD	NDPA Head for TXDMA*/
+	odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E+1, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E+2);
+		odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E+2, (bcn_valid_reg | BIT(0)));
+
+		/* download NDPA rsvd page. */
+		beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		u1b_tmp = odm_read_1byte(dm, REG_MGQ_TXBD_NUM_8192E+3);
+		count = 0;
+		while ((count < 20) && (u1b_tmp & BIT(4))) {
+			count++;
+			ODM_delay_us(10);
+			u1b_tmp = odm_read_1byte(dm, REG_MGQ_TXBD_NUM_8192E+3);
+		}
+		odm_write_1byte(dm, REG_MGQ_TXBD_NUM_8192E+3, u1b_tmp | BIT(4));
+#endif
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E+2);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(0)) && count < 20) {
+			count++;
+			ODM_delay_us(10);
+			bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E+2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(0)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(0)))
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n", __func__);
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xF9	Beacon Head for TXDMA*/
+	odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E+1, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8192E+2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8192E+1);
+	odm_write_1byte(dm, REG_CR_8192E+1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
+#endif
+}
+
+
+void
+hal_txbf_8192e_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	u32					csi_param;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	u16					sta_id = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	hal_txbf_8192e_rf_mode(dm, beamforming_info);
+
+	if (dm->rf_type == RF_2T2R)
+		odm_write_4byte(dm, 0xd80, 0x00000000);		/*nc =2*/
+
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E, 0xCB);
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (bfer_idx == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8192E+i), beamformer_entry.mac_addr[i]);
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8192E+i), beamformer_entry.mac_addr[i]);
+		}
+
+		/*CSI report parameters of Beamformer Default use nc = 2*/
+		csi_param = 0x03090309;
+
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW20_8192E, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW40_8192E, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW80_8192E, csi_param);
+
+		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E+3, 0x50);
+
+	}
+
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = beamformee_entry.mac_id;
+		else
+			sta_id = beamformee_entry.p_aid;
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s], sta_id=0x%X\n", __func__, sta_id);
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (bfee_idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8192E, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8192E+3, odm_read_1byte(dm, REG_TXBF_CTRL_8192E+3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8192E+2, sta_id | BIT(12) | BIT(14) | BIT(15));
+
+		/*CSI report parameters of Beamformee*/
+		if (bfee_idx == 0) {
+			/*Get BIT24 & BIT25*/
+			u8 tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+3) & 0x3;
+
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E, sta_id | BIT(9));
+		} else {
+			/*Set BIT25*/
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, sta_id | 0xE200);
+		}
+		phydm_beamforming_notify(dm);
+
+	}
+}
+
+
+void
+hal_txbf_8192e_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	hal_txbf_8192e_rf_mode(dm, beam_info);
+
+	/*	Clear P_AID of Beamformee
+	*	Clear MAC addresss of Beamformer
+	*	Clear Associated Bfmee Sel
+	*/
+	if (beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E, 0xC8);
+
+	if (idx == 0) {
+		odm_write_2byte(dm, REG_TXBF_CTRL_8192E, 0);
+		odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8192E, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8192E+4, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E, 0);
+	} else {
+		odm_write_2byte(dm, REG_TXBF_CTRL_8192E+2, odm_read_1byte(dm, REG_TXBF_CTRL_8192E+2) & 0xF000);
+		odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8192E, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8192E+4, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2) & 0x60);
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] idx %d\n", __func__, idx);
+}
+
+
+void
+hal_txbf_8192e_status(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beam_info =  &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamform_entry = beam_info->beamformee_entry[idx];
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+		beam_ctrl_val = beamform_entry.mac_id;
+	else
+		beam_ctrl_val = beamform_entry.p_aid;
+
+	if (idx == 0)
+		beam_ctrl_reg = REG_TXBF_CTRL_8192E;
+	else {
+		beam_ctrl_reg = REG_TXBF_CTRL_8192E+2;
+		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+	}
+
+	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (beam_info->apply_v_matrix == true)) {
+		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
+			beam_ctrl_val |= BIT(9);
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
+			beam_ctrl_val |= BIT(10);
+	} else
+		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] idx %d beam_ctrl_reg %x beam_ctrl_val %x\n", __func__, idx, beam_ctrl_reg, beam_ctrl_val);
+}
+
+
+void
+hal_txbf_8192e_fw_tx_bf(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_8192e_download_ndpa(dm, idx);
+
+	hal_txbf_8192e_fw_txbf_cmd(dm);
+}
+
+#endif	/* #if (RTL8192E_SUPPORT == 1)*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8192e.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8192e.h
new file mode 100644
index 000000000000..360cbf7d2ec6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8192e.h
@@ -0,0 +1,84 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_8192E_H__
+#define __HAL_TXBF_8192E_H__
+
+#if (RTL8192E_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_txbf_8192e_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+);
+
+void
+hal_txbf_8192e_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8192e_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8192e_status(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8192e_fw_tx_bf(
+	void			*dm_void,
+	u8				idx
+);
+#else
+
+#define hal_txbf_8192e_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8192e_enter(dm_void, idx)
+#define hal_txbf_8192e_leave(dm_void, idx)
+#define hal_txbf_8192e_status(dm_void, idx)
+#define hal_txbf_8192e_fw_tx_bf(dm_void, idx)
+
+#endif
+
+#else
+
+#define hal_txbf_8192e_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8192e_enter(dm_void, idx)
+#define hal_txbf_8192e_leave(dm_void, idx)
+#define hal_txbf_8192e_status(dm_void, idx)
+#define hal_txbf_8192e_fw_tx_bf(dm_void, idx)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8814a.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8814a.c
new file mode 100644
index 000000000000..7a4eafb1bbe2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8814a.c
@@ -0,0 +1,720 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8814A TXBF mechanism
+ *
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (RTL8814A_SUPPORT == 1)
+
+boolean
+phydm_beamforming_set_iqgen_8814A(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	u16 counter = 0;
+	u32 rf_mode[4];
+
+	for (i = RF_PATH_A ; i < MAX_RF_PATH ; i++)
+		odm_set_rf_reg(dm, i, RF_WE_LUT, 0x80000, 0x1);	/*RF mode table write enable*/
+
+	while (1) {
+		counter++;
+		for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
+			odm_set_rf_reg(dm, i, RF_RCK_OS, 0xfffff, 0x18000);	/*Select Rx mode*/
+
+		ODM_delay_us(2);
+
+		for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
+			rf_mode[i] = odm_get_rf_reg(dm, i, RF_RCK_OS, 0xfffff);
+
+		if ((rf_mode[0] == 0x18000) && (rf_mode[1] == 0x18000) && (rf_mode[2] == 0x18000) && (rf_mode[3] == 0x18000))
+			break;
+		else if (counter == 100) {
+			PHYDM_DBG(dm, DBG_TXBF, "iqgen setting fail:8814A\n");
+			return false;
+		}
+	}
+
+	for (i = RF_PATH_A ; i < MAX_RF_PATH ; i++) {
+		odm_set_rf_reg(dm, i, RF_TXPA_G1, 0xfffff, 0xBE77F); /*Set Table data*/
+		odm_set_rf_reg(dm, i, RF_TXPA_G2, 0xfffff, 0x226BF); /*Enable TXIQGEN in Rx mode*/
+	}
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, 0xfffff, 0xE26BF); /*Enable TXIQGEN in Rx mode*/
+
+	for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
+		odm_set_rf_reg(dm, i, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+
+	return true;
+
+}
+
+
+
+void
+hal_txbf_8814a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8814A, BW);
+	odm_write_1byte(dm, REG_NDPA_RATE_8814A, (u8) rate);
+
+}
+#if 0
+#define PHYDM_MEMORY_MAP_BUF_READ	0x8000
+#define PHYDM_CTRL_INFO_PAGE			0x660
+
+void
+phydm_data_rate_8814a(
+	struct dm_struct			*dm,
+	u8				mac_id,
+	u32				*data,
+	u8				data_len
+)
+{
+	u8	i = 0;
+	u16	x_read_data_addr = 0;
+
+	odm_write_2byte(dm, REG_PKTBUF_DBG_CTRL_8814A, PHYDM_CTRL_INFO_PAGE);
+	x_read_data_addr = PHYDM_MEMORY_MAP_BUF_READ + mac_id * 32; /*Ctrl Info: 32Bytes for each macid(n)*/
+
+	if ((x_read_data_addr < PHYDM_MEMORY_MAP_BUF_READ) || (x_read_data_addr > 0x8FFF)) {
+		PHYDM_DBG(dm, DBG_TXBF, "x_read_data_addr(0x%x) is not correct!\n", x_read_data_addr);
+		return;
+	}
+
+	/* Read data */
+	for (i = 0; i < data_len; i++)
+		*(data + i) = odm_read_2byte(dm, x_read_data_addr + i);
+
+}
+#endif
+
+void
+hal_txbf_8814a_get_tx_rate(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	struct ra_table	*ra_tab = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = NULL;
+	u8	data_rate = 0xFF;
+	u8	macid = 0;
+
+	entry = &(beam_info->beamformee_entry[beam_info->beamformee_cur_idx]);
+	macid = (u8)entry->mac_id;
+
+	sta = dm->phydm_sta_info[macid];
+	
+	if (is_sta_active(sta)) {
+		
+		data_rate = (sta->ra_info.curr_tx_rate) & 0x7f;	/*Bit7 indicates SGI*/
+		beam_info->tx_bf_data_rate = data_rate;
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] dm->tx_bf_data_rate = 0x%x\n", __func__, beam_info->tx_bf_data_rate);
+}
+
+void
+hal_txbf_8814a_reset_tx_path(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	u8	nr_index = 0, tx_ss = 0;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	if ((beamforming_info->last_usb_hub) != (*dm->hub_usb_mode)) {
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), beamformee_entry.comp_steering_num_of_bfer);
+
+		if (*dm->hub_usb_mode == 2) {
+			if (dm->rf_type == RF_4T4R)
+				tx_ss = 0xf;
+			else if (dm->rf_type == RF_3T3R)
+				tx_ss = 0xe;
+			else
+				tx_ss = 0x6;
+		} else if (*dm->hub_usb_mode == 1)	/*USB 2.0 always 2Tx*/
+			tx_ss = 0x6;
+		else
+			tx_ss = 0x6;
+
+		if (tx_ss == 0xf) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
+		} else if (tx_ss == 0xe) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
+		} else if (tx_ss == 0x6) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
+		}
+
+		if (idx == 0) {
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+				break;
+			}
+		} else	{
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+				break;
+			}
+		}
+
+		beamforming_info->last_usb_hub = *dm->hub_usb_mode;
+	} else
+		return;
+#endif
+}
+
+
+u8
+hal_txbf_8814a_get_ntx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		ntx = 0, tx_ss = 3;
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	tx_ss = *dm->hub_usb_mode;
+#endif
+	if (tx_ss == 3 || tx_ss == 2) {
+		if (dm->rf_type == RF_4T4R)
+			ntx = 3;
+		else if (dm->rf_type == RF_3T3R)
+			ntx = 2;
+		else
+			ntx = 1;
+	} else if (tx_ss == 1)	/*USB 2.0 always 2Tx*/
+		ntx = 1;
+	else
+		ntx = 1;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ntx = %d\n", __func__, ntx);
+	return ntx;
+}
+
+u8
+hal_txbf_8814a_get_nrx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			nrx = 0;
+
+	if (dm->rf_type == RF_4T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_3T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T2R)
+		nrx = 1;
+	else if (dm->rf_type == RF_2T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_1T1R)
+		nrx = 0;
+	else if (dm->rf_type == RF_1T2R)
+		nrx = 1;
+	else
+		nrx = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] nrx = %d\n", __func__, nrx);
+	return nrx;
+}
+
+void
+hal_txbf_8814a_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beamforming_info,
+	u8					idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8				nr_index = 0;
+	u8				tx_ss = 3;		/*default use 3 Tx*/
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), beamformee_entry.comp_steering_num_of_bfer);
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	if (beamforming_info->beamformee_su_cnt > 0) {
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+		beamforming_info->last_usb_hub = *dm->hub_usb_mode;
+		tx_ss = *dm->hub_usb_mode;
+#endif
+		if (tx_ss == 3 || tx_ss == 2) {
+			if (dm->rf_type == RF_4T4R)
+				tx_ss = 0xf;
+			else if (dm->rf_type == RF_3T3R)
+				tx_ss = 0xe;
+			else
+				tx_ss = 0x6;
+		} else if (tx_ss == 1)	/*USB 2.0 always 2Tx*/
+			tx_ss = 0x6;
+		else
+			tx_ss = 0x6;
+
+		if (tx_ss == 0xf) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
+		} else if (tx_ss == 0xe) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
+		} else if (tx_ss == 0x6) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
+		}
+
+		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT(28) | BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT30, 0x1);			/*if Nsts > Nc don't apply V matrix*/
+
+		if (idx == 0) {
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+
+				break;
+			}
+		} else {
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+				break;
+			}
+		}
+	}
+
+	if ((beamforming_info->beamformee_su_cnt == 0) && (beamforming_info->beamformer_su_cnt == 0)) {
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x932);	/*set tx_path selection for 8814a BFer bug refine*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e9360);
+	}
+}
+#if 0
+void
+hal_txbf_8814a_download_ndpa(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			u1b_tmp = 0, tmp_reg422 = 0;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	u16			head_page = 0x7FE;
+	boolean			is_send_beacon = false;
+	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+	void		*adapter = dm->adapter;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
+#endif
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8814A + 1);
+	odm_write_1byte(dm,  REG_CR_8814A + 1, (u1b_tmp | BIT(0)));
+
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s: There is an adapter is sending beacon.\n", __func__);
+		is_send_beacon = true;
+	}
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	odm_write_2byte(dm, REG_FIFOPAGE_CTRL_2_8814A, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		odm_write_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1, (bcn_valid_reg | BIT(7)));
+
+		/*download NDPA rsvd page.*/
+		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
+		else
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(7)) && count < 20) {
+			count++;
+			ODM_delay_ms(10);
+			bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(7)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(7)))
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n", __func__);
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	odm_write_2byte(dm, REG_FIFOPAGE_CTRL_2_8814A, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8814A + 1);
+	odm_write_1byte(dm, REG_CR_8814A + 1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
+#endif
+}
+
+void
+hal_txbf_8814a_fw_txbf_cmd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	idx, period = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beam_info->beamformee_entry[idx].is_sound) {
+				PageNum0 = 0xFE;
+				PageNum1 = 0x07;
+				period = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (PageNum0 == 0xFF) {
+				PageNum0 = 0xFF; /*stop sounding*/
+				PageNum1 = 0x0F;
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = period;
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	PHYDM_DBG(dm, DBG_TXBF,
+		"[%s] PageNum0 = %d, PageNum1 = %d period = %d\n", __func__, PageNum0, PageNum1, period);
+}
+#endif
+void
+hal_txbf_8814a_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	u16					sta_id = 0, csi_param = 0;
+	u8					nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] bfer_idx=%d, bfee_idx=%d\n", __func__, bfer_idx, bfee_idx);
+	odm_set_mac_reg(dm, REG_SND_PTCL_CTRL_8814A, MASKBYTE1 | MASKBYTE2, 0x0202);
+
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A, 0xDB);
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (bfer_idx == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8814A + i), beamformer_entry.mac_addr[i]);
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8814A + i), beamformer_entry.mac_addr[i]);
+		}
+
+		/*CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8814a_get_nrx(dm);	/*for 8814A nrx = 3(4 ant), min=0(1 ant)*/
+		nr_index = beamformer_entry.num_of_sounding_dim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+
+		grouping = 0;
+
+		/*for ac = 1, for n = 3*/
+		if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU)
+			codebookinfo = 1;
+		else if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
+			codebookinfo = 3;
+
+		coefficientsize = 3;
+
+		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
+
+		if (bfer_idx == 0)
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A, csi_param);
+		else
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, csi_param);
+		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A + 3, 0x40);
+
+	}
+
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
+
+		hal_txbf_8814a_rf_mode(dm, beamforming_info, bfee_idx);
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = beamformee_entry.mac_id;
+		else
+			sta_id = beamformee_entry.p_aid;
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (bfee_idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
+
+		/*CSI report parameters of Beamformee*/
+		if (bfee_idx == 0) {
+			/*Get BIT24 & BIT25*/
+			u8	tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3) & 0x3;
+
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A, sta_id | BIT(9));
+		} else
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, sta_id | 0xE200);	/*Set BIT25*/
+
+		phydm_beamforming_notify(dm);
+	}
+
+}
+
+
+void
+hal_txbf_8814a_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = beamforming_info->beamformer_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	} else
+		return;
+
+	/*Clear P_AID of Beamformee*/
+	/*Clear MAC address of Beamformer*/
+	/*Clear Associated Bfmee Sel*/
+
+	if (beamformer_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A, 0xD8);
+		if (idx == 0) {
+			odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8814A, 0);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8814A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A, 0);
+		} else {
+			odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8814A, 0);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8814A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, 0);
+		}
+	}
+
+	if (beamformee_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		hal_txbf_8814a_rf_mode(dm, beamforming_info, idx);
+		if (idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A, 0x0);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A, 0);
+		} else {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
+
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2) & 0x60);
+		}
+	}
+}
+
+void
+hal_txbf_8814a_status(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val, tmp_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamform_entry;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamform_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+		beam_ctrl_val = beamform_entry.mac_id;
+	else
+		beam_ctrl_val = beamform_entry.p_aid;
+
+	PHYDM_DBG(dm, DBG_TXBF, "@%s, beamform_entry.beamform_entry_state = %d", __func__, beamform_entry.beamform_entry_state);
+
+	if (idx == 0)
+		beam_ctrl_reg = REG_TXBF_CTRL_8814A;
+	else {
+		beam_ctrl_reg = REG_TXBF_CTRL_8814A + 2;
+		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+	}
+
+	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (beamforming_info->apply_v_matrix == true)) {
+		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
+			beam_ctrl_val |= BIT(9);
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
+			beam_ctrl_val |= (BIT(9) | BIT(10));
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_80)
+			beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
+	} else {
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, Don't apply Vmatrix",  __func__);
+		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+	}
+
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+	/*disable NDP packet use beamforming */
+	tmp_val = odm_read_2byte(dm, REG_TXBF_CTRL_8814A);
+	odm_write_2byte(dm, REG_TXBF_CTRL_8814A, tmp_val | BIT(15));
+
+}
+
+
+
+
+
+void
+hal_txbf_8814a_fw_txbf(
+	void			*dm_void,
+	u8				idx
+)
+{
+#if 0
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_8814a_download_ndpa(dm, idx);
+
+	hal_txbf_8814a_fw_txbf_cmd(dm);
+#endif
+}
+
+#endif	/* (RTL8814A_SUPPORT == 1)*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8814a.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8814a.h
new file mode 100644
index 000000000000..2612ad215ee5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8814a.h
@@ -0,0 +1,113 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_8814A_H__
+#define __HAL_TXBF_8814A_H__
+
+#if (RTL8814A_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+boolean
+phydm_beamforming_set_iqgen_8814A(
+	void			*dm_void
+);
+
+void
+hal_txbf_8814a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+);
+
+u8
+hal_txbf_8814a_get_ntx(
+	void			*dm_void
+);
+
+void
+hal_txbf_8814a_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8814a_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8814a_status(
+	void			*dm_void,
+	u8				idx
+);
+
+void
+hal_txbf_8814a_reset_tx_path(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8814a_get_tx_rate(
+	void			*dm_void
+);
+
+void
+hal_txbf_8814a_fw_txbf(
+	void			*dm_void,
+	u8				idx
+);
+
+#else
+
+#define hal_txbf_8814a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_8814a_get_ntx(dm_void) 0
+#define hal_txbf_8814a_enter(dm_void, idx)
+#define hal_txbf_8814a_leave(dm_void, idx)
+#define hal_txbf_8814a_status(dm_void, idx)
+#define hal_txbf_8814a_reset_tx_path(dm_void,	idx)
+#define hal_txbf_8814a_get_tx_rate(dm_void)
+#define hal_txbf_8814a_fw_txbf(dm_void,	idx)
+#define phydm_beamforming_set_iqgen_8814A(dm_void)	0
+
+#endif
+
+#else
+
+#define hal_txbf_8814a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_8814a_get_ntx(dm_void) 0
+#define hal_txbf_8814a_enter(dm_void, idx)
+#define hal_txbf_8814a_leave(dm_void, idx)
+#define hal_txbf_8814a_status(dm_void, idx)
+#define hal_txbf_8814a_reset_tx_path(dm_void,	idx)
+#define hal_txbf_8814a_get_tx_rate(dm_void)
+#define hal_txbf_8814a_fw_txbf(dm_void,	idx)
+#define phydm_beamforming_set_iqgen_8814A(dm_void)	0
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8822b.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8822b.c
new file mode 100644
index 000000000000..75e08b50fd62
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8822b.c
@@ -0,0 +1,1112 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8814A TXBF mechanism                     */
+/*                                                           */
+/*============================================================*/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (RTL8822B_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+u8
+hal_txbf_8822b_get_ntx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			ntx = 0;
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (dm->support_interface == ODM_ITRF_USB) {
+		if (*dm->hub_usb_mode == 2) {/*USB3.0*/
+			if (dm->rf_type == RF_4T4R)
+				ntx = 3;
+			else if (dm->rf_type == RF_3T3R)
+				ntx = 2;
+			else
+				ntx = 1;
+		} else if (*dm->hub_usb_mode == 1)	/*USB 2.0 always 2Tx*/
+			ntx = 1;
+		else
+			ntx = 1;
+	} else
+#endif
+	{
+		if (dm->rf_type == RF_4T4R)
+			ntx = 3;
+		else if (dm->rf_type == RF_3T3R)
+			ntx = 2;
+		else
+			ntx = 1;
+	}
+
+	return ntx;
+
+}
+
+u8
+hal_txbf_8822b_get_nrx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			nrx = 0;
+
+	if (dm->rf_type == RF_4T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_3T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T2R)
+		nrx = 1;
+	else if (dm->rf_type == RF_2T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_1T1R)
+		nrx = 0;
+	else if (dm->rf_type == RF_1T2R)
+		nrx = 1;
+	else
+		nrx = 0;
+
+	return nrx;
+
+}
+
+/***************SU & MU BFee Entry********************/
+void
+hal_txbf_8822b_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beamforming_info,
+	u8					idx
+)
+{
+#if 0
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8				i, nr_index = 0;
+	boolean				is_self_beamformer = false;
+	boolean				is_self_beamformee = false;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	for (i = RF_PATH_A; i < RF_PATH_B; i++) {
+		odm_set_rf_reg(dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x1);
+		/*RF mode table write enable*/
+	}
+
+	if ((beamforming_info->beamformee_su_cnt > 0) || (beamforming_info->beamformee_mu_cnt > 0)) {
+		for (i = RF_PATH_A; i < RF_PATH_B; i++) {
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_addr, 0xfffff, 0x18000);
+			/*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_data0, 0xfffff, 0xBE77F);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_data1, 0xfffff, 0x226BF);
+			/*Enable TXIQGEN in RX mode*/
+		}
+		odm_set_rf_reg(dm, RF_PATH_A, rf_mode_table_data1, 0xfffff, 0xE26BF);
+		/*Enable TXIQGEN in RX mode*/
+	}
+
+	for (i = RF_PATH_A; i < RF_PATH_B; i++) {
+		odm_set_rf_reg(dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x0);
+		/*RF mode table write disable*/
+	}
+
+	if (beamforming_info->beamformee_su_cnt > 0) {
+
+		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
+
+		if (idx == 0) {
+			/*Nsts = 2	AB*/
+			odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8822B, 0xffff, 0x0433);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+			/*odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430);*/
+
+		} else {/*IDX =1*/
+			odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+			/*odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430;*/
+		}
+	} else {
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*1SS by path-A*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*2SS by path-A,B*/
+	}
+
+	if (beamforming_info->beamformee_mu_cnt > 0) {
+		/*MU STAs share the common setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1);
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+	}
+#endif
+}
+#if 0
+void
+hal_txbf_8822b_download_ndpa(
+	void			*adapter,
+	u8				idx
+)
+{
+	u8			u1b_tmp = 0, tmp_reg422 = 0;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	u16			head_page = 0x7FE;
+	boolean			is_send_beacon = false;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	hal_data->is_fw_dw_rsvd_page_in_progress = true;
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = platform_efio_read_1byte(adapter, REG_CR_8814A + 1);
+	platform_efio_write_1byte(adapter,  REG_CR_8814A + 1, (u1b_tmp | BIT(0)));
+
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = platform_efio_read_1byte(adapter, REG_FWHW_TXQ_CTRL_8814A + 2);
+	platform_efio_write_1byte(adapter, REG_FWHW_TXQ_CTRL_8814A + 2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		RT_TRACE(COMP_INIT, DBG_LOUD, ("SetBeamformDownloadNDPA_8814A(): There is an adapter is sending beacon.\n"));
+		is_send_beacon = true;
+	}
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	platform_efio_write_2byte(adapter, REG_FIFOPAGE_CTRL_2_8814A, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		platform_efio_write_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1, (bcn_valid_reg | BIT(7)));
+
+		/*download NDPA rsvd page.*/
+		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
+		else
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(7)) && count < 20) {
+			count++;
+			delay_us(10);
+			bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(7)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(0)))
+		RT_DISP(FBEAM, FBEAM_ERROR, ("%s Download RSVD page failed!\n", __func__));
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	platform_efio_write_2byte(adapter, REG_FIFOPAGE_CTRL_2_8814A, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		platform_efio_write_1byte(adapter, REG_FWHW_TXQ_CTRL_8814A + 2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = platform_efio_read_1byte(adapter, REG_CR_8814A + 1);
+	platform_efio_write_1byte(adapter, REG_CR_8814A + 1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+
+	hal_data->is_fw_dw_rsvd_page_in_progress = false;
+}
+
+void
+hal_txbf_8822b_fw_txbf_cmd(
+	void	*adapter
+)
+{
+	u8	idx, period = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+
+	PMGNT_INFO				mgnt_info = &(adapter->MgntInfo);
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beam_info->beamformee_entry[idx].is_sound) {
+				PageNum0 = 0xFE;
+				PageNum1 = 0x07;
+				period = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (PageNum0 == 0xFF) {
+				PageNum0 = 0xFF; /*stop sounding*/
+				PageNum1 = 0x0F;
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = period;
+	fill_h2c_cmd(adapter, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	RT_DISP(FBEAM, FBEAM_FUN, ("@%s End, PageNum0 = 0x%x, PageNum1 = 0x%x period = %d", __func__, PageNum0, PageNum1, period));
+}
+#endif
+
+#if 0
+void
+hal_txbf_8822b_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		u1b_tmp;
+	struct _RT_BEAMFORMING_INFO		*beamforming_info = &dm->beamforming_info;
+	void				*adapter = dm->adapter;
+
+	odm_set_bb_reg(dm, 0x14c0, BIT(16), 1); /*Enable P1 aggr new packet according to P0 transfer time*/
+	odm_set_bb_reg(dm, 0x14c0, BIT(15) | BIT14 | BIT13 | BIT12, 10); /*MU Retry Limit*/
+	odm_set_bb_reg(dm, 0x14c0, BIT(7), 0); /*Disable Tx MU-MIMO until sounding done*/
+	odm_set_bb_reg(dm, 0x14c0, 0x3F, 0); /* Clear validity of MU STAs */
+	odm_write_1byte(dm, 0x167c, 0x70); /*MU-MIMO Option as default value*/
+	odm_write_2byte(dm, 0x1680, 0); /*MU-MIMO Control as default value*/
+
+	/* Set MU NDPA rate & BW source */
+	/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+	u1b_tmp = odm_read_1byte(dm, 0x42C);
+	odm_write_1byte(dm, REG_TXBF_CTRL_8822B, (u1b_tmp | BIT(6)));
+	/* 0x45F[7:0] = 0x10 (rate=OFDM_6M, BW20) */
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8822B, 0x10);
+
+	/*Temp Settings*/
+	odm_set_bb_reg(dm, 0x6DC, 0x3F000000, 4); /*STA2's CSI rate is fixed at 6M*/
+	odm_set_bb_reg(dm, 0x1C94, MASKDWORD, 0xAFFFAFFF); /*Grouping bitmap parameters*/
+
+	/* Init HW variable */
+	beamforming_info->reg_mu_tx_ctrl = odm_read_4byte(dm, 0x14c0);
+
+	if (dm->rf_type == RF_2T2R) { /*2T2R*/
+		PHYDM_DBG(dm, DBG_TXBF, "%s: rf_type is 2T2R\n", __func__);
+		config_phydm_trx_mode_8822b(dm, (enum bb_path)3, (enum bb_path)3, true);/*Tx2path*/
+	}
+
+#if (OMNIPEEK_SNIFFER_ENABLED == 1)
+	/* Config HW to receive packet on the user position from registry for sniffer mode. */
+	/* odm_set_bb_reg(dm, 0xB00, BIT(9), 1);*/ /* For A-cut only. RegB00[9] = 1 (enable PMAC Rx) */
+	odm_set_bb_reg(dm, 0xB54, BIT(30), 1); /* RegB54[30] = 1 (force user position) */
+	odm_set_bb_reg(dm, 0xB54, (BIT(29) | BIT28), adapter->MgntInfo.sniff_user_position); /* RegB54[29:28] = user position (0~3) */
+	PHYDM_DBG(dm, DBG_TXBF, "Set adapter->MgntInfo.sniff_user_position=%#X\n", adapter->MgntInfo.sniff_user_position);
+#endif
+}
+#endif
+
+void
+hal_txbf_8822b_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	u16					csi_param = 0;
+	struct _RT_BEAMFORMING_INFO		*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	*beamformer_entry;
+	u16					value16, sta_id = 0;
+	u8					nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
+	u32					gid_valid, user_position_l, user_position_h;
+	u32					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
+	u8					u1b_tmp;
+	u32					u4b_tmp;
+
+	RT_DISP(FBEAM, FBEAM_FUN, ("%s: bfer_bfee_idx=%d, bfer_idx=%d, bfee_idx=%d\n", __func__, bfer_bfee_idx, bfer_idx, bfee_idx));
+
+	/*************SU BFer Entry Init*************/
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = &beamforming_info->beamformer_entry[bfer_idx];
+		beamformer_entry->is_mu_ap = false;
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+
+		for (i = 0; i < MAX_BEAMFORMER_SU; i++) {
+			if ((beamforming_info->beamformer_su_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformer_su_reg_maping |= BIT(i);
+				beamformer_entry->su_reg_index = i;
+				break;
+			}
+		}
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (beamformer_entry->su_reg_index == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), beamformer_entry->mac_addr[i]);
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8822B + i), beamformer_entry->mac_addr[i]);
+		}
+
+		/*CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8822b_get_nrx(dm);	/*for 8814A nrx = 3(4 ant), min=0(1 ant)*/
+		nr_index = beamformer_entry->num_of_sounding_dim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+
+		grouping = 0;
+
+		/*for ac = 1, for n = 3*/
+		if (beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU)
+			codebookinfo = 1;
+		else if (beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
+			codebookinfo = 3;
+
+		coefficientsize = 3;
+
+		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
+
+		if (bfer_idx == 0)
+			odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, csi_param);
+		else
+			odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, csi_param);
+		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B + 3, 0x70);
+
+	}
+
+	/*************SU BFee Entry Init*************/
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		p_beamformee_entry = &beamforming_info->beamformee_entry[bfee_idx];
+		p_beamformee_entry->is_mu_sta = false;
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, bfee_idx);
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = p_beamformee_entry->mac_id;
+		else
+			sta_id = p_beamformee_entry->p_aid;
+
+		for (i = 0; i < MAX_BEAMFORMEE_SU; i++) {
+			if ((beamforming_info->beamformee_su_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformee_su_reg_maping |= BIT(i);
+				p_beamformee_entry->su_reg_index = i;
+				break;
+			}
+		}
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (p_beamformee_entry->su_reg_index == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8822B, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8822B + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
+
+		/*CSI report parameters of Beamformee*/
+		if (p_beamformee_entry->su_reg_index == 0) {
+			/*Get BIT24 & BIT25*/
+			u8	tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3) & 0x3;
+
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B, sta_id | BIT(9));
+		} else
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2, sta_id | 0xE200);	/*Set BIT25*/
+
+		phydm_beamforming_notify(dm);
+	}
+
+	/*************MU BFer Entry Init*************/
+	if ((beamforming_info->beamformer_mu_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = &beamforming_info->beamformer_entry[bfer_idx];
+		beamforming_info->mu_ap_index = bfer_idx;
+		beamformer_entry->is_mu_ap = true;
+		for (i = 0; i < 8; i++)
+			beamformer_entry->gid_valid[i] = 0;
+		for (i = 0; i < 16; i++)
+			beamformer_entry->user_position[i] = 0;
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+		/* MAC address */
+		for (i = 0; i < 6 ; i++)
+			odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), beamformer_entry->mac_addr[i]);
+
+		/* Set partial AID */
+		odm_write_2byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + 6), beamformer_entry->p_aid);
+
+		/* Fill our AID to 0x1680[11:0] and [13:12] = 2b'00, BF report segment select to 3895 bytes*/
+		u1b_tmp = odm_read_1byte(dm, 0x1680);
+		u1b_tmp = (beamformer_entry->p_aid) & 0xFFF;
+		odm_write_1byte(dm, 0x1680, u1b_tmp);
+
+		/* Set 80us for leaving ndp_rx_standby_state */
+		odm_write_1byte(dm, 0x71B, 0x50);
+
+		/* Set 0x6A0[14] = 1 to accept action_no_ack */
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP0_8822B + 1);
+		u1b_tmp |= 0x40;
+		odm_write_1byte(dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
+		/* Set 0x6A2[5:4] = 1 to NDPA and BF report poll */
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP1_8822B);
+		u1b_tmp |= 0x30;
+		odm_write_1byte(dm, REG_RXFLTMAP1_8822B, u1b_tmp);
+
+		/*CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8822b_get_nrx(dm);	/* Depend on RF type */
+		nr_index = 1;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+		grouping = 0; /*no grouping*/
+		codebookinfo = 1; /*7 bit for psi, 9 bit for phi*/
+		coefficientsize = 0; /*This is nothing really matter*/
+		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
+		odm_write_2byte(dm, 0x6F4, csi_param);
+
+		/*for B-cut*/
+		odm_set_bb_reg(dm, 0x6A0, BIT(20), 0);
+		odm_set_bb_reg(dm, 0x688, BIT(20), 0);
+
+	}
+
+	/*************MU BFee Entry Init*************/
+	if ((beamforming_info->beamformee_mu_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		p_beamformee_entry = &beamforming_info->beamformee_entry[bfee_idx];
+		p_beamformee_entry->is_mu_sta = true;
+		for (i = 0; i < MAX_BEAMFORMEE_MU; i++) {
+			if ((beamforming_info->beamformee_mu_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformee_mu_reg_maping |= BIT(i);
+				p_beamformee_entry->mu_reg_index = i;
+				break;
+			}
+		}
+
+		if (p_beamformee_entry->mu_reg_index == 0xFF) {
+			/* There is no valid bit in beamformee_mu_reg_maping */
+			RT_DISP(FBEAM, FBEAM_FUN, ("%s: ERROR! There is no valid bit in beamformee_mu_reg_maping!\n", __func__));
+			return;
+		}
+
+		/*User position table*/
+		switch (p_beamformee_entry->mu_reg_index) {
+		case 0:
+			gid_valid = 0x7fe;
+			user_position_l = 0x111110;
+			user_position_h = 0x0;
+			break;
+		case 1:
+			gid_valid = 0x7f806;
+			user_position_l = 0x11000004;
+			user_position_h = 0x11;
+			break;
+		case 2:
+			gid_valid = 0x1f81818;
+			user_position_l = 0x400040;
+			user_position_h = 0x11100;
+			break;
+		case 3:
+			gid_valid = 0x1e186060;
+			user_position_l = 0x4000400;
+			user_position_h = 0x1100040;
+			break;
+		case 4:
+			gid_valid = 0x66618180;
+			user_position_l = 0x40004000;
+			user_position_h = 0x10040400;
+			break;
+		case 5:
+			gid_valid = 0x79860600;
+			user_position_l = 0x40000;
+			user_position_h = 0x4404004;
+			break;
+		}
+
+		for (i = 0; i < 8; i++) {
+			if (i < 4) {
+				p_beamformee_entry->gid_valid[i] = (u8)(gid_valid & 0xFF);
+				gid_valid = (gid_valid >> 8);
+			} else
+				p_beamformee_entry->gid_valid[i] = 0;
+		}
+		for (i = 0; i < 16; i++) {
+			if (i < 4)
+				p_beamformee_entry->user_position[i] = (u8)((user_position_l >> (i * 8)) & 0xFF);
+			else if (i < 8)
+				p_beamformee_entry->user_position[i] = (u8)((user_position_h >> ((i - 4) * 8)) & 0xFF);
+			else
+				p_beamformee_entry->user_position[i] = 0;
+		}
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+		/*select MU STA table*/
+		beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+		beamforming_info->reg_mu_tx_ctrl |= (p_beamformee_entry->mu_reg_index << 8) & (BIT(8) | BIT(9) | BIT(10));
+		odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+		odm_set_bb_reg(dm, 0x14c4, MASKDWORD, 0); /*Reset gid_valid table*/
+		odm_set_bb_reg(dm, 0x14c8, MASKDWORD, user_position_l);
+		odm_set_bb_reg(dm, 0x14cc, MASKDWORD, user_position_h);
+
+		/*set validity of MU STAs*/
+		beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+		beamforming_info->reg_mu_tx_ctrl |= beamforming_info->beamformee_mu_reg_maping & 0x3F;
+		odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, reg_mu_tx_ctrl = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+			__func__, beamforming_info->reg_mu_tx_ctrl, user_position_l, user_position_h);
+
+		value16 = odm_read_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index]);
+		value16 &= 0xFE00; /*Clear PAID*/
+		value16 |= BIT(9); /*Enable MU BFee*/
+		value16 |= p_beamformee_entry->p_aid;
+		odm_write_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index], value16);
+
+		/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+		u1b_tmp = odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3);
+		u1b_tmp |= 0xD0; /* Set bit 28, 30, 31 to 3b'111*/
+		odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, u1b_tmp);
+		/* Set NDPA to 6M*/
+		odm_write_1byte(dm, REG_NDPA_RATE_8822B, 0x4);
+
+		u1b_tmp = odm_read_1byte(dm, REG_NDPA_OPT_CTRL_8822B);
+		u1b_tmp &= 0xFC; /* Clear bit 0, 1*/
+		odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8822B, u1b_tmp);
+
+		u4b_tmp = odm_read_4byte(dm, REG_SND_PTCL_CTRL_8822B);
+		u4b_tmp = ((u4b_tmp & 0xFF0000FF) | 0x020200); /* Set [23:8] to 0x0202*/
+		odm_write_4byte(dm, REG_SND_PTCL_CTRL_8822B, u4b_tmp);
+
+		/* Set 0x6A0[14] = 1 to accept action_no_ack */
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP0_8822B + 1);
+		u1b_tmp |= 0x40;
+		odm_write_1byte(dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
+		/* End of MAC registers setting */
+
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, bfee_idx);
+#if (SUPPORT_MU_BF == 1)
+		/*Special for plugfest*/
+		delay_ms(50); /* wait for 4-way handshake ending*/
+		send_sw_vht_gid_mgnt_frame(dm, p_beamformee_entry->mac_addr, bfee_idx);
+#endif
+
+		phydm_beamforming_notify(dm);
+#if 1
+		{
+			u32 ctrl_info_offset, index;
+			/*Set Ctrl Info*/
+			odm_write_2byte(dm, 0x140, 0x660);
+			ctrl_info_offset = 0x8000 + 32 * p_beamformee_entry->mac_id;
+			/*Reset Ctrl Info*/
+			for (index = 0; index < 8; index++)
+				odm_write_4byte(dm, ctrl_info_offset + index * 4, 0);
+
+			odm_write_4byte(dm, ctrl_info_offset, (p_beamformee_entry->mu_reg_index + 1) << 16);
+			odm_write_1byte(dm, 0x81, 0x80); /*RPTBUF ready*/
+
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, mac_id = %d, ctrl_info_offset = 0x%x, mu_reg_index = %x\n",
+				__func__, p_beamformee_entry->mac_id, ctrl_info_offset, p_beamformee_entry->mu_reg_index);
+		}
+#endif
+	}
+
+}
+
+
+void
+hal_txbf_8822b_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	*beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beamformee_entry;
+	u32					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
+
+	if (idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = &beamforming_info->beamformer_entry[idx];
+		p_beamformee_entry = &beamforming_info->beamformee_entry[idx];
+	} else
+		return;
+
+	/*Clear P_AID of Beamformee*/
+	/*Clear MAC address of Beamformer*/
+	/*Clear Associated Bfmee Sel*/
+
+	if (beamformer_entry->beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xD8);
+		if (beamformer_entry->is_mu_ap == 0) { /*SU BFer */
+			if (beamformer_entry->su_reg_index == 0) {
+				odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8822B, 0);
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8822B + 4, 0);
+				odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, 0);
+			} else {
+				odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8822B, 0);
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8822B + 4, 0);
+				odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, 0);
+			}
+			beamforming_info->beamformer_su_reg_maping &= ~(BIT(beamformer_entry->su_reg_index));
+			beamformer_entry->su_reg_index = 0xFF;
+		} else { /*MU BFer */
+			/*set validity of MU STA0 and MU STA1*/
+			beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+			odm_memory_set(dm, beamformer_entry->gid_valid, 0, 8);
+			odm_memory_set(dm, beamformer_entry->user_position, 0, 16);
+			beamformer_entry->is_mu_ap = false;
+		}
+	}
+
+	if (p_beamformee_entry->beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, idx);
+		if (p_beamformee_entry->is_mu_sta == 0) { /*SU BFee*/
+			if (p_beamformee_entry->su_reg_index == 0) {
+				odm_write_2byte(dm, REG_TXBF_CTRL_8822B, 0x0);
+				odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B, 0);
+			} else {
+				odm_write_2byte(dm, REG_TXBF_CTRL_8822B + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
+
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2,
+					odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2) & 0x60);
+			}
+			beamforming_info->beamformee_su_reg_maping &= ~(BIT(p_beamformee_entry->su_reg_index));
+			p_beamformee_entry->su_reg_index = 0xFF;
+		} else { /*MU BFee */
+			/*Disable sending NDPA & BF-rpt-poll to this BFee*/
+			odm_write_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index], 0);
+			/*set validity of MU STA*/
+			beamforming_info->reg_mu_tx_ctrl &= ~(BIT(p_beamformee_entry->mu_reg_index));
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+
+			p_beamformee_entry->is_mu_sta = false;
+			beamforming_info->beamformee_mu_reg_maping &= ~(BIT(p_beamformee_entry->mu_reg_index));
+			p_beamformee_entry->mu_reg_index = 0xFF;
+		}
+	}
+}
+
+
+/***********SU & MU BFee Entry Only when souding done****************/
+void
+hal_txbf_8822b_status(
+	void			*dm_void,
+	u8				beamform_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val, tmp_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry;
+	boolean	is_mu_sounding = beamforming_info->is_mu_sounding, is_bitmap_ready = false;
+	u16 bitmap;
+	u8 idx, gid, i;
+	u8 id1, id0;
+	u32 gid_valid[6] = {0};
+	u32 value32;
+	boolean is_sounding_success[6] = {false};
+
+	if (beamform_idx < BEAMFORMEE_ENTRY_NUM)
+		beamform_entry = &beamforming_info->beamformee_entry[beamform_idx];
+	else
+		return;
+
+	/*SU sounding done */
+	if (is_mu_sounding == false) {
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			beam_ctrl_val = beamform_entry->mac_id;
+		else
+			beam_ctrl_val = beamform_entry->p_aid;
+
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, beamform_entry.beamform_entry_state = %d", __func__, beamform_entry->beamform_entry_state);
+
+		if (beamform_entry->su_reg_index == 0)
+			beam_ctrl_reg = REG_TXBF_CTRL_8822B;
+		else {
+			beam_ctrl_reg = REG_TXBF_CTRL_8822B + 2;
+			beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+		}
+
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beamform_entry->sound_bw == CHANNEL_WIDTH_20)
+				beam_ctrl_val |= BIT(9);
+			else if (beamform_entry->sound_bw == CHANNEL_WIDTH_40)
+				beam_ctrl_val |= (BIT(9) | BIT(10));
+			else if (beamform_entry->sound_bw == CHANNEL_WIDTH_80)
+				beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
+		} else {
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, Don't apply Vmatrix",  __func__);
+			beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+		}
+
+		odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+		/*disable NDP packet use beamforming */
+		tmp_val = odm_read_2byte(dm, REG_TXBF_CTRL_8822B);
+		odm_write_2byte(dm, REG_TXBF_CTRL_8822B, tmp_val | BIT(15));
+	} else {
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, MU Sounding Done\n",  __func__);
+		/*MU sounding done */
+		if (1) { /* (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) { */
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, BEAMFORMING_ENTRY_STATE_PROGRESSED\n",  __func__);
+
+			value32 = odm_get_bb_reg(dm, 0x1684, MASKDWORD);
+			is_sounding_success[0] = (value32 & BIT(10)) ? 1 : 0;
+			is_sounding_success[1] = (value32 & BIT(26)) ? 1 : 0;
+			value32 = odm_get_bb_reg(dm, 0x1688, MASKDWORD);
+			is_sounding_success[2] = (value32 & BIT(10)) ? 1 : 0;
+			is_sounding_success[3] = (value32 & BIT(26)) ? 1 : 0;
+			value32 = odm_get_bb_reg(dm, 0x168C, MASKDWORD);
+			is_sounding_success[4] = (value32 & BIT(10)) ? 1 : 0;
+			is_sounding_success[5] = (value32 & BIT(26)) ? 1 : 0;
+
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, is_sounding_success STA1:%d,  STA2:%d, STA3:%d, STA4:%d, STA5:%d, STA6:%d\n",
+				__func__, is_sounding_success[0], is_sounding_success[1], is_sounding_success[2], is_sounding_success[3], is_sounding_success[4], is_sounding_success[5]);
+
+			value32 = odm_get_bb_reg(dm, 0xF4C, 0xFFFF0000);
+			/* odm_set_bb_reg(dm, 0x19E0, MASKHWORD, 0xFFFF);Let MAC ignore bitmap */
+
+			is_bitmap_ready = (boolean)((value32 & BIT(15)) >> 15);
+			bitmap = (u16)(value32 & 0x3FFF);
+
+			for (idx = 0; idx < 15; idx++) {
+				if (idx < 5) {/*bit0~4*/
+					id0 = 0;
+					id1 = (u8)(idx + 1);
+				} else if (idx < 9) { /*bit5~8*/
+					id0 = 1;
+					id1 = (u8)(idx - 3);
+				} else if (idx < 12) { /*bit9~11*/
+					id0 = 2;
+					id1 = (u8)(idx - 6);
+				} else if (idx < 14) { /*bit12~13*/
+					id0 = 3;
+					id1 = (u8)(idx - 8);
+				} else { /*bit14*/
+					id0 = 4;
+					id1 = (u8)(idx - 9);
+				}
+				if (bitmap & BIT(idx)) {
+					/*Pair 1*/
+					gid = (idx << 1) + 1;
+					gid_valid[id0] |= (BIT(gid));
+					gid_valid[id1] |= (BIT(gid));
+					/*Pair 2*/
+					gid += 1;
+					gid_valid[id0] |= (BIT(gid));
+					gid_valid[id1] |= (BIT(gid));
+				} else {
+					/*Pair 1*/
+					gid = (idx << 1) + 1;
+					gid_valid[id0] &= ~(BIT(gid));
+					gid_valid[id1] &= ~(BIT(gid));
+					/*Pair 2*/
+					gid += 1;
+					gid_valid[id0] &= ~(BIT(gid));
+					gid_valid[id1] &= ~(BIT(gid));
+				}
+			}
+
+			for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+				beamform_entry = &beamforming_info->beamformee_entry[i];
+				if ((beamform_entry->is_mu_sta) && (beamform_entry->mu_reg_index < 6)) {
+					value32 = gid_valid[beamform_entry->mu_reg_index];
+					for (idx = 0; idx < 4; idx++) {
+						beamform_entry->gid_valid[idx] = (u8)(value32 & 0xFF);
+						value32 = (value32 >> 8);
+					}
+				}
+			}
+
+			for (idx = 0; idx < 6; idx++) {
+				beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+				beamforming_info->reg_mu_tx_ctrl |= ((idx << 8) & (BIT(8) | BIT(9) | BIT(10)));
+				odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+				odm_set_mac_reg(dm, 0x14C4, MASKDWORD, gid_valid[idx]); /*set MU STA gid valid table*/
+			}
+
+			/*Enable TxMU PPDU*/
+			if (beamforming_info->dbg_disable_mu_tx == false)
+				beamforming_info->reg_mu_tx_ctrl |= BIT(7);
+			else
+				beamforming_info->reg_mu_tx_ctrl &= ~BIT(7);
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+		}
+	}
+}
+
+/*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
+void
+hal_txbf_8822b_config_gtab(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	*beamformer_entry = NULL;
+	u32		gid_valid = 0, user_position_l = 0, user_position_h = 0, i;
+
+	if (beamforming_info->mu_ap_index < BEAMFORMER_ENTRY_NUM)
+		beamformer_entry = &beamforming_info->beamformer_entry[beamforming_info->mu_ap_index];
+	else
+		return;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s==>\n", __func__);
+
+	/*For GID 0~31*/
+	for (i = 0; i < 4; i++)
+		gid_valid |= (beamformer_entry->gid_valid[i] << (i << 3));
+	for (i = 0; i < 8; i++) {
+		if (i < 4)
+			user_position_l |= (beamformer_entry->user_position[i] << (i << 3));
+		else
+			user_position_h |= (beamformer_entry->user_position[i] << ((i - 4) << 3));
+	}
+	/*select MU STA0 table*/
+	beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+	odm_set_bb_reg(dm, 0x14c4, MASKDWORD, gid_valid);
+	odm_set_bb_reg(dm, 0x14c8, MASKDWORD, user_position_l);
+	odm_set_bb_reg(dm, 0x14cc, MASKDWORD, user_position_h);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s: STA0: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+			__func__, gid_valid, user_position_l, user_position_h);
+
+	gid_valid = 0;
+	user_position_l = 0;
+	user_position_h = 0;
+
+	/*For GID 32~64*/
+	for (i = 4; i < 8; i++)
+		gid_valid |= (beamformer_entry->gid_valid[i] << ((i - 4) << 3));
+	for (i = 8; i < 16; i++) {
+		if (i < 4)
+			user_position_l |= (beamformer_entry->user_position[i] << ((i - 8) << 3));
+		else
+			user_position_h |= (beamformer_entry->user_position[i] << ((i - 12) << 3));
+	}
+	/*select MU STA1 table*/
+	beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+	beamforming_info->reg_mu_tx_ctrl |= BIT(8);
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+	odm_set_bb_reg(dm, 0x14c4, MASKDWORD, gid_valid);
+	odm_set_bb_reg(dm, 0x14c8, MASKDWORD, user_position_l);
+	odm_set_bb_reg(dm, 0x14cc, MASKDWORD, user_position_h);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s: STA1: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+			__func__, gid_valid, user_position_l, user_position_h);
+
+	/* Set validity of MU STA0 and MU STA1*/
+	beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+	beamforming_info->reg_mu_tx_ctrl |= 0x3; /* STA0, STA1*/
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+}
+
+
+
+#if 0
+/*This function translate the bitmap to GTAB*/
+void
+haltxbf8822b_gtab_translation(
+	struct dm_struct			*dm
+)
+{
+	u8 idx, gid;
+	u8 id1, id0;
+	u32 gid_valid[6] = {0};
+	u32 user_position_lsb[6] = {0};
+	u32 user_position_msb[6] = {0};
+
+	for (idx = 0; idx < 15; idx++) {
+		if (idx < 5) {/*bit0~4*/
+			id0 = 0;
+			id1 = (u8)(idx + 1);
+		} else if (idx < 9) { /*bit5~8*/
+			id0 = 1;
+			id1 = (u8)(idx - 3);
+		} else if (idx < 12) { /*bit9~11*/
+			id0 = 2;
+			id1 = (u8)(idx - 6);
+		} else if (idx < 14) { /*bit12~13*/
+			id0 = 3;
+			id1 = (u8)(idx - 8);
+		} else { /*bit14*/
+			id0 = 4;
+			id1 = (u8)(idx - 9);
+		}
+
+		/*Pair 1*/
+		gid = (idx << 1) + 1;
+		gid_valid[id0] |= (1 << gid);
+		gid_valid[id1] |= (1 << gid);
+		if (gid < 16) {
+			/*user_position_lsb[id0] |= (0 << (gid << 1));*/
+			user_position_lsb[id1] |= (1 << (gid << 1));
+		} else {
+			/*user_position_msb[id0] |= (0 << ((gid - 16) << 1));*/
+			user_position_msb[id1] |= (1 << ((gid - 16) << 1));
+		}
+
+		/*Pair 2*/
+		gid += 1;
+		gid_valid[id0] |= (1 << gid);
+		gid_valid[id1] |= (1 << gid);
+		if (gid < 16) {
+			user_position_lsb[id0] |= (1 << (gid << 1));
+			/*user_position_lsb[id1] |= (0 << (gid << 1));*/
+		} else {
+			user_position_msb[id0] |= (1 << ((gid - 16) << 1));
+			/*user_position_msb[id1] |= (0 << ((gid - 16) << 1));*/
+		}
+
+	}
+
+
+	for (idx = 0; idx < 6; idx++) {
+		/*dbg_print("gid_valid[%d] = 0x%x\n", idx, gid_valid[idx]);
+		dbg_print("user_position[%d] = 0x%x   %x\n", idx, user_position_msb[idx], user_position_lsb[idx]);*/
+	}
+}
+#endif
+
+void
+hal_txbf_8822b_fw_txbf(
+	void			*dm_void,
+	u8				idx
+)
+{
+#if 0
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_8822b_download_ndpa(adapter, idx);
+
+	hal_txbf_8822b_fw_txbf_cmd(adapter);
+#endif
+}
+
+#endif
+
+#if (defined(CONFIG_BB_TXBF_API))
+/*this function is only used for BFer*/
+void
+phydm_8822btxbf_rfmode(
+	void		*dm_void,
+	u8	su_bfee_cnt,
+	u8	mu_bfee_cnt
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		i;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	if ((su_bfee_cnt > 0) || (mu_bfee_cnt > 0)) {
+		for (i = RF_PATH_A; i <= RF_PATH_B; i++) {
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x1); /*RF mode table write enable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x33, 0xF, 3); /*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3E, 0xfffff, 0x00036); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3F, 0xfffff, 0x5AFCE); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x0); /*RF mode table write disable*/
+		}
+	}
+
+	odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(30), 1);			/*if Nsts > Nc, don't apply V matrix*/
+
+	if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2);	/*enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1);			/*ignore user since 8822B only 2Tx*/
+		
+
+		/*Nsts = 2	AB*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+
+	} else {
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x0);	/*enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 0);			/*ignore user since 8822B only 2Tx*/
+
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*1SS by path-A*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*2SS by path-A,B*/
+	}
+
+}
+
+
+/*this function is for BFer bug workaround*/
+void
+phydm_8822b_sutxbfer_workaroud(
+	void		*dm_void,
+	boolean	enable_su_bfer,
+	u8	nc,
+	u8	nr,
+	u8	ng,
+	u8	CB,
+	u8	BW,
+	boolean	is_vht
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (enable_su_bfer) {
+		odm_set_bb_reg(dm, 0x19f8, BIT(22) | BIT(21) | BIT(20), 0x1);
+		odm_set_bb_reg(dm, 0x19f8, BIT(25) | BIT(24) | BIT(23), 0x0);
+		odm_set_bb_reg(dm, 0x19f8, BIT(16), 0x1);
+
+		if (is_vht)
+			odm_set_bb_reg(dm, 0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x1f);
+		else
+			odm_set_bb_reg(dm, 0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x22);
+
+		odm_set_bb_reg(dm, 0x19f0, BIT(7) | BIT(6), nc);
+		odm_set_bb_reg(dm, 0x19f0, BIT(9) | BIT(8), nr);
+		odm_set_bb_reg(dm, 0x19f0, BIT(11) | BIT(10), ng);
+		odm_set_bb_reg(dm, 0x19f0, BIT(13) | BIT(12), CB);
+
+		odm_set_bb_reg(dm, 0xb58, BIT(3) | BIT(2), BW);
+		odm_set_bb_reg(dm, 0xb58, BIT(7) | BIT(6) | BIT(5) | BIT(4), 0x0);
+		odm_set_bb_reg(dm, 0xb58, BIT(9) | BIT(8), BW);
+		odm_set_bb_reg(dm, 0xb58, BIT(13) | BIT(12) | BIT(11) | BIT(10), 0x0);
+	} else
+		odm_set_bb_reg(dm, 0x19f8, BIT(16), 0x0);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] enable_su_bfer = %d, is_vht = %d\n", __func__, enable_su_bfer, is_vht);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] nc = %d, nr = %d, ng = %d, CB = %d, BW = %d\n", __func__, nc, nr, ng, CB, BW);
+
+
+}
+#endif
+#endif	/* (RTL8822B_SUPPORT == 1)*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8822b.h
new file mode 100644
index 000000000000..ba3316215fe2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbf8822b.h
@@ -0,0 +1,103 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_8822B_H__
+#define __HAL_TXBF_8822B_H__
+
+#if (RTL8822B_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_txbf_8822b_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8822b_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8822b_status(
+	void			*dm_void,
+	u8				beamform_idx
+);
+
+void
+hal_txbf_8822b_config_gtab(
+	void			*dm_void
+);
+
+void
+hal_txbf_8822b_fw_txbf(
+	void			*dm_void,
+	u8				idx
+);
+#else
+#define hal_txbf_8822b_enter(dm_void, idx)
+#define hal_txbf_8822b_leave(dm_void, idx)
+#define hal_txbf_8822b_status(dm_void, idx)
+#define hal_txbf_8822b_fw_txbf(dm_void, idx)
+#define hal_txbf_8822b_config_gtab(dm_void)
+
+#endif
+
+#if (defined(CONFIG_BB_TXBF_API))
+void
+phydm_8822btxbf_rfmode(
+	void		*dm_void,
+	u8	su_bfee_cnt,
+	u8	mu_bfee_cnt
+);
+
+void
+phydm_8822b_sutxbfer_workaroud(
+	void		*dm_void,
+	boolean	enable_su_bfer,
+	u8	nc,
+	u8	nr,
+	u8	ng,
+	u8	CB,
+	u8	BW,
+	boolean	is_vht
+);
+
+#else
+#define phydm_8822btxbf_rfmode(dm_void, su_bfee_cnt, mu_bfee_cnt)
+#define phydm_8822b_sutxbfer_workaroud(dm_void, enable_su_bfer, nc, nr, ng, CB, BW, is_vht)
+#endif
+
+#else
+#define hal_txbf_8822b_enter(dm_void, idx)
+#define hal_txbf_8822b_leave(dm_void, idx)
+#define hal_txbf_8822b_status(dm_void, idx)
+#define hal_txbf_8822b_fw_txbf(dm_void, idx)
+#define hal_txbf_8822b_config_gtab(dm_void)
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfinterface.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfinterface.c
new file mode 100644
index 000000000000..dbaeb04f12ec
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfinterface.c
@@ -0,0 +1,1520 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 TXBF interface mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+beamforming_gid_paid(
+	void	*adapter,
+	PRT_TCB		tcb
+)
+{
+	u8		RA[6] = {0};
+	u8		*p_header = GET_FRAME_OF_FIRST_FRAG((PADAPTER)adapter, tcb);
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct				*dm = &hal_data->DM_OutSrc;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+
+	if (((PADAPTER)adapter)->HardwareType < HARDWARE_TYPE_RTL8192EE)
+		return;
+	else if (IS_WIRELESS_MODE_N((PADAPTER)adapter) == false)
+		return;
+
+#if (SUPPORT_MU_BF == 1)
+	if (tcb->tx_bf_pkt_type == RT_BF_PKT_TYPE_BROADCAST_NDPA) { /* MU NDPA */
+#else
+	if (0) {
+#endif
+		/* Fill G_ID and P_AID */
+		tcb->G_ID = 63;
+		if (beam_info->first_mu_bfee_index < BEAMFORMEE_ENTRY_NUM) {
+			tcb->P_AID = beam_info->beamformee_entry[beam_info->first_mu_bfee_index].p_aid;
+			RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, tcb->G_ID, tcb->P_AID));
+		}
+	} else {
+		GET_80211_HDR_ADDRESS1(p_header, &RA);
+
+		/* VHT SU PPDU carrying one or more group addressed MPDUs or */
+		/* Transmitting a VHT NDP intended for multiple recipients */
+		if (MacAddr_isBcst(RA) || MacAddr_isMulticast(RA)	|| tcb->macId == MAC_ID_STATIC_FOR_BROADCAST_MULTICAST) {
+			tcb->G_ID = 63;
+			tcb->P_AID = 0;
+		} else if (ACTING_AS_AP((PADAPTER)adapter)) {
+			u16	AID = (u16)(MacIdGetOwnerAssociatedClientAID((PADAPTER)adapter, tcb->macId) & 0x1ff);		/*AID[0:8]*/
+
+			/*RT_DISP(FBEAM, FBEAM_FUN, ("@%s  tcb->mac_id=0x%X, AID=0x%X\n", __func__, tcb->mac_id, AID));*/
+			tcb->G_ID = 63;
+
+			if (AID == 0)		/*A PPDU sent by an AP to a non associated STA*/
+				tcb->P_AID = 0;
+			else {				/*Sent by an AP and addressed to a STA associated with that AP*/
+				u16	BSSID = 0;
+				GET_80211_HDR_ADDRESS2(p_header, &RA);
+				BSSID = ((RA[5] & 0xf0) >> 4) ^ (RA[5] & 0xf);	/*BSSID[44:47] xor BSSID[40:43]*/
+				tcb->P_AID = (AID + BSSID * 32) & 0x1ff;		/*(dec(A) + dec(B)*32) mod 512*/
+			}
+		} else if (ACTING_AS_IBSS(((PADAPTER)adapter))) {
+			tcb->G_ID = 63;
+			/*P_AID for infrasturcture mode; MACID for ad-hoc mode. */
+			tcb->P_AID = tcb->macId;
+		} else if (MgntLinkStatusQuery((PADAPTER)adapter)) {				/*Addressed to AP*/
+			tcb->G_ID = 0;
+			GET_80211_HDR_ADDRESS1(p_header, &RA);
+			tcb->P_AID =  RA[5];							/*RA[39:47]*/
+			tcb->P_AID = (tcb->P_AID << 1) | (RA[4] >> 7);
+		} else {
+			tcb->G_ID = 63;
+			tcb->P_AID = 0;
+		}
+		/*RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, tcb->G_ID, tcb->P_AID));*/
+	}
+}
+
+
+enum rt_status
+beamforming_get_report_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+)
+{
+	HAL_DATA_TYPE				*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct					*dm = &hal_data->DM_OutSrc;
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	u8						*p_mimo_ctrl_field, p_csi_matrix;
+	u8						idx, nc, nr, CH_W;
+	u16						csi_matrix_len = 0;
+
+	ACT_PKT_TYPE				pkt_type = ACT_PKT_TYPE_UNKNOWN;
+
+	/* Memory comparison to see if CSI report is the same with previous one */
+	beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, Frame_Addr2(*p_pdu_os), &idx);
+
+	if (beamform_entry == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "beamforming_get_report_frame: Cannot find entry by addr\n");
+		return RT_STATUS_FAILURE;
+	}
+
+	pkt_type = PacketGetActionFrameType(p_pdu_os);
+
+	/* -@ Modified by David */
+	if (pkt_type == ACT_PKT_VHT_COMPRESSED_BEAMFORMING) {
+		p_mimo_ctrl_field = p_pdu_os->Octet + 26;
+		nc = ((*p_mimo_ctrl_field) & 0x7) + 1;
+		nr = (((*p_mimo_ctrl_field) & 0x38) >> 3) + 1;
+		CH_W = (((*p_mimo_ctrl_field) & 0xC0) >> 6);
+		/*p_csi_matrix = p_mimo_ctrl_field + 3 + nc;*/ /* 24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(nc=2) */
+		csi_matrix_len = p_pdu_os->Length  - 26 - 3 - nc;
+	} else if (pkt_type == ACT_PKT_HT_COMPRESSED_BEAMFORMING) {
+		p_mimo_ctrl_field = p_pdu_os->Octet + 26;
+		nc = ((*p_mimo_ctrl_field) & 0x3) + 1;
+		nr = (((*p_mimo_ctrl_field) & 0xC) >> 2) + 1;
+		CH_W = (((*p_mimo_ctrl_field) & 0x10) >> 4);
+		/*p_csi_matrix = p_mimo_ctrl_field + 6 + nr;*/	/* 24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(nc=2) */
+		csi_matrix_len = p_pdu_os->Length  - 26 - 6 - nr;
+	} else
+		return RT_STATUS_SUCCESS;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] idx=%d, pkt type=%d, nc=%d, nr=%d, CH_W=%d\n", __func__, idx, pkt_type, nc, nr, CH_W);
+
+	return RT_STATUS_SUCCESS;
+}
+
+
+void
+construct_ht_ndpa_packet(
+	// 2017/11 MH PHYDM compile. But why need to use windows maco? 
+	// For all linux code, it should be useless?
+	//void				*adapter = dm->adapter;
+	ADAPTER				*adapter,
+	//void		*adapter,
+	u8			*RA,
+	u8			*buffer,
+	u32			*p_length,
+	enum channel_width	BW
+)
+{
+	u16					duration = 0;
+	PMGNT_INFO				mgnt_info = &(((PADAPTER)adapter)->MgntInfo);
+	//PMGNT_INFO				mgnt_info = &((MGNT_INFO)(((PADAPTER)adapter)->MgntInfo));
+	OCTET_STRING			p_ndpa_frame, action_content;
+	u8					action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+
+	PlatformZeroMemory(buffer, 32);
+
+	SET_80211_HDR_FRAME_CONTROL(buffer, 0);
+
+	SET_80211_HDR_ORDER(buffer, 1);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(buffer, Type_Action_No_Ack);
+
+	SET_80211_HDR_ADDRESS1(buffer, RA);
+	SET_80211_HDR_ADDRESS2(buffer, ((PADAPTER)adapter)->CurrentAddress);
+	SET_80211_HDR_ADDRESS3(buffer, ((PMGNT_INFO)mgnt_info)->Bssid);
+
+	duration = 2 * a_SifsTime + 40;
+
+	if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	SET_80211_HDR_DURATION(buffer, duration);
+
+	/* HT control field */
+	SET_HT_CTRL_CSI_STEERING(buffer + sMacHdrLng, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(buffer + sMacHdrLng, 1);
+
+	FillOctetString(p_ndpa_frame, buffer, sMacHdrLng + sHTCLng);
+
+	FillOctetString(action_content, action_hdr, 4);
+	PacketAppendData(&p_ndpa_frame, action_content);
+
+	*p_length = 32;
+}
+
+
+
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER            adapter = (PADAPTER)dm->adapter;
+	PRT_TCB				tcb;
+	PRT_TX_LOCAL_BUFFER	p_buf;
+	boolean				ret = true;
+	u32					buf_len;
+	u8					*buf_addr;
+	u8					desc_len = 0, idx = 0, ndp_tx_rate;
+	void				*p_def_adapter = GetDefaultAdapter((adapter));
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA((adapter));
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beamform_entry == NULL)
+		return false;
+
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetFWBuffer((PADAPTER)p_def_adapter, &tcb, &p_buf)) {
+#if (DEV_BUS_TYPE != RT_PCI_INTERFACE)
+		desc_len = ((PADAPTER)adapter)->HWDescHeadLength - hal_data->USBALLDummyLength;
+#endif
+		buf_addr = p_buf->Buffer.VirtualAddress + desc_len;
+
+		construct_ht_ndpa_packet(
+			adapter,
+			RA,
+			buf_addr,
+			&buf_len,
+			BW
+		);
+
+		tcb->PacketLength = buf_len + desc_len;
+
+		tcb->bTxEnableSwCalcDur = true;
+
+		tcb->BWOfPacket = BW;
+
+		if (ACTING_AS_IBSS((adapter)) || ACTING_AS_AP((adapter)))
+			tcb->G_ID = 63;
+
+		tcb->P_AID = beamform_entry->p_aid;
+		tcb->DataRate = ndp_tx_rate;	/*rate of NDP decide by nr*/
+
+		adapter->HalFunc.CmdSendPacketHandler(adapter, tcb, p_buf, tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER				adapter = (PADAPTER)dm->adapter;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					idx = 0, ndp_tx_rate = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_ht_ndpa_packet(
+			adapter,
+			RA,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength,
+			BW
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+
+		tcb->BWOfPacket = BW;
+
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+
+void
+construct_vht_ndpa_packet(
+	struct dm_struct	*dm,
+	u8			*RA,
+	u16			AID,
+	u8			*buffer,
+	u32			*p_length,
+	enum channel_width	BW
+)
+{
+	u16					duration = 0;
+	u8					sequence = 0;
+	u8					*p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO		sta_info;
+	// 2017/11 MH PHYDM compile. But why need to use windows maco? 
+	// For all linux code, it should be useless?
+	//void				*adapter = dm->adapter;
+	ADAPTER				*adapter = (PADAPTER)(dm->adapter);
+	u8	idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	/* Frame control. */
+	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
+
+	SET_80211_HDR_ADDRESS1(p_ndpa_frame, RA);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, beamform_entry->my_mac_addr);
+
+	// 2017/11 MH PHYDM compile. But why need to use windows maco? 
+	// For all linux code, it should be useless?	
+	duration = 2 * a_SifsTime + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
+
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss) || phydm_acting_determine(dm, phydm_acting_as_ap) == false)
+		AID = 0;
+
+	sta_info.aid = AID;
+	sta_info.feedback_type = 0;
+	sta_info.nc_index = 0;
+
+	odm_move_memory(dm, p_ndpa_frame + 17, (u8 *)&sta_info, 2);
+
+	*p_length = 19;
+}
+
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER              adapter = (PADAPTER)dm->adapter;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u32					buf_len;
+	u8					*buf_addr;
+	u8					desc_len = 0, idx = 0, ndp_tx_rate = 0;
+	void				*p_def_adapter = GetDefaultAdapter((adapter));
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA((adapter));
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beamform_entry == NULL)
+		return false;
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetFWBuffer((PADAPTER)p_def_adapter, &tcb, &p_buf)) {
+#if (DEV_BUS_TYPE != RT_PCI_INTERFACE)
+		desc_len = adapter->HWDescHeadLength - hal_data->USBALLDummyLength;
+#endif
+		buf_addr = p_buf->Buffer.VirtualAddress + desc_len;
+
+		construct_vht_ndpa_packet(
+			dm,
+			RA,
+			AID,
+			buf_addr,
+			&buf_len,
+			BW
+		);
+
+		tcb->PacketLength = buf_len + desc_len;
+
+		tcb->bTxEnableSwCalcDur = true;
+
+		tcb->BWOfPacket = BW;
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss) || phydm_acting_determine(dm, phydm_acting_as_ap))
+			tcb->G_ID = 63;
+
+		tcb->P_AID = beamform_entry->p_aid;
+		tcb->DataRate = ndp_tx_rate;	/*decide by nr*/
+
+		adapter->HalFunc.CmdSendPacketHandler(adapter, tcb, p_buf, tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End, ret=%d\n", __func__, ret);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER                adapter = (PADAPTER)dm->adapter;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					idx = 0, ndp_tx_rate = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_ndpa_packet(
+			dm,
+			RA,
+			AID,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength,
+			BW
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+
+		/*rate of NDP decide by nr*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+/*
+ * Description: On VHT GID management frame by an MU beamformee.
+ *
+ * 2015.05.20. Created by tynli.
+ */
+enum rt_status
+beamforming_get_vht_gid_mgnt_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+)
+{
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	enum rt_status		rt_status = RT_STATUS_SUCCESS;
+	u8			*p_buffer = NULL;
+	u8			*p_raddr = NULL;
+	u8			mem_status[8] = {0}, user_pos[16] = {0};
+	u8			idx;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMER_ENTRY	*beamform_entry = &beam_info->beamformer_entry[beam_info->mu_ap_index];
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] On VHT GID mgnt frame!\n", __func__);
+
+	/* Check length*/
+	if (p_pdu_os->length < (FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY + 16)) {
+		PHYDM_DBG(dm, DBG_TXBF, "beamforming_get_vht_gid_mgnt_frame(): Invalid length (%d)\n", p_pdu_os->length);
+		return RT_STATUS_INVALID_LENGTH;
+	}
+
+	/* Check RA*/
+	p_raddr = (u8 *)(p_pdu_os->Octet) + 4;
+	if (!eq_mac_addr(p_raddr, adapter->CurrentAddress)) {
+		PHYDM_DBG(dm, DBG_TXBF, "beamforming_get_vht_gid_mgnt_frame(): Drop because of RA error.\n");
+		return RT_STATUS_PKT_DROP;
+	}
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "On VHT GID Mgnt Frame ==>:\n", p_pdu_os->Octet, p_pdu_os->length);
+
+	/*Parsing Membership status array*/
+	p_buffer = p_pdu_os->Octet + FRAME_OFFSET_VHT_GID_MGNT_MEMBERSHIP_STATUS_ARRAY;
+	for (idx = 0; idx < 8; idx++) {
+		mem_status[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(p_buffer + idx);
+		beamform_entry->gid_valid[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(p_buffer + idx);
+	}
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "mem_status: ", mem_status, 8);
+
+	/* Parsing User Position array*/
+	p_buffer = p_pdu_os->Octet + FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY;
+	for (idx = 0; idx < 16; idx++) {
+		user_pos[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(p_buffer + idx);
+		beamform_entry->user_position[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(p_buffer + idx);
+	}
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "user_pos: ", user_pos, 16);
+
+	/* Group ID detail printed*/
+	{
+		u8	i, j;
+		u8	tmp_val;
+		u16	tmp_val2;
+
+		for (i = 0; i < 8; i++) {
+			tmp_val = mem_status[i];
+			tmp_val2 = ((user_pos[i * 2 + 1] << 8) & 0xFF00) + (user_pos[i * 2] & 0xFF);
+			for (j = 0; j < 8; j++) {
+				if ((tmp_val >> j) & BIT(0)) {
+					PHYDM_DBG(dm, DBG_TXBF, "Use Group ID (%d), User Position (%d)\n",
+						(i * 8 + j), (tmp_val2 >> 2 * j) & 0x3);
+				}
+			}
+		}
+	}
+
+	/* Indicate GID frame to IHV service. */
+	{
+		u8	indibuffer[24] = {0};
+		u8	indioffset = 0;
+
+		PlatformMoveMemory(indibuffer + indioffset, beamform_entry->gid_valid, 8);
+		indioffset += 8;
+		PlatformMoveMemory(indibuffer + indioffset, beamform_entry->user_position, 16);
+		indioffset += 16;
+
+		PlatformIndicateCustomStatus(
+			adapter,
+			RT_CUSTOM_EVENT_VHT_RECV_GID_MGNT_FRAME,
+			RT_CUSTOM_INDI_TARGET_IHV,
+			indibuffer,
+			indioffset);
+	}
+
+	/* Config HW GID table */
+	hal_com_txbf_config_gtab(dm);
+
+	return rt_status;
+}
+
+/*
+ * Description: Construct VHT Group ID (GID) management frame.
+ *
+ * 2015.05.20. Created by tynli.
+ */
+void
+construct_vht_gid_mgnt_frame(
+	struct dm_struct		*dm,
+	u8			*RA,
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry,
+	u8			*buffer,
+	u32			*p_length
+
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	OCTET_STRING		os_ftm_frame, tmp;
+
+	FillOctetString(os_ftm_frame, buffer, 0);
+	*p_length = 0;
+
+	ConstructMaFrameHdr(
+		adapter,
+		RA,
+		ACT_CAT_VHT,
+		ACT_VHT_GROUPID_MANAGEMENT,
+		&os_ftm_frame);
+
+	/* Membership status array*/
+	FillOctetString(tmp, beamform_entry->gid_valid, 8);
+	PacketAppendData(&os_ftm_frame, tmp);
+
+	/* User Position array*/
+	FillOctetString(tmp, beamform_entry->user_position, 16);
+	PacketAppendData(&os_ftm_frame, tmp);
+
+	*p_length = os_ftm_frame.length;
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "construct_vht_gid_mgnt_frame():\n", buffer, *p_length);
+}
+
+boolean
+send_sw_vht_gid_mgnt_frame(
+	void			*dm_void,
+	u8			*RA,
+	u8			idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					data_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = &beam_info->beamformee_entry[idx];
+	void				*adapter = beam_info->source_adapter;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_gid_mgnt_frame(
+			dm,
+			RA,
+			beamform_entry,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bw_of_packet = CHANNEL_WIDTH_20;
+		data_rate = MGN_6M;
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, data_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+/*
+ * Description: Construct VHT beamforming report poll.
+ *
+ * 2015.05.20. Created by tynli.
+ */
+void
+construct_vht_bf_report_poll(
+	struct dm_struct		*dm,
+	u8			*RA,
+	u8			*buffer,
+	u32			*p_length
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	u8			*p_bf_rpt_poll = buffer;
+
+	/* Frame control*/
+	SET_80211_HDR_FRAME_CONTROL(p_bf_rpt_poll, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_bf_rpt_poll, Type_Beamforming_Report_Poll);
+
+	/* duration*/
+	SET_80211_HDR_DURATION(p_bf_rpt_poll, 100);
+
+	/* RA*/
+	SET_VHT_BF_REPORT_POLL_RA(p_bf_rpt_poll, RA);
+
+	/* TA*/
+	SET_VHT_BF_REPORT_POLL_TA(p_bf_rpt_poll, adapter->CurrentAddress);
+
+	/* Feedback Segment Retransmission Bitmap*/
+	SET_VHT_BF_REPORT_POLL_FEEDBACK_SEG_RETRAN_BITMAP(p_bf_rpt_poll, 0xFF);
+
+	*p_length = 17;
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "construct_vht_bf_report_poll():\n", buffer, *p_length);
+
+}
+
+boolean
+send_sw_vht_bf_report_poll(
+	void			*dm_void,
+	u8			*RA,
+	boolean			is_final_poll
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					idx = 0, data_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	void				*adapter = beam_info->source_adapter;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_bf_report_poll(
+			dm,
+			RA,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bTxEnableSwCalcDur = true; /* <tynli_note> need?*/
+		tcb->BWOfPacket = CHANNEL_WIDTH_20;
+
+		if (is_final_poll)
+			tcb->TxBFPktType = RT_BF_PKT_TYPE_FINAL_BF_REPORT_POLL;
+		else
+			tcb->TxBFPktType = RT_BF_PKT_TYPE_BF_REPORT_POLL;
+
+		data_rate = MGN_6M;	/* Legacy OFDM rate*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, data_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "send_sw_vht_bf_report_poll():\n", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+
+}
+
+
+/*
+ * Description: Construct VHT MU NDPA packet.
+ *	<Note> We should combine this function with construct_vht_ndpa_packet() in the future.
+ *
+ * 2015.05.21. Created by tynli.
+ */
+void
+construct_vht_mu_ndpa_packet(
+	struct dm_struct		*dm,
+	enum channel_width	BW,
+	u8			*buffer,
+	u32			*p_length
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	u16					duration = 0;
+	u8					sequence = 0;
+	u8					*p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO		sta_info;
+	u8					idx;
+	u8					dest_addr[6] = {0};
+	struct _RT_BEAMFORMEE_ENTRY	*entry = NULL;
+
+	/* Fill the first MU BFee entry (STA1) MAC addr to destination address then
+	     HW will change A1 to broadcast addr. 2015.05.28. Suggested by SD1 Chunchu. */
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			cp_mac_addr(dest_addr, entry->mac_addr);
+			break;
+		}
+	}
+	if (entry == NULL)
+		return;
+
+	/* Frame control.*/
+	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
+
+	SET_80211_HDR_ADDRESS1(p_ndpa_frame, dest_addr);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, entry->my_mac_addr);
+
+	/*--------------------------------------------*/
+	/* <Note> Need to modify "duration" to MU consideration. */
+	duration = 2 * a_SifsTime + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+	/*--------------------------------------------*/
+
+	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
+
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
+
+	*p_length = 17;
+
+	/* Construct STA info. for multiple STAs*/
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			sta_info.aid = entry->AID;
+			sta_info.feedback_type = 1; /* 1'b1: MU*/
+			sta_info.nc_index = 0;
+
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] Get beamformee_entry idx(%d), AID =%d\n", __func__, idx, entry->AID);
+
+			odm_move_memory(dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
+			*p_length += 2;
+		}
+	}
+
+}
+
+boolean
+send_sw_vht_mu_ndpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					ndp_tx_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+
+	ndp_tx_rate = MGN_VHT2SS_MCS0;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_mu_ndpa_packet(
+			dm,
+			BW,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+		tcb->TxBFPktType = RT_BF_PKT_TYPE_BROADCAST_NDPA;
+
+		/*rate of NDP decide by nr*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+void
+dbg_construct_vht_mundpa_packet(
+	struct dm_struct		*dm,
+	enum channel_width	BW,
+	u8			*buffer,
+	u32			*p_length
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	u16					duration = 0;
+	u8					sequence = 0;
+	u8					*p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO		sta_info;
+	u8					idx;
+	u8					dest_addr[6] = {0};
+	struct _RT_BEAMFORMEE_ENTRY	*entry = NULL;
+
+	boolean	is_STA1 = false;
+
+
+	/* Fill the first MU BFee entry (STA1) MAC addr to destination address then
+	     HW will change A1 to broadcast addr. 2015.05.28. Suggested by SD1 Chunchu. */
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			if (is_STA1 == false) {
+				is_STA1 = true;
+				continue;
+			} else {
+				cp_mac_addr(dest_addr, entry->mac_addr);
+				break;
+			}
+		}
+	}
+
+	/* Frame control.*/
+	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
+
+	SET_80211_HDR_ADDRESS1(p_ndpa_frame, dest_addr);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, dm->CurrentAddress);
+
+	/*--------------------------------------------*/
+	/* <Note> Need to modify "duration" to MU consideration. */
+	duration = 2 * a_SifsTime + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+	/*--------------------------------------------*/
+
+	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
+
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
+
+	*p_length = 17;
+
+	/*STA2's STA Info*/
+	sta_info.aid = entry->aid;
+	sta_info.feedback_type = 1; /* 1'b1: MU */
+	sta_info.nc_index = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Get beamformee_entry idx(%d), AID =%d\n", __func__, idx, entry->aid);
+
+	odm_move_memory(dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
+	*p_length += 2;
+
+}
+
+boolean
+dbg_send_sw_vht_mundpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					ndp_tx_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+
+	ndp_tx_rate = MGN_VHT2SS_MCS0;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		dbg_construct_vht_mundpa_packet(
+			dm,
+			BW,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+		tcb->TxBFPktType = RT_BF_PKT_TYPE_UNICAST_NDPA;
+
+		/*rate of NDP decide by nr*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+#endif	/*#if (SUPPORT_MU_BF == 1)*/
+#endif	/*#ifdef SUPPORT_MU_BF*/
+
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+u32
+beamforming_get_report_frame(
+	void			*dm_void,
+	union recv_frame *precv_frame
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u32					ret = _SUCCESS;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = NULL;
+	u8					*pframe = precv_frame->u.hdr.rx_data;
+	u32					frame_len = precv_frame->u.hdr.len;
+	u8					*TA;
+	u8					idx, offset;
+
+
+	/*Memory comparison to see if CSI report is the same with previous one*/
+	TA = get_addr2_ptr(pframe);
+	beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, TA, &idx);
+	if (beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+		offset = 31;		/*24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
+	else if (beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+		offset = 34;		/*24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
+	else
+		return ret;
+
+
+	return ret;
+}
+
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+
+	pattrib->qsel = QSLT_BEACON;
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->order = 1;
+	pattrib->subtype = WIFI_ACTION_NOACK;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_order_bit(pframe);
+	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
+		a_sifs_time = 10;
+	else
+		a_sifs_time = 16;
+
+	duration = 2 * a_sifs_time + 40;
+
+	if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	/* HT control field */
+	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
+
+	_rtw_memcpy(pframe + 28, action_hdr, 4);
+
+	pattrib->pktlen = 32;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return true;
+}
+
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+	pattrib->qsel = QSLT_MGNT;
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->order = 1;
+	pattrib->subtype = WIFI_ACTION_NOACK;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_order_bit(pframe);
+	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
+		a_sifs_time = 10;
+	else
+		a_sifs_time = 16;
+
+	duration = 2 * a_sifs_time + 40;
+
+	if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	/*HT control field*/
+	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
+
+	_rtw_memcpy(pframe + 28, action_hdr, 4);
+
+	pattrib->pktlen = 32;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return true;
+}
+
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	sequence = 0, a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	struct _RT_NDPA_STA_INFO	sta_info;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	_rtw_memcpy(pattrib->ra, RA, ETH_ALEN);
+	update_mgntframe_attrib(adapter, pattrib);
+
+	pattrib->qsel = QSLT_BEACON;
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->subtype = WIFI_NDPA;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_frame_sub_type(pframe, WIFI_NDPA);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		a_sifs_time = 16;
+	else
+		a_sifs_time = 10;
+
+	duration = 2 * a_sifs_time + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	sequence = beam_info->sounding_sequence << 2;
+	if (beam_info->sounding_sequence >= 0x3f)
+		beam_info->sounding_sequence = 0;
+	else
+		beam_info->sounding_sequence++;
+
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		AID = 0;
+
+	sta_info.aid = AID;
+	sta_info.feedback_type = 0;
+	sta_info.nc_index = 0;
+
+	_rtw_memcpy(pframe + 17, (u8 *)&sta_info, 2);
+
+	pattrib->pktlen = 19;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return true;
+}
+
+
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
+	struct _RT_NDPA_STA_INFO	ndpa_sta_info;
+	u8	ndp_tx_rate = 0, sequence = 0, a_sifs_time = 0, idx = 0;
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	_rtw_memcpy(pattrib->ra, RA, ETH_ALEN);
+	update_mgntframe_attrib(adapter, pattrib);
+	pattrib->qsel = QSLT_MGNT;
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->subtype = WIFI_NDPA;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_frame_sub_type(pframe, WIFI_NDPA);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		a_sifs_time = 16;
+	else
+		a_sifs_time = 10;
+
+	duration = 2 * a_sifs_time + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	sequence = beam_info->sounding_sequence << 2;
+	if (beam_info->sounding_sequence >= 0x3f)
+		beam_info->sounding_sequence = 0;
+	else
+		beam_info->sounding_sequence++;
+
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		AID = 0;
+
+	ndpa_sta_info.aid = AID;
+	ndpa_sta_info.feedback_type = 0;
+	ndpa_sta_info.nc_index = 0;
+
+	_rtw_memcpy(pframe + 17, (u8 *)&ndpa_sta_info, 2);
+
+	pattrib->pktlen = 19;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] [%d]\n", __func__, __LINE__);
+
+	return true;
+}
+
+
+#endif
+
+
+void
+beamforming_get_ndpa_frame(
+	void			*dm_void,
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	OCTET_STRING	pdu_os
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	union recv_frame *precv_frame
+#endif
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8						*TA ;
+	u8						idx, sequence;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	u8						*p_ndpa_frame = pdu_os.Octet;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	u8						*p_ndpa_frame = precv_frame->u.hdr.rx_data;
+#endif
+	struct _RT_BEAMFORMER_ENTRY		*beamformer_entry = NULL;		/*Modified By Jeffery @2014-10-29*/
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "beamforming_get_ndpa_frame\n", pdu_os.Octet, pdu_os.Length);
+	if (IsCtrlNDPA(p_ndpa_frame) == false)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (get_frame_sub_type(p_ndpa_frame) != WIFI_NDPA)
+#endif
+		return;
+	else if (!(dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] not 8812 or 8821A, return\n", __func__);
+		return;
+	}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	TA = Frame_Addr2(pdu_os);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	TA = get_addr2_ptr(p_ndpa_frame);
+#endif
+	/*Remove signaling TA. */
+	TA[0] = TA[0] & 0xFE;
+
+	beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, TA, &idx);		/* Modified By Jeffery @2014-10-29 */
+
+	/*Break options for Clock Reset*/
+	if (beamformer_entry == NULL)
+		return;
+	else if (!(beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU))
+		return;
+	/*log_success: As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is NO LONGER needed !2015-04-10, Jeffery*/
+	/*clock_reset_times: While BFer entry always doesn't receive our CSI, clock will reset again and again.So clock_reset_times is limited to 5 times.2015-04-13, Jeffery*/
+	else if ((beamformer_entry->log_success == 1) || (beamformer_entry->clock_reset_times == 5)) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, log_success=%d, clock_reset_times=%d, clock reset is no longer needed.\n",
+			__func__, beamformer_entry->log_seq, beamformer_entry->pre_log_seq, beamformer_entry->log_retry_cnt, beamformer_entry->log_success, beamformer_entry->clock_reset_times);
+
+		return;
+	}
+
+	sequence = (p_ndpa_frame[16]) >> 2;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start, sequence=%d, log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, clock_reset_times=%d, log_success=%d\n",
+		__func__, sequence, beamformer_entry->log_seq, beamformer_entry->pre_log_seq, beamformer_entry->log_retry_cnt, beamformer_entry->clock_reset_times, beamformer_entry->log_success);
+
+	if ((beamformer_entry->log_seq != 0) && (beamformer_entry->pre_log_seq != 0)) {
+		/*Success condition*/
+		if ((beamformer_entry->log_seq != sequence) && (beamformer_entry->pre_log_seq != beamformer_entry->log_seq)) {
+			/* break option for clcok reset, 2015-03-30, Jeffery */
+			beamformer_entry->log_retry_cnt = 0;
+			/*As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is no longer needed.*/
+			/*That is, log_success is NOT needed to be reset to zero, 2015-04-13, Jeffery*/
+			beamformer_entry->log_success = 1;
+
+		} else {/*Fail condition*/
+
+			if (beamformer_entry->log_retry_cnt == 5) {
+				beamformer_entry->clock_reset_times++;
+				beamformer_entry->log_retry_cnt = 0;
+
+				PHYDM_DBG(dm, DBG_TXBF, "[%s] Clock Reset!!! clock_reset_times=%d\n",
+					__func__, beamformer_entry->clock_reset_times);
+				hal_com_txbf_set(dm, TXBF_SET_SOUNDING_CLK, NULL);
+
+			} else
+				beamformer_entry->log_retry_cnt++;
+		}
+	}
+
+	/*Update log_seq & pre_log_seq*/
+	beamformer_entry->pre_log_seq = beamformer_entry->log_seq;
+	beamformer_entry->log_seq = sequence;
+
+}
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfinterface.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfinterface.h
new file mode 100644
index 000000000000..7482ae42484c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfinterface.h
@@ -0,0 +1,189 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_INTERFACE_H__
+#define __HAL_TXBF_INTERFACE_H__
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+#define a_SifsTime					((IS_WIRELESS_MODE_5G(adapter)|| IS_WIRELESS_MODE_N_24G(adapter))? 16 : 10)
+
+void
+beamforming_gid_paid(
+	void	*adapter,
+	PRT_TCB		tcb
+);
+
+enum rt_status
+beamforming_get_report_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+);
+
+void
+beamforming_get_ndpa_frame(
+	void			*dm_void,
+	OCTET_STRING	pdu_os
+);
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+#if (SUPPORT_MU_BF == 1)
+enum rt_status
+beamforming_get_vht_gid_mgnt_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+);
+
+boolean
+send_sw_vht_gid_mgnt_frame(
+	void			*dm_void,
+	u8			*RA,
+	u8			idx
+);
+
+boolean
+send_sw_vht_bf_report_poll(
+	void			*dm_void,
+	u8			*RA,
+	boolean			is_final_poll
+);
+
+boolean
+send_sw_vht_mu_ndpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+);
+#else
+#define beamforming_get_vht_gid_mgnt_frame(adapter, rfd, p_pdu_os) RT_STATUS_FAILURE
+#define send_sw_vht_gid_mgnt_frame(dm_void, RA)
+#define send_sw_vht_bf_report_poll(dm_void, RA, is_final_poll)
+#define send_sw_vht_mu_ndpa_packet(dm_void, BW)
+#endif
+
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+u32
+beamforming_get_report_frame(
+	void			*dm_void,
+	union recv_frame *precv_frame
+);
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+#endif
+
+void
+beamforming_get_ndpa_frame(
+	void			*dm_void,
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	OCTET_STRING	pdu_os
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	union recv_frame *precv_frame
+#endif
+);
+
+boolean
+dbg_send_sw_vht_mundpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+);
+
+#else
+#define beamforming_get_ndpa_frame(dm, _pdu_os)
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#define beamforming_get_report_frame(adapter, precv_frame)		RT_STATUS_FAILURE
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define beamforming_get_report_frame(adapter, rfd, p_pdu_os)		RT_STATUS_FAILURE
+	#define beamforming_get_vht_gid_mgnt_frame(adapter, rfd, p_pdu_os) RT_STATUS_FAILURE
+#endif
+#define send_fw_ht_ndpa_packet(dm_void, RA, BW)
+#define send_sw_ht_ndpa_packet(dm_void, RA, BW)
+#define send_fw_vht_ndpa_packet(dm_void, RA, AID, BW)
+#define send_sw_vht_ndpa_packet(dm_void, RA,	AID, BW)
+#define send_sw_vht_gid_mgnt_frame(dm_void, RA, idx)
+#define send_sw_vht_bf_report_poll(dm_void, RA, is_final_poll)
+#define send_sw_vht_mu_ndpa_packet(dm_void, BW)
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfjaguar.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfjaguar.c
new file mode 100644
index 000000000000..85eac4494509
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfjaguar.c
@@ -0,0 +1,540 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8812/8821/8811 TXBF mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+void
+hal_txbf_8812a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8812A, (rate << 2 | BW));
+
+}
+
+void
+hal_txbf_jaguar_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] set TxIQGen\n", __func__);
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);	/*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);	/*RF mode table write enable*/
+
+	if (beam_info->beamformee_su_cnt > 0) {
+		/* Paath_A */
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
+		/* Path_B */
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
+	} else {
+		/* Paath_A */
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
+		/* Path_B */
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
+	}
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);	/*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);	/*RF mode table write disable*/
+
+	if (beam_info->beamformee_su_cnt > 0)
+		odm_set_bb_reg(dm, 0x80c, MASKBYTE1, 0x33);
+	else
+		odm_set_bb_reg(dm, 0x80c, MASKBYTE1, 0x11);
+}
+
+
+void
+hal_txbf_jaguar_download_ndpa(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			u1b_tmp = 0, tmp_reg422 = 0, head_page;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	boolean			is_send_beacon = false;
+	u8			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;	/*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+	void		*adapter = dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
+#endif
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (idx == 0)
+		head_page = 0xFE;
+	else
+		head_page = 0xFE;
+
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8812A + 1);
+	odm_write_1byte(dm,  REG_CR_8812A + 1, (u1b_tmp | BIT(0)));
+
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		PHYDM_DBG(dm, DBG_TXBF, "SetBeamformDownloadNDPA_8812(): There is an adapter is sending beacon.\n");
+		is_send_beacon = true;
+	}
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
+	odm_write_1byte(dm, REG_TDECTRL_8812A + 1, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
+		odm_write_1byte(dm, REG_TDECTRL_8812A + 2, (bcn_valid_reg | BIT(0)));
+
+		/*download NDPA rsvd page.*/
+		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->aid, p_beam_entry->sound_bw, BEACON_QUEUE);
+		else
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(0)) && count < 20) {
+			count++;
+			ODM_delay_ms(10);
+			bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(0)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(0)))
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n", __func__);
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
+	odm_write_1byte(dm, REG_TDECTRL_8812A + 1, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8812A + 1);
+	odm_write_1byte(dm, REG_CR_8812A + 1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
+#endif
+}
+
+
+void
+hal_txbf_jaguar_fw_txbf_cmd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	idx, period0 = 0, period1 = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		/*Modified by David*/
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (idx == 0) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum0 = 0xFE;
+				else
+					PageNum0 = 0xFF; /*stop sounding*/
+				period0 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (idx == 1) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum1 = 0xFE;
+				else
+					PageNum1 = 0xFF; /*stop sounding*/
+				period1 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = (period1 << 4) | period0;
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	PHYDM_DBG(dm, DBG_TXBF,
+		"[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n", __func__, PageNum0, period0, PageNum1, period1);
+}
+
+
+void
+hal_txbf_jaguar_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	u32					csi_param;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	u16					sta_id = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]Start!\n", __func__);
+
+	hal_txbf_jaguar_rf_mode(dm, beamforming_info);
+
+	if (dm->rf_type == RF_2T2R)
+		odm_set_bb_reg(dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x00000000);	/*nc =2*/
+	else
+		odm_set_bb_reg(dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x01081008);	/*nc =1*/
+
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (bfer_idx == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_BFMER0_INFO_8812A + i), beamformer_entry.mac_addr[i]);
+			/*CSI report use legacy ofdm so don't need to fill P_AID. */
+			/*platform_efio_write_2byte(adapter, REG_BFMER0_INFO_8812A+6, beamform_entry.P_AID); */
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_BFMER1_INFO_8812A + i), beamformer_entry.mac_addr[i]);
+			/*CSI report use legacy ofdm so don't need to fill P_AID.*/
+			/*platform_efio_write_2byte(adapter, REG_BFMER1_INFO_8812A+6, beamform_entry.P_AID);*/
+		}
+
+		/*CSI report parameters of Beamformee*/
+		if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU) {
+			if (dm->rf_type == RF_2T2R)
+				csi_param = 0x01090109;
+			else
+				csi_param = 0x01080108;
+		} else {
+			if (dm->rf_type == RF_2T2R)
+				csi_param = 0x03090309;
+			else
+				csi_param = 0x03080308;
+		}
+
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, csi_param);
+
+		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A + 3, 0x50);
+	}
+
+
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = beamformee_entry.mac_id;
+		else
+			sta_id = beamformee_entry.p_aid;
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (bfee_idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8812A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8812A + 3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A + 2, sta_id | BIT(12) | BIT(14) | BIT(15));
+
+		/*CSI report parameters of Beamformee*/
+		if (bfee_idx == 0) {
+			/*Get BIT24 & BIT25*/
+			u8	tmp = odm_read_1byte(dm, REG_BFMEE_SEL_8812A + 3) & 0x3;
+
+			odm_write_1byte(dm, REG_BFMEE_SEL_8812A + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A, sta_id | BIT(9));
+		} else {
+			/*Set BIT25*/
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A + 2, sta_id | 0xE200);
+		}
+		phydm_beamforming_notify(dm);
+	}
+}
+
+
+void
+hal_txbf_jaguar_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = beamforming_info->beamformer_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	} else
+		return;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]Start!, IDx = %d\n", __func__, idx);
+
+	/*Clear P_AID of Beamformee*/
+	/*Clear MAC address of Beamformer*/
+	/*Clear Associated Bfmee Sel*/
+
+	if (beamformer_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
+		if (idx == 0) {
+			odm_write_4byte(dm, REG_BFMER0_INFO_8812A, 0);
+			odm_write_2byte(dm, REG_BFMER0_INFO_8812A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
+		} else {
+			odm_write_4byte(dm, REG_BFMER1_INFO_8812A, 0);
+			odm_write_2byte(dm, REG_BFMER1_INFO_8812A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
+		}
+	}
+
+	if (beamformee_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		hal_txbf_jaguar_rf_mode(dm, beamforming_info);
+		if (idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A, 0x0);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A, 0);
+		} else {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A + 2, odm_read_2byte(dm, REG_TXBF_CTRL_8812A + 2) & 0xF000);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A + 2, odm_read_2byte(dm, REG_BFMEE_SEL_8812A + 2) & 0x60);
+		}
+	}
+
+}
+
+
+void
+hal_txbf_jaguar_status(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamform_entry = beam_info->beamformee_entry[idx];
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+		beam_ctrl_val = beamform_entry.mac_id;
+	else
+		beam_ctrl_val = beamform_entry.p_aid;
+
+	if (idx == 0)
+		beam_ctrl_reg = REG_TXBF_CTRL_8812A;
+	else {
+		beam_ctrl_reg = REG_TXBF_CTRL_8812A + 2;
+		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+	}
+
+	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (beam_info->apply_v_matrix == true)) {
+		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
+			beam_ctrl_val |= BIT(9);
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
+			beam_ctrl_val |= (BIT(9) | BIT(10));
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_80)
+			beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
+	} else
+		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] beam_ctrl_val = 0x%x!\n", __func__, beam_ctrl_val);
+
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+}
+
+
+
+void
+hal_txbf_jaguar_fw_txbf(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_jaguar_download_ndpa(dm, idx);
+
+	hal_txbf_jaguar_fw_txbf_cmd(dm);
+}
+
+
+void
+hal_txbf_jaguar_patch(
+	void			*dm_void,
+	u8				operation
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
+		return;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (operation == SCAN_OPT_BACKUP_BAND0)
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
+	else if (operation == SCAN_OPT_RESTORE)
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
+#endif
+}
+
+void
+hal_txbf_jaguar_clk_8812a(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16	u2btmp;
+	u8	count = 0, u1btmp;
+	void	*adapter = dm->adapter;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (*(dm->is_scan_in_process)) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] return by Scan\n", __func__);
+		return;
+	}
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	/*Stop PCIe TxDMA*/
+	odm_write_1byte(dm, REG_PCIE_CTRL_REG_8812A + 1, 0xFE);
+#endif
+
+	/*Stop Usb TxDMA*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISABLE_FUNC((PADAPTER)adapter, DF_TX_BIT);
+	PlatformReturnAllPendingTxPackets((PADAPTER)adapter);
+#else
+	rtw_write_port_cancel(adapter);
+#endif
+
+	/*Wait TXFF empty*/
+	for (count = 0; count < 100; count++) {
+		u2btmp = odm_read_2byte(dm, REG_TXPKT_EMPTY_8812A);
+		u2btmp = u2btmp & 0xfff;
+		if (u2btmp != 0xfff) {
+			ODM_delay_ms(10);
+			continue;
+		} else
+			break;
+	}
+
+	/*TX pause*/
+	odm_write_1byte(dm, REG_TXPAUSE_8812A, 0xFF);
+
+	/*Wait TX state Machine OK*/
+	for (count = 0; count < 100; count++) {
+		if (odm_read_4byte(dm, REG_SCH_TXCMD_8812A) != 0)
+			continue;
+		else
+			break;
+	}
+
+
+	/*Stop RX DMA path*/
+	u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+	odm_write_1byte(dm, REG_RXDMA_CONTROL_8812A, u1btmp | BIT(2));
+
+	for (count = 0; count < 100; count++) {
+		u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+		if (u1btmp & BIT(1))
+			break;
+		else
+			ODM_delay_ms(10);
+	}
+
+	/*Disable clock*/
+	odm_write_1byte(dm, REG_SYS_CLKR_8812A + 1, 0xf0);
+	/*Disable 320M*/
+	odm_write_1byte(dm, REG_AFE_PLL_CTRL_8812A + 3, 0x8);
+	/*Enable 320M*/
+	odm_write_1byte(dm, REG_AFE_PLL_CTRL_8812A + 3, 0xa);
+	/*Enable clock*/
+	odm_write_1byte(dm, REG_SYS_CLKR_8812A + 1, 0xfc);
+
+
+	/*Release Tx pause*/
+	odm_write_1byte(dm, REG_TXPAUSE_8812A, 0);
+
+	/*Enable RX DMA path*/
+	u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+	odm_write_1byte(dm, REG_RXDMA_CONTROL_8812A, u1btmp & (~BIT(2)));
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	/*Enable PCIe TxDMA*/
+	odm_write_1byte(dm, REG_PCIE_CTRL_REG_8812A + 1, 0);
+#endif
+	/*Start Usb TxDMA*/
+	RT_ENABLE_FUNC((PADAPTER)adapter, DF_TX_BIT);
+}
+
+#endif
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfjaguar.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfjaguar.h
new file mode 100644
index 000000000000..1b896758dfa5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/haltxbfjaguar.h
@@ -0,0 +1,98 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_JAGUAR_H__
+#define __HAL_TXBF_JAGUAR_H__
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_txbf_8812a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+);
+
+
+void
+hal_txbf_jaguar_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_status(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_fw_txbf(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_patch(
+	void			*dm_void,
+	u8				operation
+);
+
+
+void
+hal_txbf_jaguar_clk_8812a(
+	void			*dm_void
+);
+#else
+
+#define hal_txbf_8812a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_jaguar_enter(dm_void, idx)
+#define hal_txbf_jaguar_leave(dm_void, idx)
+#define hal_txbf_jaguar_status(dm_void, idx)
+#define hal_txbf_jaguar_fw_txbf(dm_void,	idx)
+#define hal_txbf_jaguar_patch(dm_void, operation)
+#define hal_txbf_jaguar_clk_8812a(dm_void)
+#endif
+#else
+
+#define hal_txbf_8812a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_jaguar_enter(dm_void, idx)
+#define hal_txbf_jaguar_leave(dm_void, idx)
+#define hal_txbf_jaguar_status(dm_void, idx)
+#define hal_txbf_jaguar_fw_txbf(dm_void,	idx)
+#define hal_txbf_jaguar_patch(dm_void, operation)
+#define hal_txbf_jaguar_clk_8812a(dm_void)
+#endif
+
+#endif	/*  #ifndef __HAL_TXBF_JAGUAR_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/phydm_hal_txbf_api.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/phydm_hal_txbf_api.c
new file mode 100644
index 000000000000..6e9be14d93dc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/phydm_hal_txbf_api.c
@@ -0,0 +1,202 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (defined(CONFIG_BB_TXBF_API))
+#if (RTL8822B_SUPPORT == 1)
+/*Add by YuChen for 8822B MU-MIMO API*/
+
+/*this function is only used for BFer*/
+u8
+phydm_get_ndpa_rate(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		ndpa_rate = ODM_RATE6M;
+
+	if (dm->rssi_min >= 30)	/*link RSSI > 30%*/
+		ndpa_rate = ODM_RATE24M;
+	else if (dm->rssi_min <= 25)
+		ndpa_rate = ODM_RATE6M;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndpa_rate = 0x%x\n", __func__, ndpa_rate);
+
+	return ndpa_rate;
+
+}
+
+/*this function is only used for BFer*/
+u8
+phydm_get_beamforming_sounding_info(
+	void		*dm_void,
+	u16	*troughput,
+	u8	total_bfee_num,
+	u8	*tx_rate
+)
+{
+	u8	idx = 0;
+	u8	soundingdecision = 0xff;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	for (idx = 0; idx < total_bfee_num; idx++) {
+		if (dm->support_ic_type & (ODM_RTL8814A)) {
+			if (((tx_rate[idx] >= ODM_RATEVHTSS3MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS3MCS9)))
+				soundingdecision = soundingdecision & ~(1 << idx);
+		} else if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8822C | ODM_RTL8812)) {
+			if (((tx_rate[idx] >= ODM_RATEVHTSS2MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS2MCS9)))
+				soundingdecision = soundingdecision & ~(1 << idx);
+		} else if (dm->support_ic_type & (ODM_RTL8814B)) {
+			if (((tx_rate[idx] >= ODM_RATEVHTSS4MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS4MCS9)))
+				soundingdecision = soundingdecision & ~(1 << idx);
+		}
+	}
+
+	for (idx = 0; idx < total_bfee_num; idx++) {
+		if (troughput[idx] <= 10)
+			soundingdecision = soundingdecision & ~(1 << idx);
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] soundingdecision = 0x%x\n", __func__, soundingdecision);
+
+	return soundingdecision;
+
+}
+
+/*this function is only used for BFer*/
+u8
+phydm_get_mu_bfee_snding_decision(
+	void		*dm_void,
+	u16	throughput
+)
+{
+	u8	snding_score = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	/*throughput unit is Mbps*/
+	if (throughput >= 500)
+		snding_score = 100;
+	else if (throughput >= 450)
+		snding_score = 90;
+	else if (throughput >= 400)
+		snding_score = 80;
+	else if (throughput >= 350)
+		snding_score = 70;
+	else if (throughput >= 300)
+		snding_score = 60;
+	else if (throughput >= 250)
+		snding_score = 50;
+	else if (throughput >= 200)
+		snding_score = 40;
+	else if (throughput >= 150)
+		snding_score = 30;
+	else if (throughput >= 100)
+		snding_score = 20;
+	else if (throughput >= 50)
+		snding_score = 10;
+	else
+		snding_score = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] snding_score = 0x%x\n", __func__, snding_score);
+
+	return snding_score;
+
+}
+
+
+#endif
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+u8
+beamforming_get_htndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 nr_index = 0;
+	u8 ndp_tx_rate;
+	/*Find nr*/
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), comp_steering_num_of_bfer);
+	else
+#endif
+		nr_index = tx_bf_nr(1, comp_steering_num_of_bfer);
+
+	switch (nr_index) {
+	case 1:
+		ndp_tx_rate = ODM_MGN_MCS8;
+		break;
+
+	case 2:
+		ndp_tx_rate = ODM_MGN_MCS16;
+		break;
+
+	case 3:
+		ndp_tx_rate = ODM_MGN_MCS24;
+		break;
+
+	default:
+		ndp_tx_rate = ODM_MGN_MCS8;
+		break;
+	}
+
+	return ndp_tx_rate;
+
+}
+
+u8
+beamforming_get_vht_ndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 nr_index = 0;
+	u8 ndp_tx_rate;
+	/*Find nr*/
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), comp_steering_num_of_bfer);
+	else
+#endif
+		nr_index = tx_bf_nr(1, comp_steering_num_of_bfer);
+
+	switch (nr_index) {
+	case 1:
+		ndp_tx_rate = ODM_MGN_VHT2SS_MCS0;
+		break;
+
+	case 2:
+		ndp_tx_rate = ODM_MGN_VHT3SS_MCS0;
+		break;
+
+	case 3:
+		ndp_tx_rate = ODM_MGN_VHT4SS_MCS0;
+		break;
+
+	default:
+		ndp_tx_rate = ODM_MGN_VHT2SS_MCS0;
+		break;
+	}
+
+	return ndp_tx_rate;
+
+}
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/phydm_hal_txbf_api.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/phydm_hal_txbf_api.h
new file mode 100644
index 000000000000..e31dab6124c9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/phydm/txbf/phydm_hal_txbf_api.h
@@ -0,0 +1,75 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef	__PHYDM_HAL_TXBF_API_H__
+#define __PHYDM_HAL_TXBF_API_H__
+
+#if (defined(CONFIG_BB_TXBF_API))
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#define tx_bf_nr(a, b) ((a > b) ? (b) : (a))
+
+u8
+beamforming_get_htndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+);
+
+u8
+beamforming_get_vht_ndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+);
+
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+u8
+phydm_get_beamforming_sounding_info(
+	void		*dm_void,
+	u16	*troughput,
+	u8	total_bfee_num,
+	u8	*tx_rate
+);
+
+u8
+phydm_get_ndpa_rate(
+	void		*dm_void
+);
+
+u8
+phydm_get_mu_bfee_snding_decision(
+	void		*dm_void,
+	u16	throughput
+);
+
+#else
+#define phydm_get_beamforming_sounding_info(dm_void, troughput, total_bfee_num, tx_rate) 0
+#define phydm_get_ndpa_rate(dm_void)
+#define phydm_get_mu_bfee_snding_decision(dm_void, troughput)
+
+#endif
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/hal8822b_fw.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/hal8822b_fw.c
new file mode 100644
index 000000000000..780755e24972
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/hal8822b_fw.c
@@ -0,0 +1,41771 @@
+/******************************************************************************
+*
+* Copyright(c) 2012 - 2017 Realtek Corporation.
+*
+* 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.
+*
+******************************************************************************/
+
+#ifdef CONFIG_RTL8822B
+
+#include "drv_types.h"
+
+#ifdef LOAD_FW_HEADER_FROM_DRIVER
+
+#if (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))
+
+u8 array_mp_8822b_fw_ap[] = {
+0x22, 0x88, 0x00, 0x00, 0x16, 0x00, 0x06, 0x00,
+0x42, 0x65, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x04, 0x19, 0x0E, 0x27, 0xE2, 0x07, 0x00, 0x00,
+0x08, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x20, 0x80, 0x28, 0x2E, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x40, 0x6A, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x10, 0x12, 0x80, 0x00, 0x00, 0x00, 0x80,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xA1, 0x31, 0x00, 0x80, 0xE9, 0x06, 0x00, 0x80,
+0x03, 0x02, 0x01, 0xFE, 0x03, 0x03, 0x01, 0xFE,
+0x03, 0x04, 0x01, 0xFE, 0x03, 0x05, 0x01, 0xFE,
+0x03, 0x06, 0x01, 0xFE, 0x03, 0x07, 0x01, 0xFE,
+0xCD, 0x73, 0x00, 0x80, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xA9, 0x75, 0x00, 0x80, 0x01, 0x00, 0x00, 0x00,
+0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x28, 0x2E, 0x20, 0x80, 0x41, 0x4E, 0x59, 0x00,
+0x61, 0x6E, 0x79, 0x00, 0x81, 0x00, 0x88, 0x00,
+0x90, 0x00, 0x99, 0x00, 0xA2, 0x00, 0xAC, 0x00,
+0xB6, 0x00, 0xC0, 0x00, 0xCC, 0x00, 0xD8, 0x00,
+0xE5, 0x00, 0xF2, 0x00, 0x01, 0x01, 0x10, 0x01,
+0x20, 0x01, 0x31, 0x01, 0x43, 0x01, 0x56, 0x01,
+0x6A, 0x01, 0x80, 0x01, 0x97, 0x01, 0xAF, 0x01,
+0xC8, 0x01, 0xE3, 0x01, 0x00, 0x02, 0x1E, 0x02,
+0x3E, 0x02, 0x61, 0x02, 0x85, 0x02, 0xAB, 0x02,
+0xD3, 0x02, 0xFE, 0x02, 0x2B, 0x03, 0x5C, 0x03,
+0x8E, 0x03, 0xC4, 0x03, 0xFE, 0x03, 0x00, 0x00,
+0x22, 0x05, 0x50, 0x05, 0x51, 0x05, 0x00, 0x00,
+0x08, 0x08, 0x0C, 0x09, 0x00, 0x0C, 0xB0, 0x0C,
+0xB4, 0x0C, 0xBC, 0x0C, 0x00, 0x0E, 0xB0, 0x0E,
+0xB4, 0x0E, 0xBC, 0x0E, 0x90, 0x19, 0xA4, 0x09,
+0x04, 0x0A, 0x00, 0x0B, 0x38, 0x08, 0x00, 0x00,
+0xDF, 0x8F, 0x65, 0x00, 0x01, 0x00, 0x00, 0x00,
+0x2C, 0x00, 0x04, 0x00, 0x2D, 0x00, 0x2C, 0x01,
+0x2D, 0x01, 0x2C, 0x02, 0x2E, 0x01, 0xFF, 0x00,
+0x2D, 0x02, 0xFF, 0x00, 0x03, 0x02, 0x00, 0x00,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x2A, 0xEA, 0xA0, 0x79, 0x2C, 0xEA, 0xA0, 0x79,
+0x2A, 0xEA, 0xA0, 0x79, 0x2A, 0xEA, 0xA0, 0x79,
+0x41, 0x55, 0x76, 0x87, 0x41, 0x63, 0x74, 0x87,
+0x41, 0x55, 0x76, 0x87, 0x41, 0x63, 0x74, 0x87,
+0x10, 0x60, 0xB8, 0x75, 0x10, 0x60, 0xB7, 0x75,
+0x10, 0x60, 0xB8, 0x75, 0x10, 0x60, 0xB7, 0x75,
+0x28, 0xEA, 0xA0, 0x79, 0x2C, 0xEA, 0xA0, 0x79,
+0x28, 0xEA, 0xA0, 0x79, 0x2A, 0xEA, 0xA0, 0x79,
+0x51, 0x64, 0x76, 0x87, 0x31, 0x64, 0x76, 0x87,
+0x51, 0x64, 0x76, 0x87, 0x31, 0x64, 0x76, 0x87,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x2A, 0xEA, 0xA0, 0x79, 0x2C, 0xEA, 0xA0, 0x97,
+0x2A, 0xEA, 0xA0, 0x79, 0x2A, 0xEA, 0xA0, 0x79,
+0x41, 0x55, 0x76, 0x87, 0x41, 0x63, 0x66, 0x86,
+0x61, 0x55, 0x76, 0x87, 0x61, 0x63, 0x66, 0x86,
+0x06, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00,
+0x01, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00,
+0x40, 0x00, 0x40, 0x00, 0x47, 0x49, 0x00, 0x80,
+0x5D, 0x49, 0x00, 0x80, 0x7B, 0x49, 0x00, 0x80,
+0xAD, 0x49, 0x00, 0x80, 0xD7, 0x49, 0x00, 0x80,
+0x3F, 0x4A, 0x00, 0x80, 0x55, 0x4A, 0x00, 0x80,
+0x6B, 0x4A, 0x00, 0x80, 0x81, 0x4A, 0x00, 0x80,
+0x9B, 0x4A, 0x00, 0x80, 0xFF, 0x52, 0x00, 0x80,
+0x05, 0x53, 0x00, 0x80, 0x11, 0x53, 0x00, 0x80,
+0x1D, 0x53, 0x00, 0x80, 0x29, 0x53, 0x00, 0x80,
+0x8D, 0x55, 0x00, 0x80, 0x75, 0x56, 0x00, 0x80,
+0xEF, 0x55, 0x00, 0x80, 0x75, 0x56, 0x00, 0x80,
+0x35, 0x55, 0x00, 0x80, 0x75, 0x56, 0x00, 0x80,
+0x75, 0x56, 0x00, 0x80, 0x75, 0x56, 0x00, 0x80,
+0x57, 0x56, 0x00, 0x80, 0x75, 0x56, 0x00, 0x80,
+0x75, 0x56, 0x00, 0x80, 0x75, 0x56, 0x00, 0x80,
+0xCF, 0x54, 0x00, 0x80, 0xAD, 0x5F, 0x00, 0x80,
+0xC1, 0x5F, 0x00, 0x80, 0xD5, 0x5F, 0x00, 0x80,
+0xE9, 0x5F, 0x00, 0x80, 0xFF, 0x5F, 0x00, 0x80,
+0x3F, 0x60, 0x00, 0x80, 0x53, 0x60, 0x00, 0x80,
+0x67, 0x60, 0x00, 0x80, 0x7B, 0x60, 0x00, 0x80,
+0x91, 0x60, 0x00, 0x80, 0xA8, 0x06, 0x10, 0x07,
+0x00, 0x16, 0x04, 0x16, 0x08, 0x16, 0x00, 0x00,
+0xA8, 0x06, 0x10, 0x07, 0x00, 0x16, 0x04, 0x16,
+0x08, 0x16, 0x00, 0x00, 0xA8, 0x06, 0x10, 0x07,
+0x00, 0x16, 0x04, 0x16, 0x08, 0x16, 0x00, 0x00,
+0xCD, 0x72, 0x00, 0x80, 0xC7, 0x72, 0x00, 0x80,
+0xD3, 0x72, 0x00, 0x80, 0xD9, 0x72, 0x00, 0x80,
+0xDF, 0x72, 0x00, 0x80, 0xE5, 0x72, 0x00, 0x80,
+0xBB, 0xE7, 0x00, 0x80, 0xC5, 0xE7, 0x00, 0x80,
+0xD3, 0xE7, 0x00, 0x80, 0x05, 0xE8, 0x00, 0x80,
+0x4B, 0xE8, 0x00, 0x80, 0x63, 0xE8, 0x00, 0x80,
+0x94, 0x0C, 0x94, 0x0E, 0x94, 0x18, 0x94, 0x1A,
+0x09, 0x12, 0x1B, 0x24, 0x75, 0x01, 0x01, 0x80,
+0xD1, 0x01, 0x01, 0x80, 0x7D, 0x01, 0x01, 0x80,
+0xBB, 0x01, 0x01, 0x80, 0xD1, 0x01, 0x01, 0x80,
+0xD1, 0x01, 0x01, 0x80, 0x85, 0x01, 0x01, 0x80,
+0x8D, 0x01, 0x01, 0x80, 0x95, 0x01, 0x01, 0x80,
+0x9D, 0x01, 0x01, 0x80, 0xAD, 0x01, 0x01, 0x80,
+0xB5, 0x01, 0x01, 0x80, 0xC3, 0x01, 0x01, 0x80,
+0xCB, 0x01, 0x01, 0x80, 0xA5, 0x01, 0x01, 0x80,
+0x02, 0x04, 0x06, 0x08, 0x0A, 0x01, 0x0C, 0x0E,
+0x10, 0x12, 0x03, 0x0B, 0x14, 0x16, 0x18, 0x05,
+0x0D, 0x13, 0x1A, 0x1C, 0x07, 0x0F, 0x15, 0x19,
+0x1E, 0x09, 0x11, 0x17, 0x1B, 0x1D, 0x00, 0x00,
+0x01, 0x03, 0x05, 0x07, 0x09, 0x02, 0x0B, 0x0D,
+0x0F, 0x11, 0x04, 0x0C, 0x13, 0x15, 0x17, 0x06,
+0x0E, 0x14, 0x19, 0x1B, 0x08, 0x10, 0x16, 0x1A,
+0x1D, 0x0A, 0x12, 0x18, 0x1C, 0x1E, 0x00, 0x00,
+0x04, 0x08, 0x08, 0x08, 0x08, 0x08, 0x0A, 0x0A,
+0x0A, 0x00, 0x00, 0x00, 0x00, 0x04, 0x0C, 0x14,
+0x1C, 0x24, 0x2C, 0x36, 0x40, 0x00, 0x00, 0x00,
+0xD1, 0x3D, 0x01, 0x80, 0xE7, 0x3D, 0x01, 0x80,
+0xD1, 0x3D, 0x01, 0x80, 0xE7, 0x3D, 0x01, 0x80,
+0xD1, 0x3D, 0x01, 0x80, 0xE7, 0x3D, 0x01, 0x80,
+0x11, 0x3E, 0x01, 0x80, 0x11, 0x3E, 0x01, 0x80,
+0x11, 0x3E, 0x01, 0x80, 0xD5, 0x3D, 0x01, 0x80,
+0xF9, 0x3D, 0x01, 0x80, 0xF9, 0x3D, 0x01, 0x80,
+0xD5, 0x3D, 0x01, 0x80, 0x25, 0x3E, 0x01, 0x80,
+0x3B, 0x3E, 0x01, 0x80, 0x02, 0x04, 0x06, 0x08,
+0x0A, 0x01, 0x0C, 0x0E, 0x10, 0x12, 0x03, 0x0B,
+0x14, 0x16, 0x18, 0x05, 0x0D, 0x13, 0x1A, 0x1C,
+0x07, 0x0F, 0x15, 0x19, 0x1E, 0x09, 0x11, 0x17,
+0x1B, 0x1D, 0x00, 0x00, 0x06, 0x07, 0x08, 0x09,
+0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11,
+0x12, 0x13, 0x14, 0x00, 0x24, 0x24, 0x28, 0x24,
+0x14, 0x12, 0x0F, 0x0F, 0x10, 0x0E, 0x09, 0x08,
+0x18, 0x18, 0x11, 0x0F, 0x10, 0x0C, 0x09, 0x08,
+0x18, 0x18, 0x11, 0x0F, 0x10, 0x0C, 0x09, 0x08,
+0x18, 0x18, 0x11, 0x0F, 0x10, 0x0C, 0x09, 0x08,
+0x18, 0x18, 0x11, 0x0F, 0x10, 0x0C, 0x09, 0x08,
+0x18, 0x18, 0x11, 0x0F, 0x10, 0x0C, 0x09, 0x08,
+0x0A, 0x07, 0x18, 0x18, 0x11, 0x0F, 0x10, 0x0C,
+0x09, 0x08, 0x0A, 0x07, 0x18, 0x18, 0x11, 0x0F,
+0x10, 0x0C, 0x09, 0x08, 0x0A, 0x07, 0x0A, 0x0A,
+0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A,
+0x30, 0x30, 0x3C, 0x30, 0x2D, 0x23, 0x19, 0x1E,
+0x19, 0x1E, 0x19, 0x0F, 0x30, 0x30, 0x23, 0x1C,
+0x20, 0x1A, 0x0F, 0x0E, 0x30, 0x30, 0x23, 0x1C,
+0x20, 0x1A, 0x0F, 0x0E, 0x30, 0x30, 0x23, 0x1C,
+0x20, 0x1A, 0x0F, 0x0D, 0x30, 0x30, 0x23, 0x1C,
+0x20, 0x1A, 0x0F, 0x0D, 0x30, 0x30, 0x23, 0x1C,
+0x23, 0x1B, 0x0F, 0x0F, 0x14, 0x0F, 0x30, 0x30,
+0x23, 0x1C, 0x23, 0x1B, 0x0F, 0x0F, 0x14, 0x0F,
+0x30, 0x2A, 0x23, 0x1C, 0x23, 0x1B, 0x0F, 0x0F,
+0x14, 0x0F, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A,
+0x0A, 0x0A, 0x0A, 0x0A, 0x7D, 0x62, 0x01, 0x80,
+0xD5, 0x62, 0x01, 0x80, 0x67, 0x63, 0x01, 0x80,
+0xCF, 0x64, 0x01, 0x80, 0xCF, 0x64, 0x01, 0x80,
+0xE1, 0x63, 0x01, 0x80, 0x57, 0x64, 0x01, 0x80,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x70, 0x61, 0x72,
+0x61, 0x6D, 0x65, 0x74, 0x65, 0x72, 0x5F, 0x69,
+0x6E, 0x69, 0x74, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x00, 0x00, 0x00, 0x05, 0x05, 0x00, 0x07,
+0x07, 0x06, 0x05, 0xFF, 0x00, 0x07, 0x07, 0x06,
+0x05, 0x05, 0x00, 0x00, 0x06, 0x05, 0x00, 0x00,
+0x07, 0x06, 0x06, 0xFF, 0x00, 0x00, 0x07, 0x06,
+0x06, 0x05, 0x00, 0xFF, 0x07, 0x06, 0x06, 0x05,
+0x00, 0x00, 0x07, 0x00, 0x07, 0x06, 0x06, 0x05,
+0x00, 0x00, 0x07, 0xFF, 0x06, 0x05, 0x00, 0x00,
+0x07, 0x06, 0x06, 0x00, 0x70, 0x68, 0x79, 0x64,
+0x6D, 0x5F, 0x63, 0x63, 0x61, 0x70, 0x61, 0x72,
+0x5F, 0x62, 0x79, 0x5F, 0x72, 0x66, 0x65, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x00, 0x00, 0x00,
+0xDB, 0x13, 0x00, 0x80, 0xD7, 0x13, 0x00, 0x80,
+0xDB, 0x13, 0x00, 0x80, 0xD7, 0x13, 0x00, 0x80,
+0xFB, 0x13, 0x00, 0x80, 0xD7, 0x13, 0x00, 0x80,
+0xFB, 0x13, 0x00, 0x80, 0xD7, 0x13, 0x00, 0x80,
+0x1B, 0x14, 0x00, 0x80, 0xD7, 0x13, 0x00, 0x80,
+0x1B, 0x14, 0x00, 0x80, 0xD7, 0x13, 0x00, 0x80,
+0x3B, 0x14, 0x00, 0x80, 0xD7, 0x13, 0x00, 0x80,
+0x3B, 0x14, 0x00, 0x80, 0xF9, 0x1E, 0x00, 0x80,
+0x1B, 0x1F, 0x00, 0x80, 0x3D, 0x1F, 0x00, 0x80,
+0x5F, 0x1F, 0x00, 0x80, 0x83, 0x1F, 0x00, 0x80,
+0xBD, 0x1F, 0x00, 0x80, 0xE1, 0x1F, 0x00, 0x80,
+0x05, 0x20, 0x00, 0x80, 0x29, 0x20, 0x00, 0x80,
+0x4F, 0x20, 0x00, 0x80, 0xD5, 0x98, 0x00, 0x80,
+0xE3, 0x98, 0x00, 0x80, 0xE7, 0x98, 0x00, 0x80,
+0xEB, 0x98, 0x00, 0x80, 0xEF, 0x98, 0x00, 0x80,
+0x69, 0x18, 0x00, 0x80, 0x69, 0x18, 0x00, 0x80,
+0x69, 0x18, 0x00, 0x80, 0x69, 0x18, 0x00, 0x80,
+0x89, 0x18, 0x00, 0x80, 0x89, 0x18, 0x00, 0x80,
+0x89, 0x18, 0x00, 0x80, 0x89, 0x18, 0x00, 0x80,
+0xA9, 0x18, 0x00, 0x80, 0xA9, 0x18, 0x00, 0x80,
+0xA9, 0x18, 0x00, 0x80, 0xA9, 0x18, 0x00, 0x80,
+0xC9, 0x18, 0x00, 0x80, 0xC9, 0x18, 0x00, 0x80,
+0xC9, 0x18, 0x00, 0x80, 0xC9, 0x18, 0x00, 0x80,
+0x57, 0xA9, 0x00, 0x80, 0x67, 0xA9, 0x00, 0x80,
+0x71, 0xA9, 0x00, 0x80, 0x7B, 0xA9, 0x00, 0x80,
+0x8D, 0xA9, 0x00, 0x80, 0x97, 0xC6, 0x00, 0x80,
+0xF3, 0xC6, 0x00, 0x80, 0x87, 0xC7, 0x00, 0x80,
+0x1B, 0xC8, 0x00, 0x80, 0xB3, 0xC8, 0x00, 0x80,
+0xFC, 0x10, 0x60, 0xB8, 0xFA, 0xFA, 0xFA, 0xFA,
+0x8C, 0x04, 0x64, 0xB8, 0x90, 0x04, 0x64, 0xB8,
+0x94, 0x04, 0x64, 0xB8, 0x98, 0x04, 0x64, 0xB8,
+0x9C, 0x04, 0x64, 0xB8, 0xA0, 0x04, 0x64, 0xB8,
+0x64, 0x01, 0x64, 0xB8, 0xBC, 0x01, 0x64, 0xB8,
+0x00, 0x09, 0x3D, 0x00, 0x77, 0x05, 0x64, 0xB8,
+0x6C, 0x05, 0x64, 0xB8, 0x68, 0x05, 0x64, 0xB8,
+0x00, 0x00, 0x00, 0x80, 0x00, 0x00, 0x01, 0x00,
+0x00, 0x00, 0xFF, 0xFF, 0x54, 0x05, 0x64, 0xB8,
+0xFF, 0xFF, 0xFF, 0x8F, 0x60, 0x05, 0x60, 0xB8,
+0x60, 0x05, 0x64, 0xB8, 0x00, 0x00, 0x00, 0x10,
+0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x30,
+0x00, 0x00, 0x00, 0x40, 0x50, 0x05, 0x64, 0xB8,
+0x51, 0x05, 0x64, 0xB8, 0x78, 0x05, 0x64, 0xB8,
+0x79, 0x05, 0x64, 0xB8, 0x7A, 0x05, 0x64, 0xB8,
+0xBF, 0x01, 0x64, 0xB8, 0x89, 0x00, 0x60, 0xB8,
+0x8A, 0x00, 0x60, 0xB8, 0x1A, 0x04, 0x64, 0xB8,
+0x1B, 0x04, 0x64, 0xB8, 0x8C, 0x00, 0x60, 0xB8,
+0x8D, 0x00, 0x60, 0xB8, 0x8E, 0x00, 0x60, 0xB8,
+0x58, 0x05, 0x64, 0xB8, 0x57, 0x01, 0x64, 0xB8,
+0x3C, 0x01, 0x64, 0xB8, 0x01, 0x00, 0x60, 0xB8,
+0x01, 0x00, 0x64, 0xB8, 0x22, 0x05, 0x64, 0xB8,
+0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00,
+0x00, 0x00, 0x08, 0x00, 0x96, 0x02, 0x64, 0xB8,
+0x86, 0x02, 0x64, 0xB8, 0x8F, 0x00, 0x60, 0xB8,
+0x0A, 0x06, 0x64, 0xB8, 0xB1, 0x05, 0x64, 0xB8,
+0x5B, 0x01, 0x64, 0xB8, 0xFE, 0x11, 0x64, 0xB8,
+0xE2, 0x10, 0x60, 0xB8, 0x00, 0x00, 0x60, 0xB8,
+0x00, 0x00, 0x64, 0xB8, 0xFC, 0x11, 0x64, 0xB8,
+0xE0, 0x10, 0x60, 0xB8, 0x00, 0x00, 0x1E, 0x00,
+0x09, 0x00, 0x78, 0xB8, 0x31, 0x00, 0x78, 0xB8,
+0x14, 0x00, 0x78, 0xB8, 0x1D, 0x04, 0x64, 0xB8,
+0x7A, 0x04, 0x64, 0xB8, 0x4D, 0x01, 0x64, 0xB8,
+0x00, 0x01, 0x64, 0xB8, 0x04, 0x02, 0x64, 0xB8,
+0x24, 0x04, 0x64, 0xB8, 0x56, 0x04, 0x64, 0xB8,
+0x04, 0x00, 0x70, 0xB8, 0x0A, 0x00, 0x70, 0xB8,
+0x34, 0x00, 0x78, 0xB8, 0x18, 0x11, 0x64, 0xB8,
+0x55, 0x00, 0x78, 0xB8, 0x56, 0x00, 0x78, 0xB8,
+0x40, 0x00, 0x78, 0xB8, 0x1C, 0x04, 0x64, 0xB8,
+0x10, 0x00, 0x70, 0xB8, 0x4C, 0x04, 0x64, 0xB8,
+0x4D, 0x04, 0x64, 0xB8, 0x16, 0x00, 0x70, 0xB8,
+0x4E, 0x04, 0x64, 0xB8, 0x17, 0x00, 0x70, 0xB8,
+0x4F, 0x04, 0x64, 0xB8, 0xEC, 0x10, 0x60, 0xB8,
+0xEC, 0x10, 0x64, 0xB8, 0xEE, 0x10, 0x60, 0xB8,
+0xEE, 0x10, 0x64, 0xB8, 0xC7, 0x01, 0x64, 0xB8,
+0x1C, 0x01, 0x64, 0xB8, 0xFF, 0xFF, 0x03, 0x00,
+0x52, 0x05, 0x64, 0xB8, 0x20, 0x04, 0x64, 0xB8,
+0xFF, 0xFF, 0xEF, 0xFF, 0x5F, 0x11, 0x64, 0xB8,
+0x86, 0x00, 0x60, 0xB8, 0x87, 0x00, 0x60, 0xB8,
+0x88, 0x00, 0x60, 0xB8, 0x84, 0x00, 0x60, 0xB8,
+0xF8, 0x10, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x02,
+0xCB, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x68, 0xB8,
+0x04, 0x00, 0x68, 0xB8, 0x08, 0x00, 0x68, 0xB8,
+0x0C, 0x00, 0x68, 0xB8, 0x00, 0x00, 0x00, 0x03,
+0x00, 0x00, 0x00, 0x42, 0xE0, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xFF, 0xFD, 0xE3, 0x00, 0x60, 0xB8,
+0x00, 0x00, 0x00, 0x01, 0xE1, 0x00, 0x60, 0xB8,
+0x00, 0x00, 0x00, 0x60, 0xCC, 0x00, 0x60, 0xB8,
+0x02, 0x00, 0x60, 0xB8, 0xE8, 0x12, 0x64, 0xB8,
+0x00, 0x00, 0x00, 0x04, 0xFF, 0xFF, 0xFF, 0xFB,
+0xFF, 0xFF, 0xFF, 0xDF, 0xFF, 0xFF, 0xFF, 0x1F,
+0x04, 0x00, 0x60, 0xB8, 0x04, 0x00, 0x64, 0xB8,
+0x08, 0x00, 0x60, 0xB8, 0x08, 0x00, 0x64, 0xB8,
+0x24, 0x00, 0x60, 0xB8, 0x80, 0x00, 0x60, 0xB8,
+0x00, 0x00, 0x03, 0x00, 0xFF, 0xFF, 0xFF, 0xEF,
+0xCC, 0x07, 0x64, 0xB8, 0x00, 0x00, 0x78, 0xB8,
+0x00, 0x00, 0x70, 0xB8, 0x87, 0x02, 0x64, 0xB8,
+0x00, 0x0C, 0x01, 0x00, 0xA8, 0x9F, 0x7B, 0x18,
+0xA8, 0x87, 0x7B, 0x18, 0x77, 0x77, 0x77, 0x77,
+0x08, 0x00, 0x00, 0xF8, 0x00, 0x00, 0x00, 0x3E,
+0x00, 0x00, 0xE0, 0xFF, 0x00, 0x1C, 0x01, 0x88,
+0x00, 0x00, 0x00, 0xFF, 0x08, 0x00, 0x45, 0x01,
+0x48, 0x08, 0x46, 0x01, 0xFF, 0xFF, 0x0F, 0x00,
+0xE0, 0x10, 0x05, 0x00, 0x00, 0x9C, 0x0A, 0x00,
+0x08, 0x00, 0x85, 0x00, 0x48, 0x08, 0x46, 0x00,
+0x60, 0x10, 0x05, 0x00, 0x88, 0x0C, 0x46, 0x01,
+0x00, 0xCC, 0x0A, 0x00, 0x48, 0x00, 0x46, 0x00,
+0x00, 0xDC, 0x0A, 0x00, 0x08, 0x00, 0x44, 0x01,
+0xF2, 0x0D, 0x05, 0x00, 0xEF, 0x00, 0x05, 0x00,
+0x6C, 0x08, 0x05, 0x00, 0x00, 0x00, 0x1F, 0x00,
+0x00, 0x00, 0x00, 0xC0, 0x00, 0x0A, 0x08, 0x00,
+0xCE, 0xEF, 0x0D, 0x00, 0xCE, 0xEF, 0x05, 0x00,
+0x01, 0x00, 0x00, 0xE0, 0x00, 0x00, 0xFF, 0x0F,
+0x21, 0x00, 0x00, 0xE0, 0x45, 0x23, 0x01, 0x00,
+0x08, 0x08, 0x00, 0xF8, 0x08, 0x07, 0x00, 0xF8,
+0x08, 0x02, 0x00, 0xF8, 0x08, 0x03, 0x00, 0xF8,
+0x00, 0x00, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x0F,
+0x62, 0x06, 0x64, 0xB8, 0xB4, 0x06, 0x64, 0xB8,
+0x06, 0x00, 0x00, 0x89, 0x00, 0x00, 0x00, 0x50,
+0x40, 0x00, 0x07, 0x70, 0x02, 0x04, 0x00, 0xD8,
+0x20, 0x01, 0x00, 0xD1, 0x40, 0x80, 0x03, 0x70,
+0x02, 0x04, 0x02, 0xD8, 0x20, 0x01, 0x00, 0xDE,
+0x08, 0x70, 0x0A, 0xF8, 0x08, 0x50, 0x01, 0xF8,
+0xDE, 0xBC, 0x0A, 0x00, 0x01, 0x00, 0x66, 0xB8,
+0x00, 0x00, 0x66, 0xB8, 0x00, 0xFF, 0xFF, 0x00,
+0xCD, 0x9B, 0x78, 0x56, 0x04, 0x1C, 0x66, 0xB8,
+0xFF, 0xFF, 0xFF, 0x3F, 0x1F, 0x00, 0x60, 0xB8,
+0x05, 0xEA, 0xEF, 0xFD, 0x06, 0xEA, 0xEF, 0xFD,
+0x00, 0x1C, 0x66, 0xB8, 0xFF, 0xFF, 0x3F, 0x00,
+0x04, 0xEA, 0xEF, 0xFD, 0x07, 0xEA, 0xEF, 0xFD,
+0x08, 0xEA, 0xEF, 0xFD, 0x09, 0xEA, 0xEF, 0xFD,
+0x0A, 0xEA, 0xEF, 0xFD, 0x00, 0xF0, 0x0F, 0x00,
+0x00, 0xF0, 0x3F, 0x00, 0x00, 0x00, 0xC0, 0xFF,
+0x00, 0x00, 0x00, 0xF0, 0x00, 0xFC, 0x0F, 0x00,
+0x80, 0x81, 0x81, 0x81, 0x81, 0x81, 0x01, 0x06,
+0x00, 0x0E, 0x0E, 0x0E, 0x0E, 0x0E, 0x0E, 0x38,
+0xE0, 0x80, 0x03, 0x00, 0x00, 0x00, 0x30, 0xC0,
+0x00, 0x03, 0x0C, 0x00, 0x4A, 0x04, 0x64, 0xB8,
+0x49, 0x04, 0x64, 0xB8, 0x02, 0x00, 0x64, 0xB8,
+0x03, 0x00, 0x60, 0xB8, 0x03, 0x00, 0x64, 0xB8,
+0x23, 0x04, 0x64, 0xB8, 0x30, 0x04, 0x64, 0xB8,
+0x34, 0x04, 0x64, 0xB8, 0x01, 0x02, 0x02, 0x03,
+0x00, 0x01, 0x01, 0x01, 0x81, 0x18, 0x66, 0xB8,
+0x53, 0x04, 0x64, 0xB8, 0x80, 0x18, 0x66, 0xB8,
+0x82, 0x18, 0x66, 0xB8, 0x83, 0x18, 0x66, 0xB8,
+0x84, 0x18, 0x66, 0xB8, 0x85, 0x18, 0x66, 0xB8,
+0x2D, 0x04, 0x64, 0xB8, 0xCF, 0x04, 0x64, 0xB8,
+0xF0, 0x10, 0x60, 0xB8, 0x00, 0x00, 0xF0, 0x00,
+0x00, 0x00, 0x00, 0x0C, 0x00, 0x00, 0x0F, 0x00,
+0x00, 0x00, 0x30, 0x00, 0x00, 0x00, 0xC0, 0x00,
+0x06, 0x00, 0x66, 0xB8, 0x50, 0x04, 0x64, 0xB8,
+0x51, 0x04, 0x64, 0xB8, 0x52, 0x04, 0x64, 0xB8,
+0x08, 0x1C, 0x66, 0xB8, 0xFF, 0xFF, 0xCF, 0x3F,
+0xFF, 0xFC, 0x3F, 0xFF, 0x01, 0x1C, 0x66, 0xB8,
+0x02, 0x1C, 0x66, 0xB8, 0x03, 0x1C, 0x66, 0xB8,
+0x05, 0x1C, 0x66, 0xB8, 0x06, 0x1C, 0x66, 0xB8,
+0x07, 0x1C, 0x66, 0xB8, 0x00, 0x10, 0x66, 0xB8,
+0x08, 0x10, 0x66, 0xB8, 0x03, 0x10, 0x66, 0xB8,
+0x09, 0x10, 0x66, 0xB8, 0x04, 0x10, 0x66, 0xB8,
+0x05, 0x10, 0x66, 0xB8, 0x0C, 0x10, 0x66, 0xB8,
+0x02, 0x10, 0x66, 0xB8, 0x01, 0x10, 0x66, 0xB8,
+0x0D, 0x10, 0x66, 0xB8, 0x06, 0x10, 0x66, 0xB8,
+0xFF, 0xFF, 0xFF, 0x00, 0x74, 0x57, 0x74, 0x00,
+0x47, 0x75, 0x47, 0x00, 0x70, 0x45, 0x70, 0x00,
+0x17, 0x45, 0x17, 0x00, 0x00, 0x00, 0xF0, 0xFF,
+0x70, 0x57, 0x70, 0x00, 0x17, 0x75, 0x17, 0x00,
+0x00, 0x00, 0x00, 0x06, 0xFF, 0xFF, 0xFF, 0x0F,
+0xFF, 0xFC, 0xFE, 0xFF, 0x92, 0x84, 0x10, 0x08,
+0x00, 0x00, 0x00, 0x08, 0x00, 0x01, 0x01, 0x00,
+0x00, 0x00, 0x10, 0x08, 0x00, 0x00, 0x40, 0x00,
+0x28, 0xEA, 0xA0, 0x79, 0xB9, 0xB2, 0x94, 0x91,
+0x00, 0x00, 0x0C, 0x00, 0x00, 0x00, 0x80, 0x00,
+0x0E, 0x08, 0x04, 0x00, 0x0C, 0x08, 0x04, 0x00,
+0x00, 0xFF, 0xF9, 0xFF, 0x00, 0x00, 0xFE, 0x1F,
+0x77, 0x65, 0x4F, 0x38, 0x00, 0x80, 0x03, 0x00,
+0x18, 0x00, 0x70, 0xB8, 0x18, 0x00, 0x78, 0xB8,
+0x0B, 0x00, 0x78, 0xB8, 0x0B, 0x00, 0x70, 0xB8,
+0x02, 0x00, 0x78, 0xB8, 0x02, 0x00, 0x70, 0xB8,
+0x01, 0xA0, 0x02, 0x00, 0x94, 0x02, 0x64, 0xB8,
+0x97, 0x02, 0x64, 0xB8, 0xCC, 0x01, 0x64, 0xB8,
+0xCF, 0x01, 0x64, 0xB8, 0x34, 0x01, 0x64, 0xB8,
+0x54, 0x02, 0x64, 0xB8, 0x50, 0x02, 0x64, 0xB8,
+0x4C, 0x02, 0x64, 0xB8, 0x04, 0x00, 0x78, 0xB8,
+0x48, 0x02, 0x64, 0xB8, 0x44, 0x02, 0x64, 0xB8,
+0xD4, 0x04, 0x60, 0xB8, 0xD4, 0x04, 0x64, 0xB8,
+0x84, 0x04, 0x60, 0xB8, 0x84, 0x04, 0x64, 0xB8,
+0xC8, 0x04, 0x60, 0xB8, 0xC8, 0x04, 0x64, 0xB8,
+0x78, 0x04, 0x60, 0xB8, 0x78, 0x04, 0x64, 0xB8,
+0xBE, 0x05, 0x64, 0xB8, 0x01, 0xEA, 0xEF, 0xFD,
+0x02, 0xEA, 0xEF, 0xFD, 0xC8, 0x01, 0x64, 0xB8,
+0xC9, 0x01, 0x64, 0xB8, 0xA0, 0x01, 0x64, 0xB8,
+0x48, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xFE, 0xFF,
+0x44, 0x00, 0x60, 0xB8, 0x60, 0x00, 0x60, 0xB8,
+0x47, 0x00, 0x60, 0xB8, 0x46, 0x00, 0x60, 0xB8,
+0x63, 0x00, 0x60, 0xB8, 0x62, 0x00, 0x60, 0xB8,
+0x45, 0x00, 0x60, 0xB8, 0x61, 0x00, 0x60, 0xB8,
+0xC6, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x00, 0x05,
+0x53, 0x05, 0x64, 0xB8, 0x80, 0x34, 0x00, 0xB8,
+0x94, 0x01, 0x64, 0xB8, 0x54, 0x00, 0x60, 0xB8,
+0x50, 0x00, 0x60, 0xB8, 0x30, 0x01, 0x64, 0xB8,
+0x24, 0x01, 0x64, 0xB8, 0x20, 0x01, 0x64, 0xB8,
+0x24, 0x11, 0x64, 0xB8, 0x20, 0x11, 0x64, 0xB8,
+0x2C, 0x11, 0x64, 0xB8, 0x28, 0x11, 0x64, 0xB8,
+0x34, 0x11, 0x64, 0xB8, 0x30, 0x11, 0x64, 0xB8,
+0x38, 0x01, 0x64, 0xB8, 0x3C, 0x11, 0x64, 0xB8,
+0x38, 0x11, 0x64, 0xB8, 0xE4, 0x11, 0x64, 0xB8,
+0xE0, 0x11, 0x64, 0xB8, 0x00, 0x40, 0xE0, 0x03,
+0x01, 0x60, 0x00, 0x03, 0xE0, 0x12, 0x64, 0xB8,
+0xE8, 0x10, 0x60, 0xB8, 0x02, 0x01, 0x64, 0xB8,
+0x21, 0x05, 0x64, 0xB8, 0x2F, 0x01, 0x64, 0xB8,
+0x00, 0x28, 0x64, 0xB8, 0x00, 0x2C, 0x64, 0xB8,
+0x00, 0x38, 0x64, 0xB8, 0x00, 0x3C, 0x64, 0xB8,
+0x83, 0x00, 0x60, 0xB8, 0x90, 0x00, 0x60, 0xB8,
+0x92, 0x06, 0x64, 0xB8, 0x08, 0x01, 0x64, 0xB8,
+0x92, 0x00, 0x60, 0xB8, 0xF8, 0x05, 0x64, 0xB8,
+0x1F, 0x07, 0x64, 0xB8, 0x1C, 0x07, 0x64, 0xB8,
+0xB8, 0x05, 0x64, 0xB8, 0xBC, 0x05, 0x64, 0xB8,
+0x6F, 0x01, 0x64, 0xB8, 0xFE, 0xFF, 0xFF, 0x7F,
+0x00, 0xA0, 0x7A, 0xB8, 0x00, 0xA0, 0x7A, 0x18,
+0x00, 0x00, 0x70, 0x18, 0x00, 0x00, 0x66, 0x18,
+0xE8, 0x03, 0x00, 0x80, 0xFF, 0x00, 0xFF, 0x00,
+0x40, 0x00, 0x00, 0xB5, 0x44, 0x00, 0x00, 0xB5,
+0x48, 0x00, 0x00, 0xB5, 0x4C, 0x00, 0x00, 0xB5,
+0xA4, 0x04, 0x64, 0xB8, 0xA8, 0x04, 0x64, 0xB8,
+0xC0, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x10, 0x00,
+0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x02, 0x02,
+0x00, 0x00, 0x04, 0x04, 0x00, 0x00, 0x08, 0x08,
+0x00, 0x00, 0x10, 0x10, 0x00, 0x00, 0x20, 0x20,
+0x00, 0x00, 0x40, 0x40, 0x00, 0x00, 0x80, 0x80,
+0x00, 0x00, 0x20, 0x00, 0x7E, 0x04, 0x64, 0xB8,
+0xAC, 0x04, 0x64, 0xB8, 0x07, 0x10, 0x66, 0xB8,
+0x7D, 0x04, 0x64, 0xB8, 0x7C, 0x04, 0x64, 0xB8,
+0xF4, 0x00, 0x60, 0xB8, 0x90, 0x06, 0x64, 0xB8,
+0x44, 0x00, 0x02, 0x00, 0xA0, 0x07, 0x64, 0xB8,
+0xFF, 0xFF, 0xFF, 0x7F, 0x9A, 0x01, 0x64, 0xB8,
+0x98, 0x01, 0x64, 0xB8, 0x7B, 0x05, 0x64, 0xB8,
+0x73, 0x05, 0x64, 0xB8, 0x0F, 0x00, 0x3E, 0x00,
+0x01, 0x01, 0x64, 0xB8, 0x14, 0x00, 0x60, 0xB8,
+0x7C, 0x00, 0x60, 0xB8, 0x10, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xDF, 0xFF, 0xFF, 0xFF, 0xFF, 0xBF,
+0xB7, 0x06, 0x64, 0xB8, 0x64, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xFF, 0xFE, 0x40, 0x00, 0x60, 0xB8,
+0x4C, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0x7F, 0xFF,
+0x44, 0x09, 0x64, 0xB8, 0x30, 0x09, 0x64, 0xB8,
+0x38, 0x00, 0x60, 0xB8, 0xEF, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xFF, 0xCF, 0xFF, 0xFF, 0xFF, 0xF9,
+0x70, 0x00, 0x60, 0xB8, 0x80, 0x10, 0x60, 0xB8,
+0xEC, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x07,
+0xFF, 0xFF, 0xFF, 0xF8, 0xE4, 0x00, 0x60, 0xB8,
+0xE5, 0x00, 0x60, 0xB8, 0xE8, 0x00, 0x60, 0xB8,
+0xE9, 0x00, 0x60, 0xB8, 0xEA, 0x00, 0x60, 0xB8,
+0xEB, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0x7F, 0xFE,
+0x31, 0x00, 0x60, 0xB8, 0x32, 0x00, 0x60, 0xB8,
+0x33, 0x00, 0x60, 0xB8, 0x30, 0x00, 0x60, 0xB8,
+0x01, 0xAA, 0xAA, 0xFA, 0x68, 0x06, 0x64, 0xB8,
+0xFF, 0xFF, 0xCF, 0xFF, 0x5C, 0x05, 0x64, 0xB8,
+0x38, 0x06, 0x64, 0xB8, 0x83, 0x04, 0x64, 0xB8,
+0x54, 0x04, 0x64, 0xB8, 0x84, 0x02, 0x64, 0xB8,
+0xFF, 0xFF, 0xFB, 0xFF, 0x04, 0x06, 0x64, 0xB8,
+0x60, 0x16, 0x64, 0xB8, 0x20, 0x00, 0x78, 0xB8,
+0x10, 0x00, 0x78, 0xB8, 0x03, 0x00, 0x78, 0xB8,
+0xFF, 0xFF, 0x01, 0xFF, 0x05, 0x00, 0x78, 0xB8,
+0x12, 0x05, 0x64, 0xB8, 0x10, 0x05, 0x64, 0xB8,
+0x30, 0x00, 0x78, 0xB8, 0x43, 0x6C, 0x65, 0x61,
+0x72, 0x50, 0x57, 0x54, 0x00, 0x00, 0x00, 0x00,
+0x41, 0x20, 0x4D, 0x69, 0x78, 0x4D, 0x6F, 0x64,
+0x65, 0x20, 0x41, 0x47, 0x43, 0x3D, 0x30, 0x78,
+0x25, 0x62, 0x58, 0x20, 0x42, 0x42, 0x53, 0x3D,
+0x30, 0x78, 0x25, 0x62, 0x58, 0x00, 0x00, 0x00,
+0x42, 0x20, 0x4D, 0x69, 0x78, 0x4D, 0x6F, 0x64,
+0x65, 0x20, 0x41, 0x47, 0x43, 0x3D, 0x30, 0x78,
+0x25, 0x62, 0x58, 0x20, 0x42, 0x42, 0x53, 0x3D,
+0x30, 0x78, 0x25, 0x62, 0x58, 0x00, 0x00, 0x00,
+0x5B, 0x49, 0x51, 0x4B, 0x5D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3E, 0x50, 0x48, 0x59, 0x5F, 0x49,
+0x51, 0x43, 0x61, 0x6C, 0x69, 0x62, 0x72, 0x61,
+0x74, 0x65, 0x5F, 0x49, 0x6E, 0x69, 0x74, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x72, 0x65, 0x6C, 0x6F,
+0x61, 0x64, 0x20, 0x49, 0x51, 0x4B, 0x20, 0x72,
+0x65, 0x73, 0x75, 0x6C, 0x74, 0x20, 0x62, 0x65,
+0x66, 0x6F, 0x72, 0x65, 0x2C, 0x20, 0x30, 0x78,
+0x25, 0x62, 0x78, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x49, 0x51, 0x4B, 0x20, 0x74, 0x69, 0x6D, 0x65,
+0x6F, 0x75, 0x74, 0x21, 0x21, 0x21, 0x0A, 0x00,
+0x64, 0x65, 0x6C, 0x61, 0x79, 0x20, 0x63, 0x6F,
+0x75, 0x6E, 0x74, 0x20, 0x3D, 0x20, 0x30, 0x78,
+0x25, 0x78, 0x21, 0x21, 0x21, 0x0A, 0x00, 0x00,
+0x64, 0x65, 0x6C, 0x61, 0x79, 0x5F, 0x63, 0x6F,
+0x75, 0x6E, 0x74, 0x20, 0x3D, 0x20, 0x30, 0x78,
+0x25, 0x78, 0x0A, 0x00, 0x49, 0x51, 0x4B, 0x73,
+0x74, 0x65, 0x70, 0x20, 0x3D, 0x20, 0x30, 0x78,
+0x25, 0x62, 0x78, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x5B, 0x49, 0x51, 0x4B, 0x5D, 0x50, 0x61, 0x74,
+0x68, 0x41, 0x5F, 0x4C, 0x4F, 0x4B, 0x5F, 0x6E,
+0x6F, 0x74, 0x72, 0x65, 0x61, 0x64, 0x79, 0x20,
+0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20, 0x50, 0x61,
+0x74, 0x68, 0x42, 0x5F, 0x4C, 0x4F, 0x4B, 0x31,
+0x5F, 0x6E, 0x6F, 0x74, 0x72, 0x65, 0x61, 0x64,
+0x79, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x0A, 0x00,
+0x5B, 0x49, 0x51, 0x4B, 0x5D, 0x50, 0x61, 0x74,
+0x68, 0x41, 0x5F, 0x54, 0x58, 0x49, 0x51, 0x4B,
+0x5F, 0x66, 0x61, 0x69, 0x6C, 0x20, 0x3D, 0x20,
+0x25, 0x64, 0x2C, 0x20, 0x50, 0x61, 0x74, 0x68,
+0x42, 0x5F, 0x54, 0x58, 0x49, 0x51, 0x4B, 0x5F,
+0x66, 0x61, 0x69, 0x6C, 0x20, 0x3D, 0x20, 0x25,
+0x64, 0x0A, 0x00, 0x00, 0x5B, 0x49, 0x51, 0x4B,
+0x5D, 0x50, 0x61, 0x74, 0x68, 0x41, 0x5F, 0x52,
+0x58, 0x49, 0x51, 0x4B, 0x5F, 0x66, 0x61, 0x69,
+0x6C, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20,
+0x50, 0x61, 0x74, 0x68, 0x42, 0x5F, 0x52, 0x58,
+0x49, 0x51, 0x4B, 0x5F, 0x66, 0x61, 0x69, 0x6C,
+0x20, 0x3D, 0x20, 0x25, 0x64, 0x0A, 0x00, 0x00,
+0x5B, 0x49, 0x51, 0x4B, 0x5D, 0x50, 0x61, 0x74,
+0x68, 0x41, 0x5F, 0x54, 0x58, 0x49, 0x51, 0x4B,
+0x5F, 0x72, 0x65, 0x74, 0x72, 0x79, 0x20, 0x3D,
+0x20, 0x25, 0x64, 0x2C, 0x20, 0x50, 0x61, 0x74,
+0x68, 0x42, 0x5F, 0x54, 0x58, 0x49, 0x51, 0x4B,
+0x5F, 0x72, 0x65, 0x74, 0x72, 0x79, 0x20, 0x3D,
+0x20, 0x25, 0x64, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x5B, 0x49, 0x51, 0x4B, 0x5D, 0x50, 0x61, 0x74,
+0x68, 0x41, 0x5F, 0x52, 0x58, 0x4B, 0x31, 0x5F,
+0x72, 0x65, 0x74, 0x72, 0x79, 0x20, 0x3D, 0x20,
+0x25, 0x64, 0x2C, 0x20, 0x50, 0x61, 0x74, 0x68,
+0x41, 0x5F, 0x52, 0x58, 0x4B, 0x32, 0x5F, 0x72,
+0x65, 0x74, 0x72, 0x79, 0x20, 0x3D, 0x20, 0x25,
+0x64, 0x2C, 0x20, 0x50, 0x61, 0x74, 0x68, 0x42,
+0x5F, 0x52, 0x58, 0x4B, 0x31, 0x5F, 0x72, 0x65,
+0x74, 0x72, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x64,
+0x2C, 0x20, 0x50, 0x61, 0x74, 0x68, 0x42, 0x5F,
+0x52, 0x58, 0x4B, 0x32, 0x5F, 0x72, 0x65, 0x74,
+0x72, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x5B, 0x49, 0x51, 0x4B,
+0x5D, 0x50, 0x61, 0x74, 0x68, 0x41, 0x5F, 0x47,
+0x53, 0x31, 0x5F, 0x72, 0x65, 0x74, 0x72, 0x79,
+0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20, 0x50,
+0x61, 0x74, 0x68, 0x41, 0x5F, 0x47, 0x53, 0x32,
+0x5F, 0x72, 0x65, 0x74, 0x72, 0x79, 0x20, 0x3D,
+0x20, 0x25, 0x64, 0x2C, 0x20, 0x50, 0x61, 0x74,
+0x68, 0x42, 0x5F, 0x47, 0x53, 0x31, 0x5F, 0x72,
+0x65, 0x74, 0x72, 0x79, 0x20, 0x3D, 0x20, 0x25,
+0x64, 0x2C, 0x20, 0x50, 0x61, 0x74, 0x68, 0x42,
+0x5F, 0x47, 0x53, 0x32, 0x5F, 0x72, 0x65, 0x74,
+0x72, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x46, 0x57, 0x49, 0x51,
+0x4B, 0x20, 0x73, 0x74, 0x61, 0x72, 0x74, 0x21,
+0x21, 0x21, 0x00, 0x00, 0x30, 0x31, 0x32, 0x33,
+0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x41, 0x42,
+0x43, 0x44, 0x45, 0x46, 0x00, 0x00, 0x00, 0x00,
+0x53, 0x65, 0x74, 0x5F, 0x43, 0x61, 0x6E, 0x64,
+0x69, 0x5F, 0x33, 0x3A, 0x20, 0x5B, 0x31, 0x5D,
+0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x2C, 0x20,
+0x20, 0x5B, 0x32, 0x5D, 0x3D, 0x30, 0x78, 0x25,
+0x62, 0x58, 0x2C, 0x20, 0x20, 0x5B, 0x33, 0x5D,
+0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x53, 0x65, 0x74, 0x5F, 0x43, 0x61, 0x6E, 0x64,
+0x69, 0x5F, 0x32, 0x3A, 0x20, 0x5B, 0x31, 0x5D,
+0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x2C, 0x20,
+0x20, 0x5B, 0x32, 0x5D, 0x3D, 0x30, 0x78, 0x25,
+0x62, 0x58, 0x20, 0x00, 0x44, 0x65, 0x6C, 0x4D,
+0x55, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x50, 0x45, 0x52, 0x20, 0x52, 0x50, 0x54, 0x3A,
+0x20, 0x6D, 0x69, 0x64, 0x25, 0x62, 0x58, 0x2C,
+0x52, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x72, 0x74,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x62, 0x77, 0x3A,
+0x25, 0x62, 0x78, 0x00, 0x50, 0x45, 0x52, 0x20,
+0x52, 0x50, 0x54, 0x3A, 0x20, 0x6D, 0x69, 0x64,
+0x25, 0x62, 0x58, 0x2C, 0x54, 0x54, 0x3A, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x50, 0x45, 0x52, 0x20,
+0x52, 0x50, 0x54, 0x3A, 0x20, 0x25, 0x62, 0x58,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x58,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x58,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x65, 0x71, 0x20, 0x50, 0x45, 0x52, 0x20,
+0x43, 0x4D, 0x44, 0x3A, 0x20, 0x47, 0x72, 0x3A,
+0x25, 0x62, 0x58, 0x2C, 0x20, 0x54, 0x59, 0x50,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x62, 0x74,
+0x6D, 0x70, 0x3A, 0x25, 0x78, 0x00, 0x00, 0x00,
+0x52, 0x65, 0x71, 0x20, 0x50, 0x45, 0x52, 0x20,
+0x43, 0x4D, 0x44, 0x3A, 0x20, 0x49, 0x64, 0x78,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x6D, 0x69,
+0x64, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x65, 0x71, 0x20, 0x50, 0x45, 0x52, 0x20,
+0x43, 0x4D, 0x44, 0x3A, 0x20, 0x49, 0x64, 0x78,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x4D, 0x69,
+0x64, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x25,
+0x62, 0x78, 0x2C, 0x20, 0x25, 0x62, 0x78, 0x00,
+0x53, 0x65, 0x74, 0x5F, 0x50, 0x6E, 0x74, 0x79,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x65, 0x74, 0x5F,
+0x52, 0x41, 0x5F, 0x55, 0x70, 0x5F, 0x72, 0x61,
+0x74, 0x69, 0x6F, 0x5F, 0x66, 0x6F, 0x72, 0x5F,
+0x52, 0x41, 0x5F, 0x64, 0x65, 0x62, 0x75, 0x67,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x65, 0x74, 0x5F,
+0x44, 0x6F, 0x77, 0x6E, 0x5F, 0x72, 0x61, 0x74,
+0x69, 0x6F, 0x00, 0x00, 0x76, 0x61, 0x6C, 0x75,
+0x65, 0x38, 0x3D, 0x30, 0x78, 0x25, 0x62, 0x58,
+0x2C, 0x20, 0x76, 0x61, 0x6C, 0x75, 0x65, 0x31,
+0x36, 0x3D, 0x30, 0x78, 0x25, 0x77, 0x78, 0x2C,
+0x20, 0x76, 0x61, 0x6C, 0x75, 0x65, 0x33, 0x32,
+0x3D, 0x30, 0x78, 0x25, 0x78, 0x00, 0x00, 0x00,
+0x48, 0x32, 0x43, 0x4D, 0x55, 0x3A, 0x41, 0x64,
+0x45, 0x6E, 0x74, 0x3D, 0x25, 0x62, 0x78, 0x2C,
+0x6D, 0x69, 0x64, 0x3D, 0x25, 0x62, 0x78, 0x00,
+0x48, 0x32, 0x43, 0x4D, 0x52, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x4D, 0x55, 0x3A, 0x20, 0x44, 0x65, 0x6C, 0x65,
+0x74, 0x65, 0x20, 0x65, 0x6E, 0x74, 0x72, 0x79,
+0x20, 0x3D, 0x20, 0x25, 0x62, 0x78, 0x2C, 0x20,
+0x6D, 0x61, 0x63, 0x69, 0x64, 0x20, 0x3D, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x4D, 0x55, 0x3A, 0x20,
+0x57, 0x61, 0x74, 0x63, 0x68, 0x20, 0x47, 0x49,
+0x44, 0x3D, 0x25, 0x62, 0x78, 0x20, 0x75, 0x73,
+0x65, 0x72, 0x3D, 0x25, 0x62, 0x78, 0x20, 0x64,
+0x6F, 0x77, 0x6E, 0x3D, 0x25, 0x62, 0x78, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x62, 0x44, 0x52, 0x61, 0x3A, 0x25,
+0x62, 0x78, 0x2C, 0x62, 0x44, 0x50, 0x54, 0x3A,
+0x25, 0x62, 0x78, 0x2C, 0x52, 0x61, 0x49, 0x64,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x49, 0x6E, 0x69,
+0x42, 0x77, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x42,
+0x77, 0x53, 0x65, 0x74, 0x25, 0x62, 0x78, 0x2C,
+0x62, 0x53, 0x47, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x56, 0x45, 0x4E, 0x3A, 0x25, 0x62, 0x78, 0x00,
+0x4D, 0x61, 0x73, 0x6B, 0x30, 0x20, 0x25, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x48, 0x32, 0x43, 0x42,
+0x46, 0x45, 0x6E, 0x74, 0x00, 0x00, 0x00, 0x00,
+0x45, 0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x4E,
+0x63, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x4D, 0x3A,
+0x25, 0x62, 0x78, 0x00, 0x44, 0x69, 0x73, 0x3A,
+0x25, 0x62, 0x78, 0x20, 0x4E, 0x63, 0x3A, 0x25,
+0x62, 0x78, 0x20, 0x4D, 0x3A, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x43, 0x6F, 0x6E, 0x6E,
+0x65, 0x63, 0x74, 0x20, 0x53, 0x74, 0x61, 0x72,
+0x74, 0x62, 0x79, 0x52, 0x53, 0x53, 0x49, 0x3A,
+0x25, 0x62, 0x58, 0x20, 0x25, 0x62, 0x78, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x52, 0x53, 0x53, 0x49,
+0x43, 0x4D, 0x44, 0x3A, 0x25, 0x62, 0x58, 0x20,
+0x25, 0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x52, 0x53, 0x53, 0x49,
+0x43, 0x4D, 0x44, 0x20, 0x44, 0x72, 0x76, 0x46,
+0x69, 0x78, 0x3A, 0x25, 0x62, 0x58, 0x20, 0x25,
+0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x63, 0x63, 0x78, 0x5F, 0x68, 0x32, 0x63, 0x20,
+0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x20,
+0x50, 0x65, 0x72, 0x69, 0x6F, 0x64, 0x3D, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x72, 0x65, 0x61, 0x64,
+0x79, 0x3D, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x43, 0x6C, 0x6D, 0x52, 0x70, 0x74, 0x3D, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x43, 0x32, 0x48, 0x20,
+0x25, 0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x00,
+0x63, 0x6E, 0x74, 0x3D, 0x25, 0x62, 0x78, 0x00,
+0x4D, 0x3A, 0x25, 0x62, 0x58, 0x2C, 0x52, 0x3A,
+0x25, 0x62, 0x58, 0x2C, 0x25, 0x62, 0x78, 0x2C,
+0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C,
+0x20, 0x25, 0x77, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x47, 0x3A, 0x25, 0x62, 0x58, 0x2C, 0x50, 0x30,
+0x25, 0x62, 0x58, 0x2C, 0x50, 0x31, 0x25, 0x62,
+0x58, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x32, 0x53, 0x25,
+0x78, 0x2C, 0x54, 0x54, 0x25, 0x78, 0x00, 0x00,
+0x4D, 0x74, 0x42, 0x77, 0x20, 0x55, 0x70, 0x44,
+0x77, 0x25, 0x62, 0x78, 0x20, 0x42, 0x57, 0x25,
+0x62, 0x78, 0x20, 0x52, 0x74, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x48, 0x69, 0x74, 0x25,
+0x62, 0x78, 0x20, 0x52, 0x74, 0x30, 0x3D, 0x25,
+0x77, 0x78, 0x20, 0x52, 0x74, 0x31, 0x3D, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x4F,
+0x46, 0x44, 0x4D, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x41, 0x3A, 0x43, 0x43, 0x4B, 0x25, 0x62,
+0x58, 0x00, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x56,
+0x31, 0x2D, 0x4D, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x41, 0x3A, 0x56, 0x32, 0x2D, 0x4D, 0x25,
+0x62, 0x58, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x56,
+0x33, 0x2D, 0x4D, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x41, 0x3A, 0x48, 0x2D, 0x4D, 0x25, 0x62,
+0x58, 0x00, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x48,
+0x2D, 0x4D, 0x31, 0x2C, 0x25, 0x62, 0x58, 0x00,
+0x52, 0x41, 0x3A, 0x48, 0x2D, 0x4D, 0x32, 0x2C,
+0x25, 0x62, 0x58, 0x00, 0x53, 0x74, 0x6F, 0x72,
+0x45, 0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x42,
+0x46, 0x63, 0x74, 0x72, 0x6C, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x57, 0x72, 0x69, 0x74,
+0x65, 0x45, 0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20,
+0x42, 0x46, 0x63, 0x74, 0x72, 0x6C, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x52, 0x65, 0x63, 0x45,
+0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x42, 0x46,
+0x63, 0x74, 0x72, 0x6C, 0x3A, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x6E, 0x64, 0x44,
+0x20, 0x4D, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x52,
+0x3A, 0x25, 0x62, 0x78, 0x20, 0x52, 0x25, 0x62,
+0x78, 0x20, 0x43, 0x74, 0x3A, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x41, 0x70, 0x70, 0x6C,
+0x56, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x4E, 0x61, 0x70, 0x70, 0x6C, 0x56, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x43, 0x68, 0x54, 0x78,
+0x42, 0x46, 0x73, 0x74, 0x73, 0x20, 0x4D, 0x3A,
+0x25, 0x62, 0x78, 0x20, 0x45, 0x6E, 0x74, 0x3A,
+0x25, 0x62, 0x78, 0x20, 0x52, 0x61, 0x3A, 0x25,
+0x62, 0x78, 0x20, 0x4E, 0x63, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x45, 0x72, 0x72, 0x4E,
+0x63, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x43, 0x6F, 0x72, 0x72, 0x4E, 0x63, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x53, 0x6E, 0x64, 0x44,
+0x6F, 0x6E, 0x53, 0x75, 0x00, 0x00, 0x00, 0x00,
+0x53, 0x6E, 0x64, 0x44, 0x6F, 0x6E, 0x46, 0x61,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x65, 0x61, 0x72,
+0x63, 0x68, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x25,
+0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x42, 0x47, 0x20, 0x3A, 0x25, 0x62, 0x78, 0x20,
+0x2C, 0x20, 0x6E, 0x75, 0x6D, 0x74, 0x72, 0x79,
+0x3A, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x53, 0x54, 0x42, 0x43, 0x20, 0x6F, 0x6E, 0x00,
+0x53, 0x74, 0x61, 0x74, 0x65, 0x20, 0x25, 0x62,
+0x58, 0x20, 0x00, 0x00, 0x72, 0x61, 0x74, 0x65,
+0x3A, 0x20, 0x25, 0x62, 0x58, 0x00, 0x00, 0x00,
+0x49, 0x44, 0x3A, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x5B, 0x30, 0x3A, 0x34, 0x5D, 0x20, 0x25,
+0x62, 0x58, 0x20, 0x2C, 0x20, 0x25, 0x62, 0x58,
+0x2C, 0x20, 0x25, 0x62, 0x58, 0x2C, 0x20, 0x25,
+0x62, 0x58, 0x2C, 0x20, 0x25, 0x62, 0x58, 0x20,
+0x00, 0x00, 0x00, 0x00, 0x55, 0x3A, 0x20, 0x25,
+0x62, 0x58, 0x20, 0x00, 0x54, 0x47, 0x3A, 0x20,
+0x25, 0x62, 0x58, 0x20, 0x00, 0x00, 0x00, 0x00,
+0x54, 0x47, 0x70, 0x61, 0x74, 0x68, 0x3A, 0x20,
+0x25, 0x62, 0x58, 0x20, 0x00, 0x00, 0x00, 0x00,
+0x53, 0x65, 0x74, 0x50, 0x61, 0x74, 0x68, 0x3A,
+0x20, 0x25, 0x62, 0x58, 0x20, 0x00, 0x00, 0x00,
+0x44, 0x54, 0x50, 0x5F, 0x65, 0x6E, 0x64, 0x00,
+0x53, 0x65, 0x74, 0x52, 0x5F, 0x4E, 0x54, 0x3A,
+0x25, 0x62, 0x58, 0x20, 0x25, 0x62, 0x78, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x54, 0x72, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x53, 0x65, 0x74, 0x52,
+0x5F, 0x54, 0x3A, 0x25, 0x62, 0x58, 0x20, 0x25,
+0x62, 0x58, 0x20, 0x25, 0x62, 0x78, 0x20, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x4D, 0x55, 0x53, 0x74,
+0x61, 0x72, 0x74, 0x20, 0x4D, 0x25, 0x62, 0x78,
+0x52, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x61, 0x55, 0x70, 0x00, 0x00, 0x00, 0x00,
+0x31, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x30, 0x55, 0x70, 0x64, 0x74, 0x5F, 0x42, 0x57,
+0x3D, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x32, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x33, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x34, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x35, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x52, 0x61, 0x44, 0x6E, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x64, 0x53, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x00,
+0x46, 0x57, 0x44, 0x62, 0x67, 0x00, 0x00, 0x00,
+0x46, 0x57, 0x46, 0x69, 0x78, 0x00, 0x00, 0x00,
+0x50, 0x43, 0x52, 0x3A, 0x20, 0x4D, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x62, 0x54, 0x52, 0x59,
+0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x54, 0x72, 0x44, 0x6F, 0x6E, 0x43, 0x6E, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x45, 0x72, 0x72, 0x6F,
+0x72, 0x31, 0x00, 0x00, 0x50, 0x6B, 0x74, 0x3A,
+0x25, 0x58, 0x2C, 0x25, 0x58, 0x2C, 0x25, 0x58,
+0x00, 0x00, 0x00, 0x00, 0x46, 0x44, 0x3A, 0x20,
+0x52, 0x44, 0x00, 0x00, 0x46, 0x44, 0x3A, 0x20,
+0x44, 0x72, 0x6F, 0x70, 0x2C, 0x20, 0x52, 0x61,
+0x74, 0x65, 0x53, 0x74, 0x61, 0x79, 0x00, 0x00,
+0x46, 0x44, 0x3A, 0x20, 0x52, 0x55, 0x00, 0x00,
+0x4D, 0x25, 0x62, 0x78, 0x20, 0x52, 0x25, 0x62,
+0x78, 0x20, 0x53, 0x50, 0x25, 0x77, 0x78, 0x20,
+0x52, 0x50, 0x25, 0x77, 0x78, 0x20, 0x54, 0x50,
+0x25, 0x77, 0x78, 0x20, 0x52, 0x52, 0x25, 0x62,
+0x78, 0x20, 0x53, 0x52, 0x25, 0x62, 0x78, 0x00,
+0x52, 0x61, 0x74, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x52, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x52, 0x34,
+0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x61, 0x74, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x20, 0x52, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x52,
+0x34, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x44, 0x72, 0x6F, 0x70, 0x50, 0x6B, 0x74, 0x3A,
+0x25, 0x62, 0x78, 0x00, 0x72, 0x74, 0x79, 0x6D,
+0x61, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x72,
+0x74, 0x79, 0x72, 0x61, 0x74, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x20, 0x64, 0x69, 0x66, 0x66, 0x3A,
+0x25, 0x62, 0x78, 0x2C, 0x20, 0x75, 0x70, 0x64,
+0x6E, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x72, 0x74, 0x79, 0x6D, 0x61, 0x5F, 0x72, 0x61,
+0x74, 0x65, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x72,
+0x74, 0x79, 0x5F, 0x76, 0x61, 0x72, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x62, 0x76, 0x61, 0x72,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x76, 0x61,
+0x72, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x44, 0x65, 0x4F, 0x46, 0x46, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x20, 0x25, 0x62, 0x58, 0x2C, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x4D, 0x6F, 0x64, 0x54,
+0x48, 0x3A, 0x20, 0x55, 0x70, 0x54, 0x48, 0x25,
+0x62, 0x78, 0x2C, 0x20, 0x44, 0x6E, 0x54, 0x48,
+0x25, 0x62, 0x78, 0x00, 0x44, 0x72, 0x76, 0x4F,
+0x66, 0x66, 0x73, 0x65, 0x74, 0x3A, 0x20, 0x53,
+0x68, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x55, 0x70,
+0x54, 0x48, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x44,
+0x6E, 0x54, 0x48, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x4D, 0x52, 0x61, 0x74, 0x65, 0x20, 0x3D, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x42, 0x57, 0x25, 0x62,
+0x78, 0x20, 0x52, 0x74, 0x25, 0x62, 0x78, 0x00,
+0x52, 0x44, 0x31, 0x00, 0x55, 0x70, 0x3A, 0x25,
+0x62, 0x58, 0x2C, 0x44, 0x6E, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x52, 0x44, 0x32, 0x00,
+0x52, 0x55, 0x20, 0x25, 0x62, 0x78, 0x20, 0x25,
+0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x52, 0x55, 0x5F, 0x53, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x53, 0x00, 0x00, 0x52, 0x53, 0x54, 0x54,
+0x78, 0x52, 0x50, 0x54, 0x00, 0x00, 0x00, 0x00,
+0x44, 0x6E, 0x54, 0x72, 0x79, 0x52, 0x3D, 0x25,
+0x62, 0x58, 0x2C, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x54, 0x72, 0x79, 0x53, 0x75, 0x3A, 0x25, 0x62,
+0x58, 0x00, 0x00, 0x00, 0x55, 0x70, 0x54, 0x72,
+0x79, 0x53, 0x25, 0x62, 0x78, 0x20, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x44, 0x6E, 0x54, 0x72,
+0x79, 0x53, 0x25, 0x62, 0x78, 0x20, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x55, 0x70, 0x54, 0x72,
+0x79, 0x46, 0x25, 0x62, 0x78, 0x20, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x44, 0x6E, 0x54, 0x72,
+0x79, 0x46, 0x25, 0x62, 0x78, 0x20, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x54, 0x72, 0x79, 0x46,
+0x50, 0x25, 0x62, 0x78, 0x20, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x50, 0x65, 0x6E, 0x64,
+0x3A, 0x25, 0x77, 0x58, 0x20, 0x00, 0x00, 0x00,
+0x54, 0x72, 0x79, 0x46, 0x3A, 0x25, 0x62, 0x58,
+0x20, 0x00, 0x00, 0x00, 0x52, 0x53, 0x53, 0x49,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x4D, 0x25, 0x62,
+0x78, 0x2C, 0x52, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x41, 0x52, 0x46, 0x52, 0x43, 0x4D, 0x44, 0x3A,
+0x25, 0x62, 0x58, 0x20, 0x25, 0x62, 0x78, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x4D, 0x55, 0x52, 0x41,
+0x3A, 0x20, 0x4E, 0x6F, 0x20, 0x45, 0x6E, 0x74,
+0x72, 0x79, 0x00, 0x00, 0x4D, 0x55, 0x41, 0x52,
+0x46, 0x52, 0x3A, 0x20, 0x4E, 0x6F, 0x20, 0x45,
+0x6E, 0x74, 0x72, 0x79, 0x00, 0x00, 0x00, 0x00,
+0x4D, 0x55, 0x52, 0x41, 0x3A, 0x20, 0x45, 0x6E,
+0x74, 0x72, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x49, 0x44, 0x3A,
+0x25, 0x62, 0x58, 0x20, 0x52, 0x49, 0x44, 0x3A,
+0x25, 0x62, 0x58, 0x20, 0x42, 0x57, 0x3A, 0x25,
+0x62, 0x58, 0x20, 0x53, 0x3A, 0x25, 0x62, 0x58,
+0x2C, 0x20, 0x56, 0x45, 0x3A, 0x25, 0x62, 0x58,
+0x00, 0x00, 0x00, 0x00, 0x49, 0x6C, 0x69, 0x4D,
+0x55, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x67, 0x69, 0x64, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x20, 0x75, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20,
+0x74, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x6F,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x64, 0x3A,
+0x25, 0x62, 0x78, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x50, 0x6F, 0x6C, 0x6C, 0x75, 0x74, 0x65, 0x64,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x69, 0x64, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x4D, 0x25, 0x62, 0x78,
+0x20, 0x47, 0x25, 0x62, 0x78, 0x20, 0x54, 0x74,
+0x25, 0x62, 0x78, 0x20, 0x4F, 0x6B, 0x25, 0x62,
+0x78, 0x20, 0x72, 0x74, 0x25, 0x62, 0x78, 0x20,
+0x62, 0x54, 0x25, 0x62, 0x78, 0x20, 0x4D, 0x32,
+0x53, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x49, 0x72, 0x61, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x46, 0x72, 0x61, 0x3A, 0x25, 0x62, 0x78, 0x00,
+0x4D, 0x25, 0x62, 0x78, 0x20, 0x47, 0x25, 0x62,
+0x78, 0x20, 0x52, 0x25, 0x62, 0x78, 0x20, 0x46,
+0x52, 0x25, 0x62, 0x78, 0x20, 0x72, 0x74, 0x25,
+0x62, 0x78, 0x20, 0x62, 0x54, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x52, 0x25, 0x62, 0x78,
+0x20, 0x44, 0x25, 0x62, 0x78, 0x20, 0x54, 0x74,
+0x25, 0x62, 0x78, 0x20, 0x4D, 0x32, 0x53, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x54, 0x52, 0x59, 0x25,
+0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x54, 0x52, 0x5F, 0x53, 0x3A, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x54, 0x52, 0x5F, 0x46, 0x3A, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x4D, 0x20, 0x4D, 0x25, 0x62, 0x78, 0x20, 0x72,
+0x74, 0x25, 0x62, 0x78, 0x20, 0x4F, 0x25, 0x62,
+0x78, 0x20, 0x54, 0x25, 0x62, 0x78, 0x20, 0x44,
+0x25, 0x62, 0x78, 0x00, 0x52, 0x30, 0x20, 0x25,
+0x77, 0x78, 0x20, 0x54, 0x54, 0x20, 0x25, 0x77,
+0x78, 0x00, 0x00, 0x00, 0x52, 0x74, 0x20, 0x25,
+0x77, 0x78, 0x2C, 0x54, 0x6F, 0x74, 0x41, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x53, 0x20, 0x4D, 0x25,
+0x62, 0x78, 0x20, 0x72, 0x74, 0x25, 0x62, 0x78,
+0x20, 0x4F, 0x25, 0x62, 0x78, 0x20, 0x44, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x52, 0x72, 0x20, 0x25,
+0x77, 0x78, 0x20, 0x54, 0x54, 0x20, 0x25, 0x77,
+0x78, 0x00, 0x00, 0x00, 0x25, 0x73, 0x3A, 0x20,
+0x50, 0x72, 0x65, 0x20, 0x73, 0x65, 0x74, 0x74,
+0x69, 0x6E, 0x67, 0x3A, 0x20, 0x64, 0x69, 0x73,
+0x61, 0x62, 0x6C, 0x65, 0x20, 0x4F, 0x46, 0x44,
+0x4D, 0x20, 0x61, 0x6E, 0x64, 0x20, 0x43, 0x43,
+0x4B, 0x20, 0x62, 0x6C, 0x6F, 0x63, 0x6B, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x25, 0x73, 0x3A, 0x20,
+0x50, 0x6F, 0x73, 0x74, 0x20, 0x73, 0x65, 0x74,
+0x74, 0x69, 0x6E, 0x67, 0x3A, 0x20, 0x65, 0x6E,
+0x61, 0x62, 0x6C, 0x65, 0x20, 0x4F, 0x46, 0x44,
+0x4D, 0x20, 0x61, 0x6E, 0x64, 0x20, 0x43, 0x43,
+0x4B, 0x20, 0x62, 0x6C, 0x6F, 0x63, 0x6B, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x25, 0x73, 0x3A, 0x20,
+0x57, 0x72, 0x6F, 0x6E, 0x67, 0x20, 0x74, 0x79,
+0x70, 0x65, 0x21, 0x21, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x77, 0x72, 0x69,
+0x74, 0x65, 0x5F, 0x74, 0x78, 0x61, 0x67, 0x63,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6C,
+0x65, 0x20, 0x50, 0x48, 0x59, 0x20, 0x41, 0x50,
+0x49, 0x20, 0x66, 0x6F, 0x72, 0x20, 0x64, 0x65,
+0x62, 0x75, 0x67, 0x21, 0x21, 0x0A, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x77, 0x72, 0x69,
+0x74, 0x65, 0x5F, 0x74, 0x78, 0x61, 0x67, 0x63,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x75, 0x6E, 0x73, 0x75, 0x70, 0x70,
+0x6F, 0x72, 0x74, 0x65, 0x64, 0x20, 0x70, 0x61,
+0x74, 0x68, 0x20, 0x28, 0x25, 0x64, 0x29, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x77, 0x72, 0x69, 0x74, 0x65, 0x5F, 0x74,
+0x78, 0x61, 0x67, 0x63, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x70, 0x61,
+0x74, 0x68, 0x2D, 0x25, 0x64, 0x20, 0x72, 0x61,
+0x74, 0x65, 0x20, 0x69, 0x6E, 0x64, 0x65, 0x78,
+0x20, 0x30, 0x78, 0x25, 0x78, 0x20, 0x28, 0x30,
+0x78, 0x25, 0x78, 0x29, 0x20, 0x3D, 0x20, 0x30,
+0x78, 0x25, 0x78, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x5B, 0x38, 0x38, 0x32, 0x32, 0x42, 0x5D, 0x20,
+0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x20, 0x52,
+0x46, 0x45, 0x20, 0x50, 0x49, 0x4E, 0x73, 0x3A,
+0x20, 0x43, 0x48, 0x3A, 0x25, 0x64, 0x2C, 0x20,
+0x54, 0x2F, 0x52, 0x58, 0x5F, 0x70, 0x61, 0x74,
+0x68, 0x3A, 0x7B, 0x20, 0x30, 0x78, 0x25, 0x78,
+0x2C, 0x20, 0x30, 0x78, 0x25, 0x78, 0x7D, 0x2C,
+0x20, 0x63, 0x75, 0x74, 0x5F, 0x76, 0x65, 0x72,
+0x3A, 0x25, 0x64, 0x2C, 0x20, 0x72, 0x66, 0x65,
+0x5F, 0x74, 0x79, 0x70, 0x65, 0x3A, 0x25, 0x64,
+0x0A, 0x00, 0x00, 0x00, 0x38, 0x38, 0x32, 0x32,
+0x42, 0x20, 0x52, 0x46, 0x45, 0x5F, 0x49, 0x6E,
+0x69, 0x74, 0x2C, 0x20, 0x52, 0x46, 0x45, 0x5F,
+0x74, 0x79, 0x70, 0x65, 0x3D, 0x28, 0x28, 0x25,
+0x64, 0x29, 0x29, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x38, 0x38, 0x32, 0x32, 0x42, 0x20, 0x52, 0x46,
+0x45, 0x5B, 0x25, 0x64, 0x5D, 0x3A, 0x7B, 0x50,
+0x61, 0x74, 0x68, 0x3D, 0x30, 0x78, 0x25, 0x78,
+0x7D, 0x7B, 0x69, 0x6E, 0x76, 0x5F, 0x65, 0x6E,
+0x3D, 0x25, 0x64, 0x7D, 0x7B, 0x73, 0x6F, 0x75,
+0x72, 0x63, 0x65, 0x3D, 0x30, 0x78, 0x25, 0x78,
+0x7D, 0x0A, 0x00, 0x00, 0x5B, 0x57, 0x61, 0x72,
+0x6E, 0x69, 0x6E, 0x67, 0x5D, 0x20, 0x57, 0x72,
+0x6F, 0x6E, 0x67, 0x20, 0x52, 0x46, 0x45, 0x20,
+0x6E, 0x75, 0x6D, 0x3D, 0x25, 0x64, 0x7D, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x72, 0x65, 0x61, 0x64, 0x5F, 0x72, 0x66,
+0x5F, 0x72, 0x65, 0x67, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x75, 0x6E,
+0x73, 0x75, 0x70, 0x70, 0x6F, 0x72, 0x74, 0x65,
+0x64, 0x20, 0x70, 0x61, 0x74, 0x68, 0x20, 0x28,
+0x25, 0x64, 0x29, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x72, 0x65, 0x61,
+0x64, 0x5F, 0x72, 0x66, 0x5F, 0x72, 0x65, 0x67,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x52, 0x46, 0x2D, 0x25, 0x64, 0x20,
+0x30, 0x78, 0x25, 0x78, 0x20, 0x3D, 0x20, 0x30,
+0x78, 0x25, 0x78, 0x2C, 0x20, 0x62, 0x69, 0x74,
+0x20, 0x6D, 0x61, 0x73, 0x6B, 0x20, 0x3D, 0x20,
+0x30, 0x78, 0x25, 0x78, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x77, 0x72, 0x69,
+0x74, 0x65, 0x5F, 0x72, 0x66, 0x5F, 0x72, 0x65,
+0x67, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x75, 0x6E, 0x73, 0x75, 0x70,
+0x70, 0x6F, 0x72, 0x74, 0x65, 0x64, 0x20, 0x70,
+0x61, 0x74, 0x68, 0x20, 0x28, 0x25, 0x64, 0x29,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x77, 0x72, 0x69, 0x74, 0x65, 0x5F, 0x72,
+0x66, 0x5F, 0x72, 0x65, 0x67, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x57,
+0x72, 0x69, 0x74, 0x65, 0x20, 0x66, 0x61, 0x69,
+0x6C, 0x2C, 0x20, 0x52, 0x46, 0x20, 0x69, 0x73,
+0x20, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6C, 0x65,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x77, 0x72, 0x69, 0x74, 0x65, 0x5F, 0x72,
+0x66, 0x5F, 0x72, 0x65, 0x67, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x52,
+0x46, 0x2D, 0x25, 0x64, 0x20, 0x30, 0x78, 0x25,
+0x78, 0x20, 0x3D, 0x20, 0x30, 0x78, 0x25, 0x78,
+0x20, 0x28, 0x6F, 0x72, 0x69, 0x67, 0x69, 0x6E,
+0x61, 0x6C, 0x3A, 0x20, 0x30, 0x78, 0x25, 0x78,
+0x29, 0x2C, 0x20, 0x62, 0x69, 0x74, 0x20, 0x6D,
+0x61, 0x73, 0x6B, 0x20, 0x3D, 0x20, 0x30, 0x78,
+0x25, 0x78, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3E, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6C,
+0x65, 0x20, 0x50, 0x48, 0x59, 0x20, 0x41, 0x50,
+0x49, 0x20, 0x66, 0x6F, 0x72, 0x20, 0x64, 0x65,
+0x62, 0x75, 0x67, 0x21, 0x21, 0x0A, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x46, 0x61, 0x69, 0x6C, 0x20, 0x74,
+0x6F, 0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68,
+0x20, 0x62, 0x61, 0x6E, 0x64, 0x20, 0x28, 0x63,
+0x68, 0x3A, 0x20, 0x25, 0x64, 0x29, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x46, 0x61, 0x69, 0x6C, 0x20, 0x74,
+0x6F, 0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68,
+0x20, 0x62, 0x61, 0x6E, 0x64, 0x20, 0x28, 0x63,
+0x68, 0x3A, 0x20, 0x25, 0x64, 0x29, 0x2C, 0x20,
+0x62, 0x65, 0x63, 0x61, 0x75, 0x73, 0x65, 0x20,
+0x77, 0x72, 0x69, 0x74, 0x69, 0x6E, 0x67, 0x20,
+0x52, 0x46, 0x20, 0x72, 0x65, 0x67, 0x69, 0x73,
+0x74, 0x65, 0x72, 0x20, 0x69, 0x73, 0x20, 0x66,
+0x61, 0x69, 0x6C, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x53, 0x75, 0x63, 0x63, 0x65, 0x73,
+0x73, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x20, 0x62, 0x61, 0x6E, 0x64,
+0x20, 0x28, 0x63, 0x68, 0x3A, 0x20, 0x25, 0x64,
+0x29, 0x0A, 0x00, 0x00, 0x25, 0x73, 0x3A, 0x20,
+0x55, 0x70, 0x64, 0x61, 0x74, 0x65, 0x20, 0x43,
+0x43, 0x41, 0x20, 0x70, 0x61, 0x72, 0x61, 0x6D,
+0x65, 0x74, 0x65, 0x72, 0x73, 0x20, 0x66, 0x6F,
+0x72, 0x20, 0x43, 0x63, 0x75, 0x74, 0x0A, 0x00,
+0x25, 0x73, 0x3A, 0x20, 0x28, 0x50, 0x6B, 0x74,
+0x25, 0x64, 0x2C, 0x20, 0x49, 0x6E, 0x74, 0x66,
+0x25, 0x64, 0x2C, 0x20, 0x52, 0x46, 0x45, 0x25,
+0x64, 0x29, 0x2C, 0x20, 0x63, 0x6F, 0x6C, 0x20,
+0x3D, 0x20, 0x25, 0x64, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3E, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x64,
+0x69, 0x73, 0x61, 0x62, 0x6C, 0x65, 0x20, 0x50,
+0x48, 0x59, 0x20, 0x41, 0x50, 0x49, 0x20, 0x66,
+0x6F, 0x72, 0x20, 0x64, 0x65, 0x62, 0x75, 0x67,
+0x21, 0x21, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x57, 0x72, 0x6F, 0x6E, 0x67,
+0x20, 0x54, 0x58, 0x20, 0x73, 0x65, 0x74, 0x74,
+0x69, 0x6E, 0x67, 0x20, 0x28, 0x54, 0x58, 0x3A,
+0x20, 0x30, 0x78, 0x25, 0x78, 0x29, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x57,
+0x72, 0x6F, 0x6E, 0x67, 0x20, 0x52, 0x58, 0x20,
+0x73, 0x65, 0x74, 0x74, 0x69, 0x6E, 0x67, 0x20,
+0x28, 0x52, 0x58, 0x3A, 0x20, 0x30, 0x78, 0x25,
+0x78, 0x29, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x46, 0x61, 0x69, 0x6C, 0x20,
+0x74, 0x6F, 0x20, 0x73, 0x65, 0x74, 0x20, 0x54,
+0x52, 0x78, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x20,
+0x73, 0x65, 0x74, 0x74, 0x69, 0x6E, 0x67, 0x2C,
+0x20, 0x62, 0x65, 0x63, 0x61, 0x75, 0x73, 0x65,
+0x20, 0x77, 0x72, 0x69, 0x74, 0x69, 0x6E, 0x67,
+0x20, 0x52, 0x46, 0x20, 0x6D, 0x6F, 0x64, 0x65,
+0x20, 0x74, 0x61, 0x62, 0x6C, 0x65, 0x20, 0x69,
+0x73, 0x20, 0x66, 0x61, 0x69, 0x6C, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x4D,
+0x50, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x20, 0x6F,
+0x72, 0x20, 0x41, 0x6E, 0x74, 0x65, 0x6E, 0x6E,
+0x61, 0x20, 0x74, 0x65, 0x73, 0x74, 0x20, 0x6D,
+0x6F, 0x64, 0x65, 0x21, 0x21, 0x20, 0x73, 0x75,
+0x70, 0x70, 0x6F, 0x72, 0x74, 0x20, 0x70, 0x61,
+0x74, 0x68, 0x2D, 0x42, 0x20, 0x54, 0x58, 0x20,
+0x61, 0x6E, 0x64, 0x20, 0x52, 0x58, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x4E,
+0x6F, 0x72, 0x6D, 0x61, 0x6C, 0x20, 0x6D, 0x6F,
+0x64, 0x65, 0x21, 0x21, 0x20, 0x44, 0x6F, 0x20,
+0x6E, 0x6F, 0x74, 0x20, 0x73, 0x75, 0x70, 0x70,
+0x6F, 0x72, 0x74, 0x20, 0x70, 0x61, 0x74, 0x68,
+0x2D, 0x42, 0x20, 0x54, 0x58, 0x20, 0x61, 0x6E,
+0x64, 0x20, 0x52, 0x58, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x46,
+0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73,
+0x65, 0x74, 0x20, 0x54, 0x52, 0x78, 0x20, 0x6D,
+0x6F, 0x64, 0x65, 0x20, 0x73, 0x65, 0x74, 0x74,
+0x69, 0x6E, 0x67, 0x20, 0x28, 0x54, 0x58, 0x3A,
+0x20, 0x30, 0x78, 0x25, 0x78, 0x2C, 0x20, 0x52,
+0x58, 0x3A, 0x20, 0x30, 0x78, 0x25, 0x78, 0x29,
+0x2C, 0x20, 0x62, 0x65, 0x63, 0x61, 0x75, 0x73,
+0x65, 0x20, 0x77, 0x72, 0x69, 0x74, 0x69, 0x6E,
+0x67, 0x20, 0x52, 0x46, 0x20, 0x72, 0x65, 0x67,
+0x69, 0x73, 0x74, 0x65, 0x72, 0x20, 0x69, 0x73,
+0x20, 0x66, 0x61, 0x69, 0x6C, 0x0A, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x53,
+0x75, 0x63, 0x63, 0x65, 0x73, 0x73, 0x20, 0x74,
+0x6F, 0x20, 0x73, 0x65, 0x74, 0x20, 0x54, 0x52,
+0x78, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x20, 0x73,
+0x65, 0x74, 0x74, 0x69, 0x6E, 0x67, 0x20, 0x28,
+0x54, 0x58, 0x3A, 0x20, 0x30, 0x78, 0x25, 0x78,
+0x2C, 0x20, 0x52, 0x58, 0x3A, 0x20, 0x30, 0x78,
+0x25, 0x78, 0x29, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x77, 0x69, 0x64, 0x74, 0x68, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3E, 0x0A, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x77, 0x69, 0x64, 0x74,
+0x68, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x64, 0x69, 0x73, 0x61, 0x62,
+0x6C, 0x65, 0x20, 0x50, 0x48, 0x59, 0x20, 0x41,
+0x50, 0x49, 0x20, 0x66, 0x6F, 0x72, 0x20, 0x64,
+0x65, 0x62, 0x75, 0x67, 0x21, 0x21, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x77, 0x69, 0x64, 0x74, 0x68, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x46,
+0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73,
+0x77, 0x69, 0x74, 0x63, 0x68, 0x20, 0x62, 0x61,
+0x6E, 0x64, 0x77, 0x69, 0x64, 0x74, 0x68, 0x20,
+0x28, 0x62, 0x77, 0x3A, 0x20, 0x25, 0x64, 0x2C,
+0x20, 0x70, 0x72, 0x69, 0x6D, 0x61, 0x72, 0x79,
+0x20, 0x63, 0x68, 0x3A, 0x20, 0x25, 0x64, 0x29,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x77, 0x69, 0x64, 0x74,
+0x68, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x46, 0x61, 0x69, 0x6C, 0x20,
+0x74, 0x6F, 0x20, 0x73, 0x77, 0x69, 0x74, 0x63,
+0x68, 0x20, 0x62, 0x61, 0x6E, 0x64, 0x77, 0x69,
+0x64, 0x74, 0x68, 0x20, 0x28, 0x62, 0x77, 0x3A,
+0x20, 0x25, 0x64, 0x2C, 0x20, 0x70, 0x72, 0x69,
+0x6D, 0x61, 0x72, 0x79, 0x20, 0x63, 0x68, 0x3A,
+0x20, 0x25, 0x64, 0x29, 0x2C, 0x20, 0x62, 0x65,
+0x63, 0x61, 0x75, 0x73, 0x65, 0x20, 0x77, 0x72,
+0x69, 0x74, 0x69, 0x6E, 0x67, 0x20, 0x52, 0x46,
+0x20, 0x72, 0x65, 0x67, 0x69, 0x73, 0x74, 0x65,
+0x72, 0x20, 0x69, 0x73, 0x20, 0x66, 0x61, 0x69,
+0x6C, 0x0A, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x77, 0x69, 0x64, 0x74,
+0x68, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x53, 0x75, 0x63, 0x63, 0x65,
+0x73, 0x73, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77,
+0x69, 0x74, 0x63, 0x68, 0x20, 0x62, 0x61, 0x6E,
+0x64, 0x77, 0x69, 0x64, 0x74, 0x68, 0x20, 0x28,
+0x62, 0x77, 0x3A, 0x20, 0x25, 0x64, 0x2C, 0x20,
+0x70, 0x72, 0x69, 0x6D, 0x61, 0x72, 0x79, 0x20,
+0x63, 0x68, 0x3A, 0x20, 0x25, 0x64, 0x29, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3E, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3A, 0x20, 0x64, 0x69, 0x73,
+0x61, 0x62, 0x6C, 0x65, 0x20, 0x50, 0x48, 0x59,
+0x20, 0x41, 0x50, 0x49, 0x20, 0x66, 0x6F, 0x72,
+0x20, 0x64, 0x65, 0x62, 0x75, 0x67, 0x21, 0x21,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3A,
+0x20, 0x46, 0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F,
+0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x20,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x20,
+0x28, 0x41, 0x47, 0x43, 0x29, 0x20, 0x28, 0x63,
+0x68, 0x3A, 0x20, 0x25, 0x64, 0x29, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3A, 0x20, 0x46, 0x61, 0x69,
+0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x20, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x20, 0x28, 0x66, 0x63, 0x5F,
+0x61, 0x72, 0x65, 0x61, 0x29, 0x20, 0x28, 0x63,
+0x68, 0x3A, 0x20, 0x25, 0x64, 0x29, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3A, 0x20, 0x46, 0x61, 0x69,
+0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x20, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x20, 0x28, 0x63, 0x68, 0x3A,
+0x20, 0x25, 0x64, 0x29, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3A, 0x20, 0x46, 0x61, 0x69,
+0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x20, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x20, 0x28, 0x63, 0x68, 0x3A,
+0x20, 0x25, 0x64, 0x2C, 0x20, 0x50, 0x68, 0x61,
+0x73, 0x65, 0x20, 0x6E, 0x6F, 0x69, 0x73, 0x65,
+0x29, 0x0A, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3A,
+0x20, 0x46, 0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F,
+0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x20,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x20,
+0x28, 0x63, 0x68, 0x3A, 0x20, 0x25, 0x64, 0x29,
+0x2C, 0x20, 0x62, 0x65, 0x63, 0x61, 0x75, 0x73,
+0x65, 0x20, 0x77, 0x72, 0x69, 0x74, 0x69, 0x6E,
+0x67, 0x20, 0x52, 0x46, 0x20, 0x72, 0x65, 0x67,
+0x69, 0x73, 0x74, 0x65, 0x72, 0x20, 0x69, 0x73,
+0x20, 0x66, 0x61, 0x69, 0x6C, 0x0A, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3A, 0x20, 0x53, 0x75, 0x63,
+0x63, 0x65, 0x73, 0x73, 0x20, 0x74, 0x6F, 0x20,
+0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x20, 0x63,
+0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x20, 0x28,
+0x63, 0x68, 0x3A, 0x20, 0x25, 0x64, 0x29, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x04, 0x04,
+0x08, 0x08, 0x08, 0x08, 0x0C, 0x0C, 0x0C, 0x0C,
+0x0C, 0x0C, 0x0C, 0x0C, 0x10, 0x10, 0x10, 0x10,
+0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10,
+0x10, 0x10, 0x10, 0x10, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x00, 0x00, 0x00, 0x00,
+0x06, 0x09, 0x0C, 0x12, 0x18, 0x24, 0x30, 0x36,
+0x01, 0x02, 0x05, 0x0B, 0x00, 0x00, 0x00, 0x00,
+0x0A, 0x08, 0x03, 0x03, 0x00, 0x04, 0x09, 0x07,
+0x03, 0x03, 0x00, 0x04, 0x08, 0x06, 0x03, 0x02,
+0x00, 0x04, 0x08, 0x05, 0x03, 0x01, 0x00, 0x04,
+0x0D, 0x0A, 0x07, 0x05, 0x00, 0x08, 0x0C, 0x0A,
+0x07, 0x04, 0x00, 0x08, 0x0B, 0x0A, 0x06, 0x05,
+0x00, 0x08, 0x0B, 0x0A, 0x05, 0x03, 0x00, 0x08,
+0x0B, 0x0A, 0x03, 0x02, 0x00, 0x08, 0x14, 0x12,
+0x0C, 0x04, 0x00, 0x10, 0x14, 0x12, 0x09, 0x04,
+0x00, 0x10, 0x24, 0x22, 0x1C, 0x12, 0x00, 0x20,
+0x24, 0x22, 0x18, 0x0C, 0x00, 0x20, 0x24, 0x22,
+0x14, 0x06, 0x00, 0x20, 0x24, 0x22, 0x0F, 0x04,
+0x00, 0x20, 0x24, 0x21, 0x0A, 0x04, 0x00, 0x20,
+0x23, 0x21, 0x0C, 0x04, 0x00, 0x20, 0x23, 0x1F,
+0x0A, 0x04, 0x00, 0x20, 0x22, 0x1F, 0x0F, 0x04,
+0x00, 0x20, 0x21, 0x1F, 0x16, 0x0C, 0x00, 0x20,
+0x31, 0x2F, 0x20, 0x14, 0x00, 0x30, 0x31, 0x2F,
+0x18, 0x10, 0x00, 0x30, 0x31, 0x2C, 0x18, 0x0C,
+0x00, 0x30, 0x31, 0x2A, 0x14, 0x0C, 0x00, 0x30,
+0x31, 0x28, 0x14, 0x00, 0x00, 0x30, 0x31, 0x24,
+0x14, 0x00, 0x00, 0x30, 0x31, 0x1E, 0x14, 0x00,
+0x00, 0x30, 0x31, 0x18, 0x0A, 0x00, 0x00, 0x30,
+0x15, 0xF0, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0x00,
+0x15, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x05, 0xF0, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0x00,
+0x05, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x10, 0xF0, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0x00,
+0x10, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xF5, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x0D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x15, 0xF0, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x15, 0xF0, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0xFF, 0xFF, 0xFF, 0x03, 0x00, 0x00,
+0x15, 0xF0, 0xFF, 0xFF, 0x0F, 0x00, 0x00, 0x00,
+0x01, 0x02, 0x03, 0x06, 0x05, 0x06, 0x07, 0x08,
+0x09, 0x0A, 0x0B, 0x2C, 0xFF, 0x00, 0x01, 0x02,
+0x02, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A,
+0x02, 0x02, 0x02, 0x04, 0x02, 0x04, 0x06, 0x06,
+0x08, 0x08, 0x09, 0x09, 0x03, 0x06, 0x08, 0x08,
+0x0A, 0x0E, 0x10, 0x18, 0x05, 0x08, 0x08, 0x08,
+0x0A, 0x0E, 0x10, 0x18, 0x05, 0x08, 0x08, 0x09,
+0x10, 0x14, 0x1C, 0x20, 0x04, 0x06, 0x08, 0x0A,
+0x10, 0x18, 0x18, 0x20, 0x03, 0x06, 0x08, 0x09,
+0x10, 0x14, 0x1C, 0x24, 0x34, 0x3A, 0x05, 0x07,
+0x09, 0x0A, 0x10, 0x14, 0x1C, 0x28, 0x34, 0x3C,
+0x06, 0x08, 0x0A, 0x0C, 0x12, 0x18, 0x1E, 0x2E,
+0x36, 0x40, 0x0A, 0x0C, 0x0C, 0x12, 0x16, 0x1C,
+0x20, 0x24, 0x24, 0x30, 0x01, 0x01, 0x01, 0x01,
+0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08,
+0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08,
+0x02, 0x04, 0x06, 0x07, 0x08, 0x0A, 0x0B, 0x0C,
+0x03, 0x05, 0x06, 0x07, 0x08, 0x0A, 0x0B, 0x0C,
+0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C,
+0x02, 0x04, 0x06, 0x07, 0x08, 0x09, 0x0B, 0x0C,
+0x0C, 0x0C, 0x03, 0x05, 0x06, 0x07, 0x08, 0x09,
+0x0B, 0x0C, 0x0C, 0x0C, 0x05, 0x06, 0x07, 0x08,
+0x09, 0x0A, 0x0B, 0x0C, 0x0C, 0x0C, 0x05, 0x06,
+0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0C, 0x0C,
+0x02, 0x04, 0x08, 0x10, 0x10, 0x14, 0x18, 0x1C,
+0x1C, 0x20, 0x20, 0x20, 0x10, 0x14, 0x18, 0x1C,
+0x1C, 0x20, 0x20, 0x20, 0x10, 0x14, 0x18, 0x1C,
+0x1C, 0x20, 0x20, 0x20, 0x10, 0x14, 0x18, 0x1C,
+0x1C, 0x20, 0x20, 0x20, 0x10, 0x14, 0x18, 0x1C,
+0x1C, 0x20, 0x20, 0x20, 0x10, 0x14, 0x18, 0x1C,
+0x1C, 0x20, 0x20, 0x20, 0x24, 0x28, 0x10, 0x14,
+0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20, 0x24, 0x28,
+0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20,
+0x24, 0x28, 0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20,
+0x20, 0x20, 0x24, 0x28, 0x2D, 0xFF, 0xFF, 0x2E,
+0x36, 0xFF, 0x37, 0x2F, 0xFF, 0x38, 0x30, 0x41,
+0x39, 0x31, 0x42, 0x42, 0x3A, 0x32, 0x43, 0x3A,
+0x33, 0x43, 0x3A, 0x34, 0x3A, 0x44, 0x35, 0x44,
+0x3B, 0xFF, 0x37, 0x2E, 0x40, 0x38, 0x30, 0x41,
+0x39, 0x42, 0x31, 0x3A, 0x42, 0x32, 0x3B, 0x43,
+0x35, 0x3C, 0x44, 0xFF, 0x3D, 0x45, 0xFF, 0x3E,
+0x45, 0xFF, 0x45, 0x3F, 0xFF, 0x46, 0xFF, 0xFF,
+0x37, 0x41, 0x2F, 0x39, 0x42, 0x31, 0x43, 0x3A,
+0x33, 0x44, 0x3B, 0x35, 0x45, 0x3D, 0xFF, 0x46,
+0x47, 0x3E, 0x47, 0xFF, 0xFF, 0x48, 0xFF, 0xFF,
+0x49, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x00,
+0x0D, 0xFF, 0xFF, 0x0E, 0x14, 0xFF, 0x15, 0x0F,
+0xFF, 0x16, 0x10, 0xFF, 0x17, 0x11, 0x1E, 0x1E,
+0x18, 0x12, 0x1F, 0x18, 0x13, 0x18, 0x1F, 0xFF,
+0x15, 0x0E, 0xFF, 0x16, 0x1D, 0x10, 0x17, 0x1E,
+0x10, 0x18, 0x1E, 0x11, 0x19, 0x1F, 0xFF, 0x1A,
+0x20, 0xFF, 0x21, 0x1B, 0xFF, 0x21, 0xFF, 0xFF,
+0x15, 0x13, 0x0F, 0x17, 0x1E, 0x11, 0x18, 0x1F,
+0x13, 0x20, 0x19, 0xFF, 0x21, 0x1B, 0xFF, 0x22,
+0xFF, 0xFF, 0x23, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
+0x04, 0x04, 0x04, 0x2C, 0xFF, 0xFF, 0x2D, 0x36,
+0xFF, 0x2E, 0x37, 0xFF, 0x2F, 0x38, 0x41, 0x30,
+0x39, 0x42, 0x43, 0x39, 0x31, 0x42, 0x39, 0x32,
+0x43, 0x3A, 0x33, 0x43, 0x3A, 0x34, 0x2D, 0x2C,
+0xFF, 0x36, 0x2E, 0xFF, 0x37, 0x2F, 0x40, 0x38,
+0x30, 0x41, 0x42, 0x33, 0x39, 0x43, 0x35, 0x3A,
+0x3B, 0x43, 0x34, 0x44, 0x3C, 0x3B, 0x45, 0x3D,
+0x3C, 0x45, 0x3E, 0x3D, 0x37, 0x2E, 0xFF, 0x38,
+0x2F, 0x40, 0x39, 0x31, 0x41, 0x3A, 0x42, 0xFF,
+0x43, 0x3B, 0xFF, 0x44, 0x3C, 0xFF, 0x45, 0x3D,
+0x3C, 0x46, 0x3F, 0x45, 0x47, 0x46, 0x45, 0x48,
+0x47, 0x47, 0x00, 0x00, 0x04, 0xFF, 0xFF, 0x0C,
+0xFF, 0xFF, 0x0D, 0x14, 0xFF, 0x0E, 0x15, 0xFF,
+0x0F, 0x16, 0xFF, 0x10, 0x17, 0xFF, 0x17, 0x11,
+0xFF, 0x17, 0x12, 0xFF, 0x0D, 0x0C, 0xFF, 0x14,
+0x0E, 0xFF, 0x15, 0x0F, 0xFF, 0x16, 0x1D, 0x10,
+0x17, 0x1E, 0x12, 0x18, 0x1F, 0x13, 0x19, 0x20,
+0x19, 0x20, 0x1A, 0x19, 0x14, 0x0E, 0xFF, 0x15,
+0x1C, 0xFF, 0x17, 0x1D, 0x11, 0x18, 0x1E, 0x13,
+0x19, 0x1F, 0x1E, 0x20, 0x1A, 0x1F, 0x21, 0x1B,
+0x20, 0x22, 0x21, 0x1B, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x24, 0x26, 0x2A,
+0x00, 0x00, 0x00, 0x1F, 0x21, 0x25, 0x27, 0x28,
+0x00, 0x00, 0x00, 0x00, 0x23, 0x26, 0x28, 0x30,
+0x00, 0x00, 0x00, 0x00, 0x23, 0x26, 0x28, 0x2A,
+0x00, 0x00, 0x00, 0x00, 0x23, 0x26, 0x28, 0x2A,
+0x00, 0x00, 0x00, 0x00, 0x24, 0x28, 0x2A, 0x2C,
+0x2E, 0x30, 0x00, 0x00, 0x00, 0x00, 0x26, 0x29,
+0x2B, 0x2D, 0x2F, 0x31, 0x00, 0x00, 0x00, 0x00,
+0x28, 0x2A, 0x2C, 0x2E, 0x30, 0x32, 0x00, 0x00,
+0x00, 0x1F, 0x23, 0x26, 0x28, 0x2A, 0x2A, 0x2A,
+0x04, 0x00, 0x04, 0x00, 0x08, 0x00, 0x10, 0x00,
+0x18, 0x00, 0x24, 0x00, 0x30, 0x00, 0x48, 0x00,
+0x60, 0x00, 0x90, 0x00, 0xC0, 0x00, 0xD8, 0x00,
+0x50, 0x00, 0x64, 0x00, 0x78, 0x00, 0xA0, 0x00,
+0xF0, 0x00, 0x40, 0x01, 0x90, 0x01, 0xE0, 0x01,
+0xC8, 0x00, 0xF0, 0x00, 0x40, 0x01, 0x90, 0x01,
+0x58, 0x02, 0x20, 0x03, 0xB0, 0x04, 0x40, 0x06,
+0xC8, 0x00, 0x18, 0x01, 0xE0, 0x01, 0xF4, 0x01,
+0x84, 0x03, 0x20, 0x03, 0xB0, 0x04, 0x40, 0x06,
+0xC8, 0x00, 0x18, 0x01, 0xE0, 0x01, 0xD0, 0x02,
+0x20, 0x03, 0xE8, 0x03, 0xB0, 0x04, 0x40, 0x06,
+0x3C, 0x00, 0x64, 0x00, 0x78, 0x00, 0xA0, 0x00,
+0xF0, 0x00, 0x40, 0x01, 0x90, 0x01, 0xE0, 0x01,
+0x58, 0x02, 0x20, 0x03, 0x78, 0x00, 0xF0, 0x00,
+0x68, 0x01, 0xA4, 0x01, 0xE0, 0x01, 0x1C, 0x02,
+0x58, 0x02, 0x20, 0x03, 0xE8, 0x03, 0xB0, 0x04,
+0xB4, 0x00, 0x2C, 0x01, 0xA4, 0x01, 0xE0, 0x01,
+0x1C, 0x02, 0x58, 0x02, 0x20, 0x03, 0xE8, 0x03,
+0xB0, 0x04, 0x78, 0x05, 0xC8, 0x00, 0x18, 0x01,
+0xE0, 0x01, 0xD0, 0x02, 0xE8, 0x03, 0xB0, 0x04,
+0x40, 0x06, 0xD0, 0x07, 0xD0, 0x07, 0xD0, 0x07,
+0x02, 0x00, 0x02, 0x00, 0x04, 0x00, 0x08, 0x00,
+0x0C, 0x00, 0x12, 0x00, 0x18, 0x00, 0x24, 0x00,
+0x30, 0x00, 0x48, 0x00, 0x60, 0x00, 0x6C, 0x00,
+0x28, 0x00, 0x32, 0x00, 0x3C, 0x00, 0x50, 0x00,
+0x78, 0x00, 0xA0, 0x00, 0xC8, 0x00, 0xF0, 0x00,
+0x64, 0x00, 0x78, 0x00, 0xA0, 0x00, 0xC8, 0x00,
+0x2C, 0x01, 0x90, 0x01, 0x58, 0x02, 0x20, 0x03,
+0x64, 0x00, 0x8C, 0x00, 0xF0, 0x00, 0xFA, 0x00,
+0xC2, 0x01, 0x90, 0x01, 0x58, 0x02, 0x20, 0x03,
+0x64, 0x00, 0x8C, 0x00, 0xF0, 0x00, 0x68, 0x01,
+0xF4, 0x01, 0x20, 0x03, 0xE8, 0x03, 0x78, 0x05,
+0x1E, 0x00, 0x32, 0x00, 0x3C, 0x00, 0x50, 0x00,
+0x78, 0x00, 0xA0, 0x00, 0xC8, 0x00, 0xF0, 0x00,
+0x2C, 0x01, 0x90, 0x01, 0x3C, 0x00, 0x78, 0x00,
+0xB4, 0x00, 0xD2, 0x00, 0xF0, 0x00, 0x0E, 0x01,
+0x2C, 0x01, 0x90, 0x01, 0xF4, 0x01, 0x58, 0x02,
+0x5A, 0x00, 0x96, 0x00, 0xD2, 0x00, 0xF0, 0x00,
+0x0E, 0x01, 0x2C, 0x01, 0x90, 0x01, 0xF4, 0x01,
+0x58, 0x02, 0xBC, 0x02, 0x64, 0x00, 0x8C, 0x00,
+0xF0, 0x00, 0x68, 0x01, 0xF4, 0x01, 0x58, 0x02,
+0x20, 0x03, 0xE8, 0x03, 0xE8, 0x03, 0xE8, 0x03,
+0x01, 0x00, 0x02, 0x00, 0x05, 0x00, 0x0B, 0x00,
+0x06, 0x00, 0x09, 0x00, 0x0C, 0x00, 0x12, 0x00,
+0x18, 0x00, 0x24, 0x00, 0x30, 0x00, 0x36, 0x00,
+0x0E, 0x00, 0x1B, 0x00, 0x29, 0x00, 0x36, 0x00,
+0x51, 0x00, 0x6C, 0x00, 0x7A, 0x00, 0x87, 0x00,
+0x1B, 0x00, 0x36, 0x00, 0x51, 0x00, 0x6C, 0x00,
+0xA2, 0x00, 0xD8, 0x00, 0xF3, 0x00, 0x0E, 0x01,
+0x29, 0x00, 0x51, 0x00, 0x7A, 0x00, 0xA2, 0x00,
+0xF3, 0x00, 0x44, 0x01, 0x6D, 0x01, 0x95, 0x01,
+0x36, 0x00, 0x6C, 0x00, 0xA2, 0x00, 0xD8, 0x00,
+0x44, 0x01, 0xB0, 0x01, 0xE6, 0x01, 0x1C, 0x02,
+0x0E, 0x00, 0x1B, 0x00, 0x29, 0x00, 0x36, 0x00,
+0x51, 0x00, 0x6C, 0x00, 0x7A, 0x00, 0x87, 0x00,
+0xA2, 0x00, 0xB4, 0x00, 0x1B, 0x00, 0x36, 0x00,
+0x51, 0x00, 0x6C, 0x00, 0xA2, 0x00, 0xD8, 0x00,
+0xF3, 0x00, 0xFF, 0x00, 0x23, 0x01, 0x44, 0x01,
+0x29, 0x00, 0x51, 0x00, 0x7A, 0x00, 0xA2, 0x00,
+0xF3, 0x00, 0x44, 0x01, 0x64, 0x01, 0x64, 0x01,
+0xB5, 0x01, 0xE6, 0x01, 0x36, 0x00, 0x6C, 0x00,
+0xA2, 0x00, 0xD8, 0x00, 0x44, 0x01, 0xB0, 0x01,
+0xE6, 0x01, 0x1C, 0x02, 0x88, 0x02, 0xD0, 0x02,
+0x14, 0x14, 0x15, 0x15, 0x16, 0x17, 0x17, 0x18,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1D, 0x1D, 0x1E, 0x1E,
+0x1C, 0x1C, 0x1D, 0x1E, 0x1F, 0x20, 0x20, 0x20,
+0x36, 0x36, 0x37, 0x37, 0x38, 0x39, 0x39, 0x3A,
+0x3A, 0x3A, 0x00, 0x00, 0x40, 0x40, 0x40, 0x40,
+0x41, 0x41, 0x42, 0x42, 0x43, 0x43, 0x00, 0x00,
+0x40, 0x40, 0x41, 0x42, 0x43, 0x44, 0x44, 0x44,
+0x45, 0x46, 0x00, 0x00, 0x00, 0xF0, 0x01, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0x01, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0x07, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0x07, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00,
+0x00, 0x00, 0x30, 0xC0, 0xE0, 0x00, 0x00, 0x00,
+0x00, 0x0C, 0x0E, 0x38, 0x18, 0x00, 0x00, 0x00,
+0x00, 0x83, 0x01, 0x06, 0x80, 0x03, 0x00, 0x00,
+0x00, 0x00, 0x70, 0xE0, 0x00, 0x00, 0x00, 0x00,
+0x61, 0x8F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x18, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x10, 0xF0, 0x20, 0x6A, 0x20, 0xF3, 0x0D, 0x4A,
+0x00, 0xEA, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x30, 0xF0, 0x21, 0x6C, 0x18, 0xF0, 0x00, 0x4C,
+0xBC, 0x65, 0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x94, 0xB8,
+0x00, 0x6D, 0xFE, 0xF7, 0x1F, 0x4D, 0xAC, 0xEC,
+0x94, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0xF4,
+0x00, 0x6D, 0xAD, 0xEC, 0x94, 0xB9, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF0, 0x00, 0x4C,
+0x00, 0x6E, 0x30, 0xF0, 0x20, 0x6F, 0x00, 0xF0,
+0x00, 0x4F, 0xC0, 0xDC, 0x04, 0x4C, 0xE3, 0xEC,
+0xB8, 0x67, 0xFB, 0x2D, 0x30, 0xF0, 0x20, 0x6C,
+0x25, 0xF6, 0x08, 0x4C, 0x00, 0x6E, 0x30, 0xF0,
+0x21, 0x6F, 0xB2, 0xF7, 0x10, 0x4F, 0xC0, 0xDC,
+0x04, 0x4C, 0xE3, 0xEC, 0xB8, 0x67, 0xFB, 0x2D,
+0x10, 0xF0, 0x20, 0x6C, 0x60, 0xF2, 0x15, 0x4C,
+0x00, 0xEC, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x60, 0xF2, 0x15, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x6D, 0x06, 0x00, 0x18,
+0x8C, 0x06, 0x00, 0x18, 0xDC, 0x08, 0x00, 0x18,
+0xAA, 0x06, 0x00, 0x18, 0xBC, 0x08, 0x00, 0x18,
+0x82, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x21, 0x6A, 0x60, 0xF0, 0x08, 0x4C, 0x15, 0xF0,
+0x00, 0x4A, 0x43, 0xDC, 0x00, 0x6D, 0x00, 0x18,
+0x3D, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x21, 0x6B, 0xE0, 0xF0, 0x08, 0x4C, 0x01, 0x6D,
+0xD1, 0xF6, 0x44, 0xDB, 0x00, 0x18, 0xF6, 0x0E,
+0x30, 0xF0, 0x21, 0x6B, 0xD1, 0xF6, 0x4C, 0xDB,
+0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0, 0x21, 0x6A,
+0xA0, 0xF0, 0x08, 0x4C, 0x15, 0xF4, 0x00, 0x4A,
+0x43, 0xDC, 0x00, 0x6D, 0x00, 0x18, 0x3D, 0x10,
+0x30, 0xF0, 0x21, 0x6B, 0xD1, 0xF6, 0x48, 0xDB,
+0x00, 0x18, 0x10, 0x09, 0x00, 0x18, 0x2E, 0x0A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x7C, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6C, 0x10, 0xF0, 0x00, 0x6D,
+0x40, 0xAB, 0xAB, 0xED, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xCB, 0x00, 0x18, 0x17, 0x0E,
+0x00, 0x18, 0x7C, 0x0C, 0xFF, 0x17, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x6D, 0xB8, 0x00, 0x65,
+0x00, 0xF0, 0x20, 0x6A, 0x7C, 0x4A, 0x6C, 0xEA,
+0x20, 0x22, 0x00, 0xF0, 0x20, 0x6B, 0x28, 0x4B,
+0x6A, 0xEA, 0x0F, 0x61, 0x30, 0xF0, 0x21, 0x6B,
+0x72, 0xF6, 0x04, 0x4B, 0x77, 0xF0, 0x24, 0x6A,
+0xA0, 0xF4, 0x04, 0x4A, 0x60, 0xDA, 0x30, 0xF0,
+0x21, 0x6A, 0x72, 0xF6, 0x04, 0x4A, 0x6A, 0xEA,
+0x31, 0x60, 0x77, 0xF0, 0x24, 0x6A, 0xA0, 0xF1,
+0x1C, 0x4A, 0x1D, 0xF4, 0x00, 0x6B, 0x60, 0xDA,
+0x10, 0xF0, 0x20, 0x6A, 0xA6, 0xF1, 0x01, 0x4A,
+0x00, 0xEA, 0x00, 0xF0, 0x20, 0x6A, 0x1F, 0xF7,
+0x00, 0x6A, 0x4C, 0xEB, 0x4C, 0xB8, 0x00, 0x65,
+0x6C, 0xEA, 0x42, 0x32, 0x30, 0xF0, 0x20, 0x6B,
+0xC4, 0xF6, 0x0C, 0x4B, 0x49, 0xE3, 0x40, 0xA2,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF0, 0x08, 0x4B,
+0x69, 0xE2, 0x30, 0xF0, 0x21, 0x6B, 0x72, 0xF6,
+0x00, 0x4B, 0x60, 0x9B, 0x05, 0x2B, 0x10, 0xF0,
+0x20, 0x6B, 0x20, 0xF5, 0x01, 0x4B, 0x00, 0xEB,
+0x10, 0xF0, 0x20, 0x6B, 0xA0, 0xF5, 0x15, 0x4B,
+0x00, 0xEB, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6B,
+0x01, 0x6B, 0x30, 0xF0, 0x21, 0x6A, 0x72, 0xF6,
+0x04, 0x4A, 0x60, 0xDA, 0x30, 0xF0, 0x21, 0x6A,
+0xB1, 0xF6, 0x10, 0x4A, 0x60, 0xDA, 0x10, 0xF0,
+0x20, 0x6B, 0xE0, 0xF3, 0x09, 0x4B, 0x00, 0xEB,
+0x5A, 0xB8, 0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65,
+0x40, 0xE8, 0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x30, 0xF0, 0x21, 0x6A, 0xB1, 0xF6,
+0x10, 0x4A, 0x00, 0xF0, 0x20, 0x6B, 0x60, 0xDA,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x08, 0x4A,
+0x60, 0x9A, 0x41, 0x9A, 0x6A, 0xEA, 0x0D, 0x61,
+0x6E, 0xB8, 0x00, 0x65, 0x62, 0x43, 0xCB, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x5A, 0xB8,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x00, 0xBA,
+0x00, 0x65, 0x36, 0x23, 0xDF, 0xF7, 0x00, 0x03,
+0x86, 0xDB, 0xA7, 0xDB, 0xC8, 0xDB, 0xE9, 0xDB,
+0x0A, 0xDB, 0x2B, 0xDB, 0x98, 0x67, 0x8C, 0xDB,
+0x9F, 0x67, 0x8E, 0xDB, 0x12, 0xEC, 0x10, 0xED,
+0x82, 0xDB, 0xA3, 0xDB, 0x9A, 0xB8, 0x00, 0x65,
+0x84, 0xDB, 0x9B, 0xB8, 0x00, 0x65, 0x85, 0xDB,
+0x8E, 0xB8, 0x00, 0x65, 0x82, 0x44, 0x81, 0xDB,
+0x8C, 0xB8, 0x00, 0x65, 0x80, 0xDB, 0x30, 0xF0,
+0x21, 0x6B, 0x11, 0xF7, 0x08, 0x4B, 0x60, 0x9B,
+0x9D, 0x67, 0x89, 0xDB, 0x6A, 0x9B, 0xCF, 0xF7,
+0x80, 0x44, 0x62, 0xEC, 0x0D, 0x60, 0x77, 0xF0,
+0x24, 0x6C, 0xA0, 0xF1, 0x1C, 0x4C, 0x1D, 0xF4,
+0x01, 0x6B, 0x60, 0xDC, 0x10, 0xF0, 0x20, 0x6C,
+0xA6, 0xF1, 0x01, 0x4C, 0x00, 0xEC, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6B, 0x11, 0xF7, 0x08, 0x4B,
+0x41, 0x9B, 0x40, 0xDB, 0x89, 0x9A, 0xBC, 0x65,
+0x7D, 0x67, 0xDF, 0xF7, 0x00, 0x03, 0x4C, 0xB8,
+0x00, 0x65, 0x00, 0xF0, 0x20, 0x6D, 0x05, 0x4D,
+0xAF, 0xED, 0xAC, 0xEA, 0xA0, 0x9B, 0x04, 0x6C,
+0x8C, 0xED, 0xAD, 0xEA, 0x82, 0x9B, 0xA3, 0x9B,
+0x32, 0xEC, 0x30, 0xED, 0x8E, 0x9B, 0xFC, 0x65,
+0x8C, 0x9B, 0x1C, 0x65, 0x84, 0x9B, 0x5C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x85, 0x9B,
+0x7C, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x2B, 0x9B, 0x0A, 0x9B, 0xE9, 0x9B, 0xC8, 0x9B,
+0xA7, 0x9B, 0x86, 0x9B, 0x61, 0x9B, 0xCB, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x7B, 0xB8,
+0x00, 0x65, 0x5A, 0xB8, 0x00, 0x65, 0x00, 0xBA,
+0xDF, 0xF7, 0x00, 0x03, 0x86, 0xDB, 0xA7, 0xDB,
+0xC8, 0xDB, 0xE9, 0xDB, 0x0A, 0xDB, 0x2B, 0xDB,
+0x98, 0x67, 0x8C, 0xDB, 0x9F, 0x67, 0x8E, 0xDB,
+0x12, 0xEC, 0x10, 0xED, 0x82, 0xDB, 0xA3, 0xDB,
+0x9A, 0xB8, 0x00, 0x65, 0x84, 0xDB, 0x9B, 0xB8,
+0x00, 0x65, 0x85, 0xDB, 0x7D, 0x67, 0x5B, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x40, 0x9A,
+0x30, 0xF0, 0x21, 0x6C, 0x52, 0xF2, 0x04, 0x4C,
+0x00, 0xF4, 0x00, 0x4C, 0xBC, 0x65, 0x82, 0x67,
+0x40, 0xEA, 0x00, 0x65, 0x7A, 0xB8, 0x00, 0x65,
+0xBB, 0x65, 0xDF, 0xF7, 0x00, 0x03, 0x82, 0x9B,
+0xA3, 0x9B, 0x32, 0xEC, 0x30, 0xED, 0x8E, 0x9B,
+0xFC, 0x65, 0x8C, 0x9B, 0x1C, 0x65, 0x84, 0x9B,
+0x5C, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x85, 0x9B, 0x7C, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x2B, 0x9B, 0x0A, 0x9B, 0xE9, 0x9B,
+0xC8, 0x9B, 0xA7, 0x9B, 0x86, 0x9B, 0x5A, 0xB8,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x00, 0xBA,
+0x00, 0x65, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6B,
+0xB1, 0xF6, 0x10, 0x4B, 0x40, 0xDB, 0xDF, 0xF7,
+0x00, 0x03, 0x86, 0xDB, 0xA7, 0xDB, 0xC8, 0xDB,
+0xE9, 0xDB, 0x0A, 0xDB, 0x2B, 0xDB, 0x98, 0x67,
+0x8C, 0xDB, 0x9F, 0x67, 0x8E, 0xDB, 0x12, 0xEC,
+0x10, 0xED, 0x82, 0xDB, 0xA3, 0xDB, 0x9A, 0xB8,
+0x00, 0x65, 0x84, 0xDB, 0x9B, 0xB8, 0x00, 0x65,
+0x85, 0xDB, 0x8E, 0xB8, 0x00, 0x65, 0x81, 0xDB,
+0x8C, 0xB8, 0x00, 0x65, 0x80, 0xDB, 0x30, 0xF0,
+0x21, 0x6B, 0x11, 0xF7, 0x08, 0x4B, 0x60, 0x9B,
+0x9D, 0x67, 0x89, 0xDB, 0x6A, 0x9B, 0xCF, 0xF7,
+0x80, 0x44, 0x62, 0xEC, 0x0D, 0x60, 0x77, 0xF0,
+0x24, 0x6C, 0xA0, 0xF1, 0x1C, 0x4C, 0x1D, 0xF4,
+0x01, 0x6B, 0x60, 0xDC, 0x10, 0xF0, 0x20, 0x6C,
+0xA6, 0xF1, 0x01, 0x4C, 0x00, 0xEC, 0x00, 0x65,
+0x40, 0x9A, 0x30, 0xF0, 0x21, 0x6C, 0x52, 0xF2,
+0x04, 0x4C, 0x00, 0xF4, 0x00, 0x4C, 0xBC, 0x65,
+0x82, 0x67, 0x40, 0xEA, 0x30, 0xF0, 0x21, 0x6C,
+0xB1, 0xF6, 0x10, 0x4C, 0x00, 0xF0, 0x20, 0x6D,
+0xA0, 0xDC, 0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7,
+0x08, 0x4A, 0x10, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x1D, 0x4B, 0x00, 0xEB, 0x61, 0x9A, 0x60, 0xDA,
+0x49, 0x9B, 0xBA, 0x65, 0xDF, 0xF7, 0x00, 0x03,
+0x4C, 0xB8, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6D,
+0x05, 0x4D, 0xAF, 0xED, 0xAC, 0xEA, 0xA0, 0x9B,
+0x00, 0xF0, 0x20, 0x6C, 0x04, 0x4C, 0x8C, 0xED,
+0xAD, 0xEA, 0x82, 0x9B, 0xA3, 0x9B, 0x32, 0xEC,
+0x30, 0xED, 0x8E, 0x9B, 0xFC, 0x65, 0x8C, 0x9B,
+0x1C, 0x65, 0x84, 0x9B, 0x5C, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x85, 0x9B, 0x7C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x2B, 0x9B,
+0x0A, 0x9B, 0xE9, 0x9B, 0xC8, 0x9B, 0xA7, 0x9B,
+0x86, 0x9B, 0x61, 0x9B, 0xCB, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x8A, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65,
+0x5A, 0xB8, 0x00, 0x65, 0x00, 0xBA, 0x00, 0x65,
+0x5F, 0x67, 0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x18, 0xCA, 0x00, 0x00, 0x18,
+0x2F, 0x0B, 0x5A, 0xB8, 0x00, 0x65, 0x00, 0xEA,
+0x6D, 0xB8, 0x00, 0xF0, 0x20, 0x6A, 0x00, 0xF2,
+0x00, 0x4A, 0x4F, 0xEA, 0x4C, 0xEB, 0xAB, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x5F, 0x67,
+0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x18, 0x41, 0x0B, 0x5A, 0xB8, 0x00, 0x65,
+0x00, 0xEA, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xE9, 0x01, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xE3, 0x01, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x0F, 0x02, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x9D, 0x02, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xAB, 0x02, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xDD, 0x01, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x15, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x80, 0xF7, 0x0D, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x05, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF4, 0x58, 0x9A, 0xA0, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0x5C, 0x9A,
+0x80, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4,
+0x40, 0x9A, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF4, 0x44, 0x9A, 0x40, 0x9A, 0x23, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4, 0x48, 0x9A,
+0xA0, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4,
+0x4C, 0x9A, 0x80, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF4, 0x50, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF4, 0x94, 0x9C, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x06, 0x4A, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0xA0, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0xA5, 0xF6, 0x74, 0x9A, 0x6C, 0x23,
+0x01, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xC7, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6,
+0x54, 0x9A, 0x02, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x24, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF6, 0x54, 0x9A, 0x04, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x0A, 0x28, 0x30, 0xF0,
+0x20, 0x6A, 0xA5, 0xF6, 0x54, 0x9A, 0x08, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xC8, 0x26,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6, 0x54, 0x9A,
+0x10, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xC9, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6,
+0x54, 0x9A, 0x20, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xCA, 0x26, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF6, 0x54, 0x9A, 0x40, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x02, 0x28, 0x30, 0xF0,
+0x20, 0x6A, 0xA5, 0xF6, 0x54, 0x9A, 0x80, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xFE, 0x27,
+0x30, 0xF0, 0x20, 0x6B, 0xA5, 0xF6, 0x74, 0x9B,
+0xFF, 0x6A, 0x01, 0x4A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xF4, 0x27, 0x30, 0xF0, 0x20, 0x6B,
+0xA5, 0xF6, 0x74, 0x9B, 0x04, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xCB, 0x26,
+0x30, 0xF0, 0x20, 0x6B, 0xA5, 0xF6, 0x74, 0x9B,
+0x08, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xCC, 0x26, 0x30, 0xF0, 0x20, 0x6B,
+0xA5, 0xF6, 0x74, 0x9B, 0x10, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xCD, 0x26,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6, 0x78, 0x9A,
+0x3C, 0x23, 0x01, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xDA, 0x27, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF6, 0x58, 0x9A, 0x02, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0xCE, 0x26, 0x30, 0xF0,
+0x20, 0x6B, 0xA5, 0xF6, 0x78, 0x9B, 0x04, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0xC3, 0x27, 0x30, 0xF0, 0x20, 0x6B,
+0xA5, 0xF6, 0x78, 0x9B, 0x08, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0xAA, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF0, 0x40, 0x9A, 0xA5, 0xF6,
+0x78, 0x9B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xD0, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF7, 0x54, 0x9A, 0xA5, 0xF6,
+0x78, 0x9B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xA6, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6,
+0x7C, 0x9A, 0x55, 0x23, 0x01, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0xC3, 0x27,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6, 0x5C, 0x9A,
+0x02, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0xAA, 0x27, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF6, 0x5C, 0x9A, 0x04, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0xC3, 0x27,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6, 0x5C, 0x9A,
+0x08, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C,
+0x00, 0x18, 0xAA, 0x27, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF6, 0x5C, 0x9A, 0x10, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0xC3, 0x27,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6, 0x5C, 0x9A,
+0x20, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0xAA, 0x27, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF6, 0x5C, 0x9A, 0x40, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0xC3, 0x27,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6, 0x5C, 0x9A,
+0x80, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0xAA, 0x27, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x1E, 0x4A, 0x40, 0xDB, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x20, 0x9A, 0x10, 0xF0, 0x20, 0x68,
+0x61, 0xF2, 0x15, 0x48, 0x00, 0xD9, 0x00, 0x18,
+0x70, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF6,
+0x44, 0x9A, 0x02, 0x22, 0x01, 0x48, 0x00, 0xD9,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xA1, 0xF2, 0x0D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x77, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0x65, 0xF6, 0x78, 0x9A, 0xE0, 0xF0,
+0x1B, 0x23, 0x08, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x09, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x65, 0xF6, 0x58, 0x9A, 0x02, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x51, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x65, 0xF6, 0x58, 0x9A,
+0x10, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x4D, 0x28, 0x30, 0xF0, 0x20, 0x6A, 0x65, 0xF6,
+0x58, 0x9A, 0x20, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x49, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x65, 0xF6, 0x58, 0x9A, 0x40, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0xB4, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0x65, 0xF6, 0x58, 0x9A, 0x80, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x1D, 0x2E,
+0x30, 0xF0, 0x20, 0x6B, 0x65, 0xF6, 0x78, 0x9B,
+0xFF, 0x6A, 0x01, 0x4A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x45, 0x28, 0x30, 0xF0, 0x20, 0x6B,
+0x65, 0xF6, 0x78, 0x9B, 0x00, 0xF2, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x41, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF4, 0x58, 0x9A, 0x65, 0xF6, 0x78, 0x9B,
+0x6C, 0xEA, 0x0D, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x40, 0x9A, 0x6C, 0xEA, 0x04, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0xE4, 0x26, 0x03, 0x10,
+0x00, 0x6C, 0x00, 0x18, 0xDB, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF4,
+0x5C, 0x9A, 0x65, 0xF6, 0x78, 0x9B, 0x6C, 0xEA,
+0x0D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x54, 0x9A, 0x6C, 0xEA, 0x04, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0xE4, 0x26, 0x03, 0x10, 0x01, 0x6C,
+0x00, 0x18, 0xDB, 0x26, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF4, 0x40, 0x9A,
+0x65, 0xF6, 0x78, 0x9B, 0x6C, 0xEA, 0x0D, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x58, 0x9A,
+0x6C, 0xEA, 0x04, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0xE4, 0x26, 0x03, 0x10, 0x02, 0x6C, 0x00, 0x18,
+0xDB, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF4, 0x44, 0x9A, 0x65, 0xF6,
+0x78, 0x9B, 0x6C, 0xEA, 0x0D, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF2, 0x50, 0x9A, 0x6C, 0xEA,
+0x04, 0x22, 0x03, 0x6C, 0x00, 0x18, 0xE4, 0x26,
+0x03, 0x10, 0x03, 0x6C, 0x00, 0x18, 0xDB, 0x26,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF4, 0x48, 0x9A, 0x65, 0xF6, 0x78, 0x9B,
+0x6C, 0xEA, 0x0D, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x6C, 0xEA, 0x04, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0xE4, 0x26, 0x03, 0x10,
+0x04, 0x6C, 0x00, 0x18, 0xDB, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF4,
+0x4C, 0x9A, 0x65, 0xF6, 0x78, 0x9B, 0x6C, 0xEA,
+0x0D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x58, 0x9A, 0x6C, 0xEA, 0x04, 0x22, 0x05, 0x6C,
+0x00, 0x18, 0xE4, 0x26, 0x03, 0x10, 0x05, 0x6C,
+0x00, 0x18, 0xDB, 0x26, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF4, 0x50, 0x9A,
+0x65, 0xF6, 0x78, 0x9B, 0x6C, 0xEA, 0x0D, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6, 0x40, 0x9A,
+0x6C, 0xEA, 0x04, 0x22, 0x06, 0x6C, 0x00, 0x18,
+0xE4, 0x26, 0x03, 0x10, 0x06, 0x6C, 0x00, 0x18,
+0xDB, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF4, 0x54, 0x9A, 0x65, 0xF6,
+0x78, 0x9B, 0x6C, 0xEA, 0x09, 0x22, 0x00, 0x53,
+0x04, 0x60, 0x07, 0x6C, 0x00, 0x18, 0xE4, 0x26,
+0x03, 0x10, 0x07, 0x6C, 0x00, 0x18, 0xDB, 0x26,
+0x30, 0xF0, 0x20, 0x6A, 0x65, 0xF6, 0x7C, 0x9A,
+0x80, 0xF0, 0x07, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF4, 0x58, 0x9A, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x7B, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF2,
+0x5C, 0x9A, 0x65, 0xF6, 0x7C, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0x7B, 0x27,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF2, 0x4C, 0x9A, 0x65, 0xF6, 0x7C, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x7B, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF0, 0x40, 0x9A, 0x65, 0xF6,
+0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x7B, 0x27, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x54, 0x9A,
+0x65, 0xF6, 0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0x7B, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6,
+0x50, 0x9A, 0x65, 0xF6, 0x7C, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x64, 0x27,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF6, 0x54, 0x9A, 0x65, 0xF6, 0x7C, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x28, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF6, 0x58, 0x9A, 0x65, 0xF6,
+0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x4A, 0x27, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF4, 0x54, 0x9A,
+0x65, 0xF6, 0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x12, 0x27, 0x30, 0xF0,
+0x20, 0x6B, 0x65, 0xF6, 0x7C, 0x9B, 0x08, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x3D, 0x28, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF6, 0x5C, 0x9A, 0x65, 0xF6,
+0x7C, 0x9B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xB6, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x8A, 0x9A, 0x7B, 0x24, 0x01, 0x6B,
+0x6C, 0xEC, 0x06, 0x24, 0x9F, 0x9A, 0x6D, 0xEC,
+0x9F, 0xDA, 0x00, 0x6C, 0x00, 0x18, 0x80, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6, 0x40, 0x9A,
+0x02, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x80, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x40, 0x9A, 0x04, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x80, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6, 0x40, 0x9A,
+0x08, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x80, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x40, 0x9A, 0x10, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x80, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6, 0x40, 0x9A,
+0x20, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x80, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x40, 0x9A, 0x40, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x80, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6, 0x40, 0x9A,
+0x80, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x80, 0x28, 0x30, 0xF0, 0x20, 0x6B,
+0x85, 0xF6, 0x60, 0x9B, 0xFF, 0x6A, 0x01, 0x4A,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x80, 0x28, 0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6,
+0x60, 0x9B, 0x00, 0xF2, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0x80, 0x28,
+0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6, 0x60, 0x9B,
+0x00, 0xF4, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x03, 0x6C, 0x00, 0x18, 0x80, 0x28, 0x30, 0xF0,
+0x20, 0x6B, 0x85, 0xF6, 0x60, 0x9B, 0x01, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x80, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x64, 0x9A, 0xA0, 0xF0, 0x13, 0x23,
+0x01, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x30, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x44, 0x9A, 0x02, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x30, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6, 0x44, 0x9A,
+0x04, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x30, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x44, 0x9A, 0x08, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x30, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6, 0x44, 0x9A,
+0x10, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x30, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x44, 0x9A, 0x20, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x30, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6, 0x44, 0x9A,
+0x40, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x30, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x44, 0x9A, 0x80, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x30, 0x28,
+0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6, 0x64, 0x9B,
+0xFF, 0x6A, 0x01, 0x4A, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0x30, 0x28, 0x30, 0xF0,
+0x20, 0x6B, 0x85, 0xF6, 0x64, 0x9B, 0x00, 0xF2,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C,
+0x00, 0x18, 0x30, 0x28, 0x30, 0xF0, 0x20, 0x6B,
+0x85, 0xF6, 0x64, 0x9B, 0x00, 0xF4, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C, 0x00, 0x18,
+0x30, 0x28, 0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6,
+0x64, 0x9B, 0x01, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0x30, 0x28,
+0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6, 0x64, 0x9B,
+0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x03, 0x06, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x54, 0x9A, 0x85, 0xF6, 0x64, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0x03, 0x06,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x58, 0x9A, 0x85, 0xF6, 0x64, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x03, 0x06, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF6, 0x40, 0x9A, 0x85, 0xF6,
+0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x03, 0x06, 0x30, 0xF0, 0x20, 0x6A,
+0x85, 0xF6, 0x44, 0x9A, 0x00, 0x52, 0x03, 0x60,
+0x04, 0x6C, 0x00, 0x18, 0x03, 0x06, 0x30, 0xF0,
+0x20, 0x6A, 0x85, 0xF6, 0x68, 0x9A, 0xC0, 0xF0,
+0x18, 0x23, 0x01, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0x64, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x85, 0xF6, 0x48, 0x9A, 0x02, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x28, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6,
+0x48, 0x9A, 0x04, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0x4A, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x85, 0xF6, 0x48, 0x9A, 0x08, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x12, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6,
+0x48, 0x9A, 0x10, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x64, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x85, 0xF6, 0x48, 0x9A, 0x20, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x28, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6,
+0x48, 0x9A, 0x40, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x4A, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x85, 0xF6, 0x48, 0x9A, 0x80, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x12, 0x27, 0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6,
+0x68, 0x9B, 0xFF, 0x6A, 0x01, 0x4A, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x64, 0x27,
+0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6, 0x68, 0x9B,
+0x00, 0xF2, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x03, 0x6C, 0x00, 0x18, 0x28, 0x27, 0x30, 0xF0,
+0x20, 0x6B, 0x85, 0xF6, 0x68, 0x9B, 0x00, 0xF4,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x4A, 0x27, 0x30, 0xF0, 0x20, 0x6B,
+0x85, 0xF6, 0x68, 0x9B, 0x01, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C, 0x00, 0x18,
+0x12, 0x27, 0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6,
+0x68, 0x9B, 0x02, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0x64, 0x27,
+0x30, 0xF0, 0x20, 0x6B, 0x85, 0xF6, 0x68, 0x9B,
+0x04, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0x28, 0x27, 0x30, 0xF0,
+0x20, 0x6B, 0x85, 0xF6, 0x68, 0x9B, 0x08, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x4A, 0x27, 0x30, 0xF0, 0x20, 0x6B,
+0x85, 0xF6, 0x68, 0x9B, 0x10, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0x12, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF6, 0x5C, 0x9A, 0x85, 0xF6,
+0x68, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0x09, 0x27, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6, 0x50, 0x9A,
+0x85, 0xF6, 0x68, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x09, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6,
+0x54, 0x9A, 0x85, 0xF6, 0x68, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x09, 0x27,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF6, 0x58, 0x9A, 0x85, 0xF6, 0x68, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0x09, 0x27, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xA1, 0xF2,
+0x0E, 0x4A, 0x40, 0xDB, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x4D, 0xB8, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0xF2, 0x00, 0x6B,
+0x6D, 0xEA, 0xAA, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x60, 0x9B, 0xFF, 0x6A, 0x8C, 0xEA,
+0x80, 0xA3, 0x10, 0x6B, 0x8C, 0xEB, 0x04, 0x23,
+0x7F, 0x4A, 0x07, 0x4A, 0x86, 0x6B, 0x31, 0x10,
+0x7F, 0x4A, 0x09, 0x4A, 0x88, 0x6B, 0x15, 0x10,
+0x1F, 0xF7, 0x00, 0x6C, 0x6C, 0xEC, 0x02, 0xF0,
+0x00, 0x74, 0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF7, 0x9C, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF7, 0x80, 0x9C,
+0xC0, 0xA5, 0x91, 0xE3, 0x01, 0x4D, 0xC0, 0xC4,
+0x01, 0x4B, 0x4A, 0xEB, 0xE9, 0x61, 0x20, 0xE8,
+0x1F, 0xF7, 0x00, 0x6C, 0x6C, 0xEC, 0x02, 0xF0,
+0x00, 0x74, 0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF7, 0x9C, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF7, 0x80, 0x9C,
+0xC0, 0xA5, 0x91, 0xE3, 0x01, 0x4D, 0xC0, 0xC4,
+0x01, 0x4B, 0x4A, 0xEB, 0xE9, 0x61, 0x20, 0xE8,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x00, 0xF1, 0xA6, 0xA2, 0x01, 0x6C,
+0x6C, 0xEC, 0x02, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB,
+0x8D, 0xEB, 0x00, 0xF1, 0x66, 0xC2, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xED, 0xFF, 0x75, 0x4C, 0xEC,
+0xCC, 0xEA, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x71, 0xE4, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x71, 0xE4, 0x43, 0xF3, 0x7F, 0xA4, 0xAC, 0xEA,
+0xAF, 0xED, 0x6C, 0xED, 0xAD, 0xEA, 0x43, 0xF3,
+0x5F, 0xC4, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0xFF, 0x74, 0xAC, 0xEA, 0x05, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0xA9, 0xF1, 0x55, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x43, 0xF3, 0xBD, 0xA3, 0x8C, 0xEA, 0x8F, 0xEC,
+0xAC, 0xEC, 0x8D, 0xEA, 0x43, 0xF3, 0x5D, 0xC3,
+0x20, 0xE8, 0x00, 0x65, 0xF7, 0x63, 0x11, 0x62,
+0x10, 0xD1, 0x0F, 0xD0, 0x40, 0xA4, 0x08, 0xD2,
+0x08, 0x93, 0x1F, 0x6A, 0x4C, 0xEB, 0x08, 0xD3,
+0x42, 0xA4, 0x61, 0xA4, 0x0D, 0xD2, 0x43, 0xA4,
+0x84, 0xA4, 0x09, 0xD4, 0x08, 0x94, 0x08, 0x5C,
+0x80, 0xF0, 0x0C, 0x60, 0x84, 0x31, 0x09, 0x94,
+0x01, 0x2C, 0x23, 0x22, 0xFF, 0x68, 0x0C, 0xEA,
+0x0C, 0xEB, 0xA2, 0x67, 0xC3, 0x67, 0x91, 0x67,
+0x0B, 0xD2, 0x0C, 0xD3, 0x00, 0x18, 0xBA, 0x04,
+0x09, 0x93, 0x0D, 0x94, 0x41, 0x41, 0x0C, 0xEA,
+0x0C, 0xEB, 0x8C, 0xE8, 0xA3, 0x67, 0x82, 0x67,
+0xD0, 0x67, 0x0A, 0xD2, 0x09, 0xD3, 0x00, 0x18,
+0xBA, 0x04, 0x0B, 0x95, 0x0C, 0x96, 0x91, 0x67,
+0x01, 0x6F, 0x00, 0x18, 0x0C, 0x06, 0x0A, 0x94,
+0x09, 0x95, 0xD0, 0x67, 0x02, 0x6F, 0x00, 0x18,
+0x0C, 0x06, 0x0F, 0x59, 0x08, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x28, 0x33, 0x60, 0xF5, 0x00, 0x4A,
+0x69, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x00, 0x6A,
+0x44, 0x10, 0xD0, 0xF4, 0x44, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x50, 0x9A, 0x34, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3, 0x54, 0x9A,
+0x2F, 0x10, 0x80, 0xF4, 0x44, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x58, 0x9A, 0x24, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3, 0x5C, 0x9A,
+0x1F, 0x10, 0xC0, 0xF4, 0x48, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF3, 0x40, 0x9A, 0x14, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x44, 0x9A,
+0x0F, 0x10, 0x70, 0xF4, 0x48, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF3, 0x48, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x4C, 0x9A,
+0x49, 0xE1, 0x60, 0xAA, 0xFF, 0xF7, 0x1F, 0x6A,
+0x6C, 0xEA, 0x7D, 0x67, 0x53, 0xC3, 0x42, 0x32,
+0x54, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x45, 0xE1, 0x43, 0xF3, 0x5F, 0xA1,
+0x55, 0xC3, 0x63, 0xF3, 0x40, 0xA1, 0x56, 0xC3,
+0x63, 0xF3, 0x4F, 0xA1, 0x57, 0xC3, 0x63, 0xF3,
+0x50, 0xA1, 0x58, 0xC3, 0x9D, 0x67, 0x21, 0x6A,
+0x50, 0xC4, 0x07, 0x6A, 0x4F, 0xCC, 0x47, 0x44,
+0x19, 0x4A, 0x40, 0xA2, 0x52, 0xC4, 0x04, 0x04,
+0x00, 0x18, 0xF3, 0x1F, 0x11, 0x97, 0x10, 0x91,
+0x0F, 0x90, 0x09, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x01, 0xA4, 0x20, 0xA4, 0x09, 0x20, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0xC7, 0x04, 0x90, 0x67,
+0xB1, 0x67, 0x53, 0x6E, 0x00, 0x18, 0x22, 0x2A,
+0x7D, 0x67, 0x20, 0x6A, 0x50, 0xC3, 0x03, 0x6A,
+0x4F, 0xCB, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x4C, 0x9A, 0x9D, 0x67, 0x40, 0xA2, 0x52, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x43, 0xF3, 0x7D, 0xA2, 0x43, 0xF3, 0x5E, 0xA2,
+0x73, 0xC4, 0x54, 0xC4, 0x04, 0x04, 0x00, 0x18,
+0xF3, 0x1F, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x40, 0xA4, 0xC0, 0xF0,
+0xC0, 0xA3, 0x7F, 0x68, 0x5E, 0x32, 0x5C, 0x32,
+0x0C, 0xEE, 0x4D, 0xEE, 0xC0, 0xF0, 0xC0, 0xC3,
+0xA0, 0xA4, 0x01, 0x6A, 0x41, 0x6F, 0xBA, 0x35,
+0x4C, 0xED, 0xEB, 0xEF, 0xB8, 0x35, 0xCC, 0xEF,
+0xAD, 0xEF, 0xC0, 0xF0, 0xE0, 0xC3, 0xA0, 0xA4,
+0x21, 0x6E, 0xCB, 0xEE, 0xB6, 0x35, 0x4C, 0xED,
+0xB4, 0x35, 0xEC, 0xEE, 0xAD, 0xEE, 0xC0, 0xF0,
+0xC0, 0xC3, 0xA0, 0xA4, 0x11, 0x6F, 0xEB, 0xEF,
+0xB2, 0x35, 0x4C, 0xED, 0xB0, 0x35, 0xCC, 0xEF,
+0xAD, 0xEF, 0xC0, 0xF0, 0xE0, 0xC3, 0xA0, 0xA4,
+0x10, 0x6E, 0x0F, 0x69, 0xCB, 0xEE, 0x2C, 0xED,
+0xEC, 0xEE, 0xAD, 0xEE, 0xC0, 0xF0, 0xC0, 0xC3,
+0xE1, 0xA4, 0xA7, 0x67, 0xC0, 0xF0, 0xE1, 0xA3,
+0x0C, 0xED, 0xFD, 0x65, 0x1F, 0x65, 0x80, 0x6D,
+0xF8, 0x67, 0xAB, 0xED, 0xEC, 0xED, 0xFF, 0x67,
+0xED, 0xED, 0xC0, 0xF0, 0xA1, 0xC3, 0xE2, 0xA4,
+0x0C, 0xED, 0xC0, 0xF0, 0xE2, 0xC3, 0xE1, 0xA4,
+0xFE, 0x37, 0xFC, 0x37, 0xED, 0xED, 0xC0, 0xF0,
+0xA1, 0xC3, 0xC0, 0xF0, 0xE3, 0xA3, 0x83, 0xA4,
+0x02, 0x6D, 0xAB, 0xED, 0x4C, 0xEC, 0xEC, 0xED,
+0x8D, 0xED, 0xC0, 0xF0, 0xA3, 0xC3, 0xC0, 0xF0,
+0xA0, 0xA3, 0x86, 0x67, 0x2C, 0xEC, 0xBA, 0x35,
+0x4E, 0xED, 0x4C, 0xED, 0x00, 0x18, 0xBB, 0x24,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0xA4, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6, 0x18, 0x48,
+0x45, 0xF7, 0x02, 0x4C, 0x07, 0x6E, 0x00, 0x18,
+0xA1, 0x1E, 0xE0, 0xF0, 0x8A, 0xA0, 0x00, 0x18,
+0x57, 0x26, 0x43, 0xF4, 0x54, 0xA0, 0x1F, 0x6B,
+0x01, 0x6C, 0x4A, 0x32, 0x6C, 0xEA, 0xE0, 0xF0,
+0x6A, 0xA0, 0x47, 0xEB, 0x8C, 0xEA, 0x03, 0x22,
+0x43, 0xF4, 0x75, 0xC0, 0x04, 0x10, 0x01, 0x6A,
+0x4B, 0xEA, 0x43, 0xF4, 0x55, 0xC0, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x43, 0xF4,
+0x74, 0xA0, 0x02, 0x6A, 0x6C, 0xEA, 0x1A, 0x22,
+0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x43, 0xF4,
+0x54, 0xC0, 0x00, 0x18, 0x4E, 0x2A, 0x04, 0xD2,
+0x04, 0x93, 0x43, 0xF4, 0x58, 0x98, 0x6E, 0xEA,
+0x03, 0x22, 0x04, 0x94, 0x00, 0x18, 0x6A, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x43, 0xF4, 0x94, 0xA2, 0x02, 0x6B, 0x8D, 0xEB,
+0x43, 0xF4, 0x74, 0xC2, 0x07, 0x97, 0x06, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xC0, 0xF0, 0xF5, 0xA2,
+0xA0, 0xA4, 0x02, 0x6B, 0x01, 0x6E, 0x6B, 0xEB,
+0xCC, 0xED, 0xEC, 0xEB, 0xAD, 0xEB, 0xC0, 0xF0,
+0x75, 0xC2, 0xA0, 0xA4, 0xA6, 0x35, 0xCC, 0xED,
+0xA4, 0x37, 0x03, 0x6D, 0xAB, 0xED, 0x6C, 0xED,
+0xED, 0xED, 0xC0, 0xF0, 0xB5, 0xC2, 0x60, 0xA4,
+0x6A, 0x33, 0xCC, 0xEB, 0x68, 0x37, 0x05, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0xED, 0xEB, 0xC0, 0xF0,
+0x75, 0xC2, 0xA0, 0xA4, 0xAE, 0x35, 0xCC, 0xED,
+0xAC, 0x36, 0x09, 0x6D, 0xAB, 0xED, 0x6C, 0xED,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7, 0x70, 0x9B,
+0xCD, 0xED, 0xC0, 0xF0, 0xB5, 0xC2, 0xA0, 0xA3,
+0x07, 0x6B, 0xFF, 0x6E, 0xAC, 0xEB, 0x0C, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF3, 0x70, 0x9B,
+0xA0, 0xA3, 0x61, 0xA4, 0xAC, 0xEE, 0x7B, 0xE6,
+0x03, 0xF4, 0xDD, 0xC2, 0x61, 0xA4, 0x14, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6, 0x64, 0x9B,
+0xA0, 0xA3, 0x61, 0xA4, 0xAC, 0xEE, 0x77, 0xE6,
+0x05, 0x6B, 0x7A, 0xED, 0x01, 0x2B, 0xE5, 0xE8,
+0x12, 0xED, 0x03, 0xF4, 0xBD, 0xC2, 0xA1, 0xA4,
+0x7B, 0xED, 0x01, 0x2B, 0xE5, 0xE8, 0x12, 0xEB,
+0x03, 0xF4, 0x7E, 0xC2, 0x00, 0xA4, 0x01, 0x69,
+0x2C, 0xE8, 0x0D, 0x28, 0x00, 0x18, 0x4C, 0x2F,
+0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18,
+0x22, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x5C, 0x9A, 0x00, 0xC2, 0x0D, 0x10, 0x01, 0x6C,
+0x0C, 0x6D, 0x00, 0x18, 0xB2, 0x12, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x03, 0xF4,
+0x7C, 0xA2, 0x6D, 0xE9, 0x03, 0xF4, 0x3C, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xC0, 0xF0, 0x95, 0xA2, 0x08, 0x6B, 0x8C, 0xEB,
+0x06, 0x2B, 0x03, 0xF4, 0x9C, 0xA2, 0x02, 0x6B,
+0x8D, 0xEB, 0x03, 0xF4, 0x7C, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xC0, 0xF0,
+0x95, 0xA2, 0x02, 0x6B, 0x8C, 0xEB, 0x1C, 0x23,
+0xC0, 0xF0, 0x87, 0xA2, 0x80, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x01, 0x6C, 0x8D, 0xEB, 0xA3, 0xF3,
+0x80, 0xA2, 0xC0, 0xF0, 0x67, 0xC2, 0x00, 0x6B,
+0xC0, 0xF0, 0x6B, 0xC2, 0x20, 0x6B, 0x8D, 0xEB,
+0xA3, 0xF3, 0xB5, 0xA2, 0xA3, 0xF3, 0x94, 0xA2,
+0xA3, 0xF3, 0xD9, 0xA2, 0xA3, 0xF3, 0x60, 0xC2,
+0x06, 0x6F, 0x00, 0x18, 0x3B, 0x13, 0x14, 0x10,
+0xC0, 0xF0, 0x87, 0xA2, 0x80, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xC0, 0xF0, 0x67, 0xC2, 0xA3, 0xF3,
+0x80, 0xA2, 0x0C, 0x6B, 0xC0, 0xF0, 0x6B, 0xC2,
+0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0x21, 0x6C,
+0x8B, 0xEC, 0x8C, 0xEB, 0xA3, 0xF3, 0x60, 0xC2,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0xC5, 0x15, 0x90, 0x67, 0x00, 0x18,
+0xA1, 0x2D, 0x01, 0x6C, 0x00, 0x18, 0x5D, 0x14,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x27, 0x67, 0x4C, 0xE9, 0x6F, 0x41,
+0x4C, 0xEB, 0x04, 0x67, 0x02, 0x5B, 0x4C, 0xE8,
+0x4C, 0xED, 0x4C, 0xEE, 0x03, 0x61, 0x90, 0x67,
+0x00, 0x18, 0x81, 0x29, 0x10, 0x58, 0x55, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x08, 0x33, 0xC0, 0xF5,
+0x18, 0x4A, 0x69, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0xD0, 0xF4, 0x44, 0x40, 0x1F, 0xF7, 0x00, 0x6B,
+0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF3, 0x70, 0x9A, 0x34, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x74, 0x9A, 0x2F, 0x10,
+0x80, 0xF4, 0x44, 0x40, 0x1F, 0xF7, 0x00, 0x6B,
+0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF3, 0x78, 0x9A, 0x24, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x7C, 0x9A, 0x1F, 0x10,
+0xC0, 0xF4, 0x48, 0x40, 0x1F, 0xF7, 0x00, 0x6B,
+0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x60, 0x9A, 0x14, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF3, 0x64, 0x9A, 0x0F, 0x10,
+0x70, 0xF4, 0x48, 0x40, 0x1F, 0xF7, 0x00, 0x6B,
+0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x68, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF3, 0x6C, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x6D, 0xE0,
+0x41, 0xE0, 0x43, 0xF3, 0x9F, 0xA0, 0x63, 0xF3,
+0x4F, 0xA0, 0x8D, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF1,
+0x34, 0xC2, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x30, 0xF0, 0x20, 0x6A, 0x10, 0xF0, 0x20, 0x6B,
+0x40, 0xF0, 0x08, 0x4A, 0x60, 0xF7, 0x05, 0x4B,
+0x62, 0xDA, 0x10, 0xF0, 0x20, 0x6B, 0x40, 0xF7,
+0x15, 0x4B, 0x63, 0xDA, 0x10, 0xF0, 0x20, 0x6B,
+0x40, 0xF7, 0x05, 0x4B, 0x64, 0xDA, 0x10, 0xF0,
+0x20, 0x6B, 0x20, 0xF7, 0x15, 0x4B, 0x65, 0xDA,
+0x10, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x05, 0x4B,
+0x66, 0xDA, 0x10, 0xF0, 0x20, 0x6B, 0x00, 0xF7,
+0x15, 0x4B, 0x67, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF1, 0x00, 0x4A,
+0x67, 0x42, 0x0C, 0x4B, 0x00, 0x6C, 0x80, 0xC2,
+0x01, 0x4A, 0x6A, 0xEA, 0xFB, 0x61, 0x42, 0xF4,
+0x10, 0x6A, 0x1F, 0xF7, 0x00, 0x6B, 0x4C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x05, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7, 0x7C, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7,
+0x60, 0x9B, 0x6D, 0xE2, 0x04, 0x4A, 0x00, 0x6C,
+0x62, 0xF4, 0x00, 0x72, 0x80, 0xDB, 0xE9, 0x61,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x58, 0x9A,
+0x03, 0x6D, 0xFF, 0x6B, 0x80, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x5C, 0x9A, 0x00, 0xF5,
+0x82, 0x34, 0xAC, 0xEC, 0x40, 0x9A, 0x01, 0x74,
+0x42, 0x32, 0x52, 0x32, 0xAC, 0xEA, 0x06, 0x60,
+0x0A, 0x2C, 0x02, 0x5A, 0x28, 0x6C, 0x0D, 0x60,
+0x50, 0x6C, 0x0B, 0x10, 0x02, 0x5A, 0x14, 0x6C,
+0x08, 0x60, 0x28, 0x6C, 0x04, 0x10, 0x02, 0x5A,
+0x0A, 0x6C, 0x03, 0x60, 0x14, 0x6C, 0x84, 0xEA,
+0x6C, 0xEC, 0x00, 0x18, 0xC5, 0x08, 0x00, 0x18,
+0x94, 0x1B, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7,
+0x70, 0x9B, 0x00, 0x6A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x6C, 0x9B,
+0x40, 0xC3, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0x00, 0x69, 0xA0, 0xF0, 0x24, 0xD8, 0x80, 0xF1,
+0x22, 0xC0, 0x00, 0x18, 0x48, 0x06, 0x00, 0xF1,
+0x66, 0xA0, 0x01, 0x6A, 0x6D, 0xEA, 0x00, 0xF1,
+0x46, 0xC0, 0x00, 0x18, 0x6A, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0x23, 0xF2,
+0x20, 0xC0, 0xA9, 0xF1, 0x17, 0x4A, 0xC9, 0xF1,
+0x07, 0x4C, 0x00, 0x6B, 0x60, 0xC2, 0x70, 0xC2,
+0x01, 0x4A, 0x62, 0x67, 0x8E, 0xEB, 0xF9, 0x2B,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x43, 0xF3, 0x7C, 0xC2, 0x43, 0xF3, 0x7D, 0xC2,
+0x43, 0xF3, 0x7E, 0xC2, 0x43, 0xF3, 0x7B, 0xC2,
+0x00, 0x18, 0xEC, 0x08, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x01, 0x68,
+0x00, 0x18, 0x5A, 0x06, 0x0B, 0xE8, 0x00, 0x18,
+0xD2, 0x06, 0x00, 0x18, 0xF2, 0x08, 0x00, 0x18,
+0xC5, 0x3B, 0x00, 0x18, 0x2E, 0x16, 0x00, 0x18,
+0x27, 0x16, 0x00, 0x18, 0x43, 0x19, 0x00, 0x18,
+0x79, 0x25, 0x00, 0x18, 0xB3, 0x2B, 0x00, 0x6A,
+0x10, 0xF0, 0x21, 0x6C, 0xF0, 0x67, 0x35, 0xF1,
+0x01, 0x4C, 0xA2, 0x67, 0x64, 0x6E, 0x04, 0xD2,
+0x00, 0x18, 0xCB, 0x2A, 0xD0, 0x67, 0x00, 0x6C,
+0x42, 0x6D, 0x00, 0x18, 0xD7, 0x28, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0xE0, 0x9B, 0xD0, 0x67,
+0x00, 0x6C, 0x4D, 0xEF, 0x42, 0x6D, 0x00, 0x18,
+0x34, 0x29, 0x10, 0xF0, 0x21, 0x6C, 0xF0, 0x67,
+0x99, 0xF2, 0x09, 0x4C, 0x00, 0x6D, 0x64, 0x6E,
+0x01, 0x6A, 0x04, 0xD2, 0x00, 0x18, 0xCB, 0x2A,
+0x00, 0x18, 0x9B, 0x2B, 0x07, 0x97, 0x06, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0x85, 0xF7, 0x17, 0x4C,
+0x00, 0x6D, 0x04, 0x6E, 0x00, 0x18, 0x9C, 0x1E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x00, 0x6B, 0x80, 0xF6, 0x64, 0xC2, 0x80, 0xF6,
+0x65, 0xC2, 0x80, 0xF1, 0x62, 0xC2, 0x80, 0xF1,
+0x63, 0xC2, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0x43, 0xF5, 0x59, 0xA0, 0x0B, 0x2A,
+0xE0, 0xF3, 0x1A, 0x6C, 0x04, 0x05, 0x00, 0x18,
+0x25, 0x30, 0x9D, 0x67, 0x70, 0xA4, 0x07, 0x6A,
+0x6C, 0xEA, 0x43, 0xF5, 0x59, 0xC0, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x43, 0xF5,
+0x5B, 0xA0, 0x0A, 0x2A, 0xE0, 0xF3, 0x1A, 0x6C,
+0x04, 0x05, 0x00, 0x18, 0x25, 0x30, 0x7D, 0x67,
+0x50, 0xA3, 0x56, 0x32, 0x43, 0xF5, 0x5B, 0xC0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0x43, 0xF5, 0x5C, 0xA0, 0x0B, 0x2A, 0xE0, 0xF3,
+0x1D, 0x6C, 0x04, 0x05, 0x00, 0x18, 0x25, 0x30,
+0x9D, 0x67, 0x70, 0xA4, 0x03, 0x6A, 0x6C, 0xEA,
+0x43, 0xF5, 0x5C, 0xC0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0x43, 0xF5, 0x5D, 0xA0,
+0x0C, 0x2A, 0xE0, 0xF3, 0x1D, 0x6C, 0x04, 0x05,
+0x00, 0x18, 0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3,
+0x30, 0x6B, 0x6C, 0xEA, 0x53, 0x32, 0x43, 0xF5,
+0x5D, 0xC0, 0x07, 0x97, 0x06, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x04, 0x01, 0x04, 0x67,
+0xB1, 0x67, 0xE0, 0xF3, 0x10, 0x6C, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x11, 0x6C, 0x40, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x12, 0x6C, 0x41, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x13, 0x6C, 0x42, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x1C, 0x6C, 0x43, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0x09, 0x97,
+0x08, 0x91, 0x44, 0xC0, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x04, 0x01, 0x04, 0x67,
+0xB1, 0x67, 0xE0, 0xF3, 0x14, 0x6C, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x15, 0x6C, 0x40, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x16, 0x6C, 0x41, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x17, 0x6C, 0x42, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x18, 0x6C, 0x43, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0xB1, 0x67,
+0xE0, 0xF3, 0x19, 0x6C, 0x44, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x7D, 0x67, 0x50, 0xA3, 0x09, 0x97,
+0x08, 0x91, 0x45, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x43, 0xF5, 0x7A, 0xA2,
+0x43, 0xF5, 0x9B, 0xA2, 0x6C, 0x33, 0x94, 0x34,
+0x8D, 0xEB, 0x43, 0xF5, 0x99, 0xA2, 0x8D, 0xEB,
+0x66, 0xC0, 0x43, 0xF5, 0x7C, 0xA2, 0x43, 0xF5,
+0x5D, 0xA2, 0x68, 0x33, 0x58, 0x32, 0x4D, 0xEB,
+0x33, 0x6A, 0x4D, 0xEB, 0x67, 0xC0, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD0, 0x04, 0x00, 0x90, 0x67, 0x00, 0x18,
+0x1B, 0x07, 0xA0, 0xF1, 0x02, 0x6A, 0x1F, 0xF7,
+0x00, 0x6B, 0x4C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x01, 0x60, 0x05, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF7, 0x7C, 0x9B, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF7, 0x60, 0x9B, 0x80, 0xA0,
+0x6D, 0xE2, 0x01, 0x4A, 0xA0, 0xF1, 0x0A, 0x72,
+0x80, 0xC3, 0x01, 0x48, 0xE8, 0x61, 0x04, 0x00,
+0x90, 0x67, 0x00, 0x18, 0x01, 0x07, 0xA0, 0xF1,
+0x0A, 0x6A, 0x1F, 0xF7, 0x00, 0x6B, 0x4C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x05, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7, 0x7C, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7,
+0x60, 0x9B, 0x80, 0xA0, 0x6D, 0xE2, 0x01, 0x4A,
+0xA0, 0xF1, 0x0F, 0x72, 0x80, 0xC3, 0x01, 0x48,
+0xE8, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x44, 0x9A, 0x19, 0x6B, 0x60, 0xC2, 0x09, 0x97,
+0x08, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0x43, 0xF5, 0x78, 0xA0, 0x01, 0x6A, 0x04, 0x01,
+0x6D, 0xEA, 0x02, 0x6B, 0x6D, 0xEA, 0x04, 0x6B,
+0x6D, 0xEA, 0x08, 0x6B, 0x6D, 0xEA, 0xE0, 0xF3,
+0x1B, 0x6C, 0xB1, 0x67, 0x43, 0xF5, 0x58, 0xC0,
+0x00, 0x18, 0x25, 0x30, 0x9D, 0x67, 0x70, 0xA4,
+0x07, 0x6A, 0xE0, 0xF3, 0x1D, 0x6C, 0x6C, 0xEA,
+0x43, 0xF5, 0x59, 0xC0, 0x18, 0x6A, 0x6C, 0xEA,
+0x4F, 0x32, 0x76, 0x33, 0xB1, 0x67, 0x43, 0xF5,
+0x7B, 0xC0, 0x43, 0xF5, 0x5A, 0xC0, 0x00, 0x18,
+0x25, 0x30, 0x5D, 0x67, 0x70, 0xA2, 0x0C, 0x6A,
+0x6C, 0xEA, 0x4B, 0x32, 0x7A, 0x33, 0x43, 0xF5,
+0x5C, 0xC0, 0x43, 0xF5, 0x7D, 0xC0, 0x00, 0x18,
+0xD9, 0x06, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x44, 0x9A, 0x60, 0xA2, 0xFF, 0x6A, 0x6C, 0xEA,
+0xFD, 0x72, 0x02, 0x61, 0x00, 0x18, 0x45, 0x07,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0x40, 0x9A, 0x01, 0x6B, 0x60, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x98, 0x9A, 0xFF, 0x6B, 0x20, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x8C, 0x9A, 0x08, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0x60, 0x9A,
+0xFD, 0x6A, 0xFF, 0x6C, 0xA0, 0xA3, 0xAC, 0xEA,
+0x40, 0xC3, 0x40, 0xA3, 0x01, 0x6D, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x52, 0x9B, 0x8D, 0xEA, 0x52, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF3, 0x64, 0x9B, 0x80, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x68, 0x9B,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0xB2, 0x9B, 0x8F, 0xEA,
+0xAC, 0xEA, 0x52, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x68, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0x44, 0x9A, 0x80, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x05, 0x5C, 0x5E, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x88, 0x34, 0x80, 0xF5,
+0x1C, 0x4A, 0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x58, 0x9B,
+0xAD, 0xEA, 0x45, 0xF6, 0x58, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF2, 0x74, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x6C, 0x9B,
+0x32, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x41, 0x9B, 0xAD, 0xEA, 0x41, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x70, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x74, 0x9B, 0x21, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x42, 0x9B, 0xAD, 0xEA,
+0x42, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x78, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x7C, 0x9B, 0x10, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x43, 0x9B,
+0xAD, 0xEA, 0x43, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF3, 0x60, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF3, 0x64, 0x9B, 0x40, 0xDB,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x44, 0x9B, 0xAD, 0xEA, 0x44, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x68, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x6C, 0x9B, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x05, 0x5C, 0x63, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0xA0, 0xF5, 0x10, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x98, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA,
+0x45, 0xF6, 0x58, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x6C, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF2, 0x54, 0x9A, 0x35, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x81, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x41, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x74, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3,
+0x50, 0x9A, 0x23, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x82, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x42, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x7C, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0x58, 0x9A, 0x11, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x83, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x43, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x64, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x40, 0x9A, 0xA0, 0xDA, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x84, 0x9B,
+0xAF, 0xEA, 0x8C, 0xEA, 0x44, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF3, 0x6C, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x48, 0x9A,
+0xA0, 0xDA, 0x20, 0xE8, 0x01, 0x74, 0x15, 0x60,
+0x03, 0x24, 0x02, 0x74, 0x23, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x54, 0x9B, 0xAD, 0xEA, 0x54, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF6, 0x60, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x70, 0x9B,
+0x21, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x55, 0x9B, 0xAD, 0xEA, 0x55, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x74, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x78, 0x9B, 0x10, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x56, 0x9B, 0xAD, 0xEA,
+0x56, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x7C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF3, 0x60, 0x9B, 0x40, 0xDB, 0x20, 0xE8,
+0x01, 0x74, 0x16, 0x60, 0x03, 0x24, 0x02, 0x74,
+0x25, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x94, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x54, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF3, 0x70, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x40, 0x9A, 0x23, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x95, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x55, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x78, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x54, 0x9A, 0x11, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x96, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x56, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF3, 0x60, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0x5C, 0x9A, 0xA0, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6C,
+0x81, 0xF3, 0x8C, 0x9C, 0x00, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x58, 0xDB, 0x45, 0xF6,
+0x18, 0x4B, 0x41, 0xDB, 0x42, 0xDB, 0x43, 0xDB,
+0x44, 0xDB, 0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C,
+0x81, 0xF3, 0x94, 0x9C, 0x40, 0xDC, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF3, 0x9C, 0x9C, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF3, 0x84, 0x9C,
+0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF3,
+0x8C, 0x9C, 0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C,
+0xA1, 0xF3, 0x90, 0x9C, 0x54, 0xDB, 0x55, 0xDB,
+0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF3,
+0x98, 0x9C, 0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C,
+0xC1, 0xF3, 0x80, 0x9C, 0x56, 0xDB, 0x40, 0xDC,
+0x52, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x68, 0x9B, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF2, 0x74, 0x9B,
+0x01, 0x6A, 0x4B, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF3, 0x70, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x78, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x60, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF3, 0x68, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF6, 0x60, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x74, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x7C, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x64, 0x9B, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0xA4, 0x9A,
+0x1F, 0xF4, 0x0E, 0x6E, 0x30, 0xF0, 0x20, 0x6B,
+0xCB, 0xEE, 0x45, 0xF6, 0xD8, 0xDB, 0xE1, 0xF7,
+0x1F, 0x6A, 0x45, 0xF6, 0x18, 0x4B, 0x00, 0x6C,
+0x42, 0xDB, 0x43, 0xDB, 0xA1, 0xDB, 0x84, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x6C, 0x9B,
+0xC0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x74, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x7C, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF3, 0x64, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x4C, 0x9A,
+0x80, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x00, 0x6B, 0x72, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0x48, 0x9A,
+0x60, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF3, 0x88, 0x9B, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xC6, 0x6D, 0xFF, 0x6B,
+0xB4, 0xDA, 0x95, 0xDA, 0x76, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0x50, 0x9A, 0xA0, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x58, 0x9A,
+0x80, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x40, 0x9A, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x59, 0x08,
+0x00, 0x18, 0x78, 0x08, 0x00, 0x18, 0x90, 0x08,
+0x00, 0x18, 0xAD, 0x08, 0x00, 0x18, 0xA7, 0x08,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x3C, 0x1E, 0x00, 0x18, 0x72, 0x1E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF1, 0x10, 0x9A, 0x00, 0x6D,
+0x02, 0xF0, 0x00, 0x6E, 0x90, 0x67, 0x00, 0x18,
+0x9C, 0x1E, 0x04, 0x6A, 0x40, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x54, 0x9A, 0x20, 0x48,
+0x0E, 0xEA, 0xF7, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x90, 0x9A, 0x00, 0x6D, 0x00, 0xF4,
+0x00, 0x6E, 0x00, 0x18, 0x9C, 0x1E, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x00, 0x09,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x02, 0xF6, 0x58, 0xC3, 0x00, 0x6A, 0x02, 0xF6,
+0x59, 0xC3, 0x00, 0x18, 0x9E, 0x07, 0x00, 0x18,
+0x3A, 0x09, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x4C, 0x9A, 0x3F, 0x6B, 0x60, 0xC2, 0x00, 0x18,
+0x8F, 0x07, 0x00, 0x18, 0x93, 0x07, 0x00, 0x18,
+0xCA, 0x08, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x00, 0x6B, 0x83, 0xF3, 0x74, 0xC2, 0x05, 0x6B,
+0x83, 0xF3, 0x7C, 0xCA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x5C, 0x9A,
+0xE0, 0xF1, 0x1B, 0x6B, 0x6B, 0xEB, 0x60, 0xCA,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x74, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF6, 0x9C, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x50, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6B, 0x40, 0xAA, 0x4C, 0xEB,
+0x62, 0x33, 0x07, 0x6A, 0x72, 0x33, 0x4C, 0xEB,
+0x02, 0x6A, 0x04, 0x23, 0x01, 0x73, 0x01, 0x6A,
+0x01, 0x60, 0x03, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x6C, 0x10, 0xF0,
+0x00, 0x6D, 0x00, 0x18, 0x66, 0x2E, 0x05, 0x97,
+0x01, 0x5A, 0x58, 0x67, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x44, 0xF4, 0x01, 0x4A, 0x40, 0xDB,
+0x00, 0x68, 0x2E, 0x10, 0x82, 0xF3, 0x08, 0x70,
+0x1A, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x70, 0x9A, 0x02, 0xF0, 0x00, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x44, 0x9A, 0x03, 0x6B,
+0x6B, 0xEB, 0x60, 0xC2, 0x15, 0x10, 0xFF, 0xF7,
+0x1F, 0x6A, 0x01, 0x48, 0x4C, 0xE8, 0x14, 0x6C,
+0x00, 0x18, 0x7D, 0x1E, 0x33, 0x58, 0x08, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x50, 0x9A,
+0x60, 0xA2, 0x08, 0x6A, 0x6C, 0xEA, 0x04, 0x2A,
+0x00, 0x18, 0x0A, 0x09, 0x01, 0x72, 0xCE, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x44, 0x9A,
+0x02, 0x6B, 0x6B, 0xEB, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x44, 0xF4, 0x02, 0x4A, 0x40, 0xDB,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF3, 0x74, 0x9A, 0x02, 0x6C, 0xFF, 0xF7,
+0x1F, 0x6D, 0x40, 0x9B, 0xFF, 0x6E, 0x41, 0x4E,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF7, 0x68, 0x9A, 0xE0, 0xF3, 0x1E, 0x4C,
+0x40, 0xAB, 0xAC, 0xEA, 0x8D, 0xEA, 0xAC, 0xEA,
+0x40, 0xCB, 0x02, 0x6C, 0x00, 0x18, 0x7E, 0x2E,
+0x0A, 0x6C, 0x00, 0x18, 0x7D, 0x1E, 0x00, 0x6C,
+0xC4, 0x67, 0x0C, 0xF0, 0x00, 0x6D, 0x00, 0x18,
+0x7E, 0x2E, 0x00, 0x6C, 0x01, 0xF0, 0x00, 0x6D,
+0x01, 0x6E, 0x00, 0x18, 0x7E, 0x2E, 0x10, 0xF0,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x6C, 0x00, 0x18,
+0x7E, 0x2E, 0x0A, 0x6C, 0x00, 0x18, 0x7D, 0x1E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xAA, 0x35, 0x01, 0x6A, 0x18, 0x10, 0xC0, 0x9C,
+0x1F, 0xF7, 0x00, 0x6B, 0xE1, 0x9C, 0xCC, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x05, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7, 0x7C, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7,
+0x60, 0x9B, 0x79, 0xE6, 0xFF, 0x6B, 0xEC, 0xEB,
+0x60, 0xC6, 0x02, 0x4A, 0x08, 0x4C, 0xA3, 0xEA,
+0xE6, 0x61, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF4, 0x54, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF7, 0x98, 0x9C, 0x60, 0x9A, 0x8C, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9A,
+0xC1, 0xF4, 0x98, 0x9C, 0x8C, 0xEB, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF4, 0x5C, 0x9A,
+0x11, 0x6C, 0x8B, 0xEC, 0x60, 0x9A, 0x8C, 0xEB,
+0x60, 0xDA, 0x60, 0x9A, 0x08, 0x6C, 0x8D, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF4,
+0x40, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF0,
+0x80, 0x9C, 0x60, 0x9A, 0x8D, 0xEB, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9A, 0xE1, 0xF4,
+0x84, 0x9C, 0x8C, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF4, 0x68, 0x9A, 0x03, 0x6C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF4, 0x4C, 0x9A, 0x77, 0x6B,
+0xE0, 0xF7, 0x1D, 0x4C, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF4, 0x70, 0x9A, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x70, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6C, 0x03, 0x6D, 0x40, 0xAB,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xCB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1, 0x64, 0x9B,
+0x07, 0x6A, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF4, 0x74, 0x9B, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF4, 0x74, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF4, 0x98, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x80, 0xF6, 0x9C, 0x9C, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF4, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF4, 0x9C, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF4, 0x7C, 0x9A, 0x05, 0x6C,
+0x8B, 0xEC, 0x40, 0x9B, 0x8C, 0xEA, 0x04, 0x6C,
+0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7, 0x68, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6C, 0x00, 0xF2, 0x00, 0x6D,
+0x40, 0xAB, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x48, 0x9A, 0x24, 0x6B, 0x6B, 0xEB, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF5, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF0, 0x98, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x64, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0xF6, 0x9C, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0x1F, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0, 0x90, 0x9B,
+0x03, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF1, 0x84, 0x9B, 0x07, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xC4, 0x01, 0xF5, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF5, 0x8C, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x70, 0x9A, 0xFC, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x64, 0x9A, 0xF8, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x68, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF5, 0x90, 0x9C, 0x40, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0xBC, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x03, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0xBC, 0x9A,
+0x01, 0xF0, 0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xAA, 0x35, 0x04, 0xD5, 0x04, 0x67, 0x01, 0x69,
+0x08, 0x10, 0x80, 0xA8, 0xC1, 0x98, 0x01, 0x6D,
+0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29, 0x02, 0x49,
+0x08, 0x48, 0x04, 0x92, 0x43, 0xE9, 0xF5, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xAA, 0x35, 0x04, 0xD5,
+0x04, 0x67, 0x01, 0x69, 0x08, 0x10, 0x80, 0xA8,
+0xC1, 0x98, 0x01, 0x6D, 0xAB, 0xED, 0x00, 0x18,
+0x0E, 0x29, 0x02, 0x49, 0x08, 0x48, 0x04, 0x92,
+0x43, 0xE9, 0xF5, 0x61, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xAA, 0x35, 0x24, 0x67, 0x04, 0xD5, 0x00, 0x68,
+0x14, 0x10, 0x08, 0x33, 0x6D, 0xE1, 0x60, 0x9B,
+0x48, 0x34, 0x91, 0xE1, 0xE1, 0xF7, 0x1E, 0x73,
+0xE0, 0x9C, 0x02, 0x61, 0x02, 0x67, 0x09, 0x10,
+0xFF, 0xF7, 0x1F, 0x6D, 0x01, 0x6E, 0x01, 0x6C,
+0x6C, 0xED, 0xCB, 0xEE, 0x00, 0x18, 0x34, 0x29,
+0x02, 0x48, 0x04, 0x93, 0x41, 0x40, 0x63, 0xEA,
+0xE8, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xAA, 0x35, 0x24, 0x67,
+0x04, 0xD5, 0x00, 0x68, 0x14, 0x10, 0x08, 0x33,
+0x6D, 0xE1, 0x60, 0x9B, 0x48, 0x34, 0x91, 0xE1,
+0xE1, 0xF7, 0x1E, 0x73, 0xE0, 0x9C, 0x02, 0x61,
+0x02, 0x67, 0x09, 0x10, 0xFF, 0xF7, 0x1F, 0x6D,
+0x01, 0x6E, 0x00, 0x6C, 0x6C, 0xED, 0xCB, 0xEE,
+0x00, 0x18, 0x34, 0x29, 0x02, 0x48, 0x04, 0x93,
+0x41, 0x40, 0x63, 0xEA, 0xE8, 0x61, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0xE0, 0xF3, 0x10, 0x6C,
+0x04, 0x05, 0x00, 0x18, 0x25, 0x30, 0x7D, 0x67,
+0x50, 0x83, 0x00, 0x52, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x40, 0x9A, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0xA5, 0x72, 0x10, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x44, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF5, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x40, 0x9A, 0x60, 0xDA, 0xF0, 0x17,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x40, 0x9A, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF0, 0x00, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0xEF, 0x9A, 0x40, 0xF6, 0x68, 0x9B,
+0xCE, 0x9A, 0xAD, 0x9A, 0x8C, 0x9A, 0xE0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x6C, 0x9B,
+0xC0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x70, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x74, 0x9B, 0x80, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x89, 0x9A, 0x40, 0xF6, 0x78, 0x9B,
+0x80, 0xDB, 0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x5C, 0x9A, 0x60, 0xDA, 0x00, 0x18,
+0x85, 0x1E, 0x00, 0x18, 0x7D, 0x0C, 0xFF, 0x17,
+0x71, 0xAC, 0x4A, 0x9C, 0x6A, 0x33, 0x68, 0x33,
+0x6D, 0xE2, 0x04, 0x6A, 0x6C, 0xEA, 0x01, 0x22,
+0xFC, 0x4B, 0x48, 0x43, 0xC8, 0x4A, 0xC2, 0x67,
+0x00, 0x6F, 0xE0, 0xDE, 0x04, 0x4E, 0x6A, 0xEE,
+0xFB, 0x61, 0x04, 0x6B, 0x60, 0xDA, 0xA1, 0xDA,
+0x67, 0x9C, 0x66, 0xDA, 0x40, 0x4A, 0x49, 0xDC,
+0xAB, 0xDC, 0x20, 0xE8, 0x49, 0x9C, 0x10, 0x4A,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x05, 0x67, 0x00, 0x18, 0x6B, 0x0A,
+0x00, 0xDA, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x05, 0x67, 0x26, 0x67,
+0x00, 0x18, 0x6B, 0x0A, 0x40, 0x9A, 0x00, 0xDA,
+0x21, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x60, 0xA4, 0xC2, 0xA5,
+0x41, 0x9C, 0x02, 0x10, 0x82, 0x67, 0x41, 0x9A,
+0x03, 0x22, 0xE2, 0xA2, 0xC3, 0xEF, 0xFA, 0x60,
+0xFF, 0x4B, 0xFF, 0x6E, 0xCC, 0xEB, 0x03, 0x5B,
+0x41, 0xDD, 0xA1, 0xDC, 0x04, 0x60, 0x01, 0x22,
+0xA2, 0xDA, 0x82, 0xDD, 0x20, 0xE8, 0x00, 0x6A,
+0x42, 0xDD, 0x20, 0xE8, 0x41, 0x9C, 0xFF, 0x6D,
+0x61, 0x9A, 0x61, 0xDC, 0x60, 0xA4, 0xFF, 0x4B,
+0xAC, 0xEB, 0x03, 0x5B, 0x08, 0x60, 0x61, 0x9A,
+0x03, 0x23, 0x82, 0xDB, 0x00, 0x6B, 0x61, 0xDA,
+0x00, 0x6B, 0x62, 0xDA, 0x20, 0xE8, 0x00, 0x6B,
+0x61, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x21, 0x6A,
+0xD1, 0xF6, 0x10, 0x4A, 0x61, 0x9A, 0x61, 0xDC,
+0x00, 0x6B, 0x62, 0xDC, 0x81, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x21, 0x6B, 0xD1, 0xF6, 0x10, 0x4B,
+0x30, 0xF0, 0x21, 0x6C, 0x41, 0x9B, 0x11, 0xF7,
+0x88, 0x9C, 0xA2, 0xA2, 0x82, 0xA4, 0xAE, 0xEC,
+0x02, 0x24, 0x00, 0x6A, 0x20, 0xE8, 0x81, 0x9A,
+0x81, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x21, 0x6B,
+0xF1, 0xF6, 0x04, 0x4B, 0xC3, 0x9B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEA, 0x00, 0x6D, 0x04, 0x26,
+0xA1, 0xAB, 0x0D, 0x10, 0xC3, 0x9B, 0x08, 0x2E,
+0x00, 0x6E, 0xAB, 0xE2, 0xC3, 0xDC, 0x83, 0xDB,
+0x64, 0xDC, 0x4A, 0xCB, 0xCA, 0xCC, 0x20, 0xE8,
+0x66, 0x67, 0xCA, 0xAE, 0xD5, 0xE5, 0x43, 0xED,
+0xF1, 0x61, 0xC3, 0x9B, 0xC3, 0xDC, 0x83, 0xDB,
+0xC3, 0x9C, 0x64, 0xDC, 0x01, 0x26, 0x84, 0xDE,
+0x4B, 0xE5, 0x4A, 0xCC, 0xAA, 0xAB, 0x4B, 0xE5,
+0x4A, 0xCB, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x21, 0x6A, 0xF1, 0xF6,
+0x04, 0x4A, 0x63, 0x9A, 0x3C, 0x23, 0x61, 0xAA,
+0xFF, 0x4B, 0x61, 0xCA, 0x30, 0x10, 0x42, 0x98,
+0x09, 0x22, 0x81, 0x98, 0x81, 0xDA, 0x41, 0x98,
+0x03, 0x22, 0x82, 0x98, 0x82, 0xDA, 0x61, 0xD8,
+0x00, 0x6A, 0x42, 0xD8, 0x30, 0xF0, 0x21, 0x6C,
+0xD1, 0xF6, 0x10, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x7B, 0x0A, 0x6A, 0xA8, 0x30, 0xF0, 0x21, 0x6A,
+0xF1, 0xF6, 0x66, 0xCA, 0x41, 0xA0, 0x04, 0x72,
+0x07, 0x61, 0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7,
+0x60, 0x9A, 0x4B, 0xA8, 0x49, 0xE3, 0x4A, 0xC8,
+0x01, 0x6A, 0x63, 0x98, 0x41, 0xC0, 0x30, 0xF0,
+0x21, 0x6A, 0xF1, 0xF6, 0x04, 0x4A, 0x63, 0xDA,
+0x63, 0x98, 0x03, 0x23, 0x44, 0xDB, 0x00, 0x6A,
+0x43, 0xD8, 0x00, 0x6A, 0x44, 0xD8, 0x30, 0xF0,
+0x21, 0x6A, 0xF1, 0xF6, 0x04, 0x4A, 0x61, 0xAA,
+0x02, 0x2B, 0x03, 0x9A, 0xC8, 0x28, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x42, 0x9C, 0x07, 0x22, 0x61, 0x9C, 0x61, 0xDA,
+0x41, 0x9C, 0x10, 0x22, 0x62, 0x9C, 0x62, 0xDA,
+0x20, 0xE8, 0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF6,
+0x10, 0x4A, 0x07, 0x10, 0x61, 0x9A, 0x8A, 0xEB,
+0x03, 0x61, 0x61, 0x9B, 0x61, 0xDA, 0x20, 0xE8,
+0x43, 0x67, 0xF8, 0x2A, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x02, 0x9C, 0x24, 0x67, 0x09, 0x28, 0x41, 0xA4,
+0x01, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x21, 0x68,
+0xD1, 0xF6, 0x10, 0x48, 0x03, 0x10, 0x02, 0x98,
+0x40, 0xA0, 0xFD, 0x22, 0x91, 0x67, 0x00, 0x18,
+0xD8, 0x0A, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x7B, 0x0A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x44, 0x9C, 0x10, 0x22,
+0x63, 0x9C, 0x63, 0xDA, 0x63, 0x9C, 0x09, 0x23,
+0x6A, 0xAA, 0xAA, 0xAC, 0x6D, 0xE5, 0x6A, 0xCA,
+0x63, 0x9C, 0x44, 0xDB, 0x00, 0x6A, 0x43, 0xDC,
+0x01, 0x10, 0x6A, 0xCA, 0x00, 0x6A, 0x44, 0xDC,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x21, 0x68,
+0x51, 0xF7, 0x00, 0x48, 0x09, 0xD5, 0x24, 0x67,
+0x83, 0xA0, 0xA2, 0x40, 0xD0, 0x67, 0x00, 0x18,
+0xF1, 0x11, 0x63, 0xA0, 0x63, 0xEA, 0x06, 0x60,
+0x4C, 0x32, 0x41, 0xE0, 0x21, 0xD8, 0x09, 0x92,
+0x42, 0xD8, 0x03, 0x10, 0x02, 0x6C, 0x00, 0x18,
+0x48, 0x0C, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF7, 0x40, 0x9A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x11, 0xF7, 0x88, 0x9B, 0x4B, 0xCC,
+0x30, 0xF0, 0x21, 0x6C, 0x11, 0xF7, 0x80, 0x9C,
+0x11, 0xF7, 0x68, 0x9B, 0x89, 0xE2, 0x4A, 0xCB,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x48, 0x9A,
+0x30, 0xF0, 0x21, 0x6B, 0x11, 0xF7, 0x80, 0x9B,
+0x6A, 0xAA, 0xFF, 0xF7, 0x1F, 0x6D, 0x93, 0xE3,
+0xAC, 0xEC, 0xAB, 0xAA, 0x6D, 0xE5, 0x6A, 0xCA,
+0x82, 0x32, 0x5E, 0x32, 0x03, 0x2A, 0x04, 0x6D,
+0x00, 0x18, 0x8B, 0x0B, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x03, 0x6D,
+0x00, 0x18, 0x8B, 0x0B, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x68, 0x9A,
+0x01, 0x6C, 0x81, 0xC3, 0x11, 0xF7, 0x88, 0x9A,
+0x00, 0x18, 0x91, 0x0A, 0x00, 0x18, 0x0E, 0x0B,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x60, 0x9A,
+0x01, 0x4B, 0x11, 0xF7, 0x60, 0xDA, 0x00, 0x18,
+0xB3, 0x0A, 0x30, 0xF0, 0x21, 0x6C, 0xD1, 0xF6,
+0x10, 0x4C, 0x00, 0x18, 0x87, 0x0A, 0x82, 0x67,
+0x00, 0x18, 0x70, 0x0B, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7,
+0x68, 0x9A, 0x01, 0x6C, 0x81, 0xC3, 0x11, 0xF7,
+0x88, 0x9A, 0x00, 0x18, 0x91, 0x0A, 0x30, 0xF0,
+0x21, 0x6A, 0x51, 0xF7, 0x01, 0xA2, 0x1A, 0x10,
+0x0C, 0x33, 0x69, 0xE2, 0x81, 0x9A, 0x60, 0xA4,
+0x04, 0x2B, 0xA4, 0xAA, 0x00, 0x18, 0x00, 0x11,
+0x02, 0x10, 0x00, 0x18, 0x9B, 0x10, 0x30, 0xF0,
+0x21, 0x6A, 0x51, 0xF7, 0x00, 0x4A, 0x83, 0xA2,
+0x01, 0x48, 0x0E, 0xEC, 0x8B, 0xEB, 0x8D, 0xEB,
+0xC0, 0xF7, 0x63, 0x33, 0x6C, 0xE8, 0x62, 0xA2,
+0xFF, 0x4B, 0x62, 0xC2, 0x30, 0xF0, 0x21, 0x6A,
+0x51, 0xF7, 0x00, 0x4A, 0x62, 0xA2, 0xE0, 0x2B,
+0x30, 0xF0, 0x21, 0x6C, 0x01, 0xC2, 0xD1, 0xF6,
+0x10, 0x4C, 0x00, 0x18, 0x87, 0x0A, 0x82, 0x67,
+0x00, 0x18, 0x70, 0x0B, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x8B, 0x04, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF2, 0x98, 0xAA, 0x30, 0xF0, 0x21, 0x6A,
+0x52, 0xF6, 0x04, 0x4A, 0x01, 0x6B, 0x07, 0x10,
+0xA0, 0x9A, 0x04, 0x4A, 0x03, 0x2D, 0xFF, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x01, 0x4B, 0x63, 0xEC,
+0xF7, 0x60, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x8C, 0xDA,
+0x02, 0x6A, 0x41, 0xC4, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x68, 0x9A,
+0x00, 0x6A, 0x01, 0x23, 0x43, 0xA3, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xFA, 0x11,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x00, 0x18, 0x96, 0x0A, 0x22, 0x67, 0x11, 0x22,
+0x30, 0xF0, 0x21, 0x68, 0x11, 0xF7, 0xA8, 0x98,
+0x30, 0xF0, 0x21, 0x6C, 0xD1, 0xF6, 0x10, 0x4C,
+0x00, 0x18, 0x7B, 0x0A, 0x11, 0xF7, 0x48, 0x98,
+0x01, 0x6B, 0x91, 0x67, 0x61, 0xC2, 0x00, 0x18,
+0x70, 0x0B, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A, 0xFF, 0x68,
+0x8C, 0xEA, 0xAC, 0xE8, 0x18, 0x22, 0xFF, 0xF7,
+0x1F, 0x72, 0x07, 0x60, 0x30, 0xF0, 0x21, 0x6B,
+0x11, 0xF7, 0x88, 0x9B, 0xA2, 0x67, 0x00, 0x18,
+0x9F, 0x0A, 0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7,
+0x48, 0x9A, 0x30, 0xF0, 0x21, 0x6C, 0xD1, 0xF6,
+0x10, 0x4C, 0x01, 0xC2, 0x00, 0x18, 0x87, 0x0A,
+0x82, 0x67, 0x00, 0x18, 0x70, 0x0B, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x08, 0x2C, 0x30, 0xF0, 0x21, 0x6C,
+0xD1, 0xF6, 0x10, 0x4C, 0x00, 0x18, 0x87, 0x0A,
+0x82, 0x67, 0x0F, 0x10, 0x30, 0xF0, 0x21, 0x69,
+0x11, 0xF7, 0x88, 0x99, 0x62, 0xA0, 0x42, 0xA4,
+0x63, 0xEA, 0x0A, 0x60, 0x00, 0x18, 0x91, 0x0A,
+0x11, 0xF7, 0x48, 0x99, 0x01, 0x6B, 0x90, 0x67,
+0x61, 0xC2, 0x00, 0x18, 0x70, 0x0B, 0x09, 0x10,
+0x01, 0x6A, 0x30, 0xF0, 0x21, 0x6C, 0x41, 0xC0,
+0xD1, 0xF6, 0x10, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x7B, 0x0A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x07, 0x22, 0x30, 0xF0, 0x21, 0x6B, 0x11, 0xF7,
+0x68, 0x9B, 0x63, 0xA3, 0x4E, 0xEB, 0x1F, 0x2B,
+0x30, 0xF0, 0x21, 0x69, 0x11, 0xF7, 0x48, 0x99,
+0x00, 0x6B, 0x61, 0xC2, 0x11, 0xF7, 0x08, 0x99,
+0x00, 0x18, 0x55, 0x0C, 0x49, 0xD8, 0x11, 0xF7,
+0x68, 0x99, 0x30, 0xF0, 0x21, 0x6A, 0x52, 0xF6,
+0x04, 0x4A, 0x83, 0xA3, 0xFF, 0x4C, 0x88, 0x34,
+0x51, 0xE4, 0x00, 0x6A, 0x40, 0xDC, 0x4A, 0xDB,
+0x82, 0x67, 0x11, 0xF7, 0x48, 0xD9, 0x00, 0x18,
+0x9E, 0x0B, 0x00, 0x6A, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF2, 0x78, 0xAB, 0x43, 0xEB,
+0x13, 0x61, 0x30, 0xF0, 0x21, 0x6B, 0x2F, 0x42,
+0x28, 0x31, 0x52, 0xF6, 0x04, 0x4B, 0x65, 0xE1,
+0x00, 0x99, 0x0A, 0x20, 0x90, 0x67, 0x00, 0x18,
+0xD8, 0x0A, 0x90, 0x67, 0x00, 0x18, 0xF3, 0x0A,
+0x00, 0x6A, 0x40, 0xD9, 0x4A, 0xD8, 0x01, 0x10,
+0xFF, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x30, 0xF0, 0x21, 0x6B,
+0x4C, 0xEC, 0xAC, 0xEA, 0xD1, 0xF6, 0xB4, 0x9B,
+0x01, 0x6B, 0x01, 0x25, 0x62, 0xA5, 0x17, 0x2C,
+0x30, 0xF0, 0x21, 0x6C, 0x11, 0xF7, 0x88, 0x9C,
+0x42, 0xC4, 0x63, 0xEA, 0x38, 0x60, 0x30, 0xF0,
+0x21, 0x68, 0x11, 0xF7, 0xA8, 0x98, 0x30, 0xF0,
+0x21, 0x6C, 0xD1, 0xF6, 0x10, 0x4C, 0x00, 0x18,
+0x7B, 0x0A, 0x11, 0xF7, 0x48, 0x98, 0x01, 0x6B,
+0x00, 0x6C, 0x61, 0xC2, 0x23, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x00, 0xF2, 0xB8, 0xAD, 0x83, 0xED,
+0x20, 0x61, 0x30, 0xF0, 0x21, 0x6D, 0xFF, 0x4C,
+0x88, 0x34, 0x52, 0xF6, 0x04, 0x4D, 0xB5, 0xE4,
+0x00, 0x9D, 0x17, 0x20, 0x42, 0xC0, 0x30, 0xF0,
+0x21, 0x6C, 0x11, 0xF7, 0x88, 0x9C, 0x0E, 0xEC,
+0xD8, 0x24, 0x90, 0x67, 0x00, 0x18, 0xE4, 0x0A,
+0x41, 0xA0, 0x01, 0x72, 0x0C, 0x61, 0x30, 0xF0,
+0x21, 0x6C, 0xD1, 0xF6, 0x10, 0x4C, 0x00, 0x18,
+0x87, 0x0A, 0x82, 0x67, 0x00, 0x18, 0x9E, 0x0B,
+0x02, 0x10, 0xFF, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x6A, 0x40, 0xC4,
+0x01, 0x6A, 0x41, 0xC4, 0x00, 0x6A, 0xA2, 0xC4,
+0x41, 0xDC, 0x42, 0xDC, 0x43, 0xDC, 0x44, 0xDC,
+0x4A, 0xCC, 0x4B, 0xCC, 0x4C, 0xCC, 0x4D, 0xCC,
+0x20, 0xF0, 0x40, 0xC4, 0xA6, 0x67, 0x00, 0x18,
+0x5E, 0x0A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF2, 0x98, 0xAA, 0x30, 0xF0,
+0x21, 0x6A, 0x52, 0xF6, 0x04, 0x4A, 0x00, 0x6B,
+0x04, 0x10, 0x00, 0x6D, 0xA0, 0xDA, 0x01, 0x4B,
+0x04, 0x4A, 0x83, 0xEB, 0xFA, 0x61, 0x30, 0xF0,
+0x21, 0x68, 0x01, 0x6A, 0x11, 0xF7, 0x10, 0x48,
+0x4B, 0xEA, 0x43, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF2, 0x48, 0xAA, 0x10, 0xF0, 0x20, 0x6E,
+0x90, 0x67, 0x51, 0xC8, 0x30, 0xF0, 0x21, 0x6A,
+0x52, 0xF1, 0x04, 0x4A, 0x00, 0x6D, 0x88, 0xF7,
+0x05, 0x4E, 0x4A, 0xD8, 0x00, 0x18, 0x04, 0x0C,
+0x30, 0xF0, 0x21, 0x6A, 0x04, 0x6C, 0x62, 0x67,
+0xD1, 0xF6, 0x90, 0xC2, 0xD1, 0xF6, 0x10, 0x4B,
+0x00, 0x6A, 0x41, 0xDB, 0x30, 0xF0, 0x21, 0x6B,
+0xF1, 0xF6, 0x84, 0xC3, 0xF1, 0xF6, 0x04, 0x4B,
+0x43, 0xDB, 0x44, 0xDB, 0x41, 0xCB, 0x30, 0xF0,
+0x21, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x11, 0xF7,
+0x08, 0xDA, 0x20, 0xF2, 0x6A, 0xA3, 0x02, 0x6A,
+0x41, 0xC0, 0x00, 0x6C, 0x30, 0xF0, 0x21, 0x6A,
+0x51, 0xF7, 0x80, 0xC2, 0x51, 0xF7, 0x00, 0x4A,
+0x81, 0xC2, 0x63, 0xC2, 0x00, 0x18, 0x0D, 0x0B,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x12, 0x24, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xE6, 0xF0, 0x11, 0x4A, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6, 0x44, 0x9A,
+0x1D, 0xF4, 0x02, 0x6B, 0x60, 0xDA, 0x00, 0x18,
+0x68, 0x0C, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x26, 0xF1, 0x01, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x44, 0x9A, 0x1D, 0xF4,
+0x03, 0x6B, 0x60, 0xDA, 0x00, 0x18, 0x68, 0x0C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xBC, 0x65, 0x20, 0xE8, 0x5D, 0x67, 0x20, 0xE8,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x80, 0x9C, 0x00, 0xF0, 0x20, 0x6B, 0x01, 0x4B,
+0x6D, 0xEC, 0x8C, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x20, 0xE8,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x4C, 0xB8, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6B,
+0x01, 0x4B, 0x6F, 0xEB, 0x6C, 0xEA, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x7B, 0xB8,
+0x00, 0x65, 0x20, 0xE8, 0x00, 0x65, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF0, 0x00, 0x4A,
+0x60, 0xDA, 0x81, 0xDA, 0xA2, 0xDA, 0xC3, 0xDA,
+0xE4, 0xDA, 0x05, 0xDA, 0x26, 0xDA, 0x78, 0x67,
+0x67, 0xDA, 0x7D, 0x67, 0x68, 0xDA, 0x7F, 0x67,
+0x69, 0xDA, 0x12, 0xEB, 0x6A, 0xDA, 0x10, 0xEB,
+0x6B, 0xDA, 0x6D, 0xB8, 0x00, 0x65, 0x6C, 0xDA,
+0x68, 0xB8, 0x00, 0x65, 0x6D, 0xDA, 0x6C, 0xB8,
+0x00, 0x65, 0x6E, 0xDA, 0x6E, 0xB8, 0x00, 0x65,
+0x6F, 0xDA, 0x10, 0xF0, 0x20, 0x6A, 0x05, 0xF1,
+0x09, 0x4A, 0x00, 0xEA, 0x00, 0x65, 0x00, 0x65,
+0x60, 0xBA, 0x20, 0xE8, 0x40, 0xBA, 0x20, 0xE8,
+0x4C, 0xB8, 0x00, 0x65, 0x80, 0x34, 0x8D, 0xEA,
+0x8A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x4C, 0xB8, 0x00, 0x65,
+0x80, 0x34, 0x8F, 0xEC, 0x8C, 0xEA, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x20, 0xE8,
+0x41, 0x44, 0x03, 0x2A, 0xFF, 0xF7, 0x1F, 0x6A,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x48, 0x9A, 0x83, 0xEA, 0x03, 0x60, 0xFF, 0xF7,
+0x1E, 0x6A, 0x20, 0xE8, 0xE0, 0xF3, 0x08, 0x6A,
+0x58, 0xEC, 0xFF, 0xF7, 0x1F, 0x6B, 0x12, 0xEA,
+0x3F, 0x4A, 0x5A, 0x32, 0x63, 0xEA, 0x02, 0x61,
+0xFF, 0xF7, 0x1E, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x06, 0x24, 0x03, 0x6A, 0x8C, 0xEA, 0x03, 0x2A,
+0x60, 0xA4, 0x44, 0x67, 0x01, 0x23, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x03, 0x6A, 0x8C, 0xEA,
+0x01, 0x5A, 0x58, 0x67, 0x4B, 0xEA, 0x8C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0x1D, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x6C, 0x9A, 0x08, 0x6E,
+0xFF, 0x6D, 0x80, 0xA3, 0x00, 0x6A, 0xCC, 0xEC,
+0x1A, 0x24, 0x80, 0xA3, 0xF7, 0x6A, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x50, 0x9A, 0x30, 0xF0, 0x21, 0x6C, 0x40, 0x9A,
+0x72, 0xF6, 0x48, 0xDC, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0x54, 0x9A, 0x72, 0xF6, 0x08, 0x4C,
+0x40, 0x9A, 0x41, 0xDC, 0x80, 0xA3, 0xAC, 0xEC,
+0xCD, 0xEC, 0xAC, 0xEC, 0x80, 0xC3, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6D,
+0x40, 0xF6, 0xA0, 0x9D, 0x10, 0xF0, 0x20, 0x6B,
+0xC6, 0xF2, 0x19, 0x4B, 0x60, 0xDD, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF6, 0x6C, 0x9B, 0x08, 0x6D,
+0xFF, 0x6A, 0xC0, 0xA3, 0x4C, 0xEC, 0xAC, 0xEE,
+0x25, 0x26, 0x05, 0x5C, 0x23, 0x60, 0x0C, 0x68,
+0x18, 0xEC, 0xE0, 0xA3, 0xF7, 0x6E, 0xEC, 0xEE,
+0xC0, 0xC3, 0x30, 0xF0, 0x20, 0x6E, 0x60, 0xF6,
+0xD0, 0x9E, 0xE0, 0x9E, 0x30, 0xF0, 0x21, 0x6E,
+0x72, 0xF6, 0x10, 0x4E, 0x12, 0xEC, 0x91, 0xE6,
+0x30, 0xF0, 0x20, 0x6E, 0x60, 0xF6, 0xD4, 0x9E,
+0xE1, 0xDC, 0xE0, 0xA4, 0xC0, 0x9E, 0xC2, 0xDC,
+0x01, 0x6E, 0xED, 0xEE, 0xC0, 0xC4, 0x80, 0xA3,
+0x4C, 0xEC, 0xAD, 0xEC, 0x4C, 0xEC, 0x80, 0xC3,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6A, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x46, 0xF3, 0x15, 0x4B,
+0x60, 0xDC, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6,
+0x6C, 0x9B, 0x08, 0x6C, 0xA0, 0xA3, 0xAC, 0xEC,
+0x2A, 0x24, 0x05, 0x5A, 0x28, 0x60, 0x0C, 0x6D,
+0xB8, 0xEA, 0x30, 0xF0, 0x21, 0x6C, 0x72, 0xF6,
+0x10, 0x4C, 0x12, 0xEA, 0x89, 0xE2, 0xA0, 0xA2,
+0x01, 0x6C, 0xAC, 0xEC, 0x1C, 0x24, 0xA0, 0xA3,
+0xF7, 0x6C, 0x08, 0x6E, 0xAC, 0xEC, 0x80, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6, 0x70, 0x9B,
+0x42, 0x9A, 0xA0, 0x9B, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF6, 0x74, 0x9B, 0xFF, 0x6D, 0x60, 0x9B,
+0x4B, 0xE3, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6,
+0x8C, 0x9B, 0x60, 0xA4, 0xAC, 0xEB, 0xCD, 0xEB,
+0xAC, 0xEB, 0x60, 0xC4, 0x20, 0xE8, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x8C, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6A, 0xC6, 0xF3, 0x15, 0x4A,
+0x05, 0x5B, 0x40, 0xDC, 0x00, 0x6A, 0x11, 0x60,
+0x0C, 0x6C, 0x98, 0xEB, 0x30, 0xF0, 0x21, 0x6A,
+0x72, 0xF6, 0x10, 0x4A, 0x12, 0xEB, 0x4D, 0xE3,
+0x80, 0xA3, 0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x00, 0x6A, 0x41, 0xDB, 0x42, 0xDB,
+0x01, 0x6A, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x06, 0xF4, 0x15, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x21, 0x6A, 0x72, 0xF6, 0x40, 0x9A, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x26, 0xF4, 0x11, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x96, 0x0C, 0x62, 0x67, 0x84, 0x6A, 0x02, 0x23,
+0x42, 0xA3, 0xFC, 0x4A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0x62,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0x46, 0xF4,
+0x1D, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x28, 0xF0, 0x09, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x82, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xE7, 0xF7,
+0x0D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0xFF, 0x17, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0xE8, 0x11,
+0x82, 0x6B, 0x18, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF6, 0x80, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0xA6, 0xF4, 0x0D, 0x4B, 0x60, 0xDC, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xA7, 0xF2,
+0x1D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0xE8, 0x11,
+0x03, 0x22, 0x01, 0x6A, 0x4B, 0xEA, 0x18, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xE6, 0xF4, 0x19, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x27, 0xF3, 0x11, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0xE8, 0x11,
+0x82, 0x6B, 0x18, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF6, 0x80, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0x46, 0xF5, 0x0D, 0x4B, 0x60, 0xDC, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x47, 0xF4,
+0x09, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0xE8, 0x11, 0x82, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x86, 0xF5, 0x19, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x67, 0xF4, 0x1D, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0xE8, 0x11, 0x82, 0x6B, 0x19, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xE6, 0xF5, 0x05, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0xA7, 0xF4, 0x1D, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x62, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x43, 0x67, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0xE8, 0x11,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x26, 0xF6,
+0x19, 0x4A, 0x40, 0xDB, 0x82, 0x6A, 0x0F, 0x10,
+0x90, 0x67, 0xB1, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x67, 0xF6, 0x01, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0xE8, 0x11,
+0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x58, 0x9A, 0x18, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF6, 0x80, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0x86, 0xF6, 0x09, 0x4B, 0x60, 0xDC, 0xB1, 0x67,
+0x90, 0x67, 0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6,
+0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0xC7, 0xF6, 0x11, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0xE8, 0x11, 0x84, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xE6, 0xF6, 0x01, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x26, 0xF4, 0x11, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0xE8, 0x11, 0x82, 0x6B, 0x19, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x26, 0xF7, 0x0D, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x67, 0xF7, 0x19, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x62, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x43, 0x67, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0xE8, 0x11, 0x82, 0x6B, 0x17, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x68, 0x86, 0xF7, 0x01, 0x48, 0x00, 0xDB,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xC7, 0xF7,
+0x09, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0xE8, 0x11, 0x82, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x80, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xC6, 0xF7, 0x09, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xE7, 0xF7, 0x0D, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0xE8, 0x11, 0x00, 0x6B,
+0x17, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0x07, 0xF0,
+0x15, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x28, 0xF0, 0x09, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0xE8, 0x11, 0x82, 0x6B,
+0x17, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0x47, 0xF0,
+0x1D, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x68, 0xF1, 0x05, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xA7, 0xF0,
+0x05, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0xE8, 0x11, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0xF5, 0x0C, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xC6, 0xF3,
+0x15, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xE7, 0xF0,
+0x15, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0xE8, 0x11, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0xD5, 0x0C, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x46, 0xF3,
+0x15, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x47, 0xF1,
+0x05, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0xE8, 0x11, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0xB6, 0x0C, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xC6, 0xF2,
+0x19, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x87, 0xF1,
+0x15, 0x4A, 0x40, 0xDB, 0x00, 0x18, 0xE8, 0x11,
+0x03, 0x22, 0x00, 0x18, 0x9F, 0x0C, 0x0D, 0x10,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x66, 0xF2,
+0x1D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC7, 0xF1, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x9B, 0x0C, 0x82, 0x67,
+0x0C, 0x22, 0x40, 0xA2, 0x02, 0x72, 0x09, 0x61,
+0x41, 0xAC, 0xFF, 0xF7, 0x1F, 0x72, 0x81, 0x6A,
+0x05, 0x60, 0x00, 0x18, 0xAB, 0x10, 0x00, 0x6A,
+0x01, 0x10, 0x80, 0x6A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x07, 0xF2,
+0x1D, 0x4A, 0x40, 0xDB, 0x04, 0x67, 0x00, 0x18,
+0xE8, 0x11, 0x04, 0x22, 0x90, 0x67, 0x00, 0x18,
+0x77, 0x0E, 0x0E, 0x10, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0xE7, 0xF2, 0x11, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x67, 0xF2, 0x09, 0x4A, 0x40, 0xDB,
+0x00, 0x18, 0xE8, 0x11, 0x05, 0x2A, 0x00, 0x18,
+0xE7, 0x11, 0x01, 0x6B, 0x4C, 0xEB, 0x05, 0x2B,
+0x30, 0xF0, 0x21, 0x6A, 0x72, 0xF6, 0x40, 0x9A,
+0x0D, 0x10, 0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6,
+0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0x06, 0xF4, 0x15, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xA7, 0xF2, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x9B, 0x0C, 0x08, 0x22,
+0x60, 0xA2, 0x02, 0x73, 0x05, 0x61, 0x82, 0x67,
+0x00, 0x18, 0xD4, 0x10, 0x00, 0x6A, 0x01, 0x10,
+0x80, 0x6A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xE7, 0xF2, 0x11, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x9B, 0x0C, 0x82, 0x67, 0x0C, 0x22, 0x40, 0xA2,
+0x02, 0x72, 0x09, 0x61, 0x41, 0xAC, 0xFF, 0xF7,
+0x1F, 0x72, 0x81, 0x6A, 0x05, 0x60, 0x00, 0x18,
+0xC6, 0x10, 0x00, 0x6A, 0x01, 0x10, 0x80, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x27, 0xF3, 0x11, 0x4A,
+0x40, 0xDB, 0x25, 0x67, 0x00, 0x18, 0x9B, 0x0C,
+0x02, 0x67, 0x12, 0x22, 0x40, 0xA2, 0x02, 0x72,
+0x0F, 0x61, 0x91, 0x67, 0x00, 0x18, 0x88, 0x0C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x90, 0x67, 0x4C, 0xED,
+0x00, 0x18, 0xB0, 0x10, 0x01, 0x72, 0x00, 0x6A,
+0x05, 0x60, 0x41, 0xA8, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x6A, 0x4B, 0xEA, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x87, 0xF3, 0x09, 0x4A, 0x40, 0xDB,
+0x02, 0x24, 0x00, 0x9C, 0x02, 0x28, 0x80, 0x6C,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x5C, 0x9A, 0x42, 0xED, 0x05, 0x61, 0x86, 0x6C,
+0x00, 0x18, 0x3C, 0x0C, 0x00, 0x6A, 0x07, 0x10,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED, 0x90, 0x67,
+0x00, 0x18, 0x98, 0x10, 0x50, 0x67, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0xE8, 0x11,
+0x00, 0x6B, 0x28, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xC7, 0xF3, 0x19, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0xE7, 0x11, 0x01, 0x6B, 0x4C, 0xEB, 0x0A, 0x2B,
+0x30, 0xF0, 0x21, 0x6B, 0x72, 0xF6, 0x60, 0x9B,
+0x05, 0x2B, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0xE2, 0x0E, 0x0F, 0x10, 0x90, 0x67, 0xB1, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x87, 0xF3,
+0x09, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x43, 0x67, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x47, 0xF4, 0x09, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x9B, 0x0C, 0x08, 0x22, 0x60, 0xA2, 0x03, 0x73,
+0x05, 0x61, 0x82, 0x67, 0x00, 0x18, 0xBB, 0x11,
+0x00, 0x6A, 0x01, 0x10, 0x80, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x67, 0xF4, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x9B, 0x0C, 0x0E, 0x22,
+0x60, 0xA2, 0x03, 0x73, 0x0B, 0x61, 0x82, 0x67,
+0x00, 0x18, 0x88, 0x11, 0xFF, 0x6B, 0x4E, 0xEB,
+0x01, 0x5B, 0x78, 0x67, 0x81, 0x6A, 0x6B, 0xEB,
+0x6C, 0xEA, 0x01, 0x10, 0x80, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xA7, 0xF4, 0x1D, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x9B, 0x0C, 0x02, 0x67, 0x13, 0x22,
+0x40, 0xA2, 0x03, 0x72, 0x10, 0x61, 0x91, 0x67,
+0x00, 0x18, 0x88, 0x0C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x90, 0x67, 0x4C, 0xED, 0x00, 0x18, 0x63, 0x11,
+0x01, 0x72, 0x00, 0x6A, 0x05, 0x61, 0xC1, 0x6A,
+0x03, 0x29, 0x81, 0x6A, 0x01, 0x10, 0x80, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x07, 0xF5,
+0x15, 0x4A, 0x40, 0xDB, 0x02, 0x24, 0x00, 0x9C,
+0x05, 0x28, 0x80, 0x6C, 0x00, 0x18, 0x3C, 0x0C,
+0x00, 0x6A, 0x04, 0x10, 0x90, 0x67, 0x00, 0x18,
+0x5E, 0x11, 0x50, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0xE8, 0x11,
+0x00, 0x6B, 0x26, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x47, 0xF5, 0x0D, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0xE7, 0x11, 0x01, 0x6B, 0x4C, 0xEB, 0x09, 0x2B,
+0x30, 0xF0, 0x21, 0x6B, 0x72, 0xF6, 0x60, 0x9B,
+0x04, 0x2B, 0x90, 0x67, 0x00, 0x18, 0x45, 0x0F,
+0x0E, 0x10, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x07, 0xF5, 0x15, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xA7, 0xF5, 0x15, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x96, 0x0C, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF6, 0x60, 0x9B, 0x2C, 0xEB,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x18, 0x9A, 0x07, 0x10, 0xA3, 0xA2, 0xFF, 0xF7,
+0x1F, 0x6C, 0x2C, 0xEC, 0x0C, 0xAA, 0x00, 0x18,
+0x1A, 0x11, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x07, 0xF6, 0x09, 0x4A,
+0x40, 0xDB, 0x04, 0x67, 0x25, 0x67, 0x00, 0x18,
+0xE8, 0x11, 0x05, 0x22, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0x6D, 0x0F, 0x0F, 0x10, 0x90, 0x67,
+0xB1, 0x67, 0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6,
+0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0x27, 0xF7, 0x05, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x67, 0xF6, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x60, 0x9A, 0x24, 0x67, 0x05, 0x67, 0x8C, 0xEB,
+0x86, 0x6A, 0x1D, 0x2B, 0x0A, 0x24, 0x85, 0x67,
+0x00, 0x18, 0x88, 0x0C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x91, 0x67, 0xAC, 0xEC, 0x01, 0x6E, 0x4C, 0xED,
+0x08, 0x10, 0x85, 0x67, 0x00, 0x18, 0x88, 0x0C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x85, 0x67, 0x00, 0x6E,
+0x4C, 0xED, 0x00, 0x18, 0x43, 0x11, 0x02, 0x72,
+0x08, 0x6A, 0x05, 0x60, 0x0B, 0xEA, 0x0D, 0xEA,
+0xC0, 0xF7, 0x42, 0x32, 0x58, 0x32, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC7, 0xF6, 0x11, 0x4A,
+0x40, 0xDB, 0x25, 0x67, 0x00, 0x18, 0x96, 0x0C,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x60, 0x9B, 0x2C, 0xEB, 0x05, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x18, 0x9A, 0x07, 0x10,
+0xA3, 0xA2, 0xFF, 0xF7, 0x1F, 0x6C, 0x2C, 0xEC,
+0x0C, 0xAA, 0x00, 0x18, 0xF3, 0x10, 0x50, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x27, 0xF7, 0x05, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x96, 0x0C, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF6, 0x60, 0x9B, 0x2C, 0xEB,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x18, 0x9A, 0x07, 0x10, 0xA3, 0xA2, 0xFF, 0xF7,
+0x1F, 0x6C, 0x2C, 0xEC, 0x0C, 0xAA, 0x00, 0x18,
+0x26, 0x11, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x67, 0xF7, 0x19, 0x4A, 0x40, 0xDB,
+0x05, 0x67, 0x00, 0x18, 0x96, 0x0C, 0x80, 0x6B,
+0x11, 0x22, 0x63, 0x40, 0x07, 0x5B, 0x86, 0x6B,
+0x0D, 0x60, 0x83, 0xA2, 0xA4, 0x40, 0xFF, 0x6A,
+0x4C, 0xED, 0x00, 0x18, 0xDB, 0x0B, 0xFF, 0x6B,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x81, 0x6B,
+0x4B, 0xEA, 0x4C, 0xEB, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xC7, 0xF7, 0x09, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x7C, 0x0B, 0x05, 0x97, 0x00, 0x6A, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xE7, 0xF7, 0x0D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x96, 0x0C, 0x80, 0x6B,
+0x0A, 0x22, 0x83, 0xA2, 0x00, 0x18, 0xB5, 0x0B,
+0xFF, 0x6B, 0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67,
+0x81, 0x6B, 0x4B, 0xEA, 0x4C, 0xEB, 0x05, 0x97,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x28, 0xF0, 0x09, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x74, 0x0B, 0x82, 0x67, 0x00, 0x6A, 0x08, 0x24,
+0x30, 0xF0, 0x21, 0x6B, 0xFF, 0x4C, 0x88, 0x34,
+0x52, 0xF6, 0x04, 0x4B, 0x6D, 0xE4, 0x40, 0x9B,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x68, 0xF0, 0x01, 0x4A,
+0x24, 0x67, 0x40, 0xDB, 0x0C, 0x24, 0xC0, 0x9C,
+0x0A, 0x26, 0x41, 0x9C, 0xFF, 0xF7, 0x1D, 0x52,
+0x06, 0x61, 0x04, 0x52, 0x04, 0x60, 0x64, 0xAC,
+0x02, 0x23, 0x83, 0x9C, 0x05, 0x2C, 0x80, 0x6C,
+0x00, 0x18, 0x3C, 0x0C, 0x00, 0x6A, 0x24, 0x10,
+0xE7, 0x41, 0x09, 0x4F, 0x04, 0xD7, 0x79, 0xC9,
+0xAB, 0xD9, 0x8E, 0xD9, 0x04, 0x4A, 0x04, 0x94,
+0xFF, 0x6B, 0xA2, 0x67, 0x6C, 0xED, 0x00, 0x18,
+0x04, 0x0C, 0x00, 0x18, 0x65, 0x0B, 0x0F, 0x42,
+0x30, 0xF0, 0x21, 0x6B, 0x52, 0xF6, 0x04, 0x4B,
+0x08, 0x30, 0x61, 0xE0, 0x04, 0x93, 0x60, 0xD8,
+0x53, 0xC1, 0x04, 0x94, 0x00, 0x18, 0x9E, 0x0B,
+0x40, 0x98, 0x10, 0xF0, 0x20, 0x6B, 0x46, 0xF4,
+0x1D, 0x4B, 0x89, 0x9A, 0xFF, 0xF7, 0x7C, 0xDC,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0xE8, 0x11, 0x00, 0x6B, 0x28, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xE8, 0xF0, 0x15, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0xE7, 0x11, 0x01, 0x6B,
+0x4C, 0xEB, 0x0A, 0x2B, 0x30, 0xF0, 0x21, 0x6B,
+0x72, 0xF6, 0x60, 0x9B, 0x05, 0x2B, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0x18, 0x10, 0x0F, 0x10,
+0x90, 0x67, 0xB1, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x72, 0xF6, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x68, 0xF0, 0x01, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x43, 0x67,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x21, 0x69,
+0x72, 0xF6, 0x00, 0x99, 0x16, 0x28, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x00, 0x6C, 0x68, 0xF1, 0x05, 0x4A,
+0x40, 0xDB, 0xA4, 0x67, 0x00, 0x18, 0xDB, 0x0B,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x08, 0xDA,
+0x00, 0x18, 0x78, 0x0B, 0x01, 0x6A, 0x72, 0xF6,
+0x40, 0xD9, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xA8, 0xF1, 0x11, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x21, 0x68, 0x52, 0xF6,
+0x3C, 0xA0, 0x13, 0x29, 0x00, 0x18, 0x10, 0x0C,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x48, 0x9A,
+0x01, 0x6B, 0x6B, 0xEB, 0x62, 0xC2, 0x00, 0x6C,
+0x00, 0x18, 0x3C, 0x0C, 0x01, 0x6A, 0x52, 0xF6,
+0x5C, 0xC0, 0x30, 0xF0, 0x21, 0x6A, 0x72, 0xF6,
+0x20, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0xE8, 0x11, 0x82, 0x6B, 0x1F, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x08, 0xF2, 0x09, 0x4A, 0x40, 0xDB,
+0x00, 0x18, 0xE7, 0x11, 0x01, 0x6B, 0x4C, 0xEB,
+0x03, 0x2B, 0x00, 0x18, 0x6C, 0x10, 0x0D, 0x10,
+0x30, 0xF0, 0x21, 0x68, 0x72, 0xF6, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xA8, 0xF1,
+0x11, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x02, 0x6A, 0x40, 0xC4, 0x00, 0x6A, 0x41, 0xDC,
+0xA1, 0xCC, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x41, 0x9C, 0x14, 0x22, 0x00, 0x18,
+0x87, 0x0A, 0x82, 0x67, 0x02, 0x67, 0x00, 0x18,
+0xF3, 0x0A, 0x01, 0x6A, 0x90, 0x67, 0x41, 0xC0,
+0x01, 0x6D, 0x00, 0x18, 0x6D, 0x0A, 0x30, 0xF0,
+0x21, 0x6C, 0xD1, 0xF6, 0x10, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x7B, 0x0A, 0x03, 0x10, 0x41, 0xAC,
+0x01, 0x4A, 0x41, 0xCC, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x6D, 0x00, 0x18, 0xFD, 0x0A, 0x00, 0x18,
+0x61, 0x0B, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x41, 0xAC,
+0xFF, 0xF7, 0x1F, 0x68, 0xAC, 0xE8, 0x04, 0x22,
+0xFF, 0x4A, 0x41, 0xCC, 0x00, 0x6A, 0x1B, 0x10,
+0x01, 0x6A, 0x19, 0x20, 0x61, 0x9C, 0x07, 0x23,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0xA8, 0x9A,
+0x00, 0x18, 0x7B, 0x0A, 0x0B, 0x10, 0x30, 0xF0,
+0x21, 0x6A, 0x11, 0xF7, 0xA8, 0x9A, 0xA1, 0xDC,
+0x11, 0xF7, 0xA8, 0x9A, 0x61, 0xDD, 0x11, 0xF7,
+0x48, 0x9A, 0x82, 0xDA, 0x90, 0x67, 0x07, 0x6D,
+0x00, 0x18, 0x8B, 0x0B, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x41, 0x9C,
+0x0E, 0x22, 0x00, 0x18, 0x87, 0x0A, 0x02, 0x67,
+0x82, 0x67, 0x01, 0x6D, 0x00, 0x18, 0x6D, 0x0A,
+0x90, 0x67, 0x00, 0x18, 0xF3, 0x0A, 0x90, 0x67,
+0x00, 0x18, 0x9E, 0x0B, 0x03, 0x10, 0x41, 0xAC,
+0x01, 0x4A, 0x41, 0xCC, 0x05, 0x97, 0x04, 0x90,
+0x00, 0x6A, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x08, 0xD4, 0x24, 0x67, 0x14, 0x10, 0x91, 0x67,
+0x00, 0x18, 0x87, 0x0A, 0x02, 0x67, 0x82, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x6D, 0x0A, 0x90, 0x67,
+0x00, 0x18, 0xF3, 0x0A, 0x01, 0x6A, 0x30, 0xF0,
+0x21, 0x6C, 0x41, 0xC0, 0xD1, 0xF6, 0x10, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x7B, 0x0A, 0x41, 0x99,
+0xEA, 0x2A, 0x30, 0xF0, 0x21, 0x6C, 0xD1, 0xF6,
+0x10, 0x4C, 0x41, 0x9C, 0x11, 0x22, 0x30, 0xF0,
+0x21, 0x68, 0x11, 0xF7, 0xA8, 0x98, 0x62, 0xA2,
+0x42, 0xA5, 0x63, 0xEA, 0x09, 0x60, 0x00, 0x18,
+0x7B, 0x0A, 0x11, 0xF7, 0x48, 0x98, 0x01, 0x6B,
+0x00, 0x6C, 0x61, 0xC2, 0x00, 0x18, 0x9E, 0x0B,
+0x08, 0x93, 0x00, 0x6A, 0x40, 0xC3, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x00, 0x6A, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x6B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA, 0xFF, 0x4B,
+0x30, 0xF0, 0x21, 0x6C, 0x68, 0x33, 0x52, 0xF6,
+0x04, 0x4C, 0x91, 0xE3, 0x60, 0x9C, 0x04, 0x23,
+0x8C, 0xAB, 0x4F, 0xEA, 0x8C, 0xEA, 0x4C, 0xCB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF7, 0x48, 0x9A, 0x4D, 0xAA, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x6C, 0xAC,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA, 0x6D, 0xEA,
+0x04, 0x67, 0x4C, 0xCC, 0x6D, 0xAC, 0x81, 0xA4,
+0x06, 0x74, 0x03, 0x61, 0x6C, 0xEA, 0x6E, 0xEA,
+0x0A, 0x22, 0x41, 0xA0, 0x05, 0x72, 0x1B, 0x61,
+0x4C, 0xA8, 0x83, 0x67, 0x4C, 0xEC, 0x17, 0x24,
+0x8D, 0xA8, 0x4C, 0xEC, 0x8D, 0xC8, 0x4C, 0xA8,
+0x6F, 0xEB, 0x90, 0x67, 0x4C, 0xEB, 0x6C, 0xC8,
+0x00, 0x18, 0xF3, 0x0A, 0x01, 0x6A, 0x90, 0x67,
+0x08, 0x6D, 0x41, 0xC0, 0x00, 0x18, 0x6D, 0x0A,
+0x30, 0xF0, 0x21, 0x6C, 0xD1, 0xF6, 0x10, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x7B, 0x0A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA, 0xFF, 0x4B,
+0x30, 0xF0, 0x21, 0x6C, 0x68, 0x33, 0x52, 0xF6,
+0x04, 0x4C, 0x91, 0xE3, 0x80, 0x9C, 0x05, 0x24,
+0xA2, 0x67, 0x00, 0x18, 0xFD, 0x0A, 0x00, 0x18,
+0x61, 0x0B, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6B,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA,
+0xFF, 0x4B, 0x30, 0xF0, 0x21, 0x6C, 0x68, 0x33,
+0x52, 0xF6, 0x04, 0x4C, 0x91, 0xE3, 0x00, 0x9C,
+0x24, 0x20, 0x6C, 0xA8, 0x81, 0xA0, 0x4D, 0xEB,
+0x06, 0x74, 0x6C, 0xC8, 0x4D, 0xA8, 0x03, 0x61,
+0x4C, 0xEB, 0x4E, 0xEB, 0x0A, 0x23, 0x61, 0xA0,
+0x05, 0x73, 0x17, 0x61, 0x6C, 0xA8, 0x82, 0x67,
+0x6C, 0xEC, 0x13, 0x24, 0x8D, 0xA8, 0x6C, 0xEC,
+0x8D, 0xC8, 0x6C, 0xA8, 0x4F, 0xEA, 0x90, 0x67,
+0x6C, 0xEA, 0x4C, 0xC8, 0x00, 0x18, 0xF3, 0x0A,
+0x01, 0x6A, 0x90, 0x67, 0x41, 0xC0, 0x08, 0x6D,
+0x00, 0x18, 0x6D, 0x0A, 0x90, 0x67, 0x00, 0x18,
+0x9E, 0x0B, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A, 0x64, 0x67,
+0x85, 0x67, 0x4C, 0xEB, 0x4C, 0xEC, 0x0D, 0x26,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x48, 0x9A,
+0xE3, 0x67, 0x06, 0x6D, 0xCC, 0xAA, 0xCC, 0xEF,
+0x6E, 0xEF, 0x15, 0x2F, 0x6F, 0xEB, 0xCC, 0xEB,
+0x0F, 0x10, 0x30, 0xF0, 0x21, 0x6F, 0x11, 0xF7,
+0x08, 0x9F, 0x05, 0x6D, 0xCC, 0xA8, 0x6C, 0xEE,
+0xCC, 0xEA, 0x09, 0x22, 0xCD, 0xC8, 0x11, 0xF7,
+0x48, 0x9F, 0x6F, 0xEB, 0x8C, 0xAA, 0x8C, 0xEB,
+0x6C, 0xCA, 0x02, 0x6A, 0x08, 0x10, 0x30, 0xF0,
+0x21, 0x6A, 0x11, 0xF7, 0x48, 0x9A, 0x6D, 0xCA,
+0x00, 0x18, 0x8B, 0x0B, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x03, 0x6A, 0x40, 0xC4, 0x00, 0x6A, 0x41, 0xC4,
+0x00, 0x6A, 0x41, 0xCC, 0x00, 0x6A, 0x41, 0xDC,
+0x42, 0xDC, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x41, 0xAC, 0xFF, 0xF7,
+0x1F, 0x69, 0x04, 0x67, 0xAC, 0xE9, 0x0A, 0x2A,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF7, 0x68, 0x9A,
+0x62, 0xDC, 0x11, 0xF7, 0x48, 0x9A, 0x42, 0xA2,
+0x41, 0xC4, 0x07, 0x10, 0x30, 0xF0, 0x21, 0x6A,
+0x62, 0x9C, 0x11, 0xF7, 0x88, 0x9A, 0x8A, 0xEB,
+0x05, 0x61, 0x41, 0xA8, 0x01, 0x4A, 0x41, 0xC8,
+0x00, 0x6A, 0x24, 0x10, 0x01, 0x6A, 0x22, 0x21,
+0xA1, 0xA0, 0x42, 0xA4, 0x43, 0xED, 0x04, 0x60,
+0x42, 0xC3, 0x82, 0x98, 0x00, 0x18, 0xE4, 0x0A,
+0x61, 0x98, 0x08, 0x23, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF7, 0xA8, 0x9A, 0x90, 0x67, 0x00, 0x18,
+0x7B, 0x0A, 0x0B, 0x10, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF7, 0x88, 0x9A, 0x81, 0xD8, 0x11, 0xF7,
+0x88, 0x9A, 0x61, 0xDC, 0x11, 0xF7, 0x48, 0x9A,
+0x02, 0xDA, 0x91, 0x67, 0x09, 0x6D, 0x00, 0x18,
+0x8B, 0x0B, 0x01, 0x6A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x41, 0xAC, 0x04, 0x67, 0x57, 0x22, 0x30, 0xF0,
+0x21, 0x6D, 0x82, 0x9C, 0x11, 0xF7, 0x68, 0x9D,
+0x8E, 0xEB, 0x50, 0x2B, 0xFF, 0x4A, 0x41, 0xC8,
+0x41, 0xA8, 0x4E, 0x2A, 0x11, 0xF7, 0x48, 0x9D,
+0x61, 0xA0, 0x62, 0xC2, 0x41, 0x98, 0x2D, 0x22,
+0x90, 0x67, 0x00, 0x18, 0x87, 0x0A, 0x22, 0x67,
+0x82, 0x67, 0x00, 0x6D, 0x00, 0x18, 0x6D, 0x0A,
+0x91, 0x67, 0x00, 0x18, 0xF3, 0x0A, 0x01, 0x6A,
+0x41, 0xC8, 0x22, 0xD8, 0x42, 0xA1, 0x30, 0xF0,
+0x21, 0x6B, 0x91, 0x67, 0x41, 0xC0, 0x30, 0xF0,
+0x21, 0x68, 0xD1, 0xF6, 0x10, 0x48, 0x11, 0xF7,
+0xA8, 0x9B, 0x41, 0x98, 0x62, 0xA5, 0x42, 0xA2,
+0x43, 0xEB, 0x25, 0x60, 0x90, 0x67, 0x00, 0x18,
+0x7B, 0x0A, 0xB1, 0x67, 0x90, 0x67, 0x00, 0x18,
+0x7B, 0x0A, 0x30, 0xF0, 0x21, 0x6D, 0x11, 0xF7,
+0x48, 0x9D, 0x01, 0x6B, 0x61, 0xC2, 0x61, 0xC1,
+0x15, 0x10, 0x30, 0xF0, 0x21, 0x6C, 0x30, 0xF0,
+0x21, 0x6B, 0xD1, 0xF6, 0x10, 0x4C, 0x41, 0x9C,
+0x11, 0xF7, 0xA8, 0x9B, 0x62, 0xA2, 0x42, 0xA5,
+0x63, 0xEA, 0x0E, 0x60, 0x00, 0x18, 0x7B, 0x0A,
+0x30, 0xF0, 0x21, 0x6D, 0x11, 0xF7, 0x48, 0x9D,
+0x01, 0x6B, 0x61, 0xC2, 0x00, 0x6C, 0x00, 0x18,
+0x9E, 0x0B, 0x02, 0x10, 0xFF, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x04, 0xD4, 0x41, 0xAC,
+0x04, 0x67, 0x21, 0x22, 0x42, 0x9C, 0x61, 0xA4,
+0x62, 0xC2, 0x30, 0xF0, 0x21, 0x6A, 0x82, 0x9C,
+0x11, 0xF7, 0x48, 0x9A, 0x8E, 0xEA, 0x17, 0x22,
+0x00, 0x18, 0xE4, 0x0A, 0x14, 0x10, 0x04, 0x94,
+0x00, 0x18, 0x87, 0x0A, 0x22, 0x67, 0x82, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x6D, 0x0A, 0x91, 0x67,
+0x00, 0x18, 0xF3, 0x0A, 0x01, 0x6A, 0x30, 0xF0,
+0x21, 0x6C, 0x41, 0xC1, 0xD1, 0xF6, 0x10, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x7B, 0x0A, 0x04, 0x93,
+0x41, 0x9B, 0xE9, 0x2A, 0x30, 0xF0, 0x21, 0x6C,
+0xD1, 0xF6, 0x10, 0x4C, 0x41, 0x9C, 0x11, 0x22,
+0x30, 0xF0, 0x21, 0x69, 0x11, 0xF7, 0xA8, 0x99,
+0x62, 0xA2, 0x42, 0xA5, 0x63, 0xEA, 0x09, 0x60,
+0x00, 0x18, 0x7B, 0x0A, 0x11, 0xF7, 0x48, 0x99,
+0x01, 0x6B, 0x00, 0x6C, 0x61, 0xC2, 0x00, 0x18,
+0x9E, 0x0B, 0x00, 0x6A, 0x40, 0xC0, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x00, 0x6A, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x88, 0xF7, 0x05, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0xF4, 0x17, 0x00, 0x6A, 0x20, 0xE8,
+0x30, 0xF0, 0x21, 0x6A, 0xB1, 0xF6, 0x70, 0x9A,
+0x02, 0x5B, 0x43, 0x67, 0x0A, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF0, 0x08, 0x4A, 0x4F, 0xE3,
+0x20, 0x5B, 0x98, 0x67, 0x6A, 0x32, 0x8B, 0xEB,
+0x6C, 0xEA, 0x20, 0xE8, 0x40, 0xA5, 0xFF, 0x6B,
+0x6C, 0xEC, 0x83, 0xEA, 0x0C, 0x60, 0x01, 0x4A,
+0x40, 0xC5, 0x40, 0xA6, 0xA1, 0x42, 0x6C, 0xED,
+0xAE, 0xEC, 0x8B, 0xEB, 0x8D, 0xEB, 0xC0, 0xF7,
+0x63, 0x33, 0x6C, 0xED, 0xA0, 0xC6, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x21, 0x6C,
+0x40, 0x6A, 0x30, 0xF0, 0x21, 0x6B, 0xB1, 0xF6,
+0x5C, 0xDC, 0xD1, 0xF6, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x40, 0x9A, 0x02, 0x6E,
+0x30, 0xF0, 0x20, 0x6D, 0x60, 0xAA, 0xE7, 0xF7,
+0x1F, 0x6A, 0x40, 0xF6, 0xA0, 0x9D, 0x6C, 0xEA,
+0x5B, 0xEE, 0x01, 0x2A, 0xE5, 0xE8, 0x30, 0xF0,
+0x21, 0x6B, 0xB1, 0xF6, 0x58, 0xDB, 0x10, 0xF0,
+0x20, 0x6B, 0xE8, 0xF7, 0x09, 0x4B, 0x60, 0xDD,
+0x01, 0x6D, 0x12, 0xEE, 0xB1, 0xF6, 0xDC, 0xDC,
+0x42, 0xF1, 0x18, 0x6C, 0x00, 0x18, 0xDF, 0x25,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x8E, 0x35, 0x45, 0xF6, 0x18, 0x4B, 0xAD, 0xE3,
+0x43, 0xF3, 0x68, 0xA3, 0x07, 0x6D, 0x8C, 0xED,
+0x67, 0xED, 0x01, 0x6C, 0x8C, 0xEB, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x24, 0x67,
+0x4C, 0xE9, 0x4C, 0xED, 0x2E, 0x34, 0x07, 0x6B,
+0x01, 0x75, 0x4C, 0xEC, 0x2C, 0xEB, 0x1F, 0x61,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0x11, 0xE4, 0x01, 0x6A, 0x44, 0xEB, 0x43, 0xF3,
+0x68, 0xA4, 0x00, 0x6D, 0x6D, 0xEA, 0x43, 0xF3,
+0x48, 0xC4, 0x91, 0x67, 0x00, 0x18, 0x14, 0x31,
+0xE0, 0xF0, 0x4B, 0xA0, 0x4E, 0xE9, 0x1C, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x44, 0x9A,
+0x40, 0x9A, 0x50, 0x32, 0x00, 0xF5, 0x42, 0x32,
+0xA3, 0xF3, 0x46, 0xC8, 0x11, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x51, 0xE4,
+0x01, 0x6A, 0x44, 0xEB, 0x43, 0xF3, 0x68, 0xA4,
+0x4F, 0xEA, 0x01, 0x6D, 0x6C, 0xEA, 0x43, 0xF3,
+0x48, 0xC4, 0x91, 0x67, 0x00, 0x18, 0x14, 0x31,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x6D, 0x00, 0x18,
+0x14, 0x31, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x6D, 0x00, 0x18, 0x14, 0x31, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFF, 0x6A, 0x4C, 0xEC,
+0x01, 0x6B, 0xAC, 0xEA, 0x6E, 0xEA, 0x01, 0x5A,
+0x58, 0x67, 0x05, 0x5C, 0x48, 0x32, 0x08, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0x88, 0x34, 0x20, 0xF2,
+0x0C, 0x4B, 0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB,
+0x01, 0x6A, 0x4B, 0xEA, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF6, 0x84, 0x9B, 0x30, 0xF0,
+0x20, 0x6D, 0x80, 0xF6, 0xA8, 0x9D, 0x60, 0x9C,
+0xAC, 0xEB, 0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x84, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0x80, 0xF6, 0xA8, 0x9D, 0x60, 0x9C, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0x80, 0xF6, 0xB4, 0x9D,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x84, 0x9B, 0x30, 0xF0, 0x20, 0x6D, 0x80, 0xF6,
+0xA8, 0x9D, 0x60, 0x9C, 0xAC, 0xEB, 0x30, 0xF0,
+0x20, 0x6D, 0x80, 0xF6, 0xB8, 0x9D, 0xAD, 0xEB,
+0x60, 0xDC, 0x60, 0xF5, 0x60, 0x42, 0x1F, 0xF7,
+0x00, 0x6C, 0x8C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x10, 0x61, 0x2E, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x84, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0x80, 0xF6, 0xA8, 0x9D, 0x60, 0x9C, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0x80, 0xF6, 0xBC, 0x9D,
+0xE6, 0x17, 0x1E, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x70, 0x9B, 0x1D, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF6, 0x84, 0x9B, 0x30, 0xF0,
+0x20, 0x6D, 0x80, 0xF6, 0xA8, 0x9D, 0x60, 0x9C,
+0xAC, 0xEB, 0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF6,
+0xA0, 0x9D, 0xAD, 0xEB, 0x60, 0xDC, 0x60, 0xF5,
+0x60, 0x42, 0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x07, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6, 0x6C, 0x9B,
+0x69, 0xE2, 0x40, 0x9A, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF6, 0x70, 0x9B, 0x69, 0xE2,
+0x40, 0x9A, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x05, 0x5C, 0xAC, 0xEA, 0x4B, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x88, 0x34, 0x40, 0xF2, 0x00, 0x4B,
+0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB, 0x05, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6, 0x64, 0x9A,
+0x2D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6,
+0x64, 0x9A, 0x20, 0x10, 0x05, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF6, 0x68, 0x9A, 0x22, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6, 0x68, 0x9A,
+0x15, 0x10, 0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x6C, 0x9A, 0x17, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF6, 0x6C, 0x9A, 0x0A, 0x10,
+0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6,
+0x70, 0x9A, 0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x70, 0x9A, 0x80, 0xA3, 0xF7, 0x6A,
+0x0A, 0x10, 0x0C, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x74, 0x9A, 0x40, 0xA3, 0xFF, 0x6C,
+0x08, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x74, 0x9A, 0xF7, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0xAC, 0xEA,
+0x13, 0x60, 0x03, 0x24, 0x02, 0x74, 0x15, 0x60,
+0x18, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0xA3, 0xF3, 0xC0, 0xA3, 0x01, 0x6D,
+0x4C, 0xED, 0x02, 0x6A, 0x4B, 0xEA, 0xCC, 0xEA,
+0xAD, 0xEA, 0xA3, 0xF3, 0x40, 0xC3, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0xE9, 0xF1, 0x5B, 0xC3,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x25, 0xF7,
+0x43, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6,
+0x58, 0x9A, 0x60, 0xA2, 0x10, 0x6A, 0x6C, 0xEA,
+0x24, 0x22, 0x02, 0x5C, 0x03, 0x61, 0x02, 0x74,
+0x17, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0xA3, 0xF3, 0x80, 0xA3,
+0x01, 0x6A, 0x8C, 0xEA, 0xA3, 0xF3, 0x83, 0xA3,
+0x7F, 0x6B, 0x5C, 0x32, 0x8C, 0xEB, 0x6D, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF6, 0x7C, 0x9B, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x25, 0xF7, 0x63, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x40, 0x9A,
+0x60, 0xC2, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x44, 0x9A, 0x60, 0xA2, 0xFF, 0x6A,
+0x6C, 0xEA, 0xFF, 0x72, 0x00, 0x6A, 0x0B, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x48, 0x9A,
+0x60, 0xA2, 0x07, 0x6A, 0x6C, 0xEA, 0x07, 0x6B,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0xAC, 0xEA,
+0x03, 0x60, 0x02, 0x74, 0x09, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x02, 0x6B, 0xA3, 0xF3, 0x68, 0xC2, 0x15, 0x10,
+0x09, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xC0, 0xF0, 0x71, 0xA2, 0xA3, 0xF3,
+0x68, 0xC2, 0x05, 0x10, 0xFF, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0x09, 0xF2, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x68, 0xA2, 0xA3, 0xF3, 0x80, 0xA2, 0xA3, 0xF3,
+0x69, 0xC2, 0x40, 0x6B, 0x8D, 0xEB, 0xA3, 0xF3,
+0x60, 0xC2, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xD9, 0x12, 0x01, 0x72, 0x01, 0x6B,
+0x18, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xA3, 0xF3, 0x80, 0xA2, 0x04, 0x6B,
+0x8C, 0xEB, 0x02, 0x23, 0x02, 0x6B, 0x0D, 0x10,
+0xC0, 0xF0, 0x6B, 0xA2, 0x05, 0x5B, 0x08, 0x6B,
+0x08, 0x60, 0x03, 0xF4, 0x7C, 0xA2, 0x01, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x0E, 0x22,
+0x11, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x4C, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x50, 0x9A, 0x02, 0x6B, 0x60, 0xC2,
+0x00, 0x6A, 0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF6, 0x6C, 0x9B, 0x40, 0xC3, 0x01, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xD9, 0x12,
+0x01, 0x72, 0x01, 0x6B, 0x2D, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x64, 0xA2, 0x03, 0x6C, 0x6C, 0xEC, 0x02, 0x24,
+0x02, 0x6B, 0x22, 0x10, 0xC0, 0xF0, 0x8B, 0xA2,
+0x02, 0x24, 0x04, 0x6B, 0x1D, 0x10, 0x04, 0x6C,
+0x6C, 0xEC, 0x02, 0x24, 0x08, 0x6B, 0x18, 0x10,
+0x10, 0x6C, 0xA3, 0x67, 0x8C, 0xED, 0x0A, 0x25,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x4C, 0x9A,
+0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x54, 0x9A, 0x0E, 0x10, 0xA3, 0xF3, 0x80, 0xA2,
+0x20, 0x6B, 0x6C, 0xEC, 0x05, 0x24, 0x63, 0xF3,
+0x5F, 0xA2, 0x0F, 0x22, 0x80, 0x6B, 0x6B, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x4C, 0x9A,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x50, 0x9A, 0x04, 0x6B, 0x60, 0xC2, 0x00, 0x6A,
+0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6,
+0x6C, 0x9B, 0x40, 0xC3, 0x01, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0xA3, 0xF3, 0x01, 0xA3, 0x20, 0x6F, 0xFF, 0x6A,
+0x0C, 0xEF, 0x4C, 0xEF, 0x4C, 0xEC, 0x4C, 0xED,
+0x4C, 0xEE, 0x80, 0xF0, 0x02, 0x2F, 0xA3, 0xF3,
+0x00, 0xA3, 0x01, 0x6F, 0x0C, 0xEF, 0x4C, 0xEF,
+0x09, 0x27, 0xA3, 0xF3, 0x5C, 0xA3, 0xE5, 0x42,
+0x03, 0x4A, 0xA3, 0xF3, 0xF7, 0xC3, 0xA3, 0xF3,
+0x56, 0xC3, 0x08, 0x10, 0x05, 0x6F, 0xA3, 0xF3,
+0xF7, 0xC3, 0x05, 0x4E, 0x04, 0x6F, 0xA3, 0xF3,
+0xF6, 0xC3, 0x4C, 0xEE, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3, 0xF5, 0xA2,
+0xA3, 0xF3, 0x76, 0xA2, 0xE3, 0xEB, 0x09, 0x61,
+0xA3, 0xF3, 0x77, 0xA2, 0xA3, 0xF3, 0xCA, 0xC2,
+0x71, 0xE4, 0xB7, 0xE4, 0xA3, 0xF3, 0xB8, 0xC2,
+0x09, 0x10, 0xA3, 0xF3, 0x97, 0xA2, 0x77, 0xE5,
+0xB9, 0xE6, 0x6F, 0xE4, 0xA3, 0xF3, 0xCA, 0xC2,
+0xA3, 0xF3, 0x78, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3, 0x77, 0xA2,
+0xA3, 0xF3, 0x98, 0xA2, 0x0A, 0x4B, 0x82, 0xEB,
+0x02, 0x60, 0xA3, 0xF3, 0x78, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x78, 0xA2, 0xA3, 0xF3, 0x8A, 0xA2, 0x23, 0x4B,
+0x82, 0xEB, 0x02, 0x60, 0xA3, 0xF3, 0x6A, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xA3, 0xF3, 0x78, 0xA2, 0xC0, 0xF0, 0x8A, 0xA2,
+0xA3, 0xF3, 0x72, 0xCA, 0x18, 0x6B, 0x8C, 0xEB,
+0x10, 0x73, 0x0C, 0x61, 0xA3, 0xF3, 0x7C, 0xA2,
+0x03, 0x6C, 0x05, 0x4B, 0xA3, 0xF3, 0x78, 0xC2,
+0xC0, 0xF0, 0x6D, 0xA2, 0x76, 0x33, 0x8C, 0xEB,
+0xA3, 0xF3, 0x6A, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x58, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x09, 0xF2, 0x8A, 0xAC, 0xA0, 0xA2, 0xFF, 0x6B,
+0x6C, 0xED, 0x8E, 0xED, 0x02, 0x25, 0x8C, 0xEB,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xA3, 0xF3, 0x81, 0xA2, 0x41, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA3, 0xF3, 0x61, 0xC2,
+0x04, 0x10, 0x40, 0x6A, 0x0D, 0xEA, 0xA3, 0xF3,
+0x41, 0xC3, 0x01, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xC0, 0xF0, 0x75, 0xA2, 0x02, 0x6C, 0x8B, 0xEC,
+0x03, 0x6D, 0x8C, 0xEB, 0xAB, 0xED, 0xAC, 0xEB,
+0x03, 0xF4, 0xBC, 0xA2, 0xAC, 0xEC, 0x03, 0xF4,
+0x9C, 0xC2, 0x08, 0x6C, 0x8D, 0xEB, 0xC0, 0xF0,
+0x75, 0xC2, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD1,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xC0, 0xF0, 0xD5, 0xA2, 0x01, 0x68,
+0x70, 0x67, 0xCC, 0xEB, 0xFF, 0x6C, 0x25, 0x23,
+0x03, 0xF4, 0xFC, 0xA2, 0x02, 0x6D, 0x67, 0x67,
+0xAC, 0xEB, 0x8C, 0xEB, 0x1E, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0x25, 0xF6, 0x30, 0xA3, 0x01, 0x49,
+0x25, 0xF6, 0x30, 0xC3, 0x25, 0xF6, 0x30, 0xA3,
+0xC9, 0x59, 0x13, 0x61, 0x03, 0x69, 0x2B, 0xE9,
+0xCC, 0xED, 0xEC, 0xE9, 0x8C, 0xED, 0x00, 0x6F,
+0x03, 0xF4, 0x3C, 0xC2, 0x25, 0xF6, 0xF0, 0xC3,
+0x08, 0x25, 0xA3, 0xF3, 0x60, 0xA2, 0x6D, 0xE8,
+0xD0, 0x6B, 0xA3, 0xF3, 0x00, 0xC2, 0xA3, 0xF3,
+0x70, 0xCA, 0x01, 0x91, 0x00, 0x90, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0xC0, 0xF0, 0x55, 0xA0,
+0x01, 0x69, 0x2C, 0xEA, 0x0C, 0x22, 0x03, 0xF4,
+0xDD, 0xA0, 0xFF, 0x6C, 0x55, 0x4C, 0x00, 0x6D,
+0x00, 0x18, 0xF1, 0x25, 0x03, 0xF4, 0x5C, 0xA0,
+0x4D, 0xE9, 0x03, 0xF4, 0x3C, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x02, 0xF6,
+0x78, 0xA2, 0x01, 0x73, 0x0E, 0x61, 0xC0, 0xF0,
+0x95, 0xA2, 0x08, 0x6B, 0x8C, 0xEB, 0x09, 0x2B,
+0x03, 0xF4, 0x7C, 0xA2, 0x02, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x93, 0x13, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x25, 0xF7, 0x6D, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0x2B, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF6, 0x5C, 0x9A, 0x00, 0x6B,
+0x02, 0x6C, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x60, 0x9A, 0x40, 0x9B, 0x8C, 0xEA,
+0x01, 0x22, 0x80, 0xDB, 0x00, 0x18, 0x4C, 0x2F,
+0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18,
+0x22, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x25, 0xF7,
+0x6D, 0xA2, 0x02, 0x6A, 0x6C, 0xEA, 0x04, 0x22,
+0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18, 0xB2, 0x12,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x03, 0xF4, 0x9C, 0xA2, 0x01, 0x6B, 0x8D, 0xEB,
+0x03, 0xF4, 0x7C, 0xC2, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x4C, 0x2F, 0x00, 0x6D, 0xC5, 0x67,
+0xFF, 0x6C, 0x00, 0x18, 0x22, 0x2A, 0x01, 0x6C,
+0x0C, 0x6D, 0x00, 0x18, 0xB2, 0x12, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x00, 0x18,
+0x4C, 0x2F, 0x05, 0x20, 0x00, 0x6D, 0xFF, 0x6C,
+0xC5, 0x67, 0x00, 0x18, 0x22, 0x2A, 0x01, 0x6C,
+0x04, 0x6D, 0x00, 0x18, 0xB2, 0x12, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x2E, 0x6E, 0xFF, 0x6C,
+0x6F, 0x6D, 0x00, 0x18, 0x22, 0x2A, 0x01, 0x6C,
+0x02, 0x6D, 0x00, 0x18, 0xB2, 0x12, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0xC0, 0xF0, 0x75, 0xA0,
+0x01, 0x6A, 0xFF, 0x69, 0x4C, 0xEB, 0x48, 0x23,
+0x03, 0xF4, 0x7C, 0xA0, 0x6C, 0xEA, 0x2C, 0xEA,
+0x23, 0x2A, 0x03, 0xF4, 0xDD, 0xA0, 0xFF, 0x6C,
+0x55, 0x4C, 0x00, 0x6D, 0x00, 0x18, 0xF1, 0x25,
+0x00, 0x18, 0x4C, 0x2F, 0x00, 0x6D, 0x91, 0x67,
+0xC5, 0x67, 0x00, 0x18, 0x22, 0x2A, 0xC0, 0xF0,
+0x75, 0xA0, 0x02, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x04, 0x22, 0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0xB2, 0x12, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x03, 0xF4, 0x9C, 0xA2, 0x01, 0x6B,
+0x8D, 0xEB, 0x03, 0xF4, 0x7C, 0xC2, 0x20, 0x10,
+0x03, 0xF4, 0xDE, 0xA0, 0xFF, 0x6C, 0x55, 0x4C,
+0x00, 0x6D, 0x00, 0x18, 0xF1, 0x25, 0x03, 0xF4,
+0x7C, 0xA0, 0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xC0, 0xF0, 0x75, 0xA0, 0x03, 0xF4, 0x5C, 0xC0,
+0x02, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x05, 0x22,
+0x01, 0x6C, 0x04, 0x6D, 0x00, 0x18, 0xB2, 0x12,
+0x07, 0x10, 0xFF, 0x6C, 0xA4, 0x67, 0x31, 0x6E,
+0x00, 0x18, 0x22, 0x2A, 0x00, 0x18, 0xE3, 0x2E,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6C, 0xA4, 0x67, 0x2F, 0x6E, 0x00, 0x18,
+0x22, 0x2A, 0x00, 0x18, 0xC8, 0x2E, 0x00, 0x18,
+0xE3, 0x2E, 0x01, 0x6C, 0x08, 0x6D, 0x00, 0x18,
+0xB2, 0x12, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF2, 0x64, 0x9A,
+0xC0, 0xF2, 0x04, 0x4A, 0xFF, 0x69, 0x04, 0xD3,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0x9A, 0x2C, 0xEC,
+0x44, 0xAA, 0x45, 0xF6, 0x18, 0x48, 0x08, 0xD4,
+0xE0, 0xF0, 0x8B, 0xA0, 0x05, 0xD3, 0x7D, 0x67,
+0x4C, 0xCB, 0x00, 0x18, 0x12, 0x12, 0x01, 0x72,
+0x2A, 0x61, 0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x24, 0x22, 0xC0, 0xF0,
+0x68, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA, 0x01, 0x72,
+0x1E, 0x61, 0x08, 0x93, 0x1F, 0xF7, 0x00, 0x6C,
+0x64, 0x32, 0x7D, 0x67, 0x49, 0xE3, 0x68, 0xAA,
+0x41, 0x43, 0x8C, 0xEA, 0x02, 0xF0, 0x00, 0x72,
+0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x44, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x48, 0x9A, 0x4D, 0xE3,
+0x60, 0xA3, 0x20, 0x6A, 0x6C, 0xEA, 0x4B, 0xEA,
+0xC0, 0xF7, 0x42, 0x32, 0x01, 0x10, 0x01, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x25, 0xF7, 0xA2, 0xA3,
+0x04, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x09, 0x23, 0x7D, 0x67, 0x1E, 0x6A,
+0x50, 0xC3, 0x01, 0x6A, 0x92, 0xC3, 0x4F, 0xCB,
+0x04, 0x04, 0x00, 0x18, 0xF3, 0x1F, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xFF, 0x68, 0x8C, 0xE8, 0xA3, 0xF3,
+0x80, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x41, 0x6D,
+0x8C, 0xEB, 0xAB, 0xED, 0xAC, 0xEB, 0xA3, 0xF3,
+0xA1, 0xA2, 0xA3, 0xF3, 0x60, 0xC2, 0x11, 0x6B,
+0x00, 0x6C, 0x6B, 0xEB, 0xA3, 0xF3, 0x8B, 0xC2,
+0xA3, 0xF3, 0x84, 0xC2, 0xAC, 0xEB, 0xA3, 0xF3,
+0x8C, 0xC2, 0x90, 0x67, 0xA3, 0xF3, 0x61, 0xC2,
+0x00, 0x18, 0xA8, 0x2D, 0x90, 0x67, 0x00, 0x18,
+0xA1, 0x2D, 0x90, 0x67, 0x00, 0x18, 0xB6, 0x2D,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0xFF, 0x69, 0x45, 0xF6,
+0x18, 0x48, 0x8C, 0xE9, 0xE0, 0xF0, 0x8B, 0xA0,
+0x00, 0x18, 0x12, 0x12, 0x01, 0x72, 0x2C, 0x61,
+0xA3, 0xF3, 0x61, 0xA0, 0x09, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6C, 0x6F, 0x6D, 0x2C, 0x6E,
+0xA3, 0xF3, 0x41, 0xC0, 0x00, 0x18, 0x22, 0x2A,
+0xA0, 0xF0, 0x8A, 0xA0, 0x01, 0x6D, 0x08, 0x6E,
+0xF1, 0x67, 0x00, 0x18, 0xF8, 0x18, 0x01, 0x72,
+0x0B, 0x61, 0xA3, 0xF3, 0x61, 0xA0, 0x02, 0x6A,
+0x01, 0x6C, 0x6D, 0xEA, 0x0E, 0x6D, 0xA3, 0xF3,
+0x41, 0xC0, 0x00, 0x18, 0xB2, 0x12, 0x0C, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x50, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x4C, 0x9A, 0x02, 0x6B, 0x60, 0xC2,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xF0, 0x6D, 0x01, 0x6C, 0x00, 0x18, 0xB2, 0x12,
+0x00, 0x6C, 0x00, 0x18, 0x4B, 0x2E, 0x00, 0x18,
+0xC7, 0x29, 0x00, 0x18, 0xB6, 0x29, 0x01, 0x6C,
+0x00, 0x18, 0x4B, 0x2E, 0x01, 0x6C, 0x00, 0x6D,
+0x00, 0x18, 0xB2, 0x12, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF6, 0x6C, 0x9B, 0xFF, 0x6A, 0x24, 0x67,
+0x00, 0xA3, 0x82, 0x67, 0xA2, 0x67, 0x2D, 0x6E,
+0x4C, 0xE9, 0x4C, 0xE8, 0x00, 0x18, 0x22, 0x2A,
+0x00, 0x18, 0xC8, 0x2E, 0x06, 0x2A, 0xFF, 0x6C,
+0xB0, 0x67, 0x2D, 0x6E, 0x00, 0x18, 0x22, 0x2A,
+0x2C, 0x10, 0x05, 0x59, 0x24, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x28, 0x31, 0x40, 0xF2, 0x14, 0x4A,
+0x29, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x00, 0x6C,
+0x08, 0x6D, 0x17, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0x60, 0xF6, 0xBC, 0x9A, 0x11, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0xE0, 0xF6,
+0xB0, 0x9A, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0xE0, 0xF6, 0xB4, 0x9A, 0x05, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0xB8, 0x9A,
+0x04, 0x6C, 0x00, 0x18, 0xB9, 0x07, 0x00, 0x18,
+0xE3, 0x2E, 0x01, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0xB2, 0x12, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0xE9, 0xF1, 0xB9, 0xA3,
+0x08, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x03, 0x2B, 0x01, 0x6C, 0x0C, 0x6D,
+0x05, 0x10, 0x01, 0x6D, 0x00, 0x18, 0x92, 0x31,
+0x01, 0x6C, 0x04, 0x6D, 0x00, 0x18, 0xB2, 0x12,
+0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18,
+0x22, 0x2A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0xE9, 0xF1, 0xB9, 0xA3, 0x04, 0x6B, 0xFF, 0x6A,
+0xAC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x06, 0x2B,
+0x03, 0x6D, 0x00, 0x18, 0x92, 0x31, 0x01, 0x6C,
+0x04, 0x6D, 0x05, 0x10, 0x00, 0x6D, 0x00, 0x18,
+0x92, 0x31, 0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0xB2, 0x12, 0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67,
+0x00, 0x18, 0x22, 0x2A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x6D, 0x00, 0x18,
+0x92, 0x31, 0x00, 0x6D, 0xC5, 0x67, 0xFF, 0x6C,
+0x00, 0x18, 0x22, 0x2A, 0x01, 0x6C, 0x0C, 0x6D,
+0x00, 0x18, 0xB2, 0x12, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x2C, 0xEC,
+0xAC, 0xE9, 0x3A, 0x24, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0xE0, 0xF0, 0x8B, 0xA0,
+0x00, 0x18, 0x12, 0x12, 0x01, 0x72, 0x30, 0x61,
+0xA3, 0xF3, 0x61, 0xA0, 0x05, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x2B, 0x6E, 0xFF, 0x6C, 0x0F, 0x6D,
+0xA3, 0xF3, 0x41, 0xC0, 0x00, 0x18, 0x22, 0x2A,
+0x91, 0x67, 0x02, 0x6D, 0x00, 0x18, 0x92, 0x31,
+0xA0, 0xF0, 0x8A, 0xA0, 0x00, 0x6D, 0x08, 0x6E,
+0xF1, 0x67, 0x00, 0x18, 0xF8, 0x18, 0x01, 0x72,
+0x0B, 0x61, 0xA3, 0xF3, 0x61, 0xA0, 0x01, 0x6A,
+0x01, 0x6C, 0x6D, 0xEA, 0x06, 0x6D, 0xA3, 0xF3,
+0x41, 0xC0, 0x00, 0x18, 0xB2, 0x12, 0x0C, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x50, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x4C, 0x9A, 0x08, 0x6B, 0x60, 0xC2,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x25, 0x67, 0x30, 0xF0,
+0x20, 0x6D, 0x45, 0xF6, 0x18, 0x4D, 0x06, 0x67,
+0xA3, 0xF3, 0xC1, 0xA5, 0x03, 0x6B, 0xFF, 0x6A,
+0xCC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x4C, 0xE9,
+0x4C, 0xE8, 0xE0, 0xF0, 0x03, 0x2B, 0xA3, 0xF3,
+0x43, 0xA5, 0x8E, 0xEA, 0xC0, 0xF0, 0x1E, 0x22,
+0x0D, 0x5C, 0xC0, 0xF0, 0x1B, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x88, 0x34, 0x60, 0xF2, 0x08, 0x4A,
+0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2, 0x0E, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0xD3, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x03, 0x2A, 0x01, 0x6C, 0x00, 0x18, 0xED, 0x13,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x06, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xE2, 0x14, 0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1,
+0x5B, 0xA2, 0x04, 0x72, 0x09, 0x61, 0x05, 0x21,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0xFD, 0x14,
+0x03, 0x10, 0x90, 0x67, 0x00, 0x18, 0xF3, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x08, 0x72, 0xA0, 0xF0, 0x03, 0x61, 0x00, 0x18,
+0xE5, 0x13, 0xA0, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x5B, 0xA2, 0x03, 0x2A, 0x01, 0x6C,
+0x00, 0x18, 0xED, 0x13, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x5B, 0xA2, 0x06, 0x72, 0x03, 0x61,
+0x90, 0x67, 0x00, 0x18, 0xE2, 0x14, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2, 0x0E, 0x72,
+0x07, 0x61, 0x00, 0x18, 0xFB, 0x12, 0x01, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0xD3, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x0C, 0x72, 0x7C, 0x61, 0x00, 0x18, 0xFB, 0x12,
+0x01, 0x72, 0x78, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x80, 0x14, 0x74, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x5B, 0xA2, 0x0E, 0x72, 0x07, 0x61,
+0x00, 0x18, 0xFB, 0x12, 0x01, 0x72, 0x03, 0x61,
+0x90, 0x67, 0x00, 0x18, 0xD3, 0x14, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2, 0x06, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0xE2, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x0C, 0x72, 0x07, 0x61, 0x00, 0x18, 0xFB, 0x12,
+0x01, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x80, 0x14, 0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1,
+0x5B, 0xA2, 0x04, 0x72, 0x4B, 0x61, 0x00, 0x18,
+0x16, 0x13, 0x01, 0x72, 0x47, 0x61, 0x90, 0x67,
+0x00, 0x18, 0xAD, 0x14, 0x43, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2, 0x0E, 0x72,
+0x07, 0x61, 0x00, 0x18, 0xFB, 0x12, 0x01, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0xD3, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x06, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xE2, 0x14, 0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1,
+0x5B, 0xA2, 0x0C, 0x72, 0x07, 0x61, 0x00, 0x18,
+0xFB, 0x12, 0x01, 0x72, 0x03, 0x61, 0x90, 0x67,
+0x00, 0x18, 0x80, 0x14, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x5B, 0xA2, 0x03, 0x2A, 0x01, 0x6C,
+0x00, 0x18, 0xED, 0x13, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x5B, 0xA2, 0x04, 0x72, 0x12, 0x61,
+0x00, 0x18, 0xF8, 0x13, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x63, 0xA2, 0x0C, 0x73, 0x07, 0x61, 0xA3, 0xF3,
+0x60, 0xA2, 0x20, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x2D, 0x14, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0xA3, 0xF3, 0x64, 0xA0, 0x10, 0x6A, 0xFF, 0x69,
+0x6D, 0xEA, 0xA3, 0xF3, 0x44, 0xC0, 0xA3, 0xF3,
+0x4B, 0xA0, 0x8C, 0xE9, 0x02, 0x5A, 0x0D, 0x60,
+0xA3, 0xF3, 0xCA, 0xA0, 0xFF, 0x6C, 0x55, 0x4C,
+0xD9, 0xE2, 0x00, 0x6D, 0x00, 0x18, 0xF1, 0x25,
+0xA3, 0xF3, 0x6B, 0xA0, 0xA3, 0xF3, 0x4A, 0xA0,
+0x14, 0x10, 0x03, 0x6B, 0x78, 0xEA, 0xA3, 0xF3,
+0xCA, 0xA0, 0xFF, 0x6C, 0x55, 0x4C, 0xFE, 0x4E,
+0x00, 0x6D, 0x12, 0xEA, 0x59, 0xE6, 0x00, 0x18,
+0xF1, 0x25, 0xA3, 0xF3, 0x4B, 0xA0, 0x03, 0x6C,
+0xA3, 0xF3, 0x6A, 0xA0, 0x98, 0xEA, 0xFE, 0x4B,
+0x12, 0xEA, 0x49, 0xE3, 0xA3, 0xF3, 0x59, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x04, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x83, 0x67,
+0x01, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0x21, 0x15,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x30, 0xF0, 0x20, 0x69, 0x45, 0xF6, 0x18, 0x49,
+0x04, 0xD4, 0xC0, 0xF0, 0x87, 0xA1, 0x00, 0x6B,
+0xA3, 0xF3, 0x6F, 0xC1, 0x7F, 0x6B, 0x8C, 0xEB,
+0x4C, 0xEB, 0x11, 0x23, 0xE0, 0xF0, 0x8B, 0xA1,
+0x01, 0x68, 0x00, 0x18, 0x12, 0x12, 0x4E, 0xE8,
+0x0A, 0x28, 0x04, 0x94, 0xA3, 0xF3, 0xA8, 0xA1,
+0x00, 0x18, 0xBD, 0x2E, 0x04, 0x94, 0xA3, 0xF3,
+0x09, 0xC1, 0x00, 0x18, 0xA0, 0x15, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0xC0, 0xF0, 0x67, 0xA0, 0x00, 0x6A, 0xA3, 0xF3,
+0x4F, 0xC0, 0x7F, 0x6A, 0xFF, 0x69, 0x6C, 0xEA,
+0x2C, 0xEC, 0x2C, 0xEA, 0x04, 0xD4, 0x15, 0x22,
+0xE0, 0xF0, 0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12,
+0x01, 0x72, 0x0F, 0x61, 0xC0, 0xF0, 0x68, 0xA0,
+0x0F, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x06, 0x22,
+0xA3, 0xF3, 0x61, 0xA0, 0x10, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x03, 0x2A, 0x04, 0x94, 0x00, 0x18,
+0xA0, 0x15, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xFF, 0x6E, 0x8C, 0xEE,
+0x25, 0xF7, 0x83, 0xA2, 0x01, 0x6D, 0x00, 0x18,
+0x21, 0x15, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xDD, 0x1D,
+0x01, 0x6B, 0x12, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x5C, 0x9A, 0x60, 0xA2, 0xFF, 0x6A,
+0x6C, 0xEA, 0x10, 0x6B, 0x09, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF7, 0x60, 0x9B, 0x80, 0xA3,
+0x02, 0x6B, 0x8C, 0xEB, 0x0E, 0x2B, 0x04, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x4C, 0x9A,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x50, 0x9A, 0x08, 0x6B, 0x60, 0xC2, 0x00, 0x6A,
+0x16, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6,
+0x6C, 0x9B, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF6, 0x70, 0x9B, 0x08, 0x6A, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6, 0x74, 0x9B,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7,
+0x64, 0x9B, 0x40, 0xC3, 0x01, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2,
+0x02, 0x22, 0x08, 0x72, 0x06, 0x61, 0x00, 0x18,
+0xF8, 0x15, 0x01, 0x72, 0x02, 0x61, 0x00, 0x18,
+0xA1, 0x14, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x78, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x17, 0x16, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF7, 0x02, 0x4C,
+0x00, 0x6D, 0x07, 0x6E, 0x00, 0x18, 0x9C, 0x1E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6C, 0x74, 0x6E, 0xE9, 0xF1,
+0x18, 0x4C, 0x00, 0x6D, 0x30, 0xF0, 0x20, 0x68,
+0x00, 0x18, 0x9C, 0x1E, 0x45, 0xF6, 0x18, 0x48,
+0x02, 0x6A, 0xC0, 0xF0, 0x49, 0xC0, 0x01, 0x6A,
+0xA3, 0xF3, 0x48, 0xC0, 0xA3, 0xF3, 0x49, 0xC0,
+0x05, 0x6A, 0xA3, 0xF3, 0x52, 0xC8, 0xA3, 0xF3,
+0x5C, 0xA0, 0x00, 0x6C, 0x0E, 0x69, 0x05, 0x4A,
+0xA4, 0x67, 0xA3, 0xF3, 0x58, 0xC0, 0xA3, 0xF3,
+0x2A, 0xC0, 0xA3, 0xF3, 0x39, 0xC0, 0x00, 0x18,
+0xB2, 0x12, 0x02, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0xB2, 0x12, 0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0xB2, 0x12, 0x30, 0xF0, 0x20, 0x6C, 0x09, 0xF2,
+0x08, 0x4C, 0x00, 0x6D, 0x00, 0x18, 0x41, 0x2E,
+0xC0, 0xF0, 0x70, 0xA0, 0x02, 0x6A, 0xC0, 0xF0,
+0x4E, 0xC0, 0x0F, 0x6A, 0xC0, 0xF0, 0x4F, 0xC0,
+0x01, 0x6A, 0x6C, 0xEA, 0x28, 0x6B, 0x6D, 0xEA,
+0xC0, 0xF0, 0x50, 0xC0, 0x07, 0x6A, 0xC0, 0xF0,
+0x51, 0xC0, 0xA3, 0xF3, 0x5C, 0xA0, 0x00, 0x6C,
+0xA4, 0x67, 0x05, 0x4A, 0xA3, 0xF3, 0x58, 0xC0,
+0xA3, 0xF3, 0x39, 0xC0, 0x00, 0x18, 0x92, 0x31,
+0x01, 0x6C, 0x00, 0x6D, 0x00, 0x18, 0x92, 0x31,
+0x02, 0x6C, 0x00, 0x6D, 0x00, 0x18, 0x92, 0x31,
+0x03, 0x6C, 0x00, 0x6D, 0x00, 0x18, 0x92, 0x31,
+0x04, 0x6C, 0x00, 0x6D, 0x00, 0x18, 0x92, 0x31,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x48, 0x9A,
+0xF8, 0x69, 0x00, 0x6D, 0x60, 0xA2, 0xFF, 0x6C,
+0xC5, 0x67, 0x2C, 0xEB, 0x60, 0xC2, 0x00, 0x18,
+0x22, 0x2A, 0x00, 0x6A, 0x63, 0xF3, 0x5F, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x4C, 0x9A,
+0x60, 0xA2, 0x6C, 0xE9, 0x20, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0xE9, 0xF1, 0xB8, 0xA3,
+0x04, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x06, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x50, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x02, 0x6D, 0x00, 0x18, 0x71, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x40, 0x9A, 0x04, 0x69,
+0x30, 0xF0, 0x20, 0x68, 0x20, 0xDA, 0x45, 0xF6,
+0x18, 0x48, 0xC0, 0xF0, 0xD0, 0xA0, 0xFF, 0x6C,
+0x59, 0x4C, 0x00, 0x6D, 0xC6, 0x36, 0x00, 0x18,
+0xF1, 0x25, 0xA3, 0xF3, 0x40, 0xA0, 0x07, 0x97,
+0x4D, 0xE9, 0xA3, 0xF3, 0x20, 0xC0, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0xC0, 0xF0,
+0xA7, 0xA3, 0x04, 0x67, 0x7F, 0x6C, 0xAC, 0xEC,
+0xFF, 0x6A, 0x01, 0x74, 0x4C, 0xE8, 0x1D, 0x61,
+0xC0, 0xF0, 0xA8, 0xA3, 0x10, 0x6C, 0x8B, 0xEC,
+0xAC, 0xEC, 0x4C, 0xEC, 0x0E, 0x24, 0xD0, 0x67,
+0x0C, 0x6C, 0x00, 0x6D, 0x00, 0x18, 0x21, 0x15,
+0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18,
+0x22, 0x2A, 0x90, 0x67, 0x00, 0x18, 0x6E, 0x16,
+0x08, 0x10, 0xA3, 0xF3, 0x43, 0xA3, 0x05, 0x2A,
+0x04, 0x6C, 0x01, 0x6D, 0xD0, 0x67, 0x00, 0x18,
+0x21, 0x15, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x88, 0x16,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x8C, 0xE9, 0x30, 0xF0, 0x20, 0x68,
+0x91, 0x67, 0x45, 0xF6, 0x18, 0x48, 0x00, 0x18,
+0x6E, 0x16, 0xA3, 0xF3, 0x43, 0xA0, 0x0C, 0x72,
+0x17, 0x60, 0x0C, 0x6C, 0x00, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0x21, 0x15, 0x00, 0x6D, 0xC5, 0x67,
+0xFF, 0x6C, 0x00, 0x18, 0x22, 0x2A, 0xA3, 0xF3,
+0x61, 0xA0, 0xA0, 0xF0, 0x8A, 0xA0, 0x01, 0x6A,
+0x6D, 0xEA, 0x00, 0x6D, 0x08, 0x6E, 0xF1, 0x67,
+0xA3, 0xF3, 0x41, 0xC0, 0x00, 0x18, 0xF8, 0x18,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x24, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x45, 0xF6, 0x18, 0x4C, 0xA3, 0xF3,
+0xA0, 0xA4, 0x40, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB,
+0x4C, 0xEB, 0x4C, 0xE9, 0x09, 0x23, 0xA3, 0xF3,
+0x81, 0xA4, 0x10, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB,
+0x03, 0x23, 0x91, 0x67, 0x00, 0x18, 0xC0, 0x2D,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0xA3, 0xF3, 0x60, 0xA0, 0x02, 0x6A, 0x6C, 0xEA,
+0x10, 0x22, 0x03, 0x6A, 0x4B, 0xEA, 0x4C, 0xEB,
+0xA3, 0xF3, 0x60, 0xC0, 0xA3, 0xF3, 0x64, 0xA0,
+0x6C, 0xEA, 0xA3, 0xF3, 0x44, 0xC0, 0xA3, 0xF3,
+0x44, 0xA0, 0x07, 0x6B, 0x6C, 0xEA, 0x62, 0x2A,
+0x5E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x94, 0x9A, 0xFF, 0xF7, 0x1F, 0x6A, 0x60, 0xAC,
+0x4C, 0xEB, 0x01, 0x4B, 0x4C, 0xEB, 0x60, 0xCC,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7, 0x98, 0x9B,
+0x60, 0xAC, 0x4C, 0xEB, 0x01, 0x4B, 0x4C, 0xEB,
+0x60, 0xCC, 0x03, 0xF4, 0x50, 0x98, 0xA3, 0xF3,
+0x64, 0xA0, 0x01, 0x4A, 0x03, 0xF4, 0x50, 0xD8,
+0xA3, 0xF3, 0x4B, 0xA0, 0x01, 0x4A, 0xA3, 0xF3,
+0x4B, 0xC0, 0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xA3, 0xF3, 0x44, 0xC0, 0xA3, 0xF3, 0x6B, 0xA0,
+0xC0, 0xF0, 0x4E, 0xA0, 0x63, 0xEA, 0x33, 0x60,
+0xE0, 0xF0, 0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12,
+0x01, 0x6B, 0x6E, 0xEA, 0x2F, 0x2A, 0xC0, 0xF0,
+0x88, 0xA0, 0xEF, 0x4B, 0x8C, 0xEB, 0xFF, 0x6C,
+0x8C, 0xEB, 0x07, 0x2B, 0xA3, 0xF3, 0x60, 0xA0,
+0xDF, 0x4A, 0x6C, 0xEA, 0xA3, 0xF3, 0x40, 0xC0,
+0x21, 0x10, 0xA3, 0xF3, 0x6C, 0xA0, 0x01, 0x4B,
+0xA3, 0xF3, 0x6C, 0xC0, 0xA3, 0xF3, 0x6C, 0xA0,
+0x03, 0x5B, 0x0A, 0x61, 0xA3, 0xF3, 0x80, 0xA0,
+0x21, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xA3, 0xF3,
+0x60, 0xC0, 0xA3, 0xF3, 0x4C, 0xC0, 0x03, 0x10,
+0x91, 0x67, 0x00, 0x18, 0xA6, 0x16, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x00, 0x6B,
+0xA3, 0xF3, 0x6B, 0xC2, 0x03, 0x10, 0x91, 0x67,
+0x00, 0x18, 0xF1, 0x15, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x8C, 0xEA,
+0xC0, 0xF2, 0x9C, 0x9B, 0xC0, 0xF2, 0x1C, 0x4B,
+0x04, 0xD4, 0x81, 0x9B, 0x64, 0xAB, 0x05, 0xD4,
+0x9D, 0x67, 0x6C, 0xCC, 0x44, 0x33, 0x6D, 0xE4,
+0x88, 0xAB, 0x1F, 0xF7, 0x00, 0x6B, 0x8C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x0B, 0x2B,
+0x9D, 0x67, 0x44, 0x33, 0x6D, 0xE4, 0x88, 0xAB,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7, 0x7C, 0x9B,
+0x6D, 0xE4, 0x60, 0xAB, 0x06, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF7, 0x60, 0x9B, 0x71, 0xE4,
+0x60, 0xAC, 0xFF, 0xF7, 0x1F, 0x68, 0x6C, 0xE8,
+0x18, 0xF0, 0x00, 0x6B, 0x0C, 0xEB, 0x13, 0x2B,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6, 0x18, 0x4C,
+0xA3, 0xF3, 0xA4, 0xA4, 0xFE, 0x4B, 0xAC, 0xEB,
+0x05, 0x6D, 0xAB, 0xED, 0xAC, 0xEB, 0x02, 0x4D,
+0xAC, 0xEB, 0xA3, 0xF3, 0x64, 0xC4, 0x82, 0x67,
+0x00, 0x18, 0xF1, 0x15, 0x57, 0x10, 0x08, 0xF0,
+0x00, 0x6B, 0x0C, 0xEB, 0x20, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0xC0, 0xF0,
+0xA7, 0xA3, 0x7F, 0x6C, 0xAC, 0xEC, 0x01, 0x74,
+0x24, 0x61, 0xA3, 0xF3, 0xA4, 0xA3, 0x01, 0x6C,
+0xAD, 0xEC, 0xA3, 0xF3, 0x84, 0xC3, 0xC0, 0xF0,
+0x88, 0xA3, 0x10, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xFF, 0x6C, 0x8C, 0xEB, 0x20, 0x73, 0x03, 0x60,
+0x00, 0x18, 0xC2, 0x18, 0x12, 0x10, 0x82, 0x67,
+0x00, 0x18, 0xA6, 0x16, 0x0E, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0xA3, 0xF3,
+0x84, 0xA3, 0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x05, 0x6C, 0x8B, 0xEC, 0x8C, 0xEA, 0xA3, 0xF3,
+0x44, 0xC3, 0x02, 0x30, 0x1E, 0x30, 0x17, 0x20,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0xA3, 0xF3, 0x44, 0xA0, 0x02, 0x69, 0xC0, 0xF0,
+0xCF, 0xA0, 0x2D, 0xEA, 0xFF, 0x6C, 0xA3, 0xF3,
+0x44, 0xC0, 0x55, 0x4C, 0x00, 0x6D, 0x00, 0x18,
+0xF1, 0x25, 0xA3, 0xF3, 0x40, 0xA0, 0x4D, 0xE9,
+0xA3, 0xF3, 0x20, 0xC0, 0x0B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x84, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA3, 0xF3, 0x64, 0xC2, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF2, 0x70, 0x9A,
+0xC0, 0xF2, 0x10, 0x4A, 0x30, 0xF0, 0x20, 0x68,
+0x04, 0xD3, 0x61, 0x9A, 0xFF, 0x69, 0x44, 0xAA,
+0x45, 0xF6, 0x18, 0x48, 0x8C, 0xE9, 0xE0, 0xF0,
+0x8B, 0xA0, 0x05, 0xD3, 0x7D, 0x67, 0x4C, 0xCB,
+0x00, 0x18, 0x12, 0x12, 0x01, 0x72, 0xE0, 0xF0,
+0x0B, 0x61, 0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A,
+0xFF, 0x6D, 0x6C, 0xEA, 0xAC, 0xEA, 0xE0, 0xF0,
+0x03, 0x22, 0xC0, 0xF0, 0x68, 0xA0, 0x0F, 0x6A,
+0x6C, 0xEA, 0x01, 0x72, 0x3C, 0x61, 0x7D, 0x67,
+0x24, 0x32, 0x49, 0xE3, 0x68, 0xAA, 0x1F, 0xF7,
+0x00, 0x6A, 0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72,
+0x01, 0x60, 0x0B, 0x2A, 0x24, 0x32, 0xBD, 0x67,
+0x49, 0xE5, 0x68, 0xAA, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x5C, 0x9A, 0x49, 0xE3, 0x60, 0x9A,
+0x06, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7,
+0x40, 0x9A, 0x4D, 0xE3, 0x60, 0x9B, 0x04, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x0F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF6, 0x62, 0x34, 0x45, 0xF6,
+0x18, 0x4A, 0x62, 0x33, 0xA3, 0xF3, 0x89, 0xC2,
+0x62, 0x33, 0xFF, 0x6C, 0x8C, 0xEB, 0x02, 0x23,
+0xA3, 0xF3, 0x68, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3, 0x69, 0xA2,
+0x02, 0x2B, 0xA3, 0xF3, 0x68, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x09, 0xF2, 0x61, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0xA4, 0x9A, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x00, 0x6B,
+0xA3, 0xF3, 0x6B, 0xC0, 0xA3, 0xF3, 0x6C, 0xC0,
+0x80, 0xAD, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC,
+0x01, 0x4C, 0x4C, 0xEC, 0x80, 0xCD, 0x30, 0xF0,
+0x20, 0x6C, 0x20, 0xF7, 0xA8, 0x9C, 0x80, 0xAD,
+0x4C, 0xEC, 0x01, 0x4C, 0x4C, 0xEC, 0x80, 0xCD,
+0x03, 0xF4, 0x4C, 0x98, 0xA3, 0xF3, 0x92, 0xA0,
+0x01, 0x4A, 0x03, 0xF4, 0x4C, 0xD8, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF6, 0x58, 0x9A, 0x80, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x5C, 0x9A,
+0x91, 0x67, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x40, 0x9A, 0x02, 0x6B, 0x60, 0xC2,
+0xA3, 0xF3, 0x64, 0xA0, 0x03, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x11, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0xA3, 0xF3, 0x44, 0xC0, 0x00, 0x18, 0x0A, 0x17,
+0xA3, 0xF3, 0x60, 0xA0, 0x40, 0x6A, 0x6C, 0xEA,
+0x4E, 0x22, 0xA3, 0xF3, 0x81, 0xA0, 0x10, 0x6B,
+0xFF, 0x6D, 0x44, 0x67, 0x6C, 0xEA, 0xAC, 0xEA,
+0x1B, 0x2A, 0xA3, 0xF3, 0x49, 0xA0, 0xA3, 0xF3,
+0xA8, 0xA0, 0xAE, 0xEA, 0x40, 0x2A, 0x8D, 0xEB,
+0x91, 0x67, 0xA3, 0xF3, 0x61, 0xC0, 0x00, 0x18,
+0xBD, 0x2E, 0x91, 0x67, 0x00, 0x18, 0x97, 0x2D,
+0x91, 0x67, 0x00, 0x18, 0xC7, 0x2D, 0x91, 0x67,
+0x00, 0x18, 0xC0, 0x2D, 0xA3, 0xF3, 0x49, 0xA0,
+0xFF, 0x4A, 0xA3, 0xF3, 0x49, 0xC0, 0x2B, 0x10,
+0xC0, 0xF0, 0x68, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA,
+0x01, 0x72, 0x25, 0x61, 0xA3, 0xF3, 0x49, 0xA0,
+0x08, 0xD2, 0x08, 0x93, 0xA3, 0xF3, 0x48, 0xA0,
+0x6E, 0xEA, 0x1D, 0x22, 0x91, 0x67, 0x00, 0x18,
+0xB2, 0x2E, 0x08, 0x95, 0xAE, 0xEA, 0x17, 0x22,
+0xA3, 0xF3, 0x60, 0xA0, 0x20, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x22, 0xA3, 0xF3,
+0x61, 0xA0, 0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x91, 0x67, 0xA3, 0xF3, 0x41, 0xC0, 0x00, 0x18,
+0xB6, 0x2D, 0x91, 0x67, 0x00, 0x18, 0xA8, 0x2D,
+0x91, 0x67, 0x00, 0x18, 0xA1, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x80, 0xA2, 0x01, 0x6B, 0xA3, 0xF3, 0x6F, 0xC2,
+0x20, 0x6B, 0x8D, 0xEB, 0xA3, 0xF3, 0x60, 0xC2,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0xAC, 0xEA, 0x49, 0x22,
+0x05, 0x5C, 0x3D, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0x80, 0xF2, 0x1C, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0xAC, 0x9A, 0x01, 0x6C, 0x00, 0x18,
+0xB9, 0x07, 0x00, 0x6C, 0x08, 0x6D, 0x29, 0x10,
+0x04, 0x6C, 0x0F, 0x6D, 0x00, 0x18, 0xB9, 0x07,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0x60, 0xF6,
+0xBC, 0x9A, 0x1F, 0x10, 0x04, 0x6C, 0xF0, 0x6D,
+0x00, 0x18, 0xB9, 0x07, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0xE0, 0xF6, 0xB0, 0x9A, 0x15, 0x10,
+0x04, 0x6C, 0x01, 0xF7, 0x00, 0x6D, 0x00, 0x18,
+0xB9, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C,
+0xE0, 0xF6, 0xB4, 0x9A, 0x0A, 0x10, 0x04, 0x6C,
+0x1E, 0xF0, 0x00, 0x6D, 0x00, 0x18, 0xB9, 0x07,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0xB8, 0x9A,
+0x04, 0x6C, 0x00, 0x18, 0xB9, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x68, 0x9A, 0xFF, 0x6C,
+0x07, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0x45, 0x10, 0x05, 0x5C, 0x3D, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x88, 0x34, 0xA0, 0xF2, 0x10, 0x4A,
+0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0xAC, 0x9A, 0x01, 0x6C,
+0x00, 0x18, 0xEA, 0x07, 0x00, 0x6C, 0x08, 0x6D,
+0x29, 0x10, 0x04, 0x6C, 0x0F, 0x6D, 0x00, 0x18,
+0xEA, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C,
+0x60, 0xF6, 0xBC, 0x9A, 0x1F, 0x10, 0x04, 0x6C,
+0xF0, 0x6D, 0x00, 0x18, 0xEA, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x04, 0x6C, 0xE0, 0xF6, 0xB0, 0x9A,
+0x15, 0x10, 0x04, 0x6C, 0x01, 0xF7, 0x00, 0x6D,
+0x00, 0x18, 0xEA, 0x07, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0xE0, 0xF6, 0xB4, 0x9A, 0x0A, 0x10,
+0x04, 0x6C, 0x1E, 0xF0, 0x00, 0x6D, 0x00, 0x18,
+0xEA, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0xB8, 0x9A, 0x04, 0x6C, 0x00, 0x18, 0xEA, 0x07,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x68, 0x9A,
+0xF8, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x68, 0x24, 0x67, 0x0C, 0xE9, 0x91, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0xE3, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x92, 0xAA, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6,
+0x78, 0x9B, 0x0C, 0xEC, 0x80, 0xC3, 0xC0, 0xF0,
+0xAD, 0xA2, 0x80, 0x6B, 0x6B, 0xEB, 0x1F, 0x6C,
+0xAC, 0xEB, 0xAC, 0xEC, 0x0C, 0xEB, 0x0C, 0xEC,
+0x10, 0x23, 0x8F, 0x33, 0x0C, 0xEB, 0x03, 0xF4,
+0x74, 0xC2, 0x01, 0x4B, 0x03, 0xF4, 0x75, 0xC2,
+0xC0, 0xF0, 0x4A, 0xA2, 0x07, 0x6B, 0x8C, 0xEB,
+0x56, 0x32, 0x4C, 0x32, 0x4D, 0xEB, 0x0C, 0xEB,
+0x06, 0x10, 0x02, 0x6C, 0x03, 0xF4, 0x94, 0xC2,
+0x03, 0x6C, 0x03, 0xF4, 0x95, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x4C, 0x9A, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x60, 0xC2,
+0xE0, 0xF0, 0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12,
+0x01, 0x72, 0x12, 0x61, 0xA3, 0xF3, 0x60, 0xA0,
+0x21, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xA3, 0xF3,
+0x40, 0xC0, 0xA3, 0xF3, 0x43, 0xA0, 0x04, 0x6B,
+0x6C, 0xEA, 0x0C, 0x2A, 0x83, 0x67, 0x01, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x21, 0x15, 0x06, 0x10,
+0xA3, 0xF3, 0x60, 0xA0, 0x20, 0x6A, 0x6D, 0xEA,
+0xA3, 0xF3, 0x40, 0xC0, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x04, 0x67, 0x2C, 0xE8, 0xAC, 0xE9,
+0x42, 0x28, 0x91, 0x67, 0x00, 0x6D, 0x00, 0x18,
+0xE3, 0x17, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x5C, 0x9A, 0x02, 0x6B, 0x00, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x40, 0x9A, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x60, 0xDA,
+0xE0, 0xF0, 0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12,
+0x19, 0x2A, 0xA3, 0xF3, 0x43, 0xA0, 0x04, 0x6B,
+0x6C, 0xEA, 0x02, 0x2A, 0x00, 0x18, 0x4C, 0x2F,
+0x91, 0x67, 0x00, 0x18, 0xF3, 0x14, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0xA3, 0xF3,
+0x81, 0xA3, 0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x03, 0x6C, 0x8B, 0xEC, 0x8C, 0xEA, 0xA3, 0xF3,
+0x41, 0xC3, 0x05, 0x10, 0x0C, 0x6C, 0x01, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x21, 0x15, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x80, 0xA2, 0x05, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA3, 0xF3, 0x60, 0xC2, 0x07, 0x10, 0x01, 0x70,
+0x05, 0x61, 0x91, 0x67, 0x00, 0x18, 0x30, 0x18,
+0x00, 0x18, 0x50, 0x38, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x45, 0xF6, 0x18, 0x48, 0x04, 0xD4, 0x00, 0x18,
+0x69, 0x14, 0xC0, 0xF0, 0x87, 0xA0, 0x7F, 0x6A,
+0x04, 0x95, 0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18,
+0x62, 0x18, 0xC0, 0xF0, 0x47, 0xA0, 0x7F, 0x6B,
+0x6C, 0xEA, 0x2C, 0xEA, 0x09, 0x22, 0xC0, 0xF0,
+0x48, 0xA0, 0x0F, 0x6C, 0xC0, 0xF0, 0xA9, 0xA0,
+0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18, 0xE4, 0x12,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x70, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0x6D, 0xE5, 0x00, 0xA3,
+0x3F, 0x6F, 0x01, 0x74, 0x0C, 0xEF, 0x4C, 0xEE,
+0xE0, 0xC3, 0x10, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF7, 0xF4, 0x9C, 0x10, 0x68, 0xFD, 0xE5,
+0x80, 0xA7, 0x4C, 0xEC, 0x0D, 0xEC, 0x4C, 0xEC,
+0x80, 0xC7, 0x80, 0xA3, 0x80, 0x6F, 0xEB, 0xEF,
+0x4C, 0xEC, 0x0D, 0x10, 0x0F, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x20, 0xF7, 0xF4, 0x9C, 0xEF, 0x6C,
+0xFD, 0xE5, 0x00, 0xA7, 0x0C, 0xEC, 0x80, 0xC7,
+0x80, 0xA3, 0x40, 0x6F, 0x4C, 0xEC, 0xED, 0xEC,
+0x4C, 0xEC, 0x80, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x58, 0x9A, 0x80, 0xF4, 0xC0, 0x36,
+0x55, 0xE5, 0x40, 0x9D, 0x4D, 0xEE, 0xC0, 0xDD,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x5C, 0x9A, 0xFF, 0x6B, 0x40, 0xA2,
+0x6C, 0xEA, 0x52, 0x32, 0x6C, 0xEA, 0x0B, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF7, 0x81, 0xA2,
+0x00, 0x6D, 0x18, 0x6E, 0xE5, 0x67, 0x00, 0x18,
+0x55, 0x32, 0x00, 0x18, 0x95, 0x32, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x2C, 0xEC,
+0x2C, 0xED, 0x02, 0x5C, 0x04, 0xD4, 0x05, 0xD5,
+0x41, 0x60, 0x00, 0x18, 0xD4, 0x1D, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF7, 0x60, 0x9B, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x80, 0xAB,
+0xFF, 0xF7, 0x1F, 0x6B, 0x8C, 0xEB, 0x4B, 0xE3,
+0xA0, 0xF0, 0x6A, 0xA0, 0x2C, 0xEA, 0x6E, 0xEA,
+0x2D, 0x2A, 0xA3, 0xF3, 0x43, 0xA0, 0x0E, 0x72,
+0x12, 0x61, 0x04, 0x92, 0x27, 0x2A, 0xA3, 0xF3,
+0x61, 0xA0, 0x05, 0x94, 0xFD, 0x4A, 0x6C, 0xEA,
+0x00, 0x6D, 0xA3, 0xF3, 0x41, 0xC0, 0x00, 0x18,
+0x92, 0x31, 0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0xB2, 0x12, 0x91, 0x67, 0x13, 0x10, 0x06, 0x72,
+0x15, 0x61, 0x04, 0x92, 0x13, 0x22, 0xA3, 0xF3,
+0x61, 0xA0, 0x05, 0x94, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x01, 0x6D, 0xA3, 0xF3, 0x41, 0xC0,
+0x00, 0x18, 0x92, 0x31, 0x04, 0x6A, 0xA3, 0xF3,
+0x43, 0xC0, 0xFF, 0x6C, 0x00, 0x6D, 0xC5, 0x67,
+0x00, 0x18, 0x22, 0x2A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x20, 0xF7,
+0x7C, 0x9B, 0x4C, 0xEE, 0x4C, 0xEF, 0x05, 0xD6,
+0x04, 0xD7, 0x60, 0xA3, 0xFF, 0xF7, 0x1F, 0x68,
+0x25, 0x67, 0x4C, 0xEB, 0x72, 0x33, 0x4C, 0xEB,
+0x8C, 0xE8, 0x4C, 0xE9, 0x25, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF6, 0x6C, 0x9B, 0x00, 0x6C,
+0xFF, 0x6D, 0x60, 0xA3, 0x26, 0x6E, 0x6C, 0xEA,
+0x06, 0xD2, 0x00, 0x18, 0x22, 0x2A, 0x00, 0x18,
+0xC8, 0x2E, 0x01, 0x72, 0x0B, 0x61, 0x05, 0x96,
+0x90, 0x67, 0x01, 0x6D, 0x00, 0x6F, 0x00, 0x18,
+0x55, 0x32, 0x04, 0x96, 0x91, 0x67, 0xA2, 0x67,
+0x00, 0x18, 0xA3, 0x18, 0x06, 0x95, 0x00, 0x6C,
+0x27, 0x6E, 0x00, 0x18, 0x22, 0x2A, 0x04, 0x95,
+0x91, 0x67, 0x00, 0x18, 0xCF, 0x18, 0x0F, 0x10,
+0x04, 0x95, 0x91, 0x67, 0x00, 0x18, 0xCF, 0x18,
+0x05, 0x96, 0x90, 0x67, 0x01, 0x6D, 0x00, 0x6F,
+0x00, 0x18, 0x55, 0x32, 0x04, 0x96, 0x91, 0x67,
+0xA2, 0x67, 0x00, 0x18, 0xA3, 0x18, 0x00, 0x18,
+0x95, 0x32, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x68, 0xF4, 0x50, 0xA2, 0xFF, 0x68, 0x24, 0x67,
+0x02, 0x72, 0x0C, 0xE9, 0x03, 0x61, 0x01, 0x71,
+0x0D, 0x61, 0x1A, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF7, 0x48, 0x9A, 0x01, 0x6B, 0x6B, 0xEB,
+0x60, 0xC2, 0x64, 0x6C, 0x00, 0x18, 0x7D, 0x1E,
+0x00, 0x18, 0x4C, 0x2E, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF7, 0x64, 0x9A, 0x80, 0x6C, 0x8B, 0xEC,
+0x40, 0xA3, 0x0C, 0xEA, 0x8E, 0xEA, 0x0C, 0xEA,
+0x40, 0xC3, 0x91, 0x67, 0x00, 0x18, 0x43, 0x25,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x6A, 0xCC, 0xEA,
+0x00, 0x6B, 0x09, 0x10, 0x79, 0xE5, 0xE0, 0xA4,
+0xC0, 0xA6, 0x01, 0x4B, 0x01, 0x4C, 0xEE, 0xEE,
+0x02, 0x26, 0x00, 0x6A, 0x20, 0xE8, 0xFF, 0x6E,
+0x6C, 0xEE, 0x43, 0xEE, 0xF3, 0x61, 0x01, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA0, 0xF0, 0x8F, 0xA2,
+0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0,
+0x6F, 0xC2, 0x00, 0x6B, 0xA0, 0xF0, 0x70, 0xC2,
+0xA0, 0xF0, 0x71, 0xC2, 0x43, 0xF4, 0x70, 0xC2,
+0x43, 0xF4, 0x71, 0xC2, 0x43, 0xF4, 0x72, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF7, 0x6C, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC,
+0xA0, 0xAB, 0xE1, 0xF7, 0x1F, 0x6B, 0xAC, 0xEB,
+0x71, 0xE4, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF7, 0x50, 0x9A, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF7, 0x54, 0x9A, 0x80, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0x43, 0xF4, 0x44, 0xA0, 0x43, 0xF4,
+0x62, 0xA8, 0x5A, 0xEB, 0x01, 0x2A, 0xE5, 0xE8,
+0x10, 0xEA, 0x03, 0x2A, 0xA0, 0xF0, 0x96, 0xA0,
+0x13, 0x10, 0x01, 0x72, 0x03, 0x61, 0xA0, 0xF0,
+0x97, 0xA0, 0x0E, 0x10, 0x02, 0x72, 0x03, 0x61,
+0xA0, 0xF0, 0x98, 0xA0, 0x09, 0x10, 0x03, 0x72,
+0x03, 0x61, 0xA0, 0xF0, 0x99, 0xA0, 0x04, 0x10,
+0x04, 0x72, 0x09, 0x61, 0xA0, 0xF0, 0x9A, 0xA0,
+0x00, 0x18, 0x4F, 0x19, 0x43, 0xF4, 0x42, 0xA8,
+0x01, 0x4A, 0x43, 0xF4, 0x42, 0xC8, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0xA0, 0xF0,
+0x6F, 0xA0, 0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xA0, 0xF0, 0x4F, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0xBC, 0x9A, 0x01, 0x6C, 0x00, 0x18,
+0xEA, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7,
+0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6D, 0x40, 0xF7,
+0xB0, 0x9D, 0x80, 0x9A, 0xE1, 0xF7, 0x1F, 0x6B,
+0x6C, 0xEC, 0x80, 0xCD, 0x80, 0x9A, 0x30, 0xF0,
+0x20, 0x6D, 0x40, 0xF7, 0xA0, 0x9D, 0x6C, 0xEC,
+0x80, 0xCD, 0x40, 0x9A, 0x42, 0x32, 0x42, 0x32,
+0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF7,
+0x74, 0x9B, 0x40, 0xCB, 0x00, 0x6A, 0x43, 0xF4,
+0x42, 0xC8, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xE3, 0x63, 0x39, 0x62,
+0x38, 0xD1, 0x37, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA0, 0xF0, 0x7B, 0xA2,
+0x9D, 0x67, 0x20, 0xF0, 0x60, 0xC4, 0xA0, 0xF0,
+0x7C, 0xA2, 0x20, 0xF0, 0x61, 0xC4, 0xA0, 0xF0,
+0x7D, 0xA2, 0x20, 0xF0, 0x62, 0xC4, 0xA0, 0xF0,
+0x7E, 0xA2, 0x20, 0xF0, 0x63, 0xC4, 0xA0, 0xF0,
+0x7F, 0xA2, 0x20, 0xF0, 0x64, 0xC4, 0x43, 0xF4,
+0x66, 0xA2, 0x20, 0xF0, 0x68, 0xC4, 0x43, 0xF4,
+0x67, 0xA2, 0x20, 0xF0, 0x69, 0xC4, 0x43, 0xF4,
+0x68, 0xA2, 0x20, 0xF0, 0x6A, 0xC4, 0x43, 0xF4,
+0x69, 0xA2, 0x20, 0xF0, 0x6B, 0xC4, 0x43, 0xF4,
+0x6A, 0xA2, 0x20, 0xF0, 0x6C, 0xC4, 0x43, 0xF4,
+0x6B, 0xA2, 0x20, 0xF0, 0x70, 0xC4, 0x43, 0xF4,
+0x6C, 0xA2, 0x20, 0xF0, 0x71, 0xC4, 0x43, 0xF4,
+0x6D, 0xA2, 0x20, 0xF0, 0x72, 0xC4, 0x43, 0xF4,
+0x6E, 0xA2, 0x20, 0xF0, 0x73, 0xC4, 0x43, 0xF4,
+0x6F, 0xA2, 0x20, 0xF0, 0x74, 0xC4, 0x00, 0x6B,
+0x20, 0xF0, 0x78, 0xC4, 0x20, 0xF0, 0x79, 0xC4,
+0x20, 0xF0, 0x7A, 0xC4, 0x20, 0xF0, 0x7B, 0xC4,
+0x43, 0xF4, 0x44, 0xA2, 0x20, 0xF0, 0x7C, 0xC4,
+0x0E, 0x03, 0x69, 0xE2, 0x03, 0x10, 0x01, 0x6C,
+0x80, 0xC3, 0x01, 0x4B, 0x4A, 0xEB, 0xFB, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7, 0x4C, 0x9A,
+0xE1, 0xF7, 0x1F, 0x6E, 0xFF, 0xF7, 0x1F, 0x69,
+0x40, 0xAA, 0x1C, 0x05, 0x12, 0x04, 0x4C, 0xEE,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0x44, 0x9A,
+0x17, 0x03, 0x40, 0xAA, 0x2F, 0xD6, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x6A, 0x89, 0xF2, 0xFC, 0xA2,
+0x00, 0x6A, 0x2E, 0xD7, 0x21, 0x10, 0xFD, 0x67,
+0x59, 0xE7, 0x20, 0xF0, 0x00, 0xA6, 0x2F, 0x96,
+0x30, 0xF0, 0x20, 0x6F, 0x01, 0xE6, 0x60, 0xF7,
+0xC8, 0x9F, 0x1C, 0x30, 0x00, 0xDD, 0x1D, 0xE6,
+0xC0, 0xA7, 0xFD, 0x67, 0x5D, 0xE7, 0xD8, 0xC7,
+0x30, 0xF0, 0x20, 0x6E, 0x60, 0xF7, 0xEC, 0x9E,
+0x01, 0x4A, 0x04, 0x4D, 0xF9, 0xE0, 0x30, 0xF0,
+0x20, 0x6F, 0xC0, 0xDC, 0x60, 0xF7, 0xD0, 0x9F,
+0x04, 0x4C, 0xC1, 0xE0, 0x00, 0xDB, 0x04, 0x4B,
+0x2E, 0x97, 0xFF, 0x68, 0x4C, 0xE8, 0xE3, 0xE8,
+0xDA, 0x61, 0x00, 0x68, 0x31, 0xD0, 0x83, 0x12,
+0x7D, 0x67, 0x00, 0x6A, 0x40, 0xF0, 0x40, 0xC3,
+0x40, 0xF0, 0x41, 0xC3, 0x40, 0xF0, 0x42, 0xC3,
+0x40, 0xF0, 0x43, 0xC3, 0x40, 0xF0, 0x44, 0xC3,
+0x81, 0x41, 0x00, 0x18, 0xC8, 0x1D, 0x02, 0x67,
+0x91, 0x67, 0x00, 0x18, 0xC8, 0x1D, 0x00, 0x30,
+0x4D, 0xE8, 0x82, 0x41, 0xE7, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE8, 0x00, 0x18, 0xC8, 0x1D, 0x0F, 0x6B,
+0x4C, 0xEB, 0xFF, 0x6C, 0x6C, 0x33, 0x8C, 0xEB,
+0x87, 0x41, 0x32, 0xD3, 0x00, 0x18, 0xC8, 0x1D,
+0x32, 0x95, 0xFF, 0x6E, 0x34, 0xD2, 0x18, 0x4D,
+0x30, 0xD5, 0xCC, 0xED, 0x31, 0xE5, 0x2F, 0xD5,
+0x00, 0x18, 0xC8, 0x1D, 0x30, 0x97, 0x33, 0xD2,
+0xF1, 0xE0, 0x00, 0x18, 0xA8, 0x30, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x2E, 0x90, 0x29, 0xE2,
+0x30, 0xD2, 0x30, 0x93, 0x02, 0xF6, 0x50, 0x98,
+0x63, 0xEA, 0x03, 0x60, 0x4F, 0xEA, 0x4D, 0xE3,
+0x30, 0xD3, 0x33, 0x94, 0x04, 0x6A, 0x4B, 0xEA,
+0x8C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x40, 0x72,
+0x00, 0xF1, 0x16, 0x61, 0x2F, 0x95, 0x87, 0x41,
+0x11, 0x4C, 0xB1, 0xE4, 0x00, 0x18, 0xC8, 0x1D,
+0x00, 0xF1, 0x03, 0x2A, 0x2F, 0x96, 0x87, 0x41,
+0x12, 0x4C, 0xD1, 0xE4, 0x00, 0x18, 0xC8, 0x1D,
+0x32, 0x97, 0x2F, 0xD2, 0x00, 0x6A, 0xE1, 0xE1,
+0x32, 0x48, 0x2E, 0xD2, 0x0B, 0x10, 0x90, 0x67,
+0x00, 0x18, 0xC8, 0x1D, 0x2E, 0x95, 0x9D, 0x67,
+0x01, 0x48, 0xAD, 0xE4, 0x01, 0x4D, 0x80, 0xF0,
+0x44, 0xC3, 0x2E, 0xD5, 0x2E, 0x96, 0x2F, 0x97,
+0xFF, 0x6A, 0xCC, 0xEA, 0xE3, 0xEA, 0xEF, 0x61,
+0x00, 0x68, 0x46, 0x2F, 0x30, 0xF0, 0x20, 0x6C,
+0x89, 0xF2, 0x9C, 0xA4, 0x10, 0x02, 0x0A, 0x03,
+0x51, 0xE4, 0x5C, 0x10, 0x06, 0x02, 0x0D, 0xE2,
+0x2E, 0xD3, 0x2F, 0x94, 0x60, 0xA3, 0x8E, 0xEB,
+0x0D, 0x2B, 0x08, 0x33, 0x69, 0xE2, 0x8C, 0x9A,
+0x2F, 0x96, 0x21, 0x05, 0x00, 0x18, 0x39, 0x19,
+0x05, 0x22, 0x2E, 0x95, 0x01, 0x6A, 0x20, 0xF0,
+0x48, 0xC5, 0x27, 0x10, 0x2F, 0x96, 0x03, 0x76,
+0x1F, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xE0, 0xF0,
+0x0C, 0x4C, 0x21, 0x05, 0x03, 0x6E, 0x00, 0x18,
+0x39, 0x19, 0x09, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0xE0, 0xF0, 0x10, 0x4C, 0x21, 0x05, 0x03, 0x6E,
+0x00, 0x18, 0x39, 0x19, 0x08, 0x22, 0x06, 0x02,
+0x09, 0xE2, 0x78, 0xA2, 0x0B, 0x2B, 0x90, 0xA2,
+0x0A, 0x2C, 0x01, 0x6B, 0x08, 0x10, 0xFD, 0x67,
+0x0D, 0xE7, 0x40, 0xF0, 0x40, 0xC3, 0x05, 0x10,
+0x06, 0x02, 0x09, 0xE2, 0x00, 0x6B, 0x20, 0xF0,
+0x68, 0xC2, 0x01, 0x48, 0xFF, 0x6A, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x89, 0xF2, 0x5C, 0xA2,
+0x43, 0xE8, 0xBC, 0x61, 0x1D, 0x67, 0x40, 0xF0,
+0x40, 0xA0, 0x1A, 0x2A, 0x40, 0xF0, 0x41, 0xA0,
+0x17, 0x2A, 0x40, 0xF0, 0x42, 0xA0, 0x14, 0x2A,
+0x40, 0xF0, 0x43, 0xA0, 0x11, 0x2A, 0x40, 0xF0,
+0x44, 0xA0, 0x1C, 0x10, 0xA0, 0xA3, 0x02, 0x25,
+0x00, 0x6D, 0x01, 0x10, 0x01, 0x6D, 0xA0, 0xC2,
+0x01, 0x4B, 0x01, 0x4A, 0x8A, 0xEA, 0xF6, 0x61,
+0x7D, 0x67, 0x40, 0xF0, 0x40, 0xA3, 0x02, 0x22,
+0x00, 0x68, 0x6F, 0x10, 0x9D, 0x67, 0x40, 0xF0,
+0x41, 0xA4, 0xFA, 0x2A, 0x40, 0xF0, 0x42, 0xA4,
+0xF7, 0x2A, 0x40, 0xF0, 0x43, 0xA4, 0xF4, 0x2A,
+0x40, 0xF0, 0x44, 0xA4, 0x6A, 0x22, 0xF0, 0x17,
+0xBD, 0x67, 0x0D, 0xE5, 0x40, 0xF0, 0x60, 0xA3,
+0x59, 0x23, 0xC0, 0xF0, 0x95, 0xA2, 0x01, 0x6B,
+0x6C, 0xEC, 0x0F, 0x24, 0x03, 0xF4, 0x5C, 0xA2,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x4E, 0x22,
+0x08, 0x10, 0xE0, 0xF3, 0x09, 0x72, 0x0F, 0x60,
+0x01, 0x4A, 0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x01, 0x10, 0x00, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x74, 0x9B, 0x02, 0xF0, 0x00, 0x6C,
+0x60, 0x9B, 0x8C, 0xEB, 0xEE, 0x2B, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF7, 0x54, 0x9A, 0x02, 0xF0,
+0x00, 0x6B, 0x40, 0x9A, 0x6C, 0xEA, 0x32, 0x2A,
+0xDD, 0x67, 0x09, 0xE6, 0x20, 0xF0, 0x80, 0xA2,
+0x01, 0x6D, 0x08, 0x6E, 0x04, 0x6F, 0x00, 0x18,
+0x55, 0x32, 0xFF, 0xF7, 0x1F, 0x6C, 0x4C, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0x40, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF7, 0x7C, 0x9B,
+0x51, 0xE4, 0x30, 0xF0, 0x20, 0x6A, 0x32, 0x95,
+0x60, 0xF7, 0x58, 0x9A, 0x6D, 0xE1, 0x18, 0x4D,
+0x49, 0xE1, 0xAD, 0xE3, 0xB5, 0xE2, 0x40, 0xA3,
+0xFF, 0x6F, 0x01, 0x4B, 0xEC, 0xEA, 0xAA, 0xEB,
+0x40, 0xC4, 0x01, 0x4C, 0xF8, 0x61, 0x00, 0x18,
+0x95, 0x32, 0x20, 0x6B, 0x4D, 0xEB, 0xFF, 0x6A,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7,
+0x5C, 0x9A, 0x60, 0xC2, 0x01, 0x48, 0xFF, 0x6A,
+0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x43, 0xF4, 0x64, 0xA2, 0x63, 0xE8,
+0x97, 0x61, 0x30, 0x94, 0x00, 0x18, 0x83, 0x30,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7, 0x40, 0x9A,
+0x23, 0x6B, 0x6B, 0xEB, 0x60, 0xC2, 0x22, 0x11,
+0x34, 0x94, 0x40, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x6C, 0xEA, 0x04, 0x22, 0x30, 0x94, 0x00, 0x18,
+0x83, 0x30, 0x18, 0x11, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF7, 0x44, 0x9A, 0x2F, 0x95, 0x49, 0xE1,
+0xA9, 0xE2, 0x80, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF7, 0x48, 0x9A, 0x6C, 0xEC, 0x80, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7, 0x4C, 0x9A,
+0x49, 0xE1, 0xA9, 0xE2, 0x40, 0xA2, 0x4C, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7, 0x50, 0x9A,
+0x60, 0xC2, 0x00, 0x6B, 0x4F, 0x10, 0xFF, 0x6E,
+0x02, 0x67, 0xCC, 0xE8, 0x02, 0x58, 0x34, 0x60,
+0xE2, 0xF0, 0x0C, 0x42, 0x1F, 0xF7, 0x00, 0x6F,
+0xEC, 0xE8, 0x02, 0xF0, 0x00, 0x70, 0x01, 0x60,
+0x09, 0x28, 0x30, 0xF0, 0x20, 0x6E, 0x80, 0xF7,
+0x14, 0x9E, 0xC0, 0xA4, 0x01, 0xE2, 0x1E, 0x65,
+0xFF, 0x6E, 0x07, 0x10, 0x30, 0xF0, 0x20, 0x68,
+0x80, 0xF7, 0x18, 0x98, 0xE0, 0xA4, 0x01, 0xE2,
+0x1F, 0x65, 0xF8, 0x67, 0xEC, 0xEE, 0xC0, 0xC0,
+0x1F, 0xF7, 0x00, 0x6E, 0xAC, 0xEE, 0x02, 0xF0,
+0x00, 0x76, 0x01, 0x60, 0x05, 0x2E, 0x30, 0xF0,
+0x20, 0x6E, 0x80, 0xF7, 0xDC, 0x9E, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6E, 0xA0, 0xF7, 0xC0, 0x9E,
+0x68, 0x30, 0xFD, 0x67, 0x01, 0xE7, 0x17, 0x98,
+0xD9, 0xE2, 0x41, 0xE0, 0x00, 0xA0, 0x00, 0xC6,
+0x00, 0xA4, 0xFF, 0x6E, 0xFF, 0x67, 0x0C, 0xEE,
+0x41, 0xE7, 0x00, 0xA0, 0x0E, 0xEE, 0x06, 0x26,
+0x06, 0x02, 0x69, 0xE2, 0x00, 0x6C, 0x20, 0xF0,
+0x80, 0xC2, 0x05, 0x10, 0x01, 0x4A, 0x06, 0x72,
+0x01, 0x4C, 0x01, 0x4D, 0xB4, 0x61, 0x01, 0x4B,
+0xFF, 0x6A, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x89, 0xF2, 0x5C, 0xA2, 0x43, 0xEB, 0x11, 0x60,
+0x68, 0x32, 0x1D, 0x67, 0x49, 0xE0, 0xF7, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7, 0x98, 0x9A,
+0x32, 0x92, 0xE2, 0xF0, 0x0E, 0x6D, 0x91, 0xE1,
+0x18, 0x4A, 0x51, 0xE4, 0xFF, 0x65, 0x00, 0x6A,
+0x9A, 0x17, 0x9D, 0x67, 0x20, 0xF0, 0x78, 0xA4,
+0x01, 0x73, 0x12, 0x60, 0x20, 0xF0, 0x79, 0xA4,
+0x01, 0x73, 0x0E, 0x60, 0x20, 0xF0, 0x7A, 0xA4,
+0x01, 0x73, 0x0A, 0x60, 0x20, 0xF0, 0x7B, 0xA4,
+0x01, 0x73, 0x06, 0x60, 0x20, 0xF0, 0x7C, 0xA4,
+0x01, 0x73, 0x02, 0x60, 0x31, 0x95, 0x65, 0x25,
+0x00, 0x18, 0x74, 0x19, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xC0, 0xF0, 0x95, 0xA2,
+0x02, 0x6B, 0x8C, 0xEB, 0x07, 0x23, 0xA3, 0xF3,
+0x60, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x45, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x44, 0x9A, 0x66, 0x6B, 0x00, 0x6C,
+0x60, 0xC2, 0x00, 0x18, 0x21, 0x19, 0x30, 0xF0,
+0x20, 0x6A, 0xA9, 0xF2, 0x48, 0xA2, 0x01, 0x6E,
+0x31, 0xD6, 0x5C, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x60, 0x9A, 0xFF, 0x6C, 0x01, 0x4C,
+0x40, 0x9B, 0x8C, 0xEA, 0x01, 0x22, 0x80, 0xDB,
+0xFF, 0x68, 0x01, 0x48, 0x00, 0x6C, 0xB0, 0x67,
+0x00, 0x18, 0x1D, 0x08, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x43, 0xF4, 0xD1, 0xA2,
+0x09, 0x26, 0x42, 0xF1, 0x1C, 0x6C, 0x01, 0x6D,
+0xCC, 0x36, 0x00, 0x18, 0xF1, 0x25, 0x01, 0x6F,
+0x31, 0xD7, 0x3C, 0x10, 0x43, 0xF4, 0xD2, 0xA2,
+0x09, 0x26, 0x42, 0xF1, 0x1C, 0x6C, 0x01, 0x6D,
+0xC4, 0x36, 0x01, 0x68, 0x00, 0x18, 0x0E, 0x26,
+0x31, 0xD0, 0x30, 0x10, 0x42, 0xF1, 0x1C, 0x6C,
+0x01, 0x6D, 0xD0, 0x67, 0x00, 0x18, 0xF1, 0x25,
+0x01, 0x6A, 0x31, 0xD2, 0x27, 0x10, 0x10, 0xF0,
+0x20, 0x6C, 0x01, 0x6F, 0x2D, 0xF5, 0x0D, 0x4C,
+0x00, 0x6D, 0x03, 0x6E, 0xEB, 0xEF, 0x04, 0xD2,
+0x00, 0x18, 0xCB, 0x2A, 0x01, 0x6B, 0x31, 0xD3,
+0x19, 0x10, 0x00, 0x6B, 0x9D, 0x67, 0x20, 0xF0,
+0x78, 0xC4, 0x20, 0xF0, 0x79, 0xC4, 0x20, 0xF0,
+0x7A, 0xC4, 0x20, 0xF0, 0x7B, 0xC4, 0x20, 0xF0,
+0x7C, 0xC4, 0x0E, 0x03, 0x69, 0xE2, 0x03, 0x10,
+0x01, 0x6C, 0x80, 0xC3, 0x01, 0x4B, 0x4A, 0xEB,
+0xFB, 0x61, 0x30, 0x94, 0x00, 0x18, 0x83, 0x30,
+0x00, 0x6D, 0x31, 0xD5, 0x30, 0x91, 0x00, 0x18,
+0xDD, 0x1D, 0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6E,
+0x45, 0xF6, 0x18, 0x4E, 0x2E, 0xD6, 0xA0, 0xF0,
+0x6F, 0xA6, 0x01, 0x6A, 0x6C, 0xEA, 0x7F, 0xF5,
+0x0F, 0x2A, 0x39, 0x97, 0x38, 0x91, 0x37, 0x90,
+0x1D, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x48, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7,
+0x6C, 0x9B, 0x40, 0x9A, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0x6C, 0xEA, 0x01, 0x6C,
+0x02, 0xF6, 0x50, 0xD8, 0x00, 0x18, 0x07, 0x31,
+0xA0, 0xF0, 0x6F, 0xA0, 0x01, 0x6A, 0x01, 0x6C,
+0x6D, 0xEA, 0xA0, 0xF0, 0x4F, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0xBC, 0x9A, 0x00, 0x18,
+0xB9, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x50, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7,
+0x98, 0x9C, 0x60, 0xA2, 0x07, 0x6A, 0x6C, 0xEA,
+0x01, 0x4A, 0x43, 0xF4, 0x44, 0xC0, 0x00, 0x6A,
+0x43, 0xF4, 0x42, 0xC8, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x74, 0x9A, 0x40, 0x9B, 0x8C, 0xEA,
+0x40, 0xDB, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xC0, 0xF0, 0x95, 0xA2, 0x02, 0x6B, 0x8C, 0xEB,
+0x07, 0x23, 0xA3, 0xF3, 0x60, 0xA2, 0x01, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x0F, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x44, 0x9A,
+0x66, 0x6B, 0x00, 0x6C, 0x60, 0xC2, 0x00, 0x18,
+0x21, 0x19, 0x10, 0xF0, 0x20, 0x6C, 0x2D, 0xF5,
+0x0D, 0x4C, 0x00, 0x18, 0xB8, 0x2A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x05, 0xF7,
+0x13, 0x4C, 0x05, 0x6E, 0x00, 0x18, 0xA1, 0x1E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x05, 0xF7, 0x0E, 0x4C, 0x05, 0x6E,
+0x00, 0x18, 0xA1, 0x1E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x60, 0xA4, 0x01, 0x6A,
+0x04, 0x67, 0x6C, 0xEA, 0x0B, 0x22, 0x00, 0x18,
+0x2B, 0x1B, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x44, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x00, 0x18,
+0x25, 0x26, 0x1B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA9, 0xF2, 0x48, 0xA2, 0x14, 0x22, 0xFF, 0x69,
+0x01, 0x49, 0x00, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x3A, 0x08, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x60, 0x9A, 0x40, 0x9B, 0x2C, 0xEA, 0x01, 0x22,
+0x20, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x5C, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x00, 0x18,
+0x74, 0x19, 0x61, 0xA0, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA0, 0xF0, 0x70, 0xC2,
+0x62, 0xA0, 0x02, 0x6F, 0x01, 0x68, 0x04, 0x6E,
+0x08, 0x6D, 0x10, 0x6C, 0x6C, 0xE8, 0x6C, 0xEF,
+0x6C, 0xEE, 0x6C, 0xED, 0x6C, 0xEC, 0xA0, 0xF0,
+0x71, 0xC2, 0x43, 0xF4, 0x06, 0xC2, 0x43, 0xF4,
+0xE7, 0xC2, 0x43, 0xF4, 0xC8, 0xC2, 0x43, 0xF4,
+0xA9, 0xC2, 0x43, 0xF4, 0x8A, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x00, 0x6B, 0x02, 0xF5, 0x69, 0xC2, 0x02, 0xF5,
+0x6A, 0xC2, 0x02, 0xF5, 0x68, 0xC2, 0x00, 0x6B,
+0x02, 0xF5, 0x66, 0xCA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0xFF, 0x6B, 0x80, 0xA2, 0x00, 0xF6, 0x80, 0x34,
+0x00, 0xF6, 0x83, 0x34, 0x00, 0x54, 0x28, 0x60,
+0xA0, 0xA2, 0x7F, 0x6C, 0xAC, 0xEC, 0x80, 0xC2,
+0x80, 0xA2, 0x40, 0x6D, 0x6C, 0xEC, 0xAD, 0xEC,
+0x6C, 0xEC, 0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6C,
+0xC0, 0xF7, 0x84, 0x9C, 0x3F, 0x6D, 0x80, 0xA4,
+0x30, 0xF0, 0x20, 0x6C, 0xC0, 0xF7, 0x88, 0x9C,
+0x80, 0xA4, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF6,
+0x9C, 0x9C, 0x80, 0xA4, 0x30, 0xF0, 0x20, 0x6C,
+0xC0, 0xF6, 0x80, 0x9C, 0x80, 0xA4, 0x80, 0xA2,
+0x6C, 0xEC, 0xAD, 0xEC, 0x6C, 0xEC, 0x80, 0xC2,
+0x80, 0xA2, 0xBF, 0x6B, 0x8C, 0xEB, 0x60, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x6C, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC,
+0xC0, 0xA3, 0x4C, 0xED, 0x15, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xC0, 0xF7, 0x94, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA, 0x20, 0xE8,
+0x80, 0xC3, 0x0B, 0x25, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x98, 0x9B, 0x80, 0x6D, 0xAB, 0xED,
+0x60, 0xA4, 0x4C, 0xEB, 0xAE, 0xEB, 0x4C, 0xEB,
+0x60, 0xC4, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF6, 0x74, 0x9B, 0x30, 0xF0, 0x20, 0x69,
+0x25, 0xF6, 0x54, 0x99, 0xE0, 0x9B, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF7, 0x7C, 0x9B, 0x50, 0x32,
+0x6D, 0xE2, 0xE0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF7, 0x60, 0x9B, 0x6D, 0xE2, 0x80, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF7, 0x64, 0x9B,
+0x6D, 0xE2, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF7, 0x68, 0x9B, 0x69, 0xE2, 0xC0, 0xDA,
+0x25, 0xF6, 0x14, 0x99, 0x01, 0x48, 0x00, 0xF1,
+0x00, 0x70, 0x25, 0xF6, 0x14, 0xD9, 0x05, 0x60,
+0x00, 0xF2, 0x00, 0x6A, 0x4E, 0xE8, 0x06, 0x20,
+0x0B, 0x10, 0x10, 0x6C, 0x01, 0x6D, 0x00, 0x18,
+0xB7, 0x1B, 0x06, 0x10, 0x11, 0x6C, 0x01, 0x6D,
+0x00, 0x18, 0xB7, 0x1B, 0x25, 0xF6, 0x14, 0xD9,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A,
+0x0E, 0x90, 0x24, 0x67, 0x4C, 0xE9, 0x03, 0x6B,
+0x4C, 0xEF, 0x2C, 0xEB, 0x00, 0x6A, 0x0B, 0xD5,
+0x0C, 0xD6, 0x04, 0xD7, 0x40, 0xC8, 0x00, 0x6A,
+0x07, 0x23, 0x25, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x7D, 0x1E, 0x40, 0xA8, 0x01, 0x4A, 0x40, 0xC8,
+0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x49, 0xE1, 0x0B, 0x93, 0x40, 0x9A, 0x6C, 0xEA,
+0x0C, 0x93, 0x6E, 0xEA, 0x04, 0x22, 0x40, 0xA8,
+0x04, 0x93, 0x63, 0xEA, 0xDF, 0x61, 0x40, 0xA8,
+0x04, 0x93, 0x63, 0xEA, 0x58, 0x67, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFF, 0x6A, 0xA0, 0x35, 0x4C, 0xEC, 0xA0, 0x35,
+0xCC, 0xEA, 0x4D, 0xED, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x4C, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x50, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF7, 0x94, 0x9B,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF7, 0x78, 0x9B,
+0xAD, 0xEA, 0x40, 0xDC, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x5C, 0x9A, 0x60, 0xDC,
+0x00, 0x6B, 0x60, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0xFF, 0xF7, 0x1F, 0x6B, 0x8C, 0xEA,
+0xAC, 0xEB, 0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x40, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x40, 0x9A, 0x60, 0x33,
+0x60, 0x33, 0x4D, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x54, 0x9A, 0x00, 0x6C, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x44, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF7, 0x7C, 0x9B,
+0x40, 0xA2, 0x80, 0xC3, 0xFF, 0x6B, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF0, 0x68, 0x9B, 0xFF, 0x6A, 0xCC, 0xEA,
+0x6D, 0xEA, 0xE0, 0xF1, 0x1F, 0x6B, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0xE0, 0xF7, 0x94, 0x9C,
+0x60, 0x33, 0x60, 0x33, 0x6D, 0xEA, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x58, 0x9A,
+0x6D, 0xEA, 0x40, 0xDC, 0x20, 0xE8, 0x00, 0x65,
+0xE0, 0xF1, 0x1F, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x78, 0x9B, 0xAC, 0xEA, 0x40, 0x32,
+0x40, 0x32, 0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF7, 0x74, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x44, 0x9A, 0xFF, 0x6B,
+0x40, 0xA2, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF0, 0xCC, 0x9B, 0xFF, 0x6A, 0x04, 0x6D,
+0x60, 0xA6, 0x4C, 0xEC, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC6, 0x11, 0x24, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF0, 0x90, 0x9B, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xC4, 0x45, 0xF6, 0x18, 0x4A,
+0x00, 0x6B, 0x02, 0xF6, 0x79, 0xC2, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x70, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x01, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x68, 0xF4,
+0x71, 0xC2, 0x30, 0xF0, 0x20, 0x6C, 0x09, 0xF2,
+0x08, 0x4C, 0x00, 0x6D, 0x00, 0x18, 0x41, 0x2E,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x6C, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x54, 0x9A,
+0x40, 0xAA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x54, 0x9A, 0x40, 0xAA, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0xF7,
+0x10, 0x68, 0x19, 0x10, 0x05, 0x6C, 0xFF, 0x48,
+0x00, 0x18, 0x7D, 0x1E, 0x14, 0x28, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A, 0x08, 0xF0,
+0x00, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x64, 0xDA, 0x00, 0x6A, 0x09, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x54, 0x9A, 0x60, 0xAA,
+0x3F, 0x6A, 0x6C, 0xEA, 0xDF, 0x2A, 0x01, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x01, 0x68, 0x04, 0xEC, 0x82, 0xF3, 0x08, 0x69,
+0x19, 0x10, 0x01, 0x6C, 0xFF, 0x49, 0x00, 0x18,
+0x7D, 0x1E, 0x14, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0x08, 0xF0, 0x00, 0x6C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3,
+0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA,
+0x00, 0x6A, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x54, 0x9A, 0x60, 0xAA, 0xFF, 0xF7,
+0x1F, 0x6A, 0x6C, 0xEA, 0x0C, 0xEA, 0xDD, 0x2A,
+0x01, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x0E, 0x92, 0x04, 0x67,
+0x0F, 0x91, 0x04, 0xD2, 0x04, 0x93, 0xFF, 0x6A,
+0x4C, 0xE8, 0x4C, 0xEB, 0x90, 0x67, 0x0B, 0xD5,
+0x0C, 0xD6, 0x0D, 0xD7, 0x04, 0xD3, 0x4C, 0xE9,
+0x00, 0x18, 0x88, 0x1C, 0x80, 0xF0, 0x07, 0x22,
+0x06, 0x58, 0x80, 0xF0, 0x04, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x08, 0x30, 0xE0, 0xF2, 0x08, 0x4A,
+0x09, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x02, 0xF2,
+0x10, 0x6A, 0x0E, 0x10, 0x02, 0xF2, 0x00, 0x6A,
+0x0B, 0x10, 0x22, 0xF2, 0x00, 0x6A, 0x08, 0x10,
+0x22, 0xF2, 0x10, 0x6A, 0x05, 0x10, 0x42, 0xF2,
+0x00, 0x6A, 0x02, 0x10, 0x42, 0xF2, 0x10, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x0D, 0x94, 0xA0, 0xF7,
+0x6C, 0x9B, 0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0xF6, 0x98, 0x9C, 0x8D, 0xEB, 0x06, 0x21,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF0, 0x98, 0x9C,
+0x6D, 0xEC, 0x05, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF0, 0x9C, 0x9C, 0x6C, 0xEC, 0x04, 0x96,
+0x06, 0x26, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x78, 0x9B, 0x8D, 0xEB, 0x05, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x60, 0x9B, 0x8C, 0xEB,
+0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC, 0x02, 0xF0,
+0x00, 0x74, 0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF7, 0xBC, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF7, 0xA0, 0x9C,
+0x30, 0xF0, 0x20, 0x6C, 0x0B, 0x96, 0x21, 0xF0,
+0x84, 0x9C, 0xB5, 0xE2, 0xCC, 0xEC, 0x80, 0xDD,
+0x84, 0x42, 0x1F, 0xF7, 0x00, 0x6D, 0xAC, 0xEC,
+0x02, 0xF0, 0x00, 0x74, 0x01, 0x60, 0x05, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF0, 0xA8, 0x9C,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF0,
+0xAC, 0x9C, 0x30, 0xF0, 0x20, 0x6C, 0x0C, 0x96,
+0x21, 0xF0, 0x84, 0x9C, 0xB5, 0xE2, 0xCC, 0xEC,
+0x80, 0xDD, 0x87, 0x42, 0x01, 0x4C, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF0, 0x90, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF0, 0x94, 0x9C, 0x89, 0xE2,
+0x60, 0xDA, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x00, 0x6A, 0x04, 0xD2,
+0x04, 0x92, 0x01, 0x72, 0x58, 0x67, 0x04, 0xD2,
+0x10, 0xF0, 0x20, 0x6A, 0x78, 0x67, 0xCE, 0xF3,
+0x0D, 0x4A, 0x69, 0xE2, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x40, 0xDB, 0x00, 0x18,
+0x7D, 0x0C, 0x00, 0x18, 0x9C, 0x1B, 0x00, 0x18,
+0x7C, 0x0C, 0x00, 0x18, 0x7D, 0x0C, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA0, 0xF0,
+0x84, 0x9A, 0x02, 0x6B, 0x8C, 0xEB, 0x09, 0x23,
+0x03, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x00, 0x18, 0x1C, 0x23, 0x00, 0x18,
+0x75, 0x23, 0x00, 0x18, 0x7C, 0x0C, 0x00, 0x18,
+0x7D, 0x0C, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xA0, 0xF0, 0x84, 0x9A, 0x04, 0x6B,
+0x8C, 0xEB, 0x09, 0x23, 0x05, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18,
+0xC8, 0x20, 0x00, 0x18, 0x76, 0x20, 0x00, 0x18,
+0x7C, 0x0C, 0x00, 0x18, 0x7D, 0x0C, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xC0, 0xF0,
+0x87, 0xA2, 0x7F, 0x6B, 0x8C, 0xEB, 0x0D, 0x23,
+0xC0, 0xF0, 0x8B, 0xA2, 0xA3, 0xF3, 0x63, 0xA2,
+0x8E, 0xEB, 0x07, 0x23, 0xC0, 0xF0, 0x8A, 0xA2,
+0xFF, 0x6A, 0x96, 0x34, 0x4C, 0xEC, 0x00, 0x18,
+0xF1, 0x15, 0x30, 0xF0, 0x20, 0x6A, 0xE5, 0xF6,
+0x5C, 0x9A, 0x02, 0x2A, 0x00, 0x18, 0x20, 0x16,
+0x00, 0x18, 0x7C, 0x0C, 0x00, 0x18, 0x7D, 0x0C,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xA0, 0xF0, 0x84, 0x9A, 0x10, 0x6B, 0x8C, 0xEB,
+0x07, 0x23, 0x11, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18, 0x72, 0x4E,
+0x00, 0x18, 0x7C, 0x0C, 0x00, 0x18, 0x7D, 0x0C,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xA0, 0xF0, 0x84, 0x9A, 0x02, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x08, 0x23, 0x02, 0xF0, 0x01, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x00, 0x18, 0x78, 0x2B, 0x00, 0x18, 0x7C, 0x0C,
+0x00, 0x18, 0x7D, 0x0C, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x74, 0x9B, 0xA0, 0xF0, 0x84, 0x9A,
+0x8C, 0xEB, 0x20, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x64, 0x9B, 0x8C, 0xEB, 0xC0, 0xF0,
+0x87, 0xA2, 0xA0, 0xF0, 0x64, 0xDA, 0x7F, 0x6B,
+0x8C, 0xEB, 0x07, 0x2B, 0xA3, 0xF3, 0x43, 0xA2,
+0x0C, 0x72, 0x03, 0x61, 0x00, 0x18, 0x7A, 0x21,
+0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF0,
+0x64, 0x9A, 0x80, 0xF6, 0x94, 0x9C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18, 0x7C, 0x0C,
+0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF3, 0x70, 0xA2,
+0x08, 0x6A, 0x6C, 0xEA, 0x0F, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x48, 0x9A, 0x01, 0x6B,
+0x80, 0xA2, 0x8C, 0xEB, 0x07, 0x23, 0x80, 0xA2,
+0xFE, 0x6B, 0x8C, 0xEB, 0x60, 0xC2, 0x03, 0x6C,
+0x00, 0x18, 0x9F, 0x23, 0x30, 0xF0, 0x20, 0x69,
+0x45, 0xF6, 0x18, 0x49, 0x23, 0xF2, 0x00, 0xA1,
+0x01, 0x6A, 0x4E, 0xE8, 0x05, 0x28, 0x0B, 0x6C,
+0x00, 0x18, 0x9F, 0x23, 0x23, 0xF2, 0x00, 0xC1,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF6, 0x8C, 0x9A,
+0x00, 0x18, 0x87, 0x0E, 0x19, 0x17, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x68,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xAE, 0xF5, 0x09, 0x4A,
+0x0A, 0x70, 0x40, 0xDB, 0x09, 0x61, 0x30, 0xF0,
+0x21, 0x6A, 0xD1, 0xF6, 0x8C, 0x9A, 0x01, 0x6D,
+0xAB, 0xED, 0x00, 0x18, 0x3E, 0x0D, 0x00, 0x68,
+0x00, 0x18, 0x7D, 0x0C, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA0, 0xF0, 0x84, 0x9A,
+0x04, 0xF0, 0x00, 0x6B, 0x8C, 0xEB, 0x08, 0x23,
+0x04, 0xF0, 0x01, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18, 0x91, 0x19,
+0x00, 0x18, 0x7C, 0x0C, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x01, 0x48, 0x40, 0xF6, 0x60, 0x9B,
+0x4C, 0xE8, 0x10, 0xF0, 0x20, 0x6A, 0xAE, 0xF5,
+0x0A, 0x4A, 0x40, 0xDB, 0xC9, 0x17, 0x00, 0x65,
+0x00, 0x6A, 0x64, 0x67, 0x66, 0xEA, 0x01, 0x6D,
+0xAC, 0xEB, 0x04, 0x2B, 0x01, 0x4A, 0x20, 0x72,
+0xF8, 0x61, 0x20, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x25, 0x67, 0x49, 0xE4, 0x00, 0x9A, 0x85, 0x67,
+0x00, 0x18, 0x88, 0x1D, 0x2C, 0xE8, 0x06, 0xEA,
+0x50, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x41, 0x45, 0x05, 0x67,
+0x0C, 0xD6, 0x13, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x20, 0x9A, 0x0F, 0xE8, 0x25, 0xE4,
+0x40, 0x99, 0x85, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0x88, 0x1D, 0x0C, 0x93, 0x64, 0xEA, 0x43, 0x67,
+0x04, 0x93, 0x6C, 0xE8, 0x0D, 0xEA, 0x40, 0xD9,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7,
+0x20, 0x9A, 0x0C, 0x92, 0x31, 0xE4, 0x40, 0xDC,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x41, 0x45, 0x0C, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0xAF, 0xEB, 0xCC, 0xED, 0x51, 0xE4, 0x40, 0x9C,
+0x6C, 0xEA, 0xAD, 0xEA, 0x40, 0xDC, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x51, 0xE4, 0xC0, 0xDC, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x6C, 0x9B,
+0xFF, 0x6A, 0xAC, 0xEA, 0x6D, 0xE4, 0x49, 0xE6,
+0x04, 0x10, 0x80, 0xA3, 0x01, 0x4B, 0x80, 0xC6,
+0x01, 0x4E, 0x4A, 0xEE, 0xFA, 0x61, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x6C, 0x9B,
+0xFF, 0x6A, 0xAC, 0xEA, 0x6D, 0xE4, 0x49, 0xE6,
+0x04, 0x10, 0x80, 0xA6, 0x01, 0x4E, 0x80, 0xC3,
+0x01, 0x4B, 0x4A, 0xEE, 0xFA, 0x61, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x48, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7, 0x6C, 0x9B,
+0x40, 0x9A, 0x6C, 0xEA, 0x83, 0xEA, 0x02, 0x60,
+0x4F, 0xEA, 0x51, 0xE4, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x50, 0x9A, 0xFF, 0x6B, 0x51, 0xE4,
+0x40, 0xA4, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7, 0x50, 0x9A,
+0xFF, 0x63, 0x60, 0xAA, 0xE1, 0xF7, 0x1F, 0x6A,
+0x6C, 0xEA, 0x7D, 0x67, 0x40, 0xCB, 0x40, 0xAB,
+0xFF, 0xF7, 0x1F, 0x6B, 0x01, 0x63, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x54, 0x9A, 0xFF, 0x63, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0x7D, 0x67, 0x40, 0xCB,
+0x40, 0xAB, 0xFF, 0xF7, 0x1F, 0x6B, 0x01, 0x63,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x54, 0x9A, 0x01, 0x6B, 0x40, 0x9A,
+0x42, 0x32, 0x52, 0x32, 0x6E, 0xEA, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x68, 0x9B, 0x44, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0x9B, 0xA0, 0xF7, 0x8C, 0x9C,
+0x8C, 0xEB, 0x43, 0xEB, 0x02, 0x60, 0x6F, 0xEB,
+0x69, 0xE2, 0x20, 0xE8, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xFF, 0xF7,
+0x1F, 0x6B, 0x4C, 0xED, 0x4C, 0xEE, 0x24, 0x67,
+0x6C, 0xEF, 0x10, 0x90, 0x6C, 0xE9, 0x05, 0xD5,
+0x06, 0xD6, 0x04, 0xD7, 0x00, 0x6A, 0x05, 0x10,
+0x0A, 0x6C, 0x00, 0x18, 0x7D, 0x1E, 0x40, 0xA8,
+0x01, 0x4A, 0x40, 0xC8, 0x1F, 0xF7, 0x00, 0x6A,
+0x2C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x40, 0x9A, 0x49, 0xE1, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0x05, 0x93, 0x6C, 0xEA,
+0x06, 0x93, 0x6E, 0xEA, 0x04, 0x22, 0x40, 0xA8,
+0x04, 0x93, 0x63, 0xEA, 0xDD, 0x61, 0x40, 0xA8,
+0x04, 0x93, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x63, 0xEA, 0x58, 0x67, 0x06, 0x63, 0x00, 0xEF,
+0x03, 0x6F, 0x8C, 0xEF, 0x64, 0x67, 0x46, 0x67,
+0x04, 0x27, 0x0B, 0x10, 0xA0, 0xDB, 0xFC, 0x4A,
+0x04, 0x4B, 0x04, 0x5A, 0xFB, 0x60, 0x03, 0x6A,
+0x4C, 0xEE, 0x03, 0x10, 0xA0, 0xC4, 0xFF, 0x4E,
+0x01, 0x4C, 0xFC, 0x2E, 0x00, 0x6A, 0x20, 0xE8,
+0xFF, 0x6A, 0xAC, 0xEA, 0x03, 0x10, 0x40, 0xC4,
+0xFF, 0x4E, 0x01, 0x4C, 0xFC, 0x2E, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x03, 0x6B, 0x05, 0x67, 0x6C, 0xE8, 0x44, 0x67,
+0xE4, 0x67, 0x85, 0x67, 0x12, 0x28, 0x4C, 0xEB,
+0x10, 0x2B, 0x86, 0x67, 0x06, 0x10, 0x61, 0xE5,
+0x00, 0x98, 0x7D, 0xE2, 0xFC, 0x4C, 0x00, 0xDF,
+0x04, 0x4B, 0x04, 0x5C, 0xF8, 0x60, 0xCA, 0x34,
+0x88, 0x34, 0x03, 0x6B, 0x9D, 0xE2, 0x6C, 0xEE,
+0x91, 0xE5, 0x00, 0x6B, 0x06, 0x10, 0x61, 0xE4,
+0x00, 0xA0, 0x75, 0xE7, 0xFF, 0x4E, 0x00, 0xC5,
+0x01, 0x4B, 0xF9, 0x2E, 0x01, 0x90, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0x09, 0x10, 0x60, 0xA4,
+0x40, 0xA5, 0xFF, 0x4E, 0x4A, 0xEB, 0x02, 0x60,
+0x4B, 0xE3, 0x20, 0xE8, 0x01, 0x4C, 0x01, 0x4D,
+0xF6, 0x2E, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x06, 0x2C, 0x64, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x25, 0xF6, 0x78, 0xDA, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x98, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x58, 0x9A, 0x28, 0x72,
+0x2D, 0x60, 0x29, 0x5A, 0x07, 0x60, 0x14, 0x72,
+0x19, 0x60, 0x19, 0x72, 0x1F, 0x60, 0x0A, 0x72,
+0x0D, 0x60, 0x20, 0xE8, 0x50, 0x72, 0x32, 0x60,
+0x51, 0x5A, 0x03, 0x60, 0x32, 0x72, 0x26, 0x60,
+0x20, 0xE8, 0x64, 0x72, 0x33, 0x60, 0xC8, 0x72,
+0x39, 0x60, 0x20, 0xE8, 0x02, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0xE0, 0xF7,
+0x1E, 0x4B, 0x39, 0x10, 0x03, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0xE1, 0xF3,
+0x1D, 0x4B, 0x31, 0x10, 0x09, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0xE4, 0xF3,
+0x17, 0x4B, 0x29, 0x10, 0x05, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0xE2, 0xF3,
+0x1B, 0x4B, 0x21, 0x10, 0x11, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0xE8, 0xF3,
+0x0F, 0x4B, 0x19, 0x10, 0x0A, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0xE4, 0xF7,
+0x16, 0x4B, 0x11, 0x10, 0x22, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0x11, 0xF0,
+0x00, 0x6B, 0x09, 0x10, 0x43, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x25, 0xF6, 0x7C, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x78, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x60, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x25, 0xF6, 0x58, 0x9A,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x40, 0x9A, 0xFF, 0x63, 0x58, 0xEC,
+0x12, 0xEA, 0x00, 0xD2, 0x00, 0x92, 0xFF, 0x4A,
+0x00, 0xD2, 0x00, 0x92, 0xFB, 0x2A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x25, 0xF6, 0x5C, 0x9A, 0xFF, 0x63, 0x58, 0xEC,
+0x12, 0xEA, 0x00, 0xD2, 0x00, 0x92, 0xFF, 0x4A,
+0x00, 0xD2, 0x00, 0x92, 0xFB, 0x2A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0xDC, 0x9A, 0x00, 0x68, 0x20, 0xF0, 0x20, 0x6D,
+0x90, 0x67, 0x45, 0xF6, 0x18, 0x4D, 0x4C, 0xF0,
+0x18, 0x6F, 0x04, 0xD0, 0x05, 0xD0, 0x00, 0x18,
+0xA1, 0x1C, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0xC0, 0x9A, 0x20, 0xF0, 0x21, 0x6D, 0x90, 0x67,
+0x15, 0xF0, 0x00, 0x4D, 0x03, 0xF0, 0x00, 0x6F,
+0x04, 0xD0, 0x05, 0xD0, 0x00, 0x18, 0xA1, 0x1C,
+0x07, 0x97, 0x06, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x35, 0x1E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xED,
+0x00, 0x18, 0x1C, 0x1E, 0x05, 0x97, 0x00, 0x6A,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x04, 0x67, 0x4C, 0xEE,
+0x00, 0x18, 0x21, 0x1E, 0x50, 0x67, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x30, 0xF0, 0x20, 0x68, 0x8C, 0xEA,
+0xE9, 0xF6, 0x08, 0x48, 0x04, 0xD2, 0x26, 0x40,
+0x40, 0xA0, 0x04, 0x93, 0x6E, 0xEA, 0x0A, 0x2A,
+0x01, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0x4B, 0xEA,
+0x82, 0xF0, 0x04, 0x4C, 0xA3, 0x67, 0x40, 0xC0,
+0x00, 0x18, 0x39, 0x3D, 0x01, 0x48, 0x2A, 0xE8,
+0xEF, 0x61, 0x30, 0xF0, 0x20, 0x68, 0x30, 0xF0,
+0x20, 0x69, 0x80, 0x6A, 0xE9, 0xF6, 0x0E, 0x48,
+0x8C, 0xF6, 0x18, 0x49, 0x05, 0xD2, 0x40, 0xA0,
+0x04, 0x93, 0x6E, 0xEA, 0x03, 0x2A, 0x01, 0x6A,
+0x4B, 0xEA, 0x40, 0xC0, 0x5E, 0xA0, 0x04, 0x93,
+0x6E, 0xEA, 0x0F, 0x2A, 0x01, 0x6A, 0x4B, 0xEA,
+0x5E, 0xC0, 0x76, 0xA1, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x56, 0xC1, 0x05, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0x82, 0xF0, 0x04, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x05, 0x92, 0x01, 0x48, 0x2E, 0x49,
+0x01, 0x4A, 0x9E, 0x72, 0x05, 0xD2, 0xDF, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF4, 0x63, 0x17, 0x62,
+0x16, 0xD1, 0x15, 0xD0, 0x30, 0xF0, 0x20, 0x6D,
+0x24, 0x67, 0x80, 0xF3, 0x00, 0x4D, 0x04, 0x04,
+0x1E, 0x6E, 0x00, 0x18, 0x21, 0x1E, 0x30, 0xF0,
+0x20, 0x6D, 0x0C, 0x04, 0x60, 0xF3, 0x00, 0x4D,
+0x1E, 0x6E, 0x00, 0x18, 0x21, 0x1E, 0x40, 0xA1,
+0x02, 0x72, 0x57, 0x60, 0x03, 0x72, 0x7A, 0x60,
+0x01, 0x72, 0x80, 0xF0, 0x0A, 0x61, 0x02, 0xA1,
+0x2E, 0x6C, 0xA1, 0xA1, 0x98, 0xE8, 0x05, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A,
+0x04, 0x06, 0x0C, 0x07, 0x12, 0xEC, 0x91, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x78, 0xED, 0x45, 0xF6,
+0x18, 0x4A, 0x49, 0xE5, 0x84, 0xF0, 0x10, 0xC2,
+0x12, 0xEB, 0x69, 0xE6, 0x79, 0xE7, 0x00, 0xF0,
+0x15, 0x07, 0x7D, 0xE7, 0xFF, 0x65, 0xE0, 0xA2,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x7D, 0xE7, 0x84, 0xF0, 0x15, 0xC7, 0xE0, 0xA6,
+0x01, 0x4A, 0x01, 0x4E, 0x6D, 0xE7, 0xA4, 0xF0,
+0x13, 0xC3, 0x7F, 0x67, 0x6A, 0xEA, 0xEF, 0x61,
+0x76, 0xA4, 0x01, 0x6A, 0x4D, 0xEB, 0x76, 0xC4,
+0xC3, 0xA1, 0xCC, 0xEA, 0x44, 0x36, 0x03, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xCD, 0xEA, 0x56, 0xC4,
+0x30, 0xF0, 0x20, 0x6C, 0xD0, 0x67, 0xE2, 0xF1,
+0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x90, 0x67,
+0x00, 0x18, 0x67, 0x4F, 0x90, 0x67, 0x00, 0x18,
+0xFE, 0x32, 0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF1,
+0x18, 0x4C, 0xB0, 0x67, 0xC2, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x90, 0x67, 0x00, 0x18, 0x38, 0x50,
+0x38, 0x10, 0x01, 0xA1, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE0, 0x84, 0xF0,
+0x30, 0xA2, 0x01, 0x6B, 0x6B, 0xEB, 0x84, 0xF0,
+0x70, 0xC2, 0x2E, 0x6B, 0x78, 0xE9, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x12, 0xEB,
+0x6D, 0xE2, 0x96, 0xA3, 0x02, 0x6A, 0x4B, 0xEA,
+0x8C, 0xEA, 0x56, 0xC3, 0x91, 0x67, 0x00, 0x18,
+0xA8, 0x1E, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF2,
+0x08, 0x4C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x13, 0x10, 0xA1, 0xA1, 0xC2, 0xA1,
+0xE3, 0xA1, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF0,
+0xB2, 0xC2, 0xC4, 0xF0, 0xD3, 0xC2, 0xC4, 0xF0,
+0xF7, 0xC2, 0x22, 0xF2, 0x0C, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x17, 0x97, 0x16, 0x91, 0x15, 0x90,
+0x0C, 0x63, 0x00, 0xEF, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0xAC, 0xEA, 0x2E, 0x5A,
+0x01, 0x60, 0x2E, 0x6A, 0x9E, 0x33, 0x26, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0x4C, 0xFF, 0x6D,
+0xC1, 0xF1, 0x64, 0x9B, 0xAC, 0xEC, 0x84, 0x36,
+0x6D, 0xE6, 0x40, 0xC3, 0x01, 0x6B, 0x8C, 0xEB,
+0x0D, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF1,
+0x6C, 0x9B, 0x01, 0x4C, 0x84, 0x34, 0x71, 0xE4,
+0x80, 0x6B, 0x6B, 0xEB, 0x4D, 0xEB, 0xAC, 0xEB,
+0x60, 0xC4, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF1, 0x6C, 0x9B, 0xFF, 0x4C, 0x84, 0x34,
+0x71, 0xE4, 0x80, 0x6B, 0x6B, 0xEB, 0x4D, 0xEB,
+0xAC, 0xEB, 0x60, 0xC4, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6, 0x7C, 0x9B,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0xA3, 0xEB,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF0, 0x70, 0x9B, 0xC1, 0xF2,
+0x88, 0x9C, 0x6D, 0xE5, 0x91, 0xE5, 0x22, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0x6C, 0x9B, 0xC1, 0xF2, 0x8C, 0x9C,
+0x6D, 0xE5, 0x91, 0xE5, 0x00, 0x6E, 0xC0, 0xDB,
+0x04, 0x4B, 0x8A, 0xEB, 0xFB, 0x61, 0xE7, 0xF7,
+0x1F, 0x6B, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0x58, 0x9A, 0x4D, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x4C, 0x9A, 0x49, 0xE5,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x50, 0x9A, 0x17, 0x10, 0x00, 0x6E, 0xC0, 0xDB,
+0x04, 0x4B, 0x8A, 0xEB, 0xFB, 0x61, 0xE7, 0xF7,
+0x1F, 0x6B, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0x58, 0x9A, 0x4D, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x50, 0x9A, 0x49, 0xE5,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x54, 0x9A, 0x55, 0xE5, 0x40, 0xA5, 0xFF, 0x6B,
+0x10, 0x6C, 0x6C, 0xEA, 0x8D, 0xEA, 0x6C, 0xEA,
+0x40, 0xC5, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0x30, 0xF0, 0x20, 0x6A,
+0x02, 0xF5, 0x68, 0x98, 0x21, 0xF1, 0x54, 0x9A,
+0xA4, 0x67, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF1, 0x74, 0x9B, 0x6E, 0xEA, 0x07, 0x22,
+0x02, 0xF5, 0x49, 0xA0, 0x02, 0xF5, 0x6A, 0xA0,
+0xFF, 0x4A, 0x6E, 0xEA, 0x15, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0xF6, 0x98, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA, 0xA3, 0x10,
+0x23, 0xA4, 0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x49,
+0x4C, 0xE9, 0x02, 0xF5, 0x46, 0xA8, 0x1F, 0x2A,
+0xE8, 0x6A, 0x58, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0xC6, 0xF4, 0x1E, 0x4A, 0xFF, 0x6E, 0x2C, 0xEE,
+0x12, 0xEB, 0x71, 0xE2, 0x00, 0x18, 0xA1, 0x1E,
+0x02, 0xF5, 0x4A, 0xA0, 0x02, 0xF5, 0x69, 0xA0,
+0x02, 0xF5, 0x26, 0xC8, 0x4E, 0xEB, 0x73, 0x2B,
+0x01, 0x4A, 0x02, 0xF5, 0x4A, 0xC0, 0x02, 0xF5,
+0x4A, 0xA0, 0x10, 0x6B, 0x6E, 0xEA, 0x6B, 0x2A,
+0x02, 0xF5, 0x4A, 0xC0, 0x68, 0x10, 0x62, 0xA4,
+0x36, 0x2B, 0x4D, 0xE1, 0xE3, 0x53, 0x33, 0x60,
+0x02, 0xF5, 0x68, 0xA0, 0xE8, 0x6C, 0x98, 0xEB,
+0x12, 0xEB, 0x0D, 0xE3, 0x80, 0xF6, 0x88, 0xA3,
+0x2A, 0x2C, 0x80, 0xF6, 0x89, 0xA3, 0xFF, 0x6E,
+0xFC, 0x4A, 0xFF, 0x4C, 0x80, 0xF6, 0x89, 0xC3,
+0x02, 0xF5, 0x66, 0xA8, 0xE8, 0x6C, 0xCC, 0xEA,
+0xFF, 0x4B, 0x02, 0xF5, 0x66, 0xC8, 0x02, 0xF5,
+0x68, 0xA0, 0x2C, 0xEE, 0x98, 0xEB, 0x12, 0xEB,
+0x6D, 0xE0, 0x49, 0xE3, 0x80, 0xF6, 0x89, 0x42,
+0x00, 0x18, 0xA1, 0x1E, 0x02, 0xF5, 0x48, 0xA0,
+0xE8, 0x6B, 0x78, 0xEA, 0x12, 0xEA, 0x09, 0xE2,
+0x80, 0xF6, 0x69, 0xA2, 0x6D, 0xE1, 0x80, 0xF6,
+0x69, 0xC2, 0x02, 0xF5, 0x46, 0xA8, 0x45, 0xE1,
+0x02, 0xF5, 0x26, 0xC8, 0x30, 0x10, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x02, 0xF5,
+0x8A, 0xA0, 0xE8, 0x6A, 0xFF, 0x6E, 0x58, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF4, 0x1E, 0x4A,
+0x2C, 0xEE, 0x12, 0xEC, 0x91, 0xE2, 0x00, 0x18,
+0xA1, 0x1E, 0x02, 0xF5, 0x4A, 0xA0, 0x10, 0x6B,
+0x02, 0xF5, 0x26, 0xC8, 0x01, 0x4A, 0x02, 0xF5,
+0x4A, 0xC0, 0x02, 0xF5, 0x4A, 0xA0, 0x6E, 0xEA,
+0x02, 0x2A, 0x02, 0xF5, 0x4A, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x02, 0xF5,
+0x68, 0xA2, 0x10, 0x6C, 0x01, 0x4B, 0x02, 0xF5,
+0x68, 0xC2, 0x02, 0xF5, 0x68, 0xA2, 0x8E, 0xEB,
+0x02, 0x2B, 0x02, 0xF5, 0x68, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x02, 0xF5,
+0x88, 0xA2, 0xE8, 0x6B, 0x78, 0xEC, 0x02, 0xF5,
+0x86, 0xAA, 0x12, 0xEB, 0x4D, 0xE3, 0x60, 0xF7,
+0x8D, 0xC3, 0xA0, 0xF0, 0x64, 0x9A, 0x04, 0x6C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x50, 0xA3, 0xFF, 0x6F,
+0xE0, 0xF0, 0xC7, 0xA5, 0x41, 0xC5, 0x43, 0xA5,
+0x45, 0xF6, 0x70, 0xA3, 0x03, 0x4A, 0xEC, 0xEA,
+0x09, 0x10, 0xED, 0x42, 0xFF, 0x68, 0x0C, 0xEF,
+0xFD, 0xE5, 0x64, 0xC7, 0xE6, 0xA7, 0x03, 0x4F,
+0xE9, 0xE2, 0x0C, 0xEA, 0xEF, 0x46, 0xE2, 0xEA,
+0xF4, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x70, 0xA2, 0x01, 0x4B, 0x45, 0xF6, 0x70, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6, 0x5C, 0x9A,
+0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x4C, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x50, 0x9A, 0x51, 0xE4,
+0x00, 0x18, 0xA1, 0x1E, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0xA0, 0xF0, 0x44, 0x98, 0x04, 0x6B,
+0xA4, 0x67, 0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8,
+0x80, 0xF6, 0x44, 0xA8, 0x09, 0xF7, 0x00, 0x72,
+0x07, 0x60, 0x80, 0xF6, 0x44, 0xA0, 0x80, 0xF6,
+0x85, 0xA0, 0xFF, 0x4A, 0x8E, 0xEA, 0x13, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x00, 0xF2, 0x00, 0x6C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x64, 0xDA, 0x15, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC5, 0xF7, 0x1C, 0x4A, 0x90, 0x34,
+0x91, 0xE2, 0x10, 0x6E, 0x00, 0x18, 0xA1, 0x1E,
+0x80, 0xF6, 0x45, 0xA0, 0x50, 0x6B, 0x01, 0x4A,
+0x80, 0xF6, 0x45, 0xC0, 0x80, 0xF6, 0x45, 0xA0,
+0x6E, 0xEA, 0x02, 0x2A, 0x80, 0xF6, 0x45, 0xC0,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x71, 0xA2,
+0x24, 0x67, 0x05, 0x67, 0x61, 0xC5, 0x01, 0x4B,
+0x45, 0xF6, 0x71, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0x5C, 0x9A, 0x83, 0xEA, 0x0D, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x8C, 0x9A,
+0x02, 0x6E, 0x91, 0xE1, 0x00, 0x18, 0xA1, 0x1E,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0x98, 0x9A,
+0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x90, 0x9A, 0x02, 0x6E, 0x91, 0xE1, 0x00, 0x18,
+0xA1, 0x1E, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x9C, 0x9A, 0xCE, 0xA0, 0x91, 0xE1, 0xA2, 0x40,
+0x00, 0x18, 0xA1, 0x1E, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x68,
+0x1D, 0x10, 0xE0, 0xF3, 0x08, 0x70, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x80, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x64, 0xDA, 0x00, 0x6A, 0x10, 0x10, 0x01, 0x48,
+0xFF, 0xF7, 0x1F, 0x6A, 0x0A, 0x6C, 0x4C, 0xE8,
+0x00, 0x18, 0x7D, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x5C, 0x9A, 0x60, 0xA2, 0x01, 0x6A,
+0x6C, 0xEA, 0xDB, 0x2A, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x24, 0x67, 0x00, 0x18, 0x32, 0x20, 0x00, 0x6B,
+0x48, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x48, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7,
+0x6C, 0x9B, 0x40, 0x9A, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF6, 0x7C, 0x9B, 0x43, 0xEB,
+0x07, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF2,
+0x00, 0x9B, 0x01, 0xE2, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x42, 0x50, 0x67, 0xFF, 0xF7, 0x1F, 0x6B,
+0x4C, 0xEB, 0x42, 0x32, 0x0F, 0x6C, 0x42, 0x32,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF2,
+0x84, 0x9C, 0xB0, 0x67, 0x60, 0xCC, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF2, 0x68, 0x9B, 0x40, 0xC3,
+0xE0, 0xF0, 0x87, 0xA1, 0x00, 0x18, 0x3E, 0x1F,
+0x87, 0x40, 0x11, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0xD6, 0x1F, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x5C, 0x9A, 0x01, 0x6B, 0x80, 0xF2, 0x16, 0x6C,
+0x60, 0xC2, 0x01, 0x6D, 0x06, 0x02, 0x00, 0x6E,
+0x04, 0xF7, 0x10, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0xF3, 0x1D, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x33, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x43, 0x67, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x02, 0xF5,
+0x49, 0xA0, 0x02, 0xF5, 0x6A, 0xA0, 0x4E, 0xEB,
+0x33, 0x23, 0xE8, 0x6B, 0x78, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0xC6, 0xF4, 0x1E, 0x4B, 0x12, 0xEA,
+0x51, 0xE3, 0x00, 0x18, 0x4A, 0x20, 0x07, 0x2A,
+0xA0, 0xF0, 0x44, 0x98, 0x04, 0x6B, 0x6D, 0xEA,
+0xA0, 0xF0, 0x44, 0xD8, 0x21, 0x10, 0x02, 0xF5,
+0x49, 0xA0, 0x10, 0x6B, 0x01, 0x4A, 0x02, 0xF5,
+0x49, 0xC0, 0x02, 0xF5, 0x49, 0xA0, 0x6E, 0xEA,
+0x02, 0x2A, 0x02, 0xF5, 0x49, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x02, 0xF5,
+0x89, 0xA2, 0x02, 0xF5, 0x6A, 0xA2, 0x8E, 0xEB,
+0x07, 0x23, 0xA0, 0xF0, 0x64, 0x9A, 0x04, 0x6C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x04, 0x10,
+0x02, 0xF5, 0x88, 0xC2, 0x02, 0xF5, 0x66, 0xCA,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x24, 0x67, 0x00, 0x18, 0x32, 0x20, 0x00, 0x6B,
+0x50, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x48, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7,
+0x6C, 0x9B, 0x40, 0x9A, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF6, 0x7C, 0x9B, 0x43, 0xEB,
+0x07, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF2,
+0x00, 0x9B, 0x01, 0xE2, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x42, 0x50, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF2, 0x64, 0x9B, 0xFF, 0xF7, 0x1F, 0x6D,
+0x82, 0x67, 0xAC, 0xEC, 0x80, 0xCB, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF2, 0x88, 0x9B, 0xFF, 0x6E,
+0x10, 0x6F, 0x60, 0xA4, 0xEB, 0xEF, 0x42, 0x32,
+0xCC, 0xEB, 0xEC, 0xEB, 0x42, 0x32, 0x6D, 0xEA,
+0xCC, 0xEA, 0x40, 0xC4, 0x87, 0xA9, 0x02, 0x4C,
+0xAC, 0xEC, 0xB0, 0x67, 0x00, 0x18, 0x3E, 0x1F,
+0x87, 0x40, 0x11, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x16, 0x20, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x5C, 0x9A, 0x01, 0x6B, 0x80, 0xF2, 0x16, 0x6C,
+0x60, 0xC2, 0x01, 0x6D, 0x06, 0x02, 0x00, 0x6E,
+0x04, 0xF7, 0x10, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0xF3, 0x1D, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x33, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x43, 0x67, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x80, 0xF6,
+0x84, 0xA0, 0x80, 0xF6, 0x45, 0xA0, 0x8E, 0xEA,
+0x25, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x90, 0x34,
+0xC5, 0xF7, 0x1C, 0x4A, 0x91, 0xE2, 0x00, 0x18,
+0x98, 0x20, 0x1C, 0x22, 0x80, 0xF6, 0x44, 0xA0,
+0x01, 0x4A, 0x80, 0xF6, 0x44, 0xC0, 0x80, 0xF6,
+0x64, 0xA0, 0x80, 0xF6, 0x45, 0xA0, 0x6E, 0xEA,
+0x06, 0x22, 0xA0, 0xF0, 0x44, 0x98, 0x04, 0x6B,
+0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x80, 0xF6,
+0x64, 0xA2, 0x50, 0x6C, 0x8E, 0xEB, 0x02, 0x2B,
+0x80, 0xF6, 0x64, 0xC2, 0x00, 0x18, 0x94, 0x21,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFE, 0x63, 0x03, 0xD1, 0x02, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF2, 0x4C, 0x9A, 0x0F, 0x6B,
+0x40, 0xA2, 0x4C, 0xEB, 0x0A, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA0, 0xF0,
+0x84, 0x9A, 0x02, 0x6D, 0xAD, 0xEC, 0xA0, 0xF0,
+0x84, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF7,
+0x5A, 0xA2, 0xFF, 0x4A, 0x00, 0xD2, 0xDF, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x80, 0xF1, 0x82, 0xAA, 0x00, 0xF7, 0x00, 0x74,
+0x05, 0x60, 0x80, 0xF1, 0x03, 0xA2, 0x00, 0x94,
+0x8A, 0xE8, 0x0E, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0xFF, 0x6C, 0x01, 0x4C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xBD, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6, 0x92, 0xA4,
+0xA3, 0x67, 0xA7, 0xEC, 0x85, 0x67, 0x01, 0x6D,
+0xAC, 0xEC, 0xA0, 0xF0, 0x0A, 0x24, 0x0C, 0x35,
+0xB5, 0xE2, 0x40, 0xF1, 0x06, 0x4D, 0x00, 0x6A,
+0x30, 0xF0, 0x20, 0x6E, 0x45, 0xF6, 0xF2, 0xA6,
+0xFF, 0x6C, 0x1F, 0xF7, 0x00, 0x69, 0x8C, 0xEF,
+0x74, 0x4F, 0xE8, 0x37, 0xFD, 0xE2, 0x2C, 0xEF,
+0x02, 0xF0, 0x00, 0x77, 0x08, 0x60, 0x45, 0xF6,
+0xF2, 0xA6, 0x8C, 0xEF, 0x74, 0x4F, 0xE8, 0x37,
+0xFD, 0xE2, 0x2C, 0xEF, 0x0F, 0x2F, 0x30, 0xF0,
+0x20, 0x6C, 0x45, 0xF6, 0x32, 0xA4, 0xFF, 0x6C,
+0x30, 0xF0, 0x20, 0x6E, 0x8C, 0xE9, 0x74, 0x49,
+0x28, 0x31, 0xE2, 0x67, 0x25, 0xE2, 0x00, 0xF7,
+0xDC, 0x9E, 0x0B, 0x10, 0x45, 0xF6, 0x32, 0xA6,
+0x30, 0xF0, 0x20, 0x6E, 0x20, 0xF7, 0xC0, 0x9E,
+0x8C, 0xE9, 0x74, 0x49, 0x28, 0x31, 0xE2, 0x67,
+0x25, 0xE2, 0xD9, 0xE1, 0xC0, 0xA6, 0x0C, 0x31,
+0xCC, 0xEC, 0x30, 0xF0, 0x20, 0x6E, 0x45, 0xF6,
+0x18, 0x4E, 0xD9, 0xE1, 0xFD, 0xE6, 0x40, 0xF1,
+0x82, 0xC7, 0x30, 0xF0, 0x20, 0x6E, 0x45, 0xF6,
+0xF2, 0xA6, 0xFF, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x8C, 0xEF, 0x7C, 0x4F, 0xE8, 0x37, 0xFD, 0xE2,
+0x2C, 0xEF, 0x02, 0xF0, 0x00, 0x77, 0x08, 0x60,
+0x45, 0xF6, 0xF2, 0xA6, 0x8C, 0xEF, 0x7C, 0x4F,
+0xE8, 0x37, 0xFD, 0xE2, 0x2C, 0xEF, 0x0E, 0x2F,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6, 0xD2, 0xA4,
+0xFF, 0x6C, 0x30, 0xF0, 0x20, 0x6F, 0x8C, 0xEE,
+0x7C, 0x4E, 0xC8, 0x36, 0xD9, 0xE2, 0x00, 0xF7,
+0xFC, 0x9F, 0x0A, 0x10, 0x45, 0xF6, 0xD2, 0xA6,
+0x30, 0xF0, 0x20, 0x6F, 0x20, 0xF7, 0xE0, 0x9F,
+0x8C, 0xEE, 0x7C, 0x4E, 0xC8, 0x36, 0xD9, 0xE2,
+0xF9, 0xE6, 0xC0, 0xA6, 0x01, 0x4A, 0x04, 0x72,
+0xCC, 0xEC, 0x80, 0xC5, 0x01, 0x4D, 0x8C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0xB2, 0xA2,
+0x01, 0x6C, 0xC4, 0x67, 0xC4, 0xED, 0xCF, 0xED,
+0x45, 0xF6, 0xD2, 0xA2, 0xAC, 0xEB, 0xFF, 0x6D,
+0x84, 0xEE, 0x30, 0xF0, 0x20, 0x6E, 0xE1, 0xF2,
+0xCC, 0x9E, 0xAC, 0xEC, 0x80, 0xC6, 0x45, 0xF6,
+0x92, 0xA2, 0xAC, 0xEC, 0x01, 0x4C, 0xAC, 0xEC,
+0x45, 0xF6, 0x92, 0xC2, 0x45, 0xF6, 0xB2, 0xA2,
+0x03, 0x6C, 0xAC, 0xEC, 0x45, 0xF6, 0x92, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x80, 0xF1, 0x83, 0xA2, 0x08, 0x6D, 0x01, 0x4C,
+0x80, 0xF1, 0x83, 0xC2, 0x80, 0xF1, 0x83, 0xA2,
+0xAE, 0xEC, 0x11, 0x2C, 0x80, 0xF1, 0x83, 0xC2,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7,
+0xB0, 0x9B, 0x02, 0x6C, 0x60, 0x9D, 0x8D, 0xEB,
+0x60, 0xDD, 0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x64, 0xDA, 0x02, 0x10, 0x1F, 0xF7,
+0x1F, 0x2B, 0x03, 0x91, 0x02, 0x90, 0x02, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF2,
+0x50, 0x9A, 0xFF, 0x68, 0x60, 0xA2, 0x6C, 0xE8,
+0x1A, 0x20, 0x00, 0x6B, 0x60, 0xC2, 0x01, 0x6C,
+0x00, 0x18, 0x7D, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF2, 0x54, 0x9A, 0x20, 0x6B, 0x20, 0x70,
+0x60, 0xC2, 0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF0, 0x64, 0x9A, 0x80, 0xF6, 0x94, 0x9C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x7D, 0x0C,
+0x00, 0x18, 0x59, 0x08, 0x05, 0x6C, 0x01, 0x6D,
+0x00, 0x18, 0xB7, 0x1B, 0x20, 0xBA, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xFF, 0x17,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF2, 0x58, 0x9A,
+0x60, 0xA2, 0x03, 0x6A, 0x6C, 0xEA, 0x10, 0x6B,
+0x64, 0xEA, 0xFF, 0x6A, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF2, 0x5C, 0x9A, 0x04, 0xD3,
+0x40, 0x9A, 0x05, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF3, 0x40, 0x9A, 0x00, 0x9A, 0x05, 0x92,
+0x0A, 0xEA, 0xA0, 0xF0, 0x1B, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA0, 0xF0,
+0x64, 0x9A, 0x02, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x30, 0xF0, 0x20, 0x69, 0x45, 0xF6,
+0x18, 0x49, 0x02, 0xF6, 0x4C, 0xA9, 0x00, 0xF7,
+0x00, 0x72, 0x07, 0x60, 0x02, 0xF6, 0x8C, 0xA1,
+0x02, 0xF6, 0x6D, 0xA1, 0xAF, 0x44, 0x6E, 0xED,
+0x13, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x70, 0x9A, 0xFF, 0x6C, 0x01, 0x4C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA, 0x8E, 0x10,
+0x30, 0xF0, 0x20, 0x6D, 0x41, 0xF0, 0xAC, 0x9D,
+0x7F, 0x6E, 0xB5, 0xE0, 0xE0, 0xA5, 0xCC, 0xEF,
+0x3F, 0x2F, 0x00, 0xF4, 0x00, 0x72, 0x80, 0xF0,
+0x01, 0x60, 0xAC, 0x44, 0x6E, 0xED, 0x7E, 0x25,
+0x00, 0xF5, 0x01, 0x72, 0x7B, 0x60, 0x00, 0xF6,
+0x02, 0x72, 0x78, 0x60, 0x00, 0xF7, 0x03, 0x72,
+0x75, 0x60, 0x00, 0xF5, 0x00, 0x72, 0x72, 0x60,
+0xFD, 0x4C, 0x8E, 0xEB, 0x6F, 0x23, 0x30, 0xF0,
+0x20, 0x69, 0x45, 0xF6, 0x18, 0x49, 0x02, 0xF6,
+0x4C, 0xA9, 0x00, 0xF6, 0x01, 0x72, 0x66, 0x60,
+0x00, 0xF7, 0x02, 0x72, 0x63, 0x60, 0x00, 0xF6,
+0x00, 0x72, 0x60, 0x60, 0x02, 0xF6, 0x8C, 0xA1,
+0x02, 0xF6, 0x6D, 0xA1, 0xFE, 0x4C, 0x6E, 0xEC,
+0x59, 0x24, 0x00, 0xF7, 0x01, 0x72, 0x56, 0x60,
+0x74, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x71, 0xE1,
+0x01, 0xF3, 0x44, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0xAC, 0x9B, 0x49, 0xE0, 0x40, 0xAA,
+0x02, 0xF5, 0x0C, 0x4C, 0xB5, 0xE0, 0x0E, 0x10,
+0x40, 0xA5, 0x4C, 0xEE, 0x01, 0x76, 0x1B, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3, 0x44, 0x9A,
+0x74, 0x33, 0x71, 0xE1, 0x49, 0xE0, 0x40, 0xAA,
+0x02, 0xF5, 0x0C, 0x4C, 0xFF, 0x6E, 0x4C, 0xEE,
+0x00, 0x18, 0xA1, 0x1E, 0x02, 0xF6, 0x4D, 0xA1,
+0x08, 0x6B, 0x01, 0x4A, 0x02, 0xF6, 0x4D, 0xC1,
+0x02, 0xF6, 0x4D, 0xA1, 0x6E, 0xEA, 0x13, 0x2A,
+0x02, 0xF6, 0x4D, 0xC1, 0x10, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x90, 0x9A, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF0, 0x78, 0x9B, 0x40, 0x9C,
+0x6D, 0xEA, 0x40, 0xDC, 0x83, 0xF3, 0x44, 0x99,
+0x6D, 0xEA, 0x83, 0xF3, 0x44, 0xD9, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x48, 0x9A, 0x04, 0x93,
+0x40, 0x9A, 0x0E, 0xEA, 0x61, 0xE0, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3, 0x4C, 0x9A,
+0x00, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3,
+0x40, 0x9A, 0x00, 0xDA, 0x05, 0x92, 0x4A, 0xE8,
+0x5F, 0xF7, 0x0F, 0x61, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x05, 0xF7, 0x00, 0x4C, 0x07, 0x6E,
+0x00, 0x18, 0xA1, 0x1E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xE0, 0x63, 0x3F, 0x62,
+0x01, 0x6A, 0x7D, 0x67, 0x4B, 0xEA, 0x50, 0xC3,
+0x01, 0x6A, 0x52, 0xC3, 0x08, 0x6A, 0x53, 0xC3,
+0x40, 0xA4, 0x7F, 0x6B, 0x6C, 0xEA, 0x01, 0x72,
+0x0C, 0x61, 0x48, 0xA4, 0xBD, 0x67, 0x54, 0xC5,
+0x41, 0xA4, 0x55, 0xC5, 0x42, 0xA4, 0x56, 0xC5,
+0x46, 0xA4, 0x58, 0xC5, 0x43, 0xA4, 0x57, 0xC5,
+0x0A, 0x10, 0x0E, 0x2A, 0x69, 0xA4, 0xBD, 0x67,
+0x74, 0xC5, 0x68, 0xA4, 0x56, 0xC5, 0x57, 0xC5,
+0x75, 0xC5, 0x46, 0xA4, 0x58, 0xC5, 0x47, 0xA4,
+0x04, 0x04, 0x59, 0xC5, 0x00, 0x18, 0x69, 0x1F,
+0x3F, 0x97, 0x20, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x68, 0x44, 0xFA, 0x4B, 0x4C, 0xEB, 0x04, 0x5B,
+0x03, 0x60, 0x00, 0x18, 0x48, 0x3C, 0x15, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xE0, 0xF6, 0x90, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3,
+0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA,
+0xFF, 0x6A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xA0, 0xA4, 0x20, 0xF1, 0xDF, 0xA2, 0x02, 0x6B,
+0x01, 0x68, 0x6B, 0xEB, 0x0C, 0xED, 0xCC, 0xEB,
+0xAD, 0xEB, 0x20, 0xF1, 0x7F, 0xC2, 0xA1, 0xA4,
+0x0C, 0xEB, 0x40, 0xF1, 0xA0, 0xC2, 0x82, 0xA4,
+0x40, 0xF1, 0x81, 0xC2, 0x40, 0xF1, 0x41, 0xA2,
+0x06, 0xD2, 0x20, 0x23, 0x01, 0x69, 0x2B, 0xE9,
+0xD1, 0x67, 0x00, 0x6C, 0x42, 0x6D, 0x00, 0x18,
+0xD7, 0x28, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0xE0, 0x9B, 0xD1, 0x67, 0x00, 0x6C, 0x4D, 0xEF,
+0x42, 0x6D, 0x00, 0x18, 0x34, 0x29, 0x06, 0x96,
+0x64, 0x6A, 0x10, 0xF0, 0x21, 0x6C, 0x01, 0x4E,
+0x58, 0xEE, 0x99, 0xF2, 0x09, 0x4C, 0x00, 0x6D,
+0xF1, 0x67, 0x04, 0xD0, 0x12, 0xEE, 0x00, 0x18,
+0xCB, 0x2A, 0x06, 0x10, 0x10, 0xF0, 0x21, 0x6C,
+0x99, 0xF2, 0x09, 0x4C, 0x00, 0x18, 0xB8, 0x2A,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0xA4, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6, 0x18, 0x48,
+0x07, 0x6E, 0x05, 0xF7, 0x1F, 0x4C, 0x00, 0x18,
+0xA1, 0x1E, 0xC0, 0xF0, 0x8A, 0xA0, 0x96, 0x34,
+0x00, 0x18, 0x8E, 0x18, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x4C, 0x9A, 0x01, 0x6B, 0x60, 0xC2,
+0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6, 0x70, 0x9B,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF0,
+0x6B, 0xA0, 0xC0, 0xF6, 0x54, 0x9A, 0x60, 0xC2,
+0xC0, 0xF0, 0x68, 0xA0, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x44, 0x9A, 0x72, 0x33, 0x60, 0xC2,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x08, 0xD4, 0x41, 0xA4, 0x24, 0x67, 0x06, 0xD2,
+0x60, 0xA4, 0x02, 0x6A, 0x6C, 0xEA, 0x06, 0x93,
+0x07, 0xD3, 0x02, 0x22, 0x42, 0xA4, 0x07, 0xD2,
+0x06, 0x90, 0x15, 0x10, 0x08, 0x93, 0x01, 0x6D,
+0x90, 0x67, 0x40, 0xA3, 0x4C, 0xED, 0x00, 0x18,
+0x1B, 0x12, 0x90, 0x67, 0x00, 0x18, 0x12, 0x12,
+0x04, 0x2A, 0x90, 0x67, 0x00, 0x18, 0x3D, 0x12,
+0x03, 0x10, 0x90, 0x67, 0x00, 0x18, 0x42, 0x12,
+0x01, 0x48, 0xFF, 0x6A, 0x4C, 0xE8, 0x07, 0x92,
+0x03, 0xEA, 0xE8, 0x60, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0xE0, 0xF0, 0x8B, 0xA0,
+0x06, 0x92, 0x8E, 0xEA, 0x1B, 0x2A, 0x00, 0x18,
+0x12, 0x12, 0x18, 0x2A, 0x00, 0x18, 0x4C, 0x2F,
+0xC0, 0xF0, 0x8A, 0xA0, 0x96, 0x34, 0x00, 0x18,
+0xF3, 0x14, 0xA3, 0xF3, 0x60, 0xA0, 0x05, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xA3, 0xF3, 0x61, 0xA0,
+0xA3, 0xF3, 0x40, 0xC0, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x03, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0xA3, 0xF3, 0x41, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0xA9, 0xF3, 0xB0, 0xA2, 0x60, 0xA1, 0x01, 0x6A,
+0xAC, 0xEA, 0x72, 0x34, 0x15, 0x2A, 0x04, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x44, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x40, 0x9A, 0x60, 0xDA, 0xF0, 0x17,
+0x05, 0x74, 0x17, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA9, 0xF3, 0x70, 0xA2, 0x04, 0x6A, 0x6C, 0xEA,
+0x10, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x44, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF3, 0x78, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x40, 0x9A, 0x60, 0xDA,
+0xF0, 0x17, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0x43, 0xF4, 0x74, 0xA0, 0x02, 0x6A,
+0x6C, 0xEA, 0x1A, 0x22, 0x03, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x43, 0xF4, 0x54, 0xC0, 0x00, 0x18,
+0x4E, 0x2A, 0x04, 0xD2, 0x04, 0x93, 0x43, 0xF4,
+0x58, 0x98, 0x6E, 0xEA, 0x03, 0x22, 0x04, 0x94,
+0x00, 0x18, 0x6A, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x43, 0xF4, 0x94, 0xA2,
+0x02, 0x6B, 0x8D, 0xEB, 0x43, 0xF4, 0x74, 0xC2,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC, 0x68, 0x44,
+0xC8, 0x4B, 0x4C, 0xEB, 0x20, 0x5B, 0x05, 0x67,
+0x03, 0x60, 0x00, 0x18, 0x54, 0x40, 0x8D, 0x10,
+0x20, 0x74, 0x58, 0x60, 0x21, 0x5C, 0x18, 0x60,
+0x0A, 0x74, 0x44, 0x60, 0x0B, 0x5C, 0x08, 0x60,
+0x01, 0x74, 0x34, 0x60, 0x2F, 0x24, 0x08, 0x74,
+0x35, 0x60, 0x09, 0x74, 0x37, 0x60, 0x6A, 0x10,
+0x14, 0x74, 0x7B, 0x60, 0x15, 0x5C, 0x03, 0x60,
+0x13, 0x74, 0x38, 0x60, 0x63, 0x10, 0x1E, 0x74,
+0x3D, 0x60, 0x1F, 0x74, 0x37, 0x60, 0x5E, 0x10,
+0x2C, 0x74, 0x44, 0x60, 0x2D, 0x5C, 0x0C, 0x60,
+0x23, 0x74, 0x6B, 0x60, 0x24, 0x5C, 0x03, 0x60,
+0x21, 0x74, 0x67, 0x60, 0x53, 0x10, 0x25, 0x74,
+0x64, 0x60, 0x26, 0x74, 0x33, 0x60, 0x4E, 0x10,
+0xC3, 0x74, 0x44, 0x60, 0xC4, 0x5C, 0x05, 0x60,
+0x2E, 0x74, 0x34, 0x60, 0xC2, 0x74, 0x36, 0x60,
+0x45, 0x10, 0xCB, 0x74, 0x37, 0x60, 0xFE, 0x74,
+0x3D, 0x60, 0x40, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x04, 0x22, 0x4F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x74, 0x22, 0x4B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x6B, 0x1B, 0x47, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x64, 0x1B, 0x43, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x5D, 0x1B, 0x3F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x43, 0x05, 0x3B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xD3, 0x04, 0x37, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x2C, 0x05, 0x33, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x59, 0x22, 0x2F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x9F, 0x05, 0x2B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x79, 0x05, 0x27, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xFD, 0x24, 0x23, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xB2, 0x04, 0x1F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x34, 0x22, 0x1B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xB8, 0x23, 0x17, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x13, 0x2D, 0x13, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0x01, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA, 0x0E, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x40, 0xC0, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x80, 0xF1,
+0x42, 0xA0, 0x80, 0xF1, 0x63, 0xA0, 0x4E, 0xEB,
+0x29, 0x23, 0x67, 0x42, 0x21, 0x4B, 0x6C, 0x33,
+0x0D, 0xE3, 0x4C, 0x32, 0x82, 0xA3, 0x55, 0xE0,
+0x40, 0xF1, 0x03, 0x4D, 0x00, 0x18, 0xCB, 0x22,
+0x80, 0xF1, 0x42, 0xA0, 0x01, 0x4A, 0x80, 0xF1,
+0x42, 0xC0, 0x80, 0xF1, 0x62, 0xA0, 0x80, 0xF1,
+0x43, 0xA0, 0x6E, 0xEA, 0x06, 0x22, 0xA0, 0xF0,
+0x44, 0x98, 0x02, 0x6B, 0x6D, 0xEA, 0xA0, 0xF0,
+0x44, 0xD8, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x80, 0xF1, 0x62, 0xA2, 0x08, 0x6C,
+0x8E, 0xEB, 0x02, 0x2B, 0x80, 0xF1, 0x62, 0xC2,
+0x00, 0x18, 0xE4, 0x20, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0x02, 0xF6, 0x6C, 0xA0, 0x7F, 0x6C,
+0xA0, 0xF0, 0xA3, 0x43, 0xB4, 0x35, 0x09, 0xE5,
+0xA0, 0xF0, 0x4C, 0xA2, 0x8C, 0xEA, 0x25, 0x2A,
+0x74, 0x33, 0x09, 0xE3, 0x02, 0xF5, 0x94, 0xA2,
+0xA2, 0x67, 0x02, 0xF5, 0x15, 0x4D, 0x00, 0x18,
+0xCB, 0x22, 0x02, 0xF6, 0x8C, 0xA0, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF3, 0x7C, 0x9B, 0x94, 0x32,
+0x09, 0xE2, 0x02, 0xF5, 0xB2, 0xA2, 0x7F, 0x4C,
+0x24, 0x4C, 0xA0, 0xC3, 0x02, 0xF5, 0x73, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x40, 0x9A,
+0x94, 0x34, 0x60, 0xC2, 0x09, 0xE4, 0xA0, 0xF0,
+0x4C, 0x82, 0x91, 0xE0, 0x00, 0x52, 0x3E, 0x60,
+0x39, 0x10, 0x01, 0x72, 0x3B, 0x61, 0x74, 0x32,
+0x09, 0xE2, 0x02, 0xF5, 0x6D, 0xA2, 0xFF, 0x73,
+0x0E, 0x61, 0xB5, 0xE0, 0x02, 0xF5, 0x8E, 0xA2,
+0x7F, 0x4D, 0x2D, 0x4D, 0x00, 0x18, 0x22, 0x22,
+0x02, 0xF6, 0x6C, 0xA0, 0x74, 0x33, 0x01, 0xE3,
+0x02, 0xF5, 0x54, 0xC0, 0x04, 0x10, 0x01, 0x6B,
+0x6B, 0xEB, 0x02, 0xF5, 0x74, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x02, 0xF6,
+0x8C, 0xA2, 0x30, 0xF0, 0x20, 0x6D, 0x21, 0xF3,
+0xBC, 0x9D, 0x94, 0x33, 0x4D, 0xE3, 0x02, 0xF5,
+0xD2, 0xA3, 0x7F, 0x4C, 0x24, 0x4C, 0xC0, 0xC5,
+0x02, 0xF5, 0xB3, 0xA3, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF3, 0x60, 0x9B, 0x94, 0x34, 0xA0, 0xC3,
+0x4D, 0xE4, 0xA0, 0xF0, 0x6C, 0x83, 0x00, 0x53,
+0x05, 0x60, 0x91, 0xE2, 0x7F, 0x4C, 0x2D, 0x4C,
+0x00, 0x18, 0x0B, 0x22, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0x02, 0xF6, 0x6C, 0xA0, 0x02, 0xF6,
+0x4D, 0xA0, 0x6E, 0xEA, 0x42, 0x22, 0x80, 0xF6,
+0x44, 0xA8, 0x09, 0xF6, 0x00, 0x72, 0x10, 0x60,
+0x80, 0xF6, 0x84, 0xA0, 0x80, 0xF6, 0x65, 0xA0,
+0xAE, 0x44, 0x6E, 0xED, 0x09, 0x25, 0x09, 0xF7,
+0x01, 0x72, 0x06, 0x60, 0x09, 0xF7, 0x00, 0x72,
+0x03, 0x60, 0xFF, 0x4C, 0x8E, 0xEB, 0x0D, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0xA0, 0xF0, 0x44, 0x9B, 0x04, 0x6C, 0x8D, 0xEA,
+0x02, 0x6C, 0x8D, 0xEA, 0xA0, 0xF0, 0x44, 0xDB,
+0x20, 0x10, 0x00, 0x18, 0x39, 0x23, 0x02, 0xF6,
+0x4C, 0xA0, 0x01, 0x4A, 0x02, 0xF6, 0x4C, 0xC0,
+0x02, 0xF6, 0x6C, 0xA0, 0x02, 0xF6, 0x4D, 0xA0,
+0x6E, 0xEA, 0x06, 0x22, 0xA0, 0xF0, 0x44, 0x98,
+0x02, 0x6B, 0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x02, 0xF6, 0x6C, 0xA2, 0x08, 0x6C, 0x8E, 0xEB,
+0x02, 0x2B, 0x02, 0xF6, 0x6C, 0xC2, 0x00, 0x18,
+0x94, 0x21, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x22, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x92, 0xC3,
+0x01, 0x6A, 0x04, 0x04, 0x4F, 0xCB, 0x00, 0x18,
+0xF3, 0x1F, 0x09, 0x97, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x1A, 0x6A, 0x7D, 0x67,
+0x50, 0xC3, 0x00, 0xF0, 0x12, 0x04, 0x05, 0x6A,
+0x4F, 0xCB, 0x00, 0x18, 0x01, 0x07, 0x04, 0x04,
+0x00, 0x18, 0xF3, 0x1F, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x19, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x00, 0xF0,
+0x12, 0x04, 0x08, 0x6A, 0x4F, 0xCB, 0x00, 0x18,
+0x1B, 0x07, 0x04, 0x04, 0x00, 0x18, 0xF3, 0x1F,
+0x09, 0x97, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x40, 0xA4, 0x01, 0x72,
+0x04, 0x61, 0x00, 0x18, 0xAF, 0x23, 0x00, 0x18,
+0xA6, 0x23, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF3, 0x68, 0x9B, 0x30, 0xF0, 0x20, 0x68,
+0x41, 0xF3, 0x0C, 0x98, 0xE0, 0x9B, 0xFF, 0x6A,
+0x4C, 0xEC, 0x0C, 0xEF, 0x08, 0x5C, 0x4C, 0xED,
+0x4C, 0xEE, 0xE0, 0xDB, 0x46, 0x60, 0xB0, 0x75,
+0x2E, 0x61, 0xB2, 0x76, 0x13, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0xB0, 0x9A, 0x01, 0x6A,
+0x44, 0xEC, 0xC0, 0x9D, 0x00, 0xF6, 0x40, 0x34,
+0xCD, 0xEC, 0x80, 0xDD, 0xC0, 0x9D, 0x40, 0x34,
+0x80, 0x34, 0x8F, 0xEC, 0xCC, 0xEC, 0x80, 0xDD,
+0x80, 0x9B, 0x4E, 0x10, 0xB1, 0x76, 0x80, 0xF0,
+0x13, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0xB0, 0x9A, 0x01, 0x6A, 0x44, 0xEC, 0xC0, 0x9D,
+0x00, 0xF6, 0x40, 0x34, 0xCD, 0xEC, 0x80, 0xDD,
+0xC0, 0x9D, 0x40, 0x34, 0x80, 0x34, 0x8F, 0xEC,
+0xCC, 0xEC, 0x80, 0xDD, 0x80, 0x9B, 0x4F, 0xEA,
+0x8C, 0xEA, 0x40, 0xDB, 0x7B, 0x10, 0xA0, 0x75,
+0x7D, 0x61, 0xA1, 0x76, 0x08, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0x50, 0x9A, 0x01, 0x6B,
+0x64, 0xEC, 0xA0, 0x9A, 0x51, 0x10, 0xA2, 0x76,
+0x6F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x50, 0x9A, 0x01, 0x6B, 0x64, 0xEC, 0xA0, 0x9A,
+0x5A, 0x10, 0xE8, 0x44, 0x4C, 0xEF, 0x08, 0x5F,
+0xE0, 0x6A, 0x65, 0x60, 0xB0, 0x75, 0x35, 0x61,
+0xB2, 0x76, 0x18, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x54, 0x9A, 0x01, 0x6E, 0xA6, 0x67,
+0x00, 0x9A, 0xA4, 0xEF, 0xE5, 0x67, 0x00, 0xF6,
+0xA0, 0x35, 0x0D, 0xED, 0xA0, 0xDA, 0xA0, 0x9A,
+0xE0, 0x37, 0xE0, 0x37, 0xEF, 0xEF, 0xAC, 0xEF,
+0xE0, 0xDA, 0x40, 0x9B, 0xC4, 0xEC, 0x86, 0x67,
+0x4D, 0xEC, 0x19, 0x10, 0xB1, 0x76, 0x44, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x54, 0x9A,
+0x01, 0x6E, 0xA6, 0x67, 0x00, 0x9A, 0xA4, 0xEF,
+0xE5, 0x67, 0x00, 0xF6, 0xA0, 0x35, 0x0D, 0xED,
+0xA0, 0xDA, 0xA0, 0x9A, 0xE0, 0x37, 0xE0, 0x37,
+0xEF, 0xEF, 0xAC, 0xEF, 0xE0, 0xDA, 0x40, 0x9B,
+0xC4, 0xEC, 0xCF, 0xEC, 0x4C, 0xEC, 0x80, 0xDB,
+0x29, 0x10, 0xA0, 0x75, 0x2B, 0x61, 0xA1, 0x76,
+0x11, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x54, 0x9A, 0x01, 0x6B, 0x64, 0xEF, 0xA0, 0x9A,
+0x00, 0xF6, 0x60, 0x34, 0x8F, 0xEC, 0xAC, 0xEC,
+0x80, 0xDA, 0x80, 0x9A, 0x60, 0x33, 0x60, 0x33,
+0x8D, 0xEB, 0x13, 0x10, 0xA2, 0x76, 0x14, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x54, 0x9A,
+0x01, 0x6B, 0x64, 0xEF, 0xA0, 0x9A, 0x00, 0xF6,
+0x60, 0x34, 0x8F, 0xEC, 0xAC, 0xEC, 0x80, 0xDA,
+0x80, 0x9A, 0x60, 0x33, 0x60, 0x33, 0x6F, 0xEB,
+0x8C, 0xEB, 0x60, 0xDA, 0xF0, 0x6A, 0x03, 0x10,
+0xE2, 0x6A, 0x01, 0x10, 0xE1, 0x6A, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6B, 0x6C, 0xEC,
+0x08, 0x5C, 0xFF, 0x63, 0x18, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0x58, 0x9A, 0x01, 0x6D,
+0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC, 0xAC, 0xEA,
+0x37, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x5C, 0x9A, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x30, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x50, 0x9A, 0x1C, 0x10, 0xF8, 0x4C,
+0x6C, 0xEC, 0x08, 0x5C, 0xE0, 0x6A, 0x27, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x40, 0x9A,
+0x01, 0x6D, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x1A, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x44, 0x9A, 0x40, 0xA2, 0x6C, 0xEA,
+0x47, 0xEC, 0xAC, 0xEA, 0x13, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0x54, 0x9A, 0x40, 0xA2,
+0xA4, 0xEC, 0x85, 0x67, 0x6C, 0xEC, 0x4C, 0xEC,
+0x5D, 0x67, 0x80, 0xC2, 0x40, 0xA2, 0x4C, 0xEB,
+0x6B, 0xEA, 0xC0, 0xF7, 0x42, 0x32, 0x03, 0x10,
+0xE4, 0x6A, 0x01, 0x10, 0xE6, 0x6A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x08, 0x5C, 0x6C, 0xED, 0x20, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0x58, 0x9A, 0x01, 0x6E,
+0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC, 0xCC, 0xEA,
+0x48, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x5C, 0x9A, 0xC4, 0xEC, 0x86, 0x67, 0x40, 0xA2,
+0x6C, 0xEA, 0xCC, 0xEA, 0xCE, 0xEA, 0x3B, 0x2A,
+0x05, 0x25, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0xA8, 0x9A, 0x24, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x48, 0x9A, 0x29, 0x10, 0xF8, 0x4C,
+0x6C, 0xEC, 0x08, 0x5C, 0xE0, 0x6A, 0x2E, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x40, 0x9A,
+0x01, 0x6E, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xCC, 0xEA, 0x23, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x44, 0x9A, 0xC4, 0xEC, 0x86, 0x67,
+0x40, 0xA2, 0x6C, 0xEA, 0xCC, 0xEA, 0xCE, 0xEA,
+0x16, 0x2A, 0x0A, 0x25, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0xAC, 0x9A, 0x40, 0xA5, 0x6C, 0xEA,
+0x8D, 0xEA, 0x6C, 0xEA, 0x40, 0xC5, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x4C, 0x9A,
+0xA0, 0xA2, 0x8F, 0xEC, 0x6C, 0xEC, 0xAC, 0xEC,
+0x80, 0xC2, 0xF0, 0x6A, 0x20, 0xE8, 0xE5, 0x6A,
+0x20, 0xE8, 0xE4, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x08, 0x5C, 0x0F, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x58, 0x9A,
+0x01, 0x6D, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x1F, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x5C, 0x9A, 0x13, 0x10, 0xF8, 0x4C,
+0x6C, 0xEC, 0x08, 0x5C, 0xE0, 0x6A, 0x16, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x40, 0x9A,
+0x01, 0x6D, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x44, 0x9A, 0x40, 0xA2, 0x4C, 0xEB,
+0x67, 0xEC, 0x45, 0x67, 0x6E, 0xEA, 0xAC, 0xEA,
+0x20, 0xE8, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x08, 0x5C, 0x1A, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x58, 0x9A,
+0x01, 0x6E, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xCC, 0xEA, 0x35, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x5C, 0x9A, 0xC4, 0xEC, 0x86, 0x67,
+0xA0, 0xA2, 0x6C, 0xED, 0xCC, 0xED, 0xCE, 0xED,
+0x2A, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x48, 0x9A, 0x1E, 0x10, 0xF8, 0x4C, 0x6C, 0xEC,
+0x08, 0x5C, 0xE0, 0x6A, 0x21, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x40, 0x9A, 0x01, 0x6E,
+0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC, 0xCC, 0xEA,
+0x16, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x44, 0x9A, 0xC4, 0xEC, 0x86, 0x67, 0xA0, 0xA2,
+0x6C, 0xED, 0xCC, 0xED, 0xCE, 0xED, 0x0B, 0x2D,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x4C, 0x9A,
+0x40, 0xA2, 0x4C, 0xEB, 0x8C, 0xEB, 0x6E, 0xEC,
+0x01, 0x5C, 0x58, 0x67, 0x20, 0xE8, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x04, 0x67,
+0x2C, 0xE8, 0x90, 0x67, 0xA0, 0x6D, 0xA2, 0x6E,
+0x00, 0x18, 0xBE, 0x23, 0x90, 0x67, 0x00, 0x18,
+0x21, 0x24, 0x7D, 0x67, 0x50, 0xC3, 0x50, 0xA3,
+0x09, 0x97, 0x07, 0x90, 0x2C, 0xEA, 0x08, 0x91,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x68, 0x24, 0x67,
+0x0C, 0xE9, 0x91, 0x67, 0xAC, 0xE8, 0xA1, 0x6E,
+0xA0, 0x6D, 0x00, 0x18, 0xBE, 0x23, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x47, 0x24, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6D,
+0x41, 0xF3, 0xAC, 0x9D, 0x40, 0x9B, 0xA2, 0x6E,
+0xAC, 0xEA, 0x40, 0xDB, 0xFF, 0x6A, 0x4C, 0xEC,
+0xA0, 0x6D, 0x00, 0x18, 0xBE, 0x23, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0xB0, 0x6D, 0xB2, 0x6E,
+0x00, 0x18, 0xBE, 0x23, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0xB0, 0x6D, 0xB1, 0x6E,
+0x00, 0x18, 0xBE, 0x23, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x04, 0x67, 0x4C, 0xE8,
+0xAC, 0xEA, 0xA4, 0x72, 0x0C, 0x61, 0x90, 0x67,
+0x00, 0x18, 0x74, 0x24, 0x01, 0x72, 0x04, 0x61,
+0x90, 0x67, 0x00, 0x18, 0xC6, 0x24, 0x1F, 0x10,
+0x90, 0x67, 0x00, 0x6D, 0x0D, 0x10, 0xA5, 0x72,
+0x11, 0x61, 0x90, 0x67, 0x00, 0x18, 0x74, 0x24,
+0x01, 0x72, 0x04, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xC6, 0x24, 0x18, 0x10, 0x90, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0xBB, 0x24, 0x90, 0x67, 0x00, 0x18,
+0xC6, 0x24, 0x14, 0x10, 0x90, 0x67, 0x00, 0x18,
+0x8C, 0x24, 0x01, 0x72, 0x07, 0x61, 0x90, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0xBB, 0x24, 0x90, 0x67,
+0x00, 0x6D, 0x06, 0x10, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0xBB, 0x24, 0x90, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0xBB, 0x24, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF7,
+0x09, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0xA1, 0x1E,
+0x30, 0xF0, 0x20, 0x6D, 0x45, 0xF6, 0x18, 0x4D,
+0xE0, 0xF0, 0x91, 0xA5, 0x01, 0x6A, 0xC2, 0x67,
+0x8C, 0xEE, 0xFF, 0x6B, 0x37, 0x26, 0x02, 0x6E,
+0x8C, 0xEE, 0x6C, 0xEE, 0x0F, 0x26, 0x04, 0x6E,
+0x8C, 0xEE, 0x6C, 0xEE, 0x22, 0x26, 0x08, 0x6A,
+0x8C, 0xEA, 0x6C, 0xEA, 0x16, 0x2A, 0xE0, 0xF0,
+0x52, 0xA5, 0x7F, 0x6C, 0x00, 0x6D, 0x4C, 0xEC,
+0x6C, 0xEC, 0x22, 0x10, 0x04, 0x6E, 0x8C, 0xEE,
+0x6C, 0xEE, 0x13, 0x26, 0x08, 0x6A, 0x8C, 0xEA,
+0x6C, 0xEA, 0x07, 0x22, 0xE0, 0xF0, 0x52, 0xA5,
+0x7F, 0x6C, 0x01, 0x6D, 0x4C, 0xEC, 0x6C, 0xEC,
+0x13, 0x10, 0xE0, 0xF0, 0x52, 0xA5, 0x7F, 0x6C,
+0x4C, 0xEC, 0x6C, 0xEC, 0x00, 0x18, 0xC6, 0x24,
+0x0D, 0x10, 0xE0, 0xF0, 0xD2, 0xA5, 0xE0, 0xF0,
+0xB1, 0xA5, 0x7F, 0x6C, 0xCC, 0xEC, 0xA6, 0x35,
+0x01, 0x6E, 0xCE, 0xED, 0x6C, 0xEC, 0x4C, 0xED,
+0x00, 0x18, 0xBB, 0x24, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x00, 0x6A, 0x7D, 0x67, 0x52, 0xC3, 0x14, 0x6A,
+0x50, 0xC3, 0x04, 0x04, 0x01, 0x6A, 0x4F, 0xCB,
+0x00, 0x18, 0xF3, 0x1F, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF7, 0x98, 0xA2,
+0x80, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x1D, 0x22, 0x10, 0x6A, 0x8C, 0xEA,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x25, 0x25,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xC0, 0xF0, 0x81, 0xA2, 0x80, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xFF, 0x6C, 0x8C, 0xEB, 0x0B, 0x23,
+0xC0, 0xF0, 0xA0, 0xA2, 0x0F, 0x6B, 0x01, 0x6A,
+0xAC, 0xEB, 0xBA, 0x35, 0x4E, 0xED, 0x6C, 0xEC,
+0x4C, 0xED, 0x00, 0x18, 0xBB, 0x24, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0xC0, 0xF0, 0x41, 0xA0,
+0x7F, 0x6B, 0xFF, 0x69, 0x4C, 0xEB, 0xC0, 0xF0,
+0x42, 0xA0, 0x2C, 0xEC, 0x2C, 0xEB, 0x01, 0x74,
+0x04, 0xD3, 0x05, 0xD2, 0x52, 0x60, 0xC0, 0xF0,
+0x80, 0xA0, 0x80, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x2C, 0xEA, 0x4B, 0x22, 0xC0, 0xF0, 0xA0, 0xA0,
+0x01, 0x6A, 0x0F, 0x6B, 0xBA, 0x35, 0x6C, 0xEC,
+0x4E, 0xED, 0x4C, 0xED, 0x2C, 0xEC, 0x00, 0x18,
+0xBB, 0x24, 0xC0, 0xF0, 0xA0, 0xA0, 0xC0, 0xF0,
+0x80, 0xA0, 0x0F, 0x6B, 0x01, 0x6A, 0xBA, 0x35,
+0x6C, 0xEC, 0x4C, 0xED, 0x2C, 0xEC, 0x2C, 0xED,
+0x00, 0x18, 0xBB, 0x24, 0xC0, 0xF0, 0x60, 0xA0,
+0x20, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x1F, 0x22,
+0x04, 0x93, 0x80, 0x6A, 0x4B, 0xEA, 0x74, 0x36,
+0xC0, 0xF0, 0x61, 0xA0, 0x6C, 0xEA, 0x2C, 0xEA,
+0x06, 0x22, 0xFF, 0x6C, 0x59, 0x4C, 0x00, 0x6D,
+0x00, 0x18, 0xF1, 0x25, 0x10, 0x10, 0x86, 0x67,
+0x00, 0x18, 0x7D, 0x1E, 0xC0, 0xF0, 0xA0, 0xA0,
+0xC0, 0xF0, 0x80, 0xA0, 0x01, 0x6B, 0x0F, 0x6A,
+0xBA, 0x35, 0x4C, 0xEC, 0x6E, 0xED, 0x2C, 0xEC,
+0x6C, 0xED, 0x00, 0x18, 0xBB, 0x24, 0x30, 0xF0,
+0x20, 0x6A, 0x05, 0xF7, 0x78, 0xA2, 0x10, 0x6A,
+0x6C, 0xEA, 0x07, 0x22, 0x05, 0x92, 0xFF, 0x6C,
+0x59, 0x4C, 0x00, 0x6D, 0x4C, 0x36, 0x00, 0x18,
+0xF1, 0x25, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0xA9, 0xF3, 0x16, 0x4C,
+0x00, 0x6D, 0x06, 0x6E, 0x00, 0x18, 0x9C, 0x1E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x01, 0x72, 0xFF, 0xF7, 0x1F, 0x6C, 0xAC, 0xEC,
+0x03, 0x61, 0x00, 0x18, 0x75, 0x1E, 0x02, 0x10,
+0x00, 0x18, 0x7D, 0x1E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x4C, 0xEE, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x60, 0xA2, 0xFF, 0xF7,
+0x1F, 0x69, 0x04, 0xD4, 0xAC, 0xE9, 0x05, 0xD6,
+0x0B, 0x23, 0x63, 0xF5, 0x61, 0xA2, 0x04, 0x23,
+0x43, 0xF5, 0x9E, 0xA2, 0xA5, 0x6D, 0x07, 0x10,
+0x43, 0xF5, 0x9E, 0xA2, 0xA4, 0x6D, 0x03, 0x10,
+0x43, 0xF5, 0x9E, 0xA2, 0xA3, 0x6D, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x00, 0x18,
+0xDD, 0x24, 0x63, 0xF5, 0x42, 0xA0, 0x7D, 0x22,
+0x04, 0x94, 0xB1, 0x67, 0x00, 0x18, 0x80, 0x25,
+0x63, 0xF5, 0x40, 0xA0, 0x0B, 0x22, 0x63, 0xF5,
+0x41, 0xA0, 0x04, 0x22, 0x43, 0xF5, 0x9E, 0xA0,
+0xA5, 0x6D, 0x07, 0x10, 0x43, 0xF5, 0x9E, 0xA0,
+0xA4, 0x6D, 0x03, 0x10, 0x43, 0xF5, 0x9E, 0xA0,
+0xA3, 0x6D, 0x00, 0x18, 0xDD, 0x24, 0x30, 0xF0,
+0x20, 0x6A, 0xA9, 0xF3, 0x5B, 0xA2, 0x01, 0x68,
+0x5D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x50, 0x9A, 0x60, 0xA2, 0x10, 0x6A, 0x6C, 0xEA,
+0x58, 0x2A, 0x04, 0x94, 0xB1, 0x67, 0x00, 0x18,
+0x80, 0x25, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x60, 0xA2, 0x0B, 0x23,
+0x63, 0xF5, 0x61, 0xA2, 0x04, 0x23, 0x43, 0xF5,
+0x9E, 0xA2, 0xA5, 0x6D, 0x07, 0x10, 0x43, 0xF5,
+0x9E, 0xA2, 0xA4, 0x6D, 0x03, 0x10, 0x43, 0xF5,
+0x9E, 0xA2, 0xA3, 0x6D, 0x00, 0x18, 0xDD, 0x24,
+0xDC, 0x17, 0x04, 0x94, 0xB1, 0x67, 0x00, 0x18,
+0x80, 0x25, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x60, 0xA2, 0x0B, 0x23,
+0x63, 0xF5, 0x61, 0xA2, 0x04, 0x23, 0x43, 0xF5,
+0x9E, 0xA2, 0xA5, 0x6D, 0x07, 0x10, 0x43, 0xF5,
+0x9E, 0xA2, 0xA4, 0x6D, 0x03, 0x10, 0x43, 0xF5,
+0x9E, 0xA2, 0xA3, 0x6D, 0x00, 0x18, 0xDD, 0x24,
+0x04, 0x94, 0xB1, 0x67, 0x00, 0x18, 0x80, 0x25,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x60, 0xA2, 0x0B, 0x23, 0x63, 0xF5,
+0x61, 0xA2, 0x04, 0x23, 0x43, 0xF5, 0x9E, 0xA2,
+0xA5, 0x6D, 0x07, 0x10, 0x43, 0xF5, 0x9E, 0xA2,
+0xA4, 0x6D, 0x03, 0x10, 0x43, 0xF5, 0x9E, 0xA2,
+0xA3, 0x6D, 0x00, 0x18, 0xDD, 0x24, 0x01, 0x48,
+0xFF, 0x6A, 0x4C, 0xE8, 0x05, 0x92, 0x43, 0xE8,
+0xC4, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFF, 0xF7, 0x1F, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x8C, 0xEA, 0x61, 0xF2,
+0x60, 0x9B, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF3,
+0x94, 0x9C, 0xCC, 0xEB, 0x40, 0xF6, 0xA0, 0x35,
+0x8D, 0xEB, 0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC,
+0x02, 0xF0, 0x00, 0x74, 0xAD, 0xEB, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF7,
+0x9C, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF7, 0x80, 0x9C, 0x89, 0xE2, 0x60, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC,
+0xFF, 0x6B, 0x02, 0xF0, 0x00, 0x74, 0xAC, 0xEB,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x00, 0xF7, 0x9C, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x20, 0xF7, 0x80, 0x9C, 0x91, 0xE2,
+0x00, 0x6D, 0xA0, 0xDC, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF2, 0x80, 0x9C, 0xD4, 0x36, 0x40, 0xF6,
+0x60, 0x33, 0x8C, 0xEE, 0x6D, 0xEE, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x74, 0x9B, 0x6D, 0xEE,
+0x1F, 0xF7, 0x00, 0x6B, 0x4C, 0xEB, 0x02, 0xF0,
+0x00, 0x73, 0x01, 0x60, 0x05, 0x2B, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF7, 0x7C, 0x9B, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x60, 0x9B,
+0x69, 0xE2, 0xC0, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x0F, 0xF5, 0x00, 0x6B, 0x78, 0xEE, 0xFF, 0xF7,
+0x1F, 0x6A, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF2, 0x80, 0x9C, 0x40, 0xF6, 0xA0, 0x35,
+0x12, 0xEB, 0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x94, 0x9C, 0xAD, 0xEB, 0x8D, 0xEB,
+0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC, 0x02, 0xF0,
+0x00, 0x74, 0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF7, 0x9C, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF7, 0x80, 0x9C,
+0x89, 0xE2, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6, 0x54, 0x9A,
+0x40, 0x9A, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x68, 0xF4, 0x50, 0xA2, 0x01, 0x72, 0x0B, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x7C, 0x9A,
+0xFF, 0x6C, 0x04, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x05, 0x5C, 0x4C, 0xED,
+0x00, 0x6A, 0x4B, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0xC0, 0xF5, 0x04, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x01, 0x6A, 0xFF, 0x6B,
+0x44, 0xED, 0x6C, 0xEA, 0xE0, 0xF3, 0x01, 0x4B,
+0x0C, 0x10, 0x01, 0x6A, 0x05, 0x10, 0x04, 0x6A,
+0x03, 0x10, 0x10, 0x6A, 0x01, 0x10, 0x40, 0x6A,
+0xFF, 0x6B, 0x44, 0xED, 0x6C, 0xEA, 0xE0, 0xF3,
+0x04, 0x4B, 0x1F, 0xF7, 0x00, 0x6C, 0x6C, 0xEC,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF7,
+0x9C, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF7, 0x80, 0x9C, 0x8D, 0xE3, 0x80, 0xA3,
+0xFF, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x01, 0x6A,
+0x1C, 0x2B, 0x0E, 0x2D, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x50, 0x9A, 0x01, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x4C, 0x9A,
+0x02, 0x6B, 0x60, 0xC2, 0x00, 0x6A, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x50, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x4C, 0x9A, 0x04, 0x6B, 0x60, 0xC2,
+0x00, 0x6A, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x00, 0x68, 0xFF, 0x6A, 0x0C, 0xEA, 0x2E, 0xEA,
+0x10, 0x2A, 0x91, 0x67, 0x00, 0x18, 0xA1, 0x2D,
+0x91, 0x67, 0x00, 0x18, 0x90, 0x2D, 0x91, 0x67,
+0x00, 0x18, 0xA8, 0x2D, 0x91, 0x67, 0x00, 0x18,
+0x72, 0x2D, 0x91, 0x67, 0x00, 0x18, 0x68, 0x2D,
+0x0F, 0x10, 0x90, 0x67, 0x00, 0x18, 0xC0, 0x2D,
+0x90, 0x67, 0x00, 0x18, 0xAF, 0x2D, 0x90, 0x67,
+0x00, 0x18, 0xC7, 0x2D, 0x90, 0x67, 0x00, 0x18,
+0x86, 0x2D, 0x90, 0x67, 0x00, 0x18, 0x7C, 0x2D,
+0x01, 0x48, 0x05, 0x70, 0xDA, 0x61, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0x84, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0xA0, 0x9C, 0x52, 0x9B, 0xAC, 0xEA, 0x53, 0xDB,
+0x40, 0xDC, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0xD1,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF2,
+0x34, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3,
+0x10, 0x4A, 0x40, 0x9A, 0x60, 0x99, 0x30, 0xF0,
+0x20, 0x6C, 0xA0, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF3, 0x58, 0x9A, 0xA1, 0xF3, 0x00, 0x4C,
+0x80, 0x9C, 0x00, 0x9A, 0x1A, 0x65, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0x9C, 0xA1, 0xF3, 0x08, 0x4A,
+0x40, 0x9A, 0x01, 0xD4, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0x9A, 0x45, 0xF6, 0xF8, 0x9C, 0x00, 0xD2,
+0x44, 0x67, 0x45, 0xF6, 0x18, 0x4A, 0xC1, 0x9A,
+0x83, 0x9A, 0x6C, 0xEF, 0xAC, 0xEE, 0x01, 0x93,
+0xA2, 0x9A, 0xE8, 0xDA, 0x6C, 0xEC, 0x0C, 0xED,
+0x64, 0x9A, 0x00, 0x90, 0x8B, 0xDA, 0xC9, 0xDA,
+0x0C, 0xEB, 0xAA, 0xDA, 0x6C, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0x10, 0x4A, 0x40, 0x9A,
+0xE0, 0xD9, 0x18, 0x67, 0xC0, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0x00, 0x4A, 0x40, 0x9A,
+0xA0, 0xD8, 0x80, 0xDA, 0x30, 0xF0, 0x20, 0x6C,
+0xA1, 0xF3, 0x08, 0x4C, 0x80, 0x9C, 0x60, 0xDC,
+0x05, 0x91, 0x04, 0x90, 0x03, 0x63, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD1, 0x00, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x00, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0xF4, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0xDC, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x80, 0x98,
+0xB4, 0x9A, 0x60, 0x9F, 0x20, 0x9E, 0x8C, 0xED,
+0x95, 0x9A, 0xB7, 0xDA, 0x6C, 0xEC, 0x76, 0x9A,
+0x98, 0xDA, 0x2C, 0xEB, 0x79, 0xDA, 0xA0, 0xD8,
+0x80, 0xDF, 0x60, 0xDE, 0x01, 0x91, 0x00, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xA0, 0xF0, 0x8F, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x07, 0x23, 0xA0, 0xF0, 0x64, 0x9A, 0x04, 0xF0,
+0x00, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0x06, 0x74, 0x0A, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF3, 0x90, 0x9B, 0x01, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF6, 0x9C, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3,
+0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x54, 0x9A, 0x60, 0xA2, 0x03, 0x6A,
+0x6C, 0xEA, 0x03, 0x72, 0x08, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x78, 0x9A, 0x7F, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x54, 0x9A,
+0x60, 0xA2, 0x03, 0x6A, 0x6C, 0xEA, 0x03, 0x72,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x78, 0x9A, 0x7F, 0x6A, 0x80, 0xA3, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x07, 0x6D, 0xB8, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x01, 0x6E, 0x12, 0xEC, 0x71, 0xE4, 0x00, 0xF1,
+0xA7, 0xA4, 0xCC, 0xED, 0x1D, 0x25, 0x00, 0xF1,
+0xA8, 0xA4, 0x02, 0xF6, 0x74, 0x9B, 0x00, 0xF1,
+0x87, 0xA4, 0x75, 0xE5, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x6C, 0x9B, 0xBC, 0x35, 0x21, 0x4D,
+0x75, 0xE5, 0xE0, 0xA5, 0x9E, 0x33, 0x9A, 0x34,
+0xCC, 0xEC, 0x78, 0x33, 0x9C, 0x34, 0x4C, 0xEF,
+0x8D, 0xEB, 0xED, 0xEB, 0x00, 0xF6, 0x60, 0x33,
+0x00, 0xF6, 0x63, 0x33, 0x4C, 0xEB, 0x60, 0xC5,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x05, 0xF7, 0xBF, 0xA3,
+0x7F, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x02, 0x23, 0x00, 0x18, 0xA1, 0x16,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x45, 0xF6, 0x18, 0x48, 0x04, 0xD4, 0xE0, 0xF0,
+0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12, 0x01, 0x72,
+0x15, 0x61, 0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x0F, 0x22, 0xA3, 0xF3,
+0x64, 0xA0, 0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xA3, 0xF3, 0x44, 0xC0, 0xA3, 0xF3, 0x44, 0xA0,
+0x07, 0x6B, 0x6C, 0xEA, 0x03, 0x2A, 0x04, 0x94,
+0x00, 0x18, 0xF1, 0x15, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x45, 0xF6, 0x18, 0x48, 0x04, 0xD4, 0xE0, 0xF0,
+0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12, 0x01, 0x72,
+0x2E, 0x61, 0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x28, 0x22, 0xA3, 0xF3,
+0x4F, 0xA0, 0x01, 0x6B, 0x6E, 0xEA, 0x0B, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6, 0x7C, 0x9B,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x40, 0x9A, 0x02, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3,
+0x80, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x6C, 0xEC,
+0xA3, 0xF3, 0x80, 0xC2, 0xA3, 0xF3, 0x84, 0xA2,
+0x8C, 0xEB, 0xA3, 0xF3, 0x64, 0xC2, 0xA3, 0xF3,
+0x44, 0xA2, 0x07, 0x6B, 0x6C, 0xEA, 0x03, 0x2A,
+0x04, 0x94, 0x00, 0x18, 0xF1, 0x15, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x45, 0xF6, 0x18, 0x48, 0x04, 0xD4, 0xE0, 0xF0,
+0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12, 0x01, 0x72,
+0x1E, 0x61, 0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x18, 0x22, 0xC0, 0xF0,
+0x88, 0xA0, 0x10, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x2C, 0xEB, 0x20, 0x73, 0x05, 0x60, 0x01, 0x72,
+0x03, 0x61, 0x00, 0x18, 0xC2, 0x18, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF7, 0x7F, 0xA2,
+0x7F, 0x6A, 0x6C, 0xEA, 0x02, 0x72, 0x03, 0x60,
+0x04, 0x94, 0x00, 0x18, 0xA6, 0x16, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0xE0, 0xF0,
+0x8B, 0xA0, 0x00, 0x18, 0x12, 0x12, 0x01, 0x72,
+0x1C, 0x61, 0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x17, 0x22, 0xA3, 0xF3, 0x4F, 0xA0,
+0x01, 0x6B, 0x6E, 0xEA, 0x12, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF6, 0x7C, 0x9B, 0xFF, 0x6C,
+0x55, 0x4C, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x40, 0x9A, 0x02, 0x6B, 0x00, 0x6D,
+0x60, 0xC2, 0xC0, 0xF0, 0xCF, 0xA0, 0x00, 0x18,
+0xF1, 0x25, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x36, 0x14, 0x49, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF1, 0x5B, 0xA2, 0x02, 0x72,
+0x03, 0x60, 0x90, 0x67, 0x00, 0x18, 0x5C, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xE0, 0xF0, 0xB1, 0xA2, 0x01, 0x6C, 0xFF, 0x6B,
+0xAC, 0xEC, 0x36, 0x24, 0xE0, 0xF0, 0xB4, 0xA2,
+0xE0, 0xF0, 0xD3, 0xA2, 0x7F, 0x6C, 0x8C, 0xED,
+0x8C, 0xEE, 0xE0, 0xF0, 0x94, 0xA2, 0x6C, 0xED,
+0x6C, 0xEE, 0x9E, 0x34, 0x6C, 0xEC, 0x05, 0x2C,
+0xB4, 0x35, 0xD0, 0x4D, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xE0, 0xF0, 0xF2, 0xA2, 0x7F, 0x6B,
+0xEC, 0xEB, 0x43, 0xF5, 0x7E, 0xC2, 0xE0, 0xF0,
+0x71, 0xA2, 0x01, 0x6F, 0x66, 0x30, 0xEC, 0xE8,
+0x43, 0xF5, 0x1F, 0xC2, 0xE0, 0xF0, 0x13, 0xA2,
+0x1E, 0x30, 0x63, 0xF5, 0x02, 0xC2, 0x6A, 0x30,
+0x6E, 0x33, 0xEC, 0xEB, 0xEC, 0xE8, 0x63, 0xF5,
+0x61, 0xC2, 0x00, 0x6B, 0x63, 0xF5, 0x00, 0xC2,
+0x63, 0xF5, 0x63, 0xC2, 0x00, 0x18, 0x89, 0x25,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x94, 0x21,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0xA3, 0xF3, 0x61, 0xA0, 0x02, 0x6A, 0xFF, 0x69,
+0x6C, 0xEA, 0x2C, 0xEC, 0x2C, 0xEA, 0x04, 0xD4,
+0x1C, 0x22, 0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x01, 0x6D, 0xA3, 0xF3, 0x41, 0xC0, 0x00, 0x18,
+0x2E, 0x26, 0xA3, 0xF3, 0x81, 0xA0, 0x01, 0x6B,
+0x4C, 0xEB, 0x09, 0x6A, 0x4B, 0xEA, 0x6C, 0x33,
+0x8C, 0xEA, 0x6D, 0xEA, 0xC0, 0xF0, 0x67, 0xA0,
+0xA3, 0xF3, 0x41, 0xC0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x03, 0x22, 0x04, 0x94, 0x00, 0x18,
+0xF1, 0x15, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x30, 0xF0,
+0x20, 0x68, 0x4C, 0xEC, 0x45, 0xF6, 0x18, 0x48,
+0x04, 0xD4, 0xA3, 0xF3, 0x81, 0xA0, 0x01, 0x69,
+0x64, 0x67, 0x2C, 0xEB, 0x4C, 0xEB, 0x16, 0x23,
+0xFF, 0xF6, 0x1F, 0x4A, 0x8C, 0xEA, 0x04, 0x94,
+0x00, 0x6D, 0xA3, 0xF3, 0x41, 0xC0, 0x00, 0x18,
+0x2E, 0x26, 0x4C, 0xE9, 0xA3, 0xF3, 0x41, 0xA0,
+0x05, 0x6B, 0x6B, 0xEB, 0x04, 0x94, 0x28, 0x31,
+0x4C, 0xEB, 0x2D, 0xEB, 0xA3, 0xF3, 0x61, 0xC0,
+0x00, 0x18, 0xF1, 0x15, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0x4B, 0x29, 0x02, 0x67, 0x01, 0x6A, 0x0C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x01, 0x6D, 0x02, 0x10,
+0x00, 0x6C, 0xA4, 0x67, 0x00, 0x18, 0xB2, 0x12,
+0x40, 0x6A, 0x0C, 0xEA, 0x0F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x5C, 0x9A, 0x60, 0xA2,
+0x00, 0xF6, 0x60, 0x33, 0x00, 0xF6, 0x63, 0x33,
+0x00, 0x53, 0x00, 0x6B, 0x02, 0x61, 0x80, 0x6B,
+0x6B, 0xEB, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xA3, 0xF3, 0x94, 0xA2,
+0xA3, 0xF3, 0xB5, 0xA2, 0xA3, 0xF3, 0xD9, 0xA2,
+0x02, 0x6F, 0x00, 0x18, 0x3B, 0x13, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xA9, 0xF2, 0x48, 0xA2, 0x09, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x44, 0x9A, 0x66, 0x6B,
+0x00, 0x6C, 0x60, 0xC2, 0x00, 0x18, 0x21, 0x19,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xB4, 0x01,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xA9, 0xF2, 0x6C, 0xA2, 0x02, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0x1F, 0x2B,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0xC0, 0xF0, 0x67, 0xA0, 0x7F, 0x6A, 0xFF, 0x69,
+0x6C, 0xEA, 0x1E, 0x22, 0xC0, 0xF0, 0x8A, 0xA0,
+0x96, 0x34, 0x2C, 0xEC, 0x00, 0x18, 0x79, 0x29,
+0x02, 0x6B, 0x4C, 0xEB, 0x2C, 0xEB, 0x07, 0x23,
+0xC0, 0xF0, 0x8A, 0xA0, 0x96, 0x34, 0x2C, 0xEC,
+0x00, 0x18, 0x6E, 0x16, 0x0D, 0x10, 0xC0, 0xF0,
+0x8A, 0xA0, 0xA3, 0xF3, 0x60, 0xA0, 0x05, 0x6A,
+0x4B, 0xEA, 0x96, 0x34, 0x6C, 0xEA, 0x2C, 0xEC,
+0xA3, 0xF3, 0x40, 0xC0, 0x00, 0x18, 0xF1, 0x15,
+0x00, 0x18, 0x2D, 0x25, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xC0, 0xF0, 0x87, 0xA2,
+0x7F, 0x6B, 0x8C, 0xEB, 0x07, 0x23, 0xC0, 0xF0,
+0x8A, 0xA2, 0xFF, 0x6A, 0x96, 0x34, 0x4C, 0xEC,
+0x00, 0x18, 0xBD, 0x16, 0x00, 0x18, 0xFF, 0x13,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x0C, 0xEC, 0x00, 0x18, 0xDA, 0x15, 0x00, 0x6C,
+0x00, 0x18, 0x5D, 0x14, 0x30, 0xF0, 0x20, 0x6A,
+0x05, 0xF7, 0x67, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x0C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x5B, 0x19,
+0x00, 0x18, 0xC9, 0x13, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x38, 0x2A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x6F, 0x1C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x6C, 0x1C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x65, 0x21, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xE4, 0x20, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x1D, 0x2E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x30, 0xF0, 0x20, 0x6C,
+0x45, 0xF6, 0x18, 0x4C, 0xC0, 0xF0, 0xA7, 0xA4,
+0x7F, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xE8, 0x09, 0x23, 0xA3, 0xF3, 0x80, 0xA4,
+0x40, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x03, 0x23,
+0x90, 0x67, 0x00, 0x18, 0xC0, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x54, 0x9A, 0xFF, 0x6B,
+0x80, 0xA2, 0x03, 0x6A, 0x8C, 0xEA, 0x03, 0x72,
+0x13, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF7,
+0x9E, 0xA2, 0x01, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x98, 0x9A, 0x80, 0x6D, 0xAB, 0xED, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x43, 0xF4, 0x75, 0xA2, 0x0E, 0xEB, 0x11, 0x2B,
+0x43, 0xF4, 0x74, 0xA2, 0x1F, 0x6C, 0x6A, 0x32,
+0x8C, 0xEA, 0x47, 0xE8, 0x01, 0x6C, 0x8C, 0xEA,
+0x08, 0x22, 0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x1F, 0x2B, 0x00, 0x18, 0xAF, 0x13, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x55, 0x28, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x6C, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEE, 0x6D, 0xE4, 0x08, 0x68,
+0x80, 0xA3, 0xDB, 0xE0, 0x02, 0x67, 0x4C, 0xED,
+0x07, 0xEE, 0xD0, 0x67, 0x4C, 0xEF, 0x04, 0xED,
+0x4C, 0xEC, 0xCC, 0xEF, 0x0F, 0xE8, 0x8C, 0xE8,
+0xE4, 0xED, 0xED, 0xE8, 0x4C, 0xE8, 0x00, 0xC3,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x4C, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6B, 0x8C, 0xEB, 0x4D, 0xE3,
+0x40, 0xA3, 0xFF, 0x6C, 0x8C, 0xEE, 0x08, 0x6B,
+0xDB, 0xE3, 0x8C, 0xED, 0x8C, 0xEA, 0x64, 0x67,
+0x47, 0xED, 0x67, 0xEE, 0x6C, 0xEA, 0x8C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x01, 0x74, 0x0D, 0x60,
+0x06, 0x24, 0x02, 0x74, 0x10, 0x60, 0x03, 0x74,
+0x00, 0x6A, 0x1C, 0x61, 0x14, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA8, 0x35, 0xE1, 0xF3, 0x40, 0x9A,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA8, 0x35,
+0xE1, 0xF3, 0x44, 0x9A, 0x05, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF3, 0x48, 0x9A, 0xA8, 0x35,
+0x55, 0xE5, 0x40, 0x9D, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF3, 0x4C, 0x9A, 0xA8, 0x35,
+0x55, 0xE5, 0x40, 0x9D, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x81, 0xF4, 0x10, 0x6B, 0x23, 0xF2, 0x64, 0xDA,
+0x00, 0xF2, 0x00, 0x4B, 0x23, 0xF2, 0x68, 0xDA,
+0x01, 0xF2, 0x00, 0x4B, 0x23, 0xF2, 0x6C, 0xDA,
+0x00, 0xF2, 0x00, 0x4B, 0x23, 0xF2, 0x70, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x1F, 0x6D, 0x8C, 0xED, 0x96, 0x34, 0x6C, 0xEC,
+0x01, 0x74, 0x03, 0x6A, 0x0A, 0x60, 0x10, 0x24,
+0x04, 0x74, 0x05, 0x60, 0x06, 0x74, 0x00, 0x6A,
+0x12, 0x61, 0xEF, 0x4A, 0x02, 0x10, 0x07, 0x6A,
+0x4B, 0xEA, 0xAB, 0xE2, 0x44, 0x32, 0x00, 0xF6,
+0x40, 0x32, 0x00, 0xF6, 0x43, 0x32, 0x20, 0xE8,
+0x08, 0x6A, 0xAB, 0xE2, 0x44, 0x32, 0x00, 0xF6,
+0x40, 0x32, 0x00, 0xF6, 0x43, 0x32, 0x20, 0xE8,
+0x00, 0xF6, 0x80, 0x34, 0x00, 0xF6, 0x83, 0x34,
+0x47, 0x44, 0x5C, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA,
+0x77, 0x5A, 0x00, 0x6A, 0x06, 0x60, 0x00, 0x54,
+0x64, 0x6A, 0x03, 0x60, 0x47, 0x44, 0x5D, 0x4A,
+0x6C, 0xEA, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6B, 0x8C, 0xEB,
+0xFF, 0xF7, 0x1F, 0x6A, 0x81, 0x46, 0x26, 0x67,
+0xAC, 0xEA, 0x06, 0x2C, 0x83, 0x67, 0xA2, 0x67,
+0x00, 0x18, 0x9F, 0x28, 0x02, 0x67, 0x0A, 0x10,
+0x83, 0x67, 0xA2, 0x67, 0x00, 0x18, 0x9F, 0x28,
+0x02, 0x67, 0x91, 0x67, 0x00, 0x18, 0x88, 0x1D,
+0x2C, 0xE8, 0x06, 0xEA, 0x50, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x0E, 0x91, 0x04, 0xD2,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED, 0x4C, 0xE9,
+0x0C, 0xD6, 0x0D, 0xD7, 0x0F, 0x90, 0x05, 0xD5,
+0x00, 0x6A, 0x05, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x7D, 0x1E, 0x40, 0xA8, 0x01, 0x4A, 0x40, 0xC8,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x94, 0x05, 0x95,
+0x81, 0xF0, 0xC4, 0x9A, 0x00, 0x18, 0xD7, 0x28,
+0x0C, 0x93, 0x6C, 0xEA, 0x0D, 0x93, 0x6E, 0xEA,
+0x03, 0x22, 0x40, 0xA8, 0x23, 0xEA, 0xEA, 0x61,
+0x40, 0xA8, 0x09, 0x97, 0x07, 0x90, 0x23, 0xEA,
+0x08, 0x91, 0x58, 0x67, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x60, 0x9B,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x69, 0xE2,
+0x00, 0x9A, 0x41, 0x45, 0x25, 0x67, 0x05, 0x22,
+0x85, 0x67, 0x00, 0x18, 0x88, 0x1D, 0x2C, 0xE8,
+0x06, 0xEA, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0xF7, 0x1F, 0x68, 0x41, 0x45, 0x25, 0x67,
+0x0C, 0xD6, 0x8C, 0xE8, 0x07, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A, 0x41, 0xE0,
+0xC0, 0xD8, 0x17, 0x10, 0x01, 0x6D, 0x90, 0x67,
+0xAB, 0xED, 0x00, 0x18, 0x00, 0x29, 0x91, 0x67,
+0x04, 0xD2, 0x00, 0x18, 0x88, 0x1D, 0x0C, 0x93,
+0x64, 0xEA, 0x43, 0x67, 0x04, 0x93, 0x2C, 0xEA,
+0x2F, 0xE9, 0x6C, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF7, 0x60, 0x9B, 0x2D, 0xEA, 0x61, 0xE0,
+0x40, 0xD8, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF0, 0x1C, 0x4A,
+0x88, 0x34, 0x91, 0xE2, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x44, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF5, 0xA0, 0x35, 0xCC, 0xEA, 0x81, 0xF2,
+0xC4, 0x9B, 0x80, 0xAC, 0xAD, 0xEA, 0x01, 0x6D,
+0xAB, 0xED, 0x4C, 0xEE, 0x00, 0x18, 0x0E, 0x29,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x46, 0x67, 0xFF, 0x68, 0xFF, 0xF7, 0x1F, 0x69,
+0x01, 0x4A, 0x0C, 0xD6, 0x0D, 0xD7, 0x8C, 0xE8,
+0xAC, 0xE9, 0x04, 0x2A, 0x90, 0x67, 0xB1, 0x67,
+0xC7, 0x67, 0x12, 0x10, 0xB1, 0x67, 0x90, 0x67,
+0x00, 0x18, 0x9F, 0x28, 0x0C, 0x94, 0x04, 0xD2,
+0x00, 0x18, 0x88, 0x1D, 0x0D, 0x96, 0x90, 0x67,
+0xB1, 0x67, 0xC4, 0xEA, 0x0C, 0x92, 0x4C, 0xEE,
+0x4F, 0xEB, 0x04, 0x92, 0x4C, 0xEB, 0x6D, 0xEE,
+0x00, 0x18, 0x25, 0x29, 0x0A, 0x6C, 0x00, 0x18,
+0x7D, 0x1E, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x34, 0xF5, 0x0D, 0x4A, 0x40, 0xDB, 0x00, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF3, 0xB0, 0x9A,
+0xFF, 0x6C, 0x40, 0xA5, 0xA0, 0xA5, 0x8C, 0xEA,
+0xAC, 0xEC, 0x4E, 0xEC, 0x19, 0x24, 0x64, 0x73,
+0x12, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7,
+0x90, 0x9B, 0x40, 0x6D, 0x60, 0x9C, 0xAD, 0xEB,
+0x60, 0xDC, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x83, 0xF3, 0x84, 0x9B, 0xAD, 0xEC,
+0x83, 0xF3, 0x84, 0xDB, 0x20, 0xE8, 0x01, 0x4B,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEB, 0xDC, 0x17,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x94, 0xF5, 0x0D, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF3, 0x54, 0x9A, 0x60, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0xF8, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x21, 0x6A, 0x94, 0xF5, 0x0E, 0x4A, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF3, 0x78, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC,
+0xE0, 0xA3, 0x1F, 0x6E, 0x94, 0x34, 0xEC, 0xEE,
+0xCD, 0xEC, 0x4C, 0xED, 0x4C, 0xEC, 0x80, 0xC3,
+0xA0, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF3, 0x78, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC,
+0xC0, 0xA3, 0x1F, 0x6D, 0x94, 0x34, 0xCC, 0xED,
+0xAD, 0xEC, 0x4C, 0xEC, 0x80, 0xC3, 0x60, 0xA3,
+0x6C, 0xEA, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xED,
+0xFF, 0x75, 0x4C, 0xEC, 0xCC, 0xEA, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x71, 0xE4, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x71, 0xE4, 0x63, 0xF3,
+0x6F, 0xA4, 0xAC, 0xEA, 0xAF, 0xED, 0x6C, 0xED,
+0xAD, 0xEA, 0x63, 0xF3, 0x4F, 0xC4, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xFF, 0x69, 0x34, 0xF6,
+0x19, 0x4A, 0x8C, 0xE9, 0x40, 0xDB, 0x00, 0x68,
+0x26, 0x10, 0x82, 0xF3, 0x08, 0x70, 0x12, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x10, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x64, 0xDA, 0x1C, 0x10, 0xFF, 0xF7, 0x1F, 0x6A,
+0x01, 0x48, 0x4C, 0xE8, 0x14, 0x6C, 0x00, 0x18,
+0x7D, 0x1E, 0x33, 0x58, 0x08, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x50, 0x9A, 0x01, 0x6B,
+0x40, 0xA2, 0x6C, 0xEA, 0x0B, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF3, 0x5C, 0x9A, 0x01, 0x6B,
+0x40, 0x9A, 0x42, 0x32, 0x5E, 0x32, 0x6C, 0xEA,
+0x2E, 0xEA, 0xCF, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x34, 0xF6, 0x1A, 0x4A, 0x40, 0xDB, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x63, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x70, 0x9A,
+0xEF, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x00, 0x6C, 0x00, 0x18, 0x8E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0x94, 0x9A, 0xA1, 0xF3, 0x70, 0x9B,
+0x80, 0xDB, 0xA3, 0xF3, 0x80, 0xA2, 0x7F, 0x6B,
+0x8C, 0xEB, 0xA3, 0xF3, 0x60, 0xC2, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0xA3, 0xF3, 0x60, 0xA0, 0x80, 0x6A,
+0x4B, 0xEA, 0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0xA3, 0xF3, 0x40, 0xC0, 0x00, 0x6D, 0x09, 0xF2,
+0x08, 0x4C, 0x00, 0x18, 0x41, 0x2E, 0x30, 0xF0,
+0x20, 0x6A, 0xA3, 0xF3, 0x70, 0xA8, 0x01, 0xF4,
+0x40, 0x9A, 0xFF, 0x68, 0x10, 0x6C, 0x60, 0xCA,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x70, 0x9A,
+0x40, 0xA3, 0x0C, 0xEA, 0x8D, 0xEA, 0x0C, 0xEA,
+0x40, 0xC3, 0x01, 0x6C, 0x00, 0x18, 0x8E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x50, 0x9A,
+0x02, 0x6B, 0x01, 0x6C, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF3, 0x74, 0x9A, 0x40, 0xA3,
+0x0C, 0xEA, 0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3,
+0x20, 0xBA, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0xF4, 0xF7,
+0x0D, 0x4A, 0x40, 0xDB, 0x00, 0x68, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF4, 0x44, 0x9A, 0x40, 0x9A,
+0x1E, 0x22, 0xE0, 0xF3, 0x09, 0x70, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x20, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x64, 0xDA, 0x00, 0x6A, 0x09, 0x10, 0x32, 0x6C,
+0x00, 0x18, 0x7D, 0x1E, 0x01, 0x48, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0xDC, 0x17, 0x01, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x6A, 0x4C, 0xEC, 0xFF, 0x74, 0xAC, 0xEA,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0xA9, 0xF1,
+0x56, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x43, 0xF3, 0xBE, 0xA3,
+0x8C, 0xEA, 0x8F, 0xEC, 0xAC, 0xEC, 0x8D, 0xEA,
+0x43, 0xF3, 0x5E, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x68, 0x26, 0x67, 0x0C, 0xE9, 0x53, 0x71,
+0x0C, 0xEC, 0x0C, 0xED, 0x09, 0x60, 0x06, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF1, 0x55, 0xA2,
+0xAD, 0xEA, 0x0B, 0x10, 0x00, 0x18, 0x16, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x43, 0xF3, 0x7E, 0xA2, 0x43, 0xF3, 0x5D, 0xA2,
+0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6,
+0x6C, 0x9B, 0x0C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xA9, 0xF1, 0x33, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF4, 0x68, 0x9A, 0x7F, 0x6A, 0xBD, 0x67,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF4, 0x4C, 0x9A, 0x7D, 0x67,
+0x80, 0xA2, 0x01, 0x6A, 0x4F, 0xCD, 0x4C, 0xEC,
+0x92, 0xC3, 0x02, 0x6B, 0x70, 0xC5, 0x00, 0x18,
+0x63, 0x46, 0x04, 0x04, 0x00, 0x18, 0xF3, 0x1F,
+0x09, 0x97, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xA0, 0xF0, 0x64, 0x9A, 0x10, 0x6C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF2, 0x4D, 0xA2,
+0xFF, 0x63, 0x05, 0x5A, 0x2C, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x48, 0x32, 0x00, 0xF6, 0x18, 0x4B,
+0x4D, 0xE3, 0x40, 0x9B, 0x00, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x44, 0x9A, 0xFF, 0xF7,
+0x1F, 0x6B, 0x40, 0x9A, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x44, 0x9A, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4, 0x50, 0x9A,
+0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4,
+0x50, 0x9A, 0x40, 0x9A, 0x50, 0x32, 0x00, 0xF5,
+0x42, 0x32, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF4, 0x54, 0x9A, 0x40, 0x9A, 0xE1, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x01, 0x10, 0x64, 0x6A,
+0x00, 0xD2, 0x00, 0x92, 0x01, 0x63, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD0, 0x0C, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0xF6, 0x98, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x5D, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x43, 0xF4,
+0xB4, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB,
+0x43, 0xF4, 0x74, 0xC2, 0x43, 0xF4, 0xD8, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xC9, 0xF2, 0x0C, 0x4A,
+0x00, 0x6D, 0x18, 0x6F, 0xF8, 0xED, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x12, 0xEF,
+0x6D, 0xE7, 0x63, 0xF4, 0x08, 0xA3, 0x01, 0x6F,
+0xEC, 0xE8, 0x23, 0x20, 0x63, 0xF4, 0x68, 0xA3,
+0x66, 0x33, 0xEC, 0xEB, 0xFF, 0x6F, 0xEC, 0xEB,
+0x1C, 0x23, 0xFF, 0xF7, 0x78, 0x9A, 0x9B, 0xEB,
+0x01, 0x2C, 0xE5, 0xE8, 0x12, 0xEB, 0xFF, 0xF7,
+0x7C, 0xDA, 0x10, 0xEF, 0x03, 0x27, 0x01, 0x4B,
+0xFF, 0xF7, 0x7C, 0xDA, 0x60, 0x9A, 0x78, 0xEE,
+0x12, 0xEB, 0x9B, 0xEB, 0x01, 0x2C, 0xE5, 0xE8,
+0x12, 0xEB, 0x60, 0xDA, 0xFF, 0xF7, 0x7C, 0x9A,
+0x04, 0x2B, 0x01, 0x6F, 0xFF, 0xF7, 0xFC, 0xDA,
+0x60, 0xDA, 0x01, 0x4D, 0x0A, 0x75, 0x18, 0x4A,
+0xCC, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x43, 0xF4, 0x7C, 0x9A, 0x43, 0xF4,
+0x98, 0xDA, 0x7B, 0xEC, 0x01, 0x2B, 0xE5, 0xE8,
+0x43, 0xF4, 0x94, 0xA2, 0x12, 0xEB, 0x63, 0xF4,
+0x60, 0xDA, 0x78, 0x67, 0x63, 0xF4, 0x64, 0xDA,
+0x02, 0x6B, 0x8D, 0xEB, 0x43, 0xF4, 0x74, 0xC2,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x43, 0xF4, 0xB4, 0xA3, 0x02, 0x6C, 0x00, 0x6A,
+0xAC, 0xEC, 0x0C, 0x24, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF4, 0x58, 0x9A, 0x00, 0x6C, 0x80, 0xC2,
+0x03, 0x6A, 0x4B, 0xEA, 0xAC, 0xEA, 0x43, 0xF4,
+0x54, 0xC3, 0x01, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x00, 0x6A, 0x18, 0x6C, 0x98, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x01, 0x4A,
+0x0A, 0x72, 0x12, 0xEC, 0x71, 0xE4, 0x63, 0xF4,
+0xA8, 0xA4, 0x02, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB,
+0x63, 0xF4, 0x68, 0xC4, 0xEE, 0x61, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF2, 0x4C, 0xA2,
+0x01, 0x6B, 0x4C, 0xEB, 0x00, 0x6A, 0x1C, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0xC9, 0xF2, 0x10, 0x4A,
+0x00, 0x6B, 0xA0, 0x9A, 0x8E, 0xED, 0x0F, 0x2D,
+0x18, 0x6E, 0xD8, 0xEB, 0x30, 0xF0, 0x20, 0x6D,
+0x45, 0xF6, 0x18, 0x4D, 0x12, 0xEE, 0xB9, 0xE6,
+0x63, 0xF4, 0xE8, 0xA6, 0x02, 0x6D, 0xAB, 0xED,
+0xEC, 0xED, 0x63, 0xF4, 0xA8, 0xC6, 0x01, 0x4B,
+0x0A, 0x73, 0x18, 0x4A, 0xEA, 0x61, 0x01, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x5D, 0x67, 0x0A, 0xD4,
+0x20, 0xF0, 0x98, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0x0B, 0xD5, 0x0C, 0xD6, 0x45, 0xF6, 0x18, 0x4A,
+0x43, 0xF4, 0xB4, 0xA2, 0x01, 0x6B, 0x00, 0xF6,
+0xE0, 0x31, 0xAC, 0xEB, 0x00, 0xF6, 0x23, 0x31,
+0x80, 0xF0, 0x09, 0x23, 0x21, 0x24, 0x01, 0x74,
+0x80, 0xF0, 0x05, 0x61, 0x0A, 0x93, 0x80, 0xF0,
+0x02, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF4,
+0x7C, 0x9B, 0xC3, 0xEB, 0x7C, 0x61, 0x7F, 0x71,
+0x7A, 0x60, 0xFF, 0xF7, 0x1F, 0x51, 0x77, 0x61,
+0x43, 0xF4, 0x18, 0x9A, 0x1B, 0xEE, 0x01, 0x28,
+0xE5, 0xE8, 0x10, 0xEA, 0x12, 0xE8, 0x02, 0x22,
+0x01, 0x48, 0x04, 0x10, 0x03, 0x28, 0x01, 0x68,
+0x50, 0x67, 0x1D, 0x10, 0x01, 0x6B, 0x1E, 0x10,
+0x0A, 0x94, 0x65, 0x24, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF4, 0x7C, 0x9B, 0x0C, 0x95, 0xA3, 0xEB,
+0x5E, 0x61, 0x7F, 0x71, 0x5C, 0x60, 0xFF, 0xF7,
+0x1F, 0x51, 0x59, 0x61, 0x43, 0xF4, 0x1C, 0x9A,
+0x1B, 0xED, 0x01, 0x28, 0xE5, 0xE8, 0x10, 0xEA,
+0x12, 0xE8, 0x02, 0x22, 0x01, 0x48, 0x05, 0x10,
+0x04, 0x28, 0x01, 0x68, 0x00, 0x6A, 0x04, 0xD2,
+0x02, 0x10, 0x00, 0x6B, 0x04, 0xD3, 0x0A, 0x94,
+0x00, 0x18, 0xB8, 0x2A, 0x00, 0x6C, 0xFF, 0x6E,
+0xA4, 0x67, 0xCC, 0xED, 0x1D, 0x65, 0x18, 0x6D,
+0xB8, 0xEC, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x01, 0x6D, 0x12, 0xEA, 0x69, 0xE2,
+0x63, 0xF4, 0x48, 0xA2, 0xAC, 0xEA, 0xCC, 0xEA,
+0x2F, 0x2A, 0xD8, 0x67, 0x18, 0x6F, 0xF8, 0xEE,
+0x04, 0x96, 0xC4, 0x36, 0x04, 0xD6, 0x03, 0x6E,
+0xCB, 0xEE, 0x12, 0xEC, 0x71, 0xE4, 0x63, 0xF4,
+0xE8, 0xA4, 0xEC, 0xEE, 0x04, 0x97, 0xED, 0xEE,
+0x63, 0xF4, 0xC8, 0xC4, 0x0A, 0x96, 0x63, 0xF4,
+0xD8, 0xDC, 0x0B, 0x97, 0x63, 0xF4, 0xFC, 0xDC,
+0x0C, 0x96, 0x18, 0x6F, 0x63, 0xF4, 0xCC, 0xDC,
+0xD8, 0x67, 0x01, 0x4E, 0xF8, 0xEE, 0x12, 0xEE,
+0x6D, 0xE6, 0x43, 0xF4, 0x5C, 0xDB, 0x43, 0xF4,
+0x18, 0xDB, 0x63, 0xF4, 0x49, 0xC4, 0x63, 0xF4,
+0x48, 0xA4, 0x63, 0xF4, 0x2A, 0xC4, 0x4D, 0xED,
+0x63, 0xF4, 0xA8, 0xC4, 0x01, 0x6A, 0x04, 0x10,
+0x01, 0x4C, 0x0A, 0x74, 0xBC, 0x61, 0x00, 0x6A,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC9, 0xF2, 0x0C, 0x4A, 0x00, 0x6C,
+0x4A, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC9, 0xF2,
+0x0C, 0x4A, 0x00, 0x6B, 0x18, 0x6D, 0xB8, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6, 0x18, 0x4C,
+0x12, 0xED, 0x91, 0xE5, 0x63, 0xF4, 0xC8, 0xA4,
+0x01, 0x6D, 0xAC, 0xEE, 0x08, 0x26, 0x63, 0xF4,
+0x88, 0xA4, 0x86, 0x34, 0xAC, 0xEC, 0x03, 0x24,
+0x80, 0x9A, 0x01, 0x4C, 0x80, 0xDA, 0x01, 0x4B,
+0x0A, 0x73, 0x18, 0x4A, 0xE7, 0x61, 0x00, 0x18,
+0x4E, 0x2A, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xC0, 0xF0, 0x6A, 0xA2,
+0x43, 0xF4, 0xB5, 0xA2, 0xFF, 0x6C, 0x76, 0x33,
+0xAE, 0xEB, 0x12, 0x2B, 0xC0, 0xF0, 0xA7, 0xA2,
+0x7F, 0x6B, 0xAC, 0xEB, 0x8C, 0xEB, 0x0C, 0x23,
+0xC0, 0xF0, 0xA8, 0xA2, 0x0F, 0x6B, 0xAC, 0xEB,
+0x8C, 0xEB, 0x06, 0x23, 0x04, 0x93, 0xA3, 0xF3,
+0x48, 0xA2, 0x78, 0xEA, 0x12, 0xEA, 0x04, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x93, 0xA9, 0xF2,
+0x50, 0x9A, 0x6E, 0xEA, 0x52, 0x22, 0x04, 0x94,
+0x00, 0x18, 0x6A, 0x2A, 0x4E, 0x10, 0x18, 0x6D,
+0xB8, 0xEC, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x12, 0xED, 0x6D, 0xE5, 0x63, 0xF4,
+0xC8, 0xA3, 0x01, 0x6D, 0xAC, 0xEE, 0x0A, 0x26,
+0x63, 0xF4, 0x68, 0xA3, 0x66, 0x33, 0xAC, 0xEB,
+0xFF, 0x6D, 0xAC, 0xEB, 0x03, 0x2B, 0x60, 0x9A,
+0x01, 0x4B, 0x60, 0xDA, 0x01, 0x4C, 0x0A, 0x74,
+0x18, 0x4A, 0xE5, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x43, 0xF4, 0x75, 0xA2,
+0xFF, 0x73, 0x2B, 0x61, 0x63, 0xF4, 0x64, 0x9A,
+0x01, 0x4B, 0x63, 0xF4, 0x64, 0xDA, 0x63, 0xF4,
+0x40, 0x9A, 0x4E, 0xEB, 0x22, 0x2B, 0x30, 0xF0,
+0x20, 0x6A, 0xC9, 0xF2, 0x0C, 0x4A, 0x18, 0x6D,
+0xB8, 0xEB, 0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6,
+0x18, 0x4C, 0x12, 0xED, 0x91, 0xE5, 0x63, 0xF4,
+0xC8, 0xA4, 0x01, 0x6D, 0xAC, 0xEE, 0x08, 0x26,
+0x63, 0xF4, 0x88, 0xA4, 0x86, 0x34, 0xAC, 0xEC,
+0x03, 0x24, 0x80, 0x9A, 0x01, 0x4C, 0x80, 0xDA,
+0x01, 0x4B, 0x0A, 0x73, 0x18, 0x4A, 0xE7, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x78, 0x67, 0xA9, 0xF2,
+0x7C, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xA0, 0xF0, 0x64, 0x9A, 0x02, 0xF0,
+0x00, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0xC9, 0xF2, 0x01, 0x48,
+0x00, 0x69, 0x18, 0x6A, 0x58, 0xE9, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x12, 0xEA,
+0x69, 0xE2, 0x63, 0xF4, 0x88, 0xA2, 0x01, 0x6B,
+0x8C, 0xEB, 0x27, 0x23, 0x00, 0xF0, 0x8B, 0x98,
+0x00, 0xF0, 0x67, 0x98, 0x63, 0xEC, 0x21, 0x61,
+0x61, 0x80, 0x81, 0x43, 0x04, 0xD4, 0x07, 0x2C,
+0x00, 0xF0, 0x4F, 0x98, 0x00, 0xF0, 0x93, 0x98,
+0x40, 0xEA, 0x04, 0x92, 0x14, 0x10, 0x80, 0xA0,
+0x01, 0x4C, 0x80, 0xC0, 0x80, 0xA0, 0x82, 0xEB,
+0x08, 0x60, 0x63, 0xF4, 0x88, 0xA2, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x63, 0xF4, 0x68, 0xC2,
+0x08, 0x10, 0x00, 0xF0, 0x4F, 0x98, 0x00, 0xF0,
+0x93, 0x98, 0x40, 0xEA, 0x00, 0x6A, 0x00, 0xF0,
+0x4B, 0xD8, 0x01, 0x49, 0x0A, 0x71, 0x18, 0x48,
+0xC8, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0x43, 0xF4, 0x94, 0xA0, 0x01, 0x6B,
+0x00, 0x6A, 0x8C, 0xEB, 0x1F, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF4, 0x58, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x03, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x43, 0xF4, 0x54, 0xC0, 0x00, 0x18, 0x4E, 0x2A,
+0x04, 0xD2, 0x04, 0x94, 0x00, 0x18, 0x6A, 0x2A,
+0x43, 0xF4, 0x74, 0xA0, 0x43, 0xF4, 0xDC, 0x98,
+0x02, 0x6A, 0xFF, 0x6C, 0x6D, 0xEA, 0x6D, 0x4C,
+0x01, 0x6D, 0x43, 0xF4, 0x54, 0xC0, 0x00, 0x18,
+0xF1, 0x25, 0x01, 0x6A, 0x07, 0x97, 0x06, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0x43, 0xF4, 0x54, 0xA0,
+0x03, 0x69, 0x4C, 0xE9, 0x00, 0x6A, 0x23, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4, 0x58, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xFF, 0x6E, 0xA9, 0xF2,
+0x0C, 0x4C, 0x20, 0xC2, 0x00, 0x6D, 0x05, 0x4E,
+0x00, 0x18, 0x9C, 0x1E, 0x64, 0x6A, 0x43, 0xF4,
+0x94, 0xA0, 0x43, 0xF4, 0x58, 0xD8, 0x63, 0xF4,
+0x40, 0xD8, 0x80, 0x4A, 0x9F, 0x4A, 0x8C, 0xEA,
+0x04, 0x6C, 0x01, 0x6B, 0x8D, 0xEA, 0x6D, 0xEA,
+0x43, 0xF4, 0x54, 0xC0, 0x43, 0xF4, 0x7C, 0xD8,
+0x43, 0xF4, 0x35, 0xC0, 0x43, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6B, 0xE9, 0xF1, 0x6D, 0xA3,
+0xFF, 0x6A, 0xAC, 0xEA, 0x03, 0x23, 0x02, 0x73,
+0x11, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF6, 0x7C, 0x9B, 0x83, 0xEB, 0x05, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF4, 0x60, 0x9B,
+0x09, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x70, 0x9B, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF1, 0x70, 0x9B, 0x71, 0xE4, 0x40, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xE9, 0xF1, 0x6D, 0xA3, 0xFF, 0xF7, 0x1F, 0x6A,
+0xAC, 0xEA, 0x03, 0x23, 0x02, 0x73, 0x11, 0x60,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6,
+0x7C, 0x9B, 0x83, 0xEB, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF4, 0x60, 0x9B, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x70, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF1,
+0x70, 0x9B, 0x71, 0xE4, 0x40, 0xCC, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x4D, 0xA2,
+0x03, 0x22, 0x02, 0x72, 0x11, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6, 0x5C, 0x9A,
+0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF4, 0x40, 0x9A, 0x09, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x50, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0x50, 0x9A,
+0x51, 0xE4, 0xA0, 0xDC, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x4D, 0xA2,
+0x04, 0x22, 0x02, 0x72, 0x00, 0x6A, 0x1D, 0x61,
+0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x5C, 0x9A, 0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF4, 0x40, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x50, 0x9A,
+0x51, 0xE4, 0x60, 0xA4, 0xFF, 0x6A, 0x6C, 0xEA,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0x50, 0x9A, 0x51, 0xE4, 0x60, 0xA4, 0xFF, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x4D, 0xA2, 0x04, 0x22, 0x02, 0x72,
+0x00, 0x6A, 0x1F, 0x61, 0x15, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x5C, 0x9A, 0x83, 0xEA,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4,
+0x40, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x50, 0x9A, 0x51, 0xE4, 0x60, 0xAC,
+0xFF, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0x50, 0x9A,
+0x51, 0xE4, 0x60, 0xAC, 0xFF, 0xF7, 0x1F, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF1, 0x4D, 0xA2, 0x04, 0x22, 0x02, 0x72,
+0x00, 0x6A, 0x19, 0x61, 0x12, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x5C, 0x9A, 0x83, 0xEA,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4,
+0x40, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x50, 0x9A, 0x51, 0xE4, 0x40, 0x9C,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0x50, 0x9A, 0x51, 0xE4, 0x40, 0x9C, 0x20, 0xE8,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x4C, 0xED,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x83, 0xF3, 0x74, 0xA2, 0x10, 0xD6, 0x11, 0xD7,
+0x01, 0x73, 0x07, 0xD4, 0x08, 0xD5, 0x80, 0xF0,
+0x0F, 0x61, 0x83, 0xF3, 0x78, 0xA2, 0x01, 0x73,
+0x19, 0x61, 0x83, 0xF3, 0x77, 0xA2, 0x16, 0x2B,
+0x83, 0xF3, 0x16, 0xA2, 0x83, 0xF3, 0x78, 0xC2,
+0x83, 0xF3, 0x70, 0x9A, 0x01, 0x6A, 0x4C, 0xE8,
+0x01, 0x58, 0x18, 0x67, 0x00, 0x30, 0xFB, 0x4B,
+0x08, 0x30, 0x01, 0xE3, 0x90, 0x67, 0x00, 0x18,
+0x00, 0x2C, 0xFE, 0x6D, 0x90, 0x67, 0x4C, 0xED,
+0x00, 0x18, 0xCE, 0x2B, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0x83, 0xF3, 0x58, 0xA0,
+0x6B, 0x2A, 0x83, 0xF3, 0x4C, 0x98, 0x83, 0xF3,
+0x76, 0xA0, 0x06, 0xD2, 0x83, 0xF3, 0x50, 0x98,
+0x05, 0xD3, 0x06, 0x94, 0x60, 0x33, 0x68, 0x33,
+0x49, 0xE3, 0x85, 0xE2, 0x04, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x54, 0x9A, 0x91, 0x67,
+0xA0, 0x9A, 0x00, 0x18, 0xF0, 0x2B, 0x07, 0x95,
+0x84, 0x41, 0x00, 0x18, 0xDF, 0x2B, 0x08, 0x95,
+0x86, 0x41, 0x00, 0x18, 0xDF, 0x2B, 0x10, 0x95,
+0x87, 0x41, 0x01, 0x4C, 0x00, 0x18, 0xF0, 0x2B,
+0x11, 0x95, 0x87, 0x41, 0x05, 0x4C, 0x00, 0x18,
+0xF0, 0x2B, 0x06, 0x92, 0x20, 0x4A, 0xE0, 0xF3,
+0x01, 0x5A, 0x39, 0x61, 0x05, 0x93, 0x01, 0x69,
+0x51, 0x67, 0x44, 0xEB, 0x83, 0xF3, 0x77, 0xA0,
+0x04, 0x94, 0x6D, 0xEA, 0xFB, 0x4C, 0x83, 0xF3,
+0x57, 0xC0, 0x04, 0xD4, 0x00, 0x18, 0x00, 0x2C,
+0x80, 0x6D, 0xAB, 0xED, 0x04, 0x94, 0x4D, 0xED,
+0xFF, 0x6A, 0x4C, 0xED, 0x00, 0x18, 0xCE, 0x2B,
+0x05, 0x92, 0x01, 0x5A, 0x58, 0x67, 0x05, 0xD2,
+0x83, 0xF3, 0x57, 0xA0, 0x78, 0x67, 0x47, 0xEB,
+0x2C, 0xEA, 0x0B, 0x22, 0x04, 0x94, 0x83, 0xF3,
+0x38, 0xC0, 0x00, 0x18, 0x00, 0x2C, 0x04, 0x94,
+0x2D, 0xEA, 0xFF, 0x6D, 0x4C, 0xED, 0x00, 0x18,
+0xCE, 0x2B, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x00, 0x6B, 0x83, 0xF3, 0x6C, 0xDA,
+0x7D, 0x67, 0x87, 0x43, 0x0D, 0x4C, 0x60, 0xA4,
+0x83, 0xF3, 0x76, 0xC2, 0x05, 0x10, 0x83, 0xF3,
+0x4C, 0x98, 0x10, 0x4A, 0x83, 0xF3, 0x4C, 0xD8,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x4C, 0x9A, 0xFF, 0x6B, 0x80, 0xA2,
+0xA4, 0x67, 0x6C, 0xED, 0x04, 0xD5, 0x42, 0x2D,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0x83, 0xF3, 0x9A, 0xA0, 0x12, 0x2C, 0x02, 0x6C,
+0x8B, 0xEC, 0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x98, 0x9A, 0x80, 0x6D, 0xAB, 0xED,
+0x40, 0xA4, 0x6C, 0xEA, 0xAE, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x01, 0x6A, 0x83, 0xF3, 0x5A, 0xC0,
+0x29, 0x10, 0x83, 0xF3, 0x39, 0xA0, 0x83, 0xF3,
+0x90, 0x98, 0x20, 0x32, 0x48, 0x32, 0xFB, 0x4C,
+0x51, 0xE4, 0x00, 0x18, 0x00, 0x2C, 0x00, 0xF6,
+0x40, 0x32, 0x00, 0xF6, 0x43, 0x32, 0x00, 0x52,
+0x19, 0x61, 0x01, 0x6A, 0x04, 0x21, 0x5D, 0x67,
+0x67, 0x42, 0x09, 0x4B, 0x40, 0xA3, 0x83, 0xF3,
+0x59, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x00, 0x6B, 0x83, 0xF3, 0x97, 0xA2,
+0x83, 0xF3, 0x7A, 0xC2, 0x01, 0x6B, 0x64, 0xE9,
+0x6F, 0xEB, 0x8C, 0xEB, 0x83, 0xF3, 0x77, 0xC2,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0x83, 0xF3, 0x50, 0x98, 0x83, 0xF3, 0x39, 0xA0,
+0x04, 0xD2, 0x00, 0x18, 0x32, 0x20, 0x00, 0x6B,
+0x33, 0x22, 0x04, 0x93, 0x20, 0x32, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0x4B, 0xE1, 0xF2, 0x84, 0x9C,
+0x48, 0x32, 0x49, 0xE3, 0xFF, 0xF7, 0x1F, 0x6B,
+0x4C, 0xEB, 0x60, 0xCC, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF2, 0x88, 0x9B, 0xFF, 0x6D, 0x10, 0x6E,
+0x60, 0xA4, 0x42, 0x32, 0xCB, 0xEE, 0xAC, 0xEB,
+0xCC, 0xEB, 0x42, 0x32, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF6, 0x7C, 0x9B, 0xAC, 0xEA,
+0x40, 0xC4, 0x01, 0x6A, 0x40, 0xC3, 0x01, 0x21,
+0x00, 0x6A, 0x83, 0xF3, 0x59, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3,
+0x97, 0xA2, 0x01, 0x6B, 0x64, 0xE9, 0x6F, 0xEB,
+0x8C, 0xEB, 0x83, 0xF3, 0x77, 0xC2, 0x01, 0x6B,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x43, 0x67,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF1, 0x4D, 0xA2,
+0x03, 0x22, 0x02, 0x72, 0x04, 0x60, 0x05, 0x10,
+0x00, 0x18, 0xB8, 0x2C, 0x02, 0x10, 0x00, 0x18,
+0x8D, 0x2C, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0xE9, 0xF1, 0x8D, 0xA4,
+0xFF, 0xF7, 0x1F, 0x6B, 0xAC, 0xEB, 0x03, 0x24,
+0x02, 0x74, 0x21, 0x60, 0x26, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0xF6, 0x9C, 0x9C, 0xC3, 0xEC,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF4,
+0x84, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF4, 0x88, 0x9C, 0x99, 0xE6, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0xF6, 0x9C, 0x9C, 0xE3, 0xEC,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF4,
+0x84, 0x9C, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF4, 0x88, 0x9C, 0x05, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF4, 0x8C, 0x9C, 0x99, 0xE6,
+0x9D, 0xE7, 0xBD, 0x67, 0x52, 0xC5, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF1, 0x54, 0xAA, 0x04, 0x6C,
+0x8B, 0xEC, 0x90, 0xC5, 0x53, 0xC5, 0x0B, 0x6C,
+0x43, 0x32, 0x75, 0xC5, 0x63, 0x33, 0x54, 0xC5,
+0x76, 0xC5, 0x8F, 0xCD, 0x00, 0xF0, 0x17, 0x03,
+0x00, 0x6A, 0x86, 0x67, 0x86, 0xEA, 0x80, 0xC3,
+0x87, 0x67, 0x86, 0xEA, 0x08, 0x4A, 0x18, 0x72,
+0x83, 0xC3, 0x01, 0x4B, 0xF6, 0x61, 0x04, 0x04,
+0x00, 0x18, 0xF3, 0x1F, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x40, 0xA4, 0x01, 0x6D,
+0xAC, 0xEA, 0x80, 0xF0, 0x05, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3,
+0x74, 0xA2, 0x7B, 0x2B, 0x83, 0xF3, 0xB4, 0xC2,
+0x80, 0xA4, 0x92, 0x34, 0x83, 0xF3, 0x95, 0xC2,
+0x83, 0xF3, 0x95, 0xA2, 0x05, 0x24, 0x02, 0x74,
+0x10, 0x61, 0x07, 0xF0, 0x00, 0x68, 0x10, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x48, 0x9A,
+0x00, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x4C, 0x9A, 0x4C, 0xE8, 0x00, 0xF1, 0x01, 0x48,
+0x03, 0x10, 0x83, 0xF3, 0x74, 0xC2, 0x00, 0x68,
+0x03, 0x6A, 0x0C, 0xEA, 0x4D, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF1, 0x4C, 0xA2, 0x01, 0x72,
+0x45, 0x61, 0x01, 0xF0, 0x40, 0x40, 0x05, 0xD2,
+0x30, 0x67, 0x23, 0x10, 0x04, 0x92, 0x00, 0x6D,
+0x31, 0xE2, 0x00, 0x18, 0xF0, 0x2B, 0x04, 0x92,
+0x04, 0x4A, 0x18, 0x72, 0x04, 0xD2, 0xF6, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0xB0, 0x9A,
+0x91, 0x67, 0x00, 0x18, 0xF0, 0x2B, 0x87, 0x41,
+0x04, 0x4C, 0x10, 0x6D, 0x00, 0x18, 0xCE, 0x2B,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0xB4, 0x9A,
+0x87, 0x41, 0x11, 0x4C, 0x00, 0x18, 0xF0, 0x2B,
+0x05, 0x93, 0x00, 0xF4, 0x00, 0x49, 0x2E, 0xEB,
+0x03, 0x23, 0x00, 0x6A, 0x04, 0xD2, 0xDA, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x87, 0x40, 0x45, 0xF6,
+0x18, 0x4A, 0x19, 0x4C, 0x00, 0xF4, 0x00, 0x6D,
+0x83, 0xF3, 0x90, 0xDA, 0x83, 0xF3, 0x6C, 0xDA,
+0x83, 0xF3, 0x76, 0xC2, 0x83, 0xF3, 0x78, 0xC2,
+0x83, 0xF3, 0x77, 0xC2, 0x83, 0xF3, 0x79, 0xC2,
+0x83, 0xF3, 0x7A, 0xC2, 0x00, 0x6C, 0xD0, 0x67,
+0xBD, 0xE0, 0x1A, 0x10, 0x03, 0x6C, 0x0E, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x00, 0x6B, 0x83, 0xF3, 0x74, 0xC2, 0x05, 0x6C,
+0x00, 0x6D, 0xD0, 0x67, 0x00, 0xF4, 0xE0, 0x40,
+0x0B, 0x10, 0x09, 0x6C, 0x00, 0x6D, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0x6C, 0xE9, 0xF1,
+0x4C, 0xC3, 0xA4, 0x67, 0xC5, 0x67, 0xE5, 0x67,
+0x00, 0x18, 0xE6, 0x2C, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x0F, 0x6A, 0x8C, 0xEA,
+0x03, 0x2A, 0x92, 0x32, 0x6C, 0xEA, 0x20, 0xE8,
+0x07, 0x4A, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x08, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0x44, 0x32, 0xFF, 0x4A, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x1D, 0x08,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x04, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0xFF, 0x4A, 0x44, 0x32, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x1D, 0x08,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x08, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0x44, 0x32, 0xFF, 0x4A, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x3A, 0x08,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x04, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0xFF, 0x4A, 0x44, 0x32, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x3A, 0x08,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6D, 0x8C, 0xED,
+0x01, 0x6C, 0x44, 0x67, 0x15, 0x4D, 0x44, 0xED,
+0xA2, 0x67, 0x00, 0x18, 0xB9, 0x07, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6D, 0x8C, 0xED, 0x04, 0x2D, 0x03, 0x6C,
+0x10, 0xF0, 0x00, 0x6D, 0x05, 0x10, 0x1B, 0x4D,
+0x01, 0x6A, 0x44, 0xED, 0x03, 0x6C, 0xA2, 0x67,
+0x00, 0x18, 0xB9, 0x07, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x62, 0x2D,
+0x01, 0x6D, 0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18,
+0xB9, 0x07, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x62, 0x2D, 0x01, 0x6D, 0x03, 0x6C,
+0xA4, 0xEA, 0x00, 0x18, 0xB9, 0x07, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6D, 0x8C, 0xED, 0x01, 0x6C, 0x44, 0x67,
+0x15, 0x4D, 0x44, 0xED, 0xA2, 0x67, 0x00, 0x18,
+0xEA, 0x07, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6D, 0x8C, 0xED,
+0x04, 0x2D, 0x03, 0x6C, 0x10, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0x1B, 0x4D, 0x01, 0x6A, 0x44, 0xED,
+0x03, 0x6C, 0xA2, 0x67, 0x00, 0x18, 0xEA, 0x07,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x62, 0x2D, 0x01, 0x6D, 0x02, 0x6C,
+0xA4, 0xEA, 0x00, 0x18, 0xEA, 0x07, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x62, 0x2D,
+0x01, 0x6D, 0x03, 0x6C, 0xA4, 0xEA, 0x00, 0x18,
+0xEA, 0x07, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x21, 0xF2,
+0x78, 0x9B, 0x8C, 0xEA, 0x50, 0x32, 0x6D, 0xE2,
+0x80, 0xA3, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF2,
+0x94, 0x9C, 0x91, 0xE2, 0xA0, 0xA4, 0x80, 0xA4,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF2, 0x94, 0x9C,
+0x91, 0xE2, 0x80, 0x9C, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF2, 0x84, 0x9C, 0x89, 0xE2, 0x80, 0xA2,
+0x40, 0x9A, 0x40, 0xA3, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x21, 0xF2,
+0x78, 0x9B, 0x8C, 0xEA, 0x50, 0x32, 0x6D, 0xE2,
+0x80, 0xA3, 0x60, 0xA3, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF2, 0x74, 0x9B, 0x6D, 0xE2, 0x80, 0xA3,
+0x60, 0xA3, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF2,
+0x74, 0x9B, 0x6D, 0xE2, 0x60, 0x9B, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF2, 0x64, 0x9B, 0x6D, 0xE2,
+0x60, 0x9B, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF2,
+0x68, 0x9B, 0x6D, 0xE2, 0x80, 0xA3, 0x60, 0xA3,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF2, 0x7C, 0x9B,
+0x6D, 0xE2, 0x60, 0xA3, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF4, 0x64, 0x9B, 0x69, 0xE2, 0x40, 0xA2,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xDE, 0x63, 0x43, 0x62,
+0x42, 0xD1, 0x41, 0xD0, 0x01, 0x6A, 0x7D, 0x67,
+0x4B, 0xEA, 0x54, 0xC3, 0x0F, 0x6A, 0x56, 0xC3,
+0x10, 0x6A, 0x57, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x54, 0x9A, 0xFF, 0x68, 0x8C, 0xE8,
+0x10, 0x30, 0x49, 0xE0, 0x40, 0x9A, 0x04, 0x01,
+0x06, 0x04, 0xB1, 0x67, 0x04, 0x6E, 0x04, 0xD2,
+0x00, 0x18, 0xA1, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF2, 0x44, 0x9A, 0x07, 0x04, 0xB1, 0x67,
+0x49, 0xE0, 0x40, 0x9A, 0x04, 0x6E, 0x04, 0xD2,
+0x00, 0x18, 0xA1, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x58, 0x9A, 0x08, 0x04, 0xB1, 0x67,
+0x49, 0xE0, 0x40, 0x9A, 0x04, 0x6E, 0x04, 0xD2,
+0x00, 0x18, 0xA1, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF2, 0x4C, 0x9A, 0xB1, 0x67, 0x09, 0x04,
+0x41, 0xE0, 0x40, 0x98, 0x04, 0x6E, 0x04, 0xD2,
+0x00, 0x18, 0xA1, 0x1E, 0x05, 0x04, 0x00, 0x18,
+0x69, 0x1F, 0x43, 0x97, 0x42, 0x91, 0x41, 0x90,
+0x22, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF4, 0x48, 0x9A,
+0x81, 0xF4, 0x6C, 0x9B, 0x00, 0xA2, 0x20, 0xA3,
+0xFF, 0x6A, 0x4C, 0xE8, 0x4C, 0xE9, 0x2A, 0xE8,
+0x2F, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x54, 0x9A, 0x10, 0x33, 0x49, 0xE3, 0x40, 0xA2,
+0xFF, 0x6B, 0x6C, 0xEA, 0x56, 0x32, 0x6C, 0xEA,
+0x02, 0x72, 0x0D, 0x60, 0x03, 0x5A, 0x02, 0x60,
+0x06, 0x22, 0x14, 0x10, 0x04, 0x72, 0x0B, 0x60,
+0x06, 0x72, 0x0D, 0x60, 0x0F, 0x10, 0x90, 0x67,
+0x00, 0x18, 0xF7, 0x51, 0x0B, 0x10, 0x90, 0x67,
+0x00, 0x18, 0xF9, 0x2D, 0x07, 0x10, 0x90, 0x67,
+0x00, 0x18, 0xCE, 0x2D, 0x03, 0x10, 0x90, 0x67,
+0x00, 0x18, 0xDE, 0x2D, 0x01, 0x48, 0x7F, 0x6A,
+0x4C, 0xE8, 0x0A, 0xE9, 0xD6, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF4, 0x48, 0x9A, 0x20, 0xC2,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x68, 0xF4, 0x50, 0xA2, 0x01, 0x72, 0x03, 0x61,
+0xAC, 0xF4, 0x00, 0x6A, 0x04, 0x10, 0x03, 0x72,
+0x04, 0x61, 0xA4, 0xF1, 0x00, 0x6A, 0x4B, 0xEA,
+0x02, 0x10, 0x61, 0xF2, 0x00, 0x6A, 0x40, 0xCC,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x74, 0x9A,
+0xFF, 0x6C, 0x20, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x40, 0xA3,
+0x01, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0xB8, 0x9A,
+0xE0, 0xF3, 0x10, 0x6C, 0x0F, 0x6E, 0x00, 0x18,
+0xCB, 0x2F, 0xE0, 0xF3, 0x0C, 0x6C, 0x00, 0x18,
+0xA3, 0x2F, 0xFF, 0x6B, 0x4C, 0xEB, 0x0B, 0x73,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4,
+0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF4,
+0x80, 0x9C, 0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0xF7, 0x1F, 0x69, 0x2C, 0xED, 0x30, 0xF0,
+0x20, 0x6B, 0x04, 0xD5, 0xA1, 0xF4, 0xA4, 0x9B,
+0xFF, 0x6A, 0x40, 0x6E, 0x60, 0xA5, 0xCB, 0xEE,
+0x4C, 0xEC, 0x4C, 0xEB, 0xCC, 0xEB, 0x6D, 0xEC,
+0x4C, 0xEC, 0x80, 0xC5, 0x0A, 0x6C, 0x00, 0x18,
+0x7D, 0x1E, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4,
+0x48, 0x9A, 0x00, 0xAA, 0x04, 0x92, 0x2C, 0xE8,
+0x2A, 0xEA, 0x08, 0x60, 0x82, 0x67, 0x00, 0x18,
+0x88, 0x1D, 0x04, 0x93, 0x2C, 0xEA, 0x6C, 0xE8,
+0x07, 0xEA, 0x2C, 0xE8, 0x50, 0x67, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0xF7, 0x1F, 0x69, 0x2C, 0xED, 0xFF, 0x68,
+0x0C, 0xEC, 0x2C, 0xEE, 0x2A, 0xED, 0x05, 0xD4,
+0x04, 0xD5, 0x06, 0xD6, 0x1F, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x64, 0x9A, 0x40, 0x6C,
+0x8B, 0xEC, 0x40, 0xA3, 0x0C, 0xEA, 0x8C, 0xEA,
+0x05, 0x94, 0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF6, 0x80, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0xF6, 0x98, 0x9C, 0x8D, 0xEA, 0xCD, 0xEA,
+0x40, 0xDB, 0x31, 0x10, 0x05, 0x94, 0xB1, 0x67,
+0x00, 0x18, 0x66, 0x2E, 0x04, 0x94, 0x07, 0xD2,
+0x00, 0x18, 0x88, 0x1D, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF4, 0x84, 0x9B, 0x40, 0x6D, 0xAB, 0xED,
+0x60, 0xA4, 0x2C, 0xEA, 0x0C, 0xEB, 0xAC, 0xEB,
+0x05, 0x95, 0xAD, 0xEB, 0x0C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF4, 0x88, 0x9B,
+0x30, 0xF0, 0x20, 0x6D, 0x80, 0xF6, 0xA0, 0x9D,
+0x60, 0x9C, 0x06, 0x96, 0xAC, 0xEB, 0x30, 0xF0,
+0x20, 0x6D, 0x60, 0xF6, 0xB8, 0x9D, 0xC4, 0xEA,
+0x46, 0x67, 0xAD, 0xEB, 0x04, 0x95, 0x07, 0x96,
+0xAC, 0xEA, 0xAF, 0xED, 0xCC, 0xED, 0xAD, 0xEA,
+0x2C, 0xEA, 0x4D, 0xEB, 0x60, 0xDC, 0x0A, 0x6C,
+0x00, 0x18, 0x7D, 0x1E, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF4, 0xAC, 0x9B,
+0xFF, 0x6A, 0x08, 0x6E, 0x60, 0xA5, 0xCB, 0xEE,
+0x4C, 0xEC, 0x4C, 0xEB, 0xCC, 0xEB, 0x6D, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF4, 0x70, 0x9B,
+0x4C, 0xEC, 0x80, 0xC5, 0x60, 0xA3, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF4, 0xCC, 0x9B, 0xFF, 0x6A, 0x08, 0x6F,
+0x60, 0xA6, 0xEB, 0xEF, 0x4C, 0xEC, 0x4C, 0xEB,
+0xEC, 0xEB, 0x6D, 0xEC, 0x4C, 0xED, 0x4C, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4, 0x50, 0x9A,
+0x80, 0xC6, 0xA0, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0,
+0x21, 0x6A, 0x37, 0xF3, 0x01, 0x4A, 0x40, 0xDB,
+0x00, 0x68, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4,
+0x44, 0x9A, 0x40, 0x9A, 0x1E, 0x22, 0xE0, 0xF3,
+0x09, 0x70, 0x13, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0x20, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA, 0x00, 0x6A,
+0x09, 0x10, 0x32, 0x6C, 0x00, 0x18, 0x7D, 0x1E,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0xDC, 0x17, 0x01, 0x6A, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x01, 0x69, 0x2B, 0xE9,
+0x00, 0x6C, 0x01, 0xF4, 0x00, 0x68, 0x00, 0x18,
+0x08, 0x30, 0x00, 0x18, 0xC8, 0x2E, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0x00, 0x29, 0x04, 0x6E,
+0xCB, 0xEE, 0x90, 0x67, 0x4C, 0xEE, 0x00, 0xF2,
+0x00, 0x48, 0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x18, 0x00, 0x29,
+0x04, 0x6E, 0xCB, 0xEE, 0x90, 0x67, 0x4C, 0xEE,
+0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x00, 0x6C,
+0xA4, 0x67, 0xD1, 0x67, 0x30, 0xF0, 0x20, 0x68,
+0x00, 0x18, 0xD7, 0x28, 0x45, 0xF6, 0x18, 0x48,
+0xE3, 0xF3, 0x54, 0xC8, 0x01, 0x6C, 0x00, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xD7, 0x28, 0x00, 0x6C,
+0xE3, 0xF3, 0x56, 0xC8, 0xA4, 0x67, 0xE4, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x34, 0x29, 0x00, 0x6D,
+0x01, 0x6C, 0xD1, 0x67, 0xE5, 0x67, 0x00, 0x18,
+0x34, 0x29, 0x00, 0x68, 0x01, 0x69, 0x2B, 0xE9,
+0x01, 0xF1, 0x08, 0x6C, 0xB1, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0xE1, 0xF5, 0x14, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x00, 0x29, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF4, 0x74, 0x9B, 0x4C, 0xEB,
+0x20, 0x23, 0xE0, 0xF3, 0x09, 0x70, 0x15, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF2, 0x9C, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3,
+0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA,
+0x17, 0x10, 0x32, 0x6C, 0x00, 0x18, 0x7D, 0x1E,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0xCD, 0x17, 0xE0, 0xF3, 0x08, 0x58, 0x0C, 0x60,
+0xA1, 0xF0, 0x14, 0x68, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0x00, 0x29, 0x40, 0x6E, 0x90, 0x67,
+0xB1, 0x67, 0x4D, 0xEE, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x70, 0x9A,
+0xFE, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x00, 0x18, 0xD9, 0x12, 0x01, 0x72, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7, 0x48, 0x9A,
+0x3F, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x78, 0x9A, 0xFD, 0x6A, 0xFF, 0x6C,
+0xA0, 0xA3, 0xAC, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF3, 0x54, 0x9A, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF2, 0x70, 0x9B, 0x40, 0x9A,
+0x6C, 0xEA, 0x20, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6D,
+0xA0, 0xF6, 0xA0, 0x9D, 0x40, 0x9B, 0xAD, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF4,
+0x60, 0x9A, 0x06, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF4, 0x64, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF4, 0x98, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF3, 0x54, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF2, 0x70, 0x9B,
+0x40, 0x9A, 0x6C, 0xEA, 0x24, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF4, 0x60, 0x9A, 0xFF, 0x6C,
+0x07, 0x6D, 0x40, 0xA3, 0xAB, 0xED, 0x8C, 0xEA,
+0xAC, 0xEA, 0x04, 0x6D, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF4,
+0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF4,
+0x88, 0x9C, 0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4, 0x7C, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF4, 0x8C, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x98, 0x9A, 0xFF, 0x6B,
+0x02, 0x6D, 0x40, 0xA4, 0x01, 0x68, 0x0B, 0xE8,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7, 0x48, 0x9A,
+0x01, 0x6C, 0x8B, 0xEC, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF4, 0x50, 0x9A, 0x09, 0x6C,
+0x01, 0x6D, 0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x5C, 0x9A, 0x7A, 0x6C, 0x8B, 0xEC,
+0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x90, 0x9A, 0xA1, 0xF0, 0x14, 0x69, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x85, 0x67, 0x00, 0x18, 0x7D, 0x1E, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x00, 0x29, 0x41, 0x6E,
+0xCB, 0xEE, 0x91, 0x67, 0xB0, 0x67, 0x4C, 0xEE,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x69,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x49,
+0x41, 0xF0, 0x00, 0x4A, 0x40, 0x9A, 0xE3, 0xF3,
+0xF4, 0xA9, 0x00, 0x6C, 0xA4, 0x67, 0x4D, 0xEF,
+0xD0, 0x67, 0x00, 0x18, 0x34, 0x29, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x00, 0x4B, 0x60, 0x9B,
+0xE3, 0xF3, 0xF6, 0xA9, 0xD0, 0x67, 0x01, 0xF4,
+0x00, 0x69, 0x6D, 0xEF, 0x01, 0x6C, 0x00, 0x6D,
+0x00, 0x18, 0x34, 0x29, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x00, 0x29, 0x03, 0x6E, 0x91, 0x67,
+0xB0, 0x67, 0x4D, 0xEE, 0x00, 0xF2, 0x00, 0x49,
+0x00, 0x18, 0x0E, 0x29, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x00, 0x29, 0x03, 0x6E, 0xB0, 0x67,
+0x4D, 0xEE, 0x91, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x01, 0x6C, 0x00, 0x18, 0x08, 0x30, 0x00, 0x18,
+0xF6, 0x36, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x03, 0x6B, 0x4C, 0xEB, 0x2D, 0x2B, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF5, 0x74, 0x9B, 0x64, 0x68,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF5,
+0x58, 0x9A, 0x30, 0x6B, 0x60, 0xC2, 0x23, 0x10,
+0x0A, 0x6C, 0x00, 0x18, 0x7D, 0x1E, 0xFF, 0x48,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8, 0x1B, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF2, 0x90, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x83, 0xF3,
+0x64, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x64, 0xDA,
+0x60, 0xA1, 0xCF, 0x6A, 0x6C, 0xEA, 0x40, 0xC1,
+0x01, 0x6A, 0x4B, 0xEA, 0x11, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x38, 0x9A, 0x20, 0x6A,
+0x60, 0xA1, 0x6C, 0xEA, 0xD5, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x5C, 0x9A, 0xEF, 0x6B,
+0x40, 0x9A, 0x80, 0xA1, 0x8C, 0xEB, 0x60, 0xC1,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x03, 0x6B, 0x8C, 0xEB, 0x4C, 0xEE, 0x69, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF5, 0x74, 0x9B,
+0x80, 0xC3, 0x0F, 0x6B, 0xCC, 0xEB, 0x61, 0x23,
+0x01, 0x6C, 0x6C, 0xEC, 0x06, 0x24, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF5, 0x9C, 0x9C, 0xAC, 0xEA,
+0x40, 0xC4, 0x02, 0x6A, 0x6C, 0xEA, 0x08, 0x22,
+0xFF, 0x6C, 0xA2, 0x32, 0x8C, 0xEA, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF5, 0x80, 0x9C, 0x40, 0xC4,
+0x04, 0x6A, 0x6C, 0xEA, 0x09, 0x22, 0xA2, 0x32,
+0xFF, 0x6C, 0x42, 0x32, 0x8C, 0xEA, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF5, 0x84, 0x9C, 0x40, 0xC4,
+0x6E, 0x32, 0x07, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x48, 0x9A, 0x00, 0xF6, 0xA2, 0x35,
+0xA0, 0xC2, 0x20, 0x6A, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF5, 0x78, 0x9B, 0x64, 0x68,
+0x40, 0xC3, 0x21, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x7D, 0x1E, 0xFF, 0x48, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE8, 0x19, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x81, 0xF2, 0x90, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x64, 0xDA, 0x60, 0xA1, 0xD0, 0x6A,
+0x6C, 0xEA, 0x40, 0xC1, 0x0E, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x38, 0x9A, 0x20, 0x6A,
+0x60, 0xA1, 0x6C, 0xEA, 0xD7, 0x2A, 0x60, 0xA1,
+0xF0, 0x6A, 0x6C, 0xEA, 0x40, 0xC1, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x01, 0x74, 0x1C, 0x60, 0x05, 0x24, 0x02, 0x74,
+0x0E, 0x60, 0x03, 0x74, 0x27, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF4, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF5, 0x8C, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x60, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF0, 0x9C, 0x9C, 0x40, 0x9B,
+0x8C, 0xEA, 0x1A, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF4, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF5, 0x8C, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF0, 0x80, 0x9C,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF5, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF0, 0x98, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x20, 0xE8, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF5,
+0x90, 0x9C, 0xFF, 0x6B, 0xC2, 0x67, 0x6C, 0xEE,
+0xC0, 0xC4, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF5,
+0xD4, 0x9C, 0x03, 0x6F, 0x42, 0x32, 0x80, 0xA6,
+0xEC, 0xEA, 0xF9, 0x4F, 0x6C, 0xEC, 0xEC, 0xEC,
+0x8D, 0xEA, 0x6C, 0xEA, 0x40, 0xC6, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0x78, 0x9A, 0x7F, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x00, 0x6A,
+0x03, 0x10, 0x01, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF5, 0x78, 0x9B,
+0x60, 0xA3, 0x00, 0xF6, 0x60, 0x33, 0x00, 0xF6,
+0x63, 0x33, 0x00, 0x53, 0x03, 0x61, 0x64, 0x72,
+0xF0, 0x61, 0x0A, 0x10, 0x64, 0x5A, 0x08, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x5C, 0x9A,
+0x40, 0xA2, 0x40, 0xC5, 0x01, 0x6A, 0x20, 0xE8,
+0x01, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF0,
+0x78, 0xC2, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5, 0x64, 0x9B,
+0xFF, 0x6A, 0x8C, 0xEA, 0x60, 0x9B, 0x80, 0xF1,
+0x01, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF0, 0x98, 0x9C, 0x01, 0x72,
+0x80, 0x9C, 0x05, 0x60, 0x02, 0x72, 0x05, 0x61,
+0xFF, 0x6A, 0x01, 0x4A, 0x01, 0x10, 0x80, 0x6A,
+0x4D, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5,
+0x44, 0x9A, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF5, 0x48, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x78, 0x9B, 0x8C, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5, 0x6C, 0x9B,
+0x50, 0x6A, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF5, 0x70, 0x9B, 0x40, 0xC3, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x4C, 0xED, 0x04, 0x67, 0x01, 0x75, 0x86, 0x67,
+0x4C, 0xE8, 0x4C, 0xEC, 0x03, 0x60, 0x03, 0x75,
+0x0A, 0x6B, 0x01, 0x61, 0x09, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF5, 0x54, 0x9A, 0x0F, 0x6F,
+0xAC, 0xEF, 0x70, 0x33, 0xED, 0xEB, 0x60, 0xC2,
+0x00, 0x18, 0x48, 0x30, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF5, 0x58, 0x9A, 0x24, 0x58, 0x60, 0xA2,
+0x7F, 0x6A, 0x6C, 0xEA, 0x05, 0x61, 0x80, 0x6B,
+0x6B, 0xEB, 0x6D, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5, 0x78, 0x9B,
+0x40, 0xC3, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x80, 0x9A, 0x04, 0x6B, 0x40, 0xA4,
+0x4C, 0xEB, 0x04, 0x6A, 0x06, 0x23, 0x60, 0xA4,
+0x02, 0x6A, 0x6C, 0xEA, 0x01, 0x5A, 0x58, 0x67,
+0x01, 0x4A, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF5, 0x7C, 0x9B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x60, 0x9A, 0x82, 0x34, 0x10, 0x6A,
+0xC0, 0xA3, 0x4B, 0xEA, 0x92, 0x34, 0x4C, 0xEC,
+0x0F, 0x6A, 0xCC, 0xEA, 0xFF, 0x6D, 0x4D, 0xEC,
+0xAC, 0xEC, 0x80, 0xC3, 0x40, 0xA3, 0x01, 0x6C,
+0xAC, 0xEA, 0x8D, 0xEA, 0xAC, 0xEA, 0x40, 0xC3,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0xA8, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF7, 0x8C, 0x9C, 0x60, 0x9D, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x8C, 0xEB,
+0x02, 0xF6, 0x70, 0xDA, 0x60, 0x9D, 0x8C, 0xEB,
+0x02, 0xF6, 0x7C, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0x44, 0x9A,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x4C, 0x9A, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x85, 0x67, 0x00, 0x18,
+0x83, 0x30, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0x07, 0x6A, 0x8C, 0xEA, 0x05, 0x22, 0xFF, 0xF7,
+0x18, 0x6A, 0x8C, 0xEA, 0x08, 0x4A, 0x20, 0xE8,
+0xFF, 0xF7, 0x18, 0x6A, 0x8C, 0xEA, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x05, 0x67, 0x82, 0x45, 0x00, 0x18, 0xC8, 0x1D,
+0x83, 0x40, 0x22, 0x67, 0x00, 0x18, 0xC8, 0x1D,
+0x03, 0x6B, 0x0F, 0x6C, 0x4C, 0xEB, 0x2C, 0xEC,
+0x18, 0x48, 0x61, 0xE0, 0x8C, 0x34, 0x89, 0xE0,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x06, 0x67, 0x81, 0x46,
+0x00, 0x18, 0xC8, 0x1D, 0x90, 0x67, 0x04, 0xD2,
+0x00, 0x18, 0xC8, 0x1D, 0x82, 0x40, 0x05, 0xD2,
+0x00, 0x18, 0xC8, 0x1D, 0x83, 0x40, 0x22, 0x67,
+0x00, 0x18, 0xC8, 0x1D, 0x03, 0x6B, 0x4C, 0xEB,
+0x0F, 0x6A, 0x2C, 0xEA, 0x18, 0x4B, 0x4C, 0x32,
+0x51, 0xE3, 0x04, 0x93, 0x60, 0x32, 0x05, 0x93,
+0x6D, 0xEA, 0xE7, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x51, 0xE4, 0x00, 0x18, 0xA8, 0x30, 0x30, 0xF0,
+0x20, 0x6B, 0x68, 0xF4, 0x68, 0x9B, 0x09, 0xE2,
+0x43, 0xEB, 0x02, 0x60, 0x6F, 0xEB, 0x69, 0xE2,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x44, 0x9A, 0xFF, 0x6B, 0x20, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x54, 0x9A,
+0x40, 0xA2, 0x82, 0x67, 0x6C, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0x05, 0xD4, 0x45, 0xF7, 0x97, 0xA2,
+0x01, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA, 0x00, 0x6B,
+0x04, 0xD3, 0x3F, 0x2A, 0x42, 0x10, 0x81, 0x41,
+0x00, 0x18, 0xC8, 0x1D, 0x02, 0x67, 0x91, 0x67,
+0x00, 0x18, 0xC8, 0x1D, 0x00, 0x30, 0x82, 0x41,
+0x4D, 0xE8, 0xE7, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0x00, 0x18, 0xC8, 0x1D, 0x83, 0x41, 0x06, 0xD2,
+0x00, 0x18, 0xC8, 0x1D, 0x03, 0x6B, 0x4C, 0xEB,
+0x87, 0x43, 0x06, 0x93, 0x0F, 0x6A, 0x11, 0x4C,
+0x6C, 0xEA, 0x4C, 0x32, 0x51, 0xE4, 0x91, 0xE0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x00, 0x18,
+0xA8, 0x30, 0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x45, 0xE1, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x4C, 0x9A, 0x80, 0x9B, 0x4C, 0xEC, 0x23, 0xEC,
+0x04, 0x60, 0x60, 0x9B, 0x4C, 0xEB, 0x6F, 0xEB,
+0x65, 0xE1, 0x91, 0x67, 0x00, 0x18, 0x83, 0x30,
+0x04, 0x94, 0xFF, 0x6A, 0x01, 0x4C, 0x4C, 0xEC,
+0x04, 0xD4, 0x04, 0x92, 0x05, 0x93, 0x63, 0xEA,
+0xBE, 0x61, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFF, 0x6A, 0x8C, 0xEA,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5,
+0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xE0, 0xF6,
+0x94, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5, 0x7C, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF5, 0x80, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x07, 0x6B, 0x8C, 0xEB,
+0x4C, 0xED, 0x8E, 0x34, 0x42, 0xF4, 0x10, 0x4C,
+0x36, 0x25, 0x1F, 0xF7, 0x00, 0x6D, 0x8C, 0xED,
+0x02, 0xF0, 0x00, 0x75, 0x01, 0x60, 0x21, 0x2D,
+0x1F, 0xF7, 0x00, 0x6A, 0x8C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x07, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0xBC, 0x9A, 0xB5, 0xE4,
+0x80, 0xA5, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0xBC, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x40, 0x9A, 0xB5, 0xE4, 0x51, 0xE4,
+0x80, 0xA4, 0x00, 0xF6, 0x80, 0x34, 0x01, 0x6A,
+0x00, 0xF6, 0x83, 0x34, 0x44, 0xEB, 0x8D, 0xEA,
+0x36, 0x10, 0x30, 0xF0, 0x20, 0x6D, 0x20, 0xF7,
+0xA0, 0x9D, 0x01, 0x6E, 0xC4, 0xEB, 0xB1, 0xE4,
+0xA0, 0xA4, 0x00, 0xF6, 0xA0, 0x35, 0x00, 0xF6,
+0xA3, 0x35, 0xCD, 0xED, 0x3A, 0x10, 0x1F, 0xF7,
+0x00, 0x6D, 0x8C, 0xED, 0x02, 0xF0, 0x00, 0x75,
+0x01, 0x60, 0x25, 0x2D, 0x1F, 0xF7, 0x00, 0x6A,
+0x8C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0xBC, 0x9A, 0xB5, 0xE4, 0x80, 0xA5, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0xBC, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0xB5, 0xE4, 0x51, 0xE4, 0x80, 0xA4, 0x01, 0x6A,
+0x00, 0xF6, 0x80, 0x34, 0x44, 0xEB, 0x00, 0xF6,
+0x83, 0x34, 0x4F, 0xEA, 0x8C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x40, 0xC5, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6D, 0x20, 0xF7, 0xA0, 0x9D, 0x01, 0x6E,
+0xC4, 0xEB, 0xB1, 0xE4, 0xA0, 0xA4, 0xCF, 0xEE,
+0x00, 0xF6, 0xA0, 0x35, 0x00, 0xF6, 0xA3, 0x35,
+0xCC, 0xED, 0x4C, 0xED, 0xA0, 0xC4, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x58, 0xF5, 0x09, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x78, 0xF5, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x9F, 0x9A, 0x07, 0x24, 0x01, 0x6B,
+0x8C, 0xEB, 0x04, 0x23, 0x02, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x7F, 0xDA, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x78, 0xF5, 0x02, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xB8, 0xF5, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6C, 0xE5, 0xF6,
+0x84, 0x9C, 0x02, 0x24, 0x01, 0x4A, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x60, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0xD8, 0xF5, 0x05, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x80, 0xF0,
+0x90, 0x9A, 0x0A, 0x24, 0xFF, 0x6B, 0x01, 0x4B,
+0x8C, 0xEB, 0x06, 0x23, 0xFF, 0x6B, 0x02, 0x4B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x80, 0xF0, 0x70, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xE5, 0xF6, 0x50, 0x9A,
+0x09, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0xD8, 0xF5,
+0x06, 0x4A, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x18, 0xF6, 0x19, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x60, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x38, 0xF6, 0x11, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0xAC, 0xEA, 0x0B, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0xA4, 0x9B,
+0x30, 0xF0, 0x20, 0x6E, 0xC1, 0xF4, 0xD8, 0x9E,
+0x60, 0x9D, 0xCC, 0xEB, 0x0C, 0x10, 0x01, 0x72,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5,
+0xA4, 0x9B, 0x30, 0xF0, 0x20, 0x6E, 0x01, 0xF0,
+0xC0, 0x9E, 0x60, 0x9D, 0xCD, 0xEB, 0x60, 0xDD,
+0x05, 0x5C, 0x60, 0xF1, 0x06, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x88, 0x34, 0x20, 0xF6, 0x0C, 0x4B,
+0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x64, 0x9A,
+0x0D, 0x11, 0x01, 0x72, 0x10, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x64, 0x9A, 0xFF, 0x6C,
+0x40, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0x40, 0xA3, 0x80, 0x4D,
+0xC0, 0x4D, 0x8C, 0xEA, 0x14, 0x10, 0x02, 0x72,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x64, 0x9A, 0xBF, 0x6A, 0x80, 0xA3, 0xF4, 0x10,
+0x03, 0x72, 0x20, 0xF1, 0x1A, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x64, 0x9A, 0xFF, 0x6C,
+0x40, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0xE7, 0x10, 0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x68, 0x9A, 0xFD, 0x6A, 0x80, 0xA3,
+0xDF, 0x10, 0x01, 0x72, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x84, 0x9A, 0xFF, 0x6A,
+0x40, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x88, 0x9B, 0x01, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x60, 0xA4, 0x02, 0x6D, 0x4C, 0xEB, 0xE1, 0x10,
+0x02, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x64, 0x9A, 0xBF, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x68, 0x9A, 0xFE, 0x6A, 0x80, 0xA3,
+0xB3, 0x10, 0x03, 0x72, 0xE0, 0xF0, 0x19, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x84, 0x9A,
+0xFF, 0x6B, 0x40, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x88, 0x9A, 0x01, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0x92, 0x10, 0x07, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x68, 0x9A,
+0xF7, 0x6A, 0x80, 0xA3, 0x95, 0x10, 0x01, 0x72,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x84, 0x9A, 0xFF, 0x6A, 0x40, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x88, 0x9B,
+0x04, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x60, 0xA4, 0x08, 0x6D,
+0x4C, 0xEB, 0x97, 0x10, 0x02, 0x72, 0x0F, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x64, 0x9A,
+0xBF, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x68, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x69, 0x10, 0x03, 0x72,
+0xA0, 0xF0, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x84, 0x9A, 0xFF, 0x6B, 0x40, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x88, 0x9A, 0x04, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0x48, 0x10, 0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x68, 0x9A, 0xDF, 0x6A, 0x80, 0xA3,
+0x4B, 0x10, 0x01, 0x72, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x84, 0x9A, 0xFF, 0x6A,
+0x40, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x88, 0x9B, 0x10, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x60, 0xA4, 0x20, 0x6D, 0x4C, 0xEB, 0x4D, 0x10,
+0x02, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x64, 0x9A, 0xBF, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x68, 0x9A, 0xEF, 0x6A, 0x80, 0xA3,
+0x1F, 0x10, 0x03, 0x72, 0x66, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x84, 0x9A, 0xFF, 0x6B,
+0x40, 0x6D, 0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA,
+0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x88, 0x9A, 0x10, 0x6D, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x20, 0xE8, 0x09, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x68, 0x9A, 0x80, 0xA3, 0x7F, 0x6A,
+0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8, 0x01, 0x72,
+0x1C, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x84, 0x9A, 0xFF, 0x6A, 0x40, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x88, 0x9B,
+0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB,
+0x60, 0xC4, 0x60, 0xA4, 0x80, 0x4D, 0xC0, 0x4D,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x20, 0xE8, 0x02, 0x72, 0x10, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x44, 0x9A, 0xBF, 0x6B,
+0x80, 0xA2, 0x6C, 0xEC, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x48, 0x9A, 0x80, 0xA2,
+0x8C, 0xEB, 0x60, 0xC2, 0x20, 0xE8, 0x03, 0x72,
+0x14, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x84, 0x9A, 0xFF, 0x6B, 0x40, 0x6D, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x88, 0x9A,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD0,
+0xFF, 0x6A, 0x4C, 0xED, 0x4C, 0xEE, 0x4C, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF7, 0x50, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEC, 0x00, 0xAA,
+0xE1, 0xF7, 0x1F, 0x6A, 0x0C, 0xEA, 0x30, 0xF0,
+0x20, 0x68, 0x40, 0xF7, 0x00, 0x98, 0x51, 0xE4,
+0x6C, 0xEC, 0x80, 0xC8, 0x9C, 0x32, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF5, 0x8C, 0x9C, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF5, 0x10, 0x98, 0x91, 0xE2,
+0x80, 0xAC, 0x01, 0xE2, 0x00, 0x98, 0x6C, 0xEC,
+0x05, 0x25, 0x10, 0xF0, 0x00, 0x6D, 0xAB, 0xED,
+0xAD, 0xEC, 0x6C, 0xEC, 0xD8, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF5,
+0x8C, 0x9C, 0x91, 0xE2, 0x60, 0xCC, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF5, 0x74, 0x9B, 0x6D, 0xE2,
+0x80, 0xA3, 0x01, 0x6B, 0x8C, 0xEB, 0x05, 0x23,
+0x03, 0xF7, 0x01, 0x6B, 0x6B, 0xEB, 0x0C, 0xEB,
+0x06, 0x10, 0x1F, 0xF7, 0x01, 0x6B, 0x6B, 0xEB,
+0x0C, 0xEB, 0xE0, 0x37, 0xED, 0xEB, 0xFF, 0x76,
+0x13, 0x60, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF5,
+0x98, 0x9C, 0x80, 0xF4, 0xC0, 0x36, 0x6C, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6, 0x70, 0x9B,
+0x6D, 0xEE, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5,
+0x70, 0x9B, 0x8D, 0xEE, 0x6D, 0xE2, 0xC0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x9C, 0x9B,
+0x7F, 0x6B, 0x91, 0xE2, 0xA0, 0xA4, 0xAC, 0xEB,
+0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF5,
+0x60, 0x9B, 0x1C, 0x6C, 0x80, 0xC3, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF5, 0x64, 0x9B, 0x08, 0xF4,
+0x13, 0x6C, 0x80, 0xCB, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF7, 0x94, 0x9B, 0xF7, 0x6B, 0x91, 0xE2,
+0xA0, 0xA4, 0xAC, 0xEB, 0x60, 0xC4, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFB, 0x63, 0x09, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0x74, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF6, 0x98, 0x9C,
+0x40, 0x9B, 0x20, 0x6D, 0x00, 0x6E, 0x8D, 0xEA,
+0x40, 0xDB, 0x00, 0xF4, 0x1F, 0x6C, 0x06, 0x02,
+0xE0, 0xF3, 0x08, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0xF3, 0x1D, 0x09, 0x97, 0x05, 0x63, 0x00, 0xEF,
+0xDF, 0x63, 0x41, 0x62, 0x40, 0xD0, 0x01, 0x68,
+0x00, 0x6A, 0x0B, 0xE8, 0x82, 0x67, 0x42, 0x6D,
+0xD0, 0x67, 0x04, 0xD2, 0x00, 0x18, 0xD7, 0x28,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x60, 0x9B,
+0x4C, 0xEB, 0x30, 0x2B, 0x00, 0x6C, 0x42, 0x6D,
+0xD0, 0x67, 0x00, 0x18, 0xD7, 0x28, 0x1F, 0xF4,
+0x00, 0x6B, 0x4C, 0xEB, 0x62, 0x32, 0x4A, 0x32,
+0x2E, 0x5A, 0x04, 0xD2, 0x02, 0x60, 0x2D, 0x72,
+0x10, 0x61, 0x01, 0x6A, 0x7D, 0x67, 0x4B, 0xEA,
+0x54, 0xC3, 0x1D, 0x6A, 0x56, 0xC3, 0x04, 0x6A,
+0x06, 0x04, 0x57, 0xC3, 0x04, 0x05, 0x04, 0x6E,
+0x00, 0x18, 0xA1, 0x1E, 0x05, 0x04, 0x00, 0x18,
+0x69, 0x1F, 0x01, 0x68, 0x0B, 0xE8, 0x00, 0x6C,
+0x42, 0x6D, 0xD0, 0x67, 0x00, 0x18, 0xD7, 0x28,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0xE0, 0x9B,
+0x00, 0x6C, 0x42, 0x6D, 0xD0, 0x67, 0x4D, 0xEF,
+0x00, 0x18, 0x34, 0x29, 0x41, 0x97, 0x40, 0x90,
+0x21, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x6B,
+0xAC, 0xEB, 0x05, 0xD3, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF7, 0x70, 0x9B, 0xFF, 0x6A, 0x8C, 0xEA,
+0x80, 0xAB, 0xE1, 0xF7, 0x1F, 0x6B, 0x00, 0x68,
+0x8C, 0xEB, 0x69, 0xE2, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF5, 0x88, 0x9B, 0x5C, 0x32, 0x91, 0xE2,
+0x04, 0xD4, 0x18, 0x10, 0x04, 0x92, 0x20, 0x9A,
+0x07, 0x28, 0x01, 0x6D, 0x83, 0xF1, 0x18, 0x6C,
+0xAB, 0xED, 0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x01, 0x6D, 0x83, 0xF1, 0x18, 0x6C, 0xAB, 0xED,
+0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x04, 0x93,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x4B,
+0x4C, 0xE8, 0x04, 0xD3, 0x05, 0x92, 0x43, 0xE8,
+0xE5, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x05, 0x6B, 0x63, 0xF5,
+0x7C, 0xDA, 0x09, 0x6B, 0x63, 0xF5, 0x78, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF1, 0xB0, 0x9A, 0x03, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xC5, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF1, 0x94, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0xC0, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF1, 0x58, 0x9A, 0xA1, 0xF1, 0x7C, 0x9B,
+0x02, 0x6F, 0xC0, 0xDC, 0x60, 0xDA, 0xE0, 0xC5,
+0x01, 0x6F, 0xC0, 0xDC, 0x60, 0xDA, 0xE0, 0xC5,
+0x30, 0xF0, 0x20, 0x6F, 0xC1, 0xF1, 0xE0, 0x9F,
+0xE0, 0xDC, 0x00, 0x6F, 0x60, 0xDA, 0xE0, 0xC5,
+0xC0, 0xDC, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x9E, 0x32, 0x06, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x94, 0x34, 0x21, 0xF1,
+0x50, 0x9A, 0x06, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x44, 0x9A, 0x81, 0x4C, 0x84, 0x34,
+0x51, 0xE4, 0x40, 0xA4, 0x4C, 0xEB, 0x43, 0x67,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF1, 0x64, 0xA2, 0x80, 0xF1, 0x04, 0x4A,
+0x60, 0xC4, 0x41, 0xA2, 0x40, 0xC5, 0x20, 0xE8,
+0xE5, 0x63, 0x35, 0x62, 0x34, 0xD1, 0x33, 0xD0,
+0x30, 0xF0, 0x20, 0x6D, 0x08, 0x04, 0x60, 0xF4,
+0x18, 0x4D, 0x54, 0x6E, 0x00, 0x18, 0x21, 0x1E,
+0x30, 0xF0, 0x20, 0x6D, 0x1D, 0x04, 0x20, 0xF4,
+0x04, 0x4D, 0x54, 0x6E, 0x00, 0x18, 0x21, 0x1E,
+0x30, 0xF0, 0x20, 0x6D, 0x00, 0xF4, 0x14, 0x4D,
+0x04, 0x04, 0x0F, 0x6E, 0x00, 0x18, 0x21, 0x1E,
+0x30, 0xF0, 0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A,
+0x00, 0x6D, 0x49, 0x6B, 0x1B, 0x65, 0x60, 0xC2,
+0x2C, 0x6B, 0x91, 0xA2, 0x63, 0xC2, 0x09, 0x6B,
+0x64, 0xC2, 0x0D, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x04, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB, 0x92, 0xA2,
+0x16, 0xA2, 0x04, 0x6F, 0x8D, 0xEF, 0x02, 0x6C,
+0x8B, 0xEC, 0x0C, 0xEC, 0x1E, 0xA2, 0x96, 0xC2,
+0x03, 0x6C, 0x8B, 0xEC, 0x0C, 0xEC, 0x34, 0xA2,
+0x41, 0x68, 0x0B, 0xE8, 0xF8, 0x65, 0x0C, 0xEC,
+0x10, 0x48, 0x0C, 0xE9, 0x1F, 0x67, 0x0C, 0xEF,
+0xF2, 0xC2, 0xEE, 0xA2, 0x00, 0x6E, 0xC1, 0xC2,
+0xFF, 0x65, 0x08, 0x6F, 0xEB, 0xEF, 0x1F, 0x67,
+0xEC, 0xE8, 0x0E, 0xC2, 0x13, 0xA2, 0xDD, 0xC2,
+0xD5, 0xC2, 0xF8, 0x65, 0x1F, 0x67, 0x0C, 0xEF,
+0xF3, 0xC2, 0xC9, 0xC2, 0x10, 0x6F, 0xD9, 0xC2,
+0x21, 0x6E, 0xEB, 0xEF, 0xCB, 0xEE, 0xEC, 0xE9,
+0xCC, 0xEC, 0xF0, 0xA2, 0xD8, 0x67, 0xC7, 0xC2,
+0x80, 0x6E, 0xCB, 0xEE, 0xCD, 0xEF, 0xF0, 0xC2,
+0x7F, 0x6F, 0xEC, 0xEC, 0x9E, 0xC2, 0x00, 0x6C,
+0x94, 0xCA, 0xBE, 0x34, 0x71, 0xC2, 0x34, 0xC2,
+0x04, 0x2C, 0x80, 0x4F, 0xD0, 0x4F, 0xEC, 0xEB,
+0x05, 0x10, 0x31, 0x68, 0x0B, 0xE8, 0x0C, 0xEB,
+0x10, 0x6C, 0x8D, 0xEB, 0x40, 0x6C, 0x8D, 0xEB,
+0xCD, 0xEB, 0x71, 0xC2, 0x01, 0x4D, 0xFF, 0x6B,
+0x6C, 0xED, 0x9F, 0x69, 0xAE, 0xE9, 0x2E, 0x4A,
+0xA0, 0x29, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0xC4, 0xF0, 0x39, 0xC0, 0x00, 0x18,
+0xC9, 0x44, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0x44, 0x9A, 0x06, 0x6B, 0x60, 0xC2, 0xEB, 0xF4,
+0x3E, 0xC0, 0x00, 0x18, 0xD2, 0x41, 0x00, 0x18,
+0xE9, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0x48, 0x9A, 0x40, 0x6B, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0xC2, 0x1D, 0x05, 0x8E, 0xF1, 0x0E, 0x4C,
+0x54, 0x6E, 0x00, 0x18, 0xA1, 0x1E, 0x30, 0xF0,
+0x20, 0x6C, 0x08, 0x05, 0xEE, 0xF1, 0x02, 0x4C,
+0x54, 0x6E, 0x00, 0x18, 0xA1, 0x1E, 0x30, 0xF0,
+0x20, 0x6C, 0x8E, 0xF3, 0x0A, 0x4C, 0x04, 0x05,
+0x0F, 0x6E, 0x00, 0x18, 0xA1, 0x1E, 0x35, 0x97,
+0x34, 0x91, 0x33, 0x90, 0x1B, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0xAC, 0xE8, 0xD0, 0x67, 0x41, 0xF4, 0x10, 0x6C,
+0x7F, 0x6D, 0x00, 0x18, 0x0E, 0x29, 0xD0, 0x67,
+0x41, 0xF6, 0x10, 0x6C, 0x7F, 0x6D, 0x00, 0x18,
+0x0E, 0x29, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x85, 0x67, 0xA6, 0x67, 0xC7, 0x67, 0x00, 0x18,
+0x21, 0x1E, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x26, 0x67, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7,
+0x40, 0x9A, 0x55, 0xE5, 0x00, 0x9D, 0x91, 0x67,
+0x00, 0x18, 0x88, 0x1D, 0x2C, 0xE8, 0x06, 0xEA,
+0x50, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x46, 0x67, 0x01, 0x4A,
+0x05, 0x67, 0x0C, 0xD6, 0x27, 0x67, 0x1C, 0x22,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x49, 0xE0, 0x40, 0x9A, 0x0C, 0x94, 0x04, 0xD2,
+0x00, 0x18, 0x88, 0x1D, 0x0C, 0x93, 0x24, 0xEA,
+0x6F, 0xEA, 0x04, 0x93, 0x6C, 0xEA, 0x4D, 0xE9,
+0x1F, 0xF7, 0x00, 0x6A, 0x0C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x41, 0xE0, 0x20, 0xD8, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x06, 0xD4, 0x06, 0x04,
+0x09, 0xD7, 0x07, 0xD5, 0x08, 0xD6, 0x00, 0x18,
+0xF3, 0x1F, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x63, 0x01, 0xD0, 0xFF, 0x6B, 0x3F, 0x68,
+0x6C, 0xED, 0xB7, 0xE0, 0x6C, 0xED, 0x00, 0x68,
+0x06, 0x92, 0x00, 0xC7, 0x05, 0x67, 0x6C, 0xED,
+0x6C, 0xEC, 0x00, 0xF6, 0xC0, 0x36, 0x10, 0x5D,
+0x00, 0xF6, 0xC3, 0x36, 0x80, 0xC2, 0x01, 0x61,
+0x0F, 0x68, 0xFF, 0x6B, 0x00, 0x56, 0x0C, 0xEB,
+0x04, 0x61, 0xC2, 0xEB, 0x02, 0x61, 0xC0, 0xC7,
+0x15, 0x10, 0xC2, 0xEB, 0x0D, 0x60, 0xA7, 0x44,
+0xD1, 0xE4, 0x60, 0xC7, 0x6F, 0xE4, 0x60, 0xC2,
+0x60, 0xA2, 0x03, 0x4D, 0xFF, 0x68, 0x0C, 0xED,
+0x63, 0xED, 0x0B, 0x60, 0xA0, 0xC2, 0x09, 0x10,
+0xCB, 0xED, 0x00, 0x6B, 0x82, 0xED, 0x60, 0xC7,
+0x03, 0x60, 0xD1, 0xE4, 0x80, 0xC2, 0x01, 0x10,
+0x60, 0xC2, 0x01, 0x90, 0x01, 0x6A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x2D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x24, 0x9A, 0x01, 0x68, 0x0B, 0xE8, 0xA1, 0xF4,
+0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0xA1, 0xF4, 0x14, 0x6C, 0xB0, 0x67,
+0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF4, 0x1C, 0x6C, 0xB0, 0x67, 0x21, 0xF0,
+0x1B, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF6,
+0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0xA1, 0xF6, 0x14, 0x6C, 0xB0, 0x67,
+0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x1C, 0x6C, 0xB0, 0x67, 0x21, 0xF0,
+0x1B, 0x6E, 0x2C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x24, 0x9A, 0x01, 0x68, 0x0B, 0xE8,
+0xA1, 0xF4, 0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF4, 0x14, 0x6C,
+0xB0, 0x67, 0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0xFF, 0x6E, 0xA1, 0xF4, 0x1C, 0x6C,
+0xB0, 0x67, 0x01, 0x4E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF6, 0x14, 0x6C,
+0xB0, 0x67, 0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0xFF, 0x6E, 0xA1, 0xF6, 0x1C, 0x6C,
+0xB0, 0x67, 0x01, 0x4E, 0x00, 0x18, 0x0E, 0x29,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x4C, 0x9A, 0x7F, 0x6B, 0x01, 0xF1,
+0x0C, 0x6C, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x44, 0x9A, 0x14, 0x6B, 0x10, 0xF0,
+0x00, 0x6D, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x48, 0x9A, 0x10, 0x6B, 0x01, 0x6E,
+0x60, 0xC2, 0x00, 0x18, 0x0E, 0x29, 0x81, 0xF4,
+0x14, 0x69, 0x01, 0x6D, 0x91, 0x67, 0xC5, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0x6D, 0x01, 0xF4,
+0x00, 0x68, 0xC5, 0x67, 0x81, 0xF6, 0x14, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x91, 0x67, 0xB0, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x7E, 0xF3,
+0x0B, 0x49, 0xB0, 0x67, 0x81, 0xF6, 0x14, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x90, 0x67,
+0xB1, 0x67, 0x04, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xB1, 0x67, 0x01, 0xF6, 0x00, 0x6C, 0x04, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0xFF, 0x6D, 0x01, 0xF3,
+0x00, 0x6C, 0x01, 0x4D, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xB4, 0x9A, 0x01, 0xF0, 0x08, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x21, 0xF0, 0x18, 0x6C,
+0x0E, 0x6D, 0x07, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x00, 0x6A, 0x0B, 0xD7,
+0xE0, 0xAE, 0x1F, 0xF7, 0x00, 0x6B, 0xEC, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x09, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xAE, 0x00, 0xF7,
+0x7C, 0x9B, 0x6D, 0xE7, 0xE0, 0xA4, 0xE0, 0xC3,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7,
+0x60, 0x9B, 0x7D, 0xE7, 0x60, 0xA4, 0x60, 0xC7,
+0x01, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x72,
+0x02, 0x4E, 0x01, 0x4C, 0xE1, 0x61, 0x25, 0x67,
+0x00, 0x68, 0x0B, 0x93, 0xC0, 0x99, 0x01, 0x6D,
+0x09, 0xE3, 0x80, 0xAA, 0xAB, 0xED, 0x02, 0x48,
+0x00, 0x18, 0x0E, 0x29, 0x1E, 0x70, 0x04, 0x49,
+0xF4, 0x61, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0x28, 0x34, 0x11, 0xE4, 0x04, 0xD4, 0xEB, 0xF6,
+0xD9, 0xA4, 0x16, 0xF0, 0x84, 0x41, 0x84, 0x34,
+0x11, 0xE4, 0xA4, 0xA4, 0x03, 0x6C, 0xB2, 0xF7,
+0x4E, 0x41, 0x8C, 0xED, 0xA0, 0x35, 0x1D, 0x65,
+0x04, 0x95, 0x48, 0x32, 0x09, 0xE2, 0xEB, 0xF6,
+0xFA, 0xA5, 0x60, 0xA2, 0x01, 0x6A, 0x4C, 0xEF,
+0x4C, 0xEB, 0xE4, 0x37, 0xFD, 0xE3, 0xEB, 0xF6,
+0x7B, 0xA5, 0x4C, 0xEE, 0xD0, 0x36, 0x4C, 0xEB,
+0x24, 0x32, 0x09, 0xE2, 0x2C, 0xF0, 0x4D, 0xA2,
+0x74, 0x33, 0x6D, 0xE6, 0x8C, 0xEA, 0x40, 0x32,
+0x06, 0xD3, 0x48, 0x32, 0x78, 0x67, 0x4D, 0xE3,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0xC8, 0x9A,
+0x01, 0x6D, 0xE3, 0xF2, 0x1D, 0x4C, 0xAB, 0xED,
+0x07, 0xD7, 0x05, 0xD3, 0x00, 0x18, 0x0E, 0x29,
+0x07, 0x94, 0x06, 0x96, 0x05, 0x92, 0xFF, 0xF7,
+0x1F, 0x6D, 0x8D, 0xEE, 0x4D, 0xEE, 0xE3, 0xF3,
+0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0x04, 0x93,
+0x13, 0xF0, 0x40, 0x41, 0x48, 0x32, 0x4C, 0xF0,
+0xC2, 0xAB, 0x09, 0xE2, 0x40, 0xAA, 0xC0, 0x36,
+0xC0, 0x36, 0x01, 0x6D, 0x4D, 0xEE, 0xE3, 0xF3,
+0x08, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x04, 0x94, 0x03, 0xF0, 0x11, 0x49, 0x28, 0x31,
+0x4C, 0xF0, 0xC6, 0xAC, 0x05, 0xE1, 0x40, 0xA9,
+0xC0, 0x36, 0xC0, 0x36, 0x01, 0x6D, 0x4D, 0xEE,
+0xE3, 0xF3, 0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x4C, 0xF0,
+0xD0, 0xA0, 0x60, 0xF6, 0xBC, 0x9A, 0xE3, 0xF3,
+0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0x00, 0x6A, 0x07, 0xD2, 0x08, 0xD2, 0x09, 0xD2,
+0x0A, 0xD2, 0x0B, 0xD2, 0xA2, 0x9C, 0x3D, 0x67,
+0x1C, 0xA1, 0x01, 0x6E, 0xE5, 0x67, 0xFE, 0x4A,
+0xCC, 0xEF, 0x0C, 0xEA, 0xED, 0xEA, 0x03, 0x68,
+0xA6, 0x37, 0x0B, 0xE8, 0xCC, 0xEF, 0xE4, 0x37,
+0x0C, 0xEA, 0xED, 0xEA, 0xAA, 0x37, 0xFE, 0x48,
+0xCC, 0xEF, 0xE8, 0x37, 0x0C, 0xEA, 0xED, 0xEA,
+0xAE, 0x37, 0xFC, 0x48, 0xCC, 0xEF, 0xEC, 0x37,
+0x0C, 0xEA, 0xED, 0xEA, 0x07, 0x68, 0xB2, 0x37,
+0x71, 0x69, 0x2B, 0xE9, 0x0C, 0xEF, 0xF0, 0x37,
+0x2C, 0xEA, 0x07, 0x03, 0xED, 0xEA, 0xA2, 0x35,
+0xFD, 0x67, 0x5C, 0xC7, 0xA1, 0xC3, 0x23, 0x9C,
+0xCC, 0xEA, 0x24, 0xC3, 0xE4, 0x9C, 0x22, 0x31,
+0xE8, 0xC3, 0xA5, 0x9C, 0xE2, 0x37, 0xAC, 0xC3,
+0x86, 0x9C, 0xA2, 0x35, 0x25, 0xC3, 0x1C, 0x65,
+0x90, 0xC3, 0x98, 0x67, 0x82, 0x34, 0xE9, 0xC3,
+0xAD, 0xC3, 0x91, 0xC3, 0x22, 0x31, 0xE2, 0x37,
+0xA2, 0x35, 0x82, 0x34, 0x26, 0xC3, 0xEA, 0xC3,
+0xAE, 0xC3, 0x92, 0xC3, 0x80, 0xF0, 0x1B, 0x22,
+0xBD, 0x67, 0x5C, 0xA5, 0xFF, 0x6B, 0x52, 0x32,
+0x0C, 0xEA, 0x6C, 0xEA, 0x03, 0x22, 0x02, 0x72,
+0x38, 0x60, 0x91, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x2C, 0x9A, 0x81, 0xF4, 0x14, 0x6C,
+0x00, 0x6E, 0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0xFD, 0x67, 0x5D, 0xA7, 0x30, 0xF0, 0x20, 0x68,
+0xE0, 0xF0, 0x14, 0x48, 0x44, 0x32, 0x30, 0xF0,
+0x20, 0x6B, 0x09, 0xE2, 0x61, 0xF0, 0x10, 0x4B,
+0xA0, 0x9B, 0xC0, 0xAA, 0x01, 0xF4, 0x1C, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0xB1, 0x67, 0x81, 0xF6,
+0x14, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x9D, 0x67, 0x5D, 0xA4, 0x30, 0xF0, 0x20, 0x6F,
+0x61, 0xF0, 0x10, 0x4F, 0x44, 0x32, 0x01, 0xE2,
+0xA0, 0x9F, 0xC0, 0xA8, 0x01, 0xF6, 0x1C, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6C,
+0x81, 0xF5, 0x0C, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x5A, 0x10, 0x3D, 0x67, 0x9D, 0xA1, 0x20, 0xF0,
+0xA0, 0xA1, 0x20, 0xF0, 0xC1, 0x81, 0x06, 0x07,
+0x00, 0xF0, 0x19, 0x02, 0x04, 0xD2, 0x00, 0x18,
+0xB0, 0x33, 0xB8, 0xA1, 0xD9, 0xA1, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF5, 0x18, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x2C, 0x9A, 0x7D, 0x67, 0xD8, 0xA3, 0xB1, 0x67,
+0x81, 0xF4, 0x14, 0x6C, 0x00, 0x18, 0x0E, 0x29,
+0x9D, 0x67, 0x59, 0xA4, 0x30, 0xF0, 0x20, 0x68,
+0xE0, 0xF0, 0x14, 0x48, 0x44, 0x32, 0x30, 0xF0,
+0x20, 0x6F, 0x09, 0xE2, 0x61, 0xF0, 0x10, 0x4F,
+0xA0, 0x9F, 0xC0, 0xAA, 0x01, 0xF4, 0x1C, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x5D, 0x67, 0x9D, 0xA2,
+0x20, 0xF0, 0xA4, 0xA2, 0x20, 0xF0, 0xC5, 0x82,
+0x00, 0xF0, 0x19, 0x03, 0x06, 0x07, 0x04, 0xD3,
+0x00, 0x18, 0xB0, 0x33, 0xFD, 0x67, 0xB8, 0xA7,
+0xD9, 0xA7, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF5,
+0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0xB1, 0x67,
+0x3D, 0x67, 0xD8, 0xA1, 0x81, 0xF6, 0x14, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x59, 0xA1, 0x01, 0xF6,
+0x1C, 0x6C, 0x44, 0x32, 0x01, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0x10, 0x4A, 0xA0, 0x9A,
+0xC0, 0xA8, 0x00, 0x18, 0x0E, 0x29, 0x0F, 0x97,
+0x0E, 0x91, 0x0D, 0x90, 0x00, 0x6A, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0xEB, 0xF6, 0x42, 0xA0,
+0x80, 0xF0, 0x00, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0xC1, 0xF5, 0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x21, 0x6B, 0x01, 0x6A, 0x30, 0xF0,
+0x21, 0x6C, 0x91, 0xF5, 0x00, 0x4B, 0xEB, 0xF6,
+0x52, 0xC0, 0xEB, 0xF6, 0x53, 0xC0, 0x71, 0xF5,
+0x08, 0x4C, 0x00, 0x6A, 0x1B, 0x65, 0x06, 0x6E,
+0xD8, 0xEA, 0x00, 0x6B, 0x60, 0xDC, 0x01, 0xF4,
+0xA6, 0x42, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0xAC, 0x35, 0xB5, 0xE3, 0x07, 0xD5,
+0x13, 0xF0, 0xA0, 0x42, 0xA8, 0x35, 0xB5, 0xE3,
+0x06, 0xD5, 0x00, 0x6D, 0x12, 0xEE, 0x0C, 0xF0,
+0x18, 0x4E, 0xD9, 0xE3, 0x78, 0x67, 0x04, 0xD3,
+0xFB, 0x65, 0x07, 0x97, 0x00, 0x6B, 0x06, 0x90,
+0x60, 0xDF, 0x44, 0x37, 0xFD, 0xE5, 0x60, 0xC8,
+0x65, 0xF7, 0x1C, 0x4F, 0x30, 0xF0, 0x20, 0x6B,
+0xE4, 0x37, 0x45, 0xF6, 0x18, 0x4B, 0xED, 0xE3,
+0x08, 0xD3, 0x04, 0x93, 0x00, 0x6F, 0x05, 0xD3,
+0x44, 0x31, 0x08, 0x90, 0xA5, 0xE1, 0x24, 0x31,
+0x01, 0x6B, 0x25, 0xE7, 0x60, 0xC0, 0x30, 0x30,
+0x30, 0xF0, 0x20, 0x6B, 0x30, 0x31, 0x45, 0xF6,
+0x18, 0x4B, 0x0B, 0xF7, 0x18, 0x48, 0x8B, 0xF7,
+0x18, 0x49, 0x01, 0xE3, 0x25, 0xE3, 0x0A, 0xD2,
+0x05, 0x92, 0x00, 0x6B, 0x60, 0xC8, 0x02, 0x48,
+0x4A, 0xE8, 0x60, 0xC9, 0x02, 0x49, 0xF8, 0x61,
+0x08, 0x90, 0x01, 0x4F, 0x02, 0x77, 0x01, 0x48,
+0x08, 0xD0, 0x05, 0x90, 0x0A, 0x92, 0x10, 0x48,
+0x05, 0xD0, 0xDA, 0x61, 0x60, 0xC6, 0x61, 0xC6,
+0x62, 0xC6, 0x06, 0x97, 0x07, 0x93, 0x04, 0x90,
+0x01, 0x4D, 0x04, 0x4B, 0x02, 0x4F, 0x20, 0x48,
+0x02, 0x75, 0x07, 0xD3, 0x06, 0xD7, 0x03, 0x4E,
+0x04, 0xD0, 0xB7, 0x61, 0x01, 0x4A, 0xFF, 0x67,
+0x02, 0x6B, 0x40, 0x4F, 0x4E, 0xEB, 0x04, 0x4C,
+0x1F, 0x65, 0x95, 0x2B, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0xD4, 0x9A, 0x01, 0x6D, 0x03, 0xF3,
+0x10, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x48, 0x9A, 0xFF, 0x69, 0x04, 0x67,
+0x2C, 0xE8, 0x04, 0x36, 0xAC, 0xE9, 0x01, 0x6D,
+0x4D, 0xEE, 0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xEB, 0xF6, 0x60, 0xA2,
+0x03, 0x23, 0x01, 0x73, 0x37, 0x60, 0x78, 0x10,
+0x03, 0x21, 0x12, 0x6B, 0xEB, 0xF6, 0x6B, 0xC2,
+0x30, 0xF0, 0x21, 0x6A, 0x51, 0xF5, 0xC3, 0xA2,
+0xC3, 0xF3, 0x0C, 0x6C, 0xFF, 0x6D, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0xB8, 0x9A, 0x23, 0xF3, 0x08, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0xDC, 0x9A, 0x01, 0x69, 0x2B, 0xE9,
+0xB1, 0x67, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xC0, 0x9A, 0xB1, 0x67, 0x23, 0xF3, 0x04, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x24, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x81, 0xF0,
+0xE8, 0x9A, 0x37, 0x10, 0x05, 0x21, 0x12, 0x6B,
+0x01, 0x20, 0x09, 0x6B, 0xEB, 0xF6, 0x6B, 0xC2,
+0x30, 0xF0, 0x21, 0x6A, 0x51, 0xF5, 0xC3, 0xA2,
+0xC3, 0xF3, 0x0C, 0x6C, 0xFF, 0x6D, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0xB8, 0x9A, 0x23, 0xF3, 0x08, 0x6C, 0x80, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0xD0, 0x9A, 0x01, 0x69, 0x2B, 0xE9,
+0xB1, 0x67, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xD4, 0x9A, 0xB1, 0x67, 0x23, 0xF3, 0x04, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x24, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0xF8, 0x9A, 0x90, 0x67, 0x56, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x34, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0xEC, 0x9A, 0x90, 0x67,
+0x8F, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0x34, 0x29,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x48, 0x9A, 0xFF, 0x68, 0x8C, 0xE8,
+0x01, 0x69, 0x2B, 0xE9, 0x04, 0x36, 0x4D, 0xEE,
+0x03, 0xF3, 0x00, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x21, 0x6A, 0x31, 0xF5,
+0x58, 0xA2, 0x03, 0x22, 0x01, 0x72, 0x37, 0x60,
+0x6D, 0x10, 0xC3, 0xF3, 0x0C, 0x6C, 0xFF, 0x6D,
+0x09, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0xB8, 0x9A, 0x23, 0xF3,
+0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0xDC, 0x9A,
+0xB1, 0x67, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xDC, 0x9A, 0xB1, 0x67, 0x23, 0xF3, 0x04, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x24, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0xE8, 0x9A, 0x90, 0x67, 0x56, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x34, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0xA1, 0xF0, 0xE0, 0x9A, 0x35, 0x10, 0xC3, 0xF3,
+0x0C, 0x6C, 0xFF, 0x6D, 0x09, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0xB8, 0x9A, 0x23, 0xF3, 0x08, 0x6C, 0x80, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0xD0, 0x9A, 0xB1, 0x67, 0x23, 0xF3,
+0x00, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF0, 0xC4, 0x9A, 0xB1, 0x67,
+0x23, 0xF3, 0x04, 0x6C, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x24, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xE8, 0x9A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0xE8, 0x9A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0x34, 0x29, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x48, 0x9A,
+0xFF, 0x68, 0x8C, 0xE8, 0x01, 0x69, 0x2B, 0xE9,
+0x04, 0x36, 0x4D, 0xEE, 0x03, 0xF3, 0x00, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0xC3, 0xF3,
+0x0C, 0x6C, 0xB1, 0x67, 0x09, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0xCC, 0x9A, 0x23, 0xF3, 0x00, 0x6C, 0xB1, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x21, 0x6A,
+0x31, 0xF5, 0x58, 0xA2, 0x03, 0x22, 0x01, 0x72,
+0x1F, 0x60, 0x3D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x24, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0xF0, 0x9A, 0x90, 0x67, 0x56, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x34, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF0, 0xE8, 0x9A, 0x90, 0x67,
+0x8F, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0x34, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x23, 0xF3, 0x08, 0x6C,
+0x61, 0xF0, 0xB8, 0x9A, 0x00, 0x6E, 0x1D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x24, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xF4, 0x9A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xEC, 0x9A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0xB8, 0x9A, 0x23, 0xF3, 0x08, 0x6C,
+0x80, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x48, 0x9A,
+0xFF, 0x68, 0x8C, 0xE8, 0x01, 0x69, 0x2B, 0xE9,
+0x04, 0x36, 0x4D, 0xEE, 0xB1, 0x67, 0x03, 0xF3,
+0x00, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0xB1, 0x67,
+0xC3, 0xF3, 0x0C, 0x6C, 0x09, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x38, 0x9A, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x6E,
+0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x21, 0x6A, 0x31, 0xF5, 0x58, 0xA2, 0x03, 0x22,
+0x01, 0x72, 0x28, 0x60, 0x4F, 0x10, 0xB1, 0x67,
+0x23, 0xF3, 0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x24, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0xF0, 0x9A, 0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0xE8, 0x9A, 0x90, 0x67, 0x8F, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x34, 0x29, 0x90, 0x67,
+0xEF, 0x6D, 0x10, 0x6E, 0x01, 0x6F, 0x00, 0x18,
+0x34, 0x29, 0x90, 0x67, 0x33, 0x6D, 0x03, 0x6E,
+0x00, 0x6F, 0x26, 0x10, 0xB1, 0x67, 0x23, 0xF3,
+0x08, 0x6C, 0x80, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x24, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xF8, 0x9A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xEC, 0x9A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0x34, 0x29, 0x90, 0x67, 0xEF, 0x6D,
+0x10, 0x6E, 0x01, 0x6F, 0x00, 0x18, 0x34, 0x29,
+0x90, 0x67, 0x33, 0x6D, 0x03, 0x6E, 0x01, 0x6F,
+0x00, 0x18, 0x34, 0x29, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF6, 0x63, 0x13, 0x62, 0x12, 0xD1, 0x11, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x4C, 0xED, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF3, 0x18, 0x4A, 0x64, 0x67,
+0x04, 0xD2, 0xA2, 0xF7, 0x1E, 0x4B, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x68, 0x33,
+0x6D, 0xE2, 0x05, 0xD3, 0x64, 0x67, 0x01, 0xF4,
+0x06, 0x4B, 0x6C, 0x33, 0x6D, 0xE2, 0x0C, 0xD4,
+0x0E, 0xD5, 0x07, 0xD3, 0x00, 0x69, 0x0E, 0x93,
+0x10, 0x2B, 0x91, 0x67, 0xDF, 0x6D, 0x10, 0x6E,
+0x01, 0x6F, 0x00, 0x18, 0x34, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0xC4, 0x9A, 0x07, 0x92,
+0x91, 0x67, 0x58, 0x6D, 0xE0, 0x9A, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x48, 0x9A, 0x24, 0x33, 0x00, 0x68, 0x4D, 0xEB,
+0x0B, 0xD3, 0x0B, 0x96, 0x01, 0x6D, 0x03, 0xF3,
+0x00, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x01, 0x6D, 0x23, 0xF3, 0x0C, 0x6C, 0xAB, 0xED,
+0x07, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x18, 0x4A, 0xC0, 0x9A,
+0x01, 0x6D, 0x23, 0xF3, 0x18, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x18, 0x4B, 0xC0, 0x9B, 0x01, 0x6D,
+0x23, 0xF3, 0x1C, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x0E, 0x29, 0x01, 0x6D, 0xC3, 0xF3, 0x0C, 0x6C,
+0xAB, 0xED, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xFF, 0x6A, 0x0C, 0xEA, 0x06, 0x2A, 0x03, 0xF3,
+0x0C, 0x6C, 0x06, 0xF0, 0x00, 0x6D, 0x03, 0x6E,
+0x05, 0x10, 0x03, 0xF3, 0x0C, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xBC, 0x9A,
+0xC3, 0xF3, 0x14, 0x6C, 0x10, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x0C, 0x95, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0x40, 0x9A, 0xA4, 0x34, 0x31, 0xE4,
+0x84, 0x34, 0x91, 0xE0, 0x90, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x0B, 0xF7,
+0x18, 0x4D, 0x90, 0x34, 0x46, 0xE8, 0xB5, 0xE3,
+0x8B, 0xF7, 0x18, 0x4C, 0x91, 0xE3, 0x0A, 0xD5,
+0x61, 0x42, 0xA3, 0x42, 0x23, 0x4A, 0x06, 0xD5,
+0x09, 0xD4, 0x08, 0xD3, 0x0D, 0xD2, 0x0A, 0x95,
+0x06, 0x92, 0xC3, 0xF3, 0x18, 0x6C, 0xC0, 0xAD,
+0x01, 0x6D, 0xAB, 0xED, 0xC0, 0x36, 0xC4, 0x36,
+0xD9, 0xE2, 0x00, 0x18, 0x0E, 0x29, 0x09, 0x93,
+0x08, 0x92, 0x01, 0x6D, 0xC0, 0xAB, 0xAB, 0xED,
+0xC3, 0xF3, 0x18, 0x6C, 0xC0, 0x36, 0xC4, 0x36,
+0xD9, 0xE2, 0x00, 0x18, 0x0E, 0x29, 0x0A, 0x93,
+0x09, 0x92, 0x06, 0x95, 0x02, 0x4B, 0x02, 0x4A,
+0x0A, 0xD3, 0x09, 0xD2, 0x08, 0x93, 0x0D, 0x92,
+0x04, 0x4D, 0x04, 0x4B, 0x4A, 0xED, 0x06, 0xD5,
+0x08, 0xD3, 0xD9, 0x61, 0xFF, 0x6A, 0x0C, 0xEA,
+0x06, 0x2A, 0x04, 0x95, 0x05, 0x93, 0x80, 0xAD,
+0xC0, 0xA3, 0x01, 0x6D, 0x06, 0x10, 0x05, 0x92,
+0x04, 0x93, 0x00, 0xF4, 0x00, 0x6D, 0xC1, 0xA2,
+0x80, 0xAB, 0xCF, 0xEE, 0x01, 0x48, 0x00, 0x18,
+0x0E, 0x29, 0x02, 0x70, 0x7F, 0xF7, 0x01, 0x61,
+0x01, 0x6D, 0xC3, 0xF3, 0x18, 0x6C, 0xAB, 0xED,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x06, 0xF0,
+0x00, 0x6D, 0x03, 0xF3, 0x0C, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x04, 0x95, 0x05, 0x92,
+0x07, 0x93, 0x01, 0x49, 0x02, 0x4D, 0x02, 0x4A,
+0x04, 0x4B, 0x02, 0x71, 0x04, 0xD5, 0x05, 0xD2,
+0x07, 0xD3, 0x3F, 0xF7, 0x0C, 0x61, 0x13, 0x97,
+0x12, 0x91, 0x11, 0x90, 0x0A, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x4C, 0xEC, 0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x00, 0x6B, 0x4C, 0xF0,
+0x70, 0xC2, 0x21, 0x2C, 0xEB, 0xF6, 0x62, 0xA2,
+0x1E, 0x23, 0xEB, 0xF6, 0x64, 0x9A, 0x0B, 0xF7,
+0x90, 0x9A, 0x00, 0x68, 0x6E, 0xEC, 0x05, 0x24,
+0x0B, 0xF7, 0x54, 0x9A, 0x4E, 0xEB, 0x13, 0x2B,
+0x01, 0x68, 0x01, 0x6B, 0x30, 0xF0, 0x21, 0x6A,
+0x90, 0x67, 0xB1, 0xF6, 0x68, 0xC2, 0x00, 0x18,
+0x5E, 0x36, 0x90, 0x67, 0x00, 0x18, 0x4D, 0x34,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF5, 0x1C, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0,
+0x21, 0x6A, 0xB1, 0xF6, 0x48, 0xA2, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x21, 0x6A,
+0x51, 0xF5, 0x49, 0xA2, 0x05, 0x22, 0x00, 0x6C,
+0x01, 0x6D, 0x00, 0x18, 0xDA, 0x36, 0x04, 0x10,
+0x00, 0x6C, 0x01, 0x6D, 0x00, 0x18, 0x5E, 0x36,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x04, 0x9A, 0x00, 0x6C,
+0xB8, 0x6D, 0xD0, 0x67, 0x01, 0xF2, 0x00, 0x6F,
+0x00, 0x18, 0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0xE4, 0x9A, 0xD0, 0x67, 0x00, 0x6C,
+0xB8, 0x6D, 0x00, 0x18, 0x34, 0x29, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0xC8, 0x9A,
+0x01, 0x68, 0x0B, 0xE8, 0xB0, 0x67, 0x03, 0xF3,
+0x00, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67,
+0xA3, 0xF3, 0x18, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x00, 0x68, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x24, 0x9A, 0x90, 0x67, 0xDF, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xD7, 0x28, 0x01, 0xF0,
+0x13, 0x6B, 0x6B, 0xEB, 0x4C, 0xEB, 0x01, 0xF0,
+0x02, 0x6F, 0x6D, 0xEF, 0x90, 0x67, 0xDF, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x34, 0x29, 0x90, 0x67,
+0x65, 0x6D, 0xD1, 0x67, 0x12, 0xF0, 0x00, 0x6F,
+0x00, 0x18, 0x34, 0x29, 0x30, 0xF0, 0x21, 0x6A,
+0x31, 0xF5, 0x58, 0xA2, 0x01, 0x72, 0x1E, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x18, 0x4A,
+0xC0, 0x9A, 0x90, 0x67, 0xEF, 0x6D, 0x01, 0x6F,
+0x00, 0x18, 0x34, 0x29, 0x90, 0x67, 0x33, 0x6D,
+0xD1, 0x67, 0x26, 0x6F, 0x00, 0x18, 0x34, 0x29,
+0x90, 0x67, 0x3E, 0x6D, 0xD1, 0x67, 0x37, 0x6F,
+0x00, 0x18, 0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0x3F, 0x6D, 0xD1, 0x67, 0xC1, 0xF0,
+0xE8, 0x9A, 0x1D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x18, 0x4A, 0xC0, 0x9A, 0x90, 0x67,
+0xEF, 0x6D, 0x01, 0x6F, 0x00, 0x18, 0x34, 0x29,
+0x90, 0x67, 0x33, 0x6D, 0xD1, 0x67, 0x26, 0x6F,
+0x00, 0x18, 0x34, 0x29, 0x90, 0x67, 0x3E, 0x6D,
+0xD1, 0x67, 0x37, 0x6F, 0x00, 0x18, 0x34, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0xEC, 0x9A,
+0x90, 0x67, 0x3F, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6,
+0x18, 0x4B, 0xC0, 0x9B, 0x90, 0x67, 0xEF, 0x6D,
+0x00, 0x6F, 0x01, 0x48, 0x00, 0x18, 0x34, 0x29,
+0x02, 0x70, 0x94, 0x61, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x68, 0x8C, 0xE8, 0x00, 0x69, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x04, 0x4A, 0xC0, 0x9A,
+0x90, 0x67, 0xEF, 0x6D, 0x00, 0x6F, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0,
+0x04, 0x4B, 0xC0, 0x9B, 0x90, 0x67, 0x08, 0x6D,
+0x00, 0x6F, 0x00, 0x18, 0x34, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x04, 0x4A, 0xC0, 0x9A,
+0x90, 0x67, 0x08, 0x6D, 0x00, 0x18, 0xD7, 0x28,
+0x07, 0x22, 0x01, 0x49, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE9, 0x2E, 0xF5, 0x10, 0x71, 0xDB, 0x61,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xC4, 0x9A,
+0x00, 0x6C, 0x18, 0x6D, 0x00, 0x18, 0xD7, 0x28,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF4, 0x00, 0x6C,
+0x45, 0xF6, 0x18, 0x4B, 0x4C, 0xEC, 0xEB, 0xF6,
+0x44, 0xDB, 0x82, 0x32, 0x4A, 0x32, 0x02, 0x72,
+0x0A, 0x60, 0x03, 0x6C, 0x4E, 0xEC, 0x04, 0x24,
+0x01, 0x72, 0x02, 0x6A, 0x05, 0x60, 0x06, 0x10,
+0xEB, 0xF6, 0x81, 0xC3, 0x03, 0x10, 0x01, 0x6A,
+0xEB, 0xF6, 0x41, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF6, 0x7C, 0x9B, 0xEB, 0xF6, 0x84, 0x9A,
+0x8C, 0xEB, 0x62, 0x33, 0x62, 0x33, 0xEB, 0xF6,
+0x60, 0xC2, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x00, 0x68, 0x25, 0x67, 0x04, 0xD4, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x04, 0x4A, 0xA0, 0xA1,
+0xC0, 0x9A, 0x00, 0x6C, 0x01, 0x48, 0x00, 0x18,
+0xD7, 0x28, 0x04, 0x93, 0x01, 0x6C, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x04, 0x4A,
+0xA0, 0xA1, 0xC0, 0x9A, 0x01, 0x49, 0x00, 0x18,
+0xD7, 0x28, 0x04, 0x93, 0x41, 0xDB, 0xFF, 0x6A,
+0x4C, 0xE8, 0x08, 0x4B, 0x05, 0x70, 0x04, 0xD3,
+0xE2, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x00, 0x6B, 0x0B, 0xD7,
+0xE0, 0xAE, 0x1F, 0xF7, 0x00, 0x6A, 0xEC, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x08, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xAE, 0x00, 0xF7,
+0x5C, 0x9A, 0x49, 0xE7, 0xE0, 0xA2, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x5D, 0xE7, 0xE0, 0xA7, 0xFF, 0x6A, 0xEC, 0xEA,
+0x7D, 0xE4, 0x01, 0x4B, 0x03, 0x73, 0x40, 0xC7,
+0x02, 0x4E, 0xE2, 0x61, 0x25, 0x67, 0x00, 0x68,
+0x0B, 0x93, 0x01, 0x6D, 0xAB, 0xED, 0x09, 0xE3,
+0x80, 0xAA, 0x02, 0x48, 0x00, 0x18, 0x00, 0x29,
+0x1E, 0x70, 0x40, 0xD9, 0x04, 0x49, 0xF4, 0x61,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xFF, 0x68, 0x24, 0x67, 0x61, 0xF0, 0x48, 0x9A,
+0x0C, 0xE9, 0xAC, 0xE8, 0x04, 0x36, 0x01, 0x6D,
+0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED, 0x4D, 0xEE,
+0x00, 0x18, 0x0E, 0x29, 0x06, 0x29, 0x03, 0xF3,
+0x0C, 0x6C, 0x06, 0xF0, 0x00, 0x6D, 0x03, 0x6E,
+0x05, 0x10, 0x03, 0xF3, 0x0C, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xBC, 0x9A,
+0x04, 0x30, 0x01, 0xE1, 0xC3, 0xF3, 0x14, 0x6C,
+0x10, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x10, 0x33,
+0x30, 0xF0, 0x20, 0x6A, 0x10, 0x30, 0x45, 0xF6,
+0x18, 0x4A, 0x0B, 0xF7, 0x18, 0x4B, 0x8B, 0xF7,
+0x18, 0x48, 0x01, 0xE2, 0x65, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x04, 0xD0, 0xC1, 0xF0, 0x10, 0x9A,
+0x01, 0x6D, 0xD0, 0x67, 0xC3, 0xF3, 0x18, 0x6C,
+0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29, 0x01, 0x6D,
+0xE3, 0xF3, 0x1C, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x00, 0x29, 0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0,
+0x74, 0x9B, 0x04, 0x48, 0x4C, 0xEB, 0x62, 0x33,
+0x62, 0x33, 0x60, 0xC9, 0xE1, 0xF7, 0x1F, 0x6B,
+0x4C, 0xEB, 0x04, 0x92, 0x02, 0x49, 0x60, 0xCA,
+0x02, 0x4A, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0x58, 0x9A, 0x0E, 0xEA, 0xDC, 0x2A,
+0x01, 0x6D, 0xC3, 0xF3, 0x18, 0x6C, 0xAB, 0xED,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x03, 0xF3,
+0x0C, 0x6C, 0x06, 0xF0, 0x00, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x05, 0x67, 0x01, 0x74,
+0x4C, 0xE8, 0x80, 0xF0, 0x15, 0x60, 0x04, 0x24,
+0x04, 0x5C, 0xA0, 0xF0, 0x08, 0x60, 0xA2, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x0B, 0xF7, 0x70, 0x9A, 0x30, 0xF0, 0x21, 0x6C,
+0x30, 0xF0, 0x21, 0x6D, 0x0B, 0xF7, 0x74, 0xDA,
+0x30, 0xF0, 0x21, 0x6B, 0x30, 0xF0, 0x21, 0x6A,
+0x91, 0xF6, 0x08, 0x4C, 0x91, 0xF6, 0x18, 0x4B,
+0x91, 0xF6, 0x04, 0x4A, 0x91, 0xF5, 0x00, 0x4D,
+0x00, 0x69, 0xC0, 0x9C, 0x75, 0xF7, 0x0C, 0x41,
+0x04, 0x30, 0xC2, 0xDC, 0xC0, 0xAB, 0x05, 0xD5,
+0xE5, 0x67, 0xC2, 0xCB, 0xC0, 0xA2, 0xC2, 0xC2,
+0x30, 0xF0, 0x20, 0x6E, 0x45, 0xF6, 0x18, 0x4E,
+0x01, 0xE6, 0x00, 0x6E, 0x04, 0xD6, 0xA0, 0xA0,
+0x24, 0x36, 0xA4, 0xC0, 0x04, 0x95, 0xD9, 0xE5,
+0x07, 0xD6, 0xD0, 0x35, 0x30, 0xF0, 0x20, 0x6E,
+0x0B, 0xF7, 0x18, 0x4D, 0x45, 0xF6, 0x18, 0x4E,
+0x1E, 0x65, 0xB9, 0xE6, 0x07, 0x95, 0x06, 0xD6,
+0x07, 0xD2, 0xB0, 0x36, 0x8B, 0xF7, 0x18, 0x4E,
+0xB8, 0x67, 0xD9, 0xE5, 0x06, 0x95, 0x40, 0xAD,
+0x40, 0xF0, 0x40, 0xCD, 0x40, 0xAE, 0x02, 0x4D,
+0x40, 0xF0, 0x40, 0xCE, 0x05, 0x92, 0x02, 0x4E,
+0x4A, 0xED, 0xF5, 0x61, 0x04, 0x95, 0x05, 0x96,
+0x07, 0x92, 0x01, 0x4D, 0x10, 0x4E, 0x02, 0x75,
+0x04, 0xD5, 0x01, 0x48, 0x05, 0xD6, 0xD3, 0x61,
+0x01, 0x49, 0x02, 0x6E, 0xA7, 0x67, 0x2E, 0xEE,
+0x04, 0x4C, 0x02, 0x4B, 0x01, 0x4A, 0x20, 0x4D,
+0xB8, 0x2E, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x00, 0x6B, 0x2C, 0xF0, 0x64, 0xC2,
+0x2C, 0xF0, 0x65, 0xC2, 0x0C, 0xF0, 0x78, 0xC2,
+0x0C, 0xF0, 0x79, 0xC2, 0x0C, 0xF0, 0x7A, 0xC2,
+0x2C, 0xF0, 0x6D, 0xC2, 0x2C, 0xF0, 0x66, 0xC2,
+0x2C, 0xF0, 0x67, 0xC2, 0x0C, 0xF0, 0x7B, 0xC2,
+0x0C, 0xF0, 0x7C, 0xC2, 0x0C, 0xF0, 0x7D, 0xC2,
+0xEB, 0xF6, 0x64, 0x9A, 0x01, 0x6C, 0x2C, 0xF0,
+0xCC, 0xC2, 0x4C, 0xF0, 0xC0, 0xCA, 0xEB, 0xF6,
+0x98, 0xC2, 0xEB, 0xF6, 0x99, 0xC2, 0x4C, 0xF0,
+0xC2, 0xCA, 0xEB, 0xF6, 0x9A, 0xC2, 0xEB, 0xF6,
+0x9B, 0xC2, 0x0B, 0xF7, 0x70, 0xDA, 0x17, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xC4, 0x9A,
+0x90, 0x67, 0x58, 0x6D, 0x00, 0x18, 0xD7, 0x28,
+0x03, 0xF0, 0x0C, 0x48, 0x30, 0xF0, 0x20, 0x6B,
+0x08, 0x30, 0x45, 0xF6, 0x18, 0x4B, 0x6D, 0xE0,
+0x40, 0xDB, 0x05, 0x10, 0xFE, 0x4C, 0x4C, 0xEC,
+0xB0, 0x67, 0x00, 0x18, 0xB7, 0x37, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x21, 0x6A,
+0x51, 0xF5, 0x49, 0xA2, 0x18, 0x2A, 0x01, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0xF2, 0x37, 0x02, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0xF2, 0x37, 0x03, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0xF2, 0x37, 0x01, 0x6C,
+0xA4, 0x67, 0x00, 0x18, 0xF2, 0x37, 0x02, 0x6C,
+0x01, 0x6D, 0x00, 0x18, 0xF2, 0x37, 0x03, 0x6C,
+0x01, 0x6D, 0x00, 0x18, 0xF2, 0x37, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x00, 0x6A, 0x7D, 0x67,
+0x4C, 0xCB, 0x2E, 0xF5, 0x10, 0x6A, 0xFF, 0x68,
+0x04, 0xD2, 0x06, 0x02, 0x0C, 0xEC, 0x05, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x08, 0xD4, 0x81, 0xF0,
+0xC4, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x08, 0x94,
+0xC1, 0xF0, 0xFC, 0x9A, 0x0C, 0xED, 0x09, 0xD5,
+0x08, 0x6D, 0x00, 0x18, 0xE8, 0x28, 0x0E, 0x22,
+0x09, 0x92, 0x00, 0x69, 0x12, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0xB8, 0x9A, 0x03, 0xF3,
+0x08, 0x6C, 0x00, 0x18, 0x00, 0x29, 0x22, 0x67,
+0x0C, 0xE9, 0x07, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF6, 0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x01, 0x69, 0x08, 0x94, 0x00, 0x18, 0x52, 0x37,
+0x7D, 0x67, 0xAC, 0xAB, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF6, 0x10, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x51, 0x67, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x24, 0x67,
+0x4C, 0xED, 0x4C, 0xE9, 0x05, 0xD5, 0x0F, 0x2D,
+0x30, 0xF0, 0x21, 0x6A, 0x31, 0xF5, 0x19, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x48, 0x9A,
+0x04, 0x48, 0x00, 0x30, 0x4D, 0xE8, 0x64, 0x41,
+0x01, 0x6A, 0x44, 0xEB, 0x10, 0x10, 0x05, 0x92,
+0x01, 0x72, 0x17, 0x61, 0x30, 0xF0, 0x21, 0x6A,
+0x31, 0xF5, 0x59, 0xA2, 0x02, 0x72, 0x09, 0x61,
+0x44, 0x41, 0x01, 0x68, 0x04, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x40, 0x9A, 0x4D, 0xE8,
+0x3E, 0x10, 0x44, 0x41, 0x01, 0x68, 0x04, 0xEA,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x44, 0x9A,
+0xF6, 0x17, 0x05, 0x93, 0x00, 0x68, 0x02, 0x73,
+0x32, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xEB, 0xF6, 0x01, 0xA2, 0x04, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x48, 0x9A,
+0x09, 0x48, 0x84, 0x41, 0x00, 0x30, 0x01, 0x6B,
+0x24, 0x36, 0x01, 0x6D, 0x64, 0xEC, 0x4D, 0xE8,
+0x4D, 0xEE, 0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED,
+0x6D, 0xE8, 0x00, 0x18, 0x0E, 0x29, 0x01, 0x6D,
+0x23, 0xF3, 0x04, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x00, 0x29, 0x03, 0xF4, 0x01, 0x6B, 0x6B, 0xEB,
+0x4C, 0xEB, 0x04, 0x92, 0x01, 0x6D, 0x23, 0xF3,
+0x04, 0x6C, 0xEB, 0xF6, 0xCC, 0x9A, 0x07, 0x6A,
+0xAB, 0xED, 0x4C, 0xEE, 0xC0, 0x36, 0xC8, 0x36,
+0x6D, 0xEE, 0x00, 0x18, 0x0E, 0x29, 0x01, 0x6D,
+0xD0, 0x67, 0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0x6D, 0xC1, 0x40,
+0xAB, 0xED, 0x03, 0xF3, 0x00, 0x6C, 0x00, 0x18,
+0x0E, 0x29, 0x02, 0x6C, 0x00, 0x18, 0x75, 0x1E,
+0x91, 0x67, 0x01, 0x6D, 0x00, 0x18, 0x61, 0x38,
+0x02, 0x67, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0xC8, 0x9A, 0x24, 0x33, 0x01, 0x6D, 0x03, 0xF3,
+0x00, 0x6C, 0xAB, 0xED, 0x6D, 0xEE, 0x04, 0xD3,
+0x00, 0x18, 0x0E, 0x29, 0x05, 0x92, 0x12, 0x2A,
+0x0C, 0x20, 0x04, 0x93, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF3, 0x18, 0x4A, 0x49, 0xE3, 0x80, 0xAA,
+0x01, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x3D, 0x10, 0x02, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0xF2, 0x37, 0x38, 0x10, 0x05, 0x92, 0x02, 0x72,
+0x55, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xC4, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0x00, 0x18,
+0xD7, 0x28, 0x30, 0xF0, 0x20, 0x6B, 0x26, 0xF0,
+0x80, 0x41, 0x45, 0xF6, 0x18, 0x4B, 0x84, 0x34,
+0x71, 0xE4, 0xEB, 0xF6, 0x6B, 0xA3, 0xFF, 0x6D,
+0x56, 0x32, 0xAC, 0xEA, 0x60, 0x33, 0x6D, 0xEA,
+0x40, 0xCC, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xD8, 0x9A, 0x80, 0x4D, 0x23, 0xF3, 0x18, 0x6C,
+0x80, 0x4D, 0x00, 0x18, 0x0E, 0x29, 0x0D, 0x20,
+0x04, 0x93, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF3,
+0x18, 0x4A, 0x49, 0xE3, 0x80, 0xAA, 0x01, 0xF4,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x25, 0x10, 0x03, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0xF2, 0x37, 0x20, 0x10, 0x0A, 0x28, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0x33, 0x00, 0xF3, 0x18, 0x4A,
+0x49, 0xE3, 0x01, 0x6D, 0x80, 0xAA, 0xC5, 0x67,
+0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x24, 0x33,
+0x00, 0xF3, 0x18, 0x4A, 0x49, 0xE3, 0x80, 0xAA,
+0x01, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x65, 0xF7, 0x1C, 0x49, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0x31, 0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE1,
+0x00, 0xC2, 0x08, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0x31, 0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE1,
+0xEB, 0xF6, 0x19, 0xC2, 0x50, 0x67, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x8C, 0xE9, 0x44, 0x41, 0x01, 0x68,
+0x04, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x48, 0x9A, 0x01, 0x6D, 0x03, 0xF3, 0x00, 0x6C,
+0x4D, 0xE8, 0xD0, 0x67, 0xAB, 0xED, 0x00, 0x18,
+0x0E, 0x29, 0x01, 0x6D, 0xC1, 0x40, 0xAB, 0xED,
+0x03, 0xF3, 0x00, 0x6C, 0x00, 0x18, 0x0E, 0x29,
+0x01, 0x6C, 0x00, 0x18, 0x75, 0x1E, 0x91, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x61, 0x38, 0x02, 0x67,
+0x04, 0x2A, 0x01, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0xF2, 0x37, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF6,
+0x08, 0x4C, 0x00, 0x6D, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x45, 0xE1, 0xEB, 0xF6, 0x12, 0xC1, 0x50, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x4C, 0xED, 0x30, 0xF0, 0x21, 0x6A, 0x51, 0xF5,
+0x43, 0xA2, 0x04, 0xD4, 0x05, 0xD5, 0x09, 0x72,
+0x00, 0x68, 0x0C, 0x60, 0x12, 0x72, 0x01, 0x68,
+0x09, 0x60, 0x1B, 0x72, 0x02, 0x68, 0x06, 0x60,
+0x24, 0x68, 0x4E, 0xE8, 0x01, 0x58, 0x18, 0x67,
+0x04, 0x6A, 0x03, 0xE2, 0x04, 0x92, 0x01, 0x69,
+0x2B, 0xE9, 0x44, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x48, 0x9A, 0x03, 0xF3, 0x00, 0x6C,
+0xB1, 0x67, 0x4D, 0xEE, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x21, 0x6A, 0x51, 0xF5, 0xC3, 0xA2,
+0xC3, 0xF3, 0x0C, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x05, 0x93, 0x01, 0x73, 0x09, 0x61,
+0x04, 0x92, 0x01, 0x69, 0x04, 0x4A, 0x24, 0xEA,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x48, 0x9A,
+0x08, 0x10, 0x04, 0x92, 0x01, 0x69, 0x04, 0x4A,
+0x24, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x4C, 0x9A, 0x4D, 0xE9, 0x01, 0x6D, 0x03, 0xF3,
+0x00, 0x6C, 0xAB, 0xED, 0xD1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x01, 0x6D, 0xAB, 0xED, 0xC1, 0x41,
+0x03, 0xF3, 0x00, 0x6C, 0x00, 0x18, 0x0E, 0x29,
+0x01, 0x6C, 0x00, 0x18, 0x75, 0x1E, 0x04, 0x94,
+0x01, 0x6D, 0x00, 0x18, 0x61, 0x38, 0x05, 0x93,
+0x02, 0x73, 0x6D, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x94, 0x81, 0xF0, 0xC4, 0x9A, 0x00, 0x6D,
+0x00, 0x18, 0xD7, 0x28, 0xE3, 0xF7, 0x00, 0x6B,
+0x4C, 0xEB, 0x76, 0x32, 0x1F, 0x6D, 0x30, 0xF0,
+0x20, 0x6B, 0x4C, 0xED, 0x45, 0xF6, 0x18, 0x4B,
+0x56, 0x34, 0x02, 0x5D, 0xEB, 0xF6, 0x8C, 0xDB,
+0x0B, 0x60, 0x02, 0x24, 0xFF, 0x4C, 0x13, 0x10,
+0x03, 0x70, 0x01, 0x48, 0x0A, 0x61, 0x01, 0x6A,
+0x4C, 0xF0, 0x48, 0xC3, 0x03, 0x68, 0x11, 0x10,
+0x0A, 0x5D, 0x00, 0x6E, 0x0F, 0x61, 0x04, 0x20,
+0xFF, 0x48, 0xFF, 0x6A, 0x4C, 0xE8, 0x09, 0x10,
+0x07, 0x74, 0x04, 0x60, 0x01, 0x4C, 0xEB, 0xF6,
+0x8C, 0xDB, 0x03, 0x10, 0x01, 0x6A, 0x4C, 0xF0,
+0x48, 0xC3, 0x01, 0x6E, 0x30, 0xF0, 0x20, 0x69,
+0x45, 0xF6, 0x18, 0x49, 0x4C, 0xF0, 0x68, 0xA1,
+0x01, 0x6A, 0x4E, 0xEB, 0x6B, 0xEA, 0x6D, 0xEA,
+0xC0, 0xF7, 0x43, 0x32, 0x4C, 0xEE, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF3, 0x00, 0x4A, 0x41, 0xE0,
+0x40, 0xA0, 0xEB, 0xF6, 0x4B, 0xC1, 0x00, 0x6A,
+0x22, 0x26, 0x04, 0x93, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x48, 0x9A, 0x01, 0x68, 0x64, 0x36,
+0x0B, 0xE8, 0x4D, 0xEE, 0x03, 0xF3, 0x00, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x23, 0xF3,
+0x04, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x00, 0x29,
+0xEB, 0xF6, 0xCC, 0x99, 0x03, 0xF4, 0x01, 0x6B,
+0x6B, 0xEB, 0xC0, 0x36, 0x4C, 0xEB, 0xC8, 0x36,
+0x23, 0xF3, 0x04, 0x6C, 0xB0, 0x67, 0x6D, 0xEE,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0x6A, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x04, 0xD2, 0xEB, 0xF6, 0x48, 0xA2, 0x02, 0x68,
+0xFF, 0x69, 0x4E, 0xE8, 0x8C, 0xE9, 0x24, 0x20,
+0x03, 0x5A, 0x03, 0x60, 0x01, 0x72, 0x07, 0x60,
+0x04, 0x10, 0x03, 0x72, 0x37, 0x60, 0x04, 0x72,
+0x50, 0x60, 0x01, 0x6A, 0x76, 0x10, 0x91, 0x67,
+0x00, 0x18, 0xA1, 0x35, 0x91, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0x25, 0x39, 0x65, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0x16, 0xF0, 0x80, 0x41, 0x84, 0x34,
+0x45, 0xF6, 0x18, 0x4B, 0x71, 0xE4, 0xA4, 0xA4,
+0x02, 0x5D, 0x03, 0x60, 0x01, 0x4D, 0xA4, 0xC4,
+0xED, 0x17, 0x65, 0xE1, 0x00, 0x6C, 0x50, 0x10,
+0x91, 0x67, 0x01, 0x6D, 0x00, 0x18, 0x53, 0x35,
+0x04, 0x93, 0x4C, 0xF0, 0x08, 0xC3, 0x91, 0x67,
+0x02, 0x6D, 0x00, 0x18, 0x25, 0x39, 0x48, 0x22,
+0x30, 0xF0, 0x20, 0x6B, 0x24, 0x34, 0x45, 0xF6,
+0x18, 0x4B, 0x6D, 0xE4, 0x2C, 0xF0, 0x85, 0xA3,
+0x0A, 0x5C, 0x3E, 0x60, 0x01, 0x4C, 0x2C, 0xF0,
+0x85, 0xC3, 0xED, 0x17, 0x91, 0x67, 0x00, 0x18,
+0xA1, 0x35, 0x91, 0x67, 0x01, 0x6D, 0x00, 0x18,
+0x83, 0x38, 0x32, 0x22, 0x03, 0x6C, 0x98, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x12, 0xEC, 0x71, 0xE4, 0x0C, 0xF0, 0xB9, 0xA4,
+0x02, 0x5D, 0x04, 0x60, 0x01, 0x4D, 0x0C, 0xF0,
+0xB9, 0xC4, 0xEB, 0x17, 0x65, 0xE1, 0x01, 0x6C,
+0x1B, 0x10, 0x91, 0x67, 0x00, 0x6D, 0x00, 0x18,
+0x53, 0x35, 0x91, 0x67, 0x02, 0x6D, 0x00, 0x18,
+0x83, 0x38, 0x16, 0x22, 0x03, 0x6C, 0x98, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x12, 0xEC, 0x71, 0xE4, 0x0C, 0xF0, 0xBA, 0xA4,
+0x02, 0x5D, 0x04, 0x60, 0x01, 0x4D, 0x0C, 0xF0,
+0xBA, 0xC4, 0xEB, 0x17, 0x65, 0xE1, 0x02, 0x6C,
+0x2C, 0xF0, 0x8C, 0xC1, 0x05, 0x6C, 0x07, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0xEB, 0xF6, 0x88, 0xA3, 0x01, 0x4C, 0xEB, 0xF6,
+0x88, 0xC3, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x21, 0x6A,
+0x31, 0xF5, 0x59, 0xA2, 0xFF, 0x69, 0x8C, 0xE9,
+0x02, 0x72, 0x02, 0x6A, 0x06, 0xD2, 0x02, 0x60,
+0x04, 0x6B, 0x06, 0xD3, 0x30, 0xF0, 0x21, 0x6A,
+0x51, 0xF5, 0xA1, 0xA2, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF6, 0x1C, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x21, 0x6A, 0x51, 0xF5, 0x41, 0xA2,
+0xFF, 0x6B, 0xFF, 0x4A, 0x6C, 0xEA, 0x06, 0x5A,
+0x74, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32,
+0x00, 0xF3, 0x00, 0x4B, 0x4D, 0xE3, 0x40, 0x9B,
+0x00, 0xEA, 0x00, 0x6C, 0x00, 0x18, 0x1E, 0x36,
+0x00, 0x6C, 0x04, 0x10, 0x01, 0x6C, 0x00, 0x18,
+0x1E, 0x36, 0x01, 0x6C, 0x00, 0x18, 0x06, 0x39,
+0x32, 0x10, 0x00, 0x6C, 0x00, 0x18, 0xE8, 0x35,
+0x00, 0x6C, 0xA4, 0x67, 0x00, 0x18, 0x83, 0x38,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0xEB, 0xF6, 0x90, 0xA3, 0x01, 0x4C, 0xEB, 0xF6,
+0x90, 0xC3, 0x21, 0x22, 0x0C, 0xF0, 0x58, 0xA3,
+0x03, 0x5A, 0x1D, 0x60, 0x01, 0x4A, 0x0C, 0xF0,
+0x58, 0xC3, 0x47, 0x10, 0x01, 0x6C, 0x00, 0x18,
+0xE8, 0x35, 0x01, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x83, 0x38, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0xEB, 0xF6, 0x90, 0xA3, 0x01, 0x4C,
+0xEB, 0xF6, 0x90, 0xC3, 0x08, 0x22, 0x0C, 0xF0,
+0x5B, 0xA3, 0x03, 0x5A, 0x04, 0x60, 0x01, 0x4A,
+0x0C, 0xF0, 0x5B, 0xC3, 0x2E, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xEB, 0xF6,
+0x69, 0xA2, 0x01, 0x4B, 0xEB, 0xF6, 0x69, 0xC2,
+0x24, 0x10, 0x00, 0x6C, 0x00, 0x18, 0x8E, 0x39,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xEB, 0xF6, 0x68, 0xA2, 0x05, 0x73, 0xF5, 0x61,
+0x0B, 0x10, 0x01, 0x6C, 0x00, 0x18, 0x8E, 0x39,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xEB, 0xF6, 0x68, 0xA2, 0x05, 0x73, 0xF5, 0x61,
+0xEB, 0xF6, 0x69, 0xA2, 0x01, 0x4B, 0xEB, 0xF6,
+0x69, 0xC2, 0x01, 0x6B, 0xEB, 0xF6, 0x68, 0xC2,
+0xEB, 0xF6, 0x70, 0xA2, 0x01, 0x4B, 0xEB, 0xF6,
+0x70, 0xC2, 0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6,
+0x18, 0x48, 0xEB, 0xF6, 0x49, 0xA0, 0x07, 0x72,
+0x6D, 0x61, 0xEB, 0xF6, 0xB2, 0xA0, 0xEB, 0xF6,
+0xD3, 0xA0, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF6,
+0x10, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0xEB, 0xF6,
+0xB8, 0xA0, 0xEB, 0xF6, 0xDA, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0xA1, 0xF6, 0x08, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0xEB, 0xF6, 0xB9, 0xA0, 0xEB, 0xF6,
+0xDB, 0xA0, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF6,
+0x1C, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x0C, 0xF0,
+0xB8, 0xA0, 0x0C, 0xF0, 0xDB, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF7, 0x10, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x0C, 0xF0, 0xB9, 0xA0, 0x0C, 0xF0,
+0xDA, 0xA0, 0x0C, 0xF0, 0xFC, 0xA0, 0x0C, 0xF0,
+0x5D, 0xA0, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF7,
+0x08, 0x4C, 0x04, 0xD2, 0x00, 0x18, 0x39, 0x3D,
+0x2C, 0xF0, 0xA5, 0xA0, 0x2C, 0xF0, 0xC6, 0xA0,
+0x2C, 0xF0, 0xE7, 0xA0, 0x2C, 0xF0, 0x48, 0xA0,
+0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF7, 0x0C, 0x4C,
+0x04, 0xD2, 0x00, 0x69, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x48, 0x9A,
+0x01, 0x68, 0x0B, 0xE8, 0x24, 0x36, 0x4D, 0xEE,
+0x03, 0xF3, 0x00, 0x6C, 0xB0, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x23, 0xF3, 0x0C, 0x6C, 0xB0, 0x67,
+0x07, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0xC3, 0xF3,
+0x0C, 0x6C, 0xB0, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xD8, 0x9A, 0x23, 0xF3, 0x18, 0x6C, 0xB0, 0x67,
+0x01, 0x49, 0x00, 0x18, 0x0E, 0x29, 0x02, 0x71,
+0xDB, 0x61, 0x09, 0x10, 0x01, 0x71, 0x1F, 0xF7,
+0x0B, 0x61, 0xEB, 0xF6, 0x50, 0xA0, 0x06, 0x93,
+0x6E, 0xEA, 0x1F, 0xF7, 0x05, 0x2A, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x04, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0xC8, 0x9A, 0x01, 0x68,
+0x0B, 0xE8, 0xB0, 0x67, 0x03, 0xF3, 0x00, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67, 0xA3, 0xF3,
+0x18, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x24, 0x9A,
+0x00, 0x6C, 0x01, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xD7, 0x28, 0x21, 0x68, 0xE2, 0x67, 0x0D, 0xEF,
+0xD1, 0x67, 0x00, 0x6C, 0x01, 0x6D, 0x00, 0x18,
+0x34, 0x29, 0x01, 0x6C, 0xA4, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0xD7, 0x28, 0xE2, 0x67, 0x01, 0x6C,
+0xA4, 0x67, 0xD1, 0x67, 0x0D, 0xEF, 0x00, 0x18,
+0x34, 0x29, 0x04, 0x94, 0x00, 0x18, 0xD9, 0x39,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x00, 0x6A, 0x7D, 0x67,
+0x4C, 0xCB, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x04, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x3C, 0x9A, 0x00, 0x6C, 0xA4, 0x67, 0xD0, 0x67,
+0xF1, 0x67, 0x00, 0x18, 0x34, 0x29, 0xF1, 0x67,
+0x01, 0x6C, 0x00, 0x6D, 0xD0, 0x67, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0xB0, 0x9A, 0xE1, 0xF0, 0x18, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0x6D, 0xE1, 0xF0,
+0x1C, 0x6C, 0xAB, 0xED, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x07, 0x6D, 0xC5, 0x67, 0x83, 0xF1,
+0x0C, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF3,
+0x18, 0x6F, 0x06, 0x02, 0xA1, 0xF7, 0x00, 0x6C,
+0x08, 0x6D, 0x00, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0xF3, 0x1D, 0x01, 0xF0, 0x08, 0x6C, 0xFF, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0xB4, 0x9A, 0x01, 0xF2,
+0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x70, 0x9A,
+0xFF, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0xFE, 0x6C,
+0x4C, 0xEC, 0x80, 0xC3, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x58, 0x9A, 0x60, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0x09, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x60, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x5C, 0x9A, 0x60, 0xDA,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x5F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1,
+0x04, 0x4A, 0xC0, 0x9A, 0x01, 0x68, 0x0B, 0xE8,
+0x61, 0xF4, 0x00, 0x69, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF1, 0x08, 0x4B, 0xC0, 0x9B, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x04, 0x4A, 0xC0, 0x9A,
+0x00, 0xF2, 0x00, 0x49, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF1, 0x08, 0x4B, 0xC0, 0x9B, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x2C, 0x9A, 0xB0, 0x67,
+0x41, 0xF4, 0x18, 0x6C, 0xD1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1,
+0x10, 0x4A, 0xC0, 0x9A, 0xB0, 0x67, 0x41, 0xF4,
+0x1C, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67,
+0x61, 0xF4, 0x0C, 0x6C, 0x01, 0xF2, 0x15, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67, 0xD1, 0x67,
+0x41, 0xF6, 0x18, 0x6C, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF1, 0x10, 0x4B,
+0xC0, 0x9B, 0xB0, 0x67, 0x41, 0xF6, 0x1C, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x61, 0xF6, 0x0C, 0x6C,
+0xB0, 0x67, 0x01, 0xF2, 0x15, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x00, 0x18, 0x85, 0x3A, 0x5C, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1, 0x04, 0x4A,
+0xC0, 0x9A, 0x01, 0x68, 0x0B, 0xE8, 0x61, 0xF4,
+0x00, 0x69, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF1,
+0x14, 0x4B, 0xC0, 0x9B, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF1, 0x04, 0x4A, 0xC0, 0x9A, 0x00, 0xF2,
+0x00, 0x49, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF1,
+0x14, 0x4B, 0xC0, 0x9B, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF1, 0x38, 0x9A, 0x41, 0xF4, 0x18, 0x6C,
+0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1, 0x1C, 0x4A,
+0xC0, 0x9A, 0x41, 0xF4, 0x1C, 0x6C, 0xB0, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x61, 0xF4, 0x0C, 0x6C,
+0xB0, 0x67, 0x22, 0xF2, 0x0A, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x41, 0xF6, 0x18, 0x6C, 0xB0, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF1, 0x1C, 0x4B, 0xC0, 0x9B,
+0x41, 0xF6, 0x1C, 0x6C, 0xB0, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x61, 0xF6, 0x0C, 0x6C, 0xB0, 0x67,
+0x22, 0xF2, 0x0A, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6, 0xB8, 0x9A,
+0xA1, 0xF1, 0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x08, 0x4A, 0xC0, 0x9A, 0x01, 0x69,
+0x03, 0xF3, 0x00, 0x68, 0x2B, 0xE9, 0xB1, 0x67,
+0x90, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x0A, 0x6C,
+0x00, 0x18, 0x7D, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0xC0, 0x9A, 0xB1, 0x67, 0x90, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x0A, 0x6C, 0x00, 0x18,
+0x7D, 0x1E, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0xC4, 0x9A, 0xB1, 0x67, 0x90, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x0A, 0x6C, 0x00, 0x18, 0x7D, 0x1E,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0, 0x08, 0x4B,
+0xC0, 0x9B, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x0C, 0xD6, 0xFF, 0x68, 0x81, 0xF0, 0xC4, 0x9A,
+0xFF, 0xF7, 0x1F, 0x69, 0x0C, 0x97, 0x8C, 0xE8,
+0xAC, 0xE9, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x34, 0x29, 0x00, 0x6A, 0x04, 0xD2, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF0, 0x04, 0x4B, 0xC0, 0x9B,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x18, 0xD7, 0x28,
+0x0C, 0x93, 0x6E, 0xEA, 0x13, 0x22, 0x0A, 0x6C,
+0x00, 0x18, 0x7D, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x04, 0x4A, 0xC0, 0x9A, 0x0C, 0x97,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x18, 0x34, 0x29,
+0x04, 0x93, 0x01, 0x4B, 0xE0, 0xF3, 0x08, 0x73,
+0x04, 0xD3, 0xE1, 0x61, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x00, 0x68, 0x0A, 0xD4, 0x0B, 0xD5, 0x04, 0xD5,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xC4, 0x9A,
+0x90, 0x67, 0xEF, 0x6D, 0x00, 0x6F, 0x00, 0x18,
+0x34, 0x29, 0x04, 0x93, 0x11, 0x6E, 0xCB, 0xEE,
+0x40, 0x9B, 0x90, 0x67, 0xDF, 0x6D, 0x4C, 0xEE,
+0x00, 0x18, 0x3F, 0x3B, 0x0B, 0x93, 0x08, 0x32,
+0x00, 0x69, 0x08, 0x4B, 0x49, 0xE3, 0x05, 0xD2,
+0x0A, 0x93, 0x90, 0x67, 0x29, 0xE3, 0xA1, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xC4, 0x9A,
+0x05, 0x92, 0x01, 0x49, 0xE0, 0x9A, 0x00, 0x18,
+0x34, 0x29, 0x05, 0x93, 0x04, 0x71, 0x08, 0x4B,
+0x05, 0xD3, 0xEE, 0x61, 0x04, 0x92, 0x01, 0x48,
+0x02, 0x70, 0x04, 0x4A, 0x04, 0xD2, 0xD0, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xEE, 0x63, 0x23, 0x62,
+0x22, 0xD1, 0x21, 0xD0, 0x28, 0xA4, 0x02, 0x6A,
+0x01, 0x68, 0x2C, 0xEA, 0x46, 0x32, 0x1E, 0xD2,
+0x00, 0x18, 0x05, 0x35, 0x00, 0x18, 0x6B, 0x37,
+0x91, 0x67, 0x0C, 0xEC, 0x00, 0x6D, 0x00, 0x18,
+0xDA, 0x36, 0x22, 0x67, 0x6D, 0x2A, 0x30, 0xF0,
+0x20, 0x6C, 0x02, 0xF0, 0x0C, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xEB, 0xF6, 0x62, 0xA2, 0x00, 0x6C,
+0xA4, 0x67, 0x01, 0x4B, 0xEB, 0xF6, 0x62, 0xC2,
+0xEB, 0xF6, 0x09, 0xC2, 0xEB, 0xF6, 0x08, 0xC2,
+0xEB, 0xF6, 0x30, 0xC2, 0xEB, 0xF6, 0x11, 0xC2,
+0x00, 0x18, 0xF2, 0x37, 0x30, 0xF0, 0x20, 0x6E,
+0x30, 0xF0, 0x20, 0x6F, 0x04, 0x04, 0x0F, 0x05,
+0x40, 0xF1, 0x00, 0x4E, 0x40, 0xF1, 0x08, 0x4F,
+0x00, 0x18, 0x9B, 0x37, 0x30, 0xF0, 0x20, 0x6D,
+0x05, 0x04, 0x60, 0xF1, 0x08, 0x4D, 0x00, 0x18,
+0x86, 0x37, 0x00, 0x18, 0x01, 0x34, 0x01, 0x6C,
+0x00, 0x18, 0xBB, 0x3A, 0x00, 0x6C, 0x00, 0x18,
+0xCD, 0x33, 0x00, 0x18, 0x23, 0x3B, 0x00, 0x18,
+0x0E, 0x37, 0x1E, 0x94, 0x00, 0x18, 0x66, 0x3A,
+0x00, 0x6C, 0x00, 0x18, 0xBB, 0x3A, 0x30, 0xF0,
+0x20, 0x6E, 0x30, 0xF0, 0x20, 0x6F, 0x04, 0x04,
+0x0F, 0x05, 0x40, 0xF1, 0x00, 0x4E, 0x40, 0xF1,
+0x08, 0x4F, 0x00, 0x18, 0x31, 0x34, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0xF1, 0x08, 0x4C, 0x05, 0x05,
+0x00, 0x18, 0x5C, 0x3B, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xEB, 0xF6, 0x69, 0xA2,
+0x07, 0x73, 0x07, 0x60, 0x00, 0x6B, 0xEB, 0xF6,
+0x70, 0xC2, 0x32, 0x6C, 0x00, 0x18, 0x75, 0x1E,
+0xCC, 0x17, 0x1E, 0x92, 0x04, 0x22, 0x00, 0x6C,
+0x01, 0x6D, 0x00, 0x18, 0xDA, 0x36, 0x00, 0x6C,
+0x00, 0x18, 0x4D, 0x34, 0x00, 0x18, 0x00, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xC4, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0xE8, 0x9A,
+0x00, 0x6C, 0x08, 0x6D, 0x00, 0x18, 0x34, 0x29,
+0x23, 0x97, 0x22, 0x91, 0x21, 0x90, 0x00, 0x6A,
+0x12, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x00, 0x6B, 0x83, 0xF5, 0x64, 0xC2,
+0x30, 0xF0, 0x20, 0x6B, 0xC9, 0xF3, 0x1C, 0x4B,
+0xA3, 0xF5, 0x68, 0xDA, 0x00, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF1, 0x6C, 0x9B, 0x54, 0x34,
+0x9F, 0x68, 0x71, 0xE4, 0xA0, 0xA4, 0xF8, 0x6B,
+0x01, 0x4A, 0xAC, 0xEB, 0x4E, 0xE8, 0x60, 0xC4,
+0xF2, 0x28, 0x00, 0x18, 0xE3, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF3, 0x11, 0xC2, 0x00, 0x18,
+0x0E, 0x33, 0x00, 0x18, 0x35, 0x51, 0x30, 0xF0,
+0x20, 0x6C, 0xC9, 0xF3, 0x00, 0x4C, 0x00, 0x18,
+0x76, 0x40, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0xD1,
+0x08, 0xD0, 0x0A, 0xD4, 0x44, 0x67, 0x82, 0x10,
+0x25, 0x73, 0x04, 0x60, 0x60, 0xA5, 0x60, 0xC2,
+0x01, 0x4A, 0x7B, 0x10, 0x61, 0x85, 0x62, 0x73,
+0x7D, 0x67, 0x20, 0x61, 0x62, 0x85, 0x78, 0x73,
+0x03, 0x60, 0x58, 0x73, 0x7D, 0x67, 0x1A, 0x61,
+0x82, 0x85, 0x60, 0xA6, 0x78, 0x6F, 0xEE, 0xEC,
+0x30, 0xF0, 0x20, 0x6F, 0x72, 0x30, 0x02, 0xF0,
+0x1C, 0x4F, 0xE1, 0xE0, 0x00, 0xA0, 0x01, 0x5C,
+0x98, 0x67, 0x94, 0x34, 0x8D, 0xE8, 0x3D, 0x67,
+0x00, 0xC1, 0x0F, 0x68, 0x6C, 0xE8, 0xFD, 0xE0,
+0x60, 0xA7, 0x02, 0x4D, 0x8D, 0xEB, 0x61, 0xC1,
+0x00, 0xF0, 0x02, 0x03, 0x81, 0x85, 0x77, 0x74,
+0x26, 0x61, 0x82, 0x85, 0x78, 0x74, 0x02, 0x60,
+0x58, 0x74, 0x21, 0x61, 0x80, 0xAE, 0x06, 0xD3,
+0x07, 0xD4, 0x82, 0x85, 0x78, 0x74, 0xF8, 0x67,
+0x01, 0x5F, 0x18, 0x67, 0x14, 0x30, 0x18, 0x65,
+0x0C, 0x6C, 0x07, 0x97, 0x0F, 0x68, 0x30, 0xF0,
+0x20, 0x69, 0xE7, 0xEC, 0x0C, 0xEF, 0x02, 0xF0,
+0x1C, 0x49, 0x3D, 0xE7, 0xE0, 0xA7, 0x06, 0x90,
+0x38, 0x67, 0x2D, 0xEF, 0xFC, 0x4C, 0xE0, 0xC0,
+0x01, 0x48, 0xE4, 0x44, 0x06, 0xD0, 0xED, 0x2F,
+0x04, 0x4B, 0x02, 0x4D, 0x25, 0x10, 0x81, 0x85,
+0x78, 0x74, 0x02, 0x60, 0x58, 0x74, 0x20, 0x61,
+0x81, 0x85, 0x20, 0x9E, 0x06, 0xD3, 0x78, 0x74,
+0x98, 0x67, 0x01, 0x5C, 0xF8, 0x67, 0xF4, 0x37,
+0x07, 0xD1, 0x1F, 0x65, 0x1C, 0x6C, 0x07, 0x97,
+0x0F, 0x68, 0x30, 0xF0, 0x20, 0x69, 0xE6, 0xEC,
+0x0C, 0xEF, 0x02, 0xF0, 0x1C, 0x49, 0x3D, 0xE7,
+0xE0, 0xA7, 0x06, 0x91, 0x18, 0x67, 0x0D, 0xEF,
+0xFC, 0x4C, 0xE0, 0xC1, 0x01, 0x49, 0xE4, 0x44,
+0x06, 0xD1, 0xED, 0x2F, 0x08, 0x4B, 0x01, 0x4D,
+0x9D, 0x67, 0x04, 0x10, 0xE0, 0xA4, 0x01, 0x4C,
+0xE0, 0xC2, 0x01, 0x4A, 0x63, 0xEC, 0xFA, 0x61,
+0x04, 0x4E, 0x01, 0x4D, 0x60, 0x85, 0x7F, 0xF7,
+0x1B, 0x2B, 0x0A, 0x94, 0x01, 0x24, 0x60, 0xC2,
+0x0A, 0x97, 0x09, 0x91, 0x08, 0x90, 0xEB, 0xE2,
+0x05, 0x63, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0x6B, 0x45, 0xF6, 0x18, 0x4A, 0x6B, 0xEB,
+0x48, 0xF5, 0x61, 0xC2, 0x48, 0xF5, 0x62, 0xC2,
+0x48, 0xF5, 0x63, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x68, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x83, 0xF5, 0x6D, 0xC2, 0x69, 0xA4,
+0x83, 0xF5, 0x62, 0xC2, 0x6A, 0xA4, 0x83, 0xF5,
+0x6C, 0xC2, 0xAB, 0xA4, 0x0F, 0x6B, 0xAC, 0xEB,
+0x83, 0xF5, 0x74, 0xC2, 0x6B, 0xA4, 0x72, 0x33,
+0x83, 0xF5, 0x73, 0xC2, 0x00, 0x6A, 0x20, 0xE8,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x83, 0xF5, 0x6D, 0xC2, 0x61, 0xA4,
+0x83, 0xF5, 0x62, 0xC2, 0x62, 0xA4, 0x83, 0xF5,
+0x6C, 0xC2, 0xA3, 0xA4, 0x0F, 0x6B, 0xAC, 0xEB,
+0x83, 0xF5, 0x74, 0xC2, 0x63, 0xA4, 0x72, 0x33,
+0x83, 0xF5, 0x73, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x0F, 0x72, 0x08, 0x60, 0x11, 0x72, 0x0A, 0x60,
+0x0E, 0x72, 0x0C, 0x61, 0x85, 0x67, 0x00, 0x18,
+0x7B, 0x3B, 0x1D, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x8C, 0x34, 0x19, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x30, 0x3C, 0x15, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xE0, 0xF6, 0x90, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x83, 0xF3, 0x64, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x64, 0xDA, 0xFF, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x42, 0xA4, 0x00, 0xA4,
+0x21, 0xA4, 0x0A, 0xD2, 0x63, 0xA4, 0x00, 0xF0,
+0x16, 0x02, 0x20, 0xF0, 0x02, 0x04, 0x00, 0x6D,
+0xA0, 0xC2, 0x01, 0x4A, 0x8A, 0xEA, 0xFB, 0x61,
+0x01, 0x6A, 0x6C, 0xEA, 0x10, 0x22, 0x04, 0x04,
+0x00, 0xF0, 0x11, 0x05, 0x00, 0x18, 0x09, 0x33,
+0x7D, 0x67, 0x50, 0xA3, 0x01, 0x6C, 0x96, 0xC3,
+0x57, 0xC3, 0x51, 0xA3, 0x58, 0xC3, 0x26, 0x6A,
+0x54, 0xC3, 0x03, 0x6A, 0x51, 0xCB, 0x0A, 0x93,
+0x01, 0x6A, 0x4C, 0xEB, 0x1C, 0x23, 0xA0, 0x58,
+0x1A, 0x61, 0xA0, 0x59, 0x18, 0x61, 0xBD, 0x67,
+0x56, 0xC5, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x2B, 0xF1, 0x6C, 0x9A, 0x62, 0x34,
+0x77, 0xC5, 0x00, 0xF6, 0x62, 0x33, 0x7A, 0xC5,
+0x0D, 0x6B, 0x74, 0xC5, 0x05, 0x6B, 0x98, 0xC5,
+0x71, 0xCD, 0x82, 0x34, 0x00, 0x6B, 0x99, 0xC5,
+0x2B, 0xF1, 0x6C, 0xDA, 0xE2, 0x10, 0x0A, 0x92,
+0x02, 0x6C, 0x8C, 0xEA, 0x3B, 0x22, 0xDD, 0x67,
+0xA0, 0x58, 0x96, 0xC6, 0x18, 0x60, 0x35, 0xF5,
+0x64, 0x40, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x64, 0x33, 0x4D, 0xE3, 0x83, 0xAB,
+0x85, 0xF4, 0x14, 0x48, 0x04, 0x30, 0x49, 0xE0,
+0x97, 0xC6, 0x82, 0x34, 0x98, 0xC6, 0x84, 0xAA,
+0x99, 0xC6, 0x82, 0x34, 0x9A, 0xC6, 0x00, 0x6C,
+0x83, 0xCB, 0x84, 0xCA, 0x04, 0x10, 0x16, 0x6A,
+0x4B, 0xEA, 0x7D, 0x67, 0x57, 0xC3, 0xA0, 0x59,
+0x57, 0x60, 0x35, 0xF5, 0x64, 0x41, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x64, 0x33,
+0x4D, 0xE3, 0x83, 0xAB, 0x85, 0xF4, 0x14, 0x49,
+0xBD, 0x67, 0x24, 0x31, 0x49, 0xE1, 0x9B, 0xC5,
+0x82, 0x34, 0x9C, 0xC5, 0x84, 0xAA, 0x9D, 0xC5,
+0x82, 0x34, 0x9E, 0xC5, 0x00, 0x6C, 0x83, 0xCB,
+0x84, 0xCA, 0x42, 0x10, 0x0A, 0x95, 0x08, 0x6B,
+0xAC, 0xEB, 0x43, 0x23, 0xDD, 0x67, 0xA0, 0x58,
+0x96, 0xC6, 0x17, 0x60, 0x35, 0xF5, 0x84, 0x40,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x84, 0x34, 0x71, 0xE4, 0xA3, 0xAC, 0xC5, 0xF5,
+0x14, 0x48, 0x04, 0x30, 0x6D, 0xE0, 0xB7, 0xC6,
+0xA2, 0x35, 0xB8, 0xC6, 0xA2, 0xAB, 0x43, 0xCC,
+0x42, 0xCB, 0xB9, 0xC6, 0xA2, 0x35, 0xBA, 0xC6,
+0x04, 0x10, 0x16, 0x6A, 0x4B, 0xEA, 0x7D, 0x67,
+0x57, 0xC3, 0xA0, 0x59, 0x19, 0x60, 0x35, 0xF5,
+0x64, 0x41, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x64, 0x33, 0x4D, 0xE3, 0x83, 0xAB,
+0xC5, 0xF5, 0x14, 0x49, 0xBD, 0x67, 0x24, 0x31,
+0x49, 0xE1, 0x9B, 0xC5, 0x82, 0x34, 0x9C, 0xC5,
+0x82, 0xAA, 0x9D, 0xC5, 0x82, 0x34, 0x9E, 0xC5,
+0x00, 0x6C, 0x83, 0xCB, 0x82, 0xCA, 0x04, 0x10,
+0x16, 0x6A, 0x4B, 0xEA, 0xDD, 0x67, 0x5B, 0xC6,
+0x0D, 0x6A, 0x7D, 0x67, 0x54, 0xC3, 0x09, 0x6A,
+0x56, 0x10, 0x0A, 0x94, 0x56, 0x2C, 0xA0, 0x58,
+0x24, 0x60, 0x55, 0xF3, 0x64, 0x40, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x64, 0x33,
+0x4D, 0xE3, 0x84, 0xAB, 0xBD, 0x67, 0x16, 0xC5,
+0x97, 0xC5, 0x82, 0x34, 0x98, 0xC5, 0xF5, 0xF3,
+0x84, 0x40, 0x84, 0x34, 0x49, 0xE4, 0x83, 0xAA,
+0x14, 0x30, 0xC7, 0x45, 0x99, 0xC5, 0x82, 0x34,
+0x9A, 0xC5, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF1,
+0x90, 0x9C, 0x21, 0x4E, 0xC0, 0xAE, 0x81, 0xE0,
+0x80, 0xA0, 0xC4, 0xCB, 0xC3, 0xCA, 0x9B, 0xC5,
+0x02, 0x10, 0x9D, 0x67, 0x16, 0xC4, 0xA0, 0x59,
+0x24, 0x60, 0x55, 0xF3, 0x64, 0x41, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x64, 0x33,
+0x4D, 0xE3, 0x84, 0xAB, 0xBD, 0x67, 0x3C, 0xC5,
+0x9D, 0xC5, 0x82, 0x34, 0x9E, 0xC5, 0xF5, 0xF3,
+0x84, 0x41, 0x84, 0x34, 0x49, 0xE4, 0x83, 0xAA,
+0x34, 0x31, 0x9F, 0xC5, 0x82, 0x34, 0x20, 0xF0,
+0x80, 0xC5, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF1,
+0x90, 0x9C, 0x85, 0xE1, 0x80, 0xA1, 0x20, 0xF0,
+0x81, 0xC5, 0x00, 0x6C, 0x84, 0xCB, 0x83, 0xCA,
+0x02, 0x10, 0x5D, 0x67, 0x3C, 0xC2, 0x04, 0x6A,
+0x7D, 0x67, 0x54, 0xC3, 0x0C, 0x6A, 0x51, 0xCB,
+0x04, 0x10, 0x9D, 0x67, 0x04, 0x6A, 0x54, 0xC4,
+0x71, 0xCC, 0x05, 0x04, 0x00, 0x18, 0xF3, 0x1F,
+0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x00, 0x6A, 0x10, 0xD4,
+0x01, 0x68, 0x62, 0x67, 0xA0, 0xA4, 0x0E, 0x25,
+0xFF, 0x6D, 0x01, 0x4B, 0xAC, 0xEB, 0x01, 0x4A,
+0x0B, 0x73, 0xAC, 0xEA, 0x03, 0x61, 0x01, 0x48,
+0xAC, 0xE8, 0x00, 0x6B, 0x37, 0x72, 0x01, 0x4C,
+0xF1, 0x61, 0x37, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x48, 0xF5, 0x84, 0xA3,
+0x0F, 0x5C, 0x01, 0x4C, 0x01, 0x61, 0x00, 0x6C,
+0x48, 0xF5, 0x84, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0x8E, 0xF3, 0x7C, 0xA3, 0x0B, 0x6D, 0x2F, 0x40,
+0x70, 0x33, 0x0A, 0xD3, 0x0A, 0x94, 0xFF, 0x6B,
+0x6C, 0xE9, 0x6C, 0xEC, 0x0A, 0xD4, 0x01, 0x6C,
+0x13, 0xE4, 0xB8, 0xEC, 0x12, 0xEC, 0x91, 0xE2,
+0x6C, 0xEC, 0x09, 0xD4, 0x00, 0x6A, 0x01, 0x4C,
+0x0B, 0xD4, 0x08, 0xD2, 0x3C, 0x10, 0x08, 0x94,
+0x0B, 0x6B, 0x0A, 0x95, 0x78, 0xEC, 0x9D, 0x67,
+0x12, 0xEB, 0x4C, 0xEB, 0x0F, 0x6A, 0x2C, 0xEA,
+0xAD, 0xEA, 0x08, 0x95, 0x52, 0xC4, 0x4F, 0x40,
+0xAE, 0xEA, 0x07, 0x22, 0x10, 0x92, 0x00, 0xF0,
+0x1E, 0x04, 0x6D, 0xE2, 0x00, 0xF0, 0x13, 0x02,
+0x0F, 0x10, 0x10, 0x94, 0x09, 0x95, 0x00, 0xF0,
+0x13, 0x02, 0x6D, 0xE4, 0xB1, 0xE2, 0x04, 0x10,
+0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2, 0x01, 0x4A,
+0x8A, 0xEA, 0xFA, 0x61, 0x0B, 0x92, 0x07, 0x10,
+0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2, 0x01, 0x4A,
+0x8A, 0xEA, 0xFA, 0x61, 0x0C, 0x6A, 0x9D, 0x67,
+0x00, 0x6B, 0x4F, 0xCC, 0x70, 0xC4, 0x05, 0x95,
+0x04, 0x94, 0x06, 0x96, 0x07, 0x97, 0xFF, 0x49,
+0x00, 0x18, 0xAA, 0x33, 0x08, 0x95, 0xFF, 0x6A,
+0x4C, 0xE9, 0x01, 0x4D, 0x08, 0xD5, 0x08, 0x93,
+0xFF, 0x6A, 0x4C, 0xEB, 0x03, 0xEB, 0xBF, 0x61,
+0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF1, 0x54, 0x9A, 0x8E, 0xF3,
+0x7C, 0x9B, 0x07, 0xD5, 0x08, 0xD6, 0x6C, 0xEA,
+0x00, 0xF1, 0x00, 0x72, 0x09, 0xD7, 0x06, 0xD4,
+0x0C, 0x61, 0x30, 0xF0, 0x21, 0x68, 0x06, 0x95,
+0xB2, 0xF6, 0x0C, 0x48, 0x90, 0x67, 0x07, 0x06,
+0x00, 0x18, 0xDF, 0x3B, 0x90, 0x67, 0x00, 0x18,
+0xF7, 0x3C, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0xEB, 0xF4, 0x7B, 0xC2, 0xA1, 0xA4,
+0x03, 0x73, 0xEB, 0xF4, 0xBC, 0xC2, 0x1F, 0x61,
+0x62, 0xA4, 0xEB, 0xF4, 0x78, 0xC2, 0x63, 0xA4,
+0xEB, 0xF4, 0x79, 0xC2, 0x64, 0xA4, 0x04, 0x6C,
+0xEB, 0xF4, 0x7A, 0xC2, 0x63, 0xF5, 0x78, 0x9A,
+0x8C, 0xEB, 0x30, 0x23, 0x63, 0xF5, 0x7C, 0x9A,
+0x05, 0x5B, 0x2C, 0x61, 0xEB, 0xF4, 0xB8, 0xA2,
+0xEB, 0xF4, 0xD9, 0xA2, 0xEB, 0xF4, 0xFA, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF0, 0x10, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x1F, 0x10, 0x02, 0x73,
+0x1D, 0x61, 0x62, 0xA4, 0xEB, 0xF4, 0x78, 0xC2,
+0x63, 0xA4, 0x04, 0x6C, 0xEB, 0xF4, 0x79, 0xC2,
+0x01, 0x6B, 0x6B, 0xEB, 0xEB, 0xF4, 0x7A, 0xC2,
+0x63, 0xF5, 0x78, 0x9A, 0x8C, 0xEB, 0x0E, 0x23,
+0x63, 0xF5, 0x7C, 0x9A, 0x05, 0x5B, 0x0A, 0x61,
+0xEB, 0xF4, 0xB8, 0xA2, 0xEB, 0xF4, 0xD9, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF0, 0x00, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A,
+0x05, 0x97, 0x45, 0xF6, 0x18, 0x4A, 0x01, 0x6B,
+0xEB, 0xF4, 0x7E, 0xC2, 0x00, 0x6B, 0xEB, 0xF4,
+0x7D, 0xC2, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF3, 0x63, 0x19, 0x62, 0x18, 0xD1, 0x17, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x15, 0xD2, 0x40, 0xF0,
+0x06, 0x03, 0x20, 0xF0, 0x1A, 0x02, 0x00, 0x6C,
+0x80, 0xC2, 0x01, 0x4A, 0x6A, 0xEA, 0xFB, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x8E, 0xF3, 0x19, 0x4B,
+0x00, 0x68, 0x12, 0xD3, 0x14, 0xD0, 0x70, 0x10,
+0x12, 0x92, 0x40, 0xA2, 0xFF, 0x72, 0x13, 0xD2,
+0x0A, 0x61, 0x7D, 0x67, 0x09, 0xE3, 0x01, 0x6B,
+0x6B, 0xEB, 0x20, 0xF0, 0x7A, 0xC2, 0x01, 0x48,
+0xFF, 0x6A, 0x4C, 0xE8, 0x65, 0x10, 0x13, 0x92,
+0x2E, 0x69, 0x9D, 0x67, 0x38, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x0E, 0x03,
+0x0D, 0xE3, 0x04, 0x48, 0x12, 0xE9, 0x25, 0xE2,
+0x47, 0x44, 0x45, 0x4A, 0x80, 0xA2, 0x82, 0xC3,
+0x59, 0xA1, 0x03, 0x6C, 0x43, 0xC3, 0x43, 0xA1,
+0x44, 0xC3, 0x51, 0xA1, 0x4A, 0x32, 0x8C, 0xEA,
+0x45, 0xC3, 0xFF, 0x6B, 0x6C, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x63, 0xF5,
+0xB8, 0x9B, 0xE7, 0xF7, 0x1D, 0x4C, 0xAC, 0xEC,
+0x0E, 0x24, 0x63, 0xF5, 0x7C, 0x9B, 0x05, 0x5B,
+0x0A, 0x61, 0xD9, 0xA1, 0xE3, 0xA1, 0x13, 0x95,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF0, 0x10, 0x4C,
+0x04, 0xD2, 0x00, 0x18, 0x39, 0x3D, 0x15, 0x92,
+0x02, 0x6B, 0x6E, 0xEA, 0x21, 0x2A, 0x95, 0xA9,
+0x0E, 0x03, 0x0D, 0xE3, 0x82, 0xC3, 0x95, 0xA9,
+0x02, 0x48, 0x82, 0x34, 0x83, 0xC3, 0x55, 0xC9,
+0xFF, 0x6A, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x98, 0x9A,
+0x08, 0xF0, 0x00, 0x6B, 0x8C, 0xEB, 0x0C, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61,
+0x13, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF0,
+0x14, 0x4C, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x3D,
+0x14, 0x94, 0xFF, 0x6A, 0x01, 0x4C, 0x4C, 0xEC,
+0x12, 0x92, 0x14, 0xD4, 0x01, 0x4A, 0x12, 0xD2,
+0x14, 0x93, 0x15, 0x94, 0x83, 0xEB, 0x8C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x98, 0x9A, 0x08, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x2D, 0x23, 0x63, 0xF5, 0x5C, 0x9A,
+0x05, 0x5A, 0x29, 0x61, 0x5D, 0x67, 0x20, 0xF0,
+0xBA, 0xA2, 0x20, 0xF0, 0xDB, 0xA2, 0x20, 0xF0,
+0xFC, 0xA2, 0x20, 0xF0, 0x5D, 0xA2, 0x7D, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0x04, 0xD2, 0x20, 0xF0,
+0x5E, 0xA3, 0xC2, 0xF0, 0x0C, 0x4C, 0x05, 0xD2,
+0x20, 0xF0, 0x5F, 0xA3, 0x06, 0xD2, 0x40, 0xF0,
+0x40, 0xA3, 0x07, 0xD2, 0x40, 0xF0, 0x41, 0xA3,
+0x08, 0xD2, 0x40, 0xF0, 0x42, 0xA3, 0x09, 0xD2,
+0x40, 0xF0, 0x43, 0xA3, 0x0A, 0xD2, 0x40, 0xF0,
+0x44, 0xA3, 0x0B, 0xD2, 0x40, 0xF0, 0x45, 0xA3,
+0x0C, 0xD2, 0x00, 0x18, 0x39, 0x3D, 0x9D, 0x67,
+0x2C, 0x6A, 0x20, 0xF0, 0x58, 0xC4, 0x40, 0xF0,
+0x06, 0xCC, 0x0E, 0x04, 0x00, 0x18, 0xF3, 0x1F,
+0x19, 0x97, 0x18, 0x91, 0x17, 0x90, 0x0D, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x43, 0xA4, 0x62, 0xA4,
+0xC0, 0xA4, 0x40, 0x32, 0x40, 0x32, 0x60, 0x33,
+0x4D, 0xE3, 0x41, 0xA4, 0x0F, 0x6D, 0xCC, 0xED,
+0x4D, 0xE3, 0x44, 0xA4, 0xD2, 0x36, 0x01, 0x5E,
+0x00, 0xF6, 0x40, 0x32, 0x49, 0xE3, 0x08, 0xD2,
+0xB4, 0x32, 0x06, 0xD2, 0x06, 0x93, 0xFF, 0x6A,
+0x4C, 0xEB, 0x06, 0xD3, 0x03, 0x6A, 0x78, 0x67,
+0x6F, 0xE2, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x98, 0x9A, 0x07, 0xD3,
+0x08, 0xF0, 0x00, 0x6B, 0x8C, 0xEB, 0x0B, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61,
+0x08, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF1,
+0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x00, 0x18,
+0x29, 0x3C, 0x00, 0x68, 0x06, 0x91, 0x4E, 0x10,
+0x08, 0x94, 0x01, 0x6A, 0x44, 0xE9, 0x8C, 0xEA,
+0x1C, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x4D, 0xE0, 0x48, 0xF5, 0x21, 0xC3,
+0x63, 0xF5, 0x98, 0x9A, 0xFF, 0x6B, 0x01, 0x48,
+0x6C, 0xE8, 0x07, 0xF7, 0x01, 0x4B, 0x8C, 0xEB,
+0x0C, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF1,
+0x10, 0x4C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x07, 0x92, 0x4A, 0xE8, 0x04, 0x60,
+0x06, 0x92, 0x1F, 0x4A, 0x2E, 0xEA, 0x23, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x98, 0x9A, 0x08, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x12, 0x23, 0x63, 0xF5, 0x7C, 0x9A,
+0x05, 0x5B, 0x0E, 0x61, 0x48, 0xF5, 0xC1, 0xA2,
+0x48, 0xF5, 0xE2, 0xA2, 0x48, 0xF5, 0x43, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x42, 0xF1, 0x10, 0x4C,
+0xB0, 0x67, 0x04, 0xD2, 0x00, 0x18, 0x39, 0x3D,
+0x0D, 0x20, 0x07, 0x94, 0x00, 0x68, 0x00, 0x18,
+0x78, 0x3D, 0x00, 0x18, 0x29, 0x3C, 0x01, 0x49,
+0xFF, 0x6A, 0x4C, 0xE9, 0x06, 0x92, 0x20, 0x4A,
+0x42, 0xE9, 0xAE, 0x61, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF6, 0x63, 0x13, 0x62, 0x12, 0xD1, 0x11, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x8C, 0xEA,
+0xA0, 0xF3, 0x8C, 0x9B, 0xA0, 0xF3, 0x0C, 0x4B,
+0x01, 0x72, 0x04, 0xD4, 0x81, 0x9B, 0x68, 0xA3,
+0x05, 0xD4, 0x9D, 0x67, 0x78, 0xC4, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF3, 0x80, 0x9B, 0xA0, 0xF3,
+0x00, 0x4B, 0x07, 0xD4, 0x81, 0x9B, 0x68, 0xA3,
+0x08, 0xD4, 0x9D, 0x67, 0x20, 0xF0, 0x64, 0xC4,
+0x20, 0x61, 0x00, 0x68, 0x5D, 0x67, 0x0D, 0xE2,
+0x5C, 0xA3, 0x0B, 0x5A, 0x01, 0x61, 0x0A, 0x6A,
+0xFF, 0x6B, 0x6C, 0xEA, 0x02, 0x4A, 0x7D, 0x67,
+0x5B, 0xCB, 0x0E, 0x6A, 0x20, 0xF0, 0x48, 0xC3,
+0x01, 0x6A, 0x20, 0xF0, 0x4A, 0xC3, 0x09, 0xE3,
+0x50, 0xA2, 0x0B, 0x95, 0x0C, 0x96, 0x20, 0xF0,
+0x4B, 0xC3, 0x0A, 0x94, 0x0D, 0x97, 0x01, 0x48,
+0x00, 0x18, 0xAA, 0x33, 0x09, 0x70, 0xE2, 0x61,
+0x71, 0x10, 0x08, 0x72, 0x37, 0x61, 0x20, 0xF0,
+0x05, 0x04, 0x07, 0x00, 0x04, 0x01, 0x0E, 0xD4,
+0x40, 0xA0, 0x0B, 0x5A, 0x01, 0x61, 0x0A, 0x6A,
+0xFF, 0x6B, 0x4C, 0xEB, 0x9D, 0x67, 0x42, 0x43,
+0x5B, 0xCC, 0x0E, 0x6A, 0x20, 0xF0, 0x48, 0xC4,
+0x08, 0x6A, 0x20, 0xF0, 0x4A, 0xC4, 0x40, 0xA1,
+0x20, 0xF0, 0x4B, 0xC4, 0x00, 0x6A, 0x0E, 0x10,
+0x9D, 0x67, 0x55, 0xE4, 0xC0, 0xA1, 0x30, 0xF0,
+0x20, 0x6C, 0x45, 0xF6, 0x18, 0x4C, 0x91, 0xE2,
+0xD1, 0xE4, 0x28, 0xF3, 0x96, 0xA4, 0x01, 0x4A,
+0x20, 0xF0, 0x8C, 0xC5, 0xFF, 0x6C, 0x4C, 0xEC,
+0x63, 0xEC, 0xEE, 0x61, 0x0A, 0x94, 0x0B, 0x95,
+0x0C, 0x96, 0x0D, 0x97, 0x01, 0x48, 0x01, 0x49,
+0x00, 0x18, 0xAA, 0x33, 0x0E, 0x92, 0x4A, 0xE8,
+0xCF, 0x61, 0x38, 0x10, 0x09, 0x72, 0x36, 0x61,
+0x20, 0xF0, 0x05, 0x03, 0x07, 0x00, 0x04, 0x01,
+0x0F, 0xD3, 0x40, 0xA0, 0x0B, 0x5A, 0x01, 0x61,
+0x0A, 0x6A, 0xFF, 0x6B, 0x4C, 0xEB, 0x9D, 0x67,
+0x42, 0x43, 0x5B, 0xCC, 0x0E, 0x6A, 0x20, 0xF0,
+0x48, 0xC4, 0x09, 0x6A, 0x20, 0xF0, 0x4A, 0xC4,
+0x40, 0xA1, 0x20, 0xF0, 0x4B, 0xC4, 0x00, 0x6A,
+0x0E, 0x10, 0x9D, 0x67, 0x55, 0xE4, 0xC0, 0xA1,
+0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6, 0x18, 0x4C,
+0x91, 0xE2, 0xD1, 0xE4, 0x88, 0xF3, 0x8A, 0xA4,
+0x01, 0x4A, 0x20, 0xF0, 0x8C, 0xC5, 0xFF, 0x6C,
+0x4C, 0xEC, 0x63, 0xEC, 0xEE, 0x61, 0x0A, 0x94,
+0x0B, 0x95, 0x0C, 0x96, 0x0D, 0x97, 0x01, 0x48,
+0x01, 0x49, 0x00, 0x18, 0xAA, 0x33, 0x0F, 0x92,
+0x4A, 0xE8, 0xCF, 0x61, 0x13, 0x97, 0x12, 0x91,
+0x11, 0x90, 0x0A, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x44, 0x67, 0x65, 0xA2, 0x02, 0x6D, 0x81, 0xA4,
+0xAC, 0xEB, 0x03, 0x23, 0x00, 0x18, 0x2A, 0x3E,
+0x3D, 0x10, 0x01, 0x74, 0x22, 0xA2, 0x04, 0xA2,
+0x43, 0xA2, 0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x62, 0xF1, 0x18, 0x4C, 0x00, 0x18, 0xF7, 0x3C,
+0x31, 0x10, 0x10, 0x30, 0x08, 0x74, 0x4D, 0xE8,
+0x0E, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF1,
+0x04, 0x4C, 0x00, 0x18, 0xF7, 0x3C, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x45, 0xE1,
+0x28, 0xF3, 0x16, 0xC1, 0x1F, 0x10, 0x09, 0x74,
+0x0E, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF1,
+0x04, 0x4C, 0x00, 0x18, 0xF7, 0x3C, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x45, 0xE1,
+0x88, 0xF3, 0x0A, 0xC1, 0x0F, 0x10, 0x0A, 0x74,
+0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0xF8, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF1,
+0x14, 0x4C, 0xF9, 0x6D, 0x28, 0xF3, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x3D, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x2E, 0x6B, 0x78, 0xEC, 0x30, 0xF0, 0x20, 0x6E,
+0x89, 0xF7, 0x18, 0x4E, 0xAC, 0xEA, 0x05, 0x6D,
+0x12, 0xEB, 0x6D, 0xE6, 0xDD, 0x67, 0xAF, 0xCE,
+0x0F, 0x6D, 0xB0, 0xC6, 0x92, 0xC6, 0x53, 0xC6,
+0x20, 0xF0, 0x44, 0xA3, 0x07, 0x97, 0x04, 0x94,
+0x54, 0xC6, 0x20, 0xF0, 0x45, 0xA3, 0x55, 0xC6,
+0x20, 0xF0, 0x46, 0xA3, 0x56, 0xC6, 0x05, 0x95,
+0x06, 0x96, 0x00, 0x18, 0xAA, 0x33, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x14, 0x92, 0x15, 0x93,
+0x16, 0x90, 0x0A, 0xD2, 0xFF, 0x6A, 0x1A, 0x65,
+0xAC, 0xEA, 0x08, 0xD2, 0x58, 0x67, 0xCC, 0xEA,
+0x17, 0x91, 0x1A, 0x65, 0x0A, 0x92, 0xFF, 0xF7,
+0x1F, 0x6D, 0xAC, 0xEF, 0xAC, 0xEA, 0xAC, 0xEB,
+0xAC, 0xE8, 0xAC, 0xE9, 0x30, 0xF0, 0x20, 0x6D,
+0x45, 0xF6, 0x18, 0x4D, 0x63, 0xF5, 0xD8, 0x9D,
+0x0A, 0xD2, 0x8C, 0xEE, 0x36, 0x26, 0x63, 0xF5,
+0x9C, 0x9D, 0x05, 0x6A, 0x4E, 0xEC, 0x31, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF1, 0x94, 0x9C,
+0x48, 0xF5, 0xA4, 0x9D, 0x7F, 0x4A, 0x7C, 0x4A,
+0xAC, 0xEC, 0x4E, 0xEC, 0x26, 0x2C, 0x9D, 0x67,
+0x47, 0x44, 0x19, 0x4A, 0x40, 0xA2, 0xF4, 0xC4,
+0xE2, 0x37, 0x52, 0xC4, 0x58, 0x67, 0x53, 0xC4,
+0x47, 0x44, 0x21, 0x4A, 0x40, 0xA2, 0xF5, 0xC4,
+0x56, 0xC4, 0x0A, 0x94, 0x82, 0x32, 0x9D, 0x67,
+0x57, 0xC4, 0x02, 0x6A, 0x4B, 0xEA, 0x78, 0xC4,
+0x1A, 0xC4, 0x3C, 0xC4, 0x50, 0xC4, 0x62, 0x33,
+0x02, 0x30, 0x22, 0x31, 0x0C, 0x6A, 0x79, 0xC4,
+0x1B, 0xC4, 0x3D, 0xC4, 0x4F, 0xCC, 0x05, 0x95,
+0x04, 0x94, 0x06, 0x96, 0x07, 0x97, 0x00, 0x18,
+0xAA, 0x33, 0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90,
+0x08, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xA4, 0x21, 0xF1,
+0x5C, 0x9A, 0x6C, 0x35, 0x49, 0xE5, 0xA3, 0xA4,
+0xA0, 0xC2, 0x84, 0xA4, 0xA1, 0x42, 0x80, 0xC5,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF1, 0x80, 0x9C,
+0x40, 0x9A, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0xA9, 0xF3, 0x93, 0xA4, 0x03, 0x5C, 0x11, 0x60,
+0x25, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x44, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x68, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x40, 0x9A, 0x60, 0xDA,
+0xF0, 0x17, 0x03, 0x74, 0x13, 0x61, 0x00, 0xF4,
+0x00, 0x5A, 0x10, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x44, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x6C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x40, 0x9A,
+0x60, 0xDA, 0xF0, 0x17, 0x83, 0x67, 0x00, 0x18,
+0x67, 0x4F, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x20, 0xA4, 0x2E, 0x68, 0x30, 0xF0, 0x20, 0x6A,
+0x18, 0xE9, 0x89, 0xF7, 0x18, 0x4A, 0x62, 0xA4,
+0x08, 0x6D, 0x6C, 0xED, 0x7E, 0x33, 0x7C, 0x33,
+0x12, 0xE8, 0x01, 0xE2, 0xD1, 0xA0, 0x7F, 0x6A,
+0xCC, 0xEA, 0x6D, 0xEA, 0x51, 0xC0, 0xC2, 0xA4,
+0x40, 0x6B, 0x6C, 0xEE, 0x80, 0x4B, 0xFF, 0x4B,
+0x4C, 0xEB, 0xCD, 0xEB, 0x71, 0xC0, 0xC1, 0xA4,
+0x1F, 0x6A, 0xCC, 0xEA, 0x44, 0xC0, 0xE2, 0xA4,
+0x04, 0x6A, 0x03, 0x6E, 0x4B, 0xEA, 0xCC, 0xEF,
+0x6C, 0xEA, 0xED, 0xEA, 0x51, 0xC0, 0x08, 0x2D,
+0x62, 0xA4, 0x6C, 0xEE, 0x0D, 0x6B, 0x6B, 0xEB,
+0xC8, 0x36, 0x4C, 0xEB, 0xCD, 0xEB, 0x71, 0xC0,
+0x61, 0xA4, 0xB2, 0xA0, 0x05, 0x6A, 0x7E, 0x33,
+0x4B, 0xEA, 0x68, 0x33, 0xAC, 0xEA, 0x6D, 0xEA,
+0x52, 0xC0, 0x41, 0xA4, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x60, 0x6D, 0x28, 0xF4,
+0xD5, 0xA3, 0xAC, 0xEA, 0x56, 0x35, 0x04, 0x6A,
+0x4B, 0xEA, 0xCC, 0xEA, 0xAD, 0xEA, 0x28, 0xF4,
+0x55, 0xC3, 0x62, 0xA4, 0xB1, 0xA0, 0x30, 0x6A,
+0x4C, 0xEB, 0x9F, 0x4A, 0xAC, 0xEA, 0x6D, 0xEA,
+0x51, 0xC0, 0x30, 0xF0, 0x20, 0x6D, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x50, 0x9A, 0x21, 0xF1,
+0xBC, 0x9D, 0x2C, 0x33, 0x49, 0xE3, 0x03, 0x4C,
+0xAD, 0xE3, 0xA0, 0xA4, 0x01, 0x4C, 0xA0, 0xC2,
+0x01, 0x4A, 0x6A, 0xEA, 0xFA, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x63, 0xF5,
+0x98, 0x9B, 0x01, 0x6A, 0x4C, 0xEC, 0x1F, 0x24,
+0x63, 0xF5, 0x7C, 0x9B, 0x05, 0x5B, 0x1B, 0x61,
+0xD1, 0xA0, 0x64, 0xA0, 0x03, 0x6C, 0xDA, 0x37,
+0x04, 0xD3, 0x66, 0x67, 0x8C, 0xEB, 0x05, 0xD3,
+0xCA, 0x33, 0x8C, 0xEB, 0x06, 0xD3, 0x72, 0xA0,
+0xB1, 0x67, 0x4C, 0xEF, 0x6A, 0x33, 0x4C, 0xEB,
+0x07, 0xD3, 0xD2, 0x33, 0x8C, 0xEB, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF2, 0x14, 0x4C, 0xDE, 0x36,
+0x08, 0xD3, 0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x11, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x0D, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x50, 0x9A,
+0x2C, 0x33, 0x30, 0xF0, 0x20, 0x6C, 0x49, 0xE3,
+0xA0, 0x9A, 0x82, 0xF2, 0x18, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x50, 0x9A, 0x2C, 0x33, 0x49, 0xE3, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF3, 0x53, 0xA2,
+0x01, 0x72, 0x16, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x54, 0x9A, 0x63, 0xEA, 0x10, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x44, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x78, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x40, 0x9A, 0x60, 0xDA, 0xF0, 0x17,
+0x51, 0xA0, 0x03, 0x6B, 0x4A, 0x32, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xA9, 0xF3, 0x71, 0xA3,
+0x05, 0x73, 0x11, 0x61, 0x38, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x44, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6,
+0x40, 0x9A, 0x60, 0xDA, 0xF0, 0x17, 0x06, 0x73,
+0x12, 0x61, 0x02, 0x5A, 0x24, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x44, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6,
+0x40, 0x9A, 0x60, 0xDA, 0xF0, 0x17, 0x07, 0x73,
+0x12, 0x61, 0x03, 0x72, 0x10, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x44, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6,
+0x40, 0x9A, 0x60, 0xDA, 0xF0, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0xA9, 0xF3, 0x54, 0xA2, 0x02, 0x72,
+0x15, 0x61, 0x51, 0xA0, 0x03, 0x6B, 0x52, 0x32,
+0x6C, 0xEA, 0x10, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x44, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x40, 0x9A,
+0x60, 0xDA, 0xF0, 0x17, 0x91, 0x67, 0x00, 0x18,
+0x67, 0x4F, 0x76, 0xA0, 0x01, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x91, 0x67, 0x00, 0x18, 0x38, 0x50,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x40, 0xA4, 0x70, 0x69,
+0x30, 0xF0, 0x20, 0x68, 0x06, 0xD2, 0x81, 0xA4,
+0x45, 0xF6, 0x18, 0x48, 0x05, 0xD4, 0x05, 0x92,
+0x9E, 0x33, 0x07, 0xD3, 0x8C, 0xE9, 0x7D, 0x67,
+0x03, 0x6C, 0x8C, 0xEA, 0x87, 0x43, 0x11, 0x4C,
+0x60, 0xA4, 0x32, 0x31, 0x04, 0xD2, 0x9D, 0x67,
+0x09, 0xE1, 0x24, 0xF1, 0x6C, 0xC2, 0x67, 0x44,
+0x09, 0x4B, 0x80, 0xA3, 0x24, 0xF1, 0x8E, 0xC2,
+0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF2, 0x04, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x07, 0x92, 0x21, 0x22,
+0x24, 0xF1, 0x72, 0xA0, 0x01, 0x6A, 0x44, 0xE9,
+0x6D, 0xEA, 0x24, 0xF1, 0x52, 0xC0, 0x63, 0xF5,
+0x58, 0x98, 0x10, 0x6B, 0x6C, 0xEA, 0x0D, 0x22,
+0x63, 0xF5, 0x5C, 0x98, 0x05, 0x5A, 0x09, 0x61,
+0x04, 0x96, 0x06, 0x97, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0xF2, 0x10, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x05, 0x93, 0x0C, 0x6D, 0x91, 0x67,
+0x6C, 0xED, 0xAA, 0x35, 0x00, 0x18, 0x05, 0x46,
+0x23, 0x10, 0x24, 0xF1, 0x72, 0xA0, 0x01, 0x6A,
+0x44, 0xE9, 0x4F, 0xEA, 0x6C, 0xEA, 0x24, 0xF1,
+0x52, 0xC0, 0x63, 0xF5, 0x58, 0x98, 0x10, 0x6B,
+0x6C, 0xEA, 0x0D, 0x22, 0x63, 0xF5, 0x5C, 0x98,
+0x05, 0x5A, 0x09, 0x61, 0x04, 0x96, 0x06, 0x97,
+0x30, 0xF0, 0x20, 0x6C, 0xC2, 0xF2, 0x04, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x45, 0xE1,
+0x01, 0x6A, 0x4B, 0xEA, 0x24, 0xF1, 0x4C, 0xC1,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x40, 0xA4, 0x2E, 0x69,
+0x04, 0x67, 0x38, 0xEA, 0x06, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x20, 0x6B,
+0x12, 0xE9, 0x25, 0xE2, 0x42, 0xA4, 0xBE, 0xA1,
+0x5B, 0xC1, 0x83, 0xA4, 0x21, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEC, 0xAC, 0xEA, 0x8D, 0xEA, 0x5E, 0xC1,
+0xA3, 0xA0, 0x01, 0x6C, 0x8C, 0xED, 0xFD, 0x4C,
+0x4C, 0xEC, 0xAD, 0xEC, 0x9E, 0xC1, 0xA3, 0xA0,
+0x02, 0x6A, 0x4C, 0xED, 0xFB, 0x4A, 0x8C, 0xEA,
+0xAD, 0xEA, 0x5E, 0xC1, 0xA3, 0xA0, 0x40, 0x6C,
+0x8C, 0xED, 0x80, 0x4C, 0xFF, 0x4C, 0x4C, 0xEC,
+0xAD, 0xEC, 0x9E, 0xC1, 0xA3, 0xA0, 0x7F, 0x6A,
+0x8C, 0xEA, 0xBE, 0x35, 0xBC, 0x35, 0xAD, 0xEA,
+0x5E, 0xC1, 0x83, 0xA0, 0x6C, 0xEA, 0x08, 0xD4,
+0x84, 0xA0, 0x20, 0xF0, 0x87, 0xC1, 0x85, 0xA0,
+0x07, 0xD4, 0x86, 0xA0, 0x09, 0xD4, 0x28, 0x22,
+0x06, 0x94, 0x00, 0x18, 0x4E, 0x51, 0xD1, 0xA1,
+0x03, 0x6A, 0x06, 0x94, 0xCA, 0x36, 0xBB, 0xA1,
+0x4C, 0xEE, 0xFF, 0x6B, 0x6C, 0xEE, 0x00, 0x18,
+0x43, 0x4F, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x12, 0x23, 0x63, 0xF5, 0x5C, 0x9A,
+0x05, 0x5A, 0x0E, 0x61, 0xF1, 0xA1, 0x03, 0x6A,
+0x06, 0x95, 0xEA, 0x37, 0xDB, 0xA1, 0x4C, 0xEF,
+0x30, 0xF0, 0x20, 0x6C, 0xFF, 0x6B, 0xC2, 0xF2,
+0x1C, 0x4C, 0x6C, 0xEF, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x10, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x0C, 0x61, 0xDB, 0xA1, 0xE3, 0xA0, 0x20, 0xF0,
+0x47, 0xA1, 0x06, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xE2, 0xF2, 0x1C, 0x4C, 0x04, 0xD2, 0x00, 0x18,
+0x39, 0x3D, 0x08, 0x94, 0x08, 0x6A, 0x8C, 0xEA,
+0x1F, 0x22, 0x09, 0x92, 0x03, 0x68, 0x01, 0x6C,
+0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A, 0x8C, 0xEB,
+0x0D, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x09, 0x61, 0x06, 0x95, 0x07, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x02, 0xF3, 0x14, 0x4C, 0xF0, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x06, 0x94, 0x07, 0x95,
+0x00, 0x6E, 0xF0, 0x67, 0x00, 0x18, 0x6A, 0x49,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x03, 0xA4, 0x44, 0xA4, 0xC0, 0xA4,
+0x00, 0x30, 0x00, 0x30, 0x00, 0xF6, 0x40, 0x32,
+0xA5, 0xA4, 0xE6, 0xA4, 0x0D, 0xEA, 0x01, 0xA4,
+0x82, 0xA4, 0x30, 0xF0, 0x20, 0x6B, 0x0D, 0xEA,
+0x80, 0x34, 0x45, 0xF6, 0x18, 0x4B, 0x8D, 0xEA,
+0x63, 0xF5, 0x58, 0xDB, 0x48, 0xF5, 0xC5, 0xC3,
+0x0A, 0x26, 0x01, 0x6C, 0x4C, 0xEC, 0x07, 0x24,
+0x48, 0xF5, 0xA6, 0xC3, 0x48, 0xF5, 0xE7, 0xC3,
+0x02, 0x25, 0x00, 0x18, 0xD1, 0x50, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x4C, 0xEC, 0xC0, 0x4C, 0x4C, 0xEC, 0x0F, 0x5C,
+0x05, 0x67, 0x36, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0x20, 0xF3, 0x04, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x85, 0x67, 0x00, 0x18,
+0x12, 0x3F, 0x2A, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE9, 0x3F, 0x26, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xEF, 0x3E, 0x22, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x86, 0x3E, 0x1E, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x4B, 0x3D, 0x1A, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x3F, 0x40, 0x16, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE1, 0x3D, 0x12, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xCF, 0x1E, 0x0E, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xAF, 0x3F, 0x90, 0x67, 0x00, 0x18, 0x5F, 0x3C,
+0x07, 0x10, 0x85, 0x67, 0x00, 0x18, 0x3C, 0x3C,
+0x03, 0x10, 0x85, 0x67, 0x00, 0x18, 0x7B, 0x40,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0x00, 0x6A, 0xC0, 0xF3, 0x51, 0xC4, 0xC0, 0xF3,
+0x50, 0xC4, 0x05, 0x6A, 0xC0, 0xF3, 0x4F, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA0, 0xA4, 0x64, 0x67, 0x80, 0x6C, 0x30, 0xF0,
+0x20, 0x6A, 0x8B, 0xEC, 0x45, 0xF6, 0x18, 0x4A,
+0xAC, 0xEC, 0x24, 0xF1, 0x99, 0xC2, 0xA0, 0xA3,
+0x0F, 0x6C, 0xAC, 0xEC, 0x24, 0xF1, 0x96, 0xC2,
+0x81, 0xA3, 0x24, 0xF1, 0xB6, 0xA2, 0x24, 0xF1,
+0x97, 0xC2, 0x00, 0x6C, 0x01, 0x4D, 0x24, 0xF1,
+0x98, 0xC2, 0x01, 0x6C, 0x84, 0xED, 0x63, 0xF5,
+0xB8, 0x9A, 0xFF, 0x4C, 0x24, 0xF1, 0x9C, 0xCA,
+0x10, 0xF0, 0x00, 0x6C, 0xAC, 0xEC, 0x0A, 0x24,
+0xA1, 0xA3, 0xC0, 0xA3, 0x24, 0xF1, 0xFC, 0xAA,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF3, 0x10, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0xBC, 0x9A, 0x24, 0x67, 0xA1, 0xF7,
+0x04, 0x6C, 0x00, 0x18, 0x00, 0x29, 0x01, 0x22,
+0x01, 0x6A, 0x64, 0x99, 0x02, 0x67, 0x10, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x07, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF3, 0x0C, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x50, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x01, 0x6D,
+0x04, 0x67, 0xAB, 0xED, 0xA1, 0xF7, 0x04, 0x6C,
+0x00, 0x18, 0x00, 0x29, 0x64, 0x98, 0xC0, 0xF3,
+0x52, 0xC8, 0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x08, 0x22, 0xC0, 0xF3, 0xB2, 0xA8, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF3, 0x18, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xC0, 0xF3, 0xD4, 0xAC, 0xFF, 0xF7, 0x1F, 0x6D,
+0x81, 0xF1, 0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29,
+0xFF, 0x6D, 0x81, 0xF1, 0x14, 0x6C, 0x01, 0x4D,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x81, 0xF1, 0x14, 0x68, 0x90, 0x67,
+0x01, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x01, 0x6D, 0x90, 0x67, 0xC5, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x64, 0x9C, 0x10, 0xF0,
+0x00, 0x6A, 0xFF, 0x69, 0x05, 0x67, 0x6C, 0xEA,
+0x2C, 0xE8, 0xCC, 0xE9, 0x08, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF3, 0x04, 0x4C, 0xB0, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x5D, 0x67,
+0x12, 0xC2, 0x33, 0xC2, 0x7D, 0x67, 0x2A, 0x6A,
+0x50, 0xC3, 0x02, 0x6A, 0x4F, 0xCB, 0x07, 0x97,
+0x04, 0x94, 0x05, 0x95, 0x06, 0x96, 0x00, 0x18,
+0xAA, 0x33, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xC0, 0xF3, 0xB1, 0xA4, 0x04, 0x67,
+0x3B, 0x25, 0xC0, 0xF3, 0xD0, 0xA4, 0xC0, 0xF3,
+0x4F, 0xA4, 0xC3, 0xEA, 0x35, 0x61, 0x64, 0x9C,
+0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF3, 0x10, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x90, 0x67, 0x00, 0x18,
+0x95, 0x40, 0x1C, 0x22, 0x90, 0x67, 0x00, 0x18,
+0xA6, 0x40, 0xC0, 0xF3, 0x54, 0xA8, 0xFF, 0xF7,
+0x1F, 0x72, 0x14, 0x61, 0xC0, 0xF3, 0xB2, 0xA8,
+0x64, 0x6A, 0x90, 0x67, 0x58, 0xED, 0x8F, 0xF7,
+0x1C, 0x4A, 0x12, 0xED, 0x55, 0xE5, 0xC0, 0xF3,
+0x50, 0xA0, 0xA2, 0x35, 0xA2, 0x35, 0x01, 0x4A,
+0xC0, 0xF3, 0x50, 0xC0, 0xC0, 0xF3, 0xD0, 0xA0,
+0x00, 0x18, 0xC9, 0x40, 0xC0, 0xF3, 0x50, 0xA0,
+0x01, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xB5, 0x40, 0x90, 0x67, 0x00, 0x18, 0xBF, 0x40,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x6B, 0x8C, 0xEB, 0x20, 0x5B, 0x00, 0x6A,
+0x02, 0x60, 0x01, 0x6A, 0x44, 0xEB, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0xE0, 0x4C, 0x8C, 0xEA,
+0x20, 0x5A, 0x00, 0x6A, 0x02, 0x60, 0x01, 0x6A,
+0x44, 0xEC, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x68, 0x44, 0xC8, 0x4B, 0x4C, 0xEB, 0x20, 0x5B,
+0x00, 0x6A, 0x02, 0x60, 0x01, 0x6A, 0x44, 0xEC,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x00, 0x18,
+0x00, 0x41, 0x0F, 0x6B, 0x4C, 0xEB, 0x43, 0x67,
+0x0C, 0xEA, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x00, 0x18,
+0x00, 0x41, 0x10, 0x6B, 0x6B, 0xEB, 0x4C, 0xEB,
+0x43, 0x67, 0x0C, 0xEA, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x00, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF1, 0x8C, 0x9B, 0x01, 0x6B, 0x4C, 0xEC,
+0x0A, 0x2C, 0x90, 0x67, 0x00, 0x18, 0x04, 0x41,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF1, 0x70, 0x9B,
+0x4C, 0xEB, 0x01, 0x23, 0x01, 0x6B, 0x05, 0x97,
+0x04, 0x90, 0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x00, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF0, 0x90, 0x9B, 0x01, 0x6B, 0x4C, 0xEC,
+0x0A, 0x2C, 0x90, 0x67, 0x00, 0x18, 0x04, 0x41,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF1, 0x74, 0x9B,
+0x4C, 0xEB, 0x01, 0x23, 0x01, 0x6B, 0x05, 0x97,
+0x04, 0x90, 0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x00, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF1, 0x78, 0x9B, 0x4C, 0xEB, 0x0D, 0x2B,
+0x90, 0x67, 0x00, 0x18, 0x04, 0x41, 0x0F, 0x6B,
+0x4C, 0xEB, 0x07, 0x2B, 0x90, 0x67, 0x00, 0x18,
+0x09, 0x41, 0xE0, 0xF3, 0x1F, 0x6B, 0x4C, 0xEB,
+0x01, 0x23, 0x01, 0x6B, 0x05, 0x97, 0x04, 0x90,
+0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x04, 0x41,
+0xE1, 0xF7, 0x10, 0x6C, 0x4C, 0xEC, 0x01, 0x6B,
+0x0A, 0x2C, 0x90, 0x67, 0x00, 0x18, 0x09, 0x41,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF1, 0x7C, 0x9B,
+0x4C, 0xEB, 0x01, 0x23, 0x01, 0x6B, 0x05, 0x97,
+0x04, 0x90, 0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x00, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF1, 0x60, 0x9B, 0x4C, 0xEB, 0x10, 0x2B,
+0x90, 0x67, 0x00, 0x18, 0x04, 0x41, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF1, 0x64, 0x9B, 0x4C, 0xEB,
+0x07, 0x2B, 0x90, 0x67, 0x00, 0x18, 0x09, 0x41,
+0x0C, 0xF0, 0x18, 0x6B, 0x4C, 0xEB, 0x01, 0x23,
+0x01, 0x6B, 0x05, 0x97, 0x04, 0x90, 0xFF, 0x6A,
+0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x00, 0x41,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF1, 0x68, 0x9B,
+0x4C, 0xEB, 0x12, 0x2B, 0x90, 0x67, 0x00, 0x18,
+0x04, 0x41, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF1,
+0x6C, 0x9B, 0x4C, 0xEB, 0x09, 0x2B, 0x90, 0x67,
+0x00, 0x18, 0x09, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF1, 0x70, 0x9B, 0x4C, 0xEB, 0x01, 0x23,
+0x01, 0x6B, 0x05, 0x97, 0x04, 0x90, 0xFF, 0x6A,
+0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x04, 0x41,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF1, 0x94, 0x9B,
+0x01, 0x6B, 0x4C, 0xEC, 0x0A, 0x2C, 0x90, 0x67,
+0x00, 0x18, 0x09, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF1, 0x78, 0x9B, 0x4C, 0xEB, 0x01, 0x23,
+0x01, 0x6B, 0x05, 0x97, 0x04, 0x90, 0xFF, 0x6A,
+0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x63, 0x01, 0xD1, 0x00, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF1, 0x1C, 0x9B, 0x30, 0xF0,
+0x20, 0x6F, 0x45, 0xF6, 0x18, 0x4F, 0x60, 0xA0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x1B, 0x65, 0x38, 0x67,
+0x7F, 0x6B, 0x2C, 0xEB, 0x48, 0xF5, 0x69, 0xC7,
+0x60, 0xA0, 0x80, 0x68, 0x0B, 0xE8, 0x4C, 0xEB,
+0x0C, 0xEB, 0x48, 0xF5, 0x6A, 0xC7, 0x48, 0xF5,
+0x69, 0xA7, 0x4C, 0xED, 0x4C, 0xEE, 0x6E, 0xEC,
+0x53, 0x2C, 0x02, 0x5D, 0xF2, 0xF0, 0x60, 0x45,
+0x09, 0x61, 0x8E, 0x45, 0x4C, 0xEC, 0x02, 0x5C,
+0x44, 0x61, 0x08, 0x5D, 0x49, 0x60, 0x48, 0xF5,
+0x4A, 0xA7, 0x3F, 0x22, 0x1F, 0xF7, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x40, 0x9A, 0x4D, 0xE3, 0xC0, 0xC3,
+0x33, 0x10, 0x1F, 0x2A, 0x1F, 0xF7, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x9C, 0x9A, 0x91, 0xE3, 0x40, 0xA4, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x9C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x91, 0xE3, 0x4D, 0xE3, 0x40, 0xA3, 0xFF, 0x6B,
+0x6C, 0xEA, 0x01, 0x4A, 0x6C, 0xEA, 0x40, 0xC4,
+0x13, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7,
+0x40, 0x9A, 0xFF, 0x6C, 0x4D, 0xE3, 0x40, 0xA3,
+0x8C, 0xEA, 0x01, 0x4A, 0x8C, 0xEA, 0x40, 0xC3,
+0x07, 0x10, 0x1F, 0xF7, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0xCE, 0x61, 0xCE, 0x17,
+0x01, 0x91, 0x00, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0xFE, 0x63, 0x03, 0xD1, 0x02, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF1, 0x5C, 0x9A, 0xFF, 0x6B,
+0x80, 0x6E, 0x80, 0xA2, 0xE0, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF1, 0xA0, 0x9A, 0xCB, 0xEE,
+0x6C, 0xEC, 0x40, 0xA5, 0x00, 0xA5, 0x6C, 0xEA,
+0xB0, 0x67, 0x6C, 0xED, 0x00, 0xD5, 0xA3, 0x67,
+0xCC, 0xED, 0xEC, 0xED, 0xA0, 0xF2, 0x17, 0x25,
+0xCC, 0xEA, 0x6C, 0xEA, 0x09, 0x22, 0xA0, 0xF4,
+0x08, 0x6F, 0xA0, 0xF4, 0x04, 0x6D, 0x20, 0xF5,
+0x00, 0x4E, 0x80, 0xF4, 0x1C, 0x6A, 0x08, 0x10,
+0x80, 0xF4, 0x18, 0x6F, 0x80, 0xF4, 0x14, 0x6D,
+0x80, 0xF4, 0x10, 0x6E, 0x80, 0xF4, 0x0C, 0x6A,
+0x7F, 0x69, 0x2E, 0x68, 0x2C, 0xEC, 0x18, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0x89, 0xF7, 0x18, 0x4B,
+0x12, 0xE8, 0x0D, 0xE3, 0x00, 0x90, 0x2C, 0xE8,
+0x01, 0x70, 0x80, 0xF1, 0x18, 0x60, 0x07, 0x20,
+0x02, 0x70, 0xC0, 0xF0, 0x1A, 0x60, 0x03, 0x70,
+0xE0, 0xF1, 0x19, 0x60, 0x8C, 0x12, 0x1F, 0xF7,
+0x00, 0x68, 0x4C, 0xE8, 0x05, 0x28, 0x30, 0xF0,
+0x20, 0x68, 0x00, 0xF7, 0x1C, 0x98, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0x20, 0xF7, 0x00, 0x98,
+0x3B, 0xA3, 0x01, 0xE2, 0x20, 0xC0, 0x01, 0x42,
+0x1F, 0xF7, 0x00, 0x69, 0x2C, 0xE8, 0x02, 0xF0,
+0x00, 0x70, 0x01, 0x60, 0x09, 0x28, 0x30, 0xF0,
+0x20, 0x68, 0xE0, 0xF6, 0x24, 0x98, 0x25, 0xE2,
+0x00, 0xD1, 0x31, 0xA3, 0x19, 0x65, 0x08, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0xE0, 0xF6, 0x28, 0x98,
+0x25, 0xE2, 0x00, 0xD1, 0x11, 0xA3, 0x18, 0x65,
+0x38, 0x67, 0x03, 0x68, 0x2C, 0xE8, 0x00, 0x91,
+0x00, 0xC1, 0x02, 0x42, 0x1F, 0xF7, 0x00, 0x69,
+0x2C, 0xE8, 0x02, 0xF0, 0x00, 0x70, 0x01, 0x60,
+0x05, 0x28, 0x30, 0xF0, 0x20, 0x68, 0x01, 0xF0,
+0x10, 0x98, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x68,
+0xA1, 0xF1, 0x04, 0x98, 0x31, 0xA3, 0x01, 0xE2,
+0x3E, 0x31, 0x20, 0xC0, 0x03, 0x42, 0x1F, 0xF7,
+0x00, 0x69, 0x2C, 0xE8, 0x02, 0xF0, 0x00, 0x70,
+0x01, 0x60, 0x05, 0x28, 0x30, 0xF0, 0x20, 0x68,
+0xA1, 0xF1, 0x08, 0x98, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x68, 0xA1, 0xF1, 0x0C, 0x98, 0x09, 0xE2,
+0x11, 0xA3, 0x03, 0x69, 0x12, 0x30, 0x2C, 0xE8,
+0x00, 0xC2, 0x1F, 0xF7, 0x00, 0x6A, 0xCC, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x40, 0x9A, 0x00, 0xA3, 0x49, 0xE6,
+0x00, 0xC2, 0x41, 0x46, 0x1F, 0xF7, 0x00, 0x68,
+0x0C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x44, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x48, 0x9A, 0x01, 0xA3, 0x49, 0xE6,
+0x00, 0xC2, 0x42, 0x46, 0x1F, 0xF7, 0x00, 0x68,
+0x0C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x10, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF1, 0x04, 0x9A, 0x52, 0xA3, 0x01, 0x69,
+0x01, 0xE6, 0x4A, 0x32, 0x2C, 0xEA, 0x40, 0xC0,
+0x43, 0x46, 0x1F, 0xF7, 0x00, 0x68, 0x0C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1, 0x48, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x4C, 0x9A, 0x59, 0xE6, 0x44, 0xA3, 0x40, 0xC6,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7,
+0x40, 0x9A, 0x55, 0xE5, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x50, 0x9A, 0x8C, 0x33, 0x49, 0xE3,
+0x40, 0x9A, 0x40, 0xDD, 0x1F, 0xF7, 0x00, 0x6A,
+0xEC, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A, 0x5D, 0xE7,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0x5C, 0x9A,
+0x8C, 0x34, 0x51, 0xE4, 0x40, 0x9C, 0x40, 0xDF,
+0xB6, 0x11, 0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC,
+0x09, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF7,
+0xFC, 0x9C, 0x91, 0xA3, 0x03, 0x68, 0xFD, 0xE2,
+0x8A, 0x34, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF7, 0xE0, 0x9C, 0x91, 0xA3, 0x03, 0x68,
+0xFD, 0xE2, 0x8A, 0x34, 0x0C, 0xEC, 0xFF, 0x68,
+0x0C, 0xEC, 0x80, 0xC7, 0x81, 0x42, 0x1F, 0xF7,
+0x00, 0x6F, 0xEC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xE0, 0xF6, 0x84, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0xF6, 0x88, 0x9C, 0xE3, 0xA3,
+0x91, 0xE2, 0xE0, 0xC4, 0x82, 0x42, 0x1F, 0xF7,
+0x00, 0x6F, 0xEC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF0, 0x90, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0xA1, 0xF1, 0x84, 0x9C, 0xE5, 0xA3,
+0x91, 0xE2, 0xE0, 0xC4, 0x83, 0x42, 0x1F, 0xF7,
+0x00, 0x6F, 0xEC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xA1, 0xF1, 0x88, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0xA1, 0xF1, 0x8C, 0x9C, 0x89, 0xE2,
+0x86, 0xA3, 0x80, 0xC2, 0x1F, 0xF7, 0x00, 0x6A,
+0xCC, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A, 0x59, 0xE6,
+0x59, 0xA3, 0x40, 0xC6, 0x1F, 0xF7, 0x00, 0x6A,
+0xAC, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A, 0x20, 0xF0,
+0x82, 0xA3, 0x49, 0xE5, 0x80, 0xC2, 0x41, 0x45,
+0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x44, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x48, 0x9A,
+0x20, 0xF0, 0x63, 0xA3, 0x49, 0xE5, 0x60, 0xC2,
+0x42, 0x45, 0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x50, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x44, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF1,
+0x64, 0xA3, 0x49, 0xE5, 0x60, 0xC2, 0x43, 0x45,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF1, 0x48, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1, 0x4C, 0x9A,
+0x55, 0xE5, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF1,
+0x45, 0xA2, 0x40, 0xC5, 0xFC, 0x10, 0x1F, 0xF7,
+0x00, 0x6D, 0x4C, 0xED, 0x10, 0x2D, 0x30, 0xF0,
+0x20, 0x6D, 0x00, 0xF7, 0xDC, 0x9D, 0x30, 0xF0,
+0x20, 0x6D, 0x21, 0xF1, 0xB0, 0x9D, 0x94, 0x37,
+0xD9, 0xE2, 0xB5, 0xE7, 0xE0, 0xA5, 0xFF, 0x6D,
+0xEC, 0xED, 0xA0, 0xC6, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6E, 0x21, 0xF1, 0xD0, 0x9E, 0x94, 0x37,
+0x30, 0xF0, 0x20, 0x6D, 0xD9, 0xE7, 0xC0, 0xA6,
+0x20, 0xF7, 0xA0, 0x9D, 0xFF, 0x69, 0x2C, 0xEE,
+0xB5, 0xE2, 0xC0, 0xC5, 0xA1, 0x42, 0x1F, 0xF7,
+0x00, 0x6E, 0xCC, 0xED, 0x02, 0xF0, 0x00, 0x75,
+0x01, 0x60, 0x05, 0x2D, 0x30, 0xF0, 0x20, 0x6D,
+0xE0, 0xF6, 0xA4, 0x9D, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0xE0, 0xF6, 0xA8, 0x9D, 0x30, 0xF0,
+0x20, 0x6E, 0x21, 0xF1, 0xCC, 0x9E, 0x94, 0x34,
+0xB5, 0xE2, 0xD1, 0xE4, 0xC0, 0xA4, 0xFF, 0x6C,
+0xCC, 0xEC, 0x80, 0xC5, 0x82, 0x42, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF0, 0x90, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0xA1, 0xF1, 0x84, 0x9C, 0xB8, 0xA3,
+0x91, 0xE2, 0xA0, 0xC4, 0x83, 0x42, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xA1, 0xF1, 0x88, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0xA1, 0xF1, 0x8C, 0x9C, 0x68, 0xA3,
+0x89, 0xE2, 0x60, 0xC2, 0x94, 0x10, 0x1F, 0xF7,
+0x00, 0x6B, 0x4C, 0xEB, 0x05, 0x2B, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF7, 0x7C, 0x9B, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x60, 0x9B,
+0x69, 0xE2, 0x52, 0xF1, 0x02, 0x44, 0x30, 0xF0,
+0x20, 0x6B, 0x08, 0x30, 0x45, 0xF6, 0x18, 0x4B,
+0x6D, 0xE0, 0x61, 0x9B, 0x60, 0xDA, 0x1F, 0xF7,
+0x00, 0x6A, 0xCC, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0x40, 0x9A,
+0x14, 0x6B, 0x78, 0xEC, 0x59, 0xE6, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x12, 0xEB,
+0x49, 0xE3, 0xC8, 0xF7, 0x48, 0x9A, 0x40, 0xDE,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7,
+0x40, 0x9A, 0x14, 0x6B, 0x78, 0xEC, 0x55, 0xE5,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x12, 0xEB, 0x49, 0xE3, 0xC8, 0xF7, 0x4C, 0x9A,
+0x40, 0xDD, 0x1F, 0xF7, 0x00, 0x6A, 0xEC, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x7C, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE4, 0x2A, 0xF4,
+0x54, 0xA2, 0x6D, 0xE7, 0x40, 0xC3, 0x41, 0x47,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x64, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x49, 0xE4, 0x6A, 0xF5, 0x52, 0xA2, 0x6D, 0xE7,
+0x40, 0xC3, 0x42, 0x47, 0x1F, 0xF7, 0x00, 0x6B,
+0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x50, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF1, 0x44, 0x9A, 0x5D, 0xE7, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x51, 0xE4,
+0xCA, 0xF4, 0x53, 0xA4, 0x40, 0xC7, 0x03, 0x91,
+0x02, 0x90, 0x02, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xAA, 0xEC, 0x64, 0x6A,
+0x31, 0x60, 0x2F, 0x24, 0x83, 0xED, 0x2D, 0x61,
+0x02, 0xF0, 0x00, 0x5D, 0x04, 0x6A, 0x0C, 0x61,
+0x04, 0xF0, 0x00, 0x5D, 0x03, 0x6A, 0x08, 0x61,
+0x08, 0xF0, 0x00, 0x5D, 0x02, 0x6A, 0x04, 0x61,
+0xEF, 0xF7, 0x1E, 0x4A, 0x43, 0xED, 0x58, 0x67,
+0xA4, 0xEA, 0x84, 0xEA, 0x00, 0x6B, 0x01, 0x6A,
+0xA6, 0x35, 0x83, 0xED, 0x11, 0x60, 0x81, 0xF4,
+0x00, 0x6E, 0xC7, 0xEB, 0xC9, 0xE2, 0x01, 0x75,
+0xFF, 0xF7, 0x1F, 0x6E, 0xCC, 0xEA, 0xB3, 0xE4,
+0x04, 0x61, 0x02, 0x5C, 0x04, 0x60, 0x01, 0x74,
+0x06, 0x60, 0x02, 0x2C, 0x04, 0x10, 0x02, 0x6D,
+0x01, 0x4B, 0x0C, 0x73, 0xE9, 0x61, 0x5A, 0x32,
+0x01, 0x10, 0x00, 0x6A, 0xFF, 0x6B, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x40, 0xA4, 0x60, 0xA5,
+0x60, 0xC4, 0x40, 0xC5, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0xA4, 0x35, 0x05, 0xF5, 0x00, 0x4A, 0x49, 0xE5,
+0x40, 0xAA, 0x6C, 0xEC, 0xCC, 0xEB, 0x58, 0xEC,
+0xFF, 0xF7, 0x1F, 0x6C, 0x12, 0xEA, 0x8C, 0xEA,
+0x05, 0x23, 0x52, 0x35, 0x56, 0x33, 0x6D, 0xE5,
+0x49, 0xE3, 0x8C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x63, 0x9D, 0x81, 0x9D, 0xFF, 0xF7, 0x1F, 0x6A,
+0xEC, 0xEA, 0x61, 0xE4, 0xC1, 0xE0, 0xE2, 0x9D,
+0xC4, 0x9D, 0x20, 0x9D, 0xE4, 0x35, 0xC1, 0xE0,
+0xB5, 0xE0, 0x79, 0xE6, 0x55, 0xE5, 0x49, 0xE6,
+0x44, 0x32, 0x55, 0xE5, 0x00, 0x6A, 0x0A, 0x25,
+0x6B, 0xEB, 0xFF, 0xE3, 0x27, 0xE7, 0x93, 0xE1,
+0xB1, 0xE4, 0x83, 0xED, 0x64, 0x6A, 0x02, 0x61,
+0x00, 0x18, 0x3F, 0x43, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x20, 0x5C, 0x01, 0x6B,
+0x03, 0x60, 0xE0, 0x4C, 0x4C, 0xEC, 0x00, 0x6B,
+0x68, 0x33, 0x75, 0xE5, 0x01, 0x6B, 0x64, 0xEC,
+0x80, 0x9D, 0x00, 0x6A, 0x8C, 0xEB, 0x01, 0x23,
+0x01, 0x6A, 0xFF, 0x6B, 0x6C, 0xEA, 0x20, 0xE8,
+0xFF, 0x6B, 0x44, 0x67, 0x6C, 0xEA, 0x6C, 0xEE,
+0x6C, 0xED, 0x82, 0x67, 0x03, 0x26, 0x88, 0x42,
+0xE8, 0x4C, 0x6C, 0xEC, 0x20, 0x5C, 0x0B, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF1, 0x7C, 0x9B,
+0xAC, 0x35, 0xE0, 0x4C, 0x75, 0xE5, 0xFF, 0x6B,
+0xA0, 0x9D, 0x6C, 0xEC, 0x07, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF1, 0x70, 0x9B, 0xAC, 0x35,
+0x75, 0xE5, 0xA0, 0x9D, 0x01, 0x6B, 0x64, 0xEC,
+0xAC, 0xEB, 0x01, 0x2B, 0xFF, 0x6A, 0x20, 0xE8,
+0xFF, 0x6A, 0x8C, 0xEA, 0x2E, 0x6B, 0x78, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x89, 0xF7, 0x18, 0x4B,
+0x12, 0xEA, 0x49, 0xE3, 0x93, 0xA2, 0x7F, 0x6B,
+0x6C, 0xEC, 0x93, 0xC2, 0x92, 0xA2, 0x8C, 0xEB,
+0x72, 0xC2, 0x20, 0xE8, 0xFF, 0x6A, 0xAC, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x7F, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x1F, 0x41, 0x01, 0x6B, 0x12, 0x2A,
+0x90, 0x67, 0x00, 0x18, 0x2F, 0x41, 0x02, 0x6B,
+0x0D, 0x2A, 0x90, 0x67, 0x00, 0x18, 0x3F, 0x41,
+0x03, 0x6B, 0x08, 0x2A, 0x90, 0x67, 0x00, 0x18,
+0x50, 0x41, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x33, 0x68, 0x33, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x63, 0xFF, 0x6B, 0xBD, 0x67, 0x20, 0xF4,
+0x0D, 0x6A, 0x6C, 0xEC, 0x40, 0xCD, 0x84, 0x34,
+0x20, 0xF4, 0x0F, 0x6A, 0x41, 0xCD, 0x91, 0xE5,
+0x80, 0xAC, 0x1F, 0xF7, 0x00, 0x6A, 0x8C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x0A, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7, 0x5C, 0x9A,
+0x51, 0xE4, 0x60, 0xA4, 0x0E, 0x6A, 0x6C, 0xEA,
+0x46, 0x32, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x40, 0x9A, 0x51, 0xE4, 0x80, 0xA4,
+0x0E, 0x6A, 0x8C, 0xEA, 0x47, 0x32, 0x6C, 0xEA,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD1,
+0x00, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x2E, 0x6A,
+0x58, 0xEC, 0x30, 0xF0, 0x20, 0x6A, 0x89, 0xF7,
+0x18, 0x4A, 0xCC, 0xE8, 0x60, 0xA5, 0x12, 0xEC,
+0x91, 0xE2, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x48, 0x9A, 0xE0, 0xA4, 0xC1, 0xA4, 0x40, 0xA2,
+0x1A, 0x65, 0x38, 0x67, 0x20, 0x6A, 0x2C, 0xEA,
+0x25, 0x2A, 0xFF, 0x73, 0x01, 0x6A, 0x23, 0x60,
+0x7F, 0x69, 0x43, 0x67, 0x2C, 0xEA, 0x2C, 0xEF,
+0x43, 0xEF, 0x05, 0x60, 0x80, 0x6E, 0xCB, 0xEE,
+0x6C, 0xEE, 0xED, 0xEE, 0x02, 0x10, 0xC3, 0xEA,
+0x01, 0x60, 0xC0, 0xC5, 0x46, 0x72, 0x12, 0x61,
+0x02, 0x70, 0x10, 0x61, 0x6F, 0xA4, 0x10, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x10, 0x72, 0x47, 0x6B, 0x01, 0x60, 0x45, 0x6B,
+0x80, 0xA5, 0x80, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x6D, 0xEA, 0x40, 0xC5, 0x00, 0x6A, 0x01, 0x91,
+0x00, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x2E, 0x6B, 0x78, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0x89, 0xF7, 0x18, 0x4B,
+0x19, 0x6E, 0xCB, 0xEE, 0x4C, 0xED, 0x12, 0xEC,
+0x91, 0xE3, 0x72, 0xA4, 0x6C, 0xEE, 0x04, 0x6B,
+0xCC, 0xEB, 0x4C, 0xEB, 0xD2, 0xC4, 0x53, 0x23,
+0xD0, 0xA4, 0x80, 0x6B, 0x6B, 0xEB, 0xCC, 0xEB,
+0x4C, 0xEB, 0x4D, 0x23, 0xEE, 0xA4, 0x07, 0x6E,
+0x7F, 0x6B, 0xEC, 0xEE, 0x4C, 0xEE, 0x03, 0x76,
+0xAC, 0xEB, 0x1C, 0x61, 0x47, 0x73, 0x06, 0x61,
+0xD1, 0xA4, 0x0C, 0x6A, 0xCC, 0xEA, 0x08, 0x72,
+0xC5, 0x6A, 0x44, 0x60, 0xC7, 0x75, 0x02, 0x60,
+0x48, 0x75, 0x06, 0x61, 0xD1, 0xA4, 0x0C, 0x6A,
+0xCC, 0xEA, 0x08, 0x72, 0x47, 0x6A, 0x3A, 0x60,
+0xC5, 0x75, 0x33, 0x60, 0x46, 0x75, 0x31, 0x60,
+0x48, 0x43, 0xC3, 0x4A, 0xFF, 0x6E, 0xCC, 0xEA,
+0x05, 0x5A, 0x13, 0x10, 0x02, 0x76, 0x07, 0x61,
+0xBD, 0x75, 0x29, 0x60, 0x3E, 0x75, 0x27, 0x60,
+0xC8, 0x43, 0xCA, 0x4E, 0x08, 0x10, 0x01, 0x76,
+0x1E, 0x61, 0xB3, 0x75, 0x22, 0x60, 0x34, 0x75,
+0x20, 0x60, 0xC8, 0x43, 0xD4, 0x4E, 0x4C, 0xEE,
+0x02, 0x5E, 0x15, 0x60, 0xBE, 0x35, 0x03, 0x25,
+0x01, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB, 0x80, 0x6D,
+0x4E, 0x43, 0xAB, 0xED, 0xAD, 0xEA, 0xFF, 0x6D,
+0xFF, 0x4B, 0xAC, 0xEA, 0xB2, 0xA4, 0x65, 0xC4,
+0x19, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB, 0x08, 0x6D,
+0xAD, 0xEB, 0x72, 0xC4, 0x20, 0xE8, 0xFF, 0x6A,
+0x20, 0xE8, 0x45, 0x6A, 0x20, 0xE8, 0x3D, 0x6A,
+0x20, 0xE8, 0x33, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x63, 0x01, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x2E, 0x6B, 0x78, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x89, 0xF7, 0x18, 0x4B, 0x19, 0x6E, 0xCB, 0xEE,
+0x4C, 0xED, 0x12, 0xEC, 0x91, 0xE3, 0x72, 0xA4,
+0x6C, 0xEE, 0x04, 0x6B, 0xCC, 0xEB, 0x4C, 0xEB,
+0xD2, 0xC4, 0x56, 0x23, 0xD0, 0xA4, 0x80, 0x6B,
+0x6B, 0xEB, 0xCC, 0xEB, 0x4C, 0xEB, 0x50, 0x23,
+0x0E, 0xA4, 0x07, 0x6F, 0x7F, 0x6B, 0x0C, 0xEF,
+0x4C, 0xEF, 0x80, 0x6E, 0x03, 0x77, 0xAC, 0xEB,
+0xAC, 0xEE, 0x14, 0x61, 0x45, 0x73, 0x09, 0x61,
+0xF1, 0xA4, 0x0C, 0x6A, 0xEC, 0xEA, 0x08, 0x72,
+0x04, 0x61, 0x47, 0x6A, 0x3E, 0x2E, 0xC5, 0x6A,
+0x3C, 0x10, 0x48, 0x43, 0xC3, 0x4A, 0xFF, 0x6F,
+0xEC, 0xEA, 0x04, 0x5A, 0x35, 0x60, 0x00, 0x6A,
+0xC8, 0x75, 0x13, 0x10, 0x02, 0x77, 0x08, 0x61,
+0xE8, 0x43, 0xCB, 0x4F, 0x4C, 0xEF, 0x02, 0x5F,
+0x2B, 0x60, 0x00, 0x6A, 0xBE, 0x75, 0x09, 0x10,
+0x01, 0x77, 0x26, 0x61, 0xE8, 0x43, 0xD5, 0x4F,
+0x4C, 0xEF, 0x02, 0x5F, 0x21, 0x60, 0x00, 0x6A,
+0xB4, 0x75, 0x01, 0x60, 0x01, 0x6A, 0x15, 0x22,
+0x05, 0x26, 0x80, 0x6D, 0x41, 0x43, 0xAB, 0xED,
+0xAD, 0xEA, 0x03, 0x10, 0x80, 0x6A, 0x4B, 0xEA,
+0x6D, 0xEA, 0xFF, 0x6D, 0x01, 0x4B, 0xAC, 0xEA,
+0xB2, 0xA4, 0x65, 0xC4, 0x19, 0x6B, 0x6B, 0xEB,
+0xAC, 0xEB, 0x08, 0x6D, 0xAD, 0xEB, 0x72, 0xC4,
+0x08, 0x10, 0x41, 0x43, 0x80, 0x6B, 0x6B, 0xEB,
+0x6D, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x01, 0x10,
+0xFF, 0x6A, 0x01, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD1, 0x00, 0xD0, 0xFF, 0x6A,
+0x8C, 0xEA, 0x05, 0x67, 0x30, 0xF0, 0x20, 0x69,
+0xF5, 0xF3, 0xA4, 0x42, 0x45, 0xF6, 0x18, 0x49,
+0xA4, 0x35, 0x06, 0x93, 0x35, 0xE5, 0xFF, 0xF7,
+0x1F, 0x6C, 0x23, 0xAD, 0x8C, 0xEE, 0x8C, 0xEF,
+0x8C, 0xEB, 0xD3, 0xE4, 0x22, 0xEC, 0x03, 0x61,
+0x39, 0xE6, 0xC3, 0xCD, 0x03, 0x10, 0x01, 0x6C,
+0x8B, 0xEC, 0x83, 0xCD, 0x30, 0xF0, 0x20, 0x6D,
+0x55, 0xF3, 0x84, 0x42, 0x45, 0xF6, 0x18, 0x4D,
+0x84, 0x34, 0xB1, 0xE4, 0xA4, 0xAC, 0xFF, 0xF7,
+0x1F, 0x6E, 0xFB, 0xE6, 0xA2, 0xEE, 0x03, 0x61,
+0xBD, 0xE7, 0xE4, 0xCC, 0x03, 0x10, 0x01, 0x6D,
+0xAB, 0xED, 0xA4, 0xCC, 0x30, 0xF0, 0x20, 0x6C,
+0x45, 0xF6, 0x18, 0x4C, 0x2B, 0xF1, 0xAC, 0x9C,
+0x6F, 0xEE, 0xA3, 0xEE, 0xAD, 0xE3, 0x02, 0x60,
+0x01, 0x6B, 0x6B, 0xEB, 0x2B, 0xF1, 0x6C, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x95, 0xF4, 0x64, 0x42,
+0x45, 0xF6, 0x18, 0x4C, 0x64, 0x33, 0x07, 0x96,
+0x8D, 0xE3, 0x84, 0xAB, 0xFF, 0xF7, 0x1F, 0x6D,
+0xD7, 0xE5, 0x83, 0xED, 0x91, 0xE6, 0x02, 0x60,
+0x01, 0x6C, 0x8B, 0xEC, 0x84, 0xCB, 0x25, 0xF5,
+0x14, 0x4A, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x44, 0x32, 0x69, 0xE2, 0x63, 0xAA,
+0xFF, 0xF7, 0x1F, 0x6C, 0x13, 0xE4, 0x63, 0xEC,
+0x03, 0x61, 0x61, 0xE0, 0x03, 0xCA, 0x03, 0x10,
+0x01, 0x6B, 0x6B, 0xEB, 0x63, 0xCA, 0x01, 0x91,
+0x00, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xED, 0x6C, 0xEC, 0x0F, 0x2D,
+0x48, 0x44, 0xFC, 0x4A, 0x6C, 0xEA, 0x08, 0x5A,
+0x1D, 0x61, 0x48, 0x44, 0xF4, 0x4A, 0x6C, 0xEA,
+0x08, 0x5A, 0x16, 0x61, 0x48, 0x44, 0xEC, 0x4A,
+0x6C, 0xEA, 0x08, 0x5A, 0x0E, 0x10, 0x48, 0x44,
+0xDC, 0x4A, 0x6C, 0xEA, 0x0A, 0x5A, 0x0E, 0x61,
+0x48, 0x44, 0xD2, 0x4A, 0x6C, 0xEA, 0x0A, 0x5A,
+0x07, 0x61, 0x48, 0x44, 0xC8, 0x4A, 0x6C, 0xEA,
+0x0A, 0x5A, 0x03, 0x6A, 0x06, 0x61, 0x04, 0x10,
+0x02, 0x6A, 0x03, 0x10, 0x01, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x30, 0xF0, 0x21, 0x6B, 0x51, 0xF3,
+0x74, 0xA3, 0x03, 0x73, 0x22, 0x61, 0x03, 0x72,
+0x35, 0x60, 0x02, 0x72, 0x11, 0x61, 0x08, 0x2D,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF5, 0x18, 0x4A,
+0x51, 0xE4, 0xFF, 0xF7, 0x4C, 0xA4, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF5, 0x18, 0x4A,
+0x51, 0xE4, 0xDF, 0xF7, 0x4A, 0xA4, 0x20, 0xE8,
+0x01, 0x72, 0x22, 0x61, 0x05, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0xA5, 0xF5, 0x10, 0x4A, 0x0E, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF5, 0x0C, 0x4A,
+0x11, 0x10, 0x02, 0x72, 0x13, 0x60, 0x01, 0x72,
+0x13, 0x61, 0x08, 0x2D, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF5, 0x08, 0x4A, 0x51, 0xE4, 0xFF, 0xF7,
+0x54, 0xA4, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xC5, 0xF5, 0x00, 0x4A, 0x51, 0xE4, 0xDF, 0xF7,
+0x54, 0xA4, 0x20, 0xE8, 0x44, 0x67, 0x20, 0xE8,
+0x00, 0x6A, 0x20, 0xE8, 0x00, 0x6A, 0x30, 0xF0,
+0x20, 0x6C, 0xC1, 0xF1, 0x8C, 0x9C, 0x01, 0x4A,
+0x44, 0x33, 0x4B, 0x6D, 0x91, 0xE3, 0xAB, 0xED,
+0xA0, 0xC4, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF1,
+0x84, 0x9C, 0x1E, 0x72, 0x8D, 0xE3, 0x35, 0x6C,
+0x80, 0xC3, 0xED, 0x61, 0x20, 0xE8, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x67, 0xA2,
+0x28, 0x5B, 0x10, 0x61, 0x00, 0x6B, 0x45, 0xF6,
+0x67, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x48, 0x9A, 0x40, 0xA2, 0x00, 0xF6, 0x40, 0x32,
+0x00, 0xF6, 0x43, 0x32, 0x00, 0x52, 0x80, 0xF0,
+0x12, 0x60, 0x04, 0x10, 0x01, 0x4B, 0x45, 0xF6,
+0x67, 0xC2, 0x8D, 0x10, 0x30, 0xF0, 0x20, 0x68,
+0xA9, 0xF7, 0x05, 0x48, 0x00, 0x69, 0x91, 0x67,
+0x00, 0x18, 0xFE, 0x32, 0x60, 0xA0, 0xEC, 0xA0,
+0x30, 0xF0, 0x20, 0x6C, 0x04, 0xD3, 0xFF, 0xF7,
+0x7F, 0xA0, 0xB1, 0x67, 0xC2, 0x67, 0x05, 0xD3,
+0x00, 0xF0, 0x7B, 0xA8, 0x62, 0xF3, 0x18, 0x4C,
+0x01, 0x49, 0x06, 0xD3, 0x00, 0x18, 0x39, 0x3D,
+0x00, 0x6A, 0xFF, 0xF7, 0x5F, 0xC0, 0x40, 0xC0,
+0x03, 0x71, 0x00, 0x6A, 0x00, 0xF0, 0x5B, 0xC8,
+0x58, 0x67, 0x2E, 0x48, 0x08, 0xD2, 0xDF, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1, 0x50, 0x9A,
+0x30, 0xF0, 0x20, 0x68, 0x45, 0xF6, 0x18, 0x48,
+0xC0, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x54, 0x9A, 0x30, 0xF0, 0x20, 0x69, 0xFF, 0x6B,
+0xE0, 0xA2, 0x47, 0xF0, 0x59, 0xA0, 0x82, 0xF3,
+0x18, 0x49, 0x6C, 0xEE, 0x04, 0xD2, 0x47, 0xF0,
+0x4D, 0xA0, 0x6C, 0xEF, 0x91, 0x67, 0x05, 0xD2,
+0x47, 0xF0, 0x4C, 0xA0, 0x01, 0x6D, 0x06, 0xD2,
+0x67, 0xF0, 0x48, 0xA8, 0x07, 0xD2, 0x00, 0x18,
+0x39, 0x3D, 0x00, 0x6A, 0x7D, 0x67, 0x47, 0xF0,
+0x4C, 0xC0, 0x47, 0xF0, 0x4D, 0xC0, 0x47, 0x43,
+0x19, 0x4A, 0x60, 0xAA, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x58, 0x9A, 0x67, 0xF0, 0x68, 0xC8,
+0x91, 0x67, 0xC0, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x5C, 0x9A, 0x02, 0x6D, 0xE0, 0xA2,
+0x87, 0xF0, 0x47, 0xA0, 0x04, 0xD2, 0x67, 0xF0,
+0x5B, 0xA0, 0x05, 0xD2, 0x67, 0xF0, 0x5A, 0xA0,
+0x06, 0xD2, 0x87, 0xF0, 0x56, 0xA8, 0x07, 0xD2,
+0xFF, 0x6A, 0x4C, 0xEE, 0x4C, 0xEF, 0x00, 0x18,
+0x39, 0x3D, 0x00, 0x6B, 0x5D, 0x67, 0x67, 0xF0,
+0x7A, 0xC0, 0x67, 0xF0, 0x7B, 0xC0, 0x67, 0x42,
+0x19, 0x4B, 0x40, 0xAB, 0xC4, 0xF0, 0xBC, 0x98,
+0xE4, 0xF0, 0xC0, 0x98, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0xF3, 0x1C, 0x4C, 0x87, 0xF0, 0x56, 0xC8,
+0x00, 0x18, 0x39, 0x3D, 0x08, 0x93, 0xC4, 0xF0,
+0x7C, 0xD8, 0xE4, 0xF0, 0x60, 0xD8, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x2E, 0x68, 0x18, 0xEC,
+0x4C, 0xEF, 0x30, 0xF0, 0x20, 0x6B, 0x0C, 0xD6,
+0x0B, 0xD5, 0x05, 0xD7, 0x89, 0xF7, 0x18, 0x4B,
+0x20, 0xA5, 0x12, 0xE8, 0x01, 0xE3, 0x60, 0xA6,
+0x04, 0xD3, 0xB1, 0xA0, 0x03, 0x6B, 0x04, 0x96,
+0xAC, 0xEB, 0x83, 0x67, 0x4C, 0xEC, 0xC2, 0xEC,
+0x03, 0x60, 0x0C, 0x92, 0x60, 0xC2, 0xB0, 0x10,
+0xA0, 0xF0, 0x0E, 0x24, 0x2F, 0x59, 0xA0, 0xF0,
+0x0B, 0x60, 0x30, 0x6B, 0xAC, 0xEB, 0x4C, 0xEB,
+0xA0, 0xF0, 0x06, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61, 0x05, 0x95,
+0x04, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0xC2, 0xF3,
+0x08, 0x4C, 0xF1, 0x67, 0x00, 0x18, 0x39, 0x3D,
+0x05, 0x93, 0x01, 0x73, 0x03, 0x60, 0x05, 0x6B,
+0x01, 0x6A, 0x47, 0x10, 0x04, 0x6B, 0x00, 0x6A,
+0x44, 0x10, 0x05, 0x94, 0x01, 0x74, 0x02, 0x61,
+0x01, 0x4A, 0x01, 0x10, 0xFF, 0x4A, 0xFF, 0x6B,
+0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x48, 0x34,
+0x60, 0xF1, 0x10, 0x4B, 0x6D, 0xE4, 0xC0, 0xAB,
+0xFF, 0x6C, 0x03, 0x6D, 0x66, 0x67, 0x8C, 0xEB,
+0x04, 0xD3, 0xC2, 0x33, 0x8C, 0xEB, 0x91, 0xA0,
+0x00, 0x69, 0xE4, 0x67, 0xAC, 0xEF, 0x62, 0xEF,
+0x08, 0x61, 0x0D, 0x6F, 0x6C, 0xED, 0xEB, 0xEF,
+0xA8, 0x35, 0x8C, 0xEF, 0xAD, 0xEF, 0xF1, 0xC0,
+0x01, 0x69, 0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF1,
+0x10, 0x4C, 0x48, 0x32, 0x49, 0xE4, 0xE1, 0xAA,
+0xB1, 0xA0, 0x03, 0x6C, 0xE2, 0x32, 0xAC, 0xEC,
+0x42, 0xEC, 0x36, 0x61, 0xE5, 0xC0, 0x20, 0xF0,
+0x4C, 0xC0, 0x45, 0xA0, 0xFF, 0x72, 0x30, 0x60,
+0x92, 0xA0, 0x19, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x08, 0x6C, 0x8D, 0xEA, 0x52, 0xC0, 0x28, 0x10,
+0x01, 0x4A, 0xFF, 0x6C, 0x8C, 0xEA, 0x63, 0xEA,
+0x4A, 0x60, 0x30, 0xF0, 0x20, 0x6C, 0x48, 0x35,
+0x60, 0xF1, 0x10, 0x4C, 0x91, 0xE5, 0xA0, 0xAC,
+0xFF, 0x6C, 0xC5, 0x67, 0x8C, 0xEE, 0x2E, 0xEE,
+0x05, 0x2E, 0xA2, 0x35, 0x8C, 0xED, 0x04, 0x94,
+0x8E, 0xED, 0xAB, 0x25, 0x30, 0xF0, 0x20, 0x6C,
+0x48, 0x35, 0x60, 0xF1, 0x10, 0x4C, 0xB1, 0xE4,
+0xA1, 0xAC, 0xFF, 0x6C, 0xC5, 0x67, 0x8C, 0xEE,
+0x2E, 0xEE, 0xDE, 0x2E, 0x04, 0x96, 0xA2, 0x35,
+0x8C, 0xED, 0xCE, 0xED, 0xD9, 0x2D, 0x99, 0x17,
+0x00, 0x68, 0x09, 0x21, 0x5D, 0x67, 0x87, 0x42,
+0x09, 0x4C, 0x0B, 0x92, 0x80, 0xA4, 0x01, 0x68,
+0x80, 0xC2, 0x0C, 0x92, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF3, 0x04, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x01, 0x10,
+0x00, 0x68, 0x50, 0x67, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x68,
+0xF0, 0x67, 0xD0, 0x67, 0xE0, 0x17, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x65, 0x67, 0x01, 0x74, 0x4C, 0xEB, 0x4C, 0xEE,
+0xC0, 0xF0, 0x08, 0x61, 0xC0, 0xF0, 0x06, 0x2E,
+0x8C, 0x43, 0x4C, 0xEC, 0x08, 0x5C, 0x1B, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x98, 0x9A, 0x01, 0x6D, 0xAC, 0xEC,
+0xA0, 0xF0, 0x18, 0x24, 0x63, 0xF5, 0x5C, 0x9A,
+0x05, 0x5A, 0xA0, 0xF0, 0x13, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xC4, 0xF7, 0x10, 0x4A, 0x4D, 0xE3,
+0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF3, 0x1C, 0x4C,
+0xFF, 0xF7, 0xBC, 0xA3, 0xA5, 0x10, 0x04, 0x5B,
+0x1A, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x98, 0x9A, 0x01, 0x6D,
+0xAC, 0xEC, 0x80, 0xF0, 0x1B, 0x24, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x80, 0xF0, 0x16, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC4, 0xF7, 0x18, 0x4A,
+0x4D, 0xE3, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF4,
+0x08, 0x4C, 0xA0, 0xA3, 0x89, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x45, 0xF6, 0x18, 0x4C, 0x64, 0xF1,
+0xDF, 0xA4, 0x30, 0x6D, 0xCC, 0xED, 0x4C, 0xED,
+0x10, 0x75, 0x3D, 0x61, 0xA8, 0x43, 0xDC, 0x4D,
+0xC5, 0x67, 0x4C, 0xEE, 0x0A, 0x5E, 0x0E, 0x60,
+0x63, 0xF5, 0x58, 0x9C, 0x01, 0x6B, 0x6C, 0xEA,
+0x75, 0x22, 0x63, 0xF5, 0x5C, 0x9C, 0x05, 0x5A,
+0x71, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF4,
+0x14, 0x4C, 0x6A, 0x10, 0xA8, 0x43, 0xD2, 0x4D,
+0xC5, 0x67, 0x4C, 0xEE, 0x0A, 0x5E, 0x0E, 0x60,
+0x63, 0xF5, 0x58, 0x9C, 0x01, 0x6B, 0x6C, 0xEA,
+0x61, 0x22, 0x63, 0xF5, 0x5C, 0x9C, 0x05, 0x5A,
+0x5D, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF4,
+0x00, 0x4C, 0x56, 0x10, 0xA8, 0x43, 0xC8, 0x4D,
+0x4C, 0xED, 0x0A, 0x5D, 0x53, 0x60, 0x63, 0xF5,
+0x58, 0x9C, 0x01, 0x6D, 0xAC, 0xEA, 0x4E, 0x22,
+0x63, 0xF5, 0x5C, 0x9C, 0x05, 0x5A, 0x4A, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xA8, 0x43, 0x22, 0xF4,
+0x0C, 0x4C, 0xC8, 0x4D, 0x41, 0x10, 0x42, 0x2D,
+0xA8, 0x43, 0xFC, 0x4D, 0x4C, 0xED, 0x0A, 0x5D,
+0x10, 0x60, 0x63, 0xF5, 0x58, 0x9C, 0x01, 0x6D,
+0xAC, 0xEA, 0x38, 0x22, 0x63, 0xF5, 0x5C, 0x9C,
+0x05, 0x5A, 0x34, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0xA8, 0x43, 0x22, 0xF4, 0x18, 0x4C, 0xDC, 0x4D,
+0x2B, 0x10, 0xA8, 0x43, 0xF2, 0x4D, 0x4C, 0xED,
+0x0A, 0x5D, 0x10, 0x60, 0x63, 0xF5, 0x58, 0x9C,
+0x01, 0x6D, 0xAC, 0xEA, 0x23, 0x22, 0x63, 0xF5,
+0x5C, 0x9C, 0x05, 0x5A, 0x1F, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xA8, 0x43, 0x42, 0xF4, 0x04, 0x4C,
+0xF2, 0x4D, 0x16, 0x10, 0xA8, 0x43, 0xE8, 0x4D,
+0x4C, 0xED, 0x04, 0x5D, 0x13, 0x60, 0x63, 0xF5,
+0x58, 0x9C, 0x01, 0x6C, 0x8C, 0xEA, 0x0E, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xC9, 0xF3, 0x54, 0x9A,
+0x05, 0x5A, 0x08, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0xA8, 0x43, 0x42, 0xF4, 0x10, 0x4C, 0xE8, 0x4D,
+0x00, 0x18, 0x39, 0x3D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6B, 0x44, 0x67, 0x6C, 0xEA, 0xAC, 0xEB,
+0x01, 0x73, 0x0B, 0x60, 0x03, 0x23, 0x02, 0x73,
+0x0F, 0x60, 0x16, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x45, 0xF6, 0x18, 0x4B, 0x6D, 0xE2, 0x01, 0x6C,
+0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x6D, 0xE2, 0x03, 0x6C, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x6D, 0xE2, 0x07, 0x6C, 0x24, 0xF1, 0x90, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x63, 0xF5, 0x98, 0x9B, 0x10, 0x6D, 0xAC, 0xEC,
+0x0E, 0x24, 0x63, 0xF5, 0x9C, 0x9B, 0x05, 0x5C,
+0x0A, 0x61, 0x6D, 0xE2, 0x24, 0xF1, 0xD0, 0xA3,
+0x30, 0xF0, 0x20, 0x6C, 0x42, 0xF4, 0x1C, 0x4C,
+0xA2, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0xFF, 0x6E, 0x44, 0x67, 0x20, 0xF4, 0x0D, 0x6B,
+0x9D, 0x67, 0x68, 0xCC, 0xCC, 0xEA, 0x20, 0xF4,
+0x0F, 0x6B, 0x69, 0xCC, 0x44, 0x33, 0x6D, 0xE4,
+0x68, 0xAB, 0x1F, 0xF7, 0x00, 0x6C, 0xAC, 0xEE,
+0x6C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF7,
+0x9C, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF7, 0x80, 0x9C, 0x91, 0xE3, 0xA0, 0xA4,
+0xF1, 0x6C, 0xAC, 0xEC, 0xC4, 0x35, 0x8D, 0xED,
+0x00, 0xF6, 0xA0, 0x34, 0x00, 0xF6, 0x83, 0x34,
+0xFF, 0x6D, 0xAC, 0xEC, 0x1F, 0xF7, 0x00, 0x6D,
+0x6C, 0xED, 0x02, 0xF0, 0x00, 0x75, 0x01, 0x60,
+0x05, 0x2D, 0x30, 0xF0, 0x20, 0x6D, 0x00, 0xF7,
+0xBC, 0x9D, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6D,
+0x20, 0xF7, 0xA0, 0x9D, 0xAD, 0xE3, 0x80, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0x63, 0xF5, 0x98, 0x9B, 0x10, 0x6D, 0xAC, 0xEC,
+0x0B, 0x24, 0x63, 0xF5, 0x7C, 0x9B, 0x05, 0x5B,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF4,
+0x14, 0x4C, 0xA2, 0x67, 0x00, 0x18, 0x39, 0x3D,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x8C, 0xE9,
+0x45, 0xF6, 0x18, 0x48, 0x09, 0xE1, 0x24, 0xF1,
+0xB0, 0xA2, 0x91, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0x23, 0x46, 0x63, 0xF5, 0x58, 0x98, 0x10, 0x6B,
+0x6C, 0xEA, 0x0E, 0x22, 0x63, 0xF5, 0x5C, 0x98,
+0x05, 0x5A, 0x0A, 0x61, 0x04, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0x82, 0xF4, 0x0C, 0x4C, 0x24, 0xF1,
+0xD0, 0xA2, 0xB1, 0x67, 0x00, 0x18, 0x39, 0x3D,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0xE1, 0xF1, 0x60, 0x9B, 0x4C, 0xEC,
+0x08, 0xD4, 0x00, 0xA3, 0x10, 0x6B, 0x30, 0xF0,
+0x20, 0x69, 0x6C, 0xE8, 0x13, 0x30, 0x4C, 0xE8,
+0x45, 0xF6, 0x18, 0x49, 0x35, 0xE0, 0x24, 0xF1,
+0x4C, 0xA5, 0x06, 0xD5, 0x82, 0x67, 0x07, 0xD2,
+0x00, 0x18, 0xFE, 0x32, 0x82, 0x67, 0x09, 0xD2,
+0x00, 0x18, 0xA5, 0x43, 0x06, 0x93, 0x0A, 0xD2,
+0x63, 0xF5, 0x58, 0x99, 0x24, 0xF1, 0x6E, 0xA3,
+0x10, 0x6D, 0xAC, 0xEA, 0x06, 0xD3, 0x10, 0x22,
+0x63, 0xF5, 0x5C, 0x99, 0x05, 0x5A, 0x0C, 0x61,
+0x24, 0xF1, 0x54, 0xA1, 0x07, 0x95, 0x08, 0x96,
+0x09, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF4,
+0x04, 0x4C, 0x04, 0xD2, 0x00, 0x18, 0x39, 0x3D,
+0x08, 0x92, 0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x24, 0xF1, 0xB3, 0xA2,
+0x01, 0x6C, 0x64, 0x67, 0x64, 0xE8, 0xAD, 0xEB,
+0x24, 0xF1, 0x73, 0xC2, 0x06, 0x93, 0x0A, 0x95,
+0x01, 0x4B, 0xAE, 0xEB, 0x27, 0x2B, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x24, 0xF1, 0x93, 0xA2, 0x01, 0x6B, 0x64, 0xE8,
+0x6F, 0xEB, 0x8C, 0xEB, 0x24, 0xF1, 0x73, 0xC2,
+0x19, 0x10, 0x24, 0xF1, 0x74, 0xA2, 0x67, 0xE8,
+0x8C, 0xEB, 0x14, 0x23, 0x63, 0xF5, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x0B, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xC2, 0xF4, 0x04, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x90, 0x67, 0x00, 0x18,
+0x4E, 0x46, 0x18, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x0B, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xC2, 0xF4, 0x10, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x23, 0x46, 0x0F, 0x97, 0x0E, 0x91,
+0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x69,
+0x06, 0xD2, 0x89, 0xF7, 0x04, 0x49, 0x00, 0x68,
+0x40, 0xA1, 0x06, 0x93, 0x6E, 0xEA, 0x80, 0xF0,
+0x1D, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x07, 0xD2, 0x24, 0xF1, 0x52, 0xA2,
+0x01, 0x6B, 0x47, 0xE8, 0x6C, 0xEA, 0x80, 0xF0,
+0x11, 0x22, 0x06, 0x94, 0x00, 0x18, 0xFE, 0x32,
+0x62, 0xA1, 0x82, 0x67, 0x09, 0xD2, 0x08, 0xD3,
+0x00, 0x18, 0xA5, 0x43, 0x07, 0x93, 0x0A, 0xD2,
+0x63, 0xF5, 0x58, 0x9B, 0x10, 0x6B, 0x6C, 0xEA,
+0x10, 0x22, 0x07, 0x93, 0x63, 0xF5, 0x5C, 0x9B,
+0x05, 0x5A, 0x0B, 0x61, 0x08, 0x92, 0x06, 0x95,
+0x09, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0xC2, 0xF4,
+0x1C, 0x4C, 0xD0, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0x39, 0x3D, 0x08, 0x92, 0x0A, 0x93, 0x01, 0x4A,
+0x62, 0xEA, 0x21, 0x60, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x23, 0x46, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x24, 0xF1, 0x94, 0xA2,
+0x01, 0x6B, 0x64, 0xE8, 0x6F, 0xEB, 0x8C, 0xEB,
+0x24, 0xF1, 0x74, 0xC2, 0x63, 0xF5, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x57, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x53, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x02, 0xF5, 0x04, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x4B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x24, 0xF1,
+0x94, 0xA2, 0x01, 0x6B, 0x64, 0xE8, 0x8D, 0xEB,
+0x24, 0xF1, 0x74, 0xC2, 0x63, 0xF5, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x0B, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x02, 0xF5, 0x10, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x24, 0xF1, 0x73, 0xA2,
+0x01, 0x6C, 0x67, 0xE8, 0x8C, 0xEB, 0x13, 0x23,
+0x63, 0xF5, 0x78, 0x9A, 0x10, 0x6C, 0x8C, 0xEB,
+0x0A, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF5,
+0x1C, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x90, 0x67,
+0x00, 0x18, 0x4E, 0x46, 0x13, 0x10, 0x63, 0xF5,
+0x78, 0x9A, 0x10, 0x6C, 0x8C, 0xEB, 0x0A, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF5, 0x08, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x23, 0x46, 0x01, 0x48, 0x02, 0x70,
+0x01, 0x49, 0x5F, 0xF7, 0x19, 0x61, 0x0F, 0x97,
+0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEE, 0x2E, 0x68, 0x18, 0xEE,
+0x30, 0xF0, 0x20, 0x6B, 0x89, 0xF7, 0x18, 0x4B,
+0x4C, 0xEC, 0x4C, 0xEF, 0x4C, 0xED, 0x07, 0xD6,
+0x08, 0xD7, 0x12, 0xE8, 0x01, 0xE3, 0x7F, 0x6B,
+0x6C, 0xEC, 0x1F, 0x2D, 0x0C, 0x5C, 0x07, 0x60,
+0x30, 0xF0, 0x20, 0x69, 0x05, 0xF1, 0x00, 0x49,
+0x85, 0xE1, 0x01, 0x6A, 0x37, 0x10, 0x08, 0x93,
+0xF4, 0x4C, 0x4C, 0xEC, 0x08, 0x2B, 0x03, 0x69,
+0x38, 0xEC, 0x30, 0xF0, 0x20, 0x6A, 0x65, 0xF2,
+0x10, 0x4A, 0x12, 0xEC, 0x29, 0x10, 0xE0, 0x4C,
+0x4C, 0xEC, 0x03, 0x69, 0x38, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0x05, 0xF2, 0x14, 0x4A, 0x12, 0xEC,
+0x1F, 0x10, 0x0C, 0x5C, 0x08, 0x60, 0x30, 0xF0,
+0x20, 0x69, 0x05, 0xF1, 0x0C, 0x49, 0x01, 0x6B,
+0x85, 0xE1, 0x06, 0xD3, 0x18, 0x10, 0x08, 0x95,
+0xF4, 0x4C, 0x4C, 0xEC, 0x08, 0x2D, 0x03, 0x69,
+0x38, 0xEC, 0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF3,
+0x14, 0x4A, 0x12, 0xEC, 0x09, 0x10, 0xE0, 0x4C,
+0x4C, 0xEC, 0x03, 0x69, 0x38, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0xA5, 0xF2, 0x18, 0x4A, 0x12, 0xEC,
+0x85, 0xE2, 0x00, 0x6A, 0x06, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61,
+0xA0, 0xA1, 0xC1, 0xA1, 0xE2, 0xA1, 0x30, 0xF0,
+0x20, 0x6C, 0x22, 0xF5, 0x14, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x0C, 0x23, 0x63, 0xF5, 0x5C, 0x9A,
+0x05, 0x5A, 0x08, 0x61, 0x06, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF5, 0x08, 0x4C, 0x03, 0x6E,
+0x00, 0x18, 0x39, 0x3D, 0x07, 0x94, 0xC0, 0xA1,
+0x04, 0x6D, 0x00, 0x18, 0x96, 0x41, 0x07, 0x94,
+0xC1, 0xA1, 0x05, 0x6D, 0x00, 0x18, 0x96, 0x41,
+0x07, 0x94, 0xC2, 0xA1, 0x06, 0x6D, 0x00, 0x18,
+0x96, 0x41, 0x06, 0x93, 0x0D, 0x2B, 0x01, 0x6A,
+0x4B, 0xEA, 0x9D, 0x67, 0x00, 0x6D, 0x0A, 0xD1,
+0x50, 0xC4, 0x51, 0xC4, 0x52, 0xC4, 0x06, 0xD5,
+0x25, 0x67, 0x09, 0xD5, 0x0B, 0xD0, 0x0B, 0x10,
+0x80, 0xA1, 0x07, 0x95, 0x08, 0x96, 0x00, 0x18,
+0x88, 0x43, 0x92, 0xA0, 0x19, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x72, 0xC0, 0x9F, 0x10, 0x0A, 0x92,
+0x00, 0xA2, 0x2C, 0x70, 0x04, 0x61, 0x08, 0x93,
+0x2C, 0x68, 0x01, 0x2B, 0x0C, 0x68, 0x07, 0x95,
+0x08, 0x96, 0x90, 0x67, 0x01, 0x49, 0x00, 0x18,
+0x88, 0x43, 0xFF, 0x72, 0xFF, 0x6B, 0x6C, 0xE9,
+0x07, 0x61, 0x46, 0x70, 0x11, 0x60, 0x09, 0x94,
+0x91, 0xE1, 0x6C, 0xEC, 0x09, 0xD4, 0x07, 0x10,
+0x06, 0x96, 0xBD, 0x67, 0xD1, 0xE5, 0x01, 0x4E,
+0x6C, 0xEE, 0x50, 0xC4, 0x06, 0xD6, 0x0A, 0x92,
+0x03, 0x71, 0x01, 0x4A, 0x0A, 0xD2, 0xDB, 0x61,
+0x06, 0x92, 0x0B, 0x90, 0x03, 0x6B, 0xFF, 0x4A,
+0x6C, 0xEA, 0xB2, 0xA0, 0x4C, 0x34, 0x19, 0x6A,
+0x4B, 0xEA, 0xAC, 0xEA, 0x8D, 0xEA, 0x52, 0xC0,
+0x09, 0x94, 0xFF, 0x6A, 0x06, 0x5C, 0x6A, 0x60,
+0x34, 0xA0, 0x02, 0x6A, 0x32, 0x31, 0x6C, 0xE9,
+0x7E, 0xA0, 0x6C, 0xEA, 0x2C, 0x22, 0x6F, 0x41,
+0x01, 0x6A, 0x63, 0xEA, 0x28, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B, 0x63, 0xF5,
+0x98, 0x9B, 0x4C, 0xEC, 0x0A, 0x24, 0x63, 0xF5,
+0x5C, 0x9B, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF5, 0x00, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0xBD, 0x67, 0x90, 0xA5, 0x00, 0x18,
+0x1F, 0x41, 0x11, 0x2A, 0xDD, 0x67, 0x91, 0xA6,
+0x00, 0x18, 0x1F, 0x41, 0x00, 0xF0, 0x11, 0x04,
+0x07, 0x2A, 0x5D, 0x67, 0x92, 0xA2, 0x00, 0x18,
+0x1F, 0x41, 0x05, 0x22, 0x00, 0xF0, 0x12, 0x04,
+0x04, 0x05, 0x00, 0x18, 0x5B, 0x43, 0x7E, 0xA0,
+0x40, 0x6A, 0x6C, 0xEA, 0x19, 0x22, 0x08, 0x93,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0xE5, 0xF5,
+0x1C, 0x4A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE5, 0xF5, 0x14, 0x4A, 0xFF, 0x49, 0x01, 0x6B,
+0x23, 0xEB, 0x0A, 0x61, 0xBD, 0x67, 0x91, 0xA5,
+0x40, 0x9A, 0x64, 0xEC, 0x4C, 0xEB, 0x04, 0x23,
+0x01, 0x6A, 0x4B, 0xEA, 0x90, 0xC5, 0x51, 0xC5,
+0xDD, 0x67, 0x71, 0xA6, 0xFF, 0x73, 0x05, 0x60,
+0x52, 0xA6, 0xFF, 0x72, 0x02, 0x60, 0x66, 0xC0,
+0x0E, 0x10, 0x7D, 0x67, 0x51, 0xA3, 0xFF, 0x72,
+0x03, 0x60, 0x72, 0xA3, 0xFF, 0x73, 0x07, 0x60,
+0x9D, 0x67, 0x51, 0xA4, 0xFF, 0x72, 0x04, 0x61,
+0x52, 0xA4, 0xFF, 0x72, 0x01, 0x60, 0x45, 0xC0,
+0xBD, 0x67, 0x50, 0xA5, 0x0F, 0x97, 0x0E, 0x91,
+0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x00, 0x6B, 0x8C, 0xE9, 0x43, 0x67,
+0x91, 0x67, 0x87, 0xEB, 0x01, 0x6D, 0xAC, 0xEC,
+0x03, 0x24, 0x01, 0x4A, 0xFF, 0x6C, 0x8C, 0xEA,
+0x01, 0x4B, 0x04, 0x73, 0xF5, 0x61, 0x01, 0x72,
+0x2C, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0xAC, 0x9A, 0x21, 0xF1, 0x1C, 0x68, 0x90, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x01, 0x71,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x90, 0x67,
+0xE0, 0xF7, 0xAC, 0x9A, 0x07, 0x10, 0x02, 0x71,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0xB0, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0xD2, 0x11,
+0x04, 0x71, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0x80, 0xF6, 0xBC, 0x9A, 0xF6, 0x17,
+0x08, 0x71, 0xC0, 0xF1, 0x09, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x90, 0x67, 0xC1, 0xF0, 0xA0, 0x9A,
+0xED, 0x17, 0x02, 0x72, 0xA0, 0xF0, 0x11, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xAC, 0x9A,
+0x21, 0xF1, 0x1C, 0x68, 0x90, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x41, 0xF1, 0x00, 0x6C,
+0xF0, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x03, 0x71, 0x1C, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0xAC, 0x9A, 0x90, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF1, 0xB0, 0x9A, 0x90, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x41, 0xF1, 0x00, 0x6C,
+0x00, 0xF3, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x41, 0xF1, 0x00, 0x6C, 0x01, 0xF4,
+0x00, 0x6D, 0x81, 0x10, 0x05, 0x71, 0x15, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0xAC, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0xBC, 0x9A,
+0x90, 0x67, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x41, 0xF1, 0x00, 0x6C, 0x00, 0xF3, 0x00, 0x6D,
+0x2D, 0x10, 0x09, 0x71, 0x15, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0xAC, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0xA0, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x41, 0xF1,
+0x00, 0x6C, 0x00, 0xF3, 0x00, 0x6D, 0x4C, 0x10,
+0x06, 0x71, 0x1C, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF1, 0xB0, 0x9A, 0x90, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0xBC, 0x9A, 0x90, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x41, 0xF1, 0x00, 0x6C,
+0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x41, 0xF1, 0x00, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x35, 0x10, 0x0A, 0x71, 0x15, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xB0, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0xA0, 0x9A,
+0x90, 0x67, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x41, 0xF1, 0x00, 0x6C, 0x01, 0xF4, 0x00, 0x6D,
+0x17, 0x10, 0x0C, 0x71, 0x20, 0xF1, 0x0C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0xBC, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0xA0, 0x9A,
+0x90, 0x67, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x41, 0xF1, 0x00, 0x6C, 0x06, 0xF0, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x41, 0xF1,
+0x00, 0x6C, 0x18, 0xF0, 0x00, 0x6D, 0x01, 0x6E,
+0x0D, 0x11, 0x03, 0x72, 0x00, 0xF1, 0x0C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xAC, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0xD1, 0x67, 0x41, 0xF1,
+0x00, 0x68, 0x00, 0x18, 0x0E, 0x29, 0x90, 0x67,
+0xF0, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xB4, 0x9A,
+0x90, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x07, 0x71, 0x2C, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x2C, 0x9A, 0x21, 0xF1, 0x1C, 0x6C,
+0x00, 0x6E, 0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xB0, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xBC, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x02, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0x01, 0xF4, 0x00, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0x06, 0xF0,
+0x00, 0x6D, 0x2D, 0x10, 0x0B, 0x71, 0x3C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0xAC, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0x30, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x01, 0x6E,
+0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0xA0, 0x9A, 0x21, 0xF1,
+0x1C, 0x6C, 0x02, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0x00, 0xF3, 0x00, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0x01, 0xF4,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0x18, 0xF0, 0x00, 0x6D, 0x02, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF1, 0xB8, 0x9A, 0x90, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0xE1, 0xF1, 0xBC, 0x9A, 0x80, 0x10,
+0x0D, 0x71, 0x41, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x2C, 0x9A, 0x21, 0xF1, 0x1C, 0x6C,
+0x00, 0x6E, 0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0xBC, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0xA0, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x02, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0x06, 0xF0, 0x00, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0x18, 0xF0,
+0x00, 0x6D, 0x02, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xB8, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0xB1, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x90, 0x67,
+0xE1, 0xF1, 0xB0, 0x9A, 0x42, 0x10, 0x0E, 0x71,
+0x43, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0x30, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x00, 0x6E,
+0xB1, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0xBC, 0x9A, 0x21, 0xF1,
+0x1C, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0xA0, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x02, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x90, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x90, 0x67,
+0x06, 0xF0, 0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x90, 0x67, 0x18, 0xF0, 0x00, 0x6D,
+0x02, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF1, 0xBC, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0xAC, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x90, 0x67,
+0xB1, 0x67, 0x02, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF4, 0x63, 0x17, 0x62,
+0x16, 0xD1, 0x15, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x45, 0xF6, 0x18, 0x48, 0xEB, 0xF4, 0x5D, 0xA0,
+0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF5, 0x08, 0x4C,
+0xA2, 0x67, 0x0D, 0xD2, 0x00, 0x18, 0x39, 0x3D,
+0x0D, 0x93, 0x29, 0x2B, 0x30, 0xF0, 0x20, 0x69,
+0x89, 0xF7, 0x18, 0x49, 0x00, 0x68, 0x90, 0x67,
+0x00, 0x18, 0x12, 0x12, 0x1B, 0x22, 0x71, 0xA1,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x14, 0x2A, 0x90, 0x67, 0x00, 0x18,
+0xFE, 0x32, 0xFF, 0x6B, 0x0C, 0xEB, 0x01, 0x73,
+0x0A, 0x61, 0x7F, 0x6D, 0x4C, 0xED, 0x30, 0xF0,
+0x20, 0x6C, 0xFF, 0x6A, 0x62, 0xF5, 0x14, 0x4C,
+0x4C, 0xED, 0x00, 0x18, 0x39, 0x3D, 0x90, 0x67,
+0x00, 0x18, 0x5F, 0x51, 0x01, 0x48, 0x9F, 0x70,
+0x2E, 0x49, 0xDD, 0x61, 0xB3, 0x10, 0x0D, 0x92,
+0xFF, 0x6B, 0xFF, 0x4A, 0x6C, 0xEA, 0x03, 0x5A,
+0xA0, 0xF0, 0x09, 0x60, 0x30, 0xF0, 0x20, 0x6B,
+0xAE, 0xF3, 0x04, 0x4B, 0x10, 0xD3, 0x0D, 0x93,
+0x30, 0xF0, 0x20, 0x6A, 0x2E, 0xF6, 0x00, 0x4A,
+0x61, 0xE0, 0x30, 0xF0, 0x20, 0x69, 0x0F, 0xD2,
+0x64, 0xF1, 0x03, 0x48, 0x00, 0x6A, 0x89, 0xF7,
+0x18, 0x49, 0x11, 0xD0, 0x0C, 0xD2, 0x0C, 0x94,
+0x00, 0x18, 0x12, 0x12, 0x7F, 0x22, 0x71, 0xA1,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x78, 0x2A, 0x10, 0x92, 0x0F, 0x95,
+0x06, 0x00, 0x40, 0x9A, 0x90, 0x67, 0x14, 0x6E,
+0x6C, 0xEA, 0x0C, 0x93, 0x0E, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x69, 0xE2,
+0x2A, 0xF4, 0x54, 0xA2, 0x12, 0xD2, 0x00, 0x18,
+0xA1, 0x1E, 0x0C, 0x94, 0x0E, 0x96, 0x12, 0x97,
+0xB0, 0x67, 0x00, 0x18, 0x6A, 0x43, 0x64, 0x6B,
+0x4B, 0xE3, 0x11, 0x93, 0x40, 0xC3, 0x0C, 0x92,
+0xFF, 0x6B, 0x6C, 0xEA, 0x01, 0x72, 0x1C, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF5, 0x00, 0x4C,
+0x01, 0x6D, 0x00, 0x18, 0x39, 0x3D, 0x09, 0x92,
+0x06, 0x95, 0x07, 0x96, 0x04, 0xD2, 0x08, 0x97,
+0x0A, 0x92, 0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF5,
+0x08, 0x4C, 0x05, 0xD2, 0x00, 0x18, 0x39, 0x3D,
+0x11, 0x92, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF5,
+0x0C, 0x4C, 0xA0, 0xA2, 0x00, 0x18, 0x39, 0x3D,
+0x0C, 0x94, 0x00, 0x18, 0x5F, 0x51, 0x0D, 0x93,
+0x03, 0x73, 0x34, 0x61, 0x20, 0xF0, 0x44, 0xA1,
+0x20, 0xF0, 0x65, 0xA1, 0x63, 0xEA, 0x05, 0x61,
+0x20, 0xF0, 0x66, 0xA1, 0x00, 0x68, 0x63, 0xEA,
+0x0A, 0x60, 0x20, 0xF0, 0x05, 0xA1, 0x20, 0xF0,
+0x46, 0xA1, 0x43, 0xE8, 0x18, 0x67, 0x01, 0x58,
+0x18, 0x67, 0x02, 0x6A, 0x03, 0xE2, 0x0C, 0x93,
+0xFF, 0x6A, 0x6C, 0xEA, 0x01, 0x72, 0x1A, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x49, 0xE0, 0xEB, 0xF4, 0x98, 0xA2, 0x0E, 0xD2,
+0x00, 0x18, 0xB0, 0x47, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0xF5, 0x14, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x0E, 0x92, 0x30, 0xF0, 0x20, 0x6C,
+0xC2, 0xF5, 0x00, 0x4C, 0xEB, 0xF4, 0xB8, 0xA2,
+0x00, 0x18, 0x39, 0x3D, 0x0C, 0x93, 0x10, 0x92,
+0x2E, 0x49, 0x01, 0x4B, 0x0C, 0xD3, 0x0F, 0x93,
+0x04, 0x4A, 0x10, 0xD2, 0x14, 0x4B, 0x11, 0x92,
+0x0F, 0xD3, 0x0C, 0x93, 0x2E, 0x4A, 0x11, 0xD2,
+0x9F, 0x73, 0x7F, 0xF7, 0x0C, 0x61, 0x0D, 0x92,
+0x03, 0x5A, 0x1B, 0x60, 0x0D, 0x93, 0x30, 0xF0,
+0x20, 0x68, 0x45, 0xF6, 0x18, 0x48, 0x05, 0xE3,
+0xEB, 0xF4, 0xB8, 0xA1, 0x30, 0xF0, 0x20, 0x6C,
+0xC2, 0xF5, 0x10, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0xEB, 0xF4, 0x98, 0xA1, 0x00, 0x18, 0xB0, 0x47,
+0x01, 0x6A, 0xEB, 0xF4, 0x5E, 0xC0, 0xEB, 0xF4,
+0x5D, 0xA0, 0x01, 0x4A, 0xEB, 0xF4, 0x5D, 0xC0,
+0x12, 0x10, 0x0D, 0x90, 0x03, 0x6A, 0x4E, 0xE8,
+0x0E, 0x28, 0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF5,
+0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xEB, 0xF4,
+0x1E, 0xC2, 0xEB, 0xF4, 0x1D, 0xC2, 0x17, 0x97,
+0x16, 0x91, 0x15, 0x90, 0x0C, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEE, 0x2E, 0x68, 0x18, 0xEE,
+0x12, 0x91, 0x13, 0x93, 0x4C, 0xEF, 0x4C, 0xEC,
+0x4C, 0xED, 0x4C, 0xE9, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x08, 0xD7,
+0x12, 0xE8, 0x01, 0xE2, 0x5C, 0xA0, 0xEE, 0xEA,
+0x05, 0x2A, 0xFF, 0xA0, 0x03, 0x6A, 0xEC, 0xEA,
+0x2E, 0xEA, 0x25, 0x22, 0x5D, 0x67, 0xE7, 0x42,
+0x19, 0x4F, 0xE0, 0xA7, 0xA4, 0x35, 0x8D, 0xED,
+0xF2, 0xC2, 0xD3, 0xC2, 0x76, 0xC2, 0xB4, 0xC2,
+0x59, 0xA0, 0x7D, 0x67, 0x38, 0xC3, 0x57, 0xC3,
+0x0C, 0x6A, 0x50, 0xC3, 0x07, 0x6A, 0x4F, 0xCB,
+0x04, 0x94, 0x05, 0x95, 0x06, 0x96, 0x07, 0x97,
+0x00, 0x18, 0xAA, 0x33, 0x5D, 0x67, 0x67, 0x42,
+0x19, 0x4B, 0x40, 0xA3, 0x9F, 0xA0, 0x03, 0x6B,
+0x5C, 0xC0, 0x04, 0x6A, 0x4B, 0xEA, 0x2C, 0xEB,
+0x8C, 0xEA, 0x6D, 0xEA, 0x5F, 0xC0, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0x6A, 0x7D, 0x67, 0x4C, 0xEE, 0x4C, 0xEF,
+0x20, 0xF0, 0xBC, 0xC3, 0x08, 0xD6, 0x06, 0xD7,
+0x24, 0x67, 0x20, 0xF0, 0x9C, 0xA3, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF1, 0x6C, 0x9B, 0x4C, 0xE9,
+0x07, 0xD4, 0x34, 0x34, 0x6D, 0xE4, 0x60, 0xA3,
+0x91, 0x67, 0x0F, 0x05, 0x6C, 0xEA, 0xC7, 0x67,
+0x09, 0xD2, 0x00, 0x18, 0xCB, 0x43, 0x00, 0xF1,
+0x06, 0x2A, 0x2E, 0x68, 0x18, 0xE9, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x12, 0xE8,
+0x01, 0xE2, 0x08, 0x92, 0x40, 0x2A, 0x63, 0xA0,
+0x48, 0xA0, 0x6E, 0xEA, 0x05, 0x22, 0x7D, 0x67,
+0x87, 0x43, 0x19, 0x4C, 0x60, 0xAC, 0x75, 0xC8,
+0x72, 0xA0, 0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x52, 0xC0, 0x9D, 0x67, 0x20, 0xF0, 0x5C, 0xA4,
+0x6E, 0xA0, 0xD1, 0x67, 0x43, 0xC0, 0x00, 0x6A,
+0x59, 0xC0, 0x5A, 0xC0, 0x10, 0x6A, 0x6D, 0xEA,
+0x4E, 0xC0, 0x06, 0x95, 0x20, 0xF0, 0xFC, 0xA4,
+0x00, 0x6A, 0x82, 0x67, 0x04, 0xD5, 0xA2, 0x67,
+0x05, 0xD2, 0x00, 0x18, 0x46, 0x49, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x75, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x71, 0x61,
+0x5D, 0x67, 0x20, 0xF0, 0xDC, 0xA2, 0x06, 0x97,
+0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF5, 0x08, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x00, 0x6B,
+0x07, 0xD3, 0x43, 0x67, 0x69, 0x10, 0x07, 0x94,
+0x7F, 0x6A, 0x40, 0x6B, 0x8C, 0xEA, 0x92, 0xA0,
+0xBD, 0x67, 0x8D, 0xEB, 0x72, 0xC0, 0x20, 0xF0,
+0x7C, 0xA5, 0x8E, 0xA0, 0x63, 0xC0, 0x11, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0x6E, 0xC0, 0x45, 0xF6, 0x18, 0x4C, 0x30, 0xF0,
+0x20, 0x6B, 0x05, 0xF1, 0x18, 0x4B, 0x91, 0xE2,
+0x6D, 0xE2, 0xC8, 0xF3, 0x9E, 0xA4, 0x60, 0xA3,
+0xA4, 0x44, 0x62, 0xED, 0x01, 0x60, 0x8F, 0xE3,
+0x78, 0xC0, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF3,
+0x1C, 0x4B, 0x69, 0xE2, 0x9B, 0xA0, 0x40, 0xA2,
+0x43, 0xEC, 0x03, 0x60, 0x58, 0xA0, 0x04, 0x4A,
+0x58, 0xC0, 0x7D, 0x67, 0x20, 0xF0, 0x5C, 0x83,
+0x00, 0x52, 0x03, 0x60, 0x58, 0xA0, 0x05, 0x4A,
+0x58, 0xC0, 0x6E, 0xA0, 0x08, 0x6A, 0x6C, 0xEA,
+0x0B, 0x22, 0x5D, 0x67, 0x20, 0xF0, 0xDC, 0xA2,
+0xF8, 0xA0, 0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF5,
+0x1C, 0x4C, 0xB1, 0x67, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x18, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x14, 0x61, 0x7D, 0x67, 0x20, 0xF0, 0xDC, 0xA3,
+0x58, 0xA0, 0x06, 0x97, 0x30, 0xF0, 0x20, 0x6C,
+0x02, 0xF6, 0x0C, 0x4C, 0xB1, 0x67, 0x04, 0xD2,
+0x00, 0x18, 0x39, 0x3D, 0x01, 0x6C, 0x07, 0xD4,
+0x06, 0x10, 0x00, 0x6D, 0x07, 0xD5, 0x45, 0x67,
+0x03, 0x10, 0x01, 0x6A, 0x07, 0xD2, 0x40, 0x6A,
+0x06, 0x95, 0x09, 0x94, 0x07, 0x6B, 0x8C, 0xEB,
+0xAC, 0x34, 0x8D, 0xE3, 0x4D, 0xEB, 0x00, 0xF6,
+0x60, 0x33, 0x00, 0xF6, 0x63, 0x33, 0x06, 0xD3,
+0x06, 0x92, 0xFF, 0x6B, 0x6C, 0xEA, 0x06, 0xD2,
+0x96, 0xA0, 0x01, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA,
+0x0C, 0x22, 0x7D, 0x67, 0x20, 0xF0, 0xBC, 0xA3,
+0x91, 0x67, 0x00, 0x18, 0x26, 0x1F, 0x3E, 0x32,
+0x36, 0x2A, 0x06, 0x94, 0xBF, 0x6A, 0x4C, 0xEC,
+0x06, 0xD4, 0x5D, 0x67, 0x20, 0xF0, 0xDC, 0xA2,
+0x91, 0x67, 0x00, 0x6D, 0x00, 0x18, 0x96, 0x41,
+0x06, 0x96, 0x91, 0x67, 0x01, 0x6D, 0x00, 0x18,
+0x96, 0x41, 0x91, 0x67, 0x00, 0x18, 0xAC, 0x46,
+0x7D, 0x67, 0x20, 0xF0, 0xBC, 0xA3, 0x08, 0x96,
+0x91, 0x67, 0x34, 0x31, 0x00, 0x18, 0x9A, 0x45,
+0x30, 0xF0, 0x20, 0x6A, 0x9D, 0x67, 0x21, 0xF1,
+0x50, 0x9A, 0x20, 0xF0, 0x7C, 0xA4, 0xA7, 0x44,
+0x49, 0xE1, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x4C, 0x9A, 0x11, 0x4D, 0xA0, 0xA5,
+0x49, 0xE1, 0xA0, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x40, 0x9A, 0x45, 0xE1, 0x47, 0x44,
+0x15, 0x4A, 0x40, 0xA2, 0x40, 0xC1, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x24, 0x67, 0x4C, 0xE9, 0x2E, 0x6C,
+0x98, 0xE9, 0x30, 0xF0, 0x20, 0x6B, 0x4C, 0xED,
+0x89, 0xF7, 0x18, 0x4B, 0x04, 0xD5, 0x33, 0x68,
+0x12, 0xEC, 0x91, 0xE3, 0xB6, 0xA4, 0x01, 0x6B,
+0xAC, 0xEB, 0x4C, 0xEB, 0x03, 0x23, 0x00, 0xA4,
+0xFF, 0x48, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x02, 0x6C, 0x8C, 0xEB, 0x0C, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x22, 0xF6, 0x04, 0x4C, 0xB1, 0x67,
+0xD0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x04, 0x97,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x6A, 0x49, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x2E, 0x68, 0x18, 0xEC, 0x4C, 0xED, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x08, 0xD4,
+0x01, 0x6C, 0x0A, 0xD5, 0x12, 0xE8, 0x01, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x8C, 0xEB, 0x0A, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF6, 0x18, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x08, 0x94, 0x00, 0x18,
+0xFE, 0x32, 0x7D, 0x67, 0x50, 0xC3, 0x90, 0xA3,
+0x03, 0x6A, 0x06, 0xD4, 0xA0, 0xA0, 0x06, 0x91,
+0x7F, 0x6C, 0x07, 0xD5, 0x71, 0xA0, 0x8C, 0xE9,
+0x72, 0x36, 0x6A, 0x33, 0x4C, 0xEB, 0x4C, 0xEE,
+0x5D, 0x67, 0xA7, 0x42, 0x11, 0x4D, 0xA0, 0xA5,
+0x71, 0xC2, 0x09, 0xD6, 0xA8, 0xC0, 0xB2, 0xA0,
+0x04, 0x6A, 0x4B, 0xEA, 0xAC, 0xEA, 0x6D, 0xEA,
+0x01, 0x6B, 0x6B, 0xEB, 0x65, 0xC0, 0x66, 0xC0,
+0x20, 0xF0, 0x6C, 0xC0, 0x20, 0xF0, 0x6D, 0xC0,
+0x73, 0xA0, 0x6C, 0xEC, 0x80, 0x6B, 0x6B, 0xEB,
+0x6D, 0xEA, 0x67, 0x4B, 0x6C, 0xEA, 0x52, 0xC0,
+0x00, 0x6A, 0x55, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x93, 0xC0, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0B, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61,
+0x06, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0x42, 0xF6,
+0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x56, 0xA0,
+0x01, 0x6E, 0xCC, 0xEA, 0x32, 0x2A, 0x08, 0x94,
+0x04, 0x05, 0x00, 0xF0, 0x11, 0x06, 0x01, 0x6F,
+0x00, 0x18, 0x2C, 0x45, 0xC0, 0xF0, 0x06, 0x2A,
+0xB1, 0xA0, 0x7D, 0x67, 0x51, 0xA3, 0x85, 0x67,
+0x03, 0x6B, 0x6C, 0xEC, 0x82, 0xEA, 0x26, 0x60,
+0x9D, 0x67, 0x01, 0x4A, 0x51, 0xC4, 0x30, 0xC4,
+0x0D, 0x6C, 0x6C, 0xEA, 0x8B, 0xEC, 0x48, 0x32,
+0xAC, 0xEC, 0x4D, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0x91, 0xC0, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x12, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x0E, 0x61,
+0xDD, 0x67, 0xB1, 0xA6, 0x30, 0xF0, 0x20, 0x6C,
+0x42, 0xF6, 0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x05, 0x10, 0x71, 0xA0, 0x03, 0x6A, 0x6C, 0xEA,
+0x7D, 0x67, 0x51, 0xC3, 0x07, 0x94, 0x83, 0xE9,
+0x50, 0x60, 0xDD, 0x67, 0xB0, 0xA6, 0x08, 0x94,
+0x00, 0x18, 0x26, 0x44, 0x7D, 0x67, 0x50, 0xC3,
+0xB0, 0xA3, 0xFF, 0x75, 0x06, 0x61, 0x87, 0x41,
+0x4C, 0x4C, 0xFF, 0x6A, 0x4C, 0xEC, 0x06, 0xD4,
+0x17, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x7C, 0x23, 0x63, 0xF5, 0x5C, 0x9A,
+0x05, 0x5A, 0x78, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x42, 0xF6, 0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x71, 0x10, 0x01, 0x49, 0xFF, 0x6A, 0x4C, 0xE9,
+0x08, 0x96, 0x09, 0x97, 0x91, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x08, 0x47, 0xBD, 0x67, 0x50, 0xC5,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x0B, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x07, 0x61, 0xB0, 0xA5, 0x30, 0xF0, 0x20, 0x6C,
+0x62, 0xF6, 0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0xDD, 0x67, 0x50, 0xA6, 0xFF, 0x72, 0x4E, 0x61,
+0x07, 0x92, 0x43, 0xE9, 0x02, 0x61, 0x50, 0xC6,
+0x49, 0x10, 0x06, 0x94, 0x8A, 0xE9, 0xD5, 0x61,
+0x45, 0x10, 0x07, 0x95, 0xAE, 0xE9, 0x27, 0x29,
+0x72, 0xA0, 0x04, 0x6A, 0x6C, 0xEA, 0x66, 0x22,
+0x06, 0x96, 0x80, 0x6A, 0x4B, 0xEA, 0xCC, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x5F, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0C, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61,
+0x5D, 0x67, 0xB0, 0xA2, 0x30, 0xF0, 0x20, 0x6C,
+0x62, 0xF6, 0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x07, 0x93, 0x80, 0x6A, 0x4B, 0xEA, 0x6D, 0xEA,
+0x9D, 0x67, 0x50, 0xC4, 0x1B, 0x10, 0xBD, 0x67,
+0xC7, 0x45, 0x15, 0x4E, 0xC0, 0xA6, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xD0, 0xC5,
+0xC8, 0xC0, 0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x10, 0x23, 0x63, 0xF5, 0x5C, 0x9A,
+0x05, 0x5A, 0x0C, 0x61, 0xB0, 0xA5, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF6, 0x10, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x04, 0x10, 0x0A, 0x93, 0x01, 0x69,
+0x01, 0x73, 0x06, 0x61, 0x72, 0xA0, 0x19, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x52, 0xC0, 0x00, 0x69,
+0x9D, 0x67, 0x71, 0xA4, 0x03, 0x6A, 0x91, 0xA0,
+0x6C, 0xEA, 0x48, 0x33, 0x0D, 0x6A, 0x4B, 0xEA,
+0x8C, 0xEA, 0x6D, 0xEA, 0x51, 0xC0, 0x08, 0x94,
+0x02, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x96, 0x41,
+0x6F, 0xA0, 0x0F, 0x6A, 0xDD, 0x67, 0x6C, 0xEA,
+0x10, 0x6B, 0x6D, 0xEA, 0x4F, 0xC0, 0x5D, 0x67,
+0xB0, 0xA6, 0x08, 0x94, 0xF1, 0xA2, 0xD1, 0x67,
+0x00, 0x18, 0x6A, 0x49, 0x0F, 0x97, 0x0E, 0x91,
+0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF7, 0x63, 0x11, 0x62, 0x10, 0xD1, 0x0F, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x2E, 0x68, 0x18, 0xEC,
+0x4C, 0xED, 0x4C, 0xEE, 0x30, 0xF0, 0x20, 0x6A,
+0x89, 0xF7, 0x18, 0x4A, 0x08, 0xD4, 0x01, 0x6C,
+0x07, 0xD5, 0x0D, 0xD6, 0x12, 0xE8, 0x01, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x8C, 0xEB, 0x0A, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF6, 0x18, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x08, 0x94, 0x00, 0x18,
+0xFE, 0x32, 0x7D, 0x67, 0x50, 0xC3, 0x81, 0xA0,
+0x40, 0xA0, 0x30, 0xA3, 0x0B, 0xD4, 0x91, 0xA0,
+0x03, 0x6B, 0x7F, 0x6D, 0x92, 0x36, 0x8A, 0x34,
+0x6C, 0xEC, 0x6C, 0xEE, 0x7D, 0x67, 0x91, 0xC3,
+0x0C, 0xD6, 0xD2, 0xA0, 0x04, 0x6B, 0x6B, 0xEB,
+0xCC, 0xEB, 0x8D, 0xEB, 0x01, 0x6C, 0x8B, 0xEC,
+0x85, 0xC0, 0x86, 0xC0, 0x20, 0xF0, 0x8C, 0xC0,
+0x20, 0xF0, 0x8D, 0xC0, 0x93, 0xA0, 0xAC, 0xE9,
+0x23, 0xEA, 0x8C, 0xED, 0x80, 0x6C, 0x8B, 0xEC,
+0x8D, 0xEB, 0x67, 0x4C, 0x8C, 0xEB, 0x72, 0xC0,
+0x00, 0x6B, 0xB3, 0xC0, 0x75, 0xC0, 0x02, 0x60,
+0x9D, 0x67, 0x50, 0xC4, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0C, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61, 0xDD, 0x67,
+0xB0, 0xA6, 0x30, 0xF0, 0x20, 0x6C, 0x42, 0xF6,
+0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x07, 0x93,
+0x00, 0x6A, 0x06, 0xD2, 0xE0, 0xF0, 0x09, 0x23,
+0xDD, 0x67, 0x08, 0x94, 0xB0, 0xA6, 0x00, 0x18,
+0xEE, 0x43, 0x07, 0x93, 0xFF, 0x72, 0x09, 0xD3,
+0x0A, 0x60, 0x9D, 0x67, 0x50, 0xC4, 0x30, 0xA4,
+0x7F, 0x6A, 0xA3, 0x67, 0x4C, 0xE9, 0xFF, 0x4D,
+0xFF, 0x6A, 0x4C, 0xED, 0x09, 0xD5, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0C, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61,
+0xDD, 0x67, 0xB0, 0xA6, 0x30, 0xF0, 0x20, 0x6C,
+0x62, 0xF6, 0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x09, 0x92, 0xA0, 0xF0, 0x1C, 0x22, 0x56, 0xA0,
+0x01, 0x6B, 0x6C, 0xEA, 0x1F, 0x2A, 0x08, 0x94,
+0x04, 0x05, 0x00, 0xF0, 0x11, 0x06, 0x02, 0x6F,
+0x00, 0x18, 0x2C, 0x45, 0xA0, 0xF0, 0x0F, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x12, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x0E, 0x61, 0xDD, 0x67, 0xB0, 0xA6, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF6, 0x08, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x05, 0x10, 0x71, 0xA0, 0x03, 0x6A,
+0x6C, 0xEA, 0x7D, 0x67, 0x51, 0xC3, 0x0B, 0x94,
+0x00, 0x6D, 0x0A, 0xD5, 0x83, 0xE9, 0x73, 0x60,
+0xDD, 0x67, 0x47, 0x46, 0x25, 0x4A, 0x40, 0xA2,
+0x06, 0xD5, 0x50, 0xC6, 0x8A, 0x10, 0x08, 0x96,
+0x0C, 0x97, 0x91, 0x67, 0x01, 0x6D, 0x00, 0x18,
+0x08, 0x47, 0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0C, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61, 0x07, 0x95,
+0x09, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF6,
+0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x07, 0x94,
+0x06, 0xD1, 0xFF, 0x74, 0x2B, 0x61, 0xA8, 0x41,
+0xB4, 0x4D, 0xFF, 0x6A, 0x4C, 0xED, 0x07, 0xD5,
+0x06, 0x96, 0xFF, 0x6A, 0x24, 0x33, 0xFF, 0x4E,
+0x4C, 0xEE, 0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF5,
+0x00, 0x4A, 0xC4, 0x34, 0x4D, 0xE3, 0x49, 0xE4,
+0x60, 0xAB, 0x40, 0xAA, 0x06, 0xD6, 0x63, 0xEA,
+0x0F, 0x60, 0x86, 0x67, 0x08, 0x95, 0x0C, 0x96,
+0x00, 0x18, 0x88, 0x43, 0xFF, 0x72, 0x08, 0x60,
+0x72, 0xA0, 0x19, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x52, 0xC0, 0x06, 0x92, 0x07, 0xD2, 0x06, 0x10,
+0x06, 0x93, 0x07, 0x94, 0x8A, 0xEB, 0xDC, 0x61,
+0xFF, 0x6D, 0x07, 0xD5, 0x07, 0x96, 0x0B, 0x95,
+0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF5, 0x00, 0x4A,
+0xC4, 0x33, 0xA4, 0x34, 0x4D, 0xE3, 0x49, 0xE4,
+0x60, 0xAB, 0x40, 0xAA, 0x43, 0xEB, 0x08, 0x60,
+0xDD, 0x67, 0xB0, 0xC6, 0x72, 0xA0, 0x19, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x52, 0xC0, 0x05, 0x10,
+0x7D, 0x67, 0x87, 0x43, 0x15, 0x4C, 0x80, 0xA4,
+0x90, 0xC3, 0x0A, 0x95, 0xFF, 0x6A, 0x06, 0x91,
+0x01, 0x4D, 0x4C, 0xED, 0x0A, 0xD5, 0x0A, 0x96,
+0x09, 0x92, 0x43, 0xEE, 0x90, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0F, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x0B, 0x61,
+0x7D, 0x67, 0xB0, 0xA3, 0x30, 0xF0, 0x20, 0x6C,
+0x62, 0xF6, 0x10, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x01, 0x6C, 0x06, 0xD4, 0x02, 0x10, 0x01, 0x6D,
+0x06, 0xD5, 0x0D, 0x96, 0x01, 0x76, 0x04, 0x60,
+0x72, 0xA0, 0x18, 0x6A, 0x6C, 0xEA, 0x07, 0x2A,
+0x72, 0xA0, 0x19, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x52, 0xC0, 0x00, 0x6A, 0x06, 0xD2, 0x7D, 0x67,
+0x50, 0xA3, 0x91, 0xA0, 0x02, 0x6D, 0x48, 0xC0,
+0x71, 0xA3, 0x03, 0x6A, 0x00, 0x6E, 0x6C, 0xEA,
+0x48, 0x33, 0x0D, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x6D, 0xEA, 0x51, 0xC0, 0x08, 0x94, 0x00, 0x18,
+0x96, 0x41, 0x6F, 0xA0, 0x0F, 0x6A, 0xDD, 0x67,
+0x6C, 0xEA, 0x20, 0x6B, 0x6D, 0xEA, 0x4F, 0xC0,
+0x5D, 0x67, 0xB0, 0xA6, 0xF1, 0xA2, 0x08, 0x94,
+0x06, 0x96, 0x00, 0x18, 0x6A, 0x49, 0x11, 0x97,
+0x10, 0x91, 0x0F, 0x90, 0x09, 0x63, 0x00, 0xEF,
+0xEF, 0x63, 0x21, 0x62, 0x20, 0xD1, 0x1F, 0xD0,
+0x24, 0x67, 0x00, 0x18, 0xD4, 0x44, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF1, 0x48, 0x9A, 0x60, 0xA2,
+0x08, 0x6A, 0x6C, 0xEA, 0x1D, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x46, 0xA2, 0x0A, 0x5A,
+0x17, 0x60, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x09, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF6, 0x10, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x66, 0xA2, 0x01, 0x4B, 0x45, 0xF6,
+0x66, 0xC2, 0x01, 0x6A, 0x1C, 0xD2, 0x07, 0x10,
+0x00, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x66, 0xC2, 0x00, 0x6B, 0x1C, 0xD3, 0x30, 0xF0,
+0x20, 0x6C, 0x30, 0xF0, 0x20, 0x6D, 0x30, 0xF0,
+0x20, 0x6E, 0x00, 0x6F, 0xAE, 0xF3, 0x04, 0x4C,
+0x2E, 0xF6, 0x00, 0x4D, 0xA9, 0xF7, 0x11, 0x4E,
+0x18, 0xD4, 0x17, 0xD5, 0x10, 0xD6, 0x12, 0xD7,
+0x16, 0xD7, 0x18, 0x94, 0x10, 0x93, 0x00, 0x9C,
+0x12, 0x94, 0xE7, 0x4B, 0x11, 0xD3, 0x00, 0x18,
+0xFE, 0x32, 0x10, 0x95, 0x0E, 0xD2, 0x11, 0x96,
+0xFF, 0xF7, 0xA7, 0xA5, 0x12, 0x93, 0x08, 0x04,
+0x0F, 0xD5, 0x51, 0xA6, 0x17, 0x95, 0x14, 0x6E,
+0x4A, 0x32, 0x15, 0xD2, 0x15, 0x97, 0x03, 0x6A,
+0x4C, 0xEF, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x69, 0xE2, 0x2A, 0xF4, 0x54, 0xA2,
+0x15, 0xD7, 0x14, 0xD2, 0x00, 0x18, 0xA1, 0x1E,
+0x0A, 0x96, 0x09, 0x95, 0x0B, 0x93, 0x0C, 0x94,
+0xA9, 0xE6, 0x69, 0xE2, 0xFC, 0x65, 0x89, 0xE2,
+0x08, 0x94, 0xFF, 0xF7, 0x1F, 0x6F, 0xEC, 0xEA,
+0x91, 0xE2, 0x1C, 0x65, 0x04, 0xD2, 0xB1, 0xE3,
+0xC4, 0x32, 0x64, 0x33, 0xDF, 0x67, 0x49, 0xE4,
+0x69, 0xE2, 0xC8, 0x35, 0xA9, 0xE2, 0x12, 0x94,
+0x14, 0x96, 0x05, 0xD2, 0x58, 0x67, 0x4C, 0xEF,
+0xB0, 0x67, 0x00, 0x18, 0x5E, 0x44, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF1, 0x48, 0x9A, 0xFF, 0x6F,
+0x60, 0xA2, 0x20, 0x6A, 0x6C, 0xEA, 0x2D, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x44, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF2, 0x6C, 0x9B,
+0xA0, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2,
+0x48, 0x9A, 0xEC, 0xED, 0x00, 0x6E, 0x40, 0xA2,
+0x80, 0xA3, 0xEC, 0xEC, 0x4C, 0xEF, 0x00, 0x18,
+0x6A, 0x49, 0x12, 0x94, 0x14, 0x97, 0x08, 0x05,
+0xD0, 0x67, 0x00, 0x18, 0x6A, 0x43, 0x0C, 0x94,
+0xB0, 0x67, 0x00, 0x18, 0x3F, 0x43, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0xC0, 0xF4, 0x1A, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0xC0, 0xF4, 0x16, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF6, 0x18, 0x4C,
+0xF7, 0x10, 0x1C, 0x93, 0xC0, 0xF4, 0x1D, 0x2B,
+0x12, 0x94, 0x00, 0x18, 0x12, 0x12, 0x07, 0x2A,
+0x9D, 0x67, 0xA7, 0x44, 0x41, 0x4D, 0x40, 0x85,
+0x00, 0x52, 0xC0, 0xF4, 0x15, 0x60, 0xC0, 0xF4,
+0x13, 0x20, 0x11, 0x96, 0x80, 0x6A, 0x4B, 0xEA,
+0x71, 0xA6, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0xC0, 0xF4, 0x0A, 0x2A, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x0A, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x07, 0x61, 0x12, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0xF6, 0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x11, 0x97, 0x40, 0x6B, 0xFF, 0x6A, 0x92, 0xA7,
+0x8C, 0xEB, 0x05, 0x2B, 0x91, 0xA7, 0x80, 0x4B,
+0x8C, 0xEB, 0x4C, 0xEB, 0x0F, 0x23, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x80, 0xF4, 0x1A, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x80, 0xF4, 0x16, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF6, 0x0C, 0x4C,
+0x12, 0x95, 0x7A, 0x11, 0x09, 0x58, 0x20, 0x61,
+0x11, 0x93, 0xD3, 0xA3, 0x07, 0x6B, 0x86, 0x67,
+0x6C, 0xEC, 0xA4, 0x67, 0x4C, 0xED, 0x18, 0x25,
+0x08, 0x6D, 0xFF, 0x4C, 0xAB, 0xED, 0x6C, 0xEC,
+0xCC, 0xED, 0x8D, 0xED, 0x11, 0x94, 0x01, 0x6E,
+0xB3, 0xC4, 0x84, 0x99, 0xCC, 0xEC, 0x60, 0xF4,
+0x19, 0x24, 0x85, 0x99, 0x05, 0x5C, 0x60, 0xF4,
+0x15, 0x61, 0x6C, 0xED, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0xF6, 0x18, 0x4C, 0x4C, 0xED, 0x58, 0x11,
+0x0E, 0x96, 0x0E, 0x92, 0x7F, 0x6D, 0x11, 0x94,
+0x80, 0x6F, 0xAC, 0xEE, 0xEC, 0xEA, 0x19, 0xD2,
+0x13, 0xD6, 0x73, 0xA4, 0x08, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x53, 0xC4, 0x0F, 0x95, 0xC3, 0xED,
+0x1E, 0x60, 0x19, 0x96, 0x0E, 0xD5, 0x09, 0x26,
+0x80, 0x4F, 0x80, 0x4F, 0x45, 0x67, 0xED, 0xEA,
+0x0E, 0xD2, 0x0E, 0x93, 0xFF, 0x6A, 0x4C, 0xEB,
+0x0E, 0xD3, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0C, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x09, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xC2, 0xF6, 0x04, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x0F, 0x94, 0x13, 0xD4,
+0x02, 0x10, 0x0F, 0x95, 0x13, 0xD5, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x0C, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x09, 0x61, 0x08, 0x96, 0x0C, 0x97,
+0x30, 0xF0, 0x20, 0x6C, 0xC2, 0xF6, 0x0C, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x4F, 0x40,
+0x07, 0x5A, 0x14, 0x60, 0x11, 0x96, 0x01, 0x6A,
+0x76, 0xA6, 0x6C, 0xEA, 0x0F, 0x2A, 0x4E, 0xA6,
+0x56, 0x33, 0x03, 0x53, 0x04, 0x60, 0x20, 0x4A,
+0x4E, 0xC6, 0x00, 0xF4, 0x1F, 0x10, 0x1F, 0x6B,
+0x11, 0x97, 0x4C, 0xEB, 0x60, 0x6A, 0x4D, 0xEB,
+0x6E, 0xC7, 0x06, 0x10, 0x11, 0x92, 0x6E, 0xA2,
+0x1F, 0x6A, 0x6C, 0xEA, 0x11, 0x93, 0x4E, 0xC3,
+0x11, 0x94, 0x20, 0x6A, 0x4B, 0xEA, 0x6E, 0xA4,
+0xFF, 0x6D, 0x6C, 0xEA, 0xAC, 0xEA, 0xA0, 0x72,
+0x48, 0x61, 0x12, 0x94, 0x00, 0x6E, 0x05, 0x6D,
+0x00, 0x18, 0x96, 0x41, 0x0C, 0x92, 0x0B, 0x93,
+0x14, 0x96, 0x4D, 0xE3, 0xCD, 0xE3, 0x0A, 0x32,
+0x63, 0xEA, 0x13, 0x60, 0x44, 0x99, 0x09, 0x6B,
+0x6C, 0xEA, 0x09, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xC2, 0xF6,
+0x1C, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x12, 0x94,
+0x01, 0x6D, 0xC5, 0x67, 0x00, 0x18, 0xD2, 0x4A,
+0xE9, 0x13, 0x14, 0x97, 0x10, 0x27, 0x44, 0x99,
+0x09, 0x6B, 0x6C, 0xEA, 0xE0, 0xF3, 0x02, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0xC0, 0xF3, 0x1E, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF6, 0x04, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0xD7, 0x13, 0x08, 0x92,
+0x03, 0xEA, 0xC0, 0xF3, 0x13, 0x61, 0x44, 0x99,
+0x09, 0x6B, 0x6C, 0xEA, 0x09, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0xE2, 0xF6, 0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x12, 0x94, 0x01, 0x6D, 0x00, 0x18, 0x1D, 0x4A,
+0xC1, 0x13, 0x12, 0x94, 0x14, 0x97, 0x08, 0x05,
+0xD0, 0x67, 0x00, 0x18, 0x6A, 0x43, 0x0C, 0x94,
+0xB0, 0x67, 0x0F, 0xD2, 0x00, 0x18, 0x3F, 0x43,
+0x1B, 0xD2, 0x11, 0x92, 0x6E, 0xA2, 0x10, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x0E, 0x22,
+0x0F, 0x94, 0x10, 0x95, 0x86, 0x32, 0x40, 0xC5,
+0x1B, 0x96, 0xC6, 0x32, 0x41, 0xC5, 0x11, 0x97,
+0x11, 0x6A, 0x4B, 0xEA, 0x6E, 0xA7, 0x6C, 0xEA,
+0x4E, 0xC7, 0x10, 0x10, 0x10, 0x93, 0x0F, 0x94,
+0x10, 0x95, 0x40, 0xA3, 0x44, 0x33, 0x49, 0xE3,
+0x89, 0xE2, 0x4B, 0x32, 0x40, 0xC5, 0x1B, 0x96,
+0x61, 0xA5, 0xC4, 0x32, 0x6D, 0xE6, 0x49, 0xE3,
+0x4B, 0x32, 0x41, 0xC5, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x48, 0x9A, 0x60, 0xA2, 0x40, 0x6A,
+0x6C, 0xEA, 0x28, 0x22, 0x0B, 0x94, 0x09, 0x97,
+0x0C, 0x95, 0x0A, 0x96, 0xED, 0xE4, 0xAD, 0xE3,
+0xC4, 0x32, 0x4D, 0xE3, 0x1F, 0x65, 0x89, 0xE5,
+0x44, 0x32, 0xB8, 0x67, 0x49, 0xE3, 0xAD, 0xE6,
+0x14, 0x96, 0xFF, 0xF7, 0x1F, 0x6F, 0x91, 0xE3,
+0x08, 0x93, 0xEC, 0xEA, 0xC3, 0xE0, 0x04, 0xD2,
+0x01, 0xE2, 0x0F, 0x92, 0x6D, 0xE4, 0x10, 0x94,
+0xEC, 0xE8, 0x05, 0xD0, 0x06, 0xD2, 0x40, 0xA4,
+0x12, 0x95, 0x0E, 0x96, 0x30, 0xF0, 0x20, 0x6C,
+0x02, 0xF7, 0x00, 0x4C, 0x6C, 0xEF, 0x07, 0xD2,
+0x00, 0x18, 0x39, 0x3D, 0x10, 0x95, 0x19, 0x96,
+0x80, 0xA5, 0x13, 0x95, 0x00, 0x18, 0x5E, 0x43,
+0x15, 0x96, 0x05, 0x2E, 0x40, 0x32, 0x5C, 0x32,
+0x42, 0x32, 0x42, 0x32, 0x07, 0x10, 0x15, 0x97,
+0x02, 0x77, 0x04, 0x61, 0x44, 0x32, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x10, 0x93, 0xFF, 0xF7,
+0x51, 0xCB, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0D, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x0A, 0x61,
+0x10, 0x97, 0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xC0, 0xA7, 0xE1, 0xA7, 0x22, 0xF7, 0x08, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x44, 0x99, 0x02, 0x6B,
+0x6C, 0xEA, 0x0D, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x0A, 0x61, 0x10, 0x92, 0x0E, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0xC0, 0xA2, 0xE1, 0xA2, 0x42, 0xF7,
+0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x14, 0x93,
+0x08, 0x5B, 0x11, 0x61, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x00, 0xF3, 0x1F, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x00, 0xF3, 0x1B, 0x61, 0x14, 0x95,
+0x30, 0xF0, 0x20, 0x6C, 0x42, 0xF7, 0x18, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x13, 0x13, 0x13, 0x94,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x49, 0xE4, 0x28, 0xF4, 0x16, 0xA2, 0x0F, 0x95,
+0x03, 0xED, 0x14, 0x60, 0xBB, 0xE0, 0xFF, 0x6A,
+0x11, 0x97, 0x4C, 0xEE, 0x0E, 0xD6, 0xB0, 0xA7,
+0x0F, 0x6C, 0x01, 0x6B, 0xAE, 0x32, 0x8C, 0xEA,
+0x44, 0x32, 0x6D, 0xEA, 0x8C, 0xEA, 0x4C, 0x33,
+0x79, 0x6A, 0x4B, 0xEA, 0xAC, 0xEA, 0x6D, 0xEA,
+0x50, 0xC7, 0x14, 0x10, 0x0F, 0x92, 0x11, 0x95,
+0x0B, 0xE2, 0x0E, 0xD2, 0x0E, 0x93, 0xFF, 0x6A,
+0x4C, 0xEB, 0x0E, 0xD3, 0x90, 0xA5, 0x0F, 0x6B,
+0x8E, 0x32, 0x6C, 0xEA, 0x44, 0x32, 0x6C, 0xEA,
+0x4C, 0x33, 0x79, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x6D, 0xEA, 0x50, 0xC5, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x12, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x0F, 0x61, 0x11, 0x96, 0x0E, 0x97, 0x0F, 0x6B,
+0x50, 0xA6, 0x0F, 0x96, 0x30, 0xF0, 0x20, 0x6C,
+0x4E, 0x32, 0x6C, 0xEA, 0x62, 0xF7, 0x04, 0x4C,
+0xB0, 0x67, 0x04, 0xD2, 0x00, 0x18, 0x39, 0x3D,
+0x0E, 0x97, 0x04, 0x5F, 0x22, 0x61, 0x0F, 0x94,
+0x10, 0x33, 0xFF, 0xF7, 0x1F, 0x6A, 0x0F, 0xE3,
+0x4C, 0xEB, 0x8D, 0xE3, 0x11, 0x95, 0x4C, 0xEB,
+0x6F, 0x33, 0x4C, 0xEB, 0x50, 0xA5, 0x01, 0x6C,
+0x4E, 0x32, 0x8C, 0xEA, 0x08, 0x22, 0x13, 0x96,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x49, 0xE6, 0x66, 0x33, 0x08, 0x10, 0x13, 0x97,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x66, 0x33, 0x49, 0xE7, 0x01, 0x4B, 0x28, 0xF4,
+0x76, 0xC2, 0x13, 0x94, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x4D, 0xE4, 0x28, 0xF4,
+0x76, 0xA3, 0x0F, 0xD3, 0x64, 0x67, 0x44, 0xF2,
+0x00, 0x4B, 0x64, 0x33, 0x49, 0xE3, 0x0A, 0xA2,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x0B, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x08, 0x61, 0x0F, 0x95,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF7, 0x10, 0x4C,
+0xD0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x0E, 0x97,
+0xBD, 0x67, 0xC7, 0x45, 0x31, 0x4E, 0x0F, 0x5F,
+0x40, 0xA6, 0x01, 0x61, 0x0E, 0x6A, 0xFF, 0x6B,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x49, 0xE3, 0x28, 0xF5, 0x52, 0xA2,
+0x0B, 0x5A, 0x08, 0x61, 0x11, 0x94, 0x50, 0xA4,
+0x03, 0x6C, 0x4E, 0x32, 0x8C, 0xEA, 0x15, 0x22,
+0x03, 0x72, 0x13, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x4D, 0xE3, 0x28, 0xF5,
+0x52, 0xA3, 0x41, 0xE0, 0xFF, 0x6A, 0x4C, 0xE8,
+0x0A, 0x58, 0x03, 0x60, 0x01, 0x6D, 0x00, 0x68,
+0x08, 0x10, 0xF6, 0x48, 0x4C, 0xE8, 0x01, 0x6D,
+0x01, 0x10, 0x00, 0x6D, 0x1A, 0x58, 0x01, 0x61,
+0x19, 0x68, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0A, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x07, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF7, 0x0C, 0x4C,
+0xD0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x13, 0x93,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x44, 0xF2, 0x00, 0x4B, 0x64, 0x33, 0x49, 0xE3,
+0x0B, 0x58, 0x05, 0xCA, 0x02, 0x6A, 0x09, 0x60,
+0x06, 0x58, 0x03, 0x6A, 0x06, 0x60, 0x03, 0x58,
+0x58, 0x67, 0x01, 0x5A, 0x58, 0x67, 0x05, 0x6B,
+0x4B, 0xE3, 0x0F, 0x93, 0x14, 0xD0, 0x0B, 0x5B,
+0x08, 0x61, 0xF6, 0x4B, 0x67, 0xEA, 0x6D, 0xE0,
+0x14, 0xD3, 0x14, 0x94, 0xFF, 0x6B, 0x6C, 0xEC,
+0x14, 0xD4, 0x0F, 0x93, 0x14, 0x95, 0xF6, 0x4B,
+0x67, 0xEA, 0x6D, 0xE5, 0xFF, 0x6A, 0x4C, 0xEB,
+0x28, 0x5D, 0x1A, 0xD3, 0x02, 0x61, 0x28, 0x6E,
+0x14, 0xD6, 0x03, 0x58, 0x05, 0x60, 0x1B, 0x97,
+0xFF, 0x6A, 0xE6, 0x37, 0x4C, 0xEF, 0x16, 0xD7,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x0C, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x09, 0x61, 0x14, 0x95,
+0x16, 0x96, 0x1A, 0x97, 0x30, 0xF0, 0x20, 0x6C,
+0xC2, 0xF7, 0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x19, 0x92, 0x13, 0x22, 0x13, 0x93, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE3,
+0x88, 0xF3, 0x4A, 0xA2, 0x00, 0x6C, 0x0E, 0xD4,
+0x02, 0x5A, 0x10, 0x61, 0xFF, 0x4A, 0x0E, 0xD2,
+0x0E, 0x95, 0xFF, 0x6A, 0x4C, 0xED, 0x0E, 0xD5,
+0x09, 0x10, 0x13, 0x96, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE6, 0x88, 0xF3,
+0x4A, 0xA2, 0x0E, 0xD2, 0x13, 0x97, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE7,
+0x28, 0xF3, 0x56, 0xA2, 0xFF, 0x68, 0x0F, 0xD2,
+0x11, 0x92, 0x76, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x1A, 0x22, 0x87, 0x67, 0x00, 0x18, 0x86, 0x41,
+0x05, 0x22, 0x0E, 0x93, 0x02, 0x4B, 0x0C, 0xEB,
+0x0E, 0xD3, 0x11, 0x10, 0x13, 0x94, 0x00, 0x18,
+0x72, 0x41, 0x05, 0x22, 0x0E, 0x94, 0x05, 0x4C,
+0x0C, 0xEC, 0x0E, 0xD4, 0x08, 0x10, 0x0F, 0x95,
+0x0E, 0x96, 0x03, 0x4D, 0x06, 0x4E, 0x0C, 0xED,
+0x0C, 0xEE, 0x0F, 0xD5, 0x0E, 0xD6, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x54, 0x9A, 0xFF, 0x6B,
+0x80, 0xA2, 0x7F, 0x6A, 0x8C, 0xEA, 0x08, 0x22,
+0x0F, 0x97, 0x0E, 0x92, 0x02, 0x4F, 0x05, 0x4A,
+0x6C, 0xEF, 0x6C, 0xEA, 0x0F, 0xD7, 0x0E, 0xD2,
+0x14, 0x93, 0x16, 0x94, 0x63, 0xEC, 0x35, 0x60,
+0x1A, 0x95, 0x0E, 0x96, 0x14, 0x97, 0x8F, 0xE5,
+0x16, 0x92, 0x6D, 0xE6, 0x0F, 0x96, 0x57, 0xE7,
+0x13, 0x97, 0xA9, 0xE6, 0x30, 0xF0, 0x20, 0x6E,
+0xFF, 0x6C, 0x45, 0xF6, 0x18, 0x4E, 0x8C, 0xEB,
+0xAB, 0x35, 0xD9, 0xE7, 0xC8, 0xF3, 0xBE, 0xC6,
+0xA3, 0x67, 0x8C, 0xEB, 0x47, 0x5B, 0x8C, 0xEA,
+0x01, 0x61, 0x46, 0x6D, 0xFF, 0x6C, 0x65, 0x67,
+0x8C, 0xEB, 0x0E, 0xD3, 0x62, 0x67, 0x8C, 0xEA,
+0x29, 0x5A, 0x01, 0x61, 0x28, 0x6B, 0xFF, 0x6C,
+0x6C, 0xEC, 0x0F, 0xD4, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x0B, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x08, 0x61, 0x0F, 0x95, 0x0E, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0xC2, 0xF7, 0x14, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x10, 0x95, 0x3F, 0x6A, 0x0E, 0xA5,
+0x4C, 0xE8, 0x4E, 0x85, 0x00, 0x52, 0x19, 0x60,
+0x0E, 0x96, 0x03, 0xEE, 0x03, 0x60, 0x00, 0x6F,
+0x0E, 0xD7, 0x07, 0x10, 0x0E, 0x92, 0x0B, 0xE2,
+0x0E, 0xD2, 0x0E, 0x93, 0xFF, 0x6A, 0x4C, 0xEB,
+0x0E, 0xD3, 0x0F, 0x94, 0x03, 0xEC, 0x03, 0x60,
+0x00, 0x6D, 0x0F, 0xD5, 0x10, 0x10, 0x0F, 0x96,
+0xFF, 0x6A, 0x1B, 0xE6, 0x4C, 0xEE, 0x0F, 0xD6,
+0x0A, 0x10, 0x09, 0x20, 0x0E, 0x97, 0x0F, 0x93,
+0xFF, 0x6A, 0x1D, 0xE7, 0x0D, 0xE3, 0x4C, 0xEF,
+0x4C, 0xEB, 0x0E, 0xD7, 0x0F, 0xD3, 0x0E, 0x96,
+0x9D, 0x67, 0xA7, 0x44, 0x31, 0x4D, 0x5B, 0x5E,
+0x40, 0xA5, 0x01, 0x61, 0x5A, 0x6A, 0x0F, 0x96,
+0xFF, 0x6B, 0xE2, 0x67, 0x9D, 0x67, 0x6C, 0xEF,
+0xA7, 0x44, 0xCC, 0xEB, 0x35, 0x4D, 0x42, 0x5B,
+0x13, 0xD7, 0x40, 0xA5, 0x01, 0x61, 0x41, 0x6A,
+0xFF, 0x6F, 0x4C, 0xEF, 0x0E, 0xD7, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x0D, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x0A, 0x61, 0x10, 0x92, 0xC7, 0x67,
+0x13, 0x97, 0xAE, 0xA2, 0x30, 0xF0, 0x20, 0x6C,
+0xE2, 0xF7, 0x0C, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x10, 0x93, 0x13, 0x94, 0x0E, 0x95, 0x4E, 0xA3,
+0x04, 0x6E, 0x06, 0xD4, 0x01, 0x6C, 0x5E, 0x32,
+0x07, 0xD5, 0xE6, 0x67, 0xA4, 0x67, 0x04, 0xD2,
+0x05, 0xD0, 0x00, 0x18, 0xC1, 0x3E, 0x11, 0x96,
+0x03, 0x6C, 0xFF, 0x6A, 0xB2, 0xA6, 0xAE, 0x35,
+0x8C, 0xED, 0x63, 0x45, 0x8C, 0xEB, 0x02, 0x5B,
+0x42, 0x60, 0x64, 0x99, 0x01, 0x6C, 0x0F, 0x45,
+0x8C, 0xEB, 0x4C, 0xE8, 0x0A, 0x23, 0x65, 0x99,
+0x05, 0x5B, 0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x03, 0xF0, 0x10, 0x4C, 0x4C, 0xED, 0x00, 0x18,
+0x39, 0x3D, 0x11, 0x97, 0x03, 0x6B, 0x19, 0x6A,
+0xB2, 0xA7, 0x4B, 0xEA, 0x11, 0xE7, 0xAE, 0x36,
+0x6C, 0xEE, 0xFF, 0x4E, 0x6C, 0xEE, 0xCC, 0x36,
+0xAC, 0xEA, 0xCD, 0xEA, 0x05, 0xA4, 0x52, 0xC7,
+0x20, 0xF0, 0x4C, 0xA4, 0xFF, 0x72, 0x09, 0x60,
+0x15, 0xD2, 0x91, 0xA7, 0x4C, 0xEB, 0x0D, 0x6A,
+0x4B, 0xEA, 0x68, 0x33, 0x8C, 0xEA, 0x6D, 0xEA,
+0x51, 0xC7, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0B, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x08, 0x61,
+0x15, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF0,
+0x1C, 0x4C, 0xD0, 0x67, 0x00, 0x18, 0x39, 0x3D,
+0x12, 0x94, 0x15, 0x97, 0xB0, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x6A, 0x49, 0xC3, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF1, 0x48, 0x9A, 0x60, 0xA2,
+0x40, 0x6A, 0x6C, 0xEA, 0x07, 0x22, 0x11, 0x92,
+0x6E, 0xA2, 0x08, 0x6A, 0x6D, 0xEA, 0x11, 0x93,
+0x4E, 0xC3, 0x06, 0x10, 0x11, 0x94, 0x09, 0x6A,
+0x4B, 0xEA, 0x6E, 0xA4, 0x6C, 0xEA, 0x4E, 0xC4,
+0x10, 0x95, 0x41, 0xA5, 0x17, 0x5A, 0x1C, 0x61,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x09, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x23, 0xF0, 0x08, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x12, 0x94, 0x01, 0x6D, 0xC5, 0x67,
+0x00, 0x18, 0xD2, 0x4A, 0x10, 0x96, 0x00, 0x6A,
+0xFF, 0xF7, 0x50, 0xC6, 0xFF, 0xF7, 0x53, 0xA6,
+0x01, 0x4A, 0xFF, 0xF7, 0x53, 0xC6, 0x8E, 0x10,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x0B, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x08, 0x61, 0x0E, 0x95,
+0x13, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x23, 0xF0,
+0x0C, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x10, 0x97,
+0x13, 0x93, 0x40, 0xA7, 0x43, 0xEB, 0x1C, 0x60,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x09, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x23, 0xF0, 0x1C, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x12, 0x94, 0x01, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0xD2, 0x4A, 0x10, 0x94, 0x00, 0x6A,
+0xFF, 0xF7, 0x50, 0xC4, 0xFF, 0xF7, 0x53, 0xA4,
+0x01, 0x4A, 0xFF, 0xF7, 0x53, 0xC4, 0x5E, 0x10,
+0x0E, 0x95, 0xA3, 0xEA, 0x44, 0x60, 0x10, 0x96,
+0x01, 0x6B, 0xFF, 0xF7, 0x50, 0xA6, 0x01, 0x4A,
+0xFF, 0xF7, 0x50, 0xC6, 0x44, 0x99, 0x6C, 0xEA,
+0x09, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF6, 0x1C, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x10, 0x92, 0xFF, 0xF7,
+0xF0, 0xA2, 0xFF, 0xF7, 0x5C, 0xA2, 0x02, 0x4A,
+0x42, 0xEF, 0x40, 0x61, 0x11, 0x94, 0x08, 0x6A,
+0x6E, 0xA4, 0x6C, 0xEA, 0x09, 0x22, 0x10, 0x92,
+0x12, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0xC0, 0xA2,
+0x43, 0xF0, 0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x09, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x43, 0xF0, 0x10, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x12, 0x94, 0x00, 0x6D, 0x00, 0x18,
+0x1D, 0x4A, 0x10, 0x93, 0x00, 0x6A, 0xFF, 0xF7,
+0x50, 0xC3, 0xFF, 0xF7, 0x54, 0xA3, 0x01, 0x4A,
+0xFF, 0xF7, 0x54, 0xC3, 0x17, 0x10, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x09, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x43, 0xF0, 0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x12, 0x94, 0x04, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x96, 0x41, 0x11, 0x94, 0x0F, 0x6A, 0x6F, 0xA4,
+0x6C, 0xEA, 0x4F, 0xC4, 0x00, 0x18, 0xD2, 0x41,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x09, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x43, 0xF0, 0x1C, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x12, 0x94, 0x00, 0x18, 0x5F, 0x51,
+0x12, 0x95, 0x18, 0x96, 0x17, 0x97, 0x10, 0x92,
+0x01, 0x4D, 0x04, 0x4E, 0x14, 0x4F, 0x2E, 0x4A,
+0x9F, 0x75, 0x12, 0xD5, 0x18, 0xD6, 0x17, 0xD7,
+0x10, 0xD2, 0x9F, 0xF2, 0x16, 0x61, 0x21, 0x97,
+0x20, 0x91, 0x1F, 0x90, 0x11, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x65, 0xA2, 0x01, 0x4B,
+0x45, 0xF6, 0x65, 0xC2, 0x45, 0xF6, 0x65, 0xA2,
+0x02, 0x5B, 0x03, 0x61, 0x00, 0x6B, 0x45, 0xF6,
+0x65, 0xC2, 0x30, 0xF0, 0x20, 0x68, 0xC9, 0xF3,
+0x00, 0x48, 0x90, 0x67, 0x00, 0x18, 0x98, 0x4B,
+0x90, 0x67, 0x00, 0x18, 0xDD, 0x40, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x2C, 0xEC, 0x2E, 0x6A, 0x58, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0x89, 0xF7, 0x18, 0x4B,
+0x04, 0xD4, 0x03, 0x6D, 0x12, 0xEA, 0x49, 0xE3,
+0xD2, 0xA2, 0xF1, 0xA2, 0x68, 0xA2, 0xCC, 0xED,
+0xA8, 0x36, 0xAC, 0xE9, 0x0D, 0x6D, 0xAB, 0xED,
+0xEC, 0xED, 0xCD, 0xED, 0x80, 0xA2, 0xB1, 0xC2,
+0x7F, 0x6D, 0x6C, 0xED, 0xA3, 0xEC, 0x01, 0x60,
+0x64, 0x67, 0x48, 0xA2, 0x80, 0x68, 0x0B, 0xE8,
+0x4C, 0xE8, 0x6D, 0xE8, 0x00, 0xF6, 0x00, 0x30,
+0xFF, 0x6A, 0x00, 0xF6, 0x03, 0x30, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x0C, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF0,
+0x08, 0x4C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x04, 0x94, 0xB0, 0x67, 0xF1, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x6A, 0x49, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x69, 0x8C, 0xE9, 0x2E, 0x68, 0x18, 0xE9,
+0xFF, 0x6A, 0xAC, 0xEA, 0x06, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x91, 0x67,
+0x12, 0xE8, 0x01, 0xE2, 0x00, 0x18, 0xFE, 0x32,
+0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0x4C, 0x9A, 0x34, 0x33, 0x91, 0x67, 0x49, 0xE3,
+0x40, 0xA2, 0xFF, 0x6B, 0x4C, 0xEB, 0x05, 0xD3,
+0x00, 0x18, 0x12, 0x12, 0x52, 0xA0, 0x01, 0x6B,
+0xFF, 0x6C, 0x5A, 0x32, 0x6C, 0xEA, 0x8C, 0xEA,
+0x00, 0xF1, 0x06, 0x22, 0x06, 0x92, 0x63, 0x22,
+0x8F, 0xA0, 0x10, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x4F, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x98, 0x9A, 0x6C, 0xEC,
+0x0B, 0x24, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x07, 0x61, 0x04, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF0, 0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x91, 0x67, 0x06, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x96, 0x41, 0x54, 0xA0, 0x10, 0x6B, 0x6B, 0xEB,
+0x6C, 0xEA, 0x54, 0xC0, 0x05, 0x94, 0x18, 0x6F,
+0x04, 0x95, 0x8C, 0xEF, 0x00, 0x6E, 0x91, 0x67,
+0xEE, 0x37, 0x00, 0x18, 0x6A, 0x49, 0x72, 0xA0,
+0x19, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x52, 0xC0,
+0x4F, 0xA0, 0x10, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x6C, 0x8E, 0xEA,
+0x01, 0x22, 0x03, 0x6A, 0x73, 0xA0, 0x55, 0xC0,
+0x00, 0x6A, 0x59, 0xC0, 0x5A, 0xC0, 0x7F, 0x6A,
+0x4C, 0xEB, 0x73, 0xC0, 0x72, 0xA0, 0x6C, 0xEA,
+0x6E, 0xA0, 0x52, 0xC0, 0x10, 0x6A, 0x6D, 0xEA,
+0x08, 0x6B, 0x4C, 0xEB, 0x4E, 0xC0, 0xA0, 0xF0,
+0x0B, 0x23, 0x6F, 0xA0, 0x10, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x72,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF0,
+0x04, 0x4C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x83, 0xF0, 0x14, 0x4C, 0x04, 0x96, 0xB1, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x95, 0x10, 0x6E, 0xA0,
+0x08, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x15, 0x22, 0x6F, 0xA0, 0x10, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA, 0x10, 0x72,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF0,
+0x04, 0x4C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xA3, 0xF0, 0x14, 0x4C, 0x04, 0x96, 0xB1, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x72, 0xA0, 0x18, 0x6A,
+0x6C, 0xEA, 0x4C, 0x2A, 0x4F, 0xA0, 0x10, 0x6B,
+0x6B, 0xEB, 0x6C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA,
+0x10, 0x72, 0x3F, 0x61, 0x54, 0xA0, 0x0F, 0x6C,
+0xA2, 0x67, 0x8C, 0xED, 0x01, 0x4D, 0x8C, 0xED,
+0x6C, 0xEA, 0xAD, 0xEA, 0x4C, 0xEC, 0x03, 0x54,
+0x54, 0xC0, 0x0E, 0x61, 0x6C, 0xEA, 0x54, 0xC0,
+0x04, 0x94, 0x30, 0xF0, 0x20, 0x6A, 0x7F, 0x6B,
+0x8C, 0xEB, 0xC5, 0xF1, 0x00, 0x4A, 0x49, 0xE3,
+0x40, 0xA2, 0x44, 0x32, 0x0A, 0x4A, 0x55, 0xC0,
+0x6E, 0xA0, 0x08, 0x6A, 0x6C, 0xEA, 0x0C, 0x22,
+0x74, 0xA0, 0x0F, 0x6A, 0xD5, 0xA0, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0xFF, 0x6D, 0xC3, 0xF0,
+0x04, 0x4C, 0x4C, 0xED, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x63, 0xF5, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x11, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x0D, 0x61, 0xB5, 0xA0, 0x30, 0xF0, 0x20, 0x6C,
+0xC3, 0xF0, 0x14, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x05, 0x10, 0x54, 0xA0, 0x4C, 0xEB, 0x03, 0x6A,
+0x74, 0xC0, 0x55, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61, 0x54, 0xA0,
+0x30, 0xF0, 0x20, 0x6C, 0x0F, 0x6D, 0xE3, 0xF0,
+0x00, 0x4C, 0x4C, 0xED, 0x00, 0x18, 0x39, 0x3D,
+0x6E, 0xA0, 0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x4E, 0xC0, 0x91, 0x67, 0x07, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x96, 0x41, 0x91, 0x67, 0x00, 0x18,
+0x82, 0x4E, 0x73, 0xA0, 0x7F, 0x6A, 0x4C, 0xEB,
+0x73, 0xC0, 0x72, 0xA0, 0x6C, 0xEA, 0x52, 0xC0,
+0x72, 0xA0, 0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x73, 0xA0, 0x52, 0xC0, 0x08, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x02, 0x6B, 0x6D, 0xEA, 0x53, 0xC0,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0xE6, 0x67, 0x2E, 0x6E, 0xD8, 0xEC, 0x30, 0xF0,
+0x20, 0x6B, 0x89, 0xF7, 0x18, 0x4B, 0x04, 0xD4,
+0x25, 0x67, 0x4C, 0xE9, 0x4C, 0xEF, 0x12, 0xEE,
+0xD9, 0xE3, 0x16, 0xA6, 0x60, 0xA6, 0x82, 0xA6,
+0xA1, 0xA6, 0x01, 0x6E, 0x0C, 0xEE, 0x4C, 0xEE,
+0x0E, 0x43, 0x0A, 0x2E, 0x38, 0x59, 0x03, 0x67,
+0x08, 0x60, 0x24, 0x59, 0x83, 0xE3, 0x04, 0x60,
+0x15, 0x59, 0x05, 0x67, 0x02, 0x61, 0xA1, 0xE4,
+0x4C, 0xE8, 0x04, 0x94, 0xB0, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x6A, 0x49, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23, 0x63, 0xF5,
+0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61, 0x04, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0xE3, 0xF0, 0x0C, 0x4C,
+0xB1, 0x67, 0xF0, 0x67, 0x00, 0x18, 0x39, 0x3D,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x2E, 0x68, 0x18, 0xEA, 0x05, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A, 0x12, 0xE8,
+0x01, 0xE2, 0x84, 0xA0, 0x0F, 0x5C, 0x48, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x88, 0x33, 0xA0, 0xF3,
+0x18, 0x4A, 0x69, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x1B, 0x6A, 0x34, 0x10, 0x3D, 0x6A, 0x6E, 0xA0,
+0x47, 0xC0, 0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x02, 0x6B, 0x6D, 0xEA, 0x39, 0x10, 0x6E, 0xA0,
+0x13, 0x6A, 0x47, 0xC0, 0x08, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x01, 0x6B, 0x6D, 0xEA, 0x4E, 0xC0,
+0x6E, 0xA0, 0x33, 0x6A, 0x47, 0xC0, 0x08, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x01, 0x6B, 0x6D, 0xEA,
+0x02, 0x6D, 0x4E, 0xC0, 0x07, 0xD5, 0x27, 0x10,
+0x6E, 0xA0, 0x0B, 0x6A, 0x47, 0xC0, 0x08, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x01, 0x6E, 0x4E, 0xC0,
+0x07, 0xD6, 0x1D, 0x10, 0x6E, 0xA0, 0x47, 0x6A,
+0x47, 0xC0, 0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x03, 0x6B, 0x6D, 0xEA, 0x4E, 0xC0, 0x07, 0xD3,
+0x12, 0x10, 0x23, 0x6A, 0x6E, 0xA0, 0x47, 0xC0,
+0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x03, 0x6B,
+0x6D, 0xEA, 0x4E, 0xC0, 0x07, 0xD3, 0x07, 0x10,
+0x6E, 0xA0, 0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x03, 0x6B, 0x4E, 0xC0, 0x07, 0xD3, 0x05, 0x96,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x50, 0x9A,
+0xCC, 0x35, 0x8C, 0x34, 0x55, 0xE5, 0x30, 0xF0,
+0x20, 0x6A, 0x85, 0xF0, 0x08, 0x4A, 0x91, 0xE2,
+0xE5, 0x67, 0x1D, 0x65, 0x00, 0x6A, 0x48, 0x33,
+0xAD, 0xE3, 0xC0, 0x9C, 0x60, 0x9B, 0x31, 0xA0,
+0xCC, 0xEB, 0x03, 0x6E, 0x2C, 0xEE, 0x02, 0x69,
+0x2E, 0xEE, 0x07, 0x2E, 0xFF, 0x6E, 0x4C, 0xEE,
+0x01, 0x69, 0x2E, 0xEE, 0x02, 0x2E, 0xBF, 0x4E,
+0xCC, 0xEB, 0x48, 0x36, 0xE5, 0xE6, 0x60, 0xD9,
+0x78, 0x67, 0x79, 0xE6, 0x60, 0x9E, 0x01, 0x4A,
+0x02, 0x6B, 0x4E, 0xEB, 0x04, 0x4C, 0xE3, 0x2B,
+0x51, 0xA0, 0x05, 0x95, 0x03, 0x6B, 0x52, 0x32,
+0xAC, 0x34, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6D,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1, 0x70, 0x9B,
+0x21, 0xF1, 0xBC, 0x9D, 0x6D, 0xE4, 0xB1, 0xE4,
+0x60, 0x9B, 0xE0, 0x9C, 0x03, 0x2F, 0xC3, 0x67,
+0x00, 0x69, 0x02, 0x10, 0xC7, 0x67, 0x20, 0x69,
+0x1F, 0x6C, 0x01, 0x6D, 0xA4, 0xEC, 0xCC, 0xED,
+0x09, 0x25, 0x25, 0xE4, 0xFF, 0x6C, 0x8C, 0xE9,
+0x0B, 0x22, 0x0C, 0x59, 0x09, 0x61, 0x20, 0x49,
+0x8C, 0xE9, 0x06, 0x10, 0xFF, 0x4C, 0xFF, 0x6D,
+0xAC, 0xEC, 0xFF, 0x74, 0xEE, 0x61, 0x00, 0x69,
+0x20, 0x6E, 0x02, 0x23, 0xE3, 0x67, 0x00, 0x6E,
+0x00, 0x6C, 0xFF, 0x6B, 0xA4, 0x67, 0x6C, 0xED,
+0x1D, 0x65, 0x01, 0x6D, 0xA4, 0xEC, 0xEC, 0xED,
+0x0B, 0x25, 0x98, 0x67, 0xD1, 0xE4, 0x6C, 0xEC,
+0x04, 0xD4, 0x0B, 0x22, 0x0C, 0x5C, 0x09, 0x61,
+0x20, 0x4C, 0x6C, 0xEC, 0x04, 0xD4, 0x05, 0x10,
+0x01, 0x4C, 0x20, 0x74, 0xEA, 0x61, 0x00, 0x6D,
+0x04, 0xD5, 0x5D, 0x67, 0x67, 0x42, 0x20, 0xC0,
+0x09, 0x4B, 0x40, 0xA3, 0x41, 0xC0, 0x05, 0x94,
+0x00, 0x18, 0xFE, 0x32, 0x05, 0x94, 0x7F, 0x6B,
+0x4C, 0xEB, 0x08, 0xD3, 0x00, 0x18, 0xFE, 0x32,
+0x08, 0x94, 0x62, 0x67, 0x06, 0xD1, 0x83, 0xE9,
+0x12, 0x61, 0xBD, 0x67, 0xC7, 0x45, 0x19, 0x4E,
+0x40, 0xA6, 0x08, 0x95, 0x04, 0x96, 0xFF, 0x6C,
+0x8C, 0xED, 0xCC, 0xEC, 0x83, 0xED, 0x04, 0x60,
+0x9D, 0x67, 0xA7, 0x44, 0x09, 0x4D, 0x40, 0xA5,
+0xFF, 0x6E, 0x4C, 0xEE, 0x06, 0xD6, 0x92, 0xA0,
+0x04, 0x6A, 0x8C, 0xEA, 0x08, 0x22, 0x80, 0x6A,
+0x6C, 0xEA, 0x05, 0x22, 0x06, 0x93, 0x4D, 0xEB,
+0xFF, 0x6A, 0x4C, 0xEB, 0x06, 0xD3, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0F, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x0B, 0x61,
+0x51, 0xA0, 0x05, 0x95, 0x06, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x03, 0x6F, 0x03, 0xF1, 0x00, 0x4C,
+0x4C, 0xEF, 0x00, 0x18, 0x39, 0x3D, 0x51, 0xA0,
+0x05, 0x94, 0x06, 0x95, 0x03, 0x6F, 0x00, 0x6E,
+0x4C, 0xEF, 0x00, 0x18, 0x6A, 0x49, 0x9D, 0x67,
+0xA7, 0x44, 0x15, 0x4D, 0x80, 0xA5, 0x4A, 0x59,
+0x82, 0xC0, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x48, 0x6B, 0x3F, 0x10,
+0x40, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x40, 0x6B, 0x37, 0x10,
+0x36, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x38, 0x6B, 0x2F, 0x10,
+0x2C, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x30, 0x6B, 0x27, 0x10,
+0x24, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x28, 0x6B, 0x1F, 0x10,
+0x1C, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x20, 0x6B, 0x17, 0x10,
+0x14, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x18, 0x6B, 0x0F, 0x10,
+0x0C, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x10, 0x6B, 0x07, 0x10,
+0x04, 0x59, 0x07, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x08, 0x6B, 0x6D, 0xEA,
+0x04, 0x10, 0x73, 0xA0, 0x79, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x53, 0xC0, 0x00, 0x18, 0xD2, 0x41,
+0x30, 0xF0, 0x20, 0x6A, 0x8E, 0xF2, 0x6D, 0xA2,
+0x03, 0x6A, 0x6C, 0xEA, 0x18, 0x22, 0x01, 0x72,
+0x38, 0x6D, 0x04, 0x60, 0x02, 0x72, 0x2D, 0x6D,
+0x01, 0x60, 0x15, 0x6D, 0x51, 0xA0, 0x05, 0x94,
+0x03, 0x6E, 0x4C, 0xEE, 0x00, 0x18, 0x43, 0x4F,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x28, 0xF4, 0x95, 0xA2, 0x04, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x28, 0xF4, 0x75, 0xC2, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xF3, 0x63, 0x19, 0x62, 0x18, 0xD1, 0x17, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x6D, 0x8C, 0xE9,
+0x2E, 0x68, 0x06, 0x04, 0xE0, 0xF3, 0x14, 0x4D,
+0x1E, 0x6E, 0x00, 0x18, 0x21, 0x1E, 0x18, 0xE9,
+0x30, 0xF0, 0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A,
+0x12, 0xE8, 0x01, 0xE2, 0x76, 0xA0, 0x01, 0x6A,
+0x6D, 0xEA, 0x70, 0xA0, 0x56, 0xC0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x50, 0xC0,
+0xE9, 0xF6, 0x08, 0x4B, 0x00, 0x6A, 0x80, 0xA3,
+0x8A, 0xE9, 0x0F, 0xD4, 0x07, 0x60, 0x01, 0x4A,
+0xFF, 0x6C, 0x8C, 0xEA, 0x06, 0x72, 0x01, 0x4B,
+0xF6, 0x61, 0xF3, 0x10, 0x22, 0x67, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB, 0x12, 0x2B,
+0x1C, 0x10, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF1,
+0x14, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0,
+0x20, 0x6C, 0x23, 0xF1, 0x04, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0xE2, 0x10, 0x63, 0xF5, 0x5C, 0x9A,
+0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x23, 0xF1, 0x18, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x72, 0xA0, 0x01, 0x6C, 0xF1, 0xA0,
+0x6A, 0x33, 0x8C, 0xEB, 0xC4, 0xA0, 0x04, 0xD3,
+0x71, 0xA0, 0x0F, 0x95, 0x03, 0x6A, 0x72, 0x33,
+0x30, 0xF0, 0x20, 0x6C, 0x4C, 0xEB, 0x4C, 0xEF,
+0x43, 0xF1, 0x0C, 0x4C, 0x05, 0xD3, 0x00, 0x18,
+0x39, 0x3D, 0x0F, 0x95, 0xBE, 0x32, 0xA0, 0xF0,
+0x1F, 0x2A, 0xAC, 0x32, 0x11, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x11, 0x93, 0x41, 0xF1, 0x50, 0x9A,
+0x49, 0xE3, 0x14, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x5C, 0x9A, 0x49, 0xE3, 0x13, 0xD2,
+0x05, 0x6A, 0x58, 0xE9, 0x06, 0x02, 0x12, 0xE9,
+0x29, 0xE2, 0x10, 0xD2, 0x00, 0xF0, 0x1D, 0x02,
+0x29, 0xE2, 0x12, 0xD2, 0x30, 0x67, 0x10, 0x93,
+0x2E, 0x68, 0x7F, 0x6D, 0x40, 0xA3, 0x01, 0x6E,
+0x7F, 0x4A, 0x0E, 0xD2, 0x0E, 0x94, 0xFF, 0x6A,
+0x4C, 0xEC, 0x18, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0x0E, 0xD4, 0x89, 0xF7, 0x18, 0x4A, 0x12, 0xE8,
+0x01, 0xE2, 0x51, 0xA1, 0x71, 0xA0, 0x5E, 0x32,
+0x5C, 0x32, 0xAC, 0xEB, 0x4D, 0xEB, 0x71, 0xC0,
+0x91, 0xA1, 0x41, 0x6A, 0x4B, 0xEA, 0x9A, 0x34,
+0xCC, 0xEC, 0x98, 0x34, 0x6C, 0xEA, 0x8D, 0xEA,
+0x51, 0xC0, 0x64, 0xA1, 0x03, 0x6C, 0x64, 0xC0,
+0xF1, 0xA1, 0x04, 0x6B, 0x6B, 0xEB, 0x8C, 0xEF,
+0x4C, 0xEB, 0xED, 0xEB, 0x71, 0xC0, 0xF1, 0xA1,
+0x0D, 0x6A, 0x4B, 0xEA, 0x8C, 0xEF, 0xE8, 0x37,
+0x6C, 0xEA, 0xED, 0xEA, 0xF2, 0xA0, 0x05, 0x6B,
+0x6B, 0xEB, 0xEC, 0xEB, 0x51, 0xC0, 0x72, 0xC0,
+0x71, 0xA1, 0x72, 0x33, 0x8C, 0xEB, 0x70, 0x34,
+0x31, 0x6B, 0x6B, 0xEB, 0x4C, 0xEB, 0x56, 0xA0,
+0x8D, 0xEB, 0x71, 0xC0, 0x4D, 0xEE, 0x50, 0xA0,
+0xD6, 0xC0, 0x4C, 0xED, 0xB0, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x70, 0x9A, 0x11, 0x94,
+0x0E, 0x95, 0x69, 0xE4, 0xAC, 0x34, 0x6D, 0xE4,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF2, 0xB0, 0x9C,
+0x11, 0x94, 0xB5, 0xE4, 0xC0, 0xA2, 0xFF, 0x6C,
+0x01, 0x4A, 0x8C, 0xEE, 0xAA, 0xEA, 0xC0, 0xC3,
+0x01, 0x4B, 0xF8, 0x61, 0x76, 0xA1, 0x02, 0x6A,
+0x6C, 0xEA, 0x8C, 0xEA, 0x1C, 0x22, 0x0E, 0x95,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x90, 0x9A,
+0xAC, 0x33, 0x14, 0x95, 0x91, 0xE3, 0x40, 0x9D,
+0x30, 0xF0, 0x20, 0x6D, 0x01, 0xF2, 0xB4, 0x9D,
+0xAC, 0xEA, 0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6A,
+0x13, 0x94, 0x21, 0xF1, 0x5C, 0x9A, 0x4D, 0xE3,
+0x40, 0x9C, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF2,
+0x98, 0x9C, 0x8C, 0xEA, 0x40, 0xDB, 0x0F, 0x94,
+0x00, 0x18, 0x67, 0x4F, 0x0E, 0x94, 0x00, 0x18,
+0x67, 0x4F, 0xB1, 0xA1, 0x0F, 0x94, 0x03, 0x6A,
+0x4C, 0xED, 0x00, 0x18, 0x00, 0x4A, 0xB1, 0xA0,
+0x0E, 0x94, 0x03, 0x6B, 0x6C, 0xED, 0x00, 0x18,
+0x00, 0x4A, 0x10, 0x94, 0x12, 0x95, 0x01, 0x4C,
+0xAA, 0xEC, 0x10, 0xD4, 0x7F, 0xF7, 0x07, 0x61,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A, 0x02, 0x6C,
+0x8C, 0xEB, 0x1F, 0xF7, 0x0E, 0x2B, 0x17, 0x17,
+0x19, 0x97, 0x18, 0x91, 0x17, 0x90, 0x0D, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x48, 0xF5, 0x27, 0xA2,
+0x2E, 0x68, 0x48, 0xF5, 0x46, 0xA2, 0x18, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0x89, 0xF7, 0x18, 0x4B,
+0x02, 0x72, 0x12, 0xE8, 0x01, 0xE3, 0x30, 0x60,
+0x03, 0x5A, 0x03, 0x60, 0x01, 0x72, 0x07, 0x60,
+0xA7, 0x10, 0x03, 0x72, 0x70, 0x60, 0x04, 0x72,
+0x80, 0xF0, 0x0B, 0x60, 0xA1, 0x10, 0x0C, 0x6A,
+0x7D, 0x67, 0x4F, 0xCB, 0x9D, 0x67, 0x0E, 0x6B,
+0x70, 0xC4, 0x52, 0xC4, 0x5B, 0xA0, 0x03, 0x6B,
+0xBD, 0x67, 0x53, 0xC4, 0x43, 0xA0, 0x54, 0xC4,
+0x51, 0xA0, 0x4A, 0x34, 0x6C, 0xEC, 0x95, 0xC5,
+0x82, 0x67, 0x6C, 0xEC, 0x96, 0xC5, 0x85, 0xA0,
+0x97, 0xC5, 0x86, 0xA0, 0x98, 0xC5, 0x5E, 0x34,
+0x52, 0x32, 0x6C, 0xEA, 0x99, 0xC5, 0x5A, 0xC5,
+0x52, 0xA0, 0x01, 0x6B, 0x4A, 0x32, 0x6C, 0xEA,
+0x5B, 0xC5, 0x58, 0xA0, 0x5C, 0xC5, 0x62, 0x10,
+0x7D, 0x67, 0x0C, 0x6A, 0x4F, 0xCB, 0x0E, 0x6A,
+0x50, 0xC3, 0x0D, 0x6A, 0x52, 0xC3, 0x44, 0xA0,
+0x2C, 0x31, 0x53, 0xC3, 0x40, 0xA0, 0x54, 0xC3,
+0x41, 0xA0, 0x55, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x50, 0x9A, 0x49, 0xE1, 0x40, 0xA2,
+0x56, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2,
+0x5C, 0x9A, 0x49, 0xE1, 0x40, 0xA2, 0x57, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A,
+0x49, 0xE1, 0x40, 0xA2, 0x58, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x44, 0x9A, 0x49, 0xE1,
+0x40, 0xA2, 0x59, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x5C, 0x9A, 0x49, 0xE1, 0x40, 0xA2,
+0x5A, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x48, 0x9A, 0x49, 0xE1, 0x40, 0xA2, 0x5B, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x4C, 0x9A,
+0x49, 0xE1, 0x40, 0xA2, 0x5C, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x50, 0x9A, 0x45, 0xE1,
+0x40, 0xA1, 0x5D, 0xC3, 0x2F, 0x10, 0x9D, 0x67,
+0x0C, 0x6A, 0x4F, 0xCC, 0x0E, 0x6A, 0x50, 0xC4,
+0x52, 0xC4, 0x59, 0xA0, 0x53, 0xC4, 0x20, 0xF0,
+0x42, 0xA0, 0x57, 0xC4, 0x20, 0xF0, 0x43, 0xA0,
+0x58, 0xC4, 0x91, 0x67, 0x00, 0x18, 0xFE, 0x32,
+0xBD, 0x67, 0x59, 0xC5, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x4C, 0x9A, 0x34, 0x31, 0x45, 0xE1,
+0x40, 0xA1, 0x5A, 0xC5, 0x48, 0xA0, 0x5D, 0xC5,
+0x11, 0x10, 0x7D, 0x67, 0x03, 0x6A, 0x4F, 0xCB,
+0x0E, 0x6A, 0x50, 0xC3, 0x0F, 0x6A, 0x52, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF1, 0x64, 0xA2,
+0x80, 0xF1, 0x04, 0x4A, 0x41, 0xA2, 0x9D, 0x67,
+0x73, 0xC4, 0x54, 0xC4, 0x04, 0x94, 0x05, 0x95,
+0x06, 0x96, 0x07, 0x97, 0x00, 0x18, 0xAA, 0x33,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6D,
+0x30, 0xF0, 0x20, 0x6B, 0x90, 0xF2, 0x0C, 0x4D,
+0x30, 0xF0, 0x20, 0x6E, 0x30, 0xF0, 0x21, 0x6C,
+0x2E, 0xF6, 0x00, 0x4B, 0xAE, 0xF3, 0x04, 0x4E,
+0x50, 0xF6, 0x06, 0x4C, 0xE5, 0x67, 0x00, 0x6A,
+0x40, 0xDB, 0x41, 0xDB, 0x42, 0xDB, 0x43, 0xDB,
+0x44, 0xDB, 0x14, 0x4B, 0xEA, 0xEB, 0x40, 0xC5,
+0x40, 0xDE, 0x80, 0xF0, 0x5F, 0xC5, 0x20, 0xF1,
+0x5E, 0xC5, 0x04, 0x4E, 0x40, 0xCC, 0xDF, 0xF6,
+0x42, 0xCC, 0x40, 0xF1, 0x42, 0xCC, 0x80, 0xF2,
+0x40, 0xCC, 0xA0, 0xF3, 0x5E, 0xCC, 0x01, 0x4D,
+0x02, 0x4C, 0xE5, 0x61, 0x30, 0xF0, 0x21, 0x6A,
+0x78, 0x67, 0x90, 0xF7, 0x64, 0xDA, 0x20, 0xE8,
+0xFF, 0x6A, 0x8C, 0xEA, 0xF5, 0xF3, 0xA4, 0x42,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0xA4, 0x35, 0x00, 0x6C, 0x75, 0xE5, 0x83, 0xCD,
+0x55, 0xF3, 0xA4, 0x42, 0xA4, 0x35, 0x75, 0xE5,
+0x84, 0xCD, 0x95, 0xF4, 0xA4, 0x42, 0xA4, 0x35,
+0x75, 0xE5, 0x84, 0xCD, 0x35, 0xF5, 0xA4, 0x42,
+0xC5, 0xF5, 0x14, 0x4A, 0xA4, 0x35, 0x44, 0x32,
+0x75, 0xE5, 0x6D, 0xE2, 0x83, 0xCD, 0x82, 0xCB,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x8C, 0xEA,
+0x14, 0x6D, 0xB8, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x45, 0xF6, 0x18, 0x4C, 0x00, 0x6B, 0x12, 0xED,
+0x95, 0xE5, 0xC8, 0xF7, 0x68, 0xDD, 0xC8, 0xF7,
+0x6C, 0xDD, 0xC8, 0xF7, 0x70, 0xDD, 0xC8, 0xF7,
+0x74, 0xDD, 0xC8, 0xF7, 0x78, 0xDD, 0x95, 0xE2,
+0x42, 0xF1, 0x12, 0x4A, 0x48, 0x32, 0x91, 0xE2,
+0x2A, 0xF4, 0x74, 0xC5, 0x61, 0xDC, 0x20, 0xE8,
+0xFF, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x18, 0x4B, 0x8C, 0xEA, 0x69, 0xE2, 0x00, 0x6B,
+0xCA, 0xF4, 0x73, 0xC2, 0x6A, 0xF5, 0x72, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x21, 0xF2, 0x74, 0x9B, 0x4C, 0xEC,
+0x90, 0x34, 0x6D, 0xE4, 0xC0, 0xA3, 0x01, 0x6D,
+0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6, 0x18, 0x4B,
+0xCC, 0xED, 0xEB, 0xF4, 0xB2, 0xC3, 0x30, 0xF0,
+0x20, 0x6D, 0x21, 0xF2, 0xB8, 0x9D, 0xB5, 0xE4,
+0xC0, 0xA5, 0x7F, 0x6D, 0xCC, 0xED, 0xEB, 0xF4,
+0xAD, 0xC3, 0x30, 0xF0, 0x20, 0x6D, 0x21, 0xF2,
+0xBC, 0x9D, 0xB5, 0xE4, 0xA0, 0xA5, 0xEB, 0xF4,
+0xB1, 0xC3, 0x30, 0xF0, 0x20, 0x6D, 0x41, 0xF2,
+0xA0, 0x9D, 0xB5, 0xE4, 0xA0, 0xA5, 0xEB, 0xF4,
+0xB3, 0xC3, 0x30, 0xF0, 0x20, 0x6D, 0x41, 0xF2,
+0xA4, 0x9D, 0xB5, 0xE4, 0xC0, 0xA5, 0x3F, 0x6D,
+0xAC, 0xEE, 0xEB, 0xF4, 0xCE, 0xC3, 0x30, 0xF0,
+0x20, 0x6E, 0x41, 0xF2, 0xC8, 0x9E, 0xD9, 0xE4,
+0xC0, 0xA6, 0xAC, 0xEE, 0xEB, 0xF4, 0xCF, 0xC3,
+0x30, 0xF0, 0x20, 0x6E, 0x41, 0xF2, 0xCC, 0x9E,
+0xD9, 0xE4, 0xC0, 0xA6, 0xAC, 0xEE, 0xEB, 0xF4,
+0xD5, 0xC3, 0x30, 0xF0, 0x20, 0x6E, 0x41, 0xF2,
+0xD0, 0x9E, 0xD9, 0xE4, 0xC0, 0xA6, 0xEB, 0xF4,
+0xCC, 0xC3, 0x30, 0xF0, 0x20, 0x6E, 0x41, 0xF2,
+0xD4, 0x9E, 0xD9, 0xE4, 0xC0, 0xA6, 0xCC, 0xEA,
+0x56, 0x32, 0xEB, 0xF4, 0x50, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF2, 0x58, 0x9A, 0x49, 0xE4,
+0xC0, 0xA2, 0xCC, 0xED, 0xEB, 0xF4, 0xB6, 0xC3,
+0xA0, 0xA2, 0x40, 0x6A, 0xAC, 0xEA, 0xEB, 0xF4,
+0x57, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF2,
+0x5C, 0x9A, 0x51, 0xE4, 0x40, 0xA4, 0xEB, 0xF4,
+0x54, 0xC3, 0x20, 0xE8, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xFF, 0x6E, 0x41, 0xF2, 0x58, 0x9A, 0xCC, 0xEC,
+0x90, 0x34, 0x49, 0xE4, 0x40, 0xA2, 0x3F, 0x68,
+0x30, 0xF0, 0x20, 0x6F, 0x4C, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x58, 0x9A, 0x41, 0xF2,
+0xEC, 0x9F, 0x49, 0xE4, 0x40, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF2, 0x50, 0x9A, 0x49, 0xE4,
+0xA0, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF2,
+0x44, 0x9A, 0xCC, 0xED, 0x49, 0xE4, 0x60, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF2, 0x48, 0x9A,
+0xCC, 0xEB, 0x49, 0xE4, 0xF1, 0xE4, 0x40, 0xA2,
+0xE0, 0xA4, 0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF6,
+0x18, 0x4C, 0x91, 0xE0, 0xCC, 0xEA, 0xCC, 0xEF,
+0x84, 0xF0, 0xD5, 0xA4, 0xAE, 0xEE, 0x0D, 0x26,
+0xA4, 0xF0, 0x93, 0xA4, 0x01, 0x69, 0xAE, 0xEC,
+0x09, 0x24, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF1,
+0x14, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0xFF, 0x6A,
+0x48, 0x10, 0x00, 0x69, 0x30, 0xF0, 0x20, 0x6C,
+0x45, 0xF6, 0x18, 0x4C, 0xC4, 0xF0, 0xB2, 0xA4,
+0x36, 0x25, 0x0E, 0xED, 0x34, 0x2D, 0xC4, 0xF0,
+0xB3, 0xA4, 0x2E, 0xED, 0x30, 0x2D, 0xC4, 0xF0,
+0xB7, 0xA4, 0x2D, 0x25, 0xC4, 0xF0, 0xD8, 0xA4,
+0xBB, 0xEE, 0x01, 0x2D, 0xE5, 0xE8, 0x10, 0xED,
+0x1D, 0x2D, 0x3F, 0x6D, 0xAC, 0xEB, 0xAC, 0xEA,
+0xAC, 0xEF, 0x63, 0xF5, 0xB8, 0x9C, 0x02, 0x6E,
+0xC4, 0xF0, 0xF4, 0xC4, 0xCC, 0xED, 0xC4, 0xF0,
+0x75, 0xC4, 0xC4, 0xF0, 0x56, 0xC4, 0x0E, 0x25,
+0x63, 0xF5, 0x9C, 0x9C, 0x04, 0x5C, 0x0A, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF1, 0x00, 0x4C,
+0xB0, 0x67, 0xD1, 0x67, 0x04, 0xD3, 0x05, 0xD2,
+0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0xC4, 0xF0, 0x78, 0xA2,
+0x01, 0x4B, 0xC4, 0xF0, 0x78, 0xC2, 0x47, 0x40,
+0x78, 0x4A, 0x07, 0x29, 0x01, 0x6B, 0x47, 0x40,
+0x0C, 0xEB, 0x77, 0x4A, 0x02, 0x23, 0x80, 0x6A,
+0x0D, 0xEA, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xF4, 0x63, 0x17, 0x62,
+0x16, 0xD1, 0x15, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x82, 0x67, 0x0F, 0xD2, 0x00, 0x18, 0x75, 0x51,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0xEB, 0xF4, 0x0C, 0xA2, 0x2E, 0x69, 0x30, 0xF0,
+0x20, 0x6B, 0x38, 0xE8, 0x89, 0xF7, 0x18, 0x4B,
+0xEB, 0xF4, 0x8E, 0xA2, 0xEB, 0xF4, 0xAF, 0xA2,
+0xEB, 0xF4, 0xD1, 0xA2, 0x08, 0xD4, 0x0C, 0xD5,
+0x0D, 0xD6, 0xEB, 0xF4, 0x94, 0xA2, 0xEB, 0xF4,
+0xB6, 0xA2, 0xEB, 0xF4, 0xD7, 0xA2, 0x12, 0xD4,
+0x0E, 0xD5, 0x10, 0xD6, 0x12, 0xE9, 0x25, 0xE3,
+0xEB, 0xF4, 0x6D, 0xA2, 0x09, 0xD3, 0xEB, 0xF4,
+0x73, 0xA2, 0x11, 0xD3, 0xEB, 0xF4, 0x75, 0xA2,
+0x0B, 0xD3, 0xEB, 0xF4, 0x72, 0xA2, 0x0F, 0x23,
+0x63, 0xF5, 0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB,
+0x0A, 0x23, 0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF1,
+0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x7E, 0xA1,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6C,
+0x8C, 0xEA, 0x0C, 0x93, 0x01, 0x5A, 0x58, 0x67,
+0x4B, 0xEA, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6D,
+0xD5, 0xF5, 0x44, 0x40, 0x45, 0xF6, 0x18, 0x4D,
+0x44, 0x32, 0xA9, 0xE2, 0x0C, 0xD3, 0x09, 0x96,
+0x62, 0xAA, 0x0A, 0xD5, 0x6D, 0xE6, 0x62, 0xCA,
+0x10, 0x92, 0x07, 0x22, 0xC4, 0xF0, 0x5C, 0x9D,
+0x08, 0x93, 0x49, 0xE3, 0xC4, 0xF0, 0x5C, 0xDD,
+0x42, 0x12, 0x0E, 0x92, 0xFF, 0x4A, 0x8C, 0xEA,
+0x3E, 0x5A, 0x2A, 0x60, 0x0F, 0x94, 0x00, 0x18,
+0xAD, 0x51, 0x0A, 0x94, 0x02, 0x67, 0x02, 0x6B,
+0x63, 0xF5, 0x58, 0x9C, 0x6C, 0xEA, 0x0B, 0x22,
+0x63, 0xF5, 0x5C, 0x9C, 0x05, 0x5A, 0x07, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF1, 0x14, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0xFF, 0x70,
+0x20, 0xF2, 0x05, 0x60, 0x2E, 0x69, 0x38, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x89, 0xF7, 0x18, 0x4A,
+0x0B, 0x94, 0x12, 0xE9, 0x25, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0xE4, 0xF0,
+0x60, 0x9A, 0x6D, 0xE4, 0xE4, 0xF0, 0x60, 0xDA,
+0x71, 0xA1, 0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xFF, 0x6D, 0xAC, 0xEA, 0x00, 0xF2, 0x0B, 0x2A,
+0x12, 0x92, 0x01, 0x6B, 0x6C, 0xEA, 0x00, 0xF2,
+0x06, 0x2A, 0x0D, 0x92, 0x49, 0x6E, 0xCE, 0xEA,
+0x01, 0x5A, 0x98, 0x67, 0x02, 0x6A, 0x93, 0xE2,
+0x10, 0xD4, 0x56, 0xA1, 0x6C, 0xEA, 0xAC, 0xEA,
+0x0C, 0x22, 0x90, 0x67, 0x00, 0x18, 0xFE, 0x32,
+0x7F, 0x6D, 0x4C, 0xED, 0x0D, 0xD5, 0x72, 0xA1,
+0x40, 0x6A, 0xFF, 0x6E, 0x6C, 0xEA, 0xCC, 0xEA,
+0x13, 0x10, 0x0F, 0x92, 0x50, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF2, 0x44, 0x9A, 0x49, 0xE3,
+0x40, 0xA2, 0x00, 0xF6, 0x40, 0x32, 0x00, 0xF6,
+0x43, 0x32, 0x00, 0x52, 0x06, 0x60, 0x72, 0xA1,
+0x40, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x2A, 0x00, 0x6C, 0x0A, 0xD4, 0x02, 0x10,
+0x01, 0x6D, 0x0A, 0xD5, 0x6E, 0xA1, 0x08, 0x6A,
+0x6C, 0xEA, 0x19, 0x22, 0x08, 0x96, 0x09, 0x92,
+0x0A, 0x93, 0x04, 0xD6, 0x0B, 0x97, 0x0E, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0x05, 0xD2, 0xA3, 0xF1,
+0x1C, 0x4C, 0x00, 0x6A, 0xB0, 0x67, 0x06, 0xD3,
+0x07, 0xD2, 0x00, 0x18, 0x39, 0x3D, 0x0D, 0x95,
+0x11, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0xE3, 0xF1,
+0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB, 0x13, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x0F, 0x61,
+0x0A, 0x96, 0x11, 0x94, 0x09, 0x95, 0x06, 0xD6,
+0x0D, 0x97, 0x0E, 0x96, 0x04, 0xD4, 0x30, 0xF0,
+0x20, 0x6C, 0x05, 0xD5, 0xE3, 0xF1, 0x18, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5,
+0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB, 0x0F, 0x23,
+0x63, 0xF5, 0x5C, 0x9A, 0x05, 0x5A, 0x0B, 0x61,
+0x08, 0x95, 0x0C, 0x96, 0x0B, 0x97, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0x6A, 0x03, 0xF2, 0x1C, 0x4C,
+0x04, 0xD2, 0x00, 0x18, 0x39, 0x3D, 0x0B, 0x94,
+0x54, 0xA9, 0xFF, 0xF7, 0x1F, 0x6B, 0x8F, 0xE3,
+0x62, 0xEA, 0x02, 0x60, 0x49, 0xE4, 0x54, 0xC9,
+0x0B, 0x95, 0x55, 0xA9, 0xFF, 0xF7, 0x1F, 0x6B,
+0xAF, 0xE3, 0x62, 0xEA, 0x02, 0x60, 0x49, 0xE5,
+0x55, 0xC9, 0x0A, 0x96, 0x80, 0xF0, 0x1A, 0x26,
+0x0E, 0x93, 0xFF, 0x6A, 0xFF, 0x4B, 0x4C, 0xEB,
+0x3E, 0x5B, 0x1F, 0x60, 0x08, 0x94, 0x0B, 0x95,
+0x90, 0x33, 0x0F, 0x6C, 0x98, 0xED, 0x12, 0xEC,
+0x82, 0xEB, 0x25, 0x61, 0x09, 0x96, 0x02, 0x5E,
+0x22, 0x60, 0x08, 0x93, 0x6E, 0x35, 0x01, 0x4D,
+0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6B, 0xAC, 0xEA,
+0x45, 0xF6, 0x18, 0x4B, 0x06, 0x5A, 0x6D, 0xE0,
+0x85, 0x67, 0x01, 0x61, 0x05, 0x6C, 0xCA, 0xF4,
+0x53, 0xA3, 0x91, 0xE2, 0xCA, 0xF4, 0x93, 0xC3,
+0x18, 0x10, 0x09, 0x94, 0x02, 0x5C, 0x0B, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A,
+0x49, 0xE0, 0xCA, 0xF4, 0x73, 0xA2, 0x01, 0x4B,
+0xCA, 0xF4, 0x73, 0xC2, 0x0A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x18, 0x4A, 0x49, 0xE0,
+0x6A, 0xF5, 0x72, 0xA2, 0x01, 0x4B, 0x6A, 0xF5,
+0x72, 0xC2, 0x6E, 0xA1, 0x08, 0x6A, 0x6C, 0xEA,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x49, 0xE0, 0xCA, 0xF4, 0xB3, 0xA2,
+0x6A, 0xF5, 0xD2, 0xA2, 0x30, 0xF0, 0x20, 0x6C,
+0x23, 0xF2, 0x14, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x2E, 0x6A, 0x58, 0xE8, 0x30, 0xF0, 0x20, 0x69,
+0x45, 0xF6, 0x18, 0x49, 0x35, 0xE0, 0x08, 0xD5,
+0xCA, 0xF4, 0x73, 0xA5, 0x12, 0xEA, 0x29, 0xE2,
+0x44, 0xF1, 0x58, 0xA2, 0x43, 0xEB, 0x17, 0x61,
+0x90, 0x67, 0x01, 0x6D, 0x00, 0x18, 0xA8, 0x4E,
+0x63, 0xF5, 0x58, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x2D, 0x22, 0x63, 0xF5, 0x5C, 0x99, 0x05, 0x5A,
+0x29, 0x61, 0x08, 0x92, 0x30, 0xF0, 0x20, 0x6C,
+0x43, 0xF2, 0x00, 0x4C, 0xCA, 0xF4, 0xB3, 0xA2,
+0x6A, 0xF5, 0xD2, 0xA2, 0x1D, 0x10, 0x08, 0x93,
+0x10, 0x94, 0x6A, 0xF5, 0x52, 0xA3, 0x83, 0xEA,
+0xE0, 0xF0, 0x11, 0x61, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0xA8, 0x4E, 0x63, 0xF5, 0x58, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x0F, 0x22, 0x63, 0xF5,
+0x5C, 0x99, 0x05, 0x5A, 0x0B, 0x61, 0x08, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF2, 0x10, 0x4C,
+0xCA, 0xF4, 0xB3, 0xA6, 0x6A, 0xF5, 0xD2, 0xA6,
+0x00, 0x18, 0x39, 0x3D, 0x90, 0x67, 0x00, 0x18,
+0x6E, 0x51, 0xD5, 0x10, 0x09, 0x94, 0x5D, 0x67,
+0x67, 0x42, 0x1D, 0x4B, 0x05, 0x5C, 0x20, 0xA3,
+0x01, 0x61, 0x04, 0x69, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x51, 0xE0, 0x2A, 0xF4,
+0xB4, 0xA4, 0x0C, 0x96, 0xFF, 0x6B, 0x6C, 0xE9,
+0xB5, 0xE6, 0x2A, 0xF4, 0xB4, 0xC4, 0x0E, 0x94,
+0xFF, 0x4C, 0x6C, 0xEC, 0x3E, 0x5C, 0x65, 0x60,
+0x04, 0x59, 0x0B, 0x60, 0x14, 0x6B, 0x78, 0xE8,
+0x08, 0x94, 0x12, 0xEB, 0x49, 0xE3, 0xC8, 0xF7,
+0x68, 0x9A, 0x6D, 0xE4, 0xC8, 0xF7, 0x68, 0xDA,
+0x0A, 0x10, 0x14, 0x6B, 0x78, 0xE8, 0x08, 0x94,
+0x12, 0xEB, 0x49, 0xE3, 0xC8, 0xF7, 0x78, 0x9A,
+0x6D, 0xE4, 0xC8, 0xF7, 0x78, 0xDA, 0x30, 0xF0,
+0x20, 0x6D, 0x52, 0xF1, 0x42, 0x40, 0x45, 0xF6,
+0x18, 0x4D, 0x48, 0x32, 0xA9, 0xE2, 0x0A, 0xD2,
+0x0B, 0x96, 0x41, 0x9A, 0x0A, 0x93, 0x09, 0xD5,
+0xC9, 0xE2, 0x41, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x48, 0x9A, 0x60, 0xA2, 0x40, 0x6A,
+0x6C, 0xEA, 0x1B, 0x22, 0x0C, 0x94, 0x08, 0x97,
+0x04, 0xD6, 0x05, 0xD4, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF2, 0x00, 0x4C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x14, 0x6A, 0x58, 0xE8,
+0x09, 0x93, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF2,
+0x1C, 0x4C, 0x12, 0xEA, 0x69, 0xE2, 0xC8, 0xF7,
+0xA8, 0x9A, 0x0A, 0x92, 0xC1, 0x9A, 0x00, 0x18,
+0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A, 0x02, 0x6C,
+0x8C, 0xEB, 0x69, 0x23, 0x63, 0xF5, 0x7C, 0x9A,
+0x05, 0x5B, 0x65, 0x61, 0x14, 0x6B, 0x78, 0xE8,
+0x42, 0xF1, 0x12, 0x48, 0x08, 0x30, 0x30, 0xF0,
+0x20, 0x6C, 0x83, 0xF2, 0x0C, 0x4C, 0x12, 0xEB,
+0x4D, 0xE3, 0xC8, 0xF7, 0xA8, 0x9B, 0x49, 0xE0,
+0x53, 0x10, 0x05, 0x6B, 0x78, 0xE8, 0x08, 0x94,
+0x0C, 0x96, 0x12, 0xEB, 0x2D, 0xE3, 0xE2, 0xF1,
+0x10, 0x4B, 0x68, 0x33, 0x4D, 0xE3, 0x0B, 0xD3,
+0x62, 0x9B, 0x0B, 0x95, 0x8D, 0xE3, 0x62, 0xDD,
+0x52, 0xF1, 0x62, 0x40, 0x68, 0x33, 0x4D, 0xE3,
+0x09, 0xD3, 0x61, 0x9B, 0x89, 0xE6, 0x49, 0xE3,
+0x09, 0x93, 0x41, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x48, 0x9A, 0x60, 0xA2, 0x40, 0x6A,
+0x6C, 0xEA, 0x14, 0x22, 0x08, 0x97, 0x30, 0xF0,
+0x20, 0x6C, 0x04, 0xD6, 0x83, 0xF2, 0x1C, 0x4C,
+0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x39, 0x3D,
+0x0B, 0x96, 0x09, 0x92, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0x9E, 0xC1, 0x9A, 0xA3, 0xF2, 0x14, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A,
+0x45, 0xF6, 0x18, 0x4A, 0x63, 0xF5, 0x78, 0x9A,
+0x02, 0x6C, 0x8C, 0xEB, 0x18, 0x23, 0x63, 0xF5,
+0x7C, 0x9A, 0x05, 0x5B, 0x14, 0x61, 0x05, 0x6B,
+0x78, 0xE8, 0x42, 0xF1, 0x12, 0x48, 0x08, 0x30,
+0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF2, 0x0C, 0x4C,
+0x12, 0xEB, 0x25, 0xE3, 0xE2, 0xF1, 0x10, 0x49,
+0x28, 0x31, 0x45, 0xE1, 0xA2, 0x99, 0x49, 0xE0,
+0xC1, 0x9A, 0x00, 0x18, 0x39, 0x3D, 0x17, 0x97,
+0x16, 0x91, 0x15, 0x90, 0x0C, 0x63, 0x00, 0xEF,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF0, 0x64, 0x9B, 0x46, 0x67, 0x8E, 0xEB,
+0x12, 0x23, 0x00, 0x6E, 0x66, 0x67, 0xE4, 0x67,
+0xE6, 0xEE, 0x01, 0x68, 0x0C, 0xEF, 0x07, 0x2F,
+0x01, 0x4B, 0xFF, 0x6F, 0xEC, 0xEB, 0x14, 0x73,
+0x01, 0x4E, 0xF5, 0x61, 0x14, 0x6B, 0x8F, 0xEC,
+0x44, 0xEB, 0xAC, 0xEC, 0x8D, 0xEA, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6B, 0x6C, 0xEC,
+0x48, 0x44, 0xD4, 0x4A, 0x6C, 0xEA, 0x59, 0x5A,
+0x58, 0x67, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x00, 0x6A, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0x00, 0x6A, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x01, 0x75,
+0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x1C, 0x9A, 0x41, 0xF1, 0x08, 0x6C, 0x01, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x41, 0xF1,
+0x0C, 0x6C, 0xB0, 0x67, 0x00, 0x6E, 0x10, 0x10,
+0x02, 0x75, 0x1F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x1C, 0x9A, 0x41, 0xF1, 0x08, 0x6C,
+0x02, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x41, 0xF1, 0x0C, 0x6C, 0xB0, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0x18, 0x9A, 0x21, 0xF4, 0x00, 0x6C,
+0x00, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x21, 0xF6, 0x00, 0x6C, 0xB0, 0x67, 0x00, 0x6E,
+0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x1C, 0x9A, 0x41, 0xF1, 0x08, 0x6C, 0x02, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67,
+0x41, 0xF1, 0x0C, 0x6C, 0x02, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0x18, 0x9A, 0x21, 0xF4, 0x00, 0x6C, 0x01, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x21, 0xF6,
+0x00, 0x6C, 0xB0, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x15, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0xBC, 0x9A, 0x01, 0xF0,
+0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x36, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xC3, 0xF2, 0x04, 0x4C, 0x16, 0x10,
+0x01, 0x75, 0x1B, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0xBC, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x03, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x1F, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0xE3, 0xF2, 0x14, 0x4C, 0x30, 0xF0, 0x20, 0x6D,
+0xE0, 0xF4, 0x08, 0x4D, 0x00, 0x18, 0x39, 0x3D,
+0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x74, 0x9A, 0x44, 0x9C, 0x4C, 0xEB, 0x00, 0x6A,
+0x0D, 0x23, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x20, 0x6D, 0x23, 0xF3, 0x04, 0x4C, 0xE0, 0xF4,
+0x08, 0x4D, 0x00, 0x18, 0x39, 0x3D, 0x00, 0x6A,
+0x01, 0x10, 0x01, 0x6A, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x4C, 0xEF,
+0x0F, 0xD5, 0x08, 0xD7, 0x20, 0xF0, 0x6E, 0xA4,
+0x04, 0x67, 0x26, 0x67, 0x0E, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x9C,
+0x6C, 0xEA, 0x4A, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x23, 0xF3, 0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x43, 0x10, 0x02, 0x5E, 0x03, 0x60, 0x08, 0x93,
+0x54, 0x5B, 0x11, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x74, 0x9A, 0x44, 0x98, 0x4C, 0xEB,
+0x00, 0x6A, 0x37, 0x23, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF3, 0x18, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x39, 0x3D, 0x00, 0x6A, 0x2E, 0x10, 0x03, 0xF5,
+0x00, 0x6B, 0x06, 0xD3, 0x7F, 0x4B, 0x01, 0x4B,
+0x07, 0xD3, 0x08, 0x93, 0x04, 0x6C, 0x8B, 0xEC,
+0x6C, 0xEC, 0x4C, 0xEC, 0x06, 0x03, 0xC8, 0x32,
+0x4D, 0xE3, 0x09, 0xD3, 0x60, 0x9B, 0x0F, 0x96,
+0x01, 0x6D, 0x71, 0xE4, 0xFF, 0xF7, 0x1F, 0x6B,
+0x6C, 0xEC, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x0D, 0x22, 0x09, 0x92,
+0x08, 0x96, 0x0F, 0x93, 0xE0, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF3, 0x14, 0x4C, 0xB1, 0x67,
+0xFD, 0xE6, 0x04, 0xD3, 0x00, 0x18, 0x39, 0x3D,
+0x01, 0x6A, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xAC, 0xEA,
+0x06, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x9C, 0x04, 0x67, 0x20, 0xF0,
+0x25, 0xA4, 0x6C, 0xEA, 0x0F, 0x22, 0x20, 0xF0,
+0xCB, 0xA4, 0x20, 0xF0, 0xEC, 0xA4, 0x20, 0xF0,
+0x44, 0xA4, 0x06, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0x03, 0xF4, 0x00, 0x4C, 0x04, 0xD2, 0x05, 0xD1,
+0x00, 0x18, 0x39, 0x3D, 0x06, 0x93, 0xFF, 0x6A,
+0xF1, 0x4B, 0x4C, 0xEB, 0x15, 0x5B, 0x20, 0xF2,
+0x07, 0x61, 0x06, 0x93, 0x20, 0xF2, 0x04, 0x23,
+0x0F, 0x5B, 0x78, 0x67, 0x06, 0xD3, 0x98, 0x67,
+0x02, 0x6B, 0x8F, 0xE3, 0x04, 0x71, 0x20, 0xF0,
+0x72, 0xC0, 0x03, 0x60, 0x0B, 0x71, 0x80, 0xF0,
+0x00, 0x61, 0x06, 0x92, 0x59, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF2,
+0x04, 0x4B, 0x61, 0xF2, 0x20, 0x9A, 0xC0, 0x9B,
+0xA1, 0xF4, 0x10, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2,
+0x04, 0x4A, 0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF6,
+0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69, 0x00, 0x18,
+0x0E, 0x29, 0xB1, 0x67, 0xA1, 0xF4, 0x14, 0x6C,
+0x57, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0xB1, 0x67,
+0xA1, 0xF6, 0x14, 0x6C, 0xA1, 0xF4, 0x1C, 0x69,
+0x57, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x91, 0x67,
+0x3F, 0x6D, 0x08, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D, 0x02, 0x6E,
+0x00, 0xF2, 0x00, 0x49, 0x00, 0x18, 0x0E, 0x29,
+0x91, 0x67, 0x3F, 0x6D, 0x08, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x02, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x20, 0xF0,
+0x6C, 0xA0, 0x03, 0x73, 0x04, 0x60, 0x20, 0xF0,
+0x4B, 0xA0, 0x03, 0x72, 0x05, 0x61, 0xFF, 0xF7,
+0x1F, 0x68, 0x5E, 0xF0, 0x10, 0x69, 0x2A, 0x11,
+0x6E, 0xEA, 0x05, 0x2A, 0xFF, 0xF7, 0x1F, 0x68,
+0x5E, 0xF0, 0x15, 0x69, 0x23, 0x11, 0xFF, 0xF7,
+0x1F, 0x68, 0x5E, 0xF5, 0x10, 0x69, 0x1E, 0x11,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF2, 0x20, 0x9A, 0x61, 0xF2, 0x08, 0x4B,
+0xC0, 0x9B, 0xB1, 0x67, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF2, 0x08, 0x4A, 0xC0, 0x9A, 0xB1, 0x67,
+0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF4, 0x14, 0x6C,
+0xB1, 0x67, 0x75, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E,
+0xD3, 0x10, 0x6F, 0x41, 0x4C, 0xEB, 0x02, 0x5B,
+0x07, 0x61, 0x06, 0x71, 0x05, 0x60, 0x07, 0x71,
+0x03, 0x60, 0x09, 0x71, 0xE0, 0xF0, 0x1C, 0x61,
+0x20, 0xF0, 0x44, 0xA0, 0x01, 0x72, 0x62, 0x61,
+0x02, 0x59, 0x60, 0x60, 0x06, 0x93, 0x09, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2, 0x00, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2, 0x2C, 0x9A,
+0x08, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2,
+0x00, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2,
+0x30, 0x9A, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67,
+0xD1, 0x67, 0x1F, 0xF7, 0x00, 0x68, 0xA1, 0xF6,
+0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67,
+0xA1, 0xF4, 0x14, 0x6C, 0x45, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0xB0, 0x67, 0xA1, 0xF6, 0x14, 0x6C,
+0x45, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF2, 0xB4, 0x9A, 0xFF, 0xF7,
+0x1F, 0x68, 0x54, 0xF5, 0x15, 0x69, 0x01, 0xF0,
+0x10, 0x6C, 0x00, 0xF2, 0x11, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4,
+0x00, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF4, 0x1C, 0x68, 0xA1, 0xF6,
+0x00, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0x01, 0xF4,
+0x00, 0x69, 0x90, 0x67, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x6E, 0x00, 0xF2, 0x00, 0x48, 0x00, 0x18,
+0x0E, 0x29, 0x90, 0x67, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x6E, 0x92, 0x10, 0x06, 0x94, 0x30, 0x24,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2, 0x20, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2, 0x18, 0x4A,
+0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF2, 0x18, 0x4B, 0xC0, 0x9B, 0xB1, 0x67,
+0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF4, 0x14, 0x6C,
+0xB1, 0x67, 0x57, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67, 0x57, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF4, 0x18, 0x6C,
+0x10, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x18, 0x6C, 0x10, 0x6D, 0x2F, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2, 0x20, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2, 0x1C, 0x4A,
+0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF2, 0x1C, 0x4B, 0xC0, 0x9B, 0xB1, 0x67,
+0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF4, 0x14, 0x6C,
+0xB1, 0x67, 0x75, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF4, 0x18, 0x6C,
+0x20, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x18, 0x6C, 0x20, 0x6D, 0x00, 0x6E,
+0xA1, 0xF4, 0x1C, 0x69, 0x00, 0x18, 0x0E, 0x29,
+0x91, 0x67, 0x3F, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0xF2, 0x00, 0x49, 0x00, 0x18,
+0x0E, 0x29, 0x91, 0x67, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x91, 0x67, 0x01, 0xF4,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x20, 0xF0, 0x6C, 0xA0, 0x03, 0x73, 0x80, 0xF0,
+0x0D, 0x61, 0x90, 0x10, 0xFF, 0xF7, 0x1F, 0x68,
+0x14, 0xF0, 0x05, 0x69, 0xA1, 0xF4, 0x00, 0x6C,
+0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x00, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0x6A, 0x91, 0x10,
+0x0E, 0x21, 0x03, 0x71, 0x0C, 0x60, 0x05, 0x71,
+0x0A, 0x60, 0x08, 0x71, 0x08, 0x60, 0x0A, 0x71,
+0x06, 0x60, 0x0C, 0x71, 0x04, 0x60, 0x0D, 0x71,
+0x01, 0x6A, 0x80, 0xF0, 0x02, 0x61, 0x06, 0x94,
+0x25, 0x24, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2,
+0x20, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF2,
+0x04, 0x4A, 0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF2, 0x04, 0x4B, 0xC0, 0x9B,
+0xB1, 0x67, 0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7,
+0x00, 0x69, 0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF4,
+0x14, 0x6C, 0xB1, 0x67, 0x57, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67,
+0x57, 0x6E, 0x24, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF2, 0x20, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF2, 0x08, 0x4A, 0xC0, 0x9A, 0xB1, 0x67,
+0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF2, 0x08, 0x4B,
+0xC0, 0x9B, 0xB1, 0x67, 0xA1, 0xF6, 0x10, 0x6C,
+0x1F, 0xF7, 0x00, 0x69, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF4, 0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0xA1, 0xF6, 0x14, 0x6C,
+0xB1, 0x67, 0x75, 0x6E, 0xA1, 0xF4, 0x1C, 0x69,
+0x00, 0x18, 0x0E, 0x29, 0x91, 0x67, 0x3F, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x91, 0x67,
+0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0xF2,
+0x00, 0x49, 0x00, 0x18, 0x0E, 0x29, 0x91, 0x67,
+0x3F, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x06, 0x94, 0x7F, 0xF7,
+0x0F, 0x2C, 0x11, 0x10, 0x20, 0xF0, 0x4B, 0xA0,
+0x03, 0x72, 0x05, 0x61, 0xFF, 0xF7, 0x1F, 0x68,
+0x14, 0xF5, 0x01, 0x69, 0x6F, 0x17, 0x6E, 0xEA,
+0x7F, 0xF7, 0x08, 0x2A, 0xFF, 0xF7, 0x1F, 0x68,
+0x14, 0xF5, 0x00, 0x69, 0x67, 0x17, 0xFF, 0xF7,
+0x1F, 0x68, 0xB4, 0xF5, 0x05, 0x69, 0x62, 0x17,
+0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x44, 0x67, 0x80, 0xF6, 0x74, 0x9B, 0x84, 0x9C,
+0x8C, 0xEB, 0x08, 0x23, 0x20, 0xF0, 0xA5, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF4, 0x14, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0xBC, 0x9A, 0x64, 0x6C, 0x03, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0xA0, 0x9A, 0x4C, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x83, 0xF1, 0x10, 0x68,
+0x40, 0x6C, 0x04, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x01, 0xF4, 0x00, 0x69, 0x90, 0x67,
+0x3F, 0x6D, 0x30, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0xB1, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0xFD, 0xF7, 0x04, 0x48, 0x3F, 0x6D,
+0x90, 0x67, 0xC5, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0xB1, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x12, 0x92, 0x25, 0x67,
+0x04, 0x67, 0x06, 0xD2, 0x06, 0x93, 0xFF, 0x6A,
+0x4C, 0xEE, 0x4C, 0xEB, 0x4C, 0xEF, 0x4C, 0xE9,
+0x08, 0xD6, 0x07, 0xD7, 0x06, 0xD3, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x9C,
+0x6C, 0xEA, 0x09, 0x22, 0x06, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0x63, 0xF4, 0x18, 0x4C, 0xB1, 0x67,
+0x04, 0xD2, 0x00, 0x18, 0x39, 0x3D, 0x0C, 0x59,
+0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x98, 0x6C, 0xEA, 0x3E, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF4, 0x0C, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x36, 0x10,
+0x08, 0x93, 0x01, 0x6D, 0xA4, 0xE9, 0x01, 0x73,
+0x00, 0x6E, 0x01, 0x60, 0x01, 0x6E, 0x83, 0xF1,
+0x10, 0x6C, 0x00, 0x18, 0x0E, 0x29, 0x01, 0x68,
+0x07, 0x96, 0x04, 0xE9, 0xA1, 0xF4, 0x1C, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29, 0x07, 0x96,
+0xA1, 0xF6, 0x1C, 0x6C, 0xB0, 0x67, 0x00, 0x18,
+0x0E, 0x29, 0x08, 0x59, 0x0C, 0x60, 0x28, 0x31,
+0x0F, 0x68, 0x06, 0x96, 0x04, 0xE9, 0xA1, 0xF4,
+0x10, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x10, 0x6C, 0x0B, 0x10, 0x28, 0x31,
+0x0F, 0x68, 0x06, 0x96, 0x04, 0xE9, 0xA1, 0xF4,
+0x14, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x0E, 0x29,
+0xA1, 0xF6, 0x14, 0x6C, 0x06, 0x96, 0xB0, 0x67,
+0x00, 0x18, 0x0E, 0x29, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x02, 0x5D, 0x0E, 0xD4, 0x05, 0x67, 0x14, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x9C, 0x6C, 0xEA, 0x03, 0x2A, 0xFF, 0x4A,
+0x09, 0xD2, 0x37, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xC3, 0xF4, 0x0C, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x01, 0x6B, 0x6B, 0xEB, 0x09, 0xD3, 0x2D, 0x10,
+0x05, 0xF0, 0x00, 0x6A, 0x06, 0xD2, 0x00, 0xF4,
+0x00, 0x4A, 0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x24, 0x9A, 0x7D, 0x67, 0xA8, 0x32,
+0x49, 0xE3, 0x46, 0x9A, 0xFF, 0x6C, 0xCC, 0xEC,
+0x08, 0xD4, 0x88, 0x34, 0xEC, 0xE9, 0x51, 0xE4,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0xB1, 0x67,
+0x00, 0x18, 0x00, 0x29, 0x0E, 0x94, 0x09, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x9C, 0x6C, 0xEA, 0x0A, 0x22, 0x08, 0x96,
+0x09, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF5,
+0x08, 0x4C, 0xB0, 0x67, 0x04, 0xD1, 0x00, 0x18,
+0x39, 0x3D, 0x09, 0x92, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x02, 0x5D, 0x0E, 0xD4, 0x05, 0x67, 0x0E, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x9C, 0x6C, 0xEA, 0x64, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x43, 0xF5, 0x10, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x5D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x44, 0x9A, 0xFF, 0x69, 0x00, 0x6B,
+0x4C, 0xEF, 0x4A, 0xEF, 0xCC, 0xE9, 0x09, 0xD7,
+0x08, 0xD3, 0x1D, 0x60, 0x0E, 0x94, 0xD1, 0x67,
+0xE2, 0x67, 0x00, 0x18, 0x72, 0x55, 0x08, 0xD2,
+0x01, 0x4A, 0x0F, 0x2A, 0x0E, 0x94, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x9C,
+0x6C, 0xEA, 0x41, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x83, 0xF5, 0x0C, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x3A, 0x10, 0x09, 0x94, 0x08, 0x95, 0x12, 0x96,
+0x00, 0x18, 0x4E, 0x53, 0x12, 0xD2, 0x81, 0xF4,
+0x10, 0x6A, 0x06, 0xD2, 0x00, 0xF2, 0x00, 0x4A,
+0x07, 0xD2, 0x08, 0x33, 0x5D, 0x67, 0x6D, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x12, 0x94, 0x81, 0xF0,
+0x44, 0x9A, 0x01, 0x6D, 0xAB, 0xED, 0x8C, 0xEA,
+0x00, 0xF5, 0x20, 0x34, 0x8D, 0xEA, 0x8C, 0xAB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF2, 0xC4, 0x9B,
+0x4C, 0xEE, 0x00, 0x18, 0x0E, 0x29, 0x0E, 0x94,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x74, 0x9A,
+0x44, 0x9C, 0x4C, 0xEB, 0x01, 0x6A, 0x10, 0x23,
+0x08, 0x92, 0x09, 0x93, 0x12, 0x97, 0x30, 0xF0,
+0x20, 0x6C, 0xC3, 0xF5, 0x0C, 0x4C, 0xB0, 0x67,
+0xD1, 0x67, 0x04, 0xD2, 0x05, 0xD3, 0x00, 0x18,
+0x39, 0x3D, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xAC, 0xEA,
+0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x9C, 0x04, 0x67, 0x6C, 0xEA,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0x23, 0xF6,
+0x04, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x20, 0xF0,
+0x4E, 0xA0, 0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x64, 0x98, 0x6C, 0xEA,
+0xE0, 0xF0, 0x19, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF6, 0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0xF2, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xE4, 0x9A, 0x90, 0x67, 0x00, 0x6D, 0x18, 0x6E,
+0x00, 0x18, 0x72, 0x55, 0x07, 0x93, 0x06, 0xD2,
+0x0F, 0x5B, 0x31, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0xB4, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x40, 0xF4,
+0x14, 0x6C, 0x80, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0xB4, 0x9A, 0x81, 0xF2, 0x00, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0xF0, 0x14, 0x6C,
+0x1F, 0xF4, 0x00, 0x6D, 0x0F, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2,
+0x28, 0x9A, 0x20, 0xF0, 0x45, 0xA0, 0x06, 0x94,
+0xFF, 0x6B, 0xFE, 0x4A, 0x6C, 0xEA, 0x02, 0x5A,
+0x8C, 0xE9, 0x50, 0x61, 0x20, 0xF0, 0x45, 0xA0,
+0x05, 0x72, 0x6A, 0x61, 0x4B, 0x10, 0x07, 0x92,
+0x24, 0x5A, 0x5A, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xB4, 0x9A, 0x81, 0xF2, 0x00, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x40, 0xF4,
+0x14, 0x6C, 0x80, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xB4, 0x9A, 0x01, 0xF0, 0x08, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0xF0, 0x14, 0x6C,
+0x1F, 0xF4, 0x00, 0x6D, 0x22, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2,
+0x28, 0x9A, 0x06, 0x93, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0x54, 0x9A, 0x6C, 0xE9, 0xA3, 0xF1,
+0x08, 0x6C, 0x4D, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0xB8, 0x9A, 0x00, 0x18, 0x00, 0x29,
+0x01, 0x72, 0x14, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0xD8, 0x9A, 0x01, 0x6D, 0xC1, 0xF0,
+0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2, 0xB0, 0x9A,
+0xC1, 0xF0, 0x18, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0xCC, 0x9A, 0x01, 0x6D, 0xC1, 0xF0,
+0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x18, 0x6C,
+0x81, 0xF2, 0xB0, 0x9A, 0x01, 0x6E, 0xEB, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x4E, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF6, 0x00, 0x4C, 0x36, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xE4, 0x9A,
+0x90, 0x67, 0x00, 0x6D, 0x18, 0x6E, 0x04, 0xD1,
+0x00, 0x18, 0x9A, 0x55, 0x06, 0x94, 0x00, 0x6B,
+0x01, 0x4C, 0x01, 0x24, 0x01, 0x6B, 0xFF, 0x6C,
+0x4C, 0xEC, 0x5A, 0xA0, 0x6C, 0xEC, 0x06, 0xD4,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xE4, 0x9A, 0x90, 0x67, 0x01, 0x6D, 0x18, 0x6E,
+0x04, 0xD1, 0x00, 0x18, 0x9A, 0x55, 0x06, 0x93,
+0xFF, 0x6C, 0x4C, 0xEB, 0x8C, 0xEB, 0x06, 0xD3,
+0x07, 0x95, 0x90, 0x67, 0x00, 0x18, 0xED, 0x53,
+0x20, 0x22, 0x06, 0x92, 0x0F, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x17, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0xE3, 0xF6, 0x00, 0x4C, 0x07, 0x95, 0x00, 0x18,
+0x39, 0x3D, 0x0F, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x64, 0x98, 0x6C, 0xEA,
+0x0A, 0x22, 0x07, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0x43, 0xF7, 0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x02, 0x10, 0x00, 0x6A, 0x01, 0x10, 0x01, 0x6A,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2, 0xBC, 0x9A,
+0x83, 0xF1, 0x08, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0xAC, 0x9A, 0x81, 0xF7, 0x04, 0x6C, 0x00, 0x18,
+0x00, 0x29, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF6,
+0x68, 0x9B, 0x03, 0x2B, 0x50, 0x32, 0xEA, 0x6B,
+0x09, 0x10, 0x01, 0x73, 0x03, 0x61, 0x4C, 0x32,
+0x6C, 0x6B, 0x04, 0x10, 0x02, 0x73, 0x06, 0x61,
+0x48, 0x32, 0x34, 0x6B, 0x7A, 0xEA, 0x01, 0x2B,
+0xE5, 0xE8, 0x12, 0xEA, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x41, 0xF4, 0x10, 0x68,
+0x90, 0x67, 0x7F, 0x6D, 0x00, 0x18, 0x00, 0x29,
+0x22, 0x67, 0xFE, 0x4A, 0xC2, 0x67, 0x90, 0x67,
+0x7F, 0x6D, 0x04, 0xD2, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0xD1, 0x67, 0x7F, 0x6D, 0x00, 0x18,
+0x0E, 0x29, 0x04, 0x96, 0x00, 0xF2, 0x00, 0x48,
+0x90, 0x67, 0x7F, 0x6D, 0x00, 0x18, 0x0E, 0x29,
+0x90, 0x67, 0xD1, 0x67, 0x7F, 0x6D, 0x00, 0x18,
+0x0E, 0x29, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xEC, 0x63, 0x27, 0x62,
+0x26, 0xD1, 0x25, 0xD0, 0x30, 0xF0, 0x20, 0x6E,
+0x24, 0x67, 0x12, 0x05, 0xA0, 0xF1, 0x18, 0x4E,
+0x30, 0x6F, 0x00, 0x18, 0x75, 0x33, 0x20, 0xF0,
+0x45, 0xA1, 0x03, 0x72, 0x02, 0x60, 0x05, 0x72,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6E, 0x91, 0x67,
+0x06, 0x05, 0xE0, 0xF1, 0x08, 0x4E, 0x30, 0x6F,
+0x00, 0x18, 0x75, 0x33, 0x01, 0x6A, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6E, 0x91, 0x67, 0x06, 0x05,
+0x80, 0xF1, 0x08, 0x4E, 0x30, 0x6F, 0x00, 0x18,
+0x75, 0x33, 0x00, 0x6A, 0x22, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x0A, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x30, 0xF0, 0x20, 0x6D, 0x83, 0xF7, 0x0C, 0x4C,
+0x40, 0xF5, 0x04, 0x4D, 0x00, 0x18, 0x39, 0x3D,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x4C, 0xA2,
+0x0F, 0x5A, 0x0A, 0x60, 0x20, 0xF0, 0x0C, 0xA1,
+0xFF, 0x6A, 0xFF, 0x48, 0x4C, 0xE8, 0x02, 0x58,
+0x18, 0x67, 0x01, 0x6A, 0x4E, 0xE8, 0x09, 0x10,
+0x20, 0xF0, 0x0C, 0xA1, 0xFF, 0x6A, 0xFF, 0x48,
+0x4C, 0xE8, 0x02, 0x58, 0x18, 0x67, 0x03, 0x6A,
+0x03, 0xE2, 0x20, 0xF0, 0x45, 0xA1, 0x01, 0x72,
+0x12, 0x60, 0x04, 0x72, 0x10, 0x60, 0x06, 0x72,
+0x0E, 0x60, 0x07, 0x72, 0x0C, 0x60, 0x0B, 0x72,
+0x0A, 0x60, 0x02, 0x72, 0x02, 0x60, 0x09, 0x72,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x4C, 0xA2, 0x0F, 0x5A, 0x13, 0x61, 0x06, 0x02,
+0x08, 0x33, 0x6D, 0xE2, 0xCC, 0x9B, 0x64, 0x40,
+0x68, 0x33, 0x6D, 0xE2, 0x6C, 0x9B, 0x1E, 0xD3,
+0x67, 0x40, 0x01, 0x4B, 0x68, 0x33, 0x69, 0xE2,
+0x4C, 0x9A, 0x21, 0xD2, 0x00, 0x6A, 0x1F, 0xD2,
+0x01, 0x6A, 0x12, 0x10, 0x06, 0x02, 0x08, 0x33,
+0x6D, 0xE2, 0xC0, 0x9B, 0x64, 0x40, 0x68, 0x33,
+0x6D, 0xE2, 0x60, 0x9B, 0x1E, 0xD3, 0x67, 0x40,
+0x01, 0x4B, 0x68, 0x33, 0x69, 0xE2, 0x40, 0x9A,
+0x21, 0xD2, 0x01, 0x6A, 0x1F, 0xD2, 0x00, 0x6A,
+0x01, 0x6D, 0x21, 0xF0, 0x0C, 0x6C, 0xAB, 0xED,
+0x20, 0xD2, 0x00, 0x18, 0x0E, 0x29, 0x1F, 0x92,
+0x21, 0x22, 0x20, 0xF0, 0x44, 0xA1, 0x01, 0x72,
+0x04, 0x61, 0x01, 0x70, 0x06, 0x60, 0x03, 0x70,
+0x04, 0x60, 0x22, 0x92, 0x08, 0x2A, 0x03, 0x70,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0x48, 0x9A, 0x01, 0x72, 0x06, 0x60, 0x20, 0xF0,
+0x45, 0xA1, 0x05, 0x72, 0x0B, 0x61, 0x03, 0x70,
+0x09, 0x61, 0x01, 0x6D, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x10, 0x6C, 0xAB, 0xED, 0xA1, 0xF2,
+0xC0, 0x9A, 0x05, 0x10, 0x1E, 0x96, 0x01, 0x6D,
+0x21, 0xF0, 0x10, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x0E, 0x29, 0x21, 0x96, 0x01, 0x6D, 0x21, 0xF0,
+0x18, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x20, 0x92, 0x0E, 0x22, 0x20, 0xF0, 0x44, 0xA1,
+0x01, 0x72, 0x0A, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF2, 0xC4, 0x9A, 0x01, 0x6D, 0x21, 0xF0,
+0x1C, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x8C, 0xA2,
+0x00, 0x18, 0x5D, 0x53, 0x0C, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x48, 0x9A, 0x02, 0x72,
+0x06, 0x61, 0x21, 0xF0, 0x18, 0x6C, 0x01, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x12, 0x22, 0x20, 0xF0, 0xC6, 0xA1,
+0x20, 0xF0, 0xE7, 0xA1, 0x20, 0xF0, 0x45, 0xA1,
+0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0, 0x20, 0x6D,
+0xA3, 0xF7, 0x10, 0x4C, 0x40, 0xF5, 0x04, 0x4D,
+0x04, 0xD2, 0x05, 0xD0, 0x00, 0x18, 0x39, 0x3D,
+0x27, 0x97, 0x26, 0x91, 0x25, 0x90, 0x14, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xEC, 0xEA,
+0x06, 0xD2, 0x0D, 0xD5, 0x0E, 0xD6, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x9C,
+0x04, 0x67, 0x6C, 0xEA, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xC3, 0xF7, 0x18, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0x20, 0xF0, 0x4E, 0xA0, 0x0F, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x80, 0xF2, 0x0B, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x04, 0xF0, 0x10, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x84, 0x12, 0x0D, 0x93,
+0x04, 0x6A, 0x4B, 0xEA, 0x4C, 0xEB, 0x0E, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x60, 0xF2, 0x19, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x44, 0xF0, 0x0C, 0x4C,
+0x0D, 0x95, 0x10, 0x10, 0x0E, 0x93, 0x6C, 0xEA,
+0x10, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x98, 0x6C, 0xEA, 0x60, 0xF2,
+0x08, 0x22, 0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0x84, 0xF0, 0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D,
+0x60, 0x12, 0x0D, 0x93, 0x0E, 0x92, 0x6D, 0xEA,
+0x01, 0x6B, 0x6C, 0xEA, 0x07, 0x22, 0x01, 0xF4,
+0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D, 0x26, 0xF2,
+0x11, 0x6E, 0x06, 0x10, 0x01, 0xF4, 0x08, 0x6C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x02, 0xF1, 0x11, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x0D, 0x93, 0x0E, 0x92,
+0x6D, 0xEA, 0x02, 0x6B, 0x6C, 0xEA, 0x07, 0x22,
+0x01, 0xF6, 0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x26, 0xF2, 0x11, 0x6E, 0x06, 0x10, 0x01, 0xF6,
+0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D, 0x02, 0xF1,
+0x11, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF2, 0xA8, 0x9A, 0x21, 0xF1,
+0x1C, 0x69, 0x91, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xBC, 0x9A, 0x01, 0xF0, 0x0C, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0xA0, 0x9A, 0x01, 0xF0, 0x0C, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x0D, 0x93,
+0x01, 0x6A, 0x6C, 0xEA, 0x10, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF2, 0xB4, 0x9A, 0x91, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x04, 0x6C, 0x61, 0xF1,
+0xB8, 0x9A, 0x08, 0x6E, 0x13, 0x10, 0x0D, 0x93,
+0x02, 0x6A, 0x6C, 0xEA, 0x11, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF2, 0xB4, 0x9A, 0x91, 0x67,
+0x02, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF1, 0xB8, 0x9A, 0x01, 0xF2,
+0x04, 0x6C, 0x04, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x0D, 0x92, 0xFF, 0x4A, 0x02, 0x5A, 0x06, 0x60,
+0x41, 0xF1, 0x00, 0x6C, 0xFF, 0xF7, 0x10, 0x6D,
+0x01, 0x6E, 0x05, 0x10, 0x41, 0xF1, 0x00, 0x6C,
+0xFF, 0xF7, 0x10, 0x6D, 0x43, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x0D, 0x92, 0x01, 0xF0, 0x0C, 0x6C,
+0xFF, 0x6D, 0x50, 0x36, 0x4D, 0xEE, 0x00, 0x18,
+0x0E, 0x29, 0x0D, 0x92, 0xFF, 0x4A, 0x02, 0x5A,
+0x17, 0x61, 0x06, 0x93, 0x03, 0x2B, 0x50, 0x98,
+0x40, 0xA2, 0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF2, 0xB4, 0x9A, 0x21, 0xF1, 0x1C, 0x6C,
+0x43, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF1, 0xB8, 0x9A, 0x01, 0xF2,
+0x04, 0x6C, 0x0C, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2, 0xBC, 0x9A,
+0x21, 0xF2, 0x0C, 0x69, 0x91, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xB4, 0x9A, 0x91, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x0E, 0x93, 0x01, 0x6A,
+0x6C, 0xEA, 0x08, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x04, 0x6C, 0xE1, 0xF0, 0xB4, 0x9A,
+0x00, 0x6E, 0x0B, 0x10, 0x0E, 0x93, 0x02, 0x6A,
+0x6C, 0xEA, 0x09, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0xB4, 0x9A, 0x01, 0xF2, 0x04, 0x6C,
+0x05, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x0E, 0x92,
+0x01, 0xF0, 0x08, 0x6C, 0xFF, 0x6D, 0x50, 0x36,
+0x4D, 0xEE, 0x00, 0x18, 0x0E, 0x29, 0x0E, 0x92,
+0xFF, 0x4A, 0x02, 0x5A, 0x1A, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0xBC, 0x9A, 0x03, 0xF1,
+0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0xB4, 0x9A,
+0x01, 0xF0, 0x00, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x10, 0x6C, 0xA1, 0xF2, 0xAC, 0x9A, 0x00, 0x6E,
+0x19, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0xBC, 0x9A, 0x03, 0xF1, 0x04, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0xB4, 0x9A, 0x01, 0xF0, 0x00, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF2, 0xAC, 0x9A, 0x41, 0xF0,
+0x10, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x0D, 0x93, 0x03, 0x6A, 0x00, 0x69, 0x4C, 0xEB,
+0x20, 0xF0, 0x6B, 0xC0, 0x0E, 0x93, 0x6C, 0xEA,
+0x20, 0xF0, 0x4C, 0xC0, 0x01, 0x6A, 0x06, 0xD2,
+0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x04, 0x4A, 0xE0, 0xF6, 0x18, 0x4B,
+0x60, 0x9B, 0xE0, 0x9A, 0x90, 0x67, 0x00, 0x6D,
+0xEF, 0x6E, 0x04, 0xD3, 0x00, 0x18, 0x9A, 0x55,
+0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x04, 0x4A, 0xE0, 0x9A, 0x01, 0x6B, 0x00, 0x6D,
+0x33, 0x6E, 0x90, 0x67, 0x04, 0xD3, 0x00, 0x18,
+0x9A, 0x55, 0x07, 0x93, 0x02, 0x6C, 0x6C, 0xEA,
+0x06, 0x93, 0x4C, 0xEB, 0x06, 0xD3, 0x00, 0x18,
+0x7D, 0x1E, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x04, 0x4A, 0xE0, 0x9A, 0x90, 0x67, 0x00, 0x6D,
+0x33, 0x6E, 0x00, 0x18, 0x72, 0x55, 0x01, 0x72,
+0x15, 0x60, 0x01, 0x49, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE9, 0x64, 0x71, 0xC9, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x00, 0xF1, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xC4, 0xF0, 0x04, 0x4C, 0x00, 0x18,
+0x39, 0x3D, 0xFF, 0x10, 0x50, 0x98, 0x40, 0xA2,
+0x07, 0x2A, 0x4F, 0x98, 0x40, 0xA2, 0x04, 0x2A,
+0x20, 0xF0, 0x70, 0xA0, 0x07, 0xD3, 0x5B, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x58, 0x9A,
+0x90, 0x67, 0x00, 0x6D, 0x04, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x04, 0x4A, 0xE0, 0x9A,
+0xEF, 0x6E, 0x00, 0x18, 0x9A, 0x55, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF0, 0x04, 0x4B, 0xE0, 0x9B,
+0x22, 0x67, 0x90, 0x67, 0x01, 0x6A, 0x00, 0x6D,
+0x33, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0x9A, 0x55,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0, 0x04, 0x4B,
+0x4C, 0xE9, 0x06, 0x92, 0xE0, 0x9B, 0x90, 0x67,
+0x4C, 0xE9, 0x00, 0x6D, 0x34, 0x6A, 0x3E, 0x6E,
+0x04, 0xD2, 0x00, 0x18, 0x9A, 0x55, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x81, 0xF0,
+0x04, 0x4B, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0x9B, 0xA1, 0xF2, 0x50, 0x9A, 0x90, 0x67,
+0x00, 0x6D, 0x3F, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0x9A, 0x55, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0,
+0x04, 0x4B, 0x4C, 0xE9, 0xE0, 0x9B, 0xFF, 0x6A,
+0x4C, 0xE9, 0x00, 0x6A, 0x90, 0x67, 0xA2, 0x67,
+0xEF, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0x9A, 0x55,
+0x4C, 0xE9, 0xFF, 0x6A, 0x4C, 0xE9, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x64, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x24, 0xF1, 0x08, 0x4C, 0x5D, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x04, 0x4A, 0xE0, 0xF6, 0x18, 0x4B, 0x60, 0x9B,
+0xE0, 0x9A, 0x90, 0x67, 0x00, 0x6D, 0xEF, 0x6E,
+0x04, 0xD3, 0x00, 0x18, 0x9A, 0x55, 0x22, 0x67,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x04, 0x4A,
+0xE0, 0x9A, 0x01, 0x6B, 0x90, 0x67, 0x00, 0x6D,
+0x33, 0x6E, 0x04, 0xD3, 0x00, 0x18, 0x9A, 0x55,
+0x06, 0x93, 0x4C, 0xE9, 0xFF, 0x6A, 0x6C, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0, 0x04, 0x4B,
+0xE0, 0x9B, 0x4C, 0xE9, 0x90, 0x67, 0x34, 0x6A,
+0x00, 0x6D, 0x3E, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0x9A, 0x55, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x81, 0xF0, 0x04, 0x4B, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0x9B, 0xA1, 0xF2,
+0x54, 0x9A, 0x90, 0x67, 0x00, 0x6D, 0x3F, 0x6E,
+0x04, 0xD2, 0x00, 0x18, 0x9A, 0x55, 0x4C, 0xE9,
+0xFF, 0x6A, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x04, 0x4A, 0x07, 0x93, 0xE0, 0x9A,
+0x90, 0x67, 0x00, 0x6D, 0xEF, 0x6E, 0x04, 0xD3,
+0x00, 0x18, 0x9A, 0x55, 0x4C, 0xE9, 0xFF, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x6C, 0xE9, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x98, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x84, 0xF1, 0x00, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x00, 0x6A, 0x04, 0xD2,
+0xA2, 0x67, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xE4, 0x9A, 0x90, 0x67, 0xEF, 0x6E, 0x00, 0x18,
+0x9A, 0x55, 0x2C, 0xEA, 0x10, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x27, 0x22, 0x0D, 0x95, 0x0E, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF1, 0x10, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x1E, 0x10, 0x90, 0x67,
+0x00, 0x18, 0x7D, 0x56, 0x90, 0x67, 0x00, 0x18,
+0x91, 0x56, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6,
+0xAC, 0xA2, 0x90, 0x67, 0x00, 0x18, 0xED, 0x53,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x08, 0x22, 0x0D, 0x95,
+0x0E, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x44, 0xF2,
+0x08, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x6A, 0xAC, 0xEA, 0x07, 0xD2, 0x0E, 0xD6,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x9C, 0x24, 0x67, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0xA4, 0xF2, 0x00, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x20, 0xF0, 0x4E, 0xA1,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0xC0, 0xF1,
+0x15, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF2,
+0x1C, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0xCE, 0x11,
+0x0E, 0x93, 0x07, 0x5B, 0x0B, 0x60, 0x01, 0x73,
+0x03, 0x61, 0x07, 0x94, 0x03, 0x5C, 0x05, 0x10,
+0x0E, 0x92, 0x02, 0x72, 0x10, 0x61, 0x07, 0x93,
+0x05, 0x5B, 0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA,
+0xA0, 0xF1, 0x1A, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x24, 0xF3, 0x00, 0x4C, 0x86, 0x11, 0x0E, 0x94,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0x6D, 0x45, 0xF6,
+0x88, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xE4, 0x9A, 0x91, 0x67, 0x18, 0x6E, 0x00, 0x18,
+0x72, 0x55, 0x06, 0xD2, 0x0E, 0x92, 0x07, 0x5A,
+0x20, 0xF1, 0x11, 0x60, 0x48, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF4, 0x0C, 0x4A, 0x69, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0xA1, 0xF0, 0x0C, 0x68,
+0x90, 0x67, 0xFF, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x90, 0x67, 0x00, 0xF3, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0xBC, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF1, 0xB8, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0xB4, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0x04, 0x6C, 0xA0, 0xF6,
+0xA0, 0x9A, 0xF5, 0x10, 0x07, 0x94, 0x0F, 0x6E,
+0x01, 0x6A, 0x8C, 0xEE, 0xC8, 0x36, 0x4D, 0xEE,
+0xA1, 0xF0, 0x0C, 0x6C, 0xFF, 0x6D, 0x00, 0x18,
+0x0E, 0x29, 0x07, 0x92, 0x01, 0x72, 0x05, 0x61,
+0x01, 0xF2, 0x00, 0x6C, 0x10, 0x6D, 0x01, 0x6E,
+0x04, 0x10, 0x01, 0xF2, 0x00, 0x6C, 0x10, 0x6D,
+0x00, 0x6E, 0xA1, 0xF0, 0x0C, 0x68, 0x00, 0x18,
+0x0E, 0x29, 0x90, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0xB0, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF1, 0xBC, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0xB8, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF6, 0xA0, 0x9A, 0xC1, 0xF0,
+0x04, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x06, 0x93, 0x5D, 0xF3, 0x13, 0x48, 0x01, 0xF0,
+0x00, 0x6A, 0x6C, 0xE8, 0x3B, 0x10, 0x07, 0x94,
+0x0F, 0x6A, 0xA1, 0xF0, 0x0C, 0x68, 0x8C, 0xEA,
+0x48, 0x32, 0x02, 0x6E, 0x4D, 0xEE, 0x90, 0x67,
+0xFF, 0x6D, 0x00, 0x18, 0x0E, 0x29, 0x90, 0x67,
+0x06, 0xF0, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0xB4, 0x9A, 0x90, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0xAC, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6,
+0x00, 0x4A, 0xA0, 0x9A, 0x90, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF6, 0x00, 0x4B, 0xA0, 0x9B, 0xC1, 0xF0,
+0x04, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x06, 0x94, 0x5D, 0xF3, 0x13, 0x48, 0x00, 0xF4,
+0x00, 0x6A, 0x8C, 0xE8, 0x4D, 0xE8, 0x88, 0x10,
+0xA1, 0xF0, 0x0C, 0x68, 0x90, 0x67, 0xFF, 0x6D,
+0x40, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x90, 0x67,
+0x00, 0xF3, 0x00, 0x6D, 0x02, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0xBC, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0xB8, 0x9A, 0x90, 0x67, 0x02, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xB4, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6,
+0xA0, 0x9A, 0xC1, 0xF0, 0x04, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0xB8, 0x9A, 0xC1, 0xF0, 0x08, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x40, 0xF3,
+0x14, 0x48, 0x06, 0x92, 0xC3, 0x17, 0xA1, 0xF0,
+0x0C, 0x68, 0x90, 0x67, 0xFF, 0x6D, 0x80, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x03, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6, 0xBC, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xB8, 0x9A,
+0x90, 0x67, 0x03, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0xB4, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF6, 0xA0, 0x9A,
+0xC1, 0xF0, 0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0xB8, 0x9A, 0xC1, 0xF0, 0x08, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x06, 0x93, 0x40, 0xF3,
+0x14, 0x48, 0x6D, 0xE8, 0x11, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99,
+0x06, 0x90, 0x6C, 0xEA, 0x09, 0x22, 0x0E, 0x95,
+0x07, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x24, 0xF3,
+0x00, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0x06, 0x90,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xE4, 0x9A,
+0x91, 0x67, 0x00, 0x6D, 0x18, 0x6E, 0x04, 0xD0,
+0x00, 0x18, 0x9A, 0x55, 0x06, 0x94, 0x00, 0x6B,
+0x01, 0x4C, 0x01, 0x24, 0x01, 0x6B, 0xFF, 0x6C,
+0x4C, 0xEC, 0x6C, 0xEC, 0x06, 0xD4, 0x5A, 0xA1,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xE4, 0x9A, 0x91, 0x67, 0x01, 0x6D, 0x18, 0x6E,
+0x04, 0xD0, 0x00, 0x18, 0x9A, 0x55, 0x06, 0x93,
+0xFF, 0x6C, 0x4C, 0xEB, 0x8C, 0xEB, 0x06, 0xD3,
+0x06, 0x92, 0x10, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA,
+0x33, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0x64, 0xF3,
+0x1C, 0x4C, 0x0E, 0x95, 0x07, 0x96, 0x00, 0x18,
+0x39, 0x3D, 0x2A, 0x10, 0x0E, 0x95, 0x91, 0x67,
+0x01, 0xF0, 0x08, 0x68, 0x00, 0x18, 0x66, 0x53,
+0x91, 0x67, 0x00, 0x18, 0x7D, 0x56, 0x91, 0x67,
+0x00, 0x18, 0x91, 0x56, 0x90, 0x67, 0xFF, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x20, 0xF0,
+0x4C, 0xA1, 0x90, 0x67, 0xFF, 0x6D, 0x50, 0x36,
+0x4D, 0xEE, 0x00, 0x18, 0x0E, 0x29, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x08, 0x22, 0x0E, 0x95, 0x07, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0xE4, 0xF3, 0x1C, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x01, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xF3, 0x63, 0x19, 0x62,
+0x18, 0xD1, 0x17, 0xD0, 0xFF, 0x68, 0xAC, 0xE8,
+0x30, 0xF0, 0x20, 0x6D, 0x24, 0x67, 0x20, 0xF5,
+0x14, 0x4D, 0x06, 0x04, 0x0F, 0x6E, 0x00, 0x18,
+0x21, 0x1E, 0x30, 0xF0, 0x20, 0x6D, 0x0E, 0x04,
+0x00, 0xF5, 0x1C, 0x4D, 0x17, 0x6E, 0x00, 0x18,
+0x21, 0x1E, 0x30, 0xF0, 0x20, 0x6D, 0x0A, 0x04,
+0x00, 0xF5, 0x0C, 0x4D, 0x0F, 0x6E, 0x00, 0x18,
+0x21, 0x1E, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x44, 0xF4, 0x1C, 0x4C,
+0x00, 0x18, 0x39, 0x3D, 0x20, 0xF0, 0x4E, 0xA1,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0xC0, 0xF1,
+0x1E, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0x84, 0xF4,
+0x18, 0x4C, 0x00, 0x18, 0x39, 0x3D, 0xD7, 0x11,
+0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF6, 0x0C, 0xC2,
+0x45, 0xF6, 0xAC, 0xA2, 0x02, 0x6B, 0x0F, 0x5D,
+0x58, 0x67, 0x4B, 0xE3, 0x20, 0xF0, 0x72, 0xA1,
+0x4A, 0xEB, 0x03, 0x60, 0x91, 0x67, 0x00, 0x18,
+0xED, 0x53, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0xE4, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0x18, 0x6E,
+0x00, 0x18, 0x72, 0x55, 0x14, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF2, 0x58, 0x9A, 0x14, 0x93,
+0x0F, 0x58, 0x6C, 0xEA, 0x36, 0x60, 0x0D, 0xEA,
+0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D, 0x00, 0x6E,
+0x15, 0xD2, 0x00, 0x18, 0x0E, 0x29, 0x00, 0x6A,
+0x40, 0xF0, 0x48, 0xC1, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF2, 0xBC, 0x9A, 0x61, 0xF0, 0x00, 0x6C,
+0x61, 0xF1, 0x0A, 0x6E, 0x00, 0x18, 0x0E, 0x29,
+0x0E, 0x70, 0x0E, 0x61, 0x01, 0x6D, 0x21, 0xF2,
+0x04, 0x6C, 0xAB, 0xED, 0x6C, 0xF5, 0x17, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x21, 0xF2, 0x08, 0x6C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x00, 0x6E, 0x58, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0xC0, 0x9A,
+0x01, 0x6D, 0x21, 0xF2, 0x04, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x0E, 0x29, 0x21, 0xF2, 0x08, 0x6C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x22, 0xF5, 0x05, 0x6E,
+0x47, 0x10, 0x24, 0x58, 0x80, 0xF0, 0x02, 0x61,
+0x0D, 0xEA, 0x68, 0x40, 0x15, 0xD2, 0xE4, 0x4B,
+0xFF, 0x6A, 0x4C, 0xEB, 0x1D, 0x5B, 0x08, 0x60,
+0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x01, 0x6A, 0x16, 0x10,
+0x68, 0x40, 0xA4, 0x4B, 0x4C, 0xEB, 0x2D, 0x5B,
+0x08, 0x60, 0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D,
+0x02, 0x6E, 0x00, 0x18, 0x0E, 0x29, 0x02, 0x6A,
+0x09, 0x10, 0x95, 0x58, 0x10, 0x61, 0x41, 0xF1,
+0x18, 0x6C, 0x1F, 0x6D, 0x03, 0x6E, 0x00, 0x18,
+0x0E, 0x29, 0x03, 0x6A, 0x68, 0x40, 0x40, 0xF0,
+0x48, 0xC1, 0xE4, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB,
+0x0D, 0x5B, 0x1D, 0x60, 0x0D, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x40, 0xF1, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xC4, 0xF4, 0x1C, 0x4C, 0x13, 0x11,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2, 0xBC, 0x9A,
+0x61, 0xF0, 0x00, 0x6C, 0x80, 0xF4, 0x14, 0x6E,
+0x00, 0x18, 0x0E, 0x29, 0x50, 0x99, 0x40, 0xA2,
+0x01, 0x72, 0x56, 0x61, 0x44, 0x10, 0x68, 0x40,
+0xD4, 0x4B, 0x4C, 0xEB, 0x0D, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0xA1, 0xF2, 0xBC, 0x9A, 0x40, 0xF4, 0x13, 0x6E,
+0xEB, 0x17, 0x68, 0x40, 0xA4, 0x4B, 0x4C, 0xEB,
+0x11, 0x5B, 0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x00, 0x6C, 0xA1, 0xF2, 0xBC, 0x9A,
+0x40, 0xF4, 0x12, 0x6E, 0xDD, 0x17, 0x68, 0x40,
+0x92, 0x4B, 0x4C, 0xEB, 0x3C, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0xA1, 0xF2, 0xBC, 0x9A, 0x00, 0xF4, 0x12, 0x6E,
+0xCF, 0x17, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0x00, 0xF1,
+0x00, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0x24, 0xF5,
+0x08, 0x4C, 0xCD, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA,
+0xE0, 0xF0, 0x13, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x64, 0xF5, 0x18, 0x4C, 0xC0, 0x10, 0x20, 0xF0,
+0x45, 0xA1, 0x03, 0x72, 0x02, 0x60, 0x05, 0x72,
+0x0B, 0x61, 0x0E, 0x70, 0x05, 0x61, 0x91, 0x67,
+0x26, 0x6D, 0x00, 0x18, 0x6A, 0x33, 0xE7, 0x10,
+0x91, 0x67, 0x20, 0x6D, 0x00, 0x18, 0x6A, 0x33,
+0x0F, 0x58, 0xE0, 0xF0, 0x00, 0x61, 0x68, 0x40,
+0xE4, 0x4B, 0xFF, 0x6A, 0x83, 0x67, 0x4C, 0xEC,
+0x1D, 0x5C, 0x05, 0x60, 0x67, 0x33, 0x9D, 0x67,
+0x6D, 0xE4, 0x58, 0xA3, 0x18, 0x10, 0x68, 0x40,
+0xA4, 0x4B, 0x83, 0x67, 0x4C, 0xEC, 0x2D, 0x5C,
+0x06, 0x60, 0x5D, 0x67, 0x67, 0x33, 0x6D, 0xE2,
+0x20, 0xF0, 0x58, 0xA3, 0x0C, 0x10, 0x67, 0x40,
+0x64, 0x4B, 0x4C, 0xEB, 0x1D, 0x5B, 0x1F, 0x60,
+0x6F, 0xF7, 0x4B, 0x40, 0x47, 0x32, 0x7D, 0x67,
+0x49, 0xE3, 0x20, 0xF0, 0x48, 0xA2, 0xFF, 0x72,
+0x16, 0x60, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF2, 0xE4, 0x9A, 0x91, 0x67, 0x00, 0x6D,
+0xBE, 0x6E, 0x00, 0x18, 0x9A, 0x55, 0x14, 0x94,
+0x00, 0x6B, 0x01, 0x4C, 0x01, 0x24, 0x01, 0x6B,
+0xFF, 0x6C, 0x4C, 0xEC, 0x6C, 0xEC, 0x90, 0x70,
+0x14, 0xD4, 0x1F, 0x61, 0x0D, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x80, 0xF0, 0x16, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xC4, 0xF5, 0x00, 0x4C, 0x63, 0x10,
+0x01, 0x6A, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xF4, 0x9A, 0x91, 0x67, 0x00, 0x6D,
+0xDF, 0x6E, 0x00, 0x18, 0x9A, 0x55, 0x14, 0x93,
+0xFF, 0x6C, 0x4C, 0xEB, 0x8C, 0xEB, 0x14, 0xD3,
+0x1C, 0x10, 0x00, 0x6A, 0x04, 0xD2, 0xA2, 0x67,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x14, 0x4A,
+0xE0, 0x9A, 0x91, 0x67, 0xDF, 0x6E, 0x00, 0x18,
+0x9A, 0x55, 0x14, 0x93, 0xFF, 0x6C, 0x91, 0x58,
+0x4C, 0xEB, 0x8C, 0xEB, 0x14, 0xD3, 0x07, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x14, 0x4A,
+0x15, 0x93, 0x40, 0x9A, 0x07, 0x10, 0x50, 0x58,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x50, 0x9A, 0x15, 0x93, 0x4D, 0xEB, 0x15, 0xD3,
+0x30, 0xF0, 0x20, 0x6A, 0x15, 0x94, 0x81, 0xF0,
+0x04, 0x4A, 0xE0, 0x9A, 0x04, 0xD4, 0x00, 0x6D,
+0x91, 0x67, 0x18, 0x6E, 0x00, 0x18, 0x9A, 0x55,
+0x14, 0x93, 0x4C, 0xEB, 0x14, 0xD3, 0x5A, 0xA1,
+0x11, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x15, 0x94,
+0x81, 0xF0, 0x04, 0x4A, 0xE0, 0x9A, 0x04, 0xD4,
+0x01, 0x6D, 0x91, 0x67, 0x18, 0x6E, 0x00, 0x18,
+0x9A, 0x55, 0x14, 0x93, 0x4C, 0xEB, 0xFF, 0x6A,
+0x4C, 0xEB, 0x14, 0xD3, 0x14, 0x94, 0x0F, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x64, 0x99, 0x6C, 0xEA, 0x32, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x04, 0xF6, 0x14, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x3D, 0x2A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x18, 0x4A, 0xC0, 0x9A,
+0x00, 0x6C, 0xE4, 0x67, 0xB8, 0x6D, 0x00, 0x18,
+0x34, 0x29, 0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6,
+0x18, 0x4B, 0xC0, 0x9B, 0xB8, 0x6D, 0x01, 0x6F,
+0x00, 0x6C, 0x00, 0x18, 0x34, 0x29, 0x91, 0x67,
+0x00, 0x18, 0x7D, 0x56, 0x91, 0x67, 0x00, 0x18,
+0x91, 0x56, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x54, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0x07, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x84, 0xF6, 0x00, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x3D, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x19, 0x97, 0x18, 0x91,
+0x17, 0x90, 0x0D, 0x63, 0x00, 0xEF, 0x00, 0x6A,
+0x44, 0x17, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x68, 0x0C, 0xED,
+0x24, 0x67, 0x0D, 0xD7, 0x04, 0xD5, 0xCC, 0xE8,
+0x00, 0x18, 0xD7, 0x55, 0x0F, 0x22, 0x04, 0x95,
+0x91, 0x67, 0x00, 0x18, 0x6F, 0x59, 0x0A, 0x22,
+0x0D, 0x96, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0x70, 0x58, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x32, 0x01, 0x10, 0x00, 0x6A, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0x60, 0x68, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+};
+
+u32 array_length_mp_8822b_fw_ap = 104632;
+
+#endif /*defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP))*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN)) || (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+
+u8 array_mp_8822b_fw_nic[] = {
+0x22, 0x88, 0x00, 0x00, 0x16, 0x00, 0x06, 0x00,
+0x42, 0x65, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x04, 0x19, 0x0E, 0x26, 0xE2, 0x07, 0x00, 0x00,
+0x08, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x20, 0x80, 0x50, 0x32, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x30, 0x04, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x10, 0x12, 0x80, 0x00, 0x00, 0x00, 0x80,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x01, 0x38, 0x00, 0x80, 0xE9, 0x06, 0x00, 0x80,
+0x03, 0x02, 0x01, 0xFE, 0x03, 0x03, 0x01, 0xFE,
+0x03, 0x04, 0x01, 0xFE, 0x03, 0x05, 0x01, 0xFE,
+0x03, 0x06, 0x01, 0xFE, 0x03, 0x07, 0x01, 0xFE,
+0x19, 0x7C, 0x00, 0x80, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x79, 0x7E, 0x00, 0x80, 0x01, 0x00, 0x00, 0x00,
+0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x50, 0x32, 0x20, 0x80, 0x81, 0x00, 0x88, 0x00,
+0x90, 0x00, 0x99, 0x00, 0xA2, 0x00, 0xAC, 0x00,
+0xB6, 0x00, 0xC0, 0x00, 0xCC, 0x00, 0xD8, 0x00,
+0xE5, 0x00, 0xF2, 0x00, 0x01, 0x01, 0x10, 0x01,
+0x20, 0x01, 0x31, 0x01, 0x43, 0x01, 0x56, 0x01,
+0x6A, 0x01, 0x80, 0x01, 0x97, 0x01, 0xAF, 0x01,
+0xC8, 0x01, 0xE3, 0x01, 0x00, 0x02, 0x1E, 0x02,
+0x3E, 0x02, 0x61, 0x02, 0x85, 0x02, 0xAB, 0x02,
+0xD3, 0x02, 0xFE, 0x02, 0x2B, 0x03, 0x5C, 0x03,
+0x8E, 0x03, 0xC4, 0x03, 0xFE, 0x03, 0x00, 0x00,
+0x22, 0x05, 0x50, 0x05, 0x51, 0x05, 0x00, 0x00,
+0x08, 0x08, 0x0C, 0x09, 0x00, 0x0C, 0xB0, 0x0C,
+0xB4, 0x0C, 0xBC, 0x0C, 0x00, 0x0E, 0xB0, 0x0E,
+0xB4, 0x0E, 0xBC, 0x0E, 0x90, 0x19, 0xA4, 0x09,
+0x04, 0x0A, 0x00, 0x0B, 0x38, 0x08, 0x00, 0x00,
+0xDF, 0x8F, 0x65, 0x00, 0x01, 0x00, 0x00, 0x00,
+0x2C, 0x00, 0x04, 0x00, 0x2D, 0x00, 0x2C, 0x01,
+0x2D, 0x01, 0x2C, 0x02, 0x2E, 0x01, 0xFF, 0x00,
+0x2D, 0x02, 0xFF, 0x00, 0x03, 0x02, 0x00, 0x00,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x2A, 0xEA, 0xA0, 0x79, 0x2C, 0xEA, 0xA0, 0x79,
+0x2A, 0xEA, 0xA0, 0x79, 0x2A, 0xEA, 0xA0, 0x79,
+0x41, 0x55, 0x76, 0x87, 0x41, 0x63, 0x74, 0x87,
+0x41, 0x55, 0x76, 0x87, 0x41, 0x63, 0x74, 0x87,
+0x10, 0x60, 0xB8, 0x75, 0x10, 0x60, 0xB7, 0x75,
+0x10, 0x60, 0xB8, 0x75, 0x10, 0x60, 0xB7, 0x75,
+0x28, 0xEA, 0xA0, 0x79, 0x2C, 0xEA, 0xA0, 0x79,
+0x28, 0xEA, 0xA0, 0x79, 0x2A, 0xEA, 0xA0, 0x79,
+0x51, 0x64, 0x76, 0x87, 0x31, 0x64, 0x76, 0x87,
+0x51, 0x64, 0x76, 0x87, 0x31, 0x64, 0x76, 0x87,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x2A, 0xEA, 0xA0, 0x79, 0x2C, 0xEA, 0xA0, 0x97,
+0x2A, 0xEA, 0xA0, 0x79, 0x2A, 0xEA, 0xA0, 0x79,
+0x41, 0x55, 0x76, 0x87, 0x41, 0x63, 0x66, 0x86,
+0x61, 0x55, 0x76, 0x87, 0x61, 0x63, 0x66, 0x86,
+0x06, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00,
+0x01, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00,
+0x40, 0x00, 0x40, 0x00, 0xA7, 0x4F, 0x00, 0x80,
+0xBD, 0x4F, 0x00, 0x80, 0xDB, 0x4F, 0x00, 0x80,
+0x0D, 0x50, 0x00, 0x80, 0x37, 0x50, 0x00, 0x80,
+0x9F, 0x50, 0x00, 0x80, 0xB5, 0x50, 0x00, 0x80,
+0xCB, 0x50, 0x00, 0x80, 0xE1, 0x50, 0x00, 0x80,
+0xFB, 0x50, 0x00, 0x80, 0x13, 0x5D, 0x00, 0x80,
+0x19, 0x5D, 0x00, 0x80, 0x25, 0x5D, 0x00, 0x80,
+0x31, 0x5D, 0x00, 0x80, 0x3D, 0x5D, 0x00, 0x80,
+0x6D, 0x60, 0x00, 0x80, 0x55, 0x61, 0x00, 0x80,
+0xCF, 0x60, 0x00, 0x80, 0x55, 0x61, 0x00, 0x80,
+0x15, 0x60, 0x00, 0x80, 0x55, 0x61, 0x00, 0x80,
+0x55, 0x61, 0x00, 0x80, 0x55, 0x61, 0x00, 0x80,
+0x37, 0x61, 0x00, 0x80, 0x55, 0x61, 0x00, 0x80,
+0x55, 0x61, 0x00, 0x80, 0x55, 0x61, 0x00, 0x80,
+0xAF, 0x5F, 0x00, 0x80, 0x09, 0x66, 0x00, 0x80,
+0x25, 0x66, 0x00, 0x80, 0x47, 0x66, 0x00, 0x80,
+0x69, 0x66, 0x00, 0x80, 0x8D, 0x66, 0x00, 0x80,
+0x75, 0x6F, 0x00, 0x80, 0x89, 0x6F, 0x00, 0x80,
+0x9D, 0x6F, 0x00, 0x80, 0xB1, 0x6F, 0x00, 0x80,
+0xC7, 0x6F, 0x00, 0x80, 0x07, 0x70, 0x00, 0x80,
+0x1B, 0x70, 0x00, 0x80, 0x2F, 0x70, 0x00, 0x80,
+0x43, 0x70, 0x00, 0x80, 0x59, 0x70, 0x00, 0x80,
+0x97, 0x71, 0x00, 0x80, 0x9D, 0x71, 0x00, 0x80,
+0xA9, 0x71, 0x00, 0x80, 0xB5, 0x71, 0x00, 0x80,
+0xC1, 0x71, 0x00, 0x80, 0xA8, 0x06, 0x10, 0x07,
+0x00, 0x16, 0x04, 0x16, 0x08, 0x16, 0x00, 0x00,
+0xA8, 0x06, 0x10, 0x07, 0x00, 0x16, 0x04, 0x16,
+0x08, 0x16, 0x00, 0x00, 0xA8, 0x06, 0x10, 0x07,
+0x00, 0x16, 0x04, 0x16, 0x08, 0x16, 0x00, 0x00,
+0xA8, 0x06, 0x10, 0x07, 0x00, 0x16, 0x04, 0x16,
+0x08, 0x16, 0x00, 0x00, 0x19, 0x7B, 0x00, 0x80,
+0x13, 0x7B, 0x00, 0x80, 0x1F, 0x7B, 0x00, 0x80,
+0x25, 0x7B, 0x00, 0x80, 0x2B, 0x7B, 0x00, 0x80,
+0x31, 0x7B, 0x00, 0x80, 0x37, 0x78, 0x01, 0x80,
+0x41, 0x78, 0x01, 0x80, 0x4F, 0x78, 0x01, 0x80,
+0x81, 0x78, 0x01, 0x80, 0xC7, 0x78, 0x01, 0x80,
+0xDF, 0x78, 0x01, 0x80, 0x94, 0x0C, 0x94, 0x0E,
+0x94, 0x18, 0x94, 0x1A, 0x09, 0x12, 0x1B, 0x24,
+0xC5, 0x99, 0x01, 0x80, 0x13, 0x9A, 0x01, 0x80,
+0xCD, 0x99, 0x01, 0x80, 0x0B, 0x9A, 0x01, 0x80,
+0x29, 0x9A, 0x01, 0x80, 0x29, 0x9A, 0x01, 0x80,
+0xD5, 0x99, 0x01, 0x80, 0xDD, 0x99, 0x01, 0x80,
+0xE5, 0x99, 0x01, 0x80, 0xED, 0x99, 0x01, 0x80,
+0xFD, 0x99, 0x01, 0x80, 0x05, 0x9A, 0x01, 0x80,
+0x1B, 0x9A, 0x01, 0x80, 0x23, 0x9A, 0x01, 0x80,
+0xF5, 0x99, 0x01, 0x80, 0x02, 0x04, 0x06, 0x08,
+0x0A, 0x01, 0x0C, 0x0E, 0x10, 0x12, 0x03, 0x0B,
+0x14, 0x16, 0x18, 0x05, 0x0D, 0x13, 0x1A, 0x1C,
+0x07, 0x0F, 0x15, 0x19, 0x1E, 0x09, 0x11, 0x17,
+0x1B, 0x1D, 0x00, 0x00, 0x01, 0x03, 0x05, 0x07,
+0x09, 0x02, 0x0B, 0x0D, 0x0F, 0x11, 0x04, 0x0C,
+0x13, 0x15, 0x17, 0x06, 0x0E, 0x14, 0x19, 0x1B,
+0x08, 0x10, 0x16, 0x1A, 0x1D, 0x0A, 0x12, 0x18,
+0x1C, 0x1E, 0x00, 0x00, 0x04, 0x08, 0x08, 0x08,
+0x08, 0x08, 0x0A, 0x0A, 0x0A, 0x00, 0x00, 0x00,
+0x00, 0x04, 0x0C, 0x14, 0x1C, 0x24, 0x2C, 0x36,
+0x40, 0x00, 0x00, 0x00, 0x49, 0xD7, 0x01, 0x80,
+0x5F, 0xD7, 0x01, 0x80, 0x49, 0xD7, 0x01, 0x80,
+0x5F, 0xD7, 0x01, 0x80, 0x49, 0xD7, 0x01, 0x80,
+0x5F, 0xD7, 0x01, 0x80, 0x89, 0xD7, 0x01, 0x80,
+0x89, 0xD7, 0x01, 0x80, 0x89, 0xD7, 0x01, 0x80,
+0x4D, 0xD7, 0x01, 0x80, 0x71, 0xD7, 0x01, 0x80,
+0x71, 0xD7, 0x01, 0x80, 0x4D, 0xD7, 0x01, 0x80,
+0x9D, 0xD7, 0x01, 0x80, 0xB3, 0xD7, 0x01, 0x80,
+0x02, 0x04, 0x06, 0x08, 0x0A, 0x01, 0x0C, 0x0E,
+0x10, 0x12, 0x03, 0x0B, 0x14, 0x16, 0x18, 0x05,
+0x0D, 0x13, 0x1A, 0x1C, 0x07, 0x0F, 0x15, 0x19,
+0x1E, 0x09, 0x11, 0x17, 0x1B, 0x1D, 0x00, 0x00,
+0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D,
+0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x00,
+0x24, 0x24, 0x28, 0x24, 0x14, 0x12, 0x0F, 0x0F,
+0x10, 0x0E, 0x09, 0x08, 0x18, 0x18, 0x11, 0x0F,
+0x10, 0x0C, 0x09, 0x08, 0x18, 0x18, 0x11, 0x0F,
+0x10, 0x0C, 0x09, 0x08, 0x18, 0x18, 0x11, 0x0F,
+0x10, 0x0C, 0x09, 0x08, 0x18, 0x18, 0x11, 0x0F,
+0x10, 0x0C, 0x09, 0x08, 0x18, 0x18, 0x11, 0x0F,
+0x10, 0x0C, 0x09, 0x08, 0x0A, 0x07, 0x18, 0x18,
+0x11, 0x0F, 0x10, 0x0C, 0x09, 0x08, 0x0A, 0x07,
+0x18, 0x18, 0x11, 0x0F, 0x10, 0x0C, 0x09, 0x08,
+0x0A, 0x07, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A,
+0x0A, 0x0A, 0x0A, 0x0A, 0x30, 0x30, 0x3C, 0x30,
+0x2D, 0x23, 0x19, 0x1E, 0x19, 0x1E, 0x19, 0x0F,
+0x30, 0x30, 0x23, 0x1C, 0x20, 0x1A, 0x0F, 0x0E,
+0x30, 0x30, 0x23, 0x1C, 0x20, 0x1A, 0x0F, 0x0E,
+0x30, 0x30, 0x23, 0x1C, 0x20, 0x1A, 0x0F, 0x0D,
+0x30, 0x30, 0x23, 0x1C, 0x20, 0x1A, 0x0F, 0x0D,
+0x30, 0x30, 0x23, 0x1C, 0x23, 0x1B, 0x0F, 0x0F,
+0x14, 0x0F, 0x30, 0x30, 0x23, 0x1C, 0x23, 0x1B,
+0x0F, 0x0F, 0x14, 0x0F, 0x30, 0x2A, 0x23, 0x1C,
+0x23, 0x1B, 0x0F, 0x0F, 0x14, 0x0F, 0x0A, 0x0A,
+0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A, 0x0A,
+0x6D, 0xFC, 0x01, 0x80, 0xC5, 0xFC, 0x01, 0x80,
+0x57, 0xFD, 0x01, 0x80, 0xBF, 0xFE, 0x01, 0x80,
+0xBF, 0xFE, 0x01, 0x80, 0xD1, 0xFD, 0x01, 0x80,
+0x47, 0xFE, 0x01, 0x80, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x70, 0x61, 0x72, 0x61, 0x6D, 0x65, 0x74,
+0x65, 0x72, 0x5F, 0x69, 0x6E, 0x69, 0x74, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x00, 0x00, 0x00,
+0x05, 0x05, 0x00, 0x07, 0x07, 0x06, 0x05, 0xFF,
+0x00, 0x07, 0x07, 0x06, 0x05, 0x05, 0x00, 0x00,
+0x06, 0x05, 0x00, 0x00, 0x07, 0x06, 0x06, 0xFF,
+0x00, 0x00, 0x07, 0x06, 0x06, 0x05, 0x00, 0xFF,
+0x07, 0x06, 0x06, 0x05, 0x00, 0x00, 0x07, 0x00,
+0x07, 0x06, 0x06, 0x05, 0x00, 0x00, 0x07, 0xFF,
+0x06, 0x05, 0x00, 0x00, 0x07, 0x06, 0x06, 0x00,
+0x70, 0x68, 0x79, 0x64, 0x6D, 0x5F, 0x63, 0x63,
+0x61, 0x70, 0x61, 0x72, 0x5F, 0x62, 0x79, 0x5F,
+0x72, 0x66, 0x65, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x00, 0x00, 0x00, 0x0B, 0x8E, 0x00, 0x80,
+0x15, 0x8E, 0x00, 0x80, 0x1F, 0x8E, 0x00, 0x80,
+0x29, 0x8E, 0x00, 0x80, 0x33, 0x8E, 0x00, 0x80,
+0x95, 0x98, 0x00, 0x80, 0x91, 0x98, 0x00, 0x80,
+0x9B, 0x98, 0x00, 0x80, 0x9F, 0x98, 0x00, 0x80,
+0xA3, 0x98, 0x00, 0x80, 0xA9, 0x98, 0x00, 0x80,
+0xB1, 0x98, 0x00, 0x80, 0xDB, 0x98, 0x00, 0x80,
+0x09, 0x99, 0x00, 0x80, 0x0F, 0x99, 0x00, 0x80,
+0x5B, 0x99, 0x00, 0x80, 0x69, 0x99, 0x00, 0x80,
+0x02, 0x02, 0x03, 0x02, 0x02, 0x02, 0x02, 0x02,
+0x0B, 0x02, 0x02, 0x02, 0x0E, 0x00, 0x00, 0x00,
+0x23, 0x18, 0x00, 0x80, 0x1F, 0x18, 0x00, 0x80,
+0x23, 0x18, 0x00, 0x80, 0x1F, 0x18, 0x00, 0x80,
+0x43, 0x18, 0x00, 0x80, 0x1F, 0x18, 0x00, 0x80,
+0x43, 0x18, 0x00, 0x80, 0x1F, 0x18, 0x00, 0x80,
+0x63, 0x18, 0x00, 0x80, 0x1F, 0x18, 0x00, 0x80,
+0x63, 0x18, 0x00, 0x80, 0x1F, 0x18, 0x00, 0x80,
+0x83, 0x18, 0x00, 0x80, 0x1F, 0x18, 0x00, 0x80,
+0x83, 0x18, 0x00, 0x80, 0x9D, 0x24, 0x00, 0x80,
+0xBF, 0x24, 0x00, 0x80, 0xE1, 0x24, 0x00, 0x80,
+0x03, 0x25, 0x00, 0x80, 0x27, 0x25, 0x00, 0x80,
+0x61, 0x25, 0x00, 0x80, 0x85, 0x25, 0x00, 0x80,
+0xA9, 0x25, 0x00, 0x80, 0xCD, 0x25, 0x00, 0x80,
+0xF3, 0x25, 0x00, 0x80, 0xFD, 0xC4, 0x00, 0x80,
+0x0B, 0xC5, 0x00, 0x80, 0x0F, 0xC5, 0x00, 0x80,
+0x13, 0xC5, 0x00, 0x80, 0x17, 0xC5, 0x00, 0x80,
+0x81, 0xC8, 0x00, 0x80, 0x81, 0xC8, 0x00, 0x80,
+0x81, 0xC8, 0x00, 0x80, 0x9B, 0xC8, 0x00, 0x80,
+0x81, 0xC8, 0x00, 0x80, 0x81, 0xC8, 0x00, 0x80,
+0x81, 0xC8, 0x00, 0x80, 0x7D, 0xC8, 0x00, 0x80,
+0x7D, 0xC8, 0x00, 0x80, 0x7D, 0xC8, 0x00, 0x80,
+0x7D, 0xC8, 0x00, 0x80, 0x7D, 0xC8, 0x00, 0x80,
+0xF9, 0xC8, 0x00, 0x80, 0x01, 0xC9, 0x00, 0x80,
+0x9B, 0xDA, 0x00, 0x80, 0x9B, 0xDA, 0x00, 0x80,
+0x9B, 0xDA, 0x00, 0x80, 0xA9, 0xDA, 0x00, 0x80,
+0xB7, 0xDA, 0x00, 0x80, 0xED, 0xDA, 0x00, 0x80,
+0x43, 0xDB, 0x00, 0x80, 0x51, 0xDB, 0x00, 0x80,
+0x93, 0xDB, 0x00, 0x80, 0xDD, 0xDB, 0x00, 0x80,
+0x93, 0xDB, 0x00, 0x80, 0x35, 0xDC, 0x00, 0x80,
+0x0D, 0x1E, 0x00, 0x80, 0x0D, 0x1E, 0x00, 0x80,
+0x0D, 0x1E, 0x00, 0x80, 0x0D, 0x1E, 0x00, 0x80,
+0x2D, 0x1E, 0x00, 0x80, 0x2D, 0x1E, 0x00, 0x80,
+0x2D, 0x1E, 0x00, 0x80, 0x2D, 0x1E, 0x00, 0x80,
+0x4D, 0x1E, 0x00, 0x80, 0x4D, 0x1E, 0x00, 0x80,
+0x4D, 0x1E, 0x00, 0x80, 0x4D, 0x1E, 0x00, 0x80,
+0x6D, 0x1E, 0x00, 0x80, 0x6D, 0x1E, 0x00, 0x80,
+0x6D, 0x1E, 0x00, 0x80, 0x6D, 0x1E, 0x00, 0x80,
+0x53, 0xEC, 0x00, 0x80, 0x63, 0xEC, 0x00, 0x80,
+0x6D, 0xEC, 0x00, 0x80, 0x77, 0xEC, 0x00, 0x80,
+0x89, 0xEC, 0x00, 0x80, 0xF9, 0x01, 0x01, 0x80,
+0x19, 0x02, 0x01, 0x80, 0x01, 0x02, 0x01, 0x80,
+0x21, 0x02, 0x01, 0x80, 0x09, 0x02, 0x01, 0x80,
+0x27, 0x02, 0x01, 0x80, 0x11, 0x02, 0x01, 0x80,
+0x5F, 0x42, 0x01, 0x80, 0xAF, 0x42, 0x01, 0x80,
+0x07, 0x43, 0x01, 0x80, 0x5F, 0x43, 0x01, 0x80,
+0xC5, 0x43, 0x01, 0x80, 0xB1, 0x4E, 0x01, 0x80,
+0xD9, 0x4E, 0x01, 0x80, 0xFF, 0x4E, 0x01, 0x80,
+0x25, 0x4F, 0x01, 0x80, 0x4B, 0x4F, 0x01, 0x80,
+0x8F, 0x56, 0x01, 0x80, 0xEB, 0x56, 0x01, 0x80,
+0x7F, 0x57, 0x01, 0x80, 0x13, 0x58, 0x01, 0x80,
+0xAB, 0x58, 0x01, 0x80, 0xFC, 0x10, 0x60, 0xB8,
+0xFA, 0xFA, 0xFA, 0xFA, 0x8C, 0x04, 0x64, 0xB8,
+0x90, 0x04, 0x64, 0xB8, 0x94, 0x04, 0x64, 0xB8,
+0x98, 0x04, 0x64, 0xB8, 0x9C, 0x04, 0x64, 0xB8,
+0xA0, 0x04, 0x64, 0xB8, 0x64, 0x01, 0x64, 0xB8,
+0xBC, 0x01, 0x64, 0xB8, 0x00, 0x09, 0x3D, 0x00,
+0x77, 0x05, 0x64, 0xB8, 0x6C, 0x05, 0x64, 0xB8,
+0x68, 0x05, 0x64, 0xB8, 0x00, 0x00, 0x00, 0x80,
+0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0xFF, 0xFF,
+0x54, 0x05, 0x64, 0xB8, 0xFF, 0xFF, 0xFF, 0x8F,
+0x60, 0x05, 0x60, 0xB8, 0x60, 0x05, 0x64, 0xB8,
+0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x20,
+0x00, 0x00, 0x00, 0x30, 0x00, 0x00, 0x00, 0x40,
+0x50, 0x05, 0x64, 0xB8, 0x51, 0x05, 0x64, 0xB8,
+0x78, 0x05, 0x64, 0xB8, 0x79, 0x05, 0x64, 0xB8,
+0x7A, 0x05, 0x64, 0xB8, 0xBF, 0x01, 0x64, 0xB8,
+0x89, 0x00, 0x60, 0xB8, 0x8A, 0x00, 0x60, 0xB8,
+0x1A, 0x04, 0x64, 0xB8, 0x1B, 0x04, 0x64, 0xB8,
+0x8C, 0x00, 0x60, 0xB8, 0x8D, 0x00, 0x60, 0xB8,
+0x8E, 0x00, 0x60, 0xB8, 0x58, 0x05, 0x64, 0xB8,
+0x96, 0x02, 0x64, 0xB8, 0x86, 0x02, 0x64, 0xB8,
+0x8F, 0x00, 0x60, 0xB8, 0x84, 0x00, 0x60, 0xB8,
+0x01, 0x00, 0x60, 0xB8, 0x01, 0x00, 0x64, 0xB8,
+0x22, 0x05, 0x64, 0xB8, 0x00, 0x00, 0x02, 0x00,
+0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x08, 0x00,
+0x5B, 0x01, 0x64, 0xB8, 0x3C, 0x01, 0x64, 0xB8,
+0x00, 0x00, 0x06, 0x00, 0x00, 0x00, 0x03, 0x00,
+0x00, 0x00, 0x30, 0x00, 0x00, 0x00, 0x00, 0x03,
+0x0A, 0x06, 0x64, 0xB8, 0xB1, 0x05, 0x64, 0xB8,
+0xFE, 0x11, 0x64, 0xB8, 0xE2, 0x10, 0x60, 0xB8,
+0x00, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x64, 0xB8,
+0xFC, 0x11, 0x64, 0xB8, 0xE0, 0x10, 0x60, 0xB8,
+0x57, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x1E, 0x00,
+0x09, 0x00, 0x78, 0xB8, 0x31, 0x00, 0x78, 0xB8,
+0x14, 0x00, 0x78, 0xB8, 0x32, 0x00, 0x78, 0xB8,
+0x33, 0x00, 0x78, 0xB8, 0x1D, 0x04, 0x64, 0xB8,
+0x7A, 0x04, 0x64, 0xB8, 0xD4, 0x04, 0x64, 0xB8,
+0x88, 0x04, 0x64, 0xB8, 0xD0, 0x04, 0x64, 0xB8,
+0x84, 0x04, 0x64, 0xB8, 0x86, 0x00, 0x60, 0xB8,
+0xF8, 0x10, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x02,
+0xCB, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x68, 0xB8,
+0x04, 0x00, 0x68, 0xB8, 0x08, 0x00, 0x68, 0xB8,
+0x0C, 0x00, 0x68, 0xB8, 0x87, 0x00, 0x60, 0xB8,
+0x88, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x42,
+0xE0, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xFF, 0xFD,
+0xE3, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x01,
+0xE1, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x60,
+0xCC, 0x00, 0x60, 0xB8, 0x02, 0x00, 0x60, 0xB8,
+0xE8, 0x12, 0x64, 0xB8, 0xFF, 0xFF, 0x03, 0x00,
+0x00, 0x00, 0x00, 0x04, 0xFF, 0xFF, 0xFF, 0xFB,
+0xFF, 0xFF, 0xFF, 0xDF, 0xFF, 0xFF, 0xFF, 0x1F,
+0x04, 0x00, 0x60, 0xB8, 0x04, 0x00, 0x64, 0xB8,
+0x08, 0x00, 0x60, 0xB8, 0x08, 0x00, 0x64, 0xB8,
+0x24, 0x00, 0x60, 0xB8, 0x80, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xFF, 0xEF, 0xCC, 0x07, 0x64, 0xB8,
+0x24, 0x04, 0x64, 0xB8, 0x87, 0x02, 0x64, 0xB8,
+0x1C, 0x04, 0x64, 0xB8, 0x1C, 0x01, 0x64, 0xB8,
+0x00, 0x0C, 0x01, 0x00, 0x10, 0xA9, 0x7B, 0x18,
+0x10, 0x91, 0x7B, 0x18, 0x77, 0x77, 0x77, 0x77,
+0x08, 0x00, 0x00, 0xF8, 0x00, 0x00, 0x00, 0x3E,
+0x00, 0x00, 0xE0, 0xFF, 0x00, 0x1C, 0x01, 0x88,
+0x00, 0x00, 0x00, 0xFF, 0x08, 0x00, 0x45, 0x01,
+0x48, 0x08, 0x46, 0x01, 0xFF, 0xFF, 0x0F, 0x00,
+0xE0, 0x10, 0x05, 0x00, 0x00, 0x9C, 0x0A, 0x00,
+0x08, 0x00, 0x85, 0x00, 0x48, 0x08, 0x46, 0x00,
+0x60, 0x10, 0x05, 0x00, 0x88, 0x0C, 0x46, 0x01,
+0x00, 0xCC, 0x0A, 0x00, 0x48, 0x00, 0x46, 0x00,
+0x00, 0xDC, 0x0A, 0x00, 0x08, 0x00, 0x44, 0x01,
+0xF2, 0x0D, 0x05, 0x00, 0xEF, 0x00, 0x05, 0x00,
+0x6C, 0x08, 0x05, 0x00, 0x00, 0x00, 0x1F, 0x00,
+0x00, 0x00, 0x00, 0xC0, 0x00, 0x0A, 0x08, 0x00,
+0xCE, 0xEF, 0x0D, 0x00, 0xCE, 0xEF, 0x05, 0x00,
+0x01, 0x00, 0x00, 0xE0, 0x00, 0x00, 0xFF, 0x0F,
+0x21, 0x00, 0x00, 0xE0, 0x45, 0x23, 0x01, 0x00,
+0x08, 0x08, 0x00, 0xF8, 0x08, 0x07, 0x00, 0xF8,
+0x08, 0x02, 0x00, 0xF8, 0x08, 0x03, 0x00, 0xF8,
+0x00, 0x00, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x0F,
+0x62, 0x06, 0x64, 0xB8, 0xB4, 0x06, 0x64, 0xB8,
+0x06, 0x00, 0x00, 0x89, 0x00, 0x00, 0x00, 0x50,
+0x40, 0x00, 0x07, 0x70, 0x02, 0x04, 0x00, 0xD8,
+0x20, 0x01, 0x00, 0xD1, 0x40, 0x80, 0x03, 0x70,
+0x02, 0x04, 0x02, 0xD8, 0x20, 0x01, 0x00, 0xDE,
+0x08, 0x70, 0x0A, 0xF8, 0x08, 0x50, 0x01, 0xF8,
+0xDE, 0xBC, 0x0A, 0x00, 0x01, 0x00, 0x66, 0xB8,
+0x20, 0x04, 0x64, 0xB8, 0x00, 0x00, 0x66, 0xB8,
+0x00, 0xFF, 0xFF, 0x00, 0xCD, 0x9B, 0x78, 0x56,
+0x04, 0x1C, 0x66, 0xB8, 0xFF, 0xFF, 0xFF, 0x3F,
+0x1F, 0x00, 0x60, 0xB8, 0x05, 0xEA, 0xEF, 0xFD,
+0x06, 0xEA, 0xEF, 0xFD, 0x00, 0x1C, 0x66, 0xB8,
+0xFF, 0xFF, 0x3F, 0x00, 0x04, 0xEA, 0xEF, 0xFD,
+0x07, 0xEA, 0xEF, 0xFD, 0x08, 0xEA, 0xEF, 0xFD,
+0x09, 0xEA, 0xEF, 0xFD, 0x0A, 0xEA, 0xEF, 0xFD,
+0x00, 0xF0, 0x0F, 0x00, 0x00, 0xF0, 0x3F, 0x00,
+0x00, 0x00, 0xC0, 0xFF, 0x00, 0x00, 0x00, 0xF0,
+0x00, 0xFC, 0x0F, 0x00, 0x80, 0x81, 0x81, 0x81,
+0x81, 0x81, 0x01, 0x06, 0x00, 0x0E, 0x0E, 0x0E,
+0x0E, 0x0E, 0x0E, 0x38, 0xE0, 0x80, 0x03, 0x00,
+0x00, 0x00, 0x30, 0xC0, 0x00, 0x03, 0x0C, 0x00,
+0x4A, 0x04, 0x64, 0xB8, 0x49, 0x04, 0x64, 0xB8,
+0x02, 0x00, 0x64, 0xB8, 0x03, 0x00, 0x60, 0xB8,
+0x03, 0x00, 0x64, 0xB8, 0x23, 0x04, 0x64, 0xB8,
+0x30, 0x04, 0x64, 0xB8, 0x34, 0x04, 0x64, 0xB8,
+0x01, 0x02, 0x02, 0x03, 0x00, 0x01, 0x01, 0x01,
+0x81, 0x18, 0x66, 0xB8, 0x53, 0x04, 0x64, 0xB8,
+0x80, 0x18, 0x66, 0xB8, 0x82, 0x18, 0x66, 0xB8,
+0x83, 0x18, 0x66, 0xB8, 0x84, 0x18, 0x66, 0xB8,
+0x85, 0x18, 0x66, 0xB8, 0x2D, 0x04, 0x64, 0xB8,
+0xCF, 0x04, 0x64, 0xB8, 0xF0, 0x10, 0x60, 0xB8,
+0x00, 0x00, 0xF0, 0x00, 0x00, 0x00, 0x00, 0x0C,
+0x00, 0x00, 0x0F, 0x00, 0x00, 0x00, 0xC0, 0x00,
+0x06, 0x00, 0x66, 0xB8, 0x50, 0x04, 0x64, 0xB8,
+0x51, 0x04, 0x64, 0xB8, 0x52, 0x04, 0x64, 0xB8,
+0x08, 0x1C, 0x66, 0xB8, 0xFF, 0xFF, 0xCF, 0x3F,
+0xFF, 0xFC, 0x3F, 0xFF, 0x01, 0x1C, 0x66, 0xB8,
+0x02, 0x1C, 0x66, 0xB8, 0x03, 0x1C, 0x66, 0xB8,
+0x05, 0x1C, 0x66, 0xB8, 0x06, 0x1C, 0x66, 0xB8,
+0x07, 0x1C, 0x66, 0xB8, 0x00, 0x10, 0x66, 0xB8,
+0x08, 0x10, 0x66, 0xB8, 0x03, 0x10, 0x66, 0xB8,
+0x09, 0x10, 0x66, 0xB8, 0x04, 0x10, 0x66, 0xB8,
+0x05, 0x10, 0x66, 0xB8, 0x0C, 0x10, 0x66, 0xB8,
+0x02, 0x10, 0x66, 0xB8, 0x01, 0x10, 0x66, 0xB8,
+0x0D, 0x10, 0x66, 0xB8, 0x06, 0x10, 0x66, 0xB8,
+0xCC, 0x06, 0x64, 0xB8, 0xFF, 0xFF, 0xFF, 0x00,
+0x74, 0x57, 0x74, 0x00, 0x47, 0x75, 0x47, 0x00,
+0x70, 0x45, 0x70, 0x00, 0x17, 0x45, 0x17, 0x00,
+0x00, 0x00, 0xF0, 0xFF, 0x70, 0x57, 0x70, 0x00,
+0x17, 0x75, 0x17, 0x00, 0x00, 0x00, 0x00, 0x06,
+0xFF, 0xFF, 0xFF, 0x0F, 0xFF, 0xFC, 0xFE, 0xFF,
+0x92, 0x84, 0x10, 0x08, 0x00, 0x00, 0x00, 0x08,
+0x00, 0x01, 0x01, 0x00, 0x00, 0x00, 0x10, 0x08,
+0x00, 0x00, 0x40, 0x00, 0x28, 0xEA, 0xA0, 0x79,
+0xB9, 0xB2, 0x94, 0x91, 0x00, 0x00, 0x0C, 0x00,
+0x00, 0x00, 0x80, 0x00, 0x0E, 0x08, 0x04, 0x00,
+0x0C, 0x08, 0x04, 0x00, 0x00, 0xFF, 0xF9, 0xFF,
+0x00, 0x00, 0xFE, 0x1F, 0x77, 0x65, 0x4F, 0x38,
+0x00, 0x80, 0x03, 0x00, 0x18, 0x34, 0x00, 0xB8,
+0x10, 0x34, 0x00, 0xB8, 0xA8, 0xEA, 0xFF, 0x47,
+0x08, 0x34, 0x00, 0xB8, 0x00, 0x34, 0x00, 0xB8,
+0x01, 0x34, 0x00, 0xB8, 0x02, 0x34, 0x00, 0xB8,
+0x78, 0x07, 0x64, 0xB8, 0xA3, 0x00, 0x60, 0xB8,
+0xA0, 0x00, 0x60, 0xB8, 0x65, 0x07, 0x64, 0xB8,
+0x40, 0x00, 0x60, 0xB8, 0x68, 0x00, 0x60, 0xB8,
+0x6E, 0x07, 0x64, 0xB8, 0x64, 0x07, 0x64, 0xB8,
+0x23, 0x05, 0x64, 0xB8, 0x64, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0x40, 0xFF, 0xAA, 0x00, 0x60, 0xB8,
+0xA8, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x02, 0x80,
+0xFF, 0xFF, 0xFF, 0xE0, 0x20, 0x34, 0x00, 0xB8,
+0xA8, 0x06, 0x64, 0xB8, 0x10, 0x07, 0x64, 0xB8,
+0x00, 0x16, 0x64, 0xB8, 0x04, 0x16, 0x64, 0xB8,
+0x08, 0x16, 0x64, 0xB8, 0x0D, 0x00, 0x78, 0xB8,
+0x12, 0x00, 0x78, 0xB8, 0x34, 0x00, 0x78, 0xB8,
+0xC4, 0x06, 0x64, 0xB8, 0x00, 0x04, 0x00, 0x04,
+0x70, 0x07, 0x64, 0xB8, 0x74, 0x07, 0x64, 0xB8,
+0x28, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xFF, 0x81,
+0x00, 0x00, 0x70, 0xB8, 0x18, 0x00, 0x70, 0xB8,
+0x00, 0x00, 0x78, 0xB8, 0x18, 0x00, 0x78, 0xB8,
+0x0B, 0x00, 0x78, 0xB8, 0x0B, 0x00, 0x70, 0xB8,
+0x02, 0x00, 0x78, 0xB8, 0x02, 0x00, 0x70, 0xB8,
+0x01, 0xA0, 0x02, 0x00, 0x94, 0x02, 0x64, 0xB8,
+0x97, 0x02, 0x64, 0xB8, 0xCC, 0x01, 0x64, 0xB8,
+0xCF, 0x01, 0x64, 0xB8, 0x34, 0x01, 0x64, 0xB8,
+0x54, 0x02, 0x64, 0xB8, 0x50, 0x02, 0x64, 0xB8,
+0x4C, 0x02, 0x64, 0xB8, 0x04, 0x00, 0x78, 0xB8,
+0x48, 0x02, 0x64, 0xB8, 0x44, 0x02, 0x64, 0xB8,
+0x64, 0x05, 0x64, 0xB8, 0xD4, 0x04, 0x60, 0xB8,
+0x84, 0x04, 0x60, 0xB8, 0xC8, 0x04, 0x60, 0xB8,
+0xC8, 0x04, 0x64, 0xB8, 0x78, 0x04, 0x60, 0xB8,
+0x78, 0x04, 0x64, 0xB8, 0x27, 0x05, 0x64, 0xB8,
+0xB5, 0x05, 0x64, 0xB8, 0xB7, 0x05, 0x64, 0xB8,
+0x31, 0x05, 0x64, 0xB8, 0x3C, 0x11, 0x64, 0xB8,
+0x40, 0x05, 0x64, 0xB8, 0x01, 0xEA, 0xEF, 0xFD,
+0x02, 0xEA, 0xEF, 0xFD, 0xC8, 0x01, 0x64, 0xB8,
+0xC9, 0x01, 0x64, 0xB8, 0xA0, 0x01, 0x64, 0xB8,
+0xB4, 0x05, 0x64, 0xB8, 0x80, 0x05, 0x64, 0xB8,
+0x01, 0x00, 0x78, 0xB8, 0x40, 0x00, 0x78, 0xB8,
+0x38, 0x00, 0x78, 0xB8, 0x30, 0x00, 0x78, 0xB8,
+0x39, 0x00, 0x78, 0xB8, 0x3A, 0x00, 0x78, 0xB8,
+0x3C, 0x00, 0x78, 0xB8, 0x3D, 0x00, 0x78, 0xB8,
+0x3E, 0x00, 0x78, 0xB8, 0x3F, 0x00, 0x78, 0xB8,
+0x42, 0x00, 0x78, 0xB8, 0x44, 0x00, 0x78, 0xB8,
+0x48, 0x00, 0x78, 0xB8, 0x49, 0x00, 0x78, 0xB8,
+0x4A, 0x00, 0x78, 0xB8, 0x4B, 0x00, 0x78, 0xB8,
+0x48, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xFE, 0xFF,
+0x44, 0x00, 0x60, 0xB8, 0x60, 0x00, 0x60, 0xB8,
+0x47, 0x00, 0x60, 0xB8, 0x46, 0x00, 0x60, 0xB8,
+0x63, 0x00, 0x60, 0xB8, 0x62, 0x00, 0x60, 0xB8,
+0x45, 0x00, 0x60, 0xB8, 0x61, 0x00, 0x60, 0xB8,
+0xC6, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x00, 0x05,
+0x53, 0x05, 0x64, 0xB8, 0x94, 0x01, 0x64, 0xB8,
+0x54, 0x00, 0x60, 0xB8, 0x50, 0x00, 0x60, 0xB8,
+0x30, 0x01, 0x64, 0xB8, 0x24, 0x01, 0x64, 0xB8,
+0x20, 0x01, 0x64, 0xB8, 0x24, 0x11, 0x64, 0xB8,
+0x20, 0x11, 0x64, 0xB8, 0x2C, 0x11, 0x64, 0xB8,
+0x28, 0x11, 0x64, 0xB8, 0x34, 0x11, 0x64, 0xB8,
+0x30, 0x11, 0x64, 0xB8, 0x38, 0x01, 0x64, 0xB8,
+0x38, 0x11, 0x64, 0xB8, 0xE4, 0x11, 0x64, 0xB8,
+0xE0, 0x11, 0x64, 0xB8, 0x00, 0x40, 0xE0, 0x17,
+0xEF, 0x01, 0x0E, 0x00, 0x01, 0x70, 0x00, 0x3F,
+0xE0, 0x12, 0x64, 0xB8, 0xE8, 0x10, 0x60, 0xB8,
+0x67, 0x05, 0x64, 0xB8, 0x66, 0x05, 0x64, 0xB8,
+0x65, 0x05, 0x64, 0xB8, 0x63, 0x05, 0x64, 0xB8,
+0x62, 0x05, 0x64, 0xB8, 0x61, 0x05, 0x64, 0xB8,
+0x00, 0x01, 0x7F, 0x00, 0x2F, 0x01, 0x64, 0xB8,
+0x00, 0x28, 0x64, 0xB8, 0x00, 0x2C, 0x64, 0xB8,
+0x00, 0x38, 0x64, 0xB8, 0x00, 0x3C, 0x64, 0xB8,
+0x54, 0x04, 0x64, 0xB8, 0x68, 0x06, 0x64, 0xB8,
+0x69, 0x06, 0x64, 0xB8, 0x00, 0x00, 0xF0, 0x3F,
+0x70, 0x77, 0x33, 0x54, 0x00, 0x00, 0x10, 0x00,
+0x17, 0x77, 0x33, 0x77, 0x77, 0x77, 0x33, 0x77,
+0x17, 0x77, 0x33, 0x54, 0x00, 0x00, 0xFF, 0x00,
+0x00, 0x00, 0x33, 0x00, 0xC3, 0x03, 0x30, 0x00,
+0x00, 0x02, 0x30, 0x00, 0x00, 0x00, 0x1C, 0x00,
+0x01, 0x02, 0x30, 0x00, 0x00, 0x00, 0xC0, 0x03,
+0x00, 0x00, 0x80, 0x01, 0x02, 0x02, 0x30, 0x00,
+0x00, 0x00, 0x40, 0x01, 0x83, 0x04, 0x64, 0xB8,
+0x00, 0x03, 0x07, 0x00, 0xFF, 0x03, 0x07, 0x00,
+0x83, 0x00, 0x60, 0xB8, 0x90, 0x00, 0x60, 0xB8,
+0x92, 0x06, 0x64, 0xB8, 0x08, 0x01, 0x64, 0xB8,
+0x00, 0x10, 0x60, 0xB8, 0xEF, 0x00, 0x60, 0xB8,
+0xF8, 0x05, 0x64, 0xB8, 0x92, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xFF, 0x7F, 0xA2, 0x02, 0x64, 0xB8,
+0x9C, 0x02, 0x64, 0xB8, 0x00, 0x00, 0x68, 0x18,
+0x01, 0x06, 0x64, 0xB8, 0x5F, 0x01, 0x64, 0xB8,
+0x1F, 0x07, 0x64, 0xB8, 0x1C, 0x07, 0x64, 0xB8,
+0x2C, 0x04, 0x64, 0xB8, 0x1F, 0x04, 0x64, 0xB8,
+0xB8, 0x05, 0x64, 0xB8, 0xBC, 0x05, 0x64, 0xB8,
+0x5F, 0x11, 0x64, 0xB8, 0xFE, 0xFF, 0xFF, 0x7F,
+0x30, 0x00, 0x78, 0x18, 0x00, 0xA0, 0x7A, 0xB8,
+0x00, 0xA0, 0x7A, 0x18, 0x00, 0x00, 0x70, 0x18,
+0x00, 0x00, 0x66, 0x18, 0xE8, 0x03, 0x00, 0x80,
+0xFF, 0x00, 0xFF, 0x00, 0x40, 0x00, 0x00, 0xB5,
+0x44, 0x00, 0x00, 0xB5, 0x48, 0x00, 0x00, 0xB5,
+0x4C, 0x00, 0x00, 0xB5, 0xA4, 0x04, 0x64, 0xB8,
+0xA8, 0x04, 0x64, 0xB8, 0xC0, 0x01, 0x64, 0xB8,
+0x00, 0x00, 0x20, 0x00, 0x7E, 0x04, 0x64, 0xB8,
+0xAC, 0x04, 0x64, 0xB8, 0x07, 0x10, 0x66, 0xB8,
+0x7D, 0x04, 0x64, 0xB8, 0x7C, 0x04, 0x64, 0xB8,
+0xF4, 0x00, 0x60, 0xB8, 0x44, 0x00, 0x02, 0x00,
+0xA0, 0x07, 0x64, 0xB8, 0x14, 0x11, 0x64, 0xB8,
+0x16, 0x11, 0x64, 0xB8, 0x17, 0x11, 0x64, 0xB8,
+0xD4, 0x07, 0x64, 0xB8, 0x08, 0x06, 0x64, 0xB8,
+0x0F, 0x06, 0x64, 0xB8, 0x9A, 0x01, 0x64, 0xB8,
+0x98, 0x01, 0x64, 0xB8, 0xC7, 0x01, 0x64, 0xB8,
+0x00, 0x01, 0x64, 0xB8, 0x7B, 0x05, 0x64, 0xB8,
+0x73, 0x05, 0x64, 0xB8, 0x0F, 0x00, 0x3E, 0x00,
+0x01, 0x01, 0x64, 0xB8, 0x14, 0x00, 0x60, 0xB8,
+0x7C, 0x00, 0x60, 0xB8, 0x10, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xDF, 0xFF, 0xFF, 0xFF, 0xFF, 0xBF,
+0xB7, 0x06, 0x64, 0xB8, 0xFF, 0xFF, 0xEF, 0xFF,
+0xFF, 0xFF, 0xFF, 0xFE, 0x4C, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0x7F, 0xFF, 0x44, 0x09, 0x64, 0xB8,
+0x30, 0x09, 0x64, 0xB8, 0x38, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xFF, 0xCF, 0xFF, 0xFF, 0xFF, 0xF9,
+0x70, 0x00, 0x60, 0xB8, 0x80, 0x10, 0x60, 0xB8,
+0xEC, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x07,
+0xFF, 0xFF, 0xFF, 0xF8, 0xE4, 0x00, 0x60, 0xB8,
+0xE5, 0x00, 0x60, 0xB8, 0xE8, 0x00, 0x60, 0xB8,
+0xE9, 0x00, 0x60, 0xB8, 0xEA, 0x00, 0x60, 0xB8,
+0xEB, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0x7F, 0xFE,
+0x00, 0x17, 0x64, 0xB8, 0x03, 0x17, 0x64, 0xB8,
+0x08, 0x17, 0x64, 0xB8, 0x04, 0x17, 0x64, 0xB8,
+0x00, 0x00, 0x0F, 0xC0, 0x00, 0x00, 0x03, 0xC0,
+0x00, 0x00, 0x0C, 0xC0, 0x00, 0x00, 0x01, 0xC0,
+0x00, 0x00, 0x02, 0xC0, 0x06, 0x17, 0x64, 0xB8,
+0x00, 0x00, 0x04, 0xC0, 0x07, 0x17, 0x64, 0xB8,
+0x00, 0x00, 0x08, 0xC0, 0x31, 0x00, 0x60, 0xB8,
+0x32, 0x00, 0x60, 0xB8, 0x33, 0x00, 0x60, 0xB8,
+0x30, 0x00, 0x60, 0xB8, 0x01, 0xAA, 0xAA, 0xFA,
+0x00, 0x00, 0x00, 0x70, 0xFF, 0xFF, 0xCF, 0xFF,
+0x5C, 0x05, 0x64, 0xB8, 0x38, 0x06, 0x64, 0xB8,
+0xA0, 0x06, 0x64, 0xB8, 0x84, 0x02, 0x64, 0xB8,
+0xFF, 0xFF, 0xFB, 0xFF, 0xA0, 0x02, 0x64, 0xB8,
+0x57, 0x05, 0x64, 0xB8, 0x04, 0x15, 0x64, 0xB8,
+0x10, 0x15, 0x64, 0xB8, 0x08, 0x15, 0x64, 0xB8,
+0x0C, 0x15, 0x64, 0xB8, 0xFF, 0xFF, 0xF8, 0xFF,
+0x4D, 0x00, 0x78, 0xB8, 0x4E, 0x00, 0x78, 0xB8,
+0x4C, 0x00, 0x78, 0xB8, 0x52, 0x00, 0x78, 0xB8,
+0xA0, 0x86, 0x01, 0x00, 0x00, 0x00, 0x05, 0x00,
+0x82, 0x06, 0x64, 0xB8, 0x83, 0x06, 0x64, 0xB8,
+0x8E, 0x06, 0x64, 0xB8, 0x84, 0x06, 0x64, 0xB8,
+0x85, 0x06, 0x64, 0xB8, 0x58, 0x01, 0x64, 0xB8,
+0x50, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x78, 0x18,
+0xB2, 0x05, 0x64, 0xB8, 0xB3, 0x05, 0x64, 0xB8,
+0x43, 0x05, 0x64, 0xB8, 0x7D, 0x05, 0x64, 0xB8,
+0x7F, 0x05, 0x64, 0xB8, 0x72, 0x05, 0x64, 0xB8,
+0xCF, 0x05, 0x64, 0xB8, 0xE0, 0x05, 0x64, 0xB8,
+0xE4, 0x05, 0x64, 0xB8, 0xE8, 0x05, 0x64, 0xB8,
+0xEC, 0x05, 0x64, 0xB8, 0xF0, 0x05, 0x64, 0xB8,
+0xB6, 0x05, 0x64, 0xB8, 0x04, 0x06, 0x64, 0xB8,
+0x60, 0x16, 0x64, 0xB8, 0x20, 0x00, 0x78, 0xB8,
+0x10, 0x00, 0x78, 0xB8, 0x03, 0x00, 0x78, 0xB8,
+0xFF, 0xFF, 0x01, 0xFF, 0x05, 0x00, 0x78, 0xB8,
+0x12, 0x05, 0x64, 0xB8, 0x10, 0x05, 0x64, 0xB8,
+0x43, 0x6C, 0x65, 0x61, 0x72, 0x50, 0x57, 0x54,
+0x00, 0x00, 0x00, 0x00, 0x41, 0x20, 0x4D, 0x69,
+0x78, 0x4D, 0x6F, 0x64, 0x65, 0x20, 0x41, 0x47,
+0x43, 0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x20,
+0x42, 0x42, 0x53, 0x3D, 0x30, 0x78, 0x25, 0x62,
+0x58, 0x00, 0x00, 0x00, 0x42, 0x20, 0x4D, 0x69,
+0x78, 0x4D, 0x6F, 0x64, 0x65, 0x20, 0x41, 0x47,
+0x43, 0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x20,
+0x42, 0x42, 0x53, 0x3D, 0x30, 0x78, 0x25, 0x62,
+0x58, 0x00, 0x00, 0x00, 0x5B, 0x49, 0x51, 0x4B,
+0x5D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3E, 0x50,
+0x48, 0x59, 0x5F, 0x49, 0x51, 0x43, 0x61, 0x6C,
+0x69, 0x62, 0x72, 0x61, 0x74, 0x65, 0x5F, 0x49,
+0x6E, 0x69, 0x74, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x72, 0x65, 0x6C, 0x6F, 0x61, 0x64, 0x20, 0x49,
+0x51, 0x4B, 0x20, 0x72, 0x65, 0x73, 0x75, 0x6C,
+0x74, 0x20, 0x62, 0x65, 0x66, 0x6F, 0x72, 0x65,
+0x2C, 0x20, 0x30, 0x78, 0x25, 0x62, 0x78, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x49, 0x51, 0x4B, 0x20,
+0x74, 0x69, 0x6D, 0x65, 0x6F, 0x75, 0x74, 0x21,
+0x21, 0x21, 0x0A, 0x00, 0x64, 0x65, 0x6C, 0x61,
+0x79, 0x20, 0x63, 0x6F, 0x75, 0x6E, 0x74, 0x20,
+0x3D, 0x20, 0x30, 0x78, 0x25, 0x78, 0x21, 0x21,
+0x21, 0x0A, 0x00, 0x00, 0x64, 0x65, 0x6C, 0x61,
+0x79, 0x5F, 0x63, 0x6F, 0x75, 0x6E, 0x74, 0x20,
+0x3D, 0x20, 0x30, 0x78, 0x25, 0x78, 0x0A, 0x00,
+0x49, 0x51, 0x4B, 0x73, 0x74, 0x65, 0x70, 0x20,
+0x3D, 0x20, 0x30, 0x78, 0x25, 0x62, 0x78, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x5B, 0x49, 0x51, 0x4B,
+0x5D, 0x50, 0x61, 0x74, 0x68, 0x41, 0x5F, 0x4C,
+0x4F, 0x4B, 0x5F, 0x6E, 0x6F, 0x74, 0x72, 0x65,
+0x61, 0x64, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x64,
+0x2C, 0x20, 0x50, 0x61, 0x74, 0x68, 0x42, 0x5F,
+0x4C, 0x4F, 0x4B, 0x31, 0x5F, 0x6E, 0x6F, 0x74,
+0x72, 0x65, 0x61, 0x64, 0x79, 0x20, 0x3D, 0x20,
+0x25, 0x64, 0x0A, 0x00, 0x5B, 0x49, 0x51, 0x4B,
+0x5D, 0x50, 0x61, 0x74, 0x68, 0x41, 0x5F, 0x54,
+0x58, 0x49, 0x51, 0x4B, 0x5F, 0x66, 0x61, 0x69,
+0x6C, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20,
+0x50, 0x61, 0x74, 0x68, 0x42, 0x5F, 0x54, 0x58,
+0x49, 0x51, 0x4B, 0x5F, 0x66, 0x61, 0x69, 0x6C,
+0x20, 0x3D, 0x20, 0x25, 0x64, 0x0A, 0x00, 0x00,
+0x5B, 0x49, 0x51, 0x4B, 0x5D, 0x50, 0x61, 0x74,
+0x68, 0x41, 0x5F, 0x52, 0x58, 0x49, 0x51, 0x4B,
+0x5F, 0x66, 0x61, 0x69, 0x6C, 0x20, 0x3D, 0x20,
+0x25, 0x64, 0x2C, 0x20, 0x50, 0x61, 0x74, 0x68,
+0x42, 0x5F, 0x52, 0x58, 0x49, 0x51, 0x4B, 0x5F,
+0x66, 0x61, 0x69, 0x6C, 0x20, 0x3D, 0x20, 0x25,
+0x64, 0x0A, 0x00, 0x00, 0x5B, 0x49, 0x51, 0x4B,
+0x5D, 0x50, 0x61, 0x74, 0x68, 0x41, 0x5F, 0x54,
+0x58, 0x49, 0x51, 0x4B, 0x5F, 0x72, 0x65, 0x74,
+0x72, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C,
+0x20, 0x50, 0x61, 0x74, 0x68, 0x42, 0x5F, 0x54,
+0x58, 0x49, 0x51, 0x4B, 0x5F, 0x72, 0x65, 0x74,
+0x72, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x5B, 0x49, 0x51, 0x4B,
+0x5D, 0x50, 0x61, 0x74, 0x68, 0x41, 0x5F, 0x52,
+0x58, 0x4B, 0x31, 0x5F, 0x72, 0x65, 0x74, 0x72,
+0x79, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20,
+0x50, 0x61, 0x74, 0x68, 0x41, 0x5F, 0x52, 0x58,
+0x4B, 0x32, 0x5F, 0x72, 0x65, 0x74, 0x72, 0x79,
+0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20, 0x50,
+0x61, 0x74, 0x68, 0x42, 0x5F, 0x52, 0x58, 0x4B,
+0x31, 0x5F, 0x72, 0x65, 0x74, 0x72, 0x79, 0x20,
+0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20, 0x50, 0x61,
+0x74, 0x68, 0x42, 0x5F, 0x52, 0x58, 0x4B, 0x32,
+0x5F, 0x72, 0x65, 0x74, 0x72, 0x79, 0x20, 0x3D,
+0x20, 0x25, 0x64, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x5B, 0x49, 0x51, 0x4B, 0x5D, 0x50, 0x61, 0x74,
+0x68, 0x41, 0x5F, 0x47, 0x53, 0x31, 0x5F, 0x72,
+0x65, 0x74, 0x72, 0x79, 0x20, 0x3D, 0x20, 0x25,
+0x64, 0x2C, 0x20, 0x50, 0x61, 0x74, 0x68, 0x41,
+0x5F, 0x47, 0x53, 0x32, 0x5F, 0x72, 0x65, 0x74,
+0x72, 0x79, 0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C,
+0x20, 0x50, 0x61, 0x74, 0x68, 0x42, 0x5F, 0x47,
+0x53, 0x31, 0x5F, 0x72, 0x65, 0x74, 0x72, 0x79,
+0x20, 0x3D, 0x20, 0x25, 0x64, 0x2C, 0x20, 0x50,
+0x61, 0x74, 0x68, 0x42, 0x5F, 0x47, 0x53, 0x32,
+0x5F, 0x72, 0x65, 0x74, 0x72, 0x79, 0x20, 0x3D,
+0x20, 0x25, 0x64, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x46, 0x57, 0x49, 0x51, 0x4B, 0x20, 0x73, 0x74,
+0x61, 0x72, 0x74, 0x21, 0x21, 0x21, 0x00, 0x00,
+0x72, 0x73, 0x73, 0x69, 0x56, 0x61, 0x72, 0x3A,
+0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x00,
+0x53, 0x5F, 0x52, 0x41, 0x3D, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x50, 0x57, 0x52, 0x53,
+0x54, 0x53, 0x20, 0x25, 0x62, 0x78, 0x2C, 0x72,
+0x61, 0x74, 0x65, 0x20, 0x25, 0x62, 0x78, 0x2C,
+0x25, 0x62, 0x78, 0x00, 0x52, 0x53, 0x53, 0x49,
+0x20, 0x30, 0x78, 0x25, 0x62, 0x78, 0x2C, 0x44,
+0x49, 0x53, 0x50, 0x54, 0x20, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x74, 0x6F, 0x74, 0x61,
+0x6C, 0x20, 0x30, 0x78, 0x25, 0x62, 0x78, 0x2C,
+0x64, 0x72, 0x6F, 0x70, 0x20, 0x30, 0x78, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x50, 0x54, 0x5F, 0x53,
+0x54, 0x41, 0x54, 0x45, 0x20, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x72, 0x74, 0x79, 0x5F,
+0x72, 0x61, 0x74, 0x69, 0x6F, 0x5F, 0x76, 0x61,
+0x72, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x50, 0x54, 0x5F, 0x6E, 0x6F, 0x69, 0x73, 0x79,
+0x00, 0x00, 0x00, 0x00, 0x74, 0x72, 0x79, 0x45,
+0x6E, 0x64, 0x2C, 0x50, 0x57, 0x52, 0x53, 0x54,
+0x53, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x50, 0x54,
+0x5F, 0x43, 0x4E, 0x54, 0x52, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x74, 0x72, 0x79, 0x49,
+0x64, 0x78, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x52,
+0x52, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x44, 0x52,
+0x53, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x53, 0x46, 0x74, 0x72, 0x3A, 0x25, 0x62, 0x78,
+0x20, 0x69, 0x64, 0x3A, 0x25, 0x62, 0x78, 0x00,
+0x64, 0x65, 0x63, 0x45, 0x6E, 0x64, 0x2C, 0x50,
+0x57, 0x52, 0x53, 0x54, 0x53, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x30, 0x31, 0x32, 0x33,
+0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x41, 0x42,
+0x43, 0x44, 0x45, 0x46, 0x00, 0x00, 0x00, 0x00,
+0x53, 0x65, 0x74, 0x5F, 0x43, 0x61, 0x6E, 0x64,
+0x69, 0x5F, 0x33, 0x3A, 0x20, 0x5B, 0x31, 0x5D,
+0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x2C, 0x20,
+0x20, 0x5B, 0x32, 0x5D, 0x3D, 0x30, 0x78, 0x25,
+0x62, 0x58, 0x2C, 0x20, 0x20, 0x5B, 0x33, 0x5D,
+0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x53, 0x65, 0x74, 0x5F, 0x43, 0x61, 0x6E, 0x64,
+0x69, 0x5F, 0x32, 0x3A, 0x20, 0x5B, 0x31, 0x5D,
+0x3D, 0x30, 0x78, 0x25, 0x62, 0x58, 0x2C, 0x20,
+0x20, 0x5B, 0x32, 0x5D, 0x3D, 0x30, 0x78, 0x25,
+0x62, 0x58, 0x20, 0x00, 0x44, 0x65, 0x6C, 0x4D,
+0x55, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x50, 0x45, 0x52, 0x20, 0x52, 0x50, 0x54, 0x3A,
+0x20, 0x6D, 0x69, 0x64, 0x25, 0x62, 0x58, 0x2C,
+0x52, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x72, 0x74,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x62, 0x77, 0x3A,
+0x25, 0x62, 0x78, 0x00, 0x50, 0x45, 0x52, 0x20,
+0x52, 0x50, 0x54, 0x3A, 0x20, 0x6D, 0x69, 0x64,
+0x25, 0x62, 0x58, 0x2C, 0x54, 0x54, 0x3A, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x50, 0x45, 0x52, 0x20,
+0x52, 0x50, 0x54, 0x3A, 0x20, 0x25, 0x62, 0x58,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x58,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x58,
+0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x2C, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x65, 0x71, 0x20, 0x50, 0x45, 0x52, 0x20,
+0x43, 0x4D, 0x44, 0x3A, 0x20, 0x47, 0x72, 0x3A,
+0x25, 0x62, 0x58, 0x2C, 0x20, 0x54, 0x59, 0x50,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x62, 0x74,
+0x6D, 0x70, 0x3A, 0x25, 0x78, 0x00, 0x00, 0x00,
+0x52, 0x65, 0x71, 0x20, 0x50, 0x45, 0x52, 0x20,
+0x43, 0x4D, 0x44, 0x3A, 0x20, 0x49, 0x64, 0x78,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x6D, 0x69,
+0x64, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x65, 0x71, 0x20, 0x50, 0x45, 0x52, 0x20,
+0x43, 0x4D, 0x44, 0x3A, 0x20, 0x49, 0x64, 0x78,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x4D, 0x69,
+0x64, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x25,
+0x62, 0x78, 0x2C, 0x20, 0x25, 0x62, 0x78, 0x00,
+0x53, 0x65, 0x74, 0x5F, 0x50, 0x6E, 0x74, 0x79,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x65, 0x74, 0x5F,
+0x52, 0x41, 0x5F, 0x55, 0x70, 0x5F, 0x72, 0x61,
+0x74, 0x69, 0x6F, 0x5F, 0x66, 0x6F, 0x72, 0x5F,
+0x52, 0x41, 0x5F, 0x64, 0x65, 0x62, 0x75, 0x67,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x65, 0x74, 0x5F,
+0x44, 0x6F, 0x77, 0x6E, 0x5F, 0x72, 0x61, 0x74,
+0x69, 0x6F, 0x00, 0x00, 0x76, 0x61, 0x6C, 0x75,
+0x65, 0x38, 0x3D, 0x30, 0x78, 0x25, 0x62, 0x58,
+0x2C, 0x20, 0x76, 0x61, 0x6C, 0x75, 0x65, 0x31,
+0x36, 0x3D, 0x30, 0x78, 0x25, 0x77, 0x78, 0x2C,
+0x20, 0x76, 0x61, 0x6C, 0x75, 0x65, 0x33, 0x32,
+0x3D, 0x30, 0x78, 0x25, 0x78, 0x00, 0x00, 0x00,
+0x48, 0x32, 0x43, 0x4D, 0x55, 0x3A, 0x41, 0x64,
+0x45, 0x6E, 0x74, 0x3D, 0x25, 0x62, 0x78, 0x2C,
+0x6D, 0x69, 0x64, 0x3D, 0x25, 0x62, 0x78, 0x00,
+0x48, 0x32, 0x43, 0x4D, 0x52, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x4D, 0x55, 0x3A, 0x20, 0x44, 0x65, 0x6C, 0x65,
+0x74, 0x65, 0x20, 0x65, 0x6E, 0x74, 0x72, 0x79,
+0x20, 0x3D, 0x20, 0x25, 0x62, 0x78, 0x2C, 0x20,
+0x6D, 0x61, 0x63, 0x69, 0x64, 0x20, 0x3D, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x4D, 0x55, 0x3A, 0x20,
+0x57, 0x61, 0x74, 0x63, 0x68, 0x20, 0x47, 0x49,
+0x44, 0x3D, 0x25, 0x62, 0x78, 0x20, 0x75, 0x73,
+0x65, 0x72, 0x3D, 0x25, 0x62, 0x78, 0x20, 0x64,
+0x6F, 0x77, 0x6E, 0x3D, 0x25, 0x62, 0x78, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x62, 0x44, 0x52, 0x61, 0x3A, 0x25,
+0x62, 0x78, 0x2C, 0x62, 0x44, 0x50, 0x54, 0x3A,
+0x25, 0x62, 0x78, 0x2C, 0x52, 0x61, 0x49, 0x64,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x49, 0x6E, 0x69,
+0x42, 0x77, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x42,
+0x77, 0x53, 0x65, 0x74, 0x25, 0x62, 0x78, 0x2C,
+0x62, 0x53, 0x47, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x56, 0x45, 0x4E, 0x3A, 0x25, 0x62, 0x78, 0x00,
+0x4D, 0x61, 0x73, 0x6B, 0x30, 0x20, 0x25, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x48, 0x32, 0x43, 0x42,
+0x46, 0x45, 0x6E, 0x74, 0x00, 0x00, 0x00, 0x00,
+0x45, 0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x4E,
+0x63, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x4D, 0x3A,
+0x25, 0x62, 0x78, 0x00, 0x44, 0x69, 0x73, 0x3A,
+0x25, 0x62, 0x78, 0x20, 0x4E, 0x63, 0x3A, 0x25,
+0x62, 0x78, 0x20, 0x4D, 0x3A, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x43, 0x6F, 0x6E, 0x6E,
+0x65, 0x63, 0x74, 0x20, 0x53, 0x74, 0x61, 0x72,
+0x74, 0x62, 0x79, 0x52, 0x53, 0x53, 0x49, 0x3A,
+0x25, 0x62, 0x58, 0x20, 0x25, 0x62, 0x78, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x52, 0x53, 0x53, 0x49,
+0x43, 0x4D, 0x44, 0x3A, 0x25, 0x62, 0x58, 0x20,
+0x25, 0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x52, 0x53, 0x53, 0x49,
+0x43, 0x4D, 0x44, 0x20, 0x44, 0x72, 0x76, 0x46,
+0x69, 0x78, 0x3A, 0x25, 0x62, 0x58, 0x20, 0x25,
+0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x63, 0x63, 0x78, 0x5F, 0x68, 0x32, 0x63, 0x20,
+0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x20,
+0x50, 0x65, 0x72, 0x69, 0x6F, 0x64, 0x3D, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x72, 0x65, 0x61, 0x64,
+0x79, 0x3D, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x43, 0x6C, 0x6D, 0x52, 0x70, 0x74, 0x3D, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x43, 0x32, 0x48, 0x20,
+0x25, 0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x00,
+0x63, 0x6E, 0x74, 0x3D, 0x25, 0x62, 0x78, 0x00,
+0x4D, 0x3A, 0x25, 0x62, 0x58, 0x2C, 0x52, 0x3A,
+0x25, 0x62, 0x58, 0x2C, 0x25, 0x62, 0x78, 0x2C,
+0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C,
+0x20, 0x25, 0x77, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x47, 0x3A, 0x25, 0x62, 0x58, 0x2C, 0x50, 0x30,
+0x25, 0x62, 0x58, 0x2C, 0x50, 0x31, 0x25, 0x62,
+0x58, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x32, 0x53, 0x25,
+0x78, 0x2C, 0x54, 0x54, 0x25, 0x78, 0x00, 0x00,
+0x4D, 0x74, 0x42, 0x77, 0x20, 0x55, 0x70, 0x44,
+0x77, 0x25, 0x62, 0x78, 0x20, 0x42, 0x57, 0x25,
+0x62, 0x78, 0x20, 0x52, 0x74, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x48, 0x69, 0x74, 0x25,
+0x62, 0x78, 0x20, 0x52, 0x74, 0x30, 0x3D, 0x25,
+0x77, 0x78, 0x20, 0x52, 0x74, 0x31, 0x3D, 0x25,
+0x77, 0x78, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x4F,
+0x46, 0x44, 0x4D, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x41, 0x3A, 0x43, 0x43, 0x4B, 0x25, 0x62,
+0x58, 0x00, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x56,
+0x31, 0x2D, 0x4D, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x41, 0x3A, 0x56, 0x32, 0x2D, 0x4D, 0x25,
+0x62, 0x58, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x56,
+0x33, 0x2D, 0x4D, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x41, 0x3A, 0x48, 0x2D, 0x4D, 0x25, 0x62,
+0x58, 0x00, 0x00, 0x00, 0x52, 0x41, 0x3A, 0x48,
+0x2D, 0x4D, 0x31, 0x2C, 0x25, 0x62, 0x58, 0x00,
+0x52, 0x41, 0x3A, 0x48, 0x2D, 0x4D, 0x32, 0x2C,
+0x25, 0x62, 0x58, 0x00, 0x53, 0x74, 0x6F, 0x72,
+0x45, 0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x42,
+0x46, 0x63, 0x74, 0x72, 0x6C, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x57, 0x72, 0x69, 0x74,
+0x65, 0x45, 0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20,
+0x42, 0x46, 0x63, 0x74, 0x72, 0x6C, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x52, 0x65, 0x63, 0x45,
+0x6E, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x42, 0x46,
+0x63, 0x74, 0x72, 0x6C, 0x3A, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x6E, 0x64, 0x44,
+0x20, 0x4D, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x52,
+0x3A, 0x25, 0x62, 0x78, 0x20, 0x52, 0x25, 0x62,
+0x78, 0x20, 0x43, 0x74, 0x3A, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x41, 0x70, 0x70, 0x6C,
+0x56, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x4E, 0x61, 0x70, 0x70, 0x6C, 0x56, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x43, 0x68, 0x54, 0x78,
+0x42, 0x46, 0x73, 0x74, 0x73, 0x20, 0x4D, 0x3A,
+0x25, 0x62, 0x78, 0x20, 0x45, 0x6E, 0x74, 0x3A,
+0x25, 0x62, 0x78, 0x20, 0x52, 0x61, 0x3A, 0x25,
+0x62, 0x78, 0x20, 0x4E, 0x63, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x45, 0x72, 0x72, 0x4E,
+0x63, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x43, 0x6F, 0x72, 0x72, 0x4E, 0x63, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x53, 0x6E, 0x64, 0x44,
+0x6F, 0x6E, 0x53, 0x75, 0x00, 0x00, 0x00, 0x00,
+0x53, 0x6E, 0x64, 0x44, 0x6F, 0x6E, 0x46, 0x61,
+0x00, 0x00, 0x00, 0x00, 0x53, 0x65, 0x61, 0x72,
+0x63, 0x68, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x25,
+0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x42, 0x47, 0x20, 0x3A, 0x25, 0x62, 0x78, 0x20,
+0x2C, 0x20, 0x6E, 0x75, 0x6D, 0x74, 0x72, 0x79,
+0x3A, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x53, 0x54, 0x42, 0x43, 0x20, 0x6F, 0x6E, 0x00,
+0x53, 0x74, 0x61, 0x74, 0x65, 0x20, 0x25, 0x62,
+0x58, 0x20, 0x00, 0x00, 0x72, 0x61, 0x74, 0x65,
+0x3A, 0x20, 0x25, 0x62, 0x58, 0x00, 0x00, 0x00,
+0x49, 0x44, 0x3A, 0x25, 0x62, 0x58, 0x00, 0x00,
+0x52, 0x5B, 0x30, 0x3A, 0x34, 0x5D, 0x20, 0x25,
+0x62, 0x58, 0x20, 0x2C, 0x20, 0x25, 0x62, 0x58,
+0x2C, 0x20, 0x25, 0x62, 0x58, 0x2C, 0x20, 0x25,
+0x62, 0x58, 0x2C, 0x20, 0x25, 0x62, 0x58, 0x20,
+0x00, 0x00, 0x00, 0x00, 0x55, 0x3A, 0x20, 0x25,
+0x62, 0x58, 0x20, 0x00, 0x54, 0x47, 0x3A, 0x20,
+0x25, 0x62, 0x58, 0x20, 0x00, 0x00, 0x00, 0x00,
+0x54, 0x47, 0x70, 0x61, 0x74, 0x68, 0x3A, 0x20,
+0x25, 0x62, 0x58, 0x20, 0x00, 0x00, 0x00, 0x00,
+0x53, 0x65, 0x74, 0x50, 0x61, 0x74, 0x68, 0x3A,
+0x20, 0x25, 0x62, 0x58, 0x20, 0x00, 0x00, 0x00,
+0x44, 0x54, 0x50, 0x5F, 0x65, 0x6E, 0x64, 0x00,
+0x53, 0x65, 0x74, 0x52, 0x5F, 0x4E, 0x54, 0x3A,
+0x25, 0x62, 0x58, 0x20, 0x25, 0x62, 0x78, 0x20,
+0x25, 0x62, 0x78, 0x00, 0x54, 0x72, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x53, 0x65, 0x74, 0x52,
+0x5F, 0x54, 0x3A, 0x25, 0x62, 0x58, 0x20, 0x25,
+0x62, 0x58, 0x20, 0x25, 0x62, 0x78, 0x20, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x4D, 0x55, 0x53, 0x74,
+0x61, 0x72, 0x74, 0x20, 0x4D, 0x25, 0x62, 0x78,
+0x52, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x61, 0x55, 0x70, 0x00, 0x00, 0x00, 0x00,
+0x31, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x30, 0x55, 0x70, 0x64, 0x74, 0x5F, 0x42, 0x57,
+0x3D, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x32, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x33, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x34, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x35, 0x72, 0x61, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x52, 0x61, 0x44, 0x6E, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x64, 0x53, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78, 0x00,
+0x46, 0x57, 0x44, 0x62, 0x67, 0x00, 0x00, 0x00,
+0x46, 0x57, 0x46, 0x69, 0x78, 0x00, 0x00, 0x00,
+0x50, 0x43, 0x52, 0x3A, 0x20, 0x4D, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x62, 0x54, 0x52, 0x59,
+0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x54, 0x72, 0x44, 0x6F, 0x6E, 0x43, 0x6E, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x45, 0x72, 0x72, 0x6F,
+0x72, 0x31, 0x00, 0x00, 0x50, 0x6B, 0x74, 0x3A,
+0x25, 0x58, 0x2C, 0x25, 0x58, 0x2C, 0x25, 0x58,
+0x00, 0x00, 0x00, 0x00, 0x46, 0x44, 0x3A, 0x20,
+0x52, 0x44, 0x00, 0x00, 0x46, 0x44, 0x3A, 0x20,
+0x44, 0x72, 0x6F, 0x70, 0x2C, 0x20, 0x52, 0x61,
+0x74, 0x65, 0x53, 0x74, 0x61, 0x79, 0x00, 0x00,
+0x46, 0x44, 0x3A, 0x20, 0x52, 0x55, 0x00, 0x00,
+0x4D, 0x25, 0x62, 0x78, 0x20, 0x52, 0x25, 0x62,
+0x78, 0x20, 0x53, 0x50, 0x25, 0x77, 0x78, 0x20,
+0x52, 0x50, 0x25, 0x77, 0x78, 0x20, 0x54, 0x50,
+0x25, 0x77, 0x78, 0x20, 0x52, 0x52, 0x25, 0x62,
+0x78, 0x20, 0x53, 0x52, 0x25, 0x62, 0x78, 0x00,
+0x52, 0x61, 0x74, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x52, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x52, 0x34,
+0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x61, 0x74, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x20, 0x52, 0x3A, 0x25, 0x62, 0x78, 0x20, 0x52,
+0x34, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x44, 0x72, 0x6F, 0x70, 0x50, 0x6B, 0x74, 0x3A,
+0x25, 0x62, 0x78, 0x00, 0x3D, 0x3E, 0x64, 0x72,
+0x6F, 0x70, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x3D, 0x3E, 0x53, 0x5F, 0x52, 0x41, 0x3A, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x3D, 0x3E, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62,
+0x78, 0x2C, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x72, 0x74, 0x79, 0x6D, 0x61, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x20, 0x72, 0x74, 0x79, 0x72, 0x61,
+0x74, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x64,
+0x69, 0x66, 0x66, 0x3A, 0x25, 0x62, 0x78, 0x2C,
+0x20, 0x75, 0x70, 0x64, 0x6E, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x72, 0x74, 0x79, 0x6D,
+0x61, 0x5F, 0x72, 0x61, 0x74, 0x65, 0x3A, 0x25,
+0x62, 0x78, 0x2C, 0x72, 0x74, 0x79, 0x5F, 0x76,
+0x61, 0x72, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x62, 0x76, 0x61, 0x72, 0x3A, 0x25, 0x62, 0x78,
+0x2C, 0x20, 0x76, 0x61, 0x72, 0x3A, 0x25, 0x62,
+0x78, 0x00, 0x00, 0x00, 0x44, 0x65, 0x4F, 0x46,
+0x46, 0x3A, 0x25, 0x62, 0x78, 0x2C, 0x20, 0x25,
+0x62, 0x58, 0x2C, 0x20, 0x25, 0x62, 0x78, 0x00,
+0x4D, 0x6F, 0x64, 0x54, 0x48, 0x3A, 0x20, 0x55,
+0x70, 0x54, 0x48, 0x25, 0x62, 0x78, 0x2C, 0x20,
+0x44, 0x6E, 0x54, 0x48, 0x25, 0x62, 0x78, 0x00,
+0x44, 0x72, 0x76, 0x4F, 0x66, 0x66, 0x73, 0x65,
+0x74, 0x3A, 0x20, 0x53, 0x68, 0x25, 0x62, 0x78,
+0x2C, 0x20, 0x55, 0x70, 0x54, 0x48, 0x25, 0x62,
+0x78, 0x2C, 0x20, 0x44, 0x6E, 0x54, 0x48, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x4D, 0x52, 0x61, 0x74,
+0x65, 0x20, 0x3D, 0x20, 0x25, 0x62, 0x78, 0x00,
+0x42, 0x57, 0x25, 0x62, 0x78, 0x20, 0x52, 0x74,
+0x25, 0x62, 0x78, 0x00, 0x52, 0x44, 0x31, 0x00,
+0x55, 0x70, 0x3A, 0x25, 0x62, 0x58, 0x2C, 0x44,
+0x6E, 0x3A, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x52, 0x44, 0x32, 0x00, 0x52, 0x55, 0x20, 0x25,
+0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x20, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x52, 0x55, 0x5F, 0x53,
+0x00, 0x00, 0x00, 0x00, 0x52, 0x53, 0x00, 0x00,
+0x52, 0x53, 0x54, 0x54, 0x78, 0x52, 0x50, 0x54,
+0x00, 0x00, 0x00, 0x00, 0x44, 0x6E, 0x54, 0x72,
+0x79, 0x52, 0x3D, 0x25, 0x62, 0x58, 0x2C, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x54, 0x72, 0x79, 0x53,
+0x75, 0x3A, 0x25, 0x62, 0x58, 0x00, 0x00, 0x00,
+0x55, 0x70, 0x54, 0x72, 0x79, 0x53, 0x25, 0x62,
+0x78, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x44, 0x6E, 0x54, 0x72, 0x79, 0x53, 0x25, 0x62,
+0x78, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x55, 0x70, 0x54, 0x72, 0x79, 0x46, 0x25, 0x62,
+0x78, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x44, 0x6E, 0x54, 0x72, 0x79, 0x46, 0x25, 0x62,
+0x78, 0x20, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00,
+0x54, 0x72, 0x79, 0x46, 0x50, 0x25, 0x62, 0x78,
+0x20, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x50, 0x65, 0x6E, 0x64, 0x3A, 0x25, 0x77, 0x58,
+0x20, 0x00, 0x00, 0x00, 0x54, 0x72, 0x79, 0x46,
+0x3A, 0x25, 0x62, 0x58, 0x20, 0x00, 0x00, 0x00,
+0x52, 0x53, 0x53, 0x49, 0x3A, 0x25, 0x62, 0x78,
+0x2C, 0x4D, 0x25, 0x62, 0x78, 0x2C, 0x52, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x41, 0x52, 0x46, 0x52,
+0x43, 0x4D, 0x44, 0x3A, 0x25, 0x62, 0x58, 0x20,
+0x25, 0x62, 0x78, 0x20, 0x25, 0x62, 0x78, 0x00,
+0x4D, 0x55, 0x52, 0x41, 0x3A, 0x20, 0x4E, 0x6F,
+0x20, 0x45, 0x6E, 0x74, 0x72, 0x79, 0x00, 0x00,
+0x4D, 0x55, 0x41, 0x52, 0x46, 0x52, 0x3A, 0x20,
+0x4E, 0x6F, 0x20, 0x45, 0x6E, 0x74, 0x72, 0x79,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x55, 0x52, 0x41,
+0x3A, 0x20, 0x45, 0x6E, 0x74, 0x72, 0x79, 0x20,
+0x3D, 0x20, 0x25, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x4D, 0x49, 0x44, 0x3A, 0x25, 0x62, 0x58, 0x20,
+0x52, 0x49, 0x44, 0x3A, 0x25, 0x62, 0x58, 0x20,
+0x42, 0x57, 0x3A, 0x25, 0x62, 0x58, 0x20, 0x53,
+0x3A, 0x25, 0x62, 0x58, 0x2C, 0x20, 0x56, 0x45,
+0x3A, 0x25, 0x62, 0x58, 0x00, 0x00, 0x00, 0x00,
+0x49, 0x6C, 0x69, 0x4D, 0x55, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x67, 0x69, 0x64, 0x3A,
+0x25, 0x62, 0x78, 0x2C, 0x20, 0x75, 0x3A, 0x25,
+0x62, 0x78, 0x2C, 0x20, 0x74, 0x3A, 0x25, 0x62,
+0x78, 0x2C, 0x20, 0x6F, 0x3A, 0x25, 0x62, 0x78,
+0x2C, 0x20, 0x64, 0x3A, 0x25, 0x62, 0x78, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x50, 0x6F, 0x6C, 0x6C,
+0x75, 0x74, 0x65, 0x64, 0x00, 0x00, 0x00, 0x00,
+0x4D, 0x69, 0x64, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x4D, 0x25, 0x62, 0x78, 0x20, 0x47, 0x25, 0x62,
+0x78, 0x20, 0x54, 0x74, 0x25, 0x62, 0x78, 0x20,
+0x4F, 0x6B, 0x25, 0x62, 0x78, 0x20, 0x72, 0x74,
+0x25, 0x62, 0x78, 0x20, 0x62, 0x54, 0x25, 0x62,
+0x78, 0x20, 0x4D, 0x32, 0x53, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x49, 0x72, 0x61, 0x3A,
+0x25, 0x62, 0x78, 0x2C, 0x46, 0x72, 0x61, 0x3A,
+0x25, 0x62, 0x78, 0x00, 0x4D, 0x25, 0x62, 0x78,
+0x20, 0x47, 0x25, 0x62, 0x78, 0x20, 0x52, 0x25,
+0x62, 0x78, 0x20, 0x46, 0x52, 0x25, 0x62, 0x78,
+0x20, 0x72, 0x74, 0x25, 0x62, 0x78, 0x20, 0x62,
+0x54, 0x25, 0x62, 0x78, 0x00, 0x00, 0x00, 0x00,
+0x52, 0x25, 0x62, 0x78, 0x20, 0x44, 0x25, 0x62,
+0x78, 0x20, 0x54, 0x74, 0x25, 0x62, 0x78, 0x20,
+0x4D, 0x32, 0x53, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x54, 0x52, 0x59, 0x25, 0x62, 0x78, 0x2C, 0x25,
+0x62, 0x78, 0x00, 0x00, 0x54, 0x52, 0x5F, 0x53,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x54, 0x52, 0x5F, 0x46,
+0x3A, 0x25, 0x62, 0x78, 0x2C, 0x25, 0x62, 0x78,
+0x00, 0x00, 0x00, 0x00, 0x4D, 0x20, 0x4D, 0x25,
+0x62, 0x78, 0x20, 0x72, 0x74, 0x25, 0x62, 0x78,
+0x20, 0x4F, 0x25, 0x62, 0x78, 0x20, 0x54, 0x25,
+0x62, 0x78, 0x20, 0x44, 0x25, 0x62, 0x78, 0x00,
+0x52, 0x30, 0x20, 0x25, 0x77, 0x78, 0x20, 0x54,
+0x54, 0x20, 0x25, 0x77, 0x78, 0x00, 0x00, 0x00,
+0x52, 0x74, 0x20, 0x25, 0x77, 0x78, 0x2C, 0x54,
+0x6F, 0x74, 0x41, 0x25, 0x77, 0x78, 0x00, 0x00,
+0x53, 0x20, 0x4D, 0x25, 0x62, 0x78, 0x20, 0x72,
+0x74, 0x25, 0x62, 0x78, 0x20, 0x4F, 0x25, 0x62,
+0x78, 0x20, 0x44, 0x25, 0x62, 0x78, 0x00, 0x00,
+0x52, 0x72, 0x20, 0x25, 0x77, 0x78, 0x20, 0x54,
+0x54, 0x20, 0x25, 0x77, 0x78, 0x00, 0x00, 0x00,
+0x25, 0x73, 0x3A, 0x20, 0x50, 0x72, 0x65, 0x20,
+0x73, 0x65, 0x74, 0x74, 0x69, 0x6E, 0x67, 0x3A,
+0x20, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6C, 0x65,
+0x20, 0x4F, 0x46, 0x44, 0x4D, 0x20, 0x61, 0x6E,
+0x64, 0x20, 0x43, 0x43, 0x4B, 0x20, 0x62, 0x6C,
+0x6F, 0x63, 0x6B, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x25, 0x73, 0x3A, 0x20, 0x50, 0x6F, 0x73, 0x74,
+0x20, 0x73, 0x65, 0x74, 0x74, 0x69, 0x6E, 0x67,
+0x3A, 0x20, 0x65, 0x6E, 0x61, 0x62, 0x6C, 0x65,
+0x20, 0x4F, 0x46, 0x44, 0x4D, 0x20, 0x61, 0x6E,
+0x64, 0x20, 0x43, 0x43, 0x4B, 0x20, 0x62, 0x6C,
+0x6F, 0x63, 0x6B, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x25, 0x73, 0x3A, 0x20, 0x57, 0x72, 0x6F, 0x6E,
+0x67, 0x20, 0x74, 0x79, 0x70, 0x65, 0x21, 0x21,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x77, 0x72, 0x69, 0x74, 0x65, 0x5F, 0x74,
+0x78, 0x61, 0x67, 0x63, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x64, 0x69,
+0x73, 0x61, 0x62, 0x6C, 0x65, 0x20, 0x50, 0x48,
+0x59, 0x20, 0x41, 0x50, 0x49, 0x20, 0x66, 0x6F,
+0x72, 0x20, 0x64, 0x65, 0x62, 0x75, 0x67, 0x21,
+0x21, 0x0A, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x77, 0x72, 0x69, 0x74, 0x65, 0x5F, 0x74,
+0x78, 0x61, 0x67, 0x63, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x75, 0x6E,
+0x73, 0x75, 0x70, 0x70, 0x6F, 0x72, 0x74, 0x65,
+0x64, 0x20, 0x70, 0x61, 0x74, 0x68, 0x20, 0x28,
+0x25, 0x64, 0x29, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x77, 0x72, 0x69,
+0x74, 0x65, 0x5F, 0x74, 0x78, 0x61, 0x67, 0x63,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x70, 0x61, 0x74, 0x68, 0x2D, 0x25,
+0x64, 0x20, 0x72, 0x61, 0x74, 0x65, 0x20, 0x69,
+0x6E, 0x64, 0x65, 0x78, 0x20, 0x30, 0x78, 0x25,
+0x78, 0x20, 0x28, 0x30, 0x78, 0x25, 0x78, 0x29,
+0x20, 0x3D, 0x20, 0x30, 0x78, 0x25, 0x78, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x5B, 0x38, 0x38, 0x32,
+0x32, 0x42, 0x5D, 0x20, 0x55, 0x70, 0x64, 0x61,
+0x74, 0x65, 0x20, 0x52, 0x46, 0x45, 0x20, 0x50,
+0x49, 0x4E, 0x73, 0x3A, 0x20, 0x43, 0x48, 0x3A,
+0x25, 0x64, 0x2C, 0x20, 0x54, 0x2F, 0x52, 0x58,
+0x5F, 0x70, 0x61, 0x74, 0x68, 0x3A, 0x7B, 0x20,
+0x30, 0x78, 0x25, 0x78, 0x2C, 0x20, 0x30, 0x78,
+0x25, 0x78, 0x7D, 0x2C, 0x20, 0x63, 0x75, 0x74,
+0x5F, 0x76, 0x65, 0x72, 0x3A, 0x25, 0x64, 0x2C,
+0x20, 0x72, 0x66, 0x65, 0x5F, 0x74, 0x79, 0x70,
+0x65, 0x3A, 0x25, 0x64, 0x0A, 0x00, 0x00, 0x00,
+0x38, 0x38, 0x32, 0x32, 0x42, 0x20, 0x52, 0x46,
+0x45, 0x5F, 0x49, 0x6E, 0x69, 0x74, 0x2C, 0x20,
+0x52, 0x46, 0x45, 0x5F, 0x74, 0x79, 0x70, 0x65,
+0x3D, 0x28, 0x28, 0x25, 0x64, 0x29, 0x29, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x38, 0x38, 0x32, 0x32,
+0x42, 0x20, 0x52, 0x46, 0x45, 0x5B, 0x25, 0x64,
+0x5D, 0x3A, 0x7B, 0x50, 0x61, 0x74, 0x68, 0x3D,
+0x30, 0x78, 0x25, 0x78, 0x7D, 0x7B, 0x69, 0x6E,
+0x76, 0x5F, 0x65, 0x6E, 0x3D, 0x25, 0x64, 0x7D,
+0x7B, 0x73, 0x6F, 0x75, 0x72, 0x63, 0x65, 0x3D,
+0x30, 0x78, 0x25, 0x78, 0x7D, 0x0A, 0x00, 0x00,
+0x5B, 0x57, 0x61, 0x72, 0x6E, 0x69, 0x6E, 0x67,
+0x5D, 0x20, 0x57, 0x72, 0x6F, 0x6E, 0x67, 0x20,
+0x52, 0x46, 0x45, 0x20, 0x6E, 0x75, 0x6D, 0x3D,
+0x25, 0x64, 0x7D, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x72, 0x65, 0x61,
+0x64, 0x5F, 0x72, 0x66, 0x5F, 0x72, 0x65, 0x67,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3A, 0x20, 0x75, 0x6E, 0x73, 0x75, 0x70, 0x70,
+0x6F, 0x72, 0x74, 0x65, 0x64, 0x20, 0x70, 0x61,
+0x74, 0x68, 0x20, 0x28, 0x25, 0x64, 0x29, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x72, 0x65, 0x61, 0x64, 0x5F, 0x72, 0x66,
+0x5F, 0x72, 0x65, 0x67, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x52, 0x46,
+0x2D, 0x25, 0x64, 0x20, 0x30, 0x78, 0x25, 0x78,
+0x20, 0x3D, 0x20, 0x30, 0x78, 0x25, 0x78, 0x2C,
+0x20, 0x62, 0x69, 0x74, 0x20, 0x6D, 0x61, 0x73,
+0x6B, 0x20, 0x3D, 0x20, 0x30, 0x78, 0x25, 0x78,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x77, 0x72, 0x69, 0x74, 0x65, 0x5F, 0x72,
+0x66, 0x5F, 0x72, 0x65, 0x67, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x75,
+0x6E, 0x73, 0x75, 0x70, 0x70, 0x6F, 0x72, 0x74,
+0x65, 0x64, 0x20, 0x70, 0x61, 0x74, 0x68, 0x20,
+0x28, 0x25, 0x64, 0x29, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x77, 0x72, 0x69,
+0x74, 0x65, 0x5F, 0x72, 0x66, 0x5F, 0x72, 0x65,
+0x67, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x57, 0x72, 0x69, 0x74, 0x65,
+0x20, 0x66, 0x61, 0x69, 0x6C, 0x2C, 0x20, 0x52,
+0x46, 0x20, 0x69, 0x73, 0x20, 0x64, 0x69, 0x73,
+0x61, 0x62, 0x6C, 0x65, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x77, 0x72, 0x69,
+0x74, 0x65, 0x5F, 0x72, 0x66, 0x5F, 0x72, 0x65,
+0x67, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x52, 0x46, 0x2D, 0x25, 0x64,
+0x20, 0x30, 0x78, 0x25, 0x78, 0x20, 0x3D, 0x20,
+0x30, 0x78, 0x25, 0x78, 0x20, 0x28, 0x6F, 0x72,
+0x69, 0x67, 0x69, 0x6E, 0x61, 0x6C, 0x3A, 0x20,
+0x30, 0x78, 0x25, 0x78, 0x29, 0x2C, 0x20, 0x62,
+0x69, 0x74, 0x20, 0x6D, 0x61, 0x73, 0x6B, 0x20,
+0x3D, 0x20, 0x30, 0x78, 0x25, 0x78, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3E, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x64, 0x69,
+0x73, 0x61, 0x62, 0x6C, 0x65, 0x20, 0x50, 0x48,
+0x59, 0x20, 0x41, 0x50, 0x49, 0x20, 0x66, 0x6F,
+0x72, 0x20, 0x64, 0x65, 0x62, 0x75, 0x67, 0x21,
+0x21, 0x0A, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x46, 0x61,
+0x69, 0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77,
+0x69, 0x74, 0x63, 0x68, 0x20, 0x62, 0x61, 0x6E,
+0x64, 0x20, 0x28, 0x63, 0x68, 0x3A, 0x20, 0x25,
+0x64, 0x29, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x46, 0x61,
+0x69, 0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77,
+0x69, 0x74, 0x63, 0x68, 0x20, 0x62, 0x61, 0x6E,
+0x64, 0x20, 0x28, 0x63, 0x68, 0x3A, 0x20, 0x25,
+0x64, 0x29, 0x2C, 0x20, 0x62, 0x65, 0x63, 0x61,
+0x75, 0x73, 0x65, 0x20, 0x77, 0x72, 0x69, 0x74,
+0x69, 0x6E, 0x67, 0x20, 0x52, 0x46, 0x20, 0x72,
+0x65, 0x67, 0x69, 0x73, 0x74, 0x65, 0x72, 0x20,
+0x69, 0x73, 0x20, 0x66, 0x61, 0x69, 0x6C, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x5F, 0x38, 0x38, 0x32,
+0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x53, 0x75,
+0x63, 0x63, 0x65, 0x73, 0x73, 0x20, 0x74, 0x6F,
+0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x20,
+0x62, 0x61, 0x6E, 0x64, 0x20, 0x28, 0x63, 0x68,
+0x3A, 0x20, 0x25, 0x64, 0x29, 0x0A, 0x00, 0x00,
+0x25, 0x73, 0x3A, 0x20, 0x55, 0x70, 0x64, 0x61,
+0x74, 0x65, 0x20, 0x43, 0x43, 0x41, 0x20, 0x70,
+0x61, 0x72, 0x61, 0x6D, 0x65, 0x74, 0x65, 0x72,
+0x73, 0x20, 0x66, 0x6F, 0x72, 0x20, 0x43, 0x63,
+0x75, 0x74, 0x0A, 0x00, 0x25, 0x73, 0x3A, 0x20,
+0x28, 0x50, 0x6B, 0x74, 0x25, 0x64, 0x2C, 0x20,
+0x49, 0x6E, 0x74, 0x66, 0x25, 0x64, 0x2C, 0x20,
+0x52, 0x46, 0x45, 0x25, 0x64, 0x29, 0x2C, 0x20,
+0x63, 0x6F, 0x6C, 0x20, 0x3D, 0x20, 0x25, 0x64,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3E, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x64, 0x69, 0x73, 0x61, 0x62,
+0x6C, 0x65, 0x20, 0x50, 0x48, 0x59, 0x20, 0x41,
+0x50, 0x49, 0x20, 0x66, 0x6F, 0x72, 0x20, 0x64,
+0x65, 0x62, 0x75, 0x67, 0x21, 0x21, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x57,
+0x72, 0x6F, 0x6E, 0x67, 0x20, 0x54, 0x58, 0x20,
+0x73, 0x65, 0x74, 0x74, 0x69, 0x6E, 0x67, 0x20,
+0x28, 0x54, 0x58, 0x3A, 0x20, 0x30, 0x78, 0x25,
+0x78, 0x29, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x57, 0x72, 0x6F, 0x6E, 0x67,
+0x20, 0x52, 0x58, 0x20, 0x73, 0x65, 0x74, 0x74,
+0x69, 0x6E, 0x67, 0x20, 0x28, 0x52, 0x58, 0x3A,
+0x20, 0x30, 0x78, 0x25, 0x78, 0x29, 0x0A, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x74, 0x72, 0x78,
+0x5F, 0x6D, 0x6F, 0x64, 0x65, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x46,
+0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73,
+0x65, 0x74, 0x20, 0x54, 0x52, 0x78, 0x20, 0x6D,
+0x6F, 0x64, 0x65, 0x20, 0x73, 0x65, 0x74, 0x74,
+0x69, 0x6E, 0x67, 0x2C, 0x20, 0x62, 0x65, 0x63,
+0x61, 0x75, 0x73, 0x65, 0x20, 0x77, 0x72, 0x69,
+0x74, 0x69, 0x6E, 0x67, 0x20, 0x52, 0x46, 0x20,
+0x6D, 0x6F, 0x64, 0x65, 0x20, 0x74, 0x61, 0x62,
+0x6C, 0x65, 0x20, 0x69, 0x73, 0x20, 0x66, 0x61,
+0x69, 0x6C, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x4D, 0x50, 0x20, 0x6D, 0x6F,
+0x64, 0x65, 0x20, 0x6F, 0x72, 0x20, 0x41, 0x6E,
+0x74, 0x65, 0x6E, 0x6E, 0x61, 0x20, 0x74, 0x65,
+0x73, 0x74, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x21,
+0x21, 0x20, 0x73, 0x75, 0x70, 0x70, 0x6F, 0x72,
+0x74, 0x20, 0x70, 0x61, 0x74, 0x68, 0x2D, 0x42,
+0x20, 0x54, 0x58, 0x20, 0x61, 0x6E, 0x64, 0x20,
+0x52, 0x58, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x4E, 0x6F, 0x72, 0x6D, 0x61,
+0x6C, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x21, 0x21,
+0x20, 0x44, 0x6F, 0x20, 0x6E, 0x6F, 0x74, 0x20,
+0x73, 0x75, 0x70, 0x70, 0x6F, 0x72, 0x74, 0x20,
+0x70, 0x61, 0x74, 0x68, 0x2D, 0x42, 0x20, 0x54,
+0x58, 0x20, 0x61, 0x6E, 0x64, 0x20, 0x52, 0x58,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x46, 0x61, 0x69, 0x6C, 0x20,
+0x74, 0x6F, 0x20, 0x73, 0x65, 0x74, 0x20, 0x54,
+0x52, 0x78, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x20,
+0x73, 0x65, 0x74, 0x74, 0x69, 0x6E, 0x67, 0x20,
+0x28, 0x54, 0x58, 0x3A, 0x20, 0x30, 0x78, 0x25,
+0x78, 0x2C, 0x20, 0x52, 0x58, 0x3A, 0x20, 0x30,
+0x78, 0x25, 0x78, 0x29, 0x2C, 0x20, 0x62, 0x65,
+0x63, 0x61, 0x75, 0x73, 0x65, 0x20, 0x77, 0x72,
+0x69, 0x74, 0x69, 0x6E, 0x67, 0x20, 0x52, 0x46,
+0x20, 0x72, 0x65, 0x67, 0x69, 0x73, 0x74, 0x65,
+0x72, 0x20, 0x69, 0x73, 0x20, 0x66, 0x61, 0x69,
+0x6C, 0x0A, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x74, 0x72, 0x78, 0x5F, 0x6D, 0x6F, 0x64,
+0x65, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x53, 0x75, 0x63, 0x63, 0x65,
+0x73, 0x73, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x65,
+0x74, 0x20, 0x54, 0x52, 0x78, 0x20, 0x6D, 0x6F,
+0x64, 0x65, 0x20, 0x73, 0x65, 0x74, 0x74, 0x69,
+0x6E, 0x67, 0x20, 0x28, 0x54, 0x58, 0x3A, 0x20,
+0x30, 0x78, 0x25, 0x78, 0x2C, 0x20, 0x52, 0x58,
+0x3A, 0x20, 0x30, 0x78, 0x25, 0x78, 0x29, 0x0A,
+0x00, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x77, 0x69, 0x64, 0x74,
+0x68, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3E, 0x0A, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x77, 0x69, 0x64, 0x74, 0x68, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x64,
+0x69, 0x73, 0x61, 0x62, 0x6C, 0x65, 0x20, 0x50,
+0x48, 0x59, 0x20, 0x41, 0x50, 0x49, 0x20, 0x66,
+0x6F, 0x72, 0x20, 0x64, 0x65, 0x62, 0x75, 0x67,
+0x21, 0x21, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x62, 0x61, 0x6E, 0x64, 0x77, 0x69, 0x64, 0x74,
+0x68, 0x5F, 0x38, 0x38, 0x32, 0x32, 0x62, 0x28,
+0x29, 0x3A, 0x20, 0x46, 0x61, 0x69, 0x6C, 0x20,
+0x74, 0x6F, 0x20, 0x73, 0x77, 0x69, 0x74, 0x63,
+0x68, 0x20, 0x62, 0x61, 0x6E, 0x64, 0x77, 0x69,
+0x64, 0x74, 0x68, 0x20, 0x28, 0x62, 0x77, 0x3A,
+0x20, 0x25, 0x64, 0x2C, 0x20, 0x70, 0x72, 0x69,
+0x6D, 0x61, 0x72, 0x79, 0x20, 0x63, 0x68, 0x3A,
+0x20, 0x25, 0x64, 0x29, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x77, 0x69, 0x64, 0x74, 0x68, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x46,
+0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73,
+0x77, 0x69, 0x74, 0x63, 0x68, 0x20, 0x62, 0x61,
+0x6E, 0x64, 0x77, 0x69, 0x64, 0x74, 0x68, 0x20,
+0x28, 0x62, 0x77, 0x3A, 0x20, 0x25, 0x64, 0x2C,
+0x20, 0x70, 0x72, 0x69, 0x6D, 0x61, 0x72, 0x79,
+0x20, 0x63, 0x68, 0x3A, 0x20, 0x25, 0x64, 0x29,
+0x2C, 0x20, 0x62, 0x65, 0x63, 0x61, 0x75, 0x73,
+0x65, 0x20, 0x77, 0x72, 0x69, 0x74, 0x69, 0x6E,
+0x67, 0x20, 0x52, 0x46, 0x20, 0x72, 0x65, 0x67,
+0x69, 0x73, 0x74, 0x65, 0x72, 0x20, 0x69, 0x73,
+0x20, 0x66, 0x61, 0x69, 0x6C, 0x0A, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x62, 0x61, 0x6E, 0x64,
+0x77, 0x69, 0x64, 0x74, 0x68, 0x5F, 0x38, 0x38,
+0x32, 0x32, 0x62, 0x28, 0x29, 0x3A, 0x20, 0x53,
+0x75, 0x63, 0x63, 0x65, 0x73, 0x73, 0x20, 0x74,
+0x6F, 0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68,
+0x20, 0x62, 0x61, 0x6E, 0x64, 0x77, 0x69, 0x64,
+0x74, 0x68, 0x20, 0x28, 0x62, 0x77, 0x3A, 0x20,
+0x25, 0x64, 0x2C, 0x20, 0x70, 0x72, 0x69, 0x6D,
+0x61, 0x72, 0x79, 0x20, 0x63, 0x68, 0x3A, 0x20,
+0x25, 0x64, 0x29, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D,
+0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3D, 0x3E,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3A,
+0x20, 0x64, 0x69, 0x73, 0x61, 0x62, 0x6C, 0x65,
+0x20, 0x50, 0x48, 0x59, 0x20, 0x41, 0x50, 0x49,
+0x20, 0x66, 0x6F, 0x72, 0x20, 0x64, 0x65, 0x62,
+0x75, 0x67, 0x21, 0x21, 0x0A, 0x00, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3A, 0x20, 0x46, 0x61, 0x69,
+0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x20, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x20, 0x28, 0x41, 0x47, 0x43,
+0x29, 0x20, 0x28, 0x63, 0x68, 0x3A, 0x20, 0x25,
+0x64, 0x29, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3A,
+0x20, 0x46, 0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F,
+0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x20,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x20,
+0x28, 0x66, 0x63, 0x5F, 0x61, 0x72, 0x65, 0x61,
+0x29, 0x20, 0x28, 0x63, 0x68, 0x3A, 0x20, 0x25,
+0x64, 0x29, 0x0A, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3A,
+0x20, 0x46, 0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F,
+0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x20,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x20,
+0x28, 0x63, 0x68, 0x3A, 0x20, 0x25, 0x64, 0x29,
+0x0A, 0x00, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3A,
+0x20, 0x46, 0x61, 0x69, 0x6C, 0x20, 0x74, 0x6F,
+0x20, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x20,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x20,
+0x28, 0x63, 0x68, 0x3A, 0x20, 0x25, 0x64, 0x2C,
+0x20, 0x50, 0x68, 0x61, 0x73, 0x65, 0x20, 0x6E,
+0x6F, 0x69, 0x73, 0x65, 0x29, 0x0A, 0x00, 0x00,
+0x63, 0x6F, 0x6E, 0x66, 0x69, 0x67, 0x5F, 0x70,
+0x68, 0x79, 0x64, 0x6D, 0x5F, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x5F, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x5F, 0x38, 0x38, 0x32, 0x32,
+0x62, 0x28, 0x29, 0x3A, 0x20, 0x46, 0x61, 0x69,
+0x6C, 0x20, 0x74, 0x6F, 0x20, 0x73, 0x77, 0x69,
+0x74, 0x63, 0x68, 0x20, 0x63, 0x68, 0x61, 0x6E,
+0x6E, 0x65, 0x6C, 0x20, 0x28, 0x63, 0x68, 0x3A,
+0x20, 0x25, 0x64, 0x29, 0x2C, 0x20, 0x62, 0x65,
+0x63, 0x61, 0x75, 0x73, 0x65, 0x20, 0x77, 0x72,
+0x69, 0x74, 0x69, 0x6E, 0x67, 0x20, 0x52, 0x46,
+0x20, 0x72, 0x65, 0x67, 0x69, 0x73, 0x74, 0x65,
+0x72, 0x20, 0x69, 0x73, 0x20, 0x66, 0x61, 0x69,
+0x6C, 0x0A, 0x00, 0x00, 0x63, 0x6F, 0x6E, 0x66,
+0x69, 0x67, 0x5F, 0x70, 0x68, 0x79, 0x64, 0x6D,
+0x5F, 0x73, 0x77, 0x69, 0x74, 0x63, 0x68, 0x5F,
+0x63, 0x68, 0x61, 0x6E, 0x6E, 0x65, 0x6C, 0x5F,
+0x38, 0x38, 0x32, 0x32, 0x62, 0x28, 0x29, 0x3A,
+0x20, 0x53, 0x75, 0x63, 0x63, 0x65, 0x73, 0x73,
+0x20, 0x74, 0x6F, 0x20, 0x73, 0x77, 0x69, 0x74,
+0x63, 0x68, 0x20, 0x63, 0x68, 0x61, 0x6E, 0x6E,
+0x65, 0x6C, 0x20, 0x28, 0x63, 0x68, 0x3A, 0x20,
+0x25, 0x64, 0x29, 0x0A, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x04, 0x04, 0x08, 0x08, 0x08, 0x08,
+0x0C, 0x0C, 0x0C, 0x0C, 0x0C, 0x0C, 0x0C, 0x0C,
+0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10,
+0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x00, 0x00, 0x00, 0x00, 0x06, 0x09, 0x0C, 0x12,
+0x18, 0x24, 0x30, 0x36, 0x01, 0x02, 0x05, 0x0B,
+0x00, 0x00, 0x00, 0x00, 0x0A, 0x08, 0x03, 0x03,
+0x00, 0x04, 0x09, 0x07, 0x03, 0x03, 0x00, 0x04,
+0x08, 0x06, 0x03, 0x02, 0x00, 0x04, 0x08, 0x05,
+0x03, 0x01, 0x00, 0x04, 0x0D, 0x0A, 0x07, 0x05,
+0x00, 0x08, 0x0C, 0x0A, 0x07, 0x04, 0x00, 0x08,
+0x0B, 0x0A, 0x06, 0x05, 0x00, 0x08, 0x0B, 0x0A,
+0x05, 0x03, 0x00, 0x08, 0x0B, 0x0A, 0x03, 0x02,
+0x00, 0x08, 0x14, 0x12, 0x0C, 0x04, 0x00, 0x10,
+0x14, 0x12, 0x09, 0x04, 0x00, 0x10, 0x24, 0x22,
+0x1C, 0x12, 0x00, 0x20, 0x24, 0x22, 0x18, 0x0C,
+0x00, 0x20, 0x24, 0x22, 0x14, 0x06, 0x00, 0x20,
+0x24, 0x22, 0x0F, 0x04, 0x00, 0x20, 0x24, 0x21,
+0x0A, 0x04, 0x00, 0x20, 0x23, 0x21, 0x0C, 0x04,
+0x00, 0x20, 0x23, 0x1F, 0x0A, 0x04, 0x00, 0x20,
+0x22, 0x1F, 0x0F, 0x04, 0x00, 0x20, 0x21, 0x1F,
+0x16, 0x0C, 0x00, 0x20, 0x31, 0x2F, 0x20, 0x14,
+0x00, 0x30, 0x31, 0x2F, 0x18, 0x10, 0x00, 0x30,
+0x31, 0x2C, 0x18, 0x0C, 0x00, 0x30, 0x31, 0x2A,
+0x14, 0x0C, 0x00, 0x30, 0x31, 0x28, 0x14, 0x00,
+0x00, 0x30, 0x31, 0x24, 0x14, 0x00, 0x00, 0x30,
+0x31, 0x1E, 0x14, 0x00, 0x00, 0x30, 0x31, 0x18,
+0x0A, 0x00, 0x00, 0x30, 0x15, 0xF0, 0xFF, 0x0F,
+0x00, 0x00, 0x00, 0x00, 0x15, 0xF0, 0x0F, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x05, 0xF0, 0xFF, 0x0F,
+0x00, 0x00, 0x00, 0x00, 0x05, 0xF0, 0x0F, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x10, 0xF0, 0xFF, 0x0F,
+0x00, 0x00, 0x00, 0x00, 0x10, 0xF0, 0x0F, 0x00,
+0x00, 0x00, 0x00, 0x00, 0xF5, 0x0F, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0xF0, 0x0F, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x0D, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0xFF, 0xFF,
+0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0x3F, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x15, 0xF0, 0x3F, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x15, 0xF0, 0xFF, 0xFF,
+0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0xFF, 0xFF,
+0xFF, 0x03, 0x00, 0x00, 0x15, 0xF0, 0xFF, 0xFF,
+0x0F, 0x00, 0x00, 0x00, 0x01, 0x02, 0x03, 0x06,
+0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x2C,
+0xFF, 0x00, 0x01, 0x02, 0x02, 0x04, 0x05, 0x06,
+0x07, 0x08, 0x09, 0x0A, 0x02, 0x02, 0x02, 0x04,
+0x02, 0x04, 0x06, 0x06, 0x08, 0x08, 0x09, 0x09,
+0x03, 0x06, 0x08, 0x08, 0x0A, 0x0E, 0x10, 0x18,
+0x05, 0x08, 0x08, 0x08, 0x0A, 0x0E, 0x10, 0x18,
+0x05, 0x08, 0x08, 0x09, 0x10, 0x14, 0x1C, 0x20,
+0x04, 0x06, 0x08, 0x0A, 0x10, 0x18, 0x18, 0x20,
+0x03, 0x06, 0x08, 0x09, 0x10, 0x14, 0x1C, 0x24,
+0x34, 0x3A, 0x05, 0x07, 0x09, 0x0A, 0x10, 0x14,
+0x1C, 0x28, 0x34, 0x3C, 0x06, 0x08, 0x0A, 0x0C,
+0x12, 0x18, 0x1E, 0x2E, 0x36, 0x40, 0x0A, 0x0C,
+0x0C, 0x12, 0x16, 0x1C, 0x20, 0x24, 0x24, 0x30,
+0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x03, 0x04,
+0x05, 0x06, 0x07, 0x08, 0x01, 0x02, 0x03, 0x04,
+0x05, 0x06, 0x07, 0x08, 0x02, 0x04, 0x06, 0x07,
+0x08, 0x0A, 0x0B, 0x0C, 0x03, 0x05, 0x06, 0x07,
+0x08, 0x0A, 0x0B, 0x0C, 0x05, 0x06, 0x07, 0x08,
+0x09, 0x0A, 0x0B, 0x0C, 0x02, 0x04, 0x06, 0x07,
+0x08, 0x09, 0x0B, 0x0C, 0x0C, 0x0C, 0x03, 0x05,
+0x06, 0x07, 0x08, 0x09, 0x0B, 0x0C, 0x0C, 0x0C,
+0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C,
+0x0C, 0x0C, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A,
+0x0B, 0x0C, 0x0C, 0x0C, 0x02, 0x04, 0x08, 0x10,
+0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20,
+0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20,
+0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20,
+0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20,
+0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20,
+0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20,
+0x24, 0x28, 0x10, 0x14, 0x18, 0x1C, 0x1C, 0x20,
+0x20, 0x20, 0x24, 0x28, 0x10, 0x14, 0x18, 0x1C,
+0x1C, 0x20, 0x20, 0x20, 0x24, 0x28, 0x10, 0x14,
+0x18, 0x1C, 0x1C, 0x20, 0x20, 0x20, 0x24, 0x28,
+0x2D, 0xFF, 0xFF, 0x2E, 0x36, 0xFF, 0x37, 0x2F,
+0xFF, 0x38, 0x30, 0x41, 0x39, 0x31, 0x42, 0x42,
+0x3A, 0x32, 0x43, 0x3A, 0x33, 0x43, 0x3A, 0x34,
+0x3A, 0x44, 0x35, 0x44, 0x3B, 0xFF, 0x37, 0x2E,
+0x40, 0x38, 0x30, 0x41, 0x39, 0x42, 0x31, 0x3A,
+0x42, 0x32, 0x3B, 0x43, 0x35, 0x3C, 0x44, 0xFF,
+0x3D, 0x45, 0xFF, 0x3E, 0x45, 0xFF, 0x45, 0x3F,
+0xFF, 0x46, 0xFF, 0xFF, 0x37, 0x41, 0x2F, 0x39,
+0x42, 0x31, 0x43, 0x3A, 0x33, 0x44, 0x3B, 0x35,
+0x45, 0x3D, 0xFF, 0x46, 0x47, 0x3E, 0x47, 0xFF,
+0xFF, 0x48, 0xFF, 0xFF, 0x49, 0xFF, 0xFF, 0xFF,
+0xFF, 0xFF, 0x00, 0x00, 0x0D, 0xFF, 0xFF, 0x0E,
+0x14, 0xFF, 0x15, 0x0F, 0xFF, 0x16, 0x10, 0xFF,
+0x17, 0x11, 0x1E, 0x1E, 0x18, 0x12, 0x1F, 0x18,
+0x13, 0x18, 0x1F, 0xFF, 0x15, 0x0E, 0xFF, 0x16,
+0x1D, 0x10, 0x17, 0x1E, 0x10, 0x18, 0x1E, 0x11,
+0x19, 0x1F, 0xFF, 0x1A, 0x20, 0xFF, 0x21, 0x1B,
+0xFF, 0x21, 0xFF, 0xFF, 0x15, 0x13, 0x0F, 0x17,
+0x1E, 0x11, 0x18, 0x1F, 0x13, 0x20, 0x19, 0xFF,
+0x21, 0x1B, 0xFF, 0x22, 0xFF, 0xFF, 0x23, 0xFF,
+0xFF, 0xFF, 0xFF, 0xFF, 0x04, 0x04, 0x04, 0x2C,
+0xFF, 0xFF, 0x2D, 0x36, 0xFF, 0x2E, 0x37, 0xFF,
+0x2F, 0x38, 0x41, 0x30, 0x39, 0x42, 0x43, 0x39,
+0x31, 0x42, 0x39, 0x32, 0x43, 0x3A, 0x33, 0x43,
+0x3A, 0x34, 0x2D, 0x2C, 0xFF, 0x36, 0x2E, 0xFF,
+0x37, 0x2F, 0x40, 0x38, 0x30, 0x41, 0x42, 0x33,
+0x39, 0x43, 0x35, 0x3A, 0x3B, 0x43, 0x34, 0x44,
+0x3C, 0x3B, 0x45, 0x3D, 0x3C, 0x45, 0x3E, 0x3D,
+0x37, 0x2E, 0xFF, 0x38, 0x2F, 0x40, 0x39, 0x31,
+0x41, 0x3A, 0x42, 0xFF, 0x43, 0x3B, 0xFF, 0x44,
+0x3C, 0xFF, 0x45, 0x3D, 0x3C, 0x46, 0x3F, 0x45,
+0x47, 0x46, 0x45, 0x48, 0x47, 0x47, 0x00, 0x00,
+0x04, 0xFF, 0xFF, 0x0C, 0xFF, 0xFF, 0x0D, 0x14,
+0xFF, 0x0E, 0x15, 0xFF, 0x0F, 0x16, 0xFF, 0x10,
+0x17, 0xFF, 0x17, 0x11, 0xFF, 0x17, 0x12, 0xFF,
+0x0D, 0x0C, 0xFF, 0x14, 0x0E, 0xFF, 0x15, 0x0F,
+0xFF, 0x16, 0x1D, 0x10, 0x17, 0x1E, 0x12, 0x18,
+0x1F, 0x13, 0x19, 0x20, 0x19, 0x20, 0x1A, 0x19,
+0x14, 0x0E, 0xFF, 0x15, 0x1C, 0xFF, 0x17, 0x1D,
+0x11, 0x18, 0x1E, 0x13, 0x19, 0x1F, 0x1E, 0x20,
+0x1A, 0x1F, 0x21, 0x1B, 0x20, 0x22, 0x21, 0x1B,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x24, 0x26, 0x2A, 0x00, 0x00, 0x00, 0x1F,
+0x21, 0x25, 0x27, 0x28, 0x00, 0x00, 0x00, 0x00,
+0x23, 0x26, 0x28, 0x30, 0x00, 0x00, 0x00, 0x00,
+0x23, 0x26, 0x28, 0x2A, 0x00, 0x00, 0x00, 0x00,
+0x23, 0x26, 0x28, 0x2A, 0x00, 0x00, 0x00, 0x00,
+0x24, 0x28, 0x2A, 0x2C, 0x2E, 0x30, 0x00, 0x00,
+0x00, 0x00, 0x26, 0x29, 0x2B, 0x2D, 0x2F, 0x31,
+0x00, 0x00, 0x00, 0x00, 0x28, 0x2A, 0x2C, 0x2E,
+0x30, 0x32, 0x00, 0x00, 0x00, 0x1F, 0x23, 0x26,
+0x28, 0x2A, 0x2A, 0x2A, 0x04, 0x00, 0x04, 0x00,
+0x08, 0x00, 0x10, 0x00, 0x18, 0x00, 0x24, 0x00,
+0x30, 0x00, 0x48, 0x00, 0x60, 0x00, 0x90, 0x00,
+0xC0, 0x00, 0xD8, 0x00, 0x50, 0x00, 0x64, 0x00,
+0x78, 0x00, 0xA0, 0x00, 0xF0, 0x00, 0x40, 0x01,
+0x90, 0x01, 0xE0, 0x01, 0xC8, 0x00, 0xF0, 0x00,
+0x40, 0x01, 0x90, 0x01, 0x58, 0x02, 0x20, 0x03,
+0xB0, 0x04, 0x40, 0x06, 0xC8, 0x00, 0x18, 0x01,
+0xE0, 0x01, 0xF4, 0x01, 0x84, 0x03, 0x20, 0x03,
+0xB0, 0x04, 0x40, 0x06, 0xC8, 0x00, 0x18, 0x01,
+0xE0, 0x01, 0xD0, 0x02, 0x20, 0x03, 0xE8, 0x03,
+0xB0, 0x04, 0x40, 0x06, 0x3C, 0x00, 0x64, 0x00,
+0x78, 0x00, 0xA0, 0x00, 0xF0, 0x00, 0x40, 0x01,
+0x90, 0x01, 0xE0, 0x01, 0x58, 0x02, 0x20, 0x03,
+0x78, 0x00, 0xF0, 0x00, 0x68, 0x01, 0xA4, 0x01,
+0xE0, 0x01, 0x1C, 0x02, 0x58, 0x02, 0x20, 0x03,
+0xE8, 0x03, 0xB0, 0x04, 0xB4, 0x00, 0x2C, 0x01,
+0xA4, 0x01, 0xE0, 0x01, 0x1C, 0x02, 0x58, 0x02,
+0x20, 0x03, 0xE8, 0x03, 0xB0, 0x04, 0x78, 0x05,
+0xC8, 0x00, 0x18, 0x01, 0xE0, 0x01, 0xD0, 0x02,
+0xE8, 0x03, 0xB0, 0x04, 0x40, 0x06, 0xD0, 0x07,
+0xD0, 0x07, 0xD0, 0x07, 0x02, 0x00, 0x02, 0x00,
+0x04, 0x00, 0x08, 0x00, 0x0C, 0x00, 0x12, 0x00,
+0x18, 0x00, 0x24, 0x00, 0x30, 0x00, 0x48, 0x00,
+0x60, 0x00, 0x6C, 0x00, 0x28, 0x00, 0x32, 0x00,
+0x3C, 0x00, 0x50, 0x00, 0x78, 0x00, 0xA0, 0x00,
+0xC8, 0x00, 0xF0, 0x00, 0x64, 0x00, 0x78, 0x00,
+0xA0, 0x00, 0xC8, 0x00, 0x2C, 0x01, 0x90, 0x01,
+0x58, 0x02, 0x20, 0x03, 0x64, 0x00, 0x8C, 0x00,
+0xF0, 0x00, 0xFA, 0x00, 0xC2, 0x01, 0x90, 0x01,
+0x58, 0x02, 0x20, 0x03, 0x64, 0x00, 0x8C, 0x00,
+0xF0, 0x00, 0x68, 0x01, 0xF4, 0x01, 0x20, 0x03,
+0xE8, 0x03, 0x78, 0x05, 0x1E, 0x00, 0x32, 0x00,
+0x3C, 0x00, 0x50, 0x00, 0x78, 0x00, 0xA0, 0x00,
+0xC8, 0x00, 0xF0, 0x00, 0x2C, 0x01, 0x90, 0x01,
+0x3C, 0x00, 0x78, 0x00, 0xB4, 0x00, 0xD2, 0x00,
+0xF0, 0x00, 0x0E, 0x01, 0x2C, 0x01, 0x90, 0x01,
+0xF4, 0x01, 0x58, 0x02, 0x5A, 0x00, 0x96, 0x00,
+0xD2, 0x00, 0xF0, 0x00, 0x0E, 0x01, 0x2C, 0x01,
+0x90, 0x01, 0xF4, 0x01, 0x58, 0x02, 0xBC, 0x02,
+0x64, 0x00, 0x8C, 0x00, 0xF0, 0x00, 0x68, 0x01,
+0xF4, 0x01, 0x58, 0x02, 0x20, 0x03, 0xE8, 0x03,
+0xE8, 0x03, 0xE8, 0x03, 0x01, 0x00, 0x02, 0x00,
+0x05, 0x00, 0x0B, 0x00, 0x06, 0x00, 0x09, 0x00,
+0x0C, 0x00, 0x12, 0x00, 0x18, 0x00, 0x24, 0x00,
+0x30, 0x00, 0x36, 0x00, 0x0E, 0x00, 0x1B, 0x00,
+0x29, 0x00, 0x36, 0x00, 0x51, 0x00, 0x6C, 0x00,
+0x7A, 0x00, 0x87, 0x00, 0x1B, 0x00, 0x36, 0x00,
+0x51, 0x00, 0x6C, 0x00, 0xA2, 0x00, 0xD8, 0x00,
+0xF3, 0x00, 0x0E, 0x01, 0x29, 0x00, 0x51, 0x00,
+0x7A, 0x00, 0xA2, 0x00, 0xF3, 0x00, 0x44, 0x01,
+0x6D, 0x01, 0x95, 0x01, 0x36, 0x00, 0x6C, 0x00,
+0xA2, 0x00, 0xD8, 0x00, 0x44, 0x01, 0xB0, 0x01,
+0xE6, 0x01, 0x1C, 0x02, 0x0E, 0x00, 0x1B, 0x00,
+0x29, 0x00, 0x36, 0x00, 0x51, 0x00, 0x6C, 0x00,
+0x7A, 0x00, 0x87, 0x00, 0xA2, 0x00, 0xB4, 0x00,
+0x1B, 0x00, 0x36, 0x00, 0x51, 0x00, 0x6C, 0x00,
+0xA2, 0x00, 0xD8, 0x00, 0xF3, 0x00, 0xFF, 0x00,
+0x23, 0x01, 0x44, 0x01, 0x29, 0x00, 0x51, 0x00,
+0x7A, 0x00, 0xA2, 0x00, 0xF3, 0x00, 0x44, 0x01,
+0x64, 0x01, 0x64, 0x01, 0xB5, 0x01, 0xE6, 0x01,
+0x36, 0x00, 0x6C, 0x00, 0xA2, 0x00, 0xD8, 0x00,
+0x44, 0x01, 0xB0, 0x01, 0xE6, 0x01, 0x1C, 0x02,
+0x88, 0x02, 0xD0, 0x02, 0x14, 0x14, 0x15, 0x15,
+0x16, 0x17, 0x17, 0x18, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1D, 0x1D, 0x1E, 0x1E, 0x1C, 0x1C, 0x1D, 0x1E,
+0x1F, 0x20, 0x20, 0x20, 0x36, 0x36, 0x37, 0x37,
+0x38, 0x39, 0x39, 0x3A, 0x3A, 0x3A, 0x00, 0x00,
+0x40, 0x40, 0x40, 0x40, 0x41, 0x41, 0x42, 0x42,
+0x43, 0x43, 0x00, 0x00, 0x40, 0x40, 0x41, 0x42,
+0x43, 0x44, 0x44, 0x44, 0x45, 0x46, 0x00, 0x00,
+0x00, 0xF0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x30, 0xC0,
+0xE0, 0x00, 0x00, 0x00, 0x00, 0x0C, 0x0E, 0x38,
+0x18, 0x00, 0x00, 0x00, 0x00, 0x83, 0x01, 0x06,
+0x80, 0x03, 0x00, 0x00, 0x00, 0x00, 0x70, 0xE0,
+0xB5, 0xA5, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x18, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x10, 0xF0, 0x20, 0x6A, 0x20, 0xF3, 0x0D, 0x4A,
+0x00, 0xEA, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x30, 0xF0, 0x21, 0x6C, 0x18, 0xF0, 0x00, 0x4C,
+0xBC, 0x65, 0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x94, 0xB8,
+0x00, 0x6D, 0xFE, 0xF7, 0x1F, 0x4D, 0xAC, 0xEC,
+0x94, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0xF4,
+0x00, 0x6D, 0xAD, 0xEC, 0x94, 0xB9, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF0, 0x00, 0x4C,
+0x00, 0x6E, 0x30, 0xF0, 0x20, 0x6F, 0x00, 0xF0,
+0x00, 0x4F, 0xC0, 0xDC, 0x04, 0x4C, 0xE3, 0xEC,
+0xB8, 0x67, 0xFB, 0x2D, 0x30, 0xF0, 0x20, 0x6C,
+0x46, 0xF2, 0x10, 0x4C, 0x00, 0x6E, 0x30, 0xF0,
+0x21, 0x6F, 0x72, 0xF2, 0x10, 0x4F, 0xC0, 0xDC,
+0x04, 0x4C, 0xE3, 0xEC, 0xB8, 0x67, 0xFB, 0x2D,
+0x10, 0xF0, 0x20, 0x6C, 0x60, 0xF2, 0x15, 0x4C,
+0x00, 0xEC, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x60, 0xF2, 0x15, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0xD4, 0x07, 0x00, 0x18,
+0xF3, 0x07, 0x00, 0x18, 0x46, 0x0A, 0x00, 0x18,
+0x15, 0x08, 0x00, 0x18, 0x26, 0x0A, 0x00, 0x18,
+0x1A, 0x12, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x21, 0x6A, 0x60, 0xF0, 0x08, 0x4C, 0x15, 0xF0,
+0x00, 0x4A, 0x43, 0xDC, 0x00, 0x6D, 0x00, 0x18,
+0xD5, 0x11, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x21, 0x6B, 0xE0, 0xF0, 0x08, 0x4C, 0x01, 0x6D,
+0x91, 0xF1, 0x44, 0xDB, 0x00, 0x18, 0x8E, 0x10,
+0x30, 0xF0, 0x21, 0x6B, 0x91, 0xF1, 0x4C, 0xDB,
+0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0, 0x21, 0x6A,
+0xA0, 0xF0, 0x08, 0x4C, 0x15, 0xF4, 0x00, 0x4A,
+0x43, 0xDC, 0x00, 0x6D, 0x00, 0x18, 0xD5, 0x11,
+0x30, 0xF0, 0x21, 0x6B, 0x91, 0xF1, 0x48, 0xDB,
+0x00, 0x18, 0xA8, 0x0A, 0x00, 0x18, 0xC6, 0x0B,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1, 0x74, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6C, 0x10, 0xF0, 0x00, 0x6D,
+0x40, 0xAB, 0xAB, 0xED, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xCB, 0x00, 0x18, 0xAF, 0x0F,
+0x00, 0x18, 0x14, 0x0E, 0xFF, 0x17, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x6D, 0xB8, 0x00, 0x65,
+0x00, 0xF0, 0x20, 0x6A, 0x7C, 0x4A, 0x6C, 0xEA,
+0x20, 0x22, 0x00, 0xF0, 0x20, 0x6B, 0x28, 0x4B,
+0x6A, 0xEA, 0x0F, 0x61, 0x30, 0xF0, 0x21, 0x6B,
+0x32, 0xF1, 0x04, 0x4B, 0x77, 0xF0, 0x24, 0x6A,
+0xA0, 0xF4, 0x04, 0x4A, 0x60, 0xDA, 0x30, 0xF0,
+0x21, 0x6A, 0x32, 0xF1, 0x04, 0x4A, 0x6A, 0xEA,
+0x31, 0x60, 0x77, 0xF0, 0x24, 0x6A, 0xA0, 0xF1,
+0x1C, 0x4A, 0x1D, 0xF4, 0x00, 0x6B, 0x60, 0xDA,
+0x10, 0xF0, 0x20, 0x6A, 0x07, 0xF0, 0x01, 0x4A,
+0x00, 0xEA, 0x00, 0xF0, 0x20, 0x6A, 0x1F, 0xF7,
+0x00, 0x6A, 0x4C, 0xEB, 0x4C, 0xB8, 0x00, 0x65,
+0x6C, 0xEA, 0x42, 0x32, 0x30, 0xF0, 0x20, 0x6B,
+0xE5, 0xF2, 0x18, 0x4B, 0x49, 0xE3, 0x40, 0xA2,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF0, 0x08, 0x4B,
+0x69, 0xE2, 0x30, 0xF0, 0x21, 0x6B, 0x32, 0xF1,
+0x00, 0x4B, 0x60, 0x9B, 0x05, 0x2B, 0x10, 0xF0,
+0x20, 0x6B, 0x20, 0xF5, 0x01, 0x4B, 0x00, 0xEB,
+0x10, 0xF0, 0x20, 0x6B, 0xA0, 0xF5, 0x15, 0x4B,
+0x00, 0xEB, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6B,
+0x01, 0x6B, 0x30, 0xF0, 0x21, 0x6A, 0x32, 0xF1,
+0x04, 0x4A, 0x60, 0xDA, 0x30, 0xF0, 0x21, 0x6A,
+0x71, 0xF1, 0x10, 0x4A, 0x60, 0xDA, 0x10, 0xF0,
+0x20, 0x6B, 0xE0, 0xF3, 0x09, 0x4B, 0x00, 0xEB,
+0x5A, 0xB8, 0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65,
+0x40, 0xE8, 0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x30, 0xF0, 0x21, 0x6A, 0x71, 0xF1,
+0x10, 0x4A, 0x00, 0xF0, 0x20, 0x6B, 0x60, 0xDA,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x08, 0x4A,
+0x60, 0x9A, 0x41, 0x9A, 0x6A, 0xEA, 0x0D, 0x61,
+0x6E, 0xB8, 0x00, 0x65, 0x62, 0x43, 0xCB, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x5A, 0xB8,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x00, 0xBA,
+0x00, 0x65, 0x36, 0x23, 0xDF, 0xF7, 0x00, 0x03,
+0x86, 0xDB, 0xA7, 0xDB, 0xC8, 0xDB, 0xE9, 0xDB,
+0x0A, 0xDB, 0x2B, 0xDB, 0x98, 0x67, 0x8C, 0xDB,
+0x9F, 0x67, 0x8E, 0xDB, 0x12, 0xEC, 0x10, 0xED,
+0x82, 0xDB, 0xA3, 0xDB, 0x9A, 0xB8, 0x00, 0x65,
+0x84, 0xDB, 0x9B, 0xB8, 0x00, 0x65, 0x85, 0xDB,
+0x8E, 0xB8, 0x00, 0x65, 0x82, 0x44, 0x81, 0xDB,
+0x8C, 0xB8, 0x00, 0x65, 0x80, 0xDB, 0x30, 0xF0,
+0x21, 0x6B, 0xD1, 0xF1, 0x08, 0x4B, 0x60, 0x9B,
+0x9D, 0x67, 0x89, 0xDB, 0x6A, 0x9B, 0xCF, 0xF7,
+0x80, 0x44, 0x62, 0xEC, 0x0D, 0x60, 0x77, 0xF0,
+0x24, 0x6C, 0xA0, 0xF1, 0x1C, 0x4C, 0x1D, 0xF4,
+0x01, 0x6B, 0x60, 0xDC, 0x10, 0xF0, 0x20, 0x6C,
+0x07, 0xF0, 0x01, 0x4C, 0x00, 0xEC, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6B, 0xD1, 0xF1, 0x08, 0x4B,
+0x41, 0x9B, 0x40, 0xDB, 0x89, 0x9A, 0xBC, 0x65,
+0x7D, 0x67, 0xDF, 0xF7, 0x00, 0x03, 0x4C, 0xB8,
+0x00, 0x65, 0x00, 0xF0, 0x20, 0x6D, 0x05, 0x4D,
+0xAF, 0xED, 0xAC, 0xEA, 0xA0, 0x9B, 0x04, 0x6C,
+0x8C, 0xED, 0xAD, 0xEA, 0x82, 0x9B, 0xA3, 0x9B,
+0x32, 0xEC, 0x30, 0xED, 0x8E, 0x9B, 0xFC, 0x65,
+0x8C, 0x9B, 0x1C, 0x65, 0x84, 0x9B, 0x5C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x85, 0x9B,
+0x7C, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x2B, 0x9B, 0x0A, 0x9B, 0xE9, 0x9B, 0xC8, 0x9B,
+0xA7, 0x9B, 0x86, 0x9B, 0x61, 0x9B, 0xCB, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x7B, 0xB8,
+0x00, 0x65, 0x5A, 0xB8, 0x00, 0x65, 0x00, 0xBA,
+0xDF, 0xF7, 0x00, 0x03, 0x86, 0xDB, 0xA7, 0xDB,
+0xC8, 0xDB, 0xE9, 0xDB, 0x0A, 0xDB, 0x2B, 0xDB,
+0x98, 0x67, 0x8C, 0xDB, 0x9F, 0x67, 0x8E, 0xDB,
+0x12, 0xEC, 0x10, 0xED, 0x82, 0xDB, 0xA3, 0xDB,
+0x9A, 0xB8, 0x00, 0x65, 0x84, 0xDB, 0x9B, 0xB8,
+0x00, 0x65, 0x85, 0xDB, 0x7D, 0x67, 0x5B, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x40, 0x9A,
+0x30, 0xF0, 0x21, 0x6C, 0x11, 0xF5, 0x04, 0x4C,
+0x00, 0xF4, 0x00, 0x4C, 0xBC, 0x65, 0x82, 0x67,
+0x40, 0xEA, 0x00, 0x65, 0x7A, 0xB8, 0x00, 0x65,
+0xBB, 0x65, 0xDF, 0xF7, 0x00, 0x03, 0x82, 0x9B,
+0xA3, 0x9B, 0x32, 0xEC, 0x30, 0xED, 0x8E, 0x9B,
+0xFC, 0x65, 0x8C, 0x9B, 0x1C, 0x65, 0x84, 0x9B,
+0x5C, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x85, 0x9B, 0x7C, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x2B, 0x9B, 0x0A, 0x9B, 0xE9, 0x9B,
+0xC8, 0x9B, 0xA7, 0x9B, 0x86, 0x9B, 0x5A, 0xB8,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x00, 0xBA,
+0x00, 0x65, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6B,
+0x71, 0xF1, 0x10, 0x4B, 0x40, 0xDB, 0xDF, 0xF7,
+0x00, 0x03, 0x86, 0xDB, 0xA7, 0xDB, 0xC8, 0xDB,
+0xE9, 0xDB, 0x0A, 0xDB, 0x2B, 0xDB, 0x98, 0x67,
+0x8C, 0xDB, 0x9F, 0x67, 0x8E, 0xDB, 0x12, 0xEC,
+0x10, 0xED, 0x82, 0xDB, 0xA3, 0xDB, 0x9A, 0xB8,
+0x00, 0x65, 0x84, 0xDB, 0x9B, 0xB8, 0x00, 0x65,
+0x85, 0xDB, 0x8E, 0xB8, 0x00, 0x65, 0x81, 0xDB,
+0x8C, 0xB8, 0x00, 0x65, 0x80, 0xDB, 0x30, 0xF0,
+0x21, 0x6B, 0xD1, 0xF1, 0x08, 0x4B, 0x60, 0x9B,
+0x9D, 0x67, 0x89, 0xDB, 0x6A, 0x9B, 0xCF, 0xF7,
+0x80, 0x44, 0x62, 0xEC, 0x0D, 0x60, 0x77, 0xF0,
+0x24, 0x6C, 0xA0, 0xF1, 0x1C, 0x4C, 0x1D, 0xF4,
+0x01, 0x6B, 0x60, 0xDC, 0x10, 0xF0, 0x20, 0x6C,
+0x07, 0xF0, 0x01, 0x4C, 0x00, 0xEC, 0x00, 0x65,
+0x40, 0x9A, 0x30, 0xF0, 0x21, 0x6C, 0x11, 0xF5,
+0x04, 0x4C, 0x00, 0xF4, 0x00, 0x4C, 0xBC, 0x65,
+0x82, 0x67, 0x40, 0xEA, 0x30, 0xF0, 0x21, 0x6C,
+0x71, 0xF1, 0x10, 0x4C, 0x00, 0xF0, 0x20, 0x6D,
+0xA0, 0xDC, 0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1,
+0x08, 0x4A, 0x10, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x1D, 0x4B, 0x00, 0xEB, 0x61, 0x9A, 0x60, 0xDA,
+0x49, 0x9B, 0xBA, 0x65, 0xDF, 0xF7, 0x00, 0x03,
+0x4C, 0xB8, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6D,
+0x05, 0x4D, 0xAF, 0xED, 0xAC, 0xEA, 0xA0, 0x9B,
+0x00, 0xF0, 0x20, 0x6C, 0x04, 0x4C, 0x8C, 0xED,
+0xAD, 0xEA, 0x82, 0x9B, 0xA3, 0x9B, 0x32, 0xEC,
+0x30, 0xED, 0x8E, 0x9B, 0xFC, 0x65, 0x8C, 0x9B,
+0x1C, 0x65, 0x84, 0x9B, 0x5C, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x85, 0x9B, 0x7C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x2B, 0x9B,
+0x0A, 0x9B, 0xE9, 0x9B, 0xC8, 0x9B, 0xA7, 0x9B,
+0x86, 0x9B, 0x61, 0x9B, 0xCB, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x8A, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65,
+0x5A, 0xB8, 0x00, 0x65, 0x00, 0xBA, 0x00, 0x65,
+0x5F, 0x67, 0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x18, 0xCA, 0x00, 0x00, 0x18,
+0xC7, 0x0C, 0x5A, 0xB8, 0x00, 0x65, 0x00, 0xEA,
+0x6D, 0xB8, 0x00, 0xF0, 0x20, 0x6A, 0x00, 0xF2,
+0x00, 0x4A, 0x4F, 0xEA, 0x4C, 0xEB, 0xAB, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x5F, 0x67,
+0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x18, 0xD9, 0x0C, 0x5A, 0xB8, 0x00, 0x65,
+0x00, 0xEA, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xE3, 0x01, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x09, 0x02, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x14, 0x02, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x77, 0x03, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x89, 0x03, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xDD, 0x01, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x15, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x80, 0xF7, 0x0D, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF6, 0x5C, 0x9A, 0xA0, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF6, 0x40, 0x9A,
+0x80, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF6,
+0x44, 0x9A, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF6, 0x48, 0x9A, 0x40, 0x9A, 0x23, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF6, 0x4C, 0x9A,
+0xA0, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF6,
+0x50, 0x9A, 0x80, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF6, 0x54, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xE1, 0xF5, 0x84, 0x9C, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x80, 0xF7, 0x0E, 0x4A, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x2C, 0x9A, 0x10, 0xF0, 0x20, 0x68,
+0x21, 0xF0, 0x05, 0x48, 0x00, 0xD9, 0x01, 0x48,
+0x00, 0x18, 0x56, 0x21, 0x00, 0xD9, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x11, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x75, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF2,
+0x7C, 0x9A, 0x80, 0xF0, 0x10, 0x23, 0x01, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x5C, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF2, 0x5C, 0x9A,
+0x02, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x4D, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF2,
+0x5C, 0x9A, 0x04, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x2F, 0x35, 0x30, 0xF0, 0x20, 0x6A,
+0xC6, 0xF2, 0x5C, 0x9A, 0x08, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x2B, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0xC6, 0xF2, 0x5C, 0x9A, 0x10, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x93, 0x32,
+0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF2, 0x5C, 0x9A,
+0x20, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x94, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF2,
+0x5C, 0x9A, 0x40, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x95, 0x32, 0x30, 0xF0, 0x20, 0x6A,
+0xC6, 0xF2, 0x5C, 0x9A, 0x80, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x27, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0xC6, 0xF2, 0x7C, 0x9B, 0xFF, 0x6A,
+0x01, 0x4A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x1F, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0xC6, 0xF2,
+0x7C, 0x9B, 0x04, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x1B, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0xC6, 0xF2, 0x7C, 0x9B, 0x08, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x96, 0x32, 0x30, 0xF0, 0x20, 0x6B, 0xC6, 0xF2,
+0x7C, 0x9B, 0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x97, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x44, 0x9A, 0xC6, 0xF2, 0x7C, 0x9B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x16, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x48, 0x9A, 0xC6, 0xF2, 0x7C, 0x9B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x0D, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x4C, 0x9A, 0xC6, 0xF2, 0x7C, 0x9B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0xE3, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0xE6, 0xF2, 0x60, 0x9A, 0xC0, 0xF1,
+0x00, 0x23, 0x01, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xFB, 0x34, 0x30, 0xF0, 0x20, 0x6A,
+0xE6, 0xF2, 0x40, 0x9A, 0x02, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x98, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0xE6, 0xF2, 0x40, 0x9A, 0x04, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x7C, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x48, 0x9A, 0xE6, 0xF2,
+0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0x7C, 0x33, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF5, 0x44, 0x9A,
+0xE6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x7C, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0,
+0x54, 0x9A, 0xE6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x7C, 0x33,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x40, 0x9A, 0xE6, 0xF2, 0x64, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0x7C, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2,
+0x40, 0x9A, 0x08, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x99, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x44, 0x9A, 0xE6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0x99, 0x32,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF6, 0x58, 0x9A, 0xE6, 0xF2, 0x64, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x99, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF0, 0x44, 0x9A, 0xE6, 0xF2,
+0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x99, 0x32, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x44, 0x9A,
+0xE6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0x99, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0xE6, 0xF2, 0x40, 0x9A, 0x10, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x9F, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x48, 0x9A, 0xE6, 0xF2,
+0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0x9F, 0x32, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x58, 0x9A,
+0xE6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x9F, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0,
+0x50, 0x9A, 0xE6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x9F, 0x32,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x4C, 0x9A, 0xE6, 0xF2, 0x64, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0x9F, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2,
+0x40, 0x9A, 0x20, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0xA0, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x4C, 0x9A, 0xE6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0xA0, 0x32,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x48, 0x9A, 0xE6, 0xF2, 0x60, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0xA0, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x4C, 0x9A, 0xE6, 0xF2,
+0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0xA0, 0x32, 0x30, 0xF0, 0x20, 0x6A,
+0xE6, 0xF2, 0x44, 0x9A, 0x00, 0x52, 0x03, 0x60,
+0x04, 0x6C, 0x00, 0x18, 0xA0, 0x32, 0x30, 0xF0,
+0x20, 0x6B, 0xE6, 0xF2, 0x60, 0x9B, 0x04, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x4B, 0x34, 0x30, 0xF0, 0x20, 0x6B,
+0xE6, 0xF2, 0x60, 0x9B, 0x08, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x16, 0x34, 0x30, 0xF0, 0x20, 0x6B, 0xE6, 0xF2,
+0x60, 0x9B, 0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x04, 0x22, 0x00, 0x18, 0xB6, 0x32, 0x00, 0x18,
+0x3B, 0x50, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x48, 0x9A, 0xE6, 0xF2,
+0x60, 0x9B, 0x6C, 0xEA, 0x04, 0x22, 0x00, 0x18,
+0xC0, 0x32, 0x00, 0x18, 0x45, 0x50, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x44, 0x9A, 0xE6, 0xF2, 0x60, 0x9B, 0x6C, 0xEA,
+0x04, 0x22, 0x00, 0x18, 0xCA, 0x32, 0x00, 0x18,
+0x4F, 0x50, 0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2,
+0x40, 0x9A, 0x40, 0x6B, 0x6C, 0xEA, 0x04, 0x22,
+0x00, 0x18, 0xE0, 0x34, 0x00, 0x18, 0x4F, 0x54,
+0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2, 0x40, 0x9A,
+0x80, 0x6B, 0x6C, 0xEA, 0x04, 0x22, 0x00, 0x18,
+0x93, 0x34, 0x00, 0x18, 0xEE, 0x51, 0x30, 0xF0,
+0x20, 0x6B, 0xE6, 0xF2, 0x60, 0x9B, 0xFF, 0x6A,
+0x01, 0x4A, 0x6C, 0xEA, 0x04, 0x22, 0x00, 0x18,
+0xC5, 0x34, 0x00, 0x18, 0x4B, 0x54, 0x30, 0xF0,
+0x20, 0x6B, 0xE6, 0xF2, 0x60, 0x9B, 0x00, 0xF2,
+0x00, 0x6A, 0x6C, 0xEA, 0x04, 0x22, 0x00, 0x18,
+0x7C, 0x34, 0x00, 0x18, 0xEA, 0x51, 0x30, 0xF0,
+0x20, 0x6B, 0xE6, 0xF2, 0x60, 0x9B, 0x00, 0xF4,
+0x00, 0x6A, 0x6C, 0xEA, 0x04, 0x22, 0x00, 0x18,
+0xAA, 0x34, 0x00, 0x18, 0x47, 0x54, 0x30, 0xF0,
+0x20, 0x6B, 0xE6, 0xF2, 0x60, 0x9B, 0x01, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x04, 0x22, 0x00, 0x18,
+0x65, 0x34, 0x00, 0x18, 0xE6, 0x51, 0x30, 0xF0,
+0x20, 0x6B, 0xE6, 0xF2, 0x60, 0x9B, 0x02, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xA1, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xC1, 0xF0, 0x54, 0x9A, 0xE6, 0xF2,
+0x60, 0x9B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xD5, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF0, 0x44, 0x9A, 0xE6, 0xF2,
+0x60, 0x9B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x12, 0x34, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF0, 0x50, 0x9A, 0xE6, 0xF2,
+0x60, 0x9B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xFB, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x4C, 0x9A, 0xE6, 0xF2,
+0x60, 0x9B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x02, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2,
+0x64, 0x9A, 0x55, 0x23, 0x01, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0x4B, 0x34,
+0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2, 0x44, 0x9A,
+0x02, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0x16, 0x34, 0x30, 0xF0, 0x20, 0x6A,
+0xE6, 0xF2, 0x44, 0x9A, 0x04, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0x4B, 0x34,
+0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2, 0x44, 0x9A,
+0x08, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C,
+0x00, 0x18, 0x16, 0x34, 0x30, 0xF0, 0x20, 0x6A,
+0xE6, 0xF2, 0x44, 0x9A, 0x10, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x4B, 0x34,
+0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2, 0x44, 0x9A,
+0x20, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x16, 0x34, 0x30, 0xF0, 0x20, 0x6A,
+0xE6, 0xF2, 0x44, 0x9A, 0x40, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0x4B, 0x34,
+0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF2, 0x44, 0x9A,
+0x80, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x16, 0x34, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x12, 0x4A, 0x40, 0xDB, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC1, 0xF5, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x45, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0xC6, 0xF2, 0x6C, 0x9A, 0x0E, 0x23,
+0x80, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x8B, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xC1, 0xF5,
+0x1E, 0x4A, 0x40, 0xDB, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x21, 0xF6, 0x05, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x4C, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x60, 0x9A, 0x47, 0x23,
+0x08, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x1F, 0x33, 0x30, 0xF0, 0x20, 0x6A,
+0xA6, 0xF2, 0x40, 0x9A, 0x02, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x09, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x40, 0x9A, 0x10, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x87, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0xA6, 0xF2, 0x40, 0x9A,
+0x20, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x83, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0xA6, 0xF2,
+0x40, 0x9A, 0x40, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x89, 0x32, 0x30, 0xF0, 0x20, 0x6A,
+0xA6, 0xF2, 0x40, 0x9A, 0x80, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x6A, 0x40, 0x30, 0xF0,
+0x20, 0x6B, 0xA6, 0xF2, 0x60, 0x9B, 0xFF, 0x6A,
+0x01, 0x4A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x7F, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2,
+0x60, 0x9B, 0x00, 0xF2, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x7B, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x64, 0x9A, 0x80, 0xF0,
+0x0D, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF6,
+0x58, 0x9A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0xCD, 0x33, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x58, 0x9A,
+0xA6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0xCD, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x48, 0x9A, 0xA6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0xCD, 0x33,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF0, 0x54, 0x9A, 0xA6, 0xF2, 0x64, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C, 0x00, 0x18,
+0xCD, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF0, 0x44, 0x9A, 0xA6, 0xF2,
+0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0xCD, 0x33, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x44, 0x9A,
+0xA6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0xAF, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x48, 0x9A, 0xA6, 0xF2, 0x64, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x54, 0x33,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x4C, 0x9A, 0xA6, 0xF2, 0x64, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x86, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF5, 0x44, 0x9A, 0xA6, 0xF2,
+0x64, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x38, 0x33, 0x30, 0xF0, 0x20, 0x6B,
+0xA6, 0xF2, 0x64, 0x9B, 0x08, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x77, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0, 0x70, 0x9B,
+0x89, 0x9A, 0x8C, 0xEB, 0x07, 0x23, 0xA0, 0xF0,
+0x64, 0x9A, 0x00, 0xF2, 0x00, 0x6C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x8A, 0x9A, 0x35, 0x24,
+0x01, 0x6B, 0x6C, 0xEC, 0x06, 0x24, 0x9F, 0x9A,
+0x6D, 0xEC, 0x9F, 0xDA, 0x00, 0x6C, 0x00, 0x18,
+0xC2, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2,
+0x68, 0x9B, 0xFF, 0x6A, 0x01, 0x4A, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0xC2, 0x35,
+0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2, 0x68, 0x9B,
+0x00, 0xF2, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0xC2, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0xA6, 0xF2, 0x68, 0x9B, 0x00, 0xF4,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0xC2, 0x35, 0x30, 0xF0, 0x20, 0x6B,
+0xA6, 0xF2, 0x68, 0x9B, 0x01, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0xC2, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0xA6, 0xF2,
+0x6C, 0x9A, 0x6D, 0x23, 0x01, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x68, 0x35,
+0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2, 0x6C, 0x9B,
+0xFF, 0x6A, 0x01, 0x4A, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0x68, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0xA6, 0xF2, 0x6C, 0x9B, 0x00, 0xF2,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C,
+0x00, 0x18, 0x68, 0x35, 0x30, 0xF0, 0x20, 0x6B,
+0xA6, 0xF2, 0x6C, 0x9B, 0x00, 0xF4, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C, 0x00, 0x18,
+0x68, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2,
+0x6C, 0x9B, 0x01, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0x68, 0x35,
+0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2, 0x6C, 0x9B,
+0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x65, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7,
+0x40, 0x9A, 0xA6, 0xF2, 0x6C, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0x65, 0x07,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x44, 0x9A, 0xA6, 0xF2, 0x6C, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x65, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF7, 0x4C, 0x9A, 0xA6, 0xF2,
+0x6C, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x65, 0x07, 0x30, 0xF0, 0x20, 0x6A,
+0xA6, 0xF2, 0x4C, 0x9A, 0x00, 0x52, 0x03, 0x60,
+0x04, 0x6C, 0x00, 0x18, 0x65, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x70, 0x9A, 0xC0, 0xF0,
+0x18, 0x23, 0x01, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0xAF, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x50, 0x9A, 0x02, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x54, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0xA6, 0xF2,
+0x50, 0x9A, 0x04, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0x86, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x50, 0x9A, 0x08, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x38, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0xA6, 0xF2,
+0x50, 0x9A, 0x10, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0xAF, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x50, 0x9A, 0x20, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x54, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0xA6, 0xF2,
+0x50, 0x9A, 0x40, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x86, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0xA6, 0xF2, 0x50, 0x9A, 0x80, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x38, 0x33, 0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2,
+0x70, 0x9B, 0xFF, 0x6A, 0x01, 0x4A, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0xAF, 0x33,
+0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2, 0x70, 0x9B,
+0x00, 0xF2, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x03, 0x6C, 0x00, 0x18, 0x54, 0x33, 0x30, 0xF0,
+0x20, 0x6B, 0xA6, 0xF2, 0x70, 0x9B, 0x00, 0xF4,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x86, 0x33, 0x30, 0xF0, 0x20, 0x6B,
+0xA6, 0xF2, 0x70, 0x9B, 0x01, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C, 0x00, 0x18,
+0x38, 0x33, 0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2,
+0x70, 0x9B, 0x02, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0xAF, 0x33,
+0x30, 0xF0, 0x20, 0x6B, 0xA6, 0xF2, 0x70, 0x9B,
+0x04, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0x54, 0x33, 0x30, 0xF0,
+0x20, 0x6B, 0xA6, 0xF2, 0x70, 0x9B, 0x08, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x86, 0x33, 0x30, 0xF0, 0x20, 0x6B,
+0xA6, 0xF2, 0x70, 0x9B, 0x10, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0x38, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x48, 0x9A, 0xA6, 0xF2,
+0x70, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0x1F, 0x33, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x44, 0x9A,
+0xA6, 0xF2, 0x70, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x1F, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x48, 0x9A, 0xA6, 0xF2, 0x70, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x1F, 0x33,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x4C, 0x9A, 0xA6, 0xF2, 0x70, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0x1F, 0x33, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x21, 0xF6,
+0x06, 0x4A, 0x40, 0xDB, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x4D, 0xB8, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0xF2, 0x00, 0x6B,
+0x6D, 0xEA, 0xAA, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x1F, 0x6B, 0x8C, 0xEB, 0x96, 0x34, 0x4C, 0xEC,
+0x01, 0x74, 0x0B, 0x60, 0x05, 0x24, 0x02, 0x74,
+0x0D, 0x60, 0x03, 0x74, 0x10, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x8C, 0x9A,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x90, 0x9A, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x94, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x98, 0x9A, 0xA0, 0x9C,
+0x01, 0x6A, 0x44, 0xEB, 0xAD, 0xEA, 0x40, 0xDC,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0x1F, 0x6B, 0x8C, 0xEB, 0x96, 0x34, 0x4C, 0xEC,
+0x01, 0x74, 0x0B, 0x60, 0x05, 0x24, 0x02, 0x74,
+0x0D, 0x60, 0x03, 0x74, 0x10, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x8C, 0x9A,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x90, 0x9A, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x94, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x98, 0x9A, 0xA0, 0x9C,
+0x01, 0x6A, 0x44, 0xEB, 0x4F, 0xEA, 0xAC, 0xEA,
+0x40, 0xDC, 0x20, 0xE8, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x8C, 0xEA, 0x00, 0xF3, 0x88, 0x9B,
+0x00, 0xF3, 0x08, 0x4B, 0x04, 0xD4, 0x81, 0x9B,
+0x64, 0xAB, 0x05, 0xD4, 0x9D, 0x67, 0x6C, 0xCC,
+0x44, 0x33, 0x6D, 0xE4, 0x88, 0xAB, 0x1F, 0xF7,
+0x00, 0x6B, 0x8C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x01, 0x60, 0x0B, 0x2B, 0x9D, 0x67, 0x44, 0x33,
+0x6D, 0xE4, 0x88, 0xAB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x78, 0x9B, 0x6D, 0xE4, 0x60, 0xAB,
+0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x7C, 0x9B, 0x71, 0xE4, 0x60, 0xAC, 0xFF, 0xF7,
+0x1F, 0x68, 0x6C, 0xE8, 0x18, 0xF0, 0x00, 0x6B,
+0x0C, 0xEB, 0x0F, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xE3, 0xF4, 0x8C, 0xA3,
+0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0x03, 0x6C,
+0x8B, 0xEC, 0x8C, 0xEA, 0xE3, 0xF4, 0x4C, 0xC3,
+0x73, 0x10, 0x08, 0xF0, 0x00, 0x6B, 0x0C, 0xEB,
+0x3F, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA0, 0xF0, 0xD6, 0xA3, 0x7F, 0x6D,
+0xFF, 0x6C, 0xCC, 0xED, 0x02, 0x75, 0x1F, 0x61,
+0xA0, 0xF0, 0x59, 0xA3, 0x01, 0x6D, 0xAC, 0xEA,
+0x8C, 0xEA, 0x06, 0x2A, 0xE3, 0xF4, 0x4C, 0xA3,
+0x4D, 0xED, 0xE3, 0xF4, 0xAC, 0xC3, 0x21, 0x10,
+0xA0, 0xF0, 0xB7, 0xA3, 0x10, 0x6A, 0x4B, 0xEA,
+0xAC, 0xEA, 0x8C, 0xEA, 0x10, 0x72, 0x2B, 0x61,
+0xE3, 0xF4, 0x8C, 0xA3, 0x04, 0x6A, 0x00, 0x6D,
+0x8D, 0xEA, 0xE3, 0xF4, 0x4C, 0xC3, 0x01, 0x6C,
+0x00, 0x18, 0x11, 0x1D, 0x20, 0x10, 0xE3, 0xF4,
+0xCC, 0xA3, 0x01, 0x6D, 0xCD, 0xED, 0xE3, 0xF4,
+0xAC, 0xC3, 0xA0, 0xF0, 0xB7, 0xA3, 0x10, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0x8C, 0xEB, 0x20, 0x73,
+0x03, 0x60, 0x00, 0x18, 0x37, 0x1D, 0x0F, 0x10,
+0x82, 0x67, 0x00, 0x18, 0x55, 0x1A, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE3, 0xF4, 0x8C, 0xA2, 0x02, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xE3, 0xF4, 0x6C, 0xC2, 0x02, 0x30,
+0x1E, 0x30, 0x17, 0x20, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xE3, 0xF4, 0x4C, 0xA0,
+0x02, 0x69, 0xA0, 0xF0, 0xDE, 0xA0, 0x2D, 0xEA,
+0xFF, 0x6C, 0xE3, 0xF4, 0x4C, 0xC0, 0x55, 0x4C,
+0x00, 0x6D, 0x00, 0x18, 0x04, 0x31, 0xE3, 0xF4,
+0x48, 0xA0, 0x4D, 0xE9, 0xE3, 0xF4, 0x28, 0xC0,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xE3, 0xF4, 0x8C, 0xA2, 0x03, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xE3, 0xF4, 0x6C, 0xC2,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x48, 0x9A, 0x60, 0xA2, 0x3D, 0x23, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x54, 0x9A, 0x02, 0x6B, 0x30, 0xF0, 0x20, 0x68,
+0x60, 0xC2, 0x86, 0xF2, 0x00, 0x48, 0xE3, 0xF4,
+0x68, 0xA0, 0x02, 0x6A, 0xFF, 0x6C, 0x6C, 0xEA,
+0x8C, 0xEA, 0x0B, 0x22, 0x03, 0x6A, 0x4B, 0xEA,
+0x4C, 0xEB, 0xE3, 0xF4, 0x68, 0xC0, 0xE3, 0xF4,
+0x6C, 0xA0, 0x6C, 0xEA, 0xE3, 0xF4, 0x4C, 0xC0,
+0x1F, 0x10, 0xE3, 0xF4, 0x53, 0xA0, 0xE3, 0xF4,
+0x6C, 0xA0, 0x01, 0x4A, 0xE3, 0xF4, 0x53, 0xC0,
+0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xE3, 0xF4,
+0x4C, 0xC0, 0xE3, 0xF4, 0x73, 0xA0, 0xA0, 0xF0,
+0x5D, 0xA0, 0x63, 0xEA, 0x0D, 0x60, 0xC0, 0xF0,
+0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13, 0x01, 0x72,
+0x07, 0x61, 0xE3, 0xF4, 0x68, 0xA0, 0x21, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xE3, 0xF4, 0x48, 0xC0,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x00, 0x18, 0x71, 0x14, 0x03, 0x2A,
+0x90, 0x67, 0x00, 0x18, 0x4C, 0x1A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x29, 0x50,
+0x01, 0x72, 0x01, 0x6C, 0x01, 0x60, 0x02, 0x6C,
+0x00, 0x18, 0x98, 0x53, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0x26, 0xF3, 0x15, 0x4C,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0xB4, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x75, 0xA2, 0x03, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEB, 0xA3, 0xF3, 0xA4, 0xA2, 0xA0, 0xF0,
+0x75, 0xC2, 0x02, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB,
+0x8C, 0xEB, 0xA3, 0xF3, 0x64, 0xC2, 0x00, 0x6B,
+0xA3, 0xF3, 0x65, 0xC2, 0x0C, 0x6B, 0xA3, 0xF3,
+0x66, 0xC2, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0, 0x7C, 0x9B,
+0xFF, 0x6A, 0x8C, 0xEA, 0x80, 0xA3, 0x10, 0x6B,
+0x8C, 0xEB, 0x04, 0x23, 0x7F, 0x4A, 0x07, 0x4A,
+0x86, 0x6B, 0x31, 0x10, 0x7F, 0x4A, 0x09, 0x4A,
+0x88, 0x6B, 0x15, 0x10, 0x1F, 0xF7, 0x00, 0x6C,
+0x6C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0x98, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0x9C, 0x9C, 0xC0, 0xA5, 0x91, 0xE3,
+0x01, 0x4D, 0xC0, 0xC4, 0x01, 0x4B, 0x4A, 0xEB,
+0xE9, 0x61, 0x20, 0xE8, 0x1F, 0xF7, 0x00, 0x6C,
+0x6C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0x98, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0x9C, 0x9C, 0xC0, 0xA5, 0x91, 0xE3,
+0x01, 0x4D, 0xC0, 0xC4, 0x01, 0x4B, 0x4A, 0xEB,
+0xE9, 0x61, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xED,
+0xFF, 0x75, 0x4C, 0xEC, 0xCC, 0xEA, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x71, 0xE4, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x71, 0xE4, 0x43, 0xF3,
+0x7B, 0xA4, 0xAC, 0xEA, 0xAF, 0xED, 0x6C, 0xED,
+0xAD, 0xEA, 0x43, 0xF3, 0x5B, 0xC4, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0xFF, 0x74, 0xAC, 0xEA,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0xC9, 0xF5,
+0x59, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x43, 0xF3, 0xB9, 0xA3,
+0x8C, 0xEA, 0x8F, 0xEC, 0xAC, 0xEC, 0x8D, 0xEA,
+0x43, 0xF3, 0x59, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0xC6, 0xF3, 0x02, 0x4C, 0x04, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B, 0x00, 0x6D,
+0x23, 0xF5, 0x72, 0xC2, 0x05, 0x6C, 0xC5, 0x67,
+0x00, 0x18, 0xB4, 0x1D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF7, 0x63, 0x11, 0x62,
+0x10, 0xD1, 0x0F, 0xD0, 0x40, 0xA4, 0x08, 0xD2,
+0x08, 0x93, 0x1F, 0x6A, 0x4C, 0xEB, 0x08, 0xD3,
+0x42, 0xA4, 0x61, 0xA4, 0x0D, 0xD2, 0x43, 0xA4,
+0x84, 0xA4, 0x09, 0xD4, 0x08, 0x94, 0x08, 0x5C,
+0x80, 0xF0, 0x0C, 0x60, 0x84, 0x31, 0x09, 0x94,
+0x01, 0x2C, 0x23, 0x22, 0xFF, 0x68, 0x0C, 0xEA,
+0x0C, 0xEB, 0xA2, 0x67, 0xC3, 0x67, 0x91, 0x67,
+0x0B, 0xD2, 0x0C, 0xD3, 0x00, 0x18, 0xBF, 0x05,
+0x09, 0x93, 0x0D, 0x94, 0x41, 0x41, 0x0C, 0xEA,
+0x0C, 0xEB, 0x8C, 0xE8, 0xA3, 0x67, 0x82, 0x67,
+0xD0, 0x67, 0x0A, 0xD2, 0x09, 0xD3, 0x00, 0x18,
+0xBF, 0x05, 0x0B, 0x95, 0x0C, 0x96, 0x91, 0x67,
+0x01, 0x6F, 0x00, 0x18, 0x75, 0x07, 0x0A, 0x94,
+0x09, 0x95, 0xD0, 0x67, 0x02, 0x6F, 0x00, 0x18,
+0x75, 0x07, 0x0F, 0x59, 0x08, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x28, 0x33, 0xE0, 0xF5, 0x00, 0x4A,
+0x69, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x00, 0x6A,
+0x44, 0x10, 0xD0, 0xF4, 0x44, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF4, 0x4C, 0x9A, 0x34, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x4C, 0x9A,
+0x2F, 0x10, 0x80, 0xF4, 0x44, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF4, 0x50, 0x9A, 0x24, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x58, 0x9A,
+0x1F, 0x10, 0xC0, 0xF4, 0x48, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF4, 0x54, 0x9A, 0x14, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x58, 0x9A,
+0x0F, 0x10, 0x70, 0xF4, 0x48, 0x41, 0x1F, 0xF7,
+0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF4, 0x5C, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4, 0x40, 0x9A,
+0x49, 0xE1, 0x60, 0xAA, 0xFF, 0xF7, 0x1F, 0x6A,
+0x6C, 0xEA, 0x7D, 0x67, 0x53, 0xC3, 0x42, 0x32,
+0x54, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x45, 0xE1, 0x43, 0xF3, 0x5B, 0xA1,
+0x55, 0xC3, 0x43, 0xF3, 0x5C, 0xA1, 0x56, 0xC3,
+0x63, 0xF3, 0x4B, 0xA1, 0x57, 0xC3, 0x63, 0xF3,
+0x4C, 0xA1, 0x58, 0xC3, 0x9D, 0x67, 0x21, 0x6A,
+0x50, 0xC4, 0x07, 0x6A, 0x4F, 0xCC, 0x47, 0x44,
+0x19, 0x4A, 0x40, 0xA2, 0x52, 0xC4, 0x04, 0x04,
+0x00, 0x18, 0xBC, 0x27, 0x11, 0x97, 0x10, 0x91,
+0x0F, 0x90, 0x09, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x01, 0xA4, 0x20, 0xA4, 0x09, 0x20, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0xCC, 0x05, 0x90, 0x67,
+0xB1, 0x67, 0x53, 0x6E, 0x00, 0x18, 0x18, 0x3A,
+0x7D, 0x67, 0x20, 0x6A, 0x50, 0xC3, 0x03, 0x6A,
+0x4F, 0xCB, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x40, 0x9A, 0x9D, 0x67, 0x40, 0xA2, 0x52, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x43, 0xF3, 0x79, 0xA2, 0x43, 0xF3, 0x5A, 0xA2,
+0x73, 0xC4, 0x54, 0xC4, 0x04, 0x04, 0x00, 0x18,
+0xBC, 0x27, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xA2, 0xA4, 0x41, 0xA4, 0x80, 0xA4, 0xA0, 0x35,
+0x55, 0xE5, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED,
+0x00, 0x18, 0xDB, 0x56, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0xA4, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x48,
+0x46, 0xF3, 0x19, 0x4C, 0x07, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0xC0, 0xF0, 0x99, 0xA0, 0x00, 0x18,
+0x61, 0x31, 0xC3, 0xF6, 0x44, 0xA0, 0x1F, 0x6B,
+0x01, 0x6C, 0x4A, 0x32, 0x6C, 0xEA, 0xC0, 0xF0,
+0x79, 0xA0, 0x47, 0xEB, 0x8C, 0xEA, 0x03, 0x22,
+0xC3, 0xF6, 0x65, 0xC0, 0x04, 0x10, 0x01, 0x6A,
+0x4B, 0xEA, 0xC3, 0xF6, 0x45, 0xC0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xC3, 0xF6,
+0x64, 0xA0, 0x02, 0x6A, 0x6C, 0xEA, 0x1A, 0x22,
+0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xC3, 0xF6,
+0x44, 0xC0, 0x00, 0x18, 0x0D, 0x3B, 0x04, 0xD2,
+0x04, 0x93, 0xC3, 0xF6, 0x48, 0x98, 0x6E, 0xEA,
+0x03, 0x22, 0x04, 0x94, 0x00, 0x18, 0x29, 0x3B,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF6, 0x84, 0xA2, 0x02, 0x6B, 0x8D, 0xEB,
+0xC3, 0xF6, 0x64, 0xC2, 0x07, 0x97, 0x06, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2,
+0x00, 0x48, 0x46, 0xF3, 0x04, 0x4C, 0x07, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0xC0, 0xF0, 0x84, 0xA0,
+0xC0, 0xF0, 0x45, 0xA0, 0x01, 0x69, 0xA4, 0x67,
+0xFF, 0x4A, 0x2C, 0xEC, 0xB6, 0x35, 0x63, 0xF5,
+0x44, 0xC0, 0x00, 0x18, 0x58, 0x18, 0xC0, 0xF0,
+0x44, 0xA0, 0x4C, 0xE9, 0x06, 0x29, 0x10, 0xF0,
+0x20, 0x6C, 0x0C, 0xF3, 0x05, 0x4C, 0x00, 0x18,
+0x77, 0x3B, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x04, 0x9A, 0x0A, 0xD4, 0x0A, 0x95,
+0x40, 0xA0, 0xFF, 0x69, 0x30, 0xF0, 0x20, 0x6C,
+0x62, 0x67, 0x2C, 0xEB, 0x26, 0xF3, 0x15, 0x4C,
+0x01, 0x6E, 0x05, 0xD3, 0x00, 0x18, 0xB9, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4, 0x68, 0x9A,
+0xF8, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4, 0x4C, 0x9A,
+0x40, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x44, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF4, 0x70, 0x9B, 0x40, 0xA2, 0x2C, 0xEA,
+0x54, 0x32, 0x01, 0x4A, 0x2C, 0xEA, 0x40, 0xC3,
+0x0A, 0x94, 0x02, 0x6B, 0x40, 0xA4, 0x6C, 0xEA,
+0x2C, 0xEA, 0xA0, 0xF0, 0x0B, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C, 0x04, 0xD4,
+0xA0, 0xF0, 0x75, 0xA4, 0x01, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x80, 0xF0, 0x14, 0x22, 0x01, 0x6C,
+0xC0, 0x6D, 0x00, 0x18, 0x86, 0x09, 0x04, 0x94,
+0x05, 0x92, 0x20, 0x68, 0xA0, 0xF0, 0x75, 0xA4,
+0x4D, 0xE8, 0x04, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x2C, 0xE8, 0x17, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x54, 0x9A, 0x01, 0x6C, 0x10, 0xF0,
+0x00, 0x6D, 0x60, 0xA2, 0x2C, 0xEB, 0x60, 0xC2,
+0x00, 0x18, 0x86, 0x09, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0x02, 0x6C, 0x40, 0xA3,
+0x2C, 0xEA, 0x8D, 0xEA, 0x2C, 0xEA, 0x40, 0xC3,
+0x11, 0x10, 0x04, 0x92, 0x01, 0x6C, 0x10, 0xF0,
+0x00, 0x6D, 0xA3, 0xF3, 0x64, 0xA2, 0x02, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x03, 0x6B, 0x6B, 0xEB,
+0x6C, 0xEA, 0x04, 0x93, 0xA3, 0xF3, 0x44, 0xC3,
+0x00, 0x18, 0xA3, 0x09, 0x30, 0xF0, 0x20, 0x6A,
+0x26, 0xF3, 0x95, 0xA2, 0x08, 0x6A, 0xFF, 0x6B,
+0x8C, 0xEA, 0x0D, 0x22, 0x02, 0x6A, 0x4D, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x90, 0x9A,
+0x01, 0x6D, 0x6C, 0xE8, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF3, 0x95, 0xA2, 0x10, 0x6A,
+0xFF, 0x6B, 0x8C, 0xEA, 0x0D, 0x22, 0x04, 0x6A,
+0x4D, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x90, 0x9A, 0x01, 0x6D, 0x6C, 0xE8, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x75, 0xA2,
+0x20, 0x6A, 0x6C, 0xEA, 0x05, 0x22, 0x80, 0x6A,
+0x4B, 0xEA, 0x4D, 0xE8, 0xFF, 0x6A, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x75, 0xA2,
+0x40, 0x6A, 0x4C, 0xEB, 0x03, 0x2B, 0x4D, 0xE8,
+0xFF, 0x6A, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x44, 0x9A, 0x00, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x29, 0xF6, 0x45, 0xA2, 0x03, 0x2A,
+0x01, 0x6C, 0x00, 0x18, 0x98, 0x53, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF3, 0x75, 0xA2, 0x40, 0x6A,
+0x04, 0x6C, 0x6C, 0xEA, 0x05, 0x2A, 0x00, 0x18,
+0x29, 0x50, 0x01, 0x6C, 0x01, 0x2A, 0x02, 0x6C,
+0x00, 0x18, 0x98, 0x53, 0x98, 0x10, 0x40, 0xC0,
+0x04, 0x94, 0xA3, 0xF3, 0x45, 0xA4, 0x04, 0x72,
+0xA0, 0xF0, 0x13, 0x61, 0x00, 0x6C, 0x00, 0x18,
+0x98, 0x53, 0xAF, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x04, 0xD2, 0xA0, 0xF0,
+0x55, 0xA2, 0x01, 0x6B, 0x6C, 0xEA, 0x2C, 0xEA,
+0x80, 0xF0, 0x08, 0x22, 0x83, 0x67, 0xC0, 0x6D,
+0x00, 0x18, 0x86, 0x09, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x10, 0x4B, 0x60, 0x9B, 0x05, 0x94,
+0x20, 0x68, 0x40, 0xA3, 0x8D, 0xE8, 0x01, 0x6C,
+0x2C, 0xEA, 0x8D, 0xEA, 0x2C, 0xEA, 0x40, 0xC3,
+0x04, 0x94, 0x04, 0x6A, 0x2C, 0xE8, 0xA0, 0xF0,
+0x75, 0xA4, 0x6C, 0xEA, 0x2C, 0xEA, 0x18, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4, 0x54, 0x9A,
+0x01, 0x6C, 0x10, 0xF0, 0x00, 0x6D, 0x60, 0xA2,
+0x2C, 0xEB, 0x60, 0xC2, 0x00, 0x18, 0x86, 0x09,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x10, 0x4B,
+0x60, 0x9B, 0x02, 0x6C, 0x40, 0xA3, 0x2C, 0xEA,
+0x8D, 0xEA, 0x2C, 0xEA, 0x40, 0xC3, 0x05, 0x10,
+0x01, 0x6C, 0x10, 0xF0, 0x00, 0x6D, 0x00, 0x18,
+0xA3, 0x09, 0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3,
+0x75, 0xA2, 0x08, 0x6A, 0x6C, 0xEA, 0x04, 0x22,
+0x02, 0x6A, 0x4D, 0xE8, 0xFF, 0x6A, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x75, 0xA2,
+0x10, 0x6A, 0x6C, 0xEA, 0x04, 0x22, 0x04, 0x6A,
+0x4D, 0xE8, 0xFF, 0x6A, 0x4C, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x64, 0x9A, 0x40, 0x6D,
+0xFF, 0x6C, 0x00, 0xC3, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xA0, 0xF0, 0x55, 0xA0,
+0xAC, 0xEA, 0x07, 0x22, 0xA3, 0xF3, 0x46, 0xA0,
+0x02, 0x72, 0x21, 0x60, 0x02, 0x6C, 0x00, 0x6D,
+0x16, 0x10, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0xA3, 0xF3, 0x46, 0xA0,
+0x02, 0x72, 0x11, 0x61, 0x00, 0x18, 0x11, 0x17,
+0x00, 0x18, 0x29, 0x50, 0x01, 0x72, 0x05, 0x61,
+0xA0, 0xF0, 0x9A, 0xA0, 0x01, 0x6D, 0x00, 0x6E,
+0x03, 0x10, 0x00, 0x6C, 0xA4, 0x67, 0xC5, 0x67,
+0x00, 0x18, 0xD9, 0x17, 0x04, 0x10, 0xE3, 0xF4,
+0x4B, 0xA0, 0xA3, 0xF3, 0x46, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x58, 0x9A, 0x22, 0x6B,
+0x60, 0xC2, 0x1B, 0x10, 0x40, 0xC0, 0x04, 0x94,
+0xA3, 0xF3, 0x46, 0xA4, 0x04, 0x6C, 0x02, 0x72,
+0x03, 0x60, 0x08, 0x72, 0x05, 0x61, 0x0C, 0x6C,
+0x01, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0xD9, 0x17,
+0x00, 0x6C, 0x00, 0x18, 0x7C, 0x05, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF3, 0x9A, 0xA2, 0x01, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0xD9, 0x17, 0x00, 0x18,
+0x8B, 0x05, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x0B, 0x19, 0x90, 0x67, 0x00, 0x18,
+0x96, 0x3F, 0x01, 0x6C, 0x00, 0x18, 0x9D, 0x16,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF3, 0x63, 0xA2,
+0x07, 0x6A, 0x6C, 0xEA, 0x0E, 0xEA, 0x02, 0x2A,
+0x00, 0x18, 0x50, 0x25, 0x90, 0x67, 0x00, 0x18,
+0xA4, 0x18, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x27, 0x67,
+0x4C, 0xE9, 0x6F, 0x41, 0x4C, 0xEB, 0x04, 0x67,
+0x02, 0x5B, 0x4C, 0xE8, 0x4C, 0xED, 0x4C, 0xEE,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x8C, 0x38,
+0x10, 0x58, 0x55, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x08, 0x33, 0xC0, 0xF6, 0x00, 0x4A, 0x69, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0xD0, 0xF4, 0x44, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x6C, 0x9A,
+0x34, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x6C, 0x9A, 0x2F, 0x10, 0x80, 0xF4, 0x44, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x70, 0x9A,
+0x24, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x78, 0x9A, 0x1F, 0x10, 0xC0, 0xF4, 0x48, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x74, 0x9A,
+0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4,
+0x78, 0x9A, 0x0F, 0x10, 0x70, 0xF4, 0x48, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4, 0x7C, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x6D, 0xE0, 0x41, 0xE0, 0x43, 0xF3,
+0x9B, 0xA0, 0x63, 0xF3, 0x4B, 0xA0, 0x8D, 0xEA,
+0xFF, 0x6C, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xC9, 0xF5, 0x38, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x30, 0xF0, 0x20, 0x6A, 0x10, 0xF0, 0x20, 0x6B,
+0x40, 0xF0, 0x08, 0x4A, 0x60, 0xF7, 0x05, 0x4B,
+0x62, 0xDA, 0x10, 0xF0, 0x20, 0x6B, 0x40, 0xF7,
+0x15, 0x4B, 0x63, 0xDA, 0x10, 0xF0, 0x20, 0x6B,
+0x40, 0xF7, 0x05, 0x4B, 0x64, 0xDA, 0x10, 0xF0,
+0x20, 0x6B, 0x20, 0xF7, 0x15, 0x4B, 0x65, 0xDA,
+0x10, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x05, 0x4B,
+0x66, 0xDA, 0x10, 0xF0, 0x20, 0x6B, 0x00, 0xF7,
+0x15, 0x4B, 0x67, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xC9, 0xF5, 0x10, 0x4A,
+0x67, 0x42, 0x00, 0x6C, 0x80, 0xC2, 0x01, 0x4A,
+0x6A, 0xEA, 0xFB, 0x61, 0x42, 0xF4, 0x10, 0x6A,
+0x1F, 0xF7, 0x00, 0x6B, 0x4C, 0xEB, 0x02, 0xF0,
+0x00, 0x73, 0x01, 0x60, 0x05, 0x2B, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x78, 0x9B, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x7C, 0x9B,
+0x6D, 0xE2, 0x04, 0x4A, 0x00, 0x6C, 0x62, 0xF4,
+0x00, 0x72, 0x80, 0xDB, 0xE9, 0x61, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF1, 0x50, 0x9A, 0x03, 0x6D, 0xFF, 0x6B,
+0x80, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1,
+0x54, 0x9A, 0x00, 0xF5, 0x82, 0x34, 0xAC, 0xEC,
+0x40, 0x9A, 0x01, 0x74, 0x42, 0x32, 0x52, 0x32,
+0xAC, 0xEA, 0x06, 0x60, 0x0A, 0x2C, 0x02, 0x5A,
+0x28, 0x6C, 0x0D, 0x60, 0x50, 0x6C, 0x0B, 0x10,
+0x02, 0x5A, 0x14, 0x6C, 0x08, 0x60, 0x28, 0x6C,
+0x04, 0x10, 0x02, 0x5A, 0x0A, 0x6C, 0x03, 0x60,
+0x14, 0x6C, 0x84, 0xEA, 0x6C, 0xEC, 0x00, 0x18,
+0x2F, 0x0A, 0x00, 0x18, 0x96, 0x1D, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF0, 0x60, 0x9B, 0x00, 0x6A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF0, 0x74, 0x9B, 0x40, 0xC3, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x00, 0x69, 0xA0, 0xF0,
+0x24, 0xD8, 0x80, 0xF1, 0x2C, 0xC0, 0x00, 0x18,
+0xB0, 0x07, 0x00, 0x18, 0xD3, 0x08, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0x23, 0xF2,
+0x28, 0xC0, 0xC9, 0xF5, 0x1B, 0x4A, 0xE9, 0xF5,
+0x0B, 0x4C, 0x00, 0x6B, 0x60, 0xC2, 0x70, 0xC2,
+0x01, 0x4A, 0x62, 0x67, 0x8E, 0xEB, 0xF9, 0x2B,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x43, 0xF3, 0x78, 0xC2, 0x43, 0xF3, 0x79, 0xC2,
+0x43, 0xF3, 0x7A, 0xC2, 0x43, 0xF3, 0x77, 0xC2,
+0x00, 0x18, 0x58, 0x0A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6C,
+0xC6, 0xF3, 0x09, 0x4C, 0x00, 0x6D, 0x04, 0x6E,
+0x00, 0x18, 0xB4, 0x20, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x00, 0x18, 0xC2, 0x07, 0x00, 0x18, 0x3B, 0x08,
+0x00, 0x18, 0x5E, 0x0A, 0x00, 0x18, 0xE4, 0x5F,
+0x00, 0x18, 0x2E, 0x3A, 0x00, 0x18, 0xA8, 0x22,
+0x00, 0x18, 0x72, 0x42, 0x00, 0x18, 0x6D, 0x22,
+0x00, 0x18, 0xD1, 0x19, 0x00, 0x18, 0xCA, 0x19,
+0x00, 0x18, 0x8B, 0x05, 0x00, 0x18, 0x53, 0x54,
+0x00, 0x18, 0x87, 0x4A, 0x00, 0x18, 0xF9, 0x4F,
+0x00, 0x18, 0x8C, 0x3C, 0x00, 0x18, 0x8C, 0x30,
+0x00, 0x18, 0x72, 0x3C, 0x10, 0xF0, 0x21, 0x6C,
+0x01, 0x6F, 0x1D, 0xF4, 0x1D, 0x4C, 0x00, 0x6D,
+0x64, 0x6E, 0xEB, 0xEF, 0x01, 0x6A, 0x04, 0xD2,
+0x00, 0x18, 0x8A, 0x3B, 0x00, 0x18, 0x0E, 0x08,
+0x00, 0x18, 0x5A, 0x3C, 0x07, 0x97, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6A,
+0x30, 0xF0, 0x21, 0x6B, 0xD0, 0xF6, 0x01, 0x4A,
+0xF0, 0xF7, 0x1C, 0x4B, 0x2C, 0x6C, 0x80, 0xC2,
+0x00, 0x6C, 0x81, 0xC2, 0x40, 0x6C, 0x8B, 0xEC,
+0x82, 0xC2, 0x05, 0x4A, 0x6A, 0xEA, 0xF6, 0x61,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B, 0x80, 0xF6,
+0x6E, 0xC2, 0x80, 0xF6, 0x6F, 0xC2, 0x80, 0xF1,
+0x6C, 0xC2, 0x80, 0xF1, 0x6D, 0xC2, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xA6, 0xF3,
+0x59, 0xA0, 0x0B, 0x2A, 0xE0, 0xF3, 0x1A, 0x6C,
+0x04, 0x05, 0x00, 0x18, 0xC1, 0x43, 0x9D, 0x67,
+0x70, 0xA4, 0x07, 0x6A, 0x6C, 0xEA, 0xA6, 0xF3,
+0x59, 0xC0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xA6, 0xF3, 0x5B, 0xA0, 0x0A, 0x2A,
+0xE0, 0xF3, 0x1A, 0x6C, 0x04, 0x05, 0x00, 0x18,
+0xC1, 0x43, 0x7D, 0x67, 0x50, 0xA3, 0x56, 0x32,
+0xA6, 0xF3, 0x5B, 0xC0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xA6, 0xF3, 0x5C, 0xA0,
+0x0B, 0x2A, 0xE0, 0xF3, 0x1D, 0x6C, 0x04, 0x05,
+0x00, 0x18, 0xC1, 0x43, 0x9D, 0x67, 0x70, 0xA4,
+0x03, 0x6A, 0x6C, 0xEA, 0xA6, 0xF3, 0x5C, 0xC0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xA6, 0xF3, 0x5D, 0xA0, 0x0C, 0x2A, 0xE0, 0xF3,
+0x1D, 0x6C, 0x04, 0x05, 0x00, 0x18, 0xC1, 0x43,
+0x7D, 0x67, 0x50, 0xA3, 0x30, 0x6B, 0x6C, 0xEA,
+0x53, 0x32, 0xA6, 0xF3, 0x5D, 0xC0, 0x07, 0x97,
+0x06, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x04, 0x01, 0x04, 0x67, 0xB1, 0x67, 0xE0, 0xF3,
+0x10, 0x6C, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x11, 0x6C,
+0x40, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x12, 0x6C,
+0x41, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x13, 0x6C,
+0x42, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x1C, 0x6C,
+0x43, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0x09, 0x97, 0x08, 0x91, 0x44, 0xC0,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x04, 0x01, 0x04, 0x67, 0xB1, 0x67, 0xE0, 0xF3,
+0x14, 0x6C, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x15, 0x6C,
+0x40, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x16, 0x6C,
+0x41, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x17, 0x6C,
+0x42, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x18, 0x6C,
+0x43, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x19, 0x6C,
+0x44, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0x09, 0x97, 0x08, 0x91, 0x45, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA6, 0xF3, 0x7A, 0xA2, 0xA6, 0xF3, 0x9B, 0xA2,
+0x6C, 0x33, 0x94, 0x34, 0x8D, 0xEB, 0xA6, 0xF3,
+0x99, 0xA2, 0x8D, 0xEB, 0x66, 0xC0, 0xA6, 0xF3,
+0x7C, 0xA2, 0xA6, 0xF3, 0x5D, 0xA2, 0x68, 0x33,
+0x58, 0x32, 0x4D, 0xEB, 0x33, 0x6A, 0x4D, 0xEB,
+0x67, 0xC0, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD0, 0x04, 0x00,
+0x90, 0x67, 0x00, 0x18, 0x84, 0x08, 0xA0, 0xF1,
+0x02, 0x6A, 0x1F, 0xF7, 0x00, 0x6B, 0x4C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x05, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x78, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x7C, 0x9B, 0x80, 0xA0, 0x6D, 0xE2, 0x01, 0x4A,
+0xA0, 0xF1, 0x0A, 0x72, 0x80, 0xC3, 0x01, 0x48,
+0xE8, 0x61, 0x04, 0x00, 0x90, 0x67, 0x00, 0x18,
+0x6A, 0x08, 0xA0, 0xF1, 0x0A, 0x6A, 0x1F, 0xF7,
+0x00, 0x6B, 0x4C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x01, 0x60, 0x05, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x78, 0x9B, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x7C, 0x9B, 0x80, 0xA0,
+0x6D, 0xE2, 0x01, 0x4A, 0xA0, 0xF1, 0x0F, 0x72,
+0x80, 0xC3, 0x01, 0x48, 0xE8, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF4, 0x4C, 0x9A, 0x19, 0x6B,
+0x60, 0xC2, 0x09, 0x97, 0x08, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xA6, 0xF3, 0x78, 0xA0,
+0x01, 0x6A, 0x04, 0x01, 0x6D, 0xEA, 0x02, 0x6B,
+0x6D, 0xEA, 0x04, 0x6B, 0x6D, 0xEA, 0x08, 0x6B,
+0x6D, 0xEA, 0xE0, 0xF3, 0x1B, 0x6C, 0xB1, 0x67,
+0xA6, 0xF3, 0x58, 0xC0, 0x00, 0x18, 0xC1, 0x43,
+0x9D, 0x67, 0x70, 0xA4, 0x07, 0x6A, 0xE0, 0xF3,
+0x1D, 0x6C, 0x6C, 0xEA, 0xA6, 0xF3, 0x59, 0xC0,
+0x18, 0x6A, 0x6C, 0xEA, 0x4F, 0x32, 0x76, 0x33,
+0xB1, 0x67, 0xA6, 0xF3, 0x7B, 0xC0, 0xA6, 0xF3,
+0x5A, 0xC0, 0x00, 0x18, 0xC1, 0x43, 0x5D, 0x67,
+0x70, 0xA2, 0x0C, 0x6A, 0x6C, 0xEA, 0x4B, 0x32,
+0x7A, 0x33, 0xA6, 0xF3, 0x5C, 0xC0, 0xA6, 0xF3,
+0x7D, 0xC0, 0x00, 0x18, 0x42, 0x08, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF4, 0x4C, 0x9A, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0xFD, 0x72, 0x02, 0x61,
+0x00, 0x18, 0xAE, 0x08, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7, 0x4C, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5, 0x88, 0x9A,
+0xFF, 0x6B, 0x20, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF7, 0x98, 0x9A, 0x08, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF5, 0x6C, 0x9A, 0xFD, 0x6A, 0xFF, 0x6C,
+0xA0, 0xA3, 0xAC, 0xEA, 0x40, 0xC3, 0x40, 0xA3,
+0x01, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x52, 0x9B, 0x8D, 0xEA,
+0x52, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5,
+0x70, 0x9B, 0x80, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF5, 0x74, 0x9B, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xB2, 0x9B, 0x8F, 0xEA, 0xAC, 0xEA, 0x52, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5, 0x74, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5,
+0x50, 0x9A, 0x80, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x05, 0x5C, 0x5E, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0x00, 0xF6, 0x1C, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x40, 0x9B, 0xAD, 0xEA, 0x86, 0xF2,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF4,
+0x6C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF5, 0x78, 0x9B, 0x32, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x41, 0x9B,
+0xAD, 0xEA, 0x41, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF5, 0x7C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF5, 0x60, 0x9B, 0x21, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x42, 0x9B, 0xAD, 0xEA, 0x42, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF5, 0x64, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x68, 0x9B,
+0x10, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0x43, 0x9B, 0xAD, 0xEA, 0x43, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x6C, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5,
+0x70, 0x9B, 0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x44, 0x9B,
+0xAD, 0xEA, 0x44, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x74, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF5, 0x78, 0x9B, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x05, 0x5C, 0x63, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x88, 0x34, 0x20, 0xF6,
+0x10, 0x4A, 0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x80, 0x9B,
+0xAF, 0xEA, 0x8C, 0xEA, 0x86, 0xF2, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5, 0x78, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x4C, 0x9A, 0x35, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x81, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x41, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x60, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF5, 0x5C, 0x9A, 0x23, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x82, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x42, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x68, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x44, 0x9A, 0x11, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x83, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x43, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x70, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x4C, 0x9A, 0xA0, 0xDA,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0x84, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA,
+0x44, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5,
+0x78, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF5, 0x54, 0x9A, 0xA0, 0xDA, 0x20, 0xE8,
+0x01, 0x74, 0x15, 0x60, 0x03, 0x24, 0x02, 0x74,
+0x23, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x54, 0x9B, 0xAD, 0xEA,
+0x54, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x74, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x7C, 0x9B, 0x21, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x55, 0x9B,
+0xAD, 0xEA, 0x55, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF4, 0x74, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF5, 0x60, 0x9B, 0x10, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x56, 0x9B, 0xAD, 0xEA, 0x56, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF5, 0x64, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF5, 0x68, 0x9B,
+0x40, 0xDB, 0x20, 0xE8, 0x01, 0x74, 0x16, 0x60,
+0x03, 0x24, 0x02, 0x74, 0x25, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x94, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x54, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x7C, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x54, 0x9A, 0x23, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x95, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x55, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF5, 0x60, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x54, 0x9A, 0x11, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x96, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x56, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF5, 0x68, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF5,
+0x44, 0x9A, 0xA0, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF5, 0x98, 0x9C,
+0x00, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x40, 0xDB, 0x86, 0xF2, 0x00, 0x4B, 0x41, 0xDB,
+0x42, 0xDB, 0x43, 0xDB, 0x44, 0xDB, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF5, 0x80, 0x9C,
+0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF5,
+0x88, 0x9C, 0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF5, 0x90, 0x9C, 0x40, 0xDC, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF5, 0x98, 0x9C, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF5, 0x9C, 0x9C,
+0x54, 0xDB, 0x55, 0xDB, 0x40, 0xDC, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF5, 0x80, 0x9C, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF5, 0x88, 0x9C,
+0x56, 0xDB, 0x40, 0xDC, 0x52, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF5, 0x74, 0x9B, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF4, 0x6C, 0x9B, 0x01, 0x6A, 0x4B, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5,
+0x7C, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x64, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF5, 0x6C, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x74, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x74, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF4, 0x74, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF5, 0x64, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5, 0x70, 0x9B,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF5, 0xAC, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF3, 0x12, 0x6E, 0x86, 0xF2, 0xC0, 0xDB,
+0x01, 0xF7, 0x01, 0x6A, 0x86, 0xF2, 0x00, 0x4B,
+0x00, 0x6C, 0x42, 0xDB, 0x43, 0xDB, 0xA1, 0xDB,
+0x84, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5,
+0x78, 0x9B, 0xC0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF5, 0x60, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF5, 0x68, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF5, 0x70, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x58, 0x9A, 0x80, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x80, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xC6, 0xF2,
+0x48, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5,
+0x74, 0x9B, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF5, 0xB0, 0x9B,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF5, 0x94, 0x9B,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xFF, 0x6B, 0xB4, 0xDA, 0x95, 0xDA, 0x76, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x5C, 0x9A,
+0xA0, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF5,
+0x40, 0x9A, 0x80, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF5, 0x48, 0x9A, 0x60, 0xDA, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xC2, 0x09,
+0x00, 0x18, 0xE1, 0x09, 0x00, 0x18, 0xF9, 0x09,
+0x00, 0x18, 0x16, 0x0A, 0x00, 0x18, 0x10, 0x0A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x54, 0x20, 0x00, 0x18, 0x8A, 0x20,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x0C, 0x9A, 0x00, 0x6D,
+0x02, 0xF0, 0x00, 0x6E, 0x90, 0x67, 0x00, 0x18,
+0xB4, 0x20, 0x04, 0x6A, 0x40, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x4C, 0x9A, 0x20, 0x48,
+0x0E, 0xEA, 0xF7, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x8C, 0x9A, 0x00, 0x6D, 0x00, 0xF4,
+0x00, 0x6E, 0x00, 0x18, 0xB4, 0x20, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x6C, 0x0A,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x22, 0xF6, 0x40, 0xC3, 0x00, 0x6A, 0x22, 0xF6,
+0x41, 0xC3, 0x00, 0x18, 0x07, 0x09, 0x00, 0x18,
+0xD2, 0x0A, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF5,
+0x58, 0x9A, 0x3F, 0x6B, 0x60, 0xC2, 0x00, 0x18,
+0xF8, 0x08, 0x00, 0x18, 0xFC, 0x08, 0x00, 0x18,
+0xF4, 0x35, 0x00, 0x18, 0x34, 0x0A, 0x00, 0x18,
+0x76, 0x0A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x00, 0x6B, 0x83, 0xF3, 0x70, 0xC2, 0x05, 0x6B,
+0x83, 0xF3, 0x78, 0xCA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF6, 0x5C, 0x9A,
+0xE0, 0xF1, 0x1B, 0x6B, 0x6B, 0xEB, 0x60, 0xCA,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x68, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF6, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7, 0x88, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF6, 0x50, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6B, 0x40, 0xAA, 0x4C, 0xEB,
+0x62, 0x33, 0x07, 0x6A, 0x72, 0x33, 0x4C, 0xEB,
+0x02, 0x6A, 0x04, 0x23, 0x01, 0x73, 0x01, 0x6A,
+0x01, 0x60, 0x03, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF6, 0x5C, 0x9A,
+0xE5, 0xF6, 0x1F, 0x6B, 0xFF, 0x6C, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF6, 0x40, 0x9A,
+0x10, 0x6B, 0x40, 0x6D, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF6, 0x44, 0x9A, 0x01, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6,
+0x58, 0x9A, 0x60, 0xA2, 0x8C, 0xEB, 0xAD, 0xEB,
+0x8C, 0xEB, 0x60, 0xC2, 0x60, 0xA2, 0x07, 0x6D,
+0x8C, 0xEB, 0xAD, 0xEB, 0x8C, 0xEB, 0x60, 0xC2,
+0x80, 0xA2, 0xEF, 0x6B, 0x8C, 0xEB, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF6, 0x48, 0x9A,
+0x00, 0xF2, 0x01, 0x6C, 0x8B, 0xEC, 0x60, 0x9A,
+0x8C, 0xEB, 0x60, 0xDA, 0x60, 0x9A, 0x00, 0xF1,
+0x00, 0x4C, 0x8C, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF6, 0x6C, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xC0, 0xF7, 0x80, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF6, 0x50, 0x9A, 0x60, 0xA2, 0x04, 0x5B,
+0x02, 0x60, 0x04, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF6, 0x58, 0x9A, 0x7F, 0x6B,
+0x80, 0xA2, 0x8C, 0xEB, 0x60, 0xC2, 0x80, 0xA2,
+0xF7, 0x6B, 0x8C, 0xEB, 0x60, 0xC2, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x6C, 0x10, 0xF0,
+0x00, 0x6D, 0x00, 0x18, 0xB3, 0x40, 0x05, 0x97,
+0x01, 0x5A, 0x58, 0x67, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xA5, 0xF2, 0x01, 0x4A, 0x40, 0xDB,
+0x00, 0x68, 0x2E, 0x10, 0x82, 0xF3, 0x08, 0x70,
+0x1A, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0x60, 0x9A, 0x02, 0xF0, 0x00, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF6, 0x5C, 0x9A, 0x03, 0x6B,
+0x6B, 0xEB, 0x60, 0xC2, 0x15, 0x10, 0xFF, 0xF7,
+0x1F, 0x6A, 0x01, 0x48, 0x4C, 0xE8, 0x14, 0x6C,
+0x00, 0x18, 0x95, 0x20, 0x33, 0x58, 0x08, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5, 0x40, 0x9A,
+0x60, 0xA2, 0x08, 0x6A, 0x6C, 0xEA, 0x04, 0x2A,
+0x00, 0x18, 0xA2, 0x0A, 0x01, 0x72, 0xCE, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF6, 0x5C, 0x9A,
+0x02, 0x6B, 0x6B, 0xEB, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xA5, 0xF2, 0x02, 0x4A, 0x40, 0xDB,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF6, 0x6C, 0x9A, 0x02, 0x6C, 0xFF, 0xF7,
+0x1F, 0x6D, 0x40, 0x9B, 0xFF, 0x6E, 0x41, 0x4E,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF7, 0x60, 0x9A, 0xE0, 0xF3, 0x1E, 0x4C,
+0x40, 0xAB, 0xAC, 0xEA, 0x8D, 0xEA, 0xAC, 0xEA,
+0x40, 0xCB, 0x02, 0x6C, 0x00, 0x18, 0xCB, 0x40,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x00, 0x6C,
+0xC4, 0x67, 0x0C, 0xF0, 0x00, 0x6D, 0x00, 0x18,
+0xCB, 0x40, 0x00, 0x6C, 0x01, 0xF0, 0x00, 0x6D,
+0x01, 0x6E, 0x00, 0x18, 0xCB, 0x40, 0x10, 0xF0,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x6C, 0x00, 0x18,
+0xCB, 0x40, 0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xAA, 0x35, 0x01, 0x6A, 0x18, 0x10, 0xC0, 0x9C,
+0x1F, 0xF7, 0x00, 0x6B, 0xE1, 0x9C, 0xCC, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x05, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x78, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x7C, 0x9B, 0x79, 0xE6, 0xFF, 0x6B, 0xEC, 0xEB,
+0x60, 0xC6, 0x02, 0x4A, 0x08, 0x4C, 0xA3, 0xEA,
+0xE6, 0x61, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF3, 0x44, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF7, 0x8C, 0x9C, 0x60, 0x9A, 0x8C, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9A,
+0x21, 0xF7, 0x90, 0x9C, 0x8C, 0xEB, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x50, 0x9A,
+0x11, 0x6C, 0x8B, 0xEC, 0x60, 0x9A, 0x8C, 0xEB,
+0x60, 0xDA, 0x60, 0x9A, 0x08, 0x6C, 0x8D, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF7,
+0x54, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF0,
+0x94, 0x9C, 0x60, 0x9A, 0x8D, 0xEB, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9A, 0x21, 0xF7,
+0x98, 0x9C, 0x8C, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF7, 0x7C, 0x9A, 0x03, 0x6C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF7, 0x40, 0x9A, 0x77, 0x6B,
+0xE0, 0xF7, 0x1D, 0x4C, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF7, 0x64, 0x9A, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x64, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6C, 0x03, 0x6D, 0x40, 0xAB,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xCB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF2, 0x60, 0x9B,
+0x07, 0x6A, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF6, 0x7C, 0x9B, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF3, 0x64, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF7, 0x88, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0xC0, 0xF7, 0x88, 0x9C, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF7, 0x74, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF7, 0x8C, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x70, 0x9A, 0x05, 0x6C,
+0x8B, 0xEC, 0x40, 0x9B, 0x8C, 0xEA, 0x04, 0x6C,
+0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF7, 0x60, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6C, 0x00, 0xF2, 0x00, 0x6D,
+0x40, 0xAB, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2,
+0x44, 0x9A, 0x24, 0x6B, 0x6B, 0xEB, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF7, 0x70, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF0, 0x90, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF7, 0x74, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xA0, 0xF7, 0x88, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0x1F, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0, 0x84, 0x9B,
+0x03, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF2, 0x80, 0x9B, 0x07, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xC4, 0x41, 0xF7, 0x78, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF7, 0x9C, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x64, 0x9A, 0xFC, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x60, 0x9A, 0xF8, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF7, 0x78, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF7, 0x80, 0x9C, 0x40, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xA8, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x03, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xA8, 0x9A,
+0x01, 0xF0, 0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xAA, 0x35, 0x04, 0xD5, 0x04, 0x67, 0x01, 0x69,
+0x08, 0x10, 0x80, 0xA8, 0xC1, 0x98, 0x01, 0x6D,
+0xAB, 0xED, 0x00, 0x18, 0x86, 0x36, 0x02, 0x49,
+0x08, 0x48, 0x04, 0x92, 0x43, 0xE9, 0xF5, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xAA, 0x35, 0x04, 0xD5,
+0x04, 0x67, 0x01, 0x69, 0x08, 0x10, 0x80, 0xA8,
+0xC1, 0x98, 0x01, 0x6D, 0xAB, 0xED, 0x00, 0x18,
+0x86, 0x36, 0x02, 0x49, 0x08, 0x48, 0x04, 0x92,
+0x43, 0xE9, 0xF5, 0x61, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xAA, 0x35, 0x24, 0x67, 0x04, 0xD5, 0x00, 0x68,
+0x14, 0x10, 0x08, 0x33, 0x6D, 0xE1, 0x60, 0x9B,
+0x48, 0x34, 0x91, 0xE1, 0xE1, 0xF7, 0x1E, 0x73,
+0xE0, 0x9C, 0x02, 0x61, 0x02, 0x67, 0x09, 0x10,
+0xFF, 0xF7, 0x1F, 0x6D, 0x01, 0x6E, 0x01, 0x6C,
+0x6C, 0xED, 0xCB, 0xEE, 0x00, 0x18, 0xC5, 0x37,
+0x02, 0x48, 0x04, 0x93, 0x41, 0x40, 0x63, 0xEA,
+0xE8, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xAA, 0x35, 0x24, 0x67,
+0x04, 0xD5, 0x00, 0x68, 0x14, 0x10, 0x08, 0x33,
+0x6D, 0xE1, 0x60, 0x9B, 0x48, 0x34, 0x91, 0xE1,
+0xE1, 0xF7, 0x1E, 0x73, 0xE0, 0x9C, 0x02, 0x61,
+0x02, 0x67, 0x09, 0x10, 0xFF, 0xF7, 0x1F, 0x6D,
+0x01, 0x6E, 0x00, 0x6C, 0x6C, 0xED, 0xCB, 0xEE,
+0x00, 0x18, 0xC5, 0x37, 0x02, 0x48, 0x04, 0x93,
+0x41, 0x40, 0x63, 0xEA, 0xE8, 0x61, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0xE0, 0xF3, 0x10, 0x6C,
+0x04, 0x05, 0x00, 0x18, 0xC1, 0x43, 0x7D, 0x67,
+0x50, 0x83, 0x00, 0x52, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF7, 0x50, 0x9A, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0xA5, 0x72, 0x10, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF7, 0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x4C, 0x9A, 0x60, 0xDA, 0xF0, 0x17,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x70, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x4C, 0x9A, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF0, 0x00, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0xEF, 0x9A, 0x60, 0xF7, 0x74, 0x9B,
+0xCE, 0x9A, 0xAD, 0x9A, 0x8C, 0x9A, 0xE0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x78, 0x9B,
+0xC0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x7C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF7, 0x60, 0x9B, 0x80, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x89, 0x9A, 0x80, 0xF7, 0x64, 0x9B,
+0x80, 0xDB, 0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF7, 0x48, 0x9A, 0x60, 0xDA, 0x00, 0x18,
+0x9D, 0x20, 0x00, 0x18, 0x15, 0x0E, 0xFF, 0x17,
+0x71, 0xAC, 0x4A, 0x9C, 0x6A, 0x33, 0x68, 0x33,
+0x6D, 0xE2, 0x04, 0x6A, 0x6C, 0xEA, 0x01, 0x22,
+0xFC, 0x4B, 0x48, 0x43, 0xC8, 0x4A, 0xC2, 0x67,
+0x00, 0x6F, 0xE0, 0xDE, 0x04, 0x4E, 0x6A, 0xEE,
+0xFB, 0x61, 0x04, 0x6B, 0x60, 0xDA, 0xA1, 0xDA,
+0x67, 0x9C, 0x66, 0xDA, 0x40, 0x4A, 0x49, 0xDC,
+0xAB, 0xDC, 0x20, 0xE8, 0x49, 0x9C, 0x10, 0x4A,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x05, 0x67, 0x00, 0x18, 0x03, 0x0C,
+0x00, 0xDA, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x05, 0x67, 0x26, 0x67,
+0x00, 0x18, 0x03, 0x0C, 0x40, 0x9A, 0x00, 0xDA,
+0x21, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x60, 0xA4, 0xC2, 0xA5,
+0x41, 0x9C, 0x02, 0x10, 0x82, 0x67, 0x41, 0x9A,
+0x03, 0x22, 0xE2, 0xA2, 0xC3, 0xEF, 0xFA, 0x60,
+0xFF, 0x4B, 0xFF, 0x6E, 0xCC, 0xEB, 0x03, 0x5B,
+0x41, 0xDD, 0xA1, 0xDC, 0x04, 0x60, 0x01, 0x22,
+0xA2, 0xDA, 0x82, 0xDD, 0x20, 0xE8, 0x00, 0x6A,
+0x42, 0xDD, 0x20, 0xE8, 0x41, 0x9C, 0xFF, 0x6D,
+0x61, 0x9A, 0x61, 0xDC, 0x60, 0xA4, 0xFF, 0x4B,
+0xAC, 0xEB, 0x03, 0x5B, 0x08, 0x60, 0x61, 0x9A,
+0x03, 0x23, 0x82, 0xDB, 0x00, 0x6B, 0x61, 0xDA,
+0x00, 0x6B, 0x62, 0xDA, 0x20, 0xE8, 0x00, 0x6B,
+0x61, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x21, 0x6A,
+0x91, 0xF1, 0x10, 0x4A, 0x61, 0x9A, 0x61, 0xDC,
+0x00, 0x6B, 0x62, 0xDC, 0x81, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x21, 0x6B, 0x91, 0xF1, 0x10, 0x4B,
+0x30, 0xF0, 0x21, 0x6C, 0x41, 0x9B, 0xD1, 0xF1,
+0x88, 0x9C, 0xA2, 0xA2, 0x82, 0xA4, 0xAE, 0xEC,
+0x02, 0x24, 0x00, 0x6A, 0x20, 0xE8, 0x81, 0x9A,
+0x81, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x21, 0x6B,
+0xB1, 0xF1, 0x04, 0x4B, 0xC3, 0x9B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEA, 0x00, 0x6D, 0x04, 0x26,
+0xA1, 0xAB, 0x0D, 0x10, 0xC3, 0x9B, 0x08, 0x2E,
+0x00, 0x6E, 0xAB, 0xE2, 0xC3, 0xDC, 0x83, 0xDB,
+0x64, 0xDC, 0x4A, 0xCB, 0xCA, 0xCC, 0x20, 0xE8,
+0x66, 0x67, 0xCA, 0xAE, 0xD5, 0xE5, 0x43, 0xED,
+0xF1, 0x61, 0xC3, 0x9B, 0xC3, 0xDC, 0x83, 0xDB,
+0xC3, 0x9C, 0x64, 0xDC, 0x01, 0x26, 0x84, 0xDE,
+0x4B, 0xE5, 0x4A, 0xCC, 0xAA, 0xAB, 0x4B, 0xE5,
+0x4A, 0xCB, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x21, 0x6A, 0xB1, 0xF1,
+0x04, 0x4A, 0x63, 0x9A, 0x3C, 0x23, 0x61, 0xAA,
+0xFF, 0x4B, 0x61, 0xCA, 0x30, 0x10, 0x42, 0x98,
+0x09, 0x22, 0x81, 0x98, 0x81, 0xDA, 0x41, 0x98,
+0x03, 0x22, 0x82, 0x98, 0x82, 0xDA, 0x61, 0xD8,
+0x00, 0x6A, 0x42, 0xD8, 0x30, 0xF0, 0x21, 0x6C,
+0x91, 0xF1, 0x10, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x13, 0x0C, 0x6A, 0xA8, 0x30, 0xF0, 0x21, 0x6A,
+0xB1, 0xF1, 0x66, 0xCA, 0x41, 0xA0, 0x04, 0x72,
+0x07, 0x61, 0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1,
+0x60, 0x9A, 0x4B, 0xA8, 0x49, 0xE3, 0x4A, 0xC8,
+0x01, 0x6A, 0x63, 0x98, 0x41, 0xC0, 0x30, 0xF0,
+0x21, 0x6A, 0xB1, 0xF1, 0x04, 0x4A, 0x63, 0xDA,
+0x63, 0x98, 0x03, 0x23, 0x44, 0xDB, 0x00, 0x6A,
+0x43, 0xD8, 0x00, 0x6A, 0x44, 0xD8, 0x30, 0xF0,
+0x21, 0x6A, 0xB1, 0xF1, 0x04, 0x4A, 0x61, 0xAA,
+0x02, 0x2B, 0x03, 0x9A, 0xC8, 0x28, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x42, 0x9C, 0x07, 0x22, 0x61, 0x9C, 0x61, 0xDA,
+0x41, 0x9C, 0x10, 0x22, 0x62, 0x9C, 0x62, 0xDA,
+0x20, 0xE8, 0x30, 0xF0, 0x21, 0x6A, 0x91, 0xF1,
+0x10, 0x4A, 0x07, 0x10, 0x61, 0x9A, 0x8A, 0xEB,
+0x03, 0x61, 0x61, 0x9B, 0x61, 0xDA, 0x20, 0xE8,
+0x43, 0x67, 0xF8, 0x2A, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x02, 0x9C, 0x24, 0x67, 0x09, 0x28, 0x41, 0xA4,
+0x01, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x21, 0x68,
+0x91, 0xF1, 0x10, 0x48, 0x03, 0x10, 0x02, 0x98,
+0x40, 0xA0, 0xFD, 0x22, 0x91, 0x67, 0x00, 0x18,
+0x70, 0x0C, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x13, 0x0C, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x44, 0x9C, 0x10, 0x22,
+0x63, 0x9C, 0x63, 0xDA, 0x63, 0x9C, 0x09, 0x23,
+0x6A, 0xAA, 0xAA, 0xAC, 0x6D, 0xE5, 0x6A, 0xCA,
+0x63, 0x9C, 0x44, 0xDB, 0x00, 0x6A, 0x43, 0xDC,
+0x01, 0x10, 0x6A, 0xCA, 0x00, 0x6A, 0x44, 0xDC,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x21, 0x68,
+0x11, 0xF2, 0x00, 0x48, 0x09, 0xD5, 0x24, 0x67,
+0x83, 0xA0, 0xA2, 0x40, 0xD0, 0x67, 0x00, 0x18,
+0x89, 0x13, 0x63, 0xA0, 0x63, 0xEA, 0x06, 0x60,
+0x4C, 0x32, 0x41, 0xE0, 0x21, 0xD8, 0x09, 0x92,
+0x42, 0xD8, 0x03, 0x10, 0x02, 0x6C, 0x00, 0x18,
+0xE0, 0x0D, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6A,
+0xD1, 0xF1, 0x40, 0x9A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0xD1, 0xF1, 0x88, 0x9B, 0x4B, 0xCC,
+0x30, 0xF0, 0x21, 0x6C, 0xD1, 0xF1, 0x80, 0x9C,
+0xD1, 0xF1, 0x68, 0x9B, 0x89, 0xE2, 0x4A, 0xCB,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x48, 0x9A,
+0x30, 0xF0, 0x21, 0x6B, 0xD1, 0xF1, 0x80, 0x9B,
+0x6A, 0xAA, 0xFF, 0xF7, 0x1F, 0x6D, 0x93, 0xE3,
+0xAC, 0xEC, 0xAB, 0xAA, 0x6D, 0xE5, 0x6A, 0xCA,
+0x82, 0x32, 0x5E, 0x32, 0x03, 0x2A, 0x04, 0x6D,
+0x00, 0x18, 0x23, 0x0D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x03, 0x6D,
+0x00, 0x18, 0x23, 0x0D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x68, 0x9A,
+0x01, 0x6C, 0x81, 0xC3, 0xD1, 0xF1, 0x88, 0x9A,
+0x00, 0x18, 0x29, 0x0C, 0x00, 0x18, 0xA6, 0x0C,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x60, 0x9A,
+0x01, 0x4B, 0xD1, 0xF1, 0x60, 0xDA, 0x00, 0x18,
+0x4B, 0x0C, 0x30, 0xF0, 0x21, 0x6C, 0x91, 0xF1,
+0x10, 0x4C, 0x00, 0x18, 0x1F, 0x0C, 0x82, 0x67,
+0x00, 0x18, 0x08, 0x0D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1,
+0x68, 0x9A, 0x01, 0x6C, 0x81, 0xC3, 0xD1, 0xF1,
+0x88, 0x9A, 0x00, 0x18, 0x29, 0x0C, 0x30, 0xF0,
+0x21, 0x6A, 0x11, 0xF2, 0x01, 0xA2, 0x1A, 0x10,
+0x0C, 0x33, 0x69, 0xE2, 0x81, 0x9A, 0x60, 0xA4,
+0x04, 0x2B, 0xA4, 0xAA, 0x00, 0x18, 0x98, 0x12,
+0x02, 0x10, 0x00, 0x18, 0x33, 0x12, 0x30, 0xF0,
+0x21, 0x6A, 0x11, 0xF2, 0x00, 0x4A, 0x83, 0xA2,
+0x01, 0x48, 0x0E, 0xEC, 0x8B, 0xEB, 0x8D, 0xEB,
+0xC0, 0xF7, 0x63, 0x33, 0x6C, 0xE8, 0x62, 0xA2,
+0xFF, 0x4B, 0x62, 0xC2, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF2, 0x00, 0x4A, 0x62, 0xA2, 0xE0, 0x2B,
+0x30, 0xF0, 0x21, 0x6C, 0x01, 0xC2, 0x91, 0xF1,
+0x10, 0x4C, 0x00, 0x18, 0x1F, 0x0C, 0x82, 0x67,
+0x00, 0x18, 0x08, 0x0D, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xCB, 0x04, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF2, 0x90, 0xAA, 0x30, 0xF0, 0x21, 0x6A,
+0x12, 0xF1, 0x04, 0x4A, 0x01, 0x6B, 0x07, 0x10,
+0xA0, 0x9A, 0x04, 0x4A, 0x03, 0x2D, 0xFF, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x01, 0x4B, 0x63, 0xEC,
+0xF7, 0x60, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x8C, 0xDA,
+0x02, 0x6A, 0x41, 0xC4, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x68, 0x9A,
+0x00, 0x6A, 0x01, 0x23, 0x43, 0xA3, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x92, 0x13,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x00, 0x18, 0x2E, 0x0C, 0x22, 0x67, 0x11, 0x22,
+0x30, 0xF0, 0x21, 0x68, 0xD1, 0xF1, 0xA8, 0x98,
+0x30, 0xF0, 0x21, 0x6C, 0x91, 0xF1, 0x10, 0x4C,
+0x00, 0x18, 0x13, 0x0C, 0xD1, 0xF1, 0x48, 0x98,
+0x01, 0x6B, 0x91, 0x67, 0x61, 0xC2, 0x00, 0x18,
+0x08, 0x0D, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A, 0xFF, 0x68,
+0x8C, 0xEA, 0xAC, 0xE8, 0x18, 0x22, 0xFF, 0xF7,
+0x1F, 0x72, 0x07, 0x60, 0x30, 0xF0, 0x21, 0x6B,
+0xD1, 0xF1, 0x88, 0x9B, 0xA2, 0x67, 0x00, 0x18,
+0x37, 0x0C, 0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1,
+0x48, 0x9A, 0x30, 0xF0, 0x21, 0x6C, 0x91, 0xF1,
+0x10, 0x4C, 0x01, 0xC2, 0x00, 0x18, 0x1F, 0x0C,
+0x82, 0x67, 0x00, 0x18, 0x08, 0x0D, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x08, 0x2C, 0x30, 0xF0, 0x21, 0x6C,
+0x91, 0xF1, 0x10, 0x4C, 0x00, 0x18, 0x1F, 0x0C,
+0x82, 0x67, 0x0F, 0x10, 0x30, 0xF0, 0x21, 0x69,
+0xD1, 0xF1, 0x88, 0x99, 0x62, 0xA0, 0x42, 0xA4,
+0x63, 0xEA, 0x0A, 0x60, 0x00, 0x18, 0x29, 0x0C,
+0xD1, 0xF1, 0x48, 0x99, 0x01, 0x6B, 0x90, 0x67,
+0x61, 0xC2, 0x00, 0x18, 0x08, 0x0D, 0x09, 0x10,
+0x01, 0x6A, 0x30, 0xF0, 0x21, 0x6C, 0x41, 0xC0,
+0x91, 0xF1, 0x10, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x13, 0x0C, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x07, 0x22, 0x30, 0xF0, 0x21, 0x6B, 0xD1, 0xF1,
+0x68, 0x9B, 0x63, 0xA3, 0x4E, 0xEB, 0x1F, 0x2B,
+0x30, 0xF0, 0x21, 0x69, 0xD1, 0xF1, 0x48, 0x99,
+0x00, 0x6B, 0x61, 0xC2, 0xD1, 0xF1, 0x08, 0x99,
+0x00, 0x18, 0xED, 0x0D, 0x49, 0xD8, 0xD1, 0xF1,
+0x68, 0x99, 0x30, 0xF0, 0x21, 0x6A, 0x12, 0xF1,
+0x04, 0x4A, 0x83, 0xA3, 0xFF, 0x4C, 0x88, 0x34,
+0x51, 0xE4, 0x00, 0x6A, 0x40, 0xDC, 0x4A, 0xDB,
+0x82, 0x67, 0xD1, 0xF1, 0x48, 0xD9, 0x00, 0x18,
+0x36, 0x0D, 0x00, 0x6A, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF2, 0x70, 0xAB, 0x43, 0xEB,
+0x13, 0x61, 0x30, 0xF0, 0x21, 0x6B, 0x2F, 0x42,
+0x28, 0x31, 0x12, 0xF1, 0x04, 0x4B, 0x65, 0xE1,
+0x00, 0x99, 0x0A, 0x20, 0x90, 0x67, 0x00, 0x18,
+0x70, 0x0C, 0x90, 0x67, 0x00, 0x18, 0x8B, 0x0C,
+0x00, 0x6A, 0x40, 0xD9, 0x4A, 0xD8, 0x01, 0x10,
+0xFF, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x30, 0xF0, 0x21, 0x6B,
+0x4C, 0xEC, 0xAC, 0xEA, 0x91, 0xF1, 0xB4, 0x9B,
+0x01, 0x6B, 0x01, 0x25, 0x62, 0xA5, 0x17, 0x2C,
+0x30, 0xF0, 0x21, 0x6C, 0xD1, 0xF1, 0x88, 0x9C,
+0x42, 0xC4, 0x63, 0xEA, 0x38, 0x60, 0x30, 0xF0,
+0x21, 0x68, 0xD1, 0xF1, 0xA8, 0x98, 0x30, 0xF0,
+0x21, 0x6C, 0x91, 0xF1, 0x10, 0x4C, 0x00, 0x18,
+0x13, 0x0C, 0xD1, 0xF1, 0x48, 0x98, 0x01, 0x6B,
+0x00, 0x6C, 0x61, 0xC2, 0x23, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x00, 0xF2, 0xB0, 0xAD, 0x83, 0xED,
+0x20, 0x61, 0x30, 0xF0, 0x21, 0x6D, 0xFF, 0x4C,
+0x88, 0x34, 0x12, 0xF1, 0x04, 0x4D, 0xB5, 0xE4,
+0x00, 0x9D, 0x17, 0x20, 0x42, 0xC0, 0x30, 0xF0,
+0x21, 0x6C, 0xD1, 0xF1, 0x88, 0x9C, 0x0E, 0xEC,
+0xD8, 0x24, 0x90, 0x67, 0x00, 0x18, 0x7C, 0x0C,
+0x41, 0xA0, 0x01, 0x72, 0x0C, 0x61, 0x30, 0xF0,
+0x21, 0x6C, 0x91, 0xF1, 0x10, 0x4C, 0x00, 0x18,
+0x1F, 0x0C, 0x82, 0x67, 0x00, 0x18, 0x36, 0x0D,
+0x02, 0x10, 0xFF, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x6A, 0x40, 0xC4,
+0x01, 0x6A, 0x41, 0xC4, 0x00, 0x6A, 0xA2, 0xC4,
+0x41, 0xDC, 0x42, 0xDC, 0x43, 0xDC, 0x44, 0xDC,
+0x4A, 0xCC, 0x4B, 0xCC, 0x4C, 0xCC, 0x4D, 0xCC,
+0x20, 0xF0, 0x40, 0xC4, 0xA6, 0x67, 0x00, 0x18,
+0xF6, 0x0B, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF2, 0x90, 0xAA, 0x30, 0xF0,
+0x21, 0x6A, 0x12, 0xF1, 0x04, 0x4A, 0x00, 0x6B,
+0x04, 0x10, 0x00, 0x6D, 0xA0, 0xDA, 0x01, 0x4B,
+0x04, 0x4A, 0x83, 0xEB, 0xFA, 0x61, 0x30, 0xF0,
+0x21, 0x68, 0x01, 0x6A, 0xD1, 0xF1, 0x10, 0x48,
+0x4B, 0xEA, 0x43, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF2, 0x40, 0xAA, 0x10, 0xF0, 0x20, 0x6E,
+0x90, 0x67, 0x51, 0xC8, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF4, 0x04, 0x4A, 0x00, 0x6D, 0xE9, 0xF5,
+0x05, 0x4E, 0x4A, 0xD8, 0x00, 0x18, 0x9C, 0x0D,
+0x30, 0xF0, 0x21, 0x6A, 0x04, 0x6C, 0x62, 0x67,
+0x91, 0xF1, 0x90, 0xC2, 0x91, 0xF1, 0x10, 0x4B,
+0x00, 0x6A, 0x41, 0xDB, 0x30, 0xF0, 0x21, 0x6B,
+0xB1, 0xF1, 0x84, 0xC3, 0xB1, 0xF1, 0x04, 0x4B,
+0x43, 0xDB, 0x44, 0xDB, 0x41, 0xCB, 0x30, 0xF0,
+0x21, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xD1, 0xF1,
+0x08, 0xDA, 0x20, 0xF2, 0x62, 0xA3, 0x02, 0x6A,
+0x41, 0xC0, 0x00, 0x6C, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF2, 0x80, 0xC2, 0x11, 0xF2, 0x00, 0x4A,
+0x81, 0xC2, 0x63, 0xC2, 0x00, 0x18, 0xA5, 0x0C,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x12, 0x24, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x46, 0xF7, 0x11, 0x4A, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7, 0x50, 0x9A,
+0x1D, 0xF4, 0x02, 0x6B, 0x60, 0xDA, 0x00, 0x18,
+0x00, 0x0E, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x86, 0xF7, 0x01, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF7, 0x50, 0x9A, 0x1D, 0xF4,
+0x03, 0x6B, 0x60, 0xDA, 0x00, 0x18, 0x00, 0x0E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xBC, 0x65, 0x20, 0xE8, 0x5D, 0x67, 0x20, 0xE8,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x80, 0x9C, 0x00, 0xF0, 0x20, 0x6B, 0x01, 0x4B,
+0x6D, 0xEC, 0x8C, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x20, 0xE8,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x4C, 0xB8, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6B,
+0x01, 0x4B, 0x6F, 0xEB, 0x6C, 0xEA, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x7B, 0xB8,
+0x00, 0x65, 0x20, 0xE8, 0x00, 0x65, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF0, 0x00, 0x4A,
+0x60, 0xDA, 0x81, 0xDA, 0xA2, 0xDA, 0xC3, 0xDA,
+0xE4, 0xDA, 0x05, 0xDA, 0x26, 0xDA, 0x78, 0x67,
+0x67, 0xDA, 0x7D, 0x67, 0x68, 0xDA, 0x7F, 0x67,
+0x69, 0xDA, 0x12, 0xEB, 0x6A, 0xDA, 0x10, 0xEB,
+0x6B, 0xDA, 0x6D, 0xB8, 0x00, 0x65, 0x6C, 0xDA,
+0x68, 0xB8, 0x00, 0x65, 0x6D, 0xDA, 0x6C, 0xB8,
+0x00, 0x65, 0x6E, 0xDA, 0x6E, 0xB8, 0x00, 0x65,
+0x6F, 0xDA, 0x10, 0xF0, 0x20, 0x6A, 0x65, 0xF7,
+0x09, 0x4A, 0x00, 0xEA, 0x00, 0x65, 0x00, 0x65,
+0x60, 0xBA, 0x20, 0xE8, 0x40, 0xBA, 0x20, 0xE8,
+0x4C, 0xB8, 0x00, 0x65, 0x80, 0x34, 0x8D, 0xEA,
+0x8A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x4C, 0xB8, 0x00, 0x65,
+0x80, 0x34, 0x8F, 0xEC, 0x8C, 0xEA, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x20, 0xE8,
+0x41, 0x44, 0x03, 0x2A, 0xFF, 0xF7, 0x1F, 0x6A,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x54, 0x9A, 0x83, 0xEA, 0x03, 0x60, 0xFF, 0xF7,
+0x1E, 0x6A, 0x20, 0xE8, 0xE0, 0xF3, 0x08, 0x6A,
+0x58, 0xEC, 0xFF, 0xF7, 0x1F, 0x6B, 0x12, 0xEA,
+0x3F, 0x4A, 0x5A, 0x32, 0x63, 0xEA, 0x02, 0x61,
+0xFF, 0xF7, 0x1E, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x06, 0x24, 0x03, 0x6A, 0x8C, 0xEA, 0x03, 0x2A,
+0x60, 0xA4, 0x44, 0x67, 0x01, 0x23, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x03, 0x6A, 0x8C, 0xEA,
+0x01, 0x5A, 0x58, 0x67, 0x4B, 0xEA, 0x8C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xC7, 0xF0, 0x1D, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF7, 0x78, 0x9A, 0x08, 0x6E,
+0xFF, 0x6D, 0x80, 0xA3, 0x00, 0x6A, 0xCC, 0xEC,
+0x1A, 0x24, 0x80, 0xA3, 0xF7, 0x6A, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x5C, 0x9A, 0x30, 0xF0, 0x21, 0x6C, 0x40, 0x9A,
+0x32, 0xF1, 0x48, 0xDC, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x40, 0x9A, 0x32, 0xF1, 0x08, 0x4C,
+0x40, 0x9A, 0x41, 0xDC, 0x80, 0xA3, 0xAC, 0xEC,
+0xCD, 0xEC, 0xAC, 0xEC, 0x80, 0xC3, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6D,
+0x60, 0xF7, 0xAC, 0x9D, 0x10, 0xF0, 0x20, 0x6B,
+0x27, 0xF1, 0x19, 0x4B, 0x60, 0xDD, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF7, 0x78, 0x9B, 0x08, 0x6D,
+0xFF, 0x6A, 0xC0, 0xA3, 0x4C, 0xEC, 0xAC, 0xEE,
+0x25, 0x26, 0x05, 0x5C, 0x23, 0x60, 0x0C, 0x68,
+0x18, 0xEC, 0xE0, 0xA3, 0xF7, 0x6E, 0xEC, 0xEE,
+0xC0, 0xC3, 0x30, 0xF0, 0x20, 0x6E, 0x80, 0xF7,
+0xDC, 0x9E, 0xE0, 0x9E, 0x30, 0xF0, 0x21, 0x6E,
+0x32, 0xF1, 0x10, 0x4E, 0x12, 0xEC, 0x91, 0xE6,
+0x30, 0xF0, 0x20, 0x6E, 0xA0, 0xF7, 0xC0, 0x9E,
+0xE1, 0xDC, 0xE0, 0xA4, 0xC0, 0x9E, 0xC2, 0xDC,
+0x01, 0x6E, 0xED, 0xEE, 0xC0, 0xC4, 0x80, 0xA3,
+0x4C, 0xEC, 0xAD, 0xEC, 0x4C, 0xEC, 0x80, 0xC3,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6A, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xA7, 0xF1, 0x15, 0x4B,
+0x60, 0xDC, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF7,
+0x78, 0x9B, 0x08, 0x6C, 0xA0, 0xA3, 0xAC, 0xEC,
+0x2A, 0x24, 0x05, 0x5A, 0x28, 0x60, 0x0C, 0x6D,
+0xB8, 0xEA, 0x30, 0xF0, 0x21, 0x6C, 0x32, 0xF1,
+0x10, 0x4C, 0x12, 0xEA, 0x89, 0xE2, 0xA0, 0xA2,
+0x01, 0x6C, 0xAC, 0xEC, 0x1C, 0x24, 0xA0, 0xA3,
+0xF7, 0x6C, 0x08, 0x6E, 0xAC, 0xEC, 0x80, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF7, 0x7C, 0x9B,
+0x42, 0x9A, 0xA0, 0x9B, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x60, 0x9B, 0xFF, 0x6D, 0x60, 0x9B,
+0x4B, 0xE3, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF7,
+0x98, 0x9B, 0x60, 0xA4, 0xAC, 0xEB, 0xCD, 0xEB,
+0xAC, 0xEB, 0x60, 0xC4, 0x20, 0xE8, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x8C, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6A, 0x27, 0xF2, 0x15, 0x4A,
+0x05, 0x5B, 0x40, 0xDC, 0x00, 0x6A, 0x11, 0x60,
+0x0C, 0x6C, 0x98, 0xEB, 0x30, 0xF0, 0x21, 0x6A,
+0x32, 0xF1, 0x10, 0x4A, 0x12, 0xEB, 0x4D, 0xE3,
+0x80, 0xA3, 0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x00, 0x6A, 0x41, 0xDB, 0x42, 0xDB,
+0x01, 0x6A, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x67, 0xF2, 0x15, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x21, 0x6A, 0x32, 0xF1, 0x40, 0x9A, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x87, 0xF2, 0x11, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x2E, 0x0E, 0x62, 0x67, 0x84, 0x6A, 0x02, 0x23,
+0x42, 0xA3, 0xFC, 0x4A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0x62,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0xA7, 0xF2,
+0x1D, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x88, 0xF6, 0x09, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x82, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x48, 0xF6,
+0x0D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0xFF, 0x17, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0x80, 0x13,
+0x82, 0x6B, 0x18, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0xF7, 0x8C, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0x07, 0xF3, 0x0D, 0x4B, 0x60, 0xDC, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x08, 0xF1,
+0x1D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x80, 0x13,
+0x03, 0x22, 0x01, 0x6A, 0x4B, 0xEA, 0x18, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x47, 0xF3, 0x19, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x88, 0xF1, 0x11, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0x80, 0x13,
+0x82, 0x6B, 0x18, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0xF7, 0x8C, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0xA7, 0xF3, 0x0D, 0x4B, 0x60, 0xDC, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xA8, 0xF2,
+0x09, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0x80, 0x13, 0x82, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xE7, 0xF3, 0x19, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xC8, 0xF2, 0x1D, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0x80, 0x13, 0x82, 0x6B, 0x19, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x47, 0xF4, 0x05, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x08, 0xF3, 0x1D, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x62, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x43, 0x67, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x80, 0x13,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x87, 0xF4,
+0x19, 0x4A, 0x40, 0xDB, 0x82, 0x6A, 0x0F, 0x10,
+0x90, 0x67, 0xB1, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xC8, 0xF4, 0x01, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x80, 0x13,
+0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x44, 0x9A, 0x18, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0xF7, 0x8C, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0xE7, 0xF4, 0x09, 0x4B, 0x60, 0xDC, 0xB1, 0x67,
+0x90, 0x67, 0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1,
+0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0x28, 0xF5, 0x11, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0x80, 0x13, 0x84, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x47, 0xF5, 0x01, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x87, 0xF2, 0x11, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0x80, 0x13, 0x82, 0x6B, 0x19, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x87, 0xF5, 0x0D, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0xC8, 0xF5, 0x19, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x62, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x43, 0x67, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0x80, 0x13, 0x82, 0x6B, 0x17, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x68, 0xE7, 0xF5, 0x01, 0x48, 0x00, 0xDB,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x28, 0xF6,
+0x09, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0x80, 0x13, 0x82, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF7, 0x8C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x27, 0xF6, 0x09, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x48, 0xF6, 0x0D, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x80, 0x13, 0x00, 0x6B,
+0x17, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0x67, 0xF6,
+0x15, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x88, 0xF6, 0x09, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x80, 0x13, 0x82, 0x6B,
+0x17, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0xA7, 0xF6,
+0x1D, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xC8, 0xF7, 0x05, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x07, 0xF7,
+0x05, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0x80, 0x13, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0x8D, 0x0E, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x27, 0xF2,
+0x15, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x47, 0xF7,
+0x15, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0x80, 0x13, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0x6D, 0x0E, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xA7, 0xF1,
+0x15, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xA7, 0xF7,
+0x05, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0x80, 0x13, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0x4E, 0x0E, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x27, 0xF1,
+0x19, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xE7, 0xF7,
+0x15, 0x4A, 0x40, 0xDB, 0x00, 0x18, 0x80, 0x13,
+0x03, 0x22, 0x00, 0x18, 0x37, 0x0E, 0x0D, 0x10,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xC7, 0xF0,
+0x1D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x28, 0xF0, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x33, 0x0E, 0x82, 0x67,
+0x0C, 0x22, 0x40, 0xA2, 0x02, 0x72, 0x09, 0x61,
+0x41, 0xAC, 0xFF, 0xF7, 0x1F, 0x72, 0x81, 0x6A,
+0x05, 0x60, 0x00, 0x18, 0x43, 0x12, 0x00, 0x6A,
+0x01, 0x10, 0x80, 0x6A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x68, 0xF0,
+0x1D, 0x4A, 0x40, 0xDB, 0x04, 0x67, 0x00, 0x18,
+0x80, 0x13, 0x04, 0x22, 0x90, 0x67, 0x00, 0x18,
+0x0F, 0x10, 0x0E, 0x10, 0x90, 0x67, 0x30, 0xF0,
+0x21, 0x68, 0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x48, 0xF1, 0x11, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xC8, 0xF0, 0x09, 0x4A, 0x40, 0xDB,
+0x00, 0x18, 0x80, 0x13, 0x05, 0x2A, 0x00, 0x18,
+0x7F, 0x13, 0x01, 0x6B, 0x4C, 0xEB, 0x05, 0x2B,
+0x30, 0xF0, 0x21, 0x6A, 0x32, 0xF1, 0x40, 0x9A,
+0x0D, 0x10, 0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1,
+0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0x67, 0xF2, 0x15, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x08, 0xF1, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x33, 0x0E, 0x08, 0x22,
+0x60, 0xA2, 0x02, 0x73, 0x05, 0x61, 0x82, 0x67,
+0x00, 0x18, 0x6C, 0x12, 0x00, 0x6A, 0x01, 0x10,
+0x80, 0x6A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x48, 0xF1, 0x11, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x33, 0x0E, 0x82, 0x67, 0x0C, 0x22, 0x40, 0xA2,
+0x02, 0x72, 0x09, 0x61, 0x41, 0xAC, 0xFF, 0xF7,
+0x1F, 0x72, 0x81, 0x6A, 0x05, 0x60, 0x00, 0x18,
+0x5E, 0x12, 0x00, 0x6A, 0x01, 0x10, 0x80, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x88, 0xF1, 0x11, 0x4A,
+0x40, 0xDB, 0x25, 0x67, 0x00, 0x18, 0x33, 0x0E,
+0x02, 0x67, 0x12, 0x22, 0x40, 0xA2, 0x02, 0x72,
+0x0F, 0x61, 0x91, 0x67, 0x00, 0x18, 0x20, 0x0E,
+0xFF, 0xF7, 0x1F, 0x6D, 0x90, 0x67, 0x4C, 0xED,
+0x00, 0x18, 0x48, 0x12, 0x01, 0x72, 0x00, 0x6A,
+0x05, 0x60, 0x41, 0xA8, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x6A, 0x4B, 0xEA, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xE8, 0xF1, 0x09, 0x4A, 0x40, 0xDB,
+0x02, 0x24, 0x00, 0x9C, 0x02, 0x28, 0x80, 0x6C,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x48, 0x9A, 0x42, 0xED, 0x05, 0x61, 0x86, 0x6C,
+0x00, 0x18, 0xD4, 0x0D, 0x00, 0x6A, 0x07, 0x10,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED, 0x90, 0x67,
+0x00, 0x18, 0x30, 0x12, 0x50, 0x67, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x80, 0x13,
+0x00, 0x6B, 0x28, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x28, 0xF2, 0x19, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x7F, 0x13, 0x01, 0x6B, 0x4C, 0xEB, 0x0A, 0x2B,
+0x30, 0xF0, 0x21, 0x6B, 0x32, 0xF1, 0x60, 0x9B,
+0x05, 0x2B, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x7A, 0x10, 0x0F, 0x10, 0x90, 0x67, 0xB1, 0x67,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xE8, 0xF1,
+0x09, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x43, 0x67, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xA8, 0xF2, 0x09, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x33, 0x0E, 0x08, 0x22, 0x60, 0xA2, 0x03, 0x73,
+0x05, 0x61, 0x82, 0x67, 0x00, 0x18, 0x53, 0x13,
+0x00, 0x6A, 0x01, 0x10, 0x80, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC8, 0xF2, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x33, 0x0E, 0x0E, 0x22,
+0x60, 0xA2, 0x03, 0x73, 0x0B, 0x61, 0x82, 0x67,
+0x00, 0x18, 0x20, 0x13, 0xFF, 0x6B, 0x4E, 0xEB,
+0x01, 0x5B, 0x78, 0x67, 0x81, 0x6A, 0x6B, 0xEB,
+0x6C, 0xEA, 0x01, 0x10, 0x80, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x08, 0xF3, 0x1D, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x33, 0x0E, 0x02, 0x67, 0x13, 0x22,
+0x40, 0xA2, 0x03, 0x72, 0x10, 0x61, 0x91, 0x67,
+0x00, 0x18, 0x20, 0x0E, 0xFF, 0xF7, 0x1F, 0x6D,
+0x90, 0x67, 0x4C, 0xED, 0x00, 0x18, 0xFB, 0x12,
+0x01, 0x72, 0x00, 0x6A, 0x05, 0x61, 0xC1, 0x6A,
+0x03, 0x29, 0x81, 0x6A, 0x01, 0x10, 0x80, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x68, 0xF3,
+0x15, 0x4A, 0x40, 0xDB, 0x02, 0x24, 0x00, 0x9C,
+0x05, 0x28, 0x80, 0x6C, 0x00, 0x18, 0xD4, 0x0D,
+0x00, 0x6A, 0x04, 0x10, 0x90, 0x67, 0x00, 0x18,
+0xF6, 0x12, 0x50, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0x80, 0x13,
+0x00, 0x6B, 0x26, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xA8, 0xF3, 0x0D, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x7F, 0x13, 0x01, 0x6B, 0x4C, 0xEB, 0x09, 0x2B,
+0x30, 0xF0, 0x21, 0x6B, 0x32, 0xF1, 0x60, 0x9B,
+0x04, 0x2B, 0x90, 0x67, 0x00, 0x18, 0xDD, 0x10,
+0x0E, 0x10, 0x90, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x68, 0xF3, 0x15, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x08, 0xF4, 0x15, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x2E, 0x0E, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x6C, 0x9B, 0x2C, 0xEB,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x04, 0x9A, 0x07, 0x10, 0xA3, 0xA2, 0xFF, 0xF7,
+0x1F, 0x6C, 0x2C, 0xEC, 0x0C, 0xAA, 0x00, 0x18,
+0xB2, 0x12, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x68, 0xF4, 0x09, 0x4A,
+0x40, 0xDB, 0x04, 0x67, 0x25, 0x67, 0x00, 0x18,
+0x80, 0x13, 0x05, 0x22, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0x05, 0x11, 0x0F, 0x10, 0x90, 0x67,
+0xB1, 0x67, 0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1,
+0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0x88, 0xF5, 0x05, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC8, 0xF4, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x6C, 0x9A, 0x24, 0x67, 0x05, 0x67, 0x8C, 0xEB,
+0x86, 0x6A, 0x1D, 0x2B, 0x0A, 0x24, 0x85, 0x67,
+0x00, 0x18, 0x20, 0x0E, 0xFF, 0xF7, 0x1F, 0x6D,
+0x91, 0x67, 0xAC, 0xEC, 0x01, 0x6E, 0x4C, 0xED,
+0x08, 0x10, 0x85, 0x67, 0x00, 0x18, 0x20, 0x0E,
+0xFF, 0xF7, 0x1F, 0x6D, 0x85, 0x67, 0x00, 0x6E,
+0x4C, 0xED, 0x00, 0x18, 0xDB, 0x12, 0x02, 0x72,
+0x08, 0x6A, 0x05, 0x60, 0x0B, 0xEA, 0x0D, 0xEA,
+0xC0, 0xF7, 0x42, 0x32, 0x58, 0x32, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x28, 0xF5, 0x11, 0x4A,
+0x40, 0xDB, 0x25, 0x67, 0x00, 0x18, 0x2E, 0x0E,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7,
+0x6C, 0x9B, 0x2C, 0xEB, 0x05, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x04, 0x9A, 0x07, 0x10,
+0xA3, 0xA2, 0xFF, 0xF7, 0x1F, 0x6C, 0x2C, 0xEC,
+0x0C, 0xAA, 0x00, 0x18, 0x8B, 0x12, 0x50, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x88, 0xF5, 0x05, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x2E, 0x0E, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x6C, 0x9B, 0x2C, 0xEB,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x04, 0x9A, 0x07, 0x10, 0xA3, 0xA2, 0xFF, 0xF7,
+0x1F, 0x6C, 0x2C, 0xEC, 0x0C, 0xAA, 0x00, 0x18,
+0xBE, 0x12, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xC8, 0xF5, 0x19, 0x4A, 0x40, 0xDB,
+0x05, 0x67, 0x00, 0x18, 0x2E, 0x0E, 0x80, 0x6B,
+0x11, 0x22, 0x63, 0x40, 0x07, 0x5B, 0x86, 0x6B,
+0x0D, 0x60, 0x83, 0xA2, 0xA4, 0x40, 0xFF, 0x6A,
+0x4C, 0xED, 0x00, 0x18, 0x73, 0x0D, 0xFF, 0x6B,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x81, 0x6B,
+0x4B, 0xEA, 0x4C, 0xEB, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x28, 0xF6, 0x09, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x14, 0x0D, 0x05, 0x97, 0x00, 0x6A, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x48, 0xF6, 0x0D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x2E, 0x0E, 0x80, 0x6B,
+0x0A, 0x22, 0x83, 0xA2, 0x00, 0x18, 0x4D, 0x0D,
+0xFF, 0x6B, 0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67,
+0x81, 0x6B, 0x4B, 0xEA, 0x4C, 0xEB, 0x05, 0x97,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x88, 0xF6, 0x09, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x0C, 0x0D, 0x82, 0x67, 0x00, 0x6A, 0x08, 0x24,
+0x30, 0xF0, 0x21, 0x6B, 0xFF, 0x4C, 0x88, 0x34,
+0x12, 0xF1, 0x04, 0x4B, 0x6D, 0xE4, 0x40, 0x9B,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC8, 0xF6, 0x01, 0x4A,
+0x24, 0x67, 0x40, 0xDB, 0x0C, 0x24, 0xC0, 0x9C,
+0x0A, 0x26, 0x41, 0x9C, 0xFF, 0xF7, 0x1D, 0x52,
+0x06, 0x61, 0x04, 0x52, 0x04, 0x60, 0x64, 0xAC,
+0x02, 0x23, 0x83, 0x9C, 0x05, 0x2C, 0x80, 0x6C,
+0x00, 0x18, 0xD4, 0x0D, 0x00, 0x6A, 0x24, 0x10,
+0xE7, 0x41, 0x09, 0x4F, 0x04, 0xD7, 0x79, 0xC9,
+0xAB, 0xD9, 0x8E, 0xD9, 0x04, 0x4A, 0x04, 0x94,
+0xFF, 0x6B, 0xA2, 0x67, 0x6C, 0xED, 0x00, 0x18,
+0x9C, 0x0D, 0x00, 0x18, 0xFD, 0x0C, 0x0F, 0x42,
+0x30, 0xF0, 0x21, 0x6B, 0x12, 0xF1, 0x04, 0x4B,
+0x08, 0x30, 0x61, 0xE0, 0x04, 0x93, 0x60, 0xD8,
+0x53, 0xC1, 0x04, 0x94, 0x00, 0x18, 0x36, 0x0D,
+0x40, 0x98, 0x10, 0xF0, 0x20, 0x6B, 0xA7, 0xF2,
+0x1D, 0x4B, 0x89, 0x9A, 0xFF, 0xF7, 0x7C, 0xDC,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0x80, 0x13, 0x00, 0x6B, 0x28, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x48, 0xF7, 0x15, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x7F, 0x13, 0x01, 0x6B,
+0x4C, 0xEB, 0x0A, 0x2B, 0x30, 0xF0, 0x21, 0x6B,
+0x32, 0xF1, 0x60, 0x9B, 0x05, 0x2B, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0xB0, 0x11, 0x0F, 0x10,
+0x90, 0x67, 0xB1, 0x67, 0x30, 0xF0, 0x21, 0x68,
+0x32, 0xF1, 0x04, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xC8, 0xF6, 0x01, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x43, 0x67,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x21, 0x69,
+0x32, 0xF1, 0x00, 0x99, 0x16, 0x28, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x00, 0x6C, 0xC8, 0xF7, 0x05, 0x4A,
+0x40, 0xDB, 0xA4, 0x67, 0x00, 0x18, 0x73, 0x0D,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x08, 0xDA,
+0x00, 0x18, 0x10, 0x0D, 0x01, 0x6A, 0x32, 0xF1,
+0x40, 0xD9, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x09, 0xF0, 0x11, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x21, 0x68, 0x12, 0xF1,
+0x3C, 0xA0, 0x13, 0x29, 0x00, 0x18, 0xA8, 0x0D,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x48, 0x9A,
+0x01, 0x6B, 0x6B, 0xEB, 0x62, 0xC2, 0x00, 0x6C,
+0x00, 0x18, 0xD4, 0x0D, 0x01, 0x6A, 0x12, 0xF1,
+0x5C, 0xC0, 0x30, 0xF0, 0x21, 0x6A, 0x32, 0xF1,
+0x20, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0x80, 0x13, 0x82, 0x6B, 0x1F, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x69, 0xF0, 0x09, 0x4A, 0x40, 0xDB,
+0x00, 0x18, 0x7F, 0x13, 0x01, 0x6B, 0x4C, 0xEB,
+0x03, 0x2B, 0x00, 0x18, 0x04, 0x12, 0x0D, 0x10,
+0x30, 0xF0, 0x21, 0x68, 0x32, 0xF1, 0x04, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x09, 0xF0,
+0x11, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x02, 0x6A, 0x40, 0xC4, 0x00, 0x6A, 0x41, 0xDC,
+0xA1, 0xCC, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x41, 0x9C, 0x14, 0x22, 0x00, 0x18,
+0x1F, 0x0C, 0x82, 0x67, 0x02, 0x67, 0x00, 0x18,
+0x8B, 0x0C, 0x01, 0x6A, 0x90, 0x67, 0x41, 0xC0,
+0x01, 0x6D, 0x00, 0x18, 0x05, 0x0C, 0x30, 0xF0,
+0x21, 0x6C, 0x91, 0xF1, 0x10, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x13, 0x0C, 0x03, 0x10, 0x41, 0xAC,
+0x01, 0x4A, 0x41, 0xCC, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x6D, 0x00, 0x18, 0x95, 0x0C, 0x00, 0x18,
+0xF9, 0x0C, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x41, 0xAC,
+0xFF, 0xF7, 0x1F, 0x68, 0xAC, 0xE8, 0x04, 0x22,
+0xFF, 0x4A, 0x41, 0xCC, 0x00, 0x6A, 0x1B, 0x10,
+0x01, 0x6A, 0x19, 0x20, 0x61, 0x9C, 0x07, 0x23,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0xA8, 0x9A,
+0x00, 0x18, 0x13, 0x0C, 0x0B, 0x10, 0x30, 0xF0,
+0x21, 0x6A, 0xD1, 0xF1, 0xA8, 0x9A, 0xA1, 0xDC,
+0xD1, 0xF1, 0xA8, 0x9A, 0x61, 0xDD, 0xD1, 0xF1,
+0x48, 0x9A, 0x82, 0xDA, 0x90, 0x67, 0x07, 0x6D,
+0x00, 0x18, 0x23, 0x0D, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x41, 0x9C,
+0x0E, 0x22, 0x00, 0x18, 0x1F, 0x0C, 0x02, 0x67,
+0x82, 0x67, 0x01, 0x6D, 0x00, 0x18, 0x05, 0x0C,
+0x90, 0x67, 0x00, 0x18, 0x8B, 0x0C, 0x90, 0x67,
+0x00, 0x18, 0x36, 0x0D, 0x03, 0x10, 0x41, 0xAC,
+0x01, 0x4A, 0x41, 0xCC, 0x05, 0x97, 0x04, 0x90,
+0x00, 0x6A, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x08, 0xD4, 0x24, 0x67, 0x14, 0x10, 0x91, 0x67,
+0x00, 0x18, 0x1F, 0x0C, 0x02, 0x67, 0x82, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x05, 0x0C, 0x90, 0x67,
+0x00, 0x18, 0x8B, 0x0C, 0x01, 0x6A, 0x30, 0xF0,
+0x21, 0x6C, 0x41, 0xC0, 0x91, 0xF1, 0x10, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x13, 0x0C, 0x41, 0x99,
+0xEA, 0x2A, 0x30, 0xF0, 0x21, 0x6C, 0x91, 0xF1,
+0x10, 0x4C, 0x41, 0x9C, 0x11, 0x22, 0x30, 0xF0,
+0x21, 0x68, 0xD1, 0xF1, 0xA8, 0x98, 0x62, 0xA2,
+0x42, 0xA5, 0x63, 0xEA, 0x09, 0x60, 0x00, 0x18,
+0x13, 0x0C, 0xD1, 0xF1, 0x48, 0x98, 0x01, 0x6B,
+0x00, 0x6C, 0x61, 0xC2, 0x00, 0x18, 0x36, 0x0D,
+0x08, 0x93, 0x00, 0x6A, 0x40, 0xC3, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x00, 0x6A, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x6B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA, 0xFF, 0x4B,
+0x30, 0xF0, 0x21, 0x6C, 0x68, 0x33, 0x12, 0xF1,
+0x04, 0x4C, 0x91, 0xE3, 0x60, 0x9C, 0x04, 0x23,
+0x8C, 0xAB, 0x4F, 0xEA, 0x8C, 0xEA, 0x4C, 0xCB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x21, 0x6A,
+0xD1, 0xF1, 0x48, 0x9A, 0x4D, 0xAA, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x6C, 0xAC,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA, 0x6D, 0xEA,
+0x04, 0x67, 0x4C, 0xCC, 0x6D, 0xAC, 0x81, 0xA4,
+0x06, 0x74, 0x03, 0x61, 0x6C, 0xEA, 0x6E, 0xEA,
+0x0A, 0x22, 0x41, 0xA0, 0x05, 0x72, 0x1B, 0x61,
+0x4C, 0xA8, 0x83, 0x67, 0x4C, 0xEC, 0x17, 0x24,
+0x8D, 0xA8, 0x4C, 0xEC, 0x8D, 0xC8, 0x4C, 0xA8,
+0x6F, 0xEB, 0x90, 0x67, 0x4C, 0xEB, 0x6C, 0xC8,
+0x00, 0x18, 0x8B, 0x0C, 0x01, 0x6A, 0x90, 0x67,
+0x08, 0x6D, 0x41, 0xC0, 0x00, 0x18, 0x05, 0x0C,
+0x30, 0xF0, 0x21, 0x6C, 0x91, 0xF1, 0x10, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x13, 0x0C, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA, 0xFF, 0x4B,
+0x30, 0xF0, 0x21, 0x6C, 0x68, 0x33, 0x12, 0xF1,
+0x04, 0x4C, 0x91, 0xE3, 0x80, 0x9C, 0x05, 0x24,
+0xA2, 0x67, 0x00, 0x18, 0x95, 0x0C, 0x00, 0x18,
+0xF9, 0x0C, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6B,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA,
+0xFF, 0x4B, 0x30, 0xF0, 0x21, 0x6C, 0x68, 0x33,
+0x12, 0xF1, 0x04, 0x4C, 0x91, 0xE3, 0x00, 0x9C,
+0x24, 0x20, 0x6C, 0xA8, 0x81, 0xA0, 0x4D, 0xEB,
+0x06, 0x74, 0x6C, 0xC8, 0x4D, 0xA8, 0x03, 0x61,
+0x4C, 0xEB, 0x4E, 0xEB, 0x0A, 0x23, 0x61, 0xA0,
+0x05, 0x73, 0x17, 0x61, 0x6C, 0xA8, 0x82, 0x67,
+0x6C, 0xEC, 0x13, 0x24, 0x8D, 0xA8, 0x6C, 0xEC,
+0x8D, 0xC8, 0x6C, 0xA8, 0x4F, 0xEA, 0x90, 0x67,
+0x6C, 0xEA, 0x4C, 0xC8, 0x00, 0x18, 0x8B, 0x0C,
+0x01, 0x6A, 0x90, 0x67, 0x41, 0xC0, 0x08, 0x6D,
+0x00, 0x18, 0x05, 0x0C, 0x90, 0x67, 0x00, 0x18,
+0x36, 0x0D, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A, 0x64, 0x67,
+0x85, 0x67, 0x4C, 0xEB, 0x4C, 0xEC, 0x0D, 0x26,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x48, 0x9A,
+0xE3, 0x67, 0x06, 0x6D, 0xCC, 0xAA, 0xCC, 0xEF,
+0x6E, 0xEF, 0x15, 0x2F, 0x6F, 0xEB, 0xCC, 0xEB,
+0x0F, 0x10, 0x30, 0xF0, 0x21, 0x6F, 0xD1, 0xF1,
+0x08, 0x9F, 0x05, 0x6D, 0xCC, 0xA8, 0x6C, 0xEE,
+0xCC, 0xEA, 0x09, 0x22, 0xCD, 0xC8, 0xD1, 0xF1,
+0x48, 0x9F, 0x6F, 0xEB, 0x8C, 0xAA, 0x8C, 0xEB,
+0x6C, 0xCA, 0x02, 0x6A, 0x08, 0x10, 0x30, 0xF0,
+0x21, 0x6A, 0xD1, 0xF1, 0x48, 0x9A, 0x6D, 0xCA,
+0x00, 0x18, 0x23, 0x0D, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x03, 0x6A, 0x40, 0xC4, 0x00, 0x6A, 0x41, 0xC4,
+0x00, 0x6A, 0x41, 0xCC, 0x00, 0x6A, 0x41, 0xDC,
+0x42, 0xDC, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x41, 0xAC, 0xFF, 0xF7,
+0x1F, 0x69, 0x04, 0x67, 0xAC, 0xE9, 0x0A, 0x2A,
+0x30, 0xF0, 0x21, 0x6A, 0xD1, 0xF1, 0x68, 0x9A,
+0x62, 0xDC, 0xD1, 0xF1, 0x48, 0x9A, 0x42, 0xA2,
+0x41, 0xC4, 0x07, 0x10, 0x30, 0xF0, 0x21, 0x6A,
+0x62, 0x9C, 0xD1, 0xF1, 0x88, 0x9A, 0x8A, 0xEB,
+0x05, 0x61, 0x41, 0xA8, 0x01, 0x4A, 0x41, 0xC8,
+0x00, 0x6A, 0x24, 0x10, 0x01, 0x6A, 0x22, 0x21,
+0xA1, 0xA0, 0x42, 0xA4, 0x43, 0xED, 0x04, 0x60,
+0x42, 0xC3, 0x82, 0x98, 0x00, 0x18, 0x7C, 0x0C,
+0x61, 0x98, 0x08, 0x23, 0x30, 0xF0, 0x21, 0x6A,
+0xD1, 0xF1, 0xA8, 0x9A, 0x90, 0x67, 0x00, 0x18,
+0x13, 0x0C, 0x0B, 0x10, 0x30, 0xF0, 0x21, 0x6A,
+0xD1, 0xF1, 0x88, 0x9A, 0x81, 0xD8, 0xD1, 0xF1,
+0x88, 0x9A, 0x61, 0xDC, 0xD1, 0xF1, 0x48, 0x9A,
+0x02, 0xDA, 0x91, 0x67, 0x09, 0x6D, 0x00, 0x18,
+0x23, 0x0D, 0x01, 0x6A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x41, 0xAC, 0x04, 0x67, 0x57, 0x22, 0x30, 0xF0,
+0x21, 0x6D, 0x82, 0x9C, 0xD1, 0xF1, 0x68, 0x9D,
+0x8E, 0xEB, 0x50, 0x2B, 0xFF, 0x4A, 0x41, 0xC8,
+0x41, 0xA8, 0x4E, 0x2A, 0xD1, 0xF1, 0x48, 0x9D,
+0x61, 0xA0, 0x62, 0xC2, 0x41, 0x98, 0x2D, 0x22,
+0x90, 0x67, 0x00, 0x18, 0x1F, 0x0C, 0x22, 0x67,
+0x82, 0x67, 0x00, 0x6D, 0x00, 0x18, 0x05, 0x0C,
+0x91, 0x67, 0x00, 0x18, 0x8B, 0x0C, 0x01, 0x6A,
+0x41, 0xC8, 0x22, 0xD8, 0x42, 0xA1, 0x30, 0xF0,
+0x21, 0x6B, 0x91, 0x67, 0x41, 0xC0, 0x30, 0xF0,
+0x21, 0x68, 0x91, 0xF1, 0x10, 0x48, 0xD1, 0xF1,
+0xA8, 0x9B, 0x41, 0x98, 0x62, 0xA5, 0x42, 0xA2,
+0x43, 0xEB, 0x25, 0x60, 0x90, 0x67, 0x00, 0x18,
+0x13, 0x0C, 0xB1, 0x67, 0x90, 0x67, 0x00, 0x18,
+0x13, 0x0C, 0x30, 0xF0, 0x21, 0x6D, 0xD1, 0xF1,
+0x48, 0x9D, 0x01, 0x6B, 0x61, 0xC2, 0x61, 0xC1,
+0x15, 0x10, 0x30, 0xF0, 0x21, 0x6C, 0x30, 0xF0,
+0x21, 0x6B, 0x91, 0xF1, 0x10, 0x4C, 0x41, 0x9C,
+0xD1, 0xF1, 0xA8, 0x9B, 0x62, 0xA2, 0x42, 0xA5,
+0x63, 0xEA, 0x0E, 0x60, 0x00, 0x18, 0x13, 0x0C,
+0x30, 0xF0, 0x21, 0x6D, 0xD1, 0xF1, 0x48, 0x9D,
+0x01, 0x6B, 0x61, 0xC2, 0x00, 0x6C, 0x00, 0x18,
+0x36, 0x0D, 0x02, 0x10, 0xFF, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x04, 0xD4, 0x41, 0xAC,
+0x04, 0x67, 0x21, 0x22, 0x42, 0x9C, 0x61, 0xA4,
+0x62, 0xC2, 0x30, 0xF0, 0x21, 0x6A, 0x82, 0x9C,
+0xD1, 0xF1, 0x48, 0x9A, 0x8E, 0xEA, 0x17, 0x22,
+0x00, 0x18, 0x7C, 0x0C, 0x14, 0x10, 0x04, 0x94,
+0x00, 0x18, 0x1F, 0x0C, 0x22, 0x67, 0x82, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x05, 0x0C, 0x91, 0x67,
+0x00, 0x18, 0x8B, 0x0C, 0x01, 0x6A, 0x30, 0xF0,
+0x21, 0x6C, 0x41, 0xC1, 0x91, 0xF1, 0x10, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x13, 0x0C, 0x04, 0x93,
+0x41, 0x9B, 0xE9, 0x2A, 0x30, 0xF0, 0x21, 0x6C,
+0x91, 0xF1, 0x10, 0x4C, 0x41, 0x9C, 0x11, 0x22,
+0x30, 0xF0, 0x21, 0x69, 0xD1, 0xF1, 0xA8, 0x99,
+0x62, 0xA2, 0x42, 0xA5, 0x63, 0xEA, 0x09, 0x60,
+0x00, 0x18, 0x13, 0x0C, 0xD1, 0xF1, 0x48, 0x99,
+0x01, 0x6B, 0x00, 0x6C, 0x61, 0xC2, 0x00, 0x18,
+0x36, 0x0D, 0x00, 0x6A, 0x40, 0xC0, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x00, 0x6A, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xE9, 0xF5, 0x05, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0xF4, 0x17, 0x00, 0x6A, 0x20, 0xE8,
+0x30, 0xF0, 0x21, 0x6A, 0x71, 0xF1, 0x70, 0x9A,
+0x02, 0x5B, 0x43, 0x67, 0x0A, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF0, 0x08, 0x4A, 0x4F, 0xE3,
+0x20, 0x5B, 0x98, 0x67, 0x6A, 0x32, 0x8B, 0xEB,
+0x6C, 0xEA, 0x20, 0xE8, 0x40, 0xA5, 0xFF, 0x6B,
+0x6C, 0xEC, 0x83, 0xEA, 0x0C, 0x60, 0x01, 0x4A,
+0x40, 0xC5, 0x40, 0xA6, 0xA1, 0x42, 0x6C, 0xED,
+0xAE, 0xEC, 0x8B, 0xEB, 0x8D, 0xEB, 0xC0, 0xF7,
+0x63, 0x33, 0x6C, 0xED, 0xA0, 0xC6, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x21, 0x6C,
+0x40, 0x6A, 0x30, 0xF0, 0x21, 0x6B, 0x71, 0xF1,
+0x5C, 0xDC, 0x91, 0xF1, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF7, 0x4C, 0x9A, 0x02, 0x6E,
+0x30, 0xF0, 0x20, 0x6D, 0x60, 0xAA, 0xE7, 0xF7,
+0x1F, 0x6A, 0x60, 0xF7, 0xAC, 0x9D, 0x6C, 0xEA,
+0x5B, 0xEE, 0x01, 0x2A, 0xE5, 0xE8, 0x30, 0xF0,
+0x21, 0x6B, 0x71, 0xF1, 0x58, 0xDB, 0x10, 0xF0,
+0x20, 0x6B, 0x49, 0xF6, 0x09, 0x4B, 0x60, 0xDD,
+0x01, 0x6D, 0x12, 0xEE, 0x71, 0xF1, 0xDC, 0xDC,
+0x42, 0xF1, 0x18, 0x6C, 0x00, 0x18, 0xF2, 0x30,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x8E, 0x35, 0x86, 0xF2, 0x00, 0x4B, 0xAD, 0xE3,
+0x43, 0xF3, 0x70, 0xA3, 0x07, 0x6D, 0x8C, 0xED,
+0x67, 0xED, 0x01, 0x6C, 0x8C, 0xEB, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x24, 0x67,
+0x4C, 0xE9, 0x4C, 0xED, 0x2E, 0x34, 0x07, 0x6B,
+0x01, 0x75, 0x4C, 0xEC, 0x2C, 0xEB, 0x1F, 0x61,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x11, 0xE4, 0x01, 0x6A, 0x44, 0xEB, 0x43, 0xF3,
+0x70, 0xA4, 0x00, 0x6D, 0x6D, 0xEA, 0x43, 0xF3,
+0x50, 0xC4, 0x91, 0x67, 0x00, 0x18, 0x74, 0x47,
+0xC0, 0xF0, 0x5A, 0xA0, 0x4E, 0xE9, 0x1C, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x50, 0x9A,
+0x40, 0x9A, 0x50, 0x32, 0x00, 0xF5, 0x42, 0x32,
+0xE3, 0xF4, 0x4E, 0xC8, 0x11, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x51, 0xE4,
+0x01, 0x6A, 0x44, 0xEB, 0x43, 0xF3, 0x70, 0xA4,
+0x4F, 0xEA, 0x01, 0x6D, 0x6C, 0xEA, 0x43, 0xF3,
+0x50, 0xC4, 0x91, 0x67, 0x00, 0x18, 0x74, 0x47,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x6D, 0x00, 0x18,
+0x74, 0x47, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x6D, 0x00, 0x18, 0x74, 0x47, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFF, 0x6A, 0x4C, 0xEC,
+0x01, 0x6B, 0xAC, 0xEA, 0x6E, 0xEA, 0x01, 0x5A,
+0x58, 0x67, 0x05, 0x5C, 0x48, 0x32, 0x08, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0x88, 0x34, 0x20, 0xF2,
+0x04, 0x4B, 0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB,
+0x01, 0x6A, 0x4B, 0xEA, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x90, 0x9B, 0x30, 0xF0,
+0x20, 0x6D, 0xA0, 0xF7, 0xB4, 0x9D, 0x60, 0x9C,
+0xAC, 0xEB, 0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x90, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0xA0, 0xF7, 0xB4, 0x9D, 0x60, 0x9C, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0xC0, 0xF7, 0xA0, 0x9D,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7,
+0x90, 0x9B, 0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF7,
+0xB4, 0x9D, 0x60, 0x9C, 0xAC, 0xEB, 0x30, 0xF0,
+0x20, 0x6D, 0xC0, 0xF7, 0xA4, 0x9D, 0xAD, 0xEB,
+0x60, 0xDC, 0x60, 0xF5, 0x60, 0x42, 0x1F, 0xF7,
+0x00, 0x6C, 0x8C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x10, 0x61, 0x2E, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x90, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0xA0, 0xF7, 0xB4, 0x9D, 0x60, 0x9C, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0xC0, 0xF7, 0xA8, 0x9D,
+0xE6, 0x17, 0x1E, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x7C, 0x9B, 0x1D, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x90, 0x9B, 0x30, 0xF0,
+0x20, 0x6D, 0xA0, 0xF7, 0xB4, 0x9D, 0x60, 0x9C,
+0xAC, 0xEB, 0x30, 0xF0, 0x20, 0x6D, 0xC0, 0xF7,
+0xAC, 0x9D, 0xAD, 0xEB, 0x60, 0xDC, 0x60, 0xF5,
+0x60, 0x42, 0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x07, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7, 0x78, 0x9B,
+0x69, 0xE2, 0x40, 0x9A, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x7C, 0x9B, 0x69, 0xE2,
+0x40, 0x9A, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x05, 0x5C, 0xAC, 0xEA, 0x4B, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x88, 0x34, 0x20, 0xF2, 0x18, 0x4B,
+0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB, 0x05, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x70, 0x9A,
+0x2D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x70, 0x9A, 0x20, 0x10, 0x05, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x74, 0x9A, 0x22, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x74, 0x9A,
+0x15, 0x10, 0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x78, 0x9A, 0x17, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x78, 0x9A, 0x0A, 0x10,
+0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x7C, 0x9A, 0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x7C, 0x9A, 0x80, 0xA3, 0xF7, 0x6A,
+0x0A, 0x10, 0x0C, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x60, 0x9A, 0x40, 0xA3, 0xFF, 0x6C,
+0x08, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x60, 0x9A, 0xF7, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0xAC, 0xEA,
+0x13, 0x60, 0x03, 0x24, 0x02, 0x74, 0x15, 0x60,
+0x18, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xE3, 0xF4, 0xC8, 0xA3, 0x01, 0x6D,
+0x4C, 0xED, 0x02, 0x6A, 0x4B, 0xEA, 0xCC, 0xEA,
+0xAD, 0xEA, 0xE3, 0xF4, 0x48, 0xC3, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x69, 0xF7, 0x4B, 0xC3,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x26, 0xF3,
+0x5A, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x44, 0x9A, 0x60, 0xA2, 0x10, 0x6A, 0x6C, 0xEA,
+0x24, 0x22, 0x02, 0x5C, 0x03, 0x61, 0x02, 0x74,
+0x17, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xE3, 0xF4, 0x88, 0xA3,
+0x01, 0x6A, 0x8C, 0xEA, 0xE3, 0xF4, 0x8B, 0xA3,
+0x7F, 0x6B, 0x5C, 0x32, 0x8C, 0xEB, 0x6D, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF7, 0x68, 0x9B, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x7A, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x4C, 0x9A,
+0x60, 0xC2, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x50, 0x9A, 0x60, 0xA2, 0xFF, 0x6A,
+0x6C, 0xEA, 0xFF, 0x72, 0x00, 0x6A, 0x0B, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x54, 0x9A,
+0x60, 0xA2, 0x07, 0x6A, 0x6C, 0xEA, 0x07, 0x6B,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0xAC, 0xEA,
+0x03, 0x60, 0x02, 0x74, 0x09, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x02, 0x6B, 0xE3, 0xF4, 0x70, 0xC2, 0x15, 0x10,
+0x09, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC0, 0xF0, 0x60, 0xA2, 0xE3, 0xF4,
+0x70, 0xC2, 0x05, 0x10, 0xFF, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0x69, 0xF7, 0x50, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4,
+0x70, 0xA2, 0xE3, 0xF4, 0x88, 0xA2, 0xE3, 0xF4,
+0x71, 0xC2, 0x40, 0x6B, 0x8D, 0xEB, 0xE3, 0xF4,
+0x68, 0xC2, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x71, 0x14, 0x01, 0x72, 0x01, 0x6B,
+0x10, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xE3, 0xF4, 0x88, 0xA3, 0x04, 0x6A,
+0x8C, 0xEA, 0x02, 0x22, 0x02, 0x6B, 0x05, 0x10,
+0xA0, 0xF0, 0x7A, 0xA3, 0x05, 0x5B, 0x0E, 0x61,
+0x08, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x58, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x5C, 0x9A, 0x02, 0x6B, 0x60, 0xC2,
+0x00, 0x6A, 0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF7, 0x78, 0x9B, 0x40, 0xC3, 0x01, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xE0, 0xF0, 0x47, 0xA0, 0x01, 0x69, 0x2C, 0xEA,
+0x15, 0x22, 0x83, 0xF6, 0x4D, 0xA0, 0x40, 0x6B,
+0x4C, 0xE9, 0xFF, 0x6A, 0x4C, 0xE9, 0x04, 0x29,
+0xA0, 0xF0, 0x5A, 0xA0, 0x07, 0x22, 0x04, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A,
+0x60, 0xC2, 0x47, 0x10, 0x63, 0xF3, 0x5B, 0xA0,
+0x33, 0x2A, 0x3B, 0x10, 0x00, 0x18, 0x71, 0x14,
+0x01, 0x72, 0x06, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x58, 0x9A, 0x20, 0xC2, 0x39, 0x10,
+0xE3, 0xF4, 0x4C, 0xA0, 0x03, 0x6B, 0x4C, 0xEB,
+0x02, 0x23, 0x02, 0x6B, 0xE5, 0x17, 0xA0, 0xF0,
+0x7A, 0xA0, 0xE1, 0x2B, 0x04, 0x6B, 0x4C, 0xEB,
+0x02, 0x23, 0x08, 0x6B, 0xDD, 0x17, 0x10, 0x6B,
+0x82, 0x67, 0x6C, 0xEC, 0x0B, 0x24, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0xF7, 0x98, 0x9C, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0, 0x60, 0x9B,
+0x40, 0xC3, 0x1B, 0x10, 0xE3, 0xF4, 0x48, 0xA0,
+0x20, 0x6B, 0xFF, 0x6C, 0x6C, 0xEA, 0x8C, 0xEA,
+0xC7, 0x22, 0x63, 0xF3, 0x5B, 0xA0, 0x03, 0x22,
+0x80, 0x6B, 0x6B, 0xEB, 0xC1, 0x17, 0x63, 0xF5,
+0x45, 0xA0, 0x4C, 0xE9, 0xFF, 0x6A, 0x4C, 0xE9,
+0x08, 0x29, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x58, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x01, 0x6A,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x5C, 0x9A, 0x04, 0x6B, 0x60, 0xC2, 0x00, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6F, 0x86, 0xF2, 0x00, 0x4F,
+0xC0, 0xF0, 0x12, 0xA7, 0x01, 0x6B, 0xFF, 0x6A,
+0x0C, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x4C, 0xED,
+0x4C, 0xEE, 0x05, 0x23, 0xC0, 0xF0, 0x54, 0xA7,
+0xFF, 0x72, 0x80, 0xF0, 0x18, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4,
+0x09, 0xA2, 0x20, 0x6F, 0xFF, 0x6B, 0x0C, 0xEF,
+0x80, 0xF0, 0x09, 0x2F, 0xC0, 0xF0, 0x12, 0xA2,
+0x01, 0x6F, 0xEC, 0xE8, 0x6C, 0xE8, 0x54, 0x28,
+0xE3, 0xF4, 0x08, 0xA2, 0x0C, 0xEF, 0x6C, 0xEF,
+0x09, 0x27, 0x03, 0xF5, 0x64, 0xA2, 0xE4, 0x43,
+0x03, 0x4B, 0xE3, 0xF4, 0xFF, 0xC2, 0xE3, 0xF4,
+0x7E, 0xC2, 0x08, 0x10, 0x05, 0x6F, 0xE3, 0xF4,
+0xFF, 0xC2, 0x05, 0x4E, 0x04, 0x6F, 0xE3, 0xF4,
+0xFE, 0xC2, 0x6C, 0xEE, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0xFD, 0xA2,
+0xE3, 0xF4, 0x7E, 0xA2, 0xE3, 0xEB, 0x09, 0x61,
+0xE3, 0xF4, 0x7F, 0xA2, 0xE3, 0xF4, 0xD2, 0xC2,
+0x71, 0xE4, 0xB7, 0xE4, 0x03, 0xF5, 0xA0, 0xC2,
+0x09, 0x10, 0xE3, 0xF4, 0x9F, 0xA2, 0x77, 0xE5,
+0xB9, 0xE6, 0x6F, 0xE4, 0xE3, 0xF4, 0xD2, 0xC2,
+0x03, 0xF5, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x7F, 0xA2,
+0x03, 0xF5, 0x80, 0xA2, 0x0A, 0x4B, 0x82, 0xEB,
+0x02, 0x60, 0x03, 0xF5, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x03, 0xF5,
+0x60, 0xA2, 0xE3, 0xF4, 0x92, 0xA2, 0x23, 0x4B,
+0x82, 0xEB, 0x02, 0x60, 0xE3, 0xF4, 0x72, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x03, 0xF5, 0x60, 0xA2, 0xE3, 0xF4, 0x7A, 0xCA,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x99, 0xA2, 0x18, 0x6B, 0x8C, 0xEB,
+0x10, 0x73, 0x0C, 0x61, 0x03, 0xF5, 0x64, 0xA2,
+0x03, 0x6C, 0x04, 0x4B, 0x03, 0xF5, 0x60, 0xC2,
+0xA0, 0xF0, 0x7C, 0xA2, 0x76, 0x33, 0x8C, 0xEB,
+0xE3, 0xF4, 0x72, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x44, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x69, 0xF7, 0x9A, 0xAC, 0xA0, 0xA2, 0xFF, 0x6B,
+0x6C, 0xED, 0x8E, 0xED, 0x02, 0x25, 0x8C, 0xEB,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xE3, 0xF4, 0x89, 0xA2, 0x41, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x02, 0x10, 0x40, 0x6B,
+0x0D, 0xEB, 0xE3, 0xF4, 0x69, 0xC2, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x02, 0x6B, 0x43, 0xF5,
+0x7C, 0xC2, 0x03, 0x6B, 0x43, 0xF5, 0x7D, 0xC2,
+0x64, 0x6B, 0x43, 0xF5, 0x7E, 0xCA, 0x01, 0x6B,
+0x63, 0xF5, 0x60, 0xC2, 0x05, 0x6B, 0x63, 0xF5,
+0x61, 0xC2, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE3, 0xF4, 0x73, 0xA2, 0xA0, 0xF0, 0x9D, 0xA2,
+0x63, 0xEC, 0x22, 0x60, 0xE3, 0xF4, 0x96, 0xA2,
+0x01, 0x4C, 0xE3, 0xF4, 0x96, 0xC2, 0xE3, 0xF4,
+0xB6, 0xA2, 0x63, 0xF5, 0x81, 0xA2, 0xA3, 0xEC,
+0x17, 0x61, 0x03, 0x6D, 0xB8, 0xEB, 0xE3, 0xF4,
+0x9C, 0xA2, 0xE3, 0xF4, 0xBD, 0xA2, 0x04, 0x6F,
+0x01, 0x4C, 0xE3, 0xF4, 0x9C, 0xC2, 0xE3, 0xF4,
+0x92, 0xA2, 0xFE, 0x4C, 0x12, 0xEB, 0x6D, 0xE4,
+0x03, 0xF5, 0x61, 0xC2, 0xE3, 0xF4, 0x9C, 0xA2,
+0x03, 0xF5, 0xC1, 0xA2, 0x00, 0x18, 0xE3, 0x14,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x89, 0xF7, 0x05, 0x4B,
+0xFF, 0x6A, 0xA7, 0x43, 0x8C, 0xEA, 0x26, 0x4D,
+0x00, 0x6C, 0x80, 0xC3, 0x01, 0x4B, 0x83, 0x67,
+0xAE, 0xEC, 0xFA, 0x2C, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xE3, 0xF4, 0x95, 0xC3,
+0xE3, 0xF4, 0x96, 0xC3, 0xE3, 0xF4, 0x9C, 0xC3,
+0x01, 0x6C, 0x8E, 0xEA, 0x05, 0x2A, 0x2D, 0x6C,
+0x03, 0xF5, 0x82, 0xC3, 0x03, 0xF5, 0x43, 0xC3,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xC0, 0xF0, 0xD2, 0xA3, 0x01, 0x6D, 0xFF, 0x6A,
+0xCC, 0xED, 0x4C, 0xED, 0x4C, 0xEC, 0x0C, 0x25,
+0xE3, 0xF4, 0x55, 0xA3, 0x01, 0x4A, 0xE3, 0xF4,
+0x55, 0xC3, 0xE3, 0xF4, 0xB5, 0xA3, 0x43, 0xF5,
+0x5E, 0xAB, 0x43, 0xED, 0xA0, 0xF0, 0x1E, 0x60,
+0x00, 0x6D, 0x00, 0x18, 0xDF, 0x13, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x23, 0xF5,
+0x98, 0x9B, 0x23, 0xF5, 0x54, 0xDB, 0x83, 0xEA,
+0x31, 0x61, 0xE3, 0xF4, 0xE8, 0xA3, 0x01, 0x6D,
+0xFF, 0x6E, 0xEC, 0xED, 0x0E, 0x25, 0x03, 0xF5,
+0xE4, 0xA3, 0x03, 0xF5, 0xA0, 0xA3, 0x93, 0xE2,
+0x0E, 0x4F, 0xBF, 0xE7, 0x43, 0xF5, 0xBC, 0xA3,
+0x82, 0x34, 0x8A, 0x34, 0xAF, 0xE7, 0x89, 0xE3,
+0x0B, 0x10, 0x43, 0xF5, 0xFD, 0xA3, 0x03, 0xF5,
+0xA0, 0xA3, 0x8B, 0xE2, 0xEB, 0xEF, 0xAF, 0xE7,
+0x42, 0x32, 0x0A, 0x4B, 0x4A, 0x32, 0x49, 0xE3,
+0xCC, 0xEA, 0x2D, 0x5A, 0x0F, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x69, 0xE2,
+0x03, 0xF5, 0x85, 0xA2, 0x01, 0x4C, 0x03, 0xF5,
+0x85, 0xC2, 0xE3, 0xF4, 0x55, 0xA3, 0x01, 0x4A,
+0xE3, 0xF4, 0x55, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x95, 0xA2,
+0x43, 0xF5, 0x7E, 0xAA, 0x63, 0xEC, 0x7A, 0x60,
+0x82, 0x10, 0xA0, 0xA4, 0xAD, 0xE3, 0xFF, 0x6D,
+0xAC, 0xEB, 0x63, 0xEE, 0x02, 0x60, 0xC2, 0x67,
+0x06, 0x10, 0x01, 0x4A, 0xAC, 0xEA, 0x2D, 0x72,
+0x01, 0x4C, 0xF3, 0x61, 0x00, 0x6E, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x43, 0xF5,
+0xFE, 0xAA, 0x63, 0xF5, 0x40, 0xA2, 0x30, 0xF0,
+0x20, 0x6D, 0x00, 0x6C, 0x5F, 0xE7, 0x89, 0xF7,
+0x05, 0x4D, 0x64, 0x67, 0x40, 0xA5, 0x51, 0xE4,
+0xFF, 0x6A, 0x4C, 0xEC, 0x82, 0xEF, 0x06, 0x61,
+0x01, 0x4B, 0x4C, 0xEB, 0x2D, 0x73, 0x01, 0x4D,
+0xF5, 0x61, 0x00, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x03, 0xF5, 0xC2, 0xC2,
+0x03, 0xF5, 0x63, 0xC2, 0x03, 0xF5, 0x62, 0xA2,
+0x0A, 0x5B, 0x05, 0x61, 0xF6, 0x4B, 0xE3, 0xF4,
+0x7D, 0xC2, 0x00, 0x6B, 0x05, 0x10, 0x00, 0x6C,
+0xE3, 0xF4, 0x9D, 0xC2, 0x0A, 0x6C, 0x6F, 0xE4,
+0xE3, 0xF4, 0x7C, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x03, 0xF5, 0x62, 0xA2,
+0x03, 0xF5, 0x83, 0xA2, 0xE3, 0xF4, 0xA8, 0xA2,
+0x73, 0xE4, 0x01, 0x6B, 0xAC, 0xEB, 0x03, 0x23,
+0x43, 0xF5, 0x7C, 0xA2, 0x02, 0x10, 0x43, 0xF5,
+0x7D, 0xA2, 0x71, 0xE4, 0x01, 0x4C, 0x03, 0xF5,
+0x81, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x03, 0xF5, 0x61, 0xA2, 0x0E, 0x5B,
+0x03, 0x60, 0x0E, 0x6B, 0x03, 0xF5, 0x61, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x03, 0xF5, 0x61, 0xA2, 0xE3, 0xF4, 0x9C, 0xA2,
+0xE3, 0xF4, 0xBD, 0xA2, 0x02, 0x4B, 0x03, 0xF5,
+0x61, 0xC2, 0x03, 0xF5, 0xC1, 0xA2, 0x03, 0x6F,
+0x00, 0x18, 0xE3, 0x14, 0x00, 0x6C, 0x00, 0x18,
+0x5E, 0x15, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x00, 0x6B, 0x63, 0xF5, 0xC0, 0xA2, 0x89, 0xF7,
+0x05, 0x4C, 0x43, 0x67, 0x7E, 0x17, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6D, 0x86, 0xF2, 0x00, 0x4D,
+0xC0, 0xF0, 0xC4, 0xA5, 0x01, 0x6B, 0xFF, 0x6A,
+0xCC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x06, 0x23,
+0xC0, 0xF0, 0x46, 0xA5, 0x01, 0x72, 0x02, 0x61,
+0x00, 0x18, 0x96, 0x3F, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x02, 0x5C,
+0xAC, 0xE8, 0x0B, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x8C, 0x3F, 0x30, 0xF0, 0x20, 0x6A, 0x46, 0xF3,
+0xA6, 0xA2, 0x90, 0x67, 0x00, 0x18, 0x0A, 0x41,
+0x06, 0x10, 0x90, 0x67, 0x00, 0x18, 0x96, 0x3F,
+0x90, 0x67, 0x00, 0x18, 0x9D, 0x3F, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x29, 0xF6, 0x68, 0xA2, 0x80, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x02, 0x2A,
+0x00, 0x18, 0x99, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3, 0x88, 0xA3,
+0x80, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0xFF, 0x6C,
+0x8C, 0xEA, 0x05, 0x22, 0xA3, 0xF3, 0x8B, 0xA3,
+0x00, 0x18, 0xE5, 0x04, 0x05, 0x10, 0x00, 0x6D,
+0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18, 0x18, 0x3A,
+0x0C, 0x6D, 0x01, 0x6C, 0x00, 0x18, 0x4A, 0x14,
+0x0C, 0x6C, 0x00, 0x18, 0x1A, 0x51, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x00, 0x18,
+0x99, 0x41, 0x05, 0x20, 0x00, 0x6D, 0xFF, 0x6C,
+0xC5, 0x67, 0x00, 0x18, 0x18, 0x3A, 0x04, 0x6D,
+0x01, 0x6C, 0x00, 0x18, 0x4A, 0x14, 0x04, 0x6C,
+0x00, 0x18, 0x1A, 0x51, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xA3, 0xF3, 0x88, 0xA3, 0x80, 0x6A, 0x4B, 0xEA,
+0x8C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA, 0x05, 0x22,
+0xA3, 0xF3, 0x8B, 0xA3, 0x00, 0x18, 0xD1, 0x04,
+0x05, 0x10, 0xFF, 0x6C, 0xA4, 0x67, 0x2F, 0x6E,
+0x00, 0x18, 0x18, 0x3A, 0x00, 0x18, 0x15, 0x41,
+0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6, 0x68, 0xA2,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x02, 0x2A, 0x00, 0x18, 0x30, 0x41,
+0x08, 0x6D, 0x01, 0x6C, 0x00, 0x18, 0x4A, 0x14,
+0x08, 0x6C, 0x00, 0x18, 0x1A, 0x51, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x46, 0xF3,
+0x44, 0xA2, 0x02, 0x68, 0x0C, 0xEA, 0x20, 0x2A,
+0x00, 0x18, 0xF5, 0x1F, 0x01, 0x6B, 0x0F, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x48, 0x9A,
+0x10, 0x6B, 0x40, 0xA2, 0x08, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x4C, 0x9A, 0x40, 0xA2,
+0x4C, 0xE8, 0x0E, 0x28, 0x04, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x5C, 0x9A,
+0x08, 0x6B, 0x60, 0xC2, 0x00, 0x6A, 0x17, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF7, 0x7C, 0x9B, 0x08, 0x6A, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0, 0x60, 0x9B,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0,
+0x70, 0x9B, 0x40, 0xC3, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2, 0x00, 0x49,
+0x40, 0xF1, 0x62, 0xA1, 0x01, 0x6A, 0x6C, 0xEA,
+0x20, 0x22, 0x00, 0x18, 0xF5, 0x1F, 0x1B, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x48, 0x9A,
+0x40, 0xA2, 0x15, 0x2A, 0x23, 0xF5, 0x72, 0xA1,
+0x40, 0xF1, 0x43, 0xA1, 0x43, 0xEB, 0x11, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x54, 0x9A,
+0x00, 0xA2, 0xFF, 0x6A, 0x4C, 0xE8, 0x07, 0x28,
+0x06, 0x6C, 0x01, 0x6D, 0x00, 0x18, 0x9E, 0x1D,
+0x23, 0xF5, 0x12, 0xC1, 0x02, 0x10, 0x00, 0x6A,
+0x01, 0x10, 0x01, 0x6A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF2, 0x64, 0x9A,
+0xE0, 0xF2, 0x04, 0x4A, 0xFF, 0x69, 0x04, 0xD3,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0x9A, 0x2C, 0xEC,
+0x44, 0xAA, 0x86, 0xF2, 0x00, 0x48, 0x08, 0xD4,
+0xC0, 0xF0, 0x9A, 0xA0, 0x05, 0xD3, 0x7D, 0x67,
+0x4C, 0xCB, 0x00, 0x18, 0xAA, 0x13, 0x01, 0x72,
+0x2A, 0x61, 0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x24, 0x22, 0xA0, 0xF0,
+0x77, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA, 0x01, 0x72,
+0x1E, 0x61, 0x08, 0x93, 0x1F, 0xF7, 0x00, 0x6C,
+0x64, 0x32, 0x7D, 0x67, 0x49, 0xE3, 0x68, 0xAA,
+0x41, 0x43, 0x8C, 0xEA, 0x02, 0xF0, 0x00, 0x72,
+0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x5C, 0x9A, 0x4D, 0xE3,
+0x60, 0xA3, 0x20, 0x6A, 0x6C, 0xEA, 0x4B, 0xEA,
+0xC0, 0xF7, 0x42, 0x32, 0x01, 0x10, 0x01, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x26, 0xF3, 0xB9, 0xA3,
+0x04, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x09, 0x23, 0x7D, 0x67, 0x1E, 0x6A,
+0x50, 0xC3, 0x01, 0x6A, 0x92, 0xC3, 0x4F, 0xCB,
+0x04, 0x04, 0x00, 0x18, 0xBC, 0x27, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xFF, 0x68, 0x8C, 0xE8, 0xE3, 0xF4,
+0x88, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x41, 0x6D,
+0x8C, 0xEB, 0xAB, 0xED, 0xAC, 0xEB, 0xE3, 0xF4,
+0xA9, 0xA2, 0xE3, 0xF4, 0x68, 0xC2, 0x11, 0x6B,
+0x00, 0x6C, 0x6B, 0xEB, 0xE3, 0xF4, 0x93, 0xC2,
+0xE3, 0xF4, 0x8C, 0xC2, 0xAC, 0xEB, 0xE3, 0xF4,
+0x94, 0xC2, 0x90, 0x67, 0xE3, 0xF4, 0x69, 0xC2,
+0x00, 0x18, 0x9D, 0x3F, 0x90, 0x67, 0x00, 0x18,
+0x96, 0x3F, 0x90, 0x67, 0x00, 0x18, 0xAB, 0x3F,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0xFF, 0x69, 0x86, 0xF2,
+0x00, 0x48, 0x8C, 0xE9, 0xC0, 0xF0, 0x9A, 0xA0,
+0x00, 0x18, 0xAA, 0x13, 0x01, 0x72, 0x2F, 0x61,
+0xE3, 0xF4, 0x69, 0xA0, 0x09, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6C, 0x6F, 0x6D, 0x2C, 0x6E,
+0xE3, 0xF4, 0x49, 0xC0, 0x00, 0x18, 0x18, 0x3A,
+0xA0, 0xF0, 0x8A, 0xA0, 0x01, 0x6D, 0x08, 0x6E,
+0xF1, 0x67, 0x00, 0x18, 0x6D, 0x1D, 0x01, 0x72,
+0x0E, 0x61, 0xE3, 0xF4, 0x69, 0xA0, 0x02, 0x6A,
+0x01, 0x6C, 0x6D, 0xEA, 0x0E, 0x6D, 0xE3, 0xF4,
+0x49, 0xC0, 0x00, 0x18, 0x4A, 0x14, 0x0E, 0x6C,
+0x00, 0x18, 0x1A, 0x51, 0x0C, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x5C, 0x9A, 0x01, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x58, 0x9A, 0x02, 0x6B, 0x60, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x01, 0x6C, 0xF0, 0x6D,
+0x00, 0x18, 0x4A, 0x14, 0x00, 0x18, 0x5C, 0x16,
+0x0E, 0x22, 0x00, 0x6C, 0x00, 0x18, 0xA1, 0x40,
+0x00, 0x18, 0x02, 0x39, 0x00, 0x18, 0xC1, 0x38,
+0x01, 0x6C, 0x00, 0x18, 0xA1, 0x40, 0x01, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0x4A, 0x14, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2,
+0x02, 0x22, 0x08, 0x72, 0x06, 0x61, 0x00, 0x18,
+0x39, 0x16, 0x01, 0x72, 0x02, 0x61, 0x00, 0x18,
+0xE2, 0x16, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x88, 0xA2,
+0x01, 0x6B, 0xFF, 0x6D, 0x6C, 0xEC, 0x20, 0x24,
+0xA0, 0xF0, 0x95, 0xA2, 0x6C, 0xEC, 0xAC, 0xEC,
+0x05, 0x2C, 0xA3, 0xF3, 0x48, 0xA2, 0x6C, 0xEA,
+0xAC, 0xEA, 0x13, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2,
+0x02, 0x6B, 0x6C, 0xEC, 0x06, 0x2C, 0xA3, 0xF3,
+0x48, 0xA2, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x04, 0x22, 0x00, 0x18, 0x80, 0x50, 0x01, 0x72,
+0x05, 0x61, 0x00, 0x18, 0xEF, 0x16, 0x02, 0x10,
+0x00, 0x18, 0x5C, 0x16, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x6D, 0xC5, 0x67, 0xFF, 0x6C,
+0x00, 0x18, 0x18, 0x3A, 0x04, 0x6D, 0x01, 0x6C,
+0x00, 0x18, 0x4A, 0x14, 0x30, 0xF0, 0x20, 0x6A,
+0x29, 0xF6, 0x0A, 0xA2, 0x90, 0x67, 0x00, 0x18,
+0x0D, 0x50, 0x40, 0x6B, 0x4D, 0xEB, 0xFF, 0x6D,
+0x90, 0x67, 0x6C, 0xED, 0x00, 0x18, 0x00, 0x50,
+0x04, 0x6C, 0x00, 0x18, 0x1A, 0x51, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x2E, 0x6E,
+0xFF, 0x6C, 0x6F, 0x6D, 0x00, 0x18, 0x18, 0x3A,
+0x02, 0x6D, 0x01, 0x6C, 0x00, 0x18, 0x4A, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6, 0x0A, 0xA2,
+0x90, 0x67, 0x00, 0x18, 0x0D, 0x50, 0xBF, 0x6D,
+0x90, 0x67, 0x4C, 0xED, 0x00, 0x18, 0x00, 0x50,
+0x02, 0x6C, 0x00, 0x18, 0x1A, 0x51, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x60, 0x9B,
+0xFF, 0x6A, 0x24, 0x67, 0x00, 0xA3, 0x82, 0x67,
+0xA2, 0x67, 0x2D, 0x6E, 0x4C, 0xE9, 0x4C, 0xE8,
+0x00, 0x18, 0x18, 0x3A, 0x00, 0x18, 0x15, 0x41,
+0x06, 0x2A, 0xFF, 0x6C, 0xB0, 0x67, 0x2D, 0x6E,
+0x00, 0x18, 0x18, 0x3A, 0x2F, 0x10, 0x05, 0x59,
+0x24, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x28, 0x31,
+0x40, 0xF2, 0x0C, 0x4A, 0x29, 0xE2, 0x40, 0x9A,
+0x00, 0xEA, 0x00, 0x6C, 0x08, 0x6D, 0x17, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0xA0, 0xF7,
+0xA8, 0x9A, 0x11, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0x21, 0xF0, 0xA4, 0x9A, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0x21, 0xF0,
+0xA8, 0x9A, 0x05, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0xAC, 0x9A, 0x04, 0x6C, 0x00, 0x18,
+0x22, 0x09, 0x00, 0x18, 0x30, 0x41, 0x01, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0x4A, 0x14, 0x00, 0x6C,
+0x00, 0x18, 0x1A, 0x51, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xE3, 0xF4, 0x69, 0xA0, 0x08, 0x6A, 0xFF, 0x69,
+0x6C, 0xEA, 0x2C, 0xEA, 0x2C, 0xEC, 0x05, 0x2A,
+0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18, 0x4A, 0x14,
+0x41, 0x10, 0x01, 0x6D, 0x00, 0x18, 0x90, 0x55,
+0x01, 0x6C, 0x04, 0x6D, 0x00, 0x18, 0x4A, 0x14,
+0xA0, 0xF0, 0x75, 0xA0, 0x01, 0x6A, 0x4C, 0xEB,
+0x2C, 0xEB, 0x05, 0x2B, 0xA3, 0xF3, 0x68, 0xA0,
+0x6C, 0xEA, 0x2C, 0xEA, 0x2C, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x95, 0xA2, 0x04, 0x6B, 0x6C, 0xEC, 0x06, 0x2C,
+0xA3, 0xF3, 0x48, 0xA2, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x1D, 0x22, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xA3, 0xF3, 0x2A, 0xA0,
+0x91, 0x67, 0x00, 0x18, 0x0D, 0x50, 0x80, 0x6D,
+0xAB, 0xED, 0x4D, 0xED, 0xFF, 0x6A, 0x4C, 0xED,
+0x91, 0x67, 0x00, 0x18, 0x00, 0x50, 0xA3, 0xF3,
+0x0A, 0xA0, 0x90, 0x67, 0x00, 0x18, 0x0D, 0x50,
+0x20, 0x6D, 0x4D, 0xED, 0xFF, 0x6A, 0x90, 0x67,
+0x4C, 0xED, 0x00, 0x18, 0x00, 0x50, 0x04, 0x6C,
+0x00, 0x18, 0x1A, 0x51, 0x00, 0x6D, 0xFF, 0x6C,
+0xC5, 0x67, 0x00, 0x18, 0x18, 0x3A, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2, 0x00, 0x49,
+0xE3, 0xF4, 0xA9, 0xA1, 0x04, 0x6B, 0xFF, 0x6A,
+0xAC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x08, 0x2B,
+0x03, 0x6D, 0x00, 0x18, 0x90, 0x55, 0x01, 0x6C,
+0x04, 0x6D, 0x00, 0x18, 0x4A, 0x14, 0x1E, 0x10,
+0x00, 0x6D, 0x00, 0x18, 0x90, 0x55, 0x0C, 0x6D,
+0x01, 0x6C, 0x00, 0x18, 0x4A, 0x14, 0xA3, 0xF3,
+0x0A, 0xA1, 0x90, 0x67, 0x00, 0x18, 0x0D, 0x50,
+0x7F, 0x6D, 0x90, 0x67, 0x4C, 0xED, 0x00, 0x18,
+0x00, 0x50, 0xA3, 0xF3, 0x0A, 0xA1, 0x90, 0x67,
+0x00, 0x18, 0x0D, 0x50, 0xDF, 0x6D, 0x90, 0x67,
+0x4C, 0xED, 0x00, 0x18, 0x00, 0x50, 0x0C, 0x6C,
+0x00, 0x18, 0x1A, 0x51, 0x00, 0x6D, 0xFF, 0x6C,
+0xC5, 0x67, 0x00, 0x18, 0x18, 0x3A, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x6D, 0x00, 0x18, 0x90, 0x55, 0x00, 0x6D,
+0xC5, 0x67, 0xFF, 0x6C, 0x00, 0x18, 0x18, 0x3A,
+0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18, 0x4A, 0x14,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x2C, 0xEC, 0xAC, 0xE9, 0x3D, 0x24,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xC0, 0xF0, 0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13,
+0x01, 0x72, 0x33, 0x61, 0xE3, 0xF4, 0x69, 0xA0,
+0x05, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x2B, 0x6E,
+0xFF, 0x6C, 0x0F, 0x6D, 0xE3, 0xF4, 0x49, 0xC0,
+0x00, 0x18, 0x18, 0x3A, 0x91, 0x67, 0x02, 0x6D,
+0x00, 0x18, 0x90, 0x55, 0xA0, 0xF0, 0x8A, 0xA0,
+0x00, 0x6D, 0x08, 0x6E, 0xF1, 0x67, 0x00, 0x18,
+0x6D, 0x1D, 0x01, 0x72, 0x0E, 0x61, 0xE3, 0xF4,
+0x69, 0xA0, 0x01, 0x6A, 0x01, 0x6C, 0x6D, 0xEA,
+0x06, 0x6D, 0xE3, 0xF4, 0x49, 0xC0, 0x00, 0x18,
+0x4A, 0x14, 0x06, 0x6C, 0x00, 0x18, 0x1A, 0x51,
+0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x5C, 0x9A, 0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A, 0x08, 0x6B,
+0x60, 0xC2, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x25, 0x67, 0x30, 0xF0,
+0x20, 0x6D, 0x86, 0xF2, 0x00, 0x4D, 0x06, 0x67,
+0xE3, 0xF4, 0xC9, 0xA5, 0x03, 0x6B, 0xFF, 0x6A,
+0xCC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x4C, 0xE9,
+0x4C, 0xE8, 0xE0, 0xF0, 0x03, 0x2B, 0xE3, 0xF4,
+0x4B, 0xA5, 0x8E, 0xEA, 0xC0, 0xF0, 0x1E, 0x22,
+0x0D, 0x5C, 0xC0, 0xF0, 0x1B, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x88, 0x34, 0x60, 0xF2, 0x00, 0x4A,
+0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2, 0x0E, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x5A, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2,
+0x03, 0x2A, 0x01, 0x6C, 0x00, 0x18, 0x15, 0x16,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2,
+0x06, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x8A, 0x17, 0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7,
+0x4B, 0xA2, 0x04, 0x72, 0x09, 0x61, 0x05, 0x21,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0xB4, 0x17,
+0x03, 0x10, 0x90, 0x67, 0x00, 0x18, 0xAA, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2,
+0x08, 0x72, 0xA0, 0xF0, 0x03, 0x61, 0x00, 0x18,
+0xFE, 0x15, 0xA0, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x69, 0xF7, 0x4B, 0xA2, 0x03, 0x2A, 0x01, 0x6C,
+0x00, 0x18, 0x15, 0x16, 0x30, 0xF0, 0x20, 0x6A,
+0x69, 0xF7, 0x4B, 0xA2, 0x06, 0x72, 0x03, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x8A, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2, 0x0E, 0x72,
+0x07, 0x61, 0x00, 0x18, 0x93, 0x14, 0x01, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x5A, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2,
+0x0C, 0x72, 0x7C, 0x61, 0x00, 0x18, 0x93, 0x14,
+0x01, 0x72, 0x78, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xC0, 0x16, 0x74, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x69, 0xF7, 0x4B, 0xA2, 0x0E, 0x72, 0x07, 0x61,
+0x00, 0x18, 0x93, 0x14, 0x01, 0x72, 0x03, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x5A, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2, 0x06, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x8A, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2,
+0x0C, 0x72, 0x07, 0x61, 0x00, 0x18, 0x93, 0x14,
+0x01, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xC0, 0x16, 0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7,
+0x4B, 0xA2, 0x04, 0x72, 0x4B, 0x61, 0x00, 0x18,
+0xAA, 0x14, 0x01, 0x72, 0x47, 0x61, 0x90, 0x67,
+0x00, 0x18, 0x32, 0x17, 0x43, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2, 0x0E, 0x72,
+0x07, 0x61, 0x00, 0x18, 0x93, 0x14, 0x01, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x5A, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2,
+0x06, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x8A, 0x17, 0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7,
+0x4B, 0xA2, 0x0C, 0x72, 0x07, 0x61, 0x00, 0x18,
+0x93, 0x14, 0x01, 0x72, 0x03, 0x61, 0x90, 0x67,
+0x00, 0x18, 0xC0, 0x16, 0x30, 0xF0, 0x20, 0x6A,
+0x69, 0xF7, 0x4B, 0xA2, 0x03, 0x2A, 0x01, 0x6C,
+0x00, 0x18, 0x15, 0x16, 0x30, 0xF0, 0x20, 0x6A,
+0x69, 0xF7, 0x4B, 0xA2, 0x04, 0x72, 0x12, 0x61,
+0x00, 0x18, 0x22, 0x17, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4,
+0x6B, 0xA2, 0x0C, 0x73, 0x07, 0x61, 0xE3, 0xF4,
+0x68, 0xA2, 0x20, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x21, 0x16, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x86, 0xF2, 0x00, 0x48, 0x05, 0xD4, 0xC0, 0xF0,
+0x86, 0xA0, 0x2C, 0xED, 0x04, 0xD5, 0x00, 0x18,
+0xEF, 0x15, 0x05, 0x92, 0x01, 0x72, 0x09, 0x61,
+0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x1C, 0x2A, 0x00, 0x18, 0x21, 0x16,
+0x19, 0x10, 0x04, 0x94, 0x00, 0x18, 0x96, 0x3F,
+0x04, 0x94, 0x00, 0x18, 0x9D, 0x3F, 0xA0, 0xF0,
+0x76, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x0B, 0x22, 0xE3, 0xF4, 0x4B, 0xA0, 0x04, 0x6B,
+0x6C, 0xEA, 0x08, 0x2A, 0x04, 0x96, 0x83, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0xD9, 0x17, 0x02, 0x10,
+0x00, 0x18, 0xFE, 0x15, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA4, 0x67,
+0x63, 0xF5, 0x84, 0xA3, 0xFF, 0x6A, 0x4C, 0xED,
+0x04, 0x24, 0xFF, 0x4C, 0x63, 0xF5, 0x84, 0xC3,
+0x3B, 0x10, 0xC0, 0xF0, 0x85, 0xA3, 0xFF, 0x4C,
+0x63, 0xF5, 0x84, 0xC3, 0x63, 0xF5, 0x85, 0xA3,
+0x02, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x03, 0x2B,
+0x00, 0x6C, 0x00, 0x18, 0x58, 0x18, 0x30, 0xF0,
+0x20, 0x6A, 0x46, 0xF3, 0x84, 0xA2, 0x04, 0x6A,
+0xFF, 0x6B, 0x8C, 0xEA, 0x25, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x44, 0x9A, 0x80, 0xA2,
+0x00, 0x6A, 0x6C, 0xEC, 0x03, 0x5C, 0x02, 0x61,
+0x4D, 0x44, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xC0, 0xF0, 0xC7, 0xA0,
+0x0A, 0x6B, 0x10, 0xF0, 0x20, 0x6C, 0x78, 0xEE,
+0x00, 0x6B, 0xA3, 0x67, 0x0C, 0xF3, 0x05, 0x4C,
+0x01, 0x6F, 0x04, 0xD3, 0x12, 0xEE, 0x5B, 0xE6,
+0x00, 0x18, 0x8A, 0x3B, 0x63, 0xF5, 0x65, 0xA0,
+0x01, 0x6A, 0x6D, 0xEA, 0x63, 0xF5, 0x45, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x63, 0xF5, 0x85, 0xA2, 0x03, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x63, 0xF5, 0x65, 0xC2, 0x07, 0x97,
+0x06, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x24, 0x67, 0xC0, 0xF0, 0x84, 0xA0, 0x01, 0x6B,
+0xFF, 0x6A, 0x8C, 0xEB, 0x4C, 0xEB, 0x4C, 0xE9,
+0x0C, 0x23, 0xC0, 0xF0, 0x46, 0xA0, 0x02, 0x5A,
+0x08, 0x61, 0x91, 0x67, 0x00, 0x18, 0x76, 0x18,
+0xC0, 0xF0, 0xA6, 0xA0, 0x91, 0x67, 0x00, 0x18,
+0x0A, 0x41, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6D, 0x86, 0xF2, 0x00, 0x4D,
+0xC0, 0xF0, 0xC4, 0xA5, 0x01, 0x6B, 0xFF, 0x6A,
+0xCC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x06, 0x23,
+0xC0, 0xF0, 0x46, 0xA5, 0x01, 0x72, 0x02, 0x61,
+0x00, 0x18, 0x76, 0x18, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC0, 0xF0, 0x84, 0xA2, 0x04, 0x6B, 0x8C, 0xEB,
+0x0B, 0x23, 0x63, 0xF5, 0x85, 0xA2, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x00, 0x6D, 0x01, 0x6C,
+0x63, 0xF5, 0x65, 0xC2, 0x00, 0x18, 0x58, 0x18,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x24, 0x67, 0xE3, 0xF4, 0x8C, 0xA0, 0x10, 0x6B,
+0xFF, 0x6A, 0x8D, 0xEB, 0xC0, 0xF0, 0x92, 0xA0,
+0xE3, 0xF4, 0x6C, 0xC0, 0x01, 0x6B, 0x8C, 0xEB,
+0x4C, 0xEB, 0x4C, 0xE9, 0x22, 0x23, 0xC0, 0xF0,
+0x54, 0xA0, 0xFF, 0x72, 0x46, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x50, 0x9A, 0x00, 0x6B,
+0xFF, 0x6C, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x54, 0x9A, 0x04, 0x6B, 0x59, 0x4C,
+0x60, 0xC2, 0x00, 0x6D, 0x05, 0x6E, 0x00, 0x18,
+0x04, 0x31, 0xC0, 0xF0, 0xD4, 0xA0, 0xFF, 0x6C,
+0x55, 0x4C, 0x00, 0x6D, 0x05, 0x4E, 0x00, 0x18,
+0x04, 0x31, 0x91, 0x67, 0x00, 0x18, 0xB5, 0x3F,
+0x28, 0x10, 0xE3, 0xF4, 0x53, 0xA0, 0x02, 0x5A,
+0x0D, 0x60, 0xE3, 0xF4, 0xD2, 0xA0, 0xFF, 0x6C,
+0x55, 0x4C, 0xD9, 0xE2, 0x00, 0x6D, 0x00, 0x18,
+0x04, 0x31, 0xE3, 0xF4, 0x73, 0xA0, 0xE3, 0xF4,
+0x52, 0xA0, 0x14, 0x10, 0x03, 0x6B, 0x78, 0xEA,
+0xE3, 0xF4, 0xD2, 0xA0, 0xFF, 0x6C, 0x55, 0x4C,
+0xFE, 0x4E, 0x00, 0x6D, 0x12, 0xEA, 0x59, 0xE6,
+0x00, 0x18, 0x04, 0x31, 0xE3, 0xF4, 0x53, 0xA0,
+0x03, 0x6C, 0xE3, 0xF4, 0x72, 0xA0, 0x98, 0xEA,
+0xFE, 0x4B, 0x12, 0xEA, 0x49, 0xE3, 0x03, 0xF5,
+0x41, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x63, 0xF5, 0x85, 0xA2, 0x02, 0x6B,
+0x8D, 0xEB, 0x63, 0xF5, 0x65, 0xC2, 0xE3, 0xF4,
+0x4B, 0xA2, 0x04, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x83, 0x67, 0x01, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xD9, 0x17, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x2C, 0xEC,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x04, 0xD4, 0xA0, 0xF0, 0x76, 0xA0, 0x00, 0x6A,
+0xE3, 0xF4, 0x57, 0xC0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x46, 0x22, 0xC0, 0xF0, 0x9A, 0xA0,
+0x00, 0x18, 0xAA, 0x13, 0x01, 0x72, 0x78, 0x67,
+0x05, 0xD3, 0x3E, 0x2B, 0x04, 0x94, 0xE3, 0xF4,
+0xB0, 0xA0, 0x00, 0x18, 0x0A, 0x41, 0x04, 0x94,
+0x00, 0x6D, 0x00, 0x18, 0xDF, 0x13, 0xE3, 0xF4,
+0x69, 0xA0, 0x23, 0xF5, 0x58, 0xD8, 0x20, 0x6A,
+0x6D, 0xEA, 0xE3, 0xF4, 0x49, 0xC0, 0x5D, 0x67,
+0x67, 0x42, 0x0D, 0x4B, 0x40, 0xA3, 0xA0, 0xF0,
+0x75, 0xA0, 0xE3, 0xF4, 0x51, 0xC0, 0x01, 0x6A,
+0x4C, 0xEB, 0x2C, 0xEB, 0x06, 0x2B, 0xA3, 0xF3,
+0x68, 0xA0, 0x6C, 0xEA, 0x2C, 0xEA, 0x01, 0x6B,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6,
+0x06, 0xA2, 0x00, 0x18, 0x29, 0x50, 0x00, 0x6B,
+0x03, 0x22, 0x02, 0x70, 0x01, 0x60, 0x01, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC0, 0xF0, 0xA5, 0xA2, 0xE3, 0xF4, 0x90, 0xA2,
+0xAE, 0xEC, 0x02, 0x2C, 0x63, 0xF5, 0x84, 0xC2,
+0x03, 0x23, 0x04, 0x94, 0x00, 0x18, 0xCE, 0x18,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xA0, 0xF0, 0x76, 0xA0,
+0x00, 0x6A, 0xE3, 0xF4, 0x57, 0xC0, 0x7F, 0x6A,
+0xFF, 0x69, 0x6C, 0xEA, 0x2C, 0xEC, 0x2C, 0xEA,
+0x04, 0xD4, 0x40, 0x22, 0xC0, 0xF0, 0x9A, 0xA0,
+0x00, 0x18, 0xAA, 0x13, 0x01, 0x72, 0x3A, 0x61,
+0x04, 0x94, 0x00, 0x6D, 0x00, 0x18, 0xDF, 0x13,
+0xE3, 0xF4, 0x69, 0xA0, 0x23, 0xF5, 0x58, 0xD8,
+0x20, 0x6A, 0x6D, 0xEA, 0xA0, 0xF0, 0x77, 0xA0,
+0xE3, 0xF4, 0x49, 0xC0, 0x0F, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x01, 0x69, 0x06, 0x22, 0xE3, 0xF4,
+0x29, 0xA0, 0x01, 0x6A, 0x32, 0x31, 0x4E, 0xE9,
+0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2, 0x01, 0x6B,
+0x6C, 0xEC, 0x06, 0x2C, 0xA3, 0xF3, 0x48, 0xA2,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x0E, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6, 0x66, 0xA2,
+0x02, 0x6A, 0x4E, 0xEB, 0x6B, 0xEA, 0x6D, 0xEA,
+0xC0, 0xF7, 0x43, 0x32, 0x4C, 0xE9, 0x00, 0x18,
+0x29, 0x50, 0x04, 0x22, 0x03, 0x21, 0x04, 0x94,
+0x00, 0x18, 0xCE, 0x18, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA0, 0xF0, 0xB5, 0xA3,
+0xC4, 0x67, 0x01, 0x6C, 0xFF, 0x6A, 0x8C, 0xED,
+0x4C, 0xED, 0x4C, 0xEE, 0x05, 0x2D, 0xA3, 0xF3,
+0xA8, 0xA3, 0xAC, 0xEC, 0x4C, 0xEC, 0x07, 0x24,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x9A, 0xA2,
+0x00, 0x18, 0x69, 0x51, 0x05, 0x10, 0xA0, 0xF0,
+0x9A, 0xA3, 0x01, 0x6D, 0x00, 0x18, 0xD9, 0x17,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x8C, 0xE9, 0x05, 0x59, 0x5D, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x28, 0x33, 0x80, 0xF2,
+0x14, 0x4A, 0x69, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x00, 0x6C, 0x08, 0x6D, 0x00, 0x18, 0x22, 0x09,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0xB8, 0x9A,
+0x01, 0x6C, 0x00, 0x18, 0x22, 0x09, 0x01, 0x6C,
+0x0C, 0x6D, 0x45, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0xA8, 0x9A, 0x04, 0x6C, 0x00, 0x18,
+0x22, 0x09, 0x04, 0x6C, 0x03, 0x6D, 0x00, 0x18,
+0x22, 0x09, 0x30, 0xF0, 0x20, 0x6A, 0x02, 0x6C,
+0x21, 0xF0, 0xBC, 0x9A, 0x34, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0xA4, 0x9A, 0x04, 0x6C,
+0x00, 0x18, 0x22, 0x09, 0x04, 0x6C, 0x30, 0x6D,
+0x00, 0x18, 0x22, 0x09, 0x30, 0xF0, 0x20, 0x6A,
+0x02, 0x6C, 0x41, 0xF0, 0xA0, 0x9A, 0x23, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0xA8, 0x9A,
+0x04, 0x6C, 0x00, 0x18, 0x22, 0x09, 0x04, 0x6C,
+0x00, 0xF3, 0x00, 0x6D, 0x00, 0x18, 0x22, 0x09,
+0x30, 0xF0, 0x20, 0x6A, 0x02, 0x6C, 0x41, 0xF0,
+0xA4, 0x9A, 0x11, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0xAC, 0x9A, 0x04, 0x6C, 0x00, 0x18,
+0x22, 0x09, 0x04, 0x6C, 0x06, 0xF0, 0x00, 0x6D,
+0x00, 0x18, 0x22, 0x09, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xA8, 0x9A, 0x02, 0x6C, 0x00, 0x18,
+0x86, 0x09, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x88, 0x9A, 0xFF, 0x6B, 0x07, 0x6D, 0x40, 0xA4,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0xE3, 0xF4, 0x5A, 0xA8, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x44, 0x9A, 0x60, 0xC2,
+0xC0, 0xF0, 0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13,
+0x01, 0x72, 0x12, 0x61, 0xE3, 0xF4, 0x68, 0xA0,
+0x21, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xE3, 0xF4,
+0x48, 0xC0, 0xE3, 0xF4, 0x4B, 0xA0, 0x04, 0x6B,
+0x6C, 0xEA, 0x0C, 0x2A, 0x83, 0x67, 0x01, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xD9, 0x17, 0x06, 0x10,
+0xE3, 0xF4, 0x68, 0xA0, 0x20, 0x6A, 0x6D, 0xEA,
+0xE3, 0xF4, 0x48, 0xC0, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6C,
+0x46, 0xF3, 0x19, 0x4C, 0x00, 0x6D, 0x07, 0x6E,
+0x00, 0x18, 0xB4, 0x20, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6C,
+0x69, 0xF7, 0x08, 0x4C, 0x00, 0x6D, 0x74, 0x6E,
+0x00, 0x18, 0xB4, 0x20, 0x30, 0xF0, 0x20, 0x6C,
+0x07, 0x6E, 0x46, 0xF3, 0x04, 0x4C, 0x00, 0x6D,
+0x30, 0xF0, 0x20, 0x68, 0x00, 0x18, 0xB4, 0x20,
+0x86, 0xF2, 0x00, 0x48, 0x02, 0x6A, 0xA0, 0xF0,
+0x58, 0xC0, 0x01, 0x6A, 0xE3, 0xF4, 0x50, 0xC0,
+0xE3, 0xF4, 0x51, 0xC0, 0x05, 0x6A, 0xE3, 0xF4,
+0x5A, 0xC8, 0x03, 0xF5, 0x44, 0xA0, 0x0E, 0x69,
+0xE3, 0xF4, 0x32, 0xC0, 0x04, 0x4A, 0x03, 0xF5,
+0x40, 0xC0, 0x03, 0xF5, 0x21, 0xC0, 0x00, 0x18,
+0x3B, 0x15, 0x00, 0x6C, 0xA4, 0x67, 0x00, 0x18,
+0x4A, 0x14, 0x02, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0x4A, 0x14, 0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0x4A, 0x14, 0x30, 0xF0, 0x20, 0x6C, 0x00, 0x6D,
+0x69, 0xF7, 0x18, 0x4C, 0x00, 0x18, 0x91, 0x40,
+0xA0, 0xF0, 0x7F, 0xA0, 0x02, 0x6A, 0xA0, 0xF0,
+0x5D, 0xC0, 0x0F, 0x6A, 0xA0, 0xF0, 0x5E, 0xC0,
+0x01, 0x6A, 0x6C, 0xEA, 0x28, 0x6B, 0x6D, 0xEA,
+0xA0, 0xF0, 0x5F, 0xC0, 0x07, 0x6A, 0xC0, 0xF0,
+0x40, 0xC0, 0x03, 0xF5, 0x44, 0xA0, 0x01, 0x6C,
+0x03, 0xF5, 0x21, 0xC0, 0x04, 0x4A, 0x03, 0xF5,
+0x40, 0xC0, 0x00, 0x18, 0x5E, 0x15, 0x00, 0x6C,
+0xA4, 0x67, 0x00, 0x18, 0x90, 0x55, 0x01, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0x90, 0x55, 0x02, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0x90, 0x55, 0x03, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0x90, 0x55, 0x04, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0x90, 0x55, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x48, 0x9A, 0xF8, 0x69,
+0x00, 0x6D, 0x60, 0xA2, 0xFF, 0x6C, 0xC5, 0x67,
+0x2C, 0xEB, 0x60, 0xC2, 0x00, 0x18, 0x18, 0x3A,
+0x00, 0x6A, 0x63, 0xF3, 0x5B, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x4C, 0x9A, 0x60, 0xA2,
+0x6C, 0xE9, 0x20, 0xC2, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x69, 0xF7, 0xA8, 0xA3,
+0x04, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x06, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x50, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x02, 0x6D, 0x00, 0x18, 0x7C, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x54, 0x9A, 0x04, 0x69,
+0x30, 0xF0, 0x20, 0x68, 0x20, 0xDA, 0x86, 0xF2,
+0x00, 0x48, 0xA0, 0xF0, 0xDF, 0xA0, 0xFF, 0x6C,
+0x59, 0x4C, 0x00, 0x6D, 0xC6, 0x36, 0x00, 0x18,
+0x04, 0x31, 0xE3, 0xF4, 0x48, 0xA0, 0x07, 0x97,
+0x4D, 0xE9, 0xE3, 0xF4, 0x28, 0xC0, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA0, 0xF0,
+0xB6, 0xA3, 0x04, 0x67, 0x7F, 0x6C, 0xFF, 0x6A,
+0xAC, 0xEC, 0x4C, 0xEC, 0x01, 0x74, 0x4C, 0xE8,
+0x15, 0x61, 0xA0, 0xF0, 0xB7, 0xA3, 0x10, 0x6C,
+0x8B, 0xEC, 0xAC, 0xEC, 0x4C, 0xEC, 0x10, 0x24,
+0xD0, 0x67, 0x0C, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0xD9, 0x17, 0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67,
+0x00, 0x18, 0x18, 0x3A, 0x90, 0x67, 0x00, 0x18,
+0x18, 0x1A, 0x0A, 0x10, 0x02, 0x74, 0x08, 0x61,
+0xE3, 0xF4, 0x4B, 0xA3, 0x05, 0x2A, 0x04, 0x6C,
+0x01, 0x6D, 0xD0, 0x67, 0x00, 0x18, 0xD9, 0x17,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x66, 0xF3, 0xA7, 0xA3, 0x01, 0x6B, 0xFF, 0x6A,
+0xAC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x02, 0x2B,
+0x00, 0x18, 0x32, 0x1A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x30, 0xF0, 0x20, 0x68, 0x91, 0x67, 0x86, 0xF2,
+0x00, 0x48, 0x00, 0x18, 0x18, 0x1A, 0xE3, 0xF4,
+0x4B, 0xA0, 0x0C, 0x72, 0x17, 0x60, 0x0C, 0x6C,
+0x00, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0xD9, 0x17,
+0x00, 0x6D, 0xC5, 0x67, 0xFF, 0x6C, 0x00, 0x18,
+0x18, 0x3A, 0xE3, 0xF4, 0x69, 0xA0, 0xA0, 0xF0,
+0x8A, 0xA0, 0x01, 0x6A, 0x6D, 0xEA, 0x00, 0x6D,
+0x08, 0x6E, 0xF1, 0x67, 0xE3, 0xF4, 0x49, 0xC0,
+0x00, 0x18, 0x6D, 0x1D, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x40, 0xF1, 0xA2, 0xA3, 0x24, 0x67, 0x01, 0x6C,
+0xFF, 0x6A, 0xAC, 0xEC, 0x4C, 0xEC, 0x4C, 0xE9,
+0x05, 0x24, 0x23, 0xF5, 0x52, 0xA3, 0x01, 0x4A,
+0x23, 0xF5, 0x52, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x88, 0xA2,
+0x40, 0x6B, 0x8C, 0xEB, 0x0E, 0x23, 0xE3, 0xF4,
+0x89, 0xA2, 0x10, 0x6B, 0x8C, 0xEB, 0xFF, 0x6C,
+0x8C, 0xEB, 0x07, 0x23, 0xC0, 0xF0, 0x46, 0xA2,
+0x01, 0x72, 0x03, 0x60, 0x91, 0x67, 0x00, 0x18,
+0xB5, 0x3F, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xE3, 0xF4, 0x68, 0xA0, 0x02, 0x6A,
+0x6C, 0xEA, 0x10, 0x22, 0x03, 0x6A, 0x4B, 0xEA,
+0x4C, 0xEB, 0xE3, 0xF4, 0x68, 0xC0, 0xE3, 0xF4,
+0x6C, 0xA0, 0x6C, 0xEA, 0xE3, 0xF4, 0x4C, 0xC0,
+0xE3, 0xF4, 0x4C, 0xA0, 0x07, 0x6B, 0x6C, 0xEA,
+0x70, 0x2A, 0x6C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x90, 0x9A, 0xFF, 0xF7, 0x1F, 0x6A,
+0x60, 0xAC, 0x4C, 0xEB, 0x01, 0x4B, 0x4C, 0xEB,
+0x60, 0xCC, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x94, 0x9B, 0x60, 0xAC, 0x4C, 0xEB, 0x01, 0x4B,
+0x4C, 0xEB, 0x60, 0xCC, 0x43, 0xF5, 0x58, 0x98,
+0xE3, 0xF4, 0x6C, 0xA0, 0x01, 0x4A, 0x43, 0xF5,
+0x58, 0xD8, 0xE3, 0xF4, 0x53, 0xA0, 0x01, 0x4A,
+0xE3, 0xF4, 0x53, 0xC0, 0x11, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xE3, 0xF4, 0x4C, 0xC0, 0xE3, 0xF4,
+0x73, 0xA0, 0xA0, 0xF0, 0x5D, 0xA0, 0x63, 0xEA,
+0x41, 0x60, 0xC0, 0xF0, 0x9A, 0xA0, 0x00, 0x18,
+0xAA, 0x13, 0x01, 0x72, 0x3E, 0x61, 0xC0, 0xF0,
+0x72, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x02, 0x2A, 0x00, 0x18, 0x45, 0x15,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x97, 0xA2, 0x10, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xFF, 0x6C, 0x8C, 0xEB, 0x07, 0x2B,
+0xE3, 0xF4, 0x88, 0xA2, 0xDF, 0x4B, 0x8C, 0xEB,
+0xE3, 0xF4, 0x68, 0xC2, 0x22, 0x10, 0xE3, 0xF4,
+0x74, 0xA2, 0x01, 0x4B, 0xE3, 0xF4, 0x74, 0xC2,
+0xE3, 0xF4, 0x74, 0xA2, 0x03, 0x5B, 0x0B, 0x61,
+0xE3, 0xF4, 0x88, 0xA2, 0x21, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xE3, 0xF4, 0x68, 0xC2, 0x00, 0x6B,
+0xE3, 0xF4, 0x74, 0xC2, 0x03, 0x10, 0x91, 0x67,
+0x00, 0x18, 0x55, 0x1A, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B, 0xE3, 0xF4,
+0x73, 0xC2, 0x03, 0x10, 0x91, 0x67, 0x00, 0x18,
+0x68, 0x19, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x8C, 0xEA, 0xE0, 0xF2, 0x9C, 0x9B,
+0xE0, 0xF2, 0x1C, 0x4B, 0x04, 0xD4, 0x81, 0x9B,
+0x64, 0xAB, 0x05, 0xD4, 0x9D, 0x67, 0x6C, 0xCC,
+0x44, 0x33, 0x6D, 0xE4, 0x88, 0xAB, 0x1F, 0xF7,
+0x00, 0x6B, 0x8C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x01, 0x60, 0x0B, 0x2B, 0x9D, 0x67, 0x44, 0x33,
+0x6D, 0xE4, 0x88, 0xAB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x78, 0x9B, 0x6D, 0xE4, 0x60, 0xAB,
+0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x7C, 0x9B, 0x71, 0xE4, 0x60, 0xAC, 0xFF, 0xF7,
+0x1F, 0x68, 0x6C, 0xE8, 0x18, 0xF0, 0x00, 0x6B,
+0x0C, 0xEB, 0x13, 0x2B, 0x30, 0xF0, 0x20, 0x6C,
+0x86, 0xF2, 0x00, 0x4C, 0xE3, 0xF4, 0xAC, 0xA4,
+0xFE, 0x4B, 0xAC, 0xEB, 0x05, 0x6D, 0xAB, 0xED,
+0xAC, 0xEB, 0x02, 0x4D, 0xAC, 0xEB, 0xE3, 0xF4,
+0x6C, 0xC4, 0x82, 0x67, 0x00, 0x18, 0x68, 0x19,
+0x77, 0x10, 0x08, 0xF0, 0x00, 0x6B, 0x0C, 0xEB,
+0x40, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA0, 0xF0, 0xD6, 0xA3, 0x7F, 0x6C,
+0xFF, 0x6D, 0xCC, 0xEC, 0x01, 0x74, 0x12, 0x61,
+0xE3, 0xF4, 0xCC, 0xA3, 0x01, 0x6C, 0xCD, 0xEC,
+0xE3, 0xF4, 0x8C, 0xC3, 0xA0, 0xF0, 0x97, 0xA3,
+0x10, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xAC, 0xEB,
+0x20, 0x73, 0x11, 0x61, 0x82, 0x67, 0x00, 0x18,
+0x55, 0x1A, 0x31, 0x10, 0x02, 0x74, 0x2F, 0x61,
+0xA0, 0xF0, 0x59, 0xA3, 0x01, 0x6C, 0x8C, 0xEA,
+0xAC, 0xEA, 0x08, 0x2A, 0xE3, 0xF4, 0x4C, 0xA3,
+0x4D, 0xEC, 0xE3, 0xF4, 0x8C, 0xC3, 0x00, 0x18,
+0x37, 0x1D, 0x21, 0x10, 0xA0, 0xF0, 0x97, 0xA3,
+0x10, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0xAC, 0xEA,
+0x10, 0x72, 0x19, 0x61, 0xE3, 0xF4, 0x8C, 0xA3,
+0x04, 0x6A, 0x00, 0x6D, 0x8D, 0xEA, 0xE3, 0xF4,
+0x4C, 0xC3, 0x01, 0x6C, 0x00, 0x18, 0x11, 0x1D,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xE3, 0xF4, 0x8C, 0xA3, 0x02, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0x05, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEA, 0xE3, 0xF4, 0x4C, 0xC3, 0x02, 0x30,
+0x1E, 0x30, 0x17, 0x20, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xE3, 0xF4, 0x4C, 0xA0,
+0x02, 0x69, 0xA0, 0xF0, 0xDE, 0xA0, 0x2D, 0xEA,
+0xFF, 0x6C, 0xE3, 0xF4, 0x4C, 0xC0, 0x55, 0x4C,
+0x00, 0x6D, 0x00, 0x18, 0x04, 0x31, 0xE3, 0xF4,
+0x48, 0xA0, 0x4D, 0xE9, 0xE3, 0xF4, 0x28, 0xC0,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xE3, 0xF4, 0x8C, 0xA2, 0x03, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xE3, 0xF4, 0x6C, 0xC2,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF2, 0x70, 0x9A, 0xE0, 0xF2, 0x10, 0x4A,
+0x30, 0xF0, 0x20, 0x68, 0x04, 0xD3, 0x61, 0x9A,
+0xFF, 0x69, 0x44, 0xAA, 0x86, 0xF2, 0x00, 0x48,
+0x8C, 0xE9, 0xC0, 0xF0, 0x9A, 0xA0, 0x05, 0xD3,
+0x7D, 0x67, 0x4C, 0xCB, 0x00, 0x18, 0xAA, 0x13,
+0x01, 0x72, 0x00, 0xF1, 0x18, 0x61, 0xA0, 0xF0,
+0x76, 0xA0, 0x7F, 0x6A, 0xFF, 0x6D, 0x6C, 0xEA,
+0xAC, 0xEA, 0x00, 0xF1, 0x10, 0x22, 0xA0, 0xF0,
+0x77, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA, 0x01, 0x72,
+0x3C, 0x61, 0x7D, 0x67, 0x24, 0x32, 0x49, 0xE3,
+0x68, 0xAA, 0x1F, 0xF7, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x0B, 0x2A,
+0x24, 0x32, 0xBD, 0x67, 0x49, 0xE5, 0x68, 0xAA,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0x49, 0xE3, 0x60, 0x9A, 0x06, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A, 0x4D, 0xE3,
+0x60, 0x9B, 0x04, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF6,
+0x62, 0x34, 0x86, 0xF2, 0x00, 0x4A, 0x62, 0x33,
+0xE3, 0xF4, 0x91, 0xC2, 0x62, 0x33, 0xFF, 0x6C,
+0x8C, 0xEB, 0x02, 0x23, 0xE3, 0xF4, 0x70, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE3, 0xF4, 0x71, 0xA2, 0x02, 0x2B, 0xE3, 0xF4,
+0x70, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7,
+0x71, 0xC2, 0x91, 0x67, 0x00, 0x18, 0x6F, 0x15,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x00, 0x6B, 0xE3, 0xF4, 0x73, 0xC2, 0xE3, 0xF4,
+0x74, 0xC2, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0,
+0xA0, 0x9B, 0xFF, 0xF7, 0x1F, 0x6B, 0x80, 0xAD,
+0x6C, 0xEC, 0x01, 0x4C, 0x6C, 0xEC, 0x80, 0xCD,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF0, 0xA4, 0x9C,
+0x80, 0xAD, 0x6C, 0xEC, 0x01, 0x4C, 0x6C, 0xEC,
+0x80, 0xCD, 0x43, 0xF5, 0x74, 0x9A, 0x40, 0xF1,
+0x82, 0xA2, 0x01, 0x4B, 0x43, 0xF5, 0x74, 0xDA,
+0x01, 0x6B, 0x8C, 0xEB, 0x05, 0x23, 0x23, 0xF5,
+0x72, 0xA2, 0x01, 0x4B, 0x23, 0xF5, 0x72, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x30, 0xF0, 0x20, 0x6B, 0xE3, 0xF4, 0x9A, 0xA2,
+0x01, 0xF0, 0x64, 0x9B, 0x80, 0xC3, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF0, 0x68, 0x9B, 0x00, 0x6C,
+0x80, 0xC3, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x74, 0x9B, 0x02, 0x6C, 0x80, 0xC3, 0xE3, 0xF4,
+0x8C, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x11, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB, 0xA0, 0xF0,
+0x95, 0xA2, 0xE3, 0xF4, 0x6C, 0xC2, 0x01, 0x6B,
+0x6C, 0xEC, 0x06, 0x2C, 0xA3, 0xF3, 0x48, 0xA2,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x04, 0x22,
+0x91, 0x67, 0x00, 0x18, 0xF9, 0x04, 0x03, 0x10,
+0x91, 0x67, 0x00, 0x18, 0xC9, 0x1A, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xE3, 0xF4,
+0x68, 0xA0, 0x40, 0x6A, 0x6C, 0xEA, 0x56, 0x22,
+0xE3, 0xF4, 0x89, 0xA0, 0x10, 0x6B, 0xFF, 0x6D,
+0x44, 0x67, 0x6C, 0xEA, 0xAC, 0xEA, 0x23, 0x2A,
+0xE3, 0xF4, 0x51, 0xA0, 0xE3, 0xF4, 0xB0, 0xA0,
+0xAE, 0xEA, 0x48, 0x2A, 0x8D, 0xEB, 0x91, 0x67,
+0xE3, 0xF4, 0x69, 0xC0, 0x00, 0x18, 0x0A, 0x41,
+0x91, 0x67, 0x00, 0x18, 0x8C, 0x3F, 0xC0, 0xF0,
+0x46, 0xA0, 0x01, 0x72, 0x06, 0x60, 0x91, 0x67,
+0x00, 0x18, 0xBC, 0x3F, 0x91, 0x67, 0x00, 0x18,
+0xB5, 0x3F, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xE3, 0xF4, 0x71, 0xA2, 0xFF, 0x4B,
+0xE3, 0xF4, 0x71, 0xC2, 0x2B, 0x10, 0xA0, 0xF0,
+0x77, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA, 0x01, 0x72,
+0x25, 0x61, 0xE3, 0xF4, 0x51, 0xA0, 0x08, 0xD2,
+0x08, 0x93, 0xE3, 0xF4, 0x50, 0xA0, 0x6E, 0xEA,
+0x1D, 0x22, 0x91, 0x67, 0x00, 0x18, 0xFF, 0x40,
+0x08, 0x95, 0xAE, 0xEA, 0x17, 0x22, 0xE3, 0xF4,
+0x68, 0xA0, 0x20, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x10, 0x22, 0xE3, 0xF4, 0x69, 0xA0,
+0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x91, 0x67,
+0xE3, 0xF4, 0x49, 0xC0, 0x00, 0x18, 0xAB, 0x3F,
+0x91, 0x67, 0x00, 0x18, 0x9D, 0x3F, 0x91, 0x67,
+0x00, 0x18, 0x96, 0x3F, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x88, 0xA2,
+0x01, 0x6B, 0xE3, 0xF4, 0x77, 0xC2, 0x20, 0x6B,
+0x8D, 0xEB, 0xE3, 0xF4, 0x68, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x95, 0xA2, 0x02, 0x6B, 0x6C, 0xEC, 0x06, 0x24,
+0xA3, 0xF3, 0x48, 0xA2, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x0A, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x88, 0xA2,
+0x20, 0x6B, 0x8D, 0xEB, 0xE3, 0xF4, 0x68, 0xC2,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0xAC, 0xEA, 0x49, 0x22,
+0x05, 0x5C, 0x3D, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0xA0, 0xF2, 0x08, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0xAC, 0x9A, 0x01, 0x6C, 0x00, 0x18,
+0x22, 0x09, 0x00, 0x6C, 0x08, 0x6D, 0x29, 0x10,
+0x04, 0x6C, 0x0F, 0x6D, 0x00, 0x18, 0x22, 0x09,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0xA0, 0xF7,
+0xA8, 0x9A, 0x1F, 0x10, 0x04, 0x6C, 0xF0, 0x6D,
+0x00, 0x18, 0x22, 0x09, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0x21, 0xF0, 0xA4, 0x9A, 0x15, 0x10,
+0x04, 0x6C, 0x01, 0xF7, 0x00, 0x6D, 0x00, 0x18,
+0x22, 0x09, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C,
+0x21, 0xF0, 0xA8, 0x9A, 0x0A, 0x10, 0x04, 0x6C,
+0x1E, 0xF0, 0x00, 0x6D, 0x00, 0x18, 0x22, 0x09,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0xAC, 0x9A,
+0x04, 0x6C, 0x00, 0x18, 0x22, 0x09, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x68, 0x9A, 0xFF, 0x6C,
+0x07, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0x45, 0x10, 0x05, 0x5C, 0x3D, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x88, 0x34, 0xA0, 0xF2, 0x1C, 0x4A,
+0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0xAC, 0x9A, 0x01, 0x6C,
+0x00, 0x18, 0x53, 0x09, 0x00, 0x6C, 0x08, 0x6D,
+0x29, 0x10, 0x04, 0x6C, 0x0F, 0x6D, 0x00, 0x18,
+0x53, 0x09, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C,
+0xA0, 0xF7, 0xA8, 0x9A, 0x1F, 0x10, 0x04, 0x6C,
+0xF0, 0x6D, 0x00, 0x18, 0x53, 0x09, 0x30, 0xF0,
+0x20, 0x6A, 0x04, 0x6C, 0x21, 0xF0, 0xA4, 0x9A,
+0x15, 0x10, 0x04, 0x6C, 0x01, 0xF7, 0x00, 0x6D,
+0x00, 0x18, 0x53, 0x09, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0x21, 0xF0, 0xA8, 0x9A, 0x0A, 0x10,
+0x04, 0x6C, 0x1E, 0xF0, 0x00, 0x6D, 0x00, 0x18,
+0x53, 0x09, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0xAC, 0x9A, 0x04, 0x6C, 0x00, 0x18, 0x53, 0x09,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x68, 0x9A,
+0xF8, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x68, 0x24, 0x67, 0x0C, 0xE9, 0x91, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0xD5, 0x1B, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4,
+0x9A, 0xAA, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0,
+0x64, 0x9B, 0x0C, 0xEC, 0x80, 0xC3, 0xA0, 0xF0,
+0xBC, 0xA2, 0x80, 0x6B, 0x6B, 0xEB, 0x1F, 0x6C,
+0xAC, 0xEB, 0xAC, 0xEC, 0x0C, 0xEB, 0x0C, 0xEC,
+0x10, 0x23, 0x8F, 0x33, 0x0C, 0xEB, 0x43, 0xF5,
+0x7C, 0xC2, 0x01, 0x4B, 0x43, 0xF5, 0x7D, 0xC2,
+0xA0, 0xF0, 0x59, 0xA2, 0x07, 0x6B, 0x8C, 0xEB,
+0x56, 0x32, 0x4C, 0x32, 0x4D, 0xEB, 0x0C, 0xEB,
+0x06, 0x10, 0x02, 0x6C, 0x43, 0xF5, 0x9C, 0xC2,
+0x03, 0x6C, 0x43, 0xF5, 0x9D, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x4C, 0x9A, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x60, 0xC2,
+0xC0, 0xF0, 0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13,
+0x01, 0x72, 0x12, 0x61, 0xE3, 0xF4, 0x68, 0xA0,
+0x21, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xE3, 0xF4,
+0x48, 0xC0, 0xE3, 0xF4, 0x4B, 0xA0, 0x04, 0x6B,
+0x6C, 0xEA, 0x0C, 0x2A, 0x83, 0x67, 0x01, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xD9, 0x17, 0x06, 0x10,
+0xE3, 0xF4, 0x68, 0xA0, 0x20, 0x6A, 0x6D, 0xEA,
+0xE3, 0xF4, 0x48, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x40, 0xF1, 0x82, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x03, 0x23, 0x00, 0x6B,
+0x23, 0xF5, 0x72, 0xC2, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x2C, 0xEC, 0xAC, 0xE9, 0x80, 0xF0,
+0x05, 0x2C, 0x91, 0x67, 0x00, 0x6D, 0x00, 0x18,
+0xD5, 0x1B, 0x05, 0x59, 0x24, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x28, 0x33, 0xC0, 0xF2, 0x10, 0x4A,
+0x69, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x01, 0x6C,
+0x0C, 0x6D, 0x17, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x02, 0x6C, 0x21, 0xF0, 0xBC, 0x9A, 0x11, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x02, 0x6C, 0x41, 0xF0,
+0xA0, 0x9A, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x02, 0x6C, 0x41, 0xF0, 0xA4, 0x9A, 0x05, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xA8, 0x9A,
+0x02, 0x6C, 0x00, 0x18, 0xA3, 0x09, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0x48, 0x9A, 0x00, 0x6B,
+0x30, 0xF0, 0x20, 0x68, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x54, 0x9A, 0x02, 0x6B,
+0x86, 0xF2, 0x00, 0x48, 0x60, 0xDA, 0xC0, 0xF0,
+0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13, 0x19, 0x2A,
+0xE3, 0xF4, 0x4B, 0xA0, 0x04, 0x6B, 0x6C, 0xEA,
+0x02, 0x2A, 0x00, 0x18, 0x99, 0x41, 0x91, 0x67,
+0x00, 0x18, 0xAA, 0x17, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xE3, 0xF4, 0x89, 0xA3,
+0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0x03, 0x6C,
+0x8B, 0xEC, 0x8C, 0xEA, 0xE3, 0xF4, 0x49, 0xC3,
+0x05, 0x10, 0x0C, 0x6C, 0x01, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0xD9, 0x17, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x88, 0xA2,
+0x05, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xE3, 0xF4,
+0x68, 0xC2, 0xC0, 0xF0, 0x72, 0xA2, 0x01, 0x6A,
+0x6C, 0xEA, 0x0C, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x50, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x54, 0x9A,
+0x04, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x40, 0xF1, 0x82, 0xA2,
+0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0x40, 0xF1,
+0x62, 0xC2, 0x0D, 0x10, 0x01, 0x74, 0x06, 0x61,
+0x91, 0x67, 0x00, 0x18, 0x22, 0x1C, 0x00, 0x18,
+0x6F, 0x5C, 0x05, 0x10, 0x02, 0x74, 0x03, 0x61,
+0x91, 0x67, 0x00, 0x18, 0x7A, 0x19, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x86, 0xF2, 0x00, 0x48, 0x04, 0xD4, 0x00, 0x18,
+0xA9, 0x16, 0xA0, 0xF0, 0x96, 0xA0, 0x7F, 0x6A,
+0x04, 0x95, 0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18,
+0x5A, 0x1C, 0xA0, 0xF0, 0x56, 0xA0, 0x7F, 0x6B,
+0x6C, 0xEA, 0x2C, 0xEA, 0x09, 0x22, 0xA0, 0xF0,
+0x57, 0xA0, 0x0F, 0x6C, 0xA0, 0xF0, 0xB8, 0xA0,
+0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18, 0x7C, 0x14,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0, 0x70, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0x6D, 0xE5, 0x00, 0xA3,
+0x3F, 0x6F, 0x01, 0x74, 0x0C, 0xEF, 0x4C, 0xEE,
+0xE0, 0xC3, 0x10, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF0, 0xF4, 0x9C, 0x10, 0x68, 0xFD, 0xE5,
+0x80, 0xA7, 0x4C, 0xEC, 0x0D, 0xEC, 0x4C, 0xEC,
+0x80, 0xC7, 0x80, 0xA3, 0x80, 0x6F, 0xEB, 0xEF,
+0x4C, 0xEC, 0x0D, 0x10, 0x0F, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF0, 0xF4, 0x9C, 0xEF, 0x6C,
+0xFD, 0xE5, 0x00, 0xA7, 0x0C, 0xEC, 0x80, 0xC7,
+0x80, 0xA3, 0x40, 0x6F, 0x4C, 0xEC, 0xED, 0xEC,
+0x4C, 0xEC, 0x80, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x58, 0x9A, 0x80, 0xF4, 0xC0, 0x36,
+0x55, 0xE5, 0x40, 0x9D, 0x4D, 0xEE, 0xC0, 0xDD,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA, 0xFF, 0x6B,
+0xA2, 0x67, 0x42, 0x32, 0x6C, 0xED, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0, 0x7C, 0x9B,
+0x6D, 0xE4, 0xA0, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF0, 0x60, 0x9B, 0x71, 0xE4, 0x40, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0xF7, 0x1F, 0x68, 0x81, 0xF0, 0x64, 0x9B,
+0x0C, 0xED, 0x04, 0xD5, 0x60, 0xA3, 0xFF, 0x6A,
+0x24, 0x67, 0x4C, 0xE9, 0x21, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x60, 0x9B, 0x00, 0x6C,
+0xFF, 0x6D, 0x60, 0xA3, 0x36, 0x6E, 0x6C, 0xEA,
+0x05, 0xD2, 0x00, 0x18, 0x18, 0x3A, 0x00, 0x18,
+0x15, 0x41, 0x01, 0x72, 0x0B, 0x61, 0x00, 0x6E,
+0x91, 0x67, 0x01, 0x6D, 0xE6, 0x67, 0x00, 0x18,
+0x53, 0x56, 0x04, 0x95, 0x82, 0x67, 0x0C, 0xEC,
+0x00, 0x18, 0xDE, 0x1C, 0x05, 0x95, 0x00, 0x6C,
+0x37, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x0B, 0x10,
+0x00, 0x6E, 0x91, 0x67, 0x01, 0x6D, 0xE6, 0x67,
+0x00, 0x18, 0x53, 0x56, 0x04, 0x95, 0x82, 0x67,
+0x0C, 0xEC, 0x00, 0x18, 0xDE, 0x1C, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x40, 0x9A, 0x6F, 0x6D,
+0x90, 0x6C, 0x40, 0xA2, 0x38, 0x6E, 0x4C, 0xED,
+0x00, 0x18, 0x18, 0x3A, 0x00, 0x18, 0xA8, 0x56,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF0, 0x64, 0x9B, 0xFF, 0x6A, 0x04, 0x67,
+0x60, 0xA3, 0x25, 0x67, 0x4C, 0xE8, 0x4C, 0xEB,
+0x72, 0x33, 0x4C, 0xEB, 0x4C, 0xE9, 0x24, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x60, 0x9B,
+0x00, 0x6C, 0xFF, 0x6D, 0x60, 0xA3, 0x29, 0x6E,
+0x6C, 0xEA, 0x04, 0xD2, 0x00, 0x18, 0x18, 0x3A,
+0x00, 0x18, 0x15, 0x41, 0x01, 0x72, 0x0E, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x8B, 0xA2,
+0x01, 0x6D, 0x08, 0x6E, 0x00, 0x6F, 0x00, 0x18,
+0x53, 0x56, 0xA2, 0x67, 0x90, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0xBF, 0x1C, 0x04, 0x95, 0x00, 0x6C,
+0x2A, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x0E, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x8B, 0xA2,
+0x01, 0x6D, 0x08, 0x6E, 0x00, 0x6F, 0x00, 0x18,
+0x53, 0x56, 0xA2, 0x67, 0x90, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0xBF, 0x1C, 0x00, 0x18, 0xA8, 0x56,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x44, 0x9A,
+0xFF, 0x6B, 0x40, 0xA2, 0x6C, 0xEA, 0x52, 0x32,
+0x6C, 0xEA, 0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x26, 0xF3, 0x89, 0xA2, 0x00, 0x6D, 0x18, 0x6E,
+0xE5, 0x67, 0x00, 0x18, 0x53, 0x56, 0x00, 0x18,
+0xA8, 0x56, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x2C, 0xEC, 0x2C, 0xED, 0x02, 0x5C,
+0x04, 0xD4, 0x05, 0xD5, 0x41, 0x60, 0x00, 0x18,
+0xEC, 0x1F, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0,
+0x68, 0x9B, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x80, 0xAB, 0xFF, 0xF7, 0x1F, 0x6B,
+0x8C, 0xEB, 0x4B, 0xE3, 0xA0, 0xF0, 0x6A, 0xA0,
+0x2C, 0xEA, 0x6E, 0xEA, 0x2D, 0x2A, 0xE3, 0xF4,
+0x4B, 0xA0, 0x0E, 0x72, 0x12, 0x61, 0x04, 0x92,
+0x27, 0x2A, 0xE3, 0xF4, 0x69, 0xA0, 0x05, 0x94,
+0xFD, 0x4A, 0x6C, 0xEA, 0x00, 0x6D, 0xE3, 0xF4,
+0x49, 0xC0, 0x00, 0x18, 0x90, 0x55, 0x01, 0x6C,
+0x0C, 0x6D, 0x00, 0x18, 0x4A, 0x14, 0x91, 0x67,
+0x13, 0x10, 0x06, 0x72, 0x15, 0x61, 0x04, 0x92,
+0x13, 0x22, 0xE3, 0xF4, 0x69, 0xA0, 0x05, 0x94,
+0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x01, 0x6D,
+0xE3, 0xF4, 0x49, 0xC0, 0x00, 0x18, 0x90, 0x55,
+0x04, 0x6A, 0xE3, 0xF4, 0x4B, 0xC0, 0xFF, 0x6C,
+0x00, 0x6D, 0xC5, 0x67, 0x00, 0x18, 0x18, 0x3A,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x81, 0xF0, 0x64, 0x9B, 0x4C, 0xEE,
+0x4C, 0xEF, 0x05, 0xD6, 0x04, 0xD7, 0x60, 0xA3,
+0xFF, 0xF7, 0x1F, 0x68, 0x25, 0x67, 0x4C, 0xEB,
+0x72, 0x33, 0x4C, 0xEB, 0x8C, 0xE8, 0x4C, 0xE9,
+0x25, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x60, 0x9B, 0x00, 0x6C, 0xFF, 0x6D, 0x60, 0xA3,
+0x26, 0x6E, 0x6C, 0xEA, 0x06, 0xD2, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0x15, 0x41, 0x01, 0x72,
+0x0B, 0x61, 0x05, 0x96, 0x90, 0x67, 0x01, 0x6D,
+0x00, 0x6F, 0x00, 0x18, 0x53, 0x56, 0x04, 0x96,
+0x91, 0x67, 0xA2, 0x67, 0x00, 0x18, 0xBF, 0x1C,
+0x06, 0x95, 0x00, 0x6C, 0x27, 0x6E, 0x00, 0x18,
+0x18, 0x3A, 0x04, 0x95, 0x91, 0x67, 0x00, 0x18,
+0x44, 0x1D, 0x0F, 0x10, 0x04, 0x95, 0x91, 0x67,
+0x00, 0x18, 0x44, 0x1D, 0x05, 0x96, 0x90, 0x67,
+0x01, 0x6D, 0x00, 0x6F, 0x00, 0x18, 0x53, 0x56,
+0x04, 0x96, 0x91, 0x67, 0xA2, 0x67, 0x00, 0x18,
+0xBF, 0x1C, 0x00, 0x18, 0xA8, 0x56, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x00, 0x6B, 0x02, 0xF5, 0x73, 0xC2, 0x02, 0xF5,
+0x74, 0xC2, 0x02, 0xF5, 0x72, 0xC2, 0x00, 0x6B,
+0x02, 0xF5, 0x70, 0xCA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0, 0x74, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0xC0, 0xA3, 0x4C, 0xED,
+0x15, 0x26, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF0,
+0x84, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x60, 0xDA, 0x20, 0xE8, 0x80, 0xC3, 0x0B, 0x25,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF0, 0x88, 0x9B,
+0x80, 0x6D, 0xAB, 0xED, 0x60, 0xA4, 0x4C, 0xEB,
+0xAE, 0xEB, 0x4C, 0xEB, 0x60, 0xC4, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7, 0x60, 0x9B,
+0x30, 0xF0, 0x20, 0x69, 0x46, 0xF2, 0x5C, 0x99,
+0xE0, 0x9B, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF0,
+0x6C, 0x9B, 0x50, 0x32, 0x6D, 0xE2, 0xE0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF0, 0x70, 0x9B,
+0x6D, 0xE2, 0x80, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF0, 0x74, 0x9B, 0x6D, 0xE2, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF0, 0x78, 0x9B,
+0x69, 0xE2, 0xC0, 0xDA, 0x46, 0xF2, 0x1C, 0x99,
+0x01, 0x48, 0x00, 0xF1, 0x00, 0x70, 0x46, 0xF2,
+0x1C, 0xD9, 0x05, 0x60, 0x00, 0xF2, 0x00, 0x6A,
+0x4E, 0xE8, 0x06, 0x20, 0x0B, 0x10, 0x10, 0x6C,
+0x01, 0x6D, 0x00, 0x18, 0x9E, 0x1D, 0x06, 0x10,
+0x11, 0x6C, 0x01, 0x6D, 0x00, 0x18, 0x9E, 0x1D,
+0x46, 0xF2, 0x1C, 0xD9, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x3C, 0x9A,
+0xFF, 0x68, 0x40, 0xA1, 0x00, 0xF6, 0x40, 0x32,
+0x00, 0xF6, 0x43, 0x32, 0x00, 0x52, 0x43, 0x60,
+0x60, 0xA1, 0x7F, 0x6A, 0x6C, 0xEA, 0x40, 0xC1,
+0x40, 0xA1, 0x40, 0x6B, 0x0C, 0xEA, 0x6D, 0xEA,
+0x0C, 0xEA, 0x40, 0xC1, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x5C, 0x9A, 0xA0, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0x40, 0x9A, 0x0C, 0xED,
+0x05, 0x75, 0x80, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x48, 0x9A, 0x0C, 0xEC, 0x60, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x4C, 0x9A,
+0x0C, 0xEB, 0x40, 0xA2, 0x0C, 0xEA, 0x09, 0x61,
+0xBD, 0x67, 0x90, 0xC5, 0x71, 0xC5, 0x52, 0xC5,
+0x04, 0x04, 0x00, 0x18, 0x79, 0x22, 0x10, 0x2A,
+0x06, 0x10, 0x40, 0xA1, 0x3F, 0x6B, 0x0C, 0xEA,
+0x6D, 0xEA, 0x0C, 0xEA, 0x40, 0xC1, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x7C, 0x9A, 0xBF, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x07, 0x10,
+0x40, 0xA1, 0x40, 0x6B, 0x6B, 0xEB, 0x0C, 0xEA,
+0x6D, 0xEA, 0x0C, 0xEA, 0x40, 0xC1, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x0E, 0x90, 0x24, 0x67,
+0x4C, 0xE9, 0x03, 0x6B, 0x4C, 0xEF, 0x2C, 0xEB,
+0x00, 0x6A, 0x0B, 0xD5, 0x0C, 0xD6, 0x04, 0xD7,
+0x40, 0xC8, 0x00, 0x6A, 0x07, 0x23, 0x25, 0x10,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x40, 0xA8,
+0x01, 0x4A, 0x40, 0xC8, 0x1F, 0xF7, 0x00, 0x6A,
+0x2C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x5C, 0x9A, 0x49, 0xE1, 0x0B, 0x93,
+0x40, 0x9A, 0x6C, 0xEA, 0x0C, 0x93, 0x6E, 0xEA,
+0x04, 0x22, 0x40, 0xA8, 0x04, 0x93, 0x63, 0xEA,
+0xDF, 0x61, 0x40, 0xA8, 0x04, 0x93, 0x63, 0xEA,
+0x58, 0x67, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFF, 0x6A, 0xA0, 0x35,
+0x4C, 0xEC, 0xA0, 0x35, 0xCC, 0xEA, 0x4D, 0xED,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x44, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0x44, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF0, 0x88, 0x9B, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF0, 0x6C, 0x9B, 0xAD, 0xEA, 0x40, 0xDC,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x50, 0x9A, 0x60, 0xDC, 0x00, 0x6B, 0x60, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0xFF, 0xF7,
+0x1F, 0x6B, 0x8C, 0xEA, 0xAC, 0xEB, 0x05, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x4C, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x54, 0x9A, 0x60, 0x33, 0x60, 0x33, 0x4D, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x48, 0x9A,
+0x00, 0x6C, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0x58, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF0, 0x70, 0x9B, 0x40, 0xA2, 0x80, 0xC3,
+0xFF, 0x6B, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0, 0x7C, 0x9B,
+0xFF, 0x6A, 0xCC, 0xEA, 0x6D, 0xEA, 0xE0, 0xF1,
+0x1F, 0x6B, 0xAC, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0xC1, 0xF0, 0x88, 0x9C, 0x60, 0x33, 0x60, 0x33,
+0x6D, 0xEA, 0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x44, 0x9A, 0x6D, 0xEA, 0x40, 0xDC,
+0x20, 0xE8, 0x00, 0x65, 0xE0, 0xF1, 0x1F, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x64, 0x9B,
+0xAC, 0xEA, 0x40, 0x32, 0x40, 0x32, 0x6D, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0, 0x68, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x58, 0x9A, 0xFF, 0x6B, 0x40, 0xA2, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0, 0xC0, 0x9B,
+0xFF, 0x6A, 0x04, 0x6D, 0x60, 0xA6, 0x4C, 0xEC,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC6,
+0x11, 0x24, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0,
+0x84, 0x9B, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xC4,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B, 0x22, 0xF6,
+0x61, 0xC2, 0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x64, 0x9A, 0xFB, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x01, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0xA9, 0xF0, 0x61, 0xC2, 0x30, 0xF0,
+0x20, 0x6C, 0x69, 0xF7, 0x18, 0x4C, 0x00, 0x6D,
+0x00, 0x18, 0x91, 0x40, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x60, 0x9A, 0xFB, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x48, 0x9A, 0x40, 0xAA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x48, 0x9A,
+0x40, 0xAA, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0xF7, 0x10, 0x68, 0x19, 0x10,
+0x05, 0x6C, 0xFF, 0x48, 0x00, 0x18, 0x95, 0x20,
+0x14, 0x28, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0x60, 0x9A, 0x08, 0xF0, 0x00, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA, 0x00, 0x6A,
+0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x48, 0x9A, 0x60, 0xAA, 0x3F, 0x6A, 0x6C, 0xEA,
+0xDF, 0x2A, 0x01, 0x6A, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x01, 0x68, 0x04, 0xEC,
+0x82, 0xF3, 0x08, 0x69, 0x19, 0x10, 0x01, 0x6C,
+0xFF, 0x49, 0x00, 0x18, 0x95, 0x20, 0x14, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A,
+0x08, 0xF0, 0x00, 0x6C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x60, 0xDA, 0x00, 0x6A, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x48, 0x9A,
+0x60, 0xAA, 0xFF, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA,
+0x0C, 0xEA, 0xDD, 0x2A, 0x01, 0x6A, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x0E, 0x92, 0x04, 0x67, 0x0F, 0x91, 0x04, 0xD2,
+0x04, 0x93, 0xFF, 0x6A, 0x4C, 0xE8, 0x4C, 0xEB,
+0x90, 0x67, 0x0B, 0xD5, 0x0C, 0xD6, 0x0D, 0xD7,
+0x04, 0xD3, 0x4C, 0xE9, 0x00, 0x18, 0x9B, 0x1E,
+0x80, 0xF0, 0x07, 0x22, 0x06, 0x58, 0x80, 0xF0,
+0x04, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x08, 0x30,
+0x00, 0xF3, 0x14, 0x4A, 0x09, 0xE2, 0x40, 0x9A,
+0x00, 0xEA, 0x02, 0xF2, 0x10, 0x6A, 0x0E, 0x10,
+0x02, 0xF2, 0x00, 0x6A, 0x0B, 0x10, 0x22, 0xF2,
+0x00, 0x6A, 0x08, 0x10, 0x22, 0xF2, 0x10, 0x6A,
+0x05, 0x10, 0x42, 0xF2, 0x00, 0x6A, 0x02, 0x10,
+0x42, 0xF2, 0x10, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x0D, 0x94, 0xE1, 0xF0, 0x6C, 0x9B, 0x8C, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7, 0x84, 0x9C,
+0x8D, 0xEB, 0x06, 0x21, 0x30, 0xF0, 0x20, 0x6C,
+0xE1, 0xF0, 0x90, 0x9C, 0x6D, 0xEC, 0x05, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF0, 0x94, 0x9C,
+0x6C, 0xEC, 0x04, 0x96, 0x06, 0x26, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF7, 0x64, 0x9B, 0x8D, 0xEB,
+0x05, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0,
+0x78, 0x9B, 0x8C, 0xEB, 0x1F, 0xF7, 0x00, 0x6C,
+0x4C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0xB8, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0xBC, 0x9C, 0x30, 0xF0, 0x20, 0x6C,
+0x0B, 0x96, 0xE1, 0xF0, 0x9C, 0x9C, 0xB5, 0xE2,
+0xCC, 0xEC, 0x80, 0xDD, 0x84, 0x42, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF1, 0xA0, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF1, 0xA4, 0x9C, 0x30, 0xF0,
+0x20, 0x6C, 0x0C, 0x96, 0xE1, 0xF0, 0x9C, 0x9C,
+0xB5, 0xE2, 0xCC, 0xEC, 0x80, 0xDD, 0x87, 0x42,
+0x01, 0x4C, 0x1F, 0xF7, 0x00, 0x6D, 0xAC, 0xEC,
+0x02, 0xF0, 0x00, 0x74, 0x01, 0x60, 0x05, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF1, 0x88, 0x9C,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF1,
+0x8C, 0x9C, 0x89, 0xE2, 0x60, 0xDA, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x00, 0x6A, 0x04, 0xD2, 0x04, 0x92, 0x01, 0x72,
+0x58, 0x67, 0x04, 0xD2, 0x10, 0xF0, 0x20, 0x6A,
+0x78, 0x67, 0x0F, 0xF4, 0x19, 0x4A, 0x69, 0xE2,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x40, 0xDB, 0x00, 0x18, 0x15, 0x0E, 0x00, 0x18,
+0xD6, 0x1D, 0x00, 0x18, 0x14, 0x0E, 0x00, 0x18,
+0x15, 0x0E, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x84, 0x9A, 0x02, 0x6B,
+0x8C, 0xEB, 0x09, 0x23, 0x03, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18,
+0xF0, 0x2B, 0x00, 0x18, 0x42, 0x2C, 0x00, 0x18,
+0x14, 0x0E, 0x00, 0x18, 0x15, 0x0E, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x84, 0x9A, 0x04, 0x6B, 0x8C, 0xEB, 0x09, 0x23,
+0x05, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x00, 0x18, 0x98, 0x28, 0x00, 0x18,
+0x3F, 0x28, 0x00, 0x18, 0x14, 0x0E, 0x00, 0x18,
+0x15, 0x0E, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x96, 0xA2, 0x7F, 0x6B,
+0x8C, 0xEB, 0x0D, 0x23, 0xA0, 0xF0, 0x9A, 0xA2,
+0xE3, 0xF4, 0x6B, 0xA2, 0x8E, 0xEB, 0x07, 0x23,
+0xA0, 0xF0, 0x99, 0xA2, 0xFF, 0x6A, 0x96, 0x34,
+0x4C, 0xEC, 0x00, 0x18, 0x68, 0x19, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF3, 0x44, 0x9A, 0x02, 0x2A,
+0x00, 0x18, 0xF8, 0x16, 0x00, 0x18, 0x14, 0x0E,
+0x00, 0x18, 0x15, 0x0E, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x84, 0x9A,
+0x10, 0x6B, 0x8C, 0xEB, 0x07, 0x23, 0x11, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x00, 0x18, 0xCF, 0x74, 0x00, 0x18, 0x14, 0x0E,
+0x00, 0x18, 0x15, 0x0E, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x84, 0x9A,
+0x02, 0xF0, 0x00, 0x6B, 0x8C, 0xEB, 0x08, 0x23,
+0x02, 0xF0, 0x01, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18, 0x37, 0x3C,
+0x00, 0x18, 0x14, 0x0E, 0x00, 0x18, 0x15, 0x0E,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x84, 0x9A, 0xFF, 0x6B, 0x01, 0x4B,
+0x8C, 0xEB, 0x08, 0x23, 0xFF, 0x6B, 0x02, 0x4B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x00, 0x18, 0x98, 0x26, 0x00, 0x18, 0x14, 0x0E,
+0x00, 0x18, 0x15, 0x0E, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x84, 0x9A,
+0x00, 0xF4, 0x00, 0x6B, 0x8C, 0xEB, 0x08, 0x23,
+0x00, 0xF4, 0x01, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18, 0x25, 0x4A,
+0x00, 0x18, 0x14, 0x0E, 0x00, 0x18, 0x15, 0x0E,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x84, 0x9A, 0x01, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x08, 0x23, 0x01, 0xF0, 0x01, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x00, 0x18, 0xFA, 0x49, 0x00, 0x18, 0x14, 0x0E,
+0x00, 0x18, 0x15, 0x0E, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x60, 0x9B, 0xA0, 0xF0, 0x84, 0x9A,
+0x8C, 0xEB, 0x20, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF1, 0x78, 0x9B, 0x8C, 0xEB, 0xA0, 0xF0,
+0x96, 0xA2, 0xA0, 0xF0, 0x64, 0xDA, 0x7F, 0x6B,
+0x8C, 0xEB, 0x07, 0x2B, 0xE3, 0xF4, 0x4B, 0xA2,
+0x0C, 0x72, 0x03, 0x61, 0x00, 0x18, 0x51, 0x29,
+0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF0,
+0x64, 0x9A, 0xC0, 0xF7, 0x80, 0x9C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18, 0x14, 0x0E,
+0x30, 0xF0, 0x20, 0x6A, 0x2C, 0xF6, 0x78, 0xA2,
+0x08, 0x6A, 0x6C, 0xEA, 0x0F, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x5C, 0x9A, 0x01, 0x6B,
+0x80, 0xA2, 0x8C, 0xEB, 0x07, 0x23, 0x80, 0xA2,
+0xFE, 0x6B, 0x8C, 0xEB, 0x60, 0xC2, 0x03, 0x6C,
+0x00, 0x18, 0x6C, 0x2C, 0x30, 0xF0, 0x20, 0x69,
+0x86, 0xF2, 0x00, 0x49, 0x23, 0xF2, 0x08, 0xA1,
+0x01, 0x6A, 0x4E, 0xE8, 0x05, 0x28, 0x0B, 0x6C,
+0x00, 0x18, 0x6C, 0x2C, 0x23, 0xF2, 0x08, 0xC1,
+0x30, 0xF0, 0x21, 0x6A, 0x91, 0xF1, 0x8C, 0x9A,
+0x00, 0x18, 0x1F, 0x10, 0xD7, 0x16, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x68,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x6F, 0xF6, 0x19, 0x4A,
+0x0A, 0x70, 0x40, 0xDB, 0x09, 0x61, 0x30, 0xF0,
+0x21, 0x6A, 0x91, 0xF1, 0x8C, 0x9A, 0x01, 0x6D,
+0xAB, 0xED, 0x00, 0x18, 0xD6, 0x0E, 0x00, 0x68,
+0x00, 0x18, 0x15, 0x0E, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x84, 0x9A,
+0x00, 0xF2, 0x00, 0x6B, 0x8C, 0xEB, 0x08, 0x23,
+0x00, 0xF2, 0x01, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18, 0x08, 0x3A,
+0x00, 0x18, 0x14, 0x0E, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x01, 0x48, 0x60, 0xF7, 0x6C, 0x9B,
+0x4C, 0xE8, 0x10, 0xF0, 0x20, 0x6A, 0x6F, 0xF6,
+0x1A, 0x4A, 0x40, 0xDB, 0xC9, 0x17, 0x00, 0x65,
+0x00, 0x6A, 0x64, 0x67, 0x66, 0xEA, 0x01, 0x6D,
+0xAC, 0xEB, 0x04, 0x2B, 0x01, 0x4A, 0x20, 0x72,
+0xF8, 0x61, 0x20, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x25, 0x67, 0x49, 0xE4, 0x00, 0x9A, 0x85, 0x67,
+0x00, 0x18, 0xBC, 0x1F, 0x2C, 0xE8, 0x06, 0xEA,
+0x50, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x41, 0x45, 0x05, 0x67,
+0x0C, 0xD6, 0x13, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x3C, 0x9A, 0x0F, 0xE8, 0x25, 0xE4,
+0x40, 0x99, 0x85, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0xBC, 0x1F, 0x0C, 0x93, 0x64, 0xEA, 0x43, 0x67,
+0x04, 0x93, 0x6C, 0xE8, 0x0D, 0xEA, 0x40, 0xD9,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x3C, 0x9A, 0x0C, 0x92, 0x31, 0xE4, 0x40, 0xDC,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x41, 0x45, 0x0C, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0xAF, 0xEB, 0xCC, 0xED, 0x51, 0xE4, 0x40, 0x9C,
+0x6C, 0xEA, 0xAD, 0xEA, 0x40, 0xDC, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x51, 0xE4, 0xC0, 0xDC, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0x40, 0x9A,
+0xFF, 0x63, 0x60, 0xAA, 0xE1, 0xF7, 0x1F, 0x6A,
+0x6C, 0xEA, 0x7D, 0x67, 0x40, 0xCB, 0x40, 0xAB,
+0xFF, 0xF7, 0x1F, 0x6B, 0x01, 0x63, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x44, 0x9A, 0xFF, 0x63, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0x7D, 0x67, 0x40, 0xCB,
+0x40, 0xAB, 0xFF, 0xF7, 0x1F, 0x6B, 0x01, 0x63,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x48, 0x9A, 0x01, 0x6B, 0x40, 0x9A,
+0x42, 0x32, 0x52, 0x32, 0x6E, 0xEA, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF1, 0x6C, 0x9B, 0x44, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0x9B, 0xE1, 0xF0, 0x8C, 0x9C,
+0x8C, 0xEB, 0x43, 0xEB, 0x02, 0x60, 0x6F, 0xEB,
+0x69, 0xE2, 0x20, 0xE8, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xFF, 0xF7,
+0x1F, 0x6B, 0x4C, 0xED, 0x4C, 0xEE, 0x24, 0x67,
+0x6C, 0xEF, 0x10, 0x90, 0x6C, 0xE9, 0x05, 0xD5,
+0x06, 0xD6, 0x04, 0xD7, 0x00, 0x6A, 0x05, 0x10,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x40, 0xA8,
+0x01, 0x4A, 0x40, 0xC8, 0x1F, 0xF7, 0x00, 0x6A,
+0x2C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x5C, 0x9A, 0x49, 0xE1, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0x05, 0x93, 0x6C, 0xEA,
+0x06, 0x93, 0x6E, 0xEA, 0x04, 0x22, 0x40, 0xA8,
+0x04, 0x93, 0x63, 0xEA, 0xDD, 0x61, 0x40, 0xA8,
+0x04, 0x93, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x63, 0xEA, 0x58, 0x67, 0x06, 0x63, 0x00, 0xEF,
+0x03, 0x6F, 0x8C, 0xEF, 0x64, 0x67, 0x46, 0x67,
+0x04, 0x27, 0x0B, 0x10, 0xA0, 0xDB, 0xFC, 0x4A,
+0x04, 0x4B, 0x04, 0x5A, 0xFB, 0x60, 0x03, 0x6A,
+0x4C, 0xEE, 0x03, 0x10, 0xA0, 0xC4, 0xFF, 0x4E,
+0x01, 0x4C, 0xFC, 0x2E, 0x00, 0x6A, 0x20, 0xE8,
+0xFF, 0x6A, 0xAC, 0xEA, 0x03, 0x10, 0x40, 0xC4,
+0xFF, 0x4E, 0x01, 0x4C, 0xFC, 0x2E, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x03, 0x6B, 0x05, 0x67, 0x6C, 0xE8, 0x44, 0x67,
+0xE4, 0x67, 0x85, 0x67, 0x12, 0x28, 0x4C, 0xEB,
+0x10, 0x2B, 0x86, 0x67, 0x06, 0x10, 0x61, 0xE5,
+0x00, 0x98, 0x7D, 0xE2, 0xFC, 0x4C, 0x00, 0xDF,
+0x04, 0x4B, 0x04, 0x5C, 0xF8, 0x60, 0xCA, 0x34,
+0x88, 0x34, 0x03, 0x6B, 0x9D, 0xE2, 0x6C, 0xEE,
+0x91, 0xE5, 0x00, 0x6B, 0x06, 0x10, 0x61, 0xE4,
+0x00, 0xA0, 0x75, 0xE7, 0xFF, 0x4E, 0x00, 0xC5,
+0x01, 0x4B, 0xF9, 0x2E, 0x01, 0x90, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0x09, 0x10, 0x60, 0xA4,
+0x40, 0xA5, 0xFF, 0x4E, 0x4A, 0xEB, 0x02, 0x60,
+0x4B, 0xE3, 0x20, 0xE8, 0x01, 0x4C, 0x01, 0x4D,
+0xF6, 0x2E, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x06, 0x2C, 0x64, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0x60, 0xDA, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x80, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x40, 0x9A, 0x28, 0x72,
+0x2D, 0x60, 0x29, 0x5A, 0x07, 0x60, 0x14, 0x72,
+0x19, 0x60, 0x19, 0x72, 0x1F, 0x60, 0x0A, 0x72,
+0x0D, 0x60, 0x20, 0xE8, 0x50, 0x72, 0x32, 0x60,
+0x51, 0x5A, 0x03, 0x60, 0x32, 0x72, 0x26, 0x60,
+0x20, 0xE8, 0x64, 0x72, 0x33, 0x60, 0xC8, 0x72,
+0x39, 0x60, 0x20, 0xE8, 0x02, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0xE0, 0xF7,
+0x1E, 0x4B, 0x39, 0x10, 0x03, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0xE1, 0xF3,
+0x1D, 0x4B, 0x31, 0x10, 0x09, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0xE4, 0xF3,
+0x17, 0x4B, 0x29, 0x10, 0x05, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0xE2, 0xF3,
+0x1B, 0x4B, 0x21, 0x10, 0x11, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0xE8, 0xF3,
+0x0F, 0x4B, 0x19, 0x10, 0x0A, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0xE4, 0xF7,
+0x16, 0x4B, 0x11, 0x10, 0x22, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0x11, 0xF0,
+0x00, 0x6B, 0x09, 0x10, 0x43, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x64, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF1, 0x70, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x68, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2, 0x40, 0x9A,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0x48, 0x9A, 0xFF, 0x63, 0x58, 0xEC,
+0x12, 0xEA, 0x00, 0xD2, 0x00, 0x92, 0xFF, 0x4A,
+0x00, 0xD2, 0x00, 0x92, 0xFB, 0x2A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0x44, 0x9A, 0xFF, 0x63, 0x58, 0xEC,
+0x12, 0xEA, 0x00, 0xD2, 0x00, 0x92, 0xFF, 0x4A,
+0x00, 0xD2, 0x00, 0x92, 0xFB, 0x2A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0xD4, 0x9A, 0x00, 0x68, 0x20, 0xF0, 0x20, 0x6D,
+0x90, 0x67, 0x86, 0xF2, 0x00, 0x4D, 0xEA, 0xF6,
+0x10, 0x6F, 0x04, 0xD0, 0x05, 0xD0, 0x00, 0x18,
+0xB4, 0x1E, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0xD8, 0x9A, 0x20, 0xF0, 0x21, 0x6D, 0x90, 0x67,
+0x15, 0xF0, 0x00, 0x4D, 0x03, 0xF0, 0x00, 0x6F,
+0x04, 0xD0, 0x05, 0xD0, 0x00, 0x18, 0xB4, 0x1E,
+0x07, 0x97, 0x06, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x4D, 0x20,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xED,
+0x00, 0x18, 0x34, 0x20, 0x05, 0x97, 0x00, 0x6A,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x04, 0x67, 0x4C, 0xEE,
+0x00, 0x18, 0x39, 0x20, 0x50, 0x67, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x30, 0xF0, 0x20, 0x68, 0x8C, 0xEA,
+0xEC, 0xF7, 0x10, 0x48, 0x04, 0xD2, 0x26, 0x40,
+0x40, 0xA0, 0x04, 0x93, 0x6E, 0xEA, 0x0A, 0x2A,
+0x01, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0x4B, 0xEA,
+0x62, 0xF4, 0x1C, 0x4C, 0xA3, 0x67, 0x40, 0xC0,
+0x00, 0x18, 0x4D, 0x63, 0x01, 0x48, 0x2A, 0xE8,
+0xEF, 0x61, 0x30, 0xF0, 0x20, 0x68, 0x30, 0xF0,
+0x20, 0x69, 0x80, 0x6A, 0xEC, 0xF7, 0x16, 0x48,
+0xAF, 0xF7, 0x00, 0x49, 0x05, 0xD2, 0x40, 0xA0,
+0x04, 0x93, 0x6E, 0xEA, 0x03, 0x2A, 0x01, 0x6A,
+0x4B, 0xEA, 0x40, 0xC0, 0x5E, 0xA0, 0x04, 0x93,
+0x6E, 0xEA, 0x0F, 0x2A, 0x01, 0x6A, 0x4B, 0xEA,
+0x5E, 0xC0, 0x76, 0xA1, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x56, 0xC1, 0x05, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF4, 0x1C, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x05, 0x92, 0x01, 0x48, 0x2E, 0x49,
+0x01, 0x4A, 0x9E, 0x72, 0x05, 0xD2, 0xDF, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF4, 0x63, 0x17, 0x62,
+0x16, 0xD1, 0x15, 0xD0, 0x30, 0xF0, 0x20, 0x6D,
+0x24, 0x67, 0xA0, 0xF3, 0x0C, 0x4D, 0x04, 0x04,
+0x1E, 0x6E, 0x00, 0x18, 0x39, 0x20, 0x30, 0xF0,
+0x20, 0x6D, 0x0C, 0x04, 0x80, 0xF3, 0x0C, 0x4D,
+0x1E, 0x6E, 0x00, 0x18, 0x39, 0x20, 0x40, 0xA1,
+0x02, 0x72, 0x57, 0x60, 0x03, 0x72, 0x7A, 0x60,
+0x01, 0x72, 0x80, 0xF0, 0x0A, 0x61, 0x02, 0xA1,
+0x2E, 0x6C, 0xA1, 0xA1, 0x98, 0xE8, 0x05, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A,
+0x04, 0x06, 0x0C, 0x07, 0x12, 0xEC, 0x91, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x78, 0xED, 0x86, 0xF2,
+0x00, 0x4A, 0x49, 0xE5, 0x66, 0xF5, 0x10, 0xC2,
+0x12, 0xEB, 0x69, 0xE6, 0x79, 0xE7, 0x00, 0xF0,
+0x15, 0x07, 0x7D, 0xE7, 0xFF, 0x65, 0xE0, 0xA2,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x7D, 0xE7, 0x66, 0xF5, 0x15, 0xC7, 0xE0, 0xA6,
+0x01, 0x4A, 0x01, 0x4E, 0x6D, 0xE7, 0x86, 0xF5,
+0x13, 0xC3, 0x7F, 0x67, 0x6A, 0xEA, 0xEF, 0x61,
+0x76, 0xA4, 0x01, 0x6A, 0x4D, 0xEB, 0x76, 0xC4,
+0xC3, 0xA1, 0xCC, 0xEA, 0x44, 0x36, 0x03, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xCD, 0xEA, 0x56, 0xC4,
+0x30, 0xF0, 0x20, 0x6C, 0xD0, 0x67, 0xC2, 0xF5,
+0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x90, 0x67,
+0x00, 0x18, 0xC5, 0x75, 0x90, 0x67, 0x00, 0x18,
+0x14, 0x57, 0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF5,
+0x10, 0x4C, 0xB0, 0x67, 0xC2, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x90, 0x67, 0x00, 0x18, 0x96, 0x76,
+0x38, 0x10, 0x01, 0xA1, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE0, 0x66, 0xF5,
+0x30, 0xA2, 0x01, 0x6B, 0x6B, 0xEB, 0x66, 0xF5,
+0x70, 0xC2, 0x2E, 0x6B, 0x78, 0xE9, 0x30, 0xF0,
+0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A, 0x12, 0xEB,
+0x6D, 0xE2, 0x96, 0xA3, 0x02, 0x6A, 0x4B, 0xEA,
+0x8C, 0xEA, 0x56, 0xC3, 0x91, 0x67, 0x00, 0x18,
+0xC0, 0x20, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF6,
+0x00, 0x4C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x13, 0x10, 0xA1, 0xA1, 0xC2, 0xA1,
+0xE3, 0xA1, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6C, 0xA6, 0xF5,
+0xB2, 0xC2, 0xA6, 0xF5, 0xD3, 0xC2, 0xA6, 0xF5,
+0xF7, 0xC2, 0x22, 0xF6, 0x04, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x17, 0x97, 0x16, 0x91, 0x15, 0x90,
+0x0C, 0x63, 0x00, 0xEF, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0xAC, 0xEA, 0x2E, 0x5A,
+0x01, 0x60, 0x2E, 0x6A, 0x20, 0x5C, 0x26, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0x4C, 0xFF, 0x6D,
+0xA1, 0xF2, 0x60, 0x9B, 0xAC, 0xEC, 0x84, 0x36,
+0x6D, 0xE6, 0x40, 0xC3, 0x01, 0x6B, 0x8C, 0xEB,
+0x0D, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF2,
+0x68, 0x9B, 0x01, 0x4C, 0x84, 0x34, 0x71, 0xE4,
+0x80, 0x6B, 0x6B, 0xEB, 0x4D, 0xEB, 0xAC, 0xEB,
+0x60, 0xC4, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF2, 0x68, 0x9B, 0xFF, 0x4C, 0x84, 0x34,
+0x71, 0xE4, 0x80, 0x6B, 0x6B, 0xEB, 0x4D, 0xEB,
+0xAC, 0xEB, 0x60, 0xC4, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x44, 0x9A,
+0x60, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0x25, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF3, 0x8C, 0x9C, 0xC0, 0xA3, 0x86, 0xF2,
+0x00, 0x4A, 0x7D, 0xE2, 0x91, 0xE7, 0xC0, 0xC4,
+0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF3, 0x84, 0x9C,
+0x01, 0x4B, 0xFF, 0x6D, 0x8A, 0xEB, 0xEC, 0x61,
+0x60, 0xA4, 0x01, 0x6E, 0xAC, 0xEB, 0xCD, 0xEB,
+0xAC, 0xEB, 0x60, 0xC4, 0xA0, 0xF0, 0x64, 0x9A,
+0xFF, 0x6C, 0x01, 0x4C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x50, 0x9A, 0x01, 0x6B, 0x40, 0xA2, 0x4C, 0xEB,
+0x00, 0x6A, 0x42, 0x2B, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF3, 0x54, 0x9A, 0x30, 0x74, 0x80, 0xC2,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x58, 0x9A, 0x20, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF3, 0x58, 0x9A, 0xA0, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0x7C, 0x9A, 0x69, 0xE5,
+0x04, 0x10, 0x80, 0xA6, 0x01, 0x4E, 0x80, 0xC3,
+0x01, 0x4B, 0x4A, 0xEB, 0xFA, 0x61, 0x45, 0x67,
+0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x7C, 0x9B, 0x00, 0x6C, 0x6D, 0xE2, 0x80, 0xC3,
+0x01, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA, 0x06, 0x5A,
+0xF4, 0x61, 0x0A, 0x10, 0x60, 0xA6, 0x01, 0x4E,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x70, 0x9B, 0x01, 0x4A, 0x4E, 0xEB, 0xF6, 0x2B,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x70, 0x9A,
+0xFF, 0x6C, 0x01, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x45, 0x67,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0xB5, 0xA2,
+0x01, 0x6E, 0xFF, 0x6B, 0xCC, 0xED, 0x6C, 0xED,
+0x6C, 0xEC, 0x07, 0x25, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x40, 0x9A, 0x09, 0x6B, 0x60, 0xC2,
+0x20, 0xE8, 0xE0, 0xF0, 0x5C, 0xA2, 0xCC, 0xEA,
+0x6C, 0xEA, 0x0B, 0x22, 0x4F, 0x44, 0x6C, 0xEA,
+0x0D, 0x5A, 0x02, 0x6C, 0x06, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF5, 0x10, 0x4B, 0x69, 0xE2,
+0x80, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x40, 0x9A, 0x80, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x05, 0x74, 0x11, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF3, 0x6A, 0xA2, 0x40, 0x6A, 0xFF, 0x6C,
+0x6C, 0xEA, 0x12, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x78, 0x9A, 0x03, 0x6D, 0x40, 0xA3,
+0x8C, 0xEA, 0xAD, 0xEA, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF3, 0x6B, 0xA2, 0x10, 0x6A,
+0xFF, 0x6D, 0x6C, 0xEA, 0x14, 0x22, 0x09, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x78, 0x9A,
+0xFC, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x78, 0x9A, 0x03, 0x6C, 0x40, 0xA3, 0xAC, 0xEA,
+0x8D, 0xEA, 0xAC, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x03, 0x24, 0x01, 0x74,
+0x1A, 0x60, 0x22, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0x8B, 0xA2,
+0x01, 0x6B, 0xFF, 0x6D, 0x8C, 0xEB, 0x1F, 0x2B,
+0xE0, 0xF0, 0x87, 0xA2, 0x40, 0x6B, 0x8C, 0xEB,
+0xAC, 0xEB, 0x0D, 0x6C, 0x1B, 0x2B, 0xE0, 0xF0,
+0x6A, 0xA2, 0x04, 0x6A, 0x09, 0x6C, 0x6C, 0xEA,
+0xAC, 0xEA, 0x14, 0x2A, 0x12, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF3, 0x6B, 0xA2, 0x80, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B, 0x05, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF3, 0x6A, 0xA2,
+0x08, 0x6A, 0x6C, 0xEA, 0x02, 0x2A, 0x01, 0x6C,
+0x01, 0x10, 0x03, 0x6C, 0x00, 0x18, 0x95, 0x21,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF6, 0x8C, 0xA2, 0x11, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x83, 0xF6, 0x99, 0xA2, 0x83, 0xF6,
+0x6C, 0xC2, 0x10, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x83, 0xF6, 0x79, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xC0, 0xA4, 0xE0, 0xF0, 0xEE, 0xA3, 0x02, 0x6A,
+0x01, 0x6D, 0x4B, 0xEA, 0xAC, 0xEE, 0xEC, 0xEA,
+0xCD, 0xEA, 0xE0, 0xF0, 0x4E, 0xC3, 0x80, 0xA4,
+0x86, 0x34, 0xAC, 0xEC, 0x84, 0x35, 0x03, 0x6C,
+0x8B, 0xEC, 0x4C, 0xEC, 0xAD, 0xEC, 0xE0, 0xF0,
+0x8E, 0xC3, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD1,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xA4,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF6, 0x8D, 0xA2,
+0x01, 0x6F, 0x09, 0x6D, 0xEC, 0xEB, 0xAB, 0xED,
+0x6C, 0x33, 0x8C, 0xED, 0x6D, 0xED, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF7, 0x64, 0x9B, 0x83, 0xF6,
+0xAD, 0xC2, 0xFE, 0x6E, 0x80, 0xA3, 0xCC, 0xEC,
+0x80, 0xC3, 0x08, 0x6C, 0x1C, 0x65, 0x18, 0x67,
+0x0C, 0xED, 0xFF, 0x6C, 0x28, 0x25, 0x30, 0xF0,
+0x20, 0x6D, 0xC1, 0xF3, 0x04, 0x9D, 0x08, 0x69,
+0x2B, 0xE9, 0xA0, 0xA0, 0x8C, 0xED, 0x2C, 0xED,
+0x05, 0x69, 0x2D, 0xED, 0x8C, 0xED, 0xA0, 0xC0,
+0x30, 0xF0, 0x20, 0x6D, 0xC1, 0xF3, 0xA8, 0x9D,
+0x00, 0xA5, 0x0F, 0x6D, 0x0C, 0xED, 0x04, 0x68,
+0x0E, 0xED, 0x0B, 0x2D, 0x83, 0xF6, 0xAC, 0xA2,
+0x18, 0x67, 0x0C, 0xED, 0x8C, 0xED, 0x0B, 0x2D,
+0xA3, 0xF6, 0x5A, 0xAA, 0xA6, 0xF5, 0x0D, 0x72,
+0x06, 0x60, 0x40, 0xA3, 0x8C, 0xEA, 0xED, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0x03, 0x10, 0x40, 0xA3,
+0x4C, 0xEE, 0xC0, 0xC3, 0x01, 0x91, 0x00, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0x40, 0xA4, 0x0C, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x6C, 0x9A,
+0xFF, 0x6C, 0x18, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x0A, 0xF1, 0x6C, 0xA2,
+0x08, 0x6A, 0x6C, 0xEA, 0x08, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x6C, 0x9A, 0xE7, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xA4, 0xE0, 0xF0, 0xD5, 0xA2, 0x02, 0x6B,
+0x01, 0x6C, 0x6B, 0xEB, 0x8C, 0xED, 0xCC, 0xEB,
+0xAD, 0xEB, 0xE0, 0xF0, 0x75, 0xC2, 0x8C, 0xEB,
+0x01, 0x23, 0x18, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x4C, 0x9A, 0x60, 0xC2, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xA4, 0xE0, 0xF0,
+0xDC, 0xA2, 0x02, 0x6B, 0x01, 0x6C, 0x6B, 0xEB,
+0x8C, 0xED, 0xCC, 0xEB, 0xAD, 0xEB, 0xE0, 0xF0,
+0x7C, 0xC2, 0x8C, 0xEB, 0xFF, 0x6A, 0x42, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF3, 0x90, 0x9B,
+0xE5, 0x6D, 0xAB, 0xED, 0x60, 0xA4, 0x4C, 0xEB,
+0xAC, 0xEB, 0xA4, 0x6D, 0xAD, 0xEB, 0x60, 0xDC,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF3, 0x74, 0x9B,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x58, 0x9A, 0x42, 0xF2,
+0x15, 0x6B, 0x01, 0x6C, 0x60, 0xCA, 0x00, 0x18,
+0x95, 0x21, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x78, 0x9A, 0x03, 0x6C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x7C, 0x9A, 0xFE, 0xF5, 0x1C, 0x4C, 0x40, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF3, 0x60, 0x9A, 0x81, 0xF1, 0x00, 0x4C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF3, 0x64, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xE1, 0xF3, 0x88, 0x9C, 0x40, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x60, 0xA4, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0xF1,
+0xA3, 0xA2, 0x07, 0x6C, 0x6C, 0xEC, 0x08, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0x8D, 0xEB, 0x00, 0xF1,
+0x63, 0xC2, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF3, 0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xE1, 0xF3, 0x94, 0x9C, 0x60, 0xAA, 0xEF, 0xF7,
+0x1F, 0x6A, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x4A, 0xF1, 0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF3, 0x70, 0x9A, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x01, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x02, 0x6A,
+0x51, 0xC3, 0x03, 0x6A, 0x52, 0xC3, 0x04, 0x6C,
+0x04, 0x6A, 0x04, 0x05, 0x53, 0xC3, 0x00, 0x18,
+0x9E, 0x05, 0x07, 0x97, 0x00, 0x6A, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF3,
+0x4C, 0x9A, 0xEF, 0xF7, 0x1F, 0x68, 0x02, 0x6B,
+0x40, 0xAA, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x4A, 0xF1, 0x40, 0xAA, 0x0E, 0xEA, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0xD2, 0x0A, 0x02, 0x6B,
+0x50, 0x67, 0x6C, 0xEA, 0x08, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x4A, 0xF1, 0x40, 0xAA, 0x6C, 0xEA,
+0x02, 0x2A, 0x00, 0x18, 0xD2, 0x0A, 0x30, 0xF0,
+0x20, 0x6A, 0x4A, 0xF1, 0x00, 0xCA, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x01, 0x6D,
+0x04, 0x67, 0xAB, 0xED, 0x41, 0xF4, 0x18, 0x6C,
+0x00, 0x18, 0x78, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x83, 0xF6, 0x54, 0xDB,
+0x30, 0xF0, 0x20, 0x6D, 0x80, 0xA0, 0xE1, 0xF3,
+0xB8, 0x9D, 0x05, 0x97, 0x04, 0x90, 0x4C, 0xED,
+0x00, 0xF6, 0x80, 0x34, 0xAD, 0xEC, 0x83, 0xF6,
+0x90, 0xDB, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6C, 0x66, 0xF3, 0x07, 0x4C, 0x00, 0x6D,
+0x07, 0x6E, 0x30, 0xF0, 0x20, 0x68, 0x00, 0x18,
+0x34, 0x20, 0x86, 0xF2, 0x00, 0x48, 0x0B, 0x6A,
+0xE0, 0xF0, 0x48, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF3, 0x5C, 0x9A, 0xE0, 0xF0, 0x8A, 0xA0,
+0x00, 0x6D, 0x60, 0xA2, 0xFF, 0x6A, 0x2C, 0x6E,
+0x6C, 0xEA, 0x4A, 0x32, 0x01, 0x6B, 0x6C, 0xEA,
+0x58, 0x33, 0x41, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x6D, 0xEA, 0x0A, 0xF1,
+0x0C, 0x4C, 0xE0, 0xF0, 0x4A, 0xC0, 0x00, 0x18,
+0x34, 0x20, 0x83, 0xF6, 0x6C, 0xA0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6C, 0x07, 0x6E, 0x6D, 0xEA,
+0x66, 0xF3, 0x1C, 0x4C, 0x00, 0x6D, 0x83, 0xF6,
+0x4C, 0xC0, 0x00, 0x18, 0x34, 0x20, 0x00, 0xF1,
+0x63, 0xA0, 0x08, 0x6A, 0x4B, 0xEA, 0x01, 0x6D,
+0x6C, 0xEA, 0xAB, 0xED, 0x41, 0xF4, 0x18, 0x6C,
+0x00, 0xF1, 0x43, 0xC0, 0x00, 0x18, 0x78, 0x36,
+0x83, 0xF6, 0x54, 0xD8, 0x1E, 0x6A, 0xA3, 0xF6,
+0x53, 0xC0, 0x01, 0x6C, 0x02, 0x6A, 0xA3, 0xF6,
+0x55, 0xC0, 0x00, 0x18, 0x95, 0x21, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6C, 0xA4, 0x67,
+0x12, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x01, 0x6C,
+0x00, 0x18, 0x95, 0x21, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xD4, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF6, 0xD9, 0xA2,
+0x83, 0xF6, 0x79, 0xA2, 0x0F, 0x6C, 0x8C, 0xEE,
+0x72, 0x35, 0xA2, 0xEE, 0x03, 0x61, 0x00, 0x18,
+0xDE, 0x21, 0x0A, 0x10, 0xA3, 0x67, 0x8C, 0xED,
+0x01, 0x4D, 0x8C, 0xED, 0x10, 0x6C, 0x8B, 0xEC,
+0x6C, 0xEC, 0xAD, 0xEC, 0x83, 0xF6, 0x99, 0xC2,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0xFF, 0x6E, 0x8C, 0xEE,
+0x00, 0x6A, 0x10, 0xF0, 0x21, 0x6C, 0xD2, 0xF4,
+0x09, 0x4C, 0xA2, 0x67, 0x01, 0x6F, 0x04, 0xD2,
+0x00, 0x18, 0x8A, 0x3B, 0x07, 0x97, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF6, 0x95, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x07, 0x2B, 0xA3, 0xF6,
+0xB6, 0xA2, 0x86, 0x34, 0x82, 0xED, 0x23, 0x61,
+0xA3, 0xF6, 0x76, 0xC2, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xE0, 0xF0, 0x47, 0xA0,
+0x01, 0x69, 0x2C, 0xEA, 0x18, 0x22, 0x83, 0xF6,
+0x4F, 0xA0, 0x15, 0x2A, 0x83, 0xF6, 0x6C, 0xA0,
+0x10, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x18, 0xDB, 0x22, 0x0B, 0x10,
+0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x18, 0xEC, 0x22,
+0x83, 0xF6, 0x4D, 0xA0, 0x83, 0xF6, 0x2F, 0xC0,
+0x4D, 0xE9, 0x83, 0xF6, 0x2D, 0xC0, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x83, 0xF6, 0x6D, 0xA0, 0x03, 0x6C, 0xFF, 0x69,
+0x66, 0x32, 0x8C, 0xEA, 0x01, 0x72, 0x01, 0x6A,
+0x39, 0x61, 0x83, 0xF6, 0x4E, 0xA0, 0x03, 0x5A,
+0x06, 0x60, 0x83, 0xF6, 0xAC, 0xA0, 0x04, 0x6C,
+0xAC, 0xEC, 0x2C, 0xEC, 0x0A, 0x24, 0x07, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x83, 0xF6, 0x4D, 0xC0,
+0x05, 0x6A, 0x83, 0xF6, 0x4F, 0xC0, 0x01, 0x6A,
+0x25, 0x10, 0x01, 0x4A, 0x03, 0x6C, 0x83, 0xF6,
+0x4E, 0xC0, 0x00, 0x18, 0xEC, 0x22, 0x00, 0xF1,
+0x43, 0xA0, 0xA0, 0xF0, 0x8A, 0xA0, 0x07, 0x6F,
+0x4C, 0xEF, 0x01, 0x6D, 0x08, 0x6E, 0x2C, 0xEF,
+0x00, 0x18, 0x6D, 0x1D, 0x83, 0xF6, 0x8C, 0xA0,
+0x01, 0x6B, 0x4C, 0xEB, 0x03, 0x6A, 0x4B, 0xEA,
+0x64, 0x33, 0x8C, 0xEA, 0x6D, 0xEA, 0x05, 0x6B,
+0x6B, 0xEB, 0x6C, 0xEA, 0x83, 0xF6, 0x4C, 0xC0,
+0xA3, 0xF6, 0x4B, 0xA0, 0x01, 0x4A, 0xA3, 0xF6,
+0x4B, 0xC0, 0x00, 0x6A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0x67, 0xA2,
+0x01, 0x6D, 0xFF, 0x6C, 0xAC, 0xEB, 0x2E, 0x23,
+0xE0, 0xF0, 0xC9, 0xA2, 0x08, 0x6B, 0xCC, 0xEB,
+0x8C, 0xEB, 0x28, 0x23, 0x83, 0xF6, 0x6D, 0xA2,
+0xAC, 0xEB, 0x8C, 0xEB, 0x05, 0x2B, 0xE0, 0xF0,
+0x4A, 0xA2, 0xAC, 0xEA, 0x8C, 0xEA, 0x14, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF6, 0x60, 0xAA, 0xFF, 0x6C, 0x01, 0x4C,
+0x8C, 0xEB, 0x14, 0x2B, 0x00, 0xF1, 0x43, 0xA2,
+0x07, 0x6C, 0x01, 0x6D, 0x4C, 0xEC, 0x00, 0x18,
+0x90, 0x55, 0x00, 0x18, 0x37, 0x1D, 0x0A, 0x10,
+0x10, 0xF0, 0x21, 0x6C, 0x01, 0x6E, 0xF1, 0xF4,
+0x09, 0x4C, 0x00, 0x6D, 0xE6, 0x67, 0x04, 0xD2,
+0x00, 0x18, 0x8A, 0x3B, 0x07, 0x97, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x25, 0x67,
+0x4C, 0xEC, 0x4C, 0xE9, 0x1E, 0x24, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x91, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0x90, 0x55, 0xA0, 0xF0,
+0x8A, 0xA0, 0x01, 0x6D, 0x08, 0x6E, 0xF1, 0x67,
+0x00, 0x18, 0x6D, 0x1D, 0x83, 0xF6, 0x8C, 0xA0,
+0x01, 0x6B, 0x4C, 0xEB, 0x03, 0x6A, 0x4B, 0xEA,
+0x64, 0x33, 0x8C, 0xEA, 0x6D, 0xEA, 0x05, 0x6B,
+0x6B, 0xEB, 0x6C, 0xEA, 0x83, 0xF6, 0x4C, 0xC0,
+0x18, 0x10, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xE0, 0xF0, 0x89, 0xA0, 0x08, 0x6B,
+0x8C, 0xEB, 0x4C, 0xEB, 0x0C, 0x2B, 0x91, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x90, 0x55, 0xA0, 0xF0,
+0x8A, 0xA0, 0x00, 0x6D, 0x08, 0x6E, 0xF1, 0x67,
+0x00, 0x18, 0x6D, 0x1D, 0x02, 0x10, 0x00, 0x18,
+0x3A, 0x23, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x05, 0x5A, 0x00, 0x6B,
+0x24, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32,
+0x80, 0xF5, 0x0C, 0x4B, 0x4D, 0xE3, 0x40, 0x9B,
+0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4,
+0x40, 0x9A, 0x13, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF4, 0x44, 0x9A, 0x0E, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF4, 0x48, 0x9A, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4, 0x4C, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4,
+0x50, 0x9A, 0x40, 0xAA, 0xFF, 0xF7, 0x1F, 0x6B,
+0x4C, 0xEB, 0x08, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x3A, 0x23, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x68, 0x0C, 0xEE,
+0x04, 0xD6, 0x0E, 0x96, 0xFF, 0xF7, 0x1F, 0x69,
+0xAC, 0xE9, 0x0C, 0xEF, 0x0C, 0xEC, 0xB1, 0x67,
+0x0C, 0xEE, 0x05, 0xD7, 0x00, 0x18, 0xBF, 0x1C,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4, 0x74, 0x9A,
+0x80, 0x6C, 0x8B, 0xEC, 0x6D, 0xE1, 0x40, 0xA3,
+0x0C, 0xEA, 0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3,
+0x80, 0xA3, 0xEF, 0x6A, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4, 0x78, 0x9A,
+0x02, 0x6C, 0x6D, 0xE1, 0x40, 0xA3, 0x0C, 0xEA,
+0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3, 0x80, 0xA3,
+0x03, 0x6A, 0x8C, 0xEA, 0x40, 0xC3, 0x7D, 0x67,
+0x87, 0x43, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x5C, 0x9A, 0x09, 0x4C, 0x60, 0xA4, 0x49, 0xE1,
+0x9D, 0x67, 0x60, 0xC2, 0x67, 0x44, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x40, 0x9A, 0x0D, 0x4B,
+0x80, 0xA3, 0x49, 0xE1, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF4, 0x5C, 0x9A, 0x45, 0xE1,
+0x40, 0xA1, 0x0C, 0xEA, 0x02, 0x4A, 0x0C, 0xEA,
+0x40, 0xC1, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x81, 0xF0, 0x64, 0x9B, 0x4C, 0xED,
+0x4C, 0xEE, 0x06, 0xD5, 0x07, 0xD6, 0x60, 0xA3,
+0x24, 0x67, 0x07, 0x67, 0x4C, 0xE9, 0x4C, 0xE8,
+0x28, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x60, 0x9B, 0x00, 0x6C, 0xFF, 0x6D, 0x60, 0xA3,
+0x01, 0x6E, 0x6C, 0xEA, 0x08, 0xD2, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0x15, 0x41, 0x01, 0x72,
+0x12, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3,
+0x8C, 0xA2, 0x01, 0x6D, 0xE5, 0x67, 0x08, 0x6E,
+0x00, 0x18, 0x53, 0x56, 0x06, 0x96, 0x07, 0x97,
+0xFF, 0xF7, 0x1F, 0x6D, 0x91, 0x67, 0x4C, 0xED,
+0x04, 0xD0, 0x00, 0x18, 0x95, 0x23, 0x08, 0x95,
+0x00, 0x6C, 0x02, 0x6E, 0x00, 0x18, 0x18, 0x3A,
+0x12, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3,
+0x8C, 0xA2, 0x01, 0x6D, 0xE5, 0x67, 0x08, 0x6E,
+0x00, 0x18, 0x53, 0x56, 0x06, 0x96, 0x07, 0x97,
+0xFF, 0xF7, 0x1F, 0x6D, 0x91, 0x67, 0x4C, 0xED,
+0x04, 0xD0, 0x00, 0x18, 0x95, 0x23, 0x00, 0x18,
+0xA8, 0x56, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x01, 0x74, 0xA0, 0xF0, 0x00, 0x60,
+0x06, 0x24, 0x02, 0x74, 0x23, 0x60, 0x04, 0x74,
+0xA0, 0xF0, 0x1B, 0x60, 0xB5, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0,
+0x87, 0xA2, 0x20, 0x6B, 0xFF, 0x6D, 0x8C, 0xEB,
+0xA0, 0xF0, 0x0A, 0x2B, 0x10, 0x6B, 0x8C, 0xEB,
+0xAC, 0xEB, 0xA0, 0xF0, 0x05, 0x23, 0x83, 0xF6,
+0x8C, 0xA2, 0x01, 0x6B, 0x8D, 0xEB, 0x83, 0xF6,
+0x6C, 0xC2, 0x00, 0xF1, 0x63, 0xA2, 0x07, 0x6A,
+0x00, 0x6C, 0x6C, 0xEA, 0x4C, 0xED, 0x00, 0x18,
+0x59, 0x23, 0x96, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0x87, 0xA2,
+0x20, 0x6B, 0x8C, 0xEB, 0x07, 0x2B, 0xE0, 0xF0,
+0x6B, 0xA2, 0x08, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x3D, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF6, 0x18, 0xA2,
+0xE0, 0xF0, 0x48, 0xA2, 0x43, 0xE0, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0x20, 0x58, 0x03, 0x61,
+0xEF, 0xF7, 0x1F, 0x68, 0x03, 0x10, 0x00, 0x30,
+0x08, 0x30, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0x8B, 0xA2,
+0x08, 0x6B, 0x8C, 0xEB, 0x05, 0x23, 0xA0, 0xF0,
+0x8D, 0xA2, 0xB0, 0x67, 0x00, 0x18, 0xE9, 0x1C,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xE0, 0xF0, 0xA7, 0xA3, 0x20, 0x6C, 0xFF, 0x6A,
+0x8C, 0xED, 0x11, 0x25, 0xE0, 0xF0, 0xAB, 0xA3,
+0xAC, 0xEC, 0x4C, 0xEC, 0x0C, 0x24, 0x00, 0xF1,
+0x63, 0xA3, 0x07, 0x6F, 0x02, 0x36, 0x6C, 0xEF,
+0xB0, 0x67, 0x00, 0x6C, 0x4C, 0xED, 0x4C, 0xEE,
+0x4C, 0xEF, 0x00, 0x18, 0xBF, 0x23, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xE0, 0xF0,
+0x87, 0xA0, 0x20, 0x6B, 0xFF, 0x6A, 0x8C, 0xEB,
+0x44, 0x2B, 0x10, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB,
+0x14, 0x23, 0x83, 0xF6, 0x8C, 0xA0, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x83, 0xF6, 0x6C, 0xC0,
+0x00, 0xF1, 0x63, 0xA0, 0x07, 0x6D, 0x01, 0x6C,
+0x6C, 0xED, 0x4C, 0xED, 0x00, 0x18, 0x59, 0x23,
+0xA3, 0xF6, 0x4A, 0xA0, 0x01, 0x4A, 0xA3, 0xF6,
+0x4A, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF3,
+0x6A, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0x25, 0x2A,
+0xFF, 0x6C, 0x6F, 0x6D, 0x06, 0x6E, 0x1F, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE0, 0xF0, 0xAA, 0xA2, 0x01, 0x6B, 0xFF, 0x6C,
+0xAC, 0xEB, 0x13, 0x2B, 0xE0, 0xF0, 0x67, 0xA2,
+0x20, 0x6A, 0x6C, 0xEA, 0x8C, 0xEA, 0x04, 0x22,
+0xFF, 0x6C, 0x6F, 0x6D, 0x0E, 0x6E, 0x0B, 0x10,
+0x10, 0x6A, 0x6C, 0xEA, 0x8C, 0xEA, 0x09, 0x22,
+0xFF, 0x6C, 0x6F, 0x6D, 0x0F, 0x6E, 0x03, 0x10,
+0xFF, 0x6C, 0x00, 0x6D, 0xC5, 0x67, 0x00, 0x18,
+0x18, 0x3A, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x24, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x66, 0xF3, 0x07, 0x4C, 0xB1, 0x67,
+0x05, 0x6E, 0x00, 0x18, 0xB9, 0x20, 0x40, 0xA1,
+0x01, 0x6B, 0x6C, 0xEA, 0x54, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x50, 0x9A, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x40, 0xA2,
+0x83, 0xF6, 0x6D, 0xA0, 0x04, 0x6C, 0x83, 0xF6,
+0x58, 0xC0, 0x41, 0xA1, 0x00, 0x69, 0x83, 0xF6,
+0x2E, 0xC0, 0xE0, 0xF0, 0x48, 0xC0, 0x07, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x83, 0xF6, 0x4D, 0xC0,
+0x00, 0x18, 0xE9, 0x23, 0xE0, 0xF0, 0x67, 0xA0,
+0x04, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x0C, 0x22, 0x01, 0x6A, 0x83, 0xF6, 0x5F, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0x40, 0x9A,
+0xA3, 0xF6, 0x28, 0xC0, 0x40, 0x9A, 0xA3, 0xF6,
+0x44, 0xD8, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xE0, 0xF0, 0x89, 0xA2, 0x04, 0x6B,
+0x8C, 0xEB, 0x11, 0x23, 0xA3, 0xF6, 0x94, 0xA2,
+0x01, 0x6B, 0xFF, 0x6D, 0x8C, 0xEB, 0x6C, 0xED,
+0x05, 0x2D, 0x64, 0x6C, 0x6D, 0xEC, 0xA3, 0xF6,
+0x94, 0xC2, 0x05, 0x10, 0x02, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xA3, 0xF6, 0x74, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x44, 0x9A, 0x05, 0x6B,
+0x60, 0xC2, 0x06, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x0A, 0xF1, 0x6F, 0xC2, 0x18, 0x10, 0x03, 0x6C,
+0x00, 0x18, 0xC2, 0x21, 0x03, 0x6C, 0x00, 0x18,
+0xE9, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF6, 0x8D, 0xA2, 0x07, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xE0, 0xF0, 0x8B, 0xA2,
+0x83, 0xF6, 0x6D, 0xC2, 0x41, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xE0, 0xF0, 0x6B, 0xC2, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x83, 0xF6,
+0x6C, 0xA0, 0x02, 0x6A, 0x4B, 0xEA, 0x4C, 0xEB,
+0x83, 0xF6, 0x6C, 0xC0, 0x83, 0xF6, 0x6D, 0xA0,
+0x01, 0x6C, 0x6C, 0xEA, 0x83, 0xF6, 0x4D, 0xC0,
+0x00, 0x18, 0xB9, 0x42, 0x05, 0x6C, 0x00, 0x18,
+0xAA, 0x21, 0xE0, 0xF0, 0x89, 0xA0, 0x08, 0x6A,
+0xFF, 0x6B, 0x8C, 0xEA, 0x07, 0x22, 0x00, 0xF1,
+0x43, 0xA0, 0x07, 0x6C, 0x01, 0x6D, 0x4C, 0xEC,
+0x6C, 0xEC, 0x0C, 0x10, 0xA0, 0xF0, 0x96, 0xA0,
+0x7F, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA, 0x08, 0x2A,
+0x00, 0xF1, 0x43, 0xA0, 0x07, 0x6C, 0x00, 0x6D,
+0x4C, 0xEC, 0x6C, 0xEC, 0x00, 0x18, 0xD5, 0x1B,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x00, 0xF1, 0x43, 0xA0, 0x07, 0x6C, 0x00, 0x6D,
+0x4C, 0xEC, 0x00, 0x18, 0x90, 0x55, 0xA3, 0xF6,
+0x55, 0xA0, 0x07, 0x97, 0x06, 0x91, 0x46, 0x32,
+0xA3, 0xF6, 0x56, 0xC0, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x4F, 0x24, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0x01, 0x6C, 0x00, 0x18, 0xE9, 0x23,
+0x01, 0x6C, 0x00, 0x18, 0xAA, 0x21, 0x01, 0x6C,
+0x00, 0x18, 0xC2, 0x21, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF3, 0x6A, 0xA2, 0x80, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0xB9, 0x42, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF3, 0x6B, 0xA2, 0x02, 0x6A,
+0x6C, 0xEA, 0x11, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x58, 0x9A, 0x02, 0xF0, 0x01, 0x6C,
+0x8B, 0xEC, 0x60, 0x9A, 0x8C, 0xEB, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9A, 0x01, 0xF1,
+0x98, 0x9C, 0x8C, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B,
+0x83, 0xF6, 0x6F, 0xC2, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF4, 0x84, 0x9B, 0xE0, 0xF0, 0x68, 0x9A,
+0x8C, 0xEB, 0x6E, 0xEC, 0x12, 0x2C, 0x83, 0xF6,
+0xAD, 0xA2, 0xA3, 0xF6, 0xD4, 0xA2, 0x10, 0x6B,
+0xAD, 0xEB, 0x83, 0xF6, 0x6D, 0xC2, 0x04, 0xD4,
+0x10, 0xF0, 0x21, 0x6C, 0x72, 0xF6, 0x01, 0x4C,
+0x00, 0x6D, 0xC6, 0x36, 0x01, 0x6F, 0x00, 0x18,
+0x8A, 0x3B, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x00, 0xF1, 0x43, 0xA0, 0x07, 0x6C,
+0x00, 0x6D, 0x4C, 0xEC, 0x00, 0x18, 0xDF, 0x13,
+0xA3, 0xF6, 0x4C, 0xD8, 0x07, 0x97, 0x06, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x03, 0x6C, 0x00, 0x18, 0xEC, 0x22, 0x02, 0x6C,
+0x00, 0x18, 0xE9, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0x8B, 0xA2,
+0x40, 0x6B, 0x8C, 0xEB, 0x16, 0x23, 0x83, 0xF6,
+0x8D, 0xA2, 0x07, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x02, 0x6C, 0x8D, 0xEB, 0x83, 0xF6, 0x6D, 0xC2,
+0x00, 0x6B, 0x83, 0xF6, 0x6E, 0xC2, 0x63, 0xF3,
+0x7B, 0xA2, 0x0A, 0x23, 0x83, 0xF6, 0x8C, 0xA2,
+0x04, 0x6B, 0x8D, 0xEB, 0x83, 0xF6, 0x6C, 0xC2,
+0x03, 0x10, 0x05, 0x6B, 0x83, 0xF6, 0x6F, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF6, 0x8D, 0xA2, 0x02, 0x6B, 0x05, 0x97,
+0x6B, 0xEB, 0x8C, 0xEB, 0x83, 0xF6, 0x6D, 0xC2,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x83, 0xF6, 0x6D, 0xA0, 0x01, 0x6A,
+0x82, 0x67, 0x6C, 0xEC, 0x4D, 0x2C, 0x6D, 0xEA,
+0x83, 0xF6, 0x4D, 0xC0, 0x00, 0x18, 0xAA, 0x21,
+0x00, 0x6C, 0x00, 0x18, 0xC2, 0x21, 0x00, 0x6C,
+0x00, 0x18, 0xE9, 0x23, 0xE0, 0xF0, 0x6A, 0xA0,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0xB9, 0x42, 0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF3,
+0x6B, 0xA2, 0x02, 0x6A, 0x6C, 0xEA, 0x10, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x58, 0x9A,
+0x02, 0xF0, 0x00, 0x6C, 0x60, 0x9A, 0x8D, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9A,
+0xC0, 0xF7, 0x80, 0x9C, 0x8D, 0xEB, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x00, 0xF1, 0x43, 0xA0, 0x07, 0x6C, 0x00, 0x6D,
+0x4C, 0xEC, 0x00, 0x18, 0xDF, 0x13, 0xE0, 0xF0,
+0x8B, 0xA0, 0x04, 0x6B, 0x8C, 0xEB, 0x10, 0x23,
+0xA3, 0xF6, 0x6C, 0x98, 0x43, 0xEB, 0x0C, 0x60,
+0xA3, 0xF6, 0x93, 0xA0, 0x6F, 0xE2, 0x80, 0x34,
+0x88, 0x34, 0x63, 0xEC, 0x05, 0x60, 0xA3, 0xF6,
+0x51, 0xA0, 0x01, 0x4A, 0xA3, 0xF6, 0x51, 0xC0,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0xA7, 0xA2,
+0x01, 0x6B, 0xFF, 0x6C, 0xAC, 0xEB, 0x2D, 0x23,
+0x83, 0xF6, 0xAC, 0xA2, 0x10, 0x6B, 0xAC, 0xEB,
+0x8C, 0xEB, 0x03, 0x23, 0x00, 0x18, 0xD4, 0x22,
+0x24, 0x10, 0xE0, 0xF0, 0x6B, 0xA2, 0x40, 0x6A,
+0x6C, 0xEA, 0x8C, 0xEA, 0x03, 0x22, 0x00, 0x18,
+0x12, 0x23, 0x1B, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF6, 0x6F, 0xA2,
+0x01, 0x73, 0x04, 0x60, 0x09, 0x23, 0x05, 0x73,
+0x04, 0x60, 0x0F, 0x10, 0x00, 0x18, 0xE7, 0x24,
+0x0C, 0x10, 0x00, 0x18, 0xB5, 0x24, 0x09, 0x10,
+0x83, 0xF6, 0x8C, 0xA2, 0x80, 0x6B, 0x6B, 0xEB,
+0x8D, 0xEB, 0x83, 0xF6, 0x6C, 0xC2, 0x00, 0x18,
+0x03, 0x25, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF6,
+0x95, 0xA2, 0x01, 0x6B, 0x8C, 0xEB, 0x0D, 0x2B,
+0xA3, 0xF6, 0x76, 0xA2, 0x01, 0x4B, 0xA3, 0xF6,
+0x76, 0xC2, 0xA3, 0xF6, 0x76, 0xA2, 0xA3, 0xF6,
+0x55, 0xA2, 0x46, 0x32, 0x42, 0xEB, 0x2E, 0x60,
+0x72, 0x10, 0xA3, 0xF6, 0x76, 0xA2, 0xA3, 0xF6,
+0x55, 0xA2, 0x46, 0x32, 0x42, 0xEB, 0x0B, 0x60,
+0x00, 0x6A, 0x10, 0xF0, 0x21, 0x6C, 0xD1, 0xF3,
+0x15, 0x4C, 0xA2, 0x67, 0x05, 0x6E, 0x01, 0x6F,
+0x04, 0xD2, 0x00, 0x18, 0x8A, 0x3B, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xA3, 0xF6,
+0x56, 0xA0, 0x0F, 0x22, 0x00, 0x6A, 0x10, 0xF0,
+0x21, 0x6C, 0x52, 0xF5, 0x01, 0x4C, 0xA2, 0x67,
+0x66, 0x6E, 0x01, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0x8A, 0x3B, 0xA3, 0xF6, 0x56, 0xA0, 0xFF, 0x4A,
+0x03, 0x10, 0xA3, 0xF6, 0x55, 0xA0, 0x46, 0x32,
+0xA3, 0xF6, 0x56, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0, 0xA7, 0xA2,
+0x01, 0x6B, 0xFF, 0x6C, 0xAC, 0xEB, 0x3B, 0x23,
+0x83, 0xF6, 0xCC, 0xA2, 0x00, 0x6B, 0x83, 0xF6,
+0x6F, 0xC2, 0x10, 0x6B, 0xCC, 0xEB, 0x8C, 0xEB,
+0x32, 0x2B, 0x80, 0x6F, 0xEB, 0xEF, 0xCD, 0xEF,
+0x04, 0x6E, 0xAC, 0xEE, 0x8C, 0xEE, 0x83, 0xF6,
+0xEC, 0xC2, 0x1B, 0x26, 0xA3, 0xF6, 0x88, 0xA2,
+0xA3, 0xF6, 0xA9, 0xA2, 0xA3, 0xEC, 0x0A, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF6, 0xA0, 0x9A,
+0x21, 0xF4, 0x80, 0x9C, 0xA0, 0xDC, 0xA3, 0xF6,
+0x68, 0xC2, 0x17, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xA3, 0xF6, 0xA4, 0x9A, 0x21, 0xF4, 0x60, 0x9B,
+0x01, 0x4C, 0xA0, 0xDB, 0xA3, 0xF6, 0x88, 0xC2,
+0x0C, 0x10, 0x83, 0xF6, 0x7F, 0xA2, 0x09, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0xA3, 0xF6, 0x84, 0x9A,
+0x21, 0xF4, 0x60, 0x9B, 0x80, 0xDB, 0x83, 0xF6,
+0xDF, 0xC2, 0x00, 0x18, 0x03, 0x25, 0x07, 0x97,
+0x06, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x0A, 0xF1, 0x6C, 0xA2, 0x80, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x02, 0x2A,
+0x00, 0x18, 0x03, 0x25, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF6, 0x8D, 0xA2,
+0x11, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0x83, 0xF6,
+0x6D, 0xC2, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF3, 0x6B, 0xA2, 0x04, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x03, 0x25, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x02, 0x6D, 0xC4, 0x67, 0x38, 0x6C, 0x00, 0x18,
+0x78, 0x42, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x01, 0x6D, 0xC4, 0x67,
+0x28, 0x6C, 0x00, 0x18, 0x78, 0x42, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x40, 0xA4, 0x7D, 0x67, 0x07, 0x6D, 0x50, 0xC3,
+0x41, 0xA4, 0x04, 0x06, 0x51, 0xC3, 0x42, 0xA4,
+0x52, 0xC3, 0x43, 0xA4, 0x53, 0xC3, 0x44, 0xA4,
+0x30, 0x6C, 0x54, 0xC3, 0x00, 0x6A, 0x55, 0xC3,
+0x56, 0xC3, 0x00, 0x18, 0x78, 0x42, 0x07, 0x97,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x03, 0x6D, 0xC4, 0x67, 0x11, 0x6C, 0x00, 0x18,
+0x78, 0x42, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x01, 0x6D, 0xC4, 0x67,
+0x1B, 0x6C, 0x00, 0x18, 0x78, 0x42, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x01, 0x6D, 0xC4, 0x67, 0x17, 0x6C, 0x00, 0x18,
+0x78, 0x42, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x01, 0x6D, 0xC4, 0x67,
+0x23, 0x6C, 0x00, 0x18, 0x78, 0x42, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x27, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x06, 0x6A,
+0x4F, 0xCB, 0x08, 0x6A, 0x52, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF6,
+0x6A, 0xA2, 0x9D, 0x67, 0x73, 0xC4, 0xA3, 0xF6,
+0x6B, 0xA2, 0x74, 0xC4, 0xA3, 0xF6, 0x72, 0xA2,
+0x75, 0xC4, 0xA3, 0xF6, 0x70, 0xA2, 0xA3, 0xF6,
+0x51, 0xA2, 0x76, 0xC4, 0x57, 0xC4, 0x04, 0x04,
+0x00, 0x18, 0xBC, 0x27, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x15, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x92, 0xC3,
+0x01, 0x6A, 0x04, 0x04, 0x4F, 0xCB, 0x00, 0x18,
+0xBC, 0x27, 0x09, 0x97, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x0B, 0x6B, 0x4C, 0xED, 0xCC, 0xEA, 0xDD, 0x67,
+0x70, 0xC6, 0x07, 0x6B, 0x6F, 0xCE, 0x92, 0xC6,
+0x17, 0x24, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA3, 0xF6, 0x7B, 0xA2, 0x73, 0xC6,
+0xA3, 0xF6, 0x79, 0xA2, 0x74, 0xC6, 0xA3, 0xF6,
+0x7C, 0xA2, 0x75, 0xC6, 0xA3, 0xF6, 0x7D, 0xA2,
+0x76, 0xC6, 0xA3, 0xF6, 0x7E, 0xA2, 0xA3, 0xF6,
+0x5F, 0xA2, 0x77, 0xC6, 0x58, 0xC6, 0x07, 0x10,
+0x7D, 0x67, 0xB3, 0xC3, 0x54, 0xC3, 0x95, 0xC3,
+0x96, 0xC3, 0x97, 0xC3, 0x98, 0xC3, 0x04, 0x04,
+0x00, 0x18, 0xBC, 0x27, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x0A, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x06, 0x6A,
+0x4F, 0xCB, 0x40, 0xA4, 0x52, 0xC3, 0x41, 0xA4,
+0x53, 0xC3, 0x42, 0xA4, 0x54, 0xC3, 0x43, 0xA4,
+0x55, 0xC3, 0x44, 0xA4, 0x56, 0xC3, 0x45, 0xA4,
+0x04, 0x04, 0x57, 0xC3, 0x00, 0x18, 0xBC, 0x27,
+0x09, 0x97, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x61, 0xA4, 0xBD, 0x67,
+0x40, 0xA4, 0x70, 0xC5, 0x62, 0xA4, 0x0C, 0x5A,
+0x71, 0xC5, 0x63, 0xA4, 0x72, 0xC5, 0x64, 0xA4,
+0x73, 0xC5, 0x65, 0xA4, 0x74, 0xC5, 0x66, 0xA4,
+0xFF, 0x6C, 0x75, 0xC5, 0x80, 0xF0, 0x00, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32, 0xA0, 0xF5,
+0x00, 0x4B, 0x4D, 0xE3, 0x40, 0x9B, 0x00, 0xEA,
+0x2A, 0x6C, 0x08, 0x10, 0x29, 0x6C, 0x02, 0x6D,
+0x74, 0x10, 0x31, 0x6C, 0x71, 0x10, 0x32, 0x6C,
+0x6F, 0x10, 0x33, 0x6C, 0x06, 0x6D, 0x6D, 0x10,
+0x04, 0x04, 0x00, 0x18, 0x09, 0x26, 0x6C, 0x10,
+0x9D, 0x67, 0x70, 0xA4, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF6, 0x7A, 0xC2,
+0x71, 0xA4, 0x83, 0xF6, 0x7B, 0xC2, 0x72, 0xA4,
+0x83, 0xF6, 0x7C, 0xC2, 0x73, 0xA4, 0x83, 0xF6,
+0x7D, 0xC2, 0x74, 0xA4, 0x83, 0xF6, 0x7E, 0xC2,
+0x57, 0x10, 0xBD, 0x67, 0x50, 0xA5, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x93, 0xA5,
+0xA3, 0xF6, 0x49, 0xC3, 0x54, 0xA5, 0x80, 0x34,
+0x80, 0x34, 0x00, 0xF6, 0x40, 0x32, 0x8D, 0xEA,
+0x91, 0xA5, 0x8D, 0xEA, 0x92, 0xA5, 0x80, 0x34,
+0x8D, 0xEA, 0xA3, 0xF6, 0x40, 0xDB, 0x40, 0x10,
+0x00, 0x18, 0xD7, 0x25, 0x3D, 0x10, 0xBD, 0x67,
+0x90, 0xA5, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0x6B,
+0x84, 0x34, 0x86, 0xF2, 0x00, 0x4A, 0x6D, 0xEC,
+0xA3, 0xF6, 0x94, 0xC2, 0xA3, 0xF6, 0x94, 0xA2,
+0x86, 0x35, 0x1E, 0x55, 0x05, 0x60, 0x8C, 0xEB,
+0x3C, 0x6C, 0x8D, 0xEB, 0xA3, 0xF6, 0x74, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA3, 0xF6, 0x74, 0xA2, 0x66, 0x34, 0x51, 0x54,
+0x1F, 0x61, 0x01, 0x6C, 0x6C, 0xEC, 0x60, 0x6B,
+0x6B, 0xEB, 0x6D, 0xEC, 0xA3, 0xF6, 0x94, 0xC2,
+0x17, 0x10, 0x5D, 0x67, 0x70, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x2A, 0xF1, 0x73, 0xC2, 0x10, 0x10,
+0x7D, 0x67, 0x50, 0xA3, 0x7F, 0x6B, 0x4C, 0xEB,
+0x64, 0x33, 0x5E, 0x32, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x2A, 0xF1, 0x55, 0xC3, 0x04, 0x10,
+0x01, 0x6D, 0x04, 0x06, 0x00, 0x18, 0x78, 0x42,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x09, 0x6B, 0xBD, 0x67,
+0xFF, 0x6A, 0x4C, 0xEC, 0x70, 0xC5, 0x07, 0x6B,
+0x6F, 0xCD, 0x92, 0xC5, 0x2E, 0x2C, 0x30, 0xF0,
+0x20, 0x6B, 0x0A, 0xF1, 0x8C, 0xA3, 0x20, 0x6B,
+0x8C, 0xEB, 0x4C, 0xEB, 0x1C, 0x23, 0x40, 0x6B,
+0x8C, 0xEB, 0x4C, 0xEB, 0x04, 0x23, 0x01, 0x6A,
+0x7D, 0x67, 0x53, 0xC3, 0x16, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF4, 0x68, 0x9B, 0x60, 0xA3,
+0x07, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF4,
+0x6C, 0x9B, 0x60, 0xA3, 0x6C, 0xEA, 0x04, 0x22,
+0x01, 0x6A, 0x9D, 0x67, 0x53, 0xC4, 0x05, 0x10,
+0xBD, 0x67, 0x53, 0xC5, 0x02, 0x10, 0x5D, 0x67,
+0x73, 0xC2, 0x00, 0x6A, 0x7D, 0x67, 0x54, 0xC3,
+0x55, 0xC3, 0x56, 0xC3, 0x57, 0xC3, 0x58, 0xC3,
+0x28, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA3, 0xF6, 0x7A, 0xA2, 0x9D, 0x67,
+0xBD, 0x67, 0x73, 0xC4, 0xA3, 0xF6, 0x9B, 0xA2,
+0x94, 0xC5, 0xA3, 0xF6, 0x9C, 0xA2, 0x95, 0xC5,
+0xA3, 0xF6, 0x9D, 0xA2, 0x96, 0xC5, 0xA3, 0xF6,
+0x9E, 0xA2, 0x97, 0xC5, 0xA3, 0xF6, 0x9F, 0xA2,
+0x98, 0xC5, 0x83, 0xF6, 0xCC, 0xA2, 0x01, 0x6C,
+0x6C, 0xEC, 0x21, 0x6B, 0x6B, 0xEB, 0x94, 0x35,
+0xCC, 0xEB, 0xAD, 0xEB, 0x41, 0x6D, 0xAB, 0xED,
+0x98, 0x34, 0xAC, 0xEB, 0x8D, 0xEB, 0x83, 0xF6,
+0x6C, 0xC2, 0x04, 0x04, 0x00, 0x18, 0xBC, 0x27,
+0x09, 0x97, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xA3, 0xF6, 0x58, 0xA0, 0x02, 0x6C, 0x27, 0x72,
+0x4B, 0x60, 0x28, 0x5A, 0x06, 0x60, 0x15, 0x72,
+0x0C, 0x60, 0x23, 0x72, 0x01, 0x6C, 0x44, 0x60,
+0xC6, 0x10, 0x34, 0x72, 0x4A, 0x60, 0x39, 0x72,
+0x80, 0xF0, 0x04, 0x60, 0x30, 0x72, 0x3F, 0x60,
+0xBE, 0x10, 0xA3, 0xF6, 0x9A, 0xA0, 0x40, 0x6A,
+0x8C, 0xEA, 0x0E, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF4, 0x50, 0x9A, 0x3F, 0x6D, 0xAF, 0xEB,
+0x40, 0x9A, 0x8D, 0xEB, 0x46, 0x32, 0xAC, 0xEA,
+0x49, 0xE3, 0xFF, 0x6B, 0x6C, 0xEA, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0x50, 0x9A,
+0x60, 0x9A, 0x3F, 0x6A, 0x66, 0x33, 0x4C, 0xEB,
+0x8C, 0xEA, 0x49, 0xE3, 0x40, 0x5A, 0x78, 0x67,
+0x6B, 0xEB, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF1, 0xB0, 0x9B, 0x30, 0xF0, 0x20, 0x6E,
+0x21, 0xF4, 0xD4, 0x9E, 0x80, 0x9D, 0x40, 0xF6,
+0x40, 0x33, 0x44, 0x32, 0xCC, 0xEC, 0x8D, 0xEB,
+0x60, 0xDD, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF4,
+0x90, 0x9B, 0x7F, 0x6D, 0xAB, 0xED, 0x60, 0x9C,
+0xAC, 0xEB, 0x6D, 0xEA, 0x40, 0xDC, 0x83, 0x10,
+0x00, 0x18, 0x64, 0x26, 0x80, 0x10, 0x00, 0x6D,
+0x01, 0x6C, 0xC5, 0x67, 0x00, 0x18, 0xF0, 0x25,
+0x7A, 0x10, 0xA3, 0xF6, 0x5A, 0xA0, 0x01, 0x69,
+0x2C, 0xEA, 0x23, 0x22, 0x83, 0xF6, 0x4D, 0xA0,
+0x08, 0x6B, 0x6C, 0xEA, 0x70, 0x2A, 0x9D, 0x67,
+0x38, 0xC4, 0xB1, 0x67, 0x34, 0x6C, 0x06, 0x06,
+0x00, 0x18, 0x78, 0x42, 0x02, 0x6C, 0x00, 0x18,
+0x55, 0x42, 0x83, 0xF6, 0x4C, 0xA0, 0x08, 0x6B,
+0xFF, 0x6C, 0x6D, 0xEA, 0x30, 0x6B, 0x83, 0xF6,
+0x79, 0xC0, 0x10, 0x6B, 0x6D, 0xEA, 0x83, 0xF6,
+0x4C, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x64, 0x9A, 0x40, 0xA3, 0x8C, 0xEA, 0x2D, 0xEA,
+0x12, 0x10, 0x03, 0x6C, 0x00, 0x18, 0x55, 0x42,
+0x00, 0x18, 0xDE, 0x21, 0x83, 0xF6, 0x6C, 0xA0,
+0x09, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x83, 0xF6,
+0x4C, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x64, 0x9A, 0xFD, 0x6A, 0x80, 0xA3, 0x8C, 0xEA,
+0x40, 0xC3, 0x3D, 0x10, 0xE0, 0xF0, 0x87, 0xA0,
+0x01, 0x6A, 0xFF, 0x6B, 0x8C, 0xEA, 0x37, 0x22,
+0xE0, 0xF0, 0x8B, 0xA0, 0x04, 0x6D, 0xAC, 0xEC,
+0x6C, 0xEC, 0x31, 0x24, 0x83, 0xF6, 0x8C, 0xA0,
+0x80, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0x6C, 0xEA,
+0x2A, 0x22, 0xA3, 0xF6, 0x50, 0xA0, 0x01, 0x4A,
+0xA3, 0xF6, 0x50, 0xC0, 0xE0, 0xF0, 0x49, 0xA0,
+0xAC, 0xEA, 0x6C, 0xEA, 0x09, 0x22, 0x83, 0xF6,
+0xAD, 0xA0, 0x10, 0x6A, 0xAC, 0xEA, 0x6C, 0xEA,
+0x03, 0x22, 0x7F, 0x6A, 0x8C, 0xEA, 0x15, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x83, 0xF6, 0x4F, 0xA0, 0x10, 0x2A, 0x10, 0xF0,
+0x21, 0x6C, 0x92, 0xF6, 0x19, 0x4C, 0x00, 0x6D,
+0x05, 0x6E, 0x01, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0x8A, 0x3B, 0x83, 0xF6, 0x6C, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x83, 0xF6, 0x4C, 0xC0, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7, 0x68, 0x9B,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0xA3, 0xEB,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF4, 0x78, 0x9B, 0x21, 0xF4,
+0x9C, 0x9C, 0x6D, 0xE5, 0x91, 0xE5, 0x22, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF4, 0x60, 0x9B, 0x41, 0xF4, 0x84, 0x9C,
+0x6D, 0xE5, 0x91, 0xE5, 0x00, 0x6E, 0xC0, 0xDB,
+0x04, 0x4B, 0x8A, 0xEB, 0xFB, 0x61, 0xE7, 0xF7,
+0x1F, 0x6B, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x44, 0x9A, 0x4D, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0x40, 0x9A, 0x49, 0xE5,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4,
+0x48, 0x9A, 0x17, 0x10, 0x00, 0x6E, 0xC0, 0xDB,
+0x04, 0x4B, 0x8A, 0xEB, 0xFB, 0x61, 0xE7, 0xF7,
+0x1F, 0x6B, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x44, 0x9A, 0x4D, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF4, 0x58, 0x9A, 0x49, 0xE5,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4,
+0x4C, 0x9A, 0x55, 0xE5, 0x40, 0xA5, 0xFF, 0x6B,
+0x10, 0x6C, 0x6C, 0xEA, 0x8D, 0xEA, 0x6C, 0xEA,
+0x40, 0xC5, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x02, 0xF5, 0x73, 0xA2,
+0xA4, 0x67, 0x04, 0x2B, 0x02, 0xF5, 0x54, 0xA2,
+0x0F, 0x72, 0x0B, 0x60, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x02, 0xF5, 0x53, 0xA0,
+0x02, 0xF5, 0x74, 0xA0, 0xFF, 0x4A, 0x6E, 0xEA,
+0x15, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF0,
+0x8C, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x60, 0xDA, 0xA3, 0x10, 0x23, 0xA5, 0xFF, 0xF7,
+0x1F, 0x6A, 0x04, 0x49, 0x4C, 0xE9, 0x02, 0xF5,
+0x50, 0xA8, 0x1F, 0x2A, 0xE8, 0x6A, 0x58, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0x07, 0xF1, 0x10, 0x4A,
+0xFF, 0x6E, 0x2C, 0xEE, 0x12, 0xEB, 0x71, 0xE2,
+0x00, 0x18, 0xB9, 0x20, 0x02, 0xF5, 0x54, 0xA0,
+0x02, 0xF5, 0x73, 0xA0, 0x02, 0xF5, 0x30, 0xC8,
+0x4E, 0xEB, 0x73, 0x2B, 0x01, 0x4A, 0x02, 0xF5,
+0x54, 0xC0, 0x02, 0xF5, 0x54, 0xA0, 0x10, 0x6B,
+0x6E, 0xEA, 0x6B, 0x2A, 0x02, 0xF5, 0x54, 0xC0,
+0x68, 0x10, 0x62, 0xA5, 0x36, 0x2B, 0x4D, 0xE1,
+0xE3, 0x53, 0x33, 0x60, 0x02, 0xF5, 0x72, 0xA0,
+0xE8, 0x6C, 0x98, 0xEB, 0x12, 0xEB, 0x0D, 0xE3,
+0x80, 0xF6, 0x92, 0xA3, 0x2A, 0x2C, 0x80, 0xF6,
+0x93, 0xA3, 0xFF, 0x6E, 0xFC, 0x4A, 0xFF, 0x4C,
+0x80, 0xF6, 0x93, 0xC3, 0x02, 0xF5, 0x70, 0xA8,
+0xE8, 0x6C, 0xCC, 0xEA, 0xFF, 0x4B, 0x02, 0xF5,
+0x70, 0xC8, 0x02, 0xF5, 0x72, 0xA0, 0x2C, 0xEE,
+0x98, 0xEB, 0x12, 0xEB, 0x6D, 0xE0, 0x49, 0xE3,
+0x90, 0xF6, 0x83, 0x42, 0x00, 0x18, 0xB9, 0x20,
+0x02, 0xF5, 0x52, 0xA0, 0xE8, 0x6B, 0x78, 0xEA,
+0x12, 0xEA, 0x09, 0xE2, 0x80, 0xF6, 0x73, 0xA2,
+0x6D, 0xE1, 0x80, 0xF6, 0x73, 0xC2, 0x02, 0xF5,
+0x50, 0xA8, 0x45, 0xE1, 0x02, 0xF5, 0x30, 0xC8,
+0x30, 0x10, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x02, 0xF5, 0x94, 0xA0, 0xE8, 0x6A,
+0xFF, 0x6E, 0x58, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0x07, 0xF1, 0x10, 0x4A, 0x2C, 0xEE, 0x12, 0xEC,
+0x91, 0xE2, 0x00, 0x18, 0xB9, 0x20, 0x02, 0xF5,
+0x54, 0xA0, 0x10, 0x6B, 0x02, 0xF5, 0x30, 0xC8,
+0x01, 0x4A, 0x02, 0xF5, 0x54, 0xC0, 0x02, 0xF5,
+0x54, 0xA0, 0x6E, 0xEA, 0x02, 0x2A, 0x02, 0xF5,
+0x54, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x02, 0xF5, 0x72, 0xA2, 0x10, 0x6C,
+0x01, 0x4B, 0x02, 0xF5, 0x72, 0xC2, 0x02, 0xF5,
+0x72, 0xA2, 0x8E, 0xEB, 0x02, 0x2B, 0x02, 0xF5,
+0x72, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x02, 0xF5, 0x92, 0xA2, 0xE8, 0x6B,
+0x78, 0xEC, 0x02, 0xF5, 0x90, 0xAA, 0x12, 0xEB,
+0x4D, 0xE3, 0x60, 0xF7, 0x97, 0xC3, 0xA0, 0xF0,
+0x64, 0x9A, 0x04, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x66, 0xF2,
+0x58, 0xA3, 0xFF, 0x6F, 0xE0, 0xF0, 0xC7, 0xA5,
+0x41, 0xC5, 0x43, 0xA5, 0x66, 0xF2, 0x78, 0xA3,
+0x03, 0x4A, 0xEC, 0xEA, 0x09, 0x10, 0xED, 0x42,
+0xFF, 0x68, 0x0C, 0xEF, 0xFD, 0xE5, 0x64, 0xC7,
+0xE6, 0xA7, 0x03, 0x4F, 0xE9, 0xE2, 0x0C, 0xEA,
+0xEF, 0x46, 0xE2, 0xEA, 0xF4, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x78, 0xA2, 0x01, 0x4B,
+0x66, 0xF2, 0x78, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x48, 0x9A, 0x83, 0xEA, 0x05, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4, 0x40, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4,
+0x58, 0x9A, 0x51, 0xE4, 0x00, 0x18, 0xB9, 0x20,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xA0, 0xF0,
+0x44, 0x98, 0x04, 0x6B, 0xA4, 0x67, 0x6D, 0xEA,
+0xA0, 0xF0, 0x44, 0xD8, 0x80, 0xF6, 0x4E, 0xA8,
+0x09, 0xF7, 0x00, 0x72, 0x07, 0x60, 0x80, 0xF6,
+0x4E, 0xA0, 0x80, 0xF6, 0x8F, 0xA0, 0xFF, 0x4A,
+0x8E, 0xEA, 0x13, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x00, 0xF2, 0x00, 0x6C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3,
+0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA,
+0x15, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x06, 0xF4,
+0x0E, 0x4A, 0x90, 0x34, 0x91, 0xE2, 0x10, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0x80, 0xF6, 0x4F, 0xA0,
+0x50, 0x6B, 0x01, 0x4A, 0x80, 0xF6, 0x4F, 0xC0,
+0x80, 0xF6, 0x4F, 0xA0, 0x6E, 0xEA, 0x02, 0x2A,
+0x80, 0xF6, 0x4F, 0xC0, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0x79, 0xA2, 0x24, 0x67, 0x05, 0x67,
+0x61, 0xC5, 0x01, 0x4B, 0x66, 0xF2, 0x79, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x48, 0x9A,
+0x83, 0xEA, 0x0D, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF4, 0x80, 0x9A, 0x02, 0x6E, 0x91, 0xE1,
+0x00, 0x18, 0xB9, 0x20, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF4, 0x90, 0x9A, 0x0C, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF4, 0x98, 0x9A, 0x02, 0x6E,
+0x91, 0xE1, 0x00, 0x18, 0xB9, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0x94, 0x9A, 0xCE, 0xA0,
+0x91, 0xE1, 0xA2, 0x40, 0x00, 0x18, 0xB9, 0x20,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x68, 0x1D, 0x10, 0xE0, 0xF3,
+0x08, 0x70, 0x13, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x80, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA, 0x00, 0x6A,
+0x10, 0x10, 0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A,
+0x0A, 0x6C, 0x4C, 0xE8, 0x00, 0x18, 0x95, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x48, 0x9A,
+0x60, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0xDB, 0x2A,
+0x01, 0x6A, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x24, 0x67, 0x00, 0x18,
+0xFB, 0x27, 0x00, 0x6B, 0x48, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF1, 0x4C, 0x9A, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF0, 0x6C, 0x9B, 0x40, 0x9A,
+0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7,
+0x68, 0x9B, 0x43, 0xEB, 0x07, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF4, 0x18, 0x9B, 0x01, 0xE2,
+0x01, 0x4A, 0x02, 0x10, 0x01, 0x42, 0x50, 0x67,
+0xFF, 0xF7, 0x1F, 0x6B, 0x4C, 0xEB, 0x42, 0x32,
+0x0F, 0x6C, 0x42, 0x32, 0x8C, 0xEA, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF4, 0x9C, 0x9C, 0xB0, 0x67,
+0x60, 0xCC, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF4,
+0x60, 0x9B, 0x40, 0xC3, 0xE0, 0xF0, 0x87, 0xA1,
+0x00, 0x18, 0x08, 0x27, 0x87, 0x40, 0x11, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x9F, 0x27, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x48, 0x9A, 0x01, 0x6B,
+0x80, 0xF2, 0x16, 0x6C, 0x60, 0xC2, 0x01, 0x6D,
+0x06, 0x02, 0x00, 0x6E, 0x04, 0xF7, 0x10, 0x6F,
+0x04, 0xD2, 0x00, 0x18, 0x0B, 0x20, 0x4B, 0xEB,
+0x4D, 0xEB, 0xC0, 0xF7, 0x62, 0x33, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x43, 0x67, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x02, 0xF5, 0x53, 0xA0, 0x02, 0xF5,
+0x74, 0xA0, 0x4E, 0xEB, 0x40, 0x23, 0xE8, 0x6B,
+0x78, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x07, 0xF1,
+0x10, 0x4B, 0x12, 0xEA, 0x51, 0xE3, 0x00, 0x18,
+0x13, 0x28, 0x07, 0x2A, 0xA0, 0xF0, 0x44, 0x98,
+0x04, 0x6B, 0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8,
+0x2E, 0x10, 0x02, 0xF5, 0x53, 0xA0, 0x10, 0x6B,
+0x01, 0x4A, 0x02, 0xF5, 0x53, 0xC0, 0x02, 0xF5,
+0x53, 0xA0, 0x6E, 0xEA, 0x02, 0x2A, 0x02, 0xF5,
+0x53, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x02, 0xF5, 0x93, 0xA2, 0x02, 0xF5,
+0x74, 0xA2, 0x8E, 0xEB, 0x07, 0x23, 0xA0, 0xF0,
+0x64, 0x9A, 0x04, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x04, 0x10, 0x02, 0xF5, 0x92, 0xC2,
+0x02, 0xF5, 0x70, 0xCA, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x40, 0xF1, 0x82, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x04, 0x23, 0x40, 0xF1,
+0x63, 0xA2, 0x23, 0xF5, 0x72, 0xC2, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x24, 0x67, 0x00, 0x18, 0xFB, 0x27, 0x00, 0x6B,
+0x50, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0,
+0x6C, 0x9B, 0x40, 0x9A, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x68, 0x9B, 0x43, 0xEB,
+0x07, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF4,
+0x18, 0x9B, 0x01, 0xE2, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x42, 0x50, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF4, 0x7C, 0x9B, 0xFF, 0xF7, 0x1F, 0x6D,
+0x82, 0x67, 0xAC, 0xEC, 0x80, 0xCB, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF4, 0x80, 0x9B, 0xFF, 0x6E,
+0x10, 0x6F, 0x60, 0xA4, 0xEB, 0xEF, 0x42, 0x32,
+0xCC, 0xEB, 0xEC, 0xEB, 0x42, 0x32, 0x6D, 0xEA,
+0xCC, 0xEA, 0x40, 0xC4, 0x87, 0xA9, 0x02, 0x4C,
+0xAC, 0xEC, 0xB0, 0x67, 0x00, 0x18, 0x08, 0x27,
+0x87, 0x40, 0x11, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0xDF, 0x27, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x48, 0x9A, 0x01, 0x6B, 0x80, 0xF2, 0x16, 0x6C,
+0x60, 0xC2, 0x01, 0x6D, 0x06, 0x02, 0x00, 0x6E,
+0x04, 0xF7, 0x10, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0x0B, 0x20, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x33, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x43, 0x67, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x80, 0xF6,
+0x8E, 0xA0, 0x80, 0xF6, 0x4F, 0xA0, 0x8E, 0xEA,
+0x32, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x90, 0x34,
+0x06, 0xF4, 0x0E, 0x4A, 0x91, 0xE2, 0x00, 0x18,
+0x68, 0x28, 0x1C, 0x22, 0x80, 0xF6, 0x4E, 0xA0,
+0x01, 0x4A, 0x80, 0xF6, 0x4E, 0xC0, 0x80, 0xF6,
+0x6E, 0xA0, 0x80, 0xF6, 0x4F, 0xA0, 0x6E, 0xEA,
+0x06, 0x22, 0xA0, 0xF0, 0x44, 0x98, 0x04, 0x6B,
+0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x80, 0xF6,
+0x6E, 0xA2, 0x50, 0x6C, 0x8E, 0xEB, 0x02, 0x2B,
+0x80, 0xF6, 0x6E, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x40, 0xF1, 0x82, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x04, 0x23, 0x40, 0xF1,
+0x63, 0xA2, 0x23, 0xF5, 0x72, 0xC2, 0x00, 0x18,
+0x6B, 0x29, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFE, 0x63, 0x03, 0xD1,
+0x02, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x44, 0x9A, 0x0F, 0x6B, 0x40, 0xA2, 0x4C, 0xEB,
+0x0A, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x84, 0x9A, 0x02, 0x6D,
+0xAD, 0xEC, 0xA0, 0xF0, 0x84, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x06, 0xF4, 0x4C, 0xA2, 0xFF, 0x4A,
+0x00, 0xD2, 0xDF, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x80, 0xF1, 0x8C, 0xAA,
+0x00, 0xF7, 0x00, 0x74, 0x05, 0x60, 0x80, 0xF1,
+0x0D, 0xA2, 0x00, 0x94, 0x8A, 0xE8, 0x0E, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A,
+0xFF, 0x6C, 0x01, 0x4C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xBD, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x66, 0xF2, 0x9A, 0xA4, 0xA3, 0x67, 0xA7, 0xEC,
+0x85, 0x67, 0x01, 0x6D, 0xAC, 0xEC, 0xA0, 0xF0,
+0x0A, 0x24, 0x0C, 0x35, 0xB5, 0xE2, 0x40, 0xF1,
+0x10, 0x4D, 0x00, 0x6A, 0x30, 0xF0, 0x20, 0x6E,
+0x66, 0xF2, 0xFA, 0xA6, 0xFF, 0x6C, 0x1F, 0xF7,
+0x00, 0x69, 0x8C, 0xEF, 0x74, 0x4F, 0xE8, 0x37,
+0xFD, 0xE2, 0x2C, 0xEF, 0x02, 0xF0, 0x00, 0x77,
+0x08, 0x60, 0x66, 0xF2, 0xFA, 0xA6, 0x8C, 0xEF,
+0x74, 0x4F, 0xE8, 0x37, 0xFD, 0xE2, 0x2C, 0xEF,
+0x0F, 0x2F, 0x30, 0xF0, 0x20, 0x6C, 0x66, 0xF2,
+0x3A, 0xA4, 0xFF, 0x6C, 0x30, 0xF0, 0x20, 0x6E,
+0x8C, 0xE9, 0x74, 0x49, 0x28, 0x31, 0xE2, 0x67,
+0x25, 0xE2, 0x41, 0xF0, 0xD8, 0x9E, 0x0B, 0x10,
+0x66, 0xF2, 0x3A, 0xA6, 0x30, 0xF0, 0x20, 0x6E,
+0x41, 0xF0, 0xDC, 0x9E, 0x8C, 0xE9, 0x74, 0x49,
+0x28, 0x31, 0xE2, 0x67, 0x25, 0xE2, 0xD9, 0xE1,
+0xC0, 0xA6, 0x0C, 0x31, 0xCC, 0xEC, 0x30, 0xF0,
+0x20, 0x6E, 0x86, 0xF2, 0x00, 0x4E, 0xD9, 0xE1,
+0xFD, 0xE6, 0x40, 0xF1, 0x8C, 0xC7, 0x30, 0xF0,
+0x20, 0x6E, 0x66, 0xF2, 0xFA, 0xA6, 0xFF, 0x6C,
+0x1F, 0xF7, 0x00, 0x69, 0x8C, 0xEF, 0x7C, 0x4F,
+0xE8, 0x37, 0xFD, 0xE2, 0x2C, 0xEF, 0x02, 0xF0,
+0x00, 0x77, 0x08, 0x60, 0x66, 0xF2, 0xFA, 0xA6,
+0x8C, 0xEF, 0x7C, 0x4F, 0xE8, 0x37, 0xFD, 0xE2,
+0x2C, 0xEF, 0x0E, 0x2F, 0x30, 0xF0, 0x20, 0x6C,
+0x66, 0xF2, 0xDA, 0xA4, 0xFF, 0x6C, 0x30, 0xF0,
+0x20, 0x6F, 0x8C, 0xEE, 0x7C, 0x4E, 0xC8, 0x36,
+0xD9, 0xE2, 0x41, 0xF0, 0xF8, 0x9F, 0x0A, 0x10,
+0x66, 0xF2, 0xDA, 0xA6, 0x30, 0xF0, 0x20, 0x6F,
+0x41, 0xF0, 0xFC, 0x9F, 0x8C, 0xEE, 0x7C, 0x4E,
+0xC8, 0x36, 0xD9, 0xE2, 0xF9, 0xE6, 0xC0, 0xA6,
+0x01, 0x4A, 0x04, 0x72, 0xCC, 0xEC, 0x80, 0xC5,
+0x01, 0x4D, 0x8C, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0xBA, 0xA2, 0x01, 0x6C, 0xC4, 0x67,
+0xC4, 0xED, 0xCF, 0xED, 0x66, 0xF2, 0xDA, 0xA2,
+0xAC, 0xEB, 0xFF, 0x6D, 0x84, 0xEE, 0x30, 0xF0,
+0x20, 0x6E, 0x61, 0xF4, 0xC4, 0x9E, 0xAC, 0xEC,
+0x80, 0xC6, 0x66, 0xF2, 0x9A, 0xA2, 0xAC, 0xEC,
+0x01, 0x4C, 0xAC, 0xEC, 0x66, 0xF2, 0x9A, 0xC2,
+0x66, 0xF2, 0xBA, 0xA2, 0x03, 0x6C, 0xAC, 0xEC,
+0x66, 0xF2, 0x9A, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x80, 0xF1, 0x8D, 0xA2,
+0x08, 0x6D, 0x01, 0x4C, 0x80, 0xF1, 0x8D, 0xC2,
+0x80, 0xF1, 0x8D, 0xA2, 0xAE, 0xEC, 0x11, 0x2C,
+0x80, 0xF1, 0x8D, 0xC2, 0x0E, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF0, 0xA0, 0x9B, 0x02, 0x6C,
+0x60, 0x9D, 0x8D, 0xEB, 0x60, 0xDD, 0x83, 0xF3,
+0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA,
+0x02, 0x10, 0x1F, 0xF7, 0x1F, 0x2B, 0x03, 0x91,
+0x02, 0x90, 0x02, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF4, 0x48, 0x9A, 0xFF, 0x68,
+0x60, 0xA2, 0x6C, 0xE8, 0x1A, 0x20, 0x00, 0x6B,
+0x60, 0xC2, 0x01, 0x6C, 0x00, 0x18, 0x95, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x4C, 0x9A,
+0x20, 0x6B, 0x20, 0x70, 0x60, 0xC2, 0x0D, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF0, 0x64, 0x9A,
+0xC0, 0xF7, 0x80, 0x9C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x15, 0x0E, 0x00, 0x18, 0xC2, 0x09,
+0x05, 0x6C, 0x01, 0x6D, 0x00, 0x18, 0x9E, 0x1D,
+0x20, 0xBA, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xFF, 0x17, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF4, 0x50, 0x9A, 0x60, 0xA2, 0x03, 0x6A,
+0x6C, 0xEA, 0x10, 0x6B, 0x64, 0xEA, 0xFF, 0x6A,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x54, 0x9A, 0x04, 0xD3, 0x40, 0x9A, 0x05, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x58, 0x9A,
+0x00, 0x9A, 0x05, 0x92, 0x0A, 0xEA, 0xA0, 0xF0,
+0x1B, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x64, 0x9A, 0x02, 0x6C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x30, 0xF0,
+0x20, 0x69, 0x86, 0xF2, 0x00, 0x49, 0x02, 0xF6,
+0x56, 0xA9, 0x00, 0xF7, 0x00, 0x72, 0x07, 0x60,
+0x02, 0xF6, 0x96, 0xA1, 0x02, 0xF6, 0x77, 0xA1,
+0xAF, 0x44, 0x6E, 0xED, 0x13, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A, 0xFF, 0x6C,
+0x01, 0x4C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x60, 0xDA, 0x8E, 0x10, 0x30, 0xF0, 0x20, 0x6D,
+0x41, 0xF4, 0xA0, 0x9D, 0x7F, 0x6E, 0xB5, 0xE0,
+0xE0, 0xA5, 0xCC, 0xEF, 0x3F, 0x2F, 0x00, 0xF4,
+0x00, 0x72, 0x80, 0xF0, 0x01, 0x60, 0xAC, 0x44,
+0x6E, 0xED, 0x7E, 0x25, 0x00, 0xF5, 0x01, 0x72,
+0x7B, 0x60, 0x00, 0xF6, 0x02, 0x72, 0x78, 0x60,
+0x00, 0xF7, 0x03, 0x72, 0x75, 0x60, 0x00, 0xF5,
+0x00, 0x72, 0x72, 0x60, 0xFD, 0x4C, 0x8E, 0xEB,
+0x6F, 0x23, 0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2,
+0x00, 0x49, 0x02, 0xF6, 0x56, 0xA9, 0x00, 0xF6,
+0x01, 0x72, 0x66, 0x60, 0x00, 0xF7, 0x02, 0x72,
+0x63, 0x60, 0x00, 0xF6, 0x00, 0x72, 0x60, 0x60,
+0x02, 0xF6, 0x96, 0xA1, 0x02, 0xF6, 0x77, 0xA1,
+0xFE, 0x4C, 0x6E, 0xEC, 0x59, 0x24, 0x00, 0xF7,
+0x01, 0x72, 0x56, 0x60, 0x74, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x71, 0xE1, 0x61, 0xF4, 0x5C, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF4, 0xA0, 0x9B,
+0x49, 0xE0, 0x40, 0xAA, 0x02, 0xF5, 0x16, 0x4C,
+0xB5, 0xE0, 0x0E, 0x10, 0x40, 0xA5, 0x4C, 0xEE,
+0x01, 0x76, 0x1B, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF4, 0x5C, 0x9A, 0x74, 0x33, 0x71, 0xE1,
+0x49, 0xE0, 0x40, 0xAA, 0x02, 0xF5, 0x16, 0x4C,
+0xFF, 0x6E, 0x4C, 0xEE, 0x00, 0x18, 0xB9, 0x20,
+0x02, 0xF6, 0x57, 0xA1, 0x08, 0x6B, 0x01, 0x4A,
+0x02, 0xF6, 0x57, 0xC1, 0x02, 0xF6, 0x57, 0xA1,
+0x6E, 0xEA, 0x13, 0x2A, 0x02, 0xF6, 0x57, 0xC1,
+0x10, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0x80, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0,
+0x70, 0x9B, 0x40, 0x9C, 0x6D, 0xEA, 0x40, 0xDC,
+0x83, 0xF3, 0x40, 0x99, 0x6D, 0xEA, 0x83, 0xF3,
+0x40, 0xD9, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4,
+0x40, 0x9A, 0x04, 0x93, 0x40, 0x9A, 0x0E, 0xEA,
+0x61, 0xE0, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF4, 0x44, 0x9A, 0x00, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF4, 0x58, 0x9A, 0x00, 0xDA,
+0x05, 0x92, 0x4A, 0xE8, 0x5F, 0xF7, 0x0F, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x46, 0xF3,
+0x12, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0xB9, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC0, 0xF0, 0x92, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x0C, 0x23, 0xC0, 0xF0, 0x74, 0xA2, 0xFF, 0x73,
+0x08, 0x60, 0xC0, 0xF0, 0x93, 0xA2, 0x03, 0xF5,
+0x64, 0xA2, 0x6D, 0xE4, 0x04, 0x4B, 0xE3, 0xF4,
+0x7A, 0xCA, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x26, 0xF3, 0x08, 0x4C, 0x07, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xDE, 0x63, 0x43, 0x62,
+0x42, 0xD1, 0x41, 0xD0, 0x01, 0x6A, 0x7D, 0x67,
+0x4B, 0xEA, 0x58, 0xC3, 0x01, 0x6A, 0x5A, 0xC3,
+0x08, 0x6A, 0x5B, 0xC3, 0x40, 0xA4, 0x7F, 0x6B,
+0x6C, 0xEA, 0x01, 0x72, 0x80, 0xF0, 0x01, 0x61,
+0x48, 0xA4, 0xBD, 0x67, 0x5C, 0xC5, 0x41, 0xA4,
+0x5D, 0xC5, 0x42, 0xA4, 0x5E, 0xC5, 0x46, 0xA4,
+0x20, 0xF0, 0x40, 0xC5, 0x43, 0xA4, 0x5F, 0xC5,
+0x47, 0xA4, 0x20, 0xF0, 0x41, 0xC5, 0x5C, 0xA5,
+0x7E, 0x2A, 0x7D, 0x67, 0x5F, 0xA3, 0x7E, 0xA3,
+0x40, 0x32, 0x6D, 0xEA, 0x03, 0x72, 0x05, 0x60,
+0x08, 0x72, 0x1A, 0x60, 0x02, 0x72, 0x2A, 0x60,
+0x72, 0x10, 0x06, 0x04, 0x00, 0x18, 0x33, 0x27,
+0x9D, 0x67, 0x20, 0xF0, 0xE1, 0xA4, 0x20, 0xF0,
+0x40, 0xA4, 0x30, 0xF0, 0x20, 0x6D, 0xE0, 0x37,
+0x5D, 0xE7, 0xFF, 0xF7, 0x1F, 0x6A, 0x05, 0x6C,
+0xA9, 0xF0, 0x08, 0x4D, 0x00, 0xF4, 0x00, 0x6E,
+0x4C, 0xEF, 0x00, 0x18, 0xBC, 0x4F, 0x5E, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0xBD, 0x67, 0x0C, 0xF5,
+0x04, 0x48, 0x10, 0x6A, 0x09, 0x04, 0x5B, 0xC5,
+0x04, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0xB9, 0x20,
+0x0A, 0x04, 0xA4, 0x40, 0x04, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0x49, 0x10, 0x30, 0xF0, 0x20, 0x68,
+0x06, 0x04, 0x86, 0xF2, 0x00, 0x48, 0x00, 0x18,
+0x33, 0x27, 0xA6, 0xF2, 0x20, 0xA0, 0x01, 0x6A,
+0x4E, 0xE9, 0x27, 0x29, 0x00, 0x18, 0x49, 0x47,
+0x86, 0xF2, 0x6C, 0xA0, 0x04, 0x6A, 0x6C, 0xEA,
+0x1D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4,
+0x48, 0x9A, 0x86, 0xF2, 0xD8, 0x98, 0x10, 0xF0,
+0x21, 0x6C, 0x40, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x5C, 0x9A, 0xBE, 0xF4, 0x1D, 0x4C,
+0x00, 0x6D, 0x40, 0x9A, 0x01, 0x6F, 0x04, 0xD1,
+0x5B, 0xE6, 0xE0, 0xF3, 0x08, 0x6A, 0x5B, 0xEE,
+0x01, 0x2A, 0xE5, 0xE8, 0x12, 0xEE, 0x00, 0x18,
+0x8A, 0x3B, 0x1C, 0x10, 0x00, 0x18, 0xE2, 0x3C,
+0x19, 0x10, 0x00, 0x18, 0x5D, 0x47, 0x86, 0xF2,
+0xBE, 0xA8, 0x00, 0x6C, 0x00, 0x18, 0x94, 0x3C,
+0x11, 0x10, 0x10, 0x2A, 0x69, 0xA4, 0xBD, 0x67,
+0x7C, 0xC5, 0x68, 0xA4, 0x5E, 0xC5, 0x5F, 0xC5,
+0x7D, 0xC5, 0x46, 0xA4, 0x20, 0xF0, 0x40, 0xC5,
+0x47, 0xA4, 0x20, 0xF0, 0x41, 0xC5, 0x06, 0x04,
+0x00, 0x18, 0x33, 0x27, 0x43, 0x97, 0x42, 0x91,
+0x41, 0x90, 0x22, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x68, 0x44, 0xFA, 0x4B, 0x4C, 0xEB, 0x04, 0x5B,
+0x03, 0x60, 0x00, 0x18, 0x5C, 0x62, 0x54, 0x10,
+0x0A, 0x74, 0x2D, 0x60, 0x0B, 0x5C, 0x0C, 0x60,
+0x03, 0x74, 0x1E, 0x60, 0x04, 0x5C, 0x03, 0x60,
+0x02, 0x74, 0x16, 0x60, 0x34, 0x10, 0x08, 0x74,
+0x1A, 0x60, 0x09, 0x74, 0x1C, 0x60, 0x2F, 0x10,
+0x0D, 0x74, 0x0A, 0x60, 0x0E, 0x5C, 0x03, 0x60,
+0x0C, 0x74, 0x1D, 0x60, 0x28, 0x10, 0x12, 0x74,
+0x22, 0x60, 0x24, 0x74, 0x1C, 0x60, 0x23, 0x10,
+0x85, 0x67, 0x00, 0x18, 0xF1, 0x4F, 0x34, 0x10,
+0x85, 0x67, 0x00, 0x18, 0xB0, 0x3C, 0x30, 0x10,
+0x00, 0x18, 0xAC, 0x4F, 0x2D, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x7B, 0x4F, 0x29, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xE8, 0x4E, 0x25, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x3B, 0x4F, 0x21, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xBF, 0x4E, 0x1D, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x66, 0x54, 0x19, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x5B, 0x3A, 0x15, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF0, 0x84, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA, 0xFF, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xA4, 0x40, 0xF1, 0xC9, 0xA2, 0x02, 0x6B,
+0x01, 0x68, 0x6B, 0xEB, 0x0C, 0xED, 0xCC, 0xEB,
+0xAD, 0xEB, 0x40, 0xF1, 0x69, 0xC2, 0xA1, 0xA4,
+0x0C, 0xEB, 0x40, 0xF1, 0xAA, 0xC2, 0x82, 0xA4,
+0x40, 0xF1, 0x8B, 0xC2, 0x40, 0xF1, 0x4B, 0xA2,
+0x06, 0xD2, 0x20, 0x23, 0x01, 0x69, 0x2B, 0xE9,
+0xD1, 0x67, 0x00, 0x6C, 0x42, 0x6D, 0x00, 0x18,
+0x4F, 0x36, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0xFC, 0x9B, 0xD1, 0x67, 0x00, 0x6C, 0x4D, 0xEF,
+0x42, 0x6D, 0x00, 0x18, 0xC5, 0x37, 0x06, 0x96,
+0x64, 0x6A, 0x10, 0xF0, 0x21, 0x6C, 0x01, 0x4E,
+0x58, 0xEE, 0xCB, 0xF2, 0x15, 0x4C, 0x00, 0x6D,
+0xF1, 0x67, 0x04, 0xD0, 0x12, 0xEE, 0x00, 0x18,
+0x8A, 0x3B, 0x06, 0x10, 0x10, 0xF0, 0x21, 0x6C,
+0xCB, 0xF2, 0x15, 0x4C, 0x00, 0x18, 0x77, 0x3B,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0xA4, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x48,
+0x07, 0x6E, 0x26, 0xF3, 0x16, 0x4C, 0x00, 0x18,
+0xB9, 0x20, 0xA0, 0xF0, 0x99, 0xA0, 0x96, 0x34,
+0x00, 0x18, 0xAA, 0x1C, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x58, 0x9A, 0x01, 0x6B, 0x60, 0xC2,
+0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF7, 0x7C, 0x9B,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF0,
+0x7A, 0xA0, 0x01, 0xF0, 0x40, 0x9A, 0x60, 0xC2,
+0xA0, 0xF0, 0x77, 0xA0, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x50, 0x9A, 0x72, 0x33, 0x60, 0xC2,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x08, 0xD4, 0x41, 0xA4, 0x24, 0x67, 0x06, 0xD2,
+0x60, 0xA4, 0x02, 0x6A, 0x6C, 0xEA, 0x06, 0x93,
+0x07, 0xD3, 0x02, 0x22, 0x42, 0xA4, 0x07, 0xD2,
+0x06, 0x90, 0x15, 0x10, 0x08, 0x93, 0x01, 0x6D,
+0x90, 0x67, 0x40, 0xA3, 0x4C, 0xED, 0x00, 0x18,
+0xB3, 0x13, 0x90, 0x67, 0x00, 0x18, 0xAA, 0x13,
+0x04, 0x2A, 0x90, 0x67, 0x00, 0x18, 0xD5, 0x13,
+0x03, 0x10, 0x90, 0x67, 0x00, 0x18, 0xDA, 0x13,
+0x01, 0x48, 0xFF, 0x6A, 0x4C, 0xE8, 0x07, 0x92,
+0x03, 0xEA, 0xE8, 0x60, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xC0, 0xF0, 0x9A, 0xA0,
+0x06, 0x92, 0x8E, 0xEA, 0x1B, 0x2A, 0x00, 0x18,
+0xAA, 0x13, 0x18, 0x2A, 0x00, 0x18, 0x99, 0x41,
+0xA0, 0xF0, 0x99, 0xA0, 0x96, 0x34, 0x00, 0x18,
+0xAA, 0x17, 0xE3, 0xF4, 0x68, 0xA0, 0x05, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xE3, 0xF4, 0x69, 0xA0,
+0xE3, 0xF4, 0x48, 0xC0, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x03, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0xE3, 0xF4, 0x49, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x2C, 0xF6, 0xB8, 0xA2, 0x60, 0xA1, 0x01, 0x6A,
+0xAC, 0xEA, 0x72, 0x34, 0x15, 0x2A, 0x04, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x4C, 0x9A, 0x60, 0xDA, 0xF0, 0x17,
+0x05, 0x74, 0x17, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x2C, 0xF6, 0x78, 0xA2, 0x04, 0x6A, 0x6C, 0xEA,
+0x10, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x40, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF4, 0x60, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF7, 0x4C, 0x9A, 0x60, 0xDA,
+0xF0, 0x17, 0x43, 0xA1, 0x07, 0x6B, 0x01, 0x6C,
+0x4C, 0xEB, 0x40, 0xA1, 0x8C, 0xEA, 0x1C, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF6, 0xC4, 0xA2, 0x84, 0xEB, 0x1F, 0x6F,
+0xCA, 0x35, 0x8F, 0xEC, 0xEC, 0xED, 0x8C, 0xED,
+0x7D, 0x6C, 0x8B, 0xEC, 0xA8, 0x35, 0xCC, 0xEC,
+0xAD, 0xEC, 0xC3, 0xF6, 0x84, 0xC2, 0xC0, 0xF0,
+0x99, 0xA2, 0x8E, 0xEB, 0x1E, 0x2B, 0x01, 0x6B,
+0x6B, 0xEB, 0xC3, 0xF6, 0x65, 0xC2, 0x19, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF6, 0xC4, 0xA2, 0x1F, 0x6F, 0x84, 0xEB,
+0xCA, 0x35, 0xEC, 0xED, 0xAD, 0xEC, 0xEC, 0xEC,
+0x88, 0x35, 0x7D, 0x6C, 0x8B, 0xEC, 0xCC, 0xEC,
+0xAD, 0xEC, 0xC3, 0xF6, 0x84, 0xC2, 0xC0, 0xF0,
+0x99, 0xA2, 0x8E, 0xEB, 0x02, 0x2B, 0xC3, 0xF6,
+0x85, 0xC2, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xC3, 0xF6, 0x64, 0xA0, 0x02, 0x6A,
+0x6C, 0xEA, 0x1A, 0x22, 0x03, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xC3, 0xF6, 0x44, 0xC0, 0x00, 0x18,
+0x0D, 0x3B, 0x04, 0xD2, 0x04, 0x93, 0xC3, 0xF6,
+0x48, 0x98, 0x6E, 0xEA, 0x03, 0x22, 0x04, 0x94,
+0x00, 0x18, 0x29, 0x3B, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF6, 0x84, 0xA2,
+0x02, 0x6B, 0x8D, 0xEB, 0xC3, 0xF6, 0x64, 0xC2,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC, 0x68, 0x44,
+0xC8, 0x4B, 0x4C, 0xEB, 0x20, 0x5B, 0x05, 0x67,
+0x03, 0x60, 0x00, 0x18, 0x68, 0x66, 0x6D, 0x11,
+0x2D, 0x74, 0xE0, 0xF0, 0x1F, 0x60, 0x2E, 0x5C,
+0x54, 0x60, 0x19, 0x74, 0xC0, 0xF0, 0x16, 0x60,
+0x1A, 0x5C, 0x24, 0x60, 0x10, 0x74, 0xA0, 0xF0,
+0x1D, 0x60, 0x11, 0x5C, 0x0C, 0x60, 0x01, 0x74,
+0xA0, 0xF0, 0x04, 0x60, 0x80, 0xF0, 0x1E, 0x24,
+0x0B, 0x74, 0xA0, 0xF0, 0x03, 0x60, 0x0E, 0x74,
+0xA0, 0xF0, 0x0C, 0x60, 0x3F, 0x11, 0x16, 0x74,
+0xA0, 0xF0, 0x14, 0x60, 0x17, 0x5C, 0x07, 0x60,
+0x14, 0x74, 0x40, 0xF1, 0x0A, 0x60, 0x15, 0x74,
+0xA0, 0xF0, 0x08, 0x60, 0x33, 0x11, 0x17, 0x74,
+0xA0, 0xF0, 0x0C, 0x60, 0x18, 0x74, 0xA0, 0xF0,
+0x0D, 0x60, 0x2C, 0x11, 0x21, 0x74, 0x20, 0xF1,
+0x1C, 0x60, 0x22, 0x5C, 0x13, 0x60, 0x1E, 0x74,
+0xA0, 0xF0, 0x18, 0x60, 0x1F, 0x5C, 0x07, 0x60,
+0x1C, 0x74, 0xA0, 0xF0, 0x07, 0x60, 0x1D, 0x74,
+0xA0, 0xF0, 0x08, 0x60, 0x1B, 0x11, 0x1F, 0x74,
+0xA0, 0xF0, 0x08, 0x60, 0x20, 0x74, 0xA0, 0xF0,
+0x0D, 0x60, 0x14, 0x11, 0x25, 0x74, 0x20, 0xF1,
+0x04, 0x60, 0x26, 0x5C, 0x07, 0x60, 0x23, 0x74,
+0x00, 0xF1, 0x1F, 0x60, 0x24, 0x74, 0xA0, 0xF0,
+0x05, 0x60, 0x08, 0x11, 0x27, 0x74, 0xA0, 0xF0,
+0x05, 0x60, 0x2C, 0x74, 0xA0, 0xF0, 0x06, 0x60,
+0x01, 0x11, 0x6C, 0x74, 0xE0, 0xF0, 0x0A, 0x60,
+0x6D, 0x5C, 0x2B, 0x60, 0x64, 0x74, 0xA0, 0xF0,
+0x0D, 0x60, 0x65, 0x5C, 0x13, 0x60, 0x61, 0x74,
+0xC0, 0xF0, 0x04, 0x60, 0x62, 0x5C, 0x07, 0x60,
+0x2E, 0x74, 0x80, 0xF0, 0x1B, 0x60, 0x60, 0x74,
+0x80, 0xF0, 0x1C, 0x60, 0xEB, 0x10, 0x62, 0x74,
+0xA0, 0xF0, 0x1C, 0x60, 0x63, 0x74, 0xA0, 0xF0,
+0x1D, 0x60, 0xE4, 0x10, 0x67, 0x74, 0xC0, 0xF0,
+0x01, 0x60, 0x68, 0x5C, 0x07, 0x60, 0x65, 0x74,
+0x80, 0xF0, 0x14, 0x60, 0x66, 0x74, 0xA0, 0xF0,
+0x15, 0x60, 0xD8, 0x10, 0x68, 0x74, 0xA0, 0xF0,
+0x19, 0x60, 0x69, 0x74, 0xA0, 0xF0, 0x1A, 0x60,
+0xD1, 0x10, 0xB0, 0x74, 0x33, 0x60, 0xB1, 0x5C,
+0x13, 0x60, 0x6F, 0x74, 0x80, 0xF0, 0x0E, 0x60,
+0x70, 0x5C, 0x07, 0x60, 0x6D, 0x74, 0x80, 0xF0,
+0x01, 0x60, 0x6E, 0x74, 0x80, 0xF0, 0x02, 0x60,
+0xC1, 0x10, 0x70, 0x74, 0x80, 0xF0, 0x06, 0x60,
+0x71, 0x74, 0x80, 0xF0, 0x07, 0x60, 0xBA, 0x10,
+0xCA, 0x74, 0xA0, 0xF0, 0x07, 0x60, 0xCB, 0x5C,
+0x06, 0x60, 0xB1, 0x74, 0x1B, 0x60, 0xC3, 0x74,
+0xA0, 0xF0, 0x08, 0x60, 0xAF, 0x10, 0xCB, 0x74,
+0xA0, 0xF0, 0x00, 0x60, 0xFE, 0x74, 0xA0, 0xF0,
+0x05, 0x60, 0xA8, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xEC, 0x29, 0xB7, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xBA, 0x2A, 0xB3, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x55, 0x06, 0xAF, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x71, 0x2E, 0xAB, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x65, 0x2E, 0xA7, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x10, 0x2D, 0xA3, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x3C, 0x2D, 0x9F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x50, 0x2E, 0x9B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x8B, 0x2C, 0x97, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xA2, 0x46, 0x93, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE4, 0x43, 0x8F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xD1, 0x2C, 0x8B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE5, 0x43, 0x87, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE6, 0x43, 0x83, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE5, 0x05, 0x7F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x3E, 0x06, 0x7B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x9F, 0x2A, 0x77, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x99, 0x06, 0x73, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x83, 0x06, 0x6F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x5D, 0x06, 0x6B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xDB, 0x29, 0x67, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x64, 0x30, 0x63, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xB1, 0x24, 0x5F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x98, 0x22, 0x5B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE8, 0x21, 0x57, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xF5, 0x21, 0x53, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x1D, 0x22, 0x4F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x2C, 0x22, 0x4B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x38, 0x22, 0x47, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x65, 0x22, 0x43, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xD2, 0x25, 0x3F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xCD, 0x25, 0x3B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xC8, 0x25, 0x37, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xC3, 0x25, 0x33, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xB7, 0x25, 0x2F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xB2, 0x25, 0x2B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x16, 0x26, 0x27, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xAD, 0x25, 0x23, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xD8, 0x05, 0x1F, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x7A, 0x2A, 0x1B, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x85, 0x2C, 0x17, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x08, 0x3F, 0x13, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x01, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA, 0x0E, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x40, 0xC0, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x80, 0xF1,
+0x4C, 0xA0, 0x80, 0xF1, 0x6D, 0xA0, 0x4E, 0xEB,
+0x29, 0x23, 0x67, 0x42, 0x22, 0x4B, 0x6C, 0x33,
+0x0D, 0xE3, 0x4C, 0x32, 0x84, 0xA3, 0x55, 0xE0,
+0x40, 0xF1, 0x0D, 0x4D, 0x00, 0x18, 0x2F, 0x2B,
+0x80, 0xF1, 0x4C, 0xA0, 0x01, 0x4A, 0x80, 0xF1,
+0x4C, 0xC0, 0x80, 0xF1, 0x6C, 0xA0, 0x80, 0xF1,
+0x4D, 0xA0, 0x6E, 0xEA, 0x06, 0x22, 0xA0, 0xF0,
+0x44, 0x98, 0x02, 0x6B, 0x6D, 0xEA, 0xA0, 0xF0,
+0x44, 0xD8, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x80, 0xF1, 0x6C, 0xA2, 0x08, 0x6C,
+0x8E, 0xEB, 0x02, 0x2B, 0x80, 0xF1, 0x6C, 0xC2,
+0x00, 0x18, 0xBB, 0x28, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x02, 0xF6, 0xB6, 0xA0, 0x7F, 0x6C,
+0xB4, 0x35, 0x09, 0xE5, 0x02, 0xF5, 0x76, 0xA2,
+0x8C, 0xEB, 0x1F, 0x2B, 0x02, 0xF5, 0x9E, 0xA2,
+0xA2, 0x67, 0x02, 0xF5, 0x1F, 0x4D, 0x00, 0x18,
+0x2F, 0x2B, 0x02, 0xF6, 0x96, 0xA0, 0x30, 0xF0,
+0x20, 0x6B, 0xC1, 0xF4, 0x64, 0x9B, 0x94, 0x34,
+0x09, 0xE4, 0x02, 0xF5, 0xBC, 0xA2, 0x91, 0xE0,
+0xA0, 0xC3, 0x30, 0xF0, 0x20, 0x6B, 0x02, 0xF5,
+0xBD, 0xA2, 0xC1, 0xF4, 0x68, 0x9B, 0xA0, 0xC3,
+0x02, 0xF5, 0x56, 0x82, 0x00, 0x52, 0x38, 0x60,
+0x33, 0x10, 0x01, 0x73, 0x35, 0x61, 0x02, 0xF5,
+0x77, 0xA2, 0xFF, 0x73, 0x0E, 0x61, 0x02, 0xF5,
+0x98, 0xA2, 0xB5, 0xE0, 0x02, 0xF5, 0x16, 0x4D,
+0x00, 0x18, 0x48, 0x2A, 0x02, 0xF6, 0x76, 0xA0,
+0x74, 0x33, 0x01, 0xE3, 0x02, 0xF5, 0x5E, 0xC0,
+0x04, 0x10, 0x01, 0x6B, 0x6B, 0xEB, 0x02, 0xF5,
+0x7E, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x02, 0xF6, 0x96, 0xA2, 0x30, 0xF0,
+0x20, 0x6D, 0xC1, 0xF4, 0xA4, 0x9D, 0x94, 0x34,
+0x4D, 0xE4, 0x02, 0xF5, 0xDC, 0xA3, 0xC0, 0xC5,
+0x30, 0xF0, 0x20, 0x6D, 0x02, 0xF5, 0xDD, 0xA3,
+0xC1, 0xF4, 0xA8, 0x9D, 0xC0, 0xC5, 0x02, 0xF5,
+0x76, 0x83, 0x00, 0x53, 0x05, 0x60, 0x91, 0xE2,
+0x02, 0xF5, 0x16, 0x4C, 0x00, 0x18, 0xF3, 0x29,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x02, 0xF6,
+0x76, 0xA0, 0x02, 0xF6, 0x57, 0xA0, 0x6E, 0xEA,
+0x42, 0x22, 0x80, 0xF6, 0x4E, 0xA8, 0x09, 0xF6,
+0x00, 0x72, 0x10, 0x60, 0x80, 0xF6, 0x8E, 0xA0,
+0x80, 0xF6, 0x6F, 0xA0, 0xAE, 0x44, 0x6E, 0xED,
+0x09, 0x25, 0x09, 0xF7, 0x01, 0x72, 0x06, 0x60,
+0x09, 0xF7, 0x00, 0x72, 0x03, 0x60, 0xFF, 0x4C,
+0x8E, 0xEB, 0x0D, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA0, 0xF0, 0x44, 0x9B,
+0x04, 0x6C, 0x8D, 0xEA, 0x02, 0x6C, 0x8D, 0xEA,
+0xA0, 0xF0, 0x44, 0xDB, 0x20, 0x10, 0x00, 0x18,
+0x0D, 0x2C, 0x02, 0xF6, 0x56, 0xA0, 0x01, 0x4A,
+0x02, 0xF6, 0x56, 0xC0, 0x02, 0xF6, 0x76, 0xA0,
+0x02, 0xF6, 0x57, 0xA0, 0x6E, 0xEA, 0x06, 0x22,
+0xA0, 0xF0, 0x44, 0x98, 0x02, 0x6B, 0x6D, 0xEA,
+0xA0, 0xF0, 0x44, 0xD8, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x02, 0xF6, 0x76, 0xA2,
+0x08, 0x6C, 0x8E, 0xEB, 0x02, 0x2B, 0x02, 0xF6,
+0x76, 0xC2, 0x00, 0x18, 0x6B, 0x29, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x22, 0x6A, 0x7D, 0x67,
+0x50, 0xC3, 0x92, 0xC3, 0x01, 0x6A, 0x04, 0x04,
+0x4F, 0xCB, 0x00, 0x18, 0xBC, 0x27, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x1A, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x00, 0xF0,
+0x12, 0x04, 0x05, 0x6A, 0x4F, 0xCB, 0x00, 0x18,
+0x6A, 0x08, 0x04, 0x04, 0x00, 0x18, 0xBC, 0x27,
+0x09, 0x97, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x19, 0x6A, 0x7D, 0x67,
+0x50, 0xC3, 0x00, 0xF0, 0x12, 0x04, 0x08, 0x6A,
+0x4F, 0xCB, 0x00, 0x18, 0x84, 0x08, 0x04, 0x04,
+0x00, 0x18, 0xBC, 0x27, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x40, 0xA4, 0x01, 0x72, 0x04, 0x61, 0x00, 0x18,
+0x7C, 0x2C, 0x00, 0x18, 0x73, 0x2C, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0x60, 0xA4, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF3,
+0x71, 0xC2, 0x61, 0xA4, 0xC3, 0xF3, 0x72, 0xC2,
+0x62, 0xA4, 0xC3, 0xF3, 0x7B, 0xC2, 0x63, 0xA4,
+0xC3, 0xF3, 0x7C, 0xC2, 0x64, 0xA4, 0xE3, 0xF3,
+0x65, 0xC2, 0x65, 0xA4, 0xE3, 0xF3, 0x66, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xC3, 0xF3, 0x60, 0xA0,
+0x01, 0x6E, 0xFF, 0x69, 0xCC, 0xEB, 0x44, 0x67,
+0x2C, 0xEB, 0x2C, 0xEA, 0x2C, 0xED, 0x3C, 0x23,
+0xC3, 0xF3, 0x80, 0xA0, 0x92, 0x34, 0x2C, 0xEC,
+0x8E, 0xEA, 0x36, 0x2A, 0x16, 0x25, 0xC3, 0xF3,
+0x42, 0xA0, 0xC3, 0xF3, 0x81, 0xA0, 0x0F, 0x6D,
+0x4C, 0xED, 0x52, 0x36, 0x2C, 0xED, 0x2C, 0xEE,
+0x00, 0x18, 0xA0, 0x3C, 0xC3, 0xF3, 0xE0, 0xA0,
+0xA0, 0xF0, 0x8A, 0xA0, 0x00, 0x6D, 0xF2, 0x37,
+0x08, 0x6E, 0x2C, 0xEF, 0x00, 0x18, 0x6D, 0x1D,
+0x1F, 0x10, 0x7D, 0x67, 0x1F, 0x6A, 0xCF, 0xCB,
+0x00, 0x6D, 0x50, 0xC3, 0x00, 0x18, 0x38, 0x31,
+0x7D, 0x67, 0x52, 0xC3, 0x04, 0x04, 0x00, 0x18,
+0xBC, 0x27, 0xC3, 0xF3, 0x60, 0xA0, 0x02, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xC3, 0xF3, 0x40, 0xC0,
+0xC3, 0xF3, 0x80, 0xA0, 0x92, 0x34, 0x2C, 0xEC,
+0x00, 0x18, 0x7B, 0x3F, 0xC3, 0xF3, 0x80, 0xA0,
+0x92, 0x34, 0x2C, 0xEC, 0x00, 0x18, 0x71, 0x3F,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xC3, 0xF3, 0x60, 0xA0, 0x01, 0x6A,
+0x6C, 0xEA, 0x10, 0x22, 0x00, 0x6C, 0x04, 0xF0,
+0x00, 0x6D, 0x00, 0x18, 0xA3, 0x09, 0xC3, 0xF3,
+0xE0, 0xA0, 0xA0, 0xF0, 0x8A, 0xA0, 0xFF, 0x6A,
+0xF2, 0x37, 0x01, 0x6D, 0x08, 0x6E, 0x4C, 0xEF,
+0x00, 0x18, 0x6D, 0x1D, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x45, 0xA4, 0x01, 0x68, 0xA4, 0x67,
+0x0C, 0xEA, 0x3F, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x74, 0xA2,
+0xA0, 0xF0, 0xCF, 0xA2, 0x0D, 0xEB, 0xA0, 0xF0,
+0x74, 0xC2, 0x81, 0xA4, 0xE0, 0xF3, 0x08, 0x6B,
+0x80, 0x34, 0x88, 0x34, 0x7A, 0xEC, 0x01, 0x2B,
+0xE5, 0xE8, 0x12, 0xEB, 0xE3, 0xF4, 0x64, 0xC2,
+0x65, 0xA5, 0x66, 0x33, 0xE3, 0xF4, 0x65, 0xC2,
+0x65, 0xA5, 0x82, 0xA5, 0x66, 0x33, 0x6F, 0xE4,
+0xE3, 0xF4, 0x66, 0xC2, 0x62, 0xA5, 0xE3, 0xF4,
+0x67, 0xC2, 0x80, 0xA5, 0x02, 0x6B, 0x6B, 0xEB,
+0x0C, 0xEC, 0xCC, 0xEB, 0x8D, 0xEB, 0xA0, 0xF0,
+0x6F, 0xC2, 0x80, 0xA5, 0x0C, 0xEB, 0x86, 0x34,
+0x84, 0x34, 0x8D, 0xEB, 0xA0, 0xF0, 0x6F, 0xC2,
+0xE3, 0xF4, 0x67, 0xA2, 0x64, 0x73, 0x03, 0x61,
+0xE3, 0xF4, 0x07, 0xC2, 0x39, 0x10, 0x96, 0x73,
+0x37, 0x61, 0x03, 0x6B, 0xE3, 0xF4, 0x67, 0xC2,
+0x33, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x26, 0xF3,
+0x0F, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0xB9, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x90, 0xA2, 0xE0, 0xF3, 0x08, 0x6B,
+0x80, 0x34, 0x88, 0x34, 0x7A, 0xEC, 0x01, 0x2B,
+0xE5, 0xE8, 0x12, 0xEB, 0xA0, 0xF0, 0x70, 0xC2,
+0xA0, 0xF0, 0x71, 0xA2, 0x64, 0x73, 0x03, 0x61,
+0xA0, 0xF0, 0x11, 0xC2, 0x05, 0x10, 0x96, 0x73,
+0x03, 0x61, 0x03, 0x6B, 0xA0, 0xF0, 0x71, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x71, 0xA2, 0xC3, 0xF3, 0xA7, 0xA2,
+0x0F, 0x6C, 0x6C, 0xEC, 0x10, 0x6B, 0x6B, 0xEB,
+0xAC, 0xEB, 0x8D, 0xEB, 0xC3, 0xF3, 0x67, 0xC2,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x24, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0xB1, 0x67,
+0x02, 0x6E, 0x49, 0xF6, 0x01, 0x4C, 0x30, 0xF0,
+0x20, 0x68, 0x00, 0x18, 0xB9, 0x20, 0x86, 0xF2,
+0x00, 0x48, 0x62, 0xA1, 0xC3, 0xF3, 0x80, 0xA0,
+0x0F, 0x6A, 0x4C, 0xEB, 0x70, 0x33, 0x8C, 0xEA,
+0x6D, 0xEA, 0xC3, 0xF3, 0x40, 0xC0, 0x66, 0xA1,
+0x00, 0xF6, 0x60, 0x33, 0x04, 0xD3, 0x65, 0xA1,
+0x04, 0x94, 0x60, 0x33, 0x60, 0x33, 0x6D, 0xEC,
+0x63, 0xA1, 0x6D, 0xEC, 0x64, 0xA1, 0xFF, 0x69,
+0x60, 0x33, 0x6D, 0xEC, 0x01, 0x6B, 0x4D, 0xEB,
+0xC3, 0xF3, 0x60, 0xC0, 0x04, 0xD4, 0xC3, 0xF3,
+0x80, 0xA0, 0x92, 0x34, 0x00, 0x18, 0x67, 0x3F,
+0xC3, 0xF3, 0x80, 0xA0, 0x92, 0x34, 0x00, 0x18,
+0x5D, 0x3F, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF4,
+0x70, 0x9A, 0x08, 0x6C, 0x8B, 0xEC, 0x40, 0xA3,
+0x04, 0xF0, 0x00, 0x6D, 0x2C, 0xEA, 0x8C, 0xEA,
+0xC3, 0xF3, 0x80, 0xA0, 0x92, 0x34, 0x8D, 0xEA,
+0x2C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF4, 0x54, 0x9A, 0x04, 0x93, 0x00, 0x6C,
+0x60, 0xDA, 0x00, 0x18, 0x86, 0x09, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xF7, 0x63, 0x11, 0x62, 0x10, 0xD1, 0x0F, 0xD0,
+0x04, 0x67, 0x00, 0x18, 0xEC, 0x1F, 0x60, 0xA0,
+0x06, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x09, 0xD0, 0xC3, 0xF3, 0x74, 0xCA,
+0x61, 0xA0, 0xC3, 0xF3, 0xA9, 0xA2, 0x01, 0x6C,
+0xC3, 0xF3, 0x7E, 0xCA, 0x62, 0xA0, 0x30, 0xF0,
+0x20, 0x6E, 0xE9, 0xF6, 0x04, 0x4E, 0xE3, 0xF3,
+0x68, 0xCA, 0x63, 0xA0, 0x6C, 0xEC, 0x02, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0x8D, 0xEB, 0xC3, 0xF3,
+0x69, 0xC2, 0xA3, 0xA0, 0x1F, 0x6C, 0x8B, 0xEC,
+0xB2, 0x35, 0xA4, 0x35, 0x6C, 0xEC, 0xAD, 0xEC,
+0xC3, 0xF3, 0x89, 0xC2, 0xC3, 0xF3, 0x49, 0xA2,
+0x00, 0x6D, 0x46, 0x32, 0x07, 0xD2, 0x07, 0x93,
+0x0F, 0x6A, 0x4C, 0xEB, 0x07, 0xD3, 0x73, 0x10,
+0x09, 0x94, 0x06, 0x97, 0xAD, 0xE4, 0x84, 0xA3,
+0xFF, 0xF7, 0x1F, 0x6B, 0x91, 0xE7, 0x6C, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0, 0x68, 0x9B,
+0x80, 0xCB, 0x9C, 0x34, 0x10, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF4, 0x60, 0x9B, 0x6D, 0xE4,
+0x60, 0xA3, 0x01, 0x4C, 0x60, 0xC6, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF4, 0x60, 0x9B, 0x0C, 0xD2,
+0x71, 0xE4, 0x00, 0x6B, 0x46, 0x10, 0x01, 0x72,
+0xF6, 0x61, 0x40, 0x4C, 0xF4, 0x17, 0x20, 0xA4,
+0x0C, 0x6A, 0x30, 0xF0, 0x20, 0x6F, 0x19, 0x65,
+0x0C, 0x91, 0x86, 0xF2, 0x00, 0x4F, 0x58, 0xE9,
+0x7C, 0x6A, 0x12, 0xE9, 0x08, 0xD1, 0x58, 0xED,
+0x08, 0x92, 0x12, 0xE9, 0x29, 0xE2, 0xE5, 0xE2,
+0x0A, 0xD2, 0x65, 0xE1, 0x58, 0x67, 0x43, 0xF4,
+0x4C, 0xC1, 0x21, 0x44, 0x20, 0xA1, 0x5D, 0x67,
+0x30, 0xC2, 0x22, 0x44, 0x20, 0xA1, 0x31, 0xC2,
+0x23, 0x44, 0x20, 0xA1, 0x32, 0xC2, 0x24, 0xA4,
+0x05, 0x4C, 0x33, 0xC2, 0x1F, 0x69, 0x38, 0xED,
+0x08, 0x91, 0x12, 0xEA, 0x29, 0xE2, 0x65, 0xE2,
+0xE0, 0xF6, 0x1A, 0x49, 0x28, 0x31, 0xE5, 0xE1,
+0x5D, 0x67, 0x19, 0x65, 0x32, 0xA2, 0xF3, 0xA2,
+0x50, 0xA2, 0x20, 0x31, 0x20, 0x31, 0x00, 0xF6,
+0xE0, 0x37, 0x2D, 0xEF, 0x3D, 0x67, 0x31, 0xA1,
+0x4D, 0xEF, 0x58, 0x67, 0x08, 0xD1, 0x20, 0x31,
+0x2D, 0xEF, 0xE1, 0xDA, 0x01, 0x4B, 0xFF, 0x6F,
+0xEC, 0xEB, 0xE0, 0xA6, 0xE3, 0xEB, 0xBB, 0x61,
+0x0C, 0x92, 0xFF, 0x6B, 0x01, 0x4A, 0x6C, 0xEA,
+0x07, 0x93, 0x62, 0xEA, 0x91, 0x61, 0x01, 0x4D,
+0x02, 0x75, 0x7C, 0x4E, 0x02, 0x60, 0x00, 0x6A,
+0xF7, 0x17, 0x06, 0x94, 0x64, 0xA0, 0xFF, 0xF7,
+0x1F, 0x6A, 0x30, 0xF0, 0x20, 0x6D, 0x6D, 0xE4,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x48, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF4,
+0x80, 0x9C, 0x60, 0xCA, 0x69, 0xF7, 0xA0, 0xA5,
+0x7C, 0x32, 0x91, 0xE2, 0xA0, 0xC4, 0x30, 0xF0,
+0x20, 0x6C, 0xC1, 0xF4, 0x98, 0x9C, 0x91, 0xE2,
+0x00, 0x6A, 0x22, 0x10, 0xB9, 0xE2, 0xC3, 0xF4,
+0xC8, 0xA6, 0xFD, 0x67, 0xC0, 0xC4, 0x10, 0xF7,
+0xC9, 0x42, 0xC8, 0x36, 0xB5, 0xE6, 0xA1, 0x9D,
+0xDD, 0x67, 0x01, 0x4A, 0xB0, 0xC6, 0xA2, 0x36,
+0xD1, 0xC7, 0xC2, 0x36, 0xD2, 0xC7, 0xD0, 0xA7,
+0x00, 0xF6, 0xA2, 0x35, 0xB3, 0xC7, 0xA1, 0x44,
+0xC0, 0xC5, 0xD1, 0xA7, 0xA2, 0x44, 0xC0, 0xC5,
+0xD2, 0xA7, 0xA3, 0x44, 0xC0, 0xC5, 0xB3, 0xA7,
+0xA4, 0xC4, 0xFF, 0x6D, 0xAC, 0xEA, 0x05, 0x4C,
+0x30, 0xF0, 0x20, 0x6D, 0x86, 0xF2, 0x00, 0x4D,
+0xE3, 0xF4, 0xC0, 0xA5, 0xC3, 0xEA, 0xD6, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF4, 0x5C, 0x9A,
+0x7C, 0x33, 0x4D, 0xE3, 0x00, 0x6A, 0x21, 0x10,
+0xB1, 0xE2, 0xC3, 0xF4, 0x94, 0xA4, 0x3D, 0x67,
+0x80, 0xC3, 0x20, 0xF7, 0x85, 0x42, 0x88, 0x34,
+0xB5, 0xE4, 0x81, 0x9D, 0x01, 0x4A, 0x82, 0x35,
+0x90, 0xC1, 0xB1, 0xC1, 0xA2, 0x35, 0xB2, 0xC1,
+0xB0, 0xA1, 0x00, 0xF6, 0x82, 0x34, 0x93, 0xC1,
+0x81, 0x43, 0xA0, 0xC4, 0xB1, 0xA1, 0x82, 0x43,
+0xA0, 0xC4, 0xB2, 0xA1, 0x83, 0x43, 0xA0, 0xC4,
+0x93, 0xA1, 0x84, 0xC3, 0xFF, 0x6C, 0x8C, 0xEA,
+0x05, 0x4B, 0x30, 0xF0, 0x20, 0x6D, 0x86, 0xF2,
+0x00, 0x4D, 0xE3, 0xF4, 0x80, 0xA5, 0x83, 0xEA,
+0xD7, 0x61, 0x06, 0x92, 0x65, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF4, 0x80, 0x9C, 0x6D, 0xE2,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x48, 0x9A, 0x60, 0xCA,
+0x63, 0xF4, 0xA4, 0xA5, 0x7C, 0x32, 0x91, 0xE2,
+0xA0, 0xC4, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF4,
+0x98, 0x9C, 0x91, 0xE2, 0x00, 0x6A, 0x22, 0x10,
+0xB9, 0xE2, 0x43, 0xF4, 0xCC, 0xA6, 0xFD, 0x67,
+0xC0, 0xC4, 0xF0, 0xF6, 0xCA, 0x42, 0xC8, 0x36,
+0xB5, 0xE6, 0xA1, 0x9D, 0xDD, 0x67, 0x01, 0x4A,
+0xB0, 0xC6, 0xA2, 0x36, 0xD1, 0xC7, 0xC2, 0x36,
+0xD2, 0xC7, 0xD0, 0xA7, 0x00, 0xF6, 0xA2, 0x35,
+0xB3, 0xC7, 0xA1, 0x44, 0xC0, 0xC5, 0xD1, 0xA7,
+0xA2, 0x44, 0xC0, 0xC5, 0xD2, 0xA7, 0xA3, 0x44,
+0xC0, 0xC5, 0xB3, 0xA7, 0xA4, 0xC4, 0xFF, 0x6D,
+0xAC, 0xEA, 0x05, 0x4C, 0x30, 0xF0, 0x20, 0x6D,
+0x86, 0xF2, 0x00, 0x4D, 0x63, 0xF4, 0xC4, 0xA5,
+0xC3, 0xEA, 0xD6, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF4, 0x5C, 0x9A, 0x7C, 0x33, 0x4D, 0xE3,
+0x00, 0x6A, 0x21, 0x10, 0x95, 0xE2, 0x43, 0xF4,
+0xB8, 0xA5, 0x3D, 0x67, 0xA0, 0xC3, 0x00, 0xF7,
+0xA6, 0x42, 0xA8, 0x35, 0x91, 0xE5, 0x81, 0x9C,
+0x01, 0x4A, 0x82, 0x35, 0x90, 0xC1, 0xB1, 0xC1,
+0xA2, 0x35, 0xB2, 0xC1, 0xB0, 0xA1, 0x00, 0xF6,
+0x82, 0x34, 0x93, 0xC1, 0x81, 0x43, 0xA0, 0xC4,
+0xB1, 0xA1, 0x82, 0x43, 0xA0, 0xC4, 0xB2, 0xA1,
+0x83, 0x43, 0xA0, 0xC4, 0x93, 0xA1, 0x84, 0xC3,
+0xFF, 0x6C, 0x8C, 0xEA, 0x05, 0x4B, 0x30, 0xF0,
+0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C, 0x63, 0xF4,
+0xA4, 0xA4, 0xA3, 0xEA, 0xD7, 0x61, 0x11, 0x97,
+0x10, 0x91, 0x0F, 0x90, 0x09, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xC3, 0xF3, 0xC9, 0xA3,
+0x20, 0x6D, 0xFF, 0x6A, 0xCC, 0xED, 0x4C, 0xED,
+0x4C, 0xEC, 0x10, 0x2D, 0xC3, 0xF3, 0xD0, 0xA3,
+0x0F, 0x6D, 0xCC, 0xED, 0x8E, 0xED, 0x0A, 0x2D,
+0xC3, 0xF3, 0x84, 0xA3, 0x01, 0x6B, 0x8C, 0xEB,
+0x4C, 0xEB, 0x04, 0x23, 0x00, 0x18, 0x40, 0x44,
+0x00, 0x18, 0xF3, 0x43, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x04, 0x67,
+0x4C, 0xE8, 0x6C, 0x40, 0x4C, 0xEB, 0x03, 0x5B,
+0x01, 0x6C, 0x03, 0x61, 0x0E, 0xEC, 0x01, 0x5C,
+0x98, 0x67, 0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF6,
+0x64, 0xA2, 0x60, 0x6A, 0x6C, 0xEA, 0x40, 0x72,
+0x09, 0x60, 0x20, 0x72, 0x01, 0x61, 0x06, 0x2C,
+0x03, 0x70, 0x04, 0x60, 0x02, 0x70, 0x02, 0x60,
+0x09, 0x70, 0x40, 0x61, 0x09, 0x70, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF6, 0x26, 0xA2,
+0x32, 0x31, 0x06, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x49, 0xF6, 0x50, 0xA2, 0x0F, 0x69, 0x4C, 0xE9,
+0x91, 0x67, 0x00, 0x6D, 0x00, 0x18, 0xDF, 0x13,
+0x91, 0x67, 0x01, 0x6D, 0x08, 0xD2, 0x00, 0x18,
+0xDF, 0x13, 0x9D, 0x67, 0x17, 0x6B, 0x70, 0xC4,
+0x0A, 0x6B, 0x6F, 0xCC, 0x12, 0xC4, 0x30, 0xF0,
+0x20, 0x6B, 0x49, 0xF6, 0x64, 0xA3, 0x0F, 0x6C,
+0x66, 0x33, 0x8C, 0xEB, 0x9D, 0x67, 0x73, 0xC4,
+0x67, 0x44, 0x19, 0x4B, 0x60, 0xA3, 0x74, 0xC4,
+0x08, 0x94, 0x82, 0x33, 0x9D, 0x67, 0x75, 0xC4,
+0x62, 0x33, 0x76, 0xC4, 0x08, 0x94, 0x00, 0xF6,
+0x82, 0x33, 0x9D, 0x67, 0x77, 0xC4, 0x42, 0x33,
+0x58, 0xC4, 0x79, 0xC4, 0x00, 0xF6, 0x42, 0x32,
+0x62, 0x33, 0x7A, 0xC4, 0x5B, 0xC4, 0x04, 0x04,
+0x00, 0x18, 0xBC, 0x27, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x0F, 0x6A, 0x4C, 0xEB, 0xC3, 0xF3,
+0x46, 0xA0, 0x24, 0x67, 0x0F, 0x6C, 0x70, 0x33,
+0x8C, 0xEA, 0x6D, 0xEA, 0x09, 0x6C, 0xC3, 0xF3,
+0x46, 0xC0, 0x00, 0x18, 0x1D, 0x2E, 0x60, 0xA1,
+0xC3, 0xF3, 0x46, 0xA0, 0x0F, 0x6C, 0x72, 0x33,
+0x70, 0x33, 0x8C, 0xEA, 0x6D, 0xEA, 0x09, 0x6C,
+0xC3, 0xF3, 0x46, 0xC0, 0x00, 0x18, 0x1D, 0x2E,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xA4, 0x63, 0xF5, 0xCD, 0xA2, 0x02, 0x6B,
+0x01, 0x6C, 0x6B, 0xEB, 0x8C, 0xED, 0xCC, 0xEB,
+0xAD, 0xEB, 0x63, 0xF5, 0x6D, 0xC2, 0x8C, 0xEB,
+0x02, 0x23, 0x00, 0x18, 0x01, 0x49, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x40, 0xA4, 0x63, 0xF5,
+0xC8, 0xA0, 0x02, 0x6B, 0x01, 0x6D, 0x6B, 0xEB,
+0xAC, 0xEA, 0xCC, 0xEB, 0x4D, 0xEB, 0x63, 0xF5,
+0x68, 0xC0, 0x40, 0xA4, 0x46, 0x32, 0xAC, 0xEA,
+0x44, 0x36, 0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xCD, 0xEA, 0x63, 0xF5, 0x48, 0xC0, 0x60, 0xA4,
+0x6A, 0x33, 0xAC, 0xEB, 0x68, 0x35, 0x05, 0x6B,
+0x6B, 0xEB, 0x4C, 0xEB, 0xAD, 0xEB, 0x63, 0xF5,
+0x68, 0xC0, 0x41, 0xA4, 0x63, 0xF5, 0x49, 0xC0,
+0x42, 0xA4, 0x63, 0xF5, 0x4A, 0xC0, 0x43, 0xA4,
+0x63, 0xF5, 0x4B, 0xC0, 0x44, 0xA4, 0x63, 0xF5,
+0x4C, 0xC0, 0x00, 0x18, 0xEC, 0x1F, 0x63, 0xF5,
+0x8A, 0xA0, 0x63, 0xF5, 0x69, 0xA0, 0xFF, 0xF7,
+0x1F, 0x6D, 0x91, 0xE2, 0xAC, 0xEC, 0x63, 0xF5,
+0xAA, 0xA0, 0x05, 0xD3, 0x63, 0xF5, 0x6C, 0xA0,
+0x04, 0xD5, 0x30, 0xF0, 0x20, 0x6D, 0xE1, 0xF4,
+0xE0, 0x9D, 0x6D, 0xE2, 0x7C, 0x33, 0xFD, 0xE3,
+0xD0, 0x67, 0x00, 0x6D, 0x08, 0xD2, 0xB0, 0x10,
+0x30, 0xF0, 0x20, 0x69, 0xE1, 0xF4, 0x24, 0x99,
+0x30, 0xF0, 0x20, 0x6A, 0x25, 0xE3, 0x20, 0xA1,
+0x83, 0xF5, 0x2C, 0xC0, 0x30, 0xF0, 0x20, 0x69,
+0x61, 0xF0, 0x34, 0x99, 0x25, 0xE3, 0x20, 0xA1,
+0x83, 0xF5, 0x2D, 0xC0, 0x30, 0xF0, 0x20, 0x69,
+0x61, 0xF0, 0x3C, 0x99, 0x09, 0xD3, 0x25, 0xE3,
+0x07, 0xD1, 0xB4, 0x31, 0xF9, 0x65, 0x22, 0x67,
+0x86, 0xF2, 0x00, 0x49, 0x5F, 0x67, 0x45, 0xE1,
+0x83, 0xF5, 0x0E, 0x49, 0x06, 0xD1, 0x07, 0x91,
+0x60, 0xA1, 0x06, 0x92, 0x01, 0x49, 0xEA, 0xE9,
+0x60, 0xC2, 0x01, 0x4A, 0x06, 0xD2, 0x58, 0x67,
+0xF7, 0x2A, 0x20, 0xA7, 0x09, 0x93, 0x83, 0xF5,
+0x34, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0xE1, 0xF4,
+0x28, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0x83, 0xF5,
+0x35, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0xE1, 0xF4,
+0x2C, 0x99, 0x25, 0xE3, 0x20, 0xA9, 0x83, 0xF5,
+0x36, 0xC8, 0x30, 0xF0, 0x20, 0x69, 0xE1, 0xF4,
+0x30, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0x83, 0xF5,
+0x38, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0xE1, 0xF4,
+0x34, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0x83, 0xF5,
+0x39, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0xE1, 0xF4,
+0x38, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0x83, 0xF5,
+0x3A, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0xE1, 0xF4,
+0x3C, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0x83, 0xF5,
+0x3B, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0xC1, 0xF4,
+0x3C, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0x83, 0xF5,
+0x3C, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0x01, 0xF5,
+0x20, 0x99, 0x25, 0xE3, 0x20, 0xA9, 0x83, 0xF5,
+0x3E, 0xC8, 0x30, 0xF0, 0x20, 0x69, 0x01, 0xF5,
+0x24, 0x99, 0x25, 0xE3, 0x20, 0x99, 0xA3, 0xF5,
+0x20, 0xD8, 0x30, 0xF0, 0x20, 0x69, 0x01, 0xF5,
+0x28, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0xA3, 0xF5,
+0x24, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0x01, 0xF5,
+0x2C, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0xA3, 0xF5,
+0x25, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0x01, 0xF5,
+0x30, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0xA3, 0xF5,
+0x26, 0xC0, 0x30, 0xF0, 0x20, 0x69, 0x01, 0xF5,
+0x34, 0x99, 0x25, 0xE3, 0x20, 0xA1, 0xA3, 0xF5,
+0x27, 0xC0, 0xE3, 0xF5, 0x8C, 0xCE, 0x04, 0x92,
+0xA5, 0xE2, 0xE3, 0xF5, 0x2E, 0xC6, 0x83, 0xF5,
+0x3E, 0xA8, 0x03, 0x29, 0x02, 0x69, 0x83, 0xF5,
+0x3E, 0xC8, 0x7F, 0x4F, 0x7F, 0x4B, 0x01, 0x4C,
+0xFF, 0xF7, 0x1F, 0x69, 0x01, 0x4D, 0x01, 0x4F,
+0x01, 0x4B, 0x20, 0x48, 0x2C, 0xEC, 0x18, 0x4E,
+0x05, 0x92, 0xFF, 0x69, 0xAC, 0xE9, 0x43, 0xE9,
+0x5F, 0xF7, 0x0A, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x63, 0xF5, 0x8B, 0xA3,
+0x08, 0x92, 0x00, 0x69, 0x63, 0xF5, 0x96, 0xC3,
+0x89, 0xE2, 0x63, 0xF5, 0x54, 0xCB, 0x18, 0x10,
+0x18, 0x6A, 0x58, 0xE9, 0x01, 0x49, 0x12, 0xEA,
+0x01, 0xE2, 0xE3, 0xF5, 0x8C, 0xA8, 0x9C, 0x32,
+0x04, 0xD2, 0x00, 0x18, 0xD3, 0x49, 0xE3, 0xF5,
+0x56, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x93,
+0x41, 0xF4, 0x40, 0x9A, 0x49, 0xE3, 0x40, 0xAA,
+0xE3, 0xF5, 0x58, 0xC8, 0xFF, 0x6A, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x63, 0xF5, 0x49, 0xA0, 0x43, 0xE9, 0xE0, 0x61,
+0x00, 0x6A, 0x63, 0xF5, 0x4E, 0xC8, 0x63, 0xF5,
+0x57, 0xC0, 0x63, 0xF5, 0x94, 0xA8, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0x40, 0x9A, 0x9C, 0x33,
+0xFF, 0x69, 0x49, 0xE3, 0x40, 0xAA, 0x63, 0xF5,
+0x58, 0xC8, 0x00, 0x18, 0xE6, 0x49, 0x63, 0xF5,
+0x68, 0xA0, 0x63, 0xF5, 0x57, 0xC0, 0x01, 0x6A,
+0x6C, 0xEA, 0x17, 0x22, 0x00, 0x18, 0x01, 0x49,
+0x00, 0x18, 0x92, 0x49, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF7, 0x78, 0x9A, 0x08, 0x6C, 0x40, 0xA3,
+0x2C, 0xEA, 0x8D, 0xEA, 0x2C, 0xEA, 0x40, 0xC3,
+0x63, 0xF5, 0x68, 0xA0, 0x02, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0xF9, 0x4C, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF5, 0x78, 0x9B,
+0x30, 0xF0, 0x20, 0x68, 0x01, 0xF5, 0x1C, 0x98,
+0xE0, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC, 0x0C, 0xEF,
+0x08, 0x5C, 0x4C, 0xED, 0x4C, 0xEE, 0xE0, 0xDB,
+0x46, 0x60, 0xB0, 0x75, 0x2E, 0x61, 0xB2, 0x76,
+0x13, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5,
+0xA0, 0x9A, 0x01, 0x6A, 0x44, 0xEC, 0xC0, 0x9D,
+0x00, 0xF6, 0x40, 0x34, 0xCD, 0xEC, 0x80, 0xDD,
+0xC0, 0x9D, 0x40, 0x34, 0x80, 0x34, 0x8F, 0xEC,
+0xCC, 0xEC, 0x80, 0xDD, 0x80, 0x9B, 0x4E, 0x10,
+0xB1, 0x76, 0x80, 0xF0, 0x13, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0xA0, 0x9A, 0x01, 0x6A,
+0x44, 0xEC, 0xC0, 0x9D, 0x00, 0xF6, 0x40, 0x34,
+0xCD, 0xEC, 0x80, 0xDD, 0xC0, 0x9D, 0x40, 0x34,
+0x80, 0x34, 0x8F, 0xEC, 0xCC, 0xEC, 0x80, 0xDD,
+0x80, 0x9B, 0x4F, 0xEA, 0x8C, 0xEA, 0x40, 0xDB,
+0x7B, 0x10, 0xA0, 0x75, 0x7D, 0x61, 0xA1, 0x76,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5,
+0x40, 0x9A, 0x01, 0x6B, 0x64, 0xEC, 0xA0, 0x9A,
+0x51, 0x10, 0xA2, 0x76, 0x6F, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0x40, 0x9A, 0x01, 0x6B,
+0x64, 0xEC, 0xA0, 0x9A, 0x5A, 0x10, 0xE8, 0x44,
+0x4C, 0xEF, 0x08, 0x5F, 0xE0, 0x6A, 0x65, 0x60,
+0xB0, 0x75, 0x35, 0x61, 0xB2, 0x76, 0x18, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x44, 0x9A,
+0x01, 0x6E, 0xA6, 0x67, 0x00, 0x9A, 0xA4, 0xEF,
+0xE5, 0x67, 0x00, 0xF6, 0xA0, 0x35, 0x0D, 0xED,
+0xA0, 0xDA, 0xA0, 0x9A, 0xE0, 0x37, 0xE0, 0x37,
+0xEF, 0xEF, 0xAC, 0xEF, 0xE0, 0xDA, 0x40, 0x9B,
+0xC4, 0xEC, 0x86, 0x67, 0x4D, 0xEC, 0x19, 0x10,
+0xB1, 0x76, 0x44, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x44, 0x9A, 0x01, 0x6E, 0xA6, 0x67,
+0x00, 0x9A, 0xA4, 0xEF, 0xE5, 0x67, 0x00, 0xF6,
+0xA0, 0x35, 0x0D, 0xED, 0xA0, 0xDA, 0xA0, 0x9A,
+0xE0, 0x37, 0xE0, 0x37, 0xEF, 0xEF, 0xAC, 0xEF,
+0xE0, 0xDA, 0x40, 0x9B, 0xC4, 0xEC, 0xCF, 0xEC,
+0x4C, 0xEC, 0x80, 0xDB, 0x29, 0x10, 0xA0, 0x75,
+0x2B, 0x61, 0xA1, 0x76, 0x11, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0x44, 0x9A, 0x01, 0x6B,
+0x64, 0xEF, 0xA0, 0x9A, 0x00, 0xF6, 0x60, 0x34,
+0x8F, 0xEC, 0xAC, 0xEC, 0x80, 0xDA, 0x80, 0x9A,
+0x60, 0x33, 0x60, 0x33, 0x8D, 0xEB, 0x13, 0x10,
+0xA2, 0x76, 0x14, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x44, 0x9A, 0x01, 0x6B, 0x64, 0xEF,
+0xA0, 0x9A, 0x00, 0xF6, 0x60, 0x34, 0x8F, 0xEC,
+0xAC, 0xEC, 0x80, 0xDA, 0x80, 0x9A, 0x60, 0x33,
+0x60, 0x33, 0x6F, 0xEB, 0x8C, 0xEB, 0x60, 0xDA,
+0xF0, 0x6A, 0x03, 0x10, 0xE2, 0x6A, 0x01, 0x10,
+0xE1, 0x6A, 0x01, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0xFF, 0x6B, 0x6C, 0xEC, 0x08, 0x5C, 0xFF, 0x63,
+0x18, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5,
+0x48, 0x9A, 0x01, 0x6D, 0x40, 0xA2, 0x6C, 0xEA,
+0x47, 0xEC, 0xAC, 0xEA, 0x37, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0x4C, 0x9A, 0x40, 0xA2,
+0x6C, 0xEA, 0x47, 0xEC, 0xAC, 0xEA, 0x30, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x40, 0x9A,
+0x1C, 0x10, 0xF8, 0x4C, 0x6C, 0xEC, 0x08, 0x5C,
+0xE0, 0x6A, 0x27, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x50, 0x9A, 0x01, 0x6D, 0x40, 0xA2,
+0x6C, 0xEA, 0x47, 0xEC, 0xAC, 0xEA, 0x1A, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x54, 0x9A,
+0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC, 0xAC, 0xEA,
+0x13, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5,
+0x44, 0x9A, 0x40, 0xA2, 0xA4, 0xEC, 0x85, 0x67,
+0x6C, 0xEC, 0x4C, 0xEC, 0x5D, 0x67, 0x80, 0xC2,
+0x40, 0xA2, 0x4C, 0xEB, 0x6B, 0xEA, 0xC0, 0xF7,
+0x42, 0x32, 0x03, 0x10, 0xE4, 0x6A, 0x01, 0x10,
+0xE6, 0x6A, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x08, 0x5C, 0x6C, 0xED,
+0x20, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5,
+0x48, 0x9A, 0x01, 0x6E, 0x40, 0xA2, 0x6C, 0xEA,
+0x47, 0xEC, 0xCC, 0xEA, 0x48, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0x4C, 0x9A, 0xC4, 0xEC,
+0x86, 0x67, 0x40, 0xA2, 0x6C, 0xEA, 0xCC, 0xEA,
+0xCE, 0xEA, 0x3B, 0x2A, 0x05, 0x25, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0xB8, 0x9A, 0x24, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x58, 0x9A,
+0x29, 0x10, 0xF8, 0x4C, 0x6C, 0xEC, 0x08, 0x5C,
+0xE0, 0x6A, 0x2E, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x50, 0x9A, 0x01, 0x6E, 0x40, 0xA2,
+0x6C, 0xEA, 0x47, 0xEC, 0xCC, 0xEA, 0x23, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x54, 0x9A,
+0xC4, 0xEC, 0x86, 0x67, 0x40, 0xA2, 0x6C, 0xEA,
+0xCC, 0xEA, 0xCE, 0xEA, 0x16, 0x2A, 0x0A, 0x25,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0xBC, 0x9A,
+0x40, 0xA5, 0x6C, 0xEA, 0x8D, 0xEA, 0x6C, 0xEA,
+0x40, 0xC5, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x5C, 0x9A, 0xA0, 0xA2, 0x8F, 0xEC,
+0x6C, 0xEC, 0xAC, 0xEC, 0x80, 0xC2, 0xF0, 0x6A,
+0x20, 0xE8, 0xE5, 0x6A, 0x20, 0xE8, 0xE4, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x08, 0x5C, 0x0F, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x48, 0x9A, 0x01, 0x6D, 0x40, 0xA2,
+0x6C, 0xEA, 0x47, 0xEC, 0xAC, 0xEA, 0x1F, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x4C, 0x9A,
+0x13, 0x10, 0xF8, 0x4C, 0x6C, 0xEC, 0x08, 0x5C,
+0xE0, 0x6A, 0x16, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x50, 0x9A, 0x01, 0x6D, 0x40, 0xA2,
+0x6C, 0xEA, 0x47, 0xEC, 0xAC, 0xEA, 0x0B, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x54, 0x9A,
+0x40, 0xA2, 0x4C, 0xEB, 0x67, 0xEC, 0x45, 0x67,
+0x6E, 0xEA, 0xAC, 0xEA, 0x20, 0xE8, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x08, 0x5C, 0x1A, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x48, 0x9A, 0x01, 0x6E, 0x40, 0xA2,
+0x6C, 0xEA, 0x47, 0xEC, 0xCC, 0xEA, 0x35, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5, 0x4C, 0x9A,
+0xC4, 0xEC, 0x86, 0x67, 0xA0, 0xA2, 0x6C, 0xED,
+0xCC, 0xED, 0xCE, 0xED, 0x2A, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0x58, 0x9A, 0x1E, 0x10,
+0xF8, 0x4C, 0x6C, 0xEC, 0x08, 0x5C, 0xE0, 0x6A,
+0x21, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF5,
+0x50, 0x9A, 0x01, 0x6E, 0x40, 0xA2, 0x6C, 0xEA,
+0x47, 0xEC, 0xCC, 0xEA, 0x16, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF5, 0x54, 0x9A, 0xC4, 0xEC,
+0x86, 0x67, 0xA0, 0xA2, 0x6C, 0xED, 0xCC, 0xED,
+0xCE, 0xED, 0x0B, 0x2D, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF5, 0x5C, 0x9A, 0x40, 0xA2, 0x4C, 0xEB,
+0x8C, 0xEB, 0x6E, 0xEC, 0x01, 0x5C, 0x58, 0x67,
+0x20, 0xE8, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x04, 0x67, 0x2C, 0xE8, 0x90, 0x67,
+0xA0, 0x6D, 0xA2, 0x6E, 0x00, 0x18, 0x25, 0x2F,
+0x90, 0x67, 0x00, 0x18, 0x88, 0x2F, 0x7D, 0x67,
+0x50, 0xC3, 0x50, 0xA3, 0x09, 0x97, 0x07, 0x90,
+0x2C, 0xEA, 0x08, 0x91, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x68, 0x24, 0x67, 0x0C, 0xE9, 0x91, 0x67,
+0xAC, 0xE8, 0xA1, 0x6E, 0xA0, 0x6D, 0x00, 0x18,
+0x25, 0x2F, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0xAE, 0x2F, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF5, 0x78, 0x9A,
+0x30, 0xF0, 0x20, 0x6D, 0x01, 0xF5, 0xBC, 0x9D,
+0x40, 0x9B, 0xA2, 0x6E, 0xAC, 0xEA, 0x40, 0xDB,
+0xFF, 0x6A, 0x4C, 0xEC, 0xA0, 0x6D, 0x00, 0x18,
+0x25, 0x2F, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0xB0, 0x6D, 0xB2, 0x6E, 0x00, 0x18, 0x25, 0x2F,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0xB0, 0x6D, 0xB1, 0x6E, 0x00, 0x18, 0x25, 0x2F,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x04, 0x67, 0x4C, 0xE8, 0xAC, 0xEA, 0xA4, 0x72,
+0x0C, 0x61, 0x90, 0x67, 0x00, 0x18, 0xDB, 0x2F,
+0x01, 0x72, 0x04, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x2D, 0x30, 0x1F, 0x10, 0x90, 0x67, 0x00, 0x6D,
+0x0D, 0x10, 0xA5, 0x72, 0x11, 0x61, 0x90, 0x67,
+0x00, 0x18, 0xDB, 0x2F, 0x01, 0x72, 0x04, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x2D, 0x30, 0x18, 0x10,
+0x90, 0x67, 0x01, 0x6D, 0x00, 0x18, 0x22, 0x30,
+0x90, 0x67, 0x00, 0x18, 0x2D, 0x30, 0x14, 0x10,
+0x90, 0x67, 0x00, 0x18, 0xF3, 0x2F, 0x01, 0x72,
+0x07, 0x61, 0x90, 0x67, 0x01, 0x6D, 0x00, 0x18,
+0x22, 0x30, 0x90, 0x67, 0x00, 0x6D, 0x06, 0x10,
+0x90, 0x67, 0x00, 0x6D, 0x00, 0x18, 0x22, 0x30,
+0x90, 0x67, 0x01, 0x6D, 0x00, 0x18, 0x22, 0x30,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x66, 0xF3, 0x00, 0x4C, 0x07, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0x30, 0xF0, 0x20, 0x6D,
+0x86, 0xF2, 0x00, 0x4D, 0xE0, 0xF0, 0x80, 0xA5,
+0x01, 0x6A, 0xC2, 0x67, 0x8C, 0xEE, 0xFF, 0x6B,
+0x37, 0x26, 0x02, 0x6E, 0x8C, 0xEE, 0x6C, 0xEE,
+0x0F, 0x26, 0x04, 0x6E, 0x8C, 0xEE, 0x6C, 0xEE,
+0x22, 0x26, 0x08, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA,
+0x16, 0x2A, 0xE0, 0xF0, 0x41, 0xA5, 0x7F, 0x6C,
+0x00, 0x6D, 0x4C, 0xEC, 0x6C, 0xEC, 0x22, 0x10,
+0x04, 0x6E, 0x8C, 0xEE, 0x6C, 0xEE, 0x13, 0x26,
+0x08, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA, 0x07, 0x22,
+0xE0, 0xF0, 0x41, 0xA5, 0x7F, 0x6C, 0x01, 0x6D,
+0x4C, 0xEC, 0x6C, 0xEC, 0x13, 0x10, 0xE0, 0xF0,
+0x41, 0xA5, 0x7F, 0x6C, 0x4C, 0xEC, 0x6C, 0xEC,
+0x00, 0x18, 0x2D, 0x30, 0x0D, 0x10, 0xE0, 0xF0,
+0xC1, 0xA5, 0xE0, 0xF0, 0xA0, 0xA5, 0x7F, 0x6C,
+0xCC, 0xEC, 0xA6, 0x35, 0x01, 0x6E, 0xCE, 0xED,
+0x6C, 0xEC, 0x4C, 0xED, 0x00, 0x18, 0x22, 0x30,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6C,
+0x2C, 0xF6, 0x1E, 0x4C, 0x00, 0x6D, 0x06, 0x6E,
+0x00, 0x18, 0xB4, 0x20, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x01, 0x72, 0xFF, 0xF7,
+0x1F, 0x6C, 0xAC, 0xEC, 0x03, 0x61, 0x00, 0x18,
+0x8D, 0x20, 0x02, 0x10, 0x00, 0x18, 0x95, 0x20,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x4C, 0xEE, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x60, 0xA2, 0xFF, 0xF7, 0x1F, 0x69, 0x04, 0xD4,
+0xAC, 0xE9, 0x05, 0xD6, 0x0B, 0x23, 0xC6, 0xF3,
+0x61, 0xA2, 0x04, 0x23, 0xA6, 0xF3, 0x9E, 0xA2,
+0xA5, 0x6D, 0x07, 0x10, 0xA6, 0xF3, 0x9E, 0xA2,
+0xA4, 0x6D, 0x03, 0x10, 0xA6, 0xF3, 0x9E, 0xA2,
+0xA3, 0x6D, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x00, 0x18, 0x44, 0x30, 0xC6, 0xF3,
+0x42, 0xA0, 0x7D, 0x22, 0x04, 0x94, 0xB1, 0x67,
+0x00, 0x18, 0x93, 0x30, 0xC6, 0xF3, 0x40, 0xA0,
+0x0B, 0x22, 0xC6, 0xF3, 0x41, 0xA0, 0x04, 0x22,
+0xA6, 0xF3, 0x9E, 0xA0, 0xA5, 0x6D, 0x07, 0x10,
+0xA6, 0xF3, 0x9E, 0xA0, 0xA4, 0x6D, 0x03, 0x10,
+0xA6, 0xF3, 0x9E, 0xA0, 0xA3, 0x6D, 0x00, 0x18,
+0x44, 0x30, 0x30, 0xF0, 0x20, 0x6A, 0x4C, 0xF6,
+0x43, 0xA2, 0x01, 0x68, 0x5D, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF5, 0x40, 0x9A, 0x60, 0xA2,
+0x10, 0x6A, 0x6C, 0xEA, 0x58, 0x2A, 0x04, 0x94,
+0xB1, 0x67, 0x00, 0x18, 0x93, 0x30, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x60, 0xA2, 0x0B, 0x23, 0xC6, 0xF3, 0x61, 0xA2,
+0x04, 0x23, 0xA6, 0xF3, 0x9E, 0xA2, 0xA5, 0x6D,
+0x07, 0x10, 0xA6, 0xF3, 0x9E, 0xA2, 0xA4, 0x6D,
+0x03, 0x10, 0xA6, 0xF3, 0x9E, 0xA2, 0xA3, 0x6D,
+0x00, 0x18, 0x44, 0x30, 0xDC, 0x17, 0x04, 0x94,
+0xB1, 0x67, 0x00, 0x18, 0x93, 0x30, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x60, 0xA2, 0x0B, 0x23, 0xC6, 0xF3, 0x61, 0xA2,
+0x04, 0x23, 0xA6, 0xF3, 0x9E, 0xA2, 0xA5, 0x6D,
+0x07, 0x10, 0xA6, 0xF3, 0x9E, 0xA2, 0xA4, 0x6D,
+0x03, 0x10, 0xA6, 0xF3, 0x9E, 0xA2, 0xA3, 0x6D,
+0x00, 0x18, 0x44, 0x30, 0x04, 0x94, 0xB1, 0x67,
+0x00, 0x18, 0x93, 0x30, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x60, 0xA2,
+0x0B, 0x23, 0xC6, 0xF3, 0x61, 0xA2, 0x04, 0x23,
+0xA6, 0xF3, 0x9E, 0xA2, 0xA5, 0x6D, 0x07, 0x10,
+0xA6, 0xF3, 0x9E, 0xA2, 0xA4, 0x6D, 0x03, 0x10,
+0xA6, 0xF3, 0x9E, 0xA2, 0xA3, 0x6D, 0x00, 0x18,
+0x44, 0x30, 0x01, 0x48, 0xFF, 0x6A, 0x4C, 0xE8,
+0x05, 0x92, 0x43, 0xE8, 0xC4, 0x61, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFF, 0xF7, 0x1F, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x8C, 0xEA, 0x21, 0xF3, 0x7C, 0x9B, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF5, 0x84, 0x9C, 0xCC, 0xEB,
+0x40, 0xF6, 0xA0, 0x35, 0x8D, 0xEB, 0x1F, 0xF7,
+0x00, 0x6C, 0x4C, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0xAD, 0xEB, 0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF0, 0x98, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0, 0x9C, 0x9C,
+0x89, 0xE2, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x1F, 0xF7,
+0x00, 0x6C, 0x4C, 0xEC, 0xFF, 0x6B, 0x02, 0xF0,
+0x00, 0x74, 0xAC, 0xEB, 0x01, 0x60, 0x05, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0, 0x98, 0x9C,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0x9C, 0x9C, 0x91, 0xE2, 0x00, 0x6D, 0xA0, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF3, 0x9C, 0x9C,
+0xD4, 0x36, 0x40, 0xF6, 0x60, 0x33, 0x8C, 0xEE,
+0x6D, 0xEE, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF5,
+0x64, 0x9B, 0x6D, 0xEE, 0x1F, 0xF7, 0x00, 0x6B,
+0x4C, 0xEB, 0x02, 0xF0, 0x00, 0x73, 0x01, 0x60,
+0x05, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x78, 0x9B, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x7C, 0x9B, 0x69, 0xE2, 0xC0, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x0F, 0xF5, 0x00, 0x6B,
+0x78, 0xEE, 0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF3, 0x9C, 0x9C,
+0x40, 0xF6, 0xA0, 0x35, 0x12, 0xEB, 0x8C, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF5, 0x84, 0x9C,
+0xAD, 0xEB, 0x8D, 0xEB, 0x1F, 0xF7, 0x00, 0x6C,
+0x4C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0x98, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0x9C, 0x9C, 0x89, 0xE2, 0x60, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x40, 0x9A, 0x40, 0x9A, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x05, 0x5C, 0x4C, 0xED,
+0x00, 0x6A, 0x4B, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0x40, 0xF6, 0x04, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x01, 0x6A, 0xFF, 0x6B,
+0x44, 0xED, 0x6C, 0xEA, 0xE0, 0xF3, 0x01, 0x4B,
+0x0C, 0x10, 0x01, 0x6A, 0x05, 0x10, 0x04, 0x6A,
+0x03, 0x10, 0x10, 0x6A, 0x01, 0x10, 0x40, 0x6A,
+0xFF, 0x6B, 0x44, 0xED, 0x6C, 0xEA, 0xE0, 0xF3,
+0x04, 0x4B, 0x1F, 0xF7, 0x00, 0x6C, 0x6C, 0xEC,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0x98, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0x9C, 0x9C, 0x8D, 0xE3, 0x80, 0xA3,
+0xFF, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x01, 0x6A,
+0x1C, 0x2B, 0x0E, 0x2D, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x5C, 0x9A, 0x01, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A,
+0x02, 0x6B, 0x60, 0xC2, 0x00, 0x6A, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x5C, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x58, 0x9A, 0x04, 0x6B, 0x60, 0xC2,
+0x00, 0x6A, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x00, 0x68, 0xFF, 0x6A, 0x0C, 0xEA, 0x2E, 0xEA,
+0x10, 0x2A, 0x91, 0x67, 0x00, 0x18, 0x96, 0x3F,
+0x91, 0x67, 0x00, 0x18, 0x85, 0x3F, 0x91, 0x67,
+0x00, 0x18, 0x9D, 0x3F, 0x91, 0x67, 0x00, 0x18,
+0x67, 0x3F, 0x91, 0x67, 0x00, 0x18, 0x5D, 0x3F,
+0x0F, 0x10, 0x90, 0x67, 0x00, 0x18, 0xB5, 0x3F,
+0x90, 0x67, 0x00, 0x18, 0xA4, 0x3F, 0x90, 0x67,
+0x00, 0x18, 0xBC, 0x3F, 0x90, 0x67, 0x00, 0x18,
+0x7B, 0x3F, 0x90, 0x67, 0x00, 0x18, 0x71, 0x3F,
+0x01, 0x48, 0x05, 0x70, 0xDA, 0x61, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0x6A, 0x4C, 0xED, 0x4C, 0xEE, 0x04, 0x00,
+0xFF, 0xF7, 0x1F, 0x69, 0x8C, 0xE9, 0x09, 0xD5,
+0x08, 0xD6, 0x90, 0x67, 0x00, 0x6D, 0x04, 0x6E,
+0x11, 0xD7, 0x00, 0x18, 0xB4, 0x20, 0x05, 0x04,
+0x00, 0x6D, 0x04, 0x6E, 0x00, 0x18, 0xB4, 0x20,
+0x11, 0x95, 0x90, 0x67, 0x04, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0x12, 0x95, 0x06, 0x04, 0x04, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0x00, 0xF1, 0x00, 0x59,
+0x08, 0x61, 0x0E, 0xF0, 0x40, 0x41, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x00, 0xF1, 0x00, 0x5A,
+0x3D, 0x60, 0x09, 0x92, 0x04, 0x72, 0x12, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0xFF, 0x6B, 0x49, 0xE1, 0x40, 0xA2, 0x4C, 0xEB,
+0x08, 0x92, 0x63, 0x22, 0x06, 0x94, 0x8F, 0xEA,
+0x6C, 0xEA, 0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA,
+0x04, 0xD2, 0x5B, 0x10, 0x09, 0x92, 0x05, 0x72,
+0x14, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0xFF, 0xF7, 0x1F, 0x6B, 0x49, 0xE1,
+0x40, 0xAA, 0x4C, 0xEB, 0x08, 0x92, 0x80, 0xF0,
+0x02, 0x22, 0x06, 0x94, 0x8F, 0xEA, 0x6C, 0xEA,
+0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA, 0x04, 0xD2,
+0x7A, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0x49, 0xE1, 0x60, 0x9A, 0x08, 0x92,
+0xA0, 0xF0, 0x01, 0x22, 0x06, 0x94, 0x8F, 0xEA,
+0x6C, 0xEA, 0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA,
+0x04, 0xD2, 0x99, 0x10, 0x01, 0xF0, 0x00, 0x59,
+0x09, 0x61, 0x0D, 0xF7, 0x40, 0x41, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x00, 0xF7, 0x00, 0x5A,
+0x80, 0xF0, 0x1A, 0x60, 0x09, 0x92, 0x04, 0x72,
+0x32, 0x61, 0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x5C, 0x9A, 0x49, 0xE1, 0x60, 0xA2, 0xFF, 0x6A,
+0x6C, 0xEA, 0x08, 0x93, 0x07, 0x23, 0x06, 0x94,
+0x8F, 0xEB, 0x4C, 0xEB, 0x04, 0x92, 0x8C, 0xEA,
+0x4D, 0xEB, 0x04, 0xD3, 0x1F, 0xF7, 0x00, 0x6A,
+0x2C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x5C, 0x9A, 0x7D, 0x67, 0x45, 0xE1,
+0x50, 0xA3, 0x40, 0xC1, 0x7D, 0x10, 0x09, 0x92,
+0x05, 0x72, 0x33, 0x61, 0x1F, 0xF7, 0x00, 0x6A,
+0x2C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x5C, 0x9A, 0x49, 0xE1, 0x60, 0xAA,
+0xFF, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA, 0x08, 0x93,
+0x07, 0x23, 0x06, 0x94, 0x8F, 0xEB, 0x4C, 0xEB,
+0x04, 0x92, 0x8C, 0xEA, 0x4D, 0xEB, 0x04, 0xD3,
+0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x7D, 0x67, 0x45, 0xE1, 0x48, 0xAB, 0x40, 0xC9,
+0x47, 0x10, 0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x5C, 0x9A, 0x49, 0xE1, 0x60, 0x9A, 0x08, 0x92,
+0x07, 0x22, 0x06, 0x94, 0x8F, 0xEA, 0x6C, 0xEA,
+0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA, 0x04, 0xD2,
+0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x45, 0xE1, 0x04, 0x92, 0x40, 0xD9, 0x18, 0x10,
+0xFF, 0xF7, 0x1C, 0x68, 0x2C, 0xE8, 0x01, 0x6D,
+0x90, 0x67, 0xAB, 0xED, 0x00, 0x18, 0x78, 0x36,
+0x08, 0x93, 0x05, 0xD2, 0x07, 0x23, 0x06, 0x94,
+0x8F, 0xEB, 0x4C, 0xEB, 0x04, 0x92, 0x8C, 0xEA,
+0x4D, 0xEB, 0x04, 0xD3, 0x04, 0x96, 0x01, 0x6D,
+0x90, 0x67, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x41, 0x9C, 0x61, 0xA4,
+0x01, 0xAC, 0x06, 0xD2, 0x42, 0x9C, 0xFF, 0x73,
+0x07, 0xD2, 0x00, 0x6A, 0x55, 0x60, 0x7F, 0x6D,
+0x6C, 0xED, 0x4C, 0x45, 0xFF, 0x6B, 0x6C, 0xEA,
+0x0E, 0x5A, 0x08, 0x60, 0x30, 0xF0, 0x20, 0x6B,
+0x48, 0x32, 0x40, 0xF6, 0x18, 0x4B, 0x4D, 0xE3,
+0x40, 0x9B, 0x00, 0xEA, 0x03, 0x6A, 0x44, 0x10,
+0x61, 0xA4, 0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xFF, 0x6E, 0x07, 0x03, 0x90, 0x67, 0x4C, 0xEE,
+0x06, 0x07, 0x04, 0xD3, 0x00, 0x18, 0x7A, 0x31,
+0x1F, 0x10, 0x81, 0xA4, 0x80, 0x6A, 0xFF, 0x69,
+0x64, 0x67, 0x4C, 0xEB, 0x0C, 0xE9, 0x02, 0x32,
+0x01, 0x6E, 0x82, 0x67, 0xB1, 0x67, 0xCB, 0xEE,
+0x08, 0xD3, 0x09, 0xD2, 0x00, 0x18, 0x4F, 0x36,
+0x08, 0x93, 0x07, 0x23, 0x07, 0x94, 0x8F, 0xEB,
+0x4C, 0xEB, 0x06, 0x92, 0x8C, 0xEA, 0x4D, 0xEB,
+0x06, 0xD3, 0x09, 0x94, 0x06, 0x97, 0x01, 0x6E,
+0xB1, 0x67, 0xCB, 0xEE, 0x00, 0x18, 0xC5, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x86, 0xF2, 0x64, 0x9A, 0x06, 0x94, 0x61, 0xE0,
+0x86, 0xF2, 0x68, 0x9A, 0x86, 0xF2, 0x04, 0xDA,
+0x6D, 0xE4, 0x86, 0xF2, 0x68, 0xDA, 0x07, 0x10,
+0x90, 0x67, 0x00, 0x18, 0x95, 0x20, 0x03, 0x10,
+0x90, 0x67, 0x00, 0x18, 0x8D, 0x20, 0x01, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF5, 0x90, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA0, 0x9C, 0x52, 0x9B,
+0xAC, 0xEA, 0x53, 0xDB, 0x40, 0xDC, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0xD1, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF4, 0x2C, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF5, 0x1C, 0x4A, 0x40, 0x9A,
+0x60, 0x99, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5, 0x44, 0x9A,
+0x61, 0xF5, 0x0C, 0x4C, 0x80, 0x9C, 0x00, 0x9A,
+0x1A, 0x65, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0x9C,
+0x61, 0xF5, 0x14, 0x4A, 0x40, 0x9A, 0x01, 0xD4,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0x9A, 0x86, 0xF2,
+0xE0, 0x9C, 0x00, 0xD2, 0x44, 0x67, 0x86, 0xF2,
+0x00, 0x4A, 0xC1, 0x9A, 0x83, 0x9A, 0x6C, 0xEF,
+0xAC, 0xEE, 0x01, 0x93, 0xA2, 0x9A, 0xE8, 0xDA,
+0x6C, 0xEC, 0x0C, 0xED, 0x64, 0x9A, 0x00, 0x90,
+0x8B, 0xDA, 0xC9, 0xDA, 0x0C, 0xEB, 0xAA, 0xDA,
+0x6C, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5,
+0x1C, 0x4A, 0x40, 0x9A, 0xE0, 0xD9, 0x18, 0x67,
+0xC0, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF5,
+0x0C, 0x4A, 0x40, 0x9A, 0xA0, 0xD8, 0x80, 0xDA,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF5, 0x14, 0x4C,
+0x80, 0x9C, 0x60, 0xDC, 0x05, 0x91, 0x04, 0x90,
+0x03, 0x63, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD1,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x14, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4,
+0xF4, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF5,
+0xC4, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x80, 0x98, 0xB4, 0x9A, 0x60, 0x9F,
+0x20, 0x9E, 0x8C, 0xED, 0x95, 0x9A, 0xB7, 0xDA,
+0x6C, 0xEC, 0x76, 0x9A, 0x98, 0xDA, 0x2C, 0xEB,
+0x79, 0xDA, 0xA0, 0xD8, 0x80, 0xDF, 0x60, 0xDE,
+0x01, 0x91, 0x00, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0x06, 0x74, 0x0A, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF5, 0x9C, 0x9B, 0x01, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0x8C, 0xA2,
+0x04, 0x6B, 0x8D, 0xEB, 0xE3, 0xF4, 0x6C, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF5, 0x40, 0x9A, 0x40, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF5, 0x44, 0x9A, 0x40, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF5, 0x48, 0x9A,
+0x40, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4,
+0x48, 0x9A, 0x40, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF5, 0x4C, 0x9A, 0x40, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF5, 0x50, 0x9A, 0x40, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF5, 0x54, 0x9A,
+0x40, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x5C, 0x9A, 0x40, 0xA2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x95, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x0A, 0x23, 0xA3, 0xF3, 0x84, 0xA2, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x03, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEB, 0xA3, 0xF3, 0x64, 0xC2, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x95, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x0A, 0x23, 0xA3, 0xF3, 0x84, 0xA2, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x03, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEB, 0xA3, 0xF3, 0x64, 0xC2, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x95, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x0A, 0x23, 0xA3, 0xF3, 0x84, 0xA2, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x03, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEB, 0xA3, 0xF3, 0x64, 0xC2, 0x20, 0xE8,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF7, 0x88, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x07, 0x6D, 0xB8, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x01, 0x6E, 0x12, 0xEC, 0x71, 0xE4, 0x00, 0xF1,
+0xAA, 0xA4, 0xCC, 0xED, 0x1D, 0x25, 0x00, 0xF1,
+0xAB, 0xA4, 0x02, 0xF6, 0x7C, 0x9B, 0x00, 0xF1,
+0x8A, 0xA4, 0x75, 0xE5, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF4, 0x60, 0x9B, 0xBC, 0x35, 0x21, 0x4D,
+0x75, 0xE5, 0xE0, 0xA5, 0x9E, 0x33, 0x9A, 0x34,
+0xCC, 0xEC, 0x78, 0x33, 0x9C, 0x34, 0x4C, 0xEF,
+0x8D, 0xEB, 0xED, 0xEB, 0x00, 0xF6, 0x60, 0x33,
+0x00, 0xF6, 0x63, 0x33, 0x4C, 0xEB, 0x60, 0xC5,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF7, 0x68, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x61, 0x4A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF7, 0x68, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x6A, 0x40, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x6A, 0x40, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x63, 0xF5, 0x88, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x04, 0x23, 0x63, 0xF5, 0x9B, 0xA2, 0x00, 0x18,
+0x87, 0x4C, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x63, 0xF5, 0x88, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x04, 0x23, 0x63, 0xF5,
+0x9A, 0xA2, 0x00, 0x18, 0x87, 0x4C, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x30, 0xF0, 0x20, 0x6D, 0xA1, 0xF5, 0xB8, 0x9D,
+0xA0, 0xF0, 0xD4, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC,
+0xCC, 0xED, 0x06, 0x2D, 0xA3, 0xF3, 0xA8, 0xA3,
+0x01, 0x6B, 0xAC, 0xEB, 0x4C, 0xEB, 0x18, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0xB5, 0xA2, 0x01, 0x6B, 0x6C, 0xED,
+0x06, 0x2D, 0xA3, 0xF3, 0x48, 0xA2, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x07, 0x22, 0x00, 0x18,
+0x29, 0x50, 0x01, 0x72, 0x05, 0x61, 0x00, 0x18,
+0x27, 0x51, 0x02, 0x10, 0x00, 0x18, 0x4C, 0x1A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x86, 0xF2, 0x00, 0x48, 0x04, 0xD4, 0xC0, 0xF0,
+0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13, 0x01, 0x72,
+0x21, 0x61, 0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x1B, 0x22, 0xE3, 0xF4,
+0x6C, 0xA0, 0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x40, 0xF1, 0x62, 0xA0, 0xE3, 0xF4, 0x4C, 0xC0,
+0x01, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x04, 0x22,
+0x40, 0xF1, 0x43, 0xA0, 0x23, 0xF5, 0x52, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7, 0x4C, 0xA2,
+0x07, 0x6B, 0x6C, 0xEA, 0x03, 0x2A, 0x04, 0x94,
+0x00, 0x18, 0x68, 0x19, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x86, 0xF2, 0x00, 0x48, 0x04, 0xD4, 0xC0, 0xF0,
+0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13, 0x01, 0x72,
+0x3A, 0x61, 0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x34, 0x22, 0x40, 0xF1,
+0x62, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x04, 0x22, 0x40, 0xF1, 0x43, 0xA0, 0x23, 0xF5,
+0x52, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7,
+0x57, 0xA2, 0x01, 0x6B, 0x6E, 0xEA, 0x0B, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0, 0x68, 0x9B,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x54, 0x9A, 0x02, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4,
+0x88, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x6C, 0xEC,
+0xE3, 0xF4, 0x88, 0xC2, 0xE3, 0xF4, 0x8C, 0xA2,
+0x8C, 0xEB, 0xE3, 0xF4, 0x6C, 0xC2, 0xE3, 0xF4,
+0x4C, 0xA2, 0x07, 0x6B, 0x6C, 0xEA, 0x03, 0x2A,
+0x04, 0x94, 0x00, 0x18, 0x68, 0x19, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4, 0xAC, 0xA2,
+0x05, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB, 0xE3, 0xF4,
+0x6C, 0xC2, 0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18,
+0x68, 0x19, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x86, 0xF2, 0x00, 0x48, 0x04, 0xD4, 0xC0, 0xF0,
+0x9A, 0xA0, 0x00, 0x18, 0xAA, 0x13, 0x01, 0x72,
+0x31, 0x61, 0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x2B, 0x22, 0x40, 0xF1,
+0x62, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x04, 0x22, 0x40, 0xF1, 0x43, 0xA0, 0x23, 0xF5,
+0x52, 0xC0, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA0, 0xF0, 0x97, 0xA3, 0x10, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA,
+0x20, 0x72, 0x09, 0x60, 0xA0, 0xF0, 0x76, 0xA3,
+0x7F, 0x6A, 0x6C, 0xEA, 0x01, 0x72, 0x03, 0x61,
+0x00, 0x18, 0x37, 0x1D, 0x0B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF3, 0x76, 0xA2, 0x7F, 0x6A,
+0x6C, 0xEA, 0x02, 0x72, 0x03, 0x60, 0x04, 0x94,
+0x00, 0x18, 0x55, 0x1A, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF3, 0x63, 0xA2, 0x07, 0x6A, 0x6C, 0xEA,
+0x04, 0x93, 0x6E, 0xEA, 0x02, 0x2A, 0x00, 0x18,
+0x3A, 0x23, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xC0, 0xF0, 0x9A, 0xA0, 0x00, 0x18,
+0xAA, 0x13, 0x01, 0x72, 0x2B, 0x61, 0xA0, 0xF0,
+0x76, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA, 0x26, 0x22,
+0x40, 0xF1, 0x62, 0xA0, 0x01, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x04, 0x22, 0x40, 0xF1,
+0x43, 0xA0, 0x23, 0xF5, 0x52, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4,
+0x77, 0xA2, 0x01, 0x6C, 0x8E, 0xEB, 0x12, 0x2B,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF0, 0x88, 0x9C,
+0x00, 0x6D, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x74, 0x9B, 0x02, 0x6C, 0x80, 0xC3,
+0xA0, 0xF0, 0xDE, 0xA2, 0xFF, 0x6C, 0x55, 0x4C,
+0x00, 0x18, 0x04, 0x31, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x04, 0x67,
+0x2C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x76, 0x16,
+0x7A, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x75, 0xA2, 0x01, 0x6C,
+0x8C, 0xEB, 0x2C, 0xEB, 0x05, 0x2B, 0xA3, 0xF3,
+0x48, 0xA2, 0x8C, 0xEA, 0x2C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6, 0x46, 0xA2,
+0x02, 0x72, 0x25, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF5, 0x78, 0x9B, 0xA0, 0xF0, 0x94, 0x9A,
+0x8C, 0xEB, 0x05, 0x2B, 0xA3, 0xF3, 0x68, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0x09, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x69, 0xF7, 0x4B, 0xA2, 0x02, 0x72,
+0x0E, 0x60, 0x90, 0x67, 0x00, 0x18, 0x2B, 0x1B,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF3, 0x63, 0xA2,
+0x07, 0x6A, 0x6C, 0xEA, 0x0E, 0xEA, 0x03, 0x2A,
+0x90, 0x67, 0x00, 0x18, 0x7B, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE0, 0xF0,
+0xA0, 0xA2, 0x01, 0x6C, 0xFF, 0x6B, 0xAC, 0xEC,
+0x36, 0x24, 0xE0, 0xF0, 0xA3, 0xA2, 0xE0, 0xF0,
+0xC2, 0xA2, 0x7F, 0x6C, 0x8C, 0xED, 0x8C, 0xEE,
+0xE0, 0xF0, 0x83, 0xA2, 0x6C, 0xED, 0x6C, 0xEE,
+0x9E, 0x34, 0x6C, 0xEC, 0x05, 0x2C, 0xB4, 0x35,
+0xD0, 0x4D, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE0, 0xF0, 0xE1, 0xA2, 0x7F, 0x6B, 0xEC, 0xEB,
+0xA6, 0xF3, 0x7E, 0xC2, 0xE0, 0xF0, 0x60, 0xA2,
+0x01, 0x6F, 0x66, 0x30, 0xEC, 0xE8, 0xA6, 0xF3,
+0x1F, 0xC2, 0xE0, 0xF0, 0x02, 0xA2, 0x1E, 0x30,
+0xC6, 0xF3, 0x02, 0xC2, 0x6A, 0x30, 0x6E, 0x33,
+0xEC, 0xEB, 0xEC, 0xE8, 0xC6, 0xF3, 0x61, 0xC2,
+0x00, 0x6B, 0xC6, 0xF3, 0x00, 0xC2, 0xC6, 0xF3,
+0x63, 0xC2, 0x00, 0x18, 0x9C, 0x30, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x6B, 0x29,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xE3, 0xF4, 0x69, 0xA0, 0xFF, 0x69, 0x02, 0x6A,
+0x8C, 0xE9, 0x6C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA,
+0x1E, 0x22, 0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x91, 0x67, 0x01, 0x6D, 0xE3, 0xF4, 0x49, 0xC0,
+0x00, 0x18, 0x38, 0x31, 0xE3, 0xF4, 0x89, 0xA0,
+0x01, 0x6B, 0x4C, 0xEB, 0x09, 0x6A, 0x4B, 0xEA,
+0x6C, 0x33, 0x8C, 0xEA, 0x6D, 0xEA, 0xA0, 0xF0,
+0x76, 0xA0, 0xE3, 0xF4, 0x49, 0xC0, 0x7F, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x91, 0x67, 0x00, 0x18, 0x68, 0x19, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xE0, 0xF0,
+0x67, 0xA0, 0x11, 0x6A, 0x6C, 0xEA, 0x11, 0x72,
+0x25, 0x61, 0x83, 0xF6, 0x6C, 0xA0, 0x02, 0x6A,
+0xFF, 0x6C, 0x6C, 0xEA, 0x8C, 0xEA, 0x1E, 0x22,
+0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x91, 0x67,
+0x01, 0x6D, 0x83, 0xF6, 0x4C, 0xC0, 0x00, 0x18,
+0x38, 0x31, 0x83, 0xF6, 0x8C, 0xA0, 0x01, 0x6B,
+0x4C, 0xEB, 0x05, 0x6A, 0x4B, 0xEA, 0x68, 0x33,
+0x8C, 0xEA, 0x6D, 0xEA, 0x04, 0x6B, 0x4C, 0xEB,
+0x83, 0xF6, 0x4C, 0xC0, 0xFF, 0x6A, 0x4C, 0xEB,
+0x05, 0x23, 0xA3, 0xF6, 0x52, 0xA0, 0x01, 0x4A,
+0xA3, 0xF6, 0x52, 0xC0, 0x91, 0x67, 0x00, 0x18,
+0x5C, 0x45, 0x91, 0x67, 0x01, 0x6D, 0x00, 0x18,
+0x97, 0x2C, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x24, 0x67, 0xE3, 0xF4,
+0x89, 0xA0, 0x01, 0x6B, 0xFF, 0x6A, 0x8C, 0xEB,
+0x4C, 0xEB, 0x4C, 0xE9, 0x16, 0x23, 0xFF, 0xF6,
+0x1F, 0x4A, 0x8C, 0xEA, 0x00, 0x6D, 0x91, 0x67,
+0xE3, 0xF4, 0x49, 0xC0, 0x00, 0x18, 0x38, 0x31,
+0xE3, 0xF4, 0x89, 0xA0, 0x01, 0x6B, 0x6C, 0xEA,
+0xFA, 0x4B, 0x8C, 0xEB, 0x48, 0x32, 0x4D, 0xEB,
+0x91, 0x67, 0xE3, 0xF4, 0x69, 0xC0, 0x00, 0x18,
+0x68, 0x19, 0x91, 0x67, 0x00, 0x18, 0xFC, 0x44,
+0x91, 0x67, 0x00, 0x6D, 0x00, 0x18, 0x97, 0x2C,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xA0, 0xF0, 0x75, 0xA0, 0x01, 0x6A,
+0x6C, 0xEA, 0x1D, 0x22, 0xA3, 0xF3, 0x45, 0xA0,
+0x04, 0x72, 0x19, 0x60, 0xA3, 0xF3, 0x46, 0xA0,
+0x02, 0x72, 0x15, 0x60, 0x02, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x18,
+0x84, 0x05, 0x0D, 0x10, 0x00, 0x18, 0x43, 0x51,
+0xA3, 0xF3, 0x46, 0xA0, 0x0C, 0x6C, 0x08, 0x72,
+0x02, 0x60, 0x05, 0x2A, 0x04, 0x6C, 0x00, 0x6D,
+0xC5, 0x67, 0x00, 0x18, 0xD9, 0x17, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xA0, 0xF0,
+0x75, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0x1D, 0x22,
+0xA3, 0xF3, 0x45, 0xA0, 0x04, 0x72, 0x19, 0x60,
+0xA3, 0xF3, 0x46, 0xA0, 0x02, 0x72, 0x15, 0x60,
+0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x18, 0x84, 0x05, 0x0D, 0x10,
+0x00, 0x18, 0x43, 0x51, 0xA3, 0xF3, 0x46, 0xA0,
+0x0C, 0x6C, 0x08, 0x72, 0x02, 0x60, 0x05, 0x2A,
+0x04, 0x6C, 0x00, 0x6D, 0xC5, 0x67, 0x00, 0x18,
+0xD9, 0x17, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xA0, 0xF0, 0x75, 0xA0, 0x01, 0x6A,
+0x6C, 0xEA, 0x1D, 0x22, 0xA3, 0xF3, 0x45, 0xA0,
+0x04, 0x72, 0x19, 0x60, 0xA3, 0xF3, 0x46, 0xA0,
+0x02, 0x72, 0x15, 0x60, 0x02, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x18,
+0x84, 0x05, 0x0D, 0x10, 0x00, 0x18, 0x43, 0x51,
+0xA3, 0xF3, 0x46, 0xA0, 0x0C, 0x6C, 0x08, 0x72,
+0x02, 0x60, 0x05, 0x2A, 0x04, 0x6C, 0x00, 0x6D,
+0xC5, 0x67, 0x00, 0x18, 0xD9, 0x17, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xA0, 0xF0,
+0x75, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0x25, 0x22,
+0xA3, 0xF3, 0x45, 0xA0, 0x04, 0x72, 0x21, 0x60,
+0xA3, 0xF3, 0x46, 0xA0, 0x02, 0x72, 0x1D, 0x60,
+0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x18, 0x84, 0x05, 0x15, 0x10,
+0xFF, 0x6C, 0xA4, 0x67, 0xC4, 0x67, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0x57, 0x05, 0xA3, 0xF3,
+0x46, 0xA0, 0x0C, 0x72, 0x03, 0x61, 0x08, 0x6C,
+0x00, 0x6D, 0x04, 0x10, 0x04, 0x72, 0x05, 0x61,
+0x00, 0x6C, 0xA4, 0x67, 0xC5, 0x67, 0x00, 0x18,
+0xD9, 0x17, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xA0, 0xF0, 0x75, 0xA0, 0x01, 0x6A,
+0x6C, 0xEA, 0x25, 0x22, 0xA3, 0xF3, 0x45, 0xA0,
+0x04, 0x72, 0x21, 0x60, 0xA3, 0xF3, 0x46, 0xA0,
+0x02, 0x72, 0x1D, 0x60, 0x02, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x18,
+0x84, 0x05, 0x15, 0x10, 0xFF, 0x6C, 0xA4, 0x67,
+0xC4, 0x67, 0x00, 0x18, 0x18, 0x3A, 0x00, 0x18,
+0x57, 0x05, 0xA3, 0xF3, 0x46, 0xA0, 0x0C, 0x72,
+0x03, 0x61, 0x08, 0x6C, 0x00, 0x6D, 0x04, 0x10,
+0x04, 0x72, 0x05, 0x61, 0x00, 0x6C, 0xA4, 0x67,
+0xC5, 0x67, 0x00, 0x18, 0xD9, 0x17, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xA0, 0xF0,
+0x75, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0x25, 0x22,
+0xA3, 0xF3, 0x45, 0xA0, 0x04, 0x72, 0x21, 0x60,
+0xA3, 0xF3, 0x46, 0xA0, 0x02, 0x72, 0x1D, 0x60,
+0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x18, 0x84, 0x05, 0x15, 0x10,
+0xFF, 0x6C, 0xA4, 0x67, 0xC4, 0x67, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0x57, 0x05, 0xA3, 0xF3,
+0x46, 0xA0, 0x0C, 0x72, 0x03, 0x61, 0x08, 0x6C,
+0x00, 0x6D, 0x04, 0x10, 0x04, 0x72, 0x05, 0x61,
+0x00, 0x6C, 0xA4, 0x67, 0xC5, 0x67, 0x00, 0x18,
+0xD9, 0x17, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x56, 0x38, 0x02, 0x67,
+0x01, 0x6A, 0x0C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x01, 0x6D, 0x02, 0x10, 0x00, 0x6C, 0xA4, 0x67,
+0x00, 0x18, 0x4A, 0x14, 0x40, 0x6A, 0x0C, 0xEA,
+0x1B, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF5,
+0x5C, 0x9A, 0x60, 0xA2, 0x00, 0xF6, 0x60, 0x33,
+0x00, 0xF6, 0x63, 0x33, 0x00, 0x53, 0x00, 0x6B,
+0x02, 0x61, 0x80, 0x6B, 0x6B, 0xEB, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x40, 0xF1, 0x82, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x03, 0x23, 0x00, 0x6B, 0x23, 0xF5, 0x72, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE3, 0xF4, 0x9C, 0xA2, 0xE3, 0xF4, 0xBD, 0xA2,
+0x03, 0xF5, 0xC1, 0xA2, 0x02, 0x6F, 0x00, 0x18,
+0xE3, 0x14, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xC1, 0x2C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x4A, 0xF1, 0x64, 0xA2,
+0x02, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0xDE, 0x3B, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xB4, 0x01, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xF3, 0x3A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF7, 0x68, 0xA2, 0x05, 0x6A, 0x6C, 0xEA,
+0x05, 0x72, 0x02, 0x61, 0x00, 0x18, 0xEC, 0x4B,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A, 0xFF, 0x69,
+0x6C, 0xEA, 0x1E, 0x22, 0xA0, 0xF0, 0x99, 0xA0,
+0x96, 0x34, 0x2C, 0xEC, 0x00, 0x18, 0x84, 0x38,
+0x02, 0x6B, 0x4C, 0xEB, 0x2C, 0xEB, 0x07, 0x23,
+0xA0, 0xF0, 0x99, 0xA0, 0x96, 0x34, 0x2C, 0xEC,
+0x00, 0x18, 0x18, 0x1A, 0x0D, 0x10, 0xA0, 0xF0,
+0x99, 0xA0, 0xE3, 0xF4, 0x68, 0xA0, 0x05, 0x6A,
+0x4B, 0xEA, 0x96, 0x34, 0x6C, 0xEA, 0x2C, 0xEC,
+0xE3, 0xF4, 0x48, 0xC0, 0x00, 0x18, 0x68, 0x19,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF7, 0x68, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xF9, 0x49, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x96, 0xA2, 0x7F, 0x6B,
+0x8C, 0xEB, 0x07, 0x23, 0xA0, 0xF0, 0x99, 0xA2,
+0xFF, 0x6A, 0x96, 0x34, 0x4C, 0xEC, 0x00, 0x18,
+0x6C, 0x1A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF7, 0x68, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x5C, 0x4E, 0x30, 0xF0,
+0x20, 0x6A, 0x49, 0xF6, 0x64, 0xA2, 0x01, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x07, 0x6C, 0x00, 0x18,
+0x1D, 0x2E, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x00, 0x18, 0x91, 0x51, 0x90, 0x67,
+0x00, 0x18, 0x3B, 0x19, 0x00, 0x6C, 0x00, 0x18,
+0x9D, 0x16, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF3,
+0x63, 0xA2, 0x07, 0x6A, 0x6C, 0xEA, 0x0E, 0xEA,
+0x02, 0x2A, 0x00, 0x18, 0x50, 0x25, 0x90, 0x67,
+0x00, 0x18, 0xE3, 0x15, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x80, 0x3A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x82, 0x1E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x7F, 0x1E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x3C, 0x29, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xBB, 0x28, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x83, 0x22, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF3, 0x63, 0xA2, 0xFF, 0x69, 0x07, 0x6A,
+0x8C, 0xE9, 0x6C, 0xEA, 0x2E, 0xEA, 0x02, 0x2A,
+0x00, 0x18, 0xF5, 0x22, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x00, 0x18, 0x0A, 0x51,
+0xA0, 0xF0, 0x76, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x26, 0x22, 0xE3, 0xF4, 0x49, 0xA0, 0x21, 0x6B,
+0x6B, 0xEB, 0x4C, 0xEB, 0x40, 0x6A, 0x6C, 0xEA,
+0xE3, 0xF4, 0x69, 0xC0, 0xFF, 0x6B, 0x6C, 0xEA,
+0x10, 0x22, 0xE3, 0xF4, 0x9C, 0xA0, 0xE3, 0xF4,
+0xBD, 0xA0, 0x03, 0xF5, 0xC1, 0xA0, 0x05, 0x6F,
+0x00, 0x18, 0xE3, 0x14, 0xE3, 0xF4, 0x69, 0xA0,
+0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xE3, 0xF4,
+0x49, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF7,
+0x68, 0xA2, 0x40, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x91, 0x67, 0x00, 0x18, 0xB5, 0x3F, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF6,
+0x65, 0xA2, 0x2E, 0xEB, 0x11, 0x2B, 0xC3, 0xF6,
+0x64, 0xA2, 0x1F, 0x6C, 0x6A, 0x32, 0x8C, 0xEA,
+0x47, 0xE9, 0x01, 0x6C, 0x8C, 0xEA, 0x08, 0x22,
+0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0xDE, 0x3B,
+0x91, 0x67, 0x00, 0x18, 0xB5, 0x18, 0x91, 0x67,
+0x00, 0x18, 0x0C, 0x2E, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x8F, 0x35, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF4, 0x60, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEE, 0x6D, 0xE4, 0x08, 0x68,
+0x80, 0xA3, 0xDB, 0xE0, 0x02, 0x67, 0x4C, 0xED,
+0x07, 0xEE, 0xD0, 0x67, 0x4C, 0xEF, 0x04, 0xED,
+0x4C, 0xEC, 0xCC, 0xEF, 0x0F, 0xE8, 0x8C, 0xE8,
+0xE4, 0xED, 0xED, 0xE8, 0x4C, 0xE8, 0x00, 0xC3,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4, 0x40, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6B, 0x8C, 0xEB, 0x4D, 0xE3,
+0x40, 0xA3, 0xFF, 0x6C, 0x8C, 0xEE, 0x08, 0x6B,
+0xDB, 0xE3, 0x8C, 0xED, 0x8C, 0xEA, 0x64, 0x67,
+0x47, 0xED, 0x67, 0xEE, 0x6C, 0xEA, 0x8C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x01, 0x74, 0x0D, 0x60,
+0x06, 0x24, 0x02, 0x74, 0x10, 0x60, 0x03, 0x74,
+0x00, 0x6A, 0x1C, 0x61, 0x14, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA8, 0x35, 0xC1, 0xF5, 0x40, 0x9A,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA8, 0x35,
+0xC1, 0xF5, 0x44, 0x9A, 0x05, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF5, 0x48, 0x9A, 0xA8, 0x35,
+0x55, 0xE5, 0x40, 0x9D, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF5, 0x4C, 0x9A, 0xA8, 0x35,
+0x55, 0xE5, 0x40, 0x9D, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x81, 0xF4, 0x10, 0x6B, 0x23, 0xF2, 0x6C, 0xDA,
+0x00, 0xF2, 0x00, 0x4B, 0x23, 0xF2, 0x70, 0xDA,
+0x01, 0xF2, 0x00, 0x4B, 0x23, 0xF2, 0x74, 0xDA,
+0x00, 0xF2, 0x00, 0x4B, 0x23, 0xF2, 0x78, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF5, 0x50, 0x9A, 0xFF, 0x6B, 0x40, 0xA2,
+0x6C, 0xEA, 0x5E, 0x32, 0x6C, 0xEA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF5, 0xB4, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0xE0, 0xAD, 0xFF, 0xF7,
+0x1F, 0x6E, 0x01, 0x74, 0xCC, 0xEF, 0x08, 0x60,
+0x03, 0x24, 0x02, 0x74, 0x0B, 0x60, 0x20, 0xE8,
+0x7F, 0xF6, 0x1F, 0x6B, 0xEC, 0xEB, 0x0E, 0x10,
+0x80, 0xF1, 0x01, 0x6B, 0x6B, 0xEB, 0xEC, 0xEB,
+0x80, 0x6C, 0x06, 0x10, 0x80, 0xF1, 0x01, 0x6B,
+0x6B, 0xEB, 0xFF, 0x6C, 0xEC, 0xEB, 0x01, 0x4C,
+0x8D, 0xEB, 0xCC, 0xEB, 0x83, 0x67, 0x62, 0x33,
+0x4C, 0xEC, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF5, 0x58, 0x9A, 0x80, 0xC5, 0x60, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0x02, 0x74, 0x4C, 0xED, 0xCC, 0xEA, 0x1C, 0x61,
+0x01, 0x75, 0x0A, 0x6C, 0x04, 0x60, 0x02, 0x75,
+0x00, 0x6C, 0x01, 0x61, 0x09, 0x6C, 0x01, 0x72,
+0x04, 0x61, 0x01, 0x75, 0x04, 0x6B, 0x07, 0x61,
+0x1D, 0x10, 0x02, 0x72, 0x07, 0x61, 0x01, 0x75,
+0x02, 0x6B, 0x04, 0x61, 0x17, 0x10, 0x02, 0x75,
+0x01, 0x6B, 0x04, 0x10, 0x02, 0x72, 0x11, 0x61,
+0x02, 0x75, 0x03, 0x6B, 0x0E, 0x61, 0x0E, 0x10,
+0x01, 0x74, 0x08, 0x61, 0x02, 0x72, 0x01, 0x6B,
+0x03, 0x60, 0x01, 0x72, 0x03, 0x61, 0x02, 0x6B,
+0x00, 0x6C, 0x04, 0x10, 0x00, 0x6B, 0x83, 0x67,
+0x01, 0x10, 0x00, 0x6B, 0x90, 0x32, 0x6D, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x1F, 0x6D, 0x8C, 0xED, 0x96, 0x34, 0x6C, 0xEC,
+0x01, 0x74, 0x03, 0x6A, 0x0A, 0x60, 0x10, 0x24,
+0x04, 0x74, 0x05, 0x60, 0x06, 0x74, 0x00, 0x6A,
+0x12, 0x61, 0xEF, 0x4A, 0x02, 0x10, 0x07, 0x6A,
+0x4B, 0xEA, 0xAB, 0xE2, 0x44, 0x32, 0x00, 0xF6,
+0x40, 0x32, 0x00, 0xF6, 0x43, 0x32, 0x20, 0xE8,
+0x08, 0x6A, 0xAB, 0xE2, 0x44, 0x32, 0x00, 0xF6,
+0x40, 0x32, 0x00, 0xF6, 0x43, 0x32, 0x20, 0xE8,
+0x00, 0xF6, 0x80, 0x34, 0x00, 0xF6, 0x83, 0x34,
+0x47, 0x44, 0x5C, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA,
+0x77, 0x5A, 0x00, 0x6A, 0x06, 0x60, 0x00, 0x54,
+0x64, 0x6A, 0x03, 0x60, 0x47, 0x44, 0x5D, 0x4A,
+0x6C, 0xEA, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6B, 0x8C, 0xEB,
+0xFF, 0xF7, 0x1F, 0x6A, 0x81, 0x46, 0x26, 0x67,
+0xAC, 0xEA, 0x06, 0x2C, 0x83, 0x67, 0xA2, 0x67,
+0x00, 0x18, 0xE1, 0x35, 0x02, 0x67, 0x0A, 0x10,
+0x83, 0x67, 0xA2, 0x67, 0x00, 0x18, 0xE1, 0x35,
+0x02, 0x67, 0x91, 0x67, 0x00, 0x18, 0xBC, 0x1F,
+0x2C, 0xE8, 0x06, 0xEA, 0x50, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x0E, 0x91, 0x04, 0xD2,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED, 0x4C, 0xE9,
+0x0C, 0xD6, 0x0D, 0xD7, 0x0F, 0x90, 0x05, 0xD5,
+0x00, 0x6A, 0x05, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x95, 0x20, 0x40, 0xA8, 0x01, 0x4A, 0x40, 0xC8,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x94, 0x05, 0x95,
+0x41, 0xF1, 0xDC, 0x9A, 0x00, 0x18, 0x4F, 0x36,
+0x0C, 0x93, 0x6C, 0xEA, 0x0D, 0x93, 0x6E, 0xEA,
+0x03, 0x22, 0x40, 0xA8, 0x23, 0xEA, 0xEA, 0x61,
+0x40, 0xA8, 0x09, 0x97, 0x07, 0x90, 0x23, 0xEA,
+0x08, 0x91, 0x58, 0x67, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x7C, 0x9B,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x69, 0xE2,
+0x00, 0x9A, 0x41, 0x45, 0x25, 0x67, 0x05, 0x22,
+0x85, 0x67, 0x00, 0x18, 0xBC, 0x1F, 0x2C, 0xE8,
+0x06, 0xEA, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0xF7, 0x1F, 0x68, 0x41, 0x45, 0x25, 0x67,
+0x0C, 0xD6, 0x8C, 0xE8, 0x07, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A, 0x41, 0xE0,
+0xC0, 0xD8, 0x17, 0x10, 0x01, 0x6D, 0x90, 0x67,
+0xAB, 0xED, 0x00, 0x18, 0x78, 0x36, 0x91, 0x67,
+0x04, 0xD2, 0x00, 0x18, 0xBC, 0x1F, 0x0C, 0x93,
+0x64, 0xEA, 0x43, 0x67, 0x04, 0x93, 0x2C, 0xEA,
+0x2F, 0xE9, 0x6C, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x7C, 0x9B, 0x2D, 0xEA, 0x61, 0xE0,
+0x40, 0xD8, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0xAC, 0xEA, 0x54, 0x2C, 0x06, 0x5A, 0xE0, 0xF0,
+0x1E, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32,
+0x80, 0xF6, 0x10, 0x4B, 0x4D, 0xE3, 0x40, 0x9B,
+0x00, 0xEA, 0x01, 0x68, 0x30, 0xF0, 0x20, 0x6A,
+0x0B, 0xE8, 0x21, 0xF1, 0x3C, 0x9A, 0x5A, 0x10,
+0x01, 0x68, 0x30, 0xF0, 0x20, 0x6A, 0x0B, 0xE8,
+0xE1, 0xF5, 0x20, 0x9A, 0x99, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF1, 0x3C, 0x9A, 0x01, 0x68,
+0x0B, 0xE8, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF6, 0x10, 0x6C, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF5,
+0x1C, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF5,
+0x24, 0x9A, 0x6D, 0x10, 0xA1, 0xF4, 0x10, 0x6C,
+0xFF, 0x6D, 0x77, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0xDC, 0x9A,
+0x01, 0x6D, 0xA1, 0xF6, 0x10, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0xB4, 0x9A, 0xA1, 0xF4, 0x14, 0x6C,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF6, 0x14, 0x6C, 0xC1, 0xF5,
+0xBC, 0x9A, 0x31, 0x10, 0x06, 0x5A, 0xA0, 0xF0,
+0x0A, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32,
+0xA0, 0xF6, 0x08, 0x4B, 0x4D, 0xE3, 0x40, 0x9B,
+0x00, 0xEA, 0x01, 0x68, 0x30, 0xF0, 0x20, 0x6A,
+0x0B, 0xE8, 0xE1, 0xF5, 0x28, 0x9A, 0x27, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF5, 0x28, 0x9A,
+0x01, 0x68, 0x0B, 0xE8, 0xB0, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0xD1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0xB0, 0x67, 0xA1, 0xF6, 0x10, 0x6C, 0xD1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF5, 0x1C, 0x9A, 0xA1, 0xF4, 0x14, 0x6C,
+0x00, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x14, 0x6C, 0xB0, 0x67, 0x00, 0x6E,
+0x78, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF5,
+0x2C, 0x9A, 0x01, 0x68, 0x0B, 0xE8, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18,
+0x86, 0x36, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF6,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF5, 0x1C, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0x34, 0x9A, 0xA1, 0xF4,
+0x14, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0xA1, 0xF6, 0x14, 0x6C, 0xB0, 0x67,
+0xD1, 0x67, 0x53, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF5, 0x30, 0x9A, 0x01, 0x68, 0x0B, 0xE8,
+0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0xB0, 0x67, 0xD1, 0x67,
+0xA1, 0xF6, 0x10, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF5, 0x1C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x34, 0x9A,
+0xA1, 0xF4, 0x14, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF6, 0x14, 0x6C,
+0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x01, 0xF1, 0x00, 0x6C, 0x00, 0xF3, 0x03, 0x6D,
+0x01, 0x6E, 0x27, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF5, 0xB4, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF5, 0xD8, 0x9A, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF5, 0xCC, 0x9A, 0x01, 0x6D, 0xA1, 0xF6,
+0x10, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x14, 0x9A,
+0xA1, 0xF4, 0x14, 0x6C, 0xB0, 0x67, 0xD0, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF5, 0xBC, 0x9A, 0xA1, 0xF6, 0x14, 0x6C,
+0xD0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x4C, 0xED, 0x4C, 0xEC, 0x04, 0xD5,
+0x28, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x08, 0x9A, 0x01, 0xF0, 0x08, 0x69, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x21, 0xF0, 0x10, 0x6C, 0x0E, 0x6D, 0x08, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6E, 0x21, 0xF0,
+0x14, 0x6C, 0x03, 0x6D, 0x00, 0x18, 0x86, 0x36,
+0x04, 0x95, 0x00, 0x6C, 0x00, 0x18, 0x9D, 0x36,
+0x91, 0x67, 0xB0, 0x67, 0xD0, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF5,
+0x70, 0x9A, 0x7F, 0x6A, 0x80, 0xA3, 0x8C, 0xEA,
+0x40, 0xC3, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x0F, 0x5C,
+0xAC, 0xE8, 0x09, 0x60, 0x00, 0x18, 0xFF, 0x35,
+0x10, 0x22, 0x00, 0x18, 0xFF, 0x35, 0x01, 0x72,
+0x00, 0x6C, 0x0B, 0x61, 0x04, 0x10, 0x00, 0x18,
+0xFF, 0x35, 0x05, 0x2A, 0x01, 0x6C, 0xB0, 0x67,
+0x00, 0x18, 0x24, 0x37, 0x02, 0x10, 0x00, 0x18,
+0xFF, 0x35, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x68, 0x24, 0x67,
+0x0C, 0xE9, 0xAC, 0xE8, 0x01, 0x6D, 0x21, 0xF0,
+0x14, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x78, 0x36,
+0x01, 0x71, 0x04, 0xD2, 0x24, 0x60, 0x03, 0x21,
+0x02, 0x71, 0x71, 0x60, 0xB4, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF5, 0xBC, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0xC0, 0x9A, 0xA1, 0xF0,
+0x0C, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xAC, 0x9A, 0xC1, 0xF0,
+0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF6, 0xA4, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x04, 0x6C,
+0xE1, 0xF5, 0xC4, 0x9A, 0x92, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF5, 0xBC, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0xC8, 0x9A, 0xA1, 0xF0,
+0x0C, 0x69, 0x91, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xAC, 0x9A,
+0xC1, 0xF0, 0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x91, 0x67, 0x3C, 0x6D, 0x08, 0x36,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF2, 0xB4, 0x9A, 0x21, 0xF0, 0x18, 0x6C,
+0x00, 0xF7, 0x00, 0x36, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF6, 0xA4, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0xCC, 0x9A,
+0x61, 0xF0, 0x04, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x50, 0x9A,
+0x04, 0x93, 0x6C, 0xEA, 0x0C, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0xAC, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0xD0, 0x9A, 0x41, 0xF0,
+0x08, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x01, 0x70,
+0x05, 0x61, 0x10, 0x6D, 0x01, 0xF2, 0x00, 0x6C,
+0xC5, 0x67, 0x47, 0x10, 0x01, 0xF2, 0x00, 0x6C,
+0x10, 0x6D, 0x00, 0x6E, 0x42, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF5, 0xBC, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0xD4, 0x9A, 0xA1, 0xF0,
+0x0C, 0x69, 0x91, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xCC, 0x9A,
+0xC1, 0xF0, 0x04, 0x6C, 0xA6, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x91, 0x67, 0x3C, 0x6D, 0x08, 0x36,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF2, 0xB4, 0x9A, 0x21, 0xF0, 0x18, 0x6C,
+0x00, 0xF7, 0x00, 0x36, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF6, 0xA4, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0xCC, 0x9A,
+0x61, 0xF0, 0x04, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x50, 0x9A,
+0x04, 0x93, 0x6C, 0xEA, 0x0C, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0xAC, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0xD8, 0x9A, 0x41, 0xF0,
+0x08, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xA9, 0xF4, 0x0C, 0x4A, 0x88, 0x34, 0x91, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x5C, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5, 0xA0, 0x35,
+0xCC, 0xEA, 0x61, 0xF3, 0xC0, 0x9B, 0x80, 0xAC,
+0xAD, 0xEA, 0x01, 0x6D, 0xAB, 0xED, 0x4C, 0xEE,
+0x00, 0x18, 0x86, 0x36, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x46, 0x67, 0xFF, 0x68,
+0xFF, 0xF7, 0x1F, 0x69, 0x01, 0x4A, 0x0C, 0xD6,
+0x0D, 0xD7, 0x8C, 0xE8, 0xAC, 0xE9, 0x04, 0x2A,
+0x90, 0x67, 0xB1, 0x67, 0xC7, 0x67, 0x12, 0x10,
+0xB1, 0x67, 0x90, 0x67, 0x00, 0x18, 0xE1, 0x35,
+0x0C, 0x94, 0x04, 0xD2, 0x00, 0x18, 0xBC, 0x1F,
+0x0D, 0x96, 0x90, 0x67, 0xB1, 0x67, 0xC4, 0xEA,
+0x0C, 0x92, 0x4C, 0xEE, 0x4F, 0xEB, 0x04, 0x92,
+0x4C, 0xEB, 0x6D, 0xEE, 0x00, 0x18, 0xB6, 0x37,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x01, 0x72, 0x11, 0x60,
+0x03, 0x22, 0x02, 0x72, 0x1D, 0x60, 0x2A, 0x10,
+0x01, 0xF4, 0x00, 0x68, 0x00, 0x6C, 0x18, 0x6D,
+0xD0, 0x67, 0xF0, 0x67, 0x00, 0x18, 0xC5, 0x37,
+0x01, 0x6C, 0x18, 0x6D, 0xD0, 0x67, 0xF0, 0x67,
+0x1B, 0x10, 0x01, 0xF4, 0x00, 0x68, 0x00, 0xF4,
+0x00, 0x69, 0x00, 0x6C, 0x18, 0x6D, 0xD0, 0x67,
+0xF1, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x01, 0x6C,
+0x18, 0x6D, 0xD0, 0x67, 0xF1, 0x67, 0x0C, 0x10,
+0x00, 0x6C, 0x01, 0xF4, 0x00, 0x68, 0xE4, 0x67,
+0x18, 0x6D, 0xD0, 0x67, 0x00, 0x18, 0xC5, 0x37,
+0x01, 0x6C, 0x18, 0x6D, 0xD0, 0x67, 0x00, 0x6F,
+0x00, 0x18, 0xC5, 0x37, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x68, 0x24, 0x67, 0x0C, 0xE9, 0x0C, 0xED,
+0x91, 0x67, 0x04, 0xD5, 0xCC, 0xE8, 0x00, 0x18,
+0x04, 0x36, 0x04, 0x95, 0xD0, 0x67, 0x91, 0x67,
+0x00, 0x18, 0x1B, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF6, 0x7C, 0x9B, 0x91, 0x67, 0xA2, 0x67,
+0x40, 0xC3, 0x00, 0x18, 0x4F, 0x37, 0x91, 0x67,
+0x00, 0x18, 0xDC, 0x37, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x04, 0x67, 0x4C, 0xE8, 0x68, 0x40,
+0xE4, 0x4B, 0x4C, 0xEB, 0x0D, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0x81, 0xF3, 0xB8, 0x9A, 0x80, 0xF4, 0x14, 0x6E,
+0x2F, 0x10, 0x68, 0x40, 0xD6, 0x4B, 0x4C, 0xEB,
+0x0F, 0x5B, 0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x00, 0x6C, 0x81, 0xF3, 0xB8, 0x9A,
+0x40, 0xF4, 0x13, 0x6E, 0x21, 0x10, 0x68, 0x40,
+0xA4, 0x4B, 0x4C, 0xEB, 0x11, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0x81, 0xF3, 0xB8, 0x9A, 0x40, 0xF4, 0x12, 0x6E,
+0x13, 0x10, 0x76, 0x58, 0x09, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C, 0x81, 0xF3,
+0xB8, 0x9A, 0x00, 0xF4, 0x12, 0x6E, 0x08, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0xB8, 0x9A,
+0x61, 0xF0, 0x00, 0x6C, 0x61, 0xF1, 0x0A, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x00, 0x69, 0x68, 0x40,
+0xE4, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB, 0x1D, 0x5B,
+0x02, 0x60, 0x02, 0x4A, 0x0E, 0x10, 0x68, 0x40,
+0xA4, 0x4B, 0x4C, 0xEB, 0x29, 0x5B, 0x03, 0x60,
+0x00, 0xF3, 0x01, 0x6A, 0x06, 0x10, 0x00, 0x6A,
+0x8D, 0x58, 0x04, 0xD2, 0x03, 0x61, 0x00, 0xF5,
+0x01, 0x4A, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF6, 0x80, 0x9A, 0x00, 0x18, 0xBC, 0x1F,
+0x04, 0x97, 0x91, 0x67, 0x18, 0x6D, 0xE4, 0xEA,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF6, 0xC4, 0x9A,
+0x0D, 0xEF, 0x01, 0x49, 0x00, 0x18, 0xC5, 0x37,
+0x04, 0x71, 0xD5, 0x61, 0x68, 0x40, 0xE4, 0x4B,
+0xFF, 0x6A, 0x4C, 0xEB, 0x1D, 0x5B, 0x05, 0x60,
+0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D, 0x01, 0x6E,
+0x10, 0x10, 0x68, 0x40, 0xA4, 0x4B, 0x4C, 0xEB,
+0x2D, 0x5B, 0x05, 0x60, 0x41, 0xF1, 0x18, 0x6C,
+0x1F, 0x6D, 0x02, 0x6E, 0x06, 0x10, 0x95, 0x58,
+0x06, 0x61, 0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D,
+0x03, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x5C, 0xF1, 0x19, 0x4A,
+0x40, 0xDB, 0x00, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF6, 0xA8, 0x9A, 0xFF, 0x6C, 0x40, 0xA5,
+0xA0, 0xA5, 0x8C, 0xEA, 0xAC, 0xEC, 0x4E, 0xEC,
+0x19, 0x24, 0x64, 0x73, 0x12, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF0, 0x80, 0x9B, 0x40, 0x6D,
+0x60, 0x9C, 0xAD, 0xEB, 0x60, 0xDC, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x83, 0xF3,
+0x80, 0x9B, 0xAD, 0xEC, 0x83, 0xF3, 0x80, 0xDB,
+0x20, 0xE8, 0x01, 0x4B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEB, 0xDC, 0x17, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xBC, 0xF1, 0x19, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF6,
+0x4C, 0x9A, 0x60, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0xF8, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0xBC, 0xF1,
+0x1A, 0x4A, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF6, 0x70, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0xE0, 0xA3, 0x1F, 0x6E,
+0x94, 0x34, 0xEC, 0xEE, 0xCD, 0xEC, 0x4C, 0xED,
+0x4C, 0xEC, 0x80, 0xC3, 0xA0, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF6, 0x70, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0xC0, 0xA3, 0x1F, 0x6D,
+0x94, 0x34, 0xCC, 0xED, 0xAD, 0xEC, 0x4C, 0xEC,
+0x80, 0xC3, 0x60, 0xA3, 0x6C, 0xEA, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xED, 0xFF, 0x75, 0x4C, 0xEC,
+0xCC, 0xEA, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x71, 0xE4, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x71, 0xE4, 0x63, 0xF3, 0x6B, 0xA4, 0xAC, 0xEA,
+0xAF, 0xED, 0x6C, 0xED, 0xAD, 0xEA, 0x63, 0xF3,
+0x4B, 0xC4, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0xFF, 0x69, 0x7C, 0xF2, 0x05, 0x4A, 0x8C, 0xE9,
+0x40, 0xDB, 0x00, 0x68, 0x26, 0x10, 0x82, 0xF3,
+0x08, 0x70, 0x12, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x10, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA, 0x1C, 0x10,
+0xFF, 0xF7, 0x1F, 0x6A, 0x01, 0x48, 0x4C, 0xE8,
+0x14, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x33, 0x58,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF5,
+0x40, 0x9A, 0x01, 0x6B, 0x40, 0xA2, 0x6C, 0xEA,
+0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF6,
+0x54, 0x9A, 0x01, 0x6B, 0x40, 0x9A, 0x42, 0x32,
+0x5E, 0x32, 0x6C, 0xEA, 0x2E, 0xEA, 0xCF, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x7C, 0xF2, 0x06, 0x4A,
+0x40, 0xDB, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x6E, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x68, 0x9A, 0xEF, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x00, 0x6C,
+0x00, 0x18, 0x99, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0x94, 0x9A, 0x61, 0xF5, 0x7C, 0x9B, 0x80, 0xDB,
+0xC0, 0xF0, 0x64, 0xA2, 0x09, 0x6A, 0x6C, 0xEA,
+0x09, 0x72, 0x1D, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF6, 0x78, 0x9A, 0x7F, 0xF7, 0x1F, 0x6A,
+0x07, 0x68, 0x80, 0xAB, 0x8C, 0xEA, 0x40, 0xCB,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A, 0x0A, 0x6C,
+0x00, 0xC2, 0x00, 0x18, 0x95, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF6, 0x5C, 0x9A, 0x0A, 0x6C,
+0x00, 0xC2, 0x00, 0x18, 0x95, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE3, 0xF4,
+0x88, 0xA2, 0x7F, 0x6B, 0x8C, 0xEB, 0xE3, 0xF4,
+0x68, 0xC2, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0x9C, 0xF3,
+0x1D, 0x4A, 0x40, 0xDB, 0x00, 0x68, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF6, 0x40, 0x9A, 0x40, 0x9A,
+0x1E, 0x22, 0xE0, 0xF3, 0x09, 0x70, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A,
+0x20, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x60, 0xDA, 0x00, 0x6A, 0x09, 0x10, 0x32, 0x6C,
+0x00, 0x18, 0x95, 0x20, 0x01, 0x48, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0xDC, 0x17, 0x01, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xE3, 0xF4,
+0x68, 0xA0, 0x80, 0x6A, 0x4B, 0xEA, 0x6D, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0xE3, 0xF4, 0x48, 0xC0,
+0x69, 0xF7, 0x18, 0x4C, 0x00, 0x6D, 0x00, 0x18,
+0x91, 0x40, 0x30, 0xF0, 0x20, 0x6A, 0xE3, 0xF4,
+0x78, 0xA8, 0x41, 0xF6, 0x44, 0x9A, 0x60, 0xCA,
+0xC0, 0xF0, 0x64, 0xA0, 0x09, 0x6A, 0x6C, 0xEA,
+0x09, 0x6B, 0x6E, 0xEA, 0x16, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF2, 0x60, 0x9B, 0xFF, 0xF7,
+0x1F, 0x6C, 0x80, 0x6D, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF6, 0x7C, 0x9B, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF6, 0x78, 0x9A,
+0x40, 0xAB, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1,
+0x68, 0x9A, 0xFF, 0x68, 0x10, 0x6C, 0x40, 0xA3,
+0x0C, 0xEA, 0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3,
+0x01, 0x6C, 0x00, 0x18, 0x99, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF5, 0x5C, 0x9A, 0x00, 0x6B,
+0x01, 0x6C, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF6, 0x6C, 0x9A, 0x40, 0xA3, 0x0C, 0xEA,
+0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3, 0x20, 0xBA,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0xF7, 0x1F, 0x68, 0x8C, 0xE8, 0xFF, 0x69,
+0xAC, 0xE9, 0x90, 0x67, 0x03, 0x6D, 0x00, 0x18,
+0xD4, 0x47, 0x03, 0x6B, 0x4C, 0xEB, 0x18, 0x49,
+0x25, 0xE3, 0xFF, 0xF7, 0x1F, 0x6D, 0x90, 0x67,
+0x2C, 0xED, 0x00, 0x18, 0xD4, 0x47, 0x04, 0x6B,
+0x6B, 0xEB, 0x4C, 0xEB, 0xFF, 0x6A, 0x4C, 0xEB,
+0xD0, 0x73, 0x3E, 0x61, 0x4C, 0xE9, 0xA1, 0x41,
+0xFF, 0xF7, 0x1F, 0x6A, 0x90, 0x67, 0x4C, 0xED,
+0x00, 0x18, 0xD4, 0x47, 0x80, 0x6B, 0x6B, 0xEB,
+0x4C, 0xEB, 0xFF, 0x6A, 0x4C, 0xEB, 0x1C, 0x6A,
+0x04, 0xD2, 0x02, 0x2B, 0x18, 0x6B, 0x04, 0xD3,
+0x04, 0x92, 0x90, 0x67, 0x35, 0xE2, 0x00, 0x18,
+0xD4, 0x47, 0x04, 0x93, 0xA1, 0x41, 0x90, 0x67,
+0xB5, 0xE3, 0x05, 0xD2, 0x00, 0x18, 0xD4, 0x47,
+0x05, 0x93, 0x04, 0x73, 0x1D, 0x61, 0x21, 0x72,
+0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF7,
+0x68, 0xA2, 0x02, 0x6A, 0x6C, 0xEA, 0x14, 0x22,
+0x04, 0x96, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x8A, 0x4D, 0x0E, 0x10, 0x20, 0x72, 0x0C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF7, 0x68, 0xA2,
+0x04, 0x6A, 0x6C, 0xEA, 0x05, 0x22, 0x04, 0x96,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x18, 0x06, 0x4C,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x9F, 0xE7, 0x01, 0x4F,
+0x00, 0xF1, 0x00, 0x5F, 0x44, 0x67, 0x05, 0x67,
+0x0E, 0xD6, 0x06, 0xD7, 0x13, 0x61, 0xC7, 0x45,
+0x0E, 0x95, 0x00, 0x6B, 0x05, 0x4E, 0x4D, 0xED,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6, 0x48, 0x9A,
+0xFF, 0x6F, 0x83, 0x67, 0x4C, 0xEE, 0x01, 0x4F,
+0x04, 0xD3, 0x05, 0xD3, 0x00, 0x18, 0xB4, 0x1E,
+0x00, 0x6C, 0x21, 0x10, 0x67, 0x45, 0x05, 0x4B,
+0x07, 0xD3, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF6,
+0x68, 0x9B, 0x07, 0x94, 0x0E, 0x95, 0x06, 0x97,
+0x6C, 0xEC, 0x07, 0xD4, 0x07, 0x96, 0x00, 0x69,
+0x91, 0x67, 0x4D, 0xED, 0x04, 0xD1, 0x05, 0xD1,
+0x00, 0x18, 0xB4, 0x1E, 0x06, 0x92, 0x07, 0x93,
+0x0E, 0x95, 0xFF, 0x6F, 0x01, 0x4F, 0x91, 0x67,
+0x79, 0xE2, 0x5F, 0xE7, 0x04, 0xD1, 0x05, 0xD1,
+0x00, 0x18, 0xB4, 0x1E, 0x91, 0x67, 0x00, 0x18,
+0x9B, 0x1E, 0x67, 0x40, 0x05, 0x4B, 0x62, 0x32,
+0x41, 0xC0, 0x42, 0x32, 0x42, 0xC0, 0x00, 0xF6,
+0x62, 0x32, 0x43, 0xC0, 0x47, 0x40, 0x1D, 0x4A,
+0x00, 0xF1, 0x4C, 0xC0, 0x42, 0x34, 0x00, 0xF6,
+0x42, 0x32, 0x60, 0xC0, 0x00, 0xF1, 0x8D, 0xC0,
+0x00, 0xF1, 0x4F, 0xC0, 0x82, 0x34, 0x41, 0xA0,
+0x00, 0xF1, 0x8E, 0xC0, 0x80, 0xA0, 0x40, 0x32,
+0x0F, 0x6D, 0x8D, 0xEA, 0x82, 0xA0, 0x03, 0x6E,
+0x0A, 0x91, 0x80, 0x34, 0x80, 0x34, 0x4D, 0xEC,
+0x43, 0xA0, 0x00, 0xF6, 0x40, 0x32, 0x8D, 0xEA,
+0xE2, 0xA2, 0x83, 0xA2, 0xAC, 0xEF, 0x03, 0x4F,
+0xEC, 0x37, 0xCC, 0xEC, 0x91, 0xE7, 0x71, 0xE4,
+0x82, 0x37, 0x84, 0xC0, 0xE5, 0xC0, 0x00, 0xF6,
+0x82, 0x34, 0xE2, 0x37, 0xE6, 0xC0, 0x87, 0xC0,
+0xE3, 0xA2, 0x8A, 0xA2, 0x42, 0xA2, 0xEC, 0xEE,
+0x8A, 0x34, 0x4C, 0xED, 0x03, 0x4D, 0xD9, 0xE4,
+0xAC, 0x35, 0xB9, 0xE6, 0x6D, 0xE6, 0x62, 0x32,
+0x00, 0xF1, 0x70, 0xC0, 0x00, 0xF1, 0x51, 0xC0,
+0x00, 0xF6, 0x62, 0x33, 0x42, 0x32, 0x00, 0xF1,
+0x52, 0xC0, 0x00, 0xF1, 0x73, 0xC0, 0x0B, 0x97,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6, 0x4C, 0x9A,
+0xFF, 0x6B, 0xFF, 0xF7, 0x1F, 0x69, 0x40, 0xA2,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6,
+0x50, 0x9A, 0x05, 0xD3, 0x40, 0xAA, 0x4C, 0xE9,
+0x00, 0x6A, 0x04, 0xD2, 0x53, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF6, 0xD4, 0x9A, 0x30, 0xF0,
+0x20, 0x6D, 0x91, 0x67, 0xA9, 0xF4, 0x1C, 0x4D,
+0xE5, 0xF6, 0x1F, 0x6F, 0x00, 0x18, 0x75, 0x39,
+0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF4, 0x7C, 0x9A,
+0x3F, 0x6C, 0x0F, 0x6D, 0x01, 0xA3, 0x42, 0xA3,
+0x01, 0x6F, 0x8C, 0xE8, 0x83, 0xA3, 0x4C, 0xED,
+0x40, 0xA3, 0x92, 0x34, 0x00, 0x30, 0xEC, 0xEC,
+0x4D, 0xE8, 0xAC, 0x35, 0xFF, 0xF7, 0x1F, 0x6E,
+0xFF, 0x6A, 0x09, 0x2C, 0x18, 0x48, 0xA1, 0xE0,
+0xCC, 0xE8, 0x91, 0x67, 0x4C, 0xED, 0xD0, 0x67,
+0x00, 0x18, 0x44, 0x39, 0x1D, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF6, 0x98, 0x9C, 0x07, 0x68,
+0xE0, 0xA4, 0x80, 0xA4, 0x8C, 0xE8, 0x10, 0x6C,
+0xEC, 0xEC, 0x0C, 0x30, 0x4C, 0xEC, 0x4C, 0xE8,
+0x0C, 0x24, 0x92, 0xA3, 0x02, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x4C, 0xEB, 0xFC, 0x73, 0x02, 0x60,
+0xFE, 0x73, 0x03, 0x61, 0x07, 0x45, 0x21, 0x48,
+0x03, 0x10, 0x18, 0x48, 0xA1, 0xE0, 0xCC, 0xE8,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0xB2, 0x47,
+0x04, 0x93, 0x22, 0x67, 0xFF, 0x6A, 0x01, 0x4B,
+0x4C, 0xEB, 0x04, 0xD3, 0x04, 0x92, 0x05, 0x93,
+0x63, 0xEA, 0xA9, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF6, 0x4C, 0x9A, 0x40, 0xA2, 0x0A, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x64, 0x9A, 0x00, 0xF2, 0x00, 0x6C,
+0x8D, 0xEB, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x64, 0x9A,
+0x00, 0xF2, 0x01, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xC0, 0x39,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0xFF, 0x74, 0xAC, 0xEA,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0xC9, 0xF5,
+0x5A, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x43, 0xF3, 0xBA, 0xA3,
+0x8C, 0xEA, 0x8F, 0xEC, 0xAC, 0xEC, 0x8D, 0xEA,
+0x43, 0xF3, 0x5A, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x68, 0x26, 0x67, 0x0C, 0xE9, 0x53, 0x71,
+0x0C, 0xEC, 0x0C, 0xED, 0x09, 0x60, 0x06, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0xC9, 0xF5, 0x59, 0xA2,
+0xAD, 0xEA, 0x0B, 0x10, 0x00, 0x18, 0x0C, 0x3A,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x43, 0xF3, 0x7A, 0xA2, 0x43, 0xF3, 0x59, 0xA2,
+0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x60, 0x9B, 0x0C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xC9, 0xF5, 0x37, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x01, 0x6A, 0xA3, 0xF3, 0xA1, 0xA3, 0x4B, 0xEA,
+0x83, 0xF3, 0x5C, 0xC3, 0x04, 0x6A, 0x00, 0x6C,
+0x4B, 0xEA, 0xAC, 0xEA, 0x83, 0xF3, 0x9E, 0xCB,
+0xA3, 0xF3, 0x80, 0xC3, 0x02, 0x6D, 0xA3, 0xF3,
+0x82, 0xCB, 0x09, 0x6C, 0x8B, 0xEC, 0xAD, 0xEA,
+0x8C, 0xEA, 0x04, 0x4C, 0x8C, 0xEA, 0xA3, 0xF3,
+0x41, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3, 0xC0, 0xA3,
+0x3F, 0x6D, 0x30, 0xF0, 0x20, 0x6A, 0xBB, 0xEE,
+0x01, 0x2D, 0xE5, 0xE8, 0xC1, 0xF4, 0x5C, 0x9A,
+0x49, 0xE4, 0x10, 0xED, 0xA8, 0x35, 0xA0, 0xC2,
+0xA3, 0xF3, 0x40, 0xA3, 0x01, 0x4A, 0xA3, 0xF3,
+0x40, 0xC3, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x00, 0x18,
+0xEC, 0x1F, 0x01, 0xE2, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE8, 0x1C, 0x30, 0x00, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6D, 0x41, 0xF4,
+0x80, 0x9A, 0xE1, 0xF4, 0xA4, 0x9D, 0x68, 0x32,
+0x91, 0xE0, 0xB5, 0xE0, 0x51, 0xE4, 0x49, 0xE5,
+0x40, 0x9A, 0x01, 0x4B, 0x14, 0x73, 0x40, 0xDC,
+0xEE, 0x61, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD0, 0xA7, 0x44, 0x01, 0x4D, 0x04, 0x04,
+0x08, 0x6E, 0x00, 0x18, 0xB9, 0x20, 0x9D, 0x67,
+0x50, 0xA4, 0x01, 0x6B, 0x4C, 0xEB, 0x1F, 0x23,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xA3, 0xF3, 0x61, 0xA0, 0x08, 0x6A, 0x6D, 0xEA,
+0xA3, 0xF3, 0x41, 0xC0, 0x52, 0xA4, 0x71, 0xA4,
+0x83, 0xF3, 0x5C, 0xC0, 0x05, 0x6A, 0x58, 0xEB,
+0x83, 0xF3, 0x9C, 0xA0, 0x12, 0xEA, 0x83, 0xF3,
+0x5E, 0xC8, 0x00, 0x18, 0x49, 0x3A, 0x83, 0xF3,
+0xDE, 0xA8, 0xFF, 0x6C, 0x5D, 0x4C, 0x00, 0x6D,
+0x00, 0x18, 0x04, 0x31, 0x17, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3,
+0xA1, 0xA2, 0x09, 0x6C, 0x8B, 0xEC, 0xAC, 0xEC,
+0xA3, 0xF3, 0x81, 0xC2, 0x01, 0x6C, 0x8B, 0xEC,
+0x83, 0xF3, 0x7E, 0xCA, 0x83, 0xF3, 0x9C, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6, 0x5C, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x07, 0x97, 0x06, 0x90,
+0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF6, 0x60, 0x9A, 0x7F, 0x6A,
+0x01, 0x68, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF6, 0x44, 0x9A,
+0x60, 0xA2, 0xFF, 0x6A, 0x6C, 0xE8, 0x2A, 0x20,
+0x30, 0xF0, 0x20, 0x6B, 0x29, 0xF6, 0x81, 0xA3,
+0x04, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x22, 0x23,
+0x03, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x01, 0x73,
+0x0B, 0x60, 0x02, 0x73, 0x11, 0x60, 0x1A, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF2, 0x9C, 0x9B,
+0x02, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0x0F, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF2, 0x9C, 0x9B,
+0x06, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0x07, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF2, 0x9C, 0x9B,
+0x0E, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x81, 0xA2,
+0x05, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xA3, 0xF3,
+0x61, 0xC2, 0x90, 0x67, 0x00, 0x18, 0x95, 0x6C,
+0x5D, 0x67, 0x7D, 0x67, 0x12, 0xC2, 0x02, 0x6A,
+0x50, 0xC3, 0x01, 0x6A, 0x4F, 0xCB, 0x04, 0x04,
+0x00, 0x18, 0xBC, 0x27, 0x09, 0x97, 0x08, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x40, 0x9A, 0xFF, 0x69, 0x00, 0x68,
+0x40, 0xA2, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF6, 0x68, 0x9A, 0xEE, 0xF1, 0x1F, 0x6A,
+0x80, 0xAB, 0x8C, 0xEA, 0x10, 0xF0, 0x00, 0x6C,
+0x8B, 0xEC, 0x8D, 0xEA, 0xFF, 0xF7, 0x1F, 0x6C,
+0x8C, 0xEA, 0x40, 0xCB, 0x15, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3,
+0x81, 0xA2, 0x08, 0x6B, 0x8C, 0xEB, 0x05, 0x2B,
+0xFB, 0x4B, 0x8C, 0xEB, 0xA3, 0xF3, 0x61, 0xC2,
+0x5C, 0x10, 0x01, 0x6C, 0x00, 0x18, 0x95, 0x20,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0x48, 0x9A,
+0x60, 0xAA, 0x02, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0xC0, 0xF7, 0x10, 0x70, 0xDF, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x09, 0xF6, 0x9C, 0xA2,
+0x01, 0x6D, 0x05, 0x6E, 0x08, 0x6F, 0x00, 0x18,
+0x53, 0x56, 0x02, 0x67, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF4, 0x44, 0x9A, 0x49, 0xE0, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0x54, 0x72, 0x03, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x3D, 0x3A, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0x58, 0x9A, 0x6F, 0x6D,
+0x2C, 0xED, 0x41, 0xE0, 0x60, 0xA0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xFF, 0x6A,
+0xA3, 0xF3, 0x81, 0xA0, 0x4C, 0xEB, 0x76, 0x33,
+0x03, 0x6A, 0x4C, 0xEB, 0xF9, 0x4A, 0x8C, 0xEA,
+0x6D, 0xEA, 0xA3, 0xF3, 0x41, 0xC0, 0x90, 0x6C,
+0x19, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0xA3, 0xF3,
+0x61, 0xA0, 0x08, 0x6A, 0xFF, 0x6C, 0x6C, 0xEA,
+0x8C, 0xEA, 0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF6, 0x4C, 0x9A, 0x20, 0x6C, 0x80, 0xC2,
+0xA3, 0xF3, 0x42, 0xA8, 0x01, 0x4A, 0xA3, 0xF3,
+0x42, 0xC8, 0x04, 0x6A, 0x6D, 0xEA, 0xA3, 0xF3,
+0x41, 0xC0, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xA3, 0xF3, 0x61, 0xA0, 0x08, 0x6A,
+0x6C, 0xEA, 0x17, 0x22, 0x00, 0x18, 0xAD, 0x3A,
+0x83, 0xF3, 0xDE, 0xA8, 0x06, 0x26, 0xFF, 0x6C,
+0x5D, 0x4C, 0x00, 0x6D, 0x00, 0x18, 0x04, 0x31,
+0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6,
+0x5C, 0x9A, 0xC0, 0xC2, 0xA3, 0xF3, 0x61, 0xA0,
+0x09, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xA3, 0xF3,
+0x41, 0xC0, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x64, 0x9A,
+0x10, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x4A, 0xF1, 0x45, 0xA2, 0xFF, 0x63, 0x05, 0x5A,
+0x2C, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32,
+0x00, 0xF7, 0x00, 0x4B, 0x4D, 0xE3, 0x40, 0x9B,
+0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x50, 0x9A, 0xFF, 0xF7, 0x1F, 0x6B, 0x40, 0x9A,
+0x1A, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x50, 0x9A, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF6, 0x50, 0x9A, 0x0D, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF6, 0x50, 0x9A, 0x40, 0x9A,
+0x50, 0x32, 0x00, 0xF5, 0x42, 0x32, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF6, 0x54, 0x9A,
+0x40, 0x9A, 0xE1, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x01, 0x10, 0x64, 0x6A, 0x00, 0xD2, 0x00, 0x92,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD0,
+0x0C, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7,
+0x84, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x5D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC3, 0xF6, 0xA4, 0xA2, 0x03, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0xC3, 0xF6, 0x64, 0xC2,
+0xC3, 0xF6, 0xC8, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x6A, 0xF1, 0x04, 0x4A, 0x00, 0x6D, 0x18, 0x6F,
+0xF8, 0xED, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0x12, 0xEF, 0x6D, 0xE7, 0xC3, 0xF6,
+0x18, 0xA3, 0x01, 0x6F, 0xEC, 0xE8, 0x23, 0x20,
+0xC3, 0xF6, 0x78, 0xA3, 0x66, 0x33, 0xEC, 0xEB,
+0xFF, 0x6F, 0xEC, 0xEB, 0x1C, 0x23, 0xFF, 0xF7,
+0x78, 0x9A, 0x9B, 0xEB, 0x01, 0x2C, 0xE5, 0xE8,
+0x12, 0xEB, 0xFF, 0xF7, 0x7C, 0xDA, 0x10, 0xEF,
+0x03, 0x27, 0x01, 0x4B, 0xFF, 0xF7, 0x7C, 0xDA,
+0x60, 0x9A, 0x78, 0xEE, 0x12, 0xEB, 0x9B, 0xEB,
+0x01, 0x2C, 0xE5, 0xE8, 0x12, 0xEB, 0x60, 0xDA,
+0xFF, 0xF7, 0x7C, 0x9A, 0x04, 0x2B, 0x01, 0x6F,
+0xFF, 0xF7, 0xFC, 0xDA, 0x60, 0xDA, 0x01, 0x4D,
+0x0A, 0x75, 0x18, 0x4A, 0xCC, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF6,
+0x6C, 0x9A, 0xC3, 0xF6, 0x88, 0xDA, 0x7B, 0xEC,
+0x01, 0x2B, 0xE5, 0xE8, 0xC3, 0xF6, 0x84, 0xA2,
+0x12, 0xEB, 0xC3, 0xF6, 0x70, 0xDA, 0x78, 0x67,
+0xC3, 0xF6, 0x74, 0xDA, 0x02, 0x6B, 0x8D, 0xEB,
+0xC3, 0xF6, 0x64, 0xC2, 0x01, 0x90, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xC3, 0xF6, 0xA4, 0xA3,
+0x02, 0x6C, 0x00, 0x6A, 0xAC, 0xEC, 0x0C, 0x24,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF6, 0x58, 0x9A,
+0x00, 0x6C, 0x80, 0xC2, 0x03, 0x6A, 0x4B, 0xEA,
+0xAC, 0xEA, 0xC3, 0xF6, 0x44, 0xC3, 0x01, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x00, 0x6A, 0x18, 0x6C,
+0x98, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0x01, 0x4A, 0x0A, 0x72, 0x12, 0xEC,
+0x71, 0xE4, 0xC3, 0xF6, 0xB8, 0xA4, 0x02, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0xC3, 0xF6, 0x78, 0xC4,
+0xEE, 0x61, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x4A, 0xF1, 0x44, 0xA2, 0x01, 0x6B, 0x4C, 0xEB,
+0x00, 0x6A, 0x1C, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0x6A, 0xF1, 0x08, 0x4A, 0x00, 0x6B, 0xA0, 0x9A,
+0x8E, 0xED, 0x0F, 0x2D, 0x18, 0x6E, 0xD8, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0x86, 0xF2, 0x00, 0x4D,
+0x12, 0xEE, 0xB9, 0xE6, 0xC3, 0xF6, 0xF8, 0xA6,
+0x02, 0x6D, 0xAB, 0xED, 0xEC, 0xED, 0xC3, 0xF6,
+0xB8, 0xC6, 0x01, 0x4B, 0x0A, 0x73, 0x18, 0x4A,
+0xEA, 0x61, 0x01, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x5D, 0x67, 0x0A, 0xD4, 0x20, 0xF0, 0x98, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x0B, 0xD5, 0x0C, 0xD6,
+0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF6, 0xA4, 0xA2,
+0x01, 0x6B, 0x00, 0xF6, 0xE0, 0x31, 0xAC, 0xEB,
+0x00, 0xF6, 0x23, 0x31, 0x80, 0xF0, 0x09, 0x23,
+0x21, 0x24, 0x01, 0x74, 0x80, 0xF0, 0x05, 0x61,
+0x0A, 0x93, 0x80, 0xF0, 0x02, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF6, 0x7C, 0x9B, 0xC3, 0xEB,
+0x7C, 0x61, 0x7F, 0x71, 0x7A, 0x60, 0xFF, 0xF7,
+0x1F, 0x51, 0x77, 0x61, 0xC3, 0xF6, 0x08, 0x9A,
+0x1B, 0xEE, 0x01, 0x28, 0xE5, 0xE8, 0x10, 0xEA,
+0x12, 0xE8, 0x02, 0x22, 0x01, 0x48, 0x04, 0x10,
+0x03, 0x28, 0x01, 0x68, 0x50, 0x67, 0x1D, 0x10,
+0x01, 0x6B, 0x1E, 0x10, 0x0A, 0x94, 0x65, 0x24,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF6, 0x7C, 0x9B,
+0x0C, 0x95, 0xA3, 0xEB, 0x5E, 0x61, 0x7F, 0x71,
+0x5C, 0x60, 0xFF, 0xF7, 0x1F, 0x51, 0x59, 0x61,
+0xC3, 0xF6, 0x0C, 0x9A, 0x1B, 0xED, 0x01, 0x28,
+0xE5, 0xE8, 0x10, 0xEA, 0x12, 0xE8, 0x02, 0x22,
+0x01, 0x48, 0x05, 0x10, 0x04, 0x28, 0x01, 0x68,
+0x00, 0x6A, 0x04, 0xD2, 0x02, 0x10, 0x00, 0x6B,
+0x04, 0xD3, 0x0A, 0x94, 0x00, 0x18, 0x77, 0x3B,
+0x00, 0x6C, 0xFF, 0x6E, 0xA4, 0x67, 0xCC, 0xED,
+0x1D, 0x65, 0x18, 0x6D, 0xB8, 0xEC, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x01, 0x6D,
+0x12, 0xEA, 0x69, 0xE2, 0xC3, 0xF6, 0x58, 0xA2,
+0xAC, 0xEA, 0xCC, 0xEA, 0x2F, 0x2A, 0xD8, 0x67,
+0x18, 0x6F, 0xF8, 0xEE, 0x04, 0x96, 0xC4, 0x36,
+0x04, 0xD6, 0x03, 0x6E, 0xCB, 0xEE, 0x12, 0xEC,
+0x71, 0xE4, 0xC3, 0xF6, 0xF8, 0xA4, 0xEC, 0xEE,
+0x04, 0x97, 0xED, 0xEE, 0xC3, 0xF6, 0xD8, 0xC4,
+0x0A, 0x96, 0xE3, 0xF6, 0xC8, 0xDC, 0x0B, 0x97,
+0xE3, 0xF6, 0xEC, 0xDC, 0x0C, 0x96, 0x18, 0x6F,
+0xC3, 0xF6, 0xDC, 0xDC, 0xD8, 0x67, 0x01, 0x4E,
+0xF8, 0xEE, 0x12, 0xEE, 0x6D, 0xE6, 0xC3, 0xF6,
+0x4C, 0xDB, 0xC3, 0xF6, 0x08, 0xDB, 0xC3, 0xF6,
+0x59, 0xC4, 0xC3, 0xF6, 0x58, 0xA4, 0xC3, 0xF6,
+0x3A, 0xC4, 0x4D, 0xED, 0xC3, 0xF6, 0xB8, 0xC4,
+0x01, 0x6A, 0x04, 0x10, 0x01, 0x4C, 0x0A, 0x74,
+0xBC, 0x61, 0x00, 0x6A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x6A, 0xF1,
+0x04, 0x4A, 0x00, 0x6C, 0x4A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x6A, 0xF1, 0x04, 0x4A, 0x00, 0x6B,
+0x18, 0x6D, 0xB8, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0x86, 0xF2, 0x00, 0x4C, 0x12, 0xED, 0x91, 0xE5,
+0xC3, 0xF6, 0xD8, 0xA4, 0x01, 0x6D, 0xAC, 0xEE,
+0x08, 0x26, 0xC3, 0xF6, 0x98, 0xA4, 0x86, 0x34,
+0xAC, 0xEC, 0x03, 0x24, 0x80, 0x9A, 0x01, 0x4C,
+0x80, 0xDA, 0x01, 0x4B, 0x0A, 0x73, 0x18, 0x4A,
+0xE7, 0x61, 0x00, 0x18, 0x0D, 0x3B, 0x04, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x79, 0xA2, 0xC3, 0xF6, 0xA5, 0xA2,
+0xFF, 0x6C, 0x76, 0x33, 0xAE, 0xEB, 0x12, 0x2B,
+0xA0, 0xF0, 0xB6, 0xA2, 0x7F, 0x6B, 0xAC, 0xEB,
+0x8C, 0xEB, 0x0C, 0x23, 0xA0, 0xF0, 0xB7, 0xA2,
+0x0F, 0x6B, 0xAC, 0xEB, 0x8C, 0xEB, 0x06, 0x23,
+0x04, 0x93, 0xE3, 0xF4, 0x50, 0xA2, 0x78, 0xEA,
+0x12, 0xEA, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x93, 0x4A, 0xF1, 0x48, 0x9A, 0x6E, 0xEA,
+0x52, 0x22, 0x04, 0x94, 0x00, 0x18, 0x29, 0x3B,
+0x4E, 0x10, 0x18, 0x6D, 0xB8, 0xEC, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x12, 0xED,
+0x6D, 0xE5, 0xC3, 0xF6, 0xD8, 0xA3, 0x01, 0x6D,
+0xAC, 0xEE, 0x0A, 0x26, 0xC3, 0xF6, 0x78, 0xA3,
+0x66, 0x33, 0xAC, 0xEB, 0xFF, 0x6D, 0xAC, 0xEB,
+0x03, 0x2B, 0x60, 0x9A, 0x01, 0x4B, 0x60, 0xDA,
+0x01, 0x4C, 0x0A, 0x74, 0x18, 0x4A, 0xE5, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF6, 0x65, 0xA2, 0xFF, 0x73, 0x2B, 0x61,
+0xC3, 0xF6, 0x74, 0x9A, 0x01, 0x4B, 0xC3, 0xF6,
+0x74, 0xDA, 0xC3, 0xF6, 0x50, 0x9A, 0x4E, 0xEB,
+0x22, 0x2B, 0x30, 0xF0, 0x20, 0x6A, 0x6A, 0xF1,
+0x04, 0x4A, 0x18, 0x6D, 0xB8, 0xEB, 0x30, 0xF0,
+0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C, 0x12, 0xED,
+0x91, 0xE5, 0xC3, 0xF6, 0xD8, 0xA4, 0x01, 0x6D,
+0xAC, 0xEE, 0x08, 0x26, 0xC3, 0xF6, 0x98, 0xA4,
+0x86, 0x34, 0xAC, 0xEC, 0x03, 0x24, 0x80, 0x9A,
+0x01, 0x4C, 0x80, 0xDA, 0x01, 0x4B, 0x0A, 0x73,
+0x18, 0x4A, 0xE7, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x78, 0x67, 0x4A, 0xF1, 0x74, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x64, 0x9A, 0x02, 0xF0, 0x00, 0x6C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x07, 0x97, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x4A, 0xF1, 0x19, 0x48, 0x00, 0x69, 0x18, 0x6A,
+0x58, 0xE9, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0x12, 0xEA, 0x69, 0xE2, 0xC3, 0xF6,
+0x98, 0xA2, 0x01, 0x6B, 0x8C, 0xEB, 0x27, 0x23,
+0x00, 0xF0, 0x8B, 0x98, 0x00, 0xF0, 0x67, 0x98,
+0x63, 0xEC, 0x21, 0x61, 0x61, 0x80, 0x81, 0x43,
+0x04, 0xD4, 0x07, 0x2C, 0x00, 0xF0, 0x4F, 0x98,
+0x00, 0xF0, 0x93, 0x98, 0x40, 0xEA, 0x04, 0x92,
+0x14, 0x10, 0x80, 0xA0, 0x01, 0x4C, 0x80, 0xC0,
+0x80, 0xA0, 0x82, 0xEB, 0x08, 0x60, 0xC3, 0xF6,
+0x98, 0xA2, 0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xC3, 0xF6, 0x78, 0xC2, 0x08, 0x10, 0x00, 0xF0,
+0x4F, 0x98, 0x00, 0xF0, 0x93, 0x98, 0x40, 0xEA,
+0x00, 0x6A, 0x00, 0xF0, 0x4B, 0xD8, 0x01, 0x49,
+0x0A, 0x71, 0x18, 0x48, 0xC8, 0x61, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xC3, 0xF6,
+0x84, 0xA0, 0x01, 0x6B, 0x00, 0x6A, 0x8C, 0xEB,
+0x1F, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF6,
+0x58, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x03, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0xC3, 0xF6, 0x44, 0xC0,
+0x00, 0x18, 0x0D, 0x3B, 0x04, 0xD2, 0x04, 0x94,
+0x00, 0x18, 0x29, 0x3B, 0xC3, 0xF6, 0x64, 0xA0,
+0xC3, 0xF6, 0xCC, 0x98, 0x02, 0x6A, 0x6D, 0xEA,
+0x42, 0xF1, 0x1C, 0x6C, 0x01, 0x6D, 0xC3, 0xF6,
+0x44, 0xC0, 0x00, 0x18, 0x04, 0x31, 0x01, 0x6A,
+0x07, 0x97, 0x06, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xC3, 0xF6,
+0x44, 0xA0, 0x03, 0x6B, 0x4C, 0xEB, 0x00, 0x6A,
+0x23, 0x2B, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF6,
+0x58, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xFF, 0x6E,
+0x60, 0xC2, 0x4A, 0xF1, 0x04, 0x4C, 0x00, 0x6D,
+0x05, 0x4E, 0x00, 0x18, 0xB4, 0x20, 0x64, 0x6A,
+0xC3, 0xF6, 0x48, 0xD8, 0xC3, 0xF6, 0x50, 0xD8,
+0x01, 0x6A, 0x4B, 0xEA, 0xC3, 0xF6, 0x84, 0xA0,
+0xC3, 0xF6, 0x45, 0xC0, 0x7D, 0x6A, 0x4B, 0xEA,
+0x01, 0x6B, 0x8C, 0xEA, 0x6D, 0xEA, 0xC3, 0xF6,
+0x44, 0xC0, 0xC3, 0xF6, 0x6C, 0xD8, 0x43, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA7, 0x44, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0x4D,
+0x0C, 0xF5, 0x0C, 0x4C, 0x14, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xE0, 0x63, 0x3F, 0x62, 0xFF, 0xF7, 0x1F, 0x6A,
+0x01, 0x6B, 0xAC, 0xEA, 0x6B, 0xEB, 0xBD, 0x67,
+0x70, 0xC5, 0x03, 0x6B, 0x72, 0xC5, 0x56, 0xC5,
+0x04, 0x6B, 0x42, 0x32, 0x94, 0xC5, 0x73, 0xC5,
+0x57, 0xC5, 0x04, 0x04, 0x00, 0x18, 0x33, 0x27,
+0x3F, 0x97, 0x20, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x04, 0x67, 0x25, 0x67, 0x4C, 0xE8,
+0x4C, 0xE9, 0x4C, 0xEE, 0xB1, 0x67, 0x90, 0x67,
+0x04, 0xD6, 0x00, 0x18, 0x30, 0x47, 0x90, 0x67,
+0x00, 0x18, 0xAD, 0x79, 0x04, 0x97, 0x30, 0xF0,
+0x20, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x4C, 0xF6,
+0x08, 0x4C, 0x00, 0x18, 0xFB, 0x80, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x04, 0x67, 0x30, 0xF0, 0x20, 0x69, 0x00, 0x18,
+0x8D, 0x3C, 0x47, 0xA0, 0x66, 0xA0, 0x86, 0xF2,
+0x00, 0x49, 0x86, 0xF2, 0x8C, 0xA1, 0x40, 0x32,
+0x69, 0xE2, 0x01, 0x6B, 0x8C, 0xEB, 0x86, 0xF2,
+0x5E, 0xC9, 0xFF, 0x6A, 0x15, 0x2B, 0xA6, 0xF2,
+0x60, 0xC1, 0x02, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB,
+0x40, 0x23, 0x86, 0xF2, 0x6F, 0xA1, 0x0F, 0x6D,
+0x86, 0xF2, 0x90, 0xA1, 0x6C, 0xED, 0x72, 0x36,
+0x4C, 0xED, 0x4C, 0xEE, 0x00, 0x18, 0xA0, 0x3C,
+0x01, 0x72, 0x0D, 0x6A, 0x33, 0x61, 0x31, 0x10,
+0x86, 0xF2, 0x5C, 0xA9, 0x00, 0x6B, 0xA6, 0xF2,
+0x60, 0xC1, 0x00, 0xF1, 0x01, 0x5A, 0x0C, 0x6A,
+0x29, 0x60, 0x00, 0x6A, 0x86, 0xF2, 0x0D, 0xA1,
+0xA6, 0xF2, 0x61, 0xC1, 0xA6, 0xF2, 0x62, 0xC1,
+0xA6, 0xF2, 0x44, 0xC9, 0xA6, 0xF2, 0x46, 0xC9,
+0x00, 0x18, 0xEC, 0x1F, 0x01, 0xE2, 0x00, 0x6A,
+0x86, 0xF2, 0xFC, 0xA9, 0x82, 0x67, 0x04, 0xD2,
+0x05, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF6,
+0xA0, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0xC4, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x2C, 0xF5,
+0x0D, 0x4B, 0x1C, 0x30, 0xB5, 0xE0, 0xD9, 0xE3,
+0x00, 0x18, 0xB4, 0x1E, 0x01, 0x6A, 0xA6, 0xF2,
+0x40, 0xC1, 0x00, 0x6A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xA6, 0xF2, 0xA4, 0xA8, 0x30, 0xF0, 0x20, 0x6A,
+0x2C, 0xF5, 0x0D, 0x4A, 0x30, 0xF0, 0x20, 0x6C,
+0x2C, 0xF6, 0x10, 0x4C, 0xB5, 0xE2, 0x04, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0xA6, 0xF3, 0x73, 0xA0,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x05, 0x2A, 0xA6, 0xF2, 0x44, 0xA8,
+0x04, 0x4A, 0xA6, 0xF2, 0x44, 0xC8, 0x30, 0xF0,
+0x20, 0x69, 0x86, 0xF2, 0x00, 0x49, 0xA6, 0xF3,
+0x51, 0xA1, 0xA6, 0xF3, 0x90, 0xA1, 0x0F, 0x6D,
+0x4C, 0xED, 0x52, 0x36, 0x00, 0x18, 0xA0, 0x3C,
+0x02, 0x67, 0x06, 0x2A, 0x00, 0x18, 0x5D, 0x47,
+0xA6, 0xF2, 0x00, 0xC1, 0x01, 0x6C, 0x4D, 0x10,
+0xA6, 0xF3, 0x73, 0xA1, 0x7F, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x13, 0x22, 0x01, 0x72,
+0x40, 0x61, 0x00, 0x6C, 0x00, 0x18, 0x15, 0x4F,
+0x43, 0x22, 0x86, 0xF2, 0x81, 0xA1, 0x01, 0x6D,
+0x18, 0x6E, 0x00, 0x6F, 0x00, 0x18, 0x53, 0x56,
+0x00, 0x18, 0xA8, 0x56, 0x03, 0x2A, 0x00, 0x18,
+0x5D, 0x47, 0x36, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA6, 0xF2, 0x61, 0xA2,
+0xA6, 0xF3, 0x92, 0xA2, 0x01, 0x4B, 0xA6, 0xF2,
+0x61, 0xC2, 0xA6, 0xF2, 0x66, 0xAA, 0x6D, 0xE4,
+0xA6, 0xF2, 0x66, 0xCA, 0xA6, 0xF2, 0x81, 0xA2,
+0x86, 0xF2, 0x6E, 0xA2, 0x8E, 0xEB, 0x09, 0x2B,
+0x10, 0xF0, 0x21, 0x6C, 0xA6, 0xF3, 0xD2, 0xA2,
+0xFE, 0xF4, 0x05, 0x4C, 0x04, 0xD3, 0x00, 0x6D,
+0x09, 0x10, 0xA6, 0xF3, 0xD2, 0xA2, 0x10, 0xF0,
+0x21, 0x6C, 0x00, 0x6A, 0x04, 0xD2, 0xBE, 0xF4,
+0x1D, 0x4C, 0xA2, 0x67, 0x64, 0x6A, 0x58, 0xEE,
+0x01, 0x6F, 0x12, 0xEE, 0x00, 0x18, 0x8A, 0x3B,
+0x13, 0x10, 0x00, 0x6A, 0xA6, 0xF2, 0x40, 0xC1,
+0x02, 0x6C, 0x86, 0xF2, 0xBE, 0xA9, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x86, 0xF2, 0xBE, 0xAA, 0x00, 0x6B, 0xA6, 0xF2,
+0x60, 0xC2, 0x03, 0x6C, 0x00, 0x18, 0x94, 0x3C,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA6, 0xF2, 0x60, 0xA2, 0x08, 0x23, 0xA6, 0xF3,
+0x6D, 0xA2, 0x03, 0x23, 0x00, 0x6B, 0xA6, 0xF3,
+0x6D, 0xC2, 0x00, 0x18, 0xE2, 0x3C, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x69,
+0x86, 0xF2, 0x00, 0x49, 0xA6, 0xF2, 0x40, 0xA1,
+0x00, 0xF1, 0x03, 0x22, 0x86, 0xF2, 0x8C, 0xA1,
+0x03, 0x6D, 0xFF, 0x6A, 0x8E, 0x33, 0xAC, 0xEB,
+0x02, 0x73, 0x76, 0x60, 0x05, 0x67, 0x6E, 0xE8,
+0xC0, 0xF0, 0x1A, 0x20, 0x01, 0x73, 0x1D, 0x60,
+0x00, 0x6B, 0xA6, 0xF2, 0x60, 0xC1, 0x02, 0x6B,
+0x8C, 0xEB, 0x4C, 0xEB, 0x0E, 0x23, 0x86, 0xF2,
+0x6F, 0xA1, 0x86, 0xF2, 0x90, 0xA1, 0x0F, 0x6D,
+0x6C, 0xED, 0x72, 0x36, 0x4C, 0xED, 0x4C, 0xEE,
+0x00, 0x18, 0xA0, 0x3C, 0x01, 0x72, 0x01, 0x6C,
+0x01, 0x61, 0x00, 0x6C, 0x86, 0xF2, 0xBE, 0xA9,
+0x00, 0x18, 0x94, 0x3C, 0x00, 0x18, 0x5D, 0x47,
+0xD8, 0x10, 0x02, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB,
+0x0E, 0x23, 0x86, 0xF2, 0x6F, 0xA1, 0x0F, 0x6D,
+0x86, 0xF2, 0x90, 0xA1, 0x6C, 0xED, 0x72, 0x36,
+0x4C, 0xED, 0x4C, 0xEE, 0x00, 0x18, 0xA0, 0x3C,
+0x01, 0x72, 0xA0, 0xF0, 0x1A, 0x61, 0x86, 0xF2,
+0xBE, 0xA9, 0x00, 0x6C, 0x00, 0x18, 0x94, 0x3C,
+0x30, 0xF0, 0x20, 0x6A, 0x0C, 0xF5, 0x51, 0xA2,
+0x5A, 0x33, 0x02, 0x73, 0x0D, 0x60, 0x03, 0x73,
+0x0F, 0x60, 0x01, 0x73, 0x05, 0x60, 0x3F, 0x6E,
+0x4C, 0xEE, 0xFF, 0x6A, 0x4C, 0xEE, 0x0E, 0x10,
+0x3F, 0x6B, 0x4C, 0xEB, 0x0A, 0x6E, 0x08, 0x10,
+0x3F, 0x6B, 0x4C, 0xEB, 0x64, 0x6E, 0x04, 0x10,
+0x3F, 0x6B, 0x4C, 0xEB, 0xE0, 0xF3, 0x08, 0x6E,
+0xD8, 0xEB, 0x12, 0xEE, 0x0A, 0x6A, 0x58, 0xEE,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA6, 0xF2, 0x66, 0xAA, 0x10, 0xF0, 0x21, 0x6C,
+0xBE, 0xF4, 0x1D, 0x4C, 0x12, 0xEE, 0x7B, 0xE6,
+0x01, 0x6B, 0xA6, 0xF3, 0x6D, 0xC2, 0x00, 0x6B,
+0xA6, 0xF2, 0x61, 0xC2, 0x00, 0x6B, 0xA6, 0xF2,
+0x66, 0xCA, 0xA6, 0xF2, 0x64, 0xCA, 0x00, 0x6A,
+0x04, 0xD2, 0xA2, 0x67, 0x64, 0x6A, 0x62, 0x10,
+0x02, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x0D, 0x23,
+0x86, 0xF2, 0x6F, 0xA1, 0x0F, 0x6D, 0x86, 0xF2,
+0x90, 0xA1, 0x6C, 0xED, 0x72, 0x36, 0x4C, 0xED,
+0x4C, 0xEE, 0x00, 0x18, 0xA0, 0x3C, 0x01, 0x72,
+0x68, 0x61, 0x86, 0xF2, 0xBE, 0xA9, 0x00, 0x6C,
+0x00, 0x18, 0x94, 0x3C, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x86, 0xF2, 0x93, 0xA2,
+0xA6, 0xF2, 0x62, 0xA2, 0xFF, 0x4C, 0x6E, 0xEC,
+0x03, 0x2C, 0x86, 0xF2, 0x72, 0xA2, 0x05, 0x10,
+0x01, 0x4B, 0xA6, 0xF2, 0x62, 0xC2, 0x86, 0xF2,
+0x71, 0xA2, 0x7A, 0x32, 0x02, 0x72, 0x0D, 0x60,
+0x03, 0x72, 0x0F, 0x60, 0x01, 0x72, 0x05, 0x60,
+0x3F, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x0E, 0x10, 0x3F, 0x6A, 0x6C, 0xEA, 0x0A, 0x6B,
+0x08, 0x10, 0x3F, 0x6A, 0x6C, 0xEA, 0x64, 0x6B,
+0x04, 0x10, 0x3F, 0x6A, 0x6C, 0xEA, 0xE0, 0xF3,
+0x08, 0x6B, 0x78, 0xEA, 0x12, 0xEA, 0x0A, 0x6B,
+0x78, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x2C, 0xF5,
+0x66, 0xAB, 0x01, 0x6C, 0x64, 0x6E, 0x12, 0xEA,
+0x6B, 0xE2, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA6, 0xF3, 0x8D, 0xC3, 0x00, 0x6C,
+0xA6, 0xF2, 0x81, 0xC3, 0x00, 0x6C, 0xA6, 0xF2,
+0x86, 0xCB, 0xA6, 0xF2, 0x84, 0xCB, 0x00, 0x6B,
+0x10, 0xF0, 0x21, 0x6C, 0x04, 0xD3, 0xBE, 0xF4,
+0x1D, 0x4C, 0xA3, 0x67, 0xD8, 0xEA, 0x01, 0x6F,
+0x12, 0xEE, 0x00, 0x18, 0x8A, 0x3B, 0x1D, 0x10,
+0x86, 0xF2, 0xBE, 0xA9, 0x00, 0x6C, 0x00, 0x18,
+0x94, 0x3C, 0x01, 0x6A, 0xA6, 0xF2, 0x01, 0xC1,
+0xA6, 0xF2, 0x06, 0xC9, 0xA6, 0xF2, 0x04, 0xC9,
+0xA6, 0xF3, 0x4D, 0xC1, 0x00, 0x18, 0x2F, 0x3D,
+0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x86, 0xF2, 0xBE, 0xAA, 0x00, 0x6B,
+0xA6, 0xF2, 0x60, 0xC2, 0x01, 0x6C, 0x00, 0x18,
+0x94, 0x3C, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6B,
+0x09, 0xF6, 0x71, 0xA3, 0xFF, 0x6A, 0xAC, 0xEA,
+0x03, 0x23, 0x02, 0x73, 0x11, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7, 0x68, 0x9B,
+0x83, 0xEB, 0x05, 0x60, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF6, 0x64, 0x9B, 0x09, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF4, 0x78, 0x9B, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF2, 0x6C, 0x9B,
+0x71, 0xE4, 0x40, 0xC4, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x09, 0xF6, 0x71, 0xA3,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA, 0x03, 0x23,
+0x02, 0x73, 0x11, 0x60, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF7, 0x68, 0x9B, 0x83, 0xEB,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF6,
+0x64, 0x9B, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF4, 0x78, 0x9B, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF2, 0x6C, 0x9B, 0x71, 0xE4,
+0x40, 0xCC, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x09, 0xF6, 0x51, 0xA2, 0x03, 0x22, 0x02, 0x72,
+0x11, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x48, 0x9A, 0x83, 0xEA, 0x05, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF6, 0x44, 0x9A,
+0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x4C, 0x9A, 0x51, 0xE4, 0xA0, 0xDC,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x09, 0xF6, 0x51, 0xA2, 0x04, 0x22, 0x02, 0x72,
+0x00, 0x6A, 0x1D, 0x61, 0x14, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x48, 0x9A, 0x83, 0xEA,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF6,
+0x44, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF4, 0x58, 0x9A, 0x51, 0xE4, 0x60, 0xA4,
+0xFF, 0x6A, 0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x4C, 0x9A, 0x51, 0xE4,
+0x60, 0xA4, 0xFF, 0x6A, 0x6C, 0xEA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x09, 0xF6, 0x51, 0xA2,
+0x04, 0x22, 0x02, 0x72, 0x00, 0x6A, 0x1F, 0x61,
+0x15, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x48, 0x9A, 0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF6, 0x44, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0x58, 0x9A,
+0x51, 0xE4, 0x60, 0xAC, 0xFF, 0xF7, 0x1F, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x4C, 0x9A, 0x51, 0xE4, 0x60, 0xAC,
+0xFF, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x09, 0xF6, 0x51, 0xA2,
+0x04, 0x22, 0x02, 0x72, 0x00, 0x6A, 0x19, 0x61,
+0x12, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x48, 0x9A, 0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF6, 0x44, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0x58, 0x9A,
+0x51, 0xE4, 0x40, 0x9C, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x4C, 0x9A, 0x51, 0xE4,
+0x40, 0x9C, 0x20, 0xE8, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEC, 0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3, 0x70, 0xA2,
+0x10, 0xD6, 0x11, 0xD7, 0x01, 0x73, 0x07, 0xD4,
+0x08, 0xD5, 0x80, 0xF0, 0x0F, 0x61, 0x83, 0xF3,
+0x74, 0xA2, 0x01, 0x73, 0x19, 0x61, 0x83, 0xF3,
+0x73, 0xA2, 0x16, 0x2B, 0x83, 0xF3, 0x12, 0xA2,
+0x83, 0xF3, 0x74, 0xC2, 0x83, 0xF3, 0x6C, 0x9A,
+0x01, 0x6A, 0x4C, 0xE8, 0x01, 0x58, 0x18, 0x67,
+0x00, 0x30, 0xFB, 0x4B, 0x08, 0x30, 0x01, 0xE3,
+0x90, 0x67, 0x00, 0x18, 0xF5, 0x3D, 0xFE, 0x6D,
+0x90, 0x67, 0x4C, 0xED, 0x00, 0x18, 0xC3, 0x3D,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x83, 0xF3, 0x54, 0xA0, 0x6B, 0x2A, 0x83, 0xF3,
+0x48, 0x98, 0x83, 0xF3, 0x72, 0xA0, 0x06, 0xD2,
+0x83, 0xF3, 0x4C, 0x98, 0x05, 0xD3, 0x06, 0x94,
+0x60, 0x33, 0x68, 0x33, 0x49, 0xE3, 0x85, 0xE2,
+0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x40, 0x9A, 0x91, 0x67, 0xA0, 0x9A, 0x00, 0x18,
+0xE5, 0x3D, 0x07, 0x95, 0x84, 0x41, 0x00, 0x18,
+0xD4, 0x3D, 0x08, 0x95, 0x86, 0x41, 0x00, 0x18,
+0xD4, 0x3D, 0x10, 0x95, 0x87, 0x41, 0x01, 0x4C,
+0x00, 0x18, 0xE5, 0x3D, 0x11, 0x95, 0x87, 0x41,
+0x05, 0x4C, 0x00, 0x18, 0xE5, 0x3D, 0x06, 0x92,
+0x20, 0x4A, 0xE0, 0xF3, 0x01, 0x5A, 0x39, 0x61,
+0x05, 0x93, 0x01, 0x69, 0x51, 0x67, 0x44, 0xEB,
+0x83, 0xF3, 0x73, 0xA0, 0x04, 0x94, 0x6D, 0xEA,
+0xFB, 0x4C, 0x83, 0xF3, 0x53, 0xC0, 0x04, 0xD4,
+0x00, 0x18, 0xF5, 0x3D, 0x80, 0x6D, 0xAB, 0xED,
+0x04, 0x94, 0x4D, 0xED, 0xFF, 0x6A, 0x4C, 0xED,
+0x00, 0x18, 0xC3, 0x3D, 0x05, 0x92, 0x01, 0x5A,
+0x58, 0x67, 0x05, 0xD2, 0x83, 0xF3, 0x53, 0xA0,
+0x78, 0x67, 0x47, 0xEB, 0x2C, 0xEA, 0x0B, 0x22,
+0x04, 0x94, 0x83, 0xF3, 0x34, 0xC0, 0x00, 0x18,
+0xF5, 0x3D, 0x04, 0x94, 0x2D, 0xEA, 0xFF, 0x6D,
+0x4C, 0xED, 0x00, 0x18, 0xC3, 0x3D, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B,
+0x83, 0xF3, 0x68, 0xDA, 0x7D, 0x67, 0x87, 0x43,
+0x0D, 0x4C, 0x60, 0xA4, 0x83, 0xF3, 0x72, 0xC2,
+0x05, 0x10, 0x83, 0xF3, 0x48, 0x98, 0x10, 0x4A,
+0x83, 0xF3, 0x48, 0xD8, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x54, 0x9A,
+0xFF, 0x6B, 0x80, 0xA2, 0xA4, 0x67, 0x6C, 0xED,
+0x04, 0xD5, 0x42, 0x2D, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x83, 0xF3, 0x96, 0xA0,
+0x12, 0x2C, 0x02, 0x6C, 0x8B, 0xEC, 0x80, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x88, 0x9A,
+0x80, 0x6D, 0xAB, 0xED, 0x40, 0xA4, 0x6C, 0xEA,
+0xAE, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x01, 0x6A,
+0x83, 0xF3, 0x56, 0xC0, 0x29, 0x10, 0x83, 0xF3,
+0x35, 0xA0, 0x83, 0xF3, 0x8C, 0x98, 0x20, 0x32,
+0x48, 0x32, 0xFB, 0x4C, 0x51, 0xE4, 0x00, 0x18,
+0xF5, 0x3D, 0x00, 0xF6, 0x40, 0x32, 0x00, 0xF6,
+0x43, 0x32, 0x00, 0x52, 0x19, 0x61, 0x01, 0x6A,
+0x04, 0x21, 0x5D, 0x67, 0x67, 0x42, 0x09, 0x4B,
+0x40, 0xA3, 0x83, 0xF3, 0x55, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B,
+0x83, 0xF3, 0x93, 0xA2, 0x83, 0xF3, 0x76, 0xC2,
+0x01, 0x6B, 0x64, 0xE9, 0x6F, 0xEB, 0x8C, 0xEB,
+0x83, 0xF3, 0x73, 0xC2, 0x01, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x83, 0xF3, 0x4C, 0x98,
+0x83, 0xF3, 0x35, 0xA0, 0x04, 0xD2, 0x00, 0x18,
+0xFB, 0x27, 0x00, 0x6B, 0x33, 0x22, 0x04, 0x93,
+0x20, 0x32, 0x30, 0xF0, 0x20, 0x6C, 0xE0, 0x4B,
+0x41, 0xF4, 0x9C, 0x9C, 0x48, 0x32, 0x49, 0xE3,
+0xFF, 0xF7, 0x1F, 0x6B, 0x4C, 0xEB, 0x60, 0xCC,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF4, 0x80, 0x9B,
+0xFF, 0x6D, 0x10, 0x6E, 0x60, 0xA4, 0x42, 0x32,
+0xCB, 0xEE, 0xAC, 0xEB, 0xCC, 0xEB, 0x42, 0x32,
+0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0,
+0x68, 0x9B, 0xAC, 0xEA, 0x40, 0xC4, 0x01, 0x6A,
+0x40, 0xC3, 0x01, 0x21, 0x00, 0x6A, 0x83, 0xF3,
+0x55, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF3, 0x93, 0xA2, 0x01, 0x6B,
+0x64, 0xE9, 0x6F, 0xEB, 0x8C, 0xEB, 0x83, 0xF3,
+0x73, 0xC2, 0x01, 0x6B, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x43, 0x67, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x09, 0xF6, 0x51, 0xA2, 0x03, 0x22, 0x02, 0x72,
+0x04, 0x60, 0x05, 0x10, 0x00, 0x18, 0xAD, 0x3E,
+0x02, 0x10, 0x00, 0x18, 0x82, 0x3E, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x09, 0xF6, 0x91, 0xA4, 0xFF, 0xF7, 0x1F, 0x6B,
+0xAC, 0xEB, 0x03, 0x24, 0x02, 0x74, 0x21, 0x60,
+0x26, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7,
+0x88, 0x9C, 0xC3, 0xEC, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF6, 0x88, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF6, 0x8C, 0x9C,
+0x99, 0xE6, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7,
+0x88, 0x9C, 0xE3, 0xEC, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF6, 0x88, 0x9C, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF6, 0x8C, 0x9C,
+0x05, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF6,
+0x90, 0x9C, 0x99, 0xE6, 0x9D, 0xE7, 0xBD, 0x67,
+0x52, 0xC5, 0x30, 0xF0, 0x20, 0x6A, 0x09, 0xF6,
+0x58, 0xAA, 0x04, 0x6C, 0x8B, 0xEC, 0x90, 0xC5,
+0x53, 0xC5, 0x0B, 0x6C, 0x43, 0x32, 0x75, 0xC5,
+0x63, 0x33, 0x54, 0xC5, 0x76, 0xC5, 0x8F, 0xCD,
+0x00, 0xF0, 0x17, 0x03, 0x00, 0x6A, 0x86, 0x67,
+0x86, 0xEA, 0x80, 0xC3, 0x87, 0x67, 0x86, 0xEA,
+0x08, 0x4A, 0x18, 0x72, 0x83, 0xC3, 0x01, 0x4B,
+0xF6, 0x61, 0x04, 0x04, 0x00, 0x18, 0xBC, 0x27,
+0x09, 0x97, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x40, 0xA4, 0x01, 0x6D, 0xAC, 0xEA, 0x80, 0xF0,
+0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF3, 0x70, 0xA2, 0x7B, 0x2B,
+0x83, 0xF3, 0xB0, 0xC2, 0x80, 0xA4, 0x92, 0x34,
+0x83, 0xF3, 0x91, 0xC2, 0x83, 0xF3, 0x91, 0xA2,
+0x05, 0x24, 0x02, 0x74, 0x10, 0x61, 0x07, 0xF0,
+0x00, 0x68, 0x10, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x4C, 0x9A, 0x00, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x4C, 0x9A, 0x4C, 0xE8,
+0x00, 0xF1, 0x01, 0x48, 0x03, 0x10, 0x83, 0xF3,
+0x70, 0xC2, 0x00, 0x68, 0x03, 0x6A, 0x0C, 0xEA,
+0x4D, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x09, 0xF6,
+0x50, 0xA2, 0x01, 0x72, 0x45, 0x61, 0x01, 0xF0,
+0x40, 0x40, 0x05, 0xD2, 0x30, 0x67, 0x23, 0x10,
+0x04, 0x92, 0x00, 0x6D, 0x31, 0xE2, 0x00, 0x18,
+0xE5, 0x3D, 0x04, 0x92, 0x04, 0x4A, 0x18, 0x72,
+0x04, 0xD2, 0xF6, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF6, 0xB4, 0x9A, 0x91, 0x67, 0x00, 0x18,
+0xE5, 0x3D, 0x87, 0x41, 0x04, 0x4C, 0x10, 0x6D,
+0x00, 0x18, 0xC3, 0x3D, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF6, 0xB8, 0x9A, 0x87, 0x41, 0x11, 0x4C,
+0x00, 0x18, 0xE5, 0x3D, 0x05, 0x93, 0x00, 0xF4,
+0x00, 0x49, 0x2E, 0xEB, 0x03, 0x23, 0x00, 0x6A,
+0x04, 0xD2, 0xDA, 0x17, 0x30, 0xF0, 0x20, 0x6A,
+0x87, 0x40, 0x86, 0xF2, 0x00, 0x4A, 0x19, 0x4C,
+0x00, 0xF4, 0x00, 0x6D, 0x83, 0xF3, 0x8C, 0xDA,
+0x83, 0xF3, 0x68, 0xDA, 0x83, 0xF3, 0x72, 0xC2,
+0x83, 0xF3, 0x74, 0xC2, 0x83, 0xF3, 0x73, 0xC2,
+0x83, 0xF3, 0x75, 0xC2, 0x83, 0xF3, 0x76, 0xC2,
+0x00, 0x6C, 0xD0, 0x67, 0xBD, 0xE0, 0x1A, 0x10,
+0x03, 0x6C, 0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B, 0x83, 0xF3,
+0x70, 0xC2, 0x05, 0x6C, 0x00, 0x6D, 0xD0, 0x67,
+0x00, 0xF4, 0xE0, 0x40, 0x0B, 0x10, 0x09, 0x6C,
+0x00, 0x6D, 0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0x6C, 0x09, 0xF6, 0x50, 0xC3, 0xA4, 0x67,
+0xC5, 0x67, 0xE5, 0x67, 0x00, 0x18, 0xDB, 0x3E,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x0F, 0x6A, 0x8C, 0xEA, 0x03, 0x2A, 0x92, 0x32,
+0x6C, 0xEA, 0x20, 0xE8, 0x07, 0x4A, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x04, 0x2A, 0x01, 0x6C,
+0x08, 0xF0, 0x00, 0x6D, 0x05, 0x10, 0x44, 0x32,
+0xFF, 0x4A, 0x01, 0x6D, 0x02, 0x6C, 0xA4, 0xEA,
+0x00, 0x18, 0x86, 0x09, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x04, 0x2A, 0x01, 0x6C,
+0x04, 0xF0, 0x00, 0x6D, 0x05, 0x10, 0xFF, 0x4A,
+0x44, 0x32, 0x01, 0x6D, 0x02, 0x6C, 0xA4, 0xEA,
+0x00, 0x18, 0x86, 0x09, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x04, 0x2A, 0x01, 0x6C,
+0x08, 0xF0, 0x00, 0x6D, 0x05, 0x10, 0x44, 0x32,
+0xFF, 0x4A, 0x01, 0x6D, 0x02, 0x6C, 0xA4, 0xEA,
+0x00, 0x18, 0xA3, 0x09, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x04, 0x2A, 0x01, 0x6C,
+0x04, 0xF0, 0x00, 0x6D, 0x05, 0x10, 0xFF, 0x4A,
+0x44, 0x32, 0x01, 0x6D, 0x02, 0x6C, 0xA4, 0xEA,
+0x00, 0x18, 0xA3, 0x09, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6D, 0x8C, 0xED, 0x01, 0x6C, 0x44, 0x67,
+0x15, 0x4D, 0x44, 0xED, 0xA2, 0x67, 0x00, 0x18,
+0x22, 0x09, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6D, 0x8C, 0xED,
+0x04, 0x2D, 0x03, 0x6C, 0x10, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0x1B, 0x4D, 0x01, 0x6A, 0x44, 0xED,
+0x03, 0x6C, 0xA2, 0x67, 0x00, 0x18, 0x22, 0x09,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x57, 0x3F, 0x01, 0x6D, 0x02, 0x6C,
+0xA4, 0xEA, 0x00, 0x18, 0x22, 0x09, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x57, 0x3F,
+0x01, 0x6D, 0x03, 0x6C, 0xA4, 0xEA, 0x00, 0x18,
+0x22, 0x09, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6D, 0x8C, 0xED,
+0x01, 0x6C, 0x44, 0x67, 0x15, 0x4D, 0x44, 0xED,
+0xA2, 0x67, 0x00, 0x18, 0x53, 0x09, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6D, 0x8C, 0xED, 0x04, 0x2D, 0x03, 0x6C,
+0x10, 0xF0, 0x00, 0x6D, 0x05, 0x10, 0x1B, 0x4D,
+0x01, 0x6A, 0x44, 0xED, 0x03, 0x6C, 0xA2, 0x67,
+0x00, 0x18, 0x53, 0x09, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x57, 0x3F,
+0x01, 0x6D, 0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18,
+0x53, 0x09, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x57, 0x3F, 0x01, 0x6D, 0x03, 0x6C,
+0xA4, 0xEA, 0x00, 0x18, 0x53, 0x09, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x01, 0xF3, 0x70, 0x9B, 0x8C, 0xEA,
+0x50, 0x32, 0x6D, 0xE2, 0x80, 0xA3, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF3, 0x8C, 0x9C, 0x91, 0xE2,
+0xA0, 0xA4, 0x80, 0xA4, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF3, 0x8C, 0x9C, 0x91, 0xE2, 0x80, 0x9C,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF3, 0x9C, 0x9C,
+0x89, 0xE2, 0x80, 0xA2, 0x40, 0x9A, 0x40, 0xA3,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x01, 0xF3, 0x70, 0x9B, 0x8C, 0xEA,
+0x50, 0x32, 0x6D, 0xE2, 0x80, 0xA3, 0x60, 0xA3,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF3, 0x6C, 0x9B,
+0x6D, 0xE2, 0x80, 0xA3, 0x60, 0xA3, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF3, 0x6C, 0x9B, 0x6D, 0xE2,
+0x60, 0x9B, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF3,
+0x7C, 0x9B, 0x6D, 0xE2, 0x60, 0x9B, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF3, 0x60, 0x9B, 0x6D, 0xE2,
+0x80, 0xA3, 0x60, 0xA3, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF3, 0x74, 0x9B, 0x6D, 0xE2, 0x60, 0xA3,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF6, 0x64, 0x9B,
+0x69, 0xE2, 0x40, 0xA2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x63, 0xF5, 0xC8, 0xA3, 0x01, 0x6D, 0xFF, 0x6A,
+0xCC, 0xED, 0x4C, 0xED, 0x4C, 0xEC, 0x42, 0x25,
+0x04, 0x6D, 0xCC, 0xED, 0x4C, 0xED, 0x3E, 0x25,
+0x30, 0xF0, 0x20, 0x6D, 0x21, 0xF3, 0xA8, 0x9D,
+0x90, 0x36, 0xB5, 0xE6, 0xA0, 0xA5, 0x30, 0xF0,
+0x20, 0x6D, 0x21, 0xF3, 0xA0, 0x9D, 0xB5, 0xE6,
+0xE0, 0xA5, 0xA0, 0xA5, 0x30, 0xF0, 0x20, 0x6D,
+0x21, 0xF3, 0xA4, 0x9D, 0xB5, 0xE6, 0xE0, 0x9D,
+0x30, 0xF0, 0x20, 0x6F, 0xC1, 0xF6, 0xE4, 0x9F,
+0xF9, 0xE6, 0xC0, 0xA6, 0xCC, 0xEA, 0x5A, 0x32,
+0x63, 0xF6, 0x45, 0xC3, 0x00, 0x6A, 0x43, 0xF6,
+0x58, 0xC3, 0xC0, 0xA5, 0x43, 0xF6, 0x59, 0xC3,
+0x43, 0xF6, 0xDE, 0xC3, 0xC1, 0x45, 0xC0, 0xA6,
+0x43, 0xF6, 0x5A, 0xC3, 0x43, 0xF6, 0xDF, 0xC3,
+0xC2, 0x45, 0xC0, 0xA6, 0x03, 0x4D, 0x43, 0xF6,
+0x5B, 0xC3, 0x63, 0xF6, 0xC0, 0xC3, 0xA0, 0xA5,
+0x43, 0xF6, 0x5C, 0xC3, 0x63, 0xF6, 0x42, 0xC3,
+0x63, 0xF6, 0xA1, 0xC3, 0x43, 0xF6, 0x5D, 0xC3,
+0x63, 0xF6, 0x43, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x63, 0xF5, 0xAD, 0xA2,
+0x01, 0x6B, 0xAC, 0xEB, 0x28, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF3, 0x6C, 0x9B, 0x90, 0x34,
+0x6D, 0xE4, 0x60, 0x9B, 0x63, 0xF5, 0x7C, 0xDA,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF3, 0x7C, 0x9B,
+0x6D, 0xE4, 0x60, 0x9B, 0x83, 0xF5, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF3, 0x70, 0x9B,
+0x6D, 0xE4, 0x60, 0x9B, 0x83, 0xF5, 0x64, 0xDA,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF3, 0x64, 0x9B,
+0x71, 0xE4, 0x60, 0x9C, 0x01, 0xF0, 0x00, 0x6C,
+0x83, 0xF5, 0x68, 0xDA, 0xA0, 0xF0, 0x64, 0x9A,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x63, 0xF5, 0xE8, 0xA3, 0x01, 0x6E, 0xFF, 0x6A,
+0xA7, 0x67, 0xCC, 0xED, 0x4C, 0xED, 0x4C, 0xEC,
+0x25, 0x25, 0x02, 0x6D, 0xEC, 0xED, 0x4C, 0xED,
+0x21, 0x25, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x48, 0x9A, 0x90, 0x34, 0x49, 0xE4, 0xA0, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x40, 0x9A,
+0x49, 0xE4, 0xE0, 0xA2, 0x40, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF3, 0x44, 0x9A, 0x51, 0xE4,
+0x40, 0x9C, 0x00, 0xF4, 0x00, 0x6C, 0x63, 0xF6,
+0xA8, 0xC3, 0x63, 0xF6, 0x50, 0xDB, 0xA0, 0xF0,
+0x44, 0x9B, 0x83, 0xF6, 0xC8, 0xC3, 0x8D, 0xEA,
+0xA0, 0xF0, 0x44, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0xDE, 0x63, 0x43, 0x62, 0x42, 0xD1, 0x41, 0xD0,
+0x01, 0x6A, 0x7D, 0x67, 0x4B, 0xEA, 0x54, 0xC3,
+0x0F, 0x6A, 0x56, 0xC3, 0x10, 0x6A, 0x57, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3, 0x4C, 0x9A,
+0xFF, 0x68, 0x8C, 0xE8, 0x10, 0x30, 0x49, 0xE0,
+0x40, 0x9A, 0x04, 0x01, 0x06, 0x04, 0xB1, 0x67,
+0x04, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0xB9, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3, 0x5C, 0x9A,
+0x07, 0x04, 0xB1, 0x67, 0x49, 0xE0, 0x40, 0x9A,
+0x04, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0xB9, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3, 0x50, 0x9A,
+0x08, 0x04, 0xB1, 0x67, 0x49, 0xE0, 0x40, 0x9A,
+0x04, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0xB9, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x44, 0x9A,
+0xB1, 0x67, 0x09, 0x04, 0x41, 0xE0, 0x40, 0x98,
+0x04, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0xB9, 0x20,
+0x05, 0x04, 0x00, 0x18, 0x33, 0x27, 0x43, 0x97,
+0x42, 0x91, 0x41, 0x90, 0x22, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF6, 0x48, 0x9A, 0xC1, 0xF6, 0x6C, 0x9B,
+0x00, 0xA2, 0x20, 0xA3, 0xFF, 0x6A, 0x4C, 0xE8,
+0x4C, 0xE9, 0x2A, 0xE8, 0x36, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x4C, 0x9A, 0x10, 0x33,
+0x49, 0xE3, 0x40, 0xA2, 0xFF, 0x6B, 0x6C, 0xEA,
+0x56, 0x32, 0x6C, 0xEA, 0x07, 0x5A, 0x1F, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32, 0x00, 0xF7,
+0x14, 0x4B, 0x4D, 0xE3, 0x40, 0x9B, 0x00, 0xEA,
+0x90, 0x67, 0x00, 0x18, 0x56, 0x78, 0x13, 0x10,
+0x90, 0x67, 0x00, 0x18, 0x46, 0x40, 0x0F, 0x10,
+0x90, 0x67, 0x00, 0x18, 0xC3, 0x3F, 0x0B, 0x10,
+0x90, 0x67, 0x00, 0x18, 0xD3, 0x3F, 0x07, 0x10,
+0x90, 0x67, 0x00, 0x18, 0xEC, 0x3F, 0x03, 0x10,
+0x90, 0x67, 0x00, 0x18, 0x2C, 0x40, 0x01, 0x48,
+0x7F, 0x6A, 0x4C, 0xE8, 0x0A, 0xE9, 0xCF, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF6, 0x48, 0x9A,
+0x20, 0xC2, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0xA9, 0xF0, 0x40, 0xA2, 0x01, 0x72, 0x03, 0x61,
+0xAC, 0xF4, 0x00, 0x6A, 0x04, 0x10, 0x03, 0x72,
+0x04, 0x61, 0xA4, 0xF1, 0x00, 0x6A, 0x4B, 0xEA,
+0x02, 0x10, 0x61, 0xF2, 0x00, 0x6A, 0x40, 0xCC,
+0x30, 0xF0, 0x20, 0x6A, 0x46, 0xF3, 0x64, 0xA2,
+0x09, 0x6A, 0x6C, 0xEA, 0x09, 0x72, 0x05, 0x61,
+0x60, 0xAC, 0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x40, 0xCC, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF6, 0xB4, 0x9A, 0xE0, 0xF3, 0x10, 0x6C,
+0x0F, 0x6E, 0x00, 0x18, 0x18, 0x42, 0xE0, 0xF3,
+0x0C, 0x6C, 0x00, 0x18, 0xF0, 0x41, 0xFF, 0x6B,
+0x4C, 0xEB, 0x0B, 0x73, 0x0B, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF6, 0x78, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF6, 0x88, 0x9C, 0x40, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x69,
+0x2C, 0xED, 0x30, 0xF0, 0x20, 0x6B, 0x04, 0xD5,
+0xE1, 0xF6, 0xB4, 0x9B, 0xFF, 0x6A, 0x40, 0x6E,
+0x60, 0xA5, 0xCB, 0xEE, 0x4C, 0xEC, 0x4C, 0xEB,
+0xCC, 0xEB, 0x6D, 0xEC, 0x4C, 0xEC, 0x80, 0xC5,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF6, 0x58, 0x9A, 0x00, 0xAA,
+0x04, 0x92, 0x2C, 0xE8, 0x2A, 0xEA, 0x08, 0x60,
+0x82, 0x67, 0x00, 0x18, 0xBC, 0x1F, 0x04, 0x93,
+0x2C, 0xEA, 0x6C, 0xE8, 0x07, 0xEA, 0x2C, 0xE8,
+0x50, 0x67, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0xF7, 0x1F, 0x69,
+0x2C, 0xED, 0xFF, 0x68, 0x0C, 0xEC, 0x2C, 0xEE,
+0x2A, 0xED, 0x05, 0xD4, 0x04, 0xD5, 0x06, 0xD6,
+0x1F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF6,
+0x74, 0x9A, 0x40, 0x6C, 0x8B, 0xEC, 0x40, 0xA3,
+0x0C, 0xEA, 0x8C, 0xEA, 0x05, 0x94, 0x8D, 0xEA,
+0x0C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF6, 0x78, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF7, 0x8C, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7, 0x84, 0x9C,
+0x8D, 0xEA, 0xCD, 0xEA, 0x40, 0xDB, 0x31, 0x10,
+0x05, 0x94, 0xB1, 0x67, 0x00, 0x18, 0xB3, 0x40,
+0x04, 0x94, 0x07, 0xD2, 0x00, 0x18, 0xBC, 0x1F,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF6, 0x94, 0x9B,
+0x40, 0x6D, 0xAB, 0xED, 0x60, 0xA4, 0x2C, 0xEA,
+0x0C, 0xEB, 0xAC, 0xEB, 0x05, 0x95, 0xAD, 0xEB,
+0x0C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF6, 0x98, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0xA0, 0xF7, 0xAC, 0x9D, 0x60, 0x9C, 0x06, 0x96,
+0xAC, 0xEB, 0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF7,
+0xA4, 0x9D, 0xC4, 0xEA, 0x46, 0x67, 0xAD, 0xEB,
+0x04, 0x95, 0x07, 0x96, 0xAC, 0xEA, 0xAF, 0xED,
+0xCC, 0xED, 0xAD, 0xEA, 0x2C, 0xEA, 0x4D, 0xEB,
+0x60, 0xDC, 0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF7, 0xA4, 0x9B, 0xFF, 0x6A, 0x08, 0x6E,
+0x60, 0xA5, 0xCB, 0xEE, 0x4C, 0xEC, 0x4C, 0xEB,
+0xCC, 0xEB, 0x6D, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF7, 0x68, 0x9B, 0x4C, 0xEC, 0x80, 0xC5,
+0x60, 0xA3, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF7, 0xC4, 0x9B,
+0xFF, 0x6A, 0x08, 0x6F, 0x60, 0xA6, 0xEB, 0xEF,
+0x4C, 0xEC, 0x4C, 0xEB, 0xEC, 0xEB, 0x6D, 0xEC,
+0x4C, 0xED, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF7, 0x48, 0x9A, 0x80, 0xC6, 0xA0, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7,
+0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0x40, 0xF4,
+0x15, 0x4A, 0x40, 0xDB, 0x00, 0x68, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF6, 0x40, 0x9A, 0x40, 0x9A,
+0x1E, 0x22, 0xE0, 0xF3, 0x09, 0x70, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A,
+0x20, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x60, 0xDA, 0x00, 0x6A, 0x09, 0x10, 0x32, 0x6C,
+0x00, 0x18, 0x95, 0x20, 0x01, 0x48, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0xDC, 0x17, 0x01, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x01, 0x69, 0x2B, 0xE9, 0x00, 0x6C, 0x01, 0xF4,
+0x00, 0x68, 0x00, 0x18, 0x55, 0x42, 0x00, 0x18,
+0x15, 0x41, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x78, 0x36, 0x04, 0x6E, 0xCB, 0xEE, 0x90, 0x67,
+0x4C, 0xEE, 0x00, 0xF2, 0x00, 0x48, 0xB1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0x78, 0x36, 0x04, 0x6E, 0xCB, 0xEE,
+0x90, 0x67, 0x4C, 0xEE, 0xB1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x00, 0x6C, 0xA4, 0x67, 0xD1, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x00, 0x18, 0x4F, 0x36,
+0x86, 0xF2, 0x00, 0x48, 0x23, 0xF5, 0x5C, 0xC8,
+0x01, 0x6C, 0x00, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0x4F, 0x36, 0x00, 0x6C, 0x23, 0xF5, 0x5E, 0xC8,
+0xA4, 0x67, 0xE4, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0xC5, 0x37, 0x00, 0x6D, 0x01, 0x6C, 0xD1, 0x67,
+0xE5, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x00, 0x68,
+0x01, 0x69, 0x2B, 0xE9, 0x01, 0xF1, 0x08, 0x6C,
+0xB1, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xE1, 0xF5, 0x14, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x78, 0x36, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF7,
+0x6C, 0x9B, 0x4C, 0xEB, 0x20, 0x23, 0xE0, 0xF3,
+0x09, 0x70, 0x15, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x98, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x60, 0xDA, 0x17, 0x10, 0x32, 0x6C,
+0x00, 0x18, 0x95, 0x20, 0x01, 0x48, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0xCD, 0x17, 0xE0, 0xF3,
+0x08, 0x58, 0x0C, 0x60, 0xA1, 0xF0, 0x14, 0x68,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x18, 0x78, 0x36,
+0x40, 0x6E, 0x90, 0x67, 0xB1, 0x67, 0x4D, 0xEE,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x64, 0x9A, 0xFE, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x00, 0x18, 0x71, 0x14,
+0x01, 0x72, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF7, 0x40, 0x9A, 0x3F, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF7, 0x70, 0x9A,
+0xFD, 0x6A, 0xFF, 0x6C, 0xA0, 0xA3, 0xAC, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF6,
+0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x6C, 0x9B, 0x40, 0x9A, 0x6C, 0xEA, 0x20, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF7, 0x74, 0x9A,
+0x30, 0xF0, 0x20, 0x6D, 0xC0, 0xF7, 0xAC, 0x9D,
+0x40, 0x9B, 0xAD, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF7, 0x78, 0x9A, 0x06, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF7,
+0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF6,
+0x98, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF6, 0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x6C, 0x9B, 0x40, 0x9A, 0x6C, 0xEA,
+0x24, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF7,
+0x78, 0x9A, 0xFF, 0x6C, 0x07, 0x6D, 0x40, 0xA3,
+0xAB, 0xED, 0x8C, 0xEA, 0xAC, 0xEA, 0x04, 0x6D,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF7, 0x7C, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF7, 0x80, 0x9C, 0x40, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF7, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF7, 0x84, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF7,
+0x90, 0x9A, 0xFF, 0x6B, 0x02, 0x6D, 0x40, 0xA4,
+0x01, 0x68, 0x0B, 0xE8, 0x6C, 0xEA, 0xAD, 0xEA,
+0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF7, 0x40, 0x9A, 0x01, 0x6C, 0x8B, 0xEC,
+0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF7,
+0x48, 0x9A, 0x09, 0x6C, 0x01, 0x6D, 0x80, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1, 0x54, 0x9A,
+0x7A, 0x6C, 0x8B, 0xEC, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x84, 0x9A, 0xA1, 0xF0,
+0x14, 0x69, 0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA,
+0x6C, 0xEA, 0x40, 0xC4, 0x85, 0x67, 0x00, 0x18,
+0x95, 0x20, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0x78, 0x36, 0x41, 0x6E, 0xCB, 0xEE, 0x91, 0x67,
+0xB0, 0x67, 0x4C, 0xEE, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x69, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x49, 0x21, 0xF0, 0x1C, 0x4A,
+0x40, 0x9A, 0x23, 0xF5, 0xFC, 0xA9, 0x00, 0x6C,
+0xA4, 0x67, 0x4D, 0xEF, 0xD0, 0x67, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x1C, 0x4B, 0x60, 0x9B, 0x23, 0xF5, 0xFE, 0xA9,
+0xD0, 0x67, 0x01, 0xF4, 0x00, 0x69, 0x6D, 0xEF,
+0x01, 0x6C, 0x00, 0x6D, 0x00, 0x18, 0xC5, 0x37,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0x78, 0x36,
+0x03, 0x6E, 0x91, 0x67, 0xB0, 0x67, 0x4D, 0xEE,
+0x00, 0xF2, 0x00, 0x49, 0x00, 0x18, 0x86, 0x36,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0x78, 0x36,
+0x03, 0x6E, 0xB0, 0x67, 0x4D, 0xEE, 0x91, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6C, 0x00, 0x18,
+0x55, 0x42, 0x00, 0x18, 0x10, 0x5B, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x03, 0x6B, 0x4C, 0xEB,
+0x2D, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF7,
+0x64, 0x9B, 0x64, 0x68, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF7, 0x48, 0x9A, 0x30, 0x6B,
+0x60, 0xC2, 0x23, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x95, 0x20, 0xFF, 0x48, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE8, 0x1B, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x8C, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x60, 0xDA, 0x60, 0xA1, 0xCF, 0x6A,
+0x6C, 0xEA, 0x40, 0xC1, 0x01, 0x6A, 0x4B, 0xEA,
+0x11, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF7,
+0x28, 0x9A, 0x20, 0x6A, 0x60, 0xA1, 0x6C, 0xEA,
+0xD5, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF7,
+0x4C, 0x9A, 0xEF, 0x6B, 0x40, 0x9A, 0x80, 0xA1,
+0x8C, 0xEB, 0x60, 0xC1, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x03, 0x6B, 0x8C, 0xEB,
+0x4C, 0xEE, 0x69, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF7, 0x64, 0x9B, 0x80, 0xC3, 0x0F, 0x6B,
+0xCC, 0xEB, 0x61, 0x23, 0x01, 0x6C, 0x6C, 0xEC,
+0x06, 0x24, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF7,
+0x8C, 0x9C, 0xAC, 0xEA, 0x40, 0xC4, 0x02, 0x6A,
+0x6C, 0xEA, 0x08, 0x22, 0xFF, 0x6C, 0xA2, 0x32,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF7,
+0x90, 0x9C, 0x40, 0xC4, 0x04, 0x6A, 0x6C, 0xEA,
+0x09, 0x22, 0xA2, 0x32, 0xFF, 0x6C, 0x42, 0x32,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF7,
+0x94, 0x9C, 0x40, 0xC4, 0x6E, 0x32, 0x07, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF7, 0x58, 0x9A,
+0x00, 0xF6, 0xA2, 0x35, 0xA0, 0xC2, 0x20, 0x6A,
+0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF7,
+0x68, 0x9B, 0x64, 0x68, 0x40, 0xC3, 0x21, 0x10,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0xFF, 0x48,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8, 0x19, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF3, 0x8C, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF3,
+0x60, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x60, 0xDA,
+0x60, 0xA1, 0xD0, 0x6A, 0x6C, 0xEA, 0x40, 0xC1,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF7,
+0x28, 0x9A, 0x20, 0x6A, 0x60, 0xA1, 0x6C, 0xEA,
+0xD7, 0x2A, 0x60, 0xA1, 0xF0, 0x6A, 0x6C, 0xEA,
+0x40, 0xC1, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x01, 0x74, 0x1C, 0x60,
+0x05, 0x24, 0x02, 0x74, 0x0E, 0x60, 0x03, 0x74,
+0x27, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF7, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF7, 0x9C, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF7,
+0x70, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF0,
+0x94, 0x9C, 0x40, 0x9B, 0x8C, 0xEA, 0x1A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF7, 0x74, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF7, 0x9C, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0xC1, 0xF0, 0x94, 0x9C, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF7, 0x70, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF0, 0x90, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3, 0x64, 0x9A,
+0xFF, 0x6C, 0x02, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x04, 0x67, 0x4C, 0xE8, 0x30, 0x70,
+0x26, 0x67, 0x4C, 0xED, 0x09, 0x61, 0x41, 0xA6,
+0x0C, 0x72, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0x5B, 0xA2, 0x00, 0x6B, 0x3B, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x64, 0x9A,
+0xFF, 0x6C, 0x08, 0x6E, 0x40, 0xA3, 0xCB, 0xEE,
+0x8C, 0xEA, 0xCC, 0xEA, 0x05, 0x6E, 0xCD, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x48, 0x9A, 0x60, 0xA2, 0x0F, 0x6A,
+0x6C, 0xEA, 0x04, 0x72, 0x16, 0x61, 0x90, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x6D, 0x21, 0x01, 0x72,
+0x01, 0x6B, 0x1D, 0x60, 0x83, 0x67, 0x00, 0x18,
+0xE9, 0x25, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x64, 0x9A, 0x04, 0x6C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x02, 0x6B,
+0x0E, 0x10, 0x02, 0x6C, 0x00, 0x18, 0xE9, 0x25,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x64, 0x9A, 0x04, 0x6C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x03, 0x6B, 0x23, 0x70,
+0x03, 0x60, 0x30, 0x70, 0x07, 0x60, 0x29, 0x10,
+0x03, 0x73, 0x27, 0x61, 0x00, 0x6C, 0x00, 0x18,
+0x64, 0x26, 0x19, 0x10, 0x41, 0xA1, 0x0D, 0x72,
+0x0E, 0x61, 0x01, 0x6A, 0x6E, 0xEA, 0x06, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x66, 0xF2, 0x5B, 0xC3,
+0x01, 0x6D, 0x09, 0x10, 0x01, 0x6C, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x9B, 0xC2, 0x01, 0x6A,
+0x4E, 0xEB, 0x01, 0x5B, 0xB8, 0x67, 0xC0, 0xA1,
+0x00, 0x6C, 0x00, 0x18, 0xF0, 0x25, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x64, 0x9A, 0x04, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x01, 0x74, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x83, 0xF6, 0xD4, 0x98, 0x01, 0x69, 0x2B, 0xE9,
+0x41, 0xF4, 0x18, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x41, 0xF6, 0x18, 0x6C, 0xB1, 0x67,
+0x83, 0xF6, 0xD4, 0x98, 0x12, 0x10, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x83, 0xF6,
+0xD0, 0x98, 0x01, 0x69, 0x2B, 0xE9, 0x41, 0xF4,
+0x18, 0x6C, 0xB1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x83, 0xF6, 0xD0, 0x98, 0x41, 0xF6, 0x18, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEA, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x64, 0x9B, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF7, 0x60, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7, 0x44, 0x9A,
+0x60, 0xA2, 0x20, 0x6A, 0x6C, 0xEA, 0xF8, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7, 0x48, 0x9A,
+0x40, 0x9A, 0x20, 0xE8, 0xFF, 0xF7, 0x1F, 0x6A,
+0x04, 0x6B, 0x4C, 0xEC, 0x6B, 0xEB, 0x8C, 0xEB,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x44, 0x9A, 0x4D, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF7, 0x40, 0x9A, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF7, 0x44, 0x9A, 0x60, 0xA2,
+0x20, 0x6A, 0x6C, 0xEA, 0xF8, 0x22, 0x03, 0x6A,
+0x8C, 0xEA, 0x09, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF7, 0x48, 0x9A, 0xFF, 0xF7, 0x1F, 0x6B,
+0x40, 0x9A, 0x6C, 0xEA, 0x20, 0xE8, 0x02, 0x72,
+0x03, 0x60, 0xFF, 0xF7, 0x1F, 0x6A, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7, 0x48, 0x9A,
+0x40, 0x9A, 0x42, 0x32, 0x42, 0x32, 0x20, 0xE8,
+0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x6B, 0x4C, 0xEC,
+0x6B, 0xEB, 0x8C, 0xEB, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x44, 0x9A, 0x4D, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7, 0x40, 0x9A,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x44, 0x9A, 0xFF, 0x6B, 0xA0, 0xA2, 0x20, 0x6A,
+0xAC, 0xEA, 0xF7, 0x22, 0x03, 0x6A, 0x8C, 0xEA,
+0x06, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x48, 0x9A, 0x40, 0x9A, 0x11, 0x10, 0x01, 0x72,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x48, 0x9A, 0x40, 0x9A, 0x08, 0x10, 0x02, 0x72,
+0x09, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x48, 0x9A, 0x40, 0x9A, 0x42, 0x32, 0x42, 0x32,
+0x6C, 0xEA, 0x20, 0xE8, 0x03, 0x72, 0xFF, 0x6A,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x48, 0x9A, 0x40, 0x9A, 0x00, 0xF6, 0x42, 0x32,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF7, 0x6C, 0x9B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF7, 0x70, 0x9B, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF7, 0x60, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7, 0x44, 0x9A,
+0x60, 0xA2, 0x20, 0x6A, 0x6C, 0xEA, 0xF8, 0x22,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEC, 0x03, 0x6E, 0xFF, 0xF7, 0x1C, 0x6B,
+0x8C, 0xEE, 0xAC, 0xEA, 0x8C, 0xEB, 0x18, 0x2E,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF7, 0x8C, 0x9C,
+0x40, 0xCC, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x54, 0x9A, 0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF7, 0x60, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF7, 0x44, 0x9A, 0x60, 0xA2,
+0x20, 0x6A, 0x6C, 0xEA, 0xF8, 0x22, 0x20, 0xE8,
+0x02, 0x76, 0x19, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x81, 0xF7, 0x8C, 0x9C, 0x40, 0x32, 0x40, 0x32,
+0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x58, 0x9A, 0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF7, 0x60, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF7, 0x44, 0x9A, 0x60, 0xA2,
+0x20, 0x6A, 0x6C, 0xEA, 0xF8, 0x22, 0x20, 0xE8,
+0xFF, 0xF7, 0x1F, 0x6A, 0xFF, 0x6B, 0x8C, 0xEA,
+0xAC, 0xEB, 0x03, 0x6D, 0xFF, 0xF7, 0x1C, 0x6C,
+0x4C, 0xED, 0x4C, 0xEC, 0x18, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF7, 0x4C, 0x9A, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7, 0x5C, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF7, 0x60, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF7, 0x44, 0x9A, 0x60, 0xA2, 0x20, 0x6A,
+0x6C, 0xEA, 0xF8, 0x22, 0x20, 0xE8, 0x01, 0x75,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x4C, 0x9A, 0x60, 0x33, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF7, 0x40, 0x9A, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF7, 0x60, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x44, 0x9A, 0x60, 0xA2, 0x20, 0x6A, 0x6C, 0xEA,
+0xF8, 0x22, 0x20, 0xE8, 0x02, 0x75, 0x1F, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF7, 0x44, 0x9A,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF7,
+0x4C, 0x9A, 0x60, 0x33, 0x60, 0x33, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF7, 0x48, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF7, 0x60, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF7, 0x44, 0x9A, 0x60, 0xA2, 0x20, 0x6A,
+0x6C, 0xEA, 0xF8, 0x22, 0x20, 0xE8, 0x03, 0x75,
+0x1E, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF7,
+0x4C, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF7, 0x4C, 0x9A, 0x00, 0xF6, 0x60, 0x33,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF7,
+0x50, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF7,
+0x60, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF7, 0x44, 0x9A, 0x60, 0xA2,
+0x20, 0x6A, 0x6C, 0xEA, 0xF8, 0x22, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x4C, 0xED, 0x4C, 0xEC, 0x4C, 0xEE,
+0xEC, 0xEA, 0x05, 0x25, 0x01, 0x75, 0x4E, 0x61,
+0x08, 0x6B, 0x0C, 0x6D, 0x02, 0x10, 0x0A, 0x6B,
+0x0E, 0x6D, 0x01, 0x74, 0x1D, 0x60, 0x02, 0x74,
+0x2A, 0x60, 0x26, 0x67, 0xE1, 0x45, 0xC4, 0xED,
+0x24, 0xEB, 0x82, 0x67, 0xCD, 0xE9, 0x84, 0xEF,
+0xC1, 0x43, 0x8D, 0xE9, 0x44, 0xEE, 0x4D, 0xE9,
+0x01, 0x6A, 0x02, 0x67, 0x04, 0xEB, 0x62, 0x67,
+0x64, 0xED, 0xA2, 0x67, 0x6D, 0xE8, 0xA4, 0xEF,
+0xAD, 0xE8, 0x44, 0xEE, 0xFF, 0xF7, 0x1F, 0x6C,
+0x4D, 0xE8, 0x8C, 0xE9, 0x8C, 0xE8, 0x1E, 0x10,
+0x01, 0x6B, 0x01, 0x45, 0x22, 0x67, 0x83, 0x67,
+0x24, 0xE8, 0xC4, 0xED, 0x84, 0xE8, 0xCD, 0xE9,
+0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x67, 0x64, 0xED,
+0x4C, 0xE9, 0x6D, 0xE8, 0x0E, 0x10, 0x01, 0x6C,
+0x01, 0x43, 0x22, 0x67, 0xA4, 0x67, 0x24, 0xE8,
+0xC4, 0xEB, 0xA4, 0xE8, 0xCD, 0xE9, 0xFF, 0xF7,
+0x1F, 0x6A, 0x05, 0x67, 0x84, 0xEB, 0x4C, 0xE9,
+0x8D, 0xE8, 0x4C, 0xE8, 0x38, 0x6C, 0x00, 0x18,
+0xE1, 0x42, 0x0F, 0xE8, 0x4C, 0xE8, 0x2D, 0xE8,
+0xFF, 0xF7, 0x1F, 0x6D, 0x38, 0x6C, 0x0C, 0xED,
+0x00, 0x18, 0x29, 0x43, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6B, 0x8C, 0xEB,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA, 0xA0, 0x6C,
+0x03, 0x23, 0x01, 0x73, 0xA4, 0x6C, 0x03, 0x61,
+0xA2, 0x67, 0x00, 0x18, 0x29, 0x43, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF7,
+0x94, 0x9C, 0xFF, 0x6B, 0xC2, 0x67, 0x6C, 0xEE,
+0xC0, 0xC4, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF7,
+0xD8, 0x9C, 0x03, 0x6F, 0x42, 0x32, 0x80, 0xA6,
+0xEC, 0xEA, 0xF9, 0x4F, 0x6C, 0xEC, 0xEC, 0xEC,
+0x8D, 0xEA, 0x6C, 0xEA, 0x40, 0xC6, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF7, 0x7C, 0x9A, 0x7F, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x00, 0x6A,
+0x03, 0x10, 0x01, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF7, 0x7C, 0x9B,
+0x60, 0xA3, 0x00, 0xF6, 0x60, 0x33, 0x00, 0xF6,
+0x63, 0x33, 0x00, 0x53, 0x03, 0x61, 0x64, 0x72,
+0xF0, 0x61, 0x0A, 0x10, 0x64, 0x5A, 0x08, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF7, 0x40, 0x9A,
+0x40, 0xA2, 0x40, 0xC5, 0x01, 0x6A, 0x20, 0xE8,
+0x01, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xA9, 0xF4,
+0x68, 0xC2, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD0, 0x41, 0xA4,
+0x04, 0x67, 0x80, 0xA4, 0x0F, 0x6D, 0x4C, 0xED,
+0x52, 0x36, 0x00, 0x18, 0xA0, 0x3C, 0x7D, 0x67,
+0x10, 0x6A, 0x50, 0xC3, 0x07, 0x6A, 0x4F, 0xCB,
+0x40, 0xA0, 0x04, 0x04, 0x52, 0xC3, 0x00, 0x18,
+0xBC, 0x27, 0x09, 0x97, 0x08, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xA0, 0xF0, 0x8F, 0xA3, 0x01, 0x6A, 0xFF, 0x6E,
+0x8C, 0xEA, 0x1D, 0x22, 0xC3, 0xF3, 0xE5, 0xA3,
+0x1F, 0x6C, 0xA7, 0x67, 0x8C, 0xED, 0x45, 0x67,
+0xCC, 0xEA, 0x15, 0x22, 0x20, 0x6A, 0x1F, 0x4D,
+0x4B, 0xEA, 0x8C, 0xED, 0xEC, 0xEA, 0xAD, 0xEA,
+0xC3, 0xF3, 0x45, 0xC3, 0x8C, 0xEA, 0xCC, 0xEA,
+0x0A, 0x2A, 0x10, 0xF0, 0x21, 0x6C, 0xC2, 0xF1,
+0x1D, 0x4C, 0x00, 0x6D, 0x14, 0x6E, 0x01, 0x6F,
+0x04, 0xD2, 0x00, 0x18, 0x8A, 0x3B, 0x07, 0x97,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0xFF, 0x6E, 0x8C, 0xEE, 0x00, 0x6A, 0x10, 0xF0,
+0x21, 0x6C, 0x63, 0xF1, 0x09, 0x4C, 0xA2, 0x67,
+0x01, 0x6F, 0x04, 0xD2, 0x00, 0x18, 0x8A, 0x3B,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xC4, 0x67, 0xC3, 0xF3,
+0x84, 0xA3, 0x0F, 0x6D, 0xFF, 0x6A, 0x86, 0x34,
+0xAC, 0xEC, 0x4C, 0xEC, 0x0A, 0x6D, 0xB8, 0xEC,
+0x4C, 0xEE, 0x12, 0xED, 0x6D, 0xE5, 0xC3, 0xF3,
+0xAF, 0xA3, 0x07, 0x6B, 0xAC, 0xEB, 0x4C, 0xEB,
+0x01, 0x73, 0x2B, 0x60, 0x05, 0x23, 0x02, 0x73,
+0x03, 0x60, 0x03, 0x73, 0x26, 0x60, 0x38, 0x10,
+0x0A, 0x6B, 0x78, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x01, 0x6D, 0x12, 0xEC,
+0x51, 0xE4, 0xC3, 0xF3, 0x6F, 0xA4, 0x76, 0x33,
+0xAC, 0xEB, 0x11, 0x2B, 0xC3, 0xF3, 0xB3, 0xA4,
+0x0F, 0x6A, 0x4B, 0xEA, 0xAC, 0xEA, 0xC3, 0xF3,
+0x53, 0xC4, 0x10, 0xF0, 0x21, 0x6C, 0x42, 0xF3,
+0x05, 0x4C, 0x00, 0x6D, 0x01, 0x6F, 0x04, 0xD3,
+0x00, 0x18, 0x8A, 0x3B, 0x19, 0x10, 0x02, 0x6B,
+0xC3, 0xF3, 0x68, 0xC2, 0xC3, 0xF3, 0x90, 0xA4,
+0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x02, 0x6B, 0xC3, 0xF3, 0x68, 0xC2,
+0x0A, 0x6B, 0x78, 0xEC, 0x12, 0xEC, 0x49, 0xE4,
+0xC3, 0xF3, 0x90, 0xA2, 0x92, 0x34, 0x91, 0xE6,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x09, 0x44,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF3,
+0x64, 0xA2, 0x80, 0x6C, 0x8B, 0xEC, 0x6C, 0xEC,
+0xFF, 0x6B, 0x6C, 0xEC, 0x5B, 0x24, 0xC3, 0xF3,
+0xE7, 0xA2, 0x0F, 0x6D, 0x10, 0x6C, 0xC7, 0x67,
+0xAC, 0xEE, 0x01, 0x4E, 0x8B, 0xEC, 0xAC, 0xEE,
+0xEC, 0xEC, 0xCD, 0xEC, 0xA0, 0xF0, 0xD1, 0xA2,
+0xC3, 0xF3, 0x87, 0xC2, 0xAC, 0xEC, 0xC2, 0xEC,
+0x49, 0x61, 0xA0, 0xF0, 0xB4, 0xA2, 0x01, 0x6C,
+0xAC, 0xEC, 0x6C, 0xEC, 0x15, 0x24, 0xFF, 0xF6,
+0x1F, 0x4B, 0xAC, 0xEB, 0xA0, 0xF0, 0x74, 0xC2,
+0xE3, 0xF4, 0x64, 0xA2, 0xA0, 0xF0, 0x70, 0xC2,
+0xE3, 0xF4, 0x67, 0xA2, 0xA0, 0xF0, 0x71, 0xC2,
+0xE3, 0xF4, 0x65, 0xA2, 0xC3, 0xF3, 0x6E, 0xC2,
+0xE3, 0xF4, 0x66, 0xA2, 0xC3, 0xF3, 0x78, 0xC2,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x08, 0x6C, 0x00, 0x18, 0x1D, 0x2E, 0xC3, 0xF3,
+0x64, 0xA0, 0x1F, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xC3, 0xF3, 0x44, 0xC0, 0xC3, 0xF3, 0x44, 0xA0,
+0x0F, 0x6B, 0x46, 0x32, 0x6C, 0xEA, 0x0A, 0x6B,
+0x78, 0xEA, 0x12, 0xEA, 0x09, 0xE2, 0xC3, 0xF3,
+0x90, 0xA2, 0xA0, 0xF0, 0x50, 0xA0, 0x92, 0x34,
+0x93, 0xE2, 0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18,
+0x12, 0x44, 0xC3, 0xF3, 0x67, 0xA0, 0x10, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xC3, 0xF3, 0x65, 0xA0,
+0xC3, 0xF3, 0x47, 0xC0, 0x1F, 0x6A, 0x6C, 0xEA,
+0xC3, 0xF3, 0x45, 0xC0, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x40, 0x9A, 0xFF, 0x6B, 0x30, 0xF0,
+0x20, 0x68, 0x40, 0xA2, 0x86, 0xF2, 0x00, 0x48,
+0x50, 0x6E, 0x4C, 0xEB, 0x00, 0x6C, 0xFF, 0x6D,
+0x05, 0xD3, 0x00, 0x18, 0x18, 0x3A, 0xA0, 0xF0,
+0x53, 0xA0, 0x0A, 0x6B, 0x0F, 0x69, 0x52, 0x32,
+0x78, 0xEA, 0x00, 0x6D, 0x12, 0xEA, 0x09, 0xE2,
+0xC3, 0xF3, 0x90, 0xA2, 0xFF, 0x6A, 0x2C, 0xEC,
+0x4C, 0xEC, 0x00, 0x18, 0x21, 0x14, 0xA0, 0xF0,
+0x53, 0xA0, 0x0A, 0x6B, 0x01, 0x6D, 0x2C, 0xEA,
+0x78, 0xEA, 0x12, 0xEA, 0x09, 0xE2, 0xC3, 0xF3,
+0x90, 0xA2, 0xFF, 0x6A, 0x2C, 0xEC, 0x4C, 0xEC,
+0x00, 0x18, 0xDF, 0x13, 0x04, 0xD2, 0xA0, 0xF0,
+0x53, 0xA0, 0x0A, 0x6B, 0x00, 0x6D, 0x2C, 0xEA,
+0x78, 0xEA, 0x12, 0xEA, 0x09, 0xE2, 0xC3, 0xF3,
+0x90, 0xA2, 0xFF, 0x6A, 0x2C, 0xEC, 0x4C, 0xEC,
+0x00, 0x18, 0xDF, 0x13, 0xA0, 0xF0, 0x6F, 0xA0,
+0x04, 0x94, 0xA0, 0xF0, 0xB3, 0xA0, 0x66, 0x33,
+0x60, 0x33, 0x68, 0x33, 0x6D, 0xE2, 0x43, 0xEB,
+0x58, 0x67, 0x51, 0xE4, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0xD0, 0x9A, 0xB2, 0x35, 0x0A, 0x6A,
+0x58, 0xED, 0x04, 0xD4, 0x30, 0xF0, 0x20, 0x6F,
+0xC1, 0xF7, 0xE8, 0x9F, 0x80, 0x9E, 0x12, 0xED,
+0x15, 0xE5, 0xC3, 0xF3, 0x50, 0xA5, 0x00, 0xF7,
+0x40, 0x32, 0xEC, 0xEA, 0x30, 0xF0, 0x20, 0x6F,
+0xA0, 0xF7, 0xF4, 0x9F, 0xEC, 0xEC, 0x8D, 0xEA,
+0x40, 0xDE, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x94,
+0x81, 0xF4, 0x48, 0x9A, 0x80, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x5C, 0x9A, 0xFF, 0x6C,
+0x60, 0xDA, 0xC3, 0xF3, 0x50, 0xA5, 0x01, 0x6D,
+0x4C, 0xE9, 0x2C, 0xEC, 0x00, 0x18, 0x21, 0x14,
+0x05, 0x95, 0x00, 0x6C, 0x50, 0x6E, 0x00, 0x18,
+0x18, 0x3A, 0xC3, 0xF3, 0x65, 0xA0, 0x20, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x14, 0x6B, 0x6D, 0xEA,
+0xC3, 0xF3, 0x64, 0xA0, 0xC3, 0xF3, 0x45, 0xC0,
+0x80, 0x6A, 0x4B, 0xEA, 0x6D, 0xEA, 0xC3, 0xF3,
+0x44, 0xC0, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xC3, 0xF3, 0x84, 0xA3, 0x0F, 0x6A, 0x0A, 0x6D,
+0x86, 0x34, 0x4C, 0xEC, 0xB8, 0xEC, 0xFF, 0x6E,
+0x00, 0x6D, 0x12, 0xEC, 0x6D, 0xE4, 0xC3, 0xF3,
+0xF0, 0xA3, 0xC3, 0xF3, 0x94, 0xAB, 0x4C, 0xEF,
+0x00, 0x18, 0x6D, 0x1D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF3, 0x24, 0xA2,
+0xC3, 0xF3, 0x88, 0xA2, 0x0F, 0x6B, 0x26, 0x31,
+0x03, 0x74, 0x6C, 0xE9, 0x40, 0x60, 0x0A, 0x68,
+0x18, 0xE9, 0xFF, 0x6E, 0x01, 0x6D, 0x12, 0xE8,
+0x41, 0xE0, 0xC3, 0xF3, 0xF0, 0xA0, 0xC3, 0xF3,
+0x94, 0xA8, 0x6C, 0xEF, 0xCC, 0xEF, 0x00, 0x18,
+0x6D, 0x1D, 0x01, 0x72, 0x06, 0x61, 0xC3, 0xF3,
+0x73, 0xA0, 0x01, 0x6A, 0x6D, 0xEA, 0xC3, 0xF3,
+0x53, 0xC0, 0x0A, 0x6B, 0x78, 0xE9, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x07, 0x6D,
+0x12, 0xE9, 0x45, 0xE1, 0xC3, 0xF3, 0x93, 0xA1,
+0x86, 0x33, 0xAC, 0xEB, 0x01, 0x4B, 0xAC, 0xEB,
+0x64, 0x35, 0x0F, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xAD, 0xEB, 0xC3, 0xF3, 0x73, 0xC1, 0xC3, 0xF3,
+0x89, 0xA2, 0x20, 0x6B, 0x8C, 0xEB, 0x0A, 0x2B,
+0xC3, 0xF3, 0x48, 0xA2, 0x07, 0x2A, 0xC3, 0xF3,
+0x90, 0xA1, 0xFF, 0x6A, 0x92, 0x34, 0x4C, 0xEC,
+0x00, 0x18, 0x09, 0x44, 0x01, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x49, 0xF6, 0x68, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xC3, 0xF3, 0xA4, 0xA3, 0x0F, 0x6E, 0xFF, 0x69,
+0xA6, 0x32, 0xCC, 0xEA, 0x01, 0x6E, 0xCC, 0xED,
+0x2C, 0xED, 0x2C, 0xEC, 0x2C, 0xEA, 0x39, 0x25,
+0x0A, 0x68, 0x18, 0xEA, 0x12, 0xE8, 0x61, 0xE0,
+0xC3, 0xF3, 0x50, 0xA0, 0x0F, 0x6B, 0x6C, 0xEA,
+0x8E, 0xEA, 0x2F, 0x2A, 0xC3, 0xF3, 0x73, 0xA0,
+0x72, 0x32, 0xCC, 0xEA, 0x2C, 0xEA, 0x29, 0x22,
+0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xC3, 0xF3,
+0x53, 0xC0, 0x00, 0x6D, 0x00, 0x18, 0x38, 0x31,
+0x20, 0x2A, 0xC3, 0xF3, 0x4F, 0xA0, 0x01, 0x6D,
+0x52, 0x32, 0xAC, 0xEA, 0x2C, 0xEA, 0x19, 0x2A,
+0xC3, 0xF3, 0x53, 0xA0, 0x56, 0x33, 0x02, 0x53,
+0x14, 0x60, 0xC3, 0xF3, 0xF0, 0xA0, 0x0F, 0x6E,
+0x10, 0x6B, 0xC3, 0xF3, 0x94, 0xA8, 0x4D, 0xEB,
+0xCC, 0xEF, 0xC3, 0xF3, 0x73, 0xC0, 0x00, 0x6D,
+0xD1, 0x67, 0x2C, 0xEF, 0x00, 0x18, 0x6D, 0x1D,
+0xC3, 0xF3, 0x53, 0xA0, 0x20, 0x4A, 0xC3, 0xF3,
+0x53, 0xC0, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x52, 0xA2,
+0xC4, 0x67, 0x05, 0x22, 0xFF, 0x6C, 0x51, 0x4C,
+0x00, 0x6D, 0x00, 0x18, 0x04, 0x31, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x68, 0x0C, 0xEC,
+0x25, 0x67, 0x01, 0x74, 0x0C, 0xE9, 0x23, 0x60,
+0x02, 0x74, 0x3F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x40, 0x9A, 0x00, 0x6C, 0x6F, 0x6D,
+0x40, 0xA2, 0x4C, 0x6E, 0x4C, 0xE8, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0x15, 0x41, 0x01, 0x72,
+0x0B, 0x61, 0xFF, 0x6D, 0xC5, 0x67, 0x00, 0x6C,
+0x0B, 0x6F, 0x00, 0x18, 0x75, 0x07, 0xFF, 0x6D,
+0x01, 0x6C, 0xC5, 0x67, 0x0C, 0x6F, 0x2F, 0x10,
+0x00, 0x6C, 0xB0, 0x67, 0x4D, 0x6E, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x6A, 0x2B, 0x10, 0x00, 0x6D,
+0xC5, 0x67, 0xFF, 0x6C, 0x00, 0x18, 0x18, 0x3A,
+0x0A, 0x6B, 0x78, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6C, 0xFF, 0x6D,
+0x0D, 0x6F, 0x12, 0xE9, 0x45, 0xE1, 0xC3, 0xF3,
+0xD1, 0xA1, 0xCF, 0xEE, 0x0C, 0xEE, 0x00, 0x18,
+0x75, 0x07, 0xC3, 0xF3, 0xD2, 0xA1, 0x01, 0x6C,
+0xFF, 0x6D, 0xCF, 0xEE, 0x0C, 0xEE, 0x0E, 0x6F,
+0x0A, 0x10, 0x00, 0x6C, 0xC4, 0x67, 0xFF, 0x6D,
+0x0F, 0x6F, 0x00, 0x18, 0x75, 0x07, 0x01, 0x6C,
+0xFF, 0x6D, 0x00, 0x6E, 0x10, 0x6F, 0x00, 0x18,
+0x75, 0x07, 0x01, 0x6A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xC3, 0xF3, 0x64, 0xA0, 0x01, 0x6D, 0xFF, 0x6A,
+0x66, 0x31, 0x0F, 0x6E, 0xAC, 0xEB, 0xCC, 0xE9,
+0x4C, 0xEB, 0x4C, 0xEC, 0x4C, 0xE9, 0x22, 0x23,
+0xC3, 0xF3, 0x68, 0xA0, 0x01, 0x73, 0x1E, 0x61,
+0x0A, 0x6B, 0x78, 0xE9, 0x12, 0xEB, 0x0D, 0xE3,
+0xC3, 0xF3, 0xF0, 0xA3, 0xEC, 0xEE, 0x8E, 0xEE,
+0x15, 0x2E, 0xC3, 0xF3, 0xD3, 0xA3, 0xCC, 0xED,
+0x4C, 0xED, 0x10, 0x25, 0xFF, 0xF6, 0x1F, 0x4A,
+0xCC, 0xEA, 0xC3, 0xF3, 0x53, 0xC3, 0x01, 0x6D,
+0x00, 0x18, 0x38, 0x31, 0x07, 0x22, 0x02, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x2D, 0x45, 0x02, 0x6A,
+0xC3, 0xF3, 0x48, 0xC0, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x00, 0x18, 0x15, 0x41, 0x00, 0x6B, 0xE0, 0xF0,
+0x1D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC3, 0xF3, 0xA4, 0xA2, 0x0F, 0x6C,
+0xFF, 0x6F, 0xA6, 0x33, 0x8C, 0xEB, 0xC3, 0x67,
+0xEC, 0xEE, 0x07, 0xD6, 0x01, 0x4B, 0x1F, 0x6E,
+0x8C, 0xEB, 0xCB, 0xEE, 0x64, 0x33, 0xCC, 0xED,
+0x6D, 0xED, 0xC3, 0xF3, 0xA4, 0xC2, 0xC3, 0xF3,
+0xA4, 0xA2, 0xC3, 0xF3, 0x66, 0xA2, 0xA6, 0x30,
+0x0E, 0xEB, 0x8C, 0xEB, 0xEC, 0xEB, 0x04, 0x2B,
+0x66, 0x67, 0xAC, 0xEB, 0xC3, 0xF3, 0x64, 0xC2,
+0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2, 0x00, 0x49,
+0xC3, 0xF3, 0x04, 0xA1, 0x0F, 0x6A, 0x0A, 0x6B,
+0x06, 0x30, 0x4C, 0xE8, 0x78, 0xE8, 0x12, 0xEB,
+0x2D, 0xE3, 0xC3, 0xF3, 0xAD, 0xA3, 0xC3, 0xF3,
+0x8C, 0xA3, 0xC5, 0x67, 0xD2, 0x36, 0x4C, 0xED,
+0x00, 0x18, 0xA0, 0x3C, 0xC3, 0xF3, 0x69, 0xA1,
+0x01, 0x6A, 0x6C, 0xEA, 0x00, 0x6B, 0x06, 0xD3,
+0x30, 0x2A, 0x3B, 0x10, 0x1F, 0x6D, 0xB8, 0xE8,
+0x06, 0x96, 0x0C, 0x6A, 0x12, 0xED, 0x58, 0xEE,
+0x12, 0xEA, 0x55, 0xE5, 0x35, 0xE5, 0x89, 0xE2,
+0xE0, 0xF6, 0x1A, 0x4D, 0x69, 0xE2, 0xA8, 0x35,
+0x29, 0xE2, 0x75, 0xE5, 0xA1, 0x9D, 0x43, 0xF4,
+0xEC, 0xA2, 0x30, 0xF0, 0x20, 0x6C, 0x4C, 0xF6,
+0x08, 0x4C, 0x00, 0x18, 0x37, 0x7A, 0x01, 0x49,
+0xFF, 0x6A, 0x4C, 0xE9, 0x7C, 0x6C, 0x98, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x12, 0xEC, 0x69, 0xE4, 0x63, 0xF4, 0x44, 0xA2,
+0x43, 0xE9, 0xD8, 0x61, 0x06, 0x92, 0x01, 0x4A,
+0x06, 0xD2, 0x06, 0x93, 0xFF, 0x6A, 0x4C, 0xEB,
+0x06, 0xD3, 0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF6,
+0x49, 0xA2, 0x06, 0x96, 0x0F, 0x6B, 0x46, 0x32,
+0x6C, 0xEA, 0x42, 0xEE, 0x02, 0x60, 0x00, 0x69,
+0xE1, 0x17, 0x00, 0x18, 0x85, 0x5B, 0x00, 0x6C,
+0xA4, 0x67, 0x00, 0x18, 0xF4, 0x5A, 0x07, 0x92,
+0x0A, 0x6D, 0x30, 0xF0, 0x20, 0x6B, 0xB8, 0xEA,
+0x86, 0xF2, 0x00, 0x4B, 0x02, 0x6A, 0x4B, 0xEA,
+0x01, 0x6F, 0x12, 0xEC, 0x71, 0xE4, 0xC3, 0xF3,
+0xD3, 0xA4, 0xB8, 0xE8, 0xCC, 0xEA, 0xC3, 0xF3,
+0x53, 0xC4, 0x11, 0x6A, 0x4B, 0xEA, 0x12, 0xED,
+0x75, 0xE5, 0xC3, 0xF3, 0x93, 0xA5, 0xC3, 0xF3,
+0xCF, 0xA5, 0x8C, 0xEA, 0x1F, 0x6C, 0x8C, 0xEA,
+0xD6, 0x34, 0xEC, 0xEC, 0xC3, 0xF3, 0x53, 0xC5,
+0xFF, 0x6A, 0x49, 0x2C, 0xC3, 0xF3, 0xE9, 0xA3,
+0x20, 0x6C, 0xEC, 0xEC, 0x4C, 0xEC, 0x24, 0x24,
+0x07, 0x6C, 0xCC, 0xEC, 0x4C, 0xEC, 0x0C, 0x2C,
+0xC3, 0xF3, 0x70, 0xA5, 0xC3, 0xF3, 0x94, 0xAD,
+0x0F, 0x6F, 0x6C, 0xEF, 0x00, 0x6D, 0xC2, 0x67,
+0x4C, 0xEF, 0x00, 0x18, 0x6D, 0x1D, 0x33, 0x10,
+0x02, 0x6A, 0x4E, 0xEC, 0x30, 0x2C, 0xA3, 0xF3,
+0xD4, 0x9B, 0xA3, 0xF3, 0x50, 0x9B, 0x04, 0xD4,
+0x10, 0xF0, 0x21, 0x6C, 0x5B, 0xE6, 0xC2, 0x36,
+0x02, 0xF3, 0x0D, 0x4C, 0x00, 0x6D, 0xCE, 0x36,
+0x01, 0x6F, 0x00, 0x18, 0x8A, 0x3B, 0x1F, 0x10,
+0x07, 0x6B, 0xCC, 0xEB, 0x4C, 0xEB, 0x02, 0x23,
+0x02, 0x73, 0x19, 0x61, 0x0A, 0x69, 0x38, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x0F, 0x6F, 0x00, 0x6D, 0xFF, 0x6E, 0x12, 0xE9,
+0x45, 0xE1, 0xC3, 0xF3, 0x50, 0xA1, 0xC3, 0xF3,
+0x94, 0xA9, 0x4C, 0xEF, 0x00, 0x18, 0x6D, 0x1D,
+0xC3, 0xF3, 0x73, 0xA1, 0x10, 0x6A, 0x6D, 0xEA,
+0x20, 0x4A, 0xC3, 0xF3, 0x53, 0xC1, 0x01, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x2D, 0x45, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0x6B, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF3, 0x68, 0xC2, 0x00, 0x6C, 0x00, 0x18,
+0x1D, 0x2E, 0x01, 0x6B, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x43, 0x67, 0x06, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF3, 0xA4, 0xA2, 0x0F, 0x6B, 0x0A, 0x69,
+0xA6, 0x35, 0x6C, 0xED, 0x38, 0xED, 0x12, 0xE9,
+0x45, 0xE1, 0xC3, 0xF3, 0x0F, 0xA1, 0x01, 0x6A,
+0x12, 0x30, 0x4C, 0xE8, 0x18, 0x28, 0xC3, 0xF3,
+0x53, 0xA1, 0x07, 0x6B, 0x46, 0x32, 0x6C, 0xEA,
+0x02, 0x52, 0x11, 0x60, 0x00, 0x18, 0xD1, 0x44,
+0xC3, 0xF3, 0xD0, 0xA1, 0x10, 0xF0, 0x21, 0x6C,
+0xFF, 0x6A, 0xD2, 0x36, 0xA3, 0xF0, 0x01, 0x4C,
+0x00, 0x6D, 0x4C, 0xEE, 0x01, 0x6F, 0x04, 0xD0,
+0x00, 0x18, 0x8A, 0x3B, 0x1B, 0x10, 0x0A, 0x6B,
+0x78, 0xED, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x01, 0x6C, 0x12, 0xEB, 0x4D, 0xE3,
+0xC3, 0xF3, 0x6F, 0xA3, 0x6E, 0x33, 0x8C, 0xEB,
+0x0A, 0x2B, 0x02, 0x6C, 0x00, 0x18, 0x2D, 0x45,
+0x00, 0x18, 0x7A, 0x45, 0x07, 0x2A, 0x06, 0x6C,
+0x00, 0x18, 0x1D, 0x2E, 0x03, 0x10, 0x03, 0x6B,
+0xC3, 0xF3, 0x68, 0xC2, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0xC3, 0xF3, 0xA4, 0xA4, 0x01, 0x6B, 0x0F, 0x6F,
+0xA6, 0x30, 0xAC, 0xEB, 0xEC, 0xE8, 0xFF, 0x6A,
+0x4D, 0x23, 0x0A, 0x69, 0x38, 0xE8, 0x07, 0x6D,
+0x12, 0xEB, 0x8D, 0xE3, 0xC3, 0xF3, 0xCF, 0xA3,
+0xCC, 0xED, 0xC3, 0xF3, 0xC8, 0xA4, 0x4C, 0xED,
+0x02, 0x76, 0x06, 0x60, 0x03, 0x6A, 0xCE, 0xEA,
+0x3B, 0x22, 0x01, 0x76, 0x36, 0x60, 0x3A, 0x10,
+0x01, 0x75, 0x04, 0x60, 0x27, 0x25, 0x04, 0x5D,
+0x35, 0x60, 0x24, 0x10, 0xC3, 0xF3, 0xC6, 0xA4,
+0xA1, 0x40, 0x4C, 0xED, 0xCC, 0xEF, 0xAE, 0xEF,
+0xEB, 0xEE, 0xED, 0xEE, 0xC0, 0xF7, 0xC3, 0x36,
+0xCC, 0xED, 0x38, 0xED, 0x12, 0xE9, 0x85, 0xE1,
+0xC3, 0xF3, 0x8E, 0xA1, 0x20, 0x5C, 0x06, 0x61,
+0xC3, 0xF3, 0x94, 0xAB, 0x0F, 0xF4, 0x00, 0x6D,
+0x4C, 0xEC, 0x0A, 0x10, 0xC3, 0xF3, 0xAE, 0xA1,
+0xC3, 0xF3, 0x94, 0xAB, 0xA0, 0x35, 0xA8, 0x35,
+0x4C, 0xEC, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED,
+0x00, 0x18, 0xE9, 0x1C, 0x02, 0x6C, 0xB0, 0x67,
+0x00, 0x18, 0x2D, 0x45, 0x00, 0x18, 0x7A, 0x45,
+0x09, 0x2A, 0x06, 0x6C, 0x00, 0x18, 0x1D, 0x2E,
+0x05, 0x10, 0x00, 0x18, 0x00, 0x46, 0x02, 0x10,
+0xC3, 0xF3, 0x48, 0xC4, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xC3, 0xF3, 0x64, 0xA0, 0x01, 0x6A, 0xFF, 0x69,
+0x6C, 0xEA, 0x21, 0x22, 0xC3, 0xF3, 0x45, 0xA0,
+0x20, 0x4A, 0xC3, 0xF3, 0x45, 0xC0, 0x00, 0x18,
+0x28, 0x46, 0xC3, 0xF3, 0x44, 0xA0, 0x0F, 0x6B,
+0xC3, 0xF3, 0x85, 0xA0, 0x46, 0x32, 0x6C, 0xEA,
+0xA0, 0xF0, 0x71, 0xA0, 0x96, 0x34, 0x2C, 0xEA,
+0x82, 0xEB, 0x0D, 0x61, 0x0A, 0x6B, 0x78, 0xEA,
+0x12, 0xEA, 0x01, 0xE2, 0xC3, 0xF3, 0x90, 0xA0,
+0xC3, 0xF3, 0x4E, 0xA0, 0x92, 0x34, 0x93, 0xE2,
+0x2C, 0xEC, 0x00, 0x18, 0x12, 0x44, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xFF, 0x68, 0x21, 0xF0,
+0x40, 0x9A, 0x0C, 0xEC, 0x04, 0xD4, 0x20, 0xA2,
+0x00, 0x6C, 0xB0, 0x67, 0x17, 0x6E, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0x15, 0x41, 0x01, 0x72,
+0x0C, 0xE9, 0x3A, 0x61, 0x04, 0x93, 0x0A, 0x69,
+0x30, 0xF0, 0x20, 0x6A, 0x38, 0xEB, 0x86, 0xF2,
+0x00, 0x4A, 0x0F, 0x6D, 0x12, 0xE9, 0x45, 0xE1,
+0xC3, 0xF3, 0x4D, 0xA1, 0xC3, 0xF3, 0x8C, 0xA1,
+0x4C, 0xED, 0x52, 0x36, 0x0C, 0xED, 0x0C, 0xEE,
+0x00, 0x18, 0xA0, 0x3C, 0xC3, 0xF3, 0x6F, 0xA1,
+0x01, 0x6C, 0x76, 0x32, 0x8C, 0xEA, 0x0C, 0xEA,
+0x19, 0x2A, 0x07, 0x6A, 0x6C, 0xEA, 0x0C, 0xEA,
+0x02, 0x22, 0x02, 0x72, 0x13, 0x61, 0x04, 0x94,
+0x0A, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x78, 0xEC,
+0x86, 0xF2, 0x00, 0x4A, 0x0F, 0x6F, 0x00, 0x6D,
+0xFF, 0x6E, 0x12, 0xEB, 0x4D, 0xE3, 0xC3, 0xF3,
+0x50, 0xA3, 0xC3, 0xF3, 0x94, 0xAB, 0x4C, 0xEF,
+0x00, 0x18, 0x6D, 0x1D, 0x04, 0x95, 0x01, 0x6C,
+0x00, 0x18, 0x2D, 0x45, 0x01, 0x6A, 0x06, 0x10,
+0x00, 0x6C, 0xB1, 0x67, 0x4B, 0x6E, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x6A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x60, 0xA4, 0x04, 0x67, 0x0F, 0x6C, 0x6C, 0xEC,
+0xFF, 0x69, 0x44, 0x67, 0x2C, 0xEA, 0x04, 0xD2,
+0x10, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x2C, 0xEA,
+0xF0, 0x72, 0x1C, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xC3, 0xF3, 0xA4, 0xA3,
+0x02, 0x6A, 0x4B, 0xEA, 0xAC, 0xEA, 0x1F, 0x6D,
+0xAB, 0xED, 0x84, 0x34, 0xAC, 0xEA, 0x8D, 0xEA,
+0xC3, 0xF3, 0x44, 0xC3, 0x04, 0x94, 0x00, 0x18,
+0x74, 0x46, 0x01, 0x72, 0x04, 0x6C, 0x49, 0x61,
+0x00, 0x6C, 0xA4, 0x67, 0x00, 0x18, 0x2D, 0x45,
+0x02, 0x6C, 0x43, 0x10, 0x04, 0x93, 0x0A, 0x6A,
+0x30, 0xF0, 0x20, 0x6C, 0x58, 0xEB, 0x49, 0xF6,
+0x0C, 0x4C, 0xA1, 0x40, 0x05, 0x6E, 0x12, 0xEB,
+0x71, 0xE4, 0x05, 0xD3, 0x00, 0x18, 0xB9, 0x20,
+0x05, 0x93, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x51, 0xE3, 0xC3, 0xF3, 0x50, 0xA4,
+0x52, 0x33, 0x2C, 0xEB, 0x06, 0x2B, 0x0F, 0x6B,
+0x6C, 0xEA, 0x20, 0x6B, 0x6D, 0xEA, 0xC3, 0xF3,
+0x50, 0xC4, 0x04, 0x94, 0x0A, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x78, 0xEC, 0x86, 0xF2, 0x00, 0x4A,
+0xE0, 0xF3, 0x08, 0x6C, 0x12, 0xEB, 0x4D, 0xE3,
+0xC3, 0xF3, 0xAE, 0xA3, 0xA0, 0x35, 0xA8, 0x35,
+0x9A, 0xED, 0x01, 0x2C, 0xE5, 0xE8, 0x12, 0xEC,
+0xC3, 0xF3, 0x8E, 0xC3, 0x60, 0xA0, 0x04, 0x94,
+0x72, 0x33, 0xFF, 0x4B, 0x8E, 0xEB, 0x7A, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF5, 0x78, 0x9B,
+0xA0, 0xF0, 0x94, 0x9A, 0x8C, 0xEB, 0x04, 0x23,
+0x05, 0x6C, 0x00, 0x18, 0x1D, 0x2E, 0x6E, 0x10,
+0xC3, 0xF3, 0x64, 0xA2, 0x1F, 0x6C, 0x8B, 0xEC,
+0x6C, 0xEC, 0xC3, 0xF3, 0x84, 0xC2, 0xC3, 0xF3,
+0xC6, 0xA2, 0xA0, 0xA0, 0x10, 0x6B, 0x6B, 0xEB,
+0xB2, 0x35, 0xCC, 0xEB, 0xAD, 0xEB, 0xC3, 0xF3,
+0x66, 0xC2, 0xC3, 0xF3, 0xAF, 0xA2, 0x61, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF0, 0x84, 0x9C, 0xBA, 0x35, 0xB4, 0x35,
+0xAD, 0xEB, 0x02, 0x6D, 0xA0, 0xC4, 0xA0, 0xF0,
+0x8F, 0xA2, 0x01, 0x6D, 0xFF, 0x6E, 0xAC, 0xEC,
+0xCC, 0xEC, 0x0B, 0x24, 0x7F, 0x6C, 0x6C, 0xEC,
+0xC3, 0xF3, 0x84, 0xC2, 0xC3, 0xF3, 0x85, 0xA2,
+0x20, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xAD, 0xEB,
+0x0A, 0x10, 0x80, 0x6C, 0x8B, 0xEC, 0x6D, 0xEC,
+0xC3, 0xF3, 0x84, 0xC2, 0xC3, 0xF3, 0x85, 0xA2,
+0x20, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xC3, 0xF3,
+0x65, 0xC2, 0xC3, 0xF3, 0x64, 0xA0, 0x01, 0x6A,
+0x03, 0x6C, 0x6D, 0xEA, 0xC3, 0xF3, 0x44, 0xC0,
+0xC3, 0xF3, 0x69, 0xA0, 0x00, 0x6A, 0xC3, 0xF3,
+0x48, 0xC0, 0x21, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xC3, 0xF3, 0x49, 0xC0, 0x00, 0x18, 0x1D, 0x2E,
+0xC3, 0xF3, 0x90, 0xA0, 0x0F, 0x69, 0x2C, 0xEC,
+0x00, 0x18, 0x96, 0x3F, 0xC3, 0xF3, 0x90, 0xA0,
+0x2C, 0xEC, 0x00, 0x18, 0x5D, 0x3F, 0xC3, 0xF3,
+0x9A, 0xA0, 0x2C, 0xEC, 0x00, 0x18, 0x5D, 0x3F,
+0xC3, 0xF3, 0x90, 0xA0, 0x2C, 0xEC, 0x00, 0x18,
+0x67, 0x3F, 0xC3, 0xF3, 0x9A, 0xA0, 0x2C, 0xEC,
+0x00, 0x18, 0x67, 0x3F, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF5, 0x74, 0x9B,
+0xFF, 0x6A, 0x8C, 0xEA, 0x60, 0x9B, 0x80, 0xF1,
+0x01, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF1, 0x90, 0x9C, 0x01, 0x72,
+0x80, 0x9C, 0x05, 0x60, 0x02, 0x72, 0x05, 0x61,
+0xFF, 0x6A, 0x01, 0x4A, 0x01, 0x10, 0x80, 0x6A,
+0x4D, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF5,
+0x54, 0x9A, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF7, 0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF1, 0x70, 0x9B, 0x8C, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF7, 0x70, 0x9B,
+0x50, 0x6A, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF7, 0x74, 0x9B, 0x40, 0xC3, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x4C, 0xED, 0x04, 0x67, 0x01, 0x75, 0x86, 0x67,
+0x4C, 0xE8, 0x4C, 0xEC, 0x03, 0x60, 0x03, 0x75,
+0x0A, 0x6B, 0x01, 0x61, 0x09, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF6, 0x5C, 0x9A, 0x0F, 0x6F,
+0xAC, 0xEF, 0x70, 0x33, 0xED, 0xEB, 0x60, 0xC2,
+0x00, 0x18, 0x16, 0x47, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF5, 0x50, 0x9A, 0x24, 0x58, 0x60, 0xA2,
+0x7F, 0x6A, 0x6C, 0xEA, 0x05, 0x61, 0x80, 0x6B,
+0x6B, 0xEB, 0x6D, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF5, 0x70, 0x9B,
+0x40, 0xC3, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF6, 0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x80, 0xA2, 0xFF, 0xF7,
+0x1F, 0x6E, 0xA6, 0xF2, 0x88, 0xC3, 0x30, 0xF0,
+0x20, 0x6C, 0xC1, 0xF7, 0x98, 0x9C, 0xA0, 0xAC,
+0xA6, 0xF2, 0xAA, 0xCB, 0xA0, 0xA2, 0xBF, 0x6B,
+0xAC, 0xEB, 0x60, 0xC2, 0xE0, 0xA2, 0x7F, 0x6D,
+0xFF, 0x6B, 0xEC, 0xED, 0xA0, 0xC2, 0xA0, 0xA2,
+0xAC, 0xEB, 0x60, 0xC2, 0x40, 0xAC, 0xFF, 0x6B,
+0x21, 0x4B, 0xCC, 0xEA, 0x6D, 0xEA, 0xCC, 0xEA,
+0x40, 0xCC, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0xA6, 0xF2, 0x88, 0xA2, 0xE1, 0xF6, 0x6C, 0x9B,
+0x80, 0xC3, 0xA6, 0xF2, 0x6A, 0xAA, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF7, 0x58, 0x9A, 0x60, 0xCA,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x8C, 0xEA,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF7,
+0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF0,
+0x88, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF7, 0x7C, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF7, 0x80, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x07, 0x6B, 0x8C, 0xEB,
+0x4C, 0xED, 0x8E, 0x34, 0x42, 0xF4, 0x10, 0x4C,
+0x36, 0x25, 0x1F, 0xF7, 0x00, 0x6D, 0x8C, 0xED,
+0x02, 0xF0, 0x00, 0x75, 0x01, 0x60, 0x21, 0x2D,
+0x1F, 0xF7, 0x00, 0x6A, 0x8C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x07, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0xB8, 0x9A, 0xB5, 0xE4,
+0x80, 0xA5, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0xB8, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x5C, 0x9A, 0xB5, 0xE4, 0x51, 0xE4,
+0x80, 0xA4, 0x00, 0xF6, 0x80, 0x34, 0x01, 0x6A,
+0x00, 0xF6, 0x83, 0x34, 0x44, 0xEB, 0x8D, 0xEA,
+0x36, 0x10, 0x30, 0xF0, 0x20, 0x6D, 0x41, 0xF0,
+0xBC, 0x9D, 0x01, 0x6E, 0xC4, 0xEB, 0xB1, 0xE4,
+0xA0, 0xA4, 0x00, 0xF6, 0xA0, 0x35, 0x00, 0xF6,
+0xA3, 0x35, 0xCD, 0xED, 0x3A, 0x10, 0x1F, 0xF7,
+0x00, 0x6D, 0x8C, 0xED, 0x02, 0xF0, 0x00, 0x75,
+0x01, 0x60, 0x25, 0x2D, 0x1F, 0xF7, 0x00, 0x6A,
+0x8C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0xB8, 0x9A, 0xB5, 0xE4, 0x80, 0xA5, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0xB8, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0xB5, 0xE4, 0x51, 0xE4, 0x80, 0xA4, 0x01, 0x6A,
+0x00, 0xF6, 0x80, 0x34, 0x44, 0xEB, 0x00, 0xF6,
+0x83, 0x34, 0x4F, 0xEA, 0x8C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x40, 0xC5, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6D, 0x41, 0xF0, 0xBC, 0x9D, 0x01, 0x6E,
+0xC4, 0xEB, 0xB1, 0xE4, 0xA0, 0xA4, 0xCF, 0xEE,
+0x00, 0xF6, 0xA0, 0x35, 0x00, 0xF6, 0xA3, 0x35,
+0xCC, 0xED, 0x4C, 0xED, 0xA0, 0xC4, 0x20, 0xE8,
+0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xED, 0x07, 0x6A,
+0xAC, 0xEA, 0x6C, 0xEC, 0xC5, 0x67, 0x04, 0x22,
+0xAE, 0x36, 0x01, 0x4E, 0xCC, 0x36, 0x6C, 0xEE,
+0x89, 0xE6, 0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x05, 0xF7, 0x00, 0x5A, 0x06, 0x61, 0x05, 0xF7,
+0x00, 0x6A, 0x8B, 0xE2, 0x6C, 0xEA, 0x4B, 0xE6,
+0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF6,
+0x70, 0x9B, 0x05, 0x6C, 0x40, 0xCB, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF7, 0x64, 0x9B, 0x80, 0xC3,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEC, 0x4C, 0xED, 0x8D, 0xE5, 0xC3, 0x67,
+0x4C, 0xEE, 0x05, 0xF7, 0x00, 0x5E, 0x0C, 0x61,
+0x05, 0xF7, 0x00, 0x6B, 0x93, 0xE3, 0x4C, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x4C, 0x9A,
+0x93, 0xE5, 0x51, 0xE4, 0x40, 0x9C, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x4C, 0x9A,
+0x4D, 0xE3, 0x40, 0x9B, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x4C, 0xED,
+0x8D, 0xE5, 0xC3, 0x67, 0x4C, 0xEE, 0x05, 0xF7,
+0x00, 0x5E, 0x0E, 0x61, 0x05, 0xF7, 0x00, 0x6B,
+0x93, 0xE3, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x4C, 0x9A, 0x93, 0xE5, 0x51, 0xE4,
+0x60, 0xA4, 0xFF, 0x6A, 0x6C, 0xEA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x4C, 0x9A,
+0x4D, 0xE3, 0x60, 0xA3, 0xFF, 0x6A, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF7, 0x68, 0x9A, 0x8F, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x5C, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x0A, 0xF0, 0x76, 0xAB, 0x40, 0x9A, 0x08, 0x6C,
+0x60, 0x33, 0x68, 0x33, 0x4D, 0xE3, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF7, 0x4C, 0x9A, 0x8B, 0xEC,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF7,
+0x50, 0x9A, 0x60, 0x9A, 0x8C, 0xEB, 0x60, 0xDA,
+0x60, 0x9A, 0x80, 0x6C, 0x8D, 0xEB, 0x60, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF7, 0x68, 0x9A, 0x8F, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x5C, 0x9A, 0x60, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x83, 0xF5,
+0x96, 0xAA, 0xA3, 0xF5, 0xB6, 0xAA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF7, 0x4C, 0x9A, 0x80, 0x34,
+0x88, 0x34, 0x71, 0xE4, 0x80, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF7, 0x50, 0x9A, 0xA0, 0x35,
+0xA8, 0x35, 0x75, 0xE5, 0x60, 0x9A, 0x08, 0x6C,
+0x8B, 0xEC, 0x8C, 0xEB, 0x60, 0xDA, 0x60, 0x9A,
+0x80, 0x6C, 0x8D, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF7, 0x94, 0x9B, 0xA0, 0xDC,
+0x60, 0x9A, 0x00, 0xF7, 0x01, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEB, 0x60, 0xDA, 0x60, 0x9A, 0x10, 0xF0,
+0x00, 0x6C, 0x8D, 0xEB, 0x60, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF7, 0x68, 0x9A,
+0x8F, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x5C, 0x9A,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF5, 0xD6, 0xAA, 0xA3, 0xF5,
+0x96, 0xAA, 0xC3, 0xF5, 0xB6, 0xAA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF7, 0x4C, 0x9A, 0xC0, 0x36,
+0xC8, 0x36, 0x79, 0xE6, 0xC0, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF7, 0x50, 0x9A, 0x80, 0x34,
+0xA0, 0x35, 0x88, 0x34, 0xA8, 0x35, 0x71, 0xE4,
+0x75, 0xE5, 0x60, 0x9A, 0x08, 0x6E, 0xCB, 0xEE,
+0xCC, 0xEB, 0x60, 0xDA, 0x60, 0x9A, 0x80, 0x6E,
+0xCD, 0xEB, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF7, 0x74, 0x9B, 0x80, 0xDB, 0x60, 0x9A,
+0x00, 0xF7, 0x01, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB,
+0x60, 0xDA, 0x60, 0x9A, 0x10, 0xF0, 0x00, 0x6C,
+0x8D, 0xEB, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF7, 0x98, 0x9B, 0xA0, 0xDC, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0x9A, 0xE1, 0xF7, 0x9C, 0x9C,
+0x8C, 0xEB, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0x9A, 0x81, 0xF3, 0x88, 0x9C, 0x8D, 0xEB,
+0x60, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x60, 0x9B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xED, 0x60, 0x9B, 0x4C, 0xEC, 0x9C, 0x34,
+0x6D, 0xE6, 0x78, 0x33, 0x62, 0x33, 0x62, 0x33,
+0x75, 0xE5, 0x18, 0x6B, 0x78, 0xEF, 0x4C, 0xED,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE5, 0x67, 0x12, 0xEB, 0x49, 0xE3, 0x30, 0xF0,
+0x20, 0x6B, 0xE3, 0xF5, 0xD6, 0xA2, 0x02, 0xF0,
+0x60, 0x9B, 0xE3, 0xF5, 0xBC, 0xCA, 0xA2, 0x35,
+0x79, 0xE6, 0xFF, 0x6B, 0x99, 0xE6, 0x6C, 0xEF,
+0xE0, 0xC6, 0xE3, 0xF5, 0xD6, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x02, 0xF0, 0x44, 0x9A, 0x6C, 0xED,
+0x49, 0xE6, 0x91, 0xE2, 0xA0, 0xC4, 0x20, 0xE8,
+0xFF, 0x6B, 0x6C, 0xED, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEC, 0x01, 0x75, 0xCC, 0xEB, 0x9C, 0x34,
+0x11, 0x61, 0x18, 0x6D, 0xB8, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0x40, 0x9A, 0x51, 0xE4,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xEB, 0x49, 0xE3, 0xE3, 0xF5, 0x58, 0xAA,
+0x40, 0xCC, 0x20, 0xE8, 0x15, 0x2D, 0x18, 0x6E,
+0xD8, 0xEB, 0x30, 0xF0, 0x20, 0x6D, 0x41, 0xF4,
+0xA0, 0x9D, 0xB1, 0xE4, 0x30, 0xF0, 0x20, 0x6D,
+0x86, 0xF2, 0x00, 0x4D, 0x12, 0xEB, 0xB5, 0xE3,
+0xE3, 0xF5, 0x78, 0xAD, 0xE3, 0xF5, 0xB6, 0xA5,
+0xF8, 0x4B, 0xAF, 0xE3, 0x4C, 0xEB, 0x60, 0xCC,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEB, 0x4C, 0xEC, 0x01, 0x73,
+0x9C, 0x34, 0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF4, 0x40, 0x9A, 0x51, 0xE4, 0x30, 0xF0,
+0x20, 0x6A, 0xE9, 0xF7, 0x58, 0xAA, 0x40, 0xCC,
+0x20, 0xE8, 0x11, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF4, 0x60, 0x9B, 0x71, 0xE4, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x63, 0xF5,
+0xD8, 0xAB, 0x63, 0xF5, 0xB7, 0xA3, 0x09, 0x4E,
+0xAF, 0xE6, 0x4C, 0xEB, 0x60, 0xCC, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD1, 0x00, 0xD0, 0xFF, 0x6A,
+0x4C, 0xEC, 0xFF, 0xF7, 0x1F, 0x6B, 0xCC, 0xEA,
+0xAC, 0xEB, 0x01, 0x72, 0x7C, 0x33, 0x1B, 0x61,
+0x14, 0x6E, 0xD8, 0xEC, 0x30, 0xF0, 0x20, 0x6D,
+0x86, 0xF2, 0x00, 0x4D, 0x01, 0x6F, 0x12, 0xEE,
+0xB9, 0xE6, 0x43, 0xF6, 0xC6, 0xA6, 0xEE, 0xEE,
+0x0A, 0x2E, 0x1E, 0x6F, 0xF8, 0xEC, 0x12, 0xEF,
+0xB5, 0xE7, 0x02, 0x6F, 0x43, 0xF6, 0xF0, 0xC5,
+0x43, 0xF6, 0xD1, 0xC5, 0x22, 0x10, 0x1E, 0x6E,
+0xD8, 0xEC, 0x12, 0xEE, 0x09, 0x10, 0x02, 0x72,
+0x0D, 0x61, 0x1E, 0x6D, 0xB8, 0xEC, 0x30, 0xF0,
+0x20, 0x6E, 0x86, 0xF2, 0x00, 0x4E, 0x12, 0xED,
+0xD5, 0xE5, 0x43, 0xF6, 0xD0, 0xA5, 0x43, 0xF6,
+0xD1, 0xC5, 0x0C, 0x10, 0x03, 0x72, 0x0D, 0x61,
+0x1E, 0x6E, 0xD8, 0xEC, 0x30, 0xF0, 0x20, 0x6D,
+0x86, 0xF2, 0x00, 0x4D, 0x12, 0xEE, 0xB5, 0xE6,
+0x43, 0xF6, 0xD0, 0xA5, 0x01, 0x4E, 0x43, 0xF6,
+0xD0, 0xC5, 0x1E, 0x68, 0x18, 0xEC, 0x30, 0xF0,
+0x20, 0x6E, 0x86, 0xF2, 0x00, 0x4E, 0x30, 0xF0,
+0x20, 0x6D, 0x01, 0xF5, 0xF0, 0x9D, 0xFD, 0xE3,
+0x12, 0xE8, 0xD5, 0xE0, 0x43, 0xF6, 0x30, 0xA5,
+0x20, 0xC7, 0x30, 0xF0, 0x20, 0x6F, 0x01, 0xF5,
+0xF4, 0x9F, 0x43, 0xF6, 0x31, 0xA5, 0xFD, 0xE3,
+0x20, 0xC7, 0x14, 0x6F, 0xF8, 0xEC, 0x12, 0xEF,
+0xDD, 0xE7, 0x43, 0xF6, 0x20, 0xA7, 0xC5, 0x67,
+0x43, 0xF6, 0x12, 0x4E, 0x43, 0xF6, 0x32, 0xC5,
+0x43, 0xF6, 0x21, 0xA7, 0x43, 0xF6, 0x33, 0xC5,
+0x43, 0xF6, 0x22, 0xA7, 0x43, 0xF6, 0x34, 0xC5,
+0x43, 0xF6, 0x23, 0xA7, 0x43, 0xF6, 0x35, 0xC5,
+0x43, 0xF6, 0x24, 0xA7, 0x43, 0xF6, 0x36, 0xC5,
+0x43, 0xF6, 0xE5, 0xA7, 0x43, 0xF6, 0xF7, 0xC5,
+0x30, 0xF0, 0x20, 0x6D, 0x30, 0xF0, 0x20, 0x6F,
+0x01, 0xF4, 0xBC, 0x9D, 0xE1, 0xF4, 0xEC, 0x9F,
+0xB5, 0xE3, 0xFD, 0xE3, 0x00, 0xA6, 0x01, 0x4E,
+0x00, 0xC5, 0x01, 0x4D, 0xEA, 0xED, 0xFA, 0x61,
+0x01, 0x72, 0x1E, 0x61, 0x14, 0x6D, 0xB8, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xED, 0x55, 0xE5, 0x43, 0xF6, 0xA6, 0xA5,
+0x01, 0x75, 0x1F, 0x61, 0x1E, 0x6E, 0xD8, 0xEC,
+0x12, 0xEE, 0x53, 0xF6, 0xA8, 0x46, 0xA9, 0xE2,
+0x30, 0xF0, 0x20, 0x6D, 0xCA, 0xF0, 0x1E, 0x4D,
+0xD5, 0xE5, 0x00, 0x6F, 0xE0, 0xC2, 0xE6, 0xC2,
+0x01, 0x4A, 0xAA, 0xEA, 0xFA, 0x61, 0x0D, 0x10,
+0x03, 0x72, 0x0B, 0x61, 0x1E, 0x6D, 0xB8, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xED, 0x59, 0xE5, 0x63, 0xF6, 0xC4, 0xA6,
+0x15, 0x26, 0x1E, 0x6A, 0x58, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0,
+0x20, 0x6D, 0x02, 0xF0, 0xAC, 0x9D, 0x12, 0xEC,
+0x43, 0xF6, 0x18, 0x4C, 0x91, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x02, 0xF0, 0x48, 0x9A, 0x49, 0xE3,
+0xAD, 0xE3, 0x17, 0x10, 0x14, 0x6E, 0xD8, 0xEC,
+0x12, 0xEE, 0x59, 0xE6, 0x43, 0xF6, 0xC6, 0xA6,
+0x01, 0x76, 0xE3, 0x61, 0x53, 0xF6, 0xC8, 0x45,
+0xC9, 0xE2, 0x30, 0xF0, 0x20, 0x6E, 0xCA, 0xF0,
+0x1E, 0x4E, 0xB5, 0xE6, 0x00, 0x6F, 0xE0, 0xC2,
+0xE6, 0xC2, 0x01, 0x4A, 0xAA, 0xEA, 0xFA, 0x61,
+0xD4, 0x17, 0xA0, 0xA4, 0xA0, 0xC2, 0xC6, 0xA4,
+0xA6, 0x42, 0x01, 0x4A, 0x6A, 0xEA, 0xC0, 0xC5,
+0x01, 0x4C, 0xF7, 0x61, 0x01, 0x91, 0x00, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF7, 0x48, 0xA2, 0x02, 0x6D, 0xFF, 0x6C,
+0xAC, 0xEA, 0x11, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF1, 0x7C, 0x9A, 0x0D, 0x6E, 0x40, 0x9B,
+0xCD, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x68, 0x9A, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x63, 0xF5,
+0x88, 0xA2, 0x04, 0x6B, 0x8C, 0xEB, 0x07, 0x2B,
+0x63, 0xF5, 0x6D, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x13, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x7C, 0x9A, 0x07, 0x6C,
+0x02, 0x6D, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x68, 0x9A,
+0xFF, 0x6C, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xE9, 0xF7, 0x68, 0xA2, 0x06, 0x6A, 0xFF, 0x6C,
+0x6C, 0xEA, 0x06, 0x72, 0x12, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x7C, 0x9A, 0x0F, 0x6D,
+0x40, 0x9B, 0xAD, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x68, 0x9A, 0x02, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF7, 0x50, 0x9A, 0x81, 0x6D, 0xAB, 0xED,
+0x60, 0x9A, 0xAC, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF7, 0x6C, 0x9B, 0x80, 0xDB,
+0x60, 0x9A, 0x05, 0x6C, 0x8D, 0xEB, 0x60, 0xDA,
+0x60, 0x9A, 0x80, 0x6C, 0x8D, 0xEB, 0x60, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x34, 0x33, 0x0D, 0xE3, 0x30, 0xF0, 0x20, 0x6A,
+0x83, 0xF5, 0x96, 0xAB, 0xA0, 0xF7, 0x40, 0x9A,
+0x05, 0x4C, 0x40, 0x9A, 0x80, 0x34, 0x88, 0x34,
+0x51, 0xE4, 0x18, 0x6A, 0x58, 0xE9, 0x12, 0xEA,
+0x09, 0xE2, 0x04, 0xD2, 0x03, 0xF6, 0x80, 0xDA,
+0x00, 0x18, 0x2D, 0x49, 0x04, 0x93, 0x01, 0x6A,
+0x63, 0xF5, 0x3A, 0xC0, 0xE3, 0xF5, 0x5A, 0xC3,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF7, 0x50, 0x9A, 0x10, 0xF0, 0x01, 0x6D,
+0xAB, 0xED, 0x60, 0x9A, 0xAC, 0xEB, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF7, 0x74, 0x9B,
+0x80, 0xDB, 0x60, 0x9A, 0x00, 0xF5, 0x00, 0x6C,
+0x8D, 0xEB, 0x60, 0xDA, 0x60, 0x9A, 0x0F, 0xF3,
+0x00, 0x4C, 0x8D, 0xEB, 0x60, 0xDA, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x18, 0x6D, 0xB8, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x40, 0x9A, 0x14, 0x34,
+0x00, 0x6E, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x51, 0xE4, 0x83, 0xF5,
+0x9E, 0xAC, 0x12, 0xED, 0x55, 0xE5, 0xE3, 0xF5,
+0xD1, 0xC5, 0x08, 0x20, 0xE3, 0xF5, 0xAF, 0xA2,
+0x02, 0x75, 0x04, 0x61, 0x03, 0xF6, 0x47, 0xA2,
+0x02, 0x72, 0x16, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x02, 0xF0, 0x50, 0x9A, 0x58, 0xEC, 0x12, 0xEC,
+0x71, 0xE4, 0x00, 0x18, 0x4F, 0x49, 0x18, 0x6B,
+0x78, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x63, 0xF5, 0x1B, 0xC2, 0x01, 0x6B,
+0x12, 0xE8, 0x49, 0xE0, 0xE3, 0xF5, 0x7A, 0xC2,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF7, 0x50, 0x9A,
+0x30, 0xF0, 0x20, 0x6D, 0x21, 0xF7, 0xB8, 0x9D,
+0x60, 0x9A, 0xAC, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF7, 0x78, 0x9B, 0x80, 0xDB,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9A, 0x02, 0xF0,
+0x94, 0x9C, 0x8D, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0x9A, 0x81, 0xF3, 0x88, 0x9C,
+0x8D, 0xEB, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x01, 0x6A, 0x8C, 0xEB, 0x82, 0x67,
+0x07, 0x10, 0xFF, 0xF7, 0x1F, 0x6D, 0x44, 0x32,
+0xAC, 0xEA, 0x01, 0x4C, 0xFF, 0x6D, 0xAC, 0xEC,
+0x83, 0xEB, 0xF7, 0x60, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF6, 0x5C, 0x9A,
+0xE5, 0xF6, 0x1F, 0x6B, 0xFF, 0x6C, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF6, 0x40, 0x9A,
+0x10, 0x6B, 0x08, 0x6D, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF6, 0x44, 0x9A, 0x01, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6,
+0x58, 0x9A, 0x60, 0xA2, 0x8C, 0xEB, 0xAD, 0xEB,
+0x8C, 0xEB, 0x60, 0xC2, 0x80, 0xA2, 0xF8, 0x6B,
+0x8C, 0xEB, 0x60, 0xC2, 0x80, 0xA2, 0xEF, 0x6B,
+0x8C, 0xEB, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF6, 0x48, 0x9A, 0x00, 0xF2, 0x01, 0x6C,
+0x8B, 0xEC, 0x60, 0x9A, 0x8C, 0xEB, 0x60, 0xDA,
+0x60, 0x9A, 0x00, 0xF1, 0x00, 0x4C, 0x8C, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF6,
+0x6C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xC0, 0xF7,
+0x80, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF6, 0x50, 0x9A,
+0x60, 0xA2, 0x04, 0x5B, 0x02, 0x60, 0x04, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x02, 0xF0,
+0x58, 0x9A, 0x04, 0x6D, 0x20, 0x6B, 0xA0, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x02, 0xF0, 0x5C, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6C, 0x00, 0xF4, 0x00, 0x6E,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x22, 0xF0,
+0x60, 0x9A, 0x40, 0xAB, 0x8C, 0xEA, 0xCD, 0xEA,
+0x8C, 0xEA, 0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6A,
+0x22, 0xF0, 0x44, 0x9A, 0xA0, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x22, 0xF0, 0x48, 0x9A, 0x21, 0x6D,
+0xA0, 0xC2, 0x40, 0xAB, 0x01, 0xF0, 0x00, 0x6D,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xCB,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF6, 0x78, 0x9A,
+0xFF, 0x6C, 0x9E, 0xF7, 0x00, 0x4D, 0x40, 0xA3,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x5C, 0x35, 0x00, 0x6B, 0x03, 0x6A,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF5, 0x88, 0x9C,
+0x30, 0xF0, 0x20, 0x6E, 0x01, 0xF5, 0xCC, 0x9E,
+0x91, 0xE5, 0x51, 0xE4, 0xE0, 0xA4, 0xD9, 0xE5,
+0x59, 0xE6, 0xFF, 0x6C, 0xC0, 0xA6, 0x8C, 0xEF,
+0xCE, 0x77, 0x8C, 0xEE, 0x0B, 0x60, 0x09, 0x73,
+0x02, 0x61, 0x44, 0x67, 0x20, 0xE8, 0x01, 0x4B,
+0x02, 0x4E, 0x8C, 0xEB, 0xC9, 0xE2, 0x0A, 0x73,
+0x8C, 0xEA, 0xE2, 0x61, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x5C, 0x35,
+0x00, 0x6B, 0x14, 0x6A, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF5, 0x88, 0x9C, 0x30, 0xF0, 0x20, 0x6E,
+0x01, 0xF5, 0xCC, 0x9E, 0x91, 0xE5, 0x51, 0xE4,
+0xE0, 0xA4, 0xD9, 0xE5, 0x59, 0xE6, 0xFF, 0x6C,
+0xC0, 0xA6, 0x8C, 0xEF, 0xCE, 0x77, 0x8C, 0xEE,
+0x0B, 0x60, 0x09, 0x73, 0x02, 0x61, 0x44, 0x67,
+0x20, 0xE8, 0x01, 0x4B, 0x02, 0x4E, 0x8C, 0xEB,
+0xC9, 0xE2, 0x0A, 0x73, 0x8C, 0xEA, 0xE2, 0x61,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0xE0, 0x63, 0x3F, 0x62, 0x3E, 0xD0, 0x01, 0x6A,
+0x7D, 0x67, 0x4B, 0xEA, 0x30, 0xF0, 0x20, 0x68,
+0x50, 0xC3, 0xE9, 0xF7, 0x1C, 0x48, 0x0D, 0x6A,
+0x52, 0xC3, 0x05, 0x04, 0xB0, 0x67, 0x20, 0x6A,
+0x04, 0x6E, 0x53, 0xC3, 0x00, 0x18, 0xB9, 0x20,
+0x06, 0x04, 0xA4, 0x40, 0x04, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0xA7, 0x40, 0x07, 0x04, 0x01, 0x4D,
+0x04, 0x6E, 0x00, 0x18, 0xB9, 0x20, 0xA7, 0x40,
+0x08, 0x04, 0x05, 0x4D, 0x04, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0x04, 0x04, 0x00, 0x18, 0x33, 0x27,
+0x3F, 0x97, 0x3E, 0x90, 0x20, 0x63, 0x00, 0xEF,
+0xE0, 0x63, 0x3F, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x18, 0x6B, 0x78, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x86, 0xF2, 0x00, 0x4C, 0x00, 0x6D, 0x12, 0xEB,
+0x8D, 0xE3, 0xE3, 0xF5, 0xAF, 0xC3, 0xE3, 0xF5,
+0xB0, 0xC3, 0xE3, 0xF5, 0xB1, 0xC3, 0xE3, 0xF5,
+0xB2, 0xC3, 0x00, 0x6D, 0xE3, 0xF5, 0xB4, 0xCB,
+0x01, 0x6B, 0x63, 0xF5, 0xB2, 0xC4, 0x6B, 0xEB,
+0x9D, 0x67, 0x70, 0xC4, 0x1C, 0x6B, 0x72, 0xC4,
+0x20, 0x6B, 0x73, 0xC4, 0x54, 0xC4, 0x04, 0x04,
+0x00, 0x18, 0x33, 0x27, 0x3F, 0x97, 0x20, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xE0, 0x63, 0x3F, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x83, 0xF6, 0x68, 0xAA, 0x00, 0xF1, 0x01, 0x73,
+0x3A, 0x61, 0x01, 0x6B, 0x9D, 0x67, 0x6B, 0xEB,
+0x70, 0xC4, 0x0C, 0x6B, 0x72, 0xC4, 0x20, 0x6B,
+0x73, 0xC4, 0x63, 0xF6, 0x68, 0xA2, 0x00, 0x6D,
+0x04, 0x6E, 0x74, 0xC4, 0x63, 0xF6, 0x69, 0xA2,
+0x75, 0xC4, 0x63, 0xF6, 0x6A, 0xA2, 0x63, 0xF6,
+0x4B, 0xA2, 0x76, 0xC4, 0x57, 0xC4, 0x06, 0x04,
+0x00, 0x18, 0xB4, 0x20, 0x30, 0xF0, 0x20, 0x6D,
+0x07, 0x04, 0xEA, 0xF0, 0x10, 0x4D, 0x04, 0x6E,
+0x00, 0x18, 0xB9, 0x20, 0x08, 0x04, 0x00, 0x6D,
+0x04, 0x6E, 0x00, 0x18, 0xB4, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0xEA, 0xF0,
+0x18, 0x4A, 0x09, 0x03, 0x0A, 0xF1, 0x00, 0x4C,
+0xA0, 0xA2, 0xA0, 0xC3, 0xA8, 0xA2, 0x01, 0x4A,
+0x8A, 0xEA, 0xA8, 0xC3, 0x01, 0x4B, 0xF8, 0x61,
+0x04, 0x04, 0x00, 0x18, 0x33, 0x27, 0x3F, 0x97,
+0x20, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x00, 0x6A, 0xFF, 0x69,
+0x8C, 0xE9, 0x63, 0xF5, 0x52, 0xC0, 0x14, 0x6A,
+0x58, 0xE9, 0x30, 0xF0, 0x20, 0x6C, 0xAA, 0xF0,
+0x14, 0x4C, 0x00, 0x6D, 0xC2, 0x67, 0x12, 0xEB,
+0x71, 0xE4, 0x04, 0xD3, 0x00, 0x18, 0xB4, 0x20,
+0x1E, 0x6A, 0x58, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0xCA, 0xF0, 0x08, 0x4A, 0x00, 0x6D, 0x1E, 0x6E,
+0x12, 0xE9, 0x31, 0xE2, 0x00, 0x18, 0xB4, 0x20,
+0x04, 0x92, 0x01, 0xE2, 0x01, 0x6A, 0x43, 0xF6,
+0x47, 0xC0, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x63, 0xF5, 0x68, 0xA0, 0x01, 0x6A,
+0x6C, 0xEA, 0x32, 0x22, 0x04, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x2D, 0x22, 0x23, 0xF6,
+0x5A, 0xA0, 0x04, 0x2A, 0x43, 0xF6, 0x50, 0xA0,
+0x01, 0x72, 0x26, 0x60, 0x00, 0x18, 0x6A, 0x40,
+0x63, 0xF6, 0x45, 0xA0, 0x05, 0x2A, 0x63, 0xF6,
+0x44, 0xA0, 0x01, 0x4A, 0x63, 0xF6, 0x44, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x63, 0xF6, 0x84, 0xA2, 0x23, 0xF6, 0x7B, 0xA2,
+0x8E, 0xEB, 0x12, 0x2B, 0x30, 0xF0, 0x20, 0x6C,
+0x22, 0xF0, 0x8C, 0x9C, 0x60, 0xDC, 0x23, 0xF6,
+0x95, 0xA2, 0x43, 0xF6, 0x06, 0xA2, 0x63, 0xF6,
+0x64, 0xC2, 0x00, 0x18, 0x8A, 0x49, 0x0E, 0xEA,
+0x03, 0x2A, 0x00, 0x6C, 0x00, 0x18, 0x49, 0x4A,
+0x30, 0xF0, 0x20, 0x6A, 0xE9, 0xF7, 0x6D, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x6A, 0x40, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x6A, 0xF0, 0x0F, 0x4A, 0x87, 0x42, 0x41, 0x4C,
+0x00, 0x6B, 0x00, 0x69, 0x60, 0xC2, 0x61, 0xC2,
+0x62, 0xC2, 0x63, 0xC2, 0x00, 0xF0, 0x25, 0xCA,
+0x27, 0xC2, 0x18, 0x4A, 0x8A, 0xEA, 0xF4, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xEA, 0xF0, 0x08, 0x4C,
+0x00, 0x6D, 0x24, 0x6E, 0x00, 0x18, 0xB4, 0x20,
+0x30, 0xF0, 0x20, 0x68, 0x30, 0xF0, 0x20, 0x6C,
+0x86, 0xF2, 0x00, 0x48, 0xAA, 0xF0, 0x14, 0x4C,
+0x00, 0x6D, 0x14, 0x6E, 0x63, 0xF5, 0x32, 0xC0,
+0x00, 0x18, 0xB4, 0x20, 0x30, 0xF0, 0x20, 0x6C,
+0xCA, 0xF0, 0x08, 0x4C, 0x00, 0x6D, 0x1E, 0x6E,
+0x00, 0x18, 0xB4, 0x20, 0x01, 0x6A, 0x43, 0xF6,
+0x47, 0xC0, 0x63, 0xF6, 0x45, 0xC0, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x04, 0xD2,
+0xFF, 0x6A, 0x4C, 0xED, 0x4C, 0xEE, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B,
+0x05, 0xD5, 0x06, 0xD6, 0x63, 0xF5, 0x70, 0xCA,
+0x00, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x63, 0xF5, 0xB0, 0xA8, 0x05, 0x93,
+0x06, 0x92, 0x03, 0x4D, 0xB5, 0xE3, 0x04, 0x94,
+0xFF, 0xF7, 0x1F, 0x6B, 0xB5, 0xE2, 0x6C, 0xED,
+0x00, 0x18, 0xD4, 0x47, 0x63, 0xF5, 0xB0, 0xA8,
+0x07, 0xD2, 0x05, 0x92, 0x06, 0x93, 0x04, 0x4D,
+0xB5, 0xE2, 0x04, 0x94, 0xB5, 0xE3, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xED, 0x00, 0x18, 0xD4, 0x47,
+0x07, 0x93, 0xCE, 0x73, 0x0C, 0x60, 0x63, 0xF5,
+0x70, 0xA8, 0x02, 0x71, 0x02, 0x4B, 0x69, 0xE2,
+0x63, 0xF5, 0x50, 0xC8, 0x09, 0x61, 0x58, 0x67,
+0x63, 0xF5, 0x50, 0xC8, 0x0A, 0x10, 0x4B, 0xEB,
+0x4D, 0xEB, 0xC0, 0xF7, 0x62, 0x32, 0x06, 0x10,
+0x01, 0x49, 0xFF, 0x6A, 0x4C, 0xE9, 0x03, 0x71,
+0xC8, 0x61, 0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x04, 0xD2,
+0xFF, 0x6A, 0x4C, 0xED, 0x4C, 0xEE, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B,
+0x05, 0xD5, 0x06, 0xD6, 0x63, 0xF5, 0x6E, 0xCA,
+0x00, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x63, 0xF5, 0xAE, 0xA8, 0x05, 0x93,
+0x06, 0x92, 0x14, 0x4D, 0xB5, 0xE3, 0x04, 0x94,
+0xFF, 0xF7, 0x1F, 0x6B, 0xB5, 0xE2, 0x6C, 0xED,
+0x00, 0x18, 0xD4, 0x47, 0x63, 0xF5, 0xAE, 0xA8,
+0x07, 0xD2, 0x05, 0x92, 0x06, 0x93, 0x15, 0x4D,
+0xB5, 0xE2, 0x04, 0x94, 0xB5, 0xE3, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xED, 0x00, 0x18, 0xD4, 0x47,
+0x07, 0x93, 0xCE, 0x73, 0x0C, 0x60, 0x63, 0xF5,
+0x6E, 0xA8, 0x09, 0x71, 0x02, 0x4B, 0x69, 0xE2,
+0x63, 0xF5, 0x4E, 0xC8, 0x09, 0x61, 0xFF, 0x6A,
+0x63, 0xF5, 0x4E, 0xC8, 0x0A, 0x10, 0x4B, 0xEB,
+0x4D, 0xEB, 0xC0, 0xF7, 0x62, 0x32, 0x06, 0x10,
+0x01, 0x49, 0xFF, 0x6A, 0x4C, 0xE9, 0x0A, 0x71,
+0xC8, 0x61, 0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x07, 0xD3, 0x63, 0xF5, 0x70, 0xA3, 0xFF, 0x6A,
+0x4C, 0xEE, 0x03, 0x4B, 0x4C, 0xEF, 0x6D, 0xE6,
+0x6D, 0xE7, 0x4C, 0xEB, 0xFF, 0xF7, 0x1F, 0x69,
+0x05, 0x67, 0x05, 0xD3, 0x03, 0x4B, 0x2C, 0xE8,
+0x2C, 0xEB, 0x4C, 0xEC, 0xA3, 0x67, 0x06, 0xD4,
+0x90, 0x67, 0x08, 0xD6, 0x04, 0xD3, 0x00, 0x18,
+0xD4, 0x47, 0x06, 0x94, 0x14, 0x6B, 0x78, 0xEC,
+0x07, 0x93, 0x12, 0xEC, 0x6D, 0xE4, 0x06, 0xD3,
+0x09, 0xD4, 0x06, 0x94, 0x0F, 0x6B, 0x4C, 0xEB,
+0x23, 0xF6, 0x75, 0xC4, 0x04, 0x95, 0x90, 0x67,
+0x00, 0x18, 0xD4, 0x47, 0x06, 0x93, 0x52, 0x32,
+0x90, 0x67, 0x23, 0xF6, 0x56, 0xC3, 0x05, 0x95,
+0x04, 0x4D, 0x2C, 0xED, 0x00, 0x18, 0xD4, 0x47,
+0x06, 0x94, 0x23, 0xF6, 0x57, 0xC4, 0x05, 0x95,
+0x90, 0x67, 0x05, 0x4D, 0x2C, 0xED, 0x00, 0x18,
+0xD4, 0x47, 0x05, 0x95, 0x90, 0x67, 0x04, 0xD2,
+0x06, 0x4D, 0x2C, 0xED, 0x00, 0x18, 0xD4, 0x47,
+0x04, 0x93, 0x06, 0x94, 0x40, 0x32, 0x49, 0xE3,
+0x23, 0xF6, 0x58, 0xCC, 0x05, 0x92, 0x90, 0x67,
+0x07, 0x4A, 0x2C, 0xEA, 0xA2, 0x67, 0x04, 0xD2,
+0x00, 0x18, 0xD4, 0x47, 0x06, 0x94, 0x04, 0x6B,
+0x4C, 0xEB, 0x67, 0x33, 0x23, 0xF6, 0x7A, 0xC4,
+0x04, 0x95, 0x90, 0x67, 0x00, 0x18, 0xD4, 0x47,
+0x06, 0x93, 0x4E, 0x32, 0x90, 0x67, 0x23, 0xF6,
+0x5B, 0xC3, 0x05, 0x95, 0x08, 0x4D, 0x2C, 0xED,
+0x00, 0x18, 0xD4, 0x47, 0x06, 0x94, 0x4A, 0x32,
+0x23, 0xF6, 0x5C, 0xC4, 0x05, 0x95, 0x90, 0x67,
+0x09, 0x4D, 0x2C, 0xED, 0x00, 0x18, 0xD4, 0x47,
+0x05, 0x95, 0x90, 0x67, 0x04, 0xD2, 0x0A, 0x4D,
+0x2C, 0xED, 0x00, 0x18, 0xD4, 0x47, 0x04, 0x93,
+0x06, 0x94, 0x40, 0x32, 0x49, 0xE3, 0x23, 0xF6,
+0x5E, 0xCC, 0x08, 0x92, 0x07, 0x93, 0x09, 0x94,
+0x0A, 0x4A, 0x2C, 0xEA, 0x04, 0xD2, 0x89, 0xE3,
+0x43, 0xF6, 0x00, 0x4A, 0x06, 0xD2, 0x08, 0x92,
+0x10, 0x4A, 0x2C, 0xEA, 0x04, 0x91, 0x05, 0xD2,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x18, 0xD4, 0x47,
+0x06, 0x93, 0x01, 0x49, 0x40, 0xC3, 0x05, 0x94,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE9, 0x01, 0x4B,
+0x8A, 0xE9, 0x06, 0xD3, 0xF1, 0x61, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x40, 0x9A, 0xFF, 0x68,
+0x00, 0x6C, 0x40, 0xA2, 0x6F, 0x6D, 0x46, 0x6E,
+0x4C, 0xE8, 0x00, 0x18, 0x18, 0x3A, 0x00, 0x18,
+0x15, 0x41, 0xB0, 0x67, 0x00, 0x6C, 0x46, 0x6E,
+0x00, 0x18, 0x18, 0x3A, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x06, 0xD2, 0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA,
+0x5C, 0x32, 0x05, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xFF, 0x6B, 0x86, 0xF2, 0x00, 0x4A, 0x6C, 0xEE,
+0x6C, 0xEF, 0x63, 0xF5, 0x77, 0xA2, 0xFF, 0x6C,
+0x1E, 0x69, 0x48, 0x4B, 0x8C, 0xEB, 0x04, 0xD3,
+0x06, 0x93, 0x00, 0x6D, 0x38, 0xEB, 0x14, 0x6B,
+0x12, 0xE9, 0x45, 0xE1, 0x43, 0xF6, 0xC8, 0xC1,
+0x43, 0xF6, 0xE9, 0xC1, 0x06, 0x94, 0x43, 0xF6,
+0xE8, 0xA1, 0x02, 0x6E, 0x78, 0xEC, 0x12, 0xEB,
+0x49, 0xE3, 0x23, 0xF6, 0x75, 0xA2, 0x43, 0xF6,
+0x6A, 0xC1, 0x23, 0xF6, 0x78, 0xAA, 0x43, 0xF6,
+0x6C, 0xC9, 0x01, 0x6B, 0x43, 0xF6, 0x6E, 0xC1,
+0x23, 0xF6, 0x5A, 0xA2, 0x43, 0xF6, 0x4F, 0xC1,
+0x04, 0x90, 0x05, 0x92, 0x02, 0x48, 0x41, 0xE0,
+0x90, 0x67, 0x00, 0x18, 0xC7, 0x35, 0x43, 0xF6,
+0xE9, 0xA1, 0x90, 0x67, 0x02, 0x6D, 0x05, 0x6E,
+0x00, 0x18, 0xC7, 0x35, 0x04, 0x94, 0x05, 0x93,
+0x43, 0xF6, 0xEA, 0xA1, 0x03, 0x4C, 0x71, 0xE4,
+0x00, 0x6D, 0x04, 0x6E, 0x00, 0x18, 0xC7, 0x35,
+0x43, 0xF6, 0x4F, 0xA1, 0x16, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x40, 0x9A, 0x04, 0x94,
+0x00, 0x6D, 0x40, 0xA2, 0x05, 0x92, 0x05, 0x4C,
+0xE5, 0x67, 0x51, 0xE4, 0x08, 0x6E, 0x00, 0x18,
+0xC7, 0x35, 0x04, 0x94, 0x05, 0x93, 0x00, 0x6D,
+0x06, 0x4C, 0x71, 0xE4, 0x08, 0x6E, 0xE5, 0x67,
+0x17, 0x10, 0x04, 0x94, 0x05, 0x92, 0x43, 0xF6,
+0xEC, 0xA9, 0xFF, 0x6B, 0x05, 0x4C, 0x51, 0xE4,
+0x6C, 0xEF, 0x00, 0x6D, 0x08, 0x6E, 0x00, 0x18,
+0xC7, 0x35, 0x04, 0x94, 0x43, 0xF6, 0xEC, 0xA9,
+0x05, 0x92, 0x06, 0x4C, 0xE2, 0x37, 0xFF, 0x6B,
+0x51, 0xE4, 0x00, 0x6D, 0x08, 0x6E, 0x6C, 0xEF,
+0x00, 0x18, 0xC7, 0x35, 0x04, 0x92, 0x05, 0x94,
+0x06, 0x93, 0x07, 0x4A, 0x89, 0xE2, 0x04, 0xD2,
+0x1E, 0x6A, 0x58, 0xEB, 0x30, 0xF0, 0x20, 0x69,
+0x86, 0xF2, 0x00, 0x49, 0x04, 0x94, 0x01, 0x6D,
+0xC5, 0x67, 0x12, 0xEB, 0x21, 0xE3, 0x07, 0xD3,
+0x43, 0xF6, 0xEE, 0xA0, 0x00, 0x18, 0xC7, 0x35,
+0x04, 0x94, 0x43, 0xF6, 0xEF, 0xA0, 0x02, 0x6D,
+0x01, 0x6E, 0x00, 0x18, 0xC7, 0x35, 0x01, 0x6A,
+0x43, 0xF6, 0x50, 0xC0, 0x00, 0x6A, 0x43, 0xF6,
+0x51, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x05, 0x94,
+0x01, 0xF5, 0x50, 0x9A, 0x01, 0x6B, 0x49, 0xE4,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF5,
+0x54, 0x9A, 0x43, 0xF6, 0x71, 0xA0, 0x49, 0xE4,
+0x60, 0xC2, 0x06, 0x93, 0x14, 0x6A, 0x58, 0xEB,
+0x12, 0xEA, 0x29, 0xE2, 0x43, 0xF6, 0x60, 0xA2,
+0x43, 0xF6, 0x72, 0xC0, 0x43, 0xF6, 0x61, 0xA2,
+0x43, 0xF6, 0x73, 0xC0, 0x43, 0xF6, 0x62, 0xA2,
+0x43, 0xF6, 0x74, 0xC0, 0x43, 0xF6, 0x63, 0xA2,
+0x43, 0xF6, 0x75, 0xC0, 0x43, 0xF6, 0x64, 0xA2,
+0x43, 0xF6, 0x76, 0xC0, 0x43, 0xF6, 0x45, 0xA2,
+0x43, 0xF6, 0x57, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x05, 0x93, 0x01, 0xF4, 0x5C, 0x9A, 0x07, 0x94,
+0x49, 0xE3, 0x30, 0xF0, 0x20, 0x6B, 0x85, 0xE1,
+0xE1, 0xF4, 0x6C, 0x9B, 0x05, 0x94, 0x43, 0xF6,
+0x12, 0x49, 0x6D, 0xE4, 0x80, 0xA1, 0x01, 0x49,
+0x80, 0xC2, 0x01, 0x4A, 0x6A, 0xEA, 0xFA, 0x61,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF1, 0x68, 0x9B, 0xFF, 0x6A, 0x25, 0x67,
+0x60, 0x9B, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x60, 0x9B, 0xFF, 0xF7, 0x1F, 0x68, 0xFF, 0x6D,
+0x60, 0xA3, 0x47, 0x6E, 0x8C, 0xE8, 0x4C, 0xE9,
+0x00, 0x6C, 0x6C, 0xEA, 0x04, 0xD2, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0x15, 0x41, 0x01, 0x72,
+0x00, 0x6A, 0x0D, 0x61, 0x90, 0x67, 0x01, 0x6D,
+0xD1, 0x67, 0x04, 0x6F, 0x00, 0x18, 0x53, 0x56,
+0x04, 0x95, 0x00, 0x6C, 0x48, 0x6E, 0x00, 0x18,
+0x18, 0x3A, 0x00, 0x18, 0xA8, 0x56, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x63, 0xF6,
+0x65, 0xA2, 0x05, 0x2B, 0x00, 0x6C, 0x63, 0xF5,
+0xB4, 0xAA, 0x02, 0x6E, 0x04, 0x10, 0x63, 0xF5,
+0xB4, 0xAA, 0x00, 0x6C, 0x03, 0x6E, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x00, 0x18,
+0x88, 0x48, 0x63, 0xF5, 0x94, 0xA8, 0x00, 0x6D,
+0x00, 0x18, 0x75, 0x48, 0x63, 0xF5, 0x96, 0xA0,
+0x00, 0x6D, 0x00, 0x18, 0xD3, 0x4B, 0x23, 0xF6,
+0xD7, 0xA0, 0x64, 0x6A, 0xFF, 0x6C, 0x58, 0xEE,
+0x59, 0x4C, 0x00, 0x6D, 0x12, 0xEE, 0xD7, 0x36,
+0x01, 0x4E, 0x00, 0x18, 0xF2, 0x30, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0x6B, 0x6C, 0xED, 0x25, 0x67, 0xFF, 0xF7,
+0x1F, 0x6A, 0x6C, 0xEE, 0x0A, 0x49, 0x30, 0xF0,
+0x20, 0x6B, 0x4C, 0xEC, 0xCA, 0xF0, 0x00, 0x4B,
+0x4C, 0xE9, 0x00, 0x6A, 0x06, 0xD4, 0x07, 0xD5,
+0x08, 0xD6, 0x04, 0xD3, 0x05, 0xD2, 0x04, 0x93,
+0x06, 0x94, 0xB1, 0x67, 0x00, 0xA3, 0x00, 0x18,
+0xD4, 0x47, 0x0E, 0xEA, 0x15, 0x2A, 0x05, 0x92,
+0x01, 0x49, 0x01, 0x4A, 0x05, 0xD2, 0x05, 0x93,
+0xFF, 0x6A, 0x4C, 0xEB, 0x04, 0x92, 0x06, 0x73,
+0x05, 0xD3, 0x01, 0x4A, 0x04, 0xD2, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE9, 0xE8, 0x61, 0x01, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0xCA, 0xF0, 0x67, 0xC2,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x43, 0xF6, 0x47, 0xA0, 0x7E, 0x22, 0x00, 0x6A,
+0x43, 0xF6, 0x47, 0xC0, 0x07, 0x91, 0x30, 0xF0,
+0x20, 0x6B, 0x30, 0xF0, 0x20, 0x68, 0xCA, 0xF0,
+0x06, 0x4B, 0x0A, 0x49, 0xCA, 0xF0, 0x00, 0x48,
+0x04, 0xD3, 0x06, 0x94, 0xB1, 0x67, 0x01, 0x49,
+0x00, 0x18, 0xD4, 0x47, 0x40, 0xC0, 0x04, 0x93,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x6A, 0xE8,
+0x4C, 0xE9, 0xF3, 0x61, 0x07, 0x95, 0x08, 0x93,
+0x06, 0x94, 0x02, 0x4D, 0xB5, 0xE3, 0x4C, 0xED,
+0x30, 0xF0, 0x20, 0x68, 0x00, 0x18, 0xD4, 0x47,
+0x86, 0xF2, 0x00, 0x48, 0x23, 0xF6, 0x54, 0xC0,
+0x23, 0xF6, 0x54, 0xA0, 0x04, 0x2A, 0x00, 0x6C,
+0x00, 0x18, 0x49, 0x4A, 0x5F, 0x10, 0x06, 0x94,
+0x07, 0x95, 0x08, 0x96, 0x00, 0x18, 0xA6, 0x4A,
+0x1A, 0x22, 0x06, 0x95, 0x07, 0x96, 0x08, 0x97,
+0x00, 0x6C, 0x00, 0x18, 0xFA, 0x4A, 0x23, 0xF6,
+0x5A, 0xA0, 0x0B, 0x22, 0x63, 0xF5, 0xB4, 0xA8,
+0x00, 0x6C, 0xE4, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x5B, 0x4B, 0x63, 0xF5, 0x94, 0xA8, 0x01, 0x6D,
+0x20, 0x10, 0x00, 0x6C, 0x63, 0xF5, 0xB4, 0xA8,
+0x01, 0x6E, 0xE4, 0x67, 0x33, 0x10, 0x43, 0xF6,
+0x46, 0xA0, 0x01, 0x4A, 0x43, 0xF6, 0x46, 0xC0,
+0x23, 0xF6, 0x5A, 0xA0, 0x05, 0x22, 0x00, 0x6C,
+0x63, 0xF5, 0xB4, 0xA8, 0x02, 0x6E, 0x04, 0x10,
+0x63, 0xF5, 0xB4, 0xA8, 0x00, 0x6C, 0x01, 0x6E,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x00, 0x18, 0x88, 0x48, 0x63, 0xF5, 0x94, 0xA8,
+0x00, 0x6D, 0x00, 0x18, 0x75, 0x48, 0x63, 0xF5,
+0x96, 0xA0, 0x00, 0x6D, 0x00, 0x18, 0xD3, 0x4B,
+0x23, 0xF6, 0xD7, 0xA0, 0x64, 0x6A, 0xFF, 0x6C,
+0x58, 0xEE, 0x59, 0x4C, 0x00, 0x6D, 0x12, 0xEE,
+0xD7, 0x36, 0x01, 0x4E, 0x00, 0x18, 0xF2, 0x30,
+0x11, 0x10, 0x63, 0xF5, 0xB4, 0xA8, 0x00, 0x6C,
+0x03, 0x6E, 0x01, 0x6F, 0x00, 0x18, 0x5B, 0x4B,
+0x63, 0xF5, 0x94, 0xA8, 0x01, 0x6D, 0x00, 0x18,
+0x75, 0x48, 0x63, 0xF5, 0x96, 0xA0, 0x00, 0x6D,
+0x00, 0x18, 0xD3, 0x4B, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF1, 0x68, 0x9B,
+0xFF, 0x6A, 0x25, 0x67, 0x60, 0x9B, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x60, 0x9B, 0xFF, 0xF7,
+0x1F, 0x68, 0xFF, 0x6D, 0x60, 0xA3, 0x44, 0x6E,
+0x8C, 0xE8, 0x4C, 0xE9, 0x00, 0x6C, 0x6C, 0xEA,
+0x04, 0xD2, 0x00, 0x18, 0x18, 0x3A, 0x00, 0x18,
+0x15, 0x41, 0x01, 0x72, 0x00, 0x6A, 0x0D, 0x61,
+0x90, 0x67, 0x01, 0x6D, 0xD1, 0x67, 0x04, 0x6F,
+0x00, 0x18, 0x53, 0x56, 0x04, 0x95, 0x00, 0x6C,
+0x45, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x00, 0x18,
+0xA8, 0x56, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x04, 0x67,
+0x18, 0x69, 0x4C, 0xE8, 0x38, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x12, 0xE9,
+0x65, 0xE1, 0xE3, 0xF5, 0x8F, 0xA1, 0x02, 0x74,
+0xC0, 0xF0, 0x0A, 0x61, 0xE3, 0xF5, 0x91, 0xA1,
+0x7D, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF7,
+0x80, 0x9C, 0x0F, 0x6D, 0x80, 0x9C, 0x04, 0xD4,
+0x14, 0x34, 0x6D, 0xE4, 0x83, 0xF5, 0x95, 0xA3,
+0x8E, 0xED, 0x0D, 0x2D, 0x30, 0xF0, 0x20, 0x6A,
+0x83, 0xF5, 0x9E, 0xAB, 0x02, 0xF0, 0x50, 0x9A,
+0x58, 0xEC, 0x04, 0x92, 0xE3, 0xF5, 0xB1, 0xC1,
+0x12, 0xEC, 0x51, 0xE4, 0x0C, 0x10, 0xFE, 0x4C,
+0x4C, 0xEC, 0x00, 0x18, 0x8A, 0x49, 0xFA, 0x6C,
+0x98, 0xEA, 0x04, 0x92, 0x12, 0xEC, 0x51, 0xE4,
+0x01, 0x6A, 0xE3, 0xF5, 0x51, 0xC1, 0x0C, 0x20,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xE3, 0xF5, 0x4F, 0xA3, 0x02, 0x72, 0x04, 0x61,
+0x03, 0xF6, 0x47, 0xA3, 0x02, 0x72, 0x0F, 0x60,
+0x00, 0x18, 0x4F, 0x49, 0x18, 0x6B, 0x78, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x63, 0xF5, 0x1B, 0xC2, 0x12, 0xEB, 0x49, 0xE3,
+0x01, 0x6B, 0xE3, 0xF5, 0x7A, 0xC2, 0x30, 0xF0,
+0x20, 0x69, 0x86, 0xF2, 0x00, 0x49, 0x14, 0x32,
+0x29, 0xE2, 0x83, 0xF5, 0x94, 0xA2, 0x00, 0x18,
+0x8A, 0x49, 0x18, 0x6B, 0x78, 0xE8, 0x12, 0xEB,
+0x25, 0xE3, 0xE3, 0xF5, 0x74, 0xA9, 0x6E, 0xEA,
+0x25, 0x22, 0xE3, 0xF5, 0x5A, 0xA1, 0x0E, 0x22,
+0xE3, 0xF5, 0x8C, 0xA9, 0x00, 0x6D, 0xD0, 0x67,
+0x00, 0x18, 0x5C, 0x48, 0xE3, 0xF5, 0x8E, 0xA1,
+0x08, 0x6D, 0x00, 0x18, 0x6E, 0x4C, 0x01, 0x72,
+0x00, 0x6A, 0x01, 0x61, 0x01, 0x6A, 0x18, 0x6B,
+0x78, 0xE8, 0xE3, 0xF5, 0x50, 0xC1, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x12, 0xE8,
+0x41, 0xE0, 0xE3, 0xF5, 0x54, 0xA8, 0x01, 0x4A,
+0xE3, 0xF5, 0x54, 0xC8, 0x00, 0x6A, 0xE3, 0xF5,
+0x52, 0xC0, 0x4E, 0x10, 0x90, 0x67, 0x00, 0x18,
+0x10, 0x4A, 0x4A, 0x10, 0xE3, 0xF5, 0x50, 0xA1,
+0x05, 0x72, 0x03, 0x60, 0x05, 0x6A, 0xE3, 0xF5,
+0x50, 0xC1, 0x18, 0x6A, 0x58, 0xE8, 0x30, 0xF0,
+0x20, 0x69, 0x86, 0xF2, 0x00, 0x49, 0x00, 0x6B,
+0x12, 0xEA, 0x29, 0xE2, 0xE3, 0xF5, 0x71, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x40, 0x9A,
+0x40, 0x9A, 0x05, 0xD2, 0x14, 0x32, 0x29, 0xE2,
+0x83, 0xF5, 0x7E, 0xAA, 0x04, 0xD3, 0x83, 0xF5,
+0x95, 0xA2, 0xFF, 0x6A, 0xFE, 0x4C, 0x4C, 0xEC,
+0x00, 0x18, 0x8A, 0x49, 0x08, 0x20, 0xE3, 0xF5,
+0x6F, 0xA1, 0x02, 0x73, 0x04, 0x61, 0x03, 0xF6,
+0x67, 0xA1, 0x02, 0x73, 0x1D, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x02, 0xF0, 0x90, 0x9B, 0x04, 0x93,
+0x98, 0xEB, 0x05, 0x93, 0x12, 0xEC, 0x71, 0xE4,
+0xFA, 0x6B, 0x6B, 0xEB, 0x78, 0xEA, 0x12, 0xEA,
+0x51, 0xE4, 0x00, 0x18, 0x4F, 0x49, 0x18, 0x6B,
+0x78, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x63, 0xF5, 0x1B, 0xC2, 0x01, 0x6B,
+0x12, 0xE8, 0x49, 0xE0, 0xE3, 0xF5, 0x7A, 0xC2,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x68, 0x18, 0x69,
+0x8C, 0xE8, 0x38, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x22, 0xF0, 0x50, 0x9A, 0x00, 0x6B, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xE9, 0x45, 0xE1, 0xE3, 0xF5, 0x6F, 0xA1,
+0x37, 0x2B, 0x14, 0x33, 0x49, 0xE3, 0x83, 0xF5,
+0xB6, 0xAA, 0xA3, 0xF5, 0xC0, 0x9A, 0xE3, 0xF5,
+0x8C, 0xA9, 0xF0, 0x67, 0x00, 0x18, 0x43, 0x48,
+0xE3, 0xF5, 0x8C, 0xA9, 0x01, 0x6D, 0xD0, 0x67,
+0x00, 0x18, 0x5C, 0x48, 0xE3, 0xF5, 0x8E, 0xA1,
+0x08, 0x6D, 0x00, 0x18, 0x6E, 0x4C, 0x01, 0x72,
+0x03, 0x61, 0x01, 0x6A, 0xE3, 0xF5, 0x4F, 0xC1,
+0xFF, 0x6C, 0x51, 0x4C, 0x00, 0x6D, 0x0A, 0x6E,
+0x00, 0x18, 0x04, 0x31, 0x30, 0xF0, 0x20, 0x6A,
+0x14, 0x33, 0x86, 0xF2, 0x00, 0x4A, 0x4D, 0xE3,
+0x83, 0xF5, 0x7A, 0xA3, 0x0A, 0x23, 0x18, 0x6B,
+0x78, 0xE8, 0x12, 0xE8, 0x49, 0xE0, 0xE3, 0xF5,
+0x74, 0xAA, 0x01, 0x4B, 0xE3, 0xF5, 0x74, 0xCA,
+0x03, 0x10, 0x90, 0x67, 0x00, 0x18, 0x39, 0x49,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x24, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0x4C, 0xEE, 0x4C, 0xE9, 0x4C, 0xED, 0x63, 0xF6,
+0xC9, 0xC4, 0xEC, 0xEA, 0x83, 0xF6, 0xEA, 0xA4,
+0x63, 0xF6, 0x09, 0xA4, 0x0D, 0x93, 0x01, 0x4F,
+0x0E, 0xEF, 0x63, 0xF6, 0x4A, 0xC4, 0x06, 0x2F,
+0x63, 0xF6, 0x0A, 0xA4, 0x83, 0xF6, 0xEB, 0xA4,
+0x0E, 0xEF, 0x0D, 0x27, 0x18, 0x6F, 0xF8, 0xE9,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0x12, 0xEF, 0x9D, 0xE7, 0xE3, 0xF5, 0x12, 0xA7,
+0x01, 0x48, 0xE3, 0xF5, 0x12, 0xC7, 0x83, 0xF6,
+0xCA, 0xC4, 0x83, 0xF6, 0x4B, 0xC4, 0x22, 0x2D,
+0x30, 0xF0, 0x20, 0x6A, 0xEA, 0xF0, 0xAB, 0xC2,
+0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0xEA, 0xF0, 0x18, 0x4A, 0x0A, 0xF1, 0x00, 0x4B,
+0x01, 0x6C, 0x8B, 0xEC, 0x80, 0xC2, 0x88, 0xC2,
+0x01, 0x4A, 0x6A, 0xEA, 0xF9, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x01, 0x6B,
+0x83, 0xF6, 0x69, 0xC2, 0xA0, 0xF0, 0x64, 0x9A,
+0x00, 0xF4, 0x00, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x75, 0x10, 0x01, 0x6A, 0x4E, 0xED,
+0x72, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0xEA, 0xF0,
+0xAB, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xEA, 0xF0,
+0x18, 0x4A, 0x00, 0x6C, 0xFF, 0x6D, 0x8C, 0xED,
+0x06, 0x5D, 0x07, 0x60, 0x0C, 0x96, 0x95, 0xE6,
+0xA0, 0xA5, 0xA0, 0xC2, 0x95, 0xE3, 0xA0, 0xA5,
+0x02, 0x10, 0x00, 0x6D, 0xA0, 0xC2, 0x01, 0x4C,
+0x08, 0x74, 0xA8, 0xC2, 0x01, 0x4A, 0xEE, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x01, 0x6B, 0x83, 0xF6, 0x69, 0xC2, 0xA0, 0xF0,
+0x64, 0x9A, 0x00, 0xF4, 0x00, 0x6C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x18, 0x6B, 0x78, 0xE9,
+0x34, 0x34, 0x12, 0xEB, 0x4D, 0xE3, 0x49, 0xE4,
+0xE3, 0xF5, 0xB2, 0xA3, 0x83, 0xF5, 0x9B, 0xA2,
+0xAE, 0xEC, 0x3D, 0x2C, 0x05, 0x6D, 0xE3, 0xF5,
+0xB0, 0xC3, 0xE3, 0xF5, 0x92, 0xC3, 0x83, 0xF5,
+0x94, 0xA2, 0xE3, 0xF5, 0x14, 0xAB, 0x00, 0x18,
+0x8A, 0x49, 0x0E, 0xEA, 0x03, 0x2A, 0x91, 0x67,
+0x00, 0x18, 0x10, 0x4A, 0x18, 0x6B, 0x78, 0xE9,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xEB, 0x4D, 0xE3, 0xE3, 0xF5, 0x74, 0xAB,
+0x01, 0x73, 0x11, 0x61, 0x06, 0x29, 0x63, 0xF5,
+0x49, 0xA2, 0x01, 0x6C, 0x02, 0x5A, 0x08, 0x60,
+0x1A, 0x10, 0x01, 0x71, 0x18, 0x61, 0x63, 0xF5,
+0x49, 0xA2, 0x03, 0x5A, 0x14, 0x61, 0x02, 0x6C,
+0x00, 0x18, 0xF9, 0x4C, 0x10, 0x10, 0x06, 0x29,
+0x63, 0xF5, 0x49, 0xA2, 0x01, 0x6C, 0x02, 0x5A,
+0x08, 0x60, 0x09, 0x10, 0x01, 0x71, 0x07, 0x61,
+0x63, 0xF5, 0x49, 0xA2, 0x03, 0x5A, 0x03, 0x61,
+0x02, 0x6C, 0x00, 0x18, 0x87, 0x4C, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xF6, 0x63, 0x13, 0x62, 0x12, 0xD1, 0x11, 0xD0,
+0xFF, 0x6A, 0xFF, 0xF7, 0x1F, 0x69, 0x4C, 0xED,
+0x4C, 0xEE, 0x8C, 0xE9, 0x0C, 0xD5, 0x0D, 0xD6,
+0x00, 0x68, 0x1B, 0x10, 0x0A, 0x95, 0x91, 0x67,
+0x00, 0x18, 0xD4, 0x47, 0x0E, 0x94, 0x60, 0xA4,
+0x6E, 0xEA, 0x80, 0xF1, 0x03, 0x2A, 0x0B, 0x95,
+0xFF, 0x6A, 0xFF, 0xF7, 0x1F, 0x6B, 0x01, 0x4D,
+0x4C, 0xED, 0x0A, 0x92, 0x01, 0x4C, 0x06, 0x75,
+0x01, 0x4A, 0x6C, 0xEA, 0x0B, 0xD5, 0x0A, 0xD2,
+0x0E, 0xD4, 0xE8, 0x61, 0x03, 0x58, 0x15, 0x61,
+0x65, 0x11, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x63, 0xF5, 0x69, 0xA2, 0x63, 0xE8,
+0x40, 0xF1, 0x1C, 0x60, 0x0C, 0x94, 0x14, 0x33,
+0x69, 0xE2, 0x0A, 0x4C, 0x83, 0xF5, 0x0E, 0x4A,
+0x00, 0x6D, 0x0A, 0xD4, 0x0E, 0xD2, 0x0B, 0xD5,
+0xD1, 0x17, 0x0C, 0x95, 0x0D, 0x92, 0xFF, 0xF7,
+0x1F, 0x6B, 0x02, 0x4D, 0xB5, 0xE2, 0x6C, 0xED,
+0x91, 0x67, 0x00, 0x18, 0xD4, 0x47, 0x0C, 0x95,
+0x0D, 0x94, 0x0E, 0xD2, 0x03, 0x4D, 0xB5, 0xE4,
+0xFF, 0xF7, 0x1F, 0x6A, 0x91, 0x67, 0x4C, 0xED,
+0x00, 0x18, 0xD4, 0x47, 0x0F, 0xD2, 0x0C, 0x92,
+0x0D, 0x93, 0xFF, 0xF7, 0x1F, 0x6C, 0x04, 0x4A,
+0x49, 0xE3, 0x8C, 0xEA, 0x00, 0x6D, 0x0A, 0xD2,
+0x0B, 0xD5, 0x0A, 0x95, 0x91, 0x67, 0x00, 0x18,
+0xD4, 0x47, 0x0B, 0x95, 0x9D, 0x67, 0xAD, 0xE4,
+0x0A, 0x95, 0x58, 0xC3, 0xFF, 0xF7, 0x1F, 0x6A,
+0x06, 0x4D, 0x91, 0x67, 0x4C, 0xED, 0x00, 0x18,
+0xD4, 0x47, 0x0B, 0x95, 0x9D, 0x67, 0xAD, 0xE4,
+0x20, 0xF0, 0x40, 0xC3, 0x0A, 0x92, 0x01, 0x4D,
+0xFF, 0xF7, 0x1F, 0x6B, 0x01, 0x4A, 0x6C, 0xEA,
+0x06, 0x75, 0x0B, 0xD5, 0x0A, 0xD2, 0xE1, 0x61,
+0x0D, 0x96, 0x0C, 0x95, 0x91, 0x67, 0x00, 0x18,
+0xD0, 0x4A, 0xC2, 0x67, 0x09, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF2, 0x7C, 0x9A, 0xFF, 0x6C,
+0x02, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0x08, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0x7C, 0x9A,
+0xFF, 0x6C, 0x04, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x0E, 0x94,
+0xE0, 0xF0, 0x10, 0x24, 0x0F, 0x95, 0xC0, 0xF0,
+0x12, 0x2D, 0xA0, 0xF0, 0x17, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x63, 0xF5,
+0xAE, 0xAA, 0x0C, 0x93, 0x0D, 0x94, 0x16, 0x4D,
+0xB5, 0xE3, 0x0A, 0xD2, 0xB5, 0xE4, 0xFF, 0xF7,
+0x1F, 0x6A, 0x91, 0x67, 0x4C, 0xED, 0x00, 0x18,
+0xD4, 0x47, 0x03, 0x6B, 0x6C, 0xEA, 0x01, 0x72,
+0xFF, 0x6C, 0x80, 0xF0, 0x10, 0x61, 0x18, 0x6A,
+0x58, 0xE8, 0x0A, 0x93, 0x12, 0xEA, 0x69, 0xE2,
+0x02, 0x6B, 0xE3, 0xF5, 0x6F, 0xC2, 0x0A, 0x94,
+0x0C, 0x92, 0x0D, 0x93, 0x63, 0xF5, 0xAE, 0xAC,
+0x91, 0x67, 0x1D, 0x4D, 0xB5, 0xE2, 0xB5, 0xE3,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED, 0x00, 0x18,
+0xD4, 0x47, 0x0A, 0x93, 0x0C, 0x94, 0x0B, 0xD2,
+0x63, 0xF5, 0xAE, 0xAB, 0x0D, 0x92, 0xFF, 0xF7,
+0x1F, 0x6B, 0x1E, 0x4D, 0xB5, 0xE4, 0xB5, 0xE2,
+0x91, 0x67, 0x6C, 0xED, 0x00, 0x18, 0xD4, 0x47,
+0x0B, 0x94, 0x40, 0x32, 0xFF, 0xF7, 0x1F, 0x6D,
+0x49, 0xE4, 0xAC, 0xEA, 0x05, 0x22, 0x0A, 0x94,
+0x14, 0x33, 0x8D, 0xE3, 0x83, 0xF5, 0x5E, 0xCB,
+0x30, 0xF0, 0x20, 0x6D, 0x86, 0xF2, 0x00, 0x4D,
+0x14, 0x32, 0x0A, 0xD5, 0xA9, 0xE2, 0x83, 0xF5,
+0x5A, 0xA2, 0x04, 0x22, 0x90, 0x67, 0x00, 0x18,
+0x5C, 0x49, 0x70, 0x10, 0x0A, 0x92, 0x0C, 0x93,
+0x0D, 0x94, 0x63, 0xF5, 0xAE, 0xAA, 0xFF, 0xF7,
+0x1F, 0x6A, 0x19, 0x4D, 0xB5, 0xE3, 0xB5, 0xE4,
+0x4C, 0xED, 0x91, 0x67, 0x00, 0x18, 0xD4, 0x47,
+0x0A, 0x93, 0x0C, 0x94, 0x0B, 0xD2, 0x63, 0xF5,
+0xAE, 0xAB, 0x0D, 0x92, 0xFF, 0xF7, 0x1F, 0x6B,
+0x1A, 0x4D, 0xB5, 0xE4, 0xB5, 0xE2, 0x6C, 0xED,
+0x91, 0x67, 0x00, 0x18, 0xD4, 0x47, 0x18, 0x6B,
+0x78, 0xE8, 0x0A, 0x93, 0x0B, 0x94, 0x40, 0x32,
+0xFF, 0xF7, 0x1F, 0x6D, 0x49, 0xE4, 0xAC, 0xEA,
+0x12, 0xE8, 0x61, 0xE0, 0xE3, 0xF5, 0x7C, 0xA8,
+0x63, 0xEA, 0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF2, 0x7C, 0x9A, 0xFF, 0x6C, 0x10, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0x6B, 0x10, 0x4A, 0xEB,
+0x09, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x7C, 0x9A, 0xFF, 0x6C, 0x20, 0x6D, 0x40, 0xA3,
+0x8C, 0xEA, 0x60, 0x10, 0x6B, 0xE2, 0x03, 0xF6,
+0x80, 0x98, 0x40, 0x32, 0x48, 0x32, 0x91, 0xE2,
+0x00, 0x18, 0x2D, 0x49, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF2, 0x7C, 0x9A, 0xFF, 0x6C, 0x40, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0x4F, 0x10, 0x18, 0x6A,
+0x58, 0xE8, 0x0A, 0x92, 0x08, 0x6D, 0x12, 0xE8,
+0x41, 0xE0, 0x30, 0xF0, 0x20, 0x6A, 0xE3, 0xF5,
+0x6F, 0xC0, 0xC1, 0xF2, 0x7C, 0x9A, 0x40, 0xA3,
+0x8C, 0xEA, 0x40, 0x10, 0x18, 0x6B, 0x78, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xEB, 0x49, 0xE3, 0xE3, 0xF5, 0x6F, 0xA2,
+0x02, 0x73, 0x3C, 0x61, 0xE3, 0xF5, 0x50, 0xA2,
+0x01, 0x72, 0x38, 0x61, 0x06, 0x02, 0x04, 0xD2,
+0x00, 0x6D, 0x08, 0x02, 0x05, 0xD2, 0x90, 0x67,
+0x0E, 0x96, 0xE5, 0x67, 0x18, 0x10, 0x18, 0x6B,
+0x78, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x12, 0xEB, 0x49, 0xE3, 0xE3, 0xF5,
+0x6F, 0xA2, 0x02, 0x73, 0x23, 0x61, 0xE3, 0xF5,
+0x50, 0xA2, 0x01, 0x72, 0x1F, 0x61, 0x06, 0x02,
+0x0E, 0x96, 0x0F, 0x97, 0x04, 0xD2, 0x08, 0x02,
+0x05, 0xD2, 0x90, 0x67, 0x01, 0x6D, 0x00, 0x18,
+0x23, 0x4D, 0x14, 0x10, 0x90, 0x67, 0x00, 0x18,
+0x10, 0x4A, 0x10, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF2, 0x7C, 0x9A, 0xFF, 0x6C, 0x01, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x04, 0x10, 0x01, 0x48, 0xFF, 0x6A,
+0x4C, 0xE8, 0x8B, 0x16, 0x13, 0x97, 0x12, 0x91,
+0x11, 0x90, 0x0A, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xE3, 0xF5,
+0x4F, 0xA0, 0x01, 0x72, 0x19, 0x61, 0x03, 0x6A,
+0xE3, 0xF5, 0x4F, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF2, 0x7C, 0x9A, 0xFF, 0x6C, 0x80, 0x6D,
+0x40, 0xA3, 0xAB, 0xED, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0x00, 0x6C, 0x00, 0x18,
+0x10, 0x4A, 0x63, 0xF5, 0x49, 0xA0, 0x02, 0x5A,
+0x03, 0x61, 0x01, 0x6C, 0x00, 0x18, 0xF9, 0x4C,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x03, 0xF6, 0x67, 0xA2, 0x01, 0x73, 0x0A, 0x61,
+0x03, 0x6B, 0x03, 0xF6, 0x67, 0xC2, 0x63, 0xF5,
+0x49, 0xA2, 0x03, 0x5A, 0x03, 0x61, 0x02, 0x6C,
+0x00, 0x18, 0xF9, 0x4C, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x03, 0xF6, 0x7F, 0xA2,
+0x01, 0x73, 0x03, 0x61, 0x03, 0x6B, 0x03, 0xF6,
+0x7F, 0xC2, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0xE7, 0xF1, 0x1D, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x07, 0xF2, 0x15, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x9F, 0x9A,
+0x07, 0x24, 0x01, 0x6B, 0x8C, 0xEB, 0x04, 0x23,
+0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0x7F, 0xDA,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x07, 0xF2, 0x16, 0x4A,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x47, 0xF2, 0x15, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6C, 0x06, 0xF3, 0x8C, 0x9C, 0x02, 0x24,
+0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x67, 0xF2, 0x19, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x80, 0xF0, 0x90, 0x9A, 0x0A, 0x24,
+0xFF, 0x6B, 0x01, 0x4B, 0x8C, 0xEB, 0x06, 0x23,
+0xFF, 0x6B, 0x02, 0x4B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x80, 0xF0, 0x70, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x06, 0xF3, 0x58, 0x9A, 0x09, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0,
+0x21, 0x6A, 0x67, 0xF2, 0x1A, 0x4A, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0xC7, 0xF2, 0x0D, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF7, 0x6C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0xE7, 0xF2, 0x05, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF1, 0x60, 0x9B,
+0xE9, 0xA4, 0x48, 0xA4, 0x60, 0xAB, 0xE0, 0x37,
+0x5D, 0xE7, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEF,
+0x4C, 0xEB, 0x4A, 0xA4, 0xAB, 0xA4, 0x01, 0x72,
+0x10, 0x60, 0x04, 0x22, 0x02, 0x72, 0x0B, 0x6A,
+0x38, 0x61, 0x17, 0x10, 0xA1, 0x5F, 0x34, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6C,
+0x4C, 0xF2, 0x1F, 0x4A, 0x4C, 0xF2, 0xFC, 0xC4,
+0x17, 0x10, 0x00, 0xF1, 0x01, 0x5F, 0x28, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6C,
+0xEC, 0xF2, 0x1F, 0x4A, 0x4C, 0xF2, 0xFD, 0xC4,
+0x0B, 0x10, 0x00, 0xF1, 0x01, 0x5F, 0x1C, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6C,
+0xEC, 0xF3, 0x1F, 0x4A, 0x4C, 0xF2, 0xFE, 0xC4,
+0x75, 0xE5, 0x00, 0x6B, 0x04, 0xD3, 0x05, 0xD3,
+0x83, 0x67, 0x30, 0xF0, 0x20, 0x6B, 0x22, 0xF0,
+0xD4, 0x9B, 0xBC, 0x35, 0x30, 0xF0, 0x20, 0x6B,
+0xD5, 0xE5, 0xA0, 0xF7, 0xC4, 0x9B, 0xD9, 0xE2,
+0x00, 0x18, 0xB4, 0x1E, 0x00, 0x6A, 0x01, 0x10,
+0x0A, 0x6A, 0x07, 0x97, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF1, 0x60, 0x9B,
+0xE9, 0xA4, 0x48, 0xA4, 0xAA, 0xA4, 0x20, 0xAB,
+0xE0, 0x37, 0x5D, 0xE7, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEF, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF7, 0x44, 0x45, 0x44, 0x32, 0x86, 0xF2,
+0x00, 0x4B, 0x02, 0x68, 0x69, 0xE2, 0xAE, 0xE8,
+0x8B, 0xA4, 0xC0, 0xAA, 0x05, 0x20, 0x03, 0x6A,
+0x4E, 0xED, 0x05, 0x6A, 0x32, 0x2D, 0x0F, 0x10,
+0xC9, 0xE7, 0x01, 0xF0, 0x01, 0x52, 0x03, 0x61,
+0xC3, 0xF7, 0x0C, 0xCB, 0x0E, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x4A, 0xF2, 0x1C, 0x4D, 0xD9, 0xE5,
+0xC3, 0xF7, 0x4C, 0xCB, 0x0F, 0x10, 0xC9, 0xE7,
+0x01, 0xF0, 0x01, 0x52, 0x04, 0x61, 0xC3, 0xF7,
+0xAE, 0xCB, 0x04, 0x6A, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x4B, 0xF2, 0x1C, 0x4D, 0xD9, 0xE5,
+0xC3, 0xF7, 0x4E, 0xCB, 0x00, 0x6A, 0x31, 0xE4,
+0x9C, 0x35, 0x04, 0xD2, 0x05, 0xD2, 0x82, 0x67,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF6, 0x40, 0x9A,
+0x55, 0xE5, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x44, 0x9A, 0x59, 0xE6, 0x00, 0x18, 0xB4, 0x1E,
+0x00, 0x6A, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x86, 0xF2, 0xA1, 0xA3, 0xFF, 0x6A, 0x8C, 0xEA,
+0x3D, 0x25, 0x71, 0xE2, 0xC5, 0xF7, 0x9C, 0xA4,
+0x39, 0x24, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF1,
+0x80, 0x9C, 0x01, 0x72, 0xC0, 0xAC, 0xFF, 0xF7,
+0x1F, 0x6C, 0xCC, 0xEC, 0x0B, 0x60, 0x03, 0x22,
+0x02, 0x72, 0x0F, 0x60, 0x2B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x4C, 0xF2, 0x1F, 0x4A, 0xC5, 0xF7,
+0xFC, 0xA3, 0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xEC, 0xF2, 0x1F, 0x4A, 0xC5, 0xF7, 0xFD, 0xA3,
+0x06, 0x10, 0xC5, 0xF7, 0xFE, 0xA3, 0x30, 0xF0,
+0x20, 0x6A, 0xEC, 0xF3, 0x1F, 0x4A, 0x00, 0x6B,
+0xE1, 0xF7, 0x1F, 0x6E, 0x8C, 0xEE, 0x04, 0xD3,
+0x05, 0xD3, 0x83, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0xB9, 0xE6, 0xA0, 0xF7, 0xA4, 0x9B, 0xDC, 0x36,
+0xB5, 0xE2, 0x30, 0xF0, 0x20, 0x6A, 0x22, 0xF0,
+0x54, 0x9A, 0x59, 0xE6, 0x00, 0x18, 0xB4, 0x1E,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x07, 0x97,
+0x04, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x68, 0xA4, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xE1, 0xF7,
+0x84, 0x43, 0x84, 0x34, 0x49, 0xE4, 0x80, 0xAA,
+0x06, 0x6A, 0x6A, 0x24, 0x02, 0x73, 0x00, 0x68,
+0x27, 0x60, 0x03, 0x73, 0x09, 0x6A, 0x64, 0x61,
+0x52, 0x10, 0x49, 0xE0, 0xC3, 0xF7, 0x3C, 0xA2,
+0x04, 0x71, 0x04, 0x60, 0x08, 0x71, 0x02, 0x60,
+0x0C, 0x71, 0x55, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x0D, 0xE3, 0x04, 0x02,
+0xC3, 0xF7, 0x1C, 0x4B, 0x31, 0xE2, 0x04, 0x10,
+0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2, 0x01, 0x4A,
+0x8A, 0xEA, 0xFA, 0x61, 0x04, 0x04, 0x00, 0x18,
+0x11, 0x32, 0x03, 0x72, 0x42, 0x60, 0x43, 0x22,
+0x01, 0xE1, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC3, 0xF7, 0x6C, 0xAA, 0x63, 0xE8, 0xD5, 0x61,
+0x00, 0x6B, 0xC3, 0xF7, 0x6C, 0xCA, 0x33, 0x10,
+0x49, 0xE0, 0xC4, 0xF7, 0x3C, 0xA2, 0x04, 0x71,
+0x04, 0x60, 0x08, 0x71, 0x02, 0x60, 0x0C, 0x71,
+0x26, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0x0D, 0xE3, 0x04, 0x02, 0xC4, 0xF7,
+0x1C, 0x4B, 0x31, 0xE2, 0x04, 0x10, 0xA0, 0xA3,
+0x01, 0x4B, 0xA0, 0xC2, 0x01, 0x4A, 0x8A, 0xEA,
+0xFA, 0x61, 0x04, 0x04, 0x00, 0x18, 0x11, 0x32,
+0x03, 0x72, 0x13, 0x60, 0x14, 0x22, 0x01, 0xE1,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF7,
+0x6E, 0xAA, 0x63, 0xE8, 0xD5, 0x61, 0x00, 0x6B,
+0xC3, 0xF7, 0x6E, 0xCA, 0x04, 0x10, 0x07, 0x6A,
+0x03, 0x10, 0x08, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B, 0x86, 0xF2,
+0x64, 0xDA, 0x86, 0xF2, 0x68, 0xDA, 0x69, 0xA4,
+0x48, 0xA4, 0x60, 0x33, 0x49, 0xE3, 0x09, 0xD2,
+0x09, 0x93, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEB,
+0x09, 0xD3, 0x6A, 0xA4, 0x01, 0x73, 0x02, 0x61,
+0x4B, 0xA4, 0x08, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF1, 0x60, 0x9B, 0x60, 0xAB, 0x6C, 0xEA,
+0x6B, 0xA4, 0x49, 0xE3, 0x5C, 0x32, 0x30, 0x4A,
+0x08, 0xD2, 0x00, 0x69, 0x2F, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0x40, 0x9A, 0x08, 0x93,
+0xFF, 0x68, 0x49, 0xE3, 0x40, 0xA2, 0x4C, 0xE8,
+0x04, 0x70, 0x06, 0x60, 0x08, 0x70, 0x04, 0x60,
+0x0C, 0x70, 0x02, 0x60, 0x01, 0x6A, 0x22, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4, 0x60, 0x9A,
+0x08, 0x92, 0x6D, 0xE2, 0x04, 0x02, 0x11, 0xE2,
+0x04, 0x10, 0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2,
+0x01, 0x4A, 0x8A, 0xEA, 0xFA, 0x61, 0x04, 0x04,
+0x00, 0x18, 0x11, 0x32, 0x03, 0x72, 0x02, 0x61,
+0x02, 0x6A, 0x0C, 0x10, 0x0A, 0x22, 0x08, 0x93,
+0x01, 0x49, 0xFF, 0xF7, 0x1F, 0x6A, 0x0D, 0xE3,
+0x08, 0xD3, 0x4C, 0xE9, 0x09, 0x92, 0x43, 0xE9,
+0xCE, 0x61, 0x00, 0x6A, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0xA9, 0xF0, 0x08, 0x48,
+0x00, 0x69, 0x91, 0x67, 0x04, 0x05, 0x00, 0x18,
+0xC1, 0x43, 0x01, 0x72, 0x02, 0x60, 0x03, 0x6A,
+0x09, 0x10, 0x7D, 0x67, 0x50, 0xA3, 0x01, 0x49,
+0x00, 0xF4, 0x00, 0x71, 0x40, 0xC0, 0x01, 0x48,
+0xF0, 0x61, 0x00, 0x6A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xDC, 0x63, 0x47, 0x62, 0x46, 0xD1, 0x45, 0xD0,
+0xFF, 0x6A, 0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEF,
+0x4C, 0xEC, 0x6C, 0xEE, 0x43, 0xD4, 0xC2, 0x33,
+0xE2, 0x34, 0x49, 0xD5, 0x4C, 0xEB, 0x00, 0x6D,
+0x4C, 0xEC, 0x3F, 0xD6, 0x42, 0xD7, 0x41, 0xD3,
+0x40, 0xD4, 0x3E, 0xD5, 0x25, 0x67, 0x4A, 0x10,
+0x01, 0x6A, 0x7D, 0x67, 0x4B, 0xEA, 0x50, 0xC3,
+0x3F, 0x92, 0x00, 0xF1, 0x8C, 0x43, 0xF0, 0xF0,
+0xA8, 0x43, 0x23, 0xE2, 0x80, 0xA4, 0xA0, 0xA5,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8, 0xC8, 0x58,
+0x92, 0xC3, 0xB4, 0xC3, 0x02, 0x61, 0xC8, 0x68,
+0x06, 0x10, 0x3E, 0x93, 0x80, 0x6A, 0x4B, 0xEA,
+0x6D, 0xEA, 0x9D, 0x67, 0x54, 0xC4, 0xBD, 0x67,
+0x15, 0xC5, 0x00, 0x6A, 0x0A, 0x10, 0x49, 0x95,
+0x9D, 0x67, 0x4D, 0xE4, 0x51, 0xE5, 0x31, 0xE4,
+0x80, 0xA4, 0x01, 0x4A, 0x9A, 0xC3, 0xFF, 0x6B,
+0x6C, 0xEA, 0x03, 0xEA, 0xF4, 0x61, 0x7D, 0x67,
+0xF0, 0xF0, 0x8C, 0x43, 0x80, 0xA4, 0x46, 0x40,
+0x53, 0xC3, 0x96, 0xC3, 0x00, 0xF1, 0xA4, 0x43,
+0x00, 0xF1, 0x48, 0x43, 0x00, 0xF1, 0x80, 0x43,
+0xA0, 0xA5, 0x40, 0xA2, 0x80, 0xA4, 0xB7, 0xC3,
+0x58, 0xC3, 0x99, 0xC3, 0x04, 0x04, 0x00, 0x18,
+0x33, 0x27, 0x3E, 0x95, 0xFF, 0xF7, 0x1F, 0x6A,
+0x25, 0xE0, 0x4C, 0xE9, 0x01, 0x4D, 0xFF, 0x6A,
+0x4C, 0xED, 0x3E, 0xD5, 0x3F, 0x92, 0x43, 0xE9,
+0xB3, 0x61, 0x47, 0x97, 0x46, 0x91, 0x45, 0x90,
+0x24, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xA7, 0x44, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0x4D,
+0xEC, 0xF4, 0x1F, 0x4C, 0x03, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0x05, 0x97, 0x00, 0x6A, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0x4A, 0xF2, 0x08, 0x4C,
+0x00, 0x6D, 0xE2, 0xF3, 0x10, 0x6E, 0x00, 0x18,
+0xB4, 0x20, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0xAC, 0xEA,
+0x09, 0x60, 0x03, 0x24, 0x02, 0x74, 0x0B, 0x60,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF4,
+0x64, 0x9B, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x22, 0xF0, 0x78, 0x9B, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x22, 0xF0, 0x7C, 0x9B, 0x40, 0xC3,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x01, 0x74, 0x0A, 0x60, 0x04, 0x24, 0x02, 0x74,
+0x00, 0x6A, 0x13, 0x61, 0x0C, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x44, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x22, 0xF0, 0x58, 0x9A,
+0x40, 0xA2, 0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x22, 0xF0, 0x5C, 0x9A, 0x40, 0xA2,
+0x6C, 0xEA, 0x20, 0xE8, 0xFF, 0x6B, 0x6C, 0xEC,
+0x01, 0x74, 0x0A, 0x60, 0x04, 0x24, 0x02, 0x74,
+0x00, 0x6A, 0x13, 0x61, 0x0C, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x42, 0xF0, 0x40, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x42, 0xF0, 0x44, 0x9A,
+0x40, 0xA2, 0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x42, 0xF0, 0x48, 0x9A, 0x40, 0xA2,
+0x6C, 0xEA, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3, 0x55, 0xA2,
+0x01, 0x6B, 0x4C, 0xEB, 0x00, 0x6A, 0x07, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x42, 0xF0, 0x40, 0x9A,
+0x60, 0xA2, 0xFF, 0x6A, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3,
+0xA8, 0xA3, 0x01, 0x6C, 0xAC, 0xEC, 0x04, 0x24,
+0xA3, 0xF3, 0x8A, 0xA3, 0x00, 0x18, 0x1B, 0x50,
+0x05, 0x97, 0xFF, 0x6B, 0x5E, 0x32, 0x6C, 0xEA,
+0x03, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x0A, 0x23, 0xA3, 0xF3,
+0x84, 0xA2, 0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x03, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB, 0xA3, 0xF3,
+0x64, 0xC2, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x0A, 0x23, 0xA3, 0xF3,
+0x84, 0xA2, 0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x03, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB, 0xA3, 0xF3,
+0x64, 0xC2, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x0A, 0x23, 0xA3, 0xF3,
+0x84, 0xA2, 0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x03, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB, 0xA3, 0xF3,
+0x64, 0xC2, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2,
+0x02, 0x6B, 0x8C, 0xEB, 0x0B, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF4, 0x84, 0x9B, 0xBF, 0x6B,
+0xA0, 0xA4, 0xAC, 0xEB, 0x60, 0xC4, 0x00, 0x6B,
+0xA3, 0xF3, 0x65, 0xC2, 0x30, 0xF0, 0x20, 0x69,
+0x86, 0xF2, 0x00, 0x49, 0xA3, 0xF3, 0x68, 0xA1,
+0x02, 0x6A, 0x6C, 0xEA, 0x0D, 0x22, 0xA3, 0xF3,
+0x0A, 0xA1, 0x90, 0x67, 0x00, 0x18, 0x0D, 0x50,
+0xBF, 0x6D, 0x4C, 0xED, 0x90, 0x67, 0x00, 0x18,
+0x00, 0x50, 0x00, 0x6A, 0xA3, 0xF3, 0x45, 0xC1,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2,
+0x02, 0x6B, 0x8C, 0xEB, 0x03, 0x23, 0x01, 0x6B,
+0xA3, 0xF3, 0x65, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2,
+0x02, 0x6B, 0x8C, 0xEB, 0x03, 0x23, 0x01, 0x6B,
+0xA3, 0xF3, 0x65, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x95, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x05, 0x23, 0xA3, 0xF3, 0x45, 0xA2, 0x02, 0x72,
+0x00, 0x6A, 0x10, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3, 0x48, 0xA3,
+0x01, 0x6C, 0x4C, 0xEC, 0x01, 0x6A, 0x06, 0x24,
+0xA3, 0xF3, 0x45, 0xA3, 0x02, 0x6B, 0x6E, 0xEA,
+0x01, 0x5A, 0x58, 0x67, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6, 0x49, 0xA2,
+0x05, 0x5A, 0xE0, 0xF0, 0x0C, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x48, 0x32, 0x20, 0xF7, 0x10, 0x4B,
+0x4D, 0xE3, 0x40, 0x9B, 0x00, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3,
+0x88, 0xA3, 0x04, 0x6A, 0xFF, 0x6D, 0x8C, 0xEA,
+0x19, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x90, 0x9A, 0x02, 0x6E, 0x40, 0xA4, 0xAC, 0xEA,
+0xCD, 0xEA, 0xAC, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF7, 0x84, 0x9A, 0xF8, 0x6A,
+0xA0, 0xA4, 0xAC, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0xA3, 0xF3, 0x6C, 0xA3, 0x42, 0xF0,
+0x4C, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x70, 0x9A, 0x83, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3,
+0xA8, 0xA3, 0x04, 0x6A, 0xFF, 0x6C, 0xAC, 0xEA,
+0x1D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xB4, 0x9A, 0x02, 0x6E, 0x40, 0xA5, 0x8C, 0xEA,
+0xCD, 0xEA, 0x8C, 0xEA, 0x40, 0xC5, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF7, 0xA4, 0x9A, 0xF6, 0x4E,
+0x40, 0xA5, 0x8C, 0xEA, 0xCC, 0xEA, 0x01, 0x6E,
+0xCD, 0xEA, 0x8C, 0xEA, 0x40, 0xC5, 0x30, 0xF0,
+0x20, 0x6A, 0xA3, 0xF3, 0x6C, 0xA3, 0x42, 0xF0,
+0x4C, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x74, 0x9A, 0x57, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3,
+0xA8, 0xA3, 0x04, 0x6A, 0xFF, 0x6C, 0xAC, 0xEA,
+0x1D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xB8, 0x9A, 0x02, 0x6E, 0x08, 0x6F, 0x40, 0xA5,
+0xEB, 0xEF, 0x8C, 0xEA, 0xCD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC5, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF7,
+0xA4, 0x9A, 0x40, 0xA5, 0x8C, 0xEA, 0xEC, 0xEA,
+0xCD, 0xEA, 0x8C, 0xEA, 0x40, 0xC5, 0x30, 0xF0,
+0x20, 0x6A, 0xA3, 0xF3, 0x6C, 0xA3, 0x42, 0xF0,
+0x4C, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x78, 0x9A, 0x2B, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3,
+0xA8, 0xA3, 0x04, 0x6A, 0xFF, 0x6C, 0xAC, 0xEA,
+0x1D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xBC, 0x9A, 0x02, 0x6E, 0x40, 0xA5, 0x8C, 0xEA,
+0xCD, 0xEA, 0x8C, 0xEA, 0x40, 0xC5, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF7, 0xA4, 0x9A, 0xF6, 0x4E,
+0x40, 0xA5, 0x8C, 0xEA, 0xCC, 0xEA, 0x03, 0x6E,
+0xCD, 0xEA, 0x8C, 0xEA, 0x40, 0xC5, 0x30, 0xF0,
+0x20, 0x6A, 0xA3, 0xF3, 0x6C, 0xA3, 0x42, 0xF0,
+0x4C, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x7C, 0x9A, 0x40, 0xA3, 0xFF, 0x6C,
+0x01, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3, 0x48, 0xA3,
+0x04, 0x6E, 0xFF, 0x6C, 0xCC, 0xEA, 0x1C, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0xA0, 0x9A,
+0x02, 0x6F, 0x40, 0xA5, 0x8C, 0xEA, 0xED, 0xEA,
+0x8C, 0xEA, 0x40, 0xC5, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF7, 0xA4, 0x9A, 0xF6, 0x4F, 0x40, 0xA5,
+0x8C, 0xEA, 0xEC, 0xEA, 0xCD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC5, 0x30, 0xF0, 0x20, 0x6A, 0xA3, 0xF3,
+0x6C, 0xA3, 0x42, 0xF0, 0x4C, 0x9A, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x60, 0x9A,
+0xFF, 0x6C, 0x01, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x95, 0xA2, 0x01, 0x6B, 0x8C, 0xEB,
+0x06, 0x23, 0xA3, 0xF3, 0x84, 0xA2, 0x02, 0x6B,
+0x8D, 0xEB, 0xA3, 0xF3, 0x64, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3,
+0x88, 0xA2, 0x01, 0x6B, 0x8C, 0xEB, 0x06, 0x23,
+0xA3, 0xF3, 0x84, 0xA2, 0x02, 0x6B, 0x8D, 0xEB,
+0xA3, 0xF3, 0x64, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6D, 0x86, 0xF2, 0x00, 0x4D,
+0xA0, 0xF0, 0xD5, 0xA5, 0x02, 0x6B, 0xFF, 0x6A,
+0xCC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x02, 0x2B,
+0xA3, 0xF3, 0x86, 0xC5, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0xA8, 0xA2,
+0x02, 0x6B, 0xAC, 0xEB, 0x02, 0x2B, 0xA3, 0xF3,
+0x86, 0xC2, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xA0, 0xF0, 0x76, 0xA0,
+0x7F, 0x6A, 0xFF, 0x69, 0x6C, 0xEA, 0x02, 0x72,
+0x24, 0x60, 0xA0, 0xF0, 0x77, 0xA0, 0x10, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x2C, 0xEA, 0x1D, 0x22,
+0x00, 0x18, 0x71, 0x14, 0x1A, 0x2A, 0xA0, 0xF0,
+0x75, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x05, 0x22, 0x00, 0x6D, 0x0C, 0x6C, 0xC5, 0x67,
+0x00, 0x18, 0xD9, 0x17, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x06, 0x23, 0xA3, 0xF3,
+0xC9, 0xA2, 0x0C, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0xD9, 0x17, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xA0, 0xF0, 0x55, 0xA3, 0x01, 0x6C, 0x8C, 0xEA,
+0x02, 0x2A, 0x0C, 0x6C, 0x08, 0x10, 0xA0, 0xF0,
+0x55, 0xA3, 0x5A, 0x32, 0x8C, 0xEA, 0xFF, 0x6C,
+0x8C, 0xEA, 0xA3, 0xF3, 0x86, 0xA3, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA3, 0xF3,
+0xC8, 0xA3, 0x01, 0x6D, 0xAC, 0xEE, 0x08, 0x26,
+0xA3, 0xF3, 0x48, 0xA3, 0xFF, 0x6C, 0x5A, 0x32,
+0xAC, 0xEA, 0x8C, 0xEA, 0xA3, 0xF3, 0x86, 0xA3,
+0x1E, 0x22, 0x02, 0x74, 0x20, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF3, 0x75, 0xA2, 0x01, 0x6A,
+0x6C, 0xEA, 0x05, 0x22, 0x02, 0x6C, 0x01, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0xD9, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3,
+0x88, 0xA2, 0x01, 0x6B, 0x8C, 0xEB, 0x09, 0x23,
+0xA3, 0xF3, 0xC9, 0xA2, 0x02, 0x6C, 0x01, 0x6D,
+0x00, 0x18, 0xD9, 0x17, 0x02, 0x10, 0x02, 0x74,
+0x02, 0x60, 0x00, 0x18, 0x27, 0x51, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x24, 0x67, 0xA0, 0xF0,
+0x95, 0xA3, 0x01, 0x6D, 0xFF, 0x6A, 0xAC, 0xEC,
+0x4C, 0xEC, 0x4C, 0xE9, 0x00, 0x68, 0x05, 0x24,
+0xA0, 0xF0, 0x15, 0xA3, 0x1A, 0x30, 0xAC, 0xE8,
+0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2, 0x01, 0x6B,
+0x6C, 0xEC, 0x06, 0x24, 0xA3, 0xF3, 0x08, 0xA2,
+0xFF, 0x6A, 0x1A, 0x30, 0x6C, 0xE8, 0x4C, 0xE8,
+0x00, 0x18, 0x29, 0x50, 0x01, 0x72, 0x1F, 0x61,
+0x1E, 0x28, 0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF3,
+0x75, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0x05, 0x22,
+0x91, 0x67, 0x01, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0xD9, 0x17, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA3, 0xF3, 0x48, 0xA3, 0x01, 0x6C,
+0x4C, 0xEC, 0x01, 0x6A, 0x09, 0x24, 0xA3, 0xF3,
+0xC9, 0xA3, 0xA2, 0x67, 0x91, 0x67, 0x00, 0x18,
+0xD9, 0x17, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x75, 0xA2, 0x01, 0x6C, 0xA4, 0x67,
+0x6C, 0xED, 0x0C, 0x25, 0xA3, 0xF3, 0xA4, 0xA2,
+0xAD, 0xEC, 0xA3, 0xF3, 0x84, 0xC2, 0x02, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x84, 0x05, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x68, 0xA2,
+0x01, 0x6C, 0xA4, 0x67, 0x6C, 0xED, 0x0C, 0x25,
+0xA3, 0xF3, 0xA4, 0xA2, 0xAD, 0xEC, 0xA3, 0xF3,
+0x84, 0xC2, 0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x84, 0x05,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xA3, 0xF3,
+0x68, 0xA0, 0x01, 0x6A, 0x6C, 0xEA, 0x1E, 0x22,
+0xA3, 0xF3, 0x45, 0xA0, 0x04, 0x72, 0x1A, 0x60,
+0xA3, 0xF3, 0x46, 0xA0, 0x02, 0x72, 0x16, 0x60,
+0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x18, 0x84, 0x05, 0x0E, 0x10,
+0x00, 0x18, 0x43, 0x51, 0xA3, 0xF3, 0x46, 0xA0,
+0x0C, 0x6C, 0x08, 0x72, 0x02, 0x60, 0x06, 0x2A,
+0x04, 0x6C, 0xA3, 0xF3, 0xC9, 0xA0, 0x00, 0x6D,
+0x00, 0x18, 0xD9, 0x17, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC3, 0xF3, 0x84, 0xA2,
+0x01, 0x6B, 0xFF, 0x6D, 0x6C, 0xEC, 0x40, 0x24,
+0xA3, 0xF3, 0x88, 0xA2, 0x8C, 0xEB, 0xAC, 0xEB,
+0x3B, 0x23, 0xC3, 0xF3, 0x6A, 0xA2, 0xFF, 0x73,
+0x27, 0x60, 0xFF, 0x4B, 0xC3, 0xF3, 0x6A, 0xC2,
+0xC3, 0xF3, 0xCA, 0xA2, 0x21, 0x2E, 0xC3, 0xF3,
+0x89, 0xA2, 0x21, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xC3, 0xF3, 0x85, 0xA2, 0xC3, 0xF3, 0x69, 0xC2,
+0x1F, 0x6B, 0x8C, 0xEB, 0xC3, 0xF3, 0x07, 0xA2,
+0xA0, 0xF0, 0xF1, 0xA2, 0xC3, 0xF3, 0x65, 0xC2,
+0x10, 0x6B, 0x0F, 0x6C, 0x6B, 0xEB, 0x8C, 0xEF,
+0x0C, 0xEB, 0xED, 0xEB, 0xC3, 0xF3, 0x67, 0xC2,
+0xC3, 0xF3, 0xC8, 0xC2, 0xC3, 0xF3, 0x50, 0xA2,
+0x4C, 0xEC, 0xAC, 0xEC, 0x00, 0x18, 0x96, 0x3F,
+0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF6, 0xA4, 0xA2,
+0x0F, 0x6A, 0x02, 0x6C, 0xA6, 0x35, 0x4C, 0xED,
+0x00, 0x18, 0x2D, 0x45, 0x00, 0x18, 0x7A, 0x45,
+0x03, 0x2A, 0x06, 0x6C, 0x00, 0x18, 0x1D, 0x2E,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xAA, 0x51,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xAA, 0x51,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xAA, 0x51,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2, 0x00, 0x49,
+0xA3, 0xF3, 0x4A, 0xA1, 0xFF, 0x68, 0x8C, 0xE8,
+0x01, 0x72, 0x31, 0x60, 0x03, 0x22, 0x02, 0x72,
+0x5F, 0x60, 0xBD, 0x10, 0x01, 0x6C, 0xC0, 0x6D,
+0x00, 0x18, 0x86, 0x09, 0x20, 0x6A, 0xA3, 0xF3,
+0x68, 0xA1, 0x4D, 0xE8, 0xFF, 0x6A, 0x4C, 0xE8,
+0x04, 0x6A, 0x6C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4,
+0x54, 0x9A, 0x10, 0xF0, 0x00, 0x6D, 0x60, 0xA2,
+0x8C, 0xEB, 0x60, 0xC2, 0x01, 0x6C, 0x5F, 0x10,
+0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x0A, 0x22, 0xA3, 0xF3, 0x64, 0xA1, 0x02, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x03, 0x6B, 0x6B, 0xEB,
+0x6C, 0xEA, 0xA3, 0xF3, 0x44, 0xC1, 0x01, 0x6C,
+0x10, 0xF0, 0x00, 0x6D, 0x63, 0x10, 0x01, 0x6C,
+0x00, 0xF3, 0x00, 0x6D, 0x00, 0x18, 0x86, 0x09,
+0xA3, 0xF3, 0x68, 0xA1, 0x20, 0x6A, 0x4D, 0xE8,
+0x04, 0x6A, 0xFF, 0x6C, 0x6C, 0xEA, 0x8C, 0xEA,
+0x8C, 0xE8, 0x0D, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x54, 0x9A, 0x60, 0xA2, 0x8C, 0xEB,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0x6C,
+0xA0, 0xF7, 0xA8, 0x9A, 0x30, 0x10, 0x02, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x0A, 0x22,
+0xA3, 0xF3, 0x64, 0xA1, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x03, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0xA3, 0xF3, 0x44, 0xC1, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0x6C, 0xA0, 0xF7, 0xA8, 0x9A, 0x32, 0x10,
+0x01, 0x6C, 0x01, 0xF4, 0x00, 0x6D, 0x00, 0x18,
+0x86, 0x09, 0xA3, 0xF3, 0x68, 0xA1, 0x20, 0x6A,
+0x4D, 0xE8, 0x04, 0x6A, 0xFF, 0x6C, 0x6C, 0xEA,
+0x8C, 0xEA, 0x8C, 0xE8, 0x0F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x54, 0x9A, 0x60, 0xA2,
+0x8C, 0xEB, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0xA4, 0x9A, 0x01, 0x6C, 0x00, 0x18,
+0x86, 0x09, 0x16, 0x10, 0x02, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x0A, 0x22, 0xA3, 0xF3,
+0x64, 0xA1, 0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x03, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA, 0xA3, 0xF3,
+0x44, 0xC1, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0xA4, 0x9A, 0x01, 0x6C, 0x00, 0x18, 0xA3, 0x09,
+0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6, 0x88, 0xA2,
+0x08, 0x6A, 0xFF, 0x6B, 0x8C, 0xEA, 0x09, 0x22,
+0x10, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA, 0x02, 0x2A,
+0x02, 0x6A, 0x01, 0x10, 0x04, 0x6A, 0x4D, 0xE8,
+0x6C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6,
+0x88, 0xA2, 0x02, 0x6A, 0xFF, 0x6B, 0x8C, 0xEA,
+0x08, 0x22, 0x20, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA,
+0x04, 0x22, 0x80, 0x6A, 0x4B, 0xEA, 0x4D, 0xE8,
+0x6C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF6,
+0x68, 0xA2, 0x40, 0x6A, 0x4C, 0xEB, 0x03, 0x2B,
+0x4D, 0xE8, 0xFF, 0x6A, 0x4C, 0xE8, 0x50, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6C, 0x6F, 0x6D,
+0x25, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x95, 0xA2, 0x02, 0x6B, 0x8C, 0xEB, 0x0B, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF4, 0x84, 0x9B,
+0xBF, 0x6B, 0xA0, 0xA4, 0xAC, 0xEB, 0x60, 0xC4,
+0x04, 0x6B, 0xA3, 0xF3, 0x65, 0xC2, 0x30, 0xF0,
+0x20, 0x69, 0x86, 0xF2, 0x00, 0x49, 0xA3, 0xF3,
+0x68, 0xA1, 0x02, 0x6A, 0x6C, 0xEA, 0x0D, 0x22,
+0xA3, 0xF3, 0x0A, 0xA1, 0x90, 0x67, 0x00, 0x18,
+0x0D, 0x50, 0xBF, 0x6D, 0x4C, 0xED, 0x90, 0x67,
+0x00, 0x18, 0x00, 0x50, 0x04, 0x6A, 0xA3, 0xF3,
+0x45, 0xC1, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18,
+0x18, 0x3A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2, 0x02, 0x6B,
+0x8C, 0xEB, 0x03, 0x23, 0x01, 0x6B, 0xA3, 0xF3,
+0x65, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2, 0x02, 0x6B,
+0x8C, 0xEB, 0x03, 0x23, 0x01, 0x6B, 0xA3, 0xF3,
+0x65, 0xC2, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x79, 0x52,
+0x00, 0x18, 0x59, 0x50, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6C, 0xA4, 0x67,
+0x22, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xA0, 0xF0,
+0x95, 0xA3, 0x02, 0x6A, 0xFF, 0x6D, 0x8C, 0xEA,
+0x0D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4,
+0x84, 0x9A, 0x40, 0x6E, 0x40, 0xA4, 0xAC, 0xEA,
+0xCD, 0xEA, 0xAC, 0xEA, 0x40, 0xC4, 0x03, 0x6A,
+0xA3, 0xF3, 0x45, 0xC3, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xA3, 0xF3, 0x68, 0xA0,
+0x02, 0x6A, 0x6C, 0xEA, 0x0F, 0x22, 0xA3, 0xF3,
+0x2A, 0xA0, 0x91, 0x67, 0x00, 0x18, 0x0D, 0x50,
+0x40, 0x6B, 0x4D, 0xEB, 0xFF, 0x6D, 0x91, 0x67,
+0x6C, 0xED, 0x00, 0x18, 0x00, 0x50, 0x03, 0x6A,
+0xA3, 0xF3, 0x45, 0xC0, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18,
+0x18, 0x3A, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA0, 0xF0, 0x95, 0xA3, 0x02, 0x6A,
+0xFF, 0x6D, 0x8C, 0xEA, 0x0D, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x84, 0x9A, 0x40, 0x6E,
+0x40, 0xA4, 0xAC, 0xEA, 0xCD, 0xEA, 0xAC, 0xEA,
+0x40, 0xC4, 0x01, 0x6A, 0xA3, 0xF3, 0x45, 0xC3,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0xA3, 0xF3, 0x68, 0xA0, 0x02, 0x6A, 0x6C, 0xEA,
+0x0F, 0x22, 0xA3, 0xF3, 0x2A, 0xA0, 0x91, 0x67,
+0x00, 0x18, 0x0D, 0x50, 0x40, 0x6B, 0x4D, 0xEB,
+0xFF, 0x6D, 0x91, 0x67, 0x6C, 0xED, 0x00, 0x18,
+0x00, 0x50, 0x01, 0x6A, 0xA3, 0xF3, 0x45, 0xC0,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xAE, 0x52, 0x00, 0x18, 0x59, 0x50,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6C, 0xA4, 0x67,
+0x21, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x95, 0xA2, 0x02, 0x6B, 0x8C, 0xEB, 0x03, 0x23,
+0x03, 0x6B, 0xA3, 0xF3, 0x65, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3,
+0x88, 0xA2, 0x02, 0x6B, 0x8C, 0xEB, 0x03, 0x23,
+0x03, 0x6B, 0xA3, 0xF3, 0x65, 0xC2, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x73, 0x50, 0x00, 0x18, 0xD2, 0x52,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6C, 0x6F, 0x6D, 0x1F, 0x6E, 0x00, 0x18,
+0x18, 0x3A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2, 0x02, 0x6B,
+0x8C, 0xEB, 0x0B, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF4, 0x84, 0x9B, 0xBF, 0x6B, 0xA0, 0xA4,
+0xAC, 0xEB, 0x60, 0xC4, 0x04, 0x6B, 0xA3, 0xF3,
+0x65, 0xC2, 0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2,
+0x00, 0x49, 0xA3, 0xF3, 0x68, 0xA1, 0x02, 0x6A,
+0x6C, 0xEA, 0x0D, 0x22, 0xA3, 0xF3, 0x0A, 0xA1,
+0x90, 0x67, 0x00, 0x18, 0x0D, 0x50, 0xBF, 0x6D,
+0x4C, 0xED, 0x90, 0x67, 0x00, 0x18, 0x00, 0x50,
+0x04, 0x6A, 0xA3, 0xF3, 0x45, 0xC1, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x73, 0x50,
+0x00, 0x18, 0xE8, 0x52, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x30, 0x41, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2,
+0x02, 0x6B, 0x6C, 0xEC, 0x02, 0x24, 0xA3, 0xF3,
+0x65, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2, 0x02, 0x6B,
+0x6C, 0xEC, 0x02, 0x24, 0xA3, 0xF3, 0x65, 0xC2,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF3, 0x75, 0xA2, 0x02, 0x6A,
+0xFF, 0x6C, 0x6C, 0xEA, 0x0A, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x64, 0x9A, 0x40, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA3, 0xF3, 0x88, 0xA2, 0x02, 0x6B,
+0x8C, 0xEB, 0x0C, 0x23, 0xA3, 0xF3, 0x0A, 0xA2,
+0x90, 0x67, 0x00, 0x18, 0x0D, 0x50, 0x40, 0x6B,
+0x4D, 0xEB, 0xFF, 0x6D, 0x90, 0x67, 0x6C, 0xED,
+0x00, 0x18, 0x00, 0x50, 0xFF, 0x6C, 0xA4, 0x67,
+0x23, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x00, 0x18,
+0x30, 0x41, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2, 0x02, 0x6B,
+0x6C, 0xEC, 0x02, 0x24, 0xA3, 0xF3, 0x65, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA3, 0xF3, 0x88, 0xA2, 0x02, 0x6B, 0x6C, 0xEC,
+0x02, 0x24, 0xA3, 0xF3, 0x65, 0xC2, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6C, 0xA4, 0x67,
+0x20, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x00, 0x18,
+0x30, 0x41, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xA0, 0xF0, 0x95, 0xA2, 0x02, 0x6B,
+0x6C, 0xEC, 0x02, 0x24, 0xA3, 0xF3, 0x65, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA3, 0xF3, 0x88, 0xA2, 0x02, 0x6B, 0x6C, 0xEC,
+0x02, 0x24, 0xA3, 0xF3, 0x65, 0xC2, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x73, 0x50, 0x00, 0x18, 0x3E, 0x53,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x99, 0x41,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA0, 0xF0, 0x95, 0xA2, 0x02, 0x6B, 0x8C, 0xEB,
+0x03, 0x23, 0x03, 0x6B, 0xA3, 0xF3, 0x65, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA3, 0xF3, 0x88, 0xA2, 0x02, 0x6B, 0x8C, 0xEB,
+0x03, 0x23, 0x03, 0x6B, 0xA3, 0xF3, 0x65, 0xC2,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x00, 0x18, 0x99, 0x41, 0xFF, 0x6C, 0x6F, 0x6D,
+0x24, 0x6E, 0x00, 0x18, 0x18, 0x3A, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x95, 0xA2, 0x02, 0x6B, 0x8C, 0xEB, 0x0B, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF4, 0x84, 0x9B,
+0xBF, 0x6B, 0xA0, 0xA4, 0xAC, 0xEB, 0x60, 0xC4,
+0x04, 0x6B, 0xA3, 0xF3, 0x65, 0xC2, 0x30, 0xF0,
+0x20, 0x69, 0x86, 0xF2, 0x00, 0x49, 0xA3, 0xF3,
+0x68, 0xA1, 0x02, 0x6A, 0x6C, 0xEA, 0x0D, 0x22,
+0xA3, 0xF3, 0x0A, 0xA1, 0x90, 0x67, 0x00, 0x18,
+0x0D, 0x50, 0xBF, 0x6D, 0x4C, 0xED, 0x90, 0x67,
+0x00, 0x18, 0x00, 0x50, 0x04, 0x6A, 0xA3, 0xF3,
+0x45, 0xC1, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x99, 0x41, 0x00, 0x6D, 0xFF, 0x6C,
+0xC5, 0x67, 0x00, 0x18, 0x18, 0x3A, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA0, 0xF0,
+0x95, 0xA2, 0x02, 0x6B, 0x8C, 0xEB, 0x03, 0x23,
+0x01, 0x6B, 0xA3, 0xF3, 0x65, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3,
+0x88, 0xA2, 0x02, 0x6B, 0x8C, 0xEB, 0x03, 0x23,
+0x01, 0x6B, 0xA3, 0xF3, 0x65, 0xC2, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x81, 0x53, 0x00, 0x18, 0x59, 0x50,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6D,
+0x86, 0xF2, 0x00, 0x4D, 0xA0, 0xF0, 0xD5, 0xA5,
+0x02, 0x6B, 0xFF, 0x6A, 0xCC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x00, 0x6A, 0x02, 0x23, 0xA3, 0xF3,
+0x45, 0xA5, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA3, 0xF3, 0xC8, 0xA3, 0x02, 0x6D,
+0xCC, 0xED, 0x02, 0x25, 0xA3, 0xF3, 0x45, 0xA3,
+0x8A, 0xEA, 0x69, 0x60, 0x05, 0x5C, 0x67, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0x88, 0x34, 0x40, 0xF7,
+0x04, 0x4B, 0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB,
+0x04, 0x72, 0x03, 0x61, 0x00, 0x18, 0xCD, 0x52,
+0x5A, 0x10, 0x02, 0x72, 0x03, 0x61, 0x00, 0x18,
+0x93, 0x53, 0x55, 0x10, 0x03, 0x72, 0x03, 0x61,
+0x00, 0x18, 0x8A, 0x52, 0x50, 0x10, 0x01, 0x72,
+0x4E, 0x61, 0x00, 0x18, 0x59, 0x50, 0x4B, 0x10,
+0x04, 0x72, 0x03, 0x61, 0x00, 0x18, 0xAE, 0x52,
+0x46, 0x10, 0x02, 0x72, 0x03, 0x61, 0x00, 0x18,
+0x81, 0x53, 0x41, 0x10, 0x03, 0x72, 0x03, 0x61,
+0x00, 0x18, 0x79, 0x52, 0x3C, 0x10, 0x3B, 0x2A,
+0x00, 0x18, 0x73, 0x50, 0x38, 0x10, 0x04, 0x72,
+0x03, 0x61, 0x00, 0x18, 0x18, 0x53, 0x33, 0x10,
+0x01, 0x72, 0x03, 0x61, 0x00, 0x18, 0x3E, 0x53,
+0x2E, 0x10, 0x03, 0x72, 0x03, 0x61, 0x00, 0x18,
+0x09, 0x53, 0x29, 0x10, 0x28, 0x2A, 0x00, 0x18,
+0x4F, 0x53, 0x25, 0x10, 0x04, 0x72, 0x03, 0x61,
+0x00, 0x18, 0x8F, 0x52, 0x20, 0x10, 0x01, 0x72,
+0x03, 0x61, 0x00, 0x18, 0xD2, 0x52, 0x1B, 0x10,
+0x02, 0x72, 0x03, 0x61, 0x00, 0x18, 0x54, 0x53,
+0x16, 0x10, 0x15, 0x2A, 0x00, 0x18, 0xE3, 0x52,
+0x12, 0x10, 0x03, 0x72, 0x03, 0x61, 0x00, 0x18,
+0x5D, 0x52, 0x0D, 0x10, 0x01, 0x72, 0x03, 0x61,
+0x00, 0x18, 0xE8, 0x52, 0x08, 0x10, 0x02, 0x72,
+0x03, 0x61, 0x00, 0x18, 0x64, 0x53, 0x03, 0x10,
+0x02, 0x2A, 0x00, 0x18, 0x04, 0x53, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xA3, 0xF3, 0x68, 0xA2,
+0x01, 0x6C, 0xFF, 0x6D, 0x6C, 0xEC, 0x33, 0x24,
+0xA3, 0xF3, 0x85, 0xA2, 0x04, 0x74, 0x2F, 0x60,
+0xA3, 0xF3, 0x86, 0xA2, 0x02, 0x74, 0x2B, 0x60,
+0x02, 0x6C, 0x6C, 0xEC, 0xAC, 0xEC, 0x03, 0x24,
+0x00, 0x18, 0x84, 0x05, 0x24, 0x10, 0x80, 0x6C,
+0x8B, 0xEC, 0x6C, 0xEC, 0xAC, 0xEC, 0x05, 0x24,
+0xA3, 0xF3, 0x8B, 0xA2, 0x00, 0x18, 0xD1, 0x04,
+0x05, 0x10, 0xFF, 0x6C, 0xA4, 0x67, 0xC4, 0x67,
+0x00, 0x18, 0x18, 0x3A, 0x00, 0x18, 0x57, 0x05,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA3, 0xF3, 0x66, 0xA2, 0x0C, 0x73, 0x03, 0x61,
+0x08, 0x6C, 0x00, 0x6D, 0x04, 0x10, 0x04, 0x73,
+0x06, 0x61, 0x00, 0x6C, 0xA4, 0x67, 0xA3, 0xF3,
+0xC9, 0xA2, 0x00, 0x18, 0xD9, 0x17, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xC3, 0xF3,
+0x64, 0xA0, 0x01, 0x6A, 0xFF, 0x69, 0x4C, 0xEB,
+0x80, 0xF0, 0x02, 0x23, 0xA3, 0xF3, 0x68, 0xA0,
+0x6C, 0xEA, 0x2C, 0xEA, 0x7D, 0x22, 0xC3, 0xF3,
+0x69, 0xA0, 0x40, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x45, 0x22, 0x20, 0x6A, 0x10, 0xF0, 0x21, 0x6C,
+0x6D, 0xEA, 0x42, 0xF3, 0x05, 0x4C, 0xC3, 0xF3,
+0x49, 0xC0, 0x00, 0x18, 0x77, 0x3B, 0x10, 0xF0,
+0x21, 0x6C, 0x63, 0xF1, 0x09, 0x4C, 0x00, 0x18,
+0x77, 0x3B, 0xC3, 0xF3, 0x46, 0xA0, 0x0F, 0x6B,
+0x4C, 0xEB, 0x2C, 0xEB, 0x00, 0x6A, 0x11, 0x10,
+0x0A, 0x6D, 0xB8, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x86, 0xF2, 0x00, 0x4C, 0x12, 0xED, 0x91, 0xE5,
+0xC3, 0xF3, 0xAF, 0xA4, 0x07, 0x6C, 0xAC, 0xEC,
+0x02, 0x74, 0x05, 0x60, 0x01, 0x4A, 0xFF, 0x6C,
+0x8C, 0xEA, 0x62, 0xEA, 0xED, 0x61, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0xC3, 0xF3,
+0xA4, 0xA0, 0x0F, 0x6C, 0x1F, 0x6B, 0x8C, 0xEA,
+0x6B, 0xEB, 0x44, 0x32, 0xAC, 0xEB, 0x4D, 0xEB,
+0xC3, 0xF3, 0x50, 0xA0, 0xC3, 0xF3, 0x64, 0xC0,
+0x4C, 0xEC, 0x00, 0x18, 0xB5, 0x3F, 0xC3, 0xF3,
+0x69, 0xA0, 0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xC3, 0xF3, 0x49, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x49, 0xF6, 0xA4, 0xA2, 0x0F, 0x6A, 0x02, 0x6C,
+0xA6, 0x35, 0x4C, 0xED, 0x00, 0x18, 0x2D, 0x45,
+0x00, 0x18, 0x7A, 0x45, 0x03, 0x2A, 0x06, 0x6C,
+0x00, 0x18, 0x1D, 0x2E, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x50, 0x9A, 0x0F, 0x6C, 0xFF, 0x6E,
+0xE0, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC3, 0xF3, 0xA4, 0xA2, 0xA3, 0xF3,
+0x70, 0x9A, 0xCC, 0xEF, 0xA6, 0x35, 0x8C, 0xED,
+0x0A, 0x6C, 0x98, 0xED, 0x62, 0x33, 0x6A, 0x33,
+0x12, 0xED, 0x49, 0xE5, 0xC3, 0xF3, 0x90, 0xA2,
+0x4F, 0x47, 0x57, 0x32, 0x92, 0x34, 0x8F, 0xE3,
+0x53, 0xE3, 0xCC, 0xEC, 0x00, 0x18, 0x12, 0x44,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xDD, 0x53, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xDD, 0x53, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xDD, 0x53, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0x29, 0xF6, 0x08, 0x4C,
+0x00, 0x6D, 0x18, 0x6E, 0x00, 0x18, 0xB4, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA3, 0xF3, 0x68, 0xA2, 0x03, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEB, 0xA3, 0xF3, 0xA4, 0xA2, 0xA3, 0xF3,
+0x68, 0xC2, 0x02, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB,
+0x8C, 0xEB, 0xA3, 0xF3, 0x64, 0xC2, 0x00, 0x6B,
+0xA3, 0xF3, 0x65, 0xC2, 0x0C, 0x6B, 0xA3, 0xF3,
+0x66, 0xC2, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xA7, 0x44, 0x30, 0xF0, 0x20, 0x6C, 0x29, 0xF6,
+0x08, 0x4C, 0x01, 0x4D, 0x18, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC3, 0xF3, 0x84, 0xA2, 0x01, 0x6B,
+0x6C, 0xEC, 0x11, 0x24, 0xA3, 0xF3, 0x88, 0xA2,
+0x8C, 0xEB, 0xFF, 0x6C, 0x8C, 0xEB, 0x0B, 0x23,
+0xC3, 0xF3, 0x89, 0xA2, 0x40, 0x6B, 0x8D, 0xEB,
+0xC3, 0xF3, 0x69, 0xC2, 0xA3, 0xF3, 0x7C, 0x9A,
+0xC3, 0xF3, 0x6A, 0xC2, 0x46, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xC3, 0xF3,
+0xE4, 0xA3, 0x01, 0x6C, 0xA4, 0x67, 0xEC, 0xED,
+0xFF, 0x6A, 0x3B, 0x25, 0xA3, 0xF3, 0xA8, 0xA3,
+0x8C, 0xED, 0x4C, 0xED, 0x36, 0x2D, 0xC3, 0xF3,
+0xC9, 0xA3, 0xDE, 0x4C, 0xA0, 0xF0, 0x11, 0xA3,
+0xCC, 0xEC, 0xC3, 0xF3, 0xC5, 0xA3, 0xC3, 0xF3,
+0x89, 0xC3, 0x1F, 0x6C, 0xCC, 0xEC, 0xC3, 0xF3,
+0x85, 0xC3, 0xC3, 0xF3, 0x87, 0xA3, 0x0F, 0x6E,
+0xCC, 0xE8, 0x1C, 0x65, 0x10, 0x6C, 0x8B, 0xEC,
+0x38, 0x67, 0x2C, 0xEC, 0x0D, 0xEC, 0xC3, 0xF3,
+0x87, 0xC3, 0x1E, 0x6C, 0xEC, 0xEC, 0x4C, 0xEC,
+0xC3, 0xF3, 0xA8, 0xC3, 0x0E, 0x24, 0xC3, 0xF3,
+0xA4, 0xA3, 0x02, 0x6C, 0xA6, 0x35, 0xCC, 0xED,
+0x4C, 0xED, 0x00, 0x18, 0x2D, 0x45, 0x00, 0x18,
+0x7A, 0x45, 0x03, 0x2A, 0x06, 0x6C, 0x00, 0x18,
+0x1D, 0x2E, 0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF6,
+0x50, 0xA2, 0x0F, 0x6C, 0x4C, 0xEC, 0x00, 0x18,
+0x96, 0x3F, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0xA3, 0xF3, 0x4A, 0xA3, 0x01, 0x72,
+0x6C, 0x60, 0x05, 0x22, 0x02, 0x72, 0x00, 0x6C,
+0x20, 0xF1, 0x13, 0x61, 0xC9, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x44, 0x9A, 0xFF, 0x6D,
+0x08, 0x6F, 0x80, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0xC8, 0x9A, 0xEB, 0xEF, 0xAC, 0xEC,
+0x40, 0xA6, 0xAC, 0xEA, 0xEC, 0xEA, 0xA3, 0xF3,
+0xE9, 0xA3, 0xED, 0xEA, 0xAC, 0xEA, 0x40, 0xC6,
+0xA3, 0xF3, 0x68, 0xA3, 0x08, 0x6A, 0x6C, 0xEA,
+0xAC, 0xEA, 0x00, 0xF1, 0x16, 0x22, 0x10, 0x6E,
+0x43, 0x67, 0xCC, 0xEA, 0xAC, 0xEA, 0x07, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x42, 0xF0, 0x70, 0x9A,
+0x8F, 0x6A, 0xA0, 0xA3, 0x0A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x42, 0xF0, 0x70, 0x9A, 0x71, 0x6F,
+0xEB, 0xEF, 0x40, 0xA3, 0xAC, 0xEA, 0xEC, 0xEA,
+0xCD, 0xEA, 0xAC, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0xA3, 0xF3, 0xB0, 0x9A, 0x42, 0xF0,
+0x74, 0x9B, 0x01, 0x6E, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xA3, 0xF3, 0xB4, 0x9A, 0x42, 0xF0,
+0x78, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA3, 0xF3, 0xB8, 0x9A, 0x42, 0xF0, 0x7C, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA3, 0xF3,
+0xBC, 0x9A, 0x62, 0xF0, 0x60, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x62, 0xF0, 0x64, 0x9B,
+0xA3, 0xF3, 0x48, 0xA2, 0xFF, 0x6D, 0xE0, 0xA3,
+0x52, 0x32, 0xCC, 0xEA, 0xC4, 0xEA, 0xAC, 0xEF,
+0x46, 0x67, 0xED, 0xEA, 0xAC, 0xEA, 0x40, 0xC3,
+0xCC, 0x10, 0x30, 0xF0, 0x20, 0x6D, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF4, 0x08, 0x9D, 0x22, 0xF0,
+0x58, 0x9A, 0xA3, 0xF3, 0xA9, 0xA3, 0x71, 0x6E,
+0x80, 0xA2, 0xE0, 0xA0, 0xFF, 0x6A, 0xCB, 0xEE,
+0x4C, 0xEF, 0xB0, 0x35, 0xCC, 0xEF, 0xED, 0xED,
+0x4C, 0xED, 0xA0, 0xC0, 0xA3, 0xF3, 0xA8, 0xA3,
+0x08, 0x6B, 0x4C, 0xEC, 0xAC, 0xEB, 0x4C, 0xEB,
+0xA0, 0xF0, 0x0F, 0x23, 0x10, 0x6B, 0xAC, 0xEB,
+0x4C, 0xEB, 0x09, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x42, 0xF0, 0xB0, 0x9B, 0x60, 0xA5, 0x4C, 0xEB,
+0xCC, 0xEB, 0x20, 0x6E, 0x08, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x42, 0xF0, 0xB0, 0x9B, 0x60, 0xA5,
+0x4C, 0xEB, 0xCC, 0xEB, 0x30, 0x6E, 0xCD, 0xEB,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xC5,
+0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0xA3, 0xF3, 0xB0, 0x9A, 0x42, 0xF0, 0x74, 0x9B,
+0x01, 0x6F, 0xFF, 0x6E, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xA3, 0xF3, 0xB4, 0x9A, 0x42, 0xF0,
+0x78, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA3, 0xF3, 0xB8, 0x9A, 0x42, 0xF0, 0x7C, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA3, 0xF3,
+0xBC, 0x9A, 0x62, 0xF0, 0x60, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x62, 0xF0, 0xA4, 0x9B,
+0xA3, 0xF3, 0x68, 0xA2, 0x00, 0xA5, 0x72, 0x33,
+0xEC, 0xEB, 0xCC, 0xE8, 0x42, 0x43, 0x64, 0x10,
+0x30, 0xF0, 0x20, 0x6D, 0x30, 0xF0, 0x20, 0x6A,
+0x22, 0xF0, 0x5C, 0x9A, 0x62, 0xF0, 0xC8, 0x9D,
+0x08, 0x6F, 0x80, 0xA2, 0xA0, 0xA6, 0xFF, 0x6A,
+0xEB, 0xEF, 0x4C, 0xED, 0xEC, 0xED, 0xA3, 0xF3,
+0xE9, 0xA3, 0x4C, 0xEC, 0xED, 0xED, 0x4C, 0xED,
+0xA0, 0xC6, 0xA3, 0xF3, 0xA8, 0xA3, 0x08, 0x6B,
+0xAC, 0xEB, 0x4C, 0xEB, 0x4E, 0x23, 0x10, 0x6B,
+0xAC, 0xEB, 0x4C, 0xEB, 0x0B, 0x2B, 0x30, 0xF0,
+0x20, 0x6B, 0x42, 0xF0, 0xB0, 0x9B, 0x71, 0x6E,
+0xCB, 0xEE, 0x60, 0xA5, 0x4C, 0xEB, 0xCC, 0xEB,
+0x40, 0x6E, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x42, 0xF0, 0xB0, 0x9B, 0x71, 0x6E, 0xCB, 0xEE,
+0x60, 0xA5, 0x4C, 0xEB, 0xCC, 0xEB, 0x50, 0x6E,
+0xCD, 0xEB, 0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xC5, 0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0xA3, 0xF3, 0xB0, 0x9A, 0x42, 0xF0,
+0x74, 0x9B, 0x01, 0x6F, 0xFF, 0x6E, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0xA3, 0xF3, 0xB4, 0x9A,
+0x42, 0xF0, 0x78, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0xA3, 0xF3, 0xB8, 0x9A, 0x42, 0xF0,
+0x7C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xA3, 0xF3, 0xBC, 0x9A, 0x62, 0xF0, 0x60, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x62, 0xF0,
+0xA4, 0x9B, 0xA3, 0xF3, 0x68, 0xA2, 0x00, 0xA5,
+0x72, 0x33, 0xEC, 0xEB, 0xCC, 0xE8, 0x44, 0x43,
+0xE4, 0xEA, 0x47, 0x67, 0x0D, 0xEA, 0xCC, 0xEA,
+0x40, 0xC5, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF4,
+0x4C, 0x9A, 0x40, 0x6B, 0xFF, 0x69, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x44, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF4, 0x70, 0x9B,
+0x40, 0xA2, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0x2C, 0xEA, 0x54, 0x32, 0x01, 0x4A,
+0x2C, 0xEA, 0x40, 0xC3, 0xA3, 0xF3, 0x68, 0xA0,
+0x01, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x51, 0x22,
+0x00, 0x18, 0xF2, 0x51, 0x04, 0xD2, 0x00, 0x18,
+0x90, 0x50, 0xA3, 0xF3, 0x8A, 0xA0, 0x04, 0x95,
+0x00, 0x18, 0x00, 0x50, 0xA3, 0xF3, 0x68, 0xA0,
+0x02, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x16, 0x22,
+0xA3, 0xF3, 0x45, 0xA0, 0x03, 0x2A, 0x01, 0x6C,
+0x00, 0x18, 0x98, 0x53, 0x30, 0xF0, 0x20, 0x6A,
+0x29, 0xF6, 0x68, 0xA2, 0x40, 0x6A, 0x04, 0x6C,
+0x6C, 0xEA, 0x05, 0x2A, 0x00, 0x18, 0x29, 0x50,
+0x01, 0x6C, 0x01, 0x2A, 0x02, 0x6C, 0x00, 0x18,
+0x98, 0x53, 0x24, 0x10, 0x40, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x07, 0x22, 0xA3, 0xF3, 0x46, 0xA0,
+0x02, 0x72, 0x1C, 0x60, 0x02, 0x6C, 0x00, 0x6D,
+0x10, 0x10, 0xA3, 0xF3, 0x46, 0xA0, 0x02, 0x72,
+0x11, 0x61, 0x00, 0x18, 0x11, 0x17, 0x00, 0x18,
+0x29, 0x50, 0x01, 0x72, 0x04, 0x61, 0xA0, 0xF0,
+0x9A, 0xA0, 0x01, 0x6D, 0x02, 0x10, 0x00, 0x6C,
+0xA4, 0x67, 0xA3, 0xF3, 0xC9, 0xA0, 0x00, 0x18,
+0xD9, 0x17, 0x04, 0x10, 0xE3, 0xF4, 0x4B, 0xA0,
+0xA3, 0xF3, 0x46, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF4, 0x58, 0x9A, 0x22, 0x6B, 0x60, 0xC2,
+0x31, 0x10, 0xA3, 0xF3, 0x8A, 0xA0, 0x00, 0x6D,
+0x00, 0x18, 0x00, 0x50, 0xA3, 0xF3, 0x68, 0xA0,
+0x02, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x08, 0x22,
+0xA3, 0xF3, 0x45, 0xA0, 0x04, 0x72, 0x22, 0x61,
+0x00, 0x6C, 0x00, 0x18, 0x98, 0x53, 0x1E, 0x10,
+0xA3, 0xF3, 0x46, 0xA0, 0x04, 0x6C, 0x02, 0x72,
+0x03, 0x60, 0x08, 0x72, 0x06, 0x61, 0x0C, 0x6C,
+0xA3, 0xF3, 0xC9, 0xA0, 0x01, 0x6D, 0x00, 0x18,
+0xD9, 0x17, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xA3, 0xF3, 0x89, 0xA0, 0x00, 0x18,
+0x7C, 0x05, 0xA0, 0xF0, 0x9A, 0xA0, 0xA3, 0xF3,
+0xC9, 0xA0, 0x01, 0x6D, 0x00, 0x18, 0xD9, 0x17,
+0x00, 0x18, 0x53, 0x54, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x00, 0x6A, 0x05, 0x63, 0x00, 0xEF,
+0xFF, 0x6A, 0x4C, 0xEC, 0xAC, 0xEA, 0x0B, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x62, 0xF0, 0xAC, 0x9B,
+0x30, 0xF0, 0x20, 0x6E, 0x21, 0xF7, 0xD0, 0x9E,
+0x60, 0x9D, 0xCC, 0xEB, 0x0C, 0x10, 0x01, 0x72,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x62, 0xF0,
+0xAC, 0x9B, 0x30, 0xF0, 0x20, 0x6E, 0xC1, 0xF0,
+0xD4, 0x9E, 0x60, 0x9D, 0xCD, 0xEB, 0x60, 0xDD,
+0x05, 0x5C, 0x60, 0xF1, 0x06, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x88, 0x34, 0x40, 0xF7, 0x18, 0x4B,
+0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0, 0x6C, 0x9A,
+0x0D, 0x11, 0x01, 0x72, 0x10, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x6C, 0x9A, 0xFF, 0x6C,
+0x40, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0x40, 0xA3, 0x80, 0x4D,
+0xC0, 0x4D, 0x8C, 0xEA, 0x14, 0x10, 0x02, 0x72,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0,
+0x6C, 0x9A, 0xBF, 0x6A, 0x80, 0xA3, 0xF4, 0x10,
+0x03, 0x72, 0x20, 0xF1, 0x1A, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x6C, 0x9A, 0xFF, 0x6C,
+0x40, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0xE7, 0x10, 0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x70, 0x9A, 0xFD, 0x6A, 0x80, 0xA3,
+0xDF, 0x10, 0x01, 0x72, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x8C, 0x9A, 0xFF, 0x6A,
+0x40, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x62, 0xF0, 0x90, 0x9B, 0x01, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x60, 0xA4, 0x02, 0x6D, 0x4C, 0xEB, 0xE1, 0x10,
+0x02, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x6C, 0x9A, 0xBF, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x70, 0x9A, 0xFE, 0x6A, 0x80, 0xA3,
+0xB3, 0x10, 0x03, 0x72, 0xE0, 0xF0, 0x19, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0, 0x8C, 0x9A,
+0xFF, 0x6B, 0x40, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x90, 0x9A, 0x01, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0x92, 0x10, 0x07, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0, 0x70, 0x9A,
+0xF7, 0x6A, 0x80, 0xA3, 0x95, 0x10, 0x01, 0x72,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0,
+0x8C, 0x9A, 0xFF, 0x6A, 0x40, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x62, 0xF0, 0x90, 0x9B,
+0x04, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x60, 0xA4, 0x08, 0x6D,
+0x4C, 0xEB, 0x97, 0x10, 0x02, 0x72, 0x0F, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0, 0x6C, 0x9A,
+0xBF, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0, 0x70, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x69, 0x10, 0x03, 0x72,
+0xA0, 0xF0, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x8C, 0x9A, 0xFF, 0x6B, 0x40, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0,
+0x90, 0x9A, 0x04, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0x48, 0x10, 0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x70, 0x9A, 0xDF, 0x6A, 0x80, 0xA3,
+0x4B, 0x10, 0x01, 0x72, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x8C, 0x9A, 0xFF, 0x6A,
+0x40, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x62, 0xF0, 0x90, 0x9B, 0x10, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x60, 0xA4, 0x20, 0x6D, 0x4C, 0xEB, 0x4D, 0x10,
+0x02, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x6C, 0x9A, 0xBF, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x70, 0x9A, 0xEF, 0x6A, 0x80, 0xA3,
+0x1F, 0x10, 0x03, 0x72, 0x66, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x8C, 0x9A, 0xFF, 0x6B,
+0x40, 0x6D, 0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA,
+0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x90, 0x9A, 0x10, 0x6D, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x20, 0xE8, 0x09, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0xF0, 0x70, 0x9A, 0x80, 0xA3, 0x7F, 0x6A,
+0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8, 0x01, 0x72,
+0x1C, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0,
+0x8C, 0x9A, 0xFF, 0x6A, 0x40, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x62, 0xF0, 0x90, 0x9B,
+0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB,
+0x60, 0xC4, 0x60, 0xA4, 0x80, 0x4D, 0xC0, 0x4D,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x20, 0xE8, 0x02, 0x72, 0x10, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x4C, 0x9A, 0xBF, 0x6B,
+0x80, 0xA2, 0x6C, 0xEC, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x62, 0xF0, 0x50, 0x9A, 0x80, 0xA2,
+0x8C, 0xEB, 0x60, 0xC2, 0x20, 0xE8, 0x03, 0x72,
+0x14, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0,
+0x8C, 0x9A, 0xFF, 0x6B, 0x40, 0x6D, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x62, 0xF0, 0x90, 0x9A,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD1,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xFF, 0x6A, 0x25, 0x67, 0xE0, 0xF0,
+0xA7, 0xA0, 0xC3, 0xF3, 0x04, 0xA0, 0x4C, 0xEF,
+0x1F, 0x65, 0x01, 0x6F, 0xEC, 0xED, 0x0C, 0xEF,
+0x4C, 0xE9, 0x4C, 0xEE, 0x4C, 0xED, 0x4C, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1, 0x40, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEC, 0x00, 0xAA,
+0xE1, 0xF7, 0x1F, 0x6A, 0x0C, 0xEA, 0x30, 0xF0,
+0x20, 0x68, 0x81, 0xF0, 0x08, 0x98, 0x51, 0xE4,
+0x6C, 0xEC, 0x80, 0xC8, 0x9C, 0x32, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF0, 0x94, 0x9C, 0x30, 0xF0,
+0x20, 0x68, 0x62, 0xF0, 0x18, 0x98, 0x91, 0xE2,
+0x80, 0xAC, 0x01, 0xE2, 0x00, 0x98, 0x6C, 0xEC,
+0x05, 0x21, 0x10, 0xF0, 0x00, 0x69, 0x2B, 0xE9,
+0x2D, 0xEC, 0x6C, 0xEC, 0xD8, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF0,
+0x94, 0x9C, 0x91, 0xE2, 0x60, 0xCC, 0x30, 0xF0,
+0x20, 0x6B, 0x62, 0xF0, 0x7C, 0x9B, 0x6D, 0xE2,
+0x80, 0xA3, 0x01, 0x6B, 0x8C, 0xEB, 0x05, 0x23,
+0x03, 0xF7, 0x01, 0x6B, 0x6B, 0xEB, 0x0C, 0xEB,
+0x07, 0x10, 0x1F, 0xF7, 0x01, 0x6B, 0x6B, 0xEB,
+0x0C, 0xEB, 0x18, 0x67, 0x00, 0x34, 0x8D, 0xEB,
+0xFF, 0x76, 0x13, 0x60, 0x30, 0xF0, 0x20, 0x6C,
+0x82, 0xF0, 0x80, 0x9C, 0x80, 0xF4, 0xC0, 0x36,
+0x6C, 0xEC, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x64, 0x9B, 0x6D, 0xEE, 0x30, 0xF0, 0x20, 0x6B,
+0x62, 0xF0, 0x78, 0x9B, 0x8D, 0xEE, 0x6D, 0xE2,
+0xC0, 0xDB, 0x01, 0x2F, 0x15, 0x25, 0x30, 0xF0,
+0x20, 0x6B, 0x82, 0xF0, 0x84, 0x9B, 0xFF, 0x6D,
+0x80, 0x6E, 0x91, 0xE2, 0x60, 0xA4, 0xCB, 0xEE,
+0xAC, 0xEB, 0xCD, 0xEB, 0xAC, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x82, 0xF0, 0x68, 0x9B,
+0x00, 0x6C, 0x80, 0xC3, 0x00, 0x6C, 0x11, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x82, 0xF0, 0x84, 0x9B,
+0x7F, 0x6B, 0x91, 0xE2, 0xA0, 0xA4, 0xAC, 0xEB,
+0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B, 0x82, 0xF0,
+0x68, 0x9B, 0x1C, 0x6C, 0x80, 0xC3, 0x08, 0xF4,
+0x13, 0x6C, 0x30, 0xF0, 0x20, 0x6B, 0x82, 0xF0,
+0x6C, 0x9B, 0x80, 0xCB, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF0, 0x94, 0x9B, 0xF7, 0x6B, 0x91, 0xE2,
+0xA0, 0xA4, 0xAC, 0xEB, 0x60, 0xC4, 0x01, 0x91,
+0x00, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xC0, 0xF7, 0x84, 0x9C, 0x40, 0x9B, 0x20, 0x6D,
+0x00, 0x6E, 0x8D, 0xEA, 0x40, 0xDB, 0x00, 0xF4,
+0x1F, 0x6C, 0x06, 0x02, 0xE0, 0xF3, 0x08, 0x6F,
+0x04, 0xD2, 0x00, 0x18, 0x0B, 0x20, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xDE, 0x63, 0x43, 0x62,
+0x42, 0xD1, 0x41, 0xD0, 0x01, 0x68, 0x00, 0x6A,
+0x0B, 0xE8, 0x04, 0xD2, 0x00, 0x6C, 0x30, 0xF0,
+0x20, 0x6A, 0x42, 0x6D, 0xD0, 0x67, 0xC6, 0xF3,
+0x2A, 0xA2, 0x00, 0x18, 0x4F, 0x36, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x7C, 0x9B, 0x4C, 0xEB,
+0x30, 0x2B, 0x00, 0x6C, 0x42, 0x6D, 0xD0, 0x67,
+0x00, 0x18, 0x4F, 0x36, 0x1F, 0xF4, 0x00, 0x6B,
+0x4C, 0xEB, 0x62, 0x32, 0x4A, 0x32, 0x43, 0xE9,
+0x04, 0xD2, 0x02, 0x61, 0x4E, 0xE9, 0x10, 0x29,
+0x01, 0x6A, 0x7D, 0x67, 0x4B, 0xEA, 0x54, 0xC3,
+0x1D, 0x6A, 0x56, 0xC3, 0x04, 0x6A, 0x06, 0x04,
+0x57, 0xC3, 0x04, 0x05, 0x04, 0x6E, 0x00, 0x18,
+0xB9, 0x20, 0x05, 0x04, 0x00, 0x18, 0x33, 0x27,
+0x01, 0x68, 0x0B, 0xE8, 0x00, 0x6C, 0x42, 0x6D,
+0xD0, 0x67, 0x00, 0x18, 0x4F, 0x36, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0xFC, 0x9B, 0x00, 0x6C,
+0x42, 0x6D, 0xD0, 0x67, 0x4D, 0xEF, 0x00, 0x18,
+0xC5, 0x37, 0x43, 0x97, 0x42, 0x91, 0x41, 0x90,
+0x22, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x6B,
+0xAC, 0xEB, 0x05, 0xD3, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF1, 0x60, 0x9B, 0xFF, 0x6A, 0x8C, 0xEA,
+0x80, 0xAB, 0xE1, 0xF7, 0x1F, 0x6B, 0x00, 0x68,
+0x8C, 0xEB, 0x69, 0xE2, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF4, 0x84, 0x9B, 0x5C, 0x32, 0x91, 0xE2,
+0x04, 0xD4, 0x18, 0x10, 0x04, 0x92, 0x20, 0x9A,
+0x07, 0x28, 0x01, 0x6D, 0x83, 0xF1, 0x18, 0x6C,
+0xAB, 0xED, 0xD1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x01, 0x6D, 0x83, 0xF1, 0x18, 0x6C, 0xAB, 0xED,
+0xD1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x04, 0x93,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x4B,
+0x4C, 0xE8, 0x04, 0xD3, 0x05, 0x92, 0x43, 0xE8,
+0xE5, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x05, 0x6B, 0xC6, 0xF3,
+0x7C, 0xDA, 0x09, 0x6B, 0xC6, 0xF3, 0x78, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0xAC, 0x9A, 0x03, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xC5, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0x90, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0xD4, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0x54, 0x9A, 0x81, 0xF2, 0x78, 0x9B,
+0x02, 0x6F, 0xC0, 0xDC, 0x60, 0xDA, 0xE0, 0xC5,
+0x01, 0x6F, 0xC0, 0xDC, 0x60, 0xDA, 0xE0, 0xC5,
+0x30, 0xF0, 0x20, 0x6F, 0x81, 0xF2, 0xFC, 0x9F,
+0xE0, 0xDC, 0x00, 0x6F, 0x60, 0xDA, 0xE0, 0xC5,
+0xC0, 0xDC, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x20, 0x5C, 0x06, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x94, 0x34, 0x01, 0xF2,
+0x4C, 0x9A, 0x06, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF2, 0x40, 0x9A, 0xE1, 0x4C, 0x84, 0x34,
+0x51, 0xE4, 0x40, 0xA4, 0x4C, 0xEB, 0x43, 0x67,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF1, 0x7C, 0xA2, 0x60, 0xF1, 0x1C, 0x4A,
+0x60, 0xC4, 0x41, 0xA2, 0x40, 0xC5, 0x20, 0xE8,
+0xE5, 0x63, 0x35, 0x62, 0x34, 0xD1, 0x33, 0xD0,
+0x30, 0xF0, 0x20, 0x6D, 0x08, 0x04, 0xA0, 0xF4,
+0x04, 0x4D, 0x54, 0x6E, 0x00, 0x18, 0x39, 0x20,
+0x30, 0xF0, 0x20, 0x6D, 0x1D, 0x04, 0x40, 0xF4,
+0x10, 0x4D, 0x54, 0x6E, 0x00, 0x18, 0x39, 0x20,
+0x30, 0xF0, 0x20, 0x6D, 0x04, 0x04, 0x40, 0xF4,
+0x00, 0x4D, 0x0F, 0x6E, 0x00, 0x18, 0x39, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A,
+0x00, 0x6C, 0x49, 0x6B, 0x1B, 0x65, 0x60, 0xC2,
+0x2C, 0x6B, 0xD1, 0xA2, 0x63, 0xC2, 0x09, 0x6B,
+0x64, 0xC2, 0x0D, 0x6B, 0x6B, 0xEB, 0xCC, 0xEB,
+0x04, 0x6E, 0xCB, 0xEE, 0xCC, 0xEB, 0xD2, 0xA2,
+0xF6, 0xA2, 0x04, 0x68, 0xCD, 0xE8, 0x02, 0x6E,
+0xCB, 0xEE, 0xEC, 0xEE, 0xD6, 0xC2, 0xDE, 0xA2,
+0x03, 0x6F, 0xEB, 0xEF, 0xCC, 0xEF, 0x34, 0xA2,
+0x41, 0x6E, 0xCB, 0xEE, 0xFE, 0x65, 0xCC, 0xEF,
+0x10, 0x4E, 0xCC, 0xE9, 0xDF, 0x67, 0xCC, 0xE8,
+0xCE, 0xA2, 0x12, 0xC2, 0x08, 0x68, 0xFE, 0x65,
+0x0B, 0xE8, 0xDF, 0x67, 0x0C, 0xEE, 0xCE, 0xC2,
+0xD3, 0xA2, 0x00, 0x6D, 0xA1, 0xC2, 0xFE, 0x65,
+0xDF, 0x67, 0xCC, 0xE8, 0xBD, 0xC2, 0xB5, 0xC2,
+0x13, 0xC2, 0xA9, 0xC2, 0x10, 0x68, 0xB9, 0xC2,
+0x21, 0x6D, 0x0B, 0xE8, 0xAB, 0xED, 0x0C, 0xE9,
+0xAC, 0xEF, 0x10, 0xA2, 0xB8, 0x67, 0xA7, 0xC2,
+0x80, 0x6D, 0xAB, 0xED, 0xAD, 0xE8, 0x10, 0xC2,
+0x7F, 0x68, 0x0C, 0xEF, 0xFE, 0xC2, 0x20, 0x5C,
+0x00, 0x6F, 0x71, 0xC2, 0x34, 0xC2, 0xF4, 0xCA,
+0x04, 0x60, 0x31, 0x6E, 0xCB, 0xEE, 0xCC, 0xEB,
+0x05, 0x10, 0x31, 0x6E, 0xCB, 0xEE, 0xCC, 0xEB,
+0x10, 0x6E, 0xCD, 0xEB, 0x40, 0x6E, 0xCD, 0xEB,
+0xAD, 0xEB, 0x71, 0xC2, 0x01, 0x4C, 0xFF, 0x6B,
+0x6C, 0xEC, 0x3F, 0x69, 0x8E, 0xE9, 0x2E, 0x4A,
+0xA0, 0x29, 0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2,
+0x00, 0x48, 0xA6, 0xF5, 0x39, 0xC0, 0x00, 0x18,
+0xFC, 0x6A, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x40, 0x9A, 0x06, 0x6B, 0x60, 0xC2, 0x4A, 0xF2,
+0x3E, 0xC0, 0x00, 0x18, 0xE8, 0x67, 0x00, 0x18,
+0xFF, 0x56, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x44, 0x9A, 0x40, 0x6B, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0xC2, 0x1D, 0x05, 0x4F, 0xF1, 0x16, 0x4C,
+0x54, 0x6E, 0x00, 0x18, 0xB9, 0x20, 0x30, 0xF0,
+0x20, 0x6C, 0x08, 0x05, 0xAF, 0xF1, 0x0A, 0x4C,
+0x54, 0x6E, 0x00, 0x18, 0xB9, 0x20, 0x30, 0xF0,
+0x20, 0x6C, 0x4F, 0xF3, 0x12, 0x4C, 0x04, 0x05,
+0x0F, 0x6E, 0x00, 0x18, 0xB9, 0x20, 0x35, 0x97,
+0x34, 0x91, 0x33, 0x90, 0x1B, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0xAC, 0xE8, 0xD0, 0x67, 0x41, 0xF4, 0x10, 0x6C,
+0x7F, 0x6D, 0x00, 0x18, 0x86, 0x36, 0xD0, 0x67,
+0x41, 0xF6, 0x10, 0x6C, 0x7F, 0x6D, 0x00, 0x18,
+0x86, 0x36, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x85, 0x67, 0xA6, 0x67, 0xC7, 0x67, 0x00, 0x18,
+0x39, 0x20, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x26, 0x67, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x5C, 0x9A, 0x55, 0xE5, 0x00, 0x9D, 0x91, 0x67,
+0x00, 0x18, 0xBC, 0x1F, 0x2C, 0xE8, 0x06, 0xEA,
+0x50, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x46, 0x67, 0x01, 0x4A,
+0x05, 0x67, 0x0C, 0xD6, 0x27, 0x67, 0x1C, 0x22,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x49, 0xE0, 0x40, 0x9A, 0x0C, 0x94, 0x04, 0xD2,
+0x00, 0x18, 0xBC, 0x1F, 0x0C, 0x93, 0x24, 0xEA,
+0x6F, 0xEA, 0x04, 0x93, 0x6C, 0xEA, 0x4D, 0xE9,
+0x1F, 0xF7, 0x00, 0x6A, 0x0C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x41, 0xE0, 0x20, 0xD8, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x06, 0xD4, 0x06, 0x04,
+0x09, 0xD7, 0x07, 0xD5, 0x08, 0xD6, 0x00, 0x18,
+0xBC, 0x27, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x63, 0x01, 0xD0, 0xFF, 0x6B, 0x3F, 0x68,
+0x6C, 0xED, 0xB7, 0xE0, 0x6C, 0xED, 0x00, 0x68,
+0x06, 0x92, 0x00, 0xC7, 0x05, 0x67, 0x6C, 0xED,
+0x6C, 0xEC, 0x00, 0xF6, 0xC0, 0x36, 0x10, 0x5D,
+0x00, 0xF6, 0xC3, 0x36, 0x80, 0xC2, 0x01, 0x61,
+0x0F, 0x68, 0xFF, 0x6B, 0x00, 0x56, 0x0C, 0xEB,
+0x04, 0x61, 0xC2, 0xEB, 0x02, 0x61, 0xC0, 0xC7,
+0x15, 0x10, 0xC2, 0xEB, 0x0D, 0x60, 0xA7, 0x44,
+0xD1, 0xE4, 0x60, 0xC7, 0x6F, 0xE4, 0x60, 0xC2,
+0x60, 0xA2, 0x03, 0x4D, 0xFF, 0x68, 0x0C, 0xED,
+0x63, 0xED, 0x0B, 0x60, 0xA0, 0xC2, 0x09, 0x10,
+0xCB, 0xED, 0x00, 0x6B, 0x82, 0xED, 0x60, 0xC7,
+0x03, 0x60, 0xD1, 0xE4, 0x80, 0xC2, 0x01, 0x10,
+0x60, 0xC2, 0x01, 0x90, 0x01, 0x6A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x2D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0x3C, 0x9A, 0x01, 0x68, 0x0B, 0xE8, 0xA1, 0xF4,
+0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0xA1, 0xF4, 0x14, 0x6C, 0xB0, 0x67,
+0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF4, 0x1C, 0x6C, 0xB0, 0x67, 0x21, 0xF0,
+0x1B, 0x6E, 0x00, 0x18, 0x86, 0x36, 0xA1, 0xF6,
+0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0xA1, 0xF6, 0x14, 0x6C, 0xB0, 0x67,
+0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x1C, 0x6C, 0xB0, 0x67, 0x21, 0xF0,
+0x1B, 0x6E, 0x2C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x3C, 0x9A, 0x01, 0x68, 0x0B, 0xE8,
+0xA1, 0xF4, 0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4, 0x14, 0x6C,
+0xB0, 0x67, 0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0xFF, 0x6E, 0xA1, 0xF4, 0x1C, 0x6C,
+0xB0, 0x67, 0x01, 0x4E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x10, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF6, 0x14, 0x6C,
+0xB0, 0x67, 0x6E, 0xF7, 0x17, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0xFF, 0x6E, 0xA1, 0xF6, 0x1C, 0x6C,
+0xB0, 0x67, 0x01, 0x4E, 0x00, 0x18, 0x86, 0x36,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x40, 0x9A, 0x7F, 0x6B, 0x01, 0xF1,
+0x0C, 0x6C, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x50, 0x9A, 0x14, 0x6B, 0x10, 0xF0,
+0x00, 0x6D, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x54, 0x9A, 0x10, 0x6B, 0x01, 0x6E,
+0x60, 0xC2, 0x00, 0x18, 0x86, 0x36, 0x81, 0xF4,
+0x14, 0x69, 0x01, 0x6D, 0x91, 0x67, 0xC5, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6D, 0x01, 0xF4,
+0x00, 0x68, 0xC5, 0x67, 0x81, 0xF6, 0x14, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x91, 0x67, 0xB0, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x7E, 0xF3,
+0x0B, 0x49, 0xB0, 0x67, 0x81, 0xF6, 0x14, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x90, 0x67,
+0xB1, 0x67, 0x04, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xB1, 0x67, 0x01, 0xF6, 0x00, 0x6C, 0x04, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0xFF, 0x6D, 0x01, 0xF3,
+0x00, 0x6C, 0x01, 0x4D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xA0, 0x9A, 0x01, 0xF0, 0x08, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x21, 0xF0, 0x18, 0x6C,
+0x0E, 0x6D, 0x07, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x00, 0x6A, 0x0B, 0xD7,
+0xE0, 0xAE, 0x1F, 0xF7, 0x00, 0x6B, 0xEC, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x09, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xAE, 0x41, 0xF0,
+0x78, 0x9B, 0x6D, 0xE7, 0xE0, 0xA4, 0xE0, 0xC3,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x7C, 0x9B, 0x7D, 0xE7, 0x60, 0xA4, 0x60, 0xC7,
+0x01, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x72,
+0x02, 0x4E, 0x01, 0x4C, 0xE1, 0x61, 0x25, 0x67,
+0x00, 0x68, 0x0B, 0x93, 0xC0, 0x99, 0x01, 0x6D,
+0x09, 0xE3, 0x80, 0xAA, 0xAB, 0xED, 0x02, 0x48,
+0x00, 0x18, 0x86, 0x36, 0x1E, 0x70, 0x04, 0x49,
+0xF4, 0x61, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x28, 0x34, 0x11, 0xE4, 0x04, 0xD4, 0x8A, 0xF5,
+0xD5, 0xA4, 0x65, 0xF3, 0x80, 0x41, 0x84, 0x34,
+0x11, 0xE4, 0xA8, 0xA4, 0x03, 0x6C, 0x62, 0xF5,
+0x44, 0x41, 0x8C, 0xED, 0xA0, 0x35, 0x1D, 0x65,
+0x04, 0x95, 0x48, 0x32, 0x09, 0xE2, 0x8A, 0xF5,
+0xF6, 0xA5, 0x64, 0xA2, 0x01, 0x6A, 0x4C, 0xEF,
+0x4C, 0xEB, 0xE4, 0x37, 0xFD, 0xE3, 0x8A, 0xF5,
+0x77, 0xA5, 0x4C, 0xEE, 0xD0, 0x36, 0x4C, 0xEB,
+0x24, 0x32, 0x09, 0xE2, 0xCA, 0xF6, 0x49, 0xA2,
+0x74, 0x33, 0x6D, 0xE6, 0x8C, 0xEA, 0x40, 0x32,
+0x06, 0xD3, 0x48, 0x32, 0x78, 0x67, 0x4D, 0xE3,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0xC0, 0x9A,
+0x01, 0x6D, 0xE3, 0xF2, 0x1D, 0x4C, 0xAB, 0xED,
+0x07, 0xD7, 0x05, 0xD3, 0x00, 0x18, 0x86, 0x36,
+0x07, 0x94, 0x06, 0x96, 0x05, 0x92, 0xFF, 0xF7,
+0x1F, 0x6D, 0x8D, 0xEE, 0x4D, 0xEE, 0xE3, 0xF3,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x04, 0x93,
+0xB2, 0xF5, 0x46, 0x41, 0x48, 0x32, 0xCA, 0xF6,
+0xDE, 0xAB, 0x09, 0xE2, 0x42, 0xAA, 0xC0, 0x36,
+0xC0, 0x36, 0x01, 0x6D, 0x4D, 0xEE, 0xE3, 0xF3,
+0x08, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x04, 0x94, 0xA2, 0xF5, 0x17, 0x49, 0x28, 0x31,
+0xEA, 0xF6, 0xC2, 0xAC, 0x05, 0xE1, 0x42, 0xA9,
+0xC0, 0x36, 0xC0, 0x36, 0x01, 0x6D, 0x4D, 0xEE,
+0xE3, 0xF3, 0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xEA, 0xF6,
+0xCC, 0xA0, 0xA0, 0xF7, 0xA8, 0x9A, 0xE3, 0xF3,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0x00, 0x6A, 0x07, 0xD2, 0x08, 0xD2, 0x09, 0xD2,
+0x0A, 0xD2, 0x0B, 0xD2, 0xA2, 0x9C, 0x3D, 0x67,
+0x1C, 0xA1, 0x01, 0x6E, 0xE5, 0x67, 0xFE, 0x4A,
+0xCC, 0xEF, 0x0C, 0xEA, 0xED, 0xEA, 0x03, 0x68,
+0xA6, 0x37, 0x0B, 0xE8, 0xCC, 0xEF, 0xE4, 0x37,
+0x0C, 0xEA, 0xED, 0xEA, 0xAA, 0x37, 0xFE, 0x48,
+0xCC, 0xEF, 0xE8, 0x37, 0x0C, 0xEA, 0xED, 0xEA,
+0xAE, 0x37, 0xFC, 0x48, 0xCC, 0xEF, 0xEC, 0x37,
+0x0C, 0xEA, 0xED, 0xEA, 0x07, 0x68, 0xB2, 0x37,
+0x71, 0x69, 0x2B, 0xE9, 0x0C, 0xEF, 0xF0, 0x37,
+0x2C, 0xEA, 0x07, 0x03, 0xED, 0xEA, 0xA2, 0x35,
+0xFD, 0x67, 0x5C, 0xC7, 0xA1, 0xC3, 0x23, 0x9C,
+0xCC, 0xEA, 0x24, 0xC3, 0xE4, 0x9C, 0x22, 0x31,
+0xE8, 0xC3, 0xA5, 0x9C, 0xE2, 0x37, 0xAC, 0xC3,
+0x86, 0x9C, 0xA2, 0x35, 0x25, 0xC3, 0x1C, 0x65,
+0x90, 0xC3, 0x98, 0x67, 0x82, 0x34, 0xE9, 0xC3,
+0xAD, 0xC3, 0x91, 0xC3, 0x22, 0x31, 0xE2, 0x37,
+0xA2, 0x35, 0x82, 0x34, 0x26, 0xC3, 0xEA, 0xC3,
+0xAE, 0xC3, 0x92, 0xC3, 0x80, 0xF0, 0x1B, 0x22,
+0xBD, 0x67, 0x5C, 0xA5, 0xFF, 0x6B, 0x52, 0x32,
+0x0C, 0xEA, 0x6C, 0xEA, 0x03, 0x22, 0x02, 0x72,
+0x38, 0x60, 0x91, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x24, 0x9A, 0x81, 0xF4, 0x14, 0x6C,
+0x00, 0x6E, 0xB1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0xFD, 0x67, 0x5D, 0xA7, 0x30, 0xF0, 0x20, 0x68,
+0xE0, 0xF0, 0x0C, 0x48, 0x44, 0x32, 0x30, 0xF0,
+0x20, 0x6B, 0x09, 0xE2, 0x41, 0xF1, 0x08, 0x4B,
+0xA0, 0x9B, 0xC0, 0xAA, 0x01, 0xF4, 0x1C, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0xB1, 0x67, 0x81, 0xF6,
+0x14, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x9D, 0x67, 0x5D, 0xA4, 0x30, 0xF0, 0x20, 0x6F,
+0x41, 0xF1, 0x08, 0x4F, 0x44, 0x32, 0x01, 0xE2,
+0xA0, 0x9F, 0xC0, 0xA8, 0x01, 0xF6, 0x1C, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6C,
+0x82, 0xF0, 0x10, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x5A, 0x10, 0x3D, 0x67, 0x9D, 0xA1, 0x20, 0xF0,
+0xA0, 0xA1, 0x20, 0xF0, 0xC1, 0x81, 0x06, 0x07,
+0x00, 0xF0, 0x19, 0x02, 0x04, 0xD2, 0x00, 0x18,
+0xC6, 0x57, 0xB8, 0xA1, 0xD9, 0xA1, 0x30, 0xF0,
+0x20, 0x6C, 0x82, 0xF0, 0x1C, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x24, 0x9A, 0x7D, 0x67, 0xD8, 0xA3, 0xB1, 0x67,
+0x81, 0xF4, 0x14, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0x9D, 0x67, 0x59, 0xA4, 0x30, 0xF0, 0x20, 0x68,
+0xE0, 0xF0, 0x0C, 0x48, 0x44, 0x32, 0x30, 0xF0,
+0x20, 0x6F, 0x09, 0xE2, 0x41, 0xF1, 0x08, 0x4F,
+0xA0, 0x9F, 0xC0, 0xAA, 0x01, 0xF4, 0x1C, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x5D, 0x67, 0x9D, 0xA2,
+0x20, 0xF0, 0xA4, 0xA2, 0x20, 0xF0, 0xC5, 0x82,
+0x00, 0xF0, 0x19, 0x03, 0x06, 0x07, 0x04, 0xD3,
+0x00, 0x18, 0xC6, 0x57, 0xFD, 0x67, 0xB8, 0xA7,
+0xD9, 0xA7, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF0,
+0x1C, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0xB1, 0x67,
+0x3D, 0x67, 0xD8, 0xA1, 0x81, 0xF6, 0x14, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x59, 0xA1, 0x01, 0xF6,
+0x1C, 0x6C, 0x44, 0x32, 0x01, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x08, 0x4A, 0xA0, 0x9A,
+0xC0, 0xA8, 0x00, 0x18, 0x86, 0x36, 0x0F, 0x97,
+0x0E, 0x91, 0x0D, 0x90, 0x00, 0x6A, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x6A, 0xF5, 0x5E, 0xA0,
+0x80, 0xF0, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0xC2, 0xF0, 0x1C, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x21, 0x6C, 0x01, 0x6A, 0x30, 0xF0,
+0x21, 0x6D, 0x51, 0xF0, 0x04, 0x4C, 0x8A, 0xF5,
+0x4E, 0xC0, 0x8A, 0xF5, 0x4F, 0xC0, 0x31, 0xF0,
+0x0C, 0x4D, 0x00, 0x6A, 0x1C, 0x65, 0x00, 0x6B,
+0x60, 0xDD, 0x30, 0xF0, 0x20, 0x6C, 0xD1, 0xF2,
+0x69, 0x42, 0x86, 0xF2, 0x00, 0x4C, 0x6C, 0x33,
+0x6D, 0xE4, 0x04, 0x4B, 0x07, 0xD3, 0xB2, 0xF5,
+0x66, 0x42, 0x68, 0x33, 0x6D, 0xE4, 0x04, 0x4B,
+0x06, 0xD3, 0x06, 0x6B, 0x78, 0xEA, 0x00, 0x6E,
+0x12, 0xEB, 0x6D, 0xE4, 0x98, 0x67, 0xAA, 0xF6,
+0x14, 0x4B, 0x04, 0xD4, 0xFC, 0x65, 0x07, 0x97,
+0x00, 0x6C, 0x06, 0x90, 0x80, 0xDF, 0x44, 0x37,
+0xFD, 0xE6, 0x80, 0xC8, 0xC5, 0xF2, 0x08, 0x4F,
+0x30, 0xF0, 0x20, 0x6C, 0xE4, 0x37, 0x86, 0xF2,
+0x00, 0x4C, 0xF1, 0xE4, 0x04, 0x4C, 0x08, 0xD4,
+0x04, 0x94, 0x00, 0x6F, 0x05, 0xD4, 0x44, 0x31,
+0x08, 0x90, 0xC5, 0xE1, 0x24, 0x31, 0x01, 0x6C,
+0x25, 0xE7, 0x80, 0xC0, 0x50, 0xF5, 0x0B, 0x41,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF5, 0x03, 0x49,
+0x86, 0xF2, 0x00, 0x4C, 0x10, 0x30, 0x30, 0x31,
+0x01, 0xE4, 0x25, 0xE4, 0x04, 0x48, 0x04, 0x49,
+0x0A, 0xD2, 0x05, 0x92, 0x00, 0x6C, 0x80, 0xC8,
+0x02, 0x48, 0x4A, 0xE8, 0x80, 0xC9, 0x02, 0x49,
+0xF8, 0x61, 0x08, 0x90, 0x01, 0x4F, 0x02, 0x77,
+0x01, 0x48, 0x08, 0xD0, 0x05, 0x90, 0x0A, 0x92,
+0x10, 0x48, 0x05, 0xD0, 0xD8, 0x61, 0x80, 0xC3,
+0x81, 0xC3, 0x82, 0xC3, 0x06, 0x97, 0x07, 0x94,
+0x04, 0x90, 0x01, 0x4E, 0x04, 0x4C, 0x02, 0x4F,
+0x20, 0x48, 0x02, 0x76, 0x07, 0xD4, 0x06, 0xD7,
+0x03, 0x4B, 0x04, 0xD0, 0xB4, 0x61, 0x01, 0x4A,
+0x9F, 0x67, 0x02, 0x6B, 0x40, 0x4C, 0x4E, 0xEB,
+0x04, 0x4D, 0x1C, 0x65, 0x90, 0x2B, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0xCC, 0x9A, 0x01, 0x6D,
+0x03, 0xF3, 0x10, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x86, 0x36, 0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90,
+0x08, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x40, 0x9A, 0xFF, 0x69, 0x04, 0x67,
+0x2C, 0xE8, 0x04, 0x36, 0xAC, 0xE9, 0x01, 0x6D,
+0x4D, 0xEE, 0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x6A, 0xF5, 0x7C, 0xA2,
+0x03, 0x23, 0x01, 0x73, 0x37, 0x60, 0x78, 0x10,
+0x03, 0x21, 0x12, 0x6B, 0x8A, 0xF5, 0x67, 0xC2,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF0, 0xC7, 0xA2,
+0xC3, 0xF3, 0x0C, 0x6C, 0xFF, 0x6D, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xB0, 0x9A, 0x23, 0xF3, 0x08, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0xD4, 0x9A, 0x01, 0x69, 0x2B, 0xE9,
+0xB1, 0x67, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xD8, 0x9A, 0xB1, 0x67, 0x23, 0xF3, 0x04, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x3C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x61, 0xF1,
+0xE0, 0x9A, 0x37, 0x10, 0x05, 0x21, 0x12, 0x6B,
+0x01, 0x20, 0x09, 0x6B, 0x8A, 0xF5, 0x67, 0xC2,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF0, 0xC7, 0xA2,
+0xC3, 0xF3, 0x0C, 0x6C, 0xFF, 0x6D, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xB0, 0x9A, 0x23, 0xF3, 0x08, 0x6C, 0x80, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF1, 0xC8, 0x9A, 0x01, 0x69, 0x2B, 0xE9,
+0xB1, 0x67, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0xCC, 0x9A, 0xB1, 0x67, 0x23, 0xF3, 0x04, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x3C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF1, 0xF0, 0x9A, 0x90, 0x67, 0x56, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF1, 0xE4, 0x9A, 0x90, 0x67,
+0x8F, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0xC5, 0x37,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x40, 0x9A, 0xFF, 0x68, 0x8C, 0xE8,
+0x01, 0x69, 0x2B, 0xE9, 0x04, 0x36, 0x4D, 0xEE,
+0x03, 0xF3, 0x00, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x21, 0x6A, 0xF0, 0xF7,
+0x5C, 0xA2, 0x03, 0x22, 0x01, 0x72, 0x37, 0x60,
+0x6D, 0x10, 0xC3, 0xF3, 0x0C, 0x6C, 0xFF, 0x6D,
+0x09, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0xB0, 0x9A, 0x23, 0xF3,
+0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0xD4, 0x9A,
+0xB1, 0x67, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0xD4, 0x9A, 0xB1, 0x67, 0x23, 0xF3, 0x04, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x3C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF1, 0xE0, 0x9A, 0x90, 0x67, 0x56, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0x61, 0xF1, 0xF8, 0x9A, 0x35, 0x10, 0xC3, 0xF3,
+0x0C, 0x6C, 0xFF, 0x6D, 0x09, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xB0, 0x9A, 0x23, 0xF3, 0x08, 0x6C, 0x80, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF1, 0xC8, 0x9A, 0xB1, 0x67, 0x23, 0xF3,
+0x00, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF1, 0xDC, 0x9A, 0xB1, 0x67,
+0x23, 0xF3, 0x04, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x3C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1, 0xE0, 0x9A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1,
+0xE0, 0x9A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0xC5, 0x37, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x40, 0x9A,
+0xFF, 0x68, 0x8C, 0xE8, 0x01, 0x69, 0x2B, 0xE9,
+0x04, 0x36, 0x4D, 0xEE, 0x03, 0xF3, 0x00, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x86, 0x36, 0xC3, 0xF3,
+0x0C, 0x6C, 0xB1, 0x67, 0x09, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1,
+0xC4, 0x9A, 0x23, 0xF3, 0x00, 0x6C, 0xB1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x21, 0x6A,
+0xF0, 0xF7, 0x5C, 0xA2, 0x03, 0x22, 0x01, 0x72,
+0x1F, 0x60, 0x3D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x3C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0xE8, 0x9A, 0x90, 0x67, 0x56, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF1, 0xE0, 0x9A, 0x90, 0x67,
+0x8F, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0xC5, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0x23, 0xF3, 0x08, 0x6C,
+0x41, 0xF1, 0xB0, 0x9A, 0x00, 0x6E, 0x1D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x3C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0xEC, 0x9A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0xE4, 0x9A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0xB0, 0x9A, 0x23, 0xF3, 0x08, 0x6C,
+0x80, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x40, 0x9A,
+0xFF, 0x68, 0x8C, 0xE8, 0x01, 0x69, 0x2B, 0xE9,
+0x04, 0x36, 0x4D, 0xEE, 0xB1, 0x67, 0x03, 0xF3,
+0x00, 0x6C, 0x00, 0x18, 0x86, 0x36, 0xB1, 0x67,
+0xC3, 0xF3, 0x0C, 0x6C, 0x09, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x30, 0x9A, 0x23, 0xF3, 0x00, 0x6C, 0x00, 0x6E,
+0xB1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x21, 0x6A, 0xF0, 0xF7, 0x5C, 0xA2, 0x03, 0x22,
+0x01, 0x72, 0x28, 0x60, 0x4F, 0x10, 0xB1, 0x67,
+0x23, 0xF3, 0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x3C, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1,
+0xE8, 0x9A, 0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0xE0, 0x9A, 0x90, 0x67, 0x8F, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x90, 0x67,
+0xEF, 0x6D, 0x10, 0x6E, 0x01, 0x6F, 0x00, 0x18,
+0xC5, 0x37, 0x90, 0x67, 0x33, 0x6D, 0x03, 0x6E,
+0x00, 0x6F, 0x26, 0x10, 0xB1, 0x67, 0x23, 0xF3,
+0x08, 0x6C, 0x80, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x3C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0xF0, 0x9A,
+0x90, 0x67, 0x56, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0xE4, 0x9A, 0x90, 0x67, 0x8F, 0x6D, 0xD1, 0x67,
+0x00, 0x18, 0xC5, 0x37, 0x90, 0x67, 0xEF, 0x6D,
+0x10, 0x6E, 0x01, 0x6F, 0x00, 0x18, 0xC5, 0x37,
+0x90, 0x67, 0x33, 0x6D, 0x03, 0x6E, 0x01, 0x6F,
+0x00, 0x18, 0xC5, 0x37, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF6, 0x63, 0x13, 0x62, 0x12, 0xD1, 0x11, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x4C, 0xED, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF3, 0x04, 0x4A, 0x64, 0x67,
+0x04, 0xD2, 0x62, 0xF5, 0x04, 0x4B, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x68, 0x33,
+0x6D, 0xE2, 0x04, 0x4B, 0x05, 0xD3, 0x64, 0x67,
+0xC1, 0xF2, 0x19, 0x4B, 0x6C, 0x33, 0x69, 0xE2,
+0x04, 0x4A, 0x0C, 0xD4, 0x0E, 0xD5, 0x07, 0xD2,
+0x00, 0x69, 0x0E, 0x93, 0x10, 0x2B, 0x91, 0x67,
+0xDF, 0x6D, 0x10, 0x6E, 0x01, 0x6F, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xDC, 0x9A, 0x07, 0x92, 0x91, 0x67, 0x58, 0x6D,
+0xE0, 0x9A, 0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x40, 0x9A, 0x24, 0x33,
+0x00, 0x68, 0x4D, 0xEB, 0x0B, 0xD3, 0x0B, 0x96,
+0x01, 0x6D, 0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6D, 0x23, 0xF3,
+0x0C, 0x6C, 0xAB, 0xED, 0x07, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x04, 0x4A, 0xC0, 0x9A, 0x01, 0x6D, 0x23, 0xF3,
+0x18, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x04, 0x4B,
+0xC0, 0x9B, 0x01, 0x6D, 0x23, 0xF3, 0x1C, 0x6C,
+0xAB, 0xED, 0x00, 0x18, 0x86, 0x36, 0x01, 0x6D,
+0xC3, 0xF3, 0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0xFF, 0x6A, 0x0C, 0xEA,
+0x06, 0x2A, 0x03, 0xF3, 0x0C, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x03, 0x6E, 0x05, 0x10, 0x03, 0xF3,
+0x0C, 0x6C, 0x06, 0xF0, 0x00, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0xB4, 0x9A, 0xC3, 0xF3, 0x14, 0x6C,
+0x10, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x0C, 0x95,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0x58, 0x9A,
+0xA4, 0x34, 0x31, 0xE4, 0x84, 0x34, 0x91, 0xE0,
+0x50, 0xF5, 0xAB, 0x44, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF5, 0x03, 0x4C, 0x86, 0xF2, 0x00, 0x4B,
+0xB0, 0x35, 0x90, 0x34, 0xB5, 0xE3, 0x8D, 0xE3,
+0x46, 0xE8, 0x04, 0x4D, 0x04, 0x4B, 0x0A, 0xD5,
+0x09, 0xD3, 0xA3, 0x42, 0x61, 0x42, 0x23, 0x4A,
+0x06, 0xD5, 0x08, 0xD3, 0x0D, 0xD2, 0x0A, 0x95,
+0x06, 0x92, 0xC3, 0xF3, 0x18, 0x6C, 0xC0, 0xAD,
+0x01, 0x6D, 0xAB, 0xED, 0xC0, 0x36, 0xC4, 0x36,
+0xD9, 0xE2, 0x00, 0x18, 0x86, 0x36, 0x09, 0x93,
+0x08, 0x92, 0x01, 0x6D, 0xC0, 0xAB, 0xAB, 0xED,
+0xC3, 0xF3, 0x18, 0x6C, 0xC0, 0x36, 0xC4, 0x36,
+0xD9, 0xE2, 0x00, 0x18, 0x86, 0x36, 0x0A, 0x93,
+0x09, 0x92, 0x06, 0x95, 0x02, 0x4B, 0x02, 0x4A,
+0x0A, 0xD3, 0x09, 0xD2, 0x08, 0x93, 0x0D, 0x92,
+0x04, 0x4D, 0x04, 0x4B, 0x4A, 0xED, 0x06, 0xD5,
+0x08, 0xD3, 0xD9, 0x61, 0xFF, 0x6A, 0x0C, 0xEA,
+0x06, 0x2A, 0x04, 0x95, 0x05, 0x93, 0x80, 0xAD,
+0xC0, 0xA3, 0x01, 0x6D, 0x06, 0x10, 0x05, 0x92,
+0x04, 0x93, 0x00, 0xF4, 0x00, 0x6D, 0xC1, 0xA2,
+0x80, 0xAB, 0xCF, 0xEE, 0x01, 0x48, 0x00, 0x18,
+0x86, 0x36, 0x02, 0x70, 0x5F, 0xF7, 0x1F, 0x61,
+0x01, 0x6D, 0xC3, 0xF3, 0x18, 0x6C, 0xAB, 0xED,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x06, 0xF0,
+0x00, 0x6D, 0x03, 0xF3, 0x0C, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x04, 0x95, 0x05, 0x92,
+0x07, 0x93, 0x01, 0x49, 0x02, 0x4D, 0x02, 0x4A,
+0x04, 0x4B, 0x02, 0x71, 0x04, 0xD5, 0x05, 0xD2,
+0x07, 0xD3, 0x3F, 0xF7, 0x0A, 0x61, 0x13, 0x97,
+0x12, 0x91, 0x11, 0x90, 0x0A, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x4C, 0xEC, 0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B, 0xEA, 0xF6,
+0x6C, 0xC2, 0x21, 0x2C, 0x6A, 0xF5, 0x7E, 0xA2,
+0x1E, 0x23, 0x8A, 0xF5, 0x60, 0x9A, 0xAA, 0xF5,
+0x8C, 0x9A, 0x00, 0x68, 0x6E, 0xEC, 0x05, 0x24,
+0xAA, 0xF5, 0x50, 0x9A, 0x4E, 0xEB, 0x13, 0x2B,
+0x01, 0x68, 0x01, 0x6B, 0x30, 0xF0, 0x21, 0x6A,
+0x90, 0x67, 0x71, 0xF1, 0x6C, 0xC2, 0x00, 0x18,
+0x76, 0x5A, 0x90, 0x67, 0x00, 0x18, 0x63, 0x58,
+0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF1, 0x00, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0,
+0x21, 0x6A, 0x71, 0xF1, 0x4C, 0xA2, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF0, 0x4D, 0xA2, 0x05, 0x22, 0x00, 0x6C,
+0x01, 0x6D, 0x00, 0x18, 0xF4, 0x5A, 0x04, 0x10,
+0x00, 0x6C, 0x01, 0x6D, 0x00, 0x18, 0x76, 0x5A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x9A, 0x00, 0x6C,
+0xB8, 0x6D, 0xD0, 0x67, 0x01, 0xF2, 0x00, 0x6F,
+0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0xFC, 0x9A, 0xD0, 0x67, 0x00, 0x6C,
+0xB8, 0x6D, 0x00, 0x18, 0xC5, 0x37, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0xC0, 0x9A,
+0x01, 0x68, 0x0B, 0xE8, 0xB0, 0x67, 0x03, 0xF3,
+0x00, 0x6C, 0x00, 0x18, 0x86, 0x36, 0xB0, 0x67,
+0xA3, 0xF3, 0x18, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x00, 0x68, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x3C, 0x9A, 0x90, 0x67, 0xDF, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x4F, 0x36, 0x01, 0xF0,
+0x13, 0x6B, 0x6B, 0xEB, 0x4C, 0xEB, 0x01, 0xF0,
+0x02, 0x6F, 0x6D, 0xEF, 0x90, 0x67, 0xDF, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x90, 0x67,
+0x65, 0x6D, 0xD1, 0x67, 0x12, 0xF0, 0x00, 0x6F,
+0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0, 0x21, 0x6A,
+0xF0, 0xF7, 0x5C, 0xA2, 0x01, 0x72, 0x1E, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x0C, 0x4A,
+0xC0, 0x9A, 0x90, 0x67, 0xEF, 0x6D, 0x01, 0x6F,
+0x00, 0x18, 0xC5, 0x37, 0x90, 0x67, 0x33, 0x6D,
+0xD1, 0x67, 0x26, 0x6F, 0x00, 0x18, 0xC5, 0x37,
+0x90, 0x67, 0x3E, 0x6D, 0xD1, 0x67, 0x37, 0x6F,
+0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0x3F, 0x6D, 0xD1, 0x67, 0xA1, 0xF1,
+0xE0, 0x9A, 0x1D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x0C, 0x4A, 0xC0, 0x9A, 0x90, 0x67,
+0xEF, 0x6D, 0x01, 0x6F, 0x00, 0x18, 0xC5, 0x37,
+0x90, 0x67, 0x33, 0x6D, 0xD1, 0x67, 0x26, 0x6F,
+0x00, 0x18, 0xC5, 0x37, 0x90, 0x67, 0x3E, 0x6D,
+0xD1, 0x67, 0x37, 0x6F, 0x00, 0x18, 0xC5, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1, 0xE4, 0x9A,
+0x90, 0x67, 0x3F, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x0C, 0x4B, 0xC0, 0x9B, 0x90, 0x67, 0xEF, 0x6D,
+0x00, 0x6F, 0x01, 0x48, 0x00, 0x18, 0xC5, 0x37,
+0x02, 0x70, 0x94, 0x61, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x68, 0x8C, 0xE8, 0x00, 0x69, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x4A, 0xC0, 0x9A,
+0x90, 0x67, 0xEF, 0x6D, 0x00, 0x6F, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1,
+0x1C, 0x4B, 0xC0, 0x9B, 0x90, 0x67, 0x08, 0x6D,
+0x00, 0x6F, 0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x4A, 0xC0, 0x9A,
+0x90, 0x67, 0x08, 0x6D, 0x00, 0x18, 0x4F, 0x36,
+0x07, 0x22, 0x01, 0x49, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE9, 0x2E, 0xF5, 0x10, 0x71, 0xDB, 0x61,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0xDC, 0x9A,
+0x00, 0x6C, 0x18, 0x6D, 0x00, 0x18, 0x4F, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF4, 0x00, 0x6C,
+0x86, 0xF2, 0x00, 0x4B, 0x4C, 0xEC, 0x8A, 0xF5,
+0x40, 0xDB, 0x82, 0x32, 0x4A, 0x32, 0x02, 0x72,
+0x0A, 0x60, 0x03, 0x6C, 0x4E, 0xEC, 0x04, 0x24,
+0x01, 0x72, 0x02, 0x6A, 0x05, 0x60, 0x06, 0x10,
+0x6A, 0xF5, 0x9D, 0xC3, 0x03, 0x10, 0x01, 0x6A,
+0x6A, 0xF5, 0x5D, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x68, 0x9B, 0x8A, 0xF5, 0x80, 0x9A,
+0x8C, 0xEB, 0x62, 0x33, 0x62, 0x33, 0x6A, 0xF5,
+0x7C, 0xC2, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x00, 0x68, 0x25, 0x67, 0x04, 0xD4, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x4A, 0xA0, 0xA1,
+0xC0, 0x9A, 0x00, 0x6C, 0x01, 0x48, 0x00, 0x18,
+0x4F, 0x36, 0x04, 0x93, 0x01, 0x6C, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x4A,
+0xA0, 0xA1, 0xC0, 0x9A, 0x01, 0x49, 0x00, 0x18,
+0x4F, 0x36, 0x04, 0x93, 0x41, 0xDB, 0xFF, 0x6A,
+0x4C, 0xE8, 0x08, 0x4B, 0x05, 0x70, 0x04, 0xD3,
+0xE2, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x00, 0x6B, 0x0B, 0xD7,
+0xE0, 0xAE, 0x1F, 0xF7, 0x00, 0x6A, 0xEC, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x08, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xAE, 0x41, 0xF0,
+0x58, 0x9A, 0x49, 0xE7, 0xE0, 0xA2, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x5D, 0xE7, 0xE0, 0xA7, 0xFF, 0x6A, 0xEC, 0xEA,
+0x7D, 0xE4, 0x01, 0x4B, 0x03, 0x73, 0x40, 0xC7,
+0x02, 0x4E, 0xE2, 0x61, 0x25, 0x67, 0x00, 0x68,
+0x0B, 0x93, 0x01, 0x6D, 0xAB, 0xED, 0x09, 0xE3,
+0x80, 0xAA, 0x02, 0x48, 0x00, 0x18, 0x78, 0x36,
+0x1E, 0x70, 0x40, 0xD9, 0x04, 0x49, 0xF4, 0x61,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xFF, 0x68, 0x24, 0x67, 0x41, 0xF1, 0x40, 0x9A,
+0x0C, 0xE9, 0xAC, 0xE8, 0x04, 0x36, 0x01, 0x6D,
+0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED, 0x4D, 0xEE,
+0x00, 0x18, 0x86, 0x36, 0x06, 0x29, 0x03, 0xF3,
+0x0C, 0x6C, 0x06, 0xF0, 0x00, 0x6D, 0x03, 0x6E,
+0x05, 0x10, 0x03, 0xF3, 0x0C, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0xB4, 0x9A,
+0x04, 0x30, 0x01, 0xE1, 0xC3, 0xF3, 0x14, 0x6C,
+0x10, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x50, 0xF5,
+0x2B, 0x40, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x03, 0x48, 0x86, 0xF2, 0x00, 0x4A, 0x10, 0x30,
+0x30, 0x31, 0x25, 0xE2, 0x09, 0xE2, 0x04, 0x4A,
+0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x08, 0x9A, 0x04, 0x49, 0x01, 0x6D, 0xD0, 0x67,
+0xC3, 0xF3, 0x18, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x86, 0x36, 0x01, 0x6D, 0xE3, 0xF3, 0x1C, 0x6C,
+0xAB, 0xED, 0x00, 0x18, 0x78, 0x36, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF1, 0x6C, 0x9B, 0x04, 0x48,
+0x4C, 0xEB, 0x62, 0x33, 0x62, 0x33, 0x60, 0xC9,
+0xE1, 0xF7, 0x1F, 0x6B, 0x4C, 0xEB, 0x04, 0x92,
+0x02, 0x49, 0x60, 0xCA, 0x02, 0x4A, 0x04, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1, 0x50, 0x9A,
+0x0E, 0xEA, 0xDC, 0x2A, 0x01, 0x6D, 0xC3, 0xF3,
+0x18, 0x6C, 0xAB, 0xED, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x03, 0xF3, 0x0C, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x05, 0x67, 0x01, 0x74, 0x4C, 0xE8, 0x80, 0xF0,
+0x1D, 0x60, 0x04, 0x24, 0x04, 0x5C, 0xA0, 0xF0,
+0x10, 0x60, 0xAA, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xAA, 0xF5, 0x6C, 0x9A,
+0x30, 0xF0, 0x21, 0x6C, 0x30, 0xF0, 0x21, 0x6D,
+0xAA, 0xF5, 0x70, 0xDA, 0x30, 0xF0, 0x21, 0x6B,
+0x30, 0xF0, 0x21, 0x6A, 0x51, 0xF1, 0x0C, 0x4C,
+0x51, 0xF1, 0x1C, 0x4B, 0x51, 0xF1, 0x08, 0x4A,
+0x51, 0xF0, 0x04, 0x4D, 0x00, 0x69, 0xC0, 0x9C,
+0xC5, 0xF2, 0x08, 0x41, 0x04, 0x30, 0xC2, 0xDC,
+0xC0, 0xAB, 0x05, 0xD5, 0xE5, 0x67, 0xC2, 0xCB,
+0xC0, 0xA2, 0xC2, 0xC2, 0x30, 0xF0, 0x20, 0x6E,
+0x86, 0xF2, 0x00, 0x4E, 0x01, 0xE6, 0x00, 0x6E,
+0x04, 0x48, 0x04, 0xD6, 0xA0, 0xA0, 0x24, 0x36,
+0xA4, 0xC0, 0x04, 0x95, 0xD9, 0xE5, 0xA6, 0x67,
+0x40, 0xF5, 0x1B, 0x4D, 0xB0, 0x35, 0x06, 0xD5,
+0x09, 0xD6, 0x30, 0xF0, 0x20, 0x6E, 0xA6, 0x67,
+0x06, 0x96, 0x86, 0xF2, 0x00, 0x4D, 0x1D, 0x65,
+0xD5, 0xE5, 0x09, 0x96, 0x04, 0x4D, 0x08, 0xD5,
+0x60, 0xF5, 0x03, 0x4E, 0xD0, 0x36, 0xB8, 0x67,
+0xD5, 0xE5, 0xC5, 0x67, 0x08, 0x95, 0x04, 0x4E,
+0x06, 0xD2, 0x40, 0xAD, 0x40, 0xF0, 0x40, 0xCD,
+0x40, 0xAE, 0x02, 0x4D, 0x40, 0xF0, 0x40, 0xCE,
+0x05, 0x92, 0x02, 0x4E, 0x4A, 0xED, 0xF5, 0x61,
+0x04, 0x95, 0x05, 0x96, 0x06, 0x92, 0x01, 0x4D,
+0x10, 0x4E, 0x02, 0x75, 0x04, 0xD5, 0x01, 0x48,
+0x05, 0xD6, 0xCC, 0x61, 0x01, 0x49, 0x02, 0x6E,
+0xA7, 0x67, 0x2E, 0xEE, 0x04, 0x4C, 0x02, 0x4B,
+0x01, 0x4A, 0x20, 0x4D, 0xB0, 0x2E, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B,
+0xCA, 0xF6, 0x60, 0xC2, 0xCA, 0xF6, 0x61, 0xC2,
+0xAA, 0xF6, 0x74, 0xC2, 0xAA, 0xF6, 0x75, 0xC2,
+0xAA, 0xF6, 0x76, 0xC2, 0xCA, 0xF6, 0x69, 0xC2,
+0xCA, 0xF6, 0x62, 0xC2, 0xCA, 0xF6, 0x63, 0xC2,
+0xAA, 0xF6, 0x77, 0xC2, 0xAA, 0xF6, 0x78, 0xC2,
+0xAA, 0xF6, 0x79, 0xC2, 0x8A, 0xF5, 0x60, 0x9A,
+0x01, 0x6C, 0xCA, 0xF6, 0xC8, 0xC2, 0xCA, 0xF6,
+0xDC, 0xCA, 0x8A, 0xF5, 0x94, 0xC2, 0x8A, 0xF5,
+0x95, 0xC2, 0xCA, 0xF6, 0xDE, 0xCA, 0x8A, 0xF5,
+0x96, 0xC2, 0x8A, 0xF5, 0x97, 0xC2, 0xAA, 0xF5,
+0x6C, 0xDA, 0x17, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0xDC, 0x9A, 0x90, 0x67, 0x58, 0x6D,
+0x00, 0x18, 0x4F, 0x36, 0xA2, 0xF5, 0x12, 0x48,
+0x30, 0xF0, 0x20, 0x6B, 0x08, 0x30, 0x86, 0xF2,
+0x00, 0x4B, 0x6D, 0xE0, 0x41, 0xDB, 0x05, 0x10,
+0xFE, 0x4C, 0x4C, 0xEC, 0xB0, 0x67, 0x00, 0x18,
+0xD1, 0x5B, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF0, 0x4D, 0xA2,
+0x18, 0x2A, 0x01, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x0D, 0x5C, 0x02, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x0D, 0x5C, 0x03, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x0D, 0x5C, 0x01, 0x6C, 0xA4, 0x67, 0x00, 0x18,
+0x0D, 0x5C, 0x02, 0x6C, 0x01, 0x6D, 0x00, 0x18,
+0x0D, 0x5C, 0x03, 0x6C, 0x01, 0x6D, 0x00, 0x18,
+0x0D, 0x5C, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x00, 0x6A, 0x7D, 0x67, 0x4C, 0xCB, 0x2E, 0xF5,
+0x10, 0x6A, 0xFF, 0x68, 0x04, 0xD2, 0x06, 0x02,
+0x0C, 0xEC, 0x05, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x08, 0xD4, 0x41, 0xF1, 0xDC, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x08, 0x94, 0xA1, 0xF1, 0xF4, 0x9A,
+0x0C, 0xED, 0x09, 0xD5, 0x08, 0x6D, 0x00, 0x18,
+0x60, 0x36, 0x0E, 0x22, 0x09, 0x92, 0x00, 0x69,
+0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0xB0, 0x9A, 0x03, 0xF3, 0x08, 0x6C, 0x00, 0x18,
+0x78, 0x36, 0x22, 0x67, 0x0C, 0xE9, 0x07, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF1, 0x04, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x01, 0x69, 0x08, 0x94,
+0x00, 0x18, 0x6C, 0x5B, 0x7D, 0x67, 0xAC, 0xAB,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF1, 0x14, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x51, 0x67, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x24, 0x67, 0x4C, 0xED, 0x4C, 0xE9,
+0x05, 0xD5, 0x0F, 0x2D, 0x30, 0xF0, 0x21, 0x6A,
+0xF0, 0xF7, 0x1D, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x40, 0x9A, 0x04, 0x48, 0x00, 0x30,
+0x4D, 0xE8, 0x64, 0x41, 0x01, 0x6A, 0x44, 0xEB,
+0x10, 0x10, 0x05, 0x92, 0x01, 0x72, 0x17, 0x61,
+0x30, 0xF0, 0x21, 0x6A, 0xF0, 0xF7, 0x5D, 0xA2,
+0x02, 0x72, 0x09, 0x61, 0x44, 0x41, 0x01, 0x68,
+0x04, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x58, 0x9A, 0x4D, 0xE8, 0x3E, 0x10, 0x44, 0x41,
+0x01, 0x68, 0x04, 0xEA, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF1, 0x5C, 0x9A, 0xF6, 0x17, 0x05, 0x93,
+0x00, 0x68, 0x02, 0x73, 0x32, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x6A, 0xF5,
+0x1D, 0xA2, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x40, 0x9A, 0x09, 0x48, 0x84, 0x41,
+0x00, 0x30, 0x01, 0x6B, 0x24, 0x36, 0x01, 0x6D,
+0x64, 0xEC, 0x4D, 0xE8, 0x4D, 0xEE, 0x03, 0xF3,
+0x00, 0x6C, 0xAB, 0xED, 0x6D, 0xE8, 0x00, 0x18,
+0x86, 0x36, 0x01, 0x6D, 0x23, 0xF3, 0x04, 0x6C,
+0xAB, 0xED, 0x00, 0x18, 0x78, 0x36, 0x03, 0xF4,
+0x01, 0x6B, 0x6B, 0xEB, 0x4C, 0xEB, 0x04, 0x92,
+0x01, 0x6D, 0x23, 0xF3, 0x04, 0x6C, 0x8A, 0xF5,
+0xC8, 0x9A, 0x07, 0x6A, 0xAB, 0xED, 0x4C, 0xEE,
+0xC0, 0x36, 0xC8, 0x36, 0x6D, 0xEE, 0x00, 0x18,
+0x86, 0x36, 0x01, 0x6D, 0xD0, 0x67, 0x03, 0xF3,
+0x00, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x01, 0x6D, 0xC1, 0x40, 0xAB, 0xED, 0x03, 0xF3,
+0x00, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x02, 0x6C,
+0x00, 0x18, 0x8D, 0x20, 0x91, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0x80, 0x5C, 0x02, 0x67, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0xC0, 0x9A, 0x24, 0x33,
+0x01, 0x6D, 0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED,
+0x6D, 0xEE, 0x04, 0xD3, 0x00, 0x18, 0x86, 0x36,
+0x05, 0x92, 0x12, 0x2A, 0x0C, 0x20, 0x04, 0x93,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF3, 0x04, 0x4A,
+0x49, 0xE3, 0x80, 0xAA, 0x01, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x3D, 0x10, 0x02, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x0D, 0x5C, 0x38, 0x10,
+0x05, 0x92, 0x02, 0x72, 0x55, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0xDC, 0x9A, 0x91, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x4F, 0x36, 0x30, 0xF0,
+0x20, 0x6B, 0x65, 0xF3, 0x8C, 0x41, 0x86, 0xF2,
+0x00, 0x4B, 0x84, 0x34, 0x71, 0xE4, 0x8A, 0xF5,
+0x67, 0xA3, 0xFF, 0x6D, 0x56, 0x32, 0xAC, 0xEA,
+0x60, 0x33, 0x6D, 0xEA, 0x42, 0xCC, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xC4, 0x9A, 0x80, 0x4D,
+0x23, 0xF3, 0x18, 0x6C, 0x80, 0x4D, 0x00, 0x18,
+0x86, 0x36, 0x0D, 0x20, 0x04, 0x93, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF3, 0x04, 0x4A, 0x49, 0xE3,
+0x80, 0xAA, 0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x25, 0x10, 0x03, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x0D, 0x5C, 0x20, 0x10,
+0x0A, 0x28, 0x30, 0xF0, 0x20, 0x6A, 0x24, 0x33,
+0x40, 0xF3, 0x04, 0x4A, 0x49, 0xE3, 0x01, 0x6D,
+0x80, 0xAA, 0xC5, 0x67, 0x09, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0x33, 0x40, 0xF3, 0x04, 0x4A,
+0x49, 0xE3, 0x80, 0xAA, 0x01, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0xC5, 0xF2, 0x08, 0x49,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0x31, 0x86, 0xF2,
+0x00, 0x4A, 0x49, 0xE1, 0x04, 0xC2, 0x08, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0x31, 0x86, 0xF2,
+0x00, 0x4A, 0x49, 0xE1, 0x8A, 0xF5, 0x15, 0xC2,
+0x50, 0x67, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x44, 0x41, 0x01, 0x68, 0x04, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x40, 0x9A, 0x01, 0x6D,
+0x03, 0xF3, 0x00, 0x6C, 0x4D, 0xE8, 0xD0, 0x67,
+0xAB, 0xED, 0x00, 0x18, 0x86, 0x36, 0x01, 0x6D,
+0xC1, 0x40, 0xAB, 0xED, 0x03, 0xF3, 0x00, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6C, 0x00, 0x18,
+0x8D, 0x20, 0x91, 0x67, 0x00, 0x6D, 0x00, 0x18,
+0x80, 0x5C, 0x02, 0x67, 0x04, 0x2A, 0x01, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x0D, 0x5C, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF1, 0x0C, 0x4C, 0x00, 0x6D,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x45, 0xE1, 0x8A, 0xF5,
+0x0E, 0xC1, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x4C, 0xED, 0x30, 0xF0,
+0x21, 0x6A, 0x11, 0xF0, 0x47, 0xA2, 0x04, 0xD4,
+0x05, 0xD5, 0x09, 0x72, 0x00, 0x68, 0x0C, 0x60,
+0x12, 0x72, 0x01, 0x68, 0x09, 0x60, 0x1B, 0x72,
+0x02, 0x68, 0x06, 0x60, 0x24, 0x68, 0x4E, 0xE8,
+0x01, 0x58, 0x18, 0x67, 0x04, 0x6A, 0x03, 0xE2,
+0x04, 0x92, 0x01, 0x69, 0x2B, 0xE9, 0x44, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x40, 0x9A,
+0x03, 0xF3, 0x00, 0x6C, 0xB1, 0x67, 0x4D, 0xEE,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF0, 0xC7, 0xA2, 0xC3, 0xF3, 0x0C, 0x6C,
+0xB1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x05, 0x93,
+0x01, 0x73, 0x09, 0x61, 0x04, 0x92, 0x01, 0x69,
+0x04, 0x4A, 0x24, 0xEA, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x40, 0x9A, 0x08, 0x10, 0x04, 0x92,
+0x01, 0x69, 0x04, 0x4A, 0x24, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF1, 0x44, 0x9A, 0x4D, 0xE9,
+0x01, 0x6D, 0x03, 0xF3, 0x00, 0x6C, 0xAB, 0xED,
+0xD1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x01, 0x6D,
+0xAB, 0xED, 0xC1, 0x41, 0x03, 0xF3, 0x00, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6C, 0x00, 0x18,
+0x8D, 0x20, 0x04, 0x94, 0x01, 0x6D, 0x00, 0x18,
+0x80, 0x5C, 0x05, 0x93, 0x02, 0x73, 0x6D, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x94, 0x41, 0xF1,
+0xDC, 0x9A, 0x00, 0x6D, 0x00, 0x18, 0x4F, 0x36,
+0xE3, 0xF7, 0x00, 0x6B, 0x4C, 0xEB, 0x76, 0x32,
+0x1F, 0x6D, 0x30, 0xF0, 0x20, 0x6B, 0x4C, 0xED,
+0x86, 0xF2, 0x00, 0x4B, 0x56, 0x34, 0x02, 0x5D,
+0x8A, 0xF5, 0x88, 0xDB, 0x0B, 0x60, 0x02, 0x24,
+0xFF, 0x4C, 0x13, 0x10, 0x03, 0x70, 0x01, 0x48,
+0x0A, 0x61, 0x01, 0x6A, 0xEA, 0xF6, 0x44, 0xC3,
+0x03, 0x68, 0x11, 0x10, 0x0A, 0x5D, 0x00, 0x6E,
+0x0F, 0x61, 0x04, 0x20, 0xFF, 0x48, 0xFF, 0x6A,
+0x4C, 0xE8, 0x09, 0x10, 0x07, 0x74, 0x04, 0x60,
+0x01, 0x4C, 0x8A, 0xF5, 0x88, 0xDB, 0x03, 0x10,
+0x01, 0x6A, 0xEA, 0xF6, 0x44, 0xC3, 0x01, 0x6E,
+0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2, 0x00, 0x49,
+0xEA, 0xF6, 0x64, 0xA1, 0x01, 0x6A, 0x4E, 0xEB,
+0x6B, 0xEA, 0x6D, 0xEA, 0xC0, 0xF7, 0x43, 0x32,
+0x4C, 0xEE, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF3,
+0x0C, 0x4A, 0x41, 0xE0, 0x40, 0xA0, 0x8A, 0xF5,
+0x47, 0xC1, 0x00, 0x6A, 0x22, 0x26, 0x04, 0x93,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x40, 0x9A,
+0x01, 0x68, 0x64, 0x36, 0x0B, 0xE8, 0x4D, 0xEE,
+0x03, 0xF3, 0x00, 0x6C, 0xB0, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x23, 0xF3, 0x04, 0x6C, 0xB0, 0x67,
+0x00, 0x18, 0x78, 0x36, 0x8A, 0xF5, 0xC8, 0x99,
+0x03, 0xF4, 0x01, 0x6B, 0x6B, 0xEB, 0xC0, 0x36,
+0x4C, 0xEB, 0xC8, 0x36, 0x23, 0xF3, 0x04, 0x6C,
+0xB0, 0x67, 0x6D, 0xEE, 0x00, 0x18, 0x86, 0x36,
+0x01, 0x6A, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x04, 0xD2, 0x8A, 0xF5,
+0x44, 0xA2, 0x02, 0x68, 0xFF, 0x69, 0x4E, 0xE8,
+0x8C, 0xE9, 0x24, 0x20, 0x03, 0x5A, 0x03, 0x60,
+0x01, 0x72, 0x07, 0x60, 0x04, 0x10, 0x03, 0x72,
+0x37, 0x60, 0x04, 0x72, 0x50, 0x60, 0x01, 0x6A,
+0x76, 0x10, 0x91, 0x67, 0x00, 0x18, 0xB9, 0x59,
+0x91, 0x67, 0x01, 0x6D, 0x00, 0x18, 0x44, 0x5D,
+0x65, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x55, 0xF3,
+0x8C, 0x41, 0x84, 0x34, 0x86, 0xF2, 0x00, 0x4B,
+0x71, 0xE4, 0xA8, 0xA4, 0x02, 0x5D, 0x03, 0x60,
+0x01, 0x4D, 0xA8, 0xC4, 0xED, 0x17, 0x65, 0xE1,
+0x00, 0x6C, 0x50, 0x10, 0x91, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0x6B, 0x59, 0x04, 0x93, 0xEA, 0xF6,
+0x04, 0xC3, 0x91, 0x67, 0x02, 0x6D, 0x00, 0x18,
+0x44, 0x5D, 0x48, 0x22, 0x30, 0xF0, 0x20, 0x6B,
+0x24, 0x34, 0x86, 0xF2, 0x00, 0x4B, 0x6D, 0xE4,
+0xCA, 0xF6, 0x81, 0xA3, 0x0A, 0x5C, 0x3E, 0x60,
+0x01, 0x4C, 0xCA, 0xF6, 0x81, 0xC3, 0xED, 0x17,
+0x91, 0x67, 0x00, 0x18, 0xB9, 0x59, 0x91, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0xA2, 0x5C, 0x32, 0x22,
+0x03, 0x6C, 0x98, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x12, 0xEC, 0x71, 0xE4,
+0xAA, 0xF6, 0xB5, 0xA4, 0x02, 0x5D, 0x04, 0x60,
+0x01, 0x4D, 0xAA, 0xF6, 0xB5, 0xC4, 0xEB, 0x17,
+0x65, 0xE1, 0x01, 0x6C, 0x1B, 0x10, 0x91, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x6B, 0x59, 0x91, 0x67,
+0x02, 0x6D, 0x00, 0x18, 0xA2, 0x5C, 0x16, 0x22,
+0x03, 0x6C, 0x98, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x12, 0xEC, 0x71, 0xE4,
+0xAA, 0xF6, 0xB6, 0xA4, 0x02, 0x5D, 0x04, 0x60,
+0x01, 0x4D, 0xAA, 0xF6, 0xB6, 0xC4, 0xEB, 0x17,
+0x65, 0xE1, 0x02, 0x6C, 0xCA, 0xF6, 0x88, 0xC1,
+0x05, 0x6C, 0x07, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x8A, 0xF5, 0x84, 0xA3,
+0x01, 0x4C, 0x8A, 0xF5, 0x84, 0xC3, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x21, 0x6A, 0xF0, 0xF7, 0x5D, 0xA2,
+0xFF, 0x69, 0x8C, 0xE9, 0x02, 0x72, 0x02, 0x6A,
+0x06, 0xD2, 0x02, 0x60, 0x04, 0x6B, 0x06, 0xD3,
+0x30, 0xF0, 0x21, 0x6A, 0x11, 0xF0, 0xA5, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF1, 0x00, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x21, 0x6A,
+0x11, 0xF0, 0x45, 0xA2, 0xFF, 0x6B, 0xFF, 0x4A,
+0x6C, 0xEA, 0x06, 0x5A, 0x74, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x48, 0x32, 0x20, 0xF3, 0x0C, 0x4B,
+0x4D, 0xE3, 0x40, 0x9B, 0x00, 0xEA, 0x00, 0x6C,
+0x00, 0x18, 0x36, 0x5A, 0x00, 0x6C, 0x04, 0x10,
+0x01, 0x6C, 0x00, 0x18, 0x36, 0x5A, 0x01, 0x6C,
+0x00, 0x18, 0x25, 0x5D, 0x32, 0x10, 0x00, 0x6C,
+0x00, 0x18, 0x00, 0x5A, 0x00, 0x6C, 0xA4, 0x67,
+0x00, 0x18, 0xA2, 0x5C, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x8A, 0xF5, 0x8C, 0xA3,
+0x01, 0x4C, 0x8A, 0xF5, 0x8C, 0xC3, 0x21, 0x22,
+0xAA, 0xF6, 0x54, 0xA3, 0x03, 0x5A, 0x1D, 0x60,
+0x01, 0x4A, 0xAA, 0xF6, 0x54, 0xC3, 0x47, 0x10,
+0x01, 0x6C, 0x00, 0x18, 0x00, 0x5A, 0x01, 0x6C,
+0x00, 0x6D, 0x00, 0x18, 0xA2, 0x5C, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x8A, 0xF5,
+0x8C, 0xA3, 0x01, 0x4C, 0x8A, 0xF5, 0x8C, 0xC3,
+0x08, 0x22, 0xAA, 0xF6, 0x57, 0xA3, 0x03, 0x5A,
+0x04, 0x60, 0x01, 0x4A, 0xAA, 0xF6, 0x57, 0xC3,
+0x2E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x8A, 0xF5, 0x65, 0xA2, 0x01, 0x4B,
+0x8A, 0xF5, 0x65, 0xC2, 0x24, 0x10, 0x00, 0x6C,
+0x00, 0x18, 0xAD, 0x5D, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x8A, 0xF5, 0x64, 0xA2,
+0x05, 0x73, 0xF5, 0x61, 0x0B, 0x10, 0x01, 0x6C,
+0x00, 0x18, 0xAD, 0x5D, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x8A, 0xF5, 0x64, 0xA2,
+0x05, 0x73, 0xF5, 0x61, 0x8A, 0xF5, 0x65, 0xA2,
+0x01, 0x4B, 0x8A, 0xF5, 0x65, 0xC2, 0x01, 0x6B,
+0x8A, 0xF5, 0x64, 0xC2, 0x8A, 0xF5, 0x6C, 0xA2,
+0x01, 0x4B, 0x8A, 0xF5, 0x6C, 0xC2, 0x30, 0xF0,
+0x20, 0x68, 0x86, 0xF2, 0x00, 0x48, 0x8A, 0xF5,
+0x45, 0xA0, 0x07, 0x72, 0x6D, 0x61, 0x8A, 0xF5,
+0xAE, 0xA0, 0x8A, 0xF5, 0xCF, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF1, 0x14, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x8A, 0xF5, 0xB4, 0xA0, 0x8A, 0xF5,
+0xD6, 0xA0, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF1,
+0x0C, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x8A, 0xF5,
+0xB5, 0xA0, 0x8A, 0xF5, 0xD7, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0xE2, 0xF1, 0x00, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0xAA, 0xF6, 0xB4, 0xA0, 0xAA, 0xF6,
+0xD7, 0xA0, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF2,
+0x14, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0xAA, 0xF6,
+0xB5, 0xA0, 0xAA, 0xF6, 0xD6, 0xA0, 0xAA, 0xF6,
+0xF8, 0xA0, 0xAA, 0xF6, 0x59, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF2, 0x0C, 0x4C, 0x04, 0xD2,
+0x00, 0x18, 0x4D, 0x63, 0xCA, 0xF6, 0xA1, 0xA0,
+0xCA, 0xF6, 0xC2, 0xA0, 0xCA, 0xF6, 0xE3, 0xA0,
+0xCA, 0xF6, 0x44, 0xA0, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0xF2, 0x10, 0x4C, 0x04, 0xD2, 0x00, 0x69,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x40, 0x9A, 0x01, 0x68, 0x0B, 0xE8,
+0x24, 0x36, 0x4D, 0xEE, 0x03, 0xF3, 0x00, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x23, 0xF3,
+0x0C, 0x6C, 0xB0, 0x67, 0x07, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0xC3, 0xF3, 0x0C, 0x6C, 0xB0, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xC4, 0x9A, 0x23, 0xF3,
+0x18, 0x6C, 0xB0, 0x67, 0x01, 0x49, 0x00, 0x18,
+0x86, 0x36, 0x02, 0x71, 0xDB, 0x61, 0x09, 0x10,
+0x01, 0x71, 0x1F, 0xF7, 0x0B, 0x61, 0x8A, 0xF5,
+0x4C, 0xA0, 0x06, 0x93, 0x6E, 0xEA, 0x1F, 0xF7,
+0x05, 0x2A, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xC0, 0x9A, 0x01, 0x68, 0x0B, 0xE8, 0xB0, 0x67,
+0x03, 0xF3, 0x00, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0xB0, 0x67, 0xA3, 0xF3, 0x18, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x3C, 0x9A, 0x00, 0x6C, 0x01, 0x6D,
+0xD1, 0x67, 0x00, 0x18, 0x4F, 0x36, 0x21, 0x68,
+0xE2, 0x67, 0x0D, 0xEF, 0xD1, 0x67, 0x00, 0x6C,
+0x01, 0x6D, 0x00, 0x18, 0xC5, 0x37, 0x01, 0x6C,
+0xA4, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x4F, 0x36,
+0xE2, 0x67, 0x01, 0x6C, 0xA4, 0x67, 0xD1, 0x67,
+0x0D, 0xEF, 0x00, 0x18, 0xC5, 0x37, 0x04, 0x94,
+0x00, 0x18, 0xF8, 0x5D, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x00, 0x6A, 0x7D, 0x67, 0x4C, 0xCB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x28, 0x9A, 0x00, 0x6C,
+0xA4, 0x67, 0xD0, 0x67, 0xF1, 0x67, 0x00, 0x18,
+0xC5, 0x37, 0xF1, 0x67, 0x01, 0x6C, 0x00, 0x6D,
+0xD0, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF1, 0xA8, 0x9A, 0xE1, 0xF0,
+0x18, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x01, 0x6D, 0xE1, 0xF0, 0x1C, 0x6C, 0xAB, 0xED,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x07, 0x6D,
+0xC5, 0x67, 0x83, 0xF1, 0x0C, 0x6C, 0x00, 0x18,
+0x86, 0x36, 0xA1, 0xF3, 0x18, 0x6F, 0x06, 0x02,
+0xA1, 0xF7, 0x00, 0x6C, 0x08, 0x6D, 0x00, 0x6E,
+0x04, 0xD2, 0x00, 0x18, 0x0B, 0x20, 0x01, 0xF0,
+0x08, 0x6C, 0xFF, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0xAC, 0x9A, 0x01, 0xF2, 0x04, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x64, 0x9A, 0xFF, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0xFE, 0x6C, 0x4C, 0xEC, 0x80, 0xC3,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x50, 0x9A, 0x60, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x09, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x78, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x54, 0x9A, 0x60, 0xDA, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x5F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF1, 0x1C, 0x4A, 0xC0, 0x9A,
+0x01, 0x68, 0x0B, 0xE8, 0x61, 0xF4, 0x00, 0x69,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF1, 0x00, 0x4B,
+0xC0, 0x9B, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x1C, 0x4A, 0xC0, 0x9A, 0x00, 0xF2, 0x00, 0x49,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF1, 0x00, 0x4B,
+0xC0, 0x9B, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0x24, 0x9A, 0xB0, 0x67, 0x41, 0xF4, 0x18, 0x6C,
+0xD1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF1, 0x08, 0x4A, 0xC0, 0x9A,
+0xB0, 0x67, 0x41, 0xF4, 0x1C, 0x6C, 0x00, 0x18,
+0x86, 0x36, 0xB0, 0x67, 0x61, 0xF4, 0x0C, 0x6C,
+0x01, 0xF2, 0x15, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xB0, 0x67, 0xD1, 0x67, 0x41, 0xF6, 0x18, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF1, 0x08, 0x4B, 0xC0, 0x9B, 0xB0, 0x67,
+0x41, 0xF6, 0x1C, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0x61, 0xF6, 0x0C, 0x6C, 0xB0, 0x67, 0x01, 0xF2,
+0x15, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x00, 0x18,
+0xA4, 0x5E, 0x5C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0x1C, 0x4A, 0xC0, 0x9A, 0x01, 0x68,
+0x0B, 0xE8, 0x61, 0xF4, 0x00, 0x69, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF1, 0x0C, 0x4B, 0xC0, 0x9B,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1, 0x1C, 0x4A,
+0xC0, 0x9A, 0x00, 0xF2, 0x00, 0x49, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF1, 0x0C, 0x4B, 0xC0, 0x9B,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0x30, 0x9A,
+0x41, 0xF4, 0x18, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF1, 0x14, 0x4A, 0xC0, 0x9A, 0x41, 0xF4,
+0x1C, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x61, 0xF4, 0x0C, 0x6C, 0xB0, 0x67, 0x22, 0xF2,
+0x0A, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x41, 0xF6,
+0x18, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF1,
+0x14, 0x4B, 0xC0, 0x9B, 0x41, 0xF6, 0x1C, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x61, 0xF6,
+0x0C, 0x6C, 0xB0, 0x67, 0x22, 0xF2, 0x0A, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0xA4, 0x9A, 0xA1, 0xF1, 0x04, 0x6C,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x00, 0x4A,
+0xC0, 0x9A, 0x01, 0x69, 0x03, 0xF3, 0x00, 0x68,
+0x2B, 0xE9, 0xB1, 0x67, 0x90, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0xD8, 0x9A,
+0xB1, 0x67, 0x90, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF1, 0xDC, 0x9A, 0xB1, 0x67,
+0x90, 0x67, 0x00, 0x18, 0x86, 0x36, 0x0A, 0x6C,
+0x00, 0x18, 0x95, 0x20, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF1, 0x00, 0x4B, 0xC0, 0x9B, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x0C, 0xD6, 0xFF, 0x68,
+0x41, 0xF1, 0xDC, 0x9A, 0xFF, 0xF7, 0x1F, 0x69,
+0x0C, 0x97, 0x8C, 0xE8, 0xAC, 0xE9, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0xC5, 0x37, 0x00, 0x6A,
+0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1,
+0x1C, 0x4B, 0xC0, 0x9B, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0x4F, 0x36, 0x0C, 0x93, 0x6E, 0xEA,
+0x13, 0x22, 0x0A, 0x6C, 0x00, 0x18, 0x95, 0x20,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x4A,
+0xC0, 0x9A, 0x0C, 0x97, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0xC5, 0x37, 0x04, 0x93, 0x01, 0x4B,
+0xE0, 0xF3, 0x08, 0x73, 0x04, 0xD3, 0xE1, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x00, 0x68, 0x0A, 0xD4,
+0x0B, 0xD5, 0x04, 0xD5, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0xDC, 0x9A, 0x90, 0x67, 0xEF, 0x6D,
+0x00, 0x6F, 0x00, 0x18, 0xC5, 0x37, 0x04, 0x93,
+0x11, 0x6E, 0xCB, 0xEE, 0x40, 0x9B, 0x90, 0x67,
+0xDF, 0x6D, 0x4C, 0xEE, 0x00, 0x18, 0x5E, 0x5F,
+0x0B, 0x93, 0x08, 0x32, 0x00, 0x69, 0x08, 0x4B,
+0x49, 0xE3, 0x05, 0xD2, 0x0A, 0x93, 0x90, 0x67,
+0x29, 0xE3, 0xA1, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0xDC, 0x9A, 0x05, 0x92, 0x01, 0x49,
+0xE0, 0x9A, 0x00, 0x18, 0xC5, 0x37, 0x05, 0x93,
+0x04, 0x71, 0x08, 0x4B, 0x05, 0xD3, 0xEE, 0x61,
+0x04, 0x92, 0x01, 0x48, 0x02, 0x70, 0x04, 0x4A,
+0x04, 0xD2, 0xD0, 0x61, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xEE, 0x63, 0x23, 0x62, 0x22, 0xD1, 0x21, 0xD0,
+0x28, 0xA4, 0x02, 0x6A, 0x01, 0x68, 0x2C, 0xEA,
+0x46, 0x32, 0x1E, 0xD2, 0x00, 0x18, 0x1B, 0x59,
+0x00, 0x18, 0x85, 0x5B, 0x91, 0x67, 0x0C, 0xEC,
+0x00, 0x6D, 0x00, 0x18, 0xF4, 0x5A, 0x22, 0x67,
+0x6D, 0x2A, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF3,
+0x10, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x6A, 0xF5,
+0x7E, 0xA2, 0x00, 0x6C, 0xA4, 0x67, 0x01, 0x4B,
+0x6A, 0xF5, 0x7E, 0xC2, 0x8A, 0xF5, 0x05, 0xC2,
+0x8A, 0xF5, 0x04, 0xC2, 0x8A, 0xF5, 0x2C, 0xC2,
+0x8A, 0xF5, 0x0D, 0xC2, 0x00, 0x18, 0x0D, 0x5C,
+0x30, 0xF0, 0x20, 0x6E, 0x30, 0xF0, 0x20, 0x6F,
+0x04, 0x04, 0x0F, 0x05, 0x20, 0xF1, 0x18, 0x4E,
+0x40, 0xF1, 0x00, 0x4F, 0x00, 0x18, 0xB5, 0x5B,
+0x30, 0xF0, 0x20, 0x6D, 0x05, 0x04, 0x60, 0xF1,
+0x00, 0x4D, 0x00, 0x18, 0xA0, 0x5B, 0x00, 0x18,
+0x17, 0x58, 0x01, 0x6C, 0x00, 0x18, 0xDA, 0x5E,
+0x00, 0x6C, 0x00, 0x18, 0xE3, 0x57, 0x00, 0x18,
+0x42, 0x5F, 0x00, 0x18, 0x28, 0x5B, 0x1E, 0x94,
+0x00, 0x18, 0x85, 0x5E, 0x00, 0x6C, 0x00, 0x18,
+0xDA, 0x5E, 0x30, 0xF0, 0x20, 0x6E, 0x30, 0xF0,
+0x20, 0x6F, 0x04, 0x04, 0x0F, 0x05, 0x20, 0xF1,
+0x18, 0x4E, 0x40, 0xF1, 0x00, 0x4F, 0x00, 0x18,
+0x47, 0x58, 0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF1,
+0x00, 0x4C, 0x05, 0x05, 0x00, 0x18, 0x7B, 0x5F,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x8A, 0xF5, 0x65, 0xA2, 0x07, 0x73, 0x07, 0x60,
+0x00, 0x6B, 0x8A, 0xF5, 0x6C, 0xC2, 0x32, 0x6C,
+0x00, 0x18, 0x8D, 0x20, 0xCC, 0x17, 0x1E, 0x92,
+0x04, 0x22, 0x00, 0x6C, 0x01, 0x6D, 0x00, 0x18,
+0xF4, 0x5A, 0x00, 0x6C, 0x00, 0x18, 0x63, 0x58,
+0x00, 0x18, 0x1A, 0x5B, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0xDC, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0xE0, 0x9A, 0x00, 0x6C, 0x08, 0x6D,
+0x00, 0x18, 0xC5, 0x37, 0x23, 0x97, 0x22, 0x91,
+0x21, 0x90, 0x00, 0x6A, 0x12, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x00, 0x6B,
+0xE6, 0xF3, 0x64, 0xC2, 0x30, 0xF0, 0x20, 0x6B,
+0x6C, 0xF6, 0x04, 0x4B, 0x06, 0xF4, 0x68, 0xDA,
+0x00, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF2,
+0x64, 0x9B, 0x54, 0x34, 0x3F, 0x68, 0x71, 0xE4,
+0xA0, 0xA4, 0xF8, 0x6B, 0x01, 0x4A, 0xAC, 0xEB,
+0x4E, 0xE8, 0x60, 0xC4, 0xF2, 0x28, 0x00, 0x18,
+0xF9, 0x56, 0x30, 0xF0, 0x20, 0x6A, 0x6C, 0xF6,
+0x19, 0xC2, 0x00, 0x18, 0x24, 0x57, 0x00, 0x18,
+0x94, 0x77, 0x30, 0xF0, 0x20, 0x6C, 0x4C, 0xF6,
+0x08, 0x4C, 0x00, 0x18, 0x8C, 0x66, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x01, 0xF2,
+0x64, 0x9B, 0x4C, 0xEC, 0x94, 0x34, 0x71, 0xE4,
+0xC0, 0xA4, 0xF8, 0x6B, 0x4C, 0xED, 0xCC, 0xEB,
+0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x2E, 0x6D, 0xB8, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x00, 0x6C, 0x12, 0xED,
+0x75, 0xE5, 0x26, 0xF6, 0x9D, 0xC5, 0x05, 0x6D,
+0xB8, 0xEA, 0x12, 0xED, 0x6D, 0xE5, 0x4A, 0xF4,
+0x82, 0xC3, 0x00, 0x6D, 0x82, 0x67, 0x00, 0x18,
+0xFE, 0x5F, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x6B, 0x6C, 0xEC, 0x2E, 0x6A, 0x58, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A,
+0x6C, 0xED, 0x12, 0xEC, 0x89, 0xE2, 0x53, 0xA2,
+0x78, 0x6C, 0x4C, 0xEC, 0x6C, 0xEC, 0x48, 0x74,
+0x02, 0x61, 0x4F, 0x5D, 0x24, 0x10, 0x40, 0x74,
+0x02, 0x61, 0x45, 0x5D, 0x20, 0x10, 0x38, 0x74,
+0x02, 0x61, 0x3B, 0x5D, 0x1C, 0x10, 0x30, 0x74,
+0x02, 0x61, 0x31, 0x5D, 0x18, 0x10, 0x28, 0x74,
+0x02, 0x61, 0x29, 0x5D, 0x14, 0x10, 0x20, 0x74,
+0x02, 0x61, 0x21, 0x5D, 0x10, 0x10, 0x18, 0x74,
+0x02, 0x61, 0x19, 0x5D, 0x0C, 0x10, 0x10, 0x74,
+0x02, 0x61, 0x11, 0x5D, 0x08, 0x10, 0x08, 0x74,
+0x02, 0x61, 0x0A, 0x5D, 0x04, 0x10, 0x00, 0x6A,
+0x1A, 0x65, 0x03, 0x2C, 0x03, 0x5D, 0x58, 0x67,
+0x01, 0x72, 0x58, 0x67, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x44, 0x9F, 0x08, 0x6B, 0xFF, 0x68, 0x6C, 0xEA,
+0x25, 0x67, 0x0A, 0xD6, 0x8C, 0xE8, 0x0F, 0x22,
+0x45, 0x9F, 0x05, 0x5A, 0x0C, 0x61, 0x05, 0x6A,
+0x58, 0xE8, 0xDB, 0xA6, 0x30, 0xF0, 0x20, 0x6C,
+0x22, 0xF3, 0x00, 0x4C, 0x12, 0xEA, 0x49, 0xE5,
+0xA4, 0xA2, 0x00, 0x18, 0x4D, 0x63, 0x05, 0x6A,
+0x58, 0xE8, 0x0A, 0x92, 0x7B, 0xA2, 0x45, 0x43,
+0x12, 0xE8, 0x05, 0xE1, 0x84, 0xA1, 0x82, 0xEA,
+0x01, 0x6A, 0x03, 0x61, 0x05, 0x4C, 0x62, 0xEC,
+0x58, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x7D, 0x67, 0xFF, 0x6A,
+0x18, 0xAB, 0x00, 0x6B, 0xAC, 0xEA, 0x83, 0x67,
+0xA6, 0x67, 0x06, 0x10, 0x01, 0x4B, 0x06, 0x73,
+0x06, 0x60, 0x20, 0x9D, 0x04, 0x4D, 0x31, 0xE4,
+0x21, 0x42, 0x62, 0xE9, 0xF7, 0x60, 0x04, 0x5A,
+0x01, 0x60, 0x01, 0x4A, 0x48, 0x32, 0x59, 0xE6,
+0x40, 0x9E, 0x1F, 0xE7, 0x55, 0xE7, 0x00, 0x6A,
+0x06, 0x25, 0x93, 0xE5, 0x83, 0xED, 0x64, 0x6A,
+0x02, 0x61, 0x00, 0x18, 0x55, 0x69, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xF1, 0x63, 0x1D, 0x62, 0x1C, 0xD1, 0x1B, 0xD0,
+0x30, 0xF0, 0x21, 0x6C, 0xD0, 0xF6, 0x01, 0x4C,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0x6D, 0x6F, 0xF4, 0x08, 0x4A, 0xAD, 0xF0,
+0x1D, 0x4B, 0x0D, 0xD4, 0x01, 0x6C, 0x13, 0xD2,
+0x10, 0xD3, 0x0C, 0xD5, 0x14, 0xD5, 0x12, 0xD5,
+0x15, 0xD4, 0x0C, 0x92, 0x10, 0x95, 0x0C, 0x94,
+0x54, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2,
+0x44, 0x9A, 0xE3, 0x4D, 0x11, 0xD5, 0x49, 0xE3,
+0x40, 0xA2, 0x07, 0x6B, 0x30, 0xF0, 0x20, 0x68,
+0x4C, 0xEB, 0x0F, 0xD3, 0x00, 0x18, 0x14, 0x57,
+0x0C, 0x95, 0x86, 0xF2, 0x00, 0x48, 0x7F, 0x6C,
+0x4C, 0xEC, 0x22, 0x67, 0xA9, 0xE0, 0xC9, 0xF6,
+0x54, 0xA2, 0x0E, 0xD4, 0x14, 0x6E, 0x16, 0xD2,
+0xA8, 0x32, 0x49, 0xE0, 0xE9, 0xF0, 0x4C, 0x9A,
+0x13, 0x95, 0x06, 0x04, 0x17, 0xD2, 0x00, 0x18,
+0xB9, 0x20, 0x0C, 0x93, 0xFF, 0x6A, 0x6C, 0xEA,
+0x5C, 0x2A, 0xC6, 0xF3, 0x58, 0x98, 0x08, 0x6B,
+0x6C, 0xEA, 0x0C, 0x22, 0xC6, 0xF3, 0x5C, 0x98,
+0x05, 0x5A, 0x08, 0x61, 0x10, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0x22, 0xF3, 0x10, 0x4C, 0xA0, 0xA2,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x08, 0x6C, 0x8C, 0xEB, 0x0E, 0x23, 0xC6, 0xF3,
+0x7C, 0x9A, 0x05, 0x5B, 0x0A, 0x61, 0x0F, 0x95,
+0x0E, 0x96, 0x4A, 0xF4, 0xE1, 0xA2, 0x30, 0xF0,
+0x20, 0x6C, 0x22, 0xF3, 0x1C, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x08, 0x6C,
+0x8C, 0xEB, 0x12, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x0E, 0x61, 0x11, 0x93, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0x6E, 0x51, 0xA3, 0x10, 0x93,
+0x42, 0xF3, 0x14, 0x4C, 0x5A, 0x32, 0xFF, 0xF7,
+0xBE, 0xA3, 0x4C, 0xEE, 0x00, 0x18, 0x4D, 0x63,
+0x10, 0x94, 0x40, 0xA4, 0x05, 0x72, 0x15, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x08, 0x6C, 0x8C, 0xEB,
+0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0x17, 0x95, 0x16, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x62, 0xF3, 0x0C, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x10, 0x95, 0xFF, 0xF7, 0x5E, 0xA5,
+0x30, 0x5A, 0x05, 0x61, 0x11, 0x92, 0x71, 0xA2,
+0x40, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x0C, 0x94,
+0x60, 0x10, 0x10, 0x93, 0x40, 0xA3, 0x05, 0x5A,
+0x60, 0xF2, 0x04, 0x61, 0x05, 0x72, 0x0F, 0x61,
+0x0C, 0x94, 0x05, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x78, 0xEC, 0x86, 0xF2, 0x00, 0x4A, 0x12, 0xEB,
+0x4D, 0xE3, 0x4A, 0xF4, 0x80, 0xA3, 0x07, 0x6A,
+0x8C, 0xEA, 0x08, 0x6C, 0x10, 0x10, 0x06, 0x72,
+0x10, 0x61, 0x0C, 0x94, 0x05, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x78, 0xEC, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xEB, 0x4D, 0xE3, 0x4A, 0xF4, 0x80, 0xA3,
+0x07, 0x6A, 0x8C, 0xEA, 0x10, 0x6C, 0x8D, 0xEA,
+0x0D, 0x10, 0x0C, 0x94, 0x05, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x78, 0xEC, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xEB, 0x4D, 0xE3, 0x4A, 0xF4, 0x80, 0xA3,
+0x07, 0x6A, 0x8C, 0xEA, 0x4A, 0xF4, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x08, 0x6C, 0x8C, 0xEB,
+0x12, 0x23, 0xC6, 0xF3, 0x7C, 0x9A, 0x05, 0x5B,
+0x0E, 0x61, 0x0C, 0x94, 0x05, 0x6B, 0x78, 0xEC,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF3, 0x04, 0x4C,
+0x12, 0xEB, 0x49, 0xE3, 0x4A, 0xF4, 0xA0, 0xA2,
+0xAE, 0x35, 0x00, 0x18, 0x4D, 0x63, 0x0C, 0x93,
+0x05, 0x6A, 0x30, 0xF0, 0x20, 0x68, 0x58, 0xEB,
+0x86, 0xF2, 0x00, 0x48, 0x12, 0xEA, 0x09, 0xE2,
+0x4A, 0xF4, 0x40, 0xA2, 0x4E, 0x32, 0x04, 0x2A,
+0x83, 0x67, 0x00, 0x18, 0x06, 0x60, 0x06, 0x12,
+0x01, 0x72, 0x20, 0xF1, 0x10, 0x61, 0x0C, 0x94,
+0x17, 0x96, 0x16, 0x97, 0x06, 0x05, 0x00, 0x18,
+0x80, 0x69, 0x0E, 0x94, 0x22, 0x67, 0x01, 0xE4,
+0xC8, 0xF7, 0x56, 0xA0, 0x08, 0x4A, 0x52, 0x32,
+0x43, 0xE9, 0x04, 0x60, 0x2B, 0xE2, 0xFF, 0x6D,
+0xAC, 0xEA, 0x03, 0x10, 0x4B, 0xE1, 0xFF, 0x6B,
+0x6C, 0xEA, 0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x79, 0xE5, 0x10, 0x94,
+0xC8, 0xF7, 0xB6, 0xA6, 0x0F, 0x5A, 0xFF, 0xF7,
+0x1C, 0xA4, 0xA7, 0x37, 0xAB, 0x34, 0x9D, 0xE7,
+0x1D, 0xE7, 0xAF, 0x34, 0x91, 0xE7, 0xB3, 0x35,
+0xB1, 0xE4, 0x0E, 0x95, 0xC8, 0xF7, 0x96, 0xC6,
+0x08, 0x4C, 0x04, 0xF4, 0x10, 0x4D, 0xA4, 0x35,
+0x6D, 0xE5, 0x0A, 0xA3, 0x92, 0x34, 0x62, 0x67,
+0x01, 0x61, 0x0E, 0x6B, 0xFF, 0x6A, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x6D, 0xE2, 0xC9, 0xF0, 0x72, 0xA3, 0x0B, 0x5B,
+0x08, 0x61, 0x11, 0x95, 0x70, 0xA5, 0x03, 0x6D,
+0x6E, 0x33, 0xAC, 0xEB, 0x19, 0x23, 0x03, 0x73,
+0x17, 0x60, 0x15, 0x93, 0x17, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x69, 0xE2,
+0xC9, 0xF0, 0x52, 0xA2, 0x41, 0xE0, 0xFF, 0x6A,
+0x4C, 0xE8, 0x0A, 0x58, 0x04, 0x60, 0x01, 0x6D,
+0x15, 0xD5, 0x00, 0x68, 0x0A, 0x10, 0xF6, 0x48,
+0x4C, 0xE8, 0x01, 0x6A, 0x15, 0xD2, 0x02, 0x10,
+0x00, 0x6B, 0x15, 0xD3, 0x1A, 0x58, 0x01, 0x61,
+0x19, 0x68, 0x0E, 0x93, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x04, 0xF4, 0x10, 0x4B,
+0x64, 0x33, 0x49, 0xE3, 0x0B, 0x58, 0x05, 0xCA,
+0x02, 0x6A, 0x09, 0x60, 0x06, 0x58, 0x03, 0x6A,
+0x06, 0x60, 0x03, 0x58, 0x58, 0x67, 0x01, 0x5A,
+0x58, 0x67, 0x05, 0x6B, 0x4B, 0xE3, 0x0B, 0x5C,
+0x12, 0xD0, 0x06, 0x61, 0xF6, 0x4C, 0x87, 0xEA,
+0x91, 0xE0, 0xFF, 0x6A, 0x4C, 0xEC, 0x12, 0xD4,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x08, 0x6C, 0x8C, 0xEB,
+0x0B, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF3,
+0x14, 0x4C, 0xB0, 0x67, 0x00, 0x18, 0x4D, 0x63,
+0x03, 0x58, 0x05, 0x61, 0x0D, 0x93, 0x0E, 0x94,
+0x40, 0xA3, 0x43, 0xEC, 0x1B, 0x61, 0x0D, 0x92,
+0xFF, 0x6D, 0x2C, 0xED, 0x14, 0xD5, 0x01, 0xA2,
+0x0C, 0x94, 0x11, 0x96, 0x0A, 0x58, 0x30, 0xF0,
+0x21, 0x6D, 0x30, 0xF0, 0x20, 0x6F, 0x18, 0x67,
+0x01, 0x6A, 0xD0, 0xF6, 0x00, 0x4D, 0x4C, 0xF6,
+0x08, 0x4F, 0x4E, 0xE8, 0x00, 0x18, 0x32, 0x60,
+0x0D, 0x95, 0x30, 0x67, 0x82, 0x67, 0x60, 0xA5,
+0x1B, 0x22, 0x30, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x08, 0x6C, 0x8C, 0xEB, 0x0A, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xA2, 0xF3, 0x08, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x5D, 0x67, 0x67, 0x42, 0x31, 0x4B,
+0x60, 0xA3, 0x0D, 0x92, 0x60, 0xC2, 0x28, 0x11,
+0x0E, 0x95, 0x63, 0xED, 0x13, 0x60, 0x12, 0x28,
+0x0F, 0x92, 0x03, 0x6B, 0x05, 0x72, 0x05, 0x60,
+0x0F, 0x92, 0x03, 0x6C, 0x8E, 0xEA, 0x01, 0x5A,
+0x78, 0x67, 0x0D, 0x94, 0x0F, 0xD3, 0x41, 0xA4,
+0x01, 0x4A, 0x41, 0xC4, 0x10, 0x95, 0x06, 0x6A,
+0x40, 0xC5, 0x25, 0x10, 0x0E, 0x92, 0x4E, 0xEB,
+0x02, 0x2B, 0x01, 0x29, 0x19, 0x24, 0x0F, 0x93,
+0x03, 0x2B, 0x01, 0x6C, 0x0F, 0xD4, 0x07, 0x10,
+0x0F, 0x95, 0x03, 0x6A, 0x0F, 0xD2, 0x01, 0x75,
+0x02, 0x60, 0x05, 0x6B, 0x0F, 0xD3, 0x10, 0x94,
+0x0D, 0x95, 0xFF, 0xF7, 0x5E, 0xA4, 0x43, 0xC5,
+0x5D, 0x67, 0x67, 0x42, 0x31, 0x4B, 0x40, 0xA3,
+0x40, 0xC5, 0x00, 0x6A, 0x41, 0xC5, 0x07, 0x10,
+0x0D, 0x93, 0x41, 0xA3, 0x01, 0x4A, 0x41, 0xC3,
+0x10, 0x94, 0x06, 0x6A, 0x40, 0xC4, 0x0C, 0x94,
+0x0F, 0x95, 0x00, 0x18, 0xFE, 0x5F, 0x0C, 0x94,
+0x00, 0x18, 0xBE, 0x77, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x08, 0x6C, 0x8C, 0xEB, 0xE0, 0xF0, 0x02, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0xC0, 0xF0,
+0x1D, 0x61, 0x0D, 0x92, 0x0F, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0xC1, 0xA2, 0xA2, 0xF3, 0x14, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0xD3, 0x10, 0x02, 0x72,
+0xC0, 0xF0, 0x0A, 0x61, 0x80, 0x6A, 0x4B, 0xEA,
+0x2C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x0A, 0x22,
+0x0E, 0x94, 0x00, 0x69, 0x01, 0xE4, 0x28, 0xF7,
+0x4A, 0xA0, 0x02, 0x5A, 0x07, 0x61, 0x2F, 0x42,
+0x6C, 0xE9, 0x04, 0x10, 0x0E, 0x92, 0x01, 0xE2,
+0x28, 0xF7, 0x2A, 0xA0, 0x11, 0x94, 0x01, 0x6A,
+0xFF, 0x68, 0x76, 0xA4, 0x6C, 0xEA, 0x0E, 0x22,
+0x0E, 0x94, 0x00, 0x18, 0x9C, 0x67, 0x02, 0x22,
+0x02, 0x49, 0x07, 0x10, 0x0E, 0x94, 0x00, 0x18,
+0x88, 0x67, 0x02, 0x22, 0x05, 0x49, 0x01, 0x10,
+0x06, 0x49, 0x0C, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x48, 0x9A, 0x60, 0xA2, 0x7F, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x05, 0x49, 0xFF, 0x6A,
+0x4C, 0xE9, 0x12, 0x95, 0x14, 0x92, 0xA3, 0xEA,
+0x0B, 0x60, 0x4B, 0xE5, 0x45, 0xE1, 0xFF, 0x6B,
+0x6C, 0xE9, 0x51, 0x67, 0x6C, 0xE9, 0x47, 0x59,
+0x01, 0x61, 0x46, 0x6A, 0xFF, 0x69, 0x4C, 0xE9,
+0x00, 0x6B, 0x0E, 0xD3, 0x03, 0x67, 0x0E, 0x94,
+0x16, 0x95, 0x17, 0x97, 0x84, 0x34, 0x11, 0xD4,
+0x04, 0xD5, 0x0C, 0x94, 0x11, 0x95, 0x06, 0x06,
+0x00, 0x18, 0x49, 0x60, 0x18, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x08, 0x6C, 0x8C, 0xEB, 0x0D, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61,
+0x11, 0x95, 0x18, 0x96, 0x30, 0xF0, 0x20, 0x6C,
+0xC2, 0xF3, 0x14, 0x4C, 0xF1, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x18, 0x92, 0x43, 0xE9, 0x09, 0x60,
+0x0E, 0x93, 0x02, 0x48, 0xFF, 0x6A, 0x4C, 0xE8,
+0x01, 0x4B, 0x06, 0x70, 0x0E, 0xD3, 0xD3, 0x61,
+0x06, 0x68, 0x0F, 0x93, 0xFF, 0x6A, 0x06, 0x30,
+0x01, 0x4B, 0x67, 0x33, 0x4C, 0xEB, 0x63, 0xE8,
+0x00, 0x69, 0x02, 0x60, 0x07, 0xE3, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x08, 0x6C, 0x8C, 0xEB,
+0x0D, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x09, 0x61, 0x0D, 0x92, 0x30, 0xF0, 0x20, 0x6C,
+0xE2, 0xF3, 0x10, 0x4C, 0xA2, 0xA2, 0xD1, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x0D, 0x93, 0x34, 0x31,
+0x42, 0xA3, 0x46, 0x32, 0x45, 0xE1, 0x22, 0xC3,
+0x42, 0xA3, 0xC0, 0x5A, 0x03, 0x61, 0x40, 0x6A,
+0x4B, 0xEA, 0x42, 0xC3, 0x16, 0x95, 0x0D, 0x94,
+0x04, 0x5D, 0x02, 0xA4, 0x08, 0x60, 0x1F, 0x48,
+0x1A, 0x30, 0x04, 0x30, 0x04, 0x20, 0xFF, 0x48,
+0xFF, 0x6A, 0x4C, 0xE8, 0x01, 0x10, 0x00, 0x68,
+0x0C, 0x94, 0xB0, 0x67, 0x00, 0x18, 0xFE, 0x5F,
+0x0C, 0x94, 0x00, 0x18, 0xBE, 0x77, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x08, 0x6C, 0x8C, 0xEB, 0x12, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x0E, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF4, 0x00, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x06, 0x10,
+0x0C, 0x94, 0x00, 0x18, 0x06, 0x60, 0x0C, 0x94,
+0x00, 0x18, 0xBE, 0x77, 0x0C, 0x92, 0x13, 0x93,
+0x10, 0x94, 0x0D, 0x95, 0x01, 0x4A, 0x14, 0x4B,
+0x2E, 0x4C, 0x05, 0x4D, 0x3F, 0x72, 0x0C, 0xD2,
+0x13, 0xD3, 0x10, 0xD4, 0x0D, 0xD5, 0xFF, 0xF4,
+0x14, 0x61, 0x1D, 0x97, 0x1C, 0x91, 0x1B, 0x90,
+0x0F, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0xD1,
+0x08, 0xD0, 0x0A, 0xD4, 0x44, 0x67, 0x82, 0x10,
+0x25, 0x73, 0x04, 0x60, 0x60, 0xA5, 0x60, 0xC2,
+0x01, 0x4A, 0x7B, 0x10, 0x61, 0x85, 0x62, 0x73,
+0x7D, 0x67, 0x20, 0x61, 0x62, 0x85, 0x78, 0x73,
+0x03, 0x60, 0x58, 0x73, 0x7D, 0x67, 0x1A, 0x61,
+0x82, 0x85, 0x60, 0xA6, 0x78, 0x6F, 0xEE, 0xEC,
+0x30, 0xF0, 0x20, 0x6F, 0x72, 0x30, 0x02, 0xF4,
+0x14, 0x4F, 0xE1, 0xE0, 0x00, 0xA0, 0x01, 0x5C,
+0x98, 0x67, 0x94, 0x34, 0x8D, 0xE8, 0x3D, 0x67,
+0x00, 0xC1, 0x0F, 0x68, 0x6C, 0xE8, 0xFD, 0xE0,
+0x60, 0xA7, 0x02, 0x4D, 0x8D, 0xEB, 0x61, 0xC1,
+0x00, 0xF0, 0x02, 0x03, 0x81, 0x85, 0x77, 0x74,
+0x26, 0x61, 0x82, 0x85, 0x78, 0x74, 0x02, 0x60,
+0x58, 0x74, 0x21, 0x61, 0x80, 0xAE, 0x06, 0xD3,
+0x07, 0xD4, 0x82, 0x85, 0x78, 0x74, 0xF8, 0x67,
+0x01, 0x5F, 0x18, 0x67, 0x14, 0x30, 0x18, 0x65,
+0x0C, 0x6C, 0x07, 0x97, 0x0F, 0x68, 0x30, 0xF0,
+0x20, 0x69, 0xE7, 0xEC, 0x0C, 0xEF, 0x02, 0xF4,
+0x14, 0x49, 0x3D, 0xE7, 0xE0, 0xA7, 0x06, 0x90,
+0x38, 0x67, 0x2D, 0xEF, 0xFC, 0x4C, 0xE0, 0xC0,
+0x01, 0x48, 0xE4, 0x44, 0x06, 0xD0, 0xED, 0x2F,
+0x04, 0x4B, 0x02, 0x4D, 0x25, 0x10, 0x81, 0x85,
+0x78, 0x74, 0x02, 0x60, 0x58, 0x74, 0x20, 0x61,
+0x81, 0x85, 0x20, 0x9E, 0x06, 0xD3, 0x78, 0x74,
+0x98, 0x67, 0x01, 0x5C, 0xF8, 0x67, 0xF4, 0x37,
+0x07, 0xD1, 0x1F, 0x65, 0x1C, 0x6C, 0x07, 0x97,
+0x0F, 0x68, 0x30, 0xF0, 0x20, 0x69, 0xE6, 0xEC,
+0x0C, 0xEF, 0x02, 0xF4, 0x14, 0x49, 0x3D, 0xE7,
+0xE0, 0xA7, 0x06, 0x91, 0x18, 0x67, 0x0D, 0xEF,
+0xFC, 0x4C, 0xE0, 0xC1, 0x01, 0x49, 0xE4, 0x44,
+0x06, 0xD1, 0xED, 0x2F, 0x08, 0x4B, 0x01, 0x4D,
+0x9D, 0x67, 0x04, 0x10, 0xE0, 0xA4, 0x01, 0x4C,
+0xE0, 0xC2, 0x01, 0x4A, 0x63, 0xEC, 0xFA, 0x61,
+0x04, 0x4E, 0x01, 0x4D, 0x60, 0x85, 0x7F, 0xF7,
+0x1B, 0x2B, 0x0A, 0x94, 0x01, 0x24, 0x60, 0xC2,
+0x0A, 0x97, 0x09, 0x91, 0x08, 0x90, 0xEB, 0xE2,
+0x05, 0x63, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0x6B, 0x86, 0xF2, 0x00, 0x4A, 0x6B, 0xEB,
+0xE9, 0xF0, 0x61, 0xC2, 0xE9, 0xF0, 0x62, 0xC2,
+0xE9, 0xF0, 0x63, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x68, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xE6, 0xF3, 0x6D, 0xC2, 0x69, 0xA4,
+0xE6, 0xF3, 0x62, 0xC2, 0x6A, 0xA4, 0xE6, 0xF3,
+0x6C, 0xC2, 0xAB, 0xA4, 0x0F, 0x6B, 0xAC, 0xEB,
+0xE6, 0xF3, 0x74, 0xC2, 0x6B, 0xA4, 0x72, 0x33,
+0xE6, 0xF3, 0x73, 0xC2, 0x00, 0x6A, 0x20, 0xE8,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xE6, 0xF3, 0x6D, 0xC2, 0x61, 0xA4,
+0xE6, 0xF3, 0x62, 0xC2, 0x62, 0xA4, 0xE6, 0xF3,
+0x6C, 0xC2, 0xA3, 0xA4, 0x0F, 0x6B, 0xAC, 0xEB,
+0xE6, 0xF3, 0x74, 0xC2, 0x63, 0xA4, 0x72, 0x33,
+0xE6, 0xF3, 0x73, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x0F, 0x72, 0x08, 0x60, 0x11, 0x72, 0x0A, 0x60,
+0x0E, 0x72, 0x0C, 0x61, 0x85, 0x67, 0x00, 0x18,
+0x9A, 0x5F, 0x1D, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xA2, 0x58, 0x19, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x44, 0x62, 0x15, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF0, 0x84, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x83, 0xF3, 0x60, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x60, 0xDA, 0xFF, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x42, 0xA4, 0x00, 0xA4,
+0x21, 0xA4, 0x0A, 0xD2, 0x63, 0xA4, 0x00, 0xF0,
+0x16, 0x02, 0x20, 0xF0, 0x02, 0x04, 0x00, 0x6D,
+0xA0, 0xC2, 0x01, 0x4A, 0x8A, 0xEA, 0xFB, 0x61,
+0x01, 0x6A, 0x6C, 0xEA, 0x10, 0x22, 0x04, 0x04,
+0x00, 0xF0, 0x11, 0x05, 0x00, 0x18, 0x1F, 0x57,
+0x7D, 0x67, 0x50, 0xA3, 0x01, 0x6C, 0x96, 0xC3,
+0x57, 0xC3, 0x51, 0xA3, 0x58, 0xC3, 0x26, 0x6A,
+0x54, 0xC3, 0x03, 0x6A, 0x51, 0xCB, 0x0A, 0x93,
+0x01, 0x6A, 0x4C, 0xEB, 0x1C, 0x23, 0x40, 0x58,
+0x1A, 0x61, 0x40, 0x59, 0x18, 0x61, 0xBD, 0x67,
+0x56, 0xC5, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xCA, 0xF0, 0x6C, 0x9A, 0x62, 0x34,
+0x77, 0xC5, 0x00, 0xF6, 0x62, 0x33, 0x7A, 0xC5,
+0x0D, 0x6B, 0x74, 0xC5, 0x05, 0x6B, 0x98, 0xC5,
+0x71, 0xCD, 0x82, 0x34, 0x00, 0x6B, 0x99, 0xC5,
+0xCA, 0xF0, 0x6C, 0xDA, 0xE2, 0x10, 0x0A, 0x92,
+0x02, 0x6C, 0x8C, 0xEA, 0x3B, 0x22, 0xDD, 0x67,
+0x40, 0x58, 0x96, 0xC6, 0x18, 0x60, 0xA5, 0xF0,
+0x64, 0x40, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x64, 0x33, 0x4D, 0xE3, 0x83, 0xAB,
+0x65, 0xF0, 0x04, 0x48, 0x04, 0x30, 0x49, 0xE0,
+0x97, 0xC6, 0x82, 0x34, 0x98, 0xC6, 0x84, 0xAA,
+0x99, 0xC6, 0x82, 0x34, 0x9A, 0xC6, 0x00, 0x6C,
+0x83, 0xCB, 0x84, 0xCA, 0x04, 0x10, 0x16, 0x6A,
+0x4B, 0xEA, 0x7D, 0x67, 0x57, 0xC3, 0x40, 0x59,
+0x57, 0x60, 0xA5, 0xF0, 0x64, 0x41, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x64, 0x33,
+0x4D, 0xE3, 0x83, 0xAB, 0x65, 0xF0, 0x04, 0x49,
+0xBD, 0x67, 0x24, 0x31, 0x49, 0xE1, 0x9B, 0xC5,
+0x82, 0x34, 0x9C, 0xC5, 0x84, 0xAA, 0x9D, 0xC5,
+0x82, 0x34, 0x9E, 0xC5, 0x00, 0x6C, 0x83, 0xCB,
+0x84, 0xCA, 0x42, 0x10, 0x0A, 0x95, 0x08, 0x6B,
+0xAC, 0xEB, 0x43, 0x23, 0xDD, 0x67, 0x40, 0x58,
+0x96, 0xC6, 0x17, 0x60, 0xA5, 0xF0, 0x84, 0x40,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x84, 0x34, 0x71, 0xE4, 0xA3, 0xAC, 0xE5, 0xF0,
+0x04, 0x48, 0x04, 0x30, 0x6D, 0xE0, 0xB7, 0xC6,
+0xA2, 0x35, 0xB8, 0xC6, 0xA2, 0xAB, 0x43, 0xCC,
+0x42, 0xCB, 0xB9, 0xC6, 0xA2, 0x35, 0xBA, 0xC6,
+0x04, 0x10, 0x16, 0x6A, 0x4B, 0xEA, 0x7D, 0x67,
+0x57, 0xC3, 0x40, 0x59, 0x19, 0x60, 0xA5, 0xF0,
+0x64, 0x41, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x64, 0x33, 0x4D, 0xE3, 0x83, 0xAB,
+0xE5, 0xF0, 0x04, 0x49, 0xBD, 0x67, 0x24, 0x31,
+0x49, 0xE1, 0x9B, 0xC5, 0x82, 0x34, 0x9C, 0xC5,
+0x82, 0xAA, 0x9D, 0xC5, 0x82, 0x34, 0x9E, 0xC5,
+0x00, 0x6C, 0x83, 0xCB, 0x82, 0xCA, 0x04, 0x10,
+0x16, 0x6A, 0x4B, 0xEA, 0xDD, 0x67, 0x5B, 0xC6,
+0x0D, 0x6A, 0x7D, 0x67, 0x54, 0xC3, 0x09, 0x6A,
+0x56, 0x10, 0x0A, 0x94, 0x56, 0x2C, 0x40, 0x58,
+0x24, 0x60, 0xE4, 0xF7, 0x64, 0x40, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x64, 0x33,
+0x4D, 0xE3, 0x84, 0xAB, 0xBD, 0x67, 0x16, 0xC5,
+0x97, 0xC5, 0x82, 0x34, 0x98, 0xC5, 0x25, 0xF0,
+0x84, 0x40, 0x84, 0x34, 0x49, 0xE4, 0x83, 0xAA,
+0x14, 0x30, 0xC7, 0x45, 0x99, 0xC5, 0x82, 0x34,
+0x9A, 0xC5, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF2,
+0x8C, 0x9C, 0x21, 0x4E, 0xC0, 0xAE, 0x81, 0xE0,
+0x80, 0xA0, 0xC4, 0xCB, 0xC3, 0xCA, 0x9B, 0xC5,
+0x02, 0x10, 0x9D, 0x67, 0x16, 0xC4, 0x40, 0x59,
+0x24, 0x60, 0xE4, 0xF7, 0x64, 0x41, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x64, 0x33,
+0x4D, 0xE3, 0x84, 0xAB, 0xBD, 0x67, 0x3C, 0xC5,
+0x9D, 0xC5, 0x82, 0x34, 0x9E, 0xC5, 0x25, 0xF0,
+0x84, 0x41, 0x84, 0x34, 0x49, 0xE4, 0x83, 0xAA,
+0x34, 0x31, 0x9F, 0xC5, 0x82, 0x34, 0x20, 0xF0,
+0x80, 0xC5, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF2,
+0x8C, 0x9C, 0x85, 0xE1, 0x80, 0xA1, 0x20, 0xF0,
+0x81, 0xC5, 0x00, 0x6C, 0x84, 0xCB, 0x83, 0xCA,
+0x02, 0x10, 0x5D, 0x67, 0x3C, 0xC2, 0x04, 0x6A,
+0x7D, 0x67, 0x54, 0xC3, 0x0C, 0x6A, 0x51, 0xCB,
+0x04, 0x10, 0x9D, 0x67, 0x04, 0x6A, 0x54, 0xC4,
+0x71, 0xCC, 0x05, 0x04, 0x00, 0x18, 0xBC, 0x27,
+0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x00, 0x6A, 0x10, 0xD4,
+0x01, 0x68, 0x62, 0x67, 0xA0, 0xA4, 0x0E, 0x25,
+0xFF, 0x6D, 0x01, 0x4B, 0xAC, 0xEB, 0x01, 0x4A,
+0x0B, 0x73, 0xAC, 0xEA, 0x03, 0x61, 0x01, 0x48,
+0xAC, 0xE8, 0x00, 0x6B, 0x37, 0x72, 0x01, 0x4C,
+0xF1, 0x61, 0x37, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xE9, 0xF0, 0x84, 0xA3,
+0x0F, 0x5C, 0x01, 0x4C, 0x01, 0x61, 0x00, 0x6C,
+0xE9, 0xF0, 0x84, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0x6F, 0xF3, 0x64, 0xA3, 0x0B, 0x6D, 0x2F, 0x40,
+0x70, 0x33, 0x0A, 0xD3, 0x0A, 0x94, 0xFF, 0x6B,
+0x6C, 0xE9, 0x6C, 0xEC, 0x0A, 0xD4, 0x01, 0x6C,
+0x13, 0xE4, 0xB8, 0xEC, 0x12, 0xEC, 0x91, 0xE2,
+0x6C, 0xEC, 0x09, 0xD4, 0x00, 0x6A, 0x01, 0x4C,
+0x0B, 0xD4, 0x08, 0xD2, 0x3C, 0x10, 0x08, 0x94,
+0x0B, 0x6B, 0x0A, 0x95, 0x78, 0xEC, 0x9D, 0x67,
+0x12, 0xEB, 0x4C, 0xEB, 0x0F, 0x6A, 0x2C, 0xEA,
+0xAD, 0xEA, 0x08, 0x95, 0x52, 0xC4, 0x4F, 0x40,
+0xAE, 0xEA, 0x07, 0x22, 0x10, 0x92, 0x00, 0xF0,
+0x1E, 0x04, 0x6D, 0xE2, 0x00, 0xF0, 0x13, 0x02,
+0x0F, 0x10, 0x10, 0x94, 0x09, 0x95, 0x00, 0xF0,
+0x13, 0x02, 0x6D, 0xE4, 0xB1, 0xE2, 0x04, 0x10,
+0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2, 0x01, 0x4A,
+0x8A, 0xEA, 0xFA, 0x61, 0x0B, 0x92, 0x07, 0x10,
+0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2, 0x01, 0x4A,
+0x8A, 0xEA, 0xFA, 0x61, 0x0C, 0x6A, 0x9D, 0x67,
+0x00, 0x6B, 0x4F, 0xCC, 0x70, 0xC4, 0x05, 0x95,
+0x04, 0x94, 0x06, 0x96, 0x07, 0x97, 0xFF, 0x49,
+0x00, 0x18, 0xC0, 0x57, 0x08, 0x95, 0xFF, 0x6A,
+0x4C, 0xE9, 0x01, 0x4D, 0x08, 0xD5, 0x08, 0x93,
+0xFF, 0x6A, 0x4C, 0xEB, 0x03, 0xEB, 0xBF, 0x61,
+0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x01, 0xF2, 0x50, 0x9A, 0x6F, 0xF3,
+0x64, 0x9B, 0x07, 0xD5, 0x08, 0xD6, 0x6C, 0xEA,
+0x00, 0xF1, 0x00, 0x72, 0x09, 0xD7, 0x06, 0xD4,
+0x0C, 0x61, 0x30, 0xF0, 0x21, 0x68, 0x06, 0x95,
+0x72, 0xF1, 0x0C, 0x48, 0x90, 0x67, 0x07, 0x06,
+0x00, 0x18, 0xF3, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x0B, 0x63, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x4A, 0xF2, 0x7B, 0xC2, 0xA1, 0xA4,
+0x03, 0x73, 0x4A, 0xF2, 0xBC, 0xC2, 0x1F, 0x61,
+0x62, 0xA4, 0x4A, 0xF2, 0x78, 0xC2, 0x63, 0xA4,
+0x4A, 0xF2, 0x79, 0xC2, 0x64, 0xA4, 0x04, 0x6C,
+0x4A, 0xF2, 0x7A, 0xC2, 0xC6, 0xF3, 0x78, 0x9A,
+0x8C, 0xEB, 0x30, 0x23, 0xC6, 0xF3, 0x7C, 0x9A,
+0x05, 0x5B, 0x2C, 0x61, 0x4A, 0xF2, 0xB8, 0xA2,
+0x4A, 0xF2, 0xD9, 0xA2, 0x4A, 0xF2, 0xFA, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF4, 0x08, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x1F, 0x10, 0x02, 0x73,
+0x1D, 0x61, 0x62, 0xA4, 0x4A, 0xF2, 0x78, 0xC2,
+0x63, 0xA4, 0x04, 0x6C, 0x4A, 0xF2, 0x79, 0xC2,
+0x01, 0x6B, 0x6B, 0xEB, 0x4A, 0xF2, 0x7A, 0xC2,
+0xC6, 0xF3, 0x78, 0x9A, 0x8C, 0xEB, 0x0E, 0x23,
+0xC6, 0xF3, 0x7C, 0x9A, 0x05, 0x5B, 0x0A, 0x61,
+0x4A, 0xF2, 0xB8, 0xA2, 0x4A, 0xF2, 0xD9, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x42, 0xF4, 0x18, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A,
+0x05, 0x97, 0x86, 0xF2, 0x00, 0x4A, 0x01, 0x6B,
+0x4A, 0xF2, 0x7E, 0xC2, 0x00, 0x6B, 0x4A, 0xF2,
+0x7D, 0xC2, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF3, 0x63, 0x19, 0x62, 0x18, 0xD1, 0x17, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x15, 0xD2, 0x40, 0xF0,
+0x06, 0x03, 0x20, 0xF0, 0x1A, 0x02, 0x00, 0x6C,
+0x80, 0xC2, 0x01, 0x4A, 0x6A, 0xEA, 0xFB, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x6F, 0xF3, 0x01, 0x4B,
+0x00, 0x68, 0x12, 0xD3, 0x14, 0xD0, 0x70, 0x10,
+0x12, 0x92, 0x40, 0xA2, 0xFF, 0x72, 0x13, 0xD2,
+0x0A, 0x61, 0x7D, 0x67, 0x09, 0xE3, 0x01, 0x6B,
+0x6B, 0xEB, 0x20, 0xF0, 0x7A, 0xC2, 0x01, 0x48,
+0xFF, 0x6A, 0x4C, 0xE8, 0x65, 0x10, 0x13, 0x92,
+0x2E, 0x69, 0x9D, 0x67, 0x38, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A, 0x0E, 0x03,
+0x0D, 0xE3, 0x04, 0x48, 0x12, 0xE9, 0x25, 0xE2,
+0x47, 0x44, 0x45, 0x4A, 0x80, 0xA2, 0x82, 0xC3,
+0x59, 0xA1, 0x03, 0x6C, 0x43, 0xC3, 0x43, 0xA1,
+0x44, 0xC3, 0x51, 0xA1, 0x4A, 0x32, 0x8C, 0xEA,
+0x45, 0xC3, 0xFF, 0x6B, 0x6C, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xC6, 0xF3,
+0xB8, 0x9B, 0xE7, 0xF7, 0x1D, 0x4C, 0xAC, 0xEC,
+0x0E, 0x24, 0xC6, 0xF3, 0x7C, 0x9B, 0x05, 0x5B,
+0x0A, 0x61, 0xD9, 0xA1, 0xE3, 0xA1, 0x13, 0x95,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF4, 0x08, 0x4C,
+0x04, 0xD2, 0x00, 0x18, 0x4D, 0x63, 0x15, 0x92,
+0x02, 0x6B, 0x6E, 0xEA, 0x21, 0x2A, 0x95, 0xA9,
+0x0E, 0x03, 0x0D, 0xE3, 0x82, 0xC3, 0x95, 0xA9,
+0x02, 0x48, 0x82, 0x34, 0x83, 0xC3, 0x55, 0xC9,
+0xFF, 0x6A, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x98, 0x9A,
+0x08, 0xF0, 0x00, 0x6B, 0x8C, 0xEB, 0x0C, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61,
+0x13, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF4,
+0x0C, 0x4C, 0x00, 0x6E, 0x00, 0x18, 0x4D, 0x63,
+0x14, 0x94, 0xFF, 0x6A, 0x01, 0x4C, 0x4C, 0xEC,
+0x12, 0x92, 0x14, 0xD4, 0x01, 0x4A, 0x12, 0xD2,
+0x14, 0x93, 0x15, 0x94, 0x83, 0xEB, 0x8C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x98, 0x9A, 0x08, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x2D, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x29, 0x61, 0x5D, 0x67, 0x20, 0xF0,
+0xBA, 0xA2, 0x20, 0xF0, 0xDB, 0xA2, 0x20, 0xF0,
+0xFC, 0xA2, 0x20, 0xF0, 0x5D, 0xA2, 0x7D, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0x04, 0xD2, 0x20, 0xF0,
+0x5E, 0xA3, 0xC2, 0xF4, 0x04, 0x4C, 0x05, 0xD2,
+0x20, 0xF0, 0x5F, 0xA3, 0x06, 0xD2, 0x40, 0xF0,
+0x40, 0xA3, 0x07, 0xD2, 0x40, 0xF0, 0x41, 0xA3,
+0x08, 0xD2, 0x40, 0xF0, 0x42, 0xA3, 0x09, 0xD2,
+0x40, 0xF0, 0x43, 0xA3, 0x0A, 0xD2, 0x40, 0xF0,
+0x44, 0xA3, 0x0B, 0xD2, 0x40, 0xF0, 0x45, 0xA3,
+0x0C, 0xD2, 0x00, 0x18, 0x4D, 0x63, 0x9D, 0x67,
+0x2C, 0x6A, 0x20, 0xF0, 0x58, 0xC4, 0x40, 0xF0,
+0x06, 0xCC, 0x0E, 0x04, 0x00, 0x18, 0xBC, 0x27,
+0x19, 0x97, 0x18, 0x91, 0x17, 0x90, 0x0D, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x43, 0xA4, 0x62, 0xA4,
+0xC0, 0xA4, 0x40, 0x32, 0x40, 0x32, 0x60, 0x33,
+0x4D, 0xE3, 0x41, 0xA4, 0x0F, 0x6D, 0xCC, 0xED,
+0x4D, 0xE3, 0x44, 0xA4, 0xD2, 0x36, 0x01, 0x5E,
+0x00, 0xF6, 0x40, 0x32, 0x49, 0xE3, 0x08, 0xD2,
+0xB4, 0x32, 0x06, 0xD2, 0x06, 0x93, 0xFF, 0x6A,
+0x4C, 0xEB, 0x06, 0xD3, 0x03, 0x6A, 0x78, 0x67,
+0x6F, 0xE2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x98, 0x9A, 0x07, 0xD3,
+0x08, 0xF0, 0x00, 0x6B, 0x8C, 0xEB, 0x0B, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61,
+0x08, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0x02, 0xF5,
+0x00, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x00, 0x18,
+0x3D, 0x62, 0x00, 0x68, 0x06, 0x91, 0x4E, 0x10,
+0x08, 0x94, 0x01, 0x6A, 0x44, 0xE9, 0x8C, 0xEA,
+0x1C, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x4D, 0xE0, 0xE9, 0xF0, 0x21, 0xC3,
+0xC6, 0xF3, 0x98, 0x9A, 0xFF, 0x6B, 0x01, 0x48,
+0x6C, 0xE8, 0x07, 0xF7, 0x01, 0x4B, 0x8C, 0xEB,
+0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF5,
+0x08, 0x4C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x07, 0x92, 0x4A, 0xE8, 0x04, 0x60,
+0x06, 0x92, 0x1F, 0x4A, 0x2E, 0xEA, 0x23, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x98, 0x9A, 0x08, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x12, 0x23, 0xC6, 0xF3, 0x7C, 0x9A,
+0x05, 0x5B, 0x0E, 0x61, 0xE9, 0xF0, 0xC1, 0xA2,
+0xE9, 0xF0, 0xE2, 0xA2, 0xE9, 0xF0, 0x43, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x42, 0xF5, 0x08, 0x4C,
+0xB0, 0x67, 0x04, 0xD2, 0x00, 0x18, 0x4D, 0x63,
+0x0D, 0x20, 0x07, 0x94, 0x00, 0x68, 0x00, 0x18,
+0x8C, 0x63, 0x00, 0x18, 0x3D, 0x62, 0x01, 0x49,
+0xFF, 0x6A, 0x4C, 0xE9, 0x06, 0x92, 0x20, 0x4A,
+0x42, 0xE9, 0xAE, 0x61, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF6, 0x63, 0x13, 0x62, 0x12, 0xD1, 0x11, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x8C, 0xEA,
+0xC0, 0xF3, 0x98, 0x9B, 0xC0, 0xF3, 0x18, 0x4B,
+0x01, 0x72, 0x04, 0xD4, 0x81, 0x9B, 0x68, 0xA3,
+0x05, 0xD4, 0x9D, 0x67, 0x78, 0xC4, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF3, 0x8C, 0x9B, 0xC0, 0xF3,
+0x0C, 0x4B, 0x07, 0xD4, 0x81, 0x9B, 0x68, 0xA3,
+0x08, 0xD4, 0x9D, 0x67, 0x20, 0xF0, 0x64, 0xC4,
+0x20, 0x61, 0x00, 0x68, 0x5D, 0x67, 0x0D, 0xE2,
+0x5C, 0xA3, 0x0B, 0x5A, 0x01, 0x61, 0x0A, 0x6A,
+0xFF, 0x6B, 0x6C, 0xEA, 0x02, 0x4A, 0x7D, 0x67,
+0x5B, 0xCB, 0x0E, 0x6A, 0x20, 0xF0, 0x48, 0xC3,
+0x01, 0x6A, 0x20, 0xF0, 0x4A, 0xC3, 0x09, 0xE3,
+0x50, 0xA2, 0x0B, 0x95, 0x0C, 0x96, 0x20, 0xF0,
+0x4B, 0xC3, 0x0A, 0x94, 0x0D, 0x97, 0x01, 0x48,
+0x00, 0x18, 0xC0, 0x57, 0x09, 0x70, 0xE2, 0x61,
+0x71, 0x10, 0x08, 0x72, 0x37, 0x61, 0x20, 0xF0,
+0x05, 0x04, 0x07, 0x00, 0x04, 0x01, 0x0E, 0xD4,
+0x40, 0xA0, 0x0B, 0x5A, 0x01, 0x61, 0x0A, 0x6A,
+0xFF, 0x6B, 0x4C, 0xEB, 0x9D, 0x67, 0x42, 0x43,
+0x5B, 0xCC, 0x0E, 0x6A, 0x20, 0xF0, 0x48, 0xC4,
+0x08, 0x6A, 0x20, 0xF0, 0x4A, 0xC4, 0x40, 0xA1,
+0x20, 0xF0, 0x4B, 0xC4, 0x00, 0x6A, 0x0E, 0x10,
+0x9D, 0x67, 0x55, 0xE4, 0xC0, 0xA1, 0x30, 0xF0,
+0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C, 0x91, 0xE2,
+0xD1, 0xE4, 0xC8, 0xF6, 0x96, 0xA4, 0x01, 0x4A,
+0x20, 0xF0, 0x8C, 0xC5, 0xFF, 0x6C, 0x4C, 0xEC,
+0x63, 0xEC, 0xEE, 0x61, 0x0A, 0x94, 0x0B, 0x95,
+0x0C, 0x96, 0x0D, 0x97, 0x01, 0x48, 0x01, 0x49,
+0x00, 0x18, 0xC0, 0x57, 0x0E, 0x92, 0x4A, 0xE8,
+0xCF, 0x61, 0x38, 0x10, 0x09, 0x72, 0x36, 0x61,
+0x20, 0xF0, 0x05, 0x03, 0x07, 0x00, 0x04, 0x01,
+0x0F, 0xD3, 0x40, 0xA0, 0x0B, 0x5A, 0x01, 0x61,
+0x0A, 0x6A, 0xFF, 0x6B, 0x4C, 0xEB, 0x9D, 0x67,
+0x42, 0x43, 0x5B, 0xCC, 0x0E, 0x6A, 0x20, 0xF0,
+0x48, 0xC4, 0x09, 0x6A, 0x20, 0xF0, 0x4A, 0xC4,
+0x40, 0xA1, 0x20, 0xF0, 0x4B, 0xC4, 0x00, 0x6A,
+0x0E, 0x10, 0x9D, 0x67, 0x55, 0xE4, 0xC0, 0xA1,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0x91, 0xE2, 0xD1, 0xE4, 0x28, 0xF7, 0x8A, 0xA4,
+0x01, 0x4A, 0x20, 0xF0, 0x8C, 0xC5, 0xFF, 0x6C,
+0x4C, 0xEC, 0x63, 0xEC, 0xEE, 0x61, 0x0A, 0x94,
+0x0B, 0x95, 0x0C, 0x96, 0x0D, 0x97, 0x01, 0x48,
+0x01, 0x49, 0x00, 0x18, 0xC0, 0x57, 0x0F, 0x92,
+0x4A, 0xE8, 0xCF, 0x61, 0x13, 0x97, 0x12, 0x91,
+0x11, 0x90, 0x0A, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x44, 0x67, 0x65, 0xA2, 0x02, 0x6D, 0x81, 0xA4,
+0xAC, 0xEB, 0x03, 0x23, 0x00, 0x18, 0x3E, 0x64,
+0x3D, 0x10, 0x01, 0x74, 0x22, 0xA2, 0x04, 0xA2,
+0x43, 0xA2, 0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x62, 0xF5, 0x10, 0x4C, 0x00, 0x18, 0x0B, 0x63,
+0x31, 0x10, 0x10, 0x30, 0x08, 0x74, 0x4D, 0xE8,
+0x0E, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF5,
+0x1C, 0x4C, 0x00, 0x18, 0x0B, 0x63, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x45, 0xE1,
+0xC8, 0xF6, 0x16, 0xC1, 0x1F, 0x10, 0x09, 0x74,
+0x0E, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF5,
+0x1C, 0x4C, 0x00, 0x18, 0x0B, 0x63, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x45, 0xE1,
+0x28, 0xF7, 0x0A, 0xC1, 0x0F, 0x10, 0x0A, 0x74,
+0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2,
+0xF4, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF5,
+0x0C, 0x4C, 0xF9, 0x6D, 0x28, 0xF3, 0x01, 0x6E,
+0x00, 0x18, 0x4D, 0x63, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x2E, 0x6B, 0x78, 0xEC, 0x30, 0xF0, 0x20, 0x6E,
+0xAD, 0xF0, 0x00, 0x4E, 0xAC, 0xEA, 0x05, 0x6D,
+0x12, 0xEB, 0x6D, 0xE6, 0xDD, 0x67, 0xAF, 0xCE,
+0x0F, 0x6D, 0xB0, 0xC6, 0x92, 0xC6, 0x53, 0xC6,
+0x20, 0xF0, 0x44, 0xA3, 0x07, 0x97, 0x04, 0x94,
+0x54, 0xC6, 0x20, 0xF0, 0x45, 0xA3, 0x55, 0xC6,
+0x20, 0xF0, 0x46, 0xA3, 0x56, 0xC6, 0x05, 0x95,
+0x06, 0x96, 0x00, 0x18, 0xC0, 0x57, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x14, 0x92, 0x15, 0x93,
+0x16, 0x90, 0x0A, 0xD2, 0xFF, 0x6A, 0x1A, 0x65,
+0xAC, 0xEA, 0x08, 0xD2, 0x58, 0x67, 0xCC, 0xEA,
+0x17, 0x91, 0x1A, 0x65, 0x0A, 0x92, 0xFF, 0xF7,
+0x1F, 0x6D, 0xAC, 0xEF, 0xAC, 0xEA, 0xAC, 0xEB,
+0xAC, 0xE8, 0xAC, 0xE9, 0x30, 0xF0, 0x20, 0x6D,
+0x86, 0xF2, 0x00, 0x4D, 0xC6, 0xF3, 0xD8, 0x9D,
+0x0A, 0xD2, 0x8C, 0xEE, 0x36, 0x26, 0xC6, 0xF3,
+0x9C, 0x9D, 0x05, 0x6A, 0x4E, 0xEC, 0x31, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF2, 0x90, 0x9C,
+0xE9, 0xF0, 0xA4, 0x9D, 0x7F, 0x4A, 0x7C, 0x4A,
+0xAC, 0xEC, 0x4E, 0xEC, 0x26, 0x2C, 0x9D, 0x67,
+0x47, 0x44, 0x19, 0x4A, 0x40, 0xA2, 0xF4, 0xC4,
+0xE2, 0x37, 0x52, 0xC4, 0x58, 0x67, 0x53, 0xC4,
+0x47, 0x44, 0x21, 0x4A, 0x40, 0xA2, 0xF5, 0xC4,
+0x56, 0xC4, 0x0A, 0x94, 0x82, 0x32, 0x9D, 0x67,
+0x57, 0xC4, 0x02, 0x6A, 0x4B, 0xEA, 0x78, 0xC4,
+0x1A, 0xC4, 0x3C, 0xC4, 0x50, 0xC4, 0x62, 0x33,
+0x02, 0x30, 0x22, 0x31, 0x0C, 0x6A, 0x79, 0xC4,
+0x1B, 0xC4, 0x3D, 0xC4, 0x4F, 0xCC, 0x05, 0x95,
+0x04, 0x94, 0x06, 0x96, 0x07, 0x97, 0x00, 0x18,
+0xC0, 0x57, 0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90,
+0x08, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xA4, 0x01, 0xF2,
+0x58, 0x9A, 0x6C, 0x35, 0x49, 0xE5, 0xA3, 0xA4,
+0xA0, 0xC2, 0x84, 0xA4, 0xA1, 0x42, 0x80, 0xC5,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF2, 0x9C, 0x9C,
+0x40, 0x9A, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x2C, 0xF6, 0x9B, 0xA4, 0x03, 0x5C, 0x11, 0x60,
+0x25, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x40, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x64, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF7, 0x4C, 0x9A, 0x60, 0xDA,
+0xF0, 0x17, 0x03, 0x74, 0x13, 0x61, 0x00, 0xF4,
+0x00, 0x5A, 0x10, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x40, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0x4C, 0x9A,
+0x60, 0xDA, 0xF0, 0x17, 0x83, 0x67, 0x00, 0x18,
+0xC5, 0x75, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x20, 0xA4, 0x2E, 0x68, 0x30, 0xF0, 0x20, 0x6A,
+0x18, 0xE9, 0xAD, 0xF0, 0x00, 0x4A, 0x62, 0xA4,
+0x08, 0x6D, 0x6C, 0xED, 0x7E, 0x33, 0x7C, 0x33,
+0x12, 0xE8, 0x01, 0xE2, 0xD1, 0xA0, 0x7F, 0x6A,
+0xCC, 0xEA, 0x6D, 0xEA, 0x51, 0xC0, 0xC2, 0xA4,
+0x40, 0x6B, 0x6C, 0xEE, 0x80, 0x4B, 0xFF, 0x4B,
+0x4C, 0xEB, 0xCD, 0xEB, 0x71, 0xC0, 0xC1, 0xA4,
+0x1F, 0x6A, 0xCC, 0xEA, 0x44, 0xC0, 0xE2, 0xA4,
+0x04, 0x6A, 0x03, 0x6E, 0x4B, 0xEA, 0xCC, 0xEF,
+0x6C, 0xEA, 0xED, 0xEA, 0x51, 0xC0, 0x08, 0x2D,
+0x62, 0xA4, 0x6C, 0xEE, 0x0D, 0x6B, 0x6B, 0xEB,
+0xC8, 0x36, 0x4C, 0xEB, 0xCD, 0xEB, 0x71, 0xC0,
+0x61, 0xA4, 0xB2, 0xA0, 0x05, 0x6A, 0x7E, 0x33,
+0x4B, 0xEA, 0x68, 0x33, 0xAC, 0xEA, 0x6D, 0xEA,
+0x52, 0xC0, 0x41, 0xA4, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x60, 0x6D, 0xC8, 0xF7,
+0xD5, 0xA3, 0xAC, 0xEA, 0x56, 0x35, 0x04, 0x6A,
+0x4B, 0xEA, 0xCC, 0xEA, 0xAD, 0xEA, 0xC8, 0xF7,
+0x55, 0xC3, 0x62, 0xA4, 0xB1, 0xA0, 0x30, 0x6A,
+0x4C, 0xEB, 0x9F, 0x4A, 0xAC, 0xEA, 0x6D, 0xEA,
+0x51, 0xC0, 0x30, 0xF0, 0x20, 0x6D, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x4C, 0x9A, 0x01, 0xF2,
+0xB8, 0x9D, 0x2C, 0x33, 0x49, 0xE3, 0x03, 0x4C,
+0xAD, 0xE3, 0xA0, 0xA4, 0x01, 0x4C, 0xA0, 0xC2,
+0x01, 0x4A, 0x6A, 0xEA, 0xFA, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xC6, 0xF3,
+0x98, 0x9B, 0x01, 0x6A, 0x4C, 0xEC, 0x1F, 0x24,
+0xC6, 0xF3, 0x7C, 0x9B, 0x05, 0x5B, 0x1B, 0x61,
+0xD1, 0xA0, 0x64, 0xA0, 0x03, 0x6C, 0xDA, 0x37,
+0x04, 0xD3, 0x66, 0x67, 0x8C, 0xEB, 0x05, 0xD3,
+0xCA, 0x33, 0x8C, 0xEB, 0x06, 0xD3, 0x72, 0xA0,
+0xB1, 0x67, 0x4C, 0xEF, 0x6A, 0x33, 0x4C, 0xEB,
+0x07, 0xD3, 0xD2, 0x33, 0x8C, 0xEB, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF6, 0x0C, 0x4C, 0xDE, 0x36,
+0x08, 0xD3, 0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x11, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x0D, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x4C, 0x9A,
+0x2C, 0x33, 0x30, 0xF0, 0x20, 0x6C, 0x49, 0xE3,
+0xA0, 0x9A, 0x82, 0xF6, 0x10, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x4C, 0x9A, 0x2C, 0x33, 0x49, 0xE3, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x2C, 0xF6, 0x5B, 0xA2,
+0x01, 0x72, 0x16, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x50, 0x9A, 0x63, 0xEA, 0x10, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0x4C, 0x9A, 0x60, 0xDA, 0xF0, 0x17,
+0x51, 0xA0, 0x03, 0x6B, 0x4A, 0x32, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x2C, 0xF6, 0x79, 0xA3,
+0x05, 0x73, 0x11, 0x61, 0x38, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x78, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7,
+0x4C, 0x9A, 0x60, 0xDA, 0xF0, 0x17, 0x06, 0x73,
+0x12, 0x61, 0x02, 0x5A, 0x24, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7,
+0x4C, 0x9A, 0x60, 0xDA, 0xF0, 0x17, 0x07, 0x73,
+0x12, 0x61, 0x03, 0x72, 0x10, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x40, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF2,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7,
+0x4C, 0x9A, 0x60, 0xDA, 0xF0, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0x2C, 0xF6, 0x5C, 0xA2, 0x02, 0x72,
+0x15, 0x61, 0x51, 0xA0, 0x03, 0x6B, 0x52, 0x32,
+0x6C, 0xEA, 0x10, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x40, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF2, 0x64, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0x4C, 0x9A,
+0x60, 0xDA, 0xF0, 0x17, 0x91, 0x67, 0x00, 0x18,
+0xC5, 0x75, 0x76, 0xA0, 0x01, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x91, 0x67, 0x00, 0x18, 0x96, 0x76,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x40, 0xA4, 0x70, 0x69,
+0x30, 0xF0, 0x20, 0x68, 0x06, 0xD2, 0x81, 0xA4,
+0x86, 0xF2, 0x00, 0x48, 0x05, 0xD4, 0x05, 0x92,
+0x9E, 0x33, 0x07, 0xD3, 0x8C, 0xE9, 0x7D, 0x67,
+0x03, 0x6C, 0x8C, 0xEA, 0x87, 0x43, 0x11, 0x4C,
+0x60, 0xA4, 0x32, 0x31, 0x04, 0xD2, 0x9D, 0x67,
+0x09, 0xE1, 0x06, 0xF6, 0x6C, 0xC2, 0x67, 0x44,
+0x09, 0x4B, 0x80, 0xA3, 0x06, 0xF6, 0x8E, 0xC2,
+0x30, 0xF0, 0x20, 0x6C, 0x82, 0xF6, 0x1C, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x07, 0x92, 0x21, 0x22,
+0x06, 0xF6, 0x72, 0xA0, 0x01, 0x6A, 0x44, 0xE9,
+0x6D, 0xEA, 0x06, 0xF6, 0x52, 0xC0, 0xC6, 0xF3,
+0x58, 0x98, 0x10, 0x6B, 0x6C, 0xEA, 0x0D, 0x22,
+0xC6, 0xF3, 0x5C, 0x98, 0x05, 0x5A, 0x09, 0x61,
+0x04, 0x96, 0x06, 0x97, 0x30, 0xF0, 0x20, 0x6C,
+0xA2, 0xF6, 0x08, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x05, 0x93, 0x0C, 0x6D, 0x91, 0x67,
+0x6C, 0xED, 0xAA, 0x35, 0x00, 0x18, 0x37, 0x6C,
+0x23, 0x10, 0x06, 0xF6, 0x72, 0xA0, 0x01, 0x6A,
+0x44, 0xE9, 0x4F, 0xEA, 0x6C, 0xEA, 0x06, 0xF6,
+0x52, 0xC0, 0xC6, 0xF3, 0x58, 0x98, 0x10, 0x6B,
+0x6C, 0xEA, 0x0D, 0x22, 0xC6, 0xF3, 0x5C, 0x98,
+0x05, 0x5A, 0x09, 0x61, 0x04, 0x96, 0x06, 0x97,
+0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF6, 0x1C, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x45, 0xE1,
+0x01, 0x6A, 0x4B, 0xEA, 0x06, 0xF6, 0x4C, 0xC1,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x40, 0xA4, 0x2E, 0x69,
+0x04, 0x67, 0x38, 0xEA, 0x06, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A, 0x20, 0x6B,
+0x12, 0xE9, 0x25, 0xE2, 0x42, 0xA4, 0xBE, 0xA1,
+0x5B, 0xC1, 0x83, 0xA4, 0x21, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEC, 0xAC, 0xEA, 0x8D, 0xEA, 0x5E, 0xC1,
+0xA3, 0xA0, 0x01, 0x6C, 0x8C, 0xED, 0xFD, 0x4C,
+0x4C, 0xEC, 0xAD, 0xEC, 0x9E, 0xC1, 0xA3, 0xA0,
+0x02, 0x6A, 0x4C, 0xED, 0xFB, 0x4A, 0x8C, 0xEA,
+0xAD, 0xEA, 0x5E, 0xC1, 0xA3, 0xA0, 0x40, 0x6C,
+0x8C, 0xED, 0x80, 0x4C, 0xFF, 0x4C, 0x4C, 0xEC,
+0xAD, 0xEC, 0x9E, 0xC1, 0xA3, 0xA0, 0x7F, 0x6A,
+0x8C, 0xEA, 0xBE, 0x35, 0xBC, 0x35, 0xAD, 0xEA,
+0x5E, 0xC1, 0x83, 0xA0, 0x6C, 0xEA, 0x08, 0xD4,
+0x84, 0xA0, 0x20, 0xF0, 0x87, 0xC1, 0x85, 0xA0,
+0x07, 0xD4, 0x86, 0xA0, 0x09, 0xD4, 0x28, 0x22,
+0x06, 0x94, 0x00, 0x18, 0xAD, 0x77, 0xD1, 0xA1,
+0x03, 0x6A, 0x06, 0x94, 0xCA, 0x36, 0xBB, 0xA1,
+0x4C, 0xEE, 0xFF, 0x6B, 0x6C, 0xEE, 0x00, 0x18,
+0xA1, 0x75, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x12, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x0E, 0x61, 0xF1, 0xA1, 0x03, 0x6A,
+0x06, 0x95, 0xEA, 0x37, 0xDB, 0xA1, 0x4C, 0xEF,
+0x30, 0xF0, 0x20, 0x6C, 0xFF, 0x6B, 0xC2, 0xF6,
+0x14, 0x4C, 0x6C, 0xEF, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x10, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x0C, 0x61, 0xDB, 0xA1, 0xE3, 0xA0, 0x20, 0xF0,
+0x47, 0xA1, 0x06, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xE2, 0xF6, 0x14, 0x4C, 0x04, 0xD2, 0x00, 0x18,
+0x4D, 0x63, 0x08, 0x94, 0x08, 0x6A, 0x8C, 0xEA,
+0x1F, 0x22, 0x09, 0x92, 0x03, 0x68, 0x01, 0x6C,
+0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x8C, 0xEB,
+0x0D, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x09, 0x61, 0x06, 0x95, 0x07, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x02, 0xF7, 0x0C, 0x4C, 0xF0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x06, 0x94, 0x07, 0x95,
+0x00, 0x6E, 0xF0, 0x67, 0x00, 0x18, 0x9B, 0x6F,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x03, 0xA4, 0x44, 0xA4, 0xC0, 0xA4,
+0x00, 0x30, 0x00, 0x30, 0x00, 0xF6, 0x40, 0x32,
+0xA5, 0xA4, 0xE6, 0xA4, 0x0D, 0xEA, 0x01, 0xA4,
+0x82, 0xA4, 0x30, 0xF0, 0x20, 0x6B, 0x0D, 0xEA,
+0x80, 0x34, 0x86, 0xF2, 0x00, 0x4B, 0x8D, 0xEA,
+0xC6, 0xF3, 0x58, 0xDB, 0xE9, 0xF0, 0xC5, 0xC3,
+0x0A, 0x26, 0x01, 0x6C, 0x4C, 0xEC, 0x07, 0x24,
+0xE9, 0xF0, 0xA6, 0xC3, 0xE9, 0xF0, 0xE7, 0xC3,
+0x02, 0x25, 0x00, 0x18, 0x30, 0x77, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x4C, 0xEC, 0xC0, 0x4C, 0x4C, 0xEC, 0x0F, 0x5C,
+0x05, 0x67, 0x3A, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0x40, 0xF3, 0x10, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x85, 0x67, 0x00, 0x18,
+0x26, 0x65, 0x2E, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xFD, 0x65, 0x2A, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x03, 0x65, 0x26, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x9A, 0x64, 0x22, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x5F, 0x63, 0x1E, 0x10, 0x85, 0x67, 0x00, 0x18,
+0x53, 0x66, 0x1A, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xF5, 0x63, 0x16, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xE7, 0x20, 0x12, 0x10, 0x85, 0x67, 0x00, 0x18,
+0xC3, 0x65, 0x90, 0x67, 0x00, 0x18, 0x73, 0x62,
+0x0B, 0x10, 0x85, 0x67, 0x00, 0x18, 0x5B, 0x3A,
+0x07, 0x10, 0x85, 0x67, 0x00, 0x18, 0x50, 0x62,
+0x03, 0x10, 0x85, 0x67, 0x00, 0x18, 0x91, 0x66,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0x00, 0x6A, 0x40, 0xF2, 0x51, 0xC4, 0x40, 0xF2,
+0x50, 0xC4, 0x05, 0x6A, 0x40, 0xF2, 0x4F, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA0, 0xA4, 0x64, 0x67, 0x80, 0x6C, 0x30, 0xF0,
+0x20, 0x6A, 0x8B, 0xEC, 0x86, 0xF2, 0x00, 0x4A,
+0xAC, 0xEC, 0x06, 0xF6, 0x99, 0xC2, 0xA0, 0xA3,
+0x0F, 0x6C, 0xAC, 0xEC, 0x06, 0xF6, 0x96, 0xC2,
+0x81, 0xA3, 0x06, 0xF6, 0xB6, 0xA2, 0x06, 0xF6,
+0x97, 0xC2, 0x00, 0x6C, 0x01, 0x4D, 0x06, 0xF6,
+0x98, 0xC2, 0x01, 0x6C, 0x84, 0xED, 0xC6, 0xF3,
+0xB8, 0x9A, 0xFF, 0x4C, 0x06, 0xF6, 0x9C, 0xCA,
+0x10, 0xF0, 0x00, 0x6C, 0xAC, 0xEC, 0x0A, 0x24,
+0xA1, 0xA3, 0xC0, 0xA3, 0x06, 0xF6, 0xFC, 0xAA,
+0x30, 0xF0, 0x20, 0x6C, 0x22, 0xF7, 0x08, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0xA8, 0x9A, 0x24, 0x67, 0xA1, 0xF7,
+0x04, 0x6C, 0x00, 0x18, 0x78, 0x36, 0x01, 0x22,
+0x01, 0x6A, 0x64, 0x99, 0x02, 0x67, 0x10, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x07, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF7, 0x04, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x50, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x01, 0x6D,
+0x04, 0x67, 0xAB, 0xED, 0xA1, 0xF7, 0x04, 0x6C,
+0x00, 0x18, 0x78, 0x36, 0x64, 0x98, 0x40, 0xF2,
+0x52, 0xC8, 0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x08, 0x22, 0x40, 0xF2, 0xB2, 0xA8, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF7, 0x10, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x40, 0xF2, 0xD4, 0xAC, 0xFF, 0xF7, 0x1F, 0x6D,
+0x81, 0xF1, 0x10, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0xFF, 0x6D, 0x81, 0xF1, 0x14, 0x6C, 0x01, 0x4D,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x81, 0xF1, 0x14, 0x68, 0x90, 0x67,
+0x01, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x01, 0x6D, 0x90, 0x67, 0xC5, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x64, 0x9C, 0x10, 0xF0,
+0x00, 0x6A, 0xFF, 0x69, 0x05, 0x67, 0x6C, 0xEA,
+0x2C, 0xE8, 0xCC, 0xE9, 0x08, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x42, 0xF7, 0x1C, 0x4C, 0xB0, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x5D, 0x67,
+0x12, 0xC2, 0x33, 0xC2, 0x7D, 0x67, 0x2A, 0x6A,
+0x50, 0xC3, 0x02, 0x6A, 0x4F, 0xCB, 0x07, 0x97,
+0x04, 0x94, 0x05, 0x95, 0x06, 0x96, 0x00, 0x18,
+0xC0, 0x57, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x40, 0xF2, 0xB1, 0xA4, 0x04, 0x67,
+0x3B, 0x25, 0x40, 0xF2, 0xD0, 0xA4, 0x40, 0xF2,
+0x4F, 0xA4, 0xC3, 0xEA, 0x35, 0x61, 0x64, 0x9C,
+0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x62, 0xF7, 0x08, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x90, 0x67, 0x00, 0x18,
+0xAB, 0x66, 0x1C, 0x22, 0x90, 0x67, 0x00, 0x18,
+0xBC, 0x66, 0x40, 0xF2, 0x54, 0xA8, 0xFF, 0xF7,
+0x1F, 0x72, 0x14, 0x61, 0x40, 0xF2, 0xB2, 0xA8,
+0x64, 0x6A, 0x90, 0x67, 0x58, 0xED, 0x8F, 0xF7,
+0x1C, 0x4A, 0x12, 0xED, 0x55, 0xE5, 0x40, 0xF2,
+0x50, 0xA0, 0xA2, 0x35, 0xA2, 0x35, 0x01, 0x4A,
+0x40, 0xF2, 0x50, 0xC0, 0x40, 0xF2, 0xD0, 0xA0,
+0x00, 0x18, 0xDF, 0x66, 0x40, 0xF2, 0x50, 0xA0,
+0x01, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xCB, 0x66, 0x90, 0x67, 0x00, 0x18, 0xD5, 0x66,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x6B, 0x8C, 0xEB, 0x20, 0x5B, 0x00, 0x6A,
+0x02, 0x60, 0x01, 0x6A, 0x44, 0xEB, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0xE0, 0x4C, 0x8C, 0xEA,
+0x20, 0x5A, 0x00, 0x6A, 0x02, 0x60, 0x01, 0x6A,
+0x44, 0xEC, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x68, 0x44, 0xC8, 0x4B, 0x4C, 0xEB, 0x20, 0x5B,
+0x00, 0x6A, 0x02, 0x60, 0x01, 0x6A, 0x44, 0xEC,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x00, 0x18,
+0x16, 0x67, 0x0F, 0x6B, 0x4C, 0xEB, 0x43, 0x67,
+0x0C, 0xEA, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x00, 0x18,
+0x16, 0x67, 0x10, 0x6B, 0x6B, 0xEB, 0x4C, 0xEB,
+0x43, 0x67, 0x0C, 0xEA, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x16, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF2, 0x88, 0x9B, 0x01, 0x6B, 0x4C, 0xEC,
+0x0A, 0x2C, 0x90, 0x67, 0x00, 0x18, 0x1A, 0x67,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF2, 0x6C, 0x9B,
+0x4C, 0xEB, 0x01, 0x23, 0x01, 0x6B, 0x05, 0x97,
+0x04, 0x90, 0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x16, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF1, 0x88, 0x9B, 0x01, 0x6B, 0x4C, 0xEC,
+0x0A, 0x2C, 0x90, 0x67, 0x00, 0x18, 0x1A, 0x67,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF2, 0x70, 0x9B,
+0x4C, 0xEB, 0x01, 0x23, 0x01, 0x6B, 0x05, 0x97,
+0x04, 0x90, 0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x16, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF2, 0x74, 0x9B, 0x4C, 0xEB, 0x0D, 0x2B,
+0x90, 0x67, 0x00, 0x18, 0x1A, 0x67, 0x0F, 0x6B,
+0x4C, 0xEB, 0x07, 0x2B, 0x90, 0x67, 0x00, 0x18,
+0x1F, 0x67, 0xE0, 0xF3, 0x1F, 0x6B, 0x4C, 0xEB,
+0x01, 0x23, 0x01, 0x6B, 0x05, 0x97, 0x04, 0x90,
+0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x1A, 0x67,
+0xE1, 0xF7, 0x10, 0x6C, 0x4C, 0xEC, 0x01, 0x6B,
+0x0A, 0x2C, 0x90, 0x67, 0x00, 0x18, 0x1F, 0x67,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF2, 0x78, 0x9B,
+0x4C, 0xEB, 0x01, 0x23, 0x01, 0x6B, 0x05, 0x97,
+0x04, 0x90, 0xFF, 0x6A, 0x6C, 0xEA, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x90, 0x67,
+0x00, 0x18, 0x16, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF2, 0x7C, 0x9B, 0x4C, 0xEB, 0x10, 0x2B,
+0x90, 0x67, 0x00, 0x18, 0x1A, 0x67, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF2, 0x60, 0x9B, 0x4C, 0xEB,
+0x07, 0x2B, 0x90, 0x67, 0x00, 0x18, 0x1F, 0x67,
+0x0C, 0xF0, 0x18, 0x6B, 0x4C, 0xEB, 0x01, 0x23,
+0x01, 0x6B, 0x05, 0x97, 0x04, 0x90, 0xFF, 0x6A,
+0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x16, 0x67,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF2, 0x64, 0x9B,
+0x4C, 0xEB, 0x12, 0x2B, 0x90, 0x67, 0x00, 0x18,
+0x1A, 0x67, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF2,
+0x68, 0x9B, 0x4C, 0xEB, 0x09, 0x2B, 0x90, 0x67,
+0x00, 0x18, 0x1F, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF2, 0x6C, 0x9B, 0x4C, 0xEB, 0x01, 0x23,
+0x01, 0x6B, 0x05, 0x97, 0x04, 0x90, 0xFF, 0x6A,
+0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x1A, 0x67,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF2, 0x90, 0x9B,
+0x01, 0x6B, 0x4C, 0xEC, 0x0A, 0x2C, 0x90, 0x67,
+0x00, 0x18, 0x1F, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF2, 0x74, 0x9B, 0x4C, 0xEB, 0x01, 0x23,
+0x01, 0x6B, 0x05, 0x97, 0x04, 0x90, 0xFF, 0x6A,
+0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x63, 0x01, 0xD1, 0x00, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF2, 0x18, 0x9B, 0x30, 0xF0,
+0x20, 0x6F, 0x86, 0xF2, 0x00, 0x4F, 0x60, 0xA0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x1B, 0x65, 0x38, 0x67,
+0x7F, 0x6B, 0x2C, 0xEB, 0xE9, 0xF0, 0x69, 0xC7,
+0x60, 0xA0, 0x80, 0x68, 0x0B, 0xE8, 0x4C, 0xEB,
+0x0C, 0xEB, 0xE9, 0xF0, 0x6A, 0xC7, 0xE9, 0xF0,
+0x69, 0xA7, 0x4C, 0xED, 0x4C, 0xEE, 0x6E, 0xEC,
+0x53, 0x2C, 0x02, 0x5D, 0xF2, 0xF0, 0x60, 0x45,
+0x09, 0x61, 0x8E, 0x45, 0x4C, 0xEC, 0x02, 0x5C,
+0x44, 0x61, 0x08, 0x5D, 0x49, 0x60, 0xE9, 0xF0,
+0x4A, 0xA7, 0x3F, 0x22, 0x1F, 0xF7, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x5C, 0x9A, 0x4D, 0xE3, 0xC0, 0xC3,
+0x33, 0x10, 0x1F, 0x2A, 0x1F, 0xF7, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x98, 0x9A, 0x91, 0xE3, 0x40, 0xA4, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x98, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x91, 0xE3, 0x4D, 0xE3, 0x40, 0xA3, 0xFF, 0x6B,
+0x6C, 0xEA, 0x01, 0x4A, 0x6C, 0xEA, 0x40, 0xC4,
+0x13, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x5C, 0x9A, 0xFF, 0x6C, 0x4D, 0xE3, 0x40, 0xA3,
+0x8C, 0xEA, 0x01, 0x4A, 0x8C, 0xEA, 0x40, 0xC3,
+0x07, 0x10, 0x1F, 0xF7, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0xCE, 0x61, 0xCE, 0x17,
+0x01, 0x91, 0x00, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0xFE, 0x63, 0x03, 0xD1, 0x02, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF2, 0x58, 0x9A, 0xFF, 0x6B,
+0x80, 0x6E, 0x80, 0xA2, 0xE0, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF2, 0xBC, 0x9A, 0xCB, 0xEE,
+0x6C, 0xEC, 0x40, 0xA5, 0x00, 0xA5, 0x6C, 0xEA,
+0xB0, 0x67, 0x6C, 0xED, 0x00, 0xD5, 0xA3, 0x67,
+0xCC, 0xED, 0xEC, 0xED, 0xA0, 0xF2, 0x17, 0x25,
+0xCC, 0xEA, 0x6C, 0xEA, 0x09, 0x22, 0xA0, 0xF4,
+0x08, 0x6F, 0xA0, 0xF4, 0x04, 0x6D, 0x20, 0xF5,
+0x00, 0x4E, 0x80, 0xF4, 0x1C, 0x6A, 0x08, 0x10,
+0x80, 0xF4, 0x18, 0x6F, 0x80, 0xF4, 0x14, 0x6D,
+0x80, 0xF4, 0x10, 0x6E, 0x80, 0xF4, 0x0C, 0x6A,
+0x7F, 0x69, 0x2E, 0x68, 0x2C, 0xEC, 0x18, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0xAD, 0xF0, 0x00, 0x4B,
+0x12, 0xE8, 0x0D, 0xE3, 0x00, 0x90, 0x2C, 0xE8,
+0x01, 0x70, 0x80, 0xF1, 0x18, 0x60, 0x07, 0x20,
+0x02, 0x70, 0xC0, 0xF0, 0x1A, 0x60, 0x03, 0x70,
+0xE0, 0xF1, 0x19, 0x60, 0x8C, 0x12, 0x1F, 0xF7,
+0x00, 0x68, 0x4C, 0xE8, 0x05, 0x28, 0x30, 0xF0,
+0x20, 0x68, 0x41, 0xF0, 0x18, 0x98, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0x41, 0xF0, 0x1C, 0x98,
+0x3B, 0xA3, 0x01, 0xE2, 0x20, 0xC0, 0x01, 0x42,
+0x1F, 0xF7, 0x00, 0x69, 0x2C, 0xE8, 0x02, 0xF0,
+0x00, 0x70, 0x01, 0x60, 0x09, 0x28, 0x30, 0xF0,
+0x20, 0x68, 0x01, 0xF0, 0x38, 0x98, 0x25, 0xE2,
+0x00, 0xD1, 0x31, 0xA3, 0x19, 0x65, 0x08, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0x01, 0xF0, 0x3C, 0x98,
+0x25, 0xE2, 0x00, 0xD1, 0x11, 0xA3, 0x18, 0x65,
+0x38, 0x67, 0x03, 0x68, 0x2C, 0xE8, 0x00, 0x91,
+0x00, 0xC1, 0x02, 0x42, 0x1F, 0xF7, 0x00, 0x69,
+0x2C, 0xE8, 0x02, 0xF0, 0x00, 0x70, 0x01, 0x60,
+0x05, 0x28, 0x30, 0xF0, 0x20, 0x68, 0xE1, 0xF0,
+0x04, 0x98, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x68,
+0x81, 0xF2, 0x00, 0x98, 0x31, 0xA3, 0x01, 0xE2,
+0x3E, 0x31, 0x20, 0xC0, 0x03, 0x42, 0x1F, 0xF7,
+0x00, 0x69, 0x2C, 0xE8, 0x02, 0xF0, 0x00, 0x70,
+0x01, 0x60, 0x05, 0x28, 0x30, 0xF0, 0x20, 0x68,
+0x81, 0xF2, 0x04, 0x98, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x68, 0x81, 0xF2, 0x08, 0x98, 0x09, 0xE2,
+0x11, 0xA3, 0x03, 0x69, 0x12, 0x30, 0x2C, 0xE8,
+0x00, 0xC2, 0x1F, 0xF7, 0x00, 0x6A, 0xCC, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x5C, 0x9A, 0x00, 0xA3, 0x49, 0xE6,
+0x00, 0xC2, 0x41, 0x46, 0x1F, 0xF7, 0x00, 0x68,
+0x0C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x5C, 0x9A, 0x01, 0xA3, 0x49, 0xE6,
+0x00, 0xC2, 0x42, 0x46, 0x1F, 0xF7, 0x00, 0x68,
+0x0C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x04, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0x00, 0x9A, 0x52, 0xA3, 0x01, 0x69,
+0x01, 0xE6, 0x4A, 0x32, 0x2C, 0xEA, 0x40, 0xC0,
+0x43, 0x46, 0x1F, 0xF7, 0x00, 0x68, 0x0C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2, 0x44, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2,
+0x48, 0x9A, 0x59, 0xE6, 0x44, 0xA3, 0x40, 0xC6,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x5C, 0x9A, 0x55, 0xE5, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x4C, 0x9A, 0x8C, 0x33, 0x49, 0xE3,
+0x40, 0x9A, 0x40, 0xDD, 0x1F, 0xF7, 0x00, 0x6A,
+0xEC, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A, 0x5D, 0xE7,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x58, 0x9A,
+0x8C, 0x34, 0x51, 0xE4, 0x40, 0x9C, 0x40, 0xDF,
+0xB6, 0x11, 0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC,
+0x09, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0xF8, 0x9C, 0x91, 0xA3, 0x03, 0x68, 0xFD, 0xE2,
+0x8A, 0x34, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0xFC, 0x9C, 0x91, 0xA3, 0x03, 0x68,
+0xFD, 0xE2, 0x8A, 0x34, 0x0C, 0xEC, 0xFF, 0x68,
+0x0C, 0xEC, 0x80, 0xC7, 0x81, 0x42, 0x1F, 0xF7,
+0x00, 0x6F, 0xEC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x01, 0xF0, 0x98, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF0, 0x9C, 0x9C, 0xE3, 0xA3,
+0x91, 0xE2, 0xE0, 0xC4, 0x82, 0x42, 0x1F, 0xF7,
+0x00, 0x6F, 0xEC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xE1, 0xF0, 0x84, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF2, 0x80, 0x9C, 0xE5, 0xA3,
+0x91, 0xE2, 0xE0, 0xC4, 0x83, 0x42, 0x1F, 0xF7,
+0x00, 0x6F, 0xEC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x81, 0xF2, 0x84, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF2, 0x88, 0x9C, 0x89, 0xE2,
+0x86, 0xA3, 0x80, 0xC2, 0x1F, 0xF7, 0x00, 0x6A,
+0xCC, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A, 0x59, 0xE6,
+0x59, 0xA3, 0x40, 0xC6, 0x1F, 0xF7, 0x00, 0x6A,
+0xAC, 0xEA, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A, 0x20, 0xF0,
+0x82, 0xA3, 0x49, 0xE5, 0x80, 0xC2, 0x41, 0x45,
+0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x5C, 0x9A,
+0x20, 0xF0, 0x63, 0xA3, 0x49, 0xE5, 0x60, 0xC2,
+0x42, 0x45, 0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x44, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2,
+0x40, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF1,
+0x7C, 0xA3, 0x49, 0xE5, 0x60, 0xC2, 0x43, 0x45,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF2, 0x44, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF2, 0x48, 0x9A,
+0x55, 0xE5, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF1,
+0x5D, 0xA2, 0x40, 0xC5, 0xFC, 0x10, 0x1F, 0xF7,
+0x00, 0x6D, 0x4C, 0xED, 0x10, 0x2D, 0x30, 0xF0,
+0x20, 0x6D, 0x41, 0xF0, 0xD8, 0x9D, 0x30, 0xF0,
+0x20, 0x6D, 0x01, 0xF2, 0xAC, 0x9D, 0x94, 0x37,
+0xD9, 0xE2, 0xB5, 0xE7, 0xE0, 0xA5, 0xFF, 0x6D,
+0xEC, 0xED, 0xA0, 0xC6, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6E, 0x01, 0xF2, 0xCC, 0x9E, 0x94, 0x37,
+0x30, 0xF0, 0x20, 0x6D, 0xD9, 0xE7, 0xC0, 0xA6,
+0x41, 0xF0, 0xBC, 0x9D, 0xFF, 0x69, 0x2C, 0xEE,
+0xB5, 0xE2, 0xC0, 0xC5, 0xA1, 0x42, 0x1F, 0xF7,
+0x00, 0x6E, 0xCC, 0xED, 0x02, 0xF0, 0x00, 0x75,
+0x01, 0x60, 0x05, 0x2D, 0x30, 0xF0, 0x20, 0x6D,
+0x01, 0xF0, 0xB8, 0x9D, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x01, 0xF0, 0xBC, 0x9D, 0x30, 0xF0,
+0x20, 0x6E, 0x01, 0xF2, 0xC4, 0x9E, 0x94, 0x34,
+0xB5, 0xE2, 0xD1, 0xE4, 0xC0, 0xA4, 0xFF, 0x6C,
+0xCC, 0xEC, 0x80, 0xC5, 0x82, 0x42, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xE1, 0xF0, 0x84, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF2, 0x80, 0x9C, 0xB8, 0xA3,
+0x91, 0xE2, 0xA0, 0xC4, 0x83, 0x42, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0x81, 0xF2, 0x84, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x81, 0xF2, 0x88, 0x9C, 0x68, 0xA3,
+0x89, 0xE2, 0x60, 0xC2, 0x94, 0x10, 0x1F, 0xF7,
+0x00, 0x6B, 0x4C, 0xEB, 0x05, 0x2B, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x78, 0x9B, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x7C, 0x9B,
+0x69, 0xE2, 0x32, 0xF2, 0x0A, 0x44, 0x30, 0xF0,
+0x20, 0x6B, 0x08, 0x30, 0x86, 0xF2, 0x00, 0x4B,
+0x6D, 0xE0, 0x61, 0x9B, 0x60, 0xDA, 0x1F, 0xF7,
+0x00, 0x6A, 0xCC, 0xEA, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x14, 0x6B, 0x78, 0xEC, 0x59, 0xE6, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x12, 0xEB,
+0x49, 0xE3, 0xE9, 0xF1, 0x48, 0x9A, 0x40, 0xDE,
+0x1F, 0xF7, 0x00, 0x6A, 0xAC, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x5C, 0x9A, 0x14, 0x6B, 0x78, 0xEC, 0x55, 0xE5,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x12, 0xEB, 0x49, 0xE3, 0xE9, 0xF1, 0x4C, 0x9A,
+0x40, 0xDD, 0x1F, 0xF7, 0x00, 0x6A, 0xEC, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x78, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE4, 0xC9, 0xF6,
+0x54, 0xA2, 0x6D, 0xE7, 0x40, 0xC3, 0x41, 0x47,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x78, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x7C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x49, 0xE4, 0x49, 0xF7, 0x52, 0xA2, 0x6D, 0xE7,
+0x40, 0xC3, 0x42, 0x47, 0x1F, 0xF7, 0x00, 0x6B,
+0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x44, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF2, 0x40, 0x9A, 0x5D, 0xE7, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x51, 0xE4,
+0x09, 0xF7, 0x53, 0xA4, 0x40, 0xC7, 0x03, 0x91,
+0x02, 0x90, 0x02, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xAA, 0xEC, 0x64, 0x6A,
+0x31, 0x60, 0x2F, 0x24, 0x83, 0xED, 0x2D, 0x61,
+0x02, 0xF0, 0x00, 0x5D, 0x04, 0x6A, 0x0C, 0x61,
+0x04, 0xF0, 0x00, 0x5D, 0x03, 0x6A, 0x08, 0x61,
+0x08, 0xF0, 0x00, 0x5D, 0x02, 0x6A, 0x04, 0x61,
+0xEF, 0xF7, 0x1E, 0x4A, 0x43, 0xED, 0x58, 0x67,
+0xA4, 0xEA, 0x84, 0xEA, 0x00, 0x6B, 0x01, 0x6A,
+0xA6, 0x35, 0x83, 0xED, 0x11, 0x60, 0x81, 0xF4,
+0x00, 0x6E, 0xC7, 0xEB, 0xC9, 0xE2, 0x01, 0x75,
+0xFF, 0xF7, 0x1F, 0x6E, 0xCC, 0xEA, 0xB3, 0xE4,
+0x04, 0x61, 0x02, 0x5C, 0x04, 0x60, 0x01, 0x74,
+0x06, 0x60, 0x02, 0x2C, 0x04, 0x10, 0x02, 0x6D,
+0x01, 0x4B, 0x0C, 0x73, 0xE9, 0x61, 0x5A, 0x32,
+0x01, 0x10, 0x00, 0x6A, 0xFF, 0x6B, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x40, 0xA4, 0x60, 0xA5,
+0x60, 0xC4, 0x40, 0xC5, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0xA4, 0x35, 0x26, 0xF1, 0x0C, 0x4A, 0x49, 0xE5,
+0x40, 0xAA, 0x6C, 0xEC, 0xCC, 0xEB, 0x58, 0xEC,
+0xFF, 0xF7, 0x1F, 0x6C, 0x12, 0xEA, 0x8C, 0xEA,
+0x05, 0x23, 0x52, 0x35, 0x56, 0x33, 0x6D, 0xE5,
+0x49, 0xE3, 0x8C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x63, 0x9D, 0x81, 0x9D, 0xFF, 0xF7, 0x1F, 0x6A,
+0xEC, 0xEA, 0x61, 0xE4, 0xC1, 0xE0, 0xE2, 0x9D,
+0xC4, 0x9D, 0x20, 0x9D, 0xE4, 0x35, 0xC1, 0xE0,
+0xB5, 0xE0, 0x79, 0xE6, 0x55, 0xE5, 0x49, 0xE6,
+0x44, 0x32, 0x55, 0xE5, 0x00, 0x6A, 0x0A, 0x25,
+0x6B, 0xEB, 0xFF, 0xE3, 0x27, 0xE7, 0x93, 0xE1,
+0xB1, 0xE4, 0x83, 0xED, 0x64, 0x6A, 0x02, 0x61,
+0x00, 0x18, 0x55, 0x69, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x20, 0x5C, 0x01, 0x6B,
+0x03, 0x60, 0xE0, 0x4C, 0x4C, 0xEC, 0x00, 0x6B,
+0x68, 0x33, 0x75, 0xE5, 0x01, 0x6B, 0x64, 0xEC,
+0x80, 0x9D, 0x00, 0x6A, 0x8C, 0xEB, 0x01, 0x23,
+0x01, 0x6A, 0xFF, 0x6B, 0x6C, 0xEA, 0x20, 0xE8,
+0xFF, 0x6B, 0x44, 0x67, 0x6C, 0xEA, 0x6C, 0xEE,
+0x6C, 0xED, 0x82, 0x67, 0x03, 0x26, 0x88, 0x42,
+0xE8, 0x4C, 0x6C, 0xEC, 0x20, 0x5C, 0x0B, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF2, 0x78, 0x9B,
+0xAC, 0x35, 0xE0, 0x4C, 0x75, 0xE5, 0xFF, 0x6B,
+0xA0, 0x9D, 0x6C, 0xEC, 0x07, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF2, 0x6C, 0x9B, 0xAC, 0x35,
+0x75, 0xE5, 0xA0, 0x9D, 0x01, 0x6B, 0x64, 0xEC,
+0xAC, 0xEB, 0x01, 0x2B, 0xFF, 0x6A, 0x20, 0xE8,
+0xFF, 0x6A, 0x8C, 0xEA, 0x2E, 0x6B, 0x78, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xAD, 0xF0, 0x00, 0x4B,
+0x12, 0xEA, 0x49, 0xE3, 0x93, 0xA2, 0x7F, 0x6B,
+0x6C, 0xEC, 0x93, 0xC2, 0x92, 0xA2, 0x8C, 0xEB,
+0x72, 0xC2, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x86, 0xF2, 0x00, 0x4B, 0x4C, 0xEC,
+0xAC, 0xEA, 0x83, 0xF6, 0xBA, 0xA3, 0x32, 0x25,
+0x13, 0x74, 0x02, 0x60, 0x0B, 0x74, 0x05, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x0A, 0xF1, 0x7C, 0xA3,
+0x14, 0x10, 0x12, 0x74, 0x02, 0x60, 0x0A, 0x74,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x0A, 0xF1,
+0x7D, 0xA3, 0x0B, 0x10, 0x11, 0x74, 0x02, 0x60,
+0x09, 0x74, 0x05, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x0A, 0xF1, 0x7E, 0xA3, 0x02, 0x10, 0x83, 0xF6,
+0x7B, 0xA3, 0x7E, 0x34, 0x08, 0x2C, 0x1D, 0x5B,
+0x10, 0x60, 0x4D, 0xE3, 0x1D, 0x53, 0x0D, 0x60,
+0xFF, 0x6A, 0x6C, 0xEA, 0x20, 0xE8, 0x6B, 0xEB,
+0xFF, 0x6C, 0x8C, 0xEB, 0x43, 0xEB, 0x02, 0x61,
+0x00, 0x6A, 0x20, 0xE8, 0x6B, 0xE2, 0x8C, 0xEA,
+0x20, 0xE8, 0x1C, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x7F, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x35, 0x67,
+0x01, 0x6B, 0x12, 0x2A, 0x90, 0x67, 0x00, 0x18,
+0x45, 0x67, 0x02, 0x6B, 0x0D, 0x2A, 0x90, 0x67,
+0x00, 0x18, 0x55, 0x67, 0x03, 0x6B, 0x08, 0x2A,
+0x90, 0x67, 0x00, 0x18, 0x66, 0x67, 0x4B, 0xEB,
+0x4D, 0xEB, 0xC0, 0xF7, 0x62, 0x33, 0x68, 0x33,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0xFF, 0x6B,
+0xBD, 0x67, 0x20, 0xF4, 0x0D, 0x6A, 0x6C, 0xEC,
+0x40, 0xCD, 0x84, 0x34, 0x20, 0xF4, 0x0F, 0x6A,
+0x41, 0xCD, 0x91, 0xE5, 0x80, 0xAC, 0x1F, 0xF7,
+0x00, 0x6A, 0x8C, 0xEA, 0x02, 0xF0, 0x00, 0x72,
+0x01, 0x60, 0x0A, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x58, 0x9A, 0x51, 0xE4, 0x60, 0xA4,
+0x0E, 0x6A, 0x6C, 0xEA, 0x46, 0x32, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x5C, 0x9A,
+0x51, 0xE4, 0x80, 0xA4, 0x0E, 0x6A, 0x8C, 0xEA,
+0x47, 0x32, 0x6C, 0xEA, 0x01, 0x63, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD1, 0x00, 0xD0, 0xFF, 0x68,
+0x0C, 0xEC, 0x2E, 0x6A, 0x58, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A, 0xCC, 0xE8,
+0x60, 0xA5, 0x12, 0xEC, 0x91, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF2, 0x44, 0x9A, 0xE0, 0xA4,
+0xC1, 0xA4, 0x40, 0xA2, 0x1A, 0x65, 0x38, 0x67,
+0x20, 0x6A, 0x2C, 0xEA, 0x25, 0x2A, 0xFF, 0x73,
+0x01, 0x6A, 0x23, 0x60, 0x7F, 0x69, 0x43, 0x67,
+0x2C, 0xEA, 0x2C, 0xEF, 0x43, 0xEF, 0x05, 0x60,
+0x80, 0x6E, 0xCB, 0xEE, 0x6C, 0xEE, 0xED, 0xEE,
+0x02, 0x10, 0xC3, 0xEA, 0x01, 0x60, 0xC0, 0xC5,
+0x46, 0x72, 0x12, 0x61, 0x02, 0x70, 0x10, 0x61,
+0x6F, 0xA4, 0x10, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x72, 0x47, 0x6B,
+0x01, 0x60, 0x45, 0x6B, 0x80, 0xA5, 0x80, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0x6D, 0xEA, 0x40, 0xC5,
+0x00, 0x6A, 0x01, 0x91, 0x00, 0x90, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0x2E, 0x6B, 0x78, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0xAD, 0xF0, 0x00, 0x4B, 0x19, 0x6E, 0xCB, 0xEE,
+0x4C, 0xED, 0x12, 0xEC, 0x91, 0xE3, 0x72, 0xA4,
+0x6C, 0xEE, 0x04, 0x6B, 0xCC, 0xEB, 0x4C, 0xEB,
+0xD2, 0xC4, 0x53, 0x23, 0xD0, 0xA4, 0x80, 0x6B,
+0x6B, 0xEB, 0xCC, 0xEB, 0x4C, 0xEB, 0x4D, 0x23,
+0xEE, 0xA4, 0x07, 0x6E, 0x7F, 0x6B, 0xEC, 0xEE,
+0x4C, 0xEE, 0x03, 0x76, 0xAC, 0xEB, 0x1C, 0x61,
+0x47, 0x73, 0x06, 0x61, 0xD1, 0xA4, 0x0C, 0x6A,
+0xCC, 0xEA, 0x08, 0x72, 0xC5, 0x6A, 0x44, 0x60,
+0xC7, 0x75, 0x02, 0x60, 0x48, 0x75, 0x06, 0x61,
+0xD1, 0xA4, 0x0C, 0x6A, 0xCC, 0xEA, 0x08, 0x72,
+0x47, 0x6A, 0x3A, 0x60, 0xC5, 0x75, 0x33, 0x60,
+0x46, 0x75, 0x31, 0x60, 0x48, 0x43, 0xC3, 0x4A,
+0xFF, 0x6E, 0xCC, 0xEA, 0x05, 0x5A, 0x13, 0x10,
+0x02, 0x76, 0x07, 0x61, 0xBD, 0x75, 0x29, 0x60,
+0x3E, 0x75, 0x27, 0x60, 0xC8, 0x43, 0xCA, 0x4E,
+0x08, 0x10, 0x01, 0x76, 0x1E, 0x61, 0xB3, 0x75,
+0x22, 0x60, 0x34, 0x75, 0x20, 0x60, 0xC8, 0x43,
+0xD4, 0x4E, 0x4C, 0xEE, 0x02, 0x5E, 0x15, 0x60,
+0xBE, 0x35, 0x03, 0x25, 0x01, 0x4B, 0xFF, 0x6A,
+0x4C, 0xEB, 0x80, 0x6D, 0x4E, 0x43, 0xAB, 0xED,
+0xAD, 0xEA, 0xFF, 0x6D, 0xFF, 0x4B, 0xAC, 0xEA,
+0xB2, 0xA4, 0x65, 0xC4, 0x19, 0x6B, 0x6B, 0xEB,
+0xAC, 0xEB, 0x08, 0x6D, 0xAD, 0xEB, 0x72, 0xC4,
+0x20, 0xE8, 0xFF, 0x6A, 0x20, 0xE8, 0x45, 0x6A,
+0x20, 0xE8, 0x3D, 0x6A, 0x20, 0xE8, 0x33, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x2E, 0x6B, 0x78, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0xAD, 0xF0, 0x00, 0x4B,
+0x19, 0x6E, 0xCB, 0xEE, 0x4C, 0xED, 0x12, 0xEC,
+0x91, 0xE3, 0x72, 0xA4, 0x6C, 0xEE, 0x04, 0x6B,
+0xCC, 0xEB, 0x4C, 0xEB, 0xD2, 0xC4, 0x56, 0x23,
+0xD0, 0xA4, 0x80, 0x6B, 0x6B, 0xEB, 0xCC, 0xEB,
+0x4C, 0xEB, 0x50, 0x23, 0x0E, 0xA4, 0x07, 0x6F,
+0x7F, 0x6B, 0x0C, 0xEF, 0x4C, 0xEF, 0x80, 0x6E,
+0x03, 0x77, 0xAC, 0xEB, 0xAC, 0xEE, 0x14, 0x61,
+0x45, 0x73, 0x09, 0x61, 0xF1, 0xA4, 0x0C, 0x6A,
+0xEC, 0xEA, 0x08, 0x72, 0x04, 0x61, 0x47, 0x6A,
+0x3E, 0x2E, 0xC5, 0x6A, 0x3C, 0x10, 0x48, 0x43,
+0xC3, 0x4A, 0xFF, 0x6F, 0xEC, 0xEA, 0x04, 0x5A,
+0x35, 0x60, 0x00, 0x6A, 0xC8, 0x75, 0x13, 0x10,
+0x02, 0x77, 0x08, 0x61, 0xE8, 0x43, 0xCB, 0x4F,
+0x4C, 0xEF, 0x02, 0x5F, 0x2B, 0x60, 0x00, 0x6A,
+0xBE, 0x75, 0x09, 0x10, 0x01, 0x77, 0x26, 0x61,
+0xE8, 0x43, 0xD5, 0x4F, 0x4C, 0xEF, 0x02, 0x5F,
+0x21, 0x60, 0x00, 0x6A, 0xB4, 0x75, 0x01, 0x60,
+0x01, 0x6A, 0x15, 0x22, 0x05, 0x26, 0x80, 0x6D,
+0x41, 0x43, 0xAB, 0xED, 0xAD, 0xEA, 0x03, 0x10,
+0x80, 0x6A, 0x4B, 0xEA, 0x6D, 0xEA, 0xFF, 0x6D,
+0x01, 0x4B, 0xAC, 0xEA, 0xB2, 0xA4, 0x65, 0xC4,
+0x19, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB, 0x08, 0x6D,
+0xAD, 0xEB, 0x72, 0xC4, 0x08, 0x10, 0x41, 0x43,
+0x80, 0x6B, 0x6B, 0xEB, 0x6D, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x01, 0x10, 0xFF, 0x6A, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD1,
+0x00, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA, 0x05, 0x67,
+0x30, 0xF0, 0x20, 0x69, 0x25, 0xF0, 0xA4, 0x42,
+0x86, 0xF2, 0x00, 0x49, 0xA4, 0x35, 0x06, 0x93,
+0x35, 0xE5, 0xFF, 0xF7, 0x1F, 0x6C, 0x23, 0xAD,
+0x8C, 0xEE, 0x8C, 0xEF, 0x8C, 0xEB, 0xD3, 0xE4,
+0x22, 0xEC, 0x03, 0x61, 0x39, 0xE6, 0xC3, 0xCD,
+0x03, 0x10, 0x01, 0x6C, 0x8B, 0xEC, 0x83, 0xCD,
+0x30, 0xF0, 0x20, 0x6D, 0xE4, 0xF7, 0x84, 0x42,
+0x86, 0xF2, 0x00, 0x4D, 0x84, 0x34, 0xB1, 0xE4,
+0xA4, 0xAC, 0xFF, 0xF7, 0x1F, 0x6E, 0xFB, 0xE6,
+0xA2, 0xEE, 0x03, 0x61, 0xBD, 0xE7, 0xE4, 0xCC,
+0x03, 0x10, 0x01, 0x6D, 0xAB, 0xED, 0xA4, 0xCC,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0xCA, 0xF0, 0xAC, 0x9C, 0x6F, 0xEE, 0xA3, 0xEE,
+0xAD, 0xE3, 0x02, 0x60, 0x01, 0x6B, 0x6B, 0xEB,
+0xCA, 0xF0, 0x6C, 0xDC, 0x30, 0xF0, 0x20, 0x6C,
+0x65, 0xF0, 0x64, 0x42, 0x86, 0xF2, 0x00, 0x4C,
+0x64, 0x33, 0x07, 0x96, 0x8D, 0xE3, 0x84, 0xAB,
+0xFF, 0xF7, 0x1F, 0x6D, 0xD7, 0xE5, 0x83, 0xED,
+0x91, 0xE6, 0x02, 0x60, 0x01, 0x6C, 0x8B, 0xEC,
+0x84, 0xCB, 0xA5, 0xF0, 0x04, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x44, 0x32,
+0x69, 0xE2, 0x63, 0xAA, 0xFF, 0xF7, 0x1F, 0x6C,
+0x13, 0xE4, 0x63, 0xEC, 0x03, 0x61, 0x61, 0xE0,
+0x03, 0xCA, 0x03, 0x10, 0x01, 0x6B, 0x6B, 0xEB,
+0x63, 0xCA, 0x01, 0x91, 0x00, 0x90, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xED,
+0x6C, 0xEC, 0x0F, 0x2D, 0x48, 0x44, 0xFC, 0x4A,
+0x6C, 0xEA, 0x08, 0x5A, 0x1D, 0x61, 0x48, 0x44,
+0xF4, 0x4A, 0x6C, 0xEA, 0x08, 0x5A, 0x16, 0x61,
+0x48, 0x44, 0xEC, 0x4A, 0x6C, 0xEA, 0x08, 0x5A,
+0x0E, 0x10, 0x48, 0x44, 0xDC, 0x4A, 0x6C, 0xEA,
+0x0A, 0x5A, 0x0E, 0x61, 0x48, 0x44, 0xD2, 0x4A,
+0x6C, 0xEA, 0x0A, 0x5A, 0x07, 0x61, 0x48, 0x44,
+0xC8, 0x4A, 0x6C, 0xEA, 0x0A, 0x5A, 0x03, 0x6A,
+0x06, 0x61, 0x04, 0x10, 0x02, 0x6A, 0x03, 0x10,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x30, 0xF0,
+0x21, 0x6B, 0xD0, 0xF4, 0x7C, 0xA3, 0x03, 0x73,
+0x22, 0x61, 0x03, 0x72, 0x35, 0x60, 0x02, 0x72,
+0x11, 0x61, 0x08, 0x2D, 0x30, 0xF0, 0x20, 0x6A,
+0xE6, 0xF1, 0x04, 0x4A, 0x51, 0xE4, 0xFF, 0xF7,
+0x4C, 0xA4, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x06, 0xF2, 0x04, 0x4A, 0x51, 0xE4, 0xDF, 0xF7,
+0x4A, 0xA4, 0x20, 0xE8, 0x01, 0x72, 0x22, 0x61,
+0x05, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF1,
+0x1C, 0x4A, 0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE6, 0xF1, 0x18, 0x4A, 0x11, 0x10, 0x02, 0x72,
+0x13, 0x60, 0x01, 0x72, 0x13, 0x61, 0x08, 0x2D,
+0x30, 0xF0, 0x20, 0x6A, 0xC6, 0xF1, 0x14, 0x4A,
+0x51, 0xE4, 0xFF, 0xF7, 0x54, 0xA4, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE6, 0xF1, 0x0C, 0x4A,
+0x51, 0xE4, 0xDF, 0xF7, 0x54, 0xA4, 0x20, 0xE8,
+0x44, 0x67, 0x20, 0xE8, 0x00, 0x6A, 0x20, 0xE8,
+0x00, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0xA1, 0xF2,
+0x88, 0x9C, 0x01, 0x4A, 0x44, 0x33, 0x4B, 0x6D,
+0x91, 0xE3, 0xAB, 0xED, 0xA0, 0xC4, 0x30, 0xF0,
+0x20, 0x6C, 0xA1, 0xF2, 0x80, 0x9C, 0x1E, 0x72,
+0x8D, 0xE3, 0x35, 0x6C, 0x80, 0xC3, 0xED, 0x61,
+0x20, 0xE8, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x66, 0xF2, 0x6F, 0xA2, 0x28, 0x5B, 0x10, 0x61,
+0x00, 0x6B, 0x66, 0xF2, 0x6F, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF2, 0x44, 0x9A, 0x40, 0xA2,
+0x00, 0xF6, 0x40, 0x32, 0x00, 0xF6, 0x43, 0x32,
+0x00, 0x52, 0x80, 0xF0, 0x12, 0x60, 0x04, 0x10,
+0x01, 0x4B, 0x66, 0xF2, 0x6F, 0xC2, 0x8D, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0xAD, 0xF0, 0x0D, 0x48,
+0x00, 0x69, 0x91, 0x67, 0x00, 0x18, 0x14, 0x57,
+0x60, 0xA0, 0xEC, 0xA0, 0x30, 0xF0, 0x20, 0x6C,
+0x04, 0xD3, 0xFF, 0xF7, 0x7F, 0xA0, 0xB1, 0x67,
+0xC2, 0x67, 0x05, 0xD3, 0x00, 0xF0, 0x7B, 0xA8,
+0x62, 0xF7, 0x10, 0x4C, 0x01, 0x49, 0x06, 0xD3,
+0x00, 0x18, 0x4D, 0x63, 0x00, 0x6A, 0xFF, 0xF7,
+0x5F, 0xC0, 0x40, 0xC0, 0x03, 0x71, 0x00, 0x6A,
+0x00, 0xF0, 0x5B, 0xC8, 0x58, 0x67, 0x2E, 0x48,
+0x08, 0xD2, 0xDF, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF2, 0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0xC0, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF2, 0x50, 0x9A, 0x30, 0xF0,
+0x20, 0x69, 0xFF, 0x6B, 0xE0, 0xA2, 0xE7, 0xF3,
+0x59, 0xA0, 0x82, 0xF7, 0x10, 0x49, 0x6C, 0xEE,
+0x04, 0xD2, 0xE7, 0xF3, 0x4D, 0xA0, 0x6C, 0xEF,
+0x91, 0x67, 0x05, 0xD2, 0xE7, 0xF3, 0x4C, 0xA0,
+0x01, 0x6D, 0x06, 0xD2, 0x07, 0xF4, 0x48, 0xA8,
+0x07, 0xD2, 0x00, 0x18, 0x4D, 0x63, 0x00, 0x6A,
+0x7D, 0x67, 0xE7, 0xF3, 0x4C, 0xC0, 0xE7, 0xF3,
+0x4D, 0xC0, 0x47, 0x43, 0x19, 0x4A, 0x60, 0xAA,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2, 0x54, 0x9A,
+0x07, 0xF4, 0x68, 0xC8, 0x91, 0x67, 0xC0, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2, 0x58, 0x9A,
+0x02, 0x6D, 0xE0, 0xA2, 0x27, 0xF4, 0x47, 0xA0,
+0x04, 0xD2, 0x07, 0xF4, 0x5B, 0xA0, 0x05, 0xD2,
+0x07, 0xF4, 0x5A, 0xA0, 0x06, 0xD2, 0x27, 0xF4,
+0x56, 0xA8, 0x07, 0xD2, 0xFF, 0x6A, 0x4C, 0xEE,
+0x4C, 0xEF, 0x00, 0x18, 0x4D, 0x63, 0x00, 0x6B,
+0x5D, 0x67, 0x07, 0xF4, 0x7A, 0xC0, 0x07, 0xF4,
+0x7B, 0xC0, 0x67, 0x42, 0x19, 0x4B, 0x40, 0xAB,
+0xA6, 0xF5, 0xBC, 0x98, 0xC6, 0xF5, 0xC0, 0x98,
+0x30, 0xF0, 0x20, 0x6C, 0xA2, 0xF7, 0x14, 0x4C,
+0x27, 0xF4, 0x56, 0xC8, 0x00, 0x18, 0x4D, 0x63,
+0x08, 0x93, 0xA6, 0xF5, 0x7C, 0xD8, 0xC6, 0xF5,
+0x60, 0xD8, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x2E, 0x68, 0x18, 0xEC, 0x4C, 0xEF, 0x30, 0xF0,
+0x20, 0x6B, 0x0C, 0xD6, 0x0B, 0xD5, 0x05, 0xD7,
+0xAD, 0xF0, 0x00, 0x4B, 0x20, 0xA5, 0x12, 0xE8,
+0x01, 0xE3, 0x60, 0xA6, 0x04, 0xD3, 0xB1, 0xA0,
+0x03, 0x6B, 0x04, 0x96, 0xAC, 0xEB, 0x83, 0x67,
+0x4C, 0xEC, 0xC2, 0xEC, 0x03, 0x60, 0x0C, 0x92,
+0x60, 0xC2, 0xB0, 0x10, 0xA0, 0xF0, 0x0E, 0x24,
+0x2F, 0x59, 0xA0, 0xF0, 0x0B, 0x60, 0x30, 0x6B,
+0xAC, 0xEB, 0x4C, 0xEB, 0xA0, 0xF0, 0x06, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x0D, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x09, 0x61, 0x05, 0x95, 0x04, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0xC2, 0xF7, 0x00, 0x4C, 0xF1, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x05, 0x93, 0x01, 0x73,
+0x03, 0x60, 0x05, 0x6B, 0x01, 0x6A, 0x47, 0x10,
+0x04, 0x6B, 0x00, 0x6A, 0x44, 0x10, 0x05, 0x94,
+0x01, 0x74, 0x02, 0x61, 0x01, 0x4A, 0x01, 0x10,
+0xFF, 0x4A, 0xFF, 0x6B, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x48, 0x34, 0x60, 0xF1, 0x08, 0x4B,
+0x6D, 0xE4, 0xC0, 0xAB, 0xFF, 0x6C, 0x03, 0x6D,
+0x66, 0x67, 0x8C, 0xEB, 0x04, 0xD3, 0xC2, 0x33,
+0x8C, 0xEB, 0x91, 0xA0, 0x00, 0x69, 0xE4, 0x67,
+0xAC, 0xEF, 0x62, 0xEF, 0x08, 0x61, 0x0D, 0x6F,
+0x6C, 0xED, 0xEB, 0xEF, 0xA8, 0x35, 0x8C, 0xEF,
+0xAD, 0xEF, 0xF1, 0xC0, 0x01, 0x69, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0xF1, 0x08, 0x4C, 0x48, 0x32,
+0x49, 0xE4, 0xE1, 0xAA, 0xB1, 0xA0, 0x03, 0x6C,
+0xE2, 0x32, 0xAC, 0xEC, 0x42, 0xEC, 0x36, 0x61,
+0xE5, 0xC0, 0x20, 0xF0, 0x4C, 0xC0, 0x45, 0xA0,
+0xFF, 0x72, 0x30, 0x60, 0x92, 0xA0, 0x19, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0x08, 0x6C, 0x8D, 0xEA,
+0x52, 0xC0, 0x28, 0x10, 0x01, 0x4A, 0xFF, 0x6C,
+0x8C, 0xEA, 0x63, 0xEA, 0x4A, 0x60, 0x30, 0xF0,
+0x20, 0x6C, 0x48, 0x35, 0x60, 0xF1, 0x08, 0x4C,
+0x91, 0xE5, 0xA0, 0xAC, 0xFF, 0x6C, 0xC5, 0x67,
+0x8C, 0xEE, 0x2E, 0xEE, 0x05, 0x2E, 0xA2, 0x35,
+0x8C, 0xED, 0x04, 0x94, 0x8E, 0xED, 0xAB, 0x25,
+0x30, 0xF0, 0x20, 0x6C, 0x48, 0x35, 0x60, 0xF1,
+0x08, 0x4C, 0xB1, 0xE4, 0xA1, 0xAC, 0xFF, 0x6C,
+0xC5, 0x67, 0x8C, 0xEE, 0x2E, 0xEE, 0xDE, 0x2E,
+0x04, 0x96, 0xA2, 0x35, 0x8C, 0xED, 0xCE, 0xED,
+0xD9, 0x2D, 0x99, 0x17, 0x00, 0x68, 0x09, 0x21,
+0x5D, 0x67, 0x87, 0x42, 0x09, 0x4C, 0x0B, 0x92,
+0x80, 0xA4, 0x01, 0x68, 0x80, 0xC2, 0x0C, 0x92,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x0D, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x09, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0xC2, 0xF7, 0x1C, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x01, 0x10, 0x00, 0x68, 0x50, 0x67,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x68, 0xF0, 0x67, 0xD0, 0x67,
+0xE0, 0x17, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x65, 0x67, 0x4C, 0xEE, 0x4C, 0xEC,
+0x4C, 0xEB, 0xC0, 0xF0, 0x08, 0x2E, 0xC0, 0xF0,
+0x06, 0x2C, 0x8C, 0x43, 0x4C, 0xEC, 0x08, 0x5C,
+0x1B, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x98, 0x9A, 0x01, 0x6D,
+0xAC, 0xEC, 0xA0, 0xF0, 0x18, 0x24, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0xA0, 0xF0, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE5, 0xF3, 0x1C, 0x4A,
+0x4D, 0xE3, 0x30, 0xF0, 0x20, 0x6C, 0xE2, 0xF7,
+0x14, 0x4C, 0xFF, 0xF7, 0xBC, 0xA3, 0xA5, 0x10,
+0x04, 0x5B, 0x1A, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x98, 0x9A,
+0x01, 0x6D, 0xAC, 0xEC, 0x80, 0xF0, 0x1B, 0x24,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x80, 0xF0,
+0x16, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF4,
+0x04, 0x4A, 0x4D, 0xE3, 0x30, 0xF0, 0x20, 0x6C,
+0x03, 0xF0, 0x00, 0x4C, 0xA0, 0xA3, 0x89, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0x26, 0xF6, 0xD1, 0xA4, 0x30, 0x6D, 0xCC, 0xED,
+0x4C, 0xED, 0x10, 0x75, 0x3D, 0x61, 0xA8, 0x43,
+0xDC, 0x4D, 0xC5, 0x67, 0x4C, 0xEE, 0x0A, 0x5E,
+0x0E, 0x60, 0xC6, 0xF3, 0x58, 0x9C, 0x01, 0x6B,
+0x6C, 0xEA, 0x75, 0x22, 0xC6, 0xF3, 0x5C, 0x9C,
+0x05, 0x5A, 0x71, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x03, 0xF0, 0x0C, 0x4C, 0x6A, 0x10, 0xA8, 0x43,
+0xD2, 0x4D, 0xC5, 0x67, 0x4C, 0xEE, 0x0A, 0x5E,
+0x0E, 0x60, 0xC6, 0xF3, 0x58, 0x9C, 0x01, 0x6B,
+0x6C, 0xEA, 0x61, 0x22, 0xC6, 0xF3, 0x5C, 0x9C,
+0x05, 0x5A, 0x5D, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x03, 0xF0, 0x18, 0x4C, 0x56, 0x10, 0xA8, 0x43,
+0xC8, 0x4D, 0x4C, 0xED, 0x0A, 0x5D, 0x53, 0x60,
+0xC6, 0xF3, 0x58, 0x9C, 0x01, 0x6D, 0xAC, 0xEA,
+0x4E, 0x22, 0xC6, 0xF3, 0x5C, 0x9C, 0x05, 0x5A,
+0x4A, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xA8, 0x43,
+0x23, 0xF0, 0x04, 0x4C, 0xC8, 0x4D, 0x41, 0x10,
+0x42, 0x2D, 0xA8, 0x43, 0xFC, 0x4D, 0x4C, 0xED,
+0x0A, 0x5D, 0x10, 0x60, 0xC6, 0xF3, 0x58, 0x9C,
+0x01, 0x6D, 0xAC, 0xEA, 0x38, 0x22, 0xC6, 0xF3,
+0x5C, 0x9C, 0x05, 0x5A, 0x34, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xA8, 0x43, 0x23, 0xF0, 0x10, 0x4C,
+0xDC, 0x4D, 0x2B, 0x10, 0xA8, 0x43, 0xF2, 0x4D,
+0x4C, 0xED, 0x0A, 0x5D, 0x10, 0x60, 0xC6, 0xF3,
+0x58, 0x9C, 0x01, 0x6D, 0xAC, 0xEA, 0x23, 0x22,
+0xC6, 0xF3, 0x5C, 0x9C, 0x05, 0x5A, 0x1F, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xA8, 0x43, 0x23, 0xF0,
+0x1C, 0x4C, 0xF2, 0x4D, 0x16, 0x10, 0xA8, 0x43,
+0xE8, 0x4D, 0x4C, 0xED, 0x04, 0x5D, 0x13, 0x60,
+0xC6, 0xF3, 0x58, 0x9C, 0x01, 0x6C, 0x8C, 0xEA,
+0x0E, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x4C, 0xF6,
+0x5C, 0x9A, 0x05, 0x5A, 0x08, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xA8, 0x43, 0x43, 0xF0, 0x08, 0x4C,
+0xE8, 0x4D, 0x00, 0x18, 0x4D, 0x63, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6B, 0x44, 0x67, 0x6C, 0xEA, 0xAC, 0xEB,
+0x01, 0x73, 0x0B, 0x60, 0x03, 0x23, 0x02, 0x73,
+0x0F, 0x60, 0x16, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0x6D, 0xE2, 0x01, 0x6C,
+0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2,
+0x00, 0x4B, 0x6D, 0xE2, 0x03, 0x6C, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0x6D, 0xE2, 0x07, 0x6C, 0x06, 0xF6, 0x90, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xC6, 0xF3, 0x98, 0x9B, 0x10, 0x6D, 0xAC, 0xEC,
+0x0E, 0x24, 0xC6, 0xF3, 0x9C, 0x9B, 0x05, 0x5C,
+0x0A, 0x61, 0x6D, 0xE2, 0x06, 0xF6, 0xD0, 0xA3,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF0, 0x14, 0x4C,
+0xA2, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0xFF, 0x6E, 0x44, 0x67, 0x20, 0xF4, 0x0D, 0x6B,
+0x9D, 0x67, 0x68, 0xCC, 0xCC, 0xEA, 0x20, 0xF4,
+0x0F, 0x6B, 0x69, 0xCC, 0x44, 0x33, 0x6D, 0xE4,
+0x68, 0xAB, 0x1F, 0xF7, 0x00, 0x6C, 0xAC, 0xEE,
+0x6C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0,
+0x98, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF0, 0x9C, 0x9C, 0x91, 0xE3, 0xA0, 0xA4,
+0xF1, 0x6C, 0xAC, 0xEC, 0xC4, 0x35, 0x8D, 0xED,
+0x00, 0xF6, 0xA0, 0x34, 0x00, 0xF6, 0x83, 0x34,
+0xFF, 0x6D, 0xAC, 0xEC, 0x1F, 0xF7, 0x00, 0x6D,
+0x6C, 0xED, 0x02, 0xF0, 0x00, 0x75, 0x01, 0x60,
+0x05, 0x2D, 0x30, 0xF0, 0x20, 0x6D, 0x41, 0xF0,
+0xB8, 0x9D, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6D,
+0x41, 0xF0, 0xBC, 0x9D, 0xAD, 0xE3, 0x80, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B,
+0xC6, 0xF3, 0x98, 0x9B, 0x10, 0x6D, 0xAC, 0xEC,
+0x0B, 0x24, 0xC6, 0xF3, 0x7C, 0x9B, 0x05, 0x5B,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF0,
+0x0C, 0x4C, 0xA2, 0x67, 0x00, 0x18, 0x4D, 0x63,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x8C, 0xE9,
+0x86, 0xF2, 0x00, 0x48, 0x09, 0xE1, 0x06, 0xF6,
+0xB0, 0xA2, 0x91, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0x55, 0x6C, 0xC6, 0xF3, 0x58, 0x98, 0x10, 0x6B,
+0x6C, 0xEA, 0x0E, 0x22, 0xC6, 0xF3, 0x5C, 0x98,
+0x05, 0x5A, 0x0A, 0x61, 0x04, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0x83, 0xF0, 0x04, 0x4C, 0x06, 0xF6,
+0xD0, 0xA2, 0xB1, 0x67, 0x00, 0x18, 0x4D, 0x63,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF8, 0x63, 0x0F, 0x62,
+0x0E, 0xD1, 0x0D, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0xA1, 0xF2, 0x7C, 0x9B, 0x4C, 0xEC,
+0x08, 0xD4, 0x00, 0xA3, 0x10, 0x6B, 0x30, 0xF0,
+0x20, 0x69, 0x6C, 0xE8, 0x13, 0x30, 0x4C, 0xE8,
+0x86, 0xF2, 0x00, 0x49, 0x35, 0xE0, 0x06, 0xF6,
+0x4C, 0xA5, 0x06, 0xD5, 0x82, 0x67, 0x07, 0xD2,
+0x00, 0x18, 0x14, 0x57, 0x82, 0x67, 0x09, 0xD2,
+0x00, 0x18, 0xD8, 0x69, 0x06, 0x93, 0x0A, 0xD2,
+0xC6, 0xF3, 0x58, 0x99, 0x06, 0xF6, 0x6E, 0xA3,
+0x10, 0x6D, 0xAC, 0xEA, 0x06, 0xD3, 0x10, 0x22,
+0xC6, 0xF3, 0x5C, 0x99, 0x05, 0x5A, 0x0C, 0x61,
+0x06, 0xF6, 0x54, 0xA1, 0x07, 0x95, 0x08, 0x96,
+0x09, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF0,
+0x1C, 0x4C, 0x04, 0xD2, 0x00, 0x18, 0x4D, 0x63,
+0x08, 0x92, 0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x06, 0xF6, 0xB3, 0xA2,
+0x01, 0x6C, 0x64, 0x67, 0x64, 0xE8, 0xAD, 0xEB,
+0x06, 0xF6, 0x73, 0xC2, 0x06, 0x93, 0x0A, 0x95,
+0x01, 0x4B, 0xAE, 0xEB, 0x27, 0x2B, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x06, 0xF6, 0x93, 0xA2, 0x01, 0x6B, 0x64, 0xE8,
+0x6F, 0xEB, 0x8C, 0xEB, 0x06, 0xF6, 0x73, 0xC2,
+0x19, 0x10, 0x06, 0xF6, 0x74, 0xA2, 0x67, 0xE8,
+0x8C, 0xEB, 0x14, 0x23, 0xC6, 0xF3, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x0B, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF0, 0x1C, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x90, 0x67, 0x00, 0x18,
+0x80, 0x6C, 0x18, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x0B, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xC3, 0xF0, 0x08, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x55, 0x6C, 0x0F, 0x97, 0x0E, 0x91,
+0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x69,
+0x06, 0xD2, 0x8D, 0xF0, 0x0C, 0x49, 0x00, 0x68,
+0x40, 0xA1, 0x06, 0x93, 0x6E, 0xEA, 0x80, 0xF0,
+0x1D, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x07, 0xD2, 0x06, 0xF6, 0x52, 0xA2,
+0x01, 0x6B, 0x47, 0xE8, 0x6C, 0xEA, 0x80, 0xF0,
+0x11, 0x22, 0x06, 0x94, 0x00, 0x18, 0x14, 0x57,
+0x62, 0xA1, 0x82, 0x67, 0x09, 0xD2, 0x08, 0xD3,
+0x00, 0x18, 0xD8, 0x69, 0x07, 0x93, 0x0A, 0xD2,
+0xC6, 0xF3, 0x58, 0x9B, 0x10, 0x6B, 0x6C, 0xEA,
+0x10, 0x22, 0x07, 0x93, 0xC6, 0xF3, 0x5C, 0x9B,
+0x05, 0x5A, 0x0B, 0x61, 0x08, 0x92, 0x06, 0x95,
+0x09, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0xC3, 0xF0,
+0x14, 0x4C, 0xD0, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0x4D, 0x63, 0x08, 0x92, 0x0A, 0x93, 0x01, 0x4A,
+0x62, 0xEA, 0x21, 0x60, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x55, 0x6C, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x06, 0xF6, 0x94, 0xA2,
+0x01, 0x6B, 0x64, 0xE8, 0x6F, 0xEB, 0x8C, 0xEB,
+0x06, 0xF6, 0x74, 0xC2, 0xC6, 0xF3, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x57, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x53, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xE3, 0xF0, 0x1C, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x4B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x06, 0xF6,
+0x94, 0xA2, 0x01, 0x6B, 0x64, 0xE8, 0x8D, 0xEB,
+0x06, 0xF6, 0x74, 0xC2, 0xC6, 0xF3, 0x78, 0x9A,
+0x10, 0x6C, 0x8C, 0xEB, 0x0B, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x03, 0xF1, 0x08, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x06, 0xF6, 0x73, 0xA2,
+0x01, 0x6C, 0x67, 0xE8, 0x8C, 0xEB, 0x13, 0x23,
+0xC6, 0xF3, 0x78, 0x9A, 0x10, 0x6C, 0x8C, 0xEB,
+0x0A, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF1,
+0x14, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x90, 0x67,
+0x00, 0x18, 0x80, 0x6C, 0x13, 0x10, 0xC6, 0xF3,
+0x78, 0x9A, 0x10, 0x6C, 0x8C, 0xEB, 0x0A, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x23, 0xF1, 0x00, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x55, 0x6C, 0x01, 0x48, 0x02, 0x70,
+0x01, 0x49, 0x5F, 0xF7, 0x19, 0x61, 0x0F, 0x97,
+0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEE, 0x2E, 0x68, 0x18, 0xEE,
+0x30, 0xF0, 0x20, 0x6B, 0xAD, 0xF0, 0x00, 0x4B,
+0x4C, 0xEC, 0x4C, 0xEF, 0x4C, 0xED, 0x07, 0xD6,
+0x08, 0xD7, 0x12, 0xE8, 0x01, 0xE3, 0x7F, 0x6B,
+0x6C, 0xEC, 0x1F, 0x2D, 0x0C, 0x5C, 0x07, 0x60,
+0x30, 0xF0, 0x20, 0x69, 0x25, 0xF5, 0x0C, 0x49,
+0x85, 0xE1, 0x01, 0x6A, 0x37, 0x10, 0x08, 0x93,
+0xF4, 0x4C, 0x4C, 0xEC, 0x08, 0x2B, 0x03, 0x69,
+0x38, 0xEC, 0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF6,
+0x1C, 0x4A, 0x12, 0xEC, 0x29, 0x10, 0xE0, 0x4C,
+0x4C, 0xEC, 0x03, 0x69, 0x38, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0x45, 0xF6, 0x00, 0x4A, 0x12, 0xEC,
+0x1F, 0x10, 0x0C, 0x5C, 0x08, 0x60, 0x30, 0xF0,
+0x20, 0x69, 0x25, 0xF5, 0x18, 0x49, 0x01, 0x6B,
+0x85, 0xE1, 0x06, 0xD3, 0x18, 0x10, 0x08, 0x95,
+0xF4, 0x4C, 0x4C, 0xEC, 0x08, 0x2D, 0x03, 0x69,
+0x38, 0xEC, 0x30, 0xF0, 0x20, 0x6A, 0x45, 0xF7,
+0x00, 0x4A, 0x12, 0xEC, 0x09, 0x10, 0xE0, 0x4C,
+0x4C, 0xEC, 0x03, 0x69, 0x38, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0xE5, 0xF6, 0x04, 0x4A, 0x12, 0xEC,
+0x85, 0xE2, 0x00, 0x6A, 0x06, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61,
+0xA0, 0xA1, 0xC1, 0xA1, 0xE2, 0xA1, 0x30, 0xF0,
+0x20, 0x6C, 0x23, 0xF1, 0x0C, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x08, 0x61, 0x06, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0x43, 0xF1, 0x00, 0x4C, 0x03, 0x6E,
+0x00, 0x18, 0x4D, 0x63, 0x07, 0x94, 0xC0, 0xA1,
+0x04, 0x6D, 0x00, 0x18, 0xAC, 0x67, 0x07, 0x94,
+0xC1, 0xA1, 0x05, 0x6D, 0x00, 0x18, 0xAC, 0x67,
+0x07, 0x94, 0xC2, 0xA1, 0x06, 0x6D, 0x00, 0x18,
+0xAC, 0x67, 0x06, 0x93, 0x0D, 0x2B, 0x01, 0x6A,
+0x4B, 0xEA, 0x9D, 0x67, 0x00, 0x6D, 0x0A, 0xD1,
+0x50, 0xC4, 0x51, 0xC4, 0x52, 0xC4, 0x06, 0xD5,
+0x25, 0x67, 0x09, 0xD5, 0x0B, 0xD0, 0x0B, 0x10,
+0x80, 0xA1, 0x07, 0x95, 0x08, 0x96, 0x00, 0x18,
+0x9E, 0x69, 0x92, 0xA0, 0x19, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x72, 0xC0, 0x9F, 0x10, 0x0A, 0x92,
+0x00, 0xA2, 0x2C, 0x70, 0x04, 0x61, 0x08, 0x93,
+0x2C, 0x68, 0x01, 0x2B, 0x0C, 0x68, 0x07, 0x95,
+0x08, 0x96, 0x90, 0x67, 0x01, 0x49, 0x00, 0x18,
+0x9E, 0x69, 0xFF, 0x72, 0xFF, 0x6B, 0x6C, 0xE9,
+0x07, 0x61, 0x46, 0x70, 0x11, 0x60, 0x09, 0x94,
+0x91, 0xE1, 0x6C, 0xEC, 0x09, 0xD4, 0x07, 0x10,
+0x06, 0x96, 0xBD, 0x67, 0xD1, 0xE5, 0x01, 0x4E,
+0x6C, 0xEE, 0x50, 0xC4, 0x06, 0xD6, 0x0A, 0x92,
+0x03, 0x71, 0x01, 0x4A, 0x0A, 0xD2, 0xDB, 0x61,
+0x06, 0x92, 0x0B, 0x90, 0x03, 0x6B, 0xFF, 0x4A,
+0x6C, 0xEA, 0xB2, 0xA0, 0x4C, 0x34, 0x19, 0x6A,
+0x4B, 0xEA, 0xAC, 0xEA, 0x8D, 0xEA, 0x52, 0xC0,
+0x09, 0x94, 0xFF, 0x6A, 0x06, 0x5C, 0x6A, 0x60,
+0x34, 0xA0, 0x02, 0x6A, 0x32, 0x31, 0x6C, 0xE9,
+0x7E, 0xA0, 0x6C, 0xEA, 0x2C, 0x22, 0x6F, 0x41,
+0x01, 0x6A, 0x63, 0xEA, 0x28, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0xC6, 0xF3,
+0x98, 0x9B, 0x4C, 0xEC, 0x0A, 0x24, 0xC6, 0xF3,
+0x5C, 0x9B, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x43, 0xF1, 0x18, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0xBD, 0x67, 0x90, 0xA5, 0x00, 0x18,
+0x35, 0x67, 0x11, 0x2A, 0xDD, 0x67, 0x91, 0xA6,
+0x00, 0x18, 0x35, 0x67, 0x00, 0xF0, 0x11, 0x04,
+0x07, 0x2A, 0x5D, 0x67, 0x92, 0xA2, 0x00, 0x18,
+0x35, 0x67, 0x05, 0x22, 0x00, 0xF0, 0x12, 0x04,
+0x04, 0x05, 0x00, 0x18, 0x71, 0x69, 0x7E, 0xA0,
+0x40, 0x6A, 0x6C, 0xEA, 0x19, 0x22, 0x08, 0x93,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x26, 0xF2,
+0x08, 0x4A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x26, 0xF2, 0x00, 0x4A, 0xFF, 0x49, 0x01, 0x6B,
+0x23, 0xEB, 0x0A, 0x61, 0xBD, 0x67, 0x91, 0xA5,
+0x40, 0x9A, 0x64, 0xEC, 0x4C, 0xEB, 0x04, 0x23,
+0x01, 0x6A, 0x4B, 0xEA, 0x90, 0xC5, 0x51, 0xC5,
+0xDD, 0x67, 0x71, 0xA6, 0xFF, 0x73, 0x05, 0x60,
+0x52, 0xA6, 0xFF, 0x72, 0x02, 0x60, 0x66, 0xC0,
+0x0E, 0x10, 0x7D, 0x67, 0x51, 0xA3, 0xFF, 0x72,
+0x03, 0x60, 0x72, 0xA3, 0xFF, 0x73, 0x07, 0x60,
+0x9D, 0x67, 0x51, 0xA4, 0xFF, 0x72, 0x04, 0x61,
+0x52, 0xA4, 0xFF, 0x72, 0x01, 0x60, 0x45, 0xC0,
+0xBD, 0x67, 0x50, 0xA5, 0x0F, 0x97, 0x0E, 0x91,
+0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x00, 0x6B, 0x8C, 0xE9, 0x43, 0x67,
+0x91, 0x67, 0x87, 0xEB, 0x01, 0x6D, 0xAC, 0xEC,
+0x03, 0x24, 0x01, 0x4A, 0xFF, 0x6C, 0x8C, 0xEA,
+0x01, 0x4B, 0x04, 0x73, 0xF5, 0x61, 0x01, 0x72,
+0x2C, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0xA8, 0x9A, 0x21, 0xF1, 0x1C, 0x68, 0x90, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x01, 0x71,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x90, 0x67,
+0x41, 0xF0, 0xA4, 0x9A, 0x07, 0x10, 0x02, 0x71,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0xAC, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0xD2, 0x11,
+0x04, 0x71, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0xC0, 0xF7, 0xA8, 0x9A, 0xF6, 0x17,
+0x08, 0x71, 0xC0, 0xF1, 0x09, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x90, 0x67, 0x81, 0xF1, 0xB8, 0x9A,
+0xED, 0x17, 0x02, 0x72, 0xA0, 0xF0, 0x11, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0xA8, 0x9A,
+0x21, 0xF1, 0x1C, 0x68, 0x90, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x41, 0xF1, 0x00, 0x6C,
+0xF0, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x03, 0x71, 0x1C, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0xA4, 0x9A, 0x90, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF2, 0xAC, 0x9A, 0x90, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x41, 0xF1, 0x00, 0x6C,
+0x00, 0xF3, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x41, 0xF1, 0x00, 0x6C, 0x01, 0xF4,
+0x00, 0x6D, 0x81, 0x10, 0x05, 0x71, 0x15, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0xA4, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xA8, 0x9A,
+0x90, 0x67, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x41, 0xF1, 0x00, 0x6C, 0x00, 0xF3, 0x00, 0x6D,
+0x2D, 0x10, 0x09, 0x71, 0x15, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0xA4, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF1, 0xB8, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x41, 0xF1,
+0x00, 0x6C, 0x00, 0xF3, 0x00, 0x6D, 0x4C, 0x10,
+0x06, 0x71, 0x1C, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF2, 0xAC, 0x9A, 0x90, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xA8, 0x9A, 0x90, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x41, 0xF1, 0x00, 0x6C,
+0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x41, 0xF1, 0x00, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x35, 0x10, 0x0A, 0x71, 0x15, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0xAC, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0xB8, 0x9A,
+0x90, 0x67, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x41, 0xF1, 0x00, 0x6C, 0x01, 0xF4, 0x00, 0x6D,
+0x17, 0x10, 0x0C, 0x71, 0x20, 0xF1, 0x0C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xA8, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0xB8, 0x9A,
+0x90, 0x67, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x41, 0xF1, 0x00, 0x6C, 0x06, 0xF0, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x41, 0xF1,
+0x00, 0x6C, 0x18, 0xF0, 0x00, 0x6D, 0x01, 0x6E,
+0x0D, 0x11, 0x03, 0x72, 0x00, 0xF1, 0x0C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0xA8, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0xD1, 0x67, 0x41, 0xF1,
+0x00, 0x68, 0x00, 0x18, 0x86, 0x36, 0x90, 0x67,
+0xF0, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0xB0, 0x9A,
+0x90, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x07, 0x71, 0x2C, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x24, 0x9A, 0x21, 0xF1, 0x1C, 0x6C,
+0x00, 0x6E, 0xB1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0xAC, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xA8, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x02, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0x01, 0xF4, 0x00, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0x06, 0xF0,
+0x00, 0x6D, 0x2D, 0x10, 0x0B, 0x71, 0x3C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0xA4, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x2C, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x01, 0x6E,
+0xB1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF1, 0xB8, 0x9A, 0x21, 0xF1,
+0x1C, 0x6C, 0x02, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0x00, 0xF3, 0x00, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0x01, 0xF4,
+0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0x18, 0xF0, 0x00, 0x6D, 0x02, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0xA0, 0x9A, 0x90, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x90, 0x67, 0xC1, 0xF2, 0xB4, 0x9A, 0x80, 0x10,
+0x0D, 0x71, 0x41, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x24, 0x9A, 0x21, 0xF1, 0x1C, 0x6C,
+0x00, 0x6E, 0xB1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xA8, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1,
+0xB8, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x02, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0x06, 0xF0, 0x00, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0x18, 0xF0,
+0x00, 0x6D, 0x02, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0xA0, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0xB1, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x90, 0x67,
+0xC1, 0xF2, 0xAC, 0x9A, 0x42, 0x10, 0x0E, 0x71,
+0x43, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x2C, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x00, 0x6E,
+0xB1, 0x67, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xA8, 0x9A, 0x21, 0xF1,
+0x1C, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0xB8, 0x9A,
+0x21, 0xF1, 0x1C, 0x6C, 0x02, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x90, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x90, 0x67,
+0x06, 0xF0, 0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x90, 0x67, 0x18, 0xF0, 0x00, 0x6D,
+0x02, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF2, 0xB4, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0xA4, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x90, 0x67,
+0xB1, 0x67, 0x02, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF4, 0x63, 0x17, 0x62,
+0x16, 0xD1, 0x15, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x86, 0xF2, 0x00, 0x48, 0x4A, 0xF2, 0x5D, 0xA0,
+0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF1, 0x00, 0x4C,
+0xA2, 0x67, 0x0D, 0xD2, 0x00, 0x18, 0x4D, 0x63,
+0x0D, 0x93, 0x28, 0x2B, 0x30, 0xF0, 0x20, 0x69,
+0xAD, 0xF0, 0x00, 0x49, 0x00, 0x68, 0x90, 0x67,
+0x00, 0x18, 0xAA, 0x13, 0x1A, 0x22, 0x71, 0xA1,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x13, 0x2A, 0x90, 0x67, 0x00, 0x18,
+0x14, 0x57, 0xFF, 0x6B, 0x0C, 0xEB, 0x0A, 0x2B,
+0x7F, 0x6D, 0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6C,
+0xFF, 0x6A, 0x63, 0xF1, 0x0C, 0x4C, 0x4C, 0xED,
+0x00, 0x18, 0x4D, 0x63, 0x90, 0x67, 0x00, 0x18,
+0xBE, 0x77, 0x01, 0x48, 0x3F, 0x70, 0x2E, 0x49,
+0xDE, 0x61, 0xB1, 0x10, 0x0D, 0x92, 0xFF, 0x6B,
+0xFF, 0x4A, 0x6C, 0xEA, 0x03, 0x5A, 0xA0, 0xF0,
+0x07, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x6F, 0xF3,
+0x0C, 0x4B, 0x10, 0xD3, 0x0D, 0x93, 0x30, 0xF0,
+0x20, 0x6A, 0x6F, 0xF4, 0x08, 0x4A, 0x61, 0xE0,
+0x30, 0xF0, 0x20, 0x69, 0x0F, 0xD2, 0x46, 0xF6,
+0x03, 0x48, 0x00, 0x6A, 0xAD, 0xF0, 0x00, 0x49,
+0x11, 0xD0, 0x0C, 0xD2, 0x0C, 0x94, 0x00, 0x18,
+0xAA, 0x13, 0x7D, 0x22, 0x71, 0xA1, 0x80, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x76, 0x2A, 0x10, 0x92, 0x0F, 0x95, 0x06, 0x00,
+0x40, 0x9A, 0x90, 0x67, 0x14, 0x6E, 0x6C, 0xEA,
+0x0C, 0x93, 0x0E, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x69, 0xE2, 0xC9, 0xF6,
+0x54, 0xA2, 0x12, 0xD2, 0x00, 0x18, 0xB9, 0x20,
+0x0C, 0x94, 0x0E, 0x96, 0x12, 0x97, 0xB0, 0x67,
+0x00, 0x18, 0x80, 0x69, 0x64, 0x6B, 0x4B, 0xE3,
+0x11, 0x93, 0x40, 0xC3, 0x0C, 0x92, 0xFF, 0x6B,
+0x6C, 0xEA, 0x1C, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF1, 0x18, 0x4C, 0x00, 0x6D, 0x00, 0x18,
+0x4D, 0x63, 0x09, 0x92, 0x06, 0x95, 0x07, 0x96,
+0x04, 0xD2, 0x08, 0x97, 0x0A, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0x83, 0xF1, 0x00, 0x4C, 0x05, 0xD2,
+0x00, 0x18, 0x4D, 0x63, 0x11, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF1, 0x04, 0x4C, 0xA0, 0xA2,
+0x00, 0x18, 0x4D, 0x63, 0x0C, 0x94, 0x00, 0x18,
+0xBE, 0x77, 0x0D, 0x93, 0x03, 0x73, 0x33, 0x61,
+0x20, 0xF0, 0x44, 0xA1, 0x20, 0xF0, 0x65, 0xA1,
+0x63, 0xEA, 0x05, 0x61, 0x20, 0xF0, 0x66, 0xA1,
+0x00, 0x68, 0x63, 0xEA, 0x0A, 0x60, 0x20, 0xF0,
+0x05, 0xA1, 0x20, 0xF0, 0x46, 0xA1, 0x43, 0xE8,
+0x18, 0x67, 0x01, 0x58, 0x18, 0x67, 0x02, 0x6A,
+0x03, 0xE2, 0x0C, 0x93, 0xFF, 0x6A, 0x6C, 0xEA,
+0x1A, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x49, 0xE0, 0x4A, 0xF2, 0x98, 0xA2,
+0x0E, 0xD2, 0x00, 0x18, 0xE2, 0x6D, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF1, 0x0C, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x0E, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF1, 0x18, 0x4C, 0x4A, 0xF2,
+0xB8, 0xA2, 0x00, 0x18, 0x4D, 0x63, 0x0C, 0x93,
+0x10, 0x92, 0x2E, 0x49, 0x01, 0x4B, 0x0C, 0xD3,
+0x0F, 0x93, 0x04, 0x4A, 0x10, 0xD2, 0x14, 0x4B,
+0x11, 0x92, 0x0F, 0xD3, 0x0C, 0x93, 0x2E, 0x4A,
+0x11, 0xD2, 0x3F, 0x73, 0x7F, 0xF7, 0x0E, 0x61,
+0x0D, 0x92, 0x03, 0x5A, 0x1B, 0x60, 0x0D, 0x93,
+0x30, 0xF0, 0x20, 0x68, 0x86, 0xF2, 0x00, 0x48,
+0x05, 0xE3, 0x4A, 0xF2, 0xB8, 0xA1, 0x30, 0xF0,
+0x20, 0x6C, 0xC3, 0xF1, 0x08, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x4A, 0xF2, 0x98, 0xA1, 0x00, 0x18,
+0xE2, 0x6D, 0x01, 0x6A, 0x4A, 0xF2, 0x5E, 0xC0,
+0x4A, 0xF2, 0x5D, 0xA0, 0x01, 0x4A, 0x4A, 0xF2,
+0x5D, 0xC0, 0x12, 0x10, 0x0D, 0x90, 0x03, 0x6A,
+0x4E, 0xE8, 0x0E, 0x28, 0x30, 0xF0, 0x20, 0x6C,
+0xC3, 0xF1, 0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x4A, 0xF2, 0x1E, 0xC2, 0x4A, 0xF2, 0x1D, 0xC2,
+0x17, 0x97, 0x16, 0x91, 0x15, 0x90, 0x0C, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x4C, 0xEE,
+0x2E, 0x68, 0x18, 0xEE, 0x12, 0x91, 0x13, 0x93,
+0x4C, 0xEF, 0x4C, 0xEC, 0x4C, 0xED, 0x4C, 0xE9,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0xAD, 0xF0,
+0x00, 0x4A, 0x08, 0xD7, 0x12, 0xE8, 0x01, 0xE2,
+0x5C, 0xA0, 0xEE, 0xEA, 0x05, 0x2A, 0xFF, 0xA0,
+0x03, 0x6A, 0xEC, 0xEA, 0x2E, 0xEA, 0x25, 0x22,
+0x5D, 0x67, 0xE7, 0x42, 0x19, 0x4F, 0xE0, 0xA7,
+0xA4, 0x35, 0x8D, 0xED, 0xF2, 0xC2, 0xD3, 0xC2,
+0x76, 0xC2, 0xB4, 0xC2, 0x59, 0xA0, 0x7D, 0x67,
+0x38, 0xC3, 0x57, 0xC3, 0x0C, 0x6A, 0x50, 0xC3,
+0x07, 0x6A, 0x4F, 0xCB, 0x04, 0x94, 0x05, 0x95,
+0x06, 0x96, 0x07, 0x97, 0x00, 0x18, 0xC0, 0x57,
+0x5D, 0x67, 0x67, 0x42, 0x19, 0x4B, 0x40, 0xA3,
+0x9F, 0xA0, 0x03, 0x6B, 0x5C, 0xC0, 0x04, 0x6A,
+0x4B, 0xEA, 0x2C, 0xEB, 0x8C, 0xEA, 0x6D, 0xEA,
+0x5F, 0xC0, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x7D, 0x67,
+0x4C, 0xEE, 0x4C, 0xEF, 0x20, 0xF0, 0xBC, 0xC3,
+0x08, 0xD6, 0x06, 0xD7, 0x24, 0x67, 0x20, 0xF0,
+0x9C, 0xA3, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF2,
+0x64, 0x9B, 0x4C, 0xE9, 0x07, 0xD4, 0x34, 0x34,
+0x6D, 0xE4, 0x60, 0xA3, 0x91, 0x67, 0x0F, 0x05,
+0x6C, 0xEA, 0xC7, 0x67, 0x09, 0xD2, 0x00, 0x18,
+0xFE, 0x69, 0x00, 0xF1, 0x06, 0x2A, 0x2E, 0x68,
+0x18, 0xE9, 0x30, 0xF0, 0x20, 0x6A, 0xAD, 0xF0,
+0x00, 0x4A, 0x12, 0xE8, 0x01, 0xE2, 0x08, 0x92,
+0x40, 0x2A, 0x63, 0xA0, 0x48, 0xA0, 0x6E, 0xEA,
+0x05, 0x22, 0x7D, 0x67, 0x87, 0x43, 0x19, 0x4C,
+0x60, 0xAC, 0x75, 0xC8, 0x72, 0xA0, 0x41, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x52, 0xC0, 0x9D, 0x67,
+0x20, 0xF0, 0x5C, 0xA4, 0x6E, 0xA0, 0xD1, 0x67,
+0x43, 0xC0, 0x00, 0x6A, 0x59, 0xC0, 0x5A, 0xC0,
+0x10, 0x6A, 0x6D, 0xEA, 0x4E, 0xC0, 0x06, 0x95,
+0x20, 0xF0, 0xFC, 0xA4, 0x00, 0x6A, 0x82, 0x67,
+0x04, 0xD5, 0xA2, 0x67, 0x05, 0xD2, 0x00, 0x18,
+0x77, 0x6F, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x75, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x71, 0x61, 0x5D, 0x67, 0x20, 0xF0,
+0xDC, 0xA2, 0x06, 0x97, 0x30, 0xF0, 0x20, 0x6C,
+0xE3, 0xF1, 0x00, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x00, 0x6B, 0x07, 0xD3, 0x43, 0x67,
+0x69, 0x10, 0x07, 0x94, 0x7F, 0x6A, 0x40, 0x6B,
+0x8C, 0xEA, 0x92, 0xA0, 0xBD, 0x67, 0x8D, 0xEB,
+0x72, 0xC0, 0x20, 0xF0, 0x7C, 0xA5, 0x8E, 0xA0,
+0x63, 0xC0, 0x11, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x6E, 0xC0, 0x86, 0xF2,
+0x00, 0x4C, 0x30, 0xF0, 0x20, 0x6B, 0x45, 0xF5,
+0x04, 0x4B, 0x91, 0xE2, 0x6D, 0xE2, 0x68, 0xF7,
+0x9E, 0xA4, 0x60, 0xA3, 0xA4, 0x44, 0x62, 0xED,
+0x01, 0x60, 0x8F, 0xE3, 0x78, 0xC0, 0x30, 0xF0,
+0x20, 0x6B, 0x85, 0xF7, 0x08, 0x4B, 0x69, 0xE2,
+0x9B, 0xA0, 0x40, 0xA2, 0x43, 0xEC, 0x03, 0x60,
+0x58, 0xA0, 0x04, 0x4A, 0x58, 0xC0, 0x7D, 0x67,
+0x20, 0xF0, 0x5C, 0x83, 0x00, 0x52, 0x03, 0x60,
+0x58, 0xA0, 0x05, 0x4A, 0x58, 0xC0, 0x6E, 0xA0,
+0x08, 0x6A, 0x6C, 0xEA, 0x0B, 0x22, 0x5D, 0x67,
+0x20, 0xF0, 0xDC, 0xA2, 0xF8, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0xE3, 0xF1, 0x14, 0x4C, 0xB1, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x18, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x14, 0x61, 0x7D, 0x67,
+0x20, 0xF0, 0xDC, 0xA3, 0x58, 0xA0, 0x06, 0x97,
+0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF2, 0x04, 0x4C,
+0xB1, 0x67, 0x04, 0xD2, 0x00, 0x18, 0x4D, 0x63,
+0x01, 0x6C, 0x07, 0xD4, 0x06, 0x10, 0x00, 0x6D,
+0x07, 0xD5, 0x45, 0x67, 0x03, 0x10, 0x01, 0x6A,
+0x07, 0xD2, 0x40, 0x6A, 0x06, 0x95, 0x09, 0x94,
+0x07, 0x6B, 0x8C, 0xEB, 0xAC, 0x34, 0x8D, 0xE3,
+0x4D, 0xEB, 0x00, 0xF6, 0x60, 0x33, 0x00, 0xF6,
+0x63, 0x33, 0x06, 0xD3, 0x06, 0x92, 0xFF, 0x6B,
+0x6C, 0xEA, 0x06, 0xD2, 0x96, 0xA0, 0x01, 0x6A,
+0x8C, 0xEA, 0x6C, 0xEA, 0x0C, 0x22, 0x7D, 0x67,
+0x20, 0xF0, 0xBC, 0xA3, 0x91, 0x67, 0x00, 0x18,
+0x3E, 0x21, 0x20, 0x59, 0x36, 0x60, 0x06, 0x94,
+0xBF, 0x6A, 0x4C, 0xEC, 0x06, 0xD4, 0x5D, 0x67,
+0x20, 0xF0, 0xDC, 0xA2, 0x91, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0xAC, 0x67, 0x06, 0x96, 0x91, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0xAC, 0x67, 0x91, 0x67,
+0x00, 0x18, 0xDE, 0x6C, 0x7D, 0x67, 0x20, 0xF0,
+0xBC, 0xA3, 0x08, 0x96, 0x91, 0x67, 0x34, 0x31,
+0x00, 0x18, 0xCD, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x9D, 0x67, 0x01, 0xF2, 0x4C, 0x9A, 0x20, 0xF0,
+0x7C, 0xA4, 0xA7, 0x44, 0x49, 0xE1, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x44, 0x9A,
+0x11, 0x4D, 0xA0, 0xA5, 0x49, 0xE1, 0xA0, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2, 0x58, 0x9A,
+0x45, 0xE1, 0x47, 0x44, 0x15, 0x4A, 0x40, 0xA2,
+0x40, 0xC1, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x24, 0x67,
+0x4C, 0xE9, 0x2E, 0x6C, 0x98, 0xE9, 0x30, 0xF0,
+0x20, 0x6B, 0x4C, 0xED, 0xAD, 0xF0, 0x00, 0x4B,
+0x04, 0xD5, 0x33, 0x68, 0x12, 0xEC, 0x91, 0xE3,
+0xB6, 0xA4, 0x01, 0x6B, 0xAC, 0xEB, 0x4C, 0xEB,
+0x03, 0x23, 0x00, 0xA4, 0xFF, 0x48, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB,
+0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF2,
+0x1C, 0x4C, 0xB1, 0x67, 0xD0, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x04, 0x97, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x9B, 0x6F, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x2E, 0x68, 0x18, 0xEC,
+0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A, 0xAD, 0xF0,
+0x00, 0x4A, 0x08, 0xD4, 0x01, 0x6C, 0x0A, 0xD5,
+0x12, 0xE8, 0x01, 0xE2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x8C, 0xEB, 0x0A, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x23, 0xF2, 0x10, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x08, 0x94, 0x00, 0x18, 0x14, 0x57, 0x7D, 0x67,
+0x50, 0xC3, 0x90, 0xA3, 0x03, 0x6A, 0x06, 0xD4,
+0xA0, 0xA0, 0x06, 0x91, 0x7F, 0x6C, 0x07, 0xD5,
+0x71, 0xA0, 0x8C, 0xE9, 0x72, 0x36, 0x6A, 0x33,
+0x4C, 0xEB, 0x4C, 0xEE, 0x5D, 0x67, 0xA7, 0x42,
+0x11, 0x4D, 0xA0, 0xA5, 0x71, 0xC2, 0x09, 0xD6,
+0xA8, 0xC0, 0xB2, 0xA0, 0x04, 0x6A, 0x4B, 0xEA,
+0xAC, 0xEA, 0x6D, 0xEA, 0x01, 0x6B, 0x6B, 0xEB,
+0x65, 0xC0, 0x66, 0xC0, 0x20, 0xF0, 0x6C, 0xC0,
+0x20, 0xF0, 0x6D, 0xC0, 0x73, 0xA0, 0x6C, 0xEC,
+0x80, 0x6B, 0x6B, 0xEB, 0x6D, 0xEA, 0x67, 0x4B,
+0x6C, 0xEA, 0x52, 0xC0, 0x00, 0x6A, 0x55, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x93, 0xC0, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x0B, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x07, 0x61, 0x06, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0x23, 0xF2, 0x18, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x56, 0xA0, 0x01, 0x6E, 0xCC, 0xEA,
+0x32, 0x2A, 0x08, 0x94, 0x04, 0x05, 0x00, 0xF0,
+0x11, 0x06, 0x01, 0x6F, 0x00, 0x18, 0x5F, 0x6B,
+0xC0, 0xF0, 0x06, 0x2A, 0xB1, 0xA0, 0x7D, 0x67,
+0x51, 0xA3, 0x85, 0x67, 0x03, 0x6B, 0x6C, 0xEC,
+0x82, 0xEA, 0x26, 0x60, 0x9D, 0x67, 0x01, 0x4A,
+0x51, 0xC4, 0x30, 0xC4, 0x0D, 0x6C, 0x6C, 0xEA,
+0x8B, 0xEC, 0x48, 0x32, 0xAC, 0xEC, 0x4D, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0x91, 0xC0, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x12, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x0E, 0x61, 0xDD, 0x67, 0xB1, 0xA6,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF2, 0x00, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x05, 0x10, 0x71, 0xA0,
+0x03, 0x6A, 0x6C, 0xEA, 0x7D, 0x67, 0x51, 0xC3,
+0x07, 0x94, 0x83, 0xE9, 0x50, 0x60, 0xDD, 0x67,
+0xB0, 0xA6, 0x08, 0x94, 0x00, 0x18, 0x59, 0x6A,
+0x7D, 0x67, 0x50, 0xC3, 0xB0, 0xA3, 0xFF, 0x75,
+0x06, 0x61, 0x87, 0x41, 0x4C, 0x4C, 0xFF, 0x6A,
+0x4C, 0xEC, 0x06, 0xD4, 0x17, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x7C, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x78, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF2, 0x10, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x71, 0x10, 0x01, 0x49,
+0xFF, 0x6A, 0x4C, 0xE9, 0x08, 0x96, 0x09, 0x97,
+0x91, 0x67, 0x00, 0x6D, 0x00, 0x18, 0x3A, 0x6D,
+0xBD, 0x67, 0x50, 0xC5, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0B, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61, 0xB0, 0xA5,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF2, 0x18, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0xDD, 0x67, 0x50, 0xA6,
+0xFF, 0x72, 0x4E, 0x61, 0x07, 0x92, 0x43, 0xE9,
+0x02, 0x61, 0x50, 0xC6, 0x49, 0x10, 0x06, 0x94,
+0x8A, 0xE9, 0xD5, 0x61, 0x45, 0x10, 0x07, 0x95,
+0xAE, 0xE9, 0x27, 0x29, 0x72, 0xA0, 0x04, 0x6A,
+0x6C, 0xEA, 0x66, 0x22, 0x06, 0x96, 0x80, 0x6A,
+0x4B, 0xEA, 0xCC, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x5F, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x08, 0x61, 0x5D, 0x67, 0xB0, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF2, 0x00, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x07, 0x93, 0x80, 0x6A,
+0x4B, 0xEA, 0x6D, 0xEA, 0x9D, 0x67, 0x50, 0xC4,
+0x1B, 0x10, 0xBD, 0x67, 0xC7, 0x45, 0x15, 0x4E,
+0xC0, 0xA6, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xD0, 0xC5, 0xC8, 0xC0, 0xC6, 0xF3,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x10, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x0C, 0x61,
+0xB0, 0xA5, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF2,
+0x08, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x04, 0x10,
+0x0A, 0x93, 0x01, 0x69, 0x01, 0x73, 0x06, 0x61,
+0x72, 0xA0, 0x19, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x52, 0xC0, 0x00, 0x69, 0x9D, 0x67, 0x71, 0xA4,
+0x03, 0x6A, 0x91, 0xA0, 0x6C, 0xEA, 0x48, 0x33,
+0x0D, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0x6D, 0xEA,
+0x51, 0xC0, 0x08, 0x94, 0x02, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0xAC, 0x67, 0x6F, 0xA0, 0x0F, 0x6A,
+0xDD, 0x67, 0x6C, 0xEA, 0x10, 0x6B, 0x6D, 0xEA,
+0x4F, 0xC0, 0x5D, 0x67, 0xB0, 0xA6, 0x08, 0x94,
+0xF1, 0xA2, 0xD1, 0x67, 0x00, 0x18, 0x9B, 0x6F,
+0x0F, 0x97, 0x0E, 0x91, 0x0D, 0x90, 0x08, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF7, 0x63, 0x11, 0x62,
+0x10, 0xD1, 0x0F, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x2E, 0x68, 0x18, 0xEC, 0x4C, 0xED, 0x4C, 0xEE,
+0x30, 0xF0, 0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A,
+0x08, 0xD4, 0x01, 0x6C, 0x07, 0xD5, 0x0D, 0xD6,
+0x12, 0xE8, 0x01, 0xE2, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x8C, 0xEB, 0x0A, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF2, 0x10, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x08, 0x94, 0x00, 0x18, 0x14, 0x57, 0x7D, 0x67,
+0x50, 0xC3, 0x81, 0xA0, 0x40, 0xA0, 0x30, 0xA3,
+0x0B, 0xD4, 0x91, 0xA0, 0x03, 0x6B, 0x7F, 0x6D,
+0x92, 0x36, 0x8A, 0x34, 0x6C, 0xEC, 0x6C, 0xEE,
+0x7D, 0x67, 0x91, 0xC3, 0x0C, 0xD6, 0xD2, 0xA0,
+0x04, 0x6B, 0x6B, 0xEB, 0xCC, 0xEB, 0x8D, 0xEB,
+0x01, 0x6C, 0x8B, 0xEC, 0x85, 0xC0, 0x86, 0xC0,
+0x20, 0xF0, 0x8C, 0xC0, 0x20, 0xF0, 0x8D, 0xC0,
+0x93, 0xA0, 0xAC, 0xE9, 0x23, 0xEA, 0x8C, 0xED,
+0x80, 0x6C, 0x8B, 0xEC, 0x8D, 0xEB, 0x67, 0x4C,
+0x8C, 0xEB, 0x72, 0xC0, 0x00, 0x6B, 0xB3, 0xC0,
+0x75, 0xC0, 0x02, 0x60, 0x9D, 0x67, 0x50, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0xDD, 0x67, 0xB0, 0xA6, 0x30, 0xF0,
+0x20, 0x6C, 0x23, 0xF2, 0x18, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x07, 0x93, 0x00, 0x6A, 0x06, 0xD2,
+0xE0, 0xF0, 0x09, 0x23, 0xDD, 0x67, 0x08, 0x94,
+0xB0, 0xA6, 0x00, 0x18, 0x21, 0x6A, 0x07, 0x93,
+0xFF, 0x72, 0x09, 0xD3, 0x0A, 0x60, 0x9D, 0x67,
+0x50, 0xC4, 0x30, 0xA4, 0x7F, 0x6A, 0xA3, 0x67,
+0x4C, 0xE9, 0xFF, 0x4D, 0xFF, 0x6A, 0x4C, 0xED,
+0x09, 0xD5, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x08, 0x61, 0xDD, 0x67, 0xB0, 0xA6,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF2, 0x18, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x09, 0x92, 0xA0, 0xF0,
+0x1C, 0x22, 0x56, 0xA0, 0x01, 0x6B, 0x6C, 0xEA,
+0x1F, 0x2A, 0x08, 0x94, 0x04, 0x05, 0x00, 0xF0,
+0x11, 0x06, 0x02, 0x6F, 0x00, 0x18, 0x5F, 0x6B,
+0xA0, 0xF0, 0x0F, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x12, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x0E, 0x61, 0xDD, 0x67,
+0xB0, 0xA6, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF2,
+0x00, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x05, 0x10,
+0x71, 0xA0, 0x03, 0x6A, 0x6C, 0xEA, 0x7D, 0x67,
+0x51, 0xC3, 0x0B, 0x94, 0x00, 0x6D, 0x0A, 0xD5,
+0x83, 0xE9, 0x73, 0x60, 0xDD, 0x67, 0x47, 0x46,
+0x25, 0x4A, 0x40, 0xA2, 0x06, 0xD5, 0x50, 0xC6,
+0x8A, 0x10, 0x08, 0x96, 0x0C, 0x97, 0x91, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0x3A, 0x6D, 0x07, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0x07, 0x95, 0x09, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x63, 0xF2, 0x18, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x07, 0x94, 0x06, 0xD1, 0xFF, 0x74,
+0x2B, 0x61, 0xA8, 0x41, 0xB4, 0x4D, 0xFF, 0x6A,
+0x4C, 0xED, 0x07, 0xD5, 0x06, 0x96, 0xFF, 0x6A,
+0x24, 0x33, 0xFF, 0x4E, 0x4C, 0xEE, 0x30, 0xF0,
+0x20, 0x6A, 0x26, 0xF1, 0x0C, 0x4A, 0xC4, 0x34,
+0x4D, 0xE3, 0x49, 0xE4, 0x60, 0xAB, 0x40, 0xAA,
+0x06, 0xD6, 0x63, 0xEA, 0x0F, 0x60, 0x86, 0x67,
+0x08, 0x95, 0x0C, 0x96, 0x00, 0x18, 0x9E, 0x69,
+0xFF, 0x72, 0x08, 0x60, 0x72, 0xA0, 0x19, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x52, 0xC0, 0x06, 0x92,
+0x07, 0xD2, 0x06, 0x10, 0x06, 0x93, 0x07, 0x94,
+0x8A, 0xEB, 0xDC, 0x61, 0xFF, 0x6D, 0x07, 0xD5,
+0x07, 0x96, 0x0B, 0x95, 0x30, 0xF0, 0x20, 0x6A,
+0x26, 0xF1, 0x0C, 0x4A, 0xC4, 0x33, 0xA4, 0x34,
+0x4D, 0xE3, 0x49, 0xE4, 0x60, 0xAB, 0x40, 0xAA,
+0x43, 0xEB, 0x08, 0x60, 0xDD, 0x67, 0xB0, 0xC6,
+0x72, 0xA0, 0x19, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x52, 0xC0, 0x05, 0x10, 0x7D, 0x67, 0x87, 0x43,
+0x15, 0x4C, 0x80, 0xA4, 0x90, 0xC3, 0x0A, 0x95,
+0xFF, 0x6A, 0x06, 0x91, 0x01, 0x4D, 0x4C, 0xED,
+0x0A, 0xD5, 0x0A, 0x96, 0x09, 0x92, 0x43, 0xEE,
+0x90, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C,
+0x8C, 0xEB, 0x0F, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x0B, 0x61, 0x7D, 0x67, 0xB0, 0xA3,
+0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF2, 0x08, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x01, 0x6C, 0x06, 0xD4,
+0x02, 0x10, 0x01, 0x6D, 0x06, 0xD5, 0x0D, 0x96,
+0x01, 0x76, 0x04, 0x60, 0x72, 0xA0, 0x18, 0x6A,
+0x6C, 0xEA, 0x07, 0x2A, 0x72, 0xA0, 0x19, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x52, 0xC0, 0x00, 0x6A,
+0x06, 0xD2, 0x7D, 0x67, 0x50, 0xA3, 0x91, 0xA0,
+0x02, 0x6D, 0x48, 0xC0, 0x71, 0xA3, 0x03, 0x6A,
+0x00, 0x6E, 0x6C, 0xEA, 0x48, 0x33, 0x0D, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0x6D, 0xEA, 0x51, 0xC0,
+0x08, 0x94, 0x00, 0x18, 0xAC, 0x67, 0x6F, 0xA0,
+0x0F, 0x6A, 0xDD, 0x67, 0x6C, 0xEA, 0x20, 0x6B,
+0x6D, 0xEA, 0x4F, 0xC0, 0x5D, 0x67, 0xB0, 0xA6,
+0xF1, 0xA2, 0x08, 0x94, 0x06, 0x96, 0x00, 0x18,
+0x9B, 0x6F, 0x11, 0x97, 0x10, 0x91, 0x0F, 0x90,
+0x09, 0x63, 0x00, 0xEF, 0xEF, 0x63, 0x21, 0x62,
+0x20, 0xD1, 0x1F, 0xD0, 0x24, 0x67, 0x00, 0x18,
+0x07, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2,
+0x44, 0x9A, 0x60, 0xA2, 0x08, 0x6A, 0x6C, 0xEA,
+0x1D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2,
+0x4E, 0xA2, 0x0A, 0x5A, 0x17, 0x60, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x09, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x83, 0xF2, 0x08, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2, 0x6E, 0xA2,
+0x01, 0x4B, 0x66, 0xF2, 0x6E, 0xC2, 0x01, 0x6A,
+0x1C, 0xD2, 0x07, 0x10, 0x00, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x6E, 0xC2, 0x00, 0x6B,
+0x1C, 0xD3, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x20, 0x6D, 0x30, 0xF0, 0x20, 0x6E, 0x00, 0x6F,
+0x6F, 0xF3, 0x0C, 0x4C, 0x6F, 0xF4, 0x08, 0x4D,
+0xAD, 0xF0, 0x1D, 0x4E, 0x18, 0xD4, 0x17, 0xD5,
+0x0F, 0xD6, 0x13, 0xD7, 0x16, 0xD7, 0x18, 0x94,
+0x0F, 0x93, 0x00, 0x9C, 0x13, 0x94, 0xE3, 0x4B,
+0x11, 0xD3, 0x00, 0x18, 0x14, 0x57, 0x0F, 0x95,
+0x0E, 0xD2, 0x11, 0x96, 0xFF, 0xF7, 0xA3, 0xA5,
+0x13, 0x93, 0x08, 0x04, 0x12, 0xD5, 0x51, 0xA6,
+0x17, 0x95, 0x14, 0x6E, 0x4A, 0x32, 0x15, 0xD2,
+0x15, 0x97, 0x03, 0x6A, 0x4C, 0xEF, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x69, 0xE2,
+0xC9, 0xF6, 0x54, 0xA2, 0x15, 0xD7, 0x10, 0xD2,
+0x00, 0x18, 0xB9, 0x20, 0x0A, 0x96, 0x09, 0x95,
+0x0B, 0x93, 0x0C, 0x94, 0xA9, 0xE6, 0x69, 0xE2,
+0xFC, 0x65, 0x89, 0xE2, 0x08, 0x94, 0xFF, 0xF7,
+0x1F, 0x6F, 0xEC, 0xEA, 0x91, 0xE2, 0x1C, 0x65,
+0x04, 0xD2, 0xB1, 0xE3, 0xC4, 0x32, 0x64, 0x33,
+0xDF, 0x67, 0x49, 0xE4, 0x69, 0xE2, 0xC8, 0x35,
+0xA9, 0xE2, 0x13, 0x94, 0x10, 0x96, 0x05, 0xD2,
+0x58, 0x67, 0x4C, 0xEF, 0xB0, 0x67, 0x00, 0x18,
+0x91, 0x6A, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2,
+0x44, 0x9A, 0x60, 0xA2, 0x20, 0x6A, 0x6C, 0xEA,
+0x32, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF2,
+0x5C, 0x9A, 0xFF, 0x6B, 0x00, 0x6E, 0xA0, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF2, 0x40, 0x9A,
+0x6C, 0xED, 0xE0, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF2, 0x44, 0x9A, 0x6C, 0xEF, 0x80, 0xA2,
+0x6C, 0xEC, 0x00, 0x18, 0x9B, 0x6F, 0x13, 0x94,
+0x10, 0x97, 0x08, 0x05, 0xD0, 0x67, 0x00, 0x18,
+0x80, 0x69, 0x0C, 0x94, 0xB0, 0x67, 0x00, 0x18,
+0x55, 0x69, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x09, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF2, 0x10, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x0F, 0x94, 0x00, 0x6A,
+0x40, 0xC4, 0x20, 0xF5, 0x05, 0x10, 0x1C, 0x95,
+0x20, 0xF5, 0x11, 0x2D, 0x13, 0x94, 0x00, 0x18,
+0xAA, 0x13, 0x05, 0x2A, 0x13, 0x92, 0xFF, 0x6E,
+0xCC, 0xEA, 0x20, 0x5A, 0x09, 0x61, 0x08, 0x20,
+0x11, 0x97, 0x80, 0x6A, 0x4B, 0xEA, 0x71, 0xA7,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x05, 0x22,
+0x0F, 0x93, 0x00, 0x6A, 0x40, 0xC3, 0x00, 0xF5,
+0x1D, 0x10, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0A, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x07, 0x61,
+0x13, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF2,
+0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x11, 0x95,
+0x40, 0x6B, 0xFF, 0x6A, 0x92, 0xA5, 0x8C, 0xEB,
+0x05, 0x2B, 0x91, 0xA5, 0x80, 0x4B, 0x8C, 0xEB,
+0x4C, 0xEB, 0x0F, 0x23, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0xE0, 0xF4, 0x0D, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0xE0, 0xF4, 0x09, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF2, 0x04, 0x4C, 0x13, 0x95,
+0x98, 0x11, 0x09, 0x58, 0x20, 0x61, 0x11, 0x97,
+0x07, 0x6B, 0xD3, 0xA7, 0xA6, 0x67, 0x6C, 0xED,
+0x85, 0x67, 0x4C, 0xEC, 0x18, 0x24, 0x08, 0x6C,
+0xFF, 0x4D, 0x8B, 0xEC, 0x6C, 0xED, 0xCC, 0xEC,
+0xAD, 0xEC, 0x93, 0xC7, 0xA4, 0x99, 0x01, 0x6E,
+0xCC, 0xED, 0xC0, 0xF4, 0x0D, 0x25, 0xA5, 0x99,
+0x05, 0x5D, 0xC0, 0xF4, 0x09, 0x61, 0xA4, 0x67,
+0x6C, 0xED, 0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF2,
+0x10, 0x4C, 0x4C, 0xED, 0x76, 0x11, 0x0E, 0x93,
+0x0E, 0x95, 0x7F, 0x6A, 0x11, 0x96, 0x80, 0x6C,
+0x4C, 0xEB, 0x8C, 0xED, 0x14, 0xD3, 0x19, 0xD5,
+0x73, 0xA6, 0x80, 0x4A, 0xF9, 0x4A, 0x6C, 0xEA,
+0x53, 0xC6, 0x14, 0x97, 0x12, 0x92, 0xE3, 0xEA,
+0x1B, 0x60, 0x0E, 0xD2, 0x07, 0x25, 0x80, 0x6B,
+0x82, 0x67, 0x6B, 0xEB, 0x6D, 0xEC, 0xFF, 0x6A,
+0x4C, 0xEC, 0x0E, 0xD4, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x0C, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x09, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF2,
+0x1C, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x12, 0x95,
+0x14, 0xD5, 0x02, 0x10, 0x12, 0x96, 0x14, 0xD6,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x0C, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x09, 0x61, 0x08, 0x96,
+0x0C, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0xC3, 0xF2,
+0x04, 0x4C, 0xB0, 0x67, 0x00, 0x18, 0x4D, 0x63,
+0x4F, 0x40, 0x07, 0x5A, 0x14, 0x60, 0x11, 0x97,
+0x01, 0x6A, 0x76, 0xA7, 0x6C, 0xEA, 0x0F, 0x2A,
+0x4E, 0xA7, 0x56, 0x33, 0x03, 0x53, 0x04, 0x60,
+0x20, 0x4A, 0x4E, 0xC7, 0x60, 0xF4, 0x14, 0x10,
+0x1F, 0x6B, 0x4C, 0xEB, 0x60, 0x6A, 0x4D, 0xEB,
+0x11, 0x92, 0x6E, 0xC2, 0x05, 0x10, 0x11, 0x94,
+0x1F, 0x6A, 0x6E, 0xA4, 0x6C, 0xEA, 0x4E, 0xC4,
+0x11, 0x95, 0x20, 0x6A, 0x4B, 0xEA, 0x6E, 0xA5,
+0xFF, 0x6E, 0xA0, 0x6F, 0x6C, 0xEA, 0xCC, 0xEA,
+0xEE, 0xEA, 0x4D, 0x2A, 0x0F, 0x93, 0x05, 0x6D,
+0x00, 0x6E, 0x40, 0xC3, 0x13, 0x94, 0x00, 0x18,
+0xAC, 0x67, 0x0C, 0x92, 0x0B, 0x93, 0x10, 0x94,
+0x4D, 0xE3, 0x8D, 0xE3, 0x0A, 0x32, 0x63, 0xEA,
+0x14, 0x60, 0x44, 0x99, 0x09, 0x6B, 0x6C, 0xEA,
+0x09, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xC3, 0xF2, 0x14, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x13, 0x94, 0x01, 0x6D,
+0xC5, 0x67, 0x00, 0x18, 0x03, 0x71, 0x20, 0xF4,
+0x1B, 0x10, 0x10, 0x95, 0x11, 0x25, 0x44, 0x99,
+0x09, 0x6B, 0x6C, 0xEA, 0x20, 0xF4, 0x14, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x20, 0xF4, 0x10, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0xC3, 0xF2, 0x1C, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x20, 0xF4, 0x08, 0x10,
+0x08, 0x92, 0x03, 0xEA, 0x20, 0xF4, 0x04, 0x61,
+0x44, 0x99, 0x09, 0x6B, 0x6C, 0xEA, 0x09, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xE3, 0xF2, 0x10, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x13, 0x94, 0x01, 0x6D, 0x00, 0x18,
+0x4E, 0x70, 0x00, 0xF4, 0x11, 0x10, 0x10, 0x97,
+0x13, 0x94, 0xD0, 0x67, 0x08, 0x05, 0x00, 0x18,
+0x80, 0x69, 0x0C, 0x94, 0xB0, 0x67, 0x12, 0xD2,
+0x00, 0x18, 0x55, 0x69, 0x11, 0x96, 0x1B, 0xD2,
+0x10, 0x6A, 0x6E, 0xA6, 0xFF, 0x6F, 0x6C, 0xEA,
+0xEC, 0xEA, 0x0F, 0x22, 0x12, 0x93, 0x0F, 0x94,
+0x66, 0x32, 0xFF, 0xF7, 0x5C, 0xC4, 0x1B, 0x95,
+0xA6, 0x32, 0xFF, 0xF7, 0x5D, 0xC4, 0x6E, 0xA6,
+0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x4E, 0xC6,
+0x13, 0x10, 0x0F, 0x96, 0x12, 0x97, 0xFF, 0xF7,
+0x5C, 0xA6, 0x44, 0x33, 0x49, 0xE3, 0xE9, 0xE2,
+0x4B, 0x32, 0xFF, 0xF7, 0x5C, 0xC6, 0x1B, 0x92,
+0xFF, 0xF7, 0x7D, 0xA6, 0x6D, 0xE2, 0x44, 0x32,
+0x49, 0xE3, 0x4B, 0x32, 0xFF, 0xF7, 0x5D, 0xC6,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2, 0x44, 0x9A,
+0x60, 0xA2, 0x40, 0x6A, 0x6C, 0xEA, 0x29, 0x22,
+0x0B, 0x94, 0x09, 0x93, 0x0C, 0x95, 0x0A, 0x96,
+0x1B, 0x65, 0x6D, 0xE4, 0xC4, 0x32, 0xAD, 0xE3,
+0x4D, 0xE3, 0x89, 0xE5, 0x44, 0x32, 0xB8, 0x67,
+0x49, 0xE3, 0xAD, 0xE6, 0x10, 0x96, 0xFF, 0xF7,
+0x1F, 0x6F, 0x91, 0xE3, 0x08, 0x93, 0xEC, 0xEA,
+0xC3, 0xE0, 0x04, 0xD2, 0x01, 0xE2, 0x12, 0x92,
+0x6D, 0xE4, 0x0F, 0x94, 0xEC, 0xE8, 0x05, 0xD0,
+0x06, 0xD2, 0xFF, 0xF7, 0x5C, 0xA4, 0x13, 0x95,
+0x0E, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0xE3, 0xF2,
+0x18, 0x4C, 0x6C, 0xEF, 0x07, 0xD2, 0x00, 0x18,
+0x4D, 0x63, 0x0F, 0x95, 0x19, 0x96, 0xFF, 0xF7,
+0x9C, 0xA5, 0x14, 0x95, 0x00, 0x18, 0x74, 0x69,
+0x15, 0x96, 0x05, 0x2E, 0x40, 0x32, 0x5C, 0x32,
+0x42, 0x32, 0x42, 0x32, 0x07, 0x10, 0x15, 0x97,
+0x02, 0x77, 0x04, 0x61, 0x44, 0x32, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x0F, 0x93, 0xFF, 0xF7,
+0x4D, 0xCB, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0F, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x0C, 0x61,
+0x0F, 0x97, 0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xFF, 0xF7, 0xDC, 0xA7, 0xFF, 0xF7, 0xFD, 0xA7,
+0x23, 0xF3, 0x00, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x44, 0x99, 0x02, 0x6B, 0x6C, 0xEA, 0x0F, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x0C, 0x61, 0x0F, 0x92,
+0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0xFF, 0xF7,
+0xDC, 0xA2, 0xFF, 0xF7, 0xFD, 0xA2, 0x23, 0xF3,
+0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x10, 0x93,
+0x08, 0x5B, 0x22, 0x61, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x0A, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x07, 0x61, 0x10, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0x43, 0xF3, 0x10, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x0F, 0x94, 0x00, 0x6A, 0x01, 0x6B, 0x40, 0xC4,
+0x44, 0x99, 0x6C, 0xEA, 0x40, 0xF3, 0x14, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x40, 0xF3, 0x10, 0x61,
+0x10, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF3,
+0x1C, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x48, 0x13,
+0x44, 0x99, 0x09, 0x6B, 0x6C, 0xEA, 0x0B, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x08, 0x61, 0x0F, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF3, 0x08, 0x4C,
+0xA0, 0xA6, 0x00, 0x18, 0x4D, 0x63, 0x44, 0x99,
+0x08, 0x6B, 0x6C, 0xEA, 0x12, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x0F, 0x61, 0x0B, 0x92, 0x10, 0x97,
+0x08, 0x95, 0x04, 0xD2, 0x06, 0xD7, 0x0C, 0x92,
+0x09, 0x96, 0x0A, 0x97, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF3, 0x14, 0x4C, 0x05, 0xD2, 0x00, 0x18,
+0x4D, 0x63, 0x0F, 0x93, 0x40, 0xA3, 0x01, 0x4A,
+0x40, 0xC3, 0x40, 0xA3, 0x05, 0x5A, 0x05, 0x61,
+0x07, 0x5A, 0x20, 0xF3, 0x0B, 0x61, 0x00, 0x6A,
+0x40, 0xC3, 0x14, 0x94, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE4, 0xC8, 0xF7,
+0x16, 0xA2, 0x12, 0x95, 0x03, 0xED, 0x14, 0x60,
+0xBB, 0xE0, 0xFF, 0x6A, 0x11, 0x97, 0x4C, 0xEE,
+0x0E, 0xD6, 0xB0, 0xA7, 0x0F, 0x6B, 0x01, 0x6C,
+0xAE, 0x32, 0x6C, 0xEA, 0x44, 0x32, 0x8D, 0xEA,
+0x6C, 0xEA, 0x80, 0x4B, 0xF8, 0x4B, 0x4C, 0x32,
+0xAC, 0xEB, 0x4D, 0xEB, 0x70, 0xC7, 0x15, 0x10,
+0x12, 0x92, 0x11, 0x94, 0x11, 0x95, 0x0B, 0xE2,
+0x0E, 0xD2, 0x0E, 0x93, 0xFF, 0x6A, 0x4C, 0xEB,
+0x0E, 0xD3, 0x70, 0xA4, 0x0F, 0x6C, 0x6E, 0x32,
+0x8C, 0xEA, 0x44, 0x32, 0x8C, 0xEA, 0x4C, 0x34,
+0x79, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x8D, 0xEA,
+0x50, 0xC5, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x12, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x0F, 0x61,
+0x11, 0x96, 0x0E, 0x97, 0x0F, 0x6B, 0x50, 0xA6,
+0x12, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x4E, 0x32,
+0x6C, 0xEA, 0x83, 0xF3, 0x10, 0x4C, 0xB0, 0x67,
+0x04, 0xD2, 0x00, 0x18, 0x4D, 0x63, 0x0E, 0x97,
+0x04, 0x5F, 0x22, 0x61, 0x12, 0x94, 0x10, 0x33,
+0xFF, 0xF7, 0x1F, 0x6A, 0x0F, 0xE3, 0x4C, 0xEB,
+0x8D, 0xE3, 0x11, 0x95, 0x4C, 0xEB, 0x6F, 0x33,
+0x4C, 0xEB, 0x50, 0xA5, 0x01, 0x6C, 0x4E, 0x32,
+0x8C, 0xEA, 0x08, 0x22, 0x14, 0x96, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE6,
+0x66, 0x33, 0x08, 0x10, 0x14, 0x97, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x66, 0x33,
+0x49, 0xE7, 0x01, 0x4B, 0xC8, 0xF7, 0x76, 0xC2,
+0x14, 0x94, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x4D, 0xE4, 0xC8, 0xF7, 0x76, 0xA3,
+0x10, 0xD3, 0x64, 0x67, 0x04, 0xF4, 0x10, 0x4B,
+0x64, 0x33, 0x49, 0xE3, 0x0A, 0xA2, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x0B, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x08, 0x61, 0x10, 0x95, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF3, 0x1C, 0x4C, 0xD0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x0E, 0x97, 0xBD, 0x67,
+0xC7, 0x45, 0x31, 0x4E, 0x0F, 0x5F, 0x40, 0xA6,
+0x01, 0x61, 0x0E, 0x6A, 0xFF, 0x6B, 0x4C, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x49, 0xE3, 0xC9, 0xF0, 0x52, 0xA2, 0x0B, 0x5A,
+0x08, 0x61, 0x11, 0x94, 0x50, 0xA4, 0x03, 0x6C,
+0x4E, 0x32, 0x8C, 0xEA, 0x15, 0x22, 0x03, 0x72,
+0x13, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x4D, 0xE3, 0xC9, 0xF0, 0x52, 0xA3,
+0x41, 0xE0, 0xFF, 0x6A, 0x4C, 0xE8, 0x0A, 0x58,
+0x03, 0x60, 0x01, 0x6D, 0x00, 0x68, 0x08, 0x10,
+0xF6, 0x48, 0x4C, 0xE8, 0x01, 0x6D, 0x01, 0x10,
+0x00, 0x6D, 0x1A, 0x58, 0x01, 0x61, 0x19, 0x68,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x0A, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xC3, 0xF3, 0x18, 0x4C, 0xD0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x14, 0x93, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x04, 0xF4,
+0x10, 0x4B, 0x64, 0x33, 0x49, 0xE3, 0x0B, 0x58,
+0x05, 0xCA, 0x02, 0x6A, 0x09, 0x60, 0x06, 0x58,
+0x03, 0x6A, 0x06, 0x60, 0x03, 0x58, 0x58, 0x67,
+0x01, 0x5A, 0x58, 0x67, 0x05, 0x6B, 0x4B, 0xE3,
+0x10, 0x93, 0x12, 0xD0, 0x0B, 0x5B, 0x08, 0x61,
+0xF6, 0x4B, 0x67, 0xEA, 0x6D, 0xE0, 0x12, 0xD3,
+0x12, 0x94, 0xFF, 0x6B, 0x6C, 0xEC, 0x12, 0xD4,
+0x10, 0x93, 0x12, 0x95, 0xF6, 0x4B, 0x67, 0xEA,
+0x6D, 0xE5, 0xFF, 0x6A, 0x4C, 0xEB, 0x28, 0x5D,
+0x1A, 0xD3, 0x02, 0x61, 0x28, 0x6E, 0x12, 0xD6,
+0x03, 0x58, 0x05, 0x60, 0x1B, 0x97, 0xFF, 0x6A,
+0xE6, 0x37, 0x4C, 0xEF, 0x16, 0xD7, 0x44, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x0C, 0x22, 0x45, 0x99,
+0x05, 0x5A, 0x09, 0x61, 0x12, 0x95, 0x16, 0x96,
+0x1A, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0xE3, 0xF3,
+0x0C, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x19, 0x92,
+0x13, 0x22, 0x14, 0x93, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE3, 0x28, 0xF7,
+0x4A, 0xA2, 0x00, 0x6C, 0x0E, 0xD4, 0x02, 0x5A,
+0x10, 0x61, 0xFF, 0x4A, 0x0E, 0xD2, 0x0E, 0x95,
+0xFF, 0x6A, 0x4C, 0xED, 0x0E, 0xD5, 0x09, 0x10,
+0x14, 0x96, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x49, 0xE6, 0x28, 0xF7, 0x4A, 0xA2,
+0x0E, 0xD2, 0x14, 0x97, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE7, 0xC8, 0xF6,
+0x56, 0xA2, 0xFF, 0x68, 0x10, 0xD2, 0x11, 0x92,
+0x76, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0x1A, 0x22,
+0x87, 0x67, 0x00, 0x18, 0x9C, 0x67, 0x05, 0x22,
+0x0E, 0x93, 0x02, 0x4B, 0x0C, 0xEB, 0x0E, 0xD3,
+0x11, 0x10, 0x14, 0x94, 0x00, 0x18, 0x88, 0x67,
+0x05, 0x22, 0x0E, 0x94, 0x05, 0x4C, 0x0C, 0xEC,
+0x0E, 0xD4, 0x08, 0x10, 0x10, 0x95, 0x0E, 0x96,
+0x03, 0x4D, 0x06, 0x4E, 0x0C, 0xED, 0x0C, 0xEE,
+0x10, 0xD5, 0x0E, 0xD6, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x48, 0x9A, 0xFF, 0x6B, 0x80, 0xA2,
+0x7F, 0x6A, 0x8C, 0xEA, 0x08, 0x22, 0x10, 0x97,
+0x0E, 0x92, 0x02, 0x4F, 0x05, 0x4A, 0x6C, 0xEF,
+0x6C, 0xEA, 0x10, 0xD7, 0x0E, 0xD2, 0x12, 0x93,
+0x16, 0x94, 0x63, 0xEC, 0x35, 0x60, 0x1A, 0x95,
+0x0E, 0x96, 0x12, 0x97, 0x8F, 0xE5, 0x16, 0x92,
+0x6D, 0xE6, 0x10, 0x96, 0x57, 0xE7, 0x14, 0x97,
+0xA9, 0xE6, 0x30, 0xF0, 0x20, 0x6E, 0xFF, 0x6C,
+0x86, 0xF2, 0x00, 0x4E, 0x8C, 0xEB, 0xAB, 0x35,
+0xD9, 0xE7, 0x68, 0xF7, 0xBE, 0xC6, 0xA3, 0x67,
+0x8C, 0xEB, 0x47, 0x5B, 0x8C, 0xEA, 0x01, 0x61,
+0x46, 0x6D, 0xFF, 0x6C, 0x65, 0x67, 0x8C, 0xEB,
+0x0E, 0xD3, 0x62, 0x67, 0x8C, 0xEA, 0x29, 0x5A,
+0x01, 0x61, 0x28, 0x6B, 0xFF, 0x6C, 0x6C, 0xEC,
+0x10, 0xD4, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0B, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x08, 0x61,
+0x10, 0x95, 0x0E, 0x96, 0x30, 0xF0, 0x20, 0x6C,
+0x03, 0xF4, 0x00, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x0F, 0x95, 0x3F, 0x6A, 0x0A, 0xA5, 0x4C, 0xE8,
+0x4A, 0x85, 0x00, 0x52, 0x19, 0x60, 0x0E, 0x96,
+0x03, 0xEE, 0x03, 0x60, 0x00, 0x6F, 0x0E, 0xD7,
+0x07, 0x10, 0x0E, 0x92, 0x0B, 0xE2, 0x0E, 0xD2,
+0x0E, 0x93, 0xFF, 0x6A, 0x4C, 0xEB, 0x0E, 0xD3,
+0x10, 0x94, 0x03, 0xEC, 0x03, 0x60, 0x00, 0x6D,
+0x10, 0xD5, 0x10, 0x10, 0x10, 0x96, 0xFF, 0x6A,
+0x1B, 0xE6, 0x4C, 0xEE, 0x10, 0xD6, 0x0A, 0x10,
+0x09, 0x20, 0x0E, 0x97, 0x10, 0x93, 0xFF, 0x6A,
+0x1D, 0xE7, 0x0D, 0xE3, 0x4C, 0xEF, 0x4C, 0xEB,
+0x0E, 0xD7, 0x10, 0xD3, 0x0E, 0x96, 0x9D, 0x67,
+0xA7, 0x44, 0x31, 0x4D, 0x5B, 0x5E, 0x40, 0xA5,
+0x01, 0x61, 0x5A, 0x6A, 0x10, 0x96, 0xFF, 0x6B,
+0xE2, 0x67, 0x9D, 0x67, 0x6C, 0xEF, 0xA7, 0x44,
+0xCC, 0xEB, 0x39, 0x4D, 0x42, 0x5B, 0x14, 0xD7,
+0x40, 0xA5, 0x01, 0x61, 0x41, 0x6A, 0xFF, 0x6F,
+0x4C, 0xEF, 0x0E, 0xD7, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x0D, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x0A, 0x61, 0x0F, 0x92, 0xC7, 0x67, 0x14, 0x97,
+0xAA, 0xA2, 0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF4,
+0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x0F, 0x93,
+0x14, 0x94, 0x0E, 0x95, 0x4A, 0xA3, 0x04, 0x6E,
+0x06, 0xD4, 0x01, 0x6C, 0x5E, 0x32, 0x07, 0xD5,
+0xE6, 0x67, 0xA4, 0x67, 0x04, 0xD2, 0x05, 0xD0,
+0x00, 0x18, 0xD5, 0x64, 0x11, 0x96, 0x03, 0x6C,
+0xFF, 0x6A, 0xB2, 0xA6, 0xAE, 0x35, 0x8C, 0xED,
+0x63, 0x45, 0x8C, 0xEB, 0x02, 0x5B, 0x42, 0x60,
+0x64, 0x99, 0x01, 0x6C, 0x0F, 0x45, 0x8C, 0xEB,
+0x4C, 0xE8, 0x0A, 0x23, 0x65, 0x99, 0x05, 0x5B,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x23, 0xF4,
+0x1C, 0x4C, 0x4C, 0xED, 0x00, 0x18, 0x4D, 0x63,
+0x11, 0x97, 0x03, 0x6B, 0x19, 0x6A, 0xB2, 0xA7,
+0x4B, 0xEA, 0x11, 0xE7, 0xAE, 0x36, 0x6C, 0xEE,
+0xFF, 0x4E, 0x6C, 0xEE, 0xCC, 0x36, 0xAC, 0xEA,
+0xCD, 0xEA, 0x05, 0xA4, 0x52, 0xC7, 0x20, 0xF0,
+0x4C, 0xA4, 0xFF, 0x72, 0x09, 0x60, 0x15, 0xD2,
+0x91, 0xA7, 0x4C, 0xEB, 0x0D, 0x6A, 0x4B, 0xEA,
+0x68, 0x33, 0x8C, 0xEA, 0x6D, 0xEA, 0x51, 0xC7,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x0B, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x08, 0x61, 0x15, 0x95,
+0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF4, 0x08, 0x4C,
+0xD0, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x13, 0x94,
+0x15, 0x97, 0xB0, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x9B, 0x6F, 0xC6, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF2, 0x44, 0x9A, 0x60, 0xA2, 0x40, 0x6A,
+0x6C, 0xEA, 0x07, 0x22, 0x11, 0x92, 0x6E, 0xA2,
+0x08, 0x6A, 0x6D, 0xEA, 0x11, 0x93, 0x4E, 0xC3,
+0x06, 0x10, 0x11, 0x94, 0x09, 0x6A, 0x4B, 0xEA,
+0x6E, 0xA4, 0x6C, 0xEA, 0x4E, 0xC4, 0x0F, 0x95,
+0xFF, 0xF7, 0x5D, 0xA5, 0x17, 0x5A, 0x1C, 0x61,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x09, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x43, 0xF4, 0x14, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x13, 0x94, 0x01, 0x6D, 0xC5, 0x67,
+0x00, 0x18, 0x03, 0x71, 0x0F, 0x96, 0x00, 0x6A,
+0xFF, 0xF7, 0x4C, 0xC6, 0xFF, 0xF7, 0x4F, 0xA6,
+0x01, 0x4A, 0xFF, 0xF7, 0x4F, 0xC6, 0x90, 0x10,
+0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA, 0x0B, 0x22,
+0x45, 0x99, 0x05, 0x5A, 0x08, 0x61, 0x0E, 0x95,
+0x14, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF4,
+0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x0F, 0x97,
+0x14, 0x93, 0xFF, 0xF7, 0x5C, 0xA7, 0x43, 0xEB,
+0x1C, 0x60, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x09, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF4, 0x08, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x13, 0x94, 0x01, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x03, 0x71, 0x0F, 0x94,
+0x00, 0x6A, 0xFF, 0xF7, 0x4C, 0xC4, 0xFF, 0xF7,
+0x4F, 0xA4, 0x01, 0x4A, 0xFF, 0xF7, 0x4F, 0xC4,
+0x5F, 0x10, 0x0E, 0x95, 0xA3, 0xEA, 0x45, 0x60,
+0x0F, 0x96, 0x01, 0x6B, 0xFF, 0xF7, 0x4C, 0xA6,
+0x01, 0x4A, 0xFF, 0xF7, 0x4C, 0xC6, 0x44, 0x99,
+0x6C, 0xEA, 0x09, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xE3, 0xF2,
+0x14, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x0F, 0x92,
+0xFF, 0xF7, 0xEC, 0xA2, 0xFF, 0xF7, 0x58, 0xA2,
+0x02, 0x4A, 0x42, 0xEF, 0x41, 0x61, 0x11, 0x94,
+0x08, 0x6A, 0x6E, 0xA4, 0x6C, 0xEA, 0x0A, 0x22,
+0x0F, 0x92, 0x13, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xFF, 0xF7, 0xDC, 0xA2, 0x63, 0xF4, 0x0C, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x09, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF4,
+0x1C, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x13, 0x94,
+0x00, 0x6D, 0x00, 0x18, 0x4E, 0x70, 0x0F, 0x93,
+0x00, 0x6A, 0xFF, 0xF7, 0x4C, 0xC3, 0xFF, 0xF7,
+0x50, 0xA3, 0x01, 0x4A, 0xFF, 0xF7, 0x50, 0xC3,
+0x17, 0x10, 0x44, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x09, 0x22, 0x45, 0x99, 0x05, 0x5A, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF4, 0x04, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x13, 0x94, 0x04, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0xAC, 0x67, 0x11, 0x94,
+0x0F, 0x6A, 0x6F, 0xA4, 0x6C, 0xEA, 0x4F, 0xC4,
+0x00, 0x18, 0xE8, 0x67, 0x44, 0x99, 0x01, 0x6B,
+0x6C, 0xEA, 0x09, 0x22, 0x45, 0x99, 0x05, 0x5A,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF4,
+0x08, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x13, 0x94,
+0x00, 0x18, 0xBE, 0x77, 0x13, 0x95, 0x18, 0x96,
+0x17, 0x97, 0x0F, 0x92, 0x01, 0x4D, 0x04, 0x4E,
+0x14, 0x4F, 0x2E, 0x4A, 0x3F, 0x75, 0x13, 0xD5,
+0x18, 0xD6, 0x17, 0xD7, 0x0F, 0xD2, 0x3F, 0xF2,
+0x1E, 0x61, 0x21, 0x97, 0x20, 0x91, 0x1F, 0x90,
+0x11, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2,
+0x6D, 0xA2, 0x01, 0x4B, 0x66, 0xF2, 0x6D, 0xC2,
+0x66, 0xF2, 0x6D, 0xA2, 0x02, 0x5B, 0x03, 0x61,
+0x00, 0x6B, 0x66, 0xF2, 0x6D, 0xC2, 0x30, 0xF0,
+0x20, 0x68, 0x4C, 0xF6, 0x08, 0x48, 0x90, 0x67,
+0x00, 0x18, 0xC9, 0x71, 0x00, 0x18, 0x5E, 0x60,
+0x90, 0x67, 0x00, 0x18, 0xF3, 0x66, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x2C, 0xEC, 0x2E, 0x6A, 0x58, 0xEC,
+0x30, 0xF0, 0x20, 0x6B, 0xAD, 0xF0, 0x00, 0x4B,
+0x04, 0xD4, 0x03, 0x6D, 0x12, 0xEA, 0x49, 0xE3,
+0xD2, 0xA2, 0xF1, 0xA2, 0x68, 0xA2, 0xCC, 0xED,
+0xA8, 0x36, 0xAC, 0xE9, 0x0D, 0x6D, 0xAB, 0xED,
+0xEC, 0xED, 0xCD, 0xED, 0x80, 0xA2, 0xB1, 0xC2,
+0x7F, 0x6D, 0x6C, 0xED, 0xA3, 0xEC, 0x01, 0x60,
+0x64, 0x67, 0x48, 0xA2, 0x80, 0x68, 0x0B, 0xE8,
+0x4C, 0xE8, 0x6D, 0xE8, 0x00, 0xF6, 0x00, 0x30,
+0xFF, 0x6A, 0x00, 0xF6, 0x03, 0x30, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x0C, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF4,
+0x14, 0x4C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x04, 0x94, 0xB0, 0x67, 0xF1, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x9B, 0x6F, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x69, 0x8C, 0xE9, 0x2E, 0x68, 0x18, 0xE9,
+0xFF, 0x6A, 0xAC, 0xEA, 0x06, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A, 0x91, 0x67,
+0x12, 0xE8, 0x01, 0xE2, 0x00, 0x18, 0x14, 0x57,
+0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2,
+0x44, 0x9A, 0x34, 0x33, 0x91, 0x67, 0x49, 0xE3,
+0x40, 0xA2, 0xFF, 0x6B, 0x4C, 0xEB, 0x05, 0xD3,
+0x00, 0x18, 0xAA, 0x13, 0x52, 0xA0, 0x01, 0x6B,
+0xFF, 0x6C, 0x5A, 0x32, 0x6C, 0xEA, 0x8C, 0xEA,
+0x00, 0xF1, 0x06, 0x22, 0x06, 0x92, 0x63, 0x22,
+0x8F, 0xA0, 0x10, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x4F, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x98, 0x9A, 0x6C, 0xEC,
+0x0B, 0x24, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x07, 0x61, 0x04, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xA3, 0xF4, 0x04, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x91, 0x67, 0x06, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0xAC, 0x67, 0x54, 0xA0, 0x10, 0x6B, 0x6B, 0xEB,
+0x6C, 0xEA, 0x54, 0xC0, 0x05, 0x94, 0x18, 0x6F,
+0x04, 0x95, 0x8C, 0xEF, 0x00, 0x6E, 0x91, 0x67,
+0xEE, 0x37, 0x00, 0x18, 0x9B, 0x6F, 0x72, 0xA0,
+0x19, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x52, 0xC0,
+0x4F, 0xA0, 0x10, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x6C, 0x8E, 0xEA,
+0x01, 0x22, 0x03, 0x6A, 0x73, 0xA0, 0x55, 0xC0,
+0x00, 0x6A, 0x59, 0xC0, 0x5A, 0xC0, 0x7F, 0x6A,
+0x4C, 0xEB, 0x73, 0xC0, 0x72, 0xA0, 0x6C, 0xEA,
+0x6E, 0xA0, 0x52, 0xC0, 0x10, 0x6A, 0x6D, 0xEA,
+0x08, 0x6B, 0x4C, 0xEB, 0x4E, 0xC0, 0xA0, 0xF0,
+0x0B, 0x23, 0x6F, 0xA0, 0x10, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x10, 0x72,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF4,
+0x10, 0x4C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xC3, 0xF4, 0x00, 0x4C, 0x04, 0x96, 0xB1, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x95, 0x10, 0x6E, 0xA0,
+0x08, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x15, 0x22, 0x6F, 0xA0, 0x10, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA, 0x10, 0x72,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0xC3, 0xF4,
+0x10, 0x4C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xE3, 0xF4, 0x00, 0x4C, 0x04, 0x96, 0xB1, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x72, 0xA0, 0x18, 0x6A,
+0x6C, 0xEA, 0x4C, 0x2A, 0x4F, 0xA0, 0x10, 0x6B,
+0x6B, 0xEB, 0x6C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA,
+0x10, 0x72, 0x3F, 0x61, 0x54, 0xA0, 0x0F, 0x6C,
+0xA2, 0x67, 0x8C, 0xED, 0x01, 0x4D, 0x8C, 0xED,
+0x6C, 0xEA, 0xAD, 0xEA, 0x4C, 0xEC, 0x03, 0x54,
+0x54, 0xC0, 0x0E, 0x61, 0x6C, 0xEA, 0x54, 0xC0,
+0x04, 0x94, 0x30, 0xF0, 0x20, 0x6A, 0x7F, 0x6B,
+0x8C, 0xEB, 0xE5, 0xF5, 0x0C, 0x4A, 0x49, 0xE3,
+0x40, 0xA2, 0x44, 0x32, 0x0A, 0x4A, 0x55, 0xC0,
+0x6E, 0xA0, 0x08, 0x6A, 0x6C, 0xEA, 0x0C, 0x22,
+0x74, 0xA0, 0x0F, 0x6A, 0xD5, 0xA0, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0xFF, 0x6D, 0xE3, 0xF4,
+0x10, 0x4C, 0x4C, 0xED, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB,
+0x11, 0x23, 0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A,
+0x0D, 0x61, 0xB5, 0xA0, 0x30, 0xF0, 0x20, 0x6C,
+0x03, 0xF5, 0x00, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x05, 0x10, 0x54, 0xA0, 0x4C, 0xEB, 0x03, 0x6A,
+0x74, 0xC0, 0x55, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61, 0x54, 0xA0,
+0x30, 0xF0, 0x20, 0x6C, 0x0F, 0x6D, 0x03, 0xF5,
+0x0C, 0x4C, 0x4C, 0xED, 0x00, 0x18, 0x4D, 0x63,
+0x6E, 0xA0, 0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x4E, 0xC0, 0x91, 0x67, 0x07, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0xAC, 0x67, 0x91, 0x67, 0x00, 0x18,
+0xE0, 0x74, 0x73, 0xA0, 0x7F, 0x6A, 0x4C, 0xEB,
+0x73, 0xC0, 0x72, 0xA0, 0x6C, 0xEA, 0x52, 0xC0,
+0x72, 0xA0, 0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x73, 0xA0, 0x52, 0xC0, 0x08, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x02, 0x6B, 0x6D, 0xEA, 0x53, 0xC0,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0xE6, 0x67, 0x2E, 0x6E, 0xD8, 0xEC, 0x30, 0xF0,
+0x20, 0x6B, 0xAD, 0xF0, 0x00, 0x4B, 0x04, 0xD4,
+0x25, 0x67, 0x4C, 0xE9, 0x4C, 0xEF, 0x12, 0xEE,
+0xD9, 0xE3, 0x16, 0xA6, 0x60, 0xA6, 0x82, 0xA6,
+0xA1, 0xA6, 0x01, 0x6E, 0x0C, 0xEE, 0x4C, 0xEE,
+0x0E, 0x43, 0x0A, 0x2E, 0x38, 0x59, 0x03, 0x67,
+0x08, 0x60, 0x24, 0x59, 0x83, 0xE3, 0x04, 0x60,
+0x15, 0x59, 0x05, 0x67, 0x02, 0x61, 0xA1, 0xE4,
+0x4C, 0xE8, 0x04, 0x94, 0xB0, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x9B, 0x6F, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A,
+0x01, 0x6C, 0x8C, 0xEB, 0x0D, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x09, 0x61, 0x04, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0x03, 0xF5, 0x18, 0x4C,
+0xB1, 0x67, 0xF0, 0x67, 0x00, 0x18, 0x4D, 0x63,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x2E, 0x68, 0x18, 0xEA, 0x05, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0xAD, 0xF0, 0x00, 0x4A, 0x12, 0xE8,
+0x01, 0xE2, 0x84, 0xA0, 0x0F, 0x5C, 0x48, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x88, 0x33, 0xE0, 0xF3,
+0x04, 0x4A, 0x69, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x1B, 0x6A, 0x34, 0x10, 0x3D, 0x6A, 0x6E, 0xA0,
+0x47, 0xC0, 0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x02, 0x6B, 0x6D, 0xEA, 0x39, 0x10, 0x6E, 0xA0,
+0x13, 0x6A, 0x47, 0xC0, 0x08, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x01, 0x6B, 0x6D, 0xEA, 0x4E, 0xC0,
+0x6E, 0xA0, 0x33, 0x6A, 0x47, 0xC0, 0x08, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x01, 0x6B, 0x6D, 0xEA,
+0x02, 0x6D, 0x4E, 0xC0, 0x07, 0xD5, 0x27, 0x10,
+0x6E, 0xA0, 0x0B, 0x6A, 0x47, 0xC0, 0x08, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x01, 0x6E, 0x4E, 0xC0,
+0x07, 0xD6, 0x1D, 0x10, 0x6E, 0xA0, 0x47, 0x6A,
+0x47, 0xC0, 0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x03, 0x6B, 0x6D, 0xEA, 0x4E, 0xC0, 0x07, 0xD3,
+0x12, 0x10, 0x23, 0x6A, 0x6E, 0xA0, 0x47, 0xC0,
+0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x03, 0x6B,
+0x6D, 0xEA, 0x4E, 0xC0, 0x07, 0xD3, 0x07, 0x10,
+0x6E, 0xA0, 0x08, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x03, 0x6B, 0x4E, 0xC0, 0x07, 0xD3, 0x05, 0x96,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x4C, 0x9A,
+0xCC, 0x35, 0x8C, 0x34, 0x55, 0xE5, 0x30, 0xF0,
+0x20, 0x6A, 0xA5, 0xF4, 0x14, 0x4A, 0x91, 0xE2,
+0xE5, 0x67, 0x1D, 0x65, 0x00, 0x6A, 0x48, 0x33,
+0xAD, 0xE3, 0xC0, 0x9C, 0x60, 0x9B, 0x31, 0xA0,
+0xCC, 0xEB, 0x03, 0x6E, 0x2C, 0xEE, 0x02, 0x69,
+0x2E, 0xEE, 0x07, 0x2E, 0xFF, 0x6E, 0x4C, 0xEE,
+0x01, 0x69, 0x2E, 0xEE, 0x02, 0x2E, 0xBF, 0x4E,
+0xCC, 0xEB, 0x48, 0x36, 0xE5, 0xE6, 0x60, 0xD9,
+0x78, 0x67, 0x79, 0xE6, 0x60, 0x9E, 0x01, 0x4A,
+0x02, 0x6B, 0x4E, 0xEB, 0x04, 0x4C, 0xE3, 0x2B,
+0x51, 0xA0, 0x05, 0x95, 0x03, 0x6B, 0x52, 0x32,
+0xAC, 0x34, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6D,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF2, 0x6C, 0x9B,
+0x01, 0xF2, 0xB8, 0x9D, 0x6D, 0xE4, 0xB1, 0xE4,
+0x60, 0x9B, 0xE0, 0x9C, 0x03, 0x2F, 0xC3, 0x67,
+0x00, 0x69, 0x02, 0x10, 0xC7, 0x67, 0x20, 0x69,
+0x1F, 0x6C, 0x01, 0x6D, 0xA4, 0xEC, 0xCC, 0xED,
+0x09, 0x25, 0x25, 0xE4, 0xFF, 0x6C, 0x8C, 0xE9,
+0x0B, 0x22, 0x0C, 0x59, 0x09, 0x61, 0x20, 0x49,
+0x8C, 0xE9, 0x06, 0x10, 0xFF, 0x4C, 0xFF, 0x6D,
+0xAC, 0xEC, 0xFF, 0x74, 0xEE, 0x61, 0x00, 0x69,
+0x20, 0x6E, 0x02, 0x23, 0xE3, 0x67, 0x00, 0x6E,
+0x00, 0x6C, 0xFF, 0x6B, 0xA4, 0x67, 0x6C, 0xED,
+0x1D, 0x65, 0x01, 0x6D, 0xA4, 0xEC, 0xEC, 0xED,
+0x0B, 0x25, 0x98, 0x67, 0xD1, 0xE4, 0x6C, 0xEC,
+0x04, 0xD4, 0x0B, 0x22, 0x0C, 0x5C, 0x09, 0x61,
+0x20, 0x4C, 0x6C, 0xEC, 0x04, 0xD4, 0x05, 0x10,
+0x01, 0x4C, 0x20, 0x74, 0xEA, 0x61, 0x00, 0x6D,
+0x04, 0xD5, 0x5D, 0x67, 0x67, 0x42, 0x20, 0xC0,
+0x09, 0x4B, 0x40, 0xA3, 0x41, 0xC0, 0x05, 0x94,
+0x00, 0x18, 0x14, 0x57, 0x05, 0x94, 0x7F, 0x6B,
+0x4C, 0xEB, 0x08, 0xD3, 0x00, 0x18, 0x14, 0x57,
+0x08, 0x94, 0x62, 0x67, 0x06, 0xD1, 0x83, 0xE9,
+0x12, 0x61, 0xBD, 0x67, 0xC7, 0x45, 0x19, 0x4E,
+0x40, 0xA6, 0x08, 0x95, 0x04, 0x96, 0xFF, 0x6C,
+0x8C, 0xED, 0xCC, 0xEC, 0x83, 0xED, 0x04, 0x60,
+0x9D, 0x67, 0xA7, 0x44, 0x09, 0x4D, 0x40, 0xA5,
+0xFF, 0x6E, 0x4C, 0xEE, 0x06, 0xD6, 0x92, 0xA0,
+0x04, 0x6A, 0x8C, 0xEA, 0x08, 0x22, 0x80, 0x6A,
+0x6C, 0xEA, 0x05, 0x22, 0x06, 0x93, 0x4D, 0xEB,
+0xFF, 0x6A, 0x4C, 0xEB, 0x06, 0xD3, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x01, 0x6C, 0x8C, 0xEB, 0x0F, 0x23,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x0B, 0x61,
+0x51, 0xA0, 0x05, 0x95, 0x06, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x03, 0x6F, 0x23, 0xF5, 0x0C, 0x4C,
+0x4C, 0xEF, 0x00, 0x18, 0x4D, 0x63, 0x51, 0xA0,
+0x05, 0x94, 0x06, 0x95, 0x03, 0x6F, 0x00, 0x6E,
+0x4C, 0xEF, 0x00, 0x18, 0x9B, 0x6F, 0x9D, 0x67,
+0xA7, 0x44, 0x15, 0x4D, 0x80, 0xA5, 0x4A, 0x59,
+0x82, 0xC0, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x48, 0x6B, 0x3F, 0x10,
+0x40, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x40, 0x6B, 0x37, 0x10,
+0x36, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x38, 0x6B, 0x2F, 0x10,
+0x2C, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x30, 0x6B, 0x27, 0x10,
+0x24, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x28, 0x6B, 0x1F, 0x10,
+0x1C, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x20, 0x6B, 0x17, 0x10,
+0x14, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x18, 0x6B, 0x0F, 0x10,
+0x0C, 0x59, 0x06, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x10, 0x6B, 0x07, 0x10,
+0x04, 0x59, 0x07, 0x61, 0x73, 0xA0, 0x79, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0x08, 0x6B, 0x6D, 0xEA,
+0x04, 0x10, 0x73, 0xA0, 0x79, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x53, 0xC0, 0x00, 0x18, 0xE8, 0x67,
+0x30, 0xF0, 0x20, 0x6A, 0x4F, 0xF2, 0x75, 0xA2,
+0x03, 0x6A, 0x6C, 0xEA, 0x18, 0x22, 0x01, 0x72,
+0x38, 0x6D, 0x04, 0x60, 0x02, 0x72, 0x2D, 0x6D,
+0x01, 0x60, 0x15, 0x6D, 0x51, 0xA0, 0x05, 0x94,
+0x03, 0x6E, 0x4C, 0xEE, 0x00, 0x18, 0xA1, 0x75,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC8, 0xF7, 0x95, 0xA2, 0x04, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xC8, 0xF7, 0x75, 0xC2, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xF3, 0x63, 0x19, 0x62, 0x18, 0xD1, 0x17, 0xD0,
+0xFF, 0x6A, 0x30, 0xF0, 0x20, 0x6D, 0x8C, 0xEA,
+0x20, 0xF4, 0x00, 0x4D, 0x06, 0x04, 0x1E, 0x6E,
+0x0F, 0xD2, 0x00, 0x18, 0x39, 0x20, 0x0F, 0x92,
+0x2E, 0x68, 0x18, 0xEA, 0x30, 0xF0, 0x20, 0x6A,
+0xAD, 0xF0, 0x00, 0x4A, 0x12, 0xE8, 0x01, 0xE2,
+0x76, 0xA0, 0x01, 0x6A, 0x6D, 0xEA, 0x70, 0xA0,
+0x56, 0xC0, 0x7F, 0x6A, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x50, 0xC0, 0xEC, 0xF7, 0x10, 0x4B,
+0x00, 0x6A, 0x20, 0xA3, 0x0F, 0x94, 0x2A, 0xEC,
+0x07, 0x60, 0x01, 0x4A, 0xFF, 0x6C, 0x8C, 0xEA,
+0x06, 0x72, 0x01, 0x4B, 0xF6, 0x61, 0xF3, 0x10,
+0x0E, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x02, 0x6C,
+0x8C, 0xEB, 0x12, 0x2B, 0x1C, 0x10, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0x43, 0xF5, 0x00, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF5,
+0x10, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0xE2, 0x10,
+0xC6, 0xF3, 0x5C, 0x9A, 0x05, 0x5A, 0x07, 0x61,
+0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF5,
+0x04, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x72, 0xA0,
+0x01, 0x6C, 0x51, 0xA0, 0x6A, 0x33, 0x8C, 0xEB,
+0xC4, 0xA0, 0x04, 0xD3, 0x71, 0xA0, 0x03, 0x6F,
+0x30, 0xF0, 0x20, 0x6C, 0x72, 0x33, 0xEC, 0xEB,
+0x63, 0xF5, 0x18, 0x4C, 0xB1, 0x67, 0x4C, 0xEF,
+0x05, 0xD3, 0x00, 0x18, 0x4D, 0x63, 0x20, 0x59,
+0xC0, 0xF0, 0x00, 0x60, 0x0F, 0x95, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x4C, 0x9A, 0xAC, 0x35,
+0x0E, 0x93, 0x49, 0xE5, 0x14, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x58, 0x9A, 0x11, 0xD5,
+0x30, 0x67, 0x49, 0xE5, 0x13, 0xD2, 0x05, 0x6A,
+0x58, 0xEB, 0x06, 0x03, 0x12, 0xEA, 0x4D, 0xE3,
+0x10, 0xD3, 0x00, 0xF0, 0x1D, 0x03, 0x4D, 0xE3,
+0x12, 0xD3, 0x10, 0x94, 0x2E, 0x68, 0x01, 0x6E,
+0x40, 0xA4, 0x7F, 0x4A, 0x0E, 0xD2, 0x0E, 0x95,
+0xFF, 0x6A, 0x4C, 0xED, 0x18, 0xED, 0x30, 0xF0,
+0x20, 0x6A, 0x0E, 0xD5, 0xAD, 0xF0, 0x00, 0x4A,
+0x7F, 0x6D, 0x12, 0xE8, 0x01, 0xE2, 0x51, 0xA1,
+0x71, 0xA0, 0x5E, 0x32, 0x5C, 0x32, 0xAC, 0xEB,
+0x4D, 0xEB, 0x71, 0xC0, 0x91, 0xA1, 0x41, 0x6A,
+0x4B, 0xEA, 0x9A, 0x34, 0xCC, 0xEC, 0x98, 0x34,
+0x6C, 0xEA, 0x8D, 0xEA, 0x51, 0xC0, 0x64, 0xA1,
+0x03, 0x6C, 0x64, 0xC0, 0xF1, 0xA1, 0x04, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEF, 0x4C, 0xEB, 0xED, 0xEB,
+0x71, 0xC0, 0xF1, 0xA1, 0x0D, 0x6A, 0x4B, 0xEA,
+0x8C, 0xEF, 0xE8, 0x37, 0x6C, 0xEA, 0xED, 0xEA,
+0xF2, 0xA0, 0x05, 0x6B, 0x6B, 0xEB, 0xEC, 0xEB,
+0x51, 0xC0, 0x72, 0xC0, 0x71, 0xA1, 0x72, 0x33,
+0x8C, 0xEB, 0x70, 0x34, 0x31, 0x6B, 0x6B, 0xEB,
+0x4C, 0xEB, 0x56, 0xA0, 0x8D, 0xEB, 0x71, 0xC0,
+0x4D, 0xEE, 0x50, 0xA0, 0xD6, 0xC0, 0x4C, 0xED,
+0xB0, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x6C, 0x9A, 0x11, 0x94, 0x0E, 0x95, 0x69, 0xE4,
+0xAC, 0x34, 0x6D, 0xE4, 0x30, 0xF0, 0x20, 0x6C,
+0xE1, 0xF2, 0xA8, 0x9C, 0x11, 0x94, 0xB5, 0xE4,
+0xC0, 0xA2, 0xFF, 0x6C, 0x01, 0x4A, 0x8C, 0xEE,
+0xAA, 0xEA, 0xC0, 0xC3, 0x01, 0x4B, 0xF8, 0x61,
+0x76, 0xA1, 0x02, 0x6A, 0x6C, 0xEA, 0x8C, 0xEA,
+0x1C, 0x22, 0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x8C, 0x9A, 0xAC, 0x33, 0x14, 0x95,
+0x91, 0xE3, 0x40, 0x9D, 0x30, 0xF0, 0x20, 0x6D,
+0xE1, 0xF2, 0xAC, 0x9D, 0xAC, 0xEA, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6A, 0x13, 0x94, 0x01, 0xF2,
+0x58, 0x9A, 0x4D, 0xE3, 0x40, 0x9C, 0x30, 0xF0,
+0x20, 0x6C, 0xE1, 0xF2, 0x90, 0x9C, 0x8C, 0xEA,
+0x40, 0xDB, 0x0F, 0x94, 0x00, 0x18, 0xC5, 0x75,
+0x0E, 0x94, 0x00, 0x18, 0xC5, 0x75, 0xB1, 0xA1,
+0x0F, 0x94, 0x03, 0x6A, 0x4C, 0xED, 0x00, 0x18,
+0x31, 0x70, 0xB1, 0xA0, 0x0E, 0x94, 0x03, 0x6B,
+0x6C, 0xED, 0x00, 0x18, 0x31, 0x70, 0x10, 0x94,
+0x12, 0x95, 0x01, 0x4C, 0xAA, 0xEC, 0x10, 0xD4,
+0x7F, 0xF7, 0x07, 0x61, 0x0B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB, 0x1F, 0xF7,
+0x0E, 0x2B, 0x17, 0x17, 0x19, 0x97, 0x18, 0x91,
+0x17, 0x90, 0x0D, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xE9, 0xF0, 0x27, 0xA2, 0x2E, 0x68, 0xE9, 0xF0,
+0x46, 0xA2, 0x18, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0xAD, 0xF0, 0x00, 0x4B, 0x02, 0x72, 0x12, 0xE8,
+0x01, 0xE3, 0x30, 0x60, 0x03, 0x5A, 0x03, 0x60,
+0x01, 0x72, 0x07, 0x60, 0xA7, 0x10, 0x03, 0x72,
+0x70, 0x60, 0x04, 0x72, 0x80, 0xF0, 0x0B, 0x60,
+0xA1, 0x10, 0x0C, 0x6A, 0x7D, 0x67, 0x4F, 0xCB,
+0x9D, 0x67, 0x0E, 0x6B, 0x70, 0xC4, 0x52, 0xC4,
+0x5B, 0xA0, 0x03, 0x6B, 0xBD, 0x67, 0x53, 0xC4,
+0x43, 0xA0, 0x54, 0xC4, 0x51, 0xA0, 0x4A, 0x34,
+0x6C, 0xEC, 0x95, 0xC5, 0x82, 0x67, 0x6C, 0xEC,
+0x96, 0xC5, 0x85, 0xA0, 0x97, 0xC5, 0x86, 0xA0,
+0x98, 0xC5, 0x5E, 0x34, 0x52, 0x32, 0x6C, 0xEA,
+0x99, 0xC5, 0x5A, 0xC5, 0x52, 0xA0, 0x01, 0x6B,
+0x4A, 0x32, 0x6C, 0xEA, 0x5B, 0xC5, 0x58, 0xA0,
+0x5C, 0xC5, 0x62, 0x10, 0x7D, 0x67, 0x0C, 0x6A,
+0x4F, 0xCB, 0x0E, 0x6A, 0x50, 0xC3, 0x0D, 0x6A,
+0x52, 0xC3, 0x44, 0xA0, 0x2C, 0x31, 0x53, 0xC3,
+0x40, 0xA0, 0x54, 0xC3, 0x41, 0xA0, 0x55, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x4C, 0x9A,
+0x49, 0xE1, 0x40, 0xA2, 0x56, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF2, 0x54, 0x9A, 0x49, 0xE1,
+0x40, 0xA2, 0x57, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF2, 0x58, 0x9A, 0x49, 0xE1, 0x40, 0xA2,
+0x58, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF2,
+0x5C, 0x9A, 0x49, 0xE1, 0x40, 0xA2, 0x59, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x58, 0x9A,
+0x49, 0xE1, 0x40, 0xA2, 0x5A, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x40, 0x9A, 0x49, 0xE1,
+0x40, 0xA2, 0x5B, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF3, 0x44, 0x9A, 0x49, 0xE1, 0x40, 0xA2,
+0x5C, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3,
+0x48, 0x9A, 0x45, 0xE1, 0x40, 0xA1, 0x5D, 0xC3,
+0x2F, 0x10, 0x9D, 0x67, 0x0C, 0x6A, 0x4F, 0xCC,
+0x0E, 0x6A, 0x50, 0xC4, 0x52, 0xC4, 0x59, 0xA0,
+0x53, 0xC4, 0x20, 0xF0, 0x42, 0xA0, 0x57, 0xC4,
+0x20, 0xF0, 0x43, 0xA0, 0x58, 0xC4, 0x91, 0x67,
+0x00, 0x18, 0x14, 0x57, 0xBD, 0x67, 0x59, 0xC5,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x44, 0x9A,
+0x34, 0x31, 0x45, 0xE1, 0x40, 0xA1, 0x5A, 0xC5,
+0x48, 0xA0, 0x5D, 0xC5, 0x11, 0x10, 0x7D, 0x67,
+0x03, 0x6A, 0x4F, 0xCB, 0x0E, 0x6A, 0x50, 0xC3,
+0x0F, 0x6A, 0x52, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF1, 0x7C, 0xA2, 0x60, 0xF1, 0x1C, 0x4A,
+0x41, 0xA2, 0x9D, 0x67, 0x73, 0xC4, 0x54, 0xC4,
+0x04, 0x94, 0x05, 0x95, 0x06, 0x96, 0x07, 0x97,
+0x00, 0x18, 0xC0, 0x57, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x21, 0x6D, 0x30, 0xF0, 0x20, 0x6B,
+0x50, 0xF1, 0x14, 0x4D, 0x30, 0xF0, 0x20, 0x6E,
+0x30, 0xF0, 0x21, 0x6C, 0x6F, 0xF4, 0x08, 0x4B,
+0x6F, 0xF3, 0x0C, 0x4E, 0xD0, 0xF2, 0x0E, 0x4C,
+0xE5, 0x67, 0x00, 0x6A, 0x40, 0xDB, 0x41, 0xDB,
+0x42, 0xDB, 0x43, 0xDB, 0x44, 0xDB, 0x14, 0x4B,
+0xEA, 0xEB, 0x40, 0xC5, 0x40, 0xDE, 0x20, 0xF0,
+0x5F, 0xC5, 0x60, 0xF0, 0x5E, 0xC5, 0x04, 0x4E,
+0x40, 0xCC, 0x9F, 0xF7, 0x42, 0xCC, 0x80, 0xF0,
+0x42, 0xCC, 0x00, 0xF1, 0x40, 0xCC, 0x60, 0xF1,
+0x5E, 0xCC, 0x01, 0x4D, 0x02, 0x4C, 0xE5, 0x61,
+0x30, 0xF0, 0x21, 0x6A, 0x78, 0x67, 0x50, 0xF3,
+0x6C, 0xDA, 0x20, 0xE8, 0xFF, 0x6A, 0x8C, 0xEA,
+0x25, 0xF0, 0xA4, 0x42, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xA4, 0x35, 0x00, 0x6C,
+0x75, 0xE5, 0x83, 0xCD, 0xE4, 0xF7, 0xA4, 0x42,
+0xA4, 0x35, 0x75, 0xE5, 0x84, 0xCD, 0x65, 0xF0,
+0xA4, 0x42, 0xA4, 0x35, 0x75, 0xE5, 0x84, 0xCD,
+0xA5, 0xF0, 0xA4, 0x42, 0xE5, 0xF0, 0x04, 0x4A,
+0xA4, 0x35, 0x44, 0x32, 0x75, 0xE5, 0x6D, 0xE2,
+0x83, 0xCD, 0x82, 0xCB, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x8C, 0xEA, 0x14, 0x6D, 0xB8, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0x00, 0x6B, 0x12, 0xED, 0x95, 0xE5, 0xE9, 0xF1,
+0x68, 0xDD, 0xE9, 0xF1, 0x6C, 0xDD, 0xE9, 0xF1,
+0x70, 0xDD, 0xE9, 0xF1, 0x74, 0xDD, 0xE9, 0xF1,
+0x78, 0xDD, 0x95, 0xE2, 0x22, 0xF2, 0x1A, 0x4A,
+0x48, 0x32, 0x91, 0xE2, 0xC9, 0xF6, 0x74, 0xC5,
+0x61, 0xDC, 0x20, 0xE8, 0xFF, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x86, 0xF2, 0x00, 0x4B, 0x8C, 0xEA,
+0x69, 0xE2, 0x00, 0x6B, 0x09, 0xF7, 0x73, 0xC2,
+0x49, 0xF7, 0x72, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x01, 0xF3,
+0x6C, 0x9B, 0x4C, 0xEC, 0x90, 0x34, 0x6D, 0xE4,
+0xC0, 0xA3, 0x01, 0x6D, 0x30, 0xF0, 0x20, 0x6B,
+0x86, 0xF2, 0x00, 0x4B, 0xCC, 0xED, 0x4A, 0xF2,
+0xB2, 0xC3, 0x30, 0xF0, 0x20, 0x6D, 0x01, 0xF3,
+0xB0, 0x9D, 0xB5, 0xE4, 0xC0, 0xA5, 0x7F, 0x6D,
+0xCC, 0xED, 0x4A, 0xF2, 0xAD, 0xC3, 0x30, 0xF0,
+0x20, 0x6D, 0x01, 0xF3, 0xB4, 0x9D, 0xB5, 0xE4,
+0xA0, 0xA5, 0x4A, 0xF2, 0xB1, 0xC3, 0x30, 0xF0,
+0x20, 0x6D, 0x01, 0xF3, 0xB8, 0x9D, 0xB5, 0xE4,
+0xA0, 0xA5, 0x4A, 0xF2, 0xB3, 0xC3, 0x30, 0xF0,
+0x20, 0x6D, 0x01, 0xF3, 0xBC, 0x9D, 0xB5, 0xE4,
+0xC0, 0xA5, 0x3F, 0x6D, 0xAC, 0xEE, 0x4A, 0xF2,
+0xCE, 0xC3, 0x30, 0xF0, 0x20, 0x6E, 0x21, 0xF3,
+0xC0, 0x9E, 0xD9, 0xE4, 0xC0, 0xA6, 0xAC, 0xEE,
+0x4A, 0xF2, 0xCF, 0xC3, 0x30, 0xF0, 0x20, 0x6E,
+0x21, 0xF3, 0xC4, 0x9E, 0xD9, 0xE4, 0xC0, 0xA6,
+0xAC, 0xEE, 0x4A, 0xF2, 0xD5, 0xC3, 0x30, 0xF0,
+0x20, 0x6E, 0x21, 0xF3, 0xC8, 0x9E, 0xD9, 0xE4,
+0xC0, 0xA6, 0x4A, 0xF2, 0xCC, 0xC3, 0x30, 0xF0,
+0x20, 0x6E, 0x21, 0xF3, 0xCC, 0x9E, 0xD9, 0xE4,
+0xC0, 0xA6, 0xCC, 0xEA, 0x56, 0x32, 0x4A, 0xF2,
+0x50, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x50, 0x9A, 0x49, 0xE4, 0xC0, 0xA2, 0xCC, 0xED,
+0x4A, 0xF2, 0xB6, 0xC3, 0xA0, 0xA2, 0x40, 0x6A,
+0xAC, 0xEA, 0x4A, 0xF2, 0x57, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF3, 0x54, 0x9A, 0x51, 0xE4,
+0x40, 0xA4, 0x4A, 0xF2, 0x54, 0xC3, 0x20, 0xE8,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xFF, 0x6E, 0x21, 0xF3,
+0x50, 0x9A, 0xCC, 0xEC, 0x90, 0x34, 0x49, 0xE4,
+0x40, 0xA2, 0x3F, 0x68, 0x30, 0xF0, 0x20, 0x6F,
+0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3,
+0x50, 0x9A, 0x21, 0xF3, 0xE4, 0x9F, 0x49, 0xE4,
+0x40, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x48, 0x9A, 0x49, 0xE4, 0xA0, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF3, 0x5C, 0x9A, 0xCC, 0xED,
+0x49, 0xE4, 0x60, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x40, 0x9A, 0xCC, 0xEB, 0x49, 0xE4,
+0xF1, 0xE4, 0x40, 0xA2, 0xE0, 0xA4, 0x30, 0xF0,
+0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C, 0x91, 0xE0,
+0xCC, 0xEA, 0xCC, 0xEF, 0x66, 0xF5, 0xD5, 0xA4,
+0xAE, 0xEE, 0x0D, 0x26, 0x86, 0xF5, 0x93, 0xA4,
+0x01, 0x69, 0xAE, 0xEC, 0x09, 0x24, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF5, 0x00, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0xFF, 0x6A, 0x48, 0x10, 0x00, 0x69,
+0x30, 0xF0, 0x20, 0x6C, 0x86, 0xF2, 0x00, 0x4C,
+0xA6, 0xF5, 0xB2, 0xA4, 0x36, 0x25, 0x0E, 0xED,
+0x34, 0x2D, 0xA6, 0xF5, 0xB3, 0xA4, 0x2E, 0xED,
+0x30, 0x2D, 0xA6, 0xF5, 0xB7, 0xA4, 0x2D, 0x25,
+0xA6, 0xF5, 0xD8, 0xA4, 0xBB, 0xEE, 0x01, 0x2D,
+0xE5, 0xE8, 0x10, 0xED, 0x1D, 0x2D, 0x3F, 0x6D,
+0xAC, 0xEB, 0xAC, 0xEA, 0xAC, 0xEF, 0xC6, 0xF3,
+0xB8, 0x9C, 0x02, 0x6E, 0xA6, 0xF5, 0xF4, 0xC4,
+0xCC, 0xED, 0xA6, 0xF5, 0x75, 0xC4, 0xA6, 0xF5,
+0x56, 0xC4, 0x0E, 0x25, 0xC6, 0xF3, 0x9C, 0x9C,
+0x04, 0x5C, 0x0A, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0xA3, 0xF5, 0x0C, 0x4C, 0xB0, 0x67, 0xD1, 0x67,
+0x04, 0xD3, 0x05, 0xD2, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xA6, 0xF5, 0x78, 0xA2, 0x01, 0x4B, 0xA6, 0xF5,
+0x78, 0xC2, 0x47, 0x40, 0x18, 0x4A, 0x07, 0x29,
+0x01, 0x6B, 0x47, 0x40, 0x0C, 0xEB, 0x19, 0x4A,
+0x02, 0x2B, 0x47, 0x40, 0x17, 0x4A, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xF4, 0x63, 0x17, 0x62, 0x16, 0xD1, 0x15, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x82, 0x67, 0x0F, 0xD2,
+0x00, 0x18, 0xD4, 0x77, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x4A, 0xF2, 0x0C, 0xA2,
+0x2E, 0x69, 0x30, 0xF0, 0x20, 0x6B, 0x38, 0xE8,
+0xAD, 0xF0, 0x00, 0x4B, 0x4A, 0xF2, 0x8E, 0xA2,
+0x4A, 0xF2, 0xAF, 0xA2, 0x4A, 0xF2, 0xD1, 0xA2,
+0x08, 0xD4, 0x0C, 0xD5, 0x0D, 0xD6, 0x4A, 0xF2,
+0x94, 0xA2, 0x4A, 0xF2, 0xB6, 0xA2, 0x4A, 0xF2,
+0xD7, 0xA2, 0x12, 0xD4, 0x0E, 0xD5, 0x10, 0xD6,
+0x12, 0xE9, 0x25, 0xE3, 0x4A, 0xF2, 0x6D, 0xA2,
+0x09, 0xD3, 0x4A, 0xF2, 0x73, 0xA2, 0x11, 0xD3,
+0x4A, 0xF2, 0x75, 0xA2, 0x0B, 0xD3, 0x4A, 0xF2,
+0x72, 0xA2, 0x0F, 0x23, 0xC6, 0xF3, 0x78, 0x9A,
+0x02, 0x6C, 0x8C, 0xEB, 0x0A, 0x23, 0xC6, 0xF3,
+0x5C, 0x9A, 0x05, 0x5A, 0x06, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xC3, 0xF5, 0x14, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x7E, 0xA1, 0x80, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA, 0x0C, 0x93,
+0x01, 0x5A, 0x58, 0x67, 0x4B, 0xEA, 0x4C, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0xE5, 0xF0, 0x44, 0x40,
+0x86, 0xF2, 0x00, 0x4D, 0x44, 0x32, 0xA9, 0xE2,
+0x0C, 0xD3, 0x09, 0x96, 0x62, 0xAA, 0x0A, 0xD5,
+0x6D, 0xE6, 0x62, 0xCA, 0x10, 0x92, 0x07, 0x22,
+0xA6, 0xF5, 0x5C, 0x9D, 0x08, 0x93, 0x49, 0xE3,
+0xA6, 0xF5, 0x5C, 0xDD, 0x42, 0x12, 0x0E, 0x92,
+0xFF, 0x4A, 0x8C, 0xEA, 0x3E, 0x5A, 0x2A, 0x60,
+0x0F, 0x94, 0x00, 0x18, 0x0C, 0x78, 0x0A, 0x94,
+0x02, 0x67, 0x02, 0x6B, 0xC6, 0xF3, 0x58, 0x9C,
+0x6C, 0xEA, 0x0B, 0x22, 0xC6, 0xF3, 0x5C, 0x9C,
+0x05, 0x5A, 0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0xE3, 0xF5, 0x00, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0xFF, 0x70, 0x20, 0xF2, 0x05, 0x60,
+0x2E, 0x69, 0x38, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xAD, 0xF0, 0x00, 0x4A, 0x0B, 0x94, 0x12, 0xE9,
+0x25, 0xE2, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF5, 0x60, 0x9A, 0x6D, 0xE4,
+0xC6, 0xF5, 0x60, 0xDA, 0x71, 0xA1, 0x80, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6D, 0xAC, 0xEA,
+0x00, 0xF2, 0x0B, 0x2A, 0x12, 0x92, 0x01, 0x6B,
+0x6C, 0xEA, 0x00, 0xF2, 0x06, 0x2A, 0x0D, 0x92,
+0x49, 0x6E, 0xCE, 0xEA, 0x01, 0x5A, 0x98, 0x67,
+0x02, 0x6A, 0x93, 0xE2, 0x10, 0xD4, 0x56, 0xA1,
+0x6C, 0xEA, 0xAC, 0xEA, 0x0C, 0x22, 0x90, 0x67,
+0x00, 0x18, 0x14, 0x57, 0x7F, 0x6D, 0x4C, 0xED,
+0x0D, 0xD5, 0x72, 0xA1, 0x40, 0x6A, 0xFF, 0x6E,
+0x6C, 0xEA, 0xCC, 0xEA, 0x13, 0x10, 0x0F, 0x92,
+0x50, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF3,
+0x5C, 0x9A, 0x49, 0xE3, 0x40, 0xA2, 0x00, 0xF6,
+0x40, 0x32, 0x00, 0xF6, 0x43, 0x32, 0x00, 0x52,
+0x06, 0x60, 0x72, 0xA1, 0x40, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0x2A, 0x00, 0x6C,
+0x0A, 0xD4, 0x02, 0x10, 0x01, 0x6D, 0x0A, 0xD5,
+0x6E, 0xA1, 0x08, 0x6A, 0x6C, 0xEA, 0x19, 0x22,
+0x08, 0x96, 0x09, 0x92, 0x0A, 0x93, 0x04, 0xD6,
+0x0B, 0x97, 0x0E, 0x96, 0x30, 0xF0, 0x20, 0x6C,
+0x05, 0xD2, 0xE3, 0xF5, 0x08, 0x4C, 0x00, 0x6A,
+0xB0, 0x67, 0x06, 0xD3, 0x07, 0xD2, 0x00, 0x18,
+0x4D, 0x63, 0x0D, 0x95, 0x11, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x03, 0xF6, 0x14, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x02, 0x6C,
+0x8C, 0xEB, 0x13, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x0F, 0x61, 0x0A, 0x96, 0x11, 0x94,
+0x09, 0x95, 0x06, 0xD6, 0x0D, 0x97, 0x0E, 0x96,
+0x04, 0xD4, 0x30, 0xF0, 0x20, 0x6C, 0x05, 0xD5,
+0x23, 0xF6, 0x04, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0xC6, 0xF3, 0x78, 0x9A, 0x02, 0x6C,
+0x8C, 0xEB, 0x0F, 0x23, 0xC6, 0xF3, 0x5C, 0x9A,
+0x05, 0x5A, 0x0B, 0x61, 0x08, 0x95, 0x0C, 0x96,
+0x0B, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0x00, 0x6A,
+0x43, 0xF6, 0x08, 0x4C, 0x04, 0xD2, 0x00, 0x18,
+0x4D, 0x63, 0x0B, 0x94, 0x54, 0xA9, 0xFF, 0xF7,
+0x1F, 0x6B, 0x8F, 0xE3, 0x62, 0xEA, 0x02, 0x60,
+0x49, 0xE4, 0x54, 0xC9, 0x0B, 0x95, 0x55, 0xA9,
+0xFF, 0xF7, 0x1F, 0x6B, 0xAF, 0xE3, 0x62, 0xEA,
+0x02, 0x60, 0x49, 0xE5, 0x55, 0xC9, 0x0A, 0x96,
+0x80, 0xF0, 0x1A, 0x26, 0x0E, 0x93, 0xFF, 0x6A,
+0xFF, 0x4B, 0x4C, 0xEB, 0x3E, 0x5B, 0x1F, 0x60,
+0x08, 0x94, 0x0B, 0x95, 0x90, 0x33, 0x0F, 0x6C,
+0x98, 0xED, 0x12, 0xEC, 0x82, 0xEB, 0x25, 0x61,
+0x09, 0x96, 0x02, 0x5E, 0x22, 0x60, 0x08, 0x93,
+0x6E, 0x35, 0x01, 0x4D, 0x4C, 0xED, 0x30, 0xF0,
+0x20, 0x6B, 0xAC, 0xEA, 0x86, 0xF2, 0x00, 0x4B,
+0x06, 0x5A, 0x6D, 0xE0, 0x85, 0x67, 0x01, 0x61,
+0x05, 0x6C, 0x09, 0xF7, 0x53, 0xA3, 0x91, 0xE2,
+0x09, 0xF7, 0x93, 0xC3, 0x18, 0x10, 0x09, 0x94,
+0x02, 0x5C, 0x0B, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE0, 0x09, 0xF7,
+0x73, 0xA2, 0x01, 0x4B, 0x09, 0xF7, 0x73, 0xC2,
+0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2,
+0x00, 0x4A, 0x49, 0xE0, 0x49, 0xF7, 0x72, 0xA2,
+0x01, 0x4B, 0x49, 0xF7, 0x72, 0xC2, 0x6E, 0xA1,
+0x08, 0x6A, 0x6C, 0xEA, 0x0F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0x49, 0xE0,
+0x09, 0xF7, 0xB3, 0xA2, 0x49, 0xF7, 0xD2, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF6, 0x00, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x2E, 0x6A, 0x58, 0xE8,
+0x30, 0xF0, 0x20, 0x69, 0x86, 0xF2, 0x00, 0x49,
+0x35, 0xE0, 0x08, 0xD5, 0x09, 0xF7, 0x73, 0xA5,
+0x12, 0xEA, 0x29, 0xE2, 0x26, 0xF6, 0x58, 0xA2,
+0x43, 0xEB, 0x17, 0x61, 0x90, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0x06, 0x75, 0xC6, 0xF3, 0x58, 0x99,
+0x01, 0x6B, 0x6C, 0xEA, 0x2D, 0x22, 0xC6, 0xF3,
+0x5C, 0x99, 0x05, 0x5A, 0x29, 0x61, 0x08, 0x92,
+0x30, 0xF0, 0x20, 0x6C, 0x63, 0xF6, 0x0C, 0x4C,
+0x09, 0xF7, 0xB3, 0xA2, 0x49, 0xF7, 0xD2, 0xA2,
+0x1D, 0x10, 0x08, 0x93, 0x10, 0x94, 0x49, 0xF7,
+0x52, 0xA3, 0x83, 0xEA, 0xE0, 0xF0, 0x11, 0x61,
+0x90, 0x67, 0x00, 0x6D, 0x00, 0x18, 0x06, 0x75,
+0xC6, 0xF3, 0x58, 0x99, 0x01, 0x6B, 0x6C, 0xEA,
+0x0F, 0x22, 0xC6, 0xF3, 0x5C, 0x99, 0x05, 0x5A,
+0x0B, 0x61, 0x08, 0x96, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF6, 0x1C, 0x4C, 0x09, 0xF7, 0xB3, 0xA6,
+0x49, 0xF7, 0xD2, 0xA6, 0x00, 0x18, 0x4D, 0x63,
+0x90, 0x67, 0x00, 0x18, 0xCD, 0x77, 0xD5, 0x10,
+0x09, 0x94, 0x5D, 0x67, 0x67, 0x42, 0x1D, 0x4B,
+0x05, 0x5C, 0x20, 0xA3, 0x01, 0x61, 0x04, 0x69,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0x51, 0xE0, 0xC9, 0xF6, 0xB4, 0xA4, 0x0C, 0x96,
+0xFF, 0x6B, 0x6C, 0xE9, 0xB5, 0xE6, 0xC9, 0xF6,
+0xB4, 0xC4, 0x0E, 0x94, 0xFF, 0x4C, 0x6C, 0xEC,
+0x3E, 0x5C, 0x65, 0x60, 0x04, 0x59, 0x0B, 0x60,
+0x14, 0x6B, 0x78, 0xE8, 0x08, 0x94, 0x12, 0xEB,
+0x49, 0xE3, 0xE9, 0xF1, 0x68, 0x9A, 0x6D, 0xE4,
+0xE9, 0xF1, 0x68, 0xDA, 0x0A, 0x10, 0x14, 0x6B,
+0x78, 0xE8, 0x08, 0x94, 0x12, 0xEB, 0x49, 0xE3,
+0xE9, 0xF1, 0x78, 0x9A, 0x6D, 0xE4, 0xE9, 0xF1,
+0x78, 0xDA, 0x30, 0xF0, 0x20, 0x6D, 0x32, 0xF2,
+0x4A, 0x40, 0x86, 0xF2, 0x00, 0x4D, 0x48, 0x32,
+0xA9, 0xE2, 0x0A, 0xD2, 0x0B, 0x96, 0x41, 0x9A,
+0x0A, 0x93, 0x09, 0xD5, 0xC9, 0xE2, 0x41, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2, 0x44, 0x9A,
+0x60, 0xA2, 0x40, 0x6A, 0x6C, 0xEA, 0x1B, 0x22,
+0x0C, 0x94, 0x08, 0x97, 0x04, 0xD6, 0x05, 0xD4,
+0x30, 0xF0, 0x20, 0x6C, 0x83, 0xF6, 0x0C, 0x4C,
+0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x4D, 0x63,
+0x14, 0x6A, 0x58, 0xE8, 0x09, 0x93, 0x30, 0xF0,
+0x20, 0x6C, 0xA3, 0xF6, 0x08, 0x4C, 0x12, 0xEA,
+0x69, 0xE2, 0xE9, 0xF1, 0xA8, 0x9A, 0x0A, 0x92,
+0xC1, 0x9A, 0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0,
+0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A, 0xC6, 0xF3,
+0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB, 0x69, 0x23,
+0xC6, 0xF3, 0x7C, 0x9A, 0x05, 0x5B, 0x65, 0x61,
+0x14, 0x6B, 0x78, 0xE8, 0x22, 0xF2, 0x1A, 0x48,
+0x08, 0x30, 0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF6,
+0x18, 0x4C, 0x12, 0xEB, 0x4D, 0xE3, 0xE9, 0xF1,
+0xA8, 0x9B, 0x49, 0xE0, 0x53, 0x10, 0x05, 0x6B,
+0x78, 0xE8, 0x08, 0x94, 0x0C, 0x96, 0x12, 0xEB,
+0x2D, 0xE3, 0x62, 0xF2, 0x18, 0x4B, 0x68, 0x33,
+0x4D, 0xE3, 0x0B, 0xD3, 0x62, 0x9B, 0x0B, 0x95,
+0x8D, 0xE3, 0x62, 0xDD, 0x32, 0xF2, 0x6A, 0x40,
+0x68, 0x33, 0x4D, 0xE3, 0x09, 0xD3, 0x61, 0x9B,
+0x89, 0xE6, 0x49, 0xE3, 0x09, 0x93, 0x41, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF2, 0x44, 0x9A,
+0x60, 0xA2, 0x40, 0x6A, 0x6C, 0xEA, 0x14, 0x22,
+0x08, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0x04, 0xD6,
+0xC3, 0xF6, 0x08, 0x4C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x0B, 0x96, 0x09, 0x92,
+0x30, 0xF0, 0x20, 0x6C, 0xA2, 0x9E, 0xC1, 0x9A,
+0xE3, 0xF6, 0x00, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x20, 0x6A, 0x86, 0xF2, 0x00, 0x4A,
+0xC6, 0xF3, 0x78, 0x9A, 0x02, 0x6C, 0x8C, 0xEB,
+0x18, 0x23, 0xC6, 0xF3, 0x7C, 0x9A, 0x05, 0x5B,
+0x14, 0x61, 0x05, 0x6B, 0x78, 0xE8, 0x22, 0xF2,
+0x1A, 0x48, 0x08, 0x30, 0x30, 0xF0, 0x20, 0x6C,
+0xA3, 0xF6, 0x18, 0x4C, 0x12, 0xEB, 0x25, 0xE3,
+0x62, 0xF2, 0x18, 0x49, 0x28, 0x31, 0x45, 0xE1,
+0xA2, 0x99, 0x49, 0xE0, 0xC1, 0x9A, 0x00, 0x18,
+0x4D, 0x63, 0x17, 0x97, 0x16, 0x91, 0x15, 0x90,
+0x0C, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x0F, 0x5C,
+0x15, 0x60, 0xA1, 0xF4, 0x1C, 0x6C, 0x00, 0xF3,
+0x00, 0x6D, 0x02, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF4, 0x14, 0x6C, 0xB0, 0x67, 0x66, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x78, 0x9A, 0xFC, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x18, 0x10, 0x24, 0x5C, 0x17, 0x61,
+0xA1, 0xF4, 0x1C, 0x6C, 0x00, 0xF3, 0x00, 0x6D,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4,
+0x14, 0x6C, 0xFF, 0x6D, 0x77, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x78, 0x9A, 0x03, 0x6C, 0x40, 0xA3, 0x0C, 0xEA,
+0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF1, 0x7C, 0x9B, 0x46, 0x67, 0x8E, 0xEB,
+0x12, 0x23, 0x00, 0x6E, 0x66, 0x67, 0xE4, 0x67,
+0xE6, 0xEE, 0x01, 0x68, 0x0C, 0xEF, 0x07, 0x2F,
+0x01, 0x4B, 0xFF, 0x6F, 0xEC, 0xEB, 0x14, 0x73,
+0x01, 0x4E, 0xF5, 0x61, 0x14, 0x6B, 0x8F, 0xEC,
+0x44, 0xEB, 0xAC, 0xEC, 0x8D, 0xEA, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6B, 0x6C, 0xEC,
+0x48, 0x44, 0xD4, 0x4A, 0x6C, 0xEA, 0x59, 0x5A,
+0x58, 0x67, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x00, 0x6A, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0x00, 0x6A, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x01, 0x75,
+0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x08, 0x9A, 0x41, 0xF1, 0x08, 0x6C, 0x01, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x41, 0xF1,
+0x0C, 0x6C, 0xB0, 0x67, 0x00, 0x6E, 0x10, 0x10,
+0x02, 0x75, 0x1F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x08, 0x9A, 0x41, 0xF1, 0x08, 0x6C,
+0x02, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x41, 0xF1, 0x0C, 0x6C, 0xB0, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x04, 0x9A, 0x21, 0xF4, 0x00, 0x6C,
+0x00, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x21, 0xF6, 0x00, 0x6C, 0xB0, 0x67, 0x00, 0x6E,
+0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x08, 0x9A, 0x41, 0xF1, 0x08, 0x6C, 0x02, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0xB0, 0x67,
+0x41, 0xF1, 0x0C, 0x6C, 0x02, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x04, 0x9A, 0x21, 0xF4, 0x00, 0x6C, 0x01, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x21, 0xF6,
+0x00, 0x6C, 0xB0, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x15, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xA8, 0x9A, 0x01, 0xF0,
+0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x36, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xE3, 0xF6, 0x10, 0x4C, 0x16, 0x10,
+0x01, 0x75, 0x1B, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xA8, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x03, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x1F, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x23, 0xF7, 0x00, 0x4C, 0x30, 0xF0, 0x20, 0x6D,
+0x00, 0xF5, 0x14, 0x4D, 0x00, 0x18, 0x4D, 0x63,
+0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x60, 0x9A, 0x44, 0x9C, 0x4C, 0xEB, 0x00, 0x6A,
+0x0D, 0x23, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x20, 0x6D, 0x43, 0xF7, 0x10, 0x4C, 0x00, 0xF5,
+0x14, 0x4D, 0x00, 0x18, 0x4D, 0x63, 0x00, 0x6A,
+0x01, 0x10, 0x01, 0x6A, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x4C, 0xEF,
+0x0F, 0xD5, 0x08, 0xD7, 0x20, 0xF0, 0x6E, 0xA4,
+0x04, 0x67, 0x26, 0x67, 0x0E, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x9C,
+0x6C, 0xEA, 0x4A, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x63, 0xF7, 0x04, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x43, 0x10, 0x02, 0x5E, 0x03, 0x60, 0x08, 0x93,
+0x54, 0x5B, 0x11, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x60, 0x9A, 0x44, 0x98, 0x4C, 0xEB,
+0x00, 0x6A, 0x37, 0x23, 0x30, 0xF0, 0x20, 0x6C,
+0xA3, 0xF7, 0x04, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x4D, 0x63, 0x00, 0x6A, 0x2E, 0x10, 0x03, 0xF5,
+0x00, 0x6B, 0x06, 0xD3, 0x7F, 0x4B, 0x01, 0x4B,
+0x07, 0xD3, 0x08, 0x93, 0x04, 0x6C, 0x8B, 0xEC,
+0x6C, 0xEC, 0x4C, 0xEC, 0x06, 0x03, 0xC8, 0x32,
+0x4D, 0xE3, 0x09, 0xD3, 0x60, 0x9B, 0x0F, 0x96,
+0x01, 0x6D, 0x71, 0xE4, 0xFF, 0xF7, 0x1F, 0x6B,
+0x6C, 0xEC, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x0D, 0x22, 0x09, 0x92,
+0x08, 0x96, 0x0F, 0x93, 0xE0, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xE3, 0xF7, 0x00, 0x4C, 0xB1, 0x67,
+0xFD, 0xE6, 0x04, 0xD3, 0x00, 0x18, 0x4D, 0x63,
+0x01, 0x6A, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xAC, 0xEA,
+0x06, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x9C, 0x04, 0x67, 0x20, 0xF0,
+0x25, 0xA4, 0x6C, 0xEA, 0x0F, 0x22, 0x20, 0xF0,
+0xCB, 0xA4, 0x20, 0xF0, 0xEC, 0xA4, 0x20, 0xF0,
+0x44, 0xA4, 0x06, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0x24, 0xF0, 0x0C, 0x4C, 0x04, 0xD2, 0x05, 0xD1,
+0x00, 0x18, 0x4D, 0x63, 0x06, 0x93, 0xFF, 0x6A,
+0xF1, 0x4B, 0x4C, 0xEB, 0x15, 0x5B, 0x20, 0xF2,
+0x07, 0x61, 0x06, 0x93, 0x20, 0xF2, 0x04, 0x23,
+0x0F, 0x5B, 0x78, 0x67, 0x06, 0xD3, 0x98, 0x67,
+0x02, 0x6B, 0x8F, 0xE3, 0x04, 0x71, 0x20, 0xF0,
+0x72, 0xC0, 0x03, 0x60, 0x0B, 0x71, 0x80, 0xF0,
+0x00, 0x61, 0x06, 0x92, 0x59, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF3,
+0x00, 0x4B, 0x21, 0xF3, 0x3C, 0x9A, 0xC0, 0x9B,
+0xA1, 0xF4, 0x10, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x00, 0x4A, 0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF6,
+0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69, 0x00, 0x18,
+0x86, 0x36, 0xB1, 0x67, 0xA1, 0xF4, 0x14, 0x6C,
+0x57, 0x6E, 0x00, 0x18, 0x86, 0x36, 0xB1, 0x67,
+0xA1, 0xF6, 0x14, 0x6C, 0xA1, 0xF4, 0x1C, 0x69,
+0x57, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x91, 0x67,
+0x3F, 0x6D, 0x08, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D, 0x02, 0x6E,
+0x00, 0xF2, 0x00, 0x49, 0x00, 0x18, 0x86, 0x36,
+0x91, 0x67, 0x3F, 0x6D, 0x08, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x02, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x20, 0xF0,
+0x6C, 0xA0, 0x03, 0x73, 0x04, 0x60, 0x20, 0xF0,
+0x4B, 0xA0, 0x03, 0x72, 0x05, 0x61, 0xFF, 0xF7,
+0x1F, 0x68, 0x5E, 0xF0, 0x10, 0x69, 0x2A, 0x11,
+0x6E, 0xEA, 0x05, 0x2A, 0xFF, 0xF7, 0x1F, 0x68,
+0x5E, 0xF0, 0x15, 0x69, 0x23, 0x11, 0xFF, 0xF7,
+0x1F, 0x68, 0x5E, 0xF5, 0x10, 0x69, 0x1E, 0x11,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF3, 0x3C, 0x9A, 0x41, 0xF3, 0x04, 0x4B,
+0xC0, 0x9B, 0xB1, 0x67, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x04, 0x4A, 0xC0, 0x9A, 0xB1, 0x67,
+0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4, 0x14, 0x6C,
+0xB1, 0x67, 0x75, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E,
+0xD3, 0x10, 0x6F, 0x41, 0x4C, 0xEB, 0x02, 0x5B,
+0x07, 0x61, 0x06, 0x71, 0x05, 0x60, 0x07, 0x71,
+0x03, 0x60, 0x09, 0x71, 0xE0, 0xF0, 0x1C, 0x61,
+0x20, 0xF0, 0x44, 0xA0, 0x01, 0x72, 0x62, 0x61,
+0x02, 0x59, 0x60, 0x60, 0x06, 0x93, 0x09, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x1C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x28, 0x9A,
+0x08, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x1C, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x2C, 0x9A, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0xB0, 0x67,
+0xD1, 0x67, 0x1F, 0xF7, 0x00, 0x68, 0xA1, 0xF6,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0xB0, 0x67,
+0xA1, 0xF4, 0x14, 0x6C, 0x45, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0xB0, 0x67, 0xA1, 0xF6, 0x14, 0x6C,
+0x45, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0xB0, 0x9A, 0xFF, 0xF7,
+0x1F, 0x68, 0x54, 0xF5, 0x15, 0x69, 0x01, 0xF0,
+0x10, 0x6C, 0x00, 0xF2, 0x11, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4,
+0x00, 0x6C, 0x00, 0x18, 0x86, 0x36, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF4, 0x1C, 0x68, 0xA1, 0xF6,
+0x00, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x01, 0xF4,
+0x00, 0x69, 0x90, 0x67, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x6E, 0x00, 0xF2, 0x00, 0x48, 0x00, 0x18,
+0x86, 0x36, 0x90, 0x67, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x6E, 0x92, 0x10, 0x06, 0x94, 0x30, 0x24,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x3C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x14, 0x4A,
+0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF3, 0x14, 0x4B, 0xC0, 0x9B, 0xB1, 0x67,
+0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4, 0x14, 0x6C,
+0xB1, 0x67, 0x57, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67, 0x57, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4, 0x18, 0x6C,
+0x10, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x18, 0x6C, 0x10, 0x6D, 0x2F, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3, 0x3C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x18, 0x4A,
+0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4, 0x10, 0x6C,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF3, 0x18, 0x4B, 0xC0, 0x9B, 0xB1, 0x67,
+0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4, 0x14, 0x6C,
+0xB1, 0x67, 0x75, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4, 0x18, 0x6C,
+0x20, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x18, 0x6C, 0x20, 0x6D, 0x00, 0x6E,
+0xA1, 0xF4, 0x1C, 0x69, 0x00, 0x18, 0x86, 0x36,
+0x91, 0x67, 0x3F, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0xF2, 0x00, 0x49, 0x00, 0x18,
+0x86, 0x36, 0x91, 0x67, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x91, 0x67, 0x01, 0xF4,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x20, 0xF0, 0x6C, 0xA0, 0x03, 0x73, 0x80, 0xF0,
+0x0D, 0x61, 0x90, 0x10, 0xFF, 0xF7, 0x1F, 0x68,
+0x14, 0xF0, 0x05, 0x69, 0xA1, 0xF4, 0x00, 0x6C,
+0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x00, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6A, 0x91, 0x10,
+0x0E, 0x21, 0x03, 0x71, 0x0C, 0x60, 0x05, 0x71,
+0x0A, 0x60, 0x08, 0x71, 0x08, 0x60, 0x0A, 0x71,
+0x06, 0x60, 0x0C, 0x71, 0x04, 0x60, 0x0D, 0x71,
+0x01, 0x6A, 0x80, 0xF0, 0x02, 0x61, 0x06, 0x94,
+0x25, 0x24, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF3,
+0x3C, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x00, 0x4A, 0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF3, 0x00, 0x4B, 0xC0, 0x9B,
+0xB1, 0x67, 0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7,
+0x00, 0x69, 0x00, 0x18, 0x86, 0x36, 0xA1, 0xF4,
+0x14, 0x6C, 0xB1, 0x67, 0x57, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67,
+0x57, 0x6E, 0x24, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF3, 0x3C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x04, 0x4A, 0xC0, 0x9A, 0xB1, 0x67,
+0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF3, 0x04, 0x4B,
+0xC0, 0x9B, 0xB1, 0x67, 0xA1, 0xF6, 0x10, 0x6C,
+0x1F, 0xF7, 0x00, 0x69, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF4, 0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0xA1, 0xF6, 0x14, 0x6C,
+0xB1, 0x67, 0x75, 0x6E, 0xA1, 0xF4, 0x1C, 0x69,
+0x00, 0x18, 0x86, 0x36, 0x91, 0x67, 0x3F, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x91, 0x67,
+0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0xF2,
+0x00, 0x49, 0x00, 0x18, 0x86, 0x36, 0x91, 0x67,
+0x3F, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x06, 0x94, 0x7F, 0xF7,
+0x0F, 0x2C, 0x11, 0x10, 0x20, 0xF0, 0x4B, 0xA0,
+0x03, 0x72, 0x05, 0x61, 0xFF, 0xF7, 0x1F, 0x68,
+0x14, 0xF5, 0x01, 0x69, 0x6F, 0x17, 0x6E, 0xEA,
+0x7F, 0xF7, 0x08, 0x2A, 0xFF, 0xF7, 0x1F, 0x68,
+0x14, 0xF5, 0x00, 0x69, 0x67, 0x17, 0xFF, 0xF7,
+0x1F, 0x68, 0xB4, 0xF5, 0x05, 0x69, 0x62, 0x17,
+0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x44, 0x67, 0xC0, 0xF7, 0x60, 0x9B, 0x84, 0x9C,
+0x8C, 0xEB, 0x08, 0x23, 0x20, 0xF0, 0xA5, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0x84, 0xF0, 0x00, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xA8, 0x9A, 0x64, 0x6C, 0x03, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0xBC, 0x9A, 0x4C, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x83, 0xF1, 0x10, 0x68,
+0x40, 0x6C, 0x04, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x01, 0xF4, 0x00, 0x69, 0x90, 0x67,
+0x3F, 0x6D, 0x30, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0xB1, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0xFD, 0xF7, 0x04, 0x48, 0x3F, 0x6D,
+0x90, 0x67, 0xC5, 0x67, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0xB1, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x12, 0x92, 0x25, 0x67,
+0x04, 0x67, 0x06, 0xD2, 0x06, 0x93, 0xFF, 0x6A,
+0x4C, 0xEE, 0x4C, 0xEB, 0x4C, 0xEF, 0x4C, 0xE9,
+0x08, 0xD6, 0x07, 0xD7, 0x06, 0xD3, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x9C,
+0x6C, 0xEA, 0x09, 0x22, 0x06, 0x92, 0x30, 0xF0,
+0x20, 0x6C, 0xA4, 0xF0, 0x04, 0x4C, 0xB1, 0x67,
+0x04, 0xD2, 0x00, 0x18, 0x4D, 0x63, 0x0C, 0x59,
+0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x98, 0x6C, 0xEA, 0x3E, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF0, 0x18, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x36, 0x10,
+0x08, 0x93, 0x01, 0x6D, 0xA4, 0xE9, 0x01, 0x73,
+0x00, 0x6E, 0x01, 0x60, 0x01, 0x6E, 0x83, 0xF1,
+0x10, 0x6C, 0x00, 0x18, 0x86, 0x36, 0x01, 0x68,
+0x07, 0x96, 0x04, 0xE9, 0xA1, 0xF4, 0x1C, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x86, 0x36, 0x07, 0x96,
+0xA1, 0xF6, 0x1C, 0x6C, 0xB0, 0x67, 0x00, 0x18,
+0x86, 0x36, 0x08, 0x59, 0x0C, 0x60, 0x28, 0x31,
+0x0F, 0x68, 0x06, 0x96, 0x04, 0xE9, 0xA1, 0xF4,
+0x10, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x10, 0x6C, 0x0B, 0x10, 0x28, 0x31,
+0x0F, 0x68, 0x06, 0x96, 0x04, 0xE9, 0xA1, 0xF4,
+0x14, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x86, 0x36,
+0xA1, 0xF6, 0x14, 0x6C, 0x06, 0x96, 0xB0, 0x67,
+0x00, 0x18, 0x86, 0x36, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x02, 0x5D, 0x0E, 0xD4, 0x05, 0x67, 0x14, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x9C, 0x6C, 0xEA, 0x03, 0x2A, 0xFF, 0x4A,
+0x09, 0xD2, 0x37, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xE4, 0xF0, 0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x01, 0x6B, 0x6B, 0xEB, 0x09, 0xD3, 0x2D, 0x10,
+0x05, 0xF0, 0x00, 0x6A, 0x06, 0xD2, 0x00, 0xF4,
+0x00, 0x4A, 0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x3C, 0x9A, 0x7D, 0x67, 0xA8, 0x32,
+0x49, 0xE3, 0x46, 0x9A, 0xFF, 0x6C, 0xCC, 0xEC,
+0x08, 0xD4, 0x88, 0x34, 0xEC, 0xE9, 0x51, 0xE4,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0xB1, 0x67,
+0x00, 0x18, 0x78, 0x36, 0x0E, 0x94, 0x09, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x9C, 0x6C, 0xEA, 0x0A, 0x22, 0x08, 0x96,
+0x09, 0x97, 0x30, 0xF0, 0x20, 0x6C, 0x24, 0xF1,
+0x14, 0x4C, 0xB0, 0x67, 0x04, 0xD1, 0x00, 0x18,
+0x4D, 0x63, 0x09, 0x92, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x02, 0x5D, 0x0E, 0xD4, 0x05, 0x67, 0x0E, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x9C, 0x6C, 0xEA, 0x64, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x64, 0xF1, 0x1C, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x5D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x5C, 0x9A, 0xFF, 0x69, 0x00, 0x6B,
+0x4C, 0xEF, 0x4A, 0xEF, 0xCC, 0xE9, 0x09, 0xD7,
+0x08, 0xD3, 0x1D, 0x60, 0x0E, 0x94, 0xD1, 0x67,
+0xE2, 0x67, 0x00, 0x18, 0xEE, 0x7B, 0x08, 0xD2,
+0x01, 0x4A, 0x0F, 0x2A, 0x0E, 0x94, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x9C,
+0x6C, 0xEA, 0x41, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0xA4, 0xF1, 0x18, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x3A, 0x10, 0x09, 0x94, 0x08, 0x95, 0x12, 0x96,
+0x00, 0x18, 0xCA, 0x79, 0x12, 0xD2, 0x81, 0xF4,
+0x10, 0x6A, 0x06, 0xD2, 0x00, 0xF2, 0x00, 0x4A,
+0x07, 0xD2, 0x08, 0x33, 0x5D, 0x67, 0x6D, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x12, 0x94, 0x41, 0xF1,
+0x5C, 0x9A, 0x01, 0x6D, 0xAB, 0xED, 0x8C, 0xEA,
+0x00, 0xF5, 0x20, 0x34, 0x8D, 0xEA, 0x8C, 0xAB,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0xC0, 0x9B,
+0x4C, 0xEE, 0x00, 0x18, 0x86, 0x36, 0x0E, 0x94,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x60, 0x9A,
+0x44, 0x9C, 0x4C, 0xEB, 0x01, 0x6A, 0x10, 0x23,
+0x08, 0x92, 0x09, 0x93, 0x12, 0x97, 0x30, 0xF0,
+0x20, 0x6C, 0xE4, 0xF1, 0x18, 0x4C, 0xB0, 0x67,
+0xD1, 0x67, 0x04, 0xD2, 0x05, 0xD3, 0x00, 0x18,
+0x4D, 0x63, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xAC, 0xEA,
+0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x9C, 0x04, 0x67, 0x6C, 0xEA,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0x44, 0xF2,
+0x10, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x20, 0xF0,
+0x4E, 0xA0, 0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x98, 0x6C, 0xEA,
+0xE0, 0xF0, 0x19, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x84, 0xF2, 0x0C, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0xF2, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xFC, 0x9A, 0x90, 0x67, 0x00, 0x6D, 0x18, 0x6E,
+0x00, 0x18, 0xEE, 0x7B, 0x07, 0x93, 0x06, 0xD2,
+0x0F, 0x5B, 0x31, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xA0, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x40, 0xF4,
+0x14, 0x6C, 0x80, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0xA8, 0x9A, 0x81, 0xF2, 0x00, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x01, 0xF0, 0x14, 0x6C,
+0x1F, 0xF4, 0x00, 0x6D, 0x0F, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x24, 0x9A, 0x20, 0xF0, 0x45, 0xA0, 0x06, 0x94,
+0xFF, 0x6B, 0xFE, 0x4A, 0x6C, 0xEA, 0x02, 0x5A,
+0x8C, 0xE9, 0x50, 0x61, 0x20, 0xF0, 0x45, 0xA0,
+0x05, 0x72, 0x6A, 0x61, 0x4B, 0x10, 0x07, 0x92,
+0x24, 0x5A, 0x5A, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0xA8, 0x9A, 0x81, 0xF2, 0x00, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x40, 0xF4,
+0x14, 0x6C, 0x80, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xA0, 0x9A, 0x01, 0xF0, 0x08, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x01, 0xF0, 0x14, 0x6C,
+0x1F, 0xF4, 0x00, 0x6D, 0x22, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x24, 0x9A, 0x06, 0x93, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x50, 0x9A, 0x6C, 0xE9, 0xA3, 0xF1,
+0x08, 0x6C, 0x4D, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0xA4, 0x9A, 0x00, 0x18, 0x78, 0x36,
+0x01, 0x72, 0x14, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0xD4, 0x9A, 0x01, 0x6D, 0xC1, 0xF0,
+0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0xAC, 0x9A,
+0xC1, 0xF0, 0x18, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0xC8, 0x9A, 0x01, 0x6D, 0xC1, 0xF0,
+0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x18, 0x6C,
+0x61, 0xF3, 0xAC, 0x9A, 0x01, 0x6E, 0xEB, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x4E, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xC4, 0xF2, 0x0C, 0x4C, 0x36, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0xFC, 0x9A,
+0x90, 0x67, 0x00, 0x6D, 0x18, 0x6E, 0x04, 0xD1,
+0x00, 0x18, 0x16, 0x7C, 0x06, 0x94, 0x00, 0x6B,
+0x01, 0x4C, 0x01, 0x24, 0x01, 0x6B, 0xFF, 0x6C,
+0x4C, 0xEC, 0x5A, 0xA0, 0x6C, 0xEC, 0x06, 0xD4,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xFC, 0x9A, 0x90, 0x67, 0x01, 0x6D, 0x18, 0x6E,
+0x04, 0xD1, 0x00, 0x18, 0x16, 0x7C, 0x06, 0x93,
+0xFF, 0x6C, 0x4C, 0xEB, 0x8C, 0xEB, 0x06, 0xD3,
+0x07, 0x95, 0x90, 0x67, 0x00, 0x18, 0x69, 0x7A,
+0x20, 0x22, 0x06, 0x92, 0x0F, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x17, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x04, 0xF3, 0x0C, 0x4C, 0x07, 0x95, 0x00, 0x18,
+0x4D, 0x63, 0x0F, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x98, 0x6C, 0xEA,
+0x0A, 0x22, 0x07, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0x64, 0xF3, 0x14, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x02, 0x10, 0x00, 0x6A, 0x01, 0x10, 0x01, 0x6A,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0xB8, 0x9A,
+0x83, 0xF1, 0x08, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0xAC, 0x9A, 0x81, 0xF7, 0x04, 0x6C, 0x00, 0x18,
+0x78, 0x36, 0x30, 0xF0, 0x20, 0x6B, 0x66, 0xF2,
+0x70, 0x9B, 0x03, 0x2B, 0x50, 0x32, 0xEA, 0x6B,
+0x09, 0x10, 0x01, 0x73, 0x03, 0x61, 0x4C, 0x32,
+0x6C, 0x6B, 0x04, 0x10, 0x02, 0x73, 0x06, 0x61,
+0x48, 0x32, 0x34, 0x6B, 0x7A, 0xEA, 0x01, 0x2B,
+0xE5, 0xE8, 0x12, 0xEA, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x41, 0xF4, 0x10, 0x68,
+0x90, 0x67, 0x7F, 0x6D, 0x00, 0x18, 0x78, 0x36,
+0x22, 0x67, 0xFE, 0x4A, 0xC2, 0x67, 0x90, 0x67,
+0x7F, 0x6D, 0x04, 0xD2, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0xD1, 0x67, 0x7F, 0x6D, 0x00, 0x18,
+0x86, 0x36, 0x04, 0x96, 0x00, 0xF2, 0x00, 0x48,
+0x90, 0x67, 0x7F, 0x6D, 0x00, 0x18, 0x86, 0x36,
+0x90, 0x67, 0xD1, 0x67, 0x7F, 0x6D, 0x00, 0x18,
+0x86, 0x36, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xEC, 0x63, 0x27, 0x62,
+0x26, 0xD1, 0x25, 0xD0, 0x30, 0xF0, 0x20, 0x6E,
+0x24, 0x67, 0x12, 0x05, 0xA0, 0xF1, 0x10, 0x4E,
+0x30, 0x6F, 0x00, 0x18, 0x8B, 0x57, 0x20, 0xF0,
+0x45, 0xA1, 0x03, 0x72, 0x02, 0x60, 0x05, 0x72,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6E, 0x91, 0x67,
+0x06, 0x05, 0xE0, 0xF1, 0x00, 0x4E, 0x30, 0x6F,
+0x00, 0x18, 0x8B, 0x57, 0x01, 0x6A, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6E, 0x91, 0x67, 0x06, 0x05,
+0x80, 0xF1, 0x00, 0x4E, 0x30, 0x6F, 0x00, 0x18,
+0x8B, 0x57, 0x00, 0x6A, 0x22, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x0A, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x30, 0xF0, 0x20, 0x6D, 0xA4, 0xF3, 0x18, 0x4C,
+0x60, 0xF5, 0x10, 0x4D, 0x00, 0x18, 0x4D, 0x63,
+0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2, 0x54, 0xA2,
+0x0F, 0x5A, 0x0A, 0x60, 0x20, 0xF0, 0x0C, 0xA1,
+0xFF, 0x6A, 0xFF, 0x48, 0x4C, 0xE8, 0x02, 0x58,
+0x18, 0x67, 0x01, 0x6A, 0x4E, 0xE8, 0x09, 0x10,
+0x20, 0xF0, 0x0C, 0xA1, 0xFF, 0x6A, 0xFF, 0x48,
+0x4C, 0xE8, 0x02, 0x58, 0x18, 0x67, 0x03, 0x6A,
+0x03, 0xE2, 0x20, 0xF0, 0x45, 0xA1, 0x01, 0x72,
+0x12, 0x60, 0x04, 0x72, 0x10, 0x60, 0x06, 0x72,
+0x0E, 0x60, 0x07, 0x72, 0x0C, 0x60, 0x0B, 0x72,
+0x0A, 0x60, 0x02, 0x72, 0x02, 0x60, 0x09, 0x72,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2,
+0x54, 0xA2, 0x0F, 0x5A, 0x13, 0x61, 0x06, 0x02,
+0x08, 0x33, 0x6D, 0xE2, 0xCC, 0x9B, 0x64, 0x40,
+0x68, 0x33, 0x6D, 0xE2, 0x6C, 0x9B, 0x1E, 0xD3,
+0x67, 0x40, 0x01, 0x4B, 0x68, 0x33, 0x69, 0xE2,
+0x4C, 0x9A, 0x21, 0xD2, 0x00, 0x6A, 0x1F, 0xD2,
+0x01, 0x6A, 0x12, 0x10, 0x06, 0x02, 0x08, 0x33,
+0x6D, 0xE2, 0xC0, 0x9B, 0x64, 0x40, 0x68, 0x33,
+0x6D, 0xE2, 0x60, 0x9B, 0x1E, 0xD3, 0x67, 0x40,
+0x01, 0x4B, 0x68, 0x33, 0x69, 0xE2, 0x40, 0x9A,
+0x21, 0xD2, 0x01, 0x6A, 0x1F, 0xD2, 0x00, 0x6A,
+0x01, 0x6D, 0x21, 0xF0, 0x0C, 0x6C, 0xAB, 0xED,
+0x20, 0xD2, 0x00, 0x18, 0x86, 0x36, 0x1F, 0x92,
+0x21, 0x22, 0x20, 0xF0, 0x44, 0xA1, 0x01, 0x72,
+0x04, 0x61, 0x01, 0x70, 0x06, 0x60, 0x03, 0x70,
+0x04, 0x60, 0x22, 0x92, 0x08, 0x2A, 0x03, 0x70,
+0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2,
+0x50, 0x9A, 0x01, 0x72, 0x06, 0x60, 0x20, 0xF0,
+0x45, 0xA1, 0x05, 0x72, 0x0B, 0x61, 0x03, 0x70,
+0x09, 0x61, 0x01, 0x6D, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x10, 0x6C, 0xAB, 0xED, 0x61, 0xF3,
+0xDC, 0x9A, 0x05, 0x10, 0x1E, 0x96, 0x01, 0x6D,
+0x21, 0xF0, 0x10, 0x6C, 0xAB, 0xED, 0x00, 0x18,
+0x86, 0x36, 0x21, 0x96, 0x01, 0x6D, 0x21, 0xF0,
+0x18, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x20, 0x92, 0x0E, 0x22, 0x20, 0xF0, 0x44, 0xA1,
+0x01, 0x72, 0x0A, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF3, 0xC0, 0x9A, 0x01, 0x6D, 0x21, 0xF0,
+0x1C, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2, 0x94, 0xA2,
+0x00, 0x18, 0xD9, 0x79, 0x0C, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x66, 0xF2, 0x50, 0x9A, 0x02, 0x72,
+0x06, 0x61, 0x21, 0xF0, 0x18, 0x6C, 0x01, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x12, 0x22, 0x20, 0xF0, 0xC6, 0xA1,
+0x20, 0xF0, 0xE7, 0xA1, 0x20, 0xF0, 0x45, 0xA1,
+0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0, 0x20, 0x6D,
+0xC4, 0xF3, 0x1C, 0x4C, 0x60, 0xF5, 0x10, 0x4D,
+0x04, 0xD2, 0x05, 0xD0, 0x00, 0x18, 0x4D, 0x63,
+0x27, 0x97, 0x26, 0x91, 0x25, 0x90, 0x14, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xEC, 0xEA,
+0x06, 0xD2, 0x0D, 0xD5, 0x0E, 0xD6, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x9C,
+0x04, 0x67, 0x6C, 0xEA, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x04, 0xF4, 0x04, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0x20, 0xF0, 0x4E, 0xA0, 0x0F, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x80, 0xF2, 0x0B, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x24, 0xF4, 0x1C, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x84, 0x12, 0x0D, 0x93,
+0x04, 0x6A, 0x4B, 0xEA, 0x4C, 0xEB, 0x0E, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x60, 0xF2, 0x19, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x64, 0xF4, 0x18, 0x4C,
+0x0D, 0x95, 0x10, 0x10, 0x0E, 0x93, 0x6C, 0xEA,
+0x10, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x98, 0x6C, 0xEA, 0x60, 0xF2,
+0x08, 0x22, 0x0E, 0x95, 0x30, 0xF0, 0x20, 0x6C,
+0xA4, 0xF4, 0x14, 0x4C, 0x00, 0x18, 0x4D, 0x63,
+0x60, 0x12, 0x0D, 0x93, 0x0E, 0x92, 0x6D, 0xEA,
+0x01, 0x6B, 0x6C, 0xEA, 0x07, 0x22, 0x01, 0xF4,
+0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D, 0x26, 0xF2,
+0x11, 0x6E, 0x06, 0x10, 0x01, 0xF4, 0x08, 0x6C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x02, 0xF1, 0x11, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x0D, 0x93, 0x0E, 0x92,
+0x6D, 0xEA, 0x02, 0x6B, 0x6C, 0xEA, 0x07, 0x22,
+0x01, 0xF6, 0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x26, 0xF2, 0x11, 0x6E, 0x06, 0x10, 0x01, 0xF6,
+0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D, 0x02, 0xF1,
+0x11, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0xA4, 0x9A, 0x21, 0xF1,
+0x1C, 0x69, 0x91, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xA8, 0x9A, 0x01, 0xF0, 0x0C, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xAC, 0x9A, 0x01, 0xF0, 0x0C, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x0D, 0x93,
+0x01, 0x6A, 0x6C, 0xEA, 0x10, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0xB0, 0x9A, 0x91, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x04, 0x6C, 0x41, 0xF2,
+0xB4, 0x9A, 0x08, 0x6E, 0x13, 0x10, 0x0D, 0x93,
+0x02, 0x6A, 0x6C, 0xEA, 0x11, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF3, 0xB0, 0x9A, 0x91, 0x67,
+0x02, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF2, 0xB4, 0x9A, 0x01, 0xF2,
+0x04, 0x6C, 0x04, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x0D, 0x92, 0xFF, 0x4A, 0x02, 0x5A, 0x06, 0x60,
+0x41, 0xF1, 0x00, 0x6C, 0xFF, 0xF7, 0x10, 0x6D,
+0x01, 0x6E, 0x05, 0x10, 0x41, 0xF1, 0x00, 0x6C,
+0xFF, 0xF7, 0x10, 0x6D, 0x43, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x0D, 0x92, 0x01, 0xF0, 0x0C, 0x6C,
+0xFF, 0x6D, 0x50, 0x36, 0x4D, 0xEE, 0x00, 0x18,
+0x86, 0x36, 0x0D, 0x92, 0xFF, 0x4A, 0x02, 0x5A,
+0x17, 0x61, 0x06, 0x93, 0x03, 0x2B, 0x50, 0x98,
+0x40, 0xA2, 0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0xB0, 0x9A, 0x21, 0xF1, 0x1C, 0x6C,
+0x43, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF2, 0xB4, 0x9A, 0x01, 0xF2,
+0x04, 0x6C, 0x0C, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0xB8, 0x9A,
+0x21, 0xF2, 0x0C, 0x69, 0x91, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0xA8, 0x9A, 0x91, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x0E, 0x93, 0x01, 0x6A,
+0x6C, 0xEA, 0x08, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x04, 0x6C, 0xC1, 0xF1, 0xAC, 0x9A,
+0x00, 0x6E, 0x0B, 0x10, 0x0E, 0x93, 0x02, 0x6A,
+0x6C, 0xEA, 0x09, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF1, 0xAC, 0x9A, 0x01, 0xF2, 0x04, 0x6C,
+0x05, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x0E, 0x92,
+0x01, 0xF0, 0x08, 0x6C, 0xFF, 0x6D, 0x50, 0x36,
+0x4D, 0xEE, 0x00, 0x18, 0x86, 0x36, 0x0E, 0x92,
+0xFF, 0x4A, 0x02, 0x5A, 0x1A, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0xA8, 0x9A, 0x03, 0xF1,
+0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xA0, 0x9A,
+0x01, 0xF0, 0x00, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x10, 0x6C, 0x81, 0xF3, 0xA8, 0x9A, 0x00, 0x6E,
+0x19, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0xA8, 0x9A, 0x03, 0xF1, 0x04, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0xA0, 0x9A, 0x01, 0xF0, 0x00, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0xA8, 0x9A, 0x41, 0xF0,
+0x10, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x0D, 0x93, 0x03, 0x6A, 0x00, 0x69, 0x4C, 0xEB,
+0x20, 0xF0, 0x6B, 0xC0, 0x0E, 0x93, 0x6C, 0xEA,
+0x20, 0xF0, 0x4C, 0xC0, 0x01, 0x6A, 0x06, 0xD2,
+0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x1C, 0x4A, 0x21, 0xF0, 0x0C, 0x4B,
+0x60, 0x9B, 0xE0, 0x9A, 0x90, 0x67, 0x00, 0x6D,
+0xEF, 0x6E, 0x04, 0xD3, 0x00, 0x18, 0x16, 0x7C,
+0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x1C, 0x4A, 0xE0, 0x9A, 0x01, 0x6B, 0x00, 0x6D,
+0x33, 0x6E, 0x90, 0x67, 0x04, 0xD3, 0x00, 0x18,
+0x16, 0x7C, 0x07, 0x93, 0x02, 0x6C, 0x6C, 0xEA,
+0x06, 0x93, 0x4C, 0xEB, 0x06, 0xD3, 0x00, 0x18,
+0x95, 0x20, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x1C, 0x4A, 0xE0, 0x9A, 0x90, 0x67, 0x00, 0x6D,
+0x33, 0x6E, 0x00, 0x18, 0xEE, 0x7B, 0x01, 0x72,
+0x15, 0x60, 0x01, 0x49, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE9, 0x64, 0x71, 0xC9, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x00, 0xF1, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xE4, 0xF4, 0x10, 0x4C, 0x00, 0x18,
+0x4D, 0x63, 0xFF, 0x10, 0x50, 0x98, 0x40, 0xA2,
+0x07, 0x2A, 0x4F, 0x98, 0x40, 0xA2, 0x04, 0x2A,
+0x20, 0xF0, 0x70, 0xA0, 0x07, 0xD3, 0x5B, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x4C, 0x9A,
+0x90, 0x67, 0x00, 0x6D, 0x04, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x4A, 0xE0, 0x9A,
+0xEF, 0x6E, 0x00, 0x18, 0x16, 0x7C, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF1, 0x1C, 0x4B, 0xE0, 0x9B,
+0x22, 0x67, 0x90, 0x67, 0x01, 0x6A, 0x00, 0x6D,
+0x33, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0x16, 0x7C,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1, 0x1C, 0x4B,
+0x4C, 0xE9, 0x06, 0x92, 0xE0, 0x9B, 0x90, 0x67,
+0x4C, 0xE9, 0x00, 0x6D, 0x34, 0x6A, 0x3E, 0x6E,
+0x04, 0xD2, 0x00, 0x18, 0x16, 0x7C, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x41, 0xF1,
+0x1C, 0x4B, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0x9B, 0x81, 0xF3, 0x4C, 0x9A, 0x90, 0x67,
+0x00, 0x6D, 0x3F, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0x16, 0x7C, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1,
+0x1C, 0x4B, 0x4C, 0xE9, 0xE0, 0x9B, 0xFF, 0x6A,
+0x4C, 0xE9, 0x00, 0x6A, 0x90, 0x67, 0xA2, 0x67,
+0xEF, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0x16, 0x7C,
+0x4C, 0xE9, 0xFF, 0x6A, 0x4C, 0xE9, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x64, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x44, 0xF5, 0x14, 0x4C, 0x5D, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x1C, 0x4A, 0x21, 0xF0, 0x0C, 0x4B, 0x60, 0x9B,
+0xE0, 0x9A, 0x90, 0x67, 0x00, 0x6D, 0xEF, 0x6E,
+0x04, 0xD3, 0x00, 0x18, 0x16, 0x7C, 0x22, 0x67,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x1C, 0x4A,
+0xE0, 0x9A, 0x01, 0x6B, 0x90, 0x67, 0x00, 0x6D,
+0x33, 0x6E, 0x04, 0xD3, 0x00, 0x18, 0x16, 0x7C,
+0x06, 0x93, 0x4C, 0xE9, 0xFF, 0x6A, 0x6C, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1, 0x1C, 0x4B,
+0xE0, 0x9B, 0x4C, 0xE9, 0x90, 0x67, 0x34, 0x6A,
+0x00, 0x6D, 0x3E, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0x16, 0x7C, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x41, 0xF1, 0x1C, 0x4B, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0x9B, 0x81, 0xF3,
+0x50, 0x9A, 0x90, 0x67, 0x00, 0x6D, 0x3F, 0x6E,
+0x04, 0xD2, 0x00, 0x18, 0x16, 0x7C, 0x4C, 0xE9,
+0xFF, 0x6A, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x1C, 0x4A, 0x07, 0x93, 0xE0, 0x9A,
+0x90, 0x67, 0x00, 0x6D, 0xEF, 0x6E, 0x04, 0xD3,
+0x00, 0x18, 0x16, 0x7C, 0x4C, 0xE9, 0xFF, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x6C, 0xE9, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x98, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0xA4, 0xF5, 0x0C, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x00, 0x6A, 0x04, 0xD2,
+0xA2, 0x67, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xFC, 0x9A, 0x90, 0x67, 0xEF, 0x6E, 0x00, 0x18,
+0x16, 0x7C, 0x2C, 0xEA, 0x10, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x98,
+0x6C, 0xEA, 0x27, 0x22, 0x0D, 0x95, 0x0E, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0xE4, 0xF5, 0x1C, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x1E, 0x10, 0x90, 0x67,
+0x00, 0x18, 0xF9, 0x7C, 0x90, 0x67, 0x00, 0x18,
+0x0D, 0x7D, 0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2,
+0xB4, 0xA2, 0x90, 0x67, 0x00, 0x18, 0x69, 0x7A,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x98, 0x6C, 0xEA, 0x08, 0x22, 0x0D, 0x95,
+0x0E, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x64, 0xF6,
+0x14, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x6A, 0xAC, 0xEA, 0x07, 0xD2, 0x0E, 0xD6,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x9C, 0x24, 0x67, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF6, 0x0C, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x20, 0xF0, 0x4E, 0xA1,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0xC0, 0xF1,
+0x15, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0x04, 0xF7,
+0x08, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0xCE, 0x11,
+0x0E, 0x93, 0x07, 0x5B, 0x0B, 0x60, 0x01, 0x73,
+0x03, 0x61, 0x07, 0x94, 0x03, 0x5C, 0x05, 0x10,
+0x0E, 0x92, 0x02, 0x72, 0x10, 0x61, 0x07, 0x93,
+0x05, 0x5B, 0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA,
+0xA0, 0xF1, 0x1A, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0x44, 0xF7, 0x0C, 0x4C, 0x86, 0x11, 0x0E, 0x94,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0x6D, 0x66, 0xF2,
+0x90, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xFC, 0x9A, 0x91, 0x67, 0x18, 0x6E, 0x00, 0x18,
+0xEE, 0x7B, 0x06, 0xD2, 0x0E, 0x92, 0x07, 0x5A,
+0x20, 0xF1, 0x11, 0x60, 0x48, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF4, 0x18, 0x4A, 0x69, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0xA1, 0xF0, 0x0C, 0x68,
+0x90, 0x67, 0xFF, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x90, 0x67, 0x00, 0xF3, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0xA8, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0xA0, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xA0, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0x04, 0x6C, 0xC0, 0xF7,
+0xAC, 0x9A, 0xF5, 0x10, 0x07, 0x94, 0x0F, 0x6E,
+0x01, 0x6A, 0x8C, 0xEE, 0xC8, 0x36, 0x4D, 0xEE,
+0xA1, 0xF0, 0x0C, 0x6C, 0xFF, 0x6D, 0x00, 0x18,
+0x86, 0x36, 0x07, 0x92, 0x01, 0x72, 0x05, 0x61,
+0x01, 0xF2, 0x00, 0x6C, 0x10, 0x6D, 0x01, 0x6E,
+0x04, 0x10, 0x01, 0xF2, 0x00, 0x6C, 0x10, 0x6D,
+0x00, 0x6E, 0xA1, 0xF0, 0x0C, 0x68, 0x00, 0x18,
+0x86, 0x36, 0x90, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0xA4, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF2, 0xB4, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xA4, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0xAC, 0x9A, 0xC1, 0xF0,
+0x04, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x06, 0x93, 0x5D, 0xF3, 0x13, 0x48, 0x01, 0xF0,
+0x00, 0x6A, 0x6C, 0xE8, 0x3B, 0x10, 0x07, 0x94,
+0x0F, 0x6A, 0xA1, 0xF0, 0x0C, 0x68, 0x8C, 0xEA,
+0x48, 0x32, 0x02, 0x6E, 0x4D, 0xEE, 0x90, 0x67,
+0xFF, 0x6D, 0x00, 0x18, 0x86, 0x36, 0x90, 0x67,
+0x06, 0xF0, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0xA8, 0x9A, 0x90, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0xA4, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x0C, 0x4A, 0xA0, 0x9A, 0x90, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x0C, 0x4B, 0xA0, 0x9B, 0xC1, 0xF0,
+0x04, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x06, 0x94, 0x5D, 0xF3, 0x13, 0x48, 0x00, 0xF4,
+0x00, 0x6A, 0x8C, 0xE8, 0x4D, 0xE8, 0x88, 0x10,
+0xA1, 0xF0, 0x0C, 0x68, 0x90, 0x67, 0xFF, 0x6D,
+0x40, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x90, 0x67,
+0x00, 0xF3, 0x00, 0x6D, 0x02, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0xA8, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0xA0, 0x9A, 0x90, 0x67, 0x02, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xA0, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0xAC, 0x9A, 0xC1, 0xF0, 0x04, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0xA4, 0x9A, 0xC1, 0xF0, 0x08, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x40, 0xF3,
+0x14, 0x48, 0x06, 0x92, 0xC3, 0x17, 0xA1, 0xF0,
+0x0C, 0x68, 0x90, 0x67, 0xFF, 0x6D, 0x80, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x03, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0xA8, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0xA0, 0x9A,
+0x90, 0x67, 0x03, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xA0, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0xAC, 0x9A,
+0xC1, 0xF0, 0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0xA4, 0x9A, 0xC1, 0xF0, 0x08, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x06, 0x93, 0x40, 0xF3,
+0x14, 0x48, 0x6D, 0xE8, 0x11, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99,
+0x06, 0x90, 0x6C, 0xEA, 0x09, 0x22, 0x0E, 0x95,
+0x07, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x44, 0xF7,
+0x0C, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0x06, 0x90,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0xFC, 0x9A,
+0x91, 0x67, 0x00, 0x6D, 0x18, 0x6E, 0x04, 0xD0,
+0x00, 0x18, 0x16, 0x7C, 0x06, 0x94, 0x00, 0x6B,
+0x01, 0x4C, 0x01, 0x24, 0x01, 0x6B, 0xFF, 0x6C,
+0x4C, 0xEC, 0x6C, 0xEC, 0x06, 0xD4, 0x5A, 0xA1,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xFC, 0x9A, 0x91, 0x67, 0x01, 0x6D, 0x18, 0x6E,
+0x04, 0xD0, 0x00, 0x18, 0x16, 0x7C, 0x06, 0x93,
+0xFF, 0x6C, 0x4C, 0xEB, 0x8C, 0xEB, 0x06, 0xD3,
+0x06, 0x92, 0x10, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA,
+0x33, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0xA4, 0xF7,
+0x08, 0x4C, 0x0E, 0x95, 0x07, 0x96, 0x00, 0x18,
+0x4D, 0x63, 0x2A, 0x10, 0x0E, 0x95, 0x91, 0x67,
+0x01, 0xF0, 0x08, 0x68, 0x00, 0x18, 0xE2, 0x79,
+0x91, 0x67, 0x00, 0x18, 0xF9, 0x7C, 0x91, 0x67,
+0x00, 0x18, 0x0D, 0x7D, 0x90, 0x67, 0xFF, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x20, 0xF0,
+0x4C, 0xA1, 0x90, 0x67, 0xFF, 0x6D, 0x50, 0x36,
+0x4D, 0xEE, 0x00, 0x18, 0x86, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x08, 0x22, 0x0E, 0x95, 0x07, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0x25, 0xF0, 0x08, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x01, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xF3, 0x63, 0x19, 0x62,
+0x18, 0xD1, 0x17, 0xD0, 0xFF, 0x68, 0xAC, 0xE8,
+0x30, 0xF0, 0x20, 0x6D, 0x24, 0x67, 0x60, 0xF5,
+0x00, 0x4D, 0x06, 0x04, 0x0F, 0x6E, 0x00, 0x18,
+0x39, 0x20, 0x30, 0xF0, 0x20, 0x6D, 0x0E, 0x04,
+0x40, 0xF5, 0x08, 0x4D, 0x17, 0x6E, 0x00, 0x18,
+0x39, 0x20, 0x30, 0xF0, 0x20, 0x6D, 0x0A, 0x04,
+0x20, 0xF5, 0x18, 0x4D, 0x0F, 0x6E, 0x00, 0x18,
+0x39, 0x20, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0x06, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0x85, 0xF0, 0x08, 0x4C,
+0x00, 0x18, 0x4D, 0x63, 0x20, 0xF0, 0x4E, 0xA1,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0xC0, 0xF1,
+0x1E, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0xC5, 0xF0,
+0x04, 0x4C, 0x00, 0x18, 0x4D, 0x63, 0xD7, 0x11,
+0x30, 0xF0, 0x20, 0x6A, 0x66, 0xF2, 0x14, 0xC2,
+0x66, 0xF2, 0xB4, 0xA2, 0x02, 0x6B, 0x0F, 0x5D,
+0x58, 0x67, 0x4B, 0xE3, 0x20, 0xF0, 0x72, 0xA1,
+0x4A, 0xEB, 0x03, 0x60, 0x91, 0x67, 0x00, 0x18,
+0x69, 0x7A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0xFC, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0x18, 0x6E,
+0x00, 0x18, 0xEE, 0x7B, 0x14, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0x54, 0x9A, 0x14, 0x93,
+0x0F, 0x58, 0x6C, 0xEA, 0x36, 0x60, 0x0D, 0xEA,
+0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D, 0x00, 0x6E,
+0x15, 0xD2, 0x00, 0x18, 0x86, 0x36, 0x00, 0x6A,
+0x40, 0xF0, 0x48, 0xC1, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF3, 0xB8, 0x9A, 0x61, 0xF0, 0x00, 0x6C,
+0x61, 0xF1, 0x0A, 0x6E, 0x00, 0x18, 0x86, 0x36,
+0x0E, 0x70, 0x0E, 0x61, 0x01, 0x6D, 0x21, 0xF2,
+0x04, 0x6C, 0xAB, 0xED, 0x6C, 0xF5, 0x17, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x21, 0xF2, 0x08, 0x6C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x00, 0x6E, 0x58, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0xDC, 0x9A,
+0x01, 0x6D, 0x21, 0xF2, 0x04, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x86, 0x36, 0x21, 0xF2, 0x08, 0x6C,
+0xFF, 0xF7, 0x1F, 0x6D, 0x22, 0xF5, 0x05, 0x6E,
+0x47, 0x10, 0x24, 0x58, 0x80, 0xF0, 0x02, 0x61,
+0x0D, 0xEA, 0x68, 0x40, 0x15, 0xD2, 0xE4, 0x4B,
+0xFF, 0x6A, 0x4C, 0xEB, 0x1D, 0x5B, 0x08, 0x60,
+0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x01, 0x6A, 0x16, 0x10,
+0x68, 0x40, 0xA4, 0x4B, 0x4C, 0xEB, 0x2D, 0x5B,
+0x08, 0x60, 0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D,
+0x02, 0x6E, 0x00, 0x18, 0x86, 0x36, 0x02, 0x6A,
+0x09, 0x10, 0x95, 0x58, 0x10, 0x61, 0x41, 0xF1,
+0x18, 0x6C, 0x1F, 0x6D, 0x03, 0x6E, 0x00, 0x18,
+0x86, 0x36, 0x03, 0x6A, 0x68, 0x40, 0x40, 0xF0,
+0x48, 0xC1, 0xE4, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB,
+0x0D, 0x5B, 0x1D, 0x60, 0x0D, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x40, 0xF1, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x05, 0xF1, 0x08, 0x4C, 0x13, 0x11,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0xB8, 0x9A,
+0x61, 0xF0, 0x00, 0x6C, 0x80, 0xF4, 0x14, 0x6E,
+0x00, 0x18, 0x86, 0x36, 0x50, 0x99, 0x40, 0xA2,
+0x01, 0x72, 0x56, 0x61, 0x44, 0x10, 0x68, 0x40,
+0xD4, 0x4B, 0x4C, 0xEB, 0x0D, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0x81, 0xF3, 0xB8, 0x9A, 0x40, 0xF4, 0x13, 0x6E,
+0xEB, 0x17, 0x68, 0x40, 0xA4, 0x4B, 0x4C, 0xEB,
+0x11, 0x5B, 0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x00, 0x6C, 0x81, 0xF3, 0xB8, 0x9A,
+0x40, 0xF4, 0x12, 0x6E, 0xDD, 0x17, 0x68, 0x40,
+0x92, 0x4B, 0x4C, 0xEB, 0x3C, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0x81, 0xF3, 0xB8, 0x9A, 0x00, 0xF4, 0x12, 0x6E,
+0xCF, 0x17, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0x00, 0xF1,
+0x00, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0x45, 0xF1,
+0x14, 0x4C, 0xCD, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA,
+0xE0, 0xF0, 0x13, 0x22, 0x30, 0xF0, 0x20, 0x6C,
+0xA5, 0xF1, 0x04, 0x4C, 0xC0, 0x10, 0x20, 0xF0,
+0x45, 0xA1, 0x03, 0x72, 0x02, 0x60, 0x05, 0x72,
+0x0B, 0x61, 0x0E, 0x70, 0x05, 0x61, 0x91, 0x67,
+0x26, 0x6D, 0x00, 0x18, 0x80, 0x57, 0xE7, 0x10,
+0x91, 0x67, 0x20, 0x6D, 0x00, 0x18, 0x80, 0x57,
+0x0F, 0x58, 0xE0, 0xF0, 0x00, 0x61, 0x68, 0x40,
+0xE4, 0x4B, 0xFF, 0x6A, 0x83, 0x67, 0x4C, 0xEC,
+0x1D, 0x5C, 0x05, 0x60, 0x67, 0x33, 0x9D, 0x67,
+0x6D, 0xE4, 0x58, 0xA3, 0x18, 0x10, 0x68, 0x40,
+0xA4, 0x4B, 0x83, 0x67, 0x4C, 0xEC, 0x2D, 0x5C,
+0x06, 0x60, 0x5D, 0x67, 0x67, 0x33, 0x6D, 0xE2,
+0x20, 0xF0, 0x58, 0xA3, 0x0C, 0x10, 0x67, 0x40,
+0x64, 0x4B, 0x4C, 0xEB, 0x1D, 0x5B, 0x1F, 0x60,
+0x6F, 0xF7, 0x4B, 0x40, 0x47, 0x32, 0x7D, 0x67,
+0x49, 0xE3, 0x20, 0xF0, 0x48, 0xA2, 0xFF, 0x72,
+0x16, 0x60, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF3, 0xE0, 0x9A, 0x91, 0x67, 0x00, 0x6D,
+0xBE, 0x6E, 0x00, 0x18, 0x16, 0x7C, 0x14, 0x94,
+0x00, 0x6B, 0x01, 0x4C, 0x01, 0x24, 0x01, 0x6B,
+0xFF, 0x6C, 0x4C, 0xEC, 0x6C, 0xEC, 0x90, 0x70,
+0x14, 0xD4, 0x1F, 0x61, 0x0D, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A, 0x64, 0x99,
+0x6C, 0xEA, 0x80, 0xF0, 0x16, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xE5, 0xF1, 0x0C, 0x4C, 0x63, 0x10,
+0x01, 0x6A, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0xE8, 0x9A, 0x91, 0x67, 0x00, 0x6D,
+0xDF, 0x6E, 0x00, 0x18, 0x16, 0x7C, 0x14, 0x93,
+0xFF, 0x6C, 0x4C, 0xEB, 0x8C, 0xEB, 0x14, 0xD3,
+0x1C, 0x10, 0x00, 0x6A, 0x04, 0xD2, 0xA2, 0x67,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x08, 0x4A,
+0xE0, 0x9A, 0x91, 0x67, 0xDF, 0x6E, 0x00, 0x18,
+0x16, 0x7C, 0x14, 0x93, 0xFF, 0x6C, 0x91, 0x58,
+0x4C, 0xEB, 0x8C, 0xEB, 0x14, 0xD3, 0x07, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x08, 0x4A,
+0x15, 0x93, 0x40, 0x9A, 0x07, 0x10, 0x50, 0x58,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x44, 0x9A, 0x15, 0x93, 0x4D, 0xEB, 0x15, 0xD3,
+0x30, 0xF0, 0x20, 0x6A, 0x15, 0x94, 0x41, 0xF1,
+0x1C, 0x4A, 0xE0, 0x9A, 0x04, 0xD4, 0x00, 0x6D,
+0x91, 0x67, 0x18, 0x6E, 0x00, 0x18, 0x16, 0x7C,
+0x14, 0x93, 0x4C, 0xEB, 0x14, 0xD3, 0x5A, 0xA1,
+0x11, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x15, 0x94,
+0x41, 0xF1, 0x1C, 0x4A, 0xE0, 0x9A, 0x04, 0xD4,
+0x01, 0x6D, 0x91, 0x67, 0x18, 0x6E, 0x00, 0x18,
+0x16, 0x7C, 0x14, 0x93, 0x4C, 0xEB, 0xFF, 0x6A,
+0x4C, 0xEB, 0x14, 0xD3, 0x14, 0x94, 0x0F, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x40, 0x9A,
+0x64, 0x99, 0x6C, 0xEA, 0x32, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0x45, 0xF2, 0x00, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0x4D, 0x63, 0x2A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x0C, 0x4A, 0xC0, 0x9A,
+0x00, 0x6C, 0xE4, 0x67, 0xB8, 0x6D, 0x00, 0x18,
+0xC5, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x0C, 0x4B, 0xC0, 0x9B, 0xB8, 0x6D, 0x01, 0x6F,
+0x00, 0x6C, 0x00, 0x18, 0xC5, 0x37, 0x91, 0x67,
+0x00, 0x18, 0xF9, 0x7C, 0x91, 0x67, 0x00, 0x18,
+0x0D, 0x7D, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x40, 0x9A, 0x64, 0x99, 0x6C, 0xEA, 0x07, 0x22,
+0x30, 0xF0, 0x20, 0x6C, 0xA5, 0xF2, 0x0C, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0x4D, 0x63, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x19, 0x97, 0x18, 0x91,
+0x17, 0x90, 0x0D, 0x63, 0x00, 0xEF, 0x00, 0x6A,
+0x44, 0x17, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x68, 0x0C, 0xED,
+0x24, 0x67, 0x0D, 0xD7, 0x04, 0xD5, 0xCC, 0xE8,
+0x00, 0x18, 0x53, 0x7C, 0x0F, 0x22, 0x04, 0x95,
+0x91, 0x67, 0x00, 0x18, 0xEB, 0x7F, 0x0A, 0x22,
+0x0D, 0x96, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x18,
+0xEC, 0x7E, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x32, 0x01, 0x10, 0x00, 0x6A, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0x42, 0x29, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+};
+
+u32 array_length_mp_8822b_fw_nic = 145104;
+
+#ifdef CONFIG_WOWLAN
+
+u8 array_mp_8822b_fw_wowlan[] = {
+0x22, 0x88, 0x00, 0x00, 0x16, 0x00, 0x06, 0x00,
+0x42, 0x65, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x04, 0x19, 0x0E, 0x27, 0xE2, 0x07, 0x00, 0x00,
+0x08, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x20, 0x80, 0x48, 0x0B, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xA0, 0x3C, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x10, 0x12, 0x80, 0x00, 0x00, 0x00, 0x80,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x71, 0x2F, 0x00, 0x80, 0xE5, 0x06, 0x00, 0x80,
+0x03, 0x02, 0x01, 0xFE, 0x03, 0x03, 0x01, 0xFE,
+0x03, 0x04, 0x01, 0xFE, 0x03, 0x05, 0x01, 0xFE,
+0x03, 0x06, 0x01, 0xFE, 0x03, 0x07, 0x01, 0xFE,
+0xD5, 0xAA, 0x00, 0x80, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xB9, 0xAC, 0x00, 0x80, 0x01, 0x00, 0x00, 0x00,
+0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x48, 0x0B, 0x20, 0x80, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x2A, 0xEA, 0xA0, 0x79,
+0x2C, 0xEA, 0xA0, 0x79, 0x2A, 0xEA, 0xA0, 0x79,
+0x2A, 0xEA, 0xA0, 0x79, 0x41, 0x55, 0x76, 0x87,
+0x41, 0x63, 0x74, 0x87, 0x41, 0x55, 0x76, 0x87,
+0x41, 0x63, 0x74, 0x87, 0x10, 0x60, 0xB8, 0x75,
+0x10, 0x60, 0xB7, 0x75, 0x10, 0x60, 0xB8, 0x75,
+0x10, 0x60, 0xB7, 0x75, 0x28, 0xEA, 0xA0, 0x79,
+0x2C, 0xEA, 0xA0, 0x79, 0x28, 0xEA, 0xA0, 0x79,
+0x2A, 0xEA, 0xA0, 0x79, 0x51, 0x64, 0x76, 0x87,
+0x31, 0x64, 0x76, 0x87, 0x51, 0x64, 0x76, 0x87,
+0x31, 0x64, 0x76, 0x87, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x10, 0x70, 0xC9, 0x75,
+0x10, 0x70, 0xC9, 0x75, 0x2A, 0xEA, 0xA0, 0x79,
+0x2C, 0xEA, 0xA0, 0x97, 0x2A, 0xEA, 0xA0, 0x79,
+0x2A, 0xEA, 0xA0, 0x79, 0x41, 0x55, 0x76, 0x87,
+0x41, 0x63, 0x66, 0x86, 0x61, 0x55, 0x76, 0x87,
+0x61, 0x63, 0x66, 0x86, 0x06, 0x00, 0x00, 0x00,
+0x05, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
+0x40, 0x00, 0x00, 0x00, 0x40, 0x00, 0x40, 0x00,
+0x17, 0x47, 0x00, 0x80, 0x2D, 0x47, 0x00, 0x80,
+0x4B, 0x47, 0x00, 0x80, 0x7D, 0x47, 0x00, 0x80,
+0xA7, 0x47, 0x00, 0x80, 0x0F, 0x48, 0x00, 0x80,
+0x25, 0x48, 0x00, 0x80, 0x3B, 0x48, 0x00, 0x80,
+0x51, 0x48, 0x00, 0x80, 0x6B, 0x48, 0x00, 0x80,
+0xD7, 0x51, 0x00, 0x80, 0xDD, 0x51, 0x00, 0x80,
+0xE9, 0x51, 0x00, 0x80, 0xF5, 0x51, 0x00, 0x80,
+0x01, 0x52, 0x00, 0x80, 0x65, 0x54, 0x00, 0x80,
+0x4D, 0x55, 0x00, 0x80, 0xC7, 0x54, 0x00, 0x80,
+0x4D, 0x55, 0x00, 0x80, 0x0D, 0x54, 0x00, 0x80,
+0x4D, 0x55, 0x00, 0x80, 0x4D, 0x55, 0x00, 0x80,
+0x4D, 0x55, 0x00, 0x80, 0x2F, 0x55, 0x00, 0x80,
+0x4D, 0x55, 0x00, 0x80, 0x4D, 0x55, 0x00, 0x80,
+0x4D, 0x55, 0x00, 0x80, 0xA7, 0x53, 0x00, 0x80,
+0x69, 0x61, 0x00, 0x80, 0x7D, 0x61, 0x00, 0x80,
+0x91, 0x61, 0x00, 0x80, 0xA5, 0x61, 0x00, 0x80,
+0xBB, 0x61, 0x00, 0x80, 0xFB, 0x61, 0x00, 0x80,
+0x0F, 0x62, 0x00, 0x80, 0x23, 0x62, 0x00, 0x80,
+0x37, 0x62, 0x00, 0x80, 0x4D, 0x62, 0x00, 0x80,
+0xA8, 0x06, 0x10, 0x07, 0x00, 0x16, 0x04, 0x16,
+0x08, 0x16, 0x00, 0x00, 0xA8, 0x06, 0x10, 0x07,
+0x00, 0x16, 0x04, 0x16, 0x08, 0x16, 0x00, 0x00,
+0xA8, 0x06, 0x10, 0x07, 0x00, 0x16, 0x04, 0x16,
+0x08, 0x16, 0x00, 0x00, 0x10, 0x06, 0x00, 0x07,
+0x20, 0x16, 0x30, 0x16, 0x40, 0x16, 0x00, 0x00,
+0x18, 0x06, 0x08, 0x07, 0x28, 0x16, 0x38, 0x16,
+0x48, 0x16, 0x00, 0x00, 0x00, 0x04, 0x08, 0x00,
+0x08, 0x04, 0x04, 0x00, 0xA8, 0x06, 0x10, 0x07,
+0x00, 0x16, 0x04, 0x16, 0x08, 0x16, 0x00, 0x00,
+0xD5, 0xA9, 0x00, 0x80, 0xCF, 0xA9, 0x00, 0x80,
+0xDB, 0xA9, 0x00, 0x80, 0xE1, 0xA9, 0x00, 0x80,
+0xE7, 0xA9, 0x00, 0x80, 0xED, 0xA9, 0x00, 0x80,
+0x21, 0x36, 0x01, 0x80, 0x79, 0x36, 0x01, 0x80,
+0x07, 0x37, 0x01, 0x80, 0x1D, 0x36, 0x01, 0x80,
+0x1D, 0x36, 0x01, 0x80, 0x7F, 0x37, 0x01, 0x80,
+0xF7, 0x37, 0x01, 0x80, 0x05, 0x05, 0x00, 0x07,
+0x07, 0x06, 0x05, 0xFF, 0x00, 0x07, 0x07, 0x06,
+0x05, 0x05, 0x00, 0x00, 0x06, 0x05, 0x00, 0x00,
+0x07, 0x06, 0x06, 0xFF, 0x00, 0x00, 0x07, 0x06,
+0x06, 0x05, 0x00, 0xFF, 0x07, 0x06, 0x06, 0x05,
+0x00, 0x00, 0x07, 0x00, 0x07, 0x06, 0x06, 0x05,
+0x00, 0x00, 0x07, 0xFF, 0x06, 0x05, 0x00, 0x00,
+0x07, 0x06, 0x06, 0x00, 0x49, 0xBF, 0x00, 0x80,
+0x51, 0xBF, 0x00, 0x80, 0x77, 0xBF, 0x00, 0x80,
+0x77, 0xBF, 0x00, 0x80, 0x77, 0xBF, 0x00, 0x80,
+0x77, 0xBF, 0x00, 0x80, 0x57, 0xBF, 0x00, 0x80,
+0x5F, 0xBF, 0x00, 0x80, 0x67, 0xBF, 0x00, 0x80,
+0x77, 0xBF, 0x00, 0x80, 0x6F, 0xBF, 0x00, 0x80,
+0x41, 0xBF, 0x00, 0x80, 0x9F, 0x12, 0x00, 0x80,
+0x9B, 0x12, 0x00, 0x80, 0x9F, 0x12, 0x00, 0x80,
+0x9B, 0x12, 0x00, 0x80, 0xBF, 0x12, 0x00, 0x80,
+0x9B, 0x12, 0x00, 0x80, 0xBF, 0x12, 0x00, 0x80,
+0x9B, 0x12, 0x00, 0x80, 0xDF, 0x12, 0x00, 0x80,
+0x9B, 0x12, 0x00, 0x80, 0xDF, 0x12, 0x00, 0x80,
+0x9B, 0x12, 0x00, 0x80, 0xFF, 0x12, 0x00, 0x80,
+0x9B, 0x12, 0x00, 0x80, 0xFF, 0x12, 0x00, 0x80,
+0x45, 0x1C, 0x00, 0x80, 0x67, 0x1C, 0x00, 0x80,
+0x89, 0x1C, 0x00, 0x80, 0xAB, 0x1C, 0x00, 0x80,
+0xCF, 0x1C, 0x00, 0x80, 0x09, 0x1D, 0x00, 0x80,
+0x2D, 0x1D, 0x00, 0x80, 0x51, 0x1D, 0x00, 0x80,
+0x75, 0x1D, 0x00, 0x80, 0x9B, 0x1D, 0x00, 0x80,
+0x55, 0xD1, 0x00, 0x80, 0x63, 0xD1, 0x00, 0x80,
+0x67, 0xD1, 0x00, 0x80, 0x6B, 0xD1, 0x00, 0x80,
+0x6F, 0xD1, 0x00, 0x80, 0xD9, 0xD4, 0x00, 0x80,
+0xD9, 0xD4, 0x00, 0x80, 0xD9, 0xD4, 0x00, 0x80,
+0xF3, 0xD4, 0x00, 0x80, 0xD9, 0xD4, 0x00, 0x80,
+0xD9, 0xD4, 0x00, 0x80, 0xD9, 0xD4, 0x00, 0x80,
+0xD5, 0xD4, 0x00, 0x80, 0xD5, 0xD4, 0x00, 0x80,
+0xD5, 0xD4, 0x00, 0x80, 0xD5, 0xD4, 0x00, 0x80,
+0xD5, 0xD4, 0x00, 0x80, 0x51, 0xD5, 0x00, 0x80,
+0x59, 0xD5, 0x00, 0x80, 0x67, 0xE1, 0x00, 0x80,
+0x67, 0xE1, 0x00, 0x80, 0x67, 0xE1, 0x00, 0x80,
+0x75, 0xE1, 0x00, 0x80, 0x83, 0xE1, 0x00, 0x80,
+0xB9, 0xE1, 0x00, 0x80, 0x0F, 0xE2, 0x00, 0x80,
+0x1D, 0xE2, 0x00, 0x80, 0x5F, 0xE2, 0x00, 0x80,
+0xA9, 0xE2, 0x00, 0x80, 0x5F, 0xE2, 0x00, 0x80,
+0x01, 0xE3, 0x00, 0x80, 0xFD, 0x15, 0x00, 0x80,
+0xFD, 0x15, 0x00, 0x80, 0xFD, 0x15, 0x00, 0x80,
+0xFD, 0x15, 0x00, 0x80, 0x1D, 0x16, 0x00, 0x80,
+0x1D, 0x16, 0x00, 0x80, 0x1D, 0x16, 0x00, 0x80,
+0x1D, 0x16, 0x00, 0x80, 0x3D, 0x16, 0x00, 0x80,
+0x3D, 0x16, 0x00, 0x80, 0x3D, 0x16, 0x00, 0x80,
+0x3D, 0x16, 0x00, 0x80, 0x5D, 0x16, 0x00, 0x80,
+0x5D, 0x16, 0x00, 0x80, 0x5D, 0x16, 0x00, 0x80,
+0x5D, 0x16, 0x00, 0x80, 0xC3, 0xEB, 0x00, 0x80,
+0xD3, 0xEB, 0x00, 0x80, 0xDD, 0xEB, 0x00, 0x80,
+0xE7, 0xEB, 0x00, 0x80, 0xF9, 0xEB, 0x00, 0x80,
+0x3B, 0x1E, 0x01, 0x80, 0x97, 0x1E, 0x01, 0x80,
+0x2B, 0x1F, 0x01, 0x80, 0xBF, 0x1F, 0x01, 0x80,
+0x57, 0x20, 0x01, 0x80, 0xFC, 0x10, 0x60, 0xB8,
+0xFA, 0xFA, 0xFA, 0xFA, 0x8C, 0x04, 0x64, 0xB8,
+0x90, 0x04, 0x64, 0xB8, 0x94, 0x04, 0x64, 0xB8,
+0x98, 0x04, 0x64, 0xB8, 0x9C, 0x04, 0x64, 0xB8,
+0xA0, 0x04, 0x64, 0xB8, 0x64, 0x01, 0x64, 0xB8,
+0xBC, 0x01, 0x64, 0xB8, 0x00, 0x09, 0x3D, 0x00,
+0x77, 0x05, 0x64, 0xB8, 0x6C, 0x05, 0x64, 0xB8,
+0x68, 0x05, 0x64, 0xB8, 0x00, 0x00, 0x00, 0x80,
+0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0xFF, 0xFF,
+0x54, 0x05, 0x64, 0xB8, 0xFF, 0xFF, 0xFF, 0x8F,
+0x60, 0x05, 0x60, 0xB8, 0x60, 0x05, 0x64, 0xB8,
+0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x20,
+0x00, 0x00, 0x00, 0x30, 0x00, 0x00, 0x00, 0x40,
+0x50, 0x05, 0x64, 0xB8, 0x51, 0x05, 0x64, 0xB8,
+0x78, 0x05, 0x64, 0xB8, 0x79, 0x05, 0x64, 0xB8,
+0x7A, 0x05, 0x64, 0xB8, 0xBF, 0x01, 0x64, 0xB8,
+0x89, 0x00, 0x60, 0xB8, 0x8A, 0x00, 0x60, 0xB8,
+0x1A, 0x04, 0x64, 0xB8, 0x1B, 0x04, 0x64, 0xB8,
+0x8C, 0x00, 0x60, 0xB8, 0x8D, 0x00, 0x60, 0xB8,
+0x8E, 0x00, 0x60, 0xB8, 0x01, 0x00, 0xFF, 0x00,
+0x58, 0x05, 0x64, 0xB8, 0x01, 0x00, 0x60, 0xB8,
+0x01, 0x00, 0x64, 0xB8, 0x22, 0x05, 0x64, 0xB8,
+0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00,
+0x00, 0x00, 0x08, 0x00, 0x5B, 0x01, 0x64, 0xB8,
+0x3C, 0x01, 0x64, 0xB8, 0x86, 0x02, 0x64, 0xB8,
+0x8F, 0x00, 0x60, 0xB8, 0x0A, 0x06, 0x64, 0xB8,
+0xB1, 0x05, 0x64, 0xB8, 0xFE, 0x11, 0x64, 0xB8,
+0xE2, 0x10, 0x60, 0xB8, 0x00, 0x00, 0x60, 0xB8,
+0x00, 0x00, 0x64, 0xB8, 0xFC, 0x11, 0x64, 0xB8,
+0xE0, 0x10, 0x60, 0xB8, 0x57, 0x01, 0x64, 0xB8,
+0x00, 0x00, 0x1E, 0x00, 0x09, 0x00, 0x78, 0xB8,
+0x31, 0x00, 0x78, 0xB8, 0x14, 0x00, 0x78, 0xB8,
+0x1D, 0x04, 0x64, 0xB8, 0x7A, 0x04, 0x64, 0xB8,
+0x74, 0x06, 0x64, 0xB8, 0x00, 0x00, 0x01, 0x80,
+0x70, 0x06, 0x64, 0xB8, 0x72, 0x06, 0x64, 0xB8,
+0x80, 0x01, 0x64, 0xB8, 0x84, 0x01, 0x64, 0xB8,
+0x00, 0x00, 0x78, 0xB8, 0xA9, 0x00, 0x78, 0xB8,
+0x61, 0x00, 0x78, 0xB8, 0x01, 0x00, 0x78, 0xB8,
+0xB9, 0x00, 0x78, 0xB8, 0xC1, 0x01, 0x64, 0xB8,
+0xB9, 0x01, 0x64, 0xB8, 0xC3, 0x01, 0x64, 0xB8,
+0xC7, 0x01, 0x64, 0xB8, 0x24, 0x01, 0x64, 0xB8,
+0x90, 0x06, 0x64, 0xB8, 0x60, 0x00, 0x60, 0xB8,
+0x44, 0x00, 0x60, 0xB8, 0x4D, 0x01, 0x64, 0xB8,
+0x00, 0x01, 0x64, 0xB8, 0x46, 0x00, 0x78, 0xB8,
+0x50, 0x00, 0x78, 0xB8, 0x40, 0x00, 0x78, 0xB8,
+0x4A, 0x00, 0x78, 0xB8, 0x30, 0x00, 0x78, 0xB8,
+0x34, 0x00, 0x78, 0xB8, 0x18, 0x00, 0x78, 0xB8,
+0x28, 0x00, 0x78, 0xB8, 0x10, 0x00, 0x78, 0xB8,
+0x08, 0x00, 0x78, 0xB8, 0x0A, 0x00, 0x78, 0xB8,
+0x78, 0x06, 0x60, 0xB8, 0x09, 0x06, 0x64, 0xB8,
+0x08, 0x06, 0x64, 0xB8, 0xFF, 0xFF, 0xFF, 0x7F,
+0x05, 0x00, 0x60, 0xB8, 0x04, 0x00, 0x78, 0xB8,
+0x38, 0x00, 0x78, 0xB8, 0x7A, 0x00, 0x78, 0xB8,
+0x60, 0x00, 0x78, 0xB8, 0x54, 0x00, 0x78, 0xB8,
+0xC0, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x70, 0x18,
+0x20, 0x00, 0x78, 0xB8, 0xC4, 0x01, 0x64, 0xB8,
+0xA5, 0xA5, 0xA5, 0xA5, 0xC2, 0x01, 0x64, 0xB8,
+0x05, 0x00, 0x78, 0xB8, 0x02, 0x00, 0x78, 0xB8,
+0x06, 0x00, 0x78, 0xB8, 0x0C, 0x00, 0x78, 0xB8,
+0x0D, 0x00, 0x78, 0xB8, 0x0E, 0x00, 0x78, 0xB8,
+0x0F, 0x00, 0x78, 0xB8, 0x02, 0x00, 0x60, 0xB8,
+0x02, 0x00, 0x64, 0xB8, 0x86, 0x00, 0x60, 0xB8,
+0x87, 0x00, 0x60, 0xB8, 0x88, 0x00, 0x60, 0xB8,
+0x84, 0x00, 0x60, 0xB8, 0xF8, 0x10, 0x60, 0xB8,
+0x00, 0x00, 0x00, 0x02, 0xCB, 0x01, 0x64, 0xB8,
+0x00, 0x00, 0x68, 0xB8, 0x04, 0x00, 0x68, 0xB8,
+0x08, 0x00, 0x68, 0xB8, 0x0C, 0x00, 0x68, 0xB8,
+0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x42,
+0xE0, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xFF, 0xFD,
+0xE3, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x01,
+0xE1, 0x00, 0x60, 0xB8, 0x00, 0x00, 0x00, 0x60,
+0xCC, 0x00, 0x60, 0xB8, 0xE8, 0x12, 0x64, 0xB8,
+0xFF, 0xFF, 0x03, 0x00, 0x00, 0x00, 0x00, 0x04,
+0xFF, 0xFF, 0xFF, 0xFB, 0xFF, 0xFF, 0xFF, 0xDF,
+0xFF, 0xFF, 0xFF, 0x1F, 0x04, 0x00, 0x60, 0xB8,
+0x04, 0x00, 0x64, 0xB8, 0x08, 0x00, 0x60, 0xB8,
+0x08, 0x00, 0x64, 0xB8, 0x24, 0x00, 0x60, 0xB8,
+0x80, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xFE, 0xFF,
+0xFF, 0xFF, 0xFF, 0xEF, 0xCC, 0x07, 0x64, 0xB8,
+0xFF, 0xFF, 0xFD, 0xFF, 0x1C, 0x01, 0x64, 0xB8,
+0x00, 0x00, 0x70, 0xB8, 0x24, 0x04, 0x64, 0xB8,
+0x87, 0x02, 0x64, 0xB8, 0x1C, 0x04, 0x64, 0xB8,
+0x00, 0x0C, 0x01, 0x00, 0xD0, 0xC7, 0x7B, 0x18,
+0xD0, 0xAF, 0x7B, 0x18, 0x01, 0x00, 0x66, 0xB8,
+0xCC, 0x06, 0x64, 0xB8, 0xFF, 0xFF, 0x0F, 0x00,
+0xFF, 0xFF, 0xFF, 0x00, 0x74, 0x57, 0x74, 0x00,
+0x47, 0x75, 0x47, 0x00, 0x70, 0x45, 0x70, 0x00,
+0x17, 0x45, 0x17, 0x00, 0x00, 0x00, 0xF0, 0xFF,
+0x70, 0x57, 0x70, 0x00, 0x17, 0x75, 0x17, 0x00,
+0x00, 0x00, 0x00, 0x06, 0xFF, 0xFF, 0xFF, 0x0F,
+0xFF, 0xFC, 0xFE, 0xFF, 0x92, 0x84, 0x10, 0x08,
+0x00, 0x00, 0x00, 0x08, 0x00, 0x01, 0x01, 0x00,
+0x00, 0x00, 0x10, 0x08, 0x00, 0x00, 0x40, 0x00,
+0x28, 0xEA, 0xA0, 0x79, 0xB9, 0xB2, 0x94, 0x91,
+0x00, 0x00, 0x0C, 0x00, 0x00, 0x00, 0x00, 0xF0,
+0x00, 0x00, 0x00, 0x0F, 0x00, 0x00, 0x80, 0x00,
+0x0E, 0x08, 0x04, 0x00, 0x0C, 0x08, 0x04, 0x00,
+0x00, 0x00, 0x30, 0x00, 0x00, 0x00, 0xC0, 0x00,
+0x00, 0xFF, 0xF9, 0xFF, 0x00, 0x00, 0xFE, 0x1F,
+0x77, 0x65, 0x4F, 0x38, 0x00, 0x80, 0x03, 0x00,
+0x18, 0x00, 0x70, 0xB8, 0x0B, 0x00, 0x78, 0xB8,
+0x0B, 0x00, 0x70, 0xB8, 0x02, 0x00, 0x70, 0xB8,
+0x96, 0x02, 0x64, 0xB8, 0x01, 0xA0, 0x02, 0x00,
+0x94, 0x02, 0x64, 0xB8, 0x97, 0x02, 0x64, 0xB8,
+0xCC, 0x01, 0x64, 0xB8, 0xCF, 0x01, 0x64, 0xB8,
+0x34, 0x01, 0x64, 0xB8, 0x54, 0x02, 0x64, 0xB8,
+0x50, 0x02, 0x64, 0xB8, 0x4C, 0x02, 0x64, 0xB8,
+0x48, 0x02, 0x64, 0xB8, 0x44, 0x02, 0x64, 0xB8,
+0x64, 0x05, 0x64, 0xB8, 0xD4, 0x04, 0x60, 0xB8,
+0xD4, 0x04, 0x64, 0xB8, 0x84, 0x04, 0x60, 0xB8,
+0x84, 0x04, 0x64, 0xB8, 0xC8, 0x04, 0x60, 0xB8,
+0xC8, 0x04, 0x64, 0xB8, 0x78, 0x04, 0x60, 0xB8,
+0x78, 0x04, 0x64, 0xB8, 0x1F, 0x00, 0x60, 0xB8,
+0x01, 0xEA, 0xEF, 0xFD, 0x02, 0xEA, 0xEF, 0xFD,
+0xC8, 0x01, 0x64, 0xB8, 0xC9, 0x01, 0x64, 0xB8,
+0xA0, 0x01, 0x64, 0xB8, 0x48, 0x00, 0x60, 0xB8,
+0x47, 0x00, 0x60, 0xB8, 0x46, 0x00, 0x60, 0xB8,
+0x63, 0x00, 0x60, 0xB8, 0x62, 0x00, 0x60, 0xB8,
+0x45, 0x00, 0x60, 0xB8, 0x61, 0x00, 0x60, 0xB8,
+0xC6, 0x01, 0x64, 0xB8, 0x00, 0x00, 0x00, 0x05,
+0x53, 0x05, 0x64, 0xB8, 0x94, 0x01, 0x64, 0xB8,
+0x54, 0x00, 0x60, 0xB8, 0x50, 0x00, 0x60, 0xB8,
+0x30, 0x01, 0x64, 0xB8, 0x20, 0x01, 0x64, 0xB8,
+0x24, 0x11, 0x64, 0xB8, 0x20, 0x11, 0x64, 0xB8,
+0x2C, 0x11, 0x64, 0xB8, 0x28, 0x11, 0x64, 0xB8,
+0x34, 0x11, 0x64, 0xB8, 0x30, 0x11, 0x64, 0xB8,
+0x38, 0x01, 0x64, 0xB8, 0x3C, 0x11, 0x64, 0xB8,
+0x38, 0x11, 0x64, 0xB8, 0xE4, 0x11, 0x64, 0xB8,
+0xE0, 0x11, 0x64, 0xB8, 0x00, 0x40, 0xE0, 0x03,
+0x01, 0x60, 0x00, 0x03, 0x00, 0x00, 0x66, 0xB8,
+0x00, 0x10, 0x66, 0xB8, 0x00, 0x1C, 0x66, 0xB8,
+0xE0, 0x12, 0x64, 0xB8, 0x2F, 0x01, 0x64, 0xB8,
+0xE8, 0x10, 0x60, 0xB8, 0x00, 0x28, 0x64, 0xB8,
+0x00, 0x2C, 0x64, 0xB8, 0x00, 0x38, 0x64, 0xB8,
+0x00, 0x3C, 0x64, 0xB8, 0x54, 0x04, 0x64, 0xB8,
+0x77, 0x77, 0x77, 0x77, 0x00, 0x00, 0xF0, 0x3F,
+0x70, 0x77, 0x33, 0x54, 0x00, 0x00, 0x10, 0x00,
+0x17, 0x77, 0x33, 0x77, 0x77, 0x77, 0x33, 0x77,
+0x17, 0x77, 0x33, 0x54, 0x00, 0x00, 0xFF, 0x00,
+0x00, 0x00, 0x33, 0x00, 0x00, 0x03, 0x07, 0x00,
+0xFF, 0x03, 0x07, 0x00, 0x83, 0x00, 0x60, 0xB8,
+0x90, 0x00, 0x60, 0xB8, 0x92, 0x06, 0x64, 0xB8,
+0x08, 0x01, 0x64, 0xB8, 0x00, 0x10, 0x60, 0xB8,
+0xEF, 0x00, 0x60, 0xB8, 0xF8, 0x05, 0x64, 0xB8,
+0x92, 0x00, 0x60, 0xB8, 0x1F, 0x07, 0x64, 0xB8,
+0x1C, 0x07, 0x64, 0xB8, 0xB8, 0x05, 0x64, 0xB8,
+0xBC, 0x05, 0x64, 0xB8, 0x5F, 0x11, 0x64, 0xB8,
+0xFE, 0xFF, 0xFF, 0x7F, 0x30, 0x00, 0x78, 0x18,
+0x00, 0xA0, 0x7A, 0xB8, 0x00, 0xA0, 0x7A, 0x18,
+0x00, 0x00, 0x66, 0x18, 0xE8, 0x03, 0x00, 0x80,
+0xFF, 0x00, 0xFF, 0x00, 0x40, 0x00, 0x00, 0xB5,
+0x44, 0x00, 0x00, 0xB5, 0x48, 0x00, 0x00, 0xB5,
+0x4C, 0x00, 0x00, 0xB5, 0xA4, 0x04, 0x64, 0xB8,
+0xA8, 0x04, 0x64, 0xB8, 0x00, 0x00, 0x20, 0x00,
+0xF4, 0x00, 0x60, 0xB8, 0x44, 0x00, 0x02, 0x00,
+0xA0, 0x07, 0x64, 0xB8, 0x14, 0x11, 0x64, 0xB8,
+0x16, 0x11, 0x64, 0xB8, 0x17, 0x11, 0x64, 0xB8,
+0x01, 0x06, 0x64, 0xB8, 0xD4, 0x07, 0x64, 0xB8,
+0x0F, 0x06, 0x64, 0xB8, 0x9A, 0x01, 0x64, 0xB8,
+0x98, 0x01, 0x64, 0xB8, 0x7B, 0x05, 0x64, 0xB8,
+0x73, 0x05, 0x64, 0xB8, 0x7C, 0x00, 0x60, 0xB8,
+0x10, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xDF, 0xFF,
+0x14, 0x00, 0x60, 0xB8, 0xFF, 0xFF, 0xFF, 0xBF,
+0x01, 0x01, 0x64, 0xB8, 0xB7, 0x06, 0x64, 0xB8,
+0xB4, 0x06, 0x64, 0xB8, 0x00, 0x00, 0x03, 0x00,
+0x0F, 0x00, 0x3E, 0x00, 0x03, 0x00, 0x78, 0xB8,
+0xBA, 0x01, 0x64, 0xB8, 0x64, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xEF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFE,
+0x40, 0x00, 0x60, 0xB8, 0x4C, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0x7F, 0xFF, 0x44, 0x09, 0x64, 0xB8,
+0x30, 0x09, 0x64, 0xB8, 0x38, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0xFF, 0xCF, 0xFF, 0xFF, 0xFF, 0xF9,
+0x03, 0x00, 0x60, 0xB8, 0x70, 0x00, 0x60, 0xB8,
+0x80, 0x10, 0x60, 0xB8, 0xEC, 0x00, 0x60, 0xB8,
+0x00, 0x00, 0x00, 0x07, 0xFF, 0xFF, 0xFF, 0xF8,
+0xE4, 0x00, 0x60, 0xB8, 0xE5, 0x00, 0x60, 0xB8,
+0xE8, 0x00, 0x60, 0xB8, 0xE9, 0x00, 0x60, 0xB8,
+0xEA, 0x00, 0x60, 0xB8, 0xEB, 0x00, 0x60, 0xB8,
+0xFF, 0xFF, 0x7F, 0xFE, 0x31, 0x00, 0x60, 0xB8,
+0x32, 0x00, 0x60, 0xB8, 0x33, 0x00, 0x60, 0xB8,
+0x30, 0x00, 0x60, 0xB8, 0x01, 0xAA, 0xAA, 0xFA,
+0x68, 0x06, 0x64, 0xB8, 0xFF, 0xFF, 0xCF, 0xFF,
+0x5C, 0x05, 0x64, 0xB8, 0x38, 0x06, 0x64, 0xB8,
+0x83, 0x04, 0x64, 0xB8, 0xA0, 0x06, 0x64, 0xB8,
+0x84, 0x02, 0x64, 0xB8, 0x18, 0x11, 0x64, 0xB8,
+0xFF, 0xFF, 0xFB, 0xFF, 0x00, 0x00, 0x78, 0x18,
+0x04, 0x06, 0x64, 0xB8, 0x60, 0x16, 0x64, 0xB8,
+0xFF, 0xFF, 0x01, 0xFF, 0x12, 0x05, 0x64, 0xB8,
+0x10, 0x05, 0x64, 0xB8, 0x00, 0x00, 0x04, 0x04,
+0x08, 0x08, 0x08, 0x08, 0x0C, 0x0C, 0x0C, 0x0C,
+0x0C, 0x0C, 0x0C, 0x0C, 0x10, 0x10, 0x10, 0x10,
+0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10,
+0x10, 0x10, 0x10, 0x10, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
+0x14, 0x14, 0x14, 0x14, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
+0x18, 0x18, 0x18, 0x18, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
+0x1C, 0x1C, 0x1C, 0x1C, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x50, 0xF2, 0x01, 0x00, 0x00, 0x00, 0x00,
+0x53, 0xAA, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x18, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x5A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x10, 0xF0, 0x20, 0x6A, 0x20, 0xF3, 0x09, 0x4A,
+0x00, 0xEA, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x30, 0xF0, 0x21, 0x6C, 0x18, 0xF0, 0x00, 0x4C,
+0xBC, 0x65, 0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x94, 0xB8,
+0x00, 0x6D, 0xFE, 0xF7, 0x1F, 0x4D, 0xAC, 0xEC,
+0x94, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0xF4,
+0x00, 0x6D, 0xAD, 0xEC, 0x94, 0xB9, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF0, 0x00, 0x4C,
+0x00, 0x6E, 0x30, 0xF0, 0x20, 0x6F, 0x00, 0xF0,
+0x00, 0x4F, 0xC0, 0xDC, 0x04, 0x4C, 0xE3, 0xEC,
+0xB8, 0x67, 0xFB, 0x2D, 0x30, 0xF0, 0x20, 0x6C,
+0x41, 0xF3, 0x08, 0x4C, 0x00, 0x6E, 0x30, 0xF0,
+0x20, 0x6F, 0xE9, 0xF4, 0x08, 0x4F, 0xC0, 0xDC,
+0x04, 0x4C, 0xE3, 0xEC, 0xB8, 0x67, 0xFB, 0x2D,
+0x10, 0xF0, 0x20, 0x6C, 0x60, 0xF2, 0x15, 0x4C,
+0x00, 0xEC, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x60, 0xF2, 0x15, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0xD6, 0x05, 0x00, 0x18,
+0xF5, 0x05, 0x00, 0x18, 0x2F, 0x08, 0x00, 0x18,
+0x10, 0x06, 0x00, 0x18, 0x0F, 0x08, 0x00, 0x18,
+0xF6, 0x0F, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x21, 0x6A, 0x60, 0xF0, 0x08, 0x4C, 0x15, 0xF0,
+0x00, 0x4A, 0x43, 0xDC, 0x00, 0x6D, 0x00, 0x18,
+0xB1, 0x0F, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF0, 0x08, 0x4C, 0x01, 0x6D,
+0xA8, 0xF3, 0x54, 0xDB, 0x00, 0x18, 0x6A, 0x0E,
+0x30, 0xF0, 0x20, 0x6B, 0xA8, 0xF3, 0x5C, 0xDB,
+0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0, 0x21, 0x6A,
+0xA0, 0xF0, 0x08, 0x4C, 0x15, 0xF4, 0x00, 0x4A,
+0x43, 0xDC, 0x00, 0x6D, 0x00, 0x18, 0xB1, 0x0F,
+0x30, 0xF0, 0x20, 0x6B, 0xA8, 0xF3, 0x58, 0xDB,
+0x00, 0x18, 0xA1, 0x09, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x60, 0x9A, 0xFF, 0xF7, 0x1F, 0x6C,
+0x10, 0xF0, 0x00, 0x6D, 0x40, 0xAB, 0xAB, 0xED,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xCB,
+0x00, 0x18, 0x8B, 0x0D, 0x00, 0x18, 0xF0, 0x0B,
+0xFF, 0x17, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x6D, 0xB8, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6A,
+0x7C, 0x4A, 0x6C, 0xEA, 0x20, 0x22, 0x00, 0xF0,
+0x20, 0x6B, 0x28, 0x4B, 0x6A, 0xEA, 0x0F, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x49, 0xF3, 0x14, 0x4B,
+0x77, 0xF0, 0x24, 0x6A, 0xA0, 0xF4, 0x04, 0x4A,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF3,
+0x14, 0x4A, 0x6A, 0xEA, 0x31, 0x60, 0x77, 0xF0,
+0x24, 0x6A, 0xA0, 0xF1, 0x1C, 0x4A, 0x1D, 0xF4,
+0x00, 0x6B, 0x60, 0xDA, 0x10, 0xF0, 0x20, 0x6A,
+0x65, 0xF7, 0x11, 0x4A, 0x00, 0xEA, 0x00, 0xF0,
+0x20, 0x6A, 0x1F, 0xF7, 0x00, 0x6A, 0x4C, 0xEB,
+0x4C, 0xB8, 0x00, 0x65, 0x6C, 0xEA, 0x42, 0x32,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF2, 0x1C, 0x4B,
+0x49, 0xE3, 0x40, 0xA2, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF0, 0x08, 0x4B, 0x69, 0xE2, 0x30, 0xF0,
+0x20, 0x6B, 0x49, 0xF3, 0x10, 0x4B, 0x60, 0x9B,
+0x05, 0x2B, 0x10, 0xF0, 0x20, 0x6B, 0x00, 0xF5,
+0x1D, 0x4B, 0x00, 0xEB, 0x10, 0xF0, 0x20, 0x6B,
+0xA0, 0xF5, 0x11, 0x4B, 0x00, 0xEB, 0x00, 0x65,
+0x00, 0xF0, 0x20, 0x6B, 0x01, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x49, 0xF3, 0x14, 0x4A, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0xA8, 0xF3, 0x00, 0x4A,
+0x60, 0xDA, 0x10, 0xF0, 0x20, 0x6B, 0xE0, 0xF3,
+0x05, 0x4B, 0x00, 0xEB, 0x5A, 0xB8, 0x00, 0x65,
+0x7B, 0xB8, 0x00, 0x65, 0x40, 0xE8, 0x5A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x7B, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x30, 0xF0,
+0x20, 0x6A, 0xA8, 0xF3, 0x00, 0x4A, 0x00, 0xF0,
+0x20, 0x6B, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0xE8, 0xF3, 0x18, 0x4A, 0x60, 0x9A, 0x41, 0x9A,
+0x6A, 0xEA, 0x0D, 0x61, 0x6E, 0xB8, 0x00, 0x65,
+0x62, 0x43, 0xCB, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x5A, 0xB8, 0x00, 0x65, 0x7B, 0xB8,
+0x00, 0x65, 0x00, 0xBA, 0x00, 0x65, 0x36, 0x23,
+0xDF, 0xF7, 0x00, 0x03, 0x86, 0xDB, 0xA7, 0xDB,
+0xC8, 0xDB, 0xE9, 0xDB, 0x0A, 0xDB, 0x2B, 0xDB,
+0x98, 0x67, 0x8C, 0xDB, 0x9F, 0x67, 0x8E, 0xDB,
+0x12, 0xEC, 0x10, 0xED, 0x82, 0xDB, 0xA3, 0xDB,
+0x9A, 0xB8, 0x00, 0x65, 0x84, 0xDB, 0x9B, 0xB8,
+0x00, 0x65, 0x85, 0xDB, 0x8E, 0xB8, 0x00, 0x65,
+0x82, 0x44, 0x81, 0xDB, 0x8C, 0xB8, 0x00, 0x65,
+0x80, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xE8, 0xF3,
+0x18, 0x4B, 0x60, 0x9B, 0x9D, 0x67, 0x89, 0xDB,
+0x6A, 0x9B, 0xCF, 0xF7, 0x80, 0x44, 0x62, 0xEC,
+0x0D, 0x60, 0x77, 0xF0, 0x24, 0x6C, 0xA0, 0xF1,
+0x1C, 0x4C, 0x1D, 0xF4, 0x01, 0x6B, 0x60, 0xDC,
+0x10, 0xF0, 0x20, 0x6C, 0x65, 0xF7, 0x11, 0x4C,
+0x00, 0xEC, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xE8, 0xF3, 0x18, 0x4B, 0x41, 0x9B, 0x40, 0xDB,
+0x89, 0x9A, 0xBC, 0x65, 0x7D, 0x67, 0xDF, 0xF7,
+0x00, 0x03, 0x4C, 0xB8, 0x00, 0x65, 0x00, 0xF0,
+0x20, 0x6D, 0x05, 0x4D, 0xAF, 0xED, 0xAC, 0xEA,
+0xA0, 0x9B, 0x04, 0x6C, 0x8C, 0xED, 0xAD, 0xEA,
+0x82, 0x9B, 0xA3, 0x9B, 0x32, 0xEC, 0x30, 0xED,
+0x8E, 0x9B, 0xFC, 0x65, 0x8C, 0x9B, 0x1C, 0x65,
+0x84, 0x9B, 0x5C, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x85, 0x9B, 0x7C, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x2B, 0x9B, 0x0A, 0x9B,
+0xE9, 0x9B, 0xC8, 0x9B, 0xA7, 0x9B, 0x86, 0x9B,
+0x61, 0x9B, 0xCB, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x8A, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x5A, 0xB8,
+0x00, 0x65, 0x00, 0xBA, 0xDF, 0xF7, 0x00, 0x03,
+0x86, 0xDB, 0xA7, 0xDB, 0xC8, 0xDB, 0xE9, 0xDB,
+0x0A, 0xDB, 0x2B, 0xDB, 0x98, 0x67, 0x8C, 0xDB,
+0x9F, 0x67, 0x8E, 0xDB, 0x12, 0xEC, 0x10, 0xED,
+0x82, 0xDB, 0xA3, 0xDB, 0x9A, 0xB8, 0x00, 0x65,
+0x84, 0xDB, 0x9B, 0xB8, 0x00, 0x65, 0x85, 0xDB,
+0x7D, 0x67, 0x5B, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x40, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x28, 0xF7, 0x14, 0x4C, 0x00, 0xF4, 0x00, 0x4C,
+0xBC, 0x65, 0x82, 0x67, 0x40, 0xEA, 0x00, 0x65,
+0x7A, 0xB8, 0x00, 0x65, 0xBB, 0x65, 0xDF, 0xF7,
+0x00, 0x03, 0x82, 0x9B, 0xA3, 0x9B, 0x32, 0xEC,
+0x30, 0xED, 0x8E, 0x9B, 0xFC, 0x65, 0x8C, 0x9B,
+0x1C, 0x65, 0x84, 0x9B, 0x5C, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x85, 0x9B, 0x7C, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x2B, 0x9B,
+0x0A, 0x9B, 0xE9, 0x9B, 0xC8, 0x9B, 0xA7, 0x9B,
+0x86, 0x9B, 0x5A, 0xB8, 0x00, 0x65, 0x7B, 0xB8,
+0x00, 0x65, 0x00, 0xBA, 0x00, 0x65, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xA8, 0xF3, 0x00, 0x4B,
+0x40, 0xDB, 0xDF, 0xF7, 0x00, 0x03, 0x86, 0xDB,
+0xA7, 0xDB, 0xC8, 0xDB, 0xE9, 0xDB, 0x0A, 0xDB,
+0x2B, 0xDB, 0x98, 0x67, 0x8C, 0xDB, 0x9F, 0x67,
+0x8E, 0xDB, 0x12, 0xEC, 0x10, 0xED, 0x82, 0xDB,
+0xA3, 0xDB, 0x9A, 0xB8, 0x00, 0x65, 0x84, 0xDB,
+0x9B, 0xB8, 0x00, 0x65, 0x85, 0xDB, 0x8E, 0xB8,
+0x00, 0x65, 0x81, 0xDB, 0x8C, 0xB8, 0x00, 0x65,
+0x80, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xE8, 0xF3,
+0x18, 0x4B, 0x60, 0x9B, 0x9D, 0x67, 0x89, 0xDB,
+0x6A, 0x9B, 0xCF, 0xF7, 0x80, 0x44, 0x62, 0xEC,
+0x0D, 0x60, 0x77, 0xF0, 0x24, 0x6C, 0xA0, 0xF1,
+0x1C, 0x4C, 0x1D, 0xF4, 0x01, 0x6B, 0x60, 0xDC,
+0x10, 0xF0, 0x20, 0x6C, 0x65, 0xF7, 0x11, 0x4C,
+0x00, 0xEC, 0x00, 0x65, 0x40, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x28, 0xF7, 0x14, 0x4C, 0x00, 0xF4,
+0x00, 0x4C, 0xBC, 0x65, 0x82, 0x67, 0x40, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0xA8, 0xF3, 0x00, 0x4C,
+0x00, 0xF0, 0x20, 0x6D, 0xA0, 0xDC, 0x30, 0xF0,
+0x20, 0x6A, 0xE8, 0xF3, 0x18, 0x4A, 0x10, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x19, 0x4B, 0x00, 0xEB,
+0x61, 0x9A, 0x60, 0xDA, 0x49, 0x9B, 0xBA, 0x65,
+0xDF, 0xF7, 0x00, 0x03, 0x4C, 0xB8, 0x00, 0x65,
+0x00, 0xF0, 0x20, 0x6D, 0x05, 0x4D, 0xAF, 0xED,
+0xAC, 0xEA, 0xA0, 0x9B, 0x00, 0xF0, 0x20, 0x6C,
+0x04, 0x4C, 0x8C, 0xED, 0xAD, 0xEA, 0x82, 0x9B,
+0xA3, 0x9B, 0x32, 0xEC, 0x30, 0xED, 0x8E, 0x9B,
+0xFC, 0x65, 0x8C, 0x9B, 0x1C, 0x65, 0x84, 0x9B,
+0x5C, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x85, 0x9B, 0x7C, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x2B, 0x9B, 0x0A, 0x9B, 0xE9, 0x9B,
+0xC8, 0x9B, 0xA7, 0x9B, 0x86, 0x9B, 0x61, 0x9B,
+0xCB, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x8A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x7B, 0xB8, 0x00, 0x65, 0x5A, 0xB8, 0x00, 0x65,
+0x00, 0xBA, 0x00, 0x65, 0x5F, 0x67, 0x5A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x18,
+0xC9, 0x00, 0x00, 0x18, 0xA3, 0x0A, 0x5A, 0xB8,
+0x00, 0x65, 0x00, 0xEA, 0x6D, 0xB8, 0x00, 0xF0,
+0x20, 0x6A, 0x00, 0xF2, 0x00, 0x4A, 0x4F, 0xEA,
+0x4C, 0xEB, 0xAB, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x5F, 0x67, 0x5A, 0xB9, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x18, 0xB5, 0x0A,
+0x5A, 0xB8, 0x00, 0x65, 0x00, 0xEA, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xE8, 0x01,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xE2, 0x01,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x0E, 0x02,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x9C, 0x02,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x0E, 0x03,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xDC, 0x01,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0x11, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x80, 0xF7, 0x09, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1,
+0x4C, 0x9A, 0xA0, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF1, 0x50, 0x9A, 0x80, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF1, 0x54, 0x9A, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1, 0x58, 0x9A,
+0x40, 0x9A, 0x23, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF1, 0x5C, 0x9A, 0xA0, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF1, 0x40, 0x9A, 0x80, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF6, 0x48, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF0, 0x9C, 0x9C,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6,
+0x74, 0x9A, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x7C, 0xDA, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x02, 0x4A, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x19, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x8B, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x6C, 0x9A, 0x6C, 0x23, 0x01, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0xA9, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x4C, 0x9A, 0x02, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xF8, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x4C, 0x9A,
+0x04, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xDF, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x4C, 0x9A, 0x08, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xDB, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x4C, 0x9A, 0x10, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0xAA, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x4C, 0x9A, 0x20, 0x6B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xAB, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x4C, 0x9A,
+0x40, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xAC, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3,
+0x4C, 0x9A, 0x80, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xD7, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF3, 0x6C, 0x9B, 0xFF, 0x6A, 0x01, 0x4A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xCF, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF3, 0x6C, 0x9B,
+0x04, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xAD, 0x35, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF3, 0x6C, 0x9B, 0x08, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xAE, 0x35,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF3, 0x6C, 0x9B,
+0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xAF, 0x35, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x70, 0x9A, 0x3C, 0x23, 0x01, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xB5, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x50, 0x9A,
+0x02, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0xB0, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF3,
+0x70, 0x9B, 0x04, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x9D, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF3, 0x70, 0x9B,
+0x08, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x82, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x44, 0x9A, 0xC1, 0xF3, 0x70, 0x9B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0xB2, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x58, 0x9A, 0xC1, 0xF3, 0x70, 0x9B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x7E, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF3, 0x74, 0x9A, 0x55, 0x23,
+0x01, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0x9D, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x54, 0x9A, 0x02, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0x82, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x54, 0x9A,
+0x04, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C,
+0x00, 0x18, 0x9D, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x54, 0x9A, 0x08, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0x82, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x54, 0x9A,
+0x10, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x9D, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x54, 0x9A, 0x20, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x82, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF3, 0x54, 0x9A,
+0x40, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x9D, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF3, 0x54, 0x9A, 0x80, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0x82, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x1A, 0x4A,
+0x40, 0xDB, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x61, 0xF2, 0x11, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x5B, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x7C, 0x9A, 0xC0, 0xF0, 0x0D, 0x23, 0x02, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x03, 0x37, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF3, 0x7C, 0x9B, 0x04, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x03, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x7C, 0x9B, 0x08, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0x03, 0x37,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x7C, 0x9B,
+0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x03, 0x6C, 0x00, 0x18, 0x03, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF4,
+0x58, 0x9A, 0xA1, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0x03, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF5, 0x48, 0x9A, 0xA1, 0xF3, 0x7C, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x05, 0x6C, 0x00, 0x18,
+0x03, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF5, 0x4C, 0x9A, 0xA1, 0xF3,
+0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x06, 0x6C,
+0x00, 0x18, 0x03, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5, 0x50, 0x9A,
+0xA1, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x07, 0x6C, 0x00, 0x18, 0x03, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF0,
+0x5C, 0x9A, 0xA1, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x08, 0x6C, 0x00, 0x18, 0x03, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF1, 0x44, 0x9A, 0xA1, 0xF3, 0x7C, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x09, 0x6C, 0x00, 0x18,
+0x03, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF7, 0x5C, 0x9A, 0xA1, 0xF3,
+0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x0A, 0x6C,
+0x00, 0x18, 0x03, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF7, 0x54, 0x9A,
+0xA1, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x0B, 0x6C, 0x00, 0x18, 0x03, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x44, 0x9A, 0xA1, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x0C, 0x6C, 0x00, 0x18, 0x03, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x58, 0x9A, 0xA1, 0xF3, 0x7C, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x0D, 0x6C, 0x00, 0x18,
+0x03, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF6, 0x5C, 0x9A, 0xA1, 0xF3,
+0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x0E, 0x6C,
+0x00, 0x18, 0x03, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x50, 0x9A,
+0xA1, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x0F, 0x6C, 0x00, 0x18, 0x03, 0x37, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x61, 0xF2, 0x12, 0x4A, 0x40, 0xDB,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x21, 0xF4, 0x19, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x62, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3,
+0x70, 0x9A, 0x35, 0x23, 0x08, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0xDA, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0x50, 0x9A,
+0x10, 0x6B, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x65, 0x37, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3,
+0x50, 0x9A, 0x20, 0x6B, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0x61, 0x37, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF3, 0x50, 0x9A, 0x40, 0x6B, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x9F, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF3, 0x70, 0x9B, 0xFF, 0x6A,
+0x01, 0x4A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x5D, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x70, 0x9B, 0x00, 0xF2, 0x00, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x59, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0x74, 0x9A, 0x80, 0xF0,
+0x07, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0x44, 0x9A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x4C, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x5C, 0x9A,
+0x81, 0xF3, 0x74, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0x4C, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF7,
+0x54, 0x9A, 0x81, 0xF3, 0x74, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0x4C, 0x36,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x44, 0x9A, 0x81, 0xF3, 0x74, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C, 0x00, 0x18,
+0x4C, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x58, 0x9A, 0x81, 0xF3,
+0x74, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x4C, 0x36, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5, 0x48, 0x9A,
+0x81, 0xF3, 0x74, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x00, 0x6C, 0x00, 0x18, 0x35, 0x36, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5,
+0x4C, 0x9A, 0x81, 0xF3, 0x74, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0xF9, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF5, 0x50, 0x9A, 0x81, 0xF3, 0x74, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x1B, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF0, 0x5C, 0x9A, 0x81, 0xF3,
+0x74, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0xE3, 0x35, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x74, 0x9B, 0x08, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0x55, 0x37,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF4, 0x58, 0x9A, 0x81, 0xF3, 0x74, 0x9B,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xA1, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x8A, 0x9A, 0x35, 0x24, 0x01, 0x6B, 0x6C, 0xEC,
+0x06, 0x24, 0x9F, 0x9A, 0x6D, 0xEC, 0x9F, 0xDA,
+0x00, 0x6C, 0x00, 0x18, 0xA6, 0x37, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF3, 0x78, 0x9B, 0xFF, 0x6A,
+0x01, 0x4A, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0xA6, 0x37, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x78, 0x9B, 0x00, 0xF2, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0xA6, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x78, 0x9B, 0x00, 0xF4, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0xA6, 0x37,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x78, 0x9B,
+0x01, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0xA6, 0x37, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF3, 0x7C, 0x9A, 0x6D, 0x23,
+0x01, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x00, 0x18, 0x4C, 0x37, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x7C, 0x9B, 0xFF, 0x6A, 0x01, 0x4A,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x4C, 0x37, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3,
+0x7C, 0x9B, 0x00, 0xF2, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x02, 0x6C, 0x00, 0x18, 0x4C, 0x37,
+0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF3, 0x7C, 0x9B,
+0x00, 0xF4, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x03, 0x6C, 0x00, 0x18, 0x4C, 0x37, 0x30, 0xF0,
+0x20, 0x6B, 0x81, 0xF3, 0x7C, 0x9B, 0x01, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x4C, 0x37, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF3, 0x7C, 0x9B, 0x10, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x66, 0x05, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF4, 0x50, 0x9A, 0x81, 0xF3,
+0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0x66, 0x05, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF4, 0x54, 0x9A,
+0x81, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0x66, 0x05, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF4,
+0x5C, 0x9A, 0x81, 0xF3, 0x7C, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x66, 0x05,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF3, 0x5C, 0x9A,
+0x00, 0x52, 0x03, 0x60, 0x04, 0x6C, 0x00, 0x18,
+0x66, 0x05, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x60, 0x9A, 0xC0, 0xF0, 0x18, 0x23, 0x01, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x35, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x40, 0x9A, 0x02, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0xF9, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0x40, 0x9A, 0x04, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C, 0x00, 0x18,
+0x1B, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x40, 0x9A, 0x08, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0xE3, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0x40, 0x9A, 0x10, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x35, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x40, 0x9A, 0x20, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0xF9, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF3, 0x40, 0x9A, 0x40, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0x1B, 0x36, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF3,
+0x40, 0x9A, 0x80, 0x6B, 0x6C, 0xEA, 0x03, 0x22,
+0x02, 0x6C, 0x00, 0x18, 0xE3, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF3, 0x60, 0x9B, 0xFF, 0x6A,
+0x01, 0x4A, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0x35, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF3, 0x60, 0x9B, 0x00, 0xF2, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C, 0x00, 0x18,
+0xF9, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x60, 0x9B, 0x00, 0xF4, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x03, 0x6C, 0x00, 0x18, 0x1B, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x60, 0x9B,
+0x01, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x03, 0x6C, 0x00, 0x18, 0xE3, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0xA1, 0xF3, 0x60, 0x9B, 0x02, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C,
+0x00, 0x18, 0x35, 0x36, 0x30, 0xF0, 0x20, 0x6B,
+0xA1, 0xF3, 0x60, 0x9B, 0x04, 0xF0, 0x00, 0x6A,
+0x6C, 0xEA, 0x03, 0x22, 0x04, 0x6C, 0x00, 0x18,
+0xF9, 0x35, 0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3,
+0x60, 0x9B, 0x08, 0xF0, 0x00, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x04, 0x6C, 0x00, 0x18, 0x1B, 0x36,
+0x30, 0xF0, 0x20, 0x6B, 0xA1, 0xF3, 0x60, 0x9B,
+0x10, 0xF0, 0x00, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0xE3, 0x35, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF4,
+0x58, 0x9A, 0xA1, 0xF3, 0x60, 0x9B, 0x6C, 0xEA,
+0x03, 0x22, 0x01, 0x6C, 0x00, 0x18, 0xDA, 0x35,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF5, 0x48, 0x9A, 0xA1, 0xF3, 0x60, 0x9B,
+0x6C, 0xEA, 0x03, 0x22, 0x02, 0x6C, 0x00, 0x18,
+0xDA, 0x35, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF5, 0x4C, 0x9A, 0xA1, 0xF3,
+0x60, 0x9B, 0x6C, 0xEA, 0x03, 0x22, 0x03, 0x6C,
+0x00, 0x18, 0xDA, 0x35, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5, 0x50, 0x9A,
+0xA1, 0xF3, 0x60, 0x9B, 0x6C, 0xEA, 0x03, 0x22,
+0x04, 0x6C, 0x00, 0x18, 0xDA, 0x35, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x21, 0xF4, 0x1A, 0x4A, 0x40, 0xDB,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x4D, 0xB8, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0xF2, 0x00, 0x6B, 0x6D, 0xEA, 0xAA, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6, 0x64, 0x9B,
+0xFF, 0x6A, 0x8C, 0xEA, 0x80, 0xA3, 0x10, 0x6B,
+0x8C, 0xEB, 0x04, 0x23, 0x7F, 0x4A, 0x07, 0x4A,
+0x86, 0x6B, 0x31, 0x10, 0x7F, 0x4A, 0x09, 0x4A,
+0x88, 0x6B, 0x15, 0x10, 0x1F, 0xF7, 0x00, 0x6C,
+0x6C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5,
+0x94, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF5, 0x98, 0x9C, 0xC0, 0xA5, 0x91, 0xE3,
+0x01, 0x4D, 0xC0, 0xC4, 0x01, 0x4B, 0x4A, 0xEB,
+0xE9, 0x61, 0x20, 0xE8, 0x1F, 0xF7, 0x00, 0x6C,
+0x6C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5,
+0x94, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF5, 0x98, 0x9C, 0xC0, 0xA5, 0x91, 0xE3,
+0x01, 0x4D, 0xC0, 0xC4, 0x01, 0x4B, 0x4A, 0xEB,
+0xE9, 0x61, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xED,
+0xFF, 0x75, 0x4C, 0xEC, 0xCC, 0xEA, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x71, 0xE4, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x71, 0xE4, 0x63, 0xF3,
+0x78, 0xA4, 0xAC, 0xEA, 0xAF, 0xED, 0x6C, 0xED,
+0xAD, 0xEA, 0x63, 0xF3, 0x58, 0xC4, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0xFF, 0x74, 0xAC, 0xEA,
+0x05, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0xE4, 0xF6,
+0x46, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x63, 0xF3, 0xB6, 0xA3,
+0x8C, 0xEA, 0x8F, 0xEC, 0xAC, 0xEC, 0x8D, 0xEA,
+0x63, 0xF3, 0x56, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xF7, 0x63, 0x11, 0x62, 0x10, 0xD1, 0x0F, 0xD0,
+0x40, 0xA4, 0x08, 0xD2, 0x08, 0x93, 0x1F, 0x6A,
+0x4C, 0xEB, 0x08, 0xD3, 0x42, 0xA4, 0x61, 0xA4,
+0x0D, 0xD2, 0x43, 0xA4, 0x84, 0xA4, 0x09, 0xD4,
+0x08, 0x94, 0x08, 0x5C, 0x80, 0xF0, 0x0C, 0x60,
+0x84, 0x31, 0x09, 0x94, 0x01, 0x2C, 0x23, 0x22,
+0xFF, 0x68, 0x0C, 0xEA, 0x0C, 0xEB, 0xA2, 0x67,
+0xC3, 0x67, 0x91, 0x67, 0x0B, 0xD2, 0x0C, 0xD3,
+0x00, 0x18, 0x6B, 0x04, 0x09, 0x93, 0x0D, 0x94,
+0x41, 0x41, 0x0C, 0xEA, 0x0C, 0xEB, 0x8C, 0xE8,
+0xA3, 0x67, 0x82, 0x67, 0xD0, 0x67, 0x0A, 0xD2,
+0x09, 0xD3, 0x00, 0x18, 0x6B, 0x04, 0x0B, 0x95,
+0x0C, 0x96, 0x91, 0x67, 0x01, 0x6F, 0x00, 0x18,
+0x71, 0x05, 0x0A, 0x94, 0x09, 0x95, 0xD0, 0x67,
+0x02, 0x6F, 0x00, 0x18, 0x71, 0x05, 0x0F, 0x59,
+0x08, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x28, 0x33,
+0x00, 0xF3, 0x14, 0x4A, 0x69, 0xE2, 0x40, 0x9A,
+0x00, 0xEA, 0x00, 0x6A, 0x44, 0x10, 0xD0, 0xF4,
+0x44, 0x41, 0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x5C, 0x9A, 0x34, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x40, 0x9A, 0x2F, 0x10, 0x80, 0xF4,
+0x44, 0x41, 0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x44, 0x9A, 0x24, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x48, 0x9A, 0x1F, 0x10, 0xC0, 0xF4,
+0x48, 0x41, 0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x4C, 0x9A, 0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x50, 0x9A, 0x0F, 0x10, 0x70, 0xF4,
+0x48, 0x41, 0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x54, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x58, 0x9A, 0x49, 0xE1, 0x60, 0xAA,
+0xFF, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA, 0x7D, 0x67,
+0x53, 0xC3, 0x42, 0x32, 0x54, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x45, 0xE1,
+0x63, 0xF3, 0x58, 0xA1, 0x55, 0xC3, 0x63, 0xF3,
+0x59, 0xA1, 0x56, 0xC3, 0x83, 0xF3, 0x48, 0xA1,
+0x57, 0xC3, 0x83, 0xF3, 0x49, 0xA1, 0x58, 0xC3,
+0x9D, 0x67, 0x21, 0x6A, 0x50, 0xC4, 0x07, 0x6A,
+0x4F, 0xCC, 0x47, 0x44, 0x19, 0x4A, 0x40, 0xA2,
+0x52, 0xC4, 0x04, 0x04, 0x00, 0x18, 0x2B, 0x2D,
+0x11, 0x97, 0x10, 0x91, 0x0F, 0x90, 0x09, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x01, 0xA4, 0x20, 0xA4,
+0x09, 0x20, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x78, 0x04, 0x90, 0x67, 0xB1, 0x67, 0x53, 0x6E,
+0x00, 0x18, 0xC5, 0x3A, 0x7D, 0x67, 0x20, 0x6A,
+0x50, 0xC3, 0x03, 0x6A, 0x4F, 0xCB, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x44, 0x9A, 0x9D, 0x67,
+0x40, 0xA2, 0x52, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x63, 0xF3, 0x76, 0xA2,
+0x63, 0xF3, 0x57, 0xA2, 0x73, 0xC4, 0x54, 0xC4,
+0x04, 0x04, 0x00, 0x18, 0x2B, 0x2D, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x40, 0xA4, 0xA0, 0xF0, 0xDD, 0xA3, 0x7F, 0x68,
+0x5E, 0x32, 0x5C, 0x32, 0x0C, 0xEE, 0x4D, 0xEE,
+0xA0, 0xF0, 0xDD, 0xC3, 0xA0, 0xA4, 0x01, 0x6A,
+0x41, 0x6F, 0xBA, 0x35, 0x4C, 0xED, 0xEB, 0xEF,
+0xB8, 0x35, 0xCC, 0xEF, 0xAD, 0xEF, 0xA0, 0xF0,
+0xFD, 0xC3, 0xA0, 0xA4, 0x21, 0x6E, 0xCB, 0xEE,
+0xB6, 0x35, 0x4C, 0xED, 0xB4, 0x35, 0xEC, 0xEE,
+0xAD, 0xEE, 0xA0, 0xF0, 0xDD, 0xC3, 0xA0, 0xA4,
+0x11, 0x6F, 0xEB, 0xEF, 0xB2, 0x35, 0x4C, 0xED,
+0xB0, 0x35, 0xCC, 0xEF, 0xAD, 0xEF, 0xA0, 0xF0,
+0xFD, 0xC3, 0xA0, 0xA4, 0x10, 0x6E, 0x0F, 0x69,
+0xCB, 0xEE, 0x2C, 0xED, 0xEC, 0xEE, 0xAD, 0xEE,
+0xA0, 0xF0, 0xDD, 0xC3, 0xE1, 0xA4, 0xA7, 0x67,
+0xA0, 0xF0, 0xFE, 0xA3, 0x0C, 0xED, 0xFD, 0x65,
+0x1F, 0x65, 0x80, 0x6D, 0xF8, 0x67, 0xAB, 0xED,
+0xEC, 0xED, 0xFF, 0x67, 0xED, 0xED, 0xA0, 0xF0,
+0xBE, 0xC3, 0xE2, 0xA4, 0x0C, 0xED, 0xA0, 0xF0,
+0xFF, 0xC3, 0xE1, 0xA4, 0xFE, 0x37, 0xFC, 0x37,
+0xED, 0xED, 0xA0, 0xF0, 0xBE, 0xC3, 0xC0, 0xF0,
+0xE0, 0xA3, 0x83, 0xA4, 0x02, 0x6D, 0xAB, 0xED,
+0x4C, 0xEC, 0xEC, 0xED, 0x8D, 0xED, 0xC0, 0xF0,
+0xA0, 0xC3, 0xA0, 0xF0, 0xBD, 0xA3, 0x86, 0x67,
+0x2C, 0xEC, 0xBA, 0x35, 0x4E, 0xED, 0x4C, 0xED,
+0x00, 0x18, 0x71, 0x32, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x10, 0x48, 0x41, 0xF4, 0x17, 0x4C,
+0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0xE0, 0xF0,
+0x87, 0xA0, 0x00, 0x18, 0x77, 0x34, 0x24, 0xF1,
+0x54, 0xA0, 0x1F, 0x6B, 0x01, 0x6C, 0x4A, 0x32,
+0x6C, 0xEA, 0xE0, 0xF0, 0x67, 0xA0, 0x47, 0xEB,
+0x8C, 0xEA, 0x03, 0x22, 0x24, 0xF1, 0x75, 0xC0,
+0x04, 0x10, 0x01, 0x6A, 0x4B, 0xEA, 0x24, 0xF1,
+0x55, 0xC0, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x24, 0xF1, 0x74, 0xA0, 0x02, 0x6A,
+0x6C, 0xEA, 0x1A, 0x22, 0x03, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x24, 0xF1, 0x54, 0xC0, 0x00, 0x18,
+0xE9, 0x3A, 0x04, 0xD2, 0x04, 0x93, 0x24, 0xF1,
+0x58, 0x98, 0x6E, 0xEA, 0x03, 0x22, 0x04, 0x94,
+0x00, 0x18, 0x05, 0x3B, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x24, 0xF1, 0x94, 0xA2,
+0x02, 0x6B, 0x8D, 0xEB, 0x24, 0xF1, 0x74, 0xC2,
+0x07, 0x97, 0x06, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF3, 0x10, 0x48, 0x41, 0xF4,
+0x02, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0xC0, 0xF0, 0x92, 0xA0, 0xC0, 0xF0, 0x53, 0xA0,
+0x01, 0x69, 0xA4, 0x67, 0xFF, 0x4A, 0x2C, 0xEC,
+0xB6, 0x35, 0x23, 0xF4, 0x54, 0xC0, 0x00, 0x18,
+0x56, 0x15, 0xC0, 0xF0, 0x52, 0xA0, 0x4C, 0xE9,
+0x06, 0x29, 0x10, 0xF0, 0x20, 0x6C, 0xEA, 0xF6,
+0x1D, 0x4C, 0x00, 0x18, 0x53, 0x3B, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x09, 0x16,
+0x90, 0x67, 0x00, 0x18, 0x87, 0x3F, 0x01, 0x6C,
+0x00, 0x18, 0x13, 0x14, 0x90, 0x67, 0x00, 0x18,
+0xA2, 0x15, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x27, 0x67,
+0x4C, 0xE9, 0x6F, 0x41, 0x4C, 0xEB, 0x04, 0x67,
+0x02, 0x5B, 0x4C, 0xE8, 0x4C, 0xED, 0x4C, 0xEE,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0xA8, 0x39,
+0x10, 0x58, 0x55, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x08, 0x33, 0xE0, 0xF3, 0x14, 0x4A, 0x69, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0xD0, 0xF4, 0x44, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x7C, 0x9A,
+0x34, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x60, 0x9A, 0x2F, 0x10, 0x80, 0xF4, 0x44, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x64, 0x9A,
+0x24, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x68, 0x9A, 0x1F, 0x10, 0xC0, 0xF4, 0x48, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x6C, 0x9A,
+0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x70, 0x9A, 0x0F, 0x10, 0x70, 0xF4, 0x48, 0x40,
+0x1F, 0xF7, 0x00, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7, 0x74, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x78, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x6D, 0xE0, 0x41, 0xE0, 0x63, 0xF3,
+0x98, 0xA0, 0x83, 0xF3, 0x48, 0xA0, 0x8D, 0xEA,
+0xFF, 0x6C, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xE4, 0xF6, 0x25, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x30, 0xF0, 0x20, 0x6A, 0x10, 0xF0, 0x20, 0x6B,
+0x40, 0xF0, 0x08, 0x4A, 0x60, 0xF7, 0x01, 0x4B,
+0x62, 0xDA, 0x10, 0xF0, 0x20, 0x6B, 0x40, 0xF7,
+0x11, 0x4B, 0x63, 0xDA, 0x10, 0xF0, 0x20, 0x6B,
+0x40, 0xF7, 0x01, 0x4B, 0x64, 0xDA, 0x10, 0xF0,
+0x20, 0x6B, 0x20, 0xF7, 0x11, 0x4B, 0x65, 0xDA,
+0x10, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x01, 0x4B,
+0x66, 0xDA, 0x10, 0xF0, 0x20, 0x6B, 0x00, 0xF7,
+0x11, 0x4B, 0x67, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0x6B, 0x63, 0xF3, 0x70, 0xC2, 0x63, 0xF3,
+0x71, 0xC2, 0x63, 0xF3, 0x72, 0xC2, 0x63, 0xF3,
+0x73, 0xC2, 0x42, 0xF4, 0x10, 0x6A, 0x1F, 0xF7,
+0x00, 0x6B, 0x4C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x01, 0x60, 0x05, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF5, 0x74, 0x9B, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF5, 0x78, 0x9B, 0x6D, 0xE2,
+0x04, 0x4A, 0x00, 0x6C, 0x62, 0xF4, 0x00, 0x72,
+0x80, 0xDB, 0xE9, 0x61, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x5C, 0x9A, 0x03, 0x6D, 0xFF, 0x6B,
+0x80, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x40, 0x9A, 0x00, 0xF5, 0x82, 0x34, 0xAC, 0xEC,
+0x40, 0x9A, 0x01, 0x74, 0x42, 0x32, 0x52, 0x32,
+0xAC, 0xEA, 0x06, 0x60, 0x0A, 0x2C, 0x02, 0x5A,
+0x28, 0x6C, 0x0D, 0x60, 0x50, 0x6C, 0x0B, 0x10,
+0x02, 0x5A, 0x14, 0x6C, 0x08, 0x60, 0x28, 0x6C,
+0x04, 0x10, 0x02, 0x5A, 0x0A, 0x6C, 0x03, 0x60,
+0x14, 0x6C, 0x84, 0xEA, 0x6C, 0xEC, 0x00, 0x18,
+0x18, 0x08, 0x00, 0x18, 0x56, 0x29, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x74, 0x9B, 0x00, 0x6A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x70, 0x9B, 0x40, 0xC3, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x00, 0x69, 0xA0, 0xF0,
+0x24, 0xD8, 0xA0, 0xF1, 0x2C, 0xC0, 0x00, 0x18,
+0xB0, 0x05, 0x00, 0x18, 0xBD, 0x06, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0x43, 0xF2,
+0x28, 0xC0, 0xE4, 0xF6, 0x08, 0x4A, 0xE4, 0xF6,
+0x18, 0x4C, 0x00, 0x6B, 0x60, 0xC2, 0x70, 0xC2,
+0x01, 0x4A, 0x62, 0x67, 0x8E, 0xEB, 0xF9, 0x2B,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x63, 0xF3, 0x75, 0xC2, 0x63, 0xF3, 0x76, 0xC2,
+0x63, 0xF3, 0x77, 0xC2, 0x63, 0xF3, 0x74, 0xC2,
+0x00, 0x18, 0x41, 0x08, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xC2, 0x05,
+0x00, 0x18, 0x25, 0x06, 0x00, 0x18, 0xF5, 0x48,
+0x00, 0x18, 0x88, 0x16, 0x00, 0x18, 0x81, 0x16,
+0x00, 0x18, 0x25, 0x22, 0x00, 0x18, 0x6A, 0x1C,
+0x00, 0x18, 0xB2, 0x1E, 0x00, 0x18, 0x74, 0x47,
+0x00, 0x18, 0x6B, 0x3C, 0x00, 0x18, 0x26, 0x33,
+0x00, 0x18, 0x4E, 0x3C, 0x00, 0x18, 0x36, 0x3C,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x64, 0x9A,
+0xFF, 0x6C, 0x04, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x00, 0x6B, 0xA0, 0xF6,
+0x6E, 0xC2, 0xA0, 0xF6, 0x6F, 0xC2, 0xA0, 0xF1,
+0x6C, 0xC2, 0xA0, 0xF1, 0x6D, 0xC2, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x46, 0xF6,
+0x49, 0xA0, 0x0B, 0x2A, 0xE0, 0xF3, 0x1A, 0x6C,
+0x04, 0x05, 0x00, 0x18, 0xFA, 0x43, 0x9D, 0x67,
+0x70, 0xA4, 0x07, 0x6A, 0x6C, 0xEA, 0x46, 0xF6,
+0x49, 0xC0, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x46, 0xF6, 0x4B, 0xA0, 0x0A, 0x2A,
+0xE0, 0xF3, 0x1A, 0x6C, 0x04, 0x05, 0x00, 0x18,
+0xFA, 0x43, 0x7D, 0x67, 0x50, 0xA3, 0x56, 0x32,
+0x46, 0xF6, 0x4B, 0xC0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x46, 0xF6, 0x4C, 0xA0,
+0x0B, 0x2A, 0xE0, 0xF3, 0x1D, 0x6C, 0x04, 0x05,
+0x00, 0x18, 0xFA, 0x43, 0x9D, 0x67, 0x70, 0xA4,
+0x03, 0x6A, 0x6C, 0xEA, 0x46, 0xF6, 0x4C, 0xC0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x46, 0xF6, 0x4D, 0xA0, 0x0C, 0x2A, 0xE0, 0xF3,
+0x1D, 0x6C, 0x04, 0x05, 0x00, 0x18, 0xFA, 0x43,
+0x7D, 0x67, 0x50, 0xA3, 0x30, 0x6B, 0x6C, 0xEA,
+0x53, 0x32, 0x46, 0xF6, 0x4D, 0xC0, 0x07, 0x97,
+0x06, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x04, 0x01, 0x04, 0x67, 0xB1, 0x67, 0xE0, 0xF3,
+0x10, 0x6C, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x11, 0x6C,
+0x40, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x12, 0x6C,
+0x41, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x13, 0x6C,
+0x42, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x1C, 0x6C,
+0x43, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0x09, 0x97, 0x08, 0x91, 0x44, 0xC0,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x04, 0x01, 0x04, 0x67, 0xB1, 0x67, 0xE0, 0xF3,
+0x14, 0x6C, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x15, 0x6C,
+0x40, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x16, 0x6C,
+0x41, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x17, 0x6C,
+0x42, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x18, 0x6C,
+0x43, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0xB1, 0x67, 0xE0, 0xF3, 0x19, 0x6C,
+0x44, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x7D, 0x67,
+0x50, 0xA3, 0x09, 0x97, 0x08, 0x91, 0x45, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x46, 0xF6, 0x6A, 0xA2, 0x46, 0xF6, 0x8B, 0xA2,
+0x6C, 0x33, 0x94, 0x34, 0x8D, 0xEB, 0x46, 0xF6,
+0x89, 0xA2, 0x8D, 0xEB, 0x66, 0xC0, 0x46, 0xF6,
+0x6C, 0xA2, 0x46, 0xF6, 0x4D, 0xA2, 0x68, 0x33,
+0x58, 0x32, 0x4D, 0xEB, 0x33, 0x6A, 0x4D, 0xEB,
+0x67, 0xC0, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD0, 0x04, 0x00,
+0x90, 0x67, 0x00, 0x18, 0x6E, 0x06, 0xA0, 0xF1,
+0x02, 0x6A, 0x1F, 0xF7, 0x00, 0x6B, 0x4C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x05, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF5, 0x74, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF5,
+0x78, 0x9B, 0x80, 0xA0, 0x6D, 0xE2, 0x01, 0x4A,
+0xA0, 0xF1, 0x0A, 0x72, 0x80, 0xC3, 0x01, 0x48,
+0xE8, 0x61, 0x04, 0x00, 0x90, 0x67, 0x00, 0x18,
+0x54, 0x06, 0xA0, 0xF1, 0x0A, 0x6A, 0x1F, 0xF7,
+0x00, 0x6B, 0x4C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x01, 0x60, 0x05, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF5, 0x74, 0x9B, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF5, 0x78, 0x9B, 0x80, 0xA0,
+0x6D, 0xE2, 0x01, 0x4A, 0xA0, 0xF1, 0x0F, 0x72,
+0x80, 0xC3, 0x01, 0x48, 0xE8, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x50, 0x9A, 0x19, 0x6B,
+0x60, 0xC2, 0x09, 0x97, 0x08, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x46, 0xF6, 0x68, 0xA0,
+0x01, 0x6A, 0x04, 0x01, 0x6D, 0xEA, 0x02, 0x6B,
+0x6D, 0xEA, 0x04, 0x6B, 0x6D, 0xEA, 0x08, 0x6B,
+0x6D, 0xEA, 0xE0, 0xF3, 0x1B, 0x6C, 0xB1, 0x67,
+0x46, 0xF6, 0x48, 0xC0, 0x00, 0x18, 0xFA, 0x43,
+0x9D, 0x67, 0x70, 0xA4, 0x07, 0x6A, 0xE0, 0xF3,
+0x1D, 0x6C, 0x6C, 0xEA, 0x46, 0xF6, 0x49, 0xC0,
+0x18, 0x6A, 0x6C, 0xEA, 0x4F, 0x32, 0x76, 0x33,
+0xB1, 0x67, 0x46, 0xF6, 0x6B, 0xC0, 0x46, 0xF6,
+0x4A, 0xC0, 0x00, 0x18, 0xFA, 0x43, 0x5D, 0x67,
+0x70, 0xA2, 0x0C, 0x6A, 0x6C, 0xEA, 0x4B, 0x32,
+0x7A, 0x33, 0x46, 0xF6, 0x4C, 0xC0, 0x46, 0xF6,
+0x6D, 0xC0, 0x00, 0x18, 0x2C, 0x06, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x50, 0x9A, 0x60, 0xA2,
+0xFF, 0x6A, 0x6C, 0xEA, 0xFD, 0x72, 0x02, 0x61,
+0x00, 0x18, 0x98, 0x06, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF4, 0x5C, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x98, 0x9A,
+0xFF, 0x6B, 0x20, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x88, 0x9A, 0x08, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x7C, 0x9A, 0xFD, 0x6A, 0xFF, 0x6C,
+0xA0, 0xA3, 0xAC, 0xEA, 0x40, 0xC3, 0x40, 0xA3,
+0x01, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x52, 0x9B, 0x8D, 0xEA,
+0x52, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x60, 0x9B, 0x80, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x64, 0x9B, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0xB2, 0x9B, 0x8F, 0xEA, 0xAC, 0xEA, 0x52, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x64, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x40, 0x9A, 0x80, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x05, 0x5C, 0x5E, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0x40, 0xF3, 0x10, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x50, 0x9B, 0xAD, 0xEA, 0x61, 0xF3,
+0x50, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF7,
+0x60, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x68, 0x9B, 0x32, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x41, 0x9B,
+0xAD, 0xEA, 0x41, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF5, 0x7C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x6C, 0x9B, 0x21, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x42, 0x9B, 0xAD, 0xEA, 0x42, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x70, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x74, 0x9B,
+0x10, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x43, 0x9B, 0xAD, 0xEA, 0x43, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x78, 0x9B,
+0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x7C, 0x9B, 0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x44, 0x9B,
+0xAD, 0xEA, 0x44, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x60, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x64, 0x9B, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x05, 0x5C, 0x63, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x88, 0x34, 0x60, 0xF3,
+0x04, 0x4A, 0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x90, 0x9B,
+0xAF, 0xEA, 0x8C, 0xEA, 0x61, 0xF3, 0x50, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x68, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x40, 0x9A, 0x35, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x81, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x41, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x6C, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x5C, 0x9A, 0x23, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x82, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x42, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x74, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x50, 0x9A, 0x11, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x83, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x43, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x7C, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF0, 0x58, 0x9A, 0xA0, 0xDA,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x84, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA,
+0x44, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x64, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x40, 0x9A, 0xA0, 0xDA, 0x20, 0xE8,
+0x01, 0x74, 0x15, 0x60, 0x03, 0x24, 0x02, 0x74,
+0x23, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x54, 0x9B, 0xAD, 0xEA,
+0x54, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5,
+0x78, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x68, 0x9B, 0x21, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x55, 0x9B,
+0xAD, 0xEA, 0x55, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x6C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x70, 0x9B, 0x10, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x56, 0x9B, 0xAD, 0xEA, 0x56, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x74, 0x9B, 0xA0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x78, 0x9B,
+0x40, 0xDB, 0x20, 0xE8, 0x01, 0x74, 0x16, 0x60,
+0x03, 0x24, 0x02, 0x74, 0x25, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x94, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x54, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x68, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x58, 0x9A, 0x23, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x95, 0x9B, 0xAF, 0xEA,
+0x8C, 0xEA, 0x55, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x70, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x4C, 0x9A, 0x11, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x96, 0x9B, 0xAF, 0xEA, 0x8C, 0xEA, 0x56, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x78, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x54, 0x9A, 0xA0, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF0, 0x88, 0x9C,
+0x00, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x50, 0xDB, 0x61, 0xF3, 0x10, 0x4B, 0x41, 0xDB,
+0x42, 0xDB, 0x43, 0xDB, 0x44, 0xDB, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF0, 0x8C, 0x9C,
+0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF0,
+0x94, 0x9C, 0x40, 0xDC, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF0, 0x9C, 0x9C, 0x40, 0xDC, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF0, 0x84, 0x9C, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0, 0x88, 0x9C,
+0x54, 0xDB, 0x55, 0xDB, 0x40, 0xDC, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF0, 0x90, 0x9C, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0, 0x98, 0x9C,
+0x56, 0xDB, 0x40, 0xDC, 0x52, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x64, 0x9B, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF7, 0x60, 0x9B, 0x01, 0x6A, 0x4B, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5,
+0x7C, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x70, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x78, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0, 0x60, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5,
+0x78, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF0, 0x6C, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x41, 0xF0, 0x74, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x60, 0x9B,
+0x40, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0xBC, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF3, 0x10, 0x6E, 0x61, 0xF3, 0xD0, 0xDB,
+0x01, 0xF7, 0x01, 0x6A, 0x61, 0xF3, 0x10, 0x4B,
+0x00, 0x6C, 0x42, 0xDB, 0x43, 0xDB, 0xA1, 0xDB,
+0x84, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0,
+0x68, 0x9B, 0xC0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF0, 0x6C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF0, 0x74, 0x9B, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF0, 0x7C, 0x9B,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x44, 0x9A, 0x80, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0x6B, 0x72, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x44, 0x9A, 0x60, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0, 0x80, 0x9B,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA0, 0xF1, 0x0E, 0x6D, 0xFF, 0x6B, 0xB4, 0xDA,
+0x95, 0xDA, 0x76, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF0, 0x48, 0x9A, 0xA0, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x50, 0x9A, 0x80, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0, 0x58, 0x9A,
+0x60, 0xDA, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xAC, 0x07, 0x00, 0x18, 0xCB, 0x07,
+0x00, 0x18, 0xE3, 0x07, 0x00, 0x18, 0x00, 0x08,
+0x00, 0x18, 0xFA, 0x07, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x0B, 0x2C,
+0x00, 0x18, 0x41, 0x2C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x04, 0x9A, 0x00, 0x6D, 0x02, 0xF0, 0x00, 0x6E,
+0x90, 0x67, 0x00, 0x18, 0x6B, 0x2C, 0x04, 0x6A,
+0x40, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x48, 0x9A, 0x20, 0x48, 0x0E, 0xEA, 0xF7, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x8C, 0x9A,
+0x00, 0x6D, 0x00, 0xF4, 0x00, 0x6E, 0x00, 0x18,
+0x6B, 0x2C, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x47, 0x08, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x42, 0xF6, 0x40, 0xC3,
+0x00, 0x6A, 0x42, 0xF6, 0x41, 0xC3, 0x00, 0x18,
+0xF1, 0x06, 0x00, 0x18, 0xAD, 0x08, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0x50, 0x9A, 0x3F, 0x6B,
+0x60, 0xC2, 0x00, 0x18, 0xE2, 0x06, 0x00, 0x18,
+0xE6, 0x06, 0x00, 0x18, 0xD8, 0x37, 0x00, 0x18,
+0x1D, 0x08, 0x00, 0x18, 0x51, 0x08, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x00, 0x6B, 0xA3, 0xF3,
+0x6C, 0xC2, 0x05, 0x6B, 0xA3, 0xF3, 0x74, 0xCA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x48, 0x9A, 0xFF, 0xF7, 0x1F, 0x6B,
+0x40, 0xAA, 0x4C, 0xEB, 0x62, 0x33, 0x07, 0x6A,
+0x72, 0x33, 0x4C, 0xEB, 0x02, 0x6A, 0x04, 0x23,
+0x01, 0x73, 0x01, 0x6A, 0x01, 0x60, 0x03, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x54, 0x9A, 0xE5, 0xF6, 0x1F, 0x6B,
+0xFF, 0x6C, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0x58, 0x9A, 0x10, 0x6B, 0x40, 0x6D,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF1,
+0x5C, 0x9A, 0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x40, 0x9A, 0x60, 0xA2,
+0x8C, 0xEB, 0xAD, 0xEB, 0x8C, 0xEB, 0x60, 0xC2,
+0x60, 0xA2, 0x07, 0x6D, 0x8C, 0xEB, 0xAD, 0xEB,
+0x8C, 0xEB, 0x60, 0xC2, 0x80, 0xA2, 0xEF, 0x6B,
+0x8C, 0xEB, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x44, 0x9A, 0x00, 0xF2, 0x01, 0x6C,
+0x8B, 0xEC, 0x60, 0x9A, 0x8C, 0xEB, 0x60, 0xDA,
+0x60, 0x9A, 0x00, 0xF1, 0x00, 0x4C, 0x8C, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF5,
+0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF4,
+0x90, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1, 0x48, 0x9A,
+0x60, 0xA2, 0x04, 0x5B, 0x02, 0x60, 0x04, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x40, 0x9A, 0x7F, 0x6B, 0x80, 0xA2, 0x8C, 0xEB,
+0x60, 0xC2, 0x80, 0xA2, 0xF7, 0x6B, 0x8C, 0xEB,
+0x60, 0xC2, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x6C, 0x10, 0xF0, 0x00, 0x6D, 0x00, 0x18,
+0xF9, 0x3F, 0x05, 0x97, 0x01, 0x5A, 0x58, 0x67,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x04, 0xF2,
+0x0D, 0x4A, 0x40, 0xDB, 0x00, 0x68, 0x2E, 0x10,
+0x82, 0xF3, 0x08, 0x70, 0x1A, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A, 0x02, 0xF0,
+0x00, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x7C, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x58, 0x9A, 0x03, 0x6B, 0x6B, 0xEB, 0x60, 0xC2,
+0x15, 0x10, 0xFF, 0xF7, 0x1F, 0x6A, 0x01, 0x48,
+0x4C, 0xE8, 0x14, 0x6C, 0x00, 0x18, 0x4C, 0x2C,
+0x33, 0x58, 0x08, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x50, 0x9A, 0x60, 0xA2, 0x08, 0x6A,
+0x6C, 0xEA, 0x04, 0x2A, 0x00, 0x18, 0x7D, 0x08,
+0x01, 0x72, 0xCE, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x58, 0x9A, 0x02, 0x6B, 0x6B, 0xEB,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x04, 0xF2,
+0x0E, 0x4A, 0x40, 0xDB, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x60, 0x9A,
+0x02, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D, 0x40, 0x9B,
+0xFF, 0x6E, 0x41, 0x4E, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5, 0x70, 0x9A,
+0xE0, 0xF3, 0x1E, 0x4C, 0x40, 0xAB, 0xAC, 0xEA,
+0x8D, 0xEA, 0xAC, 0xEA, 0x40, 0xCB, 0x02, 0x6C,
+0x00, 0x18, 0x11, 0x40, 0x0A, 0x6C, 0x00, 0x18,
+0x4C, 0x2C, 0x00, 0x6C, 0xC4, 0x67, 0x0C, 0xF0,
+0x00, 0x6D, 0x00, 0x18, 0x11, 0x40, 0x00, 0x6C,
+0x01, 0xF0, 0x00, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x11, 0x40, 0x10, 0xF0, 0x00, 0x6D, 0x01, 0x6E,
+0x00, 0x6C, 0x00, 0x18, 0x11, 0x40, 0x0A, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xAA, 0x35, 0x01, 0x6A,
+0x18, 0x10, 0xC0, 0x9C, 0x1F, 0xF7, 0x00, 0x6B,
+0xE1, 0x9C, 0xCC, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x01, 0x60, 0x05, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF5, 0x74, 0x9B, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF5, 0x78, 0x9B, 0x79, 0xE6,
+0xFF, 0x6B, 0xEC, 0xEB, 0x60, 0xC6, 0x02, 0x4A,
+0x08, 0x4C, 0xA3, 0xEA, 0xE6, 0x61, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0x4C, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF1, 0x90, 0x9C,
+0x60, 0x9A, 0x8C, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6C, 0x60, 0x9A, 0x81, 0xF1, 0x94, 0x9C,
+0x8C, 0xEB, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0x58, 0x9A, 0x11, 0x6C, 0x8B, 0xEC,
+0x60, 0x9A, 0x8C, 0xEB, 0x60, 0xDA, 0x60, 0x9A,
+0x08, 0x6C, 0x8D, 0xEB, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF1, 0x5C, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x80, 0xF6, 0x84, 0x9C, 0x60, 0x9A,
+0x8D, 0xEB, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6C,
+0x60, 0x9A, 0xA1, 0xF1, 0x80, 0x9C, 0x8C, 0xEB,
+0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x64, 0x9A, 0x03, 0x6C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x48, 0x9A, 0x77, 0x6B, 0xE0, 0xF7, 0x1D, 0x4C,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x6C, 0x9A, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF6, 0x7C, 0x9A, 0xFF, 0xF7, 0x1F, 0x6C,
+0x03, 0x6D, 0x40, 0xAB, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF7, 0x7C, 0x9B, 0x07, 0x6A, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0, 0x70, 0x9B,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0x6C, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xA1, 0xF1, 0x90, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF4, 0x98, 0x9C,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xA1, 0xF1, 0x94, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1,
+0x78, 0x9A, 0x05, 0x6C, 0x8B, 0xEC, 0x40, 0x9B,
+0x8C, 0xEA, 0x04, 0x6C, 0x8D, 0xEA, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF5, 0x70, 0x9A, 0xFF, 0xF7, 0x1F, 0x6C,
+0x00, 0xF2, 0x00, 0x6D, 0x40, 0xAB, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xCB, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF1, 0x58, 0x9A, 0x24, 0x6B,
+0x6B, 0xEB, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF1, 0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x80, 0xF6, 0x9C, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF4,
+0x98, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0x01, 0x74, 0x1F, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF6, 0x9C, 0x9B, 0x03, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x9C, 0x9B,
+0x07, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xC4,
+0xC1, 0xF1, 0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xC1, 0xF1, 0x88, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x1A, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF6,
+0x7C, 0x9A, 0xFC, 0x6A, 0x80, 0xA3, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF7,
+0x7C, 0x9A, 0xF8, 0x6A, 0x80, 0xA3, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF1,
+0x8C, 0x9C, 0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0xB8, 0x9A,
+0x01, 0xF0, 0x08, 0x6C, 0x03, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0xB8, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x00, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xAA, 0x35, 0x04, 0xD5,
+0x04, 0x67, 0x01, 0x69, 0x08, 0x10, 0x80, 0xA8,
+0xC1, 0x98, 0x01, 0x6D, 0xAB, 0xED, 0x00, 0x18,
+0x39, 0x38, 0x02, 0x49, 0x08, 0x48, 0x04, 0x92,
+0x43, 0xE9, 0xF5, 0x61, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xAA, 0x35, 0x04, 0xD5, 0x04, 0x67, 0x01, 0x69,
+0x08, 0x10, 0x80, 0xA8, 0xC1, 0x98, 0x01, 0x6D,
+0xAB, 0xED, 0x00, 0x18, 0x39, 0x38, 0x02, 0x49,
+0x08, 0x48, 0x04, 0x92, 0x43, 0xE9, 0xF5, 0x61,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xAA, 0x35, 0x24, 0x67,
+0x04, 0xD5, 0x00, 0x68, 0x14, 0x10, 0x08, 0x33,
+0x6D, 0xE1, 0x60, 0x9B, 0x48, 0x34, 0x91, 0xE1,
+0xE1, 0xF7, 0x1E, 0x73, 0xE0, 0x9C, 0x02, 0x61,
+0x02, 0x67, 0x09, 0x10, 0xFF, 0xF7, 0x1F, 0x6D,
+0x01, 0x6E, 0x01, 0x6C, 0x6C, 0xED, 0xCB, 0xEE,
+0x00, 0x18, 0x11, 0x39, 0x02, 0x48, 0x04, 0x93,
+0x41, 0x40, 0x63, 0xEA, 0xE8, 0x61, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xAA, 0x35, 0x24, 0x67, 0x04, 0xD5, 0x00, 0x68,
+0x14, 0x10, 0x08, 0x33, 0x6D, 0xE1, 0x60, 0x9B,
+0x48, 0x34, 0x91, 0xE1, 0xE1, 0xF7, 0x1E, 0x73,
+0xE0, 0x9C, 0x02, 0x61, 0x02, 0x67, 0x09, 0x10,
+0xFF, 0xF7, 0x1F, 0x6D, 0x01, 0x6E, 0x00, 0x6C,
+0x6C, 0xED, 0xCB, 0xEE, 0x00, 0x18, 0x11, 0x39,
+0x02, 0x48, 0x04, 0x93, 0x41, 0x40, 0x63, 0xEA,
+0xE8, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0xE0, 0xF3, 0x10, 0x6C, 0x04, 0x05, 0x00, 0x18,
+0xFA, 0x43, 0x7D, 0x67, 0x50, 0x83, 0x00, 0x52,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x5C, 0x9A, 0x60, 0xA2, 0xFF, 0x6A, 0x6C, 0xEA,
+0xA5, 0x72, 0x10, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x5C, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0x7C, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF4, 0x5C, 0x9A,
+0x60, 0xDA, 0xF0, 0x17, 0x07, 0x97, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x00, 0x00, 0x00, 0x00,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF4, 0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF4, 0x5C, 0x9A, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF0, 0x00, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0xEF, 0x9A, 0x60, 0xF4, 0x64, 0x9B,
+0xCE, 0x9A, 0xAD, 0x9A, 0x8C, 0x9A, 0xE0, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF4, 0x68, 0x9B,
+0xC0, 0xDB, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF4,
+0x6C, 0x9B, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF4, 0x70, 0x9B, 0x80, 0xDB, 0x30, 0xF0,
+0x20, 0x6B, 0x89, 0x9A, 0x60, 0xF4, 0x74, 0x9B,
+0x80, 0xDB, 0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF4, 0x58, 0x9A, 0x60, 0xDA, 0x00, 0x18,
+0x54, 0x2C, 0x00, 0x18, 0xF1, 0x0B, 0xFF, 0x17,
+0x71, 0xAC, 0x4A, 0x9C, 0x6A, 0x33, 0x68, 0x33,
+0x6D, 0xE2, 0x04, 0x6A, 0x6C, 0xEA, 0x01, 0x22,
+0xFC, 0x4B, 0x48, 0x43, 0xC8, 0x4A, 0xC2, 0x67,
+0x00, 0x6F, 0xE0, 0xDE, 0x04, 0x4E, 0x6A, 0xEE,
+0xFB, 0x61, 0x04, 0x6B, 0x60, 0xDA, 0xA1, 0xDA,
+0x67, 0x9C, 0x66, 0xDA, 0x40, 0x4A, 0x49, 0xDC,
+0xAB, 0xDC, 0x20, 0xE8, 0x49, 0x9C, 0x10, 0x4A,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x05, 0x67, 0x00, 0x18, 0xDF, 0x09,
+0x00, 0xDA, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x05, 0x67, 0x26, 0x67,
+0x00, 0x18, 0xDF, 0x09, 0x40, 0x9A, 0x00, 0xDA,
+0x21, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x60, 0xA4, 0xC2, 0xA5,
+0x41, 0x9C, 0x02, 0x10, 0x82, 0x67, 0x41, 0x9A,
+0x03, 0x22, 0xE2, 0xA2, 0xC3, 0xEF, 0xFA, 0x60,
+0xFF, 0x4B, 0xFF, 0x6E, 0xCC, 0xEB, 0x03, 0x5B,
+0x41, 0xDD, 0xA1, 0xDC, 0x04, 0x60, 0x01, 0x22,
+0xA2, 0xDA, 0x82, 0xDD, 0x20, 0xE8, 0x00, 0x6A,
+0x42, 0xDD, 0x20, 0xE8, 0x41, 0x9C, 0xFF, 0x6D,
+0x61, 0x9A, 0x61, 0xDC, 0x60, 0xA4, 0xFF, 0x4B,
+0xAC, 0xEB, 0x03, 0x5B, 0x08, 0x60, 0x61, 0x9A,
+0x03, 0x23, 0x82, 0xDB, 0x00, 0x6B, 0x61, 0xDA,
+0x00, 0x6B, 0x62, 0xDA, 0x20, 0xE8, 0x00, 0x6B,
+0x61, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xC8, 0xF3, 0x00, 0x4A, 0x61, 0x9A, 0x61, 0xDC,
+0x00, 0x6B, 0x62, 0xDC, 0x81, 0xDA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0xC8, 0xF3, 0x00, 0x4B,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0x9B, 0xE8, 0xF3,
+0x98, 0x9C, 0xA2, 0xA2, 0x82, 0xA4, 0xAE, 0xEC,
+0x02, 0x24, 0x00, 0x6A, 0x20, 0xE8, 0x81, 0x9A,
+0x81, 0xDB, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xC8, 0xF3, 0x14, 0x4B, 0xC3, 0x9B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEA, 0x00, 0x6D, 0x04, 0x26,
+0xA1, 0xAB, 0x0D, 0x10, 0xC3, 0x9B, 0x08, 0x2E,
+0x00, 0x6E, 0xAB, 0xE2, 0xC3, 0xDC, 0x83, 0xDB,
+0x64, 0xDC, 0x4A, 0xCB, 0xCA, 0xCC, 0x20, 0xE8,
+0x66, 0x67, 0xCA, 0xAE, 0xD5, 0xE5, 0x43, 0xED,
+0xF1, 0x61, 0xC3, 0x9B, 0xC3, 0xDC, 0x83, 0xDB,
+0xC3, 0x9C, 0x64, 0xDC, 0x01, 0x26, 0x84, 0xDE,
+0x4B, 0xE5, 0x4A, 0xCC, 0xAA, 0xAB, 0x4B, 0xE5,
+0x4A, 0xCB, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0xC8, 0xF3,
+0x14, 0x4A, 0x63, 0x9A, 0x3C, 0x23, 0x61, 0xAA,
+0xFF, 0x4B, 0x61, 0xCA, 0x30, 0x10, 0x42, 0x98,
+0x09, 0x22, 0x81, 0x98, 0x81, 0xDA, 0x41, 0x98,
+0x03, 0x22, 0x82, 0x98, 0x82, 0xDA, 0x61, 0xD8,
+0x00, 0x6A, 0x42, 0xD8, 0x30, 0xF0, 0x20, 0x6C,
+0xC8, 0xF3, 0x00, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0xEF, 0x09, 0x6A, 0xA8, 0x30, 0xF0, 0x20, 0x6A,
+0xC8, 0xF3, 0x76, 0xCA, 0x41, 0xA0, 0x04, 0x72,
+0x07, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3,
+0x70, 0x9A, 0x4B, 0xA8, 0x49, 0xE3, 0x4A, 0xC8,
+0x01, 0x6A, 0x63, 0x98, 0x41, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0xC8, 0xF3, 0x14, 0x4A, 0x63, 0xDA,
+0x63, 0x98, 0x03, 0x23, 0x44, 0xDB, 0x00, 0x6A,
+0x43, 0xD8, 0x00, 0x6A, 0x44, 0xD8, 0x30, 0xF0,
+0x20, 0x6A, 0xC8, 0xF3, 0x14, 0x4A, 0x61, 0xAA,
+0x02, 0x2B, 0x03, 0x9A, 0xC8, 0x28, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x42, 0x9C, 0x07, 0x22, 0x61, 0x9C, 0x61, 0xDA,
+0x41, 0x9C, 0x10, 0x22, 0x62, 0x9C, 0x62, 0xDA,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0xC8, 0xF3,
+0x00, 0x4A, 0x07, 0x10, 0x61, 0x9A, 0x8A, 0xEB,
+0x03, 0x61, 0x61, 0x9B, 0x61, 0xDA, 0x20, 0xE8,
+0x43, 0x67, 0xF8, 0x2A, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x02, 0x9C, 0x24, 0x67, 0x09, 0x28, 0x41, 0xA4,
+0x01, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x68,
+0xC8, 0xF3, 0x00, 0x48, 0x03, 0x10, 0x02, 0x98,
+0x40, 0xA0, 0xFD, 0x22, 0x91, 0x67, 0x00, 0x18,
+0x4C, 0x0A, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0xEF, 0x09, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x44, 0x9C, 0x10, 0x22,
+0x63, 0x9C, 0x63, 0xDA, 0x63, 0x9C, 0x09, 0x23,
+0x6A, 0xAA, 0xAA, 0xAC, 0x6D, 0xE5, 0x6A, 0xCA,
+0x63, 0x9C, 0x44, 0xDB, 0x00, 0x6A, 0x43, 0xDC,
+0x01, 0x10, 0x6A, 0xCA, 0x00, 0x6A, 0x44, 0xDC,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x28, 0xF4, 0x10, 0x48, 0x09, 0xD5, 0x24, 0x67,
+0x83, 0xA0, 0xA2, 0x40, 0xD0, 0x67, 0x00, 0x18,
+0x65, 0x11, 0x63, 0xA0, 0x63, 0xEA, 0x06, 0x60,
+0x4C, 0x32, 0x41, 0xE0, 0x21, 0xD8, 0x09, 0x92,
+0x42, 0xD8, 0x03, 0x10, 0x02, 0x6C, 0x00, 0x18,
+0xBC, 0x0B, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xE8, 0xF3, 0x50, 0x9A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0xE8, 0xF3, 0x98, 0x9B, 0x4B, 0xCC,
+0x30, 0xF0, 0x20, 0x6C, 0xE8, 0xF3, 0x90, 0x9C,
+0xE8, 0xF3, 0x78, 0x9B, 0x89, 0xE2, 0x4A, 0xCB,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x58, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0xE8, 0xF3, 0x90, 0x9B,
+0x6A, 0xAA, 0xFF, 0xF7, 0x1F, 0x6D, 0x93, 0xE3,
+0xAC, 0xEC, 0xAB, 0xAA, 0x6D, 0xE5, 0x6A, 0xCA,
+0x82, 0x32, 0x5E, 0x32, 0x03, 0x2A, 0x04, 0x6D,
+0x00, 0x18, 0xFF, 0x0A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x03, 0x6D,
+0x00, 0x18, 0xFF, 0x0A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x78, 0x9A,
+0x01, 0x6C, 0x81, 0xC3, 0xE8, 0xF3, 0x98, 0x9A,
+0x00, 0x18, 0x05, 0x0A, 0x00, 0x18, 0x82, 0x0A,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x70, 0x9A,
+0x01, 0x4B, 0xE8, 0xF3, 0x70, 0xDA, 0x00, 0x18,
+0x27, 0x0A, 0x30, 0xF0, 0x20, 0x6C, 0xC8, 0xF3,
+0x00, 0x4C, 0x00, 0x18, 0xFB, 0x09, 0x82, 0x67,
+0x00, 0x18, 0xE4, 0x0A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3,
+0x78, 0x9A, 0x01, 0x6C, 0x81, 0xC3, 0xE8, 0xF3,
+0x98, 0x9A, 0x00, 0x18, 0x05, 0x0A, 0x30, 0xF0,
+0x20, 0x6A, 0x28, 0xF4, 0x11, 0xA2, 0x1A, 0x10,
+0x0C, 0x33, 0x69, 0xE2, 0x81, 0x9A, 0x60, 0xA4,
+0x04, 0x2B, 0xA4, 0xAA, 0x00, 0x18, 0x74, 0x10,
+0x02, 0x10, 0x00, 0x18, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x28, 0xF4, 0x10, 0x4A, 0x83, 0xA2,
+0x01, 0x48, 0x0E, 0xEC, 0x8B, 0xEB, 0x8D, 0xEB,
+0xC0, 0xF7, 0x63, 0x33, 0x6C, 0xE8, 0x62, 0xA2,
+0xFF, 0x4B, 0x62, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x28, 0xF4, 0x10, 0x4A, 0x62, 0xA2, 0xE0, 0x2B,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xC2, 0xC8, 0xF3,
+0x00, 0x4C, 0x00, 0x18, 0xFB, 0x09, 0x82, 0x67,
+0x00, 0x18, 0xE4, 0x0A, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x44, 0x04, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF1, 0x9C, 0xAA, 0x30, 0xF0, 0x20, 0x6A,
+0x29, 0xF3, 0x14, 0x4A, 0x01, 0x6B, 0x07, 0x10,
+0xA0, 0x9A, 0x04, 0x4A, 0x03, 0x2D, 0xFF, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x01, 0x4B, 0x63, 0xEC,
+0xF7, 0x60, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x9C, 0xDA,
+0x02, 0x6A, 0x41, 0xC4, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x78, 0x9A,
+0x00, 0x6A, 0x01, 0x23, 0x43, 0xA3, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x6E, 0x11,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x00, 0x18, 0x0A, 0x0A, 0x22, 0x67, 0x11, 0x22,
+0x30, 0xF0, 0x20, 0x68, 0xE8, 0xF3, 0xB8, 0x98,
+0x30, 0xF0, 0x20, 0x6C, 0xC8, 0xF3, 0x00, 0x4C,
+0x00, 0x18, 0xEF, 0x09, 0xE8, 0xF3, 0x58, 0x98,
+0x01, 0x6B, 0x91, 0x67, 0x61, 0xC2, 0x00, 0x18,
+0xE4, 0x0A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A, 0xFF, 0x68,
+0x8C, 0xEA, 0xAC, 0xE8, 0x18, 0x22, 0xFF, 0xF7,
+0x1F, 0x72, 0x07, 0x60, 0x30, 0xF0, 0x20, 0x6B,
+0xE8, 0xF3, 0x98, 0x9B, 0xA2, 0x67, 0x00, 0x18,
+0x13, 0x0A, 0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3,
+0x58, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xC8, 0xF3,
+0x00, 0x4C, 0x01, 0xC2, 0x00, 0x18, 0xFB, 0x09,
+0x82, 0x67, 0x00, 0x18, 0xE4, 0x0A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x08, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xC8, 0xF3, 0x00, 0x4C, 0x00, 0x18, 0xFB, 0x09,
+0x82, 0x67, 0x0F, 0x10, 0x30, 0xF0, 0x20, 0x69,
+0xE8, 0xF3, 0x98, 0x99, 0x62, 0xA0, 0x42, 0xA4,
+0x63, 0xEA, 0x0A, 0x60, 0x00, 0x18, 0x05, 0x0A,
+0xE8, 0xF3, 0x58, 0x99, 0x01, 0x6B, 0x90, 0x67,
+0x61, 0xC2, 0x00, 0x18, 0xE4, 0x0A, 0x09, 0x10,
+0x01, 0x6A, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xC0,
+0xC8, 0xF3, 0x00, 0x4C, 0xB0, 0x67, 0x00, 0x18,
+0xEF, 0x09, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x07, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0xE8, 0xF3,
+0x78, 0x9B, 0x63, 0xA3, 0x4E, 0xEB, 0x1F, 0x2B,
+0x30, 0xF0, 0x20, 0x69, 0xE8, 0xF3, 0x58, 0x99,
+0x00, 0x6B, 0x61, 0xC2, 0xE8, 0xF3, 0x18, 0x99,
+0x00, 0x18, 0xC9, 0x0B, 0x49, 0xD8, 0xE8, 0xF3,
+0x78, 0x99, 0x30, 0xF0, 0x20, 0x6A, 0x29, 0xF3,
+0x14, 0x4A, 0x83, 0xA3, 0xFF, 0x4C, 0x88, 0x34,
+0x51, 0xE4, 0x00, 0x6A, 0x40, 0xDC, 0x4A, 0xDB,
+0x82, 0x67, 0xE8, 0xF3, 0x58, 0xD9, 0x00, 0x18,
+0x12, 0x0B, 0x00, 0x6A, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF1, 0x7C, 0xAB, 0x43, 0xEB,
+0x13, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x2F, 0x42,
+0x28, 0x31, 0x29, 0xF3, 0x14, 0x4B, 0x65, 0xE1,
+0x00, 0x99, 0x0A, 0x20, 0x90, 0x67, 0x00, 0x18,
+0x4C, 0x0A, 0x90, 0x67, 0x00, 0x18, 0x67, 0x0A,
+0x00, 0x6A, 0x40, 0xD9, 0x4A, 0xD8, 0x01, 0x10,
+0xFF, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x4C, 0xEC, 0xAC, 0xEA, 0xC8, 0xF3, 0xA4, 0x9B,
+0x01, 0x6B, 0x01, 0x25, 0x62, 0xA5, 0x17, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0xE8, 0xF3, 0x98, 0x9C,
+0x42, 0xC4, 0x63, 0xEA, 0x38, 0x60, 0x30, 0xF0,
+0x20, 0x68, 0xE8, 0xF3, 0xB8, 0x98, 0x30, 0xF0,
+0x20, 0x6C, 0xC8, 0xF3, 0x00, 0x4C, 0x00, 0x18,
+0xEF, 0x09, 0xE8, 0xF3, 0x58, 0x98, 0x01, 0x6B,
+0x00, 0x6C, 0x61, 0xC2, 0x23, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x60, 0xF1, 0xBC, 0xAD, 0x83, 0xED,
+0x20, 0x61, 0x30, 0xF0, 0x20, 0x6D, 0xFF, 0x4C,
+0x88, 0x34, 0x29, 0xF3, 0x14, 0x4D, 0xB5, 0xE4,
+0x00, 0x9D, 0x17, 0x20, 0x42, 0xC0, 0x30, 0xF0,
+0x20, 0x6C, 0xE8, 0xF3, 0x98, 0x9C, 0x0E, 0xEC,
+0xD8, 0x24, 0x90, 0x67, 0x00, 0x18, 0x58, 0x0A,
+0x41, 0xA0, 0x01, 0x72, 0x0C, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xC8, 0xF3, 0x00, 0x4C, 0x00, 0x18,
+0xFB, 0x09, 0x82, 0x67, 0x00, 0x18, 0x12, 0x0B,
+0x02, 0x10, 0xFF, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x6A, 0x40, 0xC4,
+0x01, 0x6A, 0x41, 0xC4, 0x00, 0x6A, 0xA2, 0xC4,
+0x41, 0xDC, 0x42, 0xDC, 0x43, 0xDC, 0x44, 0xDC,
+0x4A, 0xCC, 0x4B, 0xCC, 0x4C, 0xCC, 0x4D, 0xCC,
+0x20, 0xF0, 0x40, 0xC4, 0xA6, 0x67, 0x00, 0x18,
+0xD2, 0x09, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF1, 0x9C, 0xAA, 0x30, 0xF0,
+0x20, 0x6A, 0x29, 0xF3, 0x14, 0x4A, 0x00, 0x6B,
+0x04, 0x10, 0x00, 0x6D, 0xA0, 0xDA, 0x01, 0x4B,
+0x04, 0x4A, 0x83, 0xEB, 0xFA, 0x61, 0x30, 0xF0,
+0x20, 0x68, 0x01, 0x6A, 0x08, 0xF4, 0x00, 0x48,
+0x4B, 0xEA, 0x43, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF1, 0x4C, 0xAA, 0x10, 0xF0, 0x20, 0x6E,
+0x90, 0x67, 0x51, 0xC8, 0x30, 0xF0, 0x20, 0x6A,
+0x28, 0xF6, 0x14, 0x4A, 0x00, 0x6D, 0x48, 0xF5,
+0x15, 0x4E, 0x4A, 0xD8, 0x00, 0x18, 0x78, 0x0B,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0x62, 0x67,
+0xC8, 0xF3, 0x80, 0xC2, 0xC8, 0xF3, 0x00, 0x4B,
+0x00, 0x6A, 0x41, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0xC8, 0xF3, 0x94, 0xC3, 0xC8, 0xF3, 0x14, 0x4B,
+0x43, 0xDB, 0x44, 0xDB, 0x41, 0xCB, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xE8, 0xF3,
+0x18, 0xDA, 0x80, 0xF1, 0x6E, 0xA3, 0x02, 0x6A,
+0x41, 0xC0, 0x00, 0x6C, 0x30, 0xF0, 0x20, 0x6A,
+0x28, 0xF4, 0x90, 0xC2, 0x28, 0xF4, 0x10, 0x4A,
+0x81, 0xC2, 0x63, 0xC2, 0x00, 0x18, 0x81, 0x0A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x12, 0x24, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xC5, 0xF6, 0x01, 0x4A, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0x40, 0x9A,
+0x1D, 0xF4, 0x02, 0x6B, 0x60, 0xDA, 0x00, 0x18,
+0xDC, 0x0B, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xE5, 0xF6, 0x11, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x40, 0x9A, 0x1D, 0xF4,
+0x03, 0x6B, 0x60, 0xDA, 0x00, 0x18, 0xDC, 0x0B,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xBC, 0x65, 0x20, 0xE8, 0x5D, 0x67, 0x20, 0xE8,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x80, 0x9C, 0x00, 0xF0, 0x20, 0x6B, 0x01, 0x4B,
+0x6D, 0xEC, 0x8C, 0xB9, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x7B, 0xB8, 0x00, 0x65, 0x20, 0xE8,
+0x7B, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x4C, 0xB8, 0x00, 0x65, 0x00, 0xF0, 0x20, 0x6B,
+0x01, 0x4B, 0x6F, 0xEB, 0x6C, 0xEA, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x7B, 0xB8,
+0x00, 0x65, 0x20, 0xE8, 0x00, 0x65, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF0, 0x00, 0x4A,
+0x60, 0xDA, 0x81, 0xDA, 0xA2, 0xDA, 0xC3, 0xDA,
+0xE4, 0xDA, 0x05, 0xDA, 0x26, 0xDA, 0x78, 0x67,
+0x67, 0xDA, 0x7D, 0x67, 0x68, 0xDA, 0x7F, 0x67,
+0x69, 0xDA, 0x12, 0xEB, 0x6A, 0xDA, 0x10, 0xEB,
+0x6B, 0xDA, 0x6D, 0xB8, 0x00, 0x65, 0x6C, 0xDA,
+0x68, 0xB8, 0x00, 0x65, 0x6D, 0xDA, 0x6C, 0xB8,
+0x00, 0x65, 0x6E, 0xDA, 0x6E, 0xB8, 0x00, 0x65,
+0x6F, 0xDA, 0x10, 0xF0, 0x20, 0x6A, 0xC4, 0xF6,
+0x19, 0x4A, 0x00, 0xEA, 0x00, 0x65, 0x00, 0x65,
+0x60, 0xBA, 0x20, 0xE8, 0x40, 0xBA, 0x20, 0xE8,
+0x4C, 0xB8, 0x00, 0x65, 0x80, 0x34, 0x8D, 0xEA,
+0x8A, 0xB9, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x4C, 0xB8, 0x00, 0x65,
+0x80, 0x34, 0x8F, 0xEC, 0x8C, 0xEA, 0x8A, 0xB9,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x20, 0xE8,
+0x41, 0x44, 0x03, 0x2A, 0xFF, 0xF7, 0x1F, 0x6A,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x44, 0x9A, 0x83, 0xEA, 0x03, 0x60, 0xFF, 0xF7,
+0x1E, 0x6A, 0x20, 0xE8, 0xE0, 0xF3, 0x08, 0x6A,
+0x58, 0xEC, 0xFF, 0xF7, 0x1F, 0x6B, 0x12, 0xEA,
+0x3F, 0x4A, 0x5A, 0x32, 0x63, 0xEA, 0x02, 0x61,
+0xFF, 0xF7, 0x1E, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0x06, 0x24, 0x03, 0x6A, 0x8C, 0xEA, 0x03, 0x2A,
+0x60, 0xA4, 0x44, 0x67, 0x01, 0x23, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x03, 0x6A, 0x8C, 0xEA,
+0x01, 0x5A, 0x58, 0x67, 0x4B, 0xEA, 0x8C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x46, 0xF0, 0x0D, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x68, 0x9A, 0x08, 0x6E,
+0xFF, 0x6D, 0x80, 0xA3, 0x00, 0x6A, 0xCC, 0xEC,
+0x1A, 0x24, 0x80, 0xA3, 0xF7, 0x6A, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x40, 0x9A,
+0x49, 0xF3, 0x58, 0xDC, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF4, 0x50, 0x9A, 0x49, 0xF3, 0x18, 0x4C,
+0x40, 0x9A, 0x41, 0xDC, 0x80, 0xA3, 0xAC, 0xEC,
+0xCD, 0xEC, 0xAC, 0xEC, 0x80, 0xC3, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6D,
+0x40, 0xF4, 0xBC, 0x9D, 0x10, 0xF0, 0x20, 0x6B,
+0xA6, 0xF0, 0x09, 0x4B, 0x60, 0xDD, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF4, 0x68, 0x9B, 0x08, 0x6D,
+0xFF, 0x6A, 0xC0, 0xA3, 0x4C, 0xEC, 0xAC, 0xEE,
+0x25, 0x26, 0x05, 0x5C, 0x23, 0x60, 0x0C, 0x68,
+0x18, 0xEC, 0xE0, 0xA3, 0xF7, 0x6E, 0xEC, 0xEE,
+0xC0, 0xC3, 0x30, 0xF0, 0x20, 0x6E, 0x80, 0xF4,
+0xCC, 0x9E, 0xE0, 0x9E, 0x30, 0xF0, 0x20, 0x6E,
+0x69, 0xF3, 0x00, 0x4E, 0x12, 0xEC, 0x91, 0xE6,
+0x30, 0xF0, 0x20, 0x6E, 0x80, 0xF4, 0xD0, 0x9E,
+0xE1, 0xDC, 0xE0, 0xA4, 0xC0, 0x9E, 0xC2, 0xDC,
+0x01, 0x6E, 0xED, 0xEE, 0xC0, 0xC4, 0x80, 0xA3,
+0x4C, 0xEC, 0xAD, 0xEC, 0x4C, 0xEC, 0x80, 0xC3,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6A, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x26, 0xF1, 0x05, 0x4B,
+0x60, 0xDC, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF4,
+0x68, 0x9B, 0x08, 0x6C, 0xA0, 0xA3, 0xAC, 0xEC,
+0x2A, 0x24, 0x05, 0x5A, 0x28, 0x60, 0x0C, 0x6D,
+0xB8, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0x69, 0xF3,
+0x00, 0x4C, 0x12, 0xEA, 0x89, 0xE2, 0xA0, 0xA2,
+0x01, 0x6C, 0xAC, 0xEC, 0x1C, 0x24, 0xA0, 0xA3,
+0xF7, 0x6C, 0x08, 0x6E, 0xAC, 0xEC, 0x80, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF4, 0x6C, 0x9B,
+0x42, 0x9A, 0xA0, 0x9B, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF4, 0x70, 0x9B, 0xFF, 0x6D, 0x60, 0x9B,
+0x4B, 0xE3, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF4,
+0x88, 0x9B, 0x60, 0xA4, 0xAC, 0xEB, 0xCD, 0xEB,
+0xAC, 0xEB, 0x60, 0xC4, 0x20, 0xE8, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x8C, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6A, 0xA6, 0xF1, 0x05, 0x4A,
+0x05, 0x5B, 0x40, 0xDC, 0x00, 0x6A, 0x11, 0x60,
+0x0C, 0x6C, 0x98, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x69, 0xF3, 0x00, 0x4A, 0x12, 0xEB, 0x4D, 0xE3,
+0x80, 0xA3, 0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x00, 0x6A, 0x41, 0xDB, 0x42, 0xDB,
+0x01, 0x6A, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xE6, 0xF1, 0x05, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x49, 0xF3, 0x50, 0x9A, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x06, 0xF2, 0x01, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x0A, 0x0C, 0x62, 0x67, 0x84, 0x6A, 0x02, 0x23,
+0x42, 0xA3, 0xFC, 0x4A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0x62,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0x26, 0xF2,
+0x0D, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xE7, 0xF5, 0x19, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x82, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xA7, 0xF5,
+0x1D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0xFF, 0x17, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0x5C, 0x11,
+0x82, 0x6B, 0x18, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF4, 0x9C, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0x66, 0xF2, 0x1D, 0x4B, 0x60, 0xDC, 0x90, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x87, 0xF0,
+0x0D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x5C, 0x11,
+0x03, 0x22, 0x01, 0x6A, 0x4B, 0xEA, 0x18, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xC6, 0xF2, 0x09, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x20, 0x68, 0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x07, 0xF1, 0x01, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0x5C, 0x11,
+0x82, 0x6B, 0x18, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF4, 0x9C, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0x06, 0xF3, 0x1D, 0x4B, 0x60, 0xDC, 0x90, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x07, 0xF2,
+0x19, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0x5C, 0x11, 0x82, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x66, 0xF3, 0x09, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x47, 0xF2, 0x0D, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0x5C, 0x11, 0x82, 0x6B, 0x19, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xA6, 0xF3, 0x15, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x20, 0x68, 0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x87, 0xF2, 0x0D, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x62, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x43, 0x67, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x5C, 0x11,
+0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x06, 0xF4,
+0x09, 0x4A, 0x40, 0xDB, 0x82, 0x6A, 0x0F, 0x10,
+0x90, 0x67, 0xB1, 0x67, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x27, 0xF4, 0x11, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x5C, 0x11,
+0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x54, 0x9A, 0x18, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF4, 0x9C, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0x46, 0xF4, 0x19, 0x4B, 0x60, 0xDC, 0xB1, 0x67,
+0x90, 0x67, 0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3,
+0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0xA7, 0xF4, 0x01, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0x5C, 0x11, 0x84, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xA6, 0xF4, 0x11, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x06, 0xF2, 0x01, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0x5C, 0x11, 0x82, 0x6B, 0x19, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0xE6, 0xF4, 0x1D, 0x4B,
+0x60, 0xDC, 0xB1, 0x67, 0x90, 0x67, 0x30, 0xF0,
+0x20, 0x68, 0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0x47, 0xF5, 0x09, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x62, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x43, 0x67, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0x5C, 0x11, 0x82, 0x6B, 0x17, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x68, 0x46, 0xF5, 0x11, 0x48, 0x00, 0xDB,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x87, 0xF5,
+0x19, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0x5C, 0x11, 0x82, 0x6B, 0x18, 0x2A,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF4, 0x9C, 0x9C,
+0x10, 0xF0, 0x20, 0x6B, 0x86, 0xF5, 0x19, 0x4B,
+0x60, 0xDC, 0x90, 0x67, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xA7, 0xF5, 0x1D, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x5C, 0x11, 0x00, 0x6B,
+0x17, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0xE6, 0xF5,
+0x05, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xE7, 0xF5, 0x19, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x5C, 0x11, 0x82, 0x6B,
+0x17, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x68, 0x26, 0xF6,
+0x0D, 0x48, 0x00, 0xDB, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x27, 0xF7, 0x15, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x66, 0xF6,
+0x15, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0x5C, 0x11, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0x69, 0x0C, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xA6, 0xF1,
+0x05, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xC6, 0xF6,
+0x05, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0x5C, 0x11, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0x49, 0x0C, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x26, 0xF1,
+0x05, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x06, 0xF7,
+0x15, 0x4A, 0xFF, 0x68, 0x40, 0xDB, 0x8C, 0xE8,
+0x00, 0x18, 0x5C, 0x11, 0x04, 0x22, 0x90, 0x67,
+0x00, 0x18, 0x2A, 0x0C, 0x0E, 0x10, 0x90, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0xA6, 0xF0,
+0x09, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0x66, 0xF7,
+0x05, 0x4A, 0x40, 0xDB, 0x00, 0x18, 0x5C, 0x11,
+0x03, 0x22, 0x00, 0x18, 0x13, 0x0C, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x46, 0xF0,
+0x0D, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xA6, 0xF7, 0x0D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x0F, 0x0C, 0x82, 0x67,
+0x0C, 0x22, 0x40, 0xA2, 0x02, 0x72, 0x09, 0x61,
+0x41, 0xAC, 0xFF, 0xF7, 0x1F, 0x72, 0x81, 0x6A,
+0x05, 0x60, 0x00, 0x18, 0x1F, 0x10, 0x00, 0x6A,
+0x01, 0x10, 0x80, 0x6A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xE6, 0xF7,
+0x0D, 0x4A, 0x40, 0xDB, 0x04, 0x67, 0x00, 0x18,
+0x5C, 0x11, 0x04, 0x22, 0x90, 0x67, 0x00, 0x18,
+0xEB, 0x0D, 0x0E, 0x10, 0x90, 0x67, 0x30, 0xF0,
+0x20, 0x68, 0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8,
+0x10, 0xF0, 0x20, 0x68, 0xC7, 0xF0, 0x01, 0x48,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x27, 0xF0, 0x19, 0x4A, 0x40, 0xDB,
+0x00, 0x18, 0x5C, 0x11, 0x05, 0x2A, 0x00, 0x18,
+0x5B, 0x11, 0x01, 0x6B, 0x4C, 0xEB, 0x05, 0x2B,
+0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF3, 0x50, 0x9A,
+0x0D, 0x10, 0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3,
+0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0xE6, 0xF1, 0x05, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x87, 0xF0, 0x0D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x0F, 0x0C, 0x08, 0x22,
+0x60, 0xA2, 0x02, 0x73, 0x05, 0x61, 0x82, 0x67,
+0x00, 0x18, 0x48, 0x10, 0x00, 0x6A, 0x01, 0x10,
+0x80, 0x6A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xC7, 0xF0, 0x01, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x0F, 0x0C, 0x82, 0x67, 0x0C, 0x22, 0x40, 0xA2,
+0x02, 0x72, 0x09, 0x61, 0x41, 0xAC, 0xFF, 0xF7,
+0x1F, 0x72, 0x81, 0x6A, 0x05, 0x60, 0x00, 0x18,
+0x3A, 0x10, 0x00, 0x6A, 0x01, 0x10, 0x80, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x07, 0xF1, 0x01, 0x4A,
+0x40, 0xDB, 0x25, 0x67, 0x00, 0x18, 0x0F, 0x0C,
+0x02, 0x67, 0x12, 0x22, 0x40, 0xA2, 0x02, 0x72,
+0x0F, 0x61, 0x91, 0x67, 0x00, 0x18, 0xFC, 0x0B,
+0xFF, 0xF7, 0x1F, 0x6D, 0x90, 0x67, 0x4C, 0xED,
+0x00, 0x18, 0x24, 0x10, 0x01, 0x72, 0x00, 0x6A,
+0x05, 0x60, 0x41, 0xA8, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x6A, 0x4B, 0xEA, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x47, 0xF1, 0x19, 0x4A, 0x40, 0xDB,
+0x02, 0x24, 0x00, 0x9C, 0x02, 0x28, 0x80, 0x6C,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x58, 0x9A, 0x42, 0xED, 0x05, 0x61, 0x86, 0x6C,
+0x00, 0x18, 0xB0, 0x0B, 0x00, 0x6A, 0x07, 0x10,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED, 0x90, 0x67,
+0x00, 0x18, 0x0C, 0x10, 0x50, 0x67, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x04, 0x67, 0x25, 0x67, 0x00, 0x18, 0x5C, 0x11,
+0x00, 0x6B, 0x28, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xA7, 0xF1, 0x09, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x5B, 0x11, 0x01, 0x6B, 0x4C, 0xEB, 0x0A, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x49, 0xF3, 0x70, 0x9B,
+0x05, 0x2B, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x56, 0x0E, 0x0F, 0x10, 0x90, 0x67, 0xB1, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x47, 0xF1,
+0x19, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x43, 0x67, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x07, 0xF2, 0x19, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x0F, 0x0C, 0x08, 0x22, 0x60, 0xA2, 0x03, 0x73,
+0x05, 0x61, 0x82, 0x67, 0x00, 0x18, 0x2F, 0x11,
+0x00, 0x6A, 0x01, 0x10, 0x80, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x47, 0xF2, 0x0D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x0F, 0x0C, 0x0E, 0x22,
+0x60, 0xA2, 0x03, 0x73, 0x0B, 0x61, 0x82, 0x67,
+0x00, 0x18, 0xFC, 0x10, 0xFF, 0x6B, 0x4E, 0xEB,
+0x01, 0x5B, 0x78, 0x67, 0x81, 0x6A, 0x6B, 0xEB,
+0x6C, 0xEA, 0x01, 0x10, 0x80, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x87, 0xF2, 0x0D, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x0F, 0x0C, 0x02, 0x67, 0x13, 0x22,
+0x40, 0xA2, 0x03, 0x72, 0x10, 0x61, 0x91, 0x67,
+0x00, 0x18, 0xFC, 0x0B, 0xFF, 0xF7, 0x1F, 0x6D,
+0x90, 0x67, 0x4C, 0xED, 0x00, 0x18, 0xD7, 0x10,
+0x01, 0x72, 0x00, 0x6A, 0x05, 0x61, 0xC1, 0x6A,
+0x03, 0x29, 0x81, 0x6A, 0x01, 0x10, 0x80, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A, 0xE7, 0xF2,
+0x05, 0x4A, 0x40, 0xDB, 0x02, 0x24, 0x00, 0x9C,
+0x05, 0x28, 0x80, 0x6C, 0x00, 0x18, 0xB0, 0x0B,
+0x00, 0x6A, 0x04, 0x10, 0x90, 0x67, 0x00, 0x18,
+0xD2, 0x10, 0x50, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x04, 0x67, 0x00, 0x18, 0x5C, 0x11,
+0x00, 0x6B, 0x26, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x07, 0xF3, 0x1D, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0x5B, 0x11, 0x01, 0x6B, 0x4C, 0xEB, 0x09, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x49, 0xF3, 0x70, 0x9B,
+0x04, 0x2B, 0x90, 0x67, 0x00, 0x18, 0xB9, 0x0E,
+0x0E, 0x10, 0x90, 0x67, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0xE7, 0xF2, 0x05, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x05, 0x97, 0x04, 0x90, 0x43, 0x67, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x87, 0xF3, 0x05, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x0A, 0x0C, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF4, 0x7C, 0x9B, 0x2C, 0xEB,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x14, 0x9A, 0x07, 0x10, 0xA3, 0xA2, 0xFF, 0xF7,
+0x1F, 0x6C, 0x2C, 0xEC, 0x0C, 0xAA, 0x00, 0x18,
+0x8E, 0x10, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC7, 0xF3, 0x19, 0x4A,
+0x40, 0xDB, 0x04, 0x67, 0x25, 0x67, 0x00, 0x18,
+0x5C, 0x11, 0x05, 0x22, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0xE1, 0x0E, 0x0F, 0x10, 0x90, 0x67,
+0xB1, 0x67, 0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3,
+0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68,
+0xE7, 0xF4, 0x15, 0x48, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0xBA, 0xFE, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x27, 0xF4, 0x11, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x7C, 0x9A, 0x24, 0x67, 0x05, 0x67, 0x8C, 0xEB,
+0x86, 0x6A, 0x1D, 0x2B, 0x0A, 0x24, 0x85, 0x67,
+0x00, 0x18, 0xFC, 0x0B, 0xFF, 0xF7, 0x1F, 0x6D,
+0x91, 0x67, 0xAC, 0xEC, 0x01, 0x6E, 0x4C, 0xED,
+0x08, 0x10, 0x85, 0x67, 0x00, 0x18, 0xFC, 0x0B,
+0xFF, 0xF7, 0x1F, 0x6D, 0x85, 0x67, 0x00, 0x6E,
+0x4C, 0xED, 0x00, 0x18, 0xB7, 0x10, 0x02, 0x72,
+0x08, 0x6A, 0x05, 0x60, 0x0B, 0xEA, 0x0D, 0xEA,
+0xC0, 0xF7, 0x42, 0x32, 0x58, 0x32, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xA7, 0xF4, 0x01, 0x4A,
+0x40, 0xDB, 0x25, 0x67, 0x00, 0x18, 0x0A, 0x0C,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF4,
+0x7C, 0x9B, 0x2C, 0xEB, 0x05, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x14, 0x9A, 0x07, 0x10,
+0xA3, 0xA2, 0xFF, 0xF7, 0x1F, 0x6C, 0x2C, 0xEC,
+0x0C, 0xAA, 0x00, 0x18, 0x67, 0x10, 0x50, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xE7, 0xF4, 0x15, 0x4A, 0x40, 0xDB, 0x25, 0x67,
+0x00, 0x18, 0x0A, 0x0C, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF4, 0x7C, 0x9B, 0x2C, 0xEB,
+0x05, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x14, 0x9A, 0x07, 0x10, 0xA3, 0xA2, 0xFF, 0xF7,
+0x1F, 0x6C, 0x2C, 0xEC, 0x0C, 0xAA, 0x00, 0x18,
+0x9A, 0x10, 0x50, 0x67, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x47, 0xF5, 0x09, 0x4A, 0x40, 0xDB,
+0x05, 0x67, 0x00, 0x18, 0x0A, 0x0C, 0x80, 0x6B,
+0x11, 0x22, 0x63, 0x40, 0x07, 0x5B, 0x86, 0x6B,
+0x0D, 0x60, 0x83, 0xA2, 0xA4, 0x40, 0xFF, 0x6A,
+0x4C, 0xED, 0x00, 0x18, 0x4F, 0x0B, 0xFF, 0x6B,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x81, 0x6B,
+0x4B, 0xEA, 0x4C, 0xEB, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x87, 0xF5, 0x19, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0xF0, 0x0A, 0x05, 0x97, 0x00, 0x6A, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xA7, 0xF5, 0x1D, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x0A, 0x0C, 0x80, 0x6B,
+0x0A, 0x22, 0x83, 0xA2, 0x00, 0x18, 0x29, 0x0B,
+0xFF, 0x6B, 0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67,
+0x81, 0x6B, 0x4B, 0xEA, 0x4C, 0xEB, 0x05, 0x97,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0xE7, 0xF5, 0x19, 0x4A, 0x40, 0xDB, 0x00, 0x18,
+0xE8, 0x0A, 0x82, 0x67, 0x00, 0x6A, 0x08, 0x24,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x4C, 0x88, 0x34,
+0x29, 0xF3, 0x14, 0x4B, 0x6D, 0xE4, 0x40, 0x9B,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x27, 0xF6, 0x11, 0x4A,
+0x24, 0x67, 0x40, 0xDB, 0x0C, 0x24, 0xC0, 0x9C,
+0x0A, 0x26, 0x41, 0x9C, 0xFF, 0xF7, 0x1D, 0x52,
+0x06, 0x61, 0x04, 0x52, 0x04, 0x60, 0x64, 0xAC,
+0x02, 0x23, 0x83, 0x9C, 0x05, 0x2C, 0x80, 0x6C,
+0x00, 0x18, 0xB0, 0x0B, 0x00, 0x6A, 0x24, 0x10,
+0xE7, 0x41, 0x09, 0x4F, 0x04, 0xD7, 0x79, 0xC9,
+0xAB, 0xD9, 0x8E, 0xD9, 0x04, 0x4A, 0x04, 0x94,
+0xFF, 0x6B, 0xA2, 0x67, 0x6C, 0xED, 0x00, 0x18,
+0x78, 0x0B, 0x00, 0x18, 0xD9, 0x0A, 0x0F, 0x42,
+0x30, 0xF0, 0x20, 0x6B, 0x29, 0xF3, 0x14, 0x4B,
+0x08, 0x30, 0x61, 0xE0, 0x04, 0x93, 0x60, 0xD8,
+0x53, 0xC1, 0x04, 0x94, 0x00, 0x18, 0x12, 0x0B,
+0x40, 0x98, 0x10, 0xF0, 0x20, 0x6B, 0x26, 0xF2,
+0x0D, 0x4B, 0x89, 0x9A, 0xFF, 0xF7, 0x7C, 0xDC,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x25, 0x67,
+0x00, 0x18, 0x5C, 0x11, 0x00, 0x6B, 0x28, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0xC7, 0xF6, 0x05, 0x4A,
+0x40, 0xDB, 0x00, 0x18, 0x5B, 0x11, 0x01, 0x6B,
+0x4C, 0xEB, 0x0A, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x49, 0xF3, 0x70, 0x9B, 0x05, 0x2B, 0x90, 0x67,
+0xB1, 0x67, 0x00, 0x18, 0x8C, 0x0F, 0x0F, 0x10,
+0x90, 0x67, 0xB1, 0x67, 0x30, 0xF0, 0x20, 0x68,
+0x49, 0xF3, 0x14, 0x48, 0x00, 0xD8, 0x10, 0xF0,
+0x20, 0x68, 0x27, 0xF6, 0x11, 0x48, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0xBA, 0xFE, 0x62, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x43, 0x67,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x69,
+0x49, 0xF3, 0x10, 0x99, 0x16, 0x28, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0x00, 0x6C, 0x27, 0xF7, 0x15, 0x4A,
+0x40, 0xDB, 0xA4, 0x67, 0x00, 0x18, 0x4F, 0x0B,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x18, 0xDA,
+0x00, 0x18, 0xEC, 0x0A, 0x01, 0x6A, 0x49, 0xF3,
+0x50, 0xD9, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x20, 0x6A, 0x87, 0xF7, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3,
+0x2C, 0xA0, 0x13, 0x29, 0x00, 0x18, 0x84, 0x0B,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x58, 0x9A,
+0x01, 0x6B, 0x6B, 0xEB, 0x62, 0xC2, 0x00, 0x6C,
+0x00, 0x18, 0xB0, 0x0B, 0x01, 0x6A, 0x49, 0xF3,
+0x4C, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x49, 0xF3,
+0x30, 0xDA, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0x5C, 0x11, 0x82, 0x6B, 0x1F, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xC7, 0xF7, 0x19, 0x4A, 0x40, 0xDB,
+0x00, 0x18, 0x5B, 0x11, 0x01, 0x6B, 0x4C, 0xEB,
+0x03, 0x2B, 0x00, 0x18, 0xE0, 0x0F, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x68, 0x49, 0xF3, 0x14, 0x48,
+0x00, 0xD8, 0x10, 0xF0, 0x20, 0x68, 0x87, 0xF7,
+0x01, 0x48, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0xBA, 0xFE, 0x62, 0x67, 0x05, 0x97, 0x04, 0x90,
+0x43, 0x67, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x02, 0x6A, 0x40, 0xC4, 0x00, 0x6A, 0x41, 0xDC,
+0xA1, 0xCC, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x41, 0x9C, 0x14, 0x22, 0x00, 0x18,
+0xFB, 0x09, 0x82, 0x67, 0x02, 0x67, 0x00, 0x18,
+0x67, 0x0A, 0x01, 0x6A, 0x90, 0x67, 0x41, 0xC0,
+0x01, 0x6D, 0x00, 0x18, 0xE1, 0x09, 0x30, 0xF0,
+0x20, 0x6C, 0xC8, 0xF3, 0x00, 0x4C, 0xB0, 0x67,
+0x00, 0x18, 0xEF, 0x09, 0x03, 0x10, 0x41, 0xAC,
+0x01, 0x4A, 0x41, 0xCC, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x6D, 0x00, 0x18, 0x71, 0x0A, 0x00, 0x18,
+0xD5, 0x0A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x41, 0xAC,
+0xFF, 0xF7, 0x1F, 0x68, 0xAC, 0xE8, 0x04, 0x22,
+0xFF, 0x4A, 0x41, 0xCC, 0x00, 0x6A, 0x1B, 0x10,
+0x01, 0x6A, 0x19, 0x20, 0x61, 0x9C, 0x07, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0xB8, 0x9A,
+0x00, 0x18, 0xEF, 0x09, 0x0B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE8, 0xF3, 0xB8, 0x9A, 0xA1, 0xDC,
+0xE8, 0xF3, 0xB8, 0x9A, 0x61, 0xDD, 0xE8, 0xF3,
+0x58, 0x9A, 0x82, 0xDA, 0x90, 0x67, 0x07, 0x6D,
+0x00, 0x18, 0xFF, 0x0A, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x41, 0x9C,
+0x0E, 0x22, 0x00, 0x18, 0xFB, 0x09, 0x02, 0x67,
+0x82, 0x67, 0x01, 0x6D, 0x00, 0x18, 0xE1, 0x09,
+0x90, 0x67, 0x00, 0x18, 0x67, 0x0A, 0x90, 0x67,
+0x00, 0x18, 0x12, 0x0B, 0x03, 0x10, 0x41, 0xAC,
+0x01, 0x4A, 0x41, 0xCC, 0x05, 0x97, 0x04, 0x90,
+0x00, 0x6A, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x08, 0xD4, 0x24, 0x67, 0x14, 0x10, 0x91, 0x67,
+0x00, 0x18, 0xFB, 0x09, 0x02, 0x67, 0x82, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0xE1, 0x09, 0x90, 0x67,
+0x00, 0x18, 0x67, 0x0A, 0x01, 0x6A, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xC0, 0xC8, 0xF3, 0x00, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0xEF, 0x09, 0x41, 0x99,
+0xEA, 0x2A, 0x30, 0xF0, 0x20, 0x6C, 0xC8, 0xF3,
+0x00, 0x4C, 0x41, 0x9C, 0x11, 0x22, 0x30, 0xF0,
+0x20, 0x68, 0xE8, 0xF3, 0xB8, 0x98, 0x62, 0xA2,
+0x42, 0xA5, 0x63, 0xEA, 0x09, 0x60, 0x00, 0x18,
+0xEF, 0x09, 0xE8, 0xF3, 0x58, 0x98, 0x01, 0x6B,
+0x00, 0x6C, 0x61, 0xC2, 0x00, 0x18, 0x12, 0x0B,
+0x08, 0x93, 0x00, 0x6A, 0x40, 0xC3, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x00, 0x6A, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x6B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA, 0xFF, 0x4B,
+0x30, 0xF0, 0x20, 0x6C, 0x68, 0x33, 0x29, 0xF3,
+0x14, 0x4C, 0x91, 0xE3, 0x60, 0x9C, 0x04, 0x23,
+0x8C, 0xAB, 0x4F, 0xEA, 0x8C, 0xEA, 0x4C, 0xCB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xE8, 0xF3, 0x58, 0x9A, 0x4D, 0xAA, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x6C, 0xAC,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA, 0x6D, 0xEA,
+0x04, 0x67, 0x4C, 0xCC, 0x6D, 0xAC, 0x81, 0xA4,
+0x06, 0x74, 0x03, 0x61, 0x6C, 0xEA, 0x6E, 0xEA,
+0x0A, 0x22, 0x41, 0xA0, 0x05, 0x72, 0x1B, 0x61,
+0x4C, 0xA8, 0x83, 0x67, 0x4C, 0xEC, 0x17, 0x24,
+0x8D, 0xA8, 0x4C, 0xEC, 0x8D, 0xC8, 0x4C, 0xA8,
+0x6F, 0xEB, 0x90, 0x67, 0x4C, 0xEB, 0x6C, 0xC8,
+0x00, 0x18, 0x67, 0x0A, 0x01, 0x6A, 0x90, 0x67,
+0x08, 0x6D, 0x41, 0xC0, 0x00, 0x18, 0xE1, 0x09,
+0x30, 0xF0, 0x20, 0x6C, 0xC8, 0xF3, 0x00, 0x4C,
+0xB0, 0x67, 0x00, 0x18, 0xEF, 0x09, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6B, 0xFF, 0xF7,
+0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA, 0xFF, 0x4B,
+0x30, 0xF0, 0x20, 0x6C, 0x68, 0x33, 0x29, 0xF3,
+0x14, 0x4C, 0x91, 0xE3, 0x80, 0x9C, 0x05, 0x24,
+0xA2, 0x67, 0x00, 0x18, 0x71, 0x0A, 0x00, 0x18,
+0xD5, 0x0A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6B,
+0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEB, 0x8C, 0xEA,
+0xFF, 0x4B, 0x30, 0xF0, 0x20, 0x6C, 0x68, 0x33,
+0x29, 0xF3, 0x14, 0x4C, 0x91, 0xE3, 0x00, 0x9C,
+0x24, 0x20, 0x6C, 0xA8, 0x81, 0xA0, 0x4D, 0xEB,
+0x06, 0x74, 0x6C, 0xC8, 0x4D, 0xA8, 0x03, 0x61,
+0x4C, 0xEB, 0x4E, 0xEB, 0x0A, 0x23, 0x61, 0xA0,
+0x05, 0x73, 0x17, 0x61, 0x6C, 0xA8, 0x82, 0x67,
+0x6C, 0xEC, 0x13, 0x24, 0x8D, 0xA8, 0x6C, 0xEC,
+0x8D, 0xC8, 0x6C, 0xA8, 0x4F, 0xEA, 0x90, 0x67,
+0x6C, 0xEA, 0x4C, 0xC8, 0x00, 0x18, 0x67, 0x0A,
+0x01, 0x6A, 0x90, 0x67, 0x41, 0xC0, 0x08, 0x6D,
+0x00, 0x18, 0xE1, 0x09, 0x90, 0x67, 0x00, 0x18,
+0x12, 0x0B, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A, 0x64, 0x67,
+0x85, 0x67, 0x4C, 0xEB, 0x4C, 0xEC, 0x0D, 0x26,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x58, 0x9A,
+0xE3, 0x67, 0x06, 0x6D, 0xCC, 0xAA, 0xCC, 0xEF,
+0x6E, 0xEF, 0x15, 0x2F, 0x6F, 0xEB, 0xCC, 0xEB,
+0x0F, 0x10, 0x30, 0xF0, 0x20, 0x6F, 0xE8, 0xF3,
+0x18, 0x9F, 0x05, 0x6D, 0xCC, 0xA8, 0x6C, 0xEE,
+0xCC, 0xEA, 0x09, 0x22, 0xCD, 0xC8, 0xE8, 0xF3,
+0x58, 0x9F, 0x6F, 0xEB, 0x8C, 0xAA, 0x8C, 0xEB,
+0x6C, 0xCA, 0x02, 0x6A, 0x08, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE8, 0xF3, 0x58, 0x9A, 0x6D, 0xCA,
+0x00, 0x18, 0xFF, 0x0A, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x03, 0x6A, 0x40, 0xC4, 0x00, 0x6A, 0x41, 0xC4,
+0x00, 0x6A, 0x41, 0xCC, 0x00, 0x6A, 0x41, 0xDC,
+0x42, 0xDC, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x41, 0xAC, 0xFF, 0xF7,
+0x1F, 0x69, 0x04, 0x67, 0xAC, 0xE9, 0x0A, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xE8, 0xF3, 0x78, 0x9A,
+0x62, 0xDC, 0xE8, 0xF3, 0x58, 0x9A, 0x42, 0xA2,
+0x41, 0xC4, 0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x62, 0x9C, 0xE8, 0xF3, 0x98, 0x9A, 0x8A, 0xEB,
+0x05, 0x61, 0x41, 0xA8, 0x01, 0x4A, 0x41, 0xC8,
+0x00, 0x6A, 0x24, 0x10, 0x01, 0x6A, 0x22, 0x21,
+0xA1, 0xA0, 0x42, 0xA4, 0x43, 0xED, 0x04, 0x60,
+0x42, 0xC3, 0x82, 0x98, 0x00, 0x18, 0x58, 0x0A,
+0x61, 0x98, 0x08, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0xE8, 0xF3, 0xB8, 0x9A, 0x90, 0x67, 0x00, 0x18,
+0xEF, 0x09, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE8, 0xF3, 0x98, 0x9A, 0x81, 0xD8, 0xE8, 0xF3,
+0x98, 0x9A, 0x61, 0xDC, 0xE8, 0xF3, 0x58, 0x9A,
+0x02, 0xDA, 0x91, 0x67, 0x09, 0x6D, 0x00, 0x18,
+0xFF, 0x0A, 0x01, 0x6A, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x41, 0xAC, 0x04, 0x67, 0x57, 0x22, 0x30, 0xF0,
+0x20, 0x6D, 0x82, 0x9C, 0xE8, 0xF3, 0x78, 0x9D,
+0x8E, 0xEB, 0x50, 0x2B, 0xFF, 0x4A, 0x41, 0xC8,
+0x41, 0xA8, 0x4E, 0x2A, 0xE8, 0xF3, 0x58, 0x9D,
+0x61, 0xA0, 0x62, 0xC2, 0x41, 0x98, 0x2D, 0x22,
+0x90, 0x67, 0x00, 0x18, 0xFB, 0x09, 0x22, 0x67,
+0x82, 0x67, 0x00, 0x6D, 0x00, 0x18, 0xE1, 0x09,
+0x91, 0x67, 0x00, 0x18, 0x67, 0x0A, 0x01, 0x6A,
+0x41, 0xC8, 0x22, 0xD8, 0x42, 0xA1, 0x30, 0xF0,
+0x20, 0x6B, 0x91, 0x67, 0x41, 0xC0, 0x30, 0xF0,
+0x20, 0x68, 0xC8, 0xF3, 0x00, 0x48, 0xE8, 0xF3,
+0xB8, 0x9B, 0x41, 0x98, 0x62, 0xA5, 0x42, 0xA2,
+0x43, 0xEB, 0x25, 0x60, 0x90, 0x67, 0x00, 0x18,
+0xEF, 0x09, 0xB1, 0x67, 0x90, 0x67, 0x00, 0x18,
+0xEF, 0x09, 0x30, 0xF0, 0x20, 0x6D, 0xE8, 0xF3,
+0x58, 0x9D, 0x01, 0x6B, 0x61, 0xC2, 0x61, 0xC1,
+0x15, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x20, 0x6B, 0xC8, 0xF3, 0x00, 0x4C, 0x41, 0x9C,
+0xE8, 0xF3, 0xB8, 0x9B, 0x62, 0xA2, 0x42, 0xA5,
+0x63, 0xEA, 0x0E, 0x60, 0x00, 0x18, 0xEF, 0x09,
+0x30, 0xF0, 0x20, 0x6D, 0xE8, 0xF3, 0x58, 0x9D,
+0x01, 0x6B, 0x61, 0xC2, 0x00, 0x6C, 0x00, 0x18,
+0x12, 0x0B, 0x02, 0x10, 0xFF, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x04, 0xD4, 0x41, 0xAC,
+0x04, 0x67, 0x21, 0x22, 0x42, 0x9C, 0x61, 0xA4,
+0x62, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x82, 0x9C,
+0xE8, 0xF3, 0x58, 0x9A, 0x8E, 0xEA, 0x17, 0x22,
+0x00, 0x18, 0x58, 0x0A, 0x14, 0x10, 0x04, 0x94,
+0x00, 0x18, 0xFB, 0x09, 0x22, 0x67, 0x82, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0xE1, 0x09, 0x91, 0x67,
+0x00, 0x18, 0x67, 0x0A, 0x01, 0x6A, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xC1, 0xC8, 0xF3, 0x00, 0x4C,
+0xB1, 0x67, 0x00, 0x18, 0xEF, 0x09, 0x04, 0x93,
+0x41, 0x9B, 0xE9, 0x2A, 0x30, 0xF0, 0x20, 0x6C,
+0xC8, 0xF3, 0x00, 0x4C, 0x41, 0x9C, 0x11, 0x22,
+0x30, 0xF0, 0x20, 0x69, 0xE8, 0xF3, 0xB8, 0x99,
+0x62, 0xA2, 0x42, 0xA5, 0x63, 0xEA, 0x09, 0x60,
+0x00, 0x18, 0xEF, 0x09, 0xE8, 0xF3, 0x58, 0x99,
+0x01, 0x6B, 0x00, 0x6C, 0x61, 0xC2, 0x00, 0x18,
+0x12, 0x0B, 0x00, 0x6A, 0x40, 0xC0, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x00, 0x6A, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x20, 0x6A,
+0x48, 0xF5, 0x15, 0x4A, 0x40, 0xDB, 0x01, 0x4A,
+0x40, 0xDB, 0xF4, 0x17, 0x00, 0x6A, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xA8, 0xF3, 0x60, 0x9A,
+0x02, 0x5B, 0x43, 0x67, 0x0A, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF0, 0x08, 0x4A, 0x4F, 0xE3,
+0x20, 0x5B, 0x98, 0x67, 0x6A, 0x32, 0x8B, 0xEB,
+0x6C, 0xEA, 0x20, 0xE8, 0x40, 0xA5, 0xFF, 0x6B,
+0x6C, 0xEC, 0x83, 0xEA, 0x0C, 0x60, 0x01, 0x4A,
+0x40, 0xC5, 0x40, 0xA6, 0xA1, 0x42, 0x6C, 0xED,
+0xAE, 0xEC, 0x8B, 0xEB, 0x8D, 0xEB, 0xC0, 0xF7,
+0x63, 0x33, 0x6C, 0xED, 0xA0, 0xC6, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xA8, 0xF3,
+0x4C, 0xDC, 0xA8, 0xF3, 0x50, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF4, 0x5C, 0x9A, 0x02, 0x6E,
+0x30, 0xF0, 0x20, 0x6D, 0x60, 0xAA, 0xE7, 0xF7,
+0x1F, 0x6A, 0x40, 0xF4, 0xBC, 0x9D, 0x6C, 0xEA,
+0x5B, 0xEE, 0x01, 0x2A, 0xE5, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0xA8, 0xF3, 0x48, 0xDB, 0x10, 0xF0,
+0x20, 0x6B, 0xA8, 0xF5, 0x19, 0x4B, 0x60, 0xDD,
+0x01, 0x6D, 0x12, 0xEE, 0xA8, 0xF3, 0xCC, 0xDC,
+0x42, 0xF1, 0x18, 0x6C, 0x00, 0x18, 0x08, 0x34,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x8E, 0x35, 0x61, 0xF3, 0x10, 0x4B, 0xAD, 0xE3,
+0x63, 0xF3, 0x70, 0xA3, 0x07, 0x6D, 0x8C, 0xED,
+0x67, 0xED, 0x01, 0x6C, 0x8C, 0xEB, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x24, 0x67,
+0x4C, 0xE9, 0x4C, 0xED, 0x2E, 0x34, 0x07, 0x6B,
+0x01, 0x75, 0x4C, 0xEC, 0x2C, 0xEB, 0x1F, 0x61,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x11, 0xE4, 0x01, 0x6A, 0x44, 0xEB, 0x63, 0xF3,
+0x70, 0xA4, 0x00, 0x6D, 0x6D, 0xEA, 0x63, 0xF3,
+0x50, 0xC4, 0x91, 0x67, 0x00, 0x18, 0x71, 0x45,
+0xE0, 0xF0, 0x48, 0xA0, 0x4E, 0xE9, 0x1C, 0x29,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0x40, 0x9A,
+0x40, 0x9A, 0x50, 0x32, 0x00, 0xF5, 0x42, 0x32,
+0xA3, 0xF3, 0x5E, 0xC8, 0x11, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x51, 0xE4,
+0x01, 0x6A, 0x44, 0xEB, 0x63, 0xF3, 0x70, 0xA4,
+0x4F, 0xEA, 0x01, 0x6D, 0x6C, 0xEA, 0x63, 0xF3,
+0x50, 0xC4, 0x91, 0x67, 0x00, 0x18, 0x71, 0x45,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x6D, 0x00, 0x18,
+0x71, 0x45, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x6D, 0x00, 0x18, 0x71, 0x45, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFF, 0x6A, 0x4C, 0xEC,
+0x01, 0x6B, 0xAC, 0xEA, 0x6E, 0xEA, 0x01, 0x5A,
+0x58, 0x67, 0x05, 0x5C, 0x48, 0x32, 0x08, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0x88, 0x34, 0x80, 0xF1,
+0x10, 0x4B, 0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB,
+0x01, 0x6A, 0x4B, 0xEA, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF4, 0x80, 0x9B, 0x30, 0xF0,
+0x20, 0x6D, 0xA0, 0xF4, 0xA4, 0x9D, 0x60, 0x9C,
+0xAC, 0xEB, 0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF4, 0x80, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0xA0, 0xF4, 0xA4, 0x9D, 0x60, 0x9C, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF4, 0xB0, 0x9D,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF4,
+0x80, 0x9B, 0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF4,
+0xA4, 0x9D, 0x60, 0x9C, 0xAC, 0xEB, 0x30, 0xF0,
+0x20, 0x6D, 0xA0, 0xF4, 0xB4, 0x9D, 0xAD, 0xEB,
+0x60, 0xDC, 0x60, 0xF5, 0x60, 0x42, 0x1F, 0xF7,
+0x00, 0x6C, 0x8C, 0xEB, 0x02, 0xF0, 0x00, 0x73,
+0x10, 0x61, 0x2E, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF4, 0x80, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0xA0, 0xF4, 0xA4, 0x9D, 0x60, 0x9C, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF4, 0xB8, 0x9D,
+0xE6, 0x17, 0x1E, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF4, 0x6C, 0x9B, 0x1D, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF4, 0x80, 0x9B, 0x30, 0xF0,
+0x20, 0x6D, 0xA0, 0xF4, 0xA4, 0x9D, 0x60, 0x9C,
+0xAC, 0xEB, 0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF4,
+0xBC, 0x9D, 0xAD, 0xEB, 0x60, 0xDC, 0x60, 0xF5,
+0x60, 0x42, 0x1F, 0xF7, 0x00, 0x6C, 0x8C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x07, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF4, 0x68, 0x9B,
+0x69, 0xE2, 0x40, 0x9A, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF4, 0x6C, 0x9B, 0x69, 0xE2,
+0x40, 0x9A, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x05, 0x5C, 0xAC, 0xEA, 0x4B, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x88, 0x34, 0xA0, 0xF1, 0x04, 0x4B,
+0x8D, 0xE3, 0x60, 0x9B, 0x00, 0xEB, 0x05, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF4, 0x60, 0x9A,
+0x2D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF4,
+0x60, 0x9A, 0x20, 0x10, 0x05, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF4, 0x64, 0x9A, 0x22, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF4, 0x64, 0x9A,
+0x15, 0x10, 0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF4, 0x68, 0x9A, 0x17, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF4, 0x68, 0x9A, 0x0A, 0x10,
+0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF4,
+0x6C, 0x9A, 0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF4, 0x6C, 0x9A, 0x80, 0xA3, 0xF7, 0x6A,
+0x0A, 0x10, 0x0C, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF4, 0x70, 0x9A, 0x40, 0xA3, 0xFF, 0x6C,
+0x08, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF4, 0x70, 0x9A, 0xF7, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0xAC, 0xEA,
+0x13, 0x60, 0x03, 0x24, 0x02, 0x74, 0x15, 0x60,
+0x18, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0xA3, 0xF3, 0xD8, 0xA3, 0x01, 0x6D,
+0x4C, 0xED, 0x02, 0x6A, 0x4B, 0xEA, 0xCC, 0xEA,
+0xAD, 0xEA, 0xA3, 0xF3, 0x58, 0xC3, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x24, 0xF7, 0x4B, 0xC3,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF4,
+0x58, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF4,
+0x54, 0x9A, 0x60, 0xA2, 0x10, 0x6A, 0x6C, 0xEA,
+0x24, 0x22, 0x02, 0x5C, 0x03, 0x61, 0x02, 0x74,
+0x17, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0xA3, 0xF3, 0x98, 0xA3,
+0x01, 0x6A, 0x8C, 0xEA, 0xA3, 0xF3, 0x9B, 0xA3,
+0x7F, 0x6B, 0x5C, 0x32, 0x8C, 0xEB, 0x6D, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF4, 0x78, 0x9B, 0x40, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF4, 0x78, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF4, 0x5C, 0x9A,
+0x60, 0xC2, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x40, 0x9A, 0x60, 0xA2, 0xFF, 0x6A,
+0x6C, 0xEA, 0xFF, 0x72, 0x00, 0x6A, 0x0B, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4, 0x44, 0x9A,
+0x60, 0xA2, 0x07, 0x6A, 0x6C, 0xEA, 0x07, 0x6B,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x01, 0x74, 0xAC, 0xEA,
+0x03, 0x60, 0x02, 0x74, 0x09, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x02, 0x6B, 0xC3, 0xF3, 0x60, 0xC2, 0x15, 0x10,
+0x09, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xC0, 0xF0, 0x6E, 0xA2, 0xC3, 0xF3,
+0x60, 0xC2, 0x05, 0x10, 0xFF, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0x24, 0xF7, 0x50, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xC3, 0xF3,
+0x60, 0xA2, 0xA3, 0xF3, 0x98, 0xA2, 0xC3, 0xF3,
+0x61, 0xC2, 0x40, 0x6B, 0x8D, 0xEB, 0xA3, 0xF3,
+0x78, 0xC2, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x4D, 0x12, 0x01, 0x72, 0x01, 0x6B,
+0x10, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0xA3, 0xF3, 0x98, 0xA3, 0x04, 0x6A,
+0x8C, 0xEA, 0x02, 0x22, 0x02, 0x6B, 0x05, 0x10,
+0xC0, 0xF0, 0x68, 0xA3, 0x05, 0x5B, 0x0E, 0x61,
+0x08, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4,
+0x48, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x4C, 0x9A, 0x02, 0x6B, 0x60, 0xC2,
+0x00, 0x6A, 0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF4, 0x68, 0x9B, 0x40, 0xC3, 0x01, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0x4D, 0x12,
+0x01, 0x72, 0x01, 0x6B, 0x0A, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3,
+0x7C, 0xA2, 0x03, 0x6C, 0x6C, 0xEC, 0x07, 0x24,
+0x02, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4,
+0x48, 0x9A, 0x60, 0xC2, 0x31, 0x10, 0xC0, 0xF0,
+0x88, 0xA2, 0x02, 0x24, 0x04, 0x6B, 0xF5, 0x17,
+0x04, 0x6C, 0x6C, 0xEC, 0x02, 0x24, 0x08, 0x6B,
+0xF0, 0x17, 0x10, 0x6C, 0xA3, 0x67, 0x8C, 0xED,
+0x0A, 0x25, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4,
+0x48, 0x9A, 0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x50, 0x9A, 0xE6, 0x17, 0xA3, 0xF3,
+0x98, 0xA2, 0x20, 0x6B, 0x6C, 0xEC, 0xDD, 0x24,
+0x83, 0xF3, 0x78, 0xA2, 0x03, 0x23, 0x80, 0x6B,
+0x6B, 0xEB, 0xD7, 0x17, 0x23, 0xF4, 0x75, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF4,
+0x68, 0x9B, 0x40, 0xC3, 0x01, 0x6A, 0x07, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4, 0x4C, 0x9A,
+0x04, 0x6B, 0x60, 0xC2, 0x00, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6F,
+0x61, 0xF3, 0x10, 0x4B, 0xE0, 0xF4, 0x14, 0x9F,
+0xE0, 0xF0, 0xE0, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC,
+0x0C, 0xEF, 0x0E, 0xEF, 0x4C, 0xED, 0x4C, 0xEE,
+0x80, 0xF0, 0x16, 0x27, 0xA3, 0xF3, 0x19, 0xA3,
+0x20, 0x6F, 0x0C, 0xEF, 0x4C, 0xEF, 0x80, 0xF0,
+0x0B, 0x2F, 0xE0, 0xF0, 0x00, 0xA3, 0x01, 0x6F,
+0xEC, 0xE8, 0x4C, 0xE8, 0x54, 0x28, 0xA3, 0xF3,
+0x18, 0xA3, 0x0C, 0xEF, 0x4C, 0xEF, 0x09, 0x27,
+0xC3, 0xF3, 0x54, 0xA3, 0xE4, 0x42, 0x03, 0x4A,
+0xC3, 0xF3, 0xEF, 0xC3, 0xC3, 0xF3, 0x4E, 0xC3,
+0x08, 0x10, 0x05, 0x6F, 0xC3, 0xF3, 0xEF, 0xC3,
+0x05, 0x4E, 0x04, 0x6F, 0xC3, 0xF3, 0xEE, 0xC3,
+0x4C, 0xEE, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xC3, 0xF3, 0xED, 0xA2, 0xC3, 0xF3,
+0x6E, 0xA2, 0xE3, 0xEB, 0x09, 0x61, 0xC3, 0xF3,
+0x6F, 0xA2, 0xC3, 0xF3, 0xC2, 0xC2, 0x71, 0xE4,
+0xB7, 0xE4, 0xC3, 0xF3, 0xB0, 0xC2, 0x09, 0x10,
+0xC3, 0xF3, 0x8F, 0xA2, 0x77, 0xE5, 0xB9, 0xE6,
+0x6F, 0xE4, 0xC3, 0xF3, 0xC2, 0xC2, 0xC3, 0xF3,
+0x70, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xC3, 0xF3, 0x6F, 0xA2, 0xC3, 0xF3,
+0x90, 0xA2, 0x0A, 0x4B, 0x82, 0xEB, 0x02, 0x60,
+0xC3, 0xF3, 0x70, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xC3, 0xF3, 0x70, 0xA2,
+0xC3, 0xF3, 0x82, 0xA2, 0x23, 0x4B, 0x82, 0xEB,
+0x02, 0x60, 0xC3, 0xF3, 0x62, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xC3, 0xF3,
+0x70, 0xA2, 0xC3, 0xF3, 0x6A, 0xCA, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xC0, 0xF0,
+0x87, 0xA2, 0x18, 0x6B, 0x8C, 0xEB, 0x10, 0x73,
+0x0C, 0x61, 0xC3, 0xF3, 0x74, 0xA2, 0x03, 0x6C,
+0x04, 0x4B, 0xC3, 0xF3, 0x70, 0xC2, 0xC0, 0xF0,
+0x6A, 0xA2, 0x76, 0x33, 0x8C, 0xEB, 0xC3, 0xF3,
+0x62, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4,
+0x58, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x24, 0xF7,
+0x9A, 0xAC, 0xA0, 0xA2, 0xFF, 0x6B, 0x6C, 0xED,
+0x8E, 0xED, 0x02, 0x25, 0x8C, 0xEB, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA3, 0xF3, 0x99, 0xA2, 0x41, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xA3, 0xF3, 0x79, 0xC2, 0x04, 0x10,
+0x40, 0x6A, 0x0D, 0xEA, 0xA3, 0xF3, 0x59, 0xC3,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x02, 0x6B, 0x23, 0xF4, 0x6C, 0xC2, 0x03, 0x6B,
+0x23, 0xF4, 0x6D, 0xC2, 0x64, 0x6B, 0x23, 0xF4,
+0x6E, 0xCA, 0x05, 0x6B, 0x23, 0xF4, 0x70, 0xC2,
+0x23, 0xF4, 0x71, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xC3, 0xF3, 0x63, 0xA2,
+0xC0, 0xF0, 0x8B, 0xA2, 0x63, 0xEC, 0x22, 0x60,
+0xC3, 0xF3, 0x86, 0xA2, 0x01, 0x4C, 0xC3, 0xF3,
+0x86, 0xC2, 0xC3, 0xF3, 0xA6, 0xA2, 0x23, 0xF4,
+0x91, 0xA2, 0xA3, 0xEC, 0x17, 0x61, 0x03, 0x6D,
+0xB8, 0xEB, 0xC3, 0xF3, 0x8C, 0xA2, 0xC3, 0xF3,
+0xAD, 0xA2, 0x04, 0x6F, 0x01, 0x4C, 0xC3, 0xF3,
+0x8C, 0xC2, 0xC3, 0xF3, 0x82, 0xA2, 0xFE, 0x4C,
+0x12, 0xEB, 0x6D, 0xE4, 0xC3, 0xF3, 0x71, 0xC2,
+0xC3, 0xF3, 0x8C, 0xA2, 0xC3, 0xF3, 0xD1, 0xA2,
+0x00, 0x18, 0xAF, 0x12, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x44, 0xF7, 0x05, 0x4B, 0xFF, 0x6A, 0xA7, 0x43,
+0x8C, 0xEA, 0x26, 0x4D, 0x00, 0x6C, 0x80, 0xC3,
+0x01, 0x4B, 0x83, 0x67, 0xAE, 0xEC, 0xFA, 0x2C,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0xC3, 0xF3, 0x85, 0xC3, 0xC3, 0xF3, 0x86, 0xC3,
+0xC3, 0xF3, 0x8C, 0xC3, 0x01, 0x6C, 0x8E, 0xEA,
+0x05, 0x2A, 0x2D, 0x6C, 0xC3, 0xF3, 0x92, 0xC3,
+0xC3, 0xF3, 0x53, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0xE0, 0xF0, 0xC0, 0xA3,
+0x01, 0x6D, 0xFF, 0x6A, 0xCC, 0xED, 0x4C, 0xED,
+0x4C, 0xEC, 0x0C, 0x25, 0xC3, 0xF3, 0x45, 0xA3,
+0x01, 0x4A, 0xC3, 0xF3, 0x45, 0xC3, 0xC3, 0xF3,
+0xA5, 0xA3, 0x23, 0xF4, 0x4E, 0xAB, 0x43, 0xED,
+0xA0, 0xF0, 0x1E, 0x60, 0x00, 0x6D, 0x00, 0x18,
+0xBB, 0x11, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x03, 0xF4, 0x88, 0x9B, 0x03, 0xF4,
+0x44, 0xDB, 0x83, 0xEA, 0x31, 0x61, 0xA3, 0xF3,
+0xF8, 0xA3, 0x01, 0x6D, 0xFF, 0x6E, 0xEC, 0xED,
+0x0E, 0x25, 0xC3, 0xF3, 0xF4, 0xA3, 0xC3, 0xF3,
+0xB0, 0xA3, 0x93, 0xE2, 0x0E, 0x4F, 0xBF, 0xE7,
+0x23, 0xF4, 0xAC, 0xA3, 0x82, 0x34, 0x8A, 0x34,
+0xAF, 0xE7, 0x89, 0xE3, 0x0B, 0x10, 0x23, 0xF4,
+0xED, 0xA3, 0xC3, 0xF3, 0xB0, 0xA3, 0x8B, 0xE2,
+0xEB, 0xEF, 0xAF, 0xE7, 0x42, 0x32, 0x0A, 0x4B,
+0x4A, 0x32, 0x49, 0xE3, 0xCC, 0xEA, 0x2D, 0x5A,
+0x0F, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x69, 0xE2, 0xC3, 0xF3, 0x95, 0xA2,
+0x01, 0x4C, 0xC3, 0xF3, 0x95, 0xC2, 0xC3, 0xF3,
+0x45, 0xA3, 0x01, 0x4A, 0xC3, 0xF3, 0x45, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xC3, 0xF3, 0x85, 0xA2, 0x23, 0xF4, 0x6E, 0xAA,
+0x63, 0xEC, 0x7A, 0x60, 0x82, 0x10, 0xA0, 0xA4,
+0xAD, 0xE3, 0xFF, 0x6D, 0xAC, 0xEB, 0x63, 0xEE,
+0x02, 0x60, 0xC2, 0x67, 0x06, 0x10, 0x01, 0x4A,
+0xAC, 0xEA, 0x2D, 0x72, 0x01, 0x4C, 0xF3, 0x61,
+0x00, 0x6E, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x23, 0xF4, 0xEE, 0xAA, 0x23, 0xF4,
+0x50, 0xA2, 0x30, 0xF0, 0x20, 0x6D, 0x00, 0x6C,
+0x5F, 0xE7, 0x44, 0xF7, 0x05, 0x4D, 0x64, 0x67,
+0x40, 0xA5, 0x51, 0xE4, 0xFF, 0x6A, 0x4C, 0xEC,
+0x82, 0xEF, 0x06, 0x61, 0x01, 0x4B, 0x4C, 0xEB,
+0x2D, 0x73, 0x01, 0x4D, 0xF5, 0x61, 0x00, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xC3, 0xF3, 0xD2, 0xC2, 0xC3, 0xF3, 0x73, 0xC2,
+0xC3, 0xF3, 0x72, 0xA2, 0x0A, 0x5B, 0x05, 0x61,
+0xF6, 0x4B, 0xC3, 0xF3, 0x6D, 0xC2, 0x00, 0x6B,
+0x05, 0x10, 0x00, 0x6C, 0xC3, 0xF3, 0x8D, 0xC2,
+0x0A, 0x6C, 0x6F, 0xE4, 0xC3, 0xF3, 0x6C, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xC3, 0xF3, 0x72, 0xA2, 0xC3, 0xF3, 0x93, 0xA2,
+0xA3, 0xF3, 0xB8, 0xA2, 0x73, 0xE4, 0x01, 0x6B,
+0xAC, 0xEB, 0x03, 0x23, 0x23, 0xF4, 0x6C, 0xA2,
+0x02, 0x10, 0x23, 0xF4, 0x6D, 0xA2, 0x71, 0xE4,
+0x01, 0x4C, 0xC3, 0xF3, 0x91, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xC3, 0xF3,
+0x71, 0xA2, 0x0E, 0x5B, 0x03, 0x60, 0x0E, 0x6B,
+0xC3, 0xF3, 0x71, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xC3, 0xF3, 0x71, 0xA2,
+0xC3, 0xF3, 0x8C, 0xA2, 0xC3, 0xF3, 0xAD, 0xA2,
+0x02, 0x4B, 0xC3, 0xF3, 0x71, 0xC2, 0xC3, 0xF3,
+0xD1, 0xA2, 0x03, 0x6F, 0x00, 0x18, 0xAF, 0x12,
+0x00, 0x6C, 0x00, 0x18, 0x29, 0x13, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x00, 0x6B, 0x23, 0xF4,
+0xD0, 0xA2, 0x44, 0xF7, 0x05, 0x4C, 0x43, 0x67,
+0x7E, 0x17, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6D,
+0x61, 0xF3, 0x10, 0x4D, 0xC0, 0xF0, 0xD2, 0xA5,
+0x01, 0x6B, 0xFF, 0x6A, 0xCC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x06, 0x23, 0xC0, 0xF0, 0x54, 0xA5,
+0x01, 0x72, 0x02, 0x61, 0x00, 0x18, 0x87, 0x3F,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x0C, 0xEC, 0x02, 0x5C, 0xAC, 0xE8, 0x0B, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x7D, 0x3F, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0xA4, 0xA2, 0x90, 0x67,
+0x00, 0x18, 0x50, 0x40, 0x06, 0x10, 0x90, 0x67,
+0x00, 0x18, 0x87, 0x3F, 0x90, 0x67, 0x00, 0x18,
+0x8E, 0x3F, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x76, 0x40, 0x00, 0x6D, 0xC5, 0x67,
+0xFF, 0x6C, 0x00, 0x18, 0xC5, 0x3A, 0x01, 0x6C,
+0x0C, 0x6D, 0x00, 0x18, 0x26, 0x12, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x8C, 0xE8, 0x00, 0x18,
+0x76, 0x40, 0x05, 0x20, 0x00, 0x6D, 0xFF, 0x6C,
+0xC5, 0x67, 0x00, 0x18, 0xC5, 0x3A, 0x01, 0x6C,
+0x04, 0x6D, 0x00, 0x18, 0x26, 0x12, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x2E, 0x6E, 0xFF, 0x6C,
+0x6F, 0x6D, 0x00, 0x18, 0xC5, 0x3A, 0x01, 0x6C,
+0x02, 0x6D, 0x00, 0x18, 0x26, 0x12, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6C, 0xA4, 0x67, 0x2F, 0x6E, 0x00, 0x18,
+0xC5, 0x3A, 0x00, 0x18, 0x5B, 0x40, 0x00, 0x18,
+0xCC, 0x40, 0x01, 0x6C, 0x08, 0x6D, 0x00, 0x18,
+0x26, 0x12, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF2, 0x68, 0x9A,
+0x20, 0xF2, 0x08, 0x4A, 0xFF, 0x69, 0x04, 0xD3,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0x9A, 0x2C, 0xEC,
+0x44, 0xAA, 0x61, 0xF3, 0x10, 0x48, 0x08, 0xD4,
+0xE0, 0xF0, 0x88, 0xA0, 0x05, 0xD3, 0x7D, 0x67,
+0x4C, 0xCB, 0x00, 0x18, 0x86, 0x11, 0x01, 0x72,
+0x2A, 0x61, 0xC0, 0xF0, 0x64, 0xA0, 0x7F, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x24, 0x22, 0xC0, 0xF0,
+0x65, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA, 0x01, 0x72,
+0x1E, 0x61, 0x08, 0x93, 0x1F, 0xF7, 0x00, 0x6C,
+0x64, 0x32, 0x7D, 0x67, 0x49, 0xE3, 0x68, 0xAA,
+0x41, 0x43, 0x8C, 0xEA, 0x02, 0xF0, 0x00, 0x72,
+0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x40, 0x9A, 0x4D, 0xE3,
+0x60, 0xA3, 0x20, 0x6A, 0x6C, 0xEA, 0x4B, 0xEA,
+0xC0, 0xF7, 0x42, 0x32, 0x01, 0x10, 0x01, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF4, 0xB7, 0xA3,
+0x04, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x09, 0x23, 0x7D, 0x67, 0x1E, 0x6A,
+0x50, 0xC3, 0x01, 0x6A, 0x92, 0xC3, 0x4F, 0xCB,
+0x04, 0x04, 0x00, 0x18, 0x2B, 0x2D, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xFF, 0x68, 0x8C, 0xE8, 0xA3, 0xF3,
+0x98, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x41, 0x6D,
+0x8C, 0xEB, 0xAB, 0xED, 0xAC, 0xEB, 0xA3, 0xF3,
+0xB9, 0xA2, 0xA3, 0xF3, 0x78, 0xC2, 0x11, 0x6B,
+0x00, 0x6C, 0x6B, 0xEB, 0xC3, 0xF3, 0x83, 0xC2,
+0xA3, 0xF3, 0x9C, 0xC2, 0xAC, 0xEB, 0xC3, 0xF3,
+0x84, 0xC2, 0x90, 0x67, 0xA3, 0xF3, 0x79, 0xC2,
+0x00, 0x18, 0x8E, 0x3F, 0x90, 0x67, 0x00, 0x18,
+0x87, 0x3F, 0x90, 0x67, 0x00, 0x18, 0x9C, 0x3F,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0xFF, 0x69, 0x61, 0xF3,
+0x10, 0x48, 0x8C, 0xE9, 0xE0, 0xF0, 0x88, 0xA0,
+0x00, 0x18, 0x86, 0x11, 0x01, 0x72, 0x2C, 0x61,
+0xA3, 0xF3, 0x79, 0xA0, 0x09, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6C, 0x6F, 0x6D, 0x2C, 0x6E,
+0xA3, 0xF3, 0x59, 0xC0, 0x00, 0x18, 0xC5, 0x3A,
+0xA0, 0xF0, 0x8A, 0xA0, 0x01, 0x6D, 0x08, 0x6E,
+0xF1, 0x67, 0x00, 0x18, 0x71, 0x19, 0x01, 0x72,
+0x0B, 0x61, 0xA3, 0xF3, 0x79, 0xA0, 0x02, 0x6A,
+0x01, 0x6C, 0x6D, 0xEA, 0x0E, 0x6D, 0xA3, 0xF3,
+0x59, 0xC0, 0x00, 0x18, 0x26, 0x12, 0x0C, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4, 0x4C, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x48, 0x9A, 0x02, 0x6B, 0x60, 0xC2,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xF0, 0x6D, 0x01, 0x6C, 0x00, 0x18, 0x26, 0x12,
+0x00, 0x6C, 0x00, 0x18, 0xC7, 0x3F, 0x00, 0x18,
+0x1E, 0x3A, 0x00, 0x18, 0xDD, 0x39, 0x01, 0x6C,
+0x00, 0x18, 0xC7, 0x3F, 0x01, 0x6C, 0x00, 0x6D,
+0x00, 0x18, 0x26, 0x12, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF5, 0x64, 0x9B, 0xFF, 0x6A, 0x24, 0x67,
+0x00, 0xA3, 0x82, 0x67, 0xA2, 0x67, 0x2D, 0x6E,
+0x4C, 0xE9, 0x4C, 0xE8, 0x00, 0x18, 0xC5, 0x3A,
+0x00, 0x18, 0x5B, 0x40, 0x06, 0x2A, 0xFF, 0x6C,
+0xB0, 0x67, 0x2D, 0x6E, 0x00, 0x18, 0xC5, 0x3A,
+0x2C, 0x10, 0x05, 0x59, 0x24, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x28, 0x31, 0xA0, 0xF1, 0x18, 0x4A,
+0x29, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x00, 0x6C,
+0x08, 0x6D, 0x17, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0x80, 0xF4, 0xB8, 0x9A, 0x11, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0x00, 0xF5,
+0xA8, 0x9A, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0x00, 0xF5, 0xAC, 0x9A, 0x05, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0xB0, 0x9A,
+0x04, 0x6C, 0x00, 0x18, 0x0C, 0x07, 0x00, 0x18,
+0xCC, 0x40, 0x01, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x26, 0x12, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x24, 0xF7, 0xA9, 0xA3,
+0x08, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xEC, 0x03, 0x2B, 0x01, 0x6C, 0x0C, 0x6D,
+0x05, 0x10, 0x01, 0x6D, 0x00, 0x18, 0x7B, 0x47,
+0x01, 0x6C, 0x04, 0x6D, 0x00, 0x18, 0x26, 0x12,
+0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67, 0x00, 0x18,
+0xC5, 0x3A, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x24, 0xF7, 0xA9, 0xA3, 0x04, 0x6B, 0xFF, 0x6A,
+0xAC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x06, 0x2B,
+0x03, 0x6D, 0x00, 0x18, 0x7B, 0x47, 0x01, 0x6C,
+0x04, 0x6D, 0x05, 0x10, 0x00, 0x6D, 0x00, 0x18,
+0x7B, 0x47, 0x01, 0x6C, 0x0C, 0x6D, 0x00, 0x18,
+0x26, 0x12, 0x00, 0x6D, 0xFF, 0x6C, 0xC5, 0x67,
+0x00, 0x18, 0xC5, 0x3A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x6D, 0x00, 0x18,
+0x7B, 0x47, 0x00, 0x6D, 0xC5, 0x67, 0xFF, 0x6C,
+0x00, 0x18, 0xC5, 0x3A, 0x01, 0x6C, 0x0C, 0x6D,
+0x00, 0x18, 0x26, 0x12, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x2C, 0xEC,
+0xAC, 0xE9, 0x3A, 0x24, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xE0, 0xF0, 0x88, 0xA0,
+0x00, 0x18, 0x86, 0x11, 0x01, 0x72, 0x30, 0x61,
+0xA3, 0xF3, 0x79, 0xA0, 0x05, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x2B, 0x6E, 0xFF, 0x6C, 0x0F, 0x6D,
+0xA3, 0xF3, 0x59, 0xC0, 0x00, 0x18, 0xC5, 0x3A,
+0x91, 0x67, 0x02, 0x6D, 0x00, 0x18, 0x7B, 0x47,
+0xA0, 0xF0, 0x8A, 0xA0, 0x00, 0x6D, 0x08, 0x6E,
+0xF1, 0x67, 0x00, 0x18, 0x71, 0x19, 0x01, 0x72,
+0x0B, 0x61, 0xA3, 0xF3, 0x79, 0xA0, 0x01, 0x6A,
+0x01, 0x6C, 0x6D, 0xEA, 0x06, 0x6D, 0xA3, 0xF3,
+0x59, 0xC0, 0x00, 0x18, 0x26, 0x12, 0x0C, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4, 0x4C, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x48, 0x9A, 0x08, 0x6B, 0x60, 0xC2,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x25, 0x67, 0x30, 0xF0,
+0x20, 0x6D, 0x61, 0xF3, 0x10, 0x4D, 0x06, 0x67,
+0xA3, 0xF3, 0xD9, 0xA5, 0x03, 0x6B, 0xFF, 0x6A,
+0xCC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x4C, 0xE9,
+0x4C, 0xE8, 0xE0, 0xF0, 0x03, 0x2B, 0xA3, 0xF3,
+0x5B, 0xA5, 0x8E, 0xEA, 0xC0, 0xF0, 0x1E, 0x22,
+0x0D, 0x5C, 0xC0, 0xF0, 0x1B, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x88, 0x34, 0xC0, 0xF1, 0x0C, 0x4A,
+0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2, 0x0E, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x89, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2,
+0x03, 0x2A, 0x01, 0x6C, 0x00, 0x18, 0xD1, 0x13,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2,
+0x06, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x98, 0x14, 0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7,
+0x4B, 0xA2, 0x04, 0x72, 0x09, 0x61, 0x05, 0x21,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0xB3, 0x14,
+0x03, 0x10, 0x90, 0x67, 0x00, 0x18, 0xA9, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2,
+0x08, 0x72, 0xA0, 0xF0, 0x03, 0x61, 0x00, 0x18,
+0xC9, 0x13, 0xA0, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x4B, 0xA2, 0x03, 0x2A, 0x01, 0x6C,
+0x00, 0x18, 0xD1, 0x13, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x4B, 0xA2, 0x06, 0x72, 0x03, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x98, 0x14, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2, 0x0E, 0x72,
+0x07, 0x61, 0x00, 0x18, 0x6F, 0x12, 0x01, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x89, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2,
+0x0C, 0x72, 0x7C, 0x61, 0x00, 0x18, 0x6F, 0x12,
+0x01, 0x72, 0x78, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x36, 0x14, 0x74, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x4B, 0xA2, 0x0E, 0x72, 0x07, 0x61,
+0x00, 0x18, 0x6F, 0x12, 0x01, 0x72, 0x03, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x89, 0x14, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2, 0x06, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x98, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2,
+0x0C, 0x72, 0x07, 0x61, 0x00, 0x18, 0x6F, 0x12,
+0x01, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x36, 0x14, 0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7,
+0x4B, 0xA2, 0x04, 0x72, 0x4B, 0x61, 0x00, 0x18,
+0x86, 0x12, 0x01, 0x72, 0x47, 0x61, 0x90, 0x67,
+0x00, 0x18, 0x63, 0x14, 0x43, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2, 0x0E, 0x72,
+0x07, 0x61, 0x00, 0x18, 0x6F, 0x12, 0x01, 0x72,
+0x03, 0x61, 0x90, 0x67, 0x00, 0x18, 0x89, 0x14,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2,
+0x06, 0x72, 0x03, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x98, 0x14, 0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7,
+0x4B, 0xA2, 0x0C, 0x72, 0x07, 0x61, 0x00, 0x18,
+0x6F, 0x12, 0x01, 0x72, 0x03, 0x61, 0x90, 0x67,
+0x00, 0x18, 0x36, 0x14, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x4B, 0xA2, 0x03, 0x2A, 0x01, 0x6C,
+0x00, 0x18, 0xD1, 0x13, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x4B, 0xA2, 0x04, 0x72, 0x12, 0x61,
+0x00, 0x18, 0xDC, 0x13, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3,
+0x7B, 0xA2, 0x0C, 0x73, 0x07, 0x61, 0xA3, 0xF3,
+0x78, 0xA2, 0x20, 0x6A, 0x6C, 0xEA, 0x02, 0x22,
+0x00, 0x18, 0xE3, 0x13, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x61, 0xF3, 0x10, 0x48, 0x05, 0xD4, 0xC0, 0xF0,
+0x94, 0xA0, 0x2C, 0xED, 0x04, 0xD5, 0x00, 0x18,
+0xBA, 0x13, 0x05, 0x92, 0x01, 0x72, 0x09, 0x61,
+0xC0, 0xF0, 0x64, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x1C, 0x2A, 0x00, 0x18, 0xE3, 0x13,
+0x19, 0x10, 0x04, 0x94, 0x00, 0x18, 0x87, 0x3F,
+0x04, 0x94, 0x00, 0x18, 0x8E, 0x3F, 0xC0, 0xF0,
+0x64, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x0B, 0x22, 0xA3, 0xF3, 0x5B, 0xA0, 0x04, 0x6B,
+0x6C, 0xEA, 0x08, 0x2A, 0x04, 0x96, 0x83, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0xD7, 0x14, 0x02, 0x10,
+0x00, 0x18, 0xC9, 0x13, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0xA4, 0x67,
+0x23, 0xF4, 0x94, 0xA3, 0xFF, 0x6A, 0x4C, 0xED,
+0x04, 0x24, 0xFF, 0x4C, 0x23, 0xF4, 0x94, 0xC3,
+0x3B, 0x10, 0xC0, 0xF0, 0x93, 0xA3, 0xFF, 0x4C,
+0x23, 0xF4, 0x94, 0xC3, 0x23, 0xF4, 0x95, 0xA3,
+0x02, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x03, 0x2B,
+0x00, 0x6C, 0x00, 0x18, 0x56, 0x15, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0x82, 0xA2, 0x04, 0x6A,
+0xFF, 0x6B, 0x8C, 0xEA, 0x25, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF4, 0x58, 0x9A, 0x80, 0xA2,
+0x00, 0x6A, 0x6C, 0xEC, 0x03, 0x5C, 0x02, 0x61,
+0x4D, 0x44, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xC0, 0xF0, 0xD5, 0xA0,
+0x0A, 0x6B, 0x10, 0xF0, 0x20, 0x6C, 0x78, 0xEE,
+0x00, 0x6B, 0xA3, 0x67, 0xEA, 0xF6, 0x1D, 0x4C,
+0x01, 0x6F, 0x04, 0xD3, 0x12, 0xEE, 0x5B, 0xE6,
+0x00, 0x18, 0x66, 0x3B, 0x23, 0xF4, 0x75, 0xA0,
+0x01, 0x6A, 0x6D, 0xEA, 0x23, 0xF4, 0x55, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x23, 0xF4, 0x95, 0xA2, 0x03, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x23, 0xF4, 0x75, 0xC2, 0x07, 0x97,
+0x06, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x24, 0x67, 0xC0, 0xF0, 0x92, 0xA0, 0x01, 0x6B,
+0xFF, 0x6A, 0x8C, 0xEB, 0x4C, 0xEB, 0x4C, 0xE9,
+0x0C, 0x23, 0xC0, 0xF0, 0x54, 0xA0, 0x02, 0x5A,
+0x08, 0x61, 0x91, 0x67, 0x00, 0x18, 0x74, 0x15,
+0xC0, 0xF0, 0xB4, 0xA0, 0x91, 0x67, 0x00, 0x18,
+0x50, 0x40, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6D, 0x61, 0xF3, 0x10, 0x4D,
+0xC0, 0xF0, 0xD2, 0xA5, 0x01, 0x6B, 0xFF, 0x6A,
+0xCC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x06, 0x23,
+0xC0, 0xF0, 0x54, 0xA5, 0x01, 0x72, 0x02, 0x61,
+0x00, 0x18, 0x74, 0x15, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xC0, 0xF0, 0x92, 0xA2, 0x04, 0x6B, 0x8C, 0xEB,
+0x0B, 0x23, 0x23, 0xF4, 0x95, 0xA2, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x00, 0x6D, 0x01, 0x6C,
+0x23, 0xF4, 0x75, 0xC2, 0x00, 0x18, 0x56, 0x15,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x24, 0x67, 0xA3, 0xF3, 0x9C, 0xA0, 0x10, 0x6B,
+0xFF, 0x6A, 0x8D, 0xEB, 0xE0, 0xF0, 0x80, 0xA0,
+0xA3, 0xF3, 0x7C, 0xC0, 0x01, 0x6B, 0x8C, 0xEB,
+0x4C, 0xEB, 0x4C, 0xE9, 0x22, 0x23, 0xE0, 0xF0,
+0x42, 0xA0, 0xFF, 0x72, 0x46, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x54, 0x9A, 0x00, 0x6B,
+0xFF, 0x6C, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF5, 0x58, 0x9A, 0x04, 0x6B, 0x59, 0x4C,
+0x60, 0xC2, 0x00, 0x6D, 0x05, 0x6E, 0x00, 0x18,
+0x1A, 0x34, 0xE0, 0xF0, 0xC2, 0xA0, 0xFF, 0x6C,
+0x55, 0x4C, 0x00, 0x6D, 0x05, 0x4E, 0x00, 0x18,
+0x1A, 0x34, 0x91, 0x67, 0x00, 0x18, 0xA6, 0x3F,
+0x28, 0x10, 0xC3, 0xF3, 0x43, 0xA0, 0x02, 0x5A,
+0x0D, 0x60, 0xC3, 0xF3, 0xC2, 0xA0, 0xFF, 0x6C,
+0x55, 0x4C, 0xD9, 0xE2, 0x00, 0x6D, 0x00, 0x18,
+0x1A, 0x34, 0xC3, 0xF3, 0x63, 0xA0, 0xC3, 0xF3,
+0x42, 0xA0, 0x14, 0x10, 0x03, 0x6B, 0x78, 0xEA,
+0xC3, 0xF3, 0xC2, 0xA0, 0xFF, 0x6C, 0x55, 0x4C,
+0xFE, 0x4E, 0x00, 0x6D, 0x12, 0xEA, 0x59, 0xE6,
+0x00, 0x18, 0x1A, 0x34, 0xC3, 0xF3, 0x43, 0xA0,
+0x03, 0x6C, 0xC3, 0xF3, 0x62, 0xA0, 0x98, 0xEA,
+0xFE, 0x4B, 0x12, 0xEA, 0x49, 0xE3, 0xC3, 0xF3,
+0x51, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x23, 0xF4, 0x95, 0xA2, 0x02, 0x6B,
+0x8D, 0xEB, 0x23, 0xF4, 0x75, 0xC2, 0xA3, 0xF3,
+0x5B, 0xA2, 0x04, 0x6B, 0x6C, 0xEA, 0x05, 0x2A,
+0x83, 0x67, 0x01, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xD7, 0x14, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x24, 0x67, 0xC0, 0xF0,
+0x84, 0xA0, 0x00, 0x6B, 0xC3, 0xF3, 0x67, 0xC0,
+0x7F, 0x6B, 0xFF, 0x6A, 0x8C, 0xEB, 0x4C, 0xEB,
+0x4C, 0xE9, 0x22, 0x23, 0xE0, 0xF0, 0x88, 0xA0,
+0x00, 0x18, 0x86, 0x11, 0x01, 0x72, 0x78, 0x67,
+0x04, 0xD3, 0x1A, 0x2B, 0xC3, 0xF3, 0xA0, 0xA0,
+0x91, 0x67, 0x00, 0x18, 0x50, 0x40, 0x91, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0xBB, 0x11, 0xA3, 0xF3,
+0x79, 0xA0, 0x03, 0xF4, 0x48, 0xD8, 0x20, 0x6A,
+0x6D, 0xEA, 0xA3, 0xF3, 0x59, 0xC0, 0x5D, 0x67,
+0x67, 0x42, 0x09, 0x4B, 0x40, 0xA3, 0x91, 0x67,
+0xC3, 0xF3, 0x41, 0xC0, 0x00, 0x18, 0xCC, 0x15,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xC0, 0xF0, 0x64, 0xA0,
+0x00, 0x6A, 0xC3, 0xF3, 0x47, 0xC0, 0x7F, 0x6A,
+0xFF, 0x69, 0x6C, 0xEA, 0x2C, 0xEC, 0x2C, 0xEA,
+0x04, 0xD4, 0x1F, 0x22, 0xE0, 0xF0, 0x88, 0xA0,
+0x00, 0x18, 0x86, 0x11, 0x01, 0x72, 0x19, 0x61,
+0x04, 0x94, 0x00, 0x6D, 0x00, 0x18, 0xBB, 0x11,
+0x03, 0xF4, 0x48, 0xD8, 0xA3, 0xF3, 0x59, 0xA0,
+0xC0, 0xF0, 0x85, 0xA0, 0x20, 0x6B, 0x4D, 0xEB,
+0x0F, 0x6A, 0x8C, 0xEA, 0x2C, 0xEA, 0xA3, 0xF3,
+0x79, 0xC0, 0x04, 0x22, 0x10, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x03, 0x2A, 0x04, 0x94, 0x00, 0x18,
+0xCC, 0x15, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xFF, 0x6E, 0x8C, 0xEE,
+0x21, 0xF4, 0x98, 0xA2, 0x01, 0x6D, 0x00, 0x18,
+0xD7, 0x14, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xC0, 0xF0, 0x52, 0xA0, 0x02, 0x69, 0x2C, 0xEA,
+0x14, 0x2A, 0x00, 0x18, 0xAC, 0x2B, 0x01, 0x6B,
+0x14, 0x2A, 0x23, 0xF4, 0x78, 0xA0, 0x01, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x08, 0x6B,
+0x0C, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x5C, 0x9A, 0x04, 0x6B, 0x40, 0xA2, 0x4C, 0xE9,
+0x04, 0x21, 0x00, 0x18, 0xB4, 0x2B, 0x0E, 0x2A,
+0x40, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4,
+0x48, 0x9A, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x4C, 0x9A, 0x08, 0x6B, 0x60, 0xC2,
+0x00, 0x6A, 0x17, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x48, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF4, 0x6C, 0x9B,
+0x08, 0x6A, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF4, 0x70, 0x9B, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF5, 0x60, 0x9B, 0x40, 0xC3,
+0x01, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7, 0x4B, 0xA2,
+0x02, 0x22, 0x08, 0x72, 0x06, 0x61, 0x00, 0x18,
+0x4A, 0x16, 0x01, 0x72, 0x02, 0x61, 0x00, 0x18,
+0x57, 0x14, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x68, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x02, 0x22, 0x00, 0x18, 0x71, 0x16, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF4, 0x17, 0x4C,
+0x00, 0x6D, 0x07, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6C, 0x24, 0xF7, 0x08, 0x4C,
+0x00, 0x6D, 0x74, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x07, 0x6E, 0x41, 0xF4,
+0x02, 0x4C, 0x00, 0x6D, 0x30, 0xF0, 0x20, 0x68,
+0x00, 0x18, 0x6B, 0x2C, 0x61, 0xF3, 0x10, 0x48,
+0x02, 0x6A, 0xC0, 0xF0, 0x46, 0xC0, 0x01, 0x6A,
+0xC3, 0xF3, 0x40, 0xC0, 0xC3, 0xF3, 0x41, 0xC0,
+0x05, 0x6A, 0xC3, 0xF3, 0x4A, 0xC8, 0xC3, 0xF3,
+0x54, 0xA0, 0x0E, 0x69, 0xC3, 0xF3, 0x22, 0xC0,
+0x04, 0x4A, 0xC3, 0xF3, 0x50, 0xC0, 0xC3, 0xF3,
+0x31, 0xC0, 0x00, 0x18, 0x06, 0x13, 0x00, 0x6C,
+0xA4, 0x67, 0x00, 0x18, 0x26, 0x12, 0x02, 0x6C,
+0x0C, 0x6D, 0x00, 0x18, 0x26, 0x12, 0x01, 0x6C,
+0x0C, 0x6D, 0x00, 0x18, 0x26, 0x12, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0x6D, 0x24, 0xF7, 0x18, 0x4C,
+0x00, 0x18, 0xB4, 0x3F, 0xC0, 0xF0, 0x6D, 0xA0,
+0x03, 0x6A, 0xC0, 0xF0, 0x4B, 0xC0, 0x0F, 0x6A,
+0xC0, 0xF0, 0x4C, 0xC0, 0x01, 0x6A, 0x6C, 0xEA,
+0x28, 0x6B, 0x6D, 0xEA, 0xC0, 0xF0, 0x4D, 0xC0,
+0x07, 0x6A, 0xC0, 0xF0, 0x4E, 0xC0, 0xC3, 0xF3,
+0x54, 0xA0, 0x01, 0x6C, 0xC3, 0xF3, 0x31, 0xC0,
+0x04, 0x4A, 0xC3, 0xF3, 0x50, 0xC0, 0x00, 0x18,
+0x29, 0x13, 0x00, 0x6C, 0xA4, 0x67, 0x00, 0x18,
+0x7B, 0x47, 0x01, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x7B, 0x47, 0x02, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x7B, 0x47, 0x03, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x7B, 0x47, 0x04, 0x6C, 0x00, 0x6D, 0x00, 0x18,
+0x7B, 0x47, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x64, 0x9A, 0xFC, 0x6A, 0x00, 0x6D, 0x80, 0xA3,
+0xC5, 0x67, 0x8C, 0xEA, 0x40, 0xC3, 0xFF, 0x6C,
+0x00, 0x18, 0xC5, 0x3A, 0x00, 0x6A, 0x83, 0xF3,
+0x58, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x68, 0x9A, 0xF8, 0x6A, 0x80, 0xA3, 0x8C, 0xEA,
+0x40, 0xC3, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x24, 0xF7, 0xA8, 0xA3, 0x04, 0x6B, 0xFF, 0x6A,
+0xAC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x06, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0x54, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x02, 0x6D, 0x00, 0x18,
+0x98, 0x39, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x58, 0x9A, 0x04, 0x69, 0x30, 0xF0, 0x20, 0x68,
+0x20, 0xDA, 0x61, 0xF3, 0x10, 0x48, 0xC0, 0xF0,
+0xCD, 0xA0, 0xFF, 0x6C, 0x59, 0x4C, 0x00, 0x6D,
+0xC6, 0x36, 0x00, 0x18, 0x1A, 0x34, 0xA3, 0xF3,
+0x58, 0xA0, 0x07, 0x97, 0x4D, 0xE9, 0xA3, 0xF3,
+0x38, 0xC0, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0xC0, 0xF0, 0xA4, 0xA3, 0x04, 0x67,
+0x7F, 0x6C, 0xAC, 0xEC, 0xFF, 0x6A, 0x01, 0x74,
+0x4C, 0xE8, 0x1D, 0x61, 0xC0, 0xF0, 0xA5, 0xA3,
+0x10, 0x6C, 0x8B, 0xEC, 0xAC, 0xEC, 0x4C, 0xEC,
+0x0E, 0x24, 0xD0, 0x67, 0x0C, 0x6C, 0x00, 0x6D,
+0x00, 0x18, 0xD7, 0x14, 0x00, 0x6D, 0xFF, 0x6C,
+0xC5, 0x67, 0x00, 0x18, 0xC5, 0x3A, 0x90, 0x67,
+0x00, 0x18, 0xCF, 0x16, 0x08, 0x10, 0xA3, 0xF3,
+0x5B, 0xA3, 0x05, 0x2A, 0x04, 0x6C, 0x01, 0x6D,
+0xD0, 0x67, 0x00, 0x18, 0xD7, 0x14, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0xE9, 0x16, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x30, 0xF0, 0x20, 0x68, 0x91, 0x67, 0x61, 0xF3,
+0x10, 0x48, 0x00, 0x18, 0xCF, 0x16, 0xA3, 0xF3,
+0x5B, 0xA0, 0x0C, 0x72, 0x17, 0x60, 0x0C, 0x6C,
+0x00, 0x6D, 0xD1, 0x67, 0x00, 0x18, 0xD7, 0x14,
+0x00, 0x6D, 0xC5, 0x67, 0xFF, 0x6C, 0x00, 0x18,
+0xC5, 0x3A, 0xA3, 0xF3, 0x79, 0xA0, 0xA0, 0xF0,
+0x8A, 0xA0, 0x01, 0x6A, 0x6D, 0xEA, 0x00, 0x6D,
+0x08, 0x6E, 0xF1, 0x67, 0xA3, 0xF3, 0x59, 0xC0,
+0x00, 0x18, 0x71, 0x19, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0xA3, 0xF3, 0xB8, 0xA3, 0x24, 0x67, 0x40, 0x6C,
+0xFF, 0x6A, 0xAC, 0xEC, 0x4C, 0xEC, 0x4C, 0xE9,
+0x0D, 0x24, 0xA3, 0xF3, 0xB9, 0xA3, 0x10, 0x6C,
+0xAC, 0xEC, 0x4C, 0xEC, 0x07, 0x24, 0xC0, 0xF0,
+0x54, 0xA3, 0x01, 0x72, 0x03, 0x60, 0x91, 0x67,
+0x00, 0x18, 0xA6, 0x3F, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xA3, 0xF3, 0x78, 0xA0,
+0x02, 0x6A, 0x6C, 0xEA, 0x10, 0x22, 0x03, 0x6A,
+0x4B, 0xEA, 0x4C, 0xEB, 0xA3, 0xF3, 0x78, 0xC0,
+0xA3, 0xF3, 0x7C, 0xA0, 0x6C, 0xEA, 0xA3, 0xF3,
+0x5C, 0xC0, 0xA3, 0xF3, 0x5C, 0xA0, 0x07, 0x6B,
+0x6C, 0xEA, 0x70, 0x2A, 0x6C, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0x8C, 0x9A, 0xFF, 0xF7,
+0x1F, 0x6A, 0x60, 0xAC, 0x4C, 0xEB, 0x01, 0x4B,
+0x4C, 0xEB, 0x60, 0xCC, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF5, 0x90, 0x9B, 0x60, 0xAC, 0x4C, 0xEB,
+0x01, 0x4B, 0x4C, 0xEB, 0x60, 0xCC, 0x23, 0xF4,
+0x48, 0x98, 0xA3, 0xF3, 0x7C, 0xA0, 0x01, 0x4A,
+0x23, 0xF4, 0x48, 0xD8, 0xC3, 0xF3, 0x43, 0xA0,
+0x01, 0x4A, 0xC3, 0xF3, 0x43, 0xC0, 0x11, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xA3, 0xF3, 0x5C, 0xC0,
+0xC3, 0xF3, 0x63, 0xA0, 0xC0, 0xF0, 0x4B, 0xA0,
+0x63, 0xEA, 0x41, 0x60, 0xE0, 0xF0, 0x88, 0xA0,
+0x00, 0x18, 0x86, 0x11, 0x01, 0x72, 0x3E, 0x61,
+0xE0, 0xF0, 0x60, 0xA0, 0x01, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x02, 0x2A, 0x00, 0x18,
+0x10, 0x13, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xC0, 0xF0, 0x85, 0xA2, 0x10, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xFF, 0x6C, 0x8C, 0xEB,
+0x07, 0x2B, 0xA3, 0xF3, 0x98, 0xA2, 0xDF, 0x4B,
+0x8C, 0xEB, 0xA3, 0xF3, 0x78, 0xC2, 0x22, 0x10,
+0xC3, 0xF3, 0x64, 0xA2, 0x01, 0x4B, 0xC3, 0xF3,
+0x64, 0xC2, 0xC3, 0xF3, 0x64, 0xA2, 0x03, 0x5B,
+0x0B, 0x61, 0xA3, 0xF3, 0x98, 0xA2, 0x21, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA3, 0xF3, 0x78, 0xC2,
+0x00, 0x6B, 0xC3, 0xF3, 0x64, 0xC2, 0x03, 0x10,
+0x91, 0x67, 0x00, 0x18, 0x07, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x00, 0x6B,
+0xC3, 0xF3, 0x63, 0xC2, 0x03, 0x10, 0x91, 0x67,
+0x00, 0x18, 0x43, 0x16, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0x8C, 0xEA,
+0x40, 0xF2, 0x80, 0x9B, 0x40, 0xF2, 0x00, 0x4B,
+0x04, 0xD4, 0x81, 0x9B, 0x64, 0xAB, 0x05, 0xD4,
+0x9D, 0x67, 0x6C, 0xCC, 0x44, 0x33, 0x6D, 0xE4,
+0x88, 0xAB, 0x1F, 0xF7, 0x00, 0x6B, 0x8C, 0xEB,
+0x02, 0xF0, 0x00, 0x73, 0x01, 0x60, 0x0B, 0x2B,
+0x9D, 0x67, 0x44, 0x33, 0x6D, 0xE4, 0x88, 0xAB,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF5, 0x74, 0x9B,
+0x6D, 0xE4, 0x60, 0xAB, 0x06, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF5, 0x78, 0x9B, 0x71, 0xE4,
+0x60, 0xAC, 0xFF, 0xF7, 0x1F, 0x68, 0x6C, 0xE8,
+0x18, 0xF0, 0x00, 0x6B, 0x0C, 0xEB, 0x13, 0x2B,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF3, 0x10, 0x4C,
+0xA3, 0xF3, 0xBC, 0xA4, 0xFE, 0x4B, 0xAC, 0xEB,
+0x05, 0x6D, 0xAB, 0xED, 0xAC, 0xEB, 0x02, 0x4D,
+0xAC, 0xEB, 0xA3, 0xF3, 0x7C, 0xC4, 0x82, 0x67,
+0x00, 0x18, 0x43, 0x16, 0x57, 0x10, 0x08, 0xF0,
+0x00, 0x6B, 0x0C, 0xEB, 0x20, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0xC0, 0xF0,
+0xA4, 0xA3, 0x7F, 0x6C, 0xAC, 0xEC, 0x01, 0x74,
+0x24, 0x61, 0xA3, 0xF3, 0xBC, 0xA3, 0x01, 0x6C,
+0xAD, 0xEC, 0xA3, 0xF3, 0x9C, 0xC3, 0xC0, 0xF0,
+0x85, 0xA3, 0x10, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xFF, 0x6C, 0x8C, 0xEB, 0x20, 0x73, 0x03, 0x60,
+0x00, 0x18, 0x3B, 0x19, 0x12, 0x10, 0x82, 0x67,
+0x00, 0x18, 0x07, 0x17, 0x0E, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0xA3, 0xF3,
+0x9C, 0xA3, 0x02, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0x05, 0x6C, 0x8B, 0xEC, 0x8C, 0xEA, 0xA3, 0xF3,
+0x5C, 0xC3, 0x02, 0x30, 0x1E, 0x30, 0x17, 0x20,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xA3, 0xF3, 0x5C, 0xA0, 0x02, 0x69, 0xC0, 0xF0,
+0xCC, 0xA0, 0x2D, 0xEA, 0xFF, 0x6C, 0xA3, 0xF3,
+0x5C, 0xC0, 0x55, 0x4C, 0x00, 0x6D, 0x00, 0x18,
+0x1A, 0x34, 0xA3, 0xF3, 0x58, 0xA0, 0x4D, 0xE9,
+0xA3, 0xF3, 0x38, 0xC0, 0x0B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3,
+0x9C, 0xA2, 0x03, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xA3, 0xF3, 0x7C, 0xC2, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF2, 0x74, 0x9A,
+0x20, 0xF2, 0x14, 0x4A, 0x30, 0xF0, 0x20, 0x68,
+0x04, 0xD3, 0x61, 0x9A, 0xFF, 0x69, 0x44, 0xAA,
+0x61, 0xF3, 0x10, 0x48, 0x8C, 0xE9, 0xE0, 0xF0,
+0x88, 0xA0, 0x05, 0xD3, 0x7D, 0x67, 0x4C, 0xCB,
+0x00, 0x18, 0x86, 0x11, 0x01, 0x72, 0xE0, 0xF0,
+0x16, 0x61, 0xC0, 0xF0, 0x64, 0xA0, 0x7F, 0x6A,
+0xFF, 0x6D, 0x6C, 0xEA, 0xAC, 0xEA, 0xE0, 0xF0,
+0x0E, 0x22, 0xC0, 0xF0, 0x65, 0xA0, 0x0F, 0x6A,
+0x6C, 0xEA, 0x01, 0x72, 0x3C, 0x61, 0x7D, 0x67,
+0x24, 0x32, 0x49, 0xE3, 0x68, 0xAA, 0x1F, 0xF7,
+0x00, 0x6A, 0x6C, 0xEA, 0x02, 0xF0, 0x00, 0x72,
+0x01, 0x60, 0x0B, 0x2A, 0x24, 0x32, 0xBD, 0x67,
+0x49, 0xE5, 0x68, 0xAA, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x54, 0x9A, 0x49, 0xE3, 0x60, 0x9A,
+0x06, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x58, 0x9A, 0x4D, 0xE3, 0x60, 0x9B, 0x04, 0xF0,
+0x00, 0x6A, 0x6C, 0xEA, 0x0F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF6, 0x62, 0x34, 0x61, 0xF3,
+0x10, 0x4A, 0x62, 0x33, 0xC3, 0xF3, 0x81, 0xC2,
+0x62, 0x33, 0xFF, 0x6C, 0x8C, 0xEB, 0x02, 0x23,
+0xC3, 0xF3, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xC3, 0xF3, 0x61, 0xA2,
+0x02, 0x2B, 0xC3, 0xF3, 0x60, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0xF7, 0x71, 0xC2, 0x91, 0x67,
+0x00, 0x18, 0x3A, 0x13, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0xBC, 0x9A, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x00, 0x6B, 0xC3, 0xF3,
+0x63, 0xC0, 0xC3, 0xF3, 0x64, 0xC0, 0x80, 0xAD,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x01, 0x4C,
+0x4C, 0xEC, 0x80, 0xCD, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF5, 0xA0, 0x9C, 0x80, 0xAD, 0x4C, 0xEC,
+0x01, 0x4C, 0x4C, 0xEC, 0x80, 0xCD, 0x23, 0xF4,
+0x44, 0x98, 0xC3, 0xF3, 0x8A, 0xA0, 0x01, 0x4A,
+0x23, 0xF4, 0x44, 0xD8, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x58, 0x9A, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF5, 0x44, 0x9A, 0x91, 0x67,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x58, 0x9A, 0x02, 0x6B, 0x60, 0xC2, 0xA3, 0xF3,
+0x7C, 0xA0, 0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x11, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA, 0xA3, 0xF3,
+0x5C, 0xC0, 0x00, 0x18, 0x74, 0x17, 0xA3, 0xF3,
+0x78, 0xA0, 0x40, 0x6A, 0x6C, 0xEA, 0x56, 0x22,
+0xA3, 0xF3, 0x99, 0xA0, 0x10, 0x6B, 0xFF, 0x6D,
+0x44, 0x67, 0x6C, 0xEA, 0xAC, 0xEA, 0x23, 0x2A,
+0xC3, 0xF3, 0x41, 0xA0, 0xC3, 0xF3, 0xA0, 0xA0,
+0xAE, 0xEA, 0x48, 0x2A, 0x8D, 0xEB, 0x91, 0x67,
+0xA3, 0xF3, 0x79, 0xC0, 0x00, 0x18, 0x50, 0x40,
+0x91, 0x67, 0x00, 0x18, 0x7D, 0x3F, 0xC0, 0xF0,
+0x54, 0xA0, 0x01, 0x72, 0x06, 0x60, 0x91, 0x67,
+0x00, 0x18, 0xAD, 0x3F, 0x91, 0x67, 0x00, 0x18,
+0xA6, 0x3F, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xC3, 0xF3, 0x61, 0xA2, 0xFF, 0x4B,
+0xC3, 0xF3, 0x61, 0xC2, 0x2B, 0x10, 0xC0, 0xF0,
+0x65, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA, 0x01, 0x72,
+0x25, 0x61, 0xC3, 0xF3, 0x41, 0xA0, 0x08, 0xD2,
+0x08, 0x93, 0xC3, 0xF3, 0x40, 0xA0, 0x6E, 0xEA,
+0x1D, 0x22, 0x91, 0x67, 0x00, 0x18, 0x45, 0x40,
+0x08, 0x95, 0xAE, 0xEA, 0x17, 0x22, 0xA3, 0xF3,
+0x78, 0xA0, 0x20, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x10, 0x22, 0xA3, 0xF3, 0x79, 0xA0,
+0x11, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x91, 0x67,
+0xA3, 0xF3, 0x59, 0xC0, 0x00, 0x18, 0x9C, 0x3F,
+0x91, 0x67, 0x00, 0x18, 0x8E, 0x3F, 0x91, 0x67,
+0x00, 0x18, 0x87, 0x3F, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3, 0x98, 0xA2,
+0x01, 0x6B, 0xC3, 0xF3, 0x67, 0xC2, 0x20, 0x6B,
+0x8D, 0xEB, 0xA3, 0xF3, 0x78, 0xC2, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0xAC, 0xEA, 0x49, 0x22, 0x05, 0x5C, 0x3D, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x88, 0x34, 0x00, 0xF2,
+0x00, 0x4A, 0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF5, 0xA8, 0x9A,
+0x01, 0x6C, 0x00, 0x18, 0x0C, 0x07, 0x00, 0x6C,
+0x08, 0x6D, 0x29, 0x10, 0x04, 0x6C, 0x0F, 0x6D,
+0x00, 0x18, 0x0C, 0x07, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x6C, 0x80, 0xF4, 0xB8, 0x9A, 0x1F, 0x10,
+0x04, 0x6C, 0xF0, 0x6D, 0x00, 0x18, 0x0C, 0x07,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0x00, 0xF5,
+0xA8, 0x9A, 0x15, 0x10, 0x04, 0x6C, 0x01, 0xF7,
+0x00, 0x6D, 0x00, 0x18, 0x0C, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x04, 0x6C, 0x00, 0xF5, 0xAC, 0x9A,
+0x0A, 0x10, 0x04, 0x6C, 0x1E, 0xF0, 0x00, 0x6D,
+0x00, 0x18, 0x0C, 0x07, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF5, 0xB0, 0x9A, 0x04, 0x6C, 0x00, 0x18,
+0x0C, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x64, 0x9A, 0xFF, 0x6C, 0x07, 0x6D, 0x40, 0xA3,
+0x8C, 0xEA, 0xAD, 0xEA, 0x45, 0x10, 0x05, 0x5C,
+0x3D, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x88, 0x34,
+0x00, 0xF2, 0x14, 0x4A, 0x89, 0xE2, 0x40, 0x9A,
+0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF5,
+0xA8, 0x9A, 0x01, 0x6C, 0x00, 0x18, 0x3D, 0x07,
+0x00, 0x6C, 0x08, 0x6D, 0x29, 0x10, 0x04, 0x6C,
+0x0F, 0x6D, 0x00, 0x18, 0x3D, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x04, 0x6C, 0x80, 0xF4, 0xB8, 0x9A,
+0x1F, 0x10, 0x04, 0x6C, 0xF0, 0x6D, 0x00, 0x18,
+0x3D, 0x07, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C,
+0x00, 0xF5, 0xA8, 0x9A, 0x15, 0x10, 0x04, 0x6C,
+0x01, 0xF7, 0x00, 0x6D, 0x00, 0x18, 0x3D, 0x07,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0x6C, 0x00, 0xF5,
+0xAC, 0x9A, 0x0A, 0x10, 0x04, 0x6C, 0x1E, 0xF0,
+0x00, 0x6D, 0x00, 0x18, 0x3D, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0xB0, 0x9A, 0x04, 0x6C,
+0x00, 0x18, 0x3D, 0x07, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x64, 0x9A, 0xFC, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x68, 0x24, 0x67,
+0x0C, 0xE9, 0x91, 0x67, 0x01, 0x6D, 0x00, 0x18,
+0x52, 0x18, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xC3, 0xF3, 0x8A, 0xAA, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF4, 0x78, 0x9B, 0x0C, 0xEC,
+0x80, 0xC3, 0xC0, 0xF0, 0xAA, 0xA2, 0x80, 0x6B,
+0x6B, 0xEB, 0x1F, 0x6C, 0xAC, 0xEB, 0xAC, 0xEC,
+0x0C, 0xEB, 0x0C, 0xEC, 0x10, 0x23, 0x8F, 0x33,
+0x0C, 0xEB, 0x23, 0xF4, 0x6C, 0xC2, 0x01, 0x4B,
+0x23, 0xF4, 0x6D, 0xC2, 0xC0, 0xF0, 0x47, 0xA2,
+0x07, 0x6B, 0x8C, 0xEB, 0x56, 0x32, 0x4C, 0x32,
+0x4D, 0xEB, 0x0C, 0xEB, 0x06, 0x10, 0x02, 0x6C,
+0x23, 0xF4, 0x8C, 0xC2, 0x03, 0x6C, 0x23, 0xF4,
+0x8D, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x48, 0x9A, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x60, 0xC2, 0xE0, 0xF0, 0x88, 0xA0,
+0x00, 0x18, 0x86, 0x11, 0x01, 0x72, 0x12, 0x61,
+0xA3, 0xF3, 0x78, 0xA0, 0x21, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xA3, 0xF3, 0x58, 0xC0, 0xA3, 0xF3,
+0x5B, 0xA0, 0x04, 0x6B, 0x6C, 0xEA, 0x0C, 0x2A,
+0x83, 0x67, 0x01, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xD7, 0x14, 0x06, 0x10, 0xA3, 0xF3, 0x78, 0xA0,
+0x20, 0x6A, 0x6D, 0xEA, 0xA3, 0xF3, 0x58, 0xC0,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x04, 0x67,
+0x2C, 0xE8, 0xAC, 0xE9, 0x53, 0x28, 0x91, 0x67,
+0x00, 0x6D, 0x00, 0x18, 0x52, 0x18, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF5, 0x44, 0x9A, 0x02, 0x6B,
+0x00, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x58, 0x9A, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x60, 0xDA, 0xE0, 0xF0, 0x88, 0xA0,
+0x00, 0x18, 0x86, 0x11, 0x19, 0x2A, 0xA3, 0xF3,
+0x5B, 0xA0, 0x04, 0x6B, 0x6C, 0xEA, 0x02, 0x2A,
+0x00, 0x18, 0x76, 0x40, 0x91, 0x67, 0x00, 0x18,
+0xA9, 0x14, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0xA3, 0xF3, 0x99, 0xA3, 0x02, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0x03, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEA, 0xA3, 0xF3, 0x59, 0xC3, 0x05, 0x10,
+0x0C, 0x6C, 0x01, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0xD7, 0x14, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xA3, 0xF3, 0x98, 0xA2, 0x05, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA3, 0xF3, 0x78, 0xC2,
+0xE0, 0xF0, 0x60, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x54, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x58, 0x9A, 0x04, 0x6B,
+0x60, 0xC2, 0x05, 0x10, 0x01, 0x70, 0x03, 0x61,
+0x91, 0x67, 0x00, 0x18, 0x9F, 0x18, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x30, 0xF0, 0x20, 0x68, 0x2C, 0xEC,
+0x61, 0xF3, 0x10, 0x48, 0x04, 0xD4, 0x00, 0x18,
+0x1F, 0x14, 0xC0, 0xF0, 0x84, 0xA0, 0x7F, 0x6A,
+0x04, 0x95, 0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18,
+0xD1, 0x18, 0xC0, 0xF0, 0x44, 0xA0, 0x7F, 0x6B,
+0x6C, 0xEA, 0x2C, 0xEA, 0x09, 0x22, 0xC0, 0xF0,
+0x45, 0xA0, 0x0F, 0x6C, 0xC0, 0xF0, 0xA6, 0xA0,
+0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18, 0x58, 0x12,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF5, 0x6C, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0x6D, 0xE5, 0x00, 0xA3,
+0x3F, 0x6F, 0x01, 0x74, 0x0C, 0xEF, 0x4C, 0xEE,
+0xE0, 0xC3, 0x15, 0x60, 0x07, 0x24, 0x30, 0xF0,
+0x20, 0x6C, 0x24, 0xF7, 0x8B, 0xA4, 0x08, 0x6F,
+0xEC, 0xEC, 0x0D, 0x24, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF5, 0xF0, 0x9C, 0xEF, 0x6C, 0xFD, 0xE5,
+0x00, 0xA7, 0x0C, 0xEC, 0x80, 0xC7, 0x80, 0xA3,
+0x40, 0x6F, 0x4C, 0xEC, 0x0F, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x40, 0xF5, 0xF0, 0x9C, 0x10, 0x68,
+0xFD, 0xE5, 0x80, 0xA7, 0x4C, 0xEC, 0x0D, 0xEC,
+0x4C, 0xEC, 0x80, 0xC7, 0x80, 0xA3, 0x80, 0x6F,
+0xEB, 0xEF, 0x4C, 0xEC, 0xED, 0xEC, 0x4C, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF5, 0x54, 0x9A,
+0x80, 0xC3, 0x80, 0xF4, 0xC0, 0x36, 0x55, 0xE5,
+0x40, 0x9D, 0x4D, 0xEE, 0xC0, 0xDD, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF5, 0x58, 0x9A,
+0xFF, 0x6B, 0x40, 0xA2, 0x6C, 0xEA, 0x52, 0x32,
+0x6C, 0xEA, 0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF4, 0x99, 0xA2, 0x00, 0x6D, 0x18, 0x6E,
+0xE5, 0x67, 0x00, 0x18, 0x3E, 0x48, 0x00, 0x18,
+0x7E, 0x48, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x2C, 0xEC, 0x2C, 0xED, 0x02, 0x5C,
+0x04, 0xD4, 0x05, 0xD5, 0x41, 0x60, 0x00, 0x18,
+0xA3, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF5,
+0x7C, 0x9B, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x80, 0xAB, 0xFF, 0xF7, 0x1F, 0x6B,
+0x8C, 0xEB, 0x4B, 0xE3, 0xA0, 0xF0, 0x6A, 0xA0,
+0x2C, 0xEA, 0x6E, 0xEA, 0x2D, 0x2A, 0xA3, 0xF3,
+0x5B, 0xA0, 0x0E, 0x72, 0x12, 0x61, 0x04, 0x92,
+0x27, 0x2A, 0xA3, 0xF3, 0x79, 0xA0, 0x05, 0x94,
+0xFD, 0x4A, 0x6C, 0xEA, 0x00, 0x6D, 0xA3, 0xF3,
+0x59, 0xC0, 0x00, 0x18, 0x7B, 0x47, 0x01, 0x6C,
+0x0C, 0x6D, 0x00, 0x18, 0x26, 0x12, 0x91, 0x67,
+0x13, 0x10, 0x06, 0x72, 0x15, 0x61, 0x04, 0x92,
+0x13, 0x22, 0xA3, 0xF3, 0x79, 0xA0, 0x05, 0x94,
+0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x01, 0x6D,
+0xA3, 0xF3, 0x59, 0xC0, 0x00, 0x18, 0x7B, 0x47,
+0x04, 0x6A, 0xA3, 0xF3, 0x5B, 0xC0, 0xFF, 0x6C,
+0x00, 0x6D, 0xC5, 0x67, 0x00, 0x18, 0xC5, 0x3A,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x40, 0xF5, 0x78, 0x9B, 0x4C, 0xEE,
+0x4C, 0xEF, 0x05, 0xD6, 0x04, 0xD7, 0x60, 0xA3,
+0xFF, 0xF7, 0x1F, 0x68, 0x25, 0x67, 0x4C, 0xEB,
+0x72, 0x33, 0x4C, 0xEB, 0x8C, 0xE8, 0x4C, 0xE9,
+0x25, 0x23, 0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5,
+0x64, 0x9B, 0x00, 0x6C, 0xFF, 0x6D, 0x60, 0xA3,
+0x26, 0x6E, 0x6C, 0xEA, 0x06, 0xD2, 0x00, 0x18,
+0xC5, 0x3A, 0x00, 0x18, 0x5B, 0x40, 0x01, 0x72,
+0x0B, 0x61, 0x05, 0x96, 0x90, 0x67, 0x01, 0x6D,
+0x00, 0x6F, 0x00, 0x18, 0x3E, 0x48, 0x04, 0x96,
+0x91, 0x67, 0xA2, 0x67, 0x00, 0x18, 0x19, 0x19,
+0x06, 0x95, 0x00, 0x6C, 0x27, 0x6E, 0x00, 0x18,
+0xC5, 0x3A, 0x04, 0x95, 0x91, 0x67, 0x00, 0x18,
+0x48, 0x19, 0x0F, 0x10, 0x04, 0x95, 0x91, 0x67,
+0x00, 0x18, 0x48, 0x19, 0x05, 0x96, 0x90, 0x67,
+0x01, 0x6D, 0x00, 0x6F, 0x00, 0x18, 0x3E, 0x48,
+0x04, 0x96, 0x91, 0x67, 0xA2, 0x67, 0x00, 0x18,
+0x19, 0x19, 0x00, 0x18, 0x7E, 0x48, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xFF, 0x6A, 0xEC, 0xEA, 0x04, 0x72, 0x0F, 0x61,
+0x40, 0xA4, 0x40, 0xC5, 0x41, 0xA4, 0x41, 0xC5,
+0x44, 0xA4, 0x42, 0xC5, 0x45, 0xA4, 0x43, 0xC5,
+0x46, 0xA4, 0x44, 0xC5, 0x47, 0xA4, 0x45, 0xC5,
+0x43, 0xA4, 0x40, 0xC6, 0x20, 0xE8, 0x02, 0x72,
+0x0E, 0x61, 0x42, 0xA4, 0x40, 0xC5, 0x40, 0xA4,
+0x41, 0xC5, 0x44, 0xA4, 0x42, 0xC5, 0x45, 0xA4,
+0x43, 0xC5, 0x46, 0xA4, 0x44, 0xC5, 0x47, 0xA4,
+0x45, 0xC5, 0x43, 0xA4, 0x40, 0xC6, 0x20, 0xE8,
+0xFF, 0x6A, 0xEC, 0xEA, 0x04, 0x6B, 0x4E, 0xEB,
+0x06, 0x2B, 0x40, 0xA5, 0x40, 0xC4, 0x41, 0xA5,
+0x62, 0xC4, 0x41, 0xC4, 0x0C, 0x10, 0x02, 0x72,
+0x0A, 0x61, 0x41, 0xA5, 0x40, 0xC4, 0x61, 0xA5,
+0x5F, 0x6A, 0x6C, 0xEA, 0x20, 0x6B, 0x6D, 0xEA,
+0x41, 0xC4, 0x40, 0xA5, 0x42, 0xC4, 0x63, 0x44,
+0xC0, 0xA3, 0x20, 0x6A, 0xCD, 0xEA, 0x40, 0xC3,
+0x42, 0xA5, 0x44, 0xC4, 0x43, 0xA5, 0x45, 0xC4,
+0x44, 0xA5, 0x46, 0xC4, 0x45, 0xA5, 0x47, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x68, 0xAC, 0xE8,
+0x24, 0x67, 0x00, 0x6D, 0x05, 0x04, 0x08, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x07, 0x04, 0x00, 0x6D,
+0x08, 0x6E, 0x00, 0x18, 0x6B, 0x2C, 0x91, 0x67,
+0x05, 0x05, 0x00, 0xF0, 0x11, 0x06, 0xF0, 0x67,
+0x00, 0x18, 0x9A, 0x19, 0x30, 0xF0, 0x20, 0x6C,
+0xA4, 0xF7, 0x1F, 0x4C, 0x07, 0x05, 0x04, 0x06,
+0xF0, 0x67, 0x00, 0x18, 0x9A, 0x19, 0x00, 0x6B,
+0x07, 0x6A, 0x9D, 0x67, 0x75, 0xE4, 0x85, 0x67,
+0x9B, 0xA4, 0x20, 0xF0, 0xA3, 0xA5, 0xAE, 0xEC,
+0x0A, 0x2C, 0xFF, 0x4A, 0x00, 0xF6, 0x40, 0x32,
+0x00, 0xF6, 0x43, 0x32, 0x81, 0x42, 0xFF, 0x4B,
+0xF0, 0x2C, 0x00, 0x6A, 0x09, 0x10, 0x04, 0x03,
+0x49, 0xE3, 0x6C, 0xA2, 0x44, 0xA2, 0x4B, 0xE3,
+0x01, 0x52, 0x58, 0x67, 0x01, 0x6B, 0x6E, 0xEA,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x4C, 0xED,
+0x4C, 0xEE, 0x05, 0x00, 0x24, 0x67, 0x09, 0xD5,
+0x08, 0xD6, 0x90, 0x67, 0x00, 0x6D, 0x08, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x08, 0x97, 0x91, 0x67,
+0xB0, 0x67, 0x04, 0x06, 0x00, 0x18, 0x9A, 0x19,
+0x09, 0x92, 0x10, 0x2A, 0x60, 0xA0, 0xFF, 0x6C,
+0x8E, 0xEB, 0x07, 0x2B, 0x01, 0x4A, 0x8C, 0xEA,
+0x06, 0x72, 0x60, 0xC0, 0x01, 0x48, 0xF6, 0x61,
+0x05, 0x10, 0x04, 0x03, 0x49, 0xE3, 0x64, 0xA2,
+0x01, 0x4B, 0x64, 0xC2, 0x08, 0x97, 0x91, 0x67,
+0x05, 0x05, 0x04, 0x06, 0x00, 0x18, 0xAC, 0x19,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x04, 0x00, 0x0C, 0xD4,
+0x00, 0x6D, 0x90, 0x67, 0x08, 0x6E, 0x06, 0x01,
+0x00, 0x18, 0x6B, 0x2C, 0x91, 0x67, 0x00, 0x6D,
+0x08, 0x6E, 0x00, 0x18, 0x6B, 0x2C, 0x30, 0xF0,
+0x20, 0x6D, 0x90, 0x67, 0xA4, 0xF7, 0x1F, 0x4D,
+0x03, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0x0C, 0x95,
+0x91, 0x67, 0x03, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x5D, 0x67, 0x72, 0xA2, 0x5A, 0xA2, 0x4E, 0xEB,
+0x02, 0x6A, 0x0C, 0x2B, 0x9D, 0x67, 0x59, 0xA4,
+0x71, 0xA4, 0x4E, 0xEB, 0x01, 0x6A, 0x06, 0x2B,
+0x5D, 0x67, 0x70, 0xA2, 0x58, 0xA2, 0x4E, 0xEB,
+0x00, 0x6A, 0x09, 0x23, 0x04, 0x03, 0x49, 0xE3,
+0x60, 0xA2, 0x48, 0xA2, 0x4B, 0xE3, 0x01, 0x52,
+0x58, 0x67, 0x01, 0x6B, 0x6E, 0xEA, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x68, 0x24, 0x67, 0xAC, 0xE8, 0x04, 0x04,
+0xB1, 0x67, 0x03, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x21, 0x28, 0x5D, 0x67, 0x70, 0xA2, 0xFF, 0x6A,
+0x4E, 0xEB, 0x00, 0x6A, 0x11, 0x2B, 0x5D, 0x67,
+0x70, 0xC2, 0x71, 0xA2, 0xFF, 0x6A, 0x4E, 0xEB,
+0x01, 0x6A, 0x0A, 0x2B, 0x5D, 0x67, 0x71, 0xC2,
+0x52, 0xA2, 0xFF, 0x6B, 0x6E, 0xEA, 0x03, 0x2A,
+0x7D, 0x67, 0x52, 0xC3, 0x06, 0x10, 0x02, 0x6A,
+0x04, 0x03, 0x49, 0xE3, 0x60, 0xA2, 0x01, 0x4B,
+0x60, 0xC2, 0x91, 0x67, 0x04, 0x05, 0x03, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x04, 0x6E, 0x04, 0x04, 0x00, 0x18,
+0x70, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0x04, 0x93,
+0x60, 0xF5, 0x40, 0x9A, 0x01, 0x6C, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5, 0x44, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF5, 0x68, 0x9B,
+0x0D, 0xEA, 0x40, 0xDB, 0x00, 0x18, 0x4C, 0x2C,
+0x07, 0x97, 0x06, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0x69, 0x04, 0x00, 0x2C, 0xEC, 0x2C, 0xED,
+0x10, 0xD6, 0x06, 0xD4, 0x07, 0xD5, 0x90, 0x67,
+0xA6, 0x67, 0x04, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x06, 0x92, 0xB0, 0x67, 0x4C, 0x34, 0x02, 0x4C,
+0x2C, 0xEC, 0x00, 0x18, 0x34, 0x1A, 0x10, 0x95,
+0x04, 0x6E, 0x90, 0x67, 0x04, 0x4D, 0x00, 0x18,
+0x70, 0x2C, 0x06, 0x93, 0xB0, 0x67, 0x6C, 0x33,
+0x83, 0x67, 0x03, 0x4C, 0x2C, 0xEC, 0x08, 0xD3,
+0x00, 0x18, 0x34, 0x1A, 0x10, 0x95, 0x04, 0x6E,
+0x90, 0x67, 0x08, 0x4D, 0x00, 0x18, 0x70, 0x2C,
+0x06, 0x92, 0xB0, 0x67, 0x4C, 0x34, 0x04, 0x4C,
+0x2C, 0xEC, 0x00, 0x18, 0x34, 0x1A, 0x10, 0x95,
+0x90, 0x67, 0x04, 0x6E, 0x0C, 0x4D, 0x00, 0x18,
+0x70, 0x2C, 0x08, 0x94, 0xB0, 0x67, 0x05, 0x4C,
+0x2C, 0xEC, 0x00, 0x18, 0x34, 0x1A, 0x07, 0x93,
+0x48, 0x6A, 0x02, 0x73, 0x04, 0x60, 0x07, 0x92,
+0x04, 0x72, 0x05, 0x61, 0x50, 0x6A, 0x06, 0x93,
+0x6D, 0xEA, 0x7D, 0x67, 0x50, 0xC3, 0x80, 0x6A,
+0x7D, 0x67, 0x4B, 0xEA, 0x51, 0xC3, 0x06, 0x92,
+0x01, 0x68, 0x0B, 0xE8, 0x4C, 0x31, 0xFF, 0x6C,
+0x12, 0xC3, 0x13, 0xC3, 0x2C, 0xEC, 0x04, 0x05,
+0x00, 0x18, 0x34, 0x1A, 0x7D, 0x67, 0xFF, 0x6A,
+0x81, 0x41, 0x10, 0xC3, 0x11, 0xC3, 0x12, 0xC3,
+0x13, 0xC3, 0x4C, 0xEC, 0x04, 0x05, 0x00, 0x18,
+0x34, 0x1A, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x4C, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF5, 0x50, 0x9A, 0x00, 0x6B, 0x00, 0x6E,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x54, 0x9A, 0x04, 0xF7, 0x10, 0x6F, 0x80, 0x6D,
+0x60, 0xDA, 0x80, 0xF1, 0x07, 0x6C, 0x06, 0x02,
+0x04, 0xD2, 0x00, 0x18, 0xC2, 0x2B, 0xC8, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF4, 0x9F, 0xA2, 0x90, 0x34, 0x00, 0x18,
+0xCA, 0x41, 0x03, 0x6C, 0x01, 0x6D, 0x00, 0x18,
+0x34, 0x42, 0x09, 0x97, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x29, 0x22, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x00, 0x18,
+0xA3, 0x2B, 0x00, 0xF1, 0xAE, 0xA0, 0x22, 0x67,
+0x30, 0xF0, 0x20, 0x6C, 0xB5, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF5, 0x58, 0x9A, 0xBC, 0x35,
+0x40, 0x6E, 0xC4, 0xF7, 0x08, 0x4C, 0x55, 0xE5,
+0x00, 0x18, 0x70, 0x2C, 0x00, 0x6D, 0x03, 0x6C,
+0x00, 0x18, 0x34, 0x42, 0x00, 0xF1, 0x8F, 0xA0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x91, 0xE1, 0x9C, 0x34,
+0x8F, 0x34, 0x4C, 0xEC, 0x00, 0x18, 0xCA, 0x41,
+0x03, 0x6C, 0x01, 0x6D, 0x00, 0x18, 0x34, 0x42,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF4, 0x63, 0x17, 0x62,
+0x16, 0xD1, 0x15, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A,
+0xFF, 0x69, 0x8C, 0xEA, 0x2C, 0xED, 0x30, 0xF0,
+0x20, 0x6C, 0x11, 0xD5, 0x69, 0xF4, 0x04, 0x4C,
+0x00, 0x6D, 0x80, 0x6E, 0x10, 0xD2, 0x00, 0x18,
+0x6B, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x1D, 0xA2, 0x00, 0x18, 0xA3, 0x2B, 0x10, 0x93,
+0x01, 0xE2, 0x1C, 0x30, 0x01, 0x73, 0x12, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF3, 0x50, 0xA3,
+0x0D, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x98, 0x9A, 0x91, 0xE0, 0x40, 0xA4, 0x2C, 0xEA,
+0x08, 0x4A, 0x2C, 0xEA, 0x40, 0xC4, 0x01, 0x6A,
+0x41, 0xF3, 0x50, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF5, 0x50, 0x9A, 0x41, 0x6B, 0x87, 0x40,
+0x49, 0xE0, 0x60, 0xC2, 0x11, 0x95, 0x29, 0x4C,
+0x00, 0x18, 0x80, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0x6B, 0x69, 0xF4, 0x64, 0xC2, 0x69, 0xF4,
+0x04, 0x4A, 0x03, 0x6B, 0x61, 0xC2, 0x00, 0x6B,
+0x62, 0xC2, 0x5F, 0x6B, 0x63, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x05, 0xF0, 0x4C, 0xA2, 0x67, 0x40,
+0x55, 0x4B, 0xFE, 0x72, 0xFE, 0x6D, 0x01, 0x60,
+0x02, 0x6D, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x98, 0x9A, 0x89, 0xE3, 0xA0, 0xC2, 0xA0, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF4, 0x04, 0x4A,
+0xA4, 0xC2, 0x10, 0x95, 0x01, 0x4B, 0x01, 0x75,
+0x0A, 0x61, 0x91, 0xE3, 0x03, 0x6D, 0xA0, 0xC4,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF5, 0xC4, 0x9C,
+0x01, 0x6C, 0xD9, 0xE3, 0x09, 0x10, 0x91, 0xE3,
+0x03, 0x6D, 0xA0, 0xC4, 0x30, 0xF0, 0x20, 0x6C,
+0x80, 0xF5, 0xC4, 0x9C, 0x02, 0x6C, 0xD9, 0xE3,
+0x80, 0xC6, 0x86, 0xC2, 0xA5, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF4,
+0x9C, 0xA2, 0x02, 0x4B, 0xFE, 0x74, 0x1C, 0x61,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF5, 0x98, 0x9C,
+0x83, 0xF4, 0xBF, 0xA2, 0x02, 0x6E, 0x91, 0xE3,
+0xA0, 0xC4, 0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF5,
+0x84, 0x9C, 0xA3, 0xF4, 0x40, 0xA2, 0x30, 0xF0,
+0x20, 0x6D, 0x8D, 0xE3, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xC3, 0x69, 0xF4, 0x0B, 0x4C, 0x05, 0xF0,
+0x0F, 0x4D, 0x00, 0x18, 0x70, 0x2C, 0x13, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5, 0x58, 0x9A,
+0x00, 0x6C, 0x49, 0xE3, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x44, 0x9A, 0x4D, 0xE3,
+0x30, 0xF0, 0x20, 0x6A, 0x69, 0xF4, 0x04, 0x4A,
+0x80, 0xC3, 0x87, 0xC2, 0x88, 0xC2, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF5, 0x80, 0x9B, 0x30, 0xF0,
+0x20, 0x6A, 0x05, 0xF0, 0x11, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0xA7, 0x42, 0x91, 0xE0, 0x69, 0xF4,
+0x0D, 0x4B, 0x01, 0x4D, 0xC0, 0xA2, 0xC0, 0xC4,
+0xC0, 0xA2, 0x01, 0x4A, 0xAA, 0xEA, 0xC0, 0xC3,
+0x01, 0x4C, 0x01, 0x4B, 0xF7, 0x61, 0x30, 0xF0,
+0x20, 0x6D, 0x06, 0x04, 0xC4, 0xF7, 0x08, 0x4D,
+0x10, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0x00, 0x69,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF5, 0x5C, 0x9A, 0x80, 0xF5, 0x68, 0x9B,
+0x49, 0xE0, 0x6D, 0xE0, 0x00, 0x6C, 0x80, 0xC2,
+0x01, 0x4A, 0x6A, 0xEA, 0xFB, 0x61, 0x64, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x6C, 0x9A, 0xFB, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x00, 0xF1, 0x6D, 0xA2,
+0x00, 0xF1, 0x4E, 0xA2, 0x12, 0xD2, 0x4B, 0xE3,
+0x5C, 0x32, 0xFF, 0xF7, 0x1F, 0x6B, 0x58, 0x4A,
+0x6C, 0xEA, 0x11, 0xD2, 0x00, 0x18, 0xA3, 0x2B,
+0x12, 0x94, 0xFF, 0xF7, 0x1F, 0x6D, 0x63, 0x6E,
+0x89, 0xE2, 0x5C, 0x32, 0x11, 0x94, 0x4F, 0x32,
+0xAC, 0xEA, 0x10, 0x6F, 0x00, 0x6D, 0x04, 0xD2,
+0x00, 0x18, 0x83, 0x41, 0x10, 0x92, 0x01, 0x72,
+0x0A, 0x61, 0x30, 0xF0, 0x20, 0x6D, 0x06, 0x04,
+0x69, 0xF4, 0x04, 0x4D, 0x0A, 0x06, 0x10, 0x6F,
+0x00, 0x18, 0x2C, 0x43, 0x09, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x06, 0x04, 0x69, 0xF4, 0x04, 0x4D,
+0x0A, 0x06, 0x10, 0x6F, 0x00, 0x18, 0x43, 0x43,
+0xFF, 0x6A, 0x01, 0x49, 0x4C, 0xE9, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x4C, 0x9A, 0x60, 0xA2,
+0x04, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x0A, 0x71,
+0xA3, 0x61, 0x02, 0x10, 0x0A, 0x59, 0x0B, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x70, 0x9A,
+0xFF, 0x6C, 0x20, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF5, 0x7C, 0x9B, 0x0A, 0x02,
+0x61, 0xE0, 0x0E, 0x03, 0x80, 0xA2, 0x01, 0x4A,
+0x6A, 0xEA, 0x80, 0xC0, 0x01, 0x48, 0xFA, 0x61,
+0x10, 0x93, 0x01, 0x73, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF4, 0x9D, 0xA2, 0x20, 0x6D,
+0x00, 0x18, 0x37, 0x22, 0x00, 0x18, 0xB4, 0x2B,
+0x1F, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x44, 0x9A, 0x00, 0x6C, 0xFF, 0x6D, 0x40, 0xA2,
+0x1D, 0x6E, 0xFF, 0x68, 0x4C, 0xE8, 0x00, 0x18,
+0xC5, 0x3A, 0x00, 0x18, 0x5B, 0x40, 0x01, 0x72,
+0x18, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x9D, 0xA2, 0x01, 0x6D, 0x18, 0x6E, 0x00, 0x6F,
+0x00, 0x18, 0x3E, 0x48, 0x00, 0x6C, 0xB0, 0x67,
+0x1E, 0x6E, 0x00, 0x18, 0xC5, 0x3A, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x9D, 0xA2,
+0x01, 0x6D, 0x18, 0x6E, 0x00, 0x6F, 0x00, 0x18,
+0x3E, 0x48, 0x30, 0xF0, 0x20, 0x6A, 0x24, 0xF7,
+0x4B, 0xA2, 0x03, 0x2A, 0x01, 0x6C, 0x00, 0x18,
+0xD1, 0x13, 0x00, 0x18, 0x7E, 0x48, 0x0B, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x74, 0x9A,
+0xFF, 0x6C, 0x20, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x17, 0x97,
+0x16, 0x91, 0x15, 0x90, 0x0C, 0x63, 0x00, 0xEF,
+0xF5, 0x63, 0x15, 0x62, 0x14, 0xD1, 0x13, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x64, 0x67,
+0xFF, 0x4B, 0x4C, 0xEB, 0x02, 0x5B, 0x10, 0xD4,
+0x00, 0xF1, 0x0B, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x65, 0xF0, 0x2A, 0xA2, 0x30, 0xF0, 0x20, 0x68,
+0x89, 0xF3, 0x1C, 0x48, 0x30, 0xF0, 0x20, 0x6D,
+0x90, 0x67, 0x65, 0xF0, 0x0B, 0x4D, 0xD1, 0x67,
+0x00, 0x18, 0x70, 0x2C, 0x10, 0x92, 0x01, 0x72,
+0x58, 0x67, 0x10, 0xD2, 0x29, 0x2A, 0x30, 0xF0,
+0x20, 0x6D, 0x07, 0x04, 0x25, 0xF0, 0x19, 0x4D,
+0x10, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0x30, 0xF0,
+0x20, 0x6D, 0x0B, 0x04, 0xC4, 0xF7, 0x18, 0x4D,
+0x10, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0x10, 0x93,
+0x00, 0x6C, 0xA4, 0x67, 0xD1, 0x67, 0x20, 0x6F,
+0x04, 0xD3, 0x00, 0x18, 0x83, 0x41, 0x30, 0xF0,
+0x20, 0x6C, 0xC9, 0xF3, 0x1C, 0x4C, 0x10, 0xD4,
+0x10, 0x96, 0x07, 0x04, 0xB0, 0x67, 0xF1, 0x67,
+0x00, 0x18, 0xAC, 0x42, 0x30, 0xF0, 0x20, 0x6C,
+0x09, 0xF4, 0x1C, 0x4C, 0x10, 0x95, 0x21, 0x10,
+0x30, 0xF0, 0x20, 0x6D, 0x07, 0x04, 0xC4, 0xF7,
+0x18, 0x4D, 0x10, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x00, 0x6A, 0x82, 0x67, 0xA2, 0x67, 0xD1, 0x67,
+0x10, 0x6F, 0x04, 0xD2, 0x00, 0x18, 0x83, 0x41,
+0x30, 0xF0, 0x20, 0x6A, 0xC9, 0xF3, 0x1C, 0x4A,
+0x07, 0x04, 0xB0, 0x67, 0xC2, 0x67, 0xF1, 0x67,
+0x10, 0xD2, 0x00, 0x18, 0x5A, 0x43, 0x10, 0x95,
+0x30, 0xF0, 0x20, 0x6C, 0x09, 0xF4, 0x1C, 0x4C,
+0x08, 0x4D, 0x28, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF4, 0x7C, 0xA2, 0xFE, 0x73, 0x10, 0x61,
+0x83, 0xF4, 0x5E, 0xA2, 0x30, 0x6B, 0x30, 0xF0,
+0x20, 0x6C, 0x6C, 0xEA, 0x53, 0x32, 0x7D, 0x67,
+0x30, 0xF0, 0x20, 0x6D, 0x58, 0xC3, 0x49, 0xF4,
+0x04, 0x4C, 0x09, 0xF4, 0x1C, 0x4D, 0x13, 0x10,
+0xFE, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB, 0x02, 0x5B,
+0x12, 0x60, 0x30, 0xF0, 0x20, 0x6D, 0x09, 0xF4,
+0x1C, 0x4D, 0x66, 0xA5, 0x03, 0x6A, 0x9D, 0x67,
+0x6C, 0xEA, 0x58, 0xC4, 0x30, 0xF0, 0x20, 0x6C,
+0x49, 0xF4, 0x04, 0x4C, 0x08, 0x4D, 0x20, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x0D, 0x10, 0x05, 0x6B,
+0x9D, 0x67, 0x78, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF5, 0x94, 0x9B, 0x10, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF1, 0x08, 0x4A,
+0x30, 0xF0, 0x20, 0x6B, 0xA7, 0x42, 0x49, 0xF4,
+0x04, 0x4B, 0x19, 0x4D, 0x01, 0x6C, 0xE0, 0xA2,
+0xC0, 0xA3, 0x01, 0x4A, 0x01, 0x4B, 0xEE, 0xEE,
+0x01, 0x5E, 0xD8, 0x67, 0xCB, 0xEE, 0xAA, 0xEA,
+0xCC, 0xEC, 0xF5, 0x61, 0x01, 0x74, 0x0C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x74, 0x9A,
+0xFF, 0x6C, 0x08, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x49, 0x10,
+0x7D, 0x67, 0x58, 0xA3, 0x04, 0x5A, 0x40, 0x60,
+0x30, 0xF0, 0x20, 0x68, 0x30, 0xF0, 0x20, 0x69,
+0x61, 0xF3, 0x10, 0x48, 0x49, 0xF4, 0x04, 0x49,
+0x30, 0xF0, 0x20, 0x6C, 0xA5, 0xF1, 0x08, 0x4C,
+0xB1, 0x67, 0x20, 0x6E, 0x43, 0xF6, 0x58, 0xC0,
+0x00, 0x18, 0x70, 0x2C, 0x5D, 0x67, 0x98, 0xA2,
+0x00, 0xF1, 0xA4, 0xA0, 0xD1, 0x67, 0x00, 0x18,
+0x44, 0x1A, 0x43, 0xF6, 0x58, 0xA0, 0x01, 0x72,
+0x0B, 0x60, 0x05, 0x22, 0x02, 0x72, 0x0D, 0x60,
+0x03, 0x72, 0x10, 0x60, 0x22, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0xC5, 0xF1, 0x18, 0x4C, 0x0E, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0xE5, 0xF1, 0x00, 0x4C,
+0x09, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0xE5, 0xF1,
+0x08, 0x4C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xE5, 0xF1, 0x10, 0x4C, 0x43, 0xF6, 0xF9, 0xA0,
+0x30, 0xF0, 0x20, 0x6D, 0x45, 0xF0, 0x09, 0x4D,
+0x06, 0x06, 0x00, 0x18, 0xAC, 0x19, 0x05, 0x10,
+0x05, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF1,
+0x68, 0xC2, 0x15, 0x97, 0x14, 0x91, 0x13, 0x90,
+0x0B, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0xF7, 0x1F, 0x69,
+0x8C, 0xE9, 0xFF, 0x68, 0xAC, 0xE8, 0x00, 0x18,
+0x7C, 0x1A, 0x91, 0x67, 0x00, 0x18, 0x7A, 0x1B,
+0x91, 0x67, 0xB0, 0x67, 0x00, 0x18, 0xAD, 0x1A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF5, 0x0C, 0x4B, 0x60, 0x9B, 0x30, 0xF0,
+0x20, 0x68, 0x05, 0xF0, 0x08, 0x48, 0x40, 0xA3,
+0xFF, 0x6B, 0x24, 0x67, 0x6C, 0xEA, 0xFF, 0xF6,
+0x08, 0x4B, 0x6C, 0xEA, 0x08, 0x6B, 0x6D, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF5, 0x0C, 0x4B, 0x60, 0x9B, 0x90, 0x67,
+0x00, 0x6D, 0x40, 0xC3, 0x04, 0x6E, 0x00, 0x18,
+0x6B, 0x2C, 0x84, 0x40, 0x00, 0x6D, 0xDF, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x47, 0x41, 0x01, 0x4A,
+0x61, 0xA2, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x83, 0xF4, 0x79, 0xC0, 0x44, 0xA2,
+0x30, 0xF0, 0x20, 0x6C, 0xA7, 0x41, 0x05, 0xF0,
+0x0D, 0x4C, 0x06, 0x4D, 0x02, 0x6E, 0x83, 0xF4,
+0x5C, 0xC0, 0x00, 0x18, 0x70, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0xA7, 0x41, 0x05, 0xF0, 0x0F, 0x4C,
+0x08, 0x4D, 0x02, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0xA7, 0x41, 0x05, 0xF0,
+0x11, 0x4C, 0x0A, 0x4D, 0x08, 0x6E, 0x00, 0x18,
+0x70, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0xA7, 0x41,
+0x25, 0xF0, 0x19, 0x4C, 0x32, 0x4D, 0x10, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xA7, 0x41, 0x65, 0xF0, 0x09, 0x4C, 0x62, 0x4D,
+0x02, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0xE3, 0xF4,
+0xD9, 0xA0, 0xE3, 0xF4, 0x5A, 0xA0, 0x30, 0xF0,
+0x20, 0x6C, 0xC0, 0x36, 0x4D, 0xEE, 0xA7, 0x41,
+0xFF, 0x6A, 0x65, 0xF0, 0x0B, 0x4C, 0x64, 0x4D,
+0x4C, 0xEE, 0x00, 0x18, 0x70, 0x2C, 0x83, 0xF4,
+0x5D, 0xA0, 0x83, 0xF4, 0x7E, 0xA0, 0x40, 0x32,
+0x6D, 0xEA, 0x08, 0x6B, 0x4C, 0xEB, 0x0A, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x03, 0x6B, 0x01, 0x6C, 0x60, 0xC2, 0x00, 0x18,
+0x3E, 0x1E, 0x20, 0x10, 0x07, 0x6C, 0x4C, 0xEC,
+0x4F, 0x44, 0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x02, 0x5A, 0x18, 0x60, 0x00, 0x6D, 0x00, 0x18,
+0x09, 0x1C, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5,
+0x0C, 0x4B, 0x60, 0x9B, 0x40, 0xA3, 0xFF, 0x6B,
+0x6C, 0xEA, 0xFF, 0xF6, 0x08, 0x4B, 0x6C, 0xEA,
+0x10, 0x6B, 0x6D, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5, 0x0C, 0x4B,
+0x60, 0x9B, 0x40, 0xC3, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x00, 0x6A, 0x04, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA0, 0xF0, 0x8F, 0xA2, 0x02, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x05, 0x6C, 0x8B, 0xEC, 0x8C, 0xEB,
+0xA0, 0xF0, 0x6F, 0xC2, 0x0A, 0x6B, 0xA0, 0xF0,
+0x70, 0xC2, 0x00, 0x6B, 0x24, 0xF1, 0x68, 0xC2,
+0x24, 0xF1, 0x69, 0xC2, 0x24, 0xF1, 0x6A, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xA4, 0xA0, 0xF0,
+0xEF, 0xA2, 0x02, 0x6B, 0x01, 0x6E, 0x6B, 0xEB,
+0xCC, 0xED, 0xEC, 0xEB, 0xAD, 0xEB, 0xA3, 0x67,
+0xCC, 0xED, 0xA0, 0xF0, 0x6F, 0xC2, 0x19, 0x25,
+0xA0, 0xA4, 0x07, 0x6F, 0xAE, 0x35, 0xEC, 0xED,
+0x24, 0xF1, 0xA8, 0xC2, 0xA0, 0xA4, 0xAA, 0x35,
+0xCC, 0xED, 0xA8, 0x36, 0x05, 0x6D, 0xAB, 0xED,
+0x6C, 0xED, 0xCD, 0xED, 0xA0, 0xF0, 0xAF, 0xC2,
+0xA0, 0xA4, 0x02, 0x6B, 0xAC, 0xEB, 0xFF, 0x6D,
+0xAC, 0xEB, 0x03, 0x23, 0x61, 0xA4, 0xA0, 0xF0,
+0x70, 0xC2, 0x20, 0xE8, 0x50, 0xA4, 0xFF, 0x63,
+0x7D, 0x67, 0x40, 0xC3, 0x51, 0xA4, 0x41, 0xC3,
+0x52, 0xA4, 0x42, 0xC3, 0x53, 0xA4, 0x43, 0xC3,
+0x54, 0xA4, 0x44, 0xC3, 0x55, 0xA4, 0x45, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0xA4, 0xF7, 0x0F, 0x4A,
+0x86, 0x42, 0xC0, 0xA2, 0xA0, 0xA3, 0xCE, 0xED,
+0x02, 0x25, 0x00, 0x6A, 0x05, 0x10, 0x01, 0x4A,
+0x8A, 0xEA, 0x01, 0x4B, 0xF6, 0x61, 0x01, 0x6A,
+0x01, 0x63, 0x20, 0xE8, 0x08, 0x4C, 0x41, 0xA4,
+0x09, 0x2A, 0x44, 0xA4, 0x01, 0x72, 0x06, 0x61,
+0x48, 0xA4, 0x01, 0x6B, 0x6E, 0xEA, 0x01, 0x5A,
+0x58, 0x67, 0x20, 0xE8, 0x00, 0x6A, 0x20, 0xE8,
+0x46, 0xA4, 0xFF, 0x63, 0x08, 0x72, 0x29, 0x61,
+0x47, 0xA4, 0x27, 0x2A, 0x58, 0xA4, 0x7D, 0x67,
+0x40, 0xC3, 0x59, 0xA4, 0x41, 0xC3, 0x5A, 0xA4,
+0x42, 0xC3, 0x5B, 0xA4, 0x43, 0xC3, 0x30, 0xF0,
+0x20, 0x6B, 0x5D, 0x67, 0x61, 0xF3, 0x10, 0x4B,
+0x80, 0xA2, 0x83, 0xF5, 0x42, 0xA3, 0x8E, 0xEA,
+0x14, 0x2A, 0x5D, 0x67, 0x81, 0xA2, 0x83, 0xF5,
+0x43, 0xA3, 0x8E, 0xEA, 0x0E, 0x2A, 0x5D, 0x67,
+0x82, 0xA2, 0x83, 0xF5, 0x44, 0xA3, 0x8E, 0xEA,
+0x08, 0x2A, 0x5D, 0x67, 0x83, 0xA2, 0x83, 0xF5,
+0x45, 0xA3, 0x8E, 0xEA, 0x01, 0x5A, 0x58, 0x67,
+0x01, 0x10, 0x00, 0x6A, 0x01, 0x63, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x41, 0xA4, 0x60, 0xA4,
+0x01, 0x6D, 0x40, 0x32, 0x6D, 0xEA, 0x62, 0xA4,
+0x60, 0x33, 0x60, 0x33, 0x4D, 0xEB, 0x43, 0xA4,
+0x00, 0xF6, 0x40, 0x32, 0x6D, 0xEA, 0x47, 0xA2,
+0x4C, 0xED, 0x00, 0x6A, 0x16, 0x25, 0x00, 0xF1,
+0x71, 0xA4, 0x00, 0xF1, 0x50, 0xA4, 0x60, 0x33,
+0x4D, 0xEB, 0x00, 0xF1, 0x52, 0xA4, 0x00, 0xF1,
+0x93, 0xA4, 0x40, 0x32, 0x40, 0x32, 0x6D, 0xEA,
+0x00, 0xF6, 0x80, 0x34, 0x4D, 0xEC, 0x00, 0x18,
+0xA4, 0x1C, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x32, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x41, 0xA4,
+0x60, 0xA4, 0x04, 0x67, 0x40, 0x32, 0x6D, 0xEA,
+0x62, 0xA4, 0x60, 0x33, 0x60, 0x33, 0x4D, 0xEB,
+0x43, 0xA4, 0x00, 0xF6, 0x40, 0x32, 0x6D, 0xEA,
+0x67, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0x3D, 0x22,
+0x00, 0xF1, 0x71, 0xA4, 0x00, 0xF1, 0x50, 0xA4,
+0x60, 0x33, 0x4D, 0xEB, 0x00, 0xF1, 0x52, 0xA4,
+0x00, 0xF1, 0x93, 0xA4, 0x40, 0x32, 0x40, 0x32,
+0x6D, 0xEA, 0x00, 0xF6, 0x80, 0x34, 0x4D, 0xEC,
+0x00, 0x18, 0xA4, 0x1C, 0x2A, 0x22, 0x00, 0xF1,
+0x51, 0xA0, 0x00, 0xF1, 0x70, 0xA0, 0x00, 0xF1,
+0x92, 0xA0, 0x40, 0x32, 0x6D, 0xEA, 0x00, 0xF1,
+0x73, 0xA0, 0x80, 0x34, 0x80, 0x34, 0x4D, 0xEC,
+0x00, 0xF6, 0x60, 0x33, 0x30, 0xF0, 0x20, 0x6A,
+0x8D, 0xEB, 0x61, 0xF4, 0x8D, 0xA2, 0x10, 0x6A,
+0x8C, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA, 0x11, 0x22,
+0x47, 0x43, 0x01, 0x4A, 0x69, 0xA2, 0x06, 0x73,
+0x0C, 0x61, 0x74, 0xA2, 0x0A, 0x2B, 0x75, 0xA2,
+0x50, 0x73, 0x07, 0x61, 0x20, 0xF0, 0x41, 0xA2,
+0x05, 0x6B, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0x01, 0x6A, 0x8C, 0xEA,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x00, 0xF1, 0x63, 0xA2, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0xF1, 0x64, 0xA2, 0x43, 0xF6, 0x79, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF1, 0x69, 0xA2,
+0x00, 0x6A, 0x07, 0x5B, 0x06, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF2, 0x04, 0x4A, 0x4D, 0xE3,
+0x40, 0xA3, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x04, 0x67, 0x86, 0x67,
+0x4C, 0xE8, 0x4C, 0xED, 0x4C, 0xEC, 0x40, 0x6A,
+0x1E, 0x30, 0x4C, 0xED, 0x04, 0x30, 0x00, 0x6A,
+0x02, 0x25, 0x00, 0x18, 0xFD, 0x1C, 0x18, 0x48,
+0x09, 0xE2, 0x05, 0x97, 0x04, 0x90, 0xFF, 0x6B,
+0x6C, 0xEA, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xA4, 0xF7, 0xC8, 0xA3,
+0x01, 0x6B, 0xFF, 0x6A, 0xCC, 0xEB, 0x4C, 0xEB,
+0x4C, 0xED, 0x01, 0x6A, 0x3D, 0x2B, 0x02, 0x6A,
+0xAC, 0xEA, 0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x7C, 0x9A, 0x10, 0xF0, 0x00, 0x6E,
+0x40, 0x9B, 0xCC, 0xEA, 0x09, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A, 0xC0, 0xDB,
+0x23, 0x6B, 0x60, 0xC2, 0x01, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x01, 0x6B, 0xAC, 0xEB, 0x24, 0x23,
+0xAF, 0xA4, 0x40, 0x6B, 0xAC, 0xEB, 0x07, 0x23,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x22, 0x6B, 0x60, 0xC2, 0x01, 0x6A, 0xAF, 0xA4,
+0x80, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB, 0xFF, 0x6D,
+0xAC, 0xEB, 0x07, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x58, 0x9A, 0x21, 0x6B, 0x60, 0xC2,
+0x01, 0x6A, 0x8F, 0xA4, 0x20, 0x6B, 0x8C, 0xEB,
+0x07, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x58, 0x9A, 0x23, 0x6B, 0x60, 0xC2, 0x01, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x8C, 0xEA,
+0xA0, 0x72, 0x04, 0x6B, 0x01, 0x60, 0x08, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x23, 0xF4, 0x98, 0xA2, 0x01, 0x6B,
+0x8D, 0xEB, 0x23, 0xF4, 0x78, 0xC2, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x23, 0xF4, 0xB8, 0xA3, 0x01, 0x6C, 0x44, 0x67,
+0x8C, 0xED, 0x04, 0x25, 0xE0, 0xF0, 0x55, 0xA3,
+0x52, 0x32, 0x8C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5, 0x60, 0x9A,
+0xDF, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x20, 0xF1, 0x8D, 0xA2, 0x40, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x20, 0xF1, 0x6D, 0xC2, 0x20, 0xE8,
+0xFA, 0x63, 0x0B, 0xD1, 0x0A, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF2, 0x78, 0x9A, 0x40, 0xF2,
+0x18, 0x4A, 0x9D, 0x67, 0x00, 0xD3, 0x61, 0x9A,
+0x44, 0xAA, 0x01, 0xD3, 0x7D, 0x67, 0x44, 0xCB,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF2, 0x6C, 0x9A,
+0x40, 0xF2, 0x0C, 0x4A, 0x03, 0xD3, 0x61, 0x9A,
+0x44, 0xAA, 0x04, 0xD3, 0x4A, 0xCC, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF4, 0x77, 0xA2, 0x64, 0x32,
+0x49, 0xE4, 0x00, 0xAA, 0x46, 0xAA, 0xE3, 0x67,
+0xC3, 0x67, 0x1A, 0x65, 0x08, 0xD3, 0x07, 0xD3,
+0x06, 0xD3, 0x00, 0x6A, 0x11, 0xE2, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x69,
+0x2E, 0xEC, 0x07, 0x24, 0x64, 0x34, 0x3D, 0x67,
+0x91, 0xE1, 0x80, 0xAC, 0x91, 0xE2, 0xAC, 0xEC,
+0x0B, 0x2C, 0xBD, 0x67, 0xC4, 0x34, 0x91, 0xE5,
+0xA0, 0xAC, 0x30, 0xF0, 0x20, 0x6C, 0x22, 0x67,
+0xB5, 0xE2, 0x20, 0xF5, 0x94, 0x9C, 0x0A, 0x10,
+0xBD, 0x67, 0xE4, 0x34, 0x91, 0xE5, 0xA0, 0xAC,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0x98, 0x9C,
+0x22, 0x67, 0xB5, 0xE2, 0x91, 0xE5, 0xA0, 0xA4,
+0xFF, 0x6C, 0xAC, 0xEC, 0x30, 0xF0, 0x20, 0x6D,
+0x61, 0xF3, 0x10, 0x4D, 0xB5, 0xE1, 0x38, 0x67,
+0x23, 0xF4, 0x9F, 0xC5, 0x31, 0xE2, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x69,
+0x2E, 0xEC, 0x08, 0x24, 0x08, 0x91, 0x24, 0x34,
+0x3D, 0x67, 0x91, 0xE1, 0x86, 0xAC, 0x91, 0xE2,
+0xAC, 0xEC, 0x0C, 0x2C, 0x06, 0x95, 0x22, 0x67,
+0xA4, 0x34, 0xBD, 0x67, 0x91, 0xE5, 0xA6, 0xAC,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0x94, 0x9C,
+0xB5, 0xE2, 0x0B, 0x10, 0x07, 0x95, 0x22, 0x67,
+0xA4, 0x34, 0xBD, 0x67, 0x91, 0xE5, 0xA6, 0xAC,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0x98, 0x9C,
+0xB5, 0xE2, 0x91, 0xE5, 0xA0, 0xA4, 0xFF, 0x6C,
+0x01, 0x4A, 0xAC, 0xEC, 0x30, 0xF0, 0x20, 0x6D,
+0x61, 0xF3, 0x10, 0x4D, 0xB5, 0xE1, 0x23, 0xF4,
+0x99, 0xC5, 0x06, 0x6C, 0x4E, 0xEC, 0x9A, 0x2C,
+0x0B, 0x91, 0x0A, 0x90, 0x06, 0x63, 0x20, 0xE8,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x00, 0xF1, 0x63, 0xC2, 0x61, 0xA4,
+0x00, 0xF1, 0x64, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0x61, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x00, 0xF1, 0x79, 0xC2, 0x62, 0xA4,
+0x00, 0xF1, 0x7A, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0xB9, 0xA2,
+0x02, 0x6C, 0xFF, 0x6B, 0xAC, 0xEC, 0x40, 0x24,
+0x24, 0xF1, 0x90, 0xA2, 0x08, 0x5C, 0x08, 0x61,
+0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF5, 0xA4, 0x9D,
+0xF8, 0x4C, 0xA0, 0xA5, 0xAC, 0xEB, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF5, 0xA8, 0x9D,
+0xA0, 0xA5, 0xAC, 0xEB, 0x01, 0x6D, 0xA4, 0xEC,
+0x6C, 0xED, 0x24, 0xF1, 0xB2, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0,
+0x7B, 0xA2, 0x24, 0xF1, 0x92, 0xA2, 0x01, 0x6D,
+0x6A, 0x33, 0xAC, 0xEB, 0x8E, 0xEB, 0x08, 0x23,
+0x85, 0x67, 0x00, 0x18, 0x0E, 0x2A, 0xFF, 0x6C,
+0x5D, 0x4C, 0x00, 0x6D, 0x01, 0x6E, 0x12, 0x10,
+0xE0, 0xF0, 0x99, 0xA2, 0x08, 0x6B, 0x8C, 0xEB,
+0xFF, 0x6C, 0x8C, 0xEB, 0x06, 0x23, 0xE0, 0xF0,
+0xDA, 0xA2, 0x5D, 0x4C, 0x00, 0x6D, 0xC0, 0x36,
+0x05, 0x10, 0xE0, 0xF0, 0xDA, 0xA2, 0xFF, 0x6C,
+0x5D, 0x4C, 0x00, 0x6D, 0x00, 0x18, 0x1A, 0x34,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3, 0x98, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x14, 0x23, 0xE0, 0xF0,
+0x99, 0xA2, 0x08, 0x6B, 0x8C, 0xEB, 0xFF, 0x6C,
+0x8C, 0xEB, 0x06, 0x23, 0xE0, 0xF0, 0xDA, 0xA2,
+0x5D, 0x4C, 0x00, 0x6D, 0xC0, 0x36, 0x05, 0x10,
+0xE0, 0xF0, 0xDA, 0xA2, 0xFF, 0x6C, 0x5D, 0x4C,
+0x00, 0x6D, 0x00, 0x18, 0x1A, 0x34, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xE0, 0xF0, 0xB9, 0xA2, 0x02, 0x6C,
+0xFF, 0x6B, 0xAC, 0xEC, 0x4A, 0x24, 0x24, 0xF1,
+0x90, 0xA2, 0x08, 0x5C, 0x08, 0x61, 0x30, 0xF0,
+0x20, 0x6D, 0xA0, 0xF5, 0xA4, 0x9D, 0xF8, 0x4C,
+0xA0, 0xA5, 0xAC, 0xEB, 0x06, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0xA0, 0xF5, 0xA8, 0x9D, 0xA0, 0xA5,
+0xAC, 0xEB, 0x01, 0x6D, 0xA4, 0xEC, 0x6C, 0xED,
+0x30, 0xF0, 0x20, 0x68, 0x24, 0xF1, 0xB2, 0xC2,
+0x61, 0xF3, 0x10, 0x48, 0xE0, 0xF0, 0x7B, 0xA0,
+0x24, 0xF1, 0x92, 0xA0, 0x01, 0x6A, 0x6A, 0x33,
+0x4C, 0xEB, 0x8E, 0xEB, 0x1C, 0x2B, 0xE0, 0xF0,
+0x79, 0xA0, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x0E, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0x9B, 0xA2, 0x04, 0x6B, 0x8C, 0xEB,
+0x05, 0x23, 0x24, 0xF1, 0x90, 0xA2, 0x00, 0x18,
+0x87, 0x32, 0x16, 0x10, 0x24, 0xF1, 0x90, 0xA2,
+0x00, 0x18, 0x8D, 0x32, 0x11, 0x10, 0x24, 0xF1,
+0x91, 0xA0, 0x01, 0x6D, 0x00, 0x18, 0x71, 0x32,
+0x24, 0xF1, 0x90, 0xA0, 0x00, 0x18, 0x7C, 0x32,
+0x07, 0x10, 0x01, 0x6A, 0xAC, 0xEA, 0x6C, 0xEA,
+0x03, 0x22, 0x00, 0x6C, 0x00, 0x18, 0x0E, 0x2A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0,
+0xB9, 0xA2, 0x02, 0x6B, 0xFF, 0x6C, 0xAC, 0xEB,
+0x32, 0x23, 0xE0, 0xF0, 0xB6, 0xA2, 0x7F, 0x6B,
+0xAC, 0xEB, 0x24, 0xF1, 0x71, 0xC2, 0xE0, 0xF0,
+0xBB, 0xA2, 0x0C, 0x6B, 0x24, 0xF1, 0x70, 0xC2,
+0x80, 0x6B, 0x6B, 0xEB, 0xAC, 0xEB, 0x8C, 0xEB,
+0x09, 0x23, 0x20, 0xF1, 0xA6, 0xA2, 0x01, 0x6B,
+0xAC, 0xEB, 0x8C, 0xEB, 0x03, 0x23, 0xA6, 0x33,
+0x24, 0xF1, 0x70, 0xC2, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x24, 0xF1, 0x50, 0xA0,
+0x01, 0x6C, 0x0C, 0x4A, 0x84, 0xEA, 0x00, 0x18,
+0xF9, 0x06, 0xE0, 0xF0, 0x7B, 0xA0, 0x04, 0x6A,
+0x6C, 0xEA, 0x05, 0x22, 0x24, 0xF1, 0x90, 0xA0,
+0x00, 0x18, 0x8D, 0x32, 0x04, 0x10, 0x24, 0xF1,
+0x90, 0xA0, 0x00, 0x18, 0x87, 0x32, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x42, 0xF6, 0x40, 0xA0, 0xFF, 0x69, 0x2C, 0xEC,
+0x02, 0x72, 0x04, 0xD4, 0x1D, 0x61, 0x01, 0x74,
+0x72, 0x61, 0x23, 0xF4, 0x78, 0xA0, 0x01, 0x6A,
+0x80, 0x6C, 0x6D, 0xEA, 0xE0, 0xF0, 0x76, 0xA0,
+0x8B, 0xEC, 0x23, 0xF4, 0x58, 0xC0, 0x8C, 0xEB,
+0x2C, 0xEB, 0x0A, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF5, 0x6C, 0x9A, 0x40, 0xA3, 0x2C, 0xEA,
+0x8E, 0xEA, 0x2C, 0xEA, 0x40, 0xC3, 0x5B, 0x10,
+0x01, 0x6C, 0x00, 0x18, 0xAB, 0x33, 0x57, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5, 0x50, 0x9A,
+0x01, 0x6B, 0x6B, 0xEB, 0x60, 0xC2, 0x64, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0xE0, 0xF0, 0x7B, 0xA0,
+0x01, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x02, 0x2A,
+0x00, 0x18, 0xC8, 0x3F, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0xE0, 0xF0, 0x99, 0xA3,
+0x5F, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA, 0xFF, 0x6C,
+0x8C, 0xEA, 0xA1, 0x72, 0x07, 0x61, 0xE0, 0xF0,
+0x76, 0xA3, 0x7F, 0x6A, 0x6C, 0xEA, 0x4C, 0xEC,
+0x00, 0x18, 0x7C, 0x32, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF5, 0x6C, 0x9A, 0xFF, 0x68, 0x80, 0x6C,
+0x40, 0xA3, 0x8B, 0xEC, 0x0C, 0xEA, 0x8E, 0xEA,
+0x0C, 0xEA, 0x40, 0xC3, 0x04, 0x94, 0x00, 0x18,
+0xAB, 0x33, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0xE0, 0xF0, 0x99, 0xA3, 0x02, 0x6A,
+0x8C, 0xEA, 0x0C, 0xEA, 0x04, 0x22, 0x24, 0xF1,
+0x90, 0xA3, 0x00, 0x18, 0x7C, 0x32, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF4, 0x69, 0xA2, 0x5F, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0xA1, 0x72, 0x09, 0x61, 0x01, 0x6C, 0x00, 0x18,
+0x0E, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x8C, 0x9A, 0x00, 0x18, 0x02, 0x07, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xF0,
+0x96, 0xA2, 0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xE0, 0xF0, 0x9C, 0xA2, 0xA0, 0xF0, 0x76, 0xC2,
+0x41, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xE0, 0xF0,
+0x7C, 0xC2, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF4,
+0x01, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF4, 0x1A, 0x4C, 0x07, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF4,
+0x16, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x65, 0xF1, 0x10, 0x48,
+0x08, 0xD4, 0x0A, 0xD6, 0x90, 0x67, 0x10, 0x6E,
+0xFF, 0x69, 0xEC, 0xE9, 0x00, 0x18, 0x70, 0x2C,
+0x08, 0x95, 0x87, 0x40, 0x09, 0x4C, 0x10, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x0A, 0x93, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x23, 0xF6,
+0x60, 0xDA, 0x23, 0xF6, 0x27, 0xC2, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6C,
+0x85, 0xF4, 0x1B, 0x4C, 0x00, 0x6D, 0x05, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x08, 0x6B, 0xA0, 0xF0,
+0x77, 0xC2, 0x03, 0x6B, 0xA0, 0xF0, 0x78, 0xC2,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0x67,
+0x00, 0x18, 0xB2, 0x1E, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x80, 0xA0, 0xA0, 0xF0,
+0xD6, 0xA2, 0x02, 0x6B, 0x01, 0x6D, 0x6B, 0xEB,
+0xAC, 0xEC, 0xCC, 0xEB, 0x8D, 0xEB, 0x83, 0x67,
+0xAC, 0xEC, 0xA0, 0xF0, 0x76, 0xC2, 0x29, 0x24,
+0x80, 0xA0, 0x07, 0x6E, 0x92, 0x34, 0xCC, 0xEC,
+0x24, 0xF1, 0x8F, 0xC2, 0xC0, 0xA0, 0x02, 0x6C,
+0xCC, 0xEC, 0xFF, 0x6E, 0xCC, 0xEC, 0x1D, 0x24,
+0x81, 0xA0, 0xA0, 0xF0, 0x97, 0xC2, 0x82, 0xA0,
+0xA0, 0xF0, 0x98, 0xC2, 0x80, 0xA0, 0x8A, 0x34,
+0xAC, 0xEC, 0x88, 0x36, 0x05, 0x6C, 0x8B, 0xEC,
+0x6C, 0xEC, 0xCD, 0xEC, 0xA0, 0xF0, 0x96, 0xC2,
+0x63, 0xA0, 0xA0, 0xF0, 0x79, 0xC2, 0x60, 0xA0,
+0x6E, 0x33, 0xAC, 0xEB, 0x6C, 0x35, 0x09, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xAD, 0xEB, 0xA0, 0xF0,
+0x76, 0xC2, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x4F, 0x29, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xDC, 0x27, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x24, 0x67, 0x00, 0xF1,
+0x1A, 0xA2, 0x04, 0xD2, 0x00, 0x18, 0xA3, 0x2B,
+0x04, 0x93, 0x01, 0xE2, 0x0F, 0x6C, 0xE0, 0xF0,
+0x5F, 0xA3, 0x1C, 0x30, 0x4C, 0xEC, 0x07, 0xD4,
+0x00, 0x6C, 0x8F, 0x10, 0x65, 0xA1, 0x44, 0xA1,
+0x30, 0xF0, 0x20, 0x6D, 0x60, 0x33, 0x4D, 0xEB,
+0x46, 0xA1, 0x60, 0xF5, 0xB8, 0x9D, 0x40, 0x32,
+0x40, 0x32, 0x6D, 0xEA, 0x67, 0xA1, 0xB5, 0xE0,
+0x00, 0xF6, 0x60, 0x33, 0x4D, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x44, 0x9A, 0x04, 0x4B,
+0x49, 0xE0, 0xC0, 0xA2, 0xA0, 0xA5, 0xFF, 0x6A,
+0x4C, 0xEE, 0xC0, 0x36, 0xAC, 0xEA, 0xD5, 0xE2,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED, 0x02, 0x48,
+0xB9, 0xE0, 0x04, 0xD0, 0x06, 0xD6, 0x00, 0x6A,
+0x08, 0xD4, 0x59, 0x10, 0x12, 0x72, 0x06, 0x61,
+0x68, 0xA1, 0x01, 0x6E, 0x6E, 0x33, 0xCC, 0xEB,
+0x06, 0x4B, 0x07, 0x10, 0x14, 0x72, 0x05, 0x61,
+0x68, 0xA1, 0x01, 0x6E, 0x6E, 0x33, 0xCC, 0xEB,
+0x08, 0x4B, 0x44, 0x37, 0x07, 0x6E, 0xEE, 0x30,
+0xEC, 0xEE, 0x30, 0xF0, 0x20, 0x6F, 0x05, 0xD0,
+0x60, 0xF5, 0xF8, 0x9F, 0x06, 0x90, 0x1F, 0x65,
+0xF1, 0xE0, 0x05, 0x90, 0x1D, 0xE4, 0x00, 0xA7,
+0xFF, 0x6C, 0x01, 0x6F, 0xE4, 0xEE, 0x8C, 0xE8,
+0xEC, 0xE8, 0x0E, 0xEF, 0x0C, 0x2F, 0x04, 0x97,
+0x18, 0x67, 0x11, 0xE7, 0x5D, 0xE4, 0xE0, 0xA7,
+0x00, 0xA3, 0xFF, 0x6C, 0x8C, 0xEF, 0x0E, 0xEF,
+0x0F, 0x68, 0x0C, 0xEF, 0x2C, 0x2F, 0x30, 0xF0,
+0x20, 0x6F, 0x60, 0xF5, 0x18, 0x9F, 0x06, 0x97,
+0x01, 0x4E, 0x11, 0xE7, 0x05, 0x97, 0xF1, 0xE4,
+0x80, 0xA4, 0xFD, 0x67, 0x94, 0xC7, 0xFF, 0x6C,
+0x1C, 0x65, 0x9D, 0x67, 0xF4, 0xA4, 0x98, 0x67,
+0x05, 0xD6, 0x8C, 0xEF, 0x05, 0x94, 0x01, 0x6E,
+0xC4, 0xEC, 0xCC, 0xEF, 0xCE, 0xEF, 0x0B, 0x2F,
+0x04, 0x96, 0xF8, 0x67, 0x01, 0xE6, 0x41, 0xE0,
+0xC0, 0xA0, 0xCC, 0xEF, 0xC0, 0xA3, 0xEE, 0xEE,
+0xF0, 0x6F, 0xEC, 0xEE, 0x08, 0x2E, 0x01, 0x4A,
+0xFF, 0x6E, 0x01, 0x4B, 0xCC, 0xEA, 0xA3, 0xEA,
+0xA5, 0x61, 0x01, 0x6A, 0x0F, 0x10, 0x08, 0x94,
+0x06, 0x90, 0xA4, 0x35, 0xFF, 0x4D, 0x01, 0x48,
+0xAF, 0x35, 0x01, 0x4C, 0xFF, 0x6A, 0xA1, 0xE0,
+0x4C, 0xEC, 0x07, 0x92, 0x42, 0xEC, 0x7F, 0xF7,
+0x0D, 0x61, 0x00, 0x6A, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x69, 0x04, 0x67, 0x2C, 0xE8, 0x00, 0x18,
+0xA3, 0x2B, 0x01, 0xE2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF5, 0x44, 0x9A, 0x1C, 0x30, 0x49, 0xE0,
+0x80, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF5,
+0x50, 0x9A, 0x2C, 0xEC, 0x49, 0xE0, 0xA0, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5, 0x48, 0x9A,
+0x2C, 0xED, 0x49, 0xE0, 0xC0, 0xA2, 0x2C, 0xEE,
+0x00, 0x18, 0x0D, 0x1D, 0x30, 0xF0, 0x20, 0x6C,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF5, 0x80, 0x9C,
+0xA0, 0xF5, 0xBC, 0x9B, 0x30, 0xF0, 0x20, 0x6B,
+0xE5, 0xF0, 0x0C, 0x4B, 0x91, 0xE2, 0xB5, 0xE0,
+0x11, 0xE4, 0xC6, 0x43, 0xE0, 0xA5, 0x01, 0x4D,
+0xE0, 0xC3, 0xE0, 0xA4, 0x01, 0x4C, 0xEA, 0xC3,
+0x01, 0x4B, 0xCA, 0xEB, 0xF7, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF5, 0x74, 0x9B, 0x69, 0xE2,
+0x30, 0xF0, 0x20, 0x6B, 0xE5, 0xF0, 0x12, 0x4B,
+0x01, 0xE2, 0x44, 0x43, 0x80, 0xA0, 0x80, 0xC3,
+0x87, 0x40, 0x03, 0x4C, 0x80, 0xA4, 0x01, 0x48,
+0x8A, 0xC3, 0x01, 0x4B, 0x4A, 0xEB, 0xF6, 0x61,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x06, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF4, 0x9B, 0xA2, 0x00, 0x18,
+0x42, 0x1F, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x00, 0x18, 0xA3, 0x2B, 0x09, 0xE2,
+0x30, 0xF0, 0x20, 0x6E, 0x5C, 0x34, 0x70, 0x6D,
+0x05, 0xF1, 0x00, 0x4E, 0x00, 0x18, 0x87, 0x2B,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF4,
+0x80, 0xA2, 0x00, 0x18, 0x74, 0x1F, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x68, 0x8C, 0xE8,
+0x00, 0x18, 0xA3, 0x2B, 0x01, 0xE2, 0x30, 0xF0,
+0x20, 0x69, 0x1C, 0x30, 0x85, 0xF1, 0x18, 0x49,
+0x90, 0x67, 0x08, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0x87, 0x2B, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5,
+0x58, 0x9A, 0xFF, 0x6B, 0x49, 0xE0, 0x40, 0xA2,
+0x6C, 0xEA, 0xDD, 0x72, 0xC0, 0xF0, 0x01, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF5, 0x4C, 0x9A,
+0x49, 0xE0, 0x80, 0xA2, 0x01, 0x6A, 0x6C, 0xEC,
+0x8C, 0xEA, 0x0E, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF5, 0x74, 0x9A, 0x47, 0x41, 0x31, 0x4A,
+0x6D, 0xE0, 0x40, 0x49, 0xA0, 0xA3, 0x01, 0x4B,
+0xA0, 0xC2, 0x01, 0x4A, 0x2A, 0xEA, 0xFA, 0x61,
+0x02, 0x6A, 0x8C, 0xEA, 0xA0, 0xF0, 0x05, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5, 0x5C, 0x9A,
+0x49, 0xE0, 0x60, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0xC5, 0xF1, 0x68, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF5, 0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0xE5, 0xF1, 0x00, 0x4B, 0x41, 0xE0, 0x30, 0xF0,
+0x20, 0x6A, 0xC5, 0xF1, 0x18, 0x4A, 0x80, 0xA0,
+0x80, 0xC2, 0x88, 0xA0, 0x88, 0xC2, 0x90, 0xA0,
+0x90, 0xC2, 0x98, 0xA0, 0x01, 0x48, 0x98, 0xC2,
+0x01, 0x4A, 0x6A, 0xEA, 0xF4, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xC5, 0xF1, 0x28, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x54, 0x9A, 0x2C, 0x31,
+0x02, 0x49, 0x4D, 0xE9, 0x80, 0xF4, 0x0C, 0x68,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5, 0x48, 0x9A,
+0x80, 0x6D, 0x00, 0x6E, 0x20, 0xDA, 0x60, 0xF6,
+0x13, 0x6C, 0x06, 0x02, 0x14, 0x6F, 0x04, 0xD2,
+0x00, 0x18, 0xC2, 0x2B, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0xD4, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0xB8, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x09, 0xE2, 0xA3, 0xF1,
+0x0C, 0x4A, 0x08, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF5, 0x60, 0x9A, 0xD9, 0xE0, 0xB5, 0xE0,
+0x60, 0xF6, 0x18, 0x6A, 0x1F, 0xF7, 0x00, 0x6C,
+0x4C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x02, 0x2C, 0xE0, 0xA3, 0x06, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x20, 0xF5, 0x98, 0x9C, 0x91, 0xE2,
+0xE0, 0xA4, 0xFF, 0x6C, 0xEC, 0xEC, 0x08, 0x97,
+0x80, 0xC7, 0x8F, 0xF1, 0x88, 0x40, 0x51, 0xE4,
+0x1F, 0xF7, 0x00, 0x6F, 0xEC, 0xEC, 0x02, 0xF0,
+0x00, 0x74, 0x01, 0x60, 0x13, 0x2C, 0x1F, 0xF7,
+0x00, 0x6C, 0x4C, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x02, 0x2C, 0xE0, 0xA3, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0x98, 0x9C,
+0x91, 0xE2, 0xE0, 0xA4, 0xFF, 0x6C, 0xEC, 0xEC,
+0x80, 0xC6, 0x10, 0x10, 0x4C, 0xEF, 0x02, 0xF0,
+0x00, 0x77, 0x01, 0x60, 0x02, 0x2F, 0xE0, 0xA3,
+0x06, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5,
+0x98, 0x9C, 0x91, 0xE2, 0xE0, 0xA4, 0xFF, 0x6C,
+0xEC, 0xEC, 0x80, 0xC5, 0x08, 0x94, 0x01, 0x4A,
+0x60, 0xF6, 0x1C, 0x72, 0x01, 0x4C, 0x01, 0x4E,
+0x01, 0x4D, 0x01, 0x4B, 0x08, 0xD4, 0xB6, 0x61,
+0x04, 0x48, 0x80, 0xF4, 0x1C, 0x70, 0x01, 0x49,
+0x8B, 0x61, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x6E, 0x44, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF4, 0x9C, 0x9C, 0x10, 0xF0, 0x20, 0x6B,
+0xCF, 0xF7, 0x1D, 0x4B, 0x01, 0x72, 0x60, 0xDC,
+0x19, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x23, 0xF4, 0xB8, 0xA3, 0x01, 0x6C,
+0x02, 0x72, 0xAD, 0xEC, 0x23, 0xF4, 0x98, 0xC3,
+0x40, 0x6B, 0x03, 0x60, 0x04, 0x72, 0x06, 0x61,
+0x41, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x58, 0x9A, 0x60, 0xC2, 0x01, 0x6C, 0x00, 0x18,
+0x3E, 0x1E, 0x0E, 0x10, 0x00, 0x18, 0xD5, 0x44,
+0x00, 0x18, 0xAC, 0x2B, 0xFB, 0x2A, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0,
+0x20, 0x6A, 0xCF, 0xF7, 0x1E, 0x4A, 0x40, 0xDB,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x3B, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x9A, 0xA2, 0x02, 0x24, 0x00, 0x18, 0x85, 0x1F,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x00, 0x6B, 0x60, 0xC2, 0x00, 0x18, 0x86, 0x44,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF5, 0x64, 0x9A,
+0xFE, 0x6A, 0x35, 0x6E, 0x80, 0xA3, 0x8C, 0xEA,
+0xFF, 0x6C, 0x40, 0xC3, 0xA4, 0x67, 0x00, 0x18,
+0xC5, 0x3A, 0x00, 0x18, 0xCC, 0x40, 0x01, 0x6C,
+0x00, 0x18, 0x64, 0x45, 0x00, 0x18, 0xF7, 0x1F,
+0x00, 0x18, 0xE5, 0x1E, 0x00, 0x18, 0x76, 0x40,
+0x00, 0x6D, 0xC5, 0x67, 0xFF, 0x6C, 0x00, 0x18,
+0xC5, 0x3A, 0x00, 0x18, 0x5C, 0x1D, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0xB8, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x5C, 0x9A, 0x01, 0x6C,
+0xA0, 0xDA, 0x00, 0x18, 0x0C, 0x07, 0x14, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0xB8, 0x9A,
+0x01, 0x6C, 0x00, 0x18, 0x3D, 0x07, 0x00, 0x6C,
+0x00, 0x18, 0x64, 0x45, 0x00, 0x18, 0xE1, 0x1E,
+0x30, 0xF0, 0x20, 0x6C, 0xA4, 0xF7, 0x08, 0x4C,
+0x00, 0x6D, 0x1F, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x40, 0xA4, 0xE0, 0xF0, 0x7C, 0xA0, 0x02, 0x6F,
+0x01, 0x69, 0xEB, 0xEF, 0x2C, 0xEA, 0xEC, 0xEB,
+0x4D, 0xEB, 0xE0, 0xF0, 0x7C, 0xC0, 0x40, 0xA4,
+0x03, 0x6D, 0xAB, 0xED, 0x46, 0x32, 0x2C, 0xEA,
+0x44, 0x32, 0xAC, 0xEB, 0x4D, 0xEB, 0xE0, 0xF0,
+0x7C, 0xC0, 0x40, 0xA4, 0xF5, 0xE5, 0xAC, 0xEB,
+0x4A, 0x32, 0x2C, 0xEA, 0x48, 0x32, 0x4D, 0xEB,
+0xE0, 0xF0, 0x7C, 0xC0, 0x40, 0xA4, 0xFD, 0x65,
+0xFC, 0x4D, 0x4E, 0x32, 0x2C, 0xEA, 0x4C, 0x32,
+0xAC, 0xEB, 0x4D, 0xEB, 0xE0, 0xF0, 0x7C, 0xC0,
+0x40, 0xA4, 0x11, 0x6E, 0xCB, 0xEE, 0x52, 0x32,
+0x2C, 0xEA, 0x50, 0x32, 0xCC, 0xEB, 0x4D, 0xEB,
+0xE0, 0xF0, 0x7C, 0xC0, 0x40, 0xA4, 0x1D, 0x65,
+0xE8, 0x4D, 0x56, 0x32, 0x2C, 0xEA, 0x54, 0x32,
+0xAC, 0xEB, 0x4D, 0xEB, 0xE0, 0xF0, 0x7C, 0xC0,
+0x40, 0xA4, 0xE0, 0x4D, 0xAC, 0xEB, 0x5A, 0x32,
+0x2C, 0xEA, 0x58, 0x32, 0x4D, 0xEB, 0xE0, 0xF0,
+0x7C, 0xC0, 0x40, 0xA4, 0x5E, 0x32, 0x5C, 0x32,
+0x04, 0xD2, 0x7F, 0x6A, 0x6C, 0xEA, 0x04, 0x93,
+0x6D, 0xEA, 0xE0, 0xF0, 0x5C, 0xC0, 0x62, 0xA4,
+0xE0, 0xF0, 0x5E, 0xA0, 0x2C, 0xEB, 0xEC, 0xEA,
+0x6D, 0xEA, 0xE0, 0xF0, 0x5E, 0xC0, 0x61, 0xA4,
+0x2C, 0xEB, 0x04, 0xD3, 0xE0, 0xF0, 0x7D, 0xA0,
+0x6C, 0xEF, 0x04, 0x93, 0x6D, 0xEF, 0xE0, 0xF0,
+0xFD, 0xC0, 0x61, 0xA4, 0x6A, 0x33, 0x2C, 0xEB,
+0x68, 0x33, 0x04, 0xD3, 0x7F, 0x67, 0x6C, 0xEF,
+0x04, 0x93, 0x6D, 0xEF, 0xE0, 0xF0, 0xFD, 0xC0,
+0x61, 0xA4, 0xCC, 0xEF, 0x4C, 0xEE, 0x72, 0x33,
+0x2C, 0xEB, 0x70, 0x33, 0x6D, 0xEF, 0xE0, 0xF0,
+0xFD, 0xC0, 0x61, 0xA4, 0x6E, 0x33, 0x2C, 0xEB,
+0x6C, 0x33, 0xFB, 0x65, 0x78, 0x67, 0x6C, 0xEF,
+0x7F, 0x67, 0x6D, 0xEF, 0xE0, 0xF0, 0xFD, 0xC0,
+0x61, 0xA4, 0x76, 0x33, 0x2C, 0xEB, 0x74, 0x33,
+0x1B, 0x65, 0x21, 0x6B, 0x6B, 0xEB, 0x6C, 0xEF,
+0x78, 0x67, 0x6D, 0xEF, 0xE0, 0xF0, 0xFD, 0xC0,
+0x62, 0xA4, 0x72, 0x33, 0x2C, 0xEB, 0x70, 0x33,
+0x6D, 0xEE, 0xE0, 0xF0, 0xDE, 0xC0, 0x41, 0xA4,
+0x03, 0x6B, 0x6B, 0xEB, 0x46, 0x32, 0x2C, 0xEA,
+0x44, 0x32, 0x6C, 0xEF, 0x4D, 0xEF, 0xE0, 0xF0,
+0xFD, 0xC0, 0x41, 0xA4, 0xAC, 0xEF, 0xAC, 0xEE,
+0x5A, 0x32, 0x2C, 0xEA, 0x58, 0x32, 0x4D, 0xEF,
+0xE0, 0xF0, 0xFD, 0xC0, 0x63, 0xA4, 0xE0, 0xF0,
+0xFF, 0xA0, 0x0F, 0x6A, 0x6C, 0xEA, 0x10, 0x6B,
+0x6B, 0xEB, 0xEC, 0xEB, 0x4D, 0xEB, 0xE0, 0xF0,
+0x7F, 0xC0, 0x42, 0xA4, 0x5A, 0x32, 0x2C, 0xEA,
+0x58, 0x32, 0x4D, 0xEE, 0xE0, 0xF0, 0xDE, 0xC0,
+0x00, 0x18, 0x86, 0x44, 0xE0, 0xF0, 0x9C, 0xA0,
+0x86, 0x34, 0x2C, 0xEC, 0x00, 0x18, 0x6D, 0x1F,
+0xE0, 0xF0, 0x9C, 0xA0, 0x8A, 0x34, 0x2C, 0xEC,
+0x00, 0x18, 0x7E, 0x1F, 0xE0, 0xF0, 0x9D, 0xA0,
+0x08, 0x6A, 0xFF, 0x6B, 0x8C, 0xEA, 0x09, 0x22,
+0xE0, 0xF0, 0xBC, 0xA0, 0x0E, 0x6A, 0x00, 0x6C,
+0xAC, 0xEA, 0x6C, 0xEA, 0x07, 0x22, 0x91, 0x67,
+0x05, 0x10, 0xE0, 0xF0, 0x9C, 0xA0, 0x8E, 0x34,
+0x2C, 0xEC, 0x6C, 0xEC, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x00, 0x18, 0x92, 0x1A,
+0xE0, 0xF0, 0x9C, 0xA0, 0x01, 0x69, 0x92, 0x34,
+0x2C, 0xEC, 0x00, 0x18, 0xCA, 0x27, 0xE0, 0xF0,
+0x9C, 0xA0, 0x9A, 0x34, 0x2C, 0xEC, 0x00, 0x18,
+0xA3, 0x28, 0x00, 0x18, 0x83, 0x08, 0xE0, 0xF0,
+0x9C, 0xA0, 0x2C, 0xEC, 0x00, 0x18, 0x14, 0x20,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6C, 0x30, 0xF0,
+0x20, 0x6D, 0xA5, 0xF1, 0x00, 0x4C, 0x05, 0xF0,
+0x11, 0x4D, 0x08, 0x6E, 0x30, 0xF0, 0x20, 0x68,
+0x00, 0x18, 0x70, 0x2C, 0x61, 0xF3, 0x10, 0x48,
+0x01, 0x6A, 0x43, 0xF6, 0x5B, 0xC0, 0x00, 0xF1,
+0x59, 0xA0, 0x0D, 0x22, 0x00, 0x18, 0xA3, 0x2B,
+0x00, 0xF1, 0x99, 0xA0, 0x30, 0xF0, 0x20, 0x6E,
+0x60, 0x6D, 0x91, 0xE2, 0x9C, 0x34, 0x85, 0xF1,
+0x18, 0x4E, 0x00, 0x18, 0x8F, 0x2B, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF5, 0x60, 0x9A, 0xF0, 0x6A,
+0x30, 0xF0, 0x20, 0x68, 0x80, 0xA3, 0x61, 0xF3,
+0x10, 0x48, 0x8C, 0xEA, 0x40, 0xC3, 0x00, 0xF1,
+0x99, 0xA0, 0x00, 0x18, 0xC1, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF5, 0x48, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0xF5, 0x8C, 0x9C, 0x60, 0x9A,
+0x8C, 0xEB, 0x60, 0xDA, 0x23, 0xF4, 0x78, 0xA0,
+0x80, 0x9A, 0x66, 0x33, 0xC0, 0xF7, 0x60, 0x33,
+0x8D, 0xEB, 0x60, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x5C, 0x9A, 0x10, 0xF0, 0x00, 0x6B,
+0x60, 0xDA, 0x00, 0x18, 0xDD, 0x3F, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xC0, 0xA4, 0x01, 0x6A, 0x64, 0x67, 0x4C, 0xEE,
+0xFF, 0x6C, 0x43, 0x2E, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0xE0, 0xF0, 0xF5, 0xA3,
+0x02, 0x6D, 0xAB, 0xED, 0xEC, 0xED, 0xE0, 0xF0,
+0xF9, 0xA3, 0xCD, 0xED, 0x20, 0x6E, 0xCC, 0xEF,
+0x8C, 0xEF, 0xE0, 0xF0, 0xB5, 0xC3, 0x0B, 0x2F,
+0xE0, 0xF0, 0xB6, 0xA3, 0x7F, 0x6E, 0xAC, 0xEE,
+0xE0, 0xF0, 0xB5, 0xA3, 0xCC, 0xEC, 0xB6, 0x35,
+0x4E, 0xED, 0x4C, 0xED, 0x0F, 0x10, 0xE0, 0xF0,
+0xFB, 0xA3, 0x02, 0x6A, 0xEC, 0xEA, 0x8C, 0xEA,
+0x0C, 0x22, 0xCC, 0xED, 0x8C, 0xED, 0x13, 0x2D,
+0xE0, 0xF0, 0x76, 0xA3, 0x7F, 0x6A, 0x01, 0x6D,
+0x6C, 0xEA, 0x4C, 0xEC, 0x00, 0x18, 0x71, 0x32,
+0x11, 0x10, 0xCC, 0xED, 0x8C, 0xED, 0x07, 0x25,
+0xE0, 0xF0, 0x76, 0xA3, 0x7F, 0x6A, 0x00, 0x6D,
+0x6C, 0xEA, 0x4C, 0xEC, 0xF3, 0x17, 0xE0, 0xF0,
+0x76, 0xA3, 0x7F, 0x6A, 0x6C, 0xEA, 0x4C, 0xEC,
+0x00, 0x18, 0x7C, 0x32, 0x00, 0x18, 0xD6, 0x20,
+0x17, 0x12, 0x30, 0xF0, 0x20, 0x6D, 0x61, 0xF3,
+0x10, 0x4D, 0x05, 0x6E, 0x43, 0xF6, 0xD8, 0xC5,
+0xE0, 0xA3, 0xE0, 0xF0, 0x15, 0xA5, 0x02, 0x6E,
+0xCB, 0xEE, 0x4C, 0xEF, 0x0C, 0xEE, 0xED, 0xEE,
+0xE0, 0xF0, 0xD5, 0xC5, 0xE0, 0xA3, 0x11, 0x69,
+0x2B, 0xE9, 0xE6, 0x37, 0x4C, 0xEF, 0xE4, 0x30,
+0x03, 0x6F, 0xEB, 0xEF, 0x1F, 0x65, 0xCC, 0xEF,
+0x0D, 0xEF, 0xE0, 0xF0, 0xF5, 0xC5, 0xC0, 0xA3,
+0xCA, 0x36, 0x4C, 0xEE, 0xC8, 0x30, 0x05, 0x6E,
+0xCB, 0xEE, 0xEC, 0xEE, 0x0D, 0xEE, 0xE0, 0xF0,
+0xD5, 0xC5, 0xE0, 0xA3, 0x09, 0x68, 0x0B, 0xE8,
+0xEE, 0x37, 0x4C, 0xEF, 0xEC, 0x37, 0x0C, 0xEE,
+0xED, 0xEE, 0xE0, 0xF0, 0xD5, 0xC5, 0xE0, 0xA3,
+0x2C, 0xEE, 0xF2, 0x37, 0x4C, 0xEF, 0xF0, 0x37,
+0xED, 0xEE, 0xE0, 0xF0, 0xD5, 0xC5, 0xE0, 0xA3,
+0xF6, 0x37, 0x4C, 0xEF, 0xF4, 0x37, 0xFF, 0x65,
+0x21, 0x6F, 0xEB, 0xEF, 0xCC, 0xEF, 0xDF, 0x67,
+0xCD, 0xEF, 0xE0, 0xF0, 0xF5, 0xC5, 0xC0, 0xA3,
+0xDA, 0x36, 0x4C, 0xEE, 0xD8, 0x36, 0xFE, 0x65,
+0x41, 0x6E, 0xCB, 0xEE, 0xEC, 0xEE, 0xFF, 0x67,
+0xED, 0xEE, 0xE0, 0xF0, 0xD5, 0xC5, 0xE0, 0xA3,
+0xFE, 0x37, 0xFC, 0x37, 0xFF, 0x65, 0x7F, 0x6F,
+0x1F, 0x67, 0xEC, 0xEE, 0x0D, 0xEE, 0xE0, 0xF0,
+0xD5, 0xC5, 0x21, 0xA3, 0x3E, 0x31, 0x3C, 0x31,
+0x04, 0xD1, 0xE0, 0xF0, 0x16, 0xA5, 0xF8, 0x65,
+0x04, 0x90, 0x3F, 0x67, 0xEC, 0xE9, 0x0D, 0xE9,
+0xE0, 0xF0, 0x36, 0xC5, 0x24, 0xA3, 0xE0, 0xF0,
+0x19, 0xA5, 0x26, 0x31, 0x4C, 0xE9, 0x24, 0x31,
+0xF9, 0x65, 0x38, 0x67, 0x2C, 0xE8, 0x3F, 0x67,
+0x2D, 0xE8, 0xE0, 0xF0, 0x19, 0xC5, 0x18, 0x65,
+0x04, 0xA3, 0x09, 0x69, 0x2B, 0xE9, 0x0E, 0x30,
+0x4C, 0xE8, 0x0C, 0x30, 0xF8, 0x65, 0x18, 0x67,
+0x0C, 0xE9, 0x1F, 0x67, 0x0D, 0xE9, 0xE0, 0xF0,
+0x39, 0xC5, 0x05, 0xA3, 0xE0, 0xF0, 0x1A, 0xC5,
+0x04, 0xA3, 0x12, 0x30, 0x4C, 0xE8, 0x10, 0x30,
+0x18, 0x65, 0x11, 0x68, 0x0B, 0xE8, 0x0C, 0xE9,
+0x18, 0x67, 0x0D, 0xE9, 0xE0, 0xF0, 0x39, 0xC5,
+0xE0, 0xF0, 0x3B, 0xA5, 0x06, 0xA3, 0x19, 0x65,
+0x1E, 0x30, 0x38, 0x67, 0x1C, 0x30, 0x2C, 0xEF,
+0x0D, 0xEF, 0xE0, 0xF0, 0xFB, 0xC5, 0x04, 0x6F,
+0xEC, 0xEE, 0x8C, 0xEE, 0x20, 0x26, 0x30, 0xF0,
+0x20, 0x6E, 0xA0, 0xF5, 0xC0, 0x9E, 0x00, 0xA6,
+0x18, 0x65, 0x38, 0x67, 0x2F, 0x68, 0x2C, 0xE8,
+0x00, 0xC6, 0xE0, 0xF0, 0xA7, 0xA5, 0x00, 0xA6,
+0xAC, 0xEA, 0x8C, 0xE8, 0x50, 0x32, 0x0D, 0xEA,
+0x8C, 0xEA, 0x40, 0xC6, 0x00, 0xA6, 0x06, 0x6A,
+0xAC, 0xEA, 0x8C, 0xE8, 0x54, 0x32, 0x0D, 0xEA,
+0x8C, 0xEA, 0x40, 0xC6, 0x40, 0xA6, 0x8C, 0xEA,
+0xED, 0xEA, 0x8C, 0xEA, 0x40, 0xC6, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF4, 0x45, 0xA2, 0x08, 0x6E,
+0xFF, 0x6D, 0xCC, 0xEA, 0x09, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF5, 0x80, 0x9A, 0x40, 0xA4,
+0xAC, 0xEA, 0xCD, 0xEA, 0xAC, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0x95, 0xA2, 0x02, 0x6F, 0xFF, 0x6E,
+0xEC, 0xEC, 0x20, 0x24, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF5, 0xA0, 0x9C, 0x80, 0xA5, 0xCC, 0xEC,
+0xED, 0xEC, 0xCC, 0xEC, 0x80, 0xC5, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0xF5, 0xA8, 0x9C, 0x23, 0xF4,
+0xF8, 0xA2, 0x03, 0x6C, 0xC0, 0x9D, 0x8B, 0xEC,
+0xEC, 0xEC, 0xC0, 0xF7, 0xC2, 0x36, 0xC4, 0x36,
+0xCD, 0xEC, 0x23, 0xF4, 0x98, 0xC2, 0x30, 0xF0,
+0x20, 0x6C, 0x40, 0x9D, 0x80, 0xF4, 0x94, 0x9C,
+0x8D, 0xEA, 0x40, 0xDD, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0x9A, 0xA2,
+0x03, 0x2C, 0x01, 0x6C, 0xE0, 0xF0, 0x9A, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x89, 0xA2,
+0x10, 0x6A, 0x8C, 0xEA, 0x08, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF5, 0x90, 0x9A, 0x7F, 0x6A,
+0xA0, 0xA4, 0xAC, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x42, 0xF6,
+0x80, 0xA2, 0x02, 0x74, 0x09, 0x61, 0xE0, 0xF0,
+0x96, 0xA2, 0x80, 0x6A, 0x4B, 0xEA, 0x8C, 0xEA,
+0xFF, 0x6C, 0x8C, 0xEA, 0xE0, 0xF0, 0x01, 0x2A,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xA1, 0xA3, 0xE0, 0xF0, 0x96, 0xA0, 0x80, 0x6A,
+0x7F, 0x69, 0x4B, 0xEA, 0x2C, 0xED, 0x4C, 0xEC,
+0xAD, 0xEC, 0xE0, 0xF0, 0x96, 0xC0, 0xA2, 0xA3,
+0xE0, 0xF0, 0xD7, 0xA0, 0x2C, 0xED, 0x4C, 0xEE,
+0xAD, 0xEE, 0xE0, 0xF0, 0xD7, 0xC0, 0xA3, 0xA3,
+0x01, 0x6A, 0x2C, 0xEE, 0xE5, 0x67, 0x4C, 0xEF,
+0x1F, 0x65, 0xE0, 0xF0, 0xF8, 0xA0, 0x02, 0x6D,
+0xAB, 0xED, 0xAC, 0xEF, 0xB8, 0x67, 0xAD, 0xEF,
+0xE0, 0xF0, 0xF8, 0xC0, 0xA3, 0xA3, 0x4C, 0xEF,
+0xA6, 0x35, 0xA4, 0x35, 0xAD, 0xEF, 0xE0, 0xF0,
+0xF8, 0xC0, 0xE4, 0xA3, 0x05, 0x6D, 0xAB, 0xED,
+0xEA, 0x37, 0x4C, 0xEF, 0xE8, 0x37, 0xFF, 0x65,
+0xE0, 0xF0, 0xF9, 0xA0, 0x1D, 0x65, 0xAC, 0xEF,
+0xBF, 0x67, 0xAD, 0xEF, 0xE0, 0xF0, 0xF9, 0xC0,
+0xA2, 0xA3, 0xBE, 0x35, 0xBC, 0x35, 0xAD, 0xEE,
+0xE0, 0xF0, 0xD7, 0xC0, 0xC4, 0xA3, 0x02, 0x6D,
+0xAB, 0xED, 0xD6, 0x36, 0x4C, 0xEE, 0xD4, 0x36,
+0xFE, 0x65, 0x21, 0x6E, 0xCB, 0xEE, 0xEC, 0xEE,
+0xFF, 0x67, 0xED, 0xEE, 0xE0, 0xF0, 0xD9, 0xC0,
+0xE4, 0xA3, 0x2C, 0xEE, 0xFE, 0x37, 0xFC, 0x37,
+0xED, 0xEE, 0xE0, 0xF0, 0xD9, 0xC0, 0xE4, 0xA3,
+0xAC, 0xEE, 0x4C, 0xEF, 0xED, 0xEE, 0xE0, 0xF0,
+0xD9, 0xC0, 0xE6, 0xA3, 0xA7, 0x67, 0x4C, 0xED,
+0xE0, 0xF0, 0xFB, 0xA0, 0xFD, 0x65, 0x02, 0x6D,
+0xAB, 0xED, 0xAC, 0xEF, 0xBF, 0x67, 0xAD, 0xEF,
+0xE0, 0xF0, 0xFB, 0xC0, 0xA6, 0xA3, 0xA6, 0x35,
+0x4C, 0xED, 0xA4, 0x35, 0xFD, 0x65, 0x03, 0x6D,
+0xAB, 0xED, 0xEC, 0xED, 0xFF, 0x67, 0xED, 0xED,
+0xE0, 0xF0, 0xBB, 0xC0, 0x66, 0xA3, 0xF8, 0x67,
+0xEC, 0xED, 0x6A, 0x33, 0x4C, 0xEB, 0x68, 0x33,
+0x6D, 0xED, 0x20, 0x6B, 0x6C, 0xEE, 0xE0, 0xF0,
+0xBB, 0xC0, 0x09, 0x2E, 0xE0, 0xF0, 0xB5, 0xA0,
+0x2C, 0xEC, 0xFF, 0x68, 0xB6, 0x35, 0x4E, 0xED,
+0x0C, 0xEC, 0x4C, 0xED, 0x13, 0x10, 0x02, 0x6A,
+0xAC, 0xEA, 0xFF, 0x6D, 0xAC, 0xEA, 0x11, 0x22,
+0xE0, 0xF0, 0x55, 0xA0, 0x4C, 0xEB, 0xAC, 0xEB,
+0x05, 0x23, 0x2C, 0xEC, 0xAC, 0xEC, 0x00, 0x18,
+0x7C, 0x32, 0x2C, 0x10, 0x2C, 0xEC, 0xFF, 0x6E,
+0xCC, 0xEC, 0x01, 0x6D, 0x00, 0x18, 0x71, 0x32,
+0x25, 0x10, 0xE0, 0xF0, 0x55, 0xA0, 0xFF, 0x6F,
+0x6C, 0xEA, 0xEC, 0xEA, 0x04, 0x22, 0x2C, 0xEC,
+0xEC, 0xEC, 0x00, 0x6D, 0xF3, 0x17, 0xFF, 0x6A,
+0x2C, 0xEC, 0x4C, 0xEC, 0x00, 0x18, 0x7C, 0x32,
+0xE0, 0xF0, 0x79, 0xA0, 0x7F, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x81, 0x72,
+0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x8C, 0x9A, 0x00, 0x18, 0xF9, 0x06, 0xE0, 0xF0,
+0x56, 0xA0, 0xFF, 0x6C, 0x4C, 0xE9, 0x2C, 0xEC,
+0x00, 0x18, 0x8D, 0x32, 0x00, 0x18, 0x1C, 0x1E,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0x99, 0xA2, 0x03, 0x6B, 0x8C, 0xEB,
+0x01, 0x73, 0x0F, 0x61, 0x80, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xFF, 0x6C, 0x8C, 0xEB, 0x09, 0x2B,
+0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF0, 0x64, 0x9A,
+0x00, 0xF5, 0x88, 0x9C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x00, 0x18, 0xD1, 0x3F, 0x30, 0xF0,
+0x20, 0x6C, 0x05, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x05, 0xF0, 0x11, 0x4C, 0x00, 0x6D, 0x08, 0x6E,
+0xC5, 0xF1, 0x68, 0xC2, 0x00, 0x18, 0x6B, 0x2C,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6C, 0xA4, 0xF7, 0x08, 0x4C,
+0x00, 0x6D, 0x1F, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF4, 0x0C, 0x4C,
+0x00, 0x6D, 0x07, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF4, 0x05, 0x4C,
+0x00, 0x6D, 0x07, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x00, 0x18, 0x52, 0x1D, 0x00, 0x18, 0x43, 0x29,
+0x00, 0x18, 0xE8, 0x26, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF7, 0x63, 0x11, 0x62,
+0x10, 0xD1, 0x0F, 0xD0, 0xFF, 0x69, 0x04, 0x67,
+0x2C, 0xED, 0x2C, 0xE8, 0x0C, 0xD5, 0x00, 0x18,
+0xA3, 0x2B, 0x0B, 0xD2, 0x09, 0xE2, 0x5C, 0x32,
+0x0A, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x0A, 0x93,
+0x60, 0xF5, 0x58, 0x9A, 0x0A, 0x94, 0x49, 0xE3,
+0x60, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x44, 0x9A, 0x2C, 0xEB, 0x49, 0xE4, 0x40, 0xA2,
+0x4C, 0xE9, 0x20, 0x32, 0x45, 0xE3, 0xE7, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE9, 0x30, 0xF0, 0x20, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5, 0x50, 0x9A,
+0xC0, 0xF5, 0x64, 0x9B, 0x49, 0xE4, 0x6D, 0xE4,
+0x29, 0xE2, 0x2D, 0xE3, 0x00, 0x6C, 0x80, 0xC2,
+0x01, 0x4A, 0x6A, 0xEA, 0xFB, 0x61, 0x01, 0x6A,
+0x0C, 0x97, 0x04, 0xD2, 0xC8, 0x41, 0xFF, 0xF7,
+0x1F, 0x6A, 0x0A, 0x6D, 0x4C, 0xEE, 0x10, 0x6C,
+0x00, 0x18, 0x8F, 0x41, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF4, 0xBE, 0xA2, 0x03, 0xED, 0x11, 0x60,
+0x0B, 0x92, 0x0C, 0x93, 0xB3, 0xE0, 0xB5, 0xE2,
+0xBC, 0x35, 0x7B, 0xE1, 0x9C, 0x34, 0xFF, 0xF7,
+0x1F, 0x6B, 0xAF, 0x35, 0x6C, 0xED, 0x30, 0x4C,
+0x04, 0xD5, 0xF8, 0x4E, 0x6C, 0xEC, 0x38, 0x6D,
+0x14, 0x10, 0x0B, 0x93, 0x0C, 0x94, 0x17, 0xE5,
+0x09, 0xE3, 0x5C, 0x32, 0x08, 0x6B, 0x7A, 0xEA,
+0x01, 0x2B, 0xE5, 0xE8, 0xBC, 0x35, 0xFF, 0xF7,
+0x1F, 0x6B, 0x9B, 0xE1, 0x38, 0x4D, 0xF8, 0x4E,
+0x30, 0x6C, 0x6C, 0xED, 0x12, 0xEA, 0x6C, 0xEA,
+0x04, 0xD2, 0xFF, 0x6A, 0x4C, 0xEE, 0x08, 0x6F,
+0x00, 0x18, 0x83, 0x41, 0x30, 0xF0, 0x20, 0x6D,
+0x08, 0x04, 0x05, 0xF0, 0x00, 0x4D, 0x08, 0x6E,
+0x06, 0x00, 0x00, 0x18, 0x70, 0x2C, 0x08, 0x04,
+0x00, 0x6D, 0xD0, 0x67, 0x08, 0x6F, 0x00, 0x18,
+0xE3, 0x42, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5,
+0x50, 0x9A, 0x0A, 0x94, 0x49, 0xE4, 0x25, 0xE2,
+0x08, 0x02, 0x60, 0xA0, 0x01, 0x48, 0x4A, 0xE8,
+0x60, 0xC1, 0x01, 0x49, 0xFA, 0x61, 0x11, 0x97,
+0x10, 0x91, 0x0F, 0x90, 0x09, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5, 0x58, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5, 0x64, 0x9B,
+0xFF, 0x68, 0x49, 0xE4, 0x0C, 0xED, 0x05, 0xD5,
+0x04, 0xD2, 0x6D, 0xE4, 0x40, 0xA2, 0xA0, 0xA3,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF5, 0x34, 0x9B,
+0x0C, 0xED, 0x25, 0xE4, 0xC0, 0xA1, 0x90, 0x67,
+0x4C, 0xEC, 0x0C, 0xEE, 0x00, 0x18, 0x0D, 0x1D,
+0x06, 0xD2, 0x80, 0xA1, 0x0C, 0xEC, 0x00, 0x18,
+0xFD, 0x1C, 0x22, 0x67, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x43, 0xF6, 0xD9, 0xA2,
+0x07, 0x5E, 0x33, 0x60, 0x43, 0xF6, 0x79, 0x82,
+0x01, 0x6A, 0x44, 0xEB, 0x14, 0x6B, 0x4C, 0xEB,
+0x18, 0x2B, 0x62, 0x6B, 0x4C, 0xEB, 0x29, 0x23,
+0x30, 0xF0, 0x20, 0x68, 0x05, 0x95, 0x85, 0xF1,
+0x18, 0x48, 0x90, 0x67, 0x00, 0x18, 0x1A, 0x1A,
+0x04, 0x93, 0x06, 0x94, 0x89, 0xE3, 0x2B, 0xE2,
+0x25, 0xE0, 0x04, 0x10, 0x60, 0xA0, 0x01, 0x48,
+0x60, 0xC2, 0x01, 0x4A, 0x2A, 0xE8, 0xFA, 0x61,
+0x14, 0x10, 0x30, 0xF0, 0x20, 0x68, 0x05, 0x95,
+0x85, 0xF1, 0x18, 0x48, 0x90, 0x67, 0x00, 0x18,
+0xE1, 0x19, 0x04, 0x93, 0x06, 0x94, 0x89, 0xE3,
+0x2B, 0xE2, 0x25, 0xE0, 0x04, 0x10, 0x60, 0xA0,
+0x01, 0x48, 0x60, 0xC2, 0x01, 0x4A, 0x2A, 0xE8,
+0xFA, 0x61, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xEE,
+0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A, 0xA4, 0xF7,
+0x1F, 0x4A, 0x67, 0x42, 0x05, 0xD6, 0x01, 0x4B,
+0x00, 0x6E, 0xC0, 0xC2, 0x01, 0x4A, 0x6A, 0xEA,
+0xFB, 0x61, 0x05, 0x92, 0x91, 0xE5, 0x30, 0xF0,
+0x20, 0x68, 0x53, 0xE4, 0x04, 0xD4, 0xA4, 0xF7,
+0x1F, 0x48, 0x00, 0x69, 0x0B, 0x10, 0x04, 0x94,
+0x01, 0x49, 0x00, 0x18, 0x97, 0x2B, 0x40, 0xC0,
+0xFF, 0x6A, 0x4C, 0xE9, 0x04, 0x92, 0x01, 0x48,
+0x01, 0x4A, 0x04, 0xD2, 0x05, 0x92, 0x43, 0xE9,
+0xF2, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x40, 0xA4, 0x0C, 0x6B, 0x6C, 0xEA, 0x08, 0x72,
+0x40, 0x61, 0x46, 0xA4, 0x88, 0x72, 0x3D, 0x61,
+0x47, 0xA4, 0x8E, 0x72, 0x3A, 0x61, 0x49, 0xA4,
+0x03, 0x72, 0x39, 0x61, 0x4E, 0xA4, 0x08, 0x6B,
+0x6C, 0xEA, 0x0B, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x58, 0x9A, 0x01, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x21, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xE0, 0xF0, 0xDC, 0xA2, 0xFF, 0x6D,
+0x6C, 0xEE, 0x0C, 0x26, 0x00, 0xF1, 0xC3, 0xA2,
+0x02, 0x76, 0x05, 0x61, 0xE0, 0xF0, 0xDD, 0xA2,
+0xCC, 0xEB, 0xAC, 0xEB, 0x09, 0x23, 0x00, 0x18,
+0x15, 0x1C, 0x15, 0x10, 0xE0, 0xF0, 0x95, 0xA2,
+0x40, 0x6B, 0x8C, 0xEB, 0xAC, 0xEB, 0x0F, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5, 0x78, 0x9B,
+0x02, 0x6C, 0x80, 0xC3, 0x23, 0xF4, 0x98, 0xA2,
+0x01, 0x6B, 0x8D, 0xEB, 0x23, 0xF4, 0x78, 0xC2,
+0x02, 0x10, 0x00, 0x6A, 0x01, 0x10, 0x01, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x69, 0x04, 0x00, 0x8C, 0xE9, 0x00, 0x6D,
+0x90, 0x67, 0x08, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x01, 0x6A, 0x2C, 0xEA, 0x0E, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x00, 0xF1,
+0x63, 0xA2, 0x30, 0xF0, 0x20, 0x6D, 0x90, 0x67,
+0x43, 0xF6, 0x79, 0xC2, 0xC5, 0xF1, 0x10, 0x4D,
+0x29, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x00, 0xF1, 0x64, 0xA2, 0x43, 0xF6,
+0x79, 0xC2, 0x43, 0xF6, 0x58, 0xA2, 0x01, 0x72,
+0x0C, 0x60, 0x05, 0x22, 0x02, 0x72, 0x0F, 0x60,
+0x03, 0x72, 0x13, 0x60, 0x1A, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x90, 0x67, 0xC5, 0xF1, 0x18, 0x4D,
+0x11, 0x10, 0x30, 0xF0, 0x20, 0x6D, 0x90, 0x67,
+0xE5, 0xF1, 0x00, 0x4D, 0x0B, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x90, 0x67, 0xE5, 0xF1, 0x08, 0x4D,
+0x05, 0x10, 0x30, 0xF0, 0x20, 0x6D, 0x90, 0x67,
+0xE5, 0xF1, 0x10, 0x4D, 0x08, 0x6E, 0x00, 0x18,
+0x70, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x43, 0xF6, 0xB9, 0xA2, 0x07, 0x5D,
+0x66, 0x60, 0x43, 0xF6, 0x79, 0x82, 0x01, 0x6A,
+0x44, 0xEB, 0x14, 0x6B, 0x4C, 0xEB, 0x07, 0x2B,
+0x62, 0x6B, 0x4C, 0xEB, 0x5C, 0x23, 0x04, 0x04,
+0x00, 0x18, 0xFB, 0x19, 0x03, 0x10, 0x04, 0x04,
+0x00, 0x18, 0xBF, 0x19, 0x02, 0x67, 0x4D, 0x22,
+0x01, 0x6A, 0x2C, 0xEA, 0x12, 0x2A, 0x30, 0xF0,
+0x20, 0x6C, 0xC5, 0xF1, 0x10, 0x4C, 0x30, 0xF0,
+0x20, 0x6D, 0xA4, 0xF7, 0x1F, 0x4D, 0x08, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x30, 0xF0, 0x20, 0x6B,
+0xA4, 0xF7, 0x1F, 0x4B, 0x80, 0xF4, 0x0C, 0x6A,
+0x20, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF1,
+0x48, 0xA2, 0x01, 0x72, 0x0B, 0x60, 0x05, 0x22,
+0x02, 0x72, 0x0D, 0x60, 0x03, 0x72, 0x10, 0x60,
+0xED, 0x17, 0x30, 0xF0, 0x20, 0x6C, 0xC5, 0xF1,
+0x18, 0x4C, 0xE1, 0x17, 0x30, 0xF0, 0x20, 0x6C,
+0xE5, 0xF1, 0x00, 0x4C, 0xDC, 0x17, 0x30, 0xF0,
+0x20, 0x6C, 0xE5, 0xF1, 0x08, 0x4C, 0xD7, 0x17,
+0x30, 0xF0, 0x20, 0x6C, 0xE5, 0xF1, 0x10, 0x4C,
+0xD2, 0x17, 0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC,
+0x02, 0xF0, 0x00, 0x74, 0x01, 0x60, 0x05, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0x94, 0x9C,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5,
+0x98, 0x9C, 0xA0, 0xA3, 0x91, 0xE2, 0x01, 0x4A,
+0x80, 0xF4, 0x14, 0x72, 0xA0, 0xC4, 0x01, 0x4B,
+0xE8, 0x61, 0x50, 0x67, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x01, 0x68,
+0xAB, 0x17, 0x00, 0x65, 0xF5, 0x63, 0x15, 0x62,
+0x14, 0xD1, 0x13, 0xD0, 0xFF, 0x6A, 0x0F, 0xD2,
+0x7D, 0x67, 0x60, 0xF0, 0x68, 0xA3, 0x18, 0xD6,
+0xDD, 0x67, 0x10, 0xD3, 0x60, 0xF0, 0xCC, 0xA6,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0x44, 0x9A,
+0x16, 0xD4, 0x17, 0xD5, 0x19, 0xD7, 0x11, 0xD6,
+0x40, 0xA2, 0xFF, 0x6B, 0x4C, 0xEB, 0x0F, 0xD3,
+0x00, 0x18, 0xB4, 0x2B, 0x12, 0x2A, 0x00, 0x6C,
+0xFF, 0x6D, 0x39, 0x6E, 0x00, 0x18, 0xC5, 0x3A,
+0x00, 0x18, 0x5B, 0x40, 0x01, 0x72, 0x00, 0x68,
+0x12, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x9C, 0xA2, 0x01, 0x6D, 0x18, 0x6E, 0xF0, 0x67,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x9C, 0xA2, 0x01, 0x6D, 0x18, 0x6E, 0x00, 0x6F,
+0x00, 0x18, 0x3E, 0x48, 0x02, 0x67, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF5,
+0x44, 0x9A, 0x40, 0xF5, 0x70, 0x9B, 0x49, 0xE0,
+0x6D, 0xE0, 0x80, 0xA2, 0xA0, 0xA3, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF5, 0x68, 0x9B, 0xFF, 0x6A,
+0x4C, 0xEC, 0x6D, 0xE0, 0xC0, 0xA3, 0x4C, 0xED,
+0x4C, 0xEE, 0x00, 0x18, 0x0D, 0x1D, 0x10, 0x95,
+0x87, 0x40, 0x29, 0x4C, 0x22, 0x67, 0x00, 0x18,
+0x80, 0x22, 0x11, 0x96, 0x34, 0x2E, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF5,
+0x58, 0x9A, 0x00, 0xF6, 0xA0, 0x9D, 0x16, 0x94,
+0x18, 0x93, 0x49, 0xE0, 0xB5, 0xE0, 0x29, 0xE2,
+0x35, 0xE5, 0xC0, 0xA4, 0x01, 0x4C, 0xC0, 0xC2,
+0xE0, 0xA3, 0xC8, 0x42, 0xF8, 0x4E, 0xE0, 0xC6,
+0xC0, 0xA3, 0x01, 0x4B, 0xD8, 0xC2, 0x01, 0x4A,
+0xAA, 0xEA, 0xF3, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF5, 0x9C, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF5, 0x7C, 0x9A, 0x91, 0xE0, 0x00, 0x6A,
+0x6D, 0xE0, 0x2D, 0xE3, 0x17, 0x96, 0x55, 0xE6,
+0xA0, 0xA5, 0xA0, 0xC4, 0x19, 0x96, 0x01, 0x4C,
+0x55, 0xE6, 0xA0, 0xA5, 0x01, 0x4A, 0x06, 0x72,
+0xA0, 0xC3, 0x01, 0x4B, 0xF3, 0x61, 0x16, 0x94,
+0x18, 0x95, 0x20, 0x6E, 0x3A, 0x6F, 0x00, 0x18,
+0xA0, 0x1E, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF5,
+0x78, 0x9A, 0x0E, 0x04, 0x04, 0x02, 0x6D, 0xE0,
+0x2D, 0xE3, 0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2,
+0x01, 0x4A, 0x8A, 0xEA, 0xFA, 0x61, 0x38, 0x48,
+0x21, 0xE0, 0x90, 0x67, 0x0E, 0xD0, 0x30, 0xF0,
+0x20, 0x6E, 0x30, 0xF0, 0x20, 0x68, 0x28, 0x6D,
+0x65, 0xF1, 0x10, 0x4E, 0x61, 0xF3, 0x10, 0x48,
+0x00, 0x18, 0x8F, 0x2B, 0x0E, 0x95, 0x00, 0xF1,
+0xCC, 0xA0, 0x3A, 0x6C, 0x00, 0x18, 0x07, 0x45,
+0x0E, 0x94, 0x28, 0x6D, 0x04, 0x06, 0x00, 0x18,
+0x8F, 0x2B, 0x00, 0xF1, 0x43, 0xA0, 0x02, 0x72,
+0x05, 0x61, 0x00, 0xF1, 0x8C, 0xA0, 0xB1, 0x67,
+0x00, 0x18, 0x37, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x34, 0x9A, 0xFF, 0x68, 0x02, 0x6B,
+0x40, 0xA1, 0x00, 0x6C, 0x3A, 0x6E, 0x0C, 0xEA,
+0x6D, 0xEA, 0x0C, 0xEA, 0x40, 0xC1, 0x0F, 0x95,
+0x00, 0x18, 0xC5, 0x3A, 0x00, 0x18, 0x7E, 0x48,
+0x06, 0x2A, 0x40, 0xA1, 0x20, 0x6B, 0x0C, 0xEA,
+0x6D, 0xEA, 0x0C, 0xEA, 0x40, 0xC1, 0x15, 0x97,
+0x14, 0x91, 0x13, 0x90, 0x0B, 0x63, 0x00, 0xEF,
+0xF4, 0x63, 0x17, 0x62, 0x16, 0xD1, 0x15, 0xD0,
+0x00, 0x6A, 0x7D, 0x67, 0x06, 0xD2, 0x4E, 0xCB,
+0x08, 0xD2, 0x09, 0xD2, 0x0A, 0xD2, 0x0B, 0xD2,
+0x0C, 0xD2, 0x0D, 0xD2, 0x0E, 0xD2, 0x0F, 0xD2,
+0x46, 0xA4, 0x24, 0x67, 0x86, 0x72, 0xC0, 0xF0,
+0x15, 0x61, 0x47, 0xA4, 0xDD, 0x72, 0xC0, 0xF0,
+0x11, 0x61, 0x4E, 0xA4, 0x3A, 0x72, 0xC0, 0xF0,
+0x0D, 0x61, 0x20, 0xF0, 0x50, 0xA4, 0x87, 0x72,
+0xC0, 0xF0, 0x08, 0x61, 0xA7, 0x41, 0x0C, 0x04,
+0x31, 0x4D, 0x10, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x05, 0xF1, 0x01, 0x4C,
+0x11, 0xD4, 0x00, 0x68, 0x38, 0x6C, 0x98, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x12, 0xEC, 0x4D, 0xE4, 0x83, 0xF5, 0xB0, 0xA3,
+0x01, 0x6B, 0xAC, 0xEB, 0xA0, 0xF0, 0x10, 0x23,
+0x89, 0xE2, 0x83, 0xF5, 0x12, 0x4A, 0x12, 0xD2,
+0x13, 0xD2, 0x00, 0x6A, 0x10, 0xD2, 0x9B, 0x10,
+0xE0, 0xA2, 0xC0, 0xA4, 0x01, 0x4A, 0x01, 0x4C,
+0xEE, 0xEE, 0x01, 0x5E, 0xD8, 0x67, 0xCB, 0xEE,
+0xAA, 0xEA, 0xCC, 0xEB, 0xF5, 0x61, 0x01, 0x73,
+0x7C, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x74, 0x9A, 0xFF, 0x6C, 0x01, 0x6D, 0x40, 0xA3,
+0x06, 0x6E, 0x8C, 0xEA, 0xFF, 0xF6, 0x1B, 0x4C,
+0x8C, 0xEA, 0xAD, 0xEA, 0xFF, 0x6C, 0x8C, 0xEA,
+0xA7, 0x41, 0x40, 0xC3, 0x06, 0x04, 0x43, 0x4D,
+0x00, 0x18, 0x70, 0x2C, 0xA7, 0x41, 0x08, 0x04,
+0x09, 0x4D, 0x10, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x38, 0x6B, 0x78, 0xE8, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x10, 0x4C, 0x01, 0x6D, 0x12, 0xEB,
+0x89, 0xE3, 0x83, 0xF5, 0x50, 0xA2, 0x46, 0x32,
+0xAC, 0xEA, 0x30, 0x22, 0x77, 0x10, 0xE0, 0xA2,
+0xC0, 0xA4, 0x01, 0x4A, 0x01, 0x4C, 0xEE, 0xEE,
+0x01, 0x5E, 0xD8, 0x67, 0xCB, 0xEE, 0xAA, 0xEA,
+0xCC, 0xEB, 0xF5, 0x61, 0x01, 0x73, 0x50, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0xF1, 0x63, 0xA2, 0x02, 0x73, 0x12, 0x61,
+0xE0, 0xF0, 0x9D, 0xA2, 0x08, 0x6B, 0x8C, 0xEB,
+0x0D, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5,
+0x78, 0x9B, 0x0A, 0x6C, 0x80, 0xC3, 0x23, 0xF4,
+0x98, 0xA2, 0x01, 0x6B, 0x8D, 0xEB, 0x23, 0xF4,
+0x78, 0xC2, 0x4A, 0x10, 0x00, 0x6A, 0x04, 0xD2,
+0x05, 0xD2, 0x08, 0x04, 0x06, 0x05, 0x0C, 0x06,
+0x13, 0x97, 0x20, 0x10, 0x00, 0xF1, 0x43, 0xA4,
+0x02, 0x72, 0x15, 0x61, 0xE0, 0xF0, 0x7D, 0xA4,
+0x08, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x0E, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x58, 0x9A, 0x0A, 0x6B, 0x01, 0x6D, 0x60, 0xC2,
+0x23, 0xF4, 0x58, 0xA4, 0xAD, 0xEA, 0x23, 0xF4,
+0x58, 0xC4, 0x45, 0x67, 0x2A, 0x10, 0x12, 0x97,
+0x00, 0x6A, 0x04, 0xD2, 0x05, 0xD2, 0x08, 0x04,
+0x06, 0x05, 0x0C, 0x06, 0x00, 0x18, 0x4F, 0x23,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x74, 0x9A, 0xFF, 0x6C, 0x05, 0x6D, 0x40, 0xA3,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3,
+0x10, 0x92, 0x01, 0x4A, 0x10, 0xD2, 0x10, 0x93,
+0xFF, 0x6A, 0x4C, 0xEB, 0x10, 0xD3, 0x11, 0x94,
+0x10, 0x95, 0x40, 0xA4, 0x43, 0xED, 0x15, 0x61,
+0x01, 0x48, 0x38, 0x4C, 0x02, 0x70, 0x11, 0xD4,
+0x03, 0x60, 0x44, 0x17, 0x00, 0x6A, 0x01, 0x10,
+0x01, 0x6A, 0x17, 0x97, 0x16, 0x91, 0x15, 0x90,
+0x0C, 0x63, 0x00, 0xEF, 0x71, 0xE4, 0x08, 0x02,
+0x83, 0xF5, 0x18, 0x4C, 0x0C, 0x05, 0x01, 0x6B,
+0x82, 0x17, 0x10, 0x94, 0x0C, 0x02, 0x10, 0x05,
+0x90, 0x33, 0x38, 0x6C, 0x98, 0xE8, 0x12, 0xEC,
+0x91, 0xE3, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x91, 0xE3, 0xA3, 0xF5, 0x08, 0x4C,
+0x01, 0x6B, 0x3A, 0x17, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xFF, 0x6A, 0x00, 0xF5, 0x64, 0x9B, 0x4C, 0xEE,
+0x4C, 0xEF, 0x0C, 0xD4, 0x0D, 0xD5, 0x06, 0xD6,
+0x04, 0xD7, 0x60, 0xA3, 0x6C, 0xEA, 0x05, 0xD2,
+0x00, 0x18, 0xB4, 0x2B, 0x12, 0x2A, 0x00, 0x6C,
+0xFF, 0x6D, 0x33, 0x6E, 0x00, 0x18, 0xC5, 0x3A,
+0x00, 0x18, 0x5B, 0x40, 0x01, 0x72, 0x00, 0x68,
+0x12, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x9B, 0xA2, 0x01, 0x6D, 0x18, 0x6E, 0xF0, 0x67,
+0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4,
+0x9B, 0xA2, 0x01, 0x6D, 0x18, 0x6E, 0x00, 0x6F,
+0x00, 0x18, 0x3E, 0x48, 0x02, 0x67, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF5,
+0x44, 0x9A, 0x40, 0xF5, 0x70, 0x9B, 0x49, 0xE0,
+0x6D, 0xE0, 0x80, 0xA2, 0xA0, 0xA3, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF5, 0x68, 0x9B, 0xFF, 0x6A,
+0x4C, 0xEC, 0x6D, 0xE0, 0xC0, 0xA3, 0x4C, 0xED,
+0x4C, 0xEE, 0x00, 0x18, 0x0D, 0x1D, 0x06, 0x95,
+0x87, 0x40, 0x29, 0x4C, 0x22, 0x67, 0x00, 0x18,
+0x80, 0x22, 0x04, 0x92, 0x2E, 0x2A, 0x30, 0xF0,
+0x20, 0x6C, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5,
+0x80, 0x9C, 0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF5,
+0x5C, 0x9A, 0xA0, 0xF5, 0xB4, 0x9D, 0x0D, 0x93,
+0x91, 0xE0, 0x49, 0xE0, 0x31, 0xE4, 0xB5, 0xE0,
+0xC0, 0xA3, 0xC0, 0xC2, 0xC0, 0xA3, 0x01, 0x4A,
+0xAA, 0xEA, 0xC0, 0xC4, 0x01, 0x4B, 0x01, 0x4C,
+0xF7, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6C, 0xA0, 0xF5, 0x58, 0x9A, 0x00, 0xF6,
+0x84, 0x9C, 0x0C, 0x93, 0x49, 0xE0, 0x81, 0xE0,
+0x29, 0xE2, 0x21, 0xE0, 0x80, 0xA3, 0x01, 0x4B,
+0x80, 0xC2, 0x01, 0x4A, 0x0A, 0xEA, 0xFA, 0x61,
+0x2D, 0x10, 0x04, 0x92, 0x01, 0x72, 0x2A, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF5, 0x9C, 0x9B,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF5, 0x60, 0x9B,
+0x30, 0xF0, 0x20, 0x6A, 0xE5, 0xF0, 0x0C, 0x4A,
+0x6D, 0xE0, 0x91, 0xE0, 0x2D, 0xE3, 0xA6, 0x42,
+0xC0, 0xA2, 0xC0, 0xC4, 0xCA, 0xA2, 0x01, 0x4A,
+0xAA, 0xEA, 0xC0, 0xC3, 0x01, 0x4C, 0x01, 0x4B,
+0xF7, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF5,
+0x78, 0x9B, 0x30, 0xF0, 0x20, 0x6A, 0xE5, 0xF0,
+0x1C, 0x4A, 0x61, 0xE0, 0x21, 0xE0, 0x64, 0x42,
+0x80, 0xA2, 0x01, 0x4A, 0x6A, 0xEA, 0x80, 0xC0,
+0x01, 0x48, 0xFA, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x00, 0xF1, 0x63, 0xA2,
+0x02, 0x73, 0x05, 0x61, 0x00, 0xF1, 0x8B, 0xA2,
+0xB1, 0x67, 0x00, 0x18, 0x37, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF6, 0x68, 0x9A, 0xFF, 0x68,
+0x10, 0x6C, 0x40, 0xA3, 0x34, 0x6E, 0x0C, 0xEA,
+0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3, 0x05, 0x95,
+0x00, 0x6C, 0x00, 0x18, 0xC5, 0x3A, 0x00, 0x18,
+0x7E, 0x48, 0x0A, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x74, 0x9A, 0x20, 0x6C, 0x40, 0xA3,
+0x0C, 0xEA, 0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x00, 0x6A, 0x7D, 0x67,
+0x08, 0xD2, 0x52, 0xCB, 0x04, 0xD2, 0x05, 0xD2,
+0x00, 0xF1, 0x51, 0xA4, 0x00, 0xF1, 0x70, 0xA4,
+0x04, 0x67, 0x40, 0x32, 0x6D, 0xEA, 0x00, 0xF1,
+0x72, 0xA4, 0x60, 0x33, 0x60, 0x33, 0x4D, 0xEB,
+0x00, 0xF1, 0x53, 0xA4, 0x00, 0xF6, 0x40, 0x32,
+0x6D, 0xEA, 0x66, 0xA2, 0x08, 0x73, 0xC0, 0xF0,
+0x14, 0x61, 0x47, 0xA2, 0x06, 0x72, 0xC0, 0xF0,
+0x10, 0x61, 0x65, 0xA4, 0x44, 0xA4, 0xA7, 0xA4,
+0x60, 0x33, 0x4D, 0xEB, 0x46, 0xA4, 0x00, 0xF6,
+0xA0, 0x35, 0x06, 0x01, 0x40, 0x32, 0x40, 0x32,
+0x6D, 0xEA, 0x4D, 0xED, 0x91, 0x67, 0x0A, 0x4D,
+0x06, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0xA4, 0xF7, 0x0F, 0x4A, 0x00, 0xF0,
+0x1E, 0x04, 0x01, 0x6B, 0xC0, 0xA1, 0xA0, 0xA2,
+0x01, 0x49, 0x01, 0x4A, 0xCE, 0xED, 0x01, 0x5D,
+0xB8, 0x67, 0xAB, 0xED, 0x8A, 0xE9, 0xAC, 0xEB,
+0xF5, 0x61, 0x01, 0x73, 0x01, 0x6A, 0xA0, 0xF0,
+0x09, 0x61, 0x00, 0xF1, 0x71, 0xA0, 0x00, 0xF1,
+0x50, 0xA0, 0x00, 0xF1, 0xB3, 0xA0, 0x60, 0x33,
+0x4D, 0xEB, 0x00, 0xF1, 0x52, 0xA0, 0x00, 0xF6,
+0xA0, 0x35, 0x05, 0x04, 0x40, 0x32, 0x40, 0x32,
+0x6D, 0xEA, 0x4D, 0xED, 0x20, 0x4D, 0x04, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x5D, 0x67, 0xB4, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xDD, 0x67, 0x75, 0xA6, 0x83, 0xF5, 0x82, 0xA2,
+0x83, 0xF5, 0x43, 0xA2, 0x6E, 0xEA, 0x00, 0x6B,
+0x04, 0x2A, 0x65, 0x67, 0x8E, 0xEB, 0x01, 0x5B,
+0x78, 0x67, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x9D, 0x67, 0xB6, 0xA4, 0x83, 0xF5,
+0x84, 0xA2, 0xAE, 0xEC, 0x01, 0x5C, 0x98, 0x67,
+0x8B, 0xEC, 0x8C, 0xEB, 0x9D, 0x67, 0xB7, 0xA4,
+0x83, 0xF5, 0x85, 0xA2, 0xAE, 0xEC, 0x5D, 0x2C,
+0x01, 0x73, 0x5B, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF6, 0xC8, 0x9B, 0xFF, 0x6D, 0xDE, 0x4C,
+0x60, 0xA6, 0xAC, 0xEB, 0x8C, 0xEB, 0x01, 0x6C,
+0x8D, 0xEB, 0xAC, 0xEB, 0x60, 0xC6, 0xE0, 0xF0,
+0x7E, 0xA2, 0x8C, 0xEB, 0xAC, 0xEB, 0x0A, 0x2B,
+0x00, 0xF1, 0x63, 0xA2, 0x02, 0x73, 0x12, 0x61,
+0xE0, 0xF0, 0xDD, 0xA2, 0x08, 0x6B, 0xCC, 0xEB,
+0xAC, 0xEB, 0x0C, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF5, 0x78, 0x9B, 0x09, 0x6D, 0xA0, 0xC3,
+0x23, 0xF4, 0x78, 0xA2, 0x6D, 0xEC, 0x23, 0xF4,
+0x98, 0xC2, 0x41, 0x10, 0x00, 0xF1, 0x71, 0xA0,
+0x00, 0xF1, 0x50, 0xA0, 0x00, 0xF1, 0xB3, 0xA0,
+0x60, 0x33, 0x4D, 0xEB, 0x00, 0xF1, 0x52, 0xA0,
+0x00, 0xF6, 0xA0, 0x35, 0x08, 0x01, 0x40, 0x32,
+0x40, 0x32, 0x6D, 0xEA, 0x4D, 0xED, 0x91, 0x67,
+0x10, 0x4D, 0x06, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x00, 0xF1, 0x71, 0xA0, 0x00, 0xF1, 0x50, 0xA0,
+0x00, 0xF1, 0xB3, 0xA0, 0x60, 0x33, 0x4D, 0xEB,
+0x00, 0xF1, 0x52, 0xA0, 0x00, 0xF6, 0xA0, 0x35,
+0x04, 0x00, 0x40, 0x32, 0x40, 0x32, 0x6D, 0xEA,
+0x4D, 0xED, 0x90, 0x67, 0x16, 0x4D, 0x04, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x00, 0x6E, 0x90, 0x67,
+0xB1, 0x67, 0xE6, 0x67, 0x00, 0x18, 0x45, 0x24,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF6,
+0x68, 0x9A, 0xFF, 0x6C, 0x32, 0x6D, 0x40, 0xA3,
+0xAB, 0xED, 0x8C, 0xEA, 0xAC, 0xEA, 0x21, 0x6D,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x01, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF7, 0x63, 0x11, 0x62, 0x10, 0xD1, 0x0F, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xD2, 0xF4, 0x01, 0x4A,
+0x40, 0xDB, 0x00, 0x6C, 0x00, 0x18, 0x91, 0x44,
+0x01, 0x6C, 0x07, 0xD2, 0x00, 0x18, 0x91, 0x44,
+0x09, 0xD2, 0x00, 0x18, 0xAC, 0x2B, 0x0C, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x6C, 0xA2,
+0x01, 0x6A, 0x6C, 0xEA, 0x00, 0xF2, 0x08, 0x22,
+0x00, 0x6A, 0x06, 0xD2, 0x04, 0xD2, 0x08, 0xD2,
+0xFE, 0x11, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF6,
+0xCC, 0x9A, 0x22, 0xF6, 0xF8, 0x98, 0x07, 0x94,
+0x30, 0xF0, 0x20, 0x6D, 0xC4, 0xF5, 0x0C, 0x4D,
+0x00, 0x18, 0x6E, 0x3A, 0x09, 0x95, 0x07, 0x94,
+0x00, 0x18, 0xAE, 0x44, 0x43, 0xF2, 0x7C, 0x98,
+0x05, 0xD2, 0x3F, 0x6C, 0x40, 0xA3, 0x61, 0xA3,
+0x8C, 0xEB, 0x60, 0x33, 0x4D, 0xEB, 0x05, 0x94,
+0x63, 0xF2, 0x40, 0x98, 0x0A, 0xD3, 0x20, 0xA2,
+0x00, 0x18, 0x97, 0x2B, 0x05, 0x94, 0x0B, 0xD2,
+0x01, 0x4C, 0x00, 0x18, 0x97, 0x2B, 0x05, 0x94,
+0x0D, 0xD2, 0x04, 0x4C, 0x00, 0x18, 0x97, 0x2B,
+0x0B, 0x94, 0x0D, 0x95, 0xC2, 0x67, 0x00, 0x18,
+0x0D, 0x1D, 0x0B, 0xD2, 0x26, 0xF5, 0x50, 0xA0,
+0x1F, 0x22, 0x50, 0x71, 0x0F, 0x60, 0x80, 0x71,
+0x00, 0xF1, 0x06, 0x61, 0x00, 0xF1, 0x7F, 0xA0,
+0x01, 0x6A, 0x6C, 0xEA, 0x00, 0xF1, 0x00, 0x22,
+0x0A, 0x95, 0xFF, 0xF7, 0x1F, 0x6B, 0x05, 0x94,
+0x6C, 0xED, 0x0B, 0x10, 0x00, 0xF1, 0x7F, 0xA0,
+0x01, 0x6A, 0x6C, 0xEA, 0xE0, 0xF0, 0x14, 0x22,
+0x0A, 0x95, 0x05, 0x94, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xED, 0x00, 0x18, 0xCC, 0x45, 0xEC, 0x10,
+0x88, 0x71, 0x33, 0x60, 0x89, 0x59, 0x03, 0x60,
+0x08, 0x71, 0x2F, 0x60, 0xE5, 0x10, 0xA0, 0x71,
+0x03, 0x60, 0xC0, 0x71, 0xE0, 0xF0, 0x00, 0x61,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xE0, 0xF0, 0x75, 0xA0, 0x80, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0xC0, 0xF0,
+0x13, 0x22, 0x43, 0xF4, 0x45, 0xA0, 0x01, 0x4A,
+0x43, 0xF4, 0x45, 0xC0, 0x43, 0xF2, 0x5C, 0x98,
+0x87, 0xA2, 0x01, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA,
+0xC0, 0xF0, 0x06, 0x22, 0x63, 0xF2, 0x80, 0x98,
+0x00, 0x18, 0x8D, 0x1C, 0xC0, 0xF0, 0x00, 0x22,
+0x91, 0x67, 0x00, 0x18, 0x3F, 0x1D, 0x43, 0xF4,
+0x46, 0xA0, 0x01, 0x4A, 0x43, 0xF4, 0x46, 0xC0,
+0xB7, 0x10, 0x05, 0x90, 0x04, 0x48, 0x90, 0x67,
+0x00, 0x18, 0x97, 0x2B, 0x82, 0x67, 0x00, 0x18,
+0xFD, 0x1C, 0x05, 0x94, 0x0B, 0x95, 0xC2, 0x67,
+0x00, 0x18, 0xB3, 0x22, 0x90, 0x67, 0x00, 0x18,
+0x97, 0x2B, 0x82, 0x67, 0x00, 0x18, 0xF2, 0x22,
+0x80, 0xF0, 0x17, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0x9C, 0xA2,
+0x40, 0x6B, 0x8C, 0xEB, 0x1B, 0x23, 0x63, 0xF3,
+0x4C, 0x9A, 0x07, 0x42, 0x48, 0xA2, 0x01, 0x48,
+0x45, 0x72, 0x14, 0x61, 0x90, 0x67, 0x00, 0x18,
+0xDD, 0x27, 0x01, 0x72, 0x0F, 0x61, 0x90, 0x67,
+0x00, 0x18, 0xE6, 0x27, 0x01, 0x72, 0x0A, 0x61,
+0x90, 0x67, 0x00, 0x18, 0xEC, 0x27, 0x03, 0x2A,
+0x90, 0x67, 0x00, 0x18, 0x11, 0x28, 0x01, 0x6B,
+0x06, 0xD3, 0x04, 0xD3, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x43, 0xF2, 0x7C, 0x9A,
+0x87, 0xA3, 0x01, 0x6B, 0x8C, 0xEB, 0x08, 0x23,
+0x63, 0xF3, 0x8C, 0x9A, 0x00, 0x18, 0xCB, 0x22,
+0x03, 0x22, 0x01, 0x6B, 0x06, 0xD3, 0x04, 0xD3,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x6C, 0xA2,
+0x02, 0x6A, 0x6C, 0xEA, 0x0A, 0x22, 0x30, 0xF0,
+0x20, 0x6C, 0xC4, 0xF5, 0x0C, 0x4C, 0x00, 0x18,
+0xB3, 0x24, 0x03, 0x22, 0x01, 0x6B, 0x06, 0xD3,
+0x04, 0xD3, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xE0, 0xF0, 0x9C, 0xA2, 0x04, 0x6B,
+0x8C, 0xEB, 0x08, 0x23, 0x63, 0xF3, 0x8C, 0x9A,
+0x00, 0x18, 0xC0, 0x23, 0x03, 0x22, 0x01, 0x6B,
+0x06, 0xD3, 0x04, 0xD3, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xE0, 0xF0, 0x7D, 0xA0,
+0x20, 0x6A, 0x6C, 0xEA, 0x11, 0x22, 0x63, 0xF3,
+0x8C, 0x98, 0x00, 0x18, 0x9D, 0x1C, 0x0C, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x0B, 0x6B, 0x60, 0xC2, 0x23, 0xF4, 0x78, 0xA0,
+0x01, 0x6A, 0x6D, 0xEA, 0x23, 0xF4, 0x58, 0xC0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xE0, 0xF0, 0x7C, 0xA0, 0x80, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x24, 0x22,
+0x04, 0x93, 0x03, 0x23, 0x01, 0x6A, 0x04, 0xD2,
+0x1F, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF5,
+0x0C, 0x4C, 0x00, 0x18, 0xBC, 0x1C, 0x18, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x22, 0x6B, 0x60, 0xC2, 0x23, 0xF4, 0x78, 0xA0,
+0x01, 0x6A, 0x6D, 0xEA, 0x23, 0xF4, 0x58, 0xC0,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x74, 0x9A, 0xFF, 0x6C, 0x08, 0x6D, 0x40, 0xA3,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x43, 0xF2, 0x9C, 0x98, 0x01, 0x6D, 0x00, 0x18,
+0x1A, 0x1D, 0x0B, 0x22, 0x23, 0xF4, 0x78, 0xA0,
+0x01, 0x6A, 0x6D, 0xEA, 0x23, 0xF4, 0x58, 0xC0,
+0x43, 0xF2, 0x5C, 0x98, 0x50, 0xA2, 0x43, 0xF6,
+0x5A, 0xC0, 0x08, 0x71, 0x02, 0x60, 0x88, 0x71,
+0x4C, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xE0, 0xF0, 0x9E, 0xA2, 0x40, 0x6B,
+0x8C, 0xEB, 0x0E, 0x23, 0x06, 0x93, 0x0C, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5, 0x78, 0x9B,
+0x25, 0x6C, 0x80, 0xC3, 0x23, 0xF4, 0x98, 0xA2,
+0x01, 0x6B, 0x8D, 0xEB, 0x23, 0xF4, 0x78, 0xC2,
+0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF5, 0x0C, 0x4C,
+0x00, 0x18, 0xD2, 0x1C, 0x11, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x23, 0xF4, 0x98, 0xA2, 0x02, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x23, 0xF4, 0x78, 0xC2,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xE0, 0xF0, 0x7D, 0xA0, 0x40, 0x6A, 0x6C, 0xEA,
+0x14, 0x22, 0x30, 0xF0, 0x20, 0x6C, 0xC4, 0xF5,
+0x0C, 0x4C, 0x00, 0x18, 0xE9, 0x1E, 0x0D, 0x22,
+0x23, 0xF4, 0x78, 0xA0, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x23, 0xF4, 0x58, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x07, 0x95, 0x09, 0x96, 0x01, 0x6C,
+0x00, 0x18, 0xBB, 0x44, 0x07, 0x95, 0x09, 0x96,
+0x00, 0x6C, 0x22, 0x67, 0x00, 0x18, 0xBB, 0x44,
+0x07, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0xA4, 0xF7,
+0x68, 0xA2, 0x01, 0x6A, 0x6C, 0xEA, 0x03, 0x22,
+0x01, 0x6C, 0x00, 0x18, 0x3E, 0x1E, 0x00, 0x18,
+0x4A, 0x1D, 0x01, 0x72, 0x30, 0x61, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x43, 0xF4,
+0x47, 0xA0, 0x01, 0x4A, 0x43, 0xF4, 0x47, 0xC0,
+0x00, 0x18, 0x6E, 0x44, 0x01, 0x72, 0x15, 0x60,
+0x23, 0xF4, 0x98, 0xA0, 0x01, 0x6B, 0x02, 0x72,
+0x8D, 0xEB, 0x23, 0xF4, 0x78, 0xC0, 0x42, 0x6B,
+0x03, 0x60, 0x04, 0x72, 0x06, 0x61, 0x43, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x60, 0xC2, 0x01, 0x6C, 0x00, 0x18, 0x3E, 0x1E,
+0x1F, 0x10, 0x07, 0x95, 0x91, 0x67, 0x00, 0x18,
+0x97, 0x44, 0x08, 0x92, 0x09, 0xD1, 0x01, 0x4A,
+0x08, 0xD2, 0x08, 0x93, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEB, 0x08, 0xD3, 0x0C, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0,
+0x9C, 0xA2, 0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0xE0, 0xF0, 0x7C, 0xC2, 0x05, 0x10, 0x08, 0x92,
+0x0C, 0x93, 0x63, 0xEA, 0xFF, 0xF5, 0x1D, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xD2, 0xF4, 0x02, 0x4A,
+0x40, 0xDB, 0x11, 0x97, 0x10, 0x91, 0x0F, 0x90,
+0x09, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xA0, 0xF0, 0x76, 0xA0,
+0x44, 0x67, 0x01, 0x6C, 0xFF, 0x69, 0x8C, 0xEB,
+0x2C, 0xED, 0x2C, 0xEB, 0x2C, 0xEA, 0x04, 0xD5,
+0x42, 0x23, 0x24, 0xF1, 0x6C, 0xA0, 0x3F, 0x23,
+0x85, 0x67, 0xA2, 0x67, 0x00, 0x18, 0x4E, 0x34,
+0x07, 0x22, 0x00, 0x6A, 0x24, 0xF1, 0x4C, 0xC0,
+0x01, 0x6A, 0x24, 0xF1, 0x4E, 0xC0, 0x33, 0x10,
+0xA0, 0xF0, 0x78, 0xA0, 0x24, 0xF1, 0x4C, 0xA0,
+0x63, 0xEA, 0x21, 0x61, 0xA0, 0xF0, 0x76, 0xA0,
+0x08, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA, 0x0A, 0x22,
+0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x6D, 0x00, 0x18,
+0x8F, 0x11, 0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x18,
+0xB1, 0x11, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF5, 0x58, 0x9A, 0x10, 0x6B, 0x01, 0x6C,
+0x60, 0xC2, 0x00, 0x18, 0x3E, 0x1E, 0xA0, 0xF0,
+0x76, 0xA0, 0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xA0, 0xF0, 0x56, 0xC0, 0x0C, 0x10, 0xA0, 0xF0,
+0x8A, 0xA0, 0x04, 0x97, 0x02, 0x6D, 0x08, 0x6E,
+0x00, 0x18, 0x71, 0x19, 0x24, 0xF1, 0x4C, 0xA0,
+0x01, 0x4A, 0x24, 0xF1, 0x4C, 0xC0, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xE4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF3, 0x10, 0x4C, 0xA0, 0xF0,
+0xAF, 0xA4, 0x04, 0x6B, 0xFF, 0x6A, 0xAC, 0xEB,
+0x4C, 0xEB, 0x4C, 0xEF, 0x07, 0x23, 0x00, 0x6C,
+0xA4, 0x67, 0xC4, 0x67, 0x01, 0x6F, 0x00, 0x18,
+0x45, 0x24, 0x06, 0x10, 0xA0, 0xF0, 0x8A, 0xA4,
+0x02, 0x6D, 0x08, 0x6E, 0x00, 0x18, 0x71, 0x19,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xA0, 0xF0, 0x76, 0xA0, 0x24, 0x67, 0x01, 0x6C,
+0xFF, 0x6A, 0x6C, 0xEC, 0x4C, 0xEC, 0x4C, 0xE9,
+0x67, 0x24, 0x24, 0xF1, 0x8B, 0xA0, 0x01, 0x4C,
+0x24, 0xF1, 0x8B, 0xC0, 0x24, 0xF1, 0x8E, 0xA0,
+0x01, 0x74, 0x2C, 0x61, 0x04, 0x6C, 0x6C, 0xEC,
+0x4C, 0xEC, 0x28, 0x24, 0x24, 0xF1, 0x8D, 0xA0,
+0x25, 0x2C, 0x24, 0xF1, 0xAB, 0xA0, 0xA0, 0xF0,
+0x99, 0xA0, 0x83, 0xED, 0x1F, 0x61, 0x08, 0x6C,
+0x6C, 0xEC, 0x4C, 0xEC, 0x0A, 0x24, 0xE0, 0xF0,
+0x88, 0xA0, 0x00, 0x6D, 0x00, 0x18, 0x8F, 0x11,
+0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x18, 0xB1, 0x11,
+0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x58, 0x9A, 0x10, 0x6B, 0x01, 0x6C, 0x60, 0xC2,
+0x00, 0x18, 0x3E, 0x1E, 0xA0, 0xF0, 0x76, 0xA0,
+0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xA0, 0xF0,
+0x56, 0xC0, 0x32, 0x10, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xA0, 0xF0, 0x77, 0xA0,
+0x24, 0xF1, 0x4B, 0xA0, 0x63, 0xEA, 0x28, 0x61,
+0x91, 0x67, 0x00, 0x18, 0xA0, 0x39, 0x01, 0x6B,
+0x4C, 0xEB, 0x15, 0x2B, 0x24, 0xF1, 0x4D, 0xA0,
+0x12, 0x2A, 0x24, 0xF1, 0x4C, 0xA0, 0xA0, 0xF0,
+0x8A, 0xA0, 0x02, 0x6D, 0x01, 0x4A, 0x24, 0xF1,
+0x4C, 0xC0, 0x24, 0xF1, 0x4A, 0xA0, 0x08, 0x6E,
+0xF1, 0x67, 0x01, 0x4A, 0x24, 0xF1, 0x4A, 0xC0,
+0x00, 0x18, 0x71, 0x19, 0x04, 0x10, 0x91, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0x98, 0x39, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x00, 0x6B,
+0x24, 0xF1, 0x6B, 0xC2, 0x24, 0xF1, 0x6D, 0xC2,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x24, 0x67, 0xA0, 0xF0,
+0x8F, 0xA0, 0x01, 0x6B, 0xFF, 0x6A, 0x8C, 0xEB,
+0x4C, 0xEB, 0x4C, 0xE9, 0x2B, 0x23, 0xE0, 0xF0,
+0x88, 0xA0, 0x00, 0x18, 0x86, 0x11, 0x01, 0x72,
+0x25, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x71, 0xA2, 0x0A, 0x6C, 0x01, 0x4B, 0x41, 0xF3,
+0x71, 0xC2, 0x41, 0xF3, 0x71, 0xA2, 0x8E, 0xEB,
+0x07, 0x2B, 0x24, 0xF1, 0x89, 0xA0, 0x41, 0xF3,
+0x71, 0xC2, 0x01, 0x4C, 0x24, 0xF1, 0x89, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA0, 0xF0, 0x90, 0xA2, 0x24, 0xF1, 0x69, 0xA2,
+0x83, 0xEB, 0x08, 0x61, 0x24, 0xF1, 0x6A, 0xA2,
+0x05, 0x2B, 0x24, 0xF1, 0x69, 0xC2, 0x91, 0x67,
+0x00, 0x18, 0x78, 0x26, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0x9C, 0xA2, 0x11, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xE0, 0xF0, 0x7C, 0xC2, 0x00, 0x6B,
+0xE3, 0xF6, 0x60, 0xC2, 0xE3, 0xF6, 0x61, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0xF5, 0x63, 0x15, 0x62,
+0x14, 0xD1, 0x13, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xED, 0xE5, 0x67, 0x0F, 0xD5, 0xDC, 0x4F,
+0x00, 0x6D, 0x16, 0xD4, 0xC5, 0x67, 0x24, 0x4C,
+0x4C, 0xEF, 0x00, 0x18, 0xB0, 0x45, 0x02, 0x67,
+0x81, 0x42, 0x00, 0x6A, 0x0E, 0xD2, 0x13, 0x24,
+0x00, 0x18, 0x97, 0x2B, 0x0E, 0xD2, 0x02, 0x48,
+0x00, 0x69, 0x08, 0x10, 0x90, 0x67, 0x00, 0x18,
+0x97, 0x2B, 0x9D, 0x67, 0x2D, 0xE4, 0x50, 0xC3,
+0x01, 0x49, 0x01, 0x48, 0x0E, 0x93, 0xFF, 0x6A,
+0x2C, 0xEA, 0x63, 0xEA, 0xF3, 0x61, 0x0F, 0x91,
+0x16, 0x94, 0xFF, 0xF7, 0x1F, 0x6A, 0xDC, 0x49,
+0x4C, 0xE9, 0x24, 0x4C, 0x00, 0x6D, 0x03, 0x6E,
+0xF1, 0x67, 0x0D, 0xD4, 0x00, 0x18, 0xB0, 0x45,
+0x16, 0x94, 0x00, 0x68, 0x22, 0x4C, 0x00, 0x18,
+0x97, 0x2B, 0x10, 0x6B, 0x4C, 0xEB, 0x54, 0x23,
+0x0D, 0x94, 0xB0, 0x67, 0xF1, 0x67, 0x30, 0x6E,
+0x00, 0x18, 0xB0, 0x45, 0x22, 0x67, 0x01, 0x4A,
+0x01, 0x68, 0x1E, 0x22, 0x87, 0x41, 0x01, 0x4C,
+0x00, 0x18, 0x97, 0x2B, 0x0D, 0x49, 0x0D, 0xD1,
+0x10, 0xD2, 0x00, 0x69, 0x12, 0x10, 0x0D, 0x94,
+0x00, 0x18, 0x97, 0x2B, 0x02, 0x72, 0x02, 0x61,
+0x20, 0x48, 0x03, 0x10, 0x04, 0x72, 0x03, 0x61,
+0x40, 0x48, 0xFF, 0x6A, 0x4C, 0xE8, 0xFF, 0x6A,
+0x01, 0x49, 0x4C, 0xE9, 0x0D, 0x92, 0x04, 0x4A,
+0x0D, 0xD2, 0x10, 0x93, 0x63, 0xE9, 0xEB, 0x61,
+0x0F, 0x92, 0x16, 0x94, 0xFF, 0xF7, 0x1F, 0x6F,
+0xDC, 0x4A, 0x24, 0x4C, 0x01, 0x6D, 0xDD, 0x6E,
+0x4C, 0xEF, 0x00, 0x18, 0xB0, 0x45, 0x22, 0x67,
+0x01, 0x4A, 0x1E, 0x22, 0x87, 0x41, 0x05, 0x4C,
+0x00, 0x18, 0x97, 0x2B, 0x11, 0x49, 0x0C, 0xD1,
+0x0D, 0xD2, 0x00, 0x69, 0x12, 0x10, 0x0C, 0x94,
+0x00, 0x18, 0x97, 0x2B, 0x02, 0x72, 0x02, 0x61,
+0x02, 0x48, 0x03, 0x10, 0x04, 0x72, 0x03, 0x61,
+0x04, 0x48, 0xFF, 0x6A, 0x4C, 0xE8, 0x0C, 0x94,
+0x01, 0x49, 0xFF, 0x6A, 0x04, 0x4C, 0x4C, 0xE9,
+0x0C, 0xD4, 0x0D, 0x92, 0x43, 0xE9, 0xEB, 0x61,
+0x00, 0x6B, 0x0C, 0xD3, 0x6A, 0x10, 0x0C, 0x94,
+0x49, 0xE4, 0xE3, 0xF6, 0x70, 0xA2, 0x0E, 0x94,
+0x8E, 0xEB, 0x5E, 0x2B, 0x03, 0xF7, 0x40, 0xA2,
+0x01, 0x2A, 0x0A, 0x20, 0x0C, 0x93, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x49, 0xE3,
+0x03, 0xF7, 0x40, 0xA2, 0x0C, 0xEA, 0x50, 0x22,
+0x0C, 0x94, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x7F, 0x4C, 0x7A, 0x4C, 0x94, 0x34,
+0x91, 0xE3, 0x0E, 0x93, 0x04, 0x02, 0x08, 0x4C,
+0x75, 0xE2, 0x01, 0x6B, 0x09, 0x10, 0xE0, 0xA2,
+0xC0, 0xA4, 0x01, 0x4A, 0x01, 0x4C, 0xEE, 0xEE,
+0x01, 0x5E, 0xD8, 0x67, 0xCB, 0xEE, 0xCC, 0xEB,
+0xAA, 0xEA, 0xF5, 0x61, 0x01, 0x73, 0x58, 0x67,
+0x0D, 0xD2, 0x32, 0x2A, 0x30, 0xF0, 0x20, 0x69,
+0x61, 0xF3, 0x10, 0x49, 0xE0, 0xF0, 0xC7, 0xA1,
+0x00, 0x6D, 0x0C, 0x6C, 0x00, 0x18, 0xD7, 0x14,
+0xA3, 0xF3, 0x78, 0xA1, 0x21, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x02, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0x7D, 0x67, 0x87, 0x43, 0xA3, 0xF3, 0x58, 0xC1,
+0x2D, 0x4C, 0x60, 0xA4, 0xE0, 0xF0, 0x87, 0xA1,
+0x26, 0xF5, 0x70, 0xC1, 0x00, 0x18, 0x87, 0x3F,
+0xE0, 0xF0, 0x87, 0xA1, 0x00, 0x18, 0x76, 0x3F,
+0xE0, 0xF0, 0x87, 0xA1, 0x00, 0x18, 0x8E, 0x3F,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x55, 0x6B, 0x60, 0xC2, 0x23, 0xF4, 0x78, 0xA1,
+0x01, 0x6A, 0x6D, 0xEA, 0x23, 0xF4, 0x58, 0xC1,
+0x0C, 0x94, 0xFF, 0x6A, 0x01, 0x4C, 0x4C, 0xEC,
+0x0C, 0xD4, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xE3, 0xF6, 0x60, 0xA2, 0x0C, 0x94,
+0x63, 0xEC, 0x8D, 0x61, 0x15, 0x97, 0x14, 0x91,
+0x13, 0x90, 0x0B, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x18,
+0xA3, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x20, 0xF1, 0x80, 0xA3, 0x30, 0xF0,
+0x20, 0x6D, 0x60, 0xF5, 0xB8, 0x9D, 0x91, 0xE2,
+0x9C, 0x34, 0xB5, 0xE4, 0xA0, 0xA5, 0xFF, 0x6E,
+0xE4, 0x44, 0xE3, 0xF6, 0xA0, 0xC3, 0x30, 0xF0,
+0x20, 0x6D, 0x80, 0xF5, 0xA4, 0x9D, 0xB5, 0xE4,
+0xA0, 0xA5, 0xE3, 0xF6, 0xA1, 0xC3, 0xE3, 0xF6,
+0x60, 0xA3, 0x0A, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF6, 0xB4, 0x9B, 0x01, 0x68, 0x60, 0xA5,
+0xCC, 0xEB, 0x0D, 0xEB, 0xCC, 0xEB, 0x60, 0xC5,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF5, 0x78, 0x9B,
+0x30, 0xF0, 0x20, 0x6D, 0x6D, 0xE7, 0x60, 0x9B,
+0x45, 0xF2, 0x74, 0xDD, 0x30, 0xF0, 0x20, 0x6D,
+0x00, 0xF6, 0xB8, 0x9D, 0xAE, 0xEB, 0x0B, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF6, 0xB4, 0x9B,
+0xFF, 0x6E, 0x02, 0x6F, 0x60, 0xA5, 0xCC, 0xEB,
+0xED, 0xEB, 0xCC, 0xEB, 0x60, 0xC5, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF5, 0xB4, 0x9B, 0x30, 0xF0,
+0x20, 0x6B, 0x65, 0xF2, 0x00, 0x4B, 0xC7, 0x43,
+0xB5, 0xE4, 0x09, 0x4E, 0xE0, 0xA5, 0x01, 0x4D,
+0xE0, 0xC3, 0x01, 0x4B, 0xCA, 0xEB, 0xFA, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF6, 0xB0, 0x9B,
+0x30, 0xF0, 0x20, 0x6B, 0x65, 0xF2, 0x10, 0x4B,
+0xC7, 0x43, 0xB5, 0xE4, 0x09, 0x4E, 0xE0, 0xA5,
+0x01, 0x4D, 0xE0, 0xC3, 0x01, 0x4B, 0xCA, 0xEB,
+0xFA, 0x61, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF5,
+0x7C, 0x9B, 0x71, 0xE4, 0x30, 0xF0, 0x20, 0x6B,
+0x85, 0xF2, 0x10, 0x4B, 0xA7, 0x43, 0x01, 0x4D,
+0xC0, 0xA4, 0x01, 0x4C, 0xC0, 0xC3, 0x01, 0x4B,
+0xAA, 0xEB, 0xFA, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF4, 0x70, 0xA3, 0x01, 0x4B, 0x49, 0xE3,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF5, 0x78, 0x9B,
+0x5C, 0x32, 0x69, 0xE2, 0x00, 0x6B, 0x0A, 0x10,
+0xE0, 0xA4, 0x01, 0x4C, 0xCA, 0xEC, 0xE0, 0xC5,
+0x01, 0x4D, 0xFA, 0x61, 0x01, 0x4B, 0x10, 0x73,
+0x20, 0x4A, 0x0D, 0x60, 0xF0, 0xF0, 0xA9, 0x43,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF3, 0x10, 0x4C,
+0xB4, 0x35, 0xB5, 0xE4, 0xC7, 0x42, 0x08, 0x4D,
+0x19, 0x4E, 0x82, 0x67, 0xE9, 0x17, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x0D, 0x24, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5,
+0x8C, 0x9B, 0x80, 0x6D, 0xAB, 0xED, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x00, 0x18, 0x78, 0x27, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF4,
+0x0F, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x05, 0xF2, 0x04, 0x4A, 0x10, 0x4C, 0x64, 0x42,
+0xC0, 0xA4, 0xA0, 0xA2, 0xCE, 0xED, 0x02, 0x25,
+0x00, 0x6A, 0x20, 0xE8, 0x01, 0x4A, 0x6A, 0xEA,
+0x01, 0x4C, 0xF6, 0x61, 0x01, 0x6A, 0x20, 0xE8,
+0x57, 0xA4, 0x76, 0xA4, 0x40, 0x32, 0x6D, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x05, 0xF2, 0x68, 0xAB,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE5, 0xF1, 0x7E, 0xAA,
+0x00, 0x6A, 0x0F, 0x2B, 0x24, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x61, 0xF3, 0x10, 0x4D, 0x59, 0xE4,
+0xB5, 0xE2, 0xDC, 0xA6, 0x83, 0xF6, 0xBC, 0xA5,
+0xCE, 0xED, 0x19, 0x2D, 0x01, 0x4A, 0xFF, 0x6D,
+0xAC, 0xEA, 0x63, 0xEA, 0xF0, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF6, 0x7C, 0x9A, 0xFF, 0x6C,
+0x40, 0x6D, 0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x00, 0x6B, 0x83, 0xF6,
+0x7A, 0xCA, 0x01, 0x6A, 0x20, 0xE8, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF6, 0x72, 0xAA,
+0x01, 0x4B, 0x83, 0xF6, 0x72, 0xCA, 0x30, 0xF0,
+0x20, 0x6B, 0x83, 0xF6, 0xB2, 0xAA, 0xE0, 0xF5,
+0x74, 0x9B, 0xA2, 0x35, 0x6D, 0xE4, 0xA0, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF6, 0x60, 0x9B,
+0x83, 0xF6, 0x52, 0xA2, 0x71, 0xE4, 0x40, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x05, 0xF2, 0x60, 0xAA,
+0x00, 0x6A, 0x10, 0x10, 0x30, 0xF0, 0x20, 0x6D,
+0x61, 0xF3, 0x10, 0x4D, 0x59, 0xE4, 0xB5, 0xE2,
+0xDC, 0xA6, 0xA3, 0xF6, 0xBC, 0xA5, 0xCE, 0xED,
+0x02, 0x25, 0x00, 0x6A, 0x1B, 0x10, 0x01, 0x4A,
+0xFF, 0x6D, 0xAC, 0xEA, 0x63, 0xEA, 0xEE, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF6, 0x7C, 0x9A,
+0xFF, 0x6C, 0x80, 0x6D, 0x40, 0xA3, 0xAB, 0xED,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A,
+0x30, 0x6B, 0x01, 0x6C, 0x60, 0xC2, 0x00, 0x18,
+0x3E, 0x1E, 0x01, 0x6A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x69,
+0x61, 0xF3, 0x10, 0x49, 0x00, 0xF1, 0x14, 0xA1,
+0x00, 0x18, 0xA3, 0x2B, 0x01, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF5, 0x58, 0x9A, 0x1C, 0x30,
+0x49, 0xE0, 0x40, 0xAA, 0x83, 0xF6, 0x48, 0xC9,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF6, 0x44, 0x9A,
+0x49, 0xE0, 0x40, 0xAA, 0x83, 0xF6, 0x4A, 0xC9,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF5, 0x54, 0x9A,
+0x49, 0xE0, 0x40, 0xAA, 0x83, 0xF6, 0x4C, 0xC9,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF6, 0x48, 0x9A,
+0x49, 0xE0, 0x40, 0xAA, 0x83, 0xF6, 0x4E, 0xC9,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5, 0x58, 0x9A,
+0x41, 0xE0, 0x40, 0xA8, 0x83, 0xF6, 0x50, 0xC9,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x69,
+0x61, 0xF3, 0x10, 0x49, 0x00, 0xF1, 0x15, 0xA1,
+0x00, 0x18, 0xA3, 0x2B, 0x01, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF5, 0x44, 0x9A, 0x1C, 0x30,
+0x04, 0xD0, 0x49, 0xE0, 0x80, 0xA2, 0x30, 0xF0,
+0x20, 0x6A, 0x04, 0x93, 0x40, 0xF5, 0x50, 0x9A,
+0xFF, 0x68, 0x0C, 0xEC, 0x49, 0xE3, 0xA0, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5, 0x48, 0x9A,
+0x0C, 0xED, 0x49, 0xE3, 0xC0, 0xA2, 0x0C, 0xEE,
+0x00, 0x18, 0x0D, 0x1D, 0x04, 0x93, 0x38, 0x4A,
+0x30, 0xF0, 0x20, 0x6C, 0x69, 0xE2, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF5, 0x74, 0x9B, 0x20, 0xF6,
+0x80, 0x9C, 0x6D, 0xE2, 0x60, 0xA3, 0x91, 0xE2,
+0x80, 0xA4, 0x0C, 0xEB, 0x60, 0x33, 0x8C, 0xE8,
+0x61, 0xE0, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF6,
+0x6C, 0x9B, 0x83, 0xF6, 0x12, 0xC9, 0x00, 0xF1,
+0x16, 0xA1, 0x6D, 0xE2, 0x60, 0xA3, 0x83, 0xF6,
+0x74, 0xC1, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF6,
+0x70, 0x9B, 0x6D, 0xE2, 0x60, 0xA3, 0x83, 0xF6,
+0x75, 0xC1, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF6,
+0x74, 0x9B, 0x6D, 0xE2, 0x60, 0xA3, 0x83, 0xF6,
+0x76, 0xC1, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF6,
+0x78, 0x9B, 0x6D, 0xE2, 0x60, 0xA3, 0x83, 0xF6,
+0x77, 0xC1, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF5,
+0x74, 0x9B, 0x69, 0xE2, 0x40, 0xAA, 0x83, 0xF6,
+0x58, 0xC9, 0x00, 0x18, 0xA3, 0x2B, 0x83, 0xF6,
+0x8E, 0xA9, 0x01, 0xE2, 0x1C, 0x30, 0x00, 0x6B,
+0x12, 0x2C, 0x13, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF5, 0x58, 0x9A, 0x49, 0xE0, 0x69, 0xE2,
+0xA0, 0xA2, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x49, 0xE3, 0x83, 0xF6, 0xBC, 0xC2,
+0x01, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB, 0x83, 0xEB,
+0xED, 0x61, 0x30, 0xF0, 0x20, 0x69, 0x61, 0xF3,
+0x10, 0x49, 0x00, 0xF1, 0x17, 0xA1, 0x00, 0x18,
+0xA3, 0x2B, 0x83, 0xF6, 0x90, 0xA9, 0x01, 0xE2,
+0x1C, 0x30, 0x00, 0x6B, 0x11, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF5, 0x58, 0x9A, 0x49, 0xE0,
+0x69, 0xE2, 0xA0, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x49, 0xE3, 0xA3, 0xF6,
+0xBC, 0xC2, 0x01, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB,
+0x83, 0xEB, 0xED, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x05, 0xF2, 0x60, 0xAA, 0x00, 0x6A, 0x03, 0x10,
+0x01, 0x4A, 0xFF, 0x6C, 0x8C, 0xEA, 0x63, 0xEA,
+0xFB, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x04, 0x22, 0x00, 0x18,
+0x2B, 0x28, 0x00, 0x18, 0x49, 0x28, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF6, 0x7C, 0x9A, 0xFF, 0x6C, 0x30, 0xF0,
+0x20, 0x69, 0x40, 0xA3, 0x61, 0xF3, 0x10, 0x49,
+0x8C, 0xEA, 0x20, 0x6C, 0x8D, 0xEA, 0xFF, 0x6C,
+0x8C, 0xEA, 0x40, 0xC3, 0x00, 0xF1, 0x15, 0xA1,
+0x00, 0x18, 0xA3, 0x2B, 0x01, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF5, 0x44, 0x9A, 0x1C, 0x30,
+0x49, 0xE0, 0x80, 0xA2, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF5, 0x50, 0x9A, 0x49, 0xE0, 0xA0, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF5, 0x48, 0x9A,
+0x49, 0xE0, 0xC0, 0xA2, 0xFF, 0x6A, 0x4C, 0xEC,
+0x4C, 0xEE, 0x4C, 0xED, 0x00, 0x18, 0x0D, 0x1D,
+0x87, 0x40, 0x00, 0x6D, 0x29, 0x4C, 0x04, 0xD2,
+0x00, 0x18, 0x80, 0x22, 0x04, 0x92, 0x38, 0x4A,
+0x01, 0xE2, 0x90, 0x67, 0x00, 0x18, 0x03, 0x28,
+0x00, 0xF1, 0xD5, 0xA1, 0x00, 0x6C, 0xB0, 0x67,
+0x00, 0x18, 0x07, 0x45, 0x00, 0xF1, 0xD5, 0xA1,
+0x11, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x07, 0x45,
+0x00, 0x18, 0xB4, 0x2B, 0x1D, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x44, 0x9A, 0xFF, 0x6C,
+0xFF, 0x6D, 0x00, 0xA2, 0x26, 0x6E, 0x8C, 0xE8,
+0x00, 0x6C, 0x00, 0x18, 0xC5, 0x3A, 0x00, 0x18,
+0x5B, 0x40, 0x01, 0x72, 0x14, 0x61, 0x00, 0xF1,
+0x95, 0xA1, 0x01, 0x6D, 0x08, 0x6E, 0x00, 0x6F,
+0x00, 0x18, 0x3E, 0x48, 0x00, 0x6C, 0xB0, 0x67,
+0x26, 0x6E, 0x00, 0x18, 0xC5, 0x3A, 0x07, 0x10,
+0x00, 0xF1, 0x95, 0xA1, 0x01, 0x6D, 0x08, 0x6E,
+0x00, 0x6F, 0x00, 0x18, 0x3E, 0x48, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x00, 0xF1,
+0x63, 0xA2, 0x02, 0x73, 0x07, 0x61, 0x00, 0xF1,
+0x95, 0xA2, 0x04, 0x92, 0xFF, 0x6D, 0x4C, 0xED,
+0x00, 0x18, 0x37, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF4, 0x97, 0xA2, 0xFF, 0x68, 0x96, 0x34,
+0x00, 0x18, 0xE9, 0x16, 0x00, 0x18, 0x7E, 0x48,
+0x0A, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x74, 0x9A, 0x20, 0x6C, 0x40, 0xA3, 0x0C, 0xEA,
+0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF6,
+0x7A, 0xAA, 0x01, 0x4B, 0x83, 0xF6, 0x7A, 0xCA,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF2, 0xAC, 0x9B,
+0x60, 0xF2, 0x0C, 0x4B, 0xFF, 0x6A, 0x05, 0xD5,
+0xA1, 0x9B, 0x64, 0xAB, 0x4C, 0xEC, 0x06, 0xD5,
+0xBD, 0x67, 0x6E, 0xCD, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0xE0, 0xF0, 0xDC, 0xA3,
+0x40, 0x6D, 0xCC, 0xED, 0x4C, 0xED, 0x72, 0x25,
+0xC0, 0xF0, 0xC4, 0xA3, 0x7F, 0x6D, 0xCC, 0xED,
+0x4C, 0xED, 0x42, 0x25, 0xC0, 0xF0, 0xA5, 0xA3,
+0x0F, 0x6B, 0xAC, 0xEB, 0x4C, 0xEB, 0x3C, 0x23,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF3, 0x73, 0xA3,
+0x37, 0x2B, 0xBD, 0x67, 0x84, 0x33, 0x6D, 0xE5,
+0xAA, 0xAB, 0x1F, 0xF7, 0x00, 0x6E, 0x62, 0x45,
+0xCC, 0xEB, 0x02, 0xF0, 0x00, 0x73, 0x01, 0x60,
+0x0C, 0x2B, 0x5D, 0x67, 0x84, 0x34, 0x91, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0x6A, 0xAC, 0x20, 0xF6,
+0x5C, 0x9A, 0x49, 0xE3, 0x60, 0xA2, 0xFF, 0x6A,
+0x06, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0x60, 0x9B, 0x75, 0xE5, 0x60, 0xA5, 0x6C, 0xEA,
+0x7D, 0x67, 0x50, 0xC3, 0x50, 0xA3, 0x14, 0x22,
+0x70, 0xA3, 0xFF, 0x6A, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF6,
+0x88, 0xAA, 0x7A, 0xEC, 0x01, 0x2B, 0xE5, 0xE8,
+0x12, 0xEB, 0x83, 0xF6, 0x68, 0xCA, 0x01, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x73, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF6, 0x88, 0xAA, 0x64, 0x6B, 0x7B, 0xEC,
+0x01, 0x2B, 0xE5, 0xE8, 0xC3, 0xF6, 0x7C, 0xAA,
+0x12, 0xEC, 0x63, 0xEC, 0x01, 0x4B, 0x18, 0x60,
+0x83, 0xF6, 0x7A, 0xAA, 0x83, 0xF6, 0x4C, 0xAA,
+0x4E, 0xEB, 0x0B, 0x2B, 0x0A, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x58, 0x9A, 0x31, 0x6B,
+0x01, 0x6C, 0x60, 0xC2, 0x00, 0x18, 0x3E, 0x1E,
+0x09, 0x10, 0x00, 0x18, 0xA9, 0x28, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x00, 0x6B,
+0xC3, 0xF6, 0x7C, 0xCA, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0x9C, 0xA2, 0x41, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C, 0xE0, 0xF0,
+0x7C, 0xC2, 0xE5, 0xF1, 0x18, 0x4C, 0x00, 0x6D,
+0x56, 0x6E, 0x00, 0x18, 0x6B, 0x2C, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF4, 0x6C, 0xA2,
+0x40, 0x6A, 0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18,
+0x43, 0x29, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0x6B, 0x22, 0xF5, 0x73, 0xC2, 0x22, 0xF5,
+0x74, 0xC2, 0x22, 0xF5, 0x72, 0xC2, 0x00, 0x6B,
+0x22, 0xF5, 0x70, 0xCA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x44, 0x9A,
+0xFF, 0x6B, 0x80, 0xA2, 0x00, 0xF6, 0x80, 0x34,
+0x00, 0xF6, 0x83, 0x34, 0x00, 0x54, 0x28, 0x60,
+0xA0, 0xA2, 0x7F, 0x6C, 0xAC, 0xEC, 0x80, 0xC2,
+0x80, 0xA2, 0x40, 0x6D, 0x6C, 0xEC, 0xAD, 0xEC,
+0x6C, 0xEC, 0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6C,
+0x40, 0xF6, 0x88, 0x9C, 0x3F, 0x6D, 0x80, 0xA4,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0xF6, 0x8C, 0x9C,
+0x80, 0xA4, 0x30, 0xF0, 0x20, 0x6C, 0xC0, 0xF4,
+0x98, 0x9C, 0x80, 0xA4, 0x30, 0xF0, 0x20, 0x6C,
+0xC0, 0xF4, 0x9C, 0x9C, 0x80, 0xA4, 0x80, 0xA2,
+0x6C, 0xEC, 0xAD, 0xEC, 0x6C, 0xEC, 0x80, 0xC2,
+0x80, 0xA2, 0xBF, 0x6B, 0x8C, 0xEB, 0x60, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x70, 0x9B, 0xFF, 0x6A, 0x4C, 0xEC,
+0xC0, 0xA3, 0x4C, 0xED, 0x15, 0x26, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x40, 0xF6, 0x98, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA, 0x20, 0xE8,
+0x80, 0xC3, 0x0B, 0x25, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF6, 0x9C, 0x9B, 0x80, 0x6D, 0xAB, 0xED,
+0x60, 0xA4, 0x4C, 0xEB, 0xAE, 0xEB, 0x4C, 0xEB,
+0x60, 0xC4, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF4, 0x70, 0x9B, 0x30, 0xF0, 0x20, 0x69,
+0x41, 0xF3, 0x54, 0x99, 0xE0, 0x9B, 0x30, 0xF0,
+0x20, 0x6B, 0x60, 0xF6, 0x60, 0x9B, 0x50, 0x32,
+0x6D, 0xE2, 0xE0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF6, 0x64, 0x9B, 0x6D, 0xE2, 0x80, 0xDB,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6, 0x68, 0x9B,
+0x6D, 0xE2, 0xA0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF6, 0x6C, 0x9B, 0x69, 0xE2, 0xC0, 0xDA,
+0x41, 0xF3, 0x14, 0x99, 0x01, 0x48, 0x00, 0xF1,
+0x00, 0x70, 0x41, 0xF3, 0x14, 0xD9, 0x05, 0x60,
+0x00, 0xF2, 0x00, 0x6A, 0x4E, 0xE8, 0x06, 0x20,
+0x0B, 0x10, 0x10, 0x6C, 0x01, 0x6D, 0x00, 0x18,
+0x79, 0x29, 0x06, 0x10, 0x11, 0x6C, 0x01, 0x6D,
+0x00, 0x18, 0x79, 0x29, 0x41, 0xF3, 0x14, 0xD9,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x6A,
+0x0E, 0x90, 0x24, 0x67, 0x4C, 0xE9, 0x03, 0x6B,
+0x4C, 0xEF, 0x2C, 0xEB, 0x00, 0x6A, 0x0B, 0xD5,
+0x0C, 0xD6, 0x04, 0xD7, 0x40, 0xC8, 0x00, 0x6A,
+0x07, 0x23, 0x25, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x4C, 0x2C, 0x40, 0xA8, 0x01, 0x4A, 0x40, 0xC8,
+0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0x54, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x58, 0x9A,
+0x49, 0xE1, 0x0B, 0x93, 0x40, 0x9A, 0x6C, 0xEA,
+0x0C, 0x93, 0x6E, 0xEA, 0x04, 0x22, 0x40, 0xA8,
+0x04, 0x93, 0x63, 0xEA, 0xDF, 0x61, 0x40, 0xA8,
+0x04, 0x93, 0x63, 0xEA, 0x58, 0x67, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFF, 0x6A, 0xA0, 0x35, 0x4C, 0xEC, 0xA0, 0x35,
+0xCC, 0xEA, 0x4D, 0xED, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF6, 0x50, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6, 0x54, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6, 0x98, 0x9B,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF6, 0x7C, 0x9B,
+0xAD, 0xEA, 0x40, 0xDC, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x40, 0x9A, 0x60, 0xDC,
+0x00, 0x6B, 0x60, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6A, 0xFF, 0xF7, 0x1F, 0x6B, 0x8C, 0xEA,
+0xAC, 0xEB, 0x05, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0x5C, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x44, 0x9A, 0x60, 0x33,
+0x60, 0x33, 0x4D, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF6, 0x58, 0x9A, 0x00, 0x6C, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x48, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6, 0x60, 0x9B,
+0x40, 0xA2, 0x80, 0xC3, 0xFF, 0x6B, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x6C, 0x9B, 0xFF, 0x6A, 0xCC, 0xEA,
+0x6D, 0xEA, 0xE0, 0xF1, 0x1F, 0x6B, 0xAC, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF6, 0x98, 0x9C,
+0x60, 0x33, 0x60, 0x33, 0x6D, 0xEA, 0x40, 0xDC,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0x54, 0x9A,
+0x6D, 0xEA, 0x40, 0xDC, 0x20, 0xE8, 0x00, 0x65,
+0xE0, 0xF1, 0x1F, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0xA0, 0xF4, 0x74, 0x9B, 0xAC, 0xEA, 0x40, 0x32,
+0x40, 0x32, 0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF6, 0x78, 0x9B, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x48, 0x9A, 0xFF, 0x6B,
+0x40, 0xA2, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0xD0, 0x9B, 0xFF, 0x6A, 0x04, 0x6D,
+0x60, 0xA6, 0x4C, 0xEC, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC6, 0x11, 0x24, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF6, 0x9C, 0x9B, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xC4, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0x6B, 0x42, 0xF6, 0x61, 0xC2, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF6, 0x7C, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x01, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xA4, 0xF1,
+0x71, 0xC2, 0x30, 0xF0, 0x20, 0x6C, 0x24, 0xF7,
+0x18, 0x4C, 0x00, 0x6D, 0x00, 0x18, 0xB4, 0x3F,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x70, 0x9A,
+0xFB, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A,
+0x40, 0xAA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x40, 0xAA, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x04, 0xF7,
+0x10, 0x68, 0x19, 0x10, 0x05, 0x6C, 0xFF, 0x48,
+0x00, 0x18, 0x4C, 0x2C, 0x14, 0x28, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A, 0x08, 0xF0,
+0x00, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x7C, 0xDA, 0x00, 0x6A, 0x09, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x54, 0x9A, 0x60, 0xAA,
+0x3F, 0x6A, 0x6C, 0xEA, 0xDF, 0x2A, 0x01, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x01, 0x68, 0x04, 0xEC, 0x82, 0xF3, 0x08, 0x69,
+0x19, 0x10, 0x01, 0x6C, 0xFF, 0x49, 0x00, 0x18,
+0x4C, 0x2C, 0x14, 0x29, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x74, 0x9A, 0x08, 0xF0, 0x00, 0x6C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3,
+0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA,
+0x00, 0x6A, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x54, 0x9A, 0x60, 0xAA, 0xFF, 0xF7,
+0x1F, 0x6A, 0x6C, 0xEA, 0x0C, 0xEA, 0xDD, 0x2A,
+0x01, 0x6A, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x0E, 0x92, 0x04, 0x67,
+0x0F, 0x91, 0x04, 0xD2, 0x04, 0x93, 0xFF, 0x6A,
+0x4C, 0xE8, 0x4C, 0xEB, 0x90, 0x67, 0x0B, 0xD5,
+0x0C, 0xD6, 0x0D, 0xD7, 0x04, 0xD3, 0x4C, 0xE9,
+0x00, 0x18, 0x4A, 0x2A, 0x80, 0xF0, 0x07, 0x22,
+0x06, 0x58, 0x80, 0xF0, 0x04, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x08, 0x30, 0x60, 0xF2, 0x18, 0x4A,
+0x09, 0xE2, 0x40, 0x9A, 0x00, 0xEA, 0x02, 0xF2,
+0x10, 0x6A, 0x0E, 0x10, 0x02, 0xF2, 0x00, 0x6A,
+0x0B, 0x10, 0x22, 0xF2, 0x00, 0x6A, 0x08, 0x10,
+0x22, 0xF2, 0x10, 0x6A, 0x05, 0x10, 0x42, 0xF2,
+0x00, 0x6A, 0x02, 0x10, 0x42, 0xF2, 0x10, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x0D, 0x94, 0x80, 0xF6,
+0x78, 0x9B, 0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0x80, 0xF4, 0x94, 0x9C, 0x8D, 0xEB, 0x06, 0x21,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF6, 0x9C, 0x9C,
+0x6D, 0xEC, 0x05, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF6, 0x80, 0x9C, 0x6C, 0xEC, 0x04, 0x96,
+0x06, 0x26, 0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF4,
+0x74, 0x9B, 0x8D, 0xEB, 0x05, 0x10, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF6, 0x64, 0x9B, 0x8C, 0xEB,
+0x1F, 0xF7, 0x00, 0x6C, 0x4C, 0xEC, 0x02, 0xF0,
+0x00, 0x74, 0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x20, 0xF5, 0xB4, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0xB8, 0x9C,
+0x30, 0xF0, 0x20, 0x6C, 0x0B, 0x96, 0xA0, 0xF6,
+0x88, 0x9C, 0xB5, 0xE2, 0xCC, 0xEC, 0x80, 0xDD,
+0x84, 0x42, 0x1F, 0xF7, 0x00, 0x6D, 0xAC, 0xEC,
+0x02, 0xF0, 0x00, 0x74, 0x01, 0x60, 0x05, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF6, 0xAC, 0x9C,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF6,
+0xB0, 0x9C, 0x30, 0xF0, 0x20, 0x6C, 0x0C, 0x96,
+0xA0, 0xF6, 0x88, 0x9C, 0xB5, 0xE2, 0xCC, 0xEC,
+0x80, 0xDD, 0x87, 0x42, 0x01, 0x4C, 0x1F, 0xF7,
+0x00, 0x6D, 0xAC, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF6, 0x94, 0x9C, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0xA0, 0xF6, 0x98, 0x9C, 0x89, 0xE2,
+0x60, 0xDA, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x00, 0x6A, 0x04, 0xD2,
+0x04, 0x92, 0x01, 0x72, 0x58, 0x67, 0x04, 0xD2,
+0x10, 0xF0, 0x21, 0x6A, 0x78, 0x67, 0xD5, 0xF2,
+0x15, 0x4A, 0x69, 0xE2, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x40, 0xDB, 0x00, 0x18,
+0xF1, 0x0B, 0x00, 0x18, 0x5E, 0x29, 0x00, 0x18,
+0xF0, 0x0B, 0x00, 0x18, 0xF1, 0x0B, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xF0,
+0x84, 0x9A, 0x02, 0x6B, 0x8C, 0xEB, 0x09, 0x23,
+0x03, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x00, 0x18, 0xE2, 0x30, 0x00, 0x18,
+0x2B, 0x31, 0x00, 0x18, 0xF0, 0x0B, 0x00, 0x18,
+0xF1, 0x0B, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xA0, 0xF0, 0x84, 0x9A, 0x04, 0x6B,
+0x8C, 0xEB, 0x09, 0x23, 0x05, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18,
+0x00, 0x2E, 0x00, 0x18, 0xAE, 0x2D, 0x00, 0x18,
+0xF0, 0x0B, 0x00, 0x18, 0xF1, 0x0B, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xC0, 0xF0,
+0x84, 0xA2, 0x7F, 0x6B, 0x8C, 0xEB, 0x0D, 0x23,
+0xC0, 0xF0, 0x88, 0xA2, 0xA3, 0xF3, 0x7B, 0xA2,
+0x8E, 0xEB, 0x07, 0x23, 0xC0, 0xF0, 0x87, 0xA2,
+0xFF, 0x6A, 0x96, 0x34, 0x4C, 0xEC, 0x00, 0x18,
+0x43, 0x16, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4,
+0x54, 0x9A, 0x02, 0x2A, 0x00, 0x18, 0x7A, 0x16,
+0x00, 0x18, 0xF0, 0x0B, 0x00, 0x18, 0xF1, 0x0B,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA0, 0xF0, 0x84, 0x9A, 0x02, 0xF0, 0x00, 0x6B,
+0x8C, 0xEB, 0x08, 0x23, 0x02, 0xF0, 0x01, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0, 0x64, 0xDA,
+0x00, 0x18, 0x13, 0x3C, 0x00, 0x18, 0xF0, 0x0B,
+0x00, 0x18, 0xF1, 0x0B, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF4, 0x78, 0x9B, 0xA0, 0xF0, 0x84, 0x9A,
+0x8C, 0xEB, 0x09, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF6, 0x64, 0x9B, 0x8C, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x00, 0x18, 0xB2, 0x1D, 0x00, 0x18,
+0xF0, 0x0B, 0x00, 0x18, 0xF1, 0x0B, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x30, 0xF0,
+0x20, 0x6B, 0xA0, 0xF4, 0x70, 0x9B, 0xA0, 0xF0,
+0x84, 0x9A, 0x8C, 0xEB, 0x20, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF6, 0x68, 0x9B, 0x8C, 0xEB,
+0xC0, 0xF0, 0x84, 0xA2, 0xA0, 0xF0, 0x64, 0xDA,
+0x7F, 0x6B, 0x8C, 0xEB, 0x07, 0x2B, 0xA3, 0xF3,
+0x5B, 0xA2, 0x0C, 0x72, 0x03, 0x61, 0x00, 0x18,
+0xB2, 0x2E, 0x0D, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF0, 0x64, 0x9A, 0xA0, 0xF4, 0x90, 0x9C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x00, 0x18,
+0xF0, 0x0B, 0x30, 0xF0, 0x20, 0x6A, 0xA8, 0xF1,
+0x78, 0xA2, 0x08, 0x6A, 0x6C, 0xEA, 0x0F, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x4C, 0x9A,
+0x01, 0x6B, 0x80, 0xA2, 0x8C, 0xEB, 0x07, 0x23,
+0x80, 0xA2, 0xFE, 0x6B, 0x8C, 0xEB, 0x60, 0xC2,
+0x03, 0x6C, 0x00, 0x18, 0x55, 0x31, 0x30, 0xF0,
+0x20, 0x69, 0x61, 0xF3, 0x10, 0x49, 0x43, 0xF2,
+0x08, 0xA1, 0x01, 0x6A, 0x4E, 0xE8, 0x05, 0x28,
+0x0B, 0x6C, 0x00, 0x18, 0x55, 0x31, 0x43, 0xF2,
+0x08, 0xC1, 0x30, 0xF0, 0x20, 0x6A, 0xA8, 0xF3,
+0x9C, 0x9A, 0x00, 0x18, 0xFB, 0x0D, 0x14, 0x17,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x68,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xB5, 0xF4, 0x19, 0x4A,
+0x0A, 0x70, 0x40, 0xDB, 0x09, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xA8, 0xF3, 0x9C, 0x9A, 0x01, 0x6D,
+0xAB, 0xED, 0x00, 0x18, 0xB2, 0x0C, 0x00, 0x68,
+0x00, 0x18, 0xF1, 0x0B, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF5, 0x68, 0x9B, 0xA0, 0xF0, 0x84, 0x9A,
+0x8C, 0xEB, 0x09, 0x23, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF6, 0x70, 0x9B, 0x8C, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x00, 0x18, 0xDA, 0x1D, 0x00, 0x18,
+0xF0, 0x0B, 0x00, 0x18, 0xF1, 0x0B, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xF0,
+0x84, 0x9A, 0x08, 0x6B, 0x8C, 0xEB, 0x07, 0x23,
+0x09, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x00, 0x18, 0x30, 0x25, 0x00, 0x18,
+0xF0, 0x0B, 0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A,
+0x01, 0x48, 0x40, 0xF4, 0x7C, 0x9B, 0x4C, 0xE8,
+0x10, 0xF0, 0x21, 0x6A, 0xB5, 0xF4, 0x1A, 0x4A,
+0x40, 0xDB, 0xB2, 0x17, 0x00, 0x6A, 0x64, 0x67,
+0x66, 0xEA, 0x01, 0x6D, 0xAC, 0xEB, 0x04, 0x2B,
+0x01, 0x4A, 0x20, 0x72, 0xF8, 0x61, 0x20, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0x25, 0x67, 0x49, 0xE4,
+0x00, 0x9A, 0x85, 0x67, 0x00, 0x18, 0x57, 0x2B,
+0x2C, 0xE8, 0x06, 0xEA, 0x50, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x41, 0x45, 0x05, 0x67, 0x0C, 0xD6, 0x13, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x38, 0x9A,
+0x0F, 0xE8, 0x25, 0xE4, 0x40, 0x99, 0x85, 0x67,
+0x04, 0xD2, 0x00, 0x18, 0x57, 0x2B, 0x0C, 0x93,
+0x64, 0xEA, 0x43, 0x67, 0x04, 0x93, 0x6C, 0xE8,
+0x0D, 0xEA, 0x40, 0xD9, 0x07, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0x38, 0x9A, 0x0C, 0x92,
+0x31, 0xE4, 0x40, 0xDC, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x41, 0x45, 0x0C, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0xAF, 0xEB, 0xCC, 0xED,
+0x51, 0xE4, 0x40, 0x9C, 0x6C, 0xEA, 0xAD, 0xEA,
+0x40, 0xDC, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0x51, 0xE4, 0xC0, 0xDC,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF5, 0x78, 0x9B, 0xFF, 0x6A, 0xAC, 0xEA,
+0x6D, 0xE4, 0x49, 0xE6, 0x04, 0x10, 0x80, 0xA3,
+0x01, 0x4B, 0x80, 0xC6, 0x01, 0x4E, 0x4A, 0xEE,
+0xFA, 0x61, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF5, 0x78, 0x9B, 0xFF, 0x6A, 0xAC, 0xEA,
+0x6D, 0xE4, 0x49, 0xE6, 0x04, 0x10, 0x80, 0xA6,
+0x01, 0x4E, 0x80, 0xC3, 0x01, 0x4B, 0x4A, 0xEE,
+0xFA, 0x61, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x54, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF6, 0x78, 0x9B, 0x40, 0x9A, 0x6C, 0xEA,
+0x83, 0xEA, 0x02, 0x60, 0x4F, 0xEA, 0x51, 0xE4,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x58, 0x9A,
+0xFF, 0x6B, 0x51, 0xE4, 0x40, 0xA4, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x5C, 0x9A, 0xFF, 0x63, 0x60, 0xAA,
+0xE1, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA, 0x7D, 0x67,
+0x40, 0xCB, 0x40, 0xAB, 0xFF, 0xF7, 0x1F, 0x6B,
+0x01, 0x63, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x40, 0x9A,
+0xFF, 0x63, 0x60, 0xA2, 0xFF, 0x6A, 0x6C, 0xEA,
+0x7D, 0x67, 0x40, 0xCB, 0x40, 0xAB, 0xFF, 0xF7,
+0x1F, 0x6B, 0x01, 0x63, 0x6C, 0xEA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x44, 0x9A,
+0x01, 0x6B, 0x40, 0x9A, 0x42, 0x32, 0x52, 0x32,
+0x6E, 0xEA, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6, 0x74, 0x9B,
+0x44, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x60, 0x9B,
+0x80, 0xF6, 0x98, 0x9C, 0x8C, 0xEB, 0x43, 0xEB,
+0x02, 0x60, 0x6F, 0xEB, 0x69, 0xE2, 0x20, 0xE8,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x6A, 0xFF, 0xF7, 0x1F, 0x6B, 0x4C, 0xED,
+0x4C, 0xEE, 0x24, 0x67, 0x6C, 0xEF, 0x10, 0x90,
+0x6C, 0xE9, 0x05, 0xD5, 0x06, 0xD6, 0x04, 0xD7,
+0x00, 0x6A, 0x05, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x4C, 0x2C, 0x40, 0xA8, 0x01, 0x4A, 0x40, 0xC8,
+0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0x54, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x58, 0x9A,
+0x49, 0xE1, 0x60, 0xA2, 0xFF, 0x6A, 0x6C, 0xEA,
+0x05, 0x93, 0x6C, 0xEA, 0x06, 0x93, 0x6E, 0xEA,
+0x04, 0x22, 0x40, 0xA8, 0x04, 0x93, 0x63, 0xEA,
+0xDD, 0x61, 0x40, 0xA8, 0x04, 0x93, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x63, 0xEA, 0x58, 0x67,
+0x06, 0x63, 0x00, 0xEF, 0x03, 0x6F, 0x8C, 0xEF,
+0x64, 0x67, 0x46, 0x67, 0x04, 0x27, 0x0B, 0x10,
+0xA0, 0xDB, 0xFC, 0x4A, 0x04, 0x4B, 0x04, 0x5A,
+0xFB, 0x60, 0x03, 0x6A, 0x4C, 0xEE, 0x03, 0x10,
+0xA0, 0xC4, 0xFF, 0x4E, 0x01, 0x4C, 0xFC, 0x2E,
+0x00, 0x6A, 0x20, 0xE8, 0xFF, 0x6A, 0xAC, 0xEA,
+0x03, 0x10, 0x40, 0xC4, 0xFF, 0x4E, 0x01, 0x4C,
+0xFC, 0x2E, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x63, 0x01, 0xD0, 0x03, 0x6B, 0x05, 0x67,
+0x6C, 0xE8, 0x44, 0x67, 0xE4, 0x67, 0x85, 0x67,
+0x12, 0x28, 0x4C, 0xEB, 0x10, 0x2B, 0x86, 0x67,
+0x06, 0x10, 0x61, 0xE5, 0x00, 0x98, 0x7D, 0xE2,
+0xFC, 0x4C, 0x00, 0xDF, 0x04, 0x4B, 0x04, 0x5C,
+0xF8, 0x60, 0xCA, 0x34, 0x88, 0x34, 0x03, 0x6B,
+0x9D, 0xE2, 0x6C, 0xEE, 0x91, 0xE5, 0x00, 0x6B,
+0x06, 0x10, 0x61, 0xE4, 0x00, 0xA0, 0x75, 0xE7,
+0xFF, 0x4E, 0x00, 0xC5, 0x01, 0x4B, 0xF9, 0x2E,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x09, 0x10, 0x60, 0xA4, 0x40, 0xA5, 0xFF, 0x4E,
+0x4A, 0xEB, 0x02, 0x60, 0x4B, 0xE3, 0x20, 0xE8,
+0x01, 0x4C, 0x01, 0x4D, 0xF6, 0x2E, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x06, 0x2C, 0x64, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x78, 0xDA,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x98, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x58, 0x9A, 0x28, 0x72, 0x2D, 0x60, 0x29, 0x5A,
+0x07, 0x60, 0x14, 0x72, 0x19, 0x60, 0x19, 0x72,
+0x1F, 0x60, 0x0A, 0x72, 0x0D, 0x60, 0x20, 0xE8,
+0x50, 0x72, 0x32, 0x60, 0x51, 0x5A, 0x03, 0x60,
+0x32, 0x72, 0x26, 0x60, 0x20, 0xE8, 0x64, 0x72,
+0x33, 0x60, 0xC8, 0x72, 0x39, 0x60, 0x20, 0xE8,
+0x02, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0xE0, 0xF7, 0x1E, 0x4B, 0x39, 0x10,
+0x03, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0xE1, 0xF3, 0x1D, 0x4B, 0x31, 0x10,
+0x09, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0xE4, 0xF3, 0x17, 0x4B, 0x29, 0x10,
+0x05, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0xE2, 0xF3, 0x1B, 0x4B, 0x21, 0x10,
+0x11, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0xE8, 0xF3, 0x0F, 0x4B, 0x19, 0x10,
+0x0A, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0xE4, 0xF7, 0x16, 0x4B, 0x11, 0x10,
+0x22, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0x11, 0xF0, 0x00, 0x6B, 0x09, 0x10,
+0x43, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3,
+0x7C, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x68, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x60, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF3, 0x58, 0x9A, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x40, 0x9A,
+0xFF, 0x63, 0x58, 0xEC, 0x12, 0xEA, 0x00, 0xD2,
+0x00, 0x92, 0xFF, 0x4A, 0x00, 0xD2, 0x00, 0x92,
+0xFB, 0x2A, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF3, 0x5C, 0x9A,
+0xFF, 0x63, 0x58, 0xEC, 0x12, 0xEA, 0x00, 0xD2,
+0x00, 0x92, 0xFF, 0x4A, 0x00, 0xD2, 0x00, 0x92,
+0xFB, 0x2A, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0xCC, 0x9A, 0x00, 0x68,
+0x20, 0xF0, 0x20, 0x6D, 0x90, 0x67, 0x61, 0xF3,
+0x10, 0x4D, 0x27, 0xF0, 0x10, 0x6F, 0x04, 0xD0,
+0x05, 0xD0, 0x00, 0x18, 0x63, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0xD0, 0x9A, 0x20, 0xF0,
+0x21, 0x6D, 0x90, 0x67, 0x15, 0xF0, 0x00, 0x4D,
+0x03, 0xF0, 0x00, 0x6F, 0x04, 0xD0, 0x05, 0xD0,
+0x00, 0x18, 0x63, 0x2A, 0x07, 0x97, 0x06, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x04, 0x2C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xED, 0x00, 0x18, 0xEB, 0x2B,
+0x05, 0x97, 0x00, 0x6A, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x04, 0x67, 0x4C, 0xEE, 0x00, 0x18, 0xF0, 0x2B,
+0x50, 0x67, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF4, 0x78, 0x9B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0xA3, 0xEB, 0x0B, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6C, 0xC0, 0xF6,
+0x78, 0x9B, 0x60, 0xF7, 0x98, 0x9C, 0x6D, 0xE5,
+0x91, 0xE5, 0x22, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x30, 0xF0, 0x20, 0x6C, 0x60, 0xF5, 0x78, 0x9B,
+0xC0, 0xF5, 0x8C, 0x9C, 0x6D, 0xE5, 0x91, 0xE5,
+0x00, 0x6E, 0xC0, 0xDB, 0x04, 0x4B, 0x8A, 0xEB,
+0xFB, 0x61, 0xE7, 0xF7, 0x1F, 0x6B, 0x4C, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0x54, 0x9A,
+0x4D, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x58, 0x9A, 0x49, 0xE5, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF7, 0x5C, 0x9A, 0x17, 0x10,
+0x00, 0x6E, 0xC0, 0xDB, 0x04, 0x4B, 0x8A, 0xEB,
+0xFB, 0x61, 0xE7, 0xF7, 0x1F, 0x6B, 0x4C, 0xEB,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0x54, 0x9A,
+0x4D, 0xEB, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x58, 0x9A, 0x49, 0xE5, 0x60, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF7, 0x40, 0x9A, 0x55, 0xE5,
+0x40, 0xA5, 0xFF, 0x6B, 0x10, 0x6C, 0x6C, 0xEA,
+0x8D, 0xEA, 0x6C, 0xEA, 0x40, 0xC5, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x22, 0xF5, 0x73, 0xA2, 0xA4, 0x67, 0x04, 0x2B,
+0x22, 0xF5, 0x54, 0xA2, 0x0F, 0x72, 0x0B, 0x60,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x22, 0xF5, 0x53, 0xA0, 0x22, 0xF5, 0x74, 0xA0,
+0xFF, 0x4A, 0x6E, 0xEA, 0x15, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF5, 0x90, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA, 0xA3, 0x10,
+0x23, 0xA5, 0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x49,
+0x4C, 0xE9, 0x22, 0xF5, 0x50, 0xA8, 0x1F, 0x2A,
+0xE8, 0x6A, 0x58, 0xEB, 0x30, 0xF0, 0x20, 0x6A,
+0x22, 0xF2, 0x00, 0x4A, 0xFF, 0x6E, 0x2C, 0xEE,
+0x12, 0xEB, 0x71, 0xE2, 0x00, 0x18, 0x70, 0x2C,
+0x22, 0xF5, 0x54, 0xA0, 0x22, 0xF5, 0x73, 0xA0,
+0x22, 0xF5, 0x30, 0xC8, 0x4E, 0xEB, 0x73, 0x2B,
+0x01, 0x4A, 0x22, 0xF5, 0x54, 0xC0, 0x22, 0xF5,
+0x54, 0xA0, 0x10, 0x6B, 0x6E, 0xEA, 0x6B, 0x2A,
+0x22, 0xF5, 0x54, 0xC0, 0x68, 0x10, 0x62, 0xA5,
+0x36, 0x2B, 0x4D, 0xE1, 0xE3, 0x53, 0x33, 0x60,
+0x22, 0xF5, 0x72, 0xA0, 0xE8, 0x6C, 0x98, 0xEB,
+0x12, 0xEB, 0x0D, 0xE3, 0xA0, 0xF6, 0x92, 0xA3,
+0x2A, 0x2C, 0xA0, 0xF6, 0x93, 0xA3, 0xFF, 0x6E,
+0xFC, 0x4A, 0xFF, 0x4C, 0xA0, 0xF6, 0x93, 0xC3,
+0x22, 0xF5, 0x70, 0xA8, 0xE8, 0x6C, 0xCC, 0xEA,
+0xFF, 0x4B, 0x22, 0xF5, 0x70, 0xC8, 0x22, 0xF5,
+0x72, 0xA0, 0x2C, 0xEE, 0x98, 0xEB, 0x12, 0xEB,
+0x6D, 0xE0, 0x49, 0xE3, 0xB0, 0xF6, 0x83, 0x42,
+0x00, 0x18, 0x70, 0x2C, 0x22, 0xF5, 0x52, 0xA0,
+0xE8, 0x6B, 0x78, 0xEA, 0x12, 0xEA, 0x09, 0xE2,
+0xA0, 0xF6, 0x73, 0xA2, 0x6D, 0xE1, 0xA0, 0xF6,
+0x73, 0xC2, 0x22, 0xF5, 0x50, 0xA8, 0x45, 0xE1,
+0x22, 0xF5, 0x30, 0xC8, 0x30, 0x10, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x22, 0xF5,
+0x94, 0xA0, 0xE8, 0x6A, 0xFF, 0x6E, 0x58, 0xEC,
+0x30, 0xF0, 0x20, 0x6A, 0x22, 0xF2, 0x00, 0x4A,
+0x2C, 0xEE, 0x12, 0xEC, 0x91, 0xE2, 0x00, 0x18,
+0x70, 0x2C, 0x22, 0xF5, 0x54, 0xA0, 0x10, 0x6B,
+0x22, 0xF5, 0x30, 0xC8, 0x01, 0x4A, 0x22, 0xF5,
+0x54, 0xC0, 0x22, 0xF5, 0x54, 0xA0, 0x6E, 0xEA,
+0x02, 0x2A, 0x22, 0xF5, 0x54, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x22, 0xF5,
+0x72, 0xA2, 0x10, 0x6C, 0x01, 0x4B, 0x22, 0xF5,
+0x72, 0xC2, 0x22, 0xF5, 0x72, 0xA2, 0x8E, 0xEB,
+0x02, 0x2B, 0x22, 0xF5, 0x72, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x22, 0xF5,
+0x92, 0xA2, 0xE8, 0x6B, 0x78, 0xEC, 0x22, 0xF5,
+0x90, 0xAA, 0x12, 0xEB, 0x4D, 0xE3, 0x80, 0xF7,
+0x97, 0xC3, 0xA0, 0xF0, 0x64, 0x9A, 0x04, 0x6C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x4C, 0xA3, 0xFF, 0x6F,
+0xE0, 0xF0, 0xC7, 0xA5, 0x41, 0xC5, 0x43, 0xA5,
+0x61, 0xF3, 0x6C, 0xA3, 0x03, 0x4A, 0xEC, 0xEA,
+0x09, 0x10, 0xED, 0x42, 0xFF, 0x68, 0x0C, 0xEF,
+0xFD, 0xE5, 0x64, 0xC7, 0xE6, 0xA7, 0x03, 0x4F,
+0xE9, 0xE2, 0x0C, 0xEA, 0xEF, 0x46, 0xE2, 0xEA,
+0xF4, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x6C, 0xA2, 0x01, 0x4B, 0x61, 0xF3, 0x6C, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0x58, 0x9A,
+0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF5, 0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF6, 0x58, 0x9A, 0x51, 0xE4,
+0x00, 0x18, 0x70, 0x2C, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0xA0, 0xF0, 0x44, 0x98, 0x04, 0x6B,
+0xA4, 0x67, 0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8,
+0xA0, 0xF6, 0x4E, 0xA8, 0x09, 0xF7, 0x00, 0x72,
+0x07, 0x60, 0xA0, 0xF6, 0x4E, 0xA0, 0xA0, 0xF6,
+0x8F, 0xA0, 0xFF, 0x4A, 0x8E, 0xEA, 0x13, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A,
+0x00, 0xF2, 0x00, 0x6C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x7C, 0xDA, 0x15, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF5, 0x1E, 0x4A, 0x90, 0x34,
+0x91, 0xE2, 0x10, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0xA0, 0xF6, 0x4F, 0xA0, 0x50, 0x6B, 0x01, 0x4A,
+0xA0, 0xF6, 0x4F, 0xC0, 0xA0, 0xF6, 0x4F, 0xA0,
+0x6E, 0xEA, 0x02, 0x2A, 0xA0, 0xF6, 0x4F, 0xC0,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x6D, 0xA2,
+0x24, 0x67, 0x05, 0x67, 0x61, 0xC5, 0x01, 0x4B,
+0x61, 0xF3, 0x6D, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF4, 0x58, 0x9A, 0x83, 0xEA, 0x0D, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5, 0x98, 0x9A,
+0x02, 0x6E, 0x91, 0xE1, 0x00, 0x18, 0x70, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF6, 0x84, 0x9A,
+0x0C, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x98, 0x9A, 0x02, 0x6E, 0x91, 0xE1, 0x00, 0x18,
+0x70, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x84, 0x9A, 0xCE, 0xA0, 0x91, 0xE1, 0xA2, 0x40,
+0x00, 0x18, 0x70, 0x2C, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x00, 0x68,
+0x1D, 0x10, 0xE0, 0xF3, 0x08, 0x70, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A,
+0x80, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x7C, 0xDA, 0x00, 0x6A, 0x10, 0x10, 0x01, 0x48,
+0xFF, 0xF7, 0x1F, 0x6A, 0x0A, 0x6C, 0x4C, 0xE8,
+0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF7, 0x48, 0x9A, 0x60, 0xA2, 0x01, 0x6A,
+0x6C, 0xEA, 0xDB, 0x2A, 0x01, 0x6A, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x24, 0x67, 0x00, 0x18, 0x6A, 0x2D, 0x00, 0x6B,
+0x48, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x54, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x78, 0x9B, 0x40, 0x9A, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF4, 0x78, 0x9B, 0x43, 0xEB,
+0x07, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF7,
+0x0C, 0x9B, 0x01, 0xE2, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x42, 0x50, 0x67, 0xFF, 0xF7, 0x1F, 0x6B,
+0x4C, 0xEB, 0x42, 0x32, 0x0F, 0x6C, 0x42, 0x32,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF7,
+0x90, 0x9C, 0xB0, 0x67, 0x60, 0xCC, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF7, 0x74, 0x9B, 0x40, 0xC3,
+0xE0, 0xF0, 0x87, 0xA1, 0x00, 0x18, 0x77, 0x2C,
+0x87, 0x40, 0x11, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x0E, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x48, 0x9A, 0x01, 0x6B, 0x80, 0xF2, 0x16, 0x6C,
+0x60, 0xC2, 0x01, 0x6D, 0x06, 0x02, 0x00, 0x6E,
+0x04, 0xF7, 0x10, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0xC2, 0x2B, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x33, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x43, 0x67, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x22, 0xF5,
+0x53, 0xA0, 0x22, 0xF5, 0x74, 0xA0, 0x4E, 0xEB,
+0x33, 0x23, 0xE8, 0x6B, 0x78, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x22, 0xF2, 0x00, 0x4B, 0x12, 0xEA,
+0x51, 0xE3, 0x00, 0x18, 0x82, 0x2D, 0x07, 0x2A,
+0xA0, 0xF0, 0x44, 0x98, 0x04, 0x6B, 0x6D, 0xEA,
+0xA0, 0xF0, 0x44, 0xD8, 0x21, 0x10, 0x22, 0xF5,
+0x53, 0xA0, 0x10, 0x6B, 0x01, 0x4A, 0x22, 0xF5,
+0x53, 0xC0, 0x22, 0xF5, 0x53, 0xA0, 0x6E, 0xEA,
+0x02, 0x2A, 0x22, 0xF5, 0x53, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x22, 0xF5,
+0x93, 0xA2, 0x22, 0xF5, 0x74, 0xA2, 0x8E, 0xEB,
+0x07, 0x23, 0xA0, 0xF0, 0x64, 0x9A, 0x04, 0x6C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x04, 0x10,
+0x22, 0xF5, 0x92, 0xC2, 0x22, 0xF5, 0x70, 0xCA,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x24, 0x67, 0x00, 0x18, 0x6A, 0x2D, 0x00, 0x6B,
+0x50, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x54, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF6,
+0x78, 0x9B, 0x40, 0x9A, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF4, 0x78, 0x9B, 0x43, 0xEB,
+0x07, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF7,
+0x0C, 0x9B, 0x01, 0xE2, 0x01, 0x4A, 0x02, 0x10,
+0x01, 0x42, 0x50, 0x67, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF7, 0x70, 0x9B, 0xFF, 0xF7, 0x1F, 0x6D,
+0x82, 0x67, 0xAC, 0xEC, 0x80, 0xCB, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF7, 0x94, 0x9B, 0xFF, 0x6E,
+0x10, 0x6F, 0x60, 0xA4, 0xEB, 0xEF, 0x42, 0x32,
+0xCC, 0xEB, 0xEC, 0xEB, 0x42, 0x32, 0x6D, 0xEA,
+0xCC, 0xEA, 0x40, 0xC4, 0x87, 0xA9, 0x02, 0x4C,
+0xAC, 0xEC, 0xB0, 0x67, 0x00, 0x18, 0x77, 0x2C,
+0x87, 0x40, 0x11, 0x4C, 0xB1, 0x67, 0x00, 0x18,
+0x4E, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x48, 0x9A, 0x01, 0x6B, 0x80, 0xF2, 0x16, 0x6C,
+0x60, 0xC2, 0x01, 0x6D, 0x06, 0x02, 0x00, 0x6E,
+0x04, 0xF7, 0x10, 0x6F, 0x04, 0xD2, 0x00, 0x18,
+0xC2, 0x2B, 0x4B, 0xEB, 0x4D, 0xEB, 0xC0, 0xF7,
+0x62, 0x33, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x43, 0x67, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0xA0, 0xF6,
+0x8E, 0xA0, 0xA0, 0xF6, 0x4F, 0xA0, 0x8E, 0xEA,
+0x25, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x90, 0x34,
+0x01, 0xF5, 0x1E, 0x4A, 0x91, 0xE2, 0x00, 0x18,
+0xD0, 0x2D, 0x1C, 0x22, 0xA0, 0xF6, 0x4E, 0xA0,
+0x01, 0x4A, 0xA0, 0xF6, 0x4E, 0xC0, 0xA0, 0xF6,
+0x6E, 0xA0, 0xA0, 0xF6, 0x4F, 0xA0, 0x6E, 0xEA,
+0x06, 0x22, 0xA0, 0xF0, 0x44, 0x98, 0x04, 0x6B,
+0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xF6,
+0x6E, 0xA2, 0x50, 0x6C, 0x8E, 0xEB, 0x02, 0x2B,
+0xA0, 0xF6, 0x6E, 0xC2, 0x00, 0x18, 0xCC, 0x2E,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFE, 0x63, 0x03, 0xD1, 0x02, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF7, 0x58, 0x9A, 0x0F, 0x6B,
+0x40, 0xA2, 0x4C, 0xEB, 0x0A, 0x23, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xF0,
+0x84, 0x9A, 0x02, 0x6D, 0xAD, 0xEC, 0xA0, 0xF0,
+0x84, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF5,
+0x5C, 0xA2, 0xFF, 0x4A, 0x00, 0xD2, 0xDF, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA0, 0xF1, 0x8C, 0xAA, 0x00, 0xF7, 0x00, 0x74,
+0x05, 0x60, 0xA0, 0xF1, 0x0D, 0xA2, 0x00, 0x94,
+0x8A, 0xE8, 0x0E, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x74, 0x9A, 0xFF, 0x6C, 0x01, 0x4C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xBD, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF3, 0x8E, 0xA4,
+0xA3, 0x67, 0xA7, 0xEC, 0x85, 0x67, 0x01, 0x6D,
+0xAC, 0xEC, 0xA0, 0xF0, 0x0A, 0x24, 0x0C, 0x35,
+0xB5, 0xE2, 0x60, 0xF1, 0x10, 0x4D, 0x00, 0x6A,
+0x30, 0xF0, 0x20, 0x6E, 0x61, 0xF3, 0xEE, 0xA6,
+0xFF, 0x6C, 0x1F, 0xF7, 0x00, 0x69, 0x8C, 0xEF,
+0x74, 0x4F, 0xE8, 0x37, 0xFD, 0xE2, 0x2C, 0xEF,
+0x02, 0xF0, 0x00, 0x77, 0x08, 0x60, 0x61, 0xF3,
+0xEE, 0xA6, 0x8C, 0xEF, 0x74, 0x4F, 0xE8, 0x37,
+0xFD, 0xE2, 0x2C, 0xEF, 0x0F, 0x2F, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF3, 0x2E, 0xA4, 0xFF, 0x6C,
+0x30, 0xF0, 0x20, 0x6E, 0x8C, 0xE9, 0x74, 0x49,
+0x28, 0x31, 0xE2, 0x67, 0x25, 0xE2, 0x20, 0xF5,
+0xD4, 0x9E, 0x0B, 0x10, 0x61, 0xF3, 0x2E, 0xA6,
+0x30, 0xF0, 0x20, 0x6E, 0x20, 0xF5, 0xD8, 0x9E,
+0x8C, 0xE9, 0x74, 0x49, 0x28, 0x31, 0xE2, 0x67,
+0x25, 0xE2, 0xD9, 0xE1, 0xC0, 0xA6, 0x0C, 0x31,
+0xCC, 0xEC, 0x30, 0xF0, 0x20, 0x6E, 0x61, 0xF3,
+0x10, 0x4E, 0xD9, 0xE1, 0xFD, 0xE6, 0x60, 0xF1,
+0x8C, 0xC7, 0x30, 0xF0, 0x20, 0x6E, 0x61, 0xF3,
+0xEE, 0xA6, 0xFF, 0x6C, 0x1F, 0xF7, 0x00, 0x69,
+0x8C, 0xEF, 0x7C, 0x4F, 0xE8, 0x37, 0xFD, 0xE2,
+0x2C, 0xEF, 0x02, 0xF0, 0x00, 0x77, 0x08, 0x60,
+0x61, 0xF3, 0xEE, 0xA6, 0x8C, 0xEF, 0x7C, 0x4F,
+0xE8, 0x37, 0xFD, 0xE2, 0x2C, 0xEF, 0x0E, 0x2F,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF3, 0xCE, 0xA4,
+0xFF, 0x6C, 0x30, 0xF0, 0x20, 0x6F, 0x8C, 0xEE,
+0x7C, 0x4E, 0xC8, 0x36, 0xD9, 0xE2, 0x20, 0xF5,
+0xF4, 0x9F, 0x0A, 0x10, 0x61, 0xF3, 0xCE, 0xA6,
+0x30, 0xF0, 0x20, 0x6F, 0x20, 0xF5, 0xF8, 0x9F,
+0x8C, 0xEE, 0x7C, 0x4E, 0xC8, 0x36, 0xD9, 0xE2,
+0xF9, 0xE6, 0xC0, 0xA6, 0x01, 0x4A, 0x04, 0x72,
+0xCC, 0xEC, 0x80, 0xC5, 0x01, 0x4D, 0x8C, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0xAE, 0xA2,
+0x01, 0x6C, 0xC4, 0x67, 0xC4, 0xED, 0xCF, 0xED,
+0x61, 0xF3, 0xCE, 0xA2, 0xAC, 0xEB, 0xFF, 0x6D,
+0x84, 0xEE, 0x30, 0xF0, 0x20, 0x6E, 0x80, 0xF7,
+0xD8, 0x9E, 0xAC, 0xEC, 0x80, 0xC6, 0x61, 0xF3,
+0x8E, 0xA2, 0xAC, 0xEC, 0x01, 0x4C, 0xAC, 0xEC,
+0x61, 0xF3, 0x8E, 0xC2, 0x61, 0xF3, 0xAE, 0xA2,
+0x03, 0x6C, 0xAC, 0xEC, 0x61, 0xF3, 0x8E, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA0, 0xF1, 0x8D, 0xA2, 0x08, 0x6D, 0x01, 0x4C,
+0xA0, 0xF1, 0x8D, 0xC2, 0xA0, 0xF1, 0x8D, 0xA2,
+0xAE, 0xEC, 0x11, 0x2C, 0xA0, 0xF1, 0x8D, 0xC2,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF6,
+0xB4, 0x9B, 0x02, 0x6C, 0x60, 0x9D, 0x8D, 0xEB,
+0x60, 0xDD, 0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x7C, 0xDA, 0x02, 0x10, 0x1F, 0xF7,
+0x1F, 0x2B, 0x03, 0x91, 0x02, 0x90, 0x02, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF7,
+0x5C, 0x9A, 0xFF, 0x68, 0x60, 0xA2, 0x6C, 0xE8,
+0x1A, 0x20, 0x00, 0x6B, 0x60, 0xC2, 0x01, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x40, 0x9A, 0x20, 0x6B, 0x20, 0x70,
+0x60, 0xC2, 0x0D, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF0, 0x64, 0x9A, 0xA0, 0xF4, 0x90, 0x9C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xF1, 0x0B,
+0x00, 0x18, 0xAC, 0x07, 0x05, 0x6C, 0x01, 0x6D,
+0x00, 0x18, 0x79, 0x29, 0x20, 0xBA, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0xFF, 0x17,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x44, 0x9A,
+0x60, 0xA2, 0x03, 0x6A, 0x6C, 0xEA, 0x10, 0x6B,
+0x64, 0xEA, 0xFF, 0x6A, 0x4C, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x48, 0x9A, 0x04, 0xD3,
+0x40, 0x9A, 0x05, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF7, 0x4C, 0x9A, 0x00, 0x9A, 0x05, 0x92,
+0x0A, 0xEA, 0xA0, 0xF0, 0x1B, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xF0,
+0x64, 0x9A, 0x02, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x30, 0xF0, 0x20, 0x69, 0x61, 0xF3,
+0x10, 0x49, 0x22, 0xF6, 0x56, 0xA9, 0x00, 0xF7,
+0x00, 0x72, 0x07, 0x60, 0x22, 0xF6, 0x96, 0xA1,
+0x22, 0xF6, 0x77, 0xA1, 0xAF, 0x44, 0x6E, 0xED,
+0x13, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6,
+0x74, 0x9A, 0xFF, 0x6C, 0x01, 0x4C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA, 0x8E, 0x10,
+0x30, 0xF0, 0x20, 0x6D, 0x60, 0xF5, 0xB8, 0x9D,
+0x7F, 0x6E, 0xB5, 0xE0, 0xE0, 0xA5, 0xCC, 0xEF,
+0x3F, 0x2F, 0x00, 0xF4, 0x00, 0x72, 0x80, 0xF0,
+0x01, 0x60, 0xAC, 0x44, 0x6E, 0xED, 0x7E, 0x25,
+0x00, 0xF5, 0x01, 0x72, 0x7B, 0x60, 0x00, 0xF6,
+0x02, 0x72, 0x78, 0x60, 0x00, 0xF7, 0x03, 0x72,
+0x75, 0x60, 0x00, 0xF5, 0x00, 0x72, 0x72, 0x60,
+0xFD, 0x4C, 0x8E, 0xEB, 0x6F, 0x23, 0x30, 0xF0,
+0x20, 0x69, 0x61, 0xF3, 0x10, 0x49, 0x22, 0xF6,
+0x56, 0xA9, 0x00, 0xF6, 0x01, 0x72, 0x66, 0x60,
+0x00, 0xF7, 0x02, 0x72, 0x63, 0x60, 0x00, 0xF6,
+0x00, 0x72, 0x60, 0x60, 0x22, 0xF6, 0x96, 0xA1,
+0x22, 0xF6, 0x77, 0xA1, 0xFE, 0x4C, 0x6E, 0xEC,
+0x59, 0x24, 0x00, 0xF7, 0x01, 0x72, 0x56, 0x60,
+0x74, 0x33, 0x30, 0xF0, 0x20, 0x6A, 0x71, 0xE1,
+0xE0, 0xF5, 0x54, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF5, 0xB8, 0x9B, 0x49, 0xE0, 0x40, 0xAA,
+0x22, 0xF5, 0x16, 0x4C, 0xB5, 0xE0, 0x0E, 0x10,
+0x40, 0xA5, 0x4C, 0xEE, 0x01, 0x76, 0x1B, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF5, 0x54, 0x9A,
+0x74, 0x33, 0x71, 0xE1, 0x49, 0xE0, 0x40, 0xAA,
+0x22, 0xF5, 0x16, 0x4C, 0xFF, 0x6E, 0x4C, 0xEE,
+0x00, 0x18, 0x70, 0x2C, 0x22, 0xF6, 0x57, 0xA1,
+0x08, 0x6B, 0x01, 0x4A, 0x22, 0xF6, 0x57, 0xC1,
+0x22, 0xF6, 0x57, 0xA1, 0x6E, 0xEA, 0x13, 0x2A,
+0x22, 0xF6, 0x57, 0xC1, 0x10, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x94, 0x9A, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF6, 0x7C, 0x9B, 0x40, 0x9C,
+0x6D, 0xEA, 0x40, 0xDC, 0x83, 0xF3, 0x5C, 0x99,
+0x6D, 0xEA, 0x83, 0xF3, 0x5C, 0xD9, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x50, 0x9A, 0x04, 0x93,
+0x40, 0x9A, 0x0E, 0xEA, 0x61, 0xE0, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7, 0x54, 0x9A,
+0x00, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x4C, 0x9A, 0x00, 0xDA, 0x05, 0x92, 0x4A, 0xE8,
+0x5F, 0xF7, 0x0F, 0x61, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xA4, 0x67, 0x30, 0xF0,
+0x20, 0x6C, 0x41, 0xF4, 0x10, 0x4C, 0x07, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0x80, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x0C, 0x23, 0xE0, 0xF0,
+0x62, 0xA2, 0xFF, 0x73, 0x08, 0x60, 0xE0, 0xF0,
+0x81, 0xA2, 0xC3, 0xF3, 0x74, 0xA2, 0x6D, 0xE4,
+0x04, 0x4B, 0xC3, 0xF3, 0x6A, 0xCA, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF4,
+0x18, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xDE, 0x63, 0x43, 0x62, 0x42, 0xD1, 0x41, 0xD0,
+0x01, 0x6A, 0x7D, 0x67, 0x4B, 0xEA, 0x58, 0xC3,
+0x01, 0x6A, 0x5A, 0xC3, 0x08, 0x6A, 0x5B, 0xC3,
+0x40, 0xA4, 0x7F, 0x6B, 0x6C, 0xEA, 0x01, 0x72,
+0xA0, 0xF0, 0x18, 0x61, 0x48, 0xA4, 0xBD, 0x67,
+0x5C, 0xC5, 0x41, 0xA4, 0x5D, 0xC5, 0x42, 0xA4,
+0x5E, 0xC5, 0x46, 0xA4, 0x20, 0xF0, 0x40, 0xC5,
+0x43, 0xA4, 0x5F, 0xC5, 0x47, 0xA4, 0x20, 0xF0,
+0x41, 0xC5, 0x5C, 0xA5, 0xA0, 0xF0, 0x14, 0x2A,
+0x7D, 0x67, 0x5F, 0xA3, 0x7E, 0xA3, 0x40, 0x32,
+0x6D, 0xEA, 0x03, 0x72, 0x05, 0x60, 0x08, 0x72,
+0x1A, 0x60, 0x02, 0x72, 0x2A, 0x60, 0xA8, 0x10,
+0x06, 0x04, 0x00, 0x18, 0xA2, 0x2C, 0x9D, 0x67,
+0x20, 0xF0, 0xE1, 0xA4, 0x20, 0xF0, 0x40, 0xA4,
+0x30, 0xF0, 0x20, 0x6D, 0xE0, 0x37, 0x5D, 0xE7,
+0xFF, 0xF7, 0x1F, 0x6A, 0x05, 0x6C, 0xA4, 0xF1,
+0x18, 0x4D, 0x00, 0xF4, 0x00, 0x6E, 0x4C, 0xEF,
+0x00, 0x18, 0x37, 0x47, 0x94, 0x10, 0x30, 0xF0,
+0x20, 0x68, 0xBD, 0x67, 0x88, 0xF0, 0x04, 0x48,
+0x10, 0x6A, 0x09, 0x04, 0x5B, 0xC5, 0x04, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x70, 0x2C, 0x0A, 0x04,
+0xA4, 0x40, 0x04, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x7F, 0x10, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x26, 0xF5, 0x30, 0xA0, 0x01, 0x6A,
+0x4E, 0xE9, 0x37, 0x29, 0x00, 0x18, 0x50, 0x44,
+0xE0, 0xF0, 0xC7, 0xA0, 0x0C, 0x6C, 0x00, 0x6D,
+0x00, 0x18, 0xD7, 0x14, 0xA3, 0xF3, 0x78, 0xA0,
+0x21, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x02, 0x6B,
+0x6B, 0xEB, 0x6C, 0xEA, 0x06, 0xF5, 0x7C, 0xA0,
+0xA3, 0xF3, 0x58, 0xC0, 0x04, 0x6A, 0x6C, 0xEA,
+0x1D, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF7,
+0x58, 0x9A, 0x26, 0xF5, 0xC8, 0x98, 0x10, 0xF0,
+0x21, 0x6C, 0x40, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0x4C, 0x9A, 0x3E, 0xF4, 0x1D, 0x4C,
+0x00, 0x6D, 0x40, 0x9A, 0x01, 0x6F, 0x04, 0xD1,
+0x5B, 0xE6, 0xE0, 0xF3, 0x08, 0x6A, 0x5B, 0xEE,
+0x01, 0x2A, 0xE5, 0xE8, 0x12, 0xEE, 0x00, 0x18,
+0x66, 0x3B, 0x45, 0x10, 0x00, 0x18, 0xB6, 0x3C,
+0x42, 0x10, 0x00, 0x18, 0x64, 0x44, 0x26, 0xF5,
+0xAE, 0xA8, 0x00, 0x6C, 0x00, 0x18, 0x6C, 0x3C,
+0xE0, 0xF0, 0x87, 0xA0, 0x00, 0x18, 0xA6, 0x3F,
+0xE0, 0xF0, 0x87, 0xA0, 0x00, 0x18, 0x95, 0x3F,
+0xE0, 0xF0, 0x87, 0xA0, 0x00, 0x18, 0xAD, 0x3F,
+0xA3, 0xF3, 0x78, 0xA0, 0xE0, 0xF0, 0xC7, 0xA0,
+0x20, 0x6A, 0x6D, 0xEA, 0x08, 0x6C, 0x00, 0x6D,
+0xA3, 0xF3, 0x58, 0xC0, 0x00, 0x18, 0xD7, 0x14,
+0x00, 0xF1, 0x7F, 0xA0, 0x02, 0x6A, 0x6C, 0xEA,
+0x05, 0x22, 0xA3, 0xF3, 0x78, 0xA0, 0x01, 0x6A,
+0x6D, 0xEA, 0x05, 0x10, 0xA3, 0xF3, 0x78, 0xA0,
+0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xA3, 0xF3,
+0x58, 0xC0, 0x11, 0x10, 0x10, 0x2A, 0x69, 0xA4,
+0xBD, 0x67, 0x7C, 0xC5, 0x68, 0xA4, 0x5E, 0xC5,
+0x5F, 0xC5, 0x7D, 0xC5, 0x46, 0xA4, 0x20, 0xF0,
+0x40, 0xC5, 0x47, 0xA4, 0x20, 0xF0, 0x41, 0xC5,
+0x06, 0x04, 0x00, 0x18, 0xA2, 0x2C, 0x43, 0x97,
+0x42, 0x91, 0x41, 0x90, 0x22, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x68, 0x44, 0xFA, 0x4B, 0x4C, 0xEB, 0x04, 0x5B,
+0x03, 0x60, 0x00, 0x18, 0x28, 0x49, 0x3C, 0x10,
+0xFE, 0x4C, 0x4C, 0xEC, 0x0C, 0x5C, 0x23, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x88, 0x34, 0xE0, 0xF2,
+0x04, 0x4A, 0x89, 0xE2, 0x40, 0x9A, 0x00, 0xEA,
+0x85, 0x67, 0x00, 0x18, 0x6C, 0x47, 0x2C, 0x10,
+0x85, 0x67, 0x00, 0x18, 0x84, 0x3C, 0x28, 0x10,
+0x00, 0x18, 0x27, 0x47, 0x25, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xF6, 0x46, 0x21, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x63, 0x46, 0x1D, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xB6, 0x46, 0x19, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x3A, 0x46, 0x15, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF5, 0x88, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA, 0xFF, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x10, 0x48, 0x07, 0x6E, 0x21, 0xF4,
+0x14, 0x4C, 0x00, 0x18, 0x70, 0x2C, 0xC0, 0xF0,
+0x87, 0xA0, 0x96, 0x34, 0x00, 0x18, 0x04, 0x19,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4, 0x48, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0xC0, 0xF0, 0x64, 0xA0,
+0x7F, 0x6A, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF4, 0x6C, 0x9B, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF0, 0x68, 0xA0, 0xE0, 0xF4,
+0x50, 0x9A, 0x60, 0xC2, 0xC0, 0xF0, 0x65, 0xA0,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x40, 0x9A,
+0x72, 0x33, 0x60, 0xC2, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x08, 0xD4, 0x41, 0xA4,
+0x24, 0x67, 0x06, 0xD2, 0x60, 0xA4, 0x02, 0x6A,
+0x6C, 0xEA, 0x06, 0x93, 0x07, 0xD3, 0x02, 0x22,
+0x42, 0xA4, 0x07, 0xD2, 0x06, 0x90, 0x15, 0x10,
+0x08, 0x93, 0x01, 0x6D, 0x90, 0x67, 0x40, 0xA3,
+0x4C, 0xED, 0x00, 0x18, 0x8F, 0x11, 0x90, 0x67,
+0x00, 0x18, 0x86, 0x11, 0x04, 0x2A, 0x90, 0x67,
+0x00, 0x18, 0xB1, 0x11, 0x03, 0x10, 0x90, 0x67,
+0x00, 0x18, 0xB6, 0x11, 0x01, 0x48, 0xFF, 0x6A,
+0x4C, 0xE8, 0x07, 0x92, 0x03, 0xEA, 0xE8, 0x60,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xE0, 0xF0, 0x88, 0xA0, 0x06, 0x92, 0x8E, 0xEA,
+0x1B, 0x2A, 0x00, 0x18, 0x86, 0x11, 0x18, 0x2A,
+0x00, 0x18, 0x76, 0x40, 0xC0, 0xF0, 0x87, 0xA0,
+0x96, 0x34, 0x00, 0x18, 0xA9, 0x14, 0xA3, 0xF3,
+0x78, 0xA0, 0x05, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xA3, 0xF3, 0x79, 0xA0, 0xA3, 0xF3, 0x58, 0xC0,
+0x02, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x03, 0x6B,
+0x6B, 0xEB, 0x6C, 0xEA, 0xA3, 0xF3, 0x59, 0xC0,
+0x30, 0xF0, 0x20, 0x6A, 0xA8, 0xF1, 0xB8, 0xA2,
+0x60, 0xA1, 0x01, 0x6A, 0xAC, 0xEA, 0x72, 0x34,
+0x15, 0x2A, 0x04, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x10, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF7, 0x5C, 0x9A, 0x00, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x60, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF4, 0x5C, 0x9A,
+0x60, 0xDA, 0xF0, 0x17, 0x05, 0x74, 0x17, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA8, 0xF1, 0x78, 0xA2,
+0x04, 0x6A, 0x6C, 0xEA, 0x10, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x5C, 0x9A, 0x00, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF4,
+0x5C, 0x9A, 0x60, 0xDA, 0xF0, 0x17, 0x43, 0xA1,
+0x07, 0x6B, 0x01, 0x6C, 0x4C, 0xEB, 0x40, 0xA1,
+0x8C, 0xEA, 0x1C, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x24, 0xF1, 0xD4, 0xA2,
+0x84, 0xEB, 0x1F, 0x6F, 0xCA, 0x35, 0x8F, 0xEC,
+0xEC, 0xED, 0x8C, 0xED, 0x7D, 0x6C, 0x8B, 0xEC,
+0xA8, 0x35, 0xCC, 0xEC, 0xAD, 0xEC, 0x24, 0xF1,
+0x94, 0xC2, 0xE0, 0xF0, 0x87, 0xA2, 0x8E, 0xEB,
+0x1E, 0x2B, 0x01, 0x6B, 0x6B, 0xEB, 0x24, 0xF1,
+0x75, 0xC2, 0x19, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x24, 0xF1, 0xD4, 0xA2,
+0x1F, 0x6F, 0x84, 0xEB, 0xCA, 0x35, 0xEC, 0xED,
+0xAD, 0xEC, 0xEC, 0xEC, 0x88, 0x35, 0x7D, 0x6C,
+0x8B, 0xEC, 0xCC, 0xEC, 0xAD, 0xEC, 0x24, 0xF1,
+0x94, 0xC2, 0xE0, 0xF0, 0x87, 0xA2, 0x8E, 0xEB,
+0x02, 0x2B, 0x24, 0xF1, 0x95, 0xC2, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x24, 0xF1,
+0x74, 0xA0, 0x02, 0x6A, 0x6C, 0xEA, 0x1A, 0x22,
+0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x24, 0xF1,
+0x54, 0xC0, 0x00, 0x18, 0xE9, 0x3A, 0x04, 0xD2,
+0x04, 0x93, 0x24, 0xF1, 0x58, 0x98, 0x6E, 0xEA,
+0x03, 0x22, 0x04, 0x94, 0x00, 0x18, 0x05, 0x3B,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x24, 0xF1, 0x94, 0xA2, 0x02, 0x6B, 0x8D, 0xEB,
+0x24, 0xF1, 0x74, 0xC2, 0x0D, 0x97, 0x0C, 0x91,
+0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x6A,
+0x4C, 0xEC, 0x68, 0x44, 0xC8, 0x4B, 0x4C, 0xEB,
+0x20, 0x5B, 0x05, 0x67, 0x03, 0x60, 0x00, 0x18,
+0x22, 0x49, 0xBC, 0x10, 0x2C, 0x74, 0x6F, 0x60,
+0x2D, 0x5C, 0x27, 0x60, 0x1E, 0x74, 0x5F, 0x60,
+0x1F, 0x5C, 0x10, 0x60, 0x03, 0x74, 0x4B, 0x60,
+0x04, 0x5C, 0x04, 0x60, 0x40, 0x24, 0x01, 0x74,
+0x42, 0x60, 0x99, 0x10, 0x13, 0x74, 0x4B, 0x60,
+0x14, 0x74, 0xA0, 0xF0, 0x07, 0x60, 0x04, 0x74,
+0x42, 0x60, 0x91, 0x10, 0x21, 0x74, 0xA0, 0xF0,
+0x01, 0x60, 0x22, 0x5C, 0x05, 0x60, 0x1F, 0x74,
+0x42, 0x60, 0x20, 0x74, 0x48, 0x60, 0x87, 0x10,
+0x25, 0x74, 0x80, 0xF0, 0x17, 0x60, 0x27, 0x74,
+0x46, 0x60, 0x23, 0x74, 0x80, 0xF0, 0x12, 0x60,
+0x7E, 0x10, 0x84, 0x74, 0x60, 0x60, 0x85, 0x5C,
+0x0E, 0x60, 0x80, 0x74, 0x4C, 0x60, 0x81, 0x5C,
+0x05, 0x60, 0x2D, 0x74, 0x40, 0x60, 0x2E, 0x74,
+0x42, 0x60, 0x71, 0x10, 0x82, 0x74, 0x4B, 0x60,
+0x83, 0x5C, 0x4D, 0x60, 0x44, 0x10, 0x8C, 0x74,
+0x56, 0x60, 0x8D, 0x5C, 0x05, 0x60, 0x88, 0x74,
+0x4E, 0x60, 0x89, 0x74, 0x54, 0x60, 0x63, 0x10,
+0xC3, 0x74, 0x59, 0x60, 0xFE, 0x74, 0x5B, 0x60,
+0x8F, 0x74, 0x51, 0x60, 0x5C, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x4D, 0x2F, 0x6B, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x05, 0x30, 0x67, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x77, 0x1C, 0x63, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xBE, 0x1E, 0x5F, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xF4, 0x04, 0x5B, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x84, 0x04, 0x57, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xDD, 0x04, 0x53, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xEA, 0x2F, 0x4F, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x50, 0x05, 0x4B, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x2A, 0x05, 0x47, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x3C, 0x2F, 0x43, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xF7, 0x32, 0x3F, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xF0, 0x20, 0x3B, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x40, 0x20, 0x37, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xA6, 0x1D, 0x33, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x92, 0x1E, 0x2F, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x8B, 0x1E, 0x2B, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xAC, 0x1D, 0x27, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xD5, 0x27, 0x23, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x1F, 0x33, 0x1F, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x99, 0x1E, 0x1B, 0x10, 0x85, 0x67,
+0x00, 0x18, 0x6E, 0x31, 0x17, 0x10, 0x85, 0x67,
+0x00, 0x18, 0xF9, 0x3E, 0x13, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A, 0x01, 0x6C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3,
+0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA,
+0x0E, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x40, 0xC0,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0xA0, 0xF1,
+0x4C, 0xA0, 0xA0, 0xF1, 0x6D, 0xA0, 0x4E, 0xEB,
+0x29, 0x23, 0x67, 0x42, 0x26, 0x4B, 0x6C, 0x33,
+0x0D, 0xE3, 0x4C, 0x32, 0x84, 0xA3, 0x55, 0xE0,
+0x60, 0xF1, 0x0D, 0x4D, 0x00, 0x18, 0x7A, 0x30,
+0xA0, 0xF1, 0x4C, 0xA0, 0x01, 0x4A, 0xA0, 0xF1,
+0x4C, 0xC0, 0xA0, 0xF1, 0x6C, 0xA0, 0xA0, 0xF1,
+0x4D, 0xA0, 0x6E, 0xEA, 0x06, 0x22, 0xA0, 0xF0,
+0x44, 0x98, 0x02, 0x6B, 0x6D, 0xEA, 0xA0, 0xF0,
+0x44, 0xD8, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xA0, 0xF1, 0x6C, 0xA2, 0x08, 0x6C,
+0x8E, 0xEB, 0x02, 0x2B, 0xA0, 0xF1, 0x6C, 0xC2,
+0x00, 0x18, 0x1C, 0x2E, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x22, 0xF6, 0xB6, 0xA0, 0x7F, 0x6C,
+0xB4, 0x35, 0x09, 0xE5, 0x22, 0xF5, 0x76, 0xA2,
+0x8C, 0xEB, 0x15, 0x2B, 0x22, 0xF5, 0x9E, 0xA2,
+0xA2, 0x67, 0x22, 0xF5, 0x1F, 0x4D, 0x00, 0x18,
+0x7A, 0x30, 0x22, 0xF6, 0x56, 0xA0, 0x54, 0x32,
+0x01, 0xE2, 0x30, 0xF0, 0x20, 0x6A, 0x22, 0xF5,
+0x7C, 0xA0, 0xE0, 0xF7, 0x48, 0x9A, 0x60, 0xC2,
+0x22, 0xF5, 0x7D, 0xA0, 0x29, 0x10, 0x01, 0x73,
+0x2C, 0x61, 0x22, 0xF5, 0x77, 0xA2, 0xFF, 0x73,
+0x0E, 0x61, 0x22, 0xF5, 0x98, 0xA2, 0xB5, 0xE0,
+0x22, 0xF5, 0x16, 0x4D, 0x00, 0x18, 0xC4, 0x2F,
+0x22, 0xF6, 0x76, 0xA0, 0x74, 0x33, 0x01, 0xE3,
+0x22, 0xF5, 0x5E, 0xC0, 0x04, 0x10, 0x01, 0x6B,
+0x6B, 0xEB, 0x22, 0xF5, 0x7E, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x22, 0xF6,
+0x76, 0xA2, 0x74, 0x33, 0x49, 0xE3, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF7, 0x68, 0x9B, 0x22, 0xF5,
+0x9C, 0xA2, 0x80, 0xC3, 0x22, 0xF5, 0x7D, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x4C, 0x9A,
+0x60, 0xC2, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x22, 0xF6, 0x76, 0xA0, 0x22, 0xF6,
+0x57, 0xA0, 0x6E, 0xEA, 0x42, 0x22, 0xA0, 0xF6,
+0x4E, 0xA8, 0x09, 0xF6, 0x00, 0x72, 0x10, 0x60,
+0xA0, 0xF6, 0x8E, 0xA0, 0xA0, 0xF6, 0x6F, 0xA0,
+0xAE, 0x44, 0x6E, 0xED, 0x09, 0x25, 0x09, 0xF7,
+0x01, 0x72, 0x06, 0x60, 0x09, 0xF7, 0x00, 0x72,
+0x03, 0x60, 0xFF, 0x4C, 0x8E, 0xEB, 0x0D, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0xA0, 0xF0, 0x44, 0x9B, 0x04, 0x6C, 0x8D, 0xEA,
+0x02, 0x6C, 0x8D, 0xEA, 0xA0, 0xF0, 0x44, 0xDB,
+0x20, 0x10, 0x00, 0x18, 0xFF, 0x30, 0x22, 0xF6,
+0x56, 0xA0, 0x01, 0x4A, 0x22, 0xF6, 0x56, 0xC0,
+0x22, 0xF6, 0x76, 0xA0, 0x22, 0xF6, 0x57, 0xA0,
+0x6E, 0xEA, 0x06, 0x22, 0xA0, 0xF0, 0x44, 0x98,
+0x02, 0x6B, 0x6D, 0xEA, 0xA0, 0xF0, 0x44, 0xD8,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x22, 0xF6, 0x76, 0xA2, 0x08, 0x6C, 0x8E, 0xEB,
+0x02, 0x2B, 0x22, 0xF6, 0x76, 0xC2, 0x00, 0x18,
+0xCC, 0x2E, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x22, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x92, 0xC3,
+0x01, 0x6A, 0x04, 0x04, 0x4F, 0xCB, 0x00, 0x18,
+0x2B, 0x2D, 0x09, 0x97, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x1A, 0x6A, 0x7D, 0x67,
+0x50, 0xC3, 0x00, 0xF0, 0x12, 0x04, 0x05, 0x6A,
+0x4F, 0xCB, 0x00, 0x18, 0x54, 0x06, 0x04, 0x04,
+0x00, 0x18, 0x2B, 0x2D, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x19, 0x6A, 0x7D, 0x67, 0x50, 0xC3, 0x00, 0xF0,
+0x12, 0x04, 0x08, 0x6A, 0x4F, 0xCB, 0x00, 0x18,
+0x6E, 0x06, 0x04, 0x04, 0x00, 0x18, 0x2B, 0x2D,
+0x09, 0x97, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x40, 0xA4, 0x01, 0x72,
+0x04, 0x61, 0x00, 0x18, 0x65, 0x31, 0x00, 0x18,
+0x5C, 0x31, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF7, 0x74, 0x9B, 0x30, 0xF0, 0x20, 0x68,
+0xC0, 0xF6, 0x04, 0x98, 0xE0, 0x9B, 0xFF, 0x6A,
+0x4C, 0xEC, 0x0C, 0xEF, 0x08, 0x5C, 0x4C, 0xED,
+0x4C, 0xEE, 0xE0, 0xDB, 0x46, 0x60, 0xB0, 0x75,
+0x2E, 0x61, 0xB2, 0x76, 0x13, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF5, 0xA8, 0x9A, 0x01, 0x6A,
+0x44, 0xEC, 0xC0, 0x9D, 0x00, 0xF6, 0x40, 0x34,
+0xCD, 0xEC, 0x80, 0xDD, 0xC0, 0x9D, 0x40, 0x34,
+0x80, 0x34, 0x8F, 0xEC, 0xCC, 0xEC, 0x80, 0xDD,
+0x80, 0x9B, 0x4E, 0x10, 0xB1, 0x76, 0x80, 0xF0,
+0x13, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5,
+0xA8, 0x9A, 0x01, 0x6A, 0x44, 0xEC, 0xC0, 0x9D,
+0x00, 0xF6, 0x40, 0x34, 0xCD, 0xEC, 0x80, 0xDD,
+0xC0, 0x9D, 0x40, 0x34, 0x80, 0x34, 0x8F, 0xEC,
+0xCC, 0xEC, 0x80, 0xDD, 0x80, 0x9B, 0x4F, 0xEA,
+0x8C, 0xEA, 0x40, 0xDB, 0x7B, 0x10, 0xA0, 0x75,
+0x7D, 0x61, 0xA1, 0x76, 0x08, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF5, 0x48, 0x9A, 0x01, 0x6B,
+0x64, 0xEC, 0xA0, 0x9A, 0x51, 0x10, 0xA2, 0x76,
+0x6F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5,
+0x48, 0x9A, 0x01, 0x6B, 0x64, 0xEC, 0xA0, 0x9A,
+0x5A, 0x10, 0xE8, 0x44, 0x4C, 0xEF, 0x08, 0x5F,
+0xE0, 0x6A, 0x65, 0x60, 0xB0, 0x75, 0x35, 0x61,
+0xB2, 0x76, 0x18, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF5, 0x44, 0x9A, 0x01, 0x6E, 0xA6, 0x67,
+0x00, 0x9A, 0xA4, 0xEF, 0xE5, 0x67, 0x00, 0xF6,
+0xA0, 0x35, 0x0D, 0xED, 0xA0, 0xDA, 0xA0, 0x9A,
+0xE0, 0x37, 0xE0, 0x37, 0xEF, 0xEF, 0xAC, 0xEF,
+0xE0, 0xDA, 0x40, 0x9B, 0xC4, 0xEC, 0x86, 0x67,
+0x4D, 0xEC, 0x19, 0x10, 0xB1, 0x76, 0x44, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5, 0x44, 0x9A,
+0x01, 0x6E, 0xA6, 0x67, 0x00, 0x9A, 0xA4, 0xEF,
+0xE5, 0x67, 0x00, 0xF6, 0xA0, 0x35, 0x0D, 0xED,
+0xA0, 0xDA, 0xA0, 0x9A, 0xE0, 0x37, 0xE0, 0x37,
+0xEF, 0xEF, 0xAC, 0xEF, 0xE0, 0xDA, 0x40, 0x9B,
+0xC4, 0xEC, 0xCF, 0xEC, 0x4C, 0xEC, 0x80, 0xDB,
+0x29, 0x10, 0xA0, 0x75, 0x2B, 0x61, 0xA1, 0x76,
+0x11, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5,
+0x44, 0x9A, 0x01, 0x6B, 0x64, 0xEF, 0xA0, 0x9A,
+0x00, 0xF6, 0x60, 0x34, 0x8F, 0xEC, 0xAC, 0xEC,
+0x80, 0xDA, 0x80, 0x9A, 0x60, 0x33, 0x60, 0x33,
+0x8D, 0xEB, 0x13, 0x10, 0xA2, 0x76, 0x14, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5, 0x44, 0x9A,
+0x01, 0x6B, 0x64, 0xEF, 0xA0, 0x9A, 0x00, 0xF6,
+0x60, 0x34, 0x8F, 0xEC, 0xAC, 0xEC, 0x80, 0xDA,
+0x80, 0x9A, 0x60, 0x33, 0x60, 0x33, 0x6F, 0xEB,
+0x8C, 0xEB, 0x60, 0xDA, 0xF0, 0x6A, 0x03, 0x10,
+0xE2, 0x6A, 0x01, 0x10, 0xE1, 0x6A, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6B, 0x6C, 0xEC,
+0x08, 0x5C, 0xFF, 0x63, 0x18, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A, 0x01, 0x6D,
+0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC, 0xAC, 0xEA,
+0x37, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x5C, 0x9A, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x30, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF5, 0x48, 0x9A, 0x1C, 0x10, 0xF8, 0x4C,
+0x6C, 0xEC, 0x08, 0x5C, 0xE0, 0x6A, 0x27, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x40, 0x9A,
+0x01, 0x6D, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x1A, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x44, 0x9A, 0x40, 0xA2, 0x6C, 0xEA,
+0x47, 0xEC, 0xAC, 0xEA, 0x13, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF5, 0x44, 0x9A, 0x40, 0xA2,
+0xA4, 0xEC, 0x85, 0x67, 0x6C, 0xEC, 0x4C, 0xEC,
+0x5D, 0x67, 0x80, 0xC2, 0x40, 0xA2, 0x4C, 0xEB,
+0x6B, 0xEA, 0xC0, 0xF7, 0x42, 0x32, 0x03, 0x10,
+0xE4, 0x6A, 0x01, 0x10, 0xE6, 0x6A, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6B, 0x6C, 0xEC,
+0x08, 0x5C, 0x6C, 0xED, 0x20, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A, 0x01, 0x6E,
+0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC, 0xCC, 0xEA,
+0x48, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7,
+0x5C, 0x9A, 0xC4, 0xEC, 0x86, 0x67, 0x40, 0xA2,
+0x6C, 0xEA, 0xCC, 0xEA, 0xCE, 0xEA, 0x3B, 0x2A,
+0x05, 0x25, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0xA8, 0x9A, 0x24, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x48, 0x9A, 0x29, 0x10, 0xF8, 0x4C,
+0x6C, 0xEC, 0x08, 0x5C, 0xE0, 0x6A, 0x2E, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x40, 0x9A,
+0x01, 0x6E, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xCC, 0xEA, 0x23, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x44, 0x9A, 0xC4, 0xEC, 0x86, 0x67,
+0x40, 0xA2, 0x6C, 0xEA, 0xCC, 0xEA, 0xCE, 0xEA,
+0x16, 0x2A, 0x0A, 0x25, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0xAC, 0x9A, 0x40, 0xA5, 0x6C, 0xEA,
+0x8D, 0xEA, 0x6C, 0xEA, 0x40, 0xC5, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x4C, 0x9A,
+0xA0, 0xA2, 0x8F, 0xEC, 0x6C, 0xEC, 0xAC, 0xEC,
+0x80, 0xC2, 0xF0, 0x6A, 0x20, 0xE8, 0xE5, 0x6A,
+0x20, 0xE8, 0xE4, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x08, 0x5C, 0x0F, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A,
+0x01, 0x6D, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x1F, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x5C, 0x9A, 0x13, 0x10, 0xF8, 0x4C,
+0x6C, 0xEC, 0x08, 0x5C, 0xE0, 0x6A, 0x16, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x40, 0x9A,
+0x01, 0x6D, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xAC, 0xEA, 0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF0, 0x44, 0x9A, 0x40, 0xA2, 0x4C, 0xEB,
+0x67, 0xEC, 0x45, 0x67, 0x6E, 0xEA, 0xAC, 0xEA,
+0x20, 0xE8, 0x00, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x08, 0x5C, 0x1A, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF7, 0x58, 0x9A,
+0x01, 0x6E, 0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC,
+0xCC, 0xEA, 0x35, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x5C, 0x9A, 0xC4, 0xEC, 0x86, 0x67,
+0xA0, 0xA2, 0x6C, 0xED, 0xCC, 0xED, 0xCE, 0xED,
+0x2A, 0x2D, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x48, 0x9A, 0x1E, 0x10, 0xF8, 0x4C, 0x6C, 0xEC,
+0x08, 0x5C, 0xE0, 0x6A, 0x21, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x40, 0x9A, 0x01, 0x6E,
+0x40, 0xA2, 0x6C, 0xEA, 0x47, 0xEC, 0xCC, 0xEA,
+0x16, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x44, 0x9A, 0xC4, 0xEC, 0x86, 0x67, 0xA0, 0xA2,
+0x6C, 0xED, 0xCC, 0xED, 0xCE, 0xED, 0x0B, 0x2D,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0, 0x4C, 0x9A,
+0x40, 0xA2, 0x4C, 0xEB, 0x8C, 0xEB, 0x6E, 0xEC,
+0x01, 0x5C, 0x58, 0x67, 0x20, 0xE8, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x04, 0x67,
+0x2C, 0xE8, 0x90, 0x67, 0xA0, 0x6D, 0xA2, 0x6E,
+0x00, 0x18, 0x74, 0x31, 0x90, 0x67, 0x00, 0x18,
+0xD7, 0x31, 0x7D, 0x67, 0x50, 0xC3, 0x50, 0xA3,
+0x09, 0x97, 0x07, 0x90, 0x2C, 0xEA, 0x08, 0x91,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x68, 0x24, 0x67,
+0x0C, 0xE9, 0x91, 0x67, 0xAC, 0xE8, 0xA1, 0x6E,
+0xA0, 0x6D, 0x00, 0x18, 0x74, 0x31, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0xFD, 0x31, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF7, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6D,
+0xC0, 0xF6, 0xA4, 0x9D, 0x40, 0x9B, 0xA2, 0x6E,
+0xAC, 0xEA, 0x40, 0xDB, 0xFF, 0x6A, 0x4C, 0xEC,
+0xA0, 0x6D, 0x00, 0x18, 0x74, 0x31, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0xB0, 0x6D, 0xB2, 0x6E,
+0x00, 0x18, 0x74, 0x31, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0xB0, 0x6D, 0xB1, 0x6E,
+0x00, 0x18, 0x74, 0x31, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x04, 0x67, 0x4C, 0xE8,
+0xAC, 0xEA, 0xA4, 0x72, 0x0C, 0x61, 0x90, 0x67,
+0x00, 0x18, 0x2A, 0x32, 0x01, 0x72, 0x04, 0x61,
+0x90, 0x67, 0x00, 0x18, 0x7C, 0x32, 0x1F, 0x10,
+0x90, 0x67, 0x00, 0x6D, 0x0D, 0x10, 0xA5, 0x72,
+0x11, 0x61, 0x90, 0x67, 0x00, 0x18, 0x2A, 0x32,
+0x01, 0x72, 0x04, 0x61, 0x90, 0x67, 0x00, 0x18,
+0x7C, 0x32, 0x18, 0x10, 0x90, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0x71, 0x32, 0x90, 0x67, 0x00, 0x18,
+0x7C, 0x32, 0x14, 0x10, 0x90, 0x67, 0x00, 0x18,
+0x42, 0x32, 0x01, 0x72, 0x07, 0x61, 0x90, 0x67,
+0x01, 0x6D, 0x00, 0x18, 0x71, 0x32, 0x90, 0x67,
+0x00, 0x6D, 0x06, 0x10, 0x90, 0x67, 0x00, 0x6D,
+0x00, 0x18, 0x71, 0x32, 0x90, 0x67, 0x01, 0x6D,
+0x00, 0x18, 0x71, 0x32, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0xB9, 0xA2, 0x02, 0x6C, 0xFF, 0x6B,
+0xAC, 0xEC, 0x3C, 0x24, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x8F, 0xA4, 0x37, 0x2C, 0x24, 0xF1,
+0x50, 0xA2, 0x08, 0x5A, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6C, 0xA0, 0xF5, 0x84, 0x9C, 0xF8, 0x4A,
+0xA0, 0xA4, 0x05, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF5, 0x88, 0x9C, 0xA0, 0xA4, 0x01, 0x6C,
+0x84, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x6C, 0xEC, 0xE0, 0xF0, 0x7B, 0xA2,
+0xAC, 0xEC, 0x01, 0x6D, 0x6A, 0x33, 0xAC, 0xEB,
+0x8E, 0xEB, 0x18, 0x23, 0x30, 0xF0, 0x20, 0x6D,
+0xA0, 0xF0, 0x64, 0x9A, 0x80, 0xF4, 0xB8, 0x9D,
+0xAD, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x05, 0x2C,
+0x24, 0xF1, 0x90, 0xA2, 0x00, 0x18, 0x8D, 0x32,
+0x04, 0x10, 0x24, 0xF1, 0x90, 0xA2, 0x00, 0x18,
+0x87, 0x32, 0x01, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x6F, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0xB9, 0xA2,
+0x02, 0x6C, 0xFF, 0x6B, 0xAC, 0xEC, 0x33, 0x24,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF3, 0x8F, 0xA4,
+0x01, 0x74, 0x2D, 0x61, 0x24, 0xF1, 0x50, 0xA2,
+0x08, 0x5A, 0x07, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF5, 0x84, 0x9C, 0xF8, 0x4A, 0xA0, 0xA4,
+0x05, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF5,
+0x88, 0x9C, 0xA0, 0xA4, 0x01, 0x6C, 0x84, 0xEA,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x6C, 0xEC, 0xE0, 0xF0, 0x7B, 0xA2, 0xAC, 0xEC,
+0x01, 0x6D, 0x6A, 0x33, 0xAC, 0xEB, 0x6E, 0xEC,
+0x0E, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF0,
+0x64, 0x9A, 0x80, 0xF4, 0x98, 0x9C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x02, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x6F, 0xC2, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF4,
+0x1E, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x30, 0xF0, 0x20, 0x6D, 0x61, 0xF3, 0x10, 0x4D,
+0xE0, 0xF0, 0x8E, 0xA5, 0x01, 0x6A, 0xC2, 0x67,
+0x8C, 0xEE, 0xFF, 0x6B, 0x37, 0x26, 0x02, 0x6E,
+0x8C, 0xEE, 0x6C, 0xEE, 0x0F, 0x26, 0x04, 0x6E,
+0x8C, 0xEE, 0x6C, 0xEE, 0x22, 0x26, 0x08, 0x6A,
+0x8C, 0xEA, 0x6C, 0xEA, 0x16, 0x2A, 0xE0, 0xF0,
+0x4F, 0xA5, 0x7F, 0x6C, 0x00, 0x6D, 0x4C, 0xEC,
+0x6C, 0xEC, 0x22, 0x10, 0x04, 0x6E, 0x8C, 0xEE,
+0x6C, 0xEE, 0x13, 0x26, 0x08, 0x6A, 0x8C, 0xEA,
+0x6C, 0xEA, 0x07, 0x22, 0xE0, 0xF0, 0x4F, 0xA5,
+0x7F, 0x6C, 0x01, 0x6D, 0x4C, 0xEC, 0x6C, 0xEC,
+0x13, 0x10, 0xE0, 0xF0, 0x4F, 0xA5, 0x7F, 0x6C,
+0x4C, 0xEC, 0x6C, 0xEC, 0x00, 0x18, 0x7C, 0x32,
+0x0D, 0x10, 0xE0, 0xF0, 0xCF, 0xA5, 0xE0, 0xF0,
+0xAE, 0xA5, 0x7F, 0x6C, 0xCC, 0xEC, 0xA6, 0x35,
+0x01, 0x6E, 0xCE, 0xED, 0x6C, 0xEC, 0x4C, 0xED,
+0x00, 0x18, 0x71, 0x32, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA4, 0x67, 0x30, 0xF0, 0x20, 0x6C, 0x81, 0xF4,
+0x1D, 0x4C, 0x07, 0x6E, 0x00, 0x18, 0x70, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6C,
+0xA8, 0xF1, 0x1E, 0x4C, 0x00, 0x6D, 0x06, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x8C, 0xEA, 0x01, 0x72, 0xFF, 0xF7,
+0x1F, 0x6C, 0xAC, 0xEC, 0x03, 0x61, 0x00, 0x18,
+0x44, 0x2C, 0x02, 0x10, 0x00, 0x18, 0x4C, 0x2C,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x4C, 0xEE, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x46, 0xF6,
+0x70, 0xA2, 0xFF, 0xF7, 0x1F, 0x69, 0x04, 0xD4,
+0xAC, 0xE9, 0x05, 0xD6, 0x0B, 0x23, 0x46, 0xF6,
+0x71, 0xA2, 0x04, 0x23, 0x46, 0xF6, 0x8E, 0xA2,
+0xA5, 0x6D, 0x07, 0x10, 0x46, 0xF6, 0x8E, 0xA2,
+0xA4, 0x6D, 0x03, 0x10, 0x46, 0xF6, 0x8E, 0xA2,
+0xA3, 0x6D, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x00, 0x18, 0x93, 0x32, 0x46, 0xF6,
+0x52, 0xA0, 0x7D, 0x22, 0x04, 0x94, 0xB1, 0x67,
+0x00, 0x18, 0x2D, 0x33, 0x46, 0xF6, 0x50, 0xA0,
+0x0B, 0x22, 0x46, 0xF6, 0x51, 0xA0, 0x04, 0x22,
+0x46, 0xF6, 0x8E, 0xA0, 0xA5, 0x6D, 0x07, 0x10,
+0x46, 0xF6, 0x8E, 0xA0, 0xA4, 0x6D, 0x03, 0x10,
+0x46, 0xF6, 0x8E, 0xA0, 0xA3, 0x6D, 0x00, 0x18,
+0x93, 0x32, 0x30, 0xF0, 0x20, 0x6A, 0xC8, 0xF1,
+0x43, 0xA2, 0x01, 0x68, 0x5D, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x50, 0x9A, 0x60, 0xA2,
+0x10, 0x6A, 0x6C, 0xEA, 0x58, 0x2A, 0x04, 0x94,
+0xB1, 0x67, 0x00, 0x18, 0x2D, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x46, 0xF6,
+0x70, 0xA2, 0x0B, 0x23, 0x46, 0xF6, 0x71, 0xA2,
+0x04, 0x23, 0x46, 0xF6, 0x8E, 0xA2, 0xA5, 0x6D,
+0x07, 0x10, 0x46, 0xF6, 0x8E, 0xA2, 0xA4, 0x6D,
+0x03, 0x10, 0x46, 0xF6, 0x8E, 0xA2, 0xA3, 0x6D,
+0x00, 0x18, 0x93, 0x32, 0xDC, 0x17, 0x04, 0x94,
+0xB1, 0x67, 0x00, 0x18, 0x2D, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x46, 0xF6,
+0x70, 0xA2, 0x0B, 0x23, 0x46, 0xF6, 0x71, 0xA2,
+0x04, 0x23, 0x46, 0xF6, 0x8E, 0xA2, 0xA5, 0x6D,
+0x07, 0x10, 0x46, 0xF6, 0x8E, 0xA2, 0xA4, 0x6D,
+0x03, 0x10, 0x46, 0xF6, 0x8E, 0xA2, 0xA3, 0x6D,
+0x00, 0x18, 0x93, 0x32, 0x04, 0x94, 0xB1, 0x67,
+0x00, 0x18, 0x2D, 0x33, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x46, 0xF6, 0x70, 0xA2,
+0x0B, 0x23, 0x46, 0xF6, 0x71, 0xA2, 0x04, 0x23,
+0x46, 0xF6, 0x8E, 0xA2, 0xA5, 0x6D, 0x07, 0x10,
+0x46, 0xF6, 0x8E, 0xA2, 0xA4, 0x6D, 0x03, 0x10,
+0x46, 0xF6, 0x8E, 0xA2, 0xA3, 0x6D, 0x00, 0x18,
+0x93, 0x32, 0x01, 0x48, 0xFF, 0x6A, 0x4C, 0xE8,
+0x05, 0x92, 0x43, 0xE8, 0xC4, 0x61, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0x97, 0xA2,
+0x7F, 0x6B, 0xE0, 0xF0, 0xD8, 0xA2, 0x8C, 0xEB,
+0xE0, 0xF0, 0x99, 0xA2, 0x01, 0x6A, 0xC6, 0x36,
+0x8A, 0x34, 0x4C, 0xEC, 0x68, 0x35, 0x05, 0x2C,
+0x74, 0x35, 0xD0, 0x4D, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xE0, 0xF0, 0xF8, 0xA2, 0x01, 0x6B,
+0xEC, 0xEB, 0x46, 0xF6, 0x72, 0xC2, 0xE0, 0xF0,
+0x77, 0xA2, 0x7E, 0x33, 0x46, 0xF6, 0x73, 0xC2,
+0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF5, 0x78, 0x9B,
+0x20, 0xF1, 0x4E, 0xA2, 0xE0, 0xA3, 0xFF, 0x6B,
+0xEC, 0xEB, 0x4E, 0xEB, 0x06, 0x2B, 0x03, 0x6A,
+0x58, 0xED, 0xFF, 0xF7, 0x1F, 0x6A, 0x12, 0xED,
+0x4C, 0xED, 0x00, 0x18, 0x36, 0x33, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xE0, 0xF0, 0x76, 0xA2, 0x7F, 0x6D,
+0x01, 0x6F, 0xAC, 0xEB, 0x46, 0xF6, 0x6E, 0xC2,
+0xE0, 0xF0, 0x75, 0xA2, 0x20, 0xF1, 0xCD, 0xA2,
+0x3F, 0x6C, 0x76, 0x33, 0xEC, 0xEB, 0x46, 0xF6,
+0x6F, 0xC2, 0xE0, 0xF0, 0x79, 0xA2, 0xCC, 0xEC,
+0x01, 0x74, 0x76, 0x33, 0xEC, 0xEB, 0x46, 0xF6,
+0x70, 0xC2, 0xE0, 0xF0, 0x7B, 0xA2, 0x66, 0x33,
+0xEC, 0xEB, 0x46, 0xF6, 0x71, 0xC2, 0xFF, 0x6B,
+0x80, 0xF0, 0x0D, 0x60, 0x02, 0x74, 0x03, 0x61,
+0x00, 0x18, 0x8C, 0x33, 0x88, 0x10, 0x3F, 0x74,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF5,
+0x98, 0x9C, 0x20, 0xF1, 0xCE, 0xA2, 0x80, 0xA4,
+0x6C, 0xEC, 0xCE, 0xEC, 0x54, 0x2C, 0x0C, 0x10,
+0x3E, 0x74, 0x51, 0x61, 0x30, 0xF0, 0x20, 0x6C,
+0x80, 0xF5, 0x98, 0x9C, 0x20, 0xF1, 0x0E, 0xA2,
+0xC0, 0xA4, 0x6C, 0xEE, 0x0E, 0xEE, 0x21, 0x2E,
+0x20, 0xF1, 0x8D, 0xA2, 0x20, 0xF1, 0x0F, 0xA2,
+0x20, 0xF1, 0xD0, 0xA2, 0x9A, 0x34, 0xAC, 0xE8,
+0xEC, 0xEC, 0x6C, 0xE8, 0xC6, 0x36, 0x6C, 0xEC,
+0x6C, 0xEE, 0x08, 0x35, 0x05, 0x2C, 0x14, 0x35,
+0xD0, 0x4D, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x20, 0xF1, 0xF0, 0xA2, 0x01, 0x6B, 0xEC, 0xEB,
+0x46, 0xF6, 0x72, 0xC2, 0x20, 0xF1, 0x6F, 0xA2,
+0x49, 0x10, 0x80, 0xA4, 0x20, 0xF1, 0xD1, 0xA2,
+0x6C, 0xEC, 0xCE, 0xEC, 0x20, 0x2C, 0x20, 0xF1,
+0xF2, 0xA2, 0x20, 0xF1, 0x8D, 0xA2, 0x20, 0xF1,
+0xD3, 0xA2, 0xAC, 0xEF, 0x9E, 0x34, 0x6C, 0xEF,
+0xC6, 0x36, 0x6C, 0xEC, 0x6C, 0xEE, 0xE8, 0x35,
+0x05, 0x2C, 0xF4, 0x35, 0xD0, 0x4D, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x20, 0xF1, 0xF3, 0xA2,
+0x01, 0x6B, 0xEC, 0xEB, 0x46, 0xF6, 0x72, 0xC2,
+0x20, 0xF1, 0x72, 0xA2, 0x23, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0,
+0x97, 0xA2, 0x7F, 0x6B, 0xE0, 0xF0, 0xD8, 0xA2,
+0x8C, 0xEB, 0xE0, 0xF0, 0x99, 0xA2, 0x01, 0x6A,
+0xC6, 0x36, 0x8A, 0x34, 0x4C, 0xEC, 0x68, 0x35,
+0x05, 0x2C, 0x74, 0x35, 0xD0, 0x4D, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0xF8, 0xA2,
+0x01, 0x6B, 0xEC, 0xEB, 0x46, 0xF6, 0x72, 0xC2,
+0xE0, 0xF0, 0x77, 0xA2, 0x7E, 0x33, 0x46, 0xF6,
+0x73, 0xC2, 0x00, 0x18, 0x36, 0x33, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0xF7, 0x1F, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x8C, 0xEA, 0x00, 0xF7, 0x60, 0x9B, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF0, 0x94, 0x9C, 0xCC, 0xEB,
+0x40, 0xF6, 0xA0, 0x35, 0x8D, 0xEB, 0x1F, 0xF7,
+0x00, 0x6C, 0x4C, 0xEC, 0x02, 0xF0, 0x00, 0x74,
+0xAD, 0xEB, 0x01, 0x60, 0x05, 0x2C, 0x30, 0xF0,
+0x20, 0x6C, 0x20, 0xF5, 0x94, 0x9C, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0x98, 0x9C,
+0x89, 0xE2, 0x60, 0xDA, 0x20, 0xE8, 0x00, 0x65,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x1F, 0xF7,
+0x00, 0x6C, 0x4C, 0xEC, 0xFF, 0x6B, 0x02, 0xF0,
+0x00, 0x74, 0xAC, 0xEB, 0x01, 0x60, 0x05, 0x2C,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5, 0x94, 0x9C,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5,
+0x98, 0x9C, 0x91, 0xE2, 0x00, 0x6D, 0xA0, 0xDC,
+0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF7, 0x80, 0x9C,
+0xD4, 0x36, 0x40, 0xF6, 0x60, 0x33, 0x8C, 0xEE,
+0x6D, 0xEE, 0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF0,
+0x74, 0x9B, 0x6D, 0xEE, 0x1F, 0xF7, 0x00, 0x6B,
+0x4C, 0xEB, 0x02, 0xF0, 0x00, 0x73, 0x01, 0x60,
+0x05, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF5,
+0x74, 0x9B, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF5, 0x78, 0x9B, 0x69, 0xE2, 0xC0, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x0F, 0xF5, 0x00, 0x6B,
+0x78, 0xEE, 0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF7, 0x80, 0x9C,
+0x40, 0xF6, 0xA0, 0x35, 0x12, 0xEB, 0x8C, 0xEB,
+0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF0, 0x94, 0x9C,
+0xAD, 0xEB, 0x8D, 0xEB, 0x1F, 0xF7, 0x00, 0x6C,
+0x4C, 0xEC, 0x02, 0xF0, 0x00, 0x74, 0x01, 0x60,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5,
+0x94, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF5, 0x98, 0x9C, 0x89, 0xE2, 0x60, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF4, 0x50, 0x9A, 0x40, 0x9A, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xEC, 0x05, 0x5C, 0x4C, 0xED,
+0x00, 0x6A, 0x4B, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x88, 0x34, 0x60, 0xF3, 0x18, 0x4A, 0x89, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x01, 0x6A, 0xFF, 0x6B,
+0x44, 0xED, 0x6C, 0xEA, 0xE0, 0xF3, 0x01, 0x4B,
+0x0C, 0x10, 0x01, 0x6A, 0x05, 0x10, 0x04, 0x6A,
+0x03, 0x10, 0x10, 0x6A, 0x01, 0x10, 0x40, 0x6A,
+0xFF, 0x6B, 0x44, 0xED, 0x6C, 0xEA, 0xE0, 0xF3,
+0x04, 0x4B, 0x1F, 0xF7, 0x00, 0x6C, 0x6C, 0xEC,
+0x05, 0x2C, 0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF5,
+0x94, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF5, 0x98, 0x9C, 0x8D, 0xE3, 0x80, 0xA3,
+0xFF, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0x01, 0x6A,
+0x1C, 0x2B, 0x0E, 0x2D, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x4C, 0x9A, 0x01, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4, 0x48, 0x9A,
+0x02, 0x6B, 0x60, 0xC2, 0x00, 0x6A, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF4, 0x4C, 0x9A,
+0x01, 0x6B, 0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF4, 0x48, 0x9A, 0x04, 0x6B, 0x60, 0xC2,
+0x00, 0x6A, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x8C, 0xE9,
+0x00, 0x68, 0xFF, 0x6A, 0x0C, 0xEA, 0x2E, 0xEA,
+0x10, 0x2A, 0x91, 0x67, 0x00, 0x18, 0x87, 0x3F,
+0x91, 0x67, 0x00, 0x18, 0x76, 0x3F, 0x91, 0x67,
+0x00, 0x18, 0x8E, 0x3F, 0x91, 0x67, 0x00, 0x18,
+0x58, 0x3F, 0x91, 0x67, 0x00, 0x18, 0x4E, 0x3F,
+0x0F, 0x10, 0x90, 0x67, 0x00, 0x18, 0xA6, 0x3F,
+0x90, 0x67, 0x00, 0x18, 0x95, 0x3F, 0x90, 0x67,
+0x00, 0x18, 0xAD, 0x3F, 0x90, 0x67, 0x00, 0x18,
+0x6C, 0x3F, 0x90, 0x67, 0x00, 0x18, 0x62, 0x3F,
+0x01, 0x48, 0x05, 0x70, 0xDA, 0x61, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0x6A, 0x4C, 0xED, 0x4C, 0xEE, 0x04, 0x00,
+0xFF, 0xF7, 0x1F, 0x69, 0x8C, 0xE9, 0x09, 0xD5,
+0x08, 0xD6, 0x90, 0x67, 0x00, 0x6D, 0x04, 0x6E,
+0x11, 0xD7, 0x00, 0x18, 0x6B, 0x2C, 0x05, 0x04,
+0x00, 0x6D, 0x04, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x11, 0x95, 0x90, 0x67, 0x04, 0x6E, 0x00, 0x18,
+0x70, 0x2C, 0x12, 0x95, 0x06, 0x04, 0x04, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x00, 0xF1, 0x00, 0x59,
+0x08, 0x61, 0x0E, 0xF0, 0x40, 0x41, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x00, 0xF1, 0x00, 0x5A,
+0x3D, 0x60, 0x09, 0x92, 0x04, 0x72, 0x12, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x54, 0x9A,
+0xFF, 0x6B, 0x49, 0xE1, 0x40, 0xA2, 0x4C, 0xEB,
+0x08, 0x92, 0x63, 0x22, 0x06, 0x94, 0x8F, 0xEA,
+0x6C, 0xEA, 0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA,
+0x04, 0xD2, 0x5B, 0x10, 0x09, 0x92, 0x05, 0x72,
+0x14, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x54, 0x9A, 0xFF, 0xF7, 0x1F, 0x6B, 0x49, 0xE1,
+0x40, 0xAA, 0x4C, 0xEB, 0x08, 0x92, 0x80, 0xF0,
+0x02, 0x22, 0x06, 0x94, 0x8F, 0xEA, 0x6C, 0xEA,
+0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA, 0x04, 0xD2,
+0x7A, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x54, 0x9A, 0x49, 0xE1, 0x60, 0x9A, 0x08, 0x92,
+0xA0, 0xF0, 0x01, 0x22, 0x06, 0x94, 0x8F, 0xEA,
+0x6C, 0xEA, 0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA,
+0x04, 0xD2, 0x99, 0x10, 0x01, 0xF0, 0x00, 0x59,
+0x09, 0x61, 0x0D, 0xF7, 0x40, 0x41, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEA, 0x00, 0xF7, 0x00, 0x5A,
+0x80, 0xF0, 0x1A, 0x60, 0x09, 0x92, 0x04, 0x72,
+0x32, 0x61, 0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x54, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x58, 0x9A, 0x49, 0xE1, 0x60, 0xA2, 0xFF, 0x6A,
+0x6C, 0xEA, 0x08, 0x93, 0x07, 0x23, 0x06, 0x94,
+0x8F, 0xEB, 0x4C, 0xEB, 0x04, 0x92, 0x8C, 0xEA,
+0x4D, 0xEB, 0x04, 0xD3, 0x1F, 0xF7, 0x00, 0x6A,
+0x2C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x54, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0x7D, 0x67, 0x45, 0xE1,
+0x50, 0xA3, 0x40, 0xC1, 0x7D, 0x10, 0x09, 0x92,
+0x05, 0x72, 0x33, 0x61, 0x1F, 0xF7, 0x00, 0x6A,
+0x2C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x54, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0x49, 0xE1, 0x60, 0xAA,
+0xFF, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA, 0x08, 0x93,
+0x07, 0x23, 0x06, 0x94, 0x8F, 0xEB, 0x4C, 0xEB,
+0x04, 0x92, 0x8C, 0xEA, 0x4D, 0xEB, 0x04, 0xD3,
+0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0x54, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x58, 0x9A,
+0x7D, 0x67, 0x45, 0xE1, 0x48, 0xAB, 0x40, 0xC9,
+0x47, 0x10, 0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA,
+0x02, 0xF0, 0x00, 0x72, 0x01, 0x60, 0x05, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x54, 0x9A,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x58, 0x9A, 0x49, 0xE1, 0x60, 0x9A, 0x08, 0x92,
+0x07, 0x22, 0x06, 0x94, 0x8F, 0xEA, 0x6C, 0xEA,
+0x04, 0x93, 0x8C, 0xEB, 0x6D, 0xEA, 0x04, 0xD2,
+0x1F, 0xF7, 0x00, 0x6A, 0x2C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0x54, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x58, 0x9A,
+0x45, 0xE1, 0x04, 0x92, 0x40, 0xD9, 0x18, 0x10,
+0xFF, 0xF7, 0x1C, 0x68, 0x2C, 0xE8, 0x01, 0x6D,
+0x90, 0x67, 0xAB, 0xED, 0x00, 0x18, 0x2B, 0x38,
+0x08, 0x93, 0x05, 0xD2, 0x07, 0x23, 0x06, 0x94,
+0x8F, 0xEB, 0x4C, 0xEB, 0x04, 0x92, 0x8C, 0xEA,
+0x4D, 0xEB, 0x04, 0xD3, 0x04, 0x96, 0x01, 0x6D,
+0x90, 0x67, 0xAB, 0xED, 0x00, 0x18, 0x39, 0x38,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0x41, 0x9C, 0x61, 0xA4,
+0x01, 0xAC, 0x06, 0xD2, 0x42, 0x9C, 0xFF, 0x73,
+0x07, 0xD2, 0x00, 0x6A, 0x55, 0x60, 0x7F, 0x6D,
+0x6C, 0xED, 0x4C, 0x45, 0xFF, 0x6B, 0x6C, 0xEA,
+0x0E, 0x5A, 0x08, 0x60, 0x30, 0xF0, 0x20, 0x6B,
+0x48, 0x32, 0x80, 0xF3, 0x0C, 0x4B, 0x4D, 0xE3,
+0x40, 0x9B, 0x00, 0xEA, 0x03, 0x6A, 0x44, 0x10,
+0x61, 0xA4, 0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xFF, 0x6E, 0x07, 0x03, 0x90, 0x67, 0x4C, 0xEE,
+0x06, 0x07, 0x04, 0xD3, 0x00, 0x18, 0x90, 0x34,
+0x1F, 0x10, 0x81, 0xA4, 0x80, 0x6A, 0xFF, 0x69,
+0x64, 0x67, 0x4C, 0xEB, 0x0C, 0xE9, 0x02, 0x32,
+0x01, 0x6E, 0x82, 0x67, 0xB1, 0x67, 0xCB, 0xEE,
+0x08, 0xD3, 0x09, 0xD2, 0x00, 0x18, 0x02, 0x38,
+0x08, 0x93, 0x07, 0x23, 0x07, 0x94, 0x8F, 0xEB,
+0x4C, 0xEB, 0x06, 0x92, 0x8C, 0xEA, 0x4D, 0xEB,
+0x06, 0xD3, 0x09, 0x94, 0x06, 0x97, 0x01, 0x6E,
+0xB1, 0x67, 0xCB, 0xEE, 0x00, 0x18, 0x11, 0x39,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x06, 0xF5, 0x74, 0x9A, 0x06, 0x94, 0x61, 0xE0,
+0x06, 0xF5, 0x78, 0x9A, 0x06, 0xF5, 0x14, 0xDA,
+0x6D, 0xE4, 0x06, 0xF5, 0x78, 0xDA, 0x07, 0x10,
+0x90, 0x67, 0x00, 0x18, 0x4C, 0x2C, 0x03, 0x10,
+0x90, 0x67, 0x00, 0x18, 0x44, 0x2C, 0x01, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF0, 0x80, 0x9A, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0xA0, 0x9C, 0x52, 0x9B,
+0xAC, 0xEA, 0x53, 0xDB, 0x40, 0xDC, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0xD1, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF7, 0x20, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF5, 0x1C, 0x4A, 0x40, 0x9A,
+0x60, 0x99, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0, 0x50, 0x9A,
+0x21, 0xF0, 0x18, 0x4C, 0x80, 0x9C, 0x00, 0x9A,
+0x1A, 0x65, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0x9C,
+0x41, 0xF0, 0x00, 0x4A, 0x40, 0x9A, 0x01, 0xD4,
+0x30, 0xF0, 0x20, 0x6C, 0x40, 0x9A, 0x61, 0xF3,
+0xF0, 0x9C, 0x00, 0xD2, 0x44, 0x67, 0x61, 0xF3,
+0x10, 0x4A, 0xC1, 0x9A, 0x83, 0x9A, 0x6C, 0xEF,
+0xAC, 0xEE, 0x01, 0x93, 0xA2, 0x9A, 0xE8, 0xDA,
+0x6C, 0xEC, 0x0C, 0xED, 0x64, 0x9A, 0x00, 0x90,
+0x8B, 0xDA, 0xC9, 0xDA, 0x0C, 0xEB, 0xAA, 0xDA,
+0x6C, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5,
+0x1C, 0x4A, 0x40, 0x9A, 0xE0, 0xD9, 0x18, 0x67,
+0xC0, 0xDA, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x18, 0x4A, 0x40, 0x9A, 0xA0, 0xD8, 0x80, 0xDA,
+0x30, 0xF0, 0x20, 0x6C, 0x41, 0xF0, 0x00, 0x4C,
+0x80, 0x9C, 0x60, 0xDC, 0x05, 0x91, 0x04, 0x90,
+0x03, 0x63, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD1,
+0x00, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x18, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0xEC, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0xD4, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x80, 0x98, 0xB4, 0x9A, 0x60, 0x9F,
+0x20, 0x9E, 0x8C, 0xED, 0x95, 0x9A, 0xB7, 0xDA,
+0x6C, 0xEC, 0x76, 0x9A, 0x98, 0xDA, 0x2C, 0xEB,
+0x79, 0xDA, 0xA0, 0xD8, 0x80, 0xDF, 0x60, 0xDE,
+0x01, 0x91, 0x00, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0, 0x9C, 0xA2,
+0x01, 0x6B, 0x8C, 0xEB, 0x06, 0x23, 0xA0, 0xF0,
+0x64, 0x9A, 0x08, 0x6C, 0x8D, 0xEB, 0xA0, 0xF0,
+0x64, 0xDA, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF4, 0x98, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3,
+0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0x07, 0x6D, 0xB8, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x01, 0x6E, 0x12, 0xEC,
+0x71, 0xE4, 0x20, 0xF1, 0xB4, 0xA4, 0xCC, 0xED,
+0x1D, 0x25, 0x20, 0xF1, 0xB5, 0xA4, 0x22, 0xF6,
+0x7C, 0x9B, 0x20, 0xF1, 0x94, 0xA4, 0x75, 0xE5,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF5, 0x78, 0x9B,
+0xBC, 0x35, 0x21, 0x4D, 0x75, 0xE5, 0xE0, 0xA5,
+0x9E, 0x33, 0x9A, 0x34, 0xCC, 0xEC, 0x78, 0x33,
+0x9C, 0x34, 0x4C, 0xEF, 0x8D, 0xEB, 0xED, 0xEB,
+0x00, 0xF6, 0x60, 0x33, 0x00, 0xF6, 0x63, 0x33,
+0x4C, 0xEB, 0x60, 0xC5, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF4, 0xB4, 0xA3, 0x7F, 0x6B, 0xFF, 0x6A,
+0xAC, 0xEB, 0x4C, 0xEB, 0x4C, 0xEC, 0x02, 0x23,
+0x00, 0x18, 0x02, 0x17, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x30, 0xF0,
+0x20, 0x68, 0x2C, 0xEC, 0x61, 0xF3, 0x10, 0x48,
+0x04, 0xD4, 0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x18,
+0x86, 0x11, 0x01, 0x72, 0x15, 0x61, 0xC0, 0xF0,
+0x64, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x0F, 0x22, 0xA3, 0xF3, 0x7C, 0xA0, 0x02, 0x6A,
+0x4B, 0xEA, 0x6C, 0xEA, 0xA3, 0xF3, 0x5C, 0xC0,
+0xA3, 0xF3, 0x5C, 0xA0, 0x07, 0x6B, 0x6C, 0xEA,
+0x03, 0x2A, 0x04, 0x94, 0x00, 0x18, 0x43, 0x16,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x30, 0xF0,
+0x20, 0x68, 0x2C, 0xEC, 0x61, 0xF3, 0x10, 0x48,
+0x04, 0xD4, 0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x18,
+0x86, 0x11, 0x01, 0x72, 0x2E, 0x61, 0xC0, 0xF0,
+0x64, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x28, 0x22, 0xC3, 0xF3, 0x47, 0xA0, 0x01, 0x6B,
+0x6E, 0xEA, 0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF5, 0x64, 0x9B, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x58, 0x9A, 0x02, 0x6B,
+0x60, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0xA3, 0xF3, 0x98, 0xA2, 0x03, 0x6B,
+0x6B, 0xEB, 0x6C, 0xEC, 0xA3, 0xF3, 0x98, 0xC2,
+0xA3, 0xF3, 0x9C, 0xA2, 0x8C, 0xEB, 0xA3, 0xF3,
+0x7C, 0xC2, 0xA3, 0xF3, 0x5C, 0xA2, 0x07, 0x6B,
+0x6C, 0xEA, 0x03, 0x2A, 0x04, 0x94, 0x00, 0x18,
+0x43, 0x16, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x69, 0x30, 0xF0,
+0x20, 0x68, 0x2C, 0xEC, 0x61, 0xF3, 0x10, 0x48,
+0x04, 0xD4, 0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x18,
+0x86, 0x11, 0x01, 0x72, 0x1E, 0x61, 0xC0, 0xF0,
+0x64, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA, 0x2C, 0xEA,
+0x18, 0x22, 0xC0, 0xF0, 0x85, 0xA0, 0x10, 0x6B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x2C, 0xEB, 0x20, 0x73,
+0x05, 0x60, 0x01, 0x72, 0x03, 0x61, 0x00, 0x18,
+0x3B, 0x19, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF4, 0x74, 0xA2, 0x7F, 0x6A, 0x6C, 0xEA,
+0x02, 0x72, 0x03, 0x60, 0x04, 0x94, 0x00, 0x18,
+0x07, 0x17, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0xE0, 0xF0, 0x88, 0xA0, 0x00, 0x18,
+0x86, 0x11, 0x01, 0x72, 0x1C, 0x61, 0xC0, 0xF0,
+0x64, 0xA0, 0x7F, 0x6A, 0x6C, 0xEA, 0x17, 0x22,
+0xC3, 0xF3, 0x47, 0xA0, 0x01, 0x6B, 0x6E, 0xEA,
+0x12, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF5,
+0x64, 0x9B, 0xFF, 0x6C, 0x55, 0x4C, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0x58, 0x9A,
+0x02, 0x6B, 0x00, 0x6D, 0x60, 0xC2, 0xC0, 0xF0,
+0xCC, 0xA0, 0x00, 0x18, 0x1A, 0x34, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0xEC, 0x13,
+0x56, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x24, 0xF1, 0x6F, 0xA2, 0x0E, 0xEB,
+0x05, 0x2B, 0x24, 0xF1, 0x6D, 0xA2, 0x01, 0x4B,
+0x24, 0xF1, 0x6D, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x4B, 0xA2, 0x02, 0x72, 0x03, 0x60,
+0x90, 0x67, 0x00, 0x18, 0xC6, 0x17, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xE0, 0xF0,
+0xAE, 0xA2, 0x01, 0x6C, 0xFF, 0x6B, 0xAC, 0xEC,
+0x36, 0x24, 0xE0, 0xF0, 0xB1, 0xA2, 0xE0, 0xF0,
+0xD0, 0xA2, 0x7F, 0x6C, 0x8C, 0xED, 0x8C, 0xEE,
+0xE0, 0xF0, 0x91, 0xA2, 0x6C, 0xED, 0x6C, 0xEE,
+0x9E, 0x34, 0x6C, 0xEC, 0x05, 0x2C, 0xB4, 0x35,
+0xD0, 0x4D, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xED,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0xEF, 0xA2, 0x7F, 0x6B, 0xEC, 0xEB,
+0x46, 0xF6, 0x6E, 0xC2, 0xE0, 0xF0, 0x6E, 0xA2,
+0x01, 0x6F, 0x66, 0x30, 0xEC, 0xE8, 0x46, 0xF6,
+0x0F, 0xC2, 0xE0, 0xF0, 0x10, 0xA2, 0x1E, 0x30,
+0x46, 0xF6, 0x12, 0xC2, 0x6A, 0x30, 0x6E, 0x33,
+0xEC, 0xEB, 0xEC, 0xE8, 0x46, 0xF6, 0x71, 0xC2,
+0x00, 0x6B, 0x46, 0xF6, 0x10, 0xC2, 0x46, 0xF6,
+0x73, 0xC2, 0x00, 0x18, 0x36, 0x33, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x00, 0x18, 0xCC, 0x2E,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xA3, 0xF3, 0x79, 0xA0, 0x02, 0x6A, 0xFF, 0x69,
+0x6C, 0xEA, 0x2C, 0xEC, 0x2C, 0xEA, 0x04, 0xD4,
+0x1C, 0x22, 0x03, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x01, 0x6D, 0xA3, 0xF3, 0x59, 0xC0, 0x00, 0x18,
+0x4E, 0x34, 0xA3, 0xF3, 0x99, 0xA0, 0x01, 0x6B,
+0x4C, 0xEB, 0x09, 0x6A, 0x4B, 0xEA, 0x6C, 0x33,
+0x8C, 0xEA, 0x6D, 0xEA, 0xC0, 0xF0, 0x64, 0xA0,
+0xA3, 0xF3, 0x59, 0xC0, 0x7F, 0x6A, 0x6C, 0xEA,
+0x2C, 0xEA, 0x03, 0x22, 0x04, 0x94, 0x00, 0x18,
+0x43, 0x16, 0x04, 0x95, 0x01, 0x6C, 0x00, 0x18,
+0x4B, 0x26, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x24, 0x67, 0xA3, 0xF3,
+0x99, 0xA0, 0x01, 0x6B, 0xFF, 0x6A, 0x8C, 0xEB,
+0x4C, 0xEB, 0x4C, 0xE9, 0x16, 0x23, 0xFF, 0xF6,
+0x1F, 0x4A, 0x8C, 0xEA, 0x00, 0x6D, 0x91, 0x67,
+0xA3, 0xF3, 0x59, 0xC0, 0x00, 0x18, 0x4E, 0x34,
+0xA3, 0xF3, 0x99, 0xA0, 0x01, 0x6B, 0x6C, 0xEA,
+0xFA, 0x4B, 0x8C, 0xEB, 0x48, 0x32, 0x4D, 0xEB,
+0x91, 0x67, 0xA3, 0xF3, 0x79, 0xC0, 0x00, 0x18,
+0x43, 0x16, 0xB1, 0x67, 0x00, 0x6C, 0x00, 0x18,
+0x4B, 0x26, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x72, 0x39, 0x02, 0x67,
+0x01, 0x6A, 0x0C, 0xEA, 0x03, 0x22, 0x00, 0x6C,
+0x01, 0x6D, 0x02, 0x10, 0x00, 0x6C, 0xA4, 0x67,
+0x00, 0x18, 0x26, 0x12, 0x40, 0x6A, 0x0C, 0xEA,
+0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x54, 0x9A, 0x60, 0xA2, 0x00, 0xF6, 0x60, 0x33,
+0x00, 0xF6, 0x63, 0x33, 0x00, 0x53, 0x00, 0x6B,
+0x02, 0x61, 0x80, 0x6B, 0x6B, 0xEB, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xC3, 0xF3, 0x8C, 0xA2, 0xC3, 0xF3, 0xAD, 0xA2,
+0xC3, 0xF3, 0xD1, 0xA2, 0x02, 0x6F, 0x00, 0x18,
+0xAF, 0x12, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF4, 0x64, 0xA2,
+0x02, 0x6A, 0x6C, 0xEA, 0x03, 0x22, 0x01, 0x6C,
+0x00, 0x18, 0xBA, 0x3B, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xB3, 0x01, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xEB, 0x1D, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xC0, 0xF0, 0x64, 0xA0,
+0x7F, 0x6A, 0xFF, 0x69, 0x6C, 0xEA, 0x1E, 0x22,
+0xC0, 0xF0, 0x87, 0xA0, 0x96, 0x34, 0x2C, 0xEC,
+0x00, 0x18, 0xA0, 0x39, 0x02, 0x6B, 0x4C, 0xEB,
+0x2C, 0xEB, 0x07, 0x23, 0xC0, 0xF0, 0x87, 0xA0,
+0x96, 0x34, 0x2C, 0xEC, 0x00, 0x18, 0xCF, 0x16,
+0x0D, 0x10, 0xC0, 0xF0, 0x87, 0xA0, 0xA3, 0xF3,
+0x78, 0xA0, 0x05, 0x6A, 0x4B, 0xEA, 0x96, 0x34,
+0x6C, 0xEA, 0x2C, 0xEC, 0xA3, 0xF3, 0x58, 0xC0,
+0x00, 0x18, 0x43, 0x16, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0xC0, 0xF0, 0x84, 0xA2,
+0x7F, 0x6B, 0x8C, 0xEB, 0x07, 0x23, 0xC0, 0xF0,
+0x87, 0xA2, 0xFF, 0x6A, 0x96, 0x34, 0x4C, 0xEC,
+0x00, 0x18, 0x1E, 0x17, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x69, 0x2C, 0xEC,
+0x06, 0x74, 0x6E, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF0, 0x18, 0x4B, 0x60, 0x9B, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x40, 0xA3,
+0x01, 0x6B, 0x2C, 0xEA, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF0, 0x18, 0x4B, 0x60, 0x9B,
+0x2C, 0xEA, 0x40, 0xC3, 0xE0, 0xF0, 0x79, 0xA0,
+0x7F, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x2C, 0xEA,
+0x81, 0x72, 0x69, 0x61, 0xE0, 0xF0, 0x96, 0xA0,
+0x7F, 0x6A, 0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18,
+0x65, 0x32, 0x01, 0x72, 0x23, 0x61, 0x32, 0x6C,
+0x00, 0x18, 0x44, 0x2C, 0xE0, 0xF0, 0x96, 0xA0,
+0x7F, 0x6B, 0x6C, 0xEC, 0x2C, 0xEC, 0x00, 0x18,
+0x65, 0x32, 0x55, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0x0E, 0x2A, 0xE0, 0xF0, 0x75, 0xA0, 0x20, 0x6A,
+0x6C, 0xEA, 0x2C, 0xEA, 0x4C, 0x2A, 0xE0, 0xF0,
+0x96, 0xA0, 0x7F, 0x6A, 0x4C, 0xEC, 0x2C, 0xEC,
+0x00, 0x18, 0x7C, 0x32, 0xE0, 0xF0, 0x96, 0xA0,
+0x7F, 0x6B, 0x6C, 0xEC, 0x2C, 0xEC, 0x00, 0x18,
+0x87, 0x32, 0x3D, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF0, 0x18, 0x4B, 0x60, 0x9B, 0x32, 0x6C,
+0x40, 0xA3, 0x08, 0x6B, 0x2C, 0xEA, 0x6D, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0, 0x18, 0x4B,
+0x60, 0x9B, 0x2C, 0xEA, 0x40, 0xC3, 0x00, 0x18,
+0x44, 0x2C, 0xE0, 0xF0, 0x96, 0xA0, 0x7F, 0x6A,
+0x4C, 0xEC, 0x2C, 0xEC, 0x00, 0x18, 0x65, 0x32,
+0x01, 0x72, 0x21, 0x60, 0x01, 0x6C, 0x00, 0x18,
+0x0E, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x8C, 0x9A, 0x00, 0x18, 0x02, 0x07, 0x17, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x24, 0xF1, 0x70, 0xA2, 0x6E, 0xEC, 0x0F, 0x2C,
+0xE0, 0xF0, 0x99, 0xA2, 0x10, 0x6B, 0x8C, 0xEB,
+0x2C, 0xEB, 0x09, 0x2B, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF0, 0x64, 0x9A, 0x80, 0xF4, 0x98, 0x9C,
+0x8D, 0xEB, 0xA0, 0xF0, 0x64, 0xDA, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x8C, 0xE8, 0x90, 0x67, 0x00, 0x18, 0x27, 0x16,
+0x00, 0x6C, 0x00, 0x18, 0x13, 0x14, 0x90, 0x67,
+0x00, 0x18, 0xAE, 0x13, 0x05, 0x97, 0x04, 0x90,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0xDB, 0x3A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x31, 0x2A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x2E, 0x2A, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x9D, 0x2E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x00, 0x18, 0x1C, 0x2E, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x24, 0x67, 0xC0, 0xF0,
+0x84, 0xA0, 0x7F, 0x6B, 0xFF, 0x6A, 0x8C, 0xEB,
+0x4C, 0xEB, 0x4C, 0xE9, 0x25, 0x23, 0xA3, 0xF3,
+0x79, 0xA0, 0x21, 0x6C, 0x8B, 0xEC, 0x6C, 0xEC,
+0x40, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB, 0xA3, 0xF3,
+0x99, 0xC0, 0x10, 0x23, 0xC3, 0xF3, 0x8C, 0xA0,
+0xC3, 0xF3, 0xAD, 0xA0, 0xC3, 0xF3, 0xD1, 0xA0,
+0x05, 0x6F, 0x00, 0x18, 0xAF, 0x12, 0xA3, 0xF3,
+0x79, 0xA0, 0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0xA3, 0xF3, 0x59, 0xC0, 0x30, 0xF0, 0x20, 0x6A,
+0x24, 0xF7, 0x68, 0xA2, 0x40, 0x6A, 0x6C, 0xEA,
+0x03, 0x22, 0x91, 0x67, 0x00, 0x18, 0xA6, 0x3F,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x24, 0xF1, 0x75, 0xA2, 0x2E, 0xEB, 0x11, 0x2B,
+0x24, 0xF1, 0x74, 0xA2, 0x1F, 0x6C, 0x6A, 0x32,
+0x8C, 0xEA, 0x47, 0xE9, 0x01, 0x6C, 0x8C, 0xEA,
+0x08, 0x22, 0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x03, 0x22, 0x00, 0x6C, 0x00, 0x18,
+0xBA, 0x3B, 0x30, 0xF0, 0x20, 0x6A, 0x85, 0xF4,
+0x5F, 0xA2, 0x2E, 0xEA, 0x03, 0x2A, 0x91, 0x67,
+0x00, 0x18, 0x88, 0x26, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x24, 0xF1, 0x08, 0xA2,
+0x04, 0xD2, 0x2E, 0xE8, 0x06, 0x28, 0x91, 0x67,
+0x00, 0x18, 0xC7, 0x26, 0x04, 0x92, 0x24, 0xF1,
+0x0A, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4,
+0x57, 0xA2, 0x2E, 0xEA, 0x02, 0x2A, 0x00, 0x18,
+0xB3, 0x32, 0x91, 0x67, 0x00, 0x18, 0xB3, 0x15,
+0x91, 0x67, 0x00, 0x18, 0xFB, 0x28, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x69, 0x37, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF5, 0x78, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEE, 0x6D, 0xE4, 0x08, 0x68,
+0x80, 0xA3, 0xDB, 0xE0, 0x02, 0x67, 0x4C, 0xED,
+0x07, 0xEE, 0xD0, 0x67, 0x4C, 0xEF, 0x04, 0xED,
+0x4C, 0xEC, 0xCC, 0xEF, 0x0F, 0xE8, 0x8C, 0xE8,
+0xE4, 0xED, 0xED, 0xE8, 0x4C, 0xE8, 0x00, 0xC3,
+0x01, 0x90, 0x01, 0x63, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5, 0x58, 0x9A,
+0xFF, 0xF7, 0x1F, 0x6B, 0x8C, 0xEB, 0x4D, 0xE3,
+0x40, 0xA3, 0xFF, 0x6C, 0x8C, 0xEE, 0x08, 0x6B,
+0xDB, 0xE3, 0x8C, 0xED, 0x8C, 0xEA, 0x64, 0x67,
+0x47, 0xED, 0x67, 0xEE, 0x6C, 0xEA, 0x8C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0x01, 0x74, 0x0D, 0x60,
+0x06, 0x24, 0x02, 0x74, 0x10, 0x60, 0x03, 0x74,
+0x00, 0x6A, 0x1C, 0x61, 0x14, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA8, 0x35, 0x61, 0xF0, 0x5C, 0x9A,
+0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA8, 0x35,
+0x81, 0xF0, 0x40, 0x9A, 0x05, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x44, 0x9A, 0xA8, 0x35,
+0x55, 0xE5, 0x40, 0x9D, 0x20, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x48, 0x9A, 0xA8, 0x35,
+0x55, 0xE5, 0x40, 0x9D, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x81, 0xF4, 0x10, 0x6B, 0x43, 0xF2, 0x6C, 0xDA,
+0x00, 0xF2, 0x00, 0x4B, 0x43, 0xF2, 0x70, 0xDA,
+0x01, 0xF2, 0x00, 0x4B, 0x43, 0xF2, 0x74, 0xDA,
+0x00, 0xF2, 0x00, 0x4B, 0x43, 0xF2, 0x78, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x4C, 0x9A, 0xFF, 0x6B, 0x40, 0xA2,
+0x6C, 0xEA, 0x5E, 0x32, 0x6C, 0xEA, 0x20, 0xE8,
+0xFF, 0x6B, 0x6C, 0xEC, 0x1F, 0x6D, 0x8C, 0xED,
+0x96, 0x34, 0x6C, 0xEC, 0x01, 0x74, 0x03, 0x6A,
+0x0A, 0x60, 0x10, 0x24, 0x04, 0x74, 0x05, 0x60,
+0x06, 0x74, 0x00, 0x6A, 0x12, 0x61, 0xEF, 0x4A,
+0x02, 0x10, 0x07, 0x6A, 0x4B, 0xEA, 0xAB, 0xE2,
+0x44, 0x32, 0x00, 0xF6, 0x40, 0x32, 0x00, 0xF6,
+0x43, 0x32, 0x20, 0xE8, 0x08, 0x6A, 0xAB, 0xE2,
+0x44, 0x32, 0x00, 0xF6, 0x40, 0x32, 0x00, 0xF6,
+0x43, 0x32, 0x20, 0xE8, 0x00, 0xF6, 0x80, 0x34,
+0x00, 0xF6, 0x83, 0x34, 0x47, 0x44, 0x5C, 0x4A,
+0xFF, 0x6B, 0x6C, 0xEA, 0x77, 0x5A, 0x00, 0x6A,
+0x06, 0x60, 0x00, 0x54, 0x64, 0x6A, 0x03, 0x60,
+0x47, 0x44, 0x5D, 0x4A, 0x6C, 0xEA, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6B, 0x8C, 0xEB, 0xFF, 0xF7, 0x1F, 0x6A,
+0x81, 0x46, 0x26, 0x67, 0xAC, 0xEA, 0x06, 0x2C,
+0x83, 0x67, 0xA2, 0x67, 0x00, 0x18, 0xC5, 0x37,
+0x02, 0x67, 0x0A, 0x10, 0x83, 0x67, 0xA2, 0x67,
+0x00, 0x18, 0xC5, 0x37, 0x02, 0x67, 0x91, 0x67,
+0x00, 0x18, 0x57, 0x2B, 0x2C, 0xE8, 0x06, 0xEA,
+0x50, 0x67, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x8C, 0xEA,
+0x0E, 0x91, 0x04, 0xD2, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xED, 0x4C, 0xE9, 0x0C, 0xD6, 0x0D, 0xD7,
+0x0F, 0x90, 0x05, 0xD5, 0x00, 0x6A, 0x05, 0x10,
+0x0A, 0x6C, 0x00, 0x18, 0x4C, 0x2C, 0x40, 0xA8,
+0x01, 0x4A, 0x40, 0xC8, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x94, 0x05, 0x95, 0xE0, 0xF6, 0xDC, 0x9A,
+0x00, 0x18, 0x02, 0x38, 0x0C, 0x93, 0x6C, 0xEA,
+0x0D, 0x93, 0x6E, 0xEA, 0x03, 0x22, 0x40, 0xA8,
+0x23, 0xEA, 0xEA, 0x61, 0x40, 0xA8, 0x09, 0x97,
+0x07, 0x90, 0x23, 0xEA, 0x08, 0x91, 0x58, 0x67,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF5, 0x78, 0x9B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x69, 0xE2, 0x00, 0x9A, 0x41, 0x45,
+0x25, 0x67, 0x05, 0x22, 0x85, 0x67, 0x00, 0x18,
+0x57, 0x2B, 0x2C, 0xE8, 0x06, 0xEA, 0x50, 0x67,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x68,
+0x41, 0x45, 0x25, 0x67, 0x0C, 0xD6, 0x8C, 0xE8,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x58, 0x9A, 0x41, 0xE0, 0xC0, 0xD8, 0x17, 0x10,
+0x01, 0x6D, 0x90, 0x67, 0xAB, 0xED, 0x00, 0x18,
+0x2B, 0x38, 0x91, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0x57, 0x2B, 0x0C, 0x93, 0x64, 0xEA, 0x43, 0x67,
+0x04, 0x93, 0x2C, 0xEA, 0x2F, 0xE9, 0x6C, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF5, 0x78, 0x9B,
+0x2D, 0xEA, 0x61, 0xE0, 0x40, 0xD8, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0xAC, 0xEA, 0x54, 0x2C,
+0x06, 0x5A, 0xE0, 0xF0, 0x1E, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x48, 0x32, 0xC0, 0xF3, 0x04, 0x4B,
+0x4D, 0xE3, 0x40, 0x9B, 0x00, 0xEA, 0x01, 0x68,
+0x30, 0xF0, 0x20, 0x6A, 0x0B, 0xE8, 0x81, 0xF0,
+0x30, 0x9A, 0x5A, 0x10, 0x01, 0x68, 0x30, 0xF0,
+0x20, 0x6A, 0x0B, 0xE8, 0x81, 0xF0, 0x38, 0x9A,
+0x99, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x30, 0x9A, 0x01, 0x68, 0x0B, 0xE8, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF6,
+0x10, 0x6C, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x14, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x3C, 0x9A, 0x6D, 0x10,
+0xA1, 0xF4, 0x10, 0x6C, 0xFF, 0x6D, 0x77, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0xD0, 0x9A, 0x01, 0x6D, 0xA1, 0xF6,
+0x10, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6, 0xA4, 0x9A,
+0xA1, 0xF4, 0x14, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF6,
+0x14, 0x6C, 0x81, 0xF0, 0xB4, 0x9A, 0x31, 0x10,
+0x06, 0x5A, 0xA0, 0xF0, 0x0A, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0x48, 0x32, 0xC0, 0xF3, 0x1C, 0x4B,
+0x4D, 0xE3, 0x40, 0x9B, 0x00, 0xEA, 0x01, 0x68,
+0x30, 0xF0, 0x20, 0x6A, 0x0B, 0xE8, 0xA1, 0xF0,
+0x20, 0x9A, 0x27, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x20, 0x9A, 0x01, 0x68, 0x0B, 0xE8,
+0xB0, 0x67, 0xA1, 0xF4, 0x10, 0x6C, 0xD1, 0x67,
+0x00, 0x18, 0x39, 0x38, 0xB0, 0x67, 0xA1, 0xF6,
+0x10, 0x6C, 0xD1, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x14, 0x9A,
+0xA1, 0xF4, 0x14, 0x6C, 0x00, 0x6E, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x38, 0xA1, 0xF6, 0x14, 0x6C,
+0xB0, 0x67, 0x00, 0x6E, 0x78, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xA1, 0xF0, 0x24, 0x9A, 0x01, 0x68,
+0x0B, 0xE8, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x39, 0x38, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF6, 0x10, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0,
+0x14, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x24, 0x9A, 0xA1, 0xF4, 0x14, 0x6C, 0xB0, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF6,
+0x14, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x53, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0x28, 0x9A,
+0x01, 0x68, 0x0B, 0xE8, 0xB0, 0x67, 0xD1, 0x67,
+0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18, 0x39, 0x38,
+0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF6, 0x10, 0x6C,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF0, 0x14, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x24, 0x9A, 0xA1, 0xF4, 0x14, 0x6C,
+0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18, 0x39, 0x38,
+0xA1, 0xF6, 0x14, 0x6C, 0xB0, 0x67, 0xD1, 0x67,
+0x00, 0x18, 0x39, 0x38, 0x01, 0xF1, 0x00, 0x6C,
+0x00, 0xF3, 0x03, 0x6D, 0x01, 0x6E, 0x27, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xAC, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xD0, 0x9A,
+0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xC4, 0x9A,
+0x01, 0x6D, 0xA1, 0xF6, 0x10, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF6, 0x04, 0x9A, 0xA1, 0xF4, 0x14, 0x6C,
+0xB0, 0x67, 0xD0, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0xB4, 0x9A,
+0xA1, 0xF6, 0x14, 0x6C, 0xD0, 0x67, 0x00, 0x18,
+0x39, 0x38, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0x6A, 0x4C, 0xED,
+0x4C, 0xEC, 0x04, 0xD5, 0x28, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF4, 0x18, 0x9A, 0x01, 0xF0,
+0x08, 0x69, 0x91, 0x67, 0xB0, 0x67, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x21, 0xF0, 0x10, 0x6C,
+0x0E, 0x6D, 0x08, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x01, 0x6E, 0x21, 0xF0, 0x14, 0x6C, 0x03, 0x6D,
+0x00, 0x18, 0x39, 0x38, 0x04, 0x95, 0x00, 0x6C,
+0x00, 0x18, 0x50, 0x38, 0x91, 0x67, 0xB0, 0x67,
+0xD0, 0x67, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x81, 0xF0, 0x6C, 0x9A, 0x7F, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0xFF, 0x68,
+0x0C, 0xEC, 0x0F, 0x5C, 0xAC, 0xE8, 0x09, 0x60,
+0x00, 0x18, 0xE3, 0x37, 0x10, 0x22, 0x00, 0x18,
+0xE3, 0x37, 0x01, 0x72, 0x00, 0x6C, 0x0B, 0x61,
+0x04, 0x10, 0x00, 0x18, 0xE3, 0x37, 0x05, 0x2A,
+0x01, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0xD7, 0x38,
+0x02, 0x10, 0x00, 0x18, 0xE3, 0x37, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xA4, 0xF5, 0x1C, 0x4A, 0x88, 0x34, 0x91, 0xE2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x5C, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF5, 0xA0, 0x35,
+0xCC, 0xEA, 0x20, 0xF7, 0xC4, 0x9B, 0x80, 0xAC,
+0xAD, 0xEA, 0x01, 0x6D, 0xAB, 0xED, 0x4C, 0xEE,
+0x00, 0x18, 0x39, 0x38, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x46, 0x67, 0xFF, 0x68,
+0xFF, 0xF7, 0x1F, 0x69, 0x01, 0x4A, 0x0C, 0xD6,
+0x0D, 0xD7, 0x8C, 0xE8, 0xAC, 0xE9, 0x04, 0x2A,
+0x90, 0x67, 0xB1, 0x67, 0xC7, 0x67, 0x12, 0x10,
+0xB1, 0x67, 0x90, 0x67, 0x00, 0x18, 0xC5, 0x37,
+0x0C, 0x94, 0x04, 0xD2, 0x00, 0x18, 0x57, 0x2B,
+0x0D, 0x96, 0x90, 0x67, 0xB1, 0x67, 0xC4, 0xEA,
+0x0C, 0x92, 0x4C, 0xEE, 0x4F, 0xEB, 0x04, 0x92,
+0x4C, 0xEB, 0x6D, 0xEE, 0x00, 0x18, 0x02, 0x39,
+0x0A, 0x6C, 0x00, 0x18, 0x4C, 0x2C, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x04, 0x67, 0x4C, 0xE8, 0x68, 0x40,
+0xE4, 0x4B, 0x4C, 0xEB, 0x0D, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0x60, 0xF7, 0xAC, 0x9A, 0x80, 0xF4, 0x14, 0x6E,
+0x2F, 0x10, 0x68, 0x40, 0xD6, 0x4B, 0x4C, 0xEB,
+0x0F, 0x5B, 0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF0, 0x00, 0x6C, 0x60, 0xF7, 0xAC, 0x9A,
+0x40, 0xF4, 0x13, 0x6E, 0x21, 0x10, 0x68, 0x40,
+0xA4, 0x4B, 0x4C, 0xEB, 0x11, 0x5B, 0x09, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C,
+0x60, 0xF7, 0xAC, 0x9A, 0x40, 0xF4, 0x12, 0x6E,
+0x13, 0x10, 0x76, 0x58, 0x09, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C, 0x60, 0xF7,
+0xAC, 0x9A, 0x00, 0xF4, 0x12, 0x6E, 0x08, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0xAC, 0x9A,
+0x61, 0xF0, 0x00, 0x6C, 0x61, 0xF1, 0x0A, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x00, 0x69, 0x68, 0x40,
+0xE4, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB, 0x1D, 0x5B,
+0x02, 0x60, 0x02, 0x4A, 0x0E, 0x10, 0x68, 0x40,
+0xA4, 0x4B, 0x4C, 0xEB, 0x29, 0x5B, 0x03, 0x60,
+0x00, 0xF3, 0x01, 0x6A, 0x06, 0x10, 0x00, 0x6A,
+0x8D, 0x58, 0x04, 0xD2, 0x03, 0x61, 0x00, 0xF5,
+0x01, 0x4A, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0x94, 0x9A, 0x00, 0x18, 0x57, 0x2B,
+0x04, 0x97, 0x91, 0x67, 0x18, 0x6D, 0xE4, 0xEA,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF0, 0xD8, 0x9A,
+0x0D, 0xEF, 0x01, 0x49, 0x00, 0x18, 0x11, 0x39,
+0x04, 0x71, 0xD5, 0x61, 0x68, 0x40, 0xE4, 0x4B,
+0xFF, 0x6A, 0x4C, 0xEB, 0x1D, 0x5B, 0x05, 0x60,
+0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D, 0x01, 0x6E,
+0x10, 0x10, 0x68, 0x40, 0xA4, 0x4B, 0x4C, 0xEB,
+0x2D, 0x5B, 0x05, 0x60, 0x41, 0xF1, 0x18, 0x6C,
+0x1F, 0x6D, 0x02, 0x6E, 0x06, 0x10, 0x95, 0x58,
+0x06, 0x61, 0x41, 0xF1, 0x18, 0x6C, 0x1F, 0x6D,
+0x03, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xDC, 0xF5, 0x09, 0x4A,
+0x40, 0xDB, 0x00, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0xA1, 0xF0, 0xBC, 0x9A, 0xFF, 0x6C, 0x40, 0xA5,
+0xA0, 0xA5, 0x8C, 0xEA, 0xAC, 0xEC, 0x4E, 0xEC,
+0x19, 0x24, 0x64, 0x73, 0x12, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x40, 0xF6, 0x94, 0x9B, 0x40, 0x6D,
+0x60, 0x9C, 0xAD, 0xEB, 0x60, 0xDC, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x83, 0xF3,
+0x9C, 0x9B, 0xAD, 0xEC, 0x83, 0xF3, 0x9C, 0xDB,
+0x20, 0xE8, 0x01, 0x4B, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEB, 0xDC, 0x17, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x3C, 0xF6, 0x09, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x40, 0x9A, 0x60, 0xA2, 0x01, 0x6A, 0x6C, 0xEA,
+0xF8, 0x2A, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0x3C, 0xF6,
+0x0A, 0x4A, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0, 0x64, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0xE0, 0xA3, 0x1F, 0x6E,
+0x94, 0x34, 0xEC, 0xEE, 0xCD, 0xEC, 0x4C, 0xED,
+0x4C, 0xEC, 0x80, 0xC3, 0xA0, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0, 0x64, 0x9B,
+0xFF, 0x6A, 0x4C, 0xEC, 0xC0, 0xA3, 0x1F, 0x6D,
+0x94, 0x34, 0xCC, 0xED, 0xAD, 0xEC, 0x4C, 0xEC,
+0x80, 0xC3, 0x60, 0xA3, 0x6C, 0xEA, 0x20, 0xE8,
+0xFF, 0x6A, 0x4C, 0xED, 0xFF, 0x75, 0x4C, 0xEC,
+0xCC, 0xEA, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x71, 0xE4, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x71, 0xE4, 0x83, 0xF3, 0x68, 0xA4, 0xAC, 0xEA,
+0xAF, 0xED, 0x6C, 0xED, 0xAD, 0xEA, 0x83, 0xF3,
+0x48, 0xC4, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0xFF, 0x69, 0xDC, 0xF6, 0x15, 0x4A, 0x8C, 0xE9,
+0x40, 0xDB, 0x00, 0x68, 0x26, 0x10, 0x82, 0xF3,
+0x08, 0x70, 0x12, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x74, 0x9A, 0x10, 0x6C, 0x40, 0x9B,
+0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A,
+0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA, 0x1C, 0x10,
+0xFF, 0xF7, 0x1F, 0x6A, 0x01, 0x48, 0x4C, 0xE8,
+0x14, 0x6C, 0x00, 0x18, 0x4C, 0x2C, 0x33, 0x58,
+0x08, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF0,
+0x50, 0x9A, 0x01, 0x6B, 0x40, 0xA2, 0x6C, 0xEA,
+0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x48, 0x9A, 0x01, 0x6B, 0x40, 0x9A, 0x42, 0x32,
+0x5E, 0x32, 0x6C, 0xEA, 0x2E, 0xEA, 0xCF, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xDC, 0xF6, 0x16, 0x4A,
+0x40, 0xDB, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x00, 0x18, 0x8A, 0x39, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF6, 0x74, 0x9A, 0xEF, 0x6A,
+0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3, 0x00, 0x6C,
+0x00, 0x18, 0xB5, 0x39, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x30, 0xF0, 0x20, 0x6B,
+0x94, 0x9A, 0x41, 0xF0, 0x68, 0x9B, 0x80, 0xDB,
+0xC0, 0xF0, 0x72, 0xA2, 0x09, 0x6A, 0x6C, 0xEA,
+0x09, 0x72, 0x1D, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0x6C, 0x9A, 0x7F, 0xF7, 0x1F, 0x6A,
+0x07, 0x68, 0x80, 0xAB, 0x8C, 0xEA, 0x40, 0xCB,
+0x0A, 0x6C, 0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF7, 0x5C, 0x9A, 0x0A, 0x6C,
+0x00, 0xC2, 0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0x50, 0x9A, 0x0A, 0x6C,
+0x00, 0xC2, 0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3,
+0x98, 0xA2, 0x7F, 0x6B, 0x8C, 0xEB, 0xA3, 0xF3,
+0x78, 0xC2, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0x1D, 0xF0,
+0x0D, 0x4A, 0x40, 0xDB, 0x00, 0x68, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0x54, 0x9A, 0x40, 0x9A,
+0x1E, 0x22, 0xE0, 0xF3, 0x09, 0x70, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A,
+0x20, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x7C, 0xDA, 0x00, 0x6A, 0x09, 0x10, 0x32, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0x01, 0x48, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0xDC, 0x17, 0x01, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xA3, 0xF3, 0x78, 0xA0, 0x80, 0x6A, 0x4B, 0xEA,
+0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0xA3, 0xF3,
+0x58, 0xC0, 0x24, 0xF7, 0x18, 0x4C, 0x00, 0x6D,
+0x00, 0x18, 0xB4, 0x3F, 0x30, 0xF0, 0x20, 0x6A,
+0xC3, 0xF3, 0x68, 0xA8, 0xC1, 0xF0, 0x58, 0x9A,
+0x60, 0xCA, 0xC0, 0xF0, 0x72, 0xA0, 0x09, 0x6A,
+0x6C, 0xEA, 0x09, 0x6B, 0x6E, 0xEA, 0x16, 0x2A,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF7, 0x7C, 0x9B,
+0xFF, 0xF7, 0x1F, 0x6C, 0x80, 0x6D, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF0, 0x70, 0x9B,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x6C, 0x9A, 0x40, 0xAB, 0x8C, 0xEA, 0xAD, 0xEA,
+0x8C, 0xEA, 0x40, 0xCB, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF6, 0x74, 0x9A, 0xFF, 0x68, 0x10, 0x69,
+0x40, 0xA3, 0x01, 0x6C, 0x0C, 0xEA, 0x2D, 0xEA,
+0x0C, 0xEA, 0x40, 0xC3, 0x00, 0x18, 0xB5, 0x39,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xE0, 0xF0, 0x7C, 0xA2, 0x6C, 0xE9, 0x0C, 0xE9,
+0x03, 0x21, 0xFF, 0x6B, 0x01, 0x4B, 0x07, 0x10,
+0xE0, 0xF0, 0x79, 0xA2, 0x02, 0x6A, 0x6C, 0xEA,
+0x0C, 0xEA, 0x07, 0x22, 0x08, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF0, 0x48, 0x9A, 0x60, 0xDA,
+0x05, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF0,
+0x68, 0x9B, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0x60, 0x9A, 0xFF, 0x6C, 0x01, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xBA, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x00, 0x65, 0x00, 0x65,
+0x00, 0x65, 0x00, 0x65, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x9F, 0xE7, 0x01, 0x4F, 0x00, 0xF1, 0x00, 0x5F,
+0x44, 0x67, 0x05, 0x67, 0x0E, 0xD6, 0x06, 0xD7,
+0x13, 0x61, 0xC7, 0x45, 0x0E, 0x95, 0x00, 0x6B,
+0x05, 0x4E, 0x4D, 0xED, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF5, 0x4C, 0x9A, 0xFF, 0x6F, 0x83, 0x67,
+0x4C, 0xEE, 0x01, 0x4F, 0x04, 0xD3, 0x05, 0xD3,
+0x00, 0x18, 0x63, 0x2A, 0x00, 0x6C, 0x21, 0x10,
+0x67, 0x45, 0x05, 0x4B, 0x07, 0xD3, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF5, 0x6C, 0x9B, 0x07, 0x94,
+0x0E, 0x95, 0x06, 0x97, 0x6C, 0xEC, 0x07, 0xD4,
+0x07, 0x96, 0x00, 0x69, 0x91, 0x67, 0x4D, 0xED,
+0x04, 0xD1, 0x05, 0xD1, 0x00, 0x18, 0x63, 0x2A,
+0x06, 0x92, 0x07, 0x93, 0x0E, 0x95, 0xFF, 0x6F,
+0x01, 0x4F, 0x91, 0x67, 0x79, 0xE2, 0x5F, 0xE7,
+0x04, 0xD1, 0x05, 0xD1, 0x00, 0x18, 0x63, 0x2A,
+0x91, 0x67, 0x00, 0x18, 0x4A, 0x2A, 0x67, 0x40,
+0x05, 0x4B, 0x62, 0x32, 0x41, 0xC0, 0x42, 0x32,
+0x42, 0xC0, 0x00, 0xF6, 0x62, 0x32, 0x43, 0xC0,
+0x47, 0x40, 0x1D, 0x4A, 0x00, 0xF1, 0x4C, 0xC0,
+0x42, 0x34, 0x00, 0xF6, 0x42, 0x32, 0x60, 0xC0,
+0x00, 0xF1, 0x8D, 0xC0, 0x00, 0xF1, 0x4F, 0xC0,
+0x82, 0x34, 0x41, 0xA0, 0x00, 0xF1, 0x8E, 0xC0,
+0x80, 0xA0, 0x40, 0x32, 0x0F, 0x6D, 0x8D, 0xEA,
+0x82, 0xA0, 0x03, 0x6E, 0x0A, 0x91, 0x80, 0x34,
+0x80, 0x34, 0x4D, 0xEC, 0x43, 0xA0, 0x00, 0xF6,
+0x40, 0x32, 0x8D, 0xEA, 0xE2, 0xA2, 0x83, 0xA2,
+0xAC, 0xEF, 0x03, 0x4F, 0xEC, 0x37, 0xCC, 0xEC,
+0x91, 0xE7, 0x71, 0xE4, 0x82, 0x37, 0x84, 0xC0,
+0xE5, 0xC0, 0x00, 0xF6, 0x82, 0x34, 0xE2, 0x37,
+0xE6, 0xC0, 0x87, 0xC0, 0xE3, 0xA2, 0x8A, 0xA2,
+0x42, 0xA2, 0xEC, 0xEE, 0x8A, 0x34, 0x4C, 0xED,
+0x03, 0x4D, 0xD9, 0xE4, 0xAC, 0x35, 0xB9, 0xE6,
+0x6D, 0xE6, 0x62, 0x32, 0x00, 0xF1, 0x70, 0xC0,
+0x00, 0xF1, 0x51, 0xC0, 0x00, 0xF6, 0x62, 0x33,
+0x42, 0x32, 0x00, 0xF1, 0x52, 0xC0, 0x00, 0xF1,
+0x73, 0xC0, 0x0B, 0x97, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x6A, 0x4C, 0xEC,
+0xFF, 0x74, 0xAC, 0xEA, 0x05, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0xE4, 0xF6, 0x47, 0xC3, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x63, 0xF3, 0xB7, 0xA3, 0x8C, 0xEA, 0x8F, 0xEC,
+0xAC, 0xEC, 0x8D, 0xEA, 0x63, 0xF3, 0x57, 0xC3,
+0x20, 0xE8, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x68, 0x26, 0x67,
+0x0C, 0xE9, 0x53, 0x71, 0x0C, 0xEC, 0x0C, 0xED,
+0x09, 0x60, 0x06, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0xE4, 0xF6, 0x46, 0xA2, 0xAD, 0xEA, 0x0B, 0x10,
+0x00, 0x18, 0xB9, 0x3A, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x63, 0xF3, 0x77, 0xA2,
+0x63, 0xF3, 0x56, 0xA2, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF5, 0x64, 0x9B, 0x0C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xE4, 0xF6,
+0x24, 0xC2, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x7C, 0x9A,
+0x7F, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x40, 0x9A,
+0x9D, 0x67, 0x60, 0xA2, 0x01, 0x6A, 0x4F, 0xCC,
+0x4C, 0xEB, 0x72, 0xC4, 0x02, 0x6B, 0x70, 0xC4,
+0x04, 0x04, 0x00, 0x18, 0x2B, 0x2D, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF4, 0x45, 0xA2, 0xFF, 0x63, 0x05, 0x5A,
+0x2C, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x48, 0x32,
+0x20, 0xF4, 0x14, 0x4B, 0x4D, 0xE3, 0x40, 0x9B,
+0x00, 0xEA, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4,
+0x40, 0x9A, 0xFF, 0xF7, 0x1F, 0x6B, 0x40, 0x9A,
+0x1A, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4,
+0x40, 0x9A, 0x09, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x44, 0x9A, 0x0D, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x44, 0x9A, 0x40, 0x9A,
+0x50, 0x32, 0x00, 0xF5, 0x42, 0x32, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x48, 0x9A,
+0x40, 0x9A, 0xE1, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x01, 0x10, 0x64, 0x6A, 0x00, 0xD2, 0x00, 0x92,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x63, 0x01, 0xD0,
+0x0C, 0x2C, 0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6,
+0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF4,
+0x94, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x5D, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x24, 0xF1, 0xB4, 0xA2, 0x03, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0x24, 0xF1, 0x74, 0xC2,
+0x24, 0xF1, 0xD8, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0xC5, 0xF4, 0x04, 0x4A, 0x00, 0x6D, 0x18, 0x6F,
+0xF8, 0xED, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x12, 0xEF, 0x6D, 0xE7, 0x44, 0xF1,
+0x08, 0xA3, 0x01, 0x6F, 0xEC, 0xE8, 0x23, 0x20,
+0x44, 0xF1, 0x68, 0xA3, 0x66, 0x33, 0xEC, 0xEB,
+0xFF, 0x6F, 0xEC, 0xEB, 0x1C, 0x23, 0xFF, 0xF7,
+0x78, 0x9A, 0x9B, 0xEB, 0x01, 0x2C, 0xE5, 0xE8,
+0x12, 0xEB, 0xFF, 0xF7, 0x7C, 0xDA, 0x10, 0xEF,
+0x03, 0x27, 0x01, 0x4B, 0xFF, 0xF7, 0x7C, 0xDA,
+0x60, 0x9A, 0x78, 0xEE, 0x12, 0xEB, 0x9B, 0xEB,
+0x01, 0x2C, 0xE5, 0xE8, 0x12, 0xEB, 0x60, 0xDA,
+0xFF, 0xF7, 0x7C, 0x9A, 0x04, 0x2B, 0x01, 0x6F,
+0xFF, 0xF7, 0xFC, 0xDA, 0x60, 0xDA, 0x01, 0x4D,
+0x0A, 0x75, 0x18, 0x4A, 0xCC, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x24, 0xF1,
+0x7C, 0x9A, 0x24, 0xF1, 0x98, 0xDA, 0x7B, 0xEC,
+0x01, 0x2B, 0xE5, 0xE8, 0x24, 0xF1, 0x94, 0xA2,
+0x12, 0xEB, 0x44, 0xF1, 0x60, 0xDA, 0x78, 0x67,
+0x44, 0xF1, 0x64, 0xDA, 0x02, 0x6B, 0x8D, 0xEB,
+0x24, 0xF1, 0x74, 0xC2, 0x01, 0x90, 0x01, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x24, 0xF1, 0xB4, 0xA3,
+0x02, 0x6C, 0x00, 0x6A, 0xAC, 0xEC, 0x0C, 0x24,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0, 0x4C, 0x9A,
+0x00, 0x6C, 0x80, 0xC2, 0x03, 0x6A, 0x4B, 0xEA,
+0xAC, 0xEA, 0x24, 0xF1, 0x54, 0xC3, 0x01, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x00, 0x6A, 0x18, 0x6C,
+0x98, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x01, 0x4A, 0x0A, 0x72, 0x12, 0xEC,
+0x71, 0xE4, 0x44, 0xF1, 0xA8, 0xA4, 0x02, 0x6B,
+0x6B, 0xEB, 0xAC, 0xEB, 0x44, 0xF1, 0x68, 0xC4,
+0xEE, 0x61, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF4, 0x44, 0xA2, 0x01, 0x6B, 0x4C, 0xEB,
+0x00, 0x6A, 0x1C, 0x23, 0x30, 0xF0, 0x20, 0x6A,
+0xC5, 0xF4, 0x08, 0x4A, 0x00, 0x6B, 0xA0, 0x9A,
+0x8E, 0xED, 0x0F, 0x2D, 0x18, 0x6E, 0xD8, 0xEB,
+0x30, 0xF0, 0x20, 0x6D, 0x61, 0xF3, 0x10, 0x4D,
+0x12, 0xEE, 0xB9, 0xE6, 0x44, 0xF1, 0xE8, 0xA6,
+0x02, 0x6D, 0xAB, 0xED, 0xEC, 0xED, 0x44, 0xF1,
+0xA8, 0xC6, 0x01, 0x4B, 0x0A, 0x73, 0x18, 0x4A,
+0xEA, 0x61, 0x01, 0x6A, 0x20, 0xE8, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x5D, 0x67, 0x0A, 0xD4, 0x20, 0xF0, 0x98, 0xA2,
+0x30, 0xF0, 0x20, 0x6A, 0x0B, 0xD5, 0x0C, 0xD6,
+0x61, 0xF3, 0x10, 0x4A, 0x24, 0xF1, 0xB4, 0xA2,
+0x01, 0x6B, 0x00, 0xF6, 0xE0, 0x31, 0xAC, 0xEB,
+0x00, 0xF6, 0x23, 0x31, 0x80, 0xF0, 0x09, 0x23,
+0x21, 0x24, 0x01, 0x74, 0x80, 0xF0, 0x05, 0x61,
+0x0A, 0x93, 0x80, 0xF0, 0x02, 0x23, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF0, 0x70, 0x9B, 0xC3, 0xEB,
+0x7C, 0x61, 0x7F, 0x71, 0x7A, 0x60, 0xFF, 0xF7,
+0x1F, 0x51, 0x77, 0x61, 0x24, 0xF1, 0x18, 0x9A,
+0x1B, 0xEE, 0x01, 0x28, 0xE5, 0xE8, 0x10, 0xEA,
+0x12, 0xE8, 0x02, 0x22, 0x01, 0x48, 0x04, 0x10,
+0x03, 0x28, 0x01, 0x68, 0x50, 0x67, 0x1D, 0x10,
+0x01, 0x6B, 0x1E, 0x10, 0x0A, 0x94, 0x65, 0x24,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0, 0x70, 0x9B,
+0x0C, 0x95, 0xA3, 0xEB, 0x5E, 0x61, 0x7F, 0x71,
+0x5C, 0x60, 0xFF, 0xF7, 0x1F, 0x51, 0x59, 0x61,
+0x24, 0xF1, 0x1C, 0x9A, 0x1B, 0xED, 0x01, 0x28,
+0xE5, 0xE8, 0x10, 0xEA, 0x12, 0xE8, 0x02, 0x22,
+0x01, 0x48, 0x05, 0x10, 0x04, 0x28, 0x01, 0x68,
+0x00, 0x6A, 0x04, 0xD2, 0x02, 0x10, 0x00, 0x6B,
+0x04, 0xD3, 0x0A, 0x94, 0x00, 0x18, 0x53, 0x3B,
+0x00, 0x6C, 0xFF, 0x6E, 0xA4, 0x67, 0xCC, 0xED,
+0x1D, 0x65, 0x18, 0x6D, 0xB8, 0xEC, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x01, 0x6D,
+0x12, 0xEA, 0x69, 0xE2, 0x44, 0xF1, 0x48, 0xA2,
+0xAC, 0xEA, 0xCC, 0xEA, 0x2F, 0x2A, 0xD8, 0x67,
+0x18, 0x6F, 0xF8, 0xEE, 0x04, 0x96, 0xC4, 0x36,
+0x04, 0xD6, 0x03, 0x6E, 0xCB, 0xEE, 0x12, 0xEC,
+0x71, 0xE4, 0x44, 0xF1, 0xE8, 0xA4, 0xEC, 0xEE,
+0x04, 0x97, 0xED, 0xEE, 0x44, 0xF1, 0xC8, 0xC4,
+0x0A, 0x96, 0x44, 0xF1, 0xD8, 0xDC, 0x0B, 0x97,
+0x44, 0xF1, 0xFC, 0xDC, 0x0C, 0x96, 0x18, 0x6F,
+0x44, 0xF1, 0xCC, 0xDC, 0xD8, 0x67, 0x01, 0x4E,
+0xF8, 0xEE, 0x12, 0xEE, 0x6D, 0xE6, 0x24, 0xF1,
+0x5C, 0xDB, 0x24, 0xF1, 0x18, 0xDB, 0x44, 0xF1,
+0x49, 0xC4, 0x44, 0xF1, 0x48, 0xA4, 0x44, 0xF1,
+0x2A, 0xC4, 0x4D, 0xED, 0x44, 0xF1, 0xA8, 0xC4,
+0x01, 0x6A, 0x04, 0x10, 0x01, 0x4C, 0x0A, 0x74,
+0xBC, 0x61, 0x00, 0x6A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x06, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF4,
+0x04, 0x4A, 0x00, 0x6C, 0x4A, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC5, 0xF4, 0x04, 0x4A, 0x00, 0x6B,
+0x18, 0x6D, 0xB8, 0xEB, 0x30, 0xF0, 0x20, 0x6C,
+0x61, 0xF3, 0x10, 0x4C, 0x12, 0xED, 0x91, 0xE5,
+0x44, 0xF1, 0xC8, 0xA4, 0x01, 0x6D, 0xAC, 0xEE,
+0x08, 0x26, 0x44, 0xF1, 0x88, 0xA4, 0x86, 0x34,
+0xAC, 0xEC, 0x03, 0x24, 0x80, 0x9A, 0x01, 0x4C,
+0x80, 0xDA, 0x01, 0x4B, 0x0A, 0x73, 0x18, 0x4A,
+0xE7, 0x61, 0x00, 0x18, 0xE9, 0x3A, 0x04, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xC0, 0xF0, 0x67, 0xA2, 0x24, 0xF1, 0xB5, 0xA2,
+0xFF, 0x6C, 0x76, 0x33, 0xAE, 0xEB, 0x12, 0x2B,
+0xC0, 0xF0, 0xA4, 0xA2, 0x7F, 0x6B, 0xAC, 0xEB,
+0x8C, 0xEB, 0x0C, 0x23, 0xC0, 0xF0, 0xA5, 0xA2,
+0x0F, 0x6B, 0xAC, 0xEB, 0x8C, 0xEB, 0x06, 0x23,
+0x04, 0x93, 0xC3, 0xF3, 0x40, 0xA2, 0x78, 0xEA,
+0x12, 0xEA, 0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0x93, 0xA5, 0xF4, 0x48, 0x9A, 0x6E, 0xEA,
+0x52, 0x22, 0x04, 0x94, 0x00, 0x18, 0x05, 0x3B,
+0x4E, 0x10, 0x18, 0x6D, 0xB8, 0xEC, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x12, 0xED,
+0x6D, 0xE5, 0x44, 0xF1, 0xC8, 0xA3, 0x01, 0x6D,
+0xAC, 0xEE, 0x0A, 0x26, 0x44, 0xF1, 0x68, 0xA3,
+0x66, 0x33, 0xAC, 0xEB, 0xFF, 0x6D, 0xAC, 0xEB,
+0x03, 0x2B, 0x60, 0x9A, 0x01, 0x4B, 0x60, 0xDA,
+0x01, 0x4C, 0x0A, 0x74, 0x18, 0x4A, 0xE5, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x24, 0xF1, 0x75, 0xA2, 0xFF, 0x73, 0x2B, 0x61,
+0x44, 0xF1, 0x64, 0x9A, 0x01, 0x4B, 0x44, 0xF1,
+0x64, 0xDA, 0x44, 0xF1, 0x40, 0x9A, 0x4E, 0xEB,
+0x22, 0x2B, 0x30, 0xF0, 0x20, 0x6A, 0xC5, 0xF4,
+0x04, 0x4A, 0x18, 0x6D, 0xB8, 0xEB, 0x30, 0xF0,
+0x20, 0x6C, 0x61, 0xF3, 0x10, 0x4C, 0x12, 0xED,
+0x91, 0xE5, 0x44, 0xF1, 0xC8, 0xA4, 0x01, 0x6D,
+0xAC, 0xEE, 0x08, 0x26, 0x44, 0xF1, 0x88, 0xA4,
+0x86, 0x34, 0xAC, 0xEC, 0x03, 0x24, 0x80, 0x9A,
+0x01, 0x4C, 0x80, 0xDA, 0x01, 0x4B, 0x0A, 0x73,
+0x18, 0x4A, 0xE7, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x78, 0x67, 0xA5, 0xF4, 0x74, 0xDA, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA0, 0xF0,
+0x64, 0x9A, 0x02, 0xF0, 0x00, 0x6C, 0x8D, 0xEB,
+0xA0, 0xF0, 0x64, 0xDA, 0x07, 0x97, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0xA5, 0xF4, 0x19, 0x48, 0x00, 0x69, 0x18, 0x6A,
+0x58, 0xE9, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x10, 0x4B, 0x12, 0xEA, 0x69, 0xE2, 0x44, 0xF1,
+0x88, 0xA2, 0x01, 0x6B, 0x8C, 0xEB, 0x27, 0x23,
+0x00, 0xF0, 0x8B, 0x98, 0x00, 0xF0, 0x67, 0x98,
+0x63, 0xEC, 0x21, 0x61, 0x61, 0x80, 0x81, 0x43,
+0x04, 0xD4, 0x07, 0x2C, 0x00, 0xF0, 0x4F, 0x98,
+0x00, 0xF0, 0x93, 0x98, 0x40, 0xEA, 0x04, 0x92,
+0x14, 0x10, 0x80, 0xA0, 0x01, 0x4C, 0x80, 0xC0,
+0x80, 0xA0, 0x82, 0xEB, 0x08, 0x60, 0x44, 0xF1,
+0x88, 0xA2, 0x02, 0x6B, 0x6B, 0xEB, 0x8C, 0xEB,
+0x44, 0xF1, 0x68, 0xC2, 0x08, 0x10, 0x00, 0xF0,
+0x4F, 0x98, 0x00, 0xF0, 0x93, 0x98, 0x40, 0xEA,
+0x00, 0x6A, 0x00, 0xF0, 0x4B, 0xD8, 0x01, 0x49,
+0x0A, 0x71, 0x18, 0x48, 0xC8, 0x61, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x24, 0xF1,
+0x94, 0xA0, 0x01, 0x6B, 0x00, 0x6A, 0x8C, 0xEB,
+0x1F, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x4C, 0x9A, 0x00, 0x6B, 0x60, 0xC2, 0x03, 0x6A,
+0x4B, 0xEA, 0x8C, 0xEA, 0x24, 0xF1, 0x54, 0xC0,
+0x00, 0x18, 0xE9, 0x3A, 0x04, 0xD2, 0x04, 0x94,
+0x00, 0x18, 0x05, 0x3B, 0x24, 0xF1, 0x74, 0xA0,
+0x24, 0xF1, 0xDC, 0x98, 0x02, 0x6A, 0x6D, 0xEA,
+0x42, 0xF1, 0x1C, 0x6C, 0x01, 0x6D, 0x24, 0xF1,
+0x54, 0xC0, 0x00, 0x18, 0x1A, 0x34, 0x01, 0x6A,
+0x07, 0x97, 0x06, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x30, 0xF0,
+0x20, 0x68, 0x61, 0xF3, 0x10, 0x48, 0x24, 0xF1,
+0x54, 0xA0, 0x03, 0x6B, 0x4C, 0xEB, 0x00, 0x6A,
+0x28, 0x2B, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x4C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xFF, 0x6E,
+0x60, 0xC2, 0xA5, 0xF4, 0x04, 0x4C, 0x00, 0x6D,
+0x05, 0x4E, 0x00, 0x18, 0x6B, 0x2C, 0x05, 0x6A,
+0x64, 0x6B, 0x5B, 0xEB, 0x01, 0x2A, 0xE5, 0xE8,
+0x24, 0xF1, 0x5C, 0xD8, 0x24, 0xF1, 0x78, 0xD8,
+0x24, 0xF1, 0x74, 0xA0, 0x12, 0xEA, 0x44, 0xF1,
+0x40, 0xD8, 0x01, 0x6A, 0x4B, 0xEA, 0x24, 0xF1,
+0x55, 0xC0, 0x7D, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x01, 0x6B, 0x6D, 0xEA, 0x24, 0xF1, 0x54, 0xC0,
+0x43, 0x67, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x20, 0xE8, 0x00, 0x65,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xA7, 0x44, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0x4D,
+0x88, 0xF0, 0x0C, 0x4C, 0x14, 0x6E, 0x00, 0x18,
+0x70, 0x2C, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x6A, 0x04, 0x67, 0x25, 0x67, 0x4C, 0xE8,
+0x4C, 0xE9, 0x4C, 0xEE, 0xB1, 0x67, 0x90, 0x67,
+0x04, 0xD6, 0x00, 0x18, 0x37, 0x44, 0x90, 0x67,
+0x00, 0x18, 0x39, 0x49, 0x04, 0x97, 0x30, 0xF0,
+0x20, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0xC8, 0xF1,
+0x08, 0x4C, 0x00, 0x18, 0x16, 0x4F, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x04, 0x67, 0x30, 0xF0, 0x20, 0x69, 0x00, 0x18,
+0x6D, 0x3C, 0x47, 0xA0, 0x66, 0xA0, 0x61, 0xF3,
+0x10, 0x49, 0x06, 0xF5, 0x9C, 0xA1, 0x40, 0x32,
+0x69, 0xE2, 0x01, 0x6B, 0x8C, 0xEB, 0x26, 0xF5,
+0x4E, 0xC9, 0xFF, 0x6A, 0x15, 0x2B, 0x26, 0xF5,
+0x70, 0xC1, 0x02, 0x6B, 0x8C, 0xEB, 0x4C, 0xEB,
+0x40, 0x23, 0x06, 0xF5, 0x7F, 0xA1, 0x0F, 0x6D,
+0x26, 0xF5, 0x80, 0xA1, 0x6C, 0xED, 0x72, 0x36,
+0x4C, 0xED, 0x4C, 0xEE, 0x00, 0x18, 0x74, 0x3C,
+0x01, 0x72, 0x0D, 0x6A, 0x33, 0x61, 0x31, 0x10,
+0x26, 0xF5, 0x4C, 0xA9, 0x00, 0x6B, 0x26, 0xF5,
+0x70, 0xC1, 0x00, 0xF1, 0x01, 0x5A, 0x0C, 0x6A,
+0x29, 0x60, 0x00, 0x6A, 0x06, 0xF5, 0x1D, 0xA1,
+0x26, 0xF5, 0x71, 0xC1, 0x26, 0xF5, 0x72, 0xC1,
+0x26, 0xF5, 0x54, 0xC9, 0x26, 0xF5, 0x56, 0xC9,
+0x00, 0x18, 0xA3, 0x2B, 0x01, 0xE2, 0x00, 0x6A,
+0x26, 0xF5, 0xEC, 0xA9, 0x82, 0x67, 0x04, 0xD2,
+0x05, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0xB4, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0xD4, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0xA8, 0xF0,
+0x0D, 0x4B, 0x1C, 0x30, 0xB5, 0xE0, 0xD9, 0xE3,
+0x00, 0x18, 0x63, 0x2A, 0x01, 0x6A, 0x26, 0xF5,
+0x50, 0xC1, 0x00, 0x6A, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x26, 0xF5, 0xB4, 0xA8, 0x30, 0xF0, 0x20, 0x6A,
+0xA8, 0xF0, 0x0D, 0x4A, 0x30, 0xF0, 0x20, 0x6C,
+0xA8, 0xF1, 0x10, 0x4C, 0xB5, 0xE2, 0x04, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0x46, 0xF6, 0x63, 0xA0,
+0x80, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x05, 0x2A, 0x26, 0xF5, 0x54, 0xA8,
+0x04, 0x4A, 0x26, 0xF5, 0x54, 0xC8, 0x30, 0xF0,
+0x20, 0x69, 0x61, 0xF3, 0x10, 0x49, 0x46, 0xF6,
+0x41, 0xA1, 0x46, 0xF6, 0x80, 0xA1, 0x0F, 0x6D,
+0x4C, 0xED, 0x52, 0x36, 0x00, 0x18, 0x74, 0x3C,
+0x02, 0x67, 0x05, 0x2A, 0x00, 0x18, 0x64, 0x44,
+0x26, 0xF5, 0x10, 0xC1, 0x76, 0x10, 0x46, 0xF6,
+0x63, 0xA1, 0x7F, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x35, 0x22, 0x01, 0x72, 0x62, 0x61,
+0x00, 0x6C, 0x00, 0x18, 0x90, 0x46, 0x62, 0x22,
+0x06, 0xF5, 0x91, 0xA1, 0x01, 0x6D, 0x18, 0x6E,
+0x00, 0x6F, 0x00, 0x18, 0x3E, 0x48, 0x00, 0x18,
+0x7E, 0x48, 0x06, 0xD2, 0xE0, 0xF0, 0x7C, 0xA1,
+0x10, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA,
+0x19, 0x22, 0xE3, 0xF6, 0x41, 0xA1, 0x00, 0x68,
+0x0D, 0x2A, 0x14, 0x10, 0x03, 0x6C, 0x25, 0xE0,
+0x00, 0x18, 0x44, 0x2C, 0x23, 0xF7, 0x80, 0xA1,
+0x00, 0x6D, 0x01, 0x48, 0x00, 0x18, 0xD1, 0x45,
+0xFF, 0x6A, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x69,
+0x61, 0xF3, 0x10, 0x49, 0xE3, 0xF6, 0x41, 0xA1,
+0x43, 0xE8, 0xEC, 0x61, 0x06, 0x92, 0x03, 0x2A,
+0x00, 0x18, 0x64, 0x44, 0x33, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x26, 0xF5,
+0x71, 0xA2, 0x46, 0xF6, 0x82, 0xA2, 0x01, 0x4B,
+0x26, 0xF5, 0x71, 0xC2, 0x26, 0xF5, 0x76, 0xAA,
+0x6D, 0xE4, 0x26, 0xF5, 0x76, 0xCA, 0x26, 0xF5,
+0x91, 0xA2, 0x06, 0xF5, 0x7E, 0xA2, 0x8E, 0xEB,
+0x09, 0x2B, 0x10, 0xF0, 0x21, 0x6C, 0x46, 0xF6,
+0xC2, 0xA2, 0x9E, 0xF4, 0x09, 0x4C, 0x04, 0xD3,
+0x00, 0x6D, 0x09, 0x10, 0x46, 0xF6, 0xC2, 0xA2,
+0x10, 0xF0, 0x21, 0x6C, 0x00, 0x6A, 0x04, 0xD2,
+0x3E, 0xF4, 0x1D, 0x4C, 0xA2, 0x67, 0x64, 0x6A,
+0x58, 0xEE, 0x01, 0x6F, 0x12, 0xEE, 0x00, 0x18,
+0x66, 0x3B, 0x0B, 0x10, 0x00, 0x6A, 0x26, 0xF5,
+0x50, 0xC1, 0x07, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x00, 0x6B, 0x26, 0xF5,
+0x70, 0xC2, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3,
+0x10, 0x48, 0x26, 0xF5, 0x50, 0xA0, 0x18, 0x22,
+0x26, 0xF6, 0x5D, 0xA0, 0x13, 0x22, 0xE0, 0xF0,
+0xC7, 0xA0, 0x00, 0x6A, 0x0C, 0x6C, 0x00, 0x6D,
+0x26, 0xF6, 0x5D, 0xC0, 0x00, 0x18, 0xD7, 0x14,
+0xA3, 0xF3, 0x78, 0xA0, 0x21, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x02, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA,
+0xA3, 0xF3, 0x58, 0xC0, 0x00, 0x18, 0xB6, 0x3C,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x26, 0xF5,
+0x50, 0xA3, 0x00, 0xF1, 0x14, 0x22, 0x06, 0xF5,
+0xDC, 0xA3, 0x03, 0x6D, 0xFF, 0x6A, 0xCE, 0x34,
+0xAC, 0xEC, 0x02, 0x74, 0x68, 0x60, 0x8E, 0xED,
+0xC0, 0xF0, 0x09, 0x25, 0x01, 0x74, 0x15, 0x60,
+0x00, 0x6C, 0x26, 0xF5, 0x90, 0xC3, 0x02, 0x6C,
+0xCC, 0xEC, 0x4C, 0xEC, 0x0B, 0x24, 0x06, 0xF5,
+0x9F, 0xA3, 0x0F, 0x6D, 0x8C, 0xED, 0x92, 0x36,
+0x26, 0xF5, 0x80, 0xA3, 0x4C, 0xED, 0x4C, 0xEE,
+0x00, 0x18, 0x74, 0x3C, 0x00, 0x18, 0x64, 0x44,
+0xBD, 0x10, 0x02, 0x6C, 0xCC, 0xEC, 0x4C, 0xEC,
+0x0E, 0x24, 0x06, 0xF5, 0x9F, 0xA3, 0x0F, 0x6D,
+0x8C, 0xED, 0x92, 0x36, 0x26, 0xF5, 0x80, 0xA3,
+0x4C, 0xED, 0x4C, 0xEE, 0x00, 0x18, 0x74, 0x3C,
+0x01, 0x72, 0xC0, 0xF0, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x88, 0xF0, 0x51, 0xA2, 0x5A, 0x33,
+0x02, 0x73, 0x0D, 0x60, 0x03, 0x73, 0x0F, 0x60,
+0x01, 0x73, 0x05, 0x60, 0x3F, 0x6E, 0x4C, 0xEE,
+0xFF, 0x6A, 0x4C, 0xEE, 0x0E, 0x10, 0x3F, 0x6B,
+0x4C, 0xEB, 0x0A, 0x6E, 0x08, 0x10, 0x3F, 0x6B,
+0x4C, 0xEB, 0x64, 0x6E, 0x04, 0x10, 0x3F, 0x6B,
+0x4C, 0xEB, 0xE0, 0xF3, 0x08, 0x6E, 0xD8, 0xEB,
+0x12, 0xEE, 0x0A, 0x6A, 0x58, 0xEE, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x26, 0xF5,
+0x76, 0xAA, 0x10, 0xF0, 0x21, 0x6C, 0x3E, 0xF4,
+0x1D, 0x4C, 0x12, 0xEE, 0x7B, 0xE6, 0x01, 0x6B,
+0x26, 0xF6, 0x7D, 0xC2, 0x00, 0x6B, 0x26, 0xF5,
+0x71, 0xC2, 0x00, 0x6B, 0x26, 0xF5, 0x76, 0xCA,
+0x26, 0xF5, 0x74, 0xCA, 0x00, 0x6A, 0x04, 0xD2,
+0xA2, 0x67, 0x64, 0x6A, 0x5E, 0x10, 0x02, 0x6C,
+0xCC, 0xEC, 0x4C, 0xEC, 0x0E, 0x24, 0x06, 0xF5,
+0x9F, 0xA3, 0x0F, 0x6D, 0x8C, 0xED, 0x92, 0x36,
+0x26, 0xF5, 0x80, 0xA3, 0x4C, 0xED, 0x4C, 0xEE,
+0x00, 0x18, 0x74, 0x3C, 0x01, 0x72, 0x80, 0xF0,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x26, 0xF5, 0x83, 0xA2, 0x26, 0xF5,
+0x72, 0xA2, 0xFF, 0x4C, 0x6E, 0xEC, 0x03, 0x2C,
+0x26, 0xF5, 0x62, 0xA2, 0x05, 0x10, 0x01, 0x4B,
+0x26, 0xF5, 0x72, 0xC2, 0x26, 0xF5, 0x61, 0xA2,
+0x7A, 0x32, 0x02, 0x72, 0x0D, 0x60, 0x03, 0x72,
+0x0F, 0x60, 0x01, 0x72, 0x05, 0x60, 0x3F, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x0E, 0x10,
+0x3F, 0x6A, 0x6C, 0xEA, 0x0A, 0x6B, 0x08, 0x10,
+0x3F, 0x6A, 0x6C, 0xEA, 0x64, 0x6B, 0x04, 0x10,
+0x3F, 0x6A, 0x6C, 0xEA, 0xE0, 0xF3, 0x08, 0x6B,
+0x78, 0xEA, 0x12, 0xEA, 0x0A, 0x6B, 0x78, 0xEA,
+0x30, 0xF0, 0x20, 0x6B, 0xA8, 0xF0, 0x66, 0xAB,
+0x01, 0x6C, 0x64, 0x6E, 0x12, 0xEA, 0x6B, 0xE2,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x26, 0xF6, 0x9D, 0xC3, 0x00, 0x6C, 0x26, 0xF5,
+0x91, 0xC3, 0x00, 0x6C, 0x26, 0xF5, 0x96, 0xCB,
+0x26, 0xF5, 0x94, 0xCB, 0x00, 0x6B, 0x10, 0xF0,
+0x21, 0x6C, 0x04, 0xD3, 0x3E, 0xF4, 0x1D, 0x4C,
+0xA3, 0x67, 0xD8, 0xEA, 0x01, 0x6F, 0x12, 0xEE,
+0x00, 0x18, 0x66, 0x3B, 0x0B, 0x10, 0x01, 0x6A,
+0x26, 0xF5, 0xB1, 0xC3, 0x26, 0xF5, 0xB6, 0xCB,
+0x26, 0xF5, 0xB4, 0xCB, 0x26, 0xF6, 0x5D, 0xC3,
+0x00, 0x18, 0x0F, 0x3D, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xE0, 0xF0, 0x87, 0xA0,
+0x00, 0x18, 0xA6, 0x3F, 0xE0, 0xF0, 0x87, 0xA0,
+0x00, 0x18, 0x95, 0x3F, 0xE0, 0xF0, 0x87, 0xA0,
+0x00, 0x18, 0xAD, 0x3F, 0xA3, 0xF3, 0x78, 0xA0,
+0xE0, 0xF0, 0xC7, 0xA0, 0x20, 0x6A, 0x6D, 0xEA,
+0x08, 0x6C, 0x00, 0x6D, 0xA3, 0xF3, 0x58, 0xC0,
+0x00, 0x18, 0xD7, 0x14, 0x00, 0xF1, 0x7F, 0xA0,
+0x02, 0x6A, 0x6C, 0xEA, 0x05, 0x22, 0xA3, 0xF3,
+0x78, 0xA0, 0x01, 0x6A, 0x6D, 0xEA, 0x05, 0x10,
+0xA3, 0xF3, 0x78, 0xA0, 0x02, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0xA3, 0xF3, 0x58, 0xC0, 0x07, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0x6B, 0x26, 0xF5, 0x70, 0xC2, 0x07, 0x97,
+0x06, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x04, 0xF7, 0x7D, 0xA3,
+0xFF, 0x6A, 0xAC, 0xEA, 0x03, 0x23, 0x02, 0x73,
+0x11, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF4, 0x78, 0x9B, 0x83, 0xEB, 0x05, 0x60,
+0x30, 0xF0, 0x20, 0x6B, 0xE1, 0xF0, 0x78, 0x9B,
+0x09, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6,
+0x78, 0x9B, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF0, 0x64, 0x9B, 0x71, 0xE4, 0x40, 0xC4,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x04, 0xF7, 0x7D, 0xA3, 0xFF, 0xF7, 0x1F, 0x6A,
+0xAC, 0xEA, 0x03, 0x23, 0x02, 0x73, 0x11, 0x60,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B, 0x80, 0xF4,
+0x78, 0x9B, 0x83, 0xEB, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6B, 0xE1, 0xF0, 0x78, 0x9B, 0x09, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6, 0x78, 0x9B,
+0x04, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF0,
+0x64, 0x9B, 0x71, 0xE4, 0x40, 0xCC, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0xF7, 0x5D, 0xA2,
+0x03, 0x22, 0x02, 0x72, 0x11, 0x60, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0x58, 0x9A,
+0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x58, 0x9A, 0x09, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0xC0, 0xF6, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x44, 0x9A,
+0x51, 0xE4, 0xA0, 0xDC, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0xF7, 0x5D, 0xA2,
+0x04, 0x22, 0x02, 0x72, 0x00, 0x6A, 0x1D, 0x61,
+0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x58, 0x9A, 0x83, 0xEA, 0x05, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0xE1, 0xF0, 0x58, 0x9A, 0x04, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x58, 0x9A,
+0x51, 0xE4, 0x60, 0xA4, 0xFF, 0x6A, 0x6C, 0xEA,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x44, 0x9A, 0x51, 0xE4, 0x60, 0xA4, 0xFF, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0xF7, 0x5D, 0xA2, 0x04, 0x22, 0x02, 0x72,
+0x00, 0x6A, 0x1F, 0x61, 0x15, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x58, 0x9A, 0x83, 0xEA,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x58, 0x9A, 0x51, 0xE4, 0x60, 0xAC,
+0xFF, 0xF7, 0x1F, 0x6A, 0x6C, 0xEA, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0, 0x44, 0x9A,
+0x51, 0xE4, 0x60, 0xAC, 0xFF, 0xF7, 0x1F, 0x6A,
+0x6C, 0xEA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x04, 0xF7, 0x5D, 0xA2, 0x04, 0x22, 0x02, 0x72,
+0x00, 0x6A, 0x19, 0x61, 0x12, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x58, 0x9A, 0x83, 0xEA,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF0,
+0x58, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x58, 0x9A, 0x51, 0xE4, 0x40, 0x9C,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x44, 0x9A, 0x51, 0xE4, 0x40, 0x9C, 0x20, 0xE8,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x4C, 0xED,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0xA3, 0xF3, 0x6C, 0xA2, 0x10, 0xD6, 0x11, 0xD7,
+0x01, 0x73, 0x07, 0xD4, 0x08, 0xD5, 0x80, 0xF0,
+0x0F, 0x61, 0xA3, 0xF3, 0x70, 0xA2, 0x01, 0x73,
+0x19, 0x61, 0xA3, 0xF3, 0x6F, 0xA2, 0x16, 0x2B,
+0xA3, 0xF3, 0x0E, 0xA2, 0xA3, 0xF3, 0x70, 0xC2,
+0xA3, 0xF3, 0x68, 0x9A, 0x01, 0x6A, 0x4C, 0xE8,
+0x01, 0x58, 0x18, 0x67, 0x00, 0x30, 0xFB, 0x4B,
+0x08, 0x30, 0x01, 0xE3, 0x90, 0x67, 0x00, 0x18,
+0xE6, 0x3D, 0xFE, 0x6D, 0x90, 0x67, 0x4C, 0xED,
+0x00, 0x18, 0xB4, 0x3D, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0xA3, 0xF3, 0x50, 0xA0,
+0x6B, 0x2A, 0xA3, 0xF3, 0x44, 0x98, 0xA3, 0xF3,
+0x6E, 0xA0, 0x06, 0xD2, 0xA3, 0xF3, 0x48, 0x98,
+0x05, 0xD3, 0x06, 0x94, 0x60, 0x33, 0x68, 0x33,
+0x49, 0xE3, 0x85, 0xE2, 0x04, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x50, 0x9A, 0x91, 0x67,
+0xA0, 0x9A, 0x00, 0x18, 0xD6, 0x3D, 0x07, 0x95,
+0x84, 0x41, 0x00, 0x18, 0xC5, 0x3D, 0x08, 0x95,
+0x86, 0x41, 0x00, 0x18, 0xC5, 0x3D, 0x10, 0x95,
+0x87, 0x41, 0x01, 0x4C, 0x00, 0x18, 0xD6, 0x3D,
+0x11, 0x95, 0x87, 0x41, 0x05, 0x4C, 0x00, 0x18,
+0xD6, 0x3D, 0x06, 0x92, 0x20, 0x4A, 0xE0, 0xF3,
+0x01, 0x5A, 0x39, 0x61, 0x05, 0x93, 0x01, 0x69,
+0x51, 0x67, 0x44, 0xEB, 0xA3, 0xF3, 0x6F, 0xA0,
+0x04, 0x94, 0x6D, 0xEA, 0xFB, 0x4C, 0xA3, 0xF3,
+0x4F, 0xC0, 0x04, 0xD4, 0x00, 0x18, 0xE6, 0x3D,
+0x80, 0x6D, 0xAB, 0xED, 0x04, 0x94, 0x4D, 0xED,
+0xFF, 0x6A, 0x4C, 0xED, 0x00, 0x18, 0xB4, 0x3D,
+0x05, 0x92, 0x01, 0x5A, 0x58, 0x67, 0x05, 0xD2,
+0xA3, 0xF3, 0x4F, 0xA0, 0x78, 0x67, 0x47, 0xEB,
+0x2C, 0xEA, 0x0B, 0x22, 0x04, 0x94, 0xA3, 0xF3,
+0x30, 0xC0, 0x00, 0x18, 0xE6, 0x3D, 0x04, 0x94,
+0x2D, 0xEA, 0xFF, 0x6D, 0x4C, 0xED, 0x00, 0x18,
+0xB4, 0x3D, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x00, 0x6B, 0xA3, 0xF3, 0x64, 0xDA,
+0x7D, 0x67, 0x87, 0x43, 0x0D, 0x4C, 0x60, 0xA4,
+0xA3, 0xF3, 0x6E, 0xC2, 0x05, 0x10, 0xA3, 0xF3,
+0x44, 0x98, 0x10, 0x4A, 0xA3, 0xF3, 0x44, 0xD8,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x50, 0x9A, 0xFF, 0x6B, 0x80, 0xA2,
+0xA4, 0x67, 0x6C, 0xED, 0x04, 0xD5, 0x42, 0x2D,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xA3, 0xF3, 0x92, 0xA0, 0x12, 0x2C, 0x02, 0x6C,
+0x8B, 0xEC, 0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x9C, 0x9A, 0x80, 0x6D, 0xAB, 0xED,
+0x40, 0xA4, 0x6C, 0xEA, 0xAE, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x01, 0x6A, 0xA3, 0xF3, 0x52, 0xC0,
+0x29, 0x10, 0xA3, 0xF3, 0x31, 0xA0, 0xA3, 0xF3,
+0x88, 0x98, 0x20, 0x32, 0x48, 0x32, 0xFB, 0x4C,
+0x51, 0xE4, 0x00, 0x18, 0xE6, 0x3D, 0x00, 0xF6,
+0x40, 0x32, 0x00, 0xF6, 0x43, 0x32, 0x00, 0x52,
+0x19, 0x61, 0x01, 0x6A, 0x04, 0x21, 0x5D, 0x67,
+0x67, 0x42, 0x09, 0x4B, 0x40, 0xA3, 0xA3, 0xF3,
+0x51, 0xC0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x00, 0x6B, 0xA3, 0xF3, 0x8F, 0xA2,
+0xA3, 0xF3, 0x72, 0xC2, 0x01, 0x6B, 0x64, 0xE9,
+0x6F, 0xEB, 0x8C, 0xEB, 0xA3, 0xF3, 0x6F, 0xC2,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0xA3, 0xF3, 0x48, 0x98, 0xA3, 0xF3, 0x31, 0xA0,
+0x04, 0xD2, 0x00, 0x18, 0x6A, 0x2D, 0x00, 0x6B,
+0x33, 0x22, 0x04, 0x93, 0x20, 0x32, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0x4B, 0x80, 0xF7, 0x90, 0x9C,
+0x48, 0x32, 0x49, 0xE3, 0xFF, 0xF7, 0x1F, 0x6B,
+0x4C, 0xEB, 0x60, 0xCC, 0x30, 0xF0, 0x20, 0x6B,
+0x80, 0xF7, 0x94, 0x9B, 0xFF, 0x6D, 0x10, 0x6E,
+0x60, 0xA4, 0x42, 0x32, 0xCB, 0xEE, 0xAC, 0xEB,
+0xCC, 0xEB, 0x42, 0x32, 0x6D, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF7, 0x68, 0x9B, 0xAC, 0xEA,
+0x40, 0xC4, 0x01, 0x6A, 0x40, 0xC3, 0x01, 0x21,
+0x00, 0x6A, 0xA3, 0xF3, 0x51, 0xC0, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3,
+0x8F, 0xA2, 0x01, 0x6B, 0x64, 0xE9, 0x6F, 0xEB,
+0x8C, 0xEB, 0xA3, 0xF3, 0x6F, 0xC2, 0x01, 0x6B,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x43, 0x67,
+0x05, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x04, 0xF7, 0x5D, 0xA2,
+0x03, 0x22, 0x02, 0x72, 0x04, 0x60, 0x05, 0x10,
+0x00, 0x18, 0x9E, 0x3E, 0x02, 0x10, 0x00, 0x18,
+0x73, 0x3E, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x04, 0xF7, 0x9D, 0xA4,
+0xFF, 0xF7, 0x1F, 0x6B, 0xAC, 0xEB, 0x03, 0x24,
+0x02, 0x74, 0x21, 0x60, 0x26, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x80, 0xF4, 0x98, 0x9C, 0xC3, 0xEC,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF0,
+0x9C, 0x9C, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x00, 0xF6, 0x8C, 0x9C, 0x99, 0xE6, 0x30, 0xF0,
+0x20, 0x6C, 0x80, 0xF4, 0x98, 0x9C, 0xE3, 0xEC,
+0x05, 0x60, 0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF0,
+0x9C, 0x9C, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6C,
+0x00, 0xF6, 0x8C, 0x9C, 0x05, 0x10, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0xF1, 0x80, 0x9C, 0x99, 0xE6,
+0x9D, 0xE7, 0xBD, 0x67, 0x52, 0xC5, 0x30, 0xF0,
+0x20, 0x6A, 0x24, 0xF7, 0x44, 0xAA, 0x04, 0x6C,
+0x8B, 0xEC, 0x90, 0xC5, 0x53, 0xC5, 0x0B, 0x6C,
+0x43, 0x32, 0x75, 0xC5, 0x63, 0x33, 0x54, 0xC5,
+0x76, 0xC5, 0x8F, 0xCD, 0x00, 0xF0, 0x17, 0x03,
+0x00, 0x6A, 0x86, 0x67, 0x86, 0xEA, 0x80, 0xC3,
+0x87, 0x67, 0x86, 0xEA, 0x08, 0x4A, 0x18, 0x72,
+0x83, 0xC3, 0x01, 0x4B, 0xF6, 0x61, 0x04, 0x04,
+0x00, 0x18, 0x2B, 0x2D, 0x09, 0x97, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x40, 0xA4, 0x01, 0x6D,
+0xAC, 0xEA, 0x80, 0xF0, 0x05, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0xA3, 0xF3,
+0x6C, 0xA2, 0x7B, 0x2B, 0xA3, 0xF3, 0xAC, 0xC2,
+0x80, 0xA4, 0x92, 0x34, 0xA3, 0xF3, 0x8D, 0xC2,
+0xA3, 0xF3, 0x8D, 0xA2, 0x05, 0x24, 0x02, 0x74,
+0x10, 0x61, 0x07, 0xF0, 0x00, 0x68, 0x10, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0x54, 0x9A,
+0x00, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x58, 0x9A, 0x4C, 0xE8, 0x00, 0xF1, 0x01, 0x48,
+0x03, 0x10, 0xA3, 0xF3, 0x6C, 0xC2, 0x00, 0x68,
+0x03, 0x6A, 0x0C, 0xEA, 0x4D, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x04, 0xF7, 0x5C, 0xA2, 0x01, 0x72,
+0x45, 0x61, 0x01, 0xF0, 0x40, 0x40, 0x05, 0xD2,
+0x30, 0x67, 0x23, 0x10, 0x04, 0x92, 0x00, 0x6D,
+0x31, 0xE2, 0x00, 0x18, 0xD6, 0x3D, 0x04, 0x92,
+0x04, 0x4A, 0x18, 0x72, 0x04, 0xD2, 0xF6, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1, 0xA4, 0x9A,
+0x91, 0x67, 0x00, 0x18, 0xD6, 0x3D, 0x87, 0x41,
+0x04, 0x4C, 0x10, 0x6D, 0x00, 0x18, 0xB4, 0x3D,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF1, 0xA8, 0x9A,
+0x87, 0x41, 0x11, 0x4C, 0x00, 0x18, 0xD6, 0x3D,
+0x05, 0x93, 0x00, 0xF4, 0x00, 0x49, 0x2E, 0xEB,
+0x03, 0x23, 0x00, 0x6A, 0x04, 0xD2, 0xDA, 0x17,
+0x30, 0xF0, 0x20, 0x6A, 0x87, 0x40, 0x61, 0xF3,
+0x10, 0x4A, 0x19, 0x4C, 0x00, 0xF4, 0x00, 0x6D,
+0xA3, 0xF3, 0x88, 0xDA, 0xA3, 0xF3, 0x64, 0xDA,
+0xA3, 0xF3, 0x6E, 0xC2, 0xA3, 0xF3, 0x70, 0xC2,
+0xA3, 0xF3, 0x6F, 0xC2, 0xA3, 0xF3, 0x71, 0xC2,
+0xA3, 0xF3, 0x72, 0xC2, 0x00, 0x6C, 0xD0, 0x67,
+0xBD, 0xE0, 0x1A, 0x10, 0x03, 0x6C, 0x0E, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0x6B, 0xA3, 0xF3, 0x6C, 0xC2, 0x05, 0x6C,
+0x00, 0x6D, 0xD0, 0x67, 0x00, 0xF4, 0xE0, 0x40,
+0x0B, 0x10, 0x09, 0x6C, 0x00, 0x6D, 0x06, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0x6C, 0x04, 0xF7,
+0x5C, 0xC3, 0xA4, 0x67, 0xC5, 0x67, 0xE5, 0x67,
+0x00, 0x18, 0xCC, 0x3E, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6B, 0x6C, 0xEC, 0x0F, 0x6A, 0x8C, 0xEA,
+0x03, 0x2A, 0x92, 0x32, 0x6C, 0xEA, 0x20, 0xE8,
+0x07, 0x4A, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x08, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0x44, 0x32, 0xFF, 0x4A, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x70, 0x07,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x04, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0xFF, 0x4A, 0x44, 0x32, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x70, 0x07,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x08, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0x44, 0x32, 0xFF, 0x4A, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x8D, 0x07,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x04, 0x2A, 0x01, 0x6C, 0x04, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0xFF, 0x4A, 0x44, 0x32, 0x01, 0x6D,
+0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18, 0x8D, 0x07,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6D, 0x8C, 0xED,
+0x01, 0x6C, 0x44, 0x67, 0x15, 0x4D, 0x44, 0xED,
+0xA2, 0x67, 0x00, 0x18, 0x0C, 0x07, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6D, 0x8C, 0xED, 0x04, 0x2D, 0x03, 0x6C,
+0x10, 0xF0, 0x00, 0x6D, 0x05, 0x10, 0x1B, 0x4D,
+0x01, 0x6A, 0x44, 0xED, 0x03, 0x6C, 0xA2, 0x67,
+0x00, 0x18, 0x0C, 0x07, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x48, 0x3F,
+0x01, 0x6D, 0x02, 0x6C, 0xA4, 0xEA, 0x00, 0x18,
+0x0C, 0x07, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x48, 0x3F, 0x01, 0x6D, 0x03, 0x6C,
+0xA4, 0xEA, 0x00, 0x18, 0x0C, 0x07, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6D, 0x8C, 0xED, 0x01, 0x6C, 0x44, 0x67,
+0x15, 0x4D, 0x44, 0xED, 0xA2, 0x67, 0x00, 0x18,
+0x3D, 0x07, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6D, 0x8C, 0xED,
+0x04, 0x2D, 0x03, 0x6C, 0x10, 0xF0, 0x00, 0x6D,
+0x05, 0x10, 0x1B, 0x4D, 0x01, 0x6A, 0x44, 0xED,
+0x03, 0x6C, 0xA2, 0x67, 0x00, 0x18, 0x3D, 0x07,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x4C, 0xEC,
+0x00, 0x18, 0x48, 0x3F, 0x01, 0x6D, 0x02, 0x6C,
+0xA4, 0xEA, 0x00, 0x18, 0x3D, 0x07, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0xFF, 0x6A, 0x4C, 0xEC, 0x00, 0x18, 0x48, 0x3F,
+0x01, 0x6D, 0x03, 0x6C, 0xA4, 0xEA, 0x00, 0x18,
+0x3D, 0x07, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x42, 0xF6, 0x60, 0xA2, 0x01, 0x73, 0x07, 0x61,
+0x42, 0xF6, 0x41, 0xA2, 0x01, 0x72, 0x09, 0x60,
+0xAC, 0xF4, 0x00, 0x6A, 0x04, 0x10, 0x03, 0x73,
+0x04, 0x61, 0xA4, 0xF1, 0x00, 0x6A, 0x4B, 0xEA,
+0x02, 0x10, 0x61, 0xF2, 0x00, 0x6A, 0x40, 0xCC,
+0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF4, 0x62, 0xA2,
+0x09, 0x6A, 0x6C, 0xEA, 0x09, 0x72, 0x05, 0x61,
+0x60, 0xAC, 0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA,
+0x40, 0xCC, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5, 0x60, 0x9A,
+0xFF, 0x6C, 0x20, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x40, 0xA3,
+0x01, 0x6D, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xA4, 0xF1, 0x50, 0xA2,
+0x01, 0x72, 0x0C, 0x61, 0x01, 0x6C, 0x10, 0x6D,
+0x00, 0x18, 0x02, 0x2A, 0x04, 0x6B, 0x4D, 0xEB,
+0xFF, 0x6E, 0x01, 0x6C, 0x10, 0x6D, 0x6C, 0xEE,
+0x00, 0x18, 0xF5, 0x29, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0xA4, 0xF1, 0x50, 0xA2,
+0x01, 0x72, 0x0A, 0x61, 0x01, 0x6C, 0x10, 0x6D,
+0x00, 0x18, 0x02, 0x2A, 0xFB, 0x6E, 0x01, 0x6C,
+0x10, 0x6D, 0x4C, 0xEE, 0x00, 0x18, 0xF5, 0x29,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF1, 0xAC, 0x9A, 0xE0, 0xF3, 0x10, 0x6C,
+0x0F, 0x6E, 0x00, 0x18, 0xA0, 0x43, 0xE0, 0xF3,
+0x0C, 0x6C, 0x00, 0x18, 0x78, 0x43, 0xFF, 0x6B,
+0x4C, 0xEB, 0x0B, 0x73, 0x0B, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF1, 0x70, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0xE0, 0xF5, 0x8C, 0x9C, 0x40, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x69,
+0x2C, 0xED, 0x30, 0xF0, 0x20, 0x6B, 0x04, 0xD5,
+0x41, 0xF1, 0xAC, 0x9B, 0xFF, 0x6A, 0x40, 0x6E,
+0x60, 0xA5, 0xCB, 0xEE, 0x4C, 0xEC, 0x4C, 0xEB,
+0xCC, 0xEB, 0x6D, 0xEC, 0x4C, 0xEC, 0x80, 0xC5,
+0x0A, 0x6C, 0x00, 0x18, 0x4C, 0x2C, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x50, 0x9A, 0x00, 0xAA,
+0x04, 0x92, 0x2C, 0xE8, 0x2A, 0xEA, 0x08, 0x60,
+0x82, 0x67, 0x00, 0x18, 0x57, 0x2B, 0x04, 0x93,
+0x2C, 0xEA, 0x6C, 0xE8, 0x07, 0xEA, 0x2C, 0xE8,
+0x50, 0x67, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0xF7, 0x1F, 0x69,
+0x2C, 0xED, 0xFF, 0x68, 0x0C, 0xEC, 0x2C, 0xEE,
+0x2A, 0xED, 0x05, 0xD4, 0x04, 0xD5, 0x06, 0xD6,
+0x1F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF1,
+0x6C, 0x9A, 0x40, 0x6C, 0x8B, 0xEC, 0x40, 0xA3,
+0x0C, 0xEA, 0x8C, 0xEA, 0x05, 0x94, 0x8D, 0xEA,
+0x0C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x70, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x80, 0xF4, 0x9C, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF4, 0x94, 0x9C,
+0x8D, 0xEA, 0xCD, 0xEA, 0x40, 0xDB, 0x31, 0x10,
+0x05, 0x94, 0xB1, 0x67, 0x00, 0x18, 0xF9, 0x3F,
+0x04, 0x94, 0x07, 0xD2, 0x00, 0x18, 0x57, 0x2B,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1, 0x8C, 0x9B,
+0x40, 0x6D, 0xAB, 0xED, 0x60, 0xA4, 0x2C, 0xEA,
+0x0C, 0xEB, 0xAC, 0xEB, 0x05, 0x95, 0xAD, 0xEB,
+0x0C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF1, 0x90, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0x80, 0xF4, 0xBC, 0x9D, 0x60, 0x9C, 0x06, 0x96,
+0xAC, 0xEB, 0x30, 0xF0, 0x20, 0x6D, 0x80, 0xF4,
+0xB4, 0x9D, 0xC4, 0xEA, 0x46, 0x67, 0xAD, 0xEB,
+0x04, 0x95, 0x07, 0x96, 0xAC, 0xEA, 0xAF, 0xED,
+0xCC, 0xED, 0xAD, 0xEA, 0x2C, 0xEA, 0x4D, 0xEB,
+0x60, 0xDC, 0x0A, 0x6C, 0x00, 0x18, 0x4C, 0x2C,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF1, 0xB4, 0x9B, 0xFF, 0x6A, 0x08, 0x6E,
+0x60, 0xA5, 0xCB, 0xEE, 0x4C, 0xEC, 0x4C, 0xEB,
+0xCC, 0xEB, 0x6D, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x41, 0xF1, 0x78, 0x9B, 0x4C, 0xEC, 0x80, 0xC5,
+0x60, 0xA3, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x41, 0xF1, 0xD4, 0x9B,
+0xFF, 0x6A, 0x08, 0x6F, 0x60, 0xA6, 0xEB, 0xEF,
+0x4C, 0xEC, 0x4C, 0xEB, 0xEC, 0xEB, 0x6D, 0xEC,
+0x4C, 0xED, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0x41, 0xF1, 0x58, 0x9A, 0x80, 0xC6, 0xA0, 0xC2,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0x60, 0xF1,
+0x0D, 0x4A, 0x40, 0xDB, 0x00, 0x68, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF0, 0x54, 0x9A, 0x40, 0x9A,
+0x1E, 0x22, 0xE0, 0xF3, 0x09, 0x70, 0x13, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A,
+0x20, 0x6C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3,
+0x7C, 0xDA, 0x00, 0x6A, 0x09, 0x10, 0x32, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0x01, 0x48, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0xDC, 0x17, 0x01, 0x6A,
+0x05, 0x97, 0x04, 0x90, 0x03, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0, 0x40, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7, 0x70, 0x9B,
+0x40, 0x9A, 0x6C, 0xEA, 0x24, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x7C, 0x9A, 0xFF, 0x6C,
+0x07, 0x6D, 0x40, 0xA3, 0xAB, 0xED, 0x8C, 0xEA,
+0xAC, 0xEA, 0x04, 0x6D, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF1,
+0x84, 0x9C, 0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x61, 0xF1, 0x8C, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF1, 0x90, 0x9A, 0xFF, 0x6B,
+0x02, 0x6D, 0x40, 0xA4, 0x01, 0x68, 0x0B, 0xE8,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF5, 0x50, 0x9A,
+0x01, 0x6C, 0x8B, 0xEC, 0x80, 0xC2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF1, 0x54, 0x9A, 0x09, 0x6C,
+0x01, 0x6D, 0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF1, 0x58, 0x9A, 0x7A, 0x6C, 0x8B, 0xEC,
+0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF6,
+0x9C, 0x9A, 0xA1, 0xF0, 0x14, 0x69, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x85, 0x67, 0x00, 0x18, 0x4C, 0x2C, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x2B, 0x38, 0x41, 0x6E,
+0xCB, 0xEE, 0x91, 0x67, 0xB0, 0x67, 0x4C, 0xEE,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x69,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x49,
+0x61, 0xF1, 0x1C, 0x4A, 0x40, 0x9A, 0x03, 0xF4,
+0xEC, 0xA9, 0x00, 0x6C, 0xA4, 0x67, 0x4D, 0xEF,
+0xD0, 0x67, 0x00, 0x18, 0x11, 0x39, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF1, 0x1C, 0x4B, 0x60, 0x9B,
+0x03, 0xF4, 0xEE, 0xA9, 0xD0, 0x67, 0x01, 0xF4,
+0x00, 0x69, 0x6D, 0xEF, 0x01, 0x6C, 0x00, 0x6D,
+0x00, 0x18, 0x11, 0x39, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x2B, 0x38, 0x03, 0x6E, 0x91, 0x67,
+0xB0, 0x67, 0x4D, 0xEE, 0x00, 0xF2, 0x00, 0x49,
+0x00, 0x18, 0x39, 0x38, 0x91, 0x67, 0xB0, 0x67,
+0x00, 0x18, 0x2B, 0x38, 0x03, 0x6E, 0xB0, 0x67,
+0x91, 0x67, 0x4D, 0xEE, 0x00, 0x18, 0x39, 0x38,
+0x01, 0x6C, 0x00, 0x18, 0xDD, 0x43, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x01, 0x69, 0x2B, 0xE9, 0x00, 0x6C, 0x01, 0xF4,
+0x00, 0x68, 0x00, 0x18, 0xDD, 0x43, 0x00, 0x18,
+0x5B, 0x40, 0x90, 0x67, 0xB1, 0x67, 0x00, 0x18,
+0x2B, 0x38, 0x04, 0x6E, 0xCB, 0xEE, 0x90, 0x67,
+0x4C, 0xEE, 0x00, 0xF2, 0x00, 0x48, 0xB1, 0x67,
+0x00, 0x18, 0x39, 0x38, 0x90, 0x67, 0xB1, 0x67,
+0x00, 0x18, 0x2B, 0x38, 0x04, 0x6E, 0xCB, 0xEE,
+0x90, 0x67, 0x4C, 0xEE, 0xB1, 0x67, 0x00, 0x18,
+0x39, 0x38, 0x00, 0x6C, 0xA4, 0x67, 0xD1, 0x67,
+0x30, 0xF0, 0x20, 0x68, 0x00, 0x18, 0x02, 0x38,
+0x61, 0xF3, 0x10, 0x48, 0x03, 0xF4, 0x4C, 0xC8,
+0x01, 0x6C, 0x00, 0x6D, 0xD1, 0x67, 0x00, 0x18,
+0x02, 0x38, 0x00, 0x6C, 0x03, 0xF4, 0x4E, 0xC8,
+0xA4, 0x67, 0xE4, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x11, 0x39, 0x00, 0x6D, 0x01, 0x6C, 0xD1, 0x67,
+0xE5, 0x67, 0x00, 0x18, 0x11, 0x39, 0x00, 0x68,
+0x01, 0x69, 0x2B, 0xE9, 0x01, 0xF1, 0x08, 0x6C,
+0xB1, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0xE1, 0xF5, 0x14, 0x6C, 0xB1, 0x67, 0x00, 0x18,
+0x2B, 0x38, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF1,
+0x60, 0x9B, 0x4C, 0xEB, 0x20, 0x23, 0xE0, 0xF3,
+0x09, 0x70, 0x15, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF7, 0x9C, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x7C, 0xDA, 0x17, 0x10, 0x32, 0x6C,
+0x00, 0x18, 0x4C, 0x2C, 0x01, 0x48, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0xCD, 0x17, 0xE0, 0xF3,
+0x08, 0x58, 0x0C, 0x60, 0xA1, 0xF0, 0x14, 0x68,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x18, 0x2B, 0x38,
+0x40, 0x6E, 0x90, 0x67, 0xB1, 0x67, 0x4D, 0xEE,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF6, 0x7C, 0x9A, 0xFE, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x00, 0x18, 0x4D, 0x12,
+0x01, 0x72, 0x06, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF5, 0x50, 0x9A, 0x3F, 0x6B, 0x60, 0xC2,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1, 0x70, 0x9A,
+0xFD, 0x6A, 0xFF, 0x6C, 0xA0, 0xA3, 0xAC, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x40, 0x9A, 0x30, 0xF0, 0x20, 0x6B, 0x20, 0xF7,
+0x70, 0x9B, 0x40, 0x9A, 0x6C, 0xEA, 0x20, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1, 0x68, 0x9A,
+0x30, 0xF0, 0x20, 0x6D, 0xA0, 0xF4, 0xBC, 0x9D,
+0x40, 0x9B, 0xAD, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x41, 0xF1, 0x7C, 0x9A, 0x06, 0x6D,
+0x40, 0xA3, 0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF1,
+0x60, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0x21, 0xF1,
+0x84, 0x9C, 0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6B, 0xAC, 0xEB, 0x00, 0x6D,
+0x45, 0x67, 0x29, 0x10, 0x01, 0x6E, 0x6C, 0xEE,
+0x0E, 0x26, 0xCF, 0x43, 0xAE, 0xEE, 0x0B, 0x2E,
+0x30, 0xF0, 0x20, 0x6E, 0x60, 0xF5, 0xD8, 0x9E,
+0xD9, 0xE4, 0xB9, 0xE6, 0xE0, 0xA6, 0xFF, 0x6E,
+0xEC, 0xEE, 0xC0, 0x36, 0x13, 0x10, 0x30, 0xF0,
+0x20, 0x6E, 0x60, 0xF5, 0xD8, 0x9E, 0x30, 0xF0,
+0x20, 0x68, 0x80, 0xF5, 0x04, 0x98, 0xD9, 0xE4,
+0xB9, 0xE6, 0x01, 0xE4, 0xC0, 0xA6, 0xA1, 0xE0,
+0x00, 0xA0, 0xFF, 0x6F, 0xEC, 0xEE, 0xC0, 0x36,
+0x0C, 0xEF, 0xF9, 0xE6, 0xC9, 0xE2, 0x02, 0x4D,
+0xFF, 0xF7, 0x1F, 0x6E, 0xCC, 0xED, 0x63, 0xED,
+0xD5, 0x61, 0x01, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0xD1, 0x04, 0xD0, 0xFF, 0x6B,
+0x8C, 0xEB, 0x06, 0x73, 0xFF, 0xF7, 0x1F, 0x6C,
+0xAC, 0xEC, 0x03, 0x60, 0x11, 0x73, 0x0A, 0x92,
+0x4D, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x18, 0x4A, 0x40, 0x9A, 0x6D, 0xE4, 0x41, 0xE6,
+0xA0, 0xA0, 0xFF, 0x6A, 0x02, 0x48, 0x1D, 0x65,
+0x38, 0x67, 0x4C, 0xE9, 0x02, 0xD1, 0x30, 0xF0,
+0x20, 0x69, 0x80, 0xF5, 0x24, 0x99, 0xBD, 0x67,
+0x39, 0xE6, 0x19, 0x65, 0x20, 0xA6, 0x02, 0x4E,
+0x20, 0xC5, 0x20, 0xA5, 0x02, 0x95, 0x4C, 0xE9,
+0xA0, 0x35, 0x25, 0xE5, 0x0A, 0x95, 0xB5, 0xE1,
+0x00, 0xD5, 0x00, 0xA0, 0x20, 0xA6, 0x30, 0xF0,
+0x20, 0x6E, 0x60, 0xF5, 0x18, 0x4E, 0x4C, 0xE8,
+0xC0, 0x9E, 0x4C, 0xE9, 0x00, 0x30, 0x21, 0xE0,
+0x01, 0xE5, 0xD5, 0xE7, 0xD8, 0x67, 0x20, 0xA5,
+0xD5, 0xE7, 0xA0, 0xA5, 0x4C, 0xE9, 0x20, 0x31,
+0x4C, 0xED, 0xB5, 0xE1, 0xA5, 0xE0, 0x30, 0xF0,
+0x20, 0x6D, 0x20, 0xF6, 0xA4, 0x9D, 0x30, 0xF0,
+0x20, 0x6E, 0x81, 0xF1, 0xC4, 0x9E, 0xB5, 0xE7,
+0xA0, 0xA5, 0xDD, 0xE7, 0xC0, 0xA7, 0x4C, 0xED,
+0xA0, 0x35, 0xCC, 0xEA, 0x49, 0xE5, 0x49, 0xE1,
+0x49, 0xE3, 0x04, 0x10, 0xFF, 0xF7, 0x1F, 0x6B,
+0x4C, 0xEB, 0x69, 0xE4, 0x42, 0x34, 0x82, 0x34,
+0xF9, 0x2C, 0x05, 0x91, 0x04, 0x90, 0xFF, 0xF7,
+0x1F, 0x6D, 0x4F, 0xEA, 0xAC, 0xEA, 0x03, 0x63,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEC, 0xAC, 0xEA, 0x30, 0xF0, 0x20, 0x6D,
+0x61, 0xF3, 0x10, 0x4D, 0x44, 0xF2, 0x44, 0xCD,
+0x04, 0x92, 0xFF, 0x6B, 0x6C, 0xEE, 0xEC, 0xEB,
+0x44, 0xF2, 0x82, 0xCD, 0x44, 0xF2, 0xC6, 0xC5,
+0x44, 0xF2, 0x67, 0xC5, 0x44, 0xF2, 0x52, 0xCD,
+0x20, 0xE8, 0x00, 0x65, 0xFF, 0x63, 0x01, 0xD0,
+0x7D, 0x67, 0xFF, 0xF7, 0x1F, 0x6A, 0x18, 0xA3,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x4C, 0xEC, 0x4C, 0xED, 0x4C, 0xEE, 0x44, 0xF2,
+0x8A, 0xCB, 0xEC, 0xEA, 0x44, 0xF2, 0x88, 0xA3,
+0x44, 0xF2, 0x50, 0xCB, 0x01, 0x6A, 0x4C, 0xE8,
+0xFD, 0x4A, 0x8C, 0xEA, 0x0D, 0xEA, 0x44, 0xF2,
+0xAC, 0xCB, 0x44, 0xF2, 0xCE, 0xCB, 0x44, 0xF2,
+0x48, 0xC3, 0x01, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF5, 0x70, 0x9B,
+0xFF, 0x6A, 0xAC, 0xEA, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0x9C, 0x60, 0xF5, 0x54, 0x9A,
+0x60, 0xDA, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF5, 0x70, 0x9B, 0xFF, 0x6A, 0xAC, 0xEA,
+0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x54, 0x9A, 0x40, 0x9A, 0x40, 0xDC, 0x20, 0xE8,
+0xE9, 0xA4, 0xFF, 0xF7, 0x1F, 0x6A, 0xAC, 0xEA,
+0x02, 0x6D, 0xFF, 0x6B, 0xEC, 0xED, 0x6C, 0xED,
+0x6C, 0xEE, 0x05, 0x25, 0x00, 0x6A, 0x41, 0xC4,
+0x42, 0xC4, 0x45, 0xC4, 0x06, 0x10, 0x41, 0xC4,
+0x42, 0x32, 0x42, 0xC4, 0x46, 0xAC, 0x45, 0xC4,
+0x42, 0x32, 0x46, 0xC4, 0x4F, 0xA4, 0xC0, 0xC4,
+0x44, 0xC4, 0x5E, 0xA4, 0x47, 0xC4, 0x20, 0xE8,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x10, 0x6D,
+0x04, 0x67, 0x00, 0x18, 0xA0, 0x41, 0x84, 0x40,
+0x11, 0x6D, 0x00, 0x18, 0xA0, 0x41, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x69, 0xA4, 0x01, 0x6A,
+0x6C, 0xEA, 0x02, 0x22, 0x00, 0x18, 0xBC, 0x41,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0xFF, 0xF7, 0x1F, 0x6A,
+0x8C, 0xEA, 0x09, 0x6D, 0x04, 0x04, 0x04, 0xD2,
+0x00, 0x18, 0xA0, 0x41, 0x07, 0x97, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x08, 0x6D,
+0x04, 0x04, 0x04, 0xD2, 0x00, 0x18, 0xA0, 0x41,
+0x07, 0x97, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0xFF, 0x6A, 0x4C, 0xED, 0xAA, 0x33, 0x4C, 0xEB,
+0x03, 0x6A, 0xAC, 0xEA, 0x0E, 0xD4, 0x06, 0xD3,
+0x07, 0xD2, 0x08, 0xD4, 0x00, 0x69, 0x0C, 0x10,
+0xA7, 0x41, 0x08, 0x94, 0xFF, 0x68, 0x19, 0x4D,
+0x0C, 0xED, 0x00, 0x18, 0xA7, 0x41, 0x08, 0x93,
+0x01, 0x49, 0x0C, 0xE9, 0x04, 0x4B, 0x08, 0xD3,
+0x06, 0x92, 0x43, 0xE9, 0xF1, 0x61, 0x07, 0x93,
+0x17, 0x23, 0xA2, 0x67, 0x04, 0x00, 0x90, 0x67,
+0x20, 0x4D, 0x00, 0x18, 0xA7, 0x41, 0x06, 0x92,
+0xFF, 0x6C, 0x48, 0x33, 0x0E, 0x92, 0x6D, 0xE2,
+0x07, 0x92, 0xFF, 0x4A, 0x8C, 0xEA, 0x00, 0xF0,
+0x11, 0x04, 0x49, 0xE4, 0x80, 0xA0, 0x01, 0x48,
+0x4A, 0xE8, 0x80, 0xC3, 0x01, 0x4B, 0xFA, 0x61,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x4C, 0xED,
+0x07, 0x6B, 0xAC, 0xEB, 0x2A, 0x2B, 0x38, 0x5D,
+0x28, 0x60, 0xAE, 0x35, 0xFF, 0x4D, 0x4C, 0xED,
+0xA6, 0x33, 0xAC, 0x35, 0x4C, 0xEB, 0xB5, 0xE4,
+0x08, 0xD3, 0x07, 0xD5, 0x06, 0xD4, 0x00, 0x69,
+0x16, 0x10, 0x07, 0x95, 0x04, 0x00, 0x90, 0x67,
+0x08, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0x07, 0x94,
+0x06, 0x95, 0x08, 0x6E, 0x01, 0x49, 0x00, 0x18,
+0x70, 0x2C, 0x06, 0x94, 0xB0, 0x67, 0x08, 0x6E,
+0x00, 0x18, 0x70, 0x2C, 0xFF, 0x6A, 0x4C, 0xE9,
+0x07, 0x92, 0xF8, 0x4A, 0x07, 0xD2, 0x06, 0x93,
+0x08, 0x92, 0x08, 0x4B, 0x43, 0xE9, 0x06, 0xD3,
+0xE4, 0x61, 0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90,
+0x07, 0x63, 0x00, 0xEF, 0xF9, 0x63, 0x0D, 0x62,
+0x0C, 0xD1, 0x0B, 0xD0, 0xFF, 0x6A, 0x4C, 0xED,
+0xAA, 0x33, 0x4C, 0xEB, 0x03, 0x6A, 0xAC, 0xEA,
+0x0E, 0xD4, 0x06, 0xD3, 0x07, 0xD2, 0x08, 0xD4,
+0x00, 0x69, 0x0C, 0x10, 0xA7, 0x41, 0x08, 0x94,
+0xFF, 0x68, 0x19, 0x4D, 0x0C, 0xED, 0x00, 0x18,
+0xA0, 0x41, 0x08, 0x93, 0x01, 0x49, 0x0C, 0xE9,
+0x04, 0x4B, 0x08, 0xD3, 0x06, 0x92, 0x43, 0xE9,
+0xF1, 0x61, 0x07, 0x93, 0x1C, 0x23, 0x04, 0x00,
+0x90, 0x67, 0x00, 0x6D, 0x04, 0x6E, 0x00, 0x18,
+0x6B, 0x2C, 0x06, 0x92, 0xFF, 0x6C, 0x48, 0x33,
+0x0E, 0x92, 0x6D, 0xE2, 0x07, 0x92, 0xFF, 0x4A,
+0x8C, 0xEA, 0x00, 0xF0, 0x11, 0x04, 0x49, 0xE4,
+0x80, 0xA3, 0x01, 0x4B, 0x80, 0xC0, 0x01, 0x48,
+0x4A, 0xE8, 0xFA, 0x61, 0x06, 0x95, 0x04, 0x04,
+0x20, 0x4D, 0x00, 0x18, 0xA0, 0x41, 0x0D, 0x97,
+0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x69, 0x04, 0x67, 0x2C, 0xE8, 0x07, 0x04,
+0xAC, 0xE9, 0x04, 0x6E, 0x00, 0x6D, 0x00, 0x18,
+0x6B, 0x2C, 0x5D, 0x67, 0x1C, 0xC2, 0x7D, 0x67,
+0x01, 0x6A, 0x01, 0x71, 0x5D, 0xC3, 0x06, 0x61,
+0x7F, 0xA3, 0x80, 0x6A, 0x4B, 0xEA, 0x6D, 0xEA,
+0x9D, 0x67, 0x5F, 0xC4, 0x07, 0x04, 0x00, 0x6D,
+0x00, 0x18, 0xA0, 0x41, 0x06, 0x02, 0x80, 0xF1,
+0x07, 0x6C, 0x80, 0x6D, 0x00, 0x6E, 0x04, 0xF7,
+0x10, 0x6F, 0x04, 0xD2, 0x00, 0x18, 0xC2, 0x2B,
+0x03, 0x22, 0x5D, 0x67, 0x6C, 0xAA, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF5, 0x6C, 0x9A,
+0xFF, 0x6C, 0x04, 0x6D, 0x40, 0xA3, 0x8C, 0xEA,
+0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3, 0x9D, 0x67,
+0x6C, 0xAC, 0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1,
+0x48, 0x9A, 0x60, 0xCA, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF8, 0x63, 0x0F, 0x62, 0x0E, 0xD1, 0x0D, 0xD0,
+0x24, 0x67, 0x11, 0xD5, 0xA7, 0x41, 0x04, 0x04,
+0x02, 0x4D, 0x06, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x70, 0x2C, 0x5D, 0x67, 0x90, 0xA2, 0x00, 0x6D,
+0x00, 0x18, 0x34, 0x42, 0x68, 0xA1, 0x01, 0x6A,
+0x6C, 0xEA, 0x22, 0x22, 0x69, 0xA1, 0x02, 0x6A,
+0x6C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x04, 0x22,
+0xAF, 0xA1, 0x90, 0x67, 0x00, 0x18, 0x13, 0x42,
+0x63, 0xA1, 0x80, 0x6A, 0x4B, 0xEA, 0x6D, 0xEA,
+0x41, 0x6B, 0x6B, 0xEB, 0x6C, 0xEA, 0x00, 0x6D,
+0xC5, 0x67, 0x43, 0xC1, 0x91, 0x67, 0x00, 0x18,
+0xAE, 0x41, 0x91, 0x67, 0x00, 0x18, 0xC4, 0x41,
+0x8D, 0xA9, 0x00, 0x18, 0xD1, 0x41, 0x7D, 0x67,
+0x90, 0xA3, 0x01, 0x6D, 0x00, 0x18, 0x34, 0x42,
+0x68, 0xA1, 0x02, 0x6A, 0x6C, 0xEA, 0x6A, 0x22,
+0x63, 0xA1, 0x7F, 0x6A, 0x6C, 0xEA, 0x43, 0xC1,
+0x4E, 0xA1, 0x5A, 0x32, 0x01, 0x4A, 0x0B, 0xD2,
+0x0B, 0x93, 0xFF, 0x6A, 0x4C, 0xEB, 0x11, 0x92,
+0x0B, 0xD3, 0x00, 0x6B, 0x07, 0xD2, 0x06, 0xD3,
+0x08, 0xD3, 0x0A, 0xD3, 0x0B, 0x92, 0x0A, 0x93,
+0xFF, 0x4A, 0x6E, 0xEA, 0x16, 0x2A, 0x68, 0xA1,
+0x10, 0x6A, 0x6C, 0xEA, 0x04, 0x22, 0x63, 0xA1,
+0x40, 0x6A, 0x6D, 0xEA, 0x04, 0x10, 0x63, 0xA1,
+0x41, 0x6A, 0x4B, 0xEA, 0x6C, 0xEA, 0x43, 0xC1,
+0x06, 0x93, 0x4E, 0xA1, 0x49, 0xE3, 0x09, 0xD2,
+0x09, 0x93, 0xFF, 0x6A, 0x4C, 0xEB, 0x09, 0xD3,
+0x07, 0x10, 0x63, 0xA1, 0x41, 0x6A, 0x4B, 0xEA,
+0x6C, 0xEA, 0x43, 0xC1, 0x40, 0x6A, 0x09, 0xD2,
+0x68, 0xA1, 0x04, 0x6A, 0x6C, 0xEA, 0x0A, 0x2A,
+0x69, 0xA1, 0x02, 0x6A, 0x6C, 0xEA, 0xFF, 0x6B,
+0x6C, 0xEA, 0x04, 0x22, 0x07, 0x94, 0x09, 0x95,
+0x00, 0x18, 0x13, 0x42, 0x08, 0x93, 0xA5, 0xA9,
+0x09, 0x96, 0xFF, 0xF7, 0x1F, 0x68, 0xB5, 0xE3,
+0x0C, 0xED, 0x91, 0x67, 0x00, 0x18, 0xAE, 0x41,
+0x91, 0x67, 0x00, 0x18, 0xC4, 0x41, 0x5D, 0x67,
+0x90, 0xA2, 0x01, 0x6D, 0x00, 0x18, 0x34, 0x42,
+0x08, 0x92, 0x0A, 0x93, 0x40, 0x4A, 0x0C, 0xEA,
+0x01, 0x4B, 0x08, 0xD2, 0x06, 0x92, 0x0A, 0xD3,
+0x07, 0x93, 0xC0, 0x4A, 0x06, 0xD2, 0x40, 0x4B,
+0x07, 0xD3, 0x06, 0x93, 0xFF, 0x6A, 0x4C, 0xEB,
+0x06, 0xD3, 0x0A, 0x93, 0x6C, 0xEA, 0x0B, 0x93,
+0x63, 0xEA, 0xA8, 0x61, 0x0F, 0x97, 0x0E, 0x91,
+0x0D, 0x90, 0x08, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF3, 0x63, 0x19, 0x62, 0x18, 0xD1, 0x17, 0xD0,
+0xFF, 0x6A, 0x04, 0x01, 0xEC, 0xEA, 0x1A, 0xD4,
+0x1B, 0xD5, 0x91, 0x67, 0x1C, 0xD6, 0x00, 0x6D,
+0x40, 0x6E, 0x30, 0xF0, 0x20, 0x68, 0xA5, 0xF5,
+0x10, 0x48, 0x14, 0xD2, 0x00, 0x18, 0x6B, 0x2C,
+0x01, 0x6D, 0xC5, 0x67, 0x90, 0x67, 0x00, 0x18,
+0x6B, 0x2C, 0x81, 0x40, 0x03, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x08, 0x6B, 0x44, 0xF2,
+0x76, 0xC2, 0x44, 0xF2, 0x66, 0xA2, 0x1A, 0x96,
+0x30, 0xF0, 0x20, 0x6C, 0x15, 0xD3, 0x40, 0x6B,
+0xB1, 0x67, 0x44, 0xF2, 0x66, 0xC2, 0xA5, 0xF5,
+0x08, 0x4C, 0x00, 0x18, 0x56, 0x42, 0x00, 0x69,
+0x30, 0xF0, 0x20, 0x68, 0xA5, 0xF5, 0x10, 0x48,
+0x90, 0x67, 0x06, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x6B, 0x2C, 0x81, 0x40, 0x03, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x1A, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0xA5, 0xF5, 0x08, 0x4C, 0x04, 0x05,
+0x00, 0x18, 0x56, 0x42, 0x01, 0x49, 0xFF, 0x6A,
+0x4C, 0xE9, 0x04, 0x71, 0xE5, 0x61, 0x90, 0x67,
+0x12, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x9D, 0x67, 0x67, 0x44, 0x4D, 0x4B, 0x80, 0xA3,
+0x30, 0xF0, 0x20, 0x6A, 0x1B, 0x95, 0x1A, 0x96,
+0xA5, 0xF5, 0x96, 0xC2, 0x30, 0xF0, 0x20, 0x6C,
+0xA5, 0xF5, 0x08, 0x4C, 0x00, 0x18, 0x56, 0x42,
+0x1C, 0x94, 0x14, 0x95, 0x00, 0x18, 0xD8, 0x41,
+0x19, 0x97, 0x18, 0x91, 0x17, 0x90, 0x0D, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0x61, 0xF3, 0x10, 0x48, 0x0C, 0xD4, 0x44, 0xF2,
+0x82, 0xA8, 0x44, 0xF2, 0x66, 0xA0, 0x30, 0xF0,
+0x20, 0x69, 0xA5, 0xF5, 0x10, 0x49, 0xFF, 0x6A,
+0xEC, 0xEA, 0x0D, 0xD5, 0x0E, 0xD6, 0x05, 0xD4,
+0x03, 0x6D, 0x91, 0x67, 0x01, 0x6E, 0x06, 0xD3,
+0x07, 0xD2, 0x00, 0x18, 0x6B, 0x2C, 0x01, 0x6D,
+0x30, 0xF0, 0x20, 0x6C, 0xC5, 0x67, 0xA5, 0xF5,
+0x11, 0x4C, 0x00, 0x18, 0x6B, 0x2C, 0x02, 0x6A,
+0x05, 0x93, 0x44, 0xF2, 0x56, 0xC0, 0x44, 0xF2,
+0x4A, 0xA8, 0x0D, 0x95, 0x0C, 0x96, 0x49, 0xE3,
+0x44, 0xF2, 0x42, 0xC8, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF5, 0x08, 0x4A, 0x06, 0x6C, 0x44, 0xF2,
+0x86, 0xC0, 0x82, 0x67, 0x04, 0xD2, 0x00, 0x18,
+0x56, 0x42, 0x91, 0x67, 0x02, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x05, 0x93, 0x44, 0xF2,
+0x4C, 0xA8, 0x06, 0x6C, 0x44, 0xF2, 0x86, 0xC0,
+0x0D, 0x95, 0x04, 0x94, 0x0C, 0x96, 0x49, 0xE3,
+0x44, 0xF2, 0x42, 0xC8, 0x00, 0x18, 0x56, 0x42,
+0x44, 0xF2, 0x68, 0xA0, 0x01, 0x6A, 0x6C, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x13, 0x22, 0x91, 0x67,
+0x02, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x6B, 0x2C,
+0x05, 0x94, 0x44, 0xF2, 0x4E, 0xA8, 0x0D, 0x95,
+0x0C, 0x96, 0x49, 0xE4, 0x04, 0x94, 0x44, 0xF2,
+0x42, 0xC8, 0x04, 0x6A, 0x44, 0xF2, 0x46, 0xC0,
+0x00, 0x18, 0x56, 0x42, 0x30, 0xF0, 0x20, 0x6C,
+0xA5, 0xF5, 0x10, 0x4C, 0x12, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x44, 0xF2, 0x70, 0xAA,
+0x05, 0x94, 0x0D, 0x95, 0x0C, 0x96, 0x6D, 0xE4,
+0x44, 0xF2, 0x62, 0xCA, 0x7D, 0x67, 0x87, 0x43,
+0x11, 0x4C, 0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6C,
+0xA5, 0xF5, 0x08, 0x4C, 0x44, 0xF2, 0x66, 0xC2,
+0x00, 0x18, 0x56, 0x42, 0x0E, 0x94, 0x07, 0x95,
+0x00, 0x18, 0xD8, 0x41, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0xA5, 0xF5, 0x10, 0x48,
+0x08, 0xD4, 0x09, 0xD5, 0x0A, 0xD6, 0x90, 0x67,
+0x13, 0x6D, 0x01, 0x6E, 0xFF, 0x69, 0xEC, 0xE9,
+0x00, 0x18, 0x6B, 0x2C, 0x01, 0x6D, 0x81, 0x40,
+0xC5, 0x67, 0x00, 0x18, 0x6B, 0x2C, 0x09, 0x95,
+0x08, 0x96, 0x30, 0xF0, 0x20, 0x6C, 0x11, 0x6B,
+0x30, 0xF0, 0x20, 0x6A, 0xA5, 0xF5, 0x08, 0x4C,
+0xC5, 0xF5, 0x66, 0xC2, 0x00, 0x18, 0x56, 0x42,
+0x0A, 0x94, 0xB1, 0x67, 0x00, 0x18, 0xD8, 0x41,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0xA5, 0xF5, 0x10, 0x48, 0x08, 0xD4, 0x09, 0xD5,
+0x0A, 0xD6, 0x90, 0x67, 0x13, 0x6D, 0x01, 0x6E,
+0xFF, 0x69, 0xEC, 0xE9, 0x00, 0x18, 0x6B, 0x2C,
+0x01, 0x6D, 0x81, 0x40, 0xC5, 0x67, 0x00, 0x18,
+0x6B, 0x2C, 0x09, 0x95, 0x08, 0x96, 0x30, 0xF0,
+0x20, 0x6C, 0x10, 0x6B, 0x30, 0xF0, 0x20, 0x6A,
+0xA5, 0xF5, 0x08, 0x4C, 0xC5, 0xF5, 0x66, 0xC2,
+0x00, 0x18, 0x56, 0x42, 0x0A, 0x94, 0xB1, 0x67,
+0x00, 0x18, 0xD8, 0x41, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x30, 0xF0, 0x20, 0x68, 0x61, 0xF3, 0x10, 0x48,
+0x08, 0xD4, 0x09, 0xD5, 0x85, 0x67, 0x44, 0xF2,
+0xA6, 0xA0, 0xFF, 0x69, 0xEC, 0xE9, 0x0A, 0xD6,
+0x00, 0x18, 0xF7, 0x41, 0x30, 0xF0, 0x20, 0x6C,
+0xA5, 0xF5, 0x10, 0x4C, 0x13, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x30, 0xF0, 0x20, 0x6C,
+0xA5, 0xF5, 0x11, 0x4C, 0x03, 0x6D, 0x01, 0x6E,
+0x00, 0x18, 0x6B, 0x2C, 0x08, 0x96, 0x09, 0x95,
+0x30, 0xF0, 0x20, 0x6C, 0x2B, 0x6A, 0xA5, 0xF5,
+0x08, 0x4C, 0x44, 0xF2, 0x56, 0xC0, 0x00, 0x18,
+0x56, 0x42, 0x0A, 0x94, 0xB1, 0x67, 0x00, 0x18,
+0xD8, 0x41, 0x44, 0xF2, 0xA6, 0xA0, 0x0A, 0x94,
+0x00, 0x18, 0xF7, 0x41, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x8C, 0xEA, 0x03, 0x6B, 0x4C, 0xEB,
+0x2D, 0x2B, 0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF1,
+0x70, 0x9B, 0x64, 0x68, 0x40, 0xC3, 0x30, 0xF0,
+0x20, 0x6A, 0xC1, 0xF1, 0x54, 0x9A, 0x30, 0x6B,
+0x60, 0xC2, 0x23, 0x10, 0x0A, 0x6C, 0x00, 0x18,
+0x4C, 0x2C, 0xFF, 0x48, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE8, 0x1B, 0x28, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x20, 0xF7, 0x90, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x7C, 0xDA, 0x60, 0xA1, 0xCF, 0x6A,
+0x6C, 0xEA, 0x40, 0xC1, 0x01, 0x6A, 0x4B, 0xEA,
+0x11, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x34, 0x9A, 0x20, 0x6A, 0x60, 0xA1, 0x6C, 0xEA,
+0xD5, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x58, 0x9A, 0xEF, 0x6B, 0x40, 0x9A, 0x80, 0xA1,
+0x8C, 0xEB, 0x60, 0xC1, 0x07, 0x97, 0x06, 0x91,
+0x05, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0xFF, 0x6A, 0x4C, 0xEC, 0x03, 0x6B, 0x8C, 0xEB,
+0x4C, 0xEE, 0x69, 0x2B, 0x30, 0xF0, 0x20, 0x6B,
+0xC1, 0xF1, 0x70, 0x9B, 0x80, 0xC3, 0x0F, 0x6B,
+0xCC, 0xEB, 0x61, 0x23, 0x01, 0x6C, 0x6C, 0xEC,
+0x06, 0x24, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF1,
+0x98, 0x9C, 0xAC, 0xEA, 0x40, 0xC4, 0x02, 0x6A,
+0x6C, 0xEA, 0x08, 0x22, 0xFF, 0x6C, 0xA2, 0x32,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0xC1, 0xF1,
+0x9C, 0x9C, 0x40, 0xC4, 0x04, 0x6A, 0x6C, 0xEA,
+0x09, 0x22, 0xA2, 0x32, 0xFF, 0x6C, 0x42, 0x32,
+0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF1,
+0x80, 0x9C, 0x40, 0xC4, 0x6E, 0x32, 0x07, 0x22,
+0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1, 0x44, 0x9A,
+0x00, 0xF6, 0xA2, 0x35, 0xA0, 0xC2, 0x20, 0x6A,
+0x6D, 0xEA, 0x30, 0xF0, 0x20, 0x6B, 0xC1, 0xF1,
+0x74, 0x9B, 0x64, 0x68, 0x40, 0xC3, 0x21, 0x10,
+0x0A, 0x6C, 0x00, 0x18, 0x4C, 0x2C, 0xFF, 0x48,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8, 0x19, 0x28,
+0x30, 0xF0, 0x20, 0x6A, 0x40, 0xF6, 0x74, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x20, 0xF7, 0x90, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x83, 0xF3,
+0x7C, 0x9A, 0x8D, 0xEB, 0x83, 0xF3, 0x7C, 0xDA,
+0x60, 0xA1, 0xD0, 0x6A, 0x6C, 0xEA, 0x40, 0xC1,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF1,
+0x34, 0x9A, 0x20, 0x6A, 0x60, 0xA1, 0x6C, 0xEA,
+0xD7, 0x2A, 0x60, 0xA1, 0xF0, 0x6A, 0x6C, 0xEA,
+0x40, 0xC1, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0x01, 0x74, 0x1C, 0x60,
+0x05, 0x24, 0x02, 0x74, 0x0E, 0x60, 0x03, 0x74,
+0x27, 0x60, 0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x81, 0xF1, 0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xE1, 0xF1, 0x88, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1,
+0x7C, 0x9A, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF6,
+0x80, 0x9C, 0x40, 0x9B, 0x8C, 0xEA, 0x1A, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF1, 0x7C, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF1, 0x88, 0x9C,
+0x40, 0x9B, 0x8C, 0xEA, 0x30, 0xF0, 0x20, 0x6C,
+0x80, 0xF6, 0x84, 0x9C, 0x8D, 0xEA, 0x40, 0xDB,
+0x30, 0xF0, 0x20, 0x6A, 0xA1, 0xF1, 0x7C, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF6, 0x9C, 0x9C,
+0x40, 0x9B, 0x8D, 0xEA, 0x40, 0xDB, 0x20, 0xE8,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x30, 0xF0,
+0x20, 0x6C, 0xE1, 0xF1, 0x8C, 0x9C, 0xFF, 0x6B,
+0xC2, 0x67, 0x6C, 0xEE, 0xC0, 0xC4, 0x30, 0xF0,
+0x20, 0x6C, 0xE1, 0xF1, 0xD0, 0x9C, 0x03, 0x6F,
+0x42, 0x32, 0x80, 0xA6, 0xEC, 0xEA, 0xF9, 0x4F,
+0x6C, 0xEC, 0xEC, 0xEC, 0x8D, 0xEA, 0x6C, 0xEA,
+0x40, 0xC6, 0x30, 0xF0, 0x20, 0x6A, 0xE1, 0xF1,
+0x74, 0x9A, 0x7F, 0x6A, 0x80, 0xA3, 0x8C, 0xEA,
+0x40, 0xC3, 0x00, 0x6A, 0x03, 0x10, 0x01, 0x4A,
+0xFF, 0x6B, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0xE1, 0xF1, 0x74, 0x9B, 0x60, 0xA3, 0x00, 0xF6,
+0x60, 0x33, 0x00, 0xF6, 0x63, 0x33, 0x00, 0x53,
+0x03, 0x61, 0x64, 0x72, 0xF0, 0x61, 0x0A, 0x10,
+0x64, 0x5A, 0x08, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF1, 0x58, 0x9A, 0x40, 0xA2, 0x40, 0xC5,
+0x01, 0x6A, 0x20, 0xE8, 0x01, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0xA4, 0xF5, 0x78, 0xC2, 0x00, 0x6A,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF2, 0x60, 0x9B, 0xFF, 0x6A, 0x8C, 0xEA,
+0x60, 0x9B, 0x80, 0xF1, 0x01, 0x6C, 0x8B, 0xEC,
+0x8C, 0xEB, 0x30, 0xF0, 0x20, 0x6C, 0xA0, 0xF6,
+0x9C, 0x9C, 0x01, 0x72, 0x80, 0x9C, 0x05, 0x60,
+0x02, 0x72, 0x05, 0x61, 0xFF, 0x6A, 0x01, 0x4A,
+0x01, 0x10, 0x80, 0x6A, 0x4D, 0xEB, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x40, 0x9A, 0x60, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2, 0x44, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0xA0, 0xF6, 0x7C, 0x9B,
+0x8C, 0xEA, 0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x01, 0xF2, 0x68, 0x9B, 0x50, 0x6A, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF2, 0x6C, 0x9B,
+0x40, 0xC3, 0x20, 0xE8, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x6A, 0x4C, 0xED, 0x04, 0x67,
+0x01, 0x75, 0x86, 0x67, 0x4C, 0xE8, 0x4C, 0xEC,
+0x03, 0x60, 0x03, 0x75, 0x0A, 0x6B, 0x01, 0x61,
+0x09, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2,
+0x50, 0x9A, 0x0F, 0x6F, 0xAC, 0xEF, 0x70, 0x33,
+0xED, 0xEB, 0x60, 0xC2, 0x00, 0x18, 0x1D, 0x44,
+0x30, 0xF0, 0x20, 0x6A, 0x81, 0xF0, 0x4C, 0x9A,
+0x24, 0x58, 0x60, 0xA2, 0x7F, 0x6A, 0x6C, 0xEA,
+0x05, 0x61, 0x80, 0x6B, 0x6B, 0xEB, 0x6D, 0xEA,
+0xFF, 0x6B, 0x6C, 0xEA, 0x30, 0xF0, 0x20, 0x6B,
+0x81, 0xF0, 0x6C, 0x9B, 0x40, 0xC3, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF5, 0x48, 0x9A,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x80, 0xA2, 0xFF, 0xF7, 0x1F, 0x6E, 0x26, 0xF5,
+0x98, 0xC3, 0x30, 0xF0, 0x20, 0x6C, 0x01, 0xF2,
+0x94, 0x9C, 0xA0, 0xAC, 0x26, 0xF5, 0xBA, 0xCB,
+0xA0, 0xA2, 0xBF, 0x6B, 0xAC, 0xEB, 0x60, 0xC2,
+0xE0, 0xA2, 0x7F, 0x6D, 0xFF, 0x6B, 0xEC, 0xED,
+0xA0, 0xC2, 0xA0, 0xA2, 0xAC, 0xEB, 0x60, 0xC2,
+0x40, 0xAC, 0xFF, 0x6B, 0x21, 0x4B, 0xCC, 0xEA,
+0x6D, 0xEA, 0xCC, 0xEA, 0x40, 0xCC, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x30, 0xF0, 0x20, 0x6B, 0x26, 0xF5, 0x98, 0xA2,
+0xE0, 0xF5, 0x68, 0x9B, 0x80, 0xC3, 0x26, 0xF5,
+0x7A, 0xAA, 0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF2,
+0x54, 0x9A, 0x60, 0xCA, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0x9C, 0x9A,
+0x04, 0x6B, 0x40, 0xA4, 0x4C, 0xEB, 0x04, 0x6A,
+0x06, 0x23, 0x60, 0xA4, 0x02, 0x6A, 0x6C, 0xEA,
+0x01, 0x5A, 0x58, 0x67, 0x01, 0x4A, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x01, 0xF2, 0x78, 0x9B,
+0xFF, 0xF7, 0x1F, 0x6A, 0x8C, 0xEA, 0x40, 0xCB,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0x7C, 0x9A,
+0x82, 0x34, 0x10, 0x6A, 0xC0, 0xA3, 0x4B, 0xEA,
+0x92, 0x34, 0x4C, 0xEC, 0x0F, 0x6A, 0xCC, 0xEA,
+0xFF, 0x6D, 0x4D, 0xEC, 0xAC, 0xEC, 0x80, 0xC3,
+0x40, 0xA3, 0x01, 0x6C, 0xAC, 0xEA, 0x8D, 0xEA,
+0xAC, 0xEA, 0x40, 0xC3, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6, 0xB4, 0x9A,
+0x30, 0xF0, 0x20, 0x6C, 0x80, 0xF6, 0x98, 0x9C,
+0x60, 0x9D, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x8C, 0xEB, 0x22, 0xF6, 0x78, 0xDA,
+0x60, 0x9D, 0x8C, 0xEB, 0x42, 0xF6, 0x64, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x5C, 0x9A, 0x60, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF6, 0x58, 0x9A, 0x6C, 0xEA,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x85, 0x67, 0x00, 0x18, 0x76, 0x44, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0x07, 0x6A, 0x8C, 0xEA,
+0x05, 0x22, 0xFF, 0xF7, 0x18, 0x6A, 0x8C, 0xEA,
+0x08, 0x4A, 0x20, 0xE8, 0xFF, 0xF7, 0x18, 0x6A,
+0x8C, 0xEA, 0x20, 0xE8, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x04, 0x67, 0x06, 0x4C,
+0xB1, 0xE4, 0x25, 0x67, 0x00, 0x18, 0x97, 0x2B,
+0x86, 0x72, 0x00, 0x6A, 0x08, 0x61, 0x87, 0x40,
+0x31, 0xE4, 0x00, 0x18, 0x97, 0x2B, 0xDD, 0x6B,
+0x6E, 0xEA, 0x01, 0x5A, 0x58, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD1, 0x05, 0xD0,
+0x05, 0x67, 0x82, 0x45, 0x00, 0x18, 0x97, 0x2B,
+0x83, 0x40, 0x22, 0x67, 0x00, 0x18, 0x97, 0x2B,
+0x03, 0x6B, 0x0F, 0x6C, 0x4C, 0xEB, 0x2C, 0xEC,
+0x18, 0x48, 0x61, 0xE0, 0x8C, 0x34, 0x89, 0xE0,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x06, 0x67, 0x81, 0x46,
+0x00, 0x18, 0x97, 0x2B, 0x90, 0x67, 0x04, 0xD2,
+0x00, 0x18, 0x97, 0x2B, 0x82, 0x40, 0x05, 0xD2,
+0x00, 0x18, 0x97, 0x2B, 0x83, 0x40, 0x22, 0x67,
+0x00, 0x18, 0x97, 0x2B, 0x03, 0x6B, 0x4C, 0xEB,
+0x0F, 0x6A, 0x2C, 0xEA, 0x18, 0x4B, 0x4C, 0x32,
+0x51, 0xE3, 0x04, 0x93, 0x60, 0x32, 0x05, 0x93,
+0x6D, 0xEA, 0xE7, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x51, 0xE4, 0x00, 0x18, 0x9B, 0x44, 0x30, 0xF0,
+0x20, 0x6B, 0xA4, 0xF1, 0x68, 0x9B, 0x09, 0xE2,
+0x43, 0xEB, 0x02, 0x60, 0x6F, 0xEB, 0x69, 0xE2,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x5C, 0x9A, 0xFF, 0x6B, 0x20, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x40, 0x9A,
+0x40, 0xA2, 0x82, 0x67, 0x6C, 0xEC, 0x30, 0xF0,
+0x20, 0x6A, 0x05, 0xD4, 0x61, 0xF4, 0x8C, 0xA2,
+0x01, 0x6A, 0x8C, 0xEA, 0x6C, 0xEA, 0x00, 0x6B,
+0x04, 0xD3, 0x3F, 0x2A, 0x42, 0x10, 0x81, 0x41,
+0x00, 0x18, 0x97, 0x2B, 0x02, 0x67, 0x91, 0x67,
+0x00, 0x18, 0x97, 0x2B, 0x00, 0x30, 0x82, 0x41,
+0x4D, 0xE8, 0xE7, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0x00, 0x18, 0x97, 0x2B, 0x83, 0x41, 0x06, 0xD2,
+0x00, 0x18, 0x97, 0x2B, 0x03, 0x6B, 0x4C, 0xEB,
+0x87, 0x43, 0x06, 0x93, 0x0F, 0x6A, 0x11, 0x4C,
+0x6C, 0xEA, 0x4C, 0x32, 0x51, 0xE4, 0x91, 0xE0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC, 0x00, 0x18,
+0x9B, 0x44, 0xFF, 0xF7, 0x1F, 0x6B, 0x6C, 0xEA,
+0x45, 0xE1, 0x30, 0xF0, 0x20, 0x6A, 0xC0, 0xF6,
+0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0x58, 0x9A, 0x80, 0x9B, 0x4C, 0xEC, 0x23, 0xEC,
+0x04, 0x60, 0x60, 0x9B, 0x4C, 0xEB, 0x6F, 0xEB,
+0x65, 0xE1, 0x91, 0x67, 0x00, 0x18, 0x76, 0x44,
+0x04, 0x94, 0xFF, 0x6A, 0x01, 0x4C, 0x4C, 0xEC,
+0x04, 0xD4, 0x04, 0x92, 0x05, 0x93, 0x63, 0xEA,
+0xBE, 0x61, 0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90,
+0x06, 0x63, 0x00, 0xEF, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0x4C, 0xEC,
+0x11, 0x6B, 0x8E, 0xEB, 0x05, 0x67, 0x14, 0x23,
+0x12, 0x5C, 0x02, 0x60, 0x08, 0x24, 0x82, 0x10,
+0x39, 0x6D, 0x8E, 0xED, 0x36, 0x25, 0x3A, 0x6A,
+0x4E, 0xEC, 0x64, 0x24, 0x7B, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF5, 0x58, 0x9A, 0x27, 0x45,
+0x03, 0x49, 0x49, 0xE1, 0x80, 0xCA, 0x7B, 0x10,
+0x87, 0x45, 0x27, 0x45, 0x30, 0xF0, 0x20, 0x6D,
+0x60, 0xF5, 0xB8, 0x9D, 0x13, 0x49, 0x0D, 0x4C,
+0xB5, 0xE1, 0x60, 0xCD, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF5, 0x74, 0x9B, 0x30, 0xF0, 0x20, 0x6D,
+0x20, 0xF6, 0xA0, 0x9D, 0x6D, 0xE4, 0x60, 0xA3,
+0xB5, 0xE4, 0xA0, 0xA5, 0x4C, 0xEB, 0x60, 0x33,
+0xAC, 0xEA, 0x6D, 0xE2, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xEB, 0xA3, 0x67, 0x06, 0xD3, 0x00, 0x18,
+0x35, 0x41, 0xC7, 0x40, 0xE7, 0x40, 0x04, 0xD2,
+0x11, 0x6C, 0x06, 0x95, 0x05, 0x4E, 0x09, 0x4F,
+0x5B, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x60, 0xF5,
+0x78, 0x9B, 0x27, 0x40, 0x0F, 0x49, 0x71, 0xE1,
+0xA0, 0xCC, 0x6D, 0xE0, 0x80, 0xA3, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF6, 0x64, 0x9B, 0x30, 0xF0,
+0x20, 0x6D, 0x81, 0xF1, 0xA4, 0x9D, 0x6D, 0xE0,
+0x60, 0xA3, 0xB5, 0xE0, 0xA0, 0xA5, 0x4C, 0xEB,
+0x60, 0x33, 0xAC, 0xEA, 0x75, 0xE2, 0x0F, 0x6B,
+0x8C, 0xEB, 0x68, 0x33, 0x77, 0xE5, 0x87, 0x40,
+0xFF, 0xF7, 0x1F, 0x6B, 0x0D, 0x4C, 0x6C, 0xED,
+0x00, 0x18, 0x35, 0x41, 0x42, 0x33, 0xFF, 0xF7,
+0x1F, 0x6C, 0x62, 0x33, 0x8C, 0xEA, 0x69, 0xE2,
+0x42, 0x33, 0x62, 0x33, 0x49, 0xE3, 0x4F, 0xEA,
+0x8C, 0xEA, 0x2C, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF5, 0x58, 0x9A, 0x27, 0x40, 0x23, 0x49,
+0x49, 0xE1, 0x80, 0xCA, 0x48, 0x6D, 0x90, 0x67,
+0x00, 0x18, 0x35, 0x41, 0x42, 0x34, 0xFF, 0xF7,
+0x1F, 0x6B, 0x82, 0x34, 0x6C, 0xEA, 0x89, 0xE2,
+0x42, 0x34, 0x82, 0x34, 0x49, 0xE4, 0x4F, 0xEA,
+0x6C, 0xEA, 0x14, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF5, 0x58, 0x9A, 0x27, 0x40, 0x03, 0x49,
+0x49, 0xE1, 0x00, 0x6B, 0x60, 0xCA, 0x90, 0x67,
+0x14, 0x6D, 0x00, 0x18, 0x35, 0x41, 0x00, 0x6C,
+0x04, 0xD2, 0x14, 0x6D, 0xC4, 0x67, 0xE4, 0x67,
+0x00, 0x18, 0x50, 0x41, 0x30, 0xF0, 0x20, 0x6B,
+0x60, 0xF5, 0xB8, 0x9B, 0xFF, 0x6C, 0x42, 0x33,
+0xB5, 0xE1, 0x8C, 0xEB, 0x60, 0xC5, 0x30, 0xF0,
+0x20, 0x6B, 0x80, 0xF5, 0x64, 0x9B, 0x8C, 0xEA,
+0x65, 0xE1, 0x40, 0xC1, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x6A, 0x8C, 0xEA, 0x0B, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF2, 0x78, 0x9A, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF5, 0x8C, 0x9C, 0x40, 0x9B,
+0x8D, 0xEA, 0x0A, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x78, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x21, 0xF2, 0x80, 0x9C, 0x40, 0x9B, 0x8C, 0xEA,
+0x40, 0xDB, 0x20, 0xE8, 0xFF, 0x6A, 0x4C, 0xEC,
+0x07, 0x6B, 0x8C, 0xEB, 0x4C, 0xED, 0x8E, 0x34,
+0x42, 0xF4, 0x10, 0x4C, 0x36, 0x25, 0x1F, 0xF7,
+0x00, 0x6D, 0x8C, 0xED, 0x02, 0xF0, 0x00, 0x75,
+0x01, 0x60, 0x21, 0x2D, 0x1F, 0xF7, 0x00, 0x6A,
+0x8C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0xB4, 0x9A, 0xB5, 0xE4, 0x80, 0xA5, 0x0B, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0xB4, 0x9A,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5, 0x58, 0x9A,
+0xB5, 0xE4, 0x51, 0xE4, 0x80, 0xA4, 0x00, 0xF6,
+0x80, 0x34, 0x01, 0x6A, 0x00, 0xF6, 0x83, 0x34,
+0x44, 0xEB, 0x8D, 0xEA, 0x36, 0x10, 0x30, 0xF0,
+0x20, 0x6D, 0x20, 0xF5, 0xB8, 0x9D, 0x01, 0x6E,
+0xC4, 0xEB, 0xB1, 0xE4, 0xA0, 0xA4, 0x00, 0xF6,
+0xA0, 0x35, 0x00, 0xF6, 0xA3, 0x35, 0xCD, 0xED,
+0x3A, 0x10, 0x1F, 0xF7, 0x00, 0x6D, 0x8C, 0xED,
+0x02, 0xF0, 0x00, 0x75, 0x01, 0x60, 0x25, 0x2D,
+0x1F, 0xF7, 0x00, 0x6A, 0x8C, 0xEA, 0x02, 0xF0,
+0x00, 0x72, 0x01, 0x60, 0x07, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0xB4, 0x9A, 0xB5, 0xE4,
+0x80, 0xA5, 0x0B, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0xB4, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0xB5, 0xE4, 0x51, 0xE4,
+0x80, 0xA4, 0x01, 0x6A, 0x00, 0xF6, 0x80, 0x34,
+0x44, 0xEB, 0x00, 0xF6, 0x83, 0x34, 0x4F, 0xEA,
+0x8C, 0xEA, 0xFF, 0x6B, 0x6C, 0xEA, 0x40, 0xC5,
+0x20, 0xE8, 0x30, 0xF0, 0x20, 0x6D, 0x20, 0xF5,
+0xB8, 0x9D, 0x01, 0x6E, 0xC4, 0xEB, 0xB1, 0xE4,
+0xA0, 0xA4, 0xCF, 0xEE, 0x00, 0xF6, 0xA0, 0x35,
+0x00, 0xF6, 0xA3, 0x35, 0xCC, 0xED, 0x4C, 0xED,
+0xA0, 0xC4, 0x20, 0xE8, 0x01, 0x6A, 0x20, 0xE8,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEE, 0x4C, 0xEF,
+0x24, 0x67, 0x0D, 0xD5, 0x06, 0xD6, 0x04, 0xD7,
+0x23, 0x27, 0x00, 0x68, 0x91, 0x67, 0x00, 0x18,
+0x97, 0x2B, 0x06, 0x93, 0x6E, 0xEA, 0x0E, 0x2A,
+0x0D, 0x95, 0x42, 0x41, 0x82, 0x67, 0x05, 0xD2,
+0x00, 0x18, 0xAF, 0x45, 0x01, 0x72, 0x16, 0x60,
+0x81, 0x41, 0x00, 0x18, 0x97, 0x2B, 0x05, 0x93,
+0x45, 0xE3, 0x05, 0x10, 0x81, 0x41, 0x00, 0x18,
+0x97, 0x2B, 0x02, 0x49, 0x45, 0xE1, 0xFF, 0xF7,
+0x1F, 0x6B, 0x02, 0x48, 0x6C, 0xE8, 0x41, 0xE0,
+0x04, 0x92, 0x6C, 0xE8, 0x43, 0xE8, 0xDE, 0x61,
+0x01, 0x69, 0x2B, 0xE9, 0x51, 0x67, 0x0B, 0x97,
+0x0A, 0x91, 0x09, 0x90, 0x06, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xED, 0x00, 0x18, 0xF1, 0x26, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xFF, 0x68, 0xE0, 0xF6, 0x44, 0x9A, 0x0C, 0xED,
+0x04, 0xD5, 0x40, 0x9A, 0x02, 0xF0, 0x00, 0x6B,
+0xFF, 0xF7, 0x1F, 0x69, 0x6C, 0xEA, 0x8C, 0xE9,
+0x27, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x44, 0x9A, 0x00, 0x6C, 0xB0, 0x67, 0x40, 0xA2,
+0x49, 0x6E, 0x62, 0x67, 0x0C, 0xEB, 0x05, 0xD3,
+0x00, 0x18, 0xC5, 0x3A, 0x00, 0x18, 0x5B, 0x40,
+0x01, 0x72, 0x26, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF6, 0x7C, 0x9A, 0x08, 0x6C, 0x01, 0x6D,
+0x40, 0xA3, 0x03, 0x6F, 0x0C, 0xEA, 0x8D, 0xEA,
+0x0C, 0xEA, 0x40, 0xC3, 0x04, 0x96, 0x91, 0x67,
+0x00, 0x18, 0x3E, 0x48, 0x05, 0x95, 0x00, 0x6C,
+0x4A, 0x6E, 0x00, 0x18, 0xC5, 0x3A, 0x10, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF6, 0x7C, 0x9A,
+0x08, 0x6C, 0x01, 0x6D, 0x40, 0xA3, 0x03, 0x6F,
+0x0C, 0xEA, 0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3,
+0x04, 0x96, 0x91, 0x67, 0x00, 0x18, 0x3E, 0x48,
+0x00, 0x18, 0x7E, 0x48, 0x09, 0x97, 0x08, 0x91,
+0x07, 0x90, 0x05, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xE2, 0xF7, 0x09, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x03, 0xF0, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x9F, 0x9A, 0x07, 0x24, 0x01, 0x6B,
+0x8C, 0xEB, 0x04, 0x23, 0x02, 0x6B, 0x6B, 0xEB,
+0x8C, 0xEB, 0x7F, 0xDA, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x03, 0xF0, 0x02, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0x43, 0xF0, 0x01, 0x4A,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6C, 0xE1, 0xF3,
+0x9C, 0x9C, 0x02, 0x24, 0x01, 0x4A, 0x40, 0xDB,
+0x20, 0xE8, 0x00, 0x65, 0x30, 0xF0, 0x20, 0x6B,
+0x40, 0xF4, 0x7C, 0x9B, 0x10, 0xF0, 0x21, 0x6A,
+0x63, 0xF0, 0x05, 0x4A, 0x40, 0xDB, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A, 0x80, 0xF0,
+0x90, 0x9A, 0x0A, 0x24, 0xFF, 0x6B, 0x01, 0x4B,
+0x8C, 0xEB, 0x06, 0x23, 0xFF, 0x6B, 0x02, 0x4B,
+0x6B, 0xEB, 0x8C, 0xEB, 0x80, 0xF0, 0x70, 0xDA,
+0x30, 0xF0, 0x20, 0x6A, 0x01, 0xF4, 0x48, 0x9A,
+0x09, 0x22, 0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4,
+0x7C, 0x9B, 0x10, 0xF0, 0x21, 0x6A, 0x63, 0xF0,
+0x06, 0x4A, 0x40, 0xDB, 0x20, 0xE8, 0x00, 0x65,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xA3, 0xF0, 0x19, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF4, 0x7C, 0x9B,
+0x10, 0xF0, 0x21, 0x6A, 0xC3, 0xF0, 0x11, 0x4A,
+0x40, 0xDB, 0x01, 0x4A, 0x40, 0xDB, 0x20, 0xE8,
+0xFC, 0x63, 0x07, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF6, 0x7C, 0x9B, 0xE9, 0xA4, 0x48, 0xA4,
+0x60, 0xAB, 0xE0, 0x37, 0x5D, 0xE7, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xEF, 0x4C, 0xEB, 0x4A, 0xA4,
+0xAB, 0xA4, 0x01, 0x72, 0x10, 0x60, 0x04, 0x22,
+0x02, 0x72, 0x0B, 0x6A, 0x38, 0x61, 0x17, 0x10,
+0xA1, 0x5F, 0x34, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6C, 0xC7, 0xF5, 0x1F, 0x4A,
+0xC7, 0xF5, 0xFC, 0xC4, 0x17, 0x10, 0x00, 0xF1,
+0x01, 0x5F, 0x28, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6C, 0x67, 0xF6, 0x1F, 0x4A,
+0xC7, 0xF5, 0xFD, 0xC4, 0x0B, 0x10, 0x00, 0xF1,
+0x01, 0x5F, 0x1C, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6C, 0x67, 0xF7, 0x1F, 0x4A,
+0xC7, 0xF5, 0xFE, 0xC4, 0x75, 0xE5, 0x00, 0x6B,
+0x04, 0xD3, 0x05, 0xD3, 0x83, 0x67, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF2, 0xC4, 0x9B, 0xBC, 0x35,
+0x30, 0xF0, 0x20, 0x6B, 0xD5, 0xE5, 0x80, 0xF4,
+0xD4, 0x9B, 0xD9, 0xE2, 0x00, 0x18, 0x63, 0x2A,
+0x00, 0x6A, 0x01, 0x10, 0x0A, 0x6A, 0x07, 0x97,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF6, 0x7C, 0x9B, 0xE9, 0xA4, 0x48, 0xA4,
+0xAA, 0xA4, 0x20, 0xAB, 0xE0, 0x37, 0x5D, 0xE7,
+0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEF, 0x4C, 0xE9,
+0x30, 0xF0, 0x20, 0x6B, 0x22, 0xF1, 0x4C, 0x45,
+0x44, 0x32, 0x61, 0xF3, 0x10, 0x4B, 0x02, 0x68,
+0x69, 0xE2, 0xAE, 0xE8, 0x8B, 0xA4, 0xC0, 0xAA,
+0x05, 0x20, 0x03, 0x6A, 0x4E, 0xED, 0x05, 0x6A,
+0x32, 0x2D, 0x0F, 0x10, 0xC9, 0xE7, 0x01, 0xF0,
+0x01, 0x52, 0x03, 0x61, 0x44, 0xF2, 0x1C, 0xCB,
+0x0E, 0x10, 0x30, 0xF0, 0x20, 0x6D, 0xC5, 0xF5,
+0x1C, 0x4D, 0xD9, 0xE5, 0x44, 0xF2, 0x5C, 0xCB,
+0x0F, 0x10, 0xC9, 0xE7, 0x01, 0xF0, 0x01, 0x52,
+0x04, 0x61, 0x44, 0xF2, 0xBE, 0xCB, 0x04, 0x6A,
+0x1A, 0x10, 0x30, 0xF0, 0x20, 0x6D, 0xC6, 0xF5,
+0x1C, 0x4D, 0xD9, 0xE5, 0x44, 0xF2, 0x5E, 0xCB,
+0x00, 0x6A, 0x31, 0xE4, 0x9C, 0x35, 0x04, 0xD2,
+0x05, 0xD2, 0x82, 0x67, 0x30, 0xF0, 0x20, 0x6A,
+0xE1, 0xF0, 0x54, 0x9A, 0x55, 0xE5, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0x54, 0x9A, 0x59, 0xE6,
+0x00, 0x18, 0x63, 0x2A, 0x00, 0x6A, 0x09, 0x97,
+0x08, 0x91, 0x07, 0x90, 0x05, 0x63, 0x00, 0xEF,
+0xFC, 0x63, 0x07, 0x62, 0x30, 0xF0, 0x20, 0x6B,
+0x61, 0xF3, 0x10, 0x4B, 0x06, 0xF5, 0xB1, 0xA3,
+0xFF, 0x6A, 0x8C, 0xEA, 0x3D, 0x25, 0x71, 0xE2,
+0x66, 0xF2, 0x8C, 0xA4, 0x39, 0x24, 0x30, 0xF0,
+0x20, 0x6C, 0xC0, 0xF6, 0x9C, 0x9C, 0x01, 0x72,
+0xC0, 0xAC, 0xFF, 0xF7, 0x1F, 0x6C, 0xCC, 0xEC,
+0x0B, 0x60, 0x03, 0x22, 0x02, 0x72, 0x0F, 0x60,
+0x2B, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xC7, 0xF5,
+0x1F, 0x4A, 0x66, 0xF2, 0xEC, 0xA3, 0x0D, 0x10,
+0x30, 0xF0, 0x20, 0x6A, 0x67, 0xF6, 0x1F, 0x4A,
+0x66, 0xF2, 0xED, 0xA3, 0x06, 0x10, 0x66, 0xF2,
+0xEE, 0xA3, 0x30, 0xF0, 0x20, 0x6A, 0x67, 0xF7,
+0x1F, 0x4A, 0x00, 0x6B, 0xE1, 0xF7, 0x1F, 0x6E,
+0x8C, 0xEE, 0x04, 0xD3, 0x05, 0xD3, 0x83, 0x67,
+0x30, 0xF0, 0x20, 0x6B, 0xB9, 0xE6, 0x80, 0xF4,
+0xB4, 0x9B, 0xDC, 0x36, 0xB5, 0xE2, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x44, 0x9A, 0x59, 0xE6,
+0x00, 0x18, 0x63, 0x2A, 0x01, 0x6A, 0x01, 0x10,
+0x00, 0x6A, 0x07, 0x97, 0x04, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x68, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x22, 0xF1, 0x8C, 0x43, 0x84, 0x34,
+0x49, 0xE4, 0x80, 0xAA, 0x06, 0x6A, 0x6A, 0x24,
+0x02, 0x73, 0x00, 0x68, 0x27, 0x60, 0x03, 0x73,
+0x09, 0x6A, 0x64, 0x61, 0x52, 0x10, 0x49, 0xE0,
+0x64, 0xF2, 0x2C, 0xA2, 0x04, 0x71, 0x04, 0x60,
+0x08, 0x71, 0x02, 0x60, 0x0C, 0x71, 0x55, 0x61,
+0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B,
+0x0D, 0xE3, 0x04, 0x02, 0x64, 0xF2, 0x0C, 0x4B,
+0x31, 0xE2, 0x04, 0x10, 0xA0, 0xA3, 0x01, 0x4B,
+0xA0, 0xC2, 0x01, 0x4A, 0x8A, 0xEA, 0xFA, 0x61,
+0x04, 0x04, 0x00, 0x18, 0x27, 0x35, 0x03, 0x72,
+0x42, 0x60, 0x43, 0x22, 0x01, 0xE1, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x44, 0xF2, 0x7C, 0xAA,
+0x63, 0xE8, 0xD5, 0x61, 0x00, 0x6B, 0x44, 0xF2,
+0x7C, 0xCA, 0x33, 0x10, 0x49, 0xE0, 0x65, 0xF2,
+0x2C, 0xA2, 0x04, 0x71, 0x04, 0x60, 0x08, 0x71,
+0x02, 0x60, 0x0C, 0x71, 0x26, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x61, 0xF3, 0x10, 0x4B, 0x0D, 0xE3,
+0x04, 0x02, 0x65, 0xF2, 0x0C, 0x4B, 0x31, 0xE2,
+0x04, 0x10, 0xA0, 0xA3, 0x01, 0x4B, 0xA0, 0xC2,
+0x01, 0x4A, 0x8A, 0xEA, 0xFA, 0x61, 0x04, 0x04,
+0x00, 0x18, 0x27, 0x35, 0x03, 0x72, 0x13, 0x60,
+0x14, 0x22, 0x01, 0xE1, 0xFF, 0xF7, 0x1F, 0x6A,
+0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x44, 0xF2, 0x7E, 0xAA, 0x63, 0xE8,
+0xD5, 0x61, 0x00, 0x6B, 0x44, 0xF2, 0x7E, 0xCA,
+0x04, 0x10, 0x07, 0x6A, 0x03, 0x10, 0x08, 0x6A,
+0x01, 0x10, 0x00, 0x6A, 0x0B, 0x97, 0x0A, 0x91,
+0x09, 0x90, 0x06, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xF9, 0x63, 0x0D, 0x62, 0x0C, 0xD1, 0x0B, 0xD0,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x10, 0x4A,
+0x00, 0x6B, 0x06, 0xF5, 0x74, 0xDA, 0x06, 0xF5,
+0x78, 0xDA, 0x69, 0xA4, 0x48, 0xA4, 0x60, 0x33,
+0x49, 0xE3, 0x09, 0xD2, 0x09, 0x93, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xEB, 0x09, 0xD3, 0x6A, 0xA4,
+0x01, 0x73, 0x02, 0x61, 0x4B, 0xA4, 0x08, 0x10,
+0x30, 0xF0, 0x20, 0x6B, 0xC0, 0xF6, 0x7C, 0x9B,
+0x60, 0xAB, 0x6C, 0xEA, 0x6B, 0xA4, 0x49, 0xE3,
+0x5C, 0x32, 0x30, 0x4A, 0x08, 0xD2, 0x00, 0x69,
+0x2F, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF5,
+0x58, 0x9A, 0x08, 0x93, 0xFF, 0x68, 0x49, 0xE3,
+0x40, 0xA2, 0x4C, 0xE8, 0x04, 0x70, 0x06, 0x60,
+0x08, 0x70, 0x04, 0x60, 0x0C, 0x70, 0x02, 0x60,
+0x01, 0x6A, 0x22, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF5, 0x78, 0x9A, 0x08, 0x92, 0x6D, 0xE2,
+0x04, 0x02, 0x11, 0xE2, 0x04, 0x10, 0xA0, 0xA3,
+0x01, 0x4B, 0xA0, 0xC2, 0x01, 0x4A, 0x8A, 0xEA,
+0xFA, 0x61, 0x04, 0x04, 0x00, 0x18, 0x27, 0x35,
+0x03, 0x72, 0x02, 0x61, 0x02, 0x6A, 0x0C, 0x10,
+0x0A, 0x22, 0x08, 0x93, 0x01, 0x49, 0xFF, 0xF7,
+0x1F, 0x6A, 0x0D, 0xE3, 0x08, 0xD3, 0x4C, 0xE9,
+0x09, 0x92, 0x43, 0xE9, 0xCE, 0x61, 0x00, 0x6A,
+0x0D, 0x97, 0x0C, 0x91, 0x0B, 0x90, 0x07, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x30, 0xF0, 0x20, 0x68,
+0xA4, 0xF1, 0x18, 0x48, 0x00, 0x69, 0x91, 0x67,
+0x04, 0x05, 0x00, 0x18, 0xFA, 0x43, 0x01, 0x72,
+0x02, 0x60, 0x03, 0x6A, 0x09, 0x10, 0x7D, 0x67,
+0x50, 0xA3, 0x01, 0x49, 0x00, 0xF4, 0x00, 0x71,
+0x40, 0xC0, 0x01, 0x48, 0xF0, 0x61, 0x00, 0x6A,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xDC, 0x63, 0x47, 0x62,
+0x46, 0xD1, 0x45, 0xD0, 0xFF, 0x6A, 0xFF, 0xF7,
+0x1F, 0x6B, 0x6C, 0xEF, 0x4C, 0xEC, 0x6C, 0xEE,
+0x43, 0xD4, 0xC2, 0x33, 0xE2, 0x34, 0x4C, 0xEB,
+0x4C, 0xEC, 0x00, 0x69, 0x49, 0xD5, 0x3F, 0xD6,
+0x42, 0xD7, 0x41, 0xD3, 0x40, 0xD4, 0xB1, 0x67,
+0x49, 0x10, 0x01, 0x6A, 0x7D, 0x67, 0x4B, 0xEA,
+0x50, 0xC3, 0x3F, 0x92, 0x00, 0xF1, 0x8C, 0x43,
+0xF0, 0xF0, 0xA8, 0x43, 0x23, 0xE2, 0x80, 0xA4,
+0xA0, 0xA5, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0xC8, 0x58, 0x92, 0xC3, 0xB4, 0xC3, 0x02, 0x61,
+0xC8, 0x68, 0x06, 0x10, 0x3E, 0x93, 0x80, 0x6A,
+0x4B, 0xEA, 0x6D, 0xEA, 0x9D, 0x67, 0x54, 0xC4,
+0xBD, 0x67, 0x15, 0xC5, 0x00, 0x6A, 0x0A, 0x10,
+0x49, 0x95, 0x9D, 0x67, 0x4D, 0xE4, 0x51, 0xE5,
+0x31, 0xE4, 0x80, 0xA4, 0x01, 0x4A, 0x9A, 0xC3,
+0xFF, 0x6B, 0x6C, 0xEA, 0x03, 0xEA, 0xF4, 0x61,
+0x7D, 0x67, 0xF0, 0xF0, 0x8C, 0x43, 0x80, 0xA4,
+0x46, 0x40, 0x53, 0xC3, 0x96, 0xC3, 0x00, 0xF1,
+0xA4, 0x43, 0x00, 0xF1, 0x48, 0x43, 0x00, 0xF1,
+0x80, 0x43, 0xA0, 0xA5, 0x40, 0xA2, 0x80, 0xA4,
+0xB7, 0xC3, 0x58, 0xC3, 0x99, 0xC3, 0x04, 0x04,
+0x00, 0x18, 0xA2, 0x2C, 0x3E, 0x95, 0xFF, 0xF7,
+0x1F, 0x6A, 0x25, 0xE0, 0x4C, 0xE9, 0x01, 0x4D,
+0xFF, 0x6A, 0x4C, 0xED, 0x3F, 0x92, 0x3E, 0xD5,
+0x43, 0xE9, 0xB3, 0x61, 0x47, 0x97, 0x46, 0x91,
+0x45, 0x90, 0x24, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xA7, 0x44, 0x30, 0xF0,
+0x20, 0x6C, 0x01, 0x4D, 0x68, 0xF0, 0x1F, 0x4C,
+0x03, 0x6E, 0x00, 0x18, 0x70, 0x2C, 0x05, 0x97,
+0x00, 0x6A, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x30, 0xF0, 0x20, 0x6C,
+0xC5, 0xF5, 0x08, 0x4C, 0x00, 0x6D, 0xE2, 0xF3,
+0x10, 0x6E, 0x00, 0x18, 0x6B, 0x2C, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFF, 0x6A, 0x4C, 0xEC,
+0xAC, 0xEA, 0x0B, 0x2A, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF2, 0xA8, 0x9B, 0x30, 0xF0, 0x20, 0x6E,
+0x81, 0xF1, 0xD4, 0x9E, 0x60, 0x9D, 0xCC, 0xEB,
+0x0C, 0x10, 0x01, 0x72, 0x0B, 0x61, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF2, 0xA8, 0x9B, 0x30, 0xF0,
+0x20, 0x6E, 0x80, 0xF6, 0xC4, 0x9E, 0x60, 0x9D,
+0xCD, 0xEB, 0x60, 0xDD, 0x05, 0x5C, 0x60, 0xF1,
+0x06, 0x60, 0x30, 0xF0, 0x20, 0x6B, 0x88, 0x34,
+0x40, 0xF4, 0x08, 0x4B, 0x8D, 0xE3, 0x60, 0x9B,
+0x00, 0xEB, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x68, 0x9A, 0x0D, 0x11, 0x01, 0x72,
+0x10, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x68, 0x9A, 0xFF, 0x6C, 0x40, 0x6D, 0x40, 0xA3,
+0x8C, 0xEA, 0xAD, 0xEA, 0x8C, 0xEA, 0x40, 0xC3,
+0x40, 0xA3, 0x80, 0x4D, 0xC0, 0x4D, 0x8C, 0xEA,
+0x14, 0x10, 0x02, 0x72, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x68, 0x9A, 0xBF, 0x6A,
+0x80, 0xA3, 0xF4, 0x10, 0x03, 0x72, 0x20, 0xF1,
+0x1A, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x68, 0x9A, 0xFF, 0x6C, 0x40, 0x6D, 0x40, 0xA3,
+0x8C, 0xEA, 0xAD, 0xEA, 0xE7, 0x10, 0x07, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x6C, 0x9A,
+0xFD, 0x6A, 0x80, 0xA3, 0xDF, 0x10, 0x01, 0x72,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x88, 0x9A, 0xFF, 0x6A, 0x40, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF2, 0x8C, 0x9B,
+0x01, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x60, 0xA4, 0x02, 0x6D,
+0x4C, 0xEB, 0xE1, 0x10, 0x02, 0x72, 0x0F, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x68, 0x9A,
+0xBF, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x6C, 0x9A,
+0xFE, 0x6A, 0x80, 0xA3, 0xB3, 0x10, 0x03, 0x72,
+0xE0, 0xF0, 0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x88, 0x9A, 0xFF, 0x6B, 0x40, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA,
+0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x8C, 0x9A, 0x01, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0x92, 0x10, 0x07, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x6C, 0x9A, 0xF7, 0x6A, 0x80, 0xA3,
+0x95, 0x10, 0x01, 0x72, 0x19, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x88, 0x9A, 0xFF, 0x6A,
+0x40, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF2, 0x8C, 0x9B, 0x04, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x60, 0xA4, 0x08, 0x6D, 0x4C, 0xEB, 0x97, 0x10,
+0x02, 0x72, 0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x68, 0x9A, 0xBF, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x40, 0xC3, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x6C, 0x9A, 0xFB, 0x6A, 0x80, 0xA3,
+0x69, 0x10, 0x03, 0x72, 0xA0, 0xF0, 0x0F, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x88, 0x9A,
+0xFF, 0x6B, 0x40, 0x6D, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x8C, 0x9A, 0x04, 0x6D,
+0x40, 0xA4, 0x6C, 0xEA, 0x48, 0x10, 0x07, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x6C, 0x9A,
+0xDF, 0x6A, 0x80, 0xA3, 0x4B, 0x10, 0x01, 0x72,
+0x19, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x88, 0x9A, 0xFF, 0x6A, 0x40, 0x6D, 0x60, 0xA4,
+0x4C, 0xEB, 0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4,
+0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF2, 0x8C, 0x9B,
+0x10, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x60, 0xA4, 0x20, 0x6D,
+0x4C, 0xEB, 0x4D, 0x10, 0x02, 0x72, 0x0F, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x68, 0x9A,
+0xBF, 0x6A, 0x80, 0xA3, 0x8C, 0xEA, 0x40, 0xC3,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x6C, 0x9A,
+0xEF, 0x6A, 0x80, 0xA3, 0x1F, 0x10, 0x03, 0x72,
+0x66, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x88, 0x9A, 0xFF, 0x6B, 0x40, 0x6D, 0x40, 0xA4,
+0x6C, 0xEA, 0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x8C, 0x9A,
+0x10, 0x6D, 0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA,
+0x6C, 0xEA, 0x40, 0xC4, 0x20, 0xE8, 0x09, 0x2A,
+0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2, 0x6C, 0x9A,
+0x80, 0xA3, 0x7F, 0x6A, 0x8C, 0xEA, 0x40, 0xC3,
+0x20, 0xE8, 0x01, 0x72, 0x1C, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x88, 0x9A, 0xFF, 0x6A,
+0x40, 0x6D, 0x60, 0xA4, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x30, 0xF0, 0x20, 0x6B,
+0x21, 0xF2, 0x8C, 0x9B, 0x60, 0xA4, 0x4C, 0xEB,
+0xAD, 0xEB, 0x4C, 0xEB, 0x60, 0xC4, 0x60, 0xA4,
+0x80, 0x4D, 0xC0, 0x4D, 0x4C, 0xEB, 0xAD, 0xEB,
+0x4C, 0xEB, 0x60, 0xC4, 0x20, 0xE8, 0x02, 0x72,
+0x10, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x48, 0x9A, 0xBF, 0x6B, 0x80, 0xA2, 0x6C, 0xEC,
+0x80, 0xC2, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF2,
+0x4C, 0x9A, 0x80, 0xA2, 0x8C, 0xEB, 0x60, 0xC2,
+0x20, 0xE8, 0x03, 0x72, 0x14, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x21, 0xF2, 0x88, 0x9A, 0xFF, 0x6B,
+0x40, 0x6D, 0x40, 0xA4, 0x6C, 0xEA, 0xAD, 0xEA,
+0x6C, 0xEA, 0x40, 0xC4, 0x30, 0xF0, 0x20, 0x6A,
+0x21, 0xF2, 0x8C, 0x9A, 0x40, 0xA4, 0x6C, 0xEA,
+0xAD, 0xEA, 0x6C, 0xEA, 0x40, 0xC4, 0x20, 0xE8,
+0xFF, 0x63, 0x01, 0xD0, 0xFF, 0x6A, 0x4C, 0xED,
+0x4C, 0xEE, 0x4C, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0xC0, 0xF6, 0x5C, 0x9A, 0xFF, 0xF7, 0x1F, 0x6B,
+0x6C, 0xEC, 0x00, 0xAA, 0xE1, 0xF7, 0x1F, 0x6A,
+0x0C, 0xEA, 0x30, 0xF0, 0x20, 0x68, 0x40, 0xF5,
+0x1C, 0x98, 0x51, 0xE4, 0x6C, 0xEC, 0x80, 0xC8,
+0x9C, 0x32, 0x30, 0xF0, 0x20, 0x6C, 0x00, 0xF6,
+0x90, 0x9C, 0x30, 0xF0, 0x20, 0x68, 0xC0, 0xF5,
+0x14, 0x98, 0x91, 0xE2, 0x80, 0xAC, 0x01, 0xE2,
+0x00, 0x98, 0x6C, 0xEC, 0x05, 0x25, 0x10, 0xF0,
+0x00, 0x6D, 0xAB, 0xED, 0xAD, 0xEC, 0x6C, 0xEC,
+0xD8, 0xF0, 0x00, 0x6B, 0x8C, 0xEB, 0x30, 0xF0,
+0x20, 0x6C, 0x00, 0xF6, 0x90, 0x9C, 0x91, 0xE2,
+0x60, 0xCC, 0x30, 0xF0, 0x20, 0x6B, 0x81, 0xF1,
+0x64, 0x9B, 0x6D, 0xE2, 0x80, 0xA3, 0x01, 0x6B,
+0x8C, 0xEB, 0x05, 0x23, 0x03, 0xF7, 0x01, 0x6B,
+0x6B, 0xEB, 0x0C, 0xEB, 0x06, 0x10, 0x1F, 0xF7,
+0x01, 0x6B, 0x6B, 0xEB, 0x0C, 0xEB, 0xE0, 0x37,
+0xED, 0xEB, 0xFF, 0x76, 0x13, 0x60, 0x30, 0xF0,
+0x20, 0x6C, 0x21, 0xF2, 0x90, 0x9C, 0x80, 0xF4,
+0xC0, 0x36, 0x6C, 0xEC, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF5, 0x68, 0x9B, 0x6D, 0xEE, 0x30, 0xF0,
+0x20, 0x6B, 0xC0, 0xF5, 0x74, 0x9B, 0x8D, 0xEE,
+0x6D, 0xE2, 0xC0, 0xDB, 0x30, 0xF0, 0x20, 0x6B,
+0x20, 0xF6, 0x80, 0x9B, 0x7F, 0x6B, 0x91, 0xE2,
+0xA0, 0xA4, 0xAC, 0xEB, 0x60, 0xC4, 0x30, 0xF0,
+0x20, 0x6B, 0x21, 0xF2, 0x74, 0x9B, 0x1C, 0x6C,
+0x80, 0xC3, 0x30, 0xF0, 0x20, 0x6B, 0x21, 0xF2,
+0x78, 0x9B, 0x08, 0xF4, 0x13, 0x6C, 0x80, 0xCB,
+0x30, 0xF0, 0x20, 0x6B, 0x40, 0xF5, 0x90, 0x9B,
+0xF7, 0x6B, 0x91, 0xE2, 0xA0, 0xA4, 0xAC, 0xEB,
+0x60, 0xC4, 0x01, 0x90, 0x01, 0x63, 0x20, 0xE8,
+0xFB, 0x63, 0x09, 0x62, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x64, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0xA0, 0xF4, 0x94, 0x9C, 0x40, 0x9B, 0x20, 0x6D,
+0x00, 0x6E, 0x8D, 0xEA, 0x40, 0xDB, 0x00, 0xF4,
+0x1F, 0x6C, 0x06, 0x02, 0xE0, 0xF3, 0x08, 0x6F,
+0x04, 0xD2, 0x00, 0x18, 0xC2, 0x2B, 0x09, 0x97,
+0x05, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0xFF, 0xF7, 0x1F, 0x6B,
+0xAC, 0xEB, 0x05, 0xD3, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF6, 0x7C, 0x9B, 0xFF, 0x6A, 0x8C, 0xEA,
+0x80, 0xAB, 0xE1, 0xF7, 0x1F, 0x6B, 0x00, 0x68,
+0x8C, 0xEB, 0x69, 0xE2, 0x30, 0xF0, 0x20, 0x6B,
+0xC0, 0xF5, 0x84, 0x9B, 0x5C, 0x32, 0x91, 0xE2,
+0x04, 0xD4, 0x18, 0x10, 0x04, 0x92, 0x20, 0x9A,
+0x07, 0x28, 0x01, 0x6D, 0x83, 0xF1, 0x18, 0x6C,
+0xAB, 0xED, 0xD1, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x01, 0x6D, 0x83, 0xF1, 0x18, 0x6C, 0xAB, 0xED,
+0xD1, 0x67, 0x00, 0x18, 0x39, 0x38, 0x04, 0x93,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x04, 0x4B,
+0x4C, 0xE8, 0x04, 0xD3, 0x05, 0x92, 0x43, 0xE8,
+0xE5, 0x61, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x10, 0x4A, 0x05, 0x6B, 0x66, 0xF6,
+0x6C, 0xDA, 0x09, 0x6B, 0x66, 0xF6, 0x68, 0xDA,
+0x20, 0xE8, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0xAC, 0xE8, 0xD0, 0x67,
+0x41, 0xF4, 0x10, 0x6C, 0x7F, 0x6D, 0x00, 0x18,
+0x39, 0x38, 0xD0, 0x67, 0x41, 0xF6, 0x10, 0x6C,
+0x7F, 0x6D, 0x00, 0x18, 0x39, 0x38, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x85, 0x67, 0xA6, 0x67,
+0xC7, 0x67, 0x00, 0x18, 0xF0, 0x2B, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x1F, 0xF7, 0x00, 0x6A,
+0xAC, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x26, 0x67,
+0x01, 0x60, 0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x54, 0x9A, 0x04, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF5, 0x58, 0x9A, 0x55, 0xE5,
+0x00, 0x9D, 0x91, 0x67, 0x00, 0x18, 0x57, 0x2B,
+0x2C, 0xE8, 0x06, 0xEA, 0x50, 0x67, 0x07, 0x97,
+0x06, 0x91, 0x05, 0x90, 0x04, 0x63, 0x00, 0xEF,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0x46, 0x67, 0x01, 0x4A, 0x05, 0x67, 0x0C, 0xD6,
+0x27, 0x67, 0x1C, 0x22, 0x1F, 0xF7, 0x00, 0x6A,
+0xAC, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x54, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0x49, 0xE0, 0x40, 0x9A,
+0x0C, 0x94, 0x04, 0xD2, 0x00, 0x18, 0x57, 0x2B,
+0x0C, 0x93, 0x24, 0xEA, 0x6F, 0xEA, 0x04, 0x93,
+0x6C, 0xEA, 0x4D, 0xE9, 0x1F, 0xF7, 0x00, 0x6A,
+0x0C, 0xEA, 0x02, 0xF0, 0x00, 0x72, 0x01, 0x60,
+0x05, 0x2A, 0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF5,
+0x54, 0x9A, 0x04, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF5, 0x58, 0x9A, 0x41, 0xE0, 0x20, 0xD8,
+0x09, 0x97, 0x08, 0x91, 0x07, 0x90, 0x05, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFD, 0x63, 0x05, 0x62,
+0x06, 0xD4, 0x06, 0x04, 0x09, 0xD7, 0x07, 0xD5,
+0x08, 0xD6, 0x00, 0x18, 0x2B, 0x2D, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x00, 0x6B, 0x66, 0xF6, 0x74, 0xC2,
+0x30, 0xF0, 0x20, 0x6B, 0xE8, 0xF1, 0x04, 0x4B,
+0x86, 0xF6, 0x78, 0xDA, 0x00, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0xE0, 0xF6, 0x74, 0x9B, 0x54, 0x34,
+0x20, 0x68, 0x71, 0xE4, 0xA0, 0xA4, 0xF8, 0x6B,
+0x01, 0x4A, 0xAC, 0xEB, 0x4E, 0xE8, 0x60, 0xC4,
+0xF2, 0x28, 0x00, 0x18, 0xA9, 0x48, 0x30, 0xF0,
+0x20, 0x6A, 0xE8, 0xF1, 0x19, 0xC2, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0x68, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x66, 0xF6, 0x7D, 0xC2, 0x69, 0xA4,
+0x66, 0xF6, 0x72, 0xC2, 0x6A, 0xA4, 0x66, 0xF6,
+0x7C, 0xC2, 0xAB, 0xA4, 0x0F, 0x6B, 0xAC, 0xEB,
+0x86, 0xF6, 0x64, 0xC2, 0x6B, 0xA4, 0x72, 0x33,
+0x86, 0xF6, 0x63, 0xC2, 0x00, 0x6A, 0x20, 0xE8,
+0x60, 0xA4, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x66, 0xF6, 0x7D, 0xC2, 0x61, 0xA4,
+0x66, 0xF6, 0x72, 0xC2, 0x62, 0xA4, 0x66, 0xF6,
+0x7C, 0xC2, 0xA3, 0xA4, 0x0F, 0x6B, 0xAC, 0xEB,
+0x86, 0xF6, 0x64, 0xC2, 0x63, 0xA4, 0x72, 0x33,
+0x86, 0xF6, 0x63, 0xC2, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x4C, 0x72, 0x03, 0x61, 0x85, 0x67, 0x00, 0x18,
+0x16, 0x49, 0x05, 0x97, 0x03, 0x63, 0x00, 0xEF,
+0xFD, 0x63, 0x05, 0x62, 0xFF, 0x6A, 0x8C, 0xEA,
+0x11, 0x72, 0x04, 0x61, 0x85, 0x67, 0x00, 0x18,
+0x0A, 0x49, 0x15, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF6, 0x74, 0x9A, 0x30, 0xF0, 0x20, 0x6C,
+0x00, 0xF5, 0x88, 0x9C, 0x40, 0x9B, 0x8D, 0xEA,
+0x40, 0xDB, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3,
+0x10, 0x4A, 0x83, 0xF3, 0x7C, 0x9A, 0x8D, 0xEB,
+0x83, 0xF3, 0x7C, 0xDA, 0xFF, 0x6A, 0x05, 0x97,
+0x03, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x04, 0xD0, 0xFF, 0x68, 0x0C, 0xEC, 0x0F, 0x5C,
+0x15, 0x60, 0xA1, 0xF4, 0x1C, 0x6C, 0x00, 0xF3,
+0x00, 0x6D, 0x02, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0xA1, 0xF4, 0x14, 0x6C, 0xB0, 0x67, 0x66, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x78, 0x9A, 0xFC, 0x6A, 0x80, 0xA3,
+0x8C, 0xEA, 0x18, 0x10, 0x24, 0x5C, 0x17, 0x61,
+0xA1, 0xF4, 0x1C, 0x6C, 0x00, 0xF3, 0x00, 0x6D,
+0x01, 0x6E, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF4,
+0x14, 0x6C, 0xFF, 0x6D, 0x77, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x78, 0x9A, 0x03, 0x6C, 0x40, 0xA3, 0x0C, 0xEA,
+0x8D, 0xEA, 0x0C, 0xEA, 0x40, 0xC3, 0x05, 0x97,
+0x04, 0x90, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFF, 0x63, 0x01, 0xD0, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF6, 0x7C, 0x9B, 0x46, 0x67, 0x8E, 0xEB,
+0x12, 0x23, 0x00, 0x6E, 0x66, 0x67, 0xE4, 0x67,
+0xE6, 0xEE, 0x01, 0x68, 0x0C, 0xEF, 0x07, 0x2F,
+0x01, 0x4B, 0xFF, 0x6F, 0xEC, 0xEB, 0x14, 0x73,
+0x01, 0x4E, 0xF5, 0x61, 0x14, 0x6B, 0x8F, 0xEC,
+0x44, 0xEB, 0xAC, 0xEC, 0x8D, 0xEA, 0x01, 0x90,
+0x01, 0x63, 0x20, 0xE8, 0xFF, 0x6B, 0x6C, 0xEC,
+0x48, 0x44, 0xD4, 0x4A, 0x6C, 0xEA, 0x59, 0x5A,
+0x58, 0x67, 0x6C, 0xEA, 0x20, 0xE8, 0x00, 0x65,
+0x00, 0x6A, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0x00, 0x6A, 0x20, 0xE8, 0x20, 0xE8, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x08, 0x2D, 0x30, 0xF0,
+0x20, 0x6A, 0x01, 0xF0, 0x08, 0x6C, 0xA0, 0xF4,
+0xB8, 0x9A, 0x00, 0x6E, 0x0A, 0x10, 0x01, 0x75,
+0x00, 0x6A, 0x0A, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0xB8, 0x9A, 0x01, 0xF0, 0x08, 0x6C,
+0x03, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x01, 0x6A,
+0x05, 0x97, 0x03, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFC, 0x63, 0x07, 0x62, 0x06, 0xD0, 0x20, 0xF0,
+0x8E, 0xA4, 0xFF, 0x6B, 0x05, 0x67, 0x6C, 0xEF,
+0x01, 0x6A, 0x1D, 0x2C, 0x02, 0x5E, 0x1A, 0x60,
+0x54, 0x5F, 0x18, 0x60, 0xE3, 0xF4, 0x1F, 0x4A,
+0x04, 0xD2, 0x7F, 0x4A, 0x01, 0x4A, 0x05, 0xD2,
+0xC8, 0x36, 0x5D, 0x67, 0xD9, 0xE2, 0x44, 0x9E,
+0xFC, 0x4C, 0xEC, 0xEC, 0x6C, 0xEC, 0x51, 0xE4,
+0x01, 0x6D, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xEC,
+0xAB, 0xED, 0xD0, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A, 0x07, 0x97,
+0x06, 0x90, 0x04, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFD, 0x63, 0x05, 0x62, 0x04, 0xD0, 0x01, 0x75,
+0x0F, 0x61, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4,
+0x18, 0x9A, 0x41, 0xF1, 0x08, 0x6C, 0x01, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x38, 0x41, 0xF1,
+0x0C, 0x6C, 0xB0, 0x67, 0x00, 0x6E, 0x10, 0x10,
+0x02, 0x75, 0x1F, 0x61, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0x18, 0x9A, 0x41, 0xF1, 0x08, 0x6C,
+0x02, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x41, 0xF1, 0x0C, 0x6C, 0xB0, 0x67, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x80, 0xF4, 0x14, 0x9A, 0x21, 0xF4, 0x00, 0x6C,
+0x00, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x21, 0xF6, 0x00, 0x6C, 0xB0, 0x67, 0x00, 0x6E,
+0x1E, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4,
+0x18, 0x9A, 0x41, 0xF1, 0x08, 0x6C, 0x02, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x38, 0xB0, 0x67,
+0x41, 0xF1, 0x0C, 0x6C, 0x02, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0x14, 0x9A, 0x21, 0xF4, 0x00, 0x6C, 0x01, 0x6E,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x38, 0x21, 0xF6,
+0x00, 0x6C, 0xB0, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x05, 0x97, 0x04, 0x90, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0xFF, 0x6A, 0x4C, 0xED,
+0x04, 0x67, 0x20, 0xF0, 0x65, 0xA4, 0x88, 0x45,
+0xF9, 0x4C, 0x4C, 0xEC, 0x15, 0x5C, 0x20, 0xF2,
+0x06, 0x61, 0x20, 0xF2, 0x04, 0x25, 0x0F, 0x5D,
+0x38, 0x67, 0x02, 0x6C, 0x33, 0xE4, 0x04, 0x73,
+0x20, 0xF0, 0x92, 0xC0, 0x02, 0x60, 0x0B, 0x73,
+0x7F, 0x61, 0x59, 0x21, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x20, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x04, 0x4A, 0xC0, 0x9A, 0xB1, 0x67,
+0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7, 0x04, 0x4B,
+0xC0, 0x9B, 0xB1, 0x67, 0xA1, 0xF6, 0x10, 0x6C,
+0x1F, 0xF7, 0x00, 0x69, 0x00, 0x18, 0x39, 0x38,
+0xB1, 0x67, 0xA1, 0xF4, 0x14, 0x6C, 0x57, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0xB1, 0x67, 0xA1, 0xF6,
+0x14, 0x6C, 0xA1, 0xF4, 0x1C, 0x69, 0x57, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x91, 0x67, 0x3F, 0x6D,
+0x08, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x91, 0x67,
+0x01, 0xF4, 0x00, 0x6D, 0x02, 0x6E, 0x00, 0xF2,
+0x00, 0x49, 0x00, 0x18, 0x39, 0x38, 0x91, 0x67,
+0x3F, 0x6D, 0x08, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x91, 0x67, 0x01, 0xF4, 0x00, 0x6D, 0x02, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x20, 0xF0, 0x6C, 0xA0,
+0x03, 0x73, 0x04, 0x60, 0x20, 0xF0, 0x4B, 0xA0,
+0x03, 0x72, 0x05, 0x61, 0xFF, 0xF7, 0x1F, 0x68,
+0x5E, 0xF0, 0x10, 0x69, 0x28, 0x11, 0x6E, 0xEA,
+0x05, 0x2A, 0xFF, 0xF7, 0x1F, 0x68, 0x5E, 0xF0,
+0x15, 0x69, 0x21, 0x11, 0xFF, 0xF7, 0x1F, 0x68,
+0x5E, 0xF5, 0x10, 0x69, 0x1C, 0x11, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x20, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x08, 0x4A, 0xC0, 0x9A,
+0xB1, 0x67, 0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7,
+0x08, 0x4B, 0xC0, 0x9B, 0xB1, 0x67, 0xA1, 0xF6,
+0x10, 0x6C, 0x1F, 0xF7, 0x00, 0x69, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF4, 0x14, 0x6C, 0xB1, 0x67,
+0x75, 0x6E, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF6,
+0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E, 0xD1, 0x10,
+0x8F, 0x43, 0x4C, 0xEC, 0x02, 0x5C, 0x07, 0x61,
+0x06, 0x73, 0x05, 0x60, 0x07, 0x73, 0x03, 0x60,
+0x09, 0x73, 0xE0, 0xF0, 0x1A, 0x61, 0x20, 0xF0,
+0x44, 0xA0, 0x01, 0x72, 0x61, 0x61, 0x02, 0x5B,
+0x5F, 0x60, 0x09, 0x21, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x00, 0x9A, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0x2C, 0x9A, 0x08, 0x10, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x00, 0x9A, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF7, 0x30, 0x9A, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0xB0, 0x67, 0xD1, 0x67, 0x1F, 0xF7,
+0x00, 0x68, 0xA1, 0xF6, 0x10, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0xB0, 0x67, 0xA1, 0xF4, 0x14, 0x6C,
+0x45, 0x6E, 0x00, 0x18, 0x39, 0x38, 0xB0, 0x67,
+0xA1, 0xF6, 0x14, 0x6C, 0x45, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0xB4, 0x9A, 0xFF, 0xF7, 0x1F, 0x68, 0x54, 0xF5,
+0x15, 0x69, 0x01, 0xF0, 0x10, 0x6C, 0x00, 0xF2,
+0x11, 0x6E, 0x00, 0x18, 0x39, 0x38, 0xB0, 0x67,
+0xD1, 0x67, 0xA1, 0xF4, 0x00, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0xB0, 0x67, 0xD1, 0x67, 0xA1, 0xF4,
+0x1C, 0x68, 0xA1, 0xF6, 0x00, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0x01, 0xF4, 0x00, 0x69, 0x90, 0x67,
+0x3F, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x6E, 0x00, 0xF2,
+0x00, 0x48, 0x00, 0x18, 0x39, 0x38, 0x90, 0x67,
+0x3F, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x90, 0x67, 0xB1, 0x67, 0x00, 0x6E, 0x91, 0x10,
+0x30, 0x21, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x20, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x18, 0x4A, 0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF7, 0x18, 0x4B, 0xC0, 0x9B,
+0xB1, 0x67, 0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7,
+0x00, 0x69, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF4,
+0x14, 0x6C, 0xB1, 0x67, 0x57, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67,
+0x57, 0x6E, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF4,
+0x18, 0x6C, 0x10, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF6, 0x18, 0x6C, 0x10, 0x6D,
+0x2F, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x20, 0x9A, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0x1C, 0x4A, 0xC0, 0x9A, 0xB1, 0x67, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF7, 0x1C, 0x4B, 0xC0, 0x9B,
+0xB1, 0x67, 0xA1, 0xF6, 0x10, 0x6C, 0x1F, 0xF7,
+0x00, 0x69, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF4,
+0x14, 0x6C, 0xB1, 0x67, 0x75, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF6, 0x14, 0x6C, 0xB1, 0x67,
+0x75, 0x6E, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF4,
+0x18, 0x6C, 0x20, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF6, 0x18, 0x6C, 0x20, 0x6D,
+0x00, 0x6E, 0xA1, 0xF4, 0x1C, 0x69, 0x00, 0x18,
+0x39, 0x38, 0x91, 0x67, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x91, 0x67, 0x01, 0xF4,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0xF2, 0x00, 0x49,
+0x00, 0x18, 0x39, 0x38, 0x91, 0x67, 0x3F, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x91, 0x67,
+0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x20, 0xF0, 0x6C, 0xA0, 0x03, 0x73,
+0x80, 0xF0, 0x13, 0x61, 0x96, 0x10, 0xFF, 0xF7,
+0x1F, 0x68, 0x14, 0xF0, 0x05, 0x69, 0xA1, 0xF4,
+0x00, 0x6C, 0xB0, 0x67, 0xD1, 0x67, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF6, 0x00, 0x6C, 0xB0, 0x67,
+0xD1, 0x67, 0x00, 0x18, 0x39, 0x38, 0x01, 0x6A,
+0x97, 0x10, 0x0E, 0x23, 0x03, 0x73, 0x0C, 0x60,
+0x05, 0x73, 0x0A, 0x60, 0x08, 0x73, 0x08, 0x60,
+0x0A, 0x73, 0x06, 0x60, 0x0C, 0x73, 0x04, 0x60,
+0x0D, 0x73, 0x01, 0x6A, 0x80, 0xF0, 0x08, 0x61,
+0x29, 0x21, 0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0,
+0x20, 0x6B, 0x00, 0xF7, 0x00, 0x4A, 0x00, 0xF7,
+0x04, 0x4B, 0xA0, 0x9A, 0xC0, 0x9B, 0xA1, 0xF4,
+0x10, 0x6C, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7,
+0x00, 0x4A, 0x00, 0xF7, 0x04, 0x4B, 0xA0, 0x9A,
+0xC0, 0x9B, 0xA1, 0xF6, 0x10, 0x6C, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF4, 0x14, 0x6C, 0x1F, 0xF7,
+0x00, 0x6D, 0x57, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0xA1, 0xF6, 0x14, 0x6C, 0x1F, 0xF7, 0x00, 0x6D,
+0x57, 0x6E, 0x28, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x30, 0xF0, 0x20, 0x6B, 0x00, 0xF7, 0x00, 0x4A,
+0x00, 0xF7, 0x08, 0x4B, 0xA0, 0x9A, 0xC0, 0x9B,
+0xA1, 0xF4, 0x10, 0x6C, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x30, 0xF0, 0x20, 0x6B,
+0x00, 0xF7, 0x00, 0x4A, 0x00, 0xF7, 0x08, 0x4B,
+0xA0, 0x9A, 0xC0, 0x9B, 0xA1, 0xF6, 0x10, 0x6C,
+0x00, 0x18, 0x39, 0x38, 0xA1, 0xF4, 0x14, 0x6C,
+0x1F, 0xF7, 0x00, 0x6D, 0x75, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF6, 0x14, 0x6C, 0x1F, 0xF7,
+0x00, 0x6D, 0x75, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0xA1, 0xF4, 0x1C, 0x6C, 0x3F, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0xA1, 0xF4, 0x1C, 0x6C,
+0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF6, 0x1C, 0x6C, 0x3F, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF6,
+0x1C, 0x6C, 0x01, 0xF4, 0x00, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x7F, 0xF7, 0x09, 0x29,
+0x11, 0x10, 0x20, 0xF0, 0x4B, 0xA0, 0x03, 0x72,
+0x05, 0x61, 0xFF, 0xF7, 0x1F, 0x68, 0x14, 0xF5,
+0x01, 0x69, 0x69, 0x17, 0x6E, 0xEA, 0x7F, 0xF7,
+0x02, 0x2A, 0xFF, 0xF7, 0x1F, 0x68, 0x14, 0xF5,
+0x00, 0x69, 0x61, 0x17, 0xFF, 0xF7, 0x1F, 0x68,
+0xB4, 0xF5, 0x05, 0x69, 0x5C, 0x17, 0x00, 0x6A,
+0x07, 0x97, 0x06, 0x91, 0x05, 0x90, 0x04, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFC, 0x63, 0x07, 0x62,
+0x06, 0xD1, 0x05, 0xD0, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0xB8, 0x9A, 0x64, 0x6C, 0x03, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0xA0, 0x9A, 0x4C, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x83, 0xF1, 0x10, 0x68,
+0x40, 0x6C, 0x04, 0x6D, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x01, 0xF4, 0x00, 0x69, 0x90, 0x67,
+0x3F, 0x6D, 0x30, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x90, 0x67, 0xB1, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0xFD, 0xF7, 0x04, 0x48, 0x3F, 0x6D,
+0x90, 0x67, 0xC5, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x90, 0x67, 0xB1, 0x67, 0x03, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x07, 0x97, 0x06, 0x91, 0x05, 0x90,
+0x04, 0x63, 0x00, 0xEF, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x0E, 0x92, 0x25, 0x67,
+0x66, 0x67, 0x04, 0xD2, 0x04, 0x94, 0xFF, 0x6A,
+0x4C, 0xE9, 0x4C, 0xEF, 0x4C, 0xEC, 0x0C, 0x59,
+0x4C, 0xEB, 0x05, 0xD7, 0x04, 0xD4, 0x35, 0x60,
+0x01, 0x6D, 0x01, 0x73, 0xA4, 0xE9, 0x00, 0x6E,
+0x01, 0x60, 0x01, 0x6E, 0x83, 0xF1, 0x10, 0x6C,
+0x00, 0x18, 0x39, 0x38, 0x01, 0x68, 0x05, 0x96,
+0x04, 0xE9, 0xA1, 0xF4, 0x1C, 0x6C, 0xB0, 0x67,
+0x00, 0x18, 0x39, 0x38, 0x05, 0x96, 0xA1, 0xF6,
+0x1C, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x08, 0x59, 0x0C, 0x60, 0x28, 0x31, 0x0F, 0x68,
+0x04, 0x96, 0x04, 0xE9, 0xA1, 0xF4, 0x10, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF6,
+0x10, 0x6C, 0x0B, 0x10, 0x28, 0x31, 0x0F, 0x68,
+0x04, 0x96, 0x04, 0xE9, 0xA1, 0xF4, 0x14, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x38, 0xA1, 0xF6,
+0x14, 0x6C, 0x04, 0x96, 0xB0, 0x67, 0x00, 0x18,
+0x39, 0x38, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xFC, 0x63, 0x07, 0x62,
+0x02, 0x5D, 0x03, 0x61, 0x01, 0x6A, 0x4B, 0xEA,
+0x18, 0x10, 0x05, 0xF0, 0x00, 0x6A, 0x04, 0xD2,
+0x00, 0xF4, 0x00, 0x4A, 0x05, 0xD2, 0xA8, 0x35,
+0x5D, 0x67, 0xB5, 0xE2, 0x44, 0x9D, 0xFF, 0x6C,
+0xCC, 0xEC, 0x88, 0x34, 0x51, 0xE4, 0xFF, 0xF7,
+0x1F, 0x6A, 0x4C, 0xEC, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xBC, 0x9A, 0xEC, 0xED, 0x00, 0x18,
+0x2B, 0x38, 0x07, 0x97, 0x04, 0x63, 0x00, 0xEF,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0x02, 0x5D, 0x25, 0x67, 0x34, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x5C, 0x9A, 0xFF, 0x68,
+0xCC, 0xE8, 0x4C, 0xEF, 0x4A, 0xEF, 0x06, 0xD7,
+0x0C, 0x60, 0xD0, 0x67, 0xE2, 0x67, 0x00, 0x18,
+0x1F, 0x4B, 0x61, 0x42, 0x24, 0x23, 0x06, 0x94,
+0x10, 0x96, 0xA2, 0x67, 0x00, 0x18, 0x56, 0x49,
+0x10, 0xD2, 0x81, 0xF4, 0x10, 0x6A, 0x04, 0xD2,
+0x00, 0xF2, 0x00, 0x4A, 0x05, 0xD2, 0x28, 0x31,
+0x5D, 0x67, 0x25, 0xE2, 0x30, 0xF0, 0x20, 0x6A,
+0x10, 0x93, 0xE0, 0xF6, 0x5C, 0x9A, 0x00, 0xF5,
+0x00, 0x30, 0x88, 0xA9, 0x6C, 0xEA, 0x30, 0xF0,
+0x20, 0x6B, 0x20, 0xF7, 0xC4, 0x9B, 0x0D, 0xEA,
+0x01, 0x6D, 0x4C, 0xEE, 0xAB, 0xED, 0x00, 0x18,
+0x39, 0x38, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0xFF, 0x6A, 0xAC, 0xEA,
+0x07, 0xD2, 0x20, 0xF0, 0x4E, 0xA4, 0x24, 0x67,
+0x01, 0x6B, 0xC0, 0xF0, 0x05, 0x2A, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0xFC, 0x9A, 0x00, 0x6D,
+0x18, 0x6E, 0x00, 0x18, 0x1F, 0x4B, 0x07, 0x93,
+0x06, 0xD2, 0x0F, 0x5B, 0x31, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF4, 0xB0, 0x9A, 0x01, 0xF0,
+0x08, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x40, 0xF4, 0x14, 0x6C, 0x80, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF5, 0xAC, 0x9A, 0x81, 0xF2, 0x00, 0x6C,
+0x00, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x01, 0xF0,
+0x14, 0x6C, 0x1F, 0xF4, 0x00, 0x6D, 0x0F, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0x08, 0x9A, 0x20, 0xF0, 0x45, 0xA1,
+0x06, 0x94, 0xFF, 0x6B, 0xFE, 0x4A, 0x6C, 0xEA,
+0x02, 0x5A, 0x8C, 0xE8, 0x4F, 0x61, 0x20, 0xF0,
+0x45, 0xA1, 0x05, 0x72, 0x5E, 0x61, 0x4A, 0x10,
+0x07, 0x94, 0x24, 0x5C, 0x80, 0xF0, 0x03, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0xAC, 0x9A,
+0x81, 0xF2, 0x00, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x40, 0xF4, 0x14, 0x6C, 0x80, 0x6D,
+0x01, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF4, 0xB0, 0x9A, 0x01, 0xF0,
+0x08, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x01, 0xF0, 0x14, 0x6C, 0x1F, 0xF4, 0x00, 0x6D,
+0x22, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0x08, 0x9A, 0x06, 0x92,
+0xA3, 0xF1, 0x08, 0x6C, 0x4C, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0x20, 0xF7, 0x54, 0x9A, 0x4D, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0xB4, 0x9A,
+0x00, 0x18, 0x2B, 0x38, 0x01, 0x72, 0x12, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0xD8, 0x9A,
+0x01, 0x6D, 0xC1, 0xF0, 0x0C, 0x6C, 0xAB, 0xED,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0xC1, 0xF0, 0x18, 0x6C, 0x20, 0xF7, 0xB0, 0x9A,
+0x00, 0x6E, 0x11, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x20, 0xF7, 0xCC, 0x9A, 0x01, 0x6D, 0xC1, 0xF0,
+0x0C, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0xB0, 0x9A,
+0xC1, 0xF0, 0x18, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0xFC, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0x18, 0x6E,
+0x04, 0xD0, 0x00, 0x18, 0x30, 0x4B, 0x06, 0x94,
+0x00, 0x6B, 0x01, 0x4C, 0x01, 0x24, 0x01, 0x6B,
+0xFF, 0x6C, 0x4C, 0xEC, 0x6C, 0xEC, 0x06, 0xD4,
+0x5A, 0xA1, 0x0F, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xFC, 0x9A, 0x91, 0x67, 0x01, 0x6D,
+0x18, 0x6E, 0x04, 0xD0, 0x00, 0x18, 0x30, 0x4B,
+0x06, 0x93, 0xFF, 0x6C, 0x4C, 0xEB, 0x8C, 0xEB,
+0x06, 0xD3, 0x07, 0x95, 0x91, 0x67, 0x00, 0x18,
+0xBF, 0x49, 0x06, 0x93, 0x01, 0x2A, 0x00, 0x6B,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x43, 0x67,
+0x06, 0x63, 0x00, 0xEF, 0xFD, 0x63, 0x05, 0x62,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0xBC, 0x9A,
+0x83, 0xF1, 0x08, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF6,
+0xB8, 0x9A, 0x81, 0xF7, 0x04, 0x6C, 0x00, 0x18,
+0x2B, 0x38, 0x30, 0xF0, 0x20, 0x6B, 0x61, 0xF3,
+0x64, 0x9B, 0x03, 0x2B, 0x50, 0x32, 0xEA, 0x6B,
+0x09, 0x10, 0x01, 0x73, 0x03, 0x61, 0x4C, 0x32,
+0x6C, 0x6B, 0x04, 0x10, 0x02, 0x73, 0x06, 0x61,
+0x48, 0x32, 0x34, 0x6B, 0x7A, 0xEA, 0x01, 0x2B,
+0xE5, 0xE8, 0x12, 0xEA, 0x05, 0x97, 0x03, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFB, 0x63, 0x09, 0x62,
+0x08, 0xD1, 0x07, 0xD0, 0x41, 0xF4, 0x10, 0x68,
+0x90, 0x67, 0x7F, 0x6D, 0x00, 0x18, 0x2B, 0x38,
+0x22, 0x67, 0xFE, 0x4A, 0xC2, 0x67, 0x90, 0x67,
+0x7F, 0x6D, 0x04, 0xD2, 0x00, 0x18, 0x39, 0x38,
+0x90, 0x67, 0xD1, 0x67, 0x7F, 0x6D, 0x00, 0x18,
+0x39, 0x38, 0x04, 0x96, 0x00, 0xF2, 0x00, 0x48,
+0x90, 0x67, 0x7F, 0x6D, 0x00, 0x18, 0x39, 0x38,
+0x90, 0x67, 0xD1, 0x67, 0x7F, 0x6D, 0x00, 0x18,
+0x39, 0x38, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0xED, 0x63, 0x25, 0x62,
+0x24, 0xD1, 0x23, 0xD0, 0x30, 0xF0, 0x20, 0x6E,
+0x24, 0x67, 0x10, 0x05, 0x00, 0xF1, 0x1C, 0x4E,
+0x30, 0x6F, 0x00, 0x18, 0xBA, 0x48, 0x20, 0xF0,
+0x45, 0xA1, 0x03, 0x72, 0x02, 0x60, 0x05, 0x72,
+0x0B, 0x61, 0x30, 0xF0, 0x20, 0x6E, 0x91, 0x67,
+0x04, 0x05, 0x40, 0xF1, 0x0C, 0x4E, 0x30, 0x6F,
+0x00, 0x18, 0xBA, 0x48, 0x01, 0x6A, 0x0A, 0x10,
+0x30, 0xF0, 0x20, 0x6E, 0x91, 0x67, 0x04, 0x05,
+0xE0, 0xF0, 0x0C, 0x4E, 0x30, 0x6F, 0x00, 0x18,
+0xBA, 0x48, 0x00, 0x6A, 0x20, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x48, 0xA2, 0x0F, 0x5A,
+0x0A, 0x60, 0x20, 0xF0, 0x0C, 0xA1, 0xFF, 0x6A,
+0xFF, 0x48, 0x4C, 0xE8, 0x02, 0x58, 0x18, 0x67,
+0x01, 0x6A, 0x4E, 0xE8, 0x09, 0x10, 0x20, 0xF0,
+0x0C, 0xA1, 0xFF, 0x6A, 0xFF, 0x48, 0x4C, 0xE8,
+0x02, 0x58, 0x18, 0x67, 0x03, 0x6A, 0x03, 0xE2,
+0x20, 0xF0, 0x45, 0xA1, 0x01, 0x72, 0x12, 0x60,
+0x04, 0x72, 0x10, 0x60, 0x06, 0x72, 0x0E, 0x60,
+0x07, 0x72, 0x0C, 0x60, 0x0B, 0x72, 0x0A, 0x60,
+0x02, 0x72, 0x02, 0x60, 0x09, 0x72, 0x19, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x48, 0xA2,
+0x0F, 0x5A, 0x13, 0x61, 0x04, 0x02, 0x08, 0x33,
+0x6D, 0xE2, 0xCC, 0x9B, 0x64, 0x40, 0x68, 0x33,
+0x6D, 0xE2, 0x6C, 0x9B, 0x1C, 0xD3, 0x67, 0x40,
+0x01, 0x4B, 0x68, 0x33, 0x69, 0xE2, 0x4C, 0x9A,
+0x1F, 0xD2, 0x00, 0x6A, 0x1D, 0xD2, 0x01, 0x6A,
+0x12, 0x10, 0x04, 0x02, 0x08, 0x33, 0x6D, 0xE2,
+0xC0, 0x9B, 0x64, 0x40, 0x68, 0x33, 0x6D, 0xE2,
+0x60, 0x9B, 0x1C, 0xD3, 0x67, 0x40, 0x01, 0x4B,
+0x68, 0x33, 0x69, 0xE2, 0x40, 0x9A, 0x1F, 0xD2,
+0x01, 0x6A, 0x1D, 0xD2, 0x00, 0x6A, 0x01, 0x6D,
+0x21, 0xF0, 0x0C, 0x6C, 0xAB, 0xED, 0x1E, 0xD2,
+0x00, 0x18, 0x39, 0x38, 0x1D, 0x92, 0x21, 0x22,
+0x20, 0xF0, 0x44, 0xA1, 0x01, 0x72, 0x04, 0x61,
+0x01, 0x70, 0x06, 0x60, 0x03, 0x70, 0x04, 0x60,
+0x20, 0x92, 0x08, 0x2A, 0x03, 0x70, 0x06, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF3, 0x44, 0x9A,
+0x01, 0x72, 0x06, 0x60, 0x20, 0xF0, 0x45, 0xA1,
+0x05, 0x72, 0x0B, 0x61, 0x03, 0x70, 0x09, 0x61,
+0x01, 0x6D, 0x30, 0xF0, 0x20, 0x6A, 0x21, 0xF0,
+0x10, 0x6C, 0xAB, 0xED, 0x40, 0xF7, 0xC0, 0x9A,
+0x05, 0x10, 0x1C, 0x96, 0x01, 0x6D, 0x21, 0xF0,
+0x10, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x39, 0x38,
+0x01, 0x68, 0x1F, 0x96, 0x0B, 0xE8, 0x21, 0xF0,
+0x18, 0x6C, 0xB0, 0x67, 0x00, 0x18, 0x39, 0x38,
+0x1E, 0x92, 0x0D, 0x22, 0x20, 0xF0, 0x44, 0xA1,
+0x01, 0x72, 0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF7, 0xC4, 0x9A, 0x21, 0xF0, 0x1C, 0x6C,
+0xB0, 0x67, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF3, 0x88, 0xA2, 0x00, 0x18,
+0x65, 0x49, 0x0C, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x44, 0x9A, 0x02, 0x72, 0x06, 0x61,
+0x21, 0xF0, 0x18, 0x6C, 0x01, 0x6D, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x25, 0x97, 0x24, 0x91,
+0x23, 0x90, 0x13, 0x63, 0x00, 0xEF, 0x00, 0x65,
+0xFA, 0x63, 0x0B, 0x62, 0x0A, 0xD1, 0x09, 0xD0,
+0xFF, 0x6A, 0xEC, 0xEA, 0x07, 0xD2, 0x0E, 0xD6,
+0x20, 0xF0, 0x6E, 0xA4, 0x24, 0x67, 0x05, 0x67,
+0x01, 0x6A, 0x00, 0xF2, 0x19, 0x2B, 0x66, 0x67,
+0xAD, 0xEB, 0xFB, 0x4A, 0x6C, 0xEA, 0x00, 0xF2,
+0x12, 0x2A, 0x01, 0x6A, 0x6C, 0xEA, 0x07, 0x22,
+0x01, 0xF4, 0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x26, 0xF2, 0x11, 0x6E, 0x06, 0x10, 0x01, 0xF4,
+0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D, 0x02, 0xF1,
+0x11, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x0E, 0x92,
+0x02, 0x6B, 0x0D, 0xEA, 0x6C, 0xEA, 0x07, 0x22,
+0x01, 0xF6, 0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x26, 0xF2, 0x11, 0x6E, 0x06, 0x10, 0x01, 0xF6,
+0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D, 0x02, 0xF1,
+0x11, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF7, 0xA8, 0x9A, 0x21, 0xF1,
+0x1C, 0x6C, 0x03, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0xB8, 0x9A,
+0x01, 0xF0, 0x0C, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4,
+0xBC, 0x9A, 0x01, 0xF0, 0x0C, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x01, 0x6A, 0x0C, 0xEA,
+0x11, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0xB4, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x04, 0x6C, 0x40, 0xF7, 0xAC, 0x9A,
+0x08, 0x6E, 0x13, 0x10, 0x02, 0x6A, 0x0C, 0xEA,
+0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF7,
+0xB4, 0x9A, 0x21, 0xF1, 0x1C, 0x6C, 0x02, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF7, 0xAC, 0x9A, 0x01, 0xF2, 0x04, 0x6C,
+0x04, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x4F, 0x40,
+0x02, 0x5A, 0x06, 0x60, 0x41, 0xF1, 0x00, 0x6C,
+0xFF, 0xF7, 0x10, 0x6D, 0x01, 0x6E, 0x05, 0x10,
+0x41, 0xF1, 0x00, 0x6C, 0xFF, 0xF7, 0x10, 0x6D,
+0x43, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x10, 0x36,
+0x01, 0xF0, 0x0C, 0x6C, 0xFF, 0x6D, 0x0D, 0xEE,
+0x00, 0x18, 0x39, 0x38, 0x4F, 0x40, 0x02, 0x5A,
+0x17, 0x61, 0x07, 0x93, 0x03, 0x2B, 0x50, 0x99,
+0x40, 0xA2, 0x12, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x00, 0xF7, 0xB4, 0x9A, 0x21, 0xF1, 0x1C, 0x6C,
+0x43, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF7, 0xAC, 0x9A, 0x01, 0xF2,
+0x04, 0x6C, 0x0C, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x20, 0xF7, 0xBC, 0x9A,
+0x21, 0xF2, 0x0C, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0xAC, 0x9A, 0x21, 0xF2, 0x0C, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x0E, 0x93, 0x01, 0x6A,
+0x6C, 0xEA, 0x08, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x01, 0xF2, 0x04, 0x6C, 0x40, 0xF7, 0xB0, 0x9A,
+0x00, 0x6E, 0x0B, 0x10, 0x0E, 0x93, 0x02, 0x6A,
+0x6C, 0xEA, 0x09, 0x22, 0x30, 0xF0, 0x20, 0x6A,
+0x40, 0xF7, 0xB0, 0x9A, 0x01, 0xF2, 0x04, 0x6C,
+0x05, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x0E, 0x92,
+0x01, 0xF0, 0x08, 0x6C, 0xFF, 0x6D, 0x50, 0x36,
+0x4D, 0xEE, 0x00, 0x18, 0x39, 0x38, 0x0E, 0x92,
+0xFF, 0x4A, 0x02, 0x5A, 0x1A, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF4, 0xB8, 0x9A, 0x03, 0xF1,
+0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0xB0, 0x9A,
+0x01, 0xF0, 0x00, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x41, 0xF0,
+0x10, 0x6C, 0x40, 0xF7, 0xB4, 0x9A, 0x00, 0x6E,
+0x19, 0x10, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0xB8, 0x9A, 0x03, 0xF1, 0x04, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0xB0, 0x9A, 0x01, 0xF0, 0x00, 0x6C,
+0x01, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x40, 0xF7, 0xB4, 0x9A, 0x41, 0xF0,
+0x10, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x03, 0x6A, 0x4C, 0xE8, 0x20, 0xF0, 0x0B, 0xC1,
+0x0E, 0x93, 0x00, 0x68, 0x6C, 0xEA, 0x20, 0xF0,
+0x4C, 0xC1, 0x01, 0x6A, 0x06, 0xD2, 0x30, 0xF0,
+0x20, 0x6B, 0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6,
+0x1C, 0x4A, 0x00, 0xF5, 0x10, 0x4B, 0x60, 0x9B,
+0xE0, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0xEF, 0x6E,
+0x04, 0xD3, 0x00, 0x18, 0x30, 0x4B, 0x07, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x1C, 0x4A,
+0xE0, 0x9A, 0x01, 0x6B, 0x00, 0x6D, 0x33, 0x6E,
+0x91, 0x67, 0x04, 0xD3, 0x00, 0x18, 0x30, 0x4B,
+0x07, 0x93, 0x02, 0x6C, 0x6C, 0xEA, 0x06, 0x93,
+0x4C, 0xEB, 0x06, 0xD3, 0x00, 0x18, 0x4C, 0x2C,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x1C, 0x4A,
+0xE0, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0x33, 0x6E,
+0x00, 0x18, 0x1F, 0x4B, 0x01, 0x72, 0x07, 0x60,
+0x01, 0x48, 0xFF, 0xF7, 0x1F, 0x6A, 0x4C, 0xE8,
+0x64, 0x70, 0xC9, 0x61, 0xC8, 0x10, 0x50, 0x99,
+0x40, 0xA2, 0x07, 0x2A, 0x4F, 0x99, 0x40, 0xA2,
+0x04, 0x2A, 0x20, 0xF0, 0x70, 0xA1, 0x07, 0xD3,
+0x50, 0x23, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0x50, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0x04, 0xD2,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x1C, 0x4A,
+0xE0, 0x9A, 0xEF, 0x6E, 0x00, 0x18, 0x30, 0x4B,
+0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6, 0x1C, 0x4B,
+0xE0, 0x9B, 0x02, 0x67, 0x91, 0x67, 0x01, 0x6A,
+0x00, 0x6D, 0x33, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0x30, 0x4B, 0x30, 0xF0, 0x20, 0x6B, 0xE0, 0xF6,
+0x1C, 0x4B, 0x4C, 0xE8, 0x06, 0x92, 0xE0, 0x9B,
+0x91, 0x67, 0x4C, 0xE8, 0x00, 0x6D, 0x34, 0x6A,
+0x3E, 0x6E, 0x04, 0xD2, 0x00, 0x18, 0x30, 0x4B,
+0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A,
+0xE0, 0xF6, 0x1C, 0x4B, 0x4C, 0xE8, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0x9B, 0x40, 0xF7, 0x58, 0x9A,
+0x91, 0x67, 0x00, 0x6D, 0x3F, 0x6E, 0x04, 0xD2,
+0x00, 0x18, 0x30, 0x4B, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF6, 0x1C, 0x4B, 0x4C, 0xE8, 0xE0, 0x9B,
+0xFF, 0x6A, 0x4C, 0xE8, 0x00, 0x6A, 0x91, 0x67,
+0xA2, 0x67, 0xEF, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0x30, 0x4B, 0x4C, 0xE8, 0xFF, 0x6A, 0x4C, 0xE8,
+0x52, 0x10, 0x30, 0xF0, 0x20, 0x6B, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x1C, 0x4A, 0x00, 0xF5,
+0x10, 0x4B, 0x60, 0x9B, 0xE0, 0x9A, 0x91, 0x67,
+0x00, 0x6D, 0xEF, 0x6E, 0x04, 0xD3, 0x00, 0x18,
+0x30, 0x4B, 0x02, 0x67, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0x1C, 0x4A, 0xE0, 0x9A, 0x01, 0x6B,
+0x91, 0x67, 0x00, 0x6D, 0x33, 0x6E, 0x04, 0xD3,
+0x00, 0x18, 0x30, 0x4B, 0x06, 0x93, 0x4C, 0xE8,
+0xFF, 0x6A, 0x6C, 0xE8, 0x30, 0xF0, 0x20, 0x6B,
+0xE0, 0xF6, 0x1C, 0x4B, 0xE0, 0x9B, 0x4C, 0xE8,
+0x91, 0x67, 0x34, 0x6A, 0x00, 0x6D, 0x3E, 0x6E,
+0x04, 0xD2, 0x00, 0x18, 0x30, 0x4B, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6B, 0xFF, 0x6A, 0xE0, 0xF6,
+0x1C, 0x4B, 0x4C, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0x9B, 0x40, 0xF7, 0x5C, 0x9A, 0x91, 0x67,
+0x00, 0x6D, 0x3F, 0x6E, 0x04, 0xD2, 0x00, 0x18,
+0x30, 0x4B, 0x4C, 0xE8, 0xFF, 0x6A, 0x4C, 0xE8,
+0x30, 0xF0, 0x20, 0x6A, 0xE0, 0xF6, 0x1C, 0x4A,
+0x07, 0x93, 0xE0, 0x9A, 0x91, 0x67, 0x00, 0x6D,
+0xEF, 0x6E, 0x04, 0xD3, 0x00, 0x18, 0x30, 0x4B,
+0x4C, 0xE8, 0xFF, 0x6B, 0x6C, 0xE8, 0x00, 0x6A,
+0x04, 0xD2, 0xA2, 0x67, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xFC, 0x9A, 0x91, 0x67, 0xEF, 0x6E,
+0x00, 0x18, 0x30, 0x4B, 0x0C, 0xEA, 0x0F, 0x22,
+0x91, 0x67, 0x00, 0x18, 0xD3, 0x4B, 0x91, 0x67,
+0x00, 0x18, 0xE7, 0x4B, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0xA8, 0xA2, 0x91, 0x67, 0x00, 0x18,
+0xBF, 0x49, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xFA, 0x63, 0x0B, 0x62,
+0x0A, 0xD1, 0x09, 0xD0, 0x0E, 0xD6, 0x20, 0xF0,
+0x6E, 0xA4, 0xFF, 0x68, 0x24, 0x67, 0xAC, 0xE8,
+0x01, 0x6A, 0x80, 0xF1, 0x11, 0x2B, 0x07, 0x5E,
+0x80, 0xF1, 0x0D, 0x60, 0x01, 0x76, 0x02, 0x61,
+0x03, 0x58, 0x04, 0x10, 0x0E, 0x93, 0x02, 0x73,
+0x03, 0x61, 0x05, 0x58, 0x80, 0xF1, 0x03, 0x60,
+0x0E, 0x94, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0x6D,
+0x61, 0xF3, 0x84, 0xDA, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xFC, 0x9A, 0x91, 0x67, 0x18, 0x6E,
+0x00, 0x18, 0x1F, 0x4B, 0x06, 0xD2, 0x0E, 0x92,
+0x07, 0x5A, 0x08, 0x60, 0x48, 0x33, 0x30, 0xF0,
+0x20, 0x6A, 0x80, 0xF2, 0x10, 0x4A, 0x69, 0xE2,
+0x40, 0x9A, 0x00, 0xEA, 0x06, 0x90, 0x26, 0x11,
+0xA1, 0xF0, 0x0C, 0x68, 0x90, 0x67, 0xFF, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x90, 0x67,
+0x00, 0xF3, 0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0xB8, 0x9A, 0x90, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7,
+0xA0, 0x9A, 0x90, 0x67, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4,
+0xB0, 0x9A, 0x90, 0x67, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0xC1, 0xF0,
+0x04, 0x6C, 0xA0, 0xF4, 0xBC, 0x9A, 0xB7, 0x10,
+0x0F, 0x6E, 0x0C, 0xEE, 0x01, 0x6A, 0xC8, 0x36,
+0xA1, 0xF0, 0x0C, 0x6C, 0xFF, 0x6D, 0x4D, 0xEE,
+0x00, 0x18, 0x39, 0x38, 0x01, 0x70, 0x05, 0x61,
+0x01, 0xF2, 0x00, 0x6C, 0x10, 0x6D, 0x01, 0x6E,
+0x04, 0x10, 0x01, 0xF2, 0x00, 0x6C, 0x10, 0x6D,
+0x00, 0x6E, 0xA1, 0xF0, 0x0C, 0x68, 0x00, 0x18,
+0x39, 0x38, 0x90, 0x67, 0x01, 0xF4, 0x00, 0x6D,
+0x00, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0xA8, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF7, 0xA4, 0x9A, 0x90, 0x67,
+0x00, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF4, 0xB4, 0x9A, 0x90, 0x67,
+0x01, 0x6E, 0x00, 0x18, 0x39, 0x38, 0x30, 0xF0,
+0x20, 0x6A, 0xA0, 0xF4, 0xBC, 0x9A, 0xC1, 0xF0,
+0x04, 0x6C, 0x01, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x06, 0x94, 0x5D, 0xF3, 0x13, 0x48, 0x01, 0xF0,
+0x00, 0x6A, 0x8C, 0xE8, 0x3A, 0x10, 0x0F, 0x6E,
+0x0C, 0xEE, 0x02, 0x6A, 0xC8, 0x36, 0x4D, 0xEE,
+0xA1, 0xF0, 0x0C, 0x6C, 0xFF, 0x6D, 0x00, 0x18,
+0x39, 0x38, 0xA1, 0xF0, 0x0C, 0x6C, 0x06, 0xF0,
+0x00, 0x6D, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0xAC, 0x9A,
+0xA1, 0xF0, 0x0C, 0x6C, 0x01, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF6,
+0xB0, 0x9A, 0xA1, 0xF0, 0x0C, 0x6C, 0x00, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A,
+0xA0, 0xF4, 0x1C, 0x9A, 0xA1, 0xF0, 0x0C, 0x6C,
+0x01, 0x6E, 0xB0, 0x67, 0x00, 0x18, 0x39, 0x38,
+0xB0, 0x67, 0xC1, 0xF0, 0x04, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x06, 0x92, 0x01, 0xF4,
+0x01, 0x68, 0x0B, 0xE8, 0x4C, 0xE8, 0x00, 0xF4,
+0x00, 0x6A, 0x4D, 0xE8, 0x77, 0x10, 0xA1, 0xF0,
+0x0C, 0x68, 0x90, 0x67, 0xFF, 0x6D, 0x40, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x02, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0xB8, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0xA0, 0x9A,
+0x90, 0x67, 0x02, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0xB0, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0xBC, 0x9A,
+0xC1, 0xF0, 0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0xB4, 0x9A, 0xC1, 0xF0, 0x08, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x06, 0x93, 0x40, 0xF3,
+0x14, 0x48, 0x6D, 0xE8, 0x3B, 0x10, 0xA1, 0xF0,
+0x0C, 0x68, 0x90, 0x67, 0xFF, 0x6D, 0x80, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x90, 0x67, 0x00, 0xF3,
+0x00, 0x6D, 0x03, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4, 0xB8, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0xA0, 0x9A,
+0x90, 0x67, 0x03, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0xB0, 0x9A,
+0x90, 0x67, 0x00, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x30, 0xF0, 0x20, 0x6A, 0xA0, 0xF4, 0xBC, 0x9A,
+0xC1, 0xF0, 0x04, 0x6C, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x30, 0xF0, 0x20, 0x6A, 0x80, 0xF4,
+0xB4, 0x9A, 0xC1, 0xF0, 0x08, 0x6C, 0x01, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x06, 0x94, 0x40, 0xF3,
+0x14, 0x48, 0x8D, 0xE8, 0x30, 0xF0, 0x20, 0x6A,
+0xE0, 0xF6, 0xFC, 0x9A, 0x91, 0x67, 0x00, 0x6D,
+0x18, 0x6E, 0x04, 0xD0, 0x00, 0x18, 0x30, 0x4B,
+0x06, 0x94, 0x00, 0x6B, 0x01, 0x4C, 0x01, 0x24,
+0x01, 0x6B, 0xFF, 0x6C, 0x4C, 0xEC, 0x6C, 0xEC,
+0x06, 0xD4, 0x5A, 0xA1, 0x0F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0xFC, 0x9A, 0x91, 0x67,
+0x01, 0x6D, 0x18, 0x6E, 0x04, 0xD0, 0x00, 0x18,
+0x30, 0x4B, 0x06, 0x93, 0xFF, 0x6C, 0x4C, 0xEB,
+0x8C, 0xEB, 0x06, 0xD3, 0x06, 0x92, 0x1B, 0x22,
+0x0E, 0x95, 0x91, 0x67, 0x01, 0xF0, 0x08, 0x68,
+0x00, 0x18, 0x92, 0x49, 0x91, 0x67, 0x00, 0x18,
+0xD3, 0x4B, 0x91, 0x67, 0x00, 0x18, 0xE7, 0x4B,
+0x90, 0x67, 0xFF, 0x6D, 0x00, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x20, 0xF0, 0x4C, 0xA1, 0x90, 0x67,
+0xFF, 0x6D, 0x50, 0x36, 0x4D, 0xEE, 0x00, 0x18,
+0x39, 0x38, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x0B, 0x97, 0x0A, 0x91, 0x09, 0x90, 0x06, 0x63,
+0x00, 0xEF, 0x00, 0x65, 0xF3, 0x63, 0x19, 0x62,
+0x18, 0xD1, 0x17, 0xD0, 0xFF, 0x68, 0xAC, 0xE8,
+0x30, 0xF0, 0x20, 0x6D, 0x24, 0x67, 0xC0, 0xF2,
+0x14, 0x4D, 0x06, 0x04, 0x0F, 0x6E, 0x00, 0x18,
+0xF0, 0x2B, 0x30, 0xF0, 0x20, 0x6D, 0x0E, 0x04,
+0xA0, 0xF2, 0x1C, 0x4D, 0x17, 0x6E, 0x00, 0x18,
+0xF0, 0x2B, 0x30, 0xF0, 0x20, 0x6D, 0x0A, 0x04,
+0xA0, 0xF2, 0x0C, 0x4D, 0x0F, 0x6E, 0x00, 0x18,
+0xF0, 0x2B, 0x20, 0xF0, 0x6E, 0xA1, 0x01, 0x6A,
+0x80, 0xF1, 0x02, 0x2B, 0x30, 0xF0, 0x20, 0x6A,
+0x61, 0xF3, 0x08, 0xC2, 0x61, 0xF3, 0xA8, 0xA2,
+0x02, 0x6B, 0x0F, 0x5D, 0x58, 0x67, 0x4B, 0xE3,
+0x20, 0xF0, 0x72, 0xA1, 0x4A, 0xEB, 0x03, 0x60,
+0x91, 0x67, 0x00, 0x18, 0xBF, 0x49, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0xFC, 0x9A, 0x91, 0x67,
+0x00, 0x6D, 0x18, 0x6E, 0x00, 0x18, 0x1F, 0x4B,
+0x14, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7,
+0x48, 0x9A, 0x14, 0x93, 0x0F, 0x58, 0x6C, 0xEA,
+0x36, 0x60, 0x0D, 0xEA, 0x41, 0xF1, 0x18, 0x6C,
+0x1F, 0x6D, 0x00, 0x6E, 0x15, 0xD2, 0x00, 0x18,
+0x39, 0x38, 0x00, 0x6A, 0x40, 0xF0, 0x48, 0xC1,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0xAC, 0x9A,
+0x61, 0xF0, 0x00, 0x6C, 0x61, 0xF1, 0x0A, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x0E, 0x70, 0x0E, 0x61,
+0x01, 0x6D, 0x21, 0xF2, 0x04, 0x6C, 0xAB, 0xED,
+0x6C, 0xF5, 0x17, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x21, 0xF2, 0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x00, 0x6E, 0x76, 0x10, 0x30, 0xF0, 0x20, 0x6A,
+0x60, 0xF7, 0xD0, 0x9A, 0x01, 0x6D, 0x21, 0xF2,
+0x04, 0x6C, 0xAB, 0xED, 0x00, 0x18, 0x39, 0x38,
+0x21, 0xF2, 0x08, 0x6C, 0xFF, 0xF7, 0x1F, 0x6D,
+0x22, 0xF5, 0x05, 0x6E, 0x65, 0x10, 0x24, 0x58,
+0x20, 0xF1, 0x05, 0x61, 0x0D, 0xEA, 0x68, 0x40,
+0x15, 0xD2, 0xE4, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB,
+0x1D, 0x5B, 0x08, 0x60, 0x41, 0xF1, 0x18, 0x6C,
+0x1F, 0x6D, 0x01, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x01, 0x6A, 0x17, 0x10, 0x68, 0x40, 0xA4, 0x4B,
+0x4C, 0xEB, 0x2D, 0x5B, 0x08, 0x60, 0x41, 0xF1,
+0x18, 0x6C, 0x1F, 0x6D, 0x02, 0x6E, 0x00, 0x18,
+0x39, 0x38, 0x02, 0x6A, 0x0A, 0x10, 0x95, 0x58,
+0x00, 0xF1, 0x05, 0x61, 0x41, 0xF1, 0x18, 0x6C,
+0x1F, 0x6D, 0x03, 0x6E, 0x00, 0x18, 0x39, 0x38,
+0x03, 0x6A, 0x68, 0x40, 0x40, 0xF0, 0x48, 0xC1,
+0xE4, 0x4B, 0xFF, 0x6A, 0x4C, 0xEB, 0x0D, 0x5B,
+0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x00, 0x6C, 0x60, 0xF7, 0xAC, 0x9A, 0x80, 0xF4,
+0x14, 0x6E, 0x2A, 0x10, 0x68, 0x40, 0xD4, 0x4B,
+0x4C, 0xEB, 0x0D, 0x5B, 0x09, 0x60, 0x30, 0xF0,
+0x20, 0x6A, 0x61, 0xF0, 0x00, 0x6C, 0x60, 0xF7,
+0xAC, 0x9A, 0x40, 0xF4, 0x13, 0x6E, 0x1C, 0x10,
+0x68, 0x40, 0xA4, 0x4B, 0x4C, 0xEB, 0x11, 0x5B,
+0x09, 0x60, 0x30, 0xF0, 0x20, 0x6A, 0x61, 0xF0,
+0x00, 0x6C, 0x60, 0xF7, 0xAC, 0x9A, 0x40, 0xF4,
+0x12, 0x6E, 0x0E, 0x10, 0x68, 0x40, 0x92, 0x4B,
+0x4C, 0xEB, 0x3C, 0x5B, 0xC0, 0xF0, 0x0B, 0x60,
+0x30, 0xF0, 0x20, 0x6A, 0x60, 0xF7, 0xAC, 0x9A,
+0x61, 0xF0, 0x00, 0x6C, 0x00, 0xF4, 0x12, 0x6E,
+0x00, 0x18, 0x39, 0x38, 0x50, 0x99, 0x40, 0xA2,
+0x01, 0x72, 0x11, 0x61, 0x20, 0xF0, 0x45, 0xA1,
+0x03, 0x72, 0x02, 0x60, 0x05, 0x72, 0x0B, 0x61,
+0x0E, 0x70, 0x05, 0x61, 0x91, 0x67, 0x26, 0x6D,
+0x00, 0x18, 0xAF, 0x48, 0xB6, 0x10, 0x91, 0x67,
+0x20, 0x6D, 0x00, 0x18, 0xAF, 0x48, 0x0F, 0x58,
+0xA0, 0xF0, 0x0F, 0x61, 0x68, 0x40, 0xE4, 0x4B,
+0xFF, 0x6A, 0x83, 0x67, 0x4C, 0xEC, 0x1D, 0x5C,
+0x05, 0x60, 0x67, 0x33, 0x9D, 0x67, 0x6D, 0xE4,
+0x58, 0xA3, 0x19, 0x10, 0x68, 0x40, 0xA4, 0x4B,
+0x83, 0x67, 0x4C, 0xEC, 0x2D, 0x5C, 0x06, 0x60,
+0x5D, 0x67, 0x67, 0x33, 0x6D, 0xE2, 0x20, 0xF0,
+0x58, 0xA3, 0x0D, 0x10, 0x67, 0x40, 0x64, 0x4B,
+0x4C, 0xEB, 0x1D, 0x5B, 0x80, 0xF0, 0x0B, 0x60,
+0x6F, 0xF7, 0x4B, 0x40, 0x47, 0x32, 0x7D, 0x67,
+0x49, 0xE3, 0x20, 0xF0, 0x48, 0xA2, 0xFF, 0x72,
+0x80, 0xF0, 0x01, 0x60, 0x04, 0xD2, 0x30, 0xF0,
+0x20, 0x6A, 0x60, 0xF7, 0xF4, 0x9A, 0x91, 0x67,
+0x00, 0x6D, 0xBE, 0x6E, 0x00, 0x18, 0x30, 0x4B,
+0x14, 0x94, 0x00, 0x6B, 0x01, 0x4C, 0x01, 0x24,
+0x01, 0x6B, 0xFF, 0x6C, 0x4C, 0xEC, 0x6C, 0xEC,
+0x90, 0x70, 0x14, 0xD4, 0x11, 0x61, 0x01, 0x6A,
+0x04, 0xD2, 0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5,
+0xEC, 0x9A, 0x91, 0x67, 0x00, 0x6D, 0xDF, 0x6E,
+0x00, 0x18, 0x30, 0x4B, 0x14, 0x93, 0xFF, 0x6C,
+0x4C, 0xEB, 0x8C, 0xEB, 0x14, 0xD3, 0x1C, 0x10,
+0x00, 0x6A, 0x04, 0xD2, 0xA2, 0x67, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x0C, 0x4A, 0xE0, 0x9A,
+0x91, 0x67, 0xDF, 0x6E, 0x00, 0x18, 0x30, 0x4B,
+0x14, 0x93, 0xFF, 0x6C, 0x91, 0x58, 0x4C, 0xEB,
+0x8C, 0xEB, 0x14, 0xD3, 0x07, 0x61, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x0C, 0x4A, 0x15, 0x93,
+0x40, 0x9A, 0x07, 0x10, 0x50, 0x58, 0x07, 0x61,
+0x30, 0xF0, 0x20, 0x6A, 0x00, 0xF5, 0x48, 0x9A,
+0x15, 0x93, 0x4D, 0xEB, 0x15, 0xD3, 0x30, 0xF0,
+0x20, 0x6A, 0x15, 0x94, 0xE0, 0xF6, 0x1C, 0x4A,
+0xE0, 0x9A, 0x04, 0xD4, 0x00, 0x6D, 0x91, 0x67,
+0x18, 0x6E, 0x00, 0x18, 0x30, 0x4B, 0x14, 0x90,
+0x4C, 0xE8, 0x5A, 0xA1, 0x0F, 0x22, 0x30, 0xF0,
+0x20, 0x6A, 0xE0, 0xF6, 0x1C, 0x4A, 0x15, 0x93,
+0xE0, 0x9A, 0x91, 0x67, 0x01, 0x6D, 0x18, 0x6E,
+0x04, 0xD3, 0x00, 0x18, 0x30, 0x4B, 0x4C, 0xE8,
+0xFF, 0x6A, 0x4C, 0xE8, 0x18, 0x20, 0x30, 0xF0,
+0x20, 0x6A, 0x00, 0xF5, 0x10, 0x9A, 0x00, 0x6C,
+0xE4, 0x67, 0xB8, 0x6D, 0xD0, 0x67, 0x00, 0x18,
+0x11, 0x39, 0xB8, 0x6D, 0xD0, 0x67, 0x01, 0x6F,
+0x00, 0x6C, 0x00, 0x18, 0x11, 0x39, 0x91, 0x67,
+0x00, 0x18, 0xD3, 0x4B, 0x91, 0x67, 0x00, 0x18,
+0xE7, 0x4B, 0x01, 0x6A, 0x01, 0x10, 0x00, 0x6A,
+0x19, 0x97, 0x18, 0x91, 0x17, 0x90, 0x0D, 0x63,
+0x00, 0xEF, 0x00, 0x6A, 0x77, 0x17, 0x00, 0x65,
+0xFB, 0x63, 0x09, 0x62, 0x08, 0xD1, 0x07, 0xD0,
+0xFF, 0x68, 0x0C, 0xED, 0x24, 0x67, 0x0D, 0xD7,
+0x04, 0xD5, 0xCC, 0xE8, 0x00, 0x18, 0x51, 0x4B,
+0x0F, 0x22, 0x04, 0x95, 0x91, 0x67, 0x00, 0x18,
+0x3F, 0x4E, 0x0A, 0x22, 0x0D, 0x96, 0x91, 0x67,
+0xB0, 0x67, 0x00, 0x18, 0x6D, 0x4D, 0x4B, 0xEB,
+0x4D, 0xEB, 0xC0, 0xF7, 0x62, 0x32, 0x01, 0x10,
+0x00, 0x6A, 0x09, 0x97, 0x08, 0x91, 0x07, 0x90,
+0x05, 0x63, 0x00, 0xEF, 0x51, 0x0B, 0x00, 0x00,
+0xA9, 0xA6, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+};
+
+u32 array_length_mp_8822b_fw_wowlan = 84024;
+
+#endif /*CONFIG_WOWLAN*/
+
+#endif
+
+#endif /* end of LOAD_FW_HEADER_FROM_DRIVER */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/hal8822b_fw.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/hal8822b_fw.h
new file mode 100644
index 000000000000..5968ac8e69c0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/hal8822b_fw.h
@@ -0,0 +1,40 @@
+/******************************************************************************
+*
+* Copyright(c) 2012 - 2017 Realtek Corporation.
+*
+* 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.
+*
+******************************************************************************/
+
+#ifdef CONFIG_RTL8822B
+
+#ifndef _FW_HEADER_8822B_H
+#define _FW_HEADER_8822B_H
+
+#ifdef LOAD_FW_HEADER_FROM_DRIVER
+#if (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))
+extern u8 array_mp_8822b_fw_ap[104632];
+extern u32 array_length_mp_8822b_fw_ap;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN)) || (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+extern u8 array_mp_8822b_fw_nic[145104];
+extern u32 array_length_mp_8822b_fw_nic;
+#ifdef CONFIG_WOWLAN
+extern u8 array_mp_8822b_fw_wowlan[84024];
+extern u32 array_length_mp_8822b_fw_wowlan;
+#endif /*CONFIG_WOWLAN*/
+#endif
+#endif /* end of LOAD_FW_HEADER_FROM_DRIVER */
+
+#endif
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b.h
new file mode 100644
index 000000000000..79545c43d9d4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b.h
@@ -0,0 +1,142 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_H_
+#define _RTL8822B_H_
+
+#include <drv_types.h>		/* PADAPTER */
+#include <rtw_rf.h>		/* CHANNEL_WIDTH */
+#include <rtw_xmit.h>		/* struct pkt_attrib, struct xmit_frame */
+#include <rtw_recv.h>		/* struct recv_frame */
+#include <hal_intf.h>		/* HAL_DEF_VARIABLE */
+#include "hal8822b_fw.h"	/* FW array */
+
+#define DRIVER_EARLY_INT_TIME_8822B	0x05
+#define BCN_DMA_ATIME_INT_TIME_8822B	0x02
+
+/* rtl8822b_ops.c */
+struct hw_port_reg {
+	u32 net_type;	/*reg_offset*/
+	u8 net_type_shift;
+	u32 macaddr;	/*reg_offset*/
+	u32 bssid;	/*reg_offset*/
+	u32 bcn_ctl;			/*reg_offset*/
+	u32 tsf_rst;			/*reg_offset*/
+	u8 tsf_rst_bit;
+	u32 bcn_space;		/*reg_offset*/
+	u8 bcn_space_shift;
+	u16 bcn_space_mask;
+	u32	ps_aid;			/*reg_offset*/
+};
+
+
+/* rtl8822b_halinit.c */
+void rtl8822b_init_hal_spec(PADAPTER);
+u32 rtl8822b_power_on(PADAPTER);
+void rtl8822b_power_off(PADAPTER);
+u8 rtl8822b_hal_init(PADAPTER);
+u8 rtl8822b_mac_verify(PADAPTER);
+void rtl8822b_init_misc(PADAPTER padapter);
+u32 rtl8822b_init(PADAPTER);
+u32 rtl8822b_deinit(PADAPTER);
+void rtl8822b_init_default_value(PADAPTER);
+
+/* rtl8822b_mac.c */
+u8 rtl8822b_rcr_config(PADAPTER, u32 rcr);
+u8 rtl8822b_rx_ba_ssn_appended(PADAPTER);
+u8 rtl8822b_rx_fcs_append_switch(PADAPTER, u8 enable);
+u8 rtl8822b_rx_fcs_appended(PADAPTER);
+u8 rtl8822b_rx_tsf_addr_filter_config(PADAPTER, u8 config);
+s32 rtl8822b_fw_dl(PADAPTER, u8 wowlan);
+u8 rtl8822b_get_rx_drv_info_size(struct _ADAPTER *a);
+u32 rtl8822b_get_tx_desc_size(struct _ADAPTER *a);
+u32 rtl8822b_get_rx_desc_size(struct _ADAPTER *a);
+
+/* rtl8822b_ops.c */
+u8 rtl8822b_read_efuse(PADAPTER);
+void rtl8822b_run_thread(PADAPTER);
+void rtl8822b_cancel_thread(PADAPTER);
+u8 rtl8822b_sethwreg(PADAPTER, u8 variable, u8 *pval);
+void rtl8822b_gethwreg(PADAPTER, u8 variable, u8 *pval);
+u8 rtl8822b_sethaldefvar(PADAPTER, HAL_DEF_VARIABLE, void *pval);
+u8 rtl8822b_gethaldefvar(PADAPTER, HAL_DEF_VARIABLE, void *pval);
+void rtl8822b_set_hal_ops(PADAPTER);
+
+/* tx */
+void rtl8822b_fill_txdesc_sectype(struct pkt_attrib *, u8 *ptxdesc);
+void rtl8822b_fill_txdesc_vcs(PADAPTER, struct pkt_attrib *, u8 *ptxdesc);
+void rtl8822b_fill_txdesc_phy(PADAPTER, struct pkt_attrib *, u8 *ptxdesc);
+void rtl8822b_fill_txdesc_force_bmc_camid(struct pkt_attrib *, u8 *ptxdesc);
+void rtl8822b_fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+u8 rtl8822b_bw_mapping(PADAPTER, struct pkt_attrib *);
+u8 rtl8822b_sc_mapping(PADAPTER, struct pkt_attrib *);
+void rtl8822b_fill_txdesc_bf(struct xmit_frame *, u8 *desc);
+void rtl8822b_fill_txdesc_mgnt_bf(struct xmit_frame *, u8 *desc);
+void rtl8822b_cal_txdesc_chksum(PADAPTER, u8 *ptxdesc);
+void rtl8822b_update_txdesc(struct xmit_frame *, u8 *pbuf);
+void rtl8822b_dbg_dump_tx_desc(PADAPTER, int frame_tag, u8 *ptxdesc);
+
+/* rx */
+void rtl8822b_rxdesc2attribute(struct rx_pkt_attrib *a, u8 *desc);
+void rtl8822b_query_rx_desc(union recv_frame *, u8 *pdesc);
+
+/* rtl8822b_cmd.c */
+s32 rtl8822b_fillh2ccmd(PADAPTER, u8 id, u32 buf_len, u8 *pbuf);
+void rtl8822b_set_FwMediaStatusRpt_cmd(PADAPTER, u8 mstatus, u8 macid);
+void rtl8822b_set_FwRssiSetting_cmd(PADAPTER, u8 *param);
+void rtl8822b_set_FwPwrMode_cmd(PADAPTER, u8 psmode);
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8822b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
+
+void rtl8822b_set_FwPwrModeInIPS_cmd(PADAPTER adapter, u8 cmd_param);
+void rtl8822b_req_txrpt_cmd(PADAPTER, u8 macid);
+void rtl8822b_fw_update_beacon_cmd(PADAPTER);
+void rtl8822b_c2h_handler(PADAPTER, u8 *pbuf, u16 length);
+void rtl8822b_c2h_handler_no_io(PADAPTER, u8 *pbuf, u16 length);
+
+#ifdef CONFIG_BT_COEXIST
+void rtl8822b_download_BTCoex_AP_mode_rsvd_page(PADAPTER);
+#endif /* CONFIG_BT_COEXIST */
+
+/* rtl8822b_phy.c */
+u8 rtl8822b_phy_init_mac_register(PADAPTER);
+u8 rtl8822b_phy_init(PADAPTER);
+void rtl8822b_phy_init_dm_priv(PADAPTER);
+void rtl8822b_phy_deinit_dm_priv(PADAPTER);
+void rtl8822b_phy_init_haldm(PADAPTER);
+void rtl8822b_phy_haldm_watchdog(PADAPTER);
+u32 rtl8822b_read_bb_reg(PADAPTER, u32 addr, u32 mask);
+void rtl8822b_write_bb_reg(PADAPTER, u32 addr, u32 mask, u32 val);
+u32 rtl8822b_read_rf_reg(PADAPTER adapter, enum rf_path path, u32 addr, u32 mask);
+void rtl8822b_write_rf_reg(PADAPTER adapter, enum rf_path path, u32 addr, u32 mask, u32 val);
+void rtl8822b_set_channel_bw(PADAPTER adapter, u8 center_ch, enum channel_width, u8 offset40, u8 offset80);
+void rtl8822b_set_tx_power_level(PADAPTER, u8 channel);
+void rtl8822b_get_tx_power_level(PADAPTER, s32 *power);
+void rtl8822b_set_tx_power_index(PADAPTER adapter, u32 powerindex, enum rf_path rfpath, u8 rate);
+u8 rtl8822b_get_tx_power_index(PADAPTER adapter, enum rf_path rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);
+void rtl8822b_notch_filter_switch(PADAPTER, bool enable);
+#ifdef CONFIG_BEAMFORMING
+void rtl8822b_phy_bf_init(PADAPTER);
+void rtl8822b_phy_bf_enter(PADAPTER, struct sta_info*);
+void rtl8822b_phy_bf_leave(PADAPTER, u8 *addr);
+void rtl8822b_phy_bf_set_gid_table(PADAPTER, struct beamformer_entry*);
+void rtl8822b_phy_bf_set_csi_report(PADAPTER, struct _RT_CSI_INFO*);
+void rtl8822b_phy_bf_sounding_status(PADAPTER, u8 status);
+#endif /* CONFIG_BEAMFORMING */
+
+#endif /* _RTL8822B_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_cmd.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_cmd.c
new file mode 100644
index 000000000000..2d2ec0b7a583
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_cmd.c
@@ -0,0 +1,1067 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_CMD_C_
+
+#include <hal_data.h>		/* HAL_DATA_TYPE */
+#include "../hal_halmac.h"	/* HRTW_HALMAC_H2C_MAX_SIZE, CMD_ID_RSVD_PAGE and etc. */
+#include "rtl8822b.h"
+
+/*
+ * Below functions are for C2H
+ */
+/*****************************************
+ * H2C Msg format :
+ *| 31 - 8		|7-5	| 4 - 0	|
+ *| h2c_msg		|Class	|CMD_ID	|
+ *| 31-0				|
+ *| Ext msg				|
+ *
+ ******************************************/
+s32 rtl8822b_fillh2ccmd(PADAPTER adapter, u8 id, u32 buf_len, u8 *pbuf)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+#ifdef CONFIG_RTW_DEBUG
+	u8 msg[(RTW_HALMAC_H2C_MAX_SIZE - 1) * 5 + 1] = {0};
+	u8 *msg_p;
+	u32 msg_size, i, n;
+#endif /* CONFIG_RTW_DEBUG */
+	int err;
+	s32 ret = _FAIL;
+
+
+	if (!pbuf)
+		goto exit;
+
+	if (buf_len > (RTW_HALMAC_H2C_MAX_SIZE - 1))
+		goto exit;
+
+	if (rtw_is_surprise_removed(adapter))
+		goto exit;
+
+#ifdef CONFIG_RTW_DEBUG
+	msg_p = msg;
+	msg_size = (RTW_HALMAC_H2C_MAX_SIZE - 1) * 5 + 1;
+	for (i = 0; i < buf_len; i++) {
+		n = rtw_sprintf(msg_p, msg_size, " 0x%02x", pbuf[i]);
+		msg_p += n;
+		msg_size -= n;
+		if (msg_size == 0)
+			break;
+	}
+	RTW_DBG(FUNC_ADPT_FMT ": id=0x%02x buf=%s\n",
+		 FUNC_ADPT_ARG(adapter), id, msg);
+#endif /* CONFIG_RTW_DEBUG */
+
+	h2c[0] = id;
+	_rtw_memcpy(h2c + 1, pbuf, buf_len);
+
+	err = rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+	if (!err)
+		ret = _SUCCESS;
+
+exit:
+
+	return ret;
+}
+
+static void rtl8822b_set_FwRsvdPage_cmd(PADAPTER adapter, PRSVDPAGE_LOC rsvdpageloc)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+
+
+	RTW_INFO(FUNC_ADPT_FMT ": ProbeRsp=%d PsPoll=%d Null=%d QoSNull=%d BTNull=%d\n",
+		 FUNC_ADPT_ARG(adapter),
+		 rsvdpageloc->LocProbeRsp, rsvdpageloc->LocPsPoll,
+		 rsvdpageloc->LocNullData, rsvdpageloc->LocQosNull,
+		 rsvdpageloc->LocBTQosNull);
+
+	RSVD_PAGE_SET_CMD_ID(h2c, CMD_ID_RSVD_PAGE);
+	RSVD_PAGE_SET_CLASS(h2c, CLASS_RSVD_PAGE);
+	RSVD_PAGE_SET_LOC_PROBE_RSP(h2c, rsvdpageloc->LocProbeRsp);
+	RSVD_PAGE_SET_LOC_PS_POLL(h2c, rsvdpageloc->LocPsPoll);
+	RSVD_PAGE_SET_LOC_NULL_DATA(h2c, rsvdpageloc->LocNullData);
+	RSVD_PAGE_SET_LOC_QOS_NULL(h2c, rsvdpageloc->LocQosNull);
+	RSVD_PAGE_SET_LOC_BT_QOS_NULL(h2c, rsvdpageloc->LocBTQosNull);
+
+	RTW_DBG_DUMP("H2C-RsvdPage Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+static void rtl8822b_set_FwAoacRsvdPage_cmd(PADAPTER adapter, PRSVDPAGE_LOC rsvdpageloc)
+{
+#ifdef CONFIG_WOWLAN
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	u8 res = 0, count = 0;
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+
+
+	RTW_INFO(FUNC_ADPT_FMT ": RWC=%d ArpRsp=%d NbrAdv=%d GtkRsp=%d GtkInfo=%d ProbeReq=%d NetworkList=%d\n",
+		 FUNC_ADPT_ARG(adapter),
+		 rsvdpageloc->LocRemoteCtrlInfo, rsvdpageloc->LocArpRsp,
+		 rsvdpageloc->LocNbrAdv, rsvdpageloc->LocGTKRsp,
+		 rsvdpageloc->LocGTKInfo, rsvdpageloc->LocProbeReq,
+		 rsvdpageloc->LocNetList);
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		AOAC_RSVD_PAGE_SET_CMD_ID(h2c, CMD_ID_AOAC_RSVD_PAGE);
+		AOAC_RSVD_PAGE_SET_CLASS(h2c, CLASS_AOAC_RSVD_PAGE);
+		AOAC_RSVD_PAGE_SET_LOC_REMOTE_CTRL_INFO(h2c, rsvdpageloc->LocRemoteCtrlInfo);
+		AOAC_RSVD_PAGE_SET_LOC_ARP_RESPONSE(h2c, rsvdpageloc->LocArpRsp);
+		AOAC_RSVD_PAGE_SET_LOC_GTK_RSP(h2c, rsvdpageloc->LocGTKRsp);
+		AOAC_RSVD_PAGE_SET_LOC_GTK_INFO(h2c, rsvdpageloc->LocGTKInfo);
+#ifdef CONFIG_GTK_OL
+		AOAC_RSVD_PAGE_SET_LOC_GTK_EXT_MEM(h2c, rsvdpageloc->LocGTKEXTMEM);
+#endif /* CONFIG_GTK_OL */
+		RTW_DBG_DUMP("H2C-AoacRsvdPage Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+		rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+	} else {
+#ifdef CONFIG_PNO_SUPPORT
+		if (!pwrpriv->wowlan_in_resume) {
+			RTW_INFO("%s: NLO_INFO=%d\n", __FUNCTION__, rsvdpageloc->LocPNOInfo);
+			AOAC_RSVD_PAGE3_SET_CMD_ID(h2c, CMD_ID_AOAC_RSVD_PAGE3);
+			AOAC_RSVD_PAGE3_SET_CLASS(h2c, CLASS_AOAC_RSVD_PAGE3);
+			AOAC_RSVD_PAGE3_SET_LOC_NLO_INFO(h2c, rsvdpageloc->LocPNOInfo);
+			RTW_DBG_DUMP("H2C-AoacRsvdPage3 Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+			rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+			rtw_msleep_os(10);
+		}
+#endif /* CONFIG_PNO_SUPPORT */
+	}
+#endif /* CONFIG_WOWLAN */
+}
+
+void rtl8822b_set_FwMediaStatusRpt_cmd(PADAPTER	adapter, u8 mstatus, u8 macid)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+	u8 macid_end = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT ": mstatus=%d macid=%d\n",
+		 FUNC_ADPT_ARG(adapter), mstatus, macid);
+
+	MEDIA_STATUS_RPT_SET_CMD_ID(h2c, CMD_ID_MEDIA_STATUS_RPT);
+	MEDIA_STATUS_RPT_SET_CLASS(h2c, CLASS_MEDIA_STATUS_RPT);
+	MEDIA_STATUS_RPT_SET_OP_MODE(h2c, mstatus);
+	MEDIA_STATUS_RPT_SET_MACID_IN(h2c, 0);
+	MEDIA_STATUS_RPT_SET_MACID(h2c, macid);
+	MEDIA_STATUS_RPT_SET_MACID_END(h2c, macid_end);
+
+	RTW_DBG_DUMP("H2C-MediaStatusRpt Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+static void rtl8822b_set_FwKeepAlive_cmd(PADAPTER adapter, u8 benable, u8 pkt_type)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+	u8 adopt = 1;
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+	u8 check_period = 10;
+#else
+	u8 check_period = 5;
+#endif
+
+
+	RTW_INFO(FUNC_ADPT_FMT ": benable=%d\n", FUNC_ADPT_ARG(adapter), benable);
+
+	KEEP_ALIVE_SET_CMD_ID(h2c, CMD_ID_KEEP_ALIVE);
+	KEEP_ALIVE_SET_CLASS(h2c, CLASS_KEEP_ALIVE);
+	KEEP_ALIVE_SET_ENABLE(h2c, benable);
+	KEEP_ALIVE_SET_ADOPT_USER_SETTING(h2c, adopt);
+	KEEP_ALIVE_SET_PKT_TYPE(h2c, pkt_type);
+	KEEP_ALIVE_SET_KEEP_ALIVE_CHECK_PERIOD(h2c, check_period);
+
+	RTW_DBG_DUMP("H2C-KeepAlive Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+static void rtl8822b_set_FwDisconDecision_cmd(PADAPTER adapter, u8 benable)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+	u8 adopt = 1, check_period = 10, trypkt_num = 0;
+
+
+	RTW_INFO(FUNC_ADPT_FMT ": benable=%d\n",
+		 FUNC_ADPT_ARG(adapter), benable);
+
+	DISCONNECT_DECISION_SET_CMD_ID(h2c, CMD_ID_DISCONNECT_DECISION);
+	DISCONNECT_DECISION_SET_CLASS(h2c, CLASS_DISCONNECT_DECISION);
+	DISCONNECT_DECISION_SET_ENABLE(h2c, benable);
+	DISCONNECT_DECISION_SET_ADOPT_USER_SETTING(h2c, adopt);
+	DISCONNECT_DECISION_SET_DISCON_DECISION_CHECK_PERIOD(h2c, check_period);
+	DISCONNECT_DECISION_SET_TRY_PKT_NUM(h2c, trypkt_num);
+
+	RTW_DBG_DUMP("H2C-DisconDecision Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+static u8 get_ra_vht_en(u32 wirelessMode, u32 bitmap)
+{
+	u8 ret = 0;
+
+	if (wirelessMode == WIRELESS_11_24AC) {
+		if (bitmap & 0xfff00000) /* 2SS */
+			ret = 3;
+		else					/* 1SS */
+			ret = 2;
+	} else if (wirelessMode == WIRELESS_11_5AC)
+		ret = 1;
+
+	return ret;
+}
+
+void rtl8822b_set_FwRssiSetting_cmd(PADAPTER adapter, u8 *param)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+	u8 mac_id = *param;
+	u8 rssi = *(param + 2);
+	u8 ra_info = 0;
+
+
+	RTW_INFO(FUNC_ADPT_FMT ": mac_id=%d rssi=%d param=%.2x-%.2x-%.2x\n",
+		 FUNC_ADPT_ARG(adapter),
+		 mac_id, rssi, *param, *(param + 1), *(param + 2));
+
+	RSSI_SETTING_SET_CMD_ID(h2c, CMD_ID_RSSI_SETTING);
+	RSSI_SETTING_SET_CLASS(h2c, CLASS_RSSI_SETTING);
+	RSSI_SETTING_SET_MAC_ID(h2c, mac_id);
+	RSSI_SETTING_SET_RSSI(h2c, rssi);
+	RSSI_SETTING_SET_RA_INFO(h2c, ra_info);
+
+	RTW_DBG_DUMP("H2C-RssiSetting Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+void rtl8822b_set_FwAPReqRPT_cmd(PADAPTER adapter, u32 need_ack)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+	u8 macid1 = 1, macid2 = 0;
+
+
+	RTW_INFO(FUNC_ADPT_FMT ": need_ack = %d\n",
+		 FUNC_ADPT_ARG(adapter), need_ack);
+
+	AP_REQ_TXRPT_SET_CMD_ID(h2c, CMD_ID_AP_REQ_TXRPT);
+	AP_REQ_TXRPT_SET_CLASS(h2c, CLASS_AP_REQ_TXRPT);
+	AP_REQ_TXRPT_SET_STA1_MACID(h2c, macid1);
+	AP_REQ_TXRPT_SET_STA2_MACID(h2c, macid2);
+
+	RTW_DBG_DUMP("H2C-ApReqRpt Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+void rtl8822b_req_txrpt_cmd(PADAPTER adapter, u8 macid)
+{
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+
+	AP_REQ_TXRPT_SET_CMD_ID(h2c, CMD_ID_AP_REQ_TXRPT);
+	AP_REQ_TXRPT_SET_CLASS(h2c, CLASS_AP_REQ_TXRPT);
+
+	AP_REQ_TXRPT_SET_STA1_MACID(h2c, macid);
+	AP_REQ_TXRPT_SET_STA2_MACID(h2c, 0xff);
+	AP_REQ_TXRPT_SET_RTY_OK_TOTAL(h2c, 0x00);
+	AP_REQ_TXRPT_SET_RTY_CNT_MACID(h2c, 0x00);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+
+	AP_REQ_TXRPT_SET_RTY_CNT_MACID(h2c, 0x01);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+/*
+ * lps_wait_bb_rf_ready() - Wait BB/RF ready after leaving LPS
+ * @adapter	struct _ADAPTER*
+ * @timeout	time to wait complete, unit is millisecond
+ *
+ * This function is used to wait BB and RF ready after leaving LPS. Besdies
+ * checking registers, it will wait 1 ms to let everything has time to finish
+ * their jobs, so this function will cost more than 1ms to return. Please call
+ * this function carefully, or you will waste time to wait.
+ *
+ * Return 0 for BB/RF ready, otherwise NOT ready.
+ * The error codes are as following:
+ * -1	unclassified error
+ * -2	RF ready check timeout
+ * -3	BB ready check timeout
+ */
+static int lps_wait_bb_rf_ready(struct _ADAPTER *adapter, u32 timeout)
+{
+	systime s_time;	/* start time */
+	u8 ready = 0;
+#define RF_READY	BIT(0)	/* BB ready */
+#define BB_READY	BIT(1)	/* RF ready */
+	u8 awake = _FALSE;
+	u8 sys_func_en;
+
+
+	s_time = rtw_get_current_time();
+
+	do {
+		if (!(ready & RF_READY)) {
+			rtw_hal_get_hwreg(adapter, HW_VAR_FWLPS_RF_ON, &awake);
+			if (awake == _TRUE)
+				ready |= RF_READY;
+		}
+
+		if ((ready & RF_READY) && (!(ready & BB_READY))) {
+			sys_func_en = rtw_read8(adapter, REG_SYS_FUNC_EN_8822B);
+			if (sys_func_en & BIT_FEN_BBRSTB_8822B)
+				break;
+		}
+
+		if (rtw_is_surprise_removed(adapter))
+			return -1;
+
+		if (rtw_get_passing_time_ms(s_time) > timeout) {
+			if (!(ready & RF_READY))
+				return -2;
+			return -3;
+		}
+
+		rtw_usleep_os(100); /* 100us interval between each check */
+	} while (1);
+
+	rtw_usleep_os(1000); /* Wait 1ms */
+
+	return 0;
+}
+
+void rtl8822b_set_FwPwrMode_cmd(PADAPTER adapter, u8 psmode)
+{
+	int i;
+	u8 smart_ps = 0, mode = 0;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+#ifdef CONFIG_WMMPS_STA
+	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
+	struct qos_priv	*pqospriv = &pmlmepriv->qospriv;
+#endif /* CONFIG_WMMPS_STA */	
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+	u8 PowerState = 0, awake_intvl = 1, byte5 = 0, rlbm = 0;
+	u8 allQueueUAPSD = 0;
+	char *fw_psmode_str = "";
+#ifdef CONFIG_P2P
+	struct wifidirect_info *wdinfo = &adapter->wdinfo;
+#endif /* CONFIG_P2P */
+
+
+	if (pwrpriv->dtim > 0)
+		RTW_INFO(FUNC_ADPT_FMT ": dtim=%d, HW port id=%d\n", FUNC_ADPT_ARG(adapter),
+			pwrpriv->dtim, psmode == PS_MODE_ACTIVE ? pwrpriv->current_lps_hw_port_id:get_hw_port(adapter));
+	else
+		RTW_INFO(FUNC_ADPT_FMT ": HW port id=%d\n", FUNC_ADPT_ARG(adapter),
+			psmode == PS_MODE_ACTIVE ? pwrpriv->current_lps_hw_port_id:get_hw_port(adapter));
+
+	if (psmode == PS_MODE_MIN || psmode == PS_MODE_MAX) {
+#ifdef CONFIG_WMMPS_STA	
+		if (rtw_is_wmmps_mode(adapter)) {
+			mode = 2;
+
+			smart_ps = pwrpriv->wmm_smart_ps;
+
+			/* (WMMPS) allQueueUAPSD: 0: PSPoll, 1: QosNullData (if wmm_smart_ps=1) or do nothing (if wmm_smart_ps=2) */
+			if ((pqospriv->uapsd_tid & BIT_MASK_TID_TC) == ALL_TID_TC_SUPPORTED_UAPSD)
+				allQueueUAPSD = 1;
+		} else
+#endif /* CONFIG_WMMPS_STA */
+		{
+			mode = 1;
+#ifdef CONFIG_WMMPS_STA	
+			/* For WMMPS test case, the station must retain sleep mode to capture buffered data on LPS mechanism */ 
+			if ((pqospriv->uapsd_tid & BIT_MASK_TID_TC)  != 0)
+				smart_ps = 0;
+			else
+#endif /* CONFIG_WMMPS_STA */
+			{
+				smart_ps = pwrpriv->smart_ps;
+			}
+		}
+
+		if (psmode == PS_MODE_MIN)
+			rlbm = 0;
+		else
+			rlbm = 1;
+	} else if (psmode == PS_MODE_DTIM) {
+		mode = 1;
+		/* For WOWLAN LPS, DTIM = (awake_intvl - 1) */
+		if (pwrpriv->dtim > 0 && pwrpriv->dtim < 16)
+			/* DTIM = (awake_intvl - 1) */
+			awake_intvl = pwrpriv->dtim + 1;
+		else
+			/* DTIM = 3 */
+			awake_intvl = 4;
+
+		rlbm = 2;
+		smart_ps = pwrpriv->smart_ps;
+	} else if (psmode == PS_MODE_ACTIVE) {
+		mode = 0;
+	} else {
+		rlbm = 2;
+		awake_intvl = 4;
+		smart_ps = pwrpriv->smart_ps;
+	}
+
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_state(wdinfo, P2P_STATE_NONE)) {
+		awake_intvl = 2;
+		rlbm = 1;
+	}
+#endif /* CONFIG_P2P */
+
+	if (adapter->registrypriv.wifi_spec == 1) {
+		awake_intvl = 2;
+		rlbm = 1;
+	}
+
+	if (psmode > 0) {
+#ifdef CONFIG_BT_COEXIST
+		if (rtw_btcoex_IsBtControlLps(adapter) == _TRUE) {
+			PowerState = rtw_btcoex_RpwmVal(adapter);
+			byte5 = rtw_btcoex_LpsVal(adapter);
+
+			if ((rlbm == 2) && (byte5 & BIT(4))) {
+				/*
+				 * Keep awake interval to 1 to prevent from
+				 * decreasing coex performance
+				 */
+				awake_intvl = 2;
+				rlbm = 2;
+			}
+		} else
+#endif /* CONFIG_BT_COEXIST */
+		{
+			PowerState = 0x00; /* AllON(0x0C), RFON(0x04), RFOFF(0x00) */
+			byte5 = 0x40;
+		}
+	} else {
+		PowerState = 0x0C; /* AllON(0x0C), RFON(0x04), RFOFF(0x00) */
+		byte5 = 0x40;
+	}
+
+	if (mode == 0)
+		fw_psmode_str = "ACTIVE";
+	else if (mode == 1)
+		fw_psmode_str = "LPS";
+	else if (mode == 2)
+		fw_psmode_str = "WMMPS";
+	else
+		fw_psmode_str = "UNSPECIFIED";
+
+	RTW_INFO(FUNC_ADPT_FMT": fw ps mode = %s, drv ps mode = %d, rlbm = %d , smart_ps = %d, allQueueUAPSD = %d\n", 
+				FUNC_ADPT_ARG(adapter), fw_psmode_str, psmode, rlbm, smart_ps, allQueueUAPSD);
+
+	SET_PWR_MODE_SET_CMD_ID(h2c, CMD_ID_SET_PWR_MODE);
+	SET_PWR_MODE_SET_CLASS(h2c, CLASS_SET_PWR_MODE);
+	SET_PWR_MODE_SET_MODE(h2c, mode);
+	SET_PWR_MODE_SET_SMART_PS(h2c, smart_ps);
+	SET_PWR_MODE_SET_RLBM(h2c, rlbm);
+	SET_PWR_MODE_SET_AWAKE_INTERVAL(h2c, awake_intvl);
+	SET_PWR_MODE_SET_B_ALL_QUEUE_UAPSD(h2c, allQueueUAPSD);
+	SET_PWR_MODE_SET_PWR_STATE(h2c, PowerState);
+	if (psmode == PS_MODE_ACTIVE) {
+		/* Leave LPS, set the same HW port ID */
+		SET_PWR_MODE_SET_PORT_ID(h2c, pwrpriv->current_lps_hw_port_id);
+	} else {
+		/* Enter LPS, record HW port ID */
+		SET_PWR_MODE_SET_PORT_ID(h2c, get_hw_port(adapter));
+		pwrpriv->current_lps_hw_port_id = get_hw_port(adapter);
+	}
+
+	if (byte5 & BIT(0))
+		SET_PWR_MODE_SET_LOW_POWER_RX_BCN(h2c, 1);
+	if (byte5 & BIT(1))
+		SET_PWR_MODE_SET_ANT_AUTO_SWITCH(h2c, 1);
+	if (byte5 & BIT(2))
+		SET_PWR_MODE_SET_PS_ALLOW_BT_HIGH_PRIORITY(h2c, 1);
+	if (byte5 & BIT(3))
+		SET_PWR_MODE_SET_PROTECT_BCN(h2c, 1);
+	if (byte5 & BIT(4))
+		SET_PWR_MODE_SET_SILENCE_PERIOD(h2c, 1);
+	if (byte5 & BIT(5))
+		SET_PWR_MODE_SET_FAST_BT_CONNECT(h2c, 1);
+	if (byte5 & BIT(6))
+		SET_PWR_MODE_SET_TWO_ANTENNA_EN(h2c, 1);
+
+#ifdef CONFIG_LPS_LCLK
+	if (psmode != PS_MODE_ACTIVE) {
+		if ((pmlmeext->adaptive_tsf_done == _FALSE)
+		    && (pmlmeext->bcn_cnt > 0)) {
+			u8 ratio_20_delay, ratio_80_delay;
+
+			/*
+			 * byte 6 for adaptive_early_32k
+			 * [0:3] = DrvBcnEarly (ms), [4:7] = DrvBcnTimeOut (ms)
+			 * 20% for DrvBcnEarly, 80% for DrvBcnTimeOut
+			 */
+			ratio_20_delay = 0;
+			ratio_80_delay = 0;
+			pmlmeext->DrvBcnEarly = 0xff;
+			pmlmeext->DrvBcnTimeOut = 0xff;
+
+			for (i = 0; i < 9; i++) {
+				pmlmeext->bcn_delay_ratio[i] = (pmlmeext->bcn_delay_cnt[i] * 100) / pmlmeext->bcn_cnt;
+
+				ratio_20_delay += pmlmeext->bcn_delay_ratio[i];
+				ratio_80_delay += pmlmeext->bcn_delay_ratio[i];
+
+				if (ratio_20_delay > 20 && pmlmeext->DrvBcnEarly == 0xff)
+					pmlmeext->DrvBcnEarly = i;
+
+				if (ratio_80_delay > 80 && pmlmeext->DrvBcnTimeOut == 0xff)
+					pmlmeext->DrvBcnTimeOut = i;
+
+				/* reset adaptive_early_32k cnt */
+				pmlmeext->bcn_delay_cnt[i] = 0;
+				pmlmeext->bcn_delay_ratio[i] = 0;
+			}
+
+			pmlmeext->bcn_cnt = 0;
+			pmlmeext->adaptive_tsf_done = _TRUE;
+		}
+	}
+#endif /* CONFIG_LPS_LCLK */
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_RecordPwrMode(adapter, h2c + 1, RTW_HALMAC_H2C_MAX_SIZE - 1);
+#endif /* CONFIG_BT_COEXIST */
+
+	RTW_DBG_DUMP("H2C-PwrMode Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+
+	if (psmode == PS_MODE_ACTIVE) {
+		i = lps_wait_bb_rf_ready(adapter, 1000);
+		if (i)
+			RTW_WARN("%s: BB/RF status is unknown!(%d)\n",
+				 __FUNCTION__, i);
+	}
+}
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8822b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable)
+{
+	u8	u1H2CSetPwrMode[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+
+	SET_PWR_MODE_SET_CMD_ID(u1H2CSetPwrMode, CMD_ID_SET_PWR_MODE);
+	SET_PWR_MODE_SET_CLASS(u1H2CSetPwrMode, CLASS_SET_PWR_MODE);
+	SET_PWR_MODE_SET_MODE(u1H2CSetPwrMode, 1);
+	SET_PWR_MODE_SET_RLBM(u1H2CSetPwrMode, 1);
+	SET_PWR_MODE_SET_BCN_EARLY_RPT(u1H2CSetPwrMode, enable);
+	SET_PWR_MODE_SET_PWR_STATE(u1H2CSetPwrMode, 0x0C);
+	
+	rtw_halmac_send_h2c(adapter_to_dvobj(padapter), u1H2CSetPwrMode);
+}
+#endif
+#endif
+
+void rtl8822b_set_FwPwrModeInIPS_cmd(PADAPTER adapter, u8 cmd_param)
+{
+
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+
+	INACTIVE_PS_SET_CMD_ID(h2c, CMD_ID_INACTIVE_PS);
+	INACTIVE_PS_SET_CLASS(h2c, CLASS_INACTIVE_PS);
+
+	if (cmd_param & BIT0)
+		INACTIVE_PS_SET_ENABLE(h2c, 1);
+
+	if (cmd_param & BIT1)
+		INACTIVE_PS_SET_IGNORE_PS_CONDITION(h2c, 1);
+
+	RTW_DBG_DUMP("H2C-FwPwrModeInIPS Parm:", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+	rtw_halmac_send_h2c(adapter_to_dvobj(adapter), h2c);
+}
+
+static s32 rtl8822b_set_FwLowPwrLps_cmd(PADAPTER adapter, u8 enable)
+{
+	return _FALSE;
+}
+
+#ifdef CONFIG_BT_COEXIST
+static void SetFwRsvdPagePkt_BTCoex(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	struct xmit_frame *pcmdframe;
+	struct pkt_attrib *pattrib;
+	struct xmit_priv *pxmitpriv;
+	struct mlme_ext_priv *pmlmeext;
+	struct mlme_ext_info *pmlmeinfo;
+	u32 BeaconLength = 0;
+	u32 BTQosNullLength = 0;
+	u8 *ReservedPagePacket;
+	u32 page_size, desc_size;
+	u8 TxDescOffset;
+	u8 TotalPageNum = 0, CurtPktPageNum = 0, RsvdPageNum = 0;
+	u16 BufIndex;
+	u32 TotalPacketLen, MaxRsvdPageBufSize = 0;
+	RSVDPAGE_LOC RsvdPageLoc;
+
+
+	hal = GET_HAL_DATA(adapter);
+	pxmitpriv = &adapter->xmitpriv;
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
+	desc_size = rtl8822b_get_tx_desc_size(adapter);
+	TxDescOffset = TXDESC_OFFSET;
+
+	RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _FALSE);
+	MaxRsvdPageBufSize = RsvdPageNum * page_size;
+
+	pcmdframe = rtw_alloc_cmdxmitframe(pxmitpriv);
+	if (pcmdframe == NULL) {
+		RTW_INFO("%s: alloc ReservedPagePacket fail!\n", __FUNCTION__);
+		return;
+	}
+
+	ReservedPagePacket = pcmdframe->buf_addr;
+	_rtw_memset(&RsvdPageLoc, 0, sizeof(RSVDPAGE_LOC));
+
+	/* (1) beacon */
+	BufIndex = TxDescOffset;
+	rtw_hal_construct_beacon(adapter,
+		&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.
+	 */
+	CurtPktPageNum = (u8)PageNum(desc_size + BeaconLength, page_size);
+	/*
+	 * If we don't add 1 more page, the WOWLAN function has a problem.
+	 * Maybe it's a bug of firmware?
+	 */
+	if (CurtPktPageNum == 1)
+		CurtPktPageNum += 1;
+	TotalPageNum += CurtPktPageNum;
+
+	BufIndex += (CurtPktPageNum * page_size);
+
+	/* Jump to lastest page */
+	if (BufIndex < (MaxRsvdPageBufSize - page_size)) {
+		BufIndex = TxDescOffset + (MaxRsvdPageBufSize - page_size);
+		TotalPageNum = RsvdPageNum - 1;
+	}
+
+	/* (6) BT Qos null data */
+	RsvdPageLoc.LocBTQosNull = TotalPageNum;
+	rtw_hal_construct_NullFunctionData(
+		adapter,
+		&ReservedPagePacket[BufIndex],
+		&BTQosNullLength,
+		get_my_bssid(&pmlmeinfo->network),
+		_TRUE, 0, 0, _FALSE);
+	rtw_hal_fill_fake_txdesc(adapter, &ReservedPagePacket[BufIndex - desc_size], BTQosNullLength, _FALSE, _TRUE, _FALSE);
+
+	CurtPktPageNum = (u8)PageNum(desc_size + BTQosNullLength, page_size);
+
+	TotalPageNum += CurtPktPageNum;
+
+	TotalPacketLen = BufIndex + BTQosNullLength;
+	if (TotalPacketLen > MaxRsvdPageBufSize) {
+		RTW_INFO(FUNC_ADPT_FMT ": ERROR: The rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
+			FUNC_ADPT_ARG(adapter), TotalPacketLen, MaxRsvdPageBufSize);
+		goto error;
+	}
+
+	/* update attribute */
+	pattrib = &pcmdframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+	pattrib->qsel = QSLT_BEACON;
+	pattrib->pktlen = pattrib->last_txcmdsz = TotalPacketLen - TxDescOffset;
+#ifdef CONFIG_PCI_HCI
+	dump_mgntframe(adapter, pcmdframe);
+#else /* !CONFIG_PCI_HCI */
+	dump_mgntframe_and_wait(adapter, pcmdframe, 100);
+#endif /* !CONFIG_PCI_HCI */
+
+	rtl8822b_set_FwRsvdPage_cmd(adapter, &RsvdPageLoc);
+	rtl8822b_set_FwAoacRsvdPage_cmd(adapter, &RsvdPageLoc);
+
+	return;
+
+error:
+	rtw_free_xmitframe(pxmitpriv, pcmdframe);
+}
+
+void rtl8822b_download_BTCoex_AP_mode_rsvd_page(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	struct mlme_ext_priv *pmlmeext;
+	struct mlme_ext_info *pmlmeinfo;
+	u8 bRecover = _FALSE;
+	u8 bcn_valid = _FALSE;
+	u8 DLBcnCount = 0;
+	u32 poll = 0;
+	u8 val8, RegFwHwTxQCtrl;
+	u8 restore[2];
+
+
+	RTW_INFO("+" FUNC_ADPT_FMT ": hw_port=%d fw_state=0x%08X\n",
+		FUNC_ADPT_ARG(adapter), get_hw_port(adapter), get_fwstate(&adapter->mlmepriv));
+
+#ifdef CONFIG_RTW_DEBUG
+	if (check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _FALSE) {
+		RTW_INFO(FUNC_ADPT_FMT ": [WARNING] not in AP mode!!\n",
+			 FUNC_ADPT_ARG(adapter));
+	}
+#endif /* CONFIG_RTW_DEBUG */
+
+	hal = GET_HAL_DATA(adapter);
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+
+	/* We should set AID, correct TSF, HW seq enable before set JoinBssReport to Fw in 88/92C. */
+	rtw_write16(adapter, REG_BCN_PSR_RPT_8822B, (0xC000 | pmlmeinfo->aid));
+
+	/* set REG_CR bit 8 */
+	val8 = rtw_read8(adapter, REG_CR_8822B + 1);
+	restore[0] = val8;
+	val8 |= BIT(0); /* ENSWBCN */
+	rtw_write8(adapter,  REG_CR_8822B + 1, val8);
+
+	/*
+	 * 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.
+	 */
+	val8 = rtw_read8(adapter, REG_BCN_CTRL_8822B);
+	restore[1] = val8;
+	val8 &= ~BIT_EN_BCN_FUNCTION_8822B;
+	val8 |= BIT_DIS_TSF_UDT_8822B;
+	rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+
+	/* Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame. */
+	RegFwHwTxQCtrl = rtw_read8(adapter, REG_FWHW_TXQ_CTRL_8822B + 2);
+	if (RegFwHwTxQCtrl & BIT(6))
+		bRecover = _TRUE;
+
+	/* To tell Hw the packet is not a real beacon frame. */
+	RegFwHwTxQCtrl &= ~BIT(6);
+	rtw_write8(adapter, REG_FWHW_TXQ_CTRL_8822B + 2, RegFwHwTxQCtrl);
+
+	/* Clear beacon valid check bit. */
+	rtw_hal_set_hwreg(adapter, HW_VAR_BCN_VALID, NULL);
+	rtw_hal_set_hwreg(adapter, HW_VAR_DL_BCN_SEL, NULL);
+
+	DLBcnCount = 0;
+	poll = 0;
+	do {
+		SetFwRsvdPagePkt_BTCoex(adapter);
+		DLBcnCount++;
+		do {
+			rtw_yield_os();
+
+			/* check rsvd page download OK. */
+			rtw_hal_get_hwreg(adapter, HW_VAR_BCN_VALID, &bcn_valid);
+			poll++;
+		} while (!bcn_valid && (poll % 10) != 0 && !RTW_CANNOT_RUN(adapter));
+	} while (!bcn_valid && (DLBcnCount <= 100) && !RTW_CANNOT_RUN(adapter));
+
+	if (_TRUE == bcn_valid) {
+		struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+
+		pwrctl->fw_psmode_iface_id = adapter->iface_id;
+		RTW_INFO(ADPT_FMT": DL RSVD page success! DLBcnCount:%d, poll:%d\n",
+			 ADPT_ARG(adapter), DLBcnCount, poll);
+	} else {
+		RTW_INFO(ADPT_FMT": DL RSVD page fail! DLBcnCount:%d, poll:%d\n",
+			 ADPT_ARG(adapter), DLBcnCount, poll);
+		RTW_INFO(ADPT_FMT": DL RSVD page fail! bSurpriseRemoved=%s\n",
+			ADPT_ARG(adapter), rtw_is_surprise_removed(adapter) ? "True" : "False");
+		RTW_INFO(ADPT_FMT": DL RSVD page fail! bDriverStopped=%s\n",
+			ADPT_ARG(adapter), rtw_is_drv_stopped(adapter) ? "True" : "False");
+	}
+
+	/*
+	 * 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.
+	 */
+	if (bRecover) {
+		RegFwHwTxQCtrl |= BIT(6);
+		rtw_write8(adapter, REG_FWHW_TXQ_CTRL_8822B + 2, RegFwHwTxQCtrl);
+	}
+
+	rtw_write8(adapter, REG_BCN_CTRL_8822B, restore[1]);
+	rtw_write8(adapter,  REG_CR_8822B + 1, restore[0]);
+
+	/* Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
+#ifndef CONFIG_PCI_HCI
+	val8 = rtw_read8(adapter, REG_CR_8822B + 1);
+	val8 &= ~BIT(0); /* ~ENSWBCN */
+	rtw_write8(adapter, REG_CR_8822B + 1, val8);
+#endif /* !CONFIG_PCI_HCI */
+}
+#endif /* CONFIG_BT_COEXIST */
+
+void rtl8822b_fw_update_beacon_cmd(PADAPTER adapter)
+{
+}
+
+/*
+ * Below functions are for C2H
+ */
+static void c2h_ccx_rpt(PADAPTER adapter, u8 *pdata)
+{
+#ifdef CONFIG_XMIT_ACK
+	u8 tx_state;
+
+
+	tx_state = CCX_RPT_GET_TX_STATE(pdata);
+
+	/* 0 means success, 1 means retry drop */
+	if (tx_state == 0)
+		rtw_ack_tx_done(&adapter->xmitpriv, RTW_SCTX_DONE_SUCCESS);
+	else
+		rtw_ack_tx_done(&adapter->xmitpriv, RTW_SCTX_DONE_CCX_PKT_FAIL);
+#endif /* CONFIG_XMIT_ACK */
+}
+
+static VOID
+C2HTxRPTHandler_8822b(
+	IN	PADAPTER	Adapter,
+	IN	u8			*CmdBuf,
+	IN	u8			CmdLen
+)
+{
+	_irqL	 irqL;
+	u8 macid = 0, IniRate = 0;
+	u16 TxOK = 0, TxFail = 0;
+	struct sta_priv	*pstapriv = &(GET_PRIMARY_ADAPTER(Adapter))->stapriv, *pstapriv_original = NULL;
+	u8 TxOK0 = 0, TxOK1 = 0;
+	u8 TxFail0 = 0, TxFail1 = 0;
+	struct sta_info *psta = NULL;
+	PADAPTER	adapter_ognl = NULL;
+
+	if(!pstapriv->gotc2h) {
+		RTW_WARN("%s,%d: No gotc2h!\n", __FUNCTION__, __LINE__);
+		return;
+	}
+	
+	adapter_ognl = rtw_get_iface_by_id(GET_PRIMARY_ADAPTER(Adapter), pstapriv->c2h_adapter_id);
+	if(!adapter_ognl) {
+		RTW_WARN("%s: No adapter!\n", __FUNCTION__);
+		return;
+	}
+
+	psta = rtw_get_stainfo(&adapter_ognl->stapriv, pstapriv->c2h_sta_mac);
+	if (!psta) {
+		RTW_WARN("%s: No corresponding sta_info!\n", __FUNCTION__);
+		return;
+	}
+
+	macid = C2H_AP_REQ_TXRPT_GET_STA1_MACID(CmdBuf);
+	TxOK0 = C2H_AP_REQ_TXRPT_GET_TX_OK1_0(CmdBuf);
+	TxOK1 = C2H_AP_REQ_TXRPT_GET_TX_OK1_1(CmdBuf);
+	TxOK = (TxOK1 << 8) | TxOK0;
+	TxFail0 = C2H_AP_REQ_TXRPT_GET_TX_FAIL1_0(CmdBuf);
+	TxFail1 = C2H_AP_REQ_TXRPT_GET_TX_FAIL1_1(CmdBuf);
+	TxFail = (TxFail1 << 8) | TxFail0;
+	IniRate = C2H_AP_REQ_TXRPT_GET_INITIAL_RATE1(CmdBuf);
+
+	psta->sta_stats.tx_ok_cnt = TxOK;
+	psta->sta_stats.tx_fail_cnt = TxFail;
+
+}
+
+static VOID
+C2HSPC_STAT_8822b(
+	IN	PADAPTER	Adapter,
+	IN	u8			*CmdBuf,
+	IN	u8			CmdLen
+)
+{
+	_irqL	 irqL;
+	struct sta_priv *pstapriv = &(GET_PRIMARY_ADAPTER(Adapter))->stapriv;
+	struct sta_info *psta = NULL;
+	struct sta_info *pbcmc_stainfo = rtw_get_bcmc_stainfo(Adapter);
+	_list	*plist, *phead;
+	u8 idx = C2H_SPECIAL_STATISTICS_GET_STATISTICS_IDX(CmdBuf);
+	PADAPTER	adapter_ognl = NULL;
+
+	if(!pstapriv->gotc2h) {
+		RTW_WARN("%s, %d: No gotc2h!\n", __FUNCTION__, __LINE__);
+		return;
+	}
+	
+	adapter_ognl = rtw_get_iface_by_id(GET_PRIMARY_ADAPTER(Adapter), pstapriv->c2h_adapter_id);
+	if(!adapter_ognl) {
+		RTW_WARN("%s: No adapter!\n", __FUNCTION__);
+		return;
+	}
+
+	psta = rtw_get_stainfo(&adapter_ognl->stapriv, pstapriv->c2h_sta_mac);
+	if (!psta) {
+		RTW_WARN("%s: No corresponding sta_info!\n", __FUNCTION__);
+		return;
+	}
+	psta->sta_stats.tx_retry_cnt = (C2H_SPECIAL_STATISTICS_GET_DATA3(CmdBuf) << 8) | C2H_SPECIAL_STATISTICS_GET_DATA2(CmdBuf);
+	rtw_sctx_done(&pstapriv->gotc2h);
+}
+
+/**
+ * c2h = RXDESC + c2h packet
+ * size = RXDESC_SIZE + c2h packet size
+ * c2h payload = c2h packet revmoe id & seq
+ */
+static void process_c2h_event(PADAPTER adapter, u8 *c2h, u32 size)
+{
+	struct mlme_ext_priv *pmlmeext;
+	struct mlme_ext_info *pmlmeinfo;
+	u32 desc_size;
+	u8 id, seq;
+	u8 c2h_len, c2h_payload_len;
+	u8 *pc2h_data, *pc2h_payload;
+
+
+	if (!c2h) {
+		RTW_INFO("%s: c2h buffer is NULL!!\n", __FUNCTION__);
+		return;
+	}
+
+	desc_size = rtl8822b_get_rx_desc_size(adapter);
+
+	if (size < desc_size) {
+		RTW_INFO("%s: c2h length(%d) is smaller than RXDESC_SIZE(%d)!!\n",
+			 __FUNCTION__, size, desc_size);
+		return;
+	}
+
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+
+	/* shift rx desc len */
+	pc2h_data = c2h + desc_size;
+	c2h_len = size - desc_size;
+
+	id = C2H_GET_CMD_ID(pc2h_data);
+	seq = C2H_GET_SEQ(pc2h_data);
+
+	/* shift 2 byte to remove cmd id & seq */
+	pc2h_payload = pc2h_data + 2;
+	c2h_payload_len = c2h_len - 2;
+
+	switch (id) {
+#ifdef CONFIG_BEAMFORMING
+	case CMD_ID_C2H_SND_TXBF:
+		RTW_INFO("%s: [CMD_ID_C2H_SND_TXBF] len=%d\n", __FUNCTION__, c2h_payload_len);
+		rtw_bf_c2h_handler(adapter, id, pc2h_data, c2h_len);
+		break;
+#endif /* CONFIG_BEAMFORMING */
+
+	case CMD_ID_C2H_AP_REQ_TXRPT:
+		/*RTW_INFO("[C2H], C2H_AP_REQ_TXRPT!!\n");*/
+		C2HTxRPTHandler_8822b(adapter, pc2h_data, c2h_len);
+		break;
+
+	case CMD_ID_C2H_SPECIAL_STATISTICS:
+		/*RTW_INFO("[C2H], C2H_SPC_STAT!!\n");*/
+		C2HSPC_STAT_8822b(adapter, pc2h_data, c2h_len);
+		break;
+
+	case CMD_ID_C2H_CUR_CHANNEL:
+	{
+		PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+		struct submit_ctx *chsw_sctx = &hal->chsw_sctx;
+
+		/* RTW_INFO("[C2H], CMD_ID_C2H_CUR_CHANNEL!!\n"); */
+		rtw_sctx_done(&chsw_sctx);
+		break;
+	}
+
+	case C2H_EXTEND:
+		if (C2H_HDR_GET_C2H_SUB_CMD_ID(pc2h_data) == C2H_SUB_CMD_ID_CCX_RPT) {
+			/* Shift C2H HDR 4 bytes */
+			c2h_ccx_rpt(adapter, pc2h_data);
+			break;
+		}
+
+		/* indicate c2h pkt + rx desc to halmac */
+		rtw_halmac_c2h_handle(adapter_to_dvobj(adapter), c2h, size);
+		break;
+
+	/* others for c2h common code */
+	default:
+		c2h_handler(adapter, id, seq, c2h_payload_len, pc2h_payload);
+		break;
+	}
+}
+
+void rtl8822b_c2h_handler(PADAPTER adapter, u8 *pbuf, u16 length)
+{
+#ifdef CONFIG_WOWLAN
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+
+
+	if (pwrpriv->wowlan_mode == _TRUE) {
+#ifdef CONFIG_RTW_DEBUG
+		u32 desc_size;
+
+		desc_size = rtl8822b_get_rx_desc_size(adapter);
+		RTW_INFO("%s: return because wowolan_mode==TRUE! CMDID=%d\n",
+			 __FUNCTION__, C2H_GET_CMD_ID(pbuf + desc_size));
+#endif /* CONFIG_RTW_DEBUG */
+		return;
+	}
+#endif /* CONFIG_WOWLAN*/
+
+	process_c2h_event(adapter, pbuf, length);
+}
+
+/**
+ * pbuf = RXDESC + c2h packet
+ * length = RXDESC_SIZE + c2h packet size
+ */
+void rtl8822b_c2h_handler_no_io(PADAPTER adapter, u8 *pbuf, u16 length)
+{
+	u32 desc_size;
+	u8 id, seq;
+	u8 *pc2h_content;
+	u8 res;
+
+
+	if ((length == 0) || (!pbuf))
+		return;
+
+	desc_size = rtl8822b_get_rx_desc_size(adapter);
+
+	/* shift rx desc len to get c2h packet content */
+	pc2h_content = pbuf + desc_size;
+	id = C2H_GET_CMD_ID(pc2h_content);
+	seq = C2H_GET_SEQ(pc2h_content);
+
+	RTW_DBG("%s: C2H, ID=%d seq=%d len=%d\n",
+		 __FUNCTION__, id, seq, length);
+
+	switch (id) {
+	case CMD_ID_C2H_SND_TXBF:
+	case CMD_ID_C2H_CCX_RPT:
+	case C2H_BT_MP_INFO:
+	case C2H_FW_CHNL_SWITCH_COMPLETE:
+	case C2H_IQK_FINISH:
+	case C2H_MCC:
+	case C2H_BCN_EARLY_RPT:
+	case C2H_EXTEND:
+		/* no I/O, process directly */
+		process_c2h_event(adapter, pbuf, length);
+		break;
+
+	default:
+		/* Others may need I/O, run in command thread */
+		res = rtw_c2h_packet_wk_cmd(adapter, pbuf, length);
+		if (res == _FAIL)
+			RTW_ERR("%s: C2H(%d) enqueue FAIL!\n", __FUNCTION__, id);
+		break;
+	}
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_halinit.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_halinit.c
new file mode 100644
index 000000000000..b1aeb0879c08
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_halinit.c
@@ -0,0 +1,341 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_HALINIT_C_
+
+#include <drv_types.h>		/* PADAPTER, basic_types.h and etc. */
+#include <hal_data.h>		/* GET_HAL_SPEC(), HAL_DATA_TYPE */
+#include "../hal_halmac.h"	/* HALMAC API */
+#include "rtl8822b.h"
+
+
+void rtl8822b_init_hal_spec(PADAPTER adapter)
+{
+	struct hal_spec_t *hal_spec;
+
+
+	hal_spec = GET_HAL_SPEC(adapter);
+	rtw_halmac_fill_hal_spec(adapter_to_dvobj(adapter), hal_spec);
+
+	hal_spec->ic_name = "rtl8822b";
+	hal_spec->macid_num = 128;
+	/* hal_spec->sec_cam_ent_num follow halmac setting */
+	hal_spec->sec_cap = SEC_CAP_CHK_BMC;
+	hal_spec->rfpath_num_2g = 2;
+	hal_spec->rfpath_num_5g = 2;
+	hal_spec->max_tx_cnt = 2;
+	hal_spec->tx_nss_num = 2;
+	hal_spec->rx_nss_num = 2;
+	hal_spec->band_cap = BAND_CAP_2G | BAND_CAP_5G;
+	hal_spec->bw_cap = BW_CAP_20M | BW_CAP_40M | BW_CAP_80M;
+	hal_spec->port_num = 5;
+	hal_spec->proto_cap = PROTO_CAP_11B | PROTO_CAP_11G | PROTO_CAP_11N | PROTO_CAP_11AC;
+
+	hal_spec->wl_func = 0
+			    | WL_FUNC_P2P
+			    | WL_FUNC_MIRACAST
+			    | WL_FUNC_TDLS
+			    ;
+
+	hal_spec->pg_txpwr_saddr = 0x10;
+
+	hal_spec->hci_type = 0;
+
+	rtw_macid_ctl_init_sleep_reg(adapter_to_macidctl(adapter)
+		, REG_MACID_SLEEP_8822B
+		, REG_MACID_SLEEP1_8822B
+		, REG_MACID_SLEEP2_8822B
+		, REG_MACID_SLEEP3_8822B);
+}
+
+u32 rtl8822b_power_on(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	PHAL_DATA_TYPE hal;
+	u8 bMacPwrCtrlOn;
+	int err = 0;
+	u8 ret = _SUCCESS;
+
+
+	d = adapter_to_dvobj(adapter);
+
+	bMacPwrCtrlOn = _FALSE;
+	rtw_hal_get_hwreg(adapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
+	if (bMacPwrCtrlOn == _TRUE)
+		goto out;
+
+	err = rtw_halmac_poweron(d);
+	if (err) {
+		RTW_ERR("%s: Power ON Fail!!\n", __FUNCTION__);
+		ret = _FAIL;
+		goto out;
+	}
+
+	bMacPwrCtrlOn = _TRUE;
+	rtw_hal_set_hwreg(adapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
+
+out:
+	return ret;
+}
+
+void rtl8822b_power_off(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	u8 bMacPwrCtrlOn;
+	int err = 0;
+
+
+	d = adapter_to_dvobj(adapter);
+
+	bMacPwrCtrlOn = _FALSE;
+	rtw_hal_get_hwreg(adapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
+	if (bMacPwrCtrlOn == _FALSE)
+		goto out;
+
+	err = rtw_halmac_poweroff(d);
+	if (err) {
+		RTW_ERR("%s: Power OFF Fail!!\n", __FUNCTION__);
+		goto out;
+	}
+
+	bMacPwrCtrlOn = _FALSE;
+	rtw_hal_set_hwreg(adapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
+
+	GET_HAL_DATA(adapter)->bFWReady = _FALSE;
+
+out:
+	return;
+}
+
+u8 rtl8822b_hal_init(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	PHAL_DATA_TYPE hal;
+	int err;
+	u8 fw_bin = _TRUE;
+
+	d = adapter_to_dvobj(adapter);
+	hal = GET_HAL_DATA(adapter);
+
+	hal->bFWReady = _FALSE;
+	hal->fw_ractrl = _FALSE;
+
+#ifdef CONFIG_FILE_FWIMG
+	rtw_get_phy_file_path(adapter, MAC_FILE_FW_NIC);
+	if (rtw_is_file_readable(rtw_phy_para_file_path) == _TRUE) {
+		RTW_INFO("%s acquire FW from file:%s\n", __FUNCTION__, rtw_phy_para_file_path);
+		fw_bin = _TRUE;
+	} else
+#endif /* CONFIG_FILE_FWIMG */
+	{
+		RTW_INFO("%s fw source from array\n", __FUNCTION__);
+		fw_bin = _FALSE;
+	}
+
+#ifdef CONFIG_FILE_FWIMG
+	if (_TRUE == fw_bin)
+		err = rtw_halmac_init_hal_fw_file(d, rtw_phy_para_file_path);
+	else
+#endif /* CONFIG_FILE_FWIMG */
+		err = rtw_halmac_init_hal_fw(d, array_mp_8822b_fw_nic, array_length_mp_8822b_fw_nic);
+
+	if (err) {
+		RTW_ERR("%s Download Firmware from %s failed\n", __FUNCTION__, (fw_bin) ? "file" : "array");
+		return _FALSE;
+	}
+
+	
+
+	RTW_INFO("%s Download Firmware from %s success\n", __FUNCTION__, (fw_bin) ? "file" : "array");
+	RTW_INFO("%s FW Version:%d SubVersion:%d FW size:%d\n", "NIC",
+		hal->firmware_version, hal->firmware_sub_version, hal->firmware_size);
+
+	/* Sync driver status with hardware setting */
+	rtw_hal_get_hwreg(adapter, HW_VAR_RCR, NULL);
+	hal->bFWReady = _TRUE;
+	hal->fw_ractrl = _TRUE;
+
+	return _TRUE;
+}
+
+u8 rtl8822b_mac_verify(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	int err;
+
+
+	d = adapter_to_dvobj(adapter);
+
+	err = rtw_halmac_self_verify(d);
+	if (err) {
+		RTW_INFO("%s fail\n", __FUNCTION__);
+		return _FALSE;
+	}
+
+	RTW_INFO("%s successful\n", __FUNCTION__);
+	return _TRUE;
+}
+
+void rtl8822b_init_misc(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	u8 v8 = 0;
+	u32 v32 = 0;
+
+
+	hal = GET_HAL_DATA(adapter);
+
+
+	/*
+	 * Sync driver status and hardware setting
+	 */
+
+	/* initial channel setting */
+	if (IS_A_CUT(hal->version_id) || IS_B_CUT(hal->version_id)) {
+		/* for A/B cut use under only 5G */
+		u8 i = 0;
+		struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+		PADAPTER iface = NULL;
+
+		RTW_INFO("%s: under only 5G for A/B cut\n", __FUNCTION__);
+		RTW_INFO("%s: not support HT/VHT RX STBC for A/B cut\n", __FUNCTION__);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface) {
+				iface->registrypriv.wireless_mode = WIRELESS_MODE_5G;
+				iface->registrypriv.channel = 149;
+
+				iface->registrypriv.stbc_cap &= ~(BIT0 | BIT4);
+			}
+		}
+	}
+
+	/* Modify to make sure first time change channel(band) would be done properly */
+	hal->current_channel = 0;
+	hal->current_channel_bw = CHANNEL_WIDTH_MAX;
+	hal->current_band_type = BAND_MAX;
+
+	/* initial security setting */
+	invalidate_cam_all(adapter);
+
+	/* check RCR/ICV bit */
+	rtw_hal_rcr_clear(adapter, BIT_ACRC32_8822B | BIT_AICV_8822B);
+
+	/* clear rx ctrl frame */
+	rtw_write16(adapter, REG_RXFLTMAP1_8822B, 0);
+
+	/*Enable MAC security engine*/
+	rtw_write16(adapter, REG_CR, (rtw_read16(adapter, REG_CR) | BIT_MAC_SEC_EN));
+
+#ifdef CONFIG_XMIT_ACK
+	/* ack for xmit mgmt frames. */
+	rtw_write32(adapter, REG_FWHW_TXQ_CTRL_8822B,
+		rtw_read32(adapter, REG_FWHW_TXQ_CTRL_8822B) | BIT_EN_QUEUE_RPT_8822B(BIT(4)));
+#endif /* CONFIG_XMIT_ACK */
+
+	rtw_write8(adapter, REG_TIMER0_SRC_SEL_8822B, rtw_read8(adapter, REG_TIMER0_SRC_SEL_8822B) & ~BIT(6));
+}
+
+u32 rtl8822b_init(PADAPTER adapter)
+{
+	u8 ok = _TRUE;
+	PHAL_DATA_TYPE hal;
+
+	hal = GET_HAL_DATA(adapter);
+
+	ok = rtl8822b_hal_init(adapter);
+	if (_FALSE == ok)
+		return _FAIL;
+
+	rtl8822b_phy_init_haldm(adapter);
+#ifdef CONFIG_BEAMFORMING
+	rtl8822b_phy_bf_init(adapter);
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+	/* Init BT hw config. */
+	if (_TRUE == hal->EEPROMBluetoothCoexist)
+		rtw_btcoex_HAL_Initialize(adapter, _FALSE);
+	else
+		rtw_btcoex_wifionly_hw_config(adapter);
+#else /* CONFIG_BT_COEXIST */
+	rtw_btcoex_wifionly_hw_config(adapter);
+#endif /* CONFIG_BT_COEXIST */
+
+	rtl8822b_init_misc(adapter);
+
+	return _SUCCESS;
+}
+
+u32 rtl8822b_deinit(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	PHAL_DATA_TYPE hal;
+	int err;
+
+
+	d = adapter_to_dvobj(adapter);
+	hal = GET_HAL_DATA(adapter);
+
+	hal->bFWReady = _FALSE;
+	hal->fw_ractrl = _FALSE;
+
+	err = rtw_halmac_deinit_hal(d);
+	if (err)
+		return _FAIL;
+
+	return _SUCCESS;
+}
+
+void rtl8822b_init_default_value(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	u8 i;
+
+
+	hal = GET_HAL_DATA(adapter);
+
+	if (adapter->registrypriv.wireless_mode == WIRELESS_MODE_MAX)
+		adapter->registrypriv.wireless_mode = WIRELESS_MODE_24G | WIRELESS_MODE_5G;
+
+	/* init default value */
+	hal->fw_ractrl = _FALSE;
+
+	if (!adapter_to_pwrctl(adapter)->bkeepfwalive)
+		hal->LastHMEBoxNum = 0;
+
+	/* init phydm default value */
+	hal->bIQKInitialized = _FALSE;
+
+	/* init Efuse variables */
+	hal->EfuseUsedBytes = 0;
+	hal->EfuseUsedPercentage = 0;
+
+	hal->EfuseHal.fakeEfuseBank = 0;
+	hal->EfuseHal.fakeEfuseUsedBytes = 0;
+	_rtw_memset(hal->EfuseHal.fakeEfuseContent, 0xFF, EFUSE_MAX_HW_SIZE);
+	_rtw_memset(hal->EfuseHal.fakeEfuseInitMap, 0xFF, EFUSE_MAX_MAP_LEN);
+	_rtw_memset(hal->EfuseHal.fakeEfuseModifiedMap, 0xFF, EFUSE_MAX_MAP_LEN);
+	hal->EfuseHal.BTEfuseUsedBytes = 0;
+	hal->EfuseHal.BTEfuseUsedPercentage = 0;
+	_rtw_memset(hal->EfuseHal.BTEfuseContent, 0xFF, EFUSE_MAX_BT_BANK * EFUSE_MAX_HW_SIZE);
+	_rtw_memset(hal->EfuseHal.BTEfuseInitMap, 0xFF, EFUSE_BT_MAX_MAP_LEN);
+	_rtw_memset(hal->EfuseHal.BTEfuseModifiedMap, 0xFF, EFUSE_BT_MAX_MAP_LEN);
+	hal->EfuseHal.fakeBTEfuseUsedBytes = 0;
+	_rtw_memset(hal->EfuseHal.fakeBTEfuseContent, 0xFF, EFUSE_MAX_BT_BANK * EFUSE_MAX_HW_SIZE);
+	_rtw_memset(hal->EfuseHal.fakeBTEfuseInitMap, 0xFF, EFUSE_BT_MAX_MAP_LEN);
+	_rtw_memset(hal->EfuseHal.fakeBTEfuseModifiedMap, 0xFF, EFUSE_BT_MAX_MAP_LEN);
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_mac.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_mac.c
new file mode 100644
index 000000000000..43975766b1ed
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_mac.c
@@ -0,0 +1,216 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_MAC_C_
+
+#include <drv_types.h>		/* PADAPTER, basic_types.h and etc. */
+#include <hal_data.h>		/* HAL_DATA_TYPE */
+#include "../hal_halmac.h"	/* Register Definition and etc. */
+#include "rtl8822b.h"		/* FW array */
+
+
+inline u8 rtl8822b_rcr_config(PADAPTER p, u32 rcr)
+{
+	u32 v32;
+	int err;
+
+
+	v32 = GET_HAL_DATA(p)->ReceiveConfig;
+	v32 ^= rcr;
+	v32 &= BIT_APP_PHYSTS_8822B;
+	if (v32) {
+		v32 = rcr & BIT_APP_PHYSTS_8822B;
+		RTW_INFO("%s: runtime %s rx phy status!\n",
+			 __FUNCTION__, v32 ? "ENABLE" : "DISABLE");
+		if (v32) {
+			err = rtw_halmac_config_rx_info(adapter_to_dvobj(p), HALMAC_DRV_INFO_PHY_STATUS);
+			if (err) {
+				RTW_INFO("%s: Enable rx phy status FAIL!!", __FUNCTION__);
+				rcr &= ~BIT_APP_PHYSTS_8822B;
+			}
+		} else {
+			err = rtw_halmac_config_rx_info(adapter_to_dvobj(p), HALMAC_DRV_INFO_NONE);
+			if (err) {
+				RTW_INFO("%s: Disable rx phy status FAIL!!", __FUNCTION__);
+				rcr |= BIT_APP_PHYSTS_8822B;
+			}
+		}
+	}
+
+	err = rtw_write32(p, REG_RCR_8822B, rcr);
+	if (_FAIL == err)
+		return _FALSE;
+
+	GET_HAL_DATA(p)->ReceiveConfig = rcr;
+	return _TRUE;
+}
+
+inline u8 rtl8822b_rx_ba_ssn_appended(PADAPTER p)
+{
+	return rtw_hal_rcr_check(p, BIT_APP_BASSN_8822B);
+}
+
+inline u8 rtl8822b_rx_fcs_append_switch(PADAPTER p, u8 enable)
+{
+	u32 rcr_bit;
+	u8 ret = _TRUE;
+
+	rcr_bit = BIT_APP_FCS_8822B;
+	if (_TRUE == enable)
+		ret = rtw_hal_rcr_add(p, rcr_bit);
+	else
+		ret = rtw_hal_rcr_clear(p, rcr_bit);
+
+	return ret;
+}
+
+inline u8 rtl8822b_rx_fcs_appended(PADAPTER p)
+{
+	return rtw_hal_rcr_check(p, BIT_APP_FCS_8822B);
+}
+
+inline u8 rtl8822b_rx_tsf_addr_filter_config(PADAPTER p, u8 config)
+{
+	u8 v8;
+	int err;
+
+	v8 = GET_HAL_DATA(p)->rx_tsf_addr_filter_config;
+
+	if (v8 != config) {
+
+		err = rtw_write8(p, REG_NAN_RX_TSF_FILTER_8822B, config);
+		if (_FAIL == err)
+			return _FALSE;
+	}
+
+	GET_HAL_DATA(p)->rx_tsf_addr_filter_config = config;
+	return _TRUE;
+}
+
+/*
+ * Return:
+ *	_SUCCESS	Download Firmware OK.
+ *	_FAIL		Download Firmware FAIL!
+ */
+s32 rtl8822b_fw_dl(PADAPTER adapter, u8 wowlan)
+{
+	struct dvobj_priv *d = adapter_to_dvobj(adapter);
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	int err;
+	u8 fw_bin = _TRUE;
+
+#ifdef CONFIG_FILE_FWIMG
+#ifdef CONFIG_WOWLAN
+	if (wowlan)
+		rtw_get_phy_file_path(adapter, MAC_FILE_FW_WW_IMG);
+	else
+#endif /* CONFIG_WOWLAN */
+		rtw_get_phy_file_path(adapter, MAC_FILE_FW_NIC);
+
+	if (rtw_is_file_readable(rtw_phy_para_file_path) == _TRUE) {
+		RTW_INFO("%s acquire FW from file:%s\n", __FUNCTION__, rtw_phy_para_file_path);
+		fw_bin = _TRUE;
+	} else
+#endif /* CONFIG_FILE_FWIMG */
+	{
+		RTW_INFO("%s fw source from array\n", __FUNCTION__);
+		fw_bin = _FALSE;
+	}
+
+#ifdef CONFIG_FILE_FWIMG
+	if (_TRUE == fw_bin) {
+		err = rtw_halmac_dlfw_from_file(d, rtw_phy_para_file_path);
+	} else
+#endif /* CONFIG_FILE_FWIMG */
+	{
+		#ifdef CONFIG_WOWLAN
+		if (_TRUE == wowlan)
+			err = rtw_halmac_dlfw(d, array_mp_8822b_fw_wowlan, array_length_mp_8822b_fw_wowlan);
+		else
+		#endif /* CONFIG_WOWLAN */
+			err = rtw_halmac_dlfw(d, array_mp_8822b_fw_nic, array_length_mp_8822b_fw_nic);
+	}
+
+	if (!err) {
+		hal->bFWReady = _TRUE;
+		hal->fw_ractrl = _TRUE;
+		RTW_INFO("%s Download Firmware from %s success\n", __FUNCTION__, (fw_bin) ? "file" : "array");
+		RTW_INFO("%s FW Version:%d SubVersion:%d FW size:%d\n", (wowlan) ? "WOW" : "NIC",
+			hal->firmware_version, hal->firmware_sub_version, hal->firmware_size);
+		return _SUCCESS;
+	} else {
+		hal->bFWReady = _FALSE;
+		hal->fw_ractrl = _FALSE;
+		RTW_ERR("%s Download Firmware from %s failed\n", __FUNCTION__, (fw_bin) ? "file" : "array");
+		return _FAIL;
+	}
+}
+
+u8 rtl8822b_get_rx_drv_info_size(struct _ADAPTER *a)
+{
+	struct dvobj_priv *d;
+	u8 size = 80;	/* HALMAC_RX_DESC_DUMMY_SIZE_MAX_88XX */
+	int err = 0;
+
+
+	d = adapter_to_dvobj(a);
+
+	err = rtw_halmac_get_rx_drv_info_sz(d, &size);
+	if (err) {
+		RTW_WARN(FUNC_ADPT_FMT ": Fail to get DRV INFO size!!(err=%d)\n",
+			 FUNC_ADPT_ARG(a), err);
+		size = 80;
+	}
+
+	return size;
+}
+
+u32 rtl8822b_get_tx_desc_size(struct _ADAPTER *a)
+{
+	struct dvobj_priv *d;
+	u32 size = 48;	/* HALMAC_TX_DESC_SIZE_8822B */
+	int err = 0;
+
+
+	d = adapter_to_dvobj(a);
+
+	err = rtw_halmac_get_tx_desc_size(d, &size);
+	if (err) {
+		RTW_WARN(FUNC_ADPT_FMT ": Fail to get TX Descriptor size!!(err=%d)\n",
+			 FUNC_ADPT_ARG(a), err);
+		size = 48;
+	}
+
+	return size;
+}
+
+u32 rtl8822b_get_rx_desc_size(struct _ADAPTER *a)
+{
+	struct dvobj_priv *d;
+	u32 size = 24;	/* HALMAC_RX_DESC_SIZE_8822B */
+	int err = 0;
+
+
+	d = adapter_to_dvobj(a);
+
+	err = rtw_halmac_get_rx_desc_size(d, &size);
+	if (err) {
+		RTW_WARN(FUNC_ADPT_FMT ": Fail to get RX Descriptor size!!(err=%d)\n",
+			 FUNC_ADPT_ARG(a), err);
+		size = 24;
+	}
+
+	return size;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_ops.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_ops.c
new file mode 100644
index 000000000000..e0dbf72433d6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_ops.c
@@ -0,0 +1,4135 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_OPS_C_
+
+#include <drv_types.h>		/* basic_types.h, rtw_io.h and etc. */
+#include <rtw_xmit.h>		/* struct xmit_priv */
+#ifdef DBG_CONFIG_ERROR_DETECT
+#include <rtw_sreset.h>
+#endif /* DBG_CONFIG_ERROR_DETECT */
+#include <hal_data.h>		/* PHAL_DATA_TYPE, GET_HAL_DATA() */
+#include <hal_com.h>		/* rtw_hal_config_rftype(), dump_chip_info() and etc. */
+#include "../hal_halmac.h"	/* GET_RX_DESC_XXX_8822B() */
+#include "rtl8822b.h"
+#include "rtl8822b_hal.h"
+
+
+static const struct hw_port_reg port_cfg[] = {
+	/*port 0*/
+	{
+	.net_type = (REG_CR_8822B + 2),
+	.net_type_shift = 0,
+	.macaddr = REG_MACID_8822B,
+	.bssid = REG_BSSID_8822B,
+	.bcn_ctl = REG_BCN_CTRL_8822B,
+	.tsf_rst = REG_DUAL_TSF_RST,
+	.tsf_rst_bit = BIT_TSFTR_RST_8822B,
+	.bcn_space = REG_MBSSID_BCN_SPACE_8822B,
+	.bcn_space_shift = 0,
+	.bcn_space_mask = 0xffff,
+	.ps_aid = REG_BCN_PSR_RPT_8822B,
+	},
+	/*port 1*/
+	{
+	.net_type = (REG_CR_8822B + 2),
+	.net_type_shift = 2,
+	.macaddr = REG_MACID1_8822B,
+	.bssid = REG_BSSID1_8822B,
+	.bcn_ctl = REG_BCN_CTRL_CLINT0_8822B,
+	.tsf_rst = REG_DUAL_TSF_RST,
+	.tsf_rst_bit = BIT_TSFTR_CLI0_RST_8822B,
+	.bcn_space = REG_MBSSID_BCN_SPACE_8822B,
+	.bcn_space_shift = 16,
+	.bcn_space_mask = 0xfff,
+	.ps_aid = REG_BCN_PSR_RPT1_8822B,
+	},
+	/*port 2*/
+	{
+	.net_type =  REG_CR_EXT_8822B,
+	.net_type_shift = 0,
+	.macaddr = REG_MACID2_8822B,
+	.bssid = REG_BSSID2_8822B,
+	.bcn_ctl = REG_BCN_CTRL_CLINT1_8822B,
+	.tsf_rst = REG_DUAL_TSF_RST,
+	.tsf_rst_bit = BIT_TSFTR_CLI1_RST_8822B,
+	.bcn_space = REG_MBSSID_BCN_SPACE2_8822B,
+	.bcn_space_shift = 0,
+	.bcn_space_mask = 0xfff,
+	.ps_aid = REG_BCN_PSR_RPT2_8822B,
+	},
+	/*port 3*/
+	{
+	.net_type =  REG_CR_EXT_8822B,
+	.net_type_shift = 2,
+	.macaddr = REG_MACID3_8822B,
+	.bssid = REG_BSSID3_8822B,
+	.bcn_ctl = REG_BCN_CTRL_CLINT2_8822B,
+	.tsf_rst = REG_DUAL_TSF_RST,
+	.tsf_rst_bit = BIT_TSFTR_CLI2_RST_8822B,
+	.bcn_space = REG_MBSSID_BCN_SPACE2_8822B,
+	.bcn_space_shift = 16,
+	.bcn_space_mask = 0xfff,
+	.ps_aid = REG_BCN_PSR_RPT3_8822B,
+	},
+	/*port 4*/
+	{
+	.net_type =  REG_CR_EXT_8822B,
+	.net_type_shift = 4,
+	.macaddr = REG_MACID4_8822B,
+	.bssid = REG_BSSID4_8822B,
+	.bcn_ctl = REG_BCN_CTRL_CLINT3_8822B,
+	.tsf_rst = REG_DUAL_TSF_RST,
+	.tsf_rst_bit = BIT_TSFTR_CLI3_RST_8822B,
+	.bcn_space = REG_MBSSID_BCN_SPACE3_8822B,
+	.bcn_space_shift = 0,
+	.bcn_space_mask = 0xfff,
+	.ps_aid = REG_BCN_PSR_RPT4_8822B,
+	},
+};
+static void hw_bcn_ctrl_set(_adapter *adapter, u8 bcn_ctl_val)
+{
+	u8 hw_port = get_hw_port(adapter);
+	u32 bcn_ctl_addr = 0;
+
+	if (hw_port >= MAX_HW_PORT) {
+		RTW_ERR(FUNC_ADPT_FMT" HW Port(%d) invalid\n", FUNC_ADPT_ARG(adapter), hw_port);
+		rtw_warn_on(1);
+		return;
+	}
+
+	bcn_ctl_addr = port_cfg[hw_port].bcn_ctl;
+	rtw_write8(adapter, bcn_ctl_addr, bcn_ctl_val);
+}
+
+static void hw_bcn_ctrl_add(_adapter *adapter, u8 bcn_ctl_val)
+{
+	u8 hw_port = get_hw_port(adapter);
+	u32 bcn_ctl_addr = 0;
+	u8 val8 = 0;
+
+	if (hw_port >= MAX_HW_PORT) {
+		RTW_ERR(FUNC_ADPT_FMT" HW Port(%d) invalid\n", FUNC_ADPT_ARG(adapter), hw_port);
+		rtw_warn_on(1);
+		return;
+	}
+
+	bcn_ctl_addr = port_cfg[hw_port].bcn_ctl;
+	val8 = rtw_read8(adapter, bcn_ctl_addr) | bcn_ctl_val;
+	rtw_write8(adapter, bcn_ctl_addr, val8);
+}
+
+static void hw_bcn_ctrl_clr(_adapter *adapter, u8 bcn_ctl_val)
+{
+	u8 hw_port = get_hw_port(adapter);
+	u32 bcn_ctl_addr = 0;
+	u8 val8 = 0;
+
+	if (hw_port >= MAX_HW_PORT) {
+		RTW_ERR(FUNC_ADPT_FMT" HW Port(%d) invalid\n", FUNC_ADPT_ARG(adapter), hw_port);
+		rtw_warn_on(1);
+		return;
+	}
+
+	bcn_ctl_addr = port_cfg[hw_port].bcn_ctl;
+	val8 = rtw_read8(adapter, bcn_ctl_addr);
+	val8 &= ~bcn_ctl_val;
+	rtw_write8(adapter, bcn_ctl_addr, val8);
+}
+
+static void read_chip_version(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	u32 value32;
+
+
+	hal = GET_HAL_DATA(adapter);
+
+	value32 = rtw_read32(adapter, REG_SYS_CFG1_8822B);
+	hal->version_id.ICType = CHIP_8822B;
+	hal->version_id.ChipType = ((value32 & BIT_RTL_ID_8822B) ? TEST_CHIP : NORMAL_CHIP);
+	hal->version_id.CUTVersion = BIT_GET_CHIP_VER_8822B(value32);
+	hal->version_id.VendorType = BIT_GET_VENDOR_ID_8822B(value32);
+	hal->version_id.VendorType >>= 2;
+	switch (hal->version_id.VendorType) {
+	case 0:
+		hal->version_id.VendorType = CHIP_VENDOR_TSMC;
+		break;
+	case 1:
+		hal->version_id.VendorType = CHIP_VENDOR_SMIC;
+		break;
+	case 2:
+		hal->version_id.VendorType = CHIP_VENDOR_UMC;
+		break;
+	}
+
+	hal->version_id.RFType = ((value32 & BIT_RF_TYPE_ID_8822B) ? RF_TYPE_2T2R : RF_TYPE_1T1R);
+	if (adapter->registrypriv.special_rf_path == 1)
+		hal->version_id.RFType = RF_TYPE_1T1R;	/* RF_1T1R; */
+
+	hal->RegulatorMode = ((value32 & BIT_SPSLDO_SEL_8822B) ? RT_LDO_REGULATOR : RT_SWITCHING_REGULATOR);
+
+	value32 = rtw_read32(adapter, REG_SYS_STATUS1_8822B);
+	hal->version_id.ROMVer = BIT_GET_RF_RL_ID_8822B(value32);
+
+	/* For multi-function consideration. */
+	hal->MultiFunc = RT_MULTI_FUNC_NONE;
+	value32 = rtw_read32(adapter, REG_WL_BT_PWR_CTRL_8822B);
+	hal->MultiFunc |= ((value32 & BIT_WL_FUNC_EN_8822B) ? RT_MULTI_FUNC_WIFI : 0);
+	hal->MultiFunc |= ((value32 & BIT_BT_FUNC_EN_8822B) ? RT_MULTI_FUNC_BT : 0);
+	hal->PolarityCtl = ((value32 & BIT_WL_HWPDN_SL_8822B) ? RT_POLARITY_HIGH_ACT : RT_POLARITY_LOW_ACT);
+
+	rtw_hal_config_rftype(adapter);
+
+	dump_chip_info(hal->version_id);
+}
+
+/*
+ * Return:
+ *	_TRUE	valid ID
+ *	_FALSE	invalid ID
+ */
+static u8 Hal_EfuseParseIDCode(PADAPTER adapter, u8 *map)
+{
+	u16 EEPROMId;
+
+
+	/* Check 0x8129 again for making sure autoload status!! */
+	EEPROMId = le16_to_cpu(*(u16 *)map);
+	RTW_INFO("EEPROM ID = 0x%04x\n", EEPROMId);
+	if (EEPROMId == RTL_EEPROM_ID)
+		return _TRUE;
+
+	RTW_WARN("EEPROM ID is invalid!!\n");
+	return _FALSE;
+}
+
+static void Hal_EfuseParseEEPROMVer(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	if (_TRUE == mapvalid)
+		hal->EEPROMVersion = map[EEPROM_VERSION_8822B];
+	else
+		hal->EEPROMVersion = 1;
+
+	RTW_INFO("EEPROM Version = %d\n", hal->EEPROMVersion);
+}
+
+static void Hal_EfuseParseTxPowerInfo(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	TxPowerInfo24G tbl2G4;
+	TxPowerInfo5G tbl5g;
+
+	hal_load_txpwr_info(adapter, &tbl2G4, &tbl5g, map);
+
+	if ((_TRUE == mapvalid) && (map[EEPROM_RF_BOARD_OPTION_8822B] != 0xFF))
+		hal->EEPROMRegulatory = map[EEPROM_RF_BOARD_OPTION_8822B] & 0x7; /* bit0~2 */
+	else
+		hal->EEPROMRegulatory = EEPROM_DEFAULT_BOARD_OPTION & 0x7; /* bit0~2 */
+	RTW_INFO("EEPROM Regulatory=0x%02x\n", hal->EEPROMRegulatory);
+}
+
+static void Hal_EfuseParseBoardType(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	if ((_TRUE == mapvalid) && (map[EEPROM_RF_BOARD_OPTION_8822B] != 0xFF))
+		hal->InterfaceSel = (map[EEPROM_RF_BOARD_OPTION_8822B] & 0xE0) >> 5;
+	else
+		hal->InterfaceSel = (EEPROM_DEFAULT_BOARD_OPTION & 0xE0) >> 5;
+
+	RTW_INFO("EEPROM Board Type=0x%02x\n", hal->InterfaceSel);
+}
+
+static void Hal_EfuseParseBTCoexistInfo(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	u8 setting;
+	u32 tmpu4;
+
+	if ((_TRUE == mapvalid) && (map[EEPROM_RF_BOARD_OPTION_8822B] != 0xFF)) {
+		/* 0xc1[7:5] = 0x01 */
+		if (((map[EEPROM_RF_BOARD_OPTION_8822B] & 0xe0) >> 5) == 0x01)
+			hal->EEPROMBluetoothCoexist = _TRUE;
+		else
+			hal->EEPROMBluetoothCoexist = _FALSE;
+	} else
+		hal->EEPROMBluetoothCoexist = _FALSE;
+
+	hal->EEPROMBluetoothType = BT_RTL8822B;
+
+	setting = map[EEPROM_RF_BT_SETTING_8822B];
+	if ((_TRUE == mapvalid) && (setting != 0xFF)) {
+		hal->EEPROMBluetoothAntNum = setting & BIT(0);
+		/*
+		 * EFUSE_0xC3[6] == 0, S1(Main)-RF_PATH_A;
+		 * EFUSE_0xC3[6] == 1, S0(Aux)-RF_PATH_B
+		 */
+		hal->ant_path = (setting & BIT(6)) ? RF_PATH_B : RF_PATH_A;
+	} else {
+		hal->EEPROMBluetoothAntNum = Ant_x2;
+		hal->ant_path = RF_PATH_A;
+	}
+
+exit:
+	RTW_INFO("EEPROM %s BT-coex, ant_num=%d\n",
+		 hal->EEPROMBluetoothCoexist == _TRUE ? "Enable" : "Disable",
+		 hal->EEPROMBluetoothAntNum == Ant_x2 ? 2 : 1);
+}
+
+static void Hal_EfuseParseChnlPlan(PADAPTER adapter, u8 *map, u8 autoloadfail)
+{
+	hal_com_config_channel_plan(
+		adapter,
+		map ? &map[EEPROM_COUNTRY_CODE_8822B] : NULL,
+		map ? map[EEPROM_ChannelPlan_8822B] : 0xFF,
+		adapter->registrypriv.alpha2,
+		adapter->registrypriv.channel_plan,
+		RTW_CHPLAN_REALTEK_DEFINE,
+		autoloadfail
+	);
+}
+
+static void Hal_EfuseParseXtal(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	if ((_TRUE == mapvalid) && map[EEPROM_XTAL_8822B] != 0xFF)
+		hal->crystal_cap = map[EEPROM_XTAL_8822B];
+	else
+		hal->crystal_cap = EEPROM_Default_CrystalCap;
+
+	RTW_INFO("EEPROM crystal_cap=0x%02x\n", hal->crystal_cap);
+}
+
+static void Hal_EfuseParseThermalMeter(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	/* ThermalMeter from EEPROM */
+	if ((_TRUE == mapvalid) && (map[EEPROM_THERMAL_METER_8822B] != 0xFF))
+		hal->eeprom_thermal_meter = map[EEPROM_THERMAL_METER_8822B];
+	else {
+		hal->eeprom_thermal_meter = EEPROM_Default_ThermalMeter;
+		hal->odmpriv.rf_calibrate_info.is_apk_thermal_meter_ignore = _TRUE;
+	}
+
+	RTW_INFO("EEPROM ThermalMeter=0x%02x\n", hal->eeprom_thermal_meter);
+}
+
+static void Hal_EfuseParseAntennaDiversity(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct registry_priv *registry_par = &adapter->registrypriv;
+
+
+	if (hal->EEPROMBluetoothAntNum == Ant_x1)
+		hal->AntDivCfg = 0;
+	else {
+		if (registry_par->antdiv_cfg == 2)/* 0:OFF , 1:ON, 2:By EFUSE */
+			hal->AntDivCfg = 1;
+		else
+			hal->AntDivCfg = registry_par->antdiv_cfg;
+	}
+
+	/* If TRxAntDivType is AUTO in advanced setting, use EFUSE value instead. */
+	if (registry_par->antdiv_type == 0) {
+		hal->TRxAntDivType = map[EEPROM_RFE_OPTION_8822B];
+		if (hal->TRxAntDivType == 0xFF)
+			hal->TRxAntDivType = S0S1_SW_ANTDIV; /* internal switch S0S1 */
+		else if (hal->TRxAntDivType == 0x10)
+			hal->TRxAntDivType = S0S1_SW_ANTDIV; /* internal switch S0S1 */
+		else if (hal->TRxAntDivType == 0x11)
+			hal->TRxAntDivType = S0S1_SW_ANTDIV; /* internal switch S0S1 */
+		else
+			RTW_INFO("EEPROM efuse[0x%x]=0x%02x is unknown type\n",
+				 EEPROM_RFE_OPTION_8723B, hal->TRxAntDivType);
+	} else
+		hal->TRxAntDivType = registry_par->antdiv_type;
+
+	RTW_INFO("EEPROM AntDivCfg=%d, AntDivType=%d\n",
+		 hal->AntDivCfg, hal->TRxAntDivType);
+#endif /* CONFIG_ANTENNA_DIVERSITY */
+}
+
+static void Hal_EfuseParseCustomerID(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	if (_TRUE == mapvalid)
+		hal->EEPROMCustomerID = map[EEPROM_CustomID_8822B];
+	else
+		hal->EEPROMCustomerID = 0;
+	RTW_INFO("EEPROM Customer ID=0x%02x\n", hal->EEPROMCustomerID);
+}
+
+static void Hal_DetectWoWMode(PADAPTER adapter)
+{
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	adapter_to_pwrctl(adapter)->bSupportRemoteWakeup = _TRUE;
+#else /* !(CONFIG_WOWLAN || CONFIG_AP_WOWLAN) */
+	adapter_to_pwrctl(adapter)->bSupportRemoteWakeup = _FALSE;
+#endif /* !(CONFIG_WOWLAN || CONFIG_AP_WOWLAN) */
+
+	RTW_INFO("EEPROM SupportRemoteWakeup=%d\n", adapter_to_pwrctl(adapter)->bSupportRemoteWakeup);
+}
+
+static void hal_ReadPAType(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+	if (mapvalid) {
+		/* AUTO */
+		if (GetRegAmplifierType2G(adapter) == 0) {
+			hal->PAType_2G = ReadLE1Byte(&map[EEPROM_2G_5G_PA_TYPE_8822B]);
+			hal->LNAType_2G = ReadLE1Byte(&map[EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B]);
+
+			if (hal->PAType_2G == 0xFF)
+				hal->PAType_2G = 0;
+
+			if (hal->LNAType_2G == 0xFF)
+				hal->LNAType_2G = 0;
+
+			hal->ExternalPA_2G = (hal->PAType_2G & BIT4) ? 1 : 0;
+			hal->ExternalLNA_2G = (hal->LNAType_2G & BIT3) ? 1 : 0;
+		} else {
+			hal->ExternalPA_2G  = (GetRegAmplifierType2G(adapter) & ODM_BOARD_EXT_PA)  ? 1 : 0;
+			hal->ExternalLNA_2G = (GetRegAmplifierType2G(adapter) & ODM_BOARD_EXT_LNA) ? 1 : 0;
+		}
+
+		/* AUTO */
+		if (GetRegAmplifierType5G(adapter) == 0) {
+			hal->PAType_5G = ReadLE1Byte(&map[EEPROM_2G_5G_PA_TYPE_8822B]);
+			hal->LNAType_5G = ReadLE1Byte(&map[EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B]);
+			if (hal->PAType_5G == 0xFF)
+				hal->PAType_5G = 0;
+			if (hal->LNAType_5G == 0xFF)
+				hal->LNAType_5G = 0;
+
+			hal->external_pa_5g = (hal->PAType_5G & BIT0) ? 1 : 0;
+			hal->external_lna_5g = (hal->LNAType_5G & BIT3) ? 1 : 0;
+		} else {
+			hal->external_pa_5g  = (GetRegAmplifierType5G(adapter) & ODM_BOARD_EXT_PA_5G)  ? 1 : 0;
+			hal->external_lna_5g = (GetRegAmplifierType5G(adapter) & ODM_BOARD_EXT_LNA_5G) ? 1 : 0;
+		}
+	} else {
+		hal->ExternalPA_2G  = EEPROM_Default_PAType;
+		hal->external_pa_5g  = 0xFF;
+		hal->ExternalLNA_2G = EEPROM_Default_LNAType;
+		hal->external_lna_5g = 0xFF;
+
+		/* AUTO */
+		if (GetRegAmplifierType2G(adapter) == 0) {
+			hal->ExternalPA_2G  = 0;
+			hal->ExternalLNA_2G = 0;
+		} else {
+			hal->ExternalPA_2G  = (GetRegAmplifierType2G(adapter) & ODM_BOARD_EXT_PA)  ? 1 : 0;
+			hal->ExternalLNA_2G = (GetRegAmplifierType2G(adapter) & ODM_BOARD_EXT_LNA) ? 1 : 0;
+		}
+
+		/* AUTO */
+		if (GetRegAmplifierType5G(adapter) == 0) {
+			hal->external_pa_5g  = 0;
+			hal->external_lna_5g = 0;
+		} else {
+			hal->external_pa_5g  = (GetRegAmplifierType5G(adapter) & ODM_BOARD_EXT_PA_5G)  ? 1 : 0;
+			hal->external_lna_5g = (GetRegAmplifierType5G(adapter) & ODM_BOARD_EXT_LNA_5G) ? 1 : 0;
+		}
+	}
+
+	RTW_INFO("EEPROM PAType_2G is 0x%x, ExternalPA_2G = %d\n", hal->PAType_2G, hal->ExternalPA_2G);
+	RTW_INFO("EEPROM PAType_5G is 0x%x, external_pa_5g = %d\n", hal->PAType_5G, hal->external_pa_5g);
+	RTW_INFO("EEPROM LNAType_2G is 0x%x, ExternalLNA_2G = %d\n", hal->LNAType_2G, hal->ExternalLNA_2G);
+	RTW_INFO("EEPROM LNAType_5G is 0x%x, external_lna_5g = %d\n", hal->LNAType_5G, hal->external_lna_5g);
+}
+
+static void Hal_ReadAmplifierType(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	u8 extTypePA_2G_A = (map[EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B] & BIT2) >> 2;
+	u8 extTypePA_2G_B = (map[EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B] & BIT6) >> 6;
+	u8 extTypePA_5G_A = (map[EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B] & BIT2) >> 2;
+	u8 extTypePA_5G_B = (map[EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B] & BIT6) >> 6;
+	u8 extTypeLNA_2G_A = (map[EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B] & (BIT1 | BIT0)) >> 0;
+	u8 extTypeLNA_2G_B = (map[EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B] & (BIT5 | BIT4)) >> 4;
+	u8 extTypeLNA_5G_A = (map[EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B] & (BIT1 | BIT0)) >> 0;
+	u8 extTypeLNA_5G_B = (map[EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B] & (BIT5 | BIT4)) >> 4;
+
+	hal_ReadPAType(adapter, map, mapvalid);
+
+	/* [2.4G] Path A and B are both extPA */
+	if ((hal->PAType_2G & (BIT5 | BIT4)) == (BIT5 | BIT4))
+		hal->TypeGPA  = extTypePA_2G_B  << 2 | extTypePA_2G_A;
+
+	/* [5G] Path A and B are both extPA */
+	if ((hal->PAType_5G & (BIT1 | BIT0)) == (BIT1 | BIT0))
+		hal->TypeAPA  = extTypePA_5G_B  << 2 | extTypePA_5G_A;
+
+	/* [2.4G] Path A and B are both extLNA */
+	if ((hal->LNAType_2G & (BIT7 | BIT3)) == (BIT7 | BIT3))
+		hal->TypeGLNA = extTypeLNA_2G_B << 2 | extTypeLNA_2G_A;
+
+	/* [5G] Path A and B are both extLNA */
+	if ((hal->LNAType_5G & (BIT7 | BIT3)) == (BIT7 | BIT3))
+		hal->TypeALNA = extTypeLNA_5G_B << 2 | extTypeLNA_5G_A;
+
+	RTW_INFO("EEPROM TypeGPA = 0x%X\n", hal->TypeGPA);
+	RTW_INFO("EEPROM TypeAPA = 0x%X\n", hal->TypeAPA);
+	RTW_INFO("EEPROM TypeGLNA = 0x%X\n", hal->TypeGLNA);
+	RTW_INFO("EEPROM TypeALNA = 0x%X\n", hal->TypeALNA);
+}
+
+static u8 Hal_ReadRFEType(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	/* check registry value */
+	if (GetRegRFEType(adapter) != CONFIG_RTW_RFE_TYPE) {
+		hal->rfe_type = GetRegRFEType(adapter);
+		goto exit;
+	}
+
+	if (mapvalid) {
+		/* check efuse map */
+		hal->rfe_type = ReadLE1Byte(&map[EEPROM_RFE_OPTION_8822B]);
+		if (0xFF != hal->rfe_type)
+			goto exit;
+	}
+
+	/* error handle */
+	hal->rfe_type = 0;
+
+	/* If ignore incorrect rfe_type may cause card drop. */
+	/* it's DIFFICULT do debug especially on COB project */
+	RTW_ERR("\n\nEmpty EFUSE with unknown REF type!!\n\n");
+	RTW_ERR("please program efuse or specify correct RFE type.\n");
+	RTW_ERR("cmd: insmod rtl8822bx.ko rtw_RFE_type=<rfe_type>\n\n");
+
+	return _FAIL;
+
+exit:
+	RTW_INFO("EEPROM rfe_type=0x%x\n", hal->rfe_type);
+	return _SUCCESS;
+}
+
+static void Hal_EfuseParsePackageType(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+}
+
+static void Hal_EfuseParsePABias(PADAPTER adapter)
+{
+	struct hal_com_data *hal;
+	u8 data[2] = {0xFF, 0xFF};
+	u8 ret;
+
+
+	ret = rtw_efuse_access(adapter, 0, 0x3D7, 2, data);
+	if (_FAIL == ret) {
+		RTW_ERR("%s: Fail to read PA Bias from eFuse!\n", __FUNCTION__);
+		return;
+	}
+
+	hal = GET_HAL_DATA(adapter);
+	hal->efuse0x3d7 = data[0];	/* efuse[0x3D7] */
+	hal->efuse0x3d8 = data[1];	/* efuse[0x3D8] */
+
+	RTW_INFO("EEPROM efuse[0x3D7]=0x%x\n", hal->efuse0x3d7);
+	RTW_INFO("EEPROM efuse[0x3D8]=0x%x\n", hal->efuse0x3d8);
+}
+
+
+#ifdef CONFIG_USB_HCI
+static void Hal_ReadUsbModeSwitch(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+	if (_TRUE == mapvalid)
+		/* check efuse 0x06 bit7 */
+		hal->EEPROMUsbSwitch = (map[EEPROM_USB_MODE_8822BU] & BIT7) >> 7;
+	else
+		hal->EEPROMUsbSwitch = _FALSE;
+
+	RTW_INFO("EEPROM USB Switch=%d\n", hal->EEPROMUsbSwitch);
+}
+
+static void hal_read_usb_pid_vid(PADAPTER adapter, u8 *map, u8 mapvalid)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+	if (_TRUE == mapvalid) {
+		/* VID, PID */
+		hal->EEPROMVID = ReadLE2Byte(&map[EEPROM_VID_8822BU]);
+		hal->EEPROMPID = ReadLE2Byte(&map[EEPROM_PID_8822BU]);
+	} else {
+		hal->EEPROMVID = EEPROM_Default_VID;
+		hal->EEPROMPID = EEPROM_Default_PID;
+	}
+
+	RTW_INFO("EEPROM VID = 0x%04X, PID = 0x%04X\n", hal->EEPROMVID, hal->EEPROMPID);
+}
+
+#endif /* CONFIG_USB_HCI */
+
+/*
+ * Description:
+ *	Collect all information from efuse or files.
+ *	This function will do
+ *	1. Read registers to check hardware efuse available or not
+ *	2. Read Efuse/EEPROM
+ *	3. Read file if necessary
+ *	4. Parsing Efuse data
+ */
+u8 rtl8822b_read_efuse(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	u8 val8;
+	u8 *efuse_map = NULL;
+	u8 valid;
+	u8 ret = _FAIL;
+
+	hal = GET_HAL_DATA(adapter);
+	efuse_map = hal->efuse_eeprom_data;
+
+	/* 1. Read registers to check hardware eFuse available or not */
+	val8 = rtw_read8(adapter, REG_SYS_EEPROM_CTRL_8822B);
+	hal->EepromOrEfuse = (val8 & BIT_EERPOMSEL_8822B) ? _TRUE : _FALSE;
+	hal->bautoload_fail_flag = (val8 & BIT_AUTOLOAD_SUS_8822B) ? _FALSE : _TRUE;
+	/*
+	 * In 8822B, bautoload_fail_flag is used to present eFuse map is valid
+	 * or not, no matter the map comes from hardware or files.
+	 */
+
+	/* 2. Read eFuse */
+	EFUSE_ShadowMapUpdate(adapter, EFUSE_WIFI, 0);
+
+	/* 3. Read Efuse file if necessary */
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+	if (check_phy_efuse_tx_power_info_valid(adapter) == _FALSE) {
+		if (Hal_readPGDataFromConfigFile(adapter) != _SUCCESS)
+			RTW_WARN("%s: invalid phy efuse and read from file fail, will use driver default!!\n", __FUNCTION__);
+	}
+#endif /* CONFIG_EFUSE_CONFIG_FILE */
+
+	/* 4. Parse Efuse data */
+	valid = Hal_EfuseParseIDCode(adapter, efuse_map);
+	if (_TRUE == valid)
+		hal->bautoload_fail_flag = _FALSE;
+	else
+		hal->bautoload_fail_flag = _TRUE;
+
+	Hal_EfuseParseEEPROMVer(adapter, efuse_map, valid);
+	hal_config_macaddr(adapter, hal->bautoload_fail_flag);
+	Hal_EfuseParseTxPowerInfo(adapter, efuse_map, valid);
+	Hal_EfuseParseBoardType(adapter, efuse_map, valid);
+	Hal_EfuseParseBTCoexistInfo(adapter, efuse_map, valid);
+	Hal_EfuseParseChnlPlan(adapter, efuse_map, hal->bautoload_fail_flag);
+	Hal_EfuseParseXtal(adapter, efuse_map, valid);
+	Hal_EfuseParseThermalMeter(adapter, efuse_map, valid);
+	Hal_EfuseParseAntennaDiversity(adapter, efuse_map, valid);
+	Hal_EfuseParseCustomerID(adapter, efuse_map, valid);
+	Hal_DetectWoWMode(adapter);
+	Hal_ReadAmplifierType(adapter, efuse_map, valid);
+	if (Hal_ReadRFEType(adapter, efuse_map, valid) != _SUCCESS)
+		goto exit;
+
+	/* Data out of Efuse Map */
+	Hal_EfuseParsePackageType(adapter, efuse_map, valid);
+	Hal_EfuseParsePABias(adapter);
+
+#ifdef CONFIG_USB_HCI
+	Hal_ReadUsbModeSwitch(adapter, efuse_map, valid);
+	hal_read_usb_pid_vid(adapter, efuse_map, valid);
+#endif /* CONFIG_USB_HCI */
+
+	/* set coex. ant info once efuse parsing is done */
+	rtw_btcoex_set_ant_info(adapter);
+
+#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
+	hal_read_mac_hidden_rpt(adapter);
+	{
+		struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+
+		if (hal_spec->hci_type <= 3 && hal_spec->hci_type >= 1) {
+			hal->EEPROMBluetoothCoexist = _FALSE;
+			RTW_INFO("EEPROM Disable BT-coex by hal_spec\n");
+			rtw_btcoex_wifionly_AntInfoSetting(adapter);
+		}
+	}
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtl8822b_run_thread(PADAPTER adapter)
+{
+}
+
+void rtl8822b_cancel_thread(PADAPTER adapter)
+{
+}
+
+/*
+ * Description:
+ *	Using 0x100 to check the power status of FW.
+ */
+static u8 check_ips_status(PADAPTER adapter)
+{
+	u8 val8;
+
+
+	RTW_INFO(FUNC_ADPT_FMT ": Read 0x100=0x%02x 0x86=0x%02x\n",
+		 FUNC_ADPT_ARG(adapter),
+		 rtw_read8(adapter, 0x100), rtw_read8(adapter, 0x86));
+
+	val8 = rtw_read8(adapter, 0x100);
+	if (val8 == 0xEA)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+static void InitBeaconParameters(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	u16 val16;
+	u8 val8;
+
+
+	val8 = BIT_DIS_TSF_UDT_8822B;
+	val16 = val8 | (val8 << 8); /* port0 and port1 */
+#ifdef CONFIG_BT_COEXIST
+	if (hal->EEPROMBluetoothCoexist)
+		/* Enable port0 beacon function for PSTDMA under BTCOEX */
+		val16 |= EN_BCN_FUNCTION;
+#endif
+	rtw_write16(adapter, REG_BCN_CTRL_8822B, val16);
+
+	/* TBTT setup time */
+	rtw_write8(adapter, REG_TBTT_PROHIBIT_8822B, TBTT_PROHIBIT_SETUP_TIME);
+
+	/* TBTT hold time: 0x540[19:8] */
+	rtw_write8(adapter, REG_TBTT_PROHIBIT_8822B + 1, TBTT_PROHIBIT_HOLD_TIME_STOP_BCN & 0xFF);
+	rtw_write8(adapter, REG_TBTT_PROHIBIT_8822B + 2,
+		(rtw_read8(adapter, REG_TBTT_PROHIBIT_8822B + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME_STOP_BCN >> 8));
+
+	rtw_write8(adapter, REG_DRVERLYINT_8822B, DRIVER_EARLY_INT_TIME_8822B); /* 5ms */
+	rtw_write8(adapter, REG_BCNDMATIM_8822B, BCN_DMA_ATIME_INT_TIME_8822B); /* 2ms */
+
+	/*
+	 * Suggested by designer timchen. Change beacon AIFS to the largest number
+	 * beacause test chip does not contension before sending beacon.
+	 */
+	rtw_write16(adapter, REG_BCNTCFG_8822B, 0x660F);
+}
+
+static void beacon_function_enable(PADAPTER adapter, u8 Enable, u8 Linked)
+{
+	u8 val8;
+	u32 bcn_ctrl_reg;
+
+	/* port0 */
+	bcn_ctrl_reg = REG_BCN_CTRL_8822B;
+	val8  = BIT_DIS_TSF_UDT_8822B | BIT_EN_BCN_FUNCTION_8822B;
+#ifdef CONFIG_CONCURRENT_MODE
+	/* port1 */
+	if (adapter->hw_port == HW_PORT1) {
+		bcn_ctrl_reg = REG_BCN_CTRL_CLINT0_8822B;
+		val8 = BIT_CLI0_DIS_TSF_UDT_8822B | BIT_CLI0_EN_BCN_FUNCTION_8822B;
+	}
+#endif
+
+	rtw_write8(adapter, bcn_ctrl_reg, val8);
+	rtw_write8(adapter, REG_RD_CTRL_8822B + 1, 0x6F);
+}
+
+static void set_beacon_related_registers(PADAPTER adapter)
+{
+	u8 val8;
+	u32 value32;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	u32 bcn_ctrl_reg, bcn_interval_reg;
+
+
+	/* 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)
+	 */
+
+	bcn_ctrl_reg = REG_BCN_CTRL_8822B;
+#ifdef CONFIG_CONCURRENT_MODE
+	if (adapter->hw_port == HW_PORT1)
+		bcn_ctrl_reg = REG_BCN_CTRL_CLINT0_8822B;
+#endif
+
+	/*
+	 * ATIM window
+	 */
+	rtw_write16(adapter, REG_ATIMWND_8822B, 2);
+
+	/*
+	 * Beacon interval (in unit of TU).
+	 */
+#ifdef CONFIG_CONCURRENT_MODE
+	/* Port 1 bcn interval */
+	if (adapter->hw_port == HW_PORT1) {
+		u16 val16;
+
+		val16 = rtw_read16(adapter, (REG_MBSSID_BCN_SPACE_8822B + 2));
+		val16 |= (pmlmeinfo->bcn_interval & BIT_MASK_BCN_SPACE_CLINT0_8822B);
+		rtw_write16(adapter, REG_MBSSID_BCN_SPACE_8822B + 2, val16);
+	} else
+#endif
+		/* Port 0 bcn interval */
+		rtw_write16(adapter, REG_MBSSID_BCN_SPACE_8822B, pmlmeinfo->bcn_interval);
+
+	InitBeaconParameters(adapter);
+
+	rtw_write8(adapter, REG_SLOT_8822B, 0x09);
+
+	/* Reset TSF Timer to zero */
+	val8 = BIT_TSFTR_RST_8822B;
+#ifdef CONFIG_CONCURRENT_MODE
+	if (adapter->hw_port == HW_PORT1)
+		val8 = BIT_TSFTR_CLI0_RST_8822B;
+#endif
+	rtw_write8(adapter, REG_DUAL_TSF_RST_8822B, val8);
+	val8 = BIT_TSFTR_RST_8822B;
+	rtw_write8(adapter, REG_DUAL_TSF_RST_8822B, val8);
+
+	rtw_write8(adapter, REG_RXTSF_OFFSET_CCK_8822B, 0x50);
+	rtw_write8(adapter, REG_RXTSF_OFFSET_OFDM_8822B, 0x50);
+
+	beacon_function_enable(adapter, _TRUE, _TRUE);
+
+	ResumeTxBeacon(adapter);
+}
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+static void xmit_status_check(PADAPTER p)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(p);
+	struct sreset_priv *psrtpriv = &hal->srestpriv;
+	struct xmit_priv *pxmitpriv = &p->xmitpriv;
+	systime current_time = 0;
+	unsigned int diff_time = 0;
+	u32 txdma_status = 0;
+
+	txdma_status = rtw_read32(p, REG_TXDMA_STATUS_8822B);
+	if (txdma_status != 0x00) {
+		RTW_INFO("%s REG_TXDMA_STATUS:0x%08x\n", __FUNCTION__, txdma_status);
+		psrtpriv->tx_dma_status_cnt++;
+		psrtpriv->self_dect_case = 4;
+		rtw_hal_sreset_reset(p);
+	}
+#ifdef CONFIG_USB_HCI
+	current_time = rtw_get_current_time();
+
+	if (0 == pxmitpriv->free_xmitbuf_cnt || 0 == pxmitpriv->free_xmit_extbuf_cnt) {
+		diff_time = rtw_get_passing_time_ms(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 = rtw_get_passing_time_ms(psrtpriv->last_tx_complete_time);
+				if (diff_time > 4000) {
+					u32 ability = 0;
+
+					ability = rtw_phydm_ability_get(p);
+
+					RTW_INFO("%s tx hang %s\n", __FUNCTION__,
+						(ability & ODM_BB_ADAPTIVITY) ? "ODM_BB_ADAPTIVITY" : "");
+
+					if (!(ability & ODM_BB_ADAPTIVITY)) {
+						psrtpriv->self_dect_tx_cnt++;
+						psrtpriv->self_dect_case = 1;
+						rtw_hal_sreset_reset(p);
+				}
+			}
+		}
+	}
+	}
+#endif /* CONFIG_USB_HCI */
+
+	if (psrtpriv->dbg_trigger_point == SRESET_TGP_XMIT_STATUS) {
+		psrtpriv->dbg_trigger_point = SRESET_TGP_NULL;
+		rtw_hal_sreset_reset(p);
+		return;
+	}
+}
+
+static void check_rx_count(PADAPTER p)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(p);
+	struct sreset_priv *psrtpriv = &hal->srestpriv;
+	u16 cur_mac_rxff_ptr;
+
+	cur_mac_rxff_ptr = rtw_read16(p, REG_RXFF_PTR_V1_8822B);
+
+#if 0
+	RTW_INFO("%s,psrtpriv->last_mac_rxff_ptr = %d , cur_mac_rxff_ptr = %d\n", __func__, psrtpriv->last_mac_rxff_ptr, cur_mac_rxff_ptr);
+#endif
+
+	if (psrtpriv->last_mac_rxff_ptr == cur_mac_rxff_ptr) {
+		psrtpriv->rx_cnt++;
+#if 0
+		RTW_INFO("%s,MAC case rx_cnt=%d\n", __func__, psrtpriv->rx_cnt);
+#endif
+		goto exit;
+	}
+
+	psrtpriv->rx_cnt = 0;
+
+exit:
+
+	psrtpriv->last_mac_rxff_ptr = cur_mac_rxff_ptr;
+
+	if (psrtpriv->rx_cnt > 3) {
+		psrtpriv->self_dect_case = 2;
+		psrtpriv->self_dect_rx_cnt++;
+		rtw_hal_sreset_reset(p);
+	}
+}
+
+static void linked_status_check(PADAPTER p)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(p);
+	struct sreset_priv *psrtpriv = &hal->srestpriv;
+	struct	pwrctrl_priv *pwrpriv = adapter_to_pwrctl(p);
+	u32 rx_dma_status = 0;
+
+	rx_dma_status = rtw_read32(p, REG_RXDMA_STATUS_8822B);
+	if (rx_dma_status != 0x00) {
+		RTW_INFO("%s REG_RXDMA_STATUS:0x%08x\n", __FUNCTION__, rx_dma_status);
+		psrtpriv->rx_dma_status_cnt++;
+		psrtpriv->self_dect_case = 5;
+#ifdef CONFIG_USB_HCI
+		rtw_hal_sreset_reset(p);
+#endif /* CONFIG_USB_HCI */
+	}
+
+	if (psrtpriv->self_dect_fw) {
+		psrtpriv->self_dect_case = 3;
+#ifdef CONFIG_USB_HCI
+		rtw_hal_sreset_reset(p);
+#endif /* CONFIG_USB_HCI */
+	}
+
+#ifdef CONFIG_USB_HCI
+	check_rx_count(p);
+#endif /* CONFIG_USB_HCI */
+
+	if (psrtpriv->dbg_trigger_point == SRESET_TGP_LINK_STATUS) {
+		psrtpriv->dbg_trigger_point = SRESET_TGP_NULL;
+		rtw_hal_sreset_reset(p);
+		return;
+	}
+}
+#endif /* DBG_CONFIG_ERROR_DETECT */
+
+static void set_opmode_monitor(PADAPTER adapter)
+{
+	u32 rcr_bits;
+	u16 value_rxfltmap2;
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+
+
+	/* Receive all type */
+	rcr_bits = BIT_AAP_8822B | BIT_APM_8822B | BIT_AM_8822B
+		   | BIT_AB_8822B | BIT_APWRMGT_8822B
+		   | BIT_APP_PHYSTS_8822B;
+
+	/* Append FCS */
+	rcr_bits |= BIT_APP_FCS_8822B;
+
+	rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&GET_HAL_DATA(adapter)->rcr_backup);
+	rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr_bits);
+
+	/* Receive all data frames */
+	value_rxfltmap2 = 0xFFFF;
+	rtw_write16(adapter, REG_RXFLTMAP2_8822B, value_rxfltmap2);
+}
+
+static void hw_port0_tsf_sync_sel(_adapter *adapter, u8 hw_port, u8 benable, u16 tr_offset)
+{
+	u8 val8, client_port_num = 0;
+
+	/* check if port0 is already synced */
+	if (benable && adapter->tsf.sync_port != MAX_HW_PORT) {
+		RTW_WARN(FUNC_ADPT_FMT ": port0 already enable TSF sync(%d)\n",
+			FUNC_ADPT_ARG(adapter), adapter->tsf.sync_port);
+		return;
+	}
+
+	/* check if port0 already disable sync */
+	if (!benable && adapter->tsf.sync_port == MAX_HW_PORT) {
+		RTW_WARN(FUNC_ADPT_FMT ": port0 already disable TSF sync\n", FUNC_ADPT_ARG(adapter));
+		return;
+	}
+
+	/* check if port0 sync from port0 */
+	if (benable && hw_port == HW_PORT0) {
+		RTW_ERR(FUNC_ADPT_FMT ": hw_port is port0 under enable\n", FUNC_ADPT_ARG(adapter));
+		rtw_warn_on(1);
+		return;
+	}
+
+	/* translate hw_port number to client port numer */
+	switch (hw_port) {
+	case HW_PORT1:
+		client_port_num = 0;
+		break;
+	case HW_PORT2:
+		client_port_num = 1;
+		break;
+	case HW_PORT3:
+		client_port_num = 2;
+		break;
+	case HW_PORT4:
+		client_port_num = 3;
+		break;
+	}
+
+	/* stop port0 bcn funtion */
+	hw_bcn_ctrl_clr(adapter, BIT_EN_BCN_FUNCTION);
+
+
+	/*Reg 0x518[15:0]: TSFTR_SYN_OFFSET*/
+	if (tr_offset)
+		rtw_write16(adapter, REG_TSFTR_SYN_OFFSET_8822B, tr_offset);
+
+
+	/* auto sync for every TBTT */
+	val8 = rtw_read8(adapter, REG_MISC_CTRL_8822B);
+	val8 |= BIT_AUTO_SYNC_BY_TBTT_8822B;
+	rtw_write8(adapter, REG_MISC_CTRL_8822B, val8);
+
+	/*0x5B4 [6:4] :SYNC_CLI_SEL - The selector for the CLINT port of sync tsft source for port 0*/
+	/*	Bit[5:4] : 0 for CLINT 0, 1 for clint1, 2 for clint2, 3 for clint3.
+		Bit6 : 1= enable sync to port 0. 0=disable sync to port 0.*/
+	val8 = rtw_read8(adapter, REG_TIMER0_SRC_SEL_8822B);
+	if (benable) {
+		val8 &= 0x8F;
+		val8 |= (BIT(6) | (client_port_num << 4));
+
+		adapter->tsf.sync_port = hw_port;
+		adapter->tsf.offset = tr_offset;
+	} else {
+		val8 &= ~BIT(6);
+
+		adapter->tsf.sync_port = MAX_HW_PORT;
+		adapter->tsf.offset = 0;
+	}
+
+	rtw_write8(adapter, REG_TIMER0_SRC_SEL_8822B, val8);
+
+	/* restart port0 bcn funtion */
+	hw_bcn_ctrl_add(adapter, BIT_EN_BCN_FUNCTION);
+}
+
+static void set_opmode_port0(PADAPTER adapter, u8 mode)
+{
+	u8 is_tx_bcn;
+	u8 val8;
+	u16 val16;
+	u32 val32;
+
+
+#ifdef CONFIG_CONCURRENT_MODE
+	is_tx_bcn = rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter);
+#else /* !CONFIG_CONCURRENT_MODE */
+	is_tx_bcn = 0;
+#endif /* !CONFIG_CONCURRENT_MODE */
+
+	/* disable Port0 TSF update */
+	val8 = rtw_read8(adapter, REG_BCN_CTRL_8822B);
+	val8 |= BIT_DIS_TSF_UDT_8822B;
+	rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+
+	Set_MSR(adapter, mode);
+
+	RTW_INFO(FUNC_ADPT_FMT ": hw_port(%d) mode=%d\n",
+		 FUNC_ADPT_ARG(adapter), adapter->hw_port, mode);
+
+	switch (mode) {
+	case _HW_STATE_NOLINK_:
+	case _HW_STATE_STATION_:
+		if (!is_tx_bcn) {
+			StopTxBeacon(adapter);
+#ifdef CONFIG_PCI_HCI
+			UpdateInterruptMask8822BE(adapter, 0, 0, RT_BCN_INT_MASKS, 0);
+#endif /* CONFIG_PCI_HCI */
+		}
+
+		/* disable beacon function */
+		val8 = BIT_DIS_TSF_UDT_8822B | BIT_EN_BCN_FUNCTION_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+
+		/* disable atim wnd(only for Port0) */
+		val8 = rtw_read8(adapter, REG_DIS_ATIM_8822B);
+		val8 |= BIT_DIS_ATIM_ROOT_8822B;
+		rtw_write8(adapter, REG_DIS_ATIM_8822B, val8);
+		break;
+
+	case _HW_STATE_ADHOC_:
+		ResumeTxBeacon(adapter);
+		val8 = BIT_DIS_TSF_UDT_8822B | BIT_EN_BCN_FUNCTION_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+		break;
+
+	case _HW_STATE_AP_:
+#ifdef CONFIG_PCI_HCI
+		UpdateInterruptMask8822BE(adapter, RT_BCN_INT_MASKS, 0, 0, 0);
+#endif /* CONFIG_PCI_HCI */
+
+		ResumeTxBeacon(adapter);
+
+		/*
+		 * enable BCN0 Function for if1
+		 * disable update TSF0 for if1
+		 * enable TX BCN report:
+		 * Reg REG_FWHW_TXQ_CTRL_8822B [2] = 1
+		 * Reg REG_BCN_CTRL_8822B[3][5] = 1
+		 * Enable ATIM
+		 * Enable HW seq for BCN
+		 */
+		/* enable TX BCN report */
+		/* disable RX BCN report */
+		val8 = rtw_read8(adapter, REG_FWHW_TXQ_CTRL_8822B);
+		val8 |= BIT_EN_BCN_TRXRPT_V1_8822B;
+		rtw_write8(adapter, REG_FWHW_TXQ_CTRL_8822B, val8);
+
+		/* enable BCN0 Function */
+		val8 = rtw_read8(adapter, REG_BCN_CTRL_8822B);
+		val8 |= BIT_EN_BCN_FUNCTION_8822B | BIT_DIS_TSF_UDT_8822B | BIT_P0_EN_TXBCN_RPT_8822B;
+		val8 &= (~BIT_P0_EN_RXBCN_RPT_8822B);
+		rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+
+		/* Enable ATIM */
+		val8 = rtw_read8(adapter, REG_DIS_ATIM_8822B);
+		val8 &= ~BIT_DIS_ATIM_ROOT_8822B;
+		rtw_write8(adapter, REG_DIS_ATIM_8822B, val8);
+
+		/* Enable HW seq for BCN
+			0x4FC[0]: EN_HWSEQ
+=			0x4FC[1]: EN_HWSEQEXT
+			According TX desc
+		*/
+		rtw_write8(adapter, REG_DUMMY_PAGE4_V1_8822B, 0x01);
+
+		/* enable to rx data frame */
+		rtw_write16(adapter, REG_RXFLTMAP2_8822B, 0xFFFF);
+
+		/* enable to rx ps-poll */
+		val16 = rtw_read16(adapter, REG_RXFLTMAP1_8822B);
+		val16 |= BIT_CTRLFLT10EN_8822B;
+		rtw_write16(adapter, REG_RXFLTMAP1_8822B, val16);
+
+		/* Beacon Control related register for first time */
+		rtw_write8(adapter, REG_BCNDMATIM_8822B, 0x02); /* 2ms */
+
+		rtw_write8(adapter, REG_ATIMWND_8822B, 0x0c); /* 12ms */
+
+		rtw_write16(adapter, REG_BCNTCFG_8822B, 0x00);
+
+		rtw_write16(adapter, REG_TSFTR_SYN_OFFSET_8822B, 0x7fff); /* +32767 (~32ms) */
+
+		/* reset TSF */
+		rtw_write8(adapter, REG_DUAL_TSF_RST_8822B, BIT_TSFTR_RST_8822B);
+
+		/* SW_BCN_SEL - Port0 */
+		rtw_hal_set_hwreg(adapter, HW_VAR_DL_BCN_SEL, NULL);
+
+		/* select BCN on port 0 */
+		val8 = rtw_read8(adapter, REG_CCK_CHECK_8822B);
+		val8 &= ~BIT_BCN_PORT_SEL_8822B;
+		rtw_write8(adapter, REG_CCK_CHECK_8822B, val8);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		{	
+			/* Sync TSF from AP of STA interface to avoid tx bcn fail */
+			_adapter *iface;
+			struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+			u8 i = 0;
+			u8 connect = _FALSE;
+			
+			for (i = 0; i < dvobj->iface_nums; i++) {
+				iface = dvobj->padapters[i];
+				if (!iface)
+					continue;
+				if (iface == adapter)
+					continue;
+				if (check_fwstate(&iface->mlmepriv, (WIFI_STATION_STATE | WIFI_ASOC_STATE))) {
+					hw_port0_tsf_sync_sel(adapter, iface->hw_port, _TRUE, 50);/*the offset = 50ms.*/
+					break;
+				}
+			}
+		}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+		break;
+	}
+}
+
+static void set_opmode_port1(PADAPTER adapter, u8 mode)
+{
+#ifdef CONFIG_CONCURRENT_MODE
+	u8 is_tx_bcn;
+	u8 val8;
+
+	is_tx_bcn = rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter);
+
+	/* disable Port1 TSF update */
+	val8 = rtw_read8(adapter, REG_BCN_CTRL_CLINT0_8822B);
+	val8 |= BIT_CLI0_DIS_TSF_UDT_8822B;
+	rtw_write8(adapter, REG_BCN_CTRL_CLINT0_8822B, val8);
+
+	Set_MSR(adapter, mode);
+
+	RTW_INFO(FUNC_ADPT_FMT ": hw_port(%d) mode=%d\n",
+		 FUNC_ADPT_ARG(adapter), adapter->hw_port, mode);
+
+	switch (mode) {
+	case _HW_STATE_NOLINK_:
+	case _HW_STATE_STATION_:
+		if (!is_tx_bcn) {
+			StopTxBeacon(adapter);
+#ifdef CONFIG_PCI_HCI
+			UpdateInterruptMask8822BE(adapter, 0, 0, RT_BCN_INT_MASKS, 0);
+#endif /* CONFIG_PCI_HCI */
+		}
+
+		/* disable beacon function */
+		val8 = BIT_CLI0_DIS_TSF_UDT_8822B | BIT_CLI0_EN_BCN_FUNCTION_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_CLINT0_8822B, val8);
+		break;
+
+	case _HW_STATE_ADHOC_:
+		ResumeTxBeacon(adapter);
+		val8 = BIT_CLI0_DIS_TSF_UDT_8822B | BIT_CLI0_EN_BCN_FUNCTION_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_CLINT0_8822B, val8);
+		break;
+
+	case _HW_STATE_AP_:
+#ifdef CONFIG_PCI_HCI
+		UpdateInterruptMask8822BE(adapter, RT_BCN_INT_MASKS, 0, 0, 0);
+#endif /* CONFIG_PCI_HCI */
+
+		/* ToDo */
+		break;
+	}
+#endif /* CONFIG_CONCURRENT_MODE */
+}
+
+static void hw_var_set_opmode(PADAPTER adapter, u8 mode)
+{
+	u8 val8;
+	static u8 isMonitor = _FALSE;
+
+
+	if (isMonitor == _TRUE) {
+		/* reset RCR from backup */
+		rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&GET_HAL_DATA(adapter)->rcr_backup);
+		rtw_hal_rcr_set_chk_bssid(adapter, MLME_ACTION_NONE);
+		isMonitor = _FALSE;
+	}
+
+	if (mode == _HW_STATE_MONITOR_) {
+		isMonitor = _TRUE;
+
+		Set_MSR(adapter, _HW_STATE_NOLINK_);
+		set_opmode_monitor(adapter);
+		return;
+	}
+
+	/* clear crc bit */
+	if (rtw_hal_rcr_check(adapter, BIT_ACRC32_8822B))
+		rtw_hal_rcr_clear(adapter, BIT_ACRC32_8822B);
+
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+		set_opmode_port0(adapter, mode);
+		break;
+
+	case HW_PORT1:
+		set_opmode_port1(adapter, mode);
+		break;
+
+	default:
+		break;
+	}
+}
+
+static void hw_var_set_basic_rate(PADAPTER adapter, u8 *ratetbl)
+{
+#define RATE_1M		BIT(0)
+#define RATE_2M		BIT(1)
+#define RATE_5_5M	BIT(2)
+#define RATE_11M	BIT(3)
+#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)
+#define RATE_MCS0	BIT(12)
+#define RATE_MCS1	BIT(13)
+#define RATE_MCS2	BIT(14)
+#define RATE_MCS3	BIT(15)
+#define RATE_MCS4	BIT(16)
+#define RATE_MCS5	BIT(17)
+#define RATE_MCS6	BIT(18)
+#define RATE_MCS7	BIT(19)
+
+#define RATES_CCK	(RATE_11M | RATE_5_5M | RATE_2M | RATE_1M)
+#define RATES_OFDM	(RATE_54M | RATE_48M | RATE_36M | RATE_24M | RATE_18M | RATE_12M | RATE_9M | RATE_6M)
+
+	struct mlme_ext_info *mlmext_info = &adapter->mlmeextpriv.mlmext_info;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	u16 input_b = 0, masked = 0, ioted = 0, BrateCfg = 0;
+	u16 rrsr_2g_force_mask = RATES_CCK;
+	u16 rrsr_2g_allow_mask = RATE_24M | RATE_12M | RATE_6M | RATES_CCK;
+	u16 rrsr_5g_force_mask = RATE_6M;
+	u16 rrsr_5g_allow_mask = RATES_OFDM;
+	u32 val32;
+
+	HalSetBrateCfg(adapter, ratetbl, &BrateCfg);
+	input_b = BrateCfg;
+
+	/* apply force and allow mask */
+	if (hal->current_band_type == BAND_ON_2_4G) {
+		BrateCfg |= rrsr_2g_force_mask;
+		BrateCfg &= rrsr_2g_allow_mask;
+	} else {
+		BrateCfg |= rrsr_5g_force_mask;
+		BrateCfg &= rrsr_5g_allow_mask;
+	}
+
+	masked = BrateCfg;
+
+	/* IOT consideration */
+	if (mlmext_info->assoc_AP_vendor == HT_IOT_PEER_CISCO) {
+		/* if peer is cisco and didn't use ofdm rate, we enable 6M ack */
+		if ((BrateCfg & (RATE_24M | RATE_12M | RATE_6M)) == 0)
+			BrateCfg |= RATE_6M;
+	}
+
+	ioted = BrateCfg;
+
+	hal->BasicRateSet = BrateCfg;
+
+	RTW_INFO("[HW_VAR_BASIC_RATE] %#x->%#x->%#x\n", input_b, masked, ioted);
+
+	/* Set RRSR rate table. */
+	val32 = rtw_read32(adapter, REG_RRSR_8822B);
+	val32 &= ~(BIT_MASK_RRSC_BITMAP << BIT_SHIFT_RRSC_BITMAP);
+	val32 |= BIT_RRSC_BITMAP(BrateCfg);
+	val32 = rtw_write32(adapter, REG_RRSR_8822B, val32);
+}
+
+static void hw_var_hw_port_cfg(_adapter *adapter, u8 enable)
+{
+	if (enable)
+		hw_bcn_ctrl_set(adapter, (BIT_P0_EN_RXBCN_RPT | BIT_DIS_TSF_UDT | BIT_EN_BCN_FUNCTION));
+	else
+		hw_bcn_ctrl_clr(adapter, BIT_EN_BCN_FUNCTION_8822B);
+}
+
+static void hw_var_set_bcn_func(PADAPTER adapter, u8 enable)
+{
+	u8 val8 = 0;
+
+	if (enable) {
+		/* enable TX BCN report
+		 *  Reg REG_FWHW_TXQ_CTRL_8822B[2] = 1
+		 *  Reg REG_BCN_CTRL_8822B[3][5] = 1
+		 */
+		val8 = rtw_read8(adapter, REG_FWHW_TXQ_CTRL_8822B);
+		val8 |= BIT_EN_BCN_TRXRPT_V1_8822B;
+		rtw_write8(adapter, REG_FWHW_TXQ_CTRL_8822B, val8);
+
+		
+		switch (adapter->hw_port) {
+		case HW_PORT0:
+			val8 =  BIT_EN_BCN_FUNCTION_8822B | BIT_P0_EN_TXBCN_RPT_8822B;
+			hw_bcn_ctrl_clr(adapter, BIT_P0_EN_RXBCN_RPT_8822B);
+			break;
+#ifdef CONFIG_CONCURRENT_MODE
+		case HW_PORT1:
+			val8 =  BIT_CLI0_EN_BCN_FUNCTION_8822B;
+			hw_bcn_ctrl_clr(adapter, BIT_CLI0_EN_RXBCN_RPT_8822B);
+			break;
+		case HW_PORT2:
+			val8 =  BIT_CLI1_EN_BCN_FUNCTION_8822B;
+			hw_bcn_ctrl_clr(adapter, BIT_CLI1_EN_RXBCN_RPT_8822B);
+			break;
+		case HW_PORT3:
+			val8 =  BIT_CLI2_EN_BCN_FUNCTION_8822B;
+			hw_bcn_ctrl_clr(adapter, BIT_CLI2_EN_RXBCN_RPT_8822B);
+			break;
+		case HW_PORT4:
+			val8 =  BIT_CLI3_EN_BCN_FUNCTION_8822B;
+			hw_bcn_ctrl_clr(adapter, BIT_CLI3_EN_RXBCN_RPT_8822B);
+			break;
+#endif /* CONFIG_CONCURRENT_MODE */
+		default:
+			RTW_ERR(FUNC_ADPT_FMT" Unknow hw port(%d) \n", FUNC_ADPT_ARG(adapter), adapter->hw_port);
+			rtw_warn_on(1);
+			break;
+
+		}
+		hw_bcn_ctrl_add(adapter, val8);
+	} else {
+
+		switch (adapter->hw_port) {
+		case HW_PORT0:
+			val8 =  BIT_EN_BCN_FUNCTION_8822B | BIT_P0_EN_TXBCN_RPT_8822B;
+#ifdef CONFIG_BT_COEXIST
+			/* Always enable port0 beacon function for PSTDMA */
+			if (GET_HAL_DATA(adapter)->EEPROMBluetoothCoexist)
+				val8 = BIT_P0_EN_TXBCN_RPT_8822B;
+#endif /* CONFIG_BT_COEXIST */
+			break;
+#ifdef CONFIG_CONCURRENT_MODE
+		case HW_PORT1:
+			val8 =  BIT_CLI0_EN_BCN_FUNCTION_8822B;
+			break;
+		case HW_PORT2:
+			val8 =  BIT_CLI1_EN_BCN_FUNCTION_8822B;
+			break;
+		case HW_PORT3:
+			val8 =  BIT_CLI2_EN_BCN_FUNCTION_8822B;
+			break;
+		case HW_PORT4:
+			val8 =  BIT_CLI3_EN_BCN_FUNCTION_8822B;
+			break;
+#endif /* CONFIG_CONCURRENT_MODE */
+		default:
+			RTW_ERR(FUNC_ADPT_FMT" Unknow hw port(%d) \n", FUNC_ADPT_ARG(adapter), adapter->hw_port);
+			rtw_warn_on(1);
+			break;
+		}
+
+		hw_bcn_ctrl_clr(adapter, val8);
+	}
+}
+
+static void hw_var_set_correct_tsf(PADAPTER adapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	/* do nothing */
+#else /* !CONFIG_MI_WITH_MBSSID_CAM */
+	u64 tsf;
+	struct mlme_ext_priv *pmlmeext;
+	struct mlme_ext_info *pmlmeinfo;
+
+
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+
+	tsf = pmlmeext->TSFValue - rtw_modular64(pmlmeext->TSFValue, (pmlmeinfo->bcn_interval * 1024)) - 1024; /* us */
+
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)
+	    || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		StopTxBeacon(adapter);
+
+	rtw_hal_correct_tsf(adapter, adapter->hw_port, tsf);
+
+#ifdef CONFIG_CONCURRENT_MODE
+	/* Update buddy port's TSF if it is SoftAP for beacon TX issue!*/
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE)
+		&& (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
+	) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+		u32 i;
+		PADAPTER iface;
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface)
+				continue;
+			if (iface == adapter)
+				continue;
+
+			if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
+				&& check_fwstate(&iface->mlmepriv, WIFI_ASOC_STATE) == _TRUE)
+				hw_port0_tsf_sync_sel(iface, adapter->hw_port, _TRUE, 50);/* the offset = 50ms.*/
+		}
+	} else if (((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE)
+										&& (adapter->hw_port == HW_PORT0))
+	#endif /*CONFIG_CONCURRENT_MODE*/
+			/* disable func of port0 TSF sync from another port*/
+			hw_port0_tsf_sync_sel(adapter, adapter->hw_port, _FALSE, 0);
+
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)
+	    || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		ResumeTxBeacon(adapter);
+#endif /* !CONFIG_MI_WITH_MBSSID_CAM */
+}
+
+static void hw_var_set_mlme_disconnect(PADAPTER adapter)
+{
+	u8 val8;
+	struct mi_state mstate;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_check_status(adapter, MI_LINKED) == _FALSE)
+#endif
+		/* reject all data frames under not link state */
+		rtw_write16(adapter, REG_RXFLTMAP2_8822B, 0);
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (adapter->hw_port == HW_PORT1) {
+		/* reset TSF1(CLINT0) */
+		rtw_write8(adapter, REG_DUAL_TSF_RST_8822B, BIT_TSFTR_CLI0_RST_8822B);
+
+		/* disable update TSF1(CLINT0) */
+		val8 = rtw_read8(adapter, REG_BCN_CTRL_CLINT0_8822B);
+		val8 |= BIT_CLI0_DIS_TSF_UDT_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_CLINT0_8822B, val8);
+
+		/* disable Port1's beacon function */
+		val8 = rtw_read8(adapter, REG_BCN_CTRL_CLINT0_8822B);
+		val8 &= ~BIT_CLI0_EN_BCN_FUNCTION_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_CLINT0_8822B, val8);
+	} else
+#endif
+	{
+		/* reset TSF */
+		rtw_write8(adapter, REG_DUAL_TSF_RST_8822B, BIT_TSFTR_RST_8822B);
+
+		/* disable update TSF */
+		val8 = rtw_read8(adapter, REG_BCN_CTRL_8822B);
+		val8 |= BIT_DIS_TSF_UDT_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+	}
+
+	rtw_mi_status_no_self(adapter, &mstate);
+
+	/* clear update TSF only BSSID match for no linked station */
+	if (MSTATE_STA_LD_NUM(&mstate) == 0 && MSTATE_STA_LG_NUM(&mstate) == 0)
+		rtl8822b_rx_tsf_addr_filter_config(adapter, 0);
+}
+
+static void hw_var_set_mlme_sitesurvey(PADAPTER adapter, u8 enable)
+{
+	struct dvobj_priv *dvobj;
+	PHAL_DATA_TYPE hal;
+	struct mlme_priv *pmlmepriv;
+	PADAPTER iface;
+	u32 reg_bcn_ctl;
+	u16 value_rxfltmap2;
+	u8 val8, i;
+
+
+	dvobj = adapter_to_dvobj(adapter);
+	hal = GET_HAL_DATA(adapter);
+	pmlmepriv = &adapter->mlmepriv;
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	/* Receive all data frames */
+	value_rxfltmap2 = 0xFFFF;
+#else
+	/* not to receive data frame */
+	value_rxfltmap2 = 0;
+#endif
+
+	if (enable) {
+		/*
+		 * 1. configure REG_RXFLTMAP2
+		 * 2. config RCR to receive different BSSID BCN or probe rsp
+		 */
+
+		rtw_write16(adapter, REG_RXFLTMAP2_8822B, value_rxfltmap2);
+
+		rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_ENTER);
+
+		/* Save orignal RRSR setting. */
+		hal->RegRRSR = rtw_read16(adapter, REG_RRSR_8822B);
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
+			StopTxBeacon(adapter);
+	} else {
+		/* sitesurvey done
+		 * 1. enable rx data frame
+		 * 2. config RCR not to receive different BSSID BCN or probe rsp
+		 */
+
+		if (rtw_mi_check_fwstate(adapter, _FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE))
+			/* enable to rx data frame */
+			rtw_write16(adapter, REG_RXFLTMAP2_8822B, 0xFFFF);
+
+		rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_DONE);
+
+		/* Restore orignal RRSR setting. */
+		rtw_write16(adapter, REG_RRSR_8822B, hal->RegRRSR);
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
+			ResumeTxBeacon(adapter);
+			rtw_mi_tx_beacon_hdl(adapter);
+		}
+	}
+}
+
+static void hw_var_set_mlme_join(PADAPTER adapter, u8 type)
+{
+	u8 val8;
+	u16 val16;
+	u32 val32;
+	u8 RetryLimit;
+	PHAL_DATA_TYPE hal;
+	struct mlme_priv *pmlmepriv;
+
+	RetryLimit = RL_VAL_STA;
+	hal = GET_HAL_DATA(adapter);
+	pmlmepriv = &adapter->mlmepriv;
+
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (type == 0) {
+		/* prepare to join */
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
+			StopTxBeacon(adapter);
+
+		/* enable to rx data frame.Accept all data frame */
+		rtw_write16(adapter, REG_RXFLTMAP2_8822B, 0xFFFF);
+
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+			RetryLimit = (hal->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
+		else /* Ad-hoc Mode */
+			RetryLimit = RL_VAL_AP;
+
+		/*
+		 * for 8822B, must enable BCN function if BIT_CBSSID_BCN_8822B(bit 7) of REG_RCR(0x608) is enable to recv BSSID bcn
+		 */
+		hw_var_set_bcn_func(adapter, _TRUE);
+
+		/* update TSF only BSSID match for station mode */
+		rtl8822b_rx_tsf_addr_filter_config(adapter, BIT_CHK_TSF_EN_8822B | BIT_CHK_TSF_CBSSID_8822B);
+	} else if (type == 1) {
+		/* joinbss_event call back when join res < 0 */
+		if (rtw_mi_check_status(adapter, MI_LINKED) == _FALSE)
+			rtw_write16(adapter, REG_RXFLTMAP2_8822B, 0x00);
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
+			ResumeTxBeacon(adapter);
+
+			/* reset TSF 1/2 after resume_tx_beacon */
+			val8 = BIT_TSFTR_RST_8822B | BIT_TSFTR_CLI0_RST_8822B;
+			rtw_write8(adapter, REG_DUAL_TSF_RST_8822B, val8);
+		}
+	} else if (type == 2) {
+		/* sta add event callback */
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+#else /* !CONFIG_MI_WITH_MBSSID_CAM */
+		/* enable update TSF */
+		if (adapter->hw_port == HW_PORT1) {
+			val8 = rtw_read8(adapter, REG_BCN_CTRL_CLINT0_8822B);
+			val8 &= ~BIT_DIS_TSF_UDT_8822B;
+			rtw_write8(adapter, REG_BCN_CTRL_CLINT0_8822B, val8);
+		} else {
+			val8 = rtw_read8(adapter, REG_BCN_CTRL_8822B);
+			val8 &= ~BIT_DIS_TSF_UDT_8822B;
+			rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+		}
+#endif /* !CONFIG_MI_WITH_MBSSID_CAM */
+
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
+			rtw_write8(adapter, 0x542, 0x02);
+			RetryLimit = RL_VAL_AP;
+		}
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
+			ResumeTxBeacon(adapter);
+
+			/* reset TSF 1/2 after resume_tx_beacon */
+			rtw_write8(adapter, REG_DUAL_TSF_RST_8822B, BIT_TSFTR_RST_8822B | BIT_TSFTR_CLI0_RST_8822B);
+		}
+	}
+
+	val16 = BIT_LRL_8822B(RetryLimit) | BIT_SRL_8822B(RetryLimit);
+	rtw_write16(adapter, REG_RETRY_LIMIT_8822B, val16);
+#else /* !CONFIG_CONCURRENT_MODE */
+	if (type == 0) {
+		/* prepare to join */
+
+		/* enable to rx data frame. Accept all data frame */
+		rtw_write16(adapter, REG_RXFLTMAP2_8822B, 0xFFFF);
+
+		/*
+		 * for 8822B, must enable BCN function if BIT_CBSSID_BCN_8822B(bit 7) of REG_RCR(0x608) is enabled to recv BSSID bcn
+		 */
+		hw_var_set_bcn_func(adapter, _TRUE);
+
+		/* update TSF only BSSID match for station mode */
+		rtl8822b_rx_tsf_addr_filter_config(adapter, BIT_CHK_TSF_EN_8822B | BIT_CHK_TSF_CBSSID_8822B);
+
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+			RetryLimit = (hal->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
+		else /* Ad-hoc Mode */
+			RetryLimit = RL_VAL_AP;
+	} else if (type == 1) {
+		/* joinbss_event call back when join res < 0 */
+		rtw_write16(adapter, REG_RXFLTMAP2_8822B, 0x00);
+	} else if (type == 2) {
+		/* sta add event callback */
+
+		/* enable update TSF */
+		val8 = rtw_read8(adapter, REG_BCN_CTRL_8822B);
+		val8 &= ~BIT_DIS_TSF_UDT_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE))
+			RetryLimit = RL_VAL_AP;
+	}
+
+	val16 = BIT_LRL_8822B(RetryLimit) | BIT_SRL_8822B(RetryLimit);
+	rtw_write16(adapter, REG_RETRY_LIMIT_8822B, val16);
+#endif /* !CONFIG_CONCURRENT_MODE */
+}
+
+static void hw_var_set_acm_ctrl(PADAPTER adapter, u8 ctrl)
+{
+	u8 hwctrl = 0;
+
+	if (ctrl) {
+		hwctrl |= BIT_ACMHWEN_8822B;
+
+		if (ctrl & BIT(1)) /* BE */
+			hwctrl |= BIT_BEQ_ACM_EN_8822B;
+		else
+			hwctrl &= (~BIT_BEQ_ACM_EN_8822B);
+
+		if (ctrl & BIT(2)) /* VI */
+			hwctrl |= BIT_VIQ_ACM_EN_8822B;
+		else
+			hwctrl &= (~BIT_VIQ_ACM_EN_8822B);
+
+		if (ctrl & BIT(3)) /* VO */
+			hwctrl |= BIT_VOQ_ACM_EN_8822B;
+		else
+			hwctrl &= (~BIT_VOQ_ACM_EN_8822B);
+	}
+
+	RTW_INFO("[HW_VAR_ACM_CTRL] Write 0x%02X\n", hwctrl);
+	rtw_write8(adapter, REG_ACMHWCTRL_8822B, hwctrl);
+}
+
+static void hw_var_set_sec_dk_cfg(PADAPTER adapter, u8 enable)
+{
+	struct security_priv *sec = &adapter->securitypriv;
+	u8 reg_scr = rtw_read8(adapter, REG_SECCFG_8822B);
+
+	if (enable) {
+		/* Enable default key related setting */
+		reg_scr |= BIT_TXBCUSEDK_8822B;
+		if (sec->dot11AuthAlgrthm != dot11AuthAlgrthm_8021X)
+			reg_scr |= BIT_RXUHUSEDK_8822B | BIT_TXUHUSEDK_8822B;
+	} else {
+		/* Disable default key related setting */
+		reg_scr &= ~(BIT_RXBCUSEDK_8822B | BIT_TXBCUSEDK_8822B | BIT_RXUHUSEDK_8822B | BIT_TXUHUSEDK_8822B);
+	}
+
+	rtw_write8(adapter, REG_SECCFG_8822B, reg_scr);
+
+	RTW_INFO("%s: [HW_VAR_SEC_DK_CFG] 0x%x=0x%08x\n", __FUNCTION__,
+		 REG_SECCFG_8822B, rtw_read32(adapter, REG_SECCFG_8822B));
+}
+
+static void hw_var_set_bcn_valid(PADAPTER adapter)
+{
+	u8 val8 = 0;
+
+	/* only port 0 can TX BCN */
+	val8 = rtw_read8(adapter, REG_FIFOPAGE_CTRL_2_8822B + 1);
+	val8 = val8 | BIT(7);
+	rtw_write8(adapter, REG_FIFOPAGE_CTRL_2_8822B + 1, val8);
+}
+
+static void hw_var_set_cam_empty_entry(PADAPTER adapter, 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);
+		else
+			ulContent = 0;
+
+		/* polling bit, and No Write enable, and address */
+		ulCommand = CAM_CONTENT_COUNT * ucIndex + i;
+		ulCommand |= BIT_SECCAM_POLLING_8822B | BIT_SECCAM_WE_8822B;
+		/* write content 0 is equall to mark invalid */
+		rtw_write32(adapter, REG_CAMWRITE_8822B, ulContent);
+		rtw_write32(adapter, REG_CAMCMD_8822B, ulCommand);
+	}
+}
+
+static void hw_var_set_ack_preamble(PADAPTER adapter, u8 bShortPreamble)
+{
+	u8 val8 = 0;
+
+
+	val8 = rtw_read8(adapter, REG_WMAC_TRXPTCL_CTL_8822B + 2);
+	val8 |= BIT(4) | BIT(5);
+
+	if (bShortPreamble)
+		val8 |= BIT1;
+	else
+		val8 &= (~BIT1);
+
+	rtw_write8(adapter, REG_WMAC_TRXPTCL_CTL_8822B + 2, val8);
+}
+
+void hw_var_set_dl_rsvd_page(PADAPTER adapter, u8 mstatus)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	u8 bcn_valid = _FALSE;
+	u8 DLBcnCount = 0;
+	u32 poll = 0;
+	u8 val8;
+	u8 restore[2];
+
+
+	RTW_INFO(FUNC_ADPT_FMT ":+ hw_port=%d mstatus(%x)\n",
+		 FUNC_ADPT_ARG(adapter), get_hw_port(adapter), mstatus);
+
+	if (mstatus == RT_MEDIA_CONNECT) {
+#if 0
+		u8 bRecover = _FALSE;
+#endif
+		u8 v8;
+
+		/* We should set AID, correct TSF, HW seq enable before set JoinBssReport to Fw in 8822B. */
+		rtw_write16(adapter, port_cfg[get_hw_port(adapter)].ps_aid, (0xF800 | pmlmeinfo->aid));
+
+		/* Enable SW TX beacon */
+		v8 = rtw_read8(adapter, REG_CR_8822B + 1);
+		restore[0] = v8;
+		v8 |= (BIT_ENSWBCN_8822B >> 8);
+		rtw_write8(adapter, REG_CR_8822B + 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.
+		 */
+		val8 = rtw_read8(adapter, REG_BCN_CTRL_8822B);
+		restore[1] = val8;
+		val8 &= ~BIT_EN_BCN_FUNCTION_8822B;
+		val8 |= BIT_DIS_TSF_UDT_8822B;
+		rtw_write8(adapter, REG_BCN_CTRL_8822B, val8);
+
+#if 0
+		/* Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame. */
+		RegFwHwTxQCtrl = rtw_read8(adapter, REG_FWHW_TXQ_CTRL_8822B + 2);
+
+		if (RegFwHwTxQCtrl & BIT(6))
+			bRecover = _TRUE;
+
+		/* To tell Hw the packet is not a real beacon frame. */
+		RegFwHwTxQCtrl &= ~BIT(6);
+		rtw_write8(adapter, REG_FWHW_TXQ_CTRL_8822B + 2, RegFwHwTxQCtrl);
+#endif
+
+		/* Clear beacon valid check bit. */
+		rtw_hal_set_hwreg(adapter, HW_VAR_BCN_VALID, NULL);
+		rtw_hal_set_hwreg(adapter, HW_VAR_DL_BCN_SEL, NULL);
+
+		DLBcnCount = 0;
+		poll = 0;
+		do {
+			/* download rsvd page. */
+			rtw_hal_set_fw_rsvd_page(adapter, 0);
+			DLBcnCount++;
+			do {
+				rtw_yield_os();
+
+				/* check rsvd page download OK. */
+				rtw_hal_get_hwreg(adapter, HW_VAR_BCN_VALID, (u8 *)&bcn_valid);
+				poll++;
+			} while (!bcn_valid && (poll % 10) != 0 && !RTW_CANNOT_RUN(adapter));
+
+		} while (!bcn_valid && DLBcnCount <= 100 && !RTW_CANNOT_RUN(adapter));
+
+		if (RTW_CANNOT_RUN(adapter))
+			;
+		else if (!bcn_valid)
+			RTW_INFO(FUNC_ADPT_FMT ": DL RSVD page failed! DLBcnCount:%u, poll:%u\n",
+				 FUNC_ADPT_ARG(adapter), DLBcnCount, poll);
+		else {
+			struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+
+			pwrctl->fw_psmode_iface_id = adapter->iface_id;
+			RTW_INFO(ADPT_FMT ": DL RSVD page success! DLBcnCount:%u, poll:%u\n",
+				 ADPT_ARG(adapter), DLBcnCount, poll);
+		}
+
+		rtw_write8(adapter, REG_BCN_CTRL, restore[1]);
+		rtw_write8(adapter,  REG_CR + 1, restore[0]);
+#if 0
+		/*
+		 * 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.
+		 */
+		if (bRecover) {
+			RegFwHwTxQCtrl |= BIT(6);
+			rtw_write8(adapter, REG_FWHW_TXQ_CTRL_8822B + 2, RegFwHwTxQCtrl);
+		}
+#endif
+#ifndef CONFIG_PCI_HCI
+		/* Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
+		v8 = rtw_read8(adapter, REG_CR_8822B + 1);
+		v8 &= ~BIT(0); /* ~ENSWBCN */
+		rtw_write8(adapter, REG_CR_8822B + 1, v8);
+#endif /* !CONFIG_PCI_HCI */
+	}
+}
+
+static void hw_var_set_h2c_fw_joinbssrpt(PADAPTER adapter, u8 mstatus)
+{
+	if (mstatus == RT_MEDIA_CONNECT)
+		hw_var_set_dl_rsvd_page(adapter, RT_MEDIA_CONNECT);
+}
+
+/*
+ * Parameters:
+ *	adapter
+ *	enable		_TRUE: enable; _FALSE: disable
+ */
+static u8 rx_agg_switch(PADAPTER adapter, u8 enable)
+{
+	int err;
+
+	err = rtw_halmac_rx_agg_switch(adapter_to_dvobj(adapter), enable);
+	if (err)
+		return _FAIL;
+
+	return _SUCCESS;
+}
+
+
+#ifdef CONFIG_AP_PORT_SWAP
+/*
+ * Parameters:
+ *	if_ap		ap interface
+ *	if_port0		port0 interface
+ */
+
+static void hw_port_reconfig(_adapter * if_ap, _adapter *if_port0)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(if_port0);
+	struct mlme_ext_priv *pmlmeext = &if_port0->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	u32 bssid_offset = 0;
+	u8 bssid[6] = {0};
+	u8 vnet_type = 0;
+	u8 vbcn_ctrl = 0;
+	u8 i;
+	u8 port = if_ap->hw_port;
+
+	if (port > (hal_spec->port_num - 1)) {
+		RTW_INFO("[WARN] "ADPT_FMT"- hw_port : %d,will switch to invalid port-%d\n",
+			 ADPT_ARG(if_port0), if_port0->hw_port, port);
+		rtw_warn_on(1);
+	}
+
+	RTW_PRINT(ADPT_FMT" - hw_port : %d,will switch to port-%d\n",
+		  ADPT_ARG(if_port0), if_port0->hw_port, port);
+
+	/*backup*/
+	GetHwReg(if_port0, HW_VAR_MEDIA_STATUS, &vnet_type);
+	vbcn_ctrl = rtw_read8(if_port0, port_cfg[if_port0->hw_port].bcn_ctl);
+
+	if (is_client_associated_to_ap(if_port0)) {
+		RTW_INFO("port0-iface("ADPT_FMT") is STA mode and linked\n", ADPT_ARG(if_port0));
+		bssid_offset = port_cfg[if_port0->hw_port].bssid;
+		for (i = 0; i < 6; i++)
+			bssid[i] = rtw_read8(if_port0, bssid_offset + i);
+	}
+
+	/*reconfigure*/
+	if_port0->hw_port = port;
+	/* adapter mac addr switch to port mac addr */
+	rtw_hal_set_hwreg(if_port0, HW_VAR_MAC_ADDR, adapter_mac_addr(if_port0));
+	Set_MSR(if_port0, vnet_type);
+	rtw_write8(if_port0, port_cfg[if_port0->hw_port].bcn_ctl, vbcn_ctrl);
+
+	if (is_client_associated_to_ap(if_port0))
+		rtw_hal_set_hwreg(if_port0, HW_VAR_BSSID, bssid);
+
+	if_ap->hw_port =HW_PORT0;
+	/* port mac addr switch to adapter mac addr */
+	rtw_hal_set_hwreg(if_ap, HW_VAR_MAC_ADDR, adapter_mac_addr(if_ap));
+}
+
+static void hw_var_ap_port_switch(_adapter *adapter, u8 mode)
+{
+	u8 hw_port = get_hw_port(adapter);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 ap_nums = 0;
+	_adapter *if_port0 = NULL;
+	int i;
+
+	RTW_INFO(ADPT_FMT ": hw_port(%d) will set mode to %d\n", ADPT_ARG(adapter), hw_port, mode);
+#if 0
+	#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
+		RTW_INFO("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__,
+			rtw_p2p_role(&adapter->wdinfo), rtw_p2p_state(&adapter->wdinfo), rtw_p2p_pre_state(&adapter->wdinfo));
+	}
+	#endif
+#endif
+
+	if (mode != _HW_STATE_AP_)
+		return;
+
+	if (hw_port == HW_PORT0)
+		return;
+
+	/*check and prepare switch port to port0 for AP mode's BCN function*/
+	ap_nums = rtw_mi_get_ap_num(adapter);
+	if (ap_nums > 0) {
+		RTW_ERR("SortAP mode numbers:%d, must move setting to MBSSID CAM, not support yet\n", ap_nums);
+		rtw_warn_on(1);
+		return;
+	}
+
+	/*Get iface of port-0*/
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (get_hw_port(dvobj->padapters[i]) == HW_PORT0) {
+			if_port0 = dvobj->padapters[i];
+			break;
+		}
+	}
+
+	if (if_port0 == NULL) {
+		RTW_ERR("%s if_port0 == NULL\n", __func__);
+		rtw_warn_on(1);
+		return;
+	}
+	/* if_port0 switch to hw_port */
+	hw_port_reconfig(adapter, if_port0);
+	RTW_INFO(ADPT_FMT ": Cfg SoftAP mode to hw_port(%d) done\n", ADPT_ARG(adapter), adapter->hw_port);
+
+}
+#endif
+
+u8 rtl8822b_sethwreg(PADAPTER adapter, u8 variable, u8 *val)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	u8 ret = _SUCCESS;
+	u8 val8;
+	u16 val16;
+	u32 val32;
+
+
+	switch (variable) {
+/*
+	case HW_VAR_MEDIA_STATUS:
+		break;
+*/
+	case HW_VAR_SET_OPMODE:
+		hw_var_set_opmode(adapter, *val);
+		break;
+/*
+	case HW_VAR_INIT_RTS_RATE:
+		break;
+*/
+	case HW_VAR_BASIC_RATE:
+		hw_var_set_basic_rate(adapter, val);
+		break;
+
+	case HW_VAR_TXPAUSE:
+		rtw_write8(adapter, REG_TXPAUSE_8822B, *val);
+		break;
+
+	case HW_VAR_BCN_FUNC:
+		hw_var_set_bcn_func(adapter, *val);
+		break;
+
+	case HW_VAR_PORT_CFG:
+		hw_var_hw_port_cfg(adapter, *val);
+		break;
+
+	case HW_VAR_CORRECT_TSF:
+		hw_var_set_correct_tsf(adapter);
+		break;
+
+	case HW_VAR_MLME_DISCONNECT:
+		hw_var_set_mlme_disconnect(adapter);
+		break;
+
+	case HW_VAR_MLME_SITESURVEY:
+		hw_var_set_mlme_sitesurvey(adapter, *val);
+#ifdef CONFIG_BT_COEXIST
+		if (hal->EEPROMBluetoothCoexist)
+			rtw_btcoex_ScanNotify(adapter, *val ? _TRUE : _FALSE);
+		else
+			rtw_btcoex_wifionly_scan_notify(adapter);
+#else /* !CONFIG_BT_COEXIST */
+		rtw_btcoex_wifionly_scan_notify(adapter);
+#endif /* CONFIG_BT_COEXIST */
+		break;
+
+	case HW_VAR_MLME_JOIN:
+		hw_var_set_mlme_join(adapter, *val);
+
+#ifdef CONFIG_BT_COEXIST
+		if (hal->EEPROMBluetoothCoexist) {
+			switch (*val) {
+			case 0:
+				/* Notify coex. mechanism before join */
+				rtw_btcoex_ConnectNotify(adapter, _TRUE);
+				break;
+			case 1:
+			case 2:
+				/* Notify coex. mechanism after join, whether successful or failed */
+				rtw_btcoex_ConnectNotify(adapter, _FALSE);
+				break;
+			}
+		}
+#endif /* CONFIG_BT_COEXIST */
+		break;
+
+	case HW_VAR_RCR:
+		ret = rtl8822b_rcr_config(adapter, *((u32 *)val));
+		break;
+
+	case HW_VAR_BEACON_INTERVAL:
+		{
+			u16 bcn_interval = *((u16 *)val);
+
+			#ifdef CONFIG_SWTIMER_BASED_TXBCN
+			bcn_interval = rtw_hal_bcn_interval_adjust(adapter, bcn_interval);
+			#endif
+
+			SetHwReg(adapter, HW_VAR_BEACON_INTERVAL, (u8 *)&bcn_interval);
+			#ifdef CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
+			{
+				struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+				struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+				if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+					RTW_INFO("%s==> bcn_interval:%d, eraly_int:%d\n", __func__, bcn_interval, bcn_interval >> 1);
+					rtw_write8(adapter, REG_DRVERLYINT, bcn_interval >> 1);
+				}
+			}
+			#endif/* CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT */
+		}
+		break;
+
+	case HW_VAR_SLOT_TIME:
+		rtw_write8(adapter, REG_SLOT_8822B, *val);
+		break;
+
+	case HW_VAR_RESP_SIFS:
+		/* RESP_SIFS for CCK */
+		rtw_write8(adapter, REG_RESP_SIFS_CCK_8822B, val[0]);
+		rtw_write8(adapter, REG_RESP_SIFS_CCK_8822B + 1, val[1]);
+		/* RESP_SIFS for OFDM */
+		rtw_write8(adapter, REG_RESP_SIFS_OFDM_8822B, val[2]);
+		rtw_write8(adapter, REG_RESP_SIFS_OFDM_8822B + 1, val[3]);
+		break;
+
+	case HW_VAR_ACK_PREAMBLE:
+		hw_var_set_ack_preamble(adapter, *val);
+		break;
+
+/*
+	case HW_VAR_SEC_CFG:
+		follow hal_com.c
+		break;
+*/
+
+	case HW_VAR_SEC_DK_CFG:
+		if (val)
+			hw_var_set_sec_dk_cfg(adapter, _TRUE);
+		else
+			hw_var_set_sec_dk_cfg(adapter, _FALSE);
+		break;
+
+	case HW_VAR_BCN_VALID:
+		hw_var_set_bcn_valid(adapter);
+		break;
+/*
+	case HW_VAR_RF_TYPE:
+		break;
+*/
+	case HW_VAR_CAM_EMPTY_ENTRY:
+		hw_var_set_cam_empty_entry(adapter, *val);
+		break;
+
+	case HW_VAR_CAM_INVALID_ALL:
+		val32 = BIT_SECCAM_POLLING_8822B | BIT_SECCAM_CLR_8822B;
+		rtw_write32(adapter, REG_CAMCMD_8822B, val32);
+		break;
+
+	case HW_VAR_AC_PARAM_VO:
+		rtw_write32(adapter, REG_EDCA_VO_PARAM_8822B, *(u32 *)val);
+		break;
+
+	case HW_VAR_AC_PARAM_VI:
+		rtw_write32(adapter, REG_EDCA_VI_PARAM_8822B, *(u32 *)val);
+		break;
+
+	case HW_VAR_AC_PARAM_BE:
+		hal->ac_param_be = *(u32 *)val;
+		rtw_write32(adapter, REG_EDCA_BE_PARAM_8822B, *(u32 *)val);
+		break;
+
+	case HW_VAR_AC_PARAM_BK:
+		rtw_write32(adapter, REG_EDCA_BK_PARAM_8822B, *(u32 *)val);
+		break;
+
+	case HW_VAR_ACM_CTRL:
+		hw_var_set_acm_ctrl(adapter, *val);
+		break;
+/*
+	case HW_VAR_AMPDU_MIN_SPACE:
+		break;
+*/
+	case HW_VAR_AMPDU_FACTOR: {
+		u32 AMPDULen = *val; /* enum AGGRE_SIZE */
+
+		AMPDULen = (0x2000 << AMPDULen) - 1;
+		rtw_write32(adapter, REG_AMPDU_MAX_LENGTH_8822B, AMPDULen);
+	}
+	break;
+
+	case HW_VAR_RXDMA_AGG_PG_TH:
+		/*
+		 * TH=1 => invalidate RX DMA aggregation
+		 * TH=0 => validate RX DMA aggregation, use init value.
+		 */
+		if (*val == 0)
+			/* enable RXDMA aggregation */
+			rx_agg_switch(adapter, _TRUE);
+		else
+			/* disable RXDMA aggregation */
+			rx_agg_switch(adapter, _FALSE);
+		break;
+/*
+	case HW_VAR_SET_RPWM:
+	case HW_VAR_CPWM:
+		break;
+*/
+	case HW_VAR_H2C_FW_PWRMODE:
+		rtl8822b_set_FwPwrMode_cmd(adapter, *val);
+		break;
+/*
+	case HW_VAR_H2C_PS_TUNE_PARAM:
+		break;
+*/
+	case HW_VAR_H2C_FW_JOINBSSRPT:
+		hw_var_set_h2c_fw_joinbssrpt(adapter, *val);
+		break;
+/*
+	case HW_VAR_FWLPS_RF_ON:
+		break;
+*/
+#ifdef CONFIG_P2P_PS
+	case HW_VAR_H2C_FW_P2P_PS_OFFLOAD:
+		rtw_set_p2p_ps_offload_cmd(adapter, *val);
+		break;
+#endif /* CONFIG_P2P_PS */
+/*
+	case HW_VAR_TRIGGER_GPIO_0:
+	case HW_VAR_BT_SET_COEXIST:
+	case HW_VAR_BT_ISSUE_DELBA:
+	case HW_VAR_SWITCH_EPHY_WoWLAN:
+	case HW_VAR_EFUSE_USAGE:
+	case HW_VAR_EFUSE_BYTES:
+	case HW_VAR_EFUSE_BT_USAGE:
+	case HW_VAR_EFUSE_BT_BYTES:
+		break;
+*/
+	case HW_VAR_FIFO_CLEARN_UP: {
+		struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+		u8 trycnt = 100;
+
+		/* pause tx */
+		rtw_write8(adapter, REG_TXPAUSE_8822B, 0xff);
+
+		/* keep sn */
+		adapter->xmitpriv.nqos_ssn = rtw_read16(adapter, REG_HW_SEQ2_8822B);
+
+		if (pwrpriv->bkeepfwalive != _TRUE) {
+			/* RX DMA stop */
+			val32 = rtw_read32(adapter, REG_RXPKT_NUM_8822B);
+			val32 |= BIT_RW_RELEASE_EN;
+			rtw_write32(adapter, REG_RXPKT_NUM_8822B, val32);
+			do {
+				val32 = rtw_read32(adapter, REG_RXPKT_NUM_8822B);
+				val32 &= BIT_RXDMA_IDLE_8822B;
+				if (val32)
+					break;
+
+				RTW_INFO("[HW_VAR_FIFO_CLEARN_UP] val=%x times:%d\n", val32, trycnt);
+			} while (--trycnt);
+			if (trycnt == 0)
+				RTW_INFO("[HW_VAR_FIFO_CLEARN_UP] Stop RX DMA failed!\n");
+#if 0
+			/* RQPN Load 0 */
+			rtw_write16(adapter, REG_RQPN_NPQ, 0);
+			rtw_write32(adapter, REG_RQPN, 0x80000000);
+			rtw_mdelay_os(2);
+#endif
+		}
+	}
+	break;
+
+	case HW_VAR_RESTORE_HW_SEQ:
+		/* restore Sequence No. */
+		rtw_write8(adapter, REG_HW_SEQ2_8822B, adapter->xmitpriv.nqos_ssn);
+		break;
+
+	case HW_VAR_CHECK_TXBUF: {
+		u16 rtylmtorg;
+		u8 RetryLimit = 0x01;
+		systime start;
+		u32 passtime;
+		u32 timelmt = 2000;	/* ms */
+		int err;
+		u8 empty;
+
+
+		rtylmtorg = rtw_read16(adapter, REG_RETRY_LIMIT_8822B);
+
+		val16 = BIT_LRL_8822B(RetryLimit) | BIT_SRL_8822B(RetryLimit);
+		rtw_write16(adapter, REG_RETRY_LIMIT_8822B, val16);
+
+		/* Check TX FIFO empty or not */
+		empty = _FALSE;
+		start = rtw_get_current_time();
+		err = rtw_halmac_txfifo_wait_empty(adapter_to_dvobj(adapter), timelmt);
+		if (!err)
+			empty = _TRUE;
+		passtime = rtw_get_passing_time_ms(start);
+
+		if (_TRUE == empty)
+			RTW_INFO("[HW_VAR_CHECK_TXBUF] Empty in %d ms\n", passtime);
+		else if (RTW_CANNOT_RUN(adapter))
+			RTW_WARN("[HW_VAR_CHECK_TXBUF] bDriverStopped or bSurpriseRemoved\n");
+		else {
+			RTW_ERR("[HW_VAR_CHECK_TXBUF] NOT empty in %d ms\n", passtime);
+
+		}
+		rtw_write16(adapter, REG_RETRY_LIMIT_8822B, rtylmtorg);
+	}
+	break;
+/*
+	case HW_VAR_PCIE_STOP_TX_DMA:
+	case HW_VAR_APFM_ON_MAC
+	case HW_VAR_HCI_SUS_STATE:
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	case HW_VAR_WOWLAN:
+	case HW_VAR_WAKEUP_REASON:
+#endif
+	case HW_VAR_RPWM_TOG:
+		break;
+*/
+#ifdef CONFIG_GPIO_WAKEUP
+	case HW_SET_GPIO_WL_CTRL: {
+		u8 enable = *val;
+		u8 value = 0;
+		u8 addr = REG_PAD_CTRL1_8822B + 3;
+
+		if (WAKEUP_GPIO_IDX == 6) {
+			value = rtw_read8(adapter, addr);
+
+			if (enable == _TRUE && (value & BIT(1)))
+				/* set 0x64[25] = 0 to control GPIO 6 */
+				rtw_write8(adapter, addr, value & (~BIT(1)));
+			else if (enable == _FALSE)
+				rtw_write8(adapter, addr, value | BIT(1));
+
+			RTW_INFO("[HW_SET_GPIO_WL_CTRL] 0x%02X=0x%02X\n",
+				 addr, rtw_read8(adapter, addr));
+		}
+	}
+	break;
+#endif
+/*
+	case HW_VAR_SYS_CLKR:
+		break;
+*/
+	case HW_VAR_NAV_UPPER: {
+#define HAL_NAV_UPPER_UNIT	128	/* micro-second */
+		u32 usNavUpper = *(u32 *)val;
+
+		if (usNavUpper > HAL_NAV_UPPER_UNIT * 0xFF) {
+			RTW_INFO(FUNC_ADPT_FMT ": [HW_VAR_NAV_UPPER] value(0x%08X us) is larger than (%d * 0xFF)!!!\n",
+				FUNC_ADPT_ARG(adapter), usNavUpper, HAL_NAV_UPPER_UNIT);
+			break;
+		}
+
+		usNavUpper = (usNavUpper + HAL_NAV_UPPER_UNIT - 1) / HAL_NAV_UPPER_UNIT;
+		rtw_write8(adapter, REG_NAV_CTRL_8822B + 2, (u8)usNavUpper);
+	}
+	break;
+
+/*
+	case HW_VAR_RPT_TIMER_SETTING:
+	case HW_VAR_TX_RPT_MAX_MACID:
+	case HW_VAR_CHK_HI_QUEUE_EMPTY:
+		break;
+*/
+	case HW_VAR_DL_BCN_SEL:
+#ifdef CONFIG_CONCURRENT_MODE
+		if (adapter->hw_port == HW_PORT1) {
+			/* Port1 */
+			/* ToDo */
+		} else
+#endif /* CONFIG_CONCURRENT_MODE */
+		{
+			/* Port0 */
+			/* ToDo */
+		}
+		break;
+/*
+	case HW_VAR_AMPDU_MAX_TIME:
+	case HW_VAR_WIRELESS_MODE:
+	case HW_VAR_USB_MODE:
+*/
+#ifdef CONFIG_AP_PORT_SWAP
+	case HW_VAR_PORT_SWITCH:
+		{
+			u8 mode = *((u8 *)val);
+
+			hw_var_ap_port_switch(adapter, mode);
+		}
+		break;
+#endif
+	case HW_VAR_DO_IQK:
+		if (*val)
+			hal->bNeedIQK = _TRUE;
+		else
+			hal->bNeedIQK = _FALSE;
+		break;
+
+/*
+	case HW_VAR_SET_REQ_FW_PS:
+	case HW_VAR_FW_PS_STATE:
+		break;
+*/
+#ifdef CONFIG_BEAMFORMING
+	case HW_VAR_SOUNDING_ENTER:
+		rtl8822b_phy_bf_enter(adapter, (struct sta_info*)val);
+		break;
+
+	case HW_VAR_SOUNDING_LEAVE:
+		rtl8822b_phy_bf_leave(adapter, val);
+		break;
+/*
+	case HW_VAR_SOUNDING_RATE:
+		break;
+*/
+	case HW_VAR_SOUNDING_STATUS:
+		rtl8822b_phy_bf_sounding_status(adapter, *val);
+		break;
+/*
+	case HW_VAR_SOUNDING_FW_NDPA:
+	case HW_VAR_SOUNDING_CLK:
+		break;
+*/
+	case HW_VAR_SOUNDING_SET_GID_TABLE:
+		rtl8822b_phy_bf_set_gid_table(adapter, (struct beamformer_entry*)val);
+		break;
+
+	case HW_VAR_SOUNDING_CSI_REPORT:
+		rtl8822b_phy_bf_set_csi_report(adapter, (struct _RT_CSI_INFO*)val);
+		break;
+#endif /* CONFIG_BEAMFORMING */
+/*
+	case HW_VAR_HW_REG_TIMER_INIT:
+	case HW_VAR_HW_REG_TIMER_RESTART:
+	case HW_VAR_HW_REG_TIMER_START:
+	case HW_VAR_HW_REG_TIMER_STOP:
+		break;
+*/
+	case HW_VAR_DL_RSVD_PAGE:
+#ifdef CONFIG_BT_COEXIST
+		if (check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
+			rtl8822b_download_BTCoex_AP_mode_rsvd_page(adapter);
+#endif
+		break;
+/*
+	case HW_VAR_MACID_LINK:
+	case HW_VAR_MACID_NOLINK:
+	case HW_VAR_DUMP_MAC_QUEUE_INFO:
+	case HW_VAR_ASIX_IOT:
+#ifdef CONFIG_MBSSID_CAM
+	case HW_VAR_MBSSID_CAM_WRITE:
+	case HW_VAR_MBSSID_CAM_CLEAR:
+	case HW_VAR_RCR_MBSSID_EN:
+#endif
+	case HW_VAR_EN_HW_UPDATE_TSF:
+	case HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO:
+	case HW_VAR_CH_SW_IQK_INFO_BACKUP:
+	case HW_VAR_CH_SW_IQK_INFO_RESTORE:
+		break;
+*/
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	case HW_VAR_TDLS_BCN_EARLY_C2H_RPT:
+		rtl8822b_set_BcnEarly_C2H_Rpt_cmd(adapter, *val);
+		break;
+#endif
+#endif
+
+	case HW_VAR_FREECNT:
+
+		val8 = (u8)*val;
+
+		if (val8==0) {
+			/* disable free run counter set 0x577[3]=0 */
+			rtw_write8(adapter, REG_MISC_CTRL,
+				rtw_read8(adapter, REG_MISC_CTRL)&(~BIT_EN_FREECNT));
+
+			/* reset FREE_RUN_COUNTER set 0x553[5]=1 */
+			val8 = rtw_read8(adapter, REG_DUAL_TSF_RST);
+			val8 |=  BIT_FREECNT_RST;
+			rtw_write8(adapter, REG_DUAL_TSF_RST, val8);
+
+		} else if (val8==1){
+
+			/* enable free run counter */
+
+			/* disable first set 0x577[3]=0 */
+			rtw_write8(adapter, REG_MISC_CTRL,
+				rtw_read8(adapter, REG_MISC_CTRL)&(~BIT_EN_FREECNT));
+
+			/* reset FREE_RUN_COUNTER set 0x553[5]=1 */
+			val8 = rtw_read8(adapter, REG_DUAL_TSF_RST);
+			val8 |=  BIT_FREECNT_RST;
+			rtw_write8(adapter, REG_DUAL_TSF_RST, val8);
+
+			/* enable free run counter 0x577[3]=1 */
+			rtw_write8(adapter, REG_MISC_CTRL,
+				rtw_read8(adapter, REG_MISC_CTRL)|BIT_EN_FREECNT);
+		}
+		break;
+
+	case HW_VAR_TSF_AUTO_SYNC:
+		if (*val == _TRUE)
+			hw_port0_tsf_sync_sel(adapter, adapter->hw_port, _TRUE, 50);
+		else
+			hw_port0_tsf_sync_sel(adapter, adapter->hw_port, _FALSE, 50);
+		break;
+
+	case HW_VAR_SET_SOML_PARAM:
+#ifdef CONFIG_DYNAMIC_SOML
+		rtw_dyn_soml_para_set(adapter, 4, 20, 1, 0);
+#endif
+		break;
+
+	default:
+		ret = SetHwReg(adapter, variable, val);
+		break;
+	}
+
+	return ret;
+}
+
+struct qinfo {
+	u32 head:11;
+	u32 tail:11;
+	u32 empty:1;
+	u32 ac:2;
+	u32 macid:7;
+};
+
+struct bcn_qinfo {
+	u16 head:12;
+	u16 rsvd:4;
+};
+
+static void dump_qinfo(void *sel, struct qinfo *info, u32 pkt_num, const char *tag)
+{
+	RTW_PRINT_SEL(sel, "%shead:0x%02x, tail:0x%02x, pkt_num:%u, macid:%u, ac:%u\n",
+		tag ? tag : "", info->head, info->tail, pkt_num, info->macid, info->ac);
+}
+
+static void dump_bcn_qinfo(void *sel, struct bcn_qinfo *info, u32 pkt_num, const char *tag)
+{
+	RTW_PRINT_SEL(sel, "%shead:0x%02x, pkt_num:%u\n",
+		      tag ? tag : "", info->head, pkt_num);
+}
+
+static void dump_mac_qinfo(void *sel, _adapter *adapter)
+{
+	u32 q0_info;
+	u32 q1_info;
+	u32 q2_info;
+	u32 q3_info;
+	u32 q4_info;
+	u32 q5_info;
+	u32 q6_info;
+	u32 q7_info;
+	u32 mg_q_info;
+	u32 hi_q_info;
+	u16 bcn_q_info;
+	u32 q0_q1_info;
+	u32 q2_q3_info;
+	u32 q4_q5_info;
+	u32 q6_q7_info;
+	u32 mg_hi_q_info;
+	u32 cmd_bcn_q_info;
+
+	q0_info = rtw_read32(adapter, REG_Q0_INFO_8822B);
+	q1_info = rtw_read32(adapter, REG_Q1_INFO_8822B);
+	q2_info = rtw_read32(adapter, REG_Q2_INFO_8822B);
+	q3_info = rtw_read32(adapter, REG_Q3_INFO_8822B);
+	q4_info = rtw_read32(adapter, REG_Q4_INFO_8822B);
+	q5_info = rtw_read32(adapter, REG_Q5_INFO_8822B);
+	q6_info = rtw_read32(adapter, REG_Q6_INFO_8822B);
+	q7_info = rtw_read32(adapter, REG_Q7_INFO_8822B);
+	mg_q_info = rtw_read32(adapter, REG_MGQ_INFO_8822B);
+	hi_q_info = rtw_read32(adapter, REG_HIQ_INFO_8822B);
+	bcn_q_info = rtw_read16(adapter, REG_BCNQ_INFO_8822B);
+
+	q0_q1_info = rtw_read32(adapter, REG_Q0_Q1_INFO_8822B);
+	q2_q3_info = rtw_read32(adapter, REG_Q2_Q3_INFO_8822B);
+	q4_q5_info = rtw_read32(adapter, REG_Q4_Q5_INFO_8822B);
+	q6_q7_info = rtw_read32(adapter, REG_Q6_Q7_INFO_8822B);
+	mg_hi_q_info = rtw_read32(adapter, REG_MGQ_HIQ_INFO_8822B);
+	cmd_bcn_q_info = rtw_read32(adapter, REG_CMDQ_BCNQ_INFO_8822B);
+
+	dump_qinfo(sel, (struct qinfo *)&q0_info, q0_q1_info&0xFFF, "Q0 ");
+	dump_qinfo(sel, (struct qinfo *)&q1_info, (q0_q1_info>>15)&0xFFF, "Q1 ");
+	dump_qinfo(sel, (struct qinfo *)&q2_info, q2_q3_info&0xFFF, "Q2 ");
+	dump_qinfo(sel, (struct qinfo *)&q3_info, (q2_q3_info>>15)&0xFFF, "Q3 ");
+	dump_qinfo(sel, (struct qinfo *)&q4_info, q4_q5_info&0xFFF, "Q4 ");
+	dump_qinfo(sel, (struct qinfo *)&q5_info, (q4_q5_info>>15)&0xFFF, "Q5 ");
+	dump_qinfo(sel, (struct qinfo *)&q6_info, q6_q7_info&0xFFF, "Q6 ");
+	dump_qinfo(sel, (struct qinfo *)&q7_info, (q6_q7_info>>15)&0xFFF, "Q7 ");
+	dump_qinfo(sel, (struct qinfo *)&mg_q_info, mg_hi_q_info&0xFFF, "MG ");
+	dump_qinfo(sel, (struct qinfo *)&hi_q_info, (mg_hi_q_info>>15)&0xFFF, "HI ");
+	dump_bcn_qinfo(sel, (struct bcn_qinfo *)&bcn_q_info, cmd_bcn_q_info&0xFFF, "BCN ");
+
+}
+
+static void dump_mac_txfifo(void *sel, _adapter *adapter)
+{
+	u32 hpq, lpq, npq, epq, pubq;
+
+	hpq = rtw_read32(adapter, REG_FIFOPAGE_INFO_1_8822B);
+	lpq = rtw_read32(adapter, REG_FIFOPAGE_INFO_2_8822B);
+	npq = rtw_read32(adapter, REG_FIFOPAGE_INFO_3_8822B);
+	epq = rtw_read32(adapter, REG_FIFOPAGE_INFO_4_8822B);
+	pubq = rtw_read32(adapter, REG_FIFOPAGE_INFO_5_8822B);
+
+	hpq = (hpq & 0xFFF0000)>>16;
+	lpq = (lpq & 0xFFF0000)>>16;
+	npq = (npq & 0xFFF0000)>>16;
+	epq = (epq & 0xFFF0000)>>16;
+	pubq = (pubq & 0xFFF0000)>>16;
+
+	RTW_PRINT_SEL(sel, "Tx: available page num: ");
+	if ((hpq == 0xAEA) && (hpq == lpq) && (hpq == pubq))
+		RTW_PRINT_SEL(sel, "N/A (reg val = 0xea)\n");
+	else
+		RTW_PRINT_SEL(sel, "HPQ: %d, LPQ: %d, NPQ: %d, EPQ: %d, PUBQ: %d\n"
+			, hpq, lpq, npq, epq, pubq);
+}
+
+static u8 hw_var_get_bcn_valid(PADAPTER adapter)
+{
+	u8 val8 = 0;
+	u8 ret = _FALSE;
+
+	/* only port 0 can TX BCN */
+	val8 = rtw_read8(adapter, REG_FIFOPAGE_CTRL_2_8822B + 1);
+	ret = (BIT(7) & val8) ? _TRUE : _FALSE;
+
+	return ret;
+}
+
+void rtl8822b_read_wmmedca_reg(PADAPTER adapter, u16 *vo_params, u16 *vi_params, u16 *be_params, u16 *bk_params)
+{
+	u8 vo_reg_params[4];
+	u8 vi_reg_params[4];
+	u8 be_reg_params[4];
+	u8 bk_reg_params[4];
+
+	rtl8822b_gethwreg(adapter, HW_VAR_AC_PARAM_VO, vo_reg_params);
+	rtl8822b_gethwreg(adapter, HW_VAR_AC_PARAM_VI, vi_reg_params);
+	rtl8822b_gethwreg(adapter, HW_VAR_AC_PARAM_BE, be_reg_params);
+	rtl8822b_gethwreg(adapter, HW_VAR_AC_PARAM_BK, bk_reg_params);
+
+	vo_params[0] = vo_reg_params[0];
+	vo_params[1] = vo_reg_params[1] & 0x0F;
+	vo_params[2] = (vo_reg_params[1] & 0xF0) >> 4;
+	vo_params[3] = ((vo_reg_params[3] << 8) | (vo_reg_params[2])) * 32;
+
+	vi_params[0] = vi_reg_params[0];
+	vi_params[1] = vi_reg_params[1] & 0x0F;
+	vi_params[2] = (vi_reg_params[1] & 0xF0) >> 4;
+	vi_params[3] = ((vi_reg_params[3] << 8) | (vi_reg_params[2])) * 32;
+
+	be_params[0] = be_reg_params[0];
+	be_params[1] = be_reg_params[1] & 0x0F;
+	be_params[2] = (be_reg_params[1] & 0xF0) >> 4;
+	be_params[3] = ((be_reg_params[3] << 8) | (be_reg_params[2])) * 32;
+
+	bk_params[0] = bk_reg_params[0];
+	bk_params[1] = bk_reg_params[1] & 0x0F;
+	bk_params[2] = (bk_reg_params[1] & 0xF0) >> 4;
+	bk_params[3] = ((bk_reg_params[3] << 8) | (bk_reg_params[2])) * 32;
+
+	vo_params[1] = (1 << vo_params[1]) - 1;
+	vo_params[2] = (1 << vo_params[2]) - 1;
+	vi_params[1] = (1 << vi_params[1]) - 1;
+	vi_params[2] = (1 << vi_params[2]) - 1;
+	be_params[1] = (1 << be_params[1]) - 1;
+	be_params[2] = (1 << be_params[2]) - 1;
+	bk_params[1] = (1 << bk_params[1]) - 1;
+	bk_params[2] = (1 << bk_params[2]) - 1;
+}
+
+void rtl8822b_gethwreg(PADAPTER adapter, u8 variable, u8 *val)
+{
+	PHAL_DATA_TYPE hal;
+	u8 val8;
+	u16 val16;
+	u32 val32;
+	u64 val64;
+
+
+	hal = GET_HAL_DATA(adapter);
+
+	switch (variable) {
+/*
+	case HW_VAR_MEDIA_STATUS:
+	case HW_VAR_SET_OPMODE:
+	case HW_VAR_INIT_RTS_RATE:
+	case HW_VAR_BASIC_RATE:
+		break;
+*/
+	case HW_VAR_TXPAUSE:
+		*val = rtw_read8(adapter, REG_TXPAUSE_8822B);
+		break;
+/*
+	case HW_VAR_BCN_FUNC:
+	case HW_VAR_CORRECT_TSF:
+	case HW_VAR_MLME_DISCONNECT:
+	case HW_VAR_MLME_SITESURVEY:
+	case HW_VAR_MLME_JOIN:
+	case HW_VAR_BEACON_INTERVAL:
+	case HW_VAR_SLOT_TIME:
+	case HW_VAR_RESP_SIFS:
+	case HW_VAR_ACK_PREAMBLE:
+	case HW_VAR_SEC_CFG:
+	case HW_VAR_SEC_DK_CFG:
+		break;
+*/
+	case HW_VAR_BCN_VALID:
+		*val = hw_var_get_bcn_valid(adapter);
+		break;
+/*
+	case HW_VAR_RF_TYPE:
+	case HW_VAR_FREECNT:
+	case HW_VAR_CAM_EMPTY_ENTRY:
+	case HW_VAR_CAM_INVALID_ALL:
+*/
+	case HW_VAR_AC_PARAM_VO:
+		val32 = rtw_read32(adapter, REG_EDCA_VO_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
+	case HW_VAR_AC_PARAM_VI:
+		val32 = rtw_read32(adapter, REG_EDCA_VI_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
+	case HW_VAR_AC_PARAM_BE:
+		val32 = rtw_read32(adapter, REG_EDCA_BE_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
+	case HW_VAR_AC_PARAM_BK:
+		val32 = rtw_read32(adapter, REG_EDCA_BK_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+/*
+	case HW_VAR_ACM_CTRL:
+	case HW_VAR_AMPDU_MIN_SPACE:
+	case HW_VAR_AMPDU_FACTOR:
+	case HW_VAR_RXDMA_AGG_PG_TH:
+	case HW_VAR_SET_RPWM:
+	case HW_VAR_CPWM:
+	case HW_VAR_H2C_FW_PWRMODE:
+	case HW_VAR_H2C_PS_TUNE_PARAM:
+	case HW_VAR_H2C_FW_JOINBSSRPT:
+		break;
+*/
+	case HW_VAR_FWLPS_RF_ON:
+		/* When we halt NIC, we should check if FW LPS is leave. */
+		if (rtw_is_surprise_removed(adapter) ||
+		    (adapter_to_pwrctl(adapter)->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.
+			 */
+			*val = _TRUE;
+		} else {
+			rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&val32);
+
+			if (adapter_to_pwrctl(adapter)->wowlan_mode == _TRUE)
+				val32 &= (BIT_UC_MD_EN_8822B | BIT_BC_MD_EN_8822B);
+			else
+				val32 &= (BIT_UC_MD_EN_8822B | BIT_BC_MD_EN_8822B | BIT_TIM_PARSER_EN_8822B);
+
+			if (val32)
+				*val = _FALSE;
+			else
+				*val = _TRUE;
+		}
+		break;
+/*
+	case HW_VAR_H2C_FW_P2P_PS_OFFLOAD:
+	case HW_VAR_TRIGGER_GPIO_0:
+	case HW_VAR_BT_SET_COEXIST:
+	case HW_VAR_BT_ISSUE_DELBA:
+	case HW_VAR_SWITCH_EPHY_WoWLAN:
+	case HW_VAR_EFUSE_USAGE:
+	case HW_VAR_EFUSE_BYTES:
+	case HW_VAR_EFUSE_BT_USAGE:
+	case HW_VAR_EFUSE_BT_BYTES:
+	case HW_VAR_FIFO_CLEARN_UP:
+	case HW_VAR_RESTORE_HW_SEQ:
+	case HW_VAR_CHECK_TXBUF:
+	case HW_VAR_PCIE_STOP_TX_DMA:
+		break;
+*/
+
+/*
+	case HW_VAR_HCI_SUS_STATE:
+		break;
+*/
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+/*
+	case HW_VAR_WOWLAN:
+		break;
+
+	case HW_VAR_WAKEUP_REASON:
+		rtw_halmac_get_wow_reason(adapter_to_dvobj(adapter), val);
+		break;
+
+	case HW_VAR_RPWM_TOG:
+		break;
+*/
+#endif
+/*
+#ifdef CONFIG_GPIO_WAKEUP
+	case HW_SET_GPIO_WL_CTRL:
+		break;
+#endif
+*/
+	case HW_VAR_SYS_CLKR:
+		*val = rtw_read8(adapter, REG_SYS_CLK_CTRL_8822B);
+		break;
+/*
+	case HW_VAR_NAV_UPPER:
+	case HW_VAR_RPT_TIMER_SETTING:
+	case HW_VAR_TX_RPT_MAX_MACID:
+		break;
+*/
+	case HW_VAR_CHK_HI_QUEUE_EMPTY:
+		val16 = rtw_read16(adapter, REG_TXPKT_EMPTY_8822B);
+		*val = (val16 & BIT_HQQ_EMPTY_8822B) ? _TRUE : _FALSE;
+		break;
+	case HW_VAR_CHK_MGQ_CPU_EMPTY:
+		val16 = rtw_read16(adapter, REG_TXPKT_EMPTY_8822B);
+		*val = (val16 & BIT_MGQ_CPU_EMPTY_8822B) ? _TRUE : _FALSE;
+		break;
+/*
+	case HW_VAR_DL_BCN_SEL:
+	case HW_VAR_AMPDU_MAX_TIME:
+	case HW_VAR_WIRELESS_MODE:
+	case HW_VAR_USB_MODE:
+	case HW_VAR_PORT_SWITCH:
+	case HW_VAR_DO_IQK:
+	case HW_VAR_SET_REQ_FW_PS:
+	case HW_VAR_FW_PS_STATE:
+	case HW_VAR_SOUNDING_ENTER:
+	case HW_VAR_SOUNDING_LEAVE:
+	case HW_VAR_SOUNDING_RATE:
+	case HW_VAR_SOUNDING_STATUS:
+	case HW_VAR_SOUNDING_FW_NDPA:
+	case HW_VAR_SOUNDING_CLK:
+	case HW_VAR_HW_REG_TIMER_INIT:
+	case HW_VAR_HW_REG_TIMER_RESTART:
+	case HW_VAR_HW_REG_TIMER_START:
+	case HW_VAR_HW_REG_TIMER_STOP:
+	case HW_VAR_DL_RSVD_PAGE:
+	case HW_VAR_MACID_LINK:
+	case HW_VAR_MACID_NOLINK:
+		break;
+*/
+	case HW_VAR_DUMP_MAC_QUEUE_INFO:
+		dump_mac_qinfo(val, adapter);
+		break;
+
+	case HW_VAR_DUMP_MAC_TXFIFO:
+		dump_mac_txfifo(val, adapter);
+		break;
+/*
+	case HW_VAR_ASIX_IOT:
+#ifdef CONFIG_MBSSID_CAM
+	case HW_VAR_MBSSID_CAM_WRITE:
+	case HW_VAR_MBSSID_CAM_CLEAR:
+	case HW_VAR_RCR_MBSSID_EN:
+#endif
+	case HW_VAR_EN_HW_UPDATE_TSF:
+	case HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO:
+	case HW_VAR_CH_SW_IQK_INFO_BACKUP:
+	case HW_VAR_CH_SW_IQK_INFO_RESTORE:
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	case HW_VAR_TDLS_BCN_EARLY_C2H_RPT:
+#endif
+#endif
+		break;
+*/
+	case HW_VAR_TSF:
+		/* select TSF by port 0x554[30:28]=port */
+		val32 = rtw_read32(adapter, REG_MBSSID_BCN_SPACE);
+		val32 &= ~BIT_BCN_TIMER_SEL_FWRD(BIT_MASK_BCN_TIMER_SEL_FWRD);
+		val32 |=  BIT_BCN_TIMER_SEL_FWRD(adapter->hw_port);
+		rtw_write32(adapter, REG_MBSSID_BCN_SPACE, val32);
+
+		/* read and save HIGH 32bits TSF value */
+		val64 = rtw_read32(adapter, REG_TSFTR+4);
+		val64 = val64 << 32;
+
+		/* read and save LOW 32bits TSF value */
+		val64 |= rtw_read32(adapter, REG_TSFTR);
+		*((u64*)val) = val64;
+		break;
+
+	default:
+		GetHwReg(adapter, variable, val);
+		break;
+	}
+}
+
+/*
+ * Description:
+ *	Change default setting of specified variable.
+ */
+u8 rtl8822b_sethaldefvar(PADAPTER adapter, HAL_DEF_VARIABLE variable, void *pval)
+{
+	PHAL_DATA_TYPE hal;
+	u8 bResult;
+
+
+	hal = GET_HAL_DATA(adapter);
+	bResult = _SUCCESS;
+
+	switch (variable) {
+/*
+	case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB:
+	case HAL_DEF_IS_SUPPORT_ANT_DIV:
+	case HAL_DEF_DRVINFO_SZ:
+	case HAL_DEF_MAX_RECVBUF_SZ:
+	case HAL_DEF_RX_PACKET_OFFSET:
+	case HAL_DEF_RX_DMA_SZ_WOW:
+	case HAL_DEF_RX_DMA_SZ:
+	case HAL_DEF_RX_PAGE_SIZE:
+	case HAL_DEF_DBG_DUMP_RXPKT:
+	case HAL_DEF_RA_DECISION_RATE:
+	case HAL_DEF_RA_SGI:
+	case HAL_DEF_PT_PWR_STATUS:
+	case HAL_DEF_TX_LDPC:
+	case HAL_DEF_RX_LDPC:
+	case HAL_DEF_TX_STBC:
+	case HAL_DEF_RX_STBC:
+	case HAL_DEF_EXPLICIT_BEAMFORMER:
+	case HAL_DEF_EXPLICIT_BEAMFORMEE:
+	case HAL_DEF_VHT_MU_BEAMFORMER:
+	case HAL_DEF_VHT_MU_BEAMFORMEE:
+	case HAL_DEF_BEAMFORMER_CAP:
+	case HAL_DEF_BEAMFORMEE_CAP:
+	case HW_VAR_MAX_RX_AMPDU_FACTOR:
+	case HAL_DEF_DBG_DUMP_TXPKT:
+	case HAL_DEF_TX_PAGE_SIZE:
+	case HAL_DEF_TX_PAGE_BOUNDARY:
+	case HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN:
+	case HAL_DEF_ANT_DETECT:
+	case HAL_DEF_PCI_SUUPORT_L1_BACKDOOR:
+	case HAL_DEF_PCI_AMD_L1_SUPPORT:
+	case HAL_DEF_PCI_ASPM_OSC:
+	case HAL_DEF_EFUSE_USAGE:
+	case HAL_DEF_EFUSE_BYTES:
+	case HW_VAR_BEST_AMPDU_DENSITY:
+		break;
+*/
+	default:
+		bResult = SetHalDefVar(adapter, variable, pval);
+		break;
+	}
+
+	return bResult;
+}
+void rtl8822b_ra_info_dump(_adapter *padapter, void *sel)
+{
+	u8 mac_id;
+	struct sta_info *psta;
+	u32 rate_mask1, rate_mask2;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+
+	for (mac_id = 0; mac_id < macid_ctl->num; mac_id++) {
+		if (rtw_macid_is_used(macid_ctl, mac_id) && !rtw_macid_is_bmc(macid_ctl, mac_id)) {
+			psta = macid_ctl->sta[mac_id];
+			if (!psta)
+				continue;
+
+			dump_sta_info(sel, psta);
+			rate_mask1 = macid_ctl->rate_bmp0[mac_id];
+			rate_mask2 = macid_ctl->rate_bmp1[mac_id];
+			_RTW_PRINT_SEL(sel, "rate_mask2:0x%08x, rate_mask1:0x%08x\n", rate_mask2, rate_mask1);
+		}
+	}
+}
+/*
+ * Description:
+ *	Query setting of specified variable.
+ */
+u8 rtl8822b_gethaldefvar(PADAPTER adapter, HAL_DEF_VARIABLE variable, void *pval)
+{
+	PHAL_DATA_TYPE hal;
+	struct dvobj_priv *d;
+	u8 bResult;
+	u8 val8 = 0;
+	u32 val32 = 0;
+
+
+	d = adapter_to_dvobj(adapter);
+	hal = GET_HAL_DATA(adapter);
+	bResult = _SUCCESS;
+
+	switch (variable) {
+/*
+	case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB:
+		break;
+*/
+	case HAL_DEF_IS_SUPPORT_ANT_DIV:
+#ifdef CONFIG_ANTENNA_DIVERSITY
+		*(u8 *)pval = _TRUE;
+#else
+		*(u8 *)pval = _FALSE;
+#endif
+		break;
+
+/*
+	case HAL_DEF_DRVINFO_SZ:
+		break;
+*/
+	case HAL_DEF_MAX_RECVBUF_SZ:
+		*((u32 *)pval) = MAX_RECVBUF_SZ;
+		break;
+
+	case HAL_DEF_RX_PACKET_OFFSET:
+		val32 = rtl8822b_get_rx_desc_size(adapter);
+		val8 = rtl8822b_get_rx_drv_info_size(adapter);
+		*((u32 *)pval) = val32 + val8;
+		break;
+/*
+	case HAL_DEF_RX_DMA_SZ_WOW:
+	case HAL_DEF_RX_DMA_SZ:
+	case HAL_DEF_RX_PAGE_SIZE:
+	case HAL_DEF_DBG_DUMP_RXPKT:
+	case HAL_DEF_RA_DECISION_RATE:
+	case HAL_DEF_RA_SGI:
+		break;
+*/
+	/* only for 8188E */
+	case HAL_DEF_PT_PWR_STATUS:
+		break;
+
+	case HAL_DEF_TX_LDPC:
+	case HAL_DEF_RX_LDPC:
+		*(u8 *)pval = _TRUE;
+		break;
+
+	/* support 1T STBC under 2TX */
+	case HAL_DEF_TX_STBC:
+		if (hal->rf_type == RF_1T2R || hal->rf_type == RF_1T1R)
+			*(u8 *)pval = 0;
+		else
+			*(u8 *)pval = 1;
+		break;
+
+	/* support 1RX for STBC */
+	case HAL_DEF_RX_STBC:
+		*(u8 *)pval = 1;
+		break;
+
+	/* support Explicit TxBF for HT/VHT */
+	case HAL_DEF_EXPLICIT_BEAMFORMER:
+	case HAL_DEF_EXPLICIT_BEAMFORMEE:
+	case HAL_DEF_VHT_MU_BEAMFORMER:
+	case HAL_DEF_VHT_MU_BEAMFORMEE:
+		*(u8 *)pval = _TRUE;
+		break;
+
+	case HAL_DEF_BEAMFORMER_CAP:
+		val8 = 0;
+		rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, &val8);
+		switch (val8) {
+		case RF_1T1R:
+		case RF_1T2R:
+			*(u8 *)pval = 0;
+			break;
+		default:
+		case RF_2T2R:
+			*(u8 *)pval = 1;
+			break;
+		}
+		break;
+
+	case HAL_DEF_BEAMFORMEE_CAP:
+		*(u8 *)pval = 3;
+		break;
+
+	case HW_VAR_MAX_RX_AMPDU_FACTOR:
+		/* 8822B RX FIFO is 24KB */
+		*(HT_CAP_AMPDU_FACTOR *)pval = MAX_AMPDU_FACTOR_16K;
+		break;
+
+	case HW_DEF_RA_INFO_DUMP:
+		rtl8822b_ra_info_dump(adapter, pval);
+		break;
+/*
+	case HAL_DEF_DBG_DUMP_TXPKT:
+	case HAL_DEF_TX_PAGE_SIZE:
+	case HAL_DEF_TX_PAGE_BOUNDARY:
+	case HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN:
+	case HAL_DEF_ANT_DETECT:
+	case HAL_DEF_PCI_SUUPORT_L1_BACKDOOR:
+	case HAL_DEF_PCI_AMD_L1_SUPPORT:
+	case HAL_DEF_PCI_ASPM_OSC:
+	case HAL_DEF_EFUSE_USAGE:
+	case HAL_DEF_EFUSE_BYTES:
+		break;
+*/
+	case HW_VAR_BEST_AMPDU_DENSITY:
+		*((u32 *)pval) = AMPDU_DENSITY_VALUE_4;
+		break;
+
+	default:
+		bResult = GetHalDefVar(adapter, variable, pval);
+		break;
+	}
+
+	return bResult;
+}
+
+void rtl8822b_fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc)
+{
+	if ((pattrib->encrypt > 0) && !pattrib->bswenc) {
+		/* SEC_TYPE : 0:NO_ENC,1:WEP40/TKIP,2:WAPI,3:AES */
+		switch (pattrib->encrypt) {
+		case _WEP40_:
+		case _WEP104_:
+		case _TKIP_:
+		case _TKIP_WTMIC_:
+			SET_TX_DESC_SEC_TYPE_8822B(ptxdesc, 0x1);
+			break;
+#ifdef CONFIG_WAPI_SUPPORT
+		case _SMS4_:
+			SET_TX_DESC_SEC_TYPE_8822B(ptxdesc, 0x2);
+			break;
+#endif
+		case _AES_:
+			SET_TX_DESC_SEC_TYPE_8822B(ptxdesc, 0x3);
+			break;
+		case _NO_PRIVACY_:
+		default:
+			SET_TX_DESC_SEC_TYPE_8822B(ptxdesc, 0x0);
+			break;
+		}
+	}
+}
+
+void rtl8822b_fill_txdesc_vcs(PADAPTER adapter, struct pkt_attrib *pattrib, u8 *ptxdesc)
+{
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+
+
+	if (pattrib->vcs_mode) {
+		switch (pattrib->vcs_mode) {
+		case RTS_CTS:
+			SET_TX_DESC_RTSEN_8822B(ptxdesc, 1);
+			break;
+		case CTS_TO_SELF:
+			SET_TX_DESC_CTS2SELF_8822B(ptxdesc, 1);
+			break;
+		case NONE_VCS:
+		default:
+			break;
+		}
+
+		if (pmlmeinfo->preamble_mode == PREAMBLE_SHORT)
+			SET_TX_DESC_RTS_SHORT_8822B(ptxdesc, 1);
+
+		/* RTS Rate=24M */
+		SET_TX_DESC_RTSRATE_8822B(ptxdesc, 0x8);
+
+		/* compatibility for MCC consideration, use pmlmeext->cur_channel */
+		if (pmlmeext->cur_channel > 14)
+			/* RTS retry to rate OFDM 6M for 5G */
+			SET_TX_DESC_RTS_RTY_LOWEST_RATE_8822B(ptxdesc, 4);
+		else
+			/* RTS retry to rate CCK 1M for 2.4G */
+			SET_TX_DESC_RTS_RTY_LOWEST_RATE_8822B(ptxdesc, 0);
+	}
+}
+
+u8 rtl8822b_bw_mapping(PADAPTER adapter, struct pkt_attrib *pattrib)
+{
+	u8 BWSettingOfDesc = 0;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	if (hal->current_channel_bw == CHANNEL_WIDTH_80) {
+		if (pattrib->bwmode == CHANNEL_WIDTH_80)
+			BWSettingOfDesc = 2;
+		else if (pattrib->bwmode == CHANNEL_WIDTH_40)
+			BWSettingOfDesc = 1;
+		else
+			BWSettingOfDesc = 0;
+	} else if (hal->current_channel_bw == CHANNEL_WIDTH_40) {
+		if ((pattrib->bwmode == CHANNEL_WIDTH_40) || (pattrib->bwmode == CHANNEL_WIDTH_80))
+			BWSettingOfDesc = 1;
+		else
+			BWSettingOfDesc = 0;
+	} else
+		BWSettingOfDesc = 0;
+
+	return BWSettingOfDesc;
+}
+
+u8 rtl8822b_sc_mapping(PADAPTER adapter, struct pkt_attrib *pattrib)
+{
+	u8 SCSettingOfDesc = 0;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	if (hal->current_channel_bw == CHANNEL_WIDTH_80) {
+		if (pattrib->bwmode == CHANNEL_WIDTH_80)
+			SCSettingOfDesc = VHT_DATA_SC_DONOT_CARE;
+		else if (pattrib->bwmode == CHANNEL_WIDTH_40) {
+			if (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER)
+				SCSettingOfDesc = VHT_DATA_SC_40_LOWER_OF_80MHZ;
+			else if (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER)
+				SCSettingOfDesc = VHT_DATA_SC_40_UPPER_OF_80MHZ;
+			else
+				RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+		} else {
+			if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER))
+				SCSettingOfDesc = VHT_DATA_SC_20_LOWEST_OF_80MHZ;
+			else if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER))
+				SCSettingOfDesc = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+			else if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER))
+				SCSettingOfDesc = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+			else if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER))
+				SCSettingOfDesc = VHT_DATA_SC_20_UPPERST_OF_80MHZ;
+			else
+				RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+		}
+	} else if (hal->current_channel_bw == CHANNEL_WIDTH_40) {
+		if (pattrib->bwmode == CHANNEL_WIDTH_40)
+			SCSettingOfDesc = VHT_DATA_SC_DONOT_CARE;
+		else if (pattrib->bwmode == CHANNEL_WIDTH_20) {
+			if (hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER)
+				SCSettingOfDesc = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+			else if (hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER)
+				SCSettingOfDesc = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+			else
+				SCSettingOfDesc = VHT_DATA_SC_DONOT_CARE;
+		}
+	} else
+		SCSettingOfDesc = VHT_DATA_SC_DONOT_CARE;
+
+	return SCSettingOfDesc;
+}
+
+void rtl8822b_fill_txdesc_phy(PADAPTER adapter, struct pkt_attrib *pattrib, u8 *ptxdesc)
+{
+	if (pattrib->ht_en) {
+		/* Set Bandwidth and sub-channel settings. */
+		SET_TX_DESC_DATA_BW_8822B(ptxdesc, rtl8822b_bw_mapping(adapter, pattrib));
+		SET_TX_DESC_DATA_SC_8822B(ptxdesc, rtl8822b_sc_mapping(adapter, pattrib));
+	}
+}
+
+/**
+ * rtl8822b_fill_txdesc_tx_rate() - Set rate in tx description
+ * @adapter	struct _ADAPTER*
+ * @attrib	packet attribute
+ * @rate	DESC_RATE*
+ * @shrt	1/0 means short/long PLCP for CCK, short/long GI for HT/VHT
+ * @fallback	enable rate fallback or not
+ * @desc	buffer of tx description
+ *
+ * Fill rate related fields of tx description when driver want to use specific
+ * data rate to send this packet.
+ */
+static void rtl8822b_fill_txdesc_tx_rate(struct _ADAPTER *adapter,
+				struct pkt_attrib *attrib,
+				u8 rate, u8 shrt, u8 fallback, u8 *desc)
+{
+	u8 disfb;
+	u8 bw;
+
+
+	rate = rate & 0x7F;
+	shrt = shrt ? 1 : 0;
+	disfb = fallback ? 0 : 1;
+
+	SET_TX_DESC_USE_RATE_8822B(desc, 1);
+	SET_TX_DESC_DATARATE_8822B(desc, rate);
+	SET_TX_DESC_DATA_SHORT_8822B(desc, shrt);
+	SET_TX_DESC_DISDATAFB_8822B(desc, disfb);
+
+	/* HT MCS rate can't support bandwidth higher than 40MHz */
+	bw = GET_TX_DESC_DATA_BW_8822B(desc);
+	if (((rate >= DESC_RATEMCS0) && (rate <= DESC_RATEMCS31)) && (bw > 1)) {
+		RTW_WARN(FUNC_ADPT_FMT ": Use HT rate(%s) on bandwidth "
+			 "higher than 40MHz(%u>%u) is illegal, "
+			 "switch bandwidth to 40MHz!\n",
+			 FUNC_ADPT_ARG(adapter),
+			 HDATA_RATE(rate), attrib->bwmode,
+			 CHANNEL_WIDTH_40);
+
+		if (attrib->bwmode > CHANNEL_WIDTH_40)
+			attrib->bwmode = CHANNEL_WIDTH_40;
+		rtl8822b_fill_txdesc_phy(adapter, attrib, desc);
+	}
+}
+
+#ifdef CONFIG_CONCURRENT_MODE
+void rtl8822b_fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc)
+{
+	if ((pattrib->encrypt > 0) && (!pattrib->bswenc)
+	    && (pattrib->bmc_camid != INVALID_SEC_MAC_CAM_ID)) {
+		SET_TX_DESC_EN_DESC_ID_8822B(ptxdesc, 1);
+		SET_TX_DESC_MACID_8822B(ptxdesc, pattrib->bmc_camid);
+	}
+}
+#endif
+
+void rtl8822b_fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc)
+{
+	SET_TX_DESC_USE_RATE_8822B(ptxdesc, 1);
+	SET_TX_DESC_DATARATE_8822B(ptxdesc, MRateToHwRate(pattrib->rate));
+	SET_TX_DESC_DISDATAFB_8822B(ptxdesc, 1);
+}
+
+/*
+ * Description:
+ *	Fill tx description for beamforming packets
+ */
+void rtl8822b_fill_txdesc_bf(struct xmit_frame *frame, u8 *desc)
+{
+#ifndef CONFIG_BEAMFORMING
+	return;
+#else /* CONFIG_BEAMFORMING */
+	struct pkt_attrib *attrib;
+
+
+	attrib = &frame->attrib;
+
+	SET_TX_DESC_G_ID_8822B(desc, attrib->txbf_g_id);
+	SET_TX_DESC_P_AID_8822B(desc, attrib->txbf_p_aid);
+
+	SET_TX_DESC_MU_DATARATE_8822B(desc, MRateToHwRate(attrib->rate));
+	/*SET_TX_DESC_MU_RC_8822B(desc, 0);*/
+
+	/* Force to disable STBC when txbf is enabled */
+	if (attrib->txbf_p_aid && attrib->stbc)
+		SET_TX_DESC_DATA_STBC_8822B(desc, 0);
+#endif /* CONFIG_BEAMFORMING */
+}
+
+/*
+ * Description:
+ *	Fill tx description for beamformer,
+ *	include following management packets:
+ *	1. VHT NDPA
+ *	2. HT NDPA
+ *	3. Beamforming Report Poll
+ */
+void rtl8822b_fill_txdesc_mgnt_bf(struct xmit_frame *frame, u8 *desc)
+{
+#ifndef CONFIG_BEAMFORMING
+	return;
+#else /* CONFIG_BEAMFORMING */
+	PADAPTER adapter;
+	struct pkt_attrib *attrib;
+	u8 ndpa = 0;
+	u8 ht_ndpa = 0;
+	u8 report_poll = 0;
+
+
+	adapter = frame->padapter;
+	attrib = &frame->attrib;
+
+	if (attrib->subtype == WIFI_NDPA)
+		ndpa = 1;
+	if ((attrib->subtype == WIFI_ACTION_NOACK) && (attrib->order == 1))
+		ht_ndpa = 1;
+	if (attrib->subtype == WIFI_BF_REPORT_POLL)
+		report_poll = 1;
+
+	if ((!ndpa) && (!ht_ndpa) && (!report_poll))
+		return;
+
+	/*SET_TX_DESC_TXPKTSIZE_8822B(desc, pattrib->last_txcmdsz);*/
+	/*SET_TX_DESC_OFFSET_8822B(desc, HALMAC_TX_DESC_SIZE_8822B);*/
+	SET_TX_DESC_DISRTSFB_8822B(desc, 1);
+	SET_TX_DESC_DISDATAFB(desc, 1);
+	/*SET_TX_DESC_SW_SEQ_8822B(desc, pattrib->seqnum);*/
+	SET_TX_DESC_DATA_BW_8822B(desc, rtl8822b_bw_mapping(adapter, attrib));
+	SET_TX_DESC_SIGNALING_TA_PKT_SC_8822B(desc,
+					rtl8822b_sc_mapping(adapter, attrib));
+	/*SET_TX_DESC_RTY_LMT_EN_8822B(ptxdesc, 1);*/
+	SET_TX_DESC_RTS_DATA_RTY_LMT_8822B(desc, 5);
+	SET_TX_DESC_NDPA_8822B(desc, 1);
+	SET_TX_DESC_NAVUSEHDR_8822B(desc, 1);
+	/*SET_TX_DESC_QSEL_8822B(desc, QSLT_MGNT);*/
+	/*
+	 * NSS2MCS0 for VHT
+	 * MCS8 for HT
+	 */
+	SET_TX_DESC_DATARATE_8822B(desc, MRateToHwRate(attrib->rate));
+	/*SET_TX_DESC_USE_RATE_8822B(desc, 1);*/
+	/*SET_TX_DESC_MACID_8822B(desc, pattrib->mac_id);*/ /* ad-hoc mode */
+	/*SET_TX_DESC_G_ID_8822B(desc, 63);*/
+	/*
+	 * partial AID of 1st STA, at infrastructure mode, either SU or MU; 
+	 * MACID, at ad-hoc mode
+	 *
+	 * For WMAC to restore the received CSI report of STA1.
+	 * WMAC would set p_aid field to 0 in PLCP header for MU.
+	 */
+	/*SET_TX_DESC_P_AID_8822B(desc, pattrib->txbf_p_aid);*/
+	SET_TX_DESC_SND_PKT_SEL_8822B(desc, attrib->bf_pkt_type);
+#endif /* CONFIG_BEAMFORMING */
+}
+
+void rtl8822b_cal_txdesc_chksum(PADAPTER adapter, u8 *ptxdesc)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+
+
+	halmac = adapter_to_halmac(adapter);
+	api = HALMAC_GET_API(halmac);
+
+	api->halmac_fill_txdesc_checksum(halmac, ptxdesc);
+}
+
+
+#ifdef CONFIG_MP_INCLUDED
+void rtl8822b_prepare_mp_txdesc(PADAPTER adapter, struct mp_priv *pmp_priv)
+{
+	u8 *desc;
+	struct pkt_attrib *attrib;
+	u32 pkt_size;
+	s32 bmcast;
+	u32 desc_size;
+	u8 data_rate, pwr_status, offset;
+
+
+	desc = pmp_priv->tx.desc;
+	attrib = &pmp_priv->tx.attrib;
+	pkt_size = attrib->last_txcmdsz;
+	bmcast = IS_MCAST(attrib->ra);
+	desc_size = rtl8822b_get_tx_desc_size(adapter);
+
+	SET_TX_DESC_LS_8822B(desc, 1);
+	SET_TX_DESC_TXPKTSIZE_8822B(desc, pkt_size);
+
+	offset = desc_size;
+	SET_TX_DESC_OFFSET_8822B(desc, offset);
+#if defined(CONFIG_PCI_HCI)
+	SET_TX_DESC_PKT_OFFSET_8822B(desc, 0); /* 8822BE pkt_offset is 0 */
+#else
+	SET_TX_DESC_PKT_OFFSET_8822B(desc, 1);
+#endif
+
+	if (bmcast)
+		SET_TX_DESC_BMC_8822B(desc, 1);
+
+	SET_TX_DESC_MACID_8822B(desc, attrib->mac_id);
+	SET_TX_DESC_RATE_ID_8822B(desc, attrib->raid);
+	SET_TX_DESC_QSEL_8822B(desc, attrib->qsel);
+
+	if (pmp_priv->preamble)
+		SET_TX_DESC_DATA_SHORT_8822B(desc, 1);
+
+	if (!attrib->qos_en)
+		SET_TX_DESC_EN_HWSEQ_8822B(desc, 1);
+	else
+		SET_TX_DESC_SW_SEQ_8822B(desc, attrib->seqnum);
+
+	if (pmp_priv->bandwidth <= CHANNEL_WIDTH_160)
+		SET_TX_DESC_DATA_BW_8822B(desc, pmp_priv->bandwidth);
+	else {
+		RTW_ERR("%s: unknown bandwidth %d, use 20M\n",
+			 __FUNCTION__, pmp_priv->bandwidth);
+		SET_TX_DESC_DATA_BW_8822B(desc, CHANNEL_WIDTH_20);
+	}
+
+	SET_TX_DESC_DISDATAFB_8822B(desc, 1);
+	SET_TX_DESC_USE_RATE_8822B(desc, 1);
+	SET_TX_DESC_DATARATE_8822B(desc, pmp_priv->rateidx);
+}
+#endif /* CONFIG_MP_INCLUDED */
+
+static void fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf)
+{
+	PADAPTER adapter;
+	PHAL_DATA_TYPE hal;
+	struct mlme_ext_priv *pmlmeext;
+	struct mlme_ext_info *pmlmeinfo;
+	struct pkt_attrib *pattrib;
+	s32 bmcst;
+	u32 desc_size;
+
+
+	adapter = pxmitframe->padapter;
+	hal = GET_HAL_DATA(adapter);
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	pattrib = &pxmitframe->attrib;
+	bmcst = IS_MCAST(pattrib->ra);
+
+	desc_size = rtl8822b_get_tx_desc_size(adapter);
+	_rtw_memset(pbuf, 0, desc_size);
+
+	if (pxmitframe->frame_tag == DATA_FRAMETAG) {
+		u8 drv_userate = 0;
+
+		SET_TX_DESC_MACID_8822B(pbuf, pattrib->mac_id);
+		SET_TX_DESC_RATE_ID_8822B(pbuf, pattrib->raid);
+		SET_TX_DESC_QSEL_8822B(pbuf, pattrib->qsel);
+		SET_TX_DESC_SW_SEQ_8822B(pbuf, pattrib->seqnum);
+
+		rtl8822b_fill_txdesc_sectype(pattrib, pbuf);
+		rtl8822b_fill_txdesc_vcs(adapter, pattrib, pbuf);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		if (bmcst)
+			rtl8822b_fill_txdesc_force_bmc_camid(pattrib, pbuf);
+#endif
+
+#ifdef CONFIG_P2P
+		if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
+			if (pattrib->icmp_pkt == 1 && adapter->registrypriv.wifi_spec == 1)
+				drv_userate = 1;
+		}
+#endif
+
+		if ((pattrib->ether_type != 0x888e) &&
+		    (pattrib->ether_type != 0x0806) &&
+		    (pattrib->ether_type != 0x88B4) &&
+		    (pattrib->dhcp_pkt != 1) &&
+		    (drv_userate != 1)
+#ifdef CONFIG_AUTO_AP_MODE
+		    && (pattrib->pctrl != _TRUE)
+#endif
+		   ) {
+			/* Non EAP & ARP & DHCP type data packet */
+
+			if (pattrib->ampdu_en == _TRUE) {
+				SET_TX_DESC_AGG_EN_8822B(pbuf, 1);
+				SET_TX_DESC_MAX_AGG_NUM_8822B(pbuf, 0x1F);
+				SET_TX_DESC_AMPDU_DENSITY_8822B(pbuf, pattrib->ampdu_spacing);
+			} else
+				SET_TX_DESC_BK_8822B(pbuf, 1);
+
+			rtl8822b_fill_txdesc_phy(adapter, pattrib, pbuf);
+
+			/* compatibility for MCC consideration, use pmlmeext->cur_channel */
+			if (!bmcst) {
+				if (pmlmeext->cur_channel > 14)
+					/* for 5G, OFDM 6M */
+					SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(pbuf, 4);
+				else
+					/* for 2.4G, CCK 1M */
+					SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(pbuf, 0);
+			}
+
+			if (hal->fw_ractrl == _FALSE)
+				rtl8822b_fill_txdesc_tx_rate(adapter, pattrib,
+					hal->INIDATA_RATE[pattrib->mac_id] & 0x7F,
+					hal->INIDATA_RATE[pattrib->mac_id] & BIT(7) ? 1 : 0,
+					1, pbuf);
+
+			if (bmcst) {
+				SET_TX_DESC_SW_DEFINE_8822B(pbuf, 0x01);
+				rtl8822b_fill_txdesc_bmc_tx_rate(pattrib, pbuf);
+			}
+
+			/* modify data rate by iwpriv */
+			if (adapter->fix_rate != 0xFF)
+				rtl8822b_fill_txdesc_tx_rate(adapter, pattrib,
+					adapter->fix_rate & 0x7F,
+					adapter->fix_rate & BIT(7) ? 1 : 0,
+					adapter->data_fb, pbuf);
+
+			if (pattrib->ldpc)
+				SET_TX_DESC_DATA_LDPC_8822B(pbuf, 1);
+			if (pattrib->stbc)
+				SET_TX_DESC_DATA_STBC_8822B(pbuf, 1);
+
+#ifdef CONFIG_CMCC_TEST
+			SET_TX_DESC_DATA_SHORT_8822B(pbuf, 1); /* use cck short premble */
+#endif
+
+#ifdef CONFIG_WMMPS_STA
+			if (pattrib->trigger_frame)
+				SET_TX_DESC_TRI_FRAME_8822B (pbuf, 1);
+#endif /* CONFIG_WMMPS_STA */
+
+		} 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.
+			 */
+
+			SET_TX_DESC_BK_8822B(pbuf, 1);
+			SET_TX_DESC_USE_RATE_8822B(pbuf, 1);
+			if (pmlmeinfo->preamble_mode == PREAMBLE_SHORT)
+				SET_TX_DESC_DATA_SHORT_8822B(pbuf, 1);
+			SET_TX_DESC_DATARATE_8822B(pbuf, MRateToHwRate(pmlmeext->tx_rate));
+
+			RTW_INFO(FUNC_ADPT_FMT ": SP Packet(0x%04X) rate=0x%x\n",
+				FUNC_ADPT_ARG(adapter), pattrib->ether_type, MRateToHwRate(pmlmeext->tx_rate));
+		}
+
+#if defined(CONFIG_USB_TX_AGGREGATION) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+		SET_TX_DESC_DMA_TXAGG_NUM_8822B(pbuf, pxmitframe->agg_num);
+#endif
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_XMIT_ACK
+		/* CCX-TXRPT ack for xmit mgmt frames. */
+		if (pxmitframe->ack_report) {
+#ifdef DBG_CCX
+			RTW_INFO("%s set spe_rpt\n", __func__);
+#endif
+			SET_TX_DESC_SPE_RPT_8822B(pbuf, 1);
+			SET_TX_DESC_SW_DEFINE_8822B(pbuf, (u8)(GET_PRIMARY_ADAPTER(adapter)->xmitpriv.seq_no));
+		}
+#endif /* CONFIG_XMIT_ACK */
+#endif
+	} else if (pxmitframe->frame_tag == MGNT_FRAMETAG) {
+		SET_TX_DESC_MACID_8822B(pbuf, pattrib->mac_id);
+		SET_TX_DESC_QSEL_8822B(pbuf, pattrib->qsel);
+		SET_TX_DESC_RATE_ID_8822B(pbuf, pattrib->raid);
+		SET_TX_DESC_SW_SEQ_8822B(pbuf, pattrib->seqnum);
+		SET_TX_DESC_USE_RATE_8822B(pbuf, 1);
+
+		SET_TX_DESC_MBSSID_8822B(pbuf, pattrib->mbssid & 0xF);
+
+		SET_TX_DESC_DATARATE_8822B(pbuf, MRateToHwRate(pattrib->rate));
+
+		rtl8822b_fill_txdesc_mgnt_bf(pxmitframe, pbuf);
+
+#ifdef CONFIG_XMIT_ACK
+		/* CCX-TXRPT ack for xmit mgmt frames. */
+		if (pxmitframe->ack_report) {
+#ifdef DBG_CCX
+			RTW_INFO("%s set spe_rpt\n", __FUNCTION__);
+#endif
+			SET_TX_DESC_SPE_RPT_8822B(pbuf, 1);
+			SET_TX_DESC_SW_DEFINE_8822B(pbuf, (u8)(GET_PRIMARY_ADAPTER(adapter)->xmitpriv.seq_no));
+		}
+#endif /* CONFIG_XMIT_ACK */
+	} else if (pxmitframe->frame_tag == TXAGG_FRAMETAG)
+		RTW_INFO("%s: TXAGG_FRAMETAG\n", __FUNCTION__);
+#ifdef CONFIG_MP_INCLUDED
+	else if (pxmitframe->frame_tag == MP_FRAMETAG) {
+		RTW_DBG("%s: MP_FRAMETAG\n", __FUNCTION__);
+		fill_txdesc_for_mp(adapter, pbuf);
+	}
+#endif
+	else {
+		RTW_INFO("%s: frame_tag=0x%x\n", __FUNCTION__, pxmitframe->frame_tag);
+
+		SET_TX_DESC_MACID_8822B(pbuf, pattrib->mac_id);
+		SET_TX_DESC_RATE_ID_8822B(pbuf, pattrib->raid);
+		SET_TX_DESC_QSEL_8822B(pbuf, pattrib->qsel);
+		SET_TX_DESC_SW_SEQ_8822B(pbuf, pattrib->seqnum);
+		SET_TX_DESC_USE_RATE_8822B(pbuf, 1);
+		SET_TX_DESC_DATARATE_8822B(pbuf, MRateToHwRate(pmlmeext->tx_rate));
+	}
+
+	SET_TX_DESC_TXPKTSIZE_8822B(pbuf, pattrib->last_txcmdsz);
+
+	{
+		u8 pkt_offset, offset;
+
+		pkt_offset = 0;
+		offset = desc_size;
+#ifdef CONFIG_USB_HCI
+		pkt_offset = pxmitframe->pkt_offset;
+		offset += (pxmitframe->pkt_offset >> 3);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_TX_EARLY_MODE
+		if (pxmitframe->frame_tag == DATA_FRAMETAG) {
+			pkt_offset = 1;
+			offset += EARLY_MODE_INFO_SIZE;
+		}
+#endif /* CONFIG_TX_EARLY_MODE */
+
+		SET_TX_DESC_PKT_OFFSET_8822B(pbuf, pkt_offset);
+		SET_TX_DESC_OFFSET_8822B(pbuf, offset);
+	}
+
+	if (bmcst)
+		SET_TX_DESC_BMC_8822B(pbuf, 1);
+
+	/*
+	 * 2009.11.05. tynli_test. Suggested by SD4 Filen for FW LPS.
+	 * (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.
+	 * 2010.06.23. Added by tynli.
+	 */
+	if (!pattrib->qos_en)
+		SET_TX_DESC_EN_HWSEQ_8822B(pbuf, 1);
+
+	SET_TX_DESC_PORT_ID_8822B(pbuf, get_hw_port(adapter));
+	SET_TX_DESC_MULTIPLE_PORT_8822B(pbuf, get_hw_port(adapter));
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	if (!bmcst && pattrib->psta)
+		odm_set_tx_ant_by_tx_info(adapter_to_phydm(adapter), pbuf, pattrib->psta->cmn.mac_id);
+#endif
+
+	rtl8822b_fill_txdesc_bf(pxmitframe, pbuf);
+}
+
+/*
+ * Description:
+ *
+ * Parameters:
+ *	pxmitframe	xmitframe
+ *	pbuf		where to fill tx desc
+ */
+void rtl8822b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf)
+{
+	fill_default_txdesc(pxmitframe, pbuf);
+	rtl8822b_cal_txdesc_chksum(pxmitframe->padapter, pbuf);
+}
+
+/*
+ * 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 directly.
+ */
+static void fill_fake_txdesc(PADAPTER adapter, u8 *pDesc, u32 BufferLen,
+			     u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame)
+{
+	/* Clear all status */
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	u32 desc_size;
+
+
+	desc_size = rtl8822b_get_tx_desc_size(adapter);
+	_rtw_memset(pDesc, 0, desc_size);
+
+	SET_TX_DESC_LS_8822B(pDesc, 1);
+
+	SET_TX_DESC_OFFSET_8822B(pDesc, desc_size);
+
+	SET_TX_DESC_TXPKTSIZE_8822B(pDesc, BufferLen);
+	SET_TX_DESC_QSEL_8822B(pDesc, QSLT_MGNT); /* Fixed queue of Mgnt queue */
+
+	if (pmlmeext->cur_wireless_mode & WIRELESS_11B)
+		SET_TX_DESC_RATE_ID_8822B(pDesc, RATEID_IDX_B);
+	else
+		SET_TX_DESC_RATE_ID_8822B(pDesc, RATEID_IDX_G);
+
+	/* Set NAVUSEHDR to prevent Ps-poll AId filed to be changed to error vlaue by HW */
+	if (_TRUE == IsPsPoll)
+		SET_TX_DESC_NAVUSEHDR_8822B(pDesc, 1);
+	else {
+		SET_TX_DESC_DISQSELSEQ_8822B(pDesc, 1);
+		SET_TX_DESC_EN_HWSEQ_8822B(pDesc, 1);
+		SET_TX_DESC_HW_SSN_SEL_8822B(pDesc, 0);/*pattrib->hw_ssn_sel*/
+		SET_TX_DESC_EN_HWEXSEQ_8822B(pDesc, 0);
+	}
+
+	if (_TRUE == IsBTQosNull)
+		SET_TX_DESC_BT_NULL_8822B(pDesc, 1);
+
+	SET_TX_DESC_USE_RATE_8822B(pDesc, 1);
+	SET_TX_DESC_DATARATE_8822B(pDesc, MRateToHwRate(pmlmeext->tx_rate));
+
+#ifdef CONFIG_MCC_MODE
+	/* config Null data retry number */
+	if (IsPsPoll == _FALSE && IsBTQosNull == _FALSE && bDataFrame == _FALSE) {
+		if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_PROCESS_MCC_START_SETTING)) {
+			u8 rty_num = adapter->mcc_adapterpriv.null_rty_num;
+			if (rty_num != 0) {
+				SET_TX_DESC_RTY_LMT_EN_8822B(pDesc, 1);
+				SET_TX_DESC_RTS_DATA_RTY_LMT_8822B(pDesc, rty_num);
+			}
+		}
+	}
+#endif
+
+
+	/*
+	 * Encrypt the data frame if under security mode excepct null data.
+	 */
+	if (_TRUE == bDataFrame) {
+		u32 EncAlg;
+
+		EncAlg = adapter->securitypriv.dot11PrivacyAlgrthm;
+		switch (EncAlg) {
+		case _NO_PRIVACY_:
+			SET_TX_DESC_SEC_TYPE_8822B(pDesc, 0x0);
+			break;
+		case _WEP40_:
+		case _WEP104_:
+		case _TKIP_:
+			SET_TX_DESC_SEC_TYPE_8822B(pDesc, 0x1);
+			break;
+		case _SMS4_:
+			SET_TX_DESC_SEC_TYPE_8822B(pDesc, 0x2);
+			break;
+		case _AES_:
+			SET_TX_DESC_SEC_TYPE_8822B(pDesc, 0x3);
+			break;
+		default:
+			SET_TX_DESC_SEC_TYPE_8822B(pDesc, 0x0);
+			break;
+		}
+	}
+
+	SET_TX_DESC_PORT_ID_8822B(pDesc, get_hw_port(adapter));
+	SET_TX_DESC_MULTIPLE_PORT_8822B(pDesc, get_hw_port(adapter));
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	/*
+	 * 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.).
+	 */
+	rtl8822b_cal_txdesc_chksum(adapter, pDesc);
+#endif
+}
+
+void rtl8822b_dbg_dump_tx_desc(PADAPTER adapter, int frame_tag, u8 *ptxdesc)
+{
+	u8 bDumpTxPkt;
+	u8 bDumpTxDesc = _FALSE;
+
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_TXPKT, &bDumpTxPkt);
+
+	/* 1 for data frame, 2 for mgnt frame */
+	if (bDumpTxPkt == 1) {
+		RTW_INFO("dump tx_desc for data frame\n");
+		if ((frame_tag & 0x0f) == DATA_FRAMETAG)
+			bDumpTxDesc = _TRUE;
+	} else if (bDumpTxPkt == 2) {
+		RTW_INFO("dump tx_desc for mgnt frame\n");
+		if ((frame_tag & 0x0f) == MGNT_FRAMETAG)
+			bDumpTxDesc = _TRUE;
+	}
+
+	/* 8822B TX SIZE = 48(HALMAC_TX_DESC_SIZE_8822B) */
+	if (_TRUE == bDumpTxDesc) {
+		RTW_INFO("=====================================\n");
+		RTW_INFO("Offset00(0x%08x)\n", *((u32 *)(ptxdesc)));
+		RTW_INFO("Offset04(0x%08x)\n", *((u32 *)(ptxdesc + 4)));
+		RTW_INFO("Offset08(0x%08x)\n", *((u32 *)(ptxdesc + 8)));
+		RTW_INFO("Offset12(0x%08x)\n", *((u32 *)(ptxdesc + 12)));
+		RTW_INFO("Offset16(0x%08x)\n", *((u32 *)(ptxdesc + 16)));
+		RTW_INFO("Offset20(0x%08x)\n", *((u32 *)(ptxdesc + 20)));
+		RTW_INFO("Offset24(0x%08x)\n", *((u32 *)(ptxdesc + 24)));
+		RTW_INFO("Offset28(0x%08x)\n", *((u32 *)(ptxdesc + 28)));
+		RTW_INFO("Offset32(0x%08x)\n", *((u32 *)(ptxdesc + 32)));
+		RTW_INFO("Offset36(0x%08x)\n", *((u32 *)(ptxdesc + 36)));
+		RTW_INFO("Offset40(0x%08x)\n", *((u32 *)(ptxdesc + 40)));
+		RTW_INFO("Offset44(0x%08x)\n", *((u32 *)(ptxdesc + 44)));
+		RTW_INFO("=====================================\n");
+	}
+}
+
+void rtl8822b_rxdesc2attribute(struct rx_pkt_attrib *a, u8 *desc)
+{
+	/* initial value */
+	_rtw_memset(a, 0, sizeof(struct rx_pkt_attrib));
+	a->bw = CHANNEL_WIDTH_MAX;
+
+	/* Get from RX DESC */
+	a->pkt_len = (u16)GET_RX_DESC_PKT_LEN_8822B(desc);
+	a->pkt_rpt_type = GET_RX_DESC_C2H_8822B(desc) ? C2H_PACKET : NORMAL_RX;
+
+	if (a->pkt_rpt_type == NORMAL_RX) {
+		a->crc_err = (u8)GET_RX_DESC_CRC32_8822B(desc);
+		a->icv_err = (u8)GET_RX_DESC_ICV_ERR_8822B(desc);
+		a->drvinfo_sz = (u8)GET_RX_DESC_DRV_INFO_SIZE_8822B(desc) << 3;
+		a->encrypt = (u8)GET_RX_DESC_SECURITY_8822B(desc);
+		a->qos = (u8)GET_RX_DESC_QOS_8822B(desc);
+		a->shift_sz = (u8)GET_RX_DESC_SHIFT_8822B(desc);
+		a->physt = (u8)GET_RX_DESC_PHYST_8822B(desc);
+		a->bdecrypted = (u8)GET_RX_DESC_SWDEC_8822B(desc) ? 0 : 1;
+
+		a->priority = (u8)GET_RX_DESC_TID_8822B(desc);
+		a->amsdu = (u8)GET_RX_DESC_AMSDU_8822B(desc);
+		a->mdata = (u8)GET_RX_DESC_MD_8822B(desc);
+		a->mfrag = (u8)GET_RX_DESC_MF_8822B(desc);
+
+		a->seq_num = (u16)GET_RX_DESC_SEQ_8822B(desc);
+		a->frag_num = (u8)GET_RX_DESC_FRAG_8822B(desc);
+
+		a->data_rate = (u8)GET_RX_DESC_RX_RATE_8822B(desc);
+		a->ppdu_cnt = (u8)GET_RX_DESC_PPDU_CNT_8822B(desc);
+		a->free_cnt = (u32)GET_RX_DESC_TSFL_8822B(desc);
+	}
+}
+
+void rtl8822b_query_rx_desc(union recv_frame *precvframe, u8 *pdesc)
+{
+	rtl8822b_rxdesc2attribute(&precvframe->u.hdr.attrib, pdesc);
+}
+
+void rtl8822b_set_hal_ops(PADAPTER adapter)
+{
+	struct hal_com_data *hal;
+	struct hal_ops *ops;
+
+
+	hal = GET_HAL_DATA(adapter);
+	ops = &adapter->hal_func;
+
+	/*
+	 * Initialize hal_com_data variables
+	 */
+	hal->efuse0x3d7 = 0xFF;
+	hal->efuse0x3d8 = 0xFF;
+
+	/*
+	 * Initialize operation callback functions
+	 */
+	/*** initialize section ***/
+	ops->read_chip_version = read_chip_version;
+/*
+	ops->init_default_value = NULL;
+	ops->intf_chip_configure = NULL;
+*/
+	ops->read_adapter_info = rtl8822b_read_efuse;
+	ops->hal_power_on = rtl8822b_power_on;
+	ops->hal_power_off = rtl8822b_power_off;
+	ops->hal_init = rtl8822b_init;
+	ops->hal_deinit = rtl8822b_deinit;
+	ops->dm_init = rtl8822b_phy_init_dm_priv;
+	ops->dm_deinit = rtl8822b_phy_deinit_dm_priv;
+
+	/*** xmit section ***/
+/*
+	ops->init_xmit_priv = NULL;
+	ops->free_xmit_priv = NULL;
+	ops->hal_xmit = NULL;
+	ops->mgnt_xmit = NULL;
+	ops->hal_xmitframe_enqueue = NULL;
+#ifdef CONFIG_XMIT_THREAD_MODE
+	ops->xmit_thread_handler = NULL;
+#endif
+*/
+	ops->run_thread = rtl8822b_run_thread;
+	ops->cancel_thread = rtl8822b_cancel_thread;
+
+	/*** recv section ***/
+/*
+	ops->init_recv_priv = NULL;
+	ops->free_recv_priv = NULL;
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
+	ops->inirp_init = NULL;
+	ops->inirp_deinit = NULL;
+#endif
+*/
+	/*** interrupt hdl section ***/
+/*
+	ops->enable_interrupt = NULL;
+	ops->disable_interrupt = NULL;
+*/
+	ops->check_ips_status = check_ips_status;
+/*
+#if defined(CONFIG_PCI_HCI)
+	ops->interrupt_handler = NULL;
+#endif
+#if defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
+	ops->interrupt_handler = NULL;
+#endif
+#if defined(CONFIG_PCI_HCI)
+	ops->irp_reset = NULL;
+#endif
+*/
+
+	/*** DM section ***/
+	ops->set_chnl_bw_handler = rtl8822b_set_channel_bw;
+
+	ops->set_tx_power_level_handler = rtl8822b_set_tx_power_level;
+	ops->get_tx_power_level_handler = rtl8822b_get_tx_power_level;
+
+	ops->set_tx_power_index_handler = rtl8822b_set_tx_power_index;
+	ops->get_tx_power_index_handler = rtl8822b_get_tx_power_index;
+
+	ops->hal_dm_watchdog = rtl8822b_phy_haldm_watchdog;
+
+	ops->set_hw_reg_handler = rtl8822b_sethwreg;
+	ops->GetHwRegHandler = rtl8822b_gethwreg;
+	ops->get_hal_def_var_handler = rtl8822b_gethaldefvar;
+	ops->SetHalDefVarHandler = rtl8822b_sethaldefvar;
+
+	ops->GetHalODMVarHandler = GetHalODMVar;
+	ops->SetHalODMVarHandler = SetHalODMVar;
+
+	ops->SetBeaconRelatedRegistersHandler = set_beacon_related_registers;
+
+/*
+	ops->interface_ps_func = NULL;
+*/
+	ops->read_bbreg = rtl8822b_read_bb_reg;
+	ops->write_bbreg = rtl8822b_write_bb_reg;
+	ops->read_rfreg = rtl8822b_read_rf_reg;
+	ops->write_rfreg = rtl8822b_write_rf_reg;
+	ops->read_wmmedca_reg = rtl8822b_read_wmmedca_reg;
+
+#ifdef CONFIG_HOSTAPD_MLME
+/*
+	ops->hostap_mgnt_xmit_entry = NULL;
+*/
+#endif
+/*
+	ops->EfusePowerSwitch = NULL;
+	ops->BTEfusePowerSwitch = NULL;
+	ops->ReadEFuse = NULL;
+	ops->EFUSEGetEfuseDefinition = NULL;
+	ops->EfuseGetCurrentSize = NULL;
+	ops->Efuse_PgPacketRead = NULL;
+	ops->Efuse_PgPacketWrite = NULL;
+	ops->Efuse_WordEnableDataWrite = NULL;
+	ops->Efuse_PgPacketWrite_BT = NULL;
+*/
+#ifdef DBG_CONFIG_ERROR_DETECT
+	ops->sreset_init_value = sreset_init_value;
+	ops->sreset_reset_value = sreset_reset_value;
+	ops->silentreset = sreset_reset;
+	ops->sreset_xmit_status_check = xmit_status_check;
+	ops->sreset_linked_status_check = linked_status_check;
+	ops->sreset_get_wifi_status = sreset_get_wifi_status;
+	ops->sreset_inprogress = sreset_inprogress;
+#endif /* DBG_CONFIG_ERROR_DETECT */
+
+#ifdef CONFIG_IOL
+/*
+	ops->IOL_exec_cmds_sync = NULL;
+*/
+#endif
+
+	ops->hal_notch_filter = rtl8822b_notch_filter_switch;
+	ops->hal_mac_c2h_handler = rtl8822b_c2h_handler;
+	ops->fill_h2c_cmd = rtl8822b_fillh2ccmd;
+	ops->fill_fake_txdesc = fill_fake_txdesc;
+	ops->fw_dl = rtl8822b_fw_dl;
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_PCI_HCI)
+/*
+	ops->clear_interrupt = NULL;
+*/
+#endif
+/*
+	ops->hal_get_tx_buff_rsvd_page_num = NULL;
+*/
+#ifdef CONFIG_GPIO_API
+/*
+	ops->update_hisr_hsisr_ind = NULL;
+*/
+#endif
+
+	ops->fw_correct_bcn = rtl8822b_fw_update_beacon_cmd;
+
+	/* HALMAC related functions */
+	ops->init_mac_register = rtl8822b_phy_init_mac_register;
+	ops->init_phy = rtl8822b_phy_init;
+	ops->reqtxrpt = rtl8822b_req_txrpt_cmd;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_phy.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_phy.c
new file mode 100644
index 000000000000..b83d129ea2dd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/rtl8822b_phy.c
@@ -0,0 +1,2319 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_PHY_C_
+
+#include <hal_data.h>		/* HAL_DATA_TYPE */
+#include "../hal_halmac.h"	/* rtw_halmac_phy_power_switch() */
+#include "rtl8822b.h"
+
+
+/*
+ * Description:
+ *	Initialize Register definition offset for Radio Path A/B/C/D
+ *	The initialization value is constant and it should never be changes
+ */
+static void bb_rf_register_definition(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	/* RF Interface Sowrtware Control */
+	hal->PHYRegDef[RF_PATH_A].rfintfs = rFPGA0_XAB_RFInterfaceSW;
+	hal->PHYRegDef[RF_PATH_B].rfintfs = rFPGA0_XAB_RFInterfaceSW;
+
+	/* RF Interface Output (and Enable) */
+	hal->PHYRegDef[RF_PATH_A].rfintfo = rFPGA0_XA_RFInterfaceOE;
+	hal->PHYRegDef[RF_PATH_B].rfintfo = rFPGA0_XB_RFInterfaceOE;
+
+	/* RF Interface (Output and) Enable */
+	hal->PHYRegDef[RF_PATH_A].rfintfe = rFPGA0_XA_RFInterfaceOE;
+	hal->PHYRegDef[RF_PATH_B].rfintfe = rFPGA0_XB_RFInterfaceOE;
+
+	hal->PHYRegDef[RF_PATH_A].rf3wireOffset = rA_LSSIWrite_Jaguar;
+	hal->PHYRegDef[RF_PATH_B].rf3wireOffset = rB_LSSIWrite_Jaguar;
+
+	hal->PHYRegDef[RF_PATH_A].rfHSSIPara2 = rHSSIRead_Jaguar;
+	hal->PHYRegDef[RF_PATH_B].rfHSSIPara2 = rHSSIRead_Jaguar;
+
+	/* Tranceiver Readback LSSI/HSPI mode */
+	hal->PHYRegDef[RF_PATH_A].rfLSSIReadBack = rA_SIRead_Jaguar;
+	hal->PHYRegDef[RF_PATH_B].rfLSSIReadBack = rB_SIRead_Jaguar;
+	hal->PHYRegDef[RF_PATH_A].rfLSSIReadBackPi = rA_PIRead_Jaguar;
+	hal->PHYRegDef[RF_PATH_B].rfLSSIReadBackPi = rB_PIRead_Jaguar;
+}
+
+/*
+ * Description:
+ *	Initialize MAC registers
+ *
+ * Return:
+ *	_TRUE	Success
+ *	_FALSE	Fail
+ */
+u8 rtl8822b_phy_init_mac_register(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	u8 ret = _TRUE;
+	int res;
+	enum hal_status status;
+
+
+	hal = GET_HAL_DATA(adapter);
+
+	ret = _FALSE;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	res = phy_ConfigMACWithParaFile(adapter, PHY_FILE_MAC_REG);
+	if (_SUCCESS == res)
+		ret = _TRUE;
+#endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
+	if (_FALSE == ret) {
+		status = odm_config_mac_with_header_file(&hal->odmpriv);
+		if (HAL_STATUS_SUCCESS == status)
+			ret = _TRUE;
+	}
+	if (_FALSE == ret)
+		RTW_INFO("%s: Write MAC Reg Fail!!", __FUNCTION__);
+
+	return ret;
+}
+
+static u8 _init_bb_reg(PADAPTER Adapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(Adapter);
+	u8 ret = _TRUE;
+	int res;
+	enum hal_status status;
+
+	/*
+	 * 1. Read PHY_REG.TXT BB INIT!!
+	 */
+	ret = _FALSE;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	res = phy_ConfigBBWithParaFile(Adapter, PHY_FILE_PHY_REG, CONFIG_BB_PHY_REG);
+	if (_SUCCESS == res)
+		ret = _TRUE;
+#endif
+	if (_FALSE == ret) {
+		status = odm_config_bb_with_header_file(&hal->odmpriv, CONFIG_BB_PHY_REG);
+		if (HAL_STATUS_SUCCESS == status)
+			ret = _TRUE;
+	}
+	if (_FALSE == ret) {
+		RTW_INFO("%s: Write BB Reg Fail!!", __FUNCTION__);
+		goto exit;
+	}
+
+#if 0 /* No parameter with MP using currently by BB@Stanley. */
+/*#ifdef CONFIG_MP_INCLUDED*/
+	if (Adapter->registrypriv.mp_mode == 1) {
+		/*
+		 * 1.1 Read PHY_REG_MP.TXT BB INIT!!
+		 */
+		ret = _FALSE;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+		res = phy_ConfigBBWithMpParaFile(Adapter, PHY_FILE_PHY_REG_MP);
+		if (_SUCCESS == res)
+			ret = _TRUE;
+#endif
+		if (_FALSE == ret) {
+			status = odm_config_bb_with_header_file(&hal->odmpriv, CONFIG_BB_PHY_REG_MP);
+			if (HAL_STATUS_SUCCESS == status)
+				ret = _TRUE;
+		}
+		if (_FALSE == ret) {
+			RTW_INFO("%s: Write BB Reg MP Fail!!", __FUNCTION__);
+			goto exit;
+		}
+	}
+#endif /* CONFIG_MP_INCLUDED */
+
+	/*
+	 * 2. Read BB AGC table Initialization
+	 */
+	ret = _FALSE;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	res = phy_ConfigBBWithParaFile(Adapter, PHY_FILE_AGC_TAB, CONFIG_BB_AGC_TAB);
+	if (_SUCCESS == res)
+		ret = _TRUE;
+#endif
+	if (_FALSE == ret) {
+		status = odm_config_bb_with_header_file(&hal->odmpriv, CONFIG_BB_AGC_TAB);
+		if (HAL_STATUS_SUCCESS == status)
+			ret = _TRUE;
+	}
+	if (_FALSE == ret) {
+		RTW_INFO("%s: Write AGC Table Fail!\n", __FUNCTION__);
+		goto exit;
+	}
+
+exit:
+	return ret;
+}
+
+static u8 init_bb_reg(PADAPTER adapter)
+{
+	u8 ret = _TRUE;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+
+	/*
+	 * Config BB and AGC
+	 */
+	ret = _init_bb_reg(adapter);
+
+	hal_set_crystal_cap(adapter, hal->crystal_cap);
+
+	return ret;
+}
+
+static u8 _init_rf_reg(PADAPTER adapter)
+{
+	u8 path;
+	enum rf_path phydm_path;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	u8 *regfile;
+#endif
+	enum hal_status status;
+	int res;
+	u8 ret = _TRUE;
+
+
+	/*
+	 * Initialize RF
+	 */
+	for (path = 0; path < hal->NumTotalRFPath; path++) {
+		/* Initialize RF from configuration file */
+		switch (path) {
+		case 0:
+			phydm_path = RF_PATH_A;
+			#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+			regfile = PHY_FILE_RADIO_A;
+			#endif
+			break;
+
+		case 1:
+			phydm_path = RF_PATH_B;
+			#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+			regfile = PHY_FILE_RADIO_B;
+			#endif
+			break;
+
+		default:
+			RTW_INFO("%s: [WARN] Unknown path=%d, skip!\n", __FUNCTION__, path);
+			continue;
+		}
+
+		ret = _FALSE;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+		res = PHY_ConfigRFWithParaFile(adapter, regfile, phydm_path);
+		if (_SUCCESS == res)
+			ret = _TRUE;
+#endif
+		if (_FALSE == ret) {
+			status = odm_config_rf_with_header_file(&hal->odmpriv, CONFIG_RF_RADIO, phydm_path);
+			if (HAL_STATUS_SUCCESS != status)
+				goto exit;
+			ret = _TRUE;
+		}
+	}
+
+	/*
+	 * Configuration of Tx Power Tracking
+	 */
+	ret = _FALSE;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	res = PHY_ConfigRFWithTxPwrTrackParaFile(adapter, PHY_FILE_TXPWR_TRACK);
+	if (_SUCCESS == res)
+		ret = _TRUE;
+#endif
+	if (_FALSE == ret) {
+		status = odm_config_rf_with_tx_pwr_track_header_file(&hal->odmpriv);
+		if (HAL_STATUS_SUCCESS != status) {
+			RTW_INFO("%s: Write PwrTrack Table Fail!\n", __FUNCTION__);
+			goto exit;
+		}
+		ret = _TRUE;
+	}
+
+exit:
+	return ret;
+}
+
+static u8 init_rf_reg(PADAPTER adapter)
+{
+	u8 ret = _TRUE;
+
+
+	ret = _init_rf_reg(adapter);
+
+	return ret;
+}
+
+/*
+ * Description:
+ *	Initialize PHY(BB/RF) related functions
+ *
+ * Return:
+ *	_TRUE	Success
+ *	_FALSE	Fail
+ */
+u8 rtl8822b_phy_init(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	struct dm_struct *phydm;
+	enum bb_path txpath = BB_PATH_A | BB_PATH_B;
+	enum bb_path rxpath = BB_PATH_A | BB_PATH_B;
+	BOOLEAN tx2path;
+	int err;
+	u8 ok = _TRUE;
+	BOOLEAN ret;
+
+
+	d = adapter_to_dvobj(adapter);
+	phydm = adapter_to_phydm(adapter);
+
+	bb_rf_register_definition(adapter);
+
+	err = rtw_halmac_phy_power_switch(d, _TRUE);
+	if (err)
+		return _FALSE;
+
+	ret = config_phydm_parameter_init_8822b(phydm, ODM_PRE_SETTING);
+	if (FALSE == ret)
+		return _FALSE;
+
+	ok = init_bb_reg(adapter);
+	if (_FALSE == ok)
+		return _FALSE;
+	ok = init_rf_reg(adapter);
+	if (_FALSE == ok)
+		return _FALSE;
+
+	ret = config_phydm_parameter_init_8822b(phydm, ODM_POST_SETTING);
+	if (FALSE == ret)
+		return _FALSE;
+
+	rtw_hal_get_rf_path(d, NULL, &txpath, &rxpath);
+	tx2path = FALSE;
+	ret = config_phydm_trx_mode_8822b(phydm, txpath, rxpath, tx2path);
+	if (FALSE == ret)
+		return _FALSE;
+
+	return _TRUE;
+}
+
+static void dm_CheckProtection(PADAPTER	adapter)
+{
+}
+
+#ifdef CONFIG_SUPPORT_HW_WPS_PBC
+static void dm_CheckPbcGPIO(PADAPTER adapter)
+{
+	u8 tmp1byte;
+	u8 bPbcPressed = _FALSE;
+
+	if (!adapter->registrypriv.hw_wps_pbc)
+		return;
+
+#ifdef CONFIG_USB_HCI
+	tmp1byte = rtw_read8(adapter, GPIO_IO_SEL);
+	tmp1byte |= (HAL_8192C_HW_GPIO_WPS_BIT);
+	rtw_write8(adapter, GPIO_IO_SEL, tmp1byte); /* enable GPIO[2] as output mode */
+
+	tmp1byte &= ~(HAL_8192C_HW_GPIO_WPS_BIT);
+	rtw_write8(adapter, GPIO_IN, tmp1byte); /* reset the floating voltage level */
+
+	tmp1byte = rtw_read8(adapter, GPIO_IO_SEL);
+	tmp1byte &= ~(HAL_8192C_HW_GPIO_WPS_BIT);
+	rtw_write8(adapter, GPIO_IO_SEL, tmp1byte); /* enable GPIO[2] as input mode */
+
+	tmp1byte = rtw_read8(adapter, GPIO_IN);
+	if (tmp1byte == 0xff)
+		return;
+
+	if (tmp1byte & HAL_8192C_HW_GPIO_WPS_BIT)
+		bPbcPressed = _TRUE;
+#else
+	tmp1byte = rtw_read8(adapter, GPIO_IN);
+
+	if ((tmp1byte == 0xff) || adapter->init_adpt_in_progress)
+		return;
+
+	if ((tmp1byte & HAL_8192C_HW_GPIO_WPS_BIT) == 0)
+		bPbcPressed = _TRUE;
+#endif
+
+	if (_TRUE == bPbcPressed) {
+		/*
+		 * Here we only set bPbcPressed to true
+		 * After trigger PBC, the variable will be set to false
+		 */
+		RTW_INFO("CheckPbcGPIO - PBC is pressed\n");
+		rtw_request_wps_pbc_event(adapter);
+	}
+}
+#endif /* CONFIG_SUPPORT_HW_WPS_PBC */
+
+
+#ifdef CONFIG_PCI_HCI
+/*
+ * Description:
+ *	Perform interrupt migration dynamically to reduce CPU utilization.
+ *
+ * Assumption:
+ *	1. Do not enable migration under WIFI test.
+ */
+void dm_InterruptMigration(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	BOOLEAN bCurrentIntMt, bCurrentACIntDisable;
+	BOOLEAN IntMtToSet = _FALSE;
+	BOOLEAN ACIntToSet = _FALSE;
+
+
+	/* Retrieve current interrupt migration and Tx four ACs IMR settings first. */
+	bCurrentIntMt = hal->bInterruptMigration;
+	bCurrentACIntDisable = hal->bDisableTxInt;
+
+	/*
+	 * <Roger_Notes> Currently we use busy traffic for reference instead of RxIntOK counts to prevent non-linear Rx statistics
+	 * when interrupt migration is set before. 2010.03.05.
+	 */
+	if (!adapter->registrypriv.wifi_spec
+	    && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+	    && pmlmepriv->LinkDetectInfo.bHigherBusyTraffic) {
+		IntMtToSet = _TRUE;
+
+		/* To check whether we should disable Tx interrupt or not. */
+		if (pmlmepriv->LinkDetectInfo.bHigherBusyRxTraffic)
+			ACIntToSet = _TRUE;
+	}
+
+	/* Update current settings. */
+	if (bCurrentIntMt != IntMtToSet) {
+		RTW_INFO("%s: Update interrupt migration(%d)\n", __FUNCTION__, IntMtToSet);
+		if (IntMtToSet) {
+			/*
+			 * <Roger_Notes> Set interrupt migration timer and corresponging Tx/Rx counter.
+			 * timer 25ns*0xfa0=100us for 0xf packets.
+			 * 2010.03.05.
+			 */
+			rtw_write32(adapter, REG_INT_MIG, 0xff000fa0); /* 0x306:Rx, 0x307:Tx */
+			hal->bInterruptMigration = IntMtToSet;
+		} else {
+			/* Reset all interrupt migration settings. */
+			rtw_write32(adapter, REG_INT_MIG, 0);
+			hal->bInterruptMigration = IntMtToSet;
+		}
+	}
+}
+#endif /* CONFIG_PCI_HCI */
+
+/*
+ * ============================================================
+ * functions
+ * ============================================================
+ */
+static void init_phydm_cominfo(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	struct dm_struct *p_dm_odm;
+	u32 support_ability = 0;
+	u8 cut_ver = ODM_CUT_A, fab_ver = ODM_TSMC;
+
+
+	hal = GET_HAL_DATA(adapter);
+	p_dm_odm = &hal->odmpriv;
+
+	Init_ODM_ComInfo(adapter);
+
+	odm_cmn_info_init(p_dm_odm, ODM_CMNINFO_PACKAGE_TYPE, hal->PackageType);
+	odm_cmn_info_init(p_dm_odm, ODM_CMNINFO_IC_TYPE, ODM_RTL8822B);
+
+	if (IS_CHIP_VENDOR_TSMC(hal->version_id))
+		fab_ver = ODM_TSMC;
+	else if (IS_CHIP_VENDOR_UMC(hal->version_id))
+		fab_ver = ODM_UMC;
+	else if (IS_CHIP_VENDOR_SMIC(hal->version_id))
+		fab_ver = ODM_UMC + 1;
+	else
+		RTW_INFO("%s: unknown fab_ver=%d !!\n",
+			 __FUNCTION__, GET_CVID_MANUFACTUER(hal->version_id));
+
+	if (IS_A_CUT(hal->version_id))
+		cut_ver = ODM_CUT_A;
+	else if (IS_B_CUT(hal->version_id))
+		cut_ver = ODM_CUT_B;
+	else if (IS_C_CUT(hal->version_id))
+		cut_ver = ODM_CUT_C;
+	else if (IS_D_CUT(hal->version_id))
+		cut_ver = ODM_CUT_D;
+	else if (IS_E_CUT(hal->version_id))
+		cut_ver = ODM_CUT_E;
+	else if (IS_F_CUT(hal->version_id))
+		cut_ver = ODM_CUT_F;
+	else if (IS_I_CUT(hal->version_id))
+		cut_ver = ODM_CUT_I;
+	else if (IS_J_CUT(hal->version_id))
+		cut_ver = ODM_CUT_J;
+	else if (IS_K_CUT(hal->version_id))
+		cut_ver = ODM_CUT_K;
+	else
+		RTW_INFO("%s: unknown cut_ver=%d !!\n",
+			 __FUNCTION__, GET_CVID_CUT_VERSION(hal->version_id));
+
+	RTW_INFO("%s: fab_ver=%d cut_ver=%d\n", __FUNCTION__, fab_ver, cut_ver);
+	odm_cmn_info_init(p_dm_odm, ODM_CMNINFO_FAB_VER, fab_ver);
+	odm_cmn_info_init(p_dm_odm, ODM_CMNINFO_CUT_VER, cut_ver);
+
+}
+
+void rtl8822b_phy_init_dm_priv(PADAPTER adapter)
+{
+	struct dm_struct *podmpriv = adapter_to_phydm(adapter);
+
+	init_phydm_cominfo(adapter);
+	odm_init_all_timers(podmpriv);
+}
+
+void rtl8822b_phy_deinit_dm_priv(PADAPTER adapter)
+{
+	struct dm_struct *podmpriv = adapter_to_phydm(adapter);
+
+	odm_cancel_all_timers(podmpriv);
+}
+
+void rtl8822b_phy_init_haldm(PADAPTER adapter)
+{
+	rtw_phydm_init(adapter);
+}
+
+static void check_rxfifo_full(PADAPTER adapter)
+{
+	struct dvobj_priv *psdpriv = adapter->dvobj;
+	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	struct registry_priv *regsty = &adapter->registrypriv;
+	u8 val8 = 0;
+
+	if (regsty->check_hw_status == 1) {
+		/* switch counter to RX fifo */
+		val8 = rtw_read8(adapter, REG_RXERR_RPT_8822B + 3);
+		rtw_write8(adapter, REG_RXERR_RPT_8822B + 3, (val8 | 0xa0));
+
+		pdbgpriv->dbg_rx_fifo_last_overflow = pdbgpriv->dbg_rx_fifo_curr_overflow;
+		pdbgpriv->dbg_rx_fifo_curr_overflow = rtw_read16(adapter, REG_RXERR_RPT_8822B);
+		pdbgpriv->dbg_rx_fifo_diff_overflow =
+			pdbgpriv->dbg_rx_fifo_curr_overflow - pdbgpriv->dbg_rx_fifo_last_overflow;
+	}
+}
+
+void rtl8822b_phy_haldm_watchdog(PADAPTER adapter)
+{
+	BOOLEAN bFwCurrentInPSMode = _FALSE;
+	u8 bFwPSAwake = _TRUE;
+
+#ifdef CONFIG_MP_INCLUDED
+	/* for MP power tracking */
+	if ((adapter->registrypriv.mp_mode == 1)
+	    && (adapter->mppriv.mp_dm == 0))
+		return;
+#endif /* CONFIG_MP_INCLUDED */
+
+	if (!rtw_is_hw_init_completed(adapter))
+		goto skip_dm;
+
+#ifdef CONFIG_LPS
+	bFwCurrentInPSMode = adapter_to_pwrctl(adapter)->bFwCurrentInPSMode;
+	rtw_hal_get_hwreg(adapter, HW_VAR_FWLPS_RF_ON, &bFwPSAwake);
+#endif /* CONFIG_LPS */
+
+#ifdef CONFIG_P2P_PS
+	/*
+	 * Fw is under p2p powersaving mode, driver should stop dynamic mechanism.
+	 */
+	if (adapter->wdinfo.p2p_ps_mode)
+		bFwPSAwake = _FALSE;
+#endif /* CONFIG_P2P_PS */
+
+	if ((rtw_is_hw_init_completed(adapter))
+	    && ((!bFwCurrentInPSMode) && bFwPSAwake)) {
+
+		/* check rx fifo */
+		check_rxfifo_full(adapter);
+		/*
+		 * Dynamically switch RTS/CTS protection.
+		 */
+		dm_CheckProtection(adapter);
+	}
+
+#ifdef CONFIG_DISABLE_ODM
+	goto skip_dm;
+#endif
+	rtw_phydm_watchdog(adapter);
+
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+	if (check_fwstate(&adapter->mlmepriv, WIFI_STATION_STATE) &&
+			check_fwstate(&adapter->mlmepriv, _FW_LINKED))
+		rtw_hal_beamforming_config_csirate(adapter);
+#endif
+#endif
+
+skip_dm:
+	/*
+	 * Check GPIO to determine current RF on/off and Pbc status.
+	 * Check Hardware Radio ON/OFF or not
+	 */
+#ifdef CONFIG_SUPPORT_HW_WPS_PBC
+	dm_CheckPbcGPIO(adapter);
+#else /* !CONFIG_SUPPORT_HW_WPS_PBC */
+	return;
+#endif /* !CONFIG_SUPPORT_HW_WPS_PBC */
+}
+
+static u32 phy_calculatebitshift(u32 mask)
+{
+	u32 i;
+
+
+	for (i = 0; i <= 31; i++)
+		if (mask & BIT(i))
+			break;
+
+	return i;
+}
+
+u32 rtl8822b_read_bb_reg(PADAPTER adapter, u32 addr, u32 mask)
+{
+	u32 val = 0, val_org, shift;
+
+
+#if (DISABLE_BB_RF == 1)
+	return 0;
+#endif
+
+	val_org = rtw_read32(adapter, addr);
+	shift = phy_calculatebitshift(mask);
+	val = (val_org & mask) >> shift;
+
+	return val;
+}
+
+void rtl8822b_write_bb_reg(PADAPTER adapter, u32 addr, u32 mask, u32 val)
+{
+	u32 val_org, shift;
+
+
+#if (DISABLE_BB_RF == 1)
+	return;
+#endif
+
+	if (mask != 0xFFFFFFFF) {
+		/* not "double word" write */
+		val_org = rtw_read32(adapter, addr);
+		shift = phy_calculatebitshift(mask);
+		val = ((val_org & (~mask)) | ((val << shift) & mask));
+	}
+
+	rtw_write32(adapter, addr, val);
+}
+
+u32 rtl8822b_read_rf_reg(PADAPTER adapter, enum rf_path path, u32 addr, u32 mask)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	u32 val;
+
+	val = config_phydm_read_rf_reg_8822b(phydm, path, addr, mask);
+	if (!config_phydm_read_rf_check_8822b(val))
+		RTW_INFO(FUNC_ADPT_FMT ": read RF reg path=%d addr=0x%x mask=0x%x FAIL!\n",
+			 FUNC_ADPT_ARG(adapter), path, addr, mask);
+
+	return val;
+}
+
+void rtl8822b_write_rf_reg(PADAPTER adapter, enum rf_path path, u32 addr, u32 mask, u32 val)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	u8 ret;
+
+	ret = config_phydm_write_rf_reg_8822b(phydm, path, addr, mask, val);
+	if (_FALSE == ret)
+		RTW_INFO(FUNC_ADPT_FMT ": write RF reg path=%d addr=0x%x mask=0x%x val=0x%x FAIL!\n",
+			 FUNC_ADPT_ARG(adapter), path, addr, mask, val);
+}
+
+static void set_tx_power_level_by_path(PADAPTER adapter, u8 channel, u8 path)
+{
+	phy_set_tx_power_index_by_rate_section(adapter, path, channel, CCK);
+	phy_set_tx_power_index_by_rate_section(adapter, path, channel, OFDM);
+	phy_set_tx_power_index_by_rate_section(adapter, path, channel, HT_MCS0_MCS7);
+	phy_set_tx_power_index_by_rate_section(adapter, path, channel, HT_MCS8_MCS15);
+	phy_set_tx_power_index_by_rate_section(adapter, path, channel, VHT_1SSMCS0_1SSMCS9);
+	phy_set_tx_power_index_by_rate_section(adapter, path, channel, VHT_2SSMCS0_2SSMCS9);
+}
+
+void rtl8822b_set_tx_power_level(PADAPTER adapter, u8 channel)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm;
+	struct phydm_fat_struct *p_dm_fat_table;
+	u8 path = RF_PATH_A;
+
+
+	hal = GET_HAL_DATA(adapter);
+	phydm = &hal->odmpriv;
+	p_dm_fat_table = &phydm->dm_fat_table;
+
+	if (hal->AntDivCfg) {
+		/* antenna diversity Enable */
+		path = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? RF_PATH_A : RF_PATH_B;
+		set_tx_power_level_by_path(adapter, channel, path);
+	} else {
+		/* antenna diversity disable */
+		for (path = RF_PATH_A; path < hal->NumTotalRFPath; ++path)
+			set_tx_power_level_by_path(adapter, channel, path);
+	}
+}
+
+void rtl8822b_get_tx_power_level(PADAPTER adapter, s32 *power)
+{
+}
+
+/*
+ * Parameters:
+ *	padatper
+ *	powerindex	power index for rate
+ *	rfpath		Antenna(RF) path, type "enum rf_path"
+ *	rate		data rate, type "enum MGN_RATE"
+ */
+void rtl8822b_set_tx_power_index(PADAPTER adapter, u32 powerindex, enum rf_path rfpath, u8 rate)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	u8 shift = 0;
+	static u32 index = 0;
+
+
+	rate = PHY_GetRateIndexOfTxPowerByRate(rate);
+
+	/*
+	* For 8822B, phydm api use 4 bytes txagc value
+	* driver must combine every four 1 byte to one 4 byte and send to phydm api
+	*/
+	shift = rate % 4;
+	index |= ((powerindex & 0xff) << (shift * 8));
+
+	if (shift == 3) {
+		rate = rate - 3;
+
+		if (!config_phydm_write_txagc_8822b(phydm, index, rfpath, rate)) {
+			RTW_INFO("%s(index:%d, rfpath:%d, rate:0x%02x, disable api:%d) fail\n",
+				__FUNCTION__, index, rfpath, rate, phydm->is_disable_phy_api);
+
+			rtw_warn_on(1);
+		}
+		index = 0;
+	}
+}
+
+static u8 rtl8822b_phy_get_current_tx_num(PADAPTER adapter, u8 rate)
+{
+	u8 tx_num = 0;
+
+	if ((rate >= MGN_MCS8 && rate <= MGN_MCS15) ||
+	    (rate >= MGN_VHT2SS_MCS0 && rate <= MGN_VHT2SS_MCS9))
+		tx_num = RF_2TX;
+	else
+		tx_num = RF_1TX;
+
+	return tx_num;
+}
+
+/*
+ * Parameters:
+ *	padatper
+ *	rfpath		Antenna(RF) path, type "enum rf_path"
+ *	rate		data rate, type "enum MGN_RATE"
+ *	bandwidth	Bandwidth, type "enum _CHANNEL_WIDTH"
+ *	channel		Channel number
+ *
+ * Rteurn:
+ *	tx_power	power index for rate
+ */
+u8 rtl8822b_get_tx_power_index(PADAPTER adapter, enum rf_path rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	s16 power_idx;
+	u8 base_idx = 0;
+	s8 by_rate_diff = 0, limit = 0, tpt_offset = 0, extra_bias = 0;
+	u8 ntx_idx = rtl8822b_phy_get_current_tx_num(adapter, rate);
+	u8 bIn24G = _FALSE;
+
+	base_idx = PHY_GetTxPowerIndexBase(adapter, rfpath, rate, ntx_idx, bandwidth, channel, &bIn24G);
+
+	by_rate_diff = PHY_GetTxPowerByRate(adapter, (u8)(!bIn24G), rfpath, rate);
+	limit = PHY_GetTxPowerLimit(adapter, NULL, (BAND_TYPE)(!bIn24G),
+			hal->current_channel_bw, rfpath, rate, ntx_idx, hal->current_channel);
+
+	/* tpt_offset += PHY_GetTxPowerTrackingOffset(adapter, rfpath, rate); */
+
+	if (tic) {
+		tic->ntx_idx = ntx_idx;
+		tic->base = base_idx;
+		tic->by_rate = by_rate_diff;
+		tic->limit = limit;
+		tic->tpt = tpt_offset;
+		tic->ebias = extra_bias;
+	}
+
+	by_rate_diff = by_rate_diff > limit ? limit : by_rate_diff;
+	power_idx = base_idx + by_rate_diff + tpt_offset + extra_bias;
+
+#if 0
+#if CCX_SUPPORT
+	CCX_CellPowerLimit(adapter, channel, rate, (pu1Byte)&power_idx);
+#endif
+#endif
+
+	if (power_idx < 0)
+		power_idx = 0;
+	else if (power_idx > MAX_POWER_INDEX)
+		power_idx = MAX_POWER_INDEX;
+
+	return power_idx;
+}
+
+/*
+ * Description:
+ *	Check need to switch band or not
+ * Parameters:
+ *	channelToSW	channel wiii be switch to
+ * Return:
+ *	_TRUE		need to switch band
+ *	_FALSE		not need to switch band
+ */
+static u8 need_switch_band(PADAPTER adapter, u8 channelToSW)
+{
+	u8 u1tmp = 0;
+	u8 ret_value = _TRUE;
+	u8 Band = BAND_ON_5G, BandToSW = BAND_ON_5G;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+	Band = hal->current_band_type;
+
+	/* Use current swich channel to judge Band Type and switch Band if need */
+	if (channelToSW > 14)
+		BandToSW = BAND_ON_5G;
+	else
+		BandToSW = BAND_ON_2_4G;
+
+	if (BandToSW != Band) {
+		/* record current band type for other hal use */
+		hal->current_band_type = (BAND_TYPE)BandToSW;
+		ret_value = _TRUE;
+	} else
+		ret_value = _FALSE;
+
+	return ret_value;
+}
+
+static u8 get_pri_ch_id(PADAPTER adapter)
+{
+	u8 pri_ch_idx = 0;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+	if (hal->current_channel_bw == CHANNEL_WIDTH_80) {
+		/* primary channel is at lower subband of 80MHz & 40MHz */
+		if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER))
+			pri_ch_idx = VHT_DATA_SC_20_LOWEST_OF_80MHZ;
+		/* primary channel is at lower subband of 80MHz & upper subband of 40MHz */
+		else if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER))
+			pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+		/* primary channel is at upper subband of 80MHz & lower subband of 40MHz */
+		else if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER))
+			pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+		/* primary channel is at upper subband of 80MHz & upper subband of 40MHz */
+		else if ((hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER) && (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER))
+			pri_ch_idx = VHT_DATA_SC_20_UPPERST_OF_80MHZ;
+		else {
+			if (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER)
+				pri_ch_idx = VHT_DATA_SC_40_LOWER_OF_80MHZ;
+			else if (hal->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER)
+				pri_ch_idx = VHT_DATA_SC_40_UPPER_OF_80MHZ;
+			else
+				RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+		}
+	} else if (hal->current_channel_bw == CHANNEL_WIDTH_40) {
+		/* primary channel is at upper subband of 40MHz */
+		if (hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER)
+			pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+		/* primary channel is at lower subband of 40MHz */
+		else if (hal->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER)
+			pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+		else
+			RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+	}
+
+	return  pri_ch_idx;
+}
+
+static void mac_switch_bandwidth(PADAPTER adapter, u8 pri_ch_idx)
+{
+	u8 channel = 0, bw = 0;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	int err;
+
+	channel = hal->current_channel;
+	bw = hal->current_channel_bw;
+	err = rtw_halmac_set_bandwidth(adapter_to_dvobj(adapter), channel, pri_ch_idx, bw);
+	if (err) {
+		RTW_INFO(FUNC_ADPT_FMT ": (channel=%d, pri_ch_idx=%d, bw=%d) fail\n",
+			 FUNC_ADPT_ARG(adapter), channel, pri_ch_idx, bw);
+	}
+}
+
+static void switch_chnl_and_set_bw_by_drv(PADAPTER adapter, u8 switch_band)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct dm_struct *p_dm_odm = &hal->odmpriv;
+	u8 center_ch = 0, ret = 0;
+
+	/* set channel & Bandwidth register */
+	/* 1. set switch band register if need to switch band */
+	if (switch_band) {
+		/* hal->current_channel is center channel of pmlmeext->cur_channel(primary channel) */
+		ret = config_phydm_switch_band_8822b(p_dm_odm, hal->current_channel);
+
+		if (!ret) {
+			RTW_INFO("%s: config_phydm_switch_band_8822b fail\n", __FUNCTION__);
+			rtw_warn_on(1);
+			return;
+		}
+	}
+
+	/* 2. set channel register */
+	if (hal->bSwChnl) {
+		ret = config_phydm_switch_channel_8822b(p_dm_odm, hal->current_channel);
+		hal->bSwChnl = _FALSE;
+
+		if (!ret) {
+			RTW_INFO("%s: config_phydm_switch_channel_8822b fail\n", __FUNCTION__);
+			rtw_warn_on(1);
+			return;
+		}
+	}
+
+	/* 3. set Bandwidth register */
+	if (hal->bSetChnlBW) {
+		/* get primary channel index */
+		u8 pri_ch_idx = get_pri_ch_id(adapter);
+
+		/* 3.1 set MAC register */
+		mac_switch_bandwidth(adapter, pri_ch_idx);
+
+		/* 3.2 set BB/RF registet */
+		ret = config_phydm_switch_bandwidth_8822b(p_dm_odm, pri_ch_idx, hal->current_channel_bw);
+		hal->bSetChnlBW = _FALSE;
+
+		if (!ret) {
+			RTW_INFO("%s: config_phydm_switch_bandwidth_8822b fail\n", __FUNCTION__);
+			rtw_warn_on(1);
+			return;
+		}
+	}
+}
+
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+static void switch_chnl_and_set_bw_by_fw(PADAPTER adapter, u8 switch_band)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+
+	if (switch_band ||hal->bSwChnl || hal->bSetChnlBW) {
+		rtw_hal_switch_chnl_and_set_bw_offload(adapter,
+			hal->current_channel, get_pri_ch_id(adapter), hal->current_channel_bw);
+
+		hal->bSwChnl = _FALSE;
+		hal->bSetChnlBW = _FALSE;
+	}
+}
+#endif
+
+/*
+ * Description:
+ *	Set channel & bandwidth & offset
+ */
+void rtl8822b_switch_chnl_and_set_bw(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct dm_struct *p_dm_odm = &hal->odmpriv;
+	u8 center_ch = 0, ret = 0, switch_band = _FALSE;
+
+	if (adapter->bNotifyChannelChange) {
+		RTW_INFO("[%s] bSwChnl=%d, ch=%d, bSetChnlBW=%d, bw=%d\n",
+			 __FUNCTION__,
+			 hal->bSwChnl,
+			 hal->current_channel,
+			 hal->bSetChnlBW,
+			 hal->current_channel_bw);
+	}
+
+	if (RTW_CANNOT_RUN(adapter)) {
+		hal->bSwChnlAndSetBWInProgress = _FALSE;
+		return;
+	}
+
+	switch_band = need_switch_band(adapter, hal->current_channel);
+
+	/* config channel, bw, offset setting */
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+	if (hal->ch_switch_offload)
+		switch_chnl_and_set_bw_by_fw(adapter, switch_band);
+
+	else
+		switch_chnl_and_set_bw_by_drv(adapter, switch_band);
+#else
+	switch_chnl_and_set_bw_by_drv(adapter, switch_band);
+#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+
+
+	/* config coex setting */
+	if (switch_band) {
+#ifdef CONFIG_BT_COEXIST
+		if (hal->EEPROMBluetoothCoexist) {
+			struct mlme_ext_priv *mlmeext;
+
+			/* switch band under site survey or not, must notify to BT COEX */
+			mlmeext = &adapter->mlmeextpriv;
+			if (mlmeext_scan_state(mlmeext) != SCAN_DISABLE)
+				rtw_btcoex_switchband_notify(_TRUE, hal->current_band_type);
+			else
+				rtw_btcoex_switchband_notify(_FALSE, hal->current_band_type);
+		} else
+			rtw_btcoex_wifionly_switchband_notify(adapter);
+#else /* !CONFIG_BT_COEXIST */
+		rtw_btcoex_wifionly_switchband_notify(adapter);
+#endif /* CONFIG_BT_COEXIST */
+	}
+
+	/* <2016/03/09> ** This Setting is for MP Driver Only*/
+#ifdef CONFIG_MP_INCLUDED
+	if (adapter->registrypriv.mp_mode == _TRUE) {
+		/* <2016/02/25, VincentL> Add for 8822B Antenna Binding between "2.4G-WiFi"
+			And between "5G-BT", Suggested by RF SzuyiTsai*/
+		if (hal->current_channel <= 14) /* 2.4G*/
+			phy_set_rf_path_switch_8822b(p_dm_odm, 1); /*To WiFi-2.4G*/
+		else /* 5G */
+			phy_set_rf_path_switch_8822b(p_dm_odm, 0); /*To BT-5G*/
+	}
+#endif
+
+	phydm_config_kfree(p_dm_odm, hal->current_channel);
+
+	/* TX Power Setting */
+	odm_clear_txpowertracking_state(p_dm_odm);
+	rtw_hal_set_tx_power_level(adapter, hal->current_channel);
+
+	/* IQK */
+	if ((hal->bNeedIQK == _TRUE)
+	    || (adapter->registrypriv.mp_mode == 1)) {
+		/*phy_iq_calibrate_8822b(p_dm_odm, _FALSE);*/
+		rtw_phydm_iqk_trigger(adapter);
+		hal->bNeedIQK = _FALSE;
+	}
+}
+
+/*
+ * Description:
+ *	Store channel setting to hal date
+ * Parameters:
+ *	bSwitchChannel		swith channel or not
+ *	bSetBandWidth		set band or not
+ *	ChannelNum		center channel
+ *	ChnlWidth		bandwidth
+ *	ChnlOffsetOf40MHz	channel offset for 40MHz Bandwidth
+ *	ChnlOffsetOf80MHz	channel offset for 80MHz Bandwidth
+ *	CenterFrequencyIndex1	center channel index
+ */
+
+void rtl8822b_handle_sw_chnl_and_set_bw(
+	PADAPTER Adapter, u8 bSwitchChannel, u8 bSetBandWidth,
+	u8 ChannelNum, enum channel_width ChnlWidth, u8 ChnlOffsetOf40MHz,
+	u8 ChnlOffsetOf80MHz, u8 CenterFrequencyIndex1)
+{
+	PADAPTER pDefAdapter = GetDefaultAdapter(Adapter);
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(pDefAdapter);
+	u8 tmpChannel = hal->current_channel;
+	enum channel_width tmpBW = hal->current_channel_bw;
+	u8 tmpnCur40MhzPrimeSC = hal->nCur40MhzPrimeSC;
+	u8 tmpnCur80MhzPrimeSC = hal->nCur80MhzPrimeSC;
+	u8 tmpCenterFrequencyIndex1 = hal->CurrentCenterFrequencyIndex1;
+	struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
+
+
+	/* check swchnl or setbw */
+	if (!bSwitchChannel && !bSetBandWidth) {
+		RTW_INFO("%s: not switch channel and not set bandwidth\n", __FUNCTION__);
+		return;
+	}
+
+	/* skip switch channel operation for current channel & ChannelNum(will be switch) are the same */
+	if (bSwitchChannel) {
+		if (hal->current_channel != ChannelNum) {
+			if (HAL_IsLegalChannel(Adapter, ChannelNum))
+				hal->bSwChnl = _TRUE;
+			else
+				return;
+		}
+	}
+
+	/* check set BandWidth */
+	if (bSetBandWidth) {
+		/* initial channel bw setting */
+		if (hal->bChnlBWInitialized == _FALSE) {
+			hal->bChnlBWInitialized = _TRUE;
+			hal->bSetChnlBW = _TRUE;
+		} else if ((hal->current_channel_bw != ChnlWidth) || /* check whether need set band or not */
+			   (hal->nCur40MhzPrimeSC != ChnlOffsetOf40MHz) ||
+			   (hal->nCur80MhzPrimeSC != ChnlOffsetOf80MHz) ||
+			(hal->CurrentCenterFrequencyIndex1 != CenterFrequencyIndex1))
+			hal->bSetChnlBW = _TRUE;
+	}
+
+	/* return if not need set bandwidth nor channel after check*/
+	if (!hal->bSetChnlBW && !hal->bSwChnl && hal->bNeedIQK != _TRUE)
+		return;
+
+	/* set channel number to hal data */
+	if (hal->bSwChnl) {
+		hal->current_channel = ChannelNum;
+		hal->CurrentCenterFrequencyIndex1 = ChannelNum;
+	}
+
+	/* set bandwidth info to hal data */
+	if (hal->bSetChnlBW) {
+		hal->current_channel_bw = ChnlWidth;
+		hal->nCur40MhzPrimeSC = ChnlOffsetOf40MHz;
+		hal->nCur80MhzPrimeSC = ChnlOffsetOf80MHz;
+		hal->CurrentCenterFrequencyIndex1 = CenterFrequencyIndex1;
+	}
+
+	/* switch channel & bandwidth */
+	if (!RTW_CANNOT_RUN(Adapter))
+		rtl8822b_switch_chnl_and_set_bw(Adapter);
+	else {
+		if (hal->bSwChnl) {
+			hal->current_channel = tmpChannel;
+			hal->CurrentCenterFrequencyIndex1 = tmpChannel;
+		}
+
+		if (hal->bSetChnlBW) {
+			hal->current_channel_bw = tmpBW;
+			hal->nCur40MhzPrimeSC = tmpnCur40MhzPrimeSC;
+			hal->nCur80MhzPrimeSC = tmpnCur80MhzPrimeSC;
+			hal->CurrentCenterFrequencyIndex1 = tmpCenterFrequencyIndex1;
+		}
+	}
+}
+
+/*
+ * Description:
+ *	Change channel, bandwidth & offset
+ * Parameters:
+ *	center_ch	center channel
+ *	bw		bandwidth
+ *	offset40	channel offset for 40MHz Bandwidth
+ *	offset80	channel offset for 80MHz Bandwidth
+ */
+void rtl8822b_set_channel_bw(PADAPTER adapter, u8 center_ch, enum channel_width bw, u8 offset40, u8 offset80)
+{
+	rtl8822b_handle_sw_chnl_and_set_bw(adapter, _TRUE, _TRUE, center_ch, bw, offset40, offset80, center_ch);
+}
+
+void rtl8822b_notch_filter_switch(PADAPTER adapter, bool enable)
+{
+	if (enable)
+		RTW_INFO("%s: Enable notch filter\n", __FUNCTION__);
+	else
+		RTW_INFO("%s: Disable notch filter\n", __FUNCTION__);
+}
+
+#ifdef CONFIG_MP_INCLUDED
+/*
+ * Description:
+ *	Config RF path
+ *
+ * Parameters:
+ *	adapter	pointer of struct _ADAPTER
+ */
+void rtl8822b_mp_config_rfpath(PADAPTER adapter)
+{
+	PHAL_DATA_TYPE hal;
+	PMPT_CONTEXT mpt;
+	ANTENNA_PATH anttx, antrx;
+	enum bb_path bb_tx, bb_rx;
+
+
+	hal = GET_HAL_DATA(adapter);
+	mpt = &adapter->mppriv.mpt_ctx;
+	anttx = hal->antenna_tx_path;
+	antrx = hal->AntennaRxPath;
+	hal->antenna_test = _TRUE;
+	RTW_INFO("+Config RF Path, tx=0x%x rx=0x%x\n", anttx, antrx);
+
+	switch (anttx) {
+	case ANTENNA_A:
+		mpt->mpt_rf_path = RF_PATH_A;
+		bb_tx = BB_PATH_A;
+		break;
+	case ANTENNA_B:
+		mpt->mpt_rf_path = RF_PATH_B;
+		bb_tx = BB_PATH_B;
+		break;
+	case ANTENNA_AB:
+	default:
+		mpt->mpt_rf_path = RF_PATH_AB;
+		bb_tx = BB_PATH_A | BB_PATH_B;
+		break;
+	}
+
+	switch (antrx) {
+	case ANTENNA_A:
+		bb_rx = BB_PATH_A;
+		break;
+	case ANTENNA_B:
+		bb_rx = BB_PATH_B;
+		break;
+	case ANTENNA_AB:
+	default:
+		bb_rx = BB_PATH_A | BB_PATH_B;
+		break;
+	}
+
+	config_phydm_trx_mode_8822b(GET_PDM_ODM(adapter), bb_tx, bb_rx, FALSE);
+
+	RTW_INFO("-Config RF Path Finish\n");
+}
+#endif /* CONFIG_MP_INCLUDED */
+
+#ifdef CONFIG_BEAMFORMING
+/* REG_TXBF_CTRL		(Offset 0x42C) */
+#define BITS_R_TXBF1_AID_8822B			(BIT_MASK_R_TXBF1_AID_8822B << BIT_SHIFT_R_TXBF1_AID_8822B)
+#define BIT_CLEAR_R_TXBF1_AID_8822B(x)		((x) & (~BITS_R_TXBF1_AID_8822B))
+#define BIT_SET_R_TXBF1_AID_8822B(x, v)		(BIT_CLEAR_R_TXBF1_AID_8822B(x) | BIT_R_TXBF1_AID_8822B(v))
+
+#define BITS_R_TXBF0_AID_8822B			(BIT_MASK_R_TXBF0_AID_8822B << BIT_SHIFT_R_TXBF0_AID_8822B)
+#define BIT_CLEAR_R_TXBF0_AID_8822B(x)		((x) & (~BITS_R_TXBF0_AID_8822B))
+#define BIT_SET_R_TXBF0_AID_8822B(x, v)		(BIT_CLEAR_R_TXBF0_AID_8822B(x) | BIT_R_TXBF0_AID_8822B(v))
+
+/* REG_NDPA_OPT_CTRL		(Offset 0x45F) */
+#define BITS_R_NDPA_BW_8822B			(BIT_MASK_R_NDPA_BW_8822B << BIT_SHIFT_R_NDPA_BW_8822B)
+#define BIT_CLEAR_R_NDPA_BW_8822B(x)		((x) & (~BITS_R_NDPA_BW_8822B))
+#define BIT_SET_R_NDPA_BW_8822B(x, v)		(BIT_CLEAR_R_NDPA_BW_8822B(x) | BIT_R_NDPA_BW_8822B(v))
+
+/* REG_ASSOCIATED_BFMEE_SEL	(Offset 0x714) */
+#define BITS_AID1_8822B				(BIT_MASK_AID1_8822B << BIT_SHIFT_AID1_8822B)
+#define BIT_CLEAR_AID1_8822B(x)			((x) & (~BITS_AID1_8822B))
+#define BIT_SET_AID1_8822B(x, v)		(BIT_CLEAR_AID1_8822B(x) | BIT_AID1_8822B(v))
+
+#define BITS_AID0_8822B				(BIT_MASK_AID0_8822B << BIT_SHIFT_AID0_8822B)
+#define BIT_CLEAR_AID0_8822B(x)			((x) & (~BITS_AID0_8822B))
+#define BIT_SET_AID0_8822B(x, v)		(BIT_CLEAR_AID0_8822B(x) | BIT_AID0_8822B(v))
+
+/* REG_SND_PTCL_CTRL		(Offset 0x718) */
+#define BIT_VHTNDP_RPTPOLL_CSI_STR_OFFSET_SEL_8822B	BIT(15)
+
+/* REG_MU_TX_CTL		(Offset 0x14C0) */
+#define BIT_R_MU_P1_WAIT_STATE_EN_8822B		BIT(16)
+
+#define BIT_SHIFT_R_MU_RL_8822B			12
+#define BIT_MASK_R_MU_RL_8822B			0xF
+#define BITS_R_MU_RL_8822B			(BIT_MASK_R_MU_RL_8822B << BIT_SHIFT_R_MU_RL_8822B)
+#define BIT_R_MU_RL_8822B(x)			(((x) & BIT_MASK_R_MU_RL_8822B) << BIT_SHIFT_R_MU_RL_8822B)
+#define BIT_CLEAR_R_MU_RL_8822B(x)		((x) & (~BITS_R_MU_RL_8822B))
+#define BIT_SET_R_MU_RL_8822B(x, v)		(BIT_CLEAR_R_MU_RL_8822B(x) | BIT_R_MU_RL_8822B(v))
+
+#define BIT_SHIFT_R_MU_TAB_SEL_8822B		8
+#define BIT_MASK_R_MU_TAB_SEL_8822B		0x7
+#define BITS_R_MU_TAB_SEL_8822B			(BIT_MASK_R_MU_TAB_SEL_8822B << BIT_SHIFT_R_MU_TAB_SEL_8822B)
+#define BIT_R_MU_TAB_SEL_8822B(x)		(((x) & BIT_MASK_R_MU_TAB_SEL_8822B) << BIT_SHIFT_R_MU_TAB_SEL_8822B)
+#define BIT_CLEAR_R_MU_TAB_SEL_8822B(x)		((x) & (~BITS_R_MU_TAB_SEL_8822B))
+#define BIT_SET_R_MU_TAB_SEL_8822B(x, v)	(BIT_CLEAR_R_MU_TAB_SEL_8822B(x) | BIT_R_MU_TAB_SEL_8822B(v))
+
+#define BIT_R_EN_MU_MIMO_8822B			BIT(7)
+
+#define BITS_R_MU_TABLE_VALID_8822B		(BIT_MASK_R_MU_TABLE_VALID_8822B << BIT_SHIFT_R_MU_TABLE_VALID_8822B)
+#define BIT_CLEAR_R_MU_TABLE_VALID_8822B(x)	((x) & (~BITS_R_MU_TABLE_VALID_8822B))
+#define BIT_SET_R_MU_TABLE_VALID_8822B(x, v)	(BIT_CLEAR_R_MU_TABLE_VALID_8822B(x) | BIT_R_MU_TABLE_VALID_8822B(v))
+
+/* REG_WMAC_MU_BF_CTL		(Offset 0x1680) */
+#define BITS_WMAC_MU_BFRPTSEG_SEL_8822B			(BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822B << BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822B)
+#define BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8822B(x)		((x) & (~BITS_WMAC_MU_BFRPTSEG_SEL_8822B))
+#define BIT_SET_WMAC_MU_BFRPTSEG_SEL_8822B(x, v)	(BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8822B(x) | BIT_WMAC_MU_BFRPTSEG_SEL_8822B(v))
+
+#define BITS_WMAC_MU_BF_MYAID_8822B		(BIT_MASK_WMAC_MU_BF_MYAID_8822B << BIT_SHIFT_WMAC_MU_BF_MYAID_8822B)
+#define BIT_CLEAR_WMAC_MU_BF_MYAID_8822B(x)	((x) & (~BITS_WMAC_MU_BF_MYAID_8822B))
+#define BIT_SET_WMAC_MU_BF_MYAID_8822B(x, v)	(BIT_CLEAR_WMAC_MU_BF_MYAID_8822B(x) | BIT_WMAC_MU_BF_MYAID_8822B(v))
+
+/* REG_WMAC_ASSOCIATED_MU_BFMEE7	(Offset 0x168E) */
+#define BIT_STATUS_BFEE7_8822B			BIT(10)
+
+enum _HW_CFG_SOUNDING_TYPE {
+	HW_CFG_SOUNDING_TYPE_SOUNDDOWN,
+	HW_CFG_SOUNDING_TYPE_LEAVE,
+	HW_CFG_SOUNDING_TYPE_RESET,
+	HW_CFG_SOUNDING_TYPE_MAX
+};
+
+static u8 _bf_get_nrx(PADAPTER adapter)
+{
+	u8 rf;
+	u8 nrx = 0;
+
+
+	rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, &rf);
+	switch (rf) {
+	case RF_1T1R:
+		nrx = 0;
+		break;
+	default:
+	case RF_1T2R:
+	case RF_2T2R:
+		nrx = 1;
+		break;
+	}
+
+	return nrx;
+}
+
+static void _sounding_reset_all(PADAPTER adapter)
+{
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+	u8 i;
+	u32 mu_tx_ctl;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	rtw_write8(adapter, REG_TXBF_CTRL_8822B+3, 0);
+
+	/* Clear all MU entry table */
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		for (i = 0; i < 8; i++)
+			bfee->gid_valid[i] = 0;
+	}
+
+	mu_tx_ctl = rtw_read32(adapter, REG_MU_TX_CTL_8822B);
+	for (i = 0; i < 6; i++) {
+		mu_tx_ctl = BIT_SET_R_MU_TAB_SEL_8822B(mu_tx_ctl, i);
+		rtw_write32(adapter, REG_MU_TX_CTL_8822B, mu_tx_ctl);
+		/* set MU STA gid valid table */
+		rtw_write32(adapter, REG_MU_STA_GID_VLD_8822B, 0);
+	}
+
+	/* Disable TxMU PPDU */
+	mu_tx_ctl &= ~BIT_R_EN_MU_MIMO_8822B;
+	rtw_write32(adapter, REG_MU_TX_CTL_8822B, mu_tx_ctl);
+}
+
+static void _sounding_config_su(PADAPTER adapter, struct beamformee_entry *bfee, enum _HW_CFG_SOUNDING_TYPE cfg_type)
+{
+	u32 txbf_ctrl, new_ctrl;
+
+
+	txbf_ctrl = rtw_read32(adapter, REG_TXBF_CTRL_8822B);
+	new_ctrl = txbf_ctrl;
+
+	/* Clear TxBF status at 20M/40/80M first */
+	switch (bfee->su_reg_index) {
+	case 0:
+		new_ctrl &= ~(BIT_R_TXBF0_20M_8822B|BIT_R_TXBF0_40M_8822B|BIT_R_TXBF0_80M_8822B);
+		break;
+	case 1:
+		new_ctrl &= ~(BIT_R_TXBF1_20M_8822B|BIT_R_TXBF1_40M_8822B|BIT_R_TXBF1_80M_8822B);
+		break;
+	}
+
+	switch (cfg_type) {
+	case HW_CFG_SOUNDING_TYPE_SOUNDDOWN:
+		switch (bfee->sound_bw) {
+		default:
+		case CHANNEL_WIDTH_80:
+			if (0 == bfee->su_reg_index)
+				new_ctrl |= BIT_R_TXBF0_80M_8822B;
+			else if (1 == bfee->su_reg_index)
+				new_ctrl |= BIT_R_TXBF1_80M_8822B;
+			/* fall through */
+		case CHANNEL_WIDTH_40:
+			if (0 == bfee->su_reg_index)
+				new_ctrl |= BIT_R_TXBF0_40M_8822B;
+			else if (1 == bfee->su_reg_index)
+				new_ctrl |= BIT_R_TXBF1_40M_8822B;
+			/* fall through */
+		case CHANNEL_WIDTH_20:
+			if (0 == bfee->su_reg_index)
+				new_ctrl |= BIT_R_TXBF0_20M_8822B;
+			else if (1 == bfee->su_reg_index)
+				new_ctrl |= BIT_R_TXBF1_20M_8822B;
+			break;
+		}
+		break;
+
+	default:
+		RTW_INFO("%s: SU cfg_type=%d, don't apply Vmatrix!\n", __FUNCTION__, cfg_type);
+		break;
+	}
+
+	if (new_ctrl != txbf_ctrl)
+		rtw_write32(adapter, REG_TXBF_CTRL_8822B, new_ctrl);
+}
+
+static void _sounding_config_mu(PADAPTER adapter, struct beamformee_entry *bfee, enum _HW_CFG_SOUNDING_TYPE cfg_type)
+{
+	struct beamforming_info *info;
+	u8 is_bitmap_ready = _FALSE;
+	u32 mu_tx_ctl;
+	u16 bitmap;
+	u8 id1, id0, gid;
+	u32 gid_valid[6] = {0};
+	u8 i, j;
+	u32 val32;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	switch (cfg_type) {
+	case HW_CFG_SOUNDING_TYPE_LEAVE:
+		RTW_INFO("%s: MU HW_CFG_SOUNDING_TYPE_LEAVE\n", __FUNCTION__);
+
+		/* Clear the entry table */
+		mu_tx_ctl = rtw_read32(adapter, REG_MU_TX_CTL_8822B);
+		if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU)) {
+			for (i = 0; i < 8; i++)
+				bfee->gid_valid[i] = 0;
+
+			mu_tx_ctl = BIT_SET_R_MU_TAB_SEL_8822B(mu_tx_ctl, bfee->mu_reg_index);
+			rtw_write32(adapter, REG_MU_TX_CTL_8822B, mu_tx_ctl);
+			/* Set MU STA gid valid table */
+			rtw_write32(adapter, REG_MU_STA_GID_VLD_8822B, 0);
+		} else {
+			RTW_ERR("%s: ERROR! It is not an MU BFee entry!!\n",  __FUNCTION__);
+		}
+
+		if (info->beamformee_su_cnt == 0) {
+			/* Disable TxMU PPDU */
+			mu_tx_ctl &= ~BIT_R_EN_MU_MIMO_8822B;
+			rtw_write32(adapter, REG_MU_TX_CTL_8822B, mu_tx_ctl);
+		}
+
+		break;
+
+	case HW_CFG_SOUNDING_TYPE_SOUNDDOWN:
+		RTW_INFO("%s: MU HW_CFG_SOUNDING_TYPE_SOUNDDOWN\n",  __FUNCTION__);
+
+		/* Update all MU entry table */
+		i = 0;
+		do {
+			/* Check BB GID bitmap ready */
+			val32 = phy_query_bb_reg(adapter, 0xF4C, 0xFFFF0000);
+
+			is_bitmap_ready = (val32 & BIT(15)) ? _TRUE : _FALSE;
+			i++;
+			rtw_udelay_os(5);
+		} while ((_FALSE == is_bitmap_ready) && (i < 100));
+
+		bitmap = (u16)(val32 & 0x3FFF);
+
+		for (i = 0; i < 15; i++) {
+			if (i < 5) {
+				/* bit0~4 */
+				id0 = 0;
+				id1 = i + 1;
+			} else if (i < 9) {
+				/* bit5~8 */
+				id0 = 1;
+				id1 = i - 3;
+			} else if (i < 12) {
+				/* bit9~11 */
+				id0 = 2;
+				id1 = i - 6;
+			} else if (i < 14) {
+				/* bit12~13 */
+				id0 = 3;
+				id1 = i - 8;
+			} else {
+				/* bit14 */
+				id0 = 4;
+				id1 = i - 9;
+			}
+			if (bitmap & BIT(i)) {
+				/* Pair 1 */
+				gid = (i << 1) + 1;
+				gid_valid[id0] |= (BIT(gid));
+				gid_valid[id1] |= (BIT(gid));
+				/* Pair 2 */
+				gid += 1;
+				gid_valid[id0] |= (BIT(gid));
+				gid_valid[id1] |= (BIT(gid));
+			} else {
+				/* Pair 1 */
+				gid = (i << 1) + 1;
+				gid_valid[id0] &= ~(BIT(gid));
+				gid_valid[id1] &= ~(BIT(gid));
+				/* Pair 2 */
+				gid += 1;
+				gid_valid[id0] &= ~(BIT(gid));
+				gid_valid[id1] &= ~(BIT(gid));
+			}
+		}
+
+		for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+			bfee = &info->bfee_entry[i];
+			if (_FALSE == bfee->used)
+				continue;
+			if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU)
+			    && (bfee->mu_reg_index < 6)) {
+				val32 = gid_valid[bfee->mu_reg_index];
+				for (j = 0; j < 4; j++) {
+					bfee->gid_valid[j] = (u8)(val32 & 0xFF);
+					val32 >>= 8;
+				}
+			}
+		}
+
+		mu_tx_ctl = rtw_read32(adapter, REG_MU_TX_CTL_8822B);
+		for (i = 0; i < 6; i++) {
+			mu_tx_ctl = BIT_SET_R_MU_TAB_SEL_8822B(mu_tx_ctl, i);
+			rtw_write32(adapter, REG_MU_TX_CTL_8822B, mu_tx_ctl);
+			/* Set MU STA gid valid table */
+			rtw_write32(adapter, REG_MU_STA_GID_VLD_8822B, gid_valid[i]);
+		}
+
+		/* Enable TxMU PPDU */
+		mu_tx_ctl |= BIT_R_EN_MU_MIMO_8822B;
+		rtw_write32(adapter, REG_MU_TX_CTL_8822B, mu_tx_ctl);
+
+		break;
+
+	default:
+		break;
+	}
+}
+
+static void _config_sounding(PADAPTER adapter, struct beamformee_entry *bfee, u8 mu_sounding, enum _HW_CFG_SOUNDING_TYPE cfg_type)
+{
+	if (cfg_type == HW_CFG_SOUNDING_TYPE_RESET) {
+		RTW_INFO("%s: HW_CFG_SOUNDING_TYPE_RESET\n", __FUNCTION__);
+		_sounding_reset_all(adapter);
+		return;
+	}
+
+	if (_FALSE == mu_sounding)
+		_sounding_config_su(adapter, bfee, cfg_type);
+	else
+		_sounding_config_mu(adapter, bfee, cfg_type);
+}
+
+static void _config_beamformer_su(PADAPTER adapter, struct beamformer_entry *bfer)
+{
+	/* Beamforming */
+	u8 nc_index = 0, nr_index = 0;
+	u8 grouping = 0, codebookinfo = 0, coefficientsize = 0;
+	u32 addr_bfer_info, addr_csi_rpt;
+	u32 csi_param;
+	/* Misc */
+	u8 i;
+
+
+	RTW_INFO("%s: Config SU BFer entry HW setting\n", __FUNCTION__);
+
+	if (bfer->su_reg_index == 0) {
+		addr_bfer_info = REG_ASSOCIATED_BFMER0_INFO_8822B;
+		addr_csi_rpt = REG_TX_CSI_RPT_PARAM_BW20_8822B;
+	} else {
+		addr_bfer_info = REG_ASSOCIATED_BFMER1_INFO_8822B;
+		addr_csi_rpt = REG_TX_CSI_RPT_PARAM_BW20_8822B + 2;
+	}
+
+	/* Sounding protocol control */
+	rtw_write8(adapter, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+	/* MAC address/Partial AID of Beamformer */
+	for (i = 0; i < 6; i++)
+		rtw_write8(adapter, addr_bfer_info+i, bfer->mac_addr[i]);
+
+	/* CSI report parameters of Beamformer */
+	nc_index = _bf_get_nrx(adapter);
+	/*
+	 * 0x718[7] = 1 use Nsts
+	 * 0x718[7] = 0 use reg setting
+	 * As Bfee, we use Nsts, so nr_index don't care
+	 */
+	nr_index = bfer->NumofSoundingDim;
+	grouping = 0;
+	/* for ac = 1, for n = 3 */
+	if (TEST_FLAG(bfer->cap, BEAMFORMER_CAP_VHT_SU))
+		codebookinfo = 1;
+	else if (TEST_FLAG(bfer->cap, BEAMFORMER_CAP_HT_EXPLICIT))
+		codebookinfo = 3;
+	coefficientsize = 3;
+	csi_param = (u16)((coefficientsize<<10)|(codebookinfo<<8)|(grouping<<6)|(nr_index<<3)|(nc_index));
+	rtw_write16(adapter, addr_csi_rpt, csi_param);
+	RTW_INFO("%s: nc=%d nr=%d group=%d codebookinfo=%d coefficientsize=%d\n",
+		 __FUNCTION__, nc_index, nr_index, grouping, codebookinfo, coefficientsize);
+	RTW_INFO("%s: csi=0x%04x\n", __FUNCTION__, csi_param);
+
+	/* ndp_rx_standby_timer */
+	rtw_write8(adapter, REG_SND_PTCL_CTRL_8822B+3, 0x70);
+}
+
+static void _config_beamformer_mu(PADAPTER adapter, struct beamformer_entry *bfer)
+{
+	/* General */
+	PHAL_DATA_TYPE hal;
+	/* Beamforming */
+	struct beamforming_info *bf_info;
+	u8 nc_index = 0, nr_index = 0;
+	u8 grouping = 0, codebookinfo = 0, coefficientsize = 0;
+	u32 csi_param;
+	/* Misc */
+	u8 i, val8;
+	u16 val16;
+
+	RTW_INFO("%s: Config MU BFer entry HW setting\n", __FUNCTION__);
+
+	hal = GET_HAL_DATA(adapter);
+	bf_info = GET_BEAMFORM_INFO(adapter);
+
+	/* Reset GID table */
+	for (i = 0; i < 8; i++)
+		bfer->gid_valid[i] = 0;
+	for (i = 0; i < 16; i++)
+		bfer->user_position[i] = 0;
+
+	/* CSI report parameters of Beamformer */
+	nc_index = _bf_get_nrx(adapter);
+	nr_index = 1; /* 0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so Nr_index don't care */
+	grouping = 0; /* no grouping */
+	codebookinfo = 1; /* 7 bit for psi, 9 bit for phi */
+	coefficientsize = 0; /* This is nothing really matter */
+	csi_param = (u16)((coefficientsize<<10)|(codebookinfo<<8)|
+			(grouping<<6)|(nr_index<<3)|(nc_index));
+
+	RTW_INFO("%s: nc=%d nr=%d group=%d codebookinfo=%d coefficientsize=%d\n",
+		__func__, nc_index, nr_index, grouping, codebookinfo,
+		coefficientsize);
+	RTW_INFO("%s: csi=0x%04x\n", __func__, csi_param);
+
+	rtw_halmac_bf_add_mu_bfer(adapter_to_dvobj(adapter), bfer->p_aid,
+			csi_param, bfer->aid & 0xfff, HAL_CSI_SEG_4K,
+			bfer->mac_addr);
+
+	bf_info->cur_csi_rpt_rate = HALMAC_OFDM6;
+	rtw_halmac_bf_cfg_sounding(adapter_to_dvobj(adapter), HAL_BFEE,
+			bf_info->cur_csi_rpt_rate);
+
+	/* Set 0x6A0[14] = 1 to accept action_no_ack */
+	val8 = rtw_read8(adapter, REG_RXFLTMAP0_8822B+1);
+	val8 |= (BIT_MGTFLT14EN_8822B >> 8);
+	rtw_write8(adapter, REG_RXFLTMAP0_8822B+1, val8);
+
+	/* Set 0x6A2[5:4] = 1 to NDPA and BF report poll */
+	val8 = rtw_read8(adapter, REG_RXFLTMAP1_8822B);
+	val8 |= BIT_CTRLFLT4EN_8822B | BIT_CTRLFLT5EN_8822B;
+	rtw_write8(adapter, REG_RXFLTMAP1_8822B, val8);
+
+	/* for B-Cut */
+	if (IS_B_CUT(hal->version_id)) {
+		phy_set_bb_reg(adapter, REG_RXFLTMAP0_8822B, BIT(20), 0);
+		phy_set_bb_reg(adapter, REG_RXFLTMAP3_8822B, BIT(20), 0);
+	}
+}
+
+static void _config_beamformee_su(PADAPTER adapter, struct beamformee_entry *bfee)
+{
+	/* General */
+	struct mlme_priv *mlme;
+	/* Beamforming */
+	struct beamforming_info *info;
+	u8 idx;
+	u16 p_aid = 0;
+	/* Misc */
+	u8 val8;
+	u16 val16;
+	u32 val32;
+
+
+	RTW_INFO("%s: Config SU BFee entry HW setting\n", __FUNCTION__);
+
+	mlme = &adapter->mlmepriv;
+	info = GET_BEAMFORM_INFO(adapter);
+	idx = bfee->su_reg_index;
+
+	if ((check_fwstate(mlme, WIFI_ADHOC_STATE) == _TRUE)
+	    || (check_fwstate(mlme, WIFI_ADHOC_MASTER_STATE) == _TRUE))
+		p_aid = bfee->mac_id;
+	else
+		p_aid = bfee->p_aid;
+
+	phydm_8822btxbf_rfmode(GET_PDM_ODM(adapter), info->beamformee_su_cnt, info->beamformee_mu_cnt);
+
+	/* P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt */
+	val32 = rtw_read32(adapter, REG_TXBF_CTRL_8822B);
+	if (idx == 0) {
+		val32 = BIT_SET_R_TXBF0_AID_8822B(val32, p_aid);
+		val32 &= ~(BIT_R_TXBF0_20M_8822B | BIT_R_TXBF0_40M_8822B | BIT_R_TXBF0_80M_8822B);
+	} else {
+		val32 = BIT_SET_R_TXBF1_AID_8822B(val32, p_aid);
+		val32 &= ~(BIT_R_TXBF1_20M_8822B | BIT_R_TXBF1_40M_8822B | BIT_R_TXBF1_80M_8822B);
+	}
+	val32 |= BIT_R_EN_NDPA_INT_8822B | BIT_USE_NDPA_PARAMETER_8822B | BIT_R_ENABLE_NDPA_8822B;
+	rtw_write32(adapter, REG_TXBF_CTRL_8822B, val32);
+
+	/* CSI report parameters of Beamformee */
+	val32 = rtw_read32(adapter, REG_ASSOCIATED_BFMEE_SEL_8822B);
+	if (idx == 0) {
+		val32 = BIT_SET_AID0_8822B(val32, p_aid);
+		val32 |= BIT_TXUSER_ID0_8822B;
+
+		/* unknown? */
+		val32 &= 0x03FFFFFF;
+		val32 |= 0x60000000;
+	} else {
+		val32 = BIT_SET_AID1_8822B(val32, p_aid);
+		val32 |= BIT_TXUSER_ID1_8822B;
+
+		/* unknown? */
+		val32 &= 0x03FFFFFF;
+		val32 |= 0xE0000000;
+	}
+	rtw_write32(adapter, REG_ASSOCIATED_BFMEE_SEL_8822B, val32);
+}
+
+static void _config_beamformee_mu(PADAPTER adapter, struct beamformee_entry *bfee)
+{
+	/* General */
+	PHAL_DATA_TYPE hal;
+	/* Beamforming */
+	struct beamforming_info *info;
+	u8 idx;
+	u32 gid_valid = 0, user_position_l = 0, user_position_h = 0;
+	u32 mu_reg[6] = {REG_WMAC_ASSOCIATED_MU_BFMEE2_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE3_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE4_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE5_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE6_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE7_8822B};
+	/* Misc */
+	u8 i, val8;
+	u16 val16;
+	u32 val32;
+
+
+	RTW_INFO("%s: Config MU BFee entry HW setting\n", __FUNCTION__);
+
+	hal = GET_HAL_DATA(adapter);
+	info = GET_BEAMFORM_INFO(adapter);
+	idx = bfee->mu_reg_index;
+
+	/* User position table */
+	switch (idx) {
+	case 0:
+		gid_valid = 0x7fe;
+		user_position_l = 0x111110;
+		user_position_h = 0x0;
+		break;
+	case 1:
+		gid_valid = 0x7f806;
+		user_position_l = 0x11000004;
+		user_position_h = 0x11;
+		break;
+	case 2:
+		gid_valid = 0x1f81818;
+		user_position_l = 0x400040;
+		user_position_h = 0x11100;
+		break;
+	case 3:
+		gid_valid = 0x1e186060;
+		user_position_l = 0x4000400;
+		user_position_h = 0x1100040;
+		break;
+	case 4:
+		gid_valid = 0x66618180;
+		user_position_l = 0x40004000;
+		user_position_h = 0x10040400;
+		break;
+	case 5:
+		gid_valid = 0x79860600;
+		user_position_l = 0x40000;
+		user_position_h = 0x4404004;
+		break;
+	}
+
+	for (i = 0; i < 8; i++) {
+		if (i < 4) {
+			bfee->gid_valid[i] = (u8)(gid_valid & 0xFF);
+			gid_valid >>= 8;
+		} else {
+			bfee->gid_valid[i] = 0;
+		}
+	}
+	for (i = 0; i < 16; i++) {
+		if (i < 4)
+			bfee->user_position[i] = (u8)((user_position_l >> (i*8)) & 0xFF);
+		else if (i < 8)
+			bfee->user_position[i] = (u8)((user_position_h >> ((i-4)*8)) & 0xFF);
+		else
+			bfee->user_position[i] = 0;
+	}
+
+	/* Sounding protocol control */
+	rtw_write8(adapter, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+	/* select MU STA table */
+	val32 = rtw_read32(adapter, REG_MU_TX_CTL_8822B);
+	val32 = BIT_SET_R_MU_TAB_SEL_8822B(val32, idx);
+	rtw_write32(adapter, REG_MU_TX_CTL_8822B, val32);
+
+	/* Reset gid_valid table */
+	rtw_write32(adapter, REG_MU_STA_GID_VLD_8822B, 0);
+	rtw_write32(adapter, REG_MU_STA_USER_POS_INFO_8822B , user_position_l);
+	rtw_write32(adapter, REG_MU_STA_USER_POS_INFO_8822B+4 , user_position_h);
+
+	/* set validity of MU STAs */
+	val32 = BIT_SET_R_MU_TABLE_VALID_8822B(val32, info->beamformee_mu_reg_maping);
+	rtw_write32(adapter, REG_MU_TX_CTL_8822B, val32);
+
+	RTW_INFO("%s: RegMUTxCtrl=0x%x, user_position_l=0x%x, user_position_h=0x%x\n",
+		 __FUNCTION__, val32, user_position_l, user_position_h);
+
+	val16 = rtw_read16(adapter, mu_reg[idx]);
+	val16 &= 0xFE00; /* Clear PAID */
+	val16 |= BIT(9); /* Enable MU BFee */
+	val16 |= bfee->p_aid;
+	rtw_write16(adapter, mu_reg[idx], val16);
+	RTW_INFO("%s: Write mu_reg 0x%x = 0x%x\n",
+		 __FUNCTION__, mu_reg[idx], val16);
+
+	/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+	val8 = rtw_read8(adapter, REG_TXBF_CTRL_8822B+3);
+	val8 |= 0xD0; /* Set bit 28, 30, 31 to 3b'111 */
+	rtw_write8(adapter, REG_TXBF_CTRL_8822B+3, val8);
+
+	/* Set NDPA rate*/
+	val8 = phydm_get_ndpa_rate(GET_PDM_ODM(adapter));
+	rtw_write8(adapter, REG_NDPA_RATE_8822B, val8);
+
+	val8 = rtw_read8(adapter, REG_NDPA_OPT_CTRL_8822B);
+	val8 = BIT_SET_R_NDPA_BW_8822B(val8, 0); /* Clear bit 0, 1 */
+	rtw_write8(adapter, REG_NDPA_OPT_CTRL_8822B, val8);
+
+	val32 = rtw_read32(adapter, REG_SND_PTCL_CTRL_8822B);
+	val32 = (val32 & 0xFF0000FF) | 0x020200; /* Set [23:8] to 0x0202 */
+	rtw_write32(adapter, REG_SND_PTCL_CTRL_8822B, val32);
+
+	/* Set 0x6A0[14] = 1 to accept action_no_ack */
+	val8 = rtw_read8(adapter, REG_RXFLTMAP0_8822B+1);
+	val8 |= (BIT_MGTFLT14EN_8822B >> 8);
+	rtw_write8(adapter, REG_RXFLTMAP0_8822B+1, val8);
+
+	/* 0x718[15] = 1. Patch for STA2 CSI report start offset error issue for C-cut and later version */
+	if (!IS_A_CUT(hal->version_id) || !IS_B_CUT(hal->version_id)) {
+		val8 = rtw_read8(adapter, REG_SND_PTCL_CTRL_8822B+1);
+		val8 |= (BIT_VHTNDP_RPTPOLL_CSI_STR_OFFSET_SEL_8822B >> 8);
+		rtw_write8(adapter, REG_SND_PTCL_CTRL_8822B+1, val8);
+	}
+
+	/* End of MAC registers setting */
+
+	phydm_8822btxbf_rfmode(GET_PDM_ODM(adapter), info->beamformee_su_cnt, info->beamformee_mu_cnt);
+
+	/* <tynli_mark> <TODO> Need to set timer 2015.12.23 */
+	/* Special for plugfest */
+	rtw_mdelay_os(50); /* wait for 4-way handshake ending */
+	rtw_bf_send_vht_gid_mgnt_packet(adapter, bfee->mac_addr, bfee->gid_valid, bfee->user_position);
+}
+
+static void _reset_beamformer_su(PADAPTER adapter, struct beamformer_entry *bfer)
+{
+	/* Beamforming */
+	struct beamforming_info *info;
+	u8 idx;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	/* SU BFer */
+	idx = bfer->su_reg_index;
+
+	if (idx == 0) {
+		rtw_write32(adapter, REG_ASSOCIATED_BFMER0_INFO_8822B, 0);
+		rtw_write16(adapter, REG_ASSOCIATED_BFMER0_INFO_8822B+4, 0);
+		rtw_write16(adapter, REG_TX_CSI_RPT_PARAM_BW20_8822B, 0);
+	} else {
+		rtw_write32(adapter, REG_ASSOCIATED_BFMER1_INFO_8822B, 0);
+		rtw_write16(adapter, REG_ASSOCIATED_BFMER1_INFO_8822B+4, 0);
+		rtw_write16(adapter, REG_TX_CSI_RPT_PARAM_BW20_8822B+2, 0);
+	}
+
+	info->beamformer_su_reg_maping &= ~BIT(idx);
+	bfer->su_reg_index = 0xFF;
+
+	RTW_INFO("%s: Clear SU BFer entry(%d) HW setting\n", __FUNCTION__, idx);
+}
+
+static void _reset_beamformer_mu(PADAPTER adapter, struct beamformer_entry *bfer)
+{
+	struct beamforming_info *bf_info;
+
+	bf_info = GET_BEAMFORM_INFO(adapter);
+
+	rtw_halmac_bf_del_mu_bfer(adapter_to_dvobj(adapter));
+
+	if (bf_info->beamformer_su_cnt == 0 &&
+			bf_info->beamformer_mu_cnt == 0)
+		rtw_halmac_bf_del_sounding(adapter_to_dvobj(adapter), HAL_BFEE);
+
+	RTW_INFO("%s: Clear MU BFer entry HW setting\n", __FUNCTION__);
+}
+
+static void _reset_beamformee_su(PADAPTER adapter, struct beamformee_entry *bfee)
+{
+	/* Beamforming */
+	struct beamforming_info *info;
+	u8 idx;
+	/* Misc */
+	u32 txbf_ctrl, bfmee_sel;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	/* SU BFee */
+	idx = bfee->su_reg_index;
+
+	/* Force disable sounding config */
+	_config_sounding(adapter, bfee, _FALSE, HW_CFG_SOUNDING_TYPE_LEAVE);
+
+	/* clear P_AID */
+	txbf_ctrl = rtw_read32(adapter, REG_TXBF_CTRL_8822B);
+	bfmee_sel = rtw_read32(adapter, REG_ASSOCIATED_BFMEE_SEL_8822B);
+	if (idx == 0) {
+		txbf_ctrl = BIT_SET_R_TXBF0_AID_8822B(txbf_ctrl, 0);
+		txbf_ctrl &= ~(BIT_R_TXBF0_20M_8822B | BIT_R_TXBF0_40M_8822B | BIT_R_TXBF0_80M_8822B);
+
+		bfmee_sel = BIT_SET_AID0_8822B(bfmee_sel, 0);
+		bfmee_sel &= ~BIT_TXUSER_ID0_8822B;
+	} else {
+		txbf_ctrl = BIT_SET_R_TXBF1_AID_8822B(txbf_ctrl, 0);
+		txbf_ctrl &= ~(BIT_R_TXBF1_20M_8822B | BIT_R_TXBF1_40M_8822B | BIT_R_TXBF1_80M_8822B);
+
+		bfmee_sel = BIT_SET_AID1_8822B(bfmee_sel, 0);
+		bfmee_sel &= ~BIT_TXUSER_ID1_8822B;
+	}
+	txbf_ctrl |= BIT_R_EN_NDPA_INT_8822B | BIT_USE_NDPA_PARAMETER_8822B | BIT_R_ENABLE_NDPA_8822B;
+	rtw_write32(adapter, REG_TXBF_CTRL_8822B, txbf_ctrl);
+	rtw_write32(adapter, REG_ASSOCIATED_BFMEE_SEL_8822B, bfmee_sel);
+
+	info->beamformee_su_reg_maping &= ~BIT(idx);
+	bfee->su_reg_index = 0xFF;
+
+	RTW_INFO("%s: Clear SU BFee entry(%d) HW setting\n", __FUNCTION__, idx);
+}
+
+static void _reset_beamformee_mu(PADAPTER adapter, struct beamformee_entry *bfee)
+{
+	/* Beamforming */
+	struct beamforming_info *info;
+	u8 idx;
+	u32 mu_reg[6] = {REG_WMAC_ASSOCIATED_MU_BFMEE2_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE3_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE4_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE5_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE6_8822B,
+			 REG_WMAC_ASSOCIATED_MU_BFMEE7_8822B};
+	/* Misc */
+	u32 val32;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	/* MU BFee */
+	idx = bfee->mu_reg_index;
+
+	/* Disable sending NDPA & BF-rpt-poll to this BFee */
+	rtw_write16(adapter, mu_reg[idx] , 0);
+	/* Set validity of MU STA */
+	val32 = rtw_read32(adapter, REG_MU_TX_CTL_8822B);
+	val32 &= ~BIT(idx);
+	rtw_write32(adapter, REG_MU_TX_CTL_8822B, val32);
+
+	/* Force disable sounding config */
+	_config_sounding(adapter, bfee, _TRUE, HW_CFG_SOUNDING_TYPE_LEAVE);
+
+	info->beamformee_mu_reg_maping &= ~BIT(idx);
+	bfee->mu_reg_index = 0xFF;
+
+	RTW_INFO("%s: Clear MU BFee entry(%d) HW setting\n", __FUNCTION__, idx);
+}
+
+void rtl8822b_phy_bf_reset_all(PADAPTER adapter)
+{
+	struct beamforming_info *info;
+	u8 i, val8;
+	u32 val32;
+
+
+	RTW_INFO("+%s\n", __FUNCTION__);
+	info = GET_BEAMFORM_INFO(adapter);
+
+	info->bSetBFHwConfigInProgess = _TRUE;
+
+	/* Reset MU BFer entry setting */
+	/* Clear validity of MU STA0 and MU STA1 */
+	val32 = rtw_read32(adapter, REG_MU_TX_CTL_8822B);
+	val32 = BIT_SET_R_MU_TABLE_VALID_8822B(val32, 0);
+	rtw_write32(adapter, REG_MU_TX_CTL_8822B, val32);
+
+	/* Reset SU BFer entry setting */
+	rtw_write32(adapter, REG_ASSOCIATED_BFMER0_INFO_8822B, 0);
+	rtw_write16(adapter, REG_ASSOCIATED_BFMER0_INFO_8822B+4, 0);
+	rtw_write16(adapter, REG_TX_CSI_RPT_PARAM_BW20_8822B, 0);
+
+	rtw_write32(adapter, REG_ASSOCIATED_BFMER1_INFO_8822B, 0);
+	rtw_write16(adapter, REG_ASSOCIATED_BFMER1_INFO_8822B+4, 0);
+	rtw_write16(adapter, REG_TX_CSI_RPT_PARAM_BW20_8822B+2, 0);
+
+	/* Force disable sounding */
+	_config_sounding(adapter, NULL, _FALSE, HW_CFG_SOUNDING_TYPE_RESET);
+
+	/* Config RF mode */
+	phydm_8822btxbf_rfmode(GET_PDM_ODM(adapter), info->beamformee_su_cnt, info->beamformee_mu_cnt);
+
+	/* Reset MU BFee entry setting */
+
+	/* Disable sending NDPA & BF-rpt-poll to all BFee */
+	for (i=0; i < MAX_NUM_BEAMFORMEE_MU; i++)
+		rtw_write16(adapter, REG_WMAC_ASSOCIATED_MU_BFMEE2_8822B+(i*2), 0);
+
+	/* set validity of MU STA */
+	rtw_write32(adapter, REG_MU_TX_CTL_8822B, 0);
+
+	/* Reset SU BFee entry setting */
+	/* SU BF0 and BF1 */
+	val32 = BIT_R_EN_NDPA_INT_8822B | BIT_USE_NDPA_PARAMETER_8822B | BIT_R_ENABLE_NDPA_8822B;
+	rtw_write32(adapter, REG_TXBF_CTRL_8822B, val32);
+	rtw_write32(adapter, REG_ASSOCIATED_BFMEE_SEL_8822B, 0);
+
+	info->bSetBFHwConfigInProgess = _FALSE;
+
+	/* Clear SU TxBF workaround BB registers */
+	if (_TRUE == info->bEnableSUTxBFWorkAround)
+		rtl8822b_phy_bf_set_csi_report(adapter, &info->TargetCSIInfo);
+
+	RTW_INFO("-%s\n", __FUNCTION__);
+}
+
+void rtl8822b_phy_bf_init(PADAPTER adapter)
+{
+	u8 v8;
+	u32 v32;
+
+	v32 = rtw_read32(adapter, REG_MU_TX_CTL_8822B);
+	/* Enable P1 aggr new packet according to P0 transfer time */
+	v32 |= BIT_R_MU_P1_WAIT_STATE_EN_8822B;
+	/* MU Retry Limit */
+	v32 = BIT_SET_R_MU_RL_8822B(v32, 0xA);
+	/* Disable Tx MU-MIMO until sounding done */
+	v32 &= ~BIT_R_EN_MU_MIMO_8822B;
+	/* Clear validity of MU STAs */
+	v32 = BIT_SET_R_MU_TABLE_VALID_8822B(v32, 0);
+	rtw_write32(adapter, REG_MU_TX_CTL_8822B, v32);
+
+	/* MU-MIMO Option as default value */
+	v8 = BIT_WMAC_TXMU_ACKPOLICY_8822B(3);
+	v8 |= BIT_BIT_WMAC_TXMU_ACKPOLICY_EN_8822B;
+	rtw_write8(adapter, REG_WMAC_MU_BF_OPTION_8822B, v8);
+	/* MU-MIMO Control as default value */
+	rtw_write16(adapter, REG_WMAC_MU_BF_CTL_8822B, 0);
+
+	/* Set MU NDPA rate & BW source */
+	/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+	v8 = rtw_read8(adapter, REG_TXBF_CTRL_8822B+3);
+	v8 |= (BIT_USE_NDPA_PARAMETER_8822B >> 24);
+	rtw_write8(adapter, REG_TXBF_CTRL_8822B+3, v8);
+	/* 0x45F[7:0] = 0x10 (Rate=OFDM_6M, BW20) */
+	rtw_write8(adapter, REG_NDPA_OPT_CTRL_8822B, 0x10);
+
+	/* Temp Settings */
+	/* STA2's CSI rate is fixed at 6M */
+	v8 = rtw_read8(adapter, 0x6DF);
+	v8 = (v8 & 0xC0) | 0x4;
+	rtw_write8(adapter, 0x6DF, v8);
+	/* Grouping bitmap parameters */
+	rtw_write32(adapter, 0x1C94, 0xAFFFAFFF);
+}
+
+void rtl8822b_phy_bf_enter(PADAPTER adapter, struct sta_info *sta)
+{
+	struct beamforming_info *info;
+	struct beamformer_entry *bfer;
+	struct beamformee_entry *bfee;
+
+
+	RTW_INFO("+%s: " MAC_FMT "\n", __FUNCTION__, MAC_ARG(sta->cmn.mac_addr));
+
+	info = GET_BEAMFORM_INFO(adapter);
+	bfer = rtw_bf_bfer_get_entry_by_addr(adapter, sta->cmn.mac_addr);
+	bfee = rtw_bf_bfee_get_entry_by_addr(adapter, sta->cmn.mac_addr);
+
+	info->bSetBFHwConfigInProgess = _TRUE;
+
+	if (bfer) {
+		bfer->state = BEAMFORM_ENTRY_HW_STATE_ADDING;
+
+		if (TEST_FLAG(bfer->cap, BEAMFORMER_CAP_VHT_MU))
+			_config_beamformer_mu(adapter, bfer);
+		else if (TEST_FLAG(bfer->cap, BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT))
+			_config_beamformer_su(adapter, bfer);
+
+		bfer->state = BEAMFORM_ENTRY_HW_STATE_ADDED;
+	}
+
+	if (bfee) {
+		bfee->state = BEAMFORM_ENTRY_HW_STATE_ADDING;
+
+		if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU))
+			_config_beamformee_mu(adapter, bfee);
+		else if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT))
+			_config_beamformee_su(adapter, bfee);
+
+		bfee->state = BEAMFORM_ENTRY_HW_STATE_ADDED;
+	}
+
+	info->bSetBFHwConfigInProgess = _FALSE;
+
+	RTW_INFO("-%s\n", __FUNCTION__);
+}
+
+void rtl8822b_phy_bf_leave(PADAPTER adapter, u8 *addr)
+{
+	struct beamforming_info *info;
+	struct beamformer_entry *bfer;
+	struct beamformee_entry *bfee;
+
+
+	RTW_INFO("+%s: " MAC_FMT "\n", __FUNCTION__, MAC_ARG(addr));
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	bfer = rtw_bf_bfer_get_entry_by_addr(adapter, addr);
+	bfee = rtw_bf_bfee_get_entry_by_addr(adapter, addr);
+
+	/* Clear P_AID of Beamformee */
+	/* Clear MAC address of Beamformer */
+	/* Clear Associated Bfmee Sel */
+	if (bfer) {
+		bfer->state = BEAMFORM_ENTRY_HW_STATE_DELETING;
+
+		rtw_write8(adapter, REG_SND_PTCL_CTRL_8822B, 0xD8);
+
+		if (TEST_FLAG(bfer->cap, BEAMFORMER_CAP_VHT_MU))
+			_reset_beamformer_mu(adapter, bfer);
+		else if (TEST_FLAG(bfer->cap, BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT))
+			_reset_beamformer_su(adapter, bfer);
+
+		bfer->state = BEAMFORM_ENTRY_HW_STATE_NONE;
+		bfer->cap = BEAMFORMING_CAP_NONE;
+		bfer->used = _FALSE;
+	}
+
+	if (bfee) {
+		bfee->state = BEAMFORM_ENTRY_HW_STATE_DELETING;
+
+		phydm_8822btxbf_rfmode(GET_PDM_ODM(adapter), info->beamformee_su_cnt, info->beamformee_mu_cnt);
+
+		if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU))
+			_reset_beamformee_mu(adapter, bfee);
+		else if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT))
+			_reset_beamformee_su(adapter, bfee);
+
+		bfee->state = BEAMFORM_ENTRY_HW_STATE_NONE;
+		bfee->cap = BEAMFORMING_CAP_NONE;
+		bfee->used = _FALSE;
+	}
+
+	RTW_INFO("-%s\n", __FUNCTION__);
+}
+
+void rtl8822b_phy_bf_set_gid_table(PADAPTER adapter,
+		struct beamformer_entry	*bfer_info)
+{
+	struct beamformer_entry *bfer;
+	struct beamforming_info *info;
+	u32 gid_valid[2] = {0};
+	u32 user_position[4] = {0};
+	int i;
+
+	/* update bfer info */
+	bfer = rtw_bf_bfer_get_entry_by_addr(adapter, bfer_info->mac_addr);
+	if (!bfer) {
+		RTW_INFO("%s: Cannot find BFer entry!!\n", __func__);
+		return;
+	}
+	_rtw_memcpy(bfer->gid_valid, bfer_info->gid_valid, 8);
+	_rtw_memcpy(bfer->user_position, bfer_info->user_position, 16);
+
+	info = GET_BEAMFORM_INFO(adapter);
+	info->bSetBFHwConfigInProgess = _TRUE;
+
+	/* For GID 0~31 */
+	for (i = 0; i < 4; i++)
+		gid_valid[0] |= (bfer->gid_valid[i] << (i << 3));
+
+	for (i = 0; i < 8; i++) {
+		if (i < 4)
+			user_position[0] |= (bfer->user_position[i] << (i << 3));
+		else
+			user_position[1] |= (bfer->user_position[i] << ((i - 4) << 3));
+	}
+
+	RTW_INFO("%s: STA0: gid_valid=0x%x, user_position_l=0x%x, user_position_h=0x%x\n",
+		__func__, gid_valid[0], user_position[0], user_position[1]);
+
+	/* For GID 32~64 */
+	for (i = 4; i < 8; i++)
+		gid_valid[1] |= (bfer->gid_valid[i] << ((i - 4) << 3));
+
+	for (i = 8; i < 16; i++) {
+		if (i < 12)
+			user_position[2] |= (bfer->user_position[i] << ((i - 8) << 3));
+		else
+			user_position[3] |= (bfer->user_position[i] << ((i - 12) << 3));
+	}
+
+	RTW_INFO("%s: STA1: gid_valid=0x%x, user_position_l=0x%x, user_position_h=0x%x\n",
+		__func__, gid_valid[1], user_position[2], user_position[3]);
+
+	rtw_halmac_bf_cfg_mu_bfee(adapter_to_dvobj(adapter), gid_valid, user_position);
+
+	info->bSetBFHwConfigInProgess = _FALSE;
+}
+
+void rtl8822b_phy_bf_set_csi_report(PADAPTER adapter, struct _RT_CSI_INFO *csi)
+{
+	PHAL_DATA_TYPE hal;
+	struct beamforming_info *info;
+	BOOLEAN enable_su = FALSE;
+
+
+	hal = GET_HAL_DATA(adapter);
+	info = GET_BEAMFORM_INFO(adapter);
+
+	info->bSetBFHwConfigInProgess = _TRUE;
+
+	if (IS_A_CUT(hal->version_id) || IS_B_CUT(hal->version_id) || IS_C_CUT(hal->version_id)) {
+		/* If there is an MU BFee added then discard the SU BFee supported capability */
+		if ((info->beamformee_su_cnt > 0) && (info->beamformee_mu_cnt == 0))
+			enable_su = TRUE;
+
+		phydm_8822b_sutxbfer_workaroud(
+			GET_PDM_ODM(adapter),
+			enable_su,
+			csi->Nc,
+			csi->Nr,
+			csi->Ng,
+			csi->CodeBook,
+			csi->ChnlWidth,
+			csi->bVHT);
+
+		RTW_INFO("%s: bEnable=%d, Nc=%d, Nr=%d, CH_W=%d, Ng=%d, CodeBook=%d\n",
+			 __FUNCTION__, bEnable,
+			 csi->Nc, csi->Nr, csi->ChnlWidth, csi->Ng, csi->CodeBook);
+	}
+
+	info->bSetBFHwConfigInProgess = _FALSE;
+}
+
+void rtl8822b_phy_bf_sounding_status(PADAPTER adapter, u8 status)
+{
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	struct beamformee_entry *bfee;
+	enum _HW_CFG_SOUNDING_TYPE sounding_type;
+	u16 val16;
+	u32 val32;
+	u8 is_sounding_success[6] = {0};
+
+
+	RTW_INFO("+%s\n", __FUNCTION__);
+
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	info->bSetBFHwConfigInProgess = _TRUE;
+
+	if (sounding->state == SOUNDING_STATE_SU_SOUNDDOWN) {
+		/* SU sounding done */
+		RTW_INFO("%s: SUBFeeCurIdx=%d\n", __FUNCTION__, sounding->su_bfee_curidx);
+
+		bfee = &info->bfee_entry[sounding->su_bfee_curidx];
+		if (bfee->bSoundingTimeout) {
+			RTW_INFO("%s: Return because SUBFeeCurIdx(%d) is sounding timeout!!!\n", __FUNCTION__, sounding->su_bfee_curidx);
+			info->bSetBFHwConfigInProgess = _FALSE;
+			return;
+		}
+
+		RTW_INFO("%s: Config SU sound down HW settings\n", __FUNCTION__);
+		/* Config SU sounding */
+		if (_TRUE == status)
+			sounding_type = HW_CFG_SOUNDING_TYPE_SOUNDDOWN;
+		else
+			sounding_type = HW_CFG_SOUNDING_TYPE_LEAVE;
+		_config_sounding(adapter, bfee, _FALSE, sounding_type);
+
+		/* <tynli_note> Why set here? */
+		/* disable NDP packet use beamforming */
+		val16 = rtw_read16(adapter, REG_TXBF_CTRL_8822B);
+		val16 |= BIT_DIS_NDP_BFEN_8822B;
+		rtw_write16(adapter, REG_TXBF_CTRL_8822B, val16);
+	} else if (sounding->state == SOUNDING_STATE_MU_SOUNDDOWN) {
+		/* MU sounding done */
+		RTW_INFO("%s: Config MU sound down HW settings\n", __FUNCTION__);
+
+		val32 = rtw_read32(adapter, REG_WMAC_ASSOCIATED_MU_BFMEE2_8822B);
+		is_sounding_success[0] = (val32 & BIT_STATUS_BFEE2_8822B) ? 1:0;
+		is_sounding_success[1] = ((val32 >> 16) & BIT_STATUS_BFEE3_8822B) ? 1:0;
+		val32 = rtw_read32(adapter, REG_WMAC_ASSOCIATED_MU_BFMEE4_8822B);
+		is_sounding_success[2] = (val32 & BIT_STATUS_BFEE4_8822B) ? 1:0;
+		is_sounding_success[3] = ((val32 >> 16) & BIT_STATUS_BFEE5_8822B) ? 1:0;
+		val32 = rtw_read32(adapter, REG_WMAC_ASSOCIATED_MU_BFMEE6_8822B);
+		is_sounding_success[4] = (val32 & BIT_STATUS_BFEE6_8822B) ? 1:0;
+		is_sounding_success[5] = ((val32 >> 16) & BIT_STATUS_BFEE7_8822B) ? 1:0;
+
+		RTW_INFO("%s: is_sounding_success STA1:%d, STA2:%d, STA3:%d, STA4:%d, STA5:%d, STA6:%d\n",
+			 __FUNCTION__, is_sounding_success[0], is_sounding_success[1] , is_sounding_success[2],
+			 is_sounding_success[3], is_sounding_success[4], is_sounding_success[5]);
+
+		/* Config MU sounding */
+		_config_sounding(adapter, NULL, _TRUE, HW_CFG_SOUNDING_TYPE_SOUNDDOWN);
+	} else {
+		RTW_INFO("%s: Invalid sounding state(%d). Do nothing!\n", __FUNCTION__, sounding->state);
+	}
+
+	info->bSetBFHwConfigInProgess = _FALSE;
+
+	RTW_INFO("-%s\n", __FUNCTION__);
+}
+#endif /* CONFIG_BEAMFORMING */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu.h
new file mode 100644
index 000000000000..075e275093a1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu.h
@@ -0,0 +1,62 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_H_
+#define _RTL8822BU_H_
+
+#include <drv_types.h>		/* PADAPTER, basic_types.h, rtw_xmit.h and etc. */
+
+#define USB_AGG_EN_8822B			BIT(7)
+
+#ifdef CONFIG_LPS_LCLK
+/* for CONFIG_LPS_LCLK setting in rtl8822bu_ops.c */
+#define REG_USB_HRPWM_8822B		0xFE58
+#define REG_USB_HCPWM_8822B		0xFE57
+#endif /* CONFIG_LPS_LCLK */
+
+/* rtl8822bu_halinit.c */
+u32 rtl8822bu_init(PADAPTER);
+u32 rtl8822bu_deinit(PADAPTER);
+u32 rtl8822bu_inirp_init(PADAPTER);
+u32 rtl8822bu_inirp_deinit(PADAPTER);
+void rtl8822bu_interface_configure(PADAPTER);
+
+/* rtl8822bu_halmac.c */
+int rtl8822bu_halmac_init_adapter(PADAPTER);
+
+/* rtl8822bu_io.c */
+#ifdef CONFIG_RTW_SW_LED
+/* rtl8822bu_led.c */
+void rtl8822bu_initswleds(PADAPTER);
+void rtl8822bu_deinitswleds(PADAPTER);
+#endif
+/* rtl8822bu_xmit.c */
+#define OFFSET_SZ 0
+#define MAX_TX_AGG_PACKET_NUMBER_8822B 0xff
+
+s32 rtl8822bu_init_xmit_priv(PADAPTER);
+void rtl8822bu_free_xmit_priv(PADAPTER);
+s32 rtl8822bu_mgnt_xmit(PADAPTER, struct xmit_frame *);
+s32 rtl8822bu_hal_xmit(PADAPTER, struct xmit_frame *);
+s32 rtl8822bu_hal_xmitframe_enqueue(PADAPTER, struct xmit_frame *);
+s32 rtl8822bu_hostap_mgnt_xmit_entry(PADAPTER, _pkt *);
+#ifdef CONFIG_XMIT_THREAD_MODE
+s32 rtl8822bu_xmit_buf_handler(PADAPTER);
+#endif /* CONFIG_XMIT_THREAD_MODE */
+
+/* rtl8822bu_recv.c */
+int rtl8822bu_init_recv_priv(PADAPTER);
+void rtl8822bu_free_recv_priv(PADAPTER);
+
+#endif /* _RTL8822BU_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_halinit.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_halinit.c
new file mode 100644
index 000000000000..dd1d3accb7bb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_halinit.c
@@ -0,0 +1,436 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_HALINIT_C_
+
+#include <hal_data.h>			/* HAL DATA */
+#include "../../hal_halmac.h"		/* HALMAC API */
+#include "../rtl8822b.h"		/* rtl8822b hal common define */
+#include "rtl8822bu.h"
+
+#ifndef CONFIG_USB_HCI
+
+	#error "CONFIG_USB_HCI shall be on!\n"
+
+#endif
+
+
+static void _dbg_dump_macreg(PADAPTER padapter)
+{
+	u32 offset = 0;
+	u32 val32 = 0;
+	u32 index = 0;
+
+	for (index = 0; index < 64; index++) {
+		offset = index * 4;
+		val32 = rtw_read32(padapter, offset);
+		RTW_INFO("offset : 0x%02x ,val:0x%08x\n", offset, val32);
+	}
+}
+
+#ifdef CONFIG_FWLPS_IN_IPS
+u8 rtl8822bu_fw_ips_init(_adapter *padapter)
+{
+	struct sreset_priv *psrtpriv = &GET_HAL_DATA(padapter)->srestpriv;
+	struct debug_priv *pdbgpriv = &adapter_to_dvobj(padapter)->drv_dbg;
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+
+	if (pwrctl->bips_processing == _TRUE && psrtpriv->silent_reset_inprogress == _FALSE
+		&& GET_HAL_DATA(padapter)->bFWReady == _TRUE && pwrctl->pre_ips_type == 0) {
+		systime start_time;
+		u8 cpwm_orig, cpwm_now, rpwm;
+		u8 bMacPwrCtrlOn = _TRUE;
+
+		RTW_INFO("%s: Leaving FW_IPS\n", __func__);
+#ifdef CONFIG_LPS_LCLK
+		/* for polling cpwm */
+		cpwm_orig = 0;
+		rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_orig);
+
+		/* set rpwm */
+		rtw_hal_get_hwreg(padapter, HW_VAR_RPWM_TOG, &rpwm);
+		rpwm += 0x80;
+		rpwm |= PS_ACK;
+		rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
+
+
+		RTW_INFO("%s: write rpwm=%02x\n", __func__, rpwm);
+
+		pwrctl->tog = (rpwm + 0x80) & 0x80;
+
+		/* do polling cpwm */
+		start_time = rtw_get_current_time();
+		do {
+
+			rtw_mdelay_os(1);
+
+			rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_now);
+			if ((cpwm_orig ^ cpwm_now) & 0x80) {
+				#ifdef DBG_CHECK_FW_PS_STATE
+				RTW_INFO("%s: polling cpwm ok when leaving IPS in FWLPS state, cpwm_orig=%02x, cpwm_now=%02x, 0x100=0x%x\n"
+					, __func__, cpwm_orig, cpwm_now, rtw_read8(padapter, REG_CR));
+				#endif /* DBG_CHECK_FW_PS_STATE */
+				break;
+			}
+
+			if (rtw_get_passing_time_ms(start_time) > 100) {
+				RTW_INFO("%s: polling cpwm timeout when leaving IPS in FWLPS state, cpwm_orig=%02x, cpwm_now=%02x, 0x100=0x%x\n",
+					__func__, cpwm_orig, cpwm_now, rtw_read8(padapter, REG_CR));
+				break;
+			}
+		} while (1);
+#endif /* CONFIG_LPS_LCLK */
+		rtl8822b_set_FwPwrModeInIPS_cmd(padapter, 0);
+
+		rtw_hal_set_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
+#ifdef CONFIG_LPS_LCLK
+		#ifdef DBG_CHECK_FW_PS_STATE
+		if (rtw_fw_ps_state(padapter) == _FAIL) {
+			RTW_INFO("after hal init, fw ps state in 32k\n");
+			pdbgpriv->dbg_ips_drvopen_fail_cnt++;
+		}
+		#endif /* DBG_CHECK_FW_PS_STATE */
+#endif /* CONFIG_LPS_LCLK */
+		return _SUCCESS;
+	}
+	return _FAIL;
+}
+
+u8 rtl8822bu_fw_ips_deinit(_adapter *padapter)
+{
+	struct sreset_priv *psrtpriv =  &GET_HAL_DATA(padapter)->srestpriv;
+	struct debug_priv *pdbgpriv = &adapter_to_dvobj(padapter)->drv_dbg;
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+
+	if (pwrctl->bips_processing == _TRUE && psrtpriv->silent_reset_inprogress == _FALSE
+		&& GET_HAL_DATA(padapter)->bFWReady == _TRUE && padapter->netif_up == _TRUE) {
+		int cnt = 0;
+		u8 val8 = 0, rpwm;
+
+		RTW_INFO("%s: issue H2C to FW when entering IPS\n", __func__);
+
+		rtl8822b_set_FwPwrModeInIPS_cmd(padapter, 0x1);
+#ifdef CONFIG_LPS_LCLK
+		/* poll 0x1cc to make sure H2C command already finished by FW; MAC_0x1cc=0 means H2C done by FW. */
+		do {
+			val8 = rtw_read8(padapter, REG_HMETFR);
+			cnt++;
+			RTW_INFO("%s  polling REG_HMETFR=0x%x, cnt=%d\n", __func__, val8, cnt);
+			rtw_mdelay_os(10);
+		} while (cnt < 100 && (val8 != 0));
+
+		/* H2C done, enter 32k */
+		if (val8 == 0) {
+			/* set rpwm to enter 32k */
+			rtw_hal_get_hwreg(padapter, HW_VAR_RPWM_TOG, &rpwm);
+			rpwm += 0x80;
+			rpwm |= BIT_SYS_CLK_8822B;
+			rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
+			RTW_INFO("%s: write rpwm=%02x\n", __func__, rpwm);
+			pwrctl->tog = (val8 + 0x80) & 0x80;
+
+			cnt = val8 = 0;
+			do {
+				val8 = rtw_read8(padapter, REG_CR);
+				cnt++;
+				RTW_INFO("%s  polling 0x100=0x%x, cnt=%d\n", __func__, val8, cnt);
+				rtw_mdelay_os(10);
+			} while (cnt < 100 && (val8 != 0xEA));
+
+			#ifdef DBG_CHECK_FW_PS_STATE
+			if (val8 != 0xEA)
+				RTW_INFO("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n"
+					, rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
+					, rtw_read32(padapter, 0x1c8), rtw_read32(padapter, REG_HMETFR));
+			#endif /* DBG_CHECK_FW_PS_STATE */
+		} else {
+			RTW_INFO("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n"
+				, rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
+				, rtw_read32(padapter, 0x1c8), rtw_read32(padapter, REG_HMETFR));
+		}
+
+		RTW_INFO("polling done when entering IPS, check result : 0x100=0x%x, cnt=%d, MAC_1cc=0x%02x\n"
+			, rtw_read8(padapter, REG_CR), cnt, rtw_read8(padapter, REG_HMETFR));
+
+		pwrctl->pre_ips_type = 0;
+#endif /* CONFIG_LPS_LCLK */
+		return _SUCCESS;
+	}
+
+	pdbgpriv->dbg_carddisable_cnt++;
+	pwrctl->pre_ips_type = 1;
+
+	return _FAIL;
+
+}
+
+#endif
+
+static void init_hwled(PADAPTER adapter, u8 enable)
+{
+	u8 mode = 0;
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+	if (ledpriv->LedStrategy != HW_LED)
+		return;
+
+	rtw_halmac_led_cfg(adapter_to_dvobj(adapter), enable, mode);
+}
+
+static void hal_init_misc(PADAPTER adapter)
+{
+#ifdef CONFIG_RTW_LED
+	init_hwled(adapter, 1);
+#endif /* CONFIG_RTW_LED */
+
+}
+
+u32 rtl8822bu_init(PADAPTER padapter)
+{
+	u8 status = _SUCCESS;
+	systime init_start_time = rtw_get_current_time();
+
+#ifdef CONFIG_FWLPS_IN_IPS
+	if (_SUCCESS == rtl8822bu_fw_ips_init(padapter))
+		goto exit;
+#endif
+
+	rtl8822b_init(padapter);
+
+	hal_init_misc(padapter);
+
+exit:
+	RTW_INFO("%s in %dms\n", __func__, rtw_get_passing_time_ms(init_start_time));
+
+	return status;
+}
+
+static void hal_deinit_misc(PADAPTER adapter)
+{
+#ifdef CONFIG_RTW_LED
+	init_hwled(adapter, 0);
+#endif /* CONFIG_RTW_LED */
+}
+
+u32 rtl8822bu_deinit(PADAPTER padapter)
+{
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct dvobj_priv *pobj_priv = adapter_to_dvobj(padapter);
+	u8 status = _TRUE;
+
+	RTW_INFO("==> %s\n", __func__);
+
+#ifdef CONFIG_FWLPS_IN_IPS
+	if (_SUCCESS == rtl8822bu_fw_ips_deinit(padapter))
+		goto exit;
+#endif
+
+	hal_deinit_misc(padapter);
+	status = rtl8822b_deinit(padapter);
+	if (status == _FALSE) {
+		RTW_INFO("%s: rtl8822b_hal_deinit fail\n", __func__);
+		return _FAIL;
+	}
+
+exit:
+	RTW_INFO("%s <==\n", __func__);
+	return _SUCCESS;
+}
+
+
+u32 rtl8822bu_inirp_init(PADAPTER padapter)
+{
+	u8 i, status;
+	struct recv_buf *precvbuf;
+	struct dvobj_priv *pdev = adapter_to_dvobj(padapter);
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	u32(*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u32(*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
+#endif
+
+#ifdef CONFIG_FWLPS_IN_IPS
+	/* Do not sumbit urb repeat */
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+
+	if (pwrctl->bips_processing == _TRUE) {
+		status = _SUCCESS;
+		goto exit;
+	}
+#endif /* CONFIG_FWLPS_IN_IPS */
+
+	_read_port = pintfhdl->io_ops._read_port;
+
+	status = _SUCCESS;
+
+
+	precvpriv->ff_hwaddr = RECV_BULK_IN_ADDR;
+
+	/* issue Rx irp to receive data */
+	precvbuf = (struct recv_buf *)precvpriv->precv_buf;
+	for (i = 0; i < NR_RECVBUFF; i++) {
+		if (_read_port(pintfhdl, precvpriv->ff_hwaddr, 0, (u8 *)precvbuf) == _FALSE) {
+			status = _FAIL;
+			goto exit;
+		}
+
+		precvbuf++;
+		precvpriv->free_recv_buf_queue_cnt--;
+	}
+
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+	if (pdev->RtInPipe[REALTEK_USB_IN_INT_EP_IDX] != 0x05) {
+		status = _FAIL;
+		RTW_INFO("%s =>Warning !! Have not USB Int-IN pipe, RtIntInPipe(%d)!!!\n", __func__, pdev->RtInPipe[REALTEK_USB_IN_INT_EP_IDX]);
+		goto exit;
+	}
+	_read_interrupt = pintfhdl->io_ops._read_interrupt;
+	if (_read_interrupt(pintfhdl, RECV_INT_IN_ADDR) == _FALSE) {
+		status = _FAIL;
+	}
+#endif
+
+exit:
+
+
+
+	return status;
+
+}
+
+u32 rtl8822bu_inirp_deinit(PADAPTER padapter)
+{
+
+	rtw_read_port_cancel(padapter);
+
+
+	return _SUCCESS;
+}
+
+void rtl8822bu_update_interrupt_mask(PADAPTER padapter, u8 bHIMR0 , u32 AddMSR, u32 RemoveMSR)
+{
+	HAL_DATA_TYPE *pHalData;
+	u32 *himr;
+
+	pHalData = GET_HAL_DATA(padapter);
+
+	if (bHIMR0)
+		himr = &(pHalData->IntrMask[0]);
+	else
+		himr = &(pHalData->IntrMask[1]);
+
+	if (AddMSR)
+		*himr |= AddMSR;
+
+	if (RemoveMSR)
+		*himr &= (~RemoveMSR);
+
+	if (bHIMR0)
+		rtw_write32(padapter, REG_HIMR0_8822B, *himr);
+	else
+		rtw_write32(padapter, REG_HIMR1_8822B, *himr);
+
+}
+
+static void config_chip_out_EP(PADAPTER padapter, u8 NumOutPipe)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+
+
+	pHalData->OutEpQueueSel = 0;
+	pHalData->OutEpNumber = 0;
+
+	switch (NumOutPipe) {
+	case 4:
+		pHalData->OutEpQueueSel = TX_SELE_HQ | TX_SELE_LQ | TX_SELE_NQ;
+		pHalData->OutEpNumber = 4;
+		break;
+	case 3:
+		pHalData->OutEpQueueSel = TX_SELE_HQ | TX_SELE_LQ | TX_SELE_NQ;
+		pHalData->OutEpNumber = 3;
+		break;
+	case 2:
+		pHalData->OutEpQueueSel = TX_SELE_HQ | TX_SELE_NQ;
+		pHalData->OutEpNumber = 2;
+		break;
+	case  1:
+		pHalData->OutEpQueueSel = TX_SELE_HQ;
+		pHalData->OutEpNumber = 1;
+		break;
+	default:
+		break;
+	}
+
+	RTW_INFO("%s OutEpQueueSel(0x%02x), OutEpNumber(%d)\n", __func__, pHalData->OutEpQueueSel, pHalData->OutEpNumber);
+
+}
+
+static u8 usb_set_queue_pipe_mapping(PADAPTER padapter, u8 NumInPipe, u8 NumOutPipe)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 result = _FALSE;
+
+	config_chip_out_EP(padapter, NumOutPipe);
+
+	/* Normal chip with one IN and one OUT doesn't have interrupt IN EP. */
+	if (1 == pHalData->OutEpNumber) {
+		if (1 != NumInPipe)
+			return result;
+	}
+
+	result = Hal_MappingOutPipe(padapter, NumOutPipe);
+
+	return result;
+
+}
+
+void rtl8822bu_interface_configure(PADAPTER padapter)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+
+	if (IS_SUPER_SPEED_USB(padapter))
+		pHalData->UsbBulkOutSize = USB_SUPER_SPEED_BULK_SIZE;
+	else if (IS_HIGH_SPEED_USB(padapter))
+		pHalData->UsbBulkOutSize = USB_HIGH_SPEED_BULK_SIZE;
+	else
+		pHalData->UsbBulkOutSize = USB_FULL_SPEED_BULK_SIZE;
+
+	pHalData->interfaceIndex = pdvobjpriv->InterfaceNumber;
+
+#ifdef CONFIG_USB_TX_AGGREGATION
+	/* according to value defined by halmac */
+	pHalData->UsbTxAggMode		= 1;
+	rtw_halmac_usb_get_txagg_desc_num(pdvobjpriv, &pHalData->UsbTxAggDescNum);
+#endif /* CONFIG_USB_TX_AGGREGATION */
+
+#ifdef CONFIG_USB_RX_AGGREGATION
+	/* according to value defined by halmac */
+	pHalData->rxagg_mode = RX_AGG_USB;
+#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+	pHalData->rxagg_usb_size = 0x03;
+	pHalData->rxagg_usb_timeout = 0x20;
+#elif defined(CONFIG_PLATFORM_HISILICON)
+	 /* use 16k to workaround for HISILICON platform */
+	pHalData->rxagg_usb_size = 3;
+	pHalData->rxagg_usb_timeout = 8;
+#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
+#endif /* CONFIG_USB_RX_AGGREGATION */
+
+	usb_set_queue_pipe_mapping(padapter,
+			   pdvobjpriv->RtNumInPipes, pdvobjpriv->RtNumOutPipes);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_halmac.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_halmac.c
new file mode 100644
index 000000000000..48f1a9033bf9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_halmac.c
@@ -0,0 +1,320 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_HALMAC_C_
+
+#include <drv_types.h>		/* struct dvobj_priv and etc. */
+#include "../../hal_halmac.h"
+#include "../rtl8822b.h"	/* rtl8822b_cal_txdesc_chksum() and etc. */
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 5, 0)) || (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 18))
+#define usb_write_port_complete_not_xmitframe(purb, regs)	usb_write_port_complete_not_xmitframe(purb)
+#endif
+static void usb_write_port_complete_not_xmitframe(struct urb *purb, struct pt_regs *regs)
+{
+
+	if (purb->status == 0) {
+		;
+	} else {
+		RTW_INFO("###=> urb_write_port_complete status(%d)\n", purb->status);
+		if ((purb->status == -EPIPE) || (purb->status == -EPROTO)) {
+			;
+		} else if (purb->status == -EINPROGRESS) {
+			goto check_completion;
+
+		} else if (purb->status == -ENOENT) {
+			RTW_INFO("%s: -ENOENT\n", __func__);
+			goto check_completion;
+
+		} else if (purb->status == -ECONNRESET) {
+			RTW_INFO("%s: -ECONNRESET\n", __func__);
+			goto check_completion;
+
+		} else if (purb->status == -ESHUTDOWN) {
+			RTW_INFO("%s: -ESHUTDOWN\n", __func__);
+			goto check_completion;
+		} else {
+			goto check_completion;
+		}
+	}
+
+check_completion:
+	rtw_mfree(purb->transfer_buffer, purb->transfer_buffer_length);
+	usb_free_urb(purb);
+}
+
+static u32 usb_write_port_not_xmitframe(struct dvobj_priv *d, u8 addr, u32 cnt, u8 *wmem)
+{
+	struct dvobj_priv *pobj = (struct dvobj_priv *)d;
+	PADAPTER padapter = dvobj_get_primary_adapter(pobj);
+	unsigned int pipe;
+	int status;
+	u32 ret = _FAIL, bwritezero = _FALSE;
+	PURB	purb = NULL;
+	struct dvobj_priv	*pdvobj = adapter_to_dvobj(padapter);
+	struct usb_device *pusbd = pdvobj->pusbdev;
+
+
+	purb	= usb_alloc_urb(0, GFP_KERNEL);
+	if (purb == NULL) {
+		RTW_ERR("purb == NULL\n");
+		return _FAIL;
+	}
+
+	/* translate DMA FIFO addr to pipehandle */
+	pipe = ffaddr2pipehdl(pdvobj, addr);
+
+
+	usb_fill_bulk_urb(purb, pusbd, pipe,
+			  wmem,
+			  cnt,
+			  usb_write_port_complete_not_xmitframe,
+			  padapter);
+
+
+#ifdef USB_PACKET_OFFSET_SZ
+#if (USB_PACKET_OFFSET_SZ == 0)
+	purb->transfer_flags |= URB_ZERO_PACKET;
+#endif
+#endif
+
+#if 0
+	if (bwritezero)
+		purb->transfer_flags |= URB_ZERO_PACKET;
+#endif
+
+	status = usb_submit_urb(purb, GFP_ATOMIC);
+	if (!status) {
+		#ifdef DBG_CONFIG_ERROR_DETECT
+		{
+			HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+			pHalData->srestpriv.last_tx_time = rtw_get_current_time();
+		}
+		#endif
+	} else {
+		RTW_INFO("usb_write_port, status=%d\n", status);
+
+		switch (status) {
+		case -ENODEV:
+			break;
+		default:
+			break;
+		}
+		goto exit;
+	}
+
+	ret = _SUCCESS;
+
+exit:
+	if (ret != _SUCCESS)
+		usb_free_urb(purb);
+
+	return ret;
+}
+
+static u8 usb_write_data_not_xmitframe(void *d, u8 *pBuf, u32 size, u8 qsel)
+{
+	struct dvobj_priv *pobj = (struct dvobj_priv *)d;
+	PADAPTER padapter = dvobj_get_primary_adapter(pobj);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	u32 desclen, len;
+	u8 *buf;
+	u8 ret;
+	u8 addr;
+	u8 add_pkt_offset = 0;
+
+
+	desclen = rtl8822b_get_tx_desc_size(padapter);
+	len = desclen + size;
+
+	if (qsel == HALMAC_TXDESC_QSEL_BEACON) {
+
+		if (len % pHalData->UsbBulkOutSize == 0)
+			add_pkt_offset = 1;
+
+		if (add_pkt_offset == 1)
+			len = len + PACKET_OFFSET_SZ;
+
+		buf = rtw_zmalloc(len);
+		if (!buf)
+			return _FALSE;
+
+		if (add_pkt_offset == 1)
+			_rtw_memcpy(buf + desclen + PACKET_OFFSET_SZ , pBuf, size);
+		else
+			_rtw_memcpy(buf + desclen, pBuf, size);
+
+		SET_TX_DESC_TXPKTSIZE_8822B(buf, size);
+		if (add_pkt_offset == 1) {
+			SET_TX_DESC_OFFSET_8822B(buf, desclen + PACKET_OFFSET_SZ);
+			SET_TX_DESC_PKT_OFFSET_8822B(buf, 1);
+		} else
+			SET_TX_DESC_OFFSET_8822B(buf, desclen);
+
+	} else if (qsel == HALMAC_TXDESC_QSEL_H2C_CMD){
+
+		buf = rtw_zmalloc(len);
+		if (!buf)
+			return _FALSE;
+
+		_rtw_memcpy(buf + desclen, pBuf, size);
+
+		SET_TX_DESC_TXPKTSIZE_8822B(buf, size);
+	} else {
+
+		RTW_ERR("%s: qsel may be error(%d)\n", __func__, qsel);
+
+		return _FALSE;
+	}
+
+	SET_TX_DESC_QSEL_8822B(buf, qsel);
+	rtl8822b_cal_txdesc_chksum(padapter, buf);
+
+	addr = rtw_halmac_usb_get_bulkout_id(d, buf, len);
+	ret = usb_write_port_not_xmitframe(d, addr, len , buf);
+	if (_SUCCESS == ret) {
+		ret = _TRUE;
+	} else {
+		RTW_ERR("%s , rtl8822bu_simple_write_port fail\n", __func__);
+		rtw_mfree(buf , len);
+		ret = _FALSE;
+	}
+
+	return ret;
+
+}
+
+static u8 usb_write_data_rsvd_page_normal(void *d, u8 *pBuf, u32 size)
+{
+	struct dvobj_priv *pobj = (struct dvobj_priv *)d;
+	PADAPTER padapter = dvobj_get_primary_adapter(pobj);
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+	struct xmit_frame	*pcmdframe = NULL;
+	struct pkt_attrib	*pattrib = NULL;
+	u8 txdesoffset = 0;
+	u8 *buf = NULL;
+
+	if (size + TXDESC_OFFSET > MAX_CMDBUF_SZ) {
+		RTW_INFO("%s: total buffer size(%d) > MAX_CMDSZE(%d)\n"
+			 , __func__, size + TXDESC_OFFSET, MAX_CMDSZ);
+		return _FALSE;
+	}
+
+	pcmdframe = rtw_alloc_cmdxmitframe(pxmitpriv);
+
+	if (pcmdframe == NULL) {
+		RTW_INFO("%s: alloc cmd frame fail!\n", __func__);
+		return _FALSE;
+	}
+
+	txdesoffset = TXDESC_OFFSET;
+	buf = pcmdframe->buf_addr;
+	_rtw_memcpy((buf + txdesoffset), pBuf, size); /* shift desclen */
+
+	/* update attribute */
+	pattrib = &pcmdframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+	pattrib->qsel = HALMAC_TXDESC_QSEL_BEACON;
+	pattrib->pktlen = size;
+	pattrib->last_txcmdsz = size;
+
+	/* fill tx desc in dump_mgntframe */
+	dump_mgntframe(padapter, pcmdframe);
+
+	return _TRUE;
+}
+
+static u8 usb_write_data_h2c_normal(void *d, u8 *pBuf, u32 size)
+{
+	struct dvobj_priv *pobj = (struct dvobj_priv *)d;
+	PADAPTER padapter = dvobj_get_primary_adapter(pobj);
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+	struct xmit_frame	*pcmdframe = NULL;
+	struct pkt_attrib	*pattrib = NULL;
+	u8 txdesoffset = 0;
+	u8 *buf = NULL;
+
+	if (size + TXDESC_OFFSET > MAX_XMIT_EXTBUF_SZ) {
+		RTW_INFO("%s: total buffer size(%d) > MAX_XMIT_EXTBUF_SZ(%d)\n"
+			 , __func__, size + TXDESC_OFFSET, MAX_XMIT_EXTBUF_SZ);
+		return _FALSE;
+	}
+
+	pcmdframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pcmdframe == NULL) {
+		RTW_INFO("%s: alloc cmd frame fail!\n", __func__);
+		return _FALSE;
+	}
+
+	txdesoffset = TXDESC_SIZE;
+	buf = pcmdframe->buf_addr;
+	_rtw_memcpy(buf + txdesoffset, pBuf, size); /* shift desclen */
+
+	/* update attribute */
+	pattrib = &pcmdframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+	pattrib->qsel = HALMAC_TXDESC_QSEL_H2C_CMD;
+	pattrib->pktlen = size;
+	pattrib->last_txcmdsz = size;
+
+	/* fill tx desc in dump_mgntframe */
+	dump_mgntframe(padapter, pcmdframe);
+
+	return _TRUE;
+
+}
+
+
+static u8 usb_write_data_rsvd_page(void *d, u8 *pBuf, u32 size)
+{
+	struct dvobj_priv *pobj = (struct dvobj_priv *)d;
+	PADAPTER padapter = dvobj_get_primary_adapter(pobj);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	if (pHalData->not_xmitframe_fw_dl)
+		return usb_write_data_not_xmitframe(d , pBuf , size, HALMAC_TXDESC_QSEL_BEACON);
+	else
+		return usb_write_data_rsvd_page_normal(d , pBuf , size);
+}
+
+static u8 usb_write_data_h2c(void *d, u8 *pBuf, u32 size)
+{
+	struct dvobj_priv *pobj = (struct dvobj_priv *)d;
+	PADAPTER padapter = dvobj_get_primary_adapter(pobj);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	if (pHalData->not_xmitframe_fw_dl)
+		return usb_write_data_not_xmitframe(d , pBuf , size, HALMAC_TXDESC_QSEL_H2C_CMD);
+	else
+		return usb_write_data_h2c_normal(d , pBuf , size);
+}
+
+int rtl8822bu_halmac_init_adapter(PADAPTER padapter)
+{
+	struct dvobj_priv *d;
+	struct halmac_platform_api *api;
+	int err;
+
+
+	d = adapter_to_dvobj(padapter);
+	api = &rtw_halmac_platform_api;
+	api->SEND_RSVD_PAGE = usb_write_data_rsvd_page;
+	api->SEND_H2C_PKT = usb_write_data_h2c;
+
+	err = rtw_halmac_init_adapter(d, api);
+
+	return err;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_io.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_io.c
new file mode 100644
index 000000000000..63584f8f57d9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_io.c
@@ -0,0 +1,51 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_IO_C_
+
+#include <drv_types.h>		/* PADAPTER and etc. */
+
+void rtl8822bu_set_intf_ops(struct _io_ops *pops)
+{
+
+	_rtw_memset((u8 *)pops, 0, sizeof(struct _io_ops));
+
+	pops->_read8 = &usb_read8;
+	pops->_read16 = &usb_read16;
+	pops->_read32 = &usb_read32;
+	pops->_read_mem = &usb_read_mem;
+	pops->_read_port = &usb_read_port;
+
+	pops->_write8 = &usb_write8;
+	pops->_write16 = &usb_write16;
+	pops->_write32 = &usb_write32;
+	pops->_writeN = &usb_writeN;
+
+#ifdef CONFIG_USB_SUPPORT_ASYNC_VDN_REQ
+	pops->_write8_async = &usb_async_write8;
+	pops->_write16_async = &usb_async_write16;
+	pops->_write32_async = &usb_async_write32;
+#endif
+	pops->_write_mem = &usb_write_mem;
+	pops->_write_port = &usb_write_port;
+
+	pops->_read_port_cancel = &usb_read_port_cancel;
+	pops->_write_port_cancel = &usb_write_port_cancel;
+
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+	pops->_read_interrupt = &usb_read_interrupt;
+#endif
+
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_led.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_led.c
new file mode 100644
index 000000000000..d684eebc19c5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_led.c
@@ -0,0 +1,142 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_LED_C_
+
+#include <drv_types.h>		/* PADAPTER */
+#include <hal_data.h>		/* PHAL_DATA_TYPE */
+#include <hal_com_led.h>	/* PLED_USB */
+#include "../../hal_halmac.h" /* HALMAC API */
+#ifdef CONFIG_RTW_SW_LED
+
+/*
+ * =============================================================================
+ * LED object.
+ * =============================================================================
+ */
+
+
+/*
+ * =============================================================================
+ * Prototype of protected function.
+ * =============================================================================
+ */
+
+/*
+ * =============================================================================
+ * LED routines.
+ * =============================================================================
+ */
+
+/*
+ * Description:
+ * Turn on LED according to LedPin specified.
+ */
+static void swledon(PADAPTER padapter, PLED_USB led)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+
+	if (RTW_CANNOT_RUN(padapter))
+		return;
+
+	switch (led->LedPin) {
+	case LED_PIN_GPIO0:
+		break;
+	case LED_PIN_LED0:
+	case LED_PIN_LED1:
+	case LED_PIN_LED2:
+	default:
+		rtw_halmac_led_switch(adapter_to_dvobj(padapter), 1);
+		break;
+	}
+
+	led->bLedOn = _TRUE;
+}
+
+
+/*
+ * Description:
+ * Turn off LED according to LedPin specified.
+ */
+static void swledoff(PADAPTER padapter, PLED_USB led)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+
+	if (RTW_CANNOT_RUN(padapter))
+		return;
+
+	switch (led->LedPin) {
+	case LED_PIN_GPIO0:
+		break;
+	case LED_PIN_LED0:
+	case LED_PIN_LED1:
+	case LED_PIN_LED2:
+	default:
+		rtw_halmac_led_switch(adapter_to_dvobj(padapter), 0);
+		break;
+	}
+
+	led->bLedOn = _FALSE;
+}
+
+/*
+ * =============================================================================
+ * Interface to manipulate LED objects.
+ * =============================================================================
+ */
+
+/*
+ * =============================================================================
+ * Default LED behavior.
+ * =============================================================================
+ */
+
+/*
+ * Description:
+ * Initialize all LED_871x objects.
+ */
+void rtl8822bu_initswleds(PADAPTER padapter)
+{
+	struct led_priv *ledpriv = adapter_to_led(padapter);
+	u8 enable = 1;
+	u8 mode = 3;
+
+	ledpriv->LedControlHandler = LedControlUSB;
+	ledpriv->SwLedOn = swledon;
+	ledpriv->SwLedOff = swledoff;
+
+	InitLed(padapter, &(ledpriv->SwLed0), LED_PIN_LED0);
+	InitLed(padapter, &(ledpriv->SwLed1), LED_PIN_LED1);
+	InitLed(padapter, &(ledpriv->SwLed2), LED_PIN_LED2);
+
+	rtw_halmac_led_cfg(adapter_to_dvobj(padapter), enable, mode);
+}
+
+/*
+ * Description:
+ * DeInitialize all LED_819xUsb objects.
+ */
+void rtl8822bu_deinitswleds(PADAPTER padapter)
+{
+	struct led_priv *ledpriv = adapter_to_led(padapter);
+	u8 enable = 0;
+	u8 mode = 3;
+
+	DeInitLed(&(ledpriv->SwLed0));
+	DeInitLed(&(ledpriv->SwLed1));
+	DeInitLed(&(ledpriv->SwLed2));
+
+	rtw_halmac_led_cfg(adapter_to_dvobj(padapter), enable, mode);
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_ops.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_ops.c
new file mode 100644
index 000000000000..09865835797d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_ops.c
@@ -0,0 +1,355 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_OPS_C_
+
+#include <drv_types.h>			/* PADAPTER, basic_types.h and etc. */
+#include <hal_intf.h>			/* struct hal_ops */
+#include <hal_data.h>			/* HAL_DATA_TYPE */
+#include "../../hal_halmac.h"		/* register define */
+#include "../rtl8822b.h"		/* 8822b hal common define. rtl8822bu_init_default_value ...*/
+#include "rtl8822bu.h"			/* 8822bu functions */
+
+#ifdef CONFIG_SUPPORT_USB_INT
+static void rtl8822bu_interrupt_handler(PADAPTER padapter, u16 pkt_len, u8 *pbuf)
+{	
+	}
+#endif /* CONFIG_SUPPORT_USB_INT */
+
+void rtl8822bu_set_hw_type(struct dvobj_priv *pdvobj)
+{
+	pdvobj->HardwareType = HARDWARE_TYPE_RTL8822BU;
+	RTW_INFO("CHIP TYPE: RTL8822B\n");
+}
+
+static u8 sethwreg(PADAPTER padapter, u8 variable, u8 *val)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+	struct registry_priv *registry_par = &padapter->registrypriv;
+	int status = 0;
+	u8 ret = _SUCCESS;
+
+	switch (variable) {
+	case HW_VAR_RXDMA_AGG_PG_TH:
+#ifdef CONFIG_USB_RX_AGGREGATION
+		if (pdvobjpriv->traffic_stat.cur_tx_tp < 1 && pdvobjpriv->traffic_stat.cur_rx_tp < 1) {
+			/* for low traffic, do not usb AGGREGATION */
+			pHalData->rxagg_usb_timeout = 0x01;
+			pHalData->rxagg_usb_size = 0x01;
+
+		} else {
+#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+			pHalData->rxagg_usb_timeout = 0x20;
+			pHalData->rxagg_usb_size = 0x03;
+#elif defined(CONFIG_PLATFORM_HISILICON)
+			/* use 16k to workaround for HISILICON platform */
+			pHalData->rxagg_usb_timeout = 8;
+			pHalData->rxagg_usb_size = 3;
+#else
+			/* default setting */
+			pHalData->rxagg_usb_timeout = 0x20;
+			pHalData->rxagg_usb_size = 0x05;
+#endif
+		}
+		rtw_halmac_rx_agg_switch(pdvobjpriv, _TRUE);
+#if 0
+		RTW_INFO("\n==========RAFFIC_STATISTIC==============\n");
+		RTW_INFO("cur_tx_bytes:%lld\n", pdvobjpriv->traffic_stat.cur_tx_bytes);
+		RTW_INFO("cur_rx_bytes:%lld\n", pdvobjpriv->traffic_stat.cur_rx_bytes);
+
+		RTW_INFO("last_tx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_tx_bytes);
+		RTW_INFO("last_rx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_rx_bytes);
+
+		RTW_INFO("cur_tx_tp:%d\n", pdvobjpriv->traffic_stat.cur_tx_tp);
+		RTW_INFO("cur_rx_tp:%d\n", pdvobjpriv->traffic_stat.cur_rx_tp);
+		RTW_INFO("\n========================\n");
+#endif
+#endif
+		break;
+	case HW_VAR_SET_RPWM:
+#ifdef CONFIG_LPS_LCLK
+		{
+			u8	ps_state = *((u8 *)val);
+
+			/*rpwm value only use BIT0(clock bit) ,BIT6(Ack bit), and BIT7(Toggle bit) for 88e.
+			BIT0 value - 1: 32k, 0:40MHz.
+			BIT6 value - 1: report cpwm value after success set, 0:do not report.
+			BIT7 value - Toggle bit change.
+			modify by Thomas. 2012/4/2.*/
+			ps_state = ps_state & 0xC1;
+			/* RTW_INFO("##### Change RPWM value to = %x for switch clk #####\n", ps_state); */
+			rtw_write8(padapter, REG_USB_HRPWM_8822B, ps_state);
+		}
+#endif
+		break;
+	case HW_VAR_AMPDU_MAX_TIME:
+		rtw_write8(padapter, REG_AMPDU_MAX_TIME_V1_8822B, 0x70);
+		break;
+	case HW_VAR_USB_MODE:
+		/* U2 to U3 */
+		if (registry_par->switch_usb_mode == 1) {
+			if (IS_HIGH_SPEED_USB(padapter)) {
+				status = rtw_halmac_switch_usb_mode(adapter_to_dvobj(padapter), RTW_USB_SPEED_3);
+				if (status)
+					*val = _TRUE;
+			}
+		} else if (registry_par->switch_usb_mode == 2) {
+			/* U3 to U2 */
+			if (IS_SUPER_SPEED_USB(padapter)) {
+				status = rtw_halmac_switch_usb_mode(adapter_to_dvobj(padapter), RTW_USB_SPEED_2);
+				if (status)
+					*val = _TRUE;
+			}
+		}
+		break;
+	case HW_VAR_SET_REQ_FW_PS:
+	{
+		/*
+		 * 1. driver write 0x8f[4]=1
+		 *    request fw ps state (only can write bit4)
+		 */
+		u8 req_fw_ps = 0;
+
+		req_fw_ps = rtw_read8(padapter, 0x8f);
+		req_fw_ps |= 0x10;
+		rtw_write8(padapter, 0x8f, req_fw_ps);
+	}
+	break;
+	default:
+		ret = rtl8822b_sethwreg(padapter, variable, val);
+		break;
+	}
+
+	return ret;
+}
+
+static void gethwreg(PADAPTER padapter, u8 variable, u8 *val)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+
+	switch (variable) {
+	case HW_VAR_CPWM:
+#ifdef CONFIG_LPS_LCLK
+		*val = rtw_read8(padapter, REG_USB_HCPWM_8822B);
+		/* RTW_INFO("##### REG_USB_HCPWM(0x%02x) = 0x%02x #####\n", REG_USB_HCPWM_8822B, *val); */
+#endif /* CONFIG_LPS_LCLK */
+		break;
+	case HW_VAR_RPWM_TOG:
+#ifdef CONFIG_LPS_LCLK
+		*val = rtw_read8(padapter, REG_USB_HRPWM_8822B);
+		*val &= BIT_TOGGLE_8822B;
+#endif /* CONFIG_LPS_LCLK */
+		break;
+
+	case HW_VAR_FW_PS_STATE:
+		/* driver read dword 0x88 to get fw ps state */
+		*((u16 *)val) = rtw_read16(padapter, 0x88);
+		break;
+	default:
+		rtl8822b_gethwreg(padapter, variable, val);
+		break;
+	}
+
+}
+
+/*
+	Description:
+		Change default setting of specified variable.
+*/
+static u8 sethaldefvar(PADAPTER padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 bResult = _SUCCESS;
+
+	switch (eVariable) {
+	default:
+		rtl8822b_sethaldefvar(padapter, eVariable, pValue);
+		break;
+	}
+
+	return bResult;
+}
+
+/*
+	Description:
+		Query setting of specified variable.
+*/
+static u8 gethaldefvar(PADAPTER	padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 bResult = _SUCCESS;
+
+	switch (eVariable) {
+	case HW_VAR_MAX_RX_AMPDU_FACTOR:
+		*(HT_CAP_AMPDU_FACTOR *)pValue = MAX_AMPDU_FACTOR_64K;
+		break;
+	default:
+		bResult = rtl8822b_gethaldefvar(padapter, eVariable, pValue);
+		break;
+	}
+
+	return bResult;
+}
+
+static void rtl8822bu_init_default_value(PADAPTER	padapter)
+{
+	rtl8822b_init_default_value(padapter);
+}
+
+static u8 rtl8822bu_ps_func(PADAPTER padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val)
+{
+	u8 bResult = _TRUE;
+
+	switch (efunc_id) {
+
+#if defined(CONFIG_AUTOSUSPEND) && defined(SUPPORT_HW_RFOFF_DETECTED)
+	case HAL_USB_SELECT_SUSPEND:
+		break;
+#endif /* CONFIG_AUTOSUSPEND && SUPPORT_HW_RFOFF_DETECTED */
+
+	default:
+		break;
+	}
+	return bResult;
+}
+
+#ifdef CONFIG_RTW_LED
+static void read_ledsetting(PADAPTER adapter)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+#ifdef CONFIG_RTW_SW_LED
+	PHAL_DATA_TYPE hal;
+	
+	hal = GET_HAL_DATA(adapter);
+	ledpriv->bRegUseLed = _TRUE;
+
+	switch (hal->EEPROMCustomerID) {
+	default:
+		hal->CustomerID = RT_CID_DEFAULT;
+		break;
+	}
+
+	switch (hal->CustomerID) {
+	case RT_CID_DEFAULT:
+	default:
+		ledpriv->LedStrategy = SW_LED_MODE9;
+		break;
+	}
+#else /* HW LED */
+	ledpriv->LedStrategy = HW_LED;
+#endif /* CONFIG_RTW_SW_LED */
+}
+#endif /* CONFIG_RTW_LED */
+ 
+
+/*
+ * Description:
+ *	Collect all hardware information, fill "HAL_DATA_TYPE".
+ *	Sometimes this would be used to read MAC address.
+ *	This function will do
+ *	1. Read Efuse/EEPROM to initialize
+ *	2. Read registers to initialize
+ *	3. Other vaiables initialization
+ */
+static u8 read_adapter_info(PADAPTER padapter)
+{
+	u8 ret = _FAIL;
+
+	/*
+	 * 1. Read Efuse/EEPROM to initialize
+	 */
+	if (rtl8822b_read_efuse(padapter) != _SUCCESS)
+		goto exit;
+
+	/*
+	 * 2. Read registers to initialize
+	 */
+
+	/*
+	 * 3. Other Initialization
+	 */
+
+#ifdef CONFIG_RTW_LED
+	read_ledsetting(padapter);
+#endif /* CONFIG_RTW_LED */
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+
+void rtl8822bu_set_hal_ops(PADAPTER padapter)
+{
+	struct hal_ops *ops;
+	int err;
+
+
+	err = rtl8822bu_halmac_init_adapter(padapter);
+	if (err) {
+		RTW_INFO("%s: [ERROR]HALMAC initialize FAIL!\n", __func__);
+		return;
+	}
+
+	rtl8822b_set_hal_ops(padapter);
+
+	ops = &padapter->hal_func;
+
+	ops->hal_init = rtl8822bu_init;
+	ops->hal_deinit = rtl8822bu_deinit;
+
+	ops->inirp_init = rtl8822bu_inirp_init;
+	ops->inirp_deinit = rtl8822bu_inirp_deinit;
+
+	ops->init_xmit_priv = rtl8822bu_init_xmit_priv;
+	ops->free_xmit_priv = rtl8822bu_free_xmit_priv;
+
+	ops->init_recv_priv = rtl8822bu_init_recv_priv;
+	ops->free_recv_priv = rtl8822bu_free_recv_priv;
+#ifdef CONFIG_RTW_SW_LED
+	ops->InitSwLeds = rtl8822bu_initswleds;
+	ops->DeInitSwLeds = rtl8822bu_deinitswleds;
+#endif
+
+	ops->init_default_value = rtl8822bu_init_default_value;
+	ops->intf_chip_configure = rtl8822bu_interface_configure;
+	ops->read_adapter_info = read_adapter_info;
+
+	ops->set_hw_reg_handler = sethwreg;
+	ops->GetHwRegHandler = gethwreg;
+	ops->get_hal_def_var_handler = gethaldefvar;
+	ops->SetHalDefVarHandler = sethaldefvar;
+
+
+	ops->hal_xmit = rtl8822bu_hal_xmit;
+	ops->mgnt_xmit = rtl8822bu_mgnt_xmit;
+	ops->hal_xmitframe_enqueue = rtl8822bu_hal_xmitframe_enqueue;
+
+#ifdef CONFIG_HOSTAPD_MLME
+	ops->hostap_mgnt_xmit_entry = rtl8822bu_hostap_mgnt_xmit_entry;
+#endif
+	ops->interface_ps_func = rtl8822bu_ps_func;
+#ifdef CONFIG_XMIT_THREAD_MODE
+	ops->xmit_thread_handler = rtl8822bu_xmit_buf_handler;
+#endif
+#ifdef CONFIG_SUPPORT_USB_INT
+	ops->interrupt_handler = rtl8822bu_interrupt_handler;
+#endif
+
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_recv.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_recv.c
new file mode 100644
index 000000000000..e889b96a5121
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_recv.c
@@ -0,0 +1,171 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_RECV_C_
+
+#include <drv_types.h>			/* PADAPTER, rtw_xmit.h and etc. */
+#include <hal_data.h>			/* HAL_DATA_TYPE */
+#include "../../hal_halmac.h"		/* RX desc */
+#include "../rtl8822b.h"		/* rtl8822b_query_rx_desc, rtl8822b_c2h_handler_no_io() */
+
+int rtl8822bu_init_recv_priv(PADAPTER padapter)
+{
+	return usb_init_recv_priv(padapter, INTERRUPT_MSG_FORMAT_LEN);
+}
+
+void rtl8822bu_free_recv_priv(PADAPTER padapter)
+{
+	usb_free_recv_priv(padapter, INTERRUPT_MSG_FORMAT_LEN);
+}
+
+static u8 recvbuf2recvframe_proccess_c2h(PADAPTER padapter, u8 *pbuf, s32 transfer_len)
+{
+	u8 ret = _SUCCESS;
+
+	/* send rx desc + c2h content to halmac */
+	rtl8822b_c2h_handler_no_io(padapter, pbuf, transfer_len);
+
+exit:
+	return ret;
+}
+
+static u8 recvbuf2recvframe_proccess_normal_rx
+(PADAPTER padapter, u8 *pbuf, struct rx_pkt_attrib *pattrib, union recv_frame *precvframe, _pkt *pskb)
+{
+	u8 ret = _SUCCESS;
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	_queue *pfree_recv_queue = &precvpriv->free_recv_queue;
+
+#ifdef CONFIG_RX_PACKET_APPEND_FCS
+	if (check_fwstate(&padapter->mlmepriv, WIFI_MONITOR_STATE) == _FALSE) {
+		if (rtl8822b_rx_fcs_appended(padapter))
+			pattrib->pkt_len -= IEEE80211_FCS_LEN;
+	}
+#endif
+
+	if (rtw_os_alloc_recvframe(padapter, precvframe,
+		(pbuf + pattrib->shift_sz + pattrib->drvinfo_sz + RXDESC_SIZE), pskb) == _FAIL) {
+
+		rtw_free_recvframe(precvframe, pfree_recv_queue);
+		ret = _FAIL;
+		goto exit;
+	}
+
+	recvframe_put(precvframe, pattrib->pkt_len);
+
+	pre_recv_entry(precvframe, pattrib->physt ? (pbuf + RXDESC_OFFSET) : NULL);
+
+exit:
+	return ret;
+}
+
+int recvbuf2recvframe(PADAPTER padapter, void *ptr)
+{
+	u8 *pbuf;
+	u8 pkt_cnt = 0;
+	u32 pkt_offset;
+	s32 transfer_len;
+	u8 *pphy_status = NULL;
+	union recv_frame *precvframe = NULL;
+	struct rx_pkt_attrib *pattrib = NULL;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	_queue *pfree_recv_queue = &precvpriv->free_recv_queue;
+	_pkt *pskb;
+
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+	pskb = NULL;
+	transfer_len = (s32)((struct recv_buf *)ptr)->transfer_len;
+	pbuf = ((struct recv_buf *)ptr)->pbuf;
+#else /* !CONFIG_USE_USB_BUFFER_ALLOC_RX */
+	pskb = (_pkt *)ptr;
+	transfer_len = (s32)pskb->len;
+	pbuf = pskb->data;
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
+
+
+#ifdef CONFIG_USB_RX_AGGREGATION
+	pkt_cnt = GET_RX_DESC_DMA_AGG_NUM_8822B(pbuf);
+#endif
+
+	do {
+		precvframe = rtw_alloc_recvframe(pfree_recv_queue);
+		if (precvframe == NULL) {
+			RTW_INFO("%s()-%d: rtw_alloc_recvframe() failed! RX Drop!\n", __func__, __LINE__);
+			goto _exit_recvbuf2recvframe;
+		}
+
+		_rtw_init_listhead(&precvframe->u.hdr.list);
+		precvframe->u.hdr.precvbuf = NULL;	/* can't access the precvbuf for new arch */
+		precvframe->u.hdr.len = 0;
+
+		rtl8822b_query_rx_desc(precvframe, pbuf);
+
+		pattrib = &precvframe->u.hdr.attrib;
+
+		if ((padapter->registrypriv.mp_mode == 0) && ((pattrib->crc_err) || (pattrib->icv_err))) {
+			RTW_INFO("%s: RX Warning! crc_err=%d icv_err=%d, skip!\n", __func__, pattrib->crc_err, pattrib->icv_err);
+
+			rtw_free_recvframe(precvframe, pfree_recv_queue);
+			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)) {
+			RTW_INFO("%s()-%d: RX Warning!,pkt_len<=0(%d) or pkt_offset(%d)> transfer_len(%d)\n"
+				, __func__, __LINE__, pattrib->pkt_len, pkt_offset, transfer_len);
+			if (pkt_offset > transfer_len)
+				RTW_INFO("%s()-%d: RX Warning!,RXDESC_SIZE(%d), drvinfo_sz(%d), shift_sz(%d),pkt_len(%d)\n"
+					, __func__, __LINE__, RXDESC_SIZE, pattrib->drvinfo_sz, pattrib->shift_sz, pattrib->pkt_len);
+
+			rtw_free_recvframe(precvframe, pfree_recv_queue);
+			goto _exit_recvbuf2recvframe;
+		}
+
+		switch (pattrib->pkt_rpt_type) {
+		case C2H_PACKET:
+			/* C2H_PACKET doesn't use recvframe, so free it */
+			rtw_free_recvframe(precvframe, pfree_recv_queue);
+			if (recvbuf2recvframe_proccess_c2h(padapter, pbuf, transfer_len) == _FAIL)
+				goto _exit_recvbuf2recvframe;
+			break;
+		case TX_REPORT1:
+		case TX_REPORT2:
+		case HIS_REPORT:
+			RTW_INFO("%s: [WARNNING] RX type(%d) not be handled!\n", __func__, pattrib->pkt_rpt_type);
+			rtw_free_recvframe(precvframe, pfree_recv_queue);
+			break;
+		case NORMAL_RX:
+		default:
+			if (recvbuf2recvframe_proccess_normal_rx(padapter, pbuf, pattrib, precvframe, pskb) == _FAIL)
+				goto _exit_recvbuf2recvframe;
+			break;
+		}
+
+#ifdef CONFIG_USB_RX_AGGREGATION
+		/* jaguar 8-byte alignment */
+		pkt_offset = (u16)_RND8(pkt_offset);
+		pkt_cnt--;
+		pbuf += pkt_offset;
+#endif
+		transfer_len -= pkt_offset;
+		precvframe = NULL;
+
+	} while (transfer_len > 0);
+
+_exit_recvbuf2recvframe:
+
+	return _SUCCESS;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_xmit.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_xmit.c
new file mode 100644
index 000000000000..d2a9c9f08271
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/hal/rtl8822b/usb/rtl8822bu_xmit.c
@@ -0,0 +1,1074 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_XMIT_C_
+
+#include <drv_types.h>			/* PADAPTER, rtw_xmit.h and etc. */
+#include <hal_data.h>			/* HAL_DATA_TYPE */
+#include "../../hal_halmac.h"		/* halmac api */
+#include "../rtl8822b.h"		/* rtl8822b_update_txdesc() */
+#include "rtl8822bu.h"			/* OFFSET_SZ MAX_TX_AGG_PACKET_NUMBER_8822B */
+
+static void update_txdesc_h2c_pkt(struct xmit_frame *pxmitframe, u8 *pmem, s32 sz)
+{
+	u8 *ptxdesc =  pmem;
+	_adapter *padapter = pxmitframe->padapter;
+
+	_rtw_memset(ptxdesc, 0, TXDESC_SIZE);
+	SET_TX_DESC_TXPKTSIZE_8822B(ptxdesc, sz);
+	SET_TX_DESC_QSEL_8822B(ptxdesc, HALMAC_TXDESC_QSEL_H2C_CMD);
+	rtl8822b_cal_txdesc_chksum(padapter, ptxdesc);
+	rtl8822b_dbg_dump_tx_desc(padapter, pxmitframe->frame_tag, ptxdesc);
+}
+
+static s32 update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem, s32 sz, u8 bagg_pkt)
+{
+	int pull = 0;
+	uint qsel;
+	u8 data_rate, pwr_status, offset;
+	_adapter *padapter = pxmitframe->padapter;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 *ptxdesc =  pmem;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	sint	bmcst = IS_MCAST(pattrib->ra);
+	u16	SWDefineContent = 0x0;
+	u8	DriverFixedRate = 0x0;
+
+#ifndef CONFIG_USE_USB_BUFFER_ALLOC_TX
+	if (padapter->registrypriv.mp_mode == 0) {
+		if ((PACKET_OFFSET_SZ != 0) && (!bagg_pkt)
+		    && (rtw_usb_bulk_size_boundary(padapter, (TXDESC_SIZE + sz)) == _FALSE)) {
+			ptxdesc = (pmem + PACKET_OFFSET_SZ);
+			/* RTW_INFO("==> non-agg-pkt,shift pointer...\n"); */
+			pull = 1;
+		}
+	}
+#endif	/* !CONFIG_USE_USB_BUFFER_ALLOC_TX */
+
+	_rtw_memset(ptxdesc, 0, TXDESC_SIZE);
+
+	/* offset 0 */
+	SET_TX_DESC_LS_8822B(ptxdesc, 1);
+
+	/* RTW_INFO("%s==> pkt_len=%d,bagg_pkt=%02x\n",__FUNCTION__,sz,bagg_pkt); */
+	SET_TX_DESC_TXPKTSIZE_8822B(ptxdesc, sz);
+
+	offset = TXDESC_SIZE + OFFSET_SZ;
+
+#ifdef CONFIG_TX_EARLY_MODE
+	if (bagg_pkt)
+		offset += EARLY_MODE_INFO_SIZE;
+#endif
+	/* RTW_INFO("%s==>offset(0x%02x)\n",__FUNCTION__,offset); */
+	SET_TX_DESC_OFFSET_8822B(ptxdesc, offset);
+
+	if (bmcst)
+		SET_TX_DESC_BMC_8822B(ptxdesc, 1);
+
+#ifndef CONFIG_USE_USB_BUFFER_ALLOC_TX
+	if (padapter->registrypriv.mp_mode == 0) {
+		if ((PACKET_OFFSET_SZ != 0) && (!bagg_pkt)) {
+			if ((pull) && (pxmitframe->pkt_offset > 0))
+				pxmitframe->pkt_offset = pxmitframe->pkt_offset - 1;
+		}
+	}
+#endif /* !CONFIG_USE_USB_BUFFER_ALLOC_TX */
+
+	/* RTW_INFO("%s, pkt_offset=0x%02x\n",__FUNCTION__,pxmitframe->pkt_offset); */
+	/* pkt_offset, unit:8 bytes padding */
+	if (pxmitframe->pkt_offset > 0)
+		SET_TX_DESC_PKT_OFFSET_8822B(ptxdesc, pxmitframe->pkt_offset);
+
+	SET_TX_DESC_MACID_8822B(ptxdesc, pattrib->mac_id);
+	SET_TX_DESC_RATE_ID_8822B(ptxdesc, pattrib->raid);
+
+	SET_TX_DESC_QSEL_8822B(ptxdesc,  pattrib->qsel);
+
+	/*offset 12 */
+	if (!pattrib->qos_en) {
+		/* HW sequence, to fix to use 0 queue. todo: 4AC packets to use auto queue select */
+		SET_TX_DESC_EN_HWSEQ_8822B(ptxdesc, 1); /* Hw set sequence number */
+		SET_TX_DESC_EN_HWEXSEQ_8822B(ptxdesc, 0);
+		SET_TX_DESC_DISQSELSEQ_8822B(ptxdesc, 1);
+		SET_TX_DESC_HW_SSN_SEL_8822B(ptxdesc, 0);
+	} else
+		SET_TX_DESC_SW_SEQ_8822B(ptxdesc, pattrib->seqnum);
+
+	if ((pxmitframe->frame_tag & 0x0f) == DATA_FRAMETAG) {
+		/* RTW_INFO("pxmitframe->frame_tag == DATA_FRAMETAG\n");	*/
+		rtl8822b_fill_txdesc_sectype(pattrib, ptxdesc);
+
+		/* offset 20 */
+#ifdef CONFIG_USB_TX_AGGREGATION
+		if (pxmitframe->agg_num > 1) {
+			/* RTW_INFO("%s agg_num:%d\n",__FUNCTION__,pxmitframe->agg_num); */
+			SET_TX_DESC_DMA_TXAGG_NUM_8822B(ptxdesc, pxmitframe->agg_num);
+		}
+#endif /* CONFIG_USB_TX_AGGREGATION */
+
+		rtl8822b_fill_txdesc_vcs(padapter, pattrib, ptxdesc);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		if (bmcst)
+			rtl8822b_fill_txdesc_force_bmc_camid(pattrib, ptxdesc);
+#endif
+
+		if ((pattrib->ether_type != 0x888e) &&
+		    (pattrib->ether_type != 0x0806) &&
+		    (pattrib->ether_type != 0x88b4) &&
+		    (pattrib->dhcp_pkt != 1)
+#ifdef CONFIG_AUTO_AP_MODE
+		    && (pattrib->pctrl != _TRUE)
+#endif
+		   ) {
+			/* Non EAP & ARP & DHCP type data packet */
+			if (pattrib->ampdu_en == _TRUE) {
+				SET_TX_DESC_AGG_EN_8822B(ptxdesc, 1);
+				SET_TX_DESC_MAX_AGG_NUM_8822B(ptxdesc, 0x1f);
+				/* Set A-MPDU aggregation */
+				SET_TX_DESC_AMPDU_DENSITY_8822B(ptxdesc, pattrib->ampdu_spacing);
+			} else
+				SET_TX_DESC_BK_8822B(ptxdesc, 1);
+
+			rtl8822b_fill_txdesc_phy(padapter, pattrib, ptxdesc);
+
+			/* compatibility for MCC consideration, use pmlmeext->cur_channel */
+			if (!bmcst) {
+				if (pmlmeext->cur_channel > 14)
+					/* for 5G. OFDM 6M */
+					SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(ptxdesc, 4);
+				else
+					/* for 2.4G. CCK 1M */
+					SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(ptxdesc, 0);
+			}
+
+			if (pHalData->fw_ractrl == _FALSE) {
+				SET_TX_DESC_USE_RATE_8822B(ptxdesc, 1);
+				DriverFixedRate = 0x01;
+
+				if (pHalData->INIDATA_RATE[pattrib->mac_id] & BIT(7))
+					SET_TX_DESC_DATA_SHORT_8822B(ptxdesc, 1);
+
+				SET_TX_DESC_DATARATE_8822B(ptxdesc, (pHalData->INIDATA_RATE[pattrib->mac_id] & 0x7F));
+			}
+			if (bmcst) {
+				DriverFixedRate = 0x01;
+				rtl8822b_fill_txdesc_bmc_tx_rate(pattrib, ptxdesc);
+			}
+
+			/* modify data rate by iwpriv or proc */
+			if (padapter->fix_rate != 0xFF) {
+				SET_TX_DESC_USE_RATE_8822B(ptxdesc, 1);
+
+				DriverFixedRate = 0x01;
+				if (padapter->fix_rate & BIT(7))
+					SET_TX_DESC_DATA_SHORT_8822B(ptxdesc, 1);
+
+				SET_TX_DESC_DATARATE_8822B(ptxdesc, (padapter->fix_rate & 0x7F));
+
+				if (!padapter->data_fb)
+					SET_TX_DESC_DISDATAFB_8822B(ptxdesc, 1);
+			}
+
+			if (pattrib->ldpc)
+				SET_TX_DESC_DATA_LDPC_8822B(ptxdesc, 1);
+
+			if (pattrib->stbc)
+				SET_TX_DESC_DATA_STBC_8822B(ptxdesc, 1);
+
+#ifdef CONFIG_WMMPS_STA
+			if (pattrib->trigger_frame)
+				SET_TX_DESC_TRI_FRAME_8822B (ptxdesc, 1);
+#endif /* CONFIG_WMMPS_STA */			
+
+		} else {
+			/*
+				EAP data packet and ARP packet and DHCP.
+				Use the 1M data rate to send the EAP/ARP packet.
+				This will maybe make the handshake smooth.
+			*/
+
+			SET_TX_DESC_USE_RATE_8822B(ptxdesc, 1);
+			DriverFixedRate = 0x01;
+			SET_TX_DESC_BK_8822B(ptxdesc, 1);
+
+			/* HW will ignore this setting if the transmission rate is legacy OFDM */
+			if (pmlmeinfo->preamble_mode == PREAMBLE_SHORT)
+				SET_TX_DESC_DATA_SHORT_8822B(ptxdesc, 1);
+
+			SET_TX_DESC_DATARATE_8822B(ptxdesc, MRateToHwRate(pmlmeext->tx_rate));
+		}
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_XMIT_ACK
+		/* CCX-TXRPT ack for xmit data frames */
+		if (pxmitframe->ack_report) {
+			SET_TX_DESC_SPE_RPT_8822B(ptxdesc, 1);
+#ifdef DBG_CCX
+			RTW_INFO("%s set tx report\n", __func__);
+#endif
+		}
+#endif /* CONFIG_XMIT_ACK */
+#endif
+	} else if ((pxmitframe->frame_tag & 0x0f) == MGNT_FRAMETAG) {
+		/* RTW_INFO("pxmitframe->frame_tag == MGNT_FRAMETAG\n");	*/
+
+		SET_TX_DESC_USE_RATE_8822B(ptxdesc, 1);
+		DriverFixedRate = 0x01;
+
+		SET_TX_DESC_DATARATE_8822B(ptxdesc, MRateToHwRate(pattrib->rate));
+
+		SET_TX_DESC_RTY_LMT_EN_8822B(ptxdesc, 1);
+		if (pattrib->retry_ctrl == _TRUE)
+			SET_TX_DESC_RTS_DATA_RTY_LMT_8822B(ptxdesc, 6);
+		else
+			SET_TX_DESC_RTS_DATA_RTY_LMT_8822B(ptxdesc, 12);
+
+		/* VHT NDPA or HT NDPA Packet for Beamformer. */
+		rtl8822b_fill_txdesc_mgnt_bf(pxmitframe, ptxdesc);
+
+#ifdef CONFIG_XMIT_ACK
+		/* CCX-TXRPT ack for xmit mgmt frames */
+		if (pxmitframe->ack_report) {
+			SET_TX_DESC_SPE_RPT_8822B(ptxdesc, 1);
+#ifdef DBG_CCX
+			RTW_INFO("%s set tx report\n", __func__);
+#endif
+		}
+#endif /* CONFIG_XMIT_ACK */
+	} else if ((pxmitframe->frame_tag & 0x0f) == TXAGG_FRAMETAG)
+		RTW_INFO("pxmitframe->frame_tag == TXAGG_FRAMETAG\n");
+
+#ifdef CONFIG_MP_INCLUDED
+	else if (((pxmitframe->frame_tag & 0x0f) == MP_FRAMETAG) &&
+		 (padapter->registrypriv.mp_mode == 1))
+
+		fill_txdesc_for_mp(padapter, ptxdesc);
+#endif
+
+	else {
+		RTW_INFO("pxmitframe->frame_tag = %d\n", pxmitframe->frame_tag);
+
+		SET_TX_DESC_USE_RATE_8822B(ptxdesc, 1);
+		DriverFixedRate = 0x01;
+		SET_TX_DESC_DATARATE_8822B(ptxdesc, MRateToHwRate(pmlmeext->tx_rate));
+	}
+
+	rtl8822b_fill_txdesc_bf(pxmitframe, ptxdesc);
+
+	if (DriverFixedRate)
+		SWDefineContent |= 0x01;
+
+	SET_TX_DESC_SW_DEFINE_8822B(ptxdesc, SWDefineContent);
+
+	SET_TX_DESC_PORT_ID_8822B(ptxdesc, get_hw_port(padapter));
+	SET_TX_DESC_MULTIPLE_PORT_8822B(ptxdesc, get_hw_port(padapter));
+
+	rtl8822b_cal_txdesc_chksum(padapter, ptxdesc);
+	rtl8822b_dbg_dump_tx_desc(padapter, pxmitframe->frame_tag, ptxdesc);
+	return pull;
+}
+
+
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+/*
+ * Description
+ *	Transmit xmitbuf to hardware tx fifo
+ *
+ * Return
+ *	_SUCCESS	ok
+ *	_FAIL		something error
+ */
+s32 rtl8822bu_xmit_buf_handler(PADAPTER padapter)
+{
+	PHAL_DATA_TYPE phal;
+	struct xmit_priv *pxmitpriv;
+	struct xmit_buf *pxmitbuf;
+	s32 ret;
+
+
+	phal = GET_HAL_DATA(padapter);
+	pxmitpriv = &padapter->xmitpriv;
+
+	ret = _rtw_down_sema(&pxmitpriv->xmit_sema);
+	if (_FAIL == ret)
+		return _FAIL;
+
+	if (RTW_CANNOT_RUN(padapter)) {
+		RTW_DBG(FUNC_ADPT_FMT "- bDriverStopped(%s) bSurpriseRemoved(%s)\n",
+			FUNC_ADPT_ARG(padapter),
+			rtw_is_drv_stopped(padapter) ? "True" : "False",
+			rtw_is_surprise_removed(padapter) ? "True" : "False");
+		return _FAIL;
+	}
+
+	if (check_pending_xmitbuf(pxmitpriv) == _FALSE)
+		return _SUCCESS;
+
+#ifdef CONFIG_LPS_LCLK
+	ret = rtw_register_tx_alive(padapter);
+	if (ret != _SUCCESS) {
+		return _SUCCESS;
+	}
+#endif /* CONFIG_LPS_LCLK */
+
+	do {
+		pxmitbuf = dequeue_pending_xmitbuf(pxmitpriv);
+		if (pxmitbuf == NULL)
+			break;
+
+		/* only XMITBUF_DATA & XMITBUF_MGNT */
+		rtw_write_port_and_wait(padapter, pxmitbuf->ff_hwaddr, pxmitbuf->len, (unsigned char *)pxmitbuf, 500);
+	} while (1);
+
+#ifdef CONFIG_LPS_LCLK
+	rtw_unregister_tx_alive(padapter);
+#endif /*CONFIG_LPS_LCLK */
+
+	return _SUCCESS;
+}
+#endif /* CONFIG_XMIT_THREAD_MODE */
+
+
+/* for non-agg data frame or  management frame */
+static s32 rtw_dump_xframe(PADAPTER padapter, struct xmit_frame *pxmitframe)
+{
+	s32 ret = _SUCCESS;
+	s32 inner_ret = _SUCCESS;
+	int t, sz, w_sz, pull = 0;
+	u8 *mem_addr;
+	u8 ff_hwaddr;
+	struct xmit_buf *pxmitbuf = pxmitframe->pxmitbuf;
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+
+
+#ifdef CONFIG_80211N_HT
+	if ((pxmitframe->frame_tag == DATA_FRAMETAG) &&
+	    (pxmitframe->attrib.ether_type != 0x0806) &&
+	    (pxmitframe->attrib.ether_type != 0x888e) &&
+	    (pxmitframe->attrib.ether_type != 0x88b4) &&
+	    (pxmitframe->attrib.dhcp_pkt != 1))
+		rtw_issue_addbareq_cmd(padapter, pxmitframe);
+#endif /* CONFIG_80211N_HT */
+
+	mem_addr = pxmitframe->buf_addr;
+
+	for (t = 0; t < pattrib->nr_frags; t++) {
+		if (inner_ret != _SUCCESS && ret == _SUCCESS)
+			ret = _FAIL;
+
+		if (t != (pattrib->nr_frags - 1)) {
+
+			sz = pxmitpriv->frag_len;
+			sz = sz - 4 - (psecuritypriv->sw_encrypt ? 0 : pattrib->icv_len);
+		} else   /* no frag */
+			sz = pattrib->last_txcmdsz;
+
+		if (pattrib->qsel == HALMAC_TXDESC_QSEL_H2C_CMD) {
+			update_txdesc_h2c_pkt(pxmitframe, mem_addr, sz);
+			w_sz = sz + TXDESC_SIZE;
+
+		} else {
+
+			pull = update_txdesc(pxmitframe, mem_addr, sz, _FALSE);
+			if (pull) {
+				/* pull txdesc head */
+				mem_addr += PACKET_OFFSET_SZ;
+
+				pxmitframe->buf_addr = mem_addr;
+
+				w_sz = sz + TXDESC_SIZE;
+			} else
+				w_sz = sz + TXDESC_SIZE + PACKET_OFFSET_SZ;
+		}
+
+#ifdef RTW_HALMAC
+		pxmitbuf->bulkout_id = rtw_halmac_usb_get_bulkout_id(pdvobj, mem_addr, w_sz);
+#endif
+		ff_hwaddr = rtw_get_ff_hwaddr(pxmitframe);
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+		pxmitbuf->len = w_sz;
+		pxmitbuf->ff_hwaddr = ff_hwaddr;
+
+		if ((pattrib->qsel == QSLT_BEACON) || (pattrib->qsel == QSLT_CMD))
+			/* download rsvd page or fw */
+			inner_ret = rtw_write_port(padapter, ff_hwaddr, w_sz, (unsigned char *)pxmitbuf);
+		else
+			enqueue_pending_xmitbuf(pxmitpriv, pxmitbuf);		
+#else
+		inner_ret = rtw_write_port(padapter, ff_hwaddr, w_sz, (unsigned char *)pxmitbuf);
+#endif
+		rtw_count_tx_stats(padapter, pxmitframe, sz);
+
+		/* RTW_INFO("rtw_write_port, w_sz=%d, sz=%d, txdesc_sz=%d, tid=%d\n", w_sz, sz, w_sz-sz, pattrib->priority);*/
+
+		mem_addr += w_sz;
+
+		mem_addr = (u8 *)RND4(((SIZE_PTR)(mem_addr)));
+
+	}
+
+	rtw_free_xmitframe(pxmitpriv, pxmitframe);
+
+	if (ret != _SUCCESS)
+		rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_UNKNOWN);
+
+	return ret;
+}
+
+#ifdef CONFIG_USB_TX_AGGREGATION
+#define IDEA_CONDITION 1	/* check all packets before enqueue */
+static s32 rtl8822bu_xmitframe_complete(PADAPTER padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+	struct xmit_frame *pxmitframe = NULL;
+	struct xmit_frame *pfirstframe = NULL;
+
+	/* aggregate variable */
+	struct hw_xmit *phwxmit;
+	struct sta_info *psta = NULL;
+	struct tx_servq *ptxservq = NULL;
+
+	_irqL irqL;
+	_list *xmitframe_plist = NULL, *xmitframe_phead = NULL;
+
+	u32	pbuf;	/* next pkt address */
+	u32	pbuf_tail;	/* last pkt tail */
+	u32	len;	/* packet length, except TXDESC_SIZE and PKT_OFFSET */
+
+	u32	bulkSize = pHalData->UsbBulkOutSize;
+	u8	descCount;
+	u32	bulkPtr;
+
+	/* dump frame variable */
+	u8 ff_hwaddr;
+
+	_list *sta_plist, *sta_phead;
+	u8 single_sta_in_queue = _FALSE;
+
+#ifndef IDEA_CONDITION
+	int res = _SUCCESS;
+#endif
+
+
+
+	/* check xmitbuffer is ok */
+	if (pxmitbuf == NULL) {
+		pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
+		if (pxmitbuf == NULL)
+			return _FALSE;
+	}
+
+	/* 1. pick up first frame */
+	do {
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+
+		pxmitframe = rtw_dequeue_xframe(pxmitpriv, pxmitpriv->hwxmits, pxmitpriv->hwxmit_entry);
+		if (pxmitframe == NULL) {
+			/* no more xmit frame, release xmit buffer */
+			/* RTW_INFO("%s: no more xmit frame\n", __func__); */
+			rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
+			return _FALSE;
+		}
+
+#ifndef IDEA_CONDITION
+		if (pxmitframe->frame_tag != DATA_FRAMETAG) {
+			continue;
+		}
+
+		/* TID 0~15 */
+		if ((pxmitframe->attrib.priority < 0) ||
+		    (pxmitframe->attrib.priority > 15)) {
+			continue;
+		}
+#endif
+
+		pxmitframe->pxmitbuf = pxmitbuf;
+		pxmitframe->buf_addr = pxmitbuf->pbuf;
+		pxmitbuf->priv_data = pxmitframe;
+
+		pxmitframe->agg_num = 1; /* alloc xmitframe should assign to 1. */
+#ifdef CONFIG_TX_EARLY_MODE
+		/* first frame of aggregation, reserve one offset for EM info ,another for usb bulk-out block check */
+		pxmitframe->pkt_offset = (PACKET_OFFSET_SZ / 8) + 1;
+#else
+		/* first frame of aggregation, reserve offset */
+		pxmitframe->pkt_offset = (PACKET_OFFSET_SZ / 8);
+#endif
+
+		if (rtw_xmitframe_coalesce(padapter, pxmitframe->pkt, pxmitframe) == _FALSE) {
+			RTW_INFO("%s: coalesce 1st xmitframe failed\n", __func__);
+			continue;
+		}
+
+
+		/* always return ndis_packet after rtw_xmitframe_coalesce */
+		rtw_os_xmit_complete(padapter, pxmitframe);
+
+		break;
+	} while (1);
+
+	/* 2. aggregate same priority and same DA(AP or STA) frames */
+	pfirstframe = pxmitframe;
+	len = rtw_wlan_pkt_size(pfirstframe) + TXDESC_SIZE + (pfirstframe->pkt_offset * PACKET_OFFSET_SZ);
+	pbuf_tail = len;
+	pbuf = _RND8(pbuf_tail);
+
+	/* check pkt amount in one bulk */
+	descCount = 0;
+	bulkPtr = bulkSize;
+	if (pbuf < bulkPtr) {
+		descCount++;
+		if (descCount == pHalData->UsbTxAggDescNum)
+			goto agg_end;
+	} else {
+		descCount = 0;
+		bulkPtr = ((pbuf / bulkSize) + 1) * bulkSize; /* round to next bulkSize */
+	}
+
+	/* dequeue same priority packet from station tx queue */
+	psta = pfirstframe->attrib.psta;
+	switch (pfirstframe->attrib.priority) {
+	case 1:
+	case 2:
+		ptxservq = &(psta->sta_xmitpriv.bk_q);
+		phwxmit = pxmitpriv->hwxmits + 3;
+		break;
+
+	case 4:
+	case 5:
+		ptxservq = &(psta->sta_xmitpriv.vi_q);
+		phwxmit = pxmitpriv->hwxmits + 1;
+		break;
+
+	case 6:
+	case 7:
+		ptxservq = &(psta->sta_xmitpriv.vo_q);
+		phwxmit = pxmitpriv->hwxmits;
+		break;
+
+	case 0:
+	case 3:
+	default:
+		ptxservq = &(psta->sta_xmitpriv.be_q);
+		phwxmit = pxmitpriv->hwxmits + 2;
+		break;
+	}
+
+	/* RTW_INFO("==> pkt_no=%d,pkt_len=%d,len=%d,RND8_LEN=%d,pkt_offset=0x%02x\n",
+		pxmitframe->agg_num,pxmitframe->attrib.last_txcmdsz,len,pbuf,pxmitframe->pkt_offset ); */
+
+
+	_enter_critical_bh(&pxmitpriv->lock, &irqL);
+
+	sta_phead = get_list_head(phwxmit->sta_queue);
+	sta_plist = get_next(sta_phead);
+	single_sta_in_queue = rtw_end_of_queue_search(sta_phead, get_next(sta_plist));
+
+	xmitframe_phead = get_list_head(&ptxservq->sta_pending);
+	xmitframe_plist = get_next(xmitframe_phead);
+
+	while (rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist) == _FALSE) {
+		pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
+		xmitframe_plist = get_next(xmitframe_plist);
+
+		if (_FAIL == rtw_hal_busagg_qsel_check(padapter, pfirstframe->attrib.qsel, pxmitframe->attrib.qsel))
+			break;
+
+		pxmitframe->agg_num = 0; /* not first frame of aggregation */
+#ifdef CONFIG_TX_EARLY_MODE
+		pxmitframe->pkt_offset = 1;/* not first frame of aggregation,reserve offset for EM Info */
+#else
+		pxmitframe->pkt_offset = 0; /* not first frame of aggregation, no need to reserve offset */
+#endif
+
+		len = rtw_wlan_pkt_size(pxmitframe) + TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
+
+		if (_RND8(pbuf + len) > MAX_XMITBUF_SZ) {
+			/* RTW_INFO("%s: len> MAX_XMITBUF_SZ\n", __func__); */
+			pxmitframe->agg_num = 1;
+			pxmitframe->pkt_offset = 1;
+			break;
+		}
+		rtw_list_delete(&pxmitframe->list);
+		ptxservq->qcnt--;
+		phwxmit->accnt--;
+
+#ifndef IDEA_CONDITION
+		/* suppose only data frames would be in queue */
+		if (pxmitframe->frame_tag != DATA_FRAMETAG) {
+			rtw_free_xmitframe(pxmitpriv, pxmitframe);
+			continue;
+		}
+
+		/* TID 0~15 */
+		if ((pxmitframe->attrib.priority < 0) ||
+		    (pxmitframe->attrib.priority > 15)) {
+			rtw_free_xmitframe(pxmitpriv, pxmitframe);
+			continue;
+		}
+#endif
+
+		pxmitframe->buf_addr = pxmitbuf->pbuf + pbuf;
+
+		if (rtw_xmitframe_coalesce(padapter, pxmitframe->pkt, pxmitframe) == _FALSE) {
+			RTW_INFO("%s coalesce failed\n", __func__);
+			rtw_free_xmitframe(pxmitpriv, pxmitframe);
+			continue;
+		}
+
+		/* always return ndis_packet after rtw_xmitframe_coalesce */
+		rtw_os_xmit_complete(padapter, pxmitframe);
+
+		update_txdesc(pxmitframe, pxmitframe->buf_addr, pxmitframe->attrib.last_txcmdsz, _TRUE);
+
+		/* don't need xmitframe any more */
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+
+		/* handle pointer and stop condition */
+		pbuf_tail = pbuf + len;
+		pbuf = _RND8(pbuf_tail);
+
+
+		pfirstframe->agg_num++;
+#ifdef CONFIG_TX_EARLY_MODE
+		pxmitpriv->agg_pkt[pfirstframe->agg_num - 1].offset = _RND8(len);
+		pxmitpriv->agg_pkt[pfirstframe->agg_num - 1].pkt_len = pxmitframe->attrib.last_txcmdsz;
+#endif
+		if (MAX_TX_AGG_PACKET_NUMBER_8822B == pfirstframe->agg_num)
+			break;
+
+		if (pbuf < bulkPtr) {
+			descCount++;
+			if (descCount == pHalData->UsbTxAggDescNum)
+				break;
+		} else {
+			descCount = 0;
+			bulkPtr = ((pbuf / bulkSize) + 1) * bulkSize;
+		}
+	} /* end while( aggregate same priority and same DA(AP or STA) frames) */
+	if (_rtw_queue_empty(&ptxservq->sta_pending) == _TRUE)
+		rtw_list_delete(&ptxservq->tx_pending);
+	else if (single_sta_in_queue == _FALSE) {
+		/* Re-arrange the order of stations in this ac queue to balance the service for these stations */
+		rtw_list_delete(&ptxservq->tx_pending);
+		rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(phwxmit->sta_queue));
+	}
+
+	_exit_critical_bh(&pxmitpriv->lock, &irqL);
+agg_end:
+#ifdef CONFIG_80211N_HT
+	if ((pfirstframe->attrib.ether_type != 0x0806) &&
+	    (pfirstframe->attrib.ether_type != 0x888e) &&
+	    (pfirstframe->attrib.ether_type != 0x88b4) &&
+	    (pfirstframe->attrib.dhcp_pkt != 1))
+		rtw_issue_addbareq_cmd(padapter, pfirstframe);
+#endif /* CONFIG_80211N_HT */
+#ifndef CONFIG_USE_USB_BUFFER_ALLOC_TX
+	/* 3. update first frame txdesc */
+	if ((PACKET_OFFSET_SZ != 0) && ((pbuf_tail % bulkSize) == 0)) {
+		/* remove pkt_offset */
+		pbuf_tail -= PACKET_OFFSET_SZ;
+		pfirstframe->buf_addr += PACKET_OFFSET_SZ;
+		pfirstframe->pkt_offset--;
+	}
+#endif	/* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+
+	update_txdesc(pfirstframe, pfirstframe->buf_addr, pfirstframe->attrib.last_txcmdsz, _TRUE);
+
+#ifdef CONFIG_TX_EARLY_MODE
+	/* prepare EM info for first frame, agg_num value start from 1 */
+	pxmitpriv->agg_pkt[0].offset = _RND8(pfirstframe->attrib.last_txcmdsz + TXDESC_SIZE + (pfirstframe->pkt_offset * PACKET_OFFSET_SZ));
+	/* get from rtw_xmitframe_coalesce */
+	pxmitpriv->agg_pkt[0].pkt_len = pfirstframe->attrib.last_txcmdsz;
+
+	UpdateEarlyModeInfo8812(pxmitpriv, pxmitbuf);
+#endif /*CONFIG_TX_EARLY_MODE*/
+
+	/* 4. write xmit buffer to USB FIFO */
+#ifdef RTW_HALMAC
+	pxmitbuf->bulkout_id = rtw_halmac_usb_get_bulkout_id(pdvobj, pfirstframe->buf_addr, pfirstframe->attrib.last_txcmdsz);
+#endif
+	ff_hwaddr = rtw_get_ff_hwaddr(pfirstframe);
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+	pxmitbuf->len = pbuf_tail;
+	pxmitbuf->ff_hwaddr = ff_hwaddr;
+
+	if (pxmitbuf->buf_tag  == XMITBUF_CMD)
+		/* download rsvd page or fw */
+		rtw_write_port(padapter, ff_hwaddr, pbuf_tail, (u8 *)pxmitbuf);
+	else
+		enqueue_pending_xmitbuf(pxmitpriv, pxmitbuf);		
+#else
+	rtw_write_port(padapter, ff_hwaddr, pbuf_tail, (u8 *)pxmitbuf);
+#endif
+
+
+	/* 5. update statisitc */
+	pbuf_tail -= (pfirstframe->agg_num * TXDESC_SIZE);
+	pbuf_tail -= (pfirstframe->pkt_offset * PACKET_OFFSET_SZ);
+
+
+	rtw_count_tx_stats(padapter, pfirstframe, pbuf_tail);
+
+	rtw_free_xmitframe(pxmitpriv, pfirstframe);
+
+	return _TRUE;
+}
+
+#else /* CONFIG_USB_TX_AGGREGATION */
+
+static s32 rtl8822bu_xmitframe_complete(PADAPTER padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
+{
+
+	struct hw_xmit *phwxmits;
+	sint hwentry;
+	struct xmit_frame *pxmitframe = NULL;
+	int res = _SUCCESS, xcnt = 0;
+
+	phwxmits = pxmitpriv->hwxmits;
+	hwentry = pxmitpriv->hwxmit_entry;
+
+
+	if (pxmitbuf == NULL) {
+		pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
+		if (!pxmitbuf)
+			return _FALSE;
+	}
+
+
+	do {
+		pxmitframe =  rtw_dequeue_xframe(pxmitpriv, phwxmits, hwentry);
+
+		if (pxmitframe) {
+			pxmitframe->pxmitbuf = pxmitbuf;
+
+			pxmitframe->buf_addr = pxmitbuf->pbuf;
+
+			pxmitbuf->priv_data = pxmitframe;
+
+			if ((pxmitframe->frame_tag & 0x0f) == DATA_FRAMETAG) {
+				/* TID0~15 */
+				if (pxmitframe->attrib.priority <= 15)
+					res = rtw_xmitframe_coalesce(padapter, pxmitframe->pkt, pxmitframe);
+
+				rtw_os_xmit_complete(padapter, pxmitframe);/* always return ndis_packet after rtw_xmitframe_coalesce */
+			}
+
+
+
+
+			if (res == _SUCCESS)
+				rtw_dump_xframe(padapter, pxmitframe);
+			else {
+				rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
+				rtw_free_xmitframe(pxmitpriv, pxmitframe);
+			}
+
+			xcnt++;
+
+		} else {
+			rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
+			return _FALSE;
+		}
+
+		break;
+
+	} while (0/*xcnt < (NR_XMITFRAME >> 3)*/);
+
+	return _TRUE;
+
+}
+#endif
+
+static void rtl8822bu_xmit_tasklet(void *priv)
+{
+	int ret = _FALSE;
+	_adapter *padapter = (_adapter *)priv;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+
+	while (1) {
+		if (RTW_CANNOT_TX(padapter)) {
+			RTW_INFO("xmit_tasklet => bDriverStopped or bSurpriseRemoved or bWritePortCancel\n");
+			break;
+		}
+
+		if (rtw_xmit_ac_blocked(padapter) == _TRUE)
+			break;
+
+		ret = rtl8822bu_xmitframe_complete(padapter, pxmitpriv, NULL);
+
+		if (ret == _FALSE)
+			break;
+
+	}
+
+}
+
+s32	rtl8822bu_init_xmit_priv(PADAPTER padapter)
+{
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+
+#ifdef PLATFORM_LINUX
+	tasklet_init(&pxmitpriv->xmit_tasklet,
+		     (void(*)(unsigned long))rtl8822bu_xmit_tasklet,
+		     (unsigned long)padapter);
+#endif
+#ifdef CONFIG_TX_EARLY_MODE
+	pHalData->bEarlyModeEnable = padapter->registrypriv.early_mode;
+#endif
+
+	return _SUCCESS;
+}
+
+void	rtl8822bu_free_xmit_priv(PADAPTER padapter)
+{
+}
+
+static s32 xmitframe_direct(PADAPTER padapter, struct xmit_frame *pxmitframe)
+{
+	s32 res = _SUCCESS;
+
+	res = rtw_xmitframe_coalesce(padapter, pxmitframe->pkt, pxmitframe);
+	if (res == _SUCCESS)
+		rtw_dump_xframe(padapter, pxmitframe);
+	else
+		RTW_INFO("%s: xmitframe_coalsece failed\n", __func__);
+
+	return res;
+}
+
+/*
+ * Return
+ *	_TRUE	dump packet directly
+ *	_FALSE	enqueue packet
+ */
+static s32 pre_xmitframe(PADAPTER padapter, struct xmit_frame *pxmitframe)
+{
+	_irqL irqL;
+	s32 res;
+	struct xmit_buf *pxmitbuf = NULL;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	_enter_critical_bh(&pxmitpriv->lock, &irqL);
+
+	if (rtw_txframes_sta_ac_pending(padapter, pattrib) > 0)
+		goto enqueue;
+
+	if (rtw_xmit_ac_blocked(padapter) == _TRUE)
+		goto enqueue;
+
+	if (DEV_STA_LG_NUM(padapter->dvobj))
+		goto enqueue;
+
+	pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
+	if (pxmitbuf == NULL)
+		goto enqueue;
+
+	_exit_critical_bh(&pxmitpriv->lock, &irqL);
+
+	pxmitframe->pxmitbuf = pxmitbuf;
+	pxmitframe->buf_addr = pxmitbuf->pbuf;
+	pxmitbuf->priv_data = pxmitframe;
+
+	if (xmitframe_direct(padapter, pxmitframe) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+	}
+
+	return _TRUE;
+
+enqueue:
+	res = rtw_xmitframe_enqueue(padapter, pxmitframe);
+	_exit_critical_bh(&pxmitpriv->lock, &irqL);
+
+	if (res != _SUCCESS) {
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+
+		pxmitpriv->tx_drop++;
+		return _TRUE;
+	}
+
+	return _FALSE;
+}
+
+s32 rtl8822bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe)
+{
+	return rtw_dump_xframe(padapter, pmgntframe);
+}
+
+/*
+ * Return
+ *	_TRUE	dump packet directly ok
+ *	_FALSE	temporary can't transmit packets to hardware
+ */
+s32 rtl8822bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe)
+{
+	return pre_xmitframe(padapter, pxmitframe);
+}
+
+s32 rtl8822bu_hal_xmitframe_enqueue(PADAPTER padapter, struct xmit_frame *pxmitframe)
+{
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	s32 err;
+
+	err = rtw_xmitframe_enqueue(padapter, pxmitframe);
+	if (err != _SUCCESS) {
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+		pxmitpriv->tx_drop++;
+	} else {
+#ifdef PLATFORM_LINUX
+		tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
+#endif
+	}
+
+	return err;
+
+}
+
+#ifdef CONFIG_HOSTAPD_MLME
+
+static void rtl8822bu_hostap_mgnt_xmit_cb(struct urb *urb)
+{
+#ifdef PLATFORM_LINUX
+	struct sk_buff *skb = (struct sk_buff *)urb->context;
+
+	rtw_skb_free(skb);
+#endif
+}
+
+s32 rtl8822bu_hostap_mgnt_xmit_entry(PADAPTER padapter, _pkt *pkt)
+{
+#ifdef PLATFORM_LINUX
+	u16 fc;
+	int rc, len, pipe;
+	unsigned int bmcst, tid, qsel;
+	struct sk_buff *skb, *pxmit_skb;
+	struct urb *urb;
+	unsigned char *pxmitbuf;
+	struct tx_desc *ptxdesc;
+	struct rtw_ieee80211_hdr *tx_hdr;
+	struct hostapd_priv *phostapdpriv = padapter->phostapdpriv;
+	struct net_device *pnetdev = padapter->pnetdev;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+
+	skb = pkt;
+
+	len = skb->len;
+	tx_hdr = (struct rtw_ieee80211_hdr *)(skb->data);
+	fc = le16_to_cpu(tx_hdr->frame_ctl);
+	bmcst = IS_MCAST(tx_hdr->addr1);
+
+	if ((fc & RTW_IEEE80211_FCTL_FTYPE) != RTW_IEEE80211_FTYPE_MGMT)
+		goto _exit;
+
+	pxmit_skb = rtw_skb_alloc(len + TXDESC_SIZE);
+
+	if (!pxmit_skb)
+		goto _exit;
+
+	pxmitbuf = pxmit_skb->data;
+
+	urb = usb_alloc_urb(0, GFP_ATOMIC);
+	if (!urb)
+		goto _exit;
+
+	/* ----- fill tx desc ----- */
+	ptxdesc = (struct tx_desc *)pxmitbuf;
+	_rtw_memset(ptxdesc, 0, sizeof(*ptxdesc));
+
+	/* offset 0 */
+	ptxdesc->txdw0 |= cpu_to_le32(len & 0x0000ffff);
+	ptxdesc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) << OFFSET_SHT) & 0x00ff0000);/* default = 32 bytes for TX Desc */
+	ptxdesc->txdw0 |= cpu_to_le32(OWN | FSG | LSG);
+
+	if (bmcst)
+		ptxdesc->txdw0 |= cpu_to_le32(BIT(24));
+
+	/* offset 4 */
+	ptxdesc->txdw1 |= cpu_to_le32(0x00); /* MAC_ID */
+
+	ptxdesc->txdw1 |= cpu_to_le32((0x12 << QSEL_SHT) & 0x00001f00);
+
+	ptxdesc->txdw1 |= cpu_to_le32((0x06 << 16) & 0x000f0000);/* b mode */
+
+	/* offset 8 */
+
+	/* offset 12 */
+	ptxdesc->txdw3 |= cpu_to_le32((le16_to_cpu(tx_hdr->seq_ctl) << 16) & 0xffff0000);
+
+	/* offset 16 */
+	ptxdesc->txdw4 |= cpu_to_le32(BIT(8)); /* driver uses rate */
+
+	/* offset 20 */
+
+
+	/* HW append seq */
+	ptxdesc->txdw4 |= cpu_to_le32(BIT(7)); /* Hw set sequence number */
+	ptxdesc->txdw3 |= cpu_to_le32((8 << 28)); /* set bit3 to 1. Suugested by TimChen. 2009.12.29. */
+
+
+	rtl8822b_cal_txdesc_chksum(padapter, ptxdesc);
+	/* ----- end of fill tx desc -----*/
+
+
+	skb_put(pxmit_skb, len + TXDESC_SIZE);
+	pxmitbuf = pxmitbuf + TXDESC_SIZE;
+	_rtw_memcpy(pxmitbuf, skb->data, len);
+
+	/*RTW_INFO("mgnt_xmit, len=%x\n", pxmit_skb->len); */
+
+
+	/* ----- prepare urb for submit -----*/
+
+	/* translate DMA FIFO addr to pipehandle */
+	pipe = usb_sndbulkpipe(pdvobj->pusbdev, pHalData->Queue2EPNum[(u8)MGT_QUEUE_INX] & 0x0f);
+
+	usb_fill_bulk_urb(urb, pdvobj->pusbdev, pipe,
+		pxmit_skb->data, pxmit_skb->len, rtl8192cu_hostap_mgnt_xmit_cb, pxmit_skb);
+
+	urb->transfer_flags |= URB_ZERO_PACKET;
+	usb_anchor_urb(urb, &phostapdpriv->anchored);
+	rc = usb_submit_urb(urb, GFP_ATOMIC);
+	if (rc < 0) {
+		usb_unanchor_urb(urb);
+		kfree_skb(skb);
+	}
+	usb_free_urb(urb);
+
+
+_exit:
+
+	rtw_skb_free(skb);
+
+#endif
+
+	return 0;
+
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/ifcfg-wlan0 b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/ifcfg-wlan0
new file mode 100644
index 000000000000..20dcbec2b1ae
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/ifcfg-wlan0
@@ -0,0 +1,4 @@
+#DHCP client
+DEVICE=wlan0
+BOOTPROTO=dhcp
+ONBOOT=yes
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPhyCfg.h
new file mode 100644
index 000000000000..3fc0b1107908
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPhyCfg.h
@@ -0,0 +1,260 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8188EPHYCFG_H__
+#define __INC_HAL8188EPHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue		0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+#define	MAX_TX_COUNT_8188E			1
+
+/* BB/RF related */
+
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/*
+ * BB and RF register read/write
+ *   */
+u32	PHY_QueryBBReg8188E(IN	PADAPTER	Adapter,
+			    IN	u32		RegAddr,
+			    IN	u32		BitMask);
+void	PHY_SetBBReg8188E(IN	PADAPTER	Adapter,
+			  IN	u32		RegAddr,
+			  IN	u32		BitMask,
+			  IN	u32		Data);
+u32	PHY_QueryRFReg8188E(IN	PADAPTER	Adapter,
+			    IN	enum rf_path		eRFPath,
+			    IN	u32				RegAddr,
+			    IN	u32				BitMask);
+void	PHY_SetRFReg8188E(IN	PADAPTER		Adapter,
+			  IN	enum rf_path		eRFPath,
+			  IN	u32				RegAddr,
+			  IN	u32				BitMask,
+			  IN	u32				Data);
+
+/*
+ * Initialization related function
+ */
+/* MAC/BB/RF HAL config */
+int	PHY_MACConfig8188E(IN	PADAPTER	Adapter);
+int	PHY_BBConfig8188E(IN	PADAPTER	Adapter);
+int	PHY_RFConfig8188E(IN	PADAPTER	Adapter);
+
+/* RF config */
+int	rtl8188e_PHY_ConfigRFWithParaFile(IN PADAPTER Adapter, IN u8 *pFileName, enum rf_path eRFPath);
+
+/*
+ * RF Power setting
+ */
+/* extern	BOOLEAN	PHY_SetRFPowerState(IN	PADAPTER			Adapter,
+ *									IN	RT_RF_POWER_STATE	eRFPowerState); */
+
+/*
+ * BB TX Power R/W
+ *   */
+void	PHY_GetTxPowerLevel8188E(IN	PADAPTER		Adapter,
+				 OUT s32		*powerlevel);
+void	PHY_SetTxPowerLevel8188E(IN	PADAPTER		Adapter,
+				 IN	u8			channel);
+BOOLEAN	PHY_UpdateTxPowerDbm8188E(IN	PADAPTER	Adapter,
+				  IN	int		powerInDbm);
+
+VOID
+PHY_SetTxPowerIndex_8188E(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8188E(
+	IN	PADAPTER		pAdapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	IN	u8				BandWidth,
+	IN	u8				Channel,
+	struct txpwr_idx_comp *tic
+);
+
+/*
+ * Switch bandwidth for 8192S
+ */
+/* extern	void	PHY_SetBWModeCallback8192C(	IN	PRT_TIMER		pTimer	); */
+void	PHY_SetBWMode8188E(IN	PADAPTER			pAdapter,
+			   IN	enum channel_width	ChnlWidth,
+			   IN	unsigned char	Offset);
+
+/*
+ * Set FW CMD IO for 8192S.
+ */
+/* extern	BOOLEAN HalSetIO8192C(	IN	PADAPTER			Adapter,
+ *									IN	IO_TYPE				IOType); */
+
+/*
+ * Set A2 entry to fw for 8192S
+ *   */
+extern	void FillA2Entry8192C(IN	PADAPTER			Adapter,
+			      IN	u8				index,
+			      IN	u8				*val);
+
+
+/*
+ * channel switch related funciton
+ */
+/* extern	void	PHY_SwChnlCallback8192C(	IN	PRT_TIMER		pTimer	); */
+void	PHY_SwChnl8188E(IN	PADAPTER		pAdapter,
+			IN	u8			channel);
+
+VOID
+PHY_SetSwChnlBWMode8188E(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID
+PHY_SetRFEReg_8188E(
+	IN PADAPTER		Adapter
+);
+/*
+ * BB/MAC/RF other monitor API
+ *   */
+VOID phy_set_rf_path_switch_8188e(IN	struct dm_struct	*phydm, IN	bool		bMain);
+
+extern	VOID
+PHY_SwitchEphyParameter(
+	IN	PADAPTER			Adapter
+);
+
+extern	VOID
+PHY_EnableHostClkReq(
+	IN	PADAPTER			Adapter
+);
+
+BOOLEAN
+SetAntennaConfig92C(
+	IN	PADAPTER	Adapter,
+	IN	u8		DefaultAnt
+);
+
+/*--------------------------Exported Function prototype---------------------*/
+
+/*
+ * Initialization related function
+ *
+ * MAC/BB/RF HAL config */
+/* extern s32 PHY_MACConfig8723(PADAPTER padapter);
+ * s32 PHY_BBConfig8723(PADAPTER padapter);
+ * s32 PHY_RFConfig8723(PADAPTER padapter); */
+
+
+
+/* ******************************************************************
+ * Note: If SIC_ENABLE under PCIE, because of the slow operation
+ *	you should
+ * 	2) "#define RTL8723_FPGA_VERIFICATION	1"				in Precomp.h.WlanE.Windows
+ * 	3) "#define RTL8190_Download_Firmware_From_Header	0"	in Precomp.h.WlanE.Windows if needed.
+ *   */
+#if (RTL8188E_SUPPORT == 1) && (RTL8188E_FPGA_TRUE_PHY_VERIFICATION == 1)
+	#define	SIC_ENABLE				1
+	#define	SIC_HW_SUPPORT		1
+#else
+	#define	SIC_ENABLE				0
+	#define	SIC_HW_SUPPORT		0
+#endif
+/* ****************************************************************** */
+
+
+#define	SIC_MAX_POLL_CNT		5
+
+#if (SIC_HW_SUPPORT == 1)
+	#define	SIC_CMD_READY			0
+	#define	SIC_CMD_PREWRITE		0x1
+	#if (RTL8188E_SUPPORT == 1)
+		#define	SIC_CMD_WRITE			0x40
+		#define	SIC_CMD_PREREAD		0x2
+		#define	SIC_CMD_READ			0x80
+		#define	SIC_CMD_INIT			0xf0
+		#define	SIC_INIT_VAL			0xff
+
+		#define	SIC_INIT_REG			0x1b7
+		#define	SIC_CMD_REG			0x1EB		/* 1byte */
+		#define	SIC_ADDR_REG			0x1E8		/* 1b4~1b5, 2 bytes */
+		#define	SIC_DATA_REG			0x1EC		/* 1b0~1b3 */
+	#else
+		#define	SIC_CMD_WRITE			0x11
+		#define	SIC_CMD_PREREAD		0x2
+		#define	SIC_CMD_READ			0x12
+		#define	SIC_CMD_INIT			0x1f
+		#define	SIC_INIT_VAL			0xff
+
+		#define	SIC_INIT_REG			0x1b7
+		#define	SIC_CMD_REG			0x1b6		/* 1byte */
+		#define	SIC_ADDR_REG			0x1b4		/* 1b4~1b5, 2 bytes */
+		#define	SIC_DATA_REG			0x1b0		/* 1b0~1b3 */
+	#endif
+#else
+	#define	SIC_CMD_READY			0
+	#define	SIC_CMD_WRITE			1
+	#define	SIC_CMD_READ			2
+
+	#if (RTL8188E_SUPPORT == 1)
+		#define	SIC_CMD_REG			0x1EB		/* 1byte */
+		#define	SIC_ADDR_REG			0x1E8		/* 1b9~1ba, 2 bytes */
+		#define	SIC_DATA_REG			0x1EC		/* 1bc~1bf */
+	#else
+		#define	SIC_CMD_REG			0x1b8		/* 1byte */
+		#define	SIC_ADDR_REG			0x1b9		/* 1b9~1ba, 2 bytes */
+		#define	SIC_DATA_REG			0x1bc		/* 1bc~1bf */
+	#endif
+#endif
+
+#if (SIC_ENABLE == 1)
+	VOID SIC_Init(IN PADAPTER Adapter);
+#endif
+
+
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPhyReg.h
new file mode 100644
index 000000000000..2eab8313aa5d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPhyReg.h
@@ -0,0 +1,1100 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8188EPHYREG_H__
+#define __INC_HAL8188EPHYREG_H__
+/*--------------------------Define Parameters-------------------------------*/
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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		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		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
+#define		rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#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_ram64x16				0xb2c
+#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_csi_fix_mask1				0xd40
+#define		rOFDM1_csi_fix_mask2				0xd44
+#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		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		rTxAGC_B_Mcs15_Mcs12		0x868
+#define		rTxAGC_B_CCK11_A_CCK2_11		0x86c
+
+#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 */
+
+/* #endif */
+#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_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_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_88E					0x42	/*  */
+#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 */
+#define		RF_TX_BIAS_A					0x35
+#define		RF_TX_BIAS_D					0x36
+#define		RF_LOBF_9					0x38
+#define		RF_RXRF_A3					0x3C	/*	 */
+#define		RF_TRSW						0x3F
+
+#define		RF_TXRF_A2					0x41
+#define		RF_TXPA_G4					0x46
+#define		RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define		RF_WE_LUT					0xEF
+
+
+/*
+ * 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		bMaskH3Bytes				0xffffff00
+#define		bMask12Bits				0xfff
+#define		bMaskH4Bits				0xf0000000
+#define		bMaskOFDM_D			0xffc00000
+#define		bMaskCCK				0x3f3f3f3f
+
+
+
+#define		bEnable                   0x1	/* Useless */
+#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
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPwrSeq.h
new file mode 100644
index 000000000000..46c61abacb92
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188EPwrSeq.h
@@ -0,0 +1,170 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HAL8188EPWRSEQ_H__
+#define __HAL8188EPWRSEQ_H__
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20110607-Paul-RTL8188E_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
+
+    PWR SEQ Version: rtl8188E_PwrSeq_V09.h
+*/
+#define	RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS	10
+#define	RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS	10
+#define	RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS	10
+#define	RTL8188E_TRANS_SUS_TO_CARDEMU_STEPS	10
+#define	RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS	10
+#define	RTL8188E_TRANS_PDN_TO_CARDEMU_STEPS	10
+#define	RTL8188E_TRANS_ACT_TO_LPS_STEPS	15
+#define	RTL8188E_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8188E_TRANS_END_STEPS	1
+
+
+#define RTL8188E_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 | BIT1, 0}, /* 0x02[1:0] = 0	reset BB*/			\
+	{0x0026, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7}, /*0x24[23] = 2b'01 schmit trigger */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0}, /* 0x04[15] = 0 disable HWPDN (control by DRV)*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, 0}, /*0x04[12:11] = 2b'00 disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*0x04[8] = 1 polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0}, /*wait till 0x04[8] = 0*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*LDO normal mode*/	\
+
+#define RTL8188E_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*LDO Sleep mode*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+
+#define RTL8188E_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11enable WL suspend for PCIe*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, BIT7}, /*  0x04[31:30] = 2b'10 enable enable bandgap mbias in suspend */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*Clear SIC_EN register 0x40[12] = 1'b0 */	\
+	{0xfe10, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*Set USB suspend enable local register  0xfe10[4]=1 */	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8188E_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8188E_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0026, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7}, /*0x24[23] = 2b'01 schmit trigger */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0}, /*  0x04[31:30] = 2b'10 enable enable bandgap mbias in suspend */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*Clear SIC_EN register 0x40[12] = 1'b0 */	\
+	{0xfe10, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*Set USB suspend enable local register  0xfe10[4]=1 */	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8188E_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8188E_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8188E_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+	/* This is used by driver for LPSRadioOff Procedure, not for FW LPS Step */
+#define RTL8188E_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x7F},/*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, BIT0, 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*/	\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x3F},/*Reset MAC TRX*/	\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8188E_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8188E_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8188E_power_on_flow[RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_radio_off_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_card_disable_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_card_enable_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_suspend_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_resume_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_hwpdn_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_enter_lps_flow[RTL8188E_TRANS_ACT_TO_LPS_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_leave_lps_flow[RTL8188E_TRANS_LPS_TO_ACT_STEPS + RTL8188E_TRANS_END_STEPS];
+
+#endif /* __HAL8188EPWRSEQ_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPhyCfg.h
new file mode 100644
index 000000000000..1f03a33ec451
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPhyCfg.h
@@ -0,0 +1,134 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8188FPHYCFG_H__
+#define __INC_HAL8188FPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8188F(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8188F(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8188F(
+	IN	PADAPTER			Adapter,
+	IN	enum rf_path			eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8188F(
+	IN	PADAPTER			Adapter,
+	IN	enum rf_path			eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8188F(PADAPTER	Adapter);
+
+int PHY_RFConfig8188F(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8188F(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8188F(
+	IN	PADAPTER			Adapter,
+	IN	u8					*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8188F(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8188F(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8		BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8188F(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8188F(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8188F(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8188f(
+	IN	struct		dm_struct *phydm,
+	IN	bool		bMain
+);
+
+void BBTurnOnBlock_8188F(_adapter *adapter);
+
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPhyReg.h
new file mode 100644
index 000000000000..a831faade96d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPhyReg.h
@@ -0,0 +1,1165 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8188FPHYREG_H__
+#define __INC_HAL8188FPHYREG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/* ************************************************************
+ * Regsiter offset definition
+ * ************************************************************ */
+
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rS0S1_PathSwitch			0x948
+
+/*
+ * 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define 	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define		RF_RXG_MIX_SWBW				0x87
+#define		RF_DBG_LP_RX2				0xDF
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+#define RF_TX_GAIN_OFFSET_8188F(_val) (abs((_val)) | (((_val) > 0) ? BIT5 : 0))
+
+/*
+ * 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+/* BB Register Definition
+ *
+ * 4. Page9(0x900)
+ *   */
+#define rDPDT_control				0x92c
+#define rfe_ctrl_anta_src				0x930
+#define rS0S1_PathSwitch			0x948
+#define	BBrx_DFIR						0x954
+#define AGC_table_select				0xb2c
+
+/*
+ * PageB(0xB00)
+ *   */
+#define rPdp_AntA						0xb00
+#define rPdp_AntA_4						0xb04
+#define rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPwrSeq.h
new file mode 100644
index 000000000000..5cad428fdd0b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8188FPwrSeq.h
@@ -0,0 +1,212 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8188F
+#define REALTEK_POWER_SEQUENCE_8188F
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20130815-JackieLau-RTL8188F_Power_Architecture v08.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
+*/
+#define	RTL8188F_TRANS_CARDEMU_TO_ACT_STEPS	13
+#define	RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS	14
+#define	RTL8188F_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8188F_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8188F_TRANS_ACT_TO_LPS_STEPS		11
+#define	RTL8188F_TRANS_LPS_TO_ACT_STEPS		13
+#define	RTL8188F_TRANS_ACT_TO_SWLPS_STEPS		21
+#define	RTL8188F_TRANS_SWLPS_TO_ACT_STEPS		14
+#define	RTL8188F_TRANS_END_STEPS		1
+
+
+#define RTL8188F_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, (BIT3), 0},/*  0x4[11]=1'b0 disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 0x4[8]=1 polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	 \
+	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x35}, /*0x27<=35 to reduce RF noise*/
+
+#define RTL8188F_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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, BIT7, 0},/*0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */\
+	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x34}, /*0x27 <= 34, xtal_qsel = 0 to xtal bring up*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+
+#define RTL8188F_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00}, /*0x07 = 0x00 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/ \
+	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
+
+#define RTL8188F_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
+	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
+
+#define RTL8188F_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00}, /*0x07 = 0x00 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/ \
+	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
+
+#define RTL8188F_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
+	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
+
+
+#define RTL8188F_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8188F_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8188F_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*set RPWM IMR*/	\
+	{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*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT1, 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, 0x3F},/*Reset MAC TRX*/	\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/
+
+
+#define RTL8188F_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84},  /*SDIO RPWM*/\
+	{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*/\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_MS}, /*Delay*/\
+	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x35},/*xtal_qsel = 1 for low noise*/	\
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT7, 0}, /*Polling 0x109[7]=0  TSF in 40M*/\
+	{0x002B, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x1c, 0x1c},   /*.	0x2b[4:2] = 3b'111	to enable BB, AFE clock*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0},  /*.	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 RTL8188F_TRANS_ACT_TO_SWLPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*set RPWM IMR*/	\
+	{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*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT1, 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, 0x3F},/*Reset MAC TRX*/	\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+	{0x002b, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x1C, 0x00},/*0x2b[4:2]<=0 to gated BB, AFE clock*/	\
+	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x34},/*xtal_qsel = 0 for bring up*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x00},/* sdio LPS option*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x83},/* usb LPS option, open bandgap, xtal*/	\
+	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 0}, /* 0xC4[5]<=0, digital LDO no standby mode*/	\
+	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7}, /* 0xC4[7]<=1, on domain voltage adjust*/	\
+	{0x00a7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0xe0}, /* low power LPS enable for sdio*/	\
+	{0x00a7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0xe4}, /* low power LPS enable for usb*/	\
+	{0x0090, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /* enable WL_LPS_EN*/
+
+
+#define RTL8188F_TRANS_SWLPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/*polling TSF stable*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	0x101[1] = 1, enable security engine*/\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF}, /*.	0x100[7:0] = 0xFF	 enable WMAC TRX*/\
+	{0x06B7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x09}, /*.	reset MAC rx state machine*/\
+	{0x06B4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x86}, /*.	reset MAC rx state machine*/\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/* set CPU RAM code ready*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/* Enable CPU*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*enable CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2},/* Enable CPU*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT7, BIT7},/*polling FW init ready */	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT6, BIT6},/*polling FW init ready */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0}, /*.	0x522 = 0*/
+
+#define RTL8188F_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8188F_power_on_flow[RTL8188F_TRANS_CARDEMU_TO_ACT_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_radio_off_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_card_disable_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_card_enable_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_suspend_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_resume_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_hwpdn_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_enter_lps_flow[RTL8188F_TRANS_ACT_TO_LPS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_leave_lps_flow[RTL8188F_TRANS_LPS_TO_ACT_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_enter_swlps_flow[RTL8188F_TRANS_ACT_TO_SWLPS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_leave_swlps_flow[RTL8188F_TRANS_SWLPS_TO_ACT_STEPS + RTL8188F_TRANS_END_STEPS];
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPhyCfg.h
new file mode 100644
index 000000000000..d6394c6ff036
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPhyCfg.h
@@ -0,0 +1,148 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8192EPHYCFG_H__
+#define __INC_HAL8192EPHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/*------------------------------Define structure----------------------------*/
+
+/* BB/RF related */
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/*
+ * BB and RF register read/write
+ *   */
+u32	PHY_QueryBBReg8192E(IN	PADAPTER	Adapter,
+			    IN	u32			RegAddr,
+			    IN	u32			BitMask);
+void	PHY_SetBBReg8192E(IN	PADAPTER		Adapter,
+			  IN	u32			RegAddr,
+			  IN	u32			BitMask,
+			  IN	u32			Data);
+u32	PHY_QueryRFReg8192E(IN	PADAPTER	Adapter,
+			    IN	enum rf_path	eRFPath,
+			    IN	u32			RegAddr,
+			    IN	u32			BitMask);
+void	PHY_SetRFReg8192E(IN	PADAPTER		Adapter,
+			  IN	enum rf_path	eRFPath,
+			  IN	u32			RegAddr,
+			  IN	u32			BitMask,
+			  IN	u32			Data);
+
+/*
+ * Initialization related function
+ *
+ * MAC/BB/RF HAL config */
+int	PHY_MACConfig8192E(IN PADAPTER	Adapter);
+int	PHY_BBConfig8192E(IN PADAPTER	Adapter);
+int	PHY_RFConfig8192E(IN PADAPTER	Adapter);
+
+/* RF config */
+
+
+/*
+ * BB TX Power R/W
+ *   */
+void	PHY_GetTxPowerLevel8192E(IN PADAPTER	Adapter, OUT s32	*powerlevel);
+void	PHY_SetTxPowerLevel8192E(IN PADAPTER	Adapter, IN u8	channel);
+BOOLEAN	PHY_UpdateTxPowerDbm8192E(IN PADAPTER	Adapter, IN int	powerInDbm);
+
+VOID
+PHY_SetTxPowerIndex_8192E(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8192E(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+/*
+ * channel switch related funciton
+ *   */
+VOID
+PHY_SetSwChnlBWMode8192E(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID
+PHY_SetRFEReg_8192E(
+	IN PADAPTER		Adapter
+);
+
+void
+phy_SpurCalibration_8192E(
+	IN	PADAPTER			Adapter,
+	IN	enum spur_cal_method	method
+);
+void PHY_SpurCalibration_8192E(IN PADAPTER Adapter);
+
+#ifdef CONFIG_SPUR_CAL_NBI
+void
+phy_SpurCalibration_8192E_NBI(
+	IN	PADAPTER			Adapter
+);
+#endif
+/*
+ * BB/MAC/RF other monitor API
+ *   */
+
+VOID
+phy_set_rf_path_switch_8192e(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype---------------------*/
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPhyReg.h
new file mode 100644
index 000000000000..30b771111164
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPhyReg.h
@@ -0,0 +1,1146 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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) 2008,  RealTEK Technology Inc. All Right Reserved.
+ *
+ * Module:	__INC_HAL8192SPHYREG_H
+ *
+ *
+ * Note:	1. Define PMAC/BB register map
+ *			2. Define RF register map
+ *			3. PMAC/BB register bit mask.
+ *			4. RF reg bit mask.
+ *			5. Other BB/RF relative definition.
+ *
+ *
+ * Export:	Constants, macro, functions(API), global variables(None).
+ *
+ * Abbrev:
+ *
+ * History:
+ *		Data		Who		Remark
+ *      08/07/2007  MHC	1. Porting from 9x series PHYCFG.h.
+ *							2. Reorganize code architecture.
+ *	09/25/2008	MH		1. Add RL6052 register definition
+ *
+ *****************************************************************************/
+#ifndef __INC_HAL8192EPHYREG_H
+#define __INC_HAL8192EPHYREG_H
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/* ************************************************************
+ * 8192S Regsiter offset definition
+ * ************************************************************ */
+
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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
+
+
+/*
+ * 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		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		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
+#define		rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#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_ram64x16				0xb2c
+
+#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_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		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		rTxAGC_B_Mcs15_Mcs12		0x868
+#define		rTxAGC_B_CCK11_A_CCK2_11		0x86c
+
+#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 */
+
+/* #endif */
+#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_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_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_8192E			0x42	/*  */
+#define		RF_T_METER_88E				0x42
+#define		RF_T_METER					0x24	/*  */
+
+/* #endif */
+
+#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 */
+#define		RF_TX_BIAS_A					0x35
+#define		RF_TX_BIAS_D					0x36
+#define		RF_LOBF_9					0x38
+#define		RF_RXRF_A3					0x3C	/*	 */
+#define		RF_TRSW						0x3F
+
+#define		RF_TXRF_A2					0x41
+#define		RF_TXPA_G4					0x46
+#define		RF_TXPA_A4					0x4B
+#define		RF_0x52						0x52
+#define		RF_LDO						0xB1
+#define		RF_WE_LUT					0xEF
+
+
+/*
+ * 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))
+#define		RF_TX_GAIN_OFFSET_8192E(_val)		((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
+
+
+/* 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		bMaskH3Bytes				0xffffff00
+#define		bMask12Bits				0xfff
+#define		bMaskH4Bits				0xf0000000
+#define		bMaskOFDM_D			0xffc00000
+#define		bMaskCCK				0x3f3f3f3f
+
+/* for PutRFRegsetting & GetRFRegSetting BitMask
+ * #define		bMask12Bits               0xfffff */	/* RF Reg mask bits
+ * #define		bMask20Bits               0xfffff */	/* RF Reg mask bits T65 RF */
+#define		bRFRegOffsetMask			0xfffff
+
+#define		bEnable                   0x1	/* Useless */
+#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
+
+
+/* RSSI Dump Message */
+#define		rA_RSSIDump_92E			0xcb0
+#define		rB_RSSIDump_92E			0xcb1
+#define		rS1_RXevmDump_92E			0xcb2
+#define		rS2_RXevmDump_92E			0xcb3
+#define		rA_RXsnrDump_92E			0xcb4
+#define		rB_RXsnrDump_92E			0xcb5
+#define		rA_CfoShortDump_92E		0xcb6
+#define		rB_CfoShortDump_92E		0xcb8
+#define	rA_CfoLongDump_92E			0xcba
+#define		rB_CfoLongDump_92E			0xcbc
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif /* __INC_HAL8188EPHYREG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPwrSeq.h
new file mode 100644
index 000000000000..1f2ba8722572
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8192EPwrSeq.h
@@ -0,0 +1,169 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8192E
+#define REALTEK_POWER_SEQUENCE_8192E
+
+#include "HalPwrSeqCmd.h"
+/*
+	Check document WM-20110607-Paul-RTL8192E_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
+*/
+#define	RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS	18
+#define	RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS	18
+#define	RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS	18
+#define	RTL8192E_TRANS_SUS_TO_CARDEMU_STEPS	18
+#define	RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS	18
+#define	RTL8192E_TRANS_PDN_TO_CARDEMU_STEPS	18
+#define	RTL8192E_TRANS_ACT_TO_LPS_STEPS	23
+#define	RTL8192E_TRANS_LPS_TO_ACT_STEPS	23
+#define	RTL8192E_TRANS_END_STEPS	1
+
+
+#define RTL8192E_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, BIT2, 0},/* disable SW LPS 0x04[10]=0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* 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, BIT0, BIT0},/* 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, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+
+
+#define RTL8192E_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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, BIT7, 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+
+
+#define RTL8192E_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8192E_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8192E_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x00CC, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*Unlock small LDO Register*/	\
+	{0x0011, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*Disable small LDO*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8192E_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0011, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*Enable small LDO*/	\
+	{0x00CC, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*Lock small LDO Register*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+
+
+#define RTL8192E_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8192E_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8192E_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8192E_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM, For Repeatly In and out, Taggle bit should be changed*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 0}, /*Polling 0x109[7]=0  TSF in 40M*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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*/\
+	{0x013D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF}, /*Clear ISR*/
+
+#define RTL8192E_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8192E_power_on_flow[RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_radio_off_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_card_disable_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_card_enable_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_suspend_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_resume_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_hwpdn_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_enter_lps_flow[RTL8192E_TRANS_ACT_TO_LPS_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_leave_lps_flow[RTL8192E_TRANS_LPS_TO_ACT_STEPS + RTL8192E_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPhyCfg.h
new file mode 100644
index 000000000000..f5b995c536cf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPhyCfg.h
@@ -0,0 +1,132 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8703BPHYCFG_H__
+#define __INC_HAL8703BPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8703B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8703B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8703B(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8703B(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8703B(PADAPTER	Adapter);
+
+int PHY_RFConfig8703B(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8703B(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8703B(
+	IN	PADAPTER			Adapter,
+	IN	u8					*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8703B(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8703B(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8703B(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8703B(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8703B(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8703b(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPhyReg.h
new file mode 100644
index 000000000000..881a13cfac87
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPhyReg.h
@@ -0,0 +1,1133 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8703BPHYREG_H__
+#define __INC_HAL8703BPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+#define	rBBrx_DFIR					0x954
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define 	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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))
+#define	RF_TX_GAIN_OFFSET_8703B(_val) (abs((_val)) | (((_val) > 0) ? BIT5 : 0))
+
+/* 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPwrSeq.h
new file mode 100644
index 000000000000..0dac13ee34a9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8703BPwrSeq.h
@@ -0,0 +1,198 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8703B
+#define REALTEK_POWER_SEQUENCE_8703B
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20140402-JackieLau-RTL8703B_Power_Architecture v09.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
+*/
+#define	RTL8703B_TRANS_CARDEMU_TO_ACT_STEPS	23
+#define	RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8703B_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8703B_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8703B_TRANS_ACT_TO_LPS_STEPS		15
+#define	RTL8703B_TRANS_LPS_TO_ACT_STEPS		15
+#define	RTL8703B_TRANS_END_STEPS		1
+
+
+#define RTL8703B_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, (BIT4 | BIT3 | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
+	{0x0004, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 , BIT3},/* enabled usb resume */	\
+	{0x0004, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 , 0},/* disable usb resume */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* Enable WL control XTAL setting*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
+	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3},/*For GPIO9 internal pull high setting by test chip*/\
+	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/*For GPIO9 internal pull high setting*/\
+
+
+#define RTL8703B_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* Enable BT control XTAL setting*/\
+	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
+
+
+#define RTL8703B_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8703B_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8703B_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8703B_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8703B_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8703B_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8703B_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8703B_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8703B_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8703B_power_on_flow[RTL8703B_TRANS_CARDEMU_TO_ACT_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_radio_off_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_card_disable_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_card_enable_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_suspend_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_resume_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_hwpdn_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_enter_lps_flow[RTL8703B_TRANS_ACT_TO_LPS_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_leave_lps_flow[RTL8703B_TRANS_LPS_TO_ACT_STEPS + RTL8703B_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPhyCfg.h
new file mode 100644
index 000000000000..18c0a7895b18
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPhyCfg.h
@@ -0,0 +1,132 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723BPHYCFG_H__
+#define __INC_HAL8723BPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8723B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8723B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8723B(
+	IN	PADAPTER			Adapter,
+	IN	enum rf_path			eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8723B(
+	IN	PADAPTER			Adapter,
+	IN	enum rf_path			eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8723B(PADAPTER	Adapter);
+
+int PHY_RFConfig8723B(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8723B(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8723B(
+	IN	PADAPTER			Adapter,
+	IN	u8					*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8723B(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8723B(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8723B(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8723B(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8723B(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8723b(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPhyReg.h
new file mode 100644
index 000000000000..ce485c2ab4be
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPhyReg.h
@@ -0,0 +1,1131 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723BPHYREG_H__
+#define __INC_HAL8723BPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define 	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPwrSeq.h
new file mode 100644
index 000000000000..1aec885cbb1d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723BPwrSeq.h
@@ -0,0 +1,246 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8723B
+#define REALTEK_POWER_SEQUENCE_8723B
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20130815-JackieLau-RTL8723B_Power_Architecture v08.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
+*/
+#define	RTL8723B_TRANS_CARDEMU_TO_ACT_STEPS	26
+#define	RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8723B_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8723B_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8723B_TRANS_ACT_TO_LPS_STEPS		15
+#define	RTL8723B_TRANS_LPS_TO_ACT_STEPS		15
+#define	RTL8723B_TRANS_ACT_TO_SWLPS_STEPS		22
+#define	RTL8723B_TRANS_SWLPS_TO_ACT_STEPS		15
+#define	RTL8723B_TRANS_END_STEPS		1
+
+
+#define RTL8723B_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, (BIT4 | BIT3 | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* Enable WL control XTAL setting*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
+	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3},/*For GPIO9 internal pull high setting by test chip*/\
+	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/*For GPIO9 internal pull high setting*/\
+
+
+#define RTL8723B_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* Enable BT control XTAL setting*/\
+	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
+
+
+#define RTL8723B_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723B_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8723B_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723B_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8723B_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8723B_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8723B_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8723B_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8723B_TRANS_ACT_TO_SWLPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*enable 32 K source*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1},/*CCK and OFDM are enable*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1},/*CCK and OFDM are enable*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated*/	\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x3F},/*Reset MAC TRX*/	\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*disable security engine*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x40},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*reset dual TSF*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/*Reset CPU*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*Reset MCUFWDL register*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1},/*Reset CPU IO Wrapper*/	\
+	{0x0287, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, 0xFF, 0},/*polling RXFF packet number = 0 */	\
+	{0x0286, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/*polling RXDMA idle */	\
+	{0x013D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Clear FW RPWM interrupt */\
+	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Set FW RPWM interrupt source*/\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/*switch TSF to 32K*/\
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/*polling TSF stable*/\
+	{0x0090, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Set FW LPS*/	\
+	{0x0090, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/*polling FW LPS ready */
+
+
+#define RTL8723B_TRANS_SWLPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/*switch TSF to 32K*/\
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/*polling TSF stable*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	0x101[1] = 1, enable security engine*/\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF}, /*.	0x100[7:0] = 0xFF	 enable WMAC TRX*/\
+	{0x06B7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x09}, /*.	reset MAC rx state machine*/\
+	{0x06B4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x86}, /*.	reset MAC rx state machine*/\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/* set CPU RAM code ready*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/* Enable CPU*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*enable CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2},/* Enable CPU*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT7, BIT7},/*polling FW init ready */	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT6, BIT6},/*polling FW init ready */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0}, /*.	0x522 = 0*/
+
+#define RTL8723B_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8723B_power_on_flow[RTL8723B_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_radio_off_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_card_disable_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_card_enable_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_suspend_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_resume_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_hwpdn_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_enter_lps_flow[RTL8723B_TRANS_ACT_TO_LPS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_leave_lps_flow[RTL8723B_TRANS_LPS_TO_ACT_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_enter_swlps_flow[RTL8723B_TRANS_ACT_TO_SWLPS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_leave_swlps_flow[RTL8723B_TRANS_SWLPS_TO_ACT_STEPS + RTL8723B_TRANS_END_STEPS];
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPhyCfg.h
new file mode 100644
index 000000000000..8dd4819f61db
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPhyCfg.h
@@ -0,0 +1,131 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723DPHYCFG_H__
+#define __INC_HAL8723DPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8723D(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8723D(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8723D(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8723D(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8723D(PADAPTER	Adapter);
+
+int PHY_RFConfig8723D(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8723D(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8723D(
+	IN	PADAPTER			Adapter,
+	IN	u8				*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8723D(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8723D(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8723D(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8723D(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8723D(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8723d(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPhyReg.h
new file mode 100644
index 000000000000..036144a388bb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPhyReg.h
@@ -0,0 +1,1134 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723DPHYREG_H__
+#define __INC_HAL8723DPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other definition for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+#define	rBBrx_DFIR					0x954
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 imbalance 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_T_METER_88E				0x42
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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))
+#define		RF_TX_GAIN_OFFSET_8723D(_val) (abs((_val)) | (((_val) > 0) ? BIT(4) : 0))
+
+/* 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPwrSeq.h
new file mode 100644
index 000000000000..60cb53b27bd1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723DPwrSeq.h
@@ -0,0 +1,206 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8723D
+#define REALTEK_POWER_SEQUENCE_8723D
+
+/* #include "PwrSeqCmd.h" */
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20110607-Paul-RTL8192e_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 transition 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
+*/
+#define	RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS	27
+#define	RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS	8
+#define	RTL8723D_TRANS_CARDEMU_TO_SUS_STEPS	7
+#define	RTL8723D_TRANS_SUS_TO_CARDEMU_STEPS	5
+#define	RTL8723D_TRANS_CARDEMU_TO_CARDDIS_STEPS	8
+#define	RTL8723D_TRANS_CARDDIS_TO_CARDEMU_STEPS	7
+#define	RTL8723D_TRANS_CARDEMU_TO_PDN_STEPS	4
+#define	RTL8723D_TRANS_PDN_TO_CARDEMU_STEPS	1
+#define	RTL8723D_TRANS_ACT_TO_LPS_STEPS		13
+#define	RTL8723D_TRANS_LPS_TO_ACT_STEPS		11
+#define	RTL8723D_TRANS_END_STEPS	1
+
+
+#define RTL8723D_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*0x20[0] = 1b'1 enable LDOA12 MACRO block for all interface*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_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(4) | BIT(3) | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/ \
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0) , BIT(0)},/* Disable USB suspend */	\
+	{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*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0) , 0},/* Enable USB suspend */	\
+	{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_POLLING, (BIT(1) | BIT(0)), 0}, \
+	{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},/**/ \
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(6), BIT(6)},/* Enable WL control XTAL setting*/ \
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)},/*Enable HSISR GPIO9 interrupt*/\
+	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3), BIT(3)},/*For GPIO9 internal pull high setting by test chip*/\
+	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(6), BIT(6)},/*For GPIO9 internal pull high setting*/\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*reset RF path S1*/\
+	{0x0077, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*reset RF path S0*/\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/*enable RF path S1*/\
+	{0x0077, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/*enalbe RF path S0*/\
+
+
+#define RTL8723D_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	/*{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*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0}, /*0x2[0]=0 Reset BB, RF enter Power Down mode*/ \
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), 0},/*Enable rising edge triggering interrupt*/ \
+	{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(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*/ \
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(6), 0},/* Enable BT control XTAL setting*/\
+	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
+
+
+#define RTL8723D_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4) | BIT(3), (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), BIT(4)}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), 0}, /*wait power state to suspend*/
+
+#define RTL8723D_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{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*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), 0}, /*Set SDIO suspend local register*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), BIT(1)}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{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 RTL8723D_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(2), BIT(2)}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), BIT(4)}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), 0}, /*wait power state to suspend*/
+
+#define RTL8723D_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{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*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), 0}, /*Set SDIO suspend local register*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), BIT(1)}, /*wait power state to suspend*/\
+	{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*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8723D_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), BIT(4)}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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 RTL8723D_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{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 RTL8723D_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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*/ \
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{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 RTL8723D_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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), BIT1 | BIT0}, /*.	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 RTL8723D_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8723D_power_on_flow[RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_radio_off_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_card_disable_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_CARDDIS_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_card_enable_flow[RTL8723D_TRANS_CARDDIS_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_suspend_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_resume_flow[RTL8723D_TRANS_SUS_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_hwpdn_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_enter_lps_flow[RTL8723D_TRANS_ACT_TO_LPS_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_leave_lps_flow[RTL8723D_TRANS_LPS_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723PwrSeq.h
new file mode 100644
index 000000000000..22de83375e66
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8723PwrSeq.h
@@ -0,0 +1,183 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __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"
+
+#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
+
+
+#define RTL8723A_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, BIT2, 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, BIT1, BIT1},/* 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, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x004E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 1},/*0x4C[23] = 0x4E[7] = 1, switch DPDT_SEL_P output from WL BB */\
+
+#define RTL8723A_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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, BIT7, 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, BIT1, BIT1}, /*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, BIT1, 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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/   \
+
+
+#define RTL8723A_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723A_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8723A_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723A_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8723A_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8723A_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8723A_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8723A_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8723A_power_on_flow[RTL8723A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_radio_off_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_card_disable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_card_enable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_suspend_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_resume_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_hwpdn_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_enter_lps_flow[RTL8723A_TRANS_ACT_TO_LPS_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_leave_lps_flow[RTL8723A_TRANS_LPS_TO_ACT_STEPS + RTL8723A_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PhyCfg.h
new file mode 100644
index 000000000000..0d5282a427f7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PhyCfg.h
@@ -0,0 +1,143 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8812PHYCFG_H__
+#define __INC_HAL8812PHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/*------------------------------Define structure----------------------------*/
+
+
+/* BB/RF related */
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/*
+ * BB and RF register read/write
+ *   */
+u32	PHY_QueryBBReg8812(IN	PADAPTER	Adapter,
+			   IN	u32			RegAddr,
+			   IN	u32			BitMask);
+void	PHY_SetBBReg8812(IN	PADAPTER		Adapter,
+			 IN	u32			RegAddr,
+			 IN	u32			BitMask,
+			 IN	u32			Data);
+u32	PHY_QueryRFReg8812(IN	PADAPTER	Adapter,
+			   IN	enum rf_path	eRFPath,
+			   IN	u32			RegAddr,
+			   IN	u32			BitMask);
+void	PHY_SetRFReg8812(IN	PADAPTER		Adapter,
+			 IN	enum rf_path	eRFPath,
+			 IN	u32			RegAddr,
+			 IN	u32			BitMask,
+			 IN	u32			Data);
+
+/*
+ * Initialization related function
+ *
+ * MAC/BB/RF HAL config */
+int	PHY_MACConfig8812(IN PADAPTER	Adapter);
+int	PHY_BBConfig8812(IN PADAPTER	Adapter);
+void	PHY_BB8812_Config_1T(IN PADAPTER	Adapter);
+int	PHY_RFConfig8812(IN PADAPTER	Adapter);
+
+/* RF config */
+
+s32
+PHY_SwitchWirelessBand8812(
+	IN PADAPTER		Adapter,
+	IN u8			Band
+);
+
+/*
+ * BB TX Power R/W
+ *   */
+void	PHY_GetTxPowerLevel8812(IN PADAPTER	Adapter, OUT s32	*powerlevel);
+void	PHY_SetTxPowerLevel8812(IN PADAPTER	Adapter, IN u8	Channel);
+
+BOOLEAN	PHY_UpdateTxPowerDbm8812(IN PADAPTER	Adapter, IN int	powerInDbm);
+u8 PHY_GetTxPowerIndex_8812A(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+u32 phy_get_tx_bb_swing_8812a(
+	IN	PADAPTER	Adapter,
+	IN	BAND_TYPE	Band,
+	IN	enum rf_path	RFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8812A(
+	IN	PADAPTER		Adapter,
+	IN	u32				PowerIndex,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate
+);
+
+/*
+ * channel switch related funciton
+ *   */
+VOID
+PHY_SetSwChnlBWMode8812(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+/*
+ * BB/MAC/RF other monitor API
+ *   */
+
+VOID
+phy_set_rf_path_switch_8812a(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype---------------------*/
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PhyReg.h
new file mode 100644
index 000000000000..521ebb202346
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PhyReg.h
@@ -0,0 +1,735 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8812PHYREG_H__
+#define __INC_HAL8812PHYREG_H__
+/*--------------------------Define Parameters-------------------------------*/
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/* BB Register Definition */
+
+#define rCCAonSec_Jaguar		0x838
+#define rPwed_TH_Jaguar			0x830
+
+/* BW and sideband setting */
+#define rBWIndication_Jaguar		0x834
+#define rL1PeakTH_Jaguar			0x848
+#define rFPGA0_XA_LSSIReadBack	0x8a0	/*Tranceiver LSSI Readback*/
+#define rRFMOD_Jaguar			0x8ac	/* RF mode */
+#define rADC_Buf_Clk_Jaguar		0x8c4
+#define rRFECTRL_Jaguar			0x900
+#define bRFMOD_Jaguar			0xc3
+#define rCCK_System_Jaguar		0xa00   /* for cck sideband */
+#define bCCK_System_Jaguar		0x10
+
+/* Block & Path enable */
+#define rOFDMCCKEN_Jaguar 		0x808 /* OFDM/CCK block enable */
+#define bOFDMEN_Jaguar			0x20000000
+#define bCCKEN_Jaguar			0x10000000
+#define rRxPath_Jaguar			0x808	/* Rx antenna */
+#define bRxPath_Jaguar			0xff
+#define rTxPath_Jaguar			0x80c	/* Tx antenna */
+#define bTxPath_Jaguar			0x0fffffff
+#define rCCK_RX_Jaguar			0xa04	/* for cck rx path selection */
+#define bCCK_RX_Jaguar			0x0c000000
+#define rVhtlen_Use_Lsig_Jaguar	0x8c3	/* Use LSIG for VHT length */
+
+/* RF read/write-related */
+#define rHSSIRead_Jaguar			0x8b0  /* RF read addr */
+#define bHSSIRead_addr_Jaguar		0xff
+#define bHSSIRead_trigger_Jaguar	0x100
+#define rA_PIRead_Jaguar			0xd04 /* RF readback with PI */
+#define rB_PIRead_Jaguar			0xd44 /* RF readback with PI */
+#define rA_SIRead_Jaguar			0xd08 /* RF readback with SI */
+#define rB_SIRead_Jaguar			0xd48 /* RF readback with SI */
+#define rRead_data_Jaguar			0xfffff
+#define rA_LSSIWrite_Jaguar			0xc90 /* RF write addr */
+#define rB_LSSIWrite_Jaguar			0xe90 /* RF write addr */
+#define bLSSIWrite_data_Jaguar		0x000fffff
+#define bLSSIWrite_addr_Jaguar		0x0ff00000
+
+
+
+/* YN: mask the following register definition temporarily */
+#define rFPGA0_XA_RFInterfaceOE			0x860	/* RF Channel switch */
+#define rFPGA0_XB_RFInterfaceOE			0x864
+
+#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
+ * #define rFPGA0_AdDaClockEn			0x888 */	/* enable ad/da clock1 for dual-phy
+ * #define rFPGA0_AnalogParameter4		0x88c */
+
+
+/* CCK TX scaling */
+#define rCCK_TxFilter1_Jaguar		0xa20
+#define bCCK_TxFilter1_C0_Jaguar	0x00ff0000
+#define bCCK_TxFilter1_C1_Jaguar		0xff000000
+#define rCCK_TxFilter2_Jaguar		0xa24
+#define bCCK_TxFilter2_C2_Jaguar		0x000000ff
+#define bCCK_TxFilter2_C3_Jaguar		0x0000ff00
+#define bCCK_TxFilter2_C4_Jaguar		0x00ff0000
+#define bCCK_TxFilter2_C5_Jaguar		0xff000000
+#define rCCK_TxFilter3_Jaguar		0xa28
+#define bCCK_TxFilter3_C6_Jaguar		0x000000ff
+#define bCCK_TxFilter3_C7_Jaguar		0x0000ff00
+
+
+/* YN: mask the following register definition temporarily
+ * #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 */
+
+/* RXIQC */
+#define rA_RxIQC_AB_Jaguar    	0xc10  /* RxIQ imblance matrix coeff. A & B */
+#define rA_RxIQC_CD_Jaguar    	0xc14  /* RxIQ imblance matrix coeff. C & D */
+#define rA_TxScale_Jaguar 		0xc1c  /* Pah_A TX scaling factor */
+#define rB_TxScale_Jaguar 		0xe1c  /* Path_B TX scaling factor */
+#define rB_RxIQC_AB_Jaguar    	0xe10  /* RxIQ imblance matrix coeff. A & B */
+#define rB_RxIQC_CD_Jaguar    	0xe14  /* RxIQ imblance matrix coeff. C & D */
+#define b_RxIQC_AC_Jaguar		0x02ff  /* bit mask for IQC matrix element A & C */
+#define b_RxIQC_BD_Jaguar		0x02ff0000 /* bit mask for IQC matrix element A & C */
+
+
+/* DIG-related */
+#define rA_IGI_Jaguar				0xc50	/* Initial Gain for path-A */
+#define rB_IGI_Jaguar				0xe50	/* Initial Gain for path-B */
+#define rOFDM_FalseAlarm1_Jaguar	0xf48  /* counter for break */
+#define rOFDM_FalseAlarm2_Jaguar	0xf4c  /* counter for spoofing */
+#define rCCK_FalseAlarm_Jaguar        	0xa5c /* counter for cck false alarm */
+#define b_FalseAlarm_Jaguar			0xffff
+#define rCCK_CCA_Jaguar				0xa08	/* cca threshold */
+#define bCCK_CCA_Jaguar				0x00ff0000
+
+/* Tx Power Ttraining-related */
+#define rA_TxPwrTraing_Jaguar		0xc54
+#define rB_TxPwrTraing_Jaguar		0xe54
+
+/* Report-related */
+#define rOFDM_ShortCFOAB_Jaguar	0xf60
+#define rOFDM_LongCFOAB_Jaguar		0xf64
+#define rOFDM_EndCFOAB_Jaguar		0xf70
+#define rOFDM_AGCReport_Jaguar		0xf84
+#define rOFDM_RxSNR_Jaguar			0xf88
+#define rOFDM_RxEVMCSI_Jaguar		0xf8c
+#define rOFDM_SIGReport_Jaguar		0xf90
+
+/* Misc functions */
+#define rEDCCA_Jaguar				0x8a4 /* EDCCA */
+#define bEDCCA_Jaguar				0xffff
+#define rAGC_table_Jaguar			0x82c   /* AGC tabel select */
+#define bAGC_table_Jaguar			0x3
+#define b_sel5g_Jaguar    				0x1000 /* sel5g */
+#define b_LNA_sw_Jaguar				0x8000 /* HW/WS control for LNA */
+#define rFc_area_Jaguar				0x860   /* fc_area */
+#define bFc_area_Jaguar				0x1ffe000
+#define rSingleTone_ContTx_Jaguar	0x914
+
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xcb0  /* Path_A RFE cotrol pinmux */
+#define rB_RFE_Pinmux_Jaguar	0xeb0 /* Path_B RFE control pinmux */
+#define rA_RFE_Inv_Jaguar		0xcb4  /* Path_A RFE cotrol   */
+#define rB_RFE_Inv_Jaguar		0xeb4 /* Path_B RFE control */
+#define rA_RFE_Jaguar			0xcb8  /* Path_A RFE cotrol   */
+#define rB_RFE_Jaguar			0xeb8 /* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define r_ANTSEL_SW_Jaguar		0x900 /* ANTSEL SW Control */
+#define bMask_RFEInv_Jaguar		0x3ff00000
+#define bMask_AntselPathFollow_Jaguar 0x00030000
+
+/* TX AGC */
+#define rTxAGC_A_CCK11_CCK1_JAguar				0xc20
+#define rTxAGC_A_Ofdm18_Ofdm6_JAguar				0xc24
+#define rTxAGC_A_Ofdm54_Ofdm24_JAguar			0xc28
+#define rTxAGC_A_MCS3_MCS0_JAguar					0xc2c
+#define rTxAGC_A_MCS7_MCS4_JAguar					0xc30
+#define rTxAGC_A_MCS11_MCS8_JAguar				0xc34
+#define rTxAGC_A_MCS15_MCS12_JAguar				0xc38
+#define rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	0xc3c
+#define rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	0xc40
+#define rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	0xc44
+#define rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	0xc48
+#define rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	0xc4c
+#define rTxAGC_B_CCK11_CCK1_JAguar				0xe20
+#define rTxAGC_B_Ofdm18_Ofdm6_JAguar				0xe24
+#define rTxAGC_B_Ofdm54_Ofdm24_JAguar			0xe28
+#define rTxAGC_B_MCS3_MCS0_JAguar					0xe2c
+#define rTxAGC_B_MCS7_MCS4_JAguar					0xe30
+#define rTxAGC_B_MCS11_MCS8_JAguar				0xe34
+#define rTxAGC_B_MCS15_MCS12_JAguar				0xe38
+#define rTxAGC_B_Nss1Index3_Nss1Index0_JAguar		0xe3c
+#define rTxAGC_B_Nss1Index7_Nss1Index4_JAguar		0xe40
+#define rTxAGC_B_Nss2Index1_Nss1Index8_JAguar		0xe44
+#define rTxAGC_B_Nss2Index5_Nss2Index2_JAguar		0xe48
+#define rTxAGC_B_Nss2Index9_Nss2Index6_JAguar		0xe4c
+#define bTxAGC_byte0_Jaguar							0xff
+#define bTxAGC_byte1_Jaguar							0xff00
+#define bTxAGC_byte2_Jaguar							0xff0000
+#define bTxAGC_byte3_Jaguar							0xff000000
+
+/* IQK YN: temporaily mask this part
+ * #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 */
+
+
+/* AFE-related */
+#define rA_AFEPwr1_Jaguar					0xc60 /* dynamic AFE power control */
+#define rA_AFEPwr2_Jaguar					0xc64 /* dynamic AFE power control */
+#define rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xc68
+#define rA_Tx_CCKBBON_OFDMRFON_Jaguar	0xc6c
+#define rA_Tx_OFDMBBON_Tx2Rx_Jaguar		0xc70
+#define rA_Tx2Tx_RXCCK_Jaguar				0xc74
+#define rA_Rx_OFDM_WaitRIFS_Jaguar			0xc78
+#define rA_Rx2Rx_BT_Jaguar					0xc7c
+#define rA_sleep_nav_Jaguar					0xc80
+#define rA_pmpd_Jaguar						0xc84
+#define rB_AFEPwr1_Jaguar					0xe60 /* dynamic AFE power control */
+#define rB_AFEPwr2_Jaguar					0xe64 /* dynamic AFE power control */
+#define rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xe68
+#define rB_Tx_CCKBBON_OFDMRFON_Jaguar	0xe6c
+#define rB_Tx_OFDMBBON_Tx2Rx_Jaguar		0xe70
+#define rB_Tx2Tx_RXCCK_Jaguar				0xe74
+#define rB_Rx_OFDM_WaitRIFS_Jaguar			0xe78
+#define rB_Rx2Rx_BT_Jaguar					0xe7c
+#define rB_sleep_nav_Jaguar					0xe80
+#define rB_pmpd_Jaguar						0xe84
+
+
+/* YN: mask these registers temporaily
+ * #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 */
+
+
+/* RSSI Dump */
+#define rA_RSSIDump_Jaguar			0xBF0
+#define rB_RSSIDump_Jaguar			0xBF1
+#define rS1_RXevmDump_Jaguar		0xBF4
+#define rS2_RXevmDump_Jaguar		0xBF5
+#define rA_RXsnrDump_Jaguar		0xBF6
+#define rB_RXsnrDump_Jaguar		0xBF7
+#define rA_CfoShortDump_Jaguar		0xBF8
+#define rB_CfoShortDump_Jaguar		0xBFA
+#define rA_CfoLongDump_Jaguar		0xBEC
+#define rB_CfoLongDump_Jaguar		0xBEE
+
+
+/* RF Register
+ *   */
+#define RF_AC_Jaguar				0x00	/*  */
+#define RF_RF_Top_Jaguar			0x07	/*  */
+#define RF_TXLOK_Jaguar				0x08	/*  */
+#define RF_TXAPK_Jaguar				0x0B
+#define RF_CHNLBW_Jaguar 			0x18	/* RF channel and BW switch */
+#define RF_RCK1_Jaguar				0x1c	/*  */
+#define RF_RCK2_Jaguar				0x1d
+#define RF_RCK3_Jaguar			0x1e
+#define RF_ModeTableAddr			0x30
+#define RF_ModeTableData0			0x31
+#define RF_ModeTableData1			0x32
+#define RF_TxLCTank_Jaguar	0x54
+#define RF_APK_Jaguar				0x63
+#define RF_LCK						0xB4
+#define RF_WeLut_Jaguar				0xEF
+
+#define bRF_CHNLBW_MOD_AG_Jaguar	0x70300
+#define bRF_CHNLBW_BW				0xc00
+
+
+/*
+ * RL6052 Register definition
+ *   */
+#define RF_AC						0x00	/*  */
+#define RF_IPA_A					0x0C	/*  */
+#define RF_TXBIAS_A					0x0D
+#define RF_BS_PA_APSET_G9_G11		0x0E
+#define RF_MODE1					0x10	/*  */
+#define RF_MODE2					0x11	/*  */
+#define RF_CHNLBW					0x18	/* RF channel and BW switch */
+#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 */
+#define RF_0x52						0x52
+#define RF_WE_LUT					0xEF
+
+#define RF_TX_GAIN_OFFSET_8812A(_val) ((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
+#define RF_TX_GAIN_OFFSET_8821A(_val) ((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
+
+/*
+ * 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
+
+
+/*
+ * 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
+
+/*
+ * 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_XA_HSSIParameter1	0x820	/* RF 3 wire register */
+#define rFPGA0_XA_HSSIParameter2	0x824
+#define rFPGA0_XB_HSSIParameter1	0x828
+#define rFPGA0_XB_HSSIParameter2	0x82c
+
+#define rFPGA0_XAB_SwitchControl	0x858	/* RF Channel switch */
+#define rFPGA0_XCD_SwitchControl	0x85c
+
+#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
+#define rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#define rFPGA0_AnalogParameter4	0x88c
+#define rFPGA0_XB_LSSIReadBack		0x8a4
+#define rFPGA0_XCD_RFPara	0x8b4
+
+/*
+ * 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?? */
+
+/*
+ * PageA(0xA00)
+ *   */
+#define rCCK0_System				0xa00
+#define rCCK0_AFESetting				0xa04	/* Disable init gain now */ /* Select RX path by RSSI */
+#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 */
+
+/*
+ * 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
+
+/*
+ * 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 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 rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86c
+
+#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
+
+
+/* 2. Page8(0x800) */
+#define bRFMOD						0x1	/* Reg 0x800 rFPGA0_RFMOD */
+#define bJapanMode					0x2
+#define bCCKTxSC					0x30
+#define bCCKEn						0x1000000
+#define bOFDMEn						0x2000000
+#define bXBTxAGC                  			0xf00	/* Reg 80c rFPGA0_TxGainStage */
+#define bXCTxAGC			0xf000
+#define bXDTxAGC			0xf0000
+
+/* 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
+
+/* 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
+
+
+/*
+ * Other Definition
+ *   */
+
+#define bEnable                   0x1	/* Useless */
+#define bDisable                  0x0
+
+/* byte endable for srwrite */
+#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 bMaskH3Bytes				0xffffff00
+#define bMask12Bits				0xfff
+#define bMaskH4Bits				0xf0000000
+#define bMaskOFDM_D			0xffc00000
+#define bMaskCCK				0x3f3f3f3f
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PwrSeq.h
new file mode 100644
index 000000000000..498faf8114ae
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8812PwrSeq.h
@@ -0,0 +1,208 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HAL8812PWRSEQ_H__
+#define __HAL8812PWRSEQ_H__
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WB-110628-DZ-RTL8195 (Jaguar) Power Architecture-R04.pdf
+	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
+*/
+#define	RTL8812_TRANS_CARDEMU_TO_ACT_STEPS	15
+#define	RTL8812_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8812_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8812_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8812_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8812_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8812_TRANS_ACT_TO_LPS_STEPS	15
+#define	RTL8812_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8812_TRANS_END_STEPS	1
+
+
+#define RTL8812_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	/*{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, BIT3, 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/   \
+	{0x0024, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /* 0x24[1] Choose the type of buffer after xosc: nand*/   \
+	{0x0028, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, 0}, /* 0x28[33] Choose the type of buffer after xosc: nand*/
+
+#define RTL8812_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
+	{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_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	/*{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, BIT7, 0},//0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x2A}, /* 0x07[7:0] = 0x28 sps pwm mode 0x2a for BT coex*/	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	/*{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 | BIT1, 0}, //  0x02[1:0] = 0	reset BB */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/
+
+#define RTL8812_TRANS_CARDEMU_TO_SUS													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xcc},\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xEC},\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* suspend option all off */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, BIT7},/*0x14[7] = 1 turn on ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, BIT0},/* 0x15[0] =1 trun on ZCD */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 2b'11 enable WL suspend for PCIe*/
+
+#define RTL8812_TRANS_SUS_TO_CARDEMU													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 2b'01enable WL suspend*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO sleep mode leave */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, 0},/* 0x15[0] =0 trun off ZCD */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, 0},/*0x14[7] = 0 turn off ZCD */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */
+
+#define RTL8812_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	/**{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, //0x194[0]=0 , disable 32K clock*/	\
+	/**{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x94}, //0x93 = 0x94 , 90[30] =0 enable 500k ANA clock .switch clock from 12M to 500K , 90 [26] =0 disable EEprom loader clock*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x03[2] = 0, reset 8051*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x05}, /*0x80 = 05h if reload fw, fill the default value of host_CPU handshake field*/	\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xcc},\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xEC},\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, BIT7},/*0x14[7] = 1 turn on ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, BIT0},/* 0x15[0] =1 trun on ZCD */	\
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, 0},/*0x12[0] = 0 force PFM mode */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /*0x01f[1]=0 , disable RFC_0  control  REG_RF_CTRL_8812 */	\
+	{0x0076, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /*0x076[1]=0 , disable RFC_1  control REG_OPT_CTRL_8812 +2 */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 2b'01 enable WL suspend*/
+
+#define RTL8812_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/                       \
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*0x12[0] = 1 force PWM mode */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, 0},/*0x14[7] = 0 turn off ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, 0},/* 0x15[0] =0 trun off ZCD */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO leave sleep mode */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x04[10] = 0, enable SW LPS PCIE only*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 2b'01enable WL suspend*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x03[2] = 1, enable 8051*/	\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/  \
+	{0x0024, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /* 0x24[1] Choose the type of buffer after xosc: schmitt trigger*/ \
+	{0x0028, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /* 0x28[33] Choose the type of buffer after xosc: schmitt trigger*/
+
+
+#define RTL8812_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8812_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8812_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x7F},/*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*/	\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated, and RF closed*/	\
+	{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_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 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, BIT1, 0},/*check if removed later*/		\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/
+
+
+#define RTL8812_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/	\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/	\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8812_TRANS_END																\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/		\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+extern WLAN_PWR_CFG rtl8812_power_on_flow[RTL8812_TRANS_CARDEMU_TO_ACT_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_radio_off_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_card_disable_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_PDN_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_card_enable_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_PDN_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_suspend_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_SUS_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_resume_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_SUS_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_hwpdn_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_PDN_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_enter_lps_flow[RTL8812_TRANS_ACT_TO_LPS_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_leave_lps_flow[RTL8812_TRANS_LPS_TO_ACT_STEPS + RTL8812_TRANS_END_STEPS];
+
+#endif /* __HAL8812PWRSEQ_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PhyCfg.h
new file mode 100644
index 000000000000..96f07942ee03
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PhyCfg.h
@@ -0,0 +1,264 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8814PHYCFG_H__
+#define __INC_HAL8814PHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/*------------------------------Define structure----------------------------*/
+
+
+/* BB/RF related */
+
+#define	SIC_ENABLE				0
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/* 1. BB register R/W API */
+
+extern	u32
+PHY_QueryBBReg8814A(IN	PADAPTER	Adapter,
+		    IN	u32		RegAddr,
+		    IN	u32		BitMask);
+
+
+VOID
+PHY_SetBBReg8814A(IN	PADAPTER	Adapter,
+		  IN	u32		RegAddr,
+		  IN	u32		BitMask,
+		  IN	u32		Data);
+
+
+extern	u32
+PHY_QueryRFReg8814A(IN	PADAPTER			Adapter,
+		    IN	enum rf_path	eRFPath,
+		    IN	u32			RegAddr,
+		    IN	u32			BitMask);
+
+
+void
+PHY_SetRFReg8814A(IN	PADAPTER			Adapter,
+		  IN	enum rf_path		eRFPath,
+		  IN	u32				RegAddr,
+		  IN	u32				BitMask,
+		  IN	u32				Data);
+
+/* 1 3. Initial BB/RF config by reading MAC/BB/RF txt. */
+s32
+phy_BB8814A_Config_ParaFile(
+	IN	PADAPTER	Adapter
+);
+
+VOID
+PHY_ConfigBB_8814A(
+	IN	PADAPTER	Adapter
+);
+
+
+VOID
+phy_ADC_CLK_8814A(
+	IN	PADAPTER	Adapter
+);
+
+s32
+PHY_RFConfig8814A(
+	IN	PADAPTER	Adapter
+);
+
+/*
+ * RF Power setting
+ *
+ * BOOLEAN	PHY_SetRFPowerState8814A(PADAPTER Adapter, rt_rf_power_state	eRFPowerState); */
+
+/* 1 5. Tx  Power setting API */
+
+VOID
+PHY_GetTxPowerLevel8814(
+	IN	PADAPTER		Adapter,
+	OUT ps4Byte			powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8814(
+	IN	PADAPTER		Adapter,
+	IN	u8			Channel
+);
+
+u8
+phy_get_tx_power_index_8814a(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	IN	enum channel_width BandWidth,
+	IN	u8				Channel
+);
+
+u8
+PHY_GetTxPowerIndex8814A(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	IN	u8				BandWidth,
+	IN	u8				Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_SetTxPowerIndex_8814A(
+	IN	PADAPTER		Adapter,
+	IN	u32				PowerIndex,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate
+);
+
+
+BOOLEAN
+PHY_UpdateTxPowerDbm8814A(
+	IN	PADAPTER	Adapter,
+	IN	s4Byte		powerInDbm
+);
+
+
+u32
+PHY_GetTxBBSwing_8814A(
+	IN	PADAPTER	Adapter,
+	IN	BAND_TYPE	Band,
+	IN	enum rf_path	RFPath
+);
+
+
+
+/* 1 6. Channel setting API */
+#if 0
+VOID
+PHY_SwChnlTimerCallback8814A(
+	IN	struct timer_list		*p_timer
+);
+#endif
+VOID
+PHY_SwChnlWorkItemCallback8814A(
+	IN PVOID            pContext
+);
+
+
+VOID
+HAL_HandleSwChnl8814A(
+	IN	PADAPTER	pAdapter,
+	IN	u8		channel
+);
+
+VOID
+PHY_SwChnlSynchronously8814A(IN	PADAPTER		pAdapter,
+			     IN	u8			channel);
+
+VOID
+PHY_SwChnlAndSetBWModeCallback8814A(IN PVOID            pContext);
+
+
+VOID
+PHY_HandleSwChnlAndSetBW8814A(
+	IN	PADAPTER			Adapter,
+	IN	BOOLEAN				bSwitchChannel,
+	IN	BOOLEAN				bSetBandWidth,
+	IN	u8					ChannelNum,
+	IN	enum channel_width	ChnlWidth,
+	IN	u8					ChnlOffsetOf40MHz,
+	IN	u8					ChnlOffsetOf80MHz,
+	IN	u8					CenterFrequencyIndex1
+);
+
+
+BOOLEAN
+PHY_QueryRFPathSwitch_8814A(IN	PADAPTER	pAdapter);
+
+
+
+#if (USE_WORKITEM)
+VOID
+RtCheckForHangWorkItemCallback8814A(
+	IN PVOID   pContext
+);
+#endif
+
+BOOLEAN
+SetAntennaConfig8814A(
+	IN	PADAPTER	Adapter,
+	IN	u8		DefaultAnt
+);
+
+VOID
+PHY_SetRFEReg8814A(
+	IN PADAPTER		Adapter,
+	IN BOOLEAN		bInit,
+	IN u8		Band
+);
+
+
+s32
+PHY_SwitchWirelessBand8814A(
+	IN PADAPTER		 Adapter,
+	IN u8		Band
+);
+
+VOID
+PHY_SetIO_8814A(
+	PADAPTER		pAdapter
+);
+
+VOID
+PHY_SetSwChnlBWMode8814(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+s32 PHY_MACConfig8814(PADAPTER Adapter);
+int PHY_BBConfig8814(PADAPTER	Adapter);
+VOID PHY_Set_SecCCATH_by_RXANT_8814A(PADAPTER	pAdapter, u4Byte ulAntennaRx);
+
+
+
+/*--------------------------Exported Function prototype---------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PhyReg.h
new file mode 100644
index 000000000000..21851a8988b7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PhyReg.h
@@ -0,0 +1,863 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8814PHYREG_H__
+#define __INC_HAL8814PHYREG_H__
+/*--------------------------Define Parameters-------------------------------*/
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/* BB Register Definition */
+
+#define rCCAonSec_Jaguar		0x838
+#define rPwed_TH_Jaguar			0x830
+#define rL1_Weight_Jaguar		0x840
+#define	r_L1_SBD_start_time		0x844
+
+/* BW and sideband setting */
+#define rBWIndication_Jaguar		0x834
+#define rL1PeakTH_Jaguar		0x848
+#define rRFMOD_Jaguar			0x8ac	/* RF mode */
+#define rADC_Buf_Clk_Jaguar		0x8c4
+#define	rADC_Buf_40_Clk_Jaguar2		0x8c8
+#define rRFECTRL_Jaguar			0x900
+#define bRFMOD_Jaguar			0xc3
+#define rCCK_System_Jaguar		0xa00   /* for cck sideband */
+#define bCCK_System_Jaguar		0x10
+
+/* Block & Path enable */
+#define rOFDMCCKEN_Jaguar 		0x808 /* OFDM/CCK block enable */
+#define bOFDMEN_Jaguar			0x20000000
+#define bCCKEN_Jaguar			0x10000000
+#define rRxPath_Jaguar			0x808	/* Rx antenna */
+#define bRxPath_Jaguar			0xff
+#define rTxPath_Jaguar			0x80c	/* Tx antenna */
+#define bTxPath_Jaguar			0x0fffffff
+#define rCCK_RX_Jaguar			0xa04	/* for cck rx path selection */
+#define bCCK_RX_Jaguar			0x0c000000
+#define rVhtlen_Use_Lsig_Jaguar	0x8c3	/* Use LSIG for VHT length */
+
+#define	rRxPath_Jaguar2				0xa04	/* Rx antenna */
+#define	rTxAnt_1Nsts_Jaguar2		0x93c	/* Tx antenna for 1Nsts */
+#define	rTxAnt_23Nsts_Jaguar2		0x940	/* Tx antenna for 2Nsts and 3Nsts */
+
+
+/* RF read/write-related */
+#define rHSSIRead_Jaguar			0x8b0  /* RF read addr */
+#define bHSSIRead_addr_Jaguar		0xff
+#define bHSSIRead_trigger_Jaguar	0x100
+#define rA_PIRead_Jaguar			0xd04 /* RF readback with PI */
+#define rB_PIRead_Jaguar			0xd44 /* RF readback with PI */
+#define rA_SIRead_Jaguar			0xd08 /* RF readback with SI */
+#define rB_SIRead_Jaguar			0xd48 /* RF readback with SI */
+#define rRead_data_Jaguar			0xfffff
+#define rA_LSSIWrite_Jaguar			0xc90 /* RF write addr */
+#define rB_LSSIWrite_Jaguar			0xe90 /* RF write addr */
+#define bLSSIWrite_data_Jaguar		0x000fffff
+#define bLSSIWrite_addr_Jaguar		0x0ff00000
+
+#define	rC_PIRead_Jaguar2			0xd84 /* RF readback with PI */
+#define	rD_PIRead_Jaguar2			0xdC4 /* RF readback with PI */
+#define	rC_SIRead_Jaguar2			0xd88 /* RF readback with SI */
+#define	rD_SIRead_Jaguar2			0xdC8 /* RF readback with SI */
+#define	rC_LSSIWrite_Jaguar2		0x1890 /* RF write addr */
+#define	rD_LSSIWrite_Jaguar2		0x1A90 /* RF write addr */
+
+
+/* YN: mask the following register definition temporarily */
+#define rFPGA0_XA_RFInterfaceOE			0x860	/* RF Channel switch */
+#define rFPGA0_XB_RFInterfaceOE			0x864
+
+#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
+ * #define rFPGA0_AdDaClockEn			0x888 */	/* enable ad/da clock1 for dual-phy
+ * #define rFPGA0_AnalogParameter4		0x88c */
+
+
+/* CCK TX scaling */
+#define rCCK_TxFilter1_Jaguar		0xa20
+#define bCCK_TxFilter1_C0_Jaguar	0x00ff0000
+#define bCCK_TxFilter1_C1_Jaguar		0xff000000
+#define rCCK_TxFilter2_Jaguar		0xa24
+#define bCCK_TxFilter2_C2_Jaguar		0x000000ff
+#define bCCK_TxFilter2_C3_Jaguar		0x0000ff00
+#define bCCK_TxFilter2_C4_Jaguar		0x00ff0000
+#define bCCK_TxFilter2_C5_Jaguar		0xff000000
+#define rCCK_TxFilter3_Jaguar		0xa28
+#define bCCK_TxFilter3_C6_Jaguar		0x000000ff
+#define bCCK_TxFilter3_C7_Jaguar		0x0000ff00
+/* NBI & CSI Mask setting */
+#define	rCSI_Mask_Setting1_Jaguar	0x874
+#define	rCSI_Fix_Mask0_Jaguar		0x880
+#define	rCSI_Fix_Mask1_Jaguar		0x884
+#define	rCSI_Fix_Mask2_Jaguar		0x888
+#define	rCSI_Fix_Mask3_Jaguar		0x88c
+#define	rCSI_Fix_Mask4_Jaguar		0x890
+#define	rCSI_Fix_Mask5_Jaguar		0x894
+#define	rCSI_Fix_Mask6_Jaguar		0x898
+#define	rCSI_Fix_Mask7_Jaguar		0x89c
+#define	rNBI_Setting_Jaguar			0x87c
+
+
+/* YN: mask the following register definition temporarily
+ * #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 */
+
+/* RXIQC */
+#define rA_RxIQC_AB_Jaguar    	0xc10  /* RxIQ imblance matrix coeff. A & B */
+#define rA_RxIQC_CD_Jaguar    	0xc14  /* RxIQ imblance matrix coeff. C & D */
+#define rA_TxScale_Jaguar 		0xc1c  /* Pah_A TX scaling factor */
+#define rB_TxScale_Jaguar 		0xe1c  /* Path_B TX scaling factor */
+#define rB_RxIQC_AB_Jaguar    	0xe10  /* RxIQ imblance matrix coeff. A & B */
+#define rB_RxIQC_CD_Jaguar    	0xe14  /* RxIQ imblance matrix coeff. C & D */
+#define b_RxIQC_AC_Jaguar		0x02ff  /* bit mask for IQC matrix element A & C */
+#define b_RxIQC_BD_Jaguar		0x02ff0000 /* bit mask for IQC matrix element A & C */
+
+#define	rC_TxScale_Jaguar2 		0x181c  /* Pah_C TX scaling factor */
+#define	rD_TxScale_Jaguar2 		0x1A1c  /* Path_D TX scaling factor */
+#define	rRF_TxGainOffset		0x55
+
+/* DIG-related */
+#define rA_IGI_Jaguar				0xc50	/* Initial Gain for path-A */
+#define rB_IGI_Jaguar				0xe50	/* Initial Gain for path-B */
+#define	rC_IGI_Jaguar2				0x1850	/* Initial Gain for path-C */
+#define	rD_IGI_Jaguar2				0x1A50	/* Initial Gain for path-D */
+
+#define rOFDM_FalseAlarm1_Jaguar	0xf48  /* counter for break */
+#define rOFDM_FalseAlarm2_Jaguar	0xf4c  /* counter for spoofing */
+#define rCCK_FalseAlarm_Jaguar        	0xa5c /* counter for cck false alarm */
+#define b_FalseAlarm_Jaguar			0xffff
+#define rCCK_CCA_Jaguar				0xa08	/* cca threshold */
+#define bCCK_CCA_Jaguar				0x00ff0000
+
+/* Tx Power Ttraining-related */
+#define rA_TxPwrTraing_Jaguar		0xc54
+#define rB_TxPwrTraing_Jaguar		0xe54
+
+/* Report-related */
+#define rOFDM_ShortCFOAB_Jaguar	0xf60
+#define rOFDM_LongCFOAB_Jaguar		0xf64
+#define rOFDM_EndCFOAB_Jaguar		0xf70
+#define rOFDM_AGCReport_Jaguar		0xf84
+#define rOFDM_RxSNR_Jaguar			0xf88
+#define rOFDM_RxEVMCSI_Jaguar		0xf8c
+#define rOFDM_SIGReport_Jaguar		0xf90
+
+/* Misc functions */
+#define rEDCCA_Jaguar				0x8a4 /* EDCCA */
+#define bEDCCA_Jaguar				0xffff
+#define rAGC_table_Jaguar			0x82c   /* AGC tabel select */
+#define bAGC_table_Jaguar			0x3
+#define b_sel5g_Jaguar    				0x1000 /* sel5g */
+#define b_LNA_sw_Jaguar				0x8000 /* HW/WS control for LNA */
+#define rFc_area_Jaguar				0x860   /* fc_area */
+#define bFc_area_Jaguar				0x1ffe000
+#define rSingleTone_ContTx_Jaguar	0x914
+
+#define	rAGC_table_Jaguar2			0x958	/* AGC tabel select */
+#define	rDMA_trigger_Jaguar2		0x95C	/* ADC sample mode */
+
+
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xcb0  /* Path_A RFE cotrol pinmux */
+#define rB_RFE_Pinmux_Jaguar	0xeb0 /* Path_B RFE control pinmux */
+#define rA_RFE_Inv_Jaguar		0xcb4  /* Path_A RFE cotrol   */
+#define rB_RFE_Inv_Jaguar		0xeb4 /* Path_B RFE control */
+#define rA_RFE_Jaguar			0xcb8  /* Path_A RFE cotrol   */
+#define rB_RFE_Jaguar			0xeb8 /* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define r_ANTSEL_SW_Jaguar		0x900 /* ANTSEL SW Control */
+#define bMask_RFEInv_Jaguar		0x3ff00000
+#define bMask_AntselPathFollow_Jaguar 0x00030000
+
+#define	rC_RFE_Pinmux_Jaguar	0x18B4	/* Path_C RFE cotrol pinmux */
+#define	rD_RFE_Pinmux_Jaguar	0x1AB4	/* Path_D RFE cotrol pinmux */
+#define	rA_RFE_Sel_Jaguar2		0x1990
+
+
+
+/* TX AGC */
+#define rTxAGC_A_CCK11_CCK1_JAguar				0xc20
+#define rTxAGC_A_Ofdm18_Ofdm6_JAguar				0xc24
+#define rTxAGC_A_Ofdm54_Ofdm24_JAguar			0xc28
+#define rTxAGC_A_MCS3_MCS0_JAguar					0xc2c
+#define rTxAGC_A_MCS7_MCS4_JAguar					0xc30
+#define rTxAGC_A_MCS11_MCS8_JAguar				0xc34
+#define rTxAGC_A_MCS15_MCS12_JAguar				0xc38
+#define rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	0xc3c
+#define rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	0xc40
+#define rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	0xc44
+#define rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	0xc48
+#define rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	0xc4c
+#define rTxAGC_B_CCK11_CCK1_JAguar				0xe20
+#define rTxAGC_B_Ofdm18_Ofdm6_JAguar				0xe24
+#define rTxAGC_B_Ofdm54_Ofdm24_JAguar			0xe28
+#define rTxAGC_B_MCS3_MCS0_JAguar					0xe2c
+#define rTxAGC_B_MCS7_MCS4_JAguar					0xe30
+#define rTxAGC_B_MCS11_MCS8_JAguar				0xe34
+#define rTxAGC_B_MCS15_MCS12_JAguar				0xe38
+#define rTxAGC_B_Nss1Index3_Nss1Index0_JAguar		0xe3c
+#define rTxAGC_B_Nss1Index7_Nss1Index4_JAguar		0xe40
+#define rTxAGC_B_Nss2Index1_Nss1Index8_JAguar		0xe44
+#define rTxAGC_B_Nss2Index5_Nss2Index2_JAguar		0xe48
+#define rTxAGC_B_Nss2Index9_Nss2Index6_JAguar		0xe4c
+#define bTxAGC_byte0_Jaguar							0xff
+#define bTxAGC_byte1_Jaguar							0xff00
+#define bTxAGC_byte2_Jaguar							0xff0000
+#define bTxAGC_byte3_Jaguar							0xff000000
+
+
+/* TX AGC */
+#define		rTxAGC_A_CCK11_CCK1_Jaguar2	0xc20
+#define		rTxAGC_A_Ofdm18_Ofdm6_Jaguar2	0xc24
+#define		rTxAGC_A_Ofdm54_Ofdm24_Jaguar2	0xc28
+#define		rTxAGC_A_MCS3_MCS0_Jaguar2	0xc2c
+#define		rTxAGC_A_MCS7_MCS4_Jaguar2	0xc30
+#define		rTxAGC_A_MCS11_MCS8_Jaguar2	0xc34
+#define		rTxAGC_A_MCS15_MCS12_Jaguar2	0xc38
+#define		rTxAGC_A_MCS19_MCS16_Jaguar2	0xcd8
+#define		rTxAGC_A_MCS23_MCS20_Jaguar2	0xcdc
+#define		rTxAGC_A_Nss1Index3_Nss1Index0_Jaguar2	0xc3c
+#define		rTxAGC_A_Nss1Index7_Nss1Index4_Jaguar2	0xc40
+#define		rTxAGC_A_Nss2Index1_Nss1Index8_Jaguar2	0xc44
+#define		rTxAGC_A_Nss2Index5_Nss2Index2_Jaguar2	0xc48
+#define		rTxAGC_A_Nss2Index9_Nss2Index6_Jaguar2	0xc4c
+#define		rTxAGC_A_Nss3Index3_Nss3Index0_Jaguar2	0xce0
+#define		rTxAGC_A_Nss3Index7_Nss3Index4_Jaguar2	0xce4
+#define		rTxAGC_A_Nss3Index9_Nss3Index8_Jaguar2	0xce8
+#define		rTxAGC_B_CCK11_CCK1_Jaguar2	0xe20
+#define		rTxAGC_B_Ofdm18_Ofdm6_Jaguar2	0xe24
+#define		rTxAGC_B_Ofdm54_Ofdm24_Jaguar2	0xe28
+#define		rTxAGC_B_MCS3_MCS0_Jaguar2	0xe2c
+#define		rTxAGC_B_MCS7_MCS4_Jaguar2	0xe30
+#define		rTxAGC_B_MCS11_MCS8_Jaguar2	0xe34
+#define		rTxAGC_B_MCS15_MCS12_Jaguar2	0xe38
+#define		rTxAGC_B_MCS19_MCS16_Jaguar2	0xed8
+#define		rTxAGC_B_MCS23_MCS20_Jaguar2	0xedc
+#define		rTxAGC_B_Nss1Index3_Nss1Index0_Jaguar2	0xe3c
+#define		rTxAGC_B_Nss1Index7_Nss1Index4_Jaguar2	0xe40
+#define		rTxAGC_B_Nss2Index1_Nss1Index8_Jaguar2	0xe44
+#define		rTxAGC_B_Nss2Index5_Nss2Index2_Jaguar2	0xe48
+#define		rTxAGC_B_Nss2Index9_Nss2Index6_Jaguar2	0xe4c
+#define		rTxAGC_B_Nss3Index3_Nss3Index0_Jaguar2	0xee0
+#define		rTxAGC_B_Nss3Index7_Nss3Index4_Jaguar2	0xee4
+#define		rTxAGC_B_Nss3Index9_Nss3Index8_Jaguar2	0xee8
+#define		rTxAGC_C_CCK11_CCK1_Jaguar2	0x1820
+#define		rTxAGC_C_Ofdm18_Ofdm6_Jaguar2	0x1824
+#define		rTxAGC_C_Ofdm54_Ofdm24_Jaguar2	0x1828
+#define		rTxAGC_C_MCS3_MCS0_Jaguar2	0x182c
+#define		rTxAGC_C_MCS7_MCS4_Jaguar2	0x1830
+#define		rTxAGC_C_MCS11_MCS8_Jaguar2	0x1834
+#define		rTxAGC_C_MCS15_MCS12_Jaguar2	0x1838
+#define		rTxAGC_C_MCS19_MCS16_Jaguar2	0x18d8
+#define		rTxAGC_C_MCS23_MCS20_Jaguar2	0x18dc
+#define		rTxAGC_C_Nss1Index3_Nss1Index0_Jaguar2	0x183c
+#define		rTxAGC_C_Nss1Index7_Nss1Index4_Jaguar2	0x1840
+#define		rTxAGC_C_Nss2Index1_Nss1Index8_Jaguar2	0x1844
+#define		rTxAGC_C_Nss2Index5_Nss2Index2_Jaguar2	0x1848
+#define		rTxAGC_C_Nss2Index9_Nss2Index6_Jaguar2	0x184c
+#define		rTxAGC_C_Nss3Index3_Nss3Index0_Jaguar2	0x18e0
+#define		rTxAGC_C_Nss3Index7_Nss3Index4_Jaguar2	0x18e4
+#define		rTxAGC_C_Nss3Index9_Nss3Index8_Jaguar2	0x18e8
+#define		rTxAGC_D_CCK11_CCK1_Jaguar2	0x1a20
+#define		rTxAGC_D_Ofdm18_Ofdm6_Jaguar2	0x1a24
+#define		rTxAGC_D_Ofdm54_Ofdm24_Jaguar2	0x1a28
+#define		rTxAGC_D_MCS3_MCS0_Jaguar2	0x1a2c
+#define		rTxAGC_D_MCS7_MCS4_Jaguar2	0x1a30
+#define		rTxAGC_D_MCS11_MCS8_Jaguar2	0x1a34
+#define		rTxAGC_D_MCS15_MCS12_Jaguar2	0x1a38
+#define		rTxAGC_D_MCS19_MCS16_Jaguar2	0x1ad8
+#define		rTxAGC_D_MCS23_MCS20_Jaguar2	0x1adc
+#define		rTxAGC_D_Nss1Index3_Nss1Index0_Jaguar2	0x1a3c
+#define		rTxAGC_D_Nss1Index7_Nss1Index4_Jaguar2	0x1a40
+#define		rTxAGC_D_Nss2Index1_Nss1Index8_Jaguar2	0x1a44
+#define		rTxAGC_D_Nss2Index5_Nss2Index2_Jaguar2	0x1a48
+#define		rTxAGC_D_Nss2Index9_Nss2Index6_Jaguar2	0x1a4c
+#define		rTxAGC_D_Nss3Index3_Nss3Index0_Jaguar2	0x1ae0
+#define		rTxAGC_D_Nss3Index7_Nss3Index4_Jaguar2	0x1ae4
+#define		rTxAGC_D_Nss3Index9_Nss3Index8_Jaguar2	0x1ae8
+/* IQK YN: temporaily mask this part
+ * #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 */
+
+
+/* AFE-related */
+#define rA_AFEPwr1_Jaguar					0xc60 /* dynamic AFE power control */
+#define rA_AFEPwr2_Jaguar					0xc64 /* dynamic AFE power control */
+#define rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xc68
+#define rA_Tx_CCKBBON_OFDMRFON_Jaguar	0xc6c
+#define rA_Tx_OFDMBBON_Tx2Rx_Jaguar		0xc70
+#define rA_Tx2Tx_RXCCK_Jaguar				0xc74
+#define rA_Rx_OFDM_WaitRIFS_Jaguar			0xc78
+#define rA_Rx2Rx_BT_Jaguar					0xc7c
+#define rA_sleep_nav_Jaguar					0xc80
+#define rA_pmpd_Jaguar						0xc84
+#define rB_AFEPwr1_Jaguar					0xe60 /* dynamic AFE power control */
+#define rB_AFEPwr2_Jaguar					0xe64 /* dynamic AFE power control */
+#define rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xe68
+#define rB_Tx_CCKBBON_OFDMRFON_Jaguar	0xe6c
+#define rB_Tx_OFDMBBON_Tx2Rx_Jaguar		0xe70
+#define rB_Tx2Tx_RXCCK_Jaguar				0xe74
+#define rB_Rx_OFDM_WaitRIFS_Jaguar			0xe78
+#define rB_Rx2Rx_BT_Jaguar					0xe7c
+#define rB_sleep_nav_Jaguar					0xe80
+#define rB_pmpd_Jaguar						0xe84
+
+
+/* YN: mask these registers temporaily
+ * #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 */
+
+
+/* RSSI Dump */
+#define rA_RSSIDump_Jaguar			0xBF0
+#define rB_RSSIDump_Jaguar			0xBF1
+#define rS1_RXevmDump_Jaguar		0xBF4
+#define rS2_RXevmDump_Jaguar		0xBF5
+#define rA_RXsnrDump_Jaguar		0xBF6
+#define rB_RXsnrDump_Jaguar		0xBF7
+#define rA_CfoShortDump_Jaguar		0xBF8
+#define rB_CfoShortDump_Jaguar		0xBFA
+#define rA_CfoLongDump_Jaguar		0xBEC
+#define rB_CfoLongDump_Jaguar		0xBEE
+
+
+/* RF Register
+ *   */
+#define RF_AC_Jaguar				0x00	/*  */
+#define RF_RF_Top_Jaguar			0x07	/*  */
+#define RF_TXLOK_Jaguar				0x08	/*  */
+#define RF_TXAPK_Jaguar				0x0B
+#define RF_CHNLBW_Jaguar 			0x18	/* RF channel and BW switch */
+#define RF_RCK1_Jaguar				0x1c	/*  */
+#define RF_RCK2_Jaguar				0x1d
+#define RF_RCK3_Jaguar			0x1e
+#define RF_ModeTableAddr			0x30
+#define RF_ModeTableData0			0x31
+#define RF_ModeTableData1			0x32
+#define RF_TxLCTank_Jaguar	0x54
+#define RF_APK_Jaguar				0x63
+#define RF_LCK						0xB4
+#define RF_WeLut_Jaguar				0xEF
+
+#define bRF_CHNLBW_MOD_AG_Jaguar	0x70300
+#define bRF_CHNLBW_BW				0xc00
+
+
+/*
+ * RL6052 Register definition
+ *   */
+#define RF_AC						0x00	/*  */
+#define RF_IPA_A					0x0C	/*  */
+#define RF_TXBIAS_A					0x0D
+#define RF_BS_PA_APSET_G9_G11		0x0E
+#define RF_MODE1					0x10	/*  */
+#define RF_MODE2					0x11	/*  */
+#define RF_CHNLBW					0x18	/* RF channel and BW switch */
+#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 */
+#define RF_0x52						0x52
+#define RF_WE_LUT					0xEF
+
+/*
+ * 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
+
+
+/*
+ * 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
+
+/*
+ * 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_XA_HSSIParameter1	0x820	/* RF 3 wire register */
+#define rFPGA0_XA_HSSIParameter2	0x824
+#define rFPGA0_XB_HSSIParameter1	0x828
+#define rFPGA0_XB_HSSIParameter2	0x82c
+
+#define	rFPGA0_XA_LSSIParameter		0x840
+#define	rFPGA0_XB_LSSIParameter		0x844
+
+#define rFPGA0_XAB_SwitchControl	0x858	/* RF Channel switch */
+#define rFPGA0_XCD_SwitchControl	0x85c
+
+#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
+#define rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#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_XCD_RFPara	0x8b4
+#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	REG_BB_TX_PATH_SEL_1_8814A		0x93c
+#define	REG_BB_TX_PATH_SEL_2_8814A		0x940
+#define rFPGA1_TxBlock				0x904	/* Useless now */
+#define rFPGA1_DebugSelect			0x908	/* Useless now */
+#define rFPGA1_TxInfo				0x90c	/* Useless now */ /* Status report?? */
+/*Page 19 for TxBF*/
+#define	REG_BB_TXBF_ANT_SET_BF1_8814A	0x19ac
+#define	REG_BB_TXBF_ANT_SET_BF0_8814A	0x19b4
+/*
+ * PageA(0xA00)
+ *   */
+#define rCCK0_System				0xa00
+#define rCCK0_AFESetting				0xa04	/* Disable init gain now */ /* Select RX path by RSSI */
+#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 */
+
+/*
+ * 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
+
+/*
+ * 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 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 rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86c
+
+#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
+
+
+/* 2. Page8(0x800) */
+#define bRFMOD						0x1	/* Reg 0x800 rFPGA0_RFMOD */
+#define bJapanMode					0x2
+#define bCCKTxSC					0x30
+#define bCCKEn						0x1000000
+#define bOFDMEn						0x2000000
+#define bXBTxAGC                  			0xf00	/* Reg 80c rFPGA0_TxGainStage */
+#define bXCTxAGC			0xf000
+#define bXDTxAGC			0xf0000
+
+/* 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
+
+#define		RF_T_METER_88E				0x42
+
+/* 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
+
+
+/*
+ * Other Definition
+ *   */
+
+#define bEnable                   0x1	/* Useless */
+#define bDisable                  0x0
+
+/* byte endable for srwrite */
+#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 bMaskH3Bytes				0xffffff00
+#define bMask12Bits				0xfff
+#define bMaskH4Bits				0xf0000000
+#define bMaskOFDM_D			0xffc00000
+#define bMaskCCK				0x3f3f3f3f
+#define bMask7bits				0x7f
+#define bMaskByte2HighNibble			0x00f00000
+#define bMaskByte3LowNibble				0x0f000000
+#define bMaskL3Bytes			0x00ffffff
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PwrSeq.h
new file mode 100644
index 000000000000..5f4097d0f739
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8814PwrSeq.h
@@ -0,0 +1,231 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HAL8814PWRSEQ_H__
+#define __HAL8814PWRSEQ_H__
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WB-110628-DZ-RTL8195 (Jaguar) Power Architecture-R04.pdf
+	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
+*/
+#define	RTL8814A_TRANS_CARDEMU_TO_ACT_STEPS	16
+#define	RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS	20
+#define	RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS	17
+#define	RTL8814A_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS	17
+#define	RTL8814A_TRANS_PDN_TO_CARDEMU_STEPS	16
+#define	RTL8814A_TRANS_ACT_TO_LPS_STEPS	20
+#define	RTL8814A_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8814A_TRANS_END_STEPS	1
+
+
+#define RTL8814A_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x002B, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /* ??0x28[24]=1, enable pll phase select*/ \
+	{0x0015, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, (BIT3 | BIT2 | BIT1), (BIT3 | BIT2 | BIT1)},/* 0x14[11:9]=3'b111, OCP current threshold = 1.5A */ \
+	{0x002D, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0E, 0x08},/* 0x2C[11:9]=3'b100, select lpf R3 */ \
+	{0x002D, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x70, 0x50},/* 0x2C[14:12]=3'b101, select lpf Rs*/ \
+	{0x007B, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* 0x78[30]=1'b1, SDM order select*/ \
+	/*{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, BIT3, 0},/* disable WL suspend*/	\
+	{0x00F0, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* */	\
+	{0x0081, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x30, 0x20},/* */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/
+
+#define RTL8814A_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},  /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US}, /*Delay 1us*/	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},  /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
+	{0x0002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US}, /*Delay 1us*/	\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	{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, BIT7, 0},*/  /*0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x28},   /* 0x07[7:0] = 0x28 sps pwm mode 0x2a for BT coex*/	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},   /*0x8[1] = 0 ANA clk = 500k */	\
+	/*{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 | BIT1, 0},*/   /*  0x02[1:0] = 0	reset BB */	\
+	{0x0066, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},   /*0x66[7]=0, disable ckreq for gpio7 output SUS */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},   /*0x41[4]=0, disable sic for gpio7 output SUS */	\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},   /*0x42[1]=0, disable ckout for gpio7 output SUS */	\
+	{0x004e, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},   /*0x4E[5]=1, disable LED2 for gpio7 output SUS */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},   /*0x41[0]=0, disable uart for gpio7 output SUS */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/
+
+#define RTL8814A_TRANS_CARDEMU_TO_SUS													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0061, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0F, 0x0c},\
+	{0x0061, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0F, 0x0E},\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0F, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* suspend option all off */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*0x14[13] = 1 turn on ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* 0x14[14] =1 trun on ZCD */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0091, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xA0, 0xA0}, /* 0x91[7]=1 0x91[5]=1 , disable sps, ldo sleep mode */	\
+	{0x0070, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /* 0x70[3]=1 enable mainbias polling */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 1 enable WL suspend */
+
+#define RTL8814A_TRANS_SUS_TO_CARDEMU													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 0 enable WL suspend*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO sleep mode leave */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* 0x14[14] =0 trun off ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 0},/*0x14[13] = 0 turn off ZCD */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */
+
+#define RTL8814A_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	/**{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, //0x194[0]=0 , disable 32K clock*/	\
+	/**{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x94}, //0x93 = 0x94 , 90[30] =0 enable 500k ANA clock .switch clock from 12M to 500K , 90 [26] =0 disable EEprom loader clock*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x03[2] = 0, reset 3081*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x01}, /*0x80 = 05h if reload fw, fill the default value of host_CPU handshake field*/	\
+	{0x0081, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x30}, /*0x80 = 05h if reload fw, fill the default value of host_CPU handshake field*/	\
+	/*{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xcc},*/   \
+	/*{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xEC},*/   \
+	/*{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},*/  /* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* 0x15[6] =1 trun on ZCD output */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*0x15[5] = 1 turn on ZCD */	\
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/*0x12[6] = 0 force PFM mode */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x01f[1]=0 , disable RFC_0  control  REG_RF_CTRL_8814A */	\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x020[1]=0 , disable RFC_1  control  REG_RF_CTRL_8814A */	\
+	{0x0021, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x021[1]=0 , disable RFC_2  control  REG_RF_CTRL_8814A */	\
+	{0x0076, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x076[1]=0 , disable RFC_3  control REG_OPT_CTRL_8814A +2 */	\
+	{0x0091, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xA0, 0xA0}, /* 0x91[7]=1 0x91[5]=1 , disable sps, ldo sleep mode */	\
+	{0x0070, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /* 0x70[3]=1 enable mainbias polling */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 1 enable WL suspend*/
+
+#define RTL8814A_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/                       \
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/*0x12[6] = 1 force PWM mode */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 0},/*0x15[5] = 0 turn off ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* 0x15[6] =0 trun off ZCD output */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/*0x23[4] = 0 hpon LDO leave sleep mode */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00}, /* gpio11 input mode, gpio10~8 input mode */ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x04[10] = 0, enable SW LPS PCIE only*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 0, enable WL suspend*/	\
+	/*{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2},*/ /*0x03[2] = 1, enable 3081*/	\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/		\
+	{0x0071, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/*0x70[10] = 0, CPHY_MBIAS_EN disable*/
+
+
+#define RTL8814A_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8814A_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8814A_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x7F},/*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*/	\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated, and RF closed*/	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US},/*Delay 1us*/	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated, and RF closed*/	\
+	{0x0002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US},/*Delay 1us*/	\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 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, BIT1, 0},/*check if removed later*/		\
+	{0x05F1, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Respond TxOK to scheduler*/
+
+
+#define RTL8814A_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/	\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/	\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1 | BIT0, BIT1 | BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/	\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1 | BIT0, BIT1 | BIT0}, /*.	0x1002[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 RTL8814A_TRANS_END																\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/		\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+extern WLAN_PWR_CFG rtl8814A_power_on_flow[RTL8814A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_radio_off_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_card_disable_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_card_enable_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_suspend_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_resume_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_hwpdn_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_enter_lps_flow[RTL8814A_TRANS_ACT_TO_LPS_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_leave_lps_flow[RTL8814A_TRANS_LPS_TO_ACT_STEPS + RTL8814A_TRANS_END_STEPS];
+
+#endif /* __HAL8814PWRSEQ_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8821APwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8821APwrSeq.h
new file mode 100644
index 000000000000..568b8e5fc1e9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/Hal8821APwrSeq.h
@@ -0,0 +1,200 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8821
+#define REALTEK_POWER_SEQUENCE_8821
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20130516-JackieLau-RTL8821A_Power_Architecture-R10.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
+*/
+#define	RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS	25
+#define	RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8821A_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define RTL8821A_TRANS_CARDDIS_TO_CARDEMU_STEPS	15
+#define	RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8821A_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8821A_TRANS_ACT_TO_LPS_STEPS	15
+#define	RTL8821A_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8821A_TRANS_END_STEPS	1
+
+
+#define RTL8821A_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, (BIT4 | BIT3 | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[12:11]=0*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x004F, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*0x4C[24] = 0x4F[0] = 1, switch DPDT_SEL_P output from WL BB */\
+	{0x0067, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, (BIT5 | BIT4), (BIT5 | BIT4)},/*0x66[13] = 0x67[5] = 1, switch for PAPE_G/PAPE_A from WL BB ; 0x66[12] = 0x67[4] = 1, switch LNAON from WL BB */\
+	{0x0025, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/*anapar_mac<118> , 0x25[6]=0 by wlan single function*/\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
+	{0x007A, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x3A},/*0x7A = 0x3A start BT*/\
+	{0x002E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF , 0x82 },/* 0x2C[23:12]=0x820 ; XTAL trim */ \
+	{0x0010, PWR_CUT_A_MSK , PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6 , BIT6 },/* 0x10[6]=1 ; MP新增對於0x2C的控制權，須把0x10[6]設為1才能讓WLAN控制 */ \
+
+
+#define RTL8821A_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x004F, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*0x4C[24] = 0x4F[0] = 0, switch DPDT_SEL_P output from register 0x65[2] */\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/   \
+
+
+#define RTL8821A_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8821A_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8821A_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8821A_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8821A_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8821A_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8821A_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8821A_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8821A_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8821A_power_on_flow[RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_radio_off_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_card_disable_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_card_enable_flow[RTL8821A_TRANS_CARDDIS_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_suspend_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_resume_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_hwpdn_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_enter_lps_flow[RTL8821A_TRANS_ACT_TO_LPS_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_leave_lps_flow[RTL8821A_TRANS_LPS_TO_ACT_STEPS + RTL8821A_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/HalPwrSeqCmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/HalPwrSeqCmd.h
new file mode 100644
index 000000000000..f67ed22d1fc9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/HalPwrSeqCmd.h
@@ -0,0 +1,130 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+/*---------------------------------------------*/
+/* 3 The value of cmd: 4 bits
+ *---------------------------------------------*/
+#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
+
+
+typedef enum _PWRSEQ_CMD_DELAY_UNIT_ {
+	PWRSEQ_DELAY_US,
+	PWRSEQ_DELAY_MS,
+} PWRSEQ_DELAY_UNIT;
+
+typedef struct _WL_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;
+} WLAN_PWR_CFG, *PWLAN_PWR_CFG;
+
+
+#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 HalPwrSeqCmdParsing(
+	PADAPTER		padapter,
+	u8				CutVersion,
+	u8				FabVersion,
+	u8				InterfaceType,
+	WLAN_PWR_CFG	PwrCfgCmd[]);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/HalVerDef.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/HalVerDef.h
new file mode 100644
index 000000000000..1909da7a0094
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/HalVerDef.h
@@ -0,0 +1,194 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+#define TRUE	_TRUE
+#define FALSE	_FALSE
+
+/* HAL_IC_TYPE_E */
+typedef enum tag_HAL_IC_Type_Definition {
+	CHIP_8192S	=	0,
+	CHIP_8188C	=	1,
+	CHIP_8192C	=	2,
+	CHIP_8192D	=	3,
+	CHIP_8723A	=	4,
+	CHIP_8188E	=	5,
+	CHIP_8812	=	6,
+	CHIP_8821	=	7,
+	CHIP_8723B	=	8,
+	CHIP_8192E	=	9,
+	CHIP_8814A	=	10,
+	CHIP_8703B	=	11,
+	CHIP_8188F	=	12,
+	CHIP_8822B	=	13,
+	CHIP_8723D	=	14,
+	CHIP_8821C	=	15
+} HAL_IC_TYPE_E;
+
+/* HAL_CHIP_TYPE_E */
+typedef enum tag_HAL_CHIP_Type_Definition {
+	TEST_CHIP		=	0,
+	NORMAL_CHIP	=	1,
+	FPGA			=	2,
+} HAL_CHIP_TYPE_E;
+
+/* HAL_CUT_VERSION_E */
+typedef enum tag_HAL_Cut_Version_Definition {
+	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,
+	H_CUT_VERSION		=	7,
+	I_CUT_VERSION		=	8,
+	J_CUT_VERSION		=	9,
+	K_CUT_VERSION		=	10,
+} HAL_CUT_VERSION_E;
+
+/* HAL_Manufacturer */
+typedef enum tag_HAL_Manufacturer_Version_Definition {
+	CHIP_VENDOR_TSMC	=	0,
+	CHIP_VENDOR_UMC	=	1,
+	CHIP_VENDOR_SMIC	=	2,
+} HAL_VENDOR_E;
+
+typedef enum tag_HAL_RF_Type_Definition {
+	RF_TYPE_1T1R	=	0,
+	RF_TYPE_1T2R	=	1,
+	RF_TYPE_2T2R	=	2,
+	RF_TYPE_2T3R	=	3,
+	RF_TYPE_2T4R	=	4,
+	RF_TYPE_3T3R	=	5,
+	RF_TYPE_3T4R	=	6,
+	RF_TYPE_4T4R	=	7,
+} HAL_RF_TYPE_E;
+
+typedef	struct tag_HAL_VERSION {
+	HAL_IC_TYPE_E		ICType;
+	HAL_CHIP_TYPE_E		ChipType;
+	HAL_CUT_VERSION_E	CUTVersion;
+	HAL_VENDOR_E		VendorType;
+	HAL_RF_TYPE_E		RFType;
+	u8					ROMVer;
+} HAL_VERSION, *PHAL_VERSION;
+
+/* VERSION_8192C			VersionID;
+ * HAL_VERSION			VersionID; */
+
+/* Get element */
+#define GET_CVID_IC_TYPE(version)			((HAL_IC_TYPE_E)(((HAL_VERSION)version).ICType))
+#define GET_CVID_CHIP_TYPE(version)			((HAL_CHIP_TYPE_E)(((HAL_VERSION)version).ChipType))
+#define GET_CVID_RF_TYPE(version)			((HAL_RF_TYPE_E)(((HAL_VERSION)version).RFType))
+#define GET_CVID_MANUFACTUER(version)		((HAL_VENDOR_E)(((HAL_VERSION)version).VendorType))
+#define GET_CVID_CUT_VERSION(version)		((HAL_CUT_VERSION_E)(((HAL_VERSION)version).CUTVersion))
+#define GET_CVID_ROM_VERSION(version)		((((HAL_VERSION)version).ROMVer) & ROM_VERSION_MASK)
+
+/* ----------------------------------------------------------------------------
+ * Common Macro. --
+ * ----------------------------------------------------------------------------
+ * HAL_VERSION VersionID */
+
+/* HAL_IC_TYPE_E */
+#if 0
+	#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_92D(version)					((GET_CVID_IC_TYPE(version) == CHIP_8192D) ? TRUE : FALSE)
+#endif
+
+#define IS_8188E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188E) ? TRUE : FALSE)
+#define IS_8188F(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188F) ? TRUE : FALSE)
+#define IS_8192E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8192E) ? TRUE : FALSE)
+#define IS_8812_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8812) ? TRUE : FALSE)
+#define IS_8821_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8821) ? TRUE : FALSE)
+#define IS_8814A_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8814A) ? TRUE : FALSE)
+#define IS_8723B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8723B) ? TRUE : FALSE)
+#define IS_8703B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8703B) ? TRUE : FALSE)
+#define IS_8822B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8822B) ? TRUE : FALSE)
+#define IS_8821C_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8821C) ? TRUE : FALSE)
+#define IS_8723D_SERIES(version)\
+	((GET_CVID_IC_TYPE(version) == CHIP_8723D) ? TRUE : FALSE)
+/* HAL_CHIP_TYPE_E */
+#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)
+
+/* HAL_CUT_VERSION_E */
+#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_F_CUT(version)				((GET_CVID_CUT_VERSION(version) == F_CUT_VERSION) ? TRUE : FALSE)
+#define IS_I_CUT(version)				((GET_CVID_CUT_VERSION(version) == I_CUT_VERSION) ? TRUE : FALSE)
+#define IS_J_CUT(version)				((GET_CVID_CUT_VERSION(version) == J_CUT_VERSION) ? TRUE : FALSE)
+#define IS_K_CUT(version)				((GET_CVID_CUT_VERSION(version) == K_CUT_VERSION) ? TRUE : FALSE)
+
+/* HAL_VENDOR_E */
+#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)
+#define IS_CHIP_VENDOR_SMIC(version)	((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_SMIC) ? TRUE : FALSE)
+
+/* HAL_RF_TYPE_E */
+#define IS_1T1R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_1T1R) ? TRUE : FALSE)
+#define IS_1T2R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_1T2R) ? TRUE : FALSE)
+#define IS_2T2R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_2T2R) ? TRUE : FALSE)
+#define IS_3T3R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_3T3R) ? TRUE : FALSE)
+#define IS_3T4R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_3T4R) ? TRUE : FALSE)
+#define IS_4T4R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_4T4R) ? TRUE : FALSE)
+
+
+
+/* ----------------------------------------------------------------------------
+ * Chip version Macro. --
+ * ---------------------------------------------------------------------------- */
+#if 0
+	#define IS_81XXC_TEST_CHIP(version)		((IS_81XXC(version) && (!IS_NORMAL_CHIP(version))) ? TRUE : FALSE)
+
+	#define IS_92C_SERIAL(version)					((IS_81XXC(version) && IS_2T2R(version)) ? TRUE : FALSE)
+	#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_NORMAL_CHIP92D(version)		((IS_92D(version)) ? ((GET_CVID_CHIP_TYPE(version) == NORMAL_CHIP) ? TRUE : FALSE) : FALSE)
+
+	#define IS_92D_SINGLEPHY(version)		((IS_92D(version)) ? (IS_2T2R(version) ? TRUE : FALSE) : FALSE)
+	#define IS_92D_C_CUT(version)			((IS_92D(version)) ? (IS_C_CUT(version) ? TRUE : FALSE) : FALSE)
+	#define IS_92D_D_CUT(version)			((IS_92D(version)) ? (IS_D_CUT(version) ? TRUE : FALSE) : FALSE)
+	#define IS_92D_E_CUT(version)			((IS_92D(version)) ? (IS_E_CUT(version) ? TRUE : 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
+#define IS_VENDOR_8188E_I_CUT_SERIES(_Adapter)		((IS_8188E(GET_HAL_DATA(_Adapter)->version_id)) ? ((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->version_id) >= I_CUT_VERSION) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8812A_TEST_CHIP(_Adapter)		((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8812A_MP_CHIP(_Adapter)		((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8812A_C_CUT(_Adapter)			((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->version_id) == C_CUT_VERSION) ? TRUE : FALSE) : FALSE)
+
+#define IS_VENDOR_8821A_TEST_CHIP(_Adapter)	((IS_8821_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8821A_MP_CHIP(_Adapter)		((IS_8821_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
+
+#define IS_VENDOR_8192E_B_CUT(_Adapter)		((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->version_id) == B_CUT_VERSION) ? TRUE : FALSE)
+
+#define IS_VENDOR_8723B_TEST_CHIP(_Adapter)	((IS_8723B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8723B_MP_CHIP(_Adapter)		((IS_8723B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
+
+#define IS_VENDOR_8703B_TEST_CHIP(_Adapter)	((IS_8703B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8703B_MP_CHIP(_Adapter)		((IS_8703B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8814A_TEST_CHIP(_Adapter)	((IS_8814A_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8814A_MP_CHIP(_Adapter)		((IS_8814A_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/autoconf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/autoconf.h
new file mode 100644
index 000000000000..6eca5acd8162
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/autoconf.h
@@ -0,0 +1,344 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 CONFIG_SINGLE_IMG
+/* #define CONFIG_DISABLE_ODM */
+
+/*
+ * Public  General Config
+ */
+#define AUTOCONF_INCLUDED
+#define RTL871X_MODULE_NAME "88x2BU"
+#define DRV_NAME "rtl88x2bu"
+
+/* Set CONFIG_RTL8822B from Makefile */
+#ifndef CONFIG_RTL8822B
+#define CONFIG_RTL8822B
+#endif
+#define CONFIG_USB_HCI	1
+#define PLATFORM_LINUX	1
+
+/*
+ * Wi-Fi Functions Config
+ */
+
+#define CONFIG_IEEE80211_BAND_5GHZ 1
+#define CONFIG_80211N_HT	1
+#ifdef CONFIG_80211N_HT
+	#define CONFIG_80211AC_VHT 1
+
+	#define CONFIG_BEAMFORMING
+#endif
+
+/* set CONFIG_IOCTL_CFG80211 from Makefile */
+#ifdef CONFIG_IOCTL_CFG80211
+	/*
+	 * Indecate new sta asoc through cfg80211_new_sta
+	 * If kernel version >= 3.2 or
+	 * version < 3.2 but already apply cfg80211 patch,
+	 * RTW_USE_CFG80211_STA_EVENT must be defiend!
+	 */
+	/* Set RTW_USE_CFG80211_STA_EVENT from Makefile */
+	/* #define RTW_USE_CFG80211_STA_EVENT */ /* Indecate new sta asoc through cfg80211_new_sta */
+	#define CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER
+	/* #define CONFIG_DEBUG_CFG80211 */
+	/* #define CONFIG_DRV_ISSUE_PROV_REQ */ /* IOT FOR S2 */
+	#define CONFIG_SET_SCAN_DENY_TIMER
+#endif
+
+/*
+ * Internal  General Config
+ */
+/* #define CONFIG_H2CLBK */
+
+#define RTW_HALMAC		/* Use HALMAC architecture, necessary for 8822B */
+#define CONFIG_EMBEDDED_FWIMG	1
+#if (CONFIG_EMBEDDED_FWIMG==1)
+	#define	LOAD_FW_HEADER_FROM_DRIVER
+#endif
+/* #define CONFIG_FILE_FWIMG */
+
+#define CONFIG_XMIT_ACK
+#ifdef CONFIG_XMIT_ACK
+	#define CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+#endif
+
+#define CONFIG_RECV_REORDERING_CTRL	1
+
+/* #define CONFIG_SUPPORT_USB_INT */
+#ifdef CONFIG_SUPPORT_USB_INT
+	/* #define CONFIG_USB_INTERRUPT_IN_PIPE  1 */
+#endif /* CONFIG_SUPPORT_USB_INT */
+
+#ifdef CONFIG_POWER_SAVING
+	/* #define CONFIG_IPS	1 */
+	#ifdef CONFIG_IPS
+	/* #define CONFIG_IPS_LEVEL_2 1*/ /*enable this to set default IPS mode to IPS_LEVEL_2*/
+	#define CONFIG_IPS_CHECK_IN_WD /* Do IPS Check in WatchDog.	*/
+	/* #define CONFIG_FWLPS_IN_IPS */
+	#endif
+	/* #define SUPPORT_HW_RFOFF_DETECTED	1 */
+
+	#define CONFIG_LPS	1
+	#if defined(CONFIG_LPS)
+		/* #define CONFIG_LPS_LCLK	1 */
+	#endif
+
+	#ifdef CONFIG_LPS_LCLK
+		#ifdef CONFIG_POWER_SAVING
+			#define CONFIG_XMIT_THREAD_MODE
+		#endif /* CONFIG_POWER_SAVING */
+		#ifndef CONFIG_SUPPORT_USB_INT
+			#define LPS_RPWM_WAIT_MS 300
+			#define CONFIG_DETECT_CPWM_BY_POLLING
+		#endif /* !CONFIG_SUPPORT_USB_INT */
+		/* #define DBG_CHECK_FW_PS_STATE */
+	#endif /* CONFIG_LPS_LCLK */
+
+	#ifdef CONFIG_LPS
+		#define CONFIG_WMMPS_STA 1
+	#endif /* CONFIG_LPS */
+#endif /*CONFIG_POWER_SAVING*/
+	/* before link */
+	/* #define CONFIG_ANTENNA_DIVERSITY */
+
+	/* after link */
+	#ifdef CONFIG_ANTENNA_DIVERSITY
+	#define CONFIG_HW_ANTENNA_DIVERSITY
+	#endif
+
+
+/*#else*/	/* CONFIG_MP_INCLUDED */
+
+/*#endif*/	/* CONFIG_MP_INCLUDED */
+
+#define CONFIG_AP_MODE	1
+#ifdef CONFIG_AP_MODE
+	/* #define CONFIG_INTERRUPT_BASED_TXBCN */ /* Tx Beacon when driver BCN_OK ,BCN_ERR interrupt occurs */
+	#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_INTERRUPT_BASED_TXBCN)
+		#undef CONFIG_INTERRUPT_BASED_TXBCN
+	#endif
+	#ifdef CONFIG_INTERRUPT_BASED_TXBCN
+		/* #define CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT */
+		#define CONFIG_INTERRUPT_BASED_TXBCN_BCN_OK_ERR
+	#endif
+
+	#define CONFIG_NATIVEAP_MLME
+	#ifndef CONFIG_NATIVEAP_MLME
+		#define CONFIG_HOSTAPD_MLME	1
+	#endif
+	#define CONFIG_FIND_BEST_CHANNEL	1
+#endif
+
+#define CONFIG_P2P	1
+#ifdef CONFIG_P2P
+	/* The CONFIG_WFD is for supporting the Wi-Fi display */
+	#define CONFIG_WFD
+
+	#define CONFIG_P2P_REMOVE_GROUP_INFO
+
+	/* #define CONFIG_DBG_P2P */
+
+	#define CONFIG_P2P_PS
+	/* #define CONFIG_P2P_IPS */
+	#define CONFIG_P2P_OP_CHK_SOCIAL_CH
+	#define CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT  /* replace CONFIG_P2P_CHK_INVITE_CH_LIST flag */
+	/*#define CONFIG_P2P_INVITE_IOT*/
+#endif
+
+/*	Added by Kurt 20110511 */
+#ifdef CONFIG_TDLS
+	#define CONFIG_TDLS_DRIVER_SETUP
+/*
+	#ifndef CONFIG_WFD
+		#define CONFIG_WFD
+	#endif
+*/
+	/* #define CONFIG_TDLS_AUTOSETUP */
+	#define CONFIG_TDLS_AUTOCHECKALIVE
+	#define CONFIG_TDLS_CH_SW		/* Enable "CONFIG_TDLS_CH_SW" by default, however limit it to only work in wifi logo test mode but not in normal mode currently */
+#endif
+
+
+#define CONFIG_SKB_COPY	1 /* amsdu */
+
+#define CONFIG_RTW_LED
+#ifdef CONFIG_RTW_LED
+	#define CONFIG_RTW_SW_LED
+	#ifdef CONFIG_RTW_SW_LED
+		/* #define CONFIG_RTW_LED_HANDLED_BY_CMD_THREAD */
+	#endif
+#endif /* CONFIG_RTW_LED */
+
+#define USB_INTERFERENCE_ISSUE /* this should be checked in all usb interface */
+#define CONFIG_GLOBAL_UI_PID
+
+/*#define CONFIG_RTW_80211K*/
+
+#define CONFIG_LAYER2_ROAMING
+#define CONFIG_LAYER2_ROAMING_RESUME
+/*#define CONFIG_ADAPTOR_INFO_CACHING_FILE */ /* now just applied on 8192cu only, should make it general... */
+/*#define CONFIG_RESUME_IN_WORKQUEUE */
+/*#define CONFIG_SET_SCAN_DENY_TIMER */
+#define CONFIG_LONG_DELAY_ISSUE
+#define CONFIG_NEW_SIGNAL_STAT_PROCESS
+/* #define CONFIG_SIGNAL_DISPLAY_DBM */ /*display RX signal with dbm */
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+/* #define CONFIG_BACKGROUND_NOISE_MONITOR */
+#endif
+#define RTW_NOTCH_FILTER 0 /* 0:Disable, 1:Enable, */
+
+#define CONFIG_TX_MCAST2UNI		/*Support IP multicast->unicast*/
+/* #define CONFIG_CHECK_AC_LIFETIME 1 */	/* Check packet lifetime of 4 ACs. */
+
+
+/*
+ * Interface  Related Config
+ */
+
+#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+	#define CONFIG_USB_TX_AGGREGATION	1
+	#define CONFIG_USB_RX_AGGREGATION	1
+#endif
+
+/* #define CONFIG_REDUCE_USB_TX_INT	1 */ /* Trade-off: Improve performance, but may cause TX URBs blocked by USB Host/Bus driver on few platforms. */
+/* #define CONFIG_EASY_REPLACEMENT	1 */
+
+/*
+ * CONFIG_USE_USB_BUFFER_ALLOC_XX uses Linux USB Buffer alloc API and is for Linux platform only now!
+ */
+/* #define CONFIG_USE_USB_BUFFER_ALLOC_TX 1 */	/* Trade-off: For TX path, improve stability on some platforms, but may cause performance degrade on other platforms. */
+/* #define CONFIG_USE_USB_BUFFER_ALLOC_RX 1	*/ /* For RX path */
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+
+#else
+	#define CONFIG_PREALLOC_RECV_SKB
+	#ifdef CONFIG_PREALLOC_RECV_SKB
+		/* #define CONFIG_FIX_NR_BULKIN_BUFFER */ /* only use PREALLOC_RECV_SKB buffer, don't alloc skb at runtime */
+	#endif
+#endif
+
+/*
+ * USB VENDOR REQ BUFFER ALLOCATION METHOD
+ * if not set we'll use function local variable (stack memory)
+ */
+/* #define CONFIG_USB_VENDOR_REQ_BUFFER_DYNAMIC_ALLOCATE */
+#define CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC
+
+#define CONFIG_USB_VENDOR_REQ_MUTEX
+#define CONFIG_VENDOR_REQ_RETRY
+
+/* #define CONFIG_USB_SUPPORT_ASYNC_VDN_REQ 1 */
+
+/*
+ * HAL  Related Config
+ */
+#define RTL8812A_RX_PACKET_INCLUDE_CRC	0
+
+#define CONFIG_RX_PACKET_APPEND_FCS
+
+/* #define CONFIG_ONLY_ONE_OUT_EP_TO_LOW	0 */
+
+#define CONFIG_OUT_EP_WIFI_MODE	0
+
+#define ENABLE_USB_DROP_INCORRECT_OUT
+
+#define CONFIG_ADHOC_WORKAROUND_SETTING	1
+
+#define ENABLE_NEW_RFE_TYPE	0
+
+#define DISABLE_BB_RF	0
+
+#ifdef CONFIG_MP_INCLUDED
+	#define MP_DRIVER 1
+	#define CONFIG_MP_IWPRIV_SUPPORT	1
+	/*
+	 #undef CONFIG_USB_TX_AGGREGATION
+	 #undef CONFIG_USB_RX_AGGREGATION
+	*/
+#else
+	#define MP_DRIVER 0
+#endif
+
+/*
+ * Platform  Related Config
+ */
+#if defined(CONFIG_PLATFORM_ACTIONS_ATM702X)
+	#ifdef CONFIG_USB_TX_AGGREGATION
+		#undef CONFIG_USB_TX_AGGREGATION
+	#endif
+	#ifndef CONFIG_USE_USB_BUFFER_ALLOC_TX
+		#define CONFIG_USE_USB_BUFFER_ALLOC_TX
+	#endif
+	#ifndef CONFIG_USE_USB_BUFFER_ALLOC_RX
+		#define CONFIG_USE_USB_BUFFER_ALLOC_RX
+	#endif
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+	/* for ODM and outsrc BT-Coex */
+	#ifndef CONFIG_LPS
+		#define CONFIG_LPS	/* download reserved page to FW */
+	#endif
+#endif /* !CONFIG_BT_COEXIST */
+
+
+
+#ifdef CONFIG_USB_TX_AGGREGATION
+/* #define CONFIG_TX_EARLY_MODE */
+#endif
+
+#define	RTL8188E_EARLY_MODE_PKT_NUM_10	0
+
+#define CONFIG_ATTEMPT_TO_FIX_AP_BEACON_ERROR
+
+/*
+ * Debug Related Config
+ */
+#define DBG	1
+
+#define CONFIG_PROC_DEBUG
+
+#define DBG_CONFIG_ERROR_DETECT
+
+/*
+#define DBG_CONFIG_ERROR_DETECT_INT
+#define DBG_CONFIG_ERROR_RESET
+
+#define DBG_IO
+#define DBG_DELAY_OS
+#define DBG_MEM_ALLOC
+#define DBG_IOCTL
+
+#define DBG_TX
+#define DBG_XMIT_BUF
+#define DBG_XMIT_BUF_EXT
+#define DBG_TX_DROP_FRAME
+
+#define DBG_RX_DROP_FRAME
+#define DBG_RX_SEQ
+#define DBG_RX_SIGNAL_DISPLAY_PROCESSING
+#define DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED "jeff-ap"
+
+
+
+#define DBG_SHOW_MCUFWDL_BEFORE_51_ENABLE
+#define DBG_ROAMING_TEST
+
+#define DBG_HAL_INIT_PROFILING
+
+#define DBG_MEMORY_LEAK	1
+*/
+
+/*#define DBG_FW_DEBUG_MSG_PKT*/  /* FW use this feature to tx debug broadcast pkt. This pkt include FW debug message*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/basic_types.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/basic_types.h
new file mode 100644
index 000000000000..c0737f5bf235
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/basic_types.h
@@ -0,0 +1,414 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __BASIC_TYPES_H__
+#define __BASIC_TYPES_H__
+
+
+#define SUCCESS	0
+#define FAIL	(-1)
+
+#ifndef TRUE
+	#define _TRUE	1
+#else
+	#define _TRUE	TRUE
+#endif
+
+#ifndef FALSE
+	#define _FALSE	0
+#else
+	#define _FALSE	FALSE
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+	typedef signed char s8;
+	typedef unsigned char u8;
+
+	typedef signed short s16;
+	typedef unsigned short u16;
+
+	typedef signed long s32;
+	typedef unsigned long u32;
+
+	typedef unsigned int	uint;
+	typedef	signed int		sint;
+
+
+	typedef signed long long s64;
+	typedef unsigned long long u64;
+
+	#ifdef NDIS50_MINIPORT
+
+		#define NDIS_MAJOR_VERSION       5
+		#define NDIS_MINOR_VERSION       0
+
+	#endif
+
+	#ifdef NDIS51_MINIPORT
+
+		#define NDIS_MAJOR_VERSION       5
+		#define NDIS_MINOR_VERSION       1
+
+	#endif
+
+	typedef NDIS_PROC proc_t;
+
+	typedef LONG atomic_t;
+
+#endif
+
+
+#ifdef PLATFORM_LINUX
+	#include <linux/version.h>
+	#include <linux/types.h>
+	#include <linux/module.h>
+	#include <linux/kernel.h>
+	#include <linux/init.h>
+	#include <linux/utsname.h>
+	#define IN
+	#define OUT
+	#define VOID void
+	#define NDIS_OID uint
+	#define NDIS_STATUS uint
+
+	typedef	signed int sint;
+
+	#ifndef	PVOID
+		typedef void *PVOID;
+		/* #define PVOID	(void *) */
+	#endif
+
+	#define UCHAR u8
+	#define USHORT u16
+	#define UINT u32
+	#define ULONG u32
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 19))
+typedef _Bool bool;
+
+enum {
+	false	= 0,
+	true	= 1
+};
+#endif
+
+	typedef void (*proc_t)(void *);
+
+	typedef	__kernel_size_t	SIZE_T;
+	typedef	__kernel_ssize_t	SSIZE_T;
+	#define FIELD_OFFSET(s, field)	((SSIZE_T)&((s *)(0))->field)
+
+#define u1Byte		u8
+#define pu1Byte		u8*
+
+#define u2Byte		u16
+#define pu2Byte		u16*
+
+#define u4Byte		u32
+#define pu4Byte		u32*
+
+#define u8Byte		u64
+#define pu8Byte		u64*
+
+#define s1Byte		s8
+#define ps1Byte		s8*
+
+#define s2Byte		s16
+#define ps2Byte		s16*
+
+#define s4Byte		s32
+#define ps4Byte		s32*
+
+#define s8Byte		s64
+#define ps8Byte		s64*
+
+#define UCHAR u8
+#define USHORT u16
+#define UINT u32
+#define ULONG u32
+#define PULONG u32*
+
+#endif
+
+
+#ifdef PLATFORM_FREEBSD
+
+	typedef signed char s8;
+	typedef unsigned char u8;
+
+	typedef signed short s16;
+	typedef unsigned short u16;
+
+	typedef signed int s32;
+	typedef unsigned int u32;
+
+	typedef unsigned int	uint;
+	typedef	signed int		sint;
+	typedef long atomic_t;
+
+	typedef signed long long s64;
+	typedef unsigned long long u64;
+	#define IN
+	#define OUT
+	#define VOID void
+	#define NDIS_OID uint
+	#define NDIS_STATUS uint
+
+	#ifndef	PVOID
+		typedef void *PVOID;
+		/* #define PVOID	(void *) */
+	#endif
+	typedef u32 dma_addr_t;
+	#define UCHAR u8
+	#define USHORT u16
+	#define UINT u32
+	#define ULONG u32
+
+	typedef void (*proc_t)(void *);
+
+	typedef unsigned int __kernel_size_t;
+	typedef int __kernel_ssize_t;
+
+	typedef	__kernel_size_t	SIZE_T;
+	typedef	__kernel_ssize_t	SSIZE_T;
+	#define FIELD_OFFSET(s, field)	((SSIZE_T)&((s *)(0))->field)
+
+#endif
+
+#define MEM_ALIGNMENT_OFFSET	(sizeof (SIZE_T))
+#define MEM_ALIGNMENT_PADDING	(sizeof(SIZE_T) - 1)
+
+#define SIZE_PTR SIZE_T
+#define SSIZE_PTR SSIZE_T
+
+/*
+* Continuous bits starting from least significant bit
+* Example:
+* BIT_LEN_MASK_32(0) => 0x00000000
+* BIT_LEN_MASK_32(1) => 0x00000001
+* BIT_LEN_MASK_32(2) => 0x00000003
+* BIT_LEN_MASK_32(32) => 0xFFFFFFFF
+*/
+#define BIT_LEN_MASK_32(__BitLen) ((u32)(0xFFFFFFFF >> (32 - (__BitLen))))
+#define BIT_LEN_MASK_16(__BitLen) ((u16)(0xFFFF >> (16 - (__BitLen))))
+#define BIT_LEN_MASK_8(__BitLen) ((u8)(0xFF >> (8 - (__BitLen))))
+
+/*
+* Continuous bits starting from least significant bit
+* Example:
+* BIT_OFFSET_LEN_MASK_32(0, 2) => 0x00000003
+* BIT_OFFSET_LEN_MASK_32(16, 2) => 0x00030000
+*/
+#define BIT_OFFSET_LEN_MASK_32(__BitOffset, __BitLen) ((u32)(BIT_LEN_MASK_32(__BitLen) << (__BitOffset)))
+#define BIT_OFFSET_LEN_MASK_16(__BitOffset, __BitLen) ((u16)(BIT_LEN_MASK_16(__BitLen) << (__BitOffset)))
+#define BIT_OFFSET_LEN_MASK_8(__BitOffset, __BitLen) ((u8)(BIT_LEN_MASK_8(__BitLen) << (__BitOffset)))
+
+/*
+* Convert LE data to host byte order
+*/
+#define EF1Byte (u8)
+#define EF2Byte le16_to_cpu
+#define EF4Byte le32_to_cpu
+
+/*
+* Read LE data from memory to host byte order
+*/
+#define ReadLE4Byte(_ptr)	le32_to_cpu(*((u32 *)(_ptr)))
+#define ReadLE2Byte(_ptr)	le16_to_cpu(*((u16 *)(_ptr)))
+#define ReadLE1Byte(_ptr)	(*((u8 *)(_ptr)))
+
+/*
+* Read BE data from memory to host byte order
+*/
+#define ReadBEE4Byte(_ptr)	be32_to_cpu(*((u32 *)(_ptr)))
+#define ReadBE2Byte(_ptr)	be16_to_cpu(*((u16 *)(_ptr)))
+#define ReadBE1Byte(_ptr)	(*((u8 *)(_ptr)))
+
+/*
+* Write host byte order data to memory in LE order
+*/
+#define WriteLE4Byte(_ptr, _val)	((*((u32 *)(_ptr))) = cpu_to_le32(_val))
+#define WriteLE2Byte(_ptr, _val)	((*((u16 *)(_ptr))) = cpu_to_le16(_val))
+#define WriteLE1Byte(_ptr, _val)	((*((u8 *)(_ptr))) = ((u8)(_val)))
+
+/*
+* Write host byte order data to memory in BE order
+*/
+#define WriteBE4Byte(_ptr, _val)	((*((u32 *)(_ptr))) = cpu_to_be32(_val))
+#define WriteBE2Byte(_ptr, _val)	((*((u16 *)(_ptr))) = cpu_to_be16(_val))
+#define WriteBE1Byte(_ptr, _val)	((*((u8 *)(_ptr))) = ((u8)(_val)))
+
+/*
+* Return 4-byte value in host byte ordering from 4-byte pointer in litten-endian system.
+*/
+#define LE_P4BYTE_TO_HOST_4BYTE(__pStart) (le32_to_cpu(*((u32 *)(__pStart))))
+#define LE_P2BYTE_TO_HOST_2BYTE(__pStart) (le16_to_cpu(*((u16 *)(__pStart))))
+#define LE_P1BYTE_TO_HOST_1BYTE(__pStart) ((*((u8 *)(__pStart))))
+
+/*
+* Return 4-byte value in host byte ordering from 4-byte pointer in big-endian system.
+*/
+#define BE_P4BYTE_TO_HOST_4BYTE(__pStart) (be32_to_cpu(*((u32 *)(__pStart))))
+#define BE_P2BYTE_TO_HOST_2BYTE(__pStart) (be16_to_cpu(*((u16 *)(__pStart))))
+#define BE_P1BYTE_TO_HOST_1BYTE(__pStart) ((*((u8 *)(__pStart))))
+
+/*
+* Translate subfield (continuous bits in little-endian) of 4-byte value in LE byte to
+* 4-byte value in host byte ordering.
+*/
+#define LE_BITS_TO_4BYTE(__pStart, __BitOffset, __BitLen) \
+	((LE_P4BYTE_TO_HOST_4BYTE(__pStart) >> (__BitOffset)) & BIT_LEN_MASK_32(__BitLen))
+
+#define LE_BITS_TO_2BYTE(__pStart, __BitOffset, __BitLen) \
+	((LE_P2BYTE_TO_HOST_2BYTE(__pStart) >> (__BitOffset)) & BIT_LEN_MASK_16(__BitLen))
+
+#define LE_BITS_TO_1BYTE(__pStart, __BitOffset, __BitLen) \
+	((LE_P1BYTE_TO_HOST_1BYTE(__pStart) >> (__BitOffset)) & BIT_LEN_MASK_8(__BitLen))
+
+/*
+* Translate subfield (continuous bits in big-endian) of 4-byte value in BE byte to
+* 4-byte value in host byte ordering.
+*/
+#define BE_BITS_TO_4BYTE(__pStart, __BitOffset, __BitLen) \
+	((BE_P4BYTE_TO_HOST_4BYTE(__pStart) >> (__BitOffset)) & BIT_LEN_MASK_32(__BitLen))
+
+#define BE_BITS_TO_2BYTE(__pStart, __BitOffset, __BitLen) \
+	((BE_P2BYTE_TO_HOST_2BYTE(__pStart) >> (__BitOffset)) & BIT_LEN_MASK_16(__BitLen))
+
+#define BE_BITS_TO_1BYTE(__pStart, __BitOffset, __BitLen) \
+	((BE_P1BYTE_TO_HOST_1BYTE(__pStart) >> (__BitOffset)) & BIT_LEN_MASK_8(__BitLen))
+
+/*
+* Mask subfield (continuous bits in little-endian) of 4-byte value in LE byte oredering
+* and return the result in 4-byte value in host byte ordering.
+*/
+#define LE_BITS_CLEARED_TO_4BYTE(__pStart, __BitOffset, __BitLen) \
+	(LE_P4BYTE_TO_HOST_4BYTE(__pStart) & (~BIT_OFFSET_LEN_MASK_32(__BitOffset, __BitLen)))
+
+#define LE_BITS_CLEARED_TO_2BYTE(__pStart, __BitOffset, __BitLen) \
+	(LE_P2BYTE_TO_HOST_2BYTE(__pStart) & (~BIT_OFFSET_LEN_MASK_16(__BitOffset, __BitLen)))
+
+#define LE_BITS_CLEARED_TO_1BYTE(__pStart, __BitOffset, __BitLen) \
+	(LE_P1BYTE_TO_HOST_1BYTE(__pStart) & ((u8)(~BIT_OFFSET_LEN_MASK_8(__BitOffset, __BitLen))))
+
+/*
+* Mask subfield (continuous bits in big-endian) of 4-byte value in BE byte oredering
+* and return the result in 4-byte value in host byte ordering.
+*/
+#define BE_BITS_CLEARED_TO_4BYTE(__pStart, __BitOffset, __BitLen) \
+	(BE_P4BYTE_TO_HOST_4BYTE(__pStart) & (~BIT_OFFSET_LEN_MASK_32(__BitOffset, __BitLen)))
+
+#define BE_BITS_CLEARED_TO_2BYTE(__pStart, __BitOffset, __BitLen) \
+	(BE_P2BYTE_TO_HOST_2BYTE(__pStart) & (~BIT_OFFSET_LEN_MASK_16(__BitOffset, __BitLen)))
+
+#define BE_BITS_CLEARED_TO_1BYTE(__pStart, __BitOffset, __BitLen) \
+	(BE_P1BYTE_TO_HOST_1BYTE(__pStart) & (~BIT_OFFSET_LEN_MASK_8(__BitOffset, __BitLen)))
+
+/*
+* Set subfield of little-endian 4-byte value to specified value.
+*/
+#define SET_BITS_TO_LE_4BYTE(__pStart, __BitOffset, __BitLen, __Value) \
+	do { \
+		if (__BitOffset == 0 && __BitLen == 32) \
+			WriteLE4Byte(__pStart, __Value); \
+		else { \
+			WriteLE4Byte(__pStart, \
+				LE_BITS_CLEARED_TO_4BYTE(__pStart, __BitOffset, __BitLen) \
+				| \
+				((((u32)__Value) & BIT_LEN_MASK_32(__BitLen)) << (__BitOffset)) \
+			); \
+		} \
+	} while (0)
+
+#define SET_BITS_TO_LE_2BYTE(__pStart, __BitOffset, __BitLen, __Value) \
+	do { \
+		if (__BitOffset == 0 && __BitLen == 16) \
+			WriteLE2Byte(__pStart, __Value); \
+		else { \
+			WriteLE2Byte(__pStart, \
+				LE_BITS_CLEARED_TO_2BYTE(__pStart, __BitOffset, __BitLen) \
+				| \
+				((((u16)__Value) & BIT_LEN_MASK_16(__BitLen)) << (__BitOffset)) \
+			); \
+		} \
+	} while (0)
+
+#define SET_BITS_TO_LE_1BYTE(__pStart, __BitOffset, __BitLen, __Value) \
+	do { \
+		if (__BitOffset == 0 && __BitLen == 8) \
+			WriteLE1Byte(__pStart, __Value); \
+		else { \
+			WriteLE1Byte(__pStart, \
+				LE_BITS_CLEARED_TO_1BYTE(__pStart, __BitOffset, __BitLen) \
+				| \
+				((((u8)__Value) & BIT_LEN_MASK_8(__BitLen)) << (__BitOffset)) \
+			); \
+		} \
+	} while (0)
+
+/*
+* Set subfield of big-endian 4-byte value to specified value.
+*/
+#define SET_BITS_TO_BE_4BYTE(__pStart, __BitOffset, __BitLen, __Value) \
+	do { \
+		if (__BitOffset == 0 && __BitLen == 32) \
+			WriteBE4Byte(__pStart, __Value); \
+		else { \
+			WriteBE4Byte(__pStart, \
+				BE_BITS_CLEARED_TO_4BYTE(__pStart, __BitOffset, __BitLen) \
+				| \
+				((((u32)__Value) & BIT_LEN_MASK_32(__BitLen)) << (__BitOffset)) \
+			); \
+		} \
+	} while (0)
+
+#define SET_BITS_TO_BE_2BYTE(__pStart, __BitOffset, __BitLen, __Value) \
+	do { \
+		if (__BitOffset == 0 && __BitLen == 16) \
+			WriteBE2Byte(__pStart, __Value); \
+		else { \
+			WriteBE2Byte(__pStart, \
+				BE_BITS_CLEARED_TO_2BYTE(__pStart, __BitOffset, __BitLen) \
+				| \
+				((((u16)__Value) & BIT_LEN_MASK_16(__BitLen)) << (__BitOffset)) \
+			); \
+		} \
+	} while (0)
+
+#define SET_BITS_TO_BE_1BYTE(__pStart, __BitOffset, __BitLen, __Value) \
+	do { \
+		if (__BitOffset == 0 && __BitLen == 8) \
+			WriteBE1Byte(__pStart, __Value); \
+		else { \
+			WriteBE1Byte(__pStart, \
+				BE_BITS_CLEARED_TO_1BYTE(__pStart, __BitOffset, __BitLen) \
+				| \
+				((((u8)__Value) & BIT_LEN_MASK_8(__BitLen)) << (__BitOffset)) \
+			); \
+		} \
+	} while (0)
+
+/* Get the N-bytes aligment offset from the current length */
+#define N_BYTE_ALIGMENT(__Value, __Aligment) ((__Aligment == 1) ? (__Value) : (((__Value + __Aligment - 1) / __Aligment) * __Aligment))
+
+typedef unsigned char	BOOLEAN, *PBOOLEAN, boolean;
+
+#define TEST_FLAG(__Flag, __testFlag)		(((__Flag) & (__testFlag)) != 0)
+#define SET_FLAG(__Flag, __setFlag)			((__Flag) |= __setFlag)
+#define CLEAR_FLAG(__Flag, __clearFlag)		((__Flag) &= ~(__clearFlag))
+#define CLEAR_FLAGS(__Flag)					((__Flag) = 0)
+#define TEST_FLAGS(__Flag, __testFlags)		(((__Flag) & (__testFlags)) == (__testFlags))
+
+#endif /* __BASIC_TYPES_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/big_endian.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/big_endian.h
new file mode 100644
index 000000000000..6b1dc449e578
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/big_endian.h
@@ -0,0 +1,82 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_BYTEORDER_BIG_ENDIAN_H
+#define _LINUX_BYTEORDER_BIG_ENDIAN_H
+
+#ifndef __BIG_ENDIAN
+	#define __BIG_ENDIAN 4321
+#endif
+#ifndef __BIG_ENDIAN_BITFIELD
+	#define __BIG_ENDIAN_BITFIELD
+#endif
+
+#include <byteorder/swab.h>
+
+#define __constant_htonl(x) ((__u32)(x))
+#define __constant_ntohl(x) ((__u32)(x))
+#define __constant_htons(x) ((__u16)(x))
+#define __constant_ntohs(x) ((__u16)(x))
+#define __constant_cpu_to_le64(x) ___constant_swab64((x))
+#define __constant_le64_to_cpu(x) ___constant_swab64((x))
+#define __constant_cpu_to_le32(x) ___constant_swab32((x))
+#define __constant_le32_to_cpu(x) ___constant_swab32((x))
+#define __constant_cpu_to_le16(x) ___constant_swab16((x))
+#define __constant_le16_to_cpu(x) ___constant_swab16((x))
+#define __constant_cpu_to_be64(x) ((__u64)(x))
+#define __constant_be64_to_cpu(x) ((__u64)(x))
+#define __constant_cpu_to_be32(x) ((__u32)(x))
+#define __constant_be32_to_cpu(x) ((__u32)(x))
+#define __constant_cpu_to_be16(x) ((__u16)(x))
+#define __constant_be16_to_cpu(x) ((__u16)(x))
+#define __cpu_to_le64(x) __swab64((x))
+#define __le64_to_cpu(x) __swab64((x))
+#define __cpu_to_le32(x) __swab32((x))
+#define __le32_to_cpu(x) __swab32((x))
+#define __cpu_to_le16(x) __swab16((x))
+#define __le16_to_cpu(x) __swab16((x))
+#define __cpu_to_be64(x) ((__u64)(x))
+#define __be64_to_cpu(x) ((__u64)(x))
+#define __cpu_to_be32(x) ((__u32)(x))
+#define __be32_to_cpu(x) ((__u32)(x))
+#define __cpu_to_be16(x) ((__u16)(x))
+#define __be16_to_cpu(x) ((__u16)(x))
+#define __cpu_to_le64p(x) __swab64p((x))
+#define __le64_to_cpup(x) __swab64p((x))
+#define __cpu_to_le32p(x) __swab32p((x))
+#define __le32_to_cpup(x) __swab32p((x))
+#define __cpu_to_le16p(x) __swab16p((x))
+#define __le16_to_cpup(x) __swab16p((x))
+#define __cpu_to_be64p(x) (*(__u64 *)(x))
+#define __be64_to_cpup(x) (*(__u64 *)(x))
+#define __cpu_to_be32p(x) (*(__u32 *)(x))
+#define __be32_to_cpup(x) (*(__u32 *)(x))
+#define __cpu_to_be16p(x) (*(__u16 *)(x))
+#define __be16_to_cpup(x) (*(__u16 *)(x))
+#define __cpu_to_le64s(x) __swab64s((x))
+#define __le64_to_cpus(x) __swab64s((x))
+#define __cpu_to_le32s(x) __swab32s((x))
+#define __le32_to_cpus(x) __swab32s((x))
+#define __cpu_to_le16s(x) __swab16s((x))
+#define __le16_to_cpus(x) __swab16s((x))
+#define __cpu_to_be64s(x) do {} while (0)
+#define __be64_to_cpus(x) do {} while (0)
+#define __cpu_to_be32s(x) do {} while (0)
+#define __be32_to_cpus(x) do {} while (0)
+#define __cpu_to_be16s(x) do {} while (0)
+#define __be16_to_cpus(x) do {} while (0)
+
+#include <byteorder/generic.h>
+
+#endif /* _LINUX_BYTEORDER_BIG_ENDIAN_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/generic.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/generic.h
new file mode 100644
index 000000000000..f85114bf796c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/generic.h
@@ -0,0 +1,207 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_BYTEORDER_GENERIC_H
+#define _LINUX_BYTEORDER_GENERIC_H
+
+/*
+ * linux/byteorder_generic.h
+ * Generic Byte-reordering support
+ *
+ * Francois-Rene Rideau <fare@tunes.org> 19970707
+ *    gathered all the good ideas from all asm-foo/byteorder.h into one file,
+ *    cleaned them up.
+ *    I hope it is compliant with non-GCC compilers.
+ *    I decided to put __BYTEORDER_HAS_U64__ in byteorder.h,
+ *    because I wasn't sure it would be ok to put it in types.h
+ *    Upgraded it to 2.1.43
+ * Francois-Rene Rideau <fare@tunes.org> 19971012
+ *    Upgraded it to 2.1.57
+ *    to please Linus T., replaced huge #ifdef's between little/big endian
+ *    by nestedly #include'd files.
+ * Francois-Rene Rideau <fare@tunes.org> 19971205
+ *    Made it to 2.1.71; now a facelift:
+ *    Put files under include/linux/byteorder/
+ *    Split swab from generic support.
+ *
+ * TODO:
+ *   = Regular kernel maintainers could also replace all these manual
+ *    byteswap macros that remain, disseminated among drivers,
+ *    after some grep or the sources...
+ *   = Linus might want to rename all these macros and files to fit his taste,
+ *    to fit his personal naming scheme.
+ *   = it seems that a few drivers would also appreciate
+ *    nybble swapping support...
+ *   = every architecture could add their byteswap macro in asm/byteorder.h
+ *    see how some architectures already do (i386, alpha, ppc, etc)
+ *   = cpu_to_beXX and beXX_to_cpu might some day need to be well
+ *    distinguished throughout the kernel. This is not the case currently,
+ *    since little endian, big endian, and pdp endian machines needn't it.
+ *    But this might be the case for, say, a port of Linux to 20/21 bit
+ *    architectures (and F21 Linux addict around?).
+ */
+
+/*
+ * The following macros are to be defined by <asm/byteorder.h>:
+ *
+ * Conversion of long and short int between network and host format
+ *	ntohl(__u32 x)
+ *	ntohs(__u16 x)
+ *	htonl(__u32 x)
+ *	htons(__u16 x)
+ * It seems that some programs (which? where? or perhaps a standard? POSIX?)
+ * might like the above to be functions, not macros (why?).
+ * if that's true, then detect them, and take measures.
+ * Anyway, the measure is: define only ___ntohl as a macro instead,
+ * and in a separate file, have
+ * unsigned long inline ntohl(x){return ___ntohl(x);}
+ *
+ * The same for constant arguments
+ *	__constant_ntohl(__u32 x)
+ *	__constant_ntohs(__u16 x)
+ *	__constant_htonl(__u32 x)
+ *	__constant_htons(__u16 x)
+ *
+ * Conversion of XX-bit integers (16- 32- or 64-)
+ * between native CPU format and little/big endian format
+ * 64-bit stuff only defined for proper architectures
+ *	cpu_to_[bl]eXX(__uXX x)
+ *	[bl]eXX_to_cpu(__uXX x)
+ *
+ * The same, but takes a pointer to the value to convert
+ *	cpu_to_[bl]eXXp(__uXX x)
+ *	[bl]eXX_to_cpup(__uXX x)
+ *
+ * The same, but change in situ
+ *	cpu_to_[bl]eXXs(__uXX x)
+ *	[bl]eXX_to_cpus(__uXX x)
+ *
+ * See asm-foo/byteorder.h for examples of how to provide
+ * architecture-optimized versions
+ *
+ */
+
+
+#if defined(PLATFORM_LINUX) || defined(PLATFORM_WINDOWS) || defined(PLATFORM_MPIXEL) || defined(PLATFORM_FREEBSD)
+	/*
+	* inside the kernel, we can use nicknames;
+	* outside of it, we must avoid POSIX namespace pollution...
+	*/
+	#define cpu_to_le64 __cpu_to_le64
+	#define le64_to_cpu __le64_to_cpu
+	#define cpu_to_le32 __cpu_to_le32
+	#define le32_to_cpu __le32_to_cpu
+	#define cpu_to_le16 __cpu_to_le16
+	#define le16_to_cpu __le16_to_cpu
+	#define cpu_to_be64 __cpu_to_be64
+	#define be64_to_cpu __be64_to_cpu
+	#define cpu_to_be32 __cpu_to_be32
+	#define be32_to_cpu __be32_to_cpu
+	#define cpu_to_be16 __cpu_to_be16
+	#define be16_to_cpu __be16_to_cpu
+	#define cpu_to_le64p __cpu_to_le64p
+	#define le64_to_cpup __le64_to_cpup
+	#define cpu_to_le32p __cpu_to_le32p
+	#define le32_to_cpup __le32_to_cpup
+	#define cpu_to_le16p __cpu_to_le16p
+	#define le16_to_cpup __le16_to_cpup
+	#define cpu_to_be64p __cpu_to_be64p
+	#define be64_to_cpup __be64_to_cpup
+	#define cpu_to_be32p __cpu_to_be32p
+	#define be32_to_cpup __be32_to_cpup
+	#define cpu_to_be16p __cpu_to_be16p
+	#define be16_to_cpup __be16_to_cpup
+	#define cpu_to_le64s __cpu_to_le64s
+	#define le64_to_cpus __le64_to_cpus
+	#define cpu_to_le32s __cpu_to_le32s
+	#define le32_to_cpus __le32_to_cpus
+	#define cpu_to_le16s __cpu_to_le16s
+	#define le16_to_cpus __le16_to_cpus
+	#define cpu_to_be64s __cpu_to_be64s
+	#define be64_to_cpus __be64_to_cpus
+	#define cpu_to_be32s __cpu_to_be32s
+	#define be32_to_cpus __be32_to_cpus
+	#define cpu_to_be16s __cpu_to_be16s
+	#define be16_to_cpus __be16_to_cpus
+#endif
+
+
+/*
+ * Handle ntohl and suches. These have various compatibility
+ * issues - like we want to give the prototype even though we
+ * also have a macro for them in case some strange program
+ * wants to take the address of the thing or something..
+ *
+ * Note that these used to return a "long" in libc5, even though
+ * long is often 64-bit these days.. Thus the casts.
+ *
+ * They have to be macros in order to do the constant folding
+ * correctly - if the argument passed into a inline function
+ * it is no longer constant according to gcc..
+ */
+
+#undef ntohl
+#undef ntohs
+#undef htonl
+#undef htons
+
+/*
+ * Do the prototypes. Somebody might want to take the
+ * address or some such sick thing..
+ */
+#if defined(PLATFORM_LINUX) || (defined(__GLIBC__) && __GLIBC__ >= 2)
+	extern __u32			ntohl(__u32);
+	extern __u32			htonl(__u32);
+#else /* defined(PLATFORM_LINUX) || (defined (__GLIBC__) && __GLIBC__ >= 2) */
+	#ifndef PLATFORM_FREEBSD
+		extern unsigned long int	ntohl(unsigned long int);
+		extern unsigned long int	htonl(unsigned long int);
+	#endif
+#endif
+#ifndef PLATFORM_FREEBSD
+	extern unsigned short int	ntohs(unsigned short int);
+	extern unsigned short int	htons(unsigned short int);
+#endif
+
+#if defined(__GNUC__) && (__GNUC__ >= 2) && defined(__OPTIMIZE__) || defined(PLATFORM_MPIXEL)
+
+	#define ___htonl(x) __cpu_to_be32(x)
+	#define ___htons(x) __cpu_to_be16(x)
+	#define ___ntohl(x) __be32_to_cpu(x)
+	#define ___ntohs(x) __be16_to_cpu(x)
+
+	#if defined(PLATFORM_LINUX) || (defined(__GLIBC__) && __GLIBC__ >= 2)
+		#define htonl(x) ___htonl(x)
+		#define ntohl(x) ___ntohl(x)
+	#else
+		#define htonl(x) ((unsigned long)___htonl(x))
+		#define ntohl(x) ((unsigned long)___ntohl(x))
+	#endif
+	#define htons(x) ___htons(x)
+	#define ntohs(x) ___ntohs(x)
+
+#endif /* OPTIMIZE */
+
+
+#if defined(PLATFORM_WINDOWS)
+
+	#define htonl(x) __cpu_to_be32(x)
+	#define ntohl(x) __be32_to_cpu(x)
+	#define htons(x) __cpu_to_be16(x)
+	#define ntohs(x) __be16_to_cpu(x)
+
+
+#endif
+
+#endif /* _LINUX_BYTEORDER_GENERIC_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/little_endian.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/little_endian.h
new file mode 100644
index 000000000000..c4b64512f296
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/little_endian.h
@@ -0,0 +1,84 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_BYTEORDER_LITTLE_ENDIAN_H
+#define _LINUX_BYTEORDER_LITTLE_ENDIAN_H
+
+#ifndef __LITTLE_ENDIAN
+	#define __LITTLE_ENDIAN 1234
+#endif
+#ifndef __LITTLE_ENDIAN_BITFIELD
+	#define __LITTLE_ENDIAN_BITFIELD
+#endif
+
+#include <byteorder/swab.h>
+
+#ifndef __constant_htonl
+	#define __constant_htonl(x) ___constant_swab32((x))
+	#define __constant_ntohl(x) ___constant_swab32((x))
+	#define __constant_htons(x) ___constant_swab16((x))
+	#define __constant_ntohs(x) ___constant_swab16((x))
+	#define __constant_cpu_to_le64(x) ((__u64)(x))
+	#define __constant_le64_to_cpu(x) ((__u64)(x))
+	#define __constant_cpu_to_le32(x) ((__u32)(x))
+	#define __constant_le32_to_cpu(x) ((__u32)(x))
+	#define __constant_cpu_to_le16(x) ((__u16)(x))
+	#define __constant_le16_to_cpu(x) ((__u16)(x))
+	#define __constant_cpu_to_be64(x) ___constant_swab64((x))
+	#define __constant_be64_to_cpu(x) ___constant_swab64((x))
+	#define __constant_cpu_to_be32(x) ___constant_swab32((x))
+	#define __constant_be32_to_cpu(x) ___constant_swab32((x))
+	#define __constant_cpu_to_be16(x) ___constant_swab16((x))
+	#define __constant_be16_to_cpu(x) ___constant_swab16((x))
+	#define __cpu_to_le64(x) ((__u64)(x))
+	#define __le64_to_cpu(x) ((__u64)(x))
+	#define __cpu_to_le32(x) ((__u32)(x))
+	#define __le32_to_cpu(x) ((__u32)(x))
+	#define __cpu_to_le16(x) ((__u16)(x))
+	#define __le16_to_cpu(x) ((__u16)(x))
+	#define __cpu_to_be64(x) __swab64((x))
+	#define __be64_to_cpu(x) __swab64((x))
+	#define __cpu_to_be32(x) __swab32((x))
+	#define __be32_to_cpu(x) __swab32((x))
+	#define __cpu_to_be16(x) __swab16((x))
+	#define __be16_to_cpu(x) __swab16((x))
+	#define __cpu_to_le64p(x) (*(__u64 *)(x))
+	#define __le64_to_cpup(x) (*(__u64 *)(x))
+	#define __cpu_to_le32p(x) (*(__u32 *)(x))
+	#define __le32_to_cpup(x) (*(__u32 *)(x))
+	#define __cpu_to_le16p(x) (*(__u16 *)(x))
+	#define __le16_to_cpup(x) (*(__u16 *)(x))
+	#define __cpu_to_be64p(x) __swab64p((x))
+	#define __be64_to_cpup(x) __swab64p((x))
+	#define __cpu_to_be32p(x) __swab32p((x))
+	#define __be32_to_cpup(x) __swab32p((x))
+	#define __cpu_to_be16p(x) __swab16p((x))
+	#define __be16_to_cpup(x) __swab16p((x))
+	#define __cpu_to_le64s(x) do {} while (0)
+	#define __le64_to_cpus(x) do {} while (0)
+	#define __cpu_to_le32s(x) do {} while (0)
+	#define __le32_to_cpus(x) do {} while (0)
+	#define __cpu_to_le16s(x) do {} while (0)
+	#define __le16_to_cpus(x) do {} while (0)
+	#define __cpu_to_be64s(x) __swab64s((x))
+	#define __be64_to_cpus(x) __swab64s((x))
+	#define __cpu_to_be32s(x) __swab32s((x))
+	#define __be32_to_cpus(x) __swab32s((x))
+	#define __cpu_to_be16s(x) __swab16s((x))
+	#define __be16_to_cpus(x) __swab16s((x))
+#endif /* __constant_htonl */
+
+#include <byteorder/generic.h>
+
+#endif /* _LINUX_BYTEORDER_LITTLE_ENDIAN_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/swab.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/swab.h
new file mode 100644
index 000000000000..a8dd46bd3a60
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/swab.h
@@ -0,0 +1,136 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_BYTEORDER_SWAB_H
+#define _LINUX_BYTEORDER_SWAB_H
+
+#if !defined(CONFIG_PLATFORM_MSTAR)
+#ifndef __u16
+	typedef unsigned short __u16;
+#endif
+
+#ifndef __u32
+	typedef unsigned int	__u32;
+#endif
+
+#ifndef __u8
+	typedef unsigned char __u8;
+#endif
+
+#ifndef __u64
+	typedef unsigned long long	__u64;
+#endif
+
+
+__inline static __u16  ___swab16(__u16 x)
+{
+	__u16 __x = x;
+	return
+		 (__u16)(
+			 (((__u16)(__x)&(__u16)0x00ffU) << 8) |
+			 (((__u16)(__x)&(__u16)0xff00U) >> 8));
+
+}
+
+__inline static __u32  ___swab32(__u32 x)
+{
+	__u32 __x = (x);
+	return  (__u32)(
+			(((__u32)(__x)&(__u32)0x000000ffUL) << 24) |
+			(((__u32)(__x)&(__u32)0x0000ff00UL) <<  8) |
+			(((__u32)(__x)&(__u32)0x00ff0000UL) >>  8) |
+			(((__u32)(__x)&(__u32)0xff000000UL) >> 24));
+}
+
+__inline static __u64  ___swab64(__u64 x)
+{
+	__u64 __x = (x);
+
+	return
+		 (__u64)(\
+		 (__u64)(((__u64)(__x)&(__u64)0x00000000000000ffULL) << 56) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x000000000000ff00ULL) << 40) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x0000000000ff0000ULL) << 24) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x00000000ff000000ULL) <<  8) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x000000ff00000000ULL) >>  8) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x0000ff0000000000ULL) >> 24) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x00ff000000000000ULL) >> 40) | \
+		 (__u64)(((__u64)(__x)&(__u64)0xff00000000000000ULL) >> 56));
+	\
+}
+#endif /* CONFIG_PLATFORM_MSTAR */
+
+#ifndef __arch__swab16
+__inline static __u16 __arch__swab16(__u16 x)
+{
+	return ___swab16(x);
+}
+
+#endif
+
+#ifndef __arch__swab32
+__inline static __u32 __arch__swab32(__u32 x)
+{
+	__u32 __tmp = (x) ;
+	return ___swab32(__tmp);
+}
+#endif
+
+#ifndef __arch__swab64
+
+__inline static __u64 __arch__swab64(__u64 x)
+{
+	__u64 __tmp = (x) ;
+	return ___swab64(__tmp);
+}
+
+
+#endif
+
+#ifndef __swab16
+	#define __swab16(x) __fswab16(x)
+	#define __swab32(x) __fswab32(x)
+	#define __swab64(x) __fswab64(x)
+#endif /* __swab16 */
+
+#ifdef PLATFORM_FREEBSD
+	__inline static __u16 __fswab16(__u16 x)
+#else
+	__inline static const __u16 __fswab16(__u16 x)
+#endif /* PLATFORM_FREEBSD */
+{
+	return __arch__swab16(x);
+}
+#ifdef PLATFORM_FREEBSD
+	__inline static __u32 __fswab32(__u32 x)
+#else
+	__inline static const __u32 __fswab32(__u32 x)
+#endif /* PLATFORM_FREEBSD */
+{
+	return __arch__swab32(x);
+}
+
+#if defined(PLATFORM_LINUX) || defined(PLATFORM_WINDOWS)
+	#define swab16 __swab16
+	#define swab32 __swab32
+	#define swab64 __swab64
+	#define swab16p __swab16p
+	#define swab32p __swab32p
+	#define swab64p __swab64p
+	#define swab16s __swab16s
+	#define swab32s __swab32s
+	#define swab64s __swab64s
+#endif
+
+#endif /* _LINUX_BYTEORDER_SWAB_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/swabb.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/swabb.h
new file mode 100644
index 000000000000..634519a0b826
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/byteorder/swabb.h
@@ -0,0 +1,151 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_BYTEORDER_SWABB_H
+#define _LINUX_BYTEORDER_SWABB_H
+
+/*
+ * linux/byteorder/swabb.h
+ * SWAp Bytes Bizarrely
+ *	swaHHXX[ps]?(foo)
+ *
+ * Support for obNUXIous pdp-endian and other bizarre architectures.
+ * Will Linux ever run on such ancient beasts? if not, this file
+ * will be but a programming pearl. Still, it's a reminder that we
+ * shouldn't be making too many assumptions when trying to be portable.
+ *
+ */
+
+/*
+ * Meaning of the names I chose (vaxlinux people feel free to correct them):
+ * swahw32	swap 16-bit half-words in a 32-bit word
+ * swahb32	swap 8-bit halves of each 16-bit half-word in a 32-bit word
+ *
+ * No 64-bit support yet. I don't know NUXI conventions for long longs.
+ * I guarantee it will be a mess when it's there, though :->
+ * It will be even worse if there are conflicting 64-bit conventions.
+ * Hopefully, no one ever used 64-bit objects on NUXI machines.
+ *
+ */
+
+#define ___swahw32(x) \
+	({ \
+		__u32 __x = (x); \
+		((__u32)(\
+			 (((__u32)(__x) & (__u32)0x0000ffffUL) << 16) | \
+			 (((__u32)(__x) & (__u32)0xffff0000UL) >> 16))); \
+	})
+#define ___swahb32(x) \
+	({ \
+		__u32 __x = (x); \
+		((__u32)(\
+			 (((__u32)(__x) & (__u32)0x00ff00ffUL) << 8) | \
+			 (((__u32)(__x) & (__u32)0xff00ff00UL) >> 8))); \
+	})
+
+#define ___constant_swahw32(x) \
+	((__u32)(\
+		 (((__u32)(x) & (__u32)0x0000ffffUL) << 16) | \
+		 (((__u32)(x) & (__u32)0xffff0000UL) >> 16)))
+#define ___constant_swahb32(x) \
+	((__u32)(\
+		 (((__u32)(x) & (__u32)0x00ff00ffUL) << 8) | \
+		 (((__u32)(x) & (__u32)0xff00ff00UL) >> 8)))
+
+/*
+ * provide defaults when no architecture-specific optimization is detected
+ */
+#ifndef __arch__swahw32
+	#define __arch__swahw32(x) ___swahw32(x)
+#endif
+#ifndef __arch__swahb32
+	#define __arch__swahb32(x) ___swahb32(x)
+#endif
+
+#ifndef __arch__swahw32p
+	#define __arch__swahw32p(x) __swahw32(*(x))
+#endif
+#ifndef __arch__swahb32p
+	#define __arch__swahb32p(x) __swahb32(*(x))
+#endif
+
+#ifndef __arch__swahw32s
+	#define __arch__swahw32s(x) do { *(x) = __swahw32p((x)); } while (0)
+#endif
+#ifndef __arch__swahb32s
+	#define __arch__swahb32s(x) do { *(x) = __swahb32p((x)); } while (0)
+#endif
+
+
+/*
+ * Allow constant folding
+ */
+#if defined(__GNUC__) && (__GNUC__ >= 2) && defined(__OPTIMIZE__)
+#  define __swahw32(x) \
+	(__builtin_constant_p((__u32)(x)) ? \
+	 ___swahw32((x)) : \
+	 __fswahw32((x)))
+#  define __swahb32(x) \
+	(__builtin_constant_p((__u32)(x)) ? \
+	 ___swahb32((x)) : \
+	 __fswahb32((x)))
+#else
+#  define __swahw32(x) __fswahw32(x)
+#  define __swahb32(x) __fswahb32(x)
+#endif /* OPTIMIZE */
+
+
+__inline static__ __const__ __u32 __fswahw32(__u32 x)
+{
+	return __arch__swahw32(x);
+}
+__inline static__ __u32 __swahw32p(__u32 *x)
+{
+	return __arch__swahw32p(x);
+}
+__inline static__ void __swahw32s(__u32 *addr)
+{
+	__arch__swahw32s(addr);
+}
+
+
+__inline static__ __const__ __u32 __fswahb32(__u32 x)
+{
+	return __arch__swahb32(x);
+}
+__inline static__ __u32 __swahb32p(__u32 *x)
+{
+	return __arch__swahb32p(x);
+}
+__inline static__ void __swahb32s(__u32 *addr)
+{
+	__arch__swahb32s(addr);
+}
+
+#ifdef __BYTEORDER_HAS_U64__
+	/*
+	* Not supported yet
+	*/
+#endif /* __BYTEORDER_HAS_U64__ */
+
+#if defined(PLATFORM_LINUX)
+	#define swahw32 __swahw32
+	#define swahb32 __swahb32
+	#define swahw32p __swahw32p
+	#define swahb32p __swahb32p
+	#define swahw32s __swahw32s
+	#define swahb32s __swahb32s
+#endif
+
+#endif /* _LINUX_BYTEORDER_SWABB_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/circ_buf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/circ_buf.h
new file mode 100644
index 000000000000..7a5b8ef1a202
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/circ_buf.h
@@ -0,0 +1,23 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __CIRC_BUF_H_
+#define __CIRC_BUF_H_ 1
+
+#define CIRC_CNT(head,tail,size) (((head) - (tail)) & ((size)-1))
+
+#define CIRC_SPACE(head,tail,size) CIRC_CNT((tail),((head)+1),(size))
+
+#endif //_CIRC_BUF_H_
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/cmd_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/cmd_osdep.h
new file mode 100644
index 000000000000..e4ba2b6d3b62
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/cmd_osdep.h
@@ -0,0 +1,26 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __CMD_OSDEP_H_
+#define __CMD_OSDEP_H_
+
+
+extern sint _rtw_init_cmd_priv(struct	cmd_priv *pcmdpriv);
+extern sint _rtw_init_evt_priv(struct evt_priv *pevtpriv);
+extern void _rtw_free_evt_priv(struct	evt_priv *pevtpriv);
+extern void _rtw_free_cmd_priv(struct	cmd_priv *pcmdpriv);
+extern sint _rtw_enqueue_cmd(_queue *queue, struct cmd_obj *obj, bool to_head);
+extern struct cmd_obj *_rtw_dequeue_cmd(_queue *queue);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/cmn_info/rtw_sta_info.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/cmn_info/rtw_sta_info.h
new file mode 100644
index 000000000000..afc07aaaf56e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/cmn_info/rtw_sta_info.h
@@ -0,0 +1,253 @@
+/******************************************************************************
+ *
+ * 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.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
+ *
+ *
+ ******************************************************************************/
+
+ /*This header file is for all driver teams to use the same station info.
+If you want to change this file please make sure notify all driver teams maintainers.*/
+
+/*Created by YuChen 20170301*/
+
+#ifndef __INC_RTW_STA_INFO_H
+#define __INC_RTW_STA_INFO_H
+
+/*--------------------Define ---------------------------------------*/
+
+#define STA_DM_CTRL_ACTIVE			BIT(0)
+#define STA_DM_CTRL_CFO_TRACKING	BIT(1)
+
+#ifdef CONFIG_BEAMFORMING
+#define	BEAMFORMING_HT_BEAMFORMER_ENABLE	BIT(0)	/*Declare sta support beamformer*/
+#define	BEAMFORMING_HT_BEAMFORMEE_ENABLE	BIT(1)	/*Declare sta support beamformee*/
+#define	BEAMFORMING_HT_BEAMFORMER_TEST		BIT(2)	/*Transmiting Beamforming no matter the target supports it or not*/
+#define	BEAMFORMING_HT_BEAMFORMER_STEER_NUM		(BIT(4)|BIT(5))		/*Sta Bfer's capability*/
+#define	BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP	(BIT(6)|BIT(7))		/*Sta BFee's capability*/
+
+#define	BEAMFORMING_VHT_BEAMFORMER_ENABLE	BIT(0)	/*Declare sta support beamformer*/
+#define	BEAMFORMING_VHT_BEAMFORMEE_ENABLE	BIT(1)	/*Declare sta support beamformee*/
+#define	BEAMFORMING_VHT_MU_MIMO_AP_ENABLE	BIT(2)	/*Declare sta support MU beamformer*/
+#define	BEAMFORMING_VHT_MU_MIMO_STA_ENABLE	BIT(3)	/*Declare sta support MU beamformer*/
+#define	BEAMFORMING_VHT_BEAMFORMER_TEST		BIT(4)	/*Transmiting Beamforming no matter the target supports it or not*/
+#define	BEAMFORMING_VHT_BEAMFORMER_STS_CAP		(BIT(8)|BIT(9)|BIT(10))		/*Sta BFee's capability*/
+#define	BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM	(BIT(12)|BIT(13)|BIT(14))	/*Sta Bfer's capability*/
+#endif
+
+#define HT_STBC_EN	BIT(0)
+#define VHT_STBC_EN	BIT(1)
+
+#define HT_LDPC_EN	BIT(0)
+#define VHT_LDPC_EN	BIT(1)
+
+#define	SM_PS_STATIC	0
+#define	SM_PS_DYNAMIC	1
+#define	SM_PS_INVALID	2
+#define	SM_PS_DISABLE	3
+
+
+/*cmn_sta_info.ra_sta_info.txrx_state*/
+#define	TX_STATE				0
+#define	RX_STATE				1
+#define	BI_DIRECTION_STATE	2
+
+/*--------------------Define Enum-----------------------------------*/
+enum channel_width {
+	CHANNEL_WIDTH_20		= 0,
+	CHANNEL_WIDTH_40		= 1,
+	CHANNEL_WIDTH_80		= 2,
+	CHANNEL_WIDTH_160		= 3,
+	CHANNEL_WIDTH_80_80	= 4,
+	CHANNEL_WIDTH_5		= 5,
+	CHANNEL_WIDTH_10	= 6,
+	CHANNEL_WIDTH_MAX	= 7,
+};
+
+enum rf_type {
+	RF_1T1R			= 0,
+	RF_1T2R			= 1,
+	RF_2T2R			= 2,
+	RF_2T3R			= 3,
+	RF_2T4R			= 4,
+	RF_3T3R			= 5,
+	RF_3T4R			= 6,
+	RF_4T4R			= 7,
+	RF_TYPE_MAX,
+};
+
+enum bb_path {
+	BB_PATH_A = 0x00000001,
+	BB_PATH_B = 0x00000002,
+	BB_PATH_C = 0x00000004,
+	BB_PATH_D = 0x00000008,
+
+	BB_PATH_AB = (BB_PATH_A | BB_PATH_B),
+	BB_PATH_AC = (BB_PATH_A | BB_PATH_C),
+	BB_PATH_AD = (BB_PATH_A | BB_PATH_D),
+	BB_PATH_BC = (BB_PATH_B | BB_PATH_C),
+	BB_PATH_BD = (BB_PATH_B | BB_PATH_D),
+	BB_PATH_CD = (BB_PATH_C | BB_PATH_D),
+
+	BB_PATH_ABC = (BB_PATH_A | BB_PATH_B | BB_PATH_C),
+	BB_PATH_ABD = (BB_PATH_A | BB_PATH_B | BB_PATH_D),
+	BB_PATH_ACD = (BB_PATH_A | BB_PATH_C | BB_PATH_D),
+	BB_PATH_BCD = (BB_PATH_B | BB_PATH_C | BB_PATH_D),
+
+	BB_PATH_ABCD = (BB_PATH_A | BB_PATH_B | BB_PATH_C | BB_PATH_D),
+};
+
+enum rf_path {
+	RF_PATH_A = 0,
+	RF_PATH_B = 1,
+	RF_PATH_C = 2,
+	RF_PATH_D = 3,
+	RF_PATH_AB,
+	RF_PATH_AC,
+	RF_PATH_AD,
+	RF_PATH_BC,
+	RF_PATH_BD,
+	RF_PATH_CD,
+	RF_PATH_ABC,
+	RF_PATH_ACD,
+	RF_PATH_BCD,
+	RF_PATH_ABCD,
+};
+
+enum wireless_set {
+	WIRELESS_CCK	= 0x00000001,
+	WIRELESS_OFDM	= 0x00000002,
+	WIRELESS_HT	= 0x00000004,
+	WIRELESS_VHT	= 0x00000008,
+};
+
+/*--------------------Define MACRO---------------------------------*/
+
+/*--------------------Define Struct-----------------------------------*/
+
+#ifdef CONFIG_BEAMFORMING
+struct bf_cmn_info {
+	u8	ht_beamform_cap;		/*Sta capablity*/
+	u16	vht_beamform_cap;		/*Sta capablity*/
+	u16	p_aid;
+	u8	g_id;
+};
+#endif
+struct rssi_info {
+	s8		rssi;
+	s8		rssi_cck;
+	s8		rssi_ofdm;
+	u8		packet_map;
+	u8		ofdm_pkt_cnt;
+	u8		cck_pkt_cnt;
+	u16		cck_sum_power;
+	u8		is_send_rssi;
+	u8		valid_bit;
+	s16		rssi_acc;	/*accumulate RSSI for per packet MA sum*/
+};
+
+struct ra_sta_info {
+	u8	rate_id;			/*ratr_idx*/
+	u8	rssi_level;
+
+	/*New*/
+	u8	is_first_connect:1;	/*CE: ra_rpt_linked, AP: H2C_rssi_rpt*/
+	u8	is_support_sgi:1;	/*driver*/
+	u8	is_vht_enable:2;		/*driver*/
+	u8	disable_ra:1;		/*driver*/
+	u8	disable_pt:1;		/*driver*/  /*remove is_disable_power_training*/
+	u8	txrx_state:2;		/*0: Tx, 1:Rx, 2:bi-direction*/
+	u8	is_noisy:1;
+	
+	u8 curr_tx_rate;					/*FW->Driver*/
+	enum channel_width	ra_bw_mode;	/*max bandwidth, for RA only*/
+	enum channel_width	curr_tx_bw;    /*FW->Driver*/
+	u8 curr_retry_ratio;				/*FW->Driver*/
+
+	u64	ramask;
+};
+
+struct dtp_info {
+	u8	dyn_tx_power;	/*Dynamic Tx power offset*/
+	u8	sta_tx_high_power_lvl:4;
+	u8	sta_last_dtp_lvl:4;
+};
+
+struct cmn_sta_info {
+	u16	dm_ctrl;
+	enum channel_width	bw_mode;	/*max bandwidth*/
+	u8	mac_id;
+	u8	mac_addr[6];
+	u16	aid;
+	enum rf_type mimo_type;		/*sta XTXR*/
+	struct rssi_info	rssi_stat;
+	struct ra_sta_info	ra_info;
+	u16	tx_moving_average_tp;	/*tx average MBps*/
+	u16	rx_moving_average_tp;	/*rx average MBps*/
+	u8	stbc_en:2;		/*Driver : really use stbc!!*/
+	u8	ldpc_en:2;
+	enum wireless_set	support_wireless_set;
+#ifdef CONFIG_BEAMFORMING
+	struct bf_cmn_info	bf_info;
+#endif
+	u8	sm_ps:2;
+	struct dtp_info dtp_stat;	/*Dynamic Tx power offset*/
+	/*u8		pw2cca_over_TH_cnt;*/
+	/*u8		total_pw2cca_cnt;*/
+};
+
+struct phydm_phyinfo_struct {
+	u8		rx_pwdb_all;
+	u8		signal_quality;				/* OFDM: signal_quality=rx_mimo_signal_quality[0], CCK: signal qualityin 0-100 index. */
+	u8		rx_mimo_signal_strength[4];	/* RSSI in 0~100 index */
+	s8		rx_mimo_signal_quality[4];		/* OFDM: per-path's EVM translate to 0~100% , no used for CCK*/
+	u8		rx_mimo_evm_dbm[4];			/* per-path's original EVM (dbm) */
+	s16		cfo_short[4];					/* per-path's cfo_short */
+	s16		cfo_tail[4];					/* per-path's cfo_tail */
+	s8		rx_power;					/* in dBm Translate from PWdB */
+	s8		recv_signal_power;			/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. */
+	u8		bt_rx_rssi_percentage;
+	u8		signal_strength;				/* in 0-100 index. */
+	s8		rx_pwr[4];					/* per-path's pwdb */
+	s8		rx_snr[4];					/* per-path's SNR	*/
+/*ODM_PHY_STATUS_NEW_TYPE_SUPPORT*/
+	u8		rx_count:2;					/* RX path counter---*/
+	u8		band_width:2;
+	u8		rxsc:4;						/* sub-channel---*/
+	u8		channel;						/* channel number---*/
+	u8		is_mu_packet:1;				/* is MU packet or not---boolean*/
+	u8		is_beamformed:1;				/* BF packet---boolean*/
+	u8		cnt_pw2cca;
+	u8		cnt_cca2agc_rdy;
+/*ODM_PHY_STATUS_NEW_TYPE_SUPPORT*/
+};
+
+struct phydm_perpkt_info_struct {
+	u8		data_rate;
+	u8		station_id;
+	u8		is_cck_rate: 1;
+	u8		rate_ss:3;			/*spatial stream of data rate*/
+	u8		is_packet_match_bssid:1;	/*boolean*/
+	u8		is_packet_to_self:1;		/*boolean*/
+	u8		is_packet_beacon:1;		/*boolean*/
+	u8		is_to_self:1;				/*boolean*/
+	u8		ppdu_cnt;
+};
+
+/*--------------------Export global variable----------------------------*/
+
+/*--------------------Function declaration-----------------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/custom_gpio.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/custom_gpio.h
new file mode 100644
index 000000000000..49411b662efb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/custom_gpio.h
@@ -0,0 +1,46 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __CUSTOM_GPIO_H__
+#define __CUSTOM_GPIO_H___
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+
+#ifdef PLATFORM_OS_XP
+	#include <drv_types_xp.h>
+#endif
+
+#ifdef PLATFORM_OS_CE
+	#include <drv_types_ce.h>
+#endif
+
+#ifdef PLATFORM_LINUX
+	#include <drv_types_linux.h>
+#endif
+
+typedef enum cust_gpio_modes {
+	WLAN_PWDN_ON,
+	WLAN_PWDN_OFF,
+	WLAN_POWER_ON,
+	WLAN_POWER_OFF,
+	WLAN_BT_PWDN_ON,
+	WLAN_BT_PWDN_OFF
+} cust_gpio_modes_t;
+
+extern int rtw_wifi_gpio_init(void);
+extern int rtw_wifi_gpio_deinit(void);
+extern void rtw_wifi_gpio_wlan_ctrl(int onoff);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_conf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_conf.h
new file mode 100644
index 000000000000..cc001670e8b4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_conf.h
@@ -0,0 +1,414 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_CONF_H__
+#define __DRV_CONF_H__
+#include "autoconf.h"
+#include "hal_ic_cfg.h"
+
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+
+	#error "Shall be Linux or Windows, but not both!\n"
+
+#endif
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	#ifndef CONFIG_AP
+		#define CONFIG_AP
+	#endif
+	#ifndef CONFIG_CONCURRENT_MODE
+		#define CONFIG_CONCURRENT_MODE
+	#endif
+	#ifndef CONFIG_BR_EXT
+		#define CONFIG_BR_EXT
+	#endif
+	#ifndef CONFIG_RTW_REPEATER_SON_ID
+		#define CONFIG_RTW_REPEATER_SON_ID			0x02040608
+	#endif
+	//#define CONFIG_RTW_REPEATER_SON_ROOT
+	#ifndef CONFIG_RTW_REPEATER_SON_ROOT
+		#define CONFIG_LAYER2_ROAMING_ACTIVE
+	#endif
+	#undef CONFIG_POWER_SAVING
+#endif
+
+#if defined(CONFIG_MCC_MODE) && (!defined(CONFIG_CONCURRENT_MODE))
+
+	#error "Enable CONCURRENT_MODE before enable MCC MODE\n"
+
+#endif
+
+#if defined(CONFIG_MCC_MODE) && defined(CONFIG_BT_COEXIST)
+
+	#error "Disable BT COEXIST before enable MCC MODE\n"
+
+#endif
+
+#if defined(CONFIG_MCC_MODE) && defined(CONFIG_TDLS)
+
+	#error "Disable TDLS before enable MCC MODE\n"
+
+#endif
+
+#if defined(CONFIG_RTW_80211R) && !defined(CONFIG_LAYER2_ROAMING)
+
+	#error "Enable CONFIG_LAYER2_ROAMING before enable CONFIG_RTW_80211R\n"
+
+#endif
+
+/* Older Android kernel doesn't has CONFIG_ANDROID defined,
+ * add this to force CONFIG_ANDROID defined */
+#ifdef CONFIG_PLATFORM_ANDROID
+	#ifndef CONFIG_ANDROID
+		#define CONFIG_ANDROID
+	#endif
+#endif
+
+#ifdef CONFIG_ANDROID
+	/* Some Android build will restart the UI while non-printable ascii is passed
+	* between java and c/c++ layer (JNI). We force CONFIG_VALIDATE_SSID
+	* for Android here. If you are sure there is no risk on your system about this,
+	* mask this macro define to support non-printable ascii ssid.
+	* #define CONFIG_VALIDATE_SSID */
+
+	/* Android expect dbm as the rx signal strength unit */
+	#define CONFIG_SIGNAL_DISPLAY_DBM
+#endif
+
+/*
+#if defined(CONFIG_HAS_EARLYSUSPEND) && defined(CONFIG_RESUME_IN_WORKQUEUE)
+	#warning "You have CONFIG_HAS_EARLYSUSPEND enabled in your system, we disable CONFIG_RESUME_IN_WORKQUEUE automatically"
+	#undef CONFIG_RESUME_IN_WORKQUEUE
+#endif
+
+#if defined(CONFIG_ANDROID_POWER) && defined(CONFIG_RESUME_IN_WORKQUEUE)
+	#warning "You have CONFIG_ANDROID_POWER enabled in your system, we disable CONFIG_RESUME_IN_WORKQUEUE automatically"
+	#undef CONFIG_RESUME_IN_WORKQUEUE
+#endif
+*/
+
+#ifdef CONFIG_RESUME_IN_WORKQUEUE /* this can be removed, because there is no case for this... */
+	#if !defined(CONFIG_WAKELOCK) && !defined(CONFIG_ANDROID_POWER)
+		#error "enable CONFIG_RESUME_IN_WORKQUEUE without CONFIG_WAKELOCK or CONFIG_ANDROID_POWER will suffer from the danger of wifi's unfunctionality..."
+		#error "If you still want to enable CONFIG_RESUME_IN_WORKQUEUE in this case, mask this preprossor checking and GOOD LUCK..."
+	#endif
+#endif
+
+/* About USB VENDOR REQ */
+#if defined(CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC) && !defined(CONFIG_USB_VENDOR_REQ_MUTEX)
+	#warning "define CONFIG_USB_VENDOR_REQ_MUTEX for CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC automatically"
+	#define CONFIG_USB_VENDOR_REQ_MUTEX
+#endif
+#if defined(CONFIG_VENDOR_REQ_RETRY) &&  !defined(CONFIG_USB_VENDOR_REQ_MUTEX)
+	#warning "define CONFIG_USB_VENDOR_REQ_MUTEX for CONFIG_VENDOR_REQ_RETRY automatically"
+	#define CONFIG_USB_VENDOR_REQ_MUTEX
+#endif
+
+#if !defined(CONFIG_AP_MODE) && defined(CONFIG_DFS_MASTER)
+	#warning "undef CONFIG_DFS_MASTER because CONFIG_AP_MODE is not defined"
+	#undef CONFIG_DFS_MASTER
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	#ifndef CONFIG_RTW_MESH_OFFCH_CAND
+	#define CONFIG_RTW_MESH_OFFCH_CAND 1
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_PEER_BLACKLIST
+	#define CONFIG_RTW_MESH_PEER_BLACKLIST 1
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	#define CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST 1
+	#endif
+
+	#ifndef CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+	#define CONFIG_RTW_MPM_TX_IES_SYNC_BSS 1
+	#endif
+	#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+		#ifndef CONFIG_RTW_MESH_AEK
+		#define CONFIG_RTW_MESH_AEK
+		#endif
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	#define CONFIG_RTW_MESH_DATA_BMC_TO_UC 1
+	#endif
+#endif
+
+#if !defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_AP_MODE)
+#define CONFIG_SCAN_BACKOP
+#endif
+
+#define RTW_SCAN_SPARSE_MIRACAST 1
+#define RTW_SCAN_SPARSE_BG 0
+#define RTW_SCAN_SPARSE_ROAMING_ACTIVE 1
+
+#ifndef CONFIG_RTW_HIQ_FILTER
+	#define CONFIG_RTW_HIQ_FILTER 1
+#endif
+
+#ifndef CONFIG_RTW_ADAPTIVITY_EN
+	#define CONFIG_RTW_ADAPTIVITY_EN 0
+#endif
+
+#ifndef CONFIG_RTW_ADAPTIVITY_MODE
+	#define CONFIG_RTW_ADAPTIVITY_MODE 0
+#endif
+
+#ifndef CONFIG_RTW_ADAPTIVITY_DML
+	#define CONFIG_RTW_ADAPTIVITY_DML 0
+#endif
+
+#ifndef CONFIG_RTW_ADAPTIVITY_DC_BACKOFF
+	#define CONFIG_RTW_ADAPTIVITY_DC_BACKOFF 2
+#endif
+
+#ifndef CONFIG_RTW_ADAPTIVITY_TH_L2H_INI
+	#define CONFIG_RTW_ADAPTIVITY_TH_L2H_INI 0
+#endif
+
+#ifndef CONFIG_RTW_ADAPTIVITY_TH_EDCCA_HL_DIFF
+	#define CONFIG_RTW_ADAPTIVITY_TH_EDCCA_HL_DIFF 0
+#endif
+
+#ifndef CONFIG_RTW_EXCL_CHS
+	#define CONFIG_RTW_EXCL_CHS {0}
+#endif
+
+#ifndef CONFIG_RTW_DFS_REGION_DOMAIN
+	#define CONFIG_RTW_DFS_REGION_DOMAIN 0
+#endif
+
+#ifndef CONFIG_TXPWR_BY_RATE_EN
+#define CONFIG_TXPWR_BY_RATE_EN 2 /* by efuse */
+#endif
+#ifndef CONFIG_TXPWR_LIMIT_EN
+#define CONFIG_TXPWR_LIMIT_EN 2 /* by efuse */
+#endif
+
+#ifndef CONFIG_RTW_CHPLAN
+#define CONFIG_RTW_CHPLAN 0xFF /* RTW_CHPLAN_UNSPECIFIED */
+#endif
+
+/* compatible with old fashion configuration */
+#if defined(CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY)
+	#undef CONFIG_TXPWR_BY_RATE_EN
+	#undef CONFIG_TXPWR_LIMIT_EN
+	#define CONFIG_TXPWR_BY_RATE_EN 1
+	#define CONFIG_TXPWR_LIMIT_EN 1
+#elif defined(CONFIG_CALIBRATE_TX_POWER_TO_MAX)
+	#undef CONFIG_TXPWR_BY_RATE_EN
+	#undef CONFIG_TXPWR_LIMIT_EN
+	#define CONFIG_TXPWR_BY_RATE_EN 1
+	#define CONFIG_TXPWR_LIMIT_EN 0
+#endif
+
+#ifndef RTW_DEF_MODULE_REGULATORY_CERT
+	#define RTW_DEF_MODULE_REGULATORY_CERT 0
+#endif
+
+#if RTW_DEF_MODULE_REGULATORY_CERT
+	/* force enable TX power by rate and TX power limit */
+	#undef CONFIG_TXPWR_BY_RATE_EN
+	#undef CONFIG_TXPWR_LIMIT_EN
+	#define CONFIG_TXPWR_BY_RATE_EN 1
+	#define CONFIG_TXPWR_LIMIT_EN 1
+#endif
+
+#if !defined(CONFIG_TXPWR_LIMIT) && CONFIG_TXPWR_LIMIT_EN
+	#define CONFIG_TXPWR_LIMIT
+#endif
+
+#ifdef CONFIG_RTW_IPCAM_APPLICATION
+	#undef CONFIG_TXPWR_BY_RATE_EN
+	#define CONFIG_TXPWR_BY_RATE_EN 1
+	#define CONFIG_RTW_CUSTOMIZE_BEEDCA		0x0000431C
+	#define CONFIG_RTW_CUSTOMIZE_BWMODE		0x00
+	#define CONFIG_RTW_CUSTOMIZE_RLSTA		0x7
+#endif
+
+
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_2SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_2SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_3SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_3SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_4SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_4SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_2G_A
+	#define CONFIG_RTW_TARGET_TX_PWR_2G_A {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_2G_B
+	#define CONFIG_RTW_TARGET_TX_PWR_2G_B {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_2G_C
+	#define CONFIG_RTW_TARGET_TX_PWR_2G_C {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_2G_D
+	#define CONFIG_RTW_TARGET_TX_PWR_2G_D {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_5G_A
+	#define CONFIG_RTW_TARGET_TX_PWR_5G_A {-1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_5G_B
+	#define CONFIG_RTW_TARGET_TX_PWR_5G_B {-1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_5G_C
+	#define CONFIG_RTW_TARGET_TX_PWR_5G_C {-1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_TARGET_TX_PWR_5G_D
+	#define CONFIG_RTW_TARGET_TX_PWR_5G_D {-1, -1, -1, -1, -1, -1, -1, -1, -1}
+#endif
+
+#ifndef CONFIG_RTW_AMPLIFIER_TYPE_2G
+	#define CONFIG_RTW_AMPLIFIER_TYPE_2G 0
+#endif
+
+#ifndef CONFIG_RTW_AMPLIFIER_TYPE_5G
+	#define CONFIG_RTW_AMPLIFIER_TYPE_5G 0
+#endif
+
+#ifndef CONFIG_RTW_RFE_TYPE
+	#define CONFIG_RTW_RFE_TYPE 64
+#endif
+
+#ifndef CONFIG_RTW_GLNA_TYPE
+	#define CONFIG_RTW_GLNA_TYPE 0
+#endif
+
+#ifndef CONFIG_RTW_PLL_REF_CLK_SEL
+	#define CONFIG_RTW_PLL_REF_CLK_SEL 0x0F
+#endif
+
+#ifndef CONFIG_IFACE_NUMBER
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define CONFIG_IFACE_NUMBER	2
+	#else
+		#define CONFIG_IFACE_NUMBER	1
+	#endif
+#endif
+
+#ifndef CONFIG_CONCURRENT_MODE
+	#if (CONFIG_IFACE_NUMBER > 1)
+		#error "CONFIG_IFACE_NUMBER over 1,but CONFIG_CONCURRENT_MODE not defined"
+	#endif
+#endif
+
+#if (CONFIG_IFACE_NUMBER == 0)
+	#error "CONFIG_IFACE_NUMBER cound not equel to 0 !!"
+#endif
+
+#if (CONFIG_IFACE_NUMBER > 3)
+	#error "Not support over 3 interfaces yet !!"
+#endif
+
+#if (CONFIG_IFACE_NUMBER > 8)	/*IFACE_ID_MAX*/
+	#error "HW count not support over 8 interfaces !!"
+#endif
+
+#if (CONFIG_IFACE_NUMBER > 2)
+	#define CONFIG_MI_WITH_MBSSID_CAM
+
+	#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		#define CONFIG_MBSSID_CAM
+		#if defined(CONFIG_RUNTIME_PORT_SWITCH)
+			#undef CONFIG_RUNTIME_PORT_SWITCH
+		#endif
+	#endif
+
+	#ifdef CONFIG_AP_MODE
+		#define CONFIG_SWTIMER_BASED_TXBCN
+		/*#define CONFIG_FW_BASED_BCN*/
+	#endif
+#endif
+
+#define MACID_NUM_SW_LIMIT 32
+#define SEC_CAM_ENT_NUM_SW_LIMIT 32
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
+	#define CONFIG_IEEE80211_BAND_5GHZ
+#endif
+
+#if defined(CONFIG_WOWLAN) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+	#define CONFIG_WOW_PATTERN_HW_CAM
+#endif
+
+/*
+	Mark CONFIG_DEAUTH_BEFORE_CONNECT by Arvin 2015/07/20
+	If the failure of Wi-Fi connection is due to some irregular disconnection behavior (like unplug dongle,
+	power down etc.) in last time, we can unmark this flag to avoid some unpredictable response from AP.
+*/
+/*#define CONFIG_DEAUTH_BEFORE_CONNECT */
+
+/*#define CONFIG_WEXT_DONT_JOIN_BYSSID	*/
+/* #include <rtl871x_byteorder.h> */
+
+
+/*#define CONFIG_DOSCAN_IN_BUSYTRAFFIC	*/
+
+/*Don't release SDIO irq in suspend/resume procedure*/
+#define CONFIG_RTW_SDIO_KEEP_IRQ	0
+
+/*
+ * Add by Lucas@2016/02/15
+ * For RX Aggregation
+ */
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_RX_AGGREGATION)
+	#define RTW_RX_AGGREGATION
+#endif /* CONFIG_SDIO_HCI || CONFIG_USB_RX_AGGREGATION */
+
+#ifdef CONFIG_RTW_HOSTAPD_ACS
+	#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
+		#ifndef CONFIG_FIND_BEST_CHANNEL
+			#define CONFIG_FIND_BEST_CHANNEL
+		#endif
+	#else
+		#ifdef CONFIG_FIND_BEST_CHANNEL
+			#undef CONFIG_FIND_BEST_CHANNEL
+		#endif
+		#ifndef CONFIG_RTW_ACS
+			#define CONFIG_RTW_ACS
+		#endif
+		#ifndef CONFIG_BACKGROUND_NOISE_MONITOR
+			#define CONFIG_BACKGROUND_NOISE_MONITOR
+		#endif
+	#endif
+#endif
+
+#ifdef CONFIG_RTW_80211K
+	#ifndef CONFIG_RTW_ACS
+		#define CONFIG_RTW_ACS
+	#endif
+#endif /*CONFIG_RTW_80211K*/
+
+#ifdef DBG_CONFIG_ERROR_RESET
+#ifndef CONFIG_IPS
+#define CONFIG_IPS
+#endif
+#endif
+#endif /* __DRV_CONF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types.h
new file mode 100644
index 000000000000..37f8fc72902a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types.h
@@ -0,0 +1,1721 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_conf.h>
+#include <basic_types.h>
+#include <osdep_service.h>
+#include <rtw_byteorder.h>
+#include <wlan_bssdef.h>
+#include <wifi.h>
+#include <ieee80211.h>
+#ifdef CONFIG_ARP_KEEP_ALIVE
+	#include <net/neighbour.h>
+	#include <net/arp.h>
+#endif
+
+#ifdef PLATFORM_OS_XP
+	#include <drv_types_xp.h>
+#endif
+
+#ifdef PLATFORM_OS_CE
+	#include <drv_types_ce.h>
+#endif
+
+#ifdef PLATFORM_LINUX
+	#include <drv_types_linux.h>
+#endif
+
+enum _NIC_VERSION {
+
+	RTL8711_NIC,
+	RTL8712_NIC,
+	RTL8713_NIC,
+	RTL8716_NIC
+
+};
+
+typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;
+
+#include <rtw_debug.h>
+#include <cmn_info/rtw_sta_info.h>
+#include <rtw_rf.h>
+
+#ifdef CONFIG_80211N_HT
+	#include <rtw_ht.h>
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+	#include <rtw_vht.h>
+#endif
+
+#ifdef CONFIG_INTEL_WIDI
+	#include <rtw_intel_widi.h>
+#endif
+
+#include <rtw_cmd.h>
+#include <cmd_osdep.h>
+#include <rtw_security.h>
+#include <rtw_xmit.h>
+#include <xmit_osdep.h>
+#include <rtw_recv.h>
+#include <rtw_rm.h>
+
+#ifdef CONFIG_BEAMFORMING
+	#include <rtw_beamforming.h>
+#endif
+
+#include <recv_osdep.h>
+#include <rtw_efuse.h>
+#include <rtw_sreset.h>
+#include <hal_intf.h>
+#include <hal_com.h>
+#include<hal_com_h2c.h>
+#include <hal_com_led.h>
+#include "../hal/hal_dm.h"
+#include <rtw_qos.h>
+#include <rtw_pwrctrl.h>
+#include <rtw_mlme.h>
+#include <mlme_osdep.h>
+#include <rtw_io.h>
+#include <rtw_ioctl.h>
+#include <rtw_ioctl_set.h>
+#include <rtw_ioctl_query.h>
+#include <rtw_ioctl_rtl.h>
+#include <osdep_intf.h>
+#include <rtw_eeprom.h>
+#include <sta_info.h>
+#include <rtw_event.h>
+#include <rtw_mlme_ext.h>
+#include <rtw_mi.h>
+#include <rtw_ap.h>
+#ifdef CONFIG_RTW_MESH
+#include "../core/mesh/rtw_mesh.h"
+#endif
+#include <rtw_efuse.h>
+#include <rtw_version.h>
+#include <rtw_odm.h>
+
+#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+	#include <rtw_mem.h>
+#endif
+
+#include <rtw_p2p.h>
+
+#ifdef CONFIG_TDLS
+	#include <rtw_tdls.h>
+#endif /* CONFIG_TDLS */
+
+#ifdef CONFIG_WAPI_SUPPORT
+	#include <rtw_wapi.h>
+#endif /* CONFIG_WAPI_SUPPORT */
+
+#ifdef CONFIG_MP_INCLUDED
+	#include <rtw_mp.h>
+#endif /* CONFIG_MP_INCLUDED */
+
+#ifdef CONFIG_BR_EXT
+	#include <rtw_br_ext.h>
+#endif /* CONFIG_BR_EXT */
+
+#ifdef CONFIG_IOL
+	#include <rtw_iol.h>
+#endif /* CONFIG_IOL */
+
+#include <ip.h>
+#include <if_ether.h>
+#include <ethernet.h>
+#include <circ_buf.h>
+
+#include <rtw_android.h>
+
+#include <rtw_btcoex_wifionly.h>
+#include <rtw_btcoex.h>
+
+#ifdef CONFIG_MCC_MODE
+	#include <rtw_mcc.h>
+#endif /*CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	#include <rtw_rson.h>
+#endif /*CONFIG_RTW_REPEATER_SON */
+
+#define SPEC_DEV_ID_NONE BIT(0)
+#define SPEC_DEV_ID_DISABLE_HT BIT(1)
+#define SPEC_DEV_ID_ENABLE_PS BIT(2)
+#define SPEC_DEV_ID_RF_CONFIG_1T1R BIT(3)
+#define SPEC_DEV_ID_RF_CONFIG_2T2R BIT(4)
+#define SPEC_DEV_ID_ASSIGN_IFNAME BIT(5)
+
+struct specific_device_id {
+
+	u32		flags;
+
+	u16		idVendor;
+	u16		idProduct;
+
+};
+
+struct registry_priv {
+	u8	chip_version;
+	u8	rfintfs;
+	u8	lbkmode;
+	u8	hci;
+	NDIS_802_11_SSID	ssid;
+	u8	network_mode;	/* infra, ad-hoc, auto */
+	u8	channel;/* ad-hoc support requirement */
+	u8	wireless_mode;/* A, B, G, auto */
+	u8	scan_mode;/* active, passive */
+	u8	radio_enable;
+	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	lps_level;
+	u8	smart_ps;
+#ifdef CONFIG_WMMPS_STA
+	u8	wmm_smart_ps;
+#endif /* CONFIG_WMMPS_STA */
+	u8   usb_rxagg_mode;
+	u8	dynamic_agg_enable;
+	u8	long_retry_lmt;
+	u8	short_retry_lmt;
+	u16	busy_thresh;
+	u8	ack_policy;
+	u8	mp_mode;
+#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
+	u8 mp_customer_str;
+#endif
+	u8  mp_dm;
+	u8	software_encrypt;
+	u8	software_decrypt;
+#ifdef CONFIG_TX_EARLY_MODE
+	u8   early_mode;
+#endif
+	u8	acm_method;
+	/* WMM */
+	u8	wmm_enable;
+#ifdef CONFIG_WMMPS_STA
+	/* uapsd (unscheduled automatic power-save delivery) = a kind of wmmps */
+	u8	uapsd_max_sp_len;
+	/* BIT0: AC_VO UAPSD, BIT1: AC_VI UAPSD, BIT2: AC_BK UAPSD, BIT3: AC_BE UAPSD */
+	u8	uapsd_ac_enable;
+#endif /* CONFIG_WMMPS_STA */
+
+	WLAN_BSSID_EX    dev_network;
+
+	u8 tx_bw_mode;
+#ifdef CONFIG_AP_MODE
+	u8 bmc_tx_rate;
+#endif
+#ifdef CONFIG_80211N_HT
+	u8	ht_enable;
+	/* 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz */
+	/* 2.4G use bit 0 ~ 3, 5G use bit 4 ~ 7 */
+	/* 0x21 means enable 2.4G 40MHz & 5G 80MHz */
+	u8	bw_mode;
+	u8	ampdu_enable;/* for tx */
+	u8	rx_stbc;
+	u8	rx_ampdu_amsdu;/* Rx A-MPDU Supports A-MSDU is permitted */
+	u8	tx_ampdu_amsdu;/* Tx A-MPDU Supports A-MSDU is permitted */
+	u8 rx_ampdu_sz_limit_by_nss_bw[4][4]; /* 1~4SS, BW20~BW160 */
+	/* Short GI support Bit Map */
+	/* BIT0 - 20MHz, 1: support, 0: non-support */
+	/* BIT1 - 40MHz, 1: support, 0: non-support */
+	/* BIT2 - 80MHz, 1: support, 0: non-support */
+	/* BIT3 - 160MHz, 1: support, 0: non-support */
+	u8	short_gi;
+	/* BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx */
+	u8	ldpc_cap;
+	/* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
+	u8	stbc_cap;
+	/*
+	 * BIT0: Enable VHT SU Beamformer
+	 * BIT1: Enable VHT SU Beamformee
+	 * BIT2: Enable VHT MU Beamformer, depend on VHT SU Beamformer
+	 * BIT3: Enable VHT MU Beamformee, depend on VHT SU Beamformee
+	 * BIT4: Enable HT Beamformer
+	 * BIT5: Enable HT Beamformee
+	 */
+	u8	beamform_cap;
+	u8	beamformer_rf_num;
+	u8	beamformee_rf_num;
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_80211AC_VHT
+	u8	vht_enable; /* 0:disable, 1:enable, 2:auto */
+	u8	ampdu_factor;
+	u8 vht_rx_mcs_map[2];
+#endif /* CONFIG_80211AC_VHT */
+
+	u8	lowrate_two_xmit;
+
+	u8	rf_config ;
+	u8	low_power ;
+
+	u8	wifi_spec;/* !turbo_mode */
+	u8	special_rf_path; /* 0: 2T2R ,1: only turn on path A 1T1R */
+	char alpha2[2];
+	u8	channel_plan;
+	u8	excl_chs[MAX_CHANNEL_NUM];
+	u8	full_ch_in_p2p_handshake; /* 0: reply only softap channel, 1: reply full channel list*/
+
+#ifdef CONFIG_BT_COEXIST
+	u8	btcoex;
+	u8	bt_iso;
+	u8	bt_sco;
+	u8	bt_ampdu;
+	u8	ant_num;
+	u8	single_ant_path;
+#endif
+	BOOLEAN	bAcceptAddbaReq;
+
+	u8	antdiv_cfg;
+	u8	antdiv_type;
+	u8	drv_ant_band_switch;
+
+	u8	switch_usb_mode;
+
+	u8	usbss_enable;/* 0:disable,1:enable */
+	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 */
+
+#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
+	char	adaptor_info_caching_file_path[PATH_LENGTH_MAX];
+#endif
+
+#ifdef CONFIG_LAYER2_ROAMING
+	u8	max_roaming_times; /* the max number driver will try to roaming */
+#endif
+
+#ifdef CONFIG_IOL
+	u8 fw_iol; /* enable iol without other concern */
+#endif
+
+#ifdef CONFIG_80211D
+	u8 enable80211d;
+#endif
+
+	u8 ifname[16];
+	u8 if2name[16];
+
+	u8 notch_filter;
+
+	/* for pll reference clock selction */
+	u8 pll_ref_clk_sel;
+
+	/* define for tx power adjust */
+#ifdef CONFIG_TXPWR_LIMIT
+	u8	RegEnableTxPowerLimit;
+#endif
+	u8	RegEnableTxPowerByRate;
+
+	u8 target_tx_pwr_valid;
+	s8 target_tx_pwr_2g[RF_PATH_MAX][RATE_SECTION_NUM];
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	s8 target_tx_pwr_5g[RF_PATH_MAX][RATE_SECTION_NUM - 1];
+#endif
+
+	s8	TxBBSwing_2G;
+	s8	TxBBSwing_5G;
+	u8	AmplifierType_2G;
+	u8	AmplifierType_5G;
+	u8	bEn_RFE;
+	u8	RFE_Type;
+	u8	PowerTracking_Type;
+	u8	GLNA_Type;
+	u8  check_fw_ps;
+	u8	RegPwrTrimEnable;
+
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	u8	load_phy_file;
+	u8	RegDecryptCustomFile;
+#endif
+#ifdef CONFIG_CONCURRENT_MODE
+	u8 virtual_iface_num;
+#endif
+	u8 qos_opt_enable;
+
+	u8 hiq_filter;
+	u8 adaptivity_en;
+	u8 adaptivity_mode;
+	u8 adaptivity_dml;
+	u8 adaptivity_dc_backoff;
+	s8 adaptivity_th_l2h_ini;
+	s8 adaptivity_th_edcca_hl_diff;
+
+	u8 boffefusemask;
+	BOOLEAN bFileMaskEfuse;
+#ifdef CONFIG_RTW_ACS
+	u8 acs_auto_scan;
+	u8 acs_mode;
+#endif
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	u8 nm_mode;
+#endif
+	u32	reg_rxgain_offset_2g;
+	u32	reg_rxgain_offset_5gl;
+	u32	reg_rxgain_offset_5gm;
+	u32	reg_rxgain_offset_5gh;
+
+#ifdef CONFIG_DFS_MASTER
+	u8 dfs_region_domain;
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	u8 en_mcc;
+	u32 rtw_mcc_single_tx_cri;
+	u32 rtw_mcc_ap_bw20_target_tx_tp;
+	u32 rtw_mcc_ap_bw40_target_tx_tp;
+	u32 rtw_mcc_ap_bw80_target_tx_tp;
+	u32 rtw_mcc_sta_bw20_target_tx_tp;
+	u32 rtw_mcc_sta_bw40_target_tx_tp;
+	u32 rtw_mcc_sta_bw80_target_tx_tp;
+	s8 rtw_mcc_policy_table_idx;
+	u8 rtw_mcc_duration;
+	u8 rtw_mcc_enable_runtime_duration;
+#endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_NAPI
+	u8 en_napi;
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	u32 napi_threshold;	/* unit: Mbps */
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#ifdef CONFIG_RTW_GRO
+	u8 en_gro;
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+#ifdef CONFIG_WOWLAN
+	u8 wakeup_event;
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	u8 trx_share_mode;
+#endif
+	u8 check_hw_status;
+
+	u32 pci_aspm_config;
+
+	u8 iqk_fw_offload;
+	u8 ch_switch_offload;
+
+#ifdef CONFIG_TDLS
+	u8 en_tdls;
+#endif
+
+#ifdef CONFIG_ADVANCE_OTA
+	u8	adv_ota;
+#endif
+
+#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+	u8 fw_param_init;
+#endif
+#ifdef CONFIG_DYNAMIC_SOML
+	u8 dyn_soml_en;
+	u8 dyn_soml_train_num;
+	u8 dyn_soml_interval;
+	u8 dyn_soml_period;
+	u8 dyn_soml_delay;
+#endif
+};
+
+/* For registry parameters */
+#define RGTRY_OFT(field) ((ULONG)FIELD_OFFSET(struct registry_priv, field))
+#define RGTRY_SZ(field)   sizeof(((struct registry_priv *) 0)->field)
+
+#define GetRegAmplifierType2G(_Adapter)	(_Adapter->registrypriv.AmplifierType_2G)
+#define GetRegAmplifierType5G(_Adapter)	(_Adapter->registrypriv.AmplifierType_5G)
+
+#define GetRegTxBBSwing_2G(_Adapter)	(_Adapter->registrypriv.TxBBSwing_2G)
+#define GetRegTxBBSwing_5G(_Adapter)	(_Adapter->registrypriv.TxBBSwing_5G)
+
+#define GetRegbENRFEType(_Adapter)	(_Adapter->registrypriv.bEn_RFE)
+#define GetRegRFEType(_Adapter)	(_Adapter->registrypriv.RFE_Type)
+#define GetRegGLNAType(_Adapter)	(_Adapter->registrypriv.GLNA_Type)
+#define GetRegPowerTrackingType(_Adapter)	(_Adapter->registrypriv.PowerTracking_Type)
+
+#define BSSID_OFT(field) ((ULONG)FIELD_OFFSET(WLAN_BSSID_EX, field))
+#define BSSID_SZ(field)   sizeof(((PWLAN_BSSID_EX) 0)->field)
+
+#define BW_MODE_2G(bw_mode) ((bw_mode) & 0x0F)
+#define BW_MODE_5G(bw_mode) ((bw_mode) >> 4)
+#define REGSTY_BW_2G(regsty) BW_MODE_2G((regsty)->bw_mode)
+#define REGSTY_BW_5G(regsty) BW_MODE_5G((regsty)->bw_mode)
+#define REGSTY_IS_BW_2G_SUPPORT(regsty, bw) (REGSTY_BW_2G((regsty)) >= (bw))
+#define REGSTY_IS_BW_5G_SUPPORT(regsty, bw) (REGSTY_BW_5G((regsty)) >= (bw))
+
+#define REGSTY_IS_11AC_ENABLE(regsty) ((regsty)->vht_enable != 0)
+#define REGSTY_IS_11AC_AUTO(regsty) ((regsty)->vht_enable == 2)
+
+typedef struct rtw_if_operations {
+	int __must_check (*read)(struct dvobj_priv *d, unsigned int addr, void *buf,
+				size_t len, bool fixed);
+	int __must_check (*write)(struct dvobj_priv *d, unsigned int addr, void *buf,
+				 size_t len, bool fixed);
+} RTW_IF_OPS, *PRTW_IF_OPS;
+
+#ifdef CONFIG_SDIO_HCI
+	#include <drv_types_sdio.h>
+	#define INTF_DATA	SDIO_DATA
+	#define INTF_OPS	PRTW_IF_OPS
+#elif defined(CONFIG_GSPI_HCI)
+	#include <drv_types_gspi.h>
+	#define INTF_DATA GSPI_DATA
+#elif defined(CONFIG_PCI_HCI)
+	#include <drv_types_pci.h>
+#endif
+
+#ifdef CONFIG_CONCURRENT_MODE
+	#define is_primary_adapter(adapter) (adapter->adapter_type == PRIMARY_ADAPTER)
+	#define is_vir_adapter(adapter) (adapter->adapter_type == VIRTUAL_ADAPTER)
+	#define get_hw_port(adapter) (adapter->hw_port)
+#else
+	#define is_primary_adapter(adapter) (1)
+	#define is_vir_adapter(adapter) (0)
+	#define get_hw_port(adapter) (HW_PORT0)
+#endif
+#define GET_PRIMARY_ADAPTER(padapter) (((_adapter *)padapter)->dvobj->padapters[IFACE_ID0])
+#define GET_IFACE_NUMS(padapter) (((_adapter *)padapter)->dvobj->iface_nums)
+#define GET_ADAPTER(padapter, iface_id) (((_adapter *)padapter)->dvobj->padapters[iface_id])
+
+#define GetDefaultAdapter(padapter)	padapter
+
+enum _IFACE_ID {
+	IFACE_ID0, /*PRIMARY_ADAPTER*/
+	IFACE_ID1,
+	IFACE_ID2,
+	IFACE_ID3,
+	IFACE_ID4,
+	IFACE_ID5,
+	IFACE_ID6,
+	IFACE_ID7,
+	IFACE_ID_MAX,
+};
+
+#define VIF_START_ID	1
+
+#ifdef CONFIG_DBG_COUNTER
+
+struct rx_logs {
+	u32 intf_rx;
+	u32 intf_rx_err_recvframe;
+	u32 intf_rx_err_skb;
+	u32 intf_rx_report;
+	u32 core_rx;
+	u32 core_rx_pre;
+	u32 core_rx_pre_ver_err;
+	u32 core_rx_pre_mgmt;
+	u32 core_rx_pre_mgmt_err_80211w;
+	u32 core_rx_pre_mgmt_err;
+	u32 core_rx_pre_ctrl;
+	u32 core_rx_pre_ctrl_err;
+	u32 core_rx_pre_data;
+	u32 core_rx_pre_data_wapi_seq_err;
+	u32 core_rx_pre_data_wapi_key_err;
+	u32 core_rx_pre_data_handled;
+	u32 core_rx_pre_data_err;
+	u32 core_rx_pre_data_unknown;
+	u32 core_rx_pre_unknown;
+	u32 core_rx_enqueue;
+	u32 core_rx_dequeue;
+	u32 core_rx_post;
+	u32 core_rx_post_decrypt;
+	u32 core_rx_post_decrypt_wep;
+	u32 core_rx_post_decrypt_tkip;
+	u32 core_rx_post_decrypt_aes;
+	u32 core_rx_post_decrypt_wapi;
+	u32 core_rx_post_decrypt_hw;
+	u32 core_rx_post_decrypt_unknown;
+	u32 core_rx_post_decrypt_err;
+	u32 core_rx_post_defrag_err;
+	u32 core_rx_post_portctrl_err;
+	u32 core_rx_post_indicate;
+	u32 core_rx_post_indicate_in_oder;
+	u32 core_rx_post_indicate_reoder;
+	u32 core_rx_post_indicate_err;
+	u32 os_indicate;
+	u32 os_indicate_ap_mcast;
+	u32 os_indicate_ap_forward;
+	u32 os_indicate_ap_self;
+	u32 os_indicate_err;
+	u32 os_netif_ok;
+	u32 os_netif_err;
+};
+
+struct tx_logs {
+	u32 os_tx;
+	u32 os_tx_err_up;
+	u32 os_tx_err_xmit;
+	u32 os_tx_m2u;
+	u32 os_tx_m2u_ignore_fw_linked;
+	u32 os_tx_m2u_ignore_self;
+	u32 os_tx_m2u_entry;
+	u32 os_tx_m2u_entry_err_xmit;
+	u32 os_tx_m2u_entry_err_skb;
+	u32 os_tx_m2u_stop;
+	u32 core_tx;
+	u32 core_tx_err_pxmitframe;
+	u32 core_tx_err_brtx;
+	u32 core_tx_upd_attrib;
+	u32 core_tx_upd_attrib_adhoc;
+	u32 core_tx_upd_attrib_sta;
+	u32 core_tx_upd_attrib_ap;
+	u32 core_tx_upd_attrib_unknown;
+	u32 core_tx_upd_attrib_dhcp;
+	u32 core_tx_upd_attrib_icmp;
+	u32 core_tx_upd_attrib_active;
+	u32 core_tx_upd_attrib_err_ucast_sta;
+	u32 core_tx_upd_attrib_err_ucast_ap_link;
+	u32 core_tx_upd_attrib_err_sta;
+	u32 core_tx_upd_attrib_err_link;
+	u32 core_tx_upd_attrib_err_sec;
+	u32 core_tx_ap_enqueue_warn_fwstate;
+	u32 core_tx_ap_enqueue_warn_sta;
+	u32 core_tx_ap_enqueue_warn_nosta;
+	u32 core_tx_ap_enqueue_warn_link;
+	u32 core_tx_ap_enqueue_warn_trigger;
+	u32 core_tx_ap_enqueue_mcast;
+	u32 core_tx_ap_enqueue_ucast;
+	u32 core_tx_ap_enqueue;
+	u32 intf_tx;
+	u32 intf_tx_pending_ac;
+	u32 intf_tx_pending_fw_under_survey;
+	u32 intf_tx_pending_fw_under_linking;
+	u32 intf_tx_pending_xmitbuf;
+	u32 intf_tx_enqueue;
+	u32 core_tx_enqueue;
+	u32 core_tx_enqueue_class;
+	u32 core_tx_enqueue_class_err_sta;
+	u32 core_tx_enqueue_class_err_nosta;
+	u32 core_tx_enqueue_class_err_fwlink;
+	u32 intf_tx_direct;
+	u32 intf_tx_direct_err_coalesce;
+	u32 intf_tx_dequeue;
+	u32 intf_tx_dequeue_err_coalesce;
+	u32 intf_tx_dump_xframe;
+	u32 intf_tx_dump_xframe_err_txdesc;
+	u32 intf_tx_dump_xframe_err_port;
+};
+
+struct int_logs {
+	u32 all;
+	u32 err;
+	u32 tbdok;
+	u32 tbder;
+	u32 bcnderr;
+	u32 bcndma;
+	u32 bcndma_e;
+	u32 rx;
+	u32 rx_rdu;
+	u32 rx_fovw;
+	u32 txfovw;
+	u32 mgntok;
+	u32 highdok;
+	u32 bkdok;
+	u32 bedok;
+	u32 vidok;
+	u32 vodok;
+};
+
+#endif /* CONFIG_DBG_COUNTER */
+
+struct debug_priv {
+	u32 dbg_sdio_free_irq_error_cnt;
+	u32 dbg_sdio_alloc_irq_error_cnt;
+	u32 dbg_sdio_free_irq_cnt;
+	u32 dbg_sdio_alloc_irq_cnt;
+	u32 dbg_sdio_deinit_error_cnt;
+	u32 dbg_sdio_init_error_cnt;
+	u32 dbg_suspend_error_cnt;
+	u32 dbg_suspend_cnt;
+	u32 dbg_resume_cnt;
+	u32 dbg_resume_error_cnt;
+	u32 dbg_deinit_fail_cnt;
+	u32 dbg_carddisable_cnt;
+	u32 dbg_carddisable_error_cnt;
+	u32 dbg_ps_insuspend_cnt;
+	u32	dbg_dev_unload_inIPS_cnt;
+	u32 dbg_wow_leave_ps_fail_cnt;
+	u32 dbg_scan_pwr_state_cnt;
+	u32 dbg_downloadfw_pwr_state_cnt;
+	u32 dbg_fw_read_ps_state_fail_cnt;
+	u32 dbg_leave_ips_fail_cnt;
+	u32 dbg_leave_lps_fail_cnt;
+	u32 dbg_h2c_leave32k_fail_cnt;
+	u32 dbg_diswow_dload_fw_fail_cnt;
+	u32 dbg_enwow_dload_fw_fail_cnt;
+	u32 dbg_ips_drvopen_fail_cnt;
+	u32 dbg_poll_fail_cnt;
+	u32 dbg_rpwm_toogle_cnt;
+	u32 dbg_rpwm_timeout_fail_cnt;
+	u32 dbg_sreset_cnt;
+	u32 dbg_fw_mem_dl_error_cnt;
+	u64 dbg_rx_fifo_last_overflow;
+	u64 dbg_rx_fifo_curr_overflow;
+	u64 dbg_rx_fifo_diff_overflow;
+};
+
+struct rtw_traffic_statistics {
+	/* tx statistics */
+	u64	tx_bytes;
+	u64	tx_pkts;
+	u64	tx_drop;
+	u64	cur_tx_bytes;
+	u64	last_tx_bytes;
+	u32	cur_tx_tp; /* Tx throughput in MBps. */
+
+	/* rx statistics */
+	u64	rx_bytes;
+	u64	rx_pkts;
+	u64	rx_drop;
+	u64	cur_rx_bytes;
+	u64	last_rx_bytes;
+	u32	cur_rx_tp; /* Rx throughput in MBps. */
+};
+
+#define SEC_CAP_CHK_BMC	BIT0
+
+#define SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH	BIT0
+
+struct sec_cam_bmp {
+	u32 m0;
+#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
+	u32 m1;
+#endif
+#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
+	u32 m2;
+#endif
+#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
+	u32 m3;
+#endif
+};
+
+struct cam_ctl_t {
+	_lock lock;
+
+	u8 sec_cap;
+	u32 flags;
+
+	u8 num;
+	struct sec_cam_bmp used;
+
+	_mutex sec_cam_access_mutex;
+};
+
+struct sec_cam_ent {
+	u16 ctrl;
+	u8 mac[ETH_ALEN];
+	u8 key[16];
+};
+
+#define KEY_FMT "%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
+#define KEY_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
+	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9], ((u8 *)(x))[10], ((u8 *)(x))[11], \
+	((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15]
+
+#define RTW_DEFAULT_MGMT_MACID 1
+
+struct macid_bmp {
+	u32 m0;
+#if (MACID_NUM_SW_LIMIT > 32)
+	u32 m1;
+#endif
+#if (MACID_NUM_SW_LIMIT > 64)
+	u32 m2;
+#endif
+#if (MACID_NUM_SW_LIMIT > 96)
+	u32 m3;
+#endif
+};
+
+struct macid_ctl_t {
+	_lock lock;
+	u8 num;
+	struct macid_bmp used;
+	struct macid_bmp bmc;
+	struct macid_bmp if_g[CONFIG_IFACE_NUMBER];
+	struct macid_bmp ch_g[2]; /* 2 ch concurrency */
+
+	u8 iface_bmc[CONFIG_IFACE_NUMBER]; /* bmc TX macid for each iface*/
+
+	u8 h2c_msr[MACID_NUM_SW_LIMIT];
+	u8 bw[MACID_NUM_SW_LIMIT];
+	u8 vht_en[MACID_NUM_SW_LIMIT];
+	u32 rate_bmp0[MACID_NUM_SW_LIMIT];
+	u32 rate_bmp1[MACID_NUM_SW_LIMIT];
+
+	struct sta_info *sta[MACID_NUM_SW_LIMIT]; /* corresponding stainfo when macid is not shared */
+
+	/* macid sleep registers */
+	u16 reg_sleep_m0;
+#if (MACID_NUM_SW_LIMIT > 32)
+	u16 reg_sleep_m1;
+#endif
+#if (MACID_NUM_SW_LIMIT > 64)
+	u16 reg_sleep_m2;
+#endif
+#if (MACID_NUM_SW_LIMIT > 96)
+	u16 reg_sleep_m3;
+#endif
+};
+
+/* used for rf_ctl_t.rate_bmp_cck_ofdm */
+#define RATE_BMP_CCK		0x000F
+#define RATE_BMP_OFDM		0xFFF0
+#define RATE_BMP_HAS_CCK(_bmp_cck_ofdm)		(_bmp_cck_ofdm & RATE_BMP_CCK)
+#define RATE_BMP_HAS_OFDM(_bmp_cck_ofdm)	(_bmp_cck_ofdm & RATE_BMP_OFDM)
+#define RATE_BMP_GET_CCK(_bmp_cck_ofdm)		(_bmp_cck_ofdm & RATE_BMP_CCK)
+#define RATE_BMP_GET_OFDM(_bmp_cck_ofdm)	((_bmp_cck_ofdm & RATE_BMP_OFDM) >> 4)
+
+/* used for rf_ctl_t.rate_bmp_ht_by_bw */
+#define RATE_BMP_HT_1SS		0x000000FF
+#define RATE_BMP_HT_2SS		0x0000FF00
+#define RATE_BMP_HT_3SS		0x00FF0000
+#define RATE_BMP_HT_4SS		0xFF000000
+#define RATE_BMP_HAS_HT_1SS(_bmp_ht)		(_bmp_ht & RATE_BMP_HT_1SS)
+#define RATE_BMP_HAS_HT_2SS(_bmp_ht)		(_bmp_ht & RATE_BMP_HT_2SS)
+#define RATE_BMP_HAS_HT_3SS(_bmp_ht)		(_bmp_ht & RATE_BMP_HT_3SS)
+#define RATE_BMP_HAS_HT_4SS(_bmp_ht)		(_bmp_ht & RATE_BMP_HT_4SS)
+#define RATE_BMP_GET_HT_1SS(_bmp_ht)		(_bmp_ht & RATE_BMP_HT_1SS)
+#define RATE_BMP_GET_HT_2SS(_bmp_ht)		((_bmp_ht & RATE_BMP_HT_2SS) >> 8)
+#define RATE_BMP_GET_HT_3SS(_bmp_ht)		((_bmp_ht & RATE_BMP_HT_3SS) >> 16)
+#define RATE_BMP_GET_HT_4SS(_bmp_ht)		((_bmp_ht & RATE_BMP_HT_4SS) >> 24)
+
+/* used for rf_ctl_t.rate_bmp_vht_by_bw */
+#define RATE_BMP_VHT_1SS	0x000003FF
+#define RATE_BMP_VHT_2SS	0x000FFC00
+#define RATE_BMP_VHT_3SS	0x3FF00000
+#define RATE_BMP_HAS_VHT_1SS(_bmp_vht)		(_bmp_vht & RATE_BMP_VHT_1SS)
+#define RATE_BMP_HAS_VHT_2SS(_bmp_vht)		(_bmp_vht & RATE_BMP_VHT_2SS)
+#define RATE_BMP_HAS_VHT_3SS(_bmp_vht)		(_bmp_vht & RATE_BMP_VHT_3SS)
+#define RATE_BMP_GET_VHT_1SS(_bmp_vht)		(_bmp_vht & RATE_BMP_VHT_1SS)
+#define RATE_BMP_GET_VHT_2SS(_bmp_vht)		((_bmp_vht & RATE_BMP_VHT_2SS) >> 10)
+#define RATE_BMP_GET_VHT_3SS(_bmp_vht)		((_bmp_vht & RATE_BMP_VHT_3SS) >> 20)
+
+#define TXPWR_LMT_REF_VHT_FROM_HT	BIT0
+#define TXPWR_LMT_REF_HT_FROM_VHT	BIT1
+
+#define TXPWR_LMT_HAS_CCK_1T	BIT0
+#define TXPWR_LMT_HAS_CCK_2T	BIT1
+#define TXPWR_LMT_HAS_CCK_3T	BIT2
+#define TXPWR_LMT_HAS_CCK_4T	BIT3
+#define TXPWR_LMT_HAS_OFDM_1T	BIT4
+#define TXPWR_LMT_HAS_OFDM_2T	BIT5
+#define TXPWR_LMT_HAS_OFDM_3T	BIT6
+#define TXPWR_LMT_HAS_OFDM_4T	BIT7
+
+#define OFFCHS_NONE			0
+#define OFFCHS_LEAVING_OP	1
+#define OFFCHS_LEAVE_OP		2
+#define OFFCHS_BACKING_OP	3
+
+struct rf_ctl_t {
+	const struct country_chplan *country_ent;
+	u8 ChannelPlan;
+	u8 max_chan_nums;
+	RT_CHANNEL_INFO channel_set[MAX_CHANNEL_NUM];
+	struct p2p_channels channel_list;
+
+	_mutex offch_mutex;
+	u8 offch_state;
+
+	/* used for debug or by tx power limit */
+	u16 rate_bmp_cck_ofdm;		/* 20MHz */
+	u32 rate_bmp_ht_by_bw[2];	/* 20MHz, 40MHz. 4SS supported */
+	u32 rate_bmp_vht_by_bw[4];	/* 20MHz, 40MHz, 80MHz, 160MHz. up to 3SS supported */
+
+	/* used by tx power limit */
+	u8 highest_ht_rate_bw_bmp;
+	u8 highest_vht_rate_bw_bmp;
+
+#ifdef CONFIG_TXPWR_LIMIT
+	_mutex txpwr_lmt_mutex;
+	_list reg_exc_list;
+	u8 regd_exc_num;
+	_list txpwr_lmt_list;
+	u8 txpwr_regd_num;
+	const char *regd_name;
+
+	u8 txpwr_lmt_2g_cck_ofdm_state;
+	#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	u8 txpwr_lmt_5g_cck_ofdm_state;
+	u8 txpwr_lmt_5g_20_40_ref;
+	#endif
+#endif
+
+	u8 ch_sel_same_band_prefer;
+
+#ifdef CONFIG_DFS_MASTER
+	bool radar_detect_by_others;
+	u8 dfs_master_enabled;
+	bool radar_detected;
+
+	u8 radar_detect_ch;
+	u8 radar_detect_bw;
+	u8 radar_detect_offset;
+
+	systime cac_start_time;
+	systime cac_end_time;
+	u8 cac_force_stop;
+
+	u8 dfs_ch_sel_d_flags;
+
+	u8 dbg_dfs_master_fake_radar_detect_cnt;
+	u8 dbg_dfs_master_radar_detect_trigger_non;
+	u8 dbg_dfs_master_choose_dfs_ch_first;
+#endif
+};
+
+#define RTW_CAC_STOPPED 0
+#ifdef CONFIG_DFS_MASTER
+#define IS_CAC_STOPPED(rfctl) ((rfctl)->cac_end_time == RTW_CAC_STOPPED)
+#define IS_CH_WAITING(rfctl) (!IS_CAC_STOPPED(rfctl) && rtw_time_after((rfctl)->cac_end_time, rtw_get_current_time()))
+#define IS_UNDER_CAC(rfctl) (IS_CH_WAITING(rfctl) && rtw_time_after(rtw_get_current_time(), (rfctl)->cac_start_time))
+#else
+#define IS_CAC_STOPPED(rfctl) 1
+#define IS_CH_WAITING(rfctl) 0
+#define IS_UNDER_CAC(rfctl) 0
+#endif /* CONFIG_DFS_MASTER */
+
+#ifdef CONFIG_MBSSID_CAM
+#define TOTAL_MBID_CAM_NUM	8
+#define INVALID_CAM_ID			0xFF
+struct mbid_cam_ctl_t {
+	_lock lock;
+	u8 bitmap;
+	ATOMIC_T mbid_entry_num;
+};
+struct mbid_cam_cache {
+	u8 iface_id;
+	/*u8 role;*/ /*WIFI_STATION_STATE or WIFI_AP_STATE*/
+	u8 mac_addr[ETH_ALEN];
+};
+#endif /*CONFIG_MBSSID_CAM*/
+
+#ifdef RTW_HALMAC
+struct halmac_indicator {
+	struct submit_ctx *sctx;
+	u8 *buffer;
+	u32 buf_size;
+	u32 ret_size;
+	u32 status;
+};
+
+struct halmacpriv {
+	/* flags */
+
+	/* For asynchronous functions */
+	struct halmac_indicator *indicator;
+
+	/* Hardware parameters */
+#ifdef CONFIG_SDIO_HCI
+	/* Store hardware tx queue page number setting */
+	u16 txpage[HW_QUEUE_ENTRY];
+#endif /* CONFIG_SDIO_HCI */
+};
+#endif /* RTW_HALMAC */
+
+struct dvobj_priv {
+	/*-------- below is common data --------*/
+	u8	chip_type;
+	u8	HardwareType;
+	u8	interface_type;/*USB,SDIO,SPI,PCI*/
+
+	ATOMIC_T	bSurpriseRemoved;
+	ATOMIC_T	bDriverStopped;
+
+	s32	processing_dev_remove;
+
+	struct debug_priv drv_dbg;
+
+	_mutex hw_init_mutex;
+	_mutex h2c_fwcmd_mutex;
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	_mutex customer_str_mutex;
+	struct submit_ctx *customer_str_sctx;
+	u8 customer_str[RTW_CUSTOMER_STR_LEN];
+#endif
+
+	_mutex setch_mutex;
+	_mutex setbw_mutex;
+	_mutex rf_read_reg_mutex;
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+	_mutex sd_indirect_access_mutex;
+#endif
+
+	unsigned char	oper_channel; /* saved channel info when call set_channel_bw */
+	unsigned char	oper_bwmode;
+	unsigned char	oper_ch_offset;/* PRIME_CHNL_OFFSET */
+	systime on_oper_ch_time;
+
+	_adapter *padapters[CONFIG_IFACE_NUMBER];/*IFACE_ID_MAX*/
+	u8 iface_nums; /* total number of ifaces used runtime */
+	struct mi_state iface_state;
+
+#ifdef CONFIG_AP_MODE
+	u8 nr_ap_if; /* total interface s number of ap/go mode. */
+	u16 inter_bcn_space; /* unit:ms */
+	_queue	ap_if_q;
+#ifdef CONFIG_RTW_REPEATER_SON
+	struct rtw_rson_struct  rson_data;
+#endif
+
+#endif
+
+	struct macid_ctl_t macid_ctl;
+
+	struct cam_ctl_t cam_ctl;
+	struct sec_cam_ent cam_cache[SEC_CAM_ENT_NUM_SW_LIMIT];
+
+#ifdef CONFIG_MBSSID_CAM
+	struct mbid_cam_ctl_t mbid_cam_ctl;
+	struct mbid_cam_cache mbid_cam_cache[TOTAL_MBID_CAM_NUM];
+#endif
+
+	struct rf_ctl_t rf_ctl;
+
+	/* For 92D, DMDP have 2 interface. */
+	u8	InterfaceNumber;
+	u8	NumInterfaces;
+
+	/* In /Out Pipe information */
+	int	RtInPipe[2];
+	int	RtOutPipe[4];
+	u8	Queue2Pipe[HW_QUEUE_ENTRY];/* for out pipe mapping */
+
+	u8	irq_alloc;
+	ATOMIC_T continual_io_error;
+
+	ATOMIC_T disable_func;
+
+	u8 xmit_block;
+	_lock xmit_block_lock;
+
+	struct pwrctrl_priv pwrctl_priv;
+
+	struct rtw_traffic_statistics	traffic_stat;
+
+#ifdef PLATFORM_LINUX
+	_thread_hdl_ rtnl_lock_holder;
+
+	#if defined(CONFIG_IOCTL_CFG80211) && defined(RTW_SINGLE_WIPHY)
+	struct wiphy *wiphy;
+	#endif
+#endif /* PLATFORM_LINUX */
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	_timer txbcn_timer;
+#endif
+	_timer dynamic_chk_timer; /* dynamic/periodic check timer */
+	
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	u8 en_napi_dynamic;
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+
+#ifdef RTW_HALMAC
+	void *halmac;
+	struct halmacpriv hmpriv;
+#endif /* RTW_HALMAC */
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	u8 default_port_id;
+#endif
+	/*-------- below is for SDIO INTERFACE --------*/
+
+#ifdef INTF_DATA
+	INTF_DATA intf_data;
+#endif
+#ifdef INTF_OPS
+	INTF_OPS intf_ops;
+#endif
+
+	/*-------- below is for USB INTERFACE --------*/
+
+#ifdef CONFIG_USB_HCI
+
+	u8	usb_speed; /* 1.1, 2.0 or 3.0 */
+	u8	nr_endpoint;
+	u8	RtNumInPipes;
+	u8	RtNumOutPipes;
+	int	ep_num[6]; /* endpoint number */
+
+	int	RegUsbSS;
+
+	_sema	usb_suspend_sema;
+
+#ifdef CONFIG_USB_VENDOR_REQ_MUTEX
+	_mutex  usb_vendor_req_mutex;
+#endif
+
+#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC
+	u8 *usb_alloc_vendor_req_buf;
+	u8 *usb_vendor_req_buf;
+#endif
+
+#ifdef PLATFORM_WINDOWS
+	/* related device objects */
+	PDEVICE_OBJECT	pphysdevobj;/* pPhysDevObj; */
+	PDEVICE_OBJECT	pfuncdevobj;/* pFuncDevObj; */
+	PDEVICE_OBJECT	pnextdevobj;/* pNextDevObj; */
+
+	u8	nextdevstacksz;/* unsigned char NextDeviceStackSize;	 */ /* = (CHAR)CEdevice->pUsbDevObj->StackSize + 1; */
+
+	/* urb for control diescriptor request */
+
+#ifdef PLATFORM_OS_XP
+	struct _URB_CONTROL_DESCRIPTOR_REQUEST descriptor_urb;
+	PUSB_CONFIGURATION_DESCRIPTOR	pconfig_descriptor;/* UsbConfigurationDescriptor; */
+#endif
+
+#ifdef PLATFORM_OS_CE
+	WCHAR			active_path[MAX_ACTIVE_REG_PATH];	/* adapter regpath */
+	USB_EXTENSION	usb_extension;
+
+	_nic_hdl		pipehdls_r8192c[0x10];
+#endif
+
+	u32	config_descriptor_len;/* ULONG UsbConfigurationDescriptorLength; */
+#endif/* PLATFORM_WINDOWS */
+
+#ifdef PLATFORM_LINUX
+	struct usb_interface *pusbintf;
+	struct usb_device *pusbdev;
+#endif/* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	struct usb_interface *pusbintf;
+	struct usb_device *pusbdev;
+#endif/* PLATFORM_FREEBSD */
+
+#endif/* CONFIG_USB_HCI */
+
+	/*-------- below is for PCIE INTERFACE --------*/
+
+#ifdef CONFIG_PCI_HCI
+
+#ifdef PLATFORM_LINUX
+	struct pci_dev *ppcidev;
+
+	/* PCI MEM map */
+	unsigned long	pci_mem_end;	/* shared mem end	*/
+	unsigned long	pci_mem_start;	/* shared mem start	*/
+
+	/* PCI IO map */
+	unsigned long	pci_base_addr;	/* device I/O address	*/
+
+#ifdef RTK_129X_PLATFORM
+	unsigned long	ctrl_start;
+	/* PCI MASK addr */
+	unsigned long	mask_addr;
+
+	/* PCI TRANSLATE addr */
+	unsigned long	tran_addr;
+
+	_lock   io_reg_lock;
+#endif
+
+	/* PciBridge */
+	struct pci_priv	pcipriv;
+
+	unsigned int irq; /* get from pci_dev.irq, store to net_device.irq */
+	u16	irqline;
+	u8	irq_enabled;
+	RT_ISR_CONTENT	isr_content;
+	_lock	irq_th_lock;
+
+	/* ASPM */
+	u8	const_pci_aspm;
+	u8	const_amdpci_aspm;
+	u8	const_hwsw_rfoff_d3;
+	u8	const_support_pciaspm;
+	/* pci-e bridge */
+	u8	const_hostpci_aspm_setting;
+	/* pci-e device */
+	u8	const_devicepci_aspm_setting;
+	u8	b_support_aspm; /* If it supports ASPM, Offset[560h] = 0x40, otherwise Offset[560h] = 0x00. */
+	u8	b_support_backdoor;
+	u8	bdma64;
+#endif/* PLATFORM_LINUX */
+
+#endif/* CONFIG_PCI_HCI */
+
+#ifdef CONFIG_MCC_MODE
+	struct mcc_obj_priv mcc_objpriv;
+#endif /*CONFIG_MCC_MODE */
+};
+
+#define DEV_STA_NUM(_dvobj)			MSTATE_STA_NUM(&((_dvobj)->iface_state))
+#define DEV_STA_LD_NUM(_dvobj)		MSTATE_STA_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_STA_LG_NUM(_dvobj)		MSTATE_STA_LG_NUM(&((_dvobj)->iface_state))
+#define DEV_TDLS_LD_NUM(_dvobj)		MSTATE_TDLS_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_AP_NUM(_dvobj)			MSTATE_AP_NUM(&((_dvobj)->iface_state))
+#define DEV_AP_STARTING_NUM(_dvobj)	MSTATE_AP_STARTING_NUM(&((_dvobj)->iface_state))
+#define DEV_AP_LD_NUM(_dvobj)		MSTATE_AP_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_ADHOC_NUM(_dvobj)		MSTATE_ADHOC_NUM(&((_dvobj)->iface_state))
+#define DEV_ADHOC_LD_NUM(_dvobj)	MSTATE_ADHOC_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_MESH_NUM(_dvobj)		MSTATE_MESH_NUM(&((_dvobj)->iface_state))
+#define DEV_MESH_LD_NUM(_dvobj)		MSTATE_MESH_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_SCAN_NUM(_dvobj)		MSTATE_SCAN_NUM(&((_dvobj)->iface_state))
+#define DEV_WPS_NUM(_dvobj)			MSTATE_WPS_NUM(&((_dvobj)->iface_state))
+#define DEV_ROCH_NUM(_dvobj)		MSTATE_ROCH_NUM(&((_dvobj)->iface_state))
+#define DEV_MGMT_TX_NUM(_dvobj)		MSTATE_MGMT_TX_NUM(&((_dvobj)->iface_state))
+#define DEV_U_CH(_dvobj)			MSTATE_U_CH(&((_dvobj)->iface_state))
+#define DEV_U_BW(_dvobj)			MSTATE_U_BW(&((_dvobj)->iface_state))
+#define DEV_U_OFFSET(_dvobj)		MSTATE_U_OFFSET(&((_dvobj)->iface_state))
+
+#define dvobj_to_pwrctl(dvobj) (&(dvobj->pwrctl_priv))
+#define pwrctl_to_dvobj(pwrctl) container_of(pwrctl, struct dvobj_priv, pwrctl_priv)
+#define dvobj_to_macidctl(dvobj) (&(dvobj->macid_ctl))
+#define dvobj_to_sec_camctl(dvobj) (&(dvobj->cam_ctl))
+#define dvobj_to_regsty(dvobj) (&(dvobj->padapters[IFACE_ID0]->registrypriv))
+#if defined(CONFIG_IOCTL_CFG80211) && defined(RTW_SINGLE_WIPHY)
+#define dvobj_to_wiphy(dvobj) ((dvobj)->wiphy)
+#endif
+#define dvobj_to_rfctl(dvobj) (&(dvobj->rf_ctl))
+#define rfctl_to_dvobj(rfctl) container_of((rfctl), struct dvobj_priv, rf_ctl)
+
+static inline void dev_set_surprise_removed(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bSurpriseRemoved, _TRUE);
+}
+static inline void dev_clr_surprise_removed(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bSurpriseRemoved, _FALSE);
+}
+static inline void dev_set_drv_stopped(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bDriverStopped, _TRUE);
+}
+static inline void dev_clr_drv_stopped(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bDriverStopped, _FALSE);
+}
+#define dev_is_surprise_removed(dvobj)	(ATOMIC_READ(&dvobj->bSurpriseRemoved) == _TRUE)
+#define dev_is_drv_stopped(dvobj)		(ATOMIC_READ(&dvobj->bDriverStopped) == _TRUE)
+
+#ifdef PLATFORM_LINUX
+static struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
+{
+	/* todo: get interface type from dvobj and the return the dev accordingly */
+#ifdef RTW_DVOBJ_CHIP_HW_TYPE
+#endif
+
+#ifdef CONFIG_USB_HCI
+	return &dvobj->pusbintf->dev;
+#endif
+#ifdef CONFIG_SDIO_HCI
+	return &dvobj->intf_data.func->dev;
+#endif
+#ifdef CONFIG_GSPI_HCI
+	return &dvobj->intf_data.func->dev;
+#endif
+#ifdef CONFIG_PCI_HCI
+	return &dvobj->ppcidev->dev;
+#endif
+}
+#endif
+
+_adapter *dvobj_get_port0_adapter(struct dvobj_priv *dvobj);
+_adapter *dvobj_get_unregisterd_adapter(struct dvobj_priv *dvobj);
+_adapter *dvobj_get_adapter_by_addr(struct dvobj_priv *dvobj, u8 *addr);
+#define dvobj_get_primary_adapter(dvobj)	((dvobj)->padapters[IFACE_ID0])
+
+enum _hw_port {
+	HW_PORT0,
+	HW_PORT1,
+	HW_PORT2,
+	HW_PORT3,
+	HW_PORT4,
+	MAX_HW_PORT,
+};
+
+enum _ADAPTER_TYPE {
+	PRIMARY_ADAPTER,
+	VIRTUAL_ADAPTER,
+	MAX_ADAPTER = 0xFF,
+};
+
+typedef enum _DRIVER_STATE {
+	DRIVER_NORMAL = 0,
+	DRIVER_DISAPPEAR = 1,
+	DRIVER_REPLACE_DONGLE = 2,
+} DRIVER_STATE;
+
+#ifdef CONFIG_RTW_NAPI
+enum _NAPI_STATE {
+	NAPI_DISABLE = 0,
+	NAPI_ENABLE = 1,
+};
+#endif
+
+#ifdef CONFIG_INTEL_PROXIM
+struct proxim {
+	bool proxim_support;
+	bool proxim_on;
+
+	void *proximity_priv;
+	int (*proxim_rx)(_adapter *padapter,
+			 union recv_frame *precv_frame);
+	u8(*proxim_get_var)(_adapter *padapter, u8 type);
+};
+#endif /* CONFIG_INTEL_PROXIM */
+
+#ifdef CONFIG_MAC_LOOPBACK_DRIVER
+typedef struct loopbackdata {
+	_sema	sema;
+	_thread_hdl_ lbkthread;
+	u8 bstop;
+	u32 cnt;
+	u16 size;
+	u16 txsize;
+	u8 txbuf[0x8000];
+	u16 rxsize;
+	u8 rxbuf[0x8000];
+	u8 msg[100];
+
+} LOOPBACKDATA, *PLOOPBACKDATA;
+#endif
+
+struct tsf_info {
+	u8 sync_port;/*tsf sync from portx*/
+	u8 offset; /*tsf timer offset*/
+};
+
+#define ADAPTER_TX_BW_2G(adapter) BW_MODE_2G((adapter)->driver_tx_bw_mode)
+#define ADAPTER_TX_BW_5G(adapter) BW_MODE_5G((adapter)->driver_tx_bw_mode)
+
+struct _ADAPTER {
+	int	DriverState;/* for disable driver using module, use dongle to replace module. */
+	int	pid[3];/* process id from UI, 0:wps, 1:hostapd, 2:dhcpcd */
+	int	bDongle;/* build-in module or external dongle */
+
+	_list	list;
+
+	struct dvobj_priv *dvobj;
+	struct	mlme_priv mlmepriv;
+	struct	mlme_ext_priv mlmeextpriv;
+	struct	cmd_priv	cmdpriv;
+	struct	evt_priv	evtpriv;
+
+#ifdef CONFIG_RTW_80211K
+	struct	rm_priv		rmpriv;
+#endif
+	/* struct	io_queue	*pio_queue; */
+	struct	io_priv	iopriv;
+	struct	xmit_priv	xmitpriv;
+	struct	recv_priv	recvpriv;
+	struct	sta_priv	stapriv;
+	struct	security_priv	securitypriv;
+	_lock   security_key_mutex; /* add for CONFIG_IEEE80211W, none 11w also can use */
+	struct	registry_priv	registrypriv;
+
+#ifdef CONFIG_RTW_NAPI
+	struct	napi_struct napi;
+	u8	napi_state;
+#endif
+
+#ifdef CONFIG_MP_INCLUDED
+	struct	mp_priv	mppriv;
+#endif
+
+#ifdef CONFIG_AP_MODE
+	struct	hostapd_priv	*phostapdpriv;
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+#ifdef CONFIG_P2P
+	struct cfg80211_wifidirect_info	cfg80211_wdinfo;
+#endif /* CONFIG_P2P */
+#endif /* CONFIG_IOCTL_CFG80211 */
+	u32	setband;
+	ATOMIC_T bandskip;
+
+#ifdef CONFIG_P2P
+	struct wifidirect_info	wdinfo;
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+	struct tdls_info	tdlsinfo;
+#endif /* CONFIG_TDLS */
+
+#ifdef CONFIG_WAPI_SUPPORT
+	u8	WapiSupport;
+	RT_WAPI_T	wapiInfo;
+#endif
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	u8	rtw_rson_scanstage;
+#endif
+
+#ifdef CONFIG_WFD
+	struct wifi_display_info wfd_info;
+#endif /* CONFIG_WFD */
+
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	struct bt_coex_info coex_info;
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+	ERROR_CODE		LastError; /* <20130613, Kordan> Only the functions associated with MP records the error code by now. */
+
+	PVOID			HalData;
+	u32 hal_data_sz;
+	struct hal_ops	hal_func;
+
+	u32	IsrContent;
+	u32	ImrContent;
+
+	u8	EepromAddressSize;
+	u8	bDriverIsGoingToUnload;
+	u8	init_adpt_in_progress;
+	u8	bHaltInProgress;
+#ifdef CONFIG_GPIO_API
+	u8	pre_gpio_pin;
+	struct gpio_int_priv {
+		u8 interrupt_mode;
+		u8 interrupt_enable_mask;
+		void (*callback[8])(u8 level);
+	} gpiointpriv;
+#endif
+	_thread_hdl_ cmdThread;
+#ifdef CONFIG_EVENT_THREAD_MODE
+	_thread_hdl_ evtThread;
+#endif
+#ifdef CONFIG_XMIT_THREAD_MODE
+	_thread_hdl_ xmitThread;
+#endif
+#ifdef CONFIG_RECV_THREAD_MODE
+	_thread_hdl_ recvThread;
+#endif
+	u8 registered;
+#ifndef PLATFORM_LINUX
+	NDIS_STATUS(*dvobj_init)(struct dvobj_priv *dvobj);
+	void (*dvobj_deinit)(struct dvobj_priv *dvobj);
+#endif
+
+	void (*intf_start)(_adapter *adapter);
+	void (*intf_stop)(_adapter *adapter);
+
+#ifdef PLATFORM_WINDOWS
+	_nic_hdl		hndis_adapter;/* hNdisAdapter(NDISMiniportAdapterHandle); */
+	_nic_hdl		hndis_config;/* hNdisConfiguration; */
+	NDIS_STRING fw_img;
+
+	u32	NdisPacketFilter;
+	u8	MCList[MAX_MCAST_LIST_NUM][6];
+	u32	MCAddrCount;
+#endif /* end of PLATFORM_WINDOWS */
+
+
+#ifdef PLATFORM_LINUX
+	_nic_hdl pnetdev;
+	char old_ifname[IFNAMSIZ];
+
+	/* used by rtw_rereg_nd_name related function */
+	struct rereg_nd_name_data {
+		_nic_hdl old_pnetdev;
+		char old_ifname[IFNAMSIZ];
+		u8 old_ips_mode;
+		u8 old_bRegUseLed;
+	} rereg_nd_name_priv;
+
+	u8 ndev_unregistering;
+	int bup;
+	struct net_device_stats stats;
+	struct iw_statistics iwstats;
+	struct proc_dir_entry *dir_dev;/* for proc directory */
+	struct proc_dir_entry *dir_odm;
+
+#ifdef CONFIG_MCC_MODE
+	struct proc_dir_entry *dir_mcc;
+#endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_IOCTL_CFG80211
+	struct wireless_dev *rtw_wdev;
+	struct rtw_wdev_priv wdev_data;
+
+#if !defined(RTW_SINGLE_WIPHY)
+	struct wiphy *wiphy;
+#endif
+
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+#endif /* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	_nic_hdl pifp;
+	int bup;
+	_lock glock;
+#endif /* PLATFORM_FREEBSD */
+	u8 mac_addr[ETH_ALEN];
+	int net_closed;
+
+	u8 netif_up;
+
+	u8 bLinkInfoDump;
+	/*	Added by Albert 2012/10/26 */
+	/*	The driver will show up the desired channel number when this flag is 1. */
+	u8 bNotifyChannelChange;
+	u8 bsta_tp_dump;
+#ifdef CONFIG_P2P
+	/*	Added by Albert 2012/12/06 */
+	/*	The driver will show the current P2P status when the upper application reads it. */
+	u8 bShowGetP2PState;
+#endif
+#ifdef CONFIG_AUTOSUSPEND
+	u8	bDisableAutosuspend;
+#endif
+
+	u8 isprimary; /* is primary adapter or not */
+	/* notes:
+	**	if isprimary is true, the adapter_type value is 0, iface_id is IFACE_ID0 for PRIMARY_ADAPTER
+	**	if isprimary is false, the adapter_type value is 1, iface_id is IFACE_ID1 for VIRTUAL_ADAPTER
+	**	refer to iface_id if iface_nums>2 and isprimary is false and the adapter_type value is 0xff.*/
+	u8 adapter_type;/*be used in  Multi-interface to recognize whether is PRIMARY_ADAPTER  or not(PRIMARY_ADAPTER/VIRTUAL_ADAPTER) .*/
+	u8 hw_port; /*interface port type, it depends on HW port */
+	struct tsf_info tsf;
+
+
+	/*extend to support multi interface*/
+	/*IFACE_ID0 is equals to PRIMARY_ADAPTER
+	IFACE_ID1 is equals to VIRTUAL_ADAPTER*/
+	u8 iface_id;
+
+#ifdef CONFIG_BR_EXT
+	_lock					br_ext_lock;
+	/* unsigned int			macclone_completed; */
+	struct nat25_network_db_entry	*nethash[NAT25_HASH_SIZE];
+	int				pppoe_connection_in_progress;
+	unsigned char			pppoe_addr[MACADDRLEN];
+	unsigned char			scdb_mac[MACADDRLEN];
+	unsigned char			scdb_ip[4];
+	struct nat25_network_db_entry	*scdb_entry;
+	unsigned char			br_mac[MACADDRLEN];
+	unsigned char			br_ip[4];
+
+	struct br_ext_info		ethBrExtInfo;
+#endif /* CONFIG_BR_EXT */
+
+#ifdef CONFIG_INTEL_PROXIM
+	/* intel Proximity, should be alloc mem
+	 * in intel Proximity module and can only
+	 * be used in intel Proximity mode */
+	struct proxim proximity;
+#endif /* CONFIG_INTEL_PROXIM */
+
+#ifdef CONFIG_MAC_LOOPBACK_DRIVER
+	PLOOPBACKDATA ploopback;
+#endif
+#ifdef CONFIG_AP_MODE
+	u8 bmc_tx_rate;
+#endif
+
+	/* for debug purpose */
+	u8 fix_rate;
+	u8 fix_bw;
+	u8 data_fb; /* data rate fallback, valid only when fix_rate is not 0xff */
+	u8 power_offset;
+	u8 driver_tx_bw_mode;
+	u8 rsvd_page_offset;
+	u8 rsvd_page_num;
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+	u8 fifo_sel;
+	u32 fifo_addr;
+	u32 fifo_size;
+#endif
+
+	u8 driver_vcs_en; /* Enable=1, Disable=0 driver control vrtl_carrier_sense for tx */
+	u8 driver_vcs_type;/* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. */
+	u8 driver_ampdu_spacing;/* driver control AMPDU Density for peer sta's rx */
+	u8 driver_rx_ampdu_factor;/* 0xff: disable drv ctrl, 0:8k, 1:16k, 2:32k, 3:64k; */
+	u8 driver_rx_ampdu_spacing;  /* driver control Rx AMPDU Density */
+	u8 fix_rx_ampdu_accept;
+	u8 fix_rx_ampdu_size; /* 0~127, TODO:consider each sta and each TID */
+#ifdef CONFIG_TX_AMSDU
+	u8 tx_amsdu;
+	u16 tx_amsdu_rate;
+#endif
+	u8 driver_tx_max_agg_num; /*fix tx desc max agg num , 0xff: disable drv ctrl*/
+#ifdef DBG_RX_COUNTER_DUMP
+	u8 dump_rx_cnt_mode;/*BIT0:drv,BIT1:mac,BIT2:phy*/
+	u32 drv_rx_cnt_ok;
+	u32 drv_rx_cnt_crcerror;
+	u32 drv_rx_cnt_drop;
+#endif
+
+#ifdef CONFIG_DBG_COUNTER
+	struct rx_logs rx_logs;
+	struct tx_logs tx_logs;
+	struct int_logs int_logs;
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	struct mcc_adapter_priv mcc_adapterpriv;
+#endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_MESH
+	struct rtw_mesh_cfg mesh_cfg;
+	struct rtw_mesh_info mesh_info;
+	_timer mesh_path_timer;
+	_timer mesh_path_root_timer;
+	_timer mesh_atlm_param_req_timer; /* airtime link metrics param request timer */
+	_workitem mesh_work;
+	unsigned long wrkq_flags;
+#endif /* CONFIG_RTW_MESH */
+};
+
+#define adapter_to_dvobj(adapter) ((adapter)->dvobj)
+#define adapter_to_regsty(adapter) dvobj_to_regsty(adapter_to_dvobj((adapter)))
+#define adapter_to_pwrctl(adapter) dvobj_to_pwrctl(adapter_to_dvobj((adapter)))
+#define adapter_wdev_data(adapter) (&((adapter)->wdev_data))
+#if defined(RTW_SINGLE_WIPHY)
+#define adapter_to_wiphy(adapter) dvobj_to_wiphy(adapter_to_dvobj(adapter))
+#else
+#define adapter_to_wiphy(adapter) ((adapter)->wiphy)
+#endif
+
+#define adapter_to_rfctl(adapter) dvobj_to_rfctl(adapter_to_dvobj((adapter)))
+#define adapter_to_macidctl(adapter) dvobj_to_macidctl(adapter_to_dvobj((adapter)))
+
+#define adapter_mac_addr(adapter) (adapter->mac_addr)
+#define adapter_to_chset(adapter) (adapter_to_rfctl((adapter))->channel_set)
+
+#define mlme_to_adapter(mlme) container_of((mlme), struct _ADAPTER, mlmepriv)
+#define tdls_info_to_adapter(tdls) container_of((tdls), struct _ADAPTER, tdlsinfo)
+
+#define rtw_get_chip_type(adapter) (((PADAPTER)adapter)->dvobj->chip_type)
+#define rtw_get_hw_type(adapter) (((PADAPTER)adapter)->dvobj->HardwareType)
+#define rtw_get_intf_type(adapter) (((PADAPTER)adapter)->dvobj->interface_type)
+
+#define rtw_get_mi_nums(adapter) (((PADAPTER)adapter)->dvobj->iface_nums)
+
+static inline void rtw_set_surprise_removed(_adapter *padapter)
+{
+	dev_set_surprise_removed(adapter_to_dvobj(padapter));
+}
+static inline void rtw_clr_surprise_removed(_adapter *padapter)
+{
+	dev_clr_surprise_removed(adapter_to_dvobj(padapter));
+}
+static inline void rtw_set_drv_stopped(_adapter *padapter)
+{
+	dev_set_drv_stopped(adapter_to_dvobj(padapter));
+}
+static inline void rtw_clr_drv_stopped(_adapter *padapter)
+{
+	dev_clr_drv_stopped(adapter_to_dvobj(padapter));
+}
+#define rtw_is_surprise_removed(padapter)	(dev_is_surprise_removed(adapter_to_dvobj(padapter)))
+#define rtw_is_drv_stopped(padapter)		(dev_is_drv_stopped(adapter_to_dvobj(padapter)))
+
+/*
+ * Function disabled.
+ *   */
+#define DF_TX_BIT		BIT0			/*write_port_cancel*/
+#define DF_RX_BIT		BIT1			/*read_port_cancel*/
+#define DF_IO_BIT		BIT2
+
+/* #define RTW_DISABLE_FUNC(padapter, func) (ATOMIC_ADD(&adapter_to_dvobj(padapter)->disable_func, (func))) */
+/* #define RTW_ENABLE_FUNC(padapter, func) (ATOMIC_SUB(&adapter_to_dvobj(padapter)->disable_func, (func))) */
+__inline static void RTW_DISABLE_FUNC(_adapter *padapter, int func_bit)
+{
+	int	df = ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func);
+	df |= func_bit;
+	ATOMIC_SET(&adapter_to_dvobj(padapter)->disable_func, df);
+}
+
+__inline static void RTW_ENABLE_FUNC(_adapter *padapter, int func_bit)
+{
+	int	df = ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func);
+	df &= ~(func_bit);
+	ATOMIC_SET(&adapter_to_dvobj(padapter)->disable_func, df);
+}
+
+#define RTW_CANNOT_RUN(padapter) \
+	(rtw_is_surprise_removed(padapter) || \
+	 rtw_is_drv_stopped(padapter))
+
+#define RTW_IS_FUNC_DISABLED(padapter, func_bit) (ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func) & (func_bit))
+
+#define RTW_CANNOT_IO(padapter) \
+	(rtw_is_surprise_removed(padapter) || \
+	 RTW_IS_FUNC_DISABLED((padapter), DF_IO_BIT))
+
+#define RTW_CANNOT_RX(padapter) \
+	(RTW_CANNOT_RUN(padapter) || \
+	 RTW_IS_FUNC_DISABLED((padapter), DF_RX_BIT))
+
+#define RTW_CANNOT_TX(padapter) \
+	(RTW_CANNOT_RUN(padapter) || \
+	 RTW_IS_FUNC_DISABLED((padapter), DF_TX_BIT))
+
+#ifdef CONFIG_PNO_SUPPORT
+int rtw_parse_ssid_list_tlv(char **list_str, pno_ssid_t *ssid, int max, int *bytes_left);
+int rtw_dev_pno_set(struct net_device *net, pno_ssid_t *ssid, int num,
+		    int pno_time, int pno_repeat, int pno_freq_expo_max);
+#ifdef CONFIG_PNO_SET_DEBUG
+	void rtw_dev_pno_debug(struct net_device *net);
+#endif /* CONFIG_PNO_SET_DEBUG */
+#endif /* CONFIG_PNO_SUPPORT */
+
+int rtw_suspend_free_assoc_resource(_adapter *padapter);
+#ifdef CONFIG_WOWLAN
+	int rtw_suspend_wow(_adapter *padapter);
+	int rtw_resume_process_wow(_adapter *padapter);
+#endif
+
+/* HCI Related header file */
+#ifdef CONFIG_USB_HCI
+	#include <usb_osintf.h>
+	#include <usb_ops.h>
+	#include <usb_hal.h>
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+	#include <sdio_osintf.h>
+	#include <sdio_ops.h>
+	#include <sdio_hal.h>
+#endif
+
+#ifdef CONFIG_GSPI_HCI
+	#include <gspi_osintf.h>
+	#include <gspi_ops.h>
+	#include <gspi_hal.h>
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	#include <pci_osintf.h>
+	#include <pci_ops.h>
+	#include <pci_hal.h>
+#endif
+
+#endif /* __DRV_TYPES_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_ce.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_ce.h
new file mode 100644
index 000000000000..c00dea8e6b35
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_ce.h
@@ -0,0 +1,86 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_CE_H__
+#define __DRV_TYPES_CE_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+
+#include <Sdcardddk.h>
+
+#define MAX_ACTIVE_REG_PATH 256
+
+#define MAX_MCAST_LIST_NUM					32
+
+
+
+/* for ioctl */
+#define MAKE_DRIVER_VERSION(_MainVer, _MinorVer)	((((u32)(_MainVer))<<16)+_MinorVer)
+
+#define NIC_HEADER_SIZE				14			/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
+#define NIC_MAX_SEND_PACKETS			10		/* max number of send packets the MiniportSendPackets function can accept, can be moved to typedef.h */
+#define NIC_VENDOR_DRIVER_VERSION       MAKE_DRIVER_VERSION(0, 001)	/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
+
+typedef struct _MP_REG_ENTRY {
+
+	NDIS_STRING		RegName;	/* variable name text */
+	BOOLEAN			bRequired;	/* 1->required, 0->optional */
+
+	u8			Type;		/* NdisParameterInteger/NdisParameterHexInteger/NdisParameterStringle/NdisParameterMultiString */
+	uint			FieldOffset;	/* offset to MP_ADAPTER field */
+	uint			FieldSize;	/* size (in bytes) of the field */
+
+#ifdef UNDER_AMD64
+	u64			Default;
+#else
+	u32			Default;		/* default value to use */
+#endif
+
+	u32			Min;			/* minimum value allowed */
+	u32			Max;		/* maximum value allowed */
+} MP_REG_ENTRY, *PMP_REG_ENTRY;
+
+#ifdef CONFIG_USB_HCI
+typedef struct _USB_EXTENSION {
+	LPCUSB_FUNCS    _lpUsbFuncs;
+	USB_HANDLE	    _hDevice;
+	PVOID		    pAdapter;
+
+#if 0
+	USB_ENDPOINT_DESCRIPTOR		_endpACLIn;
+	USB_ENDPOINT_DESCRIPTOR		_endpACLOutHigh;
+	USB_ENDPOINT_DESCRIPTOR		_endpACLOutNormal;
+
+	USB_PIPE        pPipeIn;
+	USB_PIPE        pPipeOutNormal;
+	USB_PIPE        pPipeOutHigh;
+#endif
+
+} USB_EXTENSION, *PUSB_EXTENSION;
+#endif
+
+
+typedef struct _OCTET_STRING {
+	u8      *Octet;
+	u16      Length;
+} OCTET_STRING, *POCTET_STRING;
+
+
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_gspi.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_gspi.h
new file mode 100644
index 000000000000..c22c4972232d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_gspi.h
@@ -0,0 +1,49 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_GSPI_H__
+#define __DRV_TYPES_GSPI_H__
+
+/* SPI Header Files */
+#ifdef PLATFORM_LINUX
+	#include <linux/platform_device.h>
+	#include <linux/spi/spi.h>
+	#include <linux/gpio.h>
+	/* #include <mach/ldo.h> */
+	#include <asm/mach-types.h>
+	#include <asm/gpio.h>
+	#include <asm/io.h>
+	#include <mach/board.h>
+	#include <mach/hardware.h>
+	#include <mach/irqs.h>
+	#include <custom_gpio.h>
+#endif
+
+
+typedef struct gspi_data {
+	u8  func_number;
+
+	u8  tx_block_mode;
+	u8  rx_block_mode;
+	u32 block_transfer_len;
+
+#ifdef PLATFORM_LINUX
+	struct spi_device *func;
+
+	struct workqueue_struct *priv_wq;
+	struct delayed_work irq_work;
+#endif
+} GSPI_DATA, *PGSPI_DATA;
+
+#endif /*  #ifndef __DRV_TYPES_GSPI_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_linux.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_linux.h
new file mode 100644
index 000000000000..91ca68b39c26
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_linux.h
@@ -0,0 +1,19 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_LINUX_H__
+#define __DRV_TYPES_LINUX_H__
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_pci.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_pci.h
new file mode 100644
index 000000000000..a3a492708860
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_pci.h
@@ -0,0 +1,266 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_PCI_H__
+#define __DRV_TYPES_PCI_H__
+
+
+#ifdef PLATFORM_LINUX
+	#include <linux/pci.h>
+#endif
+
+
+#define	INTEL_VENDOR_ID				0x8086
+#define	SIS_VENDOR_ID					0x1039
+#define	ATI_VENDOR_ID					0x1002
+#define	ATI_DEVICE_ID					0x7914
+#define	AMD_VENDOR_ID					0x1022
+
+#define	PCI_MAX_BRIDGE_NUMBER			255
+#define	PCI_MAX_DEVICES				32
+#define	PCI_MAX_FUNCTION				8
+
+#define	PCI_CONF_ADDRESS   				0x0CF8   /* PCI Configuration Space Address */
+#define	PCI_CONF_DATA					0x0CFC   /* PCI Configuration Space Data */
+
+#define	PCI_CLASS_BRIDGE_DEV			0x06
+#define	PCI_SUBCLASS_BR_PCI_TO_PCI	0x04
+
+#define	PCI_CAPABILITY_ID_PCI_EXPRESS	0x10
+
+#define	U1DONTCARE					0xFF
+#define	U2DONTCARE					0xFFFF
+#define	U4DONTCARE					0xFFFFFFFF
+
+#define PCI_VENDER_ID_REALTEK		0x10ec
+
+#define HAL_HW_PCI_8180_DEVICE_ID	0x8180
+#define HAL_HW_PCI_8185_DEVICE_ID           	0x8185	/* 8185 or 8185b */
+#define HAL_HW_PCI_8188_DEVICE_ID           	0x8188	/* 8185b		 */
+#define HAL_HW_PCI_8198_DEVICE_ID           	0x8198	/* 8185b		 */
+#define HAL_HW_PCI_8190_DEVICE_ID           	0x8190	/* 8190 */
+#define HAL_HW_PCI_8723E_DEVICE_ID		0x8723	/* 8723E */
+#define HAL_HW_PCI_8192_DEVICE_ID           	0x8192	/* 8192 PCI-E */
+#define HAL_HW_PCI_8192SE_DEVICE_ID		0x8192	/* 8192 SE */
+#define HAL_HW_PCI_8174_DEVICE_ID           	0x8174	/* 8192 SE */
+#define HAL_HW_PCI_8173_DEVICE_ID           	0x8173	/* 8191 SE Crab */
+#define HAL_HW_PCI_8172_DEVICE_ID           	0x8172	/* 8191 SE RE */
+#define HAL_HW_PCI_8171_DEVICE_ID           	0x8171	/* 8191 SE Unicron */
+#define HAL_HW_PCI_0045_DEVICE_ID			0x0045	/* 8190 PCI for Ceraga */
+#define HAL_HW_PCI_0046_DEVICE_ID			0x0046	/* 8190 Cardbus for Ceraga */
+#define HAL_HW_PCI_0044_DEVICE_ID			0x0044	/* 8192e PCIE for Ceraga */
+#define HAL_HW_PCI_0047_DEVICE_ID			0x0047	/* 8192e Express Card for Ceraga */
+#define HAL_HW_PCI_700F_DEVICE_ID			0x700F
+#define HAL_HW_PCI_701F_DEVICE_ID			0x701F
+#define HAL_HW_PCI_DLINK_DEVICE_ID		0x3304
+#define HAL_HW_PCI_8188EE_DEVICE_ID		0x8179
+
+#define HAL_MEMORY_MAPPED_IO_RANGE_8190PCI 		0x1000     /* 8190 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8190PCI			0x00
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192PCIE	0x4000	/* 8192 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8192PCIE			0x01
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192SE		0x4000	/* 8192 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8192SE			0x10
+#define HAL_HW_PCI_REVISION_ID_8192CE			0x1
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192CE		0x4000	/* 8192 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8192DE			0x0
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192DE		0x4000	/* 8192 support 16 pages of IO registers */
+
+enum pci_bridge_vendor {
+	PCI_BRIDGE_VENDOR_INTEL = 0x0,/* 0b'0000,0001 */
+	PCI_BRIDGE_VENDOR_ATI, /* = 0x02, */ /* 0b'0000,0010 */
+	PCI_BRIDGE_VENDOR_AMD, /* = 0x04, */ /* 0b'0000,0100 */
+	PCI_BRIDGE_VENDOR_SIS ,/* = 0x08, */ /* 0b'0000,1000 */
+	PCI_BRIDGE_VENDOR_UNKNOWN, /* = 0x40, */ /* 0b'0100,0000 */
+	PCI_BRIDGE_VENDOR_MAX ,/* = 0x80 */
+} ;
+
+/* copy this data structor defination from MSDN SDK */
+typedef struct _PCI_COMMON_CONFIG {
+	u16	VendorID;
+	u16	DeviceID;
+	u16	Command;
+	u16	Status;
+	u8	RevisionID;
+	u8	ProgIf;
+	u8	SubClass;
+	u8	BaseClass;
+	u8	CacheLineSize;
+	u8	LatencyTimer;
+	u8	HeaderType;
+	u8	BIST;
+
+	union {
+		struct _PCI_HEADER_TYPE_0 {
+			u32	BaseAddresses[6];
+			u32	CIS;
+			u16	SubVendorID;
+			u16	SubSystemID;
+			u32	ROMBaseAddress;
+			u8	CapabilitiesPtr;
+			u8	Reserved1[3];
+			u32	Reserved2;
+
+			u8	InterruptLine;
+			u8	InterruptPin;
+			u8	MinimumGrant;
+			u8	MaximumLatency;
+		} type0;
+#if 0
+		struct _PCI_HEADER_TYPE_1 {
+			ULONG BaseAddresses[PCI_TYPE1_ADDRESSES];
+			UCHAR PrimaryBusNumber;
+			UCHAR SecondaryBusNumber;
+			UCHAR SubordinateBusNumber;
+			UCHAR SecondaryLatencyTimer;
+			UCHAR IOBase;
+			UCHAR IOLimit;
+			USHORT SecondaryStatus;
+			USHORT MemoryBase;
+			USHORT MemoryLimit;
+			USHORT PrefetchableMemoryBase;
+			USHORT PrefetchableMemoryLimit;
+			ULONG PrefetchableMemoryBaseUpper32;
+			ULONG PrefetchableMemoryLimitUpper32;
+			USHORT IOBaseUpper;
+			USHORT IOLimitUpper;
+			ULONG Reserved2;
+			ULONG ExpansionROMBase;
+			UCHAR InterruptLine;
+			UCHAR InterruptPin;
+			USHORT BridgeControl;
+		} type1;
+
+		struct _PCI_HEADER_TYPE_2 {
+			ULONG BaseAddress;
+			UCHAR CapabilitiesPtr;
+			UCHAR Reserved2;
+			USHORT SecondaryStatus;
+			UCHAR PrimaryBusNumber;
+			UCHAR CardbusBusNumber;
+			UCHAR SubordinateBusNumber;
+			UCHAR CardbusLatencyTimer;
+			ULONG MemoryBase0;
+			ULONG MemoryLimit0;
+			ULONG MemoryBase1;
+			ULONG MemoryLimit1;
+			USHORT IOBase0_LO;
+			USHORT IOBase0_HI;
+			USHORT IOLimit0_LO;
+			USHORT IOLimit0_HI;
+			USHORT IOBase1_LO;
+			USHORT IOBase1_HI;
+			USHORT IOLimit1_LO;
+			USHORT IOLimit1_HI;
+			UCHAR InterruptLine;
+			UCHAR InterruptPin;
+			USHORT BridgeControl;
+			USHORT SubVendorID;
+			USHORT SubSystemID;
+			ULONG LegacyBaseAddress;
+			UCHAR Reserved3[56];
+			ULONG SystemControl;
+			UCHAR MultiMediaControl;
+			UCHAR GeneralStatus;
+			UCHAR Reserved4[2];
+			UCHAR GPIO0Control;
+			UCHAR GPIO1Control;
+			UCHAR GPIO2Control;
+			UCHAR GPIO3Control;
+			ULONG IRQMuxRouting;
+			UCHAR RetryStatus;
+			UCHAR CardControl;
+			UCHAR DeviceControl;
+			UCHAR Diagnostic;
+		} type2;
+#endif
+	} u;
+
+	u8	DeviceSpecific[108];
+} PCI_COMMON_CONFIG , *PPCI_COMMON_CONFIG;
+
+typedef struct _RT_PCI_CAPABILITIES_HEADER {
+	u8   CapabilityID;
+	u8   Next;
+} RT_PCI_CAPABILITIES_HEADER, *PRT_PCI_CAPABILITIES_HEADER;
+
+struct pci_priv {
+	BOOLEAN		pci_clk_req;
+
+	u8	pciehdr_offset;
+	/* PCIeCap is only differece between B-cut and C-cut. */
+	/* Configuration Space offset 72[7:4] */
+	/* 0: A/B cut */
+	/* 1: C cut and later. */
+	u8	pcie_cap;
+	u8	linkctrl_reg;
+
+	u8	busnumber;
+	u8	devnumber;
+	u8	funcnumber;
+
+	u8	pcibridge_busnum;
+	u8	pcibridge_devnum;
+	u8	pcibridge_funcnum;
+	u8	pcibridge_vendor;
+	u16	pcibridge_vendorid;
+	u16	pcibridge_deviceid;
+	u8	pcibridge_pciehdr_offset;
+	u8	pcibridge_linkctrlreg;
+
+	u8	amd_l1_patch;
+};
+
+typedef struct _RT_ISR_CONTENT {
+	union {
+		u32			IntArray[2];
+		u32			IntReg4Byte;
+		u16			IntReg2Byte;
+	};
+} RT_ISR_CONTENT, *PRT_ISR_CONTENT;
+
+/* #define RegAddr(addr)           (addr + 0xB2000000UL) */
+/* some platform macros will def here */
+static inline void NdisRawWritePortUlong(u32 port,  u32 val)
+{
+	outl(val, port);
+	/* writel(val, (u8 *)RegAddr(port));	 */
+}
+
+static inline void NdisRawWritePortUchar(u32 port,  u8 val)
+{
+	outb(val, port);
+	/* writeb(val, (u8 *)RegAddr(port)); */
+}
+
+static inline void NdisRawReadPortUchar(u32 port, u8 *pval)
+{
+	*pval = inb(port);
+	/* *pval = readb((u8 *)RegAddr(port)); */
+}
+
+static inline void NdisRawReadPortUshort(u32 port, u16 *pval)
+{
+	*pval = inw(port);
+	/* *pval = readw((u8 *)RegAddr(port)); */
+}
+
+static inline void NdisRawReadPortUlong(u32 port, u32 *pval)
+{
+	*pval = inl(port);
+	/* *pval = readl((u8 *)RegAddr(port)); */
+}
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_sdio.h
new file mode 100644
index 000000000000..9feca1216820
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_sdio.h
@@ -0,0 +1,90 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_SDIO_H__
+#define __DRV_TYPES_SDIO_H__
+
+/* SDIO Header Files */
+#ifdef PLATFORM_LINUX
+	#include <linux/mmc/sdio_func.h>
+	#include <linux/mmc/sdio_ids.h>
+	#include <linux/mmc/host.h>
+	#include <linux/mmc/card.h>
+
+	#ifdef CONFIG_PLATFORM_SPRD
+		#include <linux/gpio.h>
+		#include <custom_gpio.h>
+	#endif /* CONFIG_PLATFORM_SPRD */
+#endif
+
+#ifdef PLATFORM_OS_XP
+	#include <wdm.h>
+	#include <ntddsd.h>
+#endif
+
+#ifdef PLATFORM_OS_CE
+	#include <sdcardddk.h>
+#endif
+
+#define RTW_SDIO_CLK_33M	33000000
+#define RTW_SDIO_CLK_40M	40000000
+#define RTW_SDIO_CLK_80M	80000000
+#define RTW_SDIO_CLK_160M	160000000
+
+typedef struct sdio_data {
+	u8  func_number;
+
+	u8  tx_block_mode;
+	u8  rx_block_mode;
+	u32 block_transfer_len;
+
+#ifdef PLATFORM_LINUX
+	struct sdio_func	*func;
+	_thread_hdl_ sys_sdio_irq_thd;
+	unsigned int clock;
+	unsigned int timing;
+	u8	sd3_bus_mode;
+#endif
+
+#ifdef PLATFORM_OS_XP
+	PDEVICE_OBJECT				pphysdevobj;
+	PDEVICE_OBJECT				pfuncdevobj;
+	PDEVICE_OBJECT				pnextdevobj;
+	SDBUS_INTERFACE_STANDARD	sdbusinft;
+	u8							nextdevstacksz;
+#endif
+
+#ifdef PLATFORM_OS_CE
+	SD_DEVICE_HANDLE			hDevice;
+	SD_CARD_RCA					sd_rca;
+	SD_CARD_INTERFACE			card_intf;
+	BOOLEAN						enableIsarWithStatus;
+	WCHAR						active_path[MAX_ACTIVE_REG_PATH];
+	SD_HOST_BLOCK_CAPABILITY	sd_host_blk_cap;
+#endif
+} SDIO_DATA, *PSDIO_DATA;
+
+#define dvobj_to_sdio_func(d)	((d)->intf_data.func)
+
+#define RTW_SDIO_ADDR_CMD52_BIT		(1<<17)
+#define RTW_SDIO_ADDR_CMD52_GEN(a)	(a | RTW_SDIO_ADDR_CMD52_BIT)
+#define RTW_SDIO_ADDR_CMD52_CLR(a)	(a&~RTW_SDIO_ADDR_CMD52_BIT)
+#define RTW_SDIO_ADDR_CMD52_CHK(a)	(a&RTW_SDIO_ADDR_CMD52_BIT ? 1 : 0)
+
+#define RTW_SDIO_ADDR_F0_BIT		(1<<18)
+#define RTW_SDIO_ADDR_F0_GEN(a)		(a | RTW_SDIO_ADDR_F0_BIT)
+#define RTW_SDIO_ADDR_F0_CLR(a)		(a&~RTW_SDIO_ADDR_F0_BIT)
+#define RTW_SDIO_ADDR_F0_CHK(a)		(a&RTW_SDIO_ADDR_F0_BIT ? 1 : 0)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_xp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_xp.h
new file mode 100644
index 000000000000..81c45047ae11
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/drv_types_xp.h
@@ -0,0 +1,88 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_XP_H__
+#define __DRV_TYPES_XP_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+
+
+
+#define MAX_MCAST_LIST_NUM					32
+
+
+
+/* for ioctl */
+#define MAKE_DRIVER_VERSION(_MainVer, _MinorVer)	((((u32)(_MainVer))<<16)+_MinorVer)
+
+#define NIC_HEADER_SIZE				14			/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
+#define NIC_MAX_SEND_PACKETS			10		/* max number of send packets the MiniportSendPackets function can accept, can be moved to typedef.h */
+#define NIC_VENDOR_DRIVER_VERSION       MAKE_DRIVER_VERSION(0, 001)	/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
+
+
+#undef ON_VISTA
+/* added by Jackson */
+#ifndef ON_VISTA
+	/*
+	* Bus driver versions
+	*   */
+
+	#define SDBUS_DRIVER_VERSION_1          0x100
+	#define SDBUS_DRIVER_VERSION_2          0x200
+
+	#define    SDP_FUNCTION_TYPE	4
+	#define    SDP_BUS_DRIVER_VERSION 5
+	#define    SDP_BUS_WIDTH 6
+	#define    SDP_BUS_CLOCK 7
+	#define    SDP_BUS_INTERFACE_CONTROL 8
+	#define    SDP_HOST_BLOCK_LENGTH 9
+	#define    SDP_FUNCTION_BLOCK_LENGTH 10
+	#define    SDP_FN0_BLOCK_LENGTH 11
+	#define    SDP_FUNCTION_INT_ENABLE 12
+#endif
+
+
+typedef struct _MP_REG_ENTRY {
+
+	NDIS_STRING		RegName;	/* variable name text */
+	BOOLEAN			bRequired;	/* 1->required, 0->optional */
+
+	u8			Type;		/* NdisParameterInteger/NdisParameterHexInteger/NdisParameterStringle/NdisParameterMultiString */
+	uint			FieldOffset;	/* offset to MP_ADAPTER field */
+	uint			FieldSize;	/* size (in bytes) of the field */
+
+#ifdef UNDER_AMD64
+	u64			Default;
+#else
+	u32			Default;		/* default value to use */
+#endif
+
+	u32			Min;			/* minimum value allowed */
+	u32			Max;		/* maximum value allowed */
+} MP_REG_ENTRY, *PMP_REG_ENTRY;
+
+
+typedef struct _OCTET_STRING {
+	u8      *Octet;
+	u16      Length;
+} OCTET_STRING, *POCTET_STRING;
+
+
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ethernet.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ethernet.h
new file mode 100644
index 000000000000..2bafa4d98edc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ethernet.h
@@ -0,0 +1,36 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 */
+#ifndef __INC_ETHERNET_H
+#define __INC_ETHERNET_H
+
+#define ETHERNET_ADDRESS_LENGTH				6		/* !< Ethernet Address Length */
+#define ETHERNET_HEADER_SIZE				14		/* !< Ethernet Header Length */
+#define LLC_HEADER_SIZE						6		/* !< LLC Header Length */
+#define TYPE_LENGTH_FIELD_SIZE				2		/* !< Type/Length Size */
+#define MINIMUM_ETHERNET_PACKET_SIZE		60		/* !< Minimum Ethernet Packet Size */
+#define MAXIMUM_ETHERNET_PACKET_SIZE		1514	/* !< Maximum Ethernet Packet Size */
+
+#define RT_ETH_IS_MULTICAST(_pAddr)	((((UCHAR *)(_pAddr))[0]&0x01) != 0)		/* !< Is Multicast Address? */
+#define RT_ETH_IS_BROADCAST(_pAddr)	(\
+		((UCHAR *)(_pAddr))[0] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[1] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[2] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[3] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[4] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[5] == 0xff)	/* !< Is Broadcast Address? */
+
+
+#endif /*  #ifndef __INC_ETHERNET_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_hal.h
new file mode 100644
index 000000000000..6da0f071d499
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_hal.h
@@ -0,0 +1,30 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __GSPI_HAL_H__
+#define __GSPI_HAL_H__
+
+
+void spi_int_dpc(PADAPTER padapter, u32 sdio_hisr);
+u8 rtw_set_hal_ops(_adapter *padapter);
+
+#ifdef CONFIG_RTL8188E
+	void rtl8188es_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8723B
+	void rtl8723bs_set_hal_ops(PADAPTER padapter);
+#endif
+
+#endif /* __GSPI_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_ops.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_ops.h
new file mode 100644
index 000000000000..bcfaad2e0bba
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_ops.h
@@ -0,0 +1,180 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __GSPI_OPS_H__
+#define __GSPI_OPS_H__
+
+/* follwing defination is based on
+ * GSPI spec of RTL8723, we temp
+ * suppose that it will be the same
+ * for diff chips of GSPI, if not
+ * we should move it to HAL folder */
+#define SPI_LOCAL_DOMAIN				0x0
+#define WLAN_IOREG_DOMAIN			0x8
+#define FW_FIFO_DOMAIN				0x4
+#define TX_HIQ_DOMAIN					0xc
+#define TX_MIQ_DOMAIN					0xd
+#define TX_LOQ_DOMAIN					0xe
+#define RX_RXFIFO_DOMAIN				0x1f
+
+/* IO Bus domain address mapping */
+#define DEFUALT_OFFSET					0x0
+#define SPI_LOCAL_OFFSET				0x10250000
+#define WLAN_IOREG_OFFSET			0x10260000
+#define FW_FIFO_OFFSET				0x10270000
+#define TX_HIQ_OFFSET					0x10310000
+#define TX_MIQ_OFFSET					0x1032000
+#define TX_LOQ_OFFSET					0x10330000
+#define RX_RXOFF_OFFSET				0x10340000
+
+/* SPI Local registers */
+#define SPI_REG_TX_CTRL					0x0000 /* SPI Tx Control */
+#define SPI_REG_STATUS_RECOVERY		0x0004
+#define SPI_REG_INT_TIMEOUT			0x0006
+#define SPI_REG_HIMR					0x0014 /* SPI Host Interrupt Mask */
+#define SPI_REG_HISR					0x0018 /* SPI Host Interrupt Service Routine */
+#define SPI_REG_RX0_REQ_LEN			0x001C /* RXDMA Request Length */
+#define SPI_REG_FREE_TXPG				0x0020 /* Free Tx Buffer Page */
+#define SPI_REG_HCPWM1					0x0024 /* HCI Current Power Mode 1 */
+#define SPI_REG_HCPWM2					0x0026 /* HCI Current Power Mode 2 */
+#define SPI_REG_HTSFR_INFO				0x0030 /* HTSF Informaion */
+#define SPI_REG_HRPWM1					0x0080 /* HCI Request Power Mode 1 */
+#define SPI_REG_HRPWM2					0x0082 /* HCI Request Power Mode 2 */
+#define SPI_REG_HPS_CLKR				0x0084 /* HCI Power Save Clock */
+#define SPI_REG_HSUS_CTRL				0x0086 /* SPI HCI Suspend Control */
+#define SPI_REG_HIMR_ON				0x0090 /* SPI Host Extension Interrupt Mask Always */
+#define SPI_REG_HISR_ON				0x0091 /* SPI Host Extension Interrupt Status Always */
+#define SPI_REG_CFG						0x00F0 /* SPI Configuration Register */
+
+#define SPI_TX_CTRL				(SPI_REG_TX_CTRL | SPI_LOCAL_OFFSET)
+#define SPI_STATUS_RECOVERY			(SPI_REG_STATUS_RECOVERY | SPI_LOCAL_OFFSET)
+#define SPI_INT_TIMEOUT					(SPI_REG_INT_TIMEOUT | SPI_LOCAL_OFFSET)
+#define SPI_HIMR				(SPI_REG_HIMR | SPI_LOCAL_OFFSET)
+#define SPI_HISR				(SPI_REG_HISR | SPI_LOCAL_OFFSET)
+#define SPI_RX0_REQ_LEN_1_BYTE		(SPI_REG_RX0_REQ_LEN | SPI_LOCAL_OFFSET)
+#define SPI_FREE_TXPG			(SPI_REG_FREE_TXPG | SPI_LOCAL_OFFSET)
+
+#define	SPI_HIMR_DISABLED				0
+
+/* SPI HIMR MASK diff with SDIO */
+#define SPI_HISR_RX_REQUEST			BIT(0)
+#define SPI_HISR_AVAL					BIT(1)
+#define SPI_HISR_TXERR					BIT(2)
+#define SPI_HISR_RXERR					BIT(3)
+#define SPI_HISR_TXFOVW				BIT(4)
+#define SPI_HISR_RXFOVW				BIT(5)
+#define SPI_HISR_TXBCNOK				BIT(6)
+#define SPI_HISR_TXBCNERR				BIT(7)
+#define SPI_HISR_BCNERLY_INT			BIT(16)
+#define SPI_HISR_ATIMEND				BIT(17)
+#define SPI_HISR_ATIMEND_E				BIT(18)
+#define SPI_HISR_CTWEND				BIT(19)
+#define SPI_HISR_C2HCMD				BIT(20)
+#define SPI_HISR_CPWM1					BIT(21)
+#define SPI_HISR_CPWM2					BIT(22)
+#define SPI_HISR_HSISR_IND				BIT(23)
+#define SPI_HISR_GTINT3_IND				BIT(24)
+#define SPI_HISR_GTINT4_IND				BIT(25)
+#define SPI_HISR_PSTIMEOUT				BIT(26)
+#define SPI_HISR_OCPINT					BIT(27)
+#define SPI_HISR_TSF_BIT32_TOGGLE		BIT(29)
+
+#define MASK_SPI_HISR_CLEAR		(SPI_HISR_TXERR |\
+		SPI_HISR_RXERR |\
+		SPI_HISR_TXFOVW |\
+		SPI_HISR_RXFOVW |\
+		SPI_HISR_TXBCNOK |\
+		SPI_HISR_TXBCNERR |\
+		SPI_HISR_C2HCMD |\
+		SPI_HISR_CPWM1 |\
+		SPI_HISR_CPWM2 |\
+		SPI_HISR_HSISR_IND |\
+		SPI_HISR_GTINT3_IND |\
+		SPI_HISR_GTINT4_IND |\
+		SPI_HISR_PSTIMEOUT |\
+		SPI_HISR_OCPINT)
+
+#define REG_LEN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 0, 8, x)/* (x<<(unsigned int)24) */
+#define REG_ADDR_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 8, 16, x)/* (x<<(unsigned int)16) */
+#define REG_DOMAIN_ID_FORMAT(pcmd, x) 		SET_BITS_TO_LE_4BYTE(pcmd, 24, 5, x)/* (x<<(unsigned int)0) */
+#define REG_FUN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 29, 2, x)/* (x<<(unsigned int)5) */
+#define REG_RW_FORMAT(pcmd, x) 				SET_BITS_TO_LE_4BYTE(pcmd, 31, 1, x)/* (x<<(unsigned int)7) */
+
+#define FIFO_LEN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 0, 16, x)/* (x<<(unsigned int)24)
+ * #define FIFO_ADDR_FORMAT(pcmd,x) 			SET_BITS_TO_LE_4BYTE(pcmd, 8, 16, x) */ /* (x<<(unsigned int)16) */
+#define FIFO_DOMAIN_ID_FORMAT(pcmd, x) 	SET_BITS_TO_LE_4BYTE(pcmd, 24, 5, x)/* (x<<(unsigned int)0) */
+#define FIFO_FUN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 29, 2, x)/* (x<<(unsigned int)5) */
+#define FIFO_RW_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 31, 1, x)/* (x<<(unsigned int)7) */
+
+
+/* get status dword0 */
+#define GET_STATUS_PUB_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 24, 8)
+#define GET_STATUS_HI_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 18, 6)
+#define GET_STATUS_MID_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 12, 6)
+#define GET_STATUS_LOW_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 6, 6)
+#define GET_STATUS_HISR_HI6BIT(status)			LE_BITS_TO_4BYTE(status, 0, 6)
+
+/* get status dword1 */
+#define GET_STATUS_HISR_MID8BIT(status)		LE_BITS_TO_4BYTE(status + 4, 24, 8)
+#define GET_STATUS_HISR_LOW8BIT(status)		LE_BITS_TO_4BYTE(status + 4, 16, 8)
+#define GET_STATUS_ERROR(status)				LE_BITS_TO_4BYTE(status + 4, 17, 1)
+#define GET_STATUS_INT(status)				LE_BITS_TO_4BYTE(status + 4, 16, 1)
+#define GET_STATUS_RX_LENGTH(status)			LE_BITS_TO_4BYTE(status + 4, 0, 16)
+
+
+#define RXDESC_SIZE	24
+
+
+struct spi_more_data {
+	unsigned long more_data;
+	unsigned long len;
+};
+
+#ifdef CONFIG_RTL8188E
+	void rtl8188es_set_hal_ops(PADAPTER padapter);
+	#define set_hal_ops rtl8188es_set_hal_ops
+#endif
+extern void spi_set_chip_endian(PADAPTER padapter);
+extern unsigned int spi_write8_endian(ADAPTER *Adapter, unsigned int addr, unsigned int buf, u32 big);
+extern void spi_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
+extern void spi_set_chip_endian(PADAPTER padapter);
+extern void InitInterrupt8723ASdio(PADAPTER padapter);
+extern void InitSysInterrupt8723ASdio(PADAPTER padapter);
+extern void EnableInterrupt8723ASdio(PADAPTER padapter);
+extern void DisableInterrupt8723ASdio(PADAPTER padapter);
+extern void spi_int_hdl(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8723ASdio(PADAPTER padapter);
+#ifdef CONFIG_RTL8723B
+	extern void InitInterrupt8723BSdio(PADAPTER padapter);
+	extern void InitSysInterrupt8723BSdio(PADAPTER padapter);
+	extern void EnableInterrupt8723BSdio(PADAPTER padapter);
+	extern void DisableInterrupt8723BSdio(PADAPTER padapter);
+	extern u8 HalQueryTxBufferStatus8723BSdio(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8188E
+	extern void InitInterrupt8188EGspi(PADAPTER padapter);
+	extern void EnableInterrupt8188EGspi(PADAPTER padapter);
+	extern void DisableInterrupt8188EGspi(PADAPTER padapter);
+	extern void UpdateInterruptMask8188EGspi(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
+	extern u8 HalQueryTxBufferStatus8189EGspi(PADAPTER padapter);
+	extern u8 HalQueryTxOQTBufferStatus8189EGspi(PADAPTER padapter);
+	extern void ClearInterrupt8188EGspi(PADAPTER padapter);
+	extern u8 CheckIPSStatus(PADAPTER padapter);
+#endif /* CONFIG_RTL8188E */
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	extern u8 RecvOnePkt(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
+
+#endif /* __GSPI_OPS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_ops_linux.h
new file mode 100644
index 000000000000..0ba263de8fd7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_ops_linux.h
@@ -0,0 +1,18 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __SDIO_OPS_LINUX_H__
+#define __SDIO_OPS_LINUX_H__
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_osintf.h
new file mode 100644
index 000000000000..6393f779dcf8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/gspi_osintf.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __SDIO_OSINTF_H__
+#define __SDIO_OSINTF_H__
+
+
+#ifdef PLATFORM_OS_CE
+	extern NDIS_STATUS ce_sd_get_dev_hdl(PADAPTER padapter);
+	SD_API_STATUS ce_sd_int_callback(SD_DEVICE_HANDLE hDevice, PADAPTER padapter);
+	extern void sd_setup_irs(PADAPTER padapter);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/h2clbk.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/h2clbk.h
new file mode 100644
index 000000000000..4e22afcd8652
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/h2clbk.h
@@ -0,0 +1,26 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _H2CLBK_H_
+
+
+void _lbk_cmd(PADAPTER Adapter);
+
+void _lbk_rsp(PADAPTER Adapter);
+
+void _lbk_evt(IN PADAPTER Adapter);
+
+void h2c_event_callback(unsigned char *dev, unsigned char *pbuf);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_btcoex.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_btcoex.h
new file mode 100644
index 000000000000..03021fee323a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_btcoex.h
@@ -0,0 +1,97 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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_BTCOEX_H__
+#define __HAL_BTCOEX_H__
+
+#include <drv_types.h>
+
+/* Some variables can't get from outsrc BT-Coex,
+ * so we need to save here */
+typedef struct _BT_COEXIST {
+	u8 bBtExist;
+	u8 btTotalAntNum;
+	u8 btChipType;
+	u8 bInitlized;
+	u8 btAntisolation;
+} BT_COEXIST, *PBT_COEXIST;
+
+void DBG_BT_INFO(u8 *dbgmsg);
+
+void hal_btcoex_SetBTCoexist(PADAPTER padapter, u8 bBtExist);
+u8 hal_btcoex_IsBtExist(PADAPTER padapter);
+u8 hal_btcoex_IsBtDisabled(PADAPTER);
+void hal_btcoex_SetChipType(PADAPTER padapter, u8 chipType);
+void hal_btcoex_SetPgAntNum(PADAPTER padapter, u8 antNum);
+
+u8 hal_btcoex_Initialize(PADAPTER padapter);
+void hal_btcoex_PowerOnSetting(PADAPTER padapter);
+void hal_btcoex_AntInfoSetting(PADAPTER padapter);
+void hal_btcoex_PowerOffSetting(PADAPTER padapter);
+void hal_btcoex_PreLoadFirmware(PADAPTER padapter);
+void hal_btcoex_InitHwConfig(PADAPTER padapter, u8 bWifiOnly);
+
+void hal_btcoex_IpsNotify(PADAPTER padapter, u8 type);
+void hal_btcoex_LpsNotify(PADAPTER padapter, u8 type);
+void hal_btcoex_ScanNotify(PADAPTER padapter, u8 type);
+void hal_btcoex_ConnectNotify(PADAPTER padapter, u8 action);
+void hal_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus);
+void hal_btcoex_SpecialPacketNotify(PADAPTER padapter, u8 pktType);
+void hal_btcoex_IQKNotify(PADAPTER padapter, u8 state);
+void hal_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf);
+void hal_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf);
+void hal_btcoex_SuspendNotify(PADAPTER padapter, u8 state);
+void hal_btcoex_HaltNotify(PADAPTER padapter, u8 do_halt);
+void hal_btcoex_SwitchBtTRxMask(PADAPTER padapter);
+
+void hal_btcoex_Hanlder(PADAPTER padapter);
+
+s32 hal_btcoex_IsBTCoexRejectAMPDU(PADAPTER padapter);
+s32 hal_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER padapter);
+u32 hal_btcoex_GetAMPDUSize(PADAPTER padapter);
+void hal_btcoex_SetManualControl(PADAPTER padapter, u8 bmanual);
+u8 hal_btcoex_1Ant(PADAPTER padapter);
+u8 hal_btcoex_IsBtControlLps(PADAPTER);
+u8 hal_btcoex_IsLpsOn(PADAPTER);
+u8 hal_btcoex_RpwmVal(PADAPTER);
+u8 hal_btcoex_LpsVal(PADAPTER);
+u32 hal_btcoex_GetRaMask(PADAPTER);
+void hal_btcoex_RecordPwrMode(PADAPTER padapter, u8 *pCmdBuf, u8 cmdLen);
+void hal_btcoex_DisplayBtCoexInfo(PADAPTER, u8 *pbuf, u32 bufsize);
+void hal_btcoex_SetDBG(PADAPTER, u32 *pDbgModule);
+u32 hal_btcoex_GetDBG(PADAPTER, u8 *pStrBuf, u32 bufSize);
+u8 hal_btcoex_IncreaseScanDeviceNum(PADAPTER);
+u8 hal_btcoex_IsBtLinkExist(PADAPTER);
+void hal_btcoex_SetBtPatchVersion(PADAPTER, u16 btHciVer, u16 btPatchVer);
+void hal_btcoex_SetHciVersion(PADAPTER, u16 hciVersion);
+void hal_btcoex_SendScanNotify(PADAPTER, u8 type);
+void hal_btcoex_StackUpdateProfileInfo(void);
+void hal_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON);
+void hal_btcoex_SetAntIsolationType(PADAPTER padapter, u8 anttype);
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	int hal_btcoex_AntIsolationConfig_ParaFile(IN PADAPTER	Adapter, IN char *pFileName);
+	int hal_btcoex_ParseAntIsolationConfigFile(PADAPTER Adapter, char	*buffer);
+#endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
+u16 hal_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data);
+u16 hal_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val);
+void hal_btcoex_set_rfe_type(u8 type);
+void hal_btcoex_switchband_notify(u8 under_scan, u8 band_type);
+void hal_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length);
+void hal_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id);
+
+#ifdef CONFIG_RF4CE_COEXIST
+void hal_btcoex_set_rf4ce_link_state(u8 state);
+u8 hal_btcoex_get_rf4ce_link_state(void);
+#endif
+#endif /* !__HAL_BTCOEX_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_btcoex_wifionly.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_btcoex_wifionly.h
new file mode 100644
index 000000000000..b41bc3663843
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_btcoex_wifionly.h
@@ -0,0 +1,79 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __HALBTC_WIFIONLY_H__
+#define __HALBTC_WIFIONLY_H__
+
+#include <drv_types.h>
+#include <hal_data.h>
+
+/* Define the ICs that support wifi only cfg in coex. codes */
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+#define CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG 1
+#else
+#define CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG 0
+#endif
+
+#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
+
+typedef enum _WIFIONLY_CHIP_INTERFACE {
+	WIFIONLY_INTF_UNKNOWN	= 0,
+	WIFIONLY_INTF_PCI		= 1,
+	WIFIONLY_INTF_USB		= 2,
+	WIFIONLY_INTF_SDIO		= 3,
+	WIFIONLY_INTF_MAX
+} WIFIONLY_CHIP_INTERFACE, *PWIFIONLY_CHIP_INTERFACE;
+
+typedef enum _WIFIONLY_CUSTOMER_ID {
+	CUSTOMER_NORMAL			= 0,
+	CUSTOMER_HP_1			= 1
+} WIFIONLY_CUSTOMER_ID, *PWIFIONLY_CUSTOMER_ID;
+
+struct wifi_only_haldata {
+	u16		customer_id;
+	u8		efuse_pg_antnum;
+	u8		efuse_pg_antpath;
+	u8		rfe_type;
+	u8		ant_div_cfg;
+};
+
+struct wifi_only_cfg {
+	PVOID						Adapter;
+	struct	wifi_only_haldata		haldata_info;
+	WIFIONLY_CHIP_INTERFACE	chip_interface;
+};
+
+void halwifionly_write1byte(PVOID pwifionlyContext, u32 RegAddr, u8 Data);
+void halwifionly_write2byte(PVOID pwifionlyContext, u32 RegAddr, u16 Data);
+void halwifionly_write4byte(PVOID pwifionlyContext, u32 RegAddr, u32 Data);
+u8 halwifionly_read1byte(PVOID pwifionlyContext, u32 RegAddr);
+u16 halwifionly_read2byte(PVOID pwifionlyContext, u32 RegAddr);
+u32 halwifionly_read4byte(PVOID pwifionlyContext, u32 RegAddr);
+void halwifionly_bitmaskwrite1byte(PVOID pwifionlyContext, u32 regAddr, u8 bitMask, u8 data);
+void halwifionly_phy_set_rf_reg(PVOID pwifionlyContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
+void halwifionly_phy_set_bb_reg(PVOID pwifionlyContext, u32 RegAddr, u32 BitMask, u32 Data);
+void hal_btcoex_wifionly_switchband_notify(PADAPTER padapter);
+void hal_btcoex_wifionly_scan_notify(PADAPTER padapter);
+void hal_btcoex_wifionly_hw_config(PADAPTER padapter);
+void hal_btcoex_wifionly_initlizevariables(PADAPTER padapter);
+void hal_btcoex_wifionly_AntInfoSetting(PADAPTER padapter);
+#else
+#define hal_btcoex_wifionly_switchband_notify(padapter)
+#define hal_btcoex_wifionly_scan_notify(padapter)
+#define hal_btcoex_wifionly_hw_config(padapter)
+#define hal_btcoex_wifionly_initlizevariables(padapter)
+#define hal_btcoex_wifionly_AntInfoSetting(padapter)
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com.h
new file mode 100644
index 000000000000..bdfeb6eb3ec3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com.h
@@ -0,0 +1,678 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+#include "HalVerDef.h"
+#include "hal_pg.h"
+#include "hal_phy.h"
+#include "hal_phy_reg.h"
+#include "hal_com_reg.h"
+#include "hal_com_phycfg.h"
+#include "../hal/hal_com_c2h.h"
+
+/*------------------------------ 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_RATEMCS16				0x1C
+#define DESC_RATEMCS17				0x1D
+#define DESC_RATEMCS18				0x1E
+#define DESC_RATEMCS19				0x1F
+#define DESC_RATEMCS20				0x20
+#define DESC_RATEMCS21				0x21
+#define DESC_RATEMCS22				0x22
+#define DESC_RATEMCS23				0x23
+#define DESC_RATEMCS24				0x24
+#define DESC_RATEMCS25				0x25
+#define DESC_RATEMCS26				0x26
+#define DESC_RATEMCS27				0x27
+#define DESC_RATEMCS28				0x28
+#define DESC_RATEMCS29				0x29
+#define DESC_RATEMCS30				0x2A
+#define DESC_RATEMCS31				0x2B
+#define DESC_RATEVHTSS1MCS0		0x2C
+#define DESC_RATEVHTSS1MCS1		0x2D
+#define DESC_RATEVHTSS1MCS2		0x2E
+#define DESC_RATEVHTSS1MCS3		0x2F
+#define DESC_RATEVHTSS1MCS4		0x30
+#define DESC_RATEVHTSS1MCS5		0x31
+#define DESC_RATEVHTSS1MCS6		0x32
+#define DESC_RATEVHTSS1MCS7		0x33
+#define DESC_RATEVHTSS1MCS8		0x34
+#define DESC_RATEVHTSS1MCS9		0x35
+#define DESC_RATEVHTSS2MCS0		0x36
+#define DESC_RATEVHTSS2MCS1		0x37
+#define DESC_RATEVHTSS2MCS2		0x38
+#define DESC_RATEVHTSS2MCS3		0x39
+#define DESC_RATEVHTSS2MCS4		0x3A
+#define DESC_RATEVHTSS2MCS5		0x3B
+#define DESC_RATEVHTSS2MCS6		0x3C
+#define DESC_RATEVHTSS2MCS7		0x3D
+#define DESC_RATEVHTSS2MCS8		0x3E
+#define DESC_RATEVHTSS2MCS9		0x3F
+#define DESC_RATEVHTSS3MCS0		0x40
+#define DESC_RATEVHTSS3MCS1		0x41
+#define DESC_RATEVHTSS3MCS2		0x42
+#define DESC_RATEVHTSS3MCS3		0x43
+#define DESC_RATEVHTSS3MCS4		0x44
+#define DESC_RATEVHTSS3MCS5		0x45
+#define DESC_RATEVHTSS3MCS6		0x46
+#define DESC_RATEVHTSS3MCS7		0x47
+#define DESC_RATEVHTSS3MCS8		0x48
+#define DESC_RATEVHTSS3MCS9		0x49
+#define DESC_RATEVHTSS4MCS0		0x4A
+#define DESC_RATEVHTSS4MCS1		0x4B
+#define DESC_RATEVHTSS4MCS2		0x4C
+#define DESC_RATEVHTSS4MCS3		0x4D
+#define DESC_RATEVHTSS4MCS4		0x4E
+#define DESC_RATEVHTSS4MCS5		0x4F
+#define DESC_RATEVHTSS4MCS6		0x50
+#define DESC_RATEVHTSS4MCS7		0x51
+#define DESC_RATEVHTSS4MCS8		0x52
+#define DESC_RATEVHTSS4MCS9		0x53
+
+#define HDATA_RATE(rate)\
+	(rate == DESC_RATE1M) ? "CCK_1M" :\
+	(rate == DESC_RATE2M) ? "CCK_2M" :\
+	(rate == DESC_RATE5_5M) ? "CCK5_5M" :\
+	(rate == DESC_RATE11M) ? "CCK_11M" :\
+	(rate == DESC_RATE6M) ? "OFDM_6M" :\
+	(rate == DESC_RATE9M) ? "OFDM_9M" :\
+	(rate == DESC_RATE12M) ? "OFDM_12M" :\
+	(rate == DESC_RATE18M) ? "OFDM_18M" :\
+	(rate == DESC_RATE24M) ? "OFDM_24M" :\
+	(rate == DESC_RATE36M) ? "OFDM_36M" :\
+	(rate == DESC_RATE48M) ? "OFDM_48M" :\
+	(rate == DESC_RATE54M) ? "OFDM_54M" :\
+	(rate == DESC_RATEMCS0) ? "MCS0" :\
+	(rate == DESC_RATEMCS1) ? "MCS1" :\
+	(rate == DESC_RATEMCS2) ? "MCS2" :\
+	(rate == DESC_RATEMCS3) ? "MCS3" :\
+	(rate == DESC_RATEMCS4) ? "MCS4" :\
+	(rate == DESC_RATEMCS5) ? "MCS5" :\
+	(rate == DESC_RATEMCS6) ? "MCS6" :\
+	(rate == DESC_RATEMCS7) ? "MCS7" :\
+	(rate == DESC_RATEMCS8) ? "MCS8" :\
+	(rate == DESC_RATEMCS9) ? "MCS9" :\
+	(rate == DESC_RATEMCS10) ? "MCS10" :\
+	(rate == DESC_RATEMCS11) ? "MCS11" :\
+	(rate == DESC_RATEMCS12) ? "MCS12" :\
+	(rate == DESC_RATEMCS13) ? "MCS13" :\
+	(rate == DESC_RATEMCS14) ? "MCS14" :\
+	(rate == DESC_RATEMCS15) ? "MCS15" :\
+	(rate == DESC_RATEMCS16) ? "MCS16" :\
+	(rate == DESC_RATEMCS17) ? "MCS17" :\
+	(rate == DESC_RATEMCS18) ? "MCS18" :\
+	(rate == DESC_RATEMCS19) ? "MCS19" :\
+	(rate == DESC_RATEMCS20) ? "MCS20" :\
+	(rate == DESC_RATEMCS21) ? "MCS21" :\
+	(rate == DESC_RATEMCS22) ? "MCS22" :\
+	(rate == DESC_RATEMCS23) ? "MCS23" :\
+	(rate == DESC_RATEVHTSS1MCS0) ? "VHTSS1MCS0" :\
+	(rate == DESC_RATEVHTSS1MCS1) ? "VHTSS1MCS1" :\
+	(rate == DESC_RATEVHTSS1MCS2) ? "VHTSS1MCS2" :\
+	(rate == DESC_RATEVHTSS1MCS3) ? "VHTSS1MCS3" :\
+	(rate == DESC_RATEVHTSS1MCS4) ? "VHTSS1MCS4" :\
+	(rate == DESC_RATEVHTSS1MCS5) ? "VHTSS1MCS5" :\
+	(rate == DESC_RATEVHTSS1MCS6) ? "VHTSS1MCS6" :\
+	(rate == DESC_RATEVHTSS1MCS7) ? "VHTSS1MCS7" :\
+	(rate == DESC_RATEVHTSS1MCS8) ? "VHTSS1MCS8" :\
+	(rate == DESC_RATEVHTSS1MCS9) ? "VHTSS1MCS9" :\
+	(rate == DESC_RATEVHTSS2MCS0) ? "VHTSS2MCS0" :\
+	(rate == DESC_RATEVHTSS2MCS1) ? "VHTSS2MCS1" :\
+	(rate == DESC_RATEVHTSS2MCS2) ? "VHTSS2MCS2" :\
+	(rate == DESC_RATEVHTSS2MCS3) ? "VHTSS2MCS3" :\
+	(rate == DESC_RATEVHTSS2MCS4) ? "VHTSS2MCS4" :\
+	(rate == DESC_RATEVHTSS2MCS5) ? "VHTSS2MCS5" :\
+	(rate == DESC_RATEVHTSS2MCS6) ? "VHTSS2MCS6" :\
+	(rate == DESC_RATEVHTSS2MCS7) ? "VHTSS2MCS7" :\
+	(rate == DESC_RATEVHTSS2MCS8) ? "VHTSS2MCS8" :\
+	(rate == DESC_RATEVHTSS2MCS9) ? "VHTSS2MCS9" :\
+	(rate == DESC_RATEVHTSS3MCS0) ? "VHTSS3MCS0" :\
+	(rate == DESC_RATEVHTSS3MCS1) ? "VHTSS3MCS1" :\
+	(rate == DESC_RATEVHTSS3MCS2) ? "VHTSS3MCS2" :\
+	(rate == DESC_RATEVHTSS3MCS3) ? "VHTSS3MCS3" :\
+	(rate == DESC_RATEVHTSS3MCS4) ? "VHTSS3MCS4" :\
+	(rate == DESC_RATEVHTSS3MCS5) ? "VHTSS3MCS5" :\
+	(rate == DESC_RATEVHTSS3MCS6) ? "VHTSS3MCS6" :\
+	(rate == DESC_RATEVHTSS3MCS7) ? "VHTSS3MCS7" :\
+	(rate == DESC_RATEVHTSS3MCS8) ? "VHTSS3MCS8" :\
+	(rate == DESC_RATEVHTSS3MCS9) ? "VHTSS3MCS9" : "UNKNOWN"
+
+enum {
+	UP_LINK,
+	DOWN_LINK,
+};
+typedef enum _RT_MEDIA_STATUS {
+	RT_MEDIA_DISCONNECT = 0,
+	RT_MEDIA_CONNECT       = 1
+} RT_MEDIA_STATUS;
+
+#define MAX_DLFW_PAGE_SIZE			4096	/* @ page : 4k bytes */
+typedef enum _FIRMWARE_SOURCE {
+	FW_SOURCE_IMG_FILE = 0,
+	FW_SOURCE_HEADER_FILE = 1,		/* from header file */
+} FIRMWARE_SOURCE, *PFIRMWARE_SOURCE;
+
+typedef enum _CH_SW_USE_CASE {
+	CH_SW_USE_CASE_TDLS		= 0,
+	CH_SW_USE_CASE_MCC		= 1
+} CH_SW_USE_CASE;
+
+typedef enum _WAKEUP_REASON{
+	RX_PAIRWISEKEY					= 0x01,
+	RX_GTK							= 0x02,
+	RX_FOURWAY_HANDSHAKE			= 0x03,
+	RX_DISASSOC						= 0x04,
+	RX_DEAUTH						= 0x08,
+	RX_ARP_REQUEST					= 0x09,
+	FW_DECISION_DISCONNECT			= 0x10,
+	RX_MAGIC_PKT					= 0x21,
+	RX_UNICAST_PKT					= 0x22,
+	RX_PATTERN_PKT					= 0x23,
+	RTD3_SSID_MATCH					= 0x24,
+	RX_REALWOW_V2_WAKEUP_PKT		= 0x30,
+	RX_REALWOW_V2_ACK_LOST			= 0x31,
+	ENABLE_FAIL_DMA_IDLE			= 0x40,
+	ENABLE_FAIL_DMA_PAUSE			= 0x41,
+	RTIME_FAIL_DMA_IDLE				= 0x42,
+	RTIME_FAIL_DMA_PAUSE			= 0x43,
+	RX_PNO							= 0x55,
+	AP_OFFLOAD_WAKEUP				= 0x66,
+	CLK_32K_UNLOCK					= 0xFD,
+	CLK_32K_LOCK					= 0xFE
+}WAKEUP_REASON;
+
+/*
+ * 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
+
+/* 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 */
+#define TX_SELE_EQ			BIT(3)		/* Extern Queue */
+
+#define PageNum_128(_Len)		(u32)(((_Len)>>7) + ((_Len) & 0x7F ? 1 : 0))
+#define PageNum_256(_Len)		(u32)(((_Len)>>8) + ((_Len) & 0xFF ? 1 : 0))
+#define PageNum_512(_Len)		(u32)(((_Len)>>9) + ((_Len) & 0x1FF ? 1 : 0))
+#define PageNum(_Len, _Size)		(u32)(((_Len)/(_Size)) + ((_Len)&((_Size) - 1) ? 1 : 0))
+
+struct dbg_rx_counter {
+	u32	rx_pkt_ok;
+	u32	rx_pkt_crc_error;
+	u32	rx_pkt_drop;
+	u32	rx_ofdm_fa;
+	u32	rx_cck_fa;
+	u32	rx_ht_fa;
+};
+
+#ifdef CONFIG_MBSSID_CAM
+	#define DBG_MBID_CAM_DUMP
+
+	void rtw_mbid_cam_init(struct dvobj_priv *dvobj);
+	void rtw_mbid_cam_deinit(struct dvobj_priv *dvobj);
+	void rtw_mbid_cam_reset(_adapter *adapter);
+	u8 rtw_get_max_mbid_cam_id(_adapter *adapter);
+	u8 rtw_get_mbid_cam_entry_num(_adapter *adapter);
+	int rtw_mbid_cam_cache_dump(void *sel, const char *fun_name , _adapter *adapter);
+	int rtw_mbid_cam_dump(void *sel, const char *fun_name, _adapter *adapter);
+	void rtw_mbid_cam_restore(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	void rtw_hal_set_macaddr_mbid(_adapter *adapter, u8 *mac_addr);
+	void rtw_hal_change_macaddr_mbid(_adapter *adapter, u8 *mac_addr);
+	#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	u16 rtw_hal_bcn_interval_adjust(_adapter *adapter, u16 bcn_interval);
+	#endif
+#endif
+
+void rtw_dump_mac_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter);
+void rtw_dump_phy_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter);
+void rtw_reset_mac_rx_counters(_adapter *padapter);
+void rtw_reset_phy_rx_counters(_adapter *padapter);
+void rtw_reset_phy_trx_ok_counters(_adapter *padapter);
+
+#ifdef DBG_RX_COUNTER_DUMP
+	#define DUMP_DRV_RX_COUNTER	BIT0
+	#define DUMP_MAC_RX_COUNTER	BIT1
+	#define DUMP_PHY_RX_COUNTER	BIT2
+	#define DUMP_DRV_TRX_COUNTER_DATA	BIT3
+
+	void rtw_dump_phy_rxcnts_preprocess(_adapter *padapter, u8 rx_cnt_mode);
+	void rtw_dump_rx_counters(_adapter *padapter);
+#endif
+
+void dump_chip_info(HAL_VERSION	ChipVersion);
+void rtw_hal_config_rftype(PADAPTER  padapter);
+
+#define BAND_CAP_2G			BIT0
+#define BAND_CAP_5G			BIT1
+#define BAND_CAP_BIT_NUM	2
+
+#define BW_CAP_5M		BIT0
+#define BW_CAP_10M		BIT1
+#define BW_CAP_20M		BIT2
+#define BW_CAP_40M		BIT3
+#define BW_CAP_80M		BIT4
+#define BW_CAP_160M		BIT5
+#define BW_CAP_80_80M	BIT6
+#define BW_CAP_BIT_NUM	7
+
+#define PROTO_CAP_11B		BIT0
+#define PROTO_CAP_11G		BIT1
+#define PROTO_CAP_11N		BIT2
+#define PROTO_CAP_11AC		BIT3
+#define PROTO_CAP_BIT_NUM	4
+
+#define WL_FUNC_P2P			BIT0
+#define WL_FUNC_MIRACAST	BIT1
+#define WL_FUNC_TDLS		BIT2
+#define WL_FUNC_FTM			BIT3
+#define WL_FUNC_BIT_NUM		4
+
+#define TBTT_PROHIBIT_SETUP_TIME 0x04 /* 128us, unit is 32us */
+#define TBTT_PROHIBIT_HOLD_TIME 0x80 /* 4ms, unit is 32us*/
+#define TBTT_PROHIBIT_HOLD_TIME_STOP_BCN 0x64 /* 3.2ms unit is 32us*/
+
+int hal_spec_init(_adapter *adapter);
+void dump_hal_spec(void *sel, _adapter *adapter);
+
+bool hal_chk_band_cap(_adapter *adapter, u8 cap);
+bool hal_chk_bw_cap(_adapter *adapter, u8 cap);
+bool hal_chk_proto_cap(_adapter *adapter, u8 cap);
+bool hal_is_band_support(_adapter *adapter, u8 band);
+bool hal_is_bw_support(_adapter *adapter, u8 bw);
+bool hal_is_wireless_mode_support(_adapter *adapter, u8 mode);
+u8 hal_largest_bw(_adapter *adapter, u8 in_bw);
+
+bool hal_chk_wl_func(_adapter *adapter, u8 func);
+
+void hal_com_config_channel_plan(
+	IN	PADAPTER padapter,
+	IN	char *hw_alpha2,
+	IN	u8 hw_chplan,
+	IN	char *sw_alpha2,
+	IN	u8 sw_chplan,
+	IN	u8 def_chplan,
+	IN	BOOLEAN AutoLoadFail
+);
+
+int hal_config_macaddr(_adapter *adapter, bool autoload_fail);
+
+BOOLEAN
+HAL_IsLegalChannel(
+	IN	PADAPTER	Adapter,
+	IN	u32			Channel
+);
+
+u8	MRateToHwRate(u8 rate);
+
+u8	hw_rate_to_m_rate(u8 rate);
+
+void	HalSetBrateCfg(
+	IN PADAPTER		Adapter,
+	IN u8			*mBratesOS,
+	OUT u16			*pBrateCfg);
+
+BOOLEAN
+Hal_MappingOutPipe(
+	IN	PADAPTER	pAdapter,
+	IN	u8		NumOutPipe
+);
+
+void rtw_dump_fw_info(void *sel, _adapter *adapter);
+void rtw_restore_hw_port_cfg(_adapter *adapter);
+void rtw_restore_mac_addr(_adapter *adapter);/*set mac addr when hal_init for all iface*/
+void rtw_hal_dump_macaddr(void *sel, _adapter *adapter);
+
+void rtw_init_hal_com_default_value(PADAPTER Adapter);
+
+#ifdef CONFIG_FW_C2H_REG
+void c2h_evt_clear(_adapter *adapter);
+s32 c2h_evt_read_88xx(_adapter *adapter, u8 *buf);
+#endif
+
+#ifdef CONFIG_FW_C2H_PKT
+void rtw_hal_c2h_pkt_pre_hdl(_adapter *adapter, u8 *buf, u16 len);
+void rtw_hal_c2h_pkt_hdl(_adapter *adapter, u8 *buf, u16 len);
+#endif
+
+u8 rtw_get_mgntframe_raid(_adapter *adapter, unsigned char network_type);
+
+void rtw_hal_update_sta_wset(_adapter *adapter, struct sta_info *psta);
+s8 rtw_get_sta_rx_nss(_adapter *adapter, struct sta_info *psta);
+s8 rtw_get_sta_tx_nss(_adapter *adapter, struct sta_info *psta);
+void rtw_hal_update_sta_ra_info(PADAPTER padapter, struct sta_info *psta);
+
+/* access HW only */
+u32 rtw_sec_read_cam(_adapter *adapter, u8 addr);
+void rtw_sec_write_cam(_adapter *adapter, u8 addr, u32 wdata);
+void rtw_sec_read_cam_ent(_adapter *adapter, u8 id, u8 *ctrl, u8 *mac, u8 *key);
+void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key);
+void rtw_sec_clr_cam_ent(_adapter *adapter, u8 id);
+bool rtw_sec_read_cam_is_gk(_adapter *adapter, u8 id);
+
+u8 rtw_hal_rcr_check(_adapter *adapter, u32 check_bit);
+
+u8 rtw_hal_rcr_add(_adapter *adapter, u32 add);
+u8 rtw_hal_rcr_clear(_adapter *adapter, u32 clear);
+void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action);
+
+void hw_var_port_switch(_adapter *adapter);
+
+u8 SetHwReg(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg(PADAPTER padapter, u8 variable, u8 *val);
+void rtw_hal_check_rxfifo_full(_adapter *adapter);
+void rtw_hal_reqtxrpt(_adapter *padapter, u8 macid);
+
+u8 SetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value);
+u8 GetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value);
+
+BOOLEAN
+eqNByte(
+	u8	*str1,
+	u8	*str2,
+	u32	num
+);
+
+u32
+MapCharToHexDigit(
+	IN	char	chTmp
+);
+
+BOOLEAN
+GetHexValueFromString(
+	IN		char			*szStr,
+	IN OUT	u32			*pu4bVal,
+	IN OUT	u32			*pu4bMove
+);
+
+BOOLEAN
+GetFractionValueFromString(
+	IN		char		*szStr,
+	IN OUT	u8			*pInteger,
+	IN OUT	u8			*pFraction,
+	IN OUT	u32		*pu4bMove
+);
+
+BOOLEAN
+IsCommentString(
+	IN		char		*szStr
+);
+
+BOOLEAN
+ParseQualifiedString(
+	IN	char *In,
+	IN OUT  u32 *Start,
+	OUT	char *Out,
+	IN	char  LeftQualifier,
+	IN	char  RightQualifier
+);
+
+BOOLEAN
+GetU1ByteIntegerFromStringInDecimal(
+	IN		char *Str,
+	IN OUT	u8 *pInt
+);
+
+BOOLEAN
+isAllSpaceOrTab(
+	u8	*data,
+	u8	size
+);
+
+void linked_info_dump(_adapter *padapter, u8 benable);
+#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
+	void rtw_get_raw_rssi_info(void *sel, _adapter *padapter);
+	void rtw_dump_raw_rssi_info(_adapter *padapter, void *sel);
+#endif
+
+#ifdef DBG_RX_DFRAME_RAW_DATA
+	void rtw_dump_rx_dframe_info(_adapter *padapter, void *sel);
+#endif
+void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe);
+#define		HWSET_MAX_SIZE			1024
+
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+u32 Hal_readPGDataFromConfigFile(PADAPTER padapter);
+u32 Hal_ReadMACAddrFromFile(PADAPTER padapter, u8 *mac_addr);
+#endif /* CONFIG_EFUSE_CONFIG_FILE */
+
+int hal_efuse_macaddr_offset(_adapter *adapter);
+int Hal_GetPhyEfuseMACAddr(PADAPTER padapter, u8 *mac_addr);
+void rtw_dump_cur_efuse(PADAPTER padapter);
+
+#ifdef CONFIG_RF_POWER_TRIM
+	void rtw_bb_rf_gain_offset(_adapter *padapter);
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+void dm_DynamicUsbTxAgg(_adapter *padapter, u8 from_timer);
+u8 rtw_hal_busagg_qsel_check(_adapter *padapter, u8 pre_qsel, u8 next_qsel);
+
+u8 rtw_get_current_tx_rate(_adapter *padapter, struct sta_info *psta);
+u8 rtw_get_current_tx_sgi(_adapter *padapter, struct sta_info *psta);
+
+void rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished);
+u8 rtw_hal_get_rsvd_page_num(struct _ADAPTER *adapter);
+
+#ifdef CONFIG_TSF_RESET_OFFLOAD
+int rtw_hal_reset_tsf(_adapter *adapter, u8 reset_port);
+#endif
+
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		s32 rtw_hal_ch_sw_oper_offload(_adapter *padapter, u8 channel, u8 channel_offset, u16 bwmode);
+	#endif
+#endif
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+s32 rtw_hal_set_wifi_port_id_cmd(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_API
+	u8 rtw_hal_get_gpio(_adapter *adapter, u8 gpio_num);
+	int rtw_hal_set_gpio_output_value(_adapter *adapter, u8 gpio_num, bool isHigh);
+	int rtw_hal_config_gpio(_adapter *adapter, u8 gpio_num, bool isOutput);
+	int rtw_hal_register_gpio_interrupt(_adapter *adapter, int gpio_num, void(*callback)(u8 level));
+	int rtw_hal_disable_gpio_interrupt(_adapter *adapter, int gpio_num);
+#endif
+
+s8 rtw_hal_ch_sw_iqk_info_search(_adapter *padapter, u8 central_chnl, u8 bw_mode);
+void rtw_hal_ch_sw_iqk_info_backup(_adapter *adapter);
+void rtw_hal_ch_sw_iqk_info_restore(_adapter *padapter, u8 ch_sw_use_case);
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable);
+	void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval);
+	void rtw_hal_set_input_gpio(_adapter *padapter, u8 index);
+#endif
+
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	extern char *rtw_phy_file_path;
+	extern char rtw_phy_para_file_path[PATH_LENGTH_MAX];
+	#define GetLineFromBuffer(buffer)   strsep(&buffer, "\r\n")
+#endif
+
+void update_IOT_info(_adapter *padapter);
+
+void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap);
+void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf);
+
+void ResumeTxBeacon(_adapter *padapter);
+void StopTxBeacon(_adapter *padapter);
+#ifdef CONFIG_MI_WITH_MBSSID_CAM /*HW port0 - MBSS*/
+	void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode);
+	u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr);
+#endif
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	u8	rtw_hal_antdiv_before_linked(_adapter *padapter);
+	void	rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
+#endif
+
+#ifdef DBG_SEC_CAM_MOVE
+	void rtw_hal_move_sta_gk_to_dk(_adapter *adapter);
+	void rtw_hal_read_sta_dk_key(_adapter *adapter, u8 key_id);
+#endif
+
+#ifdef CONFIG_LPS_PG
+#define LPSPG_RSVD_PAGE_SET_MACID(_rsvd_pag, _value)		SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 0, 8, _value)/*used macid*/
+#define LPSPG_RSVD_PAGE_SET_MBSSCAMID(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 8, 8, _value)/*used BSSID CAM entry*/
+#define LPSPG_RSVD_PAGE_SET_PMC_NUM(_rsvd_pag, _value)		SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 16, 8, _value)/*Max used Pattern Match CAM entry*/
+#define LPSPG_RSVD_PAGE_SET_MU_RAID_GID(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 24, 8, _value)/*Max MU rate table Group ID*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_NUM(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x04, 0, 8, _value)/*used Security CAM entry number*/
+#define LPSPG_RSVD_PAGE_SET_DRV_RSVDPAGE_NUM(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x04, 8, 8, _value)/*Txbuf used page number for fw offload*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID1(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 0, 8, _value)/*used Security CAM entry -1*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID2(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 8, 8, _value)/*used Security CAM entry -2*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID3(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 16, 8, _value)/*used Security CAM entry -3*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID4(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 24, 8, _value)/*used Security CAM entry -4*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID5(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 0, 8, _value)/*used Security CAM entry -5*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID6(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 8, 8, _value)/*used Security CAM entry -6*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID7(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 16, 8, _value)/*used Security CAM entry -7*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID8(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 24, 8, _value)/*used Security CAM entry -8*/
+enum lps_pg_hdl_id {
+	LPS_PG_INFO_CFG = 0,
+	LPS_PG_REDLEMEM,
+	LPS_PG_RESEND_H2C,
+};
+
+	u8 rtw_hal_set_lps_pg_info(_adapter *adapter);
+#endif
+
+int rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset, u32 page_num, u8 *buffer, u32 buffer_size);
+void rtw_hal_construct_beacon(_adapter *padapter, u8 *pframe, u32 *pLength);
+void rtw_hal_construct_NullFunctionData(PADAPTER, u8 *pframe, u32 *pLength,
+				u8 *StaAddr, u8 bQoS, u8 AC, u8 bEosp, u8 bForcePowerSave);
+
+#ifdef CONFIG_WOWLAN
+struct rtl_wow_pattern {
+	u16	crc;
+	u8	type;
+	u32	mask[4];
+};
+void rtw_wow_pattern_cam_dump(_adapter *adapter);
+
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+void rtw_wow_pattern_read_cam_ent(_adapter *adapter, u8 id, struct  rtl_wow_pattern *context);
+void rtw_dump_wow_pattern(void *sel, struct rtl_wow_pattern *pwow_pattern, u8 idx);
+#endif
+
+struct rtw_ndp_info {
+	u8 enable:1;
+	u8 check_remote_ip:1; /* Need to Check Sender IP or not */
+	u8 rsvd:6;
+	u8 num_of_target_ip; /* Number of Check IP which NA query IP */
+	u8 target_link_addr[6]; /* DUT's MAC address */
+	u8 remote_ipv6_addr[16]; /* Just respond IP */
+	u8 target_ipv6_addr[16]; /* target IP */
+};
+#define REMOTE_INFO_CTRL_SET_VALD_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 0, 0, 8, _value)
+#define REMOTE_INFO_CTRL_SET_PTK_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 1, 0, 1, _value)
+#define REMOTE_INFO_CTRL_SET_GTK_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 1, 1, 1, _value)
+#define REMOTE_INFO_CTRL_SET_GTK_IDX(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 2, 0, 8, _value)
+#endif /*CONFIG_WOWLAN*/
+
+void rtw_dump_phy_cap(void *sel, _adapter *adapter);
+void rtw_dump_rsvd_page(void *sel, _adapter *adapter, u8 page_offset, u8 page_num);
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+void rtw_dump_fifo(void *sel, _adapter *adapter, u8 fifo_sel, u32 fifo_addr, u32 fifo_size);
+#endif
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+s32 rtw_hal_set_default_port_id_cmd(_adapter *adapter, u8 mac_id);
+s32 rtw_set_default_port_id(_adapter *adapter);
+s32 rtw_set_ps_rsvd_page(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_P2P_PS
+#ifdef RTW_HALMAC
+void rtw_set_p2p_ps_offload_cmd(_adapter *adapter, u8 p2p_ps_state);
+#endif
+#endif
+
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+void rtw_hal_switch_chnl_and_set_bw_offload(_adapter *adapter, u8 central_ch, u8 pri_ch_idx, u8 bw);
+#endif
+
+s16 translate_dbm_to_percentage(s16 signal);
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+#ifdef CONFIG_BCN_RECOVERY
+u8 rtw_ap_bcn_recovery(_adapter *padapter);
+#endif
+#ifdef CONFIG_BCN_XMIT_PROTECT
+u8 rtw_ap_bcn_queue_empty_check(_adapter *padapter, u32 txbcn_timer_ms);
+#endif
+#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
+
+void rtw_hal_get_rf_path(struct dvobj_priv *d, enum rf_type *type,
+			 enum bb_path *tx, enum bb_path *rx);
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+void rtw_hal_beamforming_config_csirate(PADAPTER adapter);
+#endif
+#endif
+#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_h2c.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_h2c.h
new file mode 100644
index 000000000000..06cd27342a1f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_h2c.h
@@ -0,0 +1,621 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __COMMON_H2C_H__
+#define __COMMON_H2C_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * 88e, 8723b, 8812, 8821, 92e use the same FW code base */
+enum h2c_cmd {
+	/* Common Class: 000 */
+	H2C_RSVD_PAGE = 0x00,
+	H2C_MEDIA_STATUS_RPT = 0x01,
+	H2C_SCAN_ENABLE = 0x02,
+	H2C_KEEP_ALIVE = 0x03,
+	H2C_DISCON_DECISION = 0x04,
+	H2C_PSD_OFFLOAD = 0x05,
+	H2C_CUSTOMER_STR_REQ = 0x06,
+	H2C_AP_OFFLOAD = 0x08,
+	H2C_BCN_RSVDPAGE = 0x09,
+	H2C_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_FCS_RSVDPAGE = 0x10,
+	H2C_FCS_INFO = 0x11,
+	H2C_AP_WOW_GPIO_CTRL = 0x13,
+#ifdef CONFIG_MCC_MODE
+	H2C_MCC_RQT_TSF = 0x15,
+	H2C_MCC_MACID_BITMAP = 0x16,
+	H2C_MCC_LOCATION = 0x10,
+	H2C_MCC_CTRL_V2 = 0x17,
+	H2C_MCC_CTRL = 0x18,
+	H2C_MCC_TIME_SETTING = 0x19,
+	H2C_MCC_IQK_PARAM = 0x1A,
+#endif /* CONFIG_MCC_MODE */
+	H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C,
+	H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D,
+
+	/* PoweSave Class: 001 */
+	H2C_SET_PWR_MODE = 0x20,
+	H2C_PS_TUNING_PARA = 0x21,
+	H2C_PS_TUNING_PARA2 = 0x22,
+	H2C_P2P_LPS_PARAM = 0x23,
+	H2C_P2P_PS_OFFLOAD = 0x24,
+	H2C_PS_SCAN_ENABLE = 0x25,
+	H2C_SAP_PS_ = 0x26,
+	H2C_INACTIVE_PS_ = 0x27, /* Inactive_PS */
+	H2C_FWLPS_IN_IPS_ = 0x28,
+#ifdef CONFIG_LPS_POFF
+	H2C_LPS_POFF_CTRL = 0x29,
+	H2C_LPS_POFF_PARAM = 0x2A,
+#endif
+#ifdef CONFIG_LPS_PG
+	H2C_LPS_PG_INFO = 0x2B,
+#endif
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	H2C_DEFAULT_PORT_ID = 0x2C,
+#endif
+	/* Dynamic Mechanism Class: 010 */
+	H2C_MACID_CFG = 0x40,
+	H2C_TXBF = 0x41,
+	H2C_RSSI_SETTING = 0x42,
+	H2C_AP_REQ_TXRPT = 0x43,
+	H2C_INIT_RATE_COLLECT = 0x44,
+	H2C_IQ_CALIBRATION	= 0x45,
+
+	H2C_RA_MASK_3SS = 0x46,/* for 8814A */
+	H2C_RA_PARA_ADJUST = 0x47,/* CONFIG_RA_DBG_CMD */
+	H2C_DYNAMIC_TX_PATH = 0x48,/* for 8814A */
+
+	H2C_FW_TRACE_EN = 0x49,
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	H2C_REQ_PER_RPT = 0x4e,
+#endif
+	/* BT Class: 011 */
+	H2C_B_TYPE_TDMA = 0x60,
+	H2C_BT_INFO = 0x61,
+	H2C_FORCE_BT_TXPWR = 0x62,
+	H2C_BT_IGNORE_WLANACT = 0x63,
+	H2C_DAC_SWING_VALUE = 0x64,
+	H2C_ANT_SEL_RSV = 0x65,
+	H2C_WL_OPMODE = 0x66,
+	H2C_BT_MP_OPER = 0x67,
+	H2C_BT_CONTROL = 0x68,
+	H2C_BT_WIFI_CTRL = 0x69,
+	H2C_BT_FW_PATCH = 0x6A,
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+	H2C_BTC_WL_PORT_ID = 0x71,
+#endif
+	/* WOWLAN Class: 100 */
+	H2C_WOWLAN = 0x80,
+	H2C_REMOTE_WAKE_CTRL = 0x81,
+	H2C_AOAC_GLOBAL_INFO = 0x82,
+	H2C_AOAC_RSVD_PAGE = 0x83,
+	H2C_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_AOAC_RSVDPAGE3 = 0x88,
+	H2C_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
+	H2C_P2P_OFFLOAD = 0x8B,
+
+	H2C_RESET_TSF = 0xC0,
+	H2C_BCNHWSEQ = 0xC5,
+	H2C_CUSTOMER_STR_W1 = 0xC6,
+	H2C_CUSTOMER_STR_W2 = 0xC7,
+	H2C_CUSTOMER_STR_W3 = 0xC8,
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	H2C_FW_DBG_MSG_PKT = 0xE1,
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+	H2C_MAXID,
+};
+
+#define H2C_INACTIVE_PS_LEN		3
+#define H2C_RSVDPAGE_LOC_LEN		5
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+#define H2C_DEFAULT_PORT_ID_LEN		2
+#define H2C_MEDIA_STATUS_RPT_LEN		4
+#else
+#define H2C_MEDIA_STATUS_RPT_LEN		3
+#endif
+#define H2C_KEEP_ALIVE_CTRL_LEN	2
+#define H2C_DISCON_DECISION_LEN		3
+#define H2C_AP_OFFLOAD_LEN		3
+#define H2C_AP_WOW_GPIO_CTRL_LEN	4
+#define H2C_AP_PS_LEN			2
+#define H2C_PWRMODE_LEN			7
+#define H2C_PSTUNEPARAM_LEN			4
+#define H2C_MACID_CFG_LEN		7
+#define H2C_BTMP_OPER_LEN			5
+#define H2C_WOWLAN_LEN			6
+#define H2C_REMOTE_WAKE_CTRL_LEN	3
+#define H2C_AOAC_GLOBAL_INFO_LEN	2
+#define H2C_AOAC_RSVDPAGE_LOC_LEN	7
+#define H2C_SCAN_OFFLOAD_CTRL_LEN	4
+#define H2C_BT_FW_PATCH_LEN			6
+#define H2C_RSSI_SETTING_LEN		4
+#define H2C_AP_REQ_TXRPT_LEN		3
+#define H2C_FORCE_BT_TXPWR_LEN		3
+#define H2C_BCN_RSVDPAGE_LEN		5
+#define H2C_PROBERSP_RSVDPAGE_LEN	5
+#define H2C_P2PRSVDPAGE_LOC_LEN	5
+#define H2C_P2P_OFFLOAD_LEN	3
+#ifdef CONFIG_MCC_MODE
+	#define H2C_MCC_CTRL_LEN			7
+#ifdef CONFIG_MCC_MODE_V2
+	#define H2C_MCC_LOCATION_LEN		7
+#else
+	#define H2C_MCC_LOCATION_LEN		3
+#endif
+	#define H2C_MCC_MACID_BITMAP_LEN	6
+	#define H2C_MCC_RQT_TSF_LEN		1
+	#define H2C_MCC_TIME_SETTING_LEN		6
+	#define H2C_MCC_IQK_PARAM_LEN		7
+#endif /* CONFIG_MCC_MODE */
+#ifdef CONFIG_LPS_PG
+	#define H2C_LPS_PG_INFO_LEN		2
+	#define H2C_LPSPG_LEN			16
+#endif
+#ifdef CONFIG_LPS_POFF
+	#define H2C_LPS_POFF_CTRL_LEN		1
+	#define H2C_LPS_POFF_PARAM_LEN		5
+#endif
+
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+#define H2C_BTC_WL_PORT_ID_LEN	1
+#endif
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	#define H2C_FW_DBG_MSG_PKT_LEN	2
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+#define H2C_SINGLE_CHANNELSWITCH_V2_LEN 2
+
+#define eq_mac_addr(a, b)						(((a)[0] == (b)[0] && (a)[1] == (b)[1] && (a)[2] == (b)[2] && (a)[3] == (b)[3] && (a)[4] == (b)[4] && (a)[5] == (b)[5]) ? 1 : 0)
+#define cp_mac_addr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3], (des)[4] = (src)[4], (des)[5] = (src)[5])
+#define cpIpAddr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3])
+
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+/*
+* ARP packet
+*
+* LLC Header */
+#define GET_ARP_PKT_LLC_TYPE(__pHeader)					ReadLE2Byte(((u8 *)(__pHeader)) + 6)
+
+/* ARP element */
+#define GET_ARP_PKT_OPERATION(__pHeader)				ReadLE2Byte(((u8 *)(__pHeader)) + 6)
+#define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+8)
+#define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+14)
+#define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+18)
+#define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)	cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+24)
+
+#define SET_ARP_PKT_HW(__pHeader, __Value)					WriteLE2Byte(((u8 *)(__pHeader)) + 0, __Value)
+#define SET_ARP_PKT_PROTOCOL(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 2, __Value)
+#define SET_ARP_PKT_HW_ADDR_LEN(__pHeader, __Value)			WriteLE1Byte(((u8 *)(__pHeader)) + 4, __Value)
+#define SET_ARP_PKT_PROTOCOL_ADDR_LEN(__pHeader, __Value)	WriteLE1Byte(((u8 *)(__pHeader)) + 5, __Value)
+#define SET_ARP_PKT_OPERATION(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 6, __Value)
+#define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cp_mac_addr(((u8 *)(__pHeader))+8, (u8 *)(_val))
+#define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+14, (u8 *)(_val))
+#define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cp_mac_addr(((u8 *)(__pHeader))+18, (u8 *)(_val))
+#define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+24, (u8 *)(_val))
+
+#define FW_WOWLAN_FUN_EN				BIT(0)
+#define FW_WOWLAN_PATTERN_MATCH			BIT(1)
+#define FW_WOWLAN_MAGIC_PKT				BIT(2)
+#define FW_WOWLAN_UNICAST				BIT(3)
+#define FW_WOWLAN_ALL_PKT_DROP			BIT(4)
+#define FW_WOWLAN_GPIO_ACTIVE			BIT(5)
+#define FW_WOWLAN_REKEY_WAKEUP			BIT(6)
+#define FW_WOWLAN_DEAUTH_WAKEUP			BIT(7)
+
+#define FW_WOWLAN_GPIO_WAKEUP_EN		BIT(0)
+#define FW_FW_PARSE_MAGIC_PKT			BIT(1)
+
+#define FW_REMOTE_WAKE_CTRL_EN			BIT(0)
+#define FW_REALWOWLAN_EN				BIT(5)
+
+#define FW_WOWLAN_KEEP_ALIVE_EN			BIT(0)
+#define FW_ADOPT_USER					BIT(1)
+#define FW_WOWLAN_KEEP_ALIVE_PKT_TYPE	BIT(2)
+
+#define FW_REMOTE_WAKE_CTRL_EN			BIT(0)
+#define FW_ARP_EN						BIT(1)
+#define FW_REALWOWLAN_EN				BIT(5)
+#define FW_WOW_FW_UNICAST_EN			BIT(7)
+
+#endif /* CONFIG_WOWLAN */
+
+/* _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _MEDIA_STATUS_RPT_PARM_CMD_0x01 */
+#define SET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 1, 1, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 2, 1, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 3, 1, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 4, 4, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 2, 0, 8, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_PORT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 3, 0, 3, (__Value))
+
+#define GET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 0, 1)
+#define GET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 2, 1)
+#define GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(__pH2CCmd)	LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 3, 1)
+#define GET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd)			LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 4, 4)
+
+#define H2C_MSR_ROLE_RSVD	0
+#define H2C_MSR_ROLE_STA	1
+#define H2C_MSR_ROLE_AP		2
+#define H2C_MSR_ROLE_GC		3
+#define H2C_MSR_ROLE_GO		4
+#define H2C_MSR_ROLE_TDLS	5
+#define H2C_MSR_ROLE_ADHOC	6
+#define H2C_MSR_ROLE_MESH	7
+#define H2C_MSR_ROLE_MAX	8
+
+extern const char *const _h2c_msr_role_str[];
+#define h2c_msr_role_str(role) (((role) >= H2C_MSR_ROLE_MAX) ? _h2c_msr_role_str[H2C_MSR_ROLE_MAX] : _h2c_msr_role_str[(role)])
+
+#define H2C_MSR_FMT "%s %s%s"
+#define H2C_MSR_ARG(h2c_msr) \
+	GET_H2CCMD_MSRRPT_PARM_OPMODE((h2c_msr)) ? " C" : "", \
+	h2c_msr_role_str(GET_H2CCMD_MSRRPT_PARM_ROLE((h2c_msr))), \
+	GET_H2CCMD_MSRRPT_PARM_MIRACAST((h2c_msr)) ? (GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK((h2c_msr)) ? " MSINK" : " MSRC") : ""
+
+s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, bool macid_ind, u8 macid_end);
+s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid);
+s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end);
+
+/* _KEEP_ALIVE_CMD_0x03 */
+#define SET_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 3, __Value)
+#define SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _DISCONNECT_DECISION_CMD_0x04 */
+#define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_DISCONDECISION_PORT_NUM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 3, __Value)
+#define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+#define RTW_CUSTOMER_STR_LEN 16
+#define RTW_CUSTOMER_STR_FMT "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x"
+#define RTW_CUSTOMER_STR_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
+	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9], ((u8 *)(x))[10], ((u8 *)(x))[11], \
+	((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15]
+
+/* H2C_CUSTOMER_STR_REQ  0x06 */
+#define H2C_CUSTOMER_STR_REQ_LEN 1
+#define SET_H2CCMD_CUSTOMER_STR_REQ_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
+s32 rtw_hal_h2c_customer_str_req(_adapter *adapter);
+s32 rtw_hal_customer_str_read(_adapter *adapter, u8 *cs);
+
+/* H2C_CUSTOMER_STR_W1 0xC6 */
+#define H2C_CUSTOMER_STR_W1_LEN 7
+#define SET_H2CCMD_CUSTOMER_STR_W1_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
+#define H2CCMD_CUSTOMER_STR_W1_BYTE0(__pH2CCmd)				(((u8 *)(__pH2CCmd)) + 1)
+
+/* H2C_CUSTOMER_STR_W2 0xC7 */
+#define H2C_CUSTOMER_STR_W2_LEN 7
+#define SET_H2CCMD_CUSTOMER_STR_W2_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
+#define H2CCMD_CUSTOMER_STR_W2_BYTE6(__pH2CCmd)				(((u8 *)(__pH2CCmd)) + 1)
+
+/* H2C_CUSTOMER_STR_W3 0xC8 */
+#define H2C_CUSTOMER_STR_W3_LEN 5
+#define SET_H2CCMD_CUSTOMER_STR_W3_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
+#define H2CCMD_CUSTOMER_STR_W3_BYTE12(__pH2CCmd)			(((u8 *)(__pH2CCmd)) + 1)
+s32 rtw_hal_h2c_customer_str_write(_adapter *adapter, const u8 *cs);
+s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
+#endif /* CONFIG_RTW_CUSTOMER_STR */
+
+/* _AP_Offload 0x08 */
+#define SET_H2CCMD_AP_WOWLAN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+/* _BCN_RsvdPage	0x09 */
+#define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+/* _Probersp_RsvdPage 0x0a */
+#define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+/* _Probersp_RsvdPage 0x13 */
+#define SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
+#define SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
+#define SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
+#define SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+/* _AP_PS 0x26 */
+#define SET_H2CCMD_AP_WOW_PS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_AP_WOW_PS_32K_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+
+#ifdef CONFIG_LPS_POFF
+/*PARTIAL OFF Control 0x29*/
+#define SET_H2CCMD_LPS_POFF_CTRL_EN(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+/*PARTIAL OFF PARAM   0x2A*/
+#define SET_H2CCMD_LPS_POFF_PARAM_RDVLD(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_WRVLD(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_STARTADDL(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_STARTADDH(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_ENDADDL(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_ENDADDH(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#endif
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+/* DEFAULT PORT ID 0x2C*/
+#define SET_H2CCMD_DFTPID_PORT_ID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 8, (__Value))
+#define SET_H2CCMD_DFTPID_MAC_ID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
+#endif
+
+#ifdef CONFIG_MCC_MODE
+/* MCC LOC CMD 0x10 */
+#define SET_H2CCMD_MCC_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 0, 1, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_RFNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 4, 4, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 4, 0, 8, __Value)
+
+/* MCC RQT TSF 0x15 */
+#define SET_H2CCMD_MCC_RQT_TSFX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_RQT_TSFY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+
+/* MCC MAC ID CMD 0x16 */
+#define SET_H2CCMD_MCC_MACID_BITMAP_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_MCC_MACID_BITMAP_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+
+/* NEW MCC CTRL CMD 0x17 */
+#define SET_H2CCMD_MCC_CTRL_V2_ORDER(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_CENTRAL_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_PRIMARY_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_BW(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_ROLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)			
+#define SET_H2CCMD_MCC_CTRL_V2_INCURCH(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DIS_SW_RETRY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DISTXNULL(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_C2HRPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 6, 2, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_TSFX(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_NULL_EARLY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_UPDATE_PARM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
+
+
+/* MCC CTRL CMD 0x18 */
+#define SET_H2CCMD_MCC_CTRL_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_CHIDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
+#define SET_H2CCMD_MCC_CTRL_BW40SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 3, __Value)
+#define SET_H2CCMD_MCC_CTRL_BW80SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 5, 3, __Value)
+#define SET_H2CCMD_MCC_CTRL_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_ROLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)
+#define SET_H2CCMD_MCC_CTRL_INCURCH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_RSVD0(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_RSVD1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_RFETYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_DISTXNULL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 4, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_C2HRPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 5, 2, __Value)
+#define SET_H2CCMD_MCC_CTRL_CHSCAN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
+
+/* MCC Time CMD 0x19 */
+#define SET_H2CCMD_MCC_TIME_SETTING_FW_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_START_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 4, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_UPDATE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 1, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 1, 7, __Value)
+
+/* MCC IQK CMD 0x1A */
+#define SET_H2CCMD_MCC_IQK_READY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_MCC_IQK_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 4, __Value)
+#define SET_H2CCMD_MCC_IQK_PATH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 2, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 6, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 4, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 3, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 3, 5, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 6, __Value)
+#endif /* CONFIG_MCC_MODE */
+
+/* CHNL SWITCH OPER OFFLOAD 0x1C */
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 2, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 2, 3, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 5, 3, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 2, 0, 4, __Value)
+
+/* H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D */
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_CENTRAL_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_PRIMARY_CH_IDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 4, __Value)
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 4, 4, __Value)
+
+
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+#define SET_H2CCMD_BTC_WL_PORT_ID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#endif
+
+/* _WoWLAN PARAM_CMD_0x80 */
+#define SET_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_H2CCMD_WOWLAN_ALL_PKT_DROP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_ACTIVE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
+#define SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
+#define SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIONUM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 7, __Value)
+#define SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 7, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 1, 7, __Value)
+#define SET_H2CCMD_WOWLAN_DISABLE_UPHY(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 1, __Value)
+#define SET_H2CCMD_WOWLAN_HST2DEV_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 1, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_DURATION_MS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
+#define SET_H2CCMD_WOWLAN_CHANGE_UNIT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
+#define SET_H2CCMD_WOWLAN_UNIT_FOR_UPHY_DISABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
+#define SET_H2CCMD_WOWLAN_TAKE_PDN_UPHY_DIS_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
+
+/* _REMOTE_WAKEUP_CMD_0x81 */
+#define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 2, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 3, 1, __Value)
+
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 1, __Value)
+
+/* AOAC_GLOBAL_INFO_0x82 */
+#define SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+
+/* AOAC_RSVDPAGE_LOC_0x83 */
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#ifdef CONFIG_GTK_OL
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#endif /* CONFIG_GTK_OL */
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NDP_INFO(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 8, __Value)
+
+/* AOAC_RSVDPAGE_2_0x84 */
+
+/* AOAC_RSVDPAGE_3_0x88 */
+#ifdef CONFIG_PNO_SUPPORT
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
+#endif
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_AOAC_REPORT(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 8, __Value)
+
+#ifdef CONFIG_PNO_SUPPORT
+/* D0_Scan_Offload_Info_0x86 */
+#define SET_H2CCMD_AOAC_NLO_FUN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 3, 1, __Value)
+#define SET_H2CCMD_AOAC_NLO_IPS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 4, 1, __Value)
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#endif /* CONFIG_PNO_SUPPORT */
+
+#ifdef CONFIG_P2P_WOWLAN
+/* P2P_RsvdPage_0x8a */
+#define SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#endif /* CONFIG_P2P_WOWLAN */
+
+#ifdef CONFIG_LPS_PG
+#define SET_H2CCMD_LPSPG_SEC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*SecurityCAM_En*/
+#define SET_H2CCMD_LPSPG_MBID_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)/*BSSIDCAM_En*/
+#define SET_H2CCMD_LPSPG_PMC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)/*PatternMatchCAM_En*/
+#define SET_H2CCMD_LPSPG_MACID_SEARCH_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)/*MACIDSearch_En*/
+#define SET_H2CCMD_LPSPG_TXSC_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)/*TXSC_En*/
+#define SET_H2CCMD_LPSPG_MU_RATE_TB_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)/*MURateTable_En*/
+#define SET_H2CCMD_LPSPG_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)/*Loc_LPS_PG*/
+#endif
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+#define SET_H2CCMD_FW_DBG_MSG_PKT_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*sniffer_dbg_en*/
+#define SET_H2CCMD_RSVDPAGE_LOC_FW_DBG_MSG_PKT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) /*loc_debug_packet*/
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+typedef struct _RSVDPAGE_LOC {
+	u8 LocProbeRsp;
+	u8 LocPsPoll;
+	u8 LocNullData;
+	u8 LocQosNull;
+	u8 LocBTQosNull;
+#ifdef CONFIG_WOWLAN
+	u8 LocRemoteCtrlInfo;
+	u8 LocArpRsp;
+	u8 LocNbrAdv;
+	u8 LocGTKRsp;
+	u8 LocGTKInfo;
+	u8 LocProbeReq;
+	u8 LocNetList;
+#ifdef CONFIG_GTK_OL
+	u8 LocGTKEXTMEM;
+#endif /* CONFIG_GTK_OL */
+	u8 LocNDPInfo;
+	u8 LocAOACReport;
+#ifdef CONFIG_PNO_SUPPORT
+	u8 LocPNOInfo;
+	u8 LocScanInfo;
+	u8 LocSSIDInfo;
+	u8 LocProbePacket;
+#endif /* CONFIG_PNO_SUPPORT */
+#endif /* CONFIG_WOWLAN	 */
+	u8 LocApOffloadBCN;
+#ifdef CONFIG_P2P_WOWLAN
+	u8 LocP2PBeacon;
+	u8 LocP2PProbeRsp;
+	u8 LocNegoRsp;
+	u8 LocInviteRsp;
+	u8 LocPDRsp;
+#endif /* CONFIG_P2P_WOWLAN */
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	u8 loc_fw_dbg_msg_pkt;
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+} RSVDPAGE_LOC, *PRSVDPAGE_LOC;
+
+#endif
+void dump_TX_FIFO(PADAPTER padapter, u8 page_num, u16 page_size);
+u8 rtw_hal_set_fw_media_status_cmd(_adapter *adapter, u8 mstatus, u8 macid);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	/* WOW command function */
+	void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable);
+	#ifdef CONFIG_P2P_WOWLAN
+		/* H2C 0x8A */
+		u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc);
+		/* H2C 0x8B */
+		u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter);
+	#endif /* CONFIG_P2P_WOWLAN */
+#endif
+
+#ifdef RTW_PER_CMD_SUPPORT_FW
+u8 rtw_hal_set_req_per_rpt_cmd(_adapter *adapter, u8 group_macid,
+			       u8 rpt_type, u32 macid_bitmap);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_led.h
new file mode 100644
index 000000000000..d88556df7dcd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_led.h
@@ -0,0 +1,437 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_LED_H_
+#define __HAL_COMMON_LED_H_
+
+#define NO_LED 0
+#define HW_LED 1
+
+#ifdef CONFIG_RTW_LED
+#define MSECS(t)        (HZ * ((t) / 1000) + (HZ * ((t) % 1000)) / 1000)
+
+/* ********************************************************************************
+ *	LED Behavior Constant.
+ * ********************************************************************************
+ * Default LED behavior.
+ *   */
+#define LED_BLINK_NORMAL_INTERVAL	100
+#define LED_BLINK_SLOWLY_INTERVAL	200
+#define LED_BLINK_LONG_INTERVAL	400
+#define LED_INITIAL_INTERVAL		1800
+
+/* LED Customerization */
+
+/* NETTRONIX */
+#define LED_BLINK_NORMAL_INTERVAL_NETTRONIX	100
+#define LED_BLINK_SLOWLY_INTERVAL_NETTRONIX	2000
+
+/* PORNET */
+#define LED_BLINK_SLOWLY_INTERVAL_PORNET	1000
+#define LED_BLINK_NORMAL_INTERVAL_PORNET	100
+#define LED_BLINK_FAST_INTERVAL_BITLAND		30
+
+/* AzWave. */
+#define LED_CM2_BLINK_ON_INTERVAL		250
+#define LED_CM2_BLINK_OFF_INTERVAL		4750
+#define LED_CM8_BLINK_OFF_INTERVAL		3750	/* for QMI */
+
+/* RunTop */
+#define LED_RunTop_BLINK_INTERVAL		300
+
+/* ALPHA */
+#define LED_BLINK_NO_LINK_INTERVAL_ALPHA	1000
+#define LED_BLINK_NO_LINK_INTERVAL_ALPHA_500MS 500 /* add by ylb 20121012 for customer led for alpha */
+#define LED_BLINK_LINK_INTERVAL_ALPHA		500	/* 500 */
+#define LED_BLINK_SCAN_INTERVAL_ALPHA		180	/* 150 */
+#define LED_BLINK_FASTER_INTERVAL_ALPHA		50
+#define LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA	5000
+
+/* 111122 by hpfan: Customized for Xavi */
+#define LED_CM11_BLINK_INTERVAL			300
+#define LED_CM11_LINK_ON_INTERVEL		3000
+
+/* Netgear */
+#define LED_BLINK_LINK_INTERVAL_NETGEAR		500
+#define LED_BLINK_LINK_SLOWLY_INTERVAL_NETGEAR		1000
+
+#define LED_WPS_BLINK_OFF_INTERVAL_NETGEAR		100
+#define LED_WPS_BLINK_ON_INTERVAL_NETGEAR		500
+
+/* Belkin AC950 */
+#define LED_BLINK_LINK_INTERVAL_ON_BELKIN		200
+#define LED_BLINK_LINK_INTERVAL_OFF_BELKIN		100
+#define LED_BLINK_ERROR_INTERVAL_BELKIN		100
+
+/* by chiyokolin for Azurewave */
+#define LED_CM12_BLINK_INTERVAL_5Mbps		160
+#define LED_CM12_BLINK_INTERVAL_10Mbps		80
+#define LED_CM12_BLINK_INTERVAL_20Mbps		50
+#define LED_CM12_BLINK_INTERVAL_40Mbps		40
+#define LED_CM12_BLINK_INTERVAL_80Mbps		30
+#define LED_CM12_BLINK_INTERVAL_MAXMbps		25
+
+/* Dlink */
+#define	LED_BLINK_NO_LINK_INTERVAL		1000
+#define	LED_BLINK_LINK_IDEL_INTERVAL		100
+
+#define	LED_BLINK_SCAN_ON_INTERVAL		30
+#define	LED_BLINK_SCAN_OFF_INTERVAL		300
+
+#define LED_WPS_BLINK_ON_INTERVAL_DLINK		30
+#define LED_WPS_BLINK_OFF_INTERVAL_DLINK			300
+#define LED_WPS_BLINK_LINKED_ON_INTERVAL_DLINK			5000
+
+/* ********************************************************************************
+ * LED object.
+ * ******************************************************************************** */
+
+typedef enum _LED_CTL_MODE {
+	LED_CTL_POWER_ON = 1,
+	LED_CTL_LINK = 2,
+	LED_CTL_NO_LINK = 3,
+	LED_CTL_TX = 4, /* unspecific data TX, including single & group addressed */
+	LED_CTL_RX = 5, /* unspecific data RX, including single & group addressed */
+	LED_CTL_UC_TX = 6, /* single addressed data TX */
+	LED_CTL_UC_RX = 7, /* single addressed data RX */
+	LED_CTL_BMC_TX = 8, /* group addressed data TX */
+	LED_CTL_BMC_RX = 9, /* group addressed data RX */
+	LED_CTL_SITE_SURVEY = 10,
+	LED_CTL_POWER_OFF = 11,
+	LED_CTL_START_TO_LINK = 12,
+	LED_CTL_START_WPS = 13,
+	LED_CTL_STOP_WPS = 14,
+	LED_CTL_START_WPS_BOTTON = 15, /* added for runtop */
+	LED_CTL_STOP_WPS_FAIL = 16, /* added for ALPHA	 */
+	LED_CTL_STOP_WPS_FAIL_OVERLAP = 17, /* added for BELKIN */
+	LED_CTL_CONNECTION_NO_TRANSFER = 18,
+} LED_CTL_MODE;
+
+typedef	enum _LED_STATE {
+	LED_UNKNOWN = 0,
+	RTW_LED_ON = 1,
+	RTW_LED_OFF = 2,
+	LED_BLINK_NORMAL = 3,
+	LED_BLINK_SLOWLY = 4,
+	LED_BLINK_POWER_ON = 5,
+	LED_BLINK_SCAN = 6,	/* LED is blinking during scanning period, the # of times to blink is depend on time for scanning. */
+	LED_BLINK_NO_LINK = 7, /* LED is blinking during no link state. */
+	LED_BLINK_StartToBlink = 8, /* Customzied for Sercomm Printer Server case */
+	LED_BLINK_TXRX = 9,
+	LED_BLINK_WPS = 10,	/* LED is blinkg during WPS communication */
+	LED_BLINK_WPS_STOP = 11,	/* for ALPHA */
+	LED_BLINK_WPS_STOP_OVERLAP = 12,	/* for BELKIN */
+	LED_BLINK_RUNTOP = 13,	/* Customized for RunTop */
+	LED_BLINK_CAMEO = 14,
+	LED_BLINK_XAVI = 15,
+	LED_BLINK_ALWAYS_ON = 16,
+	LED_BLINK_LINK_IN_PROCESS = 17,  /* Customized for Belkin AC950 */
+	LED_BLINK_AUTH_ERROR = 18,  /* Customized for Belkin AC950 */
+	LED_BLINK_Azurewave_5Mbps = 19,
+	LED_BLINK_Azurewave_10Mbps = 20,
+	LED_BLINK_Azurewave_20Mbps = 21,
+	LED_BLINK_Azurewave_40Mbps = 22,
+	LED_BLINK_Azurewave_80Mbps = 23,
+	LED_BLINK_Azurewave_MAXMbps = 24,
+	LED_BLINK_LINK_IDEL = 25,
+	LED_BLINK_WPS_LINKED = 26,
+} LED_STATE;
+
+typedef enum _LED_PIN {
+	LED_PIN_GPIO0,
+	LED_PIN_LED0,
+	LED_PIN_LED1,
+	LED_PIN_LED2
+} LED_PIN;
+
+
+/* ********************************************************************************
+ * PCIE LED Definition.
+ * ******************************************************************************** */
+#ifdef CONFIG_PCI_HCI
+typedef	enum _LED_STRATEGY_PCIE {
+	/* start from 2 */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE1, /* SW control for PCI Express */
+	SW_LED_MODE2, /* SW control for Cameo. */
+	SW_LED_MODE3, /* SW contorl for RunTop. */
+	SW_LED_MODE4, /* SW control for Netcore */
+	SW_LED_MODE5, /* added by vivi, for led new mode, DLINK */
+	SW_LED_MODE6, /* added by vivi, for led new mode, PRONET */
+	SW_LED_MODE7, /* added by chiyokolin, for Lenovo, PCI Express Minicard Spec Rev.1.2 spec */
+	SW_LED_MODE8, /* added by chiyokolin, for QMI */
+	SW_LED_MODE9, /* added by chiyokolin, for BITLAND-LENOVO, PCI Express Minicard Spec Rev.1.1	 */
+	SW_LED_MODE10, /* added by chiyokolin, for Edimax-ASUS */
+	SW_LED_MODE11,	/* added by hpfan, for Xavi */
+	SW_LED_MODE12,	/* added by chiyokolin, for Azurewave */
+} LED_STRATEGY_PCIE, *PLED_STRATEGY_PCIE;
+
+typedef struct _LED_PCIE {
+	PADAPTER		padapter;
+
+	LED_PIN			LedPin;	/* Identify how to implement this SW led. */
+
+	LED_STATE		CurrLedState; /* Current LED state. */
+	BOOLEAN			bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
+
+	BOOLEAN			bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
+	BOOLEAN			bLedWPSBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
+
+	BOOLEAN			bLedSlowBlinkInProgress;/* added by vivi, for led new mode */
+	u32				BlinkTimes; /* Number of times to toggle led state for blinking. */
+	LED_STATE		BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
+
+	_timer			BlinkTimer; /* Timer object for led blinking. */
+} LED_PCIE, *PLED_PCIE;
+
+typedef struct _LED_PCIE	LED_DATA, *PLED_DATA;
+typedef enum _LED_STRATEGY_PCIE	LED_STRATEGY, *PLED_STRATEGY;
+
+VOID
+LedControlPCIE(
+	IN	PADAPTER		Adapter,
+	IN	LED_CTL_MODE		LedAction
+);
+
+VOID
+gen_RefreshLedState(
+	IN	PADAPTER		Adapter);
+
+/* ********************************************************************************
+ * USB  LED Definition.
+ * ******************************************************************************** */
+#elif defined(CONFIG_USB_HCI)
+
+#define IS_LED_WPS_BLINKING(_LED_USB)	(((PLED_USB)_LED_USB)->CurrLedState == LED_BLINK_WPS \
+		|| ((PLED_USB)_LED_USB)->CurrLedState == LED_BLINK_WPS_STOP \
+		|| ((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress)
+
+#define IS_LED_BLINKING(_LED_USB)	(((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress \
+		|| ((PLED_USB)_LED_USB)->bLedScanBlinkInProgress)
+
+
+typedef	enum _LED_STRATEGY_USB {
+	/* start from 2 */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
+	SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
+	SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
+	SW_LED_MODE4, /* for Edimax / Belkin */
+	SW_LED_MODE5, /* for Sercomm / Belkin	 */
+	SW_LED_MODE6,	/* for 88CU minicard, porting from ce SW_LED_MODE7 */
+	SW_LED_MODE7,	/* for Netgear special requirement */
+	SW_LED_MODE8, /* for LC */
+	SW_LED_MODE9, /* for Belkin AC950 */
+	SW_LED_MODE10, /* for Netgear A6200V2 */
+	SW_LED_MODE11, /* for Edimax / ASUS */
+	SW_LED_MODE12, /* for WNC/NEC */
+	SW_LED_MODE13, /* for Netgear A6100, 8811Au */
+	SW_LED_MODE14, /* for Buffalo, DNI, 8811Au */
+	SW_LED_MODE15, /* for DLINK,  8811Au/8812AU	 */
+} LED_STRATEGY_USB, *PLED_STRATEGY_USB;
+
+
+typedef struct _LED_USB {
+	PADAPTER			padapter;
+
+	LED_PIN				LedPin;	/* Identify how to implement this SW led. */
+
+	LED_STATE			CurrLedState; /* Current LED state. */
+	BOOLEAN				bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
+
+	BOOLEAN				bSWLedCtrl;
+
+	BOOLEAN				bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
+	/* ALPHA, added by chiyoko, 20090106 */
+	BOOLEAN				bLedNoLinkBlinkInProgress;
+	BOOLEAN				bLedLinkBlinkInProgress;
+	BOOLEAN				bLedStartToLinkBlinkInProgress;
+	BOOLEAN				bLedScanBlinkInProgress;
+	BOOLEAN				bLedWPSBlinkInProgress;
+
+	u32					BlinkTimes; /* Number of times to toggle led state for blinking. */
+	u8					BlinkCounter; /* Added for turn off overlap led after blinking a while, by page, 20120821 */
+	LED_STATE			BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
+
+	_timer				BlinkTimer; /* Timer object for led blinking. */
+
+	_workitem			BlinkWorkItem; /* Workitem used by BlinkTimer to manipulate H/W to blink LED.' */
+} LED_USB, *PLED_USB;
+
+typedef struct _LED_USB	LED_DATA, *PLED_DATA;
+typedef enum _LED_STRATEGY_USB	LED_STRATEGY, *PLED_STRATEGY;
+#ifdef CONFIG_RTW_SW_LED
+VOID
+LedControlUSB(
+	IN	PADAPTER		Adapter,
+	IN	LED_CTL_MODE		LedAction
+);
+#endif
+
+
+/* ********************************************************************************
+ * SDIO LED Definition.
+ * ******************************************************************************** */
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+#define IS_LED_WPS_BLINKING(_LED_SDIO)	(((PLED_SDIO)_LED_SDIO)->CurrLedState == LED_BLINK_WPS \
+		|| ((PLED_SDIO)_LED_SDIO)->CurrLedState == LED_BLINK_WPS_STOP \
+		|| ((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress)
+
+#define IS_LED_BLINKING(_LED_SDIO)	(((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress \
+		|| ((PLED_SDIO)_LED_SDIO)->bLedScanBlinkInProgress)
+
+
+typedef	enum _LED_STRATEGY_SDIO {
+	/* start from 2 */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
+	SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
+	SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
+	SW_LED_MODE4, /* for Edimax / Belkin */
+	SW_LED_MODE5, /* for Sercomm / Belkin	 */
+	SW_LED_MODE6,	/* for 88CU minicard, porting from ce SW_LED_MODE7 */
+} LED_STRATEGY_SDIO, *PLED_STRATEGY_SDIO;
+
+typedef struct _LED_SDIO {
+	PADAPTER			padapter;
+
+	LED_PIN				LedPin;	/* Identify how to implement this SW led. */
+
+	LED_STATE			CurrLedState; /* Current LED state. */
+	BOOLEAN				bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
+
+	BOOLEAN				bSWLedCtrl;
+
+	BOOLEAN				bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
+	/* ALPHA, added by chiyoko, 20090106 */
+	BOOLEAN				bLedNoLinkBlinkInProgress;
+	BOOLEAN				bLedLinkBlinkInProgress;
+	BOOLEAN				bLedStartToLinkBlinkInProgress;
+	BOOLEAN				bLedScanBlinkInProgress;
+	BOOLEAN				bLedWPSBlinkInProgress;
+
+	u32					BlinkTimes; /* Number of times to toggle led state for blinking. */
+	LED_STATE			BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
+
+	_timer				BlinkTimer; /* Timer object for led blinking. */
+
+	_workitem			BlinkWorkItem; /* Workitem used by BlinkTimer to manipulate H/W to blink LED. */
+} LED_SDIO, *PLED_SDIO;
+
+typedef struct _LED_SDIO	LED_DATA, *PLED_DATA;
+typedef enum _LED_STRATEGY_SDIO	LED_STRATEGY, *PLED_STRATEGY;
+
+VOID
+LedControlSDIO(
+	IN	PADAPTER		Adapter,
+	IN	LED_CTL_MODE		LedAction
+);
+
+#endif
+
+struct led_priv {
+	LED_STRATEGY		LedStrategy;
+#ifdef CONFIG_RTW_SW_LED
+	LED_DATA			SwLed0;
+	LED_DATA			SwLed1;
+	LED_DATA			SwLed2;
+	u8					bRegUseLed;
+	u8 iface_en_mask;
+	u32 ctl_en_mask[CONFIG_IFACE_NUMBER];
+	void (*LedControlHandler)(_adapter *padapter, LED_CTL_MODE LedAction);
+	void (*SwLedOn)(_adapter *padapter, PLED_DATA pLed);
+	void (*SwLedOff)(_adapter *padapter, PLED_DATA pLed);
+#endif
+};
+
+#define SwLedOn(adapter, pLed) \
+	do { \
+		if (adapter_to_led(adapter)->SwLedOn) \
+			adapter_to_led(adapter)->SwLedOn((adapter), (pLed)); \
+	} while (0)
+
+#define SwLedOff(adapter, pLed) \
+	do { \
+		if (adapter_to_led(adapter)->SwLedOff) \
+			adapter_to_led(adapter)->SwLedOff((adapter), (pLed)); \
+	} while (0)
+
+void BlinkTimerCallback(void *data);
+void BlinkWorkItemCallback(_workitem *work);
+
+void ResetLedStatus(PLED_DATA pLed);
+
+void
+InitLed(
+	_adapter			*padapter,
+	PLED_DATA		pLed,
+	LED_PIN			LedPin
+);
+
+void
+DeInitLed(
+	PLED_DATA		pLed
+);
+
+/* hal... */
+extern void BlinkHandler(PLED_DATA	pLed);
+void dump_led_config(void *sel, _adapter *adapter);
+void rtw_led_set_strategy(_adapter *adapter, u8 strategy);
+#endif /* CONFIG_RTW_LED */
+
+#if defined(CONFIG_RTW_LED)
+#define rtw_led_get_strategy(adapter) (adapter_to_led(adapter)->LedStrategy)
+#else
+#define rtw_led_get_strategy(adapter) NO_LED
+#endif
+
+#define IS_NO_LED_STRATEGY(s) ((s) == NO_LED)
+#define IS_HW_LED_STRATEGY(s) ((s) == HW_LED)
+#define IS_SW_LED_STRATEGY(s) ((s) != NO_LED && (s) != HW_LED)
+
+#if defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED)
+
+#ifndef CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+#define CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY 0
+#endif
+
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+void rtw_sw_led_blink_uc_trx_only(LED_DATA *led);
+void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl);
+#endif
+void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl);
+void rtw_led_tx_control(_adapter *adapter, const u8 *da);
+void rtw_led_rx_control(_adapter *adapter, const u8 *da);
+void rtw_led_set_iface_en(_adapter *adapter, u8 en);
+void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask);
+void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask);
+void rtw_led_set_ctl_en_mask_primary(_adapter *adapter);
+void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter);
+#else
+#define rtw_led_control(adapter, ctl) do {} while (0)
+#define rtw_led_tx_control(adapter, da) do {} while (0)
+#define rtw_led_rx_control(adapter, da) do {} while (0)
+#define rtw_led_set_iface_en(adapter, en) do {} while (0)
+#define rtw_led_set_iface_en_mask(adapter, mask) do {} while (0)
+#define rtw_led_set_ctl_en_mask(adapter, ctl_mask) do {} while (0)
+#define rtw_led_set_ctl_en_mask_primary(adapter) do {} while (0)
+#define rtw_led_set_ctl_en_mask_virtual(adapter) do {} while (0)
+#endif /* defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED) */
+
+#endif /*__HAL_COMMON_LED_H_*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_phycfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_phycfg.h
new file mode 100644
index 000000000000..581bca4732f0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_phycfg.h
@@ -0,0 +1,301 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_COM_PHYCFG_H__
+#define __HAL_COM_PHYCFG_H__
+
+#define		PathA                     			0x0	/* Useless */
+#define		PathB			0x1
+#define		PathC			0x2
+#define		PathD			0x3
+
+typedef enum _RF_TX_NUM {
+	RF_1TX = 0,
+	RF_2TX,
+	RF_3TX,
+	RF_4TX,
+	RF_MAX_TX_NUM,
+	RF_TX_NUM_NONIMPLEMENT,
+} RF_TX_NUM;
+
+#define MAX_POWER_INDEX		0x3F
+
+/*------------------------------Define structure----------------------------*/
+typedef struct _BB_REGISTER_DEFINITION {
+	u32 rfintfs;			/* set software control: */
+	/*		0x870~0x877[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 rfHSSIPara2;	/* wire parameter control2 :  */
+	/*		0x824~0x827,0x82c~0x82f, 0x834~0x837, 0x83c~0x83f [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 */
+
+} BB_REGISTER_DEFINITION_T, *PBB_REGISTER_DEFINITION_T;
+
+
+/* ---------------------------------------------------------------------- */
+u8
+PHY_GetTxPowerByRateBase(
+	IN	PADAPTER		Adapter,
+	IN	u8				Band,
+	IN	u8				RfPath,
+	IN	RATE_SECTION	RateSection
+);
+
+VOID
+PHY_GetRateValuesOfTxPowerByRate(
+	IN	PADAPTER pAdapter,
+	IN	u32 RegAddr,
+	IN	u32 BitMask,
+	IN	u32 Value,
+	OUT	u8 *Rate,
+	OUT	s8 *PwrByRateVal,
+	OUT	u8 *RateNum
+);
+
+u8
+PHY_GetRateIndexOfTxPowerByRate(
+	IN	u8	Rate
+);
+
+VOID
+phy_set_tx_power_index_by_rate_section(
+	IN	PADAPTER		pAdapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Channel,
+	IN	u8				RateSection
+);
+
+s8
+_PHY_GetTxPowerByRate(
+	IN	PADAPTER	pAdapter,
+	IN	u8			Band,
+	IN	enum rf_path	RFPath,
+	IN	u8			RateIndex
+);
+
+s8
+PHY_GetTxPowerByRate(
+	IN	PADAPTER	pAdapter,
+	IN	u8			Band,
+	IN	enum rf_path	RFPath,
+	IN	u8			RateIndex
+);
+
+VOID
+PHY_SetTxPowerByRate(
+	IN	PADAPTER	pAdapter,
+	IN	u8			Band,
+	IN	enum rf_path	RFPath,
+	IN	u8			Rate,
+	IN	s8			Value
+);
+
+VOID
+phy_set_tx_power_level_by_path(
+	IN	PADAPTER	Adapter,
+	IN	u8			channel,
+	IN	u8			path
+);
+
+VOID
+PHY_SetTxPowerIndexByRateArray(
+	IN	PADAPTER		pAdapter,
+	IN	enum rf_path		RFPath,
+	IN	enum channel_width BandWidth,
+	IN	u8				Channel,
+	IN	u8				*Rates,
+	IN	u8				RateArraySize
+);
+
+VOID
+PHY_InitTxPowerByRate(
+	IN	PADAPTER	pAdapter
+);
+
+VOID
+phy_store_tx_power_by_rate(
+	IN	PADAPTER	pAdapter,
+	IN	u32			Band,
+	IN	u32			RfPath,
+	IN	u32			TxNum,
+	IN	u32			RegAddr,
+	IN	u32			BitMask,
+	IN	u32			Data
+);
+
+VOID
+PHY_TxPowerByRateConfiguration(
+	IN  PADAPTER			pAdapter
+);
+
+u8
+PHY_GetTxPowerIndexBase(
+	IN	PADAPTER		pAdapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	u8 ntx_idx,
+	IN	enum channel_width	BandWidth,
+	IN	u8				Channel,
+	OUT PBOOLEAN		bIn24G
+);
+
+#ifdef CONFIG_TXPWR_LIMIT
+s8 phy_get_txpwr_lmt_abs(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 tlrs, u8 ntx_idx, u8 cch, u8 lock
+);
+
+s8 phy_get_txpwr_lmt(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 rfpath, u8 rs, u8 ntx_idx, u8 cch, u8 lock
+);
+
+s8 PHY_GetTxPowerLimit(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 rfpath, u8 rate, u8 ntx_idx, u8 cch
+);
+#else
+#define phy_get_txpwr_lmt_abs(adapter, regd_name, band, bw, tlrs, ntx_idx, cch, lock) MAX_POWER_INDEX
+#define phy_get_txpwr_lmt(adapter, regd_name, band, bw, rfpath, rs, ntx_idx, cch, lock) MAX_POWER_INDEX
+#define PHY_GetTxPowerLimit(adapter, regd_name, band, bw, rfpath, rate, ntx_idx, cch) MAX_POWER_INDEX
+#endif /* CONFIG_TXPWR_LIMIT */
+
+s8
+PHY_GetTxPowerTrackingOffset(
+	PADAPTER	pAdapter,
+	enum rf_path	RFPath,
+	u8			Rate
+);
+
+struct txpwr_idx_comp {
+	u8 ntx_idx;
+	u8 base;
+	s8 by_rate;
+	s8 limit;
+	s8 tpt;
+	s8 ebias;
+};
+
+u8
+phy_get_tx_power_index(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	enum channel_width	BandWidth,
+	IN	u8					Channel
+);
+
+VOID
+PHY_SetTxPowerIndex(
+	IN	PADAPTER		pAdapter,
+	IN	u32				PowerIndex,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate
+);
+
+void dump_tx_power_idx_title(void *sel, _adapter *adapter);
+void dump_tx_power_idx_by_path_rs(void *sel, _adapter *adapter, u8 rfpath, u8 rs);
+void dump_tx_power_idx(void *sel, _adapter *adapter);
+
+bool phy_is_tx_power_limit_needed(_adapter *adapter);
+bool phy_is_tx_power_by_rate_needed(_adapter *adapter);
+int phy_load_tx_power_by_rate(_adapter *adapter, u8 chk_file);
+#ifdef CONFIG_TXPWR_LIMIT
+int phy_load_tx_power_limit(_adapter *adapter, u8 chk_file);
+#endif
+void phy_load_tx_power_ext_info(_adapter *adapter, u8 chk_file);
+void phy_reload_tx_power_ext_info(_adapter *adapter);
+void phy_reload_default_tx_power_ext_info(_adapter *adapter);
+
+const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter);
+
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+int check_phy_efuse_tx_power_info_valid(_adapter *adapter);
+#endif
+
+void dump_hal_txpwr_info_2g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt);
+void dump_hal_txpwr_info_5g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt);
+
+void hal_load_txpwr_info(
+	_adapter *adapter,
+	TxPowerInfo24G *pwr_info_2g,
+	TxPowerInfo5G *pwr_info_5g,
+	u8 *pg_data
+);
+
+void dump_tx_power_ext_info(void *sel, _adapter *adapter);
+void dump_target_tx_power(void *sel, _adapter *adapter);
+void dump_tx_power_by_rate(void *sel, _adapter *adapter);
+
+int rtw_get_phy_file_path(_adapter *adapter, const char *file_name);
+
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+#define MAC_FILE_FW_NIC			"FW_NIC.bin"
+#define MAC_FILE_FW_WW_IMG		"FW_WoWLAN.bin"
+#define PHY_FILE_MAC_REG		"MAC_REG.txt"
+
+#define PHY_FILE_AGC_TAB		"AGC_TAB.txt"
+#define PHY_FILE_PHY_REG		"PHY_REG.txt"
+#define PHY_FILE_PHY_REG_MP		"PHY_REG_MP.txt"
+#define PHY_FILE_PHY_REG_PG		"PHY_REG_PG.txt"
+
+#define PHY_FILE_RADIO_A		"RadioA.txt"
+#define PHY_FILE_RADIO_B		"RadioB.txt"
+#define PHY_FILE_RADIO_C		"RadioC.txt"
+#define PHY_FILE_RADIO_D		"RadioD.txt"
+#define PHY_FILE_TXPWR_TRACK	"TxPowerTrack.txt"
+#define PHY_FILE_TXPWR_LMT		"TXPWR_LMT.txt"
+
+#define PHY_FILE_WIFI_ANT_ISOLATION	"wifi_ant_isolation.txt"
+
+#define MAX_PARA_FILE_BUF_LEN	25600
+
+#define LOAD_MAC_PARA_FILE				BIT0
+#define LOAD_BB_PARA_FILE					BIT1
+#define LOAD_BB_PG_PARA_FILE				BIT2
+#define LOAD_BB_MP_PARA_FILE				BIT3
+#define LOAD_RF_PARA_FILE					BIT4
+#define LOAD_RF_TXPWR_TRACK_PARA_FILE	BIT5
+#define LOAD_RF_TXPWR_LMT_PARA_FILE		BIT6
+
+int phy_ConfigMACWithParaFile(IN PADAPTER	Adapter, IN char	*pFileName);
+int phy_ConfigBBWithParaFile(IN PADAPTER	Adapter, IN char	*pFileName, IN u32	ConfigType);
+int phy_ConfigBBWithPgParaFile(IN PADAPTER	Adapter, IN const char *pFileName);
+int phy_ConfigBBWithMpParaFile(IN PADAPTER	Adapter, IN char	*pFileName);
+int PHY_ConfigRFWithParaFile(IN	PADAPTER	Adapter, IN char	*pFileName, IN enum rf_path	eRFPath);
+int PHY_ConfigRFWithTxPwrTrackParaFile(IN PADAPTER	Adapter, IN char	*pFileName);
+#ifdef CONFIG_TXPWR_LIMIT
+int PHY_ConfigRFWithPowerLimitTableParaFile(IN PADAPTER	Adapter, IN const char *pFileName);
+#endif
+void phy_free_filebuf_mask(_adapter *padapter, u8 mask);
+void phy_free_filebuf(_adapter *padapter);
+#endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
+
+#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_reg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_reg.h
new file mode 100644
index 000000000000..862164ff42a7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_com_reg.h
@@ -0,0 +1,1841 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_REG_H__
+#define __HAL_COMMON_REG_H__
+
+
+#define MAC_ADDR_LEN				6
+
+#define HAL_NAV_UPPER_UNIT		128		/* micro-second */
+
+/* 8188E PKT_BUFF_ACCESS_CTRL value */
+#define TXPKT_BUF_SELECT				0x69
+#define RXPKT_BUF_SELECT				0xA5
+#define DISABLE_TRXPKT_BUF_ACCESS		0x0
+
+#ifndef RTW_HALMAC
+/* ************************************************************
+*
+* ************************************************************ */
+
+/* -----------------------------------------------------
+*
+*	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_SYS_CLK_CTRL				REG_SYS_CLKR
+#define REG_9346CR						0x000A
+#define REG_SYS_EEPROM_CTRL			0x000A
+#define REG_EE_VPD						0x000C
+#define REG_AFE_MISC					0x0010
+#define REG_SPS0_CTRL					0x0011
+#define REG_SPS0_CTRL_6					0x0016
+#define REG_POWER_OFF_IN_PROCESS		0x0017
+#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_LDO_CTRL				0x0027 /* 1.5v for 8188EE test chip, 1.4v for MP chip */
+#define REG_AFE_PLL_CTRL				0x0028
+#define REG_MAC_PHY_CTRL				0x002c /* for 92d, DMDP, SMSP, DMSP contrl */
+#define REG_APE_PLL_CTRL_EXT			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_FSIMR						0x0050
+#define REG_FSISR						0x0054
+#define REG_HSIMR						0x0058
+#define REG_HSISR						0x005c
+#define REG_GPIO_PIN_CTRL_2			0x0060 /* RTL8723 WIFI/BT/GPS Multi-Function GPIO Pin Control. */
+#define REG_GPIO_IO_SEL_2				0x0062 /* RTL8723 WIFI/BT/GPS Multi-Function GPIO Select. */
+#define REG_PAD_CTRL_1				0x0064
+#define REG_MULTI_FUNC_CTRL			0x0068 /* RTL8723 WIFI/BT/GPS Multi-Function control source. */
+#define REG_GSSR						0x006c
+#define REG_AFE_XTAL_CTRL_EXT			0x0078 /* RTL8188E */
+#define REG_XCK_OUT_CTRL				0x007c /* RTL8188E */
+#define REG_MCUFWDL					0x0080
+#define REG_WOL_EVENT					0x0081 /* RTL8188E */
+#define REG_MCUTSTCFG					0x0084
+#define REG_FDHM0						0x0088
+#define REG_HOST_SUSP_CNT				0x00BC	/* RTL8192C Host suspend counter on FPGA platform */
+#define REG_SYSTEM_ON_CTRL			0x00CC	/* For 8723AE Reset after S3 */
+#define REG_EFUSE_ACCESS				0x00CF	/* Efuse access protection for RTL8723 */
+#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. */
+#define REG_TYPE_ID						0x00FC
+
+/*
+* 2010/12/29 MH Add for 92D
+*   */
+#define REG_MAC_PHY_CTRL_NORMAL		0x00f8
+
+
+/* -----------------------------------------------------
+*
+*	0x0100h ~ 0x01FFh	MACTOP General Configuration
+*
+* ----------------------------------------------------- */
+#define REG_CR							0x0100
+#define REG_PBP							0x0104
+#define REG_PKT_BUFF_ACCESS_CTRL		0x0106
+#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_FE1IMR						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_FTIMR						0x0138
+#define REG_FTISR						0x013C /* RTL8192C */
+#define REG_PKTBUF_DBG_CTRL			0x0140
+#define REG_RXPKTBUF_CTRL				(REG_PKTBUF_DBG_CTRL+2)
+#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_32K_CTRL					0x0194 /* RTL8188E */
+#define REG_C2HEVT_MSG_NORMAL		0x01A0
+#define REG_C2HEVT_CLEAR				0x01AF
+#define REG_MCUTST_1					0x01c0
+#define REG_MCUTST_WOWLAN			0x01C7	/* Defined after 8188E series. */
+#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_HMEBOX_EXT_0				0x01F0
+#define REG_HMEBOX_EXT_1				0x01F4
+#define REG_HMEBOX_EXT_2				0x01F8
+#define REG_HMEBOX_EXT_3				0x01FC
+
+
+/* -----------------------------------------------------
+*
+*	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
+#define REG_AUTO_LLT					0x0224
+
+
+/* -----------------------------------------------------
+*
+*	0x0280h ~ 0x02FFh	RXDMA Configuration
+*
+* ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH			0x0280
+#define REG_RXPKT_NUM					0x0284
+#define REG_RXDMA_STATUS				0x0288
+
+/* -----------------------------------------------------
+*
+*	0x0300h ~ 0x03FFh	PCIe
+*
+* ----------------------------------------------------- */
+#ifndef CONFIG_TRX_BD_ARCH	/* prevent CONFIG_TRX_BD_ARCH to use old registers */
+
+#define REG_PCIE_CTRL_REG				0x0300
+#define REG_INT_MIG					0x0304	/* Interrupt Migration */
+#define REG_BCNQ_DESA					0x0308	/* TX Beacon Descriptor Address */
+#define REG_HQ_DESA					0x0310	/* TX High Queue Descriptor Address */
+#define REG_MGQ_DESA					0x0318	/* TX Manage Queue Descriptor Address */
+#define REG_VOQ_DESA					0x0320	/* TX VO Queue Descriptor Address */
+#define REG_VIQ_DESA					0x0328	/* TX VI Queue Descriptor Address */
+#define REG_BEQ_DESA					0x0330	/* TX BE Queue Descriptor Address */
+#define REG_BKQ_DESA					0x0338	/* TX BK Queue Descriptor Address */
+#define REG_RX_DESA					0x0340	/* RX Queue Descriptor Address */
+/* sherry added for DBI Read/Write  20091126 */
+#define REG_DBI_WDATA					0x0348	/*  Backdoor REG for Access Configuration */
+#define REG_DBI_RDATA					0x034C	/* Backdoor REG for Access Configuration */
+#define REG_DBI_CTRL					0x0350	/* Backdoor REG for Access Configuration */
+#define REG_DBI_FLAG					0x0352	/* Backdoor REG for Access Configuration */
+#define REG_MDIO					0x0354	/* MDIO for Access PCIE PHY */
+#define REG_DBG_SEL					0x0360	/* Debug Selection Register */
+#define REG_WATCH_DOG					0x0368
+#define REG_RX_RXBD_NUM					0x0382
+
+/* RTL8723 series ------------------------------- */
+#define REG_PCIE_HISR_EN				0x0394	/* PCIE Local Interrupt Enable Register */
+#define REG_PCIE_HISR					0x03A0
+#define REG_PCIE_HISRE					0x03A4
+#define REG_PCIE_HIMR					0x03A8
+#define REG_PCIE_HIMRE					0x03AC
+
+#endif /* !CONFIG_TRX_BD_ARCH */
+
+#define REG_USB_HIMR					0xFE38
+#define REG_USB_HIMRE					0xFE3C
+#define REG_USB_HISR					0xFE78
+#define REG_USB_HISRE					0xFE7C
+
+
+/* -----------------------------------------------------
+*
+*	0x0400h ~ 0x047Fh	Protocol Configuration
+*
+* ----------------------------------------------------- */
+
+/* 92C, 92D */
+#define REG_VOQ_INFO	0x0400
+#define REG_VIQ_INFO	0x0404
+#define REG_BEQ_INFO	0x0408
+#define REG_BKQ_INFO	0x040C
+
+/* 88E, 8723A, 8812A, 8821A, 92E, 8723B */
+#define REG_Q0_INFO	0x400
+#define REG_Q1_INFO	0x404
+#define REG_Q2_INFO	0x408
+#define REG_Q3_INFO	0x40C
+
+#define REG_MGQ_INFO	0x0410
+#define REG_HGQ_INFO	0x0414
+#define REG_BCNQ_INFO	0x0418
+#define REG_TXPKT_EMPTY				0x041A
+#define REG_CPU_MGQ_INFORMATION		0x041C
+#define REG_FWHW_TXQ_CTRL				0x0420
+#define REG_HWSEQ_CTRL					0x0423
+#define REG_BCNQ_BDNY					0x0424
+#define REG_MGQ_BDNY					0x0425
+#define REG_LIFETIME_CTRL				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_CCK_CHECK					0x0454
+#define REG_BCNQ1_BDNY					0x0457
+
+#define REG_AGGLEN_LMT					0x0458
+#define REG_AMPDU_MIN_SPACE			0x045C
+#define REG_WMAC_LBK_BF_HD			0x045D
+#define REG_FAST_EDCA_CTRL				0x0460
+#define REG_RD_RESP_PKT_TH				0x0463
+
+/* 8723A, 8812A, 8821A, 92E, 8723B */
+#define REG_Q4_INFO	0x468
+#define REG_Q5_INFO	0x46C
+#define REG_Q6_INFO	0x470
+#define REG_Q7_INFO	0x474
+
+#define REG_INIRTS_RATE_SEL				0x0480
+#define REG_INIDATA_RATE_SEL			0x0484
+
+/* 8723B, 92E, 8812A, 8821A*/
+#define REG_MACID_SLEEP_3				0x0484
+#define REG_MACID_SLEEP_1				0x0488
+
+#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_QUEUE_CTRL					0x04C6
+#define REG_SINGLE_AMPDU_CTRL			0x04c7
+#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
+
+/* 8723A */
+#define REG_MACID_DROP	0x04D0
+
+/* 88E */
+#define REG_EARLY_MODE_CONTROL	0x04D0
+
+/* 8723B, 92E, 8812A, 8821A */
+#define REG_MACID_SLEEP_2	0x04D0
+
+/* 8723A, 8723B, 92E, 8812A, 8821A */
+#define REG_MACID_SLEEP	0x04D4
+
+#define REG_NQOS_SEQ					0x04DC
+#define REG_HW_SEQ0						0x04D8
+#define REG_HW_SEQ1						0x04DA
+#define REG_HW_SEQ2						0x04DC
+#define REG_HW_SEQ3						0x04DE
+
+#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_TX_RPT_CTRL					0x04EC
+#define REG_TX_RPT_TIME					0x04F0	/* 2 byte */
+#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_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
+/*
+* Format for offset 540h-542h:
+*	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+*	[7:4]:   Reserved.
+*	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+*	[23:20]: Reserved
+* Description:
+*	              |
+*      |<--Setup--|--Hold------------>|
+*   --------------|----------------------
+*                 |
+*                TBTT
+* Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+* Described by Designer Tim and Bruce, 2011-01-14.
+*   */
+#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
+#define REG_BCN_INTERVAL				0x0554	/* The same as REG_MBSSID_BCN_SPACE */
+#define REG_DRVERLYINT					0x0558
+#define REG_BCNDMATIM					0x0559
+#define REG_ATIMWND					0x055A
+#define REG_USTIME_TSF					0x055C
+#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	/* HW Port 1 TSF Register */
+#define REG_ATIMWND_1					0x0570
+#define REG_P2P_CTWIN					0x0572 /* 1 Byte long (in unit of TU) */
+#define REG_PSTIMER						0x0580
+#define REG_TIMER0						0x0584
+#define REG_TIMER1						0x0588
+#define REG_HIQ_NO_LMT_EN				0x05A7
+#define REG_ACMHWCTRL					0x05C0
+#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
+
+#define REG_DMC							0x05F0	/* Dual MAC Co-Existence Register */
+#define REG_SCH_TX_CMD					0x05F8
+
+#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_1				0x0628
+#define REG_MBIDCAMCFG_2				0x062C
+
+#define REG_PNO_STATUS					0x0631
+#define REG_USTIME_EDCA				0x0638
+#define REG_MAC_SPEC_SIFS				0x063A
+/* 20100719 Joseph: Hardware register definition change. (HW datasheet v54) */
+#define REG_RESP_SIFS_CCK				0x063C	/* [15:8]SIFS_R2T_OFDM, [7:0]SIFS_R2T_CCK */
+#define REG_RESP_SIFS_OFDM                    0x063E	/* [15:8]SIFS_T2T_OFDM, [7:0]SIFS_T2T_CCK */
+
+#define REG_ACKTO						0x0640
+#define REG_CTS2TO						0x0641
+#define REG_EIFS							0x0642
+
+
+/* RXERR_RPT */
+#define RXERR_TYPE_OFDM_PPDU			0
+#define RXERR_TYPE_OFDM_FALSE_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_CCK_FALSE_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_HT_FALSE_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)
+
+/*
+* 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 */
+
+/* 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_PS_RX_INFO					0x0692
+#define REG_WMMPS_UAPSD_TID			0x0693
+#define REG_WKFMCAM_CMD				0x0698
+#define REG_WKFMCAM_NUM				REG_WKFMCAM_CMD
+#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_BT_COEX_TABLE				0x06C0
+
+/* Hardware Port 1 */
+#define REG_MACID1						0x0700
+#define REG_BSSID1						0x0708
+/* Hardware Port 2 */
+#define REG_MACID2						0x1620
+#define REG_BSSID2						0x1628
+/* Hardware Port 3*/
+#define REG_MACID3						0x1630
+#define REG_BSSID3						0x1638
+/* Hardware Port 4 */
+#define REG_MACID4						0x1640
+#define REG_BSSID4						0x1648
+
+
+#define REG_CR_EXT						0x1100
+
+/* -----------------------------------------------------
+*
+*	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_HRPWM					0xFE58
+#define REG_USB_HCPWM					0xFE57
+
+/* for 92DU high_Queue low_Queue Normal_Queue select */
+#define REG_USB_High_NORMAL_Queue_Select_MAC0	0xFE44
+/* #define REG_USB_LOW_Queue_Select_MAC0		0xFE45 */
+#define REG_USB_High_NORMAL_Queue_Select_MAC1	0xFE47
+/* #define REG_USB_LOW_Queue_Select_MAC1		0xFE48 */
+
+/* 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		/* 0xFE6D, for 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. */
+
+#define EFUSE_CTRL				REG_EFUSE_CTRL		/* E-Fuse Control. */
+#define EFUSE_TEST				REG_EFUSE_TEST		/* E-Fuse Test. */
+#define MSR						(REG_CR + 2)		/* Media Status register */
+/* #define ISR						REG_HISR */
+#define MSR1						REG_CR_EXT
+
+#define TSFR						REG_TSFTR			/* Timing Sync Function Timer Register. */
+#define TSFR1					REG_TSFTR1			/* HW Port 1 TSF Register */
+
+#define PBP						REG_PBP
+
+/* Redifine MACID register, to compatible prior ICs. */
+#define IDR0						REG_MACID			/* MAC ID Register, Offset 0x0050-0x0053 */
+#define IDR4						(REG_MACID + 4)		/* MAC ID Register, Offset 0x0054-0x0055 */
+
+
+/*
+* 9. Security Control Registers	(Offset: )
+*   */
+#define RWCAM					REG_CAMCMD		/* IN 8190 Data Sheet is called CAMcmd */
+#define WCAMI					REG_CAMWRITE	/* Software write CAM input content */
+#define RCAMO					REG_CAMREAD		/* Software read/write CAM config */
+#define CAMDBG					REG_CAMDBG
+#define SECR						REG_SECCFG		/* Security Configuration Register */
+
+/* Unused register */
+#define UnusedRegister			0x1BF
+#define DCAM					UnusedRegister
+#define PSR						UnusedRegister
+#define BBAddr					UnusedRegister
+#define PhyDataR					UnusedRegister
+
+/* Min Spacing related settings. */
+#define MAX_MSS_DENSITY_2T			0x13
+#define MAX_MSS_DENSITY_1T			0x0A
+
+/* ----------------------------------------------------------------------------
+* 8192C Cmd9346CR bits					(Offset 0xA, 16bit)
+* ---------------------------------------------------------------------------- */
+#define CmdEEPROM_En				BIT(5)	 /* EEPROM enable when set 1 */
+#define CmdEERPOMSEL				BIT(4)	/* System EEPROM select, 0: boot from E-FUSE, 1: The EEPROM used is 9346 */
+#define Cmd9346CR_9356SEL			BIT(4)
+
+/* ----------------------------------------------------------------------------
+* 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)
+* ---------------------------------------------------------------------------- */
+#define GPIO_IN					REG_GPIO_PIN_CTRL		/* GPIO pins input value */
+#define GPIO_OUT				(REG_GPIO_PIN_CTRL+1)	/* GPIO pins output value */
+#define GPIO_IO_SEL				(REG_GPIO_PIN_CTRL+2)	/* GPIO pins output enable when a bit is set to "1"; otherwise, input is configured. */
+#define GPIO_MOD				(REG_GPIO_PIN_CTRL+3)
+
+/* ----------------------------------------------------------------------------
+* 8811A GPIO PIN Control Register (offset 0x60, 4 byte)
+* ---------------------------------------------------------------------------- */
+#define GPIO_IN_8811A			REG_GPIO_PIN_CTRL_2		/* GPIO pins input value */
+#define GPIO_OUT_8811A			(REG_GPIO_PIN_CTRL_2+1)	/* GPIO pins output value */
+#define GPIO_IO_SEL_8811A		(REG_GPIO_PIN_CTRL_2+2)	/* GPIO pins output enable when a bit is set to "1"; otherwise, input is configured. */
+#define GPIO_MOD_8811A			(REG_GPIO_PIN_CTRL_2+3)
+
+/* ----------------------------------------------------------------------------
+* 8723/8188E 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_PDN_INT_EN				BIT(7)
+#define HSIMR_GPIO9_INT_EN				BIT(25)
+
+/* ----------------------------------------------------------------------------
+* 8723/8188E 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)
+
+/* ----------------------------------------------------------------------------
+* 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
+
+/* ----------------------------------------------------------------------------
+* USB INTR CONTENT
+* ---------------------------------------------------------------------------- */
+#define USB_C2H_CMDID_OFFSET					0
+#define USB_C2H_SEQ_OFFSET					1
+#define USB_C2H_EVENT_OFFSET					2
+#define USB_INTR_CPWM_OFFSET					16
+#define USB_INTR_CONTENT_C2H_OFFSET			0
+#define USB_INTR_CONTENT_CPWM1_OFFSET		16
+#define USB_INTR_CONTENT_CPWM2_OFFSET		20
+#define USB_INTR_CONTENT_HISR_OFFSET			48
+#define USB_INTR_CONTENT_HISRE_OFFSET		52
+#define USB_INTR_CONTENT_LENGTH				56
+
+/* ----------------------------------------------------------------------------
+* Response Rate Set Register	(offset 0x440, 24bits)
+* ---------------------------------------------------------------------------- */
+#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 RRSR_CCK_RATES (RRSR_11M | RRSR_5_5M | RRSR_2M | RRSR_1M)
+#define RRSR_OFDM_RATES (RRSR_54M | RRSR_48M | RRSR_36M | RRSR_24M | RRSR_18M | RRSR_12M | RRSR_9M | RRSR_6M)
+
+/* WOL bit information */
+#define HAL92C_WOL_PTK_UPDATE_EVENT		BIT(0)
+#define HAL92C_WOL_GTK_UPDATE_EVENT		BIT(1)
+#define HAL92C_WOL_DISASSOC_EVENT		BIT(2)
+#define HAL92C_WOL_DEAUTH_EVENT			BIT(3)
+#define HAL92C_WOL_FW_DISCONNECT_EVENT	BIT(4)
+
+
+/*----------------------------------------------------------------------------
+**      REG_CCK_CHECK						(offset 0x454)
+------------------------------------------------------------------------------*/
+#define BIT_BCN_PORT_SEL		BIT(5)
+#define BIT_EN_BCN_PKT_REL		BIT(6)
+
+#endif /* RTW_HALMAC */
+
+/* ----------------------------------------------------------------------------
+ * 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)
+/* MCS 1 Spatial Stream */
+#define RATE_MCS0				BIT(12)
+#define RATE_MCS1				BIT(13)
+#define RATE_MCS2				BIT(14)
+#define RATE_MCS3				BIT(15)
+#define RATE_MCS4				BIT(16)
+#define RATE_MCS5				BIT(17)
+#define RATE_MCS6				BIT(18)
+#define RATE_MCS7				BIT(19)
+/* MCS 2 Spatial Stream */
+#define RATE_MCS8				BIT(20)
+#define RATE_MCS9				BIT(21)
+#define RATE_MCS10				BIT(22)
+#define RATE_MCS11				BIT(23)
+#define RATE_MCS12				BIT(24)
+#define RATE_MCS13				BIT(25)
+#define RATE_MCS14				BIT(26)
+#define RATE_MCS15				BIT(27)
+
+
+/* ALL CCK Rate */
+#define	RATE_ALL_CCK				(RATR_1M | RATR_2M | RATR_55M | RATR_11M)
+#define	RATE_ALL_OFDM_AG			(RATR_6M | RATR_9M | RATR_12M | RATR_18M | RATR_24M|\
+	RATR_36M | RATR_48M | RATR_54M)
+#define	RATE_ALL_OFDM_1SS			(RATR_MCS0 | RATR_MCS1 | RATR_MCS2 | RATR_MCS3 |\
+	RATR_MCS4 | RATR_MCS5 | RATR_MCS6 | RATR_MCS7)
+#define	RATE_ALL_OFDM_2SS			(RATR_MCS8 | RATR_MCS9 | RATR_MCS10 | RATR_MCS11|\
+	RATR_MCS12 | RATR_MCS13 | RATR_MCS14 | RATR_MCS15)
+
+#define RATE_BITMAP_ALL			0xFFFFF
+
+/* Only use CCK 1M rate for ACK */
+#define RATE_RRSR_CCK_ONLY_1M		0xFFFF1
+#define RATE_RRSR_WITHOUT_CCK		0xFFFF0
+
+/* ----------------------------------------------------------------------------
+ * BW_OPMODE bits				(Offset 0x603, 8bit)
+ * ---------------------------------------------------------------------------- */
+#define BW_OPMODE_20MHZ			BIT(2)
+#define BW_OPMODE_5G				BIT(1)
+
+/* ----------------------------------------------------------------------------
+ * CAM Config Setting (offset 0x680, 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 CAM_SMS4				0x6
+
+#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)
+
+/*
+ * 10. Power Save Control Registers
+ *   */
+#define WOW_PMEN				BIT(0) /* Power management Enable. */
+#define WOW_WOMEN				BIT(1) /* WoW function on or off. */
+#define WOW_MAGIC				BIT(2) /* Magic packet */
+#define WOW_UWF				BIT(3) /* Unicast Wakeup frame. */
+
+/*
+ * 12. Host Interrupt Status Registers
+ *
+ * ----------------------------------------------------------------------------
+ * 8190 IMR/ISR bits
+ * ---------------------------------------------------------------------------- */
+#define IMR8190_DISABLED		0x0
+#define IMR_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. For 8723 and later ICs, it also means P2P CTWin End interrupt. */
+#define IMR_BDOK				BIT(9)		/* Beacon Queue DMA OK Interrupt */
+#define IMR_HIGHDOK				BIT(8)		/* High Queue DMA OK Interrupt */
+#define IMR_TBDOK				BIT(7)		/* Transmit Beacon OK interrupt */
+#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 */
+
+/* 13. Host Interrupt Status Extension Register	 (Offset: 0x012C-012Eh) */
+#define IMR_TSF_BIT32_TOGGLE	BIT(15)
+#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)
+
+/* ----------------------------------------------------------------------------
+ * 8723E series PCIE Host IMR/ISR bit
+ * ---------------------------------------------------------------------------- */
+/* IMR DW0 Bit 0-31 */
+#define PHIMR_TIMEOUT2				BIT(31)
+#define PHIMR_TIMEOUT1				BIT(30)
+#define PHIMR_PSTIMEOUT			BIT(29)
+#define PHIMR_GTINT4				BIT(28)
+#define PHIMR_GTINT3				BIT(27)
+#define PHIMR_TXBCNERR				BIT(26)
+#define PHIMR_TXBCNOK				BIT(25)
+#define PHIMR_TSF_BIT32_TOGGLE	BIT(24)
+#define PHIMR_BCNDMAINT3			BIT(23)
+#define PHIMR_BCNDMAINT2			BIT(22)
+#define PHIMR_BCNDMAINT1			BIT(21)
+#define PHIMR_BCNDMAINT0			BIT(20)
+#define PHIMR_BCNDOK3				BIT(19)
+#define PHIMR_BCNDOK2				BIT(18)
+#define PHIMR_BCNDOK1				BIT(17)
+#define PHIMR_BCNDOK0				BIT(16)
+#define PHIMR_HSISR_IND_ON			BIT(15)
+#define PHIMR_BCNDMAINT_E			BIT(14)
+#define PHIMR_ATIMEND_E			BIT(13)
+#define PHIMR_ATIM_CTW_END		BIT(12)
+#define PHIMR_HISRE_IND			BIT(11)	/* RO. HISRE Indicator (HISRE & HIMRE is true, this bit is set to 1) */
+#define PHIMR_C2HCMD				BIT(10)
+#define PHIMR_CPWM2				BIT(9)
+#define PHIMR_CPWM					BIT(8)
+#define PHIMR_HIGHDOK				BIT(7)		/* High Queue DMA OK Interrupt */
+#define PHIMR_MGNTDOK				BIT(6)		/* Management Queue DMA OK Interrupt */
+#define PHIMR_BKDOK					BIT(5)		/* AC_BK DMA OK Interrupt */
+#define PHIMR_BEDOK					BIT(4)		/* AC_BE DMA OK Interrupt */
+#define PHIMR_VIDOK					BIT(3)		/* AC_VI DMA OK Interrupt */
+#define PHIMR_VODOK				BIT(2)		/* AC_VO DMA Interrupt */
+#define PHIMR_RDU					BIT(1)		/* Receive Descriptor Unavailable */
+#define PHIMR_ROK					BIT(0)		/* Receive DMA OK Interrupt */
+
+/* PCIE Host Interrupt Status Extension bit */
+#define PHIMR_BCNDMAINT7			BIT(23)
+#define PHIMR_BCNDMAINT6			BIT(22)
+#define PHIMR_BCNDMAINT5			BIT(21)
+#define PHIMR_BCNDMAINT4			BIT(20)
+#define PHIMR_BCNDOK7				BIT(19)
+#define PHIMR_BCNDOK6				BIT(18)
+#define PHIMR_BCNDOK5				BIT(17)
+#define PHIMR_BCNDOK4				BIT(16)
+/* bit12 15: RSVD */
+#define PHIMR_TXERR					BIT(11)
+#define PHIMR_RXERR					BIT(10)
+#define PHIMR_TXFOVW				BIT(9)
+#define PHIMR_RXFOVW				BIT(8)
+/* bit2-7: RSVD */
+#define PHIMR_OCPINT				BIT(1)
+/* bit0: RSVD */
+
+#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 HAL_NIC_UNPLUG_ISR			0xFFFFFFFF	/* The value when the NIC is unplugged for PCI. */
+#define HAL_NIC_UNPLUG_PCI_ISR		0xEAEAEAEA	/* The value when the NIC is unplugged for PCI in PCI interrupt (page 3). */
+
+/* ----------------------------------------------------------------------------
+ * 8188 IMR/ISR bits
+ * ---------------------------------------------------------------------------- */
+#define IMR_DISABLED_88E			0x0
+/* IMR DW0(0x0060-0063) Bit 0-31 */
+#define IMR_TXCCK_88E				BIT(30)		/* TXRPT interrupt when CCX bit of the packet is set	 */
+#define IMR_PSTIMEOUT_88E			BIT(29)		/* Power Save Time Out Interrupt */
+#define IMR_GTINT4_88E				BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define IMR_GTINT3_88E				BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define IMR_TBDER_88E				BIT(26)		/* Transmit Beacon0 Error			 */
+#define IMR_TBDOK_88E				BIT(25)		/* Transmit Beacon0 OK			 */
+#define IMR_TSF_BIT32_TOGGLE_88E	BIT(24)		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define IMR_BCNDMAINT0_88E		BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define IMR_BCNDERR0_88E			BIT(16)		/* Beacon Queue DMA Error 0 */
+#define IMR_HSISR_IND_ON_INT_88E	BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)			 */
+#define IMR_BCNDMAINT_E_88E		BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define IMR_ATIMEND_88E			BIT(12)		/* CTWidnow End or ATIM Window End */
+#define IMR_HISR1_IND_INT_88E		BIT(11)		/* HISR1 Indicator (HISR1 & HIMR1 is true, this bit is set to 1) */
+#define IMR_C2HCMD_88E				BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define IMR_CPWM2_88E				BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define IMR_CPWM_88E				BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define IMR_HIGHDOK_88E			BIT(7)			/* High Queue DMA OK	 */
+#define IMR_MGNTDOK_88E			BIT(6)			/* Management Queue DMA OK	 */
+#define IMR_BKDOK_88E				BIT(5)			/* AC_BK DMA OK		 */
+#define IMR_BEDOK_88E				BIT(4)			/* AC_BE DMA OK	 */
+#define IMR_VIDOK_88E				BIT(3)			/* AC_VI DMA OK		 */
+#define IMR_VODOK_88E				BIT(2)			/* AC_VO DMA OK	 */
+#define IMR_RDU_88E					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define IMR_ROK_88E					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define IMR_BCNDMAINT7_88E		BIT(27)		/* Beacon DMA Interrupt 7 */
+#define IMR_BCNDMAINT6_88E		BIT(26)		/* Beacon DMA Interrupt 6 */
+#define IMR_BCNDMAINT5_88E		BIT(25)		/* Beacon DMA Interrupt 5 */
+#define IMR_BCNDMAINT4_88E		BIT(24)		/* Beacon DMA Interrupt 4 */
+#define IMR_BCNDMAINT3_88E		BIT(23)		/* Beacon DMA Interrupt 3 */
+#define IMR_BCNDMAINT2_88E		BIT(22)		/* Beacon DMA Interrupt 2 */
+#define IMR_BCNDMAINT1_88E		BIT(21)		/* Beacon DMA Interrupt 1 */
+#define IMR_BCNDOK7_88E			BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define IMR_BCNDOK6_88E			BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define IMR_BCNDOK5_88E			BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define IMR_BCNDOK4_88E			BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define IMR_BCNDOK3_88E			BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define IMR_BCNDOK2_88E			BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define IMR_BCNDOK1_88E			BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define IMR_ATIMEND_E_88E			BIT(13)		/* ATIM Window End Extension for Win7 */
+#define IMR_TXERR_88E				BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define IMR_RXERR_88E				BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define IMR_TXFOVW_88E				BIT(9)			/* Transmit FIFO Overflow */
+#define IMR_RXFOVW_88E				BIT(8)			/* Receive FIFO Overflow */
+
+/*===================================================================
+=====================================================================
+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 (TXPAUSE) transmission pause 	(Offset 0x522, 8 bits) */
+/* ---------------------------------------------------------------------------- */
+/* Note:
+*	The the bits of stoping AC(VO/VI/BE/BK) queue in datasheet RTL8192S/RTL8192C are wrong,
+*	the correct arragement is VO - Bit0, VI - Bit1, BE - Bit2, and BK - Bit3.
+*	8723 and 88E may be not correct either in the eralier version. Confirmed with DD Tim.
+* By Bruce, 2011-09-22. */
+#define StopBecon		BIT(6)
+#define StopHigh			BIT(5)
+#define StopMgt			BIT(4)
+#define StopBK			BIT(3)
+#define StopBE			BIT(2)
+#define StopVI			BIT(1)
+#define StopVO			BIT(0)
+
+/* ----------------------------------------------------------------------------
+ * 8192C (RCR) Receive Configuration Register	(Offset 0x608, 32 bits)
+ * ---------------------------------------------------------------------------- */
+#define RCR_APPFCS				BIT(31)	/* WMAC append FCS after pauload */
+#define RCR_APP_MIC				BIT(30)	/* MACRX will retain the MIC at the bottom of the packet. */
+#define RCR_APP_ICV				BIT(29)	/* MACRX will retain the ICV at the bottom of the packet. */
+#define RCR_APP_PHYST_RXFF		BIT(28)	/* PHY Status is appended before RX packet in RXFF */
+#define RCR_APP_BA_SSN			BIT(27)	/* SSN of previous TXBA is appended as after original RXDESC as the 4-th DW of RXDESC. */
+#define RCR_VHT_DACK			BIT(26)	/* This bit to control response type for vht single mpdu data packet. 1. ACK as response 0. BA as response */
+#define RCR_TCPOFLD_EN			BIT(25)	/* Enable TCP checksum offload */
+#define RCR_ENMBID				BIT(24)	/* Enable Multiple BssId. Only response ACK to the packets whose DID(A1) matching to the addresses in the MBSSID CAM Entries. */
+#define RCR_LSIGEN				BIT(23)	/* Enable LSIG TXOP Protection function. Search KEYCAM for each rx packet to check if LSIGEN bit is set. */
+#define RCR_MFBEN				BIT(22)	/* Enable immediate MCS Feedback function. When Rx packet with MRQ = 1'b1, then search KEYCAM to find sender's MCS Feedback function and send response. */
+#define RCR_DISCHKPPDLLEN		BIT(21)	/* Do not check PPDU while the PPDU length is smaller than 14 byte. */
+#define RCR_PKTCTL_DLEN			BIT(20)	/* While rx path dead lock occurs, reset rx path */
+#define RCR_DISGCLK				BIT(19)	/* Disable macrx clock gating control (no used) */
+#define RCR_TIM_PARSER_EN		BIT(18)	/* RX Beacon TIM Parser. */
+#define RCR_BC_MD_EN			BIT(17)	/* Broadcast data packet more data bit check interrupt enable.*/
+#define RCR_UC_MD_EN			BIT(16)	/* Unicast data packet more data bit check interrupt enable. */
+#define RCR_RXSK_PERPKT			BIT(15)	/* Executing key search per MPDU */
+#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. Control frames BA, BAR, and PS-Poll (when in AP mode) are not controlled by this bit. They are controlled by ADF. */
+#define RCR_ADF					BIT(11)	/* Accept data type frame. This bit also regulates BA, BAR, and PS-Poll (AP mode only). */
+#define RCR_DISDECMYPKT			BIT(10)	/* This bit determines whether hw need to do decryption.1: If A1 match, do decryption.0: Do decryption. */
+#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_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 */
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* 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_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_EN_25_1				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)
+
+
+/* 2 9346CR /REG_SYS_EEPROM_CTRL */
+#define BOOT_FROM_EEPROM		BIT(4)
+#define EEPROMSEL				BIT(4)
+#define EEPROM_EN				BIT(5)
+
+
+/* 2 RF_CTRL */
+#define RF_EN					BIT(0)
+#define RF_RSTB					BIT(1)
+#define RF_SDMRSTB				BIT(2)
+
+
+/* 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 EFUSE_TEST (For RTL8723 partially) */
+#define EF_TRPT					BIT(7)
+#define EF_CELL_SEL				(BIT(8) | BIT(9)) /* 00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2 */
+#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
+
+
+/* 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 RAM_DL_SEL				BIT(7)
+#define CPU_DL_READY			BIT(15) /* add flag  by gw for fw download ready 20130826 */
+#define ROM_DLEN				BIT(19)
+#define CPRST					BIT(23)
+
+
+/* 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 SW_OFFLOAD_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 EXT_VENDOR_ID			(BIT(18) | BIT(19)) /* Currently only for RTL8723B */
+#define PAD_HWPD_IDN			BIT(22)
+#define TRP_VAUX_EN				BIT(23)	/* RTL ID */
+#define TRP_BT_EN				BIT(24)
+#define BD_PKG_SEL				BIT(25)
+#define BD_HCI_SEL				BIT(26)
+#define TYPE_ID					BIT(27)
+#define RF_TYPE_ID				BIT(27)
+
+#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 */
+
+
+#define CHIP_VER_RTL_MASK		0xF000	/* Bit 12 ~ 15 */
+#define CHIP_VER_RTL_SHIFT		12
+#define EXT_VENDOR_ID_SHIFT	18
+
+/* 2 REG_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 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 CALTMR_EN				BIT(10)	/* 32k CAL TMR enable */
+
+/* Network type */
+#define _NETTYPE(x)				(((x) & 0x3) << 16)
+#define MASK_NETTYPE			0x30000
+#define NT_NO_LINK				0x0
+#define NT_LINK_AD_HOC			0x1
+#define NT_LINK_AP				0x2
+#define NT_AS_AP				0x3
+
+/* 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_CMQ_MAP(x)			(((x) & 0x3) << 16)
+#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_EXTRA				0
+#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)
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+/* 2 RQPN */
+#define _HPQ(x)					((x) & 0xFF)
+#define _LPQ(x)					(((x) & 0xFF) << 8)
+#define _PUBQ(x)					(((x) & 0xFF) << 16)
+#define _NPQ(x)					((x) & 0xFF)			/* NOTE: in RQPN_NPQ register */
+#define _EPQ(x)					(((x) & 0xFF) << 16)	/* NOTE: in RQPN_EPQ register */
+
+
+#define HPQ_PUBLIC_DIS			BIT(24)
+#define LPQ_PUBLIC_DIS			BIT(25)
+#define LD_RQPN					BIT(31)
+
+
+/* 2 TDECTL */
+#define BLK_DESC_NUM_SHIFT			4
+#define BLK_DESC_NUM_MASK			0xF
+
+
+/* 2 TXDMA_OFFSET_CHK */
+#define DROP_DATA_EN				BIT(9)
+
+/* 2 AUTO_LLT */
+#define BIT_SHIFT_TXPKTNUM 24
+#define BIT_MASK_TXPKTNUM 0xff
+#define BIT_TXPKTNUM(x) (((x) & BIT_MASK_TXPKTNUM) << BIT_SHIFT_TXPKTNUM)
+
+#define BIT_TDE_DBG_SEL BIT(23)
+#define BIT_AUTO_INIT_LLT BIT(16)
+
+#define BIT_SHIFT_Tx_OQT_free_space 8
+#define BIT_MASK_Tx_OQT_free_space 0xff
+#define BIT_Tx_OQT_free_space(x) (((x) & BIT_MASK_Tx_OQT_free_space) << BIT_SHIFT_Tx_OQT_free_space)
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0120h ~ 0x0123h	RX DMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define BIT_FS_RXDONE_INT_EN				BIT(16)
+
+
+/* REG_RXPKT_NUM				(Offset 0x0284) */
+#define BIT_RW_RELEASE_EN				BIT(18)
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x028Bh	RX DMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* 2 REG_RXDMA_CONTROL, 0x0286h
+ * Write only. When this bit is set, RXDMA will decrease RX PKT counter by one. Before
+ * this bit is polled, FW shall update RXFF_RD_PTR first. This register is write pulse and auto clear.
+ * #define RXPKT_RELEASE_POLL			BIT(0)
+ * Read only. When RXMA finishes on-going DMA operation, RXMDA will report idle state in
+ * this bit. FW can start releasing packets after RXDMA entering idle mode.
+ * #define RXDMA_IDLE					BIT(1)
+ * When this bit is set, RXDMA will enter this mode after on-going RXDMA packet to host
+ * completed, and stop DMA packet to host. RXDMA will then report Default: 0;
+ * #define RW_RELEASE_EN				BIT(2) */
+
+/* 2 REG_RXPKT_NUM, 0x0284 */
+#define	RXPKT_RELEASE_POLL	BIT(16)
+#define	RXDMA_IDLE				BIT(17)
+#define	RW_RELEASE_EN			BIT(18)
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+/* 2 FWHW_TXQ_CTRL */
+#define EN_AMPDU_RTY_NEW			BIT(7)
+
+
+/* 2 SPEC SIFS */
+#define _SPEC_SIFS_CCK(x)			((x) & 0xFF)
+#define _SPEC_SIFS_OFDM(x)			(((x) & 0xFF) << 8)
+
+/* 2 RL */
+#define	RETRY_LIMIT_SHORT_SHIFT			8
+#define	RETRY_LIMIT_LONG_SHIFT			0
+
+#define	RL_VAL_AP					7
+#ifdef CONFIG_RTW_CUSTOMIZE_RLSTA
+#define	RL_VAL_STA					CONFIG_RTW_CUSTOMIZE_RLSTA
+#else
+#define	RL_VAL_STA					0x30
+#endif
+/* -----------------------------------------------------
+ *
+ *	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
+
+
+#define _LRL(x)					((x) & 0x3F)
+#define _SRL(x)					(((x) & 0x3F) << 8)
+
+
+/* 2 BCN_CTRL */
+#define EN_TXBCN_RPT			BIT(2)
+#define EN_BCN_FUNCTION		BIT(3)
+#define STOP_BCNQ				BIT(6)
+#define DIS_RX_BSSID_FIT		BIT(6)
+
+#define DIS_ATIM					BIT(0)
+#define DIS_BCNQ_SUB			BIT(1)
+#define DIS_TSF_UDT				BIT(4)
+
+/* 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_VoqEn			BIT(1)
+#define AcmHw_ViqEn				BIT(2)
+#define AcmHw_BeqEn			BIT(3)
+#define AcmHw_VoqStatus		BIT(5)
+#define AcmHw_ViqStatus			BIT(6)
+#define AcmHw_BeqStatus		BIT(7)
+
+/* 2 */ /* REG_DUAL_TSF_RST (0x553) */
+#define DUAL_TSF_RST_P2P		BIT(4)
+
+/* 2 */ /* REG_NOA_DESC_SEL (0x5CF) */
+#define NOA_DESC_SEL_0			0
+#define NOA_DESC_SEL_1			BIT(4)
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* 2 APSD_CTRL */
+#define APSDOFF					BIT(6)
+
+/* 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_DATA				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 FORCEACK				BIT(26)
+#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 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 */
+#define SCR_TXBCUSEDK			BIT(6)			/* Force Tx Broadcast packets Use Default Key */
+#define SCR_RXBCUSEDK			BIT(7)			/* Force Rx Broadcast packets Use Default Key */
+#define SCR_CHK_KEYID			BIT(8)
+#define SCR_CHK_BMC				BIT(9)			/* add option to support a2+keyid+bcm */
+
+/*REG_MBIDCAMCFG           (Offset 0x0628/0x62C)*/
+#define BIT_MBIDCAM_POLL		BIT(31)
+#define BIT_MBIDCAM_WT_EN		BIT(30)
+
+#define MBIDCAM_ADDR_MASK		0x1F
+#define MBIDCAM_ADDR_SHIFT		24
+
+#define BIT_MBIDCAM_VALID		BIT(23)
+#define BIT_LSIC_TXOP_EN		BIT(17)
+#define BIT_CTS_EN				BIT(16)
+
+/* -----------------------------------------------------
+ *
+ *	SDIO Bus Specification
+ *
+ * ----------------------------------------------------- */
+
+/* I/O bus domain address mapping */
+#define SDIO_LOCAL_BASE		0x10250000
+#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 TX_EPQ_BASE				0x10350000
+#define RX_RX0FF_BASE			0x10340000
+
+/* SDIO host local register space mapping. */
+#define SDIO_LOCAL_MSK				0x0FFF
+#define WLAN_IOREG_MSK		0x7FFF
+#define WLAN_FIFO_MSK			      	0x1FFF	/* Aggregation Length[12:0] */
+#define WLAN_RX0FF_MSK				0x0003
+
+#define SDIO_WITHOUT_REF_DEVICE_ID	0	/* Without reference to the SDIO Device ID */
+#define SDIO_LOCAL_DEVICE_ID           		0	/* 0b[16], 000b[15:13] */
+#define WLAN_TX_HIQ_DEVICE_ID			4	/* 0b[16], 100b[15:13] */
+#define WLAN_TX_MIQ_DEVICE_ID 		5	/* 0b[16], 101b[15:13] */
+#define WLAN_TX_LOQ_DEVICE_ID 		6	/* 0b[16], 110b[15:13] */
+#define WLAN_TX_EXQ_DEVICE_ID		3	/* 0b[16], 011b[15:13] */
+#define WLAN_RX0FF_DEVICE_ID 			7	/* 0b[16], 111b[15:13] */
+#define WLAN_IOREG_DEVICE_ID 			8	/* 1b[16] */
+
+/* SDIO Tx Free Page Index */
+#define HI_QUEUE_IDX			0
+#define MID_QUEUE_IDX			1
+#define LOW_QUEUE_IDX				2
+#define PUBLIC_QUEUE_IDX			3
+
+#define SDIO_MAX_TX_QUEUE			3		/* HIQ, MIQ and LOQ */
+#define SDIO_MAX_RX_QUEUE			1
+
+#define SDIO_REG_TX_CTRL			0x0000 /* SDIO Tx Control */
+#define SDIO_REG_HIMR				0x0014 /* SDIO Host Interrupt Mask */
+#define SDIO_REG_HISR				0x0018 /* SDIO Host Interrupt Service Routine */
+#define SDIO_REG_HCPWM			0x0019 /* HCI Current Power Mode */
+#define SDIO_REG_RX0_REQ_LEN		0x001C /* RXDMA Request Length */
+#define SDIO_REG_OQT_FREE_PG		0x001E /* OQT Free Page */
+#define SDIO_REG_FREE_TXPG			0x0020 /* Free Tx Buffer Page */
+#define SDIO_REG_HCPWM1			0x0024 /* HCI Current Power Mode 1 */
+#define SDIO_REG_HCPWM2			0x0026 /* HCI Current Power Mode 2 */
+#define SDIO_REG_FREE_TXPG_SEQ	0x0028 /* Free Tx Page Sequence */
+#define SDIO_REG_HTSFR_INFO		0x0030 /* HTSF Informaion */
+#define SDIO_REG_HRPWM1			0x0080 /* HCI Request Power Mode 1 */
+#define SDIO_REG_HRPWM2			0x0082 /* HCI Request Power Mode 2 */
+#define SDIO_REG_HPS_CLKR			0x0084 /* HCI Power Save Clock */
+#define SDIO_REG_HSUS_CTRL			0x0086 /* SDIO HCI Suspend Control */
+#define SDIO_REG_HIMR_ON			0x0090 /* SDIO Host Extension Interrupt Mask Always */
+#define SDIO_REG_HISR_ON			0x0091 /* SDIO Host Extension Interrupt Status Always */
+
+#define SDIO_HIMR_DISABLED			0
+
+/* RTL8723/RTL8188E SDIO Host Interrupt Mask Register */
+#define SDIO_HIMR_RX_REQUEST_MSK		BIT(0)
+#define SDIO_HIMR_AVAL_MSK			BIT(1)
+#define SDIO_HIMR_TXERR_MSK			BIT(2)
+#define SDIO_HIMR_RXERR_MSK			BIT(3)
+#define SDIO_HIMR_TXFOVW_MSK			BIT(4)
+#define SDIO_HIMR_RXFOVW_MSK			BIT(5)
+#define SDIO_HIMR_TXBCNOK_MSK			BIT(6)
+#define SDIO_HIMR_TXBCNERR_MSK		BIT(7)
+#define SDIO_HIMR_BCNERLY_INT_MSK		BIT(16)
+#define SDIO_HIMR_C2HCMD_MSK			BIT(17)
+#define SDIO_HIMR_CPWM1_MSK			BIT(18)
+#define SDIO_HIMR_CPWM2_MSK			BIT(19)
+#define SDIO_HIMR_HSISR_IND_MSK		BIT(20)
+#define SDIO_HIMR_GTINT3_IND_MSK		BIT(21)
+#define SDIO_HIMR_GTINT4_IND_MSK		BIT(22)
+#define SDIO_HIMR_PSTIMEOUT_MSK		BIT(23)
+#define SDIO_HIMR_OCPINT_MSK			BIT(24)
+#define SDIO_HIMR_ATIMEND_MSK			BIT(25)
+#define SDIO_HIMR_ATIMEND_E_MSK		BIT(26)
+#define SDIO_HIMR_CTWEND_MSK			BIT(27)
+
+/* RTL8188E SDIO Specific */
+#define SDIO_HIMR_MCU_ERR_MSK			BIT(28)
+#define SDIO_HIMR_TSF_BIT32_TOGGLE_MSK		BIT(29)
+
+/* SDIO Host Interrupt Service Routine */
+#define SDIO_HISR_RX_REQUEST			BIT(0)
+#define SDIO_HISR_AVAL					BIT(1)
+#define SDIO_HISR_TXERR					BIT(2)
+#define SDIO_HISR_RXERR					BIT(3)
+#define SDIO_HISR_TXFOVW				BIT(4)
+#define SDIO_HISR_RXFOVW				BIT(5)
+#define SDIO_HISR_TXBCNOK				BIT(6)
+#define SDIO_HISR_TXBCNERR				BIT(7)
+#define SDIO_HISR_BCNERLY_INT			BIT(16)
+#define SDIO_HISR_C2HCMD				BIT(17)
+#define SDIO_HISR_CPWM1				BIT(18)
+#define SDIO_HISR_CPWM2				BIT(19)
+#define SDIO_HISR_HSISR_IND			BIT(20)
+#define SDIO_HISR_GTINT3_IND			BIT(21)
+#define SDIO_HISR_GTINT4_IND			BIT(22)
+#define SDIO_HISR_PSTIMEOUT			BIT(23)
+#define SDIO_HISR_OCPINT				BIT(24)
+#define SDIO_HISR_ATIMEND				BIT(25)
+#define SDIO_HISR_ATIMEND_E			BIT(26)
+#define SDIO_HISR_CTWEND				BIT(27)
+
+/* RTL8188E SDIO Specific */
+#define SDIO_HISR_MCU_ERR				BIT(28)
+#define SDIO_HISR_TSF_BIT32_TOGGLE	BIT(29)
+
+#define MASK_SDIO_HISR_CLEAR		(SDIO_HISR_TXERR |\
+		SDIO_HISR_RXERR |\
+		SDIO_HISR_TXFOVW |\
+		SDIO_HISR_RXFOVW |\
+		SDIO_HISR_TXBCNOK |\
+		SDIO_HISR_TXBCNERR |\
+		SDIO_HISR_C2HCMD |\
+		SDIO_HISR_CPWM1 |\
+		SDIO_HISR_CPWM2 |\
+		SDIO_HISR_HSISR_IND |\
+		SDIO_HISR_GTINT3_IND |\
+		SDIO_HISR_GTINT4_IND |\
+		SDIO_HISR_PSTIMEOUT |\
+		SDIO_HISR_OCPINT)
+
+/* SDIO HCI Suspend Control Register */
+#define HCI_RESUME_PWR_RDY			BIT(1)
+#define HCI_SUS_CTRL					BIT(0)
+
+/* SDIO Tx FIFO related */
+#define SDIO_TX_FREE_PG_QUEUE			4	/* The number of Tx FIFO free page */
+#define SDIO_TX_FIFO_PAGE_SZ			128
+
+#ifdef CONFIG_SDIO_HCI
+	#define MAX_TX_AGG_PACKET_NUMBER	0x8
+#else
+	#define MAX_TX_AGG_PACKET_NUMBER	0xFF
+	#define MAX_TX_AGG_PACKET_NUMBER_8812	64
+#endif
+
+/* -----------------------------------------------------
+ *
+ *	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
+
+/* 2 Special Option */
+#define USB_AGG_EN				BIT(3)
+
+/* 0; Use interrupt endpoint to upload interrupt pkt
+ * 1; Use bulk endpoint to upload interrupt pkt, */
+#define INT_BULK_SEL			BIT(4)
+
+/* 2REG_C2HEVT_CLEAR */
+#define C2H_EVT_HOST_CLOSE		0x00	/* Set by driver and notify FW that the driver has read the C2H command message */
+#define C2H_EVT_FW_CLOSE		0xFF	/* Set by FW indicating that FW had set the C2H command message and it's not yet read by driver. */
+
+
+/* 2REG_MULTI_FUNC_CTRL(For RTL8723 Only) */
+#define WL_HWPDN_EN			BIT(0)	/* Enable GPIO[9] as WiFi HW PDn source */
+#define WL_HWPDN_SL			BIT(1)	/* WiFi HW PDn polarity control */
+#define WL_FUNC_EN				BIT(2)	/* WiFi function enable */
+#define WL_HWROF_EN			BIT(3)	/* Enable GPIO[9] as WiFi RF HW PDn source */
+#define BT_HWPDN_EN			BIT(16)	/* Enable GPIO[11] as BT HW PDn source */
+#define BT_HWPDN_SL			BIT(17)	/* BT HW PDn polarity control */
+#define BT_FUNC_EN				BIT(18)	/* BT function enable */
+#define BT_HWROF_EN			BIT(19)	/* Enable GPIO[11] as BT/GPS RF HW PDn source */
+#define GPS_HWPDN_EN			BIT(20)	/* Enable GPIO[10] as GPS HW PDn source */
+#define GPS_HWPDN_SL			BIT(21)	/* GPS HW PDn polarity control */
+#define GPS_FUNC_EN			BIT(22)	/* GPS function enable */
+
+/* 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. */
+
+/* 2 8192D PartNo. */
+#define PARTNO_92D_NIC							(BIT7 | BIT6)
+#define PARTNO_92D_NIC_REMARK				(BIT5 | BIT4)
+#define PARTNO_SINGLE_BAND_VS				BIT(3)
+#define PARTNO_SINGLE_BAND_VS_REMARK		BIT(1)
+#define PARTNO_CONCURRENT_BAND_VC			(BIT3 | BIT2)
+#define PARTNO_CONCURRENT_BAND_VC_REMARK	(BIT1 | BIT0)
+
+/* ********************************************************
+ * General definitions
+ * ******************************************************** */
+
+#ifdef CONFIG_USB_HCI
+	#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188E(__Adapter)	(175)
+#else
+	#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188E(__Adapter)	(IS_VENDOR_8188E_I_CUT_SERIES(__Adapter) ? 255 : 175)
+#endif
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8812			255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8723B		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8192C		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8703B		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_DUAL_MAC	127
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188F		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8723D		255
+
+#define POLLING_LLT_THRESHOLD				20
+#if defined(CONFIG_RTL8723B) && defined(CONFIG_PCI_HCI)
+	#define POLLING_READY_TIMEOUT_COUNT		6000
+#else
+	#define POLLING_READY_TIMEOUT_COUNT		1000
+#endif
+
+
+/* GPIO BIT */
+#define	HAL_8812A_HW_GPIO_WPS_BIT	BIT(2)
+#define	HAL_8192C_HW_GPIO_WPS_BIT	BIT(2)
+#define	HAL_8192EU_HW_GPIO_WPS_BIT	BIT(7)
+#define	HAL_8188E_HW_GPIO_WPS_BIT	BIT(7)
+
+#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_data.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_data.h
new file mode 100644
index 000000000000..7af31d25e91a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_data.h
@@ -0,0 +1,1039 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_DATA_H__
+#define __HAL_DATA_H__
+
+#if 1/* def  CONFIG_SINGLE_IMG */
+
+#include "../hal/phydm/phydm_precomp.h"
+#ifdef CONFIG_BT_COEXIST
+	#include <hal_btcoex.h>
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+	#include <hal_sdio.h>
+#endif
+#ifdef CONFIG_GSPI_HCI
+	#include <hal_gspi.h>
+#endif
+
+#if defined(CONFIG_RTW_ACS) || defined(CONFIG_BACKGROUND_NOISE_MONITOR)
+#include "../hal/hal_dm_acs.h"
+#endif
+
+/*
+ * <Roger_Notes> For RTL8723 WiFi/BT/GPS multi-function configuration. 2010.10.06.
+ *   */
+typedef enum _RT_MULTI_FUNC {
+	RT_MULTI_FUNC_NONE	= 0x00,
+	RT_MULTI_FUNC_WIFI	= 0x01,
+	RT_MULTI_FUNC_BT		= 0x02,
+	RT_MULTI_FUNC_GPS	= 0x04,
+} RT_MULTI_FUNC, *PRT_MULTI_FUNC;
+/*
+ * <Roger_Notes> For RTL8723 WiFi PDn/GPIO polarity control configuration. 2010.10.08.
+ *   */
+typedef enum _RT_POLARITY_CTL {
+	RT_POLARITY_LOW_ACT	= 0,
+	RT_POLARITY_HIGH_ACT	= 1,
+} RT_POLARITY_CTL, *PRT_POLARITY_CTL;
+
+/* For RTL8723 regulator mode. by tynli. 2011.01.14. */
+typedef enum _RT_REGULATOR_MODE {
+	RT_SWITCHING_REGULATOR	= 0,
+	RT_LDO_REGULATOR			= 1,
+} RT_REGULATOR_MODE, *PRT_REGULATOR_MODE;
+
+/*
+ * Interface type.
+ *   */
+typedef	enum _INTERFACE_SELECT_PCIE {
+	INTF_SEL0_SOLO_MINICARD			= 0,		/* WiFi solo-mCard */
+	INTF_SEL1_BT_COMBO_MINICARD		= 1,		/* WiFi+BT combo-mCard */
+	INTF_SEL2_PCIe						= 2,		/* PCIe Card */
+} INTERFACE_SELECT_PCIE, *PINTERFACE_SELECT_PCIE;
+
+
+typedef	enum _INTERFACE_SELECT_USB {
+	INTF_SEL0_USB 				= 0,		/* USB */
+	INTF_SEL1_USB_High_Power  	= 1,		/* USB with high power PA */
+	INTF_SEL2_MINICARD		  	= 2,		/* Minicard */
+	INTF_SEL3_USB_Solo 		= 3,		/* USB solo-Slim module */
+	INTF_SEL4_USB_Combo		= 4,		/* USB Combo-Slim module */
+	INTF_SEL5_USB_Combo_MF	= 5,		/* USB WiFi+BT Multi-Function Combo, i.e., Proprietary layout(AS-VAU) which is the same as SDIO card */
+} INTERFACE_SELECT_USB, *PINTERFACE_SELECT_USB;
+
+typedef enum _RT_AMPDU_BRUST_MODE {
+	RT_AMPDU_BRUST_NONE		= 0,
+	RT_AMPDU_BRUST_92D		= 1,
+	RT_AMPDU_BRUST_88E		= 2,
+	RT_AMPDU_BRUST_8812_4	= 3,
+	RT_AMPDU_BRUST_8812_8	= 4,
+	RT_AMPDU_BRUST_8812_12	= 5,
+	RT_AMPDU_BRUST_8812_15	= 6,
+	RT_AMPDU_BRUST_8723B		= 7,
+} RT_AMPDU_BRUST, *PRT_AMPDU_BRUST_MODE;
+
+/* Tx Power Limit Table Size */
+#define MAX_REGULATION_NUM						4
+#define MAX_RF_PATH_NUM_IN_POWER_LIMIT_TABLE	4
+#define MAX_2_4G_BANDWIDTH_NUM					2
+#define MAX_RATE_SECTION_NUM						10
+#define MAX_5G_BANDWIDTH_NUM						4
+
+#define MAX_BASE_NUM_IN_PHY_REG_PG_2_4G			10 /* CCK:1, OFDM:1, HT:4, VHT:4 */
+#define MAX_BASE_NUM_IN_PHY_REG_PG_5G			9 /* OFDM:1, HT:4, VHT:4 */
+
+#ifdef RTW_RX_AGGREGATION
+typedef enum _RX_AGG_MODE {
+	RX_AGG_DISABLE,
+	RX_AGG_DMA,
+	RX_AGG_USB,
+	RX_AGG_MIX
+} RX_AGG_MODE;
+
+/* #define MAX_RX_DMA_BUFFER_SIZE	10240 */		/* 10K for 8192C RX DMA buffer */
+
+#endif /* RTW_RX_AGGREGATION */
+
+/* E-Fuse */
+#ifdef CONFIG_RTL8188E
+	#define EFUSE_MAP_SIZE	512
+#endif
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8192E
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8723B
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8814A
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8703B
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8723D
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8188F
+	#define EFUSE_MAP_SIZE	512
+#endif
+
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	#define EFUSE_MAX_SIZE	1024
+#elif defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8703B)
+	#define EFUSE_MAX_SIZE	256
+#else
+	#define EFUSE_MAX_SIZE	512
+#endif
+/* end of E-Fuse */
+
+#define Mac_OFDM_OK			0x00000000
+#define Mac_OFDM_Fail		0x10000000
+#define Mac_OFDM_FasleAlarm	0x20000000
+#define Mac_CCK_OK			0x30000000
+#define Mac_CCK_Fail		0x40000000
+#define Mac_CCK_FasleAlarm	0x50000000
+#define Mac_HT_OK			0x60000000
+#define Mac_HT_Fail			0x70000000
+#define Mac_HT_FasleAlarm	0x90000000
+#define Mac_DropPacket		0xA0000000
+
+#ifdef CONFIG_RF_POWER_TRIM
+#if defined(CONFIG_RTL8723B)
+	#define REG_RF_BB_GAIN_OFFSET	0x7f
+	#define RF_GAIN_OFFSET_MASK		0xfffff
+#elif defined(CONFIG_RTL8188E)
+	#define REG_RF_BB_GAIN_OFFSET	0x55
+	#define RF_GAIN_OFFSET_MASK		0xfffff
+#else
+	#define REG_RF_BB_GAIN_OFFSET	0x55
+	#define RF_GAIN_OFFSET_MASK		0xfffff
+#endif /* CONFIG_RTL8723B */
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+/* For store initial value of BB register */
+typedef struct _BB_INIT_REGISTER {
+	u16	offset;
+	u32	value;
+
+} BB_INIT_REGISTER, *PBB_INIT_REGISTER;
+
+#define PAGE_SIZE_128	128
+#define PAGE_SIZE_256	256
+#define PAGE_SIZE_512	512
+
+#define HCI_SUS_ENTER		0
+#define HCI_SUS_LEAVING		1
+#define HCI_SUS_LEAVE		2
+#define HCI_SUS_ENTERING	3
+#define HCI_SUS_ERR			4
+
+#define EFUSE_FILE_UNUSED 0
+#define EFUSE_FILE_FAILED 1
+#define EFUSE_FILE_LOADED 2
+
+#define MACADDR_FILE_UNUSED 0
+#define MACADDR_FILE_FAILED 1
+#define MACADDR_FILE_LOADED 2
+
+#define MAX_IQK_INFO_BACKUP_CHNL_NUM	5
+#define MAX_IQK_INFO_BACKUP_REG_NUM		10
+
+struct kfree_data_t {
+	u8 flag;
+	s8 bb_gain[BB_GAIN_NUM][RF_PATH_MAX];
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	s8 pa_bias_5g[RF_PATH_MAX];
+	s8 pad_bias_5g[RF_PATH_MAX];
+#endif
+	s8 thermal;
+};
+
+bool kfree_data_is_bb_gain_empty(struct kfree_data_t *data);
+
+struct hal_spec_t {
+	char *ic_name;
+	u8 macid_num;
+
+	u8 sec_cam_ent_num;
+	u8 sec_cap;
+
+	u8 rfpath_num_2g:4;	/* used for tx power index path */
+	u8 rfpath_num_5g:4;	/* used for tx power index path */
+
+	u8 max_tx_cnt;
+	u8 tx_nss_num:4;
+	u8 rx_nss_num:4;
+	u8 band_cap;	/* value of BAND_CAP_XXX */
+	u8 bw_cap;		/* value of BW_CAP_XXX */
+	u8 port_num;
+	u8 proto_cap;	/* value of PROTO_CAP_XXX */
+	u8 wl_func;		/* value of WL_FUNC_XXX */
+
+	u8 pg_txpwr_saddr; /* starting address of PG tx power info */
+
+	u8 hci_type;	/* value of HCI Type */
+};
+
+#define HAL_SPEC_CHK_RF_PATH_2G(_spec, _path) ((_spec)->rfpath_num_2g > (_path))
+#define HAL_SPEC_CHK_RF_PATH_5G(_spec, _path) ((_spec)->rfpath_num_5g > (_path))
+#define HAL_SPEC_CHK_RF_PATH(_spec, _band, _path) ( \
+	_band == BAND_ON_2_4G ? HAL_SPEC_CHK_RF_PATH_2G(_spec, _path) : \
+	_band == BAND_ON_5G ? HAL_SPEC_CHK_RF_PATH_5G(_spec, _path) : 0)
+
+#define HAL_SPEC_CHK_TX_CNT(_spec, _cnt_idx) ((_spec)->max_tx_cnt > (_cnt_idx))
+
+#ifdef CONFIG_PHY_CAPABILITY_QUERY
+struct phy_spec_t {
+	u32 trx_cap;
+	u32 stbc_cap;
+	u32 ldpc_cap;
+	u32 txbf_param;
+	u32 txbf_cap;
+};
+#endif
+struct hal_iqk_reg_backup {
+	u8 central_chnl;
+	u8 bw_mode;
+	u32 reg_backup[MAX_RF_PATH][MAX_IQK_INFO_BACKUP_REG_NUM];
+};
+
+
+typedef struct hal_p2p_ps_para {
+	/*DW0*/
+	u8  offload_en:1;
+	u8  role:1;
+	u8  ctwindow_en:1;
+	u8  noa_en:1;
+	u8  noa_sel:1;
+	u8  all_sta_sleep:1;
+	u8  discovery:1;
+	u8  rsvd2:1;
+	u8  p2p_port_id;
+	u8  p2p_group;
+	u8  p2p_macid;
+
+	/*DW1*/
+	u8 ctwindow_length;
+	u8 rsvd3;
+	u8 rsvd4;
+	u8 rsvd5;
+
+	/*DW2*/
+	u32 noa_duration_para;
+
+	/*DW3*/
+	u32 noa_interval_para;
+
+	/*DW4*/
+	u32 noa_start_time_para;
+
+	/*DW5*/
+	u32 noa_count_para;
+} HAL_P2P_PS_PARA, *PHAL_P2P_PS_PARA;
+
+#define TXPWR_LMT_RS_CCK	0
+#define TXPWR_LMT_RS_OFDM	1
+#define TXPWR_LMT_RS_HT		2
+#define TXPWR_LMT_RS_VHT	3
+#define TXPWR_LMT_RS_NUM	4
+
+#define TXPWR_LMT_RS_NUM_2G	4 /* CCK, OFDM, HT, VHT */
+#define TXPWR_LMT_RS_NUM_5G	3 /* OFDM, HT, VHT */
+
+#ifdef CONFIG_TXPWR_LIMIT
+extern const char *const _txpwr_lmt_rs_str[];
+#define txpwr_lmt_rs_str(rs) (((rs) >= TXPWR_LMT_RS_NUM) ? _txpwr_lmt_rs_str[TXPWR_LMT_RS_NUM] : _txpwr_lmt_rs_str[(rs)])
+
+struct txpwr_lmt_ent {
+	_list list;
+
+	s8 lmt_2g[MAX_2_4G_BANDWIDTH_NUM]
+		[TXPWR_LMT_RS_NUM_2G]
+		[CENTER_CH_2G_NUM]
+		[MAX_TX_COUNT];
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	s8 lmt_5g[MAX_5G_BANDWIDTH_NUM]
+		[TXPWR_LMT_RS_NUM_5G]
+		[CENTER_CH_5G_ALL_NUM]
+		[MAX_TX_COUNT];
+#endif
+
+	char regd_name[0];
+};
+#endif /* CONFIG_TXPWR_LIMIT */
+
+typedef struct hal_com_data {
+	HAL_VERSION			version_id;
+	RT_MULTI_FUNC		MultiFunc; /* For multi-function consideration. */
+	RT_POLARITY_CTL		PolarityCtl; /* For Wifi PDn Polarity control. */
+	RT_REGULATOR_MODE	RegulatorMode; /* switching regulator or LDO */
+	u8	hw_init_completed;
+	/****** FW related ******/
+	u32 firmware_size;
+	u16 firmware_version;
+	u16	FirmwareVersionRev;
+	u16 firmware_sub_version;
+	u16	FirmwareSignature;
+	u8	RegFWOffload;
+	u8	bFWReady;
+	u8	bBTFWReady;
+	u8	fw_ractrl;
+	u8	LastHMEBoxNum;	/* H2C - for host message to fw */
+
+	/****** current WIFI_PHY values ******/
+	WIRELESS_MODE	CurrentWirelessMode;
+	enum channel_width current_channel_bw;
+	BAND_TYPE		current_band_type;	/* 0:2.4G, 1:5G */
+	BAND_TYPE		BandSet;
+	u8				current_channel;
+	u8				cch_20;
+	u8				cch_40;
+	u8				cch_80;
+	u8				CurrentCenterFrequencyIndex1;
+	u8				nCur40MhzPrimeSC;	/* Control channel sub-carrier */
+	u8				nCur80MhzPrimeSC;   /* used for primary 40MHz of 80MHz mode */
+	BOOLEAN		bSwChnlAndSetBWInProgress;
+	u8				bDisableSWChannelPlan; /* flag of disable software change channel plan	 */
+	u16				BasicRateSet;
+	u32				ReceiveConfig;
+	u32				rcr_backup; /* used for switching back from monitor mode */
+	u8				rx_tsf_addr_filter_config; /* for 8822B/8821C USE */
+	BOOLEAN			bSwChnl;
+	BOOLEAN			bSetChnlBW;
+	BOOLEAN			bSWToBW40M;
+	BOOLEAN			bSWToBW80M;
+	BOOLEAN			bChnlBWInitialized;
+	u32				BackUp_BB_REG_4_2nd_CCA[3];
+
+#ifdef CONFIG_RTW_ACS
+	struct auto_chan_sel acs;
+#endif
+#ifdef CONFIG_BCN_RECOVERY
+	u8 issue_bcn_fail;
+#endif /*CONFIG_BCN_RECOVERY*/
+
+	/****** rf_ctrl *****/
+	u8	rf_chip;
+	u8	rf_type;	/*enum rf_type*/
+	u8	PackageType;
+	u8	NumTotalRFPath;
+	u8	antenna_test;
+
+	/****** Debug ******/
+	u16	ForcedDataRate;	/* Force Data Rate. 0: Auto, 0x02: 1M ~ 0x6C: 54M. */
+	u8	bDumpRxPkt;
+	u8	bDumpTxPkt;
+	u8	dis_turboedca;
+
+
+	/****** EEPROM setting.******/
+	u8	bautoload_fail_flag;
+	u8	efuse_file_status;
+	u8	macaddr_file_status;
+	u8	EepromOrEfuse;
+	u8	efuse_eeprom_data[EEPROM_MAX_SIZE]; /*92C:256bytes, 88E:512bytes, we use union set (512bytes)*/
+	u8	InterfaceSel; /* board type kept in eFuse */
+	u16	CustomerID;
+
+	u16	EEPROMVID;
+	u16	EEPROMSVID;
+#ifdef CONFIG_USB_HCI
+	u8	EEPROMUsbSwitch;
+	u16	EEPROMPID;
+	u16	EEPROMSDID;
+#endif
+#ifdef CONFIG_PCI_HCI
+	u16	EEPROMDID;
+	u16	EEPROMSMID;
+#endif
+
+	u8	EEPROMCustomerID;
+	u8	EEPROMSubCustomerID;
+	u8	EEPROMVersion;
+	u8	EEPROMRegulatory;
+	u8	eeprom_thermal_meter;
+	u8	EEPROMBluetoothCoexist;
+	u8	EEPROMBluetoothType;
+	u8	EEPROMBluetoothAntNum;
+	u8	EEPROMBluetoothAntIsolation;
+	u8	EEPROMBluetoothRadioShared;
+	u8	EEPROMMACAddr[ETH_ALEN];
+	u8	tx_bbswing_24G;
+	u8	tx_bbswing_5G;
+	u8	efuse0x3d7;	/* efuse[0x3D7] */
+	u8	efuse0x3d8;	/* efuse[0x3D8] */
+
+#ifdef CONFIG_RF_POWER_TRIM
+	u8	EEPROMRFGainOffset;
+	u8	EEPROMRFGainVal;
+	struct kfree_data_t kfree_data;
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || \
+	defined(CONFIG_RTL8723D)
+	u8	adjuseVoltageVal;
+	u8	need_restore;
+#endif
+	u8	EfuseUsedPercentage;
+	u16	EfuseUsedBytes;
+	/*u8		EfuseMap[2][HWSET_MAX_SIZE_JAGUAR];*/
+	EFUSE_HAL	EfuseHal;
+
+	/*---------------------------------------------------------------------------------*/
+	/* 2.4G TX power info for target TX power*/
+	u8	Index24G_CCK_Base[MAX_RF_PATH][CENTER_CH_2G_NUM];
+	u8	Index24G_BW40_Base[MAX_RF_PATH][CENTER_CH_2G_NUM];
+	s8	CCK_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8	OFDM_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8	BW20_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8	BW40_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+
+	/* 5G TX power info for target TX power*/
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	u8	Index5G_BW40_Base[MAX_RF_PATH][CENTER_CH_5G_ALL_NUM];
+	u8	Index5G_BW80_Base[MAX_RF_PATH][CENTER_CH_5G_80M_NUM];
+	s8	OFDM_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8	BW20_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8	BW40_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8	BW80_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+#endif
+
+	u8 txpwr_by_rate_undefined_band_path[TX_PWR_BY_RATE_NUM_BAND]
+		[TX_PWR_BY_RATE_NUM_RF];
+
+	s8	TxPwrByRateOffset[TX_PWR_BY_RATE_NUM_BAND]
+		[TX_PWR_BY_RATE_NUM_RF]
+		[TX_PWR_BY_RATE_NUM_RATE];
+
+	/* Store the original power by rate value of the base rate for each rate section and rf path */
+	u8	TxPwrByRateBase2_4G[TX_PWR_BY_RATE_NUM_RF]
+		[MAX_BASE_NUM_IN_PHY_REG_PG_2_4G];
+	u8	TxPwrByRateBase5G[TX_PWR_BY_RATE_NUM_RF]
+		[MAX_BASE_NUM_IN_PHY_REG_PG_5G];
+
+	u8	txpwr_by_rate_loaded:1;
+	u8	txpwr_by_rate_from_file:1;
+	u8	txpwr_limit_loaded:1;
+	u8	txpwr_limit_from_file:1;
+	u8	rf_power_tracking_type;
+
+	/* Read/write are allow for following hardware information variables	 */
+	u8	crystal_cap;
+
+	u8	PAType_2G;
+	u8	PAType_5G;
+	u8	LNAType_2G;
+	u8	LNAType_5G;
+	u8	ExternalPA_2G;
+	u8	ExternalLNA_2G;
+	u8	external_pa_5g;
+	u8	external_lna_5g;
+	u16	TypeGLNA;
+	u16	TypeGPA;
+	u16	TypeALNA;
+	u16	TypeAPA;
+	u16	rfe_type;
+
+	u8	bLedOpenDrain; /* Support Open-drain arrangement for controlling the LED. Added by Roger, 2009.10.16. */
+	u32	ac_param_be; /* Original parameter for BE, use for EDCA turbo.	*/
+	u8	is_turbo_edca;
+	u8	prv_traffic_idx;
+	BB_REGISTER_DEFINITION_T	PHYRegDef[MAX_RF_PATH];	/* Radio A/B/C/D */
+
+	u32	RfRegChnlVal[MAX_RF_PATH];
+
+	/* RDG enable */
+	BOOLEAN	 bRDGEnable;
+
+	u16 RegRRSR;
+	/****** antenna diversity ******/
+	u8	AntDivCfg;
+	u8	with_extenal_ant_switch;
+	u8	b_fix_tx_ant;
+	u8	AntDetection;
+	u8	TRxAntDivType;
+	u8	ant_path; /* for 8723B s0/s1 selection	 */
+	u32	antenna_tx_path;					/* Antenna path Tx */
+	u32	AntennaRxPath;					/* Antenna path Rx */
+	u8 sw_antdiv_bl_state;
+
+	/******** PHY DM & DM Section **********/
+	_lock		IQKSpinLock;
+	u8			INIDATA_RATE[MACID_NUM_SW_LIMIT];
+
+	struct dm_struct	 odmpriv;
+	u64			bk_rf_ability;
+	u8			bIQKInitialized;
+	u8			bNeedIQK;
+	u8			IQK_MP_Switch;
+	u8			bScanInProcess;
+	/******** PHY DM & DM Section **********/
+
+
+
+	/* 2010/08/09 MH Add CU power down mode. */
+	BOOLEAN		pwrdown;
+
+	/* Add for dual MAC  0--Mac0 1--Mac1 */
+	u32	interfaceIndex;
+
+#ifdef CONFIG_P2P
+	u8	p2p_ps_offload;
+#endif
+	/* Auto FSM to Turn On, include clock, isolation, power control for MAC only */
+	u8	bMacPwrCtrlOn;
+	u8 hci_sus_state;
+
+	u8	RegIQKFWOffload;
+	struct submit_ctx	iqk_sctx;
+	u8 ch_switch_offload;
+	struct submit_ctx chsw_sctx;
+
+	RT_AMPDU_BRUST		AMPDUBurstMode; /* 92C maybe not use, but for compile successfully */
+
+	u8	OutEpQueueSel;
+	u8	OutEpNumber;
+
+#ifdef RTW_RX_AGGREGATION
+	RX_AGG_MODE rxagg_mode;
+
+	/* For RX Aggregation DMA Mode */
+	u8 rxagg_dma_size;
+	u8 rxagg_dma_timeout;
+#endif /* RTW_RX_AGGREGATION */
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	/*  */
+	/* For SDIO Interface HAL related */
+	/*  */
+
+	/*  */
+	/* SDIO ISR Related */
+	/*
+	*	u32			IntrMask[1];
+	*	u32			IntrMaskToSet[1];
+	*	LOG_INTERRUPT		InterruptLog; */
+	u32			sdio_himr;
+	u32			sdio_hisr;
+#ifndef RTW_HALMAC
+	/*  */
+	/* SDIO Tx FIFO related. */
+	/*  */
+	/* HIQ, MID, LOW, PUB free pages; padapter->xmitpriv.free_txpg */
+	u8			SdioTxFIFOFreePage[SDIO_TX_FREE_PG_QUEUE];
+	_lock		SdioTxFIFOFreePageLock;
+	u8			SdioTxOQTMaxFreeSpace;
+	u8			SdioTxOQTFreeSpace;
+#else /* RTW_HALMAC */
+	u16			SdioTxOQTFreeSpace;
+#endif /* RTW_HALMAC */
+
+	/*  */
+	/* SDIO Rx FIFO related. */
+	/*  */
+	u8			SdioRxFIFOCnt;
+	u16			SdioRxFIFOSize;
+
+#ifndef RTW_HALMAC
+	u32			sdio_tx_max_len[SDIO_MAX_TX_QUEUE];/* H, N, L, used for sdio tx aggregation max length per queue */
+#else
+#ifdef CONFIG_RTL8821C
+	u16			tx_high_page;
+	u16			tx_low_page;
+	u16			tx_normal_page;
+	u16			tx_extra_page;
+	u16			tx_pub_page;
+	u8			max_oqt_size;
+	#ifdef XMIT_BUF_SIZE
+	u32			max_xmit_size_vovi;
+	u32			max_xmit_size_bebk;
+	#endif /*XMIT_BUF_SIZE*/
+	u16			max_xmit_page;
+	u16			max_xmit_page_vo;
+	u16			max_xmit_page_vi;
+	u16			max_xmit_page_be;
+	u16			max_xmit_page_bk;
+
+#endif /*#ifdef CONFIG_RTL8821C*/
+#endif /* !RTW_HALMAC */
+#endif /* CONFIG_SDIO_HCI */
+
+#ifdef CONFIG_USB_HCI
+
+	/* 2010/12/10 MH Add for USB aggreation mode dynamic shceme. */
+	BOOLEAN		UsbRxHighSpeedMode;
+	BOOLEAN		UsbTxVeryHighSpeedMode;
+	u32			UsbBulkOutSize;
+	BOOLEAN		bSupportUSB3;
+	u8			usb_intf_start;
+
+	/* Interrupt relatd register information. */
+	u32			IntArray[3];/* HISR0,HISR1,HSISR */
+	u32			IntrMask[3];
+#ifdef CONFIG_USB_TX_AGGREGATION
+	u8			UsbTxAggMode;
+	u8			UsbTxAggDescNum;
+#endif /* CONFIG_USB_TX_AGGREGATION */
+
+#ifdef CONFIG_USB_RX_AGGREGATION
+	u16			HwRxPageSize;				/* Hardware setting */
+
+	/* For RX Aggregation USB Mode */
+	u8			rxagg_usb_size;
+	u8			rxagg_usb_timeout;
+#endif/* CONFIG_USB_RX_AGGREGATION */
+#endif /* CONFIG_USB_HCI */
+
+
+#ifdef CONFIG_PCI_HCI
+	/*  */
+	/* EEPROM setting. */
+	/*  */
+	u32			TransmitConfig;
+	u32			IntrMaskToSet[2];
+	u32			IntArray[4];
+	u32			IntrMask[4];
+	u32			SysIntArray[1];
+	u32			SysIntrMask[1];
+	u32			IntrMaskReg[2];
+	u32			IntrMaskDefault[4];
+
+	BOOLEAN		bL1OffSupport;
+	BOOLEAN	bSupportBackDoor;
+	u32			pci_backdoor_ctrl;
+
+	u8			bDefaultAntenna;
+
+	u8			bInterruptMigration;
+	u8			bDisableTxInt;
+
+	u16			RxTag;
+#ifdef CONFIG_PCI_DYNAMIC_ASPM
+	BOOLEAN		bAspmL1LastIdle;
+#endif
+#endif /* CONFIG_PCI_HCI */
+
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	struct sreset_priv srestpriv;
+#endif /* #ifdef DBG_CONFIG_ERROR_DETECT */
+
+#ifdef CONFIG_BT_COEXIST
+	/* For bluetooth co-existance */
+	BT_COEXIST		bt_coexist;
+#endif /* CONFIG_BT_COEXIST */
+
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) \
+	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8723D)
+#ifndef CONFIG_PCI_HCI	/* mutual exclusive with PCI -- so they're SDIO and GSPI */
+	/* Interrupt relatd register information. */
+	u32			SysIntrStatus;
+	u32			SysIntrMask;
+#endif
+#endif /*endif CONFIG_RTL8723B	*/
+
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	char	para_file_buf[MAX_PARA_FILE_BUF_LEN];
+	char *mac_reg;
+	u32	mac_reg_len;
+	char *bb_phy_reg;
+	u32	bb_phy_reg_len;
+	char *bb_agc_tab;
+	u32	bb_agc_tab_len;
+	char *bb_phy_reg_pg;
+	u32	bb_phy_reg_pg_len;
+	char *bb_phy_reg_mp;
+	u32	bb_phy_reg_mp_len;
+	char *rf_radio_a;
+	u32	rf_radio_a_len;
+	char *rf_radio_b;
+	u32	rf_radio_b_len;
+	char *rf_tx_pwr_track;
+	u32	rf_tx_pwr_track_len;
+	char *rf_tx_pwr_lmt;
+	u32	rf_tx_pwr_lmt_len;
+#endif
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	struct noise_monitor nm;
+#endif
+
+	struct hal_spec_t hal_spec;
+#ifdef CONFIG_PHY_CAPABILITY_QUERY
+	struct phy_spec_t phy_spec;
+#endif
+	u8	RfKFreeEnable;
+	u8	RfKFree_ch_group;
+	BOOLEAN				bCCKinCH14;
+	BB_INIT_REGISTER	RegForRecover[5];
+
+#if defined(CONFIG_PCI_HCI) && defined(RTL8814AE_SW_BCN)
+	BOOLEAN bCorrectBCN;
+#endif
+	u32 RxGainOffset[4]; /*{2G, 5G_Low, 5G_Middle, G_High}*/
+	u8 BackUp_IG_REG_4_Chnl_Section[4]; /*{A,B,C,D}*/
+
+	struct hal_iqk_reg_backup iqk_reg_backup[MAX_IQK_INFO_BACKUP_CHNL_NUM];
+
+#ifdef RTW_HALMAC
+	u8 drv_rsvd_page_number;
+#endif
+
+#ifdef CONFIG_BEAMFORMING
+	u8 backup_snd_ptcl_ctrl;
+#ifdef RTW_BEAMFORMING_VERSION_2
+	struct beamforming_info beamforming_info;
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+
+	u8 not_xmitframe_fw_dl; /*not use xmitframe to download fw*/
+	u8 phydm_op_mode;
+
+	u8 in_cta_test;
+
+#ifdef CONFIG_RTW_LED
+	struct led_priv led;
+#endif
+} HAL_DATA_COMMON, *PHAL_DATA_COMMON;
+
+typedef struct hal_com_data HAL_DATA_TYPE, *PHAL_DATA_TYPE;
+#define GET_HAL_DATA(__pAdapter)			((HAL_DATA_TYPE *)(((struct _ADAPTER*)__pAdapter)->HalData))
+#define GET_HAL_SPEC(__pAdapter)			(&(GET_HAL_DATA((__pAdapter))->hal_spec))
+#define adapter_to_led(adapter) (&(GET_HAL_DATA(adapter)->led))
+
+#define GET_HAL_RFPATH_NUM(__pAdapter)		(((HAL_DATA_TYPE *)((__pAdapter)->HalData))->NumTotalRFPath)
+#define RT_GetInterfaceSelection(_Adapter)		(GET_HAL_DATA(_Adapter)->InterfaceSel)
+#define GET_RF_TYPE(__pAdapter)				(GET_HAL_DATA(__pAdapter)->rf_type)
+#define GET_KFREE_DATA(_adapter) (&(GET_HAL_DATA((_adapter))->kfree_data))
+
+#define	SUPPORT_HW_RADIO_DETECT(Adapter)	(RT_GetInterfaceSelection(Adapter) == INTF_SEL2_MINICARD || \
+		RT_GetInterfaceSelection(Adapter) == INTF_SEL3_USB_Solo || \
+		RT_GetInterfaceSelection(Adapter) == INTF_SEL4_USB_Combo)
+
+#define get_hal_mac_addr(adapter)				(GET_HAL_DATA(adapter)->EEPROMMACAddr)
+#define is_boot_from_eeprom(adapter)			(GET_HAL_DATA(adapter)->EepromOrEfuse)
+#define rtw_get_hw_init_completed(adapter)		(GET_HAL_DATA(adapter)->hw_init_completed)
+#define rtw_set_hw_init_completed(adapter, cmp)	(GET_HAL_DATA(adapter)->hw_init_completed = cmp)
+#define rtw_is_hw_init_completed(adapter)		(GET_HAL_DATA(adapter)->hw_init_completed == _TRUE)
+#endif
+
+#ifdef RTW_HALMAC
+int rtw_halmac_deinit_adapter(struct dvobj_priv *);
+#endif /* RTW_HALMAC */
+
+/* alias for phydm coding style */
+#define REG_OFDM_0_XA_TX_IQ_IMBALANCE	rOFDM0_XATxIQImbalance
+#define REG_OFDM_0_ECCA_THRESHOLD		rOFDM0_ECCAThreshold
+#define REG_FPGA0_XB_LSSI_READ_BACK		rFPGA0_XB_LSSIReadBack
+#define REG_FPGA0_TX_GAIN_STAGE			rFPGA0_TxGainStage
+#define REG_OFDM_0_XA_AGC_CORE1			rOFDM0_XAAGCCore1
+#define REG_OFDM_0_XB_AGC_CORE1			rOFDM0_XBAGCCore1
+#define REG_A_TX_SCALE_JAGUAR			rA_TxScale_Jaguar
+#define REG_B_TX_SCALE_JAGUAR			rB_TxScale_Jaguar
+
+#define REG_FPGA0_XAB_RF_INTERFACE_SW	rFPGA0_XAB_RFInterfaceSW
+#define REG_FPGA0_XAB_RF_PARAMETER	rFPGA0_XAB_RFParameter
+#define REG_FPGA0_XA_HSSI_PARAMETER1	rFPGA0_XA_HSSIParameter1
+#define REG_FPGA0_XA_LSSI_PARAMETER	rFPGA0_XA_LSSIParameter
+#define REG_FPGA0_XA_RF_INTERFACE_OE	rFPGA0_XA_RFInterfaceOE
+#define REG_FPGA0_XB_HSSI_PARAMETER1	rFPGA0_XB_HSSIParameter1
+#define REG_FPGA0_XB_LSSI_PARAMETER	rFPGA0_XB_LSSIParameter
+#define REG_FPGA0_XB_LSSI_READ_BACK	rFPGA0_XB_LSSIReadBack
+#define REG_FPGA0_XB_RF_INTERFACE_OE	rFPGA0_XB_RFInterfaceOE
+#define REG_FPGA0_XCD_RF_INTERFACE_SW	rFPGA0_XCD_RFInterfaceSW
+#define REG_FPGA0_XCD_SWITCH_CONTROL	rFPGA0_XCD_SwitchControl
+#define REG_FPGA1_TX_BLOCK	rFPGA1_TxBlock
+#define REG_FPGA1_TX_INFO	rFPGA1_TxInfo
+#define REG_IQK_AGC_CONT	rIQK_AGC_Cont
+#define REG_IQK_AGC_PTS	rIQK_AGC_Pts
+#define REG_IQK_AGC_RSP	rIQK_AGC_Rsp
+#define REG_OFDM_0_AGC_RSSI_TABLE	rOFDM0_AGCRSSITable
+#define REG_OFDM_0_ECCA_THRESHOLD	rOFDM0_ECCAThreshold
+#define REG_OFDM_0_RX_IQ_EXT_ANTA	rOFDM0_RxIQExtAnta
+#define REG_OFDM_0_TR_MUX_PAR	rOFDM0_TRMuxPar
+#define REG_OFDM_0_TRX_PATH_ENABLE	rOFDM0_TRxPathEnable
+#define REG_OFDM_0_XA_AGC_CORE1	rOFDM0_XAAGCCore1
+#define REG_OFDM_0_XA_RX_IQ_IMBALANCE	rOFDM0_XARxIQImbalance
+#define REG_OFDM_0_XA_TX_IQ_IMBALANCE	rOFDM0_XATxIQImbalance
+#define REG_OFDM_0_XB_AGC_CORE1	rOFDM0_XBAGCCore1
+#define REG_OFDM_0_XB_RX_IQ_IMBALANCE	rOFDM0_XBRxIQImbalance
+#define REG_OFDM_0_XB_TX_IQ_IMBALANCE	rOFDM0_XBTxIQImbalance
+#define REG_OFDM_0_XC_TX_AFE	rOFDM0_XCTxAFE
+#define REG_OFDM_0_XD_TX_AFE	rOFDM0_XDTxAFE
+
+/*#define REG_A_CFO_LONG_DUMP_92E	rA_CfoLongDump_92E*/
+#define REG_A_CFO_LONG_DUMP_JAGUAR	rA_CfoLongDump_Jaguar
+/*#define REG_A_CFO_SHORT_DUMP_92E	rA_CfoShortDump_92E*/
+#define REG_A_CFO_SHORT_DUMP_JAGUAR	rA_CfoShortDump_Jaguar
+#define REG_A_RFE_PINMUX_JAGUAR	rA_RFE_Pinmux_Jaguar
+/*#define REG_A_RSSI_DUMP_92E	rA_RSSIDump_92E*/
+#define REG_A_RSSI_DUMP_JAGUAR	rA_RSSIDump_Jaguar
+/*#define REG_A_RX_SNR_DUMP_92E	rA_RXsnrDump_92E*/
+#define REG_A_RX_SNR_DUMP_JAGUAR	rA_RXsnrDump_Jaguar
+/*#define REG_A_TX_AGC	rA_TXAGC*/
+#define REG_A_TX_SCALE_JAGUAR	rA_TxScale_Jaguar
+#define REG_BW_INDICATION_JAGUAR	rBWIndication_Jaguar
+/*#define REG_B_BBSWING	rB_BBSWING*/
+/*#define REG_B_CFO_LONG_DUMP_92E	rB_CfoLongDump_92E*/
+#define REG_B_CFO_LONG_DUMP_JAGUAR	rB_CfoLongDump_Jaguar
+/*#define REG_B_CFO_SHORT_DUMP_92E	rB_CfoShortDump_92E*/
+#define REG_B_CFO_SHORT_DUMP_JAGUAR	rB_CfoShortDump_Jaguar
+/*#define REG_B_RSSI_DUMP_92E	rB_RSSIDump_92E*/
+#define REG_B_RSSI_DUMP_JAGUAR	rB_RSSIDump_Jaguar
+/*#define REG_B_RX_SNR_DUMP_92E	rB_RXsnrDump_92E*/
+#define REG_B_RX_SNR_DUMP_JAGUAR	rB_RXsnrDump_Jaguar
+/*#define REG_B_TX_AGC	rB_TXAGC*/
+#define REG_B_TX_SCALE_JAGUAR	rB_TxScale_Jaguar
+#define REG_BLUE_TOOTH	rBlue_Tooth
+#define REG_CCK_0_AFE_SETTING	rCCK0_AFESetting
+/*#define REG_C_BBSWING	rC_BBSWING*/
+/*#define REG_C_TX_AGC	rC_TXAGC*/
+#define REG_C_TX_SCALE_JAGUAR2	rC_TxScale_Jaguar2
+#define REG_CONFIG_ANT_A	rConfig_AntA
+#define REG_CONFIG_ANT_B	rConfig_AntB
+#define REG_CONFIG_PMPD_ANT_A	rConfig_Pmpd_AntA
+#define REG_CONFIG_PMPD_ANT_B	rConfig_Pmpd_AntB
+#define REG_DPDT_CONTROL	rDPDT_control
+/*#define REG_D_BBSWING	rD_BBSWING*/
+/*#define REG_D_TX_AGC	rD_TXAGC*/
+#define REG_D_TX_SCALE_JAGUAR2	rD_TxScale_Jaguar2
+#define REG_FPGA0_ANALOG_PARAMETER4	rFPGA0_AnalogParameter4
+#define REG_FPGA0_IQK	rFPGA0_IQK
+#define REG_FPGA0_PSD_FUNCTION	rFPGA0_PSDFunction
+#define REG_FPGA0_PSD_REPORT	rFPGA0_PSDReport
+#define REG_FPGA0_RFMOD	rFPGA0_RFMOD
+#define REG_FPGA0_TX_GAIN_STAGE	rFPGA0_TxGainStage
+#define REG_FPGA0_XAB_RF_INTERFACE_SW	rFPGA0_XAB_RFInterfaceSW
+#define REG_FPGA0_XAB_RF_PARAMETER	rFPGA0_XAB_RFParameter
+#define REG_FPGA0_XA_HSSI_PARAMETER1	rFPGA0_XA_HSSIParameter1
+#define REG_FPGA0_XA_LSSI_PARAMETER	rFPGA0_XA_LSSIParameter
+#define REG_FPGA0_XA_RF_INTERFACE_OE	rFPGA0_XA_RFInterfaceOE
+#define REG_FPGA0_XB_HSSI_PARAMETER1	rFPGA0_XB_HSSIParameter1
+#define REG_FPGA0_XB_LSSI_PARAMETER	rFPGA0_XB_LSSIParameter
+#define REG_FPGA0_XB_LSSI_READ_BACK	rFPGA0_XB_LSSIReadBack
+#define REG_FPGA0_XB_RF_INTERFACE_OE	rFPGA0_XB_RFInterfaceOE
+#define REG_FPGA0_XCD_RF_INTERFACE_SW	rFPGA0_XCD_RFInterfaceSW
+#define REG_FPGA0_XCD_SWITCH_CONTROL	rFPGA0_XCD_SwitchControl
+#define REG_FPGA1_TX_BLOCK	rFPGA1_TxBlock
+#define REG_FPGA1_TX_INFO	rFPGA1_TxInfo
+#define REG_IQK_AGC_CONT	rIQK_AGC_Cont
+#define REG_IQK_AGC_PTS	rIQK_AGC_Pts
+#define REG_IQK_AGC_RSP	rIQK_AGC_Rsp
+#define REG_OFDM_0_AGC_RSSI_TABLE	rOFDM0_AGCRSSITable
+#define REG_OFDM_0_ECCA_THRESHOLD	rOFDM0_ECCAThreshold
+#define REG_OFDM_0_RX_IQ_EXT_ANTA	rOFDM0_RxIQExtAnta
+#define REG_OFDM_0_TR_MUX_PAR	rOFDM0_TRMuxPar
+#define REG_OFDM_0_TRX_PATH_ENABLE	rOFDM0_TRxPathEnable
+#define REG_OFDM_0_XA_AGC_CORE1	rOFDM0_XAAGCCore1
+#define REG_OFDM_0_XA_RX_IQ_IMBALANCE	rOFDM0_XARxIQImbalance
+#define REG_OFDM_0_XA_TX_IQ_IMBALANCE	rOFDM0_XATxIQImbalance
+#define REG_OFDM_0_XB_AGC_CORE1	rOFDM0_XBAGCCore1
+#define REG_OFDM_0_XB_RX_IQ_IMBALANCE	rOFDM0_XBRxIQImbalance
+#define REG_OFDM_0_XB_TX_IQ_IMBALANCE	rOFDM0_XBTxIQImbalance
+#define REG_OFDM_0_XC_TX_AFE	rOFDM0_XCTxAFE
+#define REG_OFDM_0_XD_TX_AFE	rOFDM0_XDTxAFE
+#define REG_PMPD_ANAEN	rPMPD_ANAEN
+#define REG_PDP_ANT_A	rPdp_AntA
+#define REG_PDP_ANT_A_4	rPdp_AntA_4
+#define REG_PDP_ANT_B	rPdp_AntB
+#define REG_PDP_ANT_B_4	rPdp_AntB_4
+#define REG_PWED_TH_JAGUAR	rPwed_TH_Jaguar
+#define REG_RX_CCK	rRx_CCK
+#define REG_RX_IQK	rRx_IQK
+#define REG_RX_IQK_PI_A	rRx_IQK_PI_A
+#define REG_RX_IQK_PI_B	rRx_IQK_PI_B
+#define REG_RX_IQK_TONE_A	rRx_IQK_Tone_A
+#define REG_RX_IQK_TONE_B	rRx_IQK_Tone_B
+#define REG_RX_OFDM	rRx_OFDM
+#define REG_RX_POWER_AFTER_IQK_A_2	rRx_Power_After_IQK_A_2
+#define REG_RX_POWER_AFTER_IQK_B_2	rRx_Power_After_IQK_B_2
+#define REG_RX_POWER_BEFORE_IQK_A_2	rRx_Power_Before_IQK_A_2
+#define REG_RX_POWER_BEFORE_IQK_B_2	rRx_Power_Before_IQK_B_2
+#define REG_RX_TO_RX	rRx_TO_Rx
+#define REG_RX_WAIT_CCA	rRx_Wait_CCA
+#define REG_RX_WAIT_RIFS	rRx_Wait_RIFS
+#define REG_S0_S1_PATH_SWITCH	rS0S1_PathSwitch
+/*#define REG_S1_RXEVM_DUMP_92E	rS1_RXevmDump_92E*/
+#define REG_S1_RXEVM_DUMP_JAGUAR	rS1_RXevmDump_Jaguar
+/*#define REG_S2_RXEVM_DUMP_92E	rS2_RXevmDump_92E*/
+#define REG_S2_RXEVM_DUMP_JAGUAR	rS2_RXevmDump_Jaguar
+#define REG_SYM_WLBT_PAPE_SEL	rSYM_WLBT_PAPE_SEL
+#define REG_SINGLE_TONE_CONT_TX_JAGUAR	rSingleTone_ContTx_Jaguar
+#define REG_SLEEP	rSleep
+#define REG_STANDBY	rStandby
+#define REG_TX_AGC_A_CCK_11_CCK_1_JAGUAR	rTxAGC_A_CCK11_CCK1_JAguar
+#define REG_TX_AGC_A_CCK_1_MCS32	rTxAGC_A_CCK1_Mcs32
+#define REG_TX_AGC_A_MCS11_MCS8_JAGUAR	rTxAGC_A_MCS11_MCS8_JAguar
+#define REG_TX_AGC_A_MCS15_MCS12_JAGUAR	rTxAGC_A_MCS15_MCS12_JAguar
+#define REG_TX_AGC_A_MCS19_MCS16_JAGUAR	rTxAGC_A_MCS19_MCS16_JAguar
+#define REG_TX_AGC_A_MCS23_MCS20_JAGUAR	rTxAGC_A_MCS23_MCS20_JAguar
+#define REG_TX_AGC_A_MCS3_MCS0_JAGUAR	rTxAGC_A_MCS3_MCS0_JAguar
+#define REG_TX_AGC_A_MCS7_MCS4_JAGUAR	rTxAGC_A_MCS7_MCS4_JAguar
+#define REG_TX_AGC_A_MCS03_MCS00	rTxAGC_A_Mcs03_Mcs00
+#define REG_TX_AGC_A_MCS07_MCS04	rTxAGC_A_Mcs07_Mcs04
+#define REG_TX_AGC_A_MCS11_MCS08	rTxAGC_A_Mcs11_Mcs08
+#define REG_TX_AGC_A_MCS15_MCS12	rTxAGC_A_Mcs15_Mcs12
+#define REG_TX_AGC_A_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_A_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_A_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_A_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_A_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_A_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_A_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_A_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_A_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_A_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_A_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_A_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_A_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_A_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_A_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_A_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_A_OFDM18_OFDM6_JAGUAR	rTxAGC_A_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_A_OFDM54_OFDM24_JAGUAR	rTxAGC_A_Ofdm54_Ofdm24_JAguar
+#define REG_TX_AGC_A_RATE18_06	rTxAGC_A_Rate18_06
+#define REG_TX_AGC_A_RATE54_24	rTxAGC_A_Rate54_24
+#define REG_TX_AGC_B_CCK_11_A_CCK_2_11	rTxAGC_B_CCK11_A_CCK2_11
+#define REG_TX_AGC_B_CCK_11_CCK_1_JAGUAR	rTxAGC_B_CCK11_CCK1_JAguar
+#define REG_TX_AGC_B_CCK_1_55_MCS32	rTxAGC_B_CCK1_55_Mcs32
+#define REG_TX_AGC_B_MCS11_MCS8_JAGUAR	rTxAGC_B_MCS11_MCS8_JAguar
+#define REG_TX_AGC_B_MCS15_MCS12_JAGUAR	rTxAGC_B_MCS15_MCS12_JAguar
+#define REG_TX_AGC_B_MCS19_MCS16_JAGUAR	rTxAGC_B_MCS19_MCS16_JAguar
+#define REG_TX_AGC_B_MCS23_MCS20_JAGUAR	rTxAGC_B_MCS23_MCS20_JAguar
+#define REG_TX_AGC_B_MCS3_MCS0_JAGUAR	rTxAGC_B_MCS3_MCS0_JAguar
+#define REG_TX_AGC_B_MCS7_MCS4_JAGUAR	rTxAGC_B_MCS7_MCS4_JAguar
+#define REG_TX_AGC_B_MCS03_MCS00	rTxAGC_B_Mcs03_Mcs00
+#define REG_TX_AGC_B_MCS07_MCS04	rTxAGC_B_Mcs07_Mcs04
+#define REG_TX_AGC_B_MCS11_MCS08	rTxAGC_B_Mcs11_Mcs08
+#define REG_TX_AGC_B_MCS15_MCS12	rTxAGC_B_Mcs15_Mcs12
+#define REG_TX_AGC_B_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_B_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_B_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_B_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_B_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_B_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_B_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_B_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_B_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_B_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_B_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_B_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_B_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_B_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_B_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_B_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_B_OFDM18_OFDM6_JAGUAR	rTxAGC_B_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_B_OFDM54_OFDM24_JAGUAR	rTxAGC_B_Ofdm54_Ofdm24_JAguar
+#define REG_TX_AGC_B_RATE18_06	rTxAGC_B_Rate18_06
+#define REG_TX_AGC_B_RATE54_24	rTxAGC_B_Rate54_24
+#define REG_TX_AGC_C_CCK_11_CCK_1_JAGUAR	rTxAGC_C_CCK11_CCK1_JAguar
+#define REG_TX_AGC_C_MCS11_MCS8_JAGUAR	rTxAGC_C_MCS11_MCS8_JAguar
+#define REG_TX_AGC_C_MCS15_MCS12_JAGUAR	rTxAGC_C_MCS15_MCS12_JAguar
+#define REG_TX_AGC_C_MCS19_MCS16_JAGUAR	rTxAGC_C_MCS19_MCS16_JAguar
+#define REG_TX_AGC_C_MCS23_MCS20_JAGUAR	rTxAGC_C_MCS23_MCS20_JAguar
+#define REG_TX_AGC_C_MCS3_MCS0_JAGUAR	rTxAGC_C_MCS3_MCS0_JAguar
+#define REG_TX_AGC_C_MCS7_MCS4_JAGUAR	rTxAGC_C_MCS7_MCS4_JAguar
+#define REG_TX_AGC_C_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_C_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_C_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_C_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_C_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_C_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_C_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_C_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_C_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_C_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_C_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_C_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_C_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_C_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_C_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_C_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_C_OFDM18_OFDM6_JAGUAR	rTxAGC_C_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_C_OFDM54_OFDM24_JAGUAR	rTxAGC_C_Ofdm54_Ofdm24_JAguar
+#define REG_TX_AGC_D_CCK_11_CCK_1_JAGUAR	rTxAGC_D_CCK11_CCK1_JAguar
+#define REG_TX_AGC_D_MCS11_MCS8_JAGUAR	rTxAGC_D_MCS11_MCS8_JAguar
+#define REG_TX_AGC_D_MCS15_MCS12_JAGUAR	rTxAGC_D_MCS15_MCS12_JAguar
+#define REG_TX_AGC_D_MCS19_MCS16_JAGUAR	rTxAGC_D_MCS19_MCS16_JAguar
+#define REG_TX_AGC_D_MCS23_MCS20_JAGUAR	rTxAGC_D_MCS23_MCS20_JAguar
+#define REG_TX_AGC_D_MCS3_MCS0_JAGUAR	rTxAGC_D_MCS3_MCS0_JAguar
+#define REG_TX_AGC_D_MCS7_MCS4_JAGUAR	rTxAGC_D_MCS7_MCS4_JAguar
+#define REG_TX_AGC_D_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_D_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_D_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_D_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_D_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_D_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_D_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_D_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_D_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_D_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_D_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_D_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_D_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_D_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_D_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_D_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_D_OFDM18_OFDM6_JAGUAR	rTxAGC_D_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_D_OFDM54_OFDM24_JAGUAR	rTxAGC_D_Ofdm54_Ofdm24_JAguar
+#define REG_TX_PATH_JAGUAR	rTxPath_Jaguar
+#define REG_TX_CCK_BBON	rTx_CCK_BBON
+#define REG_TX_CCK_RFON	rTx_CCK_RFON
+#define REG_TX_IQK	rTx_IQK
+#define REG_TX_IQK_PI_A	rTx_IQK_PI_A
+#define REG_TX_IQK_PI_B	rTx_IQK_PI_B
+#define REG_TX_IQK_TONE_A	rTx_IQK_Tone_A
+#define REG_TX_IQK_TONE_B	rTx_IQK_Tone_B
+#define REG_TX_OFDM_BBON	rTx_OFDM_BBON
+#define REG_TX_OFDM_RFON	rTx_OFDM_RFON
+#define REG_TX_POWER_AFTER_IQK_A	rTx_Power_After_IQK_A
+#define REG_TX_POWER_AFTER_IQK_B	rTx_Power_After_IQK_B
+#define REG_TX_POWER_BEFORE_IQK_A	rTx_Power_Before_IQK_A
+#define REG_TX_POWER_BEFORE_IQK_B	rTx_Power_Before_IQK_B
+#define REG_TX_TO_RX	rTx_To_Rx
+#define REG_TX_TO_TX	rTx_To_Tx
+#define REG_APK	rAPK
+#define REG_ANTSEL_SW_JAGUAR	r_ANTSEL_SW_Jaguar
+
+
+
+#define rf_welut_jaguar	RF_WeLut_Jaguar
+#define rf_mode_table_addr	RF_ModeTableAddr
+#define rf_mode_table_data0	RF_ModeTableData0
+#define rf_mode_table_data1	RF_ModeTableData1
+
+
+
+
+
+
+#define RX_SMOOTH_FACTOR	Rx_Smooth_Factor
+
+#endif /* __HAL_DATA_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_gspi.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_gspi.h
new file mode 100644
index 000000000000..51d491cdb505
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_gspi.h
@@ -0,0 +1,26 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_GSPI_H_
+#define __HAL_GSPI_H_
+
+#define ffaddr2deviceId(pdvobj, addr)	(pdvobj->Queue2Pipe[addr])
+
+u8 rtw_hal_gspi_max_txoqt_free_space(_adapter *padapter);
+u8 rtw_hal_gspi_query_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum);
+void rtw_hal_gspi_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum);
+void rtw_hal_set_gspi_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
+u32 rtw_hal_get_gspi_tx_max_length(PADAPTER padapter, u8 queue_idx);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_ic_cfg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_ic_cfg.h
new file mode 100644
index 000000000000..50764f82340a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_ic_cfg.h
@@ -0,0 +1,244 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_IC_CFG_H__
+#define __HAL_IC_CFG_H__
+
+#define RTL8188E_SUPPORT				0
+#define RTL8812A_SUPPORT				0
+#define RTL8821A_SUPPORT				0
+#define RTL8723B_SUPPORT				0
+#define RTL8723D_SUPPORT				0
+#define RTL8192E_SUPPORT				0
+#define RTL8814A_SUPPORT				0
+#define RTL8195A_SUPPORT				0
+#define RTL8197F_SUPPORT				0
+#define RTL8703B_SUPPORT				0
+#define RTL8188F_SUPPORT				0
+#define RTL8822B_SUPPORT				0
+#define RTL8821B_SUPPORT				0
+#define RTL8821C_SUPPORT				0
+#define RTL8710B_SUPPORT				0
+#define RTL8814B_SUPPORT				0
+#define RTL8824B_SUPPORT				0
+#define RTL8192F_SUPPORT				0
+#define RTL8198F_SUPPORT				0
+#define RTL8195B_SUPPORT				0
+/*#if (RTL8188E_SUPPORT==1)*/
+#define RATE_ADAPTIVE_SUPPORT			0
+#define POWER_TRAINING_ACTIVE			0
+
+#ifdef CONFIG_MULTIDRV
+#endif
+
+#ifdef CONFIG_RTL8188E
+	#undef RTL8188E_SUPPORT
+	#undef RATE_ADAPTIVE_SUPPORT
+	#undef POWER_TRAINING_ACTIVE
+
+	#define RTL8188E_SUPPORT				1
+	#define RATE_ADAPTIVE_SUPPORT			1
+	#define POWER_TRAINING_ACTIVE			1
+#endif
+
+#ifdef CONFIG_RTL8812A
+	#undef RTL8812A_SUPPORT
+	#define RTL8812A_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8821A
+	#undef RTL8821A_SUPPORT
+	#define RTL8821A_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8192E
+	#undef RTL8192E_SUPPORT
+	#define RTL8192E_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8723B
+	#undef RTL8723B_SUPPORT
+	#define RTL8723B_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8723D
+	#undef RTL8723D_SUPPORT
+	#define RTL8723D_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
+	#ifndef CONFIG_RTW_CUSTOMER_STR
+		#define CONFIG_RTW_CUSTOMER_STR
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8814A
+	#undef RTL8814A_SUPPORT
+	#define RTL8814A_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8703B
+	#undef RTL8703B_SUPPORT
+	#define RTL8703B_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8188F
+	#undef RTL8188F_SUPPORT
+	#define RTL8188F_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
+	#ifndef CONFIG_RTW_CUSTOMER_STR
+		#define CONFIG_RTW_CUSTOMER_STR
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8822B
+	#undef RTL8822B_SUPPORT
+	#define RTL8822B_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif /* CONFIG_FW_C2H_PKT */
+	#define RTW_TX_PA_BIAS	/* Adjust TX PA Bias from eFuse */
+	#define CONFIG_DFS	/* Enable 5G band 2&3 channel */
+
+	#ifdef CONFIG_WOWLAN
+		#define CONFIG_GTK_OL
+		/*#define CONFIG_ARP_KEEP_ALIVE*/
+
+		#ifdef CONFIG_GPIO_WAKEUP
+			#ifndef WAKEUP_GPIO_IDX
+				#define WAKEUP_GPIO_IDX	6	/* WIFI Chip Side */
+			#endif /* !WAKEUP_GPIO_IDX */
+		#endif /* CONFIG_GPIO_WAKEUP */
+	#endif /* CONFIG_WOWLAN */
+
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define CONFIG_AP_PORT_SWAP
+		#define CONFIG_FW_MULTI_PORT_SUPPORT
+	#endif /* CONFIG_CONCURRENT_MODE */
+
+	/*
+	 * Beamforming related definition
+	 */
+	/* Beamforming mechanism is on driver not phydm, always disable it */
+	#define BEAMFORMING_SUPPORT				0
+	/* Only support new beamforming mechanism */
+	#ifdef CONFIG_BEAMFORMING
+		#define RTW_BEAMFORMING_VERSION_2
+	#endif /* CONFIG_BEAMFORMING */
+
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif /* CONFIG_RTW_MAC_HIDDEN_RPT */
+
+	#ifndef DBG_RX_DFRAME_RAW_DATA
+		#define DBG_RX_DFRAME_RAW_DATA
+	#endif /* DBG_RX_DFRAME_RAW_DATA */
+
+	#ifndef RTW_IQK_FW_OFFLOAD
+		#define RTW_IQK_FW_OFFLOAD
+	#endif /* RTW_IQK_FW_OFFLOAD */
+	#define CONFIG_ADVANCE_OTA
+
+	#ifdef CONFIG_MCC_MODE
+		#define CONFIG_MCC_MODE_V2
+	#endif /* CONFIG_MCC_MODE */
+
+	#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
+		#define CONFIG_TDLS_CH_SW_V2
+	#endif
+
+	#ifndef RTW_CHANNEL_SWITCH_OFFLOAD
+		#ifdef CONFIG_TDLS_CH_SW_V2
+			#define RTW_CHANNEL_SWITCH_OFFLOAD
+		#endif
+	#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+
+	#if defined(CONFIG_RTW_MESH) && !defined(RTW_PER_CMD_SUPPORT_FW)
+		/* Supported since fw v22.1 */
+		#define RTW_PER_CMD_SUPPORT_FW
+	#endif /* RTW_PER_CMD_SUPPORT_FW */
+
+	#ifndef CONFIG_DYNAMIC_SOML
+		#define CONFIG_DYNAMIC_SOML
+	#endif /* CONFIG_DYNAMIC_SOML */
+#endif /* CONFIG_RTL8822B */
+
+#ifdef CONFIG_RTL8821C
+	#undef RTL8821C_SUPPORT
+	#define RTL8821C_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifdef CONFIG_NO_FW
+		#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
+			#undef CONFIG_RTW_MAC_HIDDEN_RPT
+		#endif
+	#else
+		#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+			#define CONFIG_RTW_MAC_HIDDEN_RPT
+		#endif
+	#endif
+	#define LOAD_FW_HEADER_FROM_DRIVER
+	#define CONFIG_PHY_CAPABILITY_QUERY
+	#ifdef CONFIG_CONCURRENT_MODE
+	#define CONFIG_AP_PORT_SWAP
+	#define CONFIG_FW_MULTI_PORT_SUPPORT
+	#endif
+	#define CONFIG_SUPPORT_FIFO_DUMP
+	#ifndef RTW_IQK_FW_OFFLOAD
+		#define RTW_IQK_FW_OFFLOAD
+	#endif /* RTW_IQK_FW_OFFLOAD */
+	/*#define CONFIG_AMPDU_PRETX_CD*/
+	/*#define DBG_PRE_TX_HANG*/
+	/*
+	 * Beamforming related definition
+	 */
+	/* Beamforming mechanism is on driver not phydm, always disable it */
+	#define BEAMFORMING_SUPPORT				0
+	/* Only support new beamforming mechanism */
+	#ifdef CONFIG_BEAMFORMING
+		#define RTW_BEAMFORMING_VERSION_2
+	#endif /* CONFIG_BEAMFORMING */
+#endif
+
+#endif /*__HAL_IC_CFG_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_intf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_intf.h
new file mode 100644
index 000000000000..bf6ce000c72a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_intf.h
@@ -0,0 +1,784 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+
+enum RTL871X_HCI_TYPE {
+	RTW_PCIE	= BIT0,
+	RTW_USB	= BIT1,
+	RTW_SDIO	= BIT2,
+	RTW_GSPI	= BIT3,
+};
+
+enum _CHIP_TYPE {
+
+	NULL_CHIP_TYPE,
+	RTL8188E,
+	RTL8192E,
+	RTL8812,
+	RTL8821, /* RTL8811 */
+	RTL8723B,
+	RTL8814A,
+	RTL8703B,
+	RTL8188F,
+	RTL8822B,
+	RTL8723D,
+	RTL8821C,
+	MAX_CHIP_TYPE
+};
+
+#ifdef RTW_HALMAC
+enum fw_mem {
+	FW_EMEM,
+	FW_IMEM,
+	FW_DMEM,
+};
+#endif
+
+extern const u32 _chip_type_to_odm_ic_type[];
+#define chip_type_to_odm_ic_type(chip_type) (((chip_type) >= MAX_CHIP_TYPE) ? _chip_type_to_odm_ic_type[MAX_CHIP_TYPE] : _chip_type_to_odm_ic_type[(chip_type)])
+
+typedef enum _HAL_HW_TIMER_TYPE {
+	HAL_TIMER_NONE = 0,
+	HAL_TIMER_TXBF = 1,
+	HAL_TIMER_EARLYMODE = 2,
+} HAL_HW_TIMER_TYPE, *PHAL_HW_TIMER_TYPE;
+
+
+typedef enum _HW_VARIABLES {
+	HW_VAR_MEDIA_STATUS,
+	HW_VAR_SET_OPMODE,
+	HW_VAR_MAC_ADDR,
+	HW_VAR_BSSID,
+	HW_VAR_INIT_RTS_RATE,
+	HW_VAR_BASIC_RATE,
+	HW_VAR_TXPAUSE,
+	HW_VAR_BCN_FUNC,
+	HW_VAR_CORRECT_TSF,
+	HW_VAR_RCR,
+	HW_VAR_MLME_DISCONNECT,
+	HW_VAR_MLME_SITESURVEY,
+	HW_VAR_MLME_JOIN,
+	HW_VAR_ON_RCR_AM,
+	HW_VAR_OFF_RCR_AM,
+	HW_VAR_BEACON_INTERVAL,
+	HW_VAR_SLOT_TIME,
+	HW_VAR_RESP_SIFS,
+	HW_VAR_ACK_PREAMBLE,
+	HW_VAR_SEC_CFG,
+	HW_VAR_SEC_DK_CFG,
+	HW_VAR_BCN_VALID,
+	HW_VAR_RF_TYPE,
+	HW_VAR_TSF,
+	HW_VAR_FREECNT,
+
+	/* PHYDM odm->SupportAbility */
+	HW_VAR_CAM_EMPTY_ENTRY,
+	HW_VAR_CAM_INVALID_ALL,
+	HW_VAR_AC_PARAM_VO,
+	HW_VAR_AC_PARAM_VI,
+	HW_VAR_AC_PARAM_BE,
+	HW_VAR_AC_PARAM_BK,
+	HW_VAR_ACM_CTRL,
+#ifdef CONFIG_WMMPS_STA
+	HW_VAR_UAPSD_TID,
+#endif /* CONFIG_WMMPS_STA */
+	HW_VAR_AMPDU_MIN_SPACE,
+	HW_VAR_AMPDU_FACTOR,
+	HW_VAR_RXDMA_AGG_PG_TH,
+	HW_VAR_SET_RPWM,
+	HW_VAR_CPWM,
+	HW_VAR_H2C_FW_PWRMODE,
+	HW_VAR_H2C_PS_TUNE_PARAM,
+	HW_VAR_H2C_FW_JOINBSSRPT,
+	HW_VAR_FWLPS_RF_ON,
+	HW_VAR_H2C_FW_P2P_PS_OFFLOAD,
+#ifdef CONFIG_LPS_POFF
+	HW_VAR_LPS_POFF_INIT,
+	HW_VAR_LPS_POFF_DEINIT,
+	HW_VAR_LPS_POFF_SET_MODE,
+	HW_VAR_LPS_POFF_WOW_EN,
+#endif
+#ifdef CONFIG_LPS_PG
+	HW_VAR_LPS_PG_HANDLE,
+#endif
+	HW_VAR_TRIGGER_GPIO_0,
+	HW_VAR_BT_SET_COEXIST,
+	HW_VAR_BT_ISSUE_DELBA,
+	HW_VAR_SWITCH_EPHY_WoWLAN,
+	HW_VAR_EFUSE_USAGE,
+	HW_VAR_EFUSE_BYTES,
+	HW_VAR_EFUSE_BT_USAGE,
+	HW_VAR_EFUSE_BT_BYTES,
+	HW_VAR_FIFO_CLEARN_UP,
+	HW_VAR_RESTORE_HW_SEQ,
+	HW_VAR_CHECK_TXBUF,
+	HW_VAR_PCIE_STOP_TX_DMA,
+	HW_VAR_APFM_ON_MAC, /* Auto FSM to Turn On, include clock, isolation, power control for MAC only */
+	HW_VAR_HCI_SUS_STATE,
+	/* The valid upper nav range for the HW updating, if the true value is larger than the upper range, the HW won't update it. */
+	/* Unit in microsecond. 0 means disable this function. */
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	HW_VAR_WOWLAN,
+	HW_VAR_WAKEUP_REASON,
+#endif
+	HW_VAR_RPWM_TOG,
+#ifdef CONFIG_GPIO_WAKEUP
+	HW_SET_GPIO_WL_CTRL,
+#endif
+	HW_VAR_SYS_CLKR,
+	HW_VAR_NAV_UPPER,
+	HW_VAR_RPT_TIMER_SETTING,
+	HW_VAR_TX_RPT_MAX_MACID,
+	HW_VAR_CHK_HI_QUEUE_EMPTY,
+	HW_VAR_CHK_MGQ_CPU_EMPTY,
+	HW_VAR_DL_BCN_SEL,
+	HW_VAR_AMPDU_MAX_TIME,
+	HW_VAR_WIRELESS_MODE,
+	HW_VAR_USB_MODE,
+	HW_VAR_PORT_SWITCH,
+	HW_VAR_PORT_CFG,
+	HW_VAR_DO_IQK,
+	HW_VAR_DM_IN_LPS_LCLK,/*flag CONFIG_LPS_LCLK_WD_TIMER*/
+	HW_VAR_SET_REQ_FW_PS,
+	HW_VAR_FW_PS_STATE,
+	HW_VAR_SOUNDING_ENTER,
+	HW_VAR_SOUNDING_LEAVE,
+	HW_VAR_SOUNDING_RATE,
+	HW_VAR_SOUNDING_STATUS,
+	HW_VAR_SOUNDING_FW_NDPA,
+	HW_VAR_SOUNDING_CLK,
+	HW_VAR_SOUNDING_SET_GID_TABLE,
+	HW_VAR_SOUNDING_CSI_REPORT,
+	/*Add by YuChen for TXBF HW timer*/
+	HW_VAR_HW_REG_TIMER_INIT,
+	HW_VAR_HW_REG_TIMER_RESTART,
+	HW_VAR_HW_REG_TIMER_START,
+	HW_VAR_HW_REG_TIMER_STOP,
+	/*Add by YuChen for TXBF HW timer*/
+	HW_VAR_DL_RSVD_PAGE,
+	HW_VAR_MACID_LINK,
+	HW_VAR_MACID_NOLINK,
+	HW_VAR_DUMP_MAC_QUEUE_INFO,
+	HW_VAR_ASIX_IOT,
+#ifdef CONFIG_MBSSID_CAM
+	HW_VAR_MBSSID_CAM_WRITE,
+	HW_VAR_MBSSID_CAM_CLEAR,
+	HW_VAR_RCR_MBSSID_EN,
+#endif
+	HW_VAR_EN_HW_UPDATE_TSF,
+	HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO,
+	HW_VAR_CH_SW_IQK_INFO_BACKUP,
+	HW_VAR_CH_SW_IQK_INFO_RESTORE,
+
+	HW_VAR_DBI,
+	HW_VAR_MDIO,
+	HW_VAR_L1OFF_CAPABILITY,
+	HW_VAR_L1OFF_NIC_SUPPORT,
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	HW_VAR_TDLS_BCN_EARLY_C2H_RPT,
+#endif
+#endif
+	HW_VAR_DUMP_MAC_TXFIFO,
+	HW_VAR_PWR_CMD,
+	HW_VAR_SET_SOML_PARAM,
+	HW_VAR_ENABLE_RX_BAR,
+	HW_VAR_TSF_AUTO_SYNC,
+} HW_VARIABLES;
+
+typedef enum _HAL_DEF_VARIABLE {
+	HAL_DEF_UNDERCORATEDSMOOTHEDPWDB,
+	HAL_DEF_IS_SUPPORT_ANT_DIV,
+	HAL_DEF_DRVINFO_SZ,
+	HAL_DEF_MAX_RECVBUF_SZ,
+	HAL_DEF_RX_PACKET_OFFSET,
+	HAL_DEF_RX_DMA_SZ_WOW,
+	HAL_DEF_RX_DMA_SZ,
+	HAL_DEF_RX_PAGE_SIZE,
+	HAL_DEF_DBG_DUMP_RXPKT,/* for dbg */
+	HAL_DEF_RA_DECISION_RATE,
+	HAL_DEF_RA_SGI,
+	HAL_DEF_PT_PWR_STATUS,
+	HAL_DEF_TX_LDPC,				/* LDPC support */
+	HAL_DEF_RX_LDPC,				/* LDPC support */
+	HAL_DEF_TX_STBC,				/* TX STBC support */
+	HAL_DEF_RX_STBC,				/* RX STBC support */
+	HAL_DEF_EXPLICIT_BEAMFORMER,/* Explicit  Compressed Steering Capable */
+	HAL_DEF_EXPLICIT_BEAMFORMEE,/* Explicit Compressed Beamforming Feedback Capable */
+	HAL_DEF_VHT_MU_BEAMFORMER,	/* VHT MU Beamformer support */
+	HAL_DEF_VHT_MU_BEAMFORMEE,	/* VHT MU Beamformee support */
+	HAL_DEF_BEAMFORMER_CAP,
+	HAL_DEF_BEAMFORMEE_CAP,
+	HW_VAR_MAX_RX_AMPDU_FACTOR,
+	HW_DEF_RA_INFO_DUMP,
+	HAL_DEF_DBG_DUMP_TXPKT,
+
+	HAL_DEF_TX_PAGE_SIZE,
+	HAL_DEF_TX_PAGE_BOUNDARY,
+	HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN,
+	HAL_DEF_ANT_DETECT,/* to do for 8723a */
+	HAL_DEF_PCI_SUUPORT_L1_BACKDOOR, /* Determine if the L1 Backdoor setting is turned on. */
+	HAL_DEF_PCI_AMD_L1_SUPPORT,
+	HAL_DEF_PCI_ASPM_OSC, /* Support for ASPM OSC, added by Roger, 2013.03.27. */
+	HAL_DEF_EFUSE_USAGE,	/* Get current EFUSE utilization. 2008.12.19. Added by Roger. */
+	HAL_DEF_EFUSE_BYTES,
+	HW_VAR_BEST_AMPDU_DENSITY,
+} HAL_DEF_VARIABLE;
+
+typedef enum _HAL_ODM_VARIABLE {
+	HAL_ODM_STA_INFO,
+	HAL_ODM_P2P_STATE,
+	HAL_ODM_WIFI_DISPLAY_STATE,
+	HAL_ODM_REGULATION,
+	HAL_ODM_INITIAL_GAIN,
+	HAL_ODM_RX_INFO_DUMP,
+	HAL_ODM_RX_Dframe_INFO,
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	HAL_ODM_ANTDIV_SELECT
+#endif
+} HAL_ODM_VARIABLE;
+
+typedef enum _HAL_INTF_PS_FUNC {
+	HAL_USB_SELECT_SUSPEND,
+	HAL_MAX_ID,
+} HAL_INTF_PS_FUNC;
+
+typedef s32(*c2h_id_filter)(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+
+struct txpwr_idx_comp;
+
+struct hal_ops {
+	/*** initialize section ***/
+	void	(*read_chip_version)(_adapter *padapter);
+	void	(*init_default_value)(_adapter *padapter);
+	void	(*intf_chip_configure)(_adapter *padapter);
+	u8	(*read_adapter_info)(_adapter *padapter);
+	u32(*hal_power_on)(_adapter *padapter);
+	void	(*hal_power_off)(_adapter *padapter);
+	u32(*hal_init)(_adapter *padapter);
+	u32(*hal_deinit)(_adapter *padapter);
+	void	(*dm_init)(_adapter *padapter);
+	void	(*dm_deinit)(_adapter *padapter);
+
+	/*** xmit section ***/
+	s32(*init_xmit_priv)(_adapter *padapter);
+	void	(*free_xmit_priv)(_adapter *padapter);
+	s32(*hal_xmit)(_adapter *padapter, struct xmit_frame *pxmitframe);
+	/*
+	 * mgnt_xmit should be implemented to run in interrupt context
+	 */
+	s32(*mgnt_xmit)(_adapter *padapter, struct xmit_frame *pmgntframe);
+	s32(*hal_xmitframe_enqueue)(_adapter *padapter, struct xmit_frame *pxmitframe);
+#ifdef CONFIG_XMIT_THREAD_MODE
+	s32(*xmit_thread_handler)(_adapter *padapter);
+#endif
+	void	(*run_thread)(_adapter *padapter);
+	void	(*cancel_thread)(_adapter *padapter);
+
+	/*** recv section ***/
+	s32(*init_recv_priv)(_adapter *padapter);
+	void	(*free_recv_priv)(_adapter *padapter);
+#ifdef CONFIG_RECV_THREAD_MODE
+	s32 (*recv_hdl)(_adapter *adapter);
+#endif
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
+	u32(*inirp_init)(_adapter *padapter);
+	u32(*inirp_deinit)(_adapter *padapter);
+#endif
+	/*** interrupt hdl section ***/
+	void	(*enable_interrupt)(_adapter *padapter);
+	void	(*disable_interrupt)(_adapter *padapter);
+	u8(*check_ips_status)(_adapter *padapter);
+#if defined(CONFIG_PCI_HCI)
+	s32(*interrupt_handler)(_adapter *padapter);
+#endif
+
+#if defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
+	void	(*interrupt_handler)(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+
+#if defined(CONFIG_PCI_HCI)
+	void	(*irp_reset)(_adapter *padapter);
+#endif
+
+	/*** DM section ***/
+#ifdef CONFIG_RTW_SW_LED
+	void	(*InitSwLeds)(_adapter *padapter);
+	void	(*DeInitSwLeds)(_adapter *padapter);
+#endif
+	void	(*set_chnl_bw_handler)(_adapter *padapter, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80);
+
+	void	(*set_tx_power_level_handler)(_adapter *padapter, u8 channel);
+	void	(*get_tx_power_level_handler)(_adapter *padapter, s32 *powerlevel);
+
+	void (*set_tx_power_index_handler)(_adapter *padapter, u32 powerindex, enum rf_path rfpath, u8 rate);
+	u8 (*get_tx_power_index_handler)(_adapter *padapter, enum rf_path rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);
+
+	void	(*hal_dm_watchdog)(_adapter *padapter);
+
+	u8	(*set_hw_reg_handler)(_adapter *padapter, u8	variable, u8 *val);
+
+	void	(*GetHwRegHandler)(_adapter *padapter, u8	variable, u8 *val);
+
+
+
+	u8 (*get_hal_def_var_handler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
+
+	u8(*SetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
+
+	void	(*GetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, PVOID pValue2);
+	void	(*SetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, BOOLEAN bSet);
+
+	void	(*SetBeaconRelatedRegistersHandler)(_adapter *padapter);
+
+	u8(*interface_ps_func)(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val);
+
+	u32(*read_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask);
+	void	(*write_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
+	u32 (*read_rfreg)(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask);
+	void	(*write_rfreg)(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
+
+	void (*read_wmmedca_reg)(_adapter *padapter, u16 *vo_params, u16 *vi_params, u16 *be_params, u16 *bk_params);
+	
+#ifdef CONFIG_HOSTAPD_MLME
+	s32(*hostap_mgnt_xmit_entry)(_adapter *padapter, _pkt *pkt);
+#endif
+
+	void (*EfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);
+	void (*BTEfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);
+	void (*ReadEFuse)(_adapter *padapter, u8 efuseType, u16 _offset, u16 _size_byte, u8 *pbuf, BOOLEAN bPseudoTest);
+	void (*EFUSEGetEfuseDefinition)(_adapter *padapter, u8 efuseType, u8 type, void *pOut, BOOLEAN bPseudoTest);
+	u16(*EfuseGetCurrentSize)(_adapter *padapter, u8 efuseType, BOOLEAN bPseudoTest);
+	int	(*Efuse_PgPacketRead)(_adapter *padapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);
+	int	(*Efuse_PgPacketWrite)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+	u8(*Efuse_WordEnableDataWrite)(_adapter *padapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+	BOOLEAN(*Efuse_PgPacketWrite_BT)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	void (*sreset_init_value)(_adapter *padapter);
+	void (*sreset_reset_value)(_adapter *padapter);
+	void (*silentreset)(_adapter *padapter);
+	void (*sreset_xmit_status_check)(_adapter *padapter);
+	void (*sreset_linked_status_check)(_adapter *padapter);
+	u8(*sreset_get_wifi_status)(_adapter *padapter);
+	bool (*sreset_inprogress)(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_IOL
+	int (*IOL_exec_cmds_sync)(_adapter *padapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
+#endif
+
+	void (*hal_notch_filter)(_adapter *adapter, bool enable);
+#ifdef RTW_HALMAC
+	void (*hal_mac_c2h_handler)(_adapter *adapter, u8 *pbuf, u16 length);
+#else
+	s32(*c2h_handler)(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+#endif
+	void (*reqtxrpt)(_adapter *padapter, u8 macid);
+	s32(*fill_h2c_cmd)(PADAPTER, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+	void (*fill_fake_txdesc)(PADAPTER, u8 *pDesc, u32 BufferLen,
+				 u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+	s32(*fw_dl)(_adapter *adapter, u8 wowlan);
+#ifdef RTW_HALMAC
+	s32 (*fw_mem_dl)(_adapter *adapter, enum fw_mem mem);
+#endif
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_PCI_HCI)
+	void (*clear_interrupt)(_adapter *padapter);
+#endif
+	u8(*hal_get_tx_buff_rsvd_page_num)(_adapter *adapter, bool wowlan);
+#ifdef CONFIG_GPIO_API
+	void (*update_hisr_hsisr_ind)(PADAPTER padapter, u32 flag);
+	int (*hal_gpio_func_check)(_adapter *padapter, u8 gpio_num);
+	void (*hal_gpio_multi_func_reset)(_adapter *padapter, u8 gpio_num);
+#endif
+	void (*fw_correct_bcn)(PADAPTER padapter);
+
+#ifdef RTW_HALMAC
+	u8(*init_mac_register)(PADAPTER);
+	u8(*init_phy)(PADAPTER);
+#endif /* RTW_HALMAC */
+
+#ifdef CONFIG_PCI_HCI
+	void (*hal_set_l1ssbackdoor_handler)(_adapter *padapter, u8 enable);
+#endif
+
+#ifdef CONFIG_RFKILL_POLL
+	bool (*hal_radio_onoff_check)(_adapter *adapter, u8 *valid);
+#endif
+
+};
+
+typedef	enum _RT_EEPROM_TYPE {
+	EEPROM_93C46,
+	EEPROM_93C56,
+	EEPROM_BOOT_EFUSE,
+} RT_EEPROM_TYPE, *PRT_EEPROM_TYPE;
+
+
+
+#define RF_CHANGE_BY_INIT	0
+#define RF_CHANGE_BY_IPS	BIT28
+#define RF_CHANGE_BY_PS	BIT29
+#define RF_CHANGE_BY_HW	BIT30
+#define RF_CHANGE_BY_SW	BIT31
+
+typedef enum _HARDWARE_TYPE {
+	HARDWARE_TYPE_RTL8188EE,
+	HARDWARE_TYPE_RTL8188EU,
+	HARDWARE_TYPE_RTL8188ES,
+	/*	NEW_GENERATION_IC */
+	HARDWARE_TYPE_RTL8192EE,
+	HARDWARE_TYPE_RTL8192EU,
+	HARDWARE_TYPE_RTL8192ES,
+	HARDWARE_TYPE_RTL8812E,
+	HARDWARE_TYPE_RTL8812AU,
+	HARDWARE_TYPE_RTL8811AU,
+	HARDWARE_TYPE_RTL8821E,
+	HARDWARE_TYPE_RTL8821U,
+	HARDWARE_TYPE_RTL8821S,
+	HARDWARE_TYPE_RTL8723BE,
+	HARDWARE_TYPE_RTL8723BU,
+	HARDWARE_TYPE_RTL8723BS,
+	HARDWARE_TYPE_RTL8814AE,
+	HARDWARE_TYPE_RTL8814AU,
+	HARDWARE_TYPE_RTL8814AS,
+	HARDWARE_TYPE_RTL8821BE,
+	HARDWARE_TYPE_RTL8821BU,
+	HARDWARE_TYPE_RTL8821BS,
+	HARDWARE_TYPE_RTL8822BE,
+	HARDWARE_TYPE_RTL8822BU,
+	HARDWARE_TYPE_RTL8822BS,
+	HARDWARE_TYPE_RTL8703BE,
+	HARDWARE_TYPE_RTL8703BU,
+	HARDWARE_TYPE_RTL8703BS,
+	HARDWARE_TYPE_RTL8188FE,
+	HARDWARE_TYPE_RTL8188FU,
+	HARDWARE_TYPE_RTL8188FS,
+	HARDWARE_TYPE_RTL8723DE,
+	HARDWARE_TYPE_RTL8723DU,
+	HARDWARE_TYPE_RTL8723DS,
+	HARDWARE_TYPE_RTL8821CE,
+	HARDWARE_TYPE_RTL8821CU,
+	HARDWARE_TYPE_RTL8821CS,
+	HARDWARE_TYPE_MAX,
+} HARDWARE_TYPE;
+
+#define IS_NEW_GENERATION_IC(_Adapter)	(rtw_get_hw_type(_Adapter) >= HARDWARE_TYPE_RTL8192EE)
+/*
+ * RTL8188E Series
+ *   */
+#define IS_HARDWARE_TYPE_8188EE(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188EE)
+#define IS_HARDWARE_TYPE_8188EU(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188EU)
+#define IS_HARDWARE_TYPE_8188ES(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188ES)
+#define	IS_HARDWARE_TYPE_8188E(_Adapter)	\
+	(IS_HARDWARE_TYPE_8188EE(_Adapter) || IS_HARDWARE_TYPE_8188EU(_Adapter) || IS_HARDWARE_TYPE_8188ES(_Adapter))
+
+/* RTL8812 Series */
+#define IS_HARDWARE_TYPE_8812E(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8812E)
+#define IS_HARDWARE_TYPE_8812AU(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8812AU)
+#define IS_HARDWARE_TYPE_8812(_Adapter)			\
+	(IS_HARDWARE_TYPE_8812E(_Adapter) || IS_HARDWARE_TYPE_8812AU(_Adapter))
+
+/* RTL8821 Series */
+#define IS_HARDWARE_TYPE_8821E(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821E)
+#define IS_HARDWARE_TYPE_8811AU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8811AU)
+#define IS_HARDWARE_TYPE_8821U(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821U || \
+		rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8811AU)
+#define IS_HARDWARE_TYPE_8821S(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821S)
+#define IS_HARDWARE_TYPE_8821(_Adapter)			\
+	(IS_HARDWARE_TYPE_8821E(_Adapter) || IS_HARDWARE_TYPE_8821U(_Adapter) || IS_HARDWARE_TYPE_8821S(_Adapter))
+
+#define IS_HARDWARE_TYPE_JAGUAR(_Adapter)		\
+	(IS_HARDWARE_TYPE_8812(_Adapter) || IS_HARDWARE_TYPE_8821(_Adapter))
+
+/* RTL8192E Series */
+#define IS_HARDWARE_TYPE_8192EE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192EE)
+#define IS_HARDWARE_TYPE_8192EU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192EU)
+#define IS_HARDWARE_TYPE_8192ES(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192ES)
+
+#define IS_HARDWARE_TYPE_8192E(_Adapter)		\
+	(IS_HARDWARE_TYPE_8192EE(_Adapter) || IS_HARDWARE_TYPE_8192EU(_Adapter) || IS_HARDWARE_TYPE_8192ES(_Adapter))
+
+#define IS_HARDWARE_TYPE_8723BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723BE)
+#define IS_HARDWARE_TYPE_8723BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723BU)
+#define IS_HARDWARE_TYPE_8723BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723BS)
+
+#define IS_HARDWARE_TYPE_8723B(_Adapter) \
+	(IS_HARDWARE_TYPE_8723BE(_Adapter) || IS_HARDWARE_TYPE_8723BU(_Adapter) || IS_HARDWARE_TYPE_8723BS(_Adapter))
+
+/* RTL8814A Series */
+#define IS_HARDWARE_TYPE_8814AE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8814AE)
+#define IS_HARDWARE_TYPE_8814AU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8814AU)
+#define IS_HARDWARE_TYPE_8814AS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8814AS)
+
+#define IS_HARDWARE_TYPE_8814A(_Adapter)		\
+	(IS_HARDWARE_TYPE_8814AE(_Adapter) || IS_HARDWARE_TYPE_8814AU(_Adapter) || IS_HARDWARE_TYPE_8814AS(_Adapter))
+
+/* RTL8703B Series */
+#define IS_HARDWARE_TYPE_8703BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8703BE)
+#define IS_HARDWARE_TYPE_8703BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8703BS)
+#define IS_HARDWARE_TYPE_8703BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8703BU)
+#define	IS_HARDWARE_TYPE_8703B(_Adapter)			\
+	(IS_HARDWARE_TYPE_8703BE(_Adapter) || IS_HARDWARE_TYPE_8703BU(_Adapter) || IS_HARDWARE_TYPE_8703BS(_Adapter))
+
+/* RTL8723D Series */
+#define IS_HARDWARE_TYPE_8723DE(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723DE)
+#define IS_HARDWARE_TYPE_8723DS(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723DS)
+#define IS_HARDWARE_TYPE_8723DU(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723DU)
+#define	IS_HARDWARE_TYPE_8723D(_Adapter)\
+	(IS_HARDWARE_TYPE_8723DE(_Adapter) || \
+	 IS_HARDWARE_TYPE_8723DU(_Adapter) || \
+	 IS_HARDWARE_TYPE_8723DS(_Adapter))
+
+/* RTL8188F Series */
+#define IS_HARDWARE_TYPE_8188FE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FE)
+#define IS_HARDWARE_TYPE_8188FS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FS)
+#define IS_HARDWARE_TYPE_8188FU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FU)
+#define	IS_HARDWARE_TYPE_8188F(_Adapter)			\
+	(IS_HARDWARE_TYPE_8188FE(_Adapter) || IS_HARDWARE_TYPE_8188FU(_Adapter) || IS_HARDWARE_TYPE_8188FS(_Adapter))
+
+#define IS_HARDWARE_TYPE_8821BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BE)
+#define IS_HARDWARE_TYPE_8821BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BU)
+#define IS_HARDWARE_TYPE_8821BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BS)
+
+#define IS_HARDWARE_TYPE_8821B(_Adapter)		\
+	(IS_HARDWARE_TYPE_8821BE(_Adapter) || IS_HARDWARE_TYPE_8821BU(_Adapter) || IS_HARDWARE_TYPE_8821BS(_Adapter))
+
+#define IS_HARDWARE_TYPE_8822BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8822BE)
+#define IS_HARDWARE_TYPE_8822BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8822BU)
+#define IS_HARDWARE_TYPE_8822BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8822BS)
+#define IS_HARDWARE_TYPE_8822B(_Adapter)		\
+	(IS_HARDWARE_TYPE_8822BE(_Adapter) || IS_HARDWARE_TYPE_8822BU(_Adapter) || IS_HARDWARE_TYPE_8822BS(_Adapter))
+
+#define IS_HARDWARE_TYPE_8821CE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821CE)
+#define IS_HARDWARE_TYPE_8821CU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821CU)
+#define IS_HARDWARE_TYPE_8821CS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821CS)
+#define IS_HARDWARE_TYPE_8821C(_Adapter)		\
+	(IS_HARDWARE_TYPE_8821CE(_Adapter) || IS_HARDWARE_TYPE_8821CU(_Adapter) || IS_HARDWARE_TYPE_8821CS(_Adapter))
+
+#define IS_HARDWARE_TYPE_JAGUAR2(_Adapter)		\
+	(IS_HARDWARE_TYPE_8814A(_Adapter) || IS_HARDWARE_TYPE_8821B(_Adapter) || IS_HARDWARE_TYPE_8822B(_Adapter) || IS_HARDWARE_TYPE_8821C(_Adapter))
+
+#define IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(_Adapter)		\
+	(IS_HARDWARE_TYPE_JAGUAR(_Adapter) || IS_HARDWARE_TYPE_JAGUAR2(_Adapter))
+
+
+
+typedef enum _wowlan_subcode {
+	WOWLAN_ENABLE			= 0,
+	WOWLAN_DISABLE			= 1,
+	WOWLAN_AP_ENABLE		= 2,
+	WOWLAN_AP_DISABLE		= 3,
+	WOWLAN_PATTERN_CLEAN		= 4
+} wowlan_subcode;
+
+struct wowlan_ioctl_param {
+	unsigned int subcode;
+	unsigned int subcode_value;
+	unsigned int wakeup_reason;
+};
+
+u8 rtw_hal_data_init(_adapter *padapter);
+void rtw_hal_data_deinit(_adapter *padapter);
+
+void rtw_hal_def_value_init(_adapter *padapter);
+
+void	rtw_hal_free_data(_adapter *padapter);
+
+void rtw_hal_dm_init(_adapter *padapter);
+void rtw_hal_dm_deinit(_adapter *padapter);
+#ifdef CONFIG_RTW_SW_LED
+void rtw_hal_sw_led_init(_adapter *padapter);
+void rtw_hal_sw_led_deinit(_adapter *padapter);
+#endif
+u32 rtw_hal_power_on(_adapter *padapter);
+void rtw_hal_power_off(_adapter *padapter);
+
+uint rtw_hal_init(_adapter *padapter);
+uint rtw_hal_deinit(_adapter *padapter);
+void rtw_hal_stop(_adapter *padapter);
+u8 rtw_hal_set_hwreg(PADAPTER padapter, u8 variable, u8 *val);
+void rtw_hal_get_hwreg(PADAPTER padapter, u8 variable, u8 *val);
+
+void rtw_hal_chip_configure(_adapter *padapter);
+u8 rtw_hal_read_chip_info(_adapter *padapter);
+void rtw_hal_read_chip_version(_adapter *padapter);
+
+u8 rtw_hal_set_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
+u8 rtw_hal_get_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
+
+void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, BOOLEAN bSet);
+void	rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, PVOID pValue2);
+
+void rtw_hal_enable_interrupt(_adapter *padapter);
+void rtw_hal_disable_interrupt(_adapter *padapter);
+
+u8 rtw_hal_check_ips_status(_adapter *padapter);
+
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
+	u32	rtw_hal_inirp_init(_adapter *padapter);
+	u32	rtw_hal_inirp_deinit(_adapter *padapter);
+#endif
+
+#if defined(CONFIG_PCI_HCI)
+	void	rtw_hal_irp_reset(_adapter *padapter);
+void	rtw_hal_pci_dbi_write(_adapter *padapter, u16 addr, u8 data);
+u8	rtw_hal_pci_dbi_read(_adapter *padapter, u16 addr);
+void	rtw_hal_pci_mdio_write(_adapter *padapter, u8 addr, u16 data);
+u16	rtw_hal_pci_mdio_read(_adapter *padapter, u8 addr);
+u8	rtw_hal_pci_l1off_nic_support(_adapter *padapter);
+u8	rtw_hal_pci_l1off_capability(_adapter *padapter);
+#endif
+
+u8	rtw_hal_intf_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val);
+
+s32	rtw_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+s32	rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe);
+s32	rtw_hal_mgnt_xmit(_adapter *padapter, struct xmit_frame *pmgntframe);
+
+s32	rtw_hal_init_xmit_priv(_adapter *padapter);
+void	rtw_hal_free_xmit_priv(_adapter *padapter);
+
+s32	rtw_hal_init_recv_priv(_adapter *padapter);
+void	rtw_hal_free_recv_priv(_adapter *padapter);
+
+void rtw_hal_update_ra_mask(struct sta_info *psta);
+
+void	rtw_hal_start_thread(_adapter *padapter);
+void	rtw_hal_stop_thread(_adapter *padapter);
+
+void rtw_hal_bcn_related_reg_setting(_adapter *padapter);
+
+u32	rtw_hal_read_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask);
+void	rtw_hal_write_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
+u32	rtw_hal_read_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask);
+void	rtw_hal_write_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
+
+
+#define phy_query_bb_reg(Adapter, RegAddr, BitMask) rtw_hal_read_bbreg((Adapter), (RegAddr), (BitMask))
+#define phy_set_bb_reg(Adapter, RegAddr, BitMask, Data) rtw_hal_write_bbreg((Adapter), (RegAddr), (BitMask), (Data))
+#define phy_query_rf_reg(Adapter, eRFPath, RegAddr, BitMask) rtw_hal_read_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask))
+#define phy_set_rf_reg(Adapter, eRFPath, RegAddr, BitMask, Data) rtw_hal_write_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask), (Data))
+
+#define phy_set_mac_reg	phy_set_bb_reg
+#define phy_query_mac_reg phy_query_bb_reg
+
+
+#if defined(CONFIG_PCI_HCI)
+	s32	rtw_hal_interrupt_handler(_adapter *padapter);
+#endif
+#if  defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
+	void	rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+
+void	rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80);
+void	rtw_hal_dm_watchdog(_adapter *padapter);
+void	rtw_hal_dm_watchdog_in_lps(_adapter *padapter);
+
+void	rtw_hal_set_tx_power_level(_adapter *padapter, u8 channel);
+void	rtw_hal_get_tx_power_level(_adapter *padapter, s32 *powerlevel);
+
+#ifdef CONFIG_HOSTAPD_MLME
+	s32	rtw_hal_hostap_mgnt_xmit_entry(_adapter *padapter, _pkt *pkt);
+#endif
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+void rtw_hal_sreset_init(_adapter *padapter);
+void rtw_hal_sreset_reset(_adapter *padapter);
+void rtw_hal_sreset_reset_value(_adapter *padapter);
+void rtw_hal_sreset_xmit_status_check(_adapter *padapter);
+void rtw_hal_sreset_linked_status_check(_adapter *padapter);
+u8   rtw_hal_sreset_get_wifi_status(_adapter *padapter);
+bool rtw_hal_sreset_inprogress(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_IOL
+int rtw_hal_iol_cmd(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
+#endif
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+s32 rtw_hal_xmit_thread_handler(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RECV_THREAD_MODE
+s32 rtw_hal_recv_hdl(_adapter *adapter);
+#endif
+
+void rtw_hal_notch_filter(_adapter *adapter, bool enable);
+
+#ifdef CONFIG_FW_C2H_REG
+bool rtw_hal_c2h_reg_hdr_parse(_adapter *adapter, u8 *buf, u8 *id, u8 *seq, u8 *plen, u8 **payload);
+bool rtw_hal_c2h_valid(_adapter *adapter, u8 *buf);
+s32 rtw_hal_c2h_evt_read(_adapter *adapter, u8 *buf);
+#endif
+
+#ifdef CONFIG_FW_C2H_PKT
+bool rtw_hal_c2h_pkt_hdr_parse(_adapter *adapter, u8 *buf, u16 len, u8 *id, u8 *seq, u8 *plen, u8 **payload);
+#endif
+
+s32 c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+#ifndef RTW_HALMAC
+s32 rtw_hal_c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+s32 rtw_hal_c2h_id_handle_directly(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+#endif
+
+s32 rtw_hal_is_disable_sw_channel_plan(PADAPTER padapter);
+
+s32 rtw_hal_macid_sleep(_adapter *adapter, u8 macid);
+s32 rtw_hal_macid_wakeup(_adapter *adapter, u8 macid);
+s32 rtw_hal_macid_sleep_all_used(_adapter *adapter);
+s32 rtw_hal_macid_wakeup_all_used(_adapter *adapter);
+
+s32 rtw_hal_fill_h2c_cmd(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+void rtw_hal_fill_fake_txdesc(_adapter *padapter, u8 *pDesc, u32 BufferLen,
+			      u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+u8 rtw_hal_get_txbuff_rsvd_page_num(_adapter *adapter, bool wowlan);
+
+#ifdef CONFIG_GPIO_API
+void rtw_hal_update_hisr_hsisr_ind(_adapter *padapter, u32 flag);
+int rtw_hal_gpio_func_check(_adapter *padapter, u8 gpio_num);
+void rtw_hal_gpio_multi_func_reset(_adapter *padapter, u8 gpio_num);
+#endif
+
+void rtw_hal_fw_correct_bcn(_adapter *padapter);
+s32 rtw_hal_fw_dl(_adapter *padapter, u8 wowlan);
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	void rtw_hal_clear_interrupt(_adapter *padapter);
+#endif
+
+void rtw_hal_set_tx_power_index(PADAPTER adapter, u32 powerindex, enum rf_path rfpath, u8 rate);
+u8 rtw_hal_get_tx_power_index(PADAPTER adapter, enum rf_path
+	rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);
+
+u8 rtw_hal_ops_check(_adapter *padapter);
+
+#ifdef RTW_HALMAC
+	u8 rtw_hal_init_mac_register(PADAPTER);
+	u8 rtw_hal_init_phy(PADAPTER);
+s32 rtw_hal_fw_mem_dl(_adapter *padapter, enum fw_mem mem);
+#endif /* RTW_HALMAC */
+
+#ifdef CONFIG_RFKILL_POLL
+bool rtw_hal_rfkill_poll(_adapter *adapter, u8 *valid);
+#endif
+
+#endif /* __HAL_INTF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_pg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_pg.h
new file mode 100644
index 000000000000..ad6a5574fb45
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_pg.h
@@ -0,0 +1,760 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PG_H__
+#define __HAL_PG_H__
+
+#define PPG_BB_GAIN_2G_TX_OFFSET_MASK	0x0F
+#define PPG_BB_GAIN_2G_TXB_OFFSET_MASK	0xF0
+
+#define PPG_BB_GAIN_5G_TX_OFFSET_MASK	0x1F
+#define PPG_THERMAL_OFFSET_MASK			0x1F
+#define KFREE_BB_GAIN_2G_TX_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_2G_TX_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
+#define KFREE_BB_GAIN_2G_TXB_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_2G_TXB_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x10) ? ((_ppg_v) >> 5) : (-((_ppg_v) >> 5))))
+#define KFREE_BB_GAIN_5G_TX_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_5G_TX_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
+#define KFREE_THERMAL_OFFSET(_ppg_v) (((_ppg_v) == PPG_THERMAL_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 88EE/88EU/88ES
+ * **************************************************** */
+#define EEPROM_ChannelPlan_88E					0xB8
+#define EEPROM_XTAL_88E						0xB9
+#define EEPROM_THERMAL_METER_88E				0xBA
+#define EEPROM_IQK_LCK_88E						0xBB
+
+#define EEPROM_RF_BOARD_OPTION_88E			0xC1
+#define EEPROM_RF_FEATURE_OPTION_88E			0xC2
+#define EEPROM_RF_BT_SETTING_88E				0xC3
+#define EEPROM_VERSION_88E						0xC4
+#define EEPROM_CustomID_88E					0xC5
+#define EEPROM_RF_ANTENNA_OPT_88E			0xC9
+#define EEPROM_COUNTRY_CODE_88E				0xCB
+
+/* RTL88EE */
+#define EEPROM_MAC_ADDR_88EE					0xD0
+#define EEPROM_VID_88EE						0xD6
+#define EEPROM_DID_88EE						0xD8
+#define EEPROM_SVID_88EE						0xDA
+#define EEPROM_SMID_88EE						0xDC
+
+/* RTL88EU */
+#define EEPROM_MAC_ADDR_88EU					0xD7
+#define EEPROM_VID_88EU						0xD0
+#define EEPROM_PID_88EU						0xD2
+#define EEPROM_USB_OPTIONAL_FUNCTION0		0xD4 /* 8188EU, 8192EU, 8812AU is the same */
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8811AU 0x104
+
+/* RTL88ES */
+#define EEPROM_MAC_ADDR_88ES					0x11A
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8192EE/8192EU/8192ES
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8192E(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8192E(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8192E	0x1F6
+#define PPG_THERMAL_OFFSET_8192E		0x1F5
+
+#define	EEPROM_ChannelPlan_8192E				0xB8
+#define	EEPROM_XTAL_8192E						0xB9
+#define	EEPROM_THERMAL_METER_8192E			0xBA
+#define	EEPROM_IQK_LCK_8192E					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8192E			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8192E	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8192E	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8192E		0xC1
+#define	EEPROM_RF_FEATURE_OPTION_8192E		0xC2
+#define	EEPROM_RF_BT_SETTING_8192E			0xC3
+#define	EEPROM_VERSION_8192E					0xC4
+#define	EEPROM_CustomID_8192E				0xC5
+#define	EEPROM_TX_BBSWING_2G_8192E			0xC6
+#define	EEPROM_TX_BBSWING_5G_8192E			0xC7
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8192E	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8192E			0xC9
+#define	EEPROM_RFE_OPTION_8192E				0xCA
+#define	EEPROM_RFE_OPTION_8188E				0xCA
+#define EEPROM_COUNTRY_CODE_8192E			0xCB
+
+/* RTL8192EE */
+#define	EEPROM_MAC_ADDR_8192EE				0xD0
+#define	EEPROM_VID_8192EE						0xD6
+#define	EEPROM_DID_8192EE						0xD8
+#define	EEPROM_SVID_8192EE					0xDA
+#define	EEPROM_SMID_8192EE					0xDC
+
+/* RTL8192EU */
+#define	EEPROM_MAC_ADDR_8192EU				0xD7
+#define	EEPROM_VID_8192EU						0xD0
+#define	EEPROM_PID_8192EU						0xD2
+#define	EEPROM_PA_TYPE_8192EU		0xBC
+#define	EEPROM_LNA_TYPE_2G_8192EU	0xBD
+#define	EEPROM_LNA_TYPE_5G_8192EU	0xBF
+
+/* RTL8192ES */
+#define	EEPROM_MAC_ADDR_8192ES				0x11A
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8812AE/8812AU/8812AS
+ * *****************************************************/
+#define EEPROM_USB_MODE_8812					0x08
+
+#define EEPROM_ChannelPlan_8812				0xB8
+#define EEPROM_XTAL_8812						0xB9
+#define EEPROM_THERMAL_METER_8812			0xBA
+#define EEPROM_IQK_LCK_8812					0xBB
+#define EEPROM_2G_5G_PA_TYPE_8812			0xBC
+#define EEPROM_2G_LNA_TYPE_GAIN_SEL_8812	0xBD
+#define EEPROM_5G_LNA_TYPE_GAIN_SEL_8812	0xBF
+
+#define EEPROM_RF_BOARD_OPTION_8812			0xC1
+#define EEPROM_RF_FEATURE_OPTION_8812		0xC2
+#define EEPROM_RF_BT_SETTING_8812				0xC3
+#define EEPROM_VERSION_8812					0xC4
+#define EEPROM_CustomID_8812					0xC5
+#define EEPROM_TX_BBSWING_2G_8812			0xC6
+#define EEPROM_TX_BBSWING_5G_8812			0xC7
+#define EEPROM_TX_PWR_CALIBRATE_RATE_8812	0xC8
+#define EEPROM_RF_ANTENNA_OPT_8812			0xC9
+#define EEPROM_RFE_OPTION_8812				0xCA
+#define EEPROM_COUNTRY_CODE_8812			0xCB
+
+/* RTL8812AE */
+#define EEPROM_MAC_ADDR_8812AE				0xD0
+#define EEPROM_VID_8812AE						0xD6
+#define EEPROM_DID_8812AE						0xD8
+#define EEPROM_SVID_8812AE						0xDA
+#define EEPROM_SMID_8812AE					0xDC
+
+/* RTL8812AU */
+#define EEPROM_MAC_ADDR_8812AU				0xD7
+#define EEPROM_VID_8812AU						0xD0
+#define EEPROM_PID_8812AU						0xD2
+#define EEPROM_PA_TYPE_8812AU					0xBC
+#define EEPROM_LNA_TYPE_2G_8812AU			0xBD
+#define EEPROM_LNA_TYPE_5G_8812AU			0xBF
+
+/* RTL8814AU */
+#define	EEPROM_MAC_ADDR_8814AU				0xD8
+#define	EEPROM_VID_8814AU						0xD0
+#define	EEPROM_PID_8814AU						0xD2
+#define	EEPROM_PA_TYPE_8814AU				0xBC
+#define	EEPROM_LNA_TYPE_2G_8814AU			0xBD
+#define	EEPROM_LNA_TYPE_5G_8814AU			0xBF
+
+/* RTL8814AE */
+#define EEPROM_MAC_ADDR_8814AE				0xD0
+#define EEPROM_VID_8814AE						0xD6
+#define EEPROM_DID_8814AE						0xD8
+#define EEPROM_SVID_8814AE						0xDA
+#define EEPROM_SMID_8814AE					0xDC
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8814AU
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8814A(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8814A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+#define GET_PG_TX_POWER_TRACKING_MODE_8814A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 6, 2)
+
+#define KFREE_GAIN_DATA_LENGTH_8814A	22
+
+#define PPG_BB_GAIN_2G_TXBA_OFFSET_8814A	0x3EE
+
+#define PPG_THERMAL_OFFSET_8814A		0x3EF
+
+#define EEPROM_USB_MODE_8814A				0x0E
+#define EEPROM_ChannelPlan_8814				0xB8
+#define EEPROM_XTAL_8814					0xB9
+#define EEPROM_THERMAL_METER_8814			0xBA
+#define	EEPROM_IQK_LCK_8814					0xBB
+
+
+#define EEPROM_PA_TYPE_8814					0xBC
+#define EEPROM_LNA_TYPE_AB_2G_8814			0xBD
+#define	EEPROM_LNA_TYPE_CD_2G_8814			0xBE
+#define EEPROM_LNA_TYPE_AB_5G_8814			0xBF
+#define EEPROM_LNA_TYPE_CD_5G_8814			0xC0
+#define	EEPROM_RF_BOARD_OPTION_8814			0xC1
+#define	EEPROM_RF_BT_SETTING_8814			0xC3
+#define	EEPROM_VERSION_8814					0xC4
+#define	EEPROM_CustomID_8814				0xC5
+#define	EEPROM_TX_BBSWING_2G_8814			0xC6
+#define	EEPROM_TX_BBSWING_5G_8814			0xC7
+#define EEPROM_TRX_ANTENNA_OPTION_8814		0xC9
+#define	EEPROM_RFE_OPTION_8814				0xCA
+#define EEPROM_COUNTRY_CODE_8814			0xCB
+
+/*Extra Info for 8814A Initial Gain Fine Tune  suggested by Willis, JIRA: MP123*/
+#define	EEPROM_IG_OFFSET_4_AB_2G_8814A				0x120
+#define	EEPROM_IG_OFFSET_4_CD_2G_8814A				0x121
+#define	EEPROM_IG_OFFSET_4_AB_5GL_8814A				0x122
+#define	EEPROM_IG_OFFSET_4_CD_5GL_8814A				0x123
+#define	EEPROM_IG_OFFSET_4_AB_5GM_8814A				0x124
+#define	EEPROM_IG_OFFSET_4_CD_5GM_8814A				0x125
+#define	EEPROM_IG_OFFSET_4_AB_5GH_8814A				0x126
+#define	EEPROM_IG_OFFSET_4_CD_5GH_8814A				0x127
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8821AE/8821AU/8821AS
+ * **************************************************** */
+
+#define GET_PG_KFREE_ON_8821A(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8821A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8821A		0x1F6
+#define PPG_THERMAL_OFFSET_8821A			0x1F5
+#define PPG_BB_GAIN_5GLB1_TXA_OFFSET_8821A	0x1F4
+#define PPG_BB_GAIN_5GLB2_TXA_OFFSET_8821A	0x1F3
+#define PPG_BB_GAIN_5GMB1_TXA_OFFSET_8821A	0x1F2
+#define PPG_BB_GAIN_5GMB2_TXA_OFFSET_8821A	0x1F1
+#define PPG_BB_GAIN_5GHB_TXA_OFFSET_8821A	0x1F0
+
+#define EEPROM_ChannelPlan_8821				0xB8
+#define EEPROM_XTAL_8821						0xB9
+#define EEPROM_THERMAL_METER_8821			0xBA
+#define EEPROM_IQK_LCK_8821					0xBB
+
+
+#define EEPROM_RF_BOARD_OPTION_8821			0xC1
+#define EEPROM_RF_FEATURE_OPTION_8821		0xC2
+#define EEPROM_RF_BT_SETTING_8821				0xC3
+#define EEPROM_VERSION_8821					0xC4
+#define EEPROM_CustomID_8821					0xC5
+#define EEPROM_RF_ANTENNA_OPT_8821			0xC9
+
+/* RTL8821AE */
+#define EEPROM_MAC_ADDR_8821AE				0xD0
+#define EEPROM_VID_8821AE						0xD6
+#define EEPROM_DID_8821AE						0xD8
+#define EEPROM_SVID_8821AE						0xDA
+#define EEPROM_SMID_8821AE					0xDC
+
+/* RTL8821AU */
+#define EEPROM_PA_TYPE_8821AU					0xBC
+#define EEPROM_LNA_TYPE_8821AU				0xBF
+
+/* RTL8821AS */
+#define EEPROM_MAC_ADDR_8821AS				0x11A
+
+/* RTL8821AU */
+#define EEPROM_MAC_ADDR_8821AU				0x107
+#define EEPROM_VID_8821AU						0x100
+#define EEPROM_PID_8821AU						0x102
+
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8192 SE/SU
+ * **************************************************** */
+#define EEPROM_VID_92SE						0x0A
+#define EEPROM_DID_92SE						0x0C
+#define EEPROM_SVID_92SE						0x0E
+#define EEPROM_SMID_92SE						0x10
+
+#define EEPROM_MAC_ADDR_92S					0x12
+
+#define EEPROM_TSSI_A_92SE						0x74
+#define EEPROM_TSSI_B_92SE						0x75
+
+#define EEPROM_Version_92SE					0x7C
+
+
+#define EEPROM_VID_92SU						0x08
+#define EEPROM_PID_92SU						0x0A
+
+#define EEPROM_Version_92SU					0x50
+#define EEPROM_TSSI_A_92SU						0x6b
+#define EEPROM_TSSI_B_92SU						0x6c
+
+/* ====================================================
+	EEPROM/Efuse PG Offset for 8188FE/8188FU/8188FS
+   ====================================================
+ */
+
+#define GET_PG_KFREE_ON_8188F(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8188F(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8188F	0xEE
+#define PPG_THERMAL_OFFSET_8188F		0xEF
+
+#define	EEPROM_ChannelPlan_8188F			0xB8
+#define	EEPROM_XTAL_8188F					0xB9
+#define	EEPROM_THERMAL_METER_8188F			0xBA
+#define	EEPROM_IQK_LCK_8188F				0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8188F			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8188F	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8188F	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8188F		0xC1
+#define	EEPROM_FEATURE_OPTION_8188F			0xC2
+#define	EEPROM_RF_BT_SETTING_8188F			0xC3
+#define	EEPROM_VERSION_8188F				0xC4
+#define	EEPROM_CustomID_8188F				0xC5
+#define	EEPROM_TX_BBSWING_2G_8188F			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8188F	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8188F			0xC9
+#define	EEPROM_RFE_OPTION_8188F				0xCA
+#define EEPROM_COUNTRY_CODE_8188F			0xCB
+#define EEPROM_CUSTOMER_ID_8188F			0x7F
+#define EEPROM_SUBCUSTOMER_ID_8188F			0x59
+
+/* RTL8188FU */
+#define EEPROM_MAC_ADDR_8188FU				0xD7
+#define EEPROM_VID_8188FU					0xD0
+#define EEPROM_PID_8188FU					0xD2
+#define EEPROM_PA_TYPE_8188FU				0xBC
+#define EEPROM_LNA_TYPE_2G_8188FU			0xBD
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8188FU 0xD4
+
+/* RTL8188FS */
+#define	EEPROM_MAC_ADDR_8188FS				0x11A
+#define EEPROM_Voltage_ADDR_8188F			0x8
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8723BE/8723BU/8723BS
+ * *****************************************************/
+#define	EEPROM_ChannelPlan_8723B				0xB8
+#define	EEPROM_XTAL_8723B						0xB9
+#define	EEPROM_THERMAL_METER_8723B			0xBA
+#define	EEPROM_IQK_LCK_8723B					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8723B			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8723B	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8723B	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8723B		0xC1
+#define	EEPROM_FEATURE_OPTION_8723B			0xC2
+#define	EEPROM_RF_BT_SETTING_8723B			0xC3
+#define	EEPROM_VERSION_8723B					0xC4
+#define	EEPROM_CustomID_8723B				0xC5
+#define	EEPROM_TX_BBSWING_2G_8723B			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8723B	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8723B		0xC9
+#define	EEPROM_RFE_OPTION_8723B				0xCA
+#define EEPROM_COUNTRY_CODE_8723B			0xCB
+
+/* RTL8723BE */
+#define EEPROM_MAC_ADDR_8723BE				0xD0
+#define EEPROM_VID_8723BE						0xD6
+#define EEPROM_DID_8723BE						0xD8
+#define EEPROM_SVID_8723BE						0xDA
+#define EEPROM_SMID_8723BE						0xDC
+
+/* RTL8723BU */
+#define EEPROM_MAC_ADDR_8723BU				0x107
+#define EEPROM_VID_8723BU						0x100
+#define EEPROM_PID_8723BU						0x102
+#define EEPROM_PA_TYPE_8723BU					0xBC
+#define EEPROM_LNA_TYPE_2G_8723BU				0xBD
+
+
+/* RTL8723BS */
+#define	EEPROM_MAC_ADDR_8723BS				0x11A
+#define EEPROM_Voltage_ADDR_8723B			0x8
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8703B
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8703B(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8703B(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8703B	0xEE
+#define PPG_THERMAL_OFFSET_8703B		0xEF
+
+#define	EEPROM_ChannelPlan_8703B				0xB8
+#define	EEPROM_XTAL_8703B					0xB9
+#define	EEPROM_THERMAL_METER_8703B			0xBA
+#define	EEPROM_IQK_LCK_8703B					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8703B			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8703B	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8703B	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8703B		0xC1
+#define	EEPROM_FEATURE_OPTION_8703B			0xC2
+#define	EEPROM_RF_BT_SETTING_8703B			0xC3
+#define	EEPROM_VERSION_8703B					0xC4
+#define	EEPROM_CustomID_8703B					0xC5
+#define	EEPROM_TX_BBSWING_2G_8703B			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8703B	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8703B		0xC9
+#define	EEPROM_RFE_OPTION_8703B				0xCA
+#define EEPROM_COUNTRY_CODE_8703B			0xCB
+
+/* RTL8703BU */
+#define EEPROM_MAC_ADDR_8703BU                          0x107
+#define EEPROM_VID_8703BU                               0x100
+#define EEPROM_PID_8703BU                               0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8703BU            0x104
+#define EEPROM_PA_TYPE_8703BU                           0xBC
+#define EEPROM_LNA_TYPE_2G_8703BU                       0xBD
+
+/* RTL8703BS */
+#define	EEPROM_MAC_ADDR_8703BS				0x11A
+#define	EEPROM_Voltage_ADDR_8703B			0x8
+
+/*
+ * ====================================================
+ *	EEPROM/Efuse PG Offset for 8822B
+ * ====================================================
+ */
+#define	EEPROM_ChannelPlan_8822B		0xB8
+#define	EEPROM_XTAL_8822B			0xB9
+#define	EEPROM_THERMAL_METER_8822B		0xBA
+#define	EEPROM_IQK_LCK_8822B			0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8822B		0xBC
+/* PATH A & PATH B */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B	0xBD
+/* PATH C & PATH D */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_CD_8822B	0xBE
+/* PATH A & PATH B */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B	0xBF
+/* PATH C & PATH D */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_CD_8822B	0xC0
+
+#define	EEPROM_RF_BOARD_OPTION_8822B		0xC1
+#define	EEPROM_FEATURE_OPTION_8822B		0xC2
+#define	EEPROM_RF_BT_SETTING_8822B		0xC3
+#define	EEPROM_VERSION_8822B			0xC4
+#define	EEPROM_CustomID_8822B			0xC5
+#define	EEPROM_TX_BBSWING_2G_8822B		0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8822B	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8822B		0xC9
+#define	EEPROM_RFE_OPTION_8822B			0xCA
+#define EEPROM_COUNTRY_CODE_8822B		0xCB
+
+/* RTL8822BU */
+#define EEPROM_MAC_ADDR_8822BU			0x107
+#define EEPROM_VID_8822BU			0x100
+#define EEPROM_PID_8822BU			0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8822BU	0x104
+#define EEPROM_USB_MODE_8822BU			0x06
+
+/* RTL8822BS */
+#define	EEPROM_MAC_ADDR_8822BS			0x11A
+
+/* RTL8822BE */
+#define	EEPROM_MAC_ADDR_8822BE			0xD0
+/*
+ * ====================================================
+ *	EEPROM/Efuse PG Offset for 8821C
+ * ====================================================
+ */
+#define	EEPROM_CHANNEL_PLAN_8821C		0xB8
+#define	EEPROM_XTAL_8821C			0xB9
+#define	EEPROM_THERMAL_METER_8821C		0xBA
+#define	EEPROM_IQK_LCK_8821C			0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8821C		0xBC
+/* PATH A & PATH B */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8821C	0xBD
+/* PATH C & PATH D */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_CD_8821C	0xBE
+/* PATH A & PATH B */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8821C	0xBF
+/* PATH C & PATH D */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_CD_8821C	0xC0
+
+#define	EEPROM_RF_BOARD_OPTION_8821C		0xC1
+#define	EEPROM_FEATURE_OPTION_8821C		0xC2
+#define	EEPROM_RF_BT_SETTING_8821C		0xC3
+#define	EEPROM_VERSION_8821C			0xC4
+#define	EEPROM_CUSTOMER_ID_8821C			0xC5
+#define	EEPROM_TX_BBSWING_2G_8821C		0xC6
+#define	EEPROM_TX_BBSWING_5G_8821C		0xC7
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8821C	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8821C		0xC9
+#define	EEPROM_RFE_OPTION_8821C			0xCA
+#define EEPROM_COUNTRY_CODE_8821C		0xCB
+
+/* RTL8821CU */
+#define EEPROM_MAC_ADDR_8821CU			0x107
+#define EEPROM_VID_8821CU					0x100
+#define EEPROM_PID_8821CU					0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8821CU	0x104
+#define EEPROM_USB_MODE_8821CU			0x06
+
+/* RTL8821CS */
+#define	EEPROM_MAC_ADDR_8821CS			0x11A
+
+/* RTL8821CE */
+#define	EEPROM_MAC_ADDR_8821CE			0xD0
+/* ****************************************************
+ *	EEPROM/Efuse PG Offset for 8723D
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8723D(_pg_m)	\
+	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8723D(_pg_m)	\
+	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_8723D_S1	0
+#define PPG_8723D_S0	1
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8723D		0xEE
+#define PPG_BB_GAIN_2G_TX_OFFSET_8723D		0x1EE
+#define PPG_THERMAL_OFFSET_8723D		0xEF
+
+#define	EEPROM_ChannelPlan_8723D		0xB8
+#define	EEPROM_XTAL_8723D			0xB9
+#define	EEPROM_THERMAL_METER_8723D		0xBA
+#define	EEPROM_IQK_LCK_8723D			0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8723D		0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8723D	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8723D	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8723D		0xC1
+#define	EEPROM_FEATURE_OPTION_8723D		0xC2
+#define	EEPROM_RF_BT_SETTING_8723D		0xC3
+#define	EEPROM_VERSION_8723D			0xC4
+#define	EEPROM_CustomID_8723D			0xC5
+#define	EEPROM_TX_BBSWING_2G_8723D		0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8723D	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8723D		0xC9
+#define	EEPROM_RFE_OPTION_8723D			0xCA
+#define EEPROM_COUNTRY_CODE_8723D		0xCB
+
+/* RTL8723DE */
+#define EEPROM_MAC_ADDR_8723DE              0xD0
+#define EEPROM_VID_8723DE                   0xD6
+#define EEPROM_DID_8723DE                   0xD8
+#define EEPROM_SVID_8723DE                  0xDA
+#define EEPROM_SMID_8723DE                  0xDC
+
+/* RTL8723DU */
+#define EEPROM_MAC_ADDR_8723DU                  0x107
+#define EEPROM_VID_8723DU                       0x100
+#define EEPROM_PID_8723DU                       0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8723DU    0x104
+
+/* RTL8723BS */
+#define	EEPROM_MAC_ADDR_8723DS			0x11A
+#define	EEPROM_Voltage_ADDR_8723D		0x8
+
+/* ****************************************************
+ *			EEPROM/Efuse Value Type
+ * **************************************************** */
+#define EETYPE_TX_PWR							0x0
+/* ****************************************************
+ *			EEPROM/Efuse Default Value
+ * **************************************************** */
+#define EEPROM_CID_DEFAULT					0x0
+#define EEPROM_CID_DEFAULT_EXT				0xFF /* Reserved for Realtek */
+#define EEPROM_CID_TOSHIBA						0x4
+#define EEPROM_CID_CCX							0x10
+#define EEPROM_CID_QMI							0x0D
+#define EEPROM_CID_WHQL						0xFE
+
+#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_TAIWAN		0xB
+#define EEPROM_CHANNEL_PLAN_CHIAN			0XC
+#define EEPROM_CHANNEL_PLAN_SINGAPORE_INDIA_MEXICO  0XD
+#define EEPROM_CHANNEL_PLAN_KOREA			0xE
+#define EEPROM_CHANNEL_PLAN_TURKEY	0xF
+#define EEPROM_CHANNEL_PLAN_JAPAN	0x10
+#define EEPROM_CHANNEL_PLAN_FCC_NO_DFS		0x11
+#define EEPROM_CHANNEL_PLAN_JAPAN_NO_DFS	0x12
+#define EEPROM_CHANNEL_PLAN_WORLD_WIDE_5G	0x13
+#define EEPROM_CHANNEL_PLAN_TAIWAN_NO_DFS	0x14
+
+#define EEPROM_USB_OPTIONAL1					0xE
+#define EEPROM_CHANNEL_PLAN_BY_HW_MASK		0x80
+
+#define RTL_EEPROM_ID							0x8129
+#define EEPROM_Default_TSSI						0x0
+#define EEPROM_Default_BoardType				0x02
+#define EEPROM_Default_ThermalMeter			0x12
+#define EEPROM_Default_ThermalMeter_92SU		0x7
+#define EEPROM_Default_ThermalMeter_88E		0x18
+#define EEPROM_Default_ThermalMeter_8812		0x18
+#define	EEPROM_Default_ThermalMeter_8192E			0x1A
+#define	EEPROM_Default_ThermalMeter_8723B		0x18
+#define	EEPROM_Default_ThermalMeter_8703B		0x18
+#define	EEPROM_Default_ThermalMeter_8723D		0x18
+#define	EEPROM_Default_ThermalMeter_8188F		0x18
+#define EEPROM_Default_ThermalMeter_8814A		0x18
+
+
+#define EEPROM_Default_CrystalCap				0x0
+#define EEPROM_Default_CrystalCap_8723A		0x20
+#define EEPROM_Default_CrystalCap_88E			0x20
+#define EEPROM_Default_CrystalCap_8812			0x20
+#define EEPROM_Default_CrystalCap_8814			0x20
+#define EEPROM_Default_CrystalCap_8192E			0x20
+#define EEPROM_Default_CrystalCap_8723B			0x20
+#define EEPROM_Default_CrystalCap_8703B			0x20
+#define EEPROM_Default_CrystalCap_8723D			0x20
+#define EEPROM_Default_CrystalCap_8188F			0x20
+#define EEPROM_Default_CrystalFreq				0x0
+#define EEPROM_Default_TxPowerLevel_92C		0x22
+#define EEPROM_Default_TxPowerLevel_2G			0x2C
+#define EEPROM_Default_TxPowerLevel_5G			0x22
+#define EEPROM_Default_TxPowerLevel			0x22
+#define EEPROM_Default_HT40_2SDiff				0x0
+#define EEPROM_Default_HT20_Diff				2
+#define EEPROM_Default_LegacyHTTxPowerDiff		0x3
+#define EEPROM_Default_LegacyHTTxPowerDiff_92C	0x3
+#define EEPROM_Default_LegacyHTTxPowerDiff_92D	0x4
+#define EEPROM_Default_HT40_PwrMaxOffset		0
+#define EEPROM_Default_HT20_PwrMaxOffset		0
+
+#define EEPROM_Default_PID						0x1234
+#define EEPROM_Default_VID						0x5678
+#define EEPROM_Default_CustomerID				0xAB
+#define EEPROM_Default_CustomerID_8188E		0x00
+#define EEPROM_Default_SubCustomerID			0xCD
+#define EEPROM_Default_Version					0
+
+#define EEPROM_Default_externalPA_C9		0x00
+#define EEPROM_Default_externalPA_CC		0xFF
+#define EEPROM_Default_internalPA_SP3T_C9	0xAA
+#define EEPROM_Default_internalPA_SP3T_CC	0xAF
+#define EEPROM_Default_internalPA_SPDT_C9	0xAA
+#ifdef CONFIG_PCI_HCI
+	#define EEPROM_Default_internalPA_SPDT_CC	0xA0
+#else
+	#define EEPROM_Default_internalPA_SPDT_CC	0xFA
+#endif
+#define EEPROM_Default_PAType						0
+#define EEPROM_Default_LNAType						0
+
+/* New EFUSE default value */
+#define EEPROM_DEFAULT_CHANNEL_PLAN		0x7F
+#define EEPROM_DEFAULT_BOARD_OPTION		0x00
+#define EEPROM_DEFAULT_RFE_OPTION_8192E 0xFF
+#define EEPROM_DEFAULT_RFE_OPTION_8188E 0xFF
+#define EEPROM_DEFAULT_RFE_OPTION		0x04
+#define EEPROM_DEFAULT_FEATURE_OPTION	0x00
+#define EEPROM_DEFAULT_BT_OPTION			0x10
+
+
+#define EEPROM_DEFAULT_TX_CALIBRATE_RATE	0x00
+
+/* PCIe related */
+#define	EEPROM_PCIE_DEV_CAP_01				0xE0 /* Express device capability in PCIe configuration space, i.e., map to offset 0x74 */
+#define	EEPROM_PCIE_DEV_CAP_02				0xE1 /* Express device capability in PCIe configuration space, i.e., map to offset 0x75 */
+
+
+/*
+ * For VHT series TX power by rate table.
+ * VHT TX power by rate off setArray =
+ * Band:-2G&5G = 0 / 1
+ * RF: at most 4*4 = ABCD=0/1/2/3
+ * CCK=0 OFDM=1/2 HT-MCS 0-15=3/4/56 VHT=7/8/9/10/11
+ *   */
+#define TX_PWR_BY_RATE_NUM_BAND			2
+#define TX_PWR_BY_RATE_NUM_RF			4
+#define TX_PWR_BY_RATE_NUM_RATE			84
+
+#define TXPWR_LMT_MAX_RF				4
+
+/* ----------------------------------------------------------------------------
+ * EEPROM/EFUSE data structure definition.
+ * ---------------------------------------------------------------------------- */
+
+/* For 88E new structure */
+
+/*
+2.4G:
+{
+{1,2},
+{3,4,5},
+{6,7,8},
+{9,10,11},
+{12,13},
+{14}
+}
+
+5G:
+{
+{36,38,40},
+{44,46,48},
+{52,54,56},
+{60,62,64},
+{100,102,104},
+{108,110,112},
+{116,118,120},
+{124,126,128},
+{132,134,136},
+{140,142,144},
+{149,151,153},
+{157,159,161},
+{173,175,177},
+}
+*/
+#define	MAX_RF_PATH				4
+#define RF_PATH_MAX				MAX_RF_PATH
+#define	MAX_CHNL_GROUP_24G		6
+#define	MAX_CHNL_GROUP_5G		14
+
+/* It must always set to 4, otherwise read efuse table sequence will be wrong. */
+#define	MAX_TX_COUNT				4
+
+typedef struct _TxPowerInfo24G {
+	u8 IndexCCK_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];
+	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];
+	/* If only one tx, only BW20 and OFDM are used. */
+	s8 CCK_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+} TxPowerInfo24G, *PTxPowerInfo24G;
+
+typedef struct _TxPowerInfo5G {
+	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_5G];
+	/* If only one tx, only BW20, OFDM, BW80 and BW160 are used. */
+	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW80_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW160_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+} TxPowerInfo5G, *PTxPowerInfo5G;
+
+
+typedef	enum _BT_Ant_NUM {
+	Ant_x2	= 0,
+	Ant_x1	= 1
+} BT_Ant_NUM, *PBT_Ant_NUM;
+
+typedef	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,
+	BT_RTL8821		= 7,
+	BT_RTL8723B		= 8,
+	BT_RTL8192E		= 9,
+	BT_RTL8814A		= 10,
+	BT_RTL8812A		= 11,
+	BT_RTL8703B		= 12,
+	BT_RTL8822B		= 13,
+	BT_RTL8723D		= 14,
+	BT_RTL8821C		= 15
+} BT_CoType, *PBT_CoType;
+
+typedef	enum _BT_RadioShared {
+	BT_Radio_Shared	= 0,
+	BT_Radio_Individual	= 1,
+} BT_RadioShared, *PBT_RadioShared;
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_phy.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_phy.h
new file mode 100644
index 000000000000..342613be1c1d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_phy.h
@@ -0,0 +1,234 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PHY_H__
+#define __HAL_PHY_H__
+
+
+#if DISABLE_BB_RF
+	#define	HAL_FW_ENABLE				0
+	#define	HAL_MAC_ENABLE			0
+	#define	HAL_BB_ENABLE				0
+	#define	HAL_RF_ENABLE				0
+#else /* FPGA_PHY and ASIC */
+	#define	HAL_FW_ENABLE				1
+	#define	HAL_MAC_ENABLE			1
+	#define	HAL_BB_ENABLE				1
+	#define	HAL_RF_ENABLE				1
+#endif
+
+#define	RF6052_MAX_TX_PWR			0x3F
+#define	RF6052_MAX_REG_88E			0xFF
+#define	RF6052_MAX_REG_92C			0x7F
+
+#define	RF6052_MAX_REG	\
+	((RF6052_MAX_REG_88E > RF6052_MAX_REG_92C) ? RF6052_MAX_REG_88E : RF6052_MAX_REG_92C)
+
+#define GET_RF6052_REAL_MAX_REG(_Adapter)	\
+	(IS_HARDWARE_TYPE_8188E(_Adapter) ? RF6052_MAX_REG_88E : RF6052_MAX_REG_92C)
+
+#define	RF6052_MAX_PATH				2
+
+/*
+ * Antenna detection method, i.e., using single tone detection or RSSI reported from each antenna detected.
+ * Added by Roger, 2013.05.22.
+ *   */
+#define ANT_DETECT_BY_SINGLE_TONE	BIT0
+#define ANT_DETECT_BY_RSSI				BIT1
+#define IS_ANT_DETECT_SUPPORT_SINGLE_TONE(__Adapter)		((GET_HAL_DATA(__Adapter)->AntDetection) & ANT_DETECT_BY_SINGLE_TONE)
+#define IS_ANT_DETECT_SUPPORT_RSSI(__Adapter)		((GET_HAL_DATA(__Adapter)->AntDetection) & ANT_DETECT_BY_RSSI)
+
+
+/*--------------------------Define Parameters-------------------------------*/
+typedef	enum _RF_CHIP {
+	RF_CHIP_MIN = 0,	/* 0 */
+	RF_8225 = 1,			/* 1 11b/g RF for verification only */
+	RF_8256 = 2,			/* 2 11b/g/n */
+	RF_8258 = 3,			/* 3 11a/b/g/n RF */
+	RF_6052 = 4,			/* 4 11b/g/n RF */
+	RF_PSEUDO_11N = 5,	/* 5, It is a temporality RF. */
+	RF_CHIP_MAX
+} RF_CHIP_E, *PRF_CHIP_E;
+
+typedef enum _ANTENNA_PATH {
+	ANTENNA_NONE	= 0,
+	ANTENNA_D		= 1,
+	ANTENNA_C		= 2,
+	ANTENNA_CD	= 3,
+	ANTENNA_B		= 4,
+	ANTENNA_BD	= 5,
+	ANTENNA_BC	= 6,
+	ANTENNA_BCD	= 7,
+	ANTENNA_A		= 8,
+	ANTENNA_AD	= 9,
+	ANTENNA_AC	= 10,
+	ANTENNA_ACD	= 11,
+	ANTENNA_AB	= 12,
+	ANTENNA_ABD	= 13,
+	ANTENNA_ABC	= 14,
+	ANTENNA_ABCD	= 15
+} ANTENNA_PATH;
+
+typedef enum _RF_CONTENT {
+	radioa_txt = 0x1000,
+	radiob_txt = 0x1001,
+	radioc_txt = 0x1002,
+	radiod_txt = 0x1003
+} RF_CONTENT;
+
+typedef enum _BaseBand_Config_Type {
+	BaseBand_Config_PHY_REG = 0,			/* Radio Path A */
+	BaseBand_Config_AGC_TAB = 1,			/* Radio Path B */
+	BaseBand_Config_AGC_TAB_2G = 2,
+	BaseBand_Config_AGC_TAB_5G = 3,
+	BaseBand_Config_PHY_REG_PG
+} BaseBand_Config_Type, *PBaseBand_Config_Type;
+
+typedef enum _HW_BLOCK {
+	HW_BLOCK_MAC = 0,
+	HW_BLOCK_PHY0 = 1,
+	HW_BLOCK_PHY1 = 2,
+	HW_BLOCK_RF = 3,
+	HW_BLOCK_MAXIMUM = 4, /* Never use this */
+} HW_BLOCK_E, *PHW_BLOCK_E;
+
+typedef enum _WIRELESS_MODE {
+	WIRELESS_MODE_UNKNOWN = 0x00,
+	WIRELESS_MODE_A = 0x01,
+	WIRELESS_MODE_B = 0x02,
+	WIRELESS_MODE_G = 0x04,
+	WIRELESS_MODE_AUTO = 0x08,
+	WIRELESS_MODE_N_24G = 0x10,
+	WIRELESS_MODE_N_5G = 0x20,
+	WIRELESS_MODE_AC_5G = 0x40,
+	WIRELESS_MODE_AC_24G  = 0x80,
+	WIRELESS_MODE_AC_ONLY  = 0x100,
+} WIRELESS_MODE;
+
+typedef enum _SwChnlCmdID {
+	CmdID_End,
+	CmdID_SetTxPowerLevel,
+	CmdID_BBRegWrite10,
+	CmdID_WritePortUlong,
+	CmdID_WritePortUshort,
+	CmdID_WritePortUchar,
+	CmdID_RF_WriteReg,
+} SwChnlCmdID;
+
+typedef struct _SwChnlCmd {
+	SwChnlCmdID	CmdID;
+	u32				Para1;
+	u32				Para2;
+	u32				msDelay;
+} SwChnlCmd;
+
+typedef struct _R_ANTENNA_SELECT_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;
+} R_ANTENNA_SELECT_OFDM;
+
+typedef struct _R_ANTENNA_SELECT_CCK {
+	u8			r_cckrx_enable_2:2;
+	u8			r_cckrx_enable:2;
+	u8			r_ccktx_enable:4;
+} R_ANTENNA_SELECT_CCK;
+
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_CalculateBitShift(
+	u32 BitMask
+);
+
+#ifdef CONFIG_RF_SHADOW_RW
+typedef struct RF_Shadow_Compare_Map {
+	/* Shadow register value */
+	u32		Value;
+	/* Compare or not flag */
+	u8		Compare;
+	/* Record If it had ever modified unpredicted */
+	u8		ErrorOrNot;
+	/* Recorver Flag */
+	u8		Recorver;
+	/*  */
+	u8		Driver_Write;
+} RF_SHADOW_T;
+
+u32
+PHY_RFShadowRead(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				Offset);
+
+VOID
+PHY_RFShadowWrite(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				Offset,
+	IN	u32				Data);
+
+BOOLEAN
+PHY_RFShadowCompare(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				Offset);
+
+VOID
+PHY_RFShadowRecorver(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				Offset);
+
+VOID
+PHY_RFShadowCompareAll(
+	IN	PADAPTER		Adapter);
+
+VOID
+PHY_RFShadowRecorverAll(
+	IN	PADAPTER		Adapter);
+
+VOID
+PHY_RFShadowCompareFlagSet(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				Offset,
+	IN	u8				Type);
+
+VOID
+PHY_RFShadowRecorverFlagSet(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				Offset,
+	IN	u8				Type);
+
+VOID
+PHY_RFShadowCompareFlagSetAll(
+	IN	PADAPTER		Adapter);
+
+VOID
+PHY_RFShadowRecorverFlagSetAll(
+	IN	PADAPTER		Adapter);
+
+VOID
+PHY_RFShadowRefresh(
+	IN	PADAPTER		Adapter);
+#endif /*#CONFIG_RF_SHADOW_RW*/
+#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_phy_reg.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_phy_reg.h
new file mode 100644
index 000000000000..6e6a99e61272
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_phy_reg.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PHY_REG_H__
+#define __HAL_PHY_REG_H__
+
+/* for PutRFRegsetting & GetRFRegSetting BitMask
+ * #if (RTL92SE_FPGA_VERIFY == 1)
+ * #define		bRFRegOffsetMask	0xfff
+ * #else */
+#define		bRFRegOffsetMask	0xfffff
+/* #endif */
+
+#endif /* __HAL_PHY_REG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_sdio.h
new file mode 100644
index 000000000000..3c22eb9b9993
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/hal_sdio.h
@@ -0,0 +1,31 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_SDIO_H_
+#define __HAL_SDIO_H_
+
+#define ffaddr2deviceId(pdvobj, addr)	(pdvobj->Queue2Pipe[addr])
+
+u8 rtw_hal_sdio_max_txoqt_free_space(_adapter *padapter);
+u8 rtw_hal_sdio_query_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum);
+void rtw_hal_sdio_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum);
+void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
+u32 rtw_hal_get_sdio_tx_max_length(PADAPTER padapter, u8 queue_idx);
+bool sdio_power_on_check(PADAPTER padapter);
+
+#ifdef CONFIG_FW_C2H_REG
+void sd_c2h_hisr_hdl(_adapter *adapter);
+#endif
+
+#endif /* __HAL_SDIO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ieee80211.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ieee80211.h
new file mode 100644
index 000000000000..5ba92b53cee7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ieee80211.h
@@ -0,0 +1,2116 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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
+
+
+#ifndef CONFIG_RTL8711FW
+
+	#if defined PLATFORM_OS_XP
+		#include <ntstrsafe.h>
+	#endif
+#else
+
+#endif
+
+#define MGMT_QUEUE_NUM 5
+
+#define ETH_ALEN	6
+#define ETH_TYPE_LEN		2
+#define PAYLOAD_TYPE_LEN	1
+
+#define NET80211_TU_TO_US	1024		/* unit:us */
+#define DEFAULT_BCN_INTERVAL 100 /* 100 ms */
+
+#ifdef CONFIG_AP_MODE
+
+#define RTL_IOCTL_HOSTAPD (SIOCIWFIRSTPRIV + 28)
+
+/* RTL871X_IOCTL_HOSTAPD ioctl() cmd: */
+enum {
+	RTL871X_HOSTAPD_FLUSH = 1,
+	RTL871X_HOSTAPD_ADD_STA = 2,
+	RTL871X_HOSTAPD_REMOVE_STA = 3,
+	RTL871X_HOSTAPD_GET_INFO_STA = 4,
+	/* REMOVED: PRISM2_HOSTAPD_RESET_TXEXC_STA = 5, */
+	RTL871X_HOSTAPD_GET_WPAIE_STA = 5,
+	RTL871X_SET_ENCRYPTION = 6,
+	RTL871X_GET_ENCRYPTION = 7,
+	RTL871X_HOSTAPD_SET_FLAGS_STA = 8,
+	RTL871X_HOSTAPD_GET_RID = 9,
+	RTL871X_HOSTAPD_SET_RID = 10,
+	RTL871X_HOSTAPD_SET_ASSOC_AP_ADDR = 11,
+	RTL871X_HOSTAPD_SET_GENERIC_ELEMENT = 12,
+	RTL871X_HOSTAPD_MLME = 13,
+	RTL871X_HOSTAPD_SCAN_REQ = 14,
+	RTL871X_HOSTAPD_STA_CLEAR_STATS = 15,
+	RTL871X_HOSTAPD_SET_BEACON = 16,
+	RTL871X_HOSTAPD_SET_WPS_BEACON = 17,
+	RTL871X_HOSTAPD_SET_WPS_PROBE_RESP = 18,
+	RTL871X_HOSTAPD_SET_WPS_ASSOC_RESP = 19,
+	RTL871X_HOSTAPD_SET_HIDDEN_SSID = 20,
+	RTL871X_HOSTAPD_SET_MACADDR_ACL = 21,
+	RTL871X_HOSTAPD_ACL_ADD_STA = 22,
+	RTL871X_HOSTAPD_ACL_REMOVE_STA = 23,
+};
+
+/* 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_VHT BIT(14)
+#define WLAN_STA_NONERP BIT(31)
+
+#endif
+
+#define IEEE_CMD_SET_WPA_PARAM			1
+#define IEEE_CMD_SET_WPA_IE				2
+#define IEEE_CMD_SET_ENCRYPTION			3
+#define IEEE_CMD_MLME						4
+
+#define IEEE_PARAM_WPA_ENABLED				1
+#define IEEE_PARAM_TKIP_COUNTERMEASURES		2
+#define IEEE_PARAM_DROP_UNENCRYPTED			3
+#define IEEE_PARAM_PRIVACY_INVOKED			4
+#define IEEE_PARAM_AUTH_ALGS					5
+#define IEEE_PARAM_IEEE_802_1X				6
+#define IEEE_PARAM_WPAX_SELECT				7
+
+#define AUTH_ALG_OPEN_SYSTEM			0x1
+#define AUTH_ALG_SHARED_KEY			0x2
+#define AUTH_ALG_LEAP				0x00000004
+
+#define IEEE_MLME_STA_DEAUTH				1
+#define IEEE_MLME_STA_DISASSOC			2
+
+#define IEEE_CRYPT_ERR_UNKNOWN_ALG			2
+#define IEEE_CRYPT_ERR_UNKNOWN_ADDR			3
+#define IEEE_CRYPT_ERR_CRYPT_INIT_FAILED		4
+#define IEEE_CRYPT_ERR_KEY_SET_FAILED			5
+#define IEEE_CRYPT_ERR_TX_KEY_SET_FAILED		6
+#define IEEE_CRYPT_ERR_CARD_CONF_FAILED		7
+
+
+#define	IEEE_CRYPT_ALG_NAME_LEN			16
+
+#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_OUI_TYPE[] ;
+extern u16 RTW_WPA_VERSION ;
+extern u8 WPA_AUTH_KEY_MGMT_NONE[];
+extern u8 WPA_AUTH_KEY_MGMT_UNSPEC_802_1X[];
+extern u8 WPA_AUTH_KEY_MGMT_PSK_OVER_802_1X[];
+extern u8 WPA_CIPHER_SUITE_NONE[];
+extern u8 WPA_CIPHER_SUITE_WEP40[];
+extern u8 WPA_CIPHER_SUITE_TKIP[];
+extern u8 WPA_CIPHER_SUITE_WRAP[];
+extern u8 WPA_CIPHER_SUITE_CCMP[];
+extern u8 WPA_CIPHER_SUITE_WEP104[];
+
+
+#define RSN_HEADER_LEN 4
+#define RSN_SELECTOR_LEN 4
+
+extern u16 RSN_VERSION_BSD;
+extern u8 RSN_AUTH_KEY_MGMT_UNSPEC_802_1X[];
+extern u8 RSN_AUTH_KEY_MGMT_PSK_OVER_802_1X[];
+extern u8 RSN_CIPHER_SUITE_NONE[];
+extern u8 RSN_CIPHER_SUITE_WEP40[];
+extern u8 RSN_CIPHER_SUITE_TKIP[];
+extern u8 RSN_CIPHER_SUITE_WRAP[];
+extern u8 RSN_CIPHER_SUITE_CCMP[];
+extern u8 RSN_CIPHER_SUITE_WEP104[];
+
+
+typedef enum _RATEID_IDX_ {
+	RATEID_IDX_BGN_40M_2SS = 0,
+	RATEID_IDX_BGN_40M_1SS = 1,
+	RATEID_IDX_BGN_20M_2SS_BN = 2,
+	RATEID_IDX_BGN_20M_1SS_BN = 3,
+	RATEID_IDX_GN_N2SS = 4,
+	RATEID_IDX_GN_N1SS = 5,
+	RATEID_IDX_BG = 6,
+	RATEID_IDX_G = 7,
+	RATEID_IDX_B = 8,
+	RATEID_IDX_VHT_2SS = 9,
+	RATEID_IDX_VHT_1SS = 10,
+	RATEID_IDX_MIX1 = 11,
+	RATEID_IDX_MIX2 = 12,
+	RATEID_IDX_VHT_3SS = 13,
+	RATEID_IDX_BGN_3SS = 14,
+} RATEID_IDX, *PRATEID_IDX;
+
+typedef 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,
+} RATR_TABLE_MODE, *PRATR_TABLE_MODE;
+
+
+enum NETWORK_TYPE {
+	WIRELESS_INVALID = 0,
+	/* Sub-Element */
+	WIRELESS_11B = BIT(0), /* tx: cck only , rx: cck only, hw: cck */
+	WIRELESS_11G = BIT(1), /* tx: ofdm only, rx: ofdm & cck, hw: cck & ofdm */
+	WIRELESS_11A = BIT(2), /* tx: ofdm only, rx: ofdm only, hw: ofdm only */
+	WIRELESS_11_24N = BIT(3), /* tx: MCS only, rx: MCS & cck, hw: MCS & cck */
+	WIRELESS_11_5N = BIT(4), /* tx: MCS only, rx: MCS & ofdm, hw: ofdm only */
+	WIRELESS_AUTO = BIT(5),
+	WIRELESS_11AC = BIT(6),
+
+	/* Combination */
+	/* Type for current wireless mode */
+	WIRELESS_11BG = (WIRELESS_11B | WIRELESS_11G), /* tx: cck & ofdm, rx: cck & ofdm & MCS, hw: cck & ofdm */
+	WIRELESS_11G_24N = (WIRELESS_11G | WIRELESS_11_24N), /* tx: ofdm & MCS, rx: ofdm & cck & MCS, hw: cck & ofdm */
+	WIRELESS_11A_5N = (WIRELESS_11A | WIRELESS_11_5N), /* tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only */
+	WIRELESS_11B_24N = (WIRELESS_11B | WIRELESS_11_24N), /* tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck */
+	WIRELESS_11BG_24N = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N), /* tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck */
+	WIRELESS_11_24AC = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11AC),
+	WIRELESS_11_5AC = (WIRELESS_11A | WIRELESS_11AC),
+
+
+	/* Type for registry default wireless mode */
+	WIRELESS_11AGN = (WIRELESS_11A | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N), /* tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only */
+	WIRELESS_11ABGN = (WIRELESS_11A | WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N),
+	WIRELESS_MODE_24G = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N),
+	WIRELESS_MODE_5G = (WIRELESS_11A | WIRELESS_11_5N | WIRELESS_11AC),
+	WIRELESS_MODE_MAX = (WIRELESS_11A | WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N | WIRELESS_11AC),
+};
+
+#define SUPPORTED_24G_NETTYPE_MSK WIRELESS_MODE_24G
+#define SUPPORTED_5G_NETTYPE_MSK WIRELESS_MODE_5G
+
+#define IsLegacyOnly(NetType)  ((NetType) == ((NetType) & (WIRELESS_11BG | WIRELESS_11A)))
+
+#define IsSupported24G(NetType) ((NetType) & SUPPORTED_24G_NETTYPE_MSK ? _TRUE : _FALSE)
+#define is_supported_5g(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 IsSupportedRxHT(NetType) IsEnableHWOFDM(NetType)
+
+#define IsSupportedTxCCK(NetType) ((NetType) & (WIRELESS_11B) ? _TRUE : _FALSE)
+#define IsSupportedTxOFDM(NetType) ((NetType) & (WIRELESS_11G | WIRELESS_11A) ? _TRUE : _FALSE)
+#define is_supported_ht(NetType) ((NetType) & (WIRELESS_11_24N | WIRELESS_11_5N) ? _TRUE : _FALSE)
+
+#define is_supported_vht(NetType) ((NetType) & (WIRELESS_11AC) ? _TRUE : _FALSE)
+
+
+
+
+
+typedef struct ieee_param {
+	u32 cmd;
+	u8 sta_addr[ETH_ALEN];
+	union {
+		struct {
+			u8 name;
+			u32 value;
+		} wpa_param;
+		struct {
+			u32 len;
+			u8 reserved[32];
+			u8 data[0];
+		} wpa_ie;
+		struct {
+			int command;
+			int reason_code;
+		} mlme;
+		struct {
+			u8 alg[IEEE_CRYPT_ALG_NAME_LEN];
+			u8 set_tx;
+			u32 err;
+			u8 idx;
+			u8 seq[8]; /* sequence counter (set: RX, get: TX) */
+			u16 key_len;
+			u8 key[0];
+		} crypt;
+#ifdef CONFIG_AP_MODE
+		struct {
+			u16 aid;
+			u16 capability;
+			int flags;
+			u8 tx_supp_rates[16];
+			struct rtw_ieee80211_ht_cap ht_cap;
+		} add_sta;
+		struct {
+			u8	reserved[2];/* for set max_num_sta */
+			u8	buf[0];
+		} bcn_ie;
+#endif
+
+	} u;
+} ieee_param;
+
+#ifdef CONFIG_AP_MODE
+typedef struct ieee_param_ex {
+	u32 cmd;
+	u8 sta_addr[ETH_ALEN];
+	u8 data[0];
+} ieee_param_ex;
+
+struct sta_data {
+	u16 aid;
+	u16 capability;
+	int flags;
+	u32 sta_set;
+	u8 tx_supp_rates[16];
+	u32 tx_supp_rates_len;
+	struct rtw_ieee80211_ht_cap ht_cap;
+	u64	rx_pkts;
+	u64	rx_bytes;
+	u64	rx_drops;
+	u64	tx_pkts;
+	u64	tx_bytes;
+	u64	tx_drops;
+};
+#endif
+
+
+#if WIRELESS_EXT < 17
+	#define IW_QUAL_QUAL_INVALID   0x10
+	#define IW_QUAL_LEVEL_INVALID  0x20
+	#define IW_QUAL_NOISE_INVALID  0x40
+	#define IW_QUAL_QUAL_UPDATED   0x1
+	#define IW_QUAL_LEVEL_UPDATED  0x2
+	#define IW_QUAL_NOISE_UPDATED  0x4
+#endif
+
+#define IEEE80211_DATA_LEN		2304
+/* Maximum size for the MA-UNITDATA primitive, 802.11 standard section
+   6.2.1.1.2.
+
+   The figure in section 7.1.2 suggests a body size of up to 2312
+   bytes is allowed, which is a bit confusing, I suspect this
+   represents the 2304 bytes of real data, plus a possible 8 bytes of
+   WEP IV and ICV. (this interpretation suggested by Ramiro Barreiro) */
+
+
+#define IEEE80211_HLEN			30
+#define IEEE80211_FRAME_LEN		(IEEE80211_DATA_LEN + IEEE80211_HLEN)
+
+
+/* this is stolen from ipw2200 driver */
+#define IEEE_IBSS_MAC_HASH_SIZE 31
+
+struct ieee_ibss_seq {
+	u8 mac[ETH_ALEN];
+	u16 seq_num;
+	u16 frag_num;
+	unsigned long packet_time;
+	_list	list;
+};
+
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW) || defined(PLATFORM_FREEBSD)
+
+struct rtw_ieee80211_hdr {
+	u16 frame_ctl;
+	u16 duration_id;
+	u8 addr1[ETH_ALEN];
+	u8 addr2[ETH_ALEN];
+	u8 addr3[ETH_ALEN];
+	u16 seq_ctl;
+	u8 addr4[ETH_ALEN];
+} __attribute__((packed));
+
+struct rtw_ieee80211_hdr_3addr {
+	u16 frame_ctl;
+	u16 duration_id;
+	u8 addr1[ETH_ALEN];
+	u8 addr2[ETH_ALEN];
+	u8 addr3[ETH_ALEN];
+	u16 seq_ctl;
+} __attribute__((packed));
+
+
+struct rtw_ieee80211_hdr_qos {
+	u16 frame_ctl;
+	u16 duration_id;
+	u8 addr1[ETH_ALEN];
+	u8 addr2[ETH_ALEN];
+	u8 addr3[ETH_ALEN];
+	u16 seq_ctl;
+	u8 addr4[ETH_ALEN];
+	u16	qc;
+}  __attribute__((packed));
+
+struct rtw_ieee80211_hdr_3addr_qos {
+	u16 frame_ctl;
+	u16 duration_id;
+	u8 addr1[ETH_ALEN];
+	u8 addr2[ETH_ALEN];
+	u8 addr3[ETH_ALEN];
+	u16 seq_ctl;
+	u16     qc;
+}  __attribute__((packed));
+
+struct eapol {
+	u8 snap[6];
+	u16 ethertype;
+	u8 version;
+	u8 type;
+	u16 length;
+} __attribute__((packed));
+
+struct rtw_ieee80211s_hdr {
+	u8 flags;
+	u8 ttl;
+	u32 seqnum;
+	u8 eaddr1[ETH_ALEN];
+	u8 eaddr2[ETH_ALEN];
+} __attribute__((packed));
+
+/**
+ * struct rtw_ieee80211_rann_ie
+ *
+ * This structure refers to "Root Announcement information element"
+ */
+ struct rtw_ieee80211_rann_ie {
+	u8 rann_flags;
+	u8 rann_hopcount;
+	u8 rann_ttl;
+	u8 rann_addr[ETH_ALEN];
+	u32 rann_seq;
+	u32 rann_interval;
+	u32 rann_metric;
+} __attribute__((packed));
+#endif
+
+
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+struct rtw_ieee80211_hdr {
+	u16 frame_ctl;
+	u16 duration_id;
+	u8 addr1[ETH_ALEN];
+	u8 addr2[ETH_ALEN];
+	u8 addr3[ETH_ALEN];
+	u16 seq_ctl;
+	u8 addr4[ETH_ALEN];
+};
+
+struct rtw_ieee80211_hdr_3addr {
+	u16 frame_ctl;
+	u16 duration_id;
+	u8 addr1[ETH_ALEN];
+	u8 addr2[ETH_ALEN];
+	u8 addr3[ETH_ALEN];
+	u16 seq_ctl;
+};
+
+
+struct rtw_ieee80211_hdr_qos {
+	struct rtw_ieee80211_hdr wlan_hdr;
+	u16	qc;
+};
+
+struct rtw_ieee80211_hdr_3addr_qos {
+	struct  rtw_ieee80211_hdr_3addr wlan_hdr;
+	u16     qc;
+};
+
+struct eapol {
+	u8 snap[6];
+	u16 ethertype;
+	u8 version;
+	u8 type;
+	u16 length;
+};
+#pragma pack()
+
+#endif
+
+
+
+enum eap_type {
+	EAP_PACKET = 0,
+	EAPOL_START,
+	EAPOL_LOGOFF,
+	EAPOL_KEY,
+	EAPOL_ENCAP_ASF_ALERT
+};
+
+#define IEEE80211_3ADDR_LEN 24
+#define IEEE80211_4ADDR_LEN 30
+#define IEEE80211_FCS_LEN    4
+
+#define MIN_FRAG_THRESHOLD     256U
+#define	MAX_FRAG_THRESHOLD     2346U
+
+/* Frame control field constants */
+#define RTW_IEEE80211_FCTL_VERS		0x0003
+#define RTW_IEEE80211_FCTL_FTYPE		0x000c
+#define RTW_IEEE80211_FCTL_STYPE		0x00f0
+#define RTW_IEEE80211_FCTL_TODS		0x0100
+#define RTW_IEEE80211_FCTL_FROMDS	0x0200
+#define RTW_IEEE80211_FCTL_MOREFRAGS	0x0400
+#define RTW_IEEE80211_FCTL_RETRY		0x0800
+#define RTW_IEEE80211_FCTL_PM		0x1000
+#define RTW_IEEE80211_FCTL_MOREDATA	0x2000
+#define RTW_IEEE80211_FCTL_PROTECTED	0x4000
+#define RTW_IEEE80211_FCTL_ORDER		0x8000
+#define RTW_IEEE80211_FCTL_CTL_EXT	0x0f00
+
+#define RTW_IEEE80211_FTYPE_MGMT		0x0000
+#define RTW_IEEE80211_FTYPE_CTL		0x0004
+#define RTW_IEEE80211_FTYPE_DATA		0x0008
+#define RTW_IEEE80211_FTYPE_EXT		0x000c
+
+/* management */
+#define RTW_IEEE80211_STYPE_ASSOC_REQ	0x0000
+#define RTW_IEEE80211_STYPE_ASSOC_RESP	0x0010
+#define RTW_IEEE80211_STYPE_REASSOC_REQ	0x0020
+#define RTW_IEEE80211_STYPE_REASSOC_RESP	0x0030
+#define RTW_IEEE80211_STYPE_PROBE_REQ	0x0040
+#define RTW_IEEE80211_STYPE_PROBE_RESP	0x0050
+#define RTW_IEEE80211_STYPE_BEACON		0x0080
+#define RTW_IEEE80211_STYPE_ATIM		0x0090
+#define RTW_IEEE80211_STYPE_DISASSOC	0x00A0
+#define RTW_IEEE80211_STYPE_AUTH		0x00B0
+#define RTW_IEEE80211_STYPE_DEAUTH		0x00C0
+#define RTW_IEEE80211_STYPE_ACTION		0x00D0
+
+/* control */
+#define RTW_IEEE80211_STYPE_CTL_EXT		0x0060
+#define RTW_IEEE80211_STYPE_BACK_REQ		0x0080
+#define RTW_IEEE80211_STYPE_BACK		0x0090
+#define RTW_IEEE80211_STYPE_PSPOLL		0x00A0
+#define RTW_IEEE80211_STYPE_RTS		0x00B0
+#define RTW_IEEE80211_STYPE_CTS		0x00C0
+#define RTW_IEEE80211_STYPE_ACK		0x00D0
+#define RTW_IEEE80211_STYPE_CFEND		0x00E0
+#define RTW_IEEE80211_STYPE_CFENDACK		0x00F0
+
+/* data */
+#define RTW_IEEE80211_STYPE_DATA		0x0000
+#define RTW_IEEE80211_STYPE_DATA_CFACK	0x0010
+#define RTW_IEEE80211_STYPE_DATA_CFPOLL	0x0020
+#define RTW_IEEE80211_STYPE_DATA_CFACKPOLL	0x0030
+#define RTW_IEEE80211_STYPE_NULLFUNC	0x0040
+#define RTW_IEEE80211_STYPE_CFACK		0x0050
+#define RTW_IEEE80211_STYPE_CFPOLL		0x0060
+#define RTW_IEEE80211_STYPE_CFACKPOLL	0x0070
+#define RTW_IEEE80211_STYPE_QOS_DATA		0x0080
+#define RTW_IEEE80211_STYPE_QOS_DATA_CFACK		0x0090
+#define RTW_IEEE80211_STYPE_QOS_DATA_CFPOLL		0x00A0
+#define RTW_IEEE80211_STYPE_QOS_DATA_CFACKPOLL	0x00B0
+#define RTW_IEEE80211_STYPE_QOS_NULLFUNC	0x00C0
+#define RTW_IEEE80211_STYPE_QOS_CFACK		0x00D0
+#define RTW_IEEE80211_STYPE_QOS_CFPOLL		0x00E0
+#define RTW_IEEE80211_STYPE_QOS_CFACKPOLL	0x00F0
+
+/* sequence control field */
+#define RTW_IEEE80211_SCTL_FRAG	0x000F
+#define RTW_IEEE80211_SCTL_SEQ	0xFFF0
+
+
+#define RTW_ERP_INFO_NON_ERP_PRESENT BIT(0)
+#define RTW_ERP_INFO_USE_PROTECTION BIT(1)
+#define RTW_ERP_INFO_BARKER_PREAMBLE_MODE BIT(2)
+
+/* QoS,QOS */
+#define NORMAL_ACK			0
+#define NO_ACK				1
+#define NON_EXPLICIT_ACK	2
+#define BLOCK_ACK			3
+
+#ifndef ETH_P_PAE
+	#define ETH_P_PAE 0x888E /* Port Access Entity (IEEE 802.1X) */
+#endif /* ETH_P_PAE */
+
+#define ETH_P_PREAUTH 0x88C7 /* IEEE 802.11i pre-authentication */
+
+#define ETH_P_ECONET	0x0018
+
+#ifndef ETH_P_80211_RAW
+	#define ETH_P_80211_RAW (ETH_P_ECONET + 1)
+#endif
+
+/* IEEE 802.11 defines */
+
+#define P80211_OUI_LEN 3
+
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW) || defined(PLATFORM_FREEBSD)
+
+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));
+
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+struct ieee80211_snap_hdr {
+
+	u8    dsap;   /* always 0xAA */
+	u8    ssap;   /* always 0xAA */
+	u8    ctrl;   /* always 0x03 */
+	u8    oui[P80211_OUI_LEN];    /* organizational universal id */
+
+};
+#pragma pack()
+
+#endif
+
+
+#define SNAP_SIZE sizeof(struct ieee80211_snap_hdr)
+
+#define WLAN_FC_GET_TYPE(fc) ((fc) & RTW_IEEE80211_FCTL_FTYPE)
+#define WLAN_FC_GET_STYPE(fc) ((fc) & RTW_IEEE80211_FCTL_STYPE)
+
+#define WLAN_QC_GET_TID(qc) ((qc) & 0x0f)
+
+#define WLAN_GET_SEQ_FRAG(seq) ((seq) & RTW_IEEE80211_SCTL_FRAG)
+#define WLAN_GET_SEQ_SEQ(seq)  ((seq) & RTW_IEEE80211_SCTL_SEQ)
+
+/* Authentication algorithms */
+#define WLAN_AUTH_OPEN 0
+#define WLAN_AUTH_SHARED_KEY 1
+
+#define WLAN_AUTH_CHALLENGE_LEN 128
+
+#define WLAN_CAPABILITY_BSS (1<<0)
+#define WLAN_CAPABILITY_IBSS (1<<1)
+#define WLAN_CAPABILITY_CF_POLLABLE (1<<2)
+#define WLAN_CAPABILITY_CF_POLL_REQUEST (1<<3)
+#define WLAN_CAPABILITY_PRIVACY (1<<4)
+#define WLAN_CAPABILITY_SHORT_PREAMBLE (1<<5)
+#define WLAN_CAPABILITY_PBCC (1<<6)
+#define WLAN_CAPABILITY_CHANNEL_AGILITY (1<<7)
+#define WLAN_CAPABILITY_SHORT_SLOT (1<<10)
+
+/* Status codes */
+#define WLAN_STATUS_SUCCESS 0
+#define WLAN_STATUS_UNSPECIFIED_FAILURE 1
+#define WLAN_STATUS_CAPS_UNSUPPORTED 10
+#define WLAN_STATUS_REASSOC_NO_ASSOC 11
+#define WLAN_STATUS_ASSOC_DENIED_UNSPEC 12
+#define WLAN_STATUS_NOT_SUPPORTED_AUTH_ALG 13
+#define WLAN_STATUS_UNKNOWN_AUTH_TRANSACTION 14
+#define WLAN_STATUS_CHALLENGE_FAIL 15
+#define WLAN_STATUS_AUTH_TIMEOUT 16
+#define WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA 17
+#define WLAN_STATUS_ASSOC_DENIED_RATES 18
+/* 802.11b */
+#define WLAN_STATUS_ASSOC_DENIED_NOSHORT 19
+#define WLAN_STATUS_ASSOC_DENIED_NOPBCC 20
+#define WLAN_STATUS_ASSOC_DENIED_NOAGILITY 21
+
+/* Reason codes */
+#define WLAN_REASON_UNSPECIFIED 1
+#define WLAN_REASON_PREV_AUTH_NOT_VALID 2
+#define WLAN_REASON_DEAUTH_LEAVING 3
+#define WLAN_REASON_DISASSOC_DUE_TO_INACTIVITY 4
+#define WLAN_REASON_DISASSOC_AP_BUSY 5
+#define WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA 6
+#define WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA 7
+#define WLAN_REASON_DISASSOC_STA_HAS_LEFT 8
+#define WLAN_REASON_STA_REQ_ASSOC_WITHOUT_AUTH 9
+#define WLAN_REASON_MESH_PEER_CANCELED 52
+#define WLAN_REASON_MESH_MAX_PEERS 53
+#define WLAN_REASON_MESH_CONFIG 54
+#define WLAN_REASON_MESH_CLOSE 55
+#define WLAN_REASON_MESH_MAX_RETRIES 56 
+#define WLAN_REASON_MESH_CONFIRM_TIMEOUT 57
+#define WLAN_REASON_MESH_INVALID_GTK 58
+#define WLAN_REASON_MESH_INCONSISTENT_PARAM 59
+#define WLAN_REASON_MESH_INVALID_SECURITY 60
+#define WLAN_REASON_MESH_PATH_NOPROXY 61
+#define WLAN_REASON_MESH_PATH_NOFORWARD 62
+#define WLAN_REASON_MESH_PATH_DEST_UNREACHABLE 63
+#define WLAN_REASON_MAC_EXISTS_IN_MBSS 64
+#define WLAN_REASON_MESH_CHAN_REGULATORY 65
+#define WLAN_REASON_MESH_CHAN 66
+#define WLAN_REASON_SA_QUERY_TIMEOUT 65532
+#define WLAN_REASON_ACTIVE_ROAM 65533
+#define WLAN_REASON_JOIN_WRONG_CHANNEL       65534
+#define WLAN_REASON_EXPIRATION_CHK 65535
+
+#define WLAN_REASON_IS_PRIVATE(reason) ( \
+	reason == WLAN_REASON_EXPIRATION_CHK \
+	|| reason == WLAN_REASON_JOIN_WRONG_CHANNEL \
+	|| reason == WLAN_REASON_ACTIVE_ROAM \
+	|| reason == WLAN_REASON_SA_QUERY_TIMEOUT \
+	)
+
+/* Information Element IDs */
+#define WLAN_EID_SSID 0
+#define WLAN_EID_SUPP_RATES 1
+#define WLAN_EID_FH_PARAMS 2
+#define WLAN_EID_DS_PARAMS 3
+#define WLAN_EID_CF_PARAMS 4
+#define WLAN_EID_TIM 5
+#define WLAN_EID_IBSS_PARAMS 6
+#define WLAN_EID_CHALLENGE 16
+/* EIDs defined by IEEE 802.11h - START */
+#define WLAN_EID_PWR_CONSTRAINT 32
+#define WLAN_EID_PWR_CAPABILITY 33
+#define WLAN_EID_TPC_REQUEST 34
+#define WLAN_EID_TPC_REPORT 35
+#define WLAN_EID_SUPPORTED_CHANNELS 36
+#define WLAN_EID_CHANNEL_SWITCH 37
+#define WLAN_EID_MEASURE_REQUEST 38
+#define WLAN_EID_MEASURE_REPORT 39
+#define WLAN_EID_QUITE 40
+#define WLAN_EID_IBSS_DFS 41
+/* EIDs defined by IEEE 802.11h - END */
+#define WLAN_EID_ERP_INFO 42
+#define WLAN_EID_HT_CAP 45
+#define WLAN_EID_RSN 48
+#define WLAN_EID_EXT_SUPP_RATES 50
+#define WLAN_EID_MOBILITY_DOMAIN 54
+#define WLAN_EID_FAST_BSS_TRANSITION 55
+#define WLAN_EID_TIMEOUT_INTERVAL 56
+#define WLAN_EID_RIC_DATA 57
+#define WLAN_EID_HT_OPERATION 61
+#define WLAN_EID_SECONDARY_CHANNEL_OFFSET 62
+#define WLAN_EID_20_40_BSS_COEXISTENCE 72
+#define WLAN_EID_20_40_BSS_INTOLERANT 73
+#define WLAN_EID_OVERLAPPING_BSS_SCAN_PARAMS 74
+#define WLAN_EID_MMIE 76
+#define WLAN_EID_MESH_CONFIG 113
+#define WLAN_EID_MESH_ID 114
+#define WLAN_EID_MPM 117
+#define	WLAN_EID_RANN 126
+#define	WLAN_EID_PREQ 130
+#define	WLAN_EID_PREP 131
+#define	WLAN_EID_PERR 132
+#define WLAN_EID_AMPE 139
+#define WLAN_EID_MIC 140
+#define WLAN_EID_VENDOR_SPECIFIC 221
+#define WLAN_EID_GENERIC (WLAN_EID_VENDOR_SPECIFIC)
+#define WLAN_EID_VHT_CAPABILITY 191
+#define WLAN_EID_VHT_OPERATION 192
+#define WLAN_EID_VHT_OP_MODE_NOTIFY 199
+
+#define IEEE80211_MGMT_HDR_LEN 24
+#define IEEE80211_DATA_HDR3_LEN 24
+#define IEEE80211_DATA_HDR4_LEN 30
+
+
+#define IEEE80211_STATMASK_SIGNAL (1<<0)
+#define IEEE80211_STATMASK_RSSI (1<<1)
+#define IEEE80211_STATMASK_NOISE (1<<2)
+#define IEEE80211_STATMASK_RATE (1<<3)
+#define IEEE80211_STATMASK_WEMASK 0x7
+
+
+#define IEEE80211_CCK_MODULATION    (1<<0)
+#define IEEE80211_OFDM_MODULATION   (1<<1)
+
+#define IEEE80211_24GHZ_BAND     (1<<0)
+#define IEEE80211_52GHZ_BAND     (1<<1)
+
+#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
+
+
+enum MGN_RATE {
+	MGN_1M		= 0x02,
+	MGN_2M		= 0x04,
+	MGN_5_5M	= 0x0B,
+	MGN_6M		= 0x0C,
+	MGN_9M		= 0x12,
+	MGN_11M	= 0x16,
+	MGN_12M	= 0x18,
+	MGN_18M	= 0x24,
+	MGN_24M	= 0x30,
+	MGN_36M	= 0x48,
+	MGN_48M	= 0x60,
+	MGN_54M	= 0x6C,
+	MGN_MCS32	= 0x7F,
+	MGN_MCS0,
+	MGN_MCS1,
+	MGN_MCS2,
+	MGN_MCS3,
+	MGN_MCS4,
+	MGN_MCS5,
+	MGN_MCS6,
+	MGN_MCS7,
+	MGN_MCS8,
+	MGN_MCS9,
+	MGN_MCS10,
+	MGN_MCS11,
+	MGN_MCS12,
+	MGN_MCS13,
+	MGN_MCS14,
+	MGN_MCS15,
+	MGN_MCS16,
+	MGN_MCS17,
+	MGN_MCS18,
+	MGN_MCS19,
+	MGN_MCS20,
+	MGN_MCS21,
+	MGN_MCS22,
+	MGN_MCS23,
+	MGN_MCS24,
+	MGN_MCS25,
+	MGN_MCS26,
+	MGN_MCS27,
+	MGN_MCS28,
+	MGN_MCS29,
+	MGN_MCS30,
+	MGN_MCS31,
+	MGN_VHT1SS_MCS0,
+	MGN_VHT1SS_MCS1,
+	MGN_VHT1SS_MCS2,
+	MGN_VHT1SS_MCS3,
+	MGN_VHT1SS_MCS4,
+	MGN_VHT1SS_MCS5,
+	MGN_VHT1SS_MCS6,
+	MGN_VHT1SS_MCS7,
+	MGN_VHT1SS_MCS8,
+	MGN_VHT1SS_MCS9,
+	MGN_VHT2SS_MCS0,
+	MGN_VHT2SS_MCS1,
+	MGN_VHT2SS_MCS2,
+	MGN_VHT2SS_MCS3,
+	MGN_VHT2SS_MCS4,
+	MGN_VHT2SS_MCS5,
+	MGN_VHT2SS_MCS6,
+	MGN_VHT2SS_MCS7,
+	MGN_VHT2SS_MCS8,
+	MGN_VHT2SS_MCS9,
+	MGN_VHT3SS_MCS0,
+	MGN_VHT3SS_MCS1,
+	MGN_VHT3SS_MCS2,
+	MGN_VHT3SS_MCS3,
+	MGN_VHT3SS_MCS4,
+	MGN_VHT3SS_MCS5,
+	MGN_VHT3SS_MCS6,
+	MGN_VHT3SS_MCS7,
+	MGN_VHT3SS_MCS8,
+	MGN_VHT3SS_MCS9,
+	MGN_VHT4SS_MCS0,
+	MGN_VHT4SS_MCS1,
+	MGN_VHT4SS_MCS2,
+	MGN_VHT4SS_MCS3,
+	MGN_VHT4SS_MCS4,
+	MGN_VHT4SS_MCS5,
+	MGN_VHT4SS_MCS6,
+	MGN_VHT4SS_MCS7,
+	MGN_VHT4SS_MCS8,
+	MGN_VHT4SS_MCS9,
+	MGN_UNKNOWN
+};
+
+#define IS_HT_RATE(_rate)	((_rate) >= MGN_MCS0 && (_rate) <= MGN_MCS31)
+#define IS_VHT_RATE(_rate)	((_rate) >= MGN_VHT1SS_MCS0 && (_rate) <= MGN_VHT4SS_MCS9)
+#define IS_CCK_RATE(_rate)	((_rate) == MGN_1M || (_rate) == MGN_2M || (_rate) == MGN_5_5M || (_rate) == MGN_11M)
+#define IS_OFDM_RATE(_rate)	((_rate) >= MGN_6M && (_rate) <= MGN_54M  && (_rate) != MGN_11M)
+
+#define IS_HT1SS_RATE(_rate) ((_rate) >= MGN_MCS0 && (_rate) <= MGN_MCS7)
+#define IS_HT2SS_RATE(_rate) ((_rate) >= MGN_MCS8 && (_rate) <= MGN_MCS15)
+#define IS_HT3SS_RATE(_rate) ((_rate) >= MGN_MCS16 && (_rate) <= MGN_MCS23)
+#define IS_HT4SS_RATE(_rate) ((_rate) >= MGN_MCS24 && (_rate) <= MGN_MCS31)
+
+#define IS_VHT1SS_RATE(_rate) ((_rate) >= MGN_VHT1SS_MCS0 && (_rate) <= MGN_VHT1SS_MCS9)
+#define IS_VHT2SS_RATE(_rate) ((_rate) >= MGN_VHT2SS_MCS0 && (_rate) <= MGN_VHT2SS_MCS9)
+#define IS_VHT3SS_RATE(_rate) ((_rate) >= MGN_VHT3SS_MCS0 && (_rate) <= MGN_VHT3SS_MCS9)
+#define IS_VHT4SS_RATE(_rate) ((_rate) >= MGN_VHT4SS_MCS0 && (_rate) <= MGN_VHT4SS_MCS9)
+
+#define IS_1T_RATE(_rate)	(IS_CCK_RATE((_rate)) || IS_OFDM_RATE((_rate)) || IS_HT1SS_RATE((_rate)) || IS_VHT1SS_RATE((_rate)))
+#define IS_2T_RATE(_rate)	(IS_HT2SS_RATE((_rate)) || IS_VHT2SS_RATE((_rate)))
+#define IS_3T_RATE(_rate)	(IS_HT3SS_RATE((_rate)) || IS_VHT3SS_RATE((_rate)))
+#define IS_4T_RATE(_rate)	(IS_HT4SS_RATE((_rate)) || IS_VHT4SS_RATE((_rate)))
+
+#define MGN_RATE_STR(_rate) \
+	(_rate == MGN_1M) ? "CCK_1M" : \
+	(_rate == MGN_2M) ? "CCK_2M" : \
+	(_rate == MGN_5_5M) ? "CCK_5.5M" : \
+	(_rate == MGN_11M) ? "CCK_11M" : \
+	(_rate == MGN_6M) ? "OFDM_6M" : \
+	(_rate == MGN_9M) ? "OFDM_9M" : \
+	(_rate == MGN_12M) ? "OFDM_12M" : \
+	(_rate == MGN_18M) ? "OFDM_18M" : \
+	(_rate == MGN_24M) ? "OFDM_24M" : \
+	(_rate == MGN_36M) ? "OFDM_36M" : \
+	(_rate == MGN_48M) ? "OFDM_48M" : \
+	(_rate == MGN_54M) ? "OFDM_54M" : \
+	(_rate == MGN_MCS32) ? "MCS32" : \
+	(_rate == MGN_MCS0) ? "MCS0" : \
+	(_rate == MGN_MCS1) ? "MCS1" : \
+	(_rate == MGN_MCS2) ? "MCS2" : \
+	(_rate == MGN_MCS3) ? "MCS3" : \
+	(_rate == MGN_MCS4) ? "MCS4" : \
+	(_rate == MGN_MCS5) ? "MCS5" : \
+	(_rate == MGN_MCS6) ? "MCS6" : \
+	(_rate == MGN_MCS7) ? "MCS7" : \
+	(_rate == MGN_MCS8) ? "MCS8" : \
+	(_rate == MGN_MCS9) ? "MCS9" : \
+	(_rate == MGN_MCS10) ? "MCS10" : \
+	(_rate == MGN_MCS11) ? "MCS11" : \
+	(_rate == MGN_MCS12) ? "MCS12" : \
+	(_rate == MGN_MCS13) ? "MCS13" : \
+	(_rate == MGN_MCS14) ? "MCS14" : \
+	(_rate == MGN_MCS15) ? "MCS15" : \
+	(_rate == MGN_MCS16) ? "MCS16" : \
+	(_rate == MGN_MCS17) ? "MCS17" : \
+	(_rate == MGN_MCS18) ? "MCS18" : \
+	(_rate == MGN_MCS19) ? "MCS19" : \
+	(_rate == MGN_MCS20) ? "MCS20" : \
+	(_rate == MGN_MCS21) ? "MCS21" : \
+	(_rate == MGN_MCS22) ? "MCS22" : \
+	(_rate == MGN_MCS23) ? "MCS23" : \
+	(_rate == MGN_MCS24) ? "MCS24" : \
+	(_rate == MGN_MCS25) ? "MCS25" : \
+	(_rate == MGN_MCS26) ? "MCS26" : \
+	(_rate == MGN_MCS27) ? "MCS27" : \
+	(_rate == MGN_MCS28) ? "MCS28" : \
+	(_rate == MGN_MCS29) ? "MCS29" : \
+	(_rate == MGN_MCS30) ? "MCS30" : \
+	(_rate == MGN_MCS31) ? "MCS31" : \
+	(_rate == MGN_VHT1SS_MCS0) ? "VHT1SMCS0" : \
+	(_rate == MGN_VHT1SS_MCS1) ? "VHT1SMCS1" : \
+	(_rate == MGN_VHT1SS_MCS2) ? "VHT1SMCS2" : \
+	(_rate == MGN_VHT1SS_MCS3) ? "VHT1SMCS3" : \
+	(_rate == MGN_VHT1SS_MCS4) ? "VHT1SMCS4" : \
+	(_rate == MGN_VHT1SS_MCS5) ? "VHT1SMCS5" : \
+	(_rate == MGN_VHT1SS_MCS6) ? "VHT1SMCS6" : \
+	(_rate == MGN_VHT1SS_MCS7) ? "VHT1SMCS7" : \
+	(_rate == MGN_VHT1SS_MCS8) ? "VHT1SMCS8" : \
+	(_rate == MGN_VHT1SS_MCS9) ? "VHT1SMCS9" : \
+	(_rate == MGN_VHT2SS_MCS0) ? "VHT2SMCS0" : \
+	(_rate == MGN_VHT2SS_MCS1) ? "VHT2SMCS1" : \
+	(_rate == MGN_VHT2SS_MCS2) ? "VHT2SMCS2" : \
+	(_rate == MGN_VHT2SS_MCS3) ? "VHT2SMCS3" : \
+	(_rate == MGN_VHT2SS_MCS4) ? "VHT2SMCS4" : \
+	(_rate == MGN_VHT2SS_MCS5) ? "VHT2SMCS5" : \
+	(_rate == MGN_VHT2SS_MCS6) ? "VHT2SMCS6" : \
+	(_rate == MGN_VHT2SS_MCS7) ? "VHT2SMCS7" : \
+	(_rate == MGN_VHT2SS_MCS8) ? "VHT2SMCS8" : \
+	(_rate == MGN_VHT2SS_MCS9) ? "VHT2SMCS9" : \
+	(_rate == MGN_VHT3SS_MCS0) ? "VHT3SMCS0" : \
+	(_rate == MGN_VHT3SS_MCS1) ? "VHT3SMCS1" : \
+	(_rate == MGN_VHT3SS_MCS2) ? "VHT3SMCS2" : \
+	(_rate == MGN_VHT3SS_MCS3) ? "VHT3SMCS3" : \
+	(_rate == MGN_VHT3SS_MCS4) ? "VHT3SMCS4" : \
+	(_rate == MGN_VHT3SS_MCS5) ? "VHT3SMCS5" : \
+	(_rate == MGN_VHT3SS_MCS6) ? "VHT3SMCS6" : \
+	(_rate == MGN_VHT3SS_MCS7) ? "VHT3SMCS7" : \
+	(_rate == MGN_VHT3SS_MCS8) ? "VHT3SMCS8" : \
+	(_rate == MGN_VHT3SS_MCS9) ? "VHT3SMCS9" : \
+	(_rate == MGN_VHT4SS_MCS0) ? "VHT4SMCS0" : \
+	(_rate == MGN_VHT4SS_MCS1) ? "VHT4SMCS1" : \
+	(_rate == MGN_VHT4SS_MCS2) ? "VHT4SMCS2" : \
+	(_rate == MGN_VHT4SS_MCS3) ? "VHT4SMCS3" : \
+	(_rate == MGN_VHT4SS_MCS4) ? "VHT4SMCS4" : \
+	(_rate == MGN_VHT4SS_MCS5) ? "VHT4SMCS5" : \
+	(_rate == MGN_VHT4SS_MCS6) ? "VHT4SMCS6" : \
+	(_rate == MGN_VHT4SS_MCS7) ? "VHT4SMCS7" : \
+	(_rate == MGN_VHT4SS_MCS8) ? "VHT4SMCS8" : \
+	(_rate == MGN_VHT4SS_MCS9) ? "VHT4SMCS9" : "UNKNOWN"
+
+typedef enum _RATE_SECTION {
+	CCK = 0,
+	OFDM = 1,
+	HT_MCS0_MCS7 = 2,
+	HT_MCS8_MCS15 = 3,
+	HT_MCS16_MCS23 = 4,
+	HT_MCS24_MCS31 = 5,
+	HT_1SS = HT_MCS0_MCS7,
+	HT_2SS = HT_MCS8_MCS15,
+	HT_3SS = HT_MCS16_MCS23,
+	HT_4SS = HT_MCS24_MCS31,
+	VHT_1SSMCS0_1SSMCS9 = 6,
+	VHT_2SSMCS0_2SSMCS9 = 7,
+	VHT_3SSMCS0_3SSMCS9 = 8,
+	VHT_4SSMCS0_4SSMCS9 = 9,
+	VHT_1SS = VHT_1SSMCS0_1SSMCS9,
+	VHT_2SS = VHT_2SSMCS0_2SSMCS9,
+	VHT_3SS = VHT_3SSMCS0_3SSMCS9,
+	VHT_4SS = VHT_4SSMCS0_4SSMCS9,
+	RATE_SECTION_NUM,
+} RATE_SECTION;
+
+const char *rate_section_str(u8 section);
+
+#define IS_CCK_RATE_SECTION(section) ((section) == CCK)
+#define IS_OFDM_RATE_SECTION(section) ((section) == OFDM)
+#define IS_HT_RATE_SECTION(section) ((section) >= HT_1SS && (section) <= HT_4SS)
+#define IS_VHT_RATE_SECTION(section) ((section) >= VHT_1SS && (section) <= VHT_4SS)
+
+#define IS_1T_RATE_SECTION(section) ((section) == CCK || (section) == OFDM || (section) == HT_1SS || (section) == VHT_1SS)
+#define IS_2T_RATE_SECTION(section) ((section) == HT_2SS || (section) == VHT_2SS)
+#define IS_3T_RATE_SECTION(section) ((section) == HT_3SS || (section) == VHT_3SS)
+#define IS_4T_RATE_SECTION(section) ((section) == HT_4SS || (section) == VHT_4SS)
+
+extern u8 mgn_rates_cck[];
+extern u8 mgn_rates_ofdm[];
+extern u8 mgn_rates_mcs0_7[];
+extern u8 mgn_rates_mcs8_15[];
+extern u8 mgn_rates_mcs16_23[];
+extern u8 mgn_rates_mcs24_31[];
+extern u8 mgn_rates_vht1ss[];
+extern u8 mgn_rates_vht2ss[];
+extern u8 mgn_rates_vht3ss[];
+extern u8 mgn_rates_vht4ss[];
+
+struct rate_section_ent {
+	u8 tx_num; /* value of RF_TX_NUM */
+	u8 rate_num;
+	u8 *rates;
+};
+
+extern struct rate_section_ent rates_by_sections[];
+
+#define rate_section_to_tx_num(section) (rates_by_sections[(section)].tx_num)
+#define rate_section_rate_num(section) (rates_by_sections[(section)].rate_num)
+
+/* NOTE: This data is for statistical purposes; not all hardware provides this
+ *       information for frames received.  Not setting these will not cause
+ *       any adverse affects. */
+struct ieee80211_rx_stats {
+	/* u32 mac_time[2]; */
+	s8 rssi;
+	u8 signal;
+	u8 noise;
+	u8 received_channel;
+	u16 rate; /* in 100 kbps */
+	/* u8 control; */
+	u8 mask;
+	u8 freq;
+	u16 len;
+};
+
+/* IEEE 802.11 requires that STA supports concurrent reception of at least
+ * three fragmented frames. This define can be increased to support more
+ * concurrent frames, but it should be noted that each entry can consume about
+ * 2 kB of RAM and increasing cache size will slow down frame reassembly. */
+#define IEEE80211_FRAG_CACHE_LEN 4
+
+struct ieee80211_frag_entry {
+	u32 first_frag_time;
+	uint seq;
+	uint last_frag;
+	uint qos;   /* jackson */
+	uint tid;	/* jackson */
+	struct sk_buff *skb;
+	u8 src_addr[ETH_ALEN];
+	u8 dst_addr[ETH_ALEN];
+};
+
+#ifndef PLATFORM_FREEBSD /* Baron BSD has already defined */
+struct ieee80211_stats {
+	uint tx_unicast_frames;
+	uint tx_multicast_frames;
+	uint tx_fragments;
+	uint tx_unicast_octets;
+	uint tx_multicast_octets;
+	uint tx_deferred_transmissions;
+	uint tx_single_retry_frames;
+	uint tx_multiple_retry_frames;
+	uint tx_retry_limit_exceeded;
+	uint tx_discards;
+	uint rx_unicast_frames;
+	uint rx_multicast_frames;
+	uint rx_fragments;
+	uint rx_unicast_octets;
+	uint rx_multicast_octets;
+	uint rx_fcs_errors;
+	uint rx_discards_no_buffer;
+	uint tx_discards_wrong_sa;
+	uint rx_discards_undecryptable;
+	uint rx_message_in_msg_fragments;
+	uint rx_message_in_bad_msg_fragments;
+};
+#endif /* PLATFORM_FREEBSD */
+struct ieee80211_softmac_stats {
+	uint rx_ass_ok;
+	uint rx_ass_err;
+	uint rx_probe_rq;
+	uint tx_probe_rs;
+	uint tx_beacons;
+	uint rx_auth_rq;
+	uint rx_auth_rs_ok;
+	uint rx_auth_rs_err;
+	uint tx_auth_rq;
+	uint no_auth_rs;
+	uint no_ass_rs;
+	uint tx_ass_rq;
+	uint rx_ass_rq;
+	uint tx_probe_rq;
+	uint reassoc;
+	uint swtxstop;
+	uint swtxawake;
+};
+
+#define SEC_KEY_1         (1<<0)
+#define SEC_KEY_2         (1<<1)
+#define SEC_KEY_3         (1<<2)
+#define SEC_KEY_4         (1<<3)
+#define SEC_ACTIVE_KEY    (1<<4)
+#define SEC_AUTH_MODE     (1<<5)
+#define SEC_UNICAST_GROUP (1<<6)
+#define SEC_LEVEL         (1<<7)
+#define SEC_ENABLED       (1<<8)
+
+#define SEC_LEVEL_0      0 /* None */
+#define SEC_LEVEL_1      1 /* WEP 40 and 104 bit */
+#define SEC_LEVEL_2      2 /* Level 1 + TKIP */
+#define SEC_LEVEL_2_CKIP 3 /* Level 1 + CKIP */
+#define SEC_LEVEL_3      4 /* Level 2 + CCMP */
+
+#define WEP_KEYS 4
+#define WEP_KEY_LEN 13
+#define BIP_MAX_KEYID 5
+#define BIP_AAD_SIZE  20
+
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW)
+
+struct ieee80211_security {
+	u16 active_key:2,
+	    enabled:1,
+	    auth_mode:2,
+	    auth_algo:4,
+	    unicast_uses_group:1;
+	u8 key_sizes[WEP_KEYS];
+	u8 keys[WEP_KEYS][WEP_KEY_LEN];
+	u8 level;
+	u16 flags;
+} __attribute__((packed));
+
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+struct ieee80211_security {
+	u16 active_key:2,
+	    enabled:1,
+	    auth_mode:2,
+	    auth_algo:4,
+	    unicast_uses_group:1;
+	u8 key_sizes[WEP_KEYS];
+	u8 keys[WEP_KEYS][WEP_KEY_LEN];
+	u8 level;
+	u16 flags;
+} ;
+#pragma pack()
+
+#endif
+
+/*
+
+ 802.11 data frame from AP
+
+      ,-------------------------------------------------------------------.
+Bytes |  2   |  2   |    6    |    6    |    6    |  2   | 0..2312 |   4  |
+      |------|------|---------|---------|---------|------|---------|------|
+Desc. | ctrl | dura |  DA/RA  |   TA    |    SA   | Sequ |  frame  |  fcs |
+      |      | tion | (BSSID) |         |         | ence |  data   |      |
+      `-------------------------------------------------------------------'
+
+Total: 28-2340 bytes
+
+*/
+
+struct ieee80211_header_data {
+	u16 frame_ctl;
+	u16 duration_id;
+	u8 addr1[6];
+	u8 addr2[6];
+	u8 addr3[6];
+	u16 seq_ctrl;
+};
+
+#define BEACON_PROBE_SSID_ID_POSITION 12
+
+/* Management Frame Information Element Types */
+#define MFIE_TYPE_SSID       0
+#define MFIE_TYPE_RATES      1
+#define MFIE_TYPE_FH_SET     2
+#define MFIE_TYPE_DS_SET     3
+#define MFIE_TYPE_CF_SET     4
+#define MFIE_TYPE_TIM        5
+#define MFIE_TYPE_IBSS_SET   6
+#define MFIE_TYPE_CHALLENGE  16
+#define MFIE_TYPE_ERP        42
+#define MFIE_TYPE_RSN	     48
+#define MFIE_TYPE_RATES_EX   50
+#define MFIE_TYPE_GENERIC    221
+
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW)
+
+struct ieee80211_info_element_hdr {
+	u8 id;
+	u8 len;
+} __attribute__((packed));
+
+struct ieee80211_info_element {
+	u8 id;
+	u8 len;
+	u8 data[0];
+} __attribute__((packed));
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+struct ieee80211_info_element_hdr {
+	u8 id;
+	u8 len;
+} ;
+
+struct ieee80211_info_element {
+	u8 id;
+	u8 len;
+	u8 data[0];
+} ;
+#pragma pack()
+
+#endif
+
+
+/*
+ * These are the data types that can make up management packets
+ *
+	u16 auth_algorithm;
+	u16 auth_sequence;
+	u16 beacon_interval;
+	u16 capability;
+	u8 current_ap[ETH_ALEN];
+	u16 listen_interval;
+	struct {
+		u16 association_id:14, reserved:2;
+	} __attribute__ ((packed));
+	u32 time_stamp[2];
+	u16 reason;
+	u16 status;
+*/
+
+#define IEEE80211_DEFAULT_TX_ESSID "Penguin"
+#define IEEE80211_DEFAULT_BASIC_RATE 10
+
+
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW)
+
+
+struct ieee80211_authentication {
+	struct ieee80211_header_data header;
+	u16 algorithm;
+	u16 transaction;
+	u16 status;
+	/* struct ieee80211_info_element_hdr info_element; */
+} __attribute__((packed));
+
+
+struct ieee80211_probe_response {
+	struct ieee80211_header_data header;
+	u32 time_stamp[2];
+	u16 beacon_interval;
+	u16 capability;
+	struct ieee80211_info_element info_element;
+} __attribute__((packed));
+
+struct ieee80211_probe_request {
+	struct ieee80211_header_data header;
+	/*struct ieee80211_info_element info_element;*/
+} __attribute__((packed));
+
+struct ieee80211_assoc_request_frame {
+	struct rtw_ieee80211_hdr_3addr header;
+	u16 capability;
+	u16 listen_interval;
+	/* u8 current_ap[ETH_ALEN]; */
+	struct ieee80211_info_element_hdr info_element;
+} __attribute__((packed));
+
+struct ieee80211_assoc_response_frame {
+	struct rtw_ieee80211_hdr_3addr header;
+	u16 capability;
+	u16 status;
+	u16 aid;
+	/*	struct ieee80211_info_element info_element;  supported rates  */
+} __attribute__((packed));
+#endif
+
+
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+
+struct ieee80211_authentication {
+	struct ieee80211_header_data header;
+	u16 algorithm;
+	u16 transaction;
+	u16 status;
+	/* struct ieee80211_info_element_hdr info_element; */
+} ;
+
+
+struct ieee80211_probe_response {
+	struct ieee80211_header_data header;
+	u32 time_stamp[2];
+	u16 beacon_interval;
+	u16 capability;
+	struct ieee80211_info_element info_element;
+} ;
+
+struct ieee80211_probe_request {
+	struct ieee80211_header_data header;
+	/*struct ieee80211_info_element info_element;*/
+} ;
+
+struct ieee80211_assoc_request_frame {
+	struct rtw_ieee80211_hdr_3addr header;
+	u16 capability;
+	u16 listen_interval;
+	/* u8 current_ap[ETH_ALEN]; */
+	struct ieee80211_info_element_hdr info_element;
+} ;
+
+struct ieee80211_assoc_response_frame {
+	struct rtw_ieee80211_hdr_3addr header;
+	u16 capability;
+	u16 status;
+	u16 aid;
+	/*	struct ieee80211_info_element info_element;  supported rates  */
+};
+
+#pragma pack()
+
+#endif
+
+
+
+
+struct ieee80211_txb {
+	u8 nr_frags;
+	u8 encrypted;
+	u16 reserved;
+	u16 frag_size;
+	u16 payload_size;
+	struct sk_buff *fragments[0];
+};
+
+
+/* SWEEP TABLE ENTRIES NUMBER*/
+#define MAX_SWEEP_TAB_ENTRIES		  42
+#define MAX_SWEEP_TAB_ENTRIES_PER_PACKET  7
+/* 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                  ((u8)12)
+#define MAX_RATES_EX_LENGTH               ((u8)16)
+#define MAX_NETWORK_COUNT                  128
+#define IEEE80211_SOFTMAC_SCAN_TIME	  400
+/* (HZ / 2) */
+#define IEEE80211_SOFTMAC_ASSOC_RETRY_TIME (HZ * 2)
+
+#define CRC_LENGTH                 4U
+
+#define MAX_WPA_IE_LEN (256)
+#define MAX_WPS_IE_LEN (512)
+#define MAX_P2P_IE_LEN (256)
+#define MAX_WFD_IE_LEN (128)
+
+#define NETWORK_EMPTY_ESSID (1<<0)
+#define NETWORK_HAS_OFDM    (1<<1)
+#define NETWORK_HAS_CCK     (1<<2)
+
+#define IEEE80211_DTIM_MBCAST 4
+#define IEEE80211_DTIM_UCAST 2
+#define IEEE80211_DTIM_VALID 1
+#define IEEE80211_DTIM_INVALID 0
+
+#define IEEE80211_PS_DISABLED 0
+#define IEEE80211_PS_UNICAST IEEE80211_DTIM_UCAST
+#define IEEE80211_PS_MBCAST IEEE80211_DTIM_MBCAST
+#define IW_ESSID_MAX_SIZE 32
+#if 0
+struct ieee80211_network {
+	/* These entries are used to identify a unique network */
+	u8 bssid[ETH_ALEN];
+	u8 channel;
+	/* Ensure null-terminated for any debug msgs */
+	u8 ssid[IW_ESSID_MAX_SIZE + 1];
+	u8 ssid_len;
+	u8	rssi;	/* relative signal strength */
+	u8	sq;		/* signal quality */
+
+	/* These are network statistics */
+	/* struct ieee80211_rx_stats stats; */
+	u16 capability;
+	u16	aid;
+	u8 rates[MAX_RATES_LENGTH];
+	u8 rates_len;
+	u8 rates_ex[MAX_RATES_EX_LENGTH];
+	u8 rates_ex_len;
+
+	u8 edca_parmsets[18];
+
+	u8 mode;
+	u8 flags;
+	u8 time_stamp[8];
+	u16 beacon_interval;
+	u16 listen_interval;
+	u16 atim_window;
+	u8 wpa_ie[MAX_WPA_IE_LEN];
+	size_t wpa_ie_len;
+	u8 rsn_ie[MAX_WPA_IE_LEN];
+	size_t rsn_ie_len;
+	u8 country[6];
+	u8 dtim_period;
+	u8 dtim_data;
+	u8 power_constraint;
+	u8 qosinfo;
+	u8 qbssload[5];
+	u8 network_type;
+	int join_res;
+	unsigned long	last_scanned;
+};
+#endif
+/*
+join_res:
+-1: authentication fail
+-2: association fail
+> 0: TID
+*/
+
+#ifndef PLATFORM_FREEBSD /* Baron BSD has already defined */
+
+enum ieee80211_state {
+
+	/* the card is not linked at all */
+	IEEE80211_NOLINK = 0,
+
+	/* IEEE80211_ASSOCIATING* are for BSS client mode
+	 * the driver shall not perform RX filtering unless
+	 * the state is LINKED.
+	 * The driver shall just check for the state LINKED and
+	 * defaults to NOLINK for ALL the other states (including
+	 * LINKED_SCANNING)
+	 */
+
+	/* the association procedure will start (wq scheduling)*/
+	IEEE80211_ASSOCIATING,
+	IEEE80211_ASSOCIATING_RETRY,
+
+	/* the association procedure is sending AUTH request*/
+	IEEE80211_ASSOCIATING_AUTHENTICATING,
+
+	/* the association procedure has successfully authentcated
+	 * and is sending association request
+	 */
+	IEEE80211_ASSOCIATING_AUTHENTICATED,
+
+	/* the link is ok. the card associated to a BSS or linked
+	 * to a ibss cell or acting as an AP and creating the bss
+	 */
+	IEEE80211_LINKED,
+
+	/* same as LINKED, but the driver shall apply RX filter
+	 * rules as we are in NO_LINK mode. As the card is still
+	 * logically linked, but it is doing a syncro site survey
+	 * then it will be back to LINKED state.
+	 */
+	IEEE80211_LINKED_SCANNING,
+
+};
+#endif /* PLATFORM_FREEBSD */
+
+#define DEFAULT_MAX_SCAN_AGE (15 * HZ)
+#define DEFAULT_FTS 2346
+#define MAC_FMT "%02x:%02x:%02x:%02x:%02x:%02x"
+#define MAC_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5]
+#define MAC_SFMT "%02hhx:%02hhx:%02hhx:%02hhx:%02hhx:%02hhx"
+#define MAC_SARG(x) ((u8*)(x)),((u8*)(x)) + 1,((u8*)(x)) + 2,((u8*)(x)) + 3,((u8*)(x)) + 4,((u8*)(x)) + 5
+#define IP_FMT "%d.%d.%d.%d"
+#define IP_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3]
+#define PORT_FMT "%u"
+#define PORT_ARG(x) ntohs(*((u16 *)(x)))
+
+#ifdef PLATFORM_FREEBSD /* Baron change func to macro */
+#define is_multicast_mac_addr(Addr) ((((Addr[0]) & 0x01) == 0x01) && ((Addr[0]) != 0xff))
+#define is_broadcast_mac_addr(Addr) ((((Addr[0]) & 0xff) == 0xff) && (((Addr[1]) & 0xff) == 0xff) && \
+	(((Addr[2]) & 0xff) == 0xff) && (((Addr[3]) & 0xff) == 0xff) && (((Addr[4]) & 0xff) == 0xff) && \
+				     (((Addr[5]) & 0xff) == 0xff))
+#else
+extern __inline int is_multicast_mac_addr(const u8 *addr)
+{
+	return (addr[0] != 0xff) && (0x01 & addr[0]);
+}
+
+extern __inline int is_broadcast_mac_addr(const u8 *addr)
+{
+	return ((addr[0] == 0xff) && (addr[1] == 0xff) && (addr[2] == 0xff) &&   \
+		(addr[3] == 0xff) && (addr[4] == 0xff) && (addr[5] == 0xff));
+}
+
+extern __inline int is_zero_mac_addr(const u8 *addr)
+{
+	return ((addr[0] == 0x00) && (addr[1] == 0x00) && (addr[2] == 0x00) &&   \
+		(addr[3] == 0x00) && (addr[4] == 0x00) && (addr[5] == 0x00));
+}
+#endif /* PLATFORM_FREEBSD */
+
+#define CFG_IEEE80211_RESERVE_FCS (1<<0)
+#define CFG_IEEE80211_COMPUTE_FCS (1<<1)
+
+typedef struct tx_pending_t {
+	int frag;
+	struct ieee80211_txb *txb;
+} tx_pending_t;
+
+
+
+#define TID_NUM	16
+
+#define IEEE_A            (1<<0)
+#define IEEE_B            (1<<1)
+#define IEEE_G            (1<<2)
+#define IEEE_MODE_MASK    (IEEE_A | IEEE_B | IEEE_G)
+
+/* Baron move to ieee80211.c */
+int ieee80211_is_empty_essid(const char *essid, int essid_len);
+int ieee80211_get_hdrlen(u16 fc);
+
+#if 0
+	/* Action frame categories (IEEE 802.11-2007, 7.3.1.11, Table 7-24) */
+	#define WLAN_ACTION_SPECTRUM_MGMT 0
+	#define WLAN_ACTION_QOS 1
+	#define WLAN_ACTION_DLS 2
+	#define WLAN_ACTION_BLOCK_ACK 3
+	#define WLAN_ACTION_RADIO_MEASUREMENT 5
+	#define WLAN_ACTION_FT 6
+	#define WLAN_ACTION_SA_QUERY 8
+	#define WLAN_ACTION_WMM 17
+#endif
+
+
+/* Action category code */
+enum rtw_ieee80211_category {
+	RTW_WLAN_CATEGORY_SPECTRUM_MGMT = 0,
+	RTW_WLAN_CATEGORY_QOS = 1,
+	RTW_WLAN_CATEGORY_DLS = 2,
+	RTW_WLAN_CATEGORY_BACK = 3,
+	RTW_WLAN_CATEGORY_PUBLIC = 4, /* IEEE 802.11 public action frames */
+	RTW_WLAN_CATEGORY_RADIO_MEAS = 5,
+	RTW_WLAN_CATEGORY_FT = 6,
+	RTW_WLAN_CATEGORY_HT = 7,
+	RTW_WLAN_CATEGORY_SA_QUERY = 8,
+	RTW_WLAN_CATEGORY_WNM = 10,
+	RTW_WLAN_CATEGORY_UNPROTECTED_WNM = 11, /* add for CONFIG_IEEE80211W, none 11w also can use */
+	RTW_WLAN_CATEGORY_TDLS = 12,
+	RTW_WLAN_CATEGORY_MESH = 13,
+	RTW_WLAN_CATEGORY_MULTIHOP = 14,
+	RTW_WLAN_CATEGORY_SELF_PROTECTED = 15,
+	RTW_WLAN_CATEGORY_WMM = 17,
+	RTW_WLAN_CATEGORY_VHT = 21,
+	RTW_WLAN_CATEGORY_P2P = 0x7f,/* P2P action frames */
+};
+
+#define CATEGORY_IS_GROUP_PRIVACY(cat) \
+	(cat == RTW_WLAN_CATEGORY_MESH || cat == RTW_WLAN_CATEGORY_MULTIHOP)
+
+#define CATEGORY_IS_NON_ROBUST(cat) \
+	(cat == RTW_WLAN_CATEGORY_PUBLIC \
+	|| cat == RTW_WLAN_CATEGORY_HT \
+	|| cat == RTW_WLAN_CATEGORY_UNPROTECTED_WNM \
+	|| cat == RTW_WLAN_CATEGORY_SELF_PROTECTED \
+	|| cat == RTW_WLAN_CATEGORY_VHT \
+	|| cat == RTW_WLAN_CATEGORY_P2P)
+
+#define CATEGORY_IS_ROBUST(cat) !CATEGORY_IS_NON_ROBUST(cat)
+
+/* SPECTRUM_MGMT action code */
+enum rtw_ieee80211_spectrum_mgmt_actioncode {
+	RTW_WLAN_ACTION_SPCT_MSR_REQ = 0,
+	RTW_WLAN_ACTION_SPCT_MSR_RPRT = 1,
+	RTW_WLAN_ACTION_SPCT_TPC_REQ = 2,
+	RTW_WLAN_ACTION_SPCT_TPC_RPRT = 3,
+	RTW_WLAN_ACTION_SPCT_CHL_SWITCH = 4,
+	RTW_WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,
+};
+
+/* SELF_PROTECTED action code */
+enum rtw_ieee80211_self_protected_actioncode {
+	RTW_ACT_SELF_PROTECTED_RSVD = 0,
+	RTW_ACT_SELF_PROTECTED_MESH_OPEN = 1,
+	RTW_ACT_SELF_PROTECTED_MESH_CONF = 2,
+	RTW_ACT_SELF_PROTECTED_MESH_CLOSE = 3,
+	RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM = 4,
+	RTW_ACT_SELF_PROTECTED_MESH_GK_ACK = 5,
+	RTW_ACT_SELF_PROTECTED_NUM,
+};
+
+/* MESH action code */
+enum rtw_ieee80211_mesh_actioncode {
+	RTW_ACT_MESH_LINK_METRIC_REPORT,
+	RTW_ACT_MESH_HWMP_PATH_SELECTION,
+	RTW_ACT_MESH_GATE_ANNOUNCEMENT,
+	RTW_ACT_MESH_CONGESTION_CONTROL_NOTIFICATION,
+	RTW_ACT_MESH_MCCA_SETUP_REQUEST,
+	RTW_ACT_MESH_MCCA_SETUP_REPLY,
+	RTW_ACT_MESH_MCCA_ADVERTISEMENT_REQUEST,
+	RTW_ACT_MESH_MCCA_ADVERTISEMENT,
+	RTW_ACT_MESH_MCCA_TEARDOWN,
+	RTW_ACT_MESH_TBTT_ADJUSTMENT_REQUEST,
+	RTW_ACT_MESH_TBTT_ADJUSTMENT_RESPONSE,
+};
+
+enum _PUBLIC_ACTION {
+	ACT_PUBLIC_BSSCOEXIST = 0, /* 20/40 BSS Coexistence */
+	ACT_PUBLIC_DSE_ENABLE = 1,
+	ACT_PUBLIC_DSE_DEENABLE = 2,
+	ACT_PUBLIC_DSE_REG_LOCATION = 3,
+	ACT_PUBLIC_EXT_CHL_SWITCH = 4,
+	ACT_PUBLIC_DSE_MSR_REQ = 5,
+	ACT_PUBLIC_DSE_MSR_RPRT = 6,
+	ACT_PUBLIC_MP = 7, /* Measurement Pilot */
+	ACT_PUBLIC_DSE_PWR_CONSTRAINT = 8,
+	ACT_PUBLIC_VENDOR = 9, /* for WIFI_DIRECT */
+	ACT_PUBLIC_GAS_INITIAL_REQ = 10,
+	ACT_PUBLIC_GAS_INITIAL_RSP = 11,
+	ACT_PUBLIC_GAS_COMEBACK_REQ = 12,
+	ACT_PUBLIC_GAS_COMEBACK_RSP = 13,
+	ACT_PUBLIC_TDLS_DISCOVERY_RSP = 14,
+	ACT_PUBLIC_LOCATION_TRACK = 15,
+	ACT_PUBLIC_MAX
+};
+
+#ifdef CONFIG_TDLS
+enum TDLS_ACTION_FIELD {
+	TDLS_SETUP_REQUEST = 0,
+	TDLS_SETUP_RESPONSE = 1,
+	TDLS_SETUP_CONFIRM = 2,
+	TDLS_TEARDOWN = 3,
+	TDLS_PEER_TRAFFIC_INDICATION = 4,
+	TDLS_CHANNEL_SWITCH_REQUEST = 5,
+	TDLS_CHANNEL_SWITCH_RESPONSE = 6,
+	TDLS_PEER_PSM_REQUEST = 7,
+	TDLS_PEER_PSM_RESPONSE = 8,
+	TDLS_PEER_TRAFFIC_RESPONSE = 9,
+	TDLS_DISCOVERY_REQUEST = 10,
+	TDLS_DISCOVERY_RESPONSE = 14,	/* it's used in public action frame */
+};
+
+#define	TUNNELED_PROBE_REQ	15
+#define	TUNNELED_PROBE_RSP	16
+#endif /* CONFIG_TDLS */
+
+/* BACK action code */
+enum rtw_ieee80211_back_actioncode {
+	RTW_WLAN_ACTION_ADDBA_REQ = 0,
+	RTW_WLAN_ACTION_ADDBA_RESP = 1,
+	RTW_WLAN_ACTION_DELBA = 2,
+};
+
+/* HT features action code */
+enum rtw_ieee80211_ht_actioncode {
+	RTW_WLAN_ACTION_HT_NOTI_CHNL_WIDTH = 0,
+	RTW_WLAN_ACTION_HT_SM_PS = 1,
+	RTW_WLAN_ACTION_HT_PSMP = 2,
+	RTW_WLAN_ACTION_HT_SET_PCO_PHASE = 3,
+	RTW_WLAN_ACTION_HT_CSI = 4,
+	RTW_WLAN_ACTION_HT_NON_COMPRESS_BEAMFORMING = 5,
+	RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING = 6,
+	RTW_WLAN_ACTION_HT_ASEL_FEEDBACK = 7,
+};
+
+/* BACK (block-ack) parties */
+enum rtw_ieee80211_back_parties {
+	RTW_WLAN_BACK_RECIPIENT = 0,
+	RTW_WLAN_BACK_INITIATOR = 1,
+	RTW_WLAN_BACK_TIMER = 2,
+};
+
+/*20/40 BSS Coexistence element */
+#define RTW_WLAN_20_40_BSS_COEX_INFO_REQ            BIT(0)
+#define RTW_WLAN_20_40_BSS_COEX_40MHZ_INTOL         BIT(1)
+#define RTW_WLAN_20_40_BSS_COEX_20MHZ_WIDTH_REQ     BIT(2)
+#define RTW_WLAN_20_40_BSS_COEX_OBSS_EXEMPT_REQ     BIT(3)
+#define RTW_WLAN_20_40_BSS_COEX_OBSS_EXEMPT_GRNT    BIT(4)
+
+/* VHT features action code */
+enum rtw_ieee80211_vht_actioncode {
+	RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING = 0,
+	RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT = 1,
+	RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION = 2,
+};
+
+/*IEEE 802.11r action code*/
+#ifdef CONFIG_RTW_80211R
+enum rtw_ieee80211_ft_actioncode {
+	RTW_WLAN_ACTION_FT_RESV,
+	RTW_WLAN_ACTION_FT_REQ,
+	RTW_WLAN_ACTION_FT_RSP,
+	RTW_WLAN_ACTION_FT_CONF,
+	RTW_WLAN_ACTION_FT_ACK,
+	RTW_WLAN_ACTION_FT_MAX,
+};
+#endif
+
+#ifdef CONFIG_RTW_WNM
+enum rtw_ieee80211_wnm_actioncode {
+	RTW_WLAN_ACTION_WNM_BTM_QUERY = 6,
+	RTW_WLAN_ACTION_WNM_BTM_REQ = 7,
+	RTW_WLAN_ACTION_WNM_BTM_RSP = 8,
+};
+#endif
+
+#define OUI_MICROSOFT 0x0050f2 /* Microsoft (also used in Wi-Fi specs)
+				* 00:50:F2 */
+#ifndef PLATFORM_FREEBSD /* Baron BSD has defined */
+	#define WME_OUI_TYPE 2
+#endif /* PLATFORM_FREEBSD */
+#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 WME_ACTION_CODE_SETUP_REQUEST 0
+#define WME_ACTION_CODE_SETUP_RESPONSE 1
+#define WME_ACTION_CODE_TEARDOWN 2
+
+#define WME_SETUP_RESPONSE_STATUS_ADMISSION_ACCEPTED 0
+#define WME_SETUP_RESPONSE_STATUS_INVALID_PARAMETERS 1
+#define WME_SETUP_RESPONSE_STATUS_REFUSED 3
+
+#define WME_TSPEC_DIRECTION_UPLINK 0
+#define WME_TSPEC_DIRECTION_DOWNLINK 1
+#define WME_TSPEC_DIRECTION_BI_DIRECTIONAL 3
+
+
+#define OUI_BROADCOM 0x00904c /* Broadcom (Epigram) */
+
+#define VENDOR_HT_CAPAB_OUI_TYPE 0x33 /* 00-90-4c:0x33 */
+
+enum rtw_ieee80211_rann_flags {
+	RTW_RANN_FLAG_IS_GATE = 1 << 0,
+};
+
+/**
+ * enum rtw_ieee80211_preq_flags - mesh PREQ element flags
+ *
+ * @RTW_IEEE80211_PREQ_IS_GATE_FLAG: Gate Announcement subfield
+ * @RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG: proactive PREP subfield
+ */
+enum rtw_ieee80211_preq_flags {
+	RTW_IEEE80211_PREQ_IS_GATE_FLAG = 1 << 0,
+	RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG	= 1 << 2,
+};
+
+/**
+ * enum rtw_ieee80211_preq_target_flags - mesh PREQ element per target flags
+ *
+ * @RTW_IEEE80211_PREQ_TO_FLAG: target only subfield
+ * @RTW_IEEE80211_PREQ_USN_FLAG: unknown target HWMP sequence number subfield
+ */
+enum rtw_ieee80211_preq_target_flags {
+	RTW_IEEE80211_PREQ_TO_FLAG	= 1<<0,
+	RTW_IEEE80211_PREQ_USN_FLAG	= 1<<2,
+};
+
+/**
+ * enum rtw_ieee80211_root_mode_identifier - root mesh STA mode identifier
+ *
+ * These attribute are used by dot11MeshHWMPRootMode to set root mesh STA mode
+ *
+ * @RTW_IEEE80211_ROOTMODE_NO_ROOT: the mesh STA is not a root mesh STA (default)
+ * @RTW_IEEE80211_ROOTMODE_ROOT: the mesh STA is a root mesh STA if greater than
+ *	this value
+ * @RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP: the mesh STA is a root mesh STA supports
+ *	the proactive PREQ with proactive PREP subfield set to 0
+ * @RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP: the mesh STA is a root mesh STA
+ *	supports the proactive PREQ with proactive PREP subfield set to 1
+ * @RTW_IEEE80211_PROACTIVE_RANN: the mesh STA is a root mesh STA supports
+ *	the proactive RANN
+ */
+enum rtw_ieee80211_root_mode_identifier {
+	RTW_IEEE80211_ROOTMODE_NO_ROOT = 0,
+	RTW_IEEE80211_ROOTMODE_ROOT = 1,
+	RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP = 2,
+	RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP = 3,
+	RTW_IEEE80211_PROACTIVE_RANN = 4,
+};
+
+/**
+ * enum rtw_ieee80211_channel_flags - channel flags
+ *
+ * Channel flags set by the regulatory control code.
+ *
+ * @RTW_IEEE80211_CHAN_DISABLED: This channel is disabled.
+ * @RTW_IEEE80211_CHAN_PASSIVE_SCAN: Only passive scanning is permitted
+ *      on this channel.
+ * @RTW_IEEE80211_CHAN_NO_IBSS: IBSS is not allowed on this channel.
+ * @RTW_IEEE80211_CHAN_RADAR: Radar detection is required on this channel.
+ * @RTW_IEEE80211_CHAN_NO_HT40PLUS: extension channel above this channel
+ *      is not permitted.
+ * @RTW_IEEE80211_CHAN_NO_HT40MINUS: extension channel below this channel
+ *      is not permitted.
+ */
+enum rtw_ieee80211_channel_flags {
+	RTW_IEEE80211_CHAN_DISABLED         = 1 << 0,
+	RTW_IEEE80211_CHAN_PASSIVE_SCAN     = 1 << 1,
+	RTW_IEEE80211_CHAN_NO_IBSS          = 1 << 2,
+	RTW_IEEE80211_CHAN_RADAR            = 1 << 3,
+	RTW_IEEE80211_CHAN_NO_HT40PLUS      = 1 << 4,
+	RTW_IEEE80211_CHAN_NO_HT40MINUS     = 1 << 5,
+};
+
+#define RTW_IEEE80211_CHAN_NO_HT40 \
+	(RTW_IEEE80211_CHAN_NO_HT40PLUS | RTW_IEEE80211_CHAN_NO_HT40MINUS)
+
+/* Represent channel details, subset of ieee80211_channel */
+struct rtw_ieee80211_channel {
+	/* enum ieee80211_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*/ \
+
+/* Parsed Information Elements */
+struct rtw_ieee802_11_elems {
+	u8 *ssid;
+	u8 ssid_len;
+	u8 *supp_rates;
+	u8 supp_rates_len;
+	u8 *fh_params;
+	u8 fh_params_len;
+	u8 *ds_params;
+	u8 ds_params_len;
+	u8 *cf_params;
+	u8 cf_params_len;
+	u8 *tim;
+	u8 tim_len;
+	u8 *ibss_params;
+	u8 ibss_params_len;
+	u8 *challenge;
+	u8 challenge_len;
+	u8 *erp_info;
+	u8 erp_info_len;
+	u8 *ext_supp_rates;
+	u8 ext_supp_rates_len;
+	u8 *wpa_ie;
+	u8 wpa_ie_len;
+	u8 *rsn_ie;
+	u8 rsn_ie_len;
+	u8 *wme;
+	u8 wme_len;
+	u8 *wme_tspec;
+	u8 wme_tspec_len;
+	u8 *wps_ie;
+	u8 wps_ie_len;
+	u8 *power_cap;
+	u8 power_cap_len;
+	u8 *supp_channels;
+	u8 supp_channels_len;
+	u8 *mdie;
+	u8 mdie_len;
+	u8 *ftie;
+	u8 ftie_len;
+	u8 *timeout_int;
+	u8 timeout_int_len;
+	u8 *ht_capabilities;
+	u8 ht_capabilities_len;
+	u8 *ht_operation;
+	u8 ht_operation_len;
+	u8 *vendor_ht_cap;
+	u8 vendor_ht_cap_len;
+	u8 *vht_capabilities;
+	u8 vht_capabilities_len;
+	u8 *vht_operation;
+	u8 vht_operation_len;
+	u8 *vht_op_mode_notify;
+	u8 vht_op_mode_notify_len;
+	u8 *rm_en_cap;
+	u8 rm_en_cap_len;
+#ifdef CONFIG_RTW_MESH
+	u8 *preq;
+	u8 preq_len;
+	u8 *prep;
+	u8 prep_len;
+	u8 *perr;
+	u8 perr_len;
+	u8 *rann;
+	u8 rann_len;
+#endif
+};
+
+typedef enum { ParseOK = 0, ParseUnknown = 1, ParseFailed = -1 } ParseRes;
+
+ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
+				struct rtw_ieee802_11_elems *elems,
+				int show_errors);
+
+u8 *rtw_set_fixed_ie(unsigned char *pbuf, unsigned int len, unsigned char *source, unsigned int *frlen);
+u8 *rtw_set_ie(u8 *pbuf, sint index, uint len, const u8 *source, uint *frlen);
+
+enum secondary_ch_offset {
+	SCN = 0, /* no secondary channel */
+	SCA = 1, /* secondary channel above */
+	SCB = 3,  /* secondary channel below */
+};
+u8 secondary_ch_offset_to_hal_ch_offset(u8 ch_offset);
+u8 hal_ch_offset_to_secondary_ch_offset(u8 ch_offset);
+u8 *rtw_set_ie_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode, u8 new_ch, u8 ch_switch_cnt);
+u8 *rtw_set_ie_secondary_ch_offset(u8 *buf, u32 *buf_len, u8 secondary_ch_offset);
+u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl, u8 flags, u16 reason, u16 precedence);
+
+u8 *rtw_get_ie(const u8 *pbuf, sint index, sint *len, sint limit);
+u8 *rtw_get_ie_ex(const u8 *in_ie, uint in_len, u8 eid, const u8 *oui, u8 oui_len, u8 *ie, uint *ielen);
+int rtw_ies_remove_ie(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 oui_len);
+
+void rtw_set_supported_rate(u8 *SupportedRates, uint mode) ;
+
+#define GET_RSN_CAP_MFP_OPTION(cap)	LE_BITS_TO_2BYTE(((u8 *)(cap)), 6, 2)
+
+#define MFP_NO			0
+#define MFP_INVALID		1
+#define MFP_OPTIONAL	2
+#define MFP_REQUIRED	3
+
+struct rsne_info {
+	u8 *gcs;
+	u16 pcs_cnt;
+	u8 *pcs_list;
+	u16 akm_cnt;
+	u8 *akm_list;
+	u8 *cap;
+	u16 pmkid_cnt;
+	u8 *pmkid_list;
+	u8 *gmcs;
+
+	u8 err;
+};
+int rtw_rsne_info_parse(const u8 *ie, uint ie_len, struct rsne_info *info);
+
+unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit);
+unsigned char *rtw_get_wpa2_ie(unsigned char *pie, int *rsn_ie_len, int limit);
+int rtw_get_wpa_cipher_suite(u8 *s);
+int rtw_get_wpa2_cipher_suite(u8 *s);
+int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len);
+int rtw_parse_wpa_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
+int rtw_parse_wpa2_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x, u8 *mfp_opt);
+
+int rtw_get_sec_ie(u8 *in_ie, uint in_len, u8 *rsn_ie, u16 *rsn_len, u8 *wpa_ie, u16 *wpa_len);
+
+u8 rtw_is_wps_ie(u8 *ie_ptr, uint *wps_ielen);
+u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, enum bss_type frame_type);
+u8 *rtw_get_wps_ie(const u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen);
+u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_attr, u32 *len_attr);
+u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_content, uint *len_content);
+
+/**
+ * for_each_ie - iterate over continuous IEs
+ * @ie:
+ * @buf:
+ * @buf_len:
+ */
+#define for_each_ie(ie, buf, buf_len) \
+	for (ie = (void *)buf; (((u8 *)ie) - ((u8 *)buf) + 1) < buf_len; ie = (void *)(((u8 *)ie) + *(((u8 *)ie)+1) + 2))
+
+void dump_ies(void *sel, const u8 *buf, u32 buf_len);
+
+#ifdef CONFIG_80211N_HT
+#define HT_SC_OFFSET_MAX 4
+extern const char *const _ht_sc_offset_str[];
+#define ht_sc_offset_str(sc) (((sc) >= HT_SC_OFFSET_MAX) ? _ht_sc_offset_str[2] : _ht_sc_offset_str[(sc)])
+
+void dump_ht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len);
+#endif
+
+void dump_wps_ie(void *sel, const u8 *ie, u32 ie_len);
+
+void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht);
+
+void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht);
+
+bool rtw_is_chbw_grouped(u8 ch_a, u8 bw_a, u8 offset_a
+	, u8 ch_b, u8 bw_b, u8 offset_b);
+void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
+	, u8 *g_ch, u8 *g_bw, u8 *g_offset);
+
+u32 rtw_get_p2p_merged_ies_len(u8 *in_ie, u32 in_len);
+int rtw_p2p_merge_ies(u8 *in_ie, u32 in_len, u8 *merge_ie);
+void dump_p2p_ie(void *sel, const u8 *ie, u32 ie_len);
+u8 *rtw_get_p2p_ie(const u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen);
+u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr);
+u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content);
+u32 rtw_set_p2p_attr_content(u8 *pbuf, u8 attr_id, u16 attr_len, u8 *pdata_attr);
+uint rtw_del_p2p_ie(u8 *ies, uint ies_len_ori, const char *msg);
+uint rtw_del_p2p_attr(u8 *ie, uint ielen_ori, u8 attr_id);
+u8 *rtw_bss_ex_get_p2p_ie(WLAN_BSSID_EX *bss_ex, u8 *p2p_ie, uint *p2p_ielen);
+void rtw_bss_ex_del_p2p_ie(WLAN_BSSID_EX *bss_ex);
+void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id);
+
+void dump_wfd_ie(void *sel, const u8 *ie, u32 ie_len);
+u8 *rtw_get_wfd_ie(const u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen);
+u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr);
+u8 *rtw_get_wfd_attr_content(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content);
+uint rtw_del_wfd_ie(u8 *ies, uint ies_len_ori, const char *msg);
+uint rtw_del_wfd_attr(u8 *ie, uint ielen_ori, u8 attr_id);
+u8 *rtw_bss_ex_get_wfd_ie(WLAN_BSSID_EX *bss_ex, u8 *wfd_ie, uint *wfd_ielen);
+void rtw_bss_ex_del_wfd_ie(WLAN_BSSID_EX *bss_ex);
+void rtw_bss_ex_del_wfd_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id);
+
+uint	rtw_get_rateset_len(u8	*rateset);
+
+struct registry_priv;
+int rtw_generate_ie(struct registry_priv *pregistrypriv);
+
+int rtw_get_bit_value_from_ieee_value(u8 val);
+
+uint	rtw_is_cckrates_included(u8 *rate);
+
+uint	rtw_is_cckratesonly_included(u8 *rate);
+
+int rtw_check_network_type(unsigned char *rate, int ratelen, int channel);
+
+void rtw_get_bcn_info(struct wlan_network *pnetwork);
+
+u8 rtw_check_invalid_mac_address(u8 *mac_addr, u8 check_local_bit);
+void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr);
+
+u16 rtw_mcs_rate(u8 rf_type, u8 bw_40MHz, u8 short_GI, unsigned char *MCS_rate);
+u8	rtw_ht_mcsset_to_nss(u8 *supp_mcs_set);
+u32	rtw_ht_mcs_set_to_bitmap(u8 *mcs_set, u8 nss);
+
+int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8 *category, u8 *action);
+const char *action_public_str(u8 action);
+
+u8 key_2char2num(u8 hch, u8 lch);
+u8 str_2char2num(u8 hch, u8 lch);
+void macstr2num(u8 *dst, u8 *src);
+u8 convert_ip_addr(u8 hch, u8 mch, u8 lch);
+int wifirate2_ratetbl_inx(unsigned char rate);
+
+
+#endif /* IEEE80211_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ieee80211_ext.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ieee80211_ext.h
new file mode 100644
index 000000000000..94a8e582d151
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ieee80211_ext.h
@@ -0,0 +1,471 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_EXT_H
+#define __IEEE80211_EXT_H
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#define WMM_OUI_TYPE 2
+#define WMM_OUI_SUBTYPE_INFORMATION_ELEMENT 0
+#define WMM_OUI_SUBTYPE_PARAMETER_ELEMENT 1
+#define WMM_OUI_SUBTYPE_TSPEC_ELEMENT 2
+#define WMM_VERSION 1
+
+#define WPA_PROTO_WPA BIT(0)
+#define WPA_PROTO_RSN BIT(1)
+
+#define WPA_KEY_MGMT_IEEE8021X BIT(0)
+#define WPA_KEY_MGMT_PSK BIT(1)
+#define WPA_KEY_MGMT_NONE BIT(2)
+#define WPA_KEY_MGMT_IEEE8021X_NO_WPA BIT(3)
+#define WPA_KEY_MGMT_WPA_NONE BIT(4)
+
+
+#define WPA_CAPABILITY_PREAUTH BIT(0)
+#define WPA_CAPABILITY_MGMT_FRAME_PROTECTION BIT(6)
+#define WPA_CAPABILITY_PEERKEY_ENABLED BIT(9)
+
+
+#define PMKID_LEN 16
+
+
+#ifdef PLATFORM_LINUX
+struct wpa_ie_hdr {
+	u8 elem_id;
+	u8 len;
+	u8 oui[4]; /* 24-bit OUI followed by 8-bit OUI type */
+	u8 version[2]; /* little endian */
+} __attribute__((packed));
+
+struct rsn_ie_hdr {
+	u8 elem_id; /* WLAN_EID_RSN */
+	u8 len;
+	u8 version[2]; /* little endian */
+} __attribute__((packed));
+
+struct wme_ac_parameter {
+#if defined(CONFIG_LITTLE_ENDIAN)
+	/* byte 1 */
+	u8	aifsn:4,
+	     acm:1,
+	     aci:2,
+	     reserved:1;
+
+	/* byte 2 */
+	u8	eCWmin:4,
+	     eCWmax:4;
+#elif defined(CONFIG_BIG_ENDIAN)
+	/* byte 1 */
+	u8	reserved:1,
+	     aci:2,
+	     acm:1,
+	     aifsn:4;
+
+	/* byte 2 */
+	u8	eCWmax:4,
+	     eCWmin:4;
+#else
+#error	"Please fix <endian.h>"
+#endif
+
+	/* bytes 3 & 4 */
+	u16 txopLimit;
+} __attribute__((packed));
+
+struct wme_parameter_element {
+	/* required fields for WME version 1 */
+	u8 oui[3];
+	u8 oui_type;
+	u8 oui_subtype;
+	u8 version;
+	u8 acInfo;
+	u8 reserved;
+	struct wme_ac_parameter ac[4];
+
+} __attribute__((packed));
+
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+
+struct wpa_ie_hdr {
+	u8 elem_id;
+	u8 len;
+	u8 oui[4]; /* 24-bit OUI followed by 8-bit OUI type */
+	u8 version[2]; /* little endian */
+};
+
+struct rsn_ie_hdr {
+	u8 elem_id; /* WLAN_EID_RSN */
+	u8 len;
+	u8 version[2]; /* little endian */
+};
+
+#pragma pack()
+
+#endif
+
+#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_LE32(a, val)					\
+	do {							\
+		(a)[3] = (u8) ((((u32) (val)) >> 24) & 0xff);	\
+		(a)[2] = (u8) ((((u32) (val)) >> 16) & 0xff);	\
+		(a)[1] = (u8) ((((u32) (val)) >> 8) & 0xff);	\
+		(a)[0] = (u8) (((u32) (val)) & 0xff);		\
+	} while (0)
+
+#define RSN_SELECTOR_PUT(a, val) WPA_PUT_BE32((u8 *) (a), (val))
+/* #define RSN_SELECTOR_PUT(a, val) WPA_PUT_LE32((u8 *) (a), (val)) */
+
+
+
+/* Action category code */
+enum ieee80211_category {
+	WLAN_CATEGORY_SPECTRUM_MGMT = 0,
+	WLAN_CATEGORY_QOS = 1,
+	WLAN_CATEGORY_DLS = 2,
+	WLAN_CATEGORY_BACK = 3,
+	WLAN_CATEGORY_HT = 7,
+	WLAN_CATEGORY_WMM = 17,
+};
+
+/* SPECTRUM_MGMT action code */
+enum ieee80211_spectrum_mgmt_actioncode {
+	WLAN_ACTION_SPCT_MSR_REQ = 0,
+	WLAN_ACTION_SPCT_MSR_RPRT = 1,
+	WLAN_ACTION_SPCT_TPC_REQ = 2,
+	WLAN_ACTION_SPCT_TPC_RPRT = 3,
+	WLAN_ACTION_SPCT_CHL_SWITCH = 4,
+	WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,
+};
+
+/* BACK action code */
+enum ieee80211_back_actioncode {
+	WLAN_ACTION_ADDBA_REQ = 0,
+	WLAN_ACTION_ADDBA_RESP = 1,
+	WLAN_ACTION_DELBA = 2,
+};
+
+/* HT features action code */
+enum ieee80211_ht_actioncode {
+	WLAN_ACTION_NOTIFY_CH_WIDTH = 0,
+	WLAN_ACTION_SM_PS = 1,
+	WLAN_ACTION_PSPM = 2,
+	WLAN_ACTION_PCO_PHASE = 3,
+	WLAN_ACTION_MIMO_CSI_MX = 4,
+	WLAN_ACTION_MIMO_NONCP_BF = 5,
+	WLAN_ACTION_MIMP_CP_BF = 6,
+	WLAN_ACTION_ASEL_INDICATES_FB = 7,
+	WLAN_ACTION_HI_INFO_EXCHG = 8,
+};
+
+/* BACK (block-ack) parties */
+enum ieee80211_back_parties {
+	WLAN_BACK_RECIPIENT = 0,
+	WLAN_BACK_INITIATOR = 1,
+	WLAN_BACK_TIMER = 2,
+};
+
+#ifdef PLATFORM_LINUX
+
+struct ieee80211_mgmt {
+	u16 frame_control;
+	u16 duration;
+	u8 da[6];
+	u8 sa[6];
+	u8 bssid[6];
+	u16 seq_ctrl;
+	union {
+		struct {
+			u16 auth_alg;
+			u16 auth_transaction;
+			u16 status_code;
+			/* possibly followed by Challenge text */
+			u8 variable[0];
+		}  __attribute__((packed)) auth;
+		struct {
+			u16 reason_code;
+		}  __attribute__((packed)) deauth;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) assoc_req;
+		struct {
+			u16 capab_info;
+			u16 status_code;
+			u16 aid;
+			/* followed by Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) assoc_resp, reassoc_resp;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			u8 current_ap[6];
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) reassoc_req;
+		struct {
+			u16 reason_code;
+		}  __attribute__((packed)) disassoc;
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params, TIM */
+			u8 variable[0];
+		}  __attribute__((packed)) beacon;
+		struct {
+			/* only variable items: SSID, Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) probe_req;
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params */
+			u8 variable[0];
+		}  __attribute__((packed)) probe_resp;
+		struct {
+			u8 category;
+			union {
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u8 status_code;
+					u8 variable[0];
+				}  __attribute__((packed)) wme_action;
+#if 0
+				struct {
+					u8 action_code;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_channel_sw_ie sw_elem;
+				}  __attribute__((packed)) chan_switch;
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_msrment_ie msr_elem;
+				}  __attribute__((packed)) measurement;
+#endif
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 capab;
+					u16 timeout;
+					u16 start_seq_num;
+				}  __attribute__((packed)) addba_req;
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 status;
+					u16 capab;
+					u16 timeout;
+				}  __attribute__((packed)) addba_resp;
+				struct {
+					u8 action_code;
+					u16 params;
+					u16 reason_code;
+				}  __attribute__((packed)) delba;
+				struct {
+					u8 action_code;
+					/* capab_info for open and confirm,
+					 * reason for close
+					 */
+					u16 aux;
+					/* Followed in plink_confirm by status
+					 * code, AID and supported rates,
+					 * and directly by supported rates in
+					 * plink_open and plink_close
+					 */
+					u8 variable[0];
+				}  __attribute__((packed)) plink_action;
+				struct {
+					u8 action_code;
+					u8 variable[0];
+				}  __attribute__((packed)) mesh_action;
+			} __attribute__((packed)) u;
+		}  __attribute__((packed)) action;
+	} __attribute__((packed)) u;
+} __attribute__((packed));
+
+#endif
+
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+
+struct ieee80211_mgmt {
+	u16 frame_control;
+	u16 duration;
+	u8 da[6];
+	u8 sa[6];
+	u8 bssid[6];
+	u16 seq_ctrl;
+	union {
+		struct {
+			u16 auth_alg;
+			u16 auth_transaction;
+			u16 status_code;
+			/* possibly followed by Challenge text */
+			u8 variable[0];
+		}  auth;
+		struct {
+			u16 reason_code;
+		}  deauth;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  assoc_req;
+		struct {
+			u16 capab_info;
+			u16 status_code;
+			u16 aid;
+			/* followed by Supported rates */
+			u8 variable[0];
+		}  assoc_resp, reassoc_resp;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			u8 current_ap[6];
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  reassoc_req;
+		struct {
+			u16 reason_code;
+		}  disassoc;
+#if 0
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params, TIM */
+			u8 variable[0];
+		}  beacon;
+		struct {
+			/* only variable items: SSID, Supported rates */
+			u8 variable[0];
+		}  probe_req;
+
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params */
+			u8 variable[0];
+		}  probe_resp;
+#endif
+		struct {
+			u8 category;
+			union {
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u8 status_code;
+					u8 variable[0];
+				}  wme_action;
+				#if 0
+				struct{
+					u8 action_code;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_channel_sw_ie sw_elem;
+				}  chan_switch;
+				struct{
+					u8 action_code;
+					u8 dialog_token;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_msrment_ie msr_elem;
+				}  measurement;
+				#endif
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 capab;
+					u16 timeout;
+					u16 start_seq_num;
+				}  addba_req;
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 status;
+					u16 capab;
+					u16 timeout;
+				}  addba_resp;
+				struct {
+					u8 action_code;
+					u16 params;
+					u16 reason_code;
+				}  delba;
+				struct {
+					u8 action_code;
+					/* capab_info for open and confirm,
+					 * reason for close
+					 */
+					u16 aux;
+					/* Followed in plink_confirm by status
+					 * code, AID and supported rates,
+					 * and directly by supported rates in
+					 * plink_open and plink_close
+					 */
+					u8 variable[0];
+				}  plink_action;
+				struct {
+					u8 action_code;
+					u8 variable[0];
+				}  mesh_action;
+			} u;
+		}  action;
+	} u;
+} ;
+
+#pragma pack()
+
+#endif
+
+/* mgmt header + 1 byte category code */
+#define IEEE80211_MIN_ACTION_SIZE FIELD_OFFSET(struct ieee80211_mgmt, u.action.u)
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/if_ether.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/if_ether.h
new file mode 100644
index 000000000000..a3007c4ab22d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/if_ether.h
@@ -0,0 +1,106 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_IF_ETHER_H
+#define _LINUX_IF_ETHER_H
+
+/*
+ *	IEEE 802.3 Ethernet magic constants.  The frame sizes omit the preamble
+ *	and FCS/CRC (frame check sequence).
+ */
+
+#define ETH_ALEN	6		/* Octets in one ethernet addr	 */
+#define ETH_HLEN	14		/* Total octets in header.	 */
+#define ETH_ZLEN	60		/* Min. octets in frame sans FCS */
+#define ETH_DATA_LEN	1500		/* Max. octets in payload	 */
+#define ETH_FRAME_LEN	1514		/* Max. octets in frame sans FCS */
+
+/*
+ *	These are the defined Ethernet Protocol ID's.
+ */
+
+#define ETH_P_LOOP	0x0060		/* Ethernet Loopback packet	*/
+#define ETH_P_PUP	0x0200		/* Xerox PUP packet		*/
+#define ETH_P_PUPAT	0x0201		/* Xerox PUP Addr Trans packet	*/
+#define ETH_P_IP	0x0800		/* Internet Protocol packet	*/
+#define ETH_P_X25	0x0805		/* CCITT X.25			*/
+#define ETH_P_ARP	0x0806		/* Address Resolution packet	*/
+#define	ETH_P_BPQ	0x08FF		/* G8BPQ AX.25 Ethernet Packet	[ NOT AN OFFICIALLY REGISTERED ID ] */
+#define ETH_P_IEEEPUP	0x0a00		/* Xerox IEEE802.3 PUP packet */
+#define ETH_P_IEEEPUPAT	0x0a01		/* Xerox IEEE802.3 PUP Addr Trans packet */
+#define ETH_P_DEC       0x6000          /* DEC Assigned proto          */
+#define ETH_P_DNA_DL    0x6001          /* DEC DNA Dump/Load           */
+#define ETH_P_DNA_RC    0x6002          /* DEC DNA Remote Console      */
+#define ETH_P_DNA_RT    0x6003          /* DEC DNA Routing             */
+#define ETH_P_LAT       0x6004          /* DEC LAT                     */
+#define ETH_P_DIAG      0x6005          /* DEC Diagnostics             */
+#define ETH_P_CUST      0x6006          /* DEC Customer use            */
+#define ETH_P_SCA       0x6007          /* DEC Systems Comms Arch      */
+#define ETH_P_RARP      0x8035		/* Reverse Addr Res packet	*/
+#define ETH_P_ATALK	0x809B		/* Appletalk DDP		*/
+#define ETH_P_AARP	0x80F3		/* Appletalk AARP		*/
+#define ETH_P_8021Q	0x8100          /* 802.1Q VLAN Extended Header */
+#define ETH_P_IPX	0x8137		/* IPX over DIX			*/
+#define ETH_P_IPV6	0x86DD		/* IPv6 over bluebook		*/
+#define ETH_P_PPP_DISC	0x8863		/* PPPoE discovery messages    */
+#define ETH_P_PPP_SES	0x8864		/* PPPoE session messages	*/
+#define ETH_P_ATMMPOA	0x884c		/* MultiProtocol Over ATM	*/
+#define ETH_P_ATMFATE	0x8884		/* Frame-based ATM Transport
+					 * over Ethernet
+					 */
+
+/*
+ *	Non DIX types. Won't clash for 1500 types.
+ */
+
+#define ETH_P_802_3	0x0001		/* Dummy type for 802.3 frames */
+#define ETH_P_AX25	0x0002		/* Dummy protocol id for AX.25 */
+#define ETH_P_ALL	0x0003		/* Every packet (be careful!!!) */
+#define ETH_P_802_2	0x0004		/* 802.2 frames 		*/
+#define ETH_P_SNAP	0x0005		/* Internal only		*/
+#define ETH_P_DDCMP     0x0006          /* DEC DDCMP: Internal only    */
+#define ETH_P_WAN_PPP   0x0007          /* Dummy type for WAN PPP frames*/
+#define ETH_P_PPP_MP    0x0008          /* Dummy type for PPP MP frames */
+#define ETH_P_LOCALTALK 0x0009		/* Localtalk pseudo type 	*/
+#define ETH_P_PPPTALK	0x0010		/* Dummy type for Atalk over PPP*/
+#define ETH_P_TR_802_2	0x0011		/* 802.2 frames 		*/
+#define ETH_P_MOBITEX	0x0015		/* Mobitex (kaz@cafe.net)	*/
+#define ETH_P_CONTROL	0x0016		/* Card specific control frames */
+#define ETH_P_IRDA	0x0017		/* Linux-IrDA			*/
+#define ETH_P_ECONET	0x0018		/* Acorn Econet			*/
+
+/*
+ *	This is an Ethernet frame header.
+ */
+
+struct ethhdr {
+	unsigned char	h_dest[ETH_ALEN];	/* destination eth addr	*/
+	unsigned char	h_source[ETH_ALEN];	/* source ether addr	*/
+	unsigned short	h_proto;		/* packet type ID field	*/
+};
+
+struct _vlan {
+	unsigned short       h_vlan_TCI;                /* Encapsulates priority and VLAN ID */
+	unsigned short       h_vlan_encapsulated_proto;
+};
+
+
+
+#define get_vlan_id(pvlan) ((ntohs((unsigned short)pvlan->h_vlan_TCI)) & 0xfff)
+#define get_vlan_priority(pvlan) ((ntohs((unsigned short)pvlan->h_vlan_TCI))>>13)
+#define get_vlan_encap_proto(pvlan) (ntohs((unsigned short)pvlan->h_vlan_encapsulated_proto))
+
+
+#endif	/* _LINUX_IF_ETHER_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ip.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ip.h
new file mode 100644
index 000000000000..4feb98fb072a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/ip.h
@@ -0,0 +1,135 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_IP_H
+#define _LINUX_IP_H
+
+/* SOL_IP socket options */
+
+#define IPTOS_TOS_MASK		0x1E
+#define IPTOS_TOS(tos)		((tos)&IPTOS_TOS_MASK)
+#define	IPTOS_LOWDELAY		0x10
+#define	IPTOS_THROUGHPUT	0x08
+#define	IPTOS_RELIABILITY	0x04
+#define	IPTOS_MINCOST		0x02
+
+#define IPTOS_PREC_MASK		0xE0
+#define IPTOS_PREC(tos)		((tos)&IPTOS_PREC_MASK)
+#define IPTOS_PREC_NETCONTROL           0xe0
+#define IPTOS_PREC_INTERNETCONTROL      0xc0
+#define IPTOS_PREC_CRITIC_ECP           0xa0
+#define IPTOS_PREC_FLASHOVERRIDE        0x80
+#define IPTOS_PREC_FLASH                0x60
+#define IPTOS_PREC_IMMEDIATE            0x40
+#define IPTOS_PREC_PRIORITY             0x20
+#define IPTOS_PREC_ROUTINE              0x00
+
+
+/* IP options */
+#define IPOPT_COPY		0x80
+#define IPOPT_CLASS_MASK	0x60
+#define IPOPT_NUMBER_MASK	0x1f
+
+#define	IPOPT_COPIED(o)		((o)&IPOPT_COPY)
+#define	IPOPT_CLASS(o)		((o)&IPOPT_CLASS_MASK)
+#define	IPOPT_NUMBER(o)		((o)&IPOPT_NUMBER_MASK)
+
+#define	IPOPT_CONTROL		0x00
+#define	IPOPT_RESERVED1		0x20
+#define	IPOPT_MEASUREMENT	0x40
+#define	IPOPT_RESERVED2		0x60
+
+#define IPOPT_END	(0 | IPOPT_CONTROL)
+#define IPOPT_NOOP	(1 | IPOPT_CONTROL)
+#define IPOPT_SEC	(2 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_LSRR	(3 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_TIMESTAMP	(4 | IPOPT_MEASUREMENT)
+#define IPOPT_RR	(7 | IPOPT_CONTROL)
+#define IPOPT_SID	(8 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_SSRR	(9 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_RA	(20 | IPOPT_CONTROL | IPOPT_COPY)
+
+#define IPVERSION	4
+#define MAXTTL		255
+#define IPDEFTTL	64
+
+/* struct timestamp, struct route and MAX_ROUTES are removed.
+
+   REASONS: it is clear that nobody used them because:
+   - MAX_ROUTES value was wrong.
+   - "struct route" was wrong.
+   - "struct timestamp" had fatally misaligned bitfields and was completely unusable.
+ */
+
+#define IPOPT_OPTVAL 0
+#define IPOPT_OLEN   1
+#define IPOPT_OFFSET 2
+#define IPOPT_MINOFF 4
+#define MAX_IPOPTLEN 40
+#define IPOPT_NOP IPOPT_NOOP
+#define IPOPT_EOL IPOPT_END
+#define IPOPT_TS  IPOPT_TIMESTAMP
+
+#define	IPOPT_TS_TSONLY		0		/* timestamps only */
+#define	IPOPT_TS_TSANDADDR	1		/* timestamps and addresses */
+#define	IPOPT_TS_PRESPEC	3		/* specified modules only */
+
+#ifdef PLATFORM_LINUX
+
+struct ip_options {
+	__u32		faddr;				/* Saved first hop address */
+	unsigned char	optlen;
+	unsigned char srr;
+	unsigned char rr;
+	unsigned char ts;
+	unsigned char is_setbyuser:1,			/* Set by setsockopt?			*/
+		 is_data:1,			/* Options in __data, rather than skb	*/
+		 is_strictroute:1,		/* Strict source route			*/
+		 srr_is_hit:1,			/* Packet destination addr was our one	*/
+		 is_changed:1,			/* IP checksum more not valid		*/
+		 rr_needaddr:1,			/* Need to record addr of outgoing dev	*/
+		 ts_needtime:1,			/* Need to record timestamp		*/
+		 ts_needaddr:1;			/* Need to record addr of outgoing dev */
+	unsigned char router_alert;
+	unsigned char __pad1;
+	unsigned char __pad2;
+	unsigned char __data[0];
+};
+
+#define optlength(opt) (sizeof(struct ip_options) + opt->optlen)
+#endif
+
+struct iphdr {
+#if defined(__LITTLE_ENDIAN_BITFIELD)
+	__u8	ihl:4,
+		version:4;
+#elif defined (__BIG_ENDIAN_BITFIELD)
+	__u8	version:4,
+		ihl:4;
+#else
+#error	"Please fix <asm/byteorder.h>"
+#endif
+	__u8	tos;
+	__u16	tot_len;
+	__u16	id;
+	__u16	frag_off;
+	__u8	ttl;
+	__u8	protocol;
+	__u16	check;
+	__u32	saddr;
+	__u32	daddr;
+	/*The options start here. */
+};
+
+#endif	/* _LINUX_IP_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/linux/wireless.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/linux/wireless.h
new file mode 100644
index 000000000000..c7f4a6c9b66a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/linux/wireless.h
@@ -0,0 +1,87 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _LINUX_WIRELESS_H
+#define _LINUX_WIRELESS_H
+
+/***************************** INCLUDES *****************************/
+
+#if 0
+	#include <linux/types.h>		/* for __u* and __s* typedefs */
+	#include <linux/socket.h>		/* for "struct sockaddr" et al	*/
+	#include <linux/if.h>			/* for IFNAMSIZ and co... */
+#else
+	#define __user
+	/* typedef uint16_t	__u16; */
+	#include <sys/socket.h>			/* for "struct sockaddr" et al	*/
+	#include <net/if.h>			/* for IFNAMSIZ and co... */
+#endif
+
+/****************************** TYPES ******************************/
+#ifdef CONFIG_COMPAT
+struct compat_iw_point {
+	compat_caddr_t pointer;
+	__u16 length;
+	__u16 flags;
+};
+#endif
+/* --------------------------- SUBTYPES --------------------------- */
+/*
+ *	For all data larger than 16 octets, we need to use a
+ *	pointer to memory allocated in user space.
+ */
+struct	iw_point {
+	void __user	*pointer;	/* Pointer to the data  (in user space) */
+	__u16		length;		/* number of fields or size in bytes */
+	__u16		flags;		/* Optional params */
+};
+
+
+/* ------------------------ IOCTL REQUEST ------------------------ */
+/*
+ * This structure defines the payload of an ioctl, and is used
+ * below.
+ *
+ * Note that this structure should fit on the memory footprint
+ * of iwreq (which is the same as ifreq), which mean a max size of
+ * 16 octets = 128 bits. Warning, pointers might be 64 bits wide...
+ * You should check this when increasing the structures defined
+ * above in this file...
+ */
+union	iwreq_data {
+	/* Config - generic */
+	char		name[IFNAMSIZ];
+	/* Name : used to verify the presence of  wireless extensions.
+	 * Name of the protocol/provider... */
+
+	struct iw_point	data;		/* Other large parameters */
+};
+
+/*
+ * The structure to exchange data for ioctl.
+ * This structure is the same as 'struct ifreq', but (re)defined for
+ * convenience...
+ * Do I need to remind you about structure size (32 octets) ?
+ */
+struct	iwreq {
+	union {
+		char	ifrn_name[IFNAMSIZ];	/* if name, e.g. "eth0" */
+	} ifr_ifrn;
+
+	/* Data part (defined just above) */
+	union	iwreq_data	u;
+};
+
+#endif	/* _LINUX_WIRELESS_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/mlme_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/mlme_osdep.h
new file mode 100644
index 000000000000..131eb092560f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/mlme_osdep.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+extern void rtw_os_indicate_disconnect(_adapter *adapter, u16 reason, u8 locally_generated);
+extern void rtw_os_indicate_connect(_adapter *adapter);
+void rtw_os_indicate_scan_done(_adapter *padapter, bool aborted);
+extern void rtw_report_sec_ie(_adapter *adapter, u8 authmode, u8 *sec_ie);
+
+void rtw_reset_securitypriv(_adapter *adapter);
+
+#endif /* _MLME_OSDEP_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/mp_custom_oid.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/mp_custom_oid.h
new file mode 100644
index 000000000000..8ed14413c62d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/mp_custom_oid.h
@@ -0,0 +1,348 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__CUSTOM_OID_H
+#define __CUSTOM_OID_H
+
+/* by Owen
+ * 0xFF818000 - 0xFF81802F		RTL8180 Mass Production Kit
+ * 0xFF818500 - 0xFF81850F		RTL8185 Setup Utility
+ * 0xFF818580 - 0xFF81858F		RTL8185 Phy Status Utility */
+
+/*  */
+
+/* by Owen for Production Kit
+ * For Production Kit with Agilent Equipments
+ * in order to make our custom oids hopefully somewhat unique
+ * we will use 0xFF (indicating implementation specific OID)
+ * 81(first byte of non zero Realtek unique identifier)
+ * 80 (second byte of non zero Realtek unique identifier)
+ * XX (the custom OID number - providing 255 possible custom oids) */
+
+#define OID_RT_PRO_RESET_DUT				0xFF818000
+#define OID_RT_PRO_SET_DATA_RATE			0xFF818001
+#define OID_RT_PRO_START_TEST				0xFF818002
+#define OID_RT_PRO_STOP_TEST			0xFF818003
+#define OID_RT_PRO_SET_PREAMBLE				0xFF818004
+#define OID_RT_PRO_SET_SCRAMBLER			0xFF818005
+#define OID_RT_PRO_SET_FILTER_BB			0xFF818006
+#define OID_RT_PRO_SET_MANUAL_DIVERSITY_BB		0xFF818007
+#define OID_RT_PRO_SET_CHANNEL_DIRECT_CALL		0xFF818008
+#define OID_RT_PRO_SET_SLEEP_MODE_DIRECT_CALL		0xFF818009
+#define OID_RT_PRO_SET_WAKE_MODE_DIRECT_CALL		0xFF81800A
+
+#define OID_RT_PRO_SET_TX_ANTENNA_BB			0xFF81800D
+#define OID_RT_PRO_SET_ANTENNA_BB			0xFF81800E
+#define OID_RT_PRO_SET_CR_SCRAMBLER			0xFF81800F
+#define OID_RT_PRO_SET_CR_NEW_FILTER			0xFF818010
+#define OID_RT_PRO_SET_TX_POWER_CONTROL			0xFF818011
+#define OID_RT_PRO_SET_CR_TX_CONFIG			0xFF818012
+#define OID_RT_PRO_GET_TX_POWER_CONTROL			0xFF818013
+#define OID_RT_PRO_GET_CR_SIGNAL_QUALITY		0xFF818014
+#define OID_RT_PRO_SET_CR_SETPOINT			0xFF818015
+#define OID_RT_PRO_SET_INTEGRATOR			0xFF818016
+#define OID_RT_PRO_SET_SIGNAL_QUALITY			0xFF818017
+#define OID_RT_PRO_GET_INTEGRATOR			0xFF818018
+#define OID_RT_PRO_GET_SIGNAL_QUALITY			0xFF818019
+#define OID_RT_PRO_QUERY_EEPROM_TYPE			0xFF81801A
+#define OID_RT_PRO_WRITE_MAC_ADDRESS			0xFF81801B
+#define OID_RT_PRO_READ_MAC_ADDRESS			0xFF81801C
+#define OID_RT_PRO_WRITE_CIS_DATA			0xFF81801D
+#define OID_RT_PRO_READ_CIS_DATA			0xFF81801E
+#define OID_RT_PRO_WRITE_POWER_CONTROL			0xFF81801F
+#define OID_RT_PRO_READ_POWER_CONTROL			0xFF818020
+#define OID_RT_PRO_WRITE_EEPROM				0xFF818021
+#define OID_RT_PRO_READ_EEPROM				0xFF818022
+#define OID_RT_PRO_RESET_TX_PACKET_SENT			0xFF818023
+#define OID_RT_PRO_QUERY_TX_PACKET_SENT			0xFF818024
+#define OID_RT_PRO_RESET_RX_PACKET_RECEIVED		0xFF818025
+#define OID_RT_PRO_QUERY_RX_PACKET_RECEIVED		0xFF818026
+#define OID_RT_PRO_QUERY_RX_PACKET_CRC32_ERROR		0xFF818027
+#define OID_RT_PRO_QUERY_CURRENT_ADDRESS		0xFF818028
+#define OID_RT_PRO_QUERY_PERMANENT_ADDRESS		0xFF818029
+#define OID_RT_PRO_SET_PHILIPS_RF_PARAMETERS		0xFF81802A
+#define OID_RT_PRO_RECEIVE_PACKET			0xFF81802C
+/* added by Owen on 04/08/03 for Cameo's request */
+#define OID_RT_PRO_WRITE_EEPROM_BYTE			0xFF81802D
+#define OID_RT_PRO_READ_EEPROM_BYTE			0xFF81802E
+#define OID_RT_PRO_SET_MODULATION			0xFF81802F
+/*  */
+
+/* Sean		 */
+#define OID_RT_DRIVER_OPTION				0xFF818080
+#define OID_RT_RF_OFF					0xFF818081
+#define OID_RT_AUTH_STATUS				0xFF818082
+
+/* ************************************************************************ */
+#define OID_RT_PRO_SET_CONTINUOUS_TX			0xFF81800B
+#define OID_RT_PRO_SET_SINGLE_CARRIER_TX		0xFF81800C
+#define OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX		0xFF81802B
+#define OID_RT_PRO_SET_SINGLE_TONE_TX			0xFF818043
+/* ************************************************************************ */
+
+
+/* by Owen for RTL8185 Phy Status Report Utility */
+#define OID_RT_UTILITY_FALSE_ALARM_COUNTERS				0xFF818580
+#define OID_RT_UTILITY_SELECT_DEBUG_MODE				0xFF818581
+#define OID_RT_UTILITY_SELECT_SUBCARRIER_NUMBER				0xFF818582
+#define OID_RT_UTILITY_GET_RSSI_STATUS					0xFF818583
+#define OID_RT_UTILITY_GET_FRAME_DETECTION_STATUS			0xFF818584
+#define OID_RT_UTILITY_GET_AGC_AND_FREQUENCY_OFFSET_ESTIMATION_STATUS	0xFF818585
+#define OID_RT_UTILITY_GET_CHANNEL_ESTIMATION_STATUS			0xFF818586
+/*  */
+
+/* by Owen on 03/09/19-03/09/22 for RTL8185 */
+#define OID_RT_WIRELESS_MODE				0xFF818500
+#define OID_RT_SUPPORTED_RATES				0xFF818501
+#define OID_RT_DESIRED_RATES				0xFF818502
+#define OID_RT_WIRELESS_MODE_STARTING_ADHOC		0xFF818503
+/*  */
+
+#define OID_RT_GET_CONNECT_STATE	0xFF030001
+#define OID_RT_RESCAN		0xFF030002
+#define OID_RT_SET_KEY_LENGTH				0xFF030003
+#define OID_RT_SET_DEFAULT_KEY_ID			0xFF030004
+
+#define OID_RT_SET_CHANNEL				0xFF010182
+#define OID_RT_SET_SNIFFER_MODE	0xFF010183
+#define OID_RT_GET_SIGNAL_QUALITY	0xFF010184
+#define OID_RT_GET_SMALL_PACKET_CRC			0xFF010185
+#define OID_RT_GET_MIDDLE_PACKET_CRC			0xFF010186
+#define OID_RT_GET_LARGE_PACKET_CRC			0xFF010187
+#define OID_RT_GET_TX_RETRY				0xFF010188
+#define OID_RT_GET_RX_RETRY				0xFF010189
+#define OID_RT_PRO_SET_FW_DIG_STATE			0xFF01018A/* S */
+#define OID_RT_PRO_SET_FW_RA_STATE			0xFF01018B/* S */
+
+#define OID_RT_GET_RX_TOTAL_PACKET			0xFF010190
+#define OID_RT_GET_TX_BEACON_OK				0xFF010191
+#define OID_RT_GET_TX_BEACON_ERR			0xFF010192
+#define OID_RT_GET_RX_ICV_ERR				0xFF010193
+#define OID_RT_SET_ENCRYPTION_ALGORITHM			0xFF010194
+#define OID_RT_SET_NO_AUTO_RESCAN			0xFF010195
+#define OID_RT_GET_PREAMBLE_MODE			0xFF010196
+#define OID_RT_GET_DRIVER_UP_DELTA_TIME			0xFF010197
+#define OID_RT_GET_AP_IP				0xFF010198
+#define OID_RT_GET_CHANNELPLAN				0xFF010199
+#define OID_RT_SET_PREAMBLE_MODE			0xFF01019A
+#define OID_RT_SET_BCN_INTVL				0xFF01019B
+#define OID_RT_GET_RF_VENDER				0xFF01019C
+#define OID_RT_DEDICATE_PROBE				0xFF01019D
+#define OID_RT_PRO_RX_FILTER_PATTERN			0xFF01019E
+
+#define OID_RT_GET_DCST_CURRENT_THRESHOLD		0xFF01019F
+
+#define OID_RT_GET_CCA_ERR				0xFF0101A0
+#define OID_RT_GET_CCA_UPGRADE_THRESHOLD		0xFF0101A1
+#define OID_RT_GET_CCA_FALLBACK_THRESHOLD		0xFF0101A2
+
+#define OID_RT_GET_CCA_UPGRADE_EVALUATE_TIMES		0xFF0101A3
+#define OID_RT_GET_CCA_FALLBACK_EVALUATE_TIMES		0xFF0101A4
+
+/* by Owen on 03/31/03 for Cameo's request */
+#define OID_RT_SET_RATE_ADAPTIVE			0xFF0101A5
+/*  */
+#define OID_RT_GET_DCST_EVALUATE_PERIOD			0xFF0101A5
+#define OID_RT_GET_DCST_TIME_UNIT_INDEX			0xFF0101A6
+#define OID_RT_GET_TOTAL_TX_BYTES			0xFF0101A7
+#define OID_RT_GET_TOTAL_RX_BYTES			0xFF0101A8
+#define OID_RT_CURRENT_TX_POWER_LEVEL			0xFF0101A9
+#define OID_RT_GET_ENC_KEY_MISMATCH_COUNT		0xFF0101AA
+#define OID_RT_GET_ENC_KEY_MATCH_COUNT			0xFF0101AB
+#define OID_RT_GET_CHANNEL				0xFF0101AC
+
+#define OID_RT_SET_CHANNELPLAN				0xFF0101AD
+#define OID_RT_GET_HARDWARE_RADIO_OFF			0xFF0101AE
+#define OID_RT_CHANNELPLAN_BY_COUNTRY			0xFF0101AF
+#define OID_RT_SCAN_AVAILABLE_BSSID			0xFF0101B0
+#define OID_RT_GET_HARDWARE_VERSION			0xFF0101B1
+#define OID_RT_GET_IS_ROAMING				0xFF0101B2
+#define OID_RT_GET_IS_PRIVACY				0xFF0101B3
+#define OID_RT_GET_KEY_MISMATCH				0xFF0101B4
+#define OID_RT_SET_RSSI_ROAM_TRAFFIC_TH			0xFF0101B5
+#define OID_RT_SET_RSSI_ROAM_SIGNAL_TH			0xFF0101B6
+#define OID_RT_RESET_LOG				0xFF0101B7
+#define OID_RT_GET_LOG					0xFF0101B8
+#define OID_RT_SET_INDICATE_HIDDEN_AP			0xFF0101B9
+#define OID_RT_GET_HEADER_FAIL				0xFF0101BA
+#define OID_RT_SUPPORTED_WIRELESS_MODE			0xFF0101BB
+#define OID_RT_GET_CHANNEL_LIST				0xFF0101BC
+#define OID_RT_GET_SCAN_IN_PROGRESS			0xFF0101BD
+#define OID_RT_GET_TX_INFO				0xFF0101BE
+#define OID_RT_RF_READ_WRITE_OFFSET			0xFF0101BF
+#define OID_RT_RF_READ_WRITE				0xFF0101C0
+
+/* For Netgear request. 2005.01.13, by rcnjko. */
+#define OID_RT_FORCED_DATA_RATE				0xFF0101C1
+#define OID_RT_WIRELESS_MODE_FOR_SCAN_LIST		0xFF0101C2
+/* For Netgear request. 2005.02.17, by rcnjko. */
+#define OID_RT_GET_BSS_WIRELESS_MODE			0xFF0101C3
+/* For AZ project. 2005.06.27, by rcnjko. */
+#define OID_RT_SCAN_WITH_MAGIC_PACKET			0xFF0101C4
+
+/* Vincent 8185MP */
+#define OID_RT_PRO_RX_FILTER				0xFF0111C0
+
+/* Andy TEST
+ * #define OID_RT_PRO_WRITE_REGISTRY			0xFF0111C1
+ * #define OID_RT_PRO_READ_REGISTRY			0xFF0111C2 */
+#define OID_CE_USB_WRITE_REGISTRY			0xFF0111C1
+#define OID_CE_USB_READ_REGISTRY			0xFF0111C2
+
+
+#define OID_RT_PRO_SET_INITIAL_GAIN			0xFF0111C3
+#define OID_RT_PRO_SET_BB_RF_STANDBY_MODE		0xFF0111C4
+#define OID_RT_PRO_SET_BB_RF_SHUTDOWN_MODE		0xFF0111C5
+#define OID_RT_PRO_SET_TX_CHARGE_PUMP			0xFF0111C6
+#define OID_RT_PRO_SET_RX_CHARGE_PUMP			0xFF0111C7
+#define OID_RT_PRO_RF_WRITE_REGISTRY			0xFF0111C8
+#define OID_RT_PRO_RF_READ_REGISTRY			0xFF0111C9
+#define OID_RT_PRO_QUERY_RF_TYPE			0xFF0111CA
+
+/* AP OID */
+#define OID_RT_AP_GET_ASSOCIATED_STATION_LIST		0xFF010300
+#define OID_RT_AP_GET_CURRENT_TIME_STAMP		0xFF010301
+#define OID_RT_AP_SWITCH_INTO_AP_MODE			0xFF010302
+#define OID_RT_AP_SET_DTIM_PERIOD			0xFF010303
+#define OID_RT_AP_SUPPORTED				0xFF010304	/* Determine if driver supports AP mode. 2004.08.27, by rcnjko. */
+#define OID_RT_AP_SET_PASSPHRASE			0xFF010305	/* Set WPA-PSK passphrase into authenticator. 2005.07.08, byrcnjko. */
+
+/* 8187MP. 2004.09.06, by rcnjko. */
+#define OID_RT_PRO8187_WI_POLL				0xFF818780
+#define OID_RT_PRO_WRITE_BB_REG				0xFF818781
+#define OID_RT_PRO_READ_BB_REG				0xFF818782
+#define OID_RT_PRO_WRITE_RF_REG				0xFF818783
+#define OID_RT_PRO_READ_RF_REG				0xFF818784
+
+/* Meeting House. added by Annie, 2005-07-20. */
+#define OID_RT_MH_VENDER_ID				0xFFEDC100
+
+/* 8711 MP OID added 20051230. */
+#define OID_RT_PRO8711_JOIN_BSS				0xFF871100/* S */
+
+#define OID_RT_PRO_READ_REGISTER			0xFF871101 /* Q */
+#define OID_RT_PRO_WRITE_REGISTER			0xFF871102 /* S */
+
+#define OID_RT_PRO_BURST_READ_REGISTER			0xFF871103 /* Q		 */
+#define OID_RT_PRO_BURST_WRITE_REGISTER 		0xFF871104 /* S */
+
+#define OID_RT_PRO_WRITE_TXCMD				0xFF871105 /* S */
+
+#define OID_RT_PRO_READ16_EEPROM			0xFF871106 /* Q */
+#define OID_RT_PRO_WRITE16_EEPROM			0xFF871107 /* S */
+
+#define OID_RT_PRO_H2C_SET_COMMAND			0xFF871108 /* S */
+#define OID_RT_PRO_H2C_QUERY_RESULT			0xFF871109 /* Q */
+
+#define OID_RT_PRO8711_WI_POLL				0xFF87110A /* Q */
+#define OID_RT_PRO8711_PKT_LOSS				0xFF87110B /* Q */
+#define OID_RT_RD_ATTRIB_MEM				0xFF87110C/* Q */
+#define OID_RT_WR_ATTRIB_MEM				0xFF87110D/* S */
+
+
+/* Method 2 for H2C/C2H */
+#define OID_RT_PRO_H2C_CMD_MODE				0xFF871110 /* S */
+#define OID_RT_PRO_H2C_CMD_RSP_MODE			0xFF871111 /* Q */
+#define OID_RT_PRO_H2C_CMD_EVENT_MODE			0xFF871112 /* S */
+#define OID_RT_PRO_WAIT_C2H_EVENT			0xFF871113 /* Q */
+#define OID_RT_PRO_RW_ACCESS_PROTOCOL_TEST		0xFF871114/* Q */
+
+#define OID_RT_PRO_SCSI_ACCESS_TEST			0xFF871115 /* Q, S */
+
+#define OID_RT_PRO_SCSI_TCPIPOFFLOAD_OUT		0xFF871116 /* S */
+#define OID_RT_PRO_SCSI_TCPIPOFFLOAD_IN			0xFF871117 /* Q, S */
+#define OID_RT_RRO_RX_PKT_VIA_IOCTRL			0xFF871118 /* Q */
+#define OID_RT_RRO_RX_PKTARRAY_VIA_IOCTRL		0xFF871119 /* Q */
+
+#define OID_RT_RPO_SET_PWRMGT_TEST			0xFF87111A /* S */
+#define OID_RT_PRO_QRY_PWRMGT_TEST			0XFF87111B /* Q */
+#define OID_RT_RPO_ASYNC_RWIO_TEST			0xFF87111C /* S */
+#define OID_RT_RPO_ASYNC_RWIO_POLL			0xFF87111D /* Q */
+#define OID_RT_PRO_SET_RF_INTFS				0xFF87111E /* S */
+#define OID_RT_POLL_RX_STATUS				0xFF87111F /* Q */
+
+#define OID_RT_PRO_CFG_DEBUG_MESSAGE			0xFF871120 /* Q, S */
+#define OID_RT_PRO_SET_DATA_RATE_EX			0xFF871121/* S */
+#define OID_RT_PRO_SET_BASIC_RATE			0xFF871122/* S */
+#define OID_RT_PRO_READ_TSSI				0xFF871123/* S */
+#define OID_RT_PRO_SET_POWER_TRACKING			0xFF871124/* S */
+
+
+#define OID_RT_PRO_QRY_PWRSTATE				0xFF871150 /* Q */
+#define OID_RT_PRO_SET_PWRSTATE				0xFF871151 /* S */
+
+/* Method 2 , using workitem */
+#define OID_RT_SET_READ_REG				0xFF871181 /* S */
+#define OID_RT_SET_WRITE_REG				0xFF871182 /* S */
+#define OID_RT_SET_BURST_READ_REG			0xFF871183 /* S */
+#define OID_RT_SET_BURST_WRITE_REG			0xFF871184 /* S */
+#define OID_RT_SET_WRITE_TXCMD				0xFF871185 /* S */
+#define OID_RT_SET_READ16_EEPROM			0xFF871186 /* S */
+#define OID_RT_SET_WRITE16_EEPROM			0xFF871187 /* S */
+#define OID_RT_QRY_POLL_WKITEM				0xFF871188 /* Q */
+
+/* For SDIO INTERFACE only */
+#define OID_RT_PRO_SYNCPAGERW_SRAM			0xFF8711A0 /* Q, S */
+#define OID_RT_PRO_871X_DRV_EXT			0xFF8711A1
+
+/* For USB INTERFACE only */
+#define OID_RT_PRO_USB_VENDOR_REQ			0xFF8711B0 /* Q, S */
+#define OID_RT_PRO_SCSI_AUTO_TEST			0xFF8711B1 /* S */
+#define OID_RT_PRO_USB_MAC_AC_FIFO_WRITE		0xFF8711B2 /* S */
+#define OID_RT_PRO_USB_MAC_RX_FIFO_READ			0xFF8711B3 /* Q */
+#define OID_RT_PRO_USB_MAC_RX_FIFO_POLLING		0xFF8711B4 /* Q */
+
+#define OID_RT_PRO_H2C_SET_RATE_TABLE			0xFF8711FB /* S */
+#define OID_RT_PRO_H2C_GET_RATE_TABLE			0xFF8711FC /* S */
+#define OID_RT_PRO_H2C_C2H_LBK_TEST			0xFF8711FE
+
+#define OID_RT_PRO_ENCRYPTION_CTRL			0xFF871200 /* Q, S */
+#define OID_RT_PRO_ADD_STA_INFO				0xFF871201 /* S */
+#define OID_RT_PRO_DELE_STA_INFO    			0xFF871202 /* S */
+#define OID_RT_PRO_QUERY_DR_VARIABLE   			0xFF871203 /* Q */
+
+#define OID_RT_PRO_RX_PACKET_TYPE			0xFF871204 /* Q, S */
+
+#define OID_RT_PRO_READ_EFUSE				0xFF871205 /* Q */
+#define OID_RT_PRO_WRITE_EFUSE				0xFF871206 /* S */
+#define OID_RT_PRO_RW_EFUSE_PGPKT			0xFF871207 /* Q, S */
+#define OID_RT_GET_EFUSE_CURRENT_SIZE			0xFF871208 /* Q */
+
+#define OID_RT_SET_BANDWIDTH				0xFF871209 /* S */
+#define OID_RT_SET_CRYSTAL_CAP				0xFF87120A /* S */
+
+#define OID_RT_SET_RX_PACKET_TYPE    			0xFF87120B /* S */
+
+#define OID_RT_GET_EFUSE_MAX_SIZE			0xFF87120C /* Q */
+
+#define OID_RT_PRO_SET_TX_AGC_OFFSET			0xFF87120D /* S */
+
+#define OID_RT_PRO_SET_PKT_TEST_MODE			0xFF87120E /* S */
+
+#define OID_RT_PRO_FOR_EVM_TEST_SETTING			0xFF87120F /* S */
+
+#define OID_RT_PRO_GET_THERMAL_METER			0xFF871210 /* Q */
+
+#define OID_RT_RESET_PHY_RX_PACKET_COUNT		0xFF871211 /* S */
+#define OID_RT_GET_PHY_RX_PACKET_RECEIVED		0xFF871212 /* Q */
+#define OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR		0xFF871213 /* Q */
+
+#define OID_RT_SET_POWER_DOWN				0xFF871214 /* S */
+
+#define OID_RT_GET_POWER_MODE				0xFF871215 /* Q */
+
+#define OID_RT_PRO_EFUSE				0xFF871216 /* Q, S */
+#define OID_RT_PRO_EFUSE_MAP				0xFF871217 /* Q, S */
+
+#endif /* #ifndef	__CUSTOM_OID_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/nic_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/nic_spec.h
new file mode 100644
index 000000000000..913ef9ba801a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/nic_spec.h
@@ -0,0 +1,41 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __NIC_SPEC_H__
+#define __NIC_SPEC_H__
+
+#include <drv_conf.h>
+
+#define RTL8711_MCTRL_		(0x20000)
+#define RTL8711_UART_		(0x30000)
+#define RTL8711_TIMER_		(0x40000)
+#define RTL8711_FINT_		(0x50000)
+#define RTL8711_HINT_		(0x50000)
+#define RTL8711_GPIO_		(0x60000)
+#define RTL8711_WLANCTRL_	(0x200000)
+#define RTL8711_WLANFF_		(0xe00000)
+#define RTL8711_HCICTRL_	(0x600000)
+#define RTL8711_SYSCFG_		(0x620000)
+#define RTL8711_SYSCTRL_	(0x620000)
+#define RTL8711_MCCTRL_		(0x020000)
+
+
+#include <rtl8711_regdef.h>
+
+#include <rtl8711_bitdef.h>
+
+
+#endif /* __RTL8711_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_intf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_intf.h
new file mode 100644
index 000000000000..7be08808d34f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_intf.h
@@ -0,0 +1,167 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+struct intf_priv {
+
+	u8 *intf_dev;
+	u32	max_iosz;	/* USB2.0: 128, USB1.1: 64, SDIO:64 */
+	u32	max_xmitsz; /* USB2.0: unlimited, SDIO:512 */
+	u32	max_recvsz; /* USB2.0: unlimited, SDIO:512 */
+
+	volatile u8 *io_rwmem;
+	volatile u8 *allocated_io_rwmem;
+	u32	io_wsz; /* unit: 4bytes */
+	u32	io_rsz;/* unit: 4bytes */
+	u8 intf_status;
+
+	void (*_bus_io)(u8 *priv);
+
+	/*
+	Under Sync. IRP (SDIO/USB)
+	A protection mechanism is necessary for the io_rwmem(read/write protocol)
+
+	Under Async. IRP (SDIO/USB)
+	The protection mechanism is through the pending queue.
+	*/
+
+	_mutex ioctl_mutex;
+
+
+#ifdef PLATFORM_LINUX
+#ifdef CONFIG_USB_HCI
+	/* when in USB, IO is through interrupt in/out endpoints */
+	struct usb_device	*udev;
+	PURB	piorw_urb;
+	u8 io_irp_cnt;
+	u8 bio_irp_pending;
+	_sema io_retevt;
+	_timer	io_timer;
+	u8 bio_irp_timeout;
+	u8 bio_timer_cancel;
+#endif
+#endif
+
+#ifdef PLATFORM_OS_XP
+#ifdef CONFIG_SDIO_HCI
+	/* below is for io_rwmem... */
+	PMDL pmdl;
+	PSDBUS_REQUEST_PACKET  sdrp;
+	PSDBUS_REQUEST_PACKET  recv_sdrp;
+	PSDBUS_REQUEST_PACKET  xmit_sdrp;
+
+	PIRP		piorw_irp;
+
+#endif
+#ifdef CONFIG_USB_HCI
+	PURB	piorw_urb;
+	PIRP		piorw_irp;
+	u8 io_irp_cnt;
+	u8 bio_irp_pending;
+	_sema io_retevt;
+#endif
+#endif
+
+};
+
+
+#ifdef CONFIG_R871X_TEST
+	int rtw_start_pseudo_adhoc(_adapter *padapter);
+	int rtw_stop_pseudo_adhoc(_adapter *padapter);
+#endif
+
+struct dvobj_priv *devobj_init(void);
+void devobj_deinit(struct dvobj_priv *pdvobj);
+
+u8 rtw_init_drv_sw(_adapter *padapter);
+u8 rtw_free_drv_sw(_adapter *padapter);
+u8 rtw_reset_drv_sw(_adapter *padapter);
+void rtw_dev_unload(PADAPTER padapter);
+
+u32 rtw_start_drv_threads(_adapter *padapter);
+void rtw_stop_drv_threads(_adapter *padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+void rtw_cancel_dynamic_chk_timer(_adapter *padapter);
+#endif
+void rtw_cancel_all_timer(_adapter *padapter);
+
+uint loadparam(_adapter *adapter);
+
+#ifdef PLATFORM_LINUX
+int rtw_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
+
+int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname);
+struct net_device *rtw_init_netdev(_adapter *padapter);
+
+void rtw_os_ndev_free(_adapter *adapter);
+int rtw_os_ndev_init(_adapter *adapter, const char *name);
+void rtw_os_ndev_deinit(_adapter *adapter);
+void rtw_os_ndev_unregister(_adapter *adapter);
+void rtw_os_ndevs_unregister(struct dvobj_priv *dvobj);
+int rtw_os_ndevs_init(struct dvobj_priv *dvobj);
+void rtw_os_ndevs_deinit(struct dvobj_priv *dvobj);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+u16 rtw_recv_select_queue(struct sk_buff *skb);
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35) */
+
+int rtw_ndev_notifier_register(void);
+void rtw_ndev_notifier_unregister(void);
+void rtw_inetaddr_notifier_register(void);
+void rtw_inetaddr_notifier_unregister(void);
+
+#include "../os_dep/linux/rtw_proc.h"
+
+#ifdef CONFIG_IOCTL_CFG80211
+	#include "../os_dep/linux/ioctl_cfg80211.h"
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+u8 rtw_rtnl_lock_needed(struct dvobj_priv *dvobj);
+void rtw_set_rtnl_lock_holder(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl);
+
+#endif /* PLATFORM_LINUX */
+
+
+#ifdef PLATFORM_FREEBSD
+extern int rtw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data);
+#endif
+
+void rtw_ips_dev_unload(_adapter *padapter);
+
+#ifdef CONFIG_IPS
+int rtw_ips_pwr_up(_adapter *padapter);
+void rtw_ips_pwr_down(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_CONCURRENT_MODE
+struct _io_ops;
+struct dvobj_priv;
+_adapter *rtw_drv_add_vir_if(_adapter *primary_padapter, void (*set_intf_ops)(_adapter *primary_padapter, struct _io_ops *pops));
+void rtw_drv_stop_vir_ifaces(struct dvobj_priv *dvobj);
+void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj);
+#endif
+
+void rtw_ndev_destructor(_nic_hdl ndev);
+#ifdef CONFIG_ARP_KEEP_ALIVE
+int rtw_gw_addr_query(_adapter *padapter);
+#endif
+
+int rtw_suspend_common(_adapter *padapter);
+int rtw_resume_common(_adapter *padapter);
+
+#endif /* _OSDEP_INTF_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service.h
new file mode 100644
index 000000000000..442f0a7303bc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service.h
@@ -0,0 +1,792 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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
+#define RTW_RFRAME_UNAVAIL		3
+#define RTW_RFRAME_PKT_UNAVAIL	4
+#define RTW_RBUF_UNAVAIL		5
+#define RTW_RBUF_PKT_UNAVAIL	6
+#define RTW_SDIO_READ_PORT_FAIL	7
+#define RTW_ALREADY				8
+#define RTW_RA_RESOLVING		9
+#define RTW_BMC_NO_NEED			10
+
+/* #define RTW_STATUS_TIMEDOUT -110 */
+
+#undef _TRUE
+#define _TRUE		1
+
+#undef _FALSE
+#define _FALSE		0
+
+
+#ifdef PLATFORM_FREEBSD
+	#include <osdep_service_bsd.h>
+#endif
+
+#ifdef PLATFORM_LINUX
+	#include <linux/version.h>
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0))
+	#include <linux/sched/signal.h>
+	#include <linux/sched/types.h>
+#endif
+	#include <osdep_service_linux.h>
+#endif
+
+#ifdef PLATFORM_OS_XP
+	#include <osdep_service_xp.h>
+#endif
+
+#ifdef PLATFORM_OS_CE
+	#include <osdep_service_ce.h>
+#endif
+
+/* #include <rtw_byteorder.h> */
+
+#ifndef BIT
+	#define BIT(x)	(1 << (x))
+#endif
+
+#define BIT0	0x00000001
+#define BIT1	0x00000002
+#define BIT2	0x00000004
+#define BIT3	0x00000008
+#define BIT4	0x00000010
+#define BIT5	0x00000020
+#define BIT6	0x00000040
+#define BIT7	0x00000080
+#define BIT8	0x00000100
+#define BIT9	0x00000200
+#define BIT10	0x00000400
+#define BIT11	0x00000800
+#define BIT12	0x00001000
+#define BIT13	0x00002000
+#define BIT14	0x00004000
+#define BIT15	0x00008000
+#define BIT16	0x00010000
+#define BIT17	0x00020000
+#define BIT18	0x00040000
+#define BIT19	0x00080000
+#define BIT20	0x00100000
+#define BIT21	0x00200000
+#define BIT22	0x00400000
+#define BIT23	0x00800000
+#define BIT24	0x01000000
+#define BIT25	0x02000000
+#define BIT26	0x04000000
+#define BIT27	0x08000000
+#define BIT28	0x10000000
+#define BIT29	0x20000000
+#define BIT30	0x40000000
+#define BIT31	0x80000000
+#define BIT32	0x0100000000
+#define BIT33	0x0200000000
+#define BIT34	0x0400000000
+#define BIT35	0x0800000000
+#define BIT36	0x1000000000
+
+extern int RTW_STATUS_CODE(int error_code);
+
+#ifndef RTK_DMP_PLATFORM
+	#define CONFIG_USE_VMALLOC
+#endif
+
+/* flags used for rtw_mstat_update() */
+enum mstat_f {
+	/* type: 0x00ff */
+	MSTAT_TYPE_VIR = 0x00,
+	MSTAT_TYPE_PHY = 0x01,
+	MSTAT_TYPE_SKB = 0x02,
+	MSTAT_TYPE_USB = 0x03,
+	MSTAT_TYPE_MAX = 0x04,
+
+	/* func: 0xff00 */
+	MSTAT_FUNC_UNSPECIFIED = 0x00 << 8,
+	MSTAT_FUNC_IO = 0x01 << 8,
+	MSTAT_FUNC_TX_IO = 0x02 << 8,
+	MSTAT_FUNC_RX_IO = 0x03 << 8,
+	MSTAT_FUNC_TX = 0x04 << 8,
+	MSTAT_FUNC_RX = 0x05 << 8,
+	MSTAT_FUNC_CFG_VENDOR = 0x06 << 8,
+	MSTAT_FUNC_MAX = 0x07 << 8,
+};
+
+#define mstat_tf_idx(flags) ((flags) & 0xff)
+#define mstat_ff_idx(flags) (((flags) & 0xff00) >> 8)
+
+typedef enum mstat_status {
+	MSTAT_ALLOC_SUCCESS = 0,
+	MSTAT_ALLOC_FAIL,
+	MSTAT_FREE
+} MSTAT_STATUS;
+
+#ifdef DBG_MEM_ALLOC
+void rtw_mstat_update(const enum mstat_f flags, const MSTAT_STATUS status, u32 sz);
+void rtw_mstat_dump(void *sel);
+bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size);
+void *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_vmfree(void *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
+void *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_mfree(void *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
+
+struct sk_buff *dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_skb_free(struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line);
+struct sk_buff *dbg_rtw_skb_copy(const struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line);
+struct sk_buff *dbg_rtw_skb_clone(struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line);
+int dbg_rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line);
+#ifdef CONFIG_RTW_NAPI
+int dbg_rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line);
+#ifdef CONFIG_RTW_GRO
+gro_result_t dbg_rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line);
+#endif
+#endif /* CONFIG_RTW_NAPI */
+void dbg_rtw_skb_queue_purge(struct sk_buff_head *list, enum mstat_f flags, const char *func, int line);
+#ifdef CONFIG_USB_HCI
+void *dbg_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma, const enum mstat_f flags, const char *func, const int line);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_USE_VMALLOC
+#define rtw_vmalloc(sz)			dbg_rtw_vmalloc((sz), MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_zvmalloc(sz)			dbg_rtw_zvmalloc((sz), MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_vmfree(pbuf, sz)		dbg_rtw_vmfree((pbuf), (sz), MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_vmalloc_f(sz, mstat_f)			dbg_rtw_vmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_zvmalloc_f(sz, mstat_f)		dbg_rtw_zvmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_vmfree_f(pbuf, sz, mstat_f)	dbg_rtw_vmfree((pbuf), (sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#else /* CONFIG_USE_VMALLOC */
+#define rtw_vmalloc(sz)			dbg_rtw_malloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_zvmalloc(sz)			dbg_rtw_zmalloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_vmfree(pbuf, sz)		dbg_rtw_mfree((pbuf), (sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_vmalloc_f(sz, mstat_f)			dbg_rtw_malloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_zvmalloc_f(sz, mstat_f)		dbg_rtw_zmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_vmfree_f(pbuf, sz, mstat_f)	dbg_rtw_mfree((pbuf), (sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#endif /* CONFIG_USE_VMALLOC */
+#define rtw_malloc(sz)			dbg_rtw_malloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_zmalloc(sz)			dbg_rtw_zmalloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_mfree(pbuf, sz)		dbg_rtw_mfree((pbuf), (sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_malloc_f(sz, mstat_f)			dbg_rtw_malloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_zmalloc_f(sz, mstat_f)			dbg_rtw_zmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_mfree_f(pbuf, sz, mstat_f)		dbg_rtw_mfree((pbuf), (sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+
+#define rtw_skb_alloc(size)	dbg_rtw_skb_alloc((size), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_free(skb)	dbg_rtw_skb_free((skb), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_alloc_f(size, mstat_f)	dbg_rtw_skb_alloc((size), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_free_f(skb, mstat_f)	dbg_rtw_skb_free((skb), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_copy(skb)	dbg_rtw_skb_copy((skb), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_clone(skb)	dbg_rtw_skb_clone((skb), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_copy_f(skb, mstat_f)	dbg_rtw_skb_copy((skb), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_clone_f(skb, mstat_f)	dbg_rtw_skb_clone((skb), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_netif_rx(ndev, skb)	dbg_rtw_netif_rx(ndev, skb, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#ifdef CONFIG_RTW_NAPI
+#define rtw_netif_receive_skb(ndev, skb) dbg_rtw_netif_receive_skb(ndev, skb, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#ifdef CONFIG_RTW_GRO
+#define rtw_napi_gro_receive(napi, skb) dbg_rtw_napi_gro_receive(napi, skb, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#endif
+#endif /* CONFIG_RTW_NAPI */
+#define rtw_skb_queue_purge(sk_buff_head) dbg_rtw_skb_queue_purge(sk_buff_head, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#ifdef CONFIG_USB_HCI
+#define rtw_usb_buffer_alloc(dev, size, dma)		dbg_rtw_usb_buffer_alloc((dev), (size), (dma), MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
+#define rtw_usb_buffer_free(dev, size, addr, dma)	dbg_rtw_usb_buffer_free((dev), (size), (addr), (dma), MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
+#define rtw_usb_buffer_alloc_f(dev, size, dma, mstat_f)			dbg_rtw_usb_buffer_alloc((dev), (size), (dma), ((mstat_f) & 0xff00) | MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
+#define rtw_usb_buffer_free_f(dev, size, addr, dma, mstat_f)	dbg_rtw_usb_buffer_free((dev), (size), (addr), (dma), ((mstat_f) & 0xff00) | MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
+#endif /* CONFIG_USB_HCI */
+
+#else /* DBG_MEM_ALLOC */
+#define rtw_mstat_update(flag, status, sz) do {} while (0)
+#define rtw_mstat_dump(sel) do {} while (0)
+#define match_mstat_sniff_rules(flags, size) _FALSE
+void *_rtw_vmalloc(u32 sz);
+void *_rtw_zvmalloc(u32 sz);
+void _rtw_vmfree(void *pbuf, u32 sz);
+void *_rtw_zmalloc(u32 sz);
+void *_rtw_malloc(u32 sz);
+void _rtw_mfree(void *pbuf, u32 sz);
+
+struct sk_buff *_rtw_skb_alloc(u32 sz);
+void _rtw_skb_free(struct sk_buff *skb);
+struct sk_buff *_rtw_skb_copy(const struct sk_buff *skb);
+struct sk_buff *_rtw_skb_clone(struct sk_buff *skb);
+int _rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb);
+#ifdef CONFIG_RTW_NAPI
+int _rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb);
+#ifdef CONFIG_RTW_GRO
+gro_result_t _rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb);
+#endif
+#endif /* CONFIG_RTW_NAPI */
+void _rtw_skb_queue_purge(struct sk_buff_head *list);
+
+#ifdef CONFIG_USB_HCI
+void *_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma);
+void _rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_USE_VMALLOC
+#define rtw_vmalloc(sz)			_rtw_vmalloc((sz))
+#define rtw_zvmalloc(sz)			_rtw_zvmalloc((sz))
+#define rtw_vmfree(pbuf, sz)		_rtw_vmfree((pbuf), (sz))
+#define rtw_vmalloc_f(sz, mstat_f)			_rtw_vmalloc((sz))
+#define rtw_zvmalloc_f(sz, mstat_f)		_rtw_zvmalloc((sz))
+#define rtw_vmfree_f(pbuf, sz, mstat_f)	_rtw_vmfree((pbuf), (sz))
+#else /* CONFIG_USE_VMALLOC */
+#define rtw_vmalloc(sz)			_rtw_malloc((sz))
+#define rtw_zvmalloc(sz)			_rtw_zmalloc((sz))
+#define rtw_vmfree(pbuf, sz)		_rtw_mfree((pbuf), (sz))
+#define rtw_vmalloc_f(sz, mstat_f)			_rtw_malloc((sz))
+#define rtw_zvmalloc_f(sz, mstat_f)		_rtw_zmalloc((sz))
+#define rtw_vmfree_f(pbuf, sz, mstat_f)	_rtw_mfree((pbuf), (sz))
+#endif /* CONFIG_USE_VMALLOC */
+#define rtw_malloc(sz)			_rtw_malloc((sz))
+#define rtw_zmalloc(sz)			_rtw_zmalloc((sz))
+#define rtw_mfree(pbuf, sz)		_rtw_mfree((pbuf), (sz))
+#define rtw_malloc_f(sz, mstat_f)			_rtw_malloc((sz))
+#define rtw_zmalloc_f(sz, mstat_f)			_rtw_zmalloc((sz))
+#define rtw_mfree_f(pbuf, sz, mstat_f)		_rtw_mfree((pbuf), (sz))
+
+#define rtw_skb_alloc(size) _rtw_skb_alloc((size))
+#define rtw_skb_free(skb) _rtw_skb_free((skb))
+#define rtw_skb_alloc_f(size, mstat_f)	_rtw_skb_alloc((size))
+#define rtw_skb_free_f(skb, mstat_f)	_rtw_skb_free((skb))
+#define rtw_skb_copy(skb)	_rtw_skb_copy((skb))
+#define rtw_skb_clone(skb)	_rtw_skb_clone((skb))
+#define rtw_skb_copy_f(skb, mstat_f)	_rtw_skb_copy((skb))
+#define rtw_skb_clone_f(skb, mstat_f)	_rtw_skb_clone((skb))
+#define rtw_netif_rx(ndev, skb) _rtw_netif_rx(ndev, skb)
+#ifdef CONFIG_RTW_NAPI
+#define rtw_netif_receive_skb(ndev, skb) _rtw_netif_receive_skb(ndev, skb)
+#ifdef CONFIG_RTW_GRO
+#define rtw_napi_gro_receive(napi, skb) _rtw_napi_gro_receive(napi, skb)
+#endif
+#endif /* CONFIG_RTW_NAPI */
+#define rtw_skb_queue_purge(sk_buff_head) _rtw_skb_queue_purge(sk_buff_head)
+#ifdef CONFIG_USB_HCI
+#define rtw_usb_buffer_alloc(dev, size, dma) _rtw_usb_buffer_alloc((dev), (size), (dma))
+#define rtw_usb_buffer_free(dev, size, addr, dma) _rtw_usb_buffer_free((dev), (size), (addr), (dma))
+#define rtw_usb_buffer_alloc_f(dev, size, dma, mstat_f) _rtw_usb_buffer_alloc((dev), (size), (dma))
+#define rtw_usb_buffer_free_f(dev, size, addr, dma, mstat_f) _rtw_usb_buffer_free((dev), (size), (addr), (dma))
+#endif /* CONFIG_USB_HCI */
+#endif /* DBG_MEM_ALLOC */
+
+extern void	*rtw_malloc2d(int h, int w, size_t size);
+extern void	rtw_mfree2d(void *pbuf, int h, int w, int size);
+
+void rtw_os_pkt_free(_pkt *pkt);
+_pkt *rtw_os_pkt_copy(_pkt *pkt);
+void *rtw_os_pkt_data(_pkt *pkt);
+u32 rtw_os_pkt_len(_pkt *pkt);
+
+extern void	_rtw_memcpy(void *dec, const void *sour, u32 sz);
+extern void _rtw_memmove(void *dst, const void *src, u32 sz);
+extern int	_rtw_memcmp(const void *dst, const void *src, u32 sz);
+extern void	_rtw_memset(void *pbuf, int c, u32 sz);
+
+extern void	_rtw_init_listhead(_list *list);
+extern u32	rtw_is_list_empty(_list *phead);
+extern void	rtw_list_insert_head(_list *plist, _list *phead);
+extern void	rtw_list_insert_tail(_list *plist, _list *phead);
+void rtw_list_splice(_list *list, _list *head);
+void rtw_list_splice_init(_list *list, _list *head);
+void rtw_list_splice_tail(_list *list, _list *head);
+
+#ifndef PLATFORM_FREEBSD
+extern void	rtw_list_delete(_list *plist);
+#endif /* PLATFORM_FREEBSD */
+
+void rtw_hlist_head_init(rtw_hlist_head *h);
+void rtw_hlist_add_head(rtw_hlist_node *n, rtw_hlist_head *h);
+void rtw_hlist_del(rtw_hlist_node *n);
+void rtw_hlist_add_head_rcu(rtw_hlist_node *n, rtw_hlist_head *h);
+void rtw_hlist_del_rcu(rtw_hlist_node *n);
+
+extern void	_rtw_init_sema(_sema *sema, int init_val);
+extern void	_rtw_free_sema(_sema	*sema);
+extern void	_rtw_up_sema(_sema	*sema);
+extern u32	_rtw_down_sema(_sema *sema);
+extern void	_rtw_mutex_init(_mutex *pmutex);
+extern void	_rtw_mutex_free(_mutex *pmutex);
+#ifndef PLATFORM_FREEBSD
+extern void	_rtw_spinlock_init(_lock *plock);
+#endif /* PLATFORM_FREEBSD */
+extern void	_rtw_spinlock_free(_lock *plock);
+extern void	_rtw_spinlock(_lock	*plock);
+extern void	_rtw_spinunlock(_lock	*plock);
+extern void	_rtw_spinlock_ex(_lock	*plock);
+extern void	_rtw_spinunlock_ex(_lock	*plock);
+
+extern void	_rtw_init_queue(_queue *pqueue);
+extern void _rtw_deinit_queue(_queue *pqueue);
+extern u32	_rtw_queue_empty(_queue	*pqueue);
+extern u32	rtw_end_of_queue_search(_list *queue, _list *pelement);
+
+extern systime _rtw_get_current_time(void);
+extern u32	_rtw_systime_to_ms(systime stime);
+extern systime _rtw_ms_to_systime(u32 ms);
+extern systime _rtw_us_to_systime(u32 us);
+extern s32	_rtw_get_passing_time_ms(systime start);
+extern s32 _rtw_get_remaining_time_ms(systime end);
+extern s32	_rtw_get_time_interval_ms(systime start, systime end);
+extern bool _rtw_time_after(systime a, systime b);
+
+#ifdef DBG_SYSTIME
+#define rtw_get_current_time() ({systime __stime = _rtw_get_current_time(); __stime;})
+#define rtw_systime_to_ms(stime) ({u32 __ms = _rtw_systime_to_ms(stime); typecheck(systime, stime); __ms;})
+#define rtw_ms_to_systime(ms) ({systime __stime = _rtw_ms_to_systime(ms); __stime;})
+#define rtw_us_to_systime(us) ({systime __stime = _rtw_us_to_systime(us); __stime;})
+#define rtw_get_passing_time_ms(start) ({u32 __ms = _rtw_get_passing_time_ms(start); typecheck(systime, start); __ms;})
+#define rtw_get_remaining_time_ms(end) ({u32 __ms = _rtw_get_remaining_time_ms(end); typecheck(systime, end); __ms;})
+#define rtw_get_time_interval_ms(start, end) ({u32 __ms = _rtw_get_time_interval_ms(start, end); typecheck(systime, start); typecheck(systime, end); __ms;})
+#define rtw_time_after(a,b) ({bool __r = _rtw_time_after(a,b); typecheck(systime, a); typecheck(systime, b); __r;})
+#define rtw_time_before(a,b) ({bool __r = _rtw_time_after(b, a); typecheck(systime, a); typecheck(systime, b); __r;})
+#else
+#define rtw_get_current_time() _rtw_get_current_time()
+#define rtw_systime_to_ms(stime) _rtw_systime_to_ms(stime)
+#define rtw_ms_to_systime(ms) _rtw_ms_to_systime(ms)
+#define rtw_us_to_systime(us) _rtw_us_to_systime(us)
+#define rtw_get_passing_time_ms(start) _rtw_get_passing_time_ms(start)
+#define rtw_get_remaining_time_ms(end) _rtw_get_remaining_time_ms(end)
+#define rtw_get_time_interval_ms(start, end) _rtw_get_time_interval_ms(start, end)
+#define rtw_time_after(a,b) _rtw_time_after(a,b)
+#define rtw_time_before(a,b) _rtw_time_after(b,a)
+#endif
+
+extern void	rtw_sleep_schedulable(int ms);
+
+extern void	rtw_msleep_os(int ms);
+extern void	rtw_usleep_os(int us);
+
+extern u32	rtw_atoi(u8 *s);
+
+#ifdef DBG_DELAY_OS
+#define rtw_mdelay_os(ms) _rtw_mdelay_os((ms), __FUNCTION__, __LINE__)
+#define rtw_udelay_os(ms) _rtw_udelay_os((ms), __FUNCTION__, __LINE__)
+extern void _rtw_mdelay_os(int ms, const char *func, const int line);
+extern void _rtw_udelay_os(int us, const char *func, const int line);
+#else
+extern void	rtw_mdelay_os(int ms);
+extern void	rtw_udelay_os(int us);
+#endif
+
+extern void rtw_yield_os(void);
+
+
+extern void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc, void *ctx);
+
+
+__inline static unsigned char _cancel_timer_ex(_timer *ptimer)
+{
+	u8 bcancelled;
+
+	_cancel_timer(ptimer, &bcancelled);
+
+	return bcancelled;
+}
+
+static __inline void thread_enter(char *name)
+{
+#ifdef PLATFORM_LINUX
+	allow_signal(SIGTERM);
+#endif
+#ifdef PLATFORM_FREEBSD
+	printf("%s", "RTKTHREAD_enter");
+#endif
+}
+void thread_exit(_completion *comp);
+void _rtw_init_completion(_completion *comp);
+void _rtw_wait_for_comp_timeout(_completion *comp);
+void _rtw_wait_for_comp(_completion *comp);
+
+static inline bool rtw_thread_stop(_thread_hdl_ th)
+{
+#ifdef PLATFORM_LINUX
+	return kthread_stop(th);
+#endif
+}
+static inline void rtw_thread_wait_stop(void)
+{
+#ifdef PLATFORM_LINUX
+	#if 0
+	while (!kthread_should_stop())
+		rtw_msleep_os(10);
+	#else
+	set_current_state(TASK_INTERRUPTIBLE);
+	while (!kthread_should_stop()) {
+		schedule();
+		set_current_state(TASK_INTERRUPTIBLE);
+	}
+	__set_current_state(TASK_RUNNING);
+	#endif
+#endif
+}
+
+__inline static void flush_signals_thread(void)
+{
+#ifdef PLATFORM_LINUX
+	if (signal_pending(current))
+		flush_signals(current);
+#endif
+}
+
+__inline static _OS_STATUS res_to_status(sint res)
+{
+
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_MPIXEL) || defined (PLATFORM_FREEBSD)
+	return res;
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+	if (res == _SUCCESS)
+		return NDIS_STATUS_SUCCESS;
+	else
+		return NDIS_STATUS_FAILURE;
+
+#endif
+
+}
+
+__inline static void rtw_dump_stack(void)
+{
+#ifdef PLATFORM_LINUX
+	dump_stack();
+#endif
+}
+
+#ifdef PLATFORM_LINUX
+#define rtw_warn_on(condition) WARN_ON(condition)
+#else
+#define rtw_warn_on(condition) do {} while (0)
+#endif
+
+__inline static int rtw_bug_check(void *parg1, void *parg2, void *parg3, void *parg4)
+{
+	int ret = _TRUE;
+
+#ifdef PLATFORM_WINDOWS
+	if (((uint)parg1) <= 0x7fffffff ||
+	    ((uint)parg2) <= 0x7fffffff ||
+	    ((uint)parg3) <= 0x7fffffff ||
+	    ((uint)parg4) <= 0x7fffffff) {
+		ret = _FALSE;
+		KeBugCheckEx(0x87110000, (ULONG_PTR)parg1, (ULONG_PTR)parg2, (ULONG_PTR)parg3, (ULONG_PTR)parg4);
+	}
+#endif
+
+	return ret;
+
+}
+#ifdef PLATFORM_LINUX
+#define RTW_DIV_ROUND_UP(n, d)	DIV_ROUND_UP(n, d)
+#else /* !PLATFORM_LINUX */
+#define RTW_DIV_ROUND_UP(n, d)	(((n) + (d - 1)) / d)
+#endif /* !PLATFORM_LINUX */
+
+#define _RND(sz, r) ((((sz)+((r)-1))/(r))*(r))
+#define RND4(x)	(((x >> 2) + (((x & 3) == 0) ? 0 : 1)) << 2)
+
+__inline static u32 _RND4(u32 sz)
+{
+
+	u32	val;
+
+	val = ((sz >> 2) + ((sz & 3) ? 1 : 0)) << 2;
+
+	return val;
+
+}
+
+__inline static u32 _RND8(u32 sz)
+{
+
+	u32	val;
+
+	val = ((sz >> 3) + ((sz & 7) ? 1 : 0)) << 3;
+
+	return val;
+
+}
+
+__inline static u32 _RND128(u32 sz)
+{
+
+	u32	val;
+
+	val = ((sz >> 7) + ((sz & 127) ? 1 : 0)) << 7;
+
+	return val;
+
+}
+
+__inline static u32 _RND256(u32 sz)
+{
+
+	u32	val;
+
+	val = ((sz >> 8) + ((sz & 255) ? 1 : 0)) << 8;
+
+	return val;
+
+}
+
+__inline static u32 _RND512(u32 sz)
+{
+
+	u32	val;
+
+	val = ((sz >> 9) + ((sz & 511) ? 1 : 0)) << 9;
+
+	return val;
+
+}
+
+__inline static u32 bitshift(u32 bitmask)
+{
+	u32 i;
+
+	for (i = 0; i <= 31; i++)
+		if (((bitmask >> i) &  0x1) == 1)
+			break;
+
+	return i;
+}
+
+static inline int largest_bit(u32 bitmask)
+{
+	int i;
+
+	for (i = 31; i >= 0; i--)
+		if (bitmask & BIT(i))
+			break;
+
+	return i;
+}
+
+#define rtw_min(a, b) ((a > b) ? b : a)
+#define rtw_is_range_a_in_b(hi_a, lo_a, hi_b, lo_b) (((hi_a) <= (hi_b)) && ((lo_a) >= (lo_b)))
+#define rtw_is_range_overlap(hi_a, lo_a, hi_b, lo_b) (((hi_a) > (lo_b)) && ((lo_a) < (hi_b)))
+
+#ifndef MAC_FMT
+#define MAC_FMT "%02x:%02x:%02x:%02x:%02x:%02x"
+#endif
+#ifndef MAC_ARG
+#define MAC_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5]
+#endif
+
+
+extern void rtw_suspend_lock_init(void);
+extern void rtw_suspend_lock_uninit(void);
+extern void rtw_lock_suspend(void);
+extern void rtw_unlock_suspend(void);
+extern void rtw_lock_suspend_timeout(u32 timeout_ms);
+extern void rtw_lock_traffic_suspend_timeout(u32 timeout_ms);
+extern void rtw_resume_lock_suspend(void);
+extern void rtw_resume_unlock_suspend(void);
+#ifdef CONFIG_AP_WOWLAN
+extern void rtw_softap_lock_suspend(void);
+extern void rtw_softap_unlock_suspend(void);
+#endif
+
+extern void rtw_set_bit(int nr, unsigned long *addr);
+extern void rtw_clear_bit(int nr, unsigned long *addr);
+extern int rtw_test_and_clear_bit(int nr, unsigned long *addr);
+
+extern void ATOMIC_SET(ATOMIC_T *v, int i);
+extern int ATOMIC_READ(ATOMIC_T *v);
+extern void ATOMIC_ADD(ATOMIC_T *v, int i);
+extern void ATOMIC_SUB(ATOMIC_T *v, int i);
+extern void ATOMIC_INC(ATOMIC_T *v);
+extern void ATOMIC_DEC(ATOMIC_T *v);
+extern int ATOMIC_ADD_RETURN(ATOMIC_T *v, int i);
+extern int ATOMIC_SUB_RETURN(ATOMIC_T *v, int i);
+extern int ATOMIC_INC_RETURN(ATOMIC_T *v);
+extern int ATOMIC_DEC_RETURN(ATOMIC_T *v);
+extern bool ATOMIC_INC_UNLESS(ATOMIC_T *v, int u);
+
+/* File operation APIs, just for linux now */
+extern int rtw_is_file_readable(const char *path);
+extern int rtw_is_file_readable_with_size(const char *path, u32 *sz);
+extern int rtw_retrieve_from_file(const char *path, u8 *buf, u32 sz);
+extern int rtw_store_to_file(const char *path, u8 *buf, u32 sz);
+
+
+#ifndef PLATFORM_FREEBSD
+extern void rtw_free_netdev(struct net_device *netdev);
+#endif /* PLATFORM_FREEBSD */
+
+
+extern u64 rtw_modular64(u64 x, u64 y);
+extern u64 rtw_division64(u64 x, u64 y);
+extern u32 rtw_random32(void);
+
+/* Macros for handling unaligned memory accesses */
+
+#define RTW_GET_BE16(a) ((u16) (((a)[0] << 8) | (a)[1]))
+#define RTW_PUT_BE16(a, val)			\
+	do {					\
+		(a)[0] = ((u16) (val)) >> 8;	\
+		(a)[1] = ((u16) (val)) & 0xff;	\
+	} while (0)
+
+#define RTW_GET_LE16(a) ((u16) (((a)[1] << 8) | (a)[0]))
+#define RTW_PUT_LE16(a, val)			\
+	do {					\
+		(a)[1] = ((u16) (val)) >> 8;	\
+		(a)[0] = ((u16) (val)) & 0xff;	\
+	} while (0)
+
+#define RTW_GET_BE24(a) ((((u32) (a)[0]) << 16) | (((u32) (a)[1]) << 8) | \
+			 ((u32) (a)[2]))
+#define RTW_PUT_BE24(a, val)					\
+	do {							\
+		(a)[0] = (u8) ((((u32) (val)) >> 16) & 0xff);	\
+		(a)[1] = (u8) ((((u32) (val)) >> 8) & 0xff);	\
+		(a)[2] = (u8) (((u32) (val)) & 0xff);		\
+	} while (0)
+
+#define RTW_GET_BE32(a) ((((u32) (a)[0]) << 24) | (((u32) (a)[1]) << 16) | \
+			 (((u32) (a)[2]) << 8) | ((u32) (a)[3]))
+#define RTW_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 RTW_GET_LE32(a) ((((u32) (a)[3]) << 24) | (((u32) (a)[2]) << 16) | \
+			 (((u32) (a)[1]) << 8) | ((u32) (a)[0]))
+#define RTW_PUT_LE32(a, val)					\
+	do {							\
+		(a)[3] = (u8) ((((u32) (val)) >> 24) & 0xff);	\
+		(a)[2] = (u8) ((((u32) (val)) >> 16) & 0xff);	\
+		(a)[1] = (u8) ((((u32) (val)) >> 8) & 0xff);	\
+		(a)[0] = (u8) (((u32) (val)) & 0xff);		\
+	} while (0)
+
+#define RTW_GET_BE64(a) ((((u64) (a)[0]) << 56) | (((u64) (a)[1]) << 48) | \
+			 (((u64) (a)[2]) << 40) | (((u64) (a)[3]) << 32) | \
+			 (((u64) (a)[4]) << 24) | (((u64) (a)[5]) << 16) | \
+			 (((u64) (a)[6]) << 8) | ((u64) (a)[7]))
+#define RTW_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)
+
+#define RTW_GET_LE64(a) ((((u64) (a)[7]) << 56) | (((u64) (a)[6]) << 48) | \
+			 (((u64) (a)[5]) << 40) | (((u64) (a)[4]) << 32) | \
+			 (((u64) (a)[3]) << 24) | (((u64) (a)[2]) << 16) | \
+			 (((u64) (a)[1]) << 8) | ((u64) (a)[0]))
+#define RTW_PUT_LE64(a, val)					\
+	do {							\
+		(a)[7] = (u8) ((((u64) (val)) >> 56) & 0xff);	\
+		(a)[6] = (u8) ((((u64) (val)) >> 48) & 0xff);	\
+		(a)[5] = (u8) ((((u64) (val)) >> 40) & 0xff);	\
+		(a)[4] = (u8) ((((u64) (val)) >> 32) & 0xff);	\
+		(a)[3] = (u8) ((((u64) (val)) >> 24) & 0xff);	\
+		(a)[2] = (u8) ((((u64) (val)) >> 16) & 0xff);	\
+		(a)[1] = (u8) ((((u64) (val)) >> 8) & 0xff);	\
+		(a)[0] = (u8) (((u64) (val)) & 0xff);		\
+	} while (0)
+
+void rtw_buf_free(u8 **buf, u32 *buf_len);
+void rtw_buf_update(u8 **buf, u32 *buf_len, u8 *src, u32 src_len);
+
+struct rtw_cbuf {
+	u32 write;
+	u32 read;
+	u32 size;
+	void *bufs[0];
+};
+
+bool rtw_cbuf_full(struct rtw_cbuf *cbuf);
+bool rtw_cbuf_empty(struct rtw_cbuf *cbuf);
+bool rtw_cbuf_push(struct rtw_cbuf *cbuf, void *buf);
+void *rtw_cbuf_pop(struct rtw_cbuf *cbuf);
+struct rtw_cbuf *rtw_cbuf_alloc(u32 size);
+void rtw_cbuf_free(struct rtw_cbuf *cbuf);
+
+struct map_seg_t {
+	u16 sa;
+	u16 len;
+	u8 *c;
+};
+
+struct map_t {
+	u16 len;
+	u16 seg_num;
+	u8 init_value;
+	struct map_seg_t *segs;
+};
+
+#define MAPSEG_ARRAY_ENT(_sa, _len, _c, arg...) \
+	{ .sa = _sa, .len = _len, .c = (u8[_len]){ _c, ##arg}, }
+
+#define MAPSEG_PTR_ENT(_sa, _len, _p) \
+	{ .sa = _sa, .len = _len, .c = _p, }
+
+#define MAP_ENT(_len, _seg_num, _init_v, _seg, arg...) \
+	{ .len = _len, .seg_num = _seg_num, .init_value = _init_v, .segs = (struct map_seg_t[_seg_num]){ _seg, ##arg}, }
+
+int map_readN(const struct map_t *map, u16 offset, u16 len, u8 *buf);
+u8 map_read8(const struct map_t *map, u16 offset);
+
+struct blacklist_ent {
+	_list list;
+	u8 addr[ETH_ALEN];
+	systime exp_time;
+};
+
+int rtw_blacklist_add(_queue *blist, const u8 *addr, u32 timeout_ms);
+int rtw_blacklist_del(_queue *blist, const u8 *addr);
+int rtw_blacklist_search(_queue *blist, const u8 *addr);
+void rtw_blacklist_flush(_queue *blist);
+void dump_blacklist(void *sel, _queue *blist, const char *title);
+
+/* String handler */
+
+BOOLEAN is_null(char c);
+BOOLEAN is_all_null(char *c, int len);
+BOOLEAN is_eol(char c);
+BOOLEAN is_space(char c);
+BOOLEAN IsHexDigit(char chTmp);
+BOOLEAN is_alpha(char chTmp);
+char alpha_to_upper(char c);
+
+int hex2num_i(char c);
+int hex2byte_i(const char *hex);
+int hexstr2bin(const char *hex, u8 *buf, size_t len);
+
+/*
+ * Write formatted output to sized buffer
+ */
+#ifdef PLATFORM_LINUX
+#define rtw_sprintf(buf, size, format, arg...)	snprintf(buf, size, format, ##arg)
+#else /* !PLATFORM_LINUX */
+#error "NOT DEFINE \"rtw_sprintf\"!!"
+#endif /* !PLATFORM_LINUX */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_bsd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_bsd.h
new file mode 100644
index 000000000000..4412963ca1e8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_bsd.h
@@ -0,0 +1,756 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BSD_SERVICE_H_
+#define __OSDEP_BSD_SERVICE_H_
+
+
+#include <sys/cdefs.h>
+#include <sys/types.h>
+#include <sys/systm.h>
+#include <sys/param.h>
+#include <sys/sockio.h>
+#include <sys/sysctl.h>
+#include <sys/lock.h>
+#include <sys/mutex.h>
+#include <sys/mbuf.h>
+#include <sys/kernel.h>
+#include <sys/socket.h>
+#include <sys/systm.h>
+#include <sys/malloc.h>
+#include <sys/module.h>
+#include <sys/bus.h>
+#include <sys/endian.h>
+#include <sys/kdb.h>
+#include <sys/kthread.h>
+#include <sys/malloc.h>
+#include <sys/time.h>
+#include <machine/atomic.h>
+#include <machine/bus.h>
+#include <machine/resource.h>
+#include <sys/rman.h>
+
+#include <net/bpf.h>
+#include <net/if.h>
+#include <net/if_arp.h>
+#include <net/ethernet.h>
+#include <net/if_dl.h>
+#include <net/if_media.h>
+#include <net/if_types.h>
+#include <net/route.h>
+
+
+#include <netinet/in.h>
+#include <netinet/in_systm.h>
+#include <netinet/in_var.h>
+#include <netinet/if_ether.h>
+#include <if_ether.h>
+
+#include <net80211/ieee80211_var.h>
+#include <net80211/ieee80211_regdomain.h>
+#include <net80211/ieee80211_radiotap.h>
+#include <net80211/ieee80211_ratectl.h>
+
+#include <dev/usb/usb.h>
+#include <dev/usb/usbdi.h>
+#include "usbdevs.h"
+
+#define	USB_DEBUG_VAR rum_debug
+#include <dev/usb/usb_debug.h>
+
+#if 1 //Baron porting from linux, it's all temp solution, needs to check again
+#include <sys/sema.h>
+#include <sys/pcpu.h> /* XXX for PCPU_GET */
+//	typedef struct 	semaphore _sema;
+	typedef struct 	sema _sema;
+//	typedef	spinlock_t	_lock;
+	typedef	struct mtx	_lock;
+	typedef struct mtx 		_mutex;
+	typedef struct rtw_timer_list _timer;
+	struct list_head {
+	struct list_head *next, *prev;
+	};
+	struct	__queue	{
+		struct	list_head	queue;	
+		_lock	lock;
+	};
+
+	typedef	struct mbuf _pkt;
+	typedef struct mbuf	_buffer;
+	
+	typedef struct	__queue	_queue;
+	typedef struct	list_head	_list;
+	typedef	int	_OS_STATUS;
+	//typedef u32	_irqL;
+	typedef unsigned long _irqL;
+	typedef	struct	ifnet * _nic_hdl;
+	
+	typedef pid_t		_thread_hdl_;
+//	typedef struct thread		_thread_hdl_;
+	typedef void		thread_return;
+	typedef void*	thread_context;
+
+	typedef void timer_hdl_return;
+	typedef void* timer_hdl_context;
+	typedef struct work_struct _workitem;
+
+#define   KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))
+/* emulate a modern version */
+#define LINUX_VERSION_CODE KERNEL_VERSION(2, 6, 35)
+
+#define WIRELESS_EXT -1
+#define HZ hz
+#define spin_lock_irqsave mtx_lock_irqsave
+#define spin_lock_bh mtx_lock_irqsave
+#define mtx_lock_irqsave(lock, x) mtx_lock(lock)//{local_irq_save((x)); mtx_lock_spin((lock));}
+//#define IFT_RTW	0xf9 //ifnet allocate type for RTW
+#define free_netdev if_free
+#define LIST_CONTAINOR(ptr, type, member) \
+        ((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))
+#define container_of(p,t,n) (t*)((p)-&(((t*)0)->n))
+/* 
+ * Linux timers are emulated using FreeBSD callout functions
+ * (and taskqueue functionality).
+ *
+ * Currently no timer stats functionality.
+ *
+ * See (linux_compat) processes.c
+ *
+ */
+struct rtw_timer_list {
+	struct callout callout;
+	void (*function)(void *);
+	void *arg;
+};
+
+struct workqueue_struct;
+struct work_struct;
+typedef void (*work_func_t)(struct work_struct *work);
+/* Values for the state of an item of work (work_struct) */
+typedef enum work_state {
+        WORK_STATE_UNSET = 0,
+        WORK_STATE_CALLOUT_PENDING = 1,
+        WORK_STATE_TASK_PENDING = 2,
+        WORK_STATE_WORK_CANCELLED = 3        
+} work_state_t;
+
+struct work_struct {
+        struct task task; /* FreeBSD task */
+        work_state_t state; /* the pending or otherwise state of work. */
+        work_func_t func;       
+};
+#define spin_unlock_irqrestore mtx_unlock_irqrestore
+#define spin_unlock_bh mtx_unlock_irqrestore
+#define mtx_unlock_irqrestore(lock,x)    mtx_unlock(lock);
+extern void	_rtw_spinlock_init(_lock *plock);
+
+//modify private structure to match freebsd
+#define BITS_PER_LONG 32
+union ktime {
+	s64	tv64;
+#if BITS_PER_LONG != 64 && !defined(CONFIG_KTIME_SCALAR)
+	struct {
+#ifdef __BIG_ENDIAN
+	s32	sec, nsec;
+#else
+	s32	nsec, sec;
+#endif
+	} tv;
+#endif
+};
+#define kmemcheck_bitfield_begin(name)
+#define kmemcheck_bitfield_end(name)
+#define CHECKSUM_NONE 0
+typedef unsigned char *sk_buff_data_t;
+typedef union ktime ktime_t;		/* Kill this */
+
+void rtw_mtx_lock(_lock *plock);
+	
+void rtw_mtx_unlock(_lock *plock);
+
+/** 
+ *	struct sk_buff - socket buffer
+ *	@next: Next buffer in list
+ *	@prev: Previous buffer in list
+ *	@sk: Socket we are owned by
+ *	@tstamp: Time we arrived
+ *	@dev: Device we arrived on/are leaving by
+ *	@transport_header: Transport layer header
+ *	@network_header: Network layer header
+ *	@mac_header: Link layer header
+ *	@_skb_refdst: destination entry (with norefcount bit)
+ *	@sp: the security path, used for xfrm
+ *	@cb: Control buffer. Free for use by every layer. Put private vars here
+ *	@len: Length of actual data
+ *	@data_len: Data length
+ *	@mac_len: Length of link layer header
+ *	@hdr_len: writable header length of cloned skb
+ *	@csum: Checksum (must include start/offset pair)
+ *	@csum_start: Offset from skb->head where checksumming should start
+ *	@csum_offset: Offset from csum_start where checksum should be stored
+ *	@local_df: allow local fragmentation
+ *	@cloned: Head may be cloned (check refcnt to be sure)
+ *	@nohdr: Payload reference only, must not modify header
+ *	@pkt_type: Packet class
+ *	@fclone: skbuff clone status
+ *	@ip_summed: Driver fed us an IP checksum
+ *	@priority: Packet queueing priority
+ *	@users: User count - see {datagram,tcp}.c
+ *	@protocol: Packet protocol from driver
+ *	@truesize: Buffer size 
+ *	@head: Head of buffer
+ *	@data: Data head pointer
+ *	@tail: Tail pointer
+ *	@end: End pointer
+ *	@destructor: Destruct function
+ *	@mark: Generic packet mark
+ *	@nfct: Associated connection, if any
+ *	@ipvs_property: skbuff is owned by ipvs
+ *	@peeked: this packet has been seen already, so stats have been
+ *		done for it, don't do them again
+ *	@nf_trace: netfilter packet trace flag
+ *	@nfctinfo: Relationship of this skb to the connection
+ *	@nfct_reasm: netfilter conntrack re-assembly pointer
+ *	@nf_bridge: Saved data about a bridged frame - see br_netfilter.c
+ *	@skb_iif: ifindex of device we arrived on
+ *	@rxhash: the packet hash computed on receive
+ *	@queue_mapping: Queue mapping for multiqueue devices
+ *	@tc_index: Traffic control index
+ *	@tc_verd: traffic control verdict
+ *	@ndisc_nodetype: router type (from link layer)
+ *	@dma_cookie: a cookie to one of several possible DMA operations
+ *		done by skb DMA functions
+ *	@secmark: security marking
+ *	@vlan_tci: vlan tag control information
+ */
+
+struct sk_buff {
+	/* These two members must be first. */
+	struct sk_buff		*next;
+	struct sk_buff		*prev;
+
+	ktime_t			tstamp;
+
+	struct sock		*sk;
+	//struct net_device	*dev;
+	struct ifnet *dev;
+
+	/*
+	 * This is the control buffer. It is free to use for every
+	 * layer. Please put your private variables there. If you
+	 * want to keep them across layers you have to do a skb_clone()
+	 * first. This is owned by whoever has the skb queued ATM.
+	 */
+	char			cb[48] __aligned(8);
+
+	unsigned long		_skb_refdst;
+#ifdef CONFIG_XFRM
+	struct	sec_path	*sp;
+#endif
+	unsigned int		len,
+				data_len;
+	u16			mac_len,
+				hdr_len;
+	union {
+		u32		csum;
+		struct {
+			u16	csum_start;
+			u16	csum_offset;
+		}smbol2;
+	}smbol1;
+	u32			priority;
+	kmemcheck_bitfield_begin(flags1);
+	u8			local_df:1,
+				cloned:1,
+				ip_summed:2,
+				nohdr:1,
+				nfctinfo:3;
+	u8			pkt_type:3,
+				fclone:2,
+				ipvs_property:1,
+				peeked:1,
+				nf_trace:1;
+	kmemcheck_bitfield_end(flags1);
+	u16			protocol;
+
+	void			(*destructor)(struct sk_buff *skb);
+#if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE)
+	struct nf_conntrack	*nfct;
+	struct sk_buff		*nfct_reasm;
+#endif
+#ifdef CONFIG_BRIDGE_NETFILTER
+	struct nf_bridge_info	*nf_bridge;
+#endif
+
+	int			skb_iif;
+#ifdef CONFIG_NET_SCHED
+	u16			tc_index;	/* traffic control index */
+#ifdef CONFIG_NET_CLS_ACT
+	u16			tc_verd;	/* traffic control verdict */
+#endif
+#endif
+
+	u32			rxhash;
+
+	kmemcheck_bitfield_begin(flags2);
+	u16			queue_mapping:16;
+#ifdef CONFIG_IPV6_NDISC_NODETYPE
+	u8			ndisc_nodetype:2,
+				deliver_no_wcard:1;
+#else
+	u8			deliver_no_wcard:1;
+#endif
+	kmemcheck_bitfield_end(flags2);
+
+	/* 0/14 bit hole */
+
+#ifdef CONFIG_NET_DMA
+	dma_cookie_t		dma_cookie;
+#endif
+#ifdef CONFIG_NETWORK_SECMARK
+	u32			secmark;
+#endif
+	union {
+		u32		mark;
+		u32		dropcount;
+	}symbol3;
+
+	u16			vlan_tci;
+
+	sk_buff_data_t		transport_header;
+	sk_buff_data_t		network_header;
+	sk_buff_data_t		mac_header;
+	/* These elements must be at the end, see alloc_skb() for details.  */
+	sk_buff_data_t		tail;
+	sk_buff_data_t		end;
+	unsigned char		*head,
+				*data;
+	unsigned int		truesize;
+	atomic_t		users;
+};
+struct sk_buff_head {
+	/* These two members must be first. */
+	struct sk_buff	*next;
+	struct sk_buff	*prev;
+
+	u32		qlen;
+	_lock	lock;
+};
+#define skb_tail_pointer(skb)	skb->tail
+static inline unsigned char *skb_put(struct sk_buff *skb, unsigned int len)
+{
+	unsigned char *tmp = skb_tail_pointer(skb);
+	//SKB_LINEAR_ASSERT(skb);
+	skb->tail += len;
+	skb->len  += len;
+	return tmp;
+}
+
+static inline unsigned char *__skb_pull(struct sk_buff *skb, unsigned int len)
+{
+	skb->len -= len;
+	if(skb->len < skb->data_len)
+		printf("%s(),%d,error!\n",__FUNCTION__,__LINE__);
+	return skb->data += len;
+}
+static inline unsigned char *skb_pull(struct sk_buff *skb, unsigned int len)
+{
+	#ifdef PLATFORM_FREEBSD
+	return __skb_pull(skb, len);
+	#else
+	return unlikely(len > skb->len) ? NULL : __skb_pull(skb, len);
+	#endif //PLATFORM_FREEBSD
+}
+static inline u32 skb_queue_len(const struct sk_buff_head *list_)
+{
+	return list_->qlen;
+}
+static inline void __skb_insert(struct sk_buff *newsk,
+				struct sk_buff *prev, struct sk_buff *next,
+				struct sk_buff_head *list)
+{
+	newsk->next = next;
+	newsk->prev = prev;
+	next->prev  = prev->next = newsk;
+	list->qlen++;
+}
+static inline void __skb_queue_before(struct sk_buff_head *list,
+				      struct sk_buff *next,
+				      struct sk_buff *newsk)
+{
+	__skb_insert(newsk, next->prev, next, list);
+}
+static inline void skb_queue_tail(struct sk_buff_head *list,
+				   struct sk_buff *newsk)
+{
+	mtx_lock(&list->lock);
+	__skb_queue_before(list, (struct sk_buff *)list, newsk);
+	mtx_unlock(&list->lock);
+}
+static inline struct sk_buff *skb_peek(struct sk_buff_head *list_)
+{
+	struct sk_buff *list = ((struct sk_buff *)list_)->next;
+	if (list == (struct sk_buff *)list_)
+		list = NULL;
+	return list;
+}
+static inline void __skb_unlink(struct sk_buff *skb, struct sk_buff_head *list)
+{
+	struct sk_buff *next, *prev;
+
+	list->qlen--;
+	next	   = skb->next;
+	prev	   = skb->prev;
+	skb->next  = skb->prev = NULL;
+	next->prev = prev;
+	prev->next = next;
+}
+
+static inline struct sk_buff *skb_dequeue(struct sk_buff_head *list)
+{
+	mtx_lock(&list->lock);
+
+	struct sk_buff *skb = skb_peek(list);
+	if (skb)
+		__skb_unlink(skb, list);
+
+	mtx_unlock(&list->lock);
+
+	return skb;
+}
+static inline void skb_reserve(struct sk_buff *skb, int len)
+{
+	skb->data += len;
+	skb->tail += len;
+}
+static inline void __skb_queue_head_init(struct sk_buff_head *list)
+{
+	list->prev = list->next = (struct sk_buff *)list;
+	list->qlen = 0;
+}
+/*
+ * This function creates a split out lock class for each invocation;
+ * this is needed for now since a whole lot of users of the skb-queue
+ * infrastructure in drivers have different locking usage (in hardirq)
+ * than the networking core (in softirq only). In the long run either the
+ * network layer or drivers should need annotation to consolidate the
+ * main types of usage into 3 classes.
+ */
+static inline void skb_queue_head_init(struct sk_buff_head *list)
+{
+	_rtw_spinlock_init(&list->lock);
+	__skb_queue_head_init(list);
+}
+unsigned long copy_from_user(void *to, const void *from, unsigned long n);
+unsigned long copy_to_user(void *to, const void *from, unsigned long n);
+struct sk_buff * dev_alloc_skb(unsigned int size);
+struct sk_buff *skb_clone(const struct sk_buff *skb);
+void dev_kfree_skb_any(struct sk_buff *skb);
+#endif //Baron porting from linux, it's all temp solution, needs to check again
+
+
+#if 1 // kenny add Linux compatibility code for Linux USB driver
+#include <dev/usb/usb_compat_linux.h>
+
+#define __init		// __attribute ((constructor))
+#define __exit		// __attribute ((destructor))
+
+/*
+ * Definitions for module_init and module_exit macros.
+ *
+ * These macros will use the SYSINIT framework to call a specified
+ * function (with no arguments) on module loading or unloading.
+ * 
+ */
+
+void module_init_exit_wrapper(void *arg);
+
+#define module_init(initfn)                             \
+        SYSINIT(mod_init_ ## initfn,                    \
+                SI_SUB_KLD, SI_ORDER_FIRST,             \
+                module_init_exit_wrapper, initfn)
+
+#define module_exit(exitfn)                             \
+        SYSUNINIT(mod_exit_ ## exitfn,                  \
+                  SI_SUB_KLD, SI_ORDER_ANY,             \
+                  module_init_exit_wrapper, exitfn)
+
+/*
+ * The usb_register and usb_deregister functions are used to register
+ * usb drivers with the usb subsystem. 
+ */
+int usb_register(struct usb_driver *driver);
+int usb_deregister(struct usb_driver *driver);
+
+/*
+ * usb_get_dev and usb_put_dev - increment/decrement the reference count 
+ * of the usb device structure.
+ *
+ * Original body of usb_get_dev:
+ *
+ *       if (dev)
+ *               get_device(&dev->dev);
+ *       return dev;
+ *
+ * Reference counts are not currently used in this compatibility
+ * layer. So these functions will do nothing.
+ */
+static inline struct usb_device *
+usb_get_dev(struct usb_device *dev)
+{
+        return dev;
+}
+
+static inline void 
+usb_put_dev(struct usb_device *dev)
+{
+        return;
+}
+
+
+// rtw_usb_compat_linux
+int rtw_usb_submit_urb(struct urb *urb, uint16_t mem_flags);
+int rtw_usb_unlink_urb(struct urb *urb);
+int rtw_usb_clear_halt(struct usb_device *dev, struct usb_host_endpoint *uhe);
+int rtw_usb_control_msg(struct usb_device *dev, struct usb_host_endpoint *uhe,
+    uint8_t request, uint8_t requesttype,
+    uint16_t value, uint16_t index, void *data,
+    uint16_t size, usb_timeout_t timeout);
+int rtw_usb_set_interface(struct usb_device *dev, uint8_t iface_no, uint8_t alt_index);
+int rtw_usb_setup_endpoint(struct usb_device *dev,
+    struct usb_host_endpoint *uhe, usb_size_t bufsize);
+struct urb *rtw_usb_alloc_urb(uint16_t iso_packets, uint16_t mem_flags);
+struct usb_host_endpoint *rtw_usb_find_host_endpoint(struct usb_device *dev, uint8_t type, uint8_t ep);
+struct usb_host_interface *rtw_usb_altnum_to_altsetting(const struct usb_interface *intf, uint8_t alt_index);
+struct usb_interface *rtw_usb_ifnum_to_if(struct usb_device *dev, uint8_t iface_no);
+void *rtw_usbd_get_intfdata(struct usb_interface *intf);
+void rtw_usb_linux_register(void *arg);
+void rtw_usb_linux_deregister(void *arg);
+void rtw_usb_linux_free_device(struct usb_device *dev);
+void rtw_usb_free_urb(struct urb *urb);
+void rtw_usb_init_urb(struct urb *urb);
+void rtw_usb_kill_urb(struct urb *urb);
+void rtw_usb_set_intfdata(struct usb_interface *intf, void *data);
+void rtw_usb_fill_bulk_urb(struct urb *urb, struct usb_device *udev,
+    struct usb_host_endpoint *uhe, void *buf,
+    int length, usb_complete_t callback, void *arg);
+int rtw_usb_bulk_msg(struct usb_device *udev, struct usb_host_endpoint *uhe,
+    void *data, int len, uint16_t *pactlen, usb_timeout_t timeout);
+void *usb_get_intfdata(struct usb_interface *intf);
+int usb_linux_init_endpoints(struct usb_device *udev);
+
+
+
+typedef struct urb *  PURB;
+
+typedef unsigned gfp_t;
+#define __GFP_WAIT      ((gfp_t)0x10u)  /* Can wait and reschedule? */
+#define __GFP_HIGH      ((gfp_t)0x20u)  /* Should access emergency pools? */
+#define __GFP_IO        ((gfp_t)0x40u)  /* Can start physical IO? */
+#define __GFP_FS        ((gfp_t)0x80u)  /* Can call down to low-level FS? */
+#define __GFP_COLD      ((gfp_t)0x100u) /* Cache-cold page required */
+#define __GFP_NOWARN    ((gfp_t)0x200u) /* Suppress page allocation failure warning */
+#define __GFP_REPEAT    ((gfp_t)0x400u) /* Retry the allocation.  Might fail */
+#define __GFP_NOFAIL    ((gfp_t)0x800u) /* Retry for ever.  Cannot fail */
+#define __GFP_NORETRY   ((gfp_t)0x1000u)/* Do not retry.  Might fail */
+#define __GFP_NO_GROW   ((gfp_t)0x2000u)/* Slab internal usage */
+#define __GFP_COMP      ((gfp_t)0x4000u)/* Add compound page metadata */
+#define __GFP_ZERO      ((gfp_t)0x8000u)/* Return zeroed page on success */
+#define __GFP_NOMEMALLOC ((gfp_t)0x10000u) /* Don't use emergency reserves */
+#define __GFP_HARDWALL   ((gfp_t)0x20000u) /* Enforce hardwall cpuset memory allocs */
+
+/* This equals 0, but use constants in case they ever change */
+#define GFP_NOWAIT      (GFP_ATOMIC & ~__GFP_HIGH)
+/* GFP_ATOMIC means both !wait (__GFP_WAIT not set) and use emergency pool */
+#define GFP_ATOMIC      (__GFP_HIGH)
+#define GFP_NOIO        (__GFP_WAIT)
+#define GFP_NOFS        (__GFP_WAIT | __GFP_IO)
+#define GFP_KERNEL      (__GFP_WAIT | __GFP_IO | __GFP_FS)
+#define GFP_USER        (__GFP_WAIT | __GFP_IO | __GFP_FS | __GFP_HARDWALL)
+#define GFP_HIGHUSER    (__GFP_WAIT | __GFP_IO | __GFP_FS | __GFP_HARDWALL | \
+                         __GFP_HIGHMEM)
+
+
+#endif // kenny add Linux compatibility code for Linux USB
+
+__inline static _list *get_next(_list	*list)
+{
+	return list->next;
+}	
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return (&(queue->queue));
+}
+
+	
+#define LIST_CONTAINOR(ptr, type, member) \
+        ((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))	
+
+        
+__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_bh(plock, *pirqL);
+}
+
+__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_bh(plock, *pirqL);
+}
+
+__inline static void _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+
+		mtx_lock(pmutex);
+
+}
+
+
+__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+
+		mtx_unlock(pmutex);
+
+}
+static inline void __list_del(struct list_head * prev, struct list_head * next)
+{
+	next->prev = prev;
+	prev->next = next;
+}
+static inline void INIT_LIST_HEAD(struct list_head *list)
+{
+	list->next = list;
+	list->prev = list;
+}
+__inline static void rtw_list_delete(_list *plist)
+{
+	__list_del(plist->prev, plist->next);
+	INIT_LIST_HEAD(plist);
+}
+
+static inline void timer_hdl(void *ctx)
+{
+	_timer *timer = (_timer *)ctx;
+
+	rtw_mtx_lock(NULL);
+	if (callout_pending(&timer->callout)) {
+		/* callout was reset */
+		rtw_mtx_unlock(NULL);
+		return;
+	}
+
+	if (!callout_active(&timer->callout)) {
+		/* callout was stopped */
+		rtw_mtx_unlock(NULL);
+		return;
+	}
+
+	callout_deactivate(&timer->callout);
+
+	timer->function(timer->arg);
+
+	rtw_mtx_unlock(NULL);
+}
+
+static inline void _init_timer(_timer *ptimer, _nic_hdl padapter, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+	callout_init(&ptimer->callout, CALLOUT_MPSAFE);
+}
+
+__inline static void _set_timer(_timer *ptimer,u32 delay_time)
+{	
+	if (ptimer->function && ptimer->arg) {
+		rtw_mtx_lock(NULL);
+		callout_reset(&ptimer->callout, delay_time, timer_hdl, ptimer);
+		rtw_mtx_unlock(NULL);
+	}
+}
+
+__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)
+{
+	rtw_mtx_lock(NULL);
+	callout_drain(&ptimer->callout);
+	rtw_mtx_unlock(NULL);
+	*bcancelled = 1; /* assume an pending timer to be canceled */
+}
+
+__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
+{
+	printf("%s Not implement yet! \n",__FUNCTION__);
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+	printf("%s Not implement yet! \n",__FUNCTION__);
+//	schedule_work(pwork);
+}
+
+//
+// Global Mutex: can only be used at PASSIVE level.
+//
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+}
+
+#define ATOMIC_INIT(i)  { (i) }
+
+static __inline void thread_enter(char *name);
+
+//Atomic integer operations
+typedef uint32_t ATOMIC_T ;
+
+#define rtw_netdev_priv(netdev) (((struct ifnet *)netdev)->if_softc)
+
+#define rtw_free_netdev(netdev) if_free((netdev))
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ""
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) ""
+#define FUNC_NDEV_FMT "%s"
+#define FUNC_NDEV_ARG(ndev) __func__
+#define FUNC_ADPT_FMT "%s"
+#define FUNC_ADPT_ARG(adapter) __func__
+
+#define STRUCT_PACKED
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_ce.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_ce.h
new file mode 100644
index 000000000000..2bf65ef4741d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_ce.h
@@ -0,0 +1,200 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_CE_SERVICE_H_
+#define __OSDEP_CE_SERVICE_H_
+
+
+#include <ndis.h>
+#include <ntddndis.h>
+
+#ifdef CONFIG_SDIO_HCI
+#include "SDCardDDK.h"
+#endif
+
+#ifdef CONFIG_USB_HCI
+#include <usbdi.h>
+#endif
+
+typedef HANDLE 	_sema;
+typedef	LIST_ENTRY	_list;
+typedef NDIS_STATUS _OS_STATUS;
+
+typedef NDIS_SPIN_LOCK	_lock;
+
+typedef HANDLE 		_rwlock; //Mutex
+
+typedef u32	_irqL;
+
+typedef NDIS_HANDLE  _nic_hdl;
+
+struct rtw_timer_list {
+	NDIS_MINIPORT_TIMER ndis_timer;
+	void (*function)(void *);
+	void *arg;
+};
+
+struct	__queue	{
+	LIST_ENTRY	queue;
+	_lock	lock;
+};
+
+typedef	NDIS_PACKET	_pkt;
+typedef NDIS_BUFFER	_buffer;
+typedef struct	__queue	_queue;
+
+typedef HANDLE 	_thread_hdl_;
+typedef DWORD thread_return;
+typedef void*	thread_context;
+typedef NDIS_WORK_ITEM _workitem;
+
+
+
+#define SEMA_UPBND	(0x7FFFFFFF)   //8192
+
+__inline static _list *get_prev(_list	*list)
+{
+	return list->Blink;
+}
+	
+__inline static _list *get_next(_list	*list)
+{
+	return list->Flink;
+}
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return (&(queue->queue));
+}
+
+#define LIST_CONTAINOR(ptr, type, member) CONTAINING_RECORD(ptr, type, member)
+
+__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisAcquireSpinLock(plock);
+}
+
+__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisReleaseSpinLock(plock);
+}
+
+__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprAcquireSpinLock(plock);	
+}
+
+__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprReleaseSpinLock(plock);	
+}
+
+
+__inline static void _enter_hwio_critical(_rwlock *prwlock, _irqL *pirqL)
+{
+	WaitForSingleObject(*prwlock, INFINITE );
+
+}
+
+__inline static void _exit_hwio_critical(_rwlock *prwlock, _irqL *pirqL)
+{
+	ReleaseMutex(*prwlock);
+}
+
+__inline static void rtw_list_delete(_list *plist)
+{
+	RemoveEntryList(plist);
+	InitializeListHead(plist);
+}
+
+static inline void timer_hdl(
+	IN PVOID SystemSpecific1,
+	IN PVOID FunctionContext,
+	IN PVOID SystemSpecific2,
+	IN PVOID SystemSpecific3)
+{
+	_timer *timer = (_timer *)FunctionContext;
+
+	timer->function(timer->arg);
+}
+
+static inline void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+	NdisMInitializeTimer(&ptimer->ndis_timer, nic_hdl, timer_hdl, ptimer);
+}
+
+static inline void _set_timer(_timer *ptimer, u32 delay_time)
+{
+	NdisMSetTimer(ptimer, delay_time);
+}
+
+static inline void _cancel_timer(_timer *ptimer, u8 *bcancelled)
+{
+	NdisMCancelTimer(ptimer, bcancelled);
+}
+
+__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
+{
+
+	NdisInitializeWorkItem(pwork, pfunc, cntx);
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+	NdisScheduleWorkItem(pwork);
+}
+
+#define ATOMIC_INIT(i)  { (i) }
+
+//
+// Global Mutex: can only be used at PASSIVE level.
+//
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    while (NdisInterlockedIncrement((PULONG)&(_MutexCounter)) != 1)\
+    {                                                           \
+        NdisInterlockedDecrement((PULONG)&(_MutexCounter));        \
+        NdisMSleep(10000);                          \
+    }                                                           \
+}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    NdisInterlockedDecrement((PULONG)&(_MutexCounter));              \
+}
+
+// limitation of path length
+#define PATH_LENGTH_MAX MAX_PATH
+
+//Atomic integer operations
+#define ATOMIC_T LONG
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ""
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) ""
+#define FUNC_NDEV_FMT "%s"
+#define FUNC_NDEV_ARG(ndev) __func__
+#define FUNC_ADPT_FMT "%s"
+#define FUNC_ADPT_ARG(adapter) __func__
+
+#define STRUCT_PACKED
+
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_linux.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_linux.h
new file mode 100644
index 000000000000..769d6e44f3bc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_linux.h
@@ -0,0 +1,543 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_LINUX_SERVICE_H_
+#define __OSDEP_LINUX_SERVICE_H_
+
+#include <linux/version.h>
+#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>
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 5))
+	#include <linux/kref.h>
+#endif
+/* #include <linux/smp_lock.h> */
+#include <linux/netdevice.h>
+#include <linux/inetdevice.h>
+#include <linux/skbuff.h>
+#include <linux/circ_buf.h>
+#include <asm/uaccess.h>
+#include <asm/byteorder.h>
+#include <asm/atomic.h>
+#include <asm/io.h>
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
+	#include <asm/semaphore.h>
+#else
+	#include <linux/semaphore.h>
+#endif
+#include <linux/sem.h>
+#include <linux/sched.h>
+#include <linux/etherdevice.h>
+#include <linux/wireless.h>
+#include <net/iw_handler.h>
+#include <net/addrconf.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 <linux/kthread.h>
+#include <linux/list.h>
+#include <linux/vmalloc.h>
+
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 5, 41))
+	#include <linux/tqueue.h>
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 7, 0))
+	#include <uapi/linux/limits.h>
+#else
+	#include <linux/limits.h>
+#endif
+
+#ifdef RTK_DMP_PLATFORM
+	#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
+		#include <linux/pageremap.h>
+	#endif
+	#include <asm/io.h>
+#endif
+
+#ifdef CONFIG_NET_RADIO
+	#define CONFIG_WIRELESS_EXT
+#endif
+
+/* Monitor mode */
+#include <net/ieee80211_radiotap.h>
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
+	#include <linux/ieee80211.h>
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 25) && \
+	 LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 29))
+	#define CONFIG_IEEE80211_HT_ADDT_INFO
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+	/*	#include <linux/ieee80211.h> */
+	#include <net/cfg80211.h>
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+	#include <linux/in.h>
+	#include <linux/udp.h>
+#endif
+
+#ifdef CONFIG_HAS_EARLYSUSPEND
+	#include <linux/earlysuspend.h>
+#endif /* CONFIG_HAS_EARLYSUSPEND */
+
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+	#include <linux/fs.h>
+#endif
+
+#ifdef CONFIG_USB_HCI
+	#include <linux/usb.h>
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 21))
+		#include <linux/usb_ch9.h>
+	#else
+		#include <linux/usb/ch9.h>
+	#endif
+#endif
+
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	#include <net/sock.h>
+	#include <net/tcp.h>
+	#include <linux/udp.h>
+	#include <linux/in.h>
+	#include <linux/netlink.h>
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+#ifdef CONFIG_USB_HCI
+	typedef struct urb   *PURB;
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22))
+		#ifdef CONFIG_USB_SUSPEND
+			#define CONFIG_AUTOSUSPEND	1
+		#endif
+	#endif
+#endif
+
+#if defined(CONFIG_RTW_GRO) && (!defined(CONFIG_RTW_NAPI))
+
+	#error "Enable NAPI before enable GRO\n"
+
+#endif
+
+
+#if (KERNEL_VERSION(2, 6, 29) > LINUX_VERSION_CODE && defined(CONFIG_RTW_NAPI))
+
+	#undef CONFIG_RTW_NAPI
+	/*#warning "Linux Kernel version too old to support NAPI (should newer than 2.6.29)\n"*/
+
+#endif
+
+#if (KERNEL_VERSION(2, 6, 33) > LINUX_VERSION_CODE && defined(CONFIG_RTW_GRO))
+
+	#undef CONFIG_RTW_GRO
+	/*#warning "Linux Kernel version too old to support GRO(should newer than 2.6.33)\n"*/
+
+#endif
+
+typedef struct	semaphore _sema;
+typedef	spinlock_t	_lock;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	typedef struct mutex		_mutex;
+#else
+	typedef struct semaphore	_mutex;
+#endif
+struct rtw_timer_list {
+	struct timer_list timer;
+	void (*function)(void *);
+	void *arg;
+};
+
+typedef struct rtw_timer_list _timer;
+typedef struct completion _completion;
+
+struct	__queue	{
+	struct	list_head	queue;
+	_lock	lock;
+};
+
+typedef	struct sk_buff	_pkt;
+typedef unsigned char	_buffer;
+
+typedef struct	__queue	_queue;
+typedef struct	list_head	_list;
+
+/* hlist */
+typedef struct	hlist_head	rtw_hlist_head;
+typedef struct	hlist_node	rtw_hlist_node;
+
+/* RCU */
+typedef struct rcu_head rtw_rcu_head;
+#define rtw_rcu_dereference(p) rcu_dereference((p))
+#define rtw_rcu_dereference_protected(p, c) rcu_dereference_protected(p, c)
+#define rtw_rcu_assign_pointer(p, v) rcu_assign_pointer((p), (v))
+#define rtw_rcu_read_lock() rcu_read_lock()
+#define rtw_rcu_read_unlock() rcu_read_unlock()
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34))
+#define rtw_rcu_access_pointer(p) rcu_access_pointer(p)
+#endif
+
+/* rhashtable */
+#include "../os_dep/linux/rtw_rhashtable.h"
+
+typedef	int	_OS_STATUS;
+/* typedef u32	_irqL; */
+typedef unsigned long _irqL;
+typedef	struct	net_device *_nic_hdl;
+
+typedef void		*_thread_hdl_;
+typedef int		thread_return;
+typedef void	*thread_context;
+
+typedef void timer_hdl_return;
+typedef void *timer_hdl_context;
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	typedef struct work_struct _workitem;
+#else
+	typedef struct tq_struct _workitem;
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+	#define DMA_BIT_MASK(n) (((n) == 64) ? ~0ULL : ((1ULL<<(n))-1))
+#endif
+
+typedef unsigned long systime;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 22))
+/* Porting from linux kernel, for compatible with old kernel. */
+static inline unsigned char *skb_tail_pointer(const struct sk_buff *skb)
+{
+	return skb->tail;
+}
+
+static inline void skb_reset_tail_pointer(struct sk_buff *skb)
+{
+	skb->tail = skb->data;
+}
+
+static inline void skb_set_tail_pointer(struct sk_buff *skb, const int offset)
+{
+	skb->tail = skb->data + offset;
+}
+
+static inline unsigned char *skb_end_pointer(const struct sk_buff *skb)
+{
+	return skb->end;
+}
+#endif
+
+__inline static void rtw_list_delete(_list *plist)
+{
+	list_del_init(plist);
+}
+
+__inline static _list *get_next(_list	*list)
+{
+	return list->next;
+}
+
+#define LIST_CONTAINOR(ptr, type, member) \
+	((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))
+
+#define rtw_list_first_entry(ptr, type, member) list_first_entry(ptr, type, member)
+
+#define rtw_hlist_for_each_entry(pos, head, member) hlist_for_each_entry(pos, head, member)
+#define rtw_hlist_for_each_safe(pos, n, head) hlist_for_each_safe(pos, n, head)
+#define rtw_hlist_entry(ptr, type, member) hlist_entry(ptr, type, member)
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+#define rtw_hlist_for_each_entry_safe(pos, np, n, head, member) hlist_for_each_entry_safe(pos, n, head, member)
+#define rtw_hlist_for_each_entry_rcu(pos, node, head, member) hlist_for_each_entry_rcu(pos, head, member)
+#else
+#define rtw_hlist_for_each_entry_safe(pos, np, n, head, member) hlist_for_each_entry_safe(pos, np, n, head, member)
+#define rtw_hlist_for_each_entry_rcu(pos, node, head, member) hlist_for_each_entry_rcu(pos, node, head, member)
+#endif
+
+__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_bh(plock);
+}
+
+__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_bh(plock);
+}
+
+__inline static void enter_critical_bh(_lock *plock)
+{
+	spin_lock_bh(plock);
+}
+
+__inline static void exit_critical_bh(_lock *plock)
+{
+	spin_unlock_bh(plock);
+}
+
+__inline static int _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+	int ret = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	/* mutex_lock(pmutex); */
+	ret = mutex_lock_interruptible(pmutex);
+#else
+	ret = down_interruptible(pmutex);
+#endif
+	return ret;
+}
+
+
+__inline static int _enter_critical_mutex_lock(_mutex *pmutex, _irqL *pirqL)
+{
+	int ret = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	mutex_lock(pmutex);
+#else
+	down(pmutex);
+#endif
+	return ret;
+}
+
+__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	mutex_unlock(pmutex);
+#else
+	up(pmutex);
+#endif
+}
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return &(queue->queue);
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+static inline void timer_hdl(struct timer_list *in_timer)
+#else
+static inline void timer_hdl(unsigned long cntx)
+#endif
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+	_timer *ptimer = from_timer(ptimer, in_timer, timer);
+#else
+	_timer *ptimer = (_timer *)cntx;
+#endif
+	ptimer->function(ptimer->arg);
+}
+
+__inline static void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+	timer_setup(&ptimer->timer, timer_hdl, 0);
+#else
+	/* setup_timer(ptimer, pfunc,(u32)cntx);	 */
+	ptimer->timer.function = timer_hdl;
+	ptimer->timer.data = (unsigned long)ptimer;
+	init_timer(&ptimer->timer);
+#endif
+}
+
+__inline static void _set_timer(_timer *ptimer, u32 delay_time)
+{
+	mod_timer(&ptimer->timer , (jiffies + (delay_time * HZ / 1000)));
+}
+
+__inline static void _cancel_timer(_timer *ptimer, u8 *bcancelled)
+{
+	*bcancelled = del_timer_sync(&ptimer->timer) == 1 ? 1 : 0;
+}
+
+static inline void _init_workitem(_workitem *pwork, void *pfunc, void *cntx)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
+	INIT_WORK(pwork, pfunc);
+#elif (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	INIT_WORK(pwork, pfunc, pwork);
+#else
+	INIT_TQUEUE(pwork, pfunc, pwork);
+#endif
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	schedule_work(pwork);
+#else
+	schedule_task(pwork);
+#endif
+}
+
+__inline static void _cancel_workitem_sync(_workitem *pwork)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22))
+	cancel_work_sync(pwork);
+#elif (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	flush_scheduled_work();
+#else
+	flush_scheduled_tasks();
+#endif
+}
+/*
+ * Global Mutex: can only be used at PASSIVE level.
+ *   */
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+	{                                                               \
+		while (atomic_inc_return((atomic_t *)&(_MutexCounter)) != 1) { \
+			atomic_dec((atomic_t *)&(_MutexCounter));        \
+			msleep(10);                          \
+		}                                                           \
+	}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+	{                                                               \
+		atomic_dec((atomic_t *)&(_MutexCounter));        \
+	}
+
+static inline int rtw_netif_queue_stopped(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	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)));
+#else
+	return netif_queue_stopped(pnetdev);
+#endif
+}
+
+static inline void rtw_netif_wake_queue(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	netif_tx_wake_all_queues(pnetdev);
+#else
+	netif_wake_queue(pnetdev);
+#endif
+}
+
+static inline void rtw_netif_start_queue(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	netif_tx_start_all_queues(pnetdev);
+#else
+	netif_start_queue(pnetdev);
+#endif
+}
+
+static inline void rtw_netif_stop_queue(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	netif_tx_stop_all_queues(pnetdev);
+#else
+	netif_stop_queue(pnetdev);
+#endif
+}
+static inline void rtw_netif_device_attach(struct net_device *pnetdev)
+{
+	netif_device_attach(pnetdev);
+}
+static inline void rtw_netif_device_detach(struct net_device *pnetdev)
+{
+	netif_device_detach(pnetdev);
+}
+static inline void rtw_netif_carrier_on(struct net_device *pnetdev)
+{
+	netif_carrier_on(pnetdev);
+}
+static inline void rtw_netif_carrier_off(struct net_device *pnetdev)
+{
+	netif_carrier_off(pnetdev);
+}
+
+static inline int rtw_merge_string(char *dst, int dst_len, const char *src1, const char *src2)
+{
+	int	len = 0;
+	len += snprintf(dst + len, dst_len - len, "%s", src1);
+	len += snprintf(dst + len, dst_len - len, "%s", src2);
+
+	return len;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27))
+	#define rtw_signal_process(pid, sig) kill_pid(find_vpid((pid)), (sig), 1)
+#else /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27)) */
+	#define rtw_signal_process(pid, sig) kill_proc((pid), (sig), 1)
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27)) */
+
+
+/* Suspend lock prevent system from going suspend */
+#ifdef CONFIG_WAKELOCK
+	#include <linux/wakelock.h>
+#elif defined(CONFIG_ANDROID_POWER)
+	#include <linux/android_power.h>
+#endif
+
+/* limitation of path length */
+#define PATH_LENGTH_MAX PATH_MAX
+
+/* Atomic integer operations */
+#define ATOMIC_T atomic_t
+
+#define rtw_netdev_priv(netdev) (((struct rtw_netdev_priv_indicator *)netdev_priv(netdev))->priv)
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ndev->name
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) (adapter->pnetdev ? adapter->pnetdev->name : NULL)
+#define FUNC_NDEV_FMT "%s(%s)"
+#define FUNC_NDEV_ARG(ndev) __func__, ndev->name
+#define FUNC_ADPT_FMT "%s(%s)"
+#define FUNC_ADPT_ARG(adapter) __func__, (adapter->pnetdev ? adapter->pnetdev->name : NULL)
+
+struct rtw_netdev_priv_indicator {
+	void *priv;
+	u32 sizeof_priv;
+};
+struct net_device *rtw_alloc_etherdev_with_old_priv(int sizeof_priv, void *old_priv);
+extern struct net_device *rtw_alloc_etherdev(int sizeof_priv);
+
+#define STRUCT_PACKED __attribute__ ((packed))
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_xp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_xp.h
new file mode 100644
index 000000000000..57e6f314e20d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/osdep_service_xp.h
@@ -0,0 +1,210 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_LINUX_SERVICE_H_
+#define __OSDEP_LINUX_SERVICE_H_
+
+	#include <ndis.h>
+	#include <ntddk.h>
+	#include <ntddndis.h>
+	#include <ntdef.h>
+
+#ifdef CONFIG_USB_HCI
+	#include <usb.h>
+	#include <usbioctl.h>
+	#include <usbdlib.h>
+#endif
+
+	typedef KSEMAPHORE 	_sema;
+	typedef	LIST_ENTRY	_list;
+	typedef NDIS_STATUS _OS_STATUS;
+	
+
+	typedef NDIS_SPIN_LOCK	_lock;
+
+	typedef KMUTEX 			_mutex;
+
+	typedef KIRQL	_irqL;
+
+	// USB_PIPE for WINCE , but handle can be use just integer under windows
+	typedef NDIS_HANDLE  _nic_hdl;
+
+	struct rtw_timer_list {
+		NDIS_MINIPORT_TIMER ndis_timer;
+		void (*function)(void *);
+		void *arg;
+	};
+
+	struct	__queue	{
+		LIST_ENTRY	queue;	
+		_lock	lock;
+	};
+
+	typedef	NDIS_PACKET	_pkt;
+	typedef NDIS_BUFFER	_buffer;
+	typedef struct	__queue	_queue;
+	
+	typedef PKTHREAD _thread_hdl_;
+	typedef void	thread_return;
+	typedef void* thread_context;
+
+	typedef NDIS_WORK_ITEM _workitem;
+
+
+	#define HZ			10000000
+	#define SEMA_UPBND	(0x7FFFFFFF)   //8192
+	
+__inline static _list *get_next(_list	*list)
+{
+	return list->Flink;
+}	
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return (&(queue->queue));
+}
+	
+
+#define LIST_CONTAINOR(ptr, type, member) CONTAINING_RECORD(ptr, type, member)
+     
+
+__inline static _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisAcquireSpinLock(plock);	
+}
+
+__inline static _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisReleaseSpinLock(plock);	
+}
+
+
+__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprAcquireSpinLock(plock);	
+}
+
+__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprReleaseSpinLock(plock);	
+}
+
+__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	NdisDprAcquireSpinLock(plock);
+}
+
+__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	NdisDprReleaseSpinLock(plock);
+}
+
+__inline static _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+	KeWaitForSingleObject(pmutex, Executive, KernelMode, FALSE, NULL);
+}
+
+
+__inline static _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+	KeReleaseMutex(pmutex, FALSE);
+}
+
+
+__inline static void rtw_list_delete(_list *plist)
+{
+	RemoveEntryList(plist);
+	InitializeListHead(plist);	
+}
+
+static inline void timer_hdl(
+	IN PVOID SystemSpecific1,
+	IN PVOID FunctionContext,
+	IN PVOID SystemSpecific2,
+	IN PVOID SystemSpecific3)
+{
+	_timer *timer = (_timer *)FunctionContext;
+
+	timer->function(timer->arg);
+}
+
+static inline void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+	NdisMInitializeTimer(&ptimer->ndis_timer, nic_hdl, timer_hdl, ptimer);
+}
+
+static inline void _set_timer(_timer *ptimer, u32 delay_time)
+{
+	NdisMSetTimer(ptimer, delay_time);
+}
+
+static inline void _cancel_timer(_timer *ptimer, u8 *bcancelled)
+{
+	NdisMCancelTimer(ptimer, bcancelled);
+}
+
+__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
+{
+
+	NdisInitializeWorkItem(pwork, pfunc, cntx);
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+	NdisScheduleWorkItem(pwork);
+}
+
+
+#define ATOMIC_INIT(i)  { (i) }
+
+//
+// Global Mutex: can only be used at PASSIVE level.
+//
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    while (NdisInterlockedIncrement((PULONG)&(_MutexCounter)) != 1)\
+    {                                                           \
+        NdisInterlockedDecrement((PULONG)&(_MutexCounter));        \
+        NdisMSleep(10000);                          \
+    }                                                           \
+}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    NdisInterlockedDecrement((PULONG)&(_MutexCounter));              \
+}
+
+// limitation of path length
+#define PATH_LENGTH_MAX MAX_PATH
+
+//Atomic integer operations
+#define ATOMIC_T LONG
+
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ""
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) ""
+#define FUNC_NDEV_FMT "%s"
+#define FUNC_NDEV_ARG(ndev) __func__
+#define FUNC_ADPT_FMT "%s"
+#define FUNC_ADPT_ARG(adapter) __func__
+
+#define STRUCT_PACKED
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_hal.h
new file mode 100644
index 000000000000..16eac21f02a7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_hal.h
@@ -0,0 +1,48 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __PCI_HAL_H__
+#define __PCI_HAL_H__
+
+#ifdef CONFIG_RTL8188E
+	void rtl8188ee_set_hal_ops(_adapter *padapter);
+#endif
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+	void rtl8812ae_set_hal_ops(_adapter *padapter);
+#endif
+
+#if defined(CONFIG_RTL8192E)
+	void rtl8192ee_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8723B
+	void rtl8723be_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	void rtl8723de_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8814A
+	void rtl8814ae_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8822B
+	void rtl8822be_set_hal_ops(PADAPTER padapter);
+#endif
+
+u8 rtw_set_hal_ops(_adapter *padapter);
+
+#endif /* __PCIE_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_ops.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_ops.h
new file mode 100644
index 000000000000..f195f5b4fafd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_ops.h
@@ -0,0 +1,91 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __PCI_OPS_H_
+#define __PCI_OPS_H_
+
+
+#ifdef CONFIG_RTL8188E
+	u32	rtl8188ee_init_desc_ring(_adapter *padapter);
+	u32	rtl8188ee_free_desc_ring(_adapter *padapter);
+	void	rtl8188ee_reset_desc_ring(_adapter *padapter);
+	int	rtl8188ee_interrupt(PADAPTER Adapter);
+	void	rtl8188ee_xmit_tasklet(void *priv);
+	void	rtl8188ee_recv_tasklet(void *priv);
+	void	rtl8188ee_prepare_bcn_tasklet(void *priv);
+	void	rtl8188ee_set_intf_ops(struct _io_ops	*pops);
+#endif
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+	u32	rtl8812ae_init_desc_ring(_adapter *padapter);
+	u32	rtl8812ae_free_desc_ring(_adapter *padapter);
+	void	rtl8812ae_reset_desc_ring(_adapter *padapter);
+	int	rtl8812ae_interrupt(PADAPTER Adapter);
+	void	rtl8812ae_xmit_tasklet(void *priv);
+	void	rtl8812ae_recv_tasklet(void *priv);
+	void	rtl8812ae_prepare_bcn_tasklet(void *priv);
+	void	rtl8812ae_set_intf_ops(struct _io_ops	*pops);
+#endif
+
+#ifdef CONFIG_RTL8192E
+	u32	rtl8192ee_init_desc_ring(_adapter *padapter);
+	u32	rtl8192ee_free_desc_ring(_adapter *padapter);
+	void	rtl8192ee_reset_desc_ring(_adapter *padapter);
+	void	rtl8192ee_recv_tasklet(void *priv);
+	void	rtl8192ee_prepare_bcn_tasklet(void *priv);
+	int	rtl8192ee_interrupt(PADAPTER Adapter);
+	void	rtl8192ee_set_intf_ops(struct _io_ops	*pops);
+#endif
+
+#ifdef CONFIG_RTL8723B
+	u32	rtl8723be_init_desc_ring(_adapter *padapter);
+	u32	rtl8723be_free_desc_ring(_adapter *padapter);
+	void	rtl8723be_reset_desc_ring(_adapter *padapter);
+	int	rtl8723be_interrupt(PADAPTER Adapter);
+	void	rtl8723be_recv_tasklet(void *priv);
+	void	rtl8723be_prepare_bcn_tasklet(void *priv);
+	void	rtl8723be_set_intf_ops(struct _io_ops	*pops);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	u32	rtl8723de_init_desc_ring(_adapter *padapter);
+	u32	rtl8723de_free_desc_ring(_adapter *padapter);
+	void	rtl8723de_reset_desc_ring(_adapter *padapter);
+	int	rtl8723de_interrupt(PADAPTER Adapter);
+	void	rtl8723de_recv_tasklet(void *priv);
+	void	rtl8723de_prepare_bcn_tasklet(void *priv);
+	void	rtl8723de_set_intf_ops(struct _io_ops	*pops);
+	u8 check_tx_desc_resource(_adapter *padapter, int prio);
+#endif
+
+#ifdef CONFIG_RTL8814A
+	u32	rtl8814ae_init_desc_ring(_adapter *padapter);
+	u32	rtl8814ae_free_desc_ring(_adapter *padapter);
+	void	rtl8814ae_reset_desc_ring(_adapter *padapter);
+	int	rtl8814ae_interrupt(PADAPTER Adapter);
+	void	rtl8814ae_xmit_tasklet(void *priv);
+	void	rtl8814ae_recv_tasklet(void *priv);
+	void	rtl8814ae_prepare_bcn_tasklet(void *priv);
+	void	rtl8814ae_set_intf_ops(struct _io_ops	*pops);
+#endif
+
+#ifdef CONFIG_RTL8822B
+	void rtl8822be_set_intf_ops(struct _io_ops *pops);
+#endif
+
+#ifdef CONFIG_RTL8821C
+	void rtl8821ce_set_intf_ops(struct _io_ops *pops);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_osintf.h
new file mode 100644
index 000000000000..c6a0fddf651a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/pci_osintf.h
@@ -0,0 +1,50 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __PCI_OSINTF_H
+#define __PCI_OSINTF_H
+
+#ifdef RTK_129X_PLATFORM
+#define PCIE_SLOT1_MEM_START	0x9804F000
+#define PCIE_SLOT1_MEM_LEN	0x1000
+#define PCIE_SLOT1_CTRL_START	0x9804EC00
+
+#define PCIE_SLOT2_MEM_START	0x9803C000
+#define PCIE_SLOT2_MEM_LEN	0x1000
+#define PCIE_SLOT2_CTRL_START	0x9803BC00
+
+#define PCIE_MASK_OFFSET	0x100 /* mask offset from CTRL_START */
+#define PCIE_TRANSLATE_OFFSET	0x104 /* translate offset from CTRL_START */
+#endif
+
+#define PCI_BC_CLK_REQ		BIT0
+#define PCI_BC_ASPM_L0s		BIT1
+#define PCI_BC_ASPM_L1		BIT2
+#define PCI_BC_ASPM_L1Off	BIT3
+//#define PCI_BC_ASPM_LTR	BIT4
+//#define PCI_BC_ASPM_OBFF	BIT5
+
+void	rtw_pci_disable_aspm(_adapter *padapter);
+void	rtw_pci_enable_aspm(_adapter *padapter);
+void	PlatformClearPciPMEStatus(PADAPTER Adapter);
+void	rtw_pci_aspm_config(_adapter *padapter);
+void	rtw_pci_aspm_config_l1off_general(_adapter *padapter, u8 eanble);
+#ifdef CONFIG_PCI_DYNAMIC_ASPM
+void	rtw_pci_aspm_config_dynamic_l1_ilde_time(_adapter *padapter);
+#endif
+#ifdef CONFIG_64BIT_DMA
+	u8	PlatformEnableDMA64(PADAPTER Adapter);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/recv_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/recv_osdep.h
new file mode 100644
index 000000000000..8c569b6dd390
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/recv_osdep.h
@@ -0,0 +1,67 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+extern sint _rtw_init_recv_priv(struct recv_priv *precvpriv, _adapter *padapter);
+extern void _rtw_free_recv_priv(struct recv_priv *precvpriv);
+
+
+extern s32  rtw_recv_entry(union recv_frame *precv_frame);
+void rtw_rframe_set_os_pkt(union recv_frame *rframe);
+extern int rtw_recv_indicatepkt(_adapter *adapter, union recv_frame *precv_frame);
+extern void rtw_recv_returnpacket(IN _nic_hdl cnxt, IN _pkt *preturnedpkt);
+
+extern int rtw_recv_monitor(_adapter *padapter, union recv_frame *precv_frame);
+
+#ifdef CONFIG_HOSTAPD_MLME
+extern void rtw_hostapd_mlme_rx(_adapter *padapter, union recv_frame *precv_frame);
+#endif
+
+struct sta_info;
+extern void rtw_handle_tkip_mic_err(_adapter *padapter, struct sta_info *sta, u8 bgroup);
+
+
+int rtw_os_recv_resource_init(struct recv_priv *precvpriv, _adapter *padapter);
+int rtw_os_recv_resource_alloc(_adapter *padapter, union recv_frame *precvframe);
+void rtw_os_recv_resource_free(struct recv_priv *precvpriv);
+
+
+int rtw_os_alloc_recvframe(_adapter *padapter, union recv_frame *precvframe, u8 *pdata, _pkt *pskb);
+int rtw_os_recvframe_duplicate_skb(_adapter *padapter, union recv_frame *pcloneframe, _pkt *pskb);
+void rtw_os_free_recvframe(union recv_frame *precvframe);
+
+
+int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf);
+int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf);
+
+_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, const u8 *da, const u8 *sa, u8 *msdu ,u16 msdu_len);
+void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, union recv_frame *rframe);
+
+void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf);
+
+#ifdef PLATFORM_LINUX
+#ifdef CONFIG_RTW_NAPI
+#include <linux/netdevice.h>	/* struct napi_struct */
+
+int rtw_recv_napi_poll(struct napi_struct *, int budget);
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+void dynamic_napi_th_chk (_adapter *adapter);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#endif /* CONFIG_RTW_NAPI */
+#endif /* PLATFORM_LINUX */
+
+#endif /*  */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_cmd.h
new file mode 100644
index 000000000000..99a9cba972b7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_cmd.h
@@ -0,0 +1,166 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_CMD_H__
+#define __RTL8188E_CMD_H__
+
+#if 0
+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,
+	P2P_PS_CTW_CMD_EID = 32,
+	MAX_CMDMSG_EID
+};
+#else
+typedef enum _RTL8188E_H2C_CMD_ID {
+	/* Class Common */
+	H2C_COM_RSVD_PAGE			= 0x00,
+	H2C_COM_MEDIA_STATUS_RPT	= 0x01,
+	H2C_COM_SCAN					= 0x02,
+	H2C_COM_KEEP_ALIVE			= 0x03,
+	H2C_COM_DISCNT_DECISION		= 0x04,
+#ifndef CONFIG_WOWLAN
+	H2C_COM_WWLAN				= 0x05,
+#endif
+	H2C_COM_INIT_OFFLOAD			= 0x06,
+	H2C_COM_REMOTE_WAKE_CTL	= 0x07,
+	H2C_COM_AP_OFFLOAD			= 0x08,
+	H2C_COM_BCN_RSVD_PAGE		= 0x09,
+	H2C_COM_PROB_RSP_RSVD_PAGE	= 0x0A,
+
+	/* Class PS */
+	H2C_PS_PWR_MODE				= 0x20,
+	H2C_PS_TUNE_PARA				= 0x21,
+	H2C_PS_TUNE_PARA_2			= 0x22,
+	H2C_PS_LPS_PARA				= 0x23,
+	H2C_PS_P2P_OFFLOAD			= 0x24,
+
+	/* Class DM */
+	H2C_DM_MACID_CFG				= 0x40,
+	H2C_DM_TXBF					= 0x41,
+	H2C_RSSI_REPORT				= 0x42,
+	/* Class BT */
+	H2C_BT_COEX_MASK				= 0x60,
+	H2C_BT_COEX_GPIO_MODE		= 0x61,
+	H2C_BT_DAC_SWING_VAL			= 0x62,
+	H2C_BT_PSD_RST				= 0x63,
+
+	/* Class Remote WakeUp */
+#ifdef CONFIG_WOWLAN
+	H2C_COM_WWLAN				= 0x80,
+	H2C_COM_REMOTE_WAKE_CTRL	= 0x81,
+	H2C_COM_AOAC_GLOBAL_INFO	= 0x82,
+	H2C_COM_AOAC_RSVD_PAGE		= 0x83,
+#endif
+
+	/* Class */
+	/* H2C_RESET_TSF				=0xc0, */
+} RTL8188E_H2C_CMD_ID;
+
+#endif
+
+
+struct cmd_msg_parm {
+	u8 eid; /* element id */
+	u8 sz; /* sz */
+	u8 buf[6];
+};
+
+enum {
+	PWRS
+};
+
+typedef struct _SETPWRMODE_PARM {
+	u8 Mode;/* 0:Active,1:LPS,2:WMMPS */
+	/* u8 RLBM:4; */ /* 0:Min,1:Max,2: User define */
+	u8 SmartPS_RLBM;/* LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData */
+	u8 AwakeInterval;	/* unit: beacon interval */
+	u8 bAllQueueUAPSD;
+	u8 PwrState;/* AllON(0x0c),RFON(0x04),RFOFF(0x00) */
+} SETPWRMODE_PARM, *PSETPWRMODE_PARM;
+
+struct H2C_SS_RFOFF_PARAM {
+	u8 ROFOn; /* 1: on, 0:off */
+	u16 gpio_period; /* unit: 1024 us */
+} __attribute__((packed));
+
+
+typedef struct JOINBSSRPT_PARM_88E {
+	u8 OpMode;	/* RT_MEDIA_STATUS */
+#ifdef CONFIG_WOWLAN
+	u8 MacID;       /* MACID */
+#endif /* CONFIG_WOWLAN */
+} JOINBSSRPT_PARM_88E, *PJOINBSSRPT_PARM_88E;
+
+#if 0
+/* move to hal_com_h2c.h */
+typedef struct _RSVDPAGE_LOC_88E {
+	u8 LocProbeRsp;
+	u8 LocPsPoll;
+	u8 LocNullData;
+	u8 LocQosNull;
+	u8 LocBTQosNull;
+#ifdef CONFIG_WOWLAN
+	u8 LocRemoteCtrlInfo;
+	u8 LocArpRsp;
+	u8 LocNbrAdv;
+	u8 LocGTKRsp;
+	u8 LocGTKInfo;
+	u8 LocProbeReq;
+	u8 LocNetList;
+#endif /* CONFIG_WOWLAN	 */
+} RSVDPAGE_LOC_88E, *PRSVDPAGE_LOC_88E;
+#endif
+
+/* host message to firmware cmd */
+void rtl8188e_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8188e_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
+u8 rtl8188e_set_rssi_cmd(PADAPTER padapter, u8 *param);
+s32 FillH2CCmd_88E(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+/* u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period); */
+u8 GetTxBufferRsvdPageNum8188E(_adapter *padapter, bool wowlan);
+
+
+#ifdef CONFIG_P2P
+	void rtl8188e_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+/* #define H2C_8188E_RSVDPAGE_LOC_LEN      5 */
+/* #define H2C_8188E_AOAC_RSVDPAGE_LOC_LEN 7 */
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ *   */
+#if 0
+	/* move to hal_com_h2c.h
+	* _RSVDPAGE_LOC_CMD_0x00 */
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+	/*  AOAC_RSVDPAGE_LOC_0x83 */
+	#define SET_8188E_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
+	#define SET_8188E_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)                  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#endif
+#endif/* __RTL8188E_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_dm.h
new file mode 100644
index 000000000000..501d3a9c6e2b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_dm.h
@@ -0,0 +1,27 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_DM_H__
+#define __RTL8188E_DM_H__
+
+void rtl8188e_init_dm_priv(IN PADAPTER Adapter);
+void rtl8188e_deinit_dm_priv(IN PADAPTER Adapter);
+void rtl8188e_InitHalDm(IN PADAPTER Adapter);
+void rtl8188e_HalDmWatchDog(IN PADAPTER Adapter);
+
+/* VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter); */
+
+/* void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal); */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_hal.h
new file mode 100644
index 000000000000..23c435e8d090
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_hal.h
@@ -0,0 +1,318 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_HAL_H__
+#define __RTL8188E_HAL_H__
+
+/* #include "hal_com.h" */
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8188e_spec.h"
+#include "Hal8188EPhyReg.h"
+#include "Hal8188EPhyCfg.h"
+#include "rtl8188e_rf.h"
+#include "rtl8188e_dm.h"
+#include "rtl8188e_recv.h"
+#include "rtl8188e_xmit.h"
+#include "rtl8188e_cmd.h"
+#include "rtl8188e_led.h"
+#include "Hal8188EPwrSeq.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8188e_sreset.h"
+#endif
+
+/* --------------------------------------------------------------------- */
+/*		RTL8188E Power Configuration CMDs for USB/SDIO/PCIE interfaces */
+/* --------------------------------------------------------------------- */
+#define Rtl8188E_NIC_PWR_ON_FLOW				rtl8188E_power_on_flow
+#define Rtl8188E_NIC_RF_OFF_FLOW				rtl8188E_radio_off_flow
+#define Rtl8188E_NIC_DISABLE_FLOW				rtl8188E_card_disable_flow
+#define Rtl8188E_NIC_ENABLE_FLOW				rtl8188E_card_enable_flow
+#define Rtl8188E_NIC_SUSPEND_FLOW				rtl8188E_suspend_flow
+#define Rtl8188E_NIC_RESUME_FLOW				rtl8188E_resume_flow
+#define Rtl8188E_NIC_PDN_FLOW					rtl8188E_hwpdn_flow
+#define Rtl8188E_NIC_LPS_ENTER_FLOW			rtl8188E_enter_lps_flow
+#define Rtl8188E_NIC_LPS_LEAVE_FLOW			rtl8188E_leave_lps_flow
+
+
+#if 1 /* download firmware related data structure */
+#define MAX_FW_8188E_SIZE			0x8000 /* 32768, 32k / 16384, 16k */
+
+#define FW_8188E_SIZE				0x4000 /* 16384, 16k */
+#define FW_8188E_SIZE_2			0x8000 /* 32768, 32k */
+
+#define FW_8188E_START_ADDRESS	0x1000
+#define FW_8188E_END_ADDRESS		0x1FFF /* 0x5FFF */
+
+
+#define IS_FW_HEADER_EXIST_88E(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x88E0)
+
+typedef struct _RT_FIRMWARE_8188E {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[MAX_FW_8188E_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8188E, *PRT_FIRMWARE_8188E;
+
+/*
+ * This structure must be cared byte-ordering
+ *   */
+
+typedef struct _RT_8188E_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u8		Subversion;	/* FW Subversion, default 0x00 */
+	u16		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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u8		Foundry;
+	u8		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8188E_FIRMWARE_HDR, *PRT_8188E_FIRMWARE_HDR;
+#endif /* download firmware related data structure */
+
+
+#define DRIVER_EARLY_INT_TIME_8188E			0x05
+#define BCN_DMA_ATIME_INT_TIME_8188E		0x02
+
+
+/* #define MAX_RX_DMA_BUFFER_SIZE_88E	      0x2400 */ /* 9k for 88E nornal chip , */ /* MaxRxBuff=10k-max(TxReportSize(64*8), WOLPattern(16*24)) */
+#ifdef CONFIG_USB_HCI
+	#define RX_DMA_SIZE_88E(__Adapter) 0x2800
+#else
+	#define RX_DMA_SIZE_88E(__Adapter) ((!IS_VENDOR_8188E_I_CUT_SERIES(__Adapter))?0x2800:0x4000)
+#endif
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#define RX_DMA_RESERVD_FW_FEATURE	0x200 /* for tx report (64*8) */
+
+#define MAX_RX_DMA_BUFFER_SIZE_88E(__Adapter) (RX_DMA_SIZE_88E(__Adapter)-RX_DMA_RESERVD_FW_FEATURE)
+
+#define MAX_TX_REPORT_BUFFER_SIZE			0x0400 /* 1k */
+
+/* Note: We will divide number of page equally for each queue other than public queue!
+ * 22k = 22528 bytes = 176 pages (@page =  128 bytes)
+ * must reserved about 7 pages for LPS =>  176-7 = 169 (0xA9)
+ * 2*BCN / 1*ps-poll / 1*null-data /1*prob_rsp /1*QOS null-data /1*BT QOS null-data  */
+
+#define BCNQ_PAGE_NUM_88E		0x09
+
+/* For WoWLan , more reserved page */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_88E	0x00
+#else
+	#define WOWLAN_PAGE_NUM_88E	0x00
+#endif
+
+/* Note:
+Tx FIFO Size : previous CUT:22K /I_CUT after:32KB
+Tx page Size : 128B
+Total page numbers : 176(0xB0) / 256(0x100)
+*/
+#ifdef CONFIG_USB_HCI
+	#define TOTAL_PAGE_NUMBER_88E(_Adapter) (0xB0 - 1)
+#else
+	#define TOTAL_PAGE_NUMBER_88E(_Adapter)	((IS_VENDOR_8188E_I_CUT_SERIES(_Adapter)?0x100:0xB0) - 1)/* must reserved 1 page for dma issue */
+#endif
+#define TX_TOTAL_PAGE_NUMBER_88E(_Adapter)	(TOTAL_PAGE_NUMBER_88E(_Adapter) - BCNQ_PAGE_NUM_88E - WOWLAN_PAGE_NUM_88E)
+#define TX_PAGE_BOUNDARY_88E(_Adapter)		(TX_TOTAL_PAGE_NUMBER_88E(_Adapter) + 1) /* beacon header start address */
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_88E(_Adapter)	TX_TOTAL_PAGE_NUMBER_88E(_Adapter)
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_88E(_Adapter)		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_88E(_Adapter) + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723B */
+#define NORMAL_PAGE_NUM_HPQ_88E		0x0
+#define NORMAL_PAGE_NUM_LPQ_88E		0x09
+#define NORMAL_PAGE_NUM_NPQ_88E		0x0
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_88E		0x29
+#define WMM_NORMAL_PAGE_NUM_LPQ_88E		0x1C
+#define WMM_NORMAL_PAGE_NUM_NPQ_88E		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
+
+/* -------------------------------------------------------------------------
+ *	Channel Plan
+ * ------------------------------------------------------------------------- */
+
+
+#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)	      |
+ *   */
+#define EFUSE_OOB_PROTECT_BYTES 		15	/* PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte. */
+
+#define		EFUSE_REAL_CONTENT_LEN_88E	256
+#define		EFUSE_MAP_LEN_88E		512
+#define		EFUSE_MAX_SECTION_88E		64
+#define		EFUSE_MAX_WORD_UNIT_88E		4
+#define		EFUSE_IC_ID_OFFSET_88E			506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define		AVAILABLE_EFUSE_ADDR_88E(addr)	(addr < EFUSE_REAL_CONTENT_LEN_88E)
+/* <Roger_Notes> To prevent out of boundary programming case, leave 1byte and program full section
+ * 9bytes + 1byt + 5bytes and pre 1byte.
+ * For worst case:
+ * | 2byte|----8bytes----|1byte|--7bytes--|  */ /* 92D */
+#define 		EFUSE_OOB_PROTECT_BYTES_88E	18	/* PG data exclude header, dummy 7 bytes frome CP test and reserved 1byte. */
+#define		EFUSE_PROTECT_BYTES_BANK_88E	16
+
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#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
+
+#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)
+
+/* #define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE) */
+
+/* #define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) ) */
+
+#ifdef CONFIG_PCI_HCI
+	/* according to the define in the rtw_xmit.h, rtw_recv.h */
+	#define TX_DESC_NUM_8188EE  TXDESC_NUM   /* 128 */
+	#ifdef CONFIG_CONCURRENT_MODE
+		/*#define BE_QUEUE_TX_DESC_NUM_8188EE  (TXDESC_NUM<<1)*/		/* 256 */
+		#define BE_QUEUE_TX_DESC_NUM_8188EE  ((TXDESC_NUM<<1)+(TXDESC_NUM>>1))    /* 320 */
+		/*#define BE_QUEUE_TX_DESC_NUM_8188EE  ((TXDESC_NUM<<1)+TXDESC_NUM)*/    /* 384 */
+	#else
+		#define BE_QUEUE_TX_DESC_NUM_8188EE  TXDESC_NUM /* 128 */
+		/*#define BE_QUEUE_TX_DESC_NUM_8188EE  (TXDESC_NUM+(TXDESC_NUM>>1)) */ /* 192 */
+	#endif
+
+	void InterruptRecognized8188EE(PADAPTER Adapter, PRT_ISR_CONTENT pIsrContent);
+	void UpdateInterruptMask8188EE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+#endif /* CONFIG_PCI_HCI */
+
+/* rtl8188e_hal_init.c */
+
+s32 rtl8188e_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void _8051Reset88E(PADAPTER padapter);
+void rtl8188e_InitializeFirmwareVars(PADAPTER padapter);
+
+
+s32 InitLLTTable(PADAPTER padapter, u8 txpktbuf_bndy);
+
+/* EFuse */
+u8 GetEEPROMSize8188E(PADAPTER padapter);
+void Hal_InitPGData88E(PADAPTER padapter);
+void Hal_EfuseParseIDCode88E(PADAPTER padapter, u8 *hwinfo);
+void Hal_ReadTxPowerInfo88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+
+void Hal_EfuseParseEEPROMVer88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void rtl8188e_EfuseParseChnlPlan(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_ReadAntennaDiversity88E(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_ReadThermalMeter_88E(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void Hal_EfuseParseXtal_8188E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBoardType88E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_ReadPowerSavingMode88E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_ReadPAType_8188E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void Hal_ReadAmplifierType_8188E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void Hal_ReadRFEType_8188E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+
+BOOLEAN HalDetectPwrDownMode88E(PADAPTER Adapter);
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+
+#ifdef CONFIG_RF_POWER_TRIM
+	void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+void rtl8188e_init_default_value(_adapter *adapter);
+
+void InitBeaconParameters_8188e(_adapter *adapter);
+void SetBeaconRelatedRegisters8188E(PADAPTER padapter);
+
+void rtl8188e_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8188e(_adapter *adapter);
+
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+
+void rtl8188e_start_thread(_adapter *padapter);
+void rtl8188e_stop_thread(_adapter *padapter);
+
+void rtw_IOL_cmd_tx_pkt_buf_dump(ADAPTER *Adapter, int data_len);
+#ifdef CONFIG_IOL_EFUSE_PATCH
+	s32 rtl8188e_iol_efuse_patch(PADAPTER padapter);
+#endif/* CONFIG_IOL_EFUSE_PATCH */
+void _InitTransferPageSize(PADAPTER padapter);
+
+u8 SetHwReg8188E(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8188E(PADAPTER padapter, u8 variable, u8 *val);
+
+u8
+GetHalDefVar8188E(
+	IN	PADAPTER				Adapter,
+	IN	HAL_DEF_VARIABLE		eVariable,
+	IN	PVOID					pValue
+);
+#ifdef CONFIG_GPIO_API
+int rtl8188e_GpioFuncCheck(PADAPTER adapter, u8 gpio_num);
+#endif
+#endif /* __RTL8188E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_led.h
new file mode 100644
index 000000000000..ef054675024a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_led.h
@@ -0,0 +1,37 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_LED_H__
+#define __RTL8188E_LED_H__
+
+#ifdef CONFIG_RTW_SW_LED
+
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8188eu_InitSwLeds(PADAPTER padapter);
+	void rtl8188eu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8188ee_InitSwLeds(PADAPTER padapter);
+	void rtl8188ee_DeInitSwLeds(PADAPTER padapter);
+#endif
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	void rtl8188es_InitSwLeds(PADAPTER padapter);
+	void rtl8188es_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif
+#endif /*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_recv.h
new file mode 100644
index 000000000000..92425a859f5b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_recv.h
@@ -0,0 +1,161 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_RECV_H__
+#define __RTL8188E_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ (10240)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#define TX_RPT1_PKT_LEN 8
+
+typedef struct rxreport_8188e {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	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;
+
+	/* Offset 8 */
+	u32 seq:12;
+	u32 frag:4;
+	u32 nextpktlen:14;
+	u32 nextind:1;
+	u32 rsvd0831:1;
+
+	/* Offset 12 */
+	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 rpt_sel:2;
+	u32 rsvd1216:13;
+	u32 pattern_match:1;
+	u32 unicastwake:1;
+	u32 magicwake:1;
+
+	/* Offset 16 */
+	/*
+	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 rsvd16;
+
+	/* Offset 20 */
+	u32 tsfl;
+
+	/* Offset 24 */
+	u32 bassn:12;
+	u32 bavld:1;
+	u32 rsvd2413:19;
+} RXREPORT, *PRXREPORT;
+
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8188es_init_recv_priv(PADAPTER padapter);
+	void rtl8188es_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	void rtl8188eu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+	s32 rtl8188eu_init_recv_priv(PADAPTER padapter);
+	void rtl8188eu_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8188ee_init_recv_priv(PADAPTER padapter);
+	void rtl8188ee_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8188e_query_rx_desc_status(union recv_frame *precvframe, struct recv_stat *prxstat);
+
+#endif /* __RTL8188E_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_rf.h
new file mode 100644
index 000000000000..f5c5fbdfd19f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_rf.h
@@ -0,0 +1,27 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_RF_H__
+#define __RTL8188E_RF_H__
+
+
+
+int	PHY_RF6052_Config8188E(IN	PADAPTER		Adapter);
+void		rtl8188e_RF_ChangeTxPath(IN	PADAPTER	Adapter,
+		IN	u16		DataRate);
+void		rtl8188e_PHY_RF6052SetBandwidth(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
+
+#endif/* __RTL8188E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_spec.h
new file mode 100644
index 000000000000..802659a5fd07
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_spec.h
@@ -0,0 +1,159 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_SPEC_H__
+#define __RTL8188E_SPEC_H__
+
+
+/* ************************************************************
+ * 8188E Regsiter offset definition
+ * ************************************************************ */
+
+
+/* ************************************************************
+ *
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_BB_PAD_CTRL				0x0064
+#define REG_HMEBOX_E0					0x0088
+#define REG_HMEBOX_E1					0x008A
+#define REG_HMEBOX_E2					0x008C
+#define REG_HMEBOX_E3					0x008E
+#define REG_HMEBOX_EXT_0				0x01F0
+#define REG_HMEBOX_EXT_1				0x01F4
+#define REG_HMEBOX_EXT_2				0x01F8
+#define REG_HMEBOX_EXT_3				0x01FC
+#define REG_HIMR_88E					0x00B0 /* RTL8188E */
+#define REG_HISR_88E					0x00B4 /* RTL8188E */
+#define REG_HIMRE_88E					0x00B8 /* RTL8188E */
+#define REG_HISRE_88E					0x00BC /* RTL8188E */
+
+#define	REG_DBI_WDATA_8188E				0x0348	/* DBI Write data */
+#define	REG_DBI_RDATA_8188E				0x034C	/* DBI Read data */
+#define	REG_DBI_ADDR_8188E				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8188E				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8188E				0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8188E				0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8188E				0x0358	/* MDIO for Control */
+
+#define REG_MACID_NO_LINK_0			0x0484
+#define REG_MACID_NO_LINK_1			0x0488
+#define REG_MACID_PAUSE_0			0x048c
+#define REG_MACID_PAUSE_1			0x0490
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_PKTBUF_DBG_ADDR			(REG_PKTBUF_DBG_CTRL)
+#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
+#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
+#define REG_WOWLAN_WAKE_REASON		REG_MCUTST_WOWLAN
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define REG_PCIE_HRPWM_8188E		0x0361	/* PCIe RPWM */
+#define REG_PCIE_HCPWM_8188E		0x0363	/* PCIe CPWM */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x01a4
+	#define REG_TXPKTBUF_IV_HIGH            0x01a8
+#endif
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#ifdef CONFIG_RF_POWER_TRIM
+	#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#define EEPROM_RF_GAIN_VAL				0xF6
+	#define EEPROM_THERMAL_OFFSET			0xF5
+#endif /*CONFIG_RF_POWER_TRIM*/
+/* ----------------------------------------------------------------------------
+ * 88E Driver Initialization Offload REG_FDHM0(Offset 0x88, 8 bits)
+ * ----------------------------------------------------------------------------
+ * IOL config for REG_FDHM0(Reg0x88) */
+#define CMD_INIT_LLT					BIT0
+#define CMD_READ_EFUSE_MAP		BIT1
+#define CMD_EFUSE_PATCH			BIT2
+#define CMD_IOCONFIG				BIT3
+#define CMD_INIT_LLT_ERR			BIT4
+#define CMD_READ_EFUSE_MAP_ERR	BIT5
+#define CMD_EFUSE_PATCH_ERR		BIT6
+#define CMD_IOCONFIG_ERR			BIT7
+
+/* -----------------------------------------------------
+ *
+ *	Redifine register definition for compatibility
+ *
+ * ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+ * NOTE: DO NOT Remove these definition. Use later. */
+#define ISR_88E				REG_HISR_88E
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_88E|IMR_RDU_88E|IMR_RXFOVW_88E) */
+	#define IMR_TX_MASK			(IMR_VODOK_88E | IMR_VIDOK_88E | IMR_BEDOK_88E | IMR_BKDOK_88E | IMR_MGNTDOK_88E | IMR_HIGHDOK_88E | IMR_BCNDERR0_88E)
+
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_88E | IMR_TBDOK_88E | IMR_TBDER_88E | IMR_BCNDMAINT_E_88E)
+	#else
+		#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_88E | IMR_TBDOK_88E | IMR_TBDER_88E)
+	#endif
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_88E | IMR_VODOK_88E | IMR_BEDOK_88E | IMR_BKDOK_88E)
+#endif
+
+/* ----------------------------------------------------------------------------
+ * 8192C EEPROM/EFUSE share register definition.
+ * ---------------------------------------------------------------------------- */
+
+#define EFUSE_ACCESS_ON			0x69	/* For RTL8723 only. */
+#define EFUSE_ACCESS_OFF			0x00	/* For RTL8723 only. */
+
+#endif /* __RTL8188E_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_sreset.h
new file mode 100644
index 000000000000..f4ec2d88c327
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8188E_SRESET_H_
+#define _RTL8188E_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8188e_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8188e_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_xmit.h
new file mode 100644
index 000000000000..f625576608cb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188e_xmit.h
@@ -0,0 +1,295 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_XMIT_H__
+#define __RTL8188E_XMIT_H__
+
+
+
+
+/* For 88e early mode */
+#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
+#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
+#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
+#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
+#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
+#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
+#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
+
+/*
+ * 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 QSEL_SHT			8
+#define RATE_ID_SHT			16
+#define NAVUSEHDR			BIT(20)
+#define SEC_TYPE_SHT		22
+#define PKT_OFFSET_SHT		26
+
+/* OFFSET 8 */
+#define AGG_EN				BIT(12)
+#define AGG_BK					BIT(16)
+#define AMPDU_DENSITY_SHT	20
+#define ANTSEL_A			BIT(24)
+#define ANTSEL_B			BIT(25)
+#define TX_ANT_CCK_SHT		26
+#define TX_ANTL_SHT			28
+#define TX_ANT_HT_SHT		30
+
+/* OFFSET 12 */
+#define SEQ_SHT				16
+#define EN_HWSEQ			BIT(31)
+
+/* OFFSET 16 */
+#define	QOS                          BIT(6)
+#define	HW_SSN				BIT(7)
+#define	USERATE			BIT(8)
+#define	DISDATAFB			BIT(10)
+#define   CTS_2_SELF			BIT(11)
+#define	RTS_EN				BIT(12)
+#define	HW_RTS_EN			BIT(13)
+#define	DATA_SHORT			BIT(24)
+#define	PWR_STATUS_SHT	15
+#define	DATA_SC_SHT		20
+#define	DATA_BW			BIT(25)
+
+/* OFFSET 20 */
+#define	RTY_LMT_EN			BIT(17)
+
+
+/* OFFSET 20 */
+#define SGI					BIT(6)
+#define USB_TXAGG_NUM_SHT	24
+
+typedef struct txdesc_88e {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	u32 macid:6;
+	u32 rsvd0406:2;
+	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;
+
+	/* Offset 8 */
+	u32 rts_rc:6;
+	u32 data_rc:6;
+	u32 agg_en:1;
+	u32 rd_en:1;
+	u32 bar_rty_th:2;
+	u32 bk: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;
+
+	/* Offset 12 */
+	u32 nextheadpage:8;
+	u32 tailpage:8;
+	u32 seq:12;
+	u32 cpu_handle:1;
+	u32 tag1:1;
+	u32 trigger_int:1;
+	u32 hwseq_en:1;
+
+	/* Offset 16 */
+	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 pwr_status: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;
+
+	/* Offset 20 */
+	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;
+
+	/* Offset 24 */
+	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;
+
+	/* Offset 28 */
+	u32 checksum:16;	/* TxBuffSize(PCIe)/CheckSum(USB) */
+	u32 sw0:8; /* offset 30 */
+	u32 sw1:4;
+	u32 mcs15_sgi_max_len:4;
+} TXDESC_8188E, *PTXDESC_8188E;
+
+#define txdesc_set_ccx_sw_88e(txdesc, value) \
+	do { \
+		((struct txdesc_88e *)(txdesc))->sw1 = (((value)>>8) & 0x0f); \
+		((struct txdesc_88e *)(txdesc))->sw0 = ((value) & 0xff); \
+	} while (0)
+
+struct txrpt_ccx_88e {
+	/* offset 0 */
+	u8 tag1:1;
+	u8 pkt_num:3;
+	u8 txdma_underflow:1;
+	u8 int_bt:1;
+	u8 int_tri:1;
+	u8 int_ccx:1;
+
+	/* offset 1 */
+	u8 mac_id:6;
+	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_88e(txrpt_ccx) ((txrpt_ccx)->sw0 + ((txrpt_ccx)->sw1<<8))
+#define txrpt_ccx_qtime_88e(txrpt_ccx) ((txrpt_ccx)->ccx_qtime0+((txrpt_ccx)->ccx_qtime1<<8))
+
+#define SET_TX_DESC_SEC_TYPE_8188E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+
+void rtl8188e_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen,
+			       u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8188e_cal_txdesc_chksum(struct tx_desc	*ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8188es_init_xmit_priv(PADAPTER padapter);
+	void rtl8188es_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8188es_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188es_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8188es_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	thread_return rtl8188es_xmit_thread(thread_context context);
+	s32 rtl8188es_xmit_buf_handler(PADAPTER padapter);
+
+	#ifdef CONFIG_SDIO_TX_TASKLET
+		void rtl8188es_xmit_tasklet(void *priv);
+	#endif
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8188eu_init_xmit_priv(PADAPTER padapter);
+	void rtl8188eu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8188eu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188eu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8188eu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188eu_xmit_buf_handler(PADAPTER padapter);
+	void rtl8188eu_xmit_tasklet(void *priv);
+	s32 rtl8188eu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8188ee_init_xmit_priv(PADAPTER padapter);
+	void rtl8188ee_free_xmit_priv(PADAPTER padapter);
+	void	rtl8188ee_xmitframe_resume(_adapter *padapter);
+	s32 rtl8188ee_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188ee_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8188ee_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8188ee_xmit_tasklet(void *priv);
+#endif
+
+
+
+#ifdef CONFIG_TX_EARLY_MODE
+	void UpdateEarlyModeInfo8188E(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_XMIT_ACK
+	void dump_txrpt_ccx_88e(void *buf);
+	void handle_txrpt_ccx_88e(_adapter *adapter, u8 *buf);
+#else
+	#define dump_txrpt_ccx_88e(buf) do {} while (0)
+	#define handle_txrpt_ccx_88e(adapter, buf) do {} while (0)
+#endif /* CONFIG_XMIT_ACK */
+
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif /* __RTL8188E_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_cmd.h
new file mode 100644
index 000000000000..a198e33523d4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_cmd.h
@@ -0,0 +1,208 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_CMD_H__
+#define __RTL8188F_CMD_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+enum h2c_cmd_8188F {
+	/* Common Class: 000 */
+	H2C_8188F_RSVD_PAGE = 0x00,
+	H2C_8188F_MEDIA_STATUS_RPT = 0x01,
+	H2C_8188F_SCAN_ENABLE = 0x02,
+	H2C_8188F_KEEP_ALIVE = 0x03,
+	H2C_8188F_DISCON_DECISION = 0x04,
+	H2C_8188F_PSD_OFFLOAD = 0x05,
+	H2C_8188F_AP_OFFLOAD = 0x08,
+	H2C_8188F_BCN_RSVDPAGE = 0x09,
+	H2C_8188F_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8188F_FCS_RSVDPAGE = 0x10,
+	H2C_8188F_FCS_INFO = 0x11,
+	H2C_8188F_AP_WOW_GPIO_CTRL = 0x13,
+
+	/* PoweSave Class: 001 */
+	H2C_8188F_SET_PWR_MODE = 0x20,
+	H2C_8188F_PS_TUNING_PARA = 0x21,
+	H2C_8188F_PS_TUNING_PARA2 = 0x22,
+	H2C_8188F_P2P_LPS_PARAM = 0x23,
+	H2C_8188F_P2P_PS_OFFLOAD = 0x24,
+	H2C_8188F_PS_SCAN_ENABLE = 0x25,
+	H2C_8188F_SAP_PS_ = 0x26,
+	H2C_8188F_INACTIVE_PS_ = 0x27, /* Inactive_PS */
+	H2C_8188F_FWLPS_IN_IPS_ = 0x28,
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8188F_MACID_CFG = 0x40,
+	H2C_8188F_TXBF = 0x41,
+	H2C_8188F_RSSI_SETTING = 0x42,
+	H2C_8188F_AP_REQ_TXRPT = 0x43,
+	H2C_8188F_INIT_RATE_COLLECT = 0x44,
+	H2C_8188F_RA_PARA_ADJUST = 0x46,
+
+	/* BT Class: 011 */
+	H2C_8188F_B_TYPE_TDMA = 0x60,
+	H2C_8188F_BT_INFO = 0x61,
+	H2C_8188F_FORCE_BT_TXPWR = 0x62,
+	H2C_8188F_BT_IGNORE_WLANACT = 0x63,
+	H2C_8188F_DAC_SWING_VALUE = 0x64,
+	H2C_8188F_ANT_SEL_RSV = 0x65,
+	H2C_8188F_WL_OPMODE = 0x66,
+	H2C_8188F_BT_MP_OPER = 0x67,
+	H2C_8188F_BT_CONTROL = 0x68,
+	H2C_8188F_BT_WIFI_CTRL = 0x69,
+	H2C_8188F_BT_FW_PATCH = 0x6A,
+	H2C_8188F_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
+	H2C_8188F_WOWLAN = 0x80,
+	H2C_8188F_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8188F_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8188F_AOAC_RSVD_PAGE = 0x83,
+	H2C_8188F_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_8188F_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_8188F_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_8188F_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_8188F_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
+	H2C_8188F_P2P_OFFLOAD = 0x8B,
+
+	H2C_8188F_RESET_TSF = 0xC0,
+	H2C_8188F_MAXID,
+};
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_8188F_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8188F_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8188F_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8188F_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8188F_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _KEEP_ALIVE_CMD_0x03 */
+#define SET_8188F_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8188F_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8188F_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8188F_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _DISCONNECT_DECISION_CMD_0x04 */
+#define SET_8188F_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8188F_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8188F_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8188F_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+
+/* _PWR_MOD_CMD_0x20 */
+#define SET_8188F_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+#define GET_8188F_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _PS_TUNE_PARAM_CMD_0x21 */
+#define SET_8188F_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8188F_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
+#define SET_8188F_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
+#define SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _MACID_CFG_CMD_0x40 */
+#define SET_8188F_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
+#define SET_8188F_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
+
+/* _RSSI_SETTING_CMD_0x42 */
+#define SET_8188F_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8188F_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
+#define SET_8188F_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _AP_REQ_TXRPT_CMD_0x43 */
+#define SET_8188F_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8188F_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _FORCE_BT_TXPWR_CMD_0x62 */
+#define SET_8188F_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
+#define SET_8188F_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_8188F_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_8188F_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+
+/* _BT_FW_PATCH_0x6A */
+#define SET_8188F_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+/* host message to firmware cmd */
+void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8188f_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
+void rtl8188f_set_rssi_cmd(PADAPTER padapter, u8 *param);
+void rtl8188f_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
+/* s32 rtl8188f_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
+void rtl8188f_set_FwPsTuneParam_cmd(PADAPTER padapter);
+void rtl8188f_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param);
+void rtl8188f_download_rsvd_page(PADAPTER padapter, u8 mstatus);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8188f_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P
+void rtl8188f_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8188f_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+void rtl8188f_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+#endif
+
+void rtl8188f_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
+
+s32 FillH2CCmd8188F(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8188F(_adapter *padapter, bool wowlan);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_dm.h
new file mode 100644
index 000000000000..342ade9a515c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_dm.h
@@ -0,0 +1,39 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_DM_H__
+#define __RTL8188F_DM_H__
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8188F dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
+
+void rtl8188f_init_dm_priv(PADAPTER padapter);
+void rtl8188f_deinit_dm_priv(PADAPTER padapter);
+
+void rtl8188f_InitHalDm(PADAPTER padapter);
+void rtl8188f_HalDmWatchDog(PADAPTER padapter);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_hal.h
new file mode 100644
index 000000000000..7aaead7ca35e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_hal.h
@@ -0,0 +1,268 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_HAL_H__
+#define __RTL8188F_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8188f_spec.h"
+#include "rtl8188f_rf.h"
+#include "rtl8188f_dm.h"
+#include "rtl8188f_recv.h"
+#include "rtl8188f_xmit.h"
+#include "rtl8188f_cmd.h"
+#include "rtl8188f_led.h"
+#include "Hal8188FPwrSeq.h"
+#include "Hal8188FPhyReg.h"
+#include "Hal8188FPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+#include "rtl8188f_sreset.h"
+#endif
+
+#define FW_8188F_SIZE			0x8000
+#define FW_8188F_START_ADDRESS	0x1000
+#define FW_8188F_END_ADDRESS		0x1FFF /* 0x5FFF */
+
+#define IS_FW_HEADER_EXIST_8188F(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x88F0)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8188F_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8188F, *PRT_FIRMWARE_8188F;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8188F_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8188F_FIRMWARE_HDR, *PRT_8188F_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8188F		0x05
+#define BCN_DMA_ATIME_INT_TIME_8188F		0x02
+
+/* for 8188F
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8188F			128
+#define PAGE_SIZE_RX_8188F			8
+
+#define RX_DMA_SIZE_8188F			0x4000	/* 16K */
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8188F	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8188F	0x80	/* 128B, reserved for tx report */
+#endif
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#define RX_DMA_BOUNDARY_8188F		(RX_DMA_SIZE_8188F - RX_DMA_RESERVED_SIZE_8188F - 1)
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
+#define BCNQ_PAGE_NUM_8188F		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8188F		0x08 /* 0x04 */
+#else
+	#define BCNQ1_PAGE_NUM_8188F		0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+#undef BCNQ1_PAGE_NUM_8188F
+#define BCNQ1_PAGE_NUM_8188F		0x00 /* 0x04 */
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt:1 ,PNO: 6
+ * NS offload:2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8188F	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8188F	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+#undef WOWLAN_PAGE_NUM_8188F
+#define WOWLAN_PAGE_NUM_8188F	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+#define AP_WOWLAN_PAGE_NUM_8188F	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8188F	(0xFF - BCNQ_PAGE_NUM_8188F - BCNQ1_PAGE_NUM_8188F - WOWLAN_PAGE_NUM_8188F)
+#define TX_PAGE_BOUNDARY_8188F		(TX_TOTAL_PAGE_NUMBER_8188F + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8188F	TX_TOTAL_PAGE_NUMBER_8188F
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8188F		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8188F + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8188F */
+#define NORMAL_PAGE_NUM_HPQ_8188F		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8188F		0x02
+#define NORMAL_PAGE_NUM_NPQ_8188F		0x02
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8188F		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8188F		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8188F		0x20
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES (34 + 1)
+
+#define HAL_EFUSE_MEMORY
+
+#define HWSET_MAX_SIZE_8188F			512
+#define EFUSE_REAL_CONTENT_LEN_8188F	256
+#define EFUSE_MAP_LEN_8188F				512
+#define EFUSE_MAX_SECTION_8188F			(EFUSE_MAP_LEN_8188F / 8)
+
+#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_8188F)
+
+#define EFUSE_ACCESS_ON			0x69	/* For RTL8188 only. */
+#define EFUSE_ACCESS_OFF			0x00	/* For RTL8188 only. */
+
+/* ********************************************************
+ *			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
+
+#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)
+
+/* rtl8188a_hal_init.c */
+s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8188f_FirmwareSelfReset(PADAPTER padapter);
+void rtl8188f_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8188f_InitAntenna_Selection(PADAPTER padapter);
+void rtl8188f_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8188f_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8188f_init_default_value(PADAPTER padapter);
+
+s32 rtl8188f_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8188F(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8188F(PADAPTER padapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+/* void Hal_EfuseParseBTCoexistInfo_8188F(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail); */
+void Hal_EfuseParseEEPROMVer_8188F(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8188F(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8188F(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParsePowerSavingMode_8188F(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8188F(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8188F(PADAPTER pAdapter, u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8188F(PADAPTER padapter, u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseKFreeData_8188F(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+#if 0 /* Do not need for rtl8188f */
+VOID Hal_EfuseParseVoltage_8188F(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+#endif
+
+void rtl8188f_set_pll_ref_clk_sel(_adapter *adapter, u8 sel);
+
+void rtl8188f_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8188f(_adapter *adapter);
+u8 SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8188f_InitBeaconParameters(PADAPTER padapter);
+void rtl8188f_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void	_InitBurstPktLen_8188FS(PADAPTER Adapter);
+void _8051Reset8188(PADAPTER padapter);
+#ifdef CONFIG_WOWLAN
+void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8188f_start_thread(_adapter *padapter);
+void rtl8188f_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8188fs_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8188fs_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8188fs_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8188fs_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+
+void CCX_FwC2HTxRpt_8188f(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8188F(u8  rate);
+u8 HwRateToMRate8188F(u8	 rate);
+
+#ifdef CONFIG_PCI_HCI
+BOOLEAN	InterruptRecognized8188FE(PADAPTER Adapter);
+VOID	UpdateInterruptMask8188FE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_led.h
new file mode 100644
index 000000000000..ef5d1a7761a8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_led.h
@@ -0,0 +1,45 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_LED_H__
+#define __RTL8188F_LED_H__
+#ifdef CONFIG_RTW_SW_LED
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+void rtl8188fu_InitSwLeds(PADAPTER padapter);
+void rtl8188fu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+void rtl8188fs_InitSwLeds(PADAPTER padapter);
+void rtl8188fs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+void rtl8188fs_InitSwLeds(PADAPTER padapter);
+void rtl8188fs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+void rtl8188fe_InitSwLeds(PADAPTER padapter);
+void rtl8188fe_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif
+#endif/*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_recv.h
new file mode 100644
index 000000000000..6366b8105274
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_recv.h
@@ -0,0 +1,68 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_RECV_H__
+#define __RTL8188F_RECV_H__
+
+#if defined(CONFIG_USB_HCI)
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifdef CONFIG_MINIMAL_MEMORY_USAGE
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#else
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#elif defined(CONFIG_PLATFORM_HISILICON)
+					#define MAX_RECVBUF_SZ (16384) /* 16k */
+				#else
+					#define MAX_RECVBUF_SZ (32768) /* 32k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240)  */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16k - 92E RX BUF :16K */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k		 */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+#elif defined(CONFIG_PCI_HCI)
+	#define MAX_RECVBUF_SZ (4000) /* about 4K */
+#elif defined(CONFIG_SDIO_HCI)
+	#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8188F + 1)
+#endif /* CONFIG_SDIO_HCI */
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+s32 rtl8188fs_init_recv_priv(PADAPTER padapter);
+void rtl8188fs_free_recv_priv(PADAPTER padapter);
+s32 rtl8188fs_recv_hdl(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+int rtl8188fu_init_recv_priv(_adapter *padapter);
+void rtl8188fu_free_recv_priv(_adapter *padapter);
+void rtl8188fu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8188fe_init_recv_priv(PADAPTER padapter);
+void rtl8188fe_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8188f_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8188F_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_rf.h
new file mode 100644
index 000000000000..bf4f5911751e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_rf.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_RF_H__
+#define __RTL8188F_RF_H__
+
+int	PHY_RF6052_Config8188F(IN	PADAPTER		Adapter);
+
+VOID
+PHY_RF6052SetBandwidth8188F(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_spec.h
new file mode 100644
index 000000000000..6e99acf24772
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_spec.h
@@ -0,0 +1,287 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_SPEC_H__
+#define __RTL8188F_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8188F		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RSV_CTRL_8188F				0x001C	/* 3 Byte */
+#define REG_BT_WIFI_ANTENNA_SWITCH_8188F	0x0038
+#define REG_HSISR_8188F					0x005c
+#define REG_PAD_CTRL1_8188F		0x0064
+#define REG_AFE_CTRL_4_8188F		0x0078
+#define REG_HMEBOX_DBG_0_8188F	0x0088
+#define REG_HMEBOX_DBG_1_8188F	0x008A
+#define REG_HMEBOX_DBG_2_8188F	0x008C
+#define REG_HMEBOX_DBG_3_8188F	0x008E
+#define REG_HIMR0_8188F					0x00B0
+#define REG_HISR0_8188F					0x00B4
+#define REG_HIMR1_8188F					0x00B8
+#define REG_HISR1_8188F					0x00BC
+#define REG_PMC_DBG_CTRL2_8188F			0x00CC
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8188F	0x01A0
+#define REG_C2HEVT_CMD_LEN_8188F	0x01AE
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_HMEBOX_EXT0_8188F			0x01F0
+#define REG_HMEBOX_EXT1_8188F			0x01F4
+#define REG_HMEBOX_EXT2_8188F			0x01F8
+#define REG_HMEBOX_EXT3_8188F			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_CONTROL_8188F		0x0286 /* Control the RX DMA. */
+#define REG_RXDMA_MODE_CTRL_8188F		0x0290
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8188F		0x0300
+#define	REG_INT_MIG_8188F				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_DESA_8188F			0x0308	/* TX Beacon Descriptor Address */
+#define	REG_HQ_DESA_8188F				0x0310	/* TX High Queue Descriptor Address */
+#define	REG_MGQ_DESA_8188F			0x0318	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_DESA_8188F			0x0320	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_DESA_8188F				0x0328	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_DESA_8188F			0x0330	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_DESA_8188F			0x0338	/* TX BK Queue Descriptor Address */
+#define	REG_RX_DESA_8188F				0x0340	/* RX Queue	Descriptor Address */
+#define	REG_DBI_WDATA_8188F			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8188F			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8188F				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8188F				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8188F		0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8188F			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8188F			0x0358	/* MDIO for Control */
+#define	REG_DBG_SEL_8188F				0x0360	/* Debug Selection Register */
+#define	REG_PCIE_HRPWM_8188F			0x0361	/* PCIe RPWM */
+#define	REG_PCIE_HCPWM_8188F			0x0363	/* PCIe CPWM */
+#define	REG_PCIE_MULTIFET_CTRL_8188F	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_TXPKTBUF_BCNQ_BDNY_8188F	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8188F	0x0425
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8188F	0x045D
+#ifdef CONFIG_WOWLAN
+#define REG_TXPKTBUF_IV_LOW             0x0484
+#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_AMPDU_BURST_MODE_8188F	0x04BC
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SECONDARY_CCA_CTRL_8188F	0x0577
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HIQ_FREEPG_8188F		0x0020
+#define SDIO_REG_MID_FREEPG_8188F		0x0022
+#define SDIO_REG_LOW_FREEPG_8188F		0x0024
+#define SDIO_REG_PUB_FREEPG_8188F		0x0026
+#define SDIO_REG_EXQ_FREEPG_8188F		0x0028
+#define SDIO_REG_AC_OQT_FREEPG_8188F	0x002A
+#define SDIO_REG_NOAC_OQT_FREEPG_8188F	0x002B
+
+#define SDIO_REG_HCPWM1_8188F			0x0038
+
+/* indirect access */
+#define SDIO_REG_INDIRECT_REG_CFG_8188F		0x40
+#define SET_INDIRECT_REG_ADDR(_cmd, _addr)	SET_BITS_TO_LE_2BYTE(((u8 *)(_cmd)) + 0, 0, 16, (_addr))
+#define SET_INDIRECT_REG_SIZE_1BYTE(_cmd)	SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 0)
+#define SET_INDIRECT_REG_SIZE_2BYTE(_cmd)	SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 1)
+#define SET_INDIRECT_REG_SIZE_4BYTE(_cmd)	SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 2)
+#define SET_INDIRECT_REG_WRITE(_cmd)		SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 2, 1, 1)
+#define SET_INDIRECT_REG_READ(_cmd)			SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 3, 1, 1)
+#define GET_INDIRECT_REG_RDY(_cmd)			LE_BITS_TO_1BYTE(((u8 *)(_cmd)) + 2, 4, 1)
+
+#define SDIO_REG_INDIRECT_REG_DATA_8188F	0x44
+
+/* ****************************************************************************
+ *	8188 Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+/* 2 HSISR
+ * 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)
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+#define RXPKT_RELEASE_POLL		BIT(16)
+#define RXDMA_IDLE				BIT(17)
+#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* ----------------------------------------------------------------------------
+ * 8188F REG_CCK_CHECK						(offset 0x454)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8188F					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8188F					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8188F					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8188F				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8188F					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8188F					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8188F				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8188F				BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8188F		BIT(24)		/* TSF Timer BIT(32) toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8188F				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8188F				BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8188F		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8188F			BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8188F				BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8188F					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8188F					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8188F					BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8188F				BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8188F				BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8188F					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8188F					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8188F					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8188F					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8188F					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8188F					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8188F				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8188F				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8188F				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8188F				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8188F				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8188F				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8188F				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8188F					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8188F					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8188F					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8188F					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8188F					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8188F					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8188F					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8188F				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8188F					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8188F					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8188F					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8188F					BIT(8)			/* Receive FIFO Overflow */
+
+#ifdef CONFIG_PCI_HCI
+/* #define IMR_RX_MASK		(IMR_ROK_8188F|IMR_RDU_8188F|IMR_RXFOVW_8188F) */
+#define IMR_TX_MASK			(IMR_VODOK_8188F | IMR_VIDOK_8188F | IMR_BEDOK_8188F | IMR_BKDOK_8188F | IMR_MGNTDOK_8188F | IMR_HIGHDOK_8188F)
+
+#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8188F | IMR_TXBCN0OK_8188F | IMR_TXBCN0ERR_8188F | IMR_BCNDERR0_8188F)
+
+#define RT_AC_INT_MASKS	(IMR_VIDOK_8188F | IMR_VODOK_8188F | IMR_BEDOK_8188F | IMR_BKDOK_8188F)
+#endif
+
+#endif /* __RTL8188F_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_sreset.h
new file mode 100644
index 000000000000..fe56567e7396
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8188F_SRESET_H_
+#define _RTL8188F_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+extern void rtl8188f_sreset_xmit_status_check(_adapter *padapter);
+extern void rtl8188f_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_xmit.h
new file mode 100644
index 000000000000..cf75fce248f4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8188f_xmit.h
@@ -0,0 +1,334 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188F_XMIT_H__
+#define __RTL8188F_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8188FDESC_H
+#define __INC_HAL8188FDESC_H
+
+#define RX_STATUS_DESC_SIZE_8188F		24
+#define RX_DRV_INFO_SIZE_UNIT_8188F 8
+
+
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_LAST_SEG_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+#define GET_RX_STATUS_DESC_FIRST_SEG_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+#define GET_RX_STATUS_DESC_EOR_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8188F(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_8188F(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_AMSDU_8188F(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_IPVER_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_IS_TCPUDP__8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_CHK_VLD_8188F(__pRxDesc)	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8188F(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#ifdef CONFIG_USB_RX_AGGREGATION
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8188F(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+#endif
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_SPLCP_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+#define GET_RX_STATUS_DESC_LDPC_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+#define GET_RX_STATUS_DESC_STBC_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+#define GET_RX_STATUS_DESC_BW_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+#define SET_RX_STATUS_DESC_BUFF_ADDR_8188F(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+/* Dword 0 */
+#define GET_TX_DESC_OWN_8188F(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+#define SET_TX_DESC_PKT_SIZE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_LAST_SEG_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+#define SET_TX_DESC_FIRST_SEG_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_LINIP_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+#define SET_TX_DESC_OWN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+
+
+/* Dword 2 */
+#define SET_TX_DESC_PAID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+#define SET_TX_DESC_CCA_RTS_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_AGG_BREAK_8188F(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_SPE_RPT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_INT_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_GID_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+
+/* Dword 3 */
+#define SET_TX_DESC_WHEADER_LEN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+#define SET_TX_DESC_CHK_EN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+#define SET_TX_DESC_EARLY_MODE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HWSEQ_SEL_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8188F(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_CTROL_STBC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_ANTSEL_A_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+#define SET_TX_DESC_ANTSEL_B_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+#define SET_TX_DESC_ANTSEL_C_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+#define SET_TX_DESC_ANTSEL_D_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#define SET_TX_DESC_TX_BUFFER_SIZE_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#else
+#define SET_TX_DESC_TX_DESC_CHECKSUM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+#define SET_TX_DESC_USB_TXAGG_NUM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+#define SET_TX_DESC_SDIO_TXSEQ_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+#endif
+
+/* Dword 8 */
+#define SET_TX_DESC_HWSEQ_EN_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_SEQ_8188F(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+
+/* Dword 10 */
+#define SET_TX_DESC_TX_BUFFER_ADDRESS_8188F(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+#define GET_TX_DESC_TX_BUFFER_ADDRESS_8188F(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+
+/* Dword 11 */
+#define SET_TX_DESC_NEXT_DESC_ADDRESS_8188F(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+#define SET_EARLYMODE_LEN3_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8188F_RATE1M				0x00
+#define DESC8188F_RATE2M				0x01
+#define DESC8188F_RATE5_5M				0x02
+#define DESC8188F_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8188F_RATE6M				0x04
+#define DESC8188F_RATE9M				0x05
+#define DESC8188F_RATE12M				0x06
+#define DESC8188F_RATE18M				0x07
+#define DESC8188F_RATE24M				0x08
+#define DESC8188F_RATE36M				0x09
+#define DESC8188F_RATE48M				0x0a
+#define DESC8188F_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8188F_RATEMCS0				0x0c
+#define DESC8188F_RATEMCS1				0x0d
+#define DESC8188F_RATEMCS2				0x0e
+#define DESC8188F_RATEMCS3				0x0f
+#define DESC8188F_RATEMCS4				0x10
+#define DESC8188F_RATEMCS5				0x11
+#define DESC8188F_RATEMCS6				0x12
+#define DESC8188F_RATEMCS7				0x13
+#define DESC8188F_RATEMCS8				0x14
+#define DESC8188F_RATEMCS9				0x15
+#define DESC8188F_RATEMCS10		0x16
+#define DESC8188F_RATEMCS11		0x17
+#define DESC8188F_RATEMCS12		0x18
+#define DESC8188F_RATEMCS13		0x19
+#define DESC8188F_RATEMCS14		0x1a
+#define DESC8188F_RATEMCS15		0x1b
+#define DESC8188F_RATEVHTSS1MCS0		0x2c
+#define DESC8188F_RATEVHTSS1MCS1		0x2d
+#define DESC8188F_RATEVHTSS1MCS2		0x2e
+#define DESC8188F_RATEVHTSS1MCS3		0x2f
+#define DESC8188F_RATEVHTSS1MCS4		0x30
+#define DESC8188F_RATEVHTSS1MCS5		0x31
+#define DESC8188F_RATEVHTSS1MCS6		0x32
+#define DESC8188F_RATEVHTSS1MCS7		0x33
+#define DESC8188F_RATEVHTSS1MCS8		0x34
+#define DESC8188F_RATEVHTSS1MCS9		0x35
+#define DESC8188F_RATEVHTSS2MCS0		0x36
+#define DESC8188F_RATEVHTSS2MCS1		0x37
+#define DESC8188F_RATEVHTSS2MCS2		0x38
+#define DESC8188F_RATEVHTSS2MCS3		0x39
+#define DESC8188F_RATEVHTSS2MCS4		0x3a
+#define DESC8188F_RATEVHTSS2MCS5		0x3b
+#define DESC8188F_RATEVHTSS2MCS6		0x3c
+#define DESC8188F_RATEVHTSS2MCS7		0x3d
+#define DESC8188F_RATEVHTSS2MCS8		0x3e
+#define DESC8188F_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8188F(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE11M)
+
+
+void rtl8188f_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8188f_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+#if defined(CONFIG_CONCURRENT_MODE)
+void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+s32 rtl8188fs_init_xmit_priv(PADAPTER padapter);
+void rtl8188fs_free_xmit_priv(PADAPTER padapter);
+s32 rtl8188fs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8188fs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	rtl8188fs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+s32 rtl8188fs_xmit_buf_handler(PADAPTER padapter);
+thread_return rtl8188fs_xmit_thread(thread_context context);
+#define hal_xmit_handler rtl8188fs_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+#ifdef CONFIG_XMIT_THREAD_MODE
+s32 rtl8188fu_xmit_buf_handler(PADAPTER padapter);
+#define hal_xmit_handler rtl8188fu_xmit_buf_handler
+#endif
+
+s32 rtl8188fu_init_xmit_priv(PADAPTER padapter);
+void rtl8188fu_free_xmit_priv(PADAPTER padapter);
+s32 rtl8188fu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8188fu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	 rtl8188fu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+/* s32 rtl8812au_xmit_buf_handler(PADAPTER padapter); */
+void rtl8188fu_xmit_tasklet(void *priv);
+s32 rtl8188fu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8188fe_init_xmit_priv(PADAPTER padapter);
+void rtl8188fe_free_xmit_priv(PADAPTER padapter);
+struct xmit_buf *rtl8188fe_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+void	rtl8188fe_xmitframe_resume(_adapter *padapter);
+s32 rtl8188fe_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8188fe_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	rtl8188fe_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+void rtl8188fe_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8188F(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8188F(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_cmd.h
new file mode 100644
index 000000000000..6aff7ea36771
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_cmd.h
@@ -0,0 +1,149 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_CMD_H__
+#define __RTL8192E_CMD_H__
+
+typedef enum _RTL8192E_H2C_CMD {
+	H2C_8192E_RSVDPAGE	= 0x00,
+	H2C_8192E_MSRRPT	= 0x01,
+	H2C_8192E_SCAN		= 0x02,
+	H2C_8192E_KEEP_ALIVE_CTRL = 0x03,
+	H2C_8192E_DISCONNECT_DECISION = 0x04,
+	H2C_8192E_INIT_OFFLOAD = 0x06,
+	H2C_8192E_AP_OFFLOAD = 0x08,
+	H2C_8192E_BCN_RSVDPAGE = 0x09,
+	H2C_8192E_PROBERSP_RSVDPAGE = 0x0a,
+
+	H2C_8192E_AP_WOW_GPIO_CTRL = 0x13,
+
+	H2C_8192E_SETPWRMODE = 0x20,
+	H2C_8192E_PS_TUNING_PARA = 0x21,
+	H2C_8192E_PS_TUNING_PARA2 = 0x22,
+	H2C_8192E_PS_LPS_PARA = 0x23,
+	H2C_8192E_P2P_PS_OFFLOAD = 0x24,
+	H2C_8192E_SAP_PS = 0x26,
+	H2C_8192E_RA_MASK = 0x40,
+	H2C_8192E_RSSI_REPORT = 0x42,
+	H2C_8192E_RA_PARA_ADJUST = 0x46,
+
+	H2C_8192E_WO_WLAN = 0x80,
+	H2C_8192E_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8192E_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8192E_AOAC_RSVDPAGE = 0x83,
+
+	/* Not defined in new 88E H2C CMD Format */
+	H2C_8192E_SELECTIVE_SUSPEND_ROF_CMD,
+	H2C_8192E_P2P_PS_MODE,
+	H2C_8192E_PSD_RESULT,
+	MAX_8192E_H2CCMD
+} RTL8192E_H2C_CMD;
+
+struct cmd_msg_parm {
+	u8 eid; /* element id */
+	u8 sz; /* sz */
+	u8 buf[6];
+};
+
+enum {
+	PWRS
+};
+
+typedef struct _SETPWRMODE_PARM {
+	u8 Mode;/* 0:Active,1:LPS,2:WMMPS */
+	/* u8 RLBM:4; */ /* 0:Min,1:Max,2: User define */
+	u8 SmartPS_RLBM;/* LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData */
+	u8 AwakeInterval;	/* unit: beacon interval */
+	u8 bAllQueueUAPSD;
+	u8 PwrState;/* AllON(0x0c),RFON(0x04),RFOFF(0x00) */
+} SETPWRMODE_PARM, *PSETPWRMODE_PARM;
+
+struct H2C_SS_RFOFF_PARAM {
+	u8 ROFOn; /* 1: on, 0:off */
+	u16 gpio_period; /* unit: 1024 us */
+} __attribute__((packed));
+
+
+typedef struct JOINBSSRPT_PARM_92E {
+	u8 OpMode;	/* RT_MEDIA_STATUS */
+#ifdef CONFIG_WOWLAN
+	u8 MacID;       /* MACID */
+#endif /* CONFIG_WOWLAN */
+} JOINBSSRPT_PARM_92E, *PJOINBSSRPT_PARM_92E;
+
+/* move to hal_com_h2c.h
+typedef struct _RSVDPAGE_LOC_92E {
+	u8 LocProbeRsp;
+	u8 LocPsPoll;
+	u8 LocNullData;
+	u8 LocQosNull;
+	u8 LocBTQosNull;
+} RSVDPAGE_LOC_92E, *PRSVDPAGE_LOC_92E;
+*/
+
+
+/* _SETPWRMODE_PARM */
+#define SET_8192E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#define GET_8192E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)						LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _P2P_PS_OFFLOAD */
+#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_NOA0_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_NOA1_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
+
+
+/* host message to firmware cmd */
+void rtl8192e_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8192e_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
+u8 rtl8192e_set_rssi_cmd(PADAPTER padapter, u8 *param);
+s32 FillH2CCmd_8192E(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8192E(_adapter *padapter, bool wowlan);
+/* u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period); */
+s32 c2h_handler_8192e(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8192e_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P_PS
+	void rtl8192e_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8192e_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
+
+/* / TX Feedback Content */
+#define	USEC_UNIT_FOR_8192E_C2H_TX_RPT_QUEUE_TIME			256
+
+#define	GET_8192E_C2H_TX_RPT_QUEUE_SELECT(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 5)
+#define	GET_8192E_C2H_TX_RPT_PKT_BROCAST(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 5, 1)
+#define	GET_8192E_C2H_TX_RPT_LIFE_TIME_OVER(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 6, 1)
+#define	GET_8192E_C2H_TX_RPT_RETRY_OVER(_Header)				LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
+#define	GET_8192E_C2H_TX_RPT_MAC_ID(_Header)					LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
+#define	GET_8192E_C2H_TX_RPT_DATA_RETRY_CNT(_Header)		LE_BITS_TO_1BYTE((_Header + 2), 0, 6)
+#define	GET_8192E_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	/* In unit of 256 microseconds. */
+#define	GET_8192E_C2H_TX_RPT_FINAL_DATA_RATE(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
+
+#endif /* __RTL8192E_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_dm.h
new file mode 100644
index 000000000000..5f6ee4b0e61a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_dm.h
@@ -0,0 +1,28 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_DM_H__
+#define __RTL8192E_DM_H__
+
+
+void rtl8192e_init_dm_priv(IN PADAPTER Adapter);
+void rtl8192e_deinit_dm_priv(IN PADAPTER Adapter);
+void rtl8192e_InitHalDm(IN PADAPTER Adapter);
+void rtl8192e_HalDmWatchDog(IN PADAPTER Adapter);
+
+/* VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter); */
+
+/* void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal); */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_hal.h
new file mode 100644
index 000000000000..edd4040053a5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_hal.h
@@ -0,0 +1,328 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_HAL_H__
+#define __RTL8192E_HAL_H__
+
+/* #include "hal_com.h" */
+
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8192e_spec.h"
+#include "rtl8192e_rf.h"
+#include "rtl8192e_dm.h"
+#include "rtl8192e_recv.h"
+#include "rtl8192e_xmit.h"
+#include "rtl8192e_cmd.h"
+#include "rtl8192e_led.h"
+#include "Hal8192EPwrSeq.h"
+#include "Hal8192EPhyReg.h"
+#include "Hal8192EPhyCfg.h"
+
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8192e_sreset.h"
+#endif
+
+/* ---------------------------------------------------------------------
+ *		RTL8192E Power Configuration CMDs for PCIe interface
+ * --------------------------------------------------------------------- */
+#define Rtl8192E_NIC_PWR_ON_FLOW				rtl8192E_power_on_flow
+#define Rtl8192E_NIC_RF_OFF_FLOW				rtl8192E_radio_off_flow
+#define Rtl8192E_NIC_DISABLE_FLOW				rtl8192E_card_disable_flow
+#define Rtl8192E_NIC_ENABLE_FLOW				rtl8192E_card_enable_flow
+#define Rtl8192E_NIC_SUSPEND_FLOW				rtl8192E_suspend_flow
+#define Rtl8192E_NIC_RESUME_FLOW				rtl8192E_resume_flow
+#define Rtl8192E_NIC_PDN_FLOW					rtl8192E_hwpdn_flow
+#define Rtl8192E_NIC_LPS_ENTER_FLOW			rtl8192E_enter_lps_flow
+#define Rtl8192E_NIC_LPS_LEAVE_FLOW			rtl8192E_leave_lps_flow
+
+
+#if 1 /* download firmware related data structure */
+#define FW_SIZE_8192E			0x8000 /* Compatible with RTL8192e Maximal RAM code size 32k */
+#define FW_START_ADDRESS		0x1000
+#define FW_END_ADDRESS			0x5FFF
+
+
+#define IS_FW_HEADER_EXIST_8192E(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8192E(_pFwHdr) & 0xFFF0) == 0x92E0)
+
+
+
+typedef struct _RT_FIRMWARE_8192E {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_SIZE_8192E];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8192E, *PRT_FIRMWARE_8192E;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+
+/* *****************************************************
+ *					Firmware Header(8-byte alinment required)
+ * *****************************************************
+ * --- LONG WORD 0 ---- */
+#define GET_FIRMWARE_HDR_SIGNATURE_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16) /* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut */
+#define GET_FIRMWARE_HDR_CATEGORY_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) /* AP/NIC and USB/PCI */
+#define GET_FIRMWARE_HDR_FUNCTION_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 24, 8) /* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions */
+#define GET_FIRMWARE_HDR_VERSION_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)/* FW Version */
+#define GET_FIRMWARE_HDR_SUB_VER_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) /* FW Subversion, default 0x00 */
+#define GET_FIRMWARE_HDR_RSVD1_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8)
+
+/* --- LONG WORD 1 ---- */
+#define GET_FIRMWARE_HDR_MONTH_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 8) /* Release time Month field */
+#define GET_FIRMWARE_HDR_DATE_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 8, 8) /* Release time Date field */
+#define GET_FIRMWARE_HDR_HOUR_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 16, 8)/* Release time Hour field */
+#define GET_FIRMWARE_HDR_MINUTE_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 24, 8)/* Release time Minute field */
+#define GET_FIRMWARE_HDR_ROMCODE_SIZE_8192E(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+12, 0, 16)/* The size of RAM code */
+#define GET_FIRMWARE_HDR_RSVD2_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 16, 16)
+
+/* --- LONG WORD 2 ---- */
+#define GET_FIRMWARE_HDR_SVN_IDX_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 0, 32)/* The SVN entry index */
+#define GET_FIRMWARE_HDR_RSVD3_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 0, 32)
+
+/* --- LONG WORD 3 ---- */
+#define GET_FIRMWARE_HDR_RSVD4_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 0, 32)
+#define GET_FIRMWARE_HDR_RSVD5_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
+
+#endif /* download firmware related data structure */
+
+#define DRIVER_EARLY_INT_TIME_8192E		0x05
+#define BCN_DMA_ATIME_INT_TIME_8192E		0x02
+#define RX_DMA_SIZE_8192E					0x4000	/* 16K*/
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8192E	0x100	/* 256B, reserved for c2h debug message*/
+#else
+	#define RX_DMA_RESERVED_SIZE_8192E	0x40	/* 64B, reserved for c2h event(16bytes) or ccx(8 Bytes)*/
+#endif
+#define MAX_RX_DMA_BUFFER_SIZE_8192E		(RX_DMA_SIZE_8192E-RX_DMA_RESERVED_SIZE_8192E)	/*RX 16K*/
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * if (CONFIG_2BCN_EN) Beacon:4, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1
+ * Beacon:2, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1 */
+#define RSVD_PAGE_NUM_8192E		0x08
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1,PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8192E	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8192E	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8192E
+	#define WOWLAN_PAGE_NUM_8192E	0x0d
+#endif
+
+/* Note:
+Tx FIFO Size : 64KB
+Tx page Size : 256B
+Total page numbers : 256(0x100)
+*/
+
+#define	TOTAL_RSVD_PAGE_NUMBER_8192E	(RSVD_PAGE_NUM_8192E + WOWLAN_PAGE_NUM_8192E)
+
+#define	TOTAL_PAGE_NUMBER_8192E	(0x100)
+#define	TX_TOTAL_PAGE_NUMBER_8192E	(TOTAL_PAGE_NUMBER_8192E - TOTAL_RSVD_PAGE_NUMBER_8192E)
+
+#define	TX_PAGE_BOUNDARY_8192E	(TX_TOTAL_PAGE_NUMBER_8192E) /* beacon header start address */
+
+
+#define PAGE_SIZE_TX_92E	PAGE_SIZE_256
+#define RSVD_PKT_LEN_92E	(TOTAL_RSVD_PAGE_NUMBER_8192E * PAGE_SIZE_TX_92E)
+
+#define TX_PAGE_LOAD_FW_BOUNDARY_8192E		0x47 /* 0xA5 */
+#define TX_PAGE_BOUNDARY_WOWLAN_8192E		0xE0
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_92C */
+
+#define NORMAL_PAGE_NUM_HPQ_8192E			0x10
+#define NORMAL_PAGE_NUM_LPQ_8192E			0x10
+#define NORMAL_PAGE_NUM_NPQ_8192E			0x10
+#define NORMAL_PAGE_NUM_EPQ_8192E			0x00
+
+
+/* Note: For WMM Normal Chip Setting ,modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8192E		NORMAL_PAGE_NUM_HPQ_8192E
+#define WMM_NORMAL_PAGE_NUM_LPQ_8192E		NORMAL_PAGE_NUM_LPQ_8192E
+#define WMM_NORMAL_PAGE_NUM_NPQ_8192E		NORMAL_PAGE_NUM_NPQ_8192E
+
+
+/* -------------------------------------------------------------------------
+ *	Chip specific
+ * ------------------------------------------------------------------------- */
+
+/* pic buffer descriptor */
+#define RTL8192EE_SEG_NUM			TX_BUFFER_SEG_NUM
+#define TX_DESC_NUM_92E			128
+#define RX_DESC_NUM_92E			128
+
+/* -------------------------------------------------------------------------
+ *	Channel Plan
+ * ------------------------------------------------------------------------- */
+
+#define		HWSET_MAX_SIZE_8192E			512
+
+#define		EFUSE_REAL_CONTENT_LEN_8192E	512
+
+#define		EFUSE_MAP_LEN_8192E			512
+#define		EFUSE_MAX_SECTION_8192E		64
+#define		EFUSE_MAX_WORD_UNIT_8192E		4
+#define		EFUSE_IC_ID_OFFSET_8192E		506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define		AVAILABLE_EFUSE_ADDR_8192E(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8192E)
+/*
+ * <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)	      |
+ *   */
+#define		EFUSE_OOB_PROTECT_BYTES_8192E 		15	/* PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte. */
+
+
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define		EFUSE_BT_REAL_BANK_CONTENT_LEN_8192E	512
+#define		EFUSE_BT_REAL_CONTENT_LEN_8192E			1024	/* 512*2 */
+#define		EFUSE_BT_MAP_LEN_8192E					1024	/* 1k bytes */
+#define		EFUSE_BT_MAX_SECTION_8192E				128		/* 1024/8 */
+
+#define		EFUSE_PROTECT_BYTES_BANK_8192E			16
+#define		EFUSE_MAX_BANK_8192E					3
+/* *********************************************************** */
+
+#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)
+
+/* #define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE) */
+
+/* #define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) ) */
+
+/* rtl8812_hal_init.c */
+void	_8051Reset8192E(PADAPTER padapter);
+s32	FirmwareDownload8192E(PADAPTER Adapter, BOOLEAN bUsedWoWLANFw);
+void	InitializeFirmwareVars8192E(PADAPTER padapter);
+
+s32	InitLLTTable8192E(PADAPTER padapter, u8 txpktbuf_bndy);
+
+/* EFuse */
+u8	GetEEPROMSize8192E(PADAPTER padapter);
+void	hal_InitPGData_8192E(PADAPTER padapter, u8 *PROMContent);
+void	Hal_EfuseParseIDCode8192E(PADAPTER padapter, u8 *hwinfo);
+void	Hal_ReadPROMVersion8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadPowerSavingMode8192E(PADAPTER padapter, u8	*hwinfo, BOOLEAN	AutoLoadFail);
+void	Hal_ReadTxPowerInfo8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+void	Hal_ReadBoardType8192E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadThermalMeter_8192E(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void	Hal_ReadChannelPlan8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_EfuseParseXtal_8192E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadAntennaDiversity8192E(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void	Hal_ReadPAType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadAmplifierType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadRFEType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_EfuseParseBTCoexistInfo8192E(PADAPTER Adapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_EfuseParseKFreeData_8192E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+u8 Hal_CrystalAFEAdjust(_adapter *Adapter);
+
+BOOLEAN HalDetectPwrDownMode8192E(PADAPTER Adapter);
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+/***********************************************************/
+/* RTL8192E-MAC Setting */
+VOID _InitQueueReservedPage_8192E(IN  PADAPTER Adapter);
+VOID _InitQueuePriority_8192E(IN	PADAPTER Adapter);
+VOID _InitTxBufferBoundary_8192E(IN PADAPTER Adapter, IN u8 txpktbuf_bndy);
+VOID _InitPageBoundary_8192E(IN PADAPTER Adapter);
+/* VOID _InitTransferPageSize_8192E(IN PADAPTER Adapter); */
+VOID _InitDriverInfoSize_8192E(IN PADAPTER Adapter, IN u8 drvInfoSize);
+VOID _InitRDGSetting_8192E(PADAPTER Adapter);
+void _InitID_8192E(IN  PADAPTER Adapter);
+VOID _InitNetworkType_8192E(IN  PADAPTER Adapter);
+VOID _InitWMACSetting_8192E(IN PADAPTER Adapter);
+VOID _InitAdaptiveCtrl_8192E(IN  PADAPTER Adapter);
+VOID _InitEDCA_8192E(IN  PADAPTER Adapter);
+VOID _InitRetryFunction_8192E(IN  PADAPTER Adapter);
+VOID _BBTurnOnBlock_8192E(IN	PADAPTER Adapter);
+VOID _InitBeaconParameters_8192E(IN  PADAPTER Adapter);
+VOID _InitBeaconMaxError_8192E(
+	IN  PADAPTER	Adapter,
+	IN	BOOLEAN		InfraMode
+);
+void SetBeaconRelatedRegisters8192E(PADAPTER padapter);
+VOID hal_ReadRFType_8192E(PADAPTER	Adapter);
+/* RTL8192E-MAC Setting
+ ***********************************************************/
+
+u8 SetHwReg8192E(PADAPTER Adapter, u8 variable, u8 *val);
+void GetHwReg8192E(PADAPTER Adapter, u8 variable, u8 *val);
+u8
+SetHalDefVar8192E(
+	IN	PADAPTER				Adapter,
+	IN	HAL_DEF_VARIABLE		eVariable,
+	IN	PVOID					pValue
+);
+u8
+GetHalDefVar8192E(
+	IN	PADAPTER				Adapter,
+	IN	HAL_DEF_VARIABLE		eVariable,
+	IN	PVOID					pValue
+);
+
+void rtl8192e_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8192e(_adapter *adapter);
+void rtl8192e_init_default_value(_adapter *padapter);
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+
+void rtl8192e_start_thread(_adapter *padapter);
+void rtl8192e_stop_thread(_adapter *padapter);
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8192EE(PADAPTER Adapter);
+	u16	get_txbd_rw_reg(u16 ff_hwaddr);
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+	#ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT
+		void _init_available_page_threshold(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
+	#endif
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+	void rtl8192e_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
+#endif
+
+#endif /* __RTL8192E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_led.h
new file mode 100644
index 000000000000..3d795c4055a8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_led.h
@@ -0,0 +1,36 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_LED_H__
+#define __RTL8192E_LED_H__
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8192eu_InitSwLeds(PADAPTER padapter);
+	void rtl8192eu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8192ee_InitSwLeds(PADAPTER padapter);
+	void rtl8192ee_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8192es_InitSwLeds(PADAPTER padapter);
+	void rtl8192es_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif
+#endif/*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_recv.h
new file mode 100644
index 000000000000..6ccb8e9b17a1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_recv.h
@@ -0,0 +1,179 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_RECV_H__
+#define __RTL8192E_RECV_H__
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifdef CONFIG_MINIMAL_MEMORY_USAGE
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#else
+				#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+					#define MAX_RECVBUF_SZ (rtw_rtkm_get_buff_size()) /*depend rtkm*/
+				#elif defined(CONFIG_PLATFORM_HISILICON)
+					#define MAX_RECVBUF_SZ (16384) /* 16k */
+				#else
+					#define MAX_RECVBUF_SZ (32768) /* 32k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240)  */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16k - 92E RX BUF :16K */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k		 */
+				#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+					#undef MAX_RECVBUF_SZ
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI)
+
+	#define MAX_RECVBUF_SZ (16384)
+
+#endif
+
+
+/* Rx smooth factor */
+#define Rx_Smooth_Factor (20)
+
+/* *************
+ * [1] Rx Buffer Descriptor (for PCIE) buffer descriptor architecture
+ * DWORD 0 */
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_92E(__pRxStatusDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 15, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_FS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 1)
+#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+
+
+/* DWORD 1 */
+#define SET_RX_BUFFER_PHYSICAL_LOW_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+#define GET_RX_BUFFER_PHYSICAL_LOW_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 32)
+
+/* DWORD 2 */
+#define SET_RX_BUFFER_PHYSICAL_HIGH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+
+/* *************
+ * [2] Rx Descriptor
+ * DWORD 0 */
+#define GET_RX_STATUS_DESC_PKT_LEN_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICVERR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_EOR_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+
+#define SET_RX_STATUS_DESC_PKT_LEN_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_92E(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_92E(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_MACID_VLD_92E(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 12, 1)
+#define GET_RX_STATUS_DESC_AMSDU_92E(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FITS_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_HWRSVD_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 24, 4)
+#define GET_RX_STATUS_DESC_FCS_OK_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+#define GET_RX_STATUS_DESC_RPT_SEL_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#define GET_RX_STATUS_DESC_DMA_AGG_NUM_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_WAKE_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_SPLCP_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+#define GET_RX_STATUS_DESC_LDPC_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+#define GET_RX_STATUS_DESC_STBC_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+#define GET_RX_STATUS_DESC_BW_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_92E(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_92E(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+
+#ifdef CONFIG_SDIO_HCI
+	s32 rtl8192es_init_recv_priv(PADAPTER padapter);
+	void rtl8192es_free_recv_priv(PADAPTER padapter);
+	s32 rtl8192es_recv_hdl(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	void rtl8192eu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+	s32 rtl8192eu_init_recv_priv(PADAPTER padapter);
+	void rtl8192eu_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8192ee_init_recv_priv(PADAPTER padapter);
+	void rtl8192ee_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8192e_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8192E_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_rf.h
new file mode 100644
index 000000000000..f15e07041ba8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_rf.h
@@ -0,0 +1,28 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_RF_H__
+#define __RTL8192E_RF_H__
+
+VOID
+PHY_RF6052SetBandwidth8192E(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
+
+
+int
+PHY_RF6052_Config_8192E(
+	IN	PADAPTER	Adapter);
+
+#endif/* __RTL8192E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_spec.h
new file mode 100644
index 000000000000..c9b2b41e6e48
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_spec.h
@@ -0,0 +1,313 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_SPEC_H__
+#define __RTL8192E_SPEC_H__
+
+#include <drv_conf.h>
+
+#define HAL_NAV_UPPER_UNIT_8192E		128		/* micro-second */
+
+/* ************************************************************
+ * 8192E Regsiter offset definition
+ * ************************************************************ */
+
+/* ************************************************************
+ *
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_SWR_CTRL1_8192E		0x0010	/* 1 Byte        */
+#define REG_SYS_SWR_CTRL2_8192E		0x0014	/* 1 Byte      */
+#define REG_AFE_CTRL1_8192E			0x0024
+#define REG_AFE_CTRL2_8192E			0x0028
+#define REG_AFE_CTRL3_8192E			0x002c
+
+#define REG_PAD_CTRL1_8192E			0x0064
+#define REG_SDIO_CTRL_8192E			0x0070
+#define REG_OPT_CTRL_8192E				0x0074
+#define REG_RF_B_CTRL_8192E			0x0076
+#define REG_AFE_CTRL4_8192E			0x0078
+#define REG_LDO_SWR_CTRL				0x007C
+#define REG_FW_DRV_MSG_8192E			0x0088
+#define REG_HMEBOX_E2_E3_8192E		0x008C
+#define REG_HIMR0_8192E				0x00B0
+#define REG_HISR0_8192E					0x00B4
+#define REG_HIMR1_8192E					0x00B8
+#define REG_HISR1_8192E					0x00BC
+
+#define REG_SYS_CFG1_8192E				0x00F0
+#define REG_SYS_CFG2_8192E				0x00FC
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_PKTBUF_DBG_ADDR			(REG_PKTBUF_DBG_CTRL)
+#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
+#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
+#define REG_WOWLAN_WAKE_REASON		REG_MCUTST_WOWLAN
+
+#define REG_RSVD3_8192E					0x0168
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_88XX		0x01AE
+
+#define REG_HMEBOX_EXT0_8192E			0x01F0
+#define REG_HMEBOX_EXT1_8192E			0x01F4
+#define REG_HMEBOX_EXT2_8192E			0x01F8
+#define REG_HMEBOX_EXT3_8192E			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_DWBCN0_CTRL             0x0208
+#define REG_DWBCN1_CTRL             0x0228
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_8192E					0x0290
+#define REG_EARLY_MODE_CONTROL_8192E		0x02BC
+
+#define REG_RSVD5_8192E					0x02F0
+#define REG_RSVD6_8192E					0x02F4
+#define REG_RSVD7_8192E					0x02F8
+#define REG_RSVD8_8192E					0x02FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8192E			0x0300
+#define	REG_INT_MIG_8192E					0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8192E		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8192E			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8192E			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8192E			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8192E			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8192E			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8192E			0x0338	/* RX Queue	Descriptor Address */
+#define	REG_HI0Q_TXBD_DESA_8192E			0x0340
+#define	REG_HI1Q_TXBD_DESA_8192E			0x0348
+#define	REG_HI2Q_TXBD_DESA_8192E			0x0350
+#define	REG_HI3Q_TXBD_DESA_8192E			0x0358
+#define	REG_HI4Q_TXBD_DESA_8192E			0x0360
+#define	REG_HI5Q_TXBD_DESA_8192E			0x0368
+#define	REG_HI6Q_TXBD_DESA_8192E			0x0370
+#define	REG_HI7Q_TXBD_DESA_8192E			0x0378
+#define	REG_MGQ_TXBD_NUM_8192E			0x0380
+#define	REG_RX_RXBD_NUM_8192E			0x0382
+#define	REG_VOQ_TXBD_NUM_8192E			0x0384
+#define	REG_VIQ_TXBD_NUM_8192E			0x0386
+#define	REG_BEQ_TXBD_NUM_8192E			0x0388
+#define	REG_BKQ_TXBD_NUM_8192E			0x038A
+#define	REG_HI0Q_TXBD_NUM_8192E			0x038C
+#define	REG_HI1Q_TXBD_NUM_8192E			0x038E
+#define	REG_HI2Q_TXBD_NUM_8192E			0x0390
+#define	REG_HI3Q_TXBD_NUM_8192E			0x0392
+#define	REG_HI4Q_TXBD_NUM_8192E			0x0394
+#define	REG_HI5Q_TXBD_NUM_8192E			0x0396
+#define	REG_HI6Q_TXBD_NUM_8192E			0x0398
+#define	REG_HI7Q_TXBD_NUM_8192E			0x039A
+#define	REG_TSFTIMER_HCI_8192E			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8192E			0x03A0
+#define	REG_VIQ_TXBD_IDX_8192E			0x03A4
+#define	REG_BEQ_TXBD_IDX_8192E			0x03A8
+#define	REG_BKQ_TXBD_IDX_8192E			0x03AC
+#define	REG_MGQ_TXBD_IDX_8192E			0x03B0
+#define	REG_RXQ_TXBD_IDX_8192E			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8192E			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8192E			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8192E			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8192E			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8192E			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8192E			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8192E			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8192E			0x03D4
+
+#define	REG_PCIE_HCPWM_8192EE			0x03D8 /* ?????? */
+#define	REG_PCIE_HRPWM_8192EE			0x03DC	/* PCIe RPWM */ /* ?????? */
+#define	REG_DBI_WDATA_V1_8192E			0x03E8
+#define	REG_DBI_RDATA_V1_8192E			0x03EC
+#define	REG_DBI_FLAG_V1_8192E				0x03F0
+#define	REG_MDIO_V1_8192E					0x3F4
+#define	REG_PCIE_MIX_CFG_8192E				0x3F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_TXBF_CTRL_8192E				0x042C
+#define REG_ARFR0_8192E					0x0444
+#define REG_ARFR1_8192E					0x044C
+#define REG_CCK_CHECK_8192E				0x0454
+#define REG_AMPDU_MAX_TIME_8192E			0x0456
+#define REG_BCNQ1_BDNY_8192E				0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8192E	0x0458
+#define REG_WMAC_LBK_BUF_HD_8192E			0x045D
+#define REG_NDPA_OPT_CTRL_8192E		0x045F
+#define REG_DATA_SC_8192E				0x0483
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_ARFR2_8192E					0x048C
+#define REG_ARFR3_8192E					0x0494
+#define REG_TXRPT_START_OFFSET			0x04AC
+#define REG_AMPDU_BURST_MODE_8192E	0x04BC
+#define REG_HT_SINGLE_AMPDU_8192E		0x04C7
+#define REG_MACID_PKT_DROP0_8192E		0x04D0
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_CTWND_8192E					0x0572
+#define REG_SECONDARY_CCA_CTRL_8192E	0x0577
+#define REG_SCH_TXCMD_8192E			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8192E				0x0600
+
+#define REG_MAC_TX_SM_STATE_8192E		0x06B4
+
+/* Power */
+#define REG_BFMER0_INFO_8192E			0x06E4
+#define REG_BFMER1_INFO_8192E			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8192E	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8192E	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8192E	0x06FC
+
+/* Hardware Port 2 */
+#define REG_BFMEE_SEL_8192E				0x0714
+#define REG_SND_PTCL_CTRL_8192E		0x0718
+
+
+/* -----------------------------------------------------
+ *
+ *	Redifine register definition for compatibility
+ *
+ * ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+ * NOTE: DO NOT Remove these definition. Use later. */
+#define	ISR_8192E							REG_HISR0_8192E
+
+/* ----------------------------------------------------------------------------
+ * 8192E IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8192E					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8192E					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8192E					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8192E				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8192E					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8192E					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8192E				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8192E					BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8192E		BIT(24)		/* TSF Timer BIT(32) toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8192E				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8192E					BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8192E		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8192E				BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8192E					BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8192E					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8192E					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8192E						BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8192E					BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8192E					BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8192E					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8192E					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8192E					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8192E					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8192E						BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8192E						BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8192E				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8192E				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8192E				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8192E				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8192E				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8192E				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8192E				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8192E					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8192E					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8192E					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8192E					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8192E					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8192E					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8192E					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8192E				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8192E					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8192E					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8192E					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8192E					BIT(8)			/* Receive FIFO Overflow */
+
+/* ----------------------------------------------------------------------------
+ * 8192E Auto LLT bits						(offset 0x224,  8bits)
+ * ----------------------------------------------------------------------------
+ * 224 REG_AUTO_LLT
+ * move to hal_com_reg.h */
+
+/* ----------------------------------------------------------------------------
+ * 8192E Auto LLT bits						(offset 0x290,  32bits)
+ * ---------------------------------------------------------------------------- */
+#define BIT_DMA_MODE			BIT(1)
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+
+/* ----------------------------------------------------------------------------
+ * 8192E REG_SYS_CFG1						(offset 0xF0,  32bits)
+ * ---------------------------------------------------------------------------- */
+#define BIT_SPSLDO_SEL			BIT(24)
+
+
+/* ----------------------------------------------------------------------------
+ * 8192E REG_CCK_CHECK						(offset 0x454,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+/* ****************************************************************************
+ * Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+/* 2 ACMHWCTRL 0x05C0 */
+#define	AcmHw_HwEn_8192E				BIT(0)
+#define	AcmHw_VoqEn_8192E				BIT(1)
+#define	AcmHw_ViqEn_8192E				BIT(2)
+#define	AcmHw_BeqEn_8192E				BIT(3)
+#define	AcmHw_VoqStatus_8192E			BIT(5)
+#define	AcmHw_ViqStatus_8192E			BIT(6)
+#define	AcmHw_BeqStatus_8192E			BIT(7)
+
+#endif /* __RTL8192E_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_sreset.h
new file mode 100644
index 000000000000..78109aea468f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL88812A_SRESET_H_
+#define _RTL8812A_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8192e_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8192e_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_xmit.h
new file mode 100644
index 000000000000..0202302c8392
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8192e_xmit.h
@@ -0,0 +1,448 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_XMIT_H__
+#define __RTL8192E_XMIT_H__
+
+typedef struct txdescriptor_8192e {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	u32 macid:6;
+	u32 rsvd0406:2;
+	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;
+
+	/* Offset 8 */
+	u32 rts_rc:6;
+	u32 data_rc:6;
+	u32 agg_en:1;
+	u32 rd_en:1;
+	u32 bar_rty_th:2;
+	u32 bk: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;
+
+	/* Offset 12 */
+	u32 nextheadpage:8;
+	u32 tailpage:8;
+	u32 seq:12;
+	u32 cpu_handle:1;
+	u32 tag1:1;
+	u32 trigger_int:1;
+	u32 hwseq_en:1;
+
+	/* Offset 16 */
+	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 pwr_status: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;
+
+	/* Offset 20 */
+	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;
+
+	/* Offset 24 */
+	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;
+
+	/* Offset 28 */
+	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;
+} TXDESC_8192E, *PTXDESC_8192E;
+
+
+
+/* For 88e early mode */
+#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
+#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
+#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
+#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
+#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
+#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
+#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
+
+/*
+ * 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 QSEL_SHT			8
+#define RATE_ID_SHT			16
+#define NAVUSEHDR			BIT(20)
+#define SEC_TYPE_SHT		22
+#define PKT_OFFSET_SHT		26
+
+/* OFFSET 8 */
+#define AGG_EN				BIT(12)
+#define AGG_BK					BIT(16)
+#define AMPDU_DENSITY_SHT	20
+#define ANTSEL_A			BIT(24)
+#define ANTSEL_B			BIT(25)
+#define TX_ANT_CCK_SHT		26
+#define TX_ANTL_SHT			28
+#define TX_ANT_HT_SHT		30
+
+/* OFFSET 12 */
+#define SEQ_SHT				16
+#define EN_HWSEQ			BIT(31)
+
+/* OFFSET 16 */
+#define	QOS                          BIT(6)
+#define	HW_SSN				BIT(7)
+#define	USERATE			BIT(8)
+#define	DISDATAFB			BIT(10)
+#define   CTS_2_SELF			BIT(11)
+#define	RTS_EN				BIT(12)
+#define	HW_RTS_EN			BIT(13)
+#define	DATA_SHORT			BIT(24)
+#define	PWR_STATUS_SHT	15
+#define	DATA_SC_SHT		20
+#define	DATA_BW			BIT(25)
+
+/* OFFSET 20 */
+#define	RTY_LMT_EN			BIT(17)
+
+
+/* OFFSET 20 */
+#define SGI					BIT(6)
+#define USB_TXAGG_NUM_SHT	24
+
+
+/* *****Tx Desc Buffer content */
+
+/* config element for each tx buffer
+ *
+#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 0, 16, __Valeu)
+#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 31, 1, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+4, 0, 32, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+8, 0, 32, __Valeu)
+*/
+#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
+#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+8, 0, 32, __Valeu)
+
+
+/* Dword 0 */
+#define SET_TX_BUFF_DESC_LEN_0_92E(__pTxDesc, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 14, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+/* Dword 1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_DESC_TX_BUFFER_ADDRESS_92E(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+
+
+/* Dword 2 */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0, 32, __Value)
+/* Dword 3, RESERVED */
+
+
+/* *****Tx Desc content
+ * Dword 0 */
+#define SET_TX_DESC_PKT_SIZE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_LAST_SEG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+#define SET_TX_DESC_FIRST_SEG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_LINIP_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+#define SET_TX_DESC_NO_ACM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+#define SET_TX_DESC_OWN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+#define GET_TX_DESC_OWN_92E(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_CAP_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 30, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_MODE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 31, 1, __Value)
+
+
+/* Dword 2 */
+#define SET_TX_DESC_PAID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+#define SET_TX_DESC_CCA_RTS_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL_0_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL_1_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_92E(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define GET_TX_DESC_MORE_FRAG_92E(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc+8, 17, 1)
+#define SET_TX_DESC_SPE_RPT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_NULL_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_GID_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+
+/* Dword 3 */
+#define SET_TX_DESC_WHEADER_LEN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+#define SET_TX_DESC_CHK_EN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+#define SET_TX_DESC_EARLY_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HWSEQ_SEL_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_HW_PORT_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TRY_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_92E(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_VCS_STBC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_TX_ANT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
+#define SET_TX_DESC_TX_POWER_0_PSET_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_ANTSEL_A_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+#define SET_TX_DESC_ANTSEL_B_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+#define SET_TX_DESC_ANTSEL_C_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+#define SET_TX_DESC_ANTSEL_D_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	#define SET_TX_DESC_TX_BUFFER_SIZE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#else
+	#define SET_TX_DESC_TX_DESC_CHECKSUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+#define SET_TX_DESC_USB_TXAGG_NUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+
+/* #define SET_TX_DESC_HWSEQ_EN_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value) */
+/* Dword 8 */
+
+#define SET_TX_DESC_RTS_RC_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RTY_TH_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_EN_HWSEQ_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#define SET_TX_DESC_NEXT_HEAD_PAGE_92E(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#define SET_TX_DESC_TAIL_PAGE_92E(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LENGTH_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_TXBF_PATH_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 11, 1, __Value)
+#define SET_TX_DESC_SEQ_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_FINAL_DATA_RATE_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 8, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
+#define SET_EARLYMODE_LEN3_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+void rtl8192e_cal_txdesc_chksum(u8 *ptxdesc);
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8192eu_init_xmit_priv(PADAPTER padapter);
+	void rtl8192eu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8192eu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192eu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8192eu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192eu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8192eu_xmit_buf_handler
+	void rtl8192eu_xmit_tasklet(void *priv);
+	s32 rtl8192eu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8192ee_init_xmit_priv(PADAPTER padapter);
+	void rtl8192ee_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8192ee_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	s32	rtl8192ee_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void	rtl8192ee_xmitframe_resume(_adapter *padapter);
+	s32 rtl8192ee_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192ee_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	void rtl8192ee_xmit_tasklet(void *priv);
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8192es_init_xmit_priv(PADAPTER padapter);
+	void rtl8192es_free_xmit_priv(PADAPTER padapter);
+
+	s32 rtl8192es_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192es_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8192es_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	thread_return rtl8192es_xmit_thread(thread_context context);
+	s32 rtl8192es_xmit_buf_handler(PADAPTER padapter);
+
+	#ifdef CONFIG_SDIO_TX_TASKLET
+		void rtl8192es_xmit_tasklet(void *priv);
+	#endif
+#endif
+
+struct txrpt_ccx_92e {
+	/* offset 0 */
+	u8 tag1:1;
+	u8 pkt_num:3;
+	u8 txdma_underflow:1;
+	u8 int_bt:1;
+	u8 int_tri:1;
+	u8 int_ccx:1;
+
+	/* offset 1 */
+	u8 mac_id:6;
+	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;
+};
+
+#ifdef CONFIG_TX_EARLY_MODE
+	void UpdateEarlyModeInfo8192E(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+s32	rtl8192e_init_xmit_priv(_adapter *padapter);
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, u8 *ptxdesc);
+
+void rtl8192e_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen,
+			       u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8192e_cal_txdesc_chksum(u8 *ptxdesc);
+
+u8	BWMapping_92E(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_92E(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+void fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+void fill_txdesc_vcs(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+void fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8192e_fixed_rate(_adapter *padapter, u8 *ptxdesc);
+
+#endif /* __RTL8192E_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_cmd.h
new file mode 100644
index 000000000000..43f7a8805cb5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_cmd.h
@@ -0,0 +1,207 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_CMD_H__
+#define __RTL8703B_CMD_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+enum h2c_cmd_8703B {
+	/* Common Class: 000 */
+	H2C_8703B_RSVD_PAGE = 0x00,
+	H2C_8703B_MEDIA_STATUS_RPT = 0x01,
+	H2C_8703B_SCAN_ENABLE = 0x02,
+	H2C_8703B_KEEP_ALIVE = 0x03,
+	H2C_8703B_DISCON_DECISION = 0x04,
+	H2C_8703B_PSD_OFFLOAD = 0x05,
+	H2C_8703B_AP_OFFLOAD = 0x08,
+	H2C_8703B_BCN_RSVDPAGE = 0x09,
+	H2C_8703B_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8703B_FCS_RSVDPAGE = 0x10,
+	H2C_8703B_FCS_INFO = 0x11,
+	H2C_8703B_AP_WOW_GPIO_CTRL = 0x13,
+
+	/* PoweSave Class: 001 */
+	H2C_8703B_SET_PWR_MODE = 0x20,
+	H2C_8703B_PS_TUNING_PARA = 0x21,
+	H2C_8703B_PS_TUNING_PARA2 = 0x22,
+	H2C_8703B_P2P_LPS_PARAM = 0x23,
+	H2C_8703B_P2P_PS_OFFLOAD = 0x24,
+	H2C_8703B_PS_SCAN_ENABLE = 0x25,
+	H2C_8703B_SAP_PS_ = 0x26,
+	H2C_8703B_INACTIVE_PS_ = 0x27, /* Inactive_PS */
+	H2C_8703B_FWLPS_IN_IPS_ = 0x28,
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8703B_MACID_CFG = 0x40,
+	H2C_8703B_TXBF = 0x41,
+	H2C_8703B_RSSI_SETTING = 0x42,
+	H2C_8703B_AP_REQ_TXRPT = 0x43,
+	H2C_8703B_INIT_RATE_COLLECT = 0x44,
+	H2C_8703B_RA_PARA_ADJUST = 0x46,
+
+	/* BT Class: 011 */
+	H2C_8703B_B_TYPE_TDMA = 0x60,
+	H2C_8703B_BT_INFO = 0x61,
+	H2C_8703B_FORCE_BT_TXPWR = 0x62,
+	H2C_8703B_BT_IGNORE_WLANACT = 0x63,
+	H2C_8703B_DAC_SWING_VALUE = 0x64,
+	H2C_8703B_ANT_SEL_RSV = 0x65,
+	H2C_8703B_WL_OPMODE = 0x66,
+	H2C_8703B_BT_MP_OPER = 0x67,
+	H2C_8703B_BT_CONTROL = 0x68,
+	H2C_8703B_BT_WIFI_CTRL = 0x69,
+	H2C_8703B_BT_FW_PATCH = 0x6A,
+	H2C_8703B_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
+	H2C_8703B_WOWLAN = 0x80,
+	H2C_8703B_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8703B_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8703B_AOAC_RSVD_PAGE = 0x83,
+	H2C_8703B_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_8703B_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_8703B_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_8703B_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_8703B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
+	H2C_8703B_P2P_OFFLOAD = 0x8B,
+
+	H2C_8703B_RESET_TSF = 0xC0,
+	H2C_8703B_MAXID,
+};
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_8703B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8703B_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8703B_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8703B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8703B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _KEEP_ALIVE_CMD_0x03 */
+#define SET_8703B_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8703B_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8703B_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8703B_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _DISCONNECT_DECISION_CMD_0x04 */
+#define SET_8703B_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8703B_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8703B_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8703B_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+
+/* _PWR_MOD_CMD_0x20 */
+#define SET_8703B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+#define GET_8703B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _PS_TUNE_PARAM_CMD_0x21 */
+#define SET_8703B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8703B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8703B_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
+#define SET_8703B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
+#define SET_8703B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _MACID_CFG_CMD_0x40 */
+#define SET_8703B_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
+#define SET_8703B_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
+
+/* _RSSI_SETTING_CMD_0x42 */
+#define SET_8703B_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8703B_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
+#define SET_8703B_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _AP_REQ_TXRPT_CMD_0x43 */
+#define SET_8703B_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8703B_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _FORCE_BT_TXPWR_CMD_0x62 */
+#define SET_8703B_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
+#define SET_8703B_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_8703B_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_8703B_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+
+/* _BT_FW_PATCH_0x6A */
+#define SET_8703B_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+/* host message to firmware cmd */
+void rtl8703b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8703b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
+void rtl8703b_set_rssi_cmd(PADAPTER padapter, u8 *param);
+void rtl8703b_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
+/* s32 rtl8703b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
+void rtl8703b_set_FwPsTuneParam_cmd(PADAPTER padapter);
+void rtl8703b_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param);
+void rtl8703b_download_rsvd_page(PADAPTER padapter, u8 mstatus);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8703b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P
+	void rtl8703b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8703b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+	void rtl8703b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+#endif
+
+void rtl8703b_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
+
+s32 FillH2CCmd8703B(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8703B(_adapter *padapter, bool wowlan);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_dm.h
new file mode 100644
index 000000000000..912c7da079ea
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_dm.h
@@ -0,0 +1,39 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_DM_H__
+#define __RTL8703B_DM_H__
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8703B dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
+
+void rtl8703b_init_dm_priv(PADAPTER padapter);
+void rtl8703b_deinit_dm_priv(PADAPTER padapter);
+
+void rtl8703b_InitHalDm(PADAPTER padapter);
+void rtl8703b_HalDmWatchDog(PADAPTER padapter);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_hal.h
new file mode 100644
index 000000000000..dfc9b6d70abf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_hal.h
@@ -0,0 +1,274 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_HAL_H__
+#define __RTL8703B_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8703b_spec.h"
+#include "rtl8703b_rf.h"
+#include "rtl8703b_dm.h"
+#include "rtl8703b_recv.h"
+#include "rtl8703b_xmit.h"
+#include "rtl8703b_cmd.h"
+#include "rtl8703b_led.h"
+#include "Hal8703BPwrSeq.h"
+#include "Hal8703BPhyReg.h"
+#include "Hal8703BPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8703b_sreset.h"
+#endif
+
+#define FW_8703B_SIZE			0x8000
+#define FW_8703B_START_ADDRESS	0x1000
+#define FW_8703B_END_ADDRESS		0x1FFF /* 0x5FFF */
+
+#define IS_FW_HEADER_EXIST_8703B(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x03B0)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8703B_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8703B, *PRT_FIRMWARE_8703B;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8703B_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8703B_FIRMWARE_HDR, *PRT_8703B_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8703B		0x05
+#define BCN_DMA_ATIME_INT_TIME_8703B		0x02
+
+/* for 8703B
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8703B			128
+#define PAGE_SIZE_RX_8703B			8
+
+#define TX_DMA_SIZE_8703B			0x8000	/* 32K(TX) */
+#define RX_DMA_SIZE_8703B			0x4000	/* 16K(RX) */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8703B	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8703B	0x80	/* 128B, reserved for tx report */
+#endif
+#define RX_DMA_BOUNDARY_8703B		(RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
+#define BCNQ_PAGE_NUM_8703B		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8703B		0x08 /* 0x04 */
+#else
+	#define BCNQ1_PAGE_NUM_8703B		0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef BCNQ1_PAGE_NUM_8703B
+	#define BCNQ1_PAGE_NUM_8703B		0x00 /* 0x04 */
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1 PNO: 6
+ * NS offload: 2NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8703B	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8703B	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8703B
+	#define WOWLAN_PAGE_NUM_8703B	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8703B	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8703B	(0xFF - BCNQ_PAGE_NUM_8703B - BCNQ1_PAGE_NUM_8703B - WOWLAN_PAGE_NUM_8703B)
+#define TX_PAGE_BOUNDARY_8703B		(TX_TOTAL_PAGE_NUMBER_8703B + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B	TX_TOTAL_PAGE_NUMBER_8703B
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8703B		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8703B */
+#define NORMAL_PAGE_NUM_HPQ_8703B		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8703B		0x02
+#define NORMAL_PAGE_NUM_NPQ_8703B		0x02
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8703B		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8703B		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8703B		0x20
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES		15
+
+#define HAL_EFUSE_MEMORY
+
+#define HWSET_MAX_SIZE_8703B			256
+#define EFUSE_REAL_CONTENT_LEN_8703B		256
+#define EFUSE_MAP_LEN_8703B				512
+#define EFUSE_MAX_SECTION_8703B			64
+
+#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_8703B)
+
+#define EFUSE_ACCESS_ON			0x69
+#define EFUSE_ACCESS_OFF			0x00
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define BANK_NUM		1
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
+#define EFUSE_BT_REAL_CONTENT_LEN		(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN				1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION			(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK		16
+
+typedef enum tag_Package_Definition {
+	PACKAGE_DEFAULT,
+	PACKAGE_QFN68,
+	PACKAGE_TFBGA90,
+	PACKAGE_TFBGA80,
+	PACKAGE_TFBGA79
+} PACKAGE_TYPE_E;
+
+#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)
+
+/* rtl8703b_hal_init.c */
+s32 rtl8703b_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8703b_FirmwareSelfReset(PADAPTER padapter);
+void rtl8703b_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8703b_InitAntenna_Selection(PADAPTER padapter);
+void rtl8703b_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8703b_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8703b_init_default_value(PADAPTER padapter);
+
+s32 rtl8703b_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8703B(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8703B(PADAPTER padapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBTCoexistInfo_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseEEPROMVer_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8703B(PADAPTER pAdapter, u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8703B(PADAPTER padapter, u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParseVoltage_8703B(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8703B(PADAPTER Adapter,	u8	*PROMContent, BOOLEAN AutoloadFail);
+
+void rtl8703b_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8703b(_adapter *adapter);
+u8 SetHwReg8703B(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8703B(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8703B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8703B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8703b_InitBeaconParameters(PADAPTER padapter);
+void rtl8703b_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void	_InitBurstPktLen_8703BS(PADAPTER Adapter);
+void _InitLTECoex_8703BS(PADAPTER Adapter);
+void _InitMacAPLLSetting_8703B(PADAPTER Adapter);
+void _8051Reset8703(PADAPTER padapter);
+#ifdef CONFIG_WOWLAN
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8703b_start_thread(_adapter *padapter);
+void rtl8703b_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8703bs_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8703bs_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8703bs_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8703bs_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void CCX_FwC2HTxRpt_8703b(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8703B(u8  rate);
+u8 HwRateToMRate8703B(u8	 rate);
+
+void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8703BE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8703BE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_led.h
new file mode 100644
index 000000000000..99e590d31bc5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_led.h
@@ -0,0 +1,44 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_LED_H__
+#define __RTL8703B_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8703bu_InitSwLeds(PADAPTER padapter);
+	void rtl8703bu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8703bs_InitSwLeds(PADAPTER padapter);
+	void rtl8703bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+	void rtl8703bs_InitSwLeds(PADAPTER padapter);
+	void rtl8703bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8703be_InitSwLeds(PADAPTER padapter);
+	void rtl8703be_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif/*CONFIG_RTW_SW_LED*/
+#endif /*__RTL8703B_LED_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_recv.h
new file mode 100644
index 000000000000..e796e6e603de
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_recv.h
@@ -0,0 +1,86 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_RECV_H__
+#define __RTL8703B_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ (RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_SDIO_HCI
+	#ifndef CONFIG_SDIO_RX_COPY
+		#undef MAX_RECVBUF_SZ
+		#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B)
+	#endif /* !CONFIG_SDIO_RX_COPY */
+#endif /* CONFIG_SDIO_HCI */
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8703bs_init_recv_priv(PADAPTER padapter);
+	void rtl8703bs_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8703bu_init_recv_priv(_adapter *padapter);
+	void rtl8703bu_free_recv_priv(_adapter *padapter);
+	void rtl8703bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8703be_init_recv_priv(PADAPTER padapter);
+	void rtl8703be_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8703b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8703B_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_rf.h
new file mode 100644
index 000000000000..8d980a88fa67
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_rf.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_RF_H__
+#define __RTL8703B_RF_H__
+
+int	PHY_RF6052_Config8703B(IN	PADAPTER		Adapter);
+
+VOID
+PHY_RF6052SetBandwidth8703B(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_spec.h
new file mode 100644
index 000000000000..633b23b1bf10
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_spec.h
@@ -0,0 +1,464 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_SPEC_H__
+#define __RTL8703B_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8703B		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8703B			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8703B			0x0002	/* 2 Byte */
+#define REG_APS_FSMCO_8703B			0x0004	/* 4 Byte */
+#define REG_SYS_CLKR_8703B				0x0008	/* 2 Byte */
+#define REG_9346CR_8703B				0x000A	/* 2 Byte */
+#define REG_EE_VPD_8703B				0x000C	/* 2 Byte */
+#define REG_AFE_MISC_8703B				0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8703B				0x0011	/* 7 Byte */
+#define REG_SPS_OCP_CFG_8703B			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8703B				0x001C	/* 3 Byte */
+#define REG_RF_CTRL_8703B				0x001F	/* 1 Byte */
+#define REG_LPLDO_CTRL_8703B			0x0023	/* 1 Byte */
+#define REG_AFE_XTAL_CTRL_8703B		0x0024	/* 4 Byte */
+#define REG_AFE_PLL_CTRL_8703B			0x0028	/* 4 Byte */
+#define REG_MAC_PLL_CTRL_EXT_8703B		0x002c	/* 4 Byte */
+#define REG_EFUSE_CTRL_8703B			0x0030
+#define REG_EFUSE_TEST_8703B			0x0034
+#define REG_PWR_DATA_8703B				0x0038
+#define REG_CAL_TIMER_8703B				0x003C
+#define REG_ACLK_MON_8703B				0x003E
+#define REG_GPIO_MUXCFG_8703B			0x0040
+#define REG_GPIO_IO_SEL_8703B			0x0042
+#define REG_MAC_PINMUX_CFG_8703B		0x0043
+#define REG_GPIO_PIN_CTRL_8703B			0x0044
+#define REG_GPIO_INTM_8703B				0x0048
+#define REG_LEDCFG0_8703B				0x004C
+#define REG_LEDCFG1_8703B				0x004D
+#define REG_LEDCFG2_8703B				0x004E
+#define REG_LEDCFG3_8703B				0x004F
+#define REG_FSIMR_8703B					0x0050
+#define REG_FSISR_8703B					0x0054
+#define REG_HSIMR_8703B					0x0058
+#define REG_HSISR_8703B					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_PAD_CTRL1_8703B		0x0064
+#define REG_MULTI_FUNC_CTRL_8703B		0x0068
+#define REG_GPIO_STATUS_8703B			0x006C
+#define REG_SDIO_CTRL_8703B				0x0070
+#define REG_OPT_CTRL_8703B				0x0074
+#define REG_AFE_CTRL_4_8703B		0x0078
+#define REG_MCUFWDL_8703B				0x0080
+#define REG_HMEBOX_DBG_0_8703B	0x0088
+#define REG_HMEBOX_DBG_1_8703B	0x008A
+#define REG_HMEBOX_DBG_2_8703B	0x008C
+#define REG_HMEBOX_DBG_3_8703B	0x008E
+#define REG_HIMR0_8703B					0x00B0
+#define REG_HISR0_8703B					0x00B4
+#define REG_HIMR1_8703B					0x00B8
+#define REG_HISR1_8703B					0x00BC
+#define REG_PMC_DBG_CTRL2_8703B			0x00CC
+#define	REG_EFUSE_BURN_GNT_8703B		0x00CF
+#define REG_HPON_FSM_8703B				0x00EC
+#define REG_SYS_CFG_8703B				0x00F0
+#define REG_SYS_CFG1_8703B				0x00FC
+#define REG_ROM_VERSION					0x00FD
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8703B	0x01A0
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_8703B        0x01AE
+#define REG_C2HEVT_CMD_LEN_88XX		REG_C2HEVT_CMD_LEN_8703B
+#define REG_C2HEVT_CLEAR_8703B			0x01AF
+#define REG_MCUTST_1_8703B				0x01C0
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_FMETHR_8703B				0x01C8
+#define REG_HMETFR_8703B				0x01CC
+#define REG_HMEBOX_0_8703B				0x01D0
+#define REG_HMEBOX_1_8703B				0x01D4
+#define REG_HMEBOX_2_8703B				0x01D8
+#define REG_HMEBOX_3_8703B				0x01DC
+#define REG_LLT_INIT_8703B				0x01E0
+#define REG_HMEBOX_EXT0_8703B			0x01F0
+#define REG_HMEBOX_EXT1_8703B			0x01F4
+#define REG_HMEBOX_EXT2_8703B			0x01F8
+#define REG_HMEBOX_EXT3_8703B			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RQPN_8703B					0x0200
+#define REG_FIFOPAGE_8703B				0x0204
+#define REG_DWBCN0_CTRL_8703B			REG_TDECTRL
+#define REG_TXDMA_OFFSET_CHK_8703B	0x020C
+#define REG_TXDMA_STATUS_8703B		0x0210
+#define REG_RQPN_NPQ_8703B			0x0214
+#define REG_DWBCN1_CTRL_8703B			0x0228
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8703B		0x0280
+#define REG_FW_UPD_RDPTR_8703B		0x0284 /* FW shall update this register before FW write RXPKT_RELEASE_POLL to 1 */
+#define REG_RXDMA_CONTROL_8703B		0x0286 /* Control the RX DMA. */
+#define REG_RXPKT_NUM_8703B			0x0287 /* The number of packets in RXPKTBUF.	 */
+#define REG_RXDMA_STATUS_8703B			0x0288
+#define REG_RXDMA_MODE_CTRL_8703B		0x0290
+#define REG_EARLY_MODE_CONTROL_8703B	0x02BC
+#define REG_RSVD5_8703B					0x02F0
+#define REG_RSVD6_8703B					0x02F4
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8703B		0x0300
+#define	REG_INT_MIG_8703B				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_DESA_8703B			0x0308	/* TX Beacon Descriptor Address */
+#define	REG_HQ_DESA_8703B				0x0310	/* TX High Queue Descriptor Address */
+#define	REG_MGQ_DESA_8703B			0x0318	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_DESA_8703B			0x0320	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_DESA_8703B				0x0328	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_DESA_8703B			0x0330	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_DESA_8703B			0x0338	/* TX BK Queue Descriptor Address */
+#define	REG_RX_DESA_8703B				0x0340	/* RX Queue	Descriptor Address */
+#define	REG_DBI_WDATA_8703B			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8703B			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8703B				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8703B				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8703B		0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8703B			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8703B			0x0358	/* MDIO for Control */
+#define	REG_DBG_SEL_8703B				0x0360	/* Debug Selection Register */
+#define	REG_PCIE_HRPWM_8703B			0x0361	/* PCIe RPWM */
+#define	REG_PCIE_HCPWM_8703B			0x0363	/* PCIe CPWM */
+#define	REG_PCIE_MULTIFET_CTRL_8703B	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_VOQ_INFORMATION_8703B		0x0400
+#define REG_VIQ_INFORMATION_8703B		0x0404
+#define REG_BEQ_INFORMATION_8703B		0x0408
+#define REG_BKQ_INFORMATION_8703B		0x040C
+#define REG_MGQ_INFORMATION_8703B		0x0410
+#define REG_HGQ_INFORMATION_8703B		0x0414
+#define REG_BCNQ_INFORMATION_8703B	0x0418
+#define REG_TXPKT_EMPTY_8703B			0x041A
+
+#define REG_FWHW_TXQ_CTRL_8703B		0x0420
+#define REG_HWSEQ_CTRL_8703B			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8703B	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8703B	0x0425
+#define REG_LIFECTRL_CTRL_8703B			0x0426
+#define REG_MULTI_BCNQ_OFFSET_8703B	0x0427
+#define REG_SPEC_SIFS_8703B				0x0428
+#define REG_RL_8703B						0x042A
+#define REG_TXBF_CTRL_8703B				0x042C
+#define REG_DARFRC_8703B				0x0430
+#define REG_RARFRC_8703B				0x0438
+#define REG_RRSR_8703B					0x0440
+#define REG_ARFR0_8703B					0x0444
+#define REG_ARFR1_8703B					0x044C
+#define REG_CCK_CHECK_8703B				0x0454
+#define REG_AMPDU_MAX_TIME_8703B		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8703B	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8703B	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8703B	0x045D
+#define REG_NDPA_OPT_CTRL_8703B		0x045F
+#define REG_FAST_EDCA_CTRL_8703B		0x0460
+#define REG_RD_RESP_PKT_TH_8703B		0x0463
+#define REG_DATA_SC_8703B				0x0483
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_POWER_STAGE1_8703B		0x04B4
+#define REG_POWER_STAGE2_8703B		0x04B8
+#define REG_AMPDU_BURST_MODE_8703B	0x04BC
+#define REG_PKT_VO_VI_LIFE_TIME_8703B	0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8703B	0x04C2
+#define REG_STBC_SETTING_8703B			0x04C4
+#define REG_HT_SINGLE_AMPDU_8703B		0x04C7
+#define REG_PROT_MODE_CTRL_8703B		0x04C8
+#define REG_MAX_AGGR_NUM_8703B		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8703B	0x04CB
+#define REG_BAR_MODE_CTRL_8703B		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8703B	0x04CF
+#define REG_MACID_PKT_DROP0_8703B		0x04D0
+#define REG_MACID_PKT_SLEEP_8703B		0x04D4
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8703B		0x0500
+#define REG_EDCA_VI_PARAM_8703B		0x0504
+#define REG_EDCA_BE_PARAM_8703B		0x0508
+#define REG_EDCA_BK_PARAM_8703B		0x050C
+#define REG_BCNTCFG_8703B				0x0510
+#define REG_PIFS_8703B					0x0512
+#define REG_RDG_PIFS_8703B				0x0513
+#define REG_SIFS_CTX_8703B				0x0514
+#define REG_SIFS_TRX_8703B				0x0516
+#define REG_AGGR_BREAK_TIME_8703B		0x051A
+#define REG_SLOT_8703B					0x051B
+#define REG_TX_PTCL_CTRL_8703B			0x0520
+#define REG_TXPAUSE_8703B				0x0522
+#define REG_DIS_TXREQ_CLR_8703B		0x0523
+#define REG_RD_CTRL_8703B				0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8703B			0x0540
+#define REG_RD_NAV_NXT_8703B			0x0544
+#define REG_NAV_PROT_LEN_8703B			0x0546
+#define REG_BCN_CTRL_8703B				0x0550
+#define REG_BCN_CTRL_1_8703B			0x0551
+#define REG_MBID_NUM_8703B				0x0552
+#define REG_DUAL_TSF_RST_8703B			0x0553
+#define REG_BCN_INTERVAL_8703B			0x0554
+#define REG_DRVERLYINT_8703B			0x0558
+#define REG_BCNDMATIM_8703B			0x0559
+#define REG_ATIMWND_8703B				0x055A
+#define REG_USTIME_TSF_8703B			0x055C
+#define REG_BCN_MAX_ERR_8703B			0x055D
+#define REG_RXTSF_OFFSET_CCK_8703B		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8703B	0x055F
+#define REG_TSFTR_8703B					0x0560
+#define REG_CTWND_8703B					0x0572
+#define REG_SECONDARY_CCA_CTRL_8703B	0x0577
+#define REG_PSTIMER_8703B				0x0580
+#define REG_TIMER0_8703B				0x0584
+#define REG_TIMER1_8703B				0x0588
+#define REG_ACMHWCTRL_8703B			0x05C0
+#define REG_SCH_TXCMD_8703B			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8703B				0x0600
+#define REG_TCR_8703B					0x0604
+#define REG_RCR_8703B					0x0608
+#define REG_RX_PKT_LIMIT_8703B			0x060C
+#define REG_RX_DLK_TIME_8703B			0x060D
+#define REG_RX_DRVINFO_SZ_8703B		0x060F
+
+#define REG_MACID_8703B					0x0610
+#define REG_BSSID_8703B					0x0618
+#define REG_MAR_8703B					0x0620
+#define REG_MBIDCAMCFG_8703B			0x0628
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_USTIME_EDCA_8703B			0x0638
+#define REG_MAC_SPEC_SIFS_8703B		0x063A
+#define REG_RESP_SIFP_CCK_8703B			0x063C
+#define REG_RESP_SIFS_OFDM_8703B		0x063E
+#define REG_ACKTO_8703B					0x0640
+#define REG_CTS2TO_8703B				0x0641
+#define REG_EIFS_8703B					0x0642
+
+#define REG_NAV_UPPER_8703B			0x0652	/* unit of 128 */
+#define REG_TRXPTCL_CTL_8703B			0x0668
+
+/* Security */
+#define REG_CAMCMD_8703B				0x0670
+#define REG_CAMWRITE_8703B				0x0674
+#define REG_CAMREAD_8703B				0x0678
+#define REG_CAMDBG_8703B				0x067C
+#define REG_SECCFG_8703B				0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8703B				0x0690
+#define REG_PS_RX_INFO_8703B			0x0692
+#define REG_UAPSD_TID_8703B				0x0693
+#define REG_WKFMCAM_CMD_8703B			0x0698
+#define REG_WKFMCAM_NUM_8703B			0x0698
+#define REG_WKFMCAM_RWD_8703B			0x069C
+#define REG_RXFLTMAP0_8703B				0x06A0
+#define REG_RXFLTMAP1_8703B				0x06A2
+#define REG_RXFLTMAP2_8703B				0x06A4
+#define REG_BCN_PSR_RPT_8703B			0x06A8
+#define REG_BT_COEX_TABLE_8703B		0x06C0
+#define REG_BFMER0_INFO_8703B			0x06E4
+#define REG_BFMER1_INFO_8703B			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8703B	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8703B	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8703B	0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8703B				0x0700
+#define REG_BSSID1_8703B				0x0708
+#define REG_BFMEE_SEL_8703B				0x0714
+#define REG_SND_PTCL_CTRL_8703B		0x0718
+
+/* LTE_COEX */
+#define REG_LTECOEX_CTRL			0x07C0
+#define REG_LTECOEX_WRITE_DATA		0x07C4
+#define REG_LTECOEX_READ_DATA		0x07C8
+#define REG_LTECOEX_PATH_CONTROL	0x70
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HCPWM1_8703B	0x025 /* HCI Current Power Mode 1 */
+
+
+/* ****************************************************************************
+ *	8703 Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* 2 HSISR
+ * 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)
+
+
+/* ----------------------------------------------------------------------------
+ * 8703B REG_CCK_CHECK						(offset 0x454)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+#ifdef CONFIG_RF_POWER_TRIM
+
+	#ifdef CONFIG_RTL8703B
+		#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#endif
+
+	#define EEPROM_RF_GAIN_VAL				0x1F6
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8703B					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8703B					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8703B					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8703B				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8703B					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8703B					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8703B				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8703B				BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8703B		BIT(24)		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8703B				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8703B				BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8703B		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8703B			BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8703B				BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8703B					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8703B					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8703B					BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8703B				BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8703B				BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8703B					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8703B					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8703B					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8703B					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8703B					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8703B					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8703B				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8703B				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8703B				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8703B				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8703B				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8703B				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8703B				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8703B					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8703B					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8703B					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8703B					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8703B					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8703B					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8703B					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8703B				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8703B					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8703B					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8703B					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8703B					BIT(8)			/* Receive FIFO Overflow */
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_8703B|IMR_RDU_8703B|IMR_RXFOVW_8703B) */
+	#define IMR_TX_MASK			(IMR_VODOK_8703B | IMR_VIDOK_8703B | IMR_BEDOK_8703B | IMR_BKDOK_8703B | IMR_MGNTDOK_8703B | IMR_HIGHDOK_8703B)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8703B | IMR_TXBCN0OK_8703B | IMR_TXBCN0ERR_8703B | IMR_BCNDERR0_8703B)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8703B | IMR_VODOK_8703B | IMR_BEDOK_8703B | IMR_BKDOK_8703B)
+#endif
+
+#endif /* __RTL8703B_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_sreset.h
new file mode 100644
index 000000000000..5fe53cf414a1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8703B_SRESET_H_
+#define _RTL8703B_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8703b_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8703b_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_xmit.h
new file mode 100644
index 000000000000..2bcd5a7b85c5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8703b_xmit.h
@@ -0,0 +1,334 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_XMIT_H__
+#define __RTL8703B_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8703BDESC_H
+	#define __INC_HAL8703BDESC_H
+
+	#define RX_STATUS_DESC_SIZE_8703B		24
+	#define RX_DRV_INFO_SIZE_UNIT_8703B 8
+
+
+	/* DWORD 0 */
+	#define SET_RX_STATUS_DESC_PKT_LEN_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+	#define SET_RX_STATUS_DESC_EOR_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+	#define SET_RX_STATUS_DESC_OWN_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+	#define GET_RX_STATUS_DESC_PKT_LEN_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+	#define GET_RX_STATUS_DESC_CRC32_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+	#define GET_RX_STATUS_DESC_ICV_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+	#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+	#define GET_RX_STATUS_DESC_SECURITY_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+	#define GET_RX_STATUS_DESC_QOS_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+	#define GET_RX_STATUS_DESC_SHIFT_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+	#define GET_RX_STATUS_DESC_PHY_STATUS_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+	#define GET_RX_STATUS_DESC_SWDEC_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+	#define GET_RX_STATUS_DESC_LAST_SEG_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+	#define GET_RX_STATUS_DESC_FIRST_SEG_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+	#define GET_RX_STATUS_DESC_EOR_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+	#define GET_RX_STATUS_DESC_OWN_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+	/* DWORD 1 */
+	#define GET_RX_STATUS_DESC_MACID_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+	#define GET_RX_STATUS_DESC_TID_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+	#define GET_RX_STATUS_DESC_AMSDU_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+	#define GET_RX_STATUS_DESC_RXID_MATCH_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+	#define GET_RX_STATUS_DESC_PAGGR_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+	#define GET_RX_STATUS_DESC_A1_FIT_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+	#define GET_RX_STATUS_DESC_CHKERR_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+	#define GET_RX_STATUS_DESC_IPVER_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+	#define GET_RX_STATUS_DESC_IS_TCPUDP__8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+	#define GET_RX_STATUS_DESC_CHK_VLD_8703B(__pRxDesc)	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+	#define GET_RX_STATUS_DESC_PAM_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+	#define GET_RX_STATUS_DESC_PWR_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+	#define GET_RX_STATUS_DESC_MORE_DATA_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+	#define GET_RX_STATUS_DESC_MORE_FRAG_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+	#define GET_RX_STATUS_DESC_TYPE_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+	#define GET_RX_STATUS_DESC_MC_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+	#define GET_RX_STATUS_DESC_BC_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+	/* DWORD 2 */
+	#define GET_RX_STATUS_DESC_SEQ_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+	#define GET_RX_STATUS_DESC_FRAG_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+	#define GET_RX_STATUS_DESC_RX_IS_QOS_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+	#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8703B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+	#define GET_RX_STATUS_DESC_RPT_SEL_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+	/* DWORD 3 */
+	#define GET_RX_STATUS_DESC_RX_RATE_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+	#define GET_RX_STATUS_DESC_HTC_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+	#define GET_RX_STATUS_DESC_EOSP_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+	#define GET_RX_STATUS_DESC_BSSID_FIT_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+	#ifdef CONFIG_USB_RX_AGGREGATION
+		#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8703B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+	#endif
+	#define GET_RX_STATUS_DESC_PATTERN_MATCH_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+	#define GET_RX_STATUS_DESC_UNICAST_MATCH_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+	#define GET_RX_STATUS_DESC_MAGIC_MATCH_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+	/* DWORD 6 */
+	#define GET_RX_STATUS_DESC_SPLCP_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+	#define GET_RX_STATUS_DESC_LDPC_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+	#define GET_RX_STATUS_DESC_STBC_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+	#define GET_RX_STATUS_DESC_BW_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+	/* DWORD 5 */
+	#define GET_RX_STATUS_DESC_TSFL_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+	#define GET_RX_STATUS_DESC_BUFF_ADDR_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+	#define GET_RX_STATUS_DESC_BUFF_ADDR64_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+	#define SET_RX_STATUS_DESC_BUFF_ADDR_8703B(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+	/* Dword 0 */
+	#define GET_TX_DESC_OWN_8703B(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+	#define SET_TX_DESC_PKT_SIZE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+	#define SET_TX_DESC_OFFSET_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+	#define SET_TX_DESC_BMC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+	#define SET_TX_DESC_HTC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+	#define SET_TX_DESC_LAST_SEG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+	#define SET_TX_DESC_FIRST_SEG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+	#define SET_TX_DESC_LINIP_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+	#define SET_TX_DESC_NO_ACM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+	#define SET_TX_DESC_GF_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+	#define SET_TX_DESC_OWN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+	/* Dword 1 */
+	#define SET_TX_DESC_MACID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+	#define SET_TX_DESC_QUEUE_SEL_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+	#define SET_TX_DESC_RDG_NAV_EXT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+	#define SET_TX_DESC_LSIG_TXOP_EN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+	#define SET_TX_DESC_PIFS_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+	#define SET_TX_DESC_RATE_ID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+	#define SET_TX_DESC_EN_DESC_ID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+	#define SET_TX_DESC_SEC_TYPE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+	#define SET_TX_DESC_PKT_OFFSET_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+
+
+	/* Dword 2 */
+	#define SET_TX_DESC_PAID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+	#define SET_TX_DESC_CCA_RTS_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+	#define SET_TX_DESC_AGG_ENABLE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+	#define SET_TX_DESC_RDG_ENABLE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+	#define SET_TX_DESC_AGG_BREAK_8703B(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+	#define SET_TX_DESC_MORE_FRAG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+	#define SET_TX_DESC_RAW_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+	#define SET_TX_DESC_SPE_RPT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+	#define SET_TX_DESC_AMPDU_DENSITY_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+	#define SET_TX_DESC_BT_INT_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+	#define SET_TX_DESC_GID_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+
+	/* Dword 3 */
+	#define SET_TX_DESC_WHEADER_LEN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+	#define SET_TX_DESC_CHK_EN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+	#define SET_TX_DESC_EARLY_MODE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+	#define SET_TX_DESC_HWSEQ_SEL_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+	#define SET_TX_DESC_USE_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+	#define SET_TX_DESC_DISABLE_RTS_FB_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+	#define SET_TX_DESC_DISABLE_FB_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+	#define SET_TX_DESC_CTS2SELF_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+	#define SET_TX_DESC_RTS_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+	#define SET_TX_DESC_HW_RTS_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+	#define SET_TX_DESC_NAV_USE_HDR_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+	#define SET_TX_DESC_USE_MAX_LEN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+	#define SET_TX_DESC_MAX_AGG_NUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+	#define SET_TX_DESC_NDPA_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+	#define SET_TX_DESC_AMPDU_MAX_TIME_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+	/* Dword 4 */
+	#define SET_TX_DESC_TX_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+	#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+	#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+	#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+	#define SET_TX_DESC_DATA_RETRY_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+	#define SET_TX_DESC_RTS_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+
+
+	/* Dword 5 */
+	#define SET_TX_DESC_DATA_SC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+	#define SET_TX_DESC_DATA_SHORT_8703B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+	#define SET_TX_DESC_DATA_BW_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+	#define SET_TX_DESC_DATA_LDPC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+	#define SET_TX_DESC_DATA_STBC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+	#define SET_TX_DESC_CTROL_STBC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+	#define SET_TX_DESC_RTS_SHORT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+	#define SET_TX_DESC_RTS_SC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+
+
+	/* Dword 6 */
+	#define SET_TX_DESC_SW_DEFINE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+	#define SET_TX_DESC_MBSSID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+	#define SET_TX_DESC_ANTSEL_A_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_B_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_C_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_D_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+
+	/* Dword 7 */
+	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		#define SET_TX_DESC_TX_BUFFER_SIZE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#else
+		#define SET_TX_DESC_TX_DESC_CHECKSUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#endif
+	#define SET_TX_DESC_USB_TXAGG_NUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+	#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+		#define SET_TX_DESC_SDIO_TXSEQ_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+	#endif
+
+	/* Dword 8 */
+	#define SET_TX_DESC_HWSEQ_EN_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+
+	/* Dword 9 */
+	#define SET_TX_DESC_SEQ_8703B(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+
+	/* Dword 10 */
+	#define SET_TX_DESC_TX_BUFFER_ADDRESS_8703B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+	#define GET_TX_DESC_TX_BUFFER_ADDRESS_8703B(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+
+	/* Dword 11 */
+	#define SET_TX_DESC_NEXT_DESC_ADDRESS_8703B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+
+
+	#define SET_EARLYMODE_PKTNUM_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+	#define SET_EARLYMODE_LEN0_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+	#define SET_EARLYMODE_LEN1_1_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+	#define SET_EARLYMODE_LEN1_2_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+	#define SET_EARLYMODE_LEN2_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+	#define SET_EARLYMODE_LEN3_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8703B_RATE1M				0x00
+#define DESC8703B_RATE2M				0x01
+#define DESC8703B_RATE5_5M				0x02
+#define DESC8703B_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8703B_RATE6M				0x04
+#define DESC8703B_RATE9M				0x05
+#define DESC8703B_RATE12M				0x06
+#define DESC8703B_RATE18M				0x07
+#define DESC8703B_RATE24M				0x08
+#define DESC8703B_RATE36M				0x09
+#define DESC8703B_RATE48M				0x0a
+#define DESC8703B_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8703B_RATEMCS0				0x0c
+#define DESC8703B_RATEMCS1				0x0d
+#define DESC8703B_RATEMCS2				0x0e
+#define DESC8703B_RATEMCS3				0x0f
+#define DESC8703B_RATEMCS4				0x10
+#define DESC8703B_RATEMCS5				0x11
+#define DESC8703B_RATEMCS6				0x12
+#define DESC8703B_RATEMCS7				0x13
+#define DESC8703B_RATEMCS8				0x14
+#define DESC8703B_RATEMCS9				0x15
+#define DESC8703B_RATEMCS10		0x16
+#define DESC8703B_RATEMCS11		0x17
+#define DESC8703B_RATEMCS12		0x18
+#define DESC8703B_RATEMCS13		0x19
+#define DESC8703B_RATEMCS14		0x1a
+#define DESC8703B_RATEMCS15		0x1b
+#define DESC8703B_RATEVHTSS1MCS0		0x2c
+#define DESC8703B_RATEVHTSS1MCS1		0x2d
+#define DESC8703B_RATEVHTSS1MCS2		0x2e
+#define DESC8703B_RATEVHTSS1MCS3		0x2f
+#define DESC8703B_RATEVHTSS1MCS4		0x30
+#define DESC8703B_RATEVHTSS1MCS5		0x31
+#define DESC8703B_RATEVHTSS1MCS6		0x32
+#define DESC8703B_RATEVHTSS1MCS7		0x33
+#define DESC8703B_RATEVHTSS1MCS8		0x34
+#define DESC8703B_RATEVHTSS1MCS9		0x35
+#define DESC8703B_RATEVHTSS2MCS0		0x36
+#define DESC8703B_RATEVHTSS2MCS1		0x37
+#define DESC8703B_RATEVHTSS2MCS2		0x38
+#define DESC8703B_RATEVHTSS2MCS3		0x39
+#define DESC8703B_RATEVHTSS2MCS4		0x3a
+#define DESC8703B_RATEVHTSS2MCS5		0x3b
+#define DESC8703B_RATEVHTSS2MCS6		0x3c
+#define DESC8703B_RATEVHTSS2MCS7		0x3d
+#define DESC8703B_RATEVHTSS2MCS8		0x3e
+#define DESC8703B_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8703B(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE11M)
+
+
+void rtl8703b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8703b_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8703bs_init_xmit_priv(PADAPTER padapter);
+	void rtl8703bs_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8703bs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703bs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8703bs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703bs_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8703bs_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8703bs_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8703bu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8703bu_xmit_buf_handler
+
+
+	s32 rtl8703bu_init_xmit_priv(PADAPTER padapter);
+	void rtl8703bu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8703bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8703bu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	/* s32 rtl8812au_xmit_buf_handler(PADAPTER padapter); */
+	void rtl8703bu_xmit_tasklet(void *priv);
+	s32 rtl8703bu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8703be_init_xmit_priv(PADAPTER padapter);
+	void rtl8703be_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8703be_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void	rtl8703be_xmitframe_resume(_adapter *padapter);
+	s32 rtl8703be_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703be_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8703be_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8703be_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8703B(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8703B(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_cmd.h
new file mode 100644
index 000000000000..f284a05425fc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_cmd.h
@@ -0,0 +1,207 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_CMD_H__
+#define __RTL8723B_CMD_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+enum h2c_cmd_8723B {
+	/* Common Class: 000 */
+	H2C_8723B_RSVD_PAGE = 0x00,
+	H2C_8723B_MEDIA_STATUS_RPT = 0x01,
+	H2C_8723B_SCAN_ENABLE = 0x02,
+	H2C_8723B_KEEP_ALIVE = 0x03,
+	H2C_8723B_DISCON_DECISION = 0x04,
+	H2C_8723B_PSD_OFFLOAD = 0x05,
+	H2C_8723B_AP_OFFLOAD = 0x08,
+	H2C_8723B_BCN_RSVDPAGE = 0x09,
+	H2C_8723B_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8723B_FCS_RSVDPAGE = 0x10,
+	H2C_8723B_FCS_INFO = 0x11,
+	H2C_8723B_AP_WOW_GPIO_CTRL = 0x13,
+
+	/* PoweSave Class: 001 */
+	H2C_8723B_SET_PWR_MODE = 0x20,
+	H2C_8723B_PS_TUNING_PARA = 0x21,
+	H2C_8723B_PS_TUNING_PARA2 = 0x22,
+	H2C_8723B_P2P_LPS_PARAM = 0x23,
+	H2C_8723B_P2P_PS_OFFLOAD = 0x24,
+	H2C_8723B_PS_SCAN_ENABLE = 0x25,
+	H2C_8723B_SAP_PS_ = 0x26,
+	H2C_8723B_INACTIVE_PS_ = 0x27, /* Inactive_PS */
+	H2C_8723B_FWLPS_IN_IPS_ = 0x28,
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8723B_MACID_CFG = 0x40,
+	H2C_8723B_TXBF = 0x41,
+	H2C_8723B_RSSI_SETTING = 0x42,
+	H2C_8723B_AP_REQ_TXRPT = 0x43,
+	H2C_8723B_INIT_RATE_COLLECT = 0x44,
+	H2C_8723B_RA_PARA_ADJUST = 0x46,
+
+	/* BT Class: 011 */
+	H2C_8723B_B_TYPE_TDMA = 0x60,
+	H2C_8723B_BT_INFO = 0x61,
+	H2C_8723B_FORCE_BT_TXPWR = 0x62,
+	H2C_8723B_BT_IGNORE_WLANACT = 0x63,
+	H2C_8723B_DAC_SWING_VALUE = 0x64,
+	H2C_8723B_ANT_SEL_RSV = 0x65,
+	H2C_8723B_WL_OPMODE = 0x66,
+	H2C_8723B_BT_MP_OPER = 0x67,
+	H2C_8723B_BT_CONTROL = 0x68,
+	H2C_8723B_BT_WIFI_CTRL = 0x69,
+	H2C_8723B_BT_FW_PATCH = 0x6A,
+	H2C_8723B_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
+	H2C_8723B_WOWLAN = 0x80,
+	H2C_8723B_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8723B_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8723B_AOAC_RSVD_PAGE = 0x83,
+	H2C_8723B_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_8723B_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_8723B_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_8723B_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_8723B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
+	H2C_8723B_P2P_OFFLOAD = 0x8B,
+
+	H2C_8723B_RESET_TSF = 0xC0,
+	H2C_8723B_MAXID,
+};
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_8723B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723B_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8723B_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _KEEP_ALIVE_CMD_0x03 */
+#define SET_8723B_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8723B_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8723B_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8723B_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _DISCONNECT_DECISION_CMD_0x04 */
+#define SET_8723B_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8723B_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8723B_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8723B_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+
+/* _PWR_MOD_CMD_0x20 */
+#define SET_8723B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+#define GET_8723B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _PS_TUNE_PARAM_CMD_0x21 */
+#define SET_8723B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8723B_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
+#define SET_8723B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
+#define SET_8723B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _MACID_CFG_CMD_0x40 */
+#define SET_8723B_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
+#define SET_8723B_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
+
+/* _RSSI_SETTING_CMD_0x42 */
+#define SET_8723B_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723B_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
+#define SET_8723B_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _AP_REQ_TXRPT_CMD_0x43 */
+#define SET_8723B_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723B_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _FORCE_BT_TXPWR_CMD_0x62 */
+#define SET_8723B_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
+#define SET_8723B_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_8723B_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_8723B_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+
+/* _BT_FW_PATCH_0x6A */
+#define SET_8723B_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+/* host message to firmware cmd */
+void rtl8723b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8723b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
+void rtl8723b_set_rssi_cmd(PADAPTER padapter, u8 *param);
+void rtl8723b_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
+/* s32 rtl8723b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
+void rtl8723b_set_FwPsTuneParam_cmd(PADAPTER padapter);
+void rtl8723b_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param);
+void rtl8723b_download_rsvd_page(PADAPTER padapter, u8 mstatus);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8723b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P
+	void rtl8723b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8723b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+	void rtl8723b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+#endif
+
+void rtl8723b_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
+
+s32 FillH2CCmd8723B(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8723B(_adapter *padapter, bool wowlan);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_dm.h
new file mode 100644
index 000000000000..ea517175f0bd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_dm.h
@@ -0,0 +1,38 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_DM_H__
+#define __RTL8723B_DM_H__
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8723B dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
+
+void rtl8723b_init_dm_priv(PADAPTER padapter);
+void rtl8723b_deinit_dm_priv(PADAPTER padapter);
+
+void rtl8723b_InitHalDm(PADAPTER padapter);
+void rtl8723b_HalDmWatchDog(PADAPTER padapter);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_hal.h
new file mode 100644
index 000000000000..6e9ac57dd089
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_hal.h
@@ -0,0 +1,282 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_HAL_H__
+#define __RTL8723B_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8723b_spec.h"
+#include "rtl8723b_rf.h"
+#include "rtl8723b_dm.h"
+#include "rtl8723b_recv.h"
+#include "rtl8723b_xmit.h"
+#include "rtl8723b_cmd.h"
+#include "rtl8723b_led.h"
+#include "Hal8723BPwrSeq.h"
+#include "Hal8723BPhyReg.h"
+#include "Hal8723BPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8723b_sreset.h"
+#endif
+
+#define FW_8723B_SIZE			0x8000
+#define FW_8723B_START_ADDRESS	0x1000
+#define FW_8723B_END_ADDRESS		0x1FFF /* 0x5FFF */
+
+#define IS_FW_HEADER_EXIST_8723B(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x5300)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8723B_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8723B, *PRT_FIRMWARE_8723B;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8723B_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8723B_FIRMWARE_HDR, *PRT_8723B_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8723B		0x05
+#define BCN_DMA_ATIME_INT_TIME_8723B		0x02
+
+/* for 8723B
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8723B			128
+#define PAGE_SIZE_RX_8723B			8
+
+#define TX_DMA_SIZE_8723B			0x8000	/* 32K(TX) */
+#define RX_DMA_SIZE_8723B			0x4000	/* 16K(RX) */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8723B	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8723B	0x80	/* 128B, reserved for tx report */
+#endif
+#define RX_DMA_BOUNDARY_8723B		(RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
+#define BCNQ_PAGE_NUM_8723B		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8723B		0x08 /* 0x04 */
+#else
+	#define BCNQ1_PAGE_NUM_8723B		0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef BCNQ1_PAGE_NUM_8723B
+	#define BCNQ1_PAGE_NUM_8723B		0x00 /* 0x04 */
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1,PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8723B	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8723B	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8723B
+	#define WOWLAN_PAGE_NUM_8723B	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8723B	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8723B	(0xFF - BCNQ_PAGE_NUM_8723B - BCNQ1_PAGE_NUM_8723B - WOWLAN_PAGE_NUM_8723B)
+#define TX_PAGE_BOUNDARY_8723B		(TX_TOTAL_PAGE_NUMBER_8723B + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B	TX_TOTAL_PAGE_NUMBER_8723B
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8723B		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723B */
+#define NORMAL_PAGE_NUM_HPQ_8723B		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8723B		0x02
+#define NORMAL_PAGE_NUM_NPQ_8723B		0x02
+#define NORMAL_PAGE_NUM_EPQ_8723B		0x04
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8723B		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8723B		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8723B		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8723B		0x00
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES		15
+
+#define HAL_EFUSE_MEMORY
+
+#define HWSET_MAX_SIZE_8723B			512
+#define EFUSE_REAL_CONTENT_LEN_8723B		512
+#define EFUSE_MAP_LEN_8723B				512
+#define EFUSE_MAX_SECTION_8723B			64
+
+#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_8723B)
+
+#define EFUSE_ACCESS_ON			0x69	/* For RTL8723 only. */
+#define EFUSE_ACCESS_OFF			0x00	/* For RTL8723 only. */
+
+/* ********************************************************
+ *			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
+
+typedef enum tag_Package_Definition {
+	PACKAGE_DEFAULT,
+	PACKAGE_QFN68,
+	PACKAGE_TFBGA90,
+	PACKAGE_TFBGA80,
+	PACKAGE_TFBGA79
+} PACKAGE_TYPE_E;
+
+#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)
+
+/* rtl8723a_hal_init.c */
+s32 rtl8723b_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8723b_FirmwareSelfReset(PADAPTER padapter);
+void rtl8723b_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8723b_InitAntenna_Selection(PADAPTER padapter);
+void rtl8723b_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8723b_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8723b_init_default_value(PADAPTER padapter);
+
+s32 rtl8723b_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8723B(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8723B(PADAPTER padapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBTCoexistInfo_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseEEPROMVer_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8723B(PADAPTER pAdapter, u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8723B(PADAPTER padapter, u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParsePackageType_8723B(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+VOID Hal_EfuseParseVoltage_8723B(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8723B(PADAPTER Adapter,	u8	*PROMContent, BOOLEAN AutoloadFail);
+
+void rtl8723b_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8723b(_adapter *adapter);
+u8 SetHwReg8723B(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8723B(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8723B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8723B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8723b_InitBeaconParameters(PADAPTER padapter);
+void rtl8723b_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void	_InitBurstPktLen_8723BS(PADAPTER Adapter);
+void _8051Reset8723(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8723b_start_thread(_adapter *padapter);
+void rtl8723b_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8723bs_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723bs_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723bs_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723bs_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void CCX_FwC2HTxRpt_8723b(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8723B(u8  rate);
+u8 HwRateToMRate8723B(u8	 rate);
+
+#ifdef CONFIG_RF_POWER_TRIM
+	void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8723BE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8723BE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+#endif
+
+#ifdef CONFIG_GPIO_API
+int rtl8723b_GpioFuncCheck(PADAPTER adapter, u8 gpio_num);
+VOID rtl8723b_GpioMultiFuncReset(PADAPTER adapter, u8 gpio_num);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_led.h
new file mode 100644
index 000000000000..6b772cceb7ec
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_led.h
@@ -0,0 +1,44 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_LED_H__
+#define __RTL8723B_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8723bu_InitSwLeds(PADAPTER padapter);
+	void rtl8723bu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8723bs_InitSwLeds(PADAPTER padapter);
+	void rtl8723bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+	void rtl8723bs_InitSwLeds(PADAPTER padapter);
+	void rtl8723bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8723be_InitSwLeds(PADAPTER padapter);
+	void rtl8723be_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif
+#endif/*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_recv.h
new file mode 100644
index 000000000000..cf5e18b66613
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_recv.h
@@ -0,0 +1,86 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_RECV_H__
+#define __RTL8723B_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ  (RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_SDIO_HCI
+	#ifndef CONFIG_SDIO_RX_COPY
+		#undef MAX_RECVBUF_SZ
+		#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B)
+	#endif /* !CONFIG_SDIO_RX_COPY */
+#endif /* CONFIG_SDIO_HCI */
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723bs_init_recv_priv(PADAPTER padapter);
+	void rtl8723bs_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8723bu_init_recv_priv(_adapter *padapter);
+	void rtl8723bu_free_recv_priv(_adapter *padapter);
+	void rtl8723bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723be_init_recv_priv(PADAPTER padapter);
+	void rtl8723be_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8723b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8723B_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_rf.h
new file mode 100644
index 000000000000..6325ad5b8358
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_rf.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_RF_H__
+#define __RTL8723B_RF_H__
+
+int	PHY_RF6052_Config8723B(IN	PADAPTER		Adapter);
+
+VOID
+PHY_RF6052SetBandwidth8723B(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_spec.h
new file mode 100644
index 000000000000..b0fb4aa41d17
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_spec.h
@@ -0,0 +1,280 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_SPEC_H__
+#define __RTL8723B_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8723B		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RSV_CTRL_8723B				0x001C	/* 3 Byte */
+#define REG_BT_WIFI_ANTENNA_SWITCH_8723B	0x0038
+#define REG_HSISR_8723B					0x005c
+#define REG_PAD_CTRL1_8723B		0x0064
+#define REG_AFE_CTRL_4_8723B		0x0078
+#define REG_HMEBOX_DBG_0_8723B	0x0088
+#define REG_HMEBOX_DBG_1_8723B	0x008A
+#define REG_HMEBOX_DBG_2_8723B	0x008C
+#define REG_HMEBOX_DBG_3_8723B	0x008E
+#define REG_HIMR0_8723B					0x00B0
+#define REG_HISR0_8723B					0x00B4
+#define REG_HIMR1_8723B					0x00B8
+#define REG_HISR1_8723B					0x00BC
+#define REG_PMC_DBG_CTRL2_8723B			0x00CC
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8723B	0x01A0
+#define REG_C2HEVT_CMD_LEN_8723B	0x01AE
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_HMEBOX_EXT0_8723B			0x01F0
+#define REG_HMEBOX_EXT1_8723B			0x01F4
+#define REG_HMEBOX_EXT2_8723B			0x01F8
+#define REG_HMEBOX_EXT3_8723B			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_CONTROL_8723B		0x0286 /* Control the RX DMA. */
+#define REG_RXDMA_MODE_CTRL_8723B		0x0290
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8723B		0x0300
+#define	REG_INT_MIG_8723B				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_DESA_8723B			0x0308	/* TX Beacon Descriptor Address */
+#define	REG_HQ_DESA_8723B				0x0310	/* TX High Queue Descriptor Address */
+#define	REG_MGQ_DESA_8723B			0x0318	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_DESA_8723B			0x0320	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_DESA_8723B				0x0328	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_DESA_8723B			0x0330	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_DESA_8723B			0x0338	/* TX BK Queue Descriptor Address */
+#define	REG_RX_DESA_8723B				0x0340	/* RX Queue	Descriptor Address */
+#define	REG_DBI_WDATA_8723B			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8723B			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8723B				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8723B				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8723B		0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8723B			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8723B			0x0358	/* MDIO for Control */
+#define	REG_DBG_SEL_8723B				0x0360	/* Debug Selection Register */
+#define	REG_PCIE_HRPWM_8723B			0x0361	/* PCIe RPWM */
+#define	REG_PCIE_HCPWM_8723B			0x0363	/* PCIe CPWM */
+#define	REG_PCIE_MULTIFET_CTRL_8723B	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_TXPKTBUF_BCNQ_BDNY_8723B	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8723B	0x0425
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8723B	0x045D
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_AMPDU_BURST_MODE_8723B	0x04BC
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SECONDARY_CCA_CTRL_8723B	0x0577
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HCPWM1_8723B	0x025 /* HCI Current Power Mode 1 */
+
+
+/* ****************************************************************************
+ *	8723 Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+/* 2 HSISR
+ * 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)
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#undef IS_E_CUT
+#define IS_E_CUT(version)		FALSE
+#undef IS_F_CUT
+#define IS_F_CUT(version)		((GET_CVID_CUT_VERSION(version) == E_CUT_VERSION) ? TRUE : FALSE)
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* ----------------------------------------------------------------------------
+ * 8723B REG_CCK_CHECK						(offset 0x454)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#ifdef CONFIG_RF_POWER_TRIM
+
+	#ifdef CONFIG_RTL8723B
+		#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#endif
+
+	#define EEPROM_RF_GAIN_VAL				0x1F6
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8723B					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8723B					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8723B					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8723B				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8723B					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8723B					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8723B				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8723B				BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8723B		BIT(24)		/* TSF Timer BIT(32) toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8723B				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8723B				BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8723B		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8723B			BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8723B				BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8723B					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8723B					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8723B					BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8723B				BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8723B				BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8723B					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8723B					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8723B					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8723B					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8723B					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8723B					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8723B				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8723B				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8723B				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8723B				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8723B				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8723B				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8723B				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8723B					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8723B					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8723B					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8723B					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8723B					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8723B					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8723B					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8723B				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8723B					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8723B					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8723B					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8723B					BIT(8)			/* Receive FIFO Overflow */
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_8723B|IMR_RDU_8723B|IMR_RXFOVW_8723B) */
+	#define IMR_TX_MASK			(IMR_VODOK_8723B | IMR_VIDOK_8723B | IMR_BEDOK_8723B | IMR_BKDOK_8723B | IMR_MGNTDOK_8723B | IMR_HIGHDOK_8723B)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8723B | IMR_TXBCN0OK_8723B | IMR_TXBCN0ERR_8723B | IMR_BCNDERR0_8723B)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8723B | IMR_VODOK_8723B | IMR_BEDOK_8723B | IMR_BKDOK_8723B)
+#endif
+
+#endif /* __RTL8723B_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_sreset.h
new file mode 100644
index 000000000000..c97f2648ac60
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8723B_SRESET_H_
+#define _RTL8723B_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8723b_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8723b_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_xmit.h
new file mode 100644
index 000000000000..1364951d9db0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723b_xmit.h
@@ -0,0 +1,334 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_XMIT_H__
+#define __RTL8723B_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8723BDESC_H
+	#define __INC_HAL8723BDESC_H
+
+	#define RX_STATUS_DESC_SIZE_8723B		24
+	#define RX_DRV_INFO_SIZE_UNIT_8723B 8
+
+
+	/* DWORD 0 */
+	#define SET_RX_STATUS_DESC_PKT_LEN_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+	#define SET_RX_STATUS_DESC_EOR_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+	#define SET_RX_STATUS_DESC_OWN_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+	#define GET_RX_STATUS_DESC_PKT_LEN_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+	#define GET_RX_STATUS_DESC_CRC32_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+	#define GET_RX_STATUS_DESC_ICV_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+	#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+	#define GET_RX_STATUS_DESC_SECURITY_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+	#define GET_RX_STATUS_DESC_QOS_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+	#define GET_RX_STATUS_DESC_SHIFT_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+	#define GET_RX_STATUS_DESC_PHY_STATUS_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+	#define GET_RX_STATUS_DESC_SWDEC_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+	#define GET_RX_STATUS_DESC_LAST_SEG_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+	#define GET_RX_STATUS_DESC_FIRST_SEG_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+	#define GET_RX_STATUS_DESC_EOR_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+	#define GET_RX_STATUS_DESC_OWN_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+	/* DWORD 1 */
+	#define GET_RX_STATUS_DESC_MACID_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+	#define GET_RX_STATUS_DESC_TID_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+	#define GET_RX_STATUS_DESC_AMSDU_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+	#define GET_RX_STATUS_DESC_RXID_MATCH_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+	#define GET_RX_STATUS_DESC_PAGGR_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+	#define GET_RX_STATUS_DESC_A1_FIT_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+	#define GET_RX_STATUS_DESC_CHKERR_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+	#define GET_RX_STATUS_DESC_IPVER_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+	#define GET_RX_STATUS_DESC_IS_TCPUDP__8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+	#define GET_RX_STATUS_DESC_CHK_VLD_8723B(__pRxDesc)	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+	#define GET_RX_STATUS_DESC_PAM_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+	#define GET_RX_STATUS_DESC_PWR_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+	#define GET_RX_STATUS_DESC_MORE_DATA_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+	#define GET_RX_STATUS_DESC_MORE_FRAG_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+	#define GET_RX_STATUS_DESC_TYPE_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+	#define GET_RX_STATUS_DESC_MC_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+	#define GET_RX_STATUS_DESC_BC_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+	/* DWORD 2 */
+	#define GET_RX_STATUS_DESC_SEQ_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+	#define GET_RX_STATUS_DESC_FRAG_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+	#define GET_RX_STATUS_DESC_RX_IS_QOS_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+	#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8723B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+	#define GET_RX_STATUS_DESC_RPT_SEL_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+	/* DWORD 3 */
+	#define GET_RX_STATUS_DESC_RX_RATE_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+	#define GET_RX_STATUS_DESC_HTC_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+	#define GET_RX_STATUS_DESC_EOSP_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+	#define GET_RX_STATUS_DESC_BSSID_FIT_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+	#ifdef CONFIG_USB_RX_AGGREGATION
+		#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8723B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+	#endif
+	#define GET_RX_STATUS_DESC_PATTERN_MATCH_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+	#define GET_RX_STATUS_DESC_UNICAST_MATCH_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+	#define GET_RX_STATUS_DESC_MAGIC_MATCH_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+	/* DWORD 6 */
+	#define GET_RX_STATUS_DESC_SPLCP_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+	#define GET_RX_STATUS_DESC_LDPC_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+	#define GET_RX_STATUS_DESC_STBC_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+	#define GET_RX_STATUS_DESC_BW_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+	/* DWORD 5 */
+	#define GET_RX_STATUS_DESC_TSFL_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+	#define GET_RX_STATUS_DESC_BUFF_ADDR_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+	#define GET_RX_STATUS_DESC_BUFF_ADDR64_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+	#define SET_RX_STATUS_DESC_BUFF_ADDR_8723B(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+	/* Dword 0 */
+	#define GET_TX_DESC_OWN_8723B(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+	#define SET_TX_DESC_PKT_SIZE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+	#define SET_TX_DESC_OFFSET_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+	#define SET_TX_DESC_BMC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+	#define SET_TX_DESC_HTC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+	#define SET_TX_DESC_LAST_SEG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+	#define SET_TX_DESC_FIRST_SEG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+	#define SET_TX_DESC_LINIP_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+	#define SET_TX_DESC_NO_ACM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+	#define SET_TX_DESC_GF_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+	#define SET_TX_DESC_OWN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+	/* Dword 1 */
+	#define SET_TX_DESC_MACID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+	#define SET_TX_DESC_QUEUE_SEL_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+	#define SET_TX_DESC_RDG_NAV_EXT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+	#define SET_TX_DESC_LSIG_TXOP_EN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+	#define SET_TX_DESC_PIFS_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+	#define SET_TX_DESC_RATE_ID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+	#define SET_TX_DESC_EN_DESC_ID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+	#define SET_TX_DESC_SEC_TYPE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+	#define SET_TX_DESC_PKT_OFFSET_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+
+
+	/* Dword 2 */
+	#define SET_TX_DESC_PAID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+	#define SET_TX_DESC_CCA_RTS_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+	#define SET_TX_DESC_AGG_ENABLE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+	#define SET_TX_DESC_RDG_ENABLE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+	#define SET_TX_DESC_AGG_BREAK_8723B(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+	#define SET_TX_DESC_MORE_FRAG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+	#define SET_TX_DESC_RAW_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+	#define SET_TX_DESC_SPE_RPT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+	#define SET_TX_DESC_AMPDU_DENSITY_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+	#define SET_TX_DESC_BT_INT_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+	#define SET_TX_DESC_GID_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+
+	/* Dword 3 */
+	#define SET_TX_DESC_WHEADER_LEN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+	#define SET_TX_DESC_CHK_EN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+	#define SET_TX_DESC_EARLY_MODE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+	#define SET_TX_DESC_HWSEQ_SEL_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+	#define SET_TX_DESC_USE_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+	#define SET_TX_DESC_DISABLE_RTS_FB_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+	#define SET_TX_DESC_DISABLE_FB_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+	#define SET_TX_DESC_CTS2SELF_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+	#define SET_TX_DESC_RTS_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+	#define SET_TX_DESC_HW_RTS_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+	#define SET_TX_DESC_NAV_USE_HDR_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+	#define SET_TX_DESC_USE_MAX_LEN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+	#define SET_TX_DESC_MAX_AGG_NUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+	#define SET_TX_DESC_NDPA_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+	#define SET_TX_DESC_AMPDU_MAX_TIME_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+	/* Dword 4 */
+	#define SET_TX_DESC_TX_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+	#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+	#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+	#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+	#define SET_TX_DESC_DATA_RETRY_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+	#define SET_TX_DESC_RTS_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+
+
+	/* Dword 5 */
+	#define SET_TX_DESC_DATA_SC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+	#define SET_TX_DESC_DATA_SHORT_8723B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+	#define SET_TX_DESC_DATA_BW_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+	#define SET_TX_DESC_DATA_LDPC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+	#define SET_TX_DESC_DATA_STBC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+	#define SET_TX_DESC_CTROL_STBC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+	#define SET_TX_DESC_RTS_SHORT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+	#define SET_TX_DESC_RTS_SC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+
+
+	/* Dword 6 */
+	#define SET_TX_DESC_SW_DEFINE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+	#define SET_TX_DESC_MBSSID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+	#define SET_TX_DESC_ANTSEL_A_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_B_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_C_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_D_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+
+	/* Dword 7 */
+	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		#define SET_TX_DESC_TX_BUFFER_SIZE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#else
+		#define SET_TX_DESC_TX_DESC_CHECKSUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#endif
+	#define SET_TX_DESC_USB_TXAGG_NUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+	#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+		#define SET_TX_DESC_SDIO_TXSEQ_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+	#endif
+
+	/* Dword 8 */
+	#define SET_TX_DESC_HWSEQ_EN_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+
+	/* Dword 9 */
+	#define SET_TX_DESC_SEQ_8723B(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+
+	/* Dword 10 */
+	#define SET_TX_DESC_TX_BUFFER_ADDRESS_8723B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+	#define GET_TX_DESC_TX_BUFFER_ADDRESS_8723B(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+
+	/* Dword 11 */
+	#define SET_TX_DESC_NEXT_DESC_ADDRESS_8723B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+
+
+	#define SET_EARLYMODE_PKTNUM_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+	#define SET_EARLYMODE_LEN0_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+	#define SET_EARLYMODE_LEN1_1_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+	#define SET_EARLYMODE_LEN1_2_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+	#define SET_EARLYMODE_LEN2_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+	#define SET_EARLYMODE_LEN3_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8723B_RATE1M				0x00
+#define DESC8723B_RATE2M				0x01
+#define DESC8723B_RATE5_5M				0x02
+#define DESC8723B_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8723B_RATE6M				0x04
+#define DESC8723B_RATE9M				0x05
+#define DESC8723B_RATE12M				0x06
+#define DESC8723B_RATE18M				0x07
+#define DESC8723B_RATE24M				0x08
+#define DESC8723B_RATE36M				0x09
+#define DESC8723B_RATE48M				0x0a
+#define DESC8723B_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8723B_RATEMCS0				0x0c
+#define DESC8723B_RATEMCS1				0x0d
+#define DESC8723B_RATEMCS2				0x0e
+#define DESC8723B_RATEMCS3				0x0f
+#define DESC8723B_RATEMCS4				0x10
+#define DESC8723B_RATEMCS5				0x11
+#define DESC8723B_RATEMCS6				0x12
+#define DESC8723B_RATEMCS7				0x13
+#define DESC8723B_RATEMCS8				0x14
+#define DESC8723B_RATEMCS9				0x15
+#define DESC8723B_RATEMCS10		0x16
+#define DESC8723B_RATEMCS11		0x17
+#define DESC8723B_RATEMCS12		0x18
+#define DESC8723B_RATEMCS13		0x19
+#define DESC8723B_RATEMCS14		0x1a
+#define DESC8723B_RATEMCS15		0x1b
+#define DESC8723B_RATEVHTSS1MCS0		0x2c
+#define DESC8723B_RATEVHTSS1MCS1		0x2d
+#define DESC8723B_RATEVHTSS1MCS2		0x2e
+#define DESC8723B_RATEVHTSS1MCS3		0x2f
+#define DESC8723B_RATEVHTSS1MCS4		0x30
+#define DESC8723B_RATEVHTSS1MCS5		0x31
+#define DESC8723B_RATEVHTSS1MCS6		0x32
+#define DESC8723B_RATEVHTSS1MCS7		0x33
+#define DESC8723B_RATEVHTSS1MCS8		0x34
+#define DESC8723B_RATEVHTSS1MCS9		0x35
+#define DESC8723B_RATEVHTSS2MCS0		0x36
+#define DESC8723B_RATEVHTSS2MCS1		0x37
+#define DESC8723B_RATEVHTSS2MCS2		0x38
+#define DESC8723B_RATEVHTSS2MCS3		0x39
+#define DESC8723B_RATEVHTSS2MCS4		0x3a
+#define DESC8723B_RATEVHTSS2MCS5		0x3b
+#define DESC8723B_RATEVHTSS2MCS6		0x3c
+#define DESC8723B_RATEVHTSS2MCS7		0x3d
+#define DESC8723B_RATEVHTSS2MCS8		0x3e
+#define DESC8723B_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8723B(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE11M)
+
+
+void rtl8723b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8723b_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723bs_init_xmit_priv(PADAPTER padapter);
+	void rtl8723bs_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723bs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723bs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723bs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723bs_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8723bs_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8723bs_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8723bu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8723bu_xmit_buf_handler
+
+
+	s32 rtl8723bu_init_xmit_priv(PADAPTER padapter);
+	void rtl8723bu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8723bu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	/* s32 rtl8812au_xmit_buf_handler(PADAPTER padapter); */
+	void rtl8723bu_xmit_tasklet(void *priv);
+	s32 rtl8723bu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723be_init_xmit_priv(PADAPTER padapter);
+	void rtl8723be_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8723be_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void	rtl8723be_xmitframe_resume(_adapter *padapter);
+	s32 rtl8723be_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723be_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723be_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8723be_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8723B(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8723B(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_cmd.h
new file mode 100644
index 000000000000..c90b8ea8042c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_cmd.h
@@ -0,0 +1,190 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_CMD_H__
+#define __RTL8723D_CMD_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+enum h2c_cmd_8723D {
+	/* Common Class: 000 */
+	H2C_8723D_RSVD_PAGE = 0x00,
+	H2C_8723D_MEDIA_STATUS_RPT = 0x01,
+	H2C_8723D_SCAN_ENABLE = 0x02,
+	H2C_8723D_KEEP_ALIVE = 0x03,
+	H2C_8723D_DISCON_DECISION = 0x04,
+	H2C_8723D_PSD_OFFLOAD = 0x05,
+	H2C_8723D_AP_OFFLOAD = 0x08,
+	H2C_8723D_BCN_RSVDPAGE = 0x09,
+	H2C_8723D_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8723D_FCS_RSVDPAGE = 0x10,
+	H2C_8723D_FCS_INFO = 0x11,
+	H2C_8723D_AP_WOW_GPIO_CTRL = 0x13,
+
+	/* PoweSave Class: 001 */
+	H2C_8723D_SET_PWR_MODE = 0x20,
+	H2C_8723D_PS_TUNING_PARA = 0x21,
+	H2C_8723D_PS_TUNING_PARA2 = 0x22,
+	H2C_8723D_P2P_LPS_PARAM = 0x23,
+	H2C_8723D_P2P_PS_OFFLOAD = 0x24,
+	H2C_8723D_PS_SCAN_ENABLE = 0x25,
+	H2C_8723D_SAP_PS_ = 0x26,
+	H2C_8723D_INACTIVE_PS_ = 0x27, /* Inactive_PS */
+	H2C_8723D_FWLPS_IN_IPS_ = 0x28,
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8723D_MACID_CFG = 0x40,
+	H2C_8723D_TXBF = 0x41,
+	H2C_8723D_RSSI_SETTING = 0x42,
+	H2C_8723D_AP_REQ_TXRPT = 0x43,
+	H2C_8723D_INIT_RATE_COLLECT = 0x44,
+	H2C_8723D_RA_PARA_ADJUST = 0x46,
+
+	/* BT Class: 011 */
+	H2C_8723D_B_TYPE_TDMA = 0x60,
+	H2C_8723D_BT_INFO = 0x61,
+	H2C_8723D_FORCE_BT_TXPWR = 0x62,
+	H2C_8723D_BT_IGNORE_WLANACT = 0x63,
+	H2C_8723D_DAC_SWING_VALUE = 0x64,
+	H2C_8723D_ANT_SEL_RSV = 0x65,
+	H2C_8723D_WL_OPMODE = 0x66,
+	H2C_8723D_BT_MP_OPER = 0x67,
+	H2C_8723D_BT_CONTROL = 0x68,
+	H2C_8723D_BT_WIFI_CTRL = 0x69,
+	H2C_8723D_BT_FW_PATCH = 0x6A,
+	H2C_8723D_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
+	H2C_8723D_WOWLAN = 0x80,
+	H2C_8723D_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8723D_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8723D_AOAC_RSVD_PAGE = 0x83,
+	H2C_8723D_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_8723D_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_8723D_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_8723D_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_8723D_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
+	H2C_8723D_P2P_OFFLOAD = 0x8B,
+
+	H2C_8723D_RESET_TSF = 0xC0,
+	H2C_8723D_MAXID,
+};
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _PWR_MOD_CMD_0x20 */
+#define SET_8723D_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+#define GET_8723D_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _PS_TUNE_PARAM_CMD_0x21 */
+#define SET_8723D_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _MACID_CFG_CMD_0x40 */
+#define SET_8723D_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
+
+/* _RSSI_SETTING_CMD_0x42 */
+#define SET_8723D_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
+#define SET_8723D_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _AP_REQ_TXRPT_CMD_0x43 */
+#define SET_8723D_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _FORCE_BT_TXPWR_CMD_0x62 */
+#define SET_8723D_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
+#define SET_8723D_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+
+/* _BT_FW_PATCH_0x6A */
+#define SET_8723D_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+/* host message to firmware cmd */
+void rtl8723d_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8723d_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
+/* s32 rtl8723d_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
+void rtl8723d_set_FwPsTuneParam_cmd(PADAPTER padapter);
+void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8723d_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P
+	void rtl8723d_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8723d_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+	void rtl8723d_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+#endif
+
+s32 FillH2CCmd8723D(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8723D(_adapter *padapter, bool wowlan);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_dm.h
new file mode 100644
index 000000000000..0612f0620e79
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_dm.h
@@ -0,0 +1,39 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_DM_H__
+#define __RTL8723D_DM_H__
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8723D dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
+
+void rtl8723d_init_dm_priv(PADAPTER padapter);
+void rtl8723d_deinit_dm_priv(PADAPTER padapter);
+
+void rtl8723d_InitHalDm(PADAPTER padapter);
+void rtl8723d_HalDmWatchDog(PADAPTER padapter);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_hal.h
new file mode 100644
index 000000000000..7ebf666658ef
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_hal.h
@@ -0,0 +1,313 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_HAL_H__
+#define __RTL8723D_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8723d_spec.h"
+#include "rtl8723d_rf.h"
+#include "rtl8723d_dm.h"
+#include "rtl8723d_recv.h"
+#include "rtl8723d_xmit.h"
+#include "rtl8723d_cmd.h"
+#include "rtl8723d_led.h"
+#include "Hal8723DPwrSeq.h"
+#include "Hal8723DPhyReg.h"
+#include "Hal8723DPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8723d_sreset.h"
+#endif
+#ifdef CONFIG_LPS_POFF
+	#include "rtl8723d_lps_poff.h"
+#endif
+
+#define FW_8723D_SIZE		0x8000
+#define FW_8723D_START_ADDRESS	0x1000
+#define FW_8723D_END_ADDRESS	0x1FFF /* 0x5FFF */
+
+#define IS_FW_HEADER_EXIST_8723D(_pFwHdr)\
+	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x23D0)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8723D_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8723D, *PRT_FIRMWARE_8723D;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8723D_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8723D_FIRMWARE_HDR, *PRT_8723D_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8723D		0x05
+#define BCN_DMA_ATIME_INT_TIME_8723D		0x02
+
+/* for 8723D
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8723D			128
+#define PAGE_SIZE_RX_8723D			8
+
+#define TX_DMA_SIZE_8723D			0x8000	/* 32K(TX) */
+#define RX_DMA_SIZE_8723D			0x4000	/* 16K(RX) */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8723D	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8723D	0x80	/* 128B, reserved for tx report */
+#endif
+#define RX_DMA_BOUNDARY_8723D\
+	(RX_DMA_SIZE_8723D - RX_DMA_RESERVED_SIZE_8723D - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
+#define BCNQ_PAGE_NUM_8723D		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8723D		0x08 /* 0x04 */
+#else
+	#define BCNQ1_PAGE_NUM_8723D		0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef BCNQ1_PAGE_NUM_8723D
+	#define BCNQ1_PAGE_NUM_8723D		0x00 /* 0x04 */
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt 1, PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8723D	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8723D	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8723D
+	#define WOWLAN_PAGE_NUM_8723D	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8723D	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8723D\
+	(0xFF - BCNQ_PAGE_NUM_8723D - BCNQ1_PAGE_NUM_8723D - WOWLAN_PAGE_NUM_8723D)
+#define TX_PAGE_BOUNDARY_8723D		(TX_TOTAL_PAGE_NUMBER_8723D + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723D	TX_TOTAL_PAGE_NUMBER_8723D
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8723D\
+	(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723D + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723D */
+#define NORMAL_PAGE_NUM_HPQ_8723D		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8723D		0x02
+#define NORMAL_PAGE_NUM_NPQ_8723D		0x02
+#define NORMAL_PAGE_NUM_EPQ_8723D		0x04
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8723D		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8723D		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8723D		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8723D		0x00
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES (96 + 1)
+
+#define HAL_EFUSE_MEMORY
+#define HWSET_MAX_SIZE_8723D                512
+#define EFUSE_REAL_CONTENT_LEN_8723D        512
+#define EFUSE_MAP_LEN_8723D                 512
+#define EFUSE_MAX_SECTION_8723D             64
+
+/* For some inferiority IC purpose. added by Roger, 2009.09.02.*/
+#define EFUSE_IC_ID_OFFSET			506
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8723D)
+
+#define EFUSE_ACCESS_ON		0x69
+#define EFUSE_ACCESS_OFF	0x00
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define BANK_NUM			1
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
+#define EFUSE_BT_REAL_CONTENT_LEN	\
+	(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN		1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION		(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK	16
+
+typedef enum tag_Package_Definition {
+	PACKAGE_DEFAULT,
+	PACKAGE_QFN68,
+	PACKAGE_TFBGA90,
+	PACKAGE_TFBGA80,
+	PACKAGE_TFBGA79
+} PACKAGE_TYPE_E;
+
+#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)
+
+#ifdef CONFIG_FILE_FWIMG
+	extern char *rtw_fw_file_path;
+	extern char *rtw_fw_wow_file_path;
+	#ifdef CONFIG_MP_INCLUDED
+		extern char *rtw_fw_mp_bt_file_path;
+	#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
+
+/* rtl8723d_hal_init.c */
+s32 rtl8723d_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8723d_FirmwareSelfReset(PADAPTER padapter);
+void rtl8723d_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8723d_InitAntenna_Selection(PADAPTER padapter);
+void rtl8723d_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8723d_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8723d_init_default_value(PADAPTER padapter);
+
+s32 rtl8723d_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8723D(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8723D(PADAPTER padapter,
+				     u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBTCoexistInfo_8723D(PADAPTER padapter,
+				       u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseEEPROMVer_8723D(PADAPTER padapter,
+				   u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParsePackageType_8723D(PADAPTER pAdapter,
+				     u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8723D(PADAPTER padapter,
+				  u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8723D(PADAPTER padapter,
+				    u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8723D(PADAPTER padapter,
+		u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8723D(PADAPTER pAdapter,
+			      u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8723D(PADAPTER padapter,
+				      u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParseVoltage_8723D(PADAPTER pAdapter,
+				 u8 *hwinfo, BOOLEAN	AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8723D(PADAPTER Adapter,
+				   u8	*PROMContent, BOOLEAN AutoloadFail);
+
+void rtl8723d_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8723d(_adapter *adapter);
+u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8723D(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8723D(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8723d_InitBeaconParameters(PADAPTER padapter);
+void rtl8723d_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void _InitMacAPLLSetting_8723D(PADAPTER Adapter);
+void _8051Reset8723(PADAPTER padapter);
+#ifdef CONFIG_WOWLAN
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8723d_start_thread(_adapter *padapter);
+void rtl8723d_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8723ds_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723ds_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723ds_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723ds_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void CCX_FwC2HTxRpt_8723d(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8723D(u8 rate);
+u8 HwRateToMRate8723D(u8 rate);
+
+void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void check_bt_status_work(void *data);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	void rtl8723d_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8723DE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8723DE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+	u16 get_txbd_rw_reg(u16 ff_hwaddr);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_led.h
new file mode 100644
index 000000000000..1905e8bed02c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_led.h
@@ -0,0 +1,44 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_LED_H__
+#define __RTL8723D_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8723du_InitSwLeds(PADAPTER padapter);
+	void rtl8723du_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8723ds_InitSwLeds(PADAPTER padapter);
+	void rtl8723ds_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+	void rtl8723ds_InitSwLeds(PADAPTER padapter);
+	void rtl8723ds_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8723de_InitSwLeds(PADAPTER padapter);
+	void rtl8723de_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif /*#ifdef CONFIG_RTW_SW_LED*/
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_lps_poff.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_lps_poff.h
new file mode 100644
index 000000000000..138a0ca66732
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_lps_poff.h
@@ -0,0 +1,56 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/******************************************** CONST  ************************/
+#define NUM_OF_REGISTER_BANK	13
+#define NUM_OF_TOTAL_DWORD (NUM_OF_REGISTER_BANK * 64)
+#define TOTAL_LEN_FOR_HIOE ((NUM_OF_TOTAL_DWORD + 1) * 8)
+#define LPS_POFF_STATIC_FILE_LEN (TOTAL_LEN_FOR_HIOE + TXDESC_SIZE)
+#define LPS_POFF_DYNAMIC_FILE_LEN	(512 + TXDESC_SIZE)
+/******************************************** CONST  ************************/
+
+/******************************************** MACRO   ************************/
+/* HOIE Entry Definition */
+#define SET_HOIE_ENTRY_LOW_DATA(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE),	0, 16, __Value)
+#define SET_HOIE_ENTRY_HIGH_DATA(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE), 16, 16, __Value)
+#define SET_HOIE_ENTRY_MODE_SELECT(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 0, 1, __Value)
+#define SET_HOIE_ENTRY_ADDRESS(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 1, 14, __Value)
+#define SET_HOIE_ENTRY_BYTE_MASK(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 15, 4, __Value)
+#define SET_HOIE_ENTRY_IO_LOCK(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 19, 1, __Value)
+#define SET_HOIE_ENTRY_RD_EN(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 20, 1, __Value)
+#define SET_HOIE_ENTRY_WR_EN(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 21, 1, __Value)
+#define SET_HOIE_ENTRY_RAW_RW(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 22, 1, __Value)
+#define SET_HOIE_ENTRY_RAW(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 23, 1, __Value)
+#define SET_HOIE_ENTRY_IO_DELAY(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 24, 8, __Value)
+
+/*********************Function Definition*******************************************/
+void rtl8723d_lps_poff_init(PADAPTER padapter);
+void rtl8723d_lps_poff_deinit(PADAPTER padapter);
+bool rtl8723d_lps_poff_get_txbndy_status(PADAPTER padapter);
+void rtl8723d_lps_poff_h2c_ctrl(PADAPTER padapter, u8 enable);
+void rtl8723d_lps_poff_set_ps_mode(PADAPTER padapter, bool bEnterLPS);
+bool rtl8723d_lps_poff_get_status(PADAPTER padapter);
+void rtl8723d_lps_poff_wow(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_recv.h
new file mode 100644
index 000000000000..03539a8b0a39
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_recv.h
@@ -0,0 +1,116 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_RECV_H__
+#define __RTL8723D_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8723D + 1)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_SDIO_HCI
+	#ifndef CONFIG_SDIO_RX_COPY
+		#undef MAX_RECVBUF_SZ
+		#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8723D - RX_DMA_RESERVED_SIZE_8723D)
+	#endif /* !CONFIG_SDIO_RX_COPY */
+#endif /* CONFIG_SDIO_HCI */
+
+/*-----------------------------------------------------------------*/
+/*	RTL8723D RX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+/*DWORD 0*/
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_8723D(__pRxStatusDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 15, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_FS_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 1)
+#ifdef USING_RX_TAG
+	#define GET_RX_BUFFER_DESC_RX_TAG_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 13)
+#else
+	#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+#endif
+
+/*DWORD 1*/
+#define SET_RX_BUFFER_PHYSICAL_LOW_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+
+/*DWORD 2*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+#else
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8723D(__pRxStatusDesc, __Value)
+#endif
+
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723ds_init_recv_priv(PADAPTER padapter);
+	void rtl8723ds_free_recv_priv(PADAPTER padapter);
+	s32 rtl8723ds_recv_hdl(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8723du_init_recv_priv(_adapter *padapter);
+	void rtl8723du_free_recv_priv(_adapter *padapter);
+	void rtl8723du_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723de_init_recv_priv(PADAPTER padapter);
+	void rtl8723de_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8723d_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8723D_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_rf.h
new file mode 100644
index 000000000000..733eb0a46518
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_rf.h
@@ -0,0 +1,21 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_RF_H__
+#define __RTL8723D_RF_H__
+
+int PHY_RF6052_Config8723D(IN PADAPTER pdapter);
+
+void PHY_RF6052SetBandwidth8723D(IN PADAPTER Adapter, IN enum channel_width Bandwidth);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_spec.h
new file mode 100644
index 000000000000..5106b23b7722
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_spec.h
@@ -0,0 +1,447 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_SPEC_H__
+#define __RTL8723D_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8723D		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8723D			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8723D			0x0002	/* 2 Byte */
+#define REG_APS_FSMCO_8723D			0x0004	/* 4 Byte */
+#define REG_SYS_CLKR_8723D				0x0008	/* 2 Byte */
+#define REG_9346CR_8723D				0x000A	/* 2 Byte */
+#define REG_EE_VPD_8723D				0x000C	/* 2 Byte */
+#define REG_AFE_MISC_8723D				0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8723D				0x0011	/* 7 Byte */
+#define REG_SPS_OCP_CFG_8723D			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8723D				0x001C	/* 3 Byte */
+#define REG_RF_CTRL_8723D				0x001F	/* 1 Byte */
+#define REG_LPLDO_CTRL_8723D			0x0023	/* 1 Byte */
+#define REG_AFE_XTAL_CTRL_8723D		0x0024	/* 4 Byte */
+#define REG_AFE_PLL_CTRL_8723D			0x0028	/* 4 Byte */
+#define REG_MAC_PLL_CTRL_EXT_8723D		0x002c	/* 4 Byte */
+#define REG_EFUSE_CTRL_8723D			0x0030
+#define REG_EFUSE_TEST_8723D			0x0034
+#define REG_PWR_DATA_8723D				0x0038
+#define REG_CAL_TIMER_8723D				0x003C
+#define REG_ACLK_MON_8723D				0x003E
+#define REG_GPIO_MUXCFG_8723D			0x0040
+#define REG_GPIO_IO_SEL_8723D			0x0042
+#define REG_MAC_PINMUX_CFG_8723D		0x0043
+#define REG_GPIO_PIN_CTRL_8723D			0x0044
+#define REG_GPIO_INTM_8723D				0x0048
+#define REG_LEDCFG0_8723D				0x004C
+#define REG_LEDCFG1_8723D				0x004D
+#define REG_LEDCFG2_8723D				0x004E
+#define REG_LEDCFG3_8723D				0x004F
+#define REG_FSIMR_8723D					0x0050
+#define REG_FSISR_8723D					0x0054
+#define REG_HSIMR_8723D					0x0058
+#define REG_HSISR_8723D					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_PAD_CTRL1_8723D		0x0064
+#define REG_MULTI_FUNC_CTRL_8723D		0x0068
+#define REG_GPIO_STATUS_8723D			0x006C
+#define REG_SDIO_CTRL_8723D				0x0070
+#define REG_OPT_CTRL_8723D				0x0074
+#define REG_AFE_CTRL_4_8723D		0x0078
+#define REG_MCUFWDL_8723D				0x0080
+#define REG_8051FW_CTRL_8723D			0x0080
+#define REG_HMEBOX_DBG_0_8723D	0x0088
+#define REG_HMEBOX_DBG_1_8723D	0x008A
+#define REG_HMEBOX_DBG_2_8723D	0x008C
+#define REG_HMEBOX_DBG_3_8723D	0x008E
+#define REG_WLLPS_CTRL		0x0090
+#define REG_HIMR0_8723D					0x00B0
+#define REG_HISR0_8723D					0x00B4
+#define REG_HIMR1_8723D					0x00B8
+#define REG_HISR1_8723D					0x00BC
+#define REG_PMC_DBG_CTRL2_8723D			0x00CC
+#define	REG_EFUSE_BURN_GNT_8723D		0x00CF
+#define REG_HPON_FSM_8723D				0x00EC
+#define REG_SYS_CFG1_8723D				0x00F0
+#define REG_SYS_CFG_8723D				0x00FC
+#define REG_ROM_VERSION					0x00FD
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8723D	0x01A0
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_8723D        0x01AE
+#define REG_C2HEVT_CLEAR_8723D			0x01AF
+#define REG_MCUTST_1_8723D				0x01C0
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_FMETHR_8723D				0x01C8
+#define REG_HMETFR_8723D				0x01CC
+#define REG_HMEBOX_0_8723D				0x01D0
+#define REG_HMEBOX_1_8723D				0x01D4
+#define REG_HMEBOX_2_8723D				0x01D8
+#define REG_HMEBOX_3_8723D				0x01DC
+#define REG_LLT_INIT_8723D				0x01E0
+#define REG_HMEBOX_EXT0_8723D			0x01F0
+#define REG_HMEBOX_EXT1_8723D			0x01F4
+#define REG_HMEBOX_EXT2_8723D			0x01F8
+#define REG_HMEBOX_EXT3_8723D			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RQPN_8723D					0x0200
+#define REG_FIFOPAGE_8723D				0x0204
+#define REG_DWBCN0_CTRL_8723D			REG_TDECTRL
+#define REG_TXDMA_OFFSET_CHK_8723D	0x020C
+#define REG_TXDMA_STATUS_8723D		0x0210
+#define REG_RQPN_NPQ_8723D			0x0214
+#define REG_DWBCN1_CTRL_8723D			0x0228
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8723D		0x0280
+#define REG_FW_UPD_RDPTR_8723D		0x0284 /* FW shall update this register before FW write RXPKT_RELEASE_POLL to 1 */
+#define REG_RXDMA_CONTROL_8723D		0x0286 /* Control the RX DMA. */
+#define REG_RXDMA_STATUS_8723D			0x0288
+#define REG_RXDMA_MODE_CTRL_8723D		0x0290
+#define REG_EARLY_MODE_CONTROL_8723D	0x02BC
+#define REG_RSVD5_8723D					0x02F0
+#define REG_RSVD6_8723D					0x02F4
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8723D			0x0300
+#define	REG_INT_MIG_8723D				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8723D		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8723D			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8723D			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8723D			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8723D			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8723D			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8723D			0x0338	/* RX Queue	Descriptor Address */
+#define REG_HI0Q_TXBD_DESA_8723D		0x0340
+#define REG_HI1Q_TXBD_DESA_8723D		0x0348
+#define REG_HI2Q_TXBD_DESA_8723D		0x0350
+#define REG_HI3Q_TXBD_DESA_8723D		0x0358
+#define REG_HI4Q_TXBD_DESA_8723D		0x0360
+#define REG_HI5Q_TXBD_DESA_8723D		0x0368
+#define REG_HI6Q_TXBD_DESA_8723D		0x0370
+#define REG_HI7Q_TXBD_DESA_8723D		0x0378
+#define	REG_MGQ_TXBD_NUM_8723D			0x0380
+#define	REG_RX_RXBD_NUM_8723D			0x0382
+#define	REG_VOQ_TXBD_NUM_8723D			0x0384
+#define	REG_VIQ_TXBD_NUM_8723D			0x0386
+#define	REG_BEQ_TXBD_NUM_8723D			0x0388
+#define	REG_BKQ_TXBD_NUM_8723D			0x038A
+#define	REG_HI0Q_TXBD_NUM_8723D			0x038C
+#define	REG_HI1Q_TXBD_NUM_8723D			0x038E
+#define	REG_HI2Q_TXBD_NUM_8723D			0x0390
+#define	REG_HI3Q_TXBD_NUM_8723D			0x0392
+#define	REG_HI4Q_TXBD_NUM_8723D			0x0394
+#define	REG_HI5Q_TXBD_NUM_8723D			0x0396
+#define	REG_HI6Q_TXBD_NUM_8723D			0x0398
+#define	REG_HI7Q_TXBD_NUM_8723D			0x039A
+#define	REG_TSFTIMER_HCI_8723D			0x039C
+#define	REG_BD_RW_PTR_CLR_8723D			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8723D			0x03A0
+#define	REG_VIQ_TXBD_IDX_8723D			0x03A4
+#define	REG_BEQ_TXBD_IDX_8723D			0x03A8
+#define	REG_BKQ_TXBD_IDX_8723D			0x03AC
+#define	REG_MGQ_TXBD_IDX_8723D			0x03B0
+#define	REG_RXQ_TXBD_IDX_8723D			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8723D			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8723D			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8723D			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8723D			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8723D			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8723D			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8723D			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8723D			0x03D4
+
+#define	REG_PCIE_HCPWM_8723DE			0x03D8 /* ?????? */
+#define	REG_PCIE_HRPWM_8723DE			0x03DC	/* PCIe RPWM  ?????? */
+#define	REG_DBI_WDATA_V1_8723D			0x03E8
+#define	REG_DBI_RDATA_V1_8723D			0x03EC
+#define	REG_DBI_FLAG_V1_8723D			0x03F0
+#define REG_MDIO_V1_8723D				0x03F4
+#define REG_PCIE_MIX_CFG_8723D			0x03F8
+#define REG_HCI_MIX_CFG_8723D			0x03FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_VOQ_INFORMATION_8723D		0x0400
+#define REG_VIQ_INFORMATION_8723D		0x0404
+#define REG_BEQ_INFORMATION_8723D		0x0408
+#define REG_BKQ_INFORMATION_8723D		0x040C
+#define REG_MGQ_INFORMATION_8723D		0x0410
+#define REG_HGQ_INFORMATION_8723D		0x0414
+#define REG_BCNQ_INFORMATION_8723D	0x0418
+#define REG_TXPKT_EMPTY_8723D			0x041A
+
+#define REG_FWHW_TXQ_CTRL_8723D		0x0420
+#define REG_HWSEQ_CTRL_8723D			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8723D	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8723D	0x0425
+#define REG_LIFECTRL_CTRL_8723D			0x0426
+#define REG_MULTI_BCNQ_OFFSET_8723D	0x0427
+#define REG_SPEC_SIFS_8723D				0x0428
+#define REG_RL_8723D						0x042A
+#define REG_TXBF_CTRL_8723D				0x042C
+#define REG_DARFRC_8723D				0x0430
+#define REG_RARFRC_8723D				0x0438
+#define REG_RRSR_8723D					0x0440
+#define REG_ARFR0_8723D					0x0444
+#define REG_ARFR1_8723D					0x044C
+#define REG_CCK_CHECK_8723D				0x0454
+#define REG_AMPDU_MAX_TIME_8723D		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8723D	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8723D	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8723D	0x045D
+#define REG_NDPA_OPT_CTRL_8723D		0x045F
+#define REG_FAST_EDCA_CTRL_8723D		0x0460
+#define REG_RD_RESP_PKT_TH_8723D		0x0463
+#define REG_DATA_SC_8723D				0x0483
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_POWER_STAGE1_8723D		0x04B4
+#define REG_POWER_STAGE2_8723D		0x04B8
+#define REG_AMPDU_BURST_MODE_8723D	0x04BC
+#define REG_PKT_VO_VI_LIFE_TIME_8723D	0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8723D	0x04C2
+#define REG_STBC_SETTING_8723D			0x04C4
+#define REG_HT_SINGLE_AMPDU_8723D		0x04C7
+#define REG_PROT_MODE_CTRL_8723D		0x04C8
+#define REG_MAX_AGGR_NUM_8723D		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8723D	0x04CB
+#define REG_BAR_MODE_CTRL_8723D		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8723D	0x04CF
+#define REG_MACID_PKT_DROP0_8723D		0x04D0
+#define REG_MACID_PKT_SLEEP_8723D		0x04D4
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8723D		0x0500
+#define REG_EDCA_VI_PARAM_8723D		0x0504
+#define REG_EDCA_BE_PARAM_8723D		0x0508
+#define REG_EDCA_BK_PARAM_8723D		0x050C
+#define REG_BCNTCFG_8723D				0x0510
+#define REG_PIFS_8723D					0x0512
+#define REG_RDG_PIFS_8723D				0x0513
+#define REG_SIFS_CTX_8723D				0x0514
+#define REG_SIFS_TRX_8723D				0x0516
+#define REG_AGGR_BREAK_TIME_8723D		0x051A
+#define REG_SLOT_8723D					0x051B
+#define REG_TX_PTCL_CTRL_8723D			0x0520
+#define REG_TXPAUSE_8723D				0x0522
+#define REG_DIS_TXREQ_CLR_8723D		0x0523
+#define REG_RD_CTRL_8723D				0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8723D			0x0540
+#define REG_RD_NAV_NXT_8723D			0x0544
+#define REG_NAV_PROT_LEN_8723D			0x0546
+#define REG_BCN_CTRL_8723D				0x0550
+#define REG_BCN_CTRL_1_8723D			0x0551
+#define REG_MBID_NUM_8723D				0x0552
+#define REG_DUAL_TSF_RST_8723D			0x0553
+#define REG_BCN_INTERVAL_8723D			0x0554
+#define REG_DRVERLYINT_8723D			0x0558
+#define REG_BCNDMATIM_8723D			0x0559
+#define REG_ATIMWND_8723D				0x055A
+#define REG_USTIME_TSF_8723D			0x055C
+#define REG_BCN_MAX_ERR_8723D			0x055D
+#define REG_RXTSF_OFFSET_CCK_8723D		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8723D	0x055F
+#define REG_TSFTR_8723D					0x0560
+#define REG_CTWND_8723D					0x0572
+#define REG_SECONDARY_CCA_CTRL_8723D	0x0577
+#define REG_PSTIMER_8723D				0x0580
+#define REG_TIMER0_8723D				0x0584
+#define REG_TIMER1_8723D				0x0588
+#define REG_ACMHWCTRL_8723D			0x05C0
+#define REG_SCH_TXCMD_8723D			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8723D				0x0600
+#define REG_TCR_8723D					0x0604
+#define REG_RCR_8723D					0x0608
+#define REG_RX_PKT_LIMIT_8723D			0x060C
+#define REG_RX_DLK_TIME_8723D			0x060D
+#define REG_RX_DRVINFO_SZ_8723D		0x060F
+
+#define REG_MACID_8723D					0x0610
+#define REG_BSSID_8723D					0x0618
+#define REG_MAR_8723D					0x0620
+#define REG_MBIDCAMCFG_8723D			0x0628
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_USTIME_EDCA_8723D			0x0638
+#define REG_MAC_SPEC_SIFS_8723D		0x063A
+#define REG_RESP_SIFP_CCK_8723D			0x063C
+#define REG_RESP_SIFS_OFDM_8723D		0x063E
+#define REG_ACKTO_8723D					0x0640
+#define REG_CTS2TO_8723D				0x0641
+#define REG_EIFS_8723D					0x0642
+
+#define REG_NAV_UPPER_8723D			0x0652	/* unit of 128 */
+#define REG_TRXPTCL_CTL_8723D			0x0668
+
+/* Security */
+#define REG_CAMCMD_8723D				0x0670
+#define REG_CAMWRITE_8723D				0x0674
+#define REG_CAMREAD_8723D				0x0678
+#define REG_CAMDBG_8723D				0x067C
+#define REG_SECCFG_8723D				0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8723D				0x0690
+#define REG_PS_RX_INFO_8723D			0x0692
+#define REG_UAPSD_TID_8723D				0x0693
+#define REG_WKFMCAM_CMD_8723D			0x0698
+#define REG_WKFMCAM_NUM_8723D			0x0698
+#define REG_WKFMCAM_RWD_8723D			0x069C
+#define REG_RXFLTMAP0_8723D				0x06A0
+#define REG_RXFLTMAP1_8723D				0x06A2
+#define REG_RXFLTMAP2_8723D				0x06A4
+#define REG_BCN_PSR_RPT_8723D			0x06A8
+#define REG_BT_COEX_TABLE_8723D		0x06C0
+#define REG_BFMER0_INFO_8723D			0x06E4
+#define REG_BFMER1_INFO_8723D			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8723D	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8723D	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8723D	0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8723D				0x0700
+#define REG_BSSID1_8723D				0x0708
+#define REG_BFMEE_SEL_8723D				0x0714
+#define REG_SND_PTCL_CTRL_8723D		0x0718
+
+/* LTR */
+#define REG_LTR_CTRL_BASIC_8723D		0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8723D		0x0798
+#define REG_LTR_ACTIVE_LATENCY_V1_8723D		0x079C
+
+/* LTE_COEX */
+#define REG_LTECOEX_CTRL			0x07C0
+#define REG_LTECOEX_WRITE_DATA		0x07C4
+#define REG_LTECOEX_READ_DATA		0x07C8
+#define REG_LTECOEX_PATH_CONTROL	0x70
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HCPWM1_8723D	0x025 /* HCI Current Power Mode 1 */
+
+
+/* ****************************************************************************
+ *	8723 Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* 2 HSISR
+ * 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)
+
+#ifdef CONFIG_RF_POWER_TRIM
+	#ifdef CONFIG_RTL8723D
+		#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#endif
+
+	#define EEPROM_RF_GAIN_VAL				0x1F6
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_8723D|IMR_RDU_8723D|IMR_RXFOVW_8723D) */
+	#define IMR_TX_MASK			(IMR_VODOK_8723D | IMR_VIDOK_8723D | IMR_BEDOK_8723D | IMR_BKDOK_8723D | IMR_MGNTDOK_8723D | IMR_HIGHDOK_8723D)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8723D | IMR_TXBCN0OK_8723D | IMR_TXBCN0ERR_8723D | IMR_BCNDERR0_8723D)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8723D | IMR_VODOK_8723D | IMR_BEDOK_8723D | IMR_BKDOK_8723D)
+#endif
+
+#endif /* __RTL8723D_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_sreset.h
new file mode 100644
index 000000000000..db75dba73e32
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8723D_SRESET_H_
+#define _RTL8723D_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8723d_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8723d_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_xmit.h
new file mode 100644
index 000000000000..b825c83a45f4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8723d_xmit.h
@@ -0,0 +1,519 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_XMIT_H__
+#define __RTL8723D_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8723DDESC_H
+#define __INC_HAL8723DDESC_H
+
+#define RX_STATUS_DESC_SIZE_8723D		24
+#define RX_DRV_INFO_SIZE_UNIT_8723D 8
+
+
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8723D(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8723D(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8723D(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_EOR_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_AMSDU_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_IPVER_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_IS_TCPUDP__8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_CHK_VLD_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+#define GET_RX_STATUS_DESC_FCS_OK_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#ifdef CONFIG_USB_RX_AGGREGATION
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+#endif
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_MATCH_ID_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 7)
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+#define SET_RX_STATUS_DESC_BUFF_ADDR_8723D(__pRxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+/* Dword 0, rsvd: bit26, bit28 */
+#define GET_TX_DESC_OWN_8723D(__pTxDesc)\
+	LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+#define SET_TX_DESC_PKT_SIZE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_AMSDU_PAD_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+
+/* Dword 2  remove P_AID, G_ID field*/
+#define SET_TX_DESC_CCA_RTS_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL0_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL1_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_CCX_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_INT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_FTM_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 30, 1, __Value)
+
+/* Dword 3 */
+#define SET_TX_DESC_HWSEQ_SEL_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_PORT_ID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 2, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TX_TRY_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_STBC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_RTS_STBC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_PATH_A_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 1, __Value)
+#define SET_TX_DESC_TXPWR_OF_SET_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_RF_SEL_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#define SET_TX_DESC_TX_BUFFER_SIZE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#elif(DEV_BUS_TYPE == RT_USB_INTERFACE)
+#define SET_TX_DESC_TX_DESC_CHECKSUM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#else
+#define SET_TX_DESC_TX_TIMESTAMP_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 6, 18, __Value)
+#endif
+
+#define SET_TX_DESC_USB_TXAGG_NUM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+/* Dword 8 */
+#define SET_TX_DESC_RTS_RC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_HWSEQ_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#define SET_TX_DESC_NEXTHEADPAGE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#define SET_TX_DESC_TAILPAGE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LEN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_SEQ_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_FINAL_DATA_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 8, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+#define SET_EARLYMODE_LEN3_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+
+/*-----------------------------------------------------------------*/
+/*	RTL8723D TX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+8, 0, 32, __Valeu)
+#else
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu)	/* 64 BIT mode only */
+#endif
+/* ********************************************************* */
+
+/* 64 bits  -- 32 bits */
+/* =======     ======= */
+/* Dword 0     0 */
+#define SET_TX_BUFF_DESC_LEN_0_8723D(__pTxDesc, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 14, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_8723D(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_8723D(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1     1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_8723D(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_LOW_0_8723D(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+/* Dword 2     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 0, __Value)
+#ifdef CONFIG_64BIT_DMA
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8723D(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+8, 0, 32)
+#else
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8723D(__pTxDesc) 0
+#endif
+/* Dword 3     NA */
+/* RESERVED 0 */
+/* Dword 4     2 */
+#define SET_TX_BUFF_DESC_LEN_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 1, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 5     3 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 6     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 7     NA */
+/*RESERVED 0 */
+/* Dword 8     4 */
+#define SET_TX_BUFF_DESC_LEN_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 2, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 9     5 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 10    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 11    NA */
+/*RESERVED 0 */
+/* Dword 12    6 */
+#define SET_TX_BUFF_DESC_LEN_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 3, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 13    7 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 14    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 15    NA */
+/*RESERVED 0 */
+
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8723D_RATE1M				0x00
+#define DESC8723D_RATE2M				0x01
+#define DESC8723D_RATE5_5M				0x02
+#define DESC8723D_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8723D_RATE6M				0x04
+#define DESC8723D_RATE9M				0x05
+#define DESC8723D_RATE12M				0x06
+#define DESC8723D_RATE18M				0x07
+#define DESC8723D_RATE24M				0x08
+#define DESC8723D_RATE36M				0x09
+#define DESC8723D_RATE48M				0x0a
+#define DESC8723D_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8723D_RATEMCS0				0x0c
+#define DESC8723D_RATEMCS1				0x0d
+#define DESC8723D_RATEMCS2				0x0e
+#define DESC8723D_RATEMCS3				0x0f
+#define DESC8723D_RATEMCS4				0x10
+#define DESC8723D_RATEMCS5				0x11
+#define DESC8723D_RATEMCS6				0x12
+#define DESC8723D_RATEMCS7				0x13
+#define DESC8723D_RATEMCS8				0x14
+#define DESC8723D_RATEMCS9				0x15
+#define DESC8723D_RATEMCS10		0x16
+#define DESC8723D_RATEMCS11		0x17
+#define DESC8723D_RATEMCS12		0x18
+#define DESC8723D_RATEMCS13		0x19
+#define DESC8723D_RATEMCS14		0x1a
+#define DESC8723D_RATEMCS15		0x1b
+#define DESC8723D_RATEVHTSS1MCS0		0x2c
+#define DESC8723D_RATEVHTSS1MCS1		0x2d
+#define DESC8723D_RATEVHTSS1MCS2		0x2e
+#define DESC8723D_RATEVHTSS1MCS3		0x2f
+#define DESC8723D_RATEVHTSS1MCS4		0x30
+#define DESC8723D_RATEVHTSS1MCS5		0x31
+#define DESC8723D_RATEVHTSS1MCS6		0x32
+#define DESC8723D_RATEVHTSS1MCS7		0x33
+#define DESC8723D_RATEVHTSS1MCS8		0x34
+#define DESC8723D_RATEVHTSS1MCS9		0x35
+#define DESC8723D_RATEVHTSS2MCS0		0x36
+#define DESC8723D_RATEVHTSS2MCS1		0x37
+#define DESC8723D_RATEVHTSS2MCS2		0x38
+#define DESC8723D_RATEVHTSS2MCS3		0x39
+#define DESC8723D_RATEVHTSS2MCS4		0x3a
+#define DESC8723D_RATEVHTSS2MCS5		0x3b
+#define DESC8723D_RATEVHTSS2MCS6		0x3c
+#define DESC8723D_RATEVHTSS2MCS7		0x3d
+#define DESC8723D_RATEVHTSS2MCS8		0x3e
+#define DESC8723D_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8723D(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE11M)
+
+#ifdef CONFIG_TRX_BD_ARCH
+	struct tx_desc;
+#endif
+
+void rtl8723d_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+void rtl8723d_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8723d_fill_txdesc_sectype(struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8723d_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8723d_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8723d_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723ds_init_xmit_priv(PADAPTER padapter);
+	void rtl8723ds_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723ds_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723ds_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723ds_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723ds_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8723ds_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8723ds_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8723du_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8723du_xmit_buf_handler
+	s32 rtl8723du_init_xmit_priv(PADAPTER padapter);
+	void rtl8723du_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723du_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723du_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8723du_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8723du_xmit_tasklet(void *priv);
+	s32 rtl8723du_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723de_init_xmit_priv(PADAPTER padapter);
+	void rtl8723de_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8723de_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void	rtl8723de_xmitframe_resume(_adapter *padapter);
+	s32 rtl8723de_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723de_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723de_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8723de_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8723D(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8723D(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_cmd.h
new file mode 100644
index 000000000000..17dd2dd939af
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_cmd.h
@@ -0,0 +1,159 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_CMD_H__
+#define __RTL8812A_CMD_H__
+
+typedef enum _RTL8812_H2C_CMD {
+	H2C_8812_RSVDPAGE = 0,
+	H2C_8812_MSRRPT = 1,
+	H2C_8812_SCAN = 2,
+	H2C_8812_KEEP_ALIVE_CTRL = 3,
+	H2C_8812_DISCONNECT_DECISION = 4,
+
+	H2C_8812_INIT_OFFLOAD = 6,
+	H2C_8812_AP_OFFLOAD = 8,
+	H2C_8812_BCN_RSVDPAGE = 9,
+	H2C_8812_PROBERSP_RSVDPAGE = 10,
+
+	H2C_8812_SETPWRMODE = 0x20,
+	H2C_8812_PS_TUNING_PARA = 0x21,
+	H2C_8812_PS_TUNING_PARA2 = 0x22,
+	H2C_8812_PS_LPS_PARA = 0x23,
+	H2C_8812_P2P_PS_OFFLOAD = 0x24,
+	H2C_8812_INACTIVE_PS = 0x27,
+	H2C_8812_RA_MASK = 0x40,
+	H2C_8812_TxBF = 0x41,
+	H2C_8812_RSSI_REPORT = 0x42,
+	H2C_8812_IQ_CALIBRATION = 0x45,
+	H2C_8812_RA_PARA_ADJUST = 0x46,
+
+	H2C_8812_BT_FW_PATCH = 0x6a,
+
+	H2C_8812_WO_WLAN = 0x80,
+	H2C_8812_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8812_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8812_AOAC_RSVDPAGE = 0x83,
+	H2C_8812_FW_SWCHANNL = 0x87,
+
+	H2C_8812_TSF_RESET = 0xC0,
+
+	MAX_8812_H2CCMD
+} RTL8812_H2C_CMD;
+
+struct cmd_msg_parm {
+	u8 eid; /* element id */
+	u8 sz; /* sz */
+	u8 buf[6];
+};
+
+enum {
+	PWRS
+};
+
+struct H2C_SS_RFOFF_PARAM {
+	u8 ROFOn; /* 1: on, 0:off */
+	u16 gpio_period; /* unit: 1024 us */
+} __attribute__((packed));
+
+
+
+/* _RSVDPAGE_LOC_CMD0 */
+#define SET_8812_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8812_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8812_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8812_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8812_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _SETPWRMODE_PARM */
+#define SET_8812_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+#define GET_8812_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)							LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _P2P_PS_OFFLOAD */
+#define SET_8812_H2CCMD_P2P_PS_OFFLOAD_ENABLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8812_H2CCMD_P2P_PS_OFFLOAD_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8812_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8812_H2CCMD_P2P_PS_OFFLOAD_NOA0_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_8812_H2CCMD_P2P_PS_OFFLOAD_NOA1_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_8812_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
+#define SET_8812_H2CCMD_P2P_PS_OFFLOAD_DISCOVERY(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
+
+
+void	set_ra_ldpc_8812(struct cmn_sta_info *cmn_sta_info, BOOLEAN bLDPC);
+
+/* host message to firmware cmd */
+s32 fill_h2c_cmd_8812(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+void rtl8812_set_FwPwrMode_cmd(PADAPTER padapter, u8 PSMode);
+void rtl8812_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
+u8 rtl8812_set_rssi_cmd(PADAPTER padapter, u8 *param);
+void rtl8812_set_wowlan_cmd(_adapter *padapter, u8 enable);
+u8 GetTxBufferRsvdPageNum8812(_adapter *padapter, bool wowlan);
+
+#ifdef CONFIG_BT_COEXIST
+void rtl8812a_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P_PS
+void rtl8812_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_FWLPS_IN_IPS
+void rtl8812_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
+#endif
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8812_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
+
+/* ------------------------------------
+ * C2H format
+ * ------------------------------------ */
+
+/* TX Beamforming */
+#define GET_8812_C2H_TXBF_ORIGINATE(_Header)			LE_BITS_TO_1BYTE(_Header, 0, 8)
+#define GET_8812_C2H_TXBF_MACID(_Header)				LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
+
+
+
+/* / TX Feedback Content */
+#define	USEC_UNIT_FOR_8812_C2H_TX_RPT_QUEUE_TIME			256
+
+#define	GET_8812_C2H_TX_RPT_QUEUE_SELECT(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 5)
+#define	GET_8812_C2H_TX_RPT_PKT_BROCAST(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 5, 1)
+#define	GET_8812_C2H_TX_RPT_LIFE_TIME_OVER(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 6, 1)
+#define	GET_8812_C2H_TX_RPT_RETRY_OVER(_Header)				LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
+#define	GET_8812_C2H_TX_RPT_MAC_ID(_Header)					LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
+#define	GET_8812_C2H_TX_RPT_DATA_RETRY_CNT(_Header)		LE_BITS_TO_1BYTE((_Header + 2), 0, 6)
+#define	GET_8812_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	/* In unit of 256 microseconds. */
+#define	GET_8812_C2H_TX_RPT_FINAL_DATA_RATE(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
+
+/* BT_FW_PATCH */
+#define SET_8812_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8812_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8812_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8812_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8812_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+5, 0, 8, __Value)
+
+s32 c2h_handler_8812a(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+
+#endif/* __RTL8812A_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_dm.h
new file mode 100644
index 000000000000..584f6d342deb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_dm.h
@@ -0,0 +1,27 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_DM_H__
+#define __RTL8812A_DM_H__
+
+void rtl8812_init_dm_priv(IN PADAPTER Adapter);
+void rtl8812_deinit_dm_priv(IN PADAPTER Adapter);
+void rtl8812_InitHalDm(IN PADAPTER Adapter);
+void rtl8812_HalDmWatchDog(IN PADAPTER Adapter);
+
+/* VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter); */
+
+/* void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal); */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_hal.h
new file mode 100644
index 000000000000..77ffe4b4c3a6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_hal.h
@@ -0,0 +1,369 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_HAL_H__
+#define __RTL8812A_HAL_H__
+
+/* #include "hal_com.h" */
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8812a_spec.h"
+#include "rtl8812a_rf.h"
+#include "rtl8812a_dm.h"
+#include "rtl8812a_recv.h"
+#include "rtl8812a_xmit.h"
+#include "rtl8812a_cmd.h"
+#include "rtl8812a_led.h"
+#include "Hal8812PwrSeq.h"
+#include "Hal8821APwrSeq.h" /* for 8821A/8811A */
+#include "Hal8812PhyReg.h"
+#include "Hal8812PhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+#include "rtl8812a_sreset.h"
+#endif
+
+/* ---------------------------------------------------------------------
+ *		RTL8812 Power Configuration CMDs for PCIe interface
+ * --------------------------------------------------------------------- */
+#define Rtl8812_NIC_PWR_ON_FLOW				rtl8812_power_on_flow
+#define Rtl8812_NIC_RF_OFF_FLOW				rtl8812_radio_off_flow
+#define Rtl8812_NIC_DISABLE_FLOW				rtl8812_card_disable_flow
+#define Rtl8812_NIC_ENABLE_FLOW				rtl8812_card_enable_flow
+#define Rtl8812_NIC_SUSPEND_FLOW				rtl8812_suspend_flow
+#define Rtl8812_NIC_RESUME_FLOW				rtl8812_resume_flow
+#define Rtl8812_NIC_PDN_FLOW					rtl8812_hwpdn_flow
+#define Rtl8812_NIC_LPS_ENTER_FLOW			rtl8812_enter_lps_flow
+#define Rtl8812_NIC_LPS_LEAVE_FLOW				rtl8812_leave_lps_flow
+
+/* ---------------------------------------------------------------------
+ *		RTL8821 Power Configuration CMDs for PCIe interface
+ * --------------------------------------------------------------------- */
+#define Rtl8821A_NIC_PWR_ON_FLOW				rtl8821A_power_on_flow
+#define Rtl8821A_NIC_RF_OFF_FLOW				rtl8821A_radio_off_flow
+#define Rtl8821A_NIC_DISABLE_FLOW				rtl8821A_card_disable_flow
+#define Rtl8821A_NIC_ENABLE_FLOW				rtl8821A_card_enable_flow
+#define Rtl8821A_NIC_SUSPEND_FLOW				rtl8821A_suspend_flow
+#define Rtl8821A_NIC_RESUME_FLOW				rtl8821A_resume_flow
+#define Rtl8821A_NIC_PDN_FLOW					rtl8821A_hwpdn_flow
+#define Rtl8821A_NIC_LPS_ENTER_FLOW			rtl8821A_enter_lps_flow
+#define Rtl8821A_NIC_LPS_LEAVE_FLOW			rtl8821A_leave_lps_flow
+
+
+#if 1 /* download firmware related data structure */
+#define FW_SIZE_8812			0x8000 /* Compatible with RTL8723 Maximal RAM code size 24K.   modified to 32k, TO compatible with 92d maximal fw size 32k */
+#define FW_START_ADDRESS		0x1000
+#define FW_END_ADDRESS		0x5FFF
+
+
+
+typedef struct _RT_FIRMWARE_8812 {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_SIZE_8812];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8812, *PRT_FIRMWARE_8812;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+#define IS_FW_HEADER_EXIST_8812(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8812(_pFwHdr) & 0xFFF0) == 0x9500)
+
+#define IS_FW_HEADER_EXIST_8821(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8812(_pFwHdr) & 0xFFF0) == 0x2100)
+/* *****************************************************
+ *					Firmware Header(8-byte alinment required)
+ * *****************************************************
+ * --- LONG WORD 0 ---- */
+#define GET_FIRMWARE_HDR_SIGNATURE_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16) /* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut */
+#define GET_FIRMWARE_HDR_CATEGORY_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) /* AP/NIC and USB/PCI */
+#define GET_FIRMWARE_HDR_FUNCTION_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 24, 8) /* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions */
+#define GET_FIRMWARE_HDR_VERSION_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)/* FW Version */
+#define GET_FIRMWARE_HDR_SUB_VER_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) /* FW Subversion, default 0x00 */
+#define GET_FIRMWARE_HDR_RSVD1_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8)
+
+/* --- LONG WORD 1 ---- */
+#define GET_FIRMWARE_HDR_MONTH_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 8) /* Release time Month field */
+#define GET_FIRMWARE_HDR_DATE_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 8, 8) /* Release time Date field */
+#define GET_FIRMWARE_HDR_HOUR_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 16, 8)/* Release time Hour field */
+#define GET_FIRMWARE_HDR_MINUTE_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+8, 24, 8)/* Release time Minute field */
+#define GET_FIRMWARE_HDR_ROMCODE_SIZE_8812(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+12, 0, 16)/* The size of RAM code */
+#define GET_FIRMWARE_HDR_RSVD2_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 16, 16)
+
+/* --- LONG WORD 2 ---- */
+#define GET_FIRMWARE_HDR_SVN_IDX_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+16, 0, 32)/* The SVN entry index */
+#define GET_FIRMWARE_HDR_RSVD3_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 0, 32)
+
+/* --- LONG WORD 3 ---- */
+#define GET_FIRMWARE_HDR_RSVD4_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 0, 32)
+#define GET_FIRMWARE_HDR_RSVD5_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
+
+#endif /* download firmware related data structure */
+
+
+#define DRIVER_EARLY_INT_TIME_8812		0x05
+#define BCN_DMA_ATIME_INT_TIME_8812		0x02
+
+/* for 8812
+ * TX 128K, RX 16K, Page size 512B for TX, 128B for RX */
+#define MAX_RX_DMA_BUFFER_SIZE_8812	0x3E80 /* RX 16K */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8812	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8812	0x0	/* 0B */
+#endif
+#define RX_DMA_BOUNDARY_8812		(MAX_RX_DMA_BUFFER_SIZE_8812 - RX_DMA_RESERVED_SIZE_8812 - 1)
+
+#define BCNQ_PAGE_NUM_8812		0x07
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, AOAC rpt: 1,PNO: 6
+ * NS offload: 1 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8812	0x08
+#else
+	#define WOWLAN_PAGE_NUM_8812	0x00
+#endif
+
+
+#ifdef CONFIG_BEAMFORMER_FW_NDPA
+	#define FW_NDPA_PAGE_NUM	0x02
+#else
+	#define FW_NDPA_PAGE_NUM	0x00
+#endif
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	#define FW_DBG_MSG_PKT_PAGE_NUM_8812	0x01
+#else
+	#define FW_DBG_MSG_PKT_PAGE_NUM_8812	0x00
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+#define TX_TOTAL_PAGE_NUMBER_8812	(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812 - FW_NDPA_PAGE_NUM - FW_DBG_MSG_PKT_PAGE_NUM_8812)
+#define TX_PAGE_BOUNDARY_8812			(TX_TOTAL_PAGE_NUMBER_8812 + 1)
+
+#define TX_PAGE_BOUNDARY_WOWLAN_8812		(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812 + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8812	TX_TOTAL_PAGE_NUMBER_8812
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8812		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8812 + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8812 */
+#define NORMAL_PAGE_NUM_LPQ_8812				0x10
+#define NORMAL_PAGE_NUM_HPQ_8812			0x10
+#define NORMAL_PAGE_NUM_NPQ_8812			0x00
+
+#define WMM_NORMAL_PAGE_NUM_HPQ_8812		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8812		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8812		0x20
+
+
+/* for 8821A
+ * TX 64K, RX 16K, Page size 256B for TX, 128B for RX */
+#define PAGE_SIZE_TX_8821A					256
+#define PAGE_SIZE_RX_8821A					128
+
+#define MAX_RX_DMA_BUFFER_SIZE_8821			0x3E80 /* RX 16K */
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8821	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8821	0x0	/* 0B */
+#endif
+#define RX_DMA_BOUNDARY_8821		(MAX_RX_DMA_BUFFER_SIZE_8821 - RX_DMA_RESERVED_SIZE_8821 - 1)
+
+#define BCNQ_PAGE_NUM_8821		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8821		0x04
+#else
+	#define BCNQ1_PAGE_NUM_8821		0x00
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, PNO: 6 */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8821	0x06
+#else
+	#define WOWLAN_PAGE_NUM_8821	0x00
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8821	(0xFF - BCNQ_PAGE_NUM_8821 - BCNQ1_PAGE_NUM_8821 - WOWLAN_PAGE_NUM_8821)
+#define TX_PAGE_BOUNDARY_8821				(TX_TOTAL_PAGE_NUMBER_8821 + 1)
+/* #define TX_PAGE_BOUNDARY_WOWLAN_8821		0xE0 */
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8821	TX_TOTAL_PAGE_NUMBER_8821
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8821		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8821 + 1)
+
+
+/* (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER */
+#define NORMAL_PAGE_NUM_LPQ_8821			0x08/* 0x10 */
+#define NORMAL_PAGE_NUM_HPQ_8821		0x08/* 0x10 */
+#define NORMAL_PAGE_NUM_NPQ_8821		0x00
+#define NORMAL_PAGE_NUM_EPQ_8821			0x04
+
+#define WMM_NORMAL_PAGE_NUM_HPQ_8821		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8821		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8821		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8821		0x00
+
+#define MCC_NORMAL_PAGE_NUM_HPQ_8821		0x10
+#define MCC_NORMAL_PAGE_NUM_LPQ_8821		0x10
+#define MCC_NORMAL_PAGE_NUM_NPQ_8821		0x10
+
+#define	EFUSE_HIDDEN_812AU					0
+#define	EFUSE_HIDDEN_812AU_VS				1
+#define	EFUSE_HIDDEN_812AU_VL				2
+#define	EFUSE_HIDDEN_812AU_VN				3
+
+#if 0
+#define EFUSE_REAL_CONTENT_LEN_JAGUAR		1024
+#define HWSET_MAX_SIZE_JAGUAR					1024
+#else
+#define EFUSE_REAL_CONTENT_LEN_JAGUAR		512
+#define HWSET_MAX_SIZE_JAGUAR					512
+#endif
+
+#define EFUSE_MAX_BANK_8812A					2
+#define EFUSE_MAP_LEN_JAGUAR					512
+#define EFUSE_MAX_SECTION_JAGUAR				64
+#define EFUSE_MAX_WORD_UNIT_JAGUAR			4
+#define EFUSE_IC_ID_OFFSET_JAGUAR				506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define AVAILABLE_EFUSE_ADDR_8812(addr)	(addr < EFUSE_REAL_CONTENT_LEN_JAGUAR)
+/* <Roger_Notes> To prevent out of boundary programming case, leave 1byte and program full section
+ * 9bytes + 1byt + 5bytes and pre 1byte.
+ * For worst case:
+ * | 2byte|----8bytes----|1byte|--7bytes--|  */ /* 92D */
+#define EFUSE_OOB_PROTECT_BYTES_JAGUAR		18	/* PG data exclude header, dummy 7 bytes frome CP test and reserved 1byte. */
+#define EFUSE_PROTECT_BYTES_BANK_JAGUAR		16
+
+#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)
+
+/* #define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE) */
+
+/* #define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) ) */
+#define HAL_EFUSE_MEMORY
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define BANK_NUM			2
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	512
+#define EFUSE_BT_REAL_CONTENT_LEN	\
+	(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN		1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION		(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK	16
+
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_BT_REAL_CONTENT_LEN)
+
+#ifdef CONFIG_FILE_FWIMG
+extern char *rtw_fw_file_path;
+#ifdef CONFIG_WOWLAN
+extern char *rtw_fw_wow_file_path;
+#endif
+#ifdef CONFIG_MP_INCLUDED
+extern char *rtw_fw_mp_bt_file_path;
+#endif
+#endif
+
+
+/* rtl8812_hal_init.c */
+void	_8051Reset8812(PADAPTER padapter);
+s32	FirmwareDownload8812(PADAPTER Adapter, BOOLEAN bUsedWoWLANFw);
+void	InitializeFirmwareVars8812(PADAPTER padapter);
+
+s32	_LLTWrite_8812A(PADAPTER Adapter, u32 address, u32 data);
+s32	InitLLTTable8812A(PADAPTER padapter, u8 txpktbuf_bndy);
+void InitRDGSetting8812A(PADAPTER padapter);
+
+void CheckAutoloadState8812A(PADAPTER padapter);
+
+/* EFuse */
+u8	GetEEPROMSize8812A(PADAPTER padapter);
+void InitPGData8812A(PADAPTER padapter);
+void	Hal_EfuseParseIDCode8812A(PADAPTER padapter, u8 *hwinfo);
+void	Hal_ReadPROMVersion8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadTxPowerInfo8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+void	Hal_ReadBoardType8812A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadThermalMeter_8812A(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void	Hal_ReadChannelPlan8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_EfuseParseXtal_8812A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadAntennaDiversity8812A(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void	Hal_ReadAmplifierType_8812A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadPAType_8821A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadRFEType_8812A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_EfuseParseBTCoexistInfo8812A(PADAPTER Adapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadUsbType_8812AU(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+#ifdef CONFIG_MP_INCLUDED
+int	FirmwareDownloadBT(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void	Hal_ReadRemoteWakeup_8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+BOOLEAN HalDetectPwrDownMode8812(PADAPTER Adapter);
+void Hal_EfuseParseKFreeData_8821A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+
+#ifdef CONFIG_WOWLAN
+void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void _InitBeaconParameters_8812A(PADAPTER padapter);
+void SetBeaconRelatedRegisters8812A(PADAPTER padapter);
+
+void ReadRFType8812A(PADAPTER padapter);
+void InitDefaultValue8821A(PADAPTER padapter);
+
+u8 SetHwReg8812A(PADAPTER padapter, u8 variable, u8 *pval);
+void GetHwReg8812A(PADAPTER padapter, u8 variable, u8 *pval);
+u8 SetHalDefVar8812A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8812A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+void rtl8812_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8812a(_adapter *adapter);
+void init_hal_spec_8821a(_adapter *adapter);
+
+u32 upload_txpktbuf_8812au(_adapter *adapter, u8 *buf, u32 buflen);
+
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+
+void rtl8812_start_thread(PADAPTER padapter);
+void rtl8812_stop_thread(PADAPTER padapter);
+
+#ifdef CONFIG_PCI_HCI
+BOOLEAN	InterruptRecognized8812AE(PADAPTER Adapter);
+VOID	UpdateInterruptMask8812AE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+VOID	InitTRXDescHwAddress8812AE(PADAPTER Adapter);
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+void rtl8812a_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
+#endif
+
+VOID
+Hal_PatchwithJaguar_8812(
+	IN PADAPTER				Adapter,
+	IN RT_MEDIA_STATUS		MediaStatus
+);
+
+#endif /* __RTL8188E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_led.h
new file mode 100644
index 000000000000..30c676e526f3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_led.h
@@ -0,0 +1,41 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_LED_H__
+#define __RTL8812A_LED_H__
+#ifdef CONFIG_RTW_LED
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+void rtl8812au_InitSwLeds(PADAPTER padapter);
+void rtl8812au_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+void rtl8812ae_InitSwLeds(PADAPTER padapter);
+void rtl8812ae_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+void rtl8821as_InitSwLeds(PADAPTER padapter);
+void rtl8821as_DeInitSwLeds(PADAPTER padapter);
+#endif
+#endif/*CONFIG_RTW_SW_LED*/
+#endif/*#ifdef CONFIG_RTW_LED*/
+
+#ifdef CONFIG_SDIO_HCI
+void rtl8821as_init_led_circuit(PADAPTER adapter);
+#endif
+
+#endif /*__RTL8812A_LED_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_recv.h
new file mode 100644
index 000000000000..bf1d4b651ea1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_recv.h
@@ -0,0 +1,153 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_RECV_H__
+#define __RTL8812A_RECV_H__
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+					#define MAX_RECVBUF_SZ (rtw_rtkm_get_buff_size()) /*depend rtkm*/
+				#else
+					#define MAX_RECVBUF_SZ (32768)  /*32k*/
+				#endif
+				/* #define MAX_RECVBUF_SZ (24576) */ /* 24k */
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (15360) */ /* 15k < 16k */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+				#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+					#undef MAX_RECVBUF_SZ
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI)
+
+	#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8821 + 1)
+
+#endif
+
+
+/* Rx smooth factor */
+#define Rx_Smooth_Factor (20)
+
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8812(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_LAST_SEG_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+#define GET_RX_STATUS_DESC_FIRST_SEG_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+#define GET_RX_STATUS_DESC_EOR_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8812(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_8812(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_AMSDU_8812(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_IPVER_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_IS_TCPUDP__8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_CHK_VLD_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8812(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#ifdef CONFIG_USB_RX_AGGREGATION
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8812(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+#endif
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_SPLCP_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+#define GET_RX_STATUS_DESC_LDPC_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+#define GET_RX_STATUS_DESC_STBC_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+#define GET_RX_STATUS_DESC_BW_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+#define SET_RX_STATUS_DESC_BUFF_ADDR_8812(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+#ifdef CONFIG_SDIO_HCI
+s32 InitRecvPriv8821AS(PADAPTER padapter);
+void FreeRecvPriv8821AS(PADAPTER padapter);
+#endif /* CONFIG_SDIO_HCI */
+
+#ifdef CONFIG_USB_HCI
+void rtl8812au_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+s32 rtl8812au_init_recv_priv(PADAPTER padapter);
+void rtl8812au_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8812ae_init_recv_priv(PADAPTER padapter);
+void rtl8812ae_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8812_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8812A_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_rf.h
new file mode 100644
index 000000000000..9a7b60e6138c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_rf.h
@@ -0,0 +1,28 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_RF_H__
+#define __RTL8812A_RF_H__
+
+VOID
+PHY_RF6052SetBandwidth8812(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
+
+
+int
+PHY_RF6052_Config_8812(
+	IN	PADAPTER	Adapter);
+
+#endif/* __RTL8188E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_spec.h
new file mode 100644
index 000000000000..37ba2472296c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_spec.h
@@ -0,0 +1,263 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_SPEC_H__
+#define __RTL8812A_SPEC_H__
+
+#include <drv_conf.h>
+
+
+/* ************************************************************
+* 8812 Regsiter offset definition
+* ************************************************************ */
+
+/* ************************************************************
+*
+* ************************************************************ */
+
+/* -----------------------------------------------------
+*
+*	0x0000h ~ 0x00FFh	System Configuration
+*
+* ----------------------------------------------------- */
+#define REG_SYS_CLKR_8812A				0x0008
+#define REG_AFE_PLL_CTRL_8812A		0x0028
+#define REG_HSIMR_8812					0x0058
+#define REG_HSISR_8812					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_GPIO_STATUS_8812			0x006C
+#define REG_SDIO_CTRL_8812				0x0070
+#define REG_OPT_CTRL_8812				0x0074
+#define REG_RF_B_CTRL_8812				0x0076
+#define REG_FW_DRV_MSG_8812			0x0088
+#define REG_HMEBOX_E2_E3_8812			0x008C
+#define REG_HIMR0_8812					0x00B0
+#define REG_HISR0_8812					0x00B4
+#define REG_HIMR1_8812					0x00B8
+#define REG_HISR1_8812					0x00BC
+#define REG_EFUSE_BURN_GNT_8812		0x00CF
+#define REG_SYS_CFG1_8812				0x00FC
+
+/* -----------------------------------------------------
+*
+*	0x0100h ~ 0x01FFh	MACTOP General Configuration
+*
+* ----------------------------------------------------- */
+#define REG_CR_8812A					0x100
+#define REG_PKTBUF_DBG_ADDR			(REG_PKTBUF_DBG_CTRL)
+#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
+#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
+#define REG_WOWLAN_WAKE_REASON			REG_MCUTST_WOWLAN
+
+#define REG_RSVD3_8812					0x0168
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_88XX		0x01AE
+
+#define REG_HMEBOX_EXT0_8812			0x01F0
+#define REG_HMEBOX_EXT1_8812			0x01F4
+#define REG_HMEBOX_EXT2_8812			0x01F8
+#define REG_HMEBOX_EXT3_8812			0x01FC
+
+/* -----------------------------------------------------
+*
+*	0x0200h ~ 0x027Fh	TXDMA Configuration
+*
+* ----------------------------------------------------- */
+#define REG_DWBCN0_CTRL_8812				REG_TDECTRL
+#define REG_DWBCN1_CTRL_8812				0x0228
+
+/* -----------------------------------------------------
+*
+*	0x0280h ~ 0x02FFh	RXDMA Configuration
+*
+* ----------------------------------------------------- */
+#define REG_TDECTRL_8812A				0x0208
+#define REG_RXDMA_CONTROL_8812A		0x0286		/*Control the RX DMA.*/
+#define REG_RXDMA_PRO_8812			0x0290
+#define REG_EARLY_MODE_CONTROL_8812	0x02BC
+#define REG_RSVD5_8812					0x02F0
+#define REG_RSVD6_8812					0x02F4
+#define REG_RSVD7_8812					0x02F8
+#define REG_RSVD8_8812					0x02FC
+
+
+/* -----------------------------------------------------
+*
+*	0x0300h ~ 0x03FFh	PCIe
+*
+* ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8812A			0x0300
+#define	REG_DBI_WDATA_8812			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8812			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8812			0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8812			0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8812			0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8812			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8812			0x0358	/* MDIO for Control */
+#define REG_PCIE_HRPWM_8812A			0x0361  /* PCIe RPWM */
+#define REG_PCIE_HCPWM_8812A			0x0363  /* PCIe CPWM */
+
+#define	REG_PCIE_MULTIFET_CTRL_8812	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+*
+*	0x0400h ~ 0x047Fh	Protocol Configuration
+*
+* ----------------------------------------------------- */
+#define REG_TXPKT_EMPTY_8812A			0x041A
+#define REG_FWHW_TXQ_CTRL_8812A		0x0420
+#define REG_TXBF_CTRL_8812A			0x042C
+#define REG_ARFR0_8812					0x0444
+#define REG_ARFR1_8812					0x044C
+#define REG_CCK_CHECK_8812				0x0454
+#define REG_AMPDU_MAX_TIME_8812		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8812	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8812	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8812	0x045D
+#define REG_NDPA_OPT_CTRL_8812A		0x045F
+#define REG_DATA_SC_8812				0x0483
+#ifdef CONFIG_WOWLAN
+#define REG_TXPKTBUF_IV_LOW             0x0484
+#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_ARFR2_8812					0x048C
+#define REG_ARFR3_8812					0x0494
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_AMPDU_BURST_MODE_8812	0x04BC
+#define REG_HT_SINGLE_AMPDU_8812		0x04C7
+#define REG_MACID_PKT_DROP0_8812		0x04D0
+
+/* -----------------------------------------------------
+*
+*	0x0500h ~ 0x05FFh	EDCA Configuration
+*
+* ----------------------------------------------------- */
+#define REG_TXPAUSE_8812A				0x0522
+#define REG_CTWND_8812					0x0572
+#define REG_SECONDARY_CCA_CTRL_8812	0x0577
+#define REG_SCH_TXCMD_8812A			0x05F8
+
+/* -----------------------------------------------------
+*
+*	0x0600h ~ 0x07FFh	WMAC Configuration
+*
+* ----------------------------------------------------- */
+#define REG_MAC_CR_8812				0x0600
+
+#define REG_MAC_TX_SM_STATE_8812		0x06B4
+
+/* Power */
+#define REG_BFMER0_INFO_8812A			0x06E4
+#define REG_BFMER1_INFO_8812A			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8812A	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8812A	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8812A	0x06FC
+
+/* Hardware Port 2 */
+#define REG_BFMEE_SEL_8812A			0x0714
+#define REG_SND_PTCL_CTRL_8812A		0x0718
+
+
+/* -----------------------------------------------------
+*
+*	Redifine register definition for compatibility
+*
+* ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+* NOTE: DO NOT Remove these definition. Use later. */
+#define	ISR_8812							REG_HISR0_8812
+
+/* ----------------------------------------------------------------------------
+* 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+* ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8812					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8812					BIT31		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8812					BIT30		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8812				BIT29		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8812					BIT28		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8812					BIT27		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8812				BIT26		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8812					BIT25		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8812		BIT24		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8812				BIT20		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8812					BIT16		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8812		BIT15		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8812				BIT14		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8812					BIT12		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8812					BIT10		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8812					BIT9			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8812						BIT8			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8812					BIT7			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8812					BIT6			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8812					BIT5			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8812					BIT4			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8812					BIT3			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8812					BIT2			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8812						BIT1			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8812						BIT0			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8812				BIT27		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8812				BIT26		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8812				BIT25		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8812				BIT24		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8812				BIT23		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8812				BIT22		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8812				BIT21		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8812					BIT20		/* Beacon Queue DMA OK Interrup 7 */
+#define	IMR_BCNDOK6_8812					BIT19		/* Beacon Queue DMA OK Interrup 6 */
+#define	IMR_BCNDOK5_8812					BIT18		/* Beacon Queue DMA OK Interrup 5 */
+#define	IMR_BCNDOK4_8812					BIT17		/* Beacon Queue DMA OK Interrup 4 */
+#define	IMR_BCNDOK3_8812					BIT16		/* Beacon Queue DMA OK Interrup 3 */
+#define	IMR_BCNDOK2_8812					BIT15		/* Beacon Queue DMA OK Interrup 2 */
+#define	IMR_BCNDOK1_8812					BIT14		/* Beacon Queue DMA OK Interrup 1 */
+#define	IMR_ATIMEND_E_8812				BIT13		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8812					BIT11		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8812					BIT10		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8812					BIT9			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8812					BIT8			/* Receive FIFO Overflow */
+
+
+#ifdef CONFIG_PCI_HCI
+/* #define IMR_RX_MASK		(IMR_ROK_8812|IMR_RDU_8812|IMR_RXFOVW_8812) */
+#define IMR_TX_MASK			(IMR_VODOK_8812 | IMR_VIDOK_8812 | IMR_BEDOK_8812 | IMR_BKDOK_8812 | IMR_MGNTDOK_8812 | IMR_HIGHDOK_8812)
+
+#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8812 | IMR_TXBCN0OK_8812 | IMR_TXBCN0ERR_8812 | IMR_BCNDERR0_8812)
+
+#define RT_AC_INT_MASKS	(IMR_VIDOK_8812 | IMR_VODOK_8812 | IMR_BEDOK_8812 | IMR_BKDOK_8812)
+#endif
+
+
+/* ****************************************************************************
+* Regsiter Bit and Content definition
+* **************************************************************************** */
+
+/* 2 ACMHWCTRL 0x05C0 */
+#define	AcmHw_HwEn_8812				BIT(0)
+#define	AcmHw_VoqEn_8812				BIT(1)
+#define	AcmHw_ViqEn_8812				BIT(2)
+#define	AcmHw_BeqEn_8812				BIT(3)
+#define	AcmHw_VoqStatus_8812			BIT(5)
+#define	AcmHw_ViqStatus_8812			BIT(6)
+#define	AcmHw_BeqStatus_8812			BIT(7)
+
+#endif /* __RTL8812A_SPEC_H__ */
+
+#ifdef CONFIG_RTL8821A
+#include "rtl8821a_spec.h"
+#endif /* CONFIG_RTL8821A */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_sreset.h
new file mode 100644
index 000000000000..d4bbd5867b24
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL88812A_SRESET_H_
+#define _RTL8812A_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+extern void rtl8812_sreset_xmit_status_check(_adapter *padapter);
+extern void rtl8812_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_xmit.h
new file mode 100644
index 000000000000..6105a8e4192d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8812a_xmit.h
@@ -0,0 +1,367 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_XMIT_H__
+#define __RTL8812A_XMIT_H__
+
+
+/* For 88e early mode */
+#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
+#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
+#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
+#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
+#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
+#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
+#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
+
+/*
+ * 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 QSEL_SHT			8
+#define RATE_ID_SHT			16
+#define NAVUSEHDR			BIT(20)
+#define SEC_TYPE_SHT		22
+#define PKT_OFFSET_SHT		26
+
+/* OFFSET 8 */
+#define AGG_EN				BIT(12)
+#define AGG_BK				BIT(16)
+#define AMPDU_DENSITY_SHT	20
+#define ANTSEL_A			BIT(24)
+#define ANTSEL_B			BIT(25)
+#define TX_ANT_CCK_SHT		26
+#define TX_ANTL_SHT			28
+#define TX_ANT_HT_SHT		30
+
+/* OFFSET 12 */
+#define SEQ_SHT				16
+#define EN_HWSEQ			BIT(31)
+
+/* OFFSET 16 */
+#define QOS					BIT(6)
+#define	HW_SSN				BIT(7)
+#define USERATE				BIT(8)
+#define DISDATAFB			BIT(10)
+#define CTS_2_SELF			BIT(11)
+#define	RTS_EN				BIT(12)
+#define	HW_RTS_EN			BIT(13)
+#define DATA_SHORT			BIT(24)
+#define PWR_STATUS_SHT	15
+#define DATA_SC_SHT		20
+#define DATA_BW				BIT(25)
+
+/* OFFSET 20 */
+#define	RTY_LMT_EN			BIT(17)
+
+/* OFFSET 20 */
+#define SGI					BIT(6)
+#define USB_TXAGG_NUM_SHT	24
+
+typedef struct txdescriptor_8812 {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	u32 macid:6;
+	u32 rsvd0406:2;
+	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;
+
+	/* Offset 8 */
+	u32 rts_rc:6;
+	u32 data_rc:6;
+	u32 agg_en:1;
+	u32 rd_en:1;
+	u32 bar_rty_th:2;
+	u32 bk: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;
+
+	/* Offset 12 */
+	u32 nextheadpage:8;
+	u32 tailpage:8;
+	u32 seq:12;
+	u32 cpu_handle:1;
+	u32 tag1:1;
+	u32 trigger_int:1;
+	u32 hwseq_en:1;
+
+	/* Offset 16 */
+	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 pwr_status: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;
+
+	/* Offset 20 */
+	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;
+
+	/* Offset 24 */
+	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;
+
+	/* Offset 28 */
+	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;
+
+	/* Offset 32 */
+	u32 rsvd32;
+
+	/* Offset 36 */
+	u32 rsvd36;
+} TXDESC_8812, *PTXDESC_8812;
+
+
+/* Dword 0 */
+#define GET_TX_DESC_OWN_8812(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+#define SET_TX_DESC_PKT_SIZE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_LAST_SEG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+#define SET_TX_DESC_FIRST_SEG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_LINIP_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+#define SET_TX_DESC_OWN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+
+/* Dword 2 */
+#define SET_TX_DESC_PAID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+#define SET_TX_DESC_CCA_RTS_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_AGG_BREAK_8812(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_SPE_RPT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_INT_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_GID_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+/* Dword 3 */
+#define SET_TX_DESC_WHEADER_LEN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+#define SET_TX_DESC_CHK_EN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+#define SET_TX_DESC_EARLY_MODE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HWSEQ_SEL_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8812(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_CTROL_STBC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_TX_ANT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_ANTSEL_A_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+#define SET_TX_DESC_ANTSEL_B_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+#define SET_TX_DESC_ANTSEL_C_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+#define SET_TX_DESC_ANTSEL_D_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+#define SET_TX_DESC_MBSSID_8821(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+
+/* Dword 7 */
+#define SET_TX_DESC_TX_BUFFER_SIZE_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#define SET_TX_DESC_TX_DESC_CHECKSUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#define SET_TX_DESC_USB_TXAGG_NUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+#ifdef CONFIG_SDIO_HCI
+#define SET_TX_DESC_SDIO_TXSEQ_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+#endif
+
+/* Dword 8 */
+#define SET_TX_DESC_HWSEQ_EN_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_SEQ_8812(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+
+/* Dword 10 */
+#define SET_TX_DESC_TX_BUFFER_ADDRESS_8812(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+#define GET_TX_DESC_TX_BUFFER_ADDRESS_8812(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+
+/* Dword 11 */
+#define SET_TX_DESC_NEXT_DESC_ADDRESS_8812(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
+#define SET_EARLYMODE_LEN3_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+#ifdef CONFIG_TX_EARLY_MODE
+	#define USB_DUMMY_OFFSET		2
+#else
+	#define USB_DUMMY_OFFSET		1
+#endif
+#define USB_DUMMY_LENGTH		(USB_DUMMY_OFFSET * PACKET_OFFSET_SZ)
+
+
+void rtl8812a_cal_txdesc_chksum(u8 *ptxdesc);
+void rtl8812a_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8812a_fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8812a_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8812a_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#ifdef CONFIG_USB_HCI
+s32 rtl8812au_init_xmit_priv(PADAPTER padapter);
+void rtl8812au_free_xmit_priv(PADAPTER padapter);
+s32 rtl8812au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8812au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	 rtl8812au_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+s32 rtl8812au_xmit_buf_handler(PADAPTER padapter);
+void rtl8812au_xmit_tasklet(void *priv);
+s32 rtl8812au_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8812ae_init_xmit_priv(PADAPTER padapter);
+void rtl8812ae_free_xmit_priv(PADAPTER padapter);
+struct xmit_buf *rtl8812ae_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+void	rtl8812ae_xmitframe_resume(_adapter *padapter);
+s32 rtl8812ae_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8812ae_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	rtl8812ae_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+void rtl8812ae_xmit_tasklet(void *priv);
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+s32 rtl8812ae_xmit_buf_handler(_adapter *padapter);
+#endif
+
+#endif
+
+#ifdef CONFIG_TX_EARLY_MODE
+void UpdateEarlyModeInfo8812(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, u8 *ptxdesc);
+
+u8	BWMapping_8812(PADAPTER Adapter, struct pkt_attrib *pattrib);
+
+u8	SCMapping_8812(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif /* __RTL8812_XMIT_H__ */
+
+#ifdef CONFIG_RTL8821A
+#include "rtl8821a_xmit.h"
+#endif /* CONFIG_RTL8821A */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_cmd.h
new file mode 100644
index 000000000000..53c2828ae5e5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_cmd.h
@@ -0,0 +1,164 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_CMD_H__
+#define __RTL8814A_CMD_H__
+#include "hal_com_h2c.h"
+
+/* _RSVDPAGE_LOC_CMD0 */
+#define SET_8814A_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8814A_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8814A_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8814A_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8814A_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _SETPWRMODE_PARM */
+#define SET_8814A_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+#define GET_8814A_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+
+/* _WoWLAN PARAM_CMD5 */
+#define SET_8814A_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_ALL_PKT_DROP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_GPIO_ACTIVE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_REKEY_WAKE_UP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_GPIONUM(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8814A_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+
+
+/* WLANINFO_PARM */
+#define SET_8814A_H2CCMD_WLANINFO_PARM_OPMODE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8814A_H2CCMD_WLANINFO_PARM_CHANNEL(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8814A_H2CCMD_WLANINFO_PARM_BW40MHZ(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+
+/* _REMOTE_WAKEUP_CMD7 */
+#define SET_8814A_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+
+
+/* _AP_OFFLOAD_CMD8 */
+#define SET_8814A_H2CCMD_AP_OFFLOAD_ON(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8814A_H2CCMD_AP_OFFLOAD_HIDDEN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8814A_H2CCMD_AP_OFFLOAD_DENYANY(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8814A_H2CCMD_AP_OFFLOAD_WAKEUP_EVT_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+
+/* _PWR_MOD_CMD20 */
+#define SET_88E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_88E_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_88E_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_88E_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_88E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_88E_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/*	AP_REQ_TXREP_CMD 0x43	*/
+#define SET_8814A_H2CCMD_TXREP_PARM_STA1(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8814A_H2CCMD_TXREP_PARM_STA2(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8814A_H2CCMD_TXREP_PARM_RTY(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
+
+/*		C2H_AP_REQ_TXRPT		*/
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_MACID1(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 8)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXOK1(_Header)			LE_BITS_TO_2BYTE((_Header + 1), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXFAIL1(_Header)			LE_BITS_TO_2BYTE((_Header + 3), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_INIRATE1(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_MACID2(_Header)			LE_BITS_TO_1BYTE((_Header + 6), 0, 8)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXOK2(_Header)			LE_BITS_TO_2BYTE((_Header + 7), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXFAIL2(_Header)			LE_BITS_TO_2BYTE((_Header + 9), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_INIRATE2(_Header)		LE_BITS_TO_1BYTE((_Header + 11), 0, 8)
+
+/*		C2H_SPC_STAT			*/
+#define	GET_8814A_C2H_SPC_STAT_IDX(_Header)						LE_BITS_TO_1BYTE((_Header + 0), 0, 8)
+	/*	Tip :TYPE_A data3 is msb and data0 is lsb	*/
+#define	GET_8814A_C2H_SPC_STAT_TYPEA_RETRY(_Header)				LE_BITS_TO_4BYTE((_Header + 1), 0, 32)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_PKT1(_Header)				LE_BITS_TO_2BYTE((_Header + 1), 0, 16)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_RETRY1(_Header)			LE_BITS_TO_2BYTE((_Header + 3), 0, 16)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_PKT2(_Header)				LE_BITS_TO_2BYTE((_Header + 5), 0, 16)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_RETRY2(_Header)			LE_BITS_TO_2BYTE((_Header + 7), 0, 16)
+
+/*BCNHWSEQ*/
+#define SET_8814A_H2CCMD_BCNHWSEQ_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 1, __Value)
+#define SET_8814A_H2CCMD_BCNHWSEQ_BCN_NUMBER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 1, 3, __Value)
+#define SET_8814A_H2CCMD_BCNHWSEQ_HWSEQ(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 6, 1, __Value)
+#define SET_8814A_H2CCMD_BCNHWSEQ_EXHWSEQ(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 7, 1, __Value)
+#define SET_8814A_H2CCMD_BCNHWSEQ_PAGE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+void rtl8814_fw_update_beacon_cmd(_adapter *padapter);
+
+/* TX Beamforming */
+#define GET_8814A_C2H_TXBF_ORIGINATE(_Header)			LE_BITS_TO_1BYTE(_Header, 0, 8)
+#define GET_8814A_C2H_TXBF_MACID(_Header)				LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
+
+
+
+/* / TX Feedback Content */
+#define	USEC_UNIT_FOR_8814A_C2H_TX_RPT_QUEUE_TIME			256
+
+#define	GET_8814A_C2H_TX_RPT_QUEUE_SELECT(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 5)
+#define	GET_8814A_C2H_TX_RPT_PKT_BROCAST(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 5, 1)
+#define	GET_8814A_C2H_TX_RPT_LIFE_TIME_OVER(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 6, 1)
+#define	GET_8814A_C2H_TX_RPT_RETRY_OVER(_Header)				LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
+#define	GET_8814A_C2H_TX_RPT_MAC_ID(_Header)					LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
+#define	GET_8814A_C2H_TX_RPT_DATA_RETRY_CNT(_Header)		LE_BITS_TO_1BYTE((_Header + 2), 0, 6)
+#define	GET_8814A_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	/* In unit of 256 microseconds. */
+#define	GET_8814A_C2H_TX_RPT_FINAL_DATA_RATE(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
+
+
+/* _P2P_PS_OFFLOAD */
+#define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ENABLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_NOA0_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_NOA1_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
+#define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_DISCOVERY(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
+
+s32 FillH2CCmd_8814(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+void rtl8814_set_wowlan_cmd(_adapter *padapter, u8 enable);
+void rtl8814_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
+void rtl8814_set_FwPwrMode_cmd(PADAPTER padapter, u8 PSMode);
+u8 GetTxBufferRsvdPageNum8814(_adapter *padapter, bool wowlan);
+u8 rtl8814_set_rssi_cmd(_adapter *padapter, u8 *param);
+void rtl8814_req_txrpt_cmd(PADAPTER padapter, u8 macid);
+
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8814_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
+
+void
+Set_RA_LDPC_8814(
+	struct sta_info	*psta,
+	BOOLEAN			bLDPC
+);
+
+s32 c2h_handler_8814a(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+
+#ifdef CONFIG_P2P_PS
+	void rtl8814_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#endif/* __RTL8814A_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_dm.h
new file mode 100644
index 000000000000..afbc8be2565c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_dm.h
@@ -0,0 +1,23 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_DM_H__
+#define __RTL8814A_DM_H__
+
+void rtl8814_init_dm_priv(IN PADAPTER Adapter);
+void rtl8814_deinit_dm_priv(IN PADAPTER Adapter);
+void rtl8814_InitHalDm(IN PADAPTER Adapter);
+void rtl8814_HalDmWatchDog(IN PADAPTER Adapter);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_hal.h
new file mode 100644
index 000000000000..e8b0876a506f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_hal.h
@@ -0,0 +1,330 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_HAL_H__
+#define __RTL8814A_HAL_H__
+
+/* #include "hal_com.h" */
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8814a_spec.h"
+#include "rtl8814a_rf.h"
+#include "rtl8814a_dm.h"
+#include "rtl8814a_recv.h"
+#include "rtl8814a_xmit.h"
+#include "rtl8814a_cmd.h"
+#include "rtl8814a_led.h"
+#include "Hal8814PwrSeq.h"
+#include "Hal8814PhyReg.h"
+#include "Hal8814PhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8814a_sreset.h"
+#endif /* DBG_CONFIG_ERROR_DETECT */
+
+enum {
+	VOLTAGE_V25						= 0x03,
+	LDOE25_SHIFT					= 28 ,
+};
+/* max. iram is 64k , max dmen is 32k. Total = 96k = 0x18000*/
+#define FW_SIZE							0x18000
+#define FW_START_ADDRESS   0x1000
+typedef struct _RT_FIRMWARE_8814 {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8814, *PRT_FIRMWARE_8814;
+
+#define PAGE_SIZE_TX_8814	PAGE_SIZE_128
+#define BCNQ_PAGE_NUM_8814		0x08
+
+#define Rtl8814A_NIC_PWR_ON_FLOW				rtl8814A_power_on_flow
+#define Rtl8814A_NIC_RF_OFF_FLOW				rtl8814A_radio_off_flow
+#define Rtl8814A_NIC_DISABLE_FLOW				rtl8814A_card_disable_flow
+#define Rtl8814A_NIC_ENABLE_FLOW				rtl8814A_card_enable_flow
+#define Rtl8814A_NIC_SUSPEND_FLOW				rtl8814A_suspend_flow
+#define Rtl8814A_NIC_RESUME_FLOW				rtl8814A_resume_flow
+#define Rtl8814A_NIC_PDN_FLOW					rtl8814A_hwpdn_flow
+#define Rtl8814A_NIC_LPS_ENTER_FLOW			rtl8814A_enter_lps_flow
+#define Rtl8814A_NIC_LPS_LEAVE_FLOW			rtl8814A_leave_lps_flow
+
+/* *****************************************************
+ *				New	Firmware Header(8-byte alinment required)
+ * *****************************************************
+ * --- LONG WORD 0 ---- */
+#define GET_FIRMWARE_HDR_SIGNATURE_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16)
+#define GET_FIRMWARE_HDR_CATEGORY_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) /* AP/NIC and USB/PCI */
+#define GET_FIRMWARE_HDR_FUNCTION_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr, 24, 8) /* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions */
+#define GET_FIRMWARE_HDR_VERSION_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)/* FW Version */
+#define GET_FIRMWARE_HDR_SUB_VER_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) /* FW Subversion, default 0x00 */
+#define GET_FIRMWARE_HDR_SUB_IDX_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8) /* FW Subversion Index */
+
+/* --- LONG WORD 1 ---- */
+#define GET_FIRMWARE_HDR_SVN_IDX_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 32)/* The SVN entry index */
+#define GET_FIRMWARE_HDR_RSVD1_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 0, 32)
+
+/* --- LONG WORD 2 ---- */
+#define GET_FIRMWARE_HDR_MONTH_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 0, 8) /* Release time Month field */
+#define GET_FIRMWARE_HDR_DATE_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+16, 8, 8) /* Release time Date field */
+#define GET_FIRMWARE_HDR_HOUR_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+16, 16, 8)/* Release time Hour field */
+#define GET_FIRMWARE_HDR_MINUTE_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 24, 8)/* Release time Minute field */
+#define GET_FIRMWARE_HDR_YEAR_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+20, 0, 16)/* Release time Year field */
+#define GET_FIRMWARE_HDR_FOUNDRY_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 16, 8)/* Release time Foundry field */
+#define GET_FIRMWARE_HDR_RSVD2_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 24, 8)
+
+/* --- LONG WORD 3 ---- */
+#define GET_FIRMWARE_HDR_MEM_UASGE_DL_FROM_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+24, 0, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_BOOT_FROM_3081(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+24, 1, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_BOOT_LOADER_3081(__FwHdr)LE_BITS_TO_4BYTE(__FwHdr+24, 2, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_IRAM_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 3, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_ERAM_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 4, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_RSVD4_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+24, 5, 3)
+#define GET_FIRMWARE_HDR_RSVD3_3081(__FwHdr)					LE_BITS_TO_4BYTE(__FwHdr+24, 8, 8)
+#define GET_FIRMWARE_HDR_BOOT_LOADER_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 16, 16)
+#define GET_FIRMWARE_HDR_RSVD5_3081(__FwHdr)					LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
+
+/* --- LONG WORD 4 ---- */
+#define GET_FIRMWARE_HDR_TOTAL_DMEM_SZ_3081(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+36, 0, 32)
+#define GET_FIRMWARE_HDR_FW_CFG_SZ_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+36, 0, 16)
+#define GET_FIRMWARE_HDR_FW_ATTR_SZ_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+36, 16, 16)
+
+/* --- LONG WORD 5 ---- */
+#define GET_FIRMWARE_HDR_IROM_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+40, 0, 32)
+#define GET_FIRMWARE_HDR_EROM_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+44, 0, 32)
+
+/* --- LONG WORD 6 ---- */
+#define GET_FIRMWARE_HDR_IRAM_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+48, 0, 32)
+#define GET_FIRMWARE_HDR_ERAM_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+52, 0, 32)
+
+/* --- LONG WORD 7 ---- */
+#define GET_FIRMWARE_HDR_RSVD6_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+56, 0, 32)
+#define GET_FIRMWARE_HDR_RSVD7_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+60, 0, 32)
+
+
+
+/*
+ * 2013/08/16 MH MOve from SDIO.h for common use.
+ *   */
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
+	#define TRX_SHARE_MODE_8814A				0	/* TRX Buffer Share Index */
+	#define BASIC_RXFF_SIZE_8814A				24576/* Basic RXFF Size is 24K = 24*1024 Unit: Byte */
+	#define TRX_SHARE_BUFF_UNIT_8814A			65536/* TRX Share Buffer unit Size 64K = 64*1024 Unit: Byte */
+	#define TRX_SHARE_BUFF_UNIT_PAGE_8814A	(TRX_SHARE_BUFF_UNIT_8814A/PAGE_SIZE_8814A)/* 512 Pages */
+
+	/* Origin: */
+	#define  HPQ_PGNUM_8814A					0x20	/* High Queue */
+	#define  LPQ_PGNUM_8814A					0x20	/* Low Queue */
+	#define  NPQ_PGNUM_8814A					0x20	/* Normal Queue */
+	#define  EPQ_PGNUM_8814A					0x20	/* Extra Queue */
+
+#else	/*  #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI) */
+
+	#define  HPQ_PGNUM_8814A		20
+	#define  NPQ_PGNUM_8814A		20
+	#define  LPQ_PGNUM_8814A		20 /* 1972 */
+	#define  EPQ_PGNUM_8814A		20
+	#define  BCQ_PGNUM_8814A		32
+
+#endif /* #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI) */
+
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8814	0x06
+#else
+	#define WOWLAN_PAGE_NUM_8814	0x00
+#endif
+
+#define PAGE_SIZE_8814A						128/* TXFF Page Size, Unit: Byte */
+#define MAX_RX_DMA_BUFFER_SIZE_8814A		0x5C00	/* BASIC_RXFF_SIZE_8814A + TRX_SHARE_MODE_8814A * TRX_SHARE_BUFF_UNIT_8814A */ /* Basic RXFF Size + ShareBuffer Size */
+#define TX_PAGE_BOUNDARY_8814A			TXPKT_PGNUM_8814A	/* Need to enlarge boundary, by KaiYuan */
+#define TX_PAGE_BOUNDARY_WOWLAN_8814A	TXPKT_PGNUM_8814A	/* TODO: 20130415 KaiYuan Check this value later */
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8814A	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8814A	0x0	/* 0B */
+#endif
+#define RX_DMA_BOUNDARY_8814A		(MAX_RX_DMA_BUFFER_SIZE_8814A - RX_DMA_RESERVED_SIZE_8814A - 1)
+
+#define  TOTAL_PGNUM_8814A		2048
+#define  TXPKT_PGNUM_8814A		(2048 - BCNQ_PAGE_NUM_8814-WOWLAN_PAGE_NUM_8814)
+#define  PUB_PGNUM_8814A		(TXPKT_PGNUM_8814A-HPQ_PGNUM_8814A-NPQ_PGNUM_8814A-LPQ_PGNUM_8814A-EPQ_PGNUM_8814A)
+
+/* Note: For WMM Normal Chip Setting ,modify later */
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8814A	TX_PAGE_BOUNDARY_8814A
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8814A		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8814A + 1)
+
+#define DRIVER_EARLY_INT_TIME_8814		0x05
+#define BCN_DMA_ATIME_INT_TIME_8814		0x02
+
+
+#define MAX_PAGE_SIZE			4096	/* @ page : 4k bytes */
+
+#define EFUSE_MAX_SECTION_JAGUAR				64
+
+#define	HWSET_MAX_SIZE_8814A			512
+
+#define	EFUSE_REAL_CONTENT_LEN_8814A	1024
+#define	EFUSE_MAX_BANK_8814A		2
+
+#define	EFUSE_MAP_LEN_8814A			512
+#define	EFUSE_MAX_SECTION_8814A		64
+#define	EFUSE_MAX_WORD_UNIT_8814A		4
+#define	EFUSE_PROTECT_BYTES_BANK_8814A		16
+
+#define	EFUSE_IC_ID_OFFSET_8814A		506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define AVAILABLE_EFUSE_ADDR_8814A(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8814A)
+
+/*-------------------------------------------------------------------------
+Chip specific
+-------------------------------------------------------------------------*/
+
+/* pic buffer descriptor */
+#if 1 /* according to the define in the rtw_xmit.h, rtw_recv.h */
+	#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
+	#define TX_DESC_NUM_8814A  TX_BD_NUM   /* 128 */
+	#define RX_DESC_NUM_8814A  PCI_MAX_RX_COUNT /* 128 */
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define BE_QUEUE_TX_DESC_NUM_8814A  (TX_BD_NUM<<1)    /* 256 */
+	#else
+		#define BE_QUEUE_TX_DESC_NUM_8814A  (TX_BD_NUM+(TX_BD_NUM>>1)) /* 192 */
+	#endif
+#else
+	#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
+	#define TX_DESC_NUM_8814A  128 /* 1024//2048 change by ylb 20130624 */
+	#define RX_DESC_NUM_8814A  128 /* 1024 //512 change by ylb 20130624 */
+#endif
+
+/* <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)	      |
+ *   */
+#define	EFUSE_OOB_PROTECT_BYTES		15	/* PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte. */
+
+#ifdef CONFIG_FILE_FWIMG
+extern char *rtw_fw_file_path;
+#ifdef CONFIG_WOWLAN
+extern char *rtw_fw_wow_file_path;
+#endif
+#ifdef CONFIG_MP_INCLUDED
+extern char *rtw_fw_mp_bt_file_path;
+#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
+
+/* rtl8814_hal_init.c */
+s32 FirmwareDownload8814A(PADAPTER	Adapter, BOOLEAN bUsedWoWLANFw);
+void	InitializeFirmwareVars8814(PADAPTER padapter);
+
+VOID
+Hal_InitEfuseVars_8814A(
+	IN	PADAPTER	Adapter
+);
+
+s32 InitLLTTable8814A(
+	IN	PADAPTER	Adapter
+);
+
+
+void InitRDGSetting8814A(PADAPTER padapter);
+
+/* void CheckAutoloadState8812A(PADAPTER padapter); */
+
+/* EFuse */
+u8	GetEEPROMSize8814A(PADAPTER padapter);
+VOID hal_InitPGData_8814A(
+ IN PADAPTER  padapter,
+ IN OUT u8   *PROMContent
+);
+
+void	hal_ReadPROMVersion8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadTxPowerInfo8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+void	hal_ReadBoardType8814A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadThermalMeter_8814A(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void	hal_ReadChannelPlan8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_EfuseParseXtal_8814A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadAntennaDiversity8814A(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void	hal_Read_TRX_antenna_8814A(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+VOID hal_ReadAmplifierType_8814A(
+	IN	PADAPTER		Adapter
+);
+VOID hal_ReadPAType_8814A(
+	IN	PADAPTER	Adapter,
+	IN	u8			*PROMContent,
+	IN	BOOLEAN		AutoloadFail,
+	OUT u8		*pPAType,
+	OUT u8		*pLNAType
+);
+
+void hal_ReadPowerTrackingType_8814A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+
+void hal_GetRxGainOffset_8814A(
+	PADAPTER	Adapter,
+	pu1Byte		PROMContent,
+	BOOLEAN		AutoloadFail
+);
+void Hal_EfuseParseKFreeData_8814A(
+	IN		PADAPTER		Adapter,
+	IN		u8				*PROMContent,
+	IN		BOOLEAN			AutoloadFail);
+void	hal_ReadRFEType_8814A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	hal_EfuseParseBTCoexistInfo8814A(PADAPTER Adapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+/* void	hal_ReadUsbType_8812AU(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+ * int	FirmwareDownloadBT(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware); */
+void	hal_ReadRemoteWakeup_8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+u8	MgntQuery_NssTxRate(u16 Rate);
+
+/* BOOLEAN HalDetectPwrDownMode8812(PADAPTER Adapter); */
+
+#ifdef CONFIG_WOWLAN
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void _InitBeaconParameters_8814A(PADAPTER padapter);
+void SetBeaconRelatedRegisters8814A(PADAPTER padapter);
+
+void ReadRFType8814A(PADAPTER padapter);
+void InitDefaultValue8814A(PADAPTER padapter);
+
+u8 SetHwReg8814A(PADAPTER padapter, u8 variable, u8 *pval);
+void GetHwReg8814A(PADAPTER padapter, u8 variable, u8 *pval);
+u8 SetHalDefVar8814A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8814A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+void rtl8814_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8814a(_adapter *adapter);
+
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+void SetBcnCtrlReg(PADAPTER	Adapter, u8	SetBits, u8	ClearBits);
+void rtl8814_start_thread(PADAPTER padapter);
+void rtl8814_stop_thread(PADAPTER padapter);
+
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8814AE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8814AE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+	VOID	InitMAC_TRXBD_8814AE(PADAPTER Adapter);
+	u16	get_txbd_rw_reg(u16 ff_hwaddr);
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+	void rtl8812a_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
+#endif
+
+#endif /* __RTL8188E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_led.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_led.h
new file mode 100644
index 000000000000..cc457921efa1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_led.h
@@ -0,0 +1,36 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_LED_H__
+#define __RTL8814A_LED_H__
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8814au_InitSwLeds(PADAPTER padapter);
+	void rtl8814au_DeInitSwLeds(PADAPTER padapter);
+#endif /* CONFIG_USB_HCI */
+#ifdef CONFIG_PCI_HCI
+	void rtl8814ae_InitSwLeds(PADAPTER padapter);
+	void rtl8814ae_DeInitSwLeds(PADAPTER padapter);
+#endif /* CONFIG_PCI_HCI */
+#ifdef CONFIG_SDIO_HCI
+	void rtl8814s_InitSwLeds(PADAPTER padapter);
+	void rtl8814s_DeInitSwLeds(PADAPTER padapter);
+#endif /* CONFIG_SDIO_HCI */
+
+#endif /* __RTL8814A_LED_H__ */
+#endif /*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_recv.h
new file mode 100644
index 000000000000..c6792d8a5194
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_recv.h
@@ -0,0 +1,186 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_RECV_H__
+#define __RTL8814A_RECV_H__
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (32768) /* 32k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (24576) */ /* 24k */
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (15360) */ /* 15k < 16k */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI)
+	#if 0
+		/* temp solution */
+		#ifdef CONFIG_SDIO_RX_COPY
+			#define MAX_RECVBUF_SZ (10240)
+		#else /*  !CONFIG_SDIO_RX_COPY */
+			#define MAX_RECVBUF_SZ	MAX_RX_DMA_BUFFER_SIZE_8821
+		#endif /*  !CONFIG_SDIO_RX_COPY */
+	#endif
+#endif
+
+
+/* RX buffer descriptor */
+/* DWORD 0 */
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_8814A(__pRxStatusDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 14, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_8814A(__pRxStatusDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 16, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_BUFFER_DESC_FS_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+
+/* DWORD 1 */
+#define SET_RX_BUFFER_PHYSICAL_LOW_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+#define GET_RX_BUFFER_PHYSICAL_LOW_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 32)
+
+/* DWORD 2 */
+#define SET_RX_BUFFER_PHYSICAL_HIGH_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+
+/* DWORD 3*/ /* RESERVED */
+
+
+#if 0
+	/* =============
+	* RX Info
+	* ============== */
+#endif
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8814AE(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_LAST_SEG_8814AE(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+#define GET_RX_STATUS_DESC_EOR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_EXT_SECTYPE_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 7, 1)/* 20130415 KaiYuan add for 8814 */
+#define GET_RX_STATUS_DESC_TID_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_MACID_VLD_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 12, 1)
+#define GET_RX_STATUS_DESC_AMSDU_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_FIRST_SEG_8814AE(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+#define GET_RX_STATUS_DESC_EOR_8814AE(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_MC_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#ifdef CONFIG_USB_RX_AGGREGATION
+	#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 8)
+#else
+	#define GET_RX_STATUS_DESC_RX_IS_QOS_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#endif
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_HWRSVD_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 24, 4)
+#define GET_RX_STATUS_C2H_8814A(__pRxStatusDesc)								LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+#define GET_RX_STATUS_DESC_FCS_OK_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_BSSID_FIT_H_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 7, 3)/* 20130415 KaiYuan add for 8814 */
+#define GET_RX_STATUS_DESC_HTC_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_L_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#define GET_RX_STATUS_DESC_DMA_AGG_NUM_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)/* 20130415 KaiYuan Check if it exist anymore */
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_WAKE_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 31, 1)
+
+/* DWORD 4 */
+#define GET_RX_STATUS_DESC_PATTERN_IDX_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 0, 8)
+#define GET_RX_STATUS_DESC_RX_EOF_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 8, 1)
+#define GET_RX_STATUS_DESC_RX_SCRAMBLER_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 9, 7)
+#define GET_RX_STATUS_DESC_RX_PRE_NDP_VLD_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 16, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 24, 5)
+
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+
+/* Rx smooth factor */
+#define Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8814au_init_recv_priv(PADAPTER padapter);
+	void rtl8814au_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8814ae_init_recv_priv(PADAPTER padapter);
+	void rtl8814ae_free_recv_priv(PADAPTER padapter);
+#endif
+
+#if 0
+	/* temp solution */
+	#ifdef CONFIG_SDIO_HCI
+		s32 InitRecvPriv8821AS(PADAPTER padapter);
+		void FreeRecvPriv8821AS(PADAPTER padapter);
+	#endif /*  CONFIG_SDIO_HCI */
+#endif
+
+void rtl8814_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8814A_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_rf.h
new file mode 100644
index 000000000000..e374439caaf2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_rf.h
@@ -0,0 +1,28 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_RF_H__
+#define __RTL8814A_RF_H__
+
+VOID
+PHY_RF6052SetBandwidth8814A(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
+
+
+int
+PHY_RF6052_Config_8814A(
+	IN	PADAPTER	Adapter);
+
+#endif/* __RTL8188E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_spec.h
new file mode 100644
index 000000000000..917b96178d66
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_spec.h
@@ -0,0 +1,648 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_SPEC_H__
+#define __RTL8814A_SPEC_H__
+
+#include <drv_conf.h>
+
+
+/* ************************************************************
+ *
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8814A			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8814A			0x0002	/* 2 Byte */
+#define REG_SYS_PW_CTRL_8814A			0x0004	/* 4 Byte        */
+#define REG_SYS_CLKR_8814A				0x0008	/* 2 Byte */
+#define REG_SYS_EEPROM_CTRL_8814A		0x000A	/* 2 Byte        */
+#define REG_EE_VPD_8814A				0x000C	/* 2 Byte */
+#define REG_SYS_SWR_CTRL1_8814A			0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8814A				0x0011	/* 7 Byte */
+#define REG_SYS_SWR_CTRL3_8814A			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8814A				0x001C	/* 3 Byte */
+#define REG_RF_CTRL0_8814A				0x001F	/* 1 Byte */
+#define REG_RF_CTRL1_8814A				0x0020	/* 1 Byte */
+#define REG_RF_CTRL2_8814A				0x0021	/* 1 Byte */
+#define REG_LPLDO_CTRL_8814A			0x0023	/* 1 Byte */
+#define REG_AFE_CTRL1_8814A				0x0024	/* 4 Byte        */
+#define REG_AFE_CTRL2_8814A				0x0028	/* 4 Byte        */
+#define REG_AFE_CTRL3_8814A				0x002c	/* 4 Byte  */
+#define REG_EFUSE_CTRL_8814A			0x0030
+#define REG_LDO_EFUSE_CTRL_8814A		0x0034
+#define REG_PWR_DATA_8814A				0x0038
+#define REG_CAL_TIMER_8814A				0x003C
+#define REG_ACLK_MON_8814A				0x003E
+#define REG_GPIO_MUXCFG_8814A			0x0040
+#define REG_GPIO_IO_SEL_8814A			0x0042
+#define REG_MAC_PINMUX_CFG_8814A		0x0043
+#define REG_GPIO_PIN_CTRL_8814A			0x0044
+#define REG_GPIO_INTM_8814A				0x0048
+#define REG_LEDCFG0_8814A				0x004C
+#define REG_LEDCFG1_8814A				0x004D
+#define REG_LEDCFG2_8814A				0x004E
+#define REG_LEDCFG3_8814A				0x004F
+#define REG_FSIMR_8814A					0x0050
+#define REG_FSISR_8814A					0x0054
+#define REG_HSIMR_8814A					0x0058
+#define REG_HSISR_8814A					0x005c
+#define REG_GPIO_EXT_CTRL_8814A			0x0060
+#define REG_GPIO_STATUS_8814A			0x006C
+#define REG_SDIO_CTRL_8814A				0x0070
+#define REG_HCI_OPT_CTRL_8814A			0x0074
+#define REG_RF_CTRL3_8814A				0x0076	/* 1 Byte */
+#define REG_AFE_CTRL4_8814A				0x0078
+#define REG_8051FW_CTRL_8814A			0x0080
+#define REG_HIMR0_8814A					0x00B0
+#define REG_HISR0_8814A					0x00B4
+#define REG_HIMR1_8814A					0x00B8
+#define REG_HISR1_8814A					0x00BC
+#define REG_SYS_CFG1_8814A				0x00F0
+#define REG_SYS_CFG2_8814A				0x00FC
+#define REG_SYS_CFG3_8814A				0x1000
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_CR_8814A						0x0100
+#define REG_PBP_8814A					0x0104
+#define REG_PKT_BUFF_ACCESS_CTRL_8814A	0x0106
+#define REG_TRXDMA_CTRL_8814A			0x010C
+#define REG_TRXFF_BNDY_8814A			0x0114
+#define REG_TRXFF_STATUS_8814A			0x0118
+#define REG_RXFF_PTR_8814A				0x011C
+#define REG_CPWM_8814A					0x012F
+#define REG_FWIMR_8814A					0x0130
+#define REG_FWISR_8814A					0x0134
+#define REG_FTIMR_8814A					0x0138
+#define REG_PKTBUF_DBG_CTRL_8814A		0x0140
+#define REG_RXPKTBUF_CTRL_8814A		0x0142
+#define REG_PKTBUF_DBG_DATA_L_8814A	0x0144
+#define REG_PKTBUF_DBG_DATA_H_8814A	0x0148
+
+#define REG_WOWLAN_WAKE_REASON			REG_MCUTST_WOWLAN
+
+#define REG_TC0_CTRL_8814A				0x0150
+#define REG_TC1_CTRL_8814A				0x0154
+#define REG_TC2_CTRL_8814A				0x0158
+#define REG_TC3_CTRL_8814A				0x015C
+#define REG_TC4_CTRL_8814A				0x0160
+#define REG_TCUNIT_BASE_8814A			0x0164
+#define REG_RSVD3_8814A					0x0168
+#define REG_C2HEVT_MSG_NORMAL_8814A	0x01A0
+#define REG_C2HEVT_CLEAR_8814A			0x01AF
+#define REG_MCUTST_1_8814A				0x01C0
+#define REG_MCUTST_WOWLAN_8814A		0x01C7
+#define REG_FMETHR_8814A				0x01C8
+#define REG_HMETFR_8814A				0x01CC
+#define REG_HMEBOX_0_8814A				0x01D0
+#define REG_HMEBOX_1_8814A				0x01D4
+#define REG_HMEBOX_2_8814A				0x01D8
+#define REG_HMEBOX_3_8814A				0x01DC
+#define REG_LLT_INIT_8814A				0x01E0
+#define REG_LLT_ADDR_8814A				0x01E4 /* 20130415 KaiYuan add for 8814 */
+#define REG_HMEBOX_EXT0_8814A			0x01F0
+#define REG_HMEBOX_EXT1_8814A			0x01F4
+#define REG_HMEBOX_EXT2_8814A			0x01F8
+#define REG_HMEBOX_EXT3_8814A			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_FIFOPAGE_CTRL_1_8814A			0x0200
+#define REG_FIFOPAGE_CTRL_2_8814A		0x0204
+#define REG_AUTO_LLT_8814A					0x0208
+#define REG_TXDMA_OFFSET_CHK_8814A	0x020C
+#define REG_TXDMA_STATUS_8814A			0x0210
+#define REG_RQPN_NPQ_8814A				0x0214
+#define REG_TQPNT1_8814A					0x0218
+#define REG_TQPNT2_8814A					0x021C
+#define REG_TQPNT3_8814A					0x0220
+#define REG_TQPNT4_8814A					0x0224
+#define REG_RQPN_CTRL_1_8814A				0x0228
+#define REG_RQPN_CTRL_2_8814A				0x022C
+#define REG_FIFOPAGE_INFO_1_8814A			0x0230
+#define REG_FIFOPAGE_INFO_2_8814A			0x0234
+#define REG_FIFOPAGE_INFO_3_8814A			0x0238
+#define REG_FIFOPAGE_INFO_4_8814A			0x023C
+#define REG_FIFOPAGE_INFO_5_8814A			0x0240
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8814A		0x0280
+#define REG_RXPKT_NUM_8814A				0x0284 /* The number of packets in RXPKTBUF. */
+#define REG_RXDMA_CONTROL_8814A			0x0286 /* ?????? Control the RX DMA. */
+#define REG_RXDMA_STATUS_8814A			0x0288
+#define REG_RXDMA_MODE_8814A				0x0290 /* ?????? */
+#define REG_EARLY_MODE_CONTROL_8814A	0x02BC /* ?????? */
+#define REG_RSVD5_8814A					0x02F0 /* ?????? */
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8814A			0x0300
+#define	REG_INT_MIG_8814A				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8814A		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8814A			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8814A			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8814A			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8814A			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8814A			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8814A			0x0338	/* RX Queue	Descriptor Address */
+#define REG_HI0Q_TXBD_DESA_8814A		0x0340
+#define REG_HI1Q_TXBD_DESA_8814A		0x0348
+#define REG_HI2Q_TXBD_DESA_8814A		0x0350
+#define REG_HI3Q_TXBD_DESA_8814A		0x0358
+#define REG_HI4Q_TXBD_DESA_8814A		0x0360
+#define REG_HI5Q_TXBD_DESA_8814A		0x0368
+#define REG_HI6Q_TXBD_DESA_8814A		0x0370
+#define REG_HI7Q_TXBD_DESA_8814A		0x0378
+#define	REG_MGQ_TXBD_NUM_8814A			0x0380
+#define	REG_RX_RXBD_NUM_8814A			0x0382
+#define	REG_VOQ_TXBD_NUM_8814A			0x0384
+#define	REG_VIQ_TXBD_NUM_8814A			0x0386
+#define	REG_BEQ_TXBD_NUM_8814A			0x0388
+#define	REG_BKQ_TXBD_NUM_8814A			0x038A
+#define	REG_HI0Q_TXBD_NUM_8814A			0x038C
+#define	REG_HI1Q_TXBD_NUM_8814A			0x038E
+#define	REG_HI2Q_TXBD_NUM_8814A			0x0390
+#define	REG_HI3Q_TXBD_NUM_8814A			0x0392
+#define	REG_HI4Q_TXBD_NUM_8814A			0x0394
+#define	REG_HI5Q_TXBD_NUM_8814A			0x0396
+#define	REG_HI6Q_TXBD_NUM_8814A			0x0398
+#define	REG_HI7Q_TXBD_NUM_8814A			0x039A
+#define	REG_TSFTIMER_HCI_8814A			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8814A			0x03A0
+#define	REG_VIQ_TXBD_IDX_8814A			0x03A4
+#define	REG_BEQ_TXBD_IDX_8814A			0x03A8
+#define	REG_BKQ_TXBD_IDX_8814A			0x03AC
+#define	REG_MGQ_TXBD_IDX_8814A			0x03B0
+#define	REG_RXQ_TXBD_IDX_8814A			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8814A			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8814A			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8814A			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8814A			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8814A			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8814A			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8814A			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8814A			0x03D4
+#define REG_DBG_SEL_V1_8814A				0x03D8
+#define REG_PCIE_HRPWM1_V1_8814A			0x03D9
+#define REG_PCIE_HCPWM1_V1_8814A			0x03DA
+#define REG_PCIE_CTRL2_8814A				0x03DB
+#define REG_PCIE_HRPWM2_V1_8814A			0x03DC
+#define REG_PCIE_HCPWM2_V1_8814A			0x03DE
+#define REG_PCIE_H2C_MSG_V1_8814A		0x03E0
+#define REG_PCIE_C2H_MSG_V1_8814A		0x03E4
+#define REG_DBI_WDATA_V1_8814A			0x03E8
+#define REG_DBI_RDATA_V1_8814A			0x03EC
+#define REG_DBI_FLAG_V1_8814A				0x03F0
+#define REG_MDIO_V1_8814A					0x03F4
+#define REG_PCIE_MIX_CFG_8814A			0x03F8
+#define REG_DBG_8814A						0x03FC
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_VOQ_INFORMATION_8814A		0x0400
+#define REG_VIQ_INFORMATION_8814A		0x0404
+#define REG_BEQ_INFORMATION_8814A		0x0408
+#define REG_BKQ_INFORMATION_8814A		0x040C
+#define REG_MGQ_INFORMATION_8814A		0x0410
+#define REG_HGQ_INFORMATION_8814A		0x0414
+#define REG_BCNQ_INFORMATION_8814A	0x0418
+#define REG_TXPKT_EMPTY_8814A			0x041A
+#define REG_CPU_MGQ_INFORMATION_8814A	0x041C
+#define REG_FWHW_TXQ_CTRL_8814A		0x0420
+#define REG_HWSEQ_CTRL_8814A			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8814A	0x0424
+/* #define REG_MGQ_BDNY_8814A				0x0425 */
+#define REG_LIFETIME_EN_8814A				0x0426
+/* #define REG_FW_FREE_TAIL_8814A			0x0427 */
+#define REG_SPEC_SIFS_8814A				0x0428
+#define REG_RETRY_LIMIT_8814A				0x042A
+#define REG_TXBF_CTRL_8814A				0x042C
+#define REG_DARFRC_8814A				0x0430
+#define REG_RARFRC_8814A				0x0438
+#define REG_RRSR_8814A					0x0440
+#define REG_ARFR0_8814A					0x0444
+#define REG_ARFR1_8814A					0x044C
+#define REG_CCK_CHECK_8814A				0x0454
+#define REG_AMPDU_MAX_TIME_8814A			0x0455
+#define REG_TXPKTBUF_BCNQ1_BDNY_8814A	0x0456
+#define REG_AMPDU_MAX_LENGTH_8814A	0x0458
+#define REG_ACQ_STOP_8814A				0x045C
+#define REG_NDPA_RATE_8814A				0x045D
+#define REG_TX_HANG_CTRL_8814A			0x045E
+#define REG_NDPA_OPT_CTRL_8814A		0x045F
+#define REG_FAST_EDCA_CTRL_8814A		0x0460
+#define REG_RD_RESP_PKT_TH_8814A		0x0463
+#define REG_CMDQ_INFO_8814A				0x0464
+#define REG_Q4_INFO_8814A					0x0468
+#define REG_Q5_INFO_8814A					0x046C
+#define REG_Q6_INFO_8814A					0x0470
+#define REG_Q7_INFO_8814A					0x0474
+#define REG_WMAC_LBK_BUF_HD_8814A		0x0478
+#define REG_MGQ_PGBNDY_8814A				0x047A
+#define REG_INIRTS_RATE_SEL_8814A			0x0480
+#define REG_BASIC_CFEND_RATE_8814A		0x0481
+#define REG_STBC_CFEND_RATE_8814A		0x0482
+#define REG_DATA_SC_8814A					0x0483
+#define REG_MACID_SLEEP3_8814A			0x0484
+#define REG_MACID_SLEEP1_8814A			0x0488
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW				0x0484
+	#define REG_TXPKTBUF_IV_HIGH			0x0488
+#endif /* CONFIG_WOWLAN */
+#define REG_ARFR2_8814A					0x048C
+#define REG_ARFR3_8814A					0x0494
+#define REG_ARFR4_8814A					0x049C
+#define REG_ARFR5_8814A					0x04A4
+#define REG_TXRPT_START_OFFSET_8814A		0x04AC
+#define REG_TRYING_CNT_TH_8814A			0x04B0
+#define REG_POWER_STAGE1_8814A		0x04B4
+#define REG_POWER_STAGE2_8814A		0x04B8
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8814A	0x04BC
+#define REG_PKT_LIFE_TIME_8814A			0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8814A		0x04C2 /* ?????? */
+#define REG_STBC_SETTING_8814A			0x04C4
+#define REG_STBC_8814A						0x04C5
+#define REG_QUEUE_CTRL_8814A				0x04C6
+#define REG_SINGLE_AMPDU_CTRL_8814A		0x04C7
+#define REG_PROT_MODE_CTRL_8814A		0x04C8
+#define REG_MAX_AGGR_NUM_8814A		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8814A	0x04CB
+#define REG_BAR_MODE_CTRL_8814A		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8814A	0x04CF
+#define REG_MACID_SLEEP2_8814A			0x04D0
+#define REG_MACID_SLEEP0_8814A			0x04D4
+#define REG_HW_SEQ0_8814A				0x04D8
+#define REG_HW_SEQ1_8814A				0x04DA
+#define REG_HW_SEQ2_8814A				0x04DC
+#define REG_HW_SEQ3_8814A				0x04DE
+#define REG_NULL_PKT_STATUS_8814A			0x04E0
+#define REG_PTCL_ERR_STATUS_8814A			0x04E2
+#define REG_DROP_PKT_NUM_8814A			0x04EC
+#define REG_PTCL_TX_RPT_8814A				0x04F0
+#define REG_Dummy_8814A					0x04FC
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8814A			0x0500
+#define REG_EDCA_VI_PARAM_8814A			0x0504
+#define REG_EDCA_BE_PARAM_8814A			0x0508
+#define REG_EDCA_BK_PARAM_8814A			0x050C
+#define REG_BCNTCFG_8814A					0x0510
+#define REG_PIFS_8814A						0x0512
+#define REG_RDG_PIFS_8814A					0x0513
+#define REG_SIFS_CTX_8814A					0x0514
+#define REG_SIFS_TRX_8814A					0x0516
+#define REG_AGGR_BREAK_TIME_8814A			0x051A
+#define REG_SLOT_8814A						0x051B
+#define REG_TX_PTCL_CTRL_8814A				0x0520
+#define REG_TXPAUSE_8814A					0x0522
+#define REG_DIS_TXREQ_CLR_8814A			0x0523
+#define REG_RD_CTRL_8814A					0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8814A			0x0540
+#define REG_RD_NAV_NXT_8814A				0x0544
+#define REG_NAV_PROT_LEN_8814A			0x0546
+#define REG_BCN_CTRL_8814A					0x0550
+#define REG_BCN_CTRL_1_8814A				0x0551
+#define REG_MBID_NUM_8814A				0x0552
+#define REG_DUAL_TSF_RST_8814A				0x0553
+#define REG_MBSSID_BCN_SPACE_8814A		0x0554
+#define REG_DRVERLYINT_8814A				0x0558
+#define REG_BCNDMATIM_8814A				0x0559
+#define REG_ATIMWND_8814A					0x055A
+#define REG_USTIME_TSF_8814A				0x055C
+#define REG_BCN_MAX_ERR_8814A				0x055D
+#define REG_RXTSF_OFFSET_CCK_8814A		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8814A		0x055F
+#define REG_TSFTR_8814A						0x0560
+#define REG_CTWND_8814A					0x0572
+#define REG_SECONDARY_CCA_CTRL_8814A		0x0577 /* ?????? */
+#define REG_PSTIMER_8814A					0x0580
+#define REG_TIMER0_8814A					0x0584
+#define REG_TIMER1_8814A					0x0588
+#define REG_BCN_PREDL_ITV_8814A			0x058F	/* Pre download beacon interval */
+#define REG_ACMHWCTRL_8814A				0x05C0
+#define REG_P2P_RST_8814A				0x05F0
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8814A					0x0600
+#define REG_TCR_8814A						0x0604
+#define REG_RCR_8814A						0x0608
+#define REG_RX_PKT_LIMIT_8814A				0x060C
+#define REG_RX_DLK_TIME_8814A				0x060D
+#define REG_RX_DRVINFO_SZ_8814A			0x060F
+
+#define REG_MACID_8814A					0x0610
+#define REG_BSSID_8814A						0x0618
+#define REG_MAR_8814A						0x0620
+#define REG_MBIDCAMCFG_8814A				0x0628
+
+#define REG_USTIME_EDCA_8814A				0x0638
+#define REG_MAC_SPEC_SIFS_8814A			0x063A
+#define REG_RESP_SIFP_CCK_8814A			0x063C
+#define REG_RESP_SIFS_OFDM_8814A			0x063E
+#define REG_ACKTO_8814A					0x0640
+#define REG_CTS2TO_8814A					0x0641
+#define REG_EIFS_8814A						0x0642
+
+#define	REG_NAV_UPPER_8814A				0x0652	/* unit of 128 */
+#define REG_TRXPTCL_CTL_8814A				0x0668
+
+/* Security */
+#define REG_CAMCMD_8814A					0x0670
+#define REG_CAMWRITE_8814A				0x0674
+#define REG_CAMREAD_8814A					0x0678
+#define REG_CAMDBG_8814A					0x067C
+#define REG_SECCFG_8814A					0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8814A				0x0690
+#define REG_PS_RX_INFO_8814A				0x0692
+#define REG_UAPSD_TID_8814A				0x0693
+#define REG_WKFMCAM_NUM_8814A			0x0698
+#define REG_RXFLTMAP0_8814A				0x06A0
+#define REG_RXFLTMAP1_8814A				0x06A2
+#define REG_RXFLTMAP2_8814A				0x06A4
+#define REG_BCN_PSR_RPT_8814A				0x06A8
+#define REG_BT_COEX_TABLE_8814A			0x06C0
+#define REG_TX_DATA_RSP_RATE_8814A		0x06DE
+#define REG_ASSOCIATED_BFMER0_INFO_8814A	0x06E4
+#define REG_ASSOCIATED_BFMER1_INFO_8814A	0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8814A		0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8814A		0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8814A		0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8814A					0x0700
+#define REG_BSSID1_8814A					0x0708
+/* Hardware Port 3 */
+#define REG_MACID2_8814A					0x1620
+#define REG_BSSID2_8814A					0x1628
+/* Hardware Port 4 */
+#define REG_MACID3_8814A					0x1630
+#define REG_BSSID3_8814A					0x1638
+/* Hardware Port 5 */
+#define REG_MACID4_8814A					0x1640
+#define REG_BSSID4_8814A					0x1648
+
+#define REG_ASSOCIATED_BFMEE_SEL_8814A	0x0714
+#define REG_SND_PTCL_CTRL_8814A			0x0718
+#define REG_IQ_DUMP_8814A					0x07C0
+
+#define REG_CPU_DMEM_CON_8814A			0x1080
+
+/**** page 19 ****/
+/* TX BeamForming */
+#define	REG_BB_TXBF_ANT_SET_BF1				0x19ac
+#define	REG_BB_TXBF_ANT_SET_BF0				0x19b4
+
+/*	0x1200h ~ 0x12FFh	DDMA CTRL
+ *
+ * ----------------------------------------------------- */
+#define REG_DDMA_CH0SA                   0x1200
+#define REG_DDMA_CH0DA                   0x1204
+#define REG_DDMA_CH0CTRL                0x1208
+#define REG_DDMA_CH1SA                   0x1210
+#define REG_DDMA_CH1DA	0x1214
+#define REG_DDMA_CH1CTRL                0x1218
+#define REG_DDMA_CH2SA                   0x1220
+#define REG_DDMA_CH2DA                   0x1224
+#define REG_DDMA_CH2CTRL                0x1228
+#define REG_DDMA_CH3SA                   0x1230
+#define REG_DDMA_CH3DA                   0x1234
+#define REG_DDMA_CH3CTRL                0x1238
+#define REG_DDMA_CH4SA                   0x1240
+#define REG_DDMA_CH4DA                   0x1244
+#define REG_DDMA_CH4CTRL                0x1248
+#define REG_DDMA_CH5SA                   0x1250
+#define REG_DDMA_CH5DA                   0x1254
+#define REG_DDMA_CH5CTRL                0x1258
+#define REG_DDMA_INT_MSK                0x12E0
+#define REG_DDMA_CHSTATUS              0x12E8
+#define REG_DDMA_CHKSUM                 0x12F0
+#define REG_DDMA_MONITER                0x12FC
+
+#define REG_Q0_Q1_INFO_8814A		0x1400
+#define REG_Q2_Q3_INFO_8814A		0x1404
+#define REG_Q4_Q5_INFO_8814A		0x1408
+#define REG_Q6_Q7_INFO_8814A		0x140C
+#define REG_MGQ_HIQ_INFO_8814A	0x1410
+#define REG_CMDQ_BCNQ_INFO_8814A	0x1414
+
+#define DDMA_LEN_MASK		0x0001FFFF
+#define FW_CHKSUM_DUMMY_SZ		8
+#define DDMA_CH_CHKSUM_CNT		BIT(24)
+#define DDMA_RST_CHKSUM_STS		BIT(25)
+#define DDMA_MODE_BLOCK_CPU		BIT(26)
+#define DDMA_CHKSUM_FAIL			BIT(27)
+#define DDMA_DA_W_DISABLE			BIT(28)
+#define DDMA_CHKSUM_EN			BIT(29)
+#define DDMA_CH_OWN	BIT(31)
+
+
+/* 3081 FWDL */
+#define FWDL_EN                 BIT0
+#define IMEM_BOOT_DL_RDY        BIT1
+#define IMEM_BOOT_CHKSUM_FAIL   BIT2
+#define IMEM_DL_RDY             BIT3
+#define IMEM_CHKSUM_OK        BIT4
+#define DMEM_DL_RDY             BIT5
+#define DMEM_CHKSUM_OK        BIT6
+#define EMEM_DL_RDY             BIT7
+#define EMEM_CHKSUM_FAIL        BIT8
+#define EMEM_TXBUF_DL_RDY       BIT9
+#define EMEM_TXBUF_CHKSUM_FAIL  BIT10
+#define CPU_CLK_SWITCH_BUSY     BIT11
+#define CPU_CLK_SEL             (BIT12 | BIT13)
+#define FWDL_OK                 BIT14
+#define FW_INIT_RDY             BIT15
+#define R_EN_BOOT_FLASH         BIT20
+
+#define OCPBASE_IMEM_3081        0x00000000
+#define OCPBASE_DMEM_3081        0x00200000
+#define OCPBASE_RPTBUF_3081      0x18660000
+#define OCPBASE_RXBUF2_3081      0x18680000
+#define OCPBASE_RXBUF_3081       0x18700000
+#define OCPBASE_TXBUF_3081       0x18780000
+
+
+#define REG_FAST_EDCA_VOVI_SETTING_8814A 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING_8814A 0x144C
+
+
+/* -----------------------------------------------------
+ *   */
+
+
+/* -----------------------------------------------------
+ *
+ *	Redifine 8192C register definition for compatibility
+ *
+ * ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+ * NOTE: DO NOT Remove these definition. Use later. */
+#define	EFUSE_CTRL_8814A					REG_EFUSE_CTRL_8814A		/* E-Fuse Control. */
+#define	EFUSE_TEST_8814A					REG_LDO_EFUSE_CTRL_8814A		/* E-Fuse Test. */
+#define	MSR_8814A							(REG_CR_8814A + 2)		/* Media Status register */
+#define	ISR_8814A							REG_HISR0_8814A
+#define	TSFR_8814A							REG_TSFTR_8814A			/* Timing Sync Function Timer Register. */
+
+#define PBP_8814A							REG_PBP_8814A
+
+/* Redifine MACID register, to compatible prior ICs. */
+#define	IDR0_8814A							REG_MACID_8814A			/* MAC ID Register, Offset 0x0050-0x0053 */
+#define	IDR4_8814A							(REG_MACID_8814A + 4)	/* MAC ID Register, Offset 0x0054-0x0055 */
+
+
+/*
+ * 9. Security Control Registers	(Offset: )
+ *   */
+#define	RWCAM_8814A						REG_CAMCMD_8814A		/* IN 8190 Data Sheet is called CAMcmd */
+#define	WCAMI_8814A						REG_CAMWRITE_8814A		/* Software write CAM input content */
+#define	RCAMO_8814A						REG_CAMREAD_8814A		/* Software read/write CAM config */
+#define	CAMDBG_8814A						REG_CAMDBG_8814A
+#define	SECR_8814A							REG_SECCFG_8814A		/* Security Configuration Register */
+
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8814A					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8814A					BIT31		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8814A					BIT30		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8814A				BIT29		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8814A					BIT28		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8814A					BIT27		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8814A				BIT26		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8814A					BIT25		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8814A		BIT24		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8814A				BIT20		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8814A					BIT16		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8814A		BIT15		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8814A				BIT14		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8814A					BIT12		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8814A					BIT10		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8814A					BIT9			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8814A						BIT8			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8814A					BIT7			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8814A					BIT6			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8814A					BIT5			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8814A					BIT4			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8814A					BIT3			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8814A					BIT2			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8814A						BIT1			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8814A						BIT0			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_MCUERR_8814A						BIT28		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT7_8814A				BIT27		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8814A				BIT26		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8814A				BIT25		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8814A				BIT24		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8814A				BIT23		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8814A				BIT22		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8814A				BIT21		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8814A					BIT20		/* Beacon Queue DMA OK Interrup 7 */
+#define	IMR_BCNDOK6_8814A					BIT19		/* Beacon Queue DMA OK Interrup 6 */
+#define	IMR_BCNDOK5_8814A					BIT18		/* Beacon Queue DMA OK Interrup 5 */
+#define	IMR_BCNDOK4_8814A					BIT17		/* Beacon Queue DMA OK Interrup 4 */
+#define	IMR_BCNDOK3_8814A					BIT16		/* Beacon Queue DMA OK Interrup 3 */
+#define	IMR_BCNDOK2_8814A					BIT15		/* Beacon Queue DMA OK Interrup 2 */
+#define	IMR_BCNDOK1_8814A					BIT14		/* Beacon Queue DMA OK Interrup 1 */
+#define	IMR_ATIMEND_E_8814A				BIT13		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8814A					BIT11		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8814A					BIT10		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8814A					BIT9			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8814A					BIT8			/* Receive FIFO Overflow */
+
+
+#ifdef CONFIG_PCI_HCI
+	#define IMR_TX_MASK			(IMR_VODOK_8814A | IMR_VIDOK_8814A | IMR_BEDOK_8814A | IMR_BKDOK_8814A | IMR_MGNTDOK_8814A | IMR_HIGHDOK_8814A)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8814A | IMR_TXBCN0OK_8814A | IMR_TXBCN0ERR_8814A | IMR_BCNDERR0_8814A)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8814A | IMR_VODOK_8814A | IMR_BEDOK_8814A | IMR_BKDOK_8814A)
+#endif
+
+
+/*===================================================================
+=====================================================================
+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!!!!!!
+=====================================================================
+=====================================================================*/
+
+
+/* -----------------------------------------------------
+ *
+ *	0xFE00h ~ 0xFE55h	USB Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* 2 Special Option */
+#define USB_AGG_EN_8814A			BIT(7)
+#define REG_USB_HRPWM_U3			0xF052
+
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8814A       (2048-1)	/* 20130415 KaiYuan add for 8814 */
+
+#endif /* __RTL8814A_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_sreset.h
new file mode 100644
index 000000000000..d65cb98a530e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_sreset.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL88814A_SRESET_H_
+#define _RTL8814A_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8814_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8814_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_xmit.h
new file mode 100644
index 000000000000..5b1e9660cddc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8814a_xmit.h
@@ -0,0 +1,309 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_XMIT_H__
+#define __RTL8814A_XMIT_H__
+
+typedef struct txdescriptor_8814 {
+	/* Offset 0 */
+	u32 pktlen:16;
+	u32 offset:8;
+	u32 bmc:1;
+	u32 htc:1;
+	u32 ls:1;
+} TXDESC_8814, *PTXDESC_8814;
+
+
+#define OFFSET_SZ	0
+#define OFFSET_SHT	16
+
+
+
+#ifdef CONFIG_SDIO_HCI
+	#define SET_TX_DESC_SDIO_TXSEQ_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+#endif /* CONFIG_SDIO_HCI */
+
+/* -----------------------------------------------------------------
+ *	RTL8814A TX BUFFER DESC
+ * -----------------------------------------------------------------
+ *
+- Each TXBD has 4 segment.
+ -- For 32 bit, each segment is 8 bytes.
+ -- For 64 bit, each segment is 16 bytes.
+*/
+#if 0
+	#if 1 /* 32 bit */
+		#define SET_TX_EXTBUFF_DESC_LEN_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*8), 0, 16, __Value)
+		#define SET_TX_EXTBUFF_DESC_ADDR_LOW_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*8)+4, 0, 32, __Value)
+	#else /* 64 bit */
+		#define SET_TX_EXTBUFF_DESC_LEN_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16), 0, 16, __Value)
+		#define SET_TX_EXTBUFF_DESC_ADDR_LOW_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16)+4, 0, 32, __Value)
+	#endif
+	#define SET_TX_EXTBUFF_DESC_ADDR_HIGH_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16)+8, 0, 32, __Value)
+#endif
+/*c2h-DWORD 2*/
+#define GET_RX_STATUS_DESC_RPT_SEL_8814A(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+8, 28, 1)
+
+/* *********************************************************
+ * for Txfilldescroptor8814Ae, fill the desc content. */
+#if 1 /* 32 bit */
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8)+4, 0, 32, __Valeu)
+#else /* 64 bit */
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+4, 0, 32, __Valeu)
+#endif
+#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+8, 0, 32, __Valeu)
+
+/* ********************************************************* */
+
+/* TX buffer
+ * *************
+ * Dword 0 */
+#define SET_TX_BUFF_DESC_LEN_0_8814A(__pTxDesc, __Valeu)			SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+#define GET_TX_BUFF_DESC_OWN_8814A(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+/* Dword 1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_LOW_0_8814A(__pTxDesc)			LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+/* Dword 2 */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8814A(__pTxDesc)			LE_BITS_TO_4BYTE(__pTxDesc+8, 0, 32)
+/* Dword 3 */ /* RESERVED 0 */
+
+#if 0 /* 64 bit */
+	/* Dword 4 */
+	#define SET_TX_BUFF_DESC_LEN_1_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 16, __Value)
+	#define SET_TX_BUFF_DESC_AMSDU_1_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 31, 1, __Value)
+	/* Dword 5 */
+	#define SET_TX_BUFF_DESC_ADDR_LOW_1_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 32, __Value)
+	/* Dword 6 */
+	#define SET_TX_BUFF_DESC_ADDR_HIGH_1_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 32, __Value)
+	/* Dword 7 */ /* RESERVED 0 */
+	/* Dword 8 */
+	#define SET_TX_BUFF_DESC_LEN_2_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 16, __Value)
+	#define SET_TX_BUFF_DESC_AMSDU_2_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 31, 1, __Value)
+	/* Dword 9 */
+	#define SET_TX_BUFF_DESC_ADDR_LOW_2_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 32, __Value)
+	/* Dword 10 */
+	#define SET_TX_BUFF_DESC_ADDR_HIGH_2_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+	/* Dword 11 */ /* RESERVED 0 */
+	/* Dword 12 */
+	#define SET_TX_BUFF_DESC_LEN_3_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 16, __Value)
+	#define SET_TX_BUFF_DESC_AMSDU_3_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 31, 1, __Value)
+	/* Dword 13 */
+	#define SET_TX_BUFF_DESC_ADDR_LOW_3_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+52, 0, 32, __Value)
+	/* Dword 14 */
+	#define SET_TX_BUFF_DESC_ADDR_HIGH_3_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+56, 0, 32, __Value)
+	/* Dword 15 */ /* RESERVED 0 */
+#endif
+
+/* *****Desc content
+ * TX Info
+ * *************
+ * Dword 0 */
+#define SET_TX_DESC_PKT_SIZE_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define GET_TX_DESC_PKT_SIZE_8814A(__pTxDesc)									LE_BITS_TO_4BYTE(__pTxDesc, 0, 16)
+#define SET_TX_DESC_OFFSET_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define GET_TX_DESC_OFFSET_8814A(__pTxDesc)									LE_BITS_TO_4BYTE(__pTxDesc, 16, 8)
+#define SET_TX_DESC_BMC_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8814A(__pTxDesc, __Value)								SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_LAST_SEG_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+#define SET_TX_DESC_LINIP_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+#define SET_TX_DESC_AMSDU_PAD_EN_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8814A(__pTxDesc, __Value)								SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+#define SET_TX_DESC_DISQSELSEQ_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_CAP_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 30, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_MODE_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 31, 1, __Value)
+
+
+/* Dword 2 */
+#define SET_TX_DESC_PAID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+#define SET_TX_DESC_CCA_RTS_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL_0_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL_1_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_8814A(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define GET_TX_DESC_MORE_FRAG_8814A(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc+8, 17, 1)
+#define SET_TX_DESC_RAW_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_SPE_RPT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_NULL_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_GID_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+#define SET_TX_DESC_HW_AES_IV_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 31, 1, __Value)
+
+
+/* Dword 3 */
+#define SET_TX_DESC_WHEADER_LEN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 5, __Value)
+#define SET_TX_DESC_EARLY_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HW_SSN_SEL_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_CHECK_EN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TRY_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_CTROL_STBC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_SIGNALING_TA_PKT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 17, 1, __Value)
+#define SET_TX_DESC_PORT_ID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 21, 3, __Value)/* 20130415 KaiYuan add for 8814 */
+#define SET_TX_DESC_TX_ANT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
+#define SET_TX_DESC_TX_POWER_OFFSET_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_ANTSEL_A_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+#define SET_TX_DESC_ANTSEL_B_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+#define SET_TX_DESC_ANT_MAPA_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 2, __Value)
+#define SET_TX_DESC_ANT_MAPB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 24, 2, __Value)
+#define SET_TX_DESC_ANT_MAPC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 26, 2, __Value)
+#define SET_TX_DESC_ANT_MAPD_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 28, 2, __Value)
+
+
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	#define SET_TX_DESC_TX_BUFFER_SIZE_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#else
+	#define SET_TX_DESC_TX_DESC_CHECKSUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+#define SET_TX_DESC_NTX_MAP_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 20, 4, __Value)
+#define SET_TX_DESC_USB_TXAGG_NUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+
+/* Dword 8 */
+#define SET_TX_DESC_RTS_RC_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RTY_TH_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_EN_HWEXSEQ_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 14, 1, __Value)
+#define SET_TX_DESC_HWSEQ_EN_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#if (DEV_BUS_TYPE != RT_SDIO_INTERFACE)
+	#define SET_TX_DESC_NEXT_HEAD_PAGE_L_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#else
+	#define SET_TX_DESC_SDIO_SEQ_8814A(__pTxDesc, __Value)(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value) /* 20130415 KaiYuan add for 8814AS */
+#endif
+#define SET_TX_DESC_TAIL_PAGE_L_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LENGTH_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_TXBF_PATH_8814A(__pTxDesc, __Value)								SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 11, 1, __Value)
+#define SET_TX_DESC_SEQ_8814A(__pTxDesc, __Value)										SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_NEXT_HEAD_PAGE_H_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 4, __Value)
+#define SET_TX_DESC_TAIL_PAGE_H_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 28, 4, __Value)
+
+
+
+#define SET_EARLYMODE_PKTNUM_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
+#define SET_EARLYMODE_LEN3_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+
+void rtl8814a_cal_txdesc_chksum(u8 *ptxdesc);
+void rtl8814a_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8814a_fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8814a_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8814a_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8814au_init_xmit_priv(PADAPTER padapter);
+	void rtl8814au_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8814au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8814au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8814au_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8814au_xmit_buf_handler(PADAPTER padapter);
+	void rtl8814au_xmit_tasklet(void *priv);
+	s32 rtl8814au_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8814ae_init_xmit_priv(PADAPTER padapter);
+	void rtl8814ae_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8814ae_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void rtl8814ae_xmitframe_resume(_adapter *padapter);
+	s32 rtl8814ae_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8814ae_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8814ae_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8814ae_xmit_tasklet(void *priv);
+#ifdef CONFIG_XMIT_THREAD_MODE
+	s32 rtl8814ae_xmit_buf_handler(_adapter *padapter);
+#endif
+#endif
+
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, u8 *ptxdesc);
+u8
+SCMapping_8814(
+	IN	PADAPTER		Adapter,
+	IN	struct pkt_attrib	*pattrib
+);
+
+u8
+BWMapping_8814(
+	IN	PADAPTER		Adapter,
+	IN	struct pkt_attrib	*pattrib
+);
+
+
+#endif /* __RTL8814_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821a_spec.h
new file mode 100644
index 000000000000..1379ffc3cf9d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821a_spec.h
@@ -0,0 +1,90 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8821A_SPEC_H__
+#define __RTL8821A_SPEC_H__
+
+#include <drv_conf.h>
+/* This file should based on "hal_com_reg.h" */
+#include <hal_com_reg.h>
+/* Because 8812a and 8821a is the same serial,
+ * most of 8821a register definitions are the same as 8812a. */
+#include <rtl8812a_spec.h>
+
+
+/* ************************************************************
+ * 8821A Regsiter offset definition
+ * ************************************************************ */
+
+/* ************************************************************
+ * MAC register
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *	0x0000h ~ 0x00FFh	System Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ * ----------------------------------------------------- */
+#define REG_WOWLAN_WAKE_REASON          REG_MCUTST_WOWLAN
+
+/* -----------------------------------------------------
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0300h ~ 0x03FFh	PCIe
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ * ----------------------------------------------------- */
+
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_FREE_TXPG2		0x024
+#define SDIO_REG_HCPWM1_8821A	0x025
+
+/* ************************************************************
+ * Regsiter Bit and Content definition
+ * ************************************************************ */
+
+#endif /* __RTL8821A_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821a_xmit.h
new file mode 100644
index 000000000000..5d973cdc7926
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821a_xmit.h
@@ -0,0 +1,173 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8821A_XMIT_H__
+#define __RTL8821A_XMIT_H__
+
+#include <drv_types.h>
+
+typedef struct txdescriptor_8821a {
+	/* Offset 0 */
+	u32 pktlen:16;
+	u32 offset:8;
+	u32 bmc:1;
+	u32 htc:1;
+	u32 rsvd0026:1;
+	u32 rsvd0027:1;
+	u32 linip:1;
+	u32 noacm:1;
+	u32 gf:1;
+	u32 rsvd0031:1;
+
+	/* Offset 4 */
+	u32 macid:7;
+	u32 rsvd0407:1;
+	u32 qsel:5;
+	u32 rdg_nav_ext:1;
+	u32 lsig_txop_en:1;
+	u32 pifs:1;
+	u32 rate_id:5;
+	u32 en_desc_id:1;
+	u32 sectype:2;
+	u32 pkt_offset:5; /* unit: 8 bytes */
+	u32 moredata:1;
+	u32 txop_ps_cap:1;
+	u32 txop_ps_mode:1;
+
+	/* Offset 8 */
+	u32 p_aid:9;
+	u32 rsvd0809:1;
+	u32 cca_rts:2;
+	u32 agg_en:1;
+	u32 rdg_en:1;
+	u32 null_0:1;
+	u32 null_1:1;
+	u32 bk:1;
+	u32 morefrag:1;
+	u32 raw:1;
+	u32 spe_rpt:1;
+	u32 ampdu_density:3;
+	u32 bt_null:1;
+	u32 g_id:6;
+	u32 rsvd0830:2;
+
+	/* Offset 12 */
+	u32 wheader_len:4;
+	u32 chk_en:1;
+	u32 early_rate:1;
+	u32 hw_ssn_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 navusehdr:1;
+	u32 use_max_len:1;
+	u32 max_agg_num:5;
+	u32 ndpa:2;
+	u32 ampdu_max_time:8;
+
+	/* Offset 16 */
+	u32 datarate:7;
+	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 rtsrate:5;
+	u32 pcts_en:1;
+	u32 pcts_mask_idx:2;
+
+	/* Offset 20 */
+	u32 data_sc:4;
+	u32 data_short:1;
+	u32 data_bw:2;
+	u32 data_ldpc:1;
+	u32 data_stbc:2;
+	u32 vcs_stbc:2;
+	u32 rts_short:1;
+	u32 rts_sc:4;
+	u32 rsvd2016:7;
+	u32 tx_ant:4;
+	u32 txpwr_offset:3;
+	u32 rsvd2031:1;
+
+	/* Offset 24 */
+	u32 sw_define:12;
+	u32 mbssid:4;
+	u32 antsel_A:3;
+	u32 antsel_B:3;
+	u32 antsel_C:3;
+	u32 antsel_D:3;
+	u32 rsvd2428:4;
+
+	/* Offset 28 */
+	u32 checksum:16;
+	u32 rsvd2816:8;
+	u32 usb_txagg_num:8;
+
+	/* Offset 32 */
+	u32 rts_rc:6;
+	u32 bar_rty_th:2;
+	u32 data_rc:6;
+	u32 rsvd3214:1;
+	u32 en_hwseq:1;
+	u32 nextneadpage:8;
+	u32 tailpage:8;
+
+	/* Offset 36 */
+	u32 padding_len:11;
+	u32 txbf_path:1;
+	u32 seq:12;
+	u32 final_data_rate:8;
+} TXDESC_8821A, *PTXDESC_8821A;
+
+#ifdef CONFIG_SDIO_HCI
+s32 InitXmitPriv8821AS(PADAPTER padapter);
+void FreeXmitPriv8821AS(PADAPTER padapter);
+s32 XmitBufHandler8821AS(PADAPTER padapter);
+s32 MgntXmit8821AS(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	HalXmitNoLock8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 HalXmit8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe);
+#ifndef CONFIG_SDIO_TX_TASKLET
+thread_return XmitThread8821AS(thread_context context);
+#endif /* !CONFIG_SDIO_TX_TASKLET */
+#endif /* CONFIG_SDIO_HCI */
+
+#if 0
+#ifdef CONFIG_USB_HCI
+s32 rtl8821au_init_xmit_priv(PADAPTER padapter);
+void rtl8821au_free_xmit_priv(PADAPTER padapter);
+s32 rtl8821au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8821au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32 rtl8821au_hal_xmitframe_enqueue(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8821au_xmit_buf_handler(PADAPTER padapter);
+void rtl8821au_xmit_tasklet(void *priv);
+s32 rtl8821au_xmitframe_complete(PADAPTER padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8821e_init_xmit_priv(PADAPTER padapter);
+void rtl8821e_free_xmit_priv(PADAPTER padapter);
+struct xmit_buf *rtl8821e_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+void rtl8821e_xmitframe_resume(PADAPTER padapter);
+s32 rtl8821e_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8821e_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+void rtl8821e_xmit_tasklet(void *priv);
+#endif /* CONFIG_PCI_HCI */
+#endif
+
+#endif /* __RTL8821_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_dm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_dm.h
new file mode 100644
index 000000000000..b1e4fe608b2a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_dm.h
@@ -0,0 +1,23 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812C_DM_H__
+#define __RTL8812C_DM_H__
+
+void rtl8821c_phy_init_dm_priv(PADAPTER);
+void rtl8821c_phy_deinit_dm_priv(PADAPTER);
+void rtl8821c_phy_init_haldm(PADAPTER);
+void rtl8821c_phy_haldm_watchdog(PADAPTER);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_hal.h
new file mode 100644
index 000000000000..75d87505a265
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_hal.h
@@ -0,0 +1,83 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821C_HAL_H_
+#define _RTL8821C_HAL_H_
+
+#include <osdep_service.h>		/* BIT(x) */
+#include "../hal/halmac/halmac_api.h"	/* MAC REG definition */
+#include "hal_data.h"
+#include "rtl8821c_spec.h"
+#include "../hal/rtl8821c/hal8821c_fw.h"
+
+#ifdef CONFIG_USB_HCI
+#include <rtl8821cu_hal.h>
+#endif
+#ifdef CONFIG_SDIO_HCI
+#include <rtl8821cs_hal.h>
+#endif
+#ifdef CONFIG_PCI_HCI
+#include <rtl8821ce_hal.h>
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#define FIFO_BLOCK_SIZE		32768 /*@Block size = 32K*/
+#define RX_FIFO_EXPANDING	(1 * FIFO_BLOCK_SIZE)
+#else
+#define RX_FIFO_EXPANDING	0
+#endif
+
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+			/* 8821C - RX FIFO :16K ,for RX agg DMA mode = 16K, Rx agg USB mode could large than 16k*/
+			/* #define MAX_RECVBUF_SZ		(16384 + RX_FIFO_EXPANDING)*/
+			/* For Max throughput issue , need to use USB AGG mode to replace DMA AGG mode*/
+			#define MAX_RECVBUF_SZ (32768)
+
+			/*#define MAX_RECVBUF_SZ_8821C (24576)*/ /* 24k*/
+			/*#define MAX_RECVBUF_SZ_8821C (20480)*/ /*20K*/
+			/*#define MAX_RECVBUF_SZ_8821C (10240) */ /*10K*/
+			/*#define MAX_RECVBUF_SZ_8821C (15360)*/ /*15k < 16k*/
+			/*#define MAX_RECVBUF_SZ_8821C (8192+1024)*/ /* 8K+1k*/
+		#else
+			#define MAX_RECVBUF_SZ (4096 + RX_FIFO_EXPANDING) /* about 4K */
+		#endif
+	#endif/* !MAX_RECVBUF_SZ*/
+
+#elif defined(CONFIG_PCI_HCI)
+	/*#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+	#define MAX_RECVBUF_SZ (9100)
+	#else*/
+	#define MAX_RECVBUF_SZ (4096 + RX_FIFO_EXPANDING) /* about 4K */
+	/*#endif*/
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	#define MAX_RECVBUF_SZ	(16384 + RX_FIFO_EXPANDING)
+#endif
+
+void init_hal_spec_rtl8821c(PADAPTER);
+/* MP Functions */
+#ifdef CONFIG_MP_INCLUDED
+void rtl8821c_prepare_mp_txdesc(PADAPTER, struct mp_priv *);	/* rtw_mp.c */
+void rtl8821c_mp_config_rfpath(PADAPTER);			/* hal_mp.c */
+#endif
+
+#ifdef CONFIG_PCI_HCI
+u16 get_txbd_rw_reg(u16 q_idx);
+#endif
+
+#endif /* _RTL8821C_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_spec.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_spec.h
new file mode 100644
index 000000000000..26218df5bec0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821c_spec.h
@@ -0,0 +1,201 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8821C_SPEC_H__
+#define __RTL8821C_SPEC_H__
+
+#define EFUSE_MAP_SIZE		HALMAC_EFUSE_SIZE_8821C
+
+/*
+ * MAC Register definition
+ */
+#define REG_AFE_XTAL_CTRL			REG_AFE_CTRL1_8821C	/* hal_com.c & phydm */
+#define REG_AFE_PLL_CTRL			REG_AFE_CTRL2_8821C	/* hal_com.c & phydm */
+#define REG_MAC_PHY_CTRL			REG_AFE_CTRL3_8821C	/* phydm only */
+#define REG_LEDCFG0					REG_LED_CFG_8821C	/* rtw_mp.c */
+#define MSR							(REG_CR_8821C + 2)	/* rtw_mp.c */
+#define MSR1						REG_CR_EXT_8821C	/* rtw_mp.c & hal_com.c */
+#define REG_C2HEVT_MSG_NORMAL		0x1A0			/* hal_com.c */
+#define REG_C2HEVT_CLEAR			0x1AF			/* hal_com.c */
+#define REG_BCN_CTRL_1				REG_BCN_CTRL_CLINT0_8821C/* hal_com.c */
+#define REG_TSFTR1					REG_FREERUN_CNT_8821C	/* hal_com.c */
+#define REG_WOWLAN_WAKE_REASON	0x01C7
+#define REG_GPIO_PIN_CTRL_2			REG_GPIO_EXT_CTRL_8821C
+
+/* RXERR_RPT, for rtw_mp.c */
+#define RXERR_TYPE_OFDM_PPDU		0
+#define RXERR_TYPE_OFDM_FALSE_ALARM	2
+#define RXERR_TYPE_OFDM_MPDU_OK		0
+#define RXERR_TYPE_OFDM_MPDU_FAIL	1
+#define RXERR_TYPE_CCK_PPDU		3
+#define RXERR_TYPE_CCK_FALSE_ALARM	5
+#define RXERR_TYPE_CCK_MPDU_OK		3
+#define RXERR_TYPE_CCK_MPDU_FAIL	4
+#define RXERR_TYPE_HT_PPDU		8
+#define RXERR_TYPE_HT_FALSE_ALARM	9
+#define RXERR_TYPE_HT_MPDU_TOTAL	6
+#define RXERR_TYPE_HT_MPDU_OK		6
+#define RXERR_TYPE_HT_MPDU_FAIL		7
+#define RXERR_TYPE_RX_FULL_DROP		10
+
+#define RXERR_COUNTER_MASK		BIT_MASK_RPT_COUNTER_8821C
+#define RXERR_RPT_RST			BIT_RXERR_RPT_RST_8821C
+#define _RXERR_RPT_SEL(type)		(BIT_RXERR_RPT_SEL_V1_3_0_8821C(type) \
+		| ((type & 0x10) ? BIT_RXERR_RPT_SEL_V1_4_8821C : 0))
+
+/*
+ * BB Register definition
+ */
+#define rPMAC_Reset				0x100	/* hal_mp.c */
+
+#define rFPGA0_RFMOD				0x800
+#define rFPGA0_TxInfo				0x804
+#define rOFDMCCKEN_Jaguar		0x808	/* hal_mp.c */
+#define rFPGA0_TxGainStage		0x80C	/* phydm only */
+#define rFPGA0_XA_HSSIParameter1	0x820	/* hal_mp.c */
+#define rFPGA0_XA_HSSIParameter2	0x824	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter1	0x828	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter2	0x82C	/* hal_mp.c */
+#define rTxAGC_B_Rate18_06		0x830
+#define rTxAGC_B_Rate54_24		0x834
+#define rTxAGC_B_CCK1_55_Mcs32	0x838
+#define rCCAonSec_Jaguar			0x838	/* hal_mp.c */
+#define rTxAGC_B_Mcs03_Mcs00		0x83C
+#define rTxAGC_B_Mcs07_Mcs04		0x848
+#define rTxAGC_B_Mcs11_Mcs08		0x84C
+#define rFPGA0_XA_RFInterfaceOE		0x860
+#define rFPGA0_XB_RFInterfaceOE		0x864
+#define rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86C
+#define rFPGA0_XAB_RFInterfaceSW		0x870
+#define rFPGA0_XAB_RFParameter		0x878
+#define rFPGA0_AnalogParameter4		0x88C	/* hal_mp.c & phydm */
+#define rFPGA0_XB_LSSIReadBack		0x8A4	/* phydm */
+#define rHSSIRead_Jaguar				0x8B0	/* RF read addr (rtl8821c_phy.c) */
+
+#define	rC_TxScale_Jaguar2			0x181C  /* Pah_C TX scaling factor (hal_mp.c) */
+#define	rC_IGI_Jaguar2				0x1850	/* Initial Gain for path-C (hal_mp.c) */
+
+#define rFPGA1_TxInfo					0x90C	/* hal_mp.c */
+#define rSingleTone_ContTx_Jaguar		0x914	/* hal_mp.c */
+
+#define rCCK0_System					0xA00
+#define rCCK0_AFESetting				0xA04
+
+#define rCCK0_DSPParameter2			0xA1C
+#define rCCK0_TxFilter1				0xA20
+#define rCCK0_TxFilter2				0xA24
+#define rCCK0_DebugPort				0xA28
+#define rCCK0_FalseAlarmReport		0xA2C
+
+#define	rD_TxScale_Jaguar2			0x1A1C  /* Path_D TX scaling factor (hal_mp.c) */
+#define	rD_IGI_Jaguar2				0x1A50	/* Initial Gain for path-D (hal_mp.c) */
+
+#define rOFDM0_TRxPathEnable			0xC04
+#define rOFDM0_TRMuxPar				0xC08
+#define rA_TxScale_Jaguar				0xC1C	/* Pah_A TX scaling factor (hal_mp.c) */
+#define rOFDM0_RxDetector1			0xC30	/* rtw_mp.c */
+#define rOFDM0_ECCAThreshold			0xC4C	/* phydm only */
+#define rOFDM0_XAAGCCore1			0xC50	/* phydm only */
+#define rA_IGI_Jaguar					0xC50	/* Initial Gain for path-A (hal_mp.c) */
+#define rOFDM0_XBAGCCore1			0xC58	/* phydm only */
+#define rOFDM0_XATxIQImbalance		0xC80	/* phydm only */
+#define rA_LSSIWrite_Jaguar			0xC90	/* RF write addr, LSSI Parameter (rtl8821c_phy.c) */
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xCB0	/* hal_mp.c */
+#define	rB_RFE_Pinmux_Jaguar	0xEB0	/* Path_B RFE control pinmux */
+#define	rA_RFE_Inv_Jaguar		0xCB4	/* Path_A RFE cotrol */  
+#define	rB_RFE_Inv_Jaguar		0xEB4	/* Path_B RFE control */
+#define	rA_RFE_Jaguar			0xCB8 	/* Path_A RFE cotrol */  
+#define	rB_RFE_Jaguar			0xEB8	/* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define	r_ANTSEL_SW_Jaguar		0x900	/* ANTSEL SW Control */
+#define	bMask_RFEInv_Jaguar	0x3FF00000
+#define	bMask_AntselPathFollow_Jaguar 0x00030000   
+
+#define rOFDM1_LSTF					0xD00
+#define rOFDM1_TRxPathEnable			0xD04	/* hal_mp.c */
+#define rA_PIRead_Jaguar				0xD04	/* RF readback with PI (rtl8821c_phy.c) */
+#define rA_SIRead_Jaguar				0xD08	/* RF readback with SI (rtl8821c_phy.c) */
+#define rB_PIRead_Jaguar				0xD44	/* RF readback with PI (rtl8821c_phy.c) */
+#define rB_SIRead_Jaguar				0xD48	/* RF readback with SI (rtl8821c_phy.c) */
+
+#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 rB_TxScale_Jaguar				0xE1C	/* Path_B TX scaling factor (hal_mp.c) */
+#define rB_IGI_Jaguar					0xE50	/* Initial Gain for path-B (hal_mp.c) */
+#define rB_LSSIWrite_Jaguar			0xE90	/* RF write addr, LSSI Parameter (rtl8821c_phy.c) */
+
+/* Page1(0x100) */
+#define bBBResetB					0x100
+
+/* Page8(0x800) */
+#define bCCKEn						0x1000000
+#define bOFDMEn						0x2000000
+/* Reg 0x80C rFPGA0_TxGainStage */
+#define bXBTxAGC						0xF00
+#define bXCTxAGC						0xF000
+#define bXDTxAGC						0xF0000
+
+/* PageA(0xA00) */
+#define bCCKBBMode					0x3
+
+#define bCCKScramble					0x8
+#define bCCKTxRate					0x3000
+
+/* General */
+#define bMaskByte0		0xFF		/* mp, rtw_odm.c & phydm */
+#define bMaskByte1		0xFF00		/* hal_mp.c & phydm */
+#define bMaskByte2		0xFF0000	/* hal_mp.c & phydm */
+#define bMaskByte3		0xFF000000	/* hal_mp.c & phydm */
+#define bMaskHWord		0xFFFF0000	/* hal_com.c, rtw_mp.c */
+#define bMaskLWord		0x0000FFFF	/* mp, hal_com.c & phydm */
+#define bMaskDWord		0xFFFFFFFF	/* mp, hal, rtw_odm.c & phydm */
+
+#define bEnable			0x1		/* hal_mp.c, rtw_mp.c */
+#define bDisable			0x0		/* rtw_mp.c */
+
+#define MAX_STALL_TIME		50		/* unit: us, hal_com_phycfg.c */
+
+#define Rx_Smooth_Factor		20		/* phydm only */
+
+/*
+ * RF Register definition
+ */
+#define RF_AC			0x00
+#define RF_AC_Jaguar		0x00	/* hal_mp.c */
+#define RF_CHNLBW		0x18	/* rtl8821c_phy.c */
+#define RF_0x52			0x52
+
+struct hw_port_reg {
+	u32 net_type;	/*reg_offset*/
+	u8 net_type_shift;
+	u32 macaddr;	/*reg_offset*/
+	u32 bssid;	/*reg_offset*/
+	u32 bcn_ctl;			/*reg_offset*/
+	u32 tsf_rst;			/*reg_offset*/
+	u8 tsf_rst_bit;
+	u32 bcn_space;		/*reg_offset*/
+	u8 bcn_space_shift;
+	u16 bcn_space_mask;
+	u32	ps_aid;			/*reg_offset*/
+};
+
+#endif /* __RTL8192E_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821ce_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821ce_hal.h
new file mode 100644
index 000000000000..426002a30c9a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821ce_hal.h
@@ -0,0 +1,23 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821CE_HAL_H_
+#define _RTL8821CE_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8821ce_ops.c */
+void rtl8821ce_set_hal_ops(PADAPTER);
+
+#endif /* _RTL8821CE_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821cs_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821cs_hal.h
new file mode 100644
index 000000000000..ceecc15f966d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821cs_hal.h
@@ -0,0 +1,23 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821CS_HAL_H_
+#define _RTL8821CS_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8821cs_ops.c */
+u8 rtl8821cs_set_hal_ops(PADAPTER);
+
+#endif /* _RTL8821CS_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821cu_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821cu_hal.h
new file mode 100644
index 000000000000..aec437224c73
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8821cu_hal.h
@@ -0,0 +1,24 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821CU_HAL_H_
+#define _RTL8821CU_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8821cu_ops.c */
+u8 rtl8821cu_set_hal_ops(PADAPTER);
+void rtl8821cu_set_hw_type(struct dvobj_priv *pdvobj);
+
+#endif /* _RTL8821CU_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822b_hal.h
new file mode 100644
index 000000000000..3cf482e06ce1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822b_hal.h
@@ -0,0 +1,229 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_HAL_H_
+#define _RTL8822B_HAL_H_
+
+#include <osdep_service.h>		/* BIT(x) */
+#include <drv_types.h>			/* PADAPTER */
+#include "../hal/halmac/halmac_api.h"	/* MAC REG definition */
+
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#define MAX_RECVBUF_SZ		46080	/* 45KB, TX: (256-64)KB */
+#else /* !CONFIG_SUPPORT_TRX_SHARED */
+#define MAX_RECVBUF_SZ		24576	/* 24KB, TX: 256KB */
+#endif /* !CONFIG_SUPPORT_TRX_SHARED */
+
+/*
+ * MAC Register definition
+ */
+#define REG_AFE_XTAL_CTRL	REG_AFE_CTRL1_8822B	/* hal_com.c & phydm */
+#define REG_AFE_PLL_CTRL	REG_AFE_CTRL2_8822B	/* hal_com.c & phydm */
+#define REG_MAC_PHY_CTRL	REG_AFE_CTRL3_8822B	/* phydm only */
+#define REG_LEDCFG0		REG_LED_CFG_8822B	/* rtw_mp.c */
+#define MSR			(REG_CR_8822B + 2)	/* rtw_mp.c & hal_com.c */
+#define MSR1			REG_CR_EXT_8822B	/* rtw_mp.c & hal_com.c */
+#define REG_C2HEVT_MSG_NORMAL	0x1A0			/* hal_com.c */
+#define REG_C2HEVT_CLEAR	0x1AF			/* hal_com.c */
+#define REG_BCN_CTRL_1		REG_BCN_CTRL_CLINT0_8822B	/* hal_com.c */
+#define REG_TSFTR1		REG_FREERUN_CNT_8822B	/* hal_com.c */
+#define REG_WOWLAN_WAKE_REASON	0x01C7 /* hal_com.c */
+#define REG_GPIO_PIN_CTRL_2		REG_GPIO_EXT_CTRL_8822B		/* hal_com.c */
+
+/* RXERR_RPT, for rtw_mp.c */
+#define RXERR_TYPE_OFDM_PPDU		0
+#define RXERR_TYPE_OFDM_FALSE_ALARM	2
+#define RXERR_TYPE_OFDM_MPDU_OK		0
+#define RXERR_TYPE_OFDM_MPDU_FAIL	1
+#define RXERR_TYPE_CCK_PPDU		3
+#define RXERR_TYPE_CCK_FALSE_ALARM	5
+#define RXERR_TYPE_CCK_MPDU_OK		3
+#define RXERR_TYPE_CCK_MPDU_FAIL	4
+#define RXERR_TYPE_HT_PPDU		8
+#define RXERR_TYPE_HT_FALSE_ALARM	9
+#define RXERR_TYPE_HT_MPDU_TOTAL	6
+#define RXERR_TYPE_HT_MPDU_OK		6
+#define RXERR_TYPE_HT_MPDU_FAIL		7
+#define RXERR_TYPE_RX_FULL_DROP		10
+
+#define RXERR_COUNTER_MASK		BIT_MASK_RPT_COUNTER_8822B
+#define RXERR_RPT_RST			BIT_RXERR_RPT_RST_8822B
+#define _RXERR_RPT_SEL(type)		(BIT_RXERR_RPT_SEL_V1_3_0_8822B(type) \
+					| ((type & 0x10) ? BIT_RXERR_RPT_SEL_V1_4_8822B : 0))
+
+/*
+ * BB Register definition
+ */
+#define rPMAC_Reset			0x100	/* hal_mp.c */
+
+#define	rFPGA0_RFMOD			0x800
+#define rFPGA0_TxInfo			0x804
+#define rOFDMCCKEN_Jaguar		0x808	/* hal_mp.c */
+#define rFPGA0_TxGainStage		0x80C	/* phydm only */
+#define rFPGA0_XA_HSSIParameter1	0x820	/* hal_mp.c */
+#define rFPGA0_XA_HSSIParameter2	0x824	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter1	0x828	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter2	0x82C	/* hal_mp.c */
+#define rTxAGC_B_Rate18_06		0x830
+#define rTxAGC_B_Rate54_24		0x834
+#define rTxAGC_B_CCK1_55_Mcs32		0x838
+#define rCCAonSec_Jaguar		0x838	/* hal_mp.c */
+#define rTxAGC_B_Mcs03_Mcs00		0x83C
+#define rTxAGC_B_Mcs07_Mcs04		0x848
+#define rTxAGC_B_Mcs11_Mcs08		0x84C
+#define rFPGA0_XA_RFInterfaceOE		0x860
+#define rFPGA0_XB_RFInterfaceOE		0x864
+#define rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86C
+#define rFPGA0_XAB_RFInterfaceSW	0x870
+#define rFPGA0_XAB_RFParameter		0x878
+#define rFPGA0_AnalogParameter4		0x88C	/* hal_mp.c & phydm */
+#define rFPGA0_XB_LSSIReadBack		0x8A4	/* phydm */
+#define rHSSIRead_Jaguar		0x8B0	/* RF read addr (rtl8822b_phy.c) */
+
+#define	rC_TxScale_Jaguar2		0x181C  /* Pah_C TX scaling factor (hal_mp.c) */
+#define	rC_IGI_Jaguar2			0x1850	/* Initial Gain for path-C (hal_mp.c) */
+
+#define rFPGA1_TxInfo			0x90C	/* hal_mp.c */
+#define rSingleTone_ContTx_Jaguar	0x914	/* hal_mp.c */
+/* TX BeamForming */
+#define REG_BB_TX_PATH_SEL_1_8822B	0x93C	/* rtl8822b_phy.c */
+#define REG_BB_TX_PATH_SEL_2_8822B	0x940	/* rtl8822b_phy.c */
+
+/* TX BeamForming */
+#define REG_BB_TXBF_ANT_SET_BF1_8822B	0x19AC	/* rtl8822b_phy.c */
+#define REG_BB_TXBF_ANT_SET_BF0_8822B	0x19B4	/* rtl8822b_phy.c */
+
+#define rCCK0_System			0xA00
+#define rCCK0_AFESetting		0xA04
+
+#define rCCK0_DSPParameter2		0xA1C
+#define rCCK0_TxFilter1			0xA20
+#define rCCK0_TxFilter2			0xA24
+#define rCCK0_DebugPort			0xA28
+#define rCCK0_FalseAlarmReport		0xA2C
+
+#define	rD_TxScale_Jaguar2		0x1A1C  /* Path_D TX scaling factor (hal_mp.c) */
+#define	rD_IGI_Jaguar2			0x1A50	/* Initial Gain for path-D (hal_mp.c) */
+
+#define rOFDM0_TRxPathEnable		0xC04
+#define rOFDM0_TRMuxPar			0xC08
+#define rA_TxScale_Jaguar		0xC1C	/* Pah_A TX scaling factor (hal_mp.c) */
+#define rOFDM0_RxDetector1		0xC30	/* rtw_mp.c */
+#define rOFDM0_ECCAThreshold		0xC4C	/* phydm only */
+#define rOFDM0_XAAGCCore1		0xC50	/* phydm only */
+#define rA_IGI_Jaguar			0xC50	/* Initial Gain for path-A (hal_mp.c) */
+#define rOFDM0_XBAGCCore1		0xC58	/* phydm only */
+#define rOFDM0_XATxIQImbalance		0xC80	/* phydm only */
+#define rA_LSSIWrite_Jaguar		0xC90	/* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
+
+#define rOFDM1_LSTF			0xD00
+#define rOFDM1_TRxPathEnable		0xD04	/* hal_mp.c */
+#define rA_PIRead_Jaguar		0xD04	/* RF readback with PI (rtl8822b_phy.c) */
+#define rA_SIRead_Jaguar		0xD08	/* RF readback with SI (rtl8822b_phy.c) */
+#define rB_PIRead_Jaguar		0xD44	/* RF readback with PI (rtl8822b_phy.c) */
+#define rB_SIRead_Jaguar		0xD48	/* RF readback with SI (rtl8822b_phy.c) */
+
+#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 rB_TxScale_Jaguar		0xE1C	/* Path_B TX scaling factor (hal_mp.c) */
+#define rB_IGI_Jaguar			0xE50	/* Initial Gain for path-B (hal_mp.c) */
+#define rB_LSSIWrite_Jaguar		0xE90	/* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xCB0	/* hal_mp.c */
+#define	rB_RFE_Pinmux_Jaguar	0xEB0	/* Path_B RFE control pinmux */
+#define	rA_RFE_Inv_Jaguar		0xCB4	/* Path_A RFE cotrol */  
+#define	rB_RFE_Inv_Jaguar		0xEB4	/* Path_B RFE control */
+#define	rA_RFE_Jaguar			0xCB8 	/* Path_A RFE cotrol */  
+#define	rB_RFE_Jaguar			0xEB8	/* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define	r_ANTSEL_SW_Jaguar		0x900	/* ANTSEL SW Control */
+#define	bMask_RFEInv_Jaguar	0x3FF00000
+#define	bMask_AntselPathFollow_Jaguar 0x00030000
+
+#define		rC_RFE_Pinmux_Jaguar	0x18B4	/* Path_C RFE cotrol pinmux*/
+#define		rD_RFE_Pinmux_Jaguar	0x1AB4	/* Path_D RFE cotrol pinmux*/
+#define		rA_RFE_Sel_Jaguar2		0x1990
+
+/* Page1(0x100) */
+#define bBBResetB			0x100
+
+/* Page8(0x800) */
+#define bCCKEn				0x1000000
+#define bOFDMEn				0x2000000
+/* Reg 0x80C rFPGA0_TxGainStage */
+#define bXBTxAGC			0xF00
+#define bXCTxAGC			0xF000
+#define bXDTxAGC			0xF0000
+
+/* PageA(0xA00) */
+#define bCCKBBMode			0x3
+
+#define bCCKScramble			0x8
+#define bCCKTxRate			0x3000
+
+/* General */
+#define bMaskByte0		0xFF		/* mp, rtw_odm.c & phydm */
+#define bMaskByte1		0xFF00		/* hal_mp.c & phydm */
+#define bMaskByte2		0xFF0000	/* hal_mp.c & phydm */
+#define bMaskByte3		0xFF000000	/* hal_mp.c & phydm */
+#define bMaskHWord		0xFFFF0000	/* hal_com.c, rtw_mp.c */
+#define bMaskLWord		0x0000FFFF	/* mp, hal_com.c & phydm */
+#define bMaskDWord		0xFFFFFFFF	/* mp, hal, rtw_odm.c & phydm */
+
+#define bEnable			0x1		/* hal_mp.c, rtw_mp.c */
+#define bDisable		0x0		/* rtw_mp.c */
+
+#define MAX_STALL_TIME		50		/* unit: us, hal_com_phycfg.c */
+
+#define Rx_Smooth_Factor	20		/* phydm only */
+
+/*
+ * RF Register definition
+ */
+#define RF_AC			0x00
+#define RF_AC_Jaguar		0x00	/* hal_mp.c */
+#define RF_CHNLBW		0x18	/* rtl8822b_phy.c */
+#define RF_ModeTableAddr	0x30	/* rtl8822b_phy.c */
+#define RF_ModeTableData0	0x31	/* rtl8822b_phy.c */
+#define RF_ModeTableData1	0x32	/* rtl8822b_phy.c */
+#define RF_0x52			0x52
+#define RF_WeLut_Jaguar		0xEF	/* rtl8822b_phy.c */
+
+/* General Functions */
+void rtl8822b_init_hal_spec(PADAPTER);				/* hal/hal_com.c */
+
+#ifdef CONFIG_MP_INCLUDED
+/* MP Functions */
+#include <rtw_mp.h>		/* struct mp_priv */
+void rtl8822b_prepare_mp_txdesc(PADAPTER, struct mp_priv *);	/* rtw_mp.c */
+void rtl8822b_mp_config_rfpath(PADAPTER);			/* hal_mp.c */
+#endif
+
+#ifdef CONFIG_USB_HCI
+#include <rtl8822bu_hal.h>
+#elif defined(CONFIG_SDIO_HCI)
+#include <rtl8822bs_hal.h>
+#elif defined(CONFIG_PCI_HCI)
+#include <rtl8822be_hal.h>
+#endif
+
+#endif /* _RTL8822B_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822be_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822be_hal.h
new file mode 100644
index 000000000000..a81445fa166f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822be_hal.h
@@ -0,0 +1,27 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BE_HAL_H_
+#define _RTL8822BE_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+#define RT_BCN_INT_MASKS	(BIT20 | BIT25 | BIT26 | BIT16)
+
+/* rtl8822be_ops.c */
+void UpdateInterruptMask8822BE(PADAPTER, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+u16 get_txbd_rw_reg(u16 q_idx);
+
+
+#endif /* _RTL8822BE_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822bs_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822bs_hal.h
new file mode 100644
index 000000000000..ffaddee09832
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822bs_hal.h
@@ -0,0 +1,31 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BS_HAL_H_
+#define _RTL8822BS_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8822bs_ops.c */
+void rtl8822bs_set_hal_ops(PADAPTER);
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+void rtl8822bs_disable_interrupt_but_cpwm2(PADAPTER adapter);
+#endif
+
+/* rtl8822bs_xmit.c */
+s32 rtl8822bs_dequeue_writeport(PADAPTER);
+#define _dequeue_writeport(a)	rtl8822bs_dequeue_writeport(a)
+
+#endif /* _RTL8822BS_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822bu_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822bu_hal.h
new file mode 100644
index 000000000000..39618c9ea42d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtl8822bu_hal.h
@@ -0,0 +1,65 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_HAL_H_
+#define _RTL8822BU_HAL_H_
+
+#ifdef CONFIG_USB_HCI
+	#include <drv_types.h>		/* PADAPTER */
+
+	#ifdef CONFIG_USB_HCI
+		#ifdef USB_PACKET_OFFSET_SZ
+			#define PACKET_OFFSET_SZ (USB_PACKET_OFFSET_SZ)
+		#else
+			#define PACKET_OFFSET_SZ (8)
+		#endif
+		#define TXDESC_OFFSET (TXDESC_SIZE + PACKET_OFFSET_SZ)
+	#endif
+
+	/* undefine MAX_RECVBUF_SZ from rtl8822b_hal.h  */
+	#ifdef MAX_RECVBUF_SZ
+		#undef MAX_RECVBUF_SZ
+	#endif
+
+	/* recv_buffer must be large than usb agg size */
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024)
+		#else /* !PLATFORM_OS_CE */
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+				#define MAX_RECVBUF_SZ (15360) /* 15k */
+				#elif defined(CONFIG_PLATFORM_HISILICON)
+				/* use 16k to workaround for HISILICON platform */
+				#define MAX_RECVBUF_SZ (16384)
+				#else
+				#define MAX_RECVBUF_SZ (32768)
+				#endif
+			#else
+				#define MAX_RECVBUF_SZ (4000)
+			#endif
+		#endif /* PLATFORM_OS_CE */
+	#endif /* !MAX_RECVBUF_SZ */
+
+	/* rtl8822bu_ops.c */
+	void rtl8822bu_set_hal_ops(PADAPTER padapter);
+	void rtl8822bu_set_hw_type(struct dvobj_priv *pdvobj);
+
+	/* rtl8822bu_io.c */
+	void rtl8822bu_set_intf_ops(struct _io_ops *pops);
+
+#endif /* CONFIG_USB_HCI */
+
+
+#endif /* _RTL8822BU_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_android.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_android.h
new file mode 100644
index 000000000000..253ee9a0a402
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_android.h
@@ -0,0 +1,111 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_ANDROID_H__
+#define __RTW_ANDROID_H__
+
+enum ANDROID_WIFI_CMD {
+	ANDROID_WIFI_CMD_START,
+	ANDROID_WIFI_CMD_STOP,
+	ANDROID_WIFI_CMD_SCAN_ACTIVE,
+	ANDROID_WIFI_CMD_SCAN_PASSIVE,
+	ANDROID_WIFI_CMD_RSSI,
+	ANDROID_WIFI_CMD_LINKSPEED,
+	ANDROID_WIFI_CMD_RXFILTER_START,
+	ANDROID_WIFI_CMD_RXFILTER_STOP,
+	ANDROID_WIFI_CMD_RXFILTER_ADD,
+	ANDROID_WIFI_CMD_RXFILTER_REMOVE,
+	ANDROID_WIFI_CMD_BTCOEXSCAN_START,
+	ANDROID_WIFI_CMD_BTCOEXSCAN_STOP,
+	ANDROID_WIFI_CMD_BTCOEXMODE,
+	ANDROID_WIFI_CMD_SETSUSPENDOPT,
+	ANDROID_WIFI_CMD_P2P_DEV_ADDR,
+	ANDROID_WIFI_CMD_SETFWPATH,
+	ANDROID_WIFI_CMD_SETBAND,
+	ANDROID_WIFI_CMD_GETBAND,
+	ANDROID_WIFI_CMD_COUNTRY,
+	ANDROID_WIFI_CMD_P2P_SET_NOA,
+	ANDROID_WIFI_CMD_P2P_GET_NOA,
+	ANDROID_WIFI_CMD_P2P_SET_PS,
+	ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE,
+
+	ANDROID_WIFI_CMD_MIRACAST,
+
+#ifdef CONFIG_PNO_SUPPORT
+	ANDROID_WIFI_CMD_PNOSSIDCLR_SET,
+	ANDROID_WIFI_CMD_PNOSETUP_SET,
+	ANDROID_WIFI_CMD_PNOENABLE_SET,
+	ANDROID_WIFI_CMD_PNODEBUG_SET,
+#endif
+
+	ANDROID_WIFI_CMD_MACADDR,
+
+	ANDROID_WIFI_CMD_BLOCK_SCAN,
+	ANDROID_WIFI_CMD_BLOCK,
+
+	ANDROID_WIFI_CMD_WFD_ENABLE,
+	ANDROID_WIFI_CMD_WFD_DISABLE,
+
+	ANDROID_WIFI_CMD_WFD_SET_TCPPORT,
+	ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT,
+	ANDROID_WIFI_CMD_WFD_SET_DEVTYPE,
+	ANDROID_WIFI_CMD_CHANGE_DTIM,
+	ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL,
+	ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA,
+	ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA,
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
+	ANDROID_WIFI_CMD_GTK_REKEY_OFFLOAD,
+#endif /* CONFIG_GTK_OL */
+	ANDROID_WIFI_CMD_P2P_DISABLE,
+	ANDROID_WIFI_CMD_SET_AEK,
+	ANDROID_WIFI_CMD_DRIVERVERSION,
+	ANDROID_WIFI_CMD_MAX
+};
+
+int rtw_android_cmdstr_to_num(char *cmdstr);
+int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd);
+
+#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+int rtw_android_pno_enable(struct net_device *net, int pno_enable);
+int rtw_android_cfg80211_pno_setup(struct net_device *net,
+		   struct cfg80211_ssid *ssid, int n_ssids, int interval);
+#endif
+
+#if defined(RTW_ENABLE_WIFI_CONTROL_FUNC)
+int rtw_android_wifictrl_func_add(void);
+void rtw_android_wifictrl_func_del(void);
+void *wl_android_prealloc(int section, unsigned long size);
+
+int wifi_get_irq_number(unsigned long *irq_flags_ptr);
+int wifi_set_power(int on, unsigned long msec);
+int wifi_get_mac_addr(unsigned char *buf);
+void *wifi_get_country_code(char *ccode);
+#else
+static int rtw_android_wifictrl_func_add(void)
+{
+	return 0;
+}
+static void rtw_android_wifictrl_func_del(void) {}
+#endif /* defined(RTW_ENABLE_WIFI_CONTROL_FUNC) */
+
+#ifdef CONFIG_GPIO_WAKEUP
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+int wifi_configure_gpio(void);
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+void wifi_free_gpio(unsigned int gpio);
+#endif /* CONFIG_GPIO_WAKEUP */
+
+
+#endif /* __RTW_ANDROID_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ap.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ap.h
new file mode 100644
index 000000000000..88220159f5bb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ap.h
@@ -0,0 +1,104 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#ifdef CONFIG_AP_MODE
+
+/* external function */
+extern void rtw_indicate_sta_assoc_event(_adapter *padapter, struct sta_info *psta);
+extern void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info *psta);
+
+
+void init_mlme_ap_info(_adapter *padapter);
+void free_mlme_ap_info(_adapter *padapter);
+u8 rtw_set_tim_ie(u8 dtim_cnt, u8 dtim_period
+	, const u8 *tim_bmp, u8 tim_bmp_len, u8 *tim_ie);
+/* void update_BCNTIM(_adapter *padapter); */
+void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len);
+void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index);
+void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *tag);
+#define update_beacon(adapter, ie_id, oui, tx) _update_beacon((adapter), (ie_id), (oui), (tx), __func__)
+
+void rtw_ap_update_sta_ra_info(_adapter *padapter, struct sta_info *psta);
+
+void expire_timeout_chk(_adapter *padapter);
+void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta);
+void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter);
+void start_bss_network(_adapter *padapter, struct createbss_parm *parm);
+int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len);
+void rtw_ap_restore_network(_adapter *padapter);
+
+#if CONFIG_RTW_MACADDR_ACL
+void rtw_macaddr_acl_init(_adapter *adapter, u8 period);
+void rtw_macaddr_acl_deinit(_adapter *adapter, u8 period);
+void rtw_macaddr_acl_clear(_adapter *adapter, u8 period);
+void rtw_set_macaddr_acl(_adapter *adapter, u8 period, int mode);
+int rtw_acl_add_sta(_adapter *adapter, u8 period, const u8 *addr);
+int rtw_acl_remove_sta(_adapter *adapter, u8 period, const u8 *addr);
+#endif /* CONFIG_RTW_MACADDR_ACL */
+
+u8 rtw_ap_set_sta_key(_adapter *adapter, const u8 *addr, u8 alg, const u8 *key, u8 keyid, u8 gk);
+u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta);
+int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid);
+int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx);
+
+#ifdef CONFIG_NATIVEAP_MLME
+void associated_clients_update(_adapter *padapter, u8 updated, u32 sta_info_type);
+void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta);
+u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta);
+void sta_info_update(_adapter *padapter, struct sta_info *psta);
+void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta);
+u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reason, bool enqueue);
+int rtw_sta_flush(_adapter *padapter, bool enqueue);
+int rtw_ap_inform_ch_switch(_adapter *padapter, u8 new_ch, u8 ch_offset);
+void start_ap_mode(_adapter *padapter);
+void stop_ap_mode(_adapter *padapter);
+#endif
+
+void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset);
+bool rtw_ap_chbw_decision(_adapter *adapter, s16 req_ch, s8 req_bw, s8 req_offset, u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow);
+
+#ifdef CONFIG_AUTO_AP_MODE
+void rtw_auto_ap_rx_msg_dump(_adapter *padapter, union recv_frame *precv_frame, u8 *ehdr_pos);
+extern void rtw_start_auto_ap(_adapter *adapter);
+#endif /* CONFIG_AUTO_AP_MODE */
+
+void rtw_ap_parse_sta_capability(_adapter *adapter, struct sta_info *sta, u8 *cap);
+u16 rtw_ap_parse_sta_supported_rates(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len);
+u16 rtw_ap_parse_sta_security_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems);
+void rtw_ap_parse_sta_wmm_ie(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len);
+void rtw_ap_parse_sta_ht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems);
+void rtw_ap_parse_sta_vht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems);
+
+void update_bmc_sta(_adapter *padapter);
+
+#ifdef CONFIG_BMC_TX_RATE_SELECT
+void rtw_update_bmc_sta_tx_rate(_adapter *adapter);
+#endif
+
+void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field);
+void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len);
+int rtw_ht_operation_update(_adapter *padapter);
+u8 rtw_ap_sta_linking_state_check(_adapter *adapter);
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+void tx_beacon_handlder(struct dvobj_priv *pdvobj);
+void tx_beacon_timer_handlder(void *ctx);
+#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
+
+#endif /* end of CONFIG_AP_MODE */
+#endif /*__RTW_AP_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_beamforming.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_beamforming.h
new file mode 100644
index 000000000000..b5875d42bf07
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_beamforming.h
@@ -0,0 +1,401 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BEAMFORMING_H_
+#define __RTW_BEAMFORMING_H_
+
+#ifdef CONFIG_BEAMFORMING
+
+#ifdef RTW_BEAMFORMING_VERSION_2
+#define MAX_NUM_BEAMFORMEE_SU	2
+#define MAX_NUM_BEAMFORMER_SU	2
+#define MAX_NUM_BEAMFORMEE_MU	6
+#define MAX_NUM_BEAMFORMER_MU	1
+
+#define MAX_BEAMFORMEE_ENTRY_NUM	(MAX_NUM_BEAMFORMEE_SU + MAX_NUM_BEAMFORMEE_MU)
+#define MAX_BEAMFORMER_ENTRY_NUM	(MAX_NUM_BEAMFORMER_SU + MAX_NUM_BEAMFORMER_MU)
+
+/* <Note> Need to be defined by IC */
+#define SU_SOUNDING_TIMEOUT	5	/* unit: ms */
+#define MU_SOUNDING_TIMEOUT	8	/* unit: ms */
+
+#define GET_BEAMFORM_INFO(adapter)	(&GET_HAL_DATA(adapter)->beamforming_info)
+#define GetInitSoundCnt(_SoundPeriod, _MinSoundPeriod)	((_SoundPeriod)/(_MinSoundPeriod))
+
+enum BEAMFORMING_CTRL_TYPE {
+	BEAMFORMING_CTRL_ENTER = 0,
+	BEAMFORMING_CTRL_LEAVE = 1,
+	BEAMFORMING_CTRL_START_PERIOD = 2,
+	BEAMFORMING_CTRL_END_PERIOD = 3,
+	BEAMFORMING_CTRL_SOUNDING_FAIL = 4,
+	BEAMFORMING_CTRL_SOUNDING_CLK = 5,
+	BEAMFORMING_CTRL_SET_GID_TABLE = 6,
+	BEAMFORMING_CTRL_SET_CSI_REPORT = 7,
+};
+
+enum _BEAMFORMING_STATE {
+	BEAMFORMING_STATE_IDLE,
+	BEAMFORMING_STATE_START,
+	BEAMFORMING_STATE_END,
+};
+
+/*
+ * typedef BEAMFORMING_CAP for phydm
+ */
+typedef enum beamforming_cap {
+	BEAMFORMING_CAP_NONE = 0x0,
+	BEAMFORMER_CAP_HT_EXPLICIT = 0x1,
+	BEAMFORMEE_CAP_HT_EXPLICIT = 0x2,
+	BEAMFORMER_CAP_VHT_SU = 0x4,			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_SU = 0x8, 			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP_VHT_MU = 0x10,			/* Self has er Cap, because Reg er & peer ee */
+	BEAMFORMEE_CAP_VHT_MU = 0x20,			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP = 0x40,
+	BEAMFORMEE_CAP = 0x80,
+} BEAMFORMING_CAP;
+
+enum _BEAMFORM_ENTRY_HW_STATE {
+	BEAMFORM_ENTRY_HW_STATE_NONE,
+	BEAMFORM_ENTRY_HW_STATE_ADD_INIT,
+	BEAMFORM_ENTRY_HW_STATE_ADDING,
+	BEAMFORM_ENTRY_HW_STATE_ADDED,
+	BEAMFORM_ENTRY_HW_STATE_DELETE_INIT,
+	BEAMFORM_ENTRY_HW_STATE_DELETING,
+	BEAMFORM_ENTRY_HW_STATE_MAX
+};
+
+/* The sounding state is recorded by BFer. */
+enum _SOUNDING_STATE {
+	SOUNDING_STATE_NONE		= 0,
+	SOUNDING_STATE_INIT		= 1,
+	SOUNDING_STATE_SU_START		= 2,
+	SOUNDING_STATE_SU_SOUNDDOWN	= 3,
+	SOUNDING_STATE_MU_START		= 4,
+	SOUNDING_STATE_MU_SOUNDDOWN	= 5,
+	SOUNDING_STATE_SOUNDING_TIMEOUT	= 6,
+	SOUNDING_STATE_MAX
+};
+
+struct beamformee_entry {
+	u8 used;	/* _TRUE/_FALSE */
+	u8 txbf;
+	u8 sounding;
+	/* Used to construct AID field of NDPA packet */
+	u16 aid;
+	/* Used to Set Reg42C in IBSS mode */
+	u16 mac_id;
+	/* Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC */
+	u16 p_aid;
+	u8 g_id;
+	/* Used to fill Reg6E4 to fill Mac address of CSI report frame */
+	u8 mac_addr[ETH_ALEN];
+	/* Sounding BandWidth */
+	enum channel_width sound_bw;
+	u16 sound_period;
+
+	enum beamforming_cap cap;
+	enum _BEAMFORM_ENTRY_HW_STATE state;
+
+	/* The BFee need to be sounded when count to zero */
+	u8 SoundCnt;
+	u8 bCandidateSoundingPeer;
+	u8 bSoundingTimeout;
+	u8 bDeleteSounding;
+	/* Get the result through throughput and Tx rate from BB API */
+	u8 bApplySounding;
+
+	/* information for sounding judgement */
+	systime tx_timestamp;
+	u64 tx_bytes;
+
+	u16 LogStatusFailCnt:5;	/* 0~21 */
+	u16 DefaultCSICnt:5; /* 0~21 */
+	u8 CSIMatrix[327];
+	u16 CSIMatrixLen;
+
+	u8 NumofSoundingDim;
+
+	u8 comp_steering_num_of_bfer;
+
+
+	/* SU-MIMO */
+	u8 su_reg_index;
+
+	/* MU-MIMO */
+	u8 mu_reg_index;
+	u8 gid_valid[8];
+	u8 user_position[16];
+
+	/* For 8822B C-cut workaround */
+	/* If the flag set to _TRUE, do not sound this STA */
+	u8 bSuspendSUCap;
+};
+
+struct beamformer_entry {
+	u8 used;
+	/* p_aid of BFer entry is probably not used */
+	/* Used to fill Reg42C & Reg714 to compare with p_aid of Tx DESC */
+	u16 p_aid;
+	u8 g_id;
+	u8 mac_addr[ETH_ALEN];
+
+	enum beamforming_cap cap;
+	enum _BEAMFORM_ENTRY_HW_STATE state;
+
+	u8 NumofSoundingDim;
+
+	/* SU-MIMO */
+	u8 su_reg_index;
+
+	/* MU-MIMO */
+	u8 gid_valid[8];
+	u8 user_position[16];
+	u16 aid;
+};
+
+struct sounding_info {
+	u8 su_sounding_list[MAX_NUM_BEAMFORMEE_SU];
+	u8 mu_sounding_list[MAX_NUM_BEAMFORMEE_MU];
+
+	enum _SOUNDING_STATE state;
+	/*
+	 * su_bfee_curidx is index for beamforming_info.bfee_entry[]
+	 * range: 0~MAX_BEAMFORMEE_ENTRY_NUM
+	 */
+	u8 su_bfee_curidx;
+	u8 candidate_mu_bfee_cnt;
+
+	/* For sounding schedule maintenance */
+	u16 min_sounding_period;
+	/* Get from sounding list */
+	/* Ex: SU STA1, SU STA2, MU STA(1~n) => the value will be 2+1=3 */
+	u8 sound_remain_cnt_per_period;
+};
+
+struct _RT_CSI_INFO{
+	u8 Nc;
+	u8 Nr;
+	u8 Ng;
+	u8 CodeBook;
+	u8 ChnlWidth;
+	u8 bVHT;
+};
+
+struct beamforming_info {
+	enum beamforming_cap beamforming_cap;
+	enum _BEAMFORMING_STATE beamforming_state;
+	struct beamformee_entry bfee_entry[MAX_BEAMFORMEE_ENTRY_NUM];
+	struct beamformer_entry bfer_entry[MAX_BEAMFORMER_ENTRY_NUM];
+	u8 sounding_sequence;
+	u8 beamformee_su_cnt;
+	u8 beamformer_su_cnt;
+	u32 beamformee_su_reg_maping;
+	u32 beamformer_su_reg_maping;
+	/* For MU-MINO */
+	u8 beamformee_mu_cnt;
+	u8 beamformer_mu_cnt;
+	u32 beamformee_mu_reg_maping;
+	u8 first_mu_bfee_index;
+	u8 mu_bfer_curidx;
+	u8 cur_csi_rpt_rate;
+
+	struct sounding_info sounding_info;
+	/* schedule regular timer for sounding */
+	_timer sounding_timer;
+	/* moniter if soudning too long */
+	_timer sounding_timeout_timer;
+
+	/* For HW configuration */
+	u8 SetHalBFEnterOnDemandCnt;
+	u8 SetHalBFLeaveOnDemandCnt;
+	u8 SetHalSoundownOnDemandCnt;
+	u8 bSetBFHwConfigInProgess;
+
+	/*
+	 * Target CSI report info.
+	 * Keep the first SU CSI report info for 8822B HW bug workaround.
+	 */
+	u8 bEnableSUTxBFWorkAround;
+	struct _RT_CSI_INFO TargetCSIInfo;
+	/* Only peform sounding to the first SU BFee */
+	struct beamformee_entry *TargetSUBFee;
+
+	/* For debug */
+	s8 sounding_running;
+};
+
+enum beamforming_cap rtw_bf_bfee_get_entry_cap_by_macid(void *mlmepriv, u8 mac_id);
+struct beamformer_entry *rtw_bf_bfer_get_entry_by_addr(PADAPTER, u8 *ra);
+struct beamformee_entry *rtw_bf_bfee_get_entry_by_addr(PADAPTER, u8 *ra);
+void rtw_bf_get_ndpa_packet(PADAPTER, union recv_frame *);
+u32 rtw_bf_get_report_packet(PADAPTER, union recv_frame *);
+u8 rtw_bf_send_vht_gid_mgnt_packet(PADAPTER, u8 *ra, u8 *gid, u8 *position);
+void rtw_bf_get_vht_gid_mgnt_packet(PADAPTER, union recv_frame *);
+void rtw_bf_init(PADAPTER);
+void rtw_bf_cmd_hdl(PADAPTER, u8 type, u8 *pbuf);
+u8 rtw_bf_cmd(PADAPTER, s32 type, u8 *pbuf, s32 size, u8 enqueue);
+void rtw_bf_update_attrib(PADAPTER, struct pkt_attrib *, struct sta_info *);
+void rtw_bf_c2h_handler(PADAPTER, u8 id, u8 *buf, u8 buf_len);
+void rtw_bf_update_traffic(PADAPTER);
+
+/* Compatible with old function name, only for using outside rtw_beamforming.c */
+#define beamforming_get_entry_beam_cap_by_mac_id	rtw_bf_bfee_get_entry_cap_by_macid
+#define rtw_beamforming_get_ndpa_frame			rtw_bf_get_ndpa_packet
+#define rtw_beamforming_get_report_frame			rtw_bf_get_report_packet
+#define rtw_beamforming_get_vht_gid_mgnt_frame		rtw_bf_get_vht_gid_mgnt_packet
+#define beamforming_wk_hdl				rtw_bf_cmd_hdl
+#define beamforming_wk_cmd				rtw_bf_cmd
+#define update_attrib_txbf_info				rtw_bf_update_attrib
+
+#define HT_BF_CAP(adapter) ((adapter)->mlmepriv.htpriv.beamform_cap)
+#define VHT_BF_CAP(adapter) ((adapter)->mlmepriv.vhtpriv.beamform_cap)
+
+#define IS_HT_BEAMFORMEE(adapter) \
+		(HT_BF_CAP(adapter) & \
+		(BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+
+#define IS_VHT_BEAMFORMEE(adapter) \
+		(VHT_BF_CAP(adapter) & \
+		(BEAMFORMING_VHT_BEAMFORMEE_ENABLE | \
+		 BEAMFORMING_VHT_MU_MIMO_STA_ENABLE))
+
+#define IS_BEAMFORMEE(adapter) (IS_HT_BEAMFORMEE(adapter) | \
+				IS_VHT_BEAMFORMEE(adapter))
+
+#else /* !RTW_BEAMFORMING_VERSION_2 */
+
+#if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
+#define BEAMFORMING_ENTRY_NUM		2
+#define GET_BEAMFORM_INFO(_pmlmepriv)	((struct beamforming_info *)(&(_pmlmepriv)->beamforming_info))
+
+
+typedef enum _BEAMFORMING_ENTRY_STATE {
+	BEAMFORMING_ENTRY_STATE_UNINITIALIZE,
+	BEAMFORMING_ENTRY_STATE_INITIALIZEING,
+	BEAMFORMING_ENTRY_STATE_INITIALIZED,
+	BEAMFORMING_ENTRY_STATE_PROGRESSING,
+	BEAMFORMING_ENTRY_STATE_PROGRESSED,
+} BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;
+
+
+typedef enum _BEAMFORMING_STATE {
+	BEAMFORMING_STATE_IDLE,
+	BEAMFORMING_STATE_START,
+	BEAMFORMING_STATE_END,
+} BEAMFORMING_STATE, *PBEAMFORMING_STATE;
+
+
+typedef enum _BEAMFORMING_CAP {
+	BEAMFORMING_CAP_NONE = 0x0,
+	BEAMFORMER_CAP_HT_EXPLICIT = 0x1,
+	BEAMFORMEE_CAP_HT_EXPLICIT = 0x2,
+	BEAMFORMER_CAP_VHT_SU = 0x4,			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_SU = 0x8, 			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP = 0x10,
+	BEAMFORMEE_CAP = 0x20,
+} BEAMFORMING_CAP, *PBEAMFORMING_CAP;
+
+
+typedef enum _SOUNDING_MODE {
+	SOUNDING_SW_VHT_TIMER = 0x0,
+	SOUNDING_SW_HT_TIMER = 0x1,
+	SOUNDING_STOP_All_TIMER = 0x2,
+	SOUNDING_HW_VHT_TIMER = 0x3,
+	SOUNDING_HW_HT_TIMER = 0x4,
+	SOUNDING_STOP_OID_TIMER = 0x5,
+	SOUNDING_AUTO_VHT_TIMER = 0x6,
+	SOUNDING_AUTO_HT_TIMER = 0x7,
+	SOUNDING_FW_VHT_TIMER = 0x8,
+	SOUNDING_FW_HT_TIMER = 0x9,
+} SOUNDING_MODE, *PSOUNDING_MODE;
+
+struct beamforming_entry {
+	BOOLEAN	bUsed;
+	BOOLEAN	bSound;
+	u16	aid;			/* Used to construct AID field of NDPA packet. */
+	u16	mac_id;		/* Used to Set Reg42C in IBSS mode. */
+	u16	p_aid;		/* Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u16 g_id;
+	u8	mac_addr[6];/* Used to fill Reg6E4 to fill Mac address of CSI report frame. */
+	enum channel_width	sound_bw;	/* Sounding BandWidth */
+	u16	sound_period;
+	BEAMFORMING_CAP	beamforming_entry_cap;
+	BEAMFORMING_ENTRY_STATE	beamforming_entry_state;
+	u8				ClockResetTimes;			/*Modified by Jeffery @2015-04-10*/
+	u8				PreLogSeq;				/*Modified by Jeffery @2015-03-30*/
+	u8				LogSeq;					/*Modified by Jeffery @2014-10-29*/
+	u16				LogRetryCnt:3;			/*Modified by Jeffery @2014-10-29*/
+	u16				LogSuccess:2;			/*Modified by Jeffery @2014-10-29*/
+
+	u8	LogStatusFailCnt;
+	u8	PreCsiReport[327];
+	u8	DefaultCsiCnt;
+	BOOLEAN	bDefaultCSI;
+};
+
+struct sounding_info {
+	u8				sound_idx;
+	enum channel_width	sound_bw;
+	SOUNDING_MODE	sound_mode;
+	u16				sound_period;
+};
+
+struct beamforming_info {
+	BEAMFORMING_CAP		beamforming_cap;
+	BEAMFORMING_STATE		beamforming_state;
+	struct beamforming_entry	beamforming_entry[BEAMFORMING_ENTRY_NUM];
+	u8						beamforming_cur_idx;
+	u8						beamforming_in_progress;
+	u8						sounding_sequence;
+	struct sounding_info		sounding_info;
+};
+
+struct rtw_ndpa_sta_info {
+	u16	aid:12;
+	u16	feedback_type:1;
+	u16	nc_index:3;
+};
+
+BEAMFORMING_CAP beamforming_get_entry_beam_cap_by_mac_id(PVOID pmlmepriv , u8 mac_id);
+void	beamforming_notify(PADAPTER adapter);
+BEAMFORMING_CAP beamforming_get_beamform_cap(struct beamforming_info	*pBeamInfo);
+
+BOOLEAN	beamforming_send_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, enum channel_width bw, u8 qidx);
+BOOLEAN	beamforming_send_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, enum channel_width bw, u8 qidx);
+
+void	beamforming_check_sounding_success(PADAPTER Adapter, BOOLEAN status);
+
+void	beamforming_watchdog(PADAPTER Adapter);
+#endif /*#if (BEAMFORMING_SUPPORT ==0)- for diver defined beamforming*/
+
+enum BEAMFORMING_CTRL_TYPE {
+	BEAMFORMING_CTRL_ENTER = 0,
+	BEAMFORMING_CTRL_LEAVE = 1,
+	BEAMFORMING_CTRL_START_PERIOD = 2,
+	BEAMFORMING_CTRL_END_PERIOD = 3,
+	BEAMFORMING_CTRL_SOUNDING_FAIL = 4,
+	BEAMFORMING_CTRL_SOUNDING_CLK = 5,
+};
+u32	rtw_beamforming_get_report_frame(PADAPTER	 Adapter, union recv_frame *precv_frame);
+void	rtw_beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_frame);
+
+void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf);
+u8	beamforming_wk_cmd(_adapter *padapter, s32 type, u8 *pbuf, s32 size, u8 enqueue);
+void update_attrib_txbf_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
+
+#endif /* !RTW_BEAMFORMING_VERSION_2 */
+
+#endif /*#ifdef CONFIG_BEAMFORMING */
+
+#endif /*__RTW_BEAMFORMING_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_br_ext.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_br_ext.h
new file mode 100644
index 000000000000..54ba75ea1df5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_br_ext.h
@@ -0,0 +1,69 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BR_EXT_H_
+#define _RTW_BR_EXT_H_
+
+#if 1	/* rtw_wifi_driver */
+#define CL_IPV6_PASS	1
+#define MACADDRLEN		6
+#define _DEBUG_ERR		RTW_INFO
+#define _DEBUG_INFO		/* RTW_INFO */
+#define DEBUG_WARN		RTW_INFO
+#define DEBUG_INFO		/* RTW_INFO */
+#define DEBUG_ERR		RTW_INFO
+/* #define GET_MY_HWADDR		((GET_MIB(priv))->dot11OperationEntry.hwaddr) */
+#define GET_MY_HWADDR(padapter)		(adapter_mac_addr(padapter))
+#endif /* rtw_wifi_driver */
+
+#define NAT25_HASH_BITS		4
+#define NAT25_HASH_SIZE		(1 << NAT25_HASH_BITS)
+#define NAT25_AGEING_TIME	300
+
+#ifdef CL_IPV6_PASS
+	#define MAX_NETWORK_ADDR_LEN	17
+#else
+	#define MAX_NETWORK_ADDR_LEN	11
+#endif
+
+struct nat25_network_db_entry {
+	struct nat25_network_db_entry	*next_hash;
+	struct nat25_network_db_entry	**pprev_hash;
+	atomic_t						use_count;
+	unsigned char					macAddr[6];
+	unsigned long					ageing_timer;
+	unsigned char				networkAddr[MAX_NETWORK_ADDR_LEN];
+};
+
+enum NAT25_METHOD {
+	NAT25_MIN,
+	NAT25_CHECK,
+	NAT25_INSERT,
+	NAT25_LOOKUP,
+	NAT25_PARSE,
+	NAT25_MAX
+};
+
+struct br_ext_info {
+	unsigned int	nat25_disable;
+	unsigned int	macclone_enable;
+	unsigned int	dhcp_bcst_disable;
+	int		addPPPoETag;		/* 1: Add PPPoE relay-SID, 0: disable */
+	unsigned char	nat25_dmzMac[MACADDRLEN];
+	unsigned int	nat25sc_disable;
+};
+
+void nat25_db_cleanup(_adapter *priv);
+
+#endif /* _RTW_BR_EXT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_bt_mp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_bt_mp.h
new file mode 100644
index 000000000000..a152d18e9765
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_bt_mp.h
@@ -0,0 +1,288 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BT_MP_H
+#define __RTW_BT_MP_H
+
+
+#if (MP_DRIVER == 1)
+
+#pragma pack(1)
+
+/* definition for BT_UP_OP_BT_READY */
+#define	MP_BT_NOT_READY						0
+#define	MP_BT_READY							1
+
+/* definition for BT_UP_OP_BT_SET_MODE */
+typedef enum _MP_BT_MODE {
+	MP_BT_MODE_RF_TXRX_TEST_MODE							= 0,
+	MP_BT_MODE_BT20_DUT_TEST_MODE							= 1,
+	MP_BT_MODE_BT40_DIRECT_TEST_MODE						= 2,
+	MP_BT_MODE_CONNECT_TEST_MODE							= 3,
+	MP_BT_MODE_MAX
+} MP_BT_MODE, *PMP_BT_MODE;
+
+
+/* definition for BT_UP_OP_BT_SET_TX_RX_PARAMETER */
+typedef struct _BT_TXRX_PARAMETERS {
+	u1Byte		txrxChannel;
+	u4Byte		txrxTxPktCnt;
+	u1Byte		txrxTxPktInterval;
+	u1Byte		txrxPayloadType;
+	u1Byte		txrxPktType;
+	u2Byte		txrxPayloadLen;
+	u4Byte		txrxPktHeader;
+	u1Byte		txrxWhitenCoeff;
+	u1Byte		txrxBdaddr[6];
+	u1Byte		txrxTxGainIndex;
+} BT_TXRX_PARAMETERS, *PBT_TXRX_PARAMETERS;
+
+/* txrxPktType */
+typedef enum _MP_BT_PKT_TYPE {
+	MP_BT_PKT_DH1							= 0,
+	MP_BT_PKT_DH3							= 1,
+	MP_BT_PKT_DH5							= 2,
+	MP_BT_PKT_2DH1							= 3,
+	MP_BT_PKT_2DH3							= 4,
+	MP_BT_PKT_2DH5							= 5,
+	MP_BT_PKT_3DH1							= 6,
+	MP_BT_PKT_3DH3							= 7,
+	MP_BT_PKT_3DH5							= 8,
+	MP_BT_PKT_LE							= 9,
+	MP_BT_PKT_MAX
+} MP_BT_PKT_TYPE, *PMP_BT_PKT_TYPE;
+/* txrxPayloadType */
+typedef enum _MP_BT_PAYLOAD_TYPE {
+	MP_BT_PAYLOAD_01010101					= 0,
+	MP_BT_PAYLOAD_ALL_1						= 1,
+	MP_BT_PAYLOAD_ALL_0						= 2,
+	MP_BT_PAYLOAD_11110000					= 3,
+	MP_BT_PAYLOAD_PRBS9						= 4,
+	MP_BT_PAYLOAD_MAX						= 8,
+} MP_BT_PAYLOAD_TYPE, *PMP_BT_PAYLOAD_TYPE;
+
+
+/* definition for BT_UP_OP_BT_TEST_CTRL */
+typedef enum _MP_BT_TEST_CTRL {
+	MP_BT_TEST_STOP_ALL_TESTS						= 0,
+	MP_BT_TEST_START_RX_TEST						= 1,
+	MP_BT_TEST_START_PACKET_TX_TEST					= 2,
+	MP_BT_TEST_START_CONTINUOUS_TX_TEST			= 3,
+	MP_BT_TEST_START_INQUIRY_SCAN_TEST				= 4,
+	MP_BT_TEST_START_PAGE_SCAN_TEST					= 5,
+	MP_BT_TEST_START_INQUIRY_PAGE_SCAN_TEST			= 6,
+	MP_BT_TEST_START_LEGACY_CONNECT_TEST			= 7,
+	MP_BT_TEST_START_LE_CONNECT_TEST_INITIATOR		= 8,
+	MP_BT_TEST_START_LE_CONNECT_TEST_ADVERTISER	= 9,
+	MP_BT_TEST_MAX
+} MP_BT_TEST_CTRL, *PMP_BT_TEST_CTRL;
+
+
+typedef enum _RTL_EXT_C2H_EVT {
+	EXT_C2H_WIFI_FW_ACTIVE_RSP = 0,
+	EXT_C2H_TRIG_BY_BT_FW = 1,
+	MAX_EXT_C2HEVENT
+} RTL_EXT_C2H_EVT;
+
+/* OP codes definition between the user layer and driver */
+typedef enum _BT_CTRL_OPCODE_UPPER {
+	BT_UP_OP_BT_READY										= 0x00,
+	BT_UP_OP_BT_SET_MODE									= 0x01,
+	BT_UP_OP_BT_SET_TX_RX_PARAMETER						= 0x02,
+	BT_UP_OP_BT_SET_GENERAL								= 0x03,
+	BT_UP_OP_BT_GET_GENERAL								= 0x04,
+	BT_UP_OP_BT_TEST_CTRL									= 0x05,
+	BT_UP_OP_TEST_BT										= 0x06,
+	BT_UP_OP_MAX
+} BT_CTRL_OPCODE_UPPER, *PBT_CTRL_OPCODE_UPPER;
+
+
+typedef enum _BT_SET_GENERAL {
+	BT_GSET_REG											= 0x00,
+	BT_GSET_RESET											= 0x01,
+	BT_GSET_TARGET_BD_ADDR									= 0x02,
+	BT_GSET_TX_PWR_FINETUNE								= 0x03,
+	BT_SET_TRACKING_INTERVAL								= 0x04,
+	BT_SET_THERMAL_METER									= 0x05,
+	BT_ENABLE_CFO_TRACKING									= 0x06,
+	BT_GSET_UPDATE_BT_PATCH								= 0x07,
+	BT_GSET_MAX
+} BT_SET_GENERAL, *PBT_SET_GENERAL;
+
+typedef enum _BT_GET_GENERAL {
+	BT_GGET_REG											= 0x00,
+	BT_GGET_STATUS											= 0x01,
+	BT_GGET_REPORT											= 0x02,
+	BT_GGET_AFH_MAP										= 0x03,
+	BT_GGET_AFH_STATUS										= 0x04,
+	BT_GGET_MAX
+} BT_GET_GENERAL, *PBT_GET_GENERAL;
+
+/* definition for BT_UP_OP_BT_SET_GENERAL */
+typedef enum _BT_REG_TYPE {
+	BT_REG_RF								= 0,
+	BT_REG_MODEM							= 1,
+	BT_REG_BLUEWIZE						= 2,
+	BT_REG_VENDOR							= 3,
+	BT_REG_LE								= 4,
+	BT_REG_MAX
+} BT_REG_TYPE, *PBT_REG_TYPE;
+
+/* definition for BT_LO_OP_GET_AFH_MAP */
+typedef enum _BT_AFH_MAP_TYPE {
+	BT_AFH_MAP_RESULT						= 0,
+	BT_AFH_MAP_WIFI_PSD_ONLY				= 1,
+	BT_AFH_MAP_WIFI_CH_BW_ONLY				= 2,
+	BT_AFH_MAP_BT_PSD_ONLY					= 3,
+	BT_AFH_MAP_HOST_CLASSIFICATION_ONLY	= 4,
+	BT_AFH_MAP_MAX
+} BT_AFH_MAP_TYPE, *PBT_AFH_MAP_TYPE;
+
+/* definition for BT_UP_OP_BT_GET_GENERAL */
+typedef enum _BT_REPORT_TYPE {
+	BT_REPORT_RX_PACKET_CNT				= 0,
+	BT_REPORT_RX_ERROR_BITS				= 1,
+	BT_REPORT_RSSI							= 2,
+	BT_REPORT_CFO_HDR_QUALITY				= 3,
+	BT_REPORT_CONNECT_TARGET_BD_ADDR		= 4,
+	BT_REPORT_MAX
+} BT_REPORT_TYPE, *PBT_REPORT_TYPE;
+
+VOID
+MPTBT_Test(
+	IN	PADAPTER	Adapter,
+	IN	u1Byte		opCode,
+	IN	u1Byte		byte1,
+	IN	u1Byte		byte2,
+	IN	u1Byte		byte3
+);
+
+NDIS_STATUS
+MPTBT_SendOidBT(
+	IN	PADAPTER		pAdapter,
+	IN	PVOID			InformationBuffer,
+	IN	ULONG			InformationBufferLength,
+	OUT	PULONG			BytesRead,
+	OUT	PULONG			BytesNeeded
+);
+
+VOID
+MPTBT_FwC2hBtMpCtrl(
+	PADAPTER	Adapter,
+	pu1Byte	tmpBuf,
+	u1Byte		length
+);
+
+void MPh2c_timeout_handle(void *FunctionContext);
+
+VOID mptbt_BtControlProcess(
+	PADAPTER	Adapter,
+	PVOID		pInBuf
+);
+
+#define	BT_H2C_MAX_RETRY								1
+#define	BT_MAX_C2H_LEN								20
+
+typedef struct _BT_REQ_CMD {
+	UCHAR       opCodeVer;
+	UCHAR       OpCode;
+	USHORT      paraLength;
+	UCHAR       pParamStart[100];
+} BT_REQ_CMD, *PBT_REQ_CMD;
+
+typedef struct _BT_RSP_CMD {
+	USHORT      status;
+	USHORT      paraLength;
+	UCHAR       pParamStart[100];
+} BT_RSP_CMD, *PBT_RSP_CMD;
+
+
+typedef struct _BT_H2C {
+	u1Byte	opCodeVer:4;
+	u1Byte	reqNum:4;
+	u1Byte	opCode;
+	u1Byte	buf[100];
+} BT_H2C, *PBT_H2C;
+
+
+
+typedef struct _BT_EXT_C2H {
+	u1Byte	extendId;
+	u1Byte	statusCode:4;
+	u1Byte	retLen:4;
+	u1Byte	opCodeVer:4;
+	u1Byte	reqNum:4;
+	u1Byte	buf[100];
+} BT_EXT_C2H, *PBT_EXT_C2H;
+
+
+typedef enum _BT_OPCODE_STATUS {
+	BT_OP_STATUS_SUCCESS									= 0x00, /* Success */
+	BT_OP_STATUS_VERSION_MISMATCH							= 0x01,
+	BT_OP_STATUS_UNKNOWN_OPCODE								= 0x02,
+	BT_OP_STATUS_ERROR_PARAMETER							= 0x03,
+	BT_OP_STATUS_MAX
+} BT_OPCODE_STATUS, *PBT_OPCODE_STATUS;
+
+
+
+/* OP codes definition between driver and bt fw */
+typedef enum _BT_CTRL_OPCODE_LOWER {
+	BT_LO_OP_GET_BT_VERSION									= 0x00,
+	BT_LO_OP_RESET												= 0x01,
+	BT_LO_OP_TEST_CTRL											= 0x02,
+	BT_LO_OP_SET_BT_MODE										= 0x03,
+	BT_LO_OP_SET_CHNL_TX_GAIN									= 0x04,
+	BT_LO_OP_SET_PKT_TYPE_LEN									= 0x05,
+	BT_LO_OP_SET_PKT_CNT_L_PL_TYPE								= 0x06,
+	BT_LO_OP_SET_PKT_CNT_H_PKT_INTV							= 0x07,
+	BT_LO_OP_SET_PKT_HEADER									= 0x08,
+	BT_LO_OP_SET_WHITENCOEFF									= 0x09,
+	BT_LO_OP_SET_BD_ADDR_L										= 0x0a,
+	BT_LO_OP_SET_BD_ADDR_H										= 0x0b,
+	BT_LO_OP_WRITE_REG_ADDR									= 0x0c,
+	BT_LO_OP_WRITE_REG_VALUE									= 0x0d,
+	BT_LO_OP_GET_BT_STATUS										= 0x0e,
+	BT_LO_OP_GET_BD_ADDR_L										= 0x0f,
+	BT_LO_OP_GET_BD_ADDR_H										= 0x10,
+	BT_LO_OP_READ_REG											= 0x11,
+	BT_LO_OP_SET_TARGET_BD_ADDR_L								= 0x12,
+	BT_LO_OP_SET_TARGET_BD_ADDR_H								= 0x13,
+	BT_LO_OP_SET_TX_POWER_CALIBRATION							= 0x14,
+	BT_LO_OP_GET_RX_PKT_CNT_L									= 0x15,
+	BT_LO_OP_GET_RX_PKT_CNT_H									= 0x16,
+	BT_LO_OP_GET_RX_ERROR_BITS_L								= 0x17,
+	BT_LO_OP_GET_RX_ERROR_BITS_H								= 0x18,
+	BT_LO_OP_GET_RSSI											= 0x19,
+	BT_LO_OP_GET_CFO_HDR_QUALITY_L								= 0x1a,
+	BT_LO_OP_GET_CFO_HDR_QUALITY_H								= 0x1b,
+	BT_LO_OP_GET_TARGET_BD_ADDR_L								= 0x1c,
+	BT_LO_OP_GET_TARGET_BD_ADDR_H								= 0x1d,
+	BT_LO_OP_GET_AFH_MAP_L										= 0x1e,
+	BT_LO_OP_GET_AFH_MAP_M										= 0x1f,
+	BT_LO_OP_GET_AFH_MAP_H										= 0x20,
+	BT_LO_OP_GET_AFH_STATUS									= 0x21,
+	BT_LO_OP_SET_TRACKING_INTERVAL								= 0x22,
+	BT_LO_OP_SET_THERMAL_METER									= 0x23,
+	BT_LO_OP_ENABLE_CFO_TRACKING								= 0x24,
+	BT_LO_OP_MAX
+} BT_CTRL_OPCODE_LOWER, *PBT_CTRL_OPCODE_LOWER;
+
+
+
+
+#endif  /* #if(MP_DRIVER == 1) */
+
+#endif /*  #ifndef __INC_MPT_BT_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_btcoex.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_btcoex.h
new file mode 100644
index 000000000000..fd422489acde
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_btcoex.h
@@ -0,0 +1,455 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#ifdef CONFIG_BT_COEXIST
+
+#ifndef __RTW_BTCOEX_H__
+#define __RTW_BTCOEX_H__
+
+#include <drv_types.h>
+
+/* For H2C: H2C_BT_MP_OPER. Return status definition to the user layer */
+typedef enum _BT_CTRL_STATUS {
+	BT_STATUS_SUCCESS								= 0x00, /* Success */
+	BT_STATUS_BT_OP_SUCCESS							= 0x01, /* bt fw op execution success */
+	BT_STATUS_H2C_SUCCESS							= 0x02, /* H2c success */
+	BT_STATUS_H2C_FAIL								= 0x03, /* H2c fail */
+	BT_STATUS_H2C_LENGTH_EXCEEDED					= 0x04, /* H2c command length exceeded */
+	BT_STATUS_H2C_TIMTOUT							= 0x05, /* H2c timeout */
+	BT_STATUS_H2C_BT_NO_RSP							= 0x06, /* H2c sent, bt no rsp */
+	BT_STATUS_C2H_SUCCESS							= 0x07, /* C2h success */
+	BT_STATUS_C2H_REQNUM_MISMATCH					= 0x08, /* bt fw wrong rsp */
+	BT_STATUS_OPCODE_U_VERSION_MISMATCH				= 0x08, /* Upper layer OP code version mismatch. */
+	BT_STATUS_OPCODE_L_VERSION_MISMATCH				= 0x0a, /* Lower layer OP code version mismatch. */
+	BT_STATUS_UNKNOWN_OPCODE_U						= 0x0b, /* Unknown Upper layer OP code */
+	BT_STATUS_UNKNOWN_OPCODE_L						= 0x0c, /* Unknown Lower layer OP code */
+	BT_STATUS_PARAMETER_FORMAT_ERROR_U				= 0x0d, /* Wrong parameters sent by upper layer. */
+	BT_STATUS_PARAMETER_FORMAT_ERROR_L				= 0x0e, /* bt fw parameter format is not consistency */
+	BT_STATUS_PARAMETER_OUT_OF_RANGE_U				= 0x0f, /* uppery layer parameter value is out of range */
+	BT_STATUS_PARAMETER_OUT_OF_RANGE_L				= 0x10, /* bt fw parameter value is out of range */
+	BT_STATUS_UNKNOWN_STATUS_L						= 0x11, /* bt returned an defined status code */
+	BT_STATUS_UNKNOWN_STATUS_H						= 0x12, /* driver need to do error handle or not handle-well. */
+	BT_STATUS_WRONG_LEVEL							= 0x13, /* should be under passive level */
+	BT_STATUS_NOT_IMPLEMENT						= 0x14, /* op code not implemented yet */
+	BT_STATUS_BT_STACK_OP_SUCCESS					= 0x15, /* bt stack op execution success */
+	BT_STATUS_BT_STACK_NOT_SUPPORT					= 0x16, /* stack version not support this. */
+	BT_STATUS_BT_STACK_SEND_HCI_EVENT_FAIL			= 0x17, /* send hci event fail */
+	BT_STATUS_BT_STACK_NOT_BIND						= 0x18, /* stack not bind wifi driver */
+	BT_STATUS_BT_STACK_NO_RSP						= 0x19, /* stack doesn't have any rsp. */
+	BT_STATUS_MAX
+} BT_CTRL_STATUS, *PBT_CTRL_STATUS;
+
+typedef enum _BTCOEX_SUSPEND_STATE {
+	BTCOEX_SUSPEND_STATE_RESUME					= 0x0,
+	BTCOEX_SUSPEND_STATE_SUSPEND				= 0x1,
+	BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT		= 0x2,
+	BTCOEX_SUSPEND_STATE_MAX
+} BTCOEX_SUSPEND_STATE, *PBTCOEX_SUSPEND_STATE;
+
+#define SET_BT_MP_OPER_RET(OpCode, StatusCode)						((OpCode << 8) | StatusCode)
+#define GET_OP_CODE_FROM_BT_MP_OPER_RET(RetCode)					((RetCode & 0xF0) >> 8)
+#define GET_STATUS_CODE_FROM_BT_MP_OPER_RET(RetCode)				(RetCode & 0x0F)
+#define CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(RetCode, StatusCode)	(GET_STATUS_CODE_FROM_BT_MP_OPER_RET(RetCode) == StatusCode)
+
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+
+#define NETLINK_USER 31
+#define CONNECT_PORT 30000
+#define CONNECT_PORT_BT 30001
+#define KERNEL_SOCKET_OK 0x01
+#define NETLINK_SOCKET_OK 0x02
+
+#define OTHER 0
+#define RX_ATTEND_ACK 1
+#define RX_LEAVE_ACK 2
+#define RX_BT_LEAVE 3
+#define RX_INVITE_REQ 4
+#define RX_ATTEND_REQ 5
+#define RX_INVITE_RSP 6
+
+#define invite_req "INVITE_REQ"
+#define invite_rsp "INVITE_RSP"
+#define attend_req "ATTEND_REQ"
+#define attend_ack "ATTEND_ACK"
+#define wifi_leave "WIFI_LEAVE"
+#define leave_ack "LEAVE_ACK"
+#define bt_leave "BT_LEAVE"
+
+#define BT_INFO_NOTIFY_CMD 0x0106
+#define BT_INFO_LEN 8
+
+typedef struct _HCI_LINK_INFO {
+	u2Byte					ConnectHandle;
+	u1Byte					IncomingTrafficMode;
+	u1Byte					OutgoingTrafficMode;
+	u1Byte					BTProfile;
+	u1Byte					BTCoreSpec;
+	s1Byte					BT_RSSI;
+	u1Byte					TrafficProfile;
+	u1Byte					linkRole;
+} HCI_LINK_INFO, *PHCI_LINK_INFO;
+
+#define	MAX_BT_ACL_LINK_NUM				8
+
+typedef struct _HCI_EXT_CONFIG {
+	HCI_LINK_INFO				aclLink[MAX_BT_ACL_LINK_NUM];
+	u1Byte					btOperationCode;
+	u2Byte					CurrentConnectHandle;
+	u1Byte					CurrentIncomingTrafficMode;
+	u1Byte					CurrentOutgoingTrafficMode;
+
+	u1Byte					NumberOfACL;
+	u1Byte					NumberOfSCO;
+	u1Byte					CurrentBTStatus;
+	u2Byte					HCIExtensionVer;
+
+	BOOLEAN					bEnableWifiScanNotify;
+} HCI_EXT_CONFIG, *PHCI_EXT_CONFIG;
+
+typedef struct _HCI_PHY_LINK_BSS_INFO {
+	u2Byte						bdCap;			/* capability information */
+
+	/* Qos related. Added by Annie, 2005-11-01. */
+	/* BSS_QOS						BssQos;		 */
+
+} HCI_PHY_LINK_BSS_INFO, *PHCI_PHY_LINK_BSS_INFO;
+
+typedef 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
+} BT_CONNECT_TYPE, *PBT_CONNECT_TYPE;
+
+
+typedef struct _PACKET_IRP_HCIEVENT_DATA {
+	u8		EventCode;
+	u8		Length; /* total cmd length = extension event length+1(extension event code length) */
+	u8		Data[1]; /* byte1 is extension event code */
+} rtw_HCI_event;
+
+
+struct btinfo_8761ATV {
+	u8 cid;
+	u8 len;
+
+	u8 bConnection:1;
+	u8 bSCOeSCO:1;
+	u8 bInQPage:1;
+	u8 bACLBusy:1;
+	u8 bSCOBusy:1;
+	u8 bHID:1;
+	u8 bA2DP:1;
+	u8 bFTP:1;
+
+	u8 retry_cnt:4;
+	u8 rsvd_34:1;
+	u8 bPage:1;
+	u8 TRxMask:1;
+	u8 Sniff_attempt:1;
+
+	u8 rssi;
+
+	u8 A2dp_rate:1;
+	u8 ReInit:1;
+	u8 MaxPower:1;
+	u8 bEnIgnoreWlanAct:1;
+	u8 TxPowerLow:1;
+	u8 TxPowerHigh:1;
+	u8 eSCO_SCO:1;
+	u8 Master_Slave:1;
+
+	u8 ACL_TRx_TP_low;
+	u8 ACL_TRx_TP_high;
+};
+
+#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 HCI_OGF(opCode)  (unsigned char)((0xFC00 & (opCode)) >> 10)
+#define HCI_OCF(opCode)  (0x3FF & (opCode))
+
+
+typedef 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 */
+} RTW_HCI_STATUS;
+
+#define HCI_EVENT_COMMAND_COMPLETE					0x0e
+
+#define OGF_EXTENSION									0X3f
+typedef 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,
+	HCI_QUERY_RF_STATUS								= 0x0104,
+	HCI_BT_ABNORMAL_NOTIFY							= 0x0105,
+	HCI_BT_INFO_NOTIFY								= 0x0106,
+	HCI_BT_COEX_NOTIFY								= 0x0107,
+	HCI_BT_PATCH_VERSION_NOTIFY						= 0x0108,
+	HCI_BT_AFH_MAP_NOTIFY							= 0x0109,
+	HCI_BT_REGISTER_VALUE_NOTIFY					= 0x010a,
+
+	/* The following is for IVT */
+	HCI_WIFI_CURRENT_CHANNEL						= 0x0300,
+	HCI_WIFI_CURRENT_BANDWIDTH						= 0x0301,
+	HCI_WIFI_CONNECTION_STATUS						= 0x0302
+} RTW_HCI_EXT_CMD;
+
+#define HCI_EVENT_EXTENSION_RTK						0xfe
+typedef enum HCI_EXTENSION_EVENT_RTK {
+	HCI_EVENT_EXT_WIFI_SCAN_NOTIFY								= 0x01,
+	HCI_EVENT_EXT_WIFI_RF_STATUS_NOTIFY						= 0x02,
+	HCI_EVENT_EXT_BT_INFO_CONTROL								= 0x03,
+	HCI_EVENT_EXT_BT_COEX_CONTROL								= 0x04
+} RTW_HCI_EXT_EVENT;
+
+typedef 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. */
+} BT_TRAFFIC_MODE;
+
+typedef enum _BT_TRAFFIC_MODE_PROFILE {
+	BT_PROFILE_NONE,
+	BT_PROFILE_A2DP,
+	BT_PROFILE_PAN	,
+	BT_PROFILE_HID,
+	BT_PROFILE_SCO
+} BT_TRAFFIC_MODE_PROFILE;
+
+typedef enum _HCI_EXT_BT_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
+} HCI_EXT_BT_OPERATION, *PHCI_EXT_BT_OPERATION;
+
+typedef struct _BT_MGNT {
+	BOOLEAN				bBTConnectInProgress;
+	BOOLEAN				bLogLinkInProgress;
+	BOOLEAN				bPhyLinkInProgress;
+	BOOLEAN				bPhyLinkInProgressStartLL;
+	u1Byte				BtCurrentPhyLinkhandle;
+	u2Byte				BtCurrentLogLinkhandle;
+	u1Byte				CurrentConnectEntryNum;
+	u1Byte				DisconnectEntryNum;
+	u1Byte				CurrentBTConnectionCnt;
+	BT_CONNECT_TYPE		BTCurrentConnectType;
+	BT_CONNECT_TYPE		BTReceiveConnectPkt;
+	u1Byte				BTAuthCount;
+	u1Byte				BTAsocCount;
+	BOOLEAN				bStartSendSupervisionPkt;
+	BOOLEAN				BtOperationOn;
+	BOOLEAN				BTNeedAMPStatusChg;
+	BOOLEAN				JoinerNeedSendAuth;
+	HCI_PHY_LINK_BSS_INFO	bssDesc;
+	HCI_EXT_CONFIG		ExtConfig;
+	BOOLEAN				bNeedNotifyAMPNoCap;
+	BOOLEAN				bCreateSpportQos;
+	BOOLEAN				bSupportProfile;
+	u1Byte				BTChannel;
+	BOOLEAN				CheckChnlIsSuit;
+	BOOLEAN				bBtScan;
+	BOOLEAN				btLogoTest;
+	BOOLEAN				bRfStatusNotified;
+	BOOLEAN				bBtRsvedPageDownload;
+} BT_MGNT, *PBT_MGNT;
+
+struct bt_coex_info {
+	/* For Kernel Socket */
+	struct socket *udpsock;
+	struct sockaddr_in wifi_sockaddr; /*wifi socket*/
+	struct sockaddr_in bt_sockaddr;/* BT socket */
+	struct sock *sk_store;/*back up socket for UDP RX int*/
+
+	/* store which socket is OK */
+	u8 sock_open;
+
+	u8 BT_attend;
+	u8 is_exist; /* socket exist */
+	BT_MGNT BtMgnt;
+	struct workqueue_struct *btcoex_wq;
+	struct delayed_work recvmsg_work;
+};
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+#define	PACKET_NORMAL			0
+#define	PACKET_DHCP				1
+#define	PACKET_ARP				2
+#define	PACKET_EAPOL			3
+
+void rtw_btcoex_Initialize(PADAPTER);
+void rtw_btcoex_PowerOnSetting(PADAPTER padapter);
+void rtw_btcoex_AntInfoSetting(PADAPTER padapter);
+void rtw_btcoex_PowerOffSetting(PADAPTER padapter);
+void rtw_btcoex_PreLoadFirmware(PADAPTER padapter);
+void rtw_btcoex_HAL_Initialize(PADAPTER padapter, u8 bWifiOnly);
+void rtw_btcoex_IpsNotify(PADAPTER, u8 type);
+void rtw_btcoex_LpsNotify(PADAPTER, u8 type);
+void rtw_btcoex_ScanNotify(PADAPTER, u8 type);
+void rtw_btcoex_ConnectNotify(PADAPTER, u8 action);
+void rtw_btcoex_MediaStatusNotify(PADAPTER, u8 mediaStatus);
+void rtw_btcoex_SpecialPacketNotify(PADAPTER, u8 pktType);
+void rtw_btcoex_IQKNotify(PADAPTER padapter, u8 state);
+void rtw_btcoex_BtInfoNotify(PADAPTER, u8 length, u8 *tmpBuf);
+void rtw_btcoex_BtMpRptNotify(PADAPTER, u8 length, u8 *tmpBuf);
+void rtw_btcoex_SuspendNotify(PADAPTER, u8 state);
+void rtw_btcoex_HaltNotify(PADAPTER);
+void rtw_btcoex_switchband_notify(u8 under_scan, u8 band_type);
+void rtw_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length);
+void rtw_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id);
+void rtw_btcoex_SwitchBtTRxMask(PADAPTER);
+void rtw_btcoex_Switch(PADAPTER, u8 enable);
+u8 rtw_btcoex_IsBtDisabled(PADAPTER);
+void rtw_btcoex_Handler(PADAPTER);
+s32 rtw_btcoex_IsBTCoexRejectAMPDU(PADAPTER padapter);
+s32 rtw_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER);
+u32 rtw_btcoex_GetAMPDUSize(PADAPTER);
+void rtw_btcoex_SetManualControl(PADAPTER, u8 bmanual);
+u8 rtw_btcoex_1Ant(PADAPTER);
+u8 rtw_btcoex_IsBtControlLps(PADAPTER);
+u8 rtw_btcoex_IsLpsOn(PADAPTER);
+u8 rtw_btcoex_RpwmVal(PADAPTER);
+u8 rtw_btcoex_LpsVal(PADAPTER);
+u32 rtw_btcoex_GetRaMask(PADAPTER);
+void rtw_btcoex_RecordPwrMode(PADAPTER, u8 *pCmdBuf, u8 cmdLen);
+void rtw_btcoex_DisplayBtCoexInfo(PADAPTER, u8 *pbuf, u32 bufsize);
+void rtw_btcoex_SetDBG(PADAPTER, u32 *pDbgModule);
+u32 rtw_btcoex_GetDBG(PADAPTER, u8 *pStrBuf, u32 bufSize);
+u8 rtw_btcoex_IncreaseScanDeviceNum(PADAPTER);
+u8 rtw_btcoex_IsBtLinkExist(PADAPTER);
+void rtw_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON);
+
+#ifdef CONFIG_RF4CE_COEXIST
+void rtw_btcoex_SetRf4ceLinkState(PADAPTER padapter, u8 state);
+u8 rtw_btcoex_GetRf4ceLinkState(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+void rtw_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer);
+void rtw_btcoex_SetHciVersion(PADAPTER  padapter, u16 hciVersion);
+void rtw_btcoex_StackUpdateProfileInfo(void);
+void rtw_btcoex_init_socket(_adapter *padapter);
+void rtw_btcoex_close_socket(_adapter *padapter);
+void rtw_btcoex_dump_tx_msg(u8 *tx_msg, u8 len, u8 *msg_name);
+u8 rtw_btcoex_sendmsgbysocket(_adapter *padapter, u8 *msg, u8 msg_size, bool force);
+u8 rtw_btcoex_create_kernel_socket(_adapter *padapter);
+void rtw_btcoex_close_kernel_socket(_adapter *padapter);
+void rtw_btcoex_recvmsgbysocket(void *data);
+u16 rtw_btcoex_parse_recv_data(u8 *msg, u8 msg_size);
+u8 rtw_btcoex_btinfo_cmd(PADAPTER padapter, u8 *pbuf, u16 length);
+void rtw_btcoex_parse_hci_cmd(_adapter *padapter, u8 *cmd, u16 len);
+void rtw_btcoex_SendEventExtBtCoexControl(PADAPTER Adapter, u8 bNeedDbgRsp, u8 dataLen, void *pData);
+void rtw_btcoex_SendEventExtBtInfoControl(PADAPTER Adapter, u8 dataLen, void *pData);
+void rtw_btcoex_SendScanNotify(PADAPTER padapter, u8 scanType);
+#define BT_SendEventExtBtCoexControl(Adapter, bNeedDbgRsp, dataLen, pData) rtw_btcoex_SendEventExtBtCoexControl(Adapter, bNeedDbgRsp, dataLen, pData)
+#define BT_SendEventExtBtInfoControl(Adapter, dataLen, pData) rtw_btcoex_SendEventExtBtInfoControl(Adapter, dataLen, pData)
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+u16 rtw_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data);
+u16 rtw_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val);
+u8 rtw_btcoex_get_bt_coexist(PADAPTER padapter);
+u8 rtw_btcoex_get_chip_type(PADAPTER padapter);
+u8 rtw_btcoex_get_pg_ant_num(PADAPTER padapter);
+u8 rtw_btcoex_get_pg_single_ant_path(PADAPTER padapter);
+u8 rtw_btcoex_get_pg_rfe_type(PADAPTER padapter);
+u8 rtw_btcoex_is_tfbga_package_type(PADAPTER padapter);
+u8 rtw_btcoex_get_ant_div_cfg(PADAPTER padapter);
+
+/* ==================================================
+ * Below Functions are called by BT-Coex
+ * ================================================== */
+void rtw_btcoex_rx_ampdu_apply(PADAPTER padapter);
+void rtw_btcoex_LPS_Enter(PADAPTER padapter);
+u8 rtw_btcoex_LPS_Leave(PADAPTER padapter);
+
+#endif /* __RTW_BTCOEX_H__ */
+#endif /* CONFIG_BT_COEXIST */
+
+void rtw_btcoex_set_ant_info(PADAPTER padapter);
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_btcoex_wifionly.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_btcoex_wifionly.h
new file mode 100644
index 000000000000..c5a074092c5c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_btcoex_wifionly.h
@@ -0,0 +1,23 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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_BTCOEX_WIFIONLY_H__
+#define __RTW_BTCOEX_WIFIONLY_H__
+
+void rtw_btcoex_wifionly_switchband_notify(PADAPTER padapter);
+void rtw_btcoex_wifionly_scan_notify(PADAPTER padapter);
+void rtw_btcoex_wifionly_hw_config(PADAPTER padapter);
+void rtw_btcoex_wifionly_initialize(PADAPTER padapter);
+void rtw_btcoex_wifionly_AntInfoSetting(PADAPTER padapter);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_byteorder.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_byteorder.h
new file mode 100644
index 000000000000..8e6bb7a6df01
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_byteorder.h
@@ -0,0 +1,33 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL871X_BYTEORDER_H_
+#define _RTL871X_BYTEORDER_H_
+
+
+#if defined(CONFIG_LITTLE_ENDIAN) && defined (CONFIG_BIG_ENDIAN)
+	#error "Shall be CONFIG_LITTLE_ENDIAN or CONFIG_BIG_ENDIAN, but not both!\n"
+#endif
+
+#if defined(CONFIG_LITTLE_ENDIAN)
+	#ifndef CONFIG_PLATFORM_MSTAR389
+		#include <byteorder/little_endian.h>
+	#endif
+#elif defined (CONFIG_BIG_ENDIAN)
+	#include <byteorder/big_endian.h>
+#else
+	#  error "Must be LITTLE/BIG Endian Host"
+#endif
+
+#endif /* _RTL871X_BYTEORDER_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_cmd.h
new file mode 100644
index 000000000000..914dbb094f62
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_cmd.h
@@ -0,0 +1,1323 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#define C2H_MEM_SZ (16*1024)
+
+#ifndef CONFIG_RTL8711FW
+
+#define FREE_CMDOBJ_SZ	128
+
+#define MAX_CMDSZ	1024
+#define MAX_RSPSZ	512
+#define MAX_EVTSZ	1024
+
+#ifdef PLATFORM_OS_CE
+	#define CMDBUFF_ALIGN_SZ 4
+#else
+	#define CMDBUFF_ALIGN_SZ 512
+#endif
+
+struct cmd_obj {
+	_adapter *padapter;
+	u16	cmdcode;
+	u8	res;
+	u8	*parmbuf;
+	u32	cmdsz;
+	u8	*rsp;
+	u32	rspsz;
+	struct submit_ctx *sctx;
+	u8 no_io;
+	/* _sema 	cmd_sem; */
+	_list	list;
+};
+
+/* cmd flags */
+enum {
+	RTW_CMDF_DIRECTLY = BIT0,
+	RTW_CMDF_WAIT_ACK = BIT1,
+};
+
+struct cmd_priv {
+	_sema	cmd_queue_sema;
+	/* _sema	cmd_done_sema; */
+	_sema	start_cmdthread_sema;
+
+	_queue	cmd_queue;
+	u8	cmd_seq;
+	u8	*cmd_buf;	/* shall be non-paged, and 4 bytes aligned */
+	u8	*cmd_allocated_buf;
+	u8	*rsp_buf;	/* shall be non-paged, and 4 bytes aligned		 */
+	u8	*rsp_allocated_buf;
+	u32	cmd_issued_cnt;
+	u32	cmd_done_cnt;
+	u32	rsp_cnt;
+	ATOMIC_T cmdthd_running;
+	/* u8 cmdthd_running; */
+
+	_adapter *padapter;
+	_mutex sctx_mutex;
+};
+
+#ifdef CONFIG_EVENT_THREAD_MODE
+struct evt_obj {
+	u16	evtcode;
+	u8	res;
+	u8	*parmbuf;
+	u32	evtsz;
+	_list	list;
+};
+#endif
+
+struct	evt_priv {
+#ifdef CONFIG_EVENT_THREAD_MODE
+	_sema	evt_notify;
+
+	_queue	evt_queue;
+#endif
+
+#ifdef CONFIG_FW_C2H_REG
+	#define CONFIG_C2H_WK
+#endif
+
+#ifdef CONFIG_C2H_WK
+	_workitem c2h_wk;
+	bool c2h_wk_alive;
+	struct rtw_cbuf *c2h_queue;
+	#define C2H_QUEUE_MAX_LEN 10
+#endif
+
+#ifdef CONFIG_H2CLBK
+	_sema	lbkevt_done;
+	u8	lbkevt_limit;
+	u8	lbkevt_num;
+	u8	*cmdevt_parm;
+#endif
+	ATOMIC_T event_seq;
+	u8	*evt_buf;	/* shall be non-paged, and 4 bytes aligned		 */
+	u8	*evt_allocated_buf;
+	u32	evt_done_cnt;
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	u8	*c2h_mem;
+	u8	*allocated_c2h_mem;
+#ifdef PLATFORM_OS_XP
+	PMDL	pc2h_mdl;
+#endif
+#endif
+
+};
+
+#define init_h2fwcmd_w_parm_no_rsp(pcmd, pparm, code) \
+	do {\
+		_rtw_init_listhead(&pcmd->list);\
+		pcmd->cmdcode = code;\
+		pcmd->parmbuf = (u8 *)(pparm);\
+		pcmd->cmdsz = sizeof (*pparm);\
+		pcmd->rsp = NULL;\
+		pcmd->rspsz = 0;\
+	} while (0)
+
+#define init_h2fwcmd_w_parm_no_parm_rsp(pcmd, code) \
+	do {\
+		_rtw_init_listhead(&pcmd->list);\
+		pcmd->cmdcode = code;\
+		pcmd->parmbuf = NULL;\
+		pcmd->cmdsz = 0;\
+		pcmd->rsp = NULL;\
+		pcmd->rspsz = 0;\
+	} while (0)
+
+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 */
+};
+
+#ifdef CONFIG_P2P_WOWLAN
+
+struct P2P_WoWlan_Offload_t {
+	u8 Disconnect_Wkup_Drv:1;
+	u8 role:2;
+	u8 Wps_Config[2];
+};
+
+#endif /* CONFIG_P2P_WOWLAN */
+
+extern u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *obj);
+extern struct cmd_obj *rtw_dequeue_cmd(struct cmd_priv *pcmdpriv);
+extern void rtw_free_cmd_obj(struct cmd_obj *pcmd);
+
+#ifdef CONFIG_EVENT_THREAD_MODE
+extern u32 rtw_enqueue_evt(struct evt_priv *pevtpriv, struct evt_obj *obj);
+extern struct evt_obj *rtw_dequeue_evt(_queue *queue);
+extern void rtw_free_evt_obj(struct evt_obj *pcmd);
+#endif
+
+void rtw_stop_cmd_thread(_adapter *adapter);
+thread_return rtw_cmd_thread(thread_context context);
+
+extern u32 rtw_init_cmd_priv(struct cmd_priv *pcmdpriv);
+extern void rtw_free_cmd_priv(struct cmd_priv *pcmdpriv);
+
+extern u32 rtw_init_evt_priv(struct evt_priv *pevtpriv);
+extern void rtw_free_evt_priv(struct evt_priv *pevtpriv);
+extern void rtw_cmd_clr_isr(struct cmd_priv *pcmdpriv);
+extern void rtw_evt_notify_isr(struct evt_priv *pevtpriv);
+#ifdef CONFIG_P2P
+u8 p2p_protocol_wk_cmd(_adapter *padapter, int intCmdType);
+
+#ifdef CONFIG_IOCTL_CFG80211
+struct p2p_roch_parm {
+	u64 cookie;
+	struct wireless_dev *wdev;
+	struct ieee80211_channel ch;
+	enum nl80211_channel_type ch_type;
+	unsigned int duration;
+};
+
+u8 p2p_roch_cmd(_adapter *adapter
+	, u64 cookie, struct wireless_dev *wdev
+	, struct ieee80211_channel *ch, enum nl80211_channel_type ch_type
+	, unsigned int duration
+	, u8 flags
+);
+u8 p2p_cancel_roch_cmd(_adapter *adapter, u64 cookie, struct wireless_dev *wdev, u8 flags);
+
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_IOCTL_CFG80211 
+u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack, u8 flags);
+struct mgnt_tx_parm {
+	u8 tx_ch;
+	u8 no_cck;
+	const u8 *buf;
+	size_t len;
+	int wait_ack;
+};
+#endif
+
+#else
+/* #include <ieee80211.h> */
+#endif	/* CONFIG_RTL8711FW */
+
+enum rtw_drvextra_cmd_id {
+	NONE_WK_CID,
+	STA_MSTATUS_RPT_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 */
+	INTEl_WIDI_WK_CID,
+	C2H_WK_CID,
+	RTP_TIMER_CFG_WK_CID,
+	RESET_SECURITYPRIV, /* add for CONFIG_IEEE80211W, none 11w also can use */
+	FREE_ASSOC_RESOURCES, /* add for CONFIG_IEEE80211W, none 11w also can use */
+	DM_IN_LPS_WK_CID,
+	DM_RA_MSK_WK_CID, /* add for STA update RAMask when bandwith change. */
+	BEAMFORMING_WK_CID,
+	LPS_CHANGE_DTIM_CID,
+	BTINFO_WK_CID,
+	DFS_MASTER_WK_CID,
+	SESSION_TRACKER_WK_CID,
+	EN_HW_UPDATE_TSF_WK_CID,
+	TEST_H2C_CID,
+	MP_CMD_WK_CID,
+	CUSTOMER_STR_WK_CID,
+#ifdef CONFIG_RTW_REPEATER_SON
+	RSON_SCAN_WK_CID,
+#endif
+	MGNT_TX_WK_CID,
+#ifdef CONFIG_MCC_MODE
+	MCC_SET_DURATION_WK_CID,
+#endif /* CONFIG_MCC_MODE */
+	REQ_PER_CMD_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,
+	LPS_CTRL_TRAFFIC_BUSY = 6,
+	LPS_CTRL_TX_TRAFFIC_LEAVE = 7,
+	LPS_CTRL_RX_TRAFFIC_LEAVE = 8,
+	LPS_CTRL_ENTER = 9,
+	LPS_CTRL_LEAVE_CFG80211_PWRMGMT = 10,
+};
+
+enum STAKEY_TYPE {
+	GROUP_KEY		= 0,
+	UNICAST_KEY		= 1,
+	TDLS_KEY		= 2,
+};
+
+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
+
+Notes: To join the specified bss
+
+Command Event Mode
+
+*/
+struct joinbss_parm {
+	WLAN_BSSID_EX network;
+};
+
+/*
+Caller Mode: Infra, Ad-HoC(C)
+
+Notes: To disconnect the current associated BSS
+
+Command Mode
+
+*/
+struct disconnect_parm {
+	u32 deauth_timeout_ms;
+};
+
+/*
+Caller Mode: AP, Ad-HoC(M)
+
+Notes: To create a BSS
+
+Command Mode
+*/
+struct createbss_parm {
+	bool adhoc;
+
+	/* used by AP mode now */
+	s16 req_ch;
+	s8 req_bw;
+	s8 req_offset;
+};
+
+#if 0
+/* Caller Mode: AP, Ad-HoC, Infra */
+/* Notes: To set the NIC mode of RTL8711 */
+/* Command Mode */
+/* The definition of mode: */
+
+#define IW_MODE_AUTO	0	/*  Let the driver decides which AP to join */
+#define IW_MODE_ADHOC	1	/*  Single cell network (Ad-Hoc Clients) */
+#define IW_MODE_INFRA	2	/*  Multi cell network, roaming, .. */
+#define IW_MODE_MASTER	3	/*  Synchronisation master or Access Point */
+#define IW_MODE_REPEAT	4	/*  Wireless Repeater (forwarder) */
+#define IW_MODE_SECOND	5	/*  Secondary master/repeater (backup) */
+#define IW_MODE_MONITOR	6	/*  Passive monitor (listen only) */
+#endif
+
+struct	setopmode_parm {
+	u8	mode;
+	u8	rsvd[3];
+};
+
+/*
+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 {
+	sint scan_mode;	/* active: 1, passive: 0 */
+	/* sint bsslimit;	// 1 ~ 48 */
+	u8 ssid_num;
+	u8 ch_num;
+	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];
+	struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
+
+	u32 token; 	/* 80211k use it to identify caller */
+	u16 duration;	/* 0: use default, otherwise: channel scan time */
+	u8 igi;		/* 0: use defalut */
+	u8 bw;		/* 0: use default */
+};
+
+/*
+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 {
+	u8	algorithm;	/* encryption algorithm, could be none, wep40, TKIP, CCMP, wep104 */
+	u8	keyid;
+	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 algorithm;
+	u8 keyid;
+	u8 key[16];
+	u8 gk;
+};
+
+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 {
+#ifdef MP_FIRMWARE_OFFLOAD
+	u32	curr_rateidx;
+#else
+	u8	mac_id;
+	u8	datarates[NumRates];
+#endif
+};
+
+/*
+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
+
+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 readMAC_parm {
+	u8 len;
+	u32	addr;
+};
+
+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 {
+	WLAN_BSSID_EX network;
+};
+
+/*
+	Notes: This command is used for H2C/C2H loopback testing
+
+	mac[0] == 0
+	==> CMD mode, return H2C_SUCCESS.
+	The following condition must be ture under CMD mode
+		mac[1] == mac[4], mac[2] == mac[3], mac[0]=mac[5]= 0;
+		s0 == 0x1234, s1 == 0xabcd, w0 == 0x78563412, w1 == 0x5aa5def7;
+		s2 == (b1 << 8 | b0);
+
+	mac[0] == 1
+	==> CMD_RSP mode, return H2C_SUCCESS_RSP
+
+	The rsp layout shall be:
+	rsp:			parm:
+		mac[0]  =   mac[5];
+		mac[1]  =   mac[4];
+		mac[2]  =   mac[3];
+		mac[3]  =   mac[2];
+		mac[4]  =   mac[1];
+		mac[5]  =   mac[0];
+		s0		=   s1;
+		s1		=   swap16(s0);
+		w0		=	swap32(w1);
+		b0		=	b1
+		s2		=	s0 + s1
+		b1		=	b0
+		w1		=	w0
+
+	mac[0] ==	2
+	==> CMD_EVENT mode, return	H2C_SUCCESS
+	The event layout shall be:
+	event:			parm:
+		mac[0]  =   mac[5];
+		mac[1]  =   mac[4];
+		mac[2]  =   event's sequence number, starting from 1 to parm's marc[3]
+		mac[3]  =   mac[2];
+		mac[4]  =   mac[1];
+		mac[5]  =   mac[0];
+		s0		=   swap16(s0) - event.mac[2];
+		s1		=   s1 + event.mac[2];
+		w0		=	swap32(w0);
+		b0		=	b1
+		s2		=	s0 + event.mac[2]
+		b1		=	b0
+		w1		=	swap32(w1) - event.mac[2];
+
+		parm->mac[3] is the total event counts that host requested.
+
+
+	event will be the same with the cmd's param.
+
+*/
+
+#ifdef CONFIG_H2CLBK
+
+struct seth2clbk_parm {
+	u8 mac[6];
+	u16	s0;
+	u16	s1;
+	u32	w0;
+	u8	b0;
+	u16  s2;
+	u8	b1;
+	u32	w1;
+};
+
+struct geth2clbk_parm {
+	u32 rsv;
+};
+
+struct geth2clbk_rsp {
+	u8	mac[6];
+	u16	s0;
+	u16	s1;
+	u32	w0;
+	u8	b0;
+	u16	s2;
+	u8	b1;
+	u32	w1;
+};
+
+#endif	/* CONFIG_H2CLBK */
+
+/* CMD param Formart for driver extra cmd handler */
+struct drvextra_cmd_parm {
+	int ec_id; /* extra cmd id */
+	int type; /* Can use this field as the type id or command size */
+	int size; /* buffer 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];
+};
+
+struct addBaRsp_parm {
+	unsigned int tid;
+	unsigned int start_seq;
+	u8 addr[ETH_ALEN];
+	u8 status;
+	u8 size;
+};
+
+/*H2C Handler index: 46 */
+struct set_ch_parm {
+	u8 ch;
+	u8 bw;
+	u8 ch_offset;
+};
+
+#ifdef MP_FIRMWARE_OFFLOAD
+/*H2C Handler index: 47 */
+struct SetTxPower_parm {
+	u8 TxPower;
+};
+
+/*H2C Handler index: 48 */
+struct SwitchAntenna_parm {
+	u16 antenna_tx;
+	u16 antenna_rx;
+	/*	R_ANTENNA_SELECT_CCK cck_txrx; */
+	u8 cck_txrx;
+};
+
+/*H2C Handler index: 49 */
+struct SetCrystalCap_parm {
+	u32 curr_crystalcap;
+};
+
+/*H2C Handler index: 50 */
+struct SetSingleCarrierTx_parm {
+	u8 bStart;
+};
+
+/*H2C Handler index: 51 */
+struct SetSingleToneTx_parm {
+	u8 bStart;
+	u8 curr_rfpath;
+};
+
+/*H2C Handler index: 52 */
+struct SetCarrierSuppressionTx_parm {
+	u8 bStart;
+	u32 curr_rateidx;
+};
+
+/*H2C Handler index: 53 */
+struct SetContinuousTx_parm {
+	u8 bStart;
+	u8 CCK_flag; /*1:CCK 2:OFDM*/
+	u32 curr_rateidx;
+};
+
+/*H2C Handler index: 54 */
+struct SwitchBandwidth_parm {
+	u8 curr_bandwidth;
+};
+
+#endif	/* MP_FIRMWARE_OFFLOAD */
+
+/*H2C Handler index: 59 */
+struct SetChannelPlan_param {
+	const struct country_chplan *country_ent;
+	u8 channel_plan;
+};
+
+/*H2C Handler index: 60 */
+struct LedBlink_param {
+	PVOID	 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;
+};
+
+/*H2C Handler index: 64 */
+struct RunInThread_param {
+	void (*func)(void *);
+	void *context;
+};
+
+
+#define GEN_CMD_CODE(cmd)	cmd ## _CMD_
+
+
+/*
+
+Result:
+0x00: success
+0x01: sucess, 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
+#define H2C_ENQ_HEAD			0x08
+#define H2C_ENQ_HEAD_FAIL		0x09
+#define H2C_CMD_FAIL			0x0A
+
+extern u8 rtw_setassocsta_cmd(_adapter  *padapter, u8 *mac_addr);
+extern u8 rtw_setstandby_cmd(_adapter *padapter, uint action);
+void rtw_init_sitesurvey_parm(_adapter *padapter, struct sitesurvey_parm *pparm);
+u8 rtw_sitesurvey_cmd(_adapter *padapter, struct sitesurvey_parm *pparm);
+u8 rtw_create_ibss_cmd(_adapter *adapter, int flags);
+u8 rtw_startbss_cmd(_adapter *adapter, int flags);
+
+#define REQ_CH_NONE		-1
+#define REQ_BW_NONE		-1
+#define REQ_OFFSET_NONE	-1
+
+u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, s16 req_ch, s8 req_bw, s8 req_offset);
+
+extern u8 rtw_setphy_cmd(_adapter  *padapter, u8 modem, u8 ch);
+
+struct sta_info;
+extern u8 rtw_setstakey_cmd(_adapter  *padapter, struct sta_info *sta, u8 key_type, bool enqueue);
+extern u8 rtw_clearstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 enqueue);
+
+extern u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork);
+u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, int flags);
+extern u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, u8 flags);
+extern u8 rtw_setdatarate_cmd(_adapter  *padapter, u8 *rateset);
+extern u8 rtw_setbasicrate_cmd(_adapter  *padapter, u8 *rateset);
+extern u8 rtw_getmacreg_cmd(_adapter *padapter, u8 len, u32 addr);
+extern void rtw_usb_catc_trigger_cmd(_adapter *padapter, const char *caller);
+extern u8 rtw_setbbreg_cmd(_adapter *padapter, u8 offset, u8 val);
+extern u8 rtw_setrfreg_cmd(_adapter *padapter, u8 offset, u32 val);
+extern u8 rtw_getbbreg_cmd(_adapter *padapter, u8 offset, u8 *pval);
+extern u8 rtw_getrfreg_cmd(_adapter *padapter, u8 offset, u8 *pval);
+extern u8 rtw_setrfintfs_cmd(_adapter  *padapter, u8 mode);
+extern u8 rtw_setrttbl_cmd(_adapter  *padapter, struct setratable_parm *prate_table);
+extern u8 rtw_getrttbl_cmd(_adapter  *padapter, struct getratable_rsp *pval);
+
+extern u8 rtw_gettssi_cmd(_adapter  *padapter, u8 offset, u8 *pval);
+extern u8 rtw_setfwdig_cmd(_adapter *padapter, u8 type);
+extern u8 rtw_setfwra_cmd(_adapter *padapter, u8 type);
+
+extern u8 rtw_addbareq_cmd(_adapter *padapter, u8 tid, u8 *addr);
+extern u8 rtw_addbarsp_cmd(_adapter *padapter, u8 *addr, u16 tid, u8 status, u8 size, u16 start_seq);
+/* add for CONFIG_IEEE80211W, none 11w also can use */
+extern u8 rtw_reset_securitypriv_cmd(_adapter *padapter);
+extern u8 rtw_free_assoc_resources_cmd(_adapter *padapter);
+extern u8 rtw_dynamic_chk_wk_cmd(_adapter *adapter);
+
+u8 rtw_lps_ctrl_wk_cmd(_adapter *padapter, u8 lps_ctrl_type, u8 enqueue);
+u8 rtw_dm_in_lps_wk_cmd(_adapter *padapter);
+u8 rtw_lps_change_dtim_cmd(_adapter *padapter, u8 dtim);
+
+#if (RATE_ADAPTIVE_SUPPORT == 1)
+u8 rtw_rpt_timer_cfg_cmd(_adapter *padapter, u16 minRptTime);
+#endif
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
+extern  u8 rtw_antenna_select_cmd(_adapter *padapter, u8 antenna, u8 enqueue);
+#endif
+
+u8 rtw_dm_ra_mask_wk_cmd(_adapter *padapter, u8 *psta);
+
+extern u8 rtw_ps_cmd(_adapter *padapter);
+
+#ifdef CONFIG_AP_MODE
+u8 rtw_chk_hi_queue_cmd(_adapter *padapter);
+#ifdef CONFIG_DFS_MASTER
+u8 rtw_dfs_master_cmd(_adapter *adapter, bool enqueue);
+void rtw_dfs_master_timer_hdl(void *ctx);
+void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset);
+void rtw_dfs_master_disable(_adapter *adapter, u8 ch, u8 bw, u8 offset, bool by_others);
+void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action);
+#endif /* CONFIG_DFS_MASTER */
+#endif /* CONFIG_AP_MODE */
+
+#ifdef CONFIG_BT_COEXIST
+u8 rtw_btinfo_cmd(PADAPTER padapter, u8 *pbuf, u16 length);
+#endif
+
+u8 rtw_test_h2c_cmd(_adapter *adapter, u8 *buf, u8 len);
+
+u8 rtw_enable_hw_update_tsf_cmd(_adapter *padapter);
+
+u8 rtw_set_chbw_cmd(_adapter *padapter, u8 ch, u8 bw, u8 ch_offset, u8 flags);
+
+u8 rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, u8 swconfig);
+u8 rtw_set_country_cmd(_adapter *adapter, int flags, const char *country_code, u8 swconfig);
+
+extern u8 rtw_led_blink_cmd(_adapter *padapter, PVOID pLed);
+extern u8 rtw_set_csa_cmd(_adapter *padapter, u8 new_ch_no);
+extern u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option);
+
+u8 rtw_mp_cmd(_adapter *adapter, u8 mp_cmd_id, u8 flags);
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+u8 rtw_customer_str_req_cmd(_adapter *adapter);
+u8 rtw_customer_str_write_cmd(_adapter *adapter, const u8 *cstr);
+#endif
+
+#ifdef CONFIG_FW_C2H_REG
+u8 rtw_c2h_reg_wk_cmd(_adapter *adapter, u8 *c2h_evt);
+#endif
+#ifdef CONFIG_FW_C2H_PKT
+u8 rtw_c2h_packet_wk_cmd(_adapter *adapter, u8 *c2h_evt, u16 length);
+#endif
+
+#ifdef CONFIG_RTW_REPEATER_SON
+#define RSON_SCAN_PROCESS		10
+#define RSON_SCAN_DISABLE		11
+u8 rtw_rson_scan_wk_cmd(_adapter *adapter, int op);
+#endif
+
+u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void *), void *context);
+
+u8 session_tracker_chk_cmd(_adapter *adapter, struct sta_info *sta);
+u8 session_tracker_add_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
+u8 session_tracker_del_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
+
+#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
+u8 rtw_req_per_cmd(_adapter * adapter);
+#endif
+
+u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf);
+
+extern void rtw_survey_cmd_callback(_adapter  *padapter, struct cmd_obj *pcmd);
+extern void rtw_disassoc_cmd_callback(_adapter  *padapter, struct cmd_obj *pcmd);
+extern void rtw_joinbss_cmd_callback(_adapter  *padapter, struct cmd_obj *pcmd);
+void rtw_create_ibss_post_hdl(_adapter *padapter, int status);
+extern void rtw_getbbrfreg_cmdrsp_callback(_adapter  *padapter, struct cmd_obj *pcmd);
+extern void rtw_readtssi_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd);
+
+extern void rtw_setstaKey_cmdrsp_callback(_adapter  *padapter,  struct cmd_obj *pcmd);
+extern void rtw_setassocsta_cmdrsp_callback(_adapter  *padapter,  struct cmd_obj *pcmd);
+extern void rtw_getrttbl_cmdrsp_callback(_adapter  *padapter,  struct cmd_obj *pcmd);
+extern void rtw_getmacreg_cmdrsp_callback(_adapter *padapter,  struct cmd_obj *pcmd);
+
+
+struct _cmd_callback {
+	u32	cmd_code;
+	void (*callback)(_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*/
+	GEN_CMD_CODE(_ChkBMCSleepq), /*63*/
+
+	GEN_CMD_CODE(_RunInThreadCMD), /*64*/
+	GEN_CMD_CODE(_AddBARsp) , /*65*/
+	GEN_CMD_CODE(_RM_POST_EVENT), /*66*/
+
+	MAX_H2CCMD
+};
+
+#define _GetMACReg_CMD_ _Read_MACREG_CMD_
+#define _SetMACReg_CMD_ _Write_MACREG_CMD_
+#define _GetBBReg_CMD_		_Read_BBREG_CMD_
+#define _SetBBReg_CMD_		_Write_BBREG_CMD_
+#define _GetRFReg_CMD_		_Read_RFREG_CMD_
+#define _SetRFReg_CMD_		_Write_RFREG_CMD_
+
+#ifdef _RTW_CMD_C_
+struct _cmd_callback	rtw_cmd_callback[] = {
+	{GEN_CMD_CODE(_Read_MACREG), &rtw_getmacreg_cmdrsp_callback}, /*0*/
+	{GEN_CMD_CODE(_Write_MACREG), NULL},
+	{GEN_CMD_CODE(_Read_BBREG), &rtw_getbbrfreg_cmdrsp_callback},
+	{GEN_CMD_CODE(_Write_BBREG), NULL},
+	{GEN_CMD_CODE(_Read_RFREG), &rtw_getbbrfreg_cmdrsp_callback},
+	{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_cmd_callback},  /*14*/
+	{GEN_CMD_CODE(_DisConnect), &rtw_disassoc_cmd_callback}, /*15*/
+	{GEN_CMD_CODE(_CreateBss), NULL},
+	{GEN_CMD_CODE(_SetOpMode), NULL},
+	{GEN_CMD_CODE(_SiteSurvey), &rtw_survey_cmd_callback}, /*18*/
+	{GEN_CMD_CODE(_SetAuth), NULL},
+
+	{GEN_CMD_CODE(_SetKey), NULL},	/*20*/
+	{GEN_CMD_CODE(_SetStaKey), &rtw_setstaKey_cmdrsp_callback},
+	{GEN_CMD_CODE(_SetAssocSta), &rtw_setassocsta_cmdrsp_callback},
+	{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*/
+	{GEN_CMD_CODE(_ChkBMCSleepq), NULL}, /*63*/
+
+	{GEN_CMD_CODE(_RunInThreadCMD), NULL},/*64*/
+	{GEN_CMD_CODE(_AddBARsp), NULL}, /*65*/
+	{GEN_CMD_CODE(_RM_POST_EVENT), NULL}, /*66*/
+};
+#endif
+
+#define CMD_FMT "cmd=%d,%d,%d"
+#define CMD_ARG(cmd) \
+	(cmd)->cmdcode, \
+	(cmd)->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra) ? ((struct drvextra_cmd_parm *)(cmd)->parmbuf)->ec_id : ((cmd)->cmdcode == GEN_CMD_CODE(_Set_MLME_EVT) ? ((struct C2HEvent_Header *)(cmd)->parmbuf)->ID : 0), \
+	(cmd)->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra) ? ((struct drvextra_cmd_parm *)(cmd)->parmbuf)->type : 0
+
+#endif /* _CMD_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_debug.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_debug.h
new file mode 100644
index 000000000000..66f8c5c14b6e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_debug.h
@@ -0,0 +1,606 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+/* driver log level*/
+enum {
+	_DRV_NONE_ = 0,
+	_DRV_ALWAYS_ = 1,
+	_DRV_ERR_ = 2,
+	_DRV_WARNING_ = 3,
+	_DRV_INFO_ = 4,
+	_DRV_DEBUG_ = 5,
+	_DRV_MAX_ = 6
+};
+
+#define DRIVER_PREFIX "RTW: "
+
+#ifdef PLATFORM_OS_CE
+extern void rtl871x_cedbg(const char *fmt, ...);
+#endif
+
+#ifdef PLATFORM_WINDOWS
+	#define RTW_PRINT do {} while (0)
+	#define RTW_ERR do {} while (0)
+	#define RTW_WARN do {} while (0)
+	#define RTW_INFO do {} while (0)
+	#define RTW_DBG do {} while (0)
+	#define RTW_PRINT_SEL do {} while (0)
+	#define _RTW_PRINT do {} while (0)
+	#define _RTW_ERR do {} while (0)
+	#define _RTW_WARN do {} while (0)
+	#define _RTW_INFO do {} while (0)
+	#define _RTW_DBG do {} while (0)
+	#define _RTW_PRINT_SEL do {} while (0)
+#else
+	#define RTW_PRINT(x, ...) do {} while (0)
+	#define RTW_ERR(x, ...) do {} while (0)
+	#define RTW_WARN(x,...) do {} while (0)
+	#define RTW_INFO(x,...) do {} while (0)
+	#define RTW_DBG(x,...) do {} while (0)
+	#define RTW_PRINT_SEL(x,...) do {} while (0)
+	#define _RTW_PRINT(x, ...) do {} while (0)
+	#define _RTW_ERR(x, ...) do {} while (0)
+	#define _RTW_WARN(x,...) do {} while (0)
+	#define _RTW_INFO(x,...) do {} while (0)
+	#define _RTW_DBG(x,...) do {} while (0)
+	#define _RTW_PRINT_SEL(x,...) do {} while (0)
+#endif
+
+#define RTW_INFO_DUMP(_TitleString, _HexData, _HexDataLen) do {} while (0)
+#define RTW_DBG_DUMP(_TitleString, _HexData, _HexDataLen) do {} while (0)
+#define RTW_PRINT_DUMP(_TitleString, _HexData, _HexDataLen) do {} while (0)
+
+#define RTW_DBG_EXPR(EXPR) do {} while (0)
+
+#define RTW_DBGDUMP 0 /* 'stream' for _dbgdump */
+
+
+
+#undef _dbgdump
+#undef _seqdump
+
+#if defined(PLATFORM_WINDOWS) && defined(PLATFORM_OS_XP)
+	#define _dbgdump DbgPrint
+	#define KERN_CONT
+	#define _seqdump(sel, fmt, arg...) _dbgdump(fmt, ##arg)
+#elif defined(PLATFORM_WINDOWS) && defined(PLATFORM_OS_CE)
+	#define _dbgdump rtl871x_cedbg
+	#define KERN_CONT
+	#define _seqdump(sel, fmt, arg...) _dbgdump(fmt, ##arg)
+#elif defined PLATFORM_LINUX
+	#define _dbgdump printk
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+	#define KERN_CONT
+	#endif
+	#define _seqdump seq_printf
+#elif defined PLATFORM_FREEBSD
+	#define _dbgdump printf
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+	#define KERN_CONT
+	#endif
+	#define _seqdump(sel, fmt, arg...) _dbgdump(fmt, ##arg)
+#endif
+
+void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
+								bool _idx_show, const u8 *_hexdata, int _hexdatalen);
+
+#ifdef CONFIG_RTW_DEBUG
+
+#ifndef _OS_INTFS_C_
+extern uint rtw_drv_log_level;
+#endif
+
+#if defined(_dbgdump)
+
+/* with driver-defined prefix */
+#undef RTW_PRINT
+#define RTW_PRINT(fmt, arg...)     \
+	do {\
+		if (_DRV_ALWAYS_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef RTW_ERR
+#define RTW_ERR(fmt, arg...)     \
+	do {\
+		if (_DRV_ERR_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX"ERROR " fmt, ##arg);\
+		} \
+	} while (0)
+
+
+#undef RTW_WARN
+#define RTW_WARN(fmt, arg...)     \
+	do {\
+		if (_DRV_WARNING_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX"WARN " fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef RTW_INFO
+#define RTW_INFO(fmt, arg...)     \
+	do {\
+		if (_DRV_INFO_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX fmt, ##arg);\
+		} \
+	} while (0)
+
+
+#undef RTW_DBG
+#define RTW_DBG(fmt, arg...)     \
+	do {\
+		if (_DRV_DEBUG_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef RTW_INFO_DUMP
+#define RTW_INFO_DUMP(_TitleString, _HexData, _HexDataLen)	\
+	RTW_BUF_DUMP_SEL(_DRV_INFO_, RTW_DBGDUMP, _TitleString, _FALSE, _HexData, _HexDataLen)
+
+#undef RTW_DBG_DUMP
+#define RTW_DBG_DUMP(_TitleString, _HexData, _HexDataLen)	\
+	RTW_BUF_DUMP_SEL(_DRV_DEBUG_, RTW_DBGDUMP, _TitleString, _FALSE, _HexData, _HexDataLen)
+
+
+#undef RTW_PRINT_DUMP
+#define RTW_PRINT_DUMP(_TitleString, _HexData, _HexDataLen)	\
+	RTW_BUF_DUMP_SEL(_DRV_ALWAYS_, RTW_DBGDUMP, _TitleString, _FALSE, _HexData, _HexDataLen)
+
+/* without driver-defined prefix */
+#undef _RTW_PRINT
+#define _RTW_PRINT(fmt, arg...)     \
+	do {\
+		if (_DRV_ALWAYS_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef _RTW_ERR
+#define _RTW_ERR(fmt, arg...)     \
+	do {\
+		if (_DRV_ERR_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
+
+
+#undef _RTW_WARN
+#define _RTW_WARN(fmt, arg...)     \
+	do {\
+		if (_DRV_WARNING_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef _RTW_INFO
+#define _RTW_INFO(fmt, arg...)     \
+	do {\
+		if (_DRV_INFO_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef _RTW_DBG
+#define _RTW_DBG(fmt, arg...)     \
+	do {\
+		if (_DRV_DEBUG_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
+
+
+/* other debug APIs */
+#undef RTW_DBG_EXPR
+#define RTW_DBG_EXPR(EXPR) do { if (_DRV_DEBUG_ <= rtw_drv_log_level) EXPR; } while (0)
+
+#endif /* defined(_dbgdump) */
+#endif /* CONFIG_RTW_DEBUG */
+
+
+#if defined(_seqdump)
+/* dump message to selected 'stream' with driver-defined prefix */
+#undef RTW_PRINT_SEL
+#define RTW_PRINT_SEL(sel, fmt, arg...) \
+	do {\
+		if (sel == RTW_DBGDUMP)\
+			RTW_PRINT(fmt, ##arg); \
+		else {\
+			_seqdump(sel, fmt, ##arg) /*rtw_warn_on(1)*/; \
+		} \
+	} while (0)
+
+/* dump message to selected 'stream' */
+#undef _RTW_PRINT_SEL
+#define _RTW_PRINT_SEL(sel, fmt, arg...) \
+	do {\
+		if (sel == RTW_DBGDUMP)\
+			_RTW_PRINT(fmt, ##arg); \
+		else {\
+			_seqdump(sel, fmt, ##arg) /*rtw_warn_on(1)*/; \
+		} \
+	} while (0)
+
+/* dump message to selected 'stream' */
+#undef RTW_DUMP_SEL
+#define RTW_DUMP_SEL(sel, _HexData, _HexDataLen) \
+	RTW_BUF_DUMP_SEL(_DRV_ALWAYS_, sel, NULL, _FALSE, _HexData, _HexDataLen)
+
+#define RTW_MAP_DUMP_SEL(sel, _TitleString, _HexData, _HexDataLen) \
+	RTW_BUF_DUMP_SEL(_DRV_ALWAYS_, sel, _TitleString, _TRUE, _HexData, _HexDataLen)
+#endif /* defined(_seqdump) */
+
+
+#ifdef CONFIG_DBG_COUNTER
+	#define DBG_COUNTER(counter) counter++
+#else
+	#define DBG_COUNTER(counter)
+#endif
+
+void dump_drv_version(void *sel);
+void dump_log_level(void *sel);
+void dump_drv_cfg(void *sel);
+
+#ifdef CONFIG_SDIO_HCI
+void sd_f0_reg_dump(void *sel, _adapter *adapter);
+void sdio_local_reg_dump(void *sel, _adapter *adapter);
+#endif /* CONFIG_SDIO_HCI */
+
+void mac_reg_dump(void *sel, _adapter *adapter);
+void bb_reg_dump(void *sel, _adapter *adapter);
+void bb_reg_dump_ex(void *sel, _adapter *adapter);
+void rf_reg_dump(void *sel, _adapter *adapter);
+
+void rtw_sink_rtp_seq_dbg(_adapter *adapter, u8 *ehdr_pos);
+
+struct sta_info;
+void sta_rx_reorder_ctl_dump(void *sel, struct sta_info *sta);
+
+struct dvobj_priv;
+void dump_tx_rate_bmp(void *sel, struct dvobj_priv *dvobj);
+void dump_adapters_status(void *sel, struct dvobj_priv *dvobj);
+
+struct sec_cam_ent;
+void dump_sec_cam_ent(void *sel, struct sec_cam_ent *ent, int id);
+void dump_sec_cam_ent_title(void *sel, u8 has_id);
+void dump_sec_cam(void *sel, _adapter *adapter);
+void dump_sec_cam_cache(void *sel, _adapter *adapter);
+
+#ifdef CONFIG_PROC_DEBUG
+ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_read_reg(struct seq_file *m, void *v);
+ssize_t proc_set_read_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_fwstate(struct seq_file *m, void *v);
+int proc_get_sec_info(struct seq_file *m, void *v);
+int proc_get_mlmext_state(struct seq_file *m, void *v);
+#ifdef CONFIG_LAYER2_ROAMING
+int proc_get_roam_flags(struct seq_file *m, void *v);
+ssize_t proc_set_roam_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_roam_param(struct seq_file *m, void *v);
+ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_roam_tgt_addr(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /* CONFIG_LAYER2_ROAMING */
+#ifdef CONFIG_RTW_80211R
+int proc_get_ft_flags(struct seq_file *m, void *v);
+ssize_t proc_set_ft_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+int proc_get_qos_option(struct seq_file *m, void *v);
+int proc_get_ht_option(struct seq_file *m, void *v);
+int proc_get_rf_info(struct seq_file *m, void *v);
+int proc_get_scan_param(struct seq_file *m, void *v);
+ssize_t proc_set_scan_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_scan_abort(struct seq_file *m, void *v);
+#ifdef CONFIG_SCAN_BACKOP
+int proc_get_backop_flags_sta(struct seq_file *m, void *v);
+ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_backop_flags_ap(struct seq_file *m, void *v);
+ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /* CONFIG_SCAN_BACKOP */
+#ifdef CONFIG_RTW_REPEATER_SON
+int proc_get_rson_data(struct seq_file *m, void *v);
+ssize_t proc_set_rson_data(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+int proc_get_survey_info(struct seq_file *m, void *v);
+ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_ap_info(struct seq_file *m, void *v);
+ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_trx_info(struct seq_file *m, void *v);
+ssize_t proc_set_tx_power_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tx_power_offset(struct seq_file *m, void *v);
+int proc_get_rate_ctl(struct seq_file *m, void *v);
+int proc_get_wifi_spec(struct seq_file *m, void *v);
+ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_bw_ctl(struct seq_file *m, void *v);
+ssize_t proc_set_bw_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#ifdef DBG_RX_COUNTER_DUMP
+int proc_get_rx_cnt_dump(struct seq_file *m, void *v);
+ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+
+#ifdef CONFIG_AP_MODE
+int proc_get_bmc_tx_rate(struct seq_file *m, void *v);
+ssize_t proc_set_bmc_tx_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /*CONFIG_AP_MODE*/
+
+int proc_get_ps_dbg_info(struct seq_file *m, void *v);
+ssize_t proc_set_ps_dbg_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+bool rtw_fwdl_test_trigger_chksum_fail(void);
+bool rtw_fwdl_test_trigger_wintint_rdy_fail(void);
+ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void);
+ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+u32 rtw_get_wait_hiq_empty_ms(void);
+ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+void rtw_sta_linking_test_set_start(void);
+bool rtw_sta_linking_test_wait_done(void);
+bool rtw_sta_linking_test_force_fail(void);
+ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_rx_stat(struct seq_file *m, void *v);
+int proc_get_tx_stat(struct seq_file *m, void *v);
+#ifdef CONFIG_AP_MODE
+int proc_get_all_sta_info(struct seq_file *m, void *v);
+#endif /* CONFIG_AP_MODE */
+
+#ifdef DBG_MEMORY_LEAK
+int proc_get_malloc_cnt(struct seq_file *m, void *v);
+#endif /* DBG_MEMORY_LEAK */
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+int proc_get_best_channel(struct seq_file *m, void *v);
+ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /* CONFIG_FIND_BEST_CHANNEL */
+
+int proc_get_trx_info_debug(struct seq_file *m, void *v);
+
+int proc_get_rx_signal(struct seq_file *m, void *v);
+ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_hw_status(struct seq_file *m, void *v);
+ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_80211N_HT
+int proc_get_ht_enable(struct seq_file *m, void *v);
+ssize_t proc_set_ht_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_bw_mode(struct seq_file *m, void *v);
+ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_ampdu_enable(struct seq_file *m, void *v);
+ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_mac_rptbuf(struct seq_file *m, void *v);
+
+void dump_regsty_rx_ampdu_size_limit(void *sel, _adapter *adapter);
+int proc_get_rx_ampdu(struct seq_file *m, void *v);
+ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+void rtw_dump_dft_phy_cap(void *sel, _adapter *adapter);
+void rtw_get_dft_phy_cap(void *sel, _adapter *adapter);
+void rtw_dump_drv_phy_cap(void *sel, _adapter *adapter);
+
+int proc_get_rx_stbc(struct seq_file *m, void *v);
+ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_stbc_cap(struct seq_file *m, void *v);
+ssize_t proc_set_stbc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_ldpc_cap(struct seq_file *m, void *v);
+ssize_t proc_set_ldpc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#ifdef CONFIG_BEAMFORMING
+int proc_get_txbf_cap(struct seq_file *m, void *v);
+ssize_t proc_set_txbf_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+int proc_get_rx_ampdu_factor(struct seq_file *m, void *v);
+ssize_t proc_set_rx_ampdu_factor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_tx_max_agg_num(struct seq_file *m, void *v);
+ssize_t proc_set_tx_max_agg_num(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_rx_ampdu_density(struct seq_file *m, void *v);
+ssize_t proc_set_rx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_tx_ampdu_density(struct seq_file *m, void *v);
+ssize_t proc_set_tx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_TX_AMSDU
+int proc_get_tx_amsdu(struct seq_file *m, void *v);
+ssize_t proc_set_tx_amsdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tx_amsdu_rate(struct seq_file *m, void *v);
+ssize_t proc_set_tx_amsdu_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+#endif /* CONFIG_80211N_HT */
+
+int proc_get_en_fwps(struct seq_file *m, void *v);
+ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#if 0
+int proc_get_two_path_rssi(struct seq_file *m, void *v);
+int proc_get_rssi_disp(struct seq_file *m, void *v);
+ssize_t proc_set_rssi_disp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+int proc_get_btcoex_dbg(struct seq_file *m, void *v);
+ssize_t proc_set_btcoex_dbg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_btcoex_info(struct seq_file *m, void *v);
+#ifdef CONFIG_RF4CE_COEXIST
+int proc_get_rf4ce_state(struct seq_file *m, void *v);
+ssize_t proc_set_rf4ce_state(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+#endif /* CONFIG_BT_COEXIST */
+
+#if defined(DBG_CONFIG_ERROR_DETECT)
+int proc_get_sreset(struct seq_file *m, void *v);
+ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /* DBG_CONFIG_ERROR_DETECT */
+
+int proc_get_odm_adaptivity(struct seq_file *m, void *v);
+ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_DBG_COUNTER
+int proc_get_rx_logs(struct seq_file *m, void *v);
+int proc_get_tx_logs(struct seq_file *m, void *v);
+int proc_get_int_logs(struct seq_file *m, void *v);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+int proc_get_rx_ring(struct seq_file *m, void *v);
+int proc_get_tx_ring(struct seq_file *m, void *v);
+int proc_get_pci_aspm(struct seq_file *m, void *v);
+#ifdef DBG_TXBD_DESC_DUMP
+int proc_get_tx_ring_ext(struct seq_file *m, void *v);
+ssize_t proc_set_tx_ring_ext(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+#endif
+
+#ifdef CONFIG_WOWLAN
+int proc_get_pattern_info(struct seq_file *m, void *v);
+ssize_t proc_set_pattern_info(struct file *file, const char __user *buffer,
+		size_t count, loff_t *pos, void *data);
+int proc_get_wakeup_event(struct seq_file *m, void *v);
+ssize_t proc_set_wakeup_event(struct file *file, const char __user *buffer,
+		size_t count, loff_t *pos, void *data);
+int proc_get_wakeup_reason(struct seq_file *m, void *v);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+int proc_get_wowlan_gpio_info(struct seq_file *m, void *v);
+ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,
+		size_t count, loff_t *pos, void *data);
+#endif /*CONFIG_GPIO_WAKEUP*/
+
+#ifdef CONFIG_P2P_WOWLAN
+int proc_get_p2p_wowlan_info(struct seq_file *m, void *v);
+#endif /* CONFIG_P2P_WOWLAN */
+
+int proc_get_new_bcn_max(struct seq_file *m, void *v);
+ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_POWER_SAVING
+int proc_get_ps_info(struct seq_file *m, void *v);
+#ifdef CONFIG_WMMPS_STA	
+int proc_get_wmmps_info(struct seq_file *m, void *v);
+ssize_t proc_set_wmmps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /* CONFIG_WMMPS_STA */
+#endif /* CONFIG_POWER_SAVING */
+
+#ifdef CONFIG_TDLS
+int proc_get_tdls_enable(struct seq_file *m, void *v);
+ssize_t proc_set_tdls_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tdls_info(struct seq_file *m, void *v);
+#endif
+
+int proc_get_monitor(struct seq_file *m, void *v);
+ssize_t proc_set_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef DBG_XMIT_BLOCK
+int proc_get_xmit_block(struct seq_file *m, void *v);
+ssize_t proc_set_xmit_block(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+
+#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+int proc_get_rtkm_info(struct seq_file *m, void *v);
+#endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
+
+#ifdef CONFIG_IEEE80211W
+ssize_t proc_set_tx_sa_query(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tx_sa_query(struct seq_file *m, void *v);
+ssize_t proc_set_tx_deauth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tx_deauth(struct seq_file *m, void *v);
+ssize_t proc_set_tx_auth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tx_auth(struct seq_file *m, void *v);
+#endif /* CONFIG_IEEE80211W */
+
+#endif /* CONFIG_PROC_DEBUG */
+
+int proc_get_efuse_map(struct seq_file *m, void *v);
+ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_MCC_MODE
+int proc_get_mcc_info(struct seq_file *m, void *v);
+ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_duration(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_single_tx_criteria(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_ap_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_ap_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_ap_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_sta_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_sta_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_sta_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_mcc_policy_table(struct seq_file *m, void *v);
+#endif /* CONFIG_MCC_MODE */
+
+int proc_get_ack_timeout(struct seq_file *m, void *v);
+ssize_t proc_set_ack_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_fw_offload(struct seq_file *m, void *v);
+ssize_t proc_set_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_DBG_RF_CAL
+int proc_get_iqk_info(struct seq_file *m, void *v);
+ssize_t proc_set_iqk(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_lck_info(struct seq_file *m, void *v);
+ssize_t proc_set_lck(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /*CONFIG_DBG_RF_CAL*/
+
+#define _drv_always_		1
+#define _drv_emerg_			2
+#define _drv_alert_			3
+#define _drv_crit_			4
+#define _drv_err_			5
+#define _drv_warning_		6
+#define _drv_notice_		7
+#define _drv_info_			8
+#define _drv_dump_			9
+#define _drv_debug_			10
+
+#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_efuse_			BIT(27) */
+#define	_module_rtl8192c_xmit_c_ BIT(28)
+#define _module_hal_xmit_c_	BIT(28)
+#define _module_efuse_			BIT(29)
+#define _module_rtl8712_recv_c_		BIT(30)
+#define _module_rtl8712_led_c_		BIT(31)
+
+#endif /* __RTW_DEBUG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_eeprom.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_eeprom.h
new file mode 100644
index 000000000000..62304d577f38
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_eeprom.h
@@ -0,0 +1,116 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+
+#define	RTL8712_EEPROM_ID			0x8712
+/* #define	EEPROM_MAX_SIZE			256 */
+
+#define	HWSET_MAX_SIZE_128		128
+#define	HWSET_MAX_SIZE_256		256
+#define	HWSET_MAX_SIZE_512		512
+#define HWSET_MAX_SIZE_1024		1024
+
+#define	EEPROM_MAX_SIZE			HWSET_MAX_SIZE_1024
+
+#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 */
+
+/*
+ * 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.
+ *   */
+typedef 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_NETGEAR = 36,
+	RT_CID_PLANEX = 37,
+	RT_CID_CC_C = 38,
+	RT_CID_819x_Xavi = 39,
+	RT_CID_LENOVO_CHINA = 40,
+	RT_CID_INTEL_CHINA = 41,
+	RT_CID_TPLINK_HPWR = 42,
+	RT_CID_819x_Sercomm_Netgear = 43,
+	RT_CID_819x_ALPHA_Dlink = 44,/* add by ylb 20121012 for customer led for alpha */
+	RT_CID_WNC_NEC = 45,/* add by page for NEC */
+	RT_CID_DNI_BUFFALO = 46,/* add by page for NEC */
+} RT_CUSTOMER_ID, *PRT_CUSTOMER_ID;
+
+extern void eeprom_write16(_adapter *padapter, u16 reg, u16 data);
+extern u16 eeprom_read16(_adapter *padapter, u16 reg);
+extern void read_eeprom_content(_adapter *padapter);
+extern void eeprom_read_sz(_adapter *padapter, u16 reg, u8 *data, u32 sz);
+
+extern void read_eeprom_content_by_attrib(_adapter	*padapter);
+
+#ifdef PLATFORM_LINUX
+#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
+extern int isAdaptorInfoFileValid(void);
+extern int storeAdaptorInfoFile(char *path, u8 *efuse_data);
+extern int retriveAdaptorInfoFile(char *path, u8 *efuse_data);
+#endif /* CONFIG_ADAPTOR_INFO_CACHING_FILE */
+#endif /* PLATFORM_LINUX */
+
+#endif /* __RTL871X_EEPROM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_efuse.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_efuse.h
new file mode 100644
index 000000000000..2e7334287f9a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_efuse.h
@@ -0,0 +1,259 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+
+#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,
+};
+
+#define		EFUSE_MAX_MAP_LEN		1024
+
+#define		EFUSE_MAX_HW_SIZE		1024
+#define		EFUSE_MAX_SECTION_BASE	16
+#define		EFUSE_MAX_SECTION_NUM	128
+#define		EFUSE_MAX_BANK_SIZE		512
+
+/*RTL8822B 8821C BT EFUSE Define 1 BANK 128 size logical map 1024*/ 
+#ifdef RTW_HALMAC
+#define BANK_NUM		1
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
+#define EFUSE_BT_REAL_CONTENT_LEN		(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN				1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION			(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK		16
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_BT_REAL_CONTENT_LEN)
+#endif
+
+#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
+
+#define IS_MASKED_MP(ic, txt, offset) (EFUSE_IsAddressMasked_MP_##ic##txt(offset))
+#define IS_MASKED_TC(ic, txt, offset) (EFUSE_IsAddressMasked_TC_##ic##txt(offset))
+#define GET_MASK_ARRAY_LEN_MP(ic, txt) (EFUSE_GetArrayLen_MP_##ic##txt())
+#define GET_MASK_ARRAY_LEN_TC(ic, txt) (EFUSE_GetArrayLen_TC_##ic##txt())
+#define GET_MASK_ARRAY_MP(ic, txt, offset) (EFUSE_GetMaskArray_MP_##ic##txt(offset))
+#define GET_MASK_ARRAY_TC(ic, txt, offset) (EFUSE_GetMaskArray_TC_##ic##txt(offset))
+
+
+#define IS_MASKED(ic, txt, offset) (IS_MASKED_MP(ic, txt, offset))
+#define GET_MASK_ARRAY_LEN(ic, txt) (GET_MASK_ARRAY_LEN_MP(ic, txt))
+#define GET_MASK_ARRAY(ic, txt, out) do { GET_MASK_ARRAY_MP(ic, txt, out); } while (0)
+
+/* *********************************************
+ *	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----------------------------*/
+typedef struct PG_PKT_STRUCT_A {
+	u8 offset;
+	u8 word_en;
+	u8 data[8];
+	u8 word_cnts;
+} PGPKT_STRUCT, *PPGPKT_STRUCT;
+
+typedef enum {
+	ERR_SUCCESS = 0,
+	ERR_DRIVER_FAILURE,
+	ERR_IO_FAILURE,
+	ERR_WI_TIMEOUT,
+	ERR_WI_BUSY,
+	ERR_BAD_FORMAT,
+	ERR_INVALID_DATA,
+	ERR_NOT_ENOUGH_SPACE,
+	ERR_WRITE_PROTECT,
+	ERR_READ_BACK_FAIL,
+	ERR_OUT_OF_RANGE
+} ERROR_CODE;
+
+/*------------------------------Define structure----------------------------*/
+typedef struct _EFUSE_HAL {
+	u8	fakeEfuseBank;
+	u32	fakeEfuseUsedBytes;
+	u8	fakeEfuseContent[EFUSE_MAX_HW_SIZE];
+	u8	fakeEfuseInitMap[EFUSE_MAX_MAP_LEN];
+	u8	fakeEfuseModifiedMap[EFUSE_MAX_MAP_LEN];
+	u32	EfuseUsedBytes;
+	u8	EfuseUsedPercentage;
+
+	u16	BTEfuseUsedBytes;
+	u8	BTEfuseUsedPercentage;
+	u8	BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
+	u8	BTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN];
+	u8	BTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN];
+
+	u16	fakeBTEfuseUsedBytes;
+	u8	fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
+	u8	fakeBTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN];
+	u8	fakeBTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN];
+
+	/* EFUSE Configuration, initialized in HAL_CmnInitPGData(). */
+	const u16  MaxSecNum_WiFi;
+	const u16  MaxSecNum_BT;
+	const u16  WordUnit;
+	const u16  PhysicalLen_WiFi;
+	const u16  PhysicalLen_BT;
+	const u16  LogicalLen_WiFi;
+	const u16  LogicalLen_BT;
+	const u16  BankSize;
+	const u16  TotalBankNum;
+	const u16  BankNum_WiFi;
+	const u16  BankNum_BT;
+	const u16  OOBProtectBytes;
+	const u16  ProtectBytes;
+	const u16  BankAvailBytes;
+	const u16  TotalAvailBytes_WiFi;
+	const u16  TotalAvailBytes_BT;
+	const u16  HeaderRetry;
+	const u16  DataRetry;
+
+	ERROR_CODE	  Status;
+
+} EFUSE_HAL, *PEFUSE_HAL;
+
+extern u8 maskfileBuffer[64];
+
+/*------------------------Export global variable----------------------------*/
+extern u8 fakeEfuseBank;
+extern u32 fakeEfuseUsedBytes;
+extern u8 fakeEfuseContent[];
+extern u8 fakeEfuseInitMap[];
+extern u8 fakeEfuseModifiedMap[];
+
+extern u32 BTEfuseUsedBytes;
+extern u8 BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
+extern u8 BTEfuseInitMap[];
+extern u8 BTEfuseModifiedMap[];
+
+extern u32 fakeBTEfuseUsedBytes;
+extern u8 fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
+extern u8 fakeBTEfuseInitMap[];
+extern u8 fakeBTEfuseModifiedMap[];
+/*------------------------Export global variable----------------------------*/
+#define		MAX_SEGMENT_SIZE			200
+#define		MAX_SEGMENT_NUM			200
+#define		MAX_BUF_SIZE				(MAX_SEGMENT_SIZE*MAX_SEGMENT_NUM)
+#define		TMP_BUF_SIZE				100
+
+static	u8	dcmd_Return_Buffer[MAX_BUF_SIZE] = {0};
+static	u32	dcmd_Buf_Idx = 0;
+static	u32	dcmd_Finifh_Flag = 0;
+
+static	char	dcmd_Buf[TMP_BUF_SIZE];
+
+#define		rtprintf					dcmd_Store_Return_Buf
+
+u8	efuse_bt_GetCurrentSize(PADAPTER padapter, u16 *size);
+u16	efuse_bt_GetMaxSize(PADAPTER padapter);
+u16 efuse_GetavailableSize(PADAPTER adapter);
+
+u8	efuse_GetCurrentSize(PADAPTER padapter, u16 *size);
+u16	efuse_GetMaxSize(PADAPTER padapter);
+u8	rtw_efuse_access(PADAPTER padapter, u8 bRead, u16 start_addr, u16 cnts, u8 *data);
+u8	rtw_efuse_bt_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data);
+
+u8	rtw_efuse_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
+u8	rtw_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
+u8	rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
+u8	rtw_BT_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
+u8	rtw_BT_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
+
+u16	Efuse_GetCurrentSize(PADAPTER pAdapter, u8 efuseType, BOOLEAN bPseudoTest);
+u8	Efuse_CalculateWordCnts(u8 word_en);
+void	ReadEFuseByte(PADAPTER Adapter, u16 _offset, u8 *pbuf, BOOLEAN bPseudoTest) ;
+void	EFUSE_GetEfuseDefinition(PADAPTER pAdapter, u8 efuseType, u8 type, void *pOut, BOOLEAN bPseudoTest);
+u8	efuse_OneByteRead(PADAPTER pAdapter, u16 addr, u8 *data, BOOLEAN	 bPseudoTest);
+#define efuse_onebyte_read(adapter, addr, data, pseudo_test) efuse_OneByteRead((adapter), (addr), (data), (pseudo_test))
+
+u8	efuse_OneByteWrite(PADAPTER pAdapter, u16 addr, u8 data, BOOLEAN	 bPseudoTest);
+
+void	BTEfuse_PowerSwitch(PADAPTER pAdapter, u8	bWrite, u8	 PwrState);
+void	Efuse_PowerSwitch(PADAPTER pAdapter, u8	bWrite, u8	 PwrState);
+int	Efuse_PgPacketRead(PADAPTER pAdapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);
+int	Efuse_PgPacketWrite(PADAPTER pAdapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+void	efuse_WordEnableDataRead(u8 word_en, u8 *sourdata, u8 *targetdata);
+u8	Efuse_WordEnableDataWrite(PADAPTER pAdapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+void	EFUSE_ShadowMapUpdate(PADAPTER pAdapter, u8 efuseType, BOOLEAN bPseudoTest);
+void	EFUSE_ShadowRead(PADAPTER pAdapter, u8 Type, u16 Offset, u32 *Value);
+#define efuse_logical_map_read(adapter, type, offset, value) EFUSE_ShadowRead((adapter), (type), (offset), (value))
+
+VOID	hal_ReadEFuse_BT_logic_map(
+	PADAPTER	padapter,
+	u16			_offset,
+	u16			_size_byte,
+	u8			*pbuf
+);
+u8	EfusePgPacketWrite_BT(
+	PADAPTER	pAdapter,
+	u8			offset,
+	u8			word_en,
+	u8			*pData,
+	u8			bPseudoTest);
+u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter);
+void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray);
+void rtw_efuse_analyze(PADAPTER	padapter, u8 Type, u8 Fake);
+
+#define MAC_HIDDEN_MAX_BW_NUM 8
+extern const u8 _mac_hidden_max_bw_to_hal_bw_cap[];
+#define mac_hidden_max_bw_to_hal_bw_cap(max_bw) (((max_bw) >= MAC_HIDDEN_MAX_BW_NUM) ? 0 : _mac_hidden_max_bw_to_hal_bw_cap[(max_bw)])
+
+#define MAC_HIDDEN_PROTOCOL_NUM 4
+extern const u8 _mac_hidden_proto_to_hal_proto_cap[];
+#define mac_hidden_proto_to_hal_proto_cap(proto) (((proto) >= MAC_HIDDEN_PROTOCOL_NUM) ? 0 : _mac_hidden_proto_to_hal_proto_cap[(proto)])
+
+u8 mac_hidden_wl_func_to_hal_wl_func(u8 func);
+
+#ifdef PLATFORM_LINUX
+u8 rtw_efuse_file_read(PADAPTER padapter, u8 *filepatch, u8 *buf, u32 len);
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size);
+u32 rtw_read_macaddr_from_file(const char *path, u8 *buf);
+#endif /* CONFIG_EFUSE_CONFIG_FILE */
+#endif /* PLATFORM_LINUX */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_event.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_event.h
new file mode 100644
index 000000000000..8e4d5d6f5c5c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_event.h
@@ -0,0 +1,130 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+#ifdef CONFIG_H2CLBK
+	#include <h2clbk.h>
+#endif
+
+/*
+Used to report a bss has been scanned
+
+*/
+struct survey_event	{
+	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];
+};
+
+struct stadel_event {
+	unsigned char macaddr[6];
+	unsigned char rsvd[2]; /* for reason */
+	unsigned char locally_generated;
+	int mac_id;
+};
+
+struct addba_event {
+	unsigned int tid;
+};
+
+struct wmm_event {
+	unsigned char wmm;
+};
+
+#ifdef CONFIG_H2CLBK
+struct c2hlbk_event {
+	unsigned char mac[6];
+	unsigned short	s0;
+	unsigned short	s1;
+	unsigned int	w0;
+	unsigned char	b0;
+	unsigned short  s2;
+	unsigned char	b1;
+	unsigned int	w1;
+};
+#endif/* CONFIG_H2CLBK */
+
+#define GEN_EVT_CODE(event)	event ## _EVT_
+
+
+
+struct fwevent {
+	u32	parmsize;
+	void (*event_callback)(_adapter *dev, u8 *pbuf);
+};
+
+
+#define C2HEVENT_SZ			32
+
+struct event_node {
+	unsigned char *node;
+	unsigned char evt_code;
+	unsigned short evt_sz;
+	volatile int	*caller_ff_tail;
+	int	caller_ff_sz;
+};
+
+struct c2hevent_queue {
+	volatile int	head;
+	volatile int	tail;
+	struct	event_node	nodes[C2HEVENT_SZ];
+	unsigned char	seq;
+};
+
+#define NETWORK_QUEUE_SZ	4
+
+struct network_queue {
+	volatile int	head;
+	volatile int	tail;
+	WLAN_BSSID_EX networks[NETWORK_QUEUE_SZ];
+};
+
+
+#endif /* _WLANEVENT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ht.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ht.h
new file mode 100644
index 000000000000..2c7aa2f33b24
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ht.h
@@ -0,0 +1,219 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+#define HT_CAP_IE_LEN 26
+#define HT_OP_IE_LEN 22
+
+struct ht_priv {
+	u8	ht_option;
+	u8	ampdu_enable;/* for enable Tx A-MPDU */
+	u8	tx_amsdu_enable;/* for enable Tx A-MSDU */
+	u8	bss_coexist;/* for 20/40 Bss coexist */
+
+	/* u8	baddbareq_issued[16]; */
+	u32	tx_amsdu_maxlen; /* 1: 8k, 0:4k ; default:8k, for tx */
+	u32	rx_ampdu_maxlen; /* for rx reordering ctrl win_sz, updated when join_callback. */
+
+	u8	rx_ampdu_min_spacing;
+
+	u8	ch_offset;/* PRIME_CHNL_OFFSET */
+	u8	sgi_20m;
+	u8	sgi_40m;
+
+	/* for processing Tx A-MPDU */
+	u8	agg_enable_bitmap;
+	/* u8	ADDBA_retry_count; */
+	u8	candidate_tid_bitmap;
+
+	u8	ldpc_cap;
+	u8	stbc_cap;
+	u8	beamform_cap;
+	u8	smps_cap; /*spatial multiplexing power save mode. 0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
+
+	u8 op_present:1; /* ht_op is present */
+
+	struct rtw_ieee80211_ht_cap ht_cap;
+	u8 ht_op[HT_OP_IE_LEN];
+
+};
+
+typedef enum AGGRE_SIZE {
+	HT_AGG_SIZE_8K = 0,
+	HT_AGG_SIZE_16K = 1,
+	HT_AGG_SIZE_32K = 2,
+	HT_AGG_SIZE_64K = 3,
+	VHT_AGG_SIZE_128K = 4,
+	VHT_AGG_SIZE_256K = 5,
+	VHT_AGG_SIZE_512K = 6,
+	VHT_AGG_SIZE_1024K = 7,
+} AGGRE_SIZE_E, *PAGGRE_SIZE_E;
+
+typedef enum _RT_HT_INF0_CAP {
+	RT_HT_CAP_USE_TURBO_AGGR = 0x01,
+	RT_HT_CAP_USE_LONG_PREAMBLE = 0x02,
+	RT_HT_CAP_USE_AMPDU = 0x04,
+	RT_HT_CAP_USE_WOW = 0x8,
+	RT_HT_CAP_USE_SOFTAP = 0x10,
+	RT_HT_CAP_USE_92SE = 0x20,
+	RT_HT_CAP_USE_88C_92C = 0x40,
+	RT_HT_CAP_USE_AP_CLIENT_MODE = 0x80,	/* AP team request to reserve this bit, by Emily */
+} RT_HT_INF0_CAPBILITY, *PRT_HT_INF0_CAPBILITY;
+
+typedef enum _RT_HT_INF1_CAP {
+	RT_HT_CAP_USE_VIDEO_CLIENT = 0x01,
+	RT_HT_CAP_USE_JAGUAR_BCUT = 0x02,
+	RT_HT_CAP_USE_JAGUAR_CCUT = 0x04,
+} RT_HT_INF1_CAPBILITY, *PRT_HT_INF1_CAPBILITY;
+
+#define	LDPC_HT_ENABLE_RX			BIT0
+#define	LDPC_HT_ENABLE_TX			BIT1
+#define	LDPC_HT_TEST_TX_ENABLE		BIT2
+#define	LDPC_HT_CAP_TX				BIT3
+
+#define	STBC_HT_ENABLE_RX			BIT0
+#define	STBC_HT_ENABLE_TX			BIT1
+#define	STBC_HT_TEST_TX_ENABLE		BIT2
+#define	STBC_HT_CAP_TX				BIT3
+
+/* ------------------------------------------------------------
+ * The HT Control field
+ * ------------------------------------------------------------ */
+#define SET_HT_CTRL_CSI_STEERING(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart))+2, 6, 2, _val)
+#define SET_HT_CTRL_NDP_ANNOUNCEMENT(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart))+3, 0, 1, _val)
+#define GET_HT_CTRL_NDP_ANNOUNCEMENT(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+3, 0, 1)
+
+/* 20/40 BSS Coexist */
+#define SET_EXT_CAPABILITY_ELE_BSS_COEXIST(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 0, 1, _val)
+#define GET_EXT_CAPABILITY_ELE_BSS_COEXIST(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 0, 1)
+
+/* HT Capabilities Info field */
+#define HT_CAP_ELE_CAP_INFO(_pEleStart)					((u8 *)(_pEleStart))
+#define GET_HT_CAP_ELE_LDPC_CAP(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 0, 1)
+#define GET_HT_CAP_ELE_CHL_WIDTH(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 1, 1)
+#define GET_HT_CAP_ELE_SM_PS(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 2, 2)
+#define GET_HT_CAP_ELE_GREENFIELD(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 4, 1)
+#define GET_HT_CAP_ELE_SHORT_GI20M(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 5, 1)
+#define GET_HT_CAP_ELE_SHORT_GI40M(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 6, 1)
+#define GET_HT_CAP_ELE_TX_STBC(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 7, 1)
+#define GET_HT_CAP_ELE_RX_STBC(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+1, 0, 2)
+#define GET_HT_CAP_ELE_DELAYED_BA(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+1, 2, 1)
+#define GET_HT_CAP_ELE_MAX_AMSDU_LENGTH(_pEleStart)		LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+1, 3, 1)
+#define GET_HT_CAP_ELE_DSSS_CCK_40M(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+1, 4, 1)
+#define GET_HT_CAP_ELE_FORTY_INTOLERANT(_pEleStart)		LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+1, 6, 1)
+#define GET_HT_CAP_ELE_LSIG_TXOP_PROTECT(_pEleStart)	LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+1, 7, 1)
+
+#define SET_HT_CAP_ELE_LDPC_CAP(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 0, 1, _val)
+#define SET_HT_CAP_ELE_CHL_WIDTH(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 1, 1, _val)
+#define SET_HT_CAP_ELE_SM_PS(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 2, 2, _val)
+#define SET_HT_CAP_ELE_GREENFIELD(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 4, 1, _val)
+#define SET_HT_CAP_ELE_SHORT_GI20M(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 5, 1, _val)
+#define SET_HT_CAP_ELE_SHORT_GI40M(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 6, 1, _val)
+#define SET_HT_CAP_ELE_TX_STBC(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 7, 1, _val)
+#define SET_HT_CAP_ELE_RX_STBC(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 0, 2, _val)
+#define SET_HT_CAP_ELE_DELAYED_BA(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 2, 1, _val)
+#define SET_HT_CAP_ELE_MAX_AMSDU_LENGTH(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 3, 1, _val)
+#define SET_HT_CAP_ELE_DSSS_CCK_40M(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 4, 1, _val)
+#define SET_HT_CAP_ELE_FORTY_INTOLERANT(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 6, 1, _val)
+#define SET_HT_CAP_ELE_LSIG_TXOP_PROTECT(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 7, 1, _val)
+
+/* A-MPDU Parameters field */
+#define HT_CAP_ELE_AMPDU_PARA(_pEleStart)				(((u8 *)(_pEleStart))+2)
+#define GET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(_pEleStart)	LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+2, 0, 2)
+#define GET_HT_CAP_ELE_MIN_MPDU_S_SPACE(_pEleStart)		LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+2, 2, 3)
+
+#define HT_AMPDU_PARA_FMT "%02x " \
+	"MAX AMPDU len:%u bytes, MIN MPDU Start Spacing:%u"
+
+#define HT_AMPDU_PARA_ARG(x) \
+	*((u8 *)(x)) \
+	, (1 << (13+GET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(((u8 *)x)-2)))-1 \
+	, GET_HT_CAP_ELE_MIN_MPDU_S_SPACE(((u8 *)x)-2)
+
+#define SET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 0, 2, _val)
+#define SET_HT_CAP_ELE_MIN_MPDU_S_SPACE(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 2, 3, _val)
+
+/* Supported MCS Set field */
+#define HT_CAP_ELE_SUP_MCS_SET(_pEleStart)				(((u8 *)(_pEleStart))+3)
+#define HT_CAP_ELE_RX_MCS_MAP(_pEleStart)				HT_CAP_ELE_SUP_MCS_SET(_pEleStart)
+#define GET_HT_CAP_ELE_RX_HIGHEST_DATA_RATE(_pEleStart)	LE_BITS_TO_2BYTE(((u8 *)(_pEleStart))+13, 0, 10)
+#define GET_HT_CAP_ELE_TX_MCS_DEF(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 0, 1)
+#define GET_HT_CAP_ELE_TRX_MCS_NEQ(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 1, 1)
+#define GET_HT_CAP_ELE_TX_MAX_SS(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 2, 2)
+#define GET_HT_CAP_ELE_TX_UEQM(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 4, 1)
+
+#define HT_RX_MCS_BMP_FMT "%02x %02x %02x %02x %02x%02x%02x%02x%02x%02x"
+#define HT_RX_MCS_BMP_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
+	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9]
+
+#define HT_SUP_MCS_SET_FMT HT_RX_MCS_BMP_FMT \
+	/* "\n%02x%02x%02x%02x%02x%02x" */\
+	" %uMbps %s%s%s"
+#define HT_SUP_MCS_SET_ARG(x) HT_RX_MCS_BMP_ARG(x) \
+	/*,((u8 *)(x))[10], ((u8 *)(x))[11], ((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15] */\
+	, GET_HT_CAP_ELE_RX_HIGHEST_DATA_RATE(((u8 *)x)-3) \
+	, GET_HT_CAP_ELE_TX_MCS_DEF(((u8 *)x)-3) ? "TX_MCS_DEF " : "" \
+	, GET_HT_CAP_ELE_TRX_MCS_NEQ(((u8 *)x)-3) ? "TRX_MCS_NEQ " : "" \
+	, GET_HT_CAP_ELE_TX_UEQM(((u8 *)x)-3) ? "TX_UEQM " : ""
+
+/* TXBF Capabilities */
+#define SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(_pEleStart, _val)				SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 3, 1, ((u8)_val))
+#define SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(_pEleStart, _val)				SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 4, 1, ((u8)_val))
+#define SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(_pEleStart, _val)	SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 10, 1, ((u8)_val))
+#define SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(_pEleStart, _val)	SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 15, 2, ((u8)_val))
+#define SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(_pEleStart, _val)	SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 23, 2, ((u8)_val))
+#define SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(_pEleStart, _val)	SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 27, 2, ((u8)_val))
+
+
+#define GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(_pEleStart)			LE_BITS_TO_4BYTE(((u8 *)(_pEleStart))+21, 10, 1)
+#define GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(_pEleStart)			LE_BITS_TO_4BYTE(((u8 *)(_pEleStart))+21, 15, 2)
+#define GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(_pEleStart)		LE_BITS_TO_4BYTE(((u8 *)(_pEleStart))+21, 23, 2)
+#define GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(_pEleStart)		LE_BITS_TO_4BYTE(((u8 *)(_pEleStart))+21, 27, 2)
+
+/* HT Operation element */
+
+#define GET_HT_OP_ELE_PRI_CHL(_pEleStart)					LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 0, 8)
+#define SET_HT_OP_ELE_PRI_CHL(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 0, 8, _val)
+
+/* HT Operation Info field */
+#define HT_OP_ELE_OP_INFO(_pEleStart)						(((u8 *)(_pEleStart)) + 1)
+#define GET_HT_OP_ELE_2ND_CHL_OFFSET(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 1, 0, 2)
+#define GET_HT_OP_ELE_STA_CHL_WIDTH(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 1, 2, 1)
+#define GET_HT_OP_ELE_RIFS_MODE(_pEleStart)					LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 1, 3, 1)
+#define GET_HT_OP_ELE_HT_PROTECT(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 2, 0, 2)
+#define GET_HT_OP_ELE_NON_GREEN_PRESENT(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 2, 2, 1)
+#define GET_HT_OP_ELE_OBSS_NON_HT_PRESENT(_pEleStart)		LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 2, 4, 1)
+#define GET_HT_OP_ELE_DUAL_BEACON(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 4, 6, 1)
+#define GET_HT_OP_ELE_DUAL_CTS(_pEleStart)					LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 4, 7, 1)
+#define GET_HT_OP_ELE_STBC_BEACON(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 5, 0, 1)
+#define GET_HT_OP_ELE_LSIG_TXOP_PROTECT(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 5, 1, 1)
+#define GET_HT_OP_ELE_PCO_ACTIVE(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 5, 2, 1)
+#define GET_HT_OP_ELE_PCO_PHASE(_pEleStart)					LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)) + 5, 3, 1)
+
+#define SET_HT_OP_ELE_2ND_CHL_OFFSET(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 0, 2, _val)
+#define SET_HT_OP_ELE_STA_CHL_WIDTH(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 2, 1, _val)
+#define SET_HT_OP_ELE_RIFS_MODE(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 1, 3, 1, _val)
+#define SET_HT_OP_ELE_HT_PROTECT(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 0, 2, _val)
+#define SET_HT_OP_ELE_NON_GREEN_PRESENT(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 2, 1, _val)
+#define SET_HT_OP_ELE_OBSS_NON_HT_PRESENT(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 4, 1, _val)
+#define SET_HT_OP_ELE_DUAL_BEACON(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 4, 6, 1, _val)
+#define SET_HT_OP_ELE_DUAL_CTS(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 4, 7, 1, _val)
+#define SET_HT_OP_ELE_STBC_BEACON(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 5, 0, 1, _val)
+#define SET_HT_OP_ELE_LSIG_TXOP_PROTECT(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 5, 1, 1, _val)
+#define SET_HT_OP_ELE_PCO_ACTIVE(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 5, 2, 1, _val)
+#define SET_HT_OP_ELE_PCO_PHASE(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 5, 3, 1, _val)
+
+#endif /* _RTL871X_HT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_io.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_io.h
new file mode 100644
index 000000000000..28430d8b7fa1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_io.h
@@ -0,0 +1,571 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+#define NUM_IOREQ		8
+
+#ifdef PLATFORM_WINDOWS
+	#define MAX_PROT_SZ	64
+#endif
+#ifdef PLATFORM_LINUX
+	#define MAX_PROT_SZ	(64-16)
+#endif
+
+#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 intf_hdl;
+struct io_queue;
+
+struct _io_ops {
+	u8(*_read8)(struct intf_hdl *pintfhdl, u32 addr);
+	u16(*_read16)(struct intf_hdl *pintfhdl, u32 addr);
+	u32(*_read32)(struct intf_hdl *pintfhdl, u32 addr);
+
+	int (*_write8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+	int (*_write16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+	int (*_write32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+	int (*_writeN)(struct intf_hdl *pintfhdl, u32 addr, u32 length, u8 *pdata);
+
+	int (*_write8_async)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+	int (*_write16_async)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+	int (*_write32_async)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+
+	void (*_read_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	void (*_write_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+
+	void (*_sync_irp_protocol_rw)(struct io_queue *pio_q);
+
+	u32(*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
+
+	u32(*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	u32(*_write_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+
+	u32(*_write_scsi)(struct intf_hdl *pintfhdl, u32 cnt, u8 *pmem);
+
+	void (*_read_port_cancel)(struct intf_hdl *pintfhdl);
+	void (*_write_port_cancel)(struct intf_hdl *pintfhdl);
+
+#ifdef CONFIG_SDIO_HCI
+	u8(*_sd_f0_read8)(struct intf_hdl *pintfhdl, u32 addr);
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+	u8(*_sd_iread8)(struct intf_hdl *pintfhdl, u32 addr);
+	u16(*_sd_iread16)(struct intf_hdl *pintfhdl, u32 addr);
+	u32(*_sd_iread32)(struct intf_hdl *pintfhdl, u32 addr);
+	int (*_sd_iwrite8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+	int (*_sd_iwrite16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+	int (*_sd_iwrite32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+#endif
+
+};
+
+struct io_req {
+	_list	list;
+	u32	addr;
+	volatile u32	val;
+	u32	command;
+	u32	status;
+	u8	*pbuf;
+	_sema	sema;
+
+#ifdef PLATFORM_OS_CE
+#ifdef CONFIG_USB_HCI
+	/* URB handler for rtw_write_mem */
+	USB_TRANSFER usb_transfer_write_mem;
+#endif
+#endif
+
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt);
+	u8 *cnxt;
+
+#ifdef PLATFORM_OS_XP
+	PMDL pmdl;
+	PIRP  pirp;
+
+#ifdef CONFIG_SDIO_HCI
+	PSDBUS_REQUEST_PACKET sdrp;
+#endif
+
+#endif
+
+
+};
+
+struct	intf_hdl {
+
+#if 0
+	u32	intf_option;
+	u32	bus_status;
+	u32	do_flush;
+	u8	*adapter;
+	u8	*intf_dev;
+	struct intf_priv	*pintfpriv;
+	u8	cnt;
+	void (*intf_hdl_init)(u8 *priv);
+	void (*intf_hdl_unload)(u8 *priv);
+	void (*intf_hdl_open)(u8 *priv);
+	void (*intf_hdl_close)(u8 *priv);
+	struct	_io_ops	io_ops;
+	/* u8 intf_status;//moved to struct intf_priv */
+	u16 len;
+	u16 done_len;
+#endif
+	_adapter *padapter;
+	struct dvobj_priv *pintf_dev;/*	pointer to &(padapter->dvobjpriv); */
+
+	struct _io_ops	io_ops;
+
+};
+
+struct reg_protocol_rd {
+
+#ifdef CONFIG_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 CONFIG_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
+
+};
+#ifdef CONFIG_PCI_HCI
+#define MAX_CONTINUAL_IO_ERR 4
+#endif
+
+#ifdef CONFIG_USB_HCI
+#define MAX_CONTINUAL_IO_ERR 4
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+#define SD_IO_TRY_CNT (8)
+#define MAX_CONTINUAL_IO_ERR SD_IO_TRY_CNT
+#endif
+
+#ifdef CONFIG_GSPI_HCI
+#define SD_IO_TRY_CNT (8)
+#define MAX_CONTINUAL_IO_ERR SD_IO_TRY_CNT
+#endif
+
+
+int rtw_inc_and_chk_continual_io_error(struct dvobj_priv *dvobj);
+void rtw_reset_continual_io_error(struct dvobj_priv *dvobj);
+
+/*
+Below is the data structure used by _io_handler
+
+*/
+
+struct io_queue {
+	_lock	lock;
+	_list	free_ioreqs;
+	_list		pending;		/* The io_req list that will be served in the single protocol read/write.	 */
+	_list		processing;
+	u8	*free_ioreqs_buf; /* 4-byte aligned */
+	u8	*pallocated_free_ioreqs_buf;
+	struct	intf_hdl	intf;
+};
+
+struct io_priv {
+
+	_adapter *padapter;
+
+	struct intf_hdl intf;
+
+};
+
+extern uint ioreq_flush(_adapter *adapter, struct io_queue *ioqueue);
+extern void sync_ioreq_enqueue(struct io_req *preq, struct io_queue *ioqueue);
+extern uint sync_ioreq_flush(_adapter *adapter, struct io_queue *ioqueue);
+
+
+extern uint free_ioreq(struct io_req *preq, struct io_queue *pio_queue);
+extern struct io_req *alloc_ioreq(struct io_queue *pio_q);
+
+extern uint register_intf_hdl(u8 *dev, struct intf_hdl *pintfhdl);
+extern void unregister_intf_hdl(struct intf_hdl *pintfhdl);
+
+extern void _rtw_attrib_read(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+extern void _rtw_attrib_write(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+
+extern u8 _rtw_read8(_adapter *adapter, u32 addr);
+extern u16 _rtw_read16(_adapter *adapter, u32 addr);
+extern u32 _rtw_read32(_adapter *adapter, u32 addr);
+extern void _rtw_read_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+extern void _rtw_read_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+extern void _rtw_read_port_cancel(_adapter *adapter);
+
+
+extern int _rtw_write8(_adapter *adapter, u32 addr, u8 val);
+extern int _rtw_write16(_adapter *adapter, u32 addr, u16 val);
+extern int _rtw_write32(_adapter *adapter, u32 addr, u32 val);
+extern int _rtw_writeN(_adapter *adapter, u32 addr, u32 length, u8 *pdata);
+
+#ifdef CONFIG_SDIO_HCI
+u8 _rtw_sd_f0_read8(_adapter *adapter, u32 addr);
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+u8 _rtw_sd_iread8(_adapter *adapter, u32 addr);
+u16 _rtw_sd_iread16(_adapter *adapter, u32 addr);
+u32 _rtw_sd_iread32(_adapter *adapter, u32 addr);
+int _rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val);
+int _rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val);
+int _rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val);
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+#endif /* CONFIG_SDIO_HCI */
+
+extern int _rtw_write8_async(_adapter *adapter, u32 addr, u8 val);
+extern int _rtw_write16_async(_adapter *adapter, u32 addr, u16 val);
+extern int _rtw_write32_async(_adapter *adapter, u32 addr, u32 val);
+
+extern void _rtw_write_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+extern u32 _rtw_write_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+u32 _rtw_write_port_and_wait(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem, int timeout_ms);
+extern void _rtw_write_port_cancel(_adapter *adapter);
+
+#ifdef DBG_IO
+bool match_read_sniff_ranges(u32 addr, u16 len);
+bool match_write_sniff_ranges(u32 addr, u16 len);
+bool match_rf_read_sniff_ranges(u8 path, u32 addr, u32 mask);
+bool match_rf_write_sniff_ranges(u8 path, u32 addr, u32 mask);
+
+extern u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line);
+extern u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int line);
+extern u32 dbg_rtw_read32(_adapter *adapter, u32 addr, const char *caller, const int line);
+
+extern int dbg_rtw_write8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line);
+extern int dbg_rtw_write16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line);
+extern int dbg_rtw_write32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line);
+extern int dbg_rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *data, const char *caller, const int line);
+
+#ifdef CONFIG_SDIO_HCI
+u8 dbg_rtw_sd_f0_read8(_adapter *adapter, u32 addr, const char *caller, const int line);
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+u8 dbg_rtw_sd_iread8(_adapter *adapter, u32 addr, const char *caller, const int line);
+u16 dbg_rtw_sd_iread16(_adapter *adapter, u32 addr, const char *caller, const int line);
+u32 dbg_rtw_sd_iread32(_adapter *adapter, u32 addr, const char *caller, const int line);
+int dbg_rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line);
+int dbg_rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line);
+int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line);
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+#endif /* CONFIG_SDIO_HCI */
+
+#define rtw_read8(adapter, addr) dbg_rtw_read8((adapter), (addr), __FUNCTION__, __LINE__)
+#define rtw_read16(adapter, addr) dbg_rtw_read16((adapter), (addr), __FUNCTION__, __LINE__)
+#define rtw_read32(adapter, addr) dbg_rtw_read32((adapter), (addr), __FUNCTION__, __LINE__)
+#define rtw_read_mem(adapter, addr, cnt, mem) _rtw_read_mem((adapter), (addr), (cnt), (mem))
+#define rtw_read_port(adapter, addr, cnt, mem) _rtw_read_port((adapter), (addr), (cnt), (mem))
+#define rtw_read_port_cancel(adapter) _rtw_read_port_cancel((adapter))
+
+#define  rtw_write8(adapter, addr, val) dbg_rtw_write8((adapter), (addr), (val), __FUNCTION__, __LINE__)
+#define  rtw_write16(adapter, addr, val) dbg_rtw_write16((adapter), (addr), (val), __FUNCTION__, __LINE__)
+#define  rtw_write32(adapter, addr, val) dbg_rtw_write32((adapter), (addr), (val), __FUNCTION__, __LINE__)
+#define  rtw_writeN(adapter, addr, length, data) dbg_rtw_writeN((adapter), (addr), (length), (data), __FUNCTION__, __LINE__)
+
+#define rtw_write8_async(adapter, addr, val) _rtw_write8_async((adapter), (addr), (val))
+#define rtw_write16_async(adapter, addr, val) _rtw_write16_async((adapter), (addr), (val))
+#define rtw_write32_async(adapter, addr, val) _rtw_write32_async((adapter), (addr), (val))
+
+#define rtw_write_mem(adapter, addr, cnt, mem) _rtw_write_mem((adapter), addr, cnt, mem)
+#define rtw_write_port(adapter, addr, cnt, mem) _rtw_write_port(adapter, addr, cnt, mem)
+#define rtw_write_port_and_wait(adapter, addr, cnt, mem, timeout_ms) _rtw_write_port_and_wait((adapter), (addr), (cnt), (mem), (timeout_ms))
+#define rtw_write_port_cancel(adapter) _rtw_write_port_cancel(adapter)
+
+#ifdef CONFIG_SDIO_HCI
+#define rtw_sd_f0_read8(adapter, addr) dbg_rtw_sd_f0_read8((adapter), (addr), __func__, __LINE__)
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+#define rtw_sd_iread8(adapter, addr) dbg_rtw_sd_iread8((adapter), (addr), __func__, __LINE__)
+#define rtw_sd_iread16(adapter, addr) dbg_rtw_sd_iread16((adapter), (addr), __func__, __LINE__)
+#define rtw_sd_iread32(adapter, addr) dbg_rtw_sd_iread32((adapter), (addr), __func__, __LINE__)
+#define rtw_sd_iwrite8(adapter, addr, val) dbg_rtw_sd_iwrite8((adapter), (addr), (val), __func__, __LINE__)
+#define rtw_sd_iwrite16(adapter, addr, val) dbg_rtw_sd_iwrite16((adapter), (addr), (val), __func__, __LINE__)
+#define rtw_sd_iwrite32(adapter, addr, val) dbg_rtw_sd_iwrite32((adapter), (addr), (val), __func__, __LINE__)
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+#endif /* CONFIG_SDIO_HCI */
+
+#else /* DBG_IO */
+#define match_read_sniff_ranges(addr, len) _FALSE
+#define match_write_sniff_ranges(addr, len) _FALSE
+#define match_rf_read_sniff_ranges(path, addr, mask) _FALSE
+#define match_rf_write_sniff_ranges(path, addr, mask) _FALSE
+#define rtw_read8(adapter, addr) _rtw_read8((adapter), (addr))
+#define rtw_read16(adapter, addr) _rtw_read16((adapter), (addr))
+#define rtw_read32(adapter, addr) _rtw_read32((adapter), (addr))
+#define rtw_read_mem(adapter, addr, cnt, mem) _rtw_read_mem((adapter), (addr), (cnt), (mem))
+#define rtw_read_port(adapter, addr, cnt, mem) _rtw_read_port((adapter), (addr), (cnt), (mem))
+#define rtw_read_port_cancel(adapter) _rtw_read_port_cancel((adapter))
+
+#define  rtw_write8(adapter, addr, val) _rtw_write8((adapter), (addr), (val))
+#define  rtw_write16(adapter, addr, val) _rtw_write16((adapter), (addr), (val))
+#define  rtw_write32(adapter, addr, val) _rtw_write32((adapter), (addr), (val))
+#define  rtw_writeN(adapter, addr, length, data) _rtw_writeN((adapter), (addr), (length), (data))
+
+#define rtw_write8_async(adapter, addr, val) _rtw_write8_async((adapter), (addr), (val))
+#define rtw_write16_async(adapter, addr, val) _rtw_write16_async((adapter), (addr), (val))
+#define rtw_write32_async(adapter, addr, val) _rtw_write32_async((adapter), (addr), (val))
+
+#define rtw_write_mem(adapter, addr, cnt, mem) _rtw_write_mem((adapter), (addr), (cnt), (mem))
+#define rtw_write_port(adapter, addr, cnt, mem) _rtw_write_port((adapter), (addr), (cnt), (mem))
+#define rtw_write_port_and_wait(adapter, addr, cnt, mem, timeout_ms) _rtw_write_port_and_wait((adapter), (addr), (cnt), (mem), (timeout_ms))
+#define rtw_write_port_cancel(adapter) _rtw_write_port_cancel((adapter))
+
+#ifdef CONFIG_SDIO_HCI
+#define rtw_sd_f0_read8(adapter, addr) _rtw_sd_f0_read8((adapter), (addr))
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+#define rtw_sd_iread8(adapter, addr) _rtw_sd_iread8((adapter), (addr))
+#define rtw_sd_iread16(adapter, addr) _rtw_sd_iread16((adapter), (addr))
+#define rtw_sd_iread32(adapter, addr) _rtw_sd_iread32((adapter), (addr))
+#define rtw_sd_iwrite8(adapter, addr, val) _rtw_sd_iwrite8((adapter), (addr), (val))
+#define rtw_sd_iwrite16(adapter, addr, val) _rtw_sd_iwrite16((adapter), (addr), (val))
+#define rtw_sd_iwrite32(adapter, addr, val) _rtw_sd_iwrite32((adapter), (addr), (val))
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+#endif /* CONFIG_SDIO_HCI */
+
+#endif /* DBG_IO */
+
+extern void rtw_write_scsi(_adapter *adapter, u32 cnt, u8 *pmem);
+
+/* ioreq */
+extern void ioreq_read8(_adapter *adapter, u32 addr, u8 *pval);
+extern void ioreq_read16(_adapter *adapter, u32 addr, u16 *pval);
+extern void ioreq_read32(_adapter *adapter, u32 addr, u32 *pval);
+extern void ioreq_write8(_adapter *adapter, u32 addr, u8 val);
+extern void ioreq_write16(_adapter *adapter, u32 addr, u16 val);
+extern void ioreq_write32(_adapter *adapter, u32 addr, u32 val);
+
+
+extern uint async_read8(_adapter *adapter, u32 addr, u8 *pbuff,
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
+extern uint async_read16(_adapter *adapter, u32 addr,  u8 *pbuff,
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
+extern uint async_read32(_adapter *adapter, u32 addr,  u8 *pbuff,
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
+
+extern void async_read_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+extern void async_read_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+
+extern void async_write8(_adapter *adapter, u32 addr, u8 val,
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
+extern void async_write16(_adapter *adapter, u32 addr, u16 val,
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
+extern void async_write32(_adapter *adapter, u32 addr, u32 val,
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
+
+extern void async_write_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+extern void async_write_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
+
+
+int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter, struct _io_ops *pops));
+
+
+extern uint alloc_io_queue(_adapter *adapter);
+extern void free_io_queue(_adapter *adapter);
+extern void async_bus_io(struct io_queue *pio_q);
+extern void bus_sync_io(struct io_queue *pio_q);
+extern u32 _ioreq2rwmem(struct io_queue *pio_q);
+extern void dev_power_down(_adapter *Adapter, u8 bpwrup);
+
+/*
+#define RTL_R8(reg)		rtw_read8(padapter, reg)
+#define RTL_R16(reg)            rtw_read16(padapter, reg)
+#define RTL_R32(reg)            rtw_read32(padapter, reg)
+#define RTL_W8(reg, val8)       rtw_write8(padapter, reg, val8)
+#define RTL_W16(reg, val16)     rtw_write16(padapter, reg, val16)
+#define RTL_W32(reg, val32)     rtw_write32(padapter, reg, val32)
+*/
+
+/*
+#define RTL_W8_ASYNC(reg, val8) rtw_write32_async(padapter, reg, val8)
+#define RTL_W16_ASYNC(reg, val16) rtw_write32_async(padapter, reg, val16)
+#define RTL_W32_ASYNC(reg, val32) rtw_write32_async(padapter, reg, val32)
+
+#define RTL_WRITE_BB(reg, val32)	phy_SetUsbBBReg(padapter, reg, val32)
+#define RTL_READ_BB(reg)	phy_QueryUsbBBReg(padapter, reg)
+*/
+
+#define PlatformEFIOWrite1Byte(_a, _b, _c)		\
+	rtw_write8(_a, _b, _c)
+#define PlatformEFIOWrite2Byte(_a, _b, _c)		\
+	rtw_write16(_a, _b, _c)
+#define PlatformEFIOWrite4Byte(_a, _b, _c)		\
+	rtw_write32(_a, _b, _c)
+
+#define PlatformEFIORead1Byte(_a, _b)		\
+	rtw_read8(_a, _b)
+#define PlatformEFIORead2Byte(_a, _b)		\
+	rtw_read16(_a, _b)
+#define PlatformEFIORead4Byte(_a, _b)		\
+	rtw_read32(_a, _b)
+
+#endif /* _RTL8711_IO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl.h
new file mode 100644
index 000000000000..4924751c2456
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl.h
@@ -0,0 +1,319 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_IOCTL_H_
+#define _RTW_IOCTL_H_
+
+#ifndef PLATFORM_WINDOWS
+/*	00 - Success
+*	11 - Error */
+#define STATUS_SUCCESS				(0x00000000L)
+#define STATUS_PENDING				(0x00000103L)
+
+#define STATUS_UNSUCCESSFUL			(0xC0000001L)
+#define STATUS_INSUFFICIENT_RESOURCES		(0xC000009AL)
+#define STATUS_NOT_SUPPORTED			(0xC00000BBL)
+
+#define NDIS_STATUS_SUCCESS			((NDIS_STATUS)STATUS_SUCCESS)
+#define NDIS_STATUS_PENDING			((NDIS_STATUS)STATUS_PENDING)
+#define NDIS_STATUS_NOT_RECOGNIZED		((NDIS_STATUS)0x00010001L)
+#define NDIS_STATUS_NOT_COPIED			((NDIS_STATUS)0x00010002L)
+#define NDIS_STATUS_NOT_ACCEPTED		((NDIS_STATUS)0x00010003L)
+#define NDIS_STATUS_CALL_ACTIVE			((NDIS_STATUS)0x00010007L)
+
+#define NDIS_STATUS_FAILURE			((NDIS_STATUS)STATUS_UNSUCCESSFUL)
+#define NDIS_STATUS_RESOURCES			((NDIS_STATUS)STATUS_INSUFFICIENT_RESOURCES)
+#define NDIS_STATUS_CLOSING			((NDIS_STATUS)0xC0010002L)
+#define NDIS_STATUS_BAD_VERSION			((NDIS_STATUS)0xC0010004L)
+#define NDIS_STATUS_BAD_CHARACTERISTICS		((NDIS_STATUS)0xC0010005L)
+#define NDIS_STATUS_ADAPTER_NOT_FOUND		((NDIS_STATUS)0xC0010006L)
+#define NDIS_STATUS_OPEN_FAILED			((NDIS_STATUS)0xC0010007L)
+#define NDIS_STATUS_DEVICE_FAILED		((NDIS_STATUS)0xC0010008L)
+#define NDIS_STATUS_MULTICAST_FULL		((NDIS_STATUS)0xC0010009L)
+#define NDIS_STATUS_MULTICAST_EXISTS		((NDIS_STATUS)0xC001000AL)
+#define NDIS_STATUS_MULTICAST_NOT_FOUND		((NDIS_STATUS)0xC001000BL)
+#define NDIS_STATUS_REQUEST_ABORTED		((NDIS_STATUS)0xC001000CL)
+#define NDIS_STATUS_RESET_IN_PROGRESS		((NDIS_STATUS)0xC001000DL)
+#define NDIS_STATUS_CLOSING_INDICATING		((NDIS_STATUS)0xC001000EL)
+#define NDIS_STATUS_NOT_SUPPORTED		((NDIS_STATUS)STATUS_NOT_SUPPORTED)
+#define NDIS_STATUS_INVALID_PACKET		((NDIS_STATUS)0xC001000FL)
+#define NDIS_STATUS_OPEN_LIST_FULL		((NDIS_STATUS)0xC0010010L)
+#define NDIS_STATUS_ADAPTER_NOT_READY		((NDIS_STATUS)0xC0010011L)
+#define NDIS_STATUS_ADAPTER_NOT_OPEN		((NDIS_STATUS)0xC0010012L)
+#define NDIS_STATUS_NOT_INDICATING		((NDIS_STATUS)0xC0010013L)
+#define NDIS_STATUS_INVALID_LENGTH		((NDIS_STATUS)0xC0010014L)
+#define NDIS_STATUS_INVALID_DATA		((NDIS_STATUS)0xC0010015L)
+#define NDIS_STATUS_BUFFER_TOO_SHORT		((NDIS_STATUS)0xC0010016L)
+#define NDIS_STATUS_INVALID_OID			((NDIS_STATUS)0xC0010017L)
+#define NDIS_STATUS_ADAPTER_REMOVED		((NDIS_STATUS)0xC0010018L)
+#define NDIS_STATUS_UNSUPPORTED_MEDIA		((NDIS_STATUS)0xC0010019L)
+#define NDIS_STATUS_GROUP_ADDRESS_IN_USE	((NDIS_STATUS)0xC001001AL)
+#define NDIS_STATUS_FILE_NOT_FOUND		((NDIS_STATUS)0xC001001BL)
+#define NDIS_STATUS_ERROR_READING_FILE		((NDIS_STATUS)0xC001001CL)
+#define NDIS_STATUS_ALREADY_MAPPED		((NDIS_STATUS)0xC001001DL)
+#define NDIS_STATUS_RESOURCE_CONFLICT		((NDIS_STATUS)0xC001001EL)
+#define NDIS_STATUS_NO_CABLE			((NDIS_STATUS)0xC001001FL)
+
+#define NDIS_STATUS_INVALID_SAP			((NDIS_STATUS)0xC0010020L)
+#define NDIS_STATUS_SAP_IN_USE			((NDIS_STATUS)0xC0010021L)
+#define NDIS_STATUS_INVALID_ADDRESS		((NDIS_STATUS)0xC0010022L)
+#define NDIS_STATUS_VC_NOT_ACTIVATED		((NDIS_STATUS)0xC0010023L)
+#define NDIS_STATUS_DEST_OUT_OF_ORDER		((NDIS_STATUS)0xC0010024L)  /* cause 27 */
+#define NDIS_STATUS_VC_NOT_AVAILABLE		((NDIS_STATUS)0xC0010025L)  /* cause 35, 45 */
+#define NDIS_STATUS_CELLRATE_NOT_AVAILABLE	((NDIS_STATUS)0xC0010026L)  /* cause 37 */
+#define NDIS_STATUS_INCOMPATABLE_QOS		((NDIS_STATUS)0xC0010027L)  /* cause 49 */
+#define NDIS_STATUS_AAL_PARAMS_UNSUPPORTED	((NDIS_STATUS)0xC0010028L)  /* cause 93 */
+#define NDIS_STATUS_NO_ROUTE_TO_DESTINATION	((NDIS_STATUS)0xC0010029L)  /* cause 3 */
+#endif /* #ifndef PLATFORM_WINDOWS */
+
+
+#ifndef OID_802_11_CAPABILITY
+	#define OID_802_11_CAPABILITY                   0x0d010122
+#endif
+
+#ifndef OID_802_11_PMKID
+	#define OID_802_11_PMKID                        0x0d010123
+#endif
+
+
+/* For DDK-defined OIDs */
+#define OID_NDIS_SEG1	0x00010100
+#define OID_NDIS_SEG2	0x00010200
+#define OID_NDIS_SEG3	0x00020100
+#define OID_NDIS_SEG4	0x01010100
+#define OID_NDIS_SEG5	0x01020100
+#define OID_NDIS_SEG6	0x01020200
+#define OID_NDIS_SEG7	0xFD010100
+#define OID_NDIS_SEG8	0x0D010100
+#define OID_NDIS_SEG9	0x0D010200
+#define OID_NDIS_SEG10	0x0D020200
+
+#define SZ_OID_NDIS_SEG1		  23
+#define SZ_OID_NDIS_SEG2		    3
+#define SZ_OID_NDIS_SEG3		    6
+#define SZ_OID_NDIS_SEG4		    6
+#define SZ_OID_NDIS_SEG5		    4
+#define SZ_OID_NDIS_SEG6		    8
+#define SZ_OID_NDIS_SEG7		    7
+#define SZ_OID_NDIS_SEG8		  36
+#define SZ_OID_NDIS_SEG9		  24
+#define SZ_OID_NDIS_SEG10		  19
+
+/* For Realtek-defined OIDs */
+#define OID_MP_SEG1		0xFF871100
+#define OID_MP_SEG2		0xFF818000
+
+#define OID_MP_SEG3		0xFF818700
+#define OID_MP_SEG4		0xFF011100
+
+enum oid_type {
+	QUERY_OID,
+	SET_OID
+};
+
+struct oid_funs_node {
+	unsigned int oid_start; /* the starting number for OID */
+	unsigned int oid_end; /* the ending number for OID */
+	struct oid_obj_priv *node_array;
+	unsigned int array_sz; /* the size of node_array */
+	int query_counter; /* count the number of query hits for this segment  */
+	int set_counter; /* count the number of set hits for this segment  */
+};
+
+struct oid_par_priv {
+	void		*adapter_context;
+	NDIS_OID	oid;
+	void		*information_buf;
+	u32		information_buf_len;
+	u32		*bytes_rw;
+	u32		*bytes_needed;
+	enum oid_type	type_of_oid;
+	u32		dbg;
+};
+
+struct oid_obj_priv {
+	unsigned char	dbg; /* 0: without OID debug message  1: with OID debug message */
+	NDIS_STATUS(*oidfuns)(struct oid_par_priv *poid_par_priv);
+};
+
+#if (defined(CONFIG_MP_INCLUDED) && defined(_RTW_MP_IOCTL_C_)) || \
+	(defined(PLATFORM_WINDOWS) && defined(_RTW_IOCTL_RTL_C_))
+static NDIS_STATUS oid_null_function(struct oid_par_priv *poid_par_priv)
+{
+	return NDIS_STATUS_SUCCESS;
+}
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+int TranslateNdisPsToRtPs(IN NDIS_802_11_POWER_MODE	ndisPsMode);
+
+/* OID Handler for Segment 1 */
+NDIS_STATUS oid_gen_supported_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_hardware_status_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_media_supported_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_media_in_use_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_lookahead_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_frame_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_link_speed_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_transmit_buffer_space_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_receive_buffer_space_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_transmit_block_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_receive_block_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_vendor_id_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_vendor_description_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_current_packet_filter_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_current_lookahead_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_driver_version_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_total_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_protocol_options_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_mac_options_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_media_connect_status_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_send_packets_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_vendor_driver_version_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 2 */
+NDIS_STATUS oid_gen_physical_medium_hdl(struct oid_par_priv *poid_par_priv);
+
+/* OID Handler for Segment 3 */
+NDIS_STATUS oid_gen_xmit_ok_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_rcv_ok_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_xmit_error_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_rcv_error_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_rcv_no_buffer_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 4 */
+NDIS_STATUS oid_802_3_permanent_address_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_current_address_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_multicast_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_maximum_list_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_mac_options_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+/* OID Handler for Segment 5 */
+NDIS_STATUS oid_802_3_rcv_error_alignment_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_one_collision_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_more_collisions_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 6 */
+NDIS_STATUS oid_802_3_xmit_deferred_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_max_collisions_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_rcv_overrun_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_underrun_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_heartbeat_failure_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_times_crs_lost_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_late_collisions_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+/* OID Handler for Segment 7 */
+NDIS_STATUS oid_pnp_capabilities_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_set_power_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_query_power_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_add_wake_up_pattern_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_remove_wake_up_pattern_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_wake_up_pattern_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_enable_wake_up_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+/* OID Handler for Segment 8 */
+NDIS_STATUS oid_802_11_bssid_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_ssid_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_infrastructure_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_add_wep_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_remove_wep_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_disassociate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_authentication_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_privacy_filter_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_bssid_list_scan_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_encryption_status_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_reload_defaults_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_add_key_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_remove_key_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_association_information_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_test_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_media_stream_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_capability_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_pmkid_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+
+
+/* OID Handler for Segment 9 */
+NDIS_STATUS oid_802_11_network_types_supported_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_network_type_in_use_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_tx_power_level_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rssi_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rssi_trigger_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_fragmentation_threshold_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rts_threshold_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_number_of_antennas_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rx_antenna_selected_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_tx_antenna_selected_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_supported_rates_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_desired_rates_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_configuration_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_power_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_bssid_list_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 10 */
+NDIS_STATUS oid_802_11_statistics_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment ED */
+NDIS_STATUS oid_rt_mh_vender_id_hdl(struct oid_par_priv *poid_par_priv);
+
+void Set_802_3_MULTICAST_LIST(ADAPTER *pAdapter, UCHAR *MCListbuf, ULONG MCListlen, BOOLEAN bAcceptAllMulticast);
+
+#endif/* end of PLATFORM_WINDOWS */
+
+#if defined(PLATFORM_LINUX) && defined(CONFIG_WIRELESS_EXT)
+extern struct iw_handler_def  rtw_handlers_def;
+#endif
+
+extern void rtw_request_wps_pbc_event(_adapter *padapter);
+
+extern	NDIS_STATUS drv_query_info(
+	IN	_nic_hdl		MiniportAdapterContext,
+	IN	NDIS_OID		Oid,
+	IN	void			*InformationBuffer,
+	IN	u32			InformationBufferLength,
+	OUT	u32			*BytesWritten,
+	OUT	u32			*BytesNeeded
+);
+
+extern	NDIS_STATUS	drv_set_info(
+	IN	_nic_hdl		MiniportAdapterContext,
+	IN	NDIS_OID		Oid,
+	IN	void			*InformationBuffer,
+	IN	u32			InformationBufferLength,
+	OUT	u32			*BytesRead,
+	OUT	u32			*BytesNeeded
+);
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+extern int rtw_vendor_ie_get_raw_data(struct net_device *, u32, char *, u32);
+extern int rtw_vendor_ie_get_data(struct net_device*, int , char*);
+extern int rtw_vendor_ie_get(struct net_device *, struct iw_request_info *, union iwreq_data *, char *);
+extern int rtw_vendor_ie_set(struct net_device*, struct iw_request_info*, union iwreq_data*, char*);
+#endif
+
+#endif /*  #ifndef __INC_CEINFO_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_query.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_query.h
new file mode 100644
index 000000000000..cc7b557ee346
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_query.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_IOCTL_QUERY_H_
+#define _RTW_IOCTL_QUERY_H_
+
+
+#ifdef PLATFORM_WINDOWS
+u8 query_802_11_capability(_adapter	*padapter, u8 *pucBuf, u32 *pulOutLen);
+u8 query_802_11_association_information(_adapter *padapter, PNDIS_802_11_ASSOCIATION_INFORMATION pAssocInfo);
+#endif
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_rtl.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_rtl.h
new file mode 100644
index 000000000000..2df8713ad500
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_rtl.h
@@ -0,0 +1,75 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_IOCTL_RTL_H_
+#define _RTW_IOCTL_RTL_H_
+
+
+/* ************** oid_rtl_seg_01_01 ************** */
+NDIS_STATUS oid_rt_get_signal_quality_hdl(struct oid_par_priv *poid_par_priv);/* 84 */
+NDIS_STATUS oid_rt_get_small_packet_crc_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_middle_packet_crc_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_large_packet_crc_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_tx_retry_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_rx_retry_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_rx_total_packet_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_tx_beacon_ok_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_tx_beacon_err_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_set_fw_dig_state_hdl(struct oid_par_priv *poid_par_priv);	/* 8a */
+NDIS_STATUS oid_rt_pro_set_fw_ra_state_hdl(struct oid_par_priv *poid_par_priv);	/* 8b */
+
+NDIS_STATUS oid_rt_get_rx_icv_err_hdl(struct oid_par_priv *poid_par_priv);/* 93 */
+NDIS_STATUS oid_rt_set_encryption_algorithm_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_preamble_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_ap_ip_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_channelplan_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_channelplan_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_preamble_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_bcn_intvl_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_dedicate_probe_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_total_tx_bytes_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_total_rx_bytes_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_current_tx_power_level_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_enc_key_mismatch_count_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_enc_key_match_count_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_channel_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_hardware_radio_off_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_key_mismatch_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_supported_wireless_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_channel_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_scan_in_progress_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_forced_data_rate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_wireless_mode_for_scan_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_bss_wireless_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_scan_with_magic_packet_hdl(struct oid_par_priv *poid_par_priv);
+
+/* **************  oid_rtl_seg_01_03 section start ************** */
+NDIS_STATUS oid_rt_ap_get_associated_station_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_ap_switch_into_ap_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_ap_supported_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_ap_set_passphrase_hdl(struct oid_par_priv *poid_par_priv);
+
+/* oid_rtl_seg_01_11 */
+NDIS_STATUS oid_rt_pro_rf_write_registry_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_rf_read_registry_hdl(struct oid_par_priv *poid_par_priv);
+
+/* **************  oid_rtl_seg_03_00 section start **************  */
+NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_default_key_id_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_set.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_set.h
new file mode 100644
index 000000000000..2bfe570c8dcc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_ioctl_set.h
@@ -0,0 +1,67 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_IOCTL_SET_H_
+#define __RTW_IOCTL_SET_H_
+
+
+typedef u8 NDIS_802_11_PMKID_VALUE[16];
+
+typedef struct _BSSIDInfo {
+	NDIS_802_11_MAC_ADDRESS  BSSID;
+	NDIS_802_11_PMKID_VALUE  PMKID;
+} BSSIDInfo, *PBSSIDInfo;
+
+
+#ifdef PLATFORM_OS_XP
+typedef struct _NDIS_802_11_PMKID {
+	u32	Length;
+	u32	BSSIDInfoCount;
+	BSSIDInfo BSSIDInfo[1];
+} NDIS_802_11_PMKID, *PNDIS_802_11_PMKID;
+#endif
+
+
+#ifdef PLATFORM_WINDOWS
+u8 rtw_set_802_11_reload_defaults(_adapter *padapter, NDIS_802_11_RELOAD_DEFAULTS reloadDefaults);
+u8 rtw_set_802_11_test(_adapter *padapter, NDIS_802_11_TEST *test);
+u8 rtw_set_802_11_pmkid(_adapter *pdapter, NDIS_802_11_PMKID *pmkid);
+
+u8 rtw_pnp_set_power_sleep(_adapter *padapter);
+u8 rtw_pnp_set_power_wakeup(_adapter *padapter);
+
+void rtw_pnp_resume_wk(void *context);
+void rtw_pnp_sleep_wk(void *context);
+
+#endif
+
+u8 rtw_set_802_11_authentication_mode(_adapter *pdapter, NDIS_802_11_AUTHENTICATION_MODE authmode);
+u8 rtw_set_802_11_bssid(_adapter *padapter, u8 *bssid);
+u8 rtw_set_802_11_add_wep(_adapter *padapter, NDIS_802_11_WEP *wep);
+u8 rtw_set_802_11_disassociate(_adapter *padapter);
+u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, struct sitesurvey_parm *pparm);
+u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype);
+u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid);
+u8 rtw_set_802_11_connect(_adapter *padapter, u8 *bssid, NDIS_802_11_SSID *ssid);
+
+u8 rtw_validate_bssid(u8 *bssid);
+u8 rtw_validate_ssid(NDIS_802_11_SSID *ssid);
+
+u16 rtw_get_cur_max_rate(_adapter *adapter);
+int rtw_set_scan_mode(_adapter *adapter, RT_SCAN_TYPE scan_mode);
+int rtw_set_channel_plan(_adapter *adapter, u8 channel_plan);
+int rtw_set_country(_adapter *adapter, const char *country_code);
+int rtw_set_band(_adapter *adapter, u8 band);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_iol.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_iol.h
new file mode 100644
index 000000000000..fa35a59c75c7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_iol.h
@@ -0,0 +1,131 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_IOL_H_
+#define __RTW_IOL_H_
+
+
+struct xmit_frame	*rtw_IOL_accquire_xmit_frame(ADAPTER *adapter);
+int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len);
+int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary);
+int rtw_IOL_exec_cmds_sync(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
+bool rtw_IOL_applied(ADAPTER *adapter);
+int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us);
+int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms);
+int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame);
+
+
+#ifdef CONFIG_IOL_NEW_GENERATION
+#define IOREG_CMD_END_LEN	4
+
+struct ioreg_cfg {
+	u8	length;
+	u8	cmd_id;
+	u16	address;
+	u32	data;
+	u32  mask;
+};
+enum ioreg_cmd {
+	IOREG_CMD_LLT			= 0x01,
+	IOREG_CMD_REFUSE		= 0x02,
+	IOREG_CMD_EFUSE_PATH = 0x03,
+	IOREG_CMD_WB_REG		= 0x04,
+	IOREG_CMD_WW_REG	= 0x05,
+	IOREG_CMD_WD_REG	= 0x06,
+	IOREG_CMD_W_RF		= 0x07,
+	IOREG_CMD_DELAY_US	= 0x10,
+	IOREG_CMD_DELAY_MS	= 0x11,
+	IOREG_CMD_END		= 0xFF,
+};
+void read_efuse_from_txpktbuf(ADAPTER *adapter, int bcnhead, u8 *content, u16 *size);
+
+int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, u8 mask);
+int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, u16 mask);
+int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, u32 mask);
+int _rtw_IOL_append_WRF_cmd(struct xmit_frame *xmit_frame, u8 rf_path, u16 addr, u32 value, u32 mask);
+#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value, mask) _rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value), (mask))
+#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value, mask) _rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value), (mask))
+#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value, mask) _rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value), (mask))
+#define rtw_IOL_append_WRF_cmd(xmit_frame, rf_path, addr, value, mask) _rtw_IOL_append_WRF_cmd((xmit_frame), (rf_path), (addr), (value), (mask))
+
+u8 rtw_IOL_cmd_boundary_handle(struct xmit_frame *pxmit_frame);
+void  rtw_IOL_cmd_buf_dump(ADAPTER *Adapter, int buf_len, u8 *pbuf);
+
+#ifdef CONFIG_IOL_IOREG_CFG_DBG
+struct cmd_cmp {
+	u16 addr;
+	u32 value;
+};
+#endif
+
+#else /* CONFIG_IOL_NEW_GENERATION */
+
+typedef struct _io_offload_cmd {
+	u8 rsvd0;
+	u8 cmd;
+	u16 address;
+	u32 value;
+} IO_OFFLOAD_CMD, IOL_CMD;
+
+#define IOL_CMD_LLT			0x00
+/* #define IOL_CMD_R_EFUSE	0x01 */
+#define IOL_CMD_WB_REG		0x02
+#define IOL_CMD_WW_REG	0x03
+#define IOL_CMD_WD_REG		0x04
+/* #define IOL_CMD_W_RF		0x05 */
+#define IOL_CMD_DELAY_US	0x80
+#define IOL_CMD_DELAY_MS	0x81
+/* #define IOL_CMD_DELAY_S	0x82 */
+#define IOL_CMD_END			0x83
+
+/*****************************************************
+CMD					Address			Value
+(B1)					(B2/B3:H/L addr)	(B4:B7 : MSB:LSB)
+******************************************************
+IOL_CMD_LLT			-				B7: PGBNDY
+IOL_CMD_R_EFUSE	-				-
+IOL_CMD_WB_REG		0x0~0xFFFF		B7
+IOL_CMD_WW_REG	0x0~0xFFFF		B6~B7
+IOL_CMD_WD_REG	0x0~0xFFFF		B4~B7
+IOL_CMD_W_RF		RF Reg			B5~B7
+IOL_CMD_DELAY_US	-				B6~B7
+IOL_CMD_DELAY_MS	-				B6~B7
+IOL_CMD_DELAY_S	-				B6~B7
+IOL_CMD_END		-				-
+******************************************************/
+int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value);
+int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value);
+int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value);
+
+
+int rtw_IOL_exec_cmd_array_sync(PADAPTER adapter, u8 *IOL_cmds, u32 cmd_num, u32 max_wating_ms);
+int rtw_IOL_exec_empty_cmds_sync(ADAPTER *adapter, u32 max_wating_ms);
+
+#ifdef DBG_IO
+int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line);
+int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line);
+int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line);
+#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
+#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
+#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
+#else
+#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value) _rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value))
+#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value) _rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value))
+#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value) _rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value))
+#endif /* DBG_IO */
+#endif /* CONFIG_IOL_NEW_GENERATION */
+
+
+
+#endif /* __RTW_IOL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mcc.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mcc.h
new file mode 100644
index 000000000000..62e880eeba9e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mcc.h
@@ -0,0 +1,269 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#ifdef CONFIG_MCC_MODE
+
+#ifndef _RTW_MCC_H_
+#define _RTW_MCC_H_
+
+#include <drv_types.h> /* PADAPTER */
+
+#define MCC_STATUS_PROCESS_MCC_START_SETTING BIT0
+#define MCC_STATUS_PROCESS_MCC_STOP_SETTING BIT1
+#define MCC_STATUS_NEED_MCC BIT2
+#define MCC_STATUS_DOING_MCC BIT3
+
+
+#define MCC_SWCH_FW_EARLY_TIME 10 /* ms */
+#define MCC_EXPIRE_TIME 50 /* ms */
+#define MCC_TOLERANCE_TIME 2 /* 2*2 = 4s */
+#define MCC_UPDATE_PARAMETER_THRESHOLD 5 /* ms */
+
+#define MCC_ROLE_STA_GC_MGMT_QUEUE_MACID 0
+#define MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID 1
+
+/* Lower for stop, Higher for start */
+#define MCC_SETCMD_STATUS_STOP_DISCONNECT 0x0
+#define MCC_SETCMD_STATUS_STOP_SCAN_START 0x1
+#define MCC_SETCMD_STATUS_START_CONNECT 0x80
+#define MCC_SETCMD_STATUS_START_SCAN_DONE 0x81
+
+/*
+* depenad platform or customer requirement(TP unit:Mbps),
+* must be provided by PM or sales or product document
+* too large value means not to limit tx bytes (current for ap mode)
+* NOTE: following values ref from test results
+*/
+#define MCC_AP_BW20_TARGET_TX_TP (300)
+#define MCC_AP_BW40_TARGET_TX_TP (300)
+#define MCC_AP_BW80_TARGET_TX_TP (300)
+#define MCC_STA_BW20_TARGET_TX_TP (35)
+#define MCC_STA_BW40_TARGET_TX_TP (70)
+#define MCC_STA_BW80_TARGET_TX_TP (140)
+#define MCC_SINGLE_TX_CRITERIA 5 /* Mbps */
+
+#define MAX_MCC_NUM 2
+
+#define MCC_STOP(adapter) (adapter->mcc_adapterpriv.mcc_tx_stop)
+#define MCC_EN(adapter) (adapter_to_dvobj(adapter)->mcc_objpriv.en_mcc)
+#define SET_MCC_EN_FLAG(adapter, flag)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.en_mcc = (flag); \
+	} while (0)
+#define SET_MCC_DURATION(adapter, val)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.duration = (val); \
+	} while (0)
+#define SET_MCC_RUNTIME_DURATION(adapter, flag)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.enable_runtime_duration = (flag); \
+	} while (0)
+/* Represent Channel Tx Null setting */
+enum mcc_channel_tx_null {
+	MCC_ENABLE_TX_NULL = 0,
+	MCC_DISABLE_TX_NULL = 1,
+};
+
+/* Represent C2H Report setting */
+enum mcc_c2h_report {
+	MCC_C2H_REPORT_DISABLE = 0,
+	MCC_C2H_REPORT_FAIL_STATUS = 1,
+	MCC_C2H_REPORT_ALL_STATUS = 2,
+};
+
+/* Represent Channel Scan */
+enum mcc_channel_scan {
+	MCC_CHIDX = 0,
+	MCC_SCANCH_RSVD_LOC = 1,
+};
+
+/* Represent FW status report of channel switch */
+enum mcc_status_rpt {
+	MCC_RPT_SUCCESS = 0,
+	MCC_RPT_TXNULL_FAIL = 1,
+	MCC_RPT_STOPMCC = 2,
+	MCC_RPT_READY = 3,
+	MCC_RPT_SWICH_CHANNEL_NOTIFY = 7,
+	MCC_RPT_UPDATE_NOA_START_TIME = 8,
+	MCC_RPT_TSF = 9,
+	MCC_RPT_MAX,
+};
+
+enum MCC_ROLE {
+	MCC_ROLE_STA = 0,
+	MCC_ROLE_AP = 1,
+	MCC_ROLE_GC = 2,
+	MCC_ROLE_GO = 3,
+	MCC_ROLE_MAX,
+};
+
+struct mcc_iqk_backup {
+	u16 TX_X;
+	u16 TX_Y;
+	u16 RX_X;
+	u16 RX_Y;
+};
+
+enum MCC_DURATION_SETTING {
+	MCC_DURATION_MAPPING = 0,
+	MCC_DURATION_DIRECET = 1,
+};
+
+enum MCC_SCHED_MODE {
+	MCC_FAIR_SCHEDULE = 0,
+	MCC_FAVOE_STA = 1,
+	MCC_FAVOE_P2P = 2,
+};
+
+/*  mcc data for adapter */
+struct mcc_adapter_priv {
+	u8 order;		/* FW document, softap/AP must be 0 */
+	u8 role;			/* MCC role(AP,STA,GO,GC) */
+	u8 mcc_duration; /* channel stay period, UNIT:1TU */
+
+	/* flow control */
+	u8 mcc_tx_stop;				/* check if tp stop or not */
+	u8 mcc_tp_limit;				/* check if tp limit or not */
+	u32 mcc_target_tx_bytes_to_port;		/* customer require  */
+	u32 mcc_tx_bytes_to_port;	/* already tx to tx fifo (write port) */
+
+	/* data from kernel to check if enqueue data or netif stop queue */
+	u32 mcc_tp;
+	u64 mcc_tx_bytes_from_kernel;
+	u64 mcc_last_tx_bytes_from_kernel;
+
+	/* Backup IQK value for MCC */
+	struct mcc_iqk_backup mcc_iqk_arr[MAX_RF_PATH];
+
+	/* mgmt queue macid to avoid RA issue */
+	u8 mgmt_queue_macid;
+
+	/* set macid bitmap to let fw know which macid should be tx pause */
+	/* all interface share total 16 macid */
+	u16 mcc_macid_bitmap;
+
+	/* use for NoA start time (unit: mircoseconds) */
+	u32 noa_start_time;
+
+	u8 p2p_go_noa_ie[MAX_P2P_IE_LEN];
+	u32 p2p_go_noa_ie_len;
+	u64 tsf;
+#ifdef CONFIG_TDLS
+	u8 backup_tdls_en;
+#endif /* CONFIG_TDLS */
+
+	u8 null_early;
+	u8 null_rty_num;
+};
+
+struct mcc_obj_priv {
+	u8 en_mcc; /* enable MCC or not */
+	u8 duration; /* store duration(%) from registry, for primary adapter */
+	u8 interval;
+	u8 start_time;
+	u8 mcc_c2h_status;
+	u8 cur_mcc_success_cnt; /* used for check mcc switch channel success */
+	u8 prev_mcc_success_cnt; /* used for check mcc switch channel success */
+	u8 mcc_tolerance_time; /* used for detect mcc switch channel success */
+	u8 mcc_loc_rsvd_paga[MAX_MCC_NUM];  /* mcc rsvd page */
+	u8 mcc_status; /* mcc status stop or start .... */
+	u8 policy_index;
+	u8 mcc_stop_threshold;
+	u8 current_order;
+	u8 last_tsfdiff;
+	u32 mcc_launch_time; /* mcc launch time, used for starting detect mcc switch channel success */
+	_mutex mcc_mutex;
+	_lock mcc_lock;
+	PADAPTER iface[MAX_MCC_NUM]; /* by order, use for mcc parameter cmd */
+	struct submit_ctx mcc_sctx;
+	struct submit_ctx mcc_tsf_req_sctx;
+#ifdef CONFIG_MCC_MODE_V2
+	u8 mcc_iqk_value_rsvd_page[3];
+#endif /* CONFIG_MCC_MODE_V2 */
+	u8 mcc_pwr_idx_rsvd_page[MAX_MCC_NUM];
+	u8 enable_runtime_duration;
+	u32 backup_phydm_ability;
+	/* for LG */
+	u8 mchan_sched_mode;
+};
+
+/* backup IQK val */
+void rtw_hal_mcc_restore_iqk_val(PADAPTER padapter);
+
+/* check mcc status */
+u8 rtw_hal_check_mcc_status(PADAPTER padapter, u8 mcc_status);
+
+/* set mcc status */
+void rtw_hal_set_mcc_status(PADAPTER padapter, u8 mcc_status);
+
+/* clear mcc status */
+void rtw_hal_clear_mcc_status(PADAPTER padapter, u8 mcc_status);
+
+/* dl mcc rsvd page */
+u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index
+	, u8 tx_desc, u32 page_size, u8 *total_page_num, RSVDPAGE_LOC *rsvd_page_loc, u8 *page_num);
+
+/* handle C2H */
+void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf);
+
+/* switch channel successfully or not */
+void rtw_hal_mcc_sw_status_check(PADAPTER padapter);
+
+/* change some scan flags under site survey */
+u8 rtw_hal_mcc_change_scan_flag(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset);
+
+/* record data kernel TX to driver to check MCC concurrent TX  */
+void rtw_hal_mcc_calc_tx_bytes_from_kernel(PADAPTER padapter, u32 len);
+
+/* record data to port to let driver do flow ctrl  */
+void rtw_hal_mcc_calc_tx_bytes_to_port(PADAPTER padapter, u32 len);
+
+/* check stop write port or not  */
+u8 rtw_hal_mcc_stop_tx_bytes_to_port(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_scan_start(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_scan_complete(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_start_bss_network(PADAPTER padapter, u8 chbw_grouped);
+
+u8 rtw_hal_set_mcc_setting_disconnect(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_join_done_chk_ch(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_chk_start_clnt_join(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset, u8 chbw_allow);
+
+void rtw_hal_dump_mcc_info(void *sel, struct dvobj_priv *dvobj);
+
+void update_mcc_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib);
+
+u8 rtw_hal_mcc_link_status_chk(_adapter *padapter, const char *msg);
+
+void rtw_hal_mcc_issue_null_data(_adapter *padapter, u8 chbw_allow, u8 ps_mode);
+
+u8 *rtw_hal_mcc_append_go_p2p_ie(PADAPTER padapter, u8 *pframe, u32 *len);
+
+void rtw_hal_dump_mcc_policy_table(void *sel);
+
+void rtw_hal_mcc_update_macid_bitmap(PADAPTER padapter, int mac_id, u8 add);
+
+void rtw_hal_mcc_process_noa(PADAPTER padapter);
+
+void rtw_hal_mcc_parameter_init(PADAPTER padapter);
+
+u8 rtw_set_mcc_duration_hdl(PADAPTER adapter, u8 type, const u8 *val);
+
+u8 rtw_set_mcc_duration_cmd(_adapter *adapter, u8 type, u8 val);
+#endif /* _RTW_MCC_H_ */
+#endif /* CONFIG_MCC_MODE */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mem.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mem.h
new file mode 100644
index 000000000000..229028c35fa7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mem.h
@@ -0,0 +1,36 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MEM_H__
+#define __RTW_MEM_H__
+
+#include <drv_conf.h>
+#include <basic_types.h>
+#include <osdep_service.h>
+
+#ifdef CONFIG_PLATFORM_MSTAR_HIGH
+	#define MAX_RTKM_RECVBUF_SZ (31744) /* 31k */
+#else
+	#define MAX_RTKM_RECVBUF_SZ (15360) /* 15k */
+#endif /* CONFIG_PLATFORM_MSTAR_HIGH */
+#define MAX_RTKM_NR_PREALLOC_RECV_SKB 16
+
+u16 rtw_rtkm_get_buff_size(void);
+u8 rtw_rtkm_get_nr_recv_skb(void);
+struct u8 *rtw_alloc_revcbuf_premem(void);
+struct sk_buff *rtw_alloc_skb_premem(u16 in_size);
+int rtw_free_skb_premem(struct sk_buff *pskb);
+
+
+#endif /* __RTW_MEM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mi.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mi.h
new file mode 100644
index 000000000000..dfbac2d211c1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mi.h
@@ -0,0 +1,283 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MI_H_
+#define __RTW_MI_H_
+
+void rtw_mi_update_union_chan_inf(_adapter *adapter, u8 ch, u8 offset , u8 bw);
+u8 rtw_mi_stayin_union_ch_chk(_adapter *adapter);
+u8 rtw_mi_stayin_union_band_chk(_adapter *adapter);
+int rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
+int rtw_mi_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
+
+struct mi_state {
+	u8 sta_num;			/* WIFI_STATION_STATE */
+	u8 ld_sta_num;		/* WIFI_STATION_STATE && _FW_LINKED */
+	u8 lg_sta_num;		/* WIFI_STATION_STATE && _FW_UNDER_LINKING */
+#ifdef CONFIG_TDLS
+	u8 ld_tdls_num;		/* adapter.tdlsinfo.link_established */
+#endif
+#ifdef CONFIG_AP_MODE
+	u8 ap_num;			/* WIFI_AP_STATE && _FW_LINKED */
+	u8 starting_ap_num;	/*WIFI_FW_AP_STATE*/
+	u8 ld_ap_num;		/* WIFI_AP_STATE && _FW_LINKED && asoc_sta_count > 2 */
+#endif
+	u8 adhoc_num;		/* (WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) && _FW_LINKED */
+	u8 ld_adhoc_num;	/* (WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) && _FW_LINKED && asoc_sta_count > 2 */
+#ifdef CONFIG_RTW_MESH
+	u8 mesh_num;		/* WIFI_MESH_STATE &&  _FW_LINKED */
+	u8 ld_mesh_num;		/* WIFI_MESH_STATE &&  _FW_LINKED && asoc_sta_count > 2 */
+#endif
+	u8 scan_num;		/* WIFI_SITE_MONITOR */
+	u8 scan_enter_num;	/* WIFI_SITE_MONITOR && !SCAN_DISABLE && !SCAN_BACK_OP */
+	u8 uwps_num;		/* WIFI_UNDER_WPS */
+#ifdef CONFIG_IOCTL_CFG80211
+	#ifdef CONFIG_P2P
+	u8 roch_num;
+	#endif
+	u8 mgmt_tx_num;
+#endif
+
+	u8 union_ch;
+	u8 union_bw;
+	u8 union_offset;
+};
+
+#define MSTATE_STA_NUM(_mstate)			((_mstate)->sta_num)
+#define MSTATE_STA_LD_NUM(_mstate)		((_mstate)->ld_sta_num)
+#define MSTATE_STA_LG_NUM(_mstate)		((_mstate)->lg_sta_num)
+
+#ifdef CONFIG_TDLS
+#define MSTATE_TDLS_LD_NUM(_mstate)		((_mstate)->ld_tdls_num)
+#else
+#define MSTATE_TDLS_LD_NUM(_mstate)		0
+#endif
+
+#ifdef CONFIG_AP_MODE
+#define MSTATE_AP_NUM(_mstate)			((_mstate)->ap_num)
+#define MSTATE_AP_STARTING_NUM(_mstate)	((_mstate)->starting_ap_num)
+#define MSTATE_AP_LD_NUM(_mstate)		((_mstate)->ld_ap_num)
+#else
+#define MSTATE_AP_NUM(_mstate)			0
+#define MSTATE_AP_STARTING_NUM(_mstate) 0
+#define MSTATE_AP_LD_NUM(_mstate)		0
+#endif
+
+#define MSTATE_ADHOC_NUM(_mstate)		((_mstate)->adhoc_num)
+#define MSTATE_ADHOC_LD_NUM(_mstate)	((_mstate)->ld_adhoc_num)
+
+#ifdef CONFIG_RTW_MESH
+#define MSTATE_MESH_NUM(_mstate)		((_mstate)->mesh_num)
+#define MSTATE_MESH_LD_NUM(_mstate)		((_mstate)->ld_mesh_num)
+#else
+#define MSTATE_MESH_NUM(_mstate)		0
+#define MSTATE_MESH_LD_NUM(_mstate)		0
+#endif
+
+#define MSTATE_SCAN_NUM(_mstate)		((_mstate)->scan_num)
+#define MSTATE_SCAN_ENTER_NUM(_mstate)	((_mstate)->scan_enter_num)
+#define MSTATE_WPS_NUM(_mstate)			((_mstate)->uwps_num)
+
+#if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_P2P)
+#define MSTATE_ROCH_NUM(_mstate)		((_mstate)->roch_num)
+#else
+#define MSTATE_ROCH_NUM(_mstate)		0
+#endif
+
+#if defined(CONFIG_IOCTL_CFG80211)
+#define MSTATE_MGMT_TX_NUM(_mstate)		((_mstate)->mgmt_tx_num)
+#else
+#define MSTATE_MGMT_TX_NUM(_mstate)		0
+#endif
+
+#define MSTATE_U_CH(_mstate)			((_mstate)->union_ch)
+#define MSTATE_U_BW(_mstate)			((_mstate)->union_bw)
+#define MSTATE_U_OFFSET(_mstate)		((_mstate)->union_offset)
+
+#define rtw_mi_get_union_chan(adapter)	adapter_to_dvobj(adapter)->iface_state.union_ch
+#define rtw_mi_get_union_bw(adapter)		adapter_to_dvobj(adapter)->iface_state.union_bw
+#define rtw_mi_get_union_offset(adapter)	adapter_to_dvobj(adapter)->iface_state.union_offset
+
+#define rtw_mi_get_assoced_sta_num(adapter)	DEV_STA_LD_NUM(adapter_to_dvobj(adapter))
+#define rtw_mi_get_ap_num(adapter)			DEV_AP_NUM(adapter_to_dvobj(adapter))
+#define rtw_mi_get_mesh_num(adapter)		DEV_MESH_NUM(adapter_to_dvobj(adapter))
+
+/* For now, not return union_ch/bw/offset */
+void rtw_mi_status(_adapter *adapter, struct mi_state *mstate);
+void rtw_mi_status_no_self(_adapter *adapter, struct mi_state *mstate);
+void rtw_mi_status_no_others(_adapter *adapter, struct mi_state *mstate);
+
+/* For now, not handle union_ch/bw/offset */
+void rtw_mi_status_merge(struct mi_state *d, struct mi_state *a);
+
+void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state);
+
+u8 rtw_mi_netif_stop_queue(_adapter *padapter);
+u8 rtw_mi_buddy_netif_stop_queue(_adapter *padapter);
+
+u8 rtw_mi_netif_wake_queue(_adapter *padapter);
+u8 rtw_mi_buddy_netif_wake_queue(_adapter *padapter);
+
+u8 rtw_mi_netif_carrier_on(_adapter *padapter);
+u8 rtw_mi_buddy_netif_carrier_on(_adapter *padapter);
+u8 rtw_mi_netif_carrier_off(_adapter *padapter);
+u8 rtw_mi_buddy_netif_carrier_off(_adapter *padapter);
+
+u8 rtw_mi_netif_caroff_qstop(_adapter *padapter);
+u8 rtw_mi_buddy_netif_caroff_qstop(_adapter *padapter);
+u8 rtw_mi_netif_caron_qstart(_adapter *padapter);
+u8 rtw_mi_buddy_netif_caron_qstart(_adapter *padapter);
+
+void rtw_mi_scan_abort(_adapter *adapter, bool bwait);
+void rtw_mi_buddy_scan_abort(_adapter *adapter, bool bwait);
+u32 rtw_mi_start_drv_threads(_adapter *adapter);
+u32 rtw_mi_buddy_start_drv_threads(_adapter *adapter);
+void rtw_mi_stop_drv_threads(_adapter *adapter);
+void rtw_mi_buddy_stop_drv_threads(_adapter *adapter);
+void rtw_mi_cancel_all_timer(_adapter *adapter);
+void rtw_mi_buddy_cancel_all_timer(_adapter *adapter);
+void rtw_mi_reset_drv_sw(_adapter *adapter);
+void rtw_mi_buddy_reset_drv_sw(_adapter *adapter);
+
+extern void rtw_intf_start(_adapter *adapter);
+extern void rtw_intf_stop(_adapter *adapter);
+void rtw_mi_intf_start(_adapter *adapter);
+void rtw_mi_buddy_intf_start(_adapter *adapter);
+void rtw_mi_intf_stop(_adapter *adapter);
+void rtw_mi_buddy_intf_stop(_adapter *adapter);
+
+void rtw_mi_suspend_free_assoc_resource(_adapter *adapter);
+void rtw_mi_buddy_suspend_free_assoc_resource(_adapter *adapter);
+
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
+void rtw_mi_set_scan_deny(_adapter *adapter, u32 ms);
+void rtw_mi_buddy_set_scan_deny(_adapter *adapter, u32 ms);
+#else
+#define rtw_mi_set_scan_deny(adapter, ms) do {} while (0)
+#define rtw_mi_buddy_set_scan_deny(adapter, ms) do {} while (0)
+#endif
+
+u8 rtw_mi_is_scan_deny(_adapter *adapter);
+u8 rtw_mi_buddy_is_scan_deny(_adapter *adapter);
+
+void rtw_mi_beacon_update(_adapter *padapter);
+void rtw_mi_buddy_beacon_update(_adapter *padapter);
+
+void rtw_mi_hal_dump_macaddr(_adapter *padapter);
+void rtw_mi_buddy_hal_dump_macaddr(_adapter *padapter);
+
+#ifdef CONFIG_PCI_HCI
+void rtw_mi_xmit_tasklet_schedule(_adapter *padapter);
+void rtw_mi_buddy_xmit_tasklet_schedule(_adapter *padapter);
+#endif
+
+u8 rtw_mi_busy_traffic_check(_adapter *padapter, bool check_sc_interval);
+u8 rtw_mi_buddy_busy_traffic_check(_adapter *padapter, bool check_sc_interval);
+
+u8 rtw_mi_check_mlmeinfo_state(_adapter *padapter, u32 state);
+u8 rtw_mi_buddy_check_mlmeinfo_state(_adapter *padapter, u32 state);
+
+u8 rtw_mi_check_fwstate(_adapter *padapter, sint state);
+u8 rtw_mi_buddy_check_fwstate(_adapter *padapter, sint state);
+enum {
+	MI_LINKED,
+	MI_ASSOC,
+	MI_UNDER_WPS,
+	MI_AP_MODE,
+	MI_AP_ASSOC,
+	MI_ADHOC,
+	MI_ADHOC_ASSOC,
+	MI_MESH,
+	MI_MESH_ASSOC,
+	MI_STA_NOLINK, /* this is misleading, but not used now */
+	MI_STA_LINKED,
+	MI_STA_LINKING,
+};
+u8 rtw_mi_check_status(_adapter *adapter, u8 type);
+
+void dump_dvobj_mi_status(void *sel, const char *fun_name, _adapter *adapter);
+#ifdef DBG_IFACE_STATUS
+#define DBG_IFACE_STATUS_DUMP(adapter)	dump_dvobj_mi_status(RTW_DBGDUMP, __func__, adapter)
+#endif
+void dump_mi_status(void *sel, struct dvobj_priv *dvobj);
+
+u8 rtw_mi_traffic_statistics(_adapter *padapter);
+u8 rtw_mi_check_miracast_enabled(_adapter *padapter);
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+u8 rtw_mi_check_pending_xmitbuf(_adapter *padapter);
+u8 rtw_mi_buddy_check_pending_xmitbuf(_adapter *padapter);
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#ifdef CONFIG_RTL8822B
+	#include <rtl8822b_hal.h>
+#else
+	extern s32 _dequeue_writeport(PADAPTER padapter);
+#endif
+u8 rtw_mi_dequeue_writeport(_adapter *padapter);
+u8 rtw_mi_buddy_dequeue_writeport(_adapter *padapter);
+#endif
+
+void rtw_mi_adapter_reset(_adapter *padapter);
+void rtw_mi_buddy_adapter_reset(_adapter *padapter);
+
+u8 rtw_mi_dynamic_check_timer_handlder(_adapter *padapter);
+u8 rtw_mi_buddy_dynamic_check_timer_handlder(_adapter *padapter);
+
+u8 rtw_mi_dev_unload(_adapter *padapter);
+u8 rtw_mi_buddy_dev_unload(_adapter *padapter);
+
+extern void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter);
+u8 rtw_mi_dynamic_chk_wk_hdl(_adapter *padapter);
+u8 rtw_mi_buddy_dynamic_chk_wk_hdl(_adapter *padapter);
+
+u8 rtw_mi_os_xmit_schedule(_adapter *padapter);
+u8 rtw_mi_buddy_os_xmit_schedule(_adapter *padapter);
+
+u8 rtw_mi_report_survey_event(_adapter *padapter, union recv_frame *precv_frame);
+u8 rtw_mi_buddy_report_survey_event(_adapter *padapter, union recv_frame *precv_frame);
+
+extern void sreset_start_adapter(_adapter *padapter);
+extern void sreset_stop_adapter(_adapter *padapter);
+u8 rtw_mi_sreset_adapter_hdl(_adapter *padapter, u8 bstart);
+u8 rtw_mi_buddy_sreset_adapter_hdl(_adapter *padapter, u8 bstart);
+
+u8 rtw_mi_tx_beacon_hdl(_adapter *padapter);
+u8 rtw_mi_buddy_tx_beacon_hdl(_adapter *padapter);
+
+u8 rtw_mi_set_tx_beacon_cmd(_adapter *padapter);
+u8 rtw_mi_buddy_set_tx_beacon_cmd(_adapter *padapter);
+
+#ifdef CONFIG_P2P
+u8 rtw_mi_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state);
+u8 rtw_mi_buddy_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state);
+u8 rtw_mi_stay_in_p2p_mode(_adapter *padapter);
+u8 rtw_mi_buddy_stay_in_p2p_mode(_adapter *padapter);
+#endif
+
+_adapter *rtw_get_iface_by_id(_adapter *padapter, u8 iface_id);
+_adapter *rtw_get_iface_by_macddr(_adapter *padapter, u8 *mac_addr);
+_adapter *rtw_get_iface_by_hwport(_adapter *padapter, u8 hw_port);
+
+void rtw_mi_buddy_clone_bcmc_packet(_adapter *padapter, union recv_frame *precvframe, u8 *pphy_status);
+
+#ifdef CONFIG_PCI_HCI
+/*API be create temporary for MI, caller is interrupt-handler, PCIE's interrupt handler cannot apply to multi-AP*/
+_adapter *rtw_mi_get_ap_adapter(_adapter *padapter);
+#endif
+
+void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b);
+
+#endif /*__RTW_MI_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mlme.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mlme.h
new file mode 100644
index 000000000000..114a3ec499ba
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mlme.h
@@ -0,0 +1,1361 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#define	MAX_BSS_CNT	128
+/* #define   MAX_JOIN_TIMEOUT	2000 */
+/* #define   MAX_JOIN_TIMEOUT	2500 */
+#define   MAX_JOIN_TIMEOUT	6500
+
+/*	Commented by Albert 20101105
+ *	Increase the scanning timeout because of increasing the SURVEY_TO value. */
+
+
+#ifdef PALTFORM_OS_WINCE
+#define	SCANQUEUE_LIFETIME 12000000 /* unit:us */
+#else
+#define	SCANQUEUE_LIFETIME 20000 /* 20sec, unit:msec */
+#endif
+
+#define WIFI_NULL_STATE					0x00000000
+#define WIFI_ASOC_STATE					0x00000001 /* Linked */
+#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_MESH_STATE					0x00000200
+#define WIFI_STA_ALIVE_CHK_STATE		0x00000400
+#define WIFI_SITE_MONITOR				0x00000800 /* under site surveying */
+#define WIFI_WDS						0x00001000
+#define WIFI_WDS_RX_BEACON				0x00002000 /* already rx WDS AP beacon */
+#define WIFI_AUTOCONF					0x00004000
+#define WIFI_AUTOCONF_IND				0x00008000
+#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 WIFI_OP_CH_SWITCHING			0x00800000
+/*#define WIFI_UNDEFINED_STATE			0x01000000*/
+/*#define WIFI_UNDEFINED_STATE			0x02000000*/
+/*#define WIFI_UNDEFINED_STATE			0x04000000*/
+/*#define WIFI_UNDEFINED_STATE			0x08000000*/
+/*#define WIFI_UNDEFINED_STATE			0x10000000*/
+/*#define WIFI_UNDEFINED_STATE			0x20000000*/
+/*#define WIFI_UNDEFINED_STATE			0x40000000*/
+#define WIFI_MONITOR_STATE				0x80000000
+
+#define MIRACAST_DISABLED	0
+#define MIRACAST_SOURCE		BIT0
+#define MIRACAST_SINK		BIT1
+
+#define MIRACAST_MODE_REVERSE(mode) \
+	((((mode) & MIRACAST_SOURCE) ? MIRACAST_SINK : 0) | (((mode) & MIRACAST_SINK) ? MIRACAST_SOURCE : 0))
+
+bool is_miracast_enabled(_adapter *adapter);
+bool rtw_chk_miracast_mode(_adapter *adapter, u8 mode);
+const char *get_miracast_mode_str(int mode);
+void rtw_wfd_st_switch(struct sta_info *sta, bool on);
+
+#define MLME_STATE(adapter) get_fwstate(&((adapter)->mlmepriv))
+#define CHK_MLME_STATE(adapter, state) check_fwstate(&((adapter)->mlmepriv), (state))
+
+#define MLME_IS_NULL(adapter) CHK_MLME_STATE(adapter, WIFI_NULL_STATE)
+#define MLME_IS_STA(adapter) CHK_MLME_STATE(adapter, WIFI_STATION_STATE)
+#define MLME_IS_AP(adapter) CHK_MLME_STATE(adapter, WIFI_AP_STATE)
+#define MLME_IS_ADHOC(adapter) CHK_MLME_STATE(adapter, WIFI_ADHOC_STATE)
+#define MLME_IS_ADHOC_MASTER(adapter) CHK_MLME_STATE(adapter, WIFI_ADHOC_MASTER_STATE)
+#define MLME_IS_MESH(adapter) CHK_MLME_STATE(adapter, WIFI_MESH_STATE)
+#define MLME_IS_MONITOR(adapter) CHK_MLME_STATE(adapter, WIFI_MONITOR_STATE)
+#define MLME_IS_MP(adapter) CHK_MLME_STATE(adapter, WIFI_MP_STATE)
+#ifdef CONFIG_P2P
+	#define MLME_IS_PD(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_DEVICE)
+	#define MLME_IS_GC(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_CLIENT)
+	#define MLME_IS_GO(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_GO)
+#else /* !CONFIG_P2P */
+	#define MLME_IS_PD(adapter) 0
+	#define MLME_IS_GC(adapter) 0
+	#define MLME_IS_GO(adapter) 0
+#endif /* !CONFIG_P2P */
+
+#define MLME_IS_MSRC(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SOURCE)
+#define MLME_IS_MSINK(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SINK)
+
+#define MLME_IS_SCAN(adapter) CHK_MLME_STATE(adapter, WIFI_SITE_MONITOR)
+#define MLME_IS_LINKING(adapter) CHK_MLME_STATE(adapter, WIFI_UNDER_LINKING)
+#define MLME_IS_ASOC(adapter) CHK_MLME_STATE(adapter, WIFI_ASOC_STATE)
+#define MLME_IS_OPCH_SW(adapter) CHK_MLME_STATE(adapter, WIFI_OP_CH_SWITCHING)
+#define MLME_IS_WPS(adapter) CHK_MLME_STATE(adapter, WIFI_UNDER_WPS)
+
+#if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_P2P)
+#define MLME_IS_ROCH(adapter) (rtw_cfg80211_get_is_roch(adapter) == _TRUE)
+#else
+#define MLME_IS_ROCH(adapter) 0
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+#define MLME_IS_MGMT_TX(adapter) rtw_cfg80211_get_is_mgmt_tx(adapter)
+#else
+#define MLME_IS_MGMT_TX(adapter) 0
+#endif
+
+#define MLME_STATE_FMT "%s%s%s%s%s%s%s%s%s%s%s%s"
+#define MLME_STATE_ARG(adapter) \
+	MLME_IS_STA((adapter)) ? (MLME_IS_GC((adapter)) ? " GC" : " STA") : \
+	MLME_IS_AP((adapter)) ? (MLME_IS_GO((adapter)) ? " GO" : " AP") : \
+	MLME_IS_ADHOC((adapter)) ? " ADHOC" : \
+	MLME_IS_ADHOC_MASTER((adapter)) ? " ADHOC_M" : \
+	MLME_IS_MESH((adapter)) ? " MESH" : \
+	MLME_IS_MONITOR((adapter)) ? " MONITOR" : \
+	MLME_IS_MP((adapter)) ? " MP" : "", \
+	MLME_IS_PD((adapter)) ? " PD" : "", \
+	MLME_IS_MSRC((adapter)) ? " MSRC" : "", \
+	MLME_IS_MSINK((adapter)) ? " MSINK" : "", \
+	MLME_IS_SCAN((adapter)) ? " SCAN" : "", \
+	MLME_IS_LINKING((adapter)) ? " LINKING" : "", \
+	MLME_IS_ASOC((adapter)) ? " ASOC" : "", \
+	MLME_IS_OPCH_SW((adapter)) ? " OPCH_SW" : "", \
+	MLME_IS_WPS((adapter)) ? " WPS" : "", \
+	MLME_IS_ROCH((adapter)) ? " ROCH" : "", \
+	MLME_IS_MGMT_TX((adapter)) ? " MGMT_TX" : "", \
+	(MLME_STATE((adapter)) & WIFI_SLEEP_STATE) ? " SLEEP" : ""
+
+enum {
+	MLME_ACTION_UNKNOWN,
+	MLME_ACTION_NONE,
+	MLME_SCAN_ENABLE, /* WIFI_SITE_MONITOR */
+	MLME_SCAN_ENTER, /* WIFI_SITE_MONITOR && !SCAN_DISABLE && !SCAN_BACK_OP */
+	MLME_SCAN_DONE, /*  WIFI_SITE_MONITOR && (SCAN_DISABLE || SCAN_BACK_OP) */
+	MLME_SCAN_DISABLE, /* WIFI_SITE_MONITOR is going to be cleared */
+	MLME_STA_CONNECTING,
+	MLME_STA_CONNECTED,
+	MLME_STA_DISCONNECTED,
+	MLME_TDLS_LINKED,
+	MLME_TDLS_NOLINK,
+	MLME_AP_STARTED,
+	MLME_AP_STOPPED,
+	MLME_ADHOC_STARTED,
+	MLME_ADHOC_STOPPED,
+	MLME_MESH_STARTED,
+	MLME_MESH_STOPPED,
+};
+
+#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_WAPI,
+	dot11AuthAlgrthm_MaxNum
+};
+
+/* Scan type including active and passive scan. */
+typedef enum _RT_SCAN_TYPE {
+	SCAN_PASSIVE,
+	SCAN_ACTIVE,
+	SCAN_MIX,
+} RT_SCAN_TYPE, *PRT_SCAN_TYPE;
+
+#define WIFI_FREQUENCY_BAND_AUTO 0
+#define WIFI_FREQUENCY_BAND_5GHZ 1
+#define WIFI_FREQUENCY_BAND_2GHZ 2
+
+#define rtw_band_valid(band) ((band) <= WIFI_FREQUENCY_BAND_2GHZ)
+
+enum DriverInterface {
+	DRIVER_WEXT =  1,
+	DRIVER_CFG80211 = 2
+};
+
+enum SCAN_RESULT_TYPE {
+	SCAN_RESULT_P2P_ONLY = 0,		/*	Will return all the P2P devices. */
+	SCAN_RESULT_ALL = 1,			/*	Will return all the scanned device, include AP. */
+	SCAN_RESULT_WFD_TYPE = 2		/*	Will just return the correct WFD device. */
+									/*	If this device is Miracast sink device, it will just return all the Miracast source devices. */
+};
+
+/*
+
+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!
+
+*/
+
+
+#define traffic_threshold	10
+#define	traffic_scan_period	500
+
+typedef struct _RT_LINK_DETECT_T {
+	u32				NumTxOkInPeriod;
+	u32				NumRxOkInPeriod;
+	u32				NumRxUnicastOkInPeriod;
+	BOOLEAN			bBusyTraffic;
+	BOOLEAN			bTxBusyTraffic;
+	BOOLEAN			bRxBusyTraffic;
+	BOOLEAN			bHigherBusyTraffic; /* For interrupt migration purpose. */
+	BOOLEAN			bHigherBusyRxTraffic; /* We may disable Tx interrupt according as Rx traffic. */
+	BOOLEAN			bHigherBusyTxTraffic; /* We may disable Tx interrupt according as Tx traffic. */
+	/* u8 TrafficBusyState; */
+	u8 TrafficTransitionCount;
+	u32 LowPowerTransitionCount;
+} RT_LINK_DETECT_T, *PRT_LINK_DETECT_T;
+
+struct profile_info {
+	u8	ssidlen;
+	u8	ssid[WLAN_SSID_MAXLEN];
+	u8	peermac[ETH_ALEN];
+};
+
+struct tx_invite_req_info {
+	u8					token;
+	u8					benable;
+	u8					go_ssid[WLAN_SSID_MAXLEN];
+	u8					ssidlen;
+	u8					go_bssid[ETH_ALEN];
+	u8					peer_macaddr[ETH_ALEN];
+	u8					operating_ch;	/*	This information will be set by using the p2p_set op_ch=x */
+	u8					peer_ch;		/*	The listen channel for peer P2P device */
+
+};
+
+struct tx_invite_resp_info {
+	u8					token;	/*	Used to record the dialog token of p2p invitation request frame. */
+};
+
+#ifdef CONFIG_WFD
+
+struct wifi_display_info {
+	u16							wfd_enable;			/*	Eanble/Disable the WFD function. */
+	u16							init_rtsp_ctrlport;	/* init value of rtsp_ctrlport when WFD enable */
+	u16							rtsp_ctrlport;		/* TCP port number at which the this WFD device listens for RTSP messages, 0 when WFD disable */
+	u16							tdls_rtsp_ctrlport;	/* rtsp_ctrlport used by tdls, will sync when rtsp_ctrlport is changed by user */
+	u16							peer_rtsp_ctrlport;	/*	TCP port number at which the peer WFD device listens for RTSP messages */
+													/*	This filed should be filled when receiving the gropu negotiation request */
+
+	u8							peer_session_avail;	/*	WFD session is available or not for the peer wfd device. */
+													/*	This variable will be set when sending the provisioning discovery request to peer WFD device. */
+													/*	And this variable will be reset when it is read by using the iwpriv p2p_get wfd_sa command. */
+	u8							ip_address[4];
+	u8							peer_ip_address[4];
+	u8							wfd_pc;				/*	WFD preferred connection */
+													/*	0 -> Prefer to use the P2P for WFD connection on peer side. */
+													/*	1 -> Prefer to use the TDLS for WFD connection on peer side. */
+
+	u8							wfd_device_type;	/*	WFD Device Type */
+													/*	0 -> WFD Source Device */
+													/*	1 -> WFD Primary Sink Device */
+	enum	SCAN_RESULT_TYPE	scan_result_type;	/*	Used when P2P is enable. This parameter will impact the scan result. */
+	u8 op_wfd_mode;
+	u8 stack_wfd_mode;
+};
+#endif /* CONFIG_WFD */
+
+struct tx_provdisc_req_info {
+	u16					wps_config_method_request;	/*	Used when sending the provisioning request frame */
+	u16					peer_channel_num[2];		/*	The channel number which the receiver stands. */
+	NDIS_802_11_SSID	ssid;
+	u8					peerDevAddr[ETH_ALEN];		/*	Peer device address */
+	u8					peerIFAddr[ETH_ALEN];		/*	Peer interface address */
+	u8					benable;					/*	This provision discovery request frame is trigger to send or not */
+};
+
+struct rx_provdisc_req_info {	/* When peer device issue prov_disc_req first, we should store the following informations */
+	u8					peerDevAddr[ETH_ALEN];		/*	Peer device address */
+	u8					strconfig_method_desc_of_prov_disc_req[4];	/*	description for the config method located in the provisioning discovery request frame.	 */
+																	/*	The UI must know this information to know which config method the remote p2p device is requiring. */
+};
+
+struct tx_nego_req_info {
+	u16					peer_channel_num[2];		/*	The channel number which the receiver stands. */
+	u8					peerDevAddr[ETH_ALEN];		/*	Peer device address */
+	u8					benable;					/*	This negoitation request frame is trigger to send or not */
+	u8					peer_ch;					/*	The listen channel for peer P2P device */
+};
+
+struct group_id_info {
+	u8					go_device_addr[ETH_ALEN];	/*	The GO's device address of this P2P group */
+	u8					ssid[WLAN_SSID_MAXLEN];		/*	The SSID of this P2P group */
+};
+
+struct scan_limit_info {
+	u8					scan_op_ch_only;			/*	When this flag is set, the driver should just scan the operation channel */
+#ifndef CONFIG_P2P_OP_CHK_SOCIAL_CH
+	u8					operation_ch[2];				/*	Store the operation channel of invitation request frame */
+#else
+	u8					operation_ch[5];				/*	Store additional channel 1,6,11  for Android 4.2 IOT & Nexus 4 */
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
+};
+
+#ifdef CONFIG_IOCTL_CFG80211
+struct cfg80211_wifidirect_info {
+	_timer					remain_on_ch_timer;
+	u8						restore_channel;
+	struct ieee80211_channel	remain_on_ch_channel;
+	enum nl80211_channel_type	remain_on_ch_type;
+	ATOMIC_T ro_ch_cookie_gen;
+	u64 remain_on_ch_cookie;
+	bool is_ro_ch;
+	struct wireless_dev *ro_ch_wdev;
+	systime last_ro_ch_time; /* this will be updated at the beginning and end of ro_ch */
+};
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+#ifdef CONFIG_P2P_WOWLAN
+
+enum P2P_WOWLAN_RECV_FRAME_TYPE {
+	P2P_WOWLAN_RECV_NEGO_REQ = 0,
+	P2P_WOWLAN_RECV_INVITE_REQ = 1,
+	P2P_WOWLAN_RECV_PROVISION_REQ = 2,
+};
+
+struct p2p_wowlan_info {
+
+	u8						is_trigger;
+	enum P2P_WOWLAN_RECV_FRAME_TYPE	wowlan_recv_frame_type;
+	u8						wowlan_peer_addr[ETH_ALEN];
+	u16						wowlan_peer_wpsconfig;
+	u8						wowlan_peer_is_persistent;
+	u8						wowlan_peer_invitation_type;
+};
+
+#endif /* CONFIG_P2P_WOWLAN */
+
+struct wifidirect_info {
+	_adapter				*padapter;
+	_timer					find_phase_timer;
+	_timer					restore_p2p_state_timer;
+
+	/*	Used to do the scanning. After confirming the peer is availalble, the driver transmits the P2P frame to peer. */
+	_timer					pre_tx_scan_timer;
+	_timer					reset_ch_sitesurvey;
+	_timer					reset_ch_sitesurvey2;	/*	Just for resetting the scan limit function by using p2p nego */
+#ifdef CONFIG_CONCURRENT_MODE
+	/*	Used to switch the channel between legacy AP and listen state. */
+	_timer					ap_p2p_switch_timer;
+#endif
+	struct tx_provdisc_req_info	tx_prov_disc_info;
+	struct rx_provdisc_req_info rx_prov_disc_info;
+	struct tx_invite_req_info	invitereq_info;
+	struct profile_info			profileinfo[P2P_MAX_PERSISTENT_GROUP_NUM];	/*	Store the profile information of persistent group */
+	struct tx_invite_resp_info	inviteresp_info;
+	struct tx_nego_req_info	nego_req_info;
+	struct group_id_info		groupid_info;	/*	Store the group id information when doing the group negotiation handshake. */
+	struct scan_limit_info		rx_invitereq_info;	/*	Used for get the limit scan channel from the Invitation procedure */
+	struct scan_limit_info		p2p_info;		/*	Used for get the limit scan channel from the P2P negotiation handshake */
+#ifdef CONFIG_WFD
+	struct wifi_display_info		*wfd_info;
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+	struct p2p_wowlan_info		p2p_wow_info;
+#endif /* CONFIG_P2P_WOWLAN */
+
+	enum P2P_ROLE			role;
+	enum P2P_STATE			pre_p2p_state;
+	enum P2P_STATE			p2p_state;
+	u8						device_addr[ETH_ALEN];	/*	The device address should be the mac address of this device. */
+	u8						interface_addr[ETH_ALEN];
+	u8						social_chan[4];
+	u8						listen_channel;
+	u8						operating_channel;
+	u8						listen_dwell;		/*	This value should be between 1 and 3 */
+	u8						support_rate[8];
+	u8						p2p_wildcard_ssid[P2P_WILDCARD_SSID_LEN];
+	u8						intent;		/*	should only include the intent value. */
+	u8						p2p_peer_interface_addr[ETH_ALEN];
+	u8						p2p_peer_device_addr[ETH_ALEN];
+	u8						peer_intent;	/*	Included the intent value and tie breaker value. */
+	u8						device_name[WPS_MAX_DEVICE_NAME_LEN];	/*	Device name for displaying on searching device screen */
+	u16						device_name_len;
+	u8						profileindex;	/*	Used to point to the index of profileinfo array */
+	u8						peer_operating_ch;
+	u8						find_phase_state_exchange_cnt;
+	u16						device_password_id_for_nego;	/*	The device password ID for group negotation */
+	u8						negotiation_dialog_token;
+	u8						nego_ssid[WLAN_SSID_MAXLEN];	/*	SSID information for group negotitation */
+	u8						nego_ssidlen;
+	u8						p2p_group_ssid[WLAN_SSID_MAXLEN];
+	u8						p2p_group_ssid_len;
+	u8						persistent_supported;		/*	Flag to know the persistent function should be supported or not. */
+														/*	In the Sigma test, the Sigma will provide this enable from the sta_set_p2p CAPI. */
+														/*	0: disable */
+														/*	1: enable */
+	u8						session_available;			/*	Flag to set the WFD session available to enable or disable "by Sigma" */
+														/*	In the Sigma test, the Sigma will disable the session available by using the sta_preset CAPI. */
+														/*	0: disable */
+														/*	1: enable */
+
+	u8						wfd_tdls_enable;			/*	Flag to enable or disable the TDLS by WFD Sigma */
+														/*	0: disable */
+														/*	1: enable */
+	u8						wfd_tdls_weaksec;			/*	Flag to enable or disable the weak security function for TDLS by WFD Sigma */
+														/*	0: disable */
+														/*	In this case, the driver can't issue the tdsl setup request frame. */
+														/*	1: enable */
+														/*	In this case, the driver can issue the tdls setup request frame */
+														/*	even the current security is weak security. */
+
+	enum	P2P_WPSINFO		ui_got_wps_info;			/*	This field will store the WPS value (PIN value or PBC) that UI had got from the user. */
+	u16						supported_wps_cm;			/*	This field describes the WPS config method which this driver supported. */
+														/*	The value should be the combination of config method defined in page104 of WPS v2.0 spec.	 */
+	u8						external_uuid;				/* UUID flag */
+	u8						uuid[16];					/* UUID */
+	uint						channel_list_attr_len;	/*	This field will contain the length of body of P2P Channel List attribute of group negotitation response frame. */
+	u8						channel_list_attr[100];		/*	This field will contain the body of P2P Channel List attribute of group negotitation response frame. */
+														/*	We will use the channel_cnt and channel_list fields when constructing the group negotitation confirm frame. */
+	u8						driver_interface;			/*	Indicate DRIVER_WEXT or DRIVER_CFG80211 */
+
+#ifdef CONFIG_CONCURRENT_MODE
+	u16						ext_listen_interval;	/*	The interval to be available with legacy AP (ms) */
+	u16						ext_listen_period;	/*	The time period to be available for P2P listen state (ms) */
+#endif
+#ifdef CONFIG_P2P_PS
+	enum P2P_PS_MODE		p2p_ps_mode; /* indicate p2p ps mode */
+	enum P2P_PS_STATE		p2p_ps_state; /* indicate p2p ps state */
+	u8						noa_index; /* Identifies and instance of Notice of Absence timing. */
+	u8						ctwindow; /* Client traffic window. A period of time in TU after TBTT. */
+	u8						opp_ps; /* opportunistic power save. */
+	u8						noa_num; /* number of NoA descriptor in P2P IE. */
+	u8						noa_count[P2P_MAX_NOA_NUM]; /* Count for owner, Type of client. */
+	u32						noa_duration[P2P_MAX_NOA_NUM]; /* Max duration for owner, preferred or min acceptable duration for client. */
+	u32						noa_interval[P2P_MAX_NOA_NUM]; /* Length of interval for owner, preferred or max acceptable interval of client. */
+	u32						noa_start_time[P2P_MAX_NOA_NUM]; /* schedule expressed in terms of the lower 4 bytes of the TSF timer. */
+#endif /* CONFIG_P2P_PS */
+};
+
+struct tdls_ss_record {	/* signal strength record */
+	u8		macaddr[ETH_ALEN];
+	u8		RxPWDBAll;
+	u8		is_tdls_sta;	/* _TRUE: direct link sta, _FALSE: else */
+};
+
+struct tdls_temp_mgmt {
+	u8	initiator;	/* 0: None, 1: we initiate, 2: peer initiate */
+	u8	peer_addr[ETH_ALEN];
+};
+
+#ifdef CONFIG_TDLS_CH_SW
+struct tdls_ch_switch {
+	u32	ch_sw_state;
+	ATOMIC_T	chsw_on;
+	u8	addr[ETH_ALEN];
+	u8	off_ch_num;
+	u8	ch_offset;
+	u32	cur_time;
+	u8	delay_switch_back;
+	u8	dump_stack;
+	struct submit_ctx	chsw_sctx;
+};
+#endif
+
+struct tdls_info {
+	u8					ap_prohibited;
+	u8					ch_switch_prohibited;
+	u8					link_established;
+	u8					sta_cnt;
+	u8					sta_maximum;	/* 1:tdls sta is equal (NUM_STA-1), reach max direct link number; 0: else; */
+	struct tdls_ss_record	ss_record;
+#ifdef CONFIG_TDLS_CH_SW
+	struct tdls_ch_switch	chsw_info;
+#endif
+
+	u8					ch_sensing;
+	u8					cur_channel;
+	u8					collect_pkt_num[MAX_CHANNEL_NUM];
+	_lock				cmd_lock;
+	_lock				hdl_lock;
+	u8					watchdog_count;
+	u8					dev_discovered;		/* WFD_TDLS: for sigma test */
+
+	/* Let wpa_supplicant to setup*/
+	u8					driver_setup;
+#ifdef CONFIG_WFD
+	struct wifi_display_info		*wfd_info;
+#endif
+
+	struct submit_ctx	*tdls_sctx;
+};
+
+struct tdls_txmgmt {
+	u8 peer[ETH_ALEN];
+	u8 action_code;
+	u8 dialog_token;
+	u16 status_code;
+	u8 *buf;
+	size_t len;
+};
+
+/* used for mlme_priv.roam_flags */
+enum {
+	RTW_ROAM_ON_EXPIRED = BIT0,
+	RTW_ROAM_ON_RESUME = BIT1,
+	RTW_ROAM_ACTIVE = BIT2,
+};
+
+struct beacon_keys {
+	u8 ssid[IW_ESSID_MAX_SIZE];
+	u32 ssid_len;
+	u8 bcn_channel;
+	u16 ht_cap_info;
+	u8 ht_info_infos_0_sco; /* bit0 & bit1 in infos[0] is second channel offset */
+	int encryp_protocol;
+	int pairwise_cipher;
+	int group_cipher;
+	int is_8021x;
+};
+#ifdef CONFIG_RTW_80211R
+#define RTW_FT_ACTION_REQ_LMT	4
+#define RTW_FT_MAX_IE_SZ	256
+
+enum _rtw_ft_sta_status {
+	RTW_FT_UNASSOCIATED_STA = 0,
+	RTW_FT_AUTHENTICATING_STA,
+	RTW_FT_AUTHENTICATED_STA,
+	RTW_FT_ASSOCIATING_STA,
+	RTW_FT_ASSOCIATED_STA,
+	RTW_FT_REQUESTING_STA,
+	RTW_FT_REQUESTED_STA,
+	RTW_FT_CONFIRMED_STA,
+	RTW_FT_UNSPECIFIED_STA
+};
+
+#define rtw_ft_chk_status(a, s) \
+	((a)->mlmepriv.ft_roam.ft_status == (s))
+
+#define rtw_ft_roam_status(a, s)	\
+	((rtw_to_roam(a) > 0) && rtw_ft_chk_status(a, s))
+
+#define rtw_ft_authed_sta(a)	\
+	((rtw_ft_chk_status(a, RTW_FT_AUTHENTICATED_STA)) ||	\
+	(rtw_ft_chk_status(a, RTW_FT_ASSOCIATING_STA)) ||	\
+	(rtw_ft_chk_status(a, RTW_FT_ASSOCIATED_STA)))
+
+#define rtw_ft_set_status(a, s) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_status = (s)); \
+	} while (0)
+
+#define rtw_ft_lock_set_status(a, s, irq) \
+	do { \
+		_enter_critical_bh(&(a)->mlmepriv.lock, ((_irqL *)(irq)));	\
+		((a)->mlmepriv.ft_roam.ft_status = (s));	\
+		_exit_critical_bh(&(a)->mlmepriv.lock, ((_irqL *)(irq)));	\
+	} while (0)
+
+#define rtw_ft_reset_status(a) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_status = RTW_FT_UNASSOCIATED_STA); \
+	} while (0)
+
+enum rtw_ft_capability {
+	RTW_FT_EN = BIT0,
+	RTW_FT_OTD_EN = BIT1,
+	RTW_FT_PEER_EN = BIT2,
+	RTW_FT_PEER_OTD_EN = BIT3,
+	RTW_FT_BTM_ROAM = BIT4,
+};
+
+#define rtw_ft_chk_flags(a, f) \
+	((a)->mlmepriv.ft_roam.ft_flags & (f))
+
+#define rtw_ft_set_flags(a, f) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_flags |= (f)); \
+	} while (0)
+
+#define rtw_ft_clr_flags(a, f) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_flags &= ~(f)); \
+	} while (0)
+
+#define rtw_ft_roam(a)	\
+	((rtw_to_roam(a) > 0) && rtw_ft_chk_flags(a, RTW_FT_PEER_EN))
+	
+#define rtw_ft_valid_akm(a, t)	\
+	((rtw_ft_chk_flags(a, RTW_FT_EN)) && \
+	(((t) == 3) || ((t) == 4)))
+
+#define rtw_ft_roam_expired(a, r)	\
+	((rtw_chk_roam_flags(a, RTW_ROAM_ON_EXPIRED)) \
+	&& (r == WLAN_REASON_ACTIVE_ROAM))
+
+#define rtw_ft_otd_roam_en(a)	\
+	((rtw_ft_chk_flags(a, RTW_FT_OTD_EN))	\
+	&& ((a)->mlmepriv.ft_roam.ft_roam_on_expired == _FALSE)	\
+	&& ((a)->mlmepriv.ft_roam.ft_cap & 0x01))
+	
+#define rtw_ft_otd_roam(a) \
+	rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN)
+
+#define rtw_ft_valid_otd_candidate(a, p)	\
+	((rtw_ft_chk_flags(a, RTW_FT_OTD_EN)) 	\
+	&& ((rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN)	\
+	&& ((*((p)+4) & 0x01) == 0))	\
+	|| ((rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN) == 0)	\
+	&& (*((p)+4) & 0x01))))
+
+struct ft_roam_info {
+	u16	mdid;
+	u8	ft_cap;	
+	/*b0: FT over DS, b1: Resource Req Protocol Cap, b2~b7: Reserved*/
+	u8	updated_ft_ies[RTW_FT_MAX_IE_SZ];
+	u16	updated_ft_ies_len;
+	u8	ft_action[RTW_FT_MAX_IE_SZ];
+	u16	ft_action_len;
+	struct cfg80211_ft_event_params ft_event;
+	u8	ft_roam_on_expired;
+	u8	ft_flags;
+	u32 ft_status;
+	u32 ft_req_retry_cnt;
+	bool ft_updated_bcn;	
+};
+#endif
+
+#ifdef CONFIG_LAYER2_ROAMING
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+#define RTW_RRM_NB_RPT_EN		BIT(1)
+#define RTW_MAX_NB_RPT_NUM	8
+
+#define rtw_roam_busy_scan(a, nb)	\
+	(((a)->mlmepriv.LinkDetectInfo.bBusyTraffic == _TRUE) && \
+	(((a)->mlmepriv.ch_cnt) < ((nb)->nb_rpt_ch_list_num)))
+
+#define rtw_wnm_btm_preference_cap(a) \
+	((a)->mlmepriv.nb_info.preference_en == _TRUE)
+
+#define rtw_wnm_btm_diff_bss(a) \
+	((rtw_wnm_btm_preference_cap(a)) && \
+	(is_zero_mac_addr((a)->mlmepriv.nb_info.roam_target_addr) == _FALSE) && \
+	(_rtw_memcmp((a)->mlmepriv.nb_info.roam_target_addr,\
+		(a)->mlmepriv.cur_network.network.MacAddress, ETH_ALEN) == _FALSE))
+
+#define rtw_wnm_btm_roam_candidate(a, c) \
+	((rtw_wnm_btm_preference_cap(a)) && \
+	(is_zero_mac_addr((a)->mlmepriv.nb_info.roam_target_addr) == _FALSE) && \
+	(_rtw_memcmp((a)->mlmepriv.nb_info.roam_target_addr,\
+		(c)->network.MacAddress, ETH_ALEN)))
+
+#define rtw_wnm_set_ext_cap_btm(_pEleStart, _val) \
+	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart))+2, 3, 1, _val)
+
+#define wnm_btm_bss_term_inc(p) (*((u8 *)((p)+3)) & BSS_TERMINATION_INCLUDED)
+
+#define wnm_btm_ess_disassoc_im(p) (*((u8 *)((p)+3)) & ESS_DISASSOC_IMMINENT)
+
+#define wnm_btm_req_mode(p) (*((u8 *)((p)+3)))
+
+#define wnm_btm_disassoc_timer(p) (*((u16 *)((p)+4)))
+
+#define wnm_btm_valid_interval(p) (*((u8 *)((p)+6)))
+
+#define wnm_btm_term_duration_offset(p) ((p)+7)
+
+/*IEEE Std 80211k Figure 7-95b Neighbor Report element format*/
+struct nb_rpt_hdr {
+	u8 id; /*0x34: Neighbor Report Element ID*/
+	u8 len;
+	u8 bssid[ETH_ALEN];
+	u32 bss_info;
+	u8 reg_class;
+	u8 ch_num;
+	u8 phy_type;	
+};
+
+/*IEEE Std 80211v, Figure 7-95e2—BSS Termination Duration subelement field format */
+struct btm_term_duration {
+	u8 id;
+	u8 len;
+	u64 tsf;
+	u16 duration;
+};
+
+/*IEEE Std 80211v, Figure 7-101n8—BSS Transition Management Request frame body format */
+struct btm_req_hdr {
+	u8 req_mode;
+	u16 disassoc_timer;
+	u8 validity_interval;
+	struct btm_term_duration term_duration;
+};
+
+/*IEEE Std 80211v,  Table 7-43b Optional Subelement IDs for Neighbor Report*/
+/* BSS Transition Candidate Preference */
+#define WNM_BTM_CAND_PREF_SUBEID 0x03
+
+/* BSS Termination Duration */
+#define WNM_BTM_TERM_DUR_SUBEID		0x04
+
+struct wnm_btm_cant {
+	struct nb_rpt_hdr nb_rpt;
+	u8 preference;	/* BSS Transition Candidate Preference */
+};
+
+enum rtw_btm_req_mod {
+	PREFERRED_CANDIDATE_LIST_INCLUDED = BIT0,
+	ABRIDGED = BIT1,
+	DISASSOC_IMMINENT = BIT2,
+	BSS_TERMINATION_INCLUDED = BIT3,
+	ESS_DISASSOC_IMMINENT = BIT4,
+};
+
+struct roam_nb_info {
+	struct nb_rpt_hdr nb_rpt[RTW_MAX_NB_RPT_NUM];
+	struct rtw_ieee80211_channel nb_rpt_ch_list[RTW_MAX_NB_RPT_NUM];
+	bool	nb_rpt_valid;
+	u8	nb_rpt_ch_list_num;
+	u8 preference_en;
+	u8 roam_target_addr[ETH_ALEN];
+	u32	last_nb_rpt_entries;
+	bool	nb_rpt_is_same;
+	_timer roam_scan_timer;
+};
+#endif	/* defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K) */
+#endif
+
+struct mlme_priv {
+
+	_lock	lock;
+	sint	fw_state;	/* shall we protect this variable? maybe not necessarily... */
+	u8	to_join; /* flag */
+#ifdef CONFIG_LAYER2_ROAMING
+	u8 to_roam; /* roaming trying times */
+	struct wlan_network *roam_network; /* the target of active roam */
+	u8 roam_flags;
+	u8 roam_rssi_diff_th; /* rssi difference threshold for active scan candidate selection */
+	u32 roam_scan_int_ms; /* scan interval for active roam */
+	u32 roam_scanr_exp_ms; /* scan result expire time in ms  for roam */
+	u8 roam_tgt_addr[ETH_ALEN]; /* request to roam to speicific target without other consideration */
+	u8 roam_rssi_threshold;
+	bool need_to_roam;
+#endif
+
+	u8	*nic_hdl;
+
+	_list		*pscanned;
+	_queue	free_bss_pool;
+	_queue	scanned_queue;
+	u8		*free_bss_buf;
+	u32	num_of_scanned;
+
+	NDIS_802_11_SSID	assoc_ssid;
+	u8	assoc_bssid[6];
+
+	struct wlan_network	cur_network;
+	struct wlan_network *cur_network_scanned;
+
+	/* bcn check info */
+	struct beacon_keys cur_beacon_keys; /* save current beacon keys */
+	struct beacon_keys new_beacon_keys; /* save new beacon keys */
+	u8 new_beacon_cnts; /* if new_beacon_cnts >= threshold, ap beacon is changed */
+
+#ifdef CONFIG_ARP_KEEP_ALIVE
+	/* for arp offload keep alive */
+	u8 bGetGateway;
+	u8	GetGatewayTryCnt;
+	u8	gw_mac_addr[6];
+	u8	gw_ip[4];
+#endif
+
+	/* uint wireless_mode; no used, remove it */
+
+	u32	auto_scan_int_ms;
+
+	_timer assoc_timer;
+
+	uint assoc_by_bssid;
+	uint assoc_by_rssi;
+
+	_timer scan_to_timer; /* driver itself handles scan_timeout status. */
+	systime scan_start_time; /* used to evaluate the time spent in scanning */
+
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
+	_timer set_scan_deny_timer;
+	ATOMIC_T set_scan_deny; /* 0: allowed, 1: deny */
+#endif
+
+	struct qos_priv qospriv;
+
+#ifdef CONFIG_80211N_HT
+
+	/* Number of non-HT AP/stations */
+	int num_sta_no_ht;
+
+	/* Number of HT AP/stations 20 MHz */
+	/* int num_sta_ht_20mhz; */
+
+
+	int num_FortyMHzIntolerant;
+
+	struct ht_priv	htpriv;
+
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+	struct vht_priv	vhtpriv;
+#endif
+#ifdef CONFIG_BEAMFORMING
+#ifndef RTW_BEAMFORMING_VERSION_2
+#if (BEAMFORMING_SUPPORT == 0)/*for driver beamforming*/
+	struct beamforming_info	beamforming_info;
+#endif
+#endif /* !RTW_BEAMFORMING_VERSION_2 */
+#endif
+
+#ifdef CONFIG_DFS
+	u8	handle_dfs;
+#endif
+#ifdef CONFIG_DFS_MASTER
+	/* TODO: move to rfctl */
+	_timer dfs_master_timer;
+#endif
+#ifdef CONFIG_RTW_80211R
+	struct ft_roam_info ft_roam;
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+	struct roam_nb_info nb_info;
+	u8 ch_cnt;
+#endif
+
+	RT_LINK_DETECT_T	LinkDetectInfo;
+
+	u8	acm_mask; /* for wmm acm mask */
+	RT_SCAN_TYPE	scan_mode; /* active: 1, passive: 0 */
+
+	u8 *wps_probe_req_ie;
+	u32 wps_probe_req_ie_len;
+
+	u8 ext_capab_ie_data[8];/*currently for ap mode only*/
+	u8 ext_capab_ie_len;
+
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	/* 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;
+
+	ATOMIC_T olbc; /* Overlapping Legacy BSS Condition (Legacy b/g)*/
+
+	/* 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;
+
+	/* number of associated stations 40MHz intolerant */
+	int num_sta_40mhz_intolerant;
+
+	/* Overlapping BSS information */
+	ATOMIC_T olbc_ht;
+
+#ifdef CONFIG_80211N_HT
+	int ht_20mhz_width_req;
+	int ht_intolerant_ch_reported;
+	u16 ht_op_mode;
+	u8 sw_to_20mhz; /*switch to 20Mhz BW*/
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_RTW_80211R
+	u8 *auth_rsp;
+	u32 auth_rsp_len;
+#endif
+	u8 *assoc_req;
+	u32 assoc_req_len;
+
+	u8 *assoc_rsp;
+	u32 assoc_rsp_len;
+
+	/* u8 *wps_probe_req_ie; */
+	/* u32 wps_probe_req_ie_len; */
+
+	u8 *wps_beacon_ie;
+	u32 wps_beacon_ie_len;
+
+	u8 *wps_probe_resp_ie;
+	u32 wps_probe_resp_ie_len;
+
+	u8 *wps_assoc_resp_ie;
+	u32 wps_assoc_resp_ie_len;
+
+	u8 *p2p_beacon_ie;
+	u32 p2p_beacon_ie_len;
+
+	u8 *p2p_probe_req_ie;
+	u32 p2p_probe_req_ie_len;
+
+	u8 *p2p_probe_resp_ie;
+	u32 p2p_probe_resp_ie_len;
+
+	u8 *p2p_go_probe_resp_ie;		/* for GO */
+	u32 p2p_go_probe_resp_ie_len;	/* for GO */
+
+	u8 *p2p_assoc_req_ie;
+	u32 p2p_assoc_req_ie_len;
+
+	u8 *p2p_assoc_resp_ie;
+	u32 p2p_assoc_resp_ie_len;
+
+	_lock	bcn_update_lock;
+	u8		update_bcn;
+
+	u8 ori_ch;
+	u8 ori_bw;
+	u8 ori_offset;
+	#ifdef CONFIG_80211AC_VHT
+	u8 ori_vht_en;
+	#endif
+#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
+
+#if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
+	u8 *wfd_beacon_ie;
+	u32 wfd_beacon_ie_len;
+
+	u8 *wfd_probe_req_ie;
+	u32 wfd_probe_req_ie_len;
+
+	u8 *wfd_probe_resp_ie;
+	u32 wfd_probe_resp_ie_len;
+
+	u8 *wfd_go_probe_resp_ie;		/* for GO */
+	u32 wfd_go_probe_resp_ie_len;	/* for GO */
+
+	u8 *wfd_assoc_req_ie;
+	u32 wfd_assoc_req_ie_len;
+
+	u8 *wfd_assoc_resp_ie;
+	u32 wfd_assoc_resp_ie_len;
+#endif
+
+#ifdef RTK_DMP_PLATFORM
+	/* DMP kobject_hotplug function  signal need in passive level */
+	_workitem	Linkup_workitem;
+	_workitem	Linkdown_workitem;
+#endif
+
+#ifdef CONFIG_INTEL_WIDI
+	int	widi_state;
+	int	listen_state;
+	_timer	listen_timer;
+	ATOMIC_T	rx_probe_rsp; /* 1:receive probe respone from RDS source. */
+	u8	*l2sdTaBuffer;
+	u8	channel_idx;
+	u8	group_cnt;	/* In WiDi 3.5, they specified another scan algo. for WFD/RDS co-existed */
+	u8	sa_ext[L2SDTA_SERVICE_VE_LEN];
+
+	u8	widi_enable;
+	/**
+	 * For WiDi 4; upper layer would set
+	 * p2p_primary_device_type_category_id
+	 * p2p_primary_device_type_sub_category_id
+	 * p2p_secondary_device_type_category_id
+	 * p2p_secondary_device_type_sub_category_id
+	 */
+	u16	p2p_pdt_cid;
+	u16	p2p_pdt_scid;
+	u8	num_p2p_sdt;
+	u16	p2p_sdt_cid[MAX_NUM_P2P_SDT];
+	u16	p2p_sdt_scid[MAX_NUM_P2P_SDT];
+	u8	p2p_reject_disable;	/* When starting NL80211 wpa_supplicant/hostapd, it will call netdev_close */
+							/* such that it will cause p2p disabled. Use this flag to reject. */
+#endif /* CONFIG_INTEL_WIDI */
+	systime lastscantime;
+#ifdef CONFIG_CONCURRENT_MODE
+	u8	scanning_via_buddy_intf;
+#endif
+
+#if 0
+	u8	NumOfBcnInfoChkFail;
+	u32	timeBcnInfoChkStart;
+#endif
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	u32 vendor_ie_mask[WLAN_MAX_VENDOR_IE_NUM];
+	u8 vendor_ie[WLAN_MAX_VENDOR_IE_NUM][WLAN_MAX_VENDOR_IE_LEN];
+	u32 vendor_ielen[WLAN_MAX_VENDOR_IE_NUM];
+#endif
+};
+
+#define mlme_set_scan_to_timer(mlme, ms) \
+	do { \
+		/* RTW_INFO("%s set_scan_to_timer(%p, %d)\n", __FUNCTION__, (mlme), (ms)); */ \
+		_set_timer(&(mlme)->scan_to_timer, (ms)); \
+	} while (0)
+
+#define rtw_mlme_set_auto_scan_int(adapter, ms) \
+	do { \
+		adapter->mlmepriv.auto_scan_int_ms = ms; \
+	} while (0)
+
+#define RTW_AUTO_SCAN_REASON_UNSPECIFIED		0
+#define RTW_AUTO_SCAN_REASON_2040_BSS			BIT0
+#define RTW_AUTO_SCAN_REASON_ACS				BIT1
+#define RTW_AUTO_SCAN_REASON_ROAM				BIT2
+#define RTW_AUTO_SCAN_REASON_MESH_OFFCH_CAND	BIT3
+
+void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason);
+
+#ifdef CONFIG_AP_MODE
+
+struct hostapd_priv {
+	_adapter *padapter;
+
+#ifdef CONFIG_HOSTAPD_MLME
+	struct net_device *pmgnt_netdev;
+	struct usb_anchor anchored;
+#endif
+
+};
+
+extern int hostapd_mode_init(_adapter *padapter);
+extern void hostapd_mode_unload(_adapter *padapter);
+#endif
+
+
+extern void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf);
+extern void rtw_survey_event_callback(_adapter *adapter, u8 *pbuf);
+extern void rtw_surveydone_event_callback(_adapter *adapter, u8 *pbuf);
+extern void rtw_joinbss_event_callback(_adapter *adapter, u8 *pbuf);
+extern void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf);
+extern void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf);
+void rtw_sta_mstatus_disc_rpt(_adapter *adapter, u8 mac_id);
+void rtw_sta_mstatus_report(_adapter *adapter);
+extern void rtw_atimdone_event_callback(_adapter *adapter, u8 *pbuf);
+extern void rtw_cpwm_event_callback(_adapter *adapter, u8 *pbuf);
+extern void rtw_wmm_event_callback(PADAPTER padapter, u8 *pbuf);
+#ifdef CONFIG_IEEE80211W
+void rtw_sta_timeout_event_callback(_adapter *adapter, u8 *pbuf);
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_RTW_80211R
+void rtw_ft_info_init(struct ft_roam_info *pft);
+u8 rtw_ft_chk_roaming_candidate(_adapter *padapter, 
+	struct wlan_network *competitor);
+void rtw_ft_update_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork);
+void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf);
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+void rtw_roam_nb_info_init(_adapter *padapter);
+#endif
+
+thread_return event_thread(thread_context context);
+
+extern void rtw_free_network_queue(_adapter *adapter, u8 isfreeall);
+extern int rtw_init_mlme_priv(_adapter *adapter);/* (struct mlme_priv *pmlmepriv); */
+
+extern void rtw_free_mlme_priv(struct mlme_priv *pmlmepriv);
+
+
+extern sint rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv);
+extern sint rtw_set_key(_adapter *adapter, struct security_priv *psecuritypriv, sint keyid, u8 set_tx, bool enqueue);
+extern sint rtw_set_auth(_adapter *adapter, struct security_priv *psecuritypriv);
+
+__inline static 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;
+}
+
+__inline static sint check_fwstate(struct mlme_priv *pmlmepriv, sint state)
+{
+	if ((state == WIFI_NULL_STATE) &&
+		(pmlmepriv->fw_state == WIFI_NULL_STATE))
+		return _TRUE;
+
+	if (pmlmepriv->fw_state & state)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+__inline static sint 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
+ */
+extern void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state);
+
+static inline void set_fwstate(struct mlme_priv *pmlmepriv, sint state)
+{
+	pmlmepriv->fw_state |= state;
+	rtw_mi_update_iface_status(pmlmepriv, state);
+}
+static inline void init_fwstate(struct mlme_priv *pmlmepriv, sint state)
+{
+	pmlmepriv->fw_state = state;
+	rtw_mi_update_iface_status(pmlmepriv, state);
+}
+
+static inline void _clr_fwstate_(struct mlme_priv *pmlmepriv, sint state)
+{
+	pmlmepriv->fw_state &= ~state;
+	rtw_mi_update_iface_status(pmlmepriv, state);
+}
+
+/*
+ * No Limit on the calling context,
+ * therefore set it to be the critical section...
+ */
+static inline void clr_fwstate(struct mlme_priv *pmlmepriv, sint state)
+{
+	_irqL irqL;
+
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	_clr_fwstate_(pmlmepriv, state);
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+}
+
+static inline void up_scanned_network(struct mlme_priv *pmlmepriv)
+{
+	_irqL irqL;
+
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	pmlmepriv->num_of_scanned++;
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+}
+u8 rtw_is_adapter_up(_adapter *padapter);
+
+__inline static void down_scanned_network(struct mlme_priv *pmlmepriv)
+{
+	_irqL irqL;
+
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	pmlmepriv->num_of_scanned--;
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+}
+
+__inline static void set_scanned_network_val(struct mlme_priv *pmlmepriv, sint val)
+{
+	_irqL irqL;
+
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	pmlmepriv->num_of_scanned = val;
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+}
+
+extern u16 rtw_get_capability(WLAN_BSSID_EX *bss);
+extern bool rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target);
+extern void rtw_disconnect_hdl_under_linked(_adapter *adapter, struct sta_info *psta, u8 free_assoc);
+extern void rtw_generate_random_ibss(u8 *pibss);
+struct wlan_network *_rtw_find_network(_queue *scanned_queue, const u8 *addr);
+struct wlan_network *rtw_find_network(_queue *scanned_queue, const u8 *addr);
+extern struct wlan_network *rtw_get_oldest_wlan_network(_queue *scanned_queue);
+struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network);
+struct wlan_network *rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network);
+
+extern void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue);
+extern void rtw_indicate_disconnect(_adapter *adapter, u16 reason, u8 locally_generated);
+extern void rtw_indicate_connect(_adapter *adapter);
+void rtw_indicate_scan_done(_adapter *padapter, bool aborted);
+
+void rtw_drv_scan_by_self(_adapter *padapter, u8 reason);
+void rtw_scan_wait_completed(_adapter *adapter);
+u32 rtw_scan_abort_timeout(_adapter *adapter, u32 timeout_ms);
+void rtw_scan_abort_no_wait(_adapter *adapter);
+void rtw_scan_abort(_adapter *adapter);
+u32 rtw_join_abort_timeout(_adapter *adapter, u32 timeout_ms);
+
+extern int rtw_restruct_sec_ie(_adapter *adapter, u8 *out_ie);
+#ifdef CONFIG_WMMPS_STA
+void rtw_uapsd_use_default_setting(_adapter *padapter);
+bool rtw_is_wmmps_mode(_adapter *padapter);
+#endif /* CONFIG_WMMPS_STA */
+extern int rtw_restruct_wmm_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len, uint initial_out_len);
+extern void rtw_init_registrypriv_dev_network(_adapter *adapter);
+
+extern void rtw_update_registrypriv_dev_network(_adapter *adapter);
+
+extern void rtw_get_encrypt_decrypt_from_registrypriv(_adapter *adapter);
+
+extern void rtw_join_timeout_handler(void *ctx);
+extern void rtw_scan_timeout_handler(void *ctx);
+
+extern void rtw_dynamic_check_timer_handlder(void *ctx);
+extern void rtw_iface_dynamic_check_timer_handlder(_adapter *adapter);
+
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
+bool rtw_is_scan_deny(_adapter *adapter);
+void rtw_clear_scan_deny(_adapter *adapter);
+void rtw_set_scan_deny_timer_hdl(void *ctx);
+void rtw_set_scan_deny(_adapter *adapter, u32 ms);
+#else
+#define rtw_is_scan_deny(adapter) _FALSE
+#define rtw_clear_scan_deny(adapter) do {} while (0)
+#define rtw_set_scan_deny(adapter, ms) do {} while (0)
+#endif
+
+void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv);
+
+#define MLME_BEACON_IE			0
+#define MLME_PROBE_REQ_IE		1
+#define MLME_PROBE_RESP_IE		2
+#define MLME_GO_PROBE_RESP_IE	3
+#define MLME_ASSOC_REQ_IE		4
+#define MLME_ASSOC_RESP_IE		5
+
+#if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
+int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_len);
+#endif
+
+
+/* extern struct wlan_network* _rtw_dequeue_network(_queue *queue); */
+
+extern struct wlan_network *_rtw_alloc_network(struct mlme_priv *pmlmepriv);
+
+
+extern void _rtw_free_network(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork, u8 isfreeall);
+extern void _rtw_free_network_nolock(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork);
+
+extern void _rtw_free_network_queue(_adapter *padapter, u8 isfreeall);
+
+extern sint rtw_if_up(_adapter *padapter);
+
+sint rtw_linked_check(_adapter *padapter);
+
+u8 *rtw_get_capability_from_ie(u8 *ie);
+u8 *rtw_get_timestampe_from_ie(u8 *ie);
+u8 *rtw_get_beacon_interval_from_ie(u8 *ie);
+
+
+void rtw_joinbss_reset(_adapter *padapter);
+
+#ifdef CONFIG_80211N_HT
+void	rtw_ht_use_default_setting(_adapter *padapter);
+void rtw_build_wmm_ie_ht(_adapter *padapter, u8 *out_ie, uint *pout_len);
+unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len, u8 channel);
+void rtw_update_ht_cap(_adapter *padapter, u8 *pie, uint ie_len, u8 channel);
+void rtw_issue_addbareq_cmd(_adapter *padapter, struct xmit_frame *pxmitframe);
+void rtw_append_exented_cap(_adapter *padapter, u8 *out_ie, uint *pout_len);
+#endif
+
+int rtw_is_same_ibss(_adapter *adapter, struct wlan_network *pnetwork);
+int is_same_network(WLAN_BSSID_EX *src, WLAN_BSSID_EX *dst, u8 feature);
+
+#ifdef CONFIG_LAYER2_ROAMING
+#define rtw_roam_flags(adapter) ((adapter)->mlmepriv.roam_flags)
+#define rtw_chk_roam_flags(adapter, flags) ((adapter)->mlmepriv.roam_flags & flags)
+#define rtw_clr_roam_flags(adapter, flags) \
+	do { \
+		((adapter)->mlmepriv.roam_flags &= ~flags); \
+	} while (0)
+
+#define rtw_set_roam_flags(adapter, flags) \
+	do { \
+		((adapter)->mlmepriv.roam_flags |= flags); \
+	} while (0)
+
+#define rtw_assign_roam_flags(adapter, flags) \
+	do { \
+		((adapter)->mlmepriv.roam_flags = flags); \
+	} while (0)
+
+void _rtw_roaming(_adapter *adapter, struct wlan_network *tgt_network);
+void rtw_roaming(_adapter *adapter, struct wlan_network *tgt_network);
+void rtw_set_to_roam(_adapter *adapter, u8 to_roam);
+u8 rtw_dec_to_roam(_adapter *adapter);
+u8 rtw_to_roam(_adapter *adapter);
+int rtw_select_roaming_candidate(struct mlme_priv *pmlmepriv);
+#else
+#define rtw_roam_flags(adapter) 0
+#define rtw_chk_roam_flags(adapter, flags) 0
+#define rtw_clr_roam_flags(adapter, flags) do {} while (0)
+#define rtw_set_roam_flags(adapter, flags) do {} while (0)
+#define rtw_assign_roam_flags(adapter, flags) do {} while (0)
+#define _rtw_roaming(adapter, tgt_network) do {} while (0)
+#define rtw_roaming(adapter, tgt_network) do {} while (0)
+#define rtw_set_to_roam(adapter, to_roam) do {} while (0)
+#define rtw_dec_to_roam(adapter) 0
+#define rtw_to_roam(adapter) 0
+#define rtw_select_roaming_candidate(mlme) _FAIL
+#endif /* CONFIG_LAYER2_ROAMING */
+
+bool rtw_adjust_chbw(_adapter *adapter, u8 req_ch, u8 *req_bw, u8 *req_offset);
+
+struct sta_media_status_rpt_cmd_parm {
+	struct sta_info *sta;
+	bool connected;
+};
+
+void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool connected);
+u8 rtw_sta_media_status_rpt_cmd(_adapter *adapter, struct sta_info *sta, bool connected);
+void rtw_sta_media_status_rpt_cmd_hdl(_adapter *adapter, struct sta_media_status_rpt_cmd_parm *parm);
+void rtw_sta_traffic_info(void *sel, _adapter *adapter);
+
+#ifdef CONFIG_INTEL_PROXIM
+void rtw_proxim_enable(_adapter *padapter);
+void rtw_proxim_disable(_adapter *padapter);
+void rtw_proxim_send_packet(_adapter *padapter, u8 *pbuf, u16 len, u8 m_rate);
+#endif /* CONFIG_INTEL_PROXIM */
+
+#define IPV4_SRC(_iphdr)			(((u8 *)(_iphdr)) + 12)
+#define IPV4_DST(_iphdr)			(((u8 *)(_iphdr)) + 16)
+#define GET_IPV4_IHL(_iphdr)		BE_BITS_TO_1BYTE(((u8 *)(_iphdr)) + 0, 0, 4)
+#define GET_IPV4_PROTOCOL(_iphdr)	BE_BITS_TO_1BYTE(((u8 *)(_iphdr)) + 9, 0, 8)
+#define GET_IPV4_SRC(_iphdr)		BE_BITS_TO_4BYTE(((u8 *)(_iphdr)) + 12, 0, 32)
+#define GET_IPV4_DST(_iphdr)		BE_BITS_TO_4BYTE(((u8 *)(_iphdr)) + 16, 0, 32)
+
+#define GET_UDP_SRC(_udphdr)			BE_BITS_TO_2BYTE(((u8 *)(_udphdr)) + 0, 0, 16)
+#define GET_UDP_DST(_udphdr)			BE_BITS_TO_2BYTE(((u8 *)(_udphdr)) + 2, 0, 16)
+
+#define TCP_SRC(_tcphdr)				(((u8 *)(_tcphdr)) + 0)
+#define TCP_DST(_tcphdr)				(((u8 *)(_tcphdr)) + 2)
+#define GET_TCP_SRC(_tcphdr)			BE_BITS_TO_2BYTE(((u8 *)(_tcphdr)) + 0, 0, 16)
+#define GET_TCP_DST(_tcphdr)			BE_BITS_TO_2BYTE(((u8 *)(_tcphdr)) + 2, 0, 16)
+#define GET_TCP_SEQ(_tcphdr)			BE_BITS_TO_4BYTE(((u8 *)(_tcphdr)) + 4, 0, 32)
+#define GET_TCP_ACK_SEQ(_tcphdr)		BE_BITS_TO_4BYTE(((u8 *)(_tcphdr)) + 8, 0, 32)
+#define GET_TCP_DOFF(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 12, 4, 4)
+#define GET_TCP_FIN(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 0, 1)
+#define GET_TCP_SYN(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 1, 1)
+#define GET_TCP_RST(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 2, 1)
+#define GET_TCP_PSH(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 3, 1)
+#define GET_TCP_ACK(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 4, 1)
+#define GET_TCP_URG(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 5, 1)
+#define GET_TCP_ECE(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 6, 1)
+#define GET_TCP_CWR(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 7, 1)
+
+#endif /* __RTL871X_MLME_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mlme_ext.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mlme_ext.h
new file mode 100644
index 000000000000..6a784a935aa6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mlme_ext.h
@@ -0,0 +1,1344 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+/*	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)
+
+#ifdef CONFIG_GSPI_HCI
+	#define ROAMING_LIMIT	5
+#else
+	#define ROAMING_LIMIT	8
+#endif
+/* #define	IOCMD_REG0		0x10250370 */
+/* #define	IOCMD_REG1		0x10250374 */
+/* #define	IOCMD_REG2		0x10250378 */
+
+/* #define	FW_DYNAMIC_FUN_SWITCH	0x10250364 */
+
+/* #define	WRITE_BB_CMD		0xF0000001 */
+/* #define	SET_CHANNEL_CMD	0xF3000000 */
+/* #define	UPDATE_RA_CMD	0xFD0000A2 */
+
+#define _HW_STATE_NOLINK_		0x00
+#define _HW_STATE_ADHOC_		0x01
+#define _HW_STATE_STATION_	0x02
+#define _HW_STATE_AP_			0x03
+#define _HW_STATE_MONITOR_ 0x04
+
+
+#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
+
+/********************************************************
+MCS rate definitions
+*********************************************************/
+#define MCS_RATE_1R	(0x000000ff)
+#define MCS_RATE_2R	(0x0000ffff)
+#define MCS_RATE_3R	(0x00ffffff)
+#define MCS_RATE_4R	(0xffffffff)
+#define MCS_RATE_2R_13TO15_OFF	(0x00001fff)
+
+
+extern unsigned char RTW_WPA_OUI[];
+extern unsigned char WMM_OUI[];
+extern unsigned char WPS_OUI[];
+extern unsigned char WFD_OUI[];
+extern unsigned char P2P_OUI[];
+
+extern unsigned char WMM_INFO_OUI[];
+extern unsigned char WMM_PARA_OUI[];
+
+typedef enum _RT_CHANNEL_DOMAIN {
+	/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
+	RTW_CHPLAN_FCC = 0x00,
+	RTW_CHPLAN_IC = 0x01,
+	RTW_CHPLAN_ETSI = 0x02,
+	RTW_CHPLAN_SPAIN = 0x03,
+	RTW_CHPLAN_FRANCE = 0x04,
+	RTW_CHPLAN_MKK = 0x05,
+	RTW_CHPLAN_MKK1 = 0x06,
+	RTW_CHPLAN_ISRAEL = 0x07,
+	RTW_CHPLAN_TELEC = 0x08,
+	RTW_CHPLAN_GLOBAL_DOAMIN = 0x09,
+	RTW_CHPLAN_WORLD_WIDE_13 = 0x0A,
+	RTW_CHPLAN_TAIWAN = 0x0B,
+	RTW_CHPLAN_CHINA = 0x0C,
+	RTW_CHPLAN_SINGAPORE_INDIA_MEXICO = 0x0D,
+	RTW_CHPLAN_KOREA = 0x0E,
+	RTW_CHPLAN_TURKEY = 0x0F,
+	RTW_CHPLAN_JAPAN = 0x10,
+	RTW_CHPLAN_FCC_NO_DFS = 0x11,
+	RTW_CHPLAN_JAPAN_NO_DFS = 0x12,
+	RTW_CHPLAN_WORLD_WIDE_5G = 0x13,
+	RTW_CHPLAN_TAIWAN_NO_DFS = 0x14,
+
+	/* ===== 0x20 ~ 0x7F, new channel plan ===== */
+	RTW_CHPLAN_WORLD_NULL = 0x20,
+	RTW_CHPLAN_ETSI1_NULL = 0x21,
+	RTW_CHPLAN_FCC1_NULL = 0x22,
+	RTW_CHPLAN_MKK1_NULL = 0x23,
+	RTW_CHPLAN_ETSI2_NULL = 0x24,
+	RTW_CHPLAN_FCC1_FCC1 = 0x25,
+	RTW_CHPLAN_WORLD_ETSI1 = 0x26,
+	RTW_CHPLAN_MKK1_MKK1 = 0x27,
+	RTW_CHPLAN_WORLD_KCC1 = 0x28,
+	RTW_CHPLAN_WORLD_FCC2 = 0x29,
+	RTW_CHPLAN_FCC2_NULL = 0x2A,
+	RTW_CHPLAN_IC1_IC2 = 0x2B,
+	RTW_CHPLAN_MKK2_NULL = 0x2C,
+	RTW_CHPLAN_WORLD_CHILE1= 0x2D,
+	RTW_CHPLAN_WORLD1_WORLD1 = 0x2E,
+	RTW_CHPLAN_WORLD_CHILE2 = 0x2F,
+	RTW_CHPLAN_WORLD_FCC3 = 0x30,
+	RTW_CHPLAN_WORLD_FCC4 = 0x31,
+	RTW_CHPLAN_WORLD_FCC5 = 0x32,
+	RTW_CHPLAN_WORLD_FCC6 = 0x33,
+	RTW_CHPLAN_FCC1_FCC7 = 0x34,
+	RTW_CHPLAN_WORLD_ETSI2 = 0x35,
+	RTW_CHPLAN_WORLD_ETSI3 = 0x36,
+	RTW_CHPLAN_MKK1_MKK2 = 0x37,
+	RTW_CHPLAN_MKK1_MKK3 = 0x38,
+	RTW_CHPLAN_FCC1_NCC1 = 0x39,
+	RTW_CHPLAN_ETSI1_ETSI1 = 0x3A,
+	RTW_CHPLAN_ETSI1_ACMA1 = 0x3B,
+	RTW_CHPLAN_ETSI1_ETSI6 = 0x3C,
+	RTW_CHPLAN_ETSI1_ETSI12 = 0x3D,
+	RTW_CHPLAN_FCC1_NCC2 = 0x40,
+	RTW_CHPLAN_GLOBAL_NULL = 0x41,
+	RTW_CHPLAN_ETSI1_ETSI4 = 0x42,
+	RTW_CHPLAN_FCC1_FCC2 = 0x43,
+	RTW_CHPLAN_FCC1_NCC3 = 0x44,
+	RTW_CHPLAN_WORLD_ACMA1 = 0x45,
+	RTW_CHPLAN_FCC1_FCC8 = 0x46,
+	RTW_CHPLAN_WORLD_ETSI6 = 0x47,
+	RTW_CHPLAN_WORLD_ETSI7 = 0x48,
+	RTW_CHPLAN_WORLD_ETSI8 = 0x49,
+	RTW_CHPLAN_WORLD_ETSI9 = 0x50,
+	RTW_CHPLAN_WORLD_ETSI10 = 0x51,
+	RTW_CHPLAN_WORLD_ETSI11 = 0x52,
+	RTW_CHPLAN_FCC1_NCC4 = 0x53,
+	RTW_CHPLAN_WORLD_ETSI12 = 0x54,
+	RTW_CHPLAN_FCC1_FCC9 = 0x55,
+	RTW_CHPLAN_WORLD_ETSI13 = 0x56,
+	RTW_CHPLAN_FCC1_FCC10 = 0x57,
+	RTW_CHPLAN_MKK2_MKK4 = 0x58,
+	RTW_CHPLAN_WORLD_ETSI14 = 0x59,
+	RTW_CHPLAN_FCC1_FCC5 = 0x60,
+	RTW_CHPLAN_FCC2_FCC7 = 0x61,
+	RTW_CHPLAN_FCC2_FCC1 = 0x62,
+	RTW_CHPLAN_WORLD_ETSI15 = 0x63,
+	RTW_CHPLAN_MKK2_MKK5 = 0x64,
+	RTW_CHPLAN_ETSI1_ETSI16 = 0x65,
+	RTW_CHPLAN_FCC1_FCC14 = 0x66,
+	RTW_CHPLAN_FCC1_FCC12 = 0x67,
+	RTW_CHPLAN_FCC2_FCC14 = 0x68,
+	RTW_CHPLAN_FCC2_FCC12 = 0x69,
+	RTW_CHPLAN_ETSI1_ETSI17 = 0x6A,
+	RTW_CHPLAN_WORLD_FCC16 = 0x6B,
+	RTW_CHPLAN_WORLD_FCC13 = 0x6C,
+	RTW_CHPLAN_FCC2_FCC15 = 0x6D,
+	RTW_CHPLAN_WORLD_FCC12 = 0x6E,
+	RTW_CHPLAN_NULL_ETSI8 = 0x6F,
+	RTW_CHPLAN_NULL_ETSI18 = 0x70,
+	RTW_CHPLAN_NULL_ETSI17 = 0x71,
+	RTW_CHPLAN_NULL_ETSI19 = 0x72,
+	RTW_CHPLAN_WORLD_FCC7 = 0x73,
+	RTW_CHPLAN_FCC2_FCC17 = 0x74,
+	RTW_CHPLAN_WORLD_ETSI20 = 0x75,
+	RTW_CHPLAN_FCC2_FCC11 = 0x76,
+	RTW_CHPLAN_WORLD_ETSI21 = 0x77,
+	RTW_CHPLAN_FCC1_FCC18 = 0x78,
+	RTW_CHPLAN_MKK2_MKK1 = 0x79,
+
+	RTW_CHPLAN_MAX,
+	RTW_CHPLAN_REALTEK_DEFINE = 0x7F,
+	RTW_CHPLAN_UNSPECIFIED = 0xFF,
+} RT_CHANNEL_DOMAIN, *PRT_CHANNEL_DOMAIN;
+
+bool rtw_chplan_is_empty(u8 id);
+#define rtw_is_channel_plan_valid(chplan) (((chplan) < RTW_CHPLAN_MAX || (chplan) == RTW_CHPLAN_REALTEK_DEFINE) && !rtw_chplan_is_empty(chplan))
+#define rtw_is_legacy_channel_plan(chplan) ((chplan) < 0x20)
+
+typedef struct _RT_CHANNEL_PLAN {
+	unsigned char	Channel[MAX_CHANNEL_NUM];
+	unsigned char	Len;
+} RT_CHANNEL_PLAN, *PRT_CHANNEL_PLAN;
+
+struct ch_list_t {
+	u8 *len_ch;
+};
+
+#define CH_LIST_ENT(_len, arg...) \
+	{.len_ch = (u8[_len + 1]) {_len, ##arg}, }
+
+#define CH_LIST_LEN(_ch_list) (_ch_list.len_ch[0])
+#define CH_LIST_CH(_ch_list, _i) (_ch_list.len_ch[_i + 1])
+
+typedef struct _RT_CHANNEL_PLAN_MAP {
+	u8 Index2G;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	u8 Index5G;
+#endif
+	u8 regd; /* value of REGULATION_TXPWR_LMT */
+} RT_CHANNEL_PLAN_MAP, *PRT_CHANNEL_PLAN_MAP;
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+#define CHPLAN_ENT(i2g, i5g, regd) {i2g, i5g, regd}
+#else
+#define CHPLAN_ENT(i2g, i5g, regd) {i2g, regd}
+#endif
+
+enum Associated_AP {
+	atherosAP	= 0,
+	broadcomAP	= 1,
+	ciscoAP		= 2,
+	marvellAP	= 3,
+	ralinkAP	= 4,
+	realtekAP	= 5,
+	airgocapAP	= 6,
+	unknownAP	= 7,
+	maxAP,
+};
+
+typedef enum _HT_IOT_PEER {
+	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_REALTEK_JAGUAR_BCUTAP = 16,
+	HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,
+	HT_IOT_PEER_MAX				= 18
+} HT_IOT_PEER_E, *PHTIOT_PEER_E;
+
+struct mlme_handler {
+	unsigned int   num;
+	char *str;
+	unsigned int (*func)(_adapter *padapter, union recv_frame *precv_frame);
+};
+
+struct action_handler {
+	unsigned int   num;
+	char *str;
+	unsigned int (*func)(_adapter *padapter, union recv_frame *precv_frame);
+};
+
+enum SCAN_STATE {
+	SCAN_DISABLE = 0,
+	SCAN_START = 1,
+	SCAN_PS_ANNC_WAIT = 2,
+	SCAN_ENTER = 3,
+	SCAN_PROCESS = 4,
+
+	/* backop */
+	SCAN_BACKING_OP = 5,
+	SCAN_BACK_OP = 6,
+	SCAN_LEAVING_OP = 7,
+	SCAN_LEAVE_OP = 8,
+
+	/* SW antenna diversity (before linked) */
+	SCAN_SW_ANTDIV_BL = 9,
+
+	/* legacy p2p */
+	SCAN_TO_P2P_LISTEN = 10,
+	SCAN_P2P_LISTEN = 11,
+
+	SCAN_COMPLETE = 12,
+	SCAN_STATE_MAX,
+};
+
+const char *scan_state_str(u8 state);
+
+enum ss_backop_flag {
+	SS_BACKOP_EN = BIT0, /* backop when linked */
+	SS_BACKOP_EN_NL = BIT1, /* backop even when no linked */
+
+	SS_BACKOP_PS_ANNC = BIT4,
+	SS_BACKOP_TX_RESUME = BIT5,
+};
+
+struct ss_res {
+	u8 state;
+	u8 next_state; /* will set to state on next cmd hdl */
+	int	bss_cnt;
+	int	channel_idx;
+#ifdef CONFIG_DFS
+	u8 dfs_ch_ssid_scan;
+#endif
+	int	scan_mode;
+	u16 scan_ch_ms;
+	u32 scan_timeout_ms;
+	u8 rx_ampdu_accept;
+	u8 rx_ampdu_size;
+	u8 igi_scan;
+	u8 igi_before_scan; /* used for restoring IGI value without enable DIG & FA_CNT */
+#ifdef CONFIG_SCAN_BACKOP
+	u8 backop_flags_sta; /* policy for station mode*/
+	u8 backop_flags_ap; /* policy for ap mode */
+	u8 backop_flags; /* per backop runtime decision */
+	u8 scan_cnt;
+	u8 scan_cnt_max;
+	systime backop_time; /* the start time of backop */
+	u16 backop_ms;
+#endif
+#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
+	u8 is_sw_antdiv_bl_scan;
+#endif
+	u8 ssid_num;
+	u8 ch_num;
+	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];
+	struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
+
+	u32 token; 	/* 0: use to identify caller */
+	u16 duration;	/* 0: use default */
+	u8 igi;		/* 0: use defalut */
+	u8 bw;		/* 0: use default */
+};
+
+/* #define AP_MODE				0x0C */
+/* #define STATION_MODE	0x08 */
+/* #define AD_HOC_MODE		0x04 */
+/* #define NO_LINK_MODE	0x00 */
+
+#define	WIFI_FW_NULL_STATE			_HW_STATE_NOLINK_
+#define	WIFI_FW_STATION_STATE		_HW_STATE_STATION_
+#define	WIFI_FW_AP_STATE				_HW_STATE_AP_
+#define	WIFI_FW_ADHOC_STATE			_HW_STATE_ADHOC_
+
+#define WIFI_FW_PRE_LINK			0x00000800
+#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)
+
+#ifdef CONFIG_TDLS
+enum TDLS_option {
+	TDLS_ESTABLISHED = 1,
+	TDLS_ISSUE_PTI,
+	TDLS_CH_SW_RESP,
+	TDLS_CH_SW_PREPARE,
+	TDLS_CH_SW_START,
+	TDLS_CH_SW_TO_OFF_CHNL,
+	TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED,
+	TDLS_CH_SW_TO_BASE_CHNL,
+	TDLS_CH_SW_END_TO_BASE_CHNL,
+	TDLS_CH_SW_END,
+	TDLS_RS_RCR,
+	TDLS_TEARDOWN_STA,
+	TDLS_TEARDOWN_STA_NO_WAIT,
+	TDLS_TEARDOWN_STA_LOCALLY,
+	TDLS_TEARDOWN_STA_LOCALLY_POST,
+	maxTDLS,
+};
+
+#endif /* CONFIG_TDLS */
+
+/*
+ * 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_BACK_OP_CH_MS milliseconds.
+ * Example:
+ * For chip supports 2.4G + 5GHz and AP mode is operating in channel 1,
+ * RTW_SCAN_NUM_OF_CH is 8, RTW_BACK_OP_CH_MS is 300
+ * 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.
+ */
+#if defined(CONFIG_ATMEL_RC_PATCH)
+	#define RTW_SCAN_NUM_OF_CH 2
+	#define RTW_BACK_OP_CH_MS 200
+#else
+	#define RTW_SCAN_NUM_OF_CH 3
+	#define RTW_BACK_OP_CH_MS 400
+#endif
+
+#define RTW_IP_ADDR_LEN 4
+#define RTW_IPv6_ADDR_LEN 16
+
+struct mlme_ext_info {
+	u32	state;
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	u8	hw_media_state;
+#endif
+	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	agg_enable_bitmap;
+	u8	ADDBA_retry_count;
+	u8	candidate_tid_bitmap;
+	u8	dialogToken;
+	/* Accept ADDBA Request */
+	BOOLEAN bAcceptAddbaReq;
+	u8	bwmode_updated;
+	u8	hidden_ssid_mode;
+	u8	VHT_enable;
+
+	u8 ip_addr[RTW_IP_ADDR_LEN];
+	u8 ip6_addr[RTW_IPv6_ADDR_LEN];
+
+	struct ADDBA_request		ADDBA_req;
+	struct WMM_para_element	WMM_param;
+	struct HT_caps_element	HT_caps;
+	struct HT_info_element		HT_info;
+	WLAN_BSSID_EX			network;/* join network or bss_network, if in ap mode, it is the same to cur_network.network */
+};
+
+/* The channel information about this channel including joining, scanning, and power constraints. */
+typedef struct _RT_CHANNEL_INFO {
+	u8				ChannelNum;		/* The channel number. */
+	RT_SCAN_TYPE	ScanType;		/* Scan type such as passive or active scan. */
+	/* u16				ScanPeriod;		 */ /* Listen time in millisecond in this channel. */
+	/* s32				MaxTxPwrDbm;	 */ /* Max allowed tx power. */
+	/* u32				ExInfo;			 */ /* Extended Information for this channel. */
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	u32				rx_count;
+#endif
+#ifdef CONFIG_DFS
+	#ifdef CONFIG_DFS_MASTER
+	systime non_ocp_end_time;
+	#endif
+	u8 hidden_bss_cnt; /* per scan count */
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_OFFCH_CAND
+	u8 mesh_candidate_cnt; /* update at scan done for specific mesh iface */
+	#endif
+#endif /* CONFIG_RTW_MESH */
+} RT_CHANNEL_INFO, *PRT_CHANNEL_INFO;
+
+#define DFS_MASTER_TIMER_MS 100
+#define CAC_TIME_MS (60*1000)
+#define CAC_TIME_CE_MS (10*60*1000)
+#define NON_OCP_TIME_MS (30*60*1000)
+
+#ifdef CONFIG_TXPWR_LIMIT
+void rtw_txpwr_init_regd(struct rf_ctl_t *rfctl);
+#endif
+void rtw_rfctl_init(_adapter *adapter);
+void rtw_rfctl_deinit(_adapter *adapter);
+
+#ifdef CONFIG_DFS_MASTER
+struct rf_ctl_t;
+#define CH_IS_NON_OCP(rt_ch_info) (rtw_time_after((rt_ch_info)->non_ocp_end_time, rtw_get_current_time()))
+bool rtw_is_cac_reset_needed(_adapter *adapter, u8 ch, u8 bw, u8 offset);
+bool _rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset);
+bool rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl);
+bool rtw_rfctl_is_tx_blocked_by_ch_waiting(struct rf_ctl_t *rfctl);
+bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
+void rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
+void rtw_chset_update_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms);
+u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms);
+void rtw_reset_cac(_adapter *adapter, u8 ch, u8 bw, u8 offset);
+u32 rtw_force_stop_cac(_adapter *adapter, u32 timeout_ms);
+#else
+#define CH_IS_NON_OCP(rt_ch_info) 0
+#define rtw_chset_is_ch_non_ocp(ch_set, ch, bw, offset) _FALSE
+#define rtw_rfctl_is_tx_blocked_by_ch_waiting(rfctl) _FALSE
+#endif
+
+enum {
+	RTW_CHF_2G = BIT0,
+	RTW_CHF_5G = BIT1,
+	RTW_CHF_DFS = BIT2,
+	RTW_CHF_LONG_CAC = BIT3,
+	RTW_CHF_NON_DFS = BIT4,
+	RTW_CHF_NON_LONG_CAC = BIT5,
+	RTW_CHF_NON_OCP = BIT6,
+};
+
+bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 sel_ch, u8 max_bw
+	, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset
+	, u8 d_flags, u8 cur_ch, u8 same_band_prefer);
+
+void dump_country_chplan(void *sel, const struct country_chplan *ent);
+void dump_country_chplan_map(void *sel);
+void dump_chplan_id_list(void *sel);
+void dump_chplan_test(void *sel);
+void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set);
+void dump_cur_chset(void *sel, _adapter *adapter);
+
+int rtw_chset_search_ch(RT_CHANNEL_INFO *ch_set, const u32 ch);
+u8 rtw_chset_is_chbw_valid(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
+void rtw_chset_sync_chbw(RT_CHANNEL_INFO *ch_set, u8 *req_ch, u8 *req_bw, u8 *req_offset
+	, u8 *g_ch, u8 *g_bw, u8 *g_offset);
+
+bool rtw_mlme_band_check(_adapter *adapter, const u32 ch);
+
+
+enum {
+	BAND_24G = BIT0,
+	BAND_5G = BIT1,
+};
+void RTW_SET_SCAN_BAND_SKIP(_adapter *padapter, int skip_band);
+void RTW_CLR_SCAN_BAND_SKIP(_adapter *padapter, int skip_band);
+int RTW_GET_SCAN_BAND_SKIP(_adapter *padapter);
+
+bool rtw_mlme_ignore_chan(_adapter *adapter, 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 {
+	_adapter	*padapter;
+	u8	mlmeext_init;
+	ATOMIC_T		event_seq;
+	u16	mgnt_seq;
+#ifdef CONFIG_IEEE80211W
+	u16	sa_query_seq;
+#endif
+	/* 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	basicrate[NumRates];
+	unsigned char	datarate[NumRates];
+#ifdef CONFIG_80211N_HT
+	unsigned char default_supported_mcs_set[16];
+#endif
+
+	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 */
+	_timer		survey_timer;
+	_timer		link_timer;
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	_timer		rson_scan_timer;
+#endif
+#ifdef CONFIG_RTW_80211R
+	_timer		ft_link_timer;
+	_timer		ft_roam_timer;
+#endif
+
+	systime last_scan_time;
+	u8	scan_abort;
+	u8 join_abort;
+	u8	tx_rate; /* TXRATE when USERATE is set. */
+
+	u32	retry; /* retry for issue probereq */
+
+	u64 TSFValue;
+
+	/* for LPS-32K to adaptive bcn early and timeout */
+	u8 adaptive_tsf_done;
+	u32 bcn_delay_cnt[9];
+	u32 bcn_delay_ratio[9];
+	u32 bcn_cnt;
+	u8 DrvBcnEarly;
+	u8 DrvBcnTimeOut;
+
+#ifdef CONFIG_AP_MODE
+	unsigned char bstart_bss;
+#endif
+
+#ifdef CONFIG_80211D
+	u8 update_channel_plan_by_ap_done;
+#endif
+	/* recv_decache check for Action_public frame */
+	u8 action_public_dialog_token;
+	u16	 action_public_rxseq;
+
+	/* #ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
+	u8 active_keep_alive_check;
+	/* #endif */
+#ifdef DBG_FIXED_CHAN
+	u8 fixed_chan;
+#endif
+	/* set hw sync bcn tsf register or not */
+	u8 en_hw_update_tsf;
+};
+
+static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)
+{
+	if ((plmeext->mlmext_info.state & 0x03) == state)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+void sitesurvey_set_offch_state(_adapter *adapter, u8 scan_state);
+
+#define mlmeext_msr(mlmeext) ((mlmeext)->mlmext_info.state & 0x03)
+#define mlmeext_scan_state(mlmeext) ((mlmeext)->sitesurvey_res.state)
+#define mlmeext_scan_state_str(mlmeext) scan_state_str((mlmeext)->sitesurvey_res.state)
+#define mlmeext_chk_scan_state(mlmeext, _state) ((mlmeext)->sitesurvey_res.state == (_state))
+#define mlmeext_set_scan_state(mlmeext, _state) \
+	do { \
+		((mlmeext)->sitesurvey_res.state = (_state)); \
+		((mlmeext)->sitesurvey_res.next_state = (_state)); \
+		rtw_mi_update_iface_status(&((container_of(mlmeext, _adapter, mlmeextpriv)->mlmepriv)), 0); \
+		/* RTW_INFO("set_scan_state:%s\n", scan_state_str(_state)); */ \
+		sitesurvey_set_offch_state(container_of(mlmeext, _adapter, mlmeextpriv), _state); \
+	} while (0)
+
+#define mlmeext_scan_next_state(mlmeext) ((mlmeext)->sitesurvey_res.next_state)
+#define mlmeext_set_scan_next_state(mlmeext, _state) \
+	do { \
+		((mlmeext)->sitesurvey_res.next_state = (_state)); \
+		/* RTW_INFO("set_scan_next_state:%s\n", scan_state_str(_state)); */ \
+	} while (0)
+
+#ifdef CONFIG_SCAN_BACKOP
+#define mlmeext_scan_backop_flags(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags)
+#define mlmeext_chk_scan_backop_flags(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags & (flags))
+#define mlmeext_assign_scan_backop_flags(mlmeext, flags) \
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags = (flags)); \
+		RTW_INFO("assign_scan_backop_flags:0x%02x\n", (mlmeext)->sitesurvey_res.backop_flags); \
+	} while (0)
+
+#define mlmeext_scan_backop_flags_sta(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_sta)
+#define mlmeext_chk_scan_backop_flags_sta(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_sta & (flags))
+#define mlmeext_assign_scan_backop_flags_sta(mlmeext, flags) \
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags_sta = (flags)); \
+	} while (0)
+
+#define mlmeext_scan_backop_flags_ap(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_ap)
+#define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_ap & (flags))
+#define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) \
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags_ap = (flags)); \
+	} while (0)
+#else
+#define mlmeext_scan_backop_flags(mlmeext) (0)
+#define mlmeext_chk_scan_backop_flags(mlmeext, flags) (0)
+#define mlmeext_assign_scan_backop_flags(mlmeext, flags) do {} while (0)
+
+#define mlmeext_scan_backop_flags_sta(mlmeext) (0)
+#define mlmeext_chk_scan_backop_flags_sta(mlmeext, flags) (0)
+#define mlmeext_assign_scan_backop_flags_sta(mlmeext, flags) do {} while (0)
+
+#define mlmeext_scan_backop_flags_ap(mlmeext) (0)
+#define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) (0)
+#define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) do {} while (0)
+#endif
+u32 rtw_scan_timeout_decision(_adapter *padapter);
+
+void init_mlme_default_rate_set(_adapter *padapter);
+int init_mlme_ext_priv(_adapter *padapter);
+int init_hw_mlme_ext(_adapter *padapter);
+void free_mlme_ext_priv(struct mlme_ext_priv *pmlmeext);
+extern struct xmit_frame *alloc_mgtxmitframe(struct xmit_priv *pxmitpriv);
+struct xmit_frame *alloc_mgtxmitframe_once(struct xmit_priv *pxmitpriv);
+
+/* void fill_fwpriv(_adapter * padapter, struct fw_priv *pfwpriv); */
+u8 judge_network_type(_adapter *padapter, unsigned char *rate, int ratelen);
+void get_rate_set(_adapter *padapter, unsigned char *pbssrate, int *bssrate_len);
+void set_mcs_rate_by_mask(u8 *mcs_set, u32 mask);
+void UpdateBrateTbl(_adapter *padapter, u8 *mBratesOS);
+void UpdateBrateTblForSoftAP(u8 *bssrateset, u32 bssratelen);
+void change_band_update_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 ch);
+
+void Set_MSR(_adapter *padapter, u8 type);
+
+u8 rtw_get_oper_ch(_adapter *adapter);
+void rtw_set_oper_ch(_adapter *adapter, u8 ch);
+u8 rtw_get_oper_bw(_adapter *adapter);
+void rtw_set_oper_bw(_adapter *adapter, u8 bw);
+u8 rtw_get_oper_choffset(_adapter *adapter);
+void rtw_set_oper_choffset(_adapter *adapter, u8 offset);
+u8	rtw_get_center_ch(u8 channel, u8 chnl_bw, u8 chnl_offset);
+systime rtw_get_on_oper_ch_time(_adapter *adapter);
+systime rtw_get_on_cur_ch_time(_adapter *adapter);
+
+u8 rtw_get_offset_by_chbw(u8 ch, u8 bw, u8 *r_offset);
+
+void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char channel_offset, unsigned short bwmode);
+
+unsigned int decide_wait_for_beacon_timeout(unsigned int bcn_interval);
+
+void _clear_cam_entry(_adapter *padapter, u8 entry);
+void write_cam_from_cache(_adapter *adapter, u8 id);
+void rtw_sec_cam_swap(_adapter *adapter, u8 cam_id_a, u8 cam_id_b);
+void rtw_clean_dk_section(_adapter *adapter);
+void rtw_clean_hw_dk_cam(_adapter *adapter);
+
+/* modify both HW and cache */
+void write_cam(_adapter *padapter, u8 id, u16 ctrl, u8 *mac, u8 *key);
+void clear_cam_entry(_adapter *padapter, u8 id);
+
+/* modify cache only */
+void write_cam_cache(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key);
+void clear_cam_cache(_adapter *adapter, u8 id);
+
+void invalidate_cam_all(_adapter *padapter);
+void CAM_empty_entry(PADAPTER Adapter, u8 ucIndex);
+
+void flush_all_cam_entry(_adapter *padapter);
+
+BOOLEAN IsLegal5GChannel(PADAPTER Adapter, u8 channel);
+
+void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType);
+u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid);
+void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src, _adapter *padapter, bool update_ie);
+
+u8 *get_my_bssid(WLAN_BSSID_EX *pnetwork);
+u16 get_beacon_interval(WLAN_BSSID_EX *bss);
+
+int is_client_associated_to_ap(_adapter *padapter);
+int is_client_associated_to_ibss(_adapter *padapter);
+int is_IBSS_empty(_adapter *padapter);
+
+unsigned char check_assoc_AP(u8 *pframe, uint len);
+
+int WMM_param_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs	pIE);
+#ifdef CONFIG_WFD
+void rtw_process_wfd_ie(_adapter *adapter, u8 *ie, u8 ie_len, const char *tag);
+void rtw_process_wfd_ies(_adapter *adapter, u8 *ies, u8 ies_len, const char *tag);
+#endif
+void WMMOnAssocRsp(_adapter *padapter);
+
+void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void HT_info_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void HTOnAssocRsp(_adapter *padapter);
+
+void ERP_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void VCS_update(_adapter *padapter, struct sta_info *psta);
+void	update_ldpc_stbc_cap(struct sta_info *psta);
+
+int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
+		struct beacon_keys *recv_beacon);
+int validate_beacon_len(u8 *pframe, uint len);
+void rtw_dump_bcn_keys(struct beacon_keys *recv_beacon);
+int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len);
+void update_beacon_info(_adapter *padapter, u8 *pframe, uint len, struct sta_info *psta);
+#ifdef CONFIG_DFS
+void process_csa_ie(_adapter *padapter, u8 *ies, uint ies_len);
+#endif /* CONFIG_DFS */
+void update_capinfo(PADAPTER Adapter, u16 updateCap);
+void update_wireless_mode(_adapter *padapter);
+void update_tx_basic_rate(_adapter *padapter, u8 modulation);
+void update_sta_basic_rate(struct sta_info *psta, u8 wireless_mode);
+int rtw_ies_get_supported_rate(u8 *ies, uint ies_len, u8 *rate_set, u8 *rate_num);
+
+/* for sta/adhoc mode */
+void update_sta_info(_adapter *padapter, struct sta_info *psta);
+unsigned int update_basic_rate(unsigned char *ptn, unsigned int ptn_sz);
+unsigned int update_supported_rate(unsigned char *ptn, unsigned int ptn_sz);
+void Update_RA_Entry(_adapter *padapter, struct sta_info *psta);
+void set_sta_rate(_adapter *padapter, struct sta_info *psta);
+
+unsigned int receive_disconnect(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, u8 locally_generated);
+
+unsigned char get_highest_rate_idx(u64 mask);
+unsigned char get_lowest_rate_idx_ex(u64 mask, int start_bit);
+#define get_lowest_rate_idx(mask) get_lowest_rate_idx_ex(mask, 0)
+
+int support_short_GI(_adapter *padapter, struct HT_caps_element *pHT_caps, u8 bwmode);
+unsigned int is_ap_in_tkip(_adapter *padapter);
+unsigned int is_ap_in_wep(_adapter *padapter);
+unsigned int should_forbid_n_rate(_adapter *padapter);
+
+bool _rtw_camctl_chk_cap(_adapter *adapter, u8 cap);
+void _rtw_camctl_set_flags(_adapter *adapter, u32 flags);
+void rtw_camctl_set_flags(_adapter *adapter, u32 flags);
+void _rtw_camctl_clr_flags(_adapter *adapter, u32 flags);
+void rtw_camctl_clr_flags(_adapter *adapter, u32 flags);
+bool _rtw_camctl_chk_flags(_adapter *adapter, u32 flags);
+
+struct sec_cam_bmp;
+void dump_sec_cam_map(void *sel, struct sec_cam_bmp *map, u8 max_num);
+void rtw_sec_cam_map_clr_all(struct sec_cam_bmp *map);
+
+bool _rtw_camid_is_gk(_adapter *adapter, u8 cam_id);
+bool rtw_camid_is_gk(_adapter *adapter, u8 cam_id);
+s16 rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk);
+s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, u8 gk, bool *used);
+void rtw_camid_free(_adapter *adapter, u8 cam_id);
+u8 rtw_get_sec_camid(_adapter *adapter, u8 max_bk_key_num, u8 *sec_key_id);
+
+struct macid_bmp;
+struct macid_ctl_t;
+void dump_macid_map(void *sel, struct macid_bmp *map, u8 max_num);
+bool rtw_macid_is_set(struct macid_bmp *map, u8 id);
+void rtw_macid_map_clr(struct macid_bmp *map, u8 id);
+bool rtw_macid_is_used(struct macid_ctl_t *macid_ctl, u8 id);
+bool rtw_macid_is_bmc(struct macid_ctl_t *macid_ctl, u8 id);
+u8 rtw_macid_get_iface_bmp(struct macid_ctl_t *macid_ctl, u8 id);
+bool rtw_macid_is_iface_shared(struct macid_ctl_t *macid_ctl, u8 id);
+bool rtw_macid_is_iface_specific(struct macid_ctl_t *macid_ctl, u8 id, _adapter *adapter);
+s8 rtw_macid_get_ch_g(struct macid_ctl_t *macid_ctl, u8 id);
+void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta);
+void rtw_release_macid(_adapter *padapter, struct sta_info *psta);
+u8 rtw_search_max_mac_id(_adapter *padapter);
+void rtw_macid_ctl_set_h2c_msr(struct macid_ctl_t *macid_ctl, u8 id, u8 h2c_msr);
+void rtw_macid_ctl_set_bw(struct macid_ctl_t *macid_ctl, u8 id, u8 bw);
+void rtw_macid_ctl_set_vht_en(struct macid_ctl_t *macid_ctl, u8 id, u8 en);
+void rtw_macid_ctl_set_rate_bmp0(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp);
+void rtw_macid_ctl_set_rate_bmp1(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp);
+void rtw_macid_ctl_init_sleep_reg(struct macid_ctl_t *macid_ctl, u16 m0, u16 m1, u16 m2, u16 m3);
+void rtw_macid_ctl_init(struct macid_ctl_t *macid_ctl);
+void rtw_macid_ctl_deinit(struct macid_ctl_t *macid_ctl);
+u8 rtw_iface_bcmc_id_get(_adapter *padapter);
+void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id);
+
+bool rtw_bmp_is_set(const u8 *bmp, u8 bmp_len, u8 id);
+void rtw_bmp_set(u8 *bmp, u8 bmp_len, u8 id);
+void rtw_bmp_clear(u8 *bmp, u8 bmp_len, u8 id);
+bool rtw_bmp_not_empty(const u8 *bmp, u8 bmp_len);
+bool rtw_bmp_not_empty_exclude_bit0(const u8 *bmp, u8 bmp_len);
+
+#ifdef CONFIG_AP_MODE
+bool rtw_tim_map_is_set(_adapter *padapter, const u8 *map, u8 id);
+void rtw_tim_map_set(_adapter *padapter, u8 *map, u8 id);
+void rtw_tim_map_clear(_adapter *padapter, u8 *map, u8 id);
+bool rtw_tim_map_anyone_be_set(_adapter *padapter, const u8 *map);
+bool rtw_tim_map_anyone_be_set_exclude_aid0(_adapter *padapter, const u8 *map);
+#endif /* CONFIG_AP_MODE */
+
+u32 report_join_res(_adapter *padapter, int res);
+void report_survey_event(_adapter *padapter, union recv_frame *precv_frame);
+void report_surveydone_event(_adapter *padapter);
+u32 report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated);
+void report_add_sta_event(_adapter *padapter, unsigned char *MacAddr);
+bool rtw_port_switch_chk(_adapter *adapter);
+void report_wmm_edca_update(_adapter *padapter);
+
+void beacon_timing_control(_adapter *padapter);
+u8 chk_bmc_sleepq_cmd(_adapter *padapter);
+extern u8 set_tx_beacon_cmd(_adapter *padapter);
+unsigned int setup_beacon_frame(_adapter *padapter, unsigned char *beacon_frame);
+void update_mgnt_tx_rate(_adapter *padapter, u8 rate);
+void update_monitor_frame_attrib(_adapter *padapter, struct pkt_attrib *pattrib);
+void update_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib);
+void update_mgntframe_attrib_addr(_adapter *padapter, struct xmit_frame *pmgntframe);
+void dump_mgntframe(_adapter *padapter, struct xmit_frame *pmgntframe);
+s32 dump_mgntframe_and_wait(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms);
+s32 dump_mgntframe_and_wait_ack(_adapter *padapter, struct xmit_frame *pmgntframe);
+s32 dump_mgntframe_and_wait_ack_timeout(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms);
+
+#ifdef CONFIG_P2P
+int get_reg_classes_full_count(struct p2p_channels *channel_list);
+void issue_probersp_p2p(_adapter *padapter, unsigned char *da);
+void issue_p2p_provision_request(_adapter *padapter, u8 *pssid, u8 ussidlen, u8 *pdev_raddr);
+void issue_p2p_GO_request(_adapter *padapter, u8 *raddr);
+void issue_probereq_p2p(_adapter *padapter, u8 *da);
+int issue_probereq_p2p_ex(_adapter *adapter, u8 *da, int try_cnt, int wait_ms);
+void issue_p2p_invitation_response(_adapter *padapter, u8 *raddr, u8 dialogToken, u8 success);
+void issue_p2p_invitation_request(_adapter *padapter, u8 *raddr);
+#endif /* CONFIG_P2P */
+void issue_beacon(_adapter *padapter, int timeout_ms);
+void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probereq);
+void _issue_assocreq(_adapter *padapter, u8 is_assoc);
+void issue_assocreq(_adapter *padapter);
+void issue_reassocreq(_adapter *padapter);
+void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *pstat, int pkt_type);
+void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status);
+void issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da);
+s32 issue_probereq_ex(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps, int try_cnt, int wait_ms);
+int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms);
+int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int try_cnt, int wait_ms);
+int issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason);
+int issue_deauth_ex(_adapter *padapter, u8 *da, unsigned short reason, int try_cnt, int wait_ms);
+void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset);
+void issue_addba_req(_adapter *adapter, unsigned char *ra, u8 tid);
+void issue_addba_rsp(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size);
+u8 issue_addba_rsp_wait_ack(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size, int try_cnt, int wait_ms);
+void issue_del_ba(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator);
+int issue_del_ba_ex(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator, int try_cnt, int wait_ms);
+void issue_action_BSSCoexistPacket(_adapter *padapter);
+
+#ifdef CONFIG_IEEE80211W
+void issue_action_SA_Query(_adapter *padapter, unsigned char *raddr, unsigned char action, unsigned short tid, u8 key_type);
+int issue_deauth_11w(_adapter *padapter, unsigned char *da, unsigned short reason, u8 key_type);
+#endif /* CONFIG_IEEE80211W */
+int issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode);
+int issue_action_SM_PS_wait_ack(_adapter *padapter, unsigned char *raddr, u8 NewMimoPsMode, int try_cnt, int wait_ms);
+
+unsigned int send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid, u8 force);
+unsigned int send_delba_sta_tid_wait_ack(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid, u8 force);
+
+unsigned int send_delba(_adapter *padapter, u8 initiator, u8 *addr);
+unsigned int send_beacon(_adapter *padapter);
+
+void start_clnt_assoc(_adapter *padapter);
+void start_clnt_auth(_adapter *padapter);
+void start_clnt_join(_adapter *padapter);
+void start_create_ibss(_adapter *padapter);
+
+unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnProbeReq(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnProbeRsp(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int DoReserved(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAtim(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnDeAuth(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction(_adapter *padapter, union recv_frame *precv_frame);
+
+unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_qos(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_dls(_adapter *padapter, union recv_frame *precv_frame);
+#ifdef CONFIG_RTW_WNM
+unsigned int on_action_wnm(_adapter *adapter, union recv_frame *rframe);
+#endif
+
+#define RX_AMPDU_ACCEPT_INVALID 0xFF
+#define RX_AMPDU_SIZE_INVALID 0xFF
+
+enum rx_ampdu_reason {
+	RX_AMPDU_DRV_FIXED = 1,
+	RX_AMPDU_BTCOEX = 2, /* not used, because BTCOEX has its own variable management */
+	RX_AMPDU_DRV_SCAN = 3,
+};
+u8 rtw_rx_ampdu_size(_adapter *adapter);
+bool rtw_rx_ampdu_is_accept(_adapter *adapter);
+bool rtw_rx_ampdu_set_size(_adapter *adapter, u8 size, u8 reason);
+bool rtw_rx_ampdu_set_accept(_adapter *adapter, u8 accept, u8 reason);
+u8 rx_ampdu_apply_sta_tid(_adapter *adapter, struct sta_info *sta, u8 tid, u8 accept, u8 size);
+u8 rx_ampdu_size_sta_limit(_adapter *adapter, struct sta_info *sta);
+u8 rx_ampdu_apply_sta(_adapter *adapter, struct sta_info *sta, u8 accept, u8 size);
+u16 rtw_rx_ampdu_apply(_adapter *adapter);
+
+unsigned int OnAction_back(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int on_action_public(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_ht(_adapter *padapter, union recv_frame *precv_frame);
+#ifdef CONFIG_IEEE80211W
+unsigned int OnAction_sa_query(_adapter *padapter, union recv_frame *precv_frame);
+#endif /* CONFIG_IEEE80211W */
+unsigned int on_action_rm(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_wmm(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_p2p(_adapter *padapter, union recv_frame *precv_frame);
+
+#ifdef CONFIG_RTW_80211R
+void rtw_ft_update_bcn(_adapter *padapter, union recv_frame *precv_frame);
+void rtw_ft_start_clnt_join(_adapter *padapter);
+u8 rtw_ft_update_rsnie(_adapter *padapter, u8 bwrite, 
+	struct pkt_attrib *pattrib, u8 **pframe);
+void rtw_ft_build_auth_req_ies(_adapter *padapter, 
+	struct pkt_attrib *pattrib, u8 **pframe);
+void rtw_ft_build_assoc_req_ies(_adapter *padapter, 
+	u8 is_reassoc, struct pkt_attrib *pattrib, u8 **pframe);
+u8 rtw_ft_update_auth_rsp_ies(_adapter *padapter, u8 *pframe, u32 len);
+void rtw_ft_start_roam(_adapter *padapter, u8 *pTargetAddr);
+void rtw_ft_issue_action_req(_adapter *padapter, u8 *pTargetAddr);
+void rtw_ft_report_evt(_adapter *padapter);
+void rtw_ft_report_reassoc_evt(_adapter *padapter, u8 *pMacAddr);
+void rtw_ft_link_timer_hdl(void *ctx);
+void rtw_ft_roam_timer_hdl(void *ctx);
+void rtw_ft_roam_status_reset(_adapter *padapter);
+#endif
+#ifdef CONFIG_RTW_WNM
+void rtw_wnm_roam_scan_hdl(void *ctx);
+void rtw_wnm_process_btm_req(_adapter *padapter,  u8* pframe, u32 frame_len);
+void rtw_wnm_reset_btm_candidate(struct roam_nb_info *pnb);
+void rtw_wnm_reset_btm_state(_adapter *padapter);
+void rtw_wnm_issue_action(_adapter *padapter, u8 action, u8 reason);
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+u32 rtw_wnm_btm_candidates_survey(_adapter *padapter, u8* pframe, u32 elem_len, u8 is_preference);
+#endif
+void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res);
+void mlmeext_sta_del_event_callback(_adapter *padapter);
+void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta);
+
+void linked_status_chk(_adapter *padapter, u8 from_timer);
+
+void _linked_info_dump(_adapter *padapter);
+
+void survey_timer_hdl(void *ctx);
+#ifdef CONFIG_RTW_REPEATER_SON
+void rson_timer_hdl(void *ctx);
+#endif
+void link_timer_hdl(void *ctx);
+void addba_timer_hdl(void *ctx);
+#ifdef CONFIG_IEEE80211W
+void sa_query_timer_hdl(void *ctx);
+#endif /* CONFIG_IEEE80211W */
+#if 0
+void reauth_timer_hdl(_adapter *padapter);
+void reassoc_timer_hdl(_adapter *padapter);
+#endif
+
+#define set_survey_timer(mlmeext, ms) \
+	do { \
+		/*RTW_INFO("%s set_survey_timer(%p, %d)\n", __FUNCTION__, (mlmeext), (ms));*/ \
+		_set_timer(&(mlmeext)->survey_timer, (ms)); \
+	} while (0)
+
+#define set_link_timer(mlmeext, ms) \
+	do { \
+		/*RTW_INFO("%s set_link_timer(%p, %d)\n", __FUNCTION__, (mlmeext), (ms));*/ \
+		_set_timer(&(mlmeext)->link_timer, (ms)); \
+	} while (0)
+
+bool rtw_is_basic_rate_cck(u8 rate);
+bool rtw_is_basic_rate_ofdm(u8 rate);
+bool rtw_is_basic_rate_mix(u8 rate);
+
+extern int cckrates_included(unsigned char *rate, int ratelen);
+extern int cckratesonly_included(unsigned char *rate, int ratelen);
+
+extern void process_addba_req(_adapter *padapter, u8 *paddba_req, u8 *addr);
+
+extern void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len);
+extern void correct_TSF(_adapter *padapter, struct mlme_ext_priv *pmlmeext);
+extern void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len);
+extern u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer);
+
+void rtw_process_bar_frame(_adapter *padapter, union recv_frame *precv_frame);
+void rtw_join_done_chk_ch(_adapter *padapter, int join_res);
+
+int rtw_chk_start_clnt_join(_adapter *padapter, u8 *ch, u8 *bw, u8 *offset);
+
+#ifdef CONFIG_PLATFORM_ARM_SUN8I
+	#define BUSY_TRAFFIC_SCAN_DENY_PERIOD	8000
+#else
+	#define BUSY_TRAFFIC_SCAN_DENY_PERIOD	12000
+#endif
+
+struct cmd_hdl {
+	uint	parmsize;
+	u8(*h2cfuns)(struct _ADAPTER *padapter, u8 *pbuf);
+};
+
+void rtw_leave_opch(_adapter *adapter);
+void rtw_back_opch(_adapter *adapter);
+
+u8 read_macreg_hdl(_adapter *padapter, u8 *pbuf);
+u8 write_macreg_hdl(_adapter *padapter, u8 *pbuf);
+u8 read_bbreg_hdl(_adapter *padapter, u8 *pbuf);
+u8 write_bbreg_hdl(_adapter *padapter, u8 *pbuf);
+u8 read_rfreg_hdl(_adapter *padapter, u8 *pbuf);
+u8 write_rfreg_hdl(_adapter *padapter, u8 *pbuf);
+
+
+u8 NULL_hdl(_adapter *padapter, u8 *pbuf);
+u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf);
+u8 disconnect_hdl(_adapter *padapter, u8 *pbuf);
+u8 createbss_hdl(_adapter *padapter, u8 *pbuf);
+u8 setopmode_hdl(_adapter *padapter, u8 *pbuf);
+u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf);
+u8 setauth_hdl(_adapter *padapter, u8 *pbuf);
+u8 setkey_hdl(_adapter *padapter, u8 *pbuf);
+u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf);
+u8 set_assocsta_hdl(_adapter *padapter, u8 *pbuf);
+u8 del_assocsta_hdl(_adapter *padapter, u8 *pbuf);
+u8 add_ba_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 add_ba_rsp_hdl(_adapter *padapter, unsigned char *pbuf);
+
+void rtw_ap_wep_pk_setting(_adapter *adapter, struct sta_info *psta);
+
+u8 mlme_evt_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 h2c_msg_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 rtw_set_chbw_hdl(_adapter *padapter, u8 *pbuf);
+u8 set_chplan_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 led_blink_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf);	/* Kurt: Handling DFS channel switch announcement ie. */
+u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 run_in_thread_hdl(_adapter *padapter, u8 *pbuf);
+u8 rtw_getmacreg_hdl(_adapter *padapter, u8 *pbuf);
+
+#define GEN_DRV_CMD_HANDLER(size, cmd)	{size, &cmd ## _hdl},
+#define GEN_MLME_EXT_HANDLER(size, cmd)	{size, cmd},
+
+#ifdef _RTW_CMD_C_
+
+struct cmd_hdl wlancmds[] = {
+	GEN_DRV_CMD_HANDLER(sizeof(struct readMAC_parm), rtw_getmacreg) /*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 joinbss_parm), join_cmd_hdl)  /*14*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct disconnect_parm), disconnect_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct createbss_parm), createbss_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct setopmode_parm), setopmode_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct sitesurvey_parm), sitesurvey_cmd_hdl)  /*18*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct setauth_parm), setauth_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct setkey_parm), setkey_hdl)  /*20*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct set_stakey_parm), set_stakey_hdl)
+	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(0, NULL)
+	GEN_MLME_EXT_HANDLER(0, 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_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct set_ch_parm), rtw_set_chbw_hdl) /* 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_hdl) /*55*/
+
+	GEN_MLME_EXT_HANDLER(0, mlme_evt_hdl) /*56*/
+	GEN_MLME_EXT_HANDLER(0, rtw_drvextra_cmd_hdl) /*57*/
+
+	GEN_MLME_EXT_HANDLER(0, h2c_msg_hdl) /*58*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct SetChannelPlan_param), set_chplan_hdl) /*59*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct LedBlink_param), led_blink_hdl) /*60*/
+
+	GEN_MLME_EXT_HANDLER(sizeof(struct SetChannelSwitch_param), set_csa_hdl) /*61*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct TDLSoption_param), tdls_hdl) /*62*/
+	GEN_MLME_EXT_HANDLER(0, chk_bmc_sleepq_hdl) /*63*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct RunInThread_param), run_in_thread_hdl) /*64*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct addBaRsp_parm), add_ba_rsp_hdl) /* 65 */
+	GEN_MLME_EXT_HANDLER(sizeof(struct rm_event), rm_post_event_hdl) /* 66 */
+};
+
+#endif
+
+struct C2HEvent_Header {
+
+#ifdef CONFIG_LITTLE_ENDIAN
+
+	unsigned int len:16;
+	unsigned int ID:8;
+	unsigned int seq:8;
+
+#elif defined(CONFIG_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;
+
+};
+
+void rtw_dummy_event_callback(_adapter *adapter , u8 *pbuf);
+void rtw_fwdbg_event_callback(_adapter *adapter , u8 *pbuf);
+
+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 */
+	GEN_EVT_CODE(_WMM),					/*25*/
+#ifdef CONFIG_IEEE80211W
+	GEN_EVT_CODE(_TimeoutSTA),
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_RTW_80211R
+	GEN_EVT_CODE(_FT_REASSOC),
+#endif
+	MAX_C2HEVT
+};
+
+
+#ifdef _RTW_MLME_EXT_C_
+
+static struct fwevent wlanevents[] = {
+	{0, rtw_dummy_event_callback},	/*0*/
+	{0, NULL},
+	{0, NULL},
+	{0, NULL},
+	{0, NULL},
+	{0, NULL},
+	{0, NULL},
+	{0, NULL},
+	{0, &rtw_survey_event_callback},		/*8*/
+	{sizeof(struct surveydone_event), &rtw_surveydone_event_callback},	/*9*/
+
+	{0, &rtw_joinbss_event_callback},		/*10*/
+	{sizeof(struct stassoc_event), &rtw_stassoc_event_callback},
+	{sizeof(struct stadel_event), &rtw_stadel_event_callback},
+	{0, &rtw_atimdone_event_callback},
+	{0, rtw_dummy_event_callback},
+	{0, NULL},	/*15*/
+	{0, NULL},
+	{0, NULL},
+	{0, NULL},
+	{0, rtw_fwdbg_event_callback},
+	{0, NULL},	 /*20*/
+	{0, NULL},
+	{0, NULL},
+	{0, &rtw_cpwm_event_callback},
+	{0, NULL},
+	{0, &rtw_wmm_event_callback}, /*25*/
+#ifdef CONFIG_IEEE80211W
+	{sizeof(struct stadel_event), &rtw_sta_timeout_event_callback},
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_RTW_80211R
+	{sizeof(struct stassoc_event), &rtw_ft_reassoc_event_callback},
+#endif
+};
+
+#endif/* _RTW_MLME_EXT_C_ */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp.h
new file mode 100644
index 000000000000..2fbf74e530b3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp.h
@@ -0,0 +1,936 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MP_H_
+#define _RTW_MP_H_
+
+#define RTWPRIV_VER_INFO	1
+
+#define MAX_MP_XMITBUF_SZ	2048
+#define NR_MP_XMITFRAME		8
+
+struct mp_xmit_frame {
+	_list	list;
+
+	struct pkt_attrib attrib;
+
+	_pkt *pkt;
+
+	int frame_tag;
+
+	_adapter *padapter;
+
+#ifdef CONFIG_USB_HCI
+
+	/* insert urb, irp, and irpcnt info below... */
+	/* max frag_cnt = 8 */
+
+	u8 *mem_addr;
+	u32 sz[8];
+
+#if defined(PLATFORM_OS_XP) || defined(PLATFORM_LINUX)
+	PURB pxmit_urb[8];
+#endif
+
+#ifdef PLATFORM_OS_XP
+	PIRP pxmit_irp[8];
+#endif
+
+	u8 bpending[8];
+	sint ac_tag[8];
+	sint last[8];
+	uint irpcnt;
+	uint fragcnt;
+#endif /* CONFIG_USB_HCI */
+
+	uint mem[(MAX_MP_XMITBUF_SZ >> 2)];
+};
+
+struct mp_wiparam {
+	u32 bcompleted;
+	u32 act_type;
+	u32 io_offset;
+	u32 io_value;
+};
+
+typedef void(*wi_act_func)(void *padapter);
+
+#ifdef PLATFORM_WINDOWS
+struct mp_wi_cntx {
+	u8 bmpdrv_unload;
+
+	/* Work Item */
+	NDIS_WORK_ITEM mp_wi;
+	NDIS_EVENT mp_wi_evt;
+	_lock mp_wi_lock;
+	u8 bmp_wi_progress;
+	wi_act_func curractfunc;
+	/* Variable needed in each implementation of CurrActFunc. */
+	struct mp_wiparam param;
+};
+#endif
+
+struct mp_tx {
+	u8 stop;
+	u32 count, sended;
+	u8 payload;
+	struct pkt_attrib attrib;
+	/* struct tx_desc desc; */
+	/* u8 resvdtx[7]; */
+	u8 desc[TXDESC_SIZE];
+	u8 *pallocated_buf;
+	u8 *buf;
+	u32 buf_size, write_size;
+	_thread_hdl_ PktTxThread;
+};
+
+#define MP_MAX_LINES		1000
+#define MP_MAX_LINES_BYTES	256
+
+
+typedef struct _RT_PMAC_PKT_INFO {
+	UCHAR			MCS;
+	UCHAR			Nss;
+	UCHAR			Nsts;
+	UINT			N_sym;
+	UCHAR			SIGA2B3;
+} RT_PMAC_PKT_INFO, *PRT_PMAC_PKT_INFO;
+
+typedef struct _RT_PMAC_TX_INFO {
+	u8			bEnPMacTx:1;		/* 0: Disable PMac 1: Enable PMac */
+	u8			Mode:3;				/* 0: Packet TX 3:Continuous TX */
+	u8			Ntx:4;				/* 0-7 */
+	u8			TX_RATE;			/* MPT_RATE_E */
+	u8			TX_RATE_HEX;
+	u8			TX_SC;
+	u8			bSGI:1;
+	u8			bSPreamble:1;
+	u8			bSTBC:1;
+	u8			bLDPC:1;
+	u8			NDP_sound:1;
+	u8			BandWidth:3;		/* 0: 20 1:40 2:80Mhz */
+	u8			m_STBC;			/* bSTBC + 1 */
+	USHORT			PacketPeriod;
+	UINT		PacketCount;
+	UINT		PacketLength;
+	u8			PacketPattern;
+	USHORT			SFD;
+	u8			SignalField;
+	u8			ServiceField;
+	USHORT			LENGTH;
+	u8			CRC16[2];
+	u8			LSIG[3];
+	u8			HT_SIG[6];
+	u8			VHT_SIG_A[6];
+	u8			VHT_SIG_B[4];
+	u8			VHT_SIG_B_CRC;
+	u8			VHT_Delimiter[4];
+	u8			MacAddress[6];
+} RT_PMAC_TX_INFO, *PRT_PMAC_TX_INFO;
+
+
+typedef VOID (*MPT_WORK_ITEM_HANDLER)(IN PVOID Adapter);
+typedef struct _MPT_CONTEXT {
+	/* Indicate if we have started Mass Production Test. */
+	BOOLEAN			bMassProdTest;
+
+	/* Indicate if the driver is unloading or unloaded. */
+	BOOLEAN			bMptDrvUnload;
+
+	_sema			MPh2c_Sema;
+	_timer			MPh2c_timeout_timer;
+	/* Event used to sync H2c for BT control */
+
+	BOOLEAN		MptH2cRspEvent;
+	BOOLEAN		MptBtC2hEvent;
+	BOOLEAN		bMPh2c_timeout;
+
+	/* 8190 PCI does not support NDIS_WORK_ITEM. */
+	/* Work Item for Mass Production Test. */
+	/* NDIS_WORK_ITEM	MptWorkItem;
+	*	RT_WORK_ITEM		MptWorkItem; */
+	/* Event used to sync the case unloading driver and MptWorkItem is still in progress.
+	*	NDIS_EVENT		MptWorkItemEvent; */
+	/* To protect the following variables.
+	*	NDIS_SPIN_LOCK		MptWorkItemSpinLock; */
+	/* Indicate a MptWorkItem is scheduled and not yet finished. */
+	BOOLEAN			bMptWorkItemInProgress;
+	/* An instance which implements function and context of MptWorkItem. */
+	MPT_WORK_ITEM_HANDLER	CurrMptAct;
+
+	/* 1=Start, 0=Stop from UI. */
+	ULONG			MptTestStart;
+	/* _TEST_MODE, defined in MPT_Req2.h */
+	ULONG			MptTestItem;
+	/* Variable needed in each implementation of CurrMptAct. */
+	ULONG			MptActType;	/* Type of action performed in CurrMptAct. */
+	/* The Offset of IO operation is depend of MptActType. */
+	ULONG			MptIoOffset;
+	/* The Value of IO operation is depend of MptActType. */
+	ULONG			MptIoValue;
+	/* The RfPath of IO operation is depend of MptActType. */
+
+	ULONG			mpt_rf_path;
+
+
+	WIRELESS_MODE		MptWirelessModeToSw;	/* Wireless mode to switch. */
+	u8			MptChannelToSw;	/* Channel to switch. */
+	u8			MptInitGainToSet;	/* Initial gain to set. */
+	/* ULONG			bMptAntennaA;		 */ /* TRUE if we want to use antenna A. */
+	ULONG			MptBandWidth;		/* bandwidth to switch. */
+
+	ULONG			mpt_rate_index;/* rate index. */
+
+	/* Register value kept for Single Carrier Tx test. */
+	u8			btMpCckTxPower;
+	/* Register value kept for Single Carrier Tx test. */
+	u8			btMpOfdmTxPower;
+	/* For MP Tx Power index */
+	u8			TxPwrLevel[4];	/* rf-A, rf-B*/
+	u32			RegTxPwrLimit;
+	/* Content of RCR Regsiter for Mass Production Test. */
+	ULONG			MptRCR;
+	/* TRUE if we only receive packets with specific pattern. */
+	BOOLEAN			bMptFilterPattern;
+	/* Rx OK count, statistics used in Mass Production Test. */
+	ULONG			MptRxOkCnt;
+	/* Rx CRC32 error count, statistics used in Mass Production Test. */
+	ULONG			MptRxCrcErrCnt;
+
+	BOOLEAN			bCckContTx;	/* TRUE if we are in CCK Continuous Tx test. */
+	BOOLEAN			bOfdmContTx;	/* TRUE if we are in OFDM Continuous Tx test. */
+		/* TRUE if we have start Continuous Tx test. */
+	BOOLEAN			is_start_cont_tx;
+
+	/* TRUE if we are in Single Carrier Tx test. */
+	BOOLEAN			bSingleCarrier;
+	/* TRUE if we are in Carrier Suppression Tx Test. */
+
+	BOOLEAN			is_carrier_suppression;
+
+	/* TRUE if we are in Single Tone Tx test. */
+
+	BOOLEAN			is_single_tone;
+
+
+	/* ACK counter asked by K.Y.. */
+	BOOLEAN			bMptEnableAckCounter;
+	ULONG			MptAckCounter;
+
+	/* SD3 Willis For 8192S to save 1T/2T RF table for ACUT	Only fro ACUT delete later ~~~! */
+	/* s1Byte		BufOfLines[2][MAX_LINES_HWCONFIG_TXT][MAX_BYTES_LINE_HWCONFIG_TXT]; */
+	/* s1Byte			BufOfLines[2][MP_MAX_LINES][MP_MAX_LINES_BYTES]; */
+	/* s4Byte			RfReadLine[2]; */
+
+	u8		APK_bound[2];	/* for APK	path A/path B */
+	BOOLEAN		bMptIndexEven;
+
+	u8		backup0xc50;
+	u8		backup0xc58;
+	u8		backup0xc30;
+	u8		backup0x52_RF_A;
+	u8		backup0x52_RF_B;
+
+	u4Byte			backup0x58_RF_A;
+	u4Byte			backup0x58_RF_B;
+
+	u1Byte			h2cReqNum;
+	u1Byte			c2hBuf[32];
+
+	u1Byte          btInBuf[100];
+	ULONG			mptOutLen;
+	u1Byte          mptOutBuf[100];
+	RT_PMAC_TX_INFO	PMacTxInfo;
+	RT_PMAC_PKT_INFO	PMacPktInfo;
+	u8 HWTxmode;
+
+	BOOLEAN			bldpc;
+	BOOLEAN			bstbc;
+} MPT_CONTEXT, *PMPT_CONTEXT;
+/* #endif */
+
+
+/* #define RTPRIV_IOCTL_MP					( SIOCIWFIRSTPRIV + 0x17) */
+enum {
+	WRITE_REG = 1,
+	READ_REG,
+	WRITE_RF,
+	READ_RF,
+	MP_START,
+	MP_STOP,
+	MP_RATE,
+	MP_CHANNEL,
+	MP_CHL_OFFSET,
+	MP_BANDWIDTH,
+	MP_TXPOWER,
+	MP_ANT_TX,
+	MP_ANT_RX,
+	MP_CTX,
+	MP_QUERY,
+	MP_ARX,
+	MP_PSD,
+	MP_PWRTRK,
+	MP_THER,
+	MP_IOCTL,
+	EFUSE_GET,
+	EFUSE_SET,
+	MP_RESET_STATS,
+	MP_DUMP,
+	MP_PHYPARA,
+	MP_SetRFPathSwh,
+	MP_QueryDrvStats,
+	CTA_TEST,
+	MP_DISABLE_BT_COEXIST,
+	MP_PwrCtlDM,
+	MP_GETVER,
+	MP_MON,
+	EFUSE_MASK,
+	EFUSE_FILE,
+	MP_TX,
+	MP_RX,
+	MP_IQK,
+	MP_LCK,
+	MP_HW_TX_MODE,
+	MP_GET_TXPOWER_INX,
+	MP_CUSTOMER_STR,
+	MP_PWRLMT,
+	MP_PWRBYRATE,
+	BT_EFUSE_FILE,
+	MP_SetBT,
+	MP_SWRFPath,
+	MP_NULL,
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	VENDOR_IE_SET ,
+	VENDOR_IE_GET ,
+#endif
+#ifdef CONFIG_WOWLAN
+	MP_WOW_ENABLE,
+	MP_WOW_SET_PATTERN,
+#endif
+#ifdef CONFIG_AP_WOWLAN
+	MP_AP_WOW_ENABLE,
+#endif
+	MP_SD_IREAD,
+	MP_SD_IWRITE,
+};
+
+struct mp_priv {
+	_adapter *papdater;
+
+	/* Testing Flag */
+	u32 mode;/* 0 for normal type packet, 1 for loopback packet (16bytes TXCMD) */
+
+	u32 prev_fw_state;
+
+	/* OID cmd handler */
+	struct mp_wiparam workparam;
+	/*	u8 act_in_progress; */
+
+	/* Tx Section */
+	u8 TID;
+	u32 tx_pktcount;
+	u32 pktInterval;
+	u32 pktLength;
+	struct mp_tx tx;
+
+	/* Rx Section */
+	u32 rx_bssidpktcount;
+	u32 rx_pktcount;
+	u32 rx_pktcount_filter_out;
+	u32 rx_crcerrpktcount;
+	u32 rx_pktloss;
+	BOOLEAN  rx_bindicatePkt;
+	struct recv_stat rxstat;
+
+	/* RF/BB relative */
+	u8 channel;
+	u8 bandwidth;
+	u8 prime_channel_offset;
+	u8 txpoweridx;
+	u8 rateidx;
+	u32 preamble;
+	/*	u8 modem; */
+	u32 CrystalCap;
+	/*	u32 curr_crystalcap; */
+
+	u16 antenna_tx;
+	u16 antenna_rx;
+	/*	u8 curr_rfpath; */
+
+	u8 check_mp_pkt;
+
+	u8 bSetTxPower;
+	/*	uint ForcedDataRate; */
+	u8 mp_dm;
+	u8 mac_filter[ETH_ALEN];
+	u8 bmac_filter;
+
+	/* RF PATH Setting for WLG WLA BTG BT */
+	u8 rf_path_cfg;
+
+	struct wlan_network mp_network;
+	NDIS_802_11_MAC_ADDRESS network_macaddr;
+
+#ifdef PLATFORM_WINDOWS
+	u32 rx_testcnt;
+	u32 rx_testcnt1;
+	u32 rx_testcnt2;
+	u32 tx_testcnt;
+	u32 tx_testcnt1;
+
+	struct mp_wi_cntx wi_cntx;
+
+	u8 h2c_result;
+	u8 h2c_seqnum;
+	u16 h2c_cmdcode;
+	u8 h2c_resp_parambuf[512];
+	_lock h2c_lock;
+	_lock wkitm_lock;
+	u32 h2c_cmdcnt;
+	NDIS_EVENT h2c_cmd_evt;
+	NDIS_EVENT c2h_set;
+	NDIS_EVENT h2c_clr;
+	NDIS_EVENT cpwm_int;
+
+	NDIS_EVENT scsir_full_evt;
+	NDIS_EVENT scsiw_empty_evt;
+#endif
+
+	u8 *pallocated_mp_xmitframe_buf;
+	u8 *pmp_xmtframe_buf;
+	_queue free_mp_xmitqueue;
+	u32 free_mp_xmitframe_cnt;
+	BOOLEAN bSetRxBssid;
+	BOOLEAN bTxBufCkFail;
+	BOOLEAN bRTWSmbCfg;
+	BOOLEAN bloopback;
+	BOOLEAN bloadefusemap;
+	BOOLEAN bloadBTefusemap;
+
+	MPT_CONTEXT	mpt_ctx;
+
+
+	u8		*TXradomBuffer;
+};
+
+typedef struct _IOCMD_STRUCT_ {
+	u8	cmdclass;
+	u16	value;
+	u8	index;
+} IOCMD_STRUCT;
+
+struct rf_reg_param {
+	u32 path;
+	u32 offset;
+	u32 value;
+};
+
+struct bb_reg_param {
+	u32 offset;
+	u32 value;
+};
+
+typedef struct _MP_FIRMWARE {
+	FIRMWARE_SOURCE eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8		*szFwBuffer;
+#else
+	u8			szFwBuffer[0x8000];
+#endif
+	u32		ulFwLength;
+} RT_MP_FIRMWARE, *PRT_MP_FIRMWARE;
+
+
+
+
+/* *********************************************************************** */
+
+#define LOWER	_TRUE
+#define RAISE	_FALSE
+
+/* Hardware Registers */
+#if 0
+#if 0
+#define IOCMD_CTRL_REG			0x102502C0
+#define IOCMD_DATA_REG			0x102502C4
+#else
+#define IOCMD_CTRL_REG			0x10250370
+#define IOCMD_DATA_REG			0x10250374
+#endif
+
+#define IOCMD_GET_THERMAL_METER		0xFD000028
+
+#define IOCMD_CLASS_BB_RF		0xF0
+#define IOCMD_BB_READ_IDX		0x00
+#define IOCMD_BB_WRITE_IDX		0x01
+#define IOCMD_RF_READ_IDX		0x02
+#define IOCMD_RF_WRIT_IDX		0x03
+#endif
+#define BB_REG_BASE_ADDR		0x800
+
+/* MP variables */
+#if 0
+#define _2MAC_MODE_	0
+#define _LOOPBOOK_MODE_	1
+#endif
+typedef enum _MP_MODE_ {
+	MP_OFF,
+	MP_ON,
+	MP_ERR,
+	MP_CONTINUOUS_TX,
+	MP_SINGLE_CARRIER_TX,
+	MP_CARRIER_SUPPRISSION_TX,
+	MP_SINGLE_TONE_TX,
+	MP_PACKET_TX,
+	MP_PACKET_RX
+} MP_MODE;
+
+typedef enum _TEST_MODE {
+	TEST_NONE                 ,
+	PACKETS_TX                ,
+	PACKETS_RX                ,
+	CONTINUOUS_TX             ,
+	OFDM_Single_Tone_TX       ,
+	CCK_Carrier_Suppression_TX
+} TEST_MODE;
+
+
+typedef enum _MPT_BANDWIDTH {
+	MPT_BW_20MHZ = 0,
+	MPT_BW_40MHZ_DUPLICATE = 1,
+	MPT_BW_40MHZ_ABOVE = 2,
+	MPT_BW_40MHZ_BELOW = 3,
+	MPT_BW_40MHZ = 4,
+	MPT_BW_80MHZ = 5,
+	MPT_BW_80MHZ_20_ABOVE = 6,
+	MPT_BW_80MHZ_20_BELOW = 7,
+	MPT_BW_80MHZ_20_BOTTOM = 8,
+	MPT_BW_80MHZ_20_TOP = 9,
+	MPT_BW_80MHZ_40_ABOVE = 10,
+	MPT_BW_80MHZ_40_BELOW = 11,
+} MPT_BANDWIDTHE, *PMPT_BANDWIDTH;
+
+#define MAX_RF_PATH_NUMS	RF_PATH_MAX
+
+
+extern u8 mpdatarate[NumRates];
+
+/* MP set force data rate base on the definition. */
+typedef enum _MPT_RATE_INDEX {
+	/* CCK rate. */
+	MPT_RATE_1M = 1 ,	/* 0 */
+	MPT_RATE_2M,
+	MPT_RATE_55M,
+	MPT_RATE_11M,	/* 3 */
+
+	/* OFDM rate. */
+	MPT_RATE_6M,	/* 4 */
+	MPT_RATE_9M,
+	MPT_RATE_12M,
+	MPT_RATE_18M,
+	MPT_RATE_24M,
+	MPT_RATE_36M,
+	MPT_RATE_48M,
+	MPT_RATE_54M,	/* 11 */
+
+	/* HT rate. */
+	MPT_RATE_MCS0,	/* 12 */
+	MPT_RATE_MCS1,
+	MPT_RATE_MCS2,
+	MPT_RATE_MCS3,
+	MPT_RATE_MCS4,
+	MPT_RATE_MCS5,
+	MPT_RATE_MCS6,
+	MPT_RATE_MCS7,	/* 19 */
+	MPT_RATE_MCS8,
+	MPT_RATE_MCS9,
+	MPT_RATE_MCS10,
+	MPT_RATE_MCS11,
+	MPT_RATE_MCS12,
+	MPT_RATE_MCS13,
+	MPT_RATE_MCS14,
+	MPT_RATE_MCS15,	/* 27 */
+	MPT_RATE_MCS16,
+	MPT_RATE_MCS17, /*  #29 */
+	MPT_RATE_MCS18,
+	MPT_RATE_MCS19,
+	MPT_RATE_MCS20,
+	MPT_RATE_MCS21,
+	MPT_RATE_MCS22, /*  #34 */
+	MPT_RATE_MCS23,
+	MPT_RATE_MCS24,
+	MPT_RATE_MCS25,
+	MPT_RATE_MCS26,
+	MPT_RATE_MCS27, /*  #39 */
+	MPT_RATE_MCS28, /*  #40 */
+	MPT_RATE_MCS29, /*  #41 */
+	MPT_RATE_MCS30, /*  #42 */
+	MPT_RATE_MCS31, /*  #43 */
+	/* VHT rate. Total: 20*/
+	MPT_RATE_VHT1SS_MCS0 = 100,/*  #44*/
+	MPT_RATE_VHT1SS_MCS1, /*  # */
+	MPT_RATE_VHT1SS_MCS2,
+	MPT_RATE_VHT1SS_MCS3,
+	MPT_RATE_VHT1SS_MCS4,
+	MPT_RATE_VHT1SS_MCS5,
+	MPT_RATE_VHT1SS_MCS6, /*  # */
+	MPT_RATE_VHT1SS_MCS7,
+	MPT_RATE_VHT1SS_MCS8,
+	MPT_RATE_VHT1SS_MCS9, /* #53 */
+	MPT_RATE_VHT2SS_MCS0, /* #54 */
+	MPT_RATE_VHT2SS_MCS1,
+	MPT_RATE_VHT2SS_MCS2,
+	MPT_RATE_VHT2SS_MCS3,
+	MPT_RATE_VHT2SS_MCS4,
+	MPT_RATE_VHT2SS_MCS5,
+	MPT_RATE_VHT2SS_MCS6,
+	MPT_RATE_VHT2SS_MCS7,
+	MPT_RATE_VHT2SS_MCS8,
+	MPT_RATE_VHT2SS_MCS9, /* #63 */
+	MPT_RATE_VHT3SS_MCS0,
+	MPT_RATE_VHT3SS_MCS1,
+	MPT_RATE_VHT3SS_MCS2,
+	MPT_RATE_VHT3SS_MCS3,
+	MPT_RATE_VHT3SS_MCS4,
+	MPT_RATE_VHT3SS_MCS5,
+	MPT_RATE_VHT3SS_MCS6, /*  #126 */
+	MPT_RATE_VHT3SS_MCS7,
+	MPT_RATE_VHT3SS_MCS8,
+	MPT_RATE_VHT3SS_MCS9,
+	MPT_RATE_VHT4SS_MCS0,
+	MPT_RATE_VHT4SS_MCS1, /*  #131 */
+	MPT_RATE_VHT4SS_MCS2,
+	MPT_RATE_VHT4SS_MCS3,
+	MPT_RATE_VHT4SS_MCS4,
+	MPT_RATE_VHT4SS_MCS5,
+	MPT_RATE_VHT4SS_MCS6, /*  #136 */
+	MPT_RATE_VHT4SS_MCS7,
+	MPT_RATE_VHT4SS_MCS8,
+	MPT_RATE_VHT4SS_MCS9,
+	MPT_RATE_LAST
+} MPT_RATE_E, *PMPT_RATE_E;
+
+#define MAX_TX_PWR_INDEX_N_MODE 64	/* 0x3F */
+
+#define MPT_IS_CCK_RATE(_value)		(MPT_RATE_1M <= _value && _value <= MPT_RATE_11M)
+#define MPT_IS_OFDM_RATE(_value)	(MPT_RATE_6M <= _value && _value <= MPT_RATE_54M)
+#define MPT_IS_HT_RATE(_value)		(MPT_RATE_MCS0 <= _value && _value <= MPT_RATE_MCS31)
+#define MPT_IS_HT_1S_RATE(_value)	(MPT_RATE_MCS0 <= _value && _value <= MPT_RATE_MCS7)
+#define MPT_IS_HT_2S_RATE(_value)	(MPT_RATE_MCS8 <= _value && _value <= MPT_RATE_MCS15)
+#define MPT_IS_HT_3S_RATE(_value)	(MPT_RATE_MCS16 <= _value && _value <= MPT_RATE_MCS23)
+#define MPT_IS_HT_4S_RATE(_value)	(MPT_RATE_MCS24 <= _value && _value <= MPT_RATE_MCS31)
+
+#define MPT_IS_VHT_RATE(_value)		(MPT_RATE_VHT1SS_MCS0 <= _value && _value <= MPT_RATE_VHT4SS_MCS9)
+#define MPT_IS_VHT_1S_RATE(_value)	(MPT_RATE_VHT1SS_MCS0 <= _value && _value <= MPT_RATE_VHT1SS_MCS9)
+#define MPT_IS_VHT_2S_RATE(_value)	(MPT_RATE_VHT2SS_MCS0 <= _value && _value <= MPT_RATE_VHT2SS_MCS9)
+#define MPT_IS_VHT_3S_RATE(_value)	(MPT_RATE_VHT3SS_MCS0 <= _value && _value <= MPT_RATE_VHT3SS_MCS9)
+#define MPT_IS_VHT_4S_RATE(_value)	(MPT_RATE_VHT4SS_MCS0 <= _value && _value <= MPT_RATE_VHT4SS_MCS9)
+
+#define MPT_IS_2SS_RATE(_rate) ((MPT_RATE_MCS8 <= _rate && _rate <= MPT_RATE_MCS15) || \
+	(MPT_RATE_VHT2SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT2SS_MCS9))
+#define MPT_IS_3SS_RATE(_rate) ((MPT_RATE_MCS16 <= _rate && _rate <= MPT_RATE_MCS23) || \
+	(MPT_RATE_VHT3SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT3SS_MCS9))
+#define MPT_IS_4SS_RATE(_rate) ((MPT_RATE_MCS24 <= _rate && _rate <= MPT_RATE_MCS31) || \
+	(MPT_RATE_VHT4SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT4SS_MCS9))
+
+typedef enum _POWER_MODE_ {
+	POWER_LOW = 0,
+	POWER_NORMAL
+} POWER_MODE;
+
+/* The following enumeration is used to define the value of Reg0xD00[30:28] or JaguarReg0x914[18:16]. */
+typedef enum _OFDM_TX_MODE {
+	OFDM_ALL_OFF		= 0,
+	OFDM_ContinuousTx	= 1,
+	OFDM_SingleCarrier	= 2,
+	OFDM_SingleTone	= 4,
+} OFDM_TX_MODE;
+
+
+#define RX_PKT_BROADCAST	1
+#define RX_PKT_DEST_ADDR	2
+#define RX_PKT_PHY_MATCH	3
+
+typedef enum _ENCRY_CTRL_STATE_ {
+	HW_CONTROL,		/* hw encryption& decryption */
+	SW_CONTROL,		/* sw encryption& decryption */
+	HW_ENCRY_SW_DECRY,	/* hw encryption & sw decryption */
+	SW_ENCRY_HW_DECRY	/* sw encryption & hw decryption */
+} ENCRY_CTRL_STATE;
+
+typedef enum	_MPT_TXPWR_DEF {
+	MPT_CCK,
+	MPT_OFDM, /* L and HT OFDM */
+	MPT_OFDM_AND_HT,
+	MPT_HT,
+	MPT_VHT
+} MPT_TXPWR_DEF;
+
+
+#define IS_MPT_HT_RATE(_rate)			(_rate >= MPT_RATE_MCS0 && _rate <= MPT_RATE_MCS31)
+#define IS_MPT_VHT_RATE(_rate)			(_rate >= MPT_RATE_VHT1SS_MCS0 && _rate <= MPT_RATE_VHT4SS_MCS9)
+#define IS_MPT_CCK_RATE(_rate)			(_rate >= MPT_RATE_1M && _rate <= MPT_RATE_11M)
+#define IS_MPT_OFDM_RATE(_rate)			(_rate >= MPT_RATE_6M && _rate <= MPT_RATE_54M)
+/*************************************************************************/
+#if 0
+extern struct mp_xmit_frame *alloc_mp_xmitframe(struct mp_priv *pmp_priv);
+extern int free_mp_xmitframe(struct xmit_priv *pxmitpriv, struct mp_xmit_frame *pmp_xmitframe);
+#endif
+
+extern s32 init_mp_priv(PADAPTER padapter);
+extern void free_mp_priv(struct mp_priv *pmp_priv);
+extern s32 MPT_InitializeAdapter(PADAPTER padapter, u8 Channel);
+extern void MPT_DeInitAdapter(PADAPTER padapter);
+extern s32 mp_start_test(PADAPTER padapter);
+extern void mp_stop_test(PADAPTER padapter);
+
+extern u32 _read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask);
+extern void _write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask, u32 val);
+
+extern u32 read_macreg(_adapter *padapter, u32 addr, u32 sz);
+extern void write_macreg(_adapter *padapter, u32 addr, u32 val, u32 sz);
+extern u32 read_bbreg(_adapter *padapter, u32 addr, u32 bitmask);
+extern void write_bbreg(_adapter *padapter, u32 addr, u32 bitmask, u32 val);
+extern u32 read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr);
+extern void write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 val);
+#ifdef CONFIG_ANTENNA_DIVERSITY
+u8 rtw_mp_set_antdiv(PADAPTER padapter, BOOLEAN bMain);
+#endif
+void	SetChannel(PADAPTER pAdapter);
+void	SetBandwidth(PADAPTER pAdapter);
+int	SetTxPower(PADAPTER pAdapter);
+void	SetAntenna(PADAPTER pAdapter);
+void	SetDataRate(PADAPTER pAdapter);
+void	SetAntenna(PADAPTER pAdapter);
+s32	SetThermalMeter(PADAPTER pAdapter, u8 target_ther);
+void	GetThermalMeter(PADAPTER pAdapter, u8 *value);
+void	SetContinuousTx(PADAPTER pAdapter, u8 bStart);
+void	SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart);
+void	SetSingleToneTx(PADAPTER pAdapter, u8 bStart);
+void	SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
+void	PhySetTxPowerLevel(PADAPTER pAdapter);
+void	fill_txdesc_for_mp(PADAPTER padapter, u8 *ptxdesc);
+void	SetPacketTx(PADAPTER padapter);
+void	SetPacketRx(PADAPTER pAdapter, u8 bStartRx, u8 bAB);
+void	ResetPhyRxPktCount(PADAPTER pAdapter);
+u32	GetPhyRxPktReceived(PADAPTER pAdapter);
+u32	GetPhyRxPktCRC32Error(PADAPTER pAdapter);
+s32	SetPowerTracking(PADAPTER padapter, u8 enable);
+void	GetPowerTracking(PADAPTER padapter, u8 *enable);
+u32	mp_query_psd(PADAPTER pAdapter, u8 *data);
+void	rtw_mp_trigger_iqk(PADAPTER padapter);
+void	rtw_mp_trigger_lck(PADAPTER padapter);
+u8 rtw_mp_mode_check(PADAPTER padapter);
+
+
+void hal_mpt_SwitchRfSetting(PADAPTER pAdapter);
+s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable);
+void hal_mpt_GetPowerTracking(PADAPTER padapter, u8 *enable);
+void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14);
+void hal_mpt_SetChannel(PADAPTER pAdapter);
+void hal_mpt_SetBandwidth(PADAPTER pAdapter);
+void hal_mpt_SetTxPower(PADAPTER pAdapter);
+void hal_mpt_SetDataRate(PADAPTER pAdapter);
+void hal_mpt_SetAntenna(PADAPTER pAdapter);
+s32 hal_mpt_SetThermalMeter(PADAPTER pAdapter, u8 target_ther);
+void hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter);
+u8 hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter);
+void hal_mpt_GetThermalMeter(PADAPTER pAdapter, u8 *value);
+void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart);
+void hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart);
+void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart);
+void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
+void mpt_ProSetPMacTx(PADAPTER	Adapter);
+void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter , BOOLEAN bMain);
+void mp_phy_switch_rf_path_set(PADAPTER pAdapter , u8 *pstate);
+u8 MP_PHY_QueryRFPathSwitch(PADAPTER pAdapter);
+ULONG mpt_ProQueryCalTxPower(PADAPTER	pAdapter, u8 RfPath);
+void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart);
+u8 mpt_to_mgnt_rate(u32	MptRateIdx);
+u8 rtw_mpRateParseFunc(PADAPTER pAdapter, u8 *targetStr);
+u32 mp_join(PADAPTER padapter, u8 mode);
+u32 hal_mpt_query_phytxok(PADAPTER	pAdapter);
+
+void
+PMAC_Get_Pkt_Param(
+	PRT_PMAC_TX_INFO	pPMacTxInfo,
+	PRT_PMAC_PKT_INFO	pPMacPktInfo
+);
+void
+CCK_generator(
+	PRT_PMAC_TX_INFO	pPMacTxInfo,
+	PRT_PMAC_PKT_INFO	pPMacPktInfo
+);
+void
+PMAC_Nsym_generator(
+	PRT_PMAC_TX_INFO	pPMacTxInfo,
+	PRT_PMAC_PKT_INFO	pPMacPktInfo
+);
+void
+L_SIG_generator(
+	UINT	N_SYM,		/* Max: 750*/
+	PRT_PMAC_TX_INFO	pPMacTxInfo,
+	PRT_PMAC_PKT_INFO	pPMacPktInfo
+);
+
+void HT_SIG_generator(
+	PRT_PMAC_TX_INFO	pPMacTxInfo,
+	PRT_PMAC_PKT_INFO	pPMacPktInfo);
+
+void VHT_SIG_A_generator(
+	PRT_PMAC_TX_INFO	pPMacTxInfo,
+	PRT_PMAC_PKT_INFO	pPMacPktInfo);
+
+void VHT_SIG_B_generator(
+	PRT_PMAC_TX_INFO	pPMacTxInfo);
+
+void VHT_Delimiter_generator(
+	PRT_PMAC_TX_INFO	pPMacTxInfo);
+
+
+int rtw_mp_write_reg(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_read_reg(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_write_rf(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_read_rf(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_start(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_stop(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_rate(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_channel(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_ch_offset(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_bandwidth(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_txpower_index(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_txpower(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_txpower(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_ant_tx(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_ant_rx(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_set_ctx_destAddr(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_ctx(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_disable_bt_coexist(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_disable_bt_coexist(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_arx(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_trx_query(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_pwrtrk(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_psd(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_thermal(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_reset_stats(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_dump(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_phypara(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_SetRFPath(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_switch_rf_path(struct net_device *dev,
+			struct iw_request_info *info,
+			struct iw_point *wrqu, char *extra);
+int rtw_mp_QueryDrv(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_PwrCtlDM(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_getver(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_mon(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_pwrlmt(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_pwrbyrate(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_efuse_mask_file(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_efuse_file_map(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_bt_efuse_file_map(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_SetBT(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra);
+int rtw_mp_tx(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_rx(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_hwtx(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+u8 HwRateToMPTRate(u8 rate);
+int rtw_mp_iqk(struct net_device *dev,
+		 struct iw_request_info *info,
+		 struct iw_point *wrqu, char *extra);
+int rtw_mp_lck(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+#endif /* _RTW_MP_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp_ioctl.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp_ioctl.h
new file mode 100644
index 000000000000..a9dabfcefddf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp_ioctl.h
@@ -0,0 +1,570 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MP_IOCTL_H_
+#define _RTW_MP_IOCTL_H_
+
+#include <mp_custom_oid.h>
+#include <rtw_mp.h>
+
+#if 0
+#define TESTFWCMDNUMBER			1000000
+#define TEST_H2CINT_WAIT_TIME		500
+#define TEST_C2HINT_WAIT_TIME		500
+#define HCI_TEST_SYSCFG_HWMASK		1
+#define _BUSCLK_40M			(4 << 2)
+#endif
+/* ------------------------------------------------------------------------------ */
+typedef struct CFG_DBG_MSG_STRUCT {
+	u32 DebugLevel;
+	u32 DebugComponent_H32;
+	u32 DebugComponent_L32;
+} CFG_DBG_MSG_STRUCT, *PCFG_DBG_MSG_STRUCT;
+
+typedef struct _RW_REG {
+	u32 offset;
+	u32 width;
+	u32 value;
+} mp_rw_reg, RW_Reg, *pRW_Reg;
+
+/* for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM */
+typedef struct _EEPROM_RW_PARAM {
+	u32 offset;
+	u16 value;
+} eeprom_rw_param, EEPROM_RWParam, *pEEPROM_RWParam;
+
+typedef struct _EFUSE_ACCESS_STRUCT_ {
+	u16	start_addr;
+	u16	cnts;
+	u8	data[0];
+} EFUSE_ACCESS_STRUCT, *PEFUSE_ACCESS_STRUCT;
+
+typedef struct _BURST_RW_REG {
+	u32 offset;
+	u32 len;
+	u8 Data[256];
+} burst_rw_reg, Burst_RW_Reg, *pBurst_RW_Reg;
+
+typedef struct _USB_VendorReq {
+	u8	bRequest;
+	u16	wValue;
+	u16	wIndex;
+	u16	wLength;
+	u8	u8Dir;/* 0:OUT, 1:IN */
+	u8	u8InData;
+} usb_vendor_req, USB_VendorReq, *pUSB_VendorReq;
+
+typedef struct _DR_VARIABLE_STRUCT_ {
+	u8 offset;
+	u32 variable;
+} DR_VARIABLE_STRUCT;
+
+/* int mp_start_joinbss(_adapter *padapter, NDIS_802_11_SSID *pssid); */
+
+/* void _irqlevel_changed_(_irqL *irqlevel, BOOLEANunsigned char bLower); */
+#ifdef PLATFORM_OS_XP
+static void _irqlevel_changed_(_irqL *irqlevel, u8 bLower)
+{
+
+	if (bLower == LOWER) {
+		*irqlevel = KeGetCurrentIrql();
+
+		if (*irqlevel > PASSIVE_LEVEL)
+			KeLowerIrql(PASSIVE_LEVEL);
+	} else {
+		if (KeGetCurrentIrql() == PASSIVE_LEVEL)
+			KeRaiseIrql(DISPATCH_LEVEL, irqlevel);
+	}
+
+}
+#else
+#define _irqlevel_changed_(a, b)
+#endif
+
+/* oid_rtl_seg_81_80_00 */
+NDIS_STATUS oid_rt_pro_set_data_rate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_start_test_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_stop_test_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_channel_direct_call_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_antenna_bb_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_tx_power_control_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_81_80_20 */
+NDIS_STATUS oid_rt_pro_query_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_query_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_query_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_reset_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_reset_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_modulation_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_set_continuous_tx_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_single_carrier_tx_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_carrier_suppression_tx_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_single_tone_tx_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_81_87 */
+NDIS_STATUS oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_81_85 */
+NDIS_STATUS oid_rt_wireless_mode_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_87_11_00 */
+NDIS_STATUS oid_rt_pro8711_join_bss_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_write_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_burst_read_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_burst_write_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_write_txcmd_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read16_eeprom_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_write16_eeprom_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro8711_wi_poll_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro8711_pkt_loss_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_rd_attrib_mem_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_wr_attrib_mem_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS  oid_rt_pro_set_rf_intfs_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_poll_rx_status_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_87_11_20 */
+NDIS_STATUS oid_rt_pro_cfg_debug_message_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_data_rate_ex_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_basic_rate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_tssi_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_power_tracking_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_87_11_50 */
+NDIS_STATUS oid_rt_pro_qry_pwrstate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_pwrstate_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_87_11_F0 */
+NDIS_STATUS oid_rt_pro_h2c_set_rate_table_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_h2c_get_rate_table_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_87_12_00 */
+NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_dele_sta_info_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_query_dr_variable_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_read_efuse_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_write_efuse_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_rw_efuse_pgpkt_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_efuse_current_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_efuse_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_efuse_map_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_set_bandwidth_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_crystal_cap_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_efuse_max_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_tx_agc_offset_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_set_pkt_test_mode_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_get_thermal_meter_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_reset_phy_rx_packet_count_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_phy_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_phy_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_set_power_down_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_get_power_mode_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_trigger_gpio_hdl(struct oid_par_priv *poid_par_priv);
+
+#ifdef _RTW_MP_IOCTL_C_
+
+const struct oid_obj_priv oid_rtl_seg_81_80_00[] = {
+	{1, &oid_null_function},			/* 0x00	OID_RT_PRO_RESET_DUT */
+	{1, &oid_rt_pro_set_data_rate_hdl},		/* 0x01 */
+	{1, &oid_rt_pro_start_test_hdl},		/* 0x02 */
+	{1, &oid_rt_pro_stop_test_hdl},			/* 0x03 */
+	{1, &oid_null_function},			/* 0x04	OID_RT_PRO_SET_PREAMBLE */
+	{1, &oid_null_function},			/* 0x05	OID_RT_PRO_SET_SCRAMBLER */
+	{1, &oid_null_function},			/* 0x06	OID_RT_PRO_SET_FILTER_BB */
+	{1, &oid_null_function},			/* 0x07	OID_RT_PRO_SET_MANUAL_DIVERSITY_BB */
+	{1, &oid_rt_pro_set_channel_direct_call_hdl},	/* 0x08 */
+	{1, &oid_null_function},			/* 0x09	OID_RT_PRO_SET_SLEEP_MODE_DIRECT_CALL */
+	{1, &oid_null_function},			/* 0x0A	OID_RT_PRO_SET_WAKE_MODE_DIRECT_CALL */
+	{1, &oid_rt_pro_set_continuous_tx_hdl},		/* 0x0B	OID_RT_PRO_SET_TX_CONTINUOUS_DIRECT_CALL */
+	{1, &oid_rt_pro_set_single_carrier_tx_hdl},	/* 0x0C	OID_RT_PRO_SET_SINGLE_CARRIER_TX_CONTINUOUS */
+	{1, &oid_null_function},			/* 0x0D	OID_RT_PRO_SET_TX_ANTENNA_BB */
+	{1, &oid_rt_pro_set_antenna_bb_hdl},		/* 0x0E */
+	{1, &oid_null_function},			/* 0x0F	OID_RT_PRO_SET_CR_SCRAMBLER */
+	{1, &oid_null_function},			/* 0x10	OID_RT_PRO_SET_CR_NEW_FILTER */
+	{1, &oid_rt_pro_set_tx_power_control_hdl},	/* 0x11	OID_RT_PRO_SET_TX_POWER_CONTROL */
+	{1, &oid_null_function},			/* 0x12	OID_RT_PRO_SET_CR_TX_CONFIG */
+	{1, &oid_null_function},			/* 0x13	OID_RT_PRO_GET_TX_POWER_CONTROL */
+	{1, &oid_null_function},			/* 0x14	OID_RT_PRO_GET_CR_SIGNAL_QUALITY */
+	{1, &oid_null_function},			/* 0x15	OID_RT_PRO_SET_CR_SETPOINT */
+	{1, &oid_null_function},			/* 0x16	OID_RT_PRO_SET_INTEGRATOR */
+	{1, &oid_null_function},			/* 0x17	OID_RT_PRO_SET_SIGNAL_QUALITY */
+	{1, &oid_null_function},			/* 0x18	OID_RT_PRO_GET_INTEGRATOR */
+	{1, &oid_null_function},			/* 0x19	OID_RT_PRO_GET_SIGNAL_QUALITY */
+	{1, &oid_null_function},			/* 0x1A	OID_RT_PRO_QUERY_EEPROM_TYPE */
+	{1, &oid_null_function},			/* 0x1B	OID_RT_PRO_WRITE_MAC_ADDRESS */
+	{1, &oid_null_function},			/* 0x1C	OID_RT_PRO_READ_MAC_ADDRESS */
+	{1, &oid_null_function},			/* 0x1D	OID_RT_PRO_WRITE_CIS_DATA */
+	{1, &oid_null_function},			/* 0x1E	OID_RT_PRO_READ_CIS_DATA */
+	{1, &oid_null_function}				/* 0x1F	OID_RT_PRO_WRITE_POWER_CONTROL */
+
+};
+
+const struct oid_obj_priv oid_rtl_seg_81_80_20[] = {
+	{1, &oid_null_function},			/* 0x20	OID_RT_PRO_READ_POWER_CONTROL */
+	{1, &oid_null_function},			/* 0x21	OID_RT_PRO_WRITE_EEPROM */
+	{1, &oid_null_function},			/* 0x22	OID_RT_PRO_READ_EEPROM */
+	{1, &oid_rt_pro_reset_tx_packet_sent_hdl},	/* 0x23 */
+	{1, &oid_rt_pro_query_tx_packet_sent_hdl},	/* 0x24 */
+	{1, &oid_rt_pro_reset_rx_packet_received_hdl},	/* 0x25 */
+	{1, &oid_rt_pro_query_rx_packet_received_hdl},	/* 0x26 */
+	{1, &oid_rt_pro_query_rx_packet_crc32_error_hdl},	/* 0x27 */
+	{1, &oid_null_function},			/* 0x28	OID_RT_PRO_QUERY_CURRENT_ADDRESS */
+	{1, &oid_null_function},			/* 0x29	OID_RT_PRO_QUERY_PERMANENT_ADDRESS */
+	{1, &oid_null_function},			/* 0x2A	OID_RT_PRO_SET_PHILIPS_RF_PARAMETERS */
+	{1, &oid_rt_pro_set_carrier_suppression_tx_hdl},/* 0x2B	OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX */
+	{1, &oid_null_function},			/* 0x2C	OID_RT_PRO_RECEIVE_PACKET */
+	{1, &oid_null_function},			/* 0x2D	OID_RT_PRO_WRITE_EEPROM_BYTE */
+	{1, &oid_null_function},			/* 0x2E	OID_RT_PRO_READ_EEPROM_BYTE */
+	{1, &oid_rt_pro_set_modulation_hdl}		/* 0x2F */
+
+};
+
+const struct oid_obj_priv oid_rtl_seg_81_80_40[] = {
+	{1, &oid_null_function},			/* 0x40 */
+	{1, &oid_null_function},			/* 0x41 */
+	{1, &oid_null_function},			/* 0x42 */
+	{1, &oid_rt_pro_set_single_tone_tx_hdl},	/* 0x43 */
+	{1, &oid_null_function},			/* 0x44 */
+	{1, &oid_null_function}				/* 0x45 */
+};
+
+const struct oid_obj_priv oid_rtl_seg_81_80_80[] = {
+	{1, &oid_null_function},			/* 0x80	OID_RT_DRIVER_OPTION */
+	{1, &oid_null_function},			/* 0x81	OID_RT_RF_OFF */
+	{1, &oid_null_function}				/* 0x82	OID_RT_AUTH_STATUS */
+
+};
+
+const struct oid_obj_priv oid_rtl_seg_81_85[] = {
+	{1, &oid_rt_wireless_mode_hdl}			/* 0x00	OID_RT_WIRELESS_MODE */
+};
+
+struct oid_obj_priv oid_rtl_seg_81_87[] = {
+	{1, &oid_null_function},			/* 0x80	OID_RT_PRO8187_WI_POLL */
+	{1, &oid_rt_pro_write_bb_reg_hdl},		/* 0x81 */
+	{1, &oid_rt_pro_read_bb_reg_hdl},		/* 0x82 */
+	{1, &oid_rt_pro_write_rf_reg_hdl},		/* 0x82 */
+	{1, &oid_rt_pro_read_rf_reg_hdl}		/* 0x83 */
+};
+
+struct oid_obj_priv oid_rtl_seg_87_11_00[] = {
+	{1, &oid_rt_pro8711_join_bss_hdl},		/* 0x00  */ /* S */
+	{1, &oid_rt_pro_read_register_hdl},		/* 0x01 */
+	{1, &oid_rt_pro_write_register_hdl},		/* 0x02 */
+	{1, &oid_rt_pro_burst_read_register_hdl},	/* 0x03 */
+	{1, &oid_rt_pro_burst_write_register_hdl},	/* 0x04 */
+	{1, &oid_rt_pro_write_txcmd_hdl},		/* 0x05 */
+	{1, &oid_rt_pro_read16_eeprom_hdl},		/* 0x06 */
+	{1, &oid_rt_pro_write16_eeprom_hdl},		/* 0x07 */
+	{1, &oid_null_function},			/* 0x08	OID_RT_PRO_H2C_SET_COMMAND */
+	{1, &oid_null_function},			/* 0x09	OID_RT_PRO_H2C_QUERY_RESULT */
+	{1, &oid_rt_pro8711_wi_poll_hdl},		/* 0x0A */
+	{1, &oid_rt_pro8711_pkt_loss_hdl},		/* 0x0B */
+	{1, &oid_rt_rd_attrib_mem_hdl},			/* 0x0C */
+	{1, &oid_rt_wr_attrib_mem_hdl},			/* 0x0D */
+	{1, &oid_null_function},			/* 0x0E */
+	{1, &oid_null_function},			/* 0x0F */
+	{1, &oid_null_function},			/* 0x10	OID_RT_PRO_H2C_CMD_MODE */
+	{1, &oid_null_function},			/* 0x11	OID_RT_PRO_H2C_CMD_RSP_MODE */
+	{1, &oid_null_function},			/* 0X12	OID_RT_PRO_WAIT_C2H_EVENT */
+	{1, &oid_null_function},			/* 0X13	OID_RT_PRO_RW_ACCESS_PROTOCOL_TEST */
+	{1, &oid_null_function},			/* 0X14	OID_RT_PRO_SCSI_ACCESS_TEST */
+	{1, &oid_null_function},			/* 0X15	OID_RT_PRO_SCSI_TCPIPOFFLOAD_OUT */
+	{1, &oid_null_function},			/* 0X16	OID_RT_PRO_SCSI_TCPIPOFFLOAD_IN */
+	{1, &oid_null_function},			/* 0X17	OID_RT_RRO_RX_PKT_VIA_IOCTRL */
+	{1, &oid_null_function},			/* 0X18	OID_RT_RRO_RX_PKTARRAY_VIA_IOCTRL */
+	{1, &oid_null_function},			/* 0X19	OID_RT_RPO_SET_PWRMGT_TEST */
+	{1, &oid_null_function},			/* 0X1A */
+	{1, &oid_null_function},			/* 0X1B	OID_RT_PRO_QRY_PWRMGT_TEST */
+	{1, &oid_null_function},			/* 0X1C	OID_RT_RPO_ASYNC_RWIO_TEST */
+	{1, &oid_null_function},			/* 0X1D	OID_RT_RPO_ASYNC_RWIO_POLL */
+	{1, &oid_rt_pro_set_rf_intfs_hdl},		/* 0X1E */
+	{1, &oid_rt_poll_rx_status_hdl}			/* 0X1F */
+};
+
+struct oid_obj_priv oid_rtl_seg_87_11_20[] = {
+	{1, &oid_rt_pro_cfg_debug_message_hdl},		/* 0x20 */
+	{1, &oid_rt_pro_set_data_rate_ex_hdl},		/* 0x21 */
+	{1, &oid_rt_pro_set_basic_rate_hdl},		/* 0x22 */
+	{1, &oid_rt_pro_read_tssi_hdl},			/* 0x23 */
+	{1, &oid_rt_pro_set_power_tracking_hdl}		/* 0x24 */
+};
+
+
+struct oid_obj_priv oid_rtl_seg_87_11_50[] = {
+	{1, &oid_rt_pro_qry_pwrstate_hdl},		/* 0x50 */
+	{1, &oid_rt_pro_set_pwrstate_hdl}		/* 0x51 */
+};
+
+struct oid_obj_priv oid_rtl_seg_87_11_80[] = {
+	{1, &oid_null_function}				/* 0x80 */
+};
+
+struct oid_obj_priv oid_rtl_seg_87_11_B0[] = {
+	{1, &oid_null_function}				/* 0xB0 */
+};
+
+struct oid_obj_priv oid_rtl_seg_87_11_F0[] = {
+	{1, &oid_null_function},			/* 0xF0 */
+	{1, &oid_null_function},			/* 0xF1 */
+	{1, &oid_null_function},			/* 0xF2 */
+	{1, &oid_null_function},			/* 0xF3 */
+	{1, &oid_null_function},			/* 0xF4 */
+	{1, &oid_null_function},			/* 0xF5 */
+	{1, &oid_null_function},			/* 0xF6 */
+	{1, &oid_null_function},			/* 0xF7 */
+	{1, &oid_null_function},			/* 0xF8 */
+	{1, &oid_null_function},			/* 0xF9 */
+	{1, &oid_null_function},			/* 0xFA */
+	{1, &oid_rt_pro_h2c_set_rate_table_hdl},	/* 0xFB */
+	{1, &oid_rt_pro_h2c_get_rate_table_hdl},	/* 0xFC */
+	{1, &oid_null_function},			/* 0xFD */
+	{1, &oid_null_function},			/* 0xFE	OID_RT_PRO_H2C_C2H_LBK_TEST */
+	{1, &oid_null_function}				/* 0xFF */
+
+};
+
+struct oid_obj_priv oid_rtl_seg_87_12_00[] = {
+	{1, &oid_rt_pro_encryption_ctrl_hdl},		/* 0x00	Q&S */
+	{1, &oid_rt_pro_add_sta_info_hdl},		/* 0x01	S */
+	{1, &oid_rt_pro_dele_sta_info_hdl},		/* 0x02	S */
+	{1, &oid_rt_pro_query_dr_variable_hdl},		/* 0x03	Q */
+	{1, &oid_rt_pro_rx_packet_type_hdl},		/* 0x04	Q,S */
+	{1, &oid_rt_pro_read_efuse_hdl},		/* 0x05	Q	OID_RT_PRO_READ_EFUSE */
+	{1, &oid_rt_pro_write_efuse_hdl},		/* 0x06	S	OID_RT_PRO_WRITE_EFUSE */
+	{1, &oid_rt_pro_rw_efuse_pgpkt_hdl},		/* 0x07	Q,S */
+	{1, &oid_rt_get_efuse_current_size_hdl},	/* 0x08 	Q */
+	{1, &oid_rt_set_bandwidth_hdl},			/* 0x09 */
+	{1, &oid_rt_set_crystal_cap_hdl},		/* 0x0a */
+	{1, &oid_rt_set_rx_packet_type_hdl},		/* 0x0b	S */
+	{1, &oid_rt_get_efuse_max_size_hdl},		/* 0x0c */
+	{1, &oid_rt_pro_set_tx_agc_offset_hdl},		/* 0x0d */
+	{1, &oid_rt_pro_set_pkt_test_mode_hdl},		/* 0x0e */
+	{1, &oid_null_function},			/* 0x0f		OID_RT_PRO_FOR_EVM_TEST_SETTING */
+	{1, &oid_rt_get_thermal_meter_hdl},		/* 0x10	Q	OID_RT_PRO_GET_THERMAL_METER */
+	{1, &oid_rt_reset_phy_rx_packet_count_hdl},	/* 0x11	S	OID_RT_RESET_PHY_RX_PACKET_COUNT */
+	{1, &oid_rt_get_phy_rx_packet_received_hdl},	/* 0x12	Q	OID_RT_GET_PHY_RX_PACKET_RECEIVED */
+	{1, &oid_rt_get_phy_rx_packet_crc32_error_hdl},	/* 0x13	Q	OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR */
+	{1, &oid_rt_set_power_down_hdl},		/* 0x14	Q	OID_RT_SET_POWER_DOWN */
+	{1, &oid_rt_get_power_mode_hdl}			/* 0x15	Q	OID_RT_GET_POWER_MODE */
+};
+
+#else /* _RTL871X_MP_IOCTL_C_ */
+
+extern struct oid_obj_priv oid_rtl_seg_81_80_00[32];
+extern struct oid_obj_priv oid_rtl_seg_81_80_20[16];
+extern struct oid_obj_priv oid_rtl_seg_81_80_40[6];
+extern struct oid_obj_priv oid_rtl_seg_81_80_80[3];
+
+extern struct oid_obj_priv oid_rtl_seg_81_85[1];
+extern struct oid_obj_priv oid_rtl_seg_81_87[5];
+
+extern struct oid_obj_priv oid_rtl_seg_87_11_00[32];
+extern struct oid_obj_priv oid_rtl_seg_87_11_20[5];
+extern struct oid_obj_priv oid_rtl_seg_87_11_50[2];
+extern struct oid_obj_priv oid_rtl_seg_87_11_80[1];
+extern struct oid_obj_priv oid_rtl_seg_87_11_B0[1];
+extern struct oid_obj_priv oid_rtl_seg_87_11_F0[16];
+
+extern struct oid_obj_priv oid_rtl_seg_87_12_00[32];
+
+#endif /* _RTL871X_MP_IOCTL_C_ */
+
+struct rwreg_param {
+	u32 offset;
+	u32 width;
+	u32 value;
+};
+
+struct bbreg_param {
+	u32 offset;
+	u32 phymask;
+	u32 value;
+};
+/*
+struct rfchannel_param{
+	u32 ch;
+	u32 modem;
+};
+*/
+struct txpower_param {
+	u32 pwr_index;
+};
+
+
+struct datarate_param {
+	u32 rate_index;
+};
+
+
+struct rfintfs_parm {
+	u32 rfintfs;
+};
+
+typedef struct _mp_xmit_parm_ {
+	u8 enable;
+	u32 count;
+	u16 length;
+	u8 payload_type;
+	u8 da[ETH_ALEN];
+} MP_XMIT_PARM, *PMP_XMIT_PARM;
+
+struct mp_xmit_packet {
+	u32 len;
+	u32 mem[MAX_MP_XMITBUF_SZ >> 2];
+};
+
+struct psmode_param {
+	u32 ps_mode;
+	u32 smart_ps;
+};
+
+/* for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM */
+struct eeprom_rw_param {
+	u32 offset;
+	u16 value;
+};
+
+struct mp_ioctl_handler {
+	u32 paramsize;
+	u32(*handler)(struct oid_par_priv *poid_par_priv);
+	u32 oid;
+};
+
+struct mp_ioctl_param {
+	u32 subcode;
+	u32 len;
+	u8 data[0];
+};
+
+#define GEN_MP_IOCTL_SUBCODE(code) _MP_IOCTL_ ## code ## _CMD_
+
+enum RTL871X_MP_IOCTL_SUBCODE {
+	GEN_MP_IOCTL_SUBCODE(MP_START),			/*0*/
+	GEN_MP_IOCTL_SUBCODE(MP_STOP),
+	GEN_MP_IOCTL_SUBCODE(READ_REG),
+	GEN_MP_IOCTL_SUBCODE(WRITE_REG),
+	GEN_MP_IOCTL_SUBCODE(READ_BB_REG),
+	GEN_MP_IOCTL_SUBCODE(WRITE_BB_REG),		/*5*/
+	GEN_MP_IOCTL_SUBCODE(READ_RF_REG),
+	GEN_MP_IOCTL_SUBCODE(WRITE_RF_REG),
+	GEN_MP_IOCTL_SUBCODE(SET_CHANNEL),
+	GEN_MP_IOCTL_SUBCODE(SET_TXPOWER),
+	GEN_MP_IOCTL_SUBCODE(SET_DATARATE),		/*10*/
+	GEN_MP_IOCTL_SUBCODE(SET_BANDWIDTH),
+	GEN_MP_IOCTL_SUBCODE(SET_ANTENNA),
+	GEN_MP_IOCTL_SUBCODE(CNTU_TX),
+	GEN_MP_IOCTL_SUBCODE(SC_TX),
+	GEN_MP_IOCTL_SUBCODE(CS_TX),			/*15*/
+	GEN_MP_IOCTL_SUBCODE(ST_TX),
+	GEN_MP_IOCTL_SUBCODE(IOCTL_XMIT_PACKET),
+	GEN_MP_IOCTL_SUBCODE(SET_RX_PKT_TYPE),
+	GEN_MP_IOCTL_SUBCODE(RESET_PHY_RX_PKT_CNT),
+	GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_RECV),	/*20*/
+	GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_ERROR),
+	GEN_MP_IOCTL_SUBCODE(READ16_EEPROM),
+	GEN_MP_IOCTL_SUBCODE(WRITE16_EEPROM),
+	GEN_MP_IOCTL_SUBCODE(EFUSE),
+	GEN_MP_IOCTL_SUBCODE(EFUSE_MAP),		/*25*/
+	GEN_MP_IOCTL_SUBCODE(GET_EFUSE_MAX_SIZE),
+	GEN_MP_IOCTL_SUBCODE(GET_EFUSE_CURRENT_SIZE),
+	GEN_MP_IOCTL_SUBCODE(GET_THERMAL_METER),
+	GEN_MP_IOCTL_SUBCODE(SET_PTM),
+	GEN_MP_IOCTL_SUBCODE(SET_POWER_DOWN),		/*30*/
+	GEN_MP_IOCTL_SUBCODE(TRIGGER_GPIO),
+	GEN_MP_IOCTL_SUBCODE(SET_DM_BT),		/*32*/
+	GEN_MP_IOCTL_SUBCODE(DEL_BA),			/*33*/
+	GEN_MP_IOCTL_SUBCODE(GET_WIFI_STATUS),	/*34*/
+	MAX_MP_IOCTL_SUBCODE,
+};
+
+u32 mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv);
+
+#ifdef _RTW_MP_IOCTL_C_
+
+#define GEN_MP_IOCTL_HANDLER(sz, hdl, oid) {sz, hdl, oid},
+
+#define EXT_MP_IOCTL_HANDLER(sz, subcode, oid) {sz, mp_ioctl_ ## subcode ## _hdl, oid},
+
+
+struct mp_ioctl_handler mp_ioctl_hdl[] = {
+
+	/*0*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_start_test_hdl, OID_RT_PRO_START_TEST)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_stop_test_hdl, OID_RT_PRO_STOP_TEST)
+
+	GEN_MP_IOCTL_HANDLER(sizeof(struct rwreg_param), oid_rt_pro_read_register_hdl, OID_RT_PRO_READ_REGISTER)
+	GEN_MP_IOCTL_HANDLER(sizeof(struct rwreg_param), oid_rt_pro_write_register_hdl, OID_RT_PRO_WRITE_REGISTER)
+	GEN_MP_IOCTL_HANDLER(sizeof(struct bb_reg_param), oid_rt_pro_read_bb_reg_hdl, OID_RT_PRO_READ_BB_REG)
+	/*5*/	GEN_MP_IOCTL_HANDLER(sizeof(struct bb_reg_param), oid_rt_pro_write_bb_reg_hdl, OID_RT_PRO_WRITE_BB_REG)
+	GEN_MP_IOCTL_HANDLER(sizeof(struct rf_reg_param), oid_rt_pro_read_rf_reg_hdl, OID_RT_PRO_RF_READ_REGISTRY)
+	GEN_MP_IOCTL_HANDLER(sizeof(struct rf_reg_param), oid_rt_pro_write_rf_reg_hdl, OID_RT_PRO_RF_WRITE_REGISTRY)
+
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_channel_direct_call_hdl, OID_RT_PRO_SET_CHANNEL_DIRECT_CALL)
+	GEN_MP_IOCTL_HANDLER(sizeof(struct txpower_param), oid_rt_pro_set_tx_power_control_hdl, OID_RT_PRO_SET_TX_POWER_CONTROL)
+	/*10*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_data_rate_hdl, OID_RT_PRO_SET_DATA_RATE)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_set_bandwidth_hdl, OID_RT_SET_BANDWIDTH)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_antenna_bb_hdl, OID_RT_PRO_SET_ANTENNA_BB)
+
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_continuous_tx_hdl, OID_RT_PRO_SET_CONTINUOUS_TX)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_single_carrier_tx_hdl, OID_RT_PRO_SET_SINGLE_CARRIER_TX)
+	/*15*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_carrier_suppression_tx_hdl, OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_single_tone_tx_hdl, OID_RT_PRO_SET_SINGLE_TONE_TX)
+
+	EXT_MP_IOCTL_HANDLER(0, xmit_packet, 0)
+
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_set_rx_packet_type_hdl, OID_RT_SET_RX_PACKET_TYPE)
+	GEN_MP_IOCTL_HANDLER(0, oid_rt_reset_phy_rx_packet_count_hdl, OID_RT_RESET_PHY_RX_PACKET_COUNT)
+	/*20*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_phy_rx_packet_received_hdl, OID_RT_GET_PHY_RX_PACKET_RECEIVED)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_phy_rx_packet_crc32_error_hdl, OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR)
+
+	GEN_MP_IOCTL_HANDLER(sizeof(struct eeprom_rw_param), NULL, 0)
+	GEN_MP_IOCTL_HANDLER(sizeof(struct eeprom_rw_param), NULL, 0)
+	GEN_MP_IOCTL_HANDLER(sizeof(EFUSE_ACCESS_STRUCT), oid_rt_pro_efuse_hdl, OID_RT_PRO_EFUSE)
+	/*25*/	GEN_MP_IOCTL_HANDLER(0, oid_rt_pro_efuse_map_hdl, OID_RT_PRO_EFUSE_MAP)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_efuse_max_size_hdl, OID_RT_GET_EFUSE_MAX_SIZE)
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_efuse_current_size_hdl, OID_RT_GET_EFUSE_CURRENT_SIZE)
+
+	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_thermal_meter_hdl, OID_RT_PRO_GET_THERMAL_METER)
+	GEN_MP_IOCTL_HANDLER(sizeof(u8), oid_rt_pro_set_power_tracking_hdl, OID_RT_PRO_SET_POWER_TRACKING)
+	/*30*/	GEN_MP_IOCTL_HANDLER(sizeof(u8), oid_rt_set_power_down_hdl, OID_RT_SET_POWER_DOWN)
+	/*31*/	GEN_MP_IOCTL_HANDLER(0, oid_rt_pro_trigger_gpio_hdl, 0)
+	GEN_MP_IOCTL_HANDLER(0, NULL, 0)
+	GEN_MP_IOCTL_HANDLER(0, NULL, 0)
+	GEN_MP_IOCTL_HANDLER(0, NULL, 0)
+};
+
+#else /* _RTW_MP_IOCTL_C_ */
+
+extern struct mp_ioctl_handler mp_ioctl_hdl[];
+
+#endif /* _RTW_MP_IOCTL_C_ */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp_phy_regdef.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp_phy_regdef.h
new file mode 100644
index 000000000000..be627800e522
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_mp_phy_regdef.h
@@ -0,0 +1,1094 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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:	__RTW_MP_PHY_REGDEF_H_
+ *
+ *
+ * Note:	1. Define PMAC/BB register map
+ *			2. Define RF register map
+ *			3. PMAC/BB register bit mask.
+ *			4. RF reg bit mask.
+ *			5. Other BB/RF relative definition.
+ *
+ *
+ * Export:	Constants, macro, functions(API), global variables(None).
+ *
+ * Abbrev:
+ *
+ * History:
+ *	Data			Who		Remark
+ *	08/07/2007	MHC		1. Porting from 9x series PHYCFG.h.
+ *						2. Reorganize code architecture.
+ *	09/25/2008	MH		1. Add RL6052 register definition
+ *
+ *****************************************************************************/
+#ifndef __RTW_MP_PHY_REGDEF_H_
+#define __RTW_MP_PHY_REGDEF_H_
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/* ************************************************************
+ * 8192S Regsiter offset definition
+ * ************************************************************ */
+
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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_XC_RFTiming		0x818 */
+/* #define rFPGA0_XD_RFTiming		0x81c */
+
+#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		rFPGA0_XC_HSSIParameter1		0x830
+#define		rFPGA0_XC_HSSIParameter2		0x834
+#define		rFPGA0_XD_HSSIParameter1		0x838
+#define		rFPGA0_XD_HSSIParameter2		0x83c
+#define		rFPGA0_XA_LSSIParameter		0x840
+#define		rFPGA0_XB_LSSIParameter		0x844
+#define		rFPGA0_XC_LSSIParameter		0x848
+#define		rFPGA0_XD_LSSIParameter		0x84c
+
+#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		rFPGA0_XC_RFInterfaceOE		0x868
+#define		rFPGA0_XD_RFInterfaceOE		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		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?? */
+#define	rS0S1_PathSwitch			0x948
+
+/*
+ * 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 */
+
+/*
+ * 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_RxHPParameter			0xce0
+#define		rOFDM0_TxPseudoNoiseWgt		0xce4
+#define		rOFDM0_FrameSync				0xcf0
+#define		rOFDM0_DFSReport				0xcf4
+#define		rOFDM0_TxCoeff1				0xca4
+#define		rOFDM0_TxCoeff2				0xca8
+#define		rOFDM0_TxCoeff3				0xcac
+#define		rOFDM0_TxCoeff4				0xcb0
+#define		rOFDM0_TxCoeff5				0xcb4
+#define		rOFDM0_TxCoeff6				0xcb8
+
+
+/*
+ * 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_Rate18_06				0xe00
+#define		rTxAGC_Rate54_24				0xe04
+#define		rTxAGC_CCK_Mcs32				0xe08
+#define		rTxAGC_Mcs03_Mcs00			0xe10
+#define		rTxAGC_Mcs07_Mcs04			0xe14
+#define		rTxAGC_Mcs11_Mcs08			0xe18
+#define		rTxAGC_Mcs15_Mcs12			0xe1c
+
+/* Analog- control in RX_WAIT_CCA : REG: EE0 [Analog- Power & Control Register] */
+#define		rRx_Wait_CCCA					0xe70
+#define		rAnapar_Ctrl_BB					0xee0
+
+/*
+ * 7. RF Register 0x00-0x2E (RF 8256)
+ * RF-0222D 0x00-3F
+ *
+ * Zebra1 */
+#define RTL92SE_FPGA_VERIFY 0
+#define		rZebra1_HSSIEnable				0x0	/* Useless now */
+#define		rZebra1_TRxEnable1				0x1
+#define		rZebra1_TRxEnable2				0x2
+#define		rZebra1_AGC					0x4
+#define		rZebra1_ChargePump			0x5
+/* #if (RTL92SE_FPGA_VERIFY == 1) */
+#define		rZebra1_Channel				0x7	/* RF channel switch
+ * #else */
+
+/* #endif */
+#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_POW_TRSW				0x05	/*  */
+
+#define		RF_GAIN_RX					0x06	/*  */
+#define		RF_GAIN_TX					0x07	/*  */
+
+#define		RF_TXM_IDAC				0x08	/*  */
+#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		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
+#if (RTL92SE_FPGA_VERIFY == 1)
+	#define		bLSSIReadAddress          		0x3f000000   /* LSSI "Read" Address	 */ /* Reg 0x824 rFPGA0_XA_HSSIParameter2 */
+#else
+	#define		bLSSIReadAddress          		0x7f800000   /* T65 RF */
+#endif
+#define		bLSSIReadEdge             		0x80000000   /* LSSI "Read" edge signal */
+#if (RTL92SE_FPGA_VERIFY == 1)
+	#define		bLSSIReadBackData         		0xfff		/* Reg 0x8a0 rFPGA0_XA_LSSIReadBack */
+#else
+	#define		bLSSIReadBackData         		0xfffff		/* T65 RF */
+#endif
+#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
+
+#define		bTxAGCRate18_06			0x7f7f7f7f	/* Useless */
+#define		bTxAGCRate54_24			0x7f7f7f7f
+#define		bTxAGCRateMCS32			0x7f
+#define		bTxAGCRateCCK			0x7f00
+#define		bTxAGCRateMCS3_MCS0		0x7f7f7f7f
+#define		bTxAGCRateMCS7_MCS4		0x7f7f7f7f
+#define		bTxAGCRateMCS11_MCS8	0x7f7f7f7f
+#define		bTxAGCRateMCS15_MCS12	0x7f7f7f7f
+
+/* 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		bMaskH4Bits		0xf0000000
+#define		bMaskH3Bytes	0xffffff00
+#define		bMaskOFDM_D	0xffc00000
+#define		bMaskCCK		0x3f3f3f3f
+#define		bMask12Bits		0xfff
+
+/* for PutRFRegsetting & GetRFRegSetting BitMask */
+#if (RTL92SE_FPGA_VERIFY == 1)
+/* #define		bMask12Bits               0xfff */	/* RF Reg mask bits */
+/* #define		bMask20Bits               0xfff */	/* RF Reg mask bits T65 RF */
+#define		bRFRegOffsetMask	0xfff
+#else
+/* #define		bMask12Bits               0xfffff */	/* RF Reg mask bits */
+/* #define		bMask20Bits               0xfffff */	/* RF Reg mask bits T65 RF */
+#define		bRFRegOffsetMask	0xfffff
+#endif
+#define		bEnable                   0x1	/* Useless */
+#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
+
+#if 0
+#define		ANTENNA_A	0x1	/* Useless */
+#define		ANTENNA_B	0x2
+#define		ANTENNA_AB	0x3	/* ANTENNA_A | ANTENNA_B */
+
+#define		ANTENNA_C	0x4
+#define		ANTENNA_D	0x8
+#endif
+
+#define RCR_AAP			BIT(0)				/* accept all physical address */
+#define RCR_APM			BIT(1)				/* accept physical match */
+#define RCR_AM			BIT(2)				/* accept multicast */
+#define RCR_AB			BIT(3)				/* accept broadcast */
+#define RCR_ACRC32		BIT(5)				/* accept error packet */
+#define RCR_9356SEL		BIT(6)
+#define RCR_AICV		BIT(9)				/* Accept ICV error packet */
+#define RCR_RXFTH0		(BIT(13) | BIT(14) | BIT(15))	/* Rx FIFO threshold */
+#define RCR_ADF			BIT(18)				/* Accept Data(frame type) frame */
+#define RCR_ACF			BIT(19)				/* Accept control frame */
+#define RCR_AMF			BIT(20)				/* Accept management frame */
+#define RCR_ADD3		BIT(21)
+#define RCR_APWRMGT		BIT(22)				/* Accept power management packet */
+#define RCR_CBSSID		BIT(23)				/* Accept BSSID match packet */
+#define RCR_ENMARP		BIT(28)				/* enable mac auto reset phy */
+#define RCR_EnCS1		BIT(29)				/* enable carrier sense method 1 */
+#define RCR_EnCS2		BIT(30)				/* enable carrier sense method 2 */
+#define RCR_OnlyErlPkt		BIT(31)				/* Rx Early mode is performed for packet size greater than 1536 */
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif /* __INC_HAL8192SPHYREG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_odm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_odm.h
new file mode 100644
index 000000000000..4ce6fe1407a4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_odm.h
@@ -0,0 +1,96 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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_ODM_H__
+#define __RTW_ODM_H__
+
+#include <drv_types.h>
+#include "../hal/phydm/phydm_types.h"
+/*
+* This file provides utilities/wrappers for rtw driver to use ODM
+*/
+typedef enum _HAL_PHYDM_OPS {
+	HAL_PHYDM_DIS_ALL_FUNC,
+	HAL_PHYDM_FUNC_SET,
+	HAL_PHYDM_FUNC_CLR,
+	HAL_PHYDM_ABILITY_BK,
+	HAL_PHYDM_ABILITY_RESTORE,
+	HAL_PHYDM_ABILITY_SET,
+	HAL_PHYDM_ABILITY_GET,
+} HAL_PHYDM_OPS;
+
+
+#define DYNAMIC_FUNC_DISABLE		(0x0)
+	u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability);
+
+#define rtw_phydm_func_disable_all(adapter)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0)
+
+#ifdef CONFIG_RTW_ACS
+#define rtw_phydm_func_for_offchannel(adapter) \
+		do { \
+			rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0); \
+			if (rtw_odm_adaptivity_needed(adapter)) \
+				rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ODM_BB_ADAPTIVITY); \
+			if (IS_ACS_ENABLE(adapter))\
+				rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ODM_BB_ENV_MONITOR); \
+		} while (0)
+#else
+#define rtw_phydm_func_for_offchannel(adapter) \
+		do { \
+			rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0); \
+			if (rtw_odm_adaptivity_needed(adapter)) \
+				rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ODM_BB_ADAPTIVITY); \
+		} while (0)
+#endif
+
+#define rtw_phydm_func_clr(adapter, ability)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_CLR, ability)
+
+#define rtw_phydm_ability_backup(adapter)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_BK, 0)
+
+#define rtw_phydm_ability_restore(adapter)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_RESTORE, 0)
+
+
+static inline u32 rtw_phydm_ability_get(_adapter *adapter)
+{
+	return rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_GET, 0);
+}
+
+
+void rtw_odm_init_ic_type(_adapter *adapter);
+
+void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter);
+
+bool rtw_odm_adaptivity_needed(_adapter *adapter);
+void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter);
+void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff, s8 th_l2h_ini_mode2, s8 th_edcca_hl_diff_mode2, u8 edcca_enable);
+void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter);
+void rtw_odm_acquirespinlock(_adapter *adapter,	enum rt_spinlock_type type);
+void rtw_odm_releasespinlock(_adapter *adapter,	enum rt_spinlock_type type);
+
+u8 rtw_odm_get_dfs_domain(_adapter *adapter);
+u8 rtw_odm_dfs_domain_unknown(_adapter *adapter);
+#ifdef CONFIG_DFS_MASTER
+VOID rtw_odm_radar_detect_reset(_adapter *adapter);
+VOID rtw_odm_radar_detect_disable(_adapter *adapter);
+VOID rtw_odm_radar_detect_enable(_adapter *adapter);
+BOOLEAN rtw_odm_radar_detect(_adapter *adapter);
+#endif /* CONFIG_DFS_MASTER */
+
+void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys);
+
+#endif /* __RTW_ODM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_p2p.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_p2p.h
new file mode 100644
index 000000000000..203886be0a45
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_p2p.h
@@ -0,0 +1,172 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_P2P_H_
+#define __RTW_P2P_H_
+
+
+u32 build_beacon_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_probe_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_prov_disc_request_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 *pssid, u8 ussidlen, u8 *pdev_raddr);
+u32 build_assoc_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 status_code);
+u32 build_deauth_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+#ifdef CONFIG_WFD
+int rtw_init_wifi_display_info(_adapter *padapter);
+void rtw_wfd_enable(_adapter *adapter, bool on);
+void rtw_wfd_set_ctrl_port(_adapter *adapter, u16 port);
+void rtw_tdls_wfd_enable(_adapter *adapter, bool on);
+
+u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunneled);
+u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_nego_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_nego_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_nego_confirm_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_assoc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_provdisc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+u32 build_provdisc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
+
+u32 rtw_append_beacon_wfd_ie(_adapter *adapter, u8 *pbuf);
+u32 rtw_append_probe_req_wfd_ie(_adapter *adapter, u8 *pbuf);
+u32 rtw_append_probe_resp_wfd_ie(_adapter *adapter, u8 *pbuf);
+u32 rtw_append_assoc_req_wfd_ie(_adapter *adapter, u8 *pbuf);
+u32 rtw_append_assoc_resp_wfd_ie(_adapter *adapter, u8 *pbuf);
+#endif /*CONFIG_WFD */
+
+void rtw_xframe_chk_wfd_ie(struct xmit_frame *xframe);
+
+u32 process_probe_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u32 process_assoc_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len, struct sta_info *psta);
+u32 process_p2p_devdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u32 process_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u8 process_p2p_provdisc_req(struct wifidirect_info *pwdinfo,  u8 *pframe, uint len);
+u8 process_p2p_provdisc_resp(struct wifidirect_info *pwdinfo,  u8 *pframe);
+u8 process_p2p_group_negotation_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u8 process_p2p_group_negotation_confirm(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u8 process_p2p_presence_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+int process_p2p_cross_connect_ie(PADAPTER padapter, u8 *IEs, u32 IELength);
+
+s32 p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType, u8 *buf);
+
+#ifdef CONFIG_P2P_PS
+void	process_p2p_ps_ie(PADAPTER padapter, u8 *IEs, u32 IELength);
+void	p2p_ps_wk_hdl(_adapter *padapter, u8 p2p_ps_state);
+u8	p2p_ps_wk_cmd(_adapter *padapter, u8 p2p_ps_state, u8 enqueue);
+#endif /* CONFIG_P2P_PS */
+
+#ifdef CONFIG_IOCTL_CFG80211
+u8 roch_stay_in_cur_chan(_adapter *padapter);
+void rtw_init_cfg80211_wifidirect_info(_adapter	*padapter);
+int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx);
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+void reset_global_wifidirect_info(_adapter *padapter);
+void rtw_init_wifidirect_timers(_adapter *padapter);
+void rtw_init_wifidirect_addrs(_adapter *padapter, u8 *dev_addr, u8 *iface_addr);
+void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role);
+int rtw_p2p_enable(_adapter *padapter, enum P2P_ROLE role);
+
+static inline void _rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)
+{
+	if (wdinfo->p2p_state != state) {
+		/* wdinfo->pre_p2p_state = wdinfo->p2p_state; */
+		wdinfo->p2p_state = state;
+	}
+}
+static inline void _rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)
+{
+	if (wdinfo->pre_p2p_state != state)
+		wdinfo->pre_p2p_state = state;
+}
+#if 0
+static inline void _rtw_p2p_restore_state(struct wifidirect_info *wdinfo)
+{
+	if (wdinfo->pre_p2p_state != -1) {
+		wdinfo->p2p_state = wdinfo->pre_p2p_state;
+		wdinfo->pre_p2p_state = -1;
+	}
+}
+#endif
+static inline void _rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)
+{
+	if (wdinfo->role != role)
+		wdinfo->role = role;
+}
+static inline int _rtw_p2p_state(struct wifidirect_info *wdinfo)
+{
+	return wdinfo->p2p_state;
+}
+static inline int _rtw_p2p_pre_state(struct wifidirect_info *wdinfo)
+{
+	return wdinfo->pre_p2p_state;
+}
+static inline int _rtw_p2p_role(struct wifidirect_info *wdinfo)
+{
+	return wdinfo->role;
+}
+static inline bool _rtw_p2p_chk_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)
+{
+	return wdinfo->p2p_state == state;
+}
+static inline bool _rtw_p2p_chk_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)
+{
+	return wdinfo->role == role;
+}
+
+#ifdef CONFIG_DBG_P2P
+void dbg_rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line);
+void dbg_rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line);
+/* void dbg_rtw_p2p_restore_state(struct wifidirect_info *wdinfo, const char *caller, int line); */
+void dbg_rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role, const char *caller, int line);
+#define rtw_p2p_set_state(wdinfo, state) dbg_rtw_p2p_set_state(wdinfo, state, __FUNCTION__, __LINE__)
+#define rtw_p2p_set_pre_state(wdinfo, state) dbg_rtw_p2p_set_pre_state(wdinfo, state, __FUNCTION__, __LINE__)
+#define rtw_p2p_set_role(wdinfo, role) dbg_rtw_p2p_set_role(wdinfo, role, __FUNCTION__, __LINE__)
+/* #define rtw_p2p_restore_state(wdinfo) dbg_rtw_p2p_restore_state(wdinfo, __FUNCTION__, __LINE__) */
+#else /* CONFIG_DBG_P2P */
+#define rtw_p2p_set_state(wdinfo, state) _rtw_p2p_set_state(wdinfo, state)
+#define rtw_p2p_set_pre_state(wdinfo, state) _rtw_p2p_set_pre_state(wdinfo, state)
+#define rtw_p2p_set_role(wdinfo, role) _rtw_p2p_set_role(wdinfo, role)
+/* #define rtw_p2p_restore_state(wdinfo) _rtw_p2p_restore_state(wdinfo) */
+#endif /* CONFIG_DBG_P2P */
+
+#define rtw_p2p_state(wdinfo) _rtw_p2p_state(wdinfo)
+#define rtw_p2p_pre_state(wdinfo) _rtw_p2p_pre_state(wdinfo)
+#define rtw_p2p_role(wdinfo) _rtw_p2p_role(wdinfo)
+#define rtw_p2p_chk_state(wdinfo, state) _rtw_p2p_chk_state(wdinfo, state)
+#define rtw_p2p_chk_role(wdinfo, role) _rtw_p2p_chk_role(wdinfo, role)
+
+#define rtw_p2p_findphase_ex_set(wdinfo, value) \
+	(wdinfo)->find_phase_state_exchange_cnt = (value)
+
+#ifdef CONFIG_P2P
+/* is this find phase exchange for social channel scan? */
+#define rtw_p2p_findphase_ex_is_social(wdinfo)   \
+	(wdinfo)->find_phase_state_exchange_cnt >= P2P_FINDPHASE_EX_SOCIAL_FIRST
+
+/* should we need find phase exchange anymore? */
+#define rtw_p2p_findphase_ex_is_needed(wdinfo) \
+	((wdinfo)->find_phase_state_exchange_cnt < P2P_FINDPHASE_EX_MAX && \
+	 (wdinfo)->find_phase_state_exchange_cnt != P2P_FINDPHASE_EX_NONE && \
+	 !(wdinfo)->rx_invitereq_info.scan_op_ch_only && \
+	 !(wdinfo)->p2p_info.scan_op_ch_only)
+#else
+#define rtw_p2p_findphase_ex_is_social(wdinfo) 0
+#define rtw_p2p_findphase_ex_is_needed(wdinfo) 0
+#endif /* CONFIG_P2P */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_pwrctrl.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_pwrctrl.h
new file mode 100644
index 000000000000..696ff70d6800
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_pwrctrl.h
@@ -0,0 +1,586 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#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)
+#ifdef CONFIG_BT_COEXIST
+#define BTCOEX_ALIVE	BIT(4)
+#endif /* CONFIG_BT_COEXIST */
+
+#ifdef CONFIG_WOWLAN
+	#ifdef CONFIG_PLATFORM_ANDROID_INTEL_X86
+		/* TCP/ICMP/UDP multicast with specific IP addr */
+		#define DEFAULT_PATTERN_NUM 4
+	#else
+		/* TCP/ICMP */
+		#define DEFAULT_PATTERN_NUM 3
+	#endif
+
+#ifdef CONFIG_WOW_PATTERN_HW_CAM	/* Frame Mask Cam number for pattern match */
+#define MAX_WKFM_CAM_NUM	12
+#else
+#define MAX_WKFM_CAM_NUM	16
+#endif
+
+#define MAX_WKFM_SIZE	16 /* (16 bytes for WKFM bit mask, 16*8 = 128 bits) */
+#define MAX_WKFM_PATTERN_SIZE	128
+#define WKFMCAM_ADDR_NUM 6
+#define WKFMCAM_SIZE 24 /* each entry need 6*4 bytes */
+enum pattern_type {
+	PATTERN_BROADCAST = 0,
+	PATTERN_MULTICAST,
+	PATTERN_UNICAST,
+	PATTERN_VALID,
+	PATTERN_INVALID,
+};
+
+typedef struct rtl_priv_pattern {
+	int len;
+	char content[MAX_WKFM_PATTERN_SIZE];
+	char mask[MAX_WKFM_SIZE];
+} rtl_priv_pattern_t;
+
+#endif /* CONFIG_WOWLAN */
+
+enum Power_Mgnt {
+	PS_MODE_ACTIVE	= 0	,
+	PS_MODE_MIN			,
+	PS_MODE_MAX			,
+	PS_MODE_DTIM			,	/* PS_MODE_SELF_DEFINED */
+	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,
+};
+
+enum lps_level {
+	LPS_NORMAL = 0,
+	LPS_LCLK,
+	LPS_PG,
+	LPS_LEVEL_MAX,
+};
+
+#ifdef CONFIG_PNO_SUPPORT
+#define MAX_PNO_LIST_COUNT 16
+#define MAX_SCAN_LIST_COUNT 14	/* 2.4G only */
+#define MAX_HIDDEN_AP 8		/* 8 hidden AP */
+#endif
+
+/*
+	BIT[2:0] = HW state
+	BIT[3] = Protocol PS state,   0: register active state , 1: register 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;
+};
+
+
+typedef _sema _pwrlock;
+
+
+__inline static void _init_pwrlock(_pwrlock *plock)
+{
+	_rtw_init_sema(plock, 1);
+}
+
+__inline static void _free_pwrlock(_pwrlock *plock)
+{
+	_rtw_free_sema(plock);
+}
+
+
+__inline static void _enter_pwrlock(_pwrlock *plock)
+{
+	_rtw_down_sema(plock);
+}
+
+
+__inline static void _exit_pwrlock(_pwrlock *plock)
+{
+	_rtw_up_sema(plock);
+}
+
+#define LPS_DELAY_MS	1000 /* 1 sec */
+
+#define EXE_PWR_NONE	0x01
+#define EXE_PWR_IPS		0x02
+#define EXE_PWR_LPS		0x04
+
+/* RF state. */
+typedef 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
+} rt_rf_power_state;
+
+/* 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 */
+#define	RT_RF_OFF_LEVL_HALT_NIC		BIT(3)	/* NIC halt, re-initialize hw parameters */
+#define	RT_RF_OFF_LEVL_FREE_FW		BIT(4)	/* FW free, re-download the FW */
+#define	RT_RF_OFF_LEVL_FW_32K		BIT(5)	/* FW in 32k */
+#define	RT_RF_PS_LEVEL_ALWAYS_ASPM	BIT(6)	/* Always enable ASPM and Clock Req in initialization. */
+#define	RT_RF_LPS_DISALBE_2R			BIT(30)	/* When LPS is on, disable 2R if no packet is received or transmittd. */
+#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)
+
+/* ASPM OSC Control bit, added by Roger, 2013.03.29. */
+#define	RT_PCI_ASPM_OSC_IGNORE		0	 /* PCI ASPM ignore OSC control in default */
+#define	RT_PCI_ASPM_OSC_ENABLE		BIT0 /* PCI ASPM controlled by OS according to ACPI Spec 5.0 */
+#define	RT_PCI_ASPM_OSC_DISABLE		BIT1 /* PCI ASPM controlled by driver or BIOS, i.e., force enable ASPM */
+
+
+enum _PS_BBRegBackup_ {
+	PSBBREG_RF0 = 0,
+	PSBBREG_RF1,
+	PSBBREG_RF2,
+	PSBBREG_AFE0,
+	PSBBREG_TOTALCNT
+};
+
+enum { /* for ips_mode */
+	IPS_NONE = 0,
+	IPS_NORMAL,
+	IPS_LEVEL_2,
+	IPS_NUM
+};
+
+/* Design for pwrctrl_priv.ips_deny, 32 bits for 32 reasons at most */
+typedef enum _PS_DENY_REASON {
+	PS_DENY_DRV_INITIAL = 0,
+	PS_DENY_SCAN,
+	PS_DENY_JOIN,
+	PS_DENY_DISCONNECT,
+	PS_DENY_SUSPEND,
+	PS_DENY_IOCTL,
+	PS_DENY_MGNT_TX,
+	PS_DENY_MONITOR_MODE,
+	PS_DENY_BEAMFORMING,		/* Beamforming */
+	PS_DENY_DRV_REMOVE = 30,
+	PS_DENY_OTHERS = 31
+} PS_DENY_REASON;
+
+#ifdef CONFIG_PNO_SUPPORT
+typedef struct pno_nlo_info {
+	u32 fast_scan_period;				/* Fast scan period */
+	u8	ssid_num;				/* number of entry */
+	u8	hidden_ssid_num;
+	u32	slow_scan_period;			/* slow scan period */
+	u32	fast_scan_iterations;			/* Fast scan iterations */
+	u8	ssid_length[MAX_PNO_LIST_COUNT];	/* SSID Length Array */
+	u8	ssid_cipher_info[MAX_PNO_LIST_COUNT];	/* Cipher information for security */
+	u8	ssid_channel_info[MAX_PNO_LIST_COUNT];	/* channel information */
+	u8	loc_probe_req[MAX_HIDDEN_AP];		/* loc_probeReq */
+} pno_nlo_info_t;
+
+typedef struct pno_ssid {
+	u32		SSID_len;
+	u8		SSID[32];
+} pno_ssid_t;
+
+typedef struct pno_ssid_list {
+	pno_ssid_t	node[MAX_PNO_LIST_COUNT];
+} pno_ssid_list_t;
+
+typedef struct pno_scan_channel_info {
+	u8	channel;
+	u8	tx_power;
+	u8	timeout;
+	u8	active;				/* set 1 means active scan, or pasivite scan. */
+} pno_scan_channel_info_t;
+
+typedef struct pno_scan_info {
+	u8	enableRFE;			/* Enable RFE */
+	u8	period_scan_time;		/* exclusive with fast_scan_period and slow_scan_period */
+	u8	periodScan;			/* exclusive with fast_scan_period and slow_scan_period */
+	u8	orig_80_offset;			/* original channel 80 offset */
+	u8	orig_40_offset;			/* original channel 40 offset */
+	u8	orig_bw;			/* original bandwidth */
+	u8	orig_ch;			/* original channel */
+	u8	channel_num;			/* number of channel */
+	u64	rfe_type;			/* rfe_type && 0x00000000000000ff */
+	pno_scan_channel_info_t ssid_channel_info[MAX_SCAN_LIST_COUNT];
+} pno_scan_info_t;
+#endif /* CONFIG_PNO_SUPPORT */
+
+#ifdef CONFIG_LPS_POFF
+/* Driver context for LPS 32K Close IO Power */
+typedef struct lps_poff_info {
+	bool	bEn;
+	u8	*pStaticFile;
+	u8	*pDynamicFile;
+	u32	ConfFileOffset;
+	u32	tx_bndy_static;
+	u32	tx_bndy_dynamic;
+	u16	ConfLenForPTK;
+	u16	ConfLenForGTK;
+	ATOMIC_T bEnterPOFF;
+	ATOMIC_T bTxBoundInProgress;
+	ATOMIC_T bSetPOFFParm;
+} lps_poff_info_t;
+#endif /*CONFIG_LPS_POFF*/
+
+struct aoac_report {
+	u8 iv[8];
+	u8 replay_counter_eapol_key[8];
+	u8 group_key[32];
+	u8 key_index;
+	u8 security_type;
+	u8 wow_pattern_idx;
+	u8 version_info;
+	u8 reserved[4];
+	u8 rxptk_iv[8];
+	u8 rxgtk_iv[4][8];
+};
+
+struct pwrctrl_priv {
+	_pwrlock	lock;
+	_pwrlock	check_32k_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 */
+	volatile u8 cpwm_tog; /* toggling */
+
+	u8	pwr_mode;
+	u8	smart_ps;
+	u8	bcn_ant_mode;
+	u8	dtim;
+
+#ifdef CONFIG_WMMPS_STA
+	u8 wmm_smart_ps;
+#endif /* CONFIG_WMMPS_STA */	
+
+	u32	alives;
+	_workitem cpwm_event;
+	_workitem dma_event; /*for handle un-synchronized tx dma*/
+#ifdef CONFIG_LPS_RPWM_TIMER
+	u8 brpwmtimeout;
+	_workitem rpwmtimeoutwi;
+	_timer pwr_rpwm_timer;
+#endif /* CONFIG_LPS_RPWM_TIMER */
+	u8	bpower_saving; /* for LPS/IPS */
+
+	u8	b_hw_radio_off;
+	u8	reg_rfoff;
+	u8	reg_pdnmode; /* powerdown mode */
+	u32	rfoff_reason;
+
+	/* RF OFF Level */
+	u32	cur_ps_level;
+	u32	reg_rfps_level;
+
+	uint	ips_enter_cnts;
+	uint	ips_leave_cnts;
+	uint	lps_enter_cnts;
+	uint	lps_leave_cnts;
+
+	u8	ips_mode;
+	u8	ips_org_mode;
+	u8	ips_mode_req; /* used to accept the mode setting request, will update to ipsmode later */
+	uint bips_processing;
+	systime ips_deny_time; /* will deny IPS when system time is smaller than this */
+	u8 pre_ips_type;/* 0: default flow, 1: carddisbale flow */
+
+	/* ps_deny: if 0, power save is free to go; otherwise deny all kinds of power save. */
+	/* Use PS_DENY_REASON to decide reason. */
+	/* Don't access this variable directly without control function, */
+	/* and this variable should be protected by lock. */
+	u32 ps_deny;
+
+	u8 ps_processing; /* temporarily used to mark whether in rtw_ps_processor */
+
+	u8 fw_psmode_iface_id;
+	u8	bLeisurePs;
+	u8	LpsIdleCount;
+	u8	power_mgnt;
+	u8	org_power_mgnt;
+	u8	bFwCurrentInPSMode;
+	systime	DelayLPSLastTimeStamp;
+	s32		pnp_current_pwr_state;
+	u8		pnp_bstop_trx;
+
+	#ifdef CONFIG_AUTOSUSPEND
+	int		ps_flag; /* used by autosuspend */
+	u8		bInternalAutoSuspend;
+	#endif
+	u8		bInSuspend;
+#ifdef CONFIG_BT_COEXIST
+	u8		bAutoResume;
+	u8		autopm_cnt;
+#endif
+	u8		bSupportRemoteWakeup;
+	u8		wowlan_wake_reason;
+	u8		wowlan_last_wake_reason;
+	u8		wowlan_ap_mode;
+	u8		wowlan_mode;
+	u8		wowlan_p2p_mode;
+	u8		wowlan_pno_enable;
+	u8		wowlan_in_resume;
+
+#ifdef CONFIG_GPIO_WAKEUP
+	u8		is_high_active;
+#endif /* CONFIG_GPIO_WAKEUP */
+#ifdef CONFIG_WOWLAN
+	bool		default_patterns_en;
+#ifdef CONFIG_IPV6
+	u8		wowlan_ns_offload_en;
+#endif /*CONFIG_IPV6*/
+	u8		wowlan_txpause_status;
+	u8		wowlan_pattern_idx;
+	u64		wowlan_fw_iv;
+	struct rtl_priv_pattern	patterns[MAX_WKFM_CAM_NUM];
+#ifdef CONFIG_PNO_SUPPORT
+	u8		pno_inited;
+	pno_nlo_info_t	*pnlo_info;
+	pno_scan_info_t	*pscan_info;
+	pno_ssid_list_t	*pno_ssid_list;
+#endif /* CONFIG_PNO_SUPPORT */
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+	_mutex	wowlan_pattern_cam_mutex;
+#endif
+	u8		wowlan_aoac_rpt_loc;
+	struct aoac_report wowlan_aoac_rpt;
+	u8		wowlan_dis_lps;/*for debug purpose*/
+#endif /* CONFIG_WOWLAN */
+	_timer	pwr_state_check_timer;
+	int		pwr_state_check_interval;
+	u8		pwr_state_check_cnts;
+
+
+	rt_rf_power_state	rf_pwrstate;/* cur power state, only for IPS */
+	/* rt_rf_power_state	current_rfpwrstate; */
+	rt_rf_power_state	change_rfpwrstate;
+
+	u8		bHWPowerdown; /* power down mode selection. 0:radio off, 1:power down */
+	u8		bHWPwrPindetect; /* come from registrypriv.hwpwrp_detect. enable power down function. 0:disable, 1:enable */
+	u8		bkeepfwalive;
+	u8		brfoffbyhw;
+	unsigned long PS_BBRegBackup[PSBBREG_TOTALCNT];
+
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+	struct workqueue_struct *rtw_workqueue;
+	_workitem resume_work;
+#endif
+
+#ifdef CONFIG_HAS_EARLYSUSPEND
+	struct early_suspend early_suspend;
+	u8 do_late_resume;
+#endif /* CONFIG_HAS_EARLYSUSPEND */
+
+#ifdef CONFIG_ANDROID_POWER
+	android_early_suspend_t early_suspend;
+	u8 do_late_resume;
+#endif
+
+#ifdef CONFIG_INTEL_PROXIM
+	u8	stored_power_mgnt;
+#endif
+
+#ifdef CONFIG_LPS_POFF
+	lps_poff_info_t	*plps_poff_info;
+#endif
+	u8 lps_level_bk;
+	u8 lps_level; /*LPS_NORMAL,LPA_CG,LPS_PG*/
+#ifdef CONFIG_LPS_PG
+	u8 lpspg_rsvd_page_locate;
+	u8 blpspg_info_up;
+#endif
+	u8 current_lps_hw_port_id;
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	systime radio_on_start_time;
+	systime pwr_saving_start_time;
+	u32 pwr_saving_time;
+	u32 on_time;
+	u32 tx_time;
+	u32 rx_time;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+};
+
+#define rtw_get_ips_mode_req(pwrctl) \
+	(pwrctl)->ips_mode_req
+
+#define rtw_ips_mode_req(pwrctl, ips_mode) \
+	(pwrctl)->ips_mode_req = (ips_mode)
+
+#define RTW_PWR_STATE_CHK_INTERVAL 2000
+
+#define _rtw_set_pwr_state_check_timer(pwrctl, ms) \
+	do { \
+		/*RTW_INFO("%s _rtw_set_pwr_state_check_timer(%p, %d)\n", __FUNCTION__, (pwrctl), (ms));*/ \
+		_set_timer(&(pwrctl)->pwr_state_check_timer, (ms)); \
+	} while (0)
+
+#define rtw_set_pwr_state_check_timer(pwrctl) \
+	_rtw_set_pwr_state_check_timer((pwrctl), (pwrctl)->pwr_state_check_interval)
+
+extern void rtw_init_pwrctrl_priv(_adapter *adapter);
+extern void rtw_free_pwrctrl_priv(_adapter *adapter);
+
+#ifdef CONFIG_LPS_LCLK
+s32 rtw_register_task_alive(PADAPTER, u32 task);
+void rtw_unregister_task_alive(PADAPTER, u32 task);
+extern s32 rtw_register_tx_alive(PADAPTER padapter);
+extern void rtw_unregister_tx_alive(PADAPTER padapter);
+extern s32 rtw_register_rx_alive(PADAPTER padapter);
+extern void rtw_unregister_rx_alive(PADAPTER padapter);
+extern s32 rtw_register_cmd_alive(PADAPTER padapter);
+extern void rtw_unregister_cmd_alive(PADAPTER padapter);
+extern s32 rtw_register_evt_alive(PADAPTER padapter);
+extern void rtw_unregister_evt_alive(PADAPTER padapter);
+extern void cpwm_int_hdl(PADAPTER padapter, struct reportpwrstate_parm *preportpwrstate);
+extern void LPS_Leave_check(PADAPTER padapter);
+#endif
+
+extern void LeaveAllPowerSaveMode(PADAPTER Adapter);
+extern void LeaveAllPowerSaveModeDirect(PADAPTER Adapter);
+#ifdef CONFIG_IPS
+void _ips_enter(_adapter *padapter);
+void ips_enter(_adapter *padapter);
+int _ips_leave(_adapter *padapter);
+int ips_leave(_adapter *padapter);
+#endif
+
+void rtw_ps_processor(_adapter *padapter);
+
+#ifdef CONFIG_AUTOSUSPEND
+int autoresume_enter(_adapter *padapter);
+#endif
+#ifdef SUPPORT_HW_RFOFF_DETECTED
+rt_rf_power_state RfOnOffDetect(IN	PADAPTER pAdapter);
+#endif
+
+
+int rtw_fw_ps_state(PADAPTER padapter);
+
+#ifdef CONFIG_LPS
+s32 LPS_RF_ON_check(PADAPTER padapter, u32 delay_ms);
+void LPS_Enter(PADAPTER padapter, const char *msg);
+void LPS_Leave(PADAPTER padapter, const char *msg);
+void traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets);
+void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode, const char *msg);
+void rtw_set_fw_in_ips_mode(PADAPTER padapter, u8 enable);
+void rtw_set_rpwm(_adapter *padapter, u8 val8);
+void rtw_wow_lps_level_decide(_adapter *adapter, u8 wow_en);
+#endif
+
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+void rtw_resume_in_workqueue(struct pwrctrl_priv *pwrpriv);
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
+
+#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
+bool rtw_is_earlysuspend_registered(struct pwrctrl_priv *pwrpriv);
+bool rtw_is_do_late_resume(struct pwrctrl_priv *pwrpriv);
+void rtw_set_do_late_resume(struct pwrctrl_priv *pwrpriv, bool enable);
+void rtw_register_early_suspend(struct pwrctrl_priv *pwrpriv);
+void rtw_unregister_early_suspend(struct pwrctrl_priv *pwrpriv);
+#else
+#define rtw_is_earlysuspend_registered(pwrpriv) _FALSE
+#define rtw_is_do_late_resume(pwrpriv) _FALSE
+#define rtw_set_do_late_resume(pwrpriv, enable) do {} while (0)
+#define rtw_register_early_suspend(pwrpriv) do {} while (0)
+#define rtw_unregister_early_suspend(pwrpriv) do {} while (0)
+#endif /* CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER */
+
+u8 rtw_interface_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val);
+void rtw_set_ips_deny(_adapter *padapter, u32 ms);
+int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller);
+#define rtw_pwr_wakeup(adapter) _rtw_pwr_wakeup(adapter, RTW_PWR_STATE_CHK_INTERVAL, __FUNCTION__)
+#define rtw_pwr_wakeup_ex(adapter, ips_deffer_ms) _rtw_pwr_wakeup(adapter, ips_deffer_ms, __FUNCTION__)
+int rtw_pm_set_ips(_adapter *padapter, u8 mode);
+int rtw_pm_set_lps(_adapter *padapter, u8 mode);
+int rtw_pm_set_lps_level(_adapter *padapter, u8 level);
+
+void rtw_ps_deny(PADAPTER padapter, PS_DENY_REASON reason);
+void rtw_ps_deny_cancel(PADAPTER padapter, PS_DENY_REASON reason);
+u32 rtw_ps_deny_get(PADAPTER padapter);
+
+#if defined(CONFIG_WOWLAN)
+void rtw_get_current_ip_address(PADAPTER padapter, u8 *pcurrentip);
+void rtw_get_sec_iv(PADAPTER padapter, u8 *pcur_dot11txpn, u8 *StaAddr);
+bool rtw_check_pattern_valid(u8 *input, u8 len);
+bool rtw_wowlan_parser_pattern_cmd(u8 *input, char *pattern,
+				int *pattern_len, char *bit_mask);
+void rtw_wow_pattern_sw_reset(_adapter *adapter);
+u8 rtw_set_default_pattern(_adapter *adapter);
+void rtw_wow_pattern_sw_dump(_adapter *adapter);
+#endif /* CONFIG_WOWLAN */
+#endif /* __RTL871X_PWRCTRL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_qos.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_qos.h
new file mode 100644
index 000000000000..8e1d013e128f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_qos.h
@@ -0,0 +1,66 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_QOS_H_
+#define _RTW_QOS_H_
+
+#define DRV_CFG_UAPSD_VO 	BIT0
+#define DRV_CFG_UAPSD_VI 	BIT1
+#define DRV_CFG_UAPSD_BK 	BIT2
+#define DRV_CFG_UAPSD_BE 	BIT3
+
+#define WMM_IE_UAPSD_VO 	BIT0
+#define WMM_IE_UAPSD_VI 	BIT1
+#define WMM_IE_UAPSD_BK 	BIT2
+#define WMM_IE_UAPSD_BE 	BIT3
+
+#define WMM_TID0 	BIT0
+#define WMM_TID1 	BIT1
+#define WMM_TID2 	BIT2
+#define WMM_TID3 	BIT3
+#define WMM_TID4 	BIT4
+#define WMM_TID5 	BIT5
+#define WMM_TID6 	BIT6
+#define WMM_TID7 	BIT7
+
+#define AP_SUPPORTED_UAPSD BIT7
+/* TC = Traffic Category,  TID0~7 represents TC */
+#define BIT_MASK_TID_TC 0xff
+/* TS = Traffic Stream,  TID8~15 represents TS */
+#define BIT_MASK_TID_TS 0xff00
+#define ALL_TID_TC_SUPPORTED_UAPSD 0xff
+
+struct	qos_priv	{
+
+	unsigned int	  qos_option;	/* bit mask option: u-apsd, s-apsd, ts, block ack...		 */
+
+#ifdef CONFIG_WMMPS_STA
+	/* uapsd (unscheduled automatic power-save delivery) = a kind of wmmps */
+	u8 uapsd_max_sp_len;
+	/* declare uapsd_tid as a bitmap for the uapsd setting of TID 0~15 */
+	u16 uapsd_tid;
+	/* declare uapsd_tid_delivery_enabled as a bitmap for the delivery-enabled setting of TID 0~7 */
+	u8 uapsd_tid_delivery_enabled;
+	/* declare uapsd_tid_trigger_enabled as a bitmap for the trigger-enabled setting of TID 0~7 */
+	u8 uapsd_tid_trigger_enabled;
+	/* declare uapsd_ap_supported to record whether the connected ap  supports uapsd or not */
+	u8 uapsd_ap_supported;
+#endif /* CONFIG_WMMPS_STA */	
+
+};
+
+
+#endif /* _RTL871X_QOS_H_ */
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_recv.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_recv.h
new file mode 100644
index 000000000000..d77557d13d9e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_recv.h
@@ -0,0 +1,889 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+#define RTW_RX_MSDU_ACT_NONE		0
+#define RTW_RX_MSDU_ACT_INDICATE	BIT0
+#define RTW_RX_MSDU_ACT_FORWARD		BIT1
+
+#ifdef PLATFORM_OS_XP
+	#ifdef CONFIG_SDIO_HCI
+		#define NR_RECVBUFF 1024/* 512 */ /* 128 */
+	#else
+		#define NR_RECVBUFF (16)
+	#endif
+#elif defined(PLATFORM_OS_CE)
+	#ifdef CONFIG_SDIO_HCI
+		#define NR_RECVBUFF (128)
+	#else
+		#define NR_RECVBUFF (4)
+	#endif
+#else /* PLATFORM_LINUX /PLATFORM_BSD */
+
+	#ifdef CONFIG_SINGLE_RECV_BUF
+		#define NR_RECVBUFF (1)
+	#else
+		#if defined(CONFIG_GSPI_HCI)
+			#define NR_RECVBUFF (32)
+		#elif defined(CONFIG_SDIO_HCI)
+			#define NR_RECVBUFF (8)
+		#else
+			#define NR_RECVBUFF (8)
+		#endif
+	#endif /* CONFIG_SINGLE_RECV_BUF */
+	#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+		#define NR_PREALLOC_RECV_SKB (rtw_rtkm_get_nr_recv_skb()>>1)
+	#else /*!CONFIG_PREALLOC_RX_SKB_BUFFER */
+		#define NR_PREALLOC_RECV_SKB 8
+	#endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
+
+	#ifdef CONFIG_RTW_NAPI
+		#define RTL_NAPI_WEIGHT (32)
+	#endif
+#endif
+
+#if defined(CONFIG_RTL8821C) && defined(CONFIG_SDIO_HCI) && defined(CONFIG_RECV_THREAD_MODE)
+	#ifdef NR_RECVBUFF
+	#undef NR_RECVBUFF
+	#define NR_RECVBUFF (32)
+	#endif
+#endif
+
+#define NR_RECVFRAME 256
+
+#define RXFRAME_ALIGN	8
+#define RXFRAME_ALIGN_SZ	(1<<RXFRAME_ALIGN)
+
+#define DRVINFO_SZ	4 /* unit is 8bytes */
+
+#define MAX_RXFRAME_CNT	512
+#define MAX_RX_NUMBLKS		(32)
+#define RECVFRAME_HDR_ALIGN 128
+#define MAX_CONTINUAL_NORXPACKET_COUNT 4    /*  In MAX_CONTINUAL_NORXPACKET_COUNT*2 sec  , no rx traffict would issue DELBA*/
+
+#define PHY_RSSI_SLID_WIN_MAX				100
+#define PHY_LINKQUALITY_SLID_WIN_MAX		20
+
+
+#define SNAP_SIZE sizeof(struct ieee80211_snap_hdr)
+
+#define RX_MPDU_QUEUE				0
+#define RX_CMD_QUEUE				1
+#define RX_MAX_QUEUE				2
+
+static u8 SNAP_ETH_TYPE_IPX[2] = {0x81, 0x37};
+
+static u8 SNAP_ETH_TYPE_APPLETALK_AARP[2] = {0x80, 0xf3};
+static u8 SNAP_ETH_TYPE_APPLETALK_DDP[2] = {0x80, 0x9b};
+static u8 SNAP_ETH_TYPE_TDLS[2] = {0x89, 0x0d};
+static u8 SNAP_HDR_APPLETALK_DDP[3] = {0x08, 0x00, 0x07}; /* Datagram Delivery Protocol */
+
+static u8 oui_8021h[] = {0x00, 0x00, 0xf8};
+static u8 oui_rfc1042[] = {0x00, 0x00, 0x00};
+
+#define MAX_SUBFRAME_COUNT	64
+static u8 rtw_rfc1042_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };
+/* Bridge-Tunnel header (for EtherTypes ETH_P_AARP and ETH_P_IPX) */
+static u8 rtw_bridge_tunnel_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8 };
+
+/* for Rx reordering buffer control */
+struct recv_reorder_ctrl {
+	_adapter	*padapter;
+	u8 tid;
+	u8 enable;
+	u16 indicate_seq;/* =wstart_b, init_value=0xffff */
+	u16 wend_b;
+	u8 wsize_b;
+	u8 ampdu_size;
+	_queue pending_recvframe_queue;
+	_timer reordering_ctrl_timer;
+	u8 bReorderWaiting;
+};
+
+struct	stainfo_rxcache	{
+	u16	tid_rxseq[16];
+	u8 iv[16][8];
+	u8 last_tid;
+#if 0
+	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;
+#endif
+};
+
+
+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 rx_raw_rssi {
+	u8 data_rate;
+	u8 pwdball;
+	s8 pwr_all;
+
+	u8 mimo_signal_strength[4];/* in 0~100 index */
+	u8 mimo_signal_quality[4];
+
+	s8 ofdm_pwr[4];
+	u8 ofdm_snr[4];
+};
+
+
+#include "cmn_info/rtw_sta_info.h"
+
+struct rx_pkt_attrib	{
+	u16	pkt_len;
+	u8	physt;
+	u8	drvinfo_sz;
+	u8	shift_sz;
+	u8	hdrlen; /* the WLAN Header Len */
+	u8	to_fr_ds;
+	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;
+	u8	encrypt; /* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith */
+	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];
+#ifdef CONFIG_RTW_MESH
+	u8	msa[ETH_ALEN]; /* mesh sa */
+	u8	mda[ETH_ALEN]; /* mesh da */
+	u8 mesh_ctrl_present;
+	u8	mesh_ctrl_len; /* length of mesh control field */
+#endif
+
+	u8	ack_policy;
+
+	u8	key_index;
+
+	u8	data_rate;
+	u8 ch; /* RX channel */
+	u8	bw;
+	u8	stbc;
+	u8	ldpc;
+	u8	sgi;
+	u8	pkt_rpt_type;
+	u32 tsfl;
+	u32	MacIDValidEntry[2];	/* 64 bits present 64 entry. */
+	u8	ppdu_cnt;
+	u32 	free_cnt;		/* free run counter */
+	struct phydm_phyinfo_struct phy_info;
+};
+
+#ifdef CONFIG_RTW_MESH
+#define RATTRIB_GET_MCTRL_LEN(rattrib) ((rattrib)->mesh_ctrl_len)
+#else
+#define RATTRIB_GET_MCTRL_LEN(rattrib) 0
+#endif
+
+/* 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_WIN_SIZE	128 */
+/* #define REORDER_ENTRY_NUM	128 */
+#define REORDER_WAIT_TIME	(50) /* (ms) */
+
+#define RECVBUFF_ALIGN_SZ 8
+
+#ifdef CONFIG_TRX_BD_ARCH
+	#define RX_WIFI_INFO_SIZE	24
+#elif (defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)) && defined(CONFIG_PCI_HCI)
+	#define RXBD_SIZE	sizeof(struct recv_stat)
+#endif
+
+#define RXDESC_SIZE	24
+#define RXDESC_OFFSET RXDESC_SIZE
+
+#ifdef CONFIG_TRX_BD_ARCH
+struct rx_buf_desc {
+	/* RX has exactly one segment */
+#ifdef CONFIG_64BIT_DMA
+	unsigned int dword[4];
+#else
+	unsigned int dword[2];
+#endif
+};
+
+struct recv_stat {
+	unsigned int rxdw[8];
+};
+#else
+struct recv_stat {
+	unsigned int rxdw0;
+
+	unsigned int rxdw1;
+
+#if !((defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)) && defined(CONFIG_PCI_HCI))  /* exclude 8192ee, 8814ae, 8822be, 8821ce */
+	unsigned int rxdw2;
+
+	unsigned int rxdw3;
+#endif
+
+#ifndef BUF_DESC_ARCH
+	unsigned int rxdw4;
+
+	unsigned int rxdw5;
+
+#ifdef CONFIG_PCI_HCI
+	unsigned int rxdw6;
+
+	unsigned int rxdw7;
+#endif
+#endif /* if BUF_DESC_ARCH is defined, rx_buf_desc occupy 4 double words */
+};
+#endif
+
+#define EOR BIT(30)
+
+#ifdef CONFIG_PCI_HCI
+#define PCI_MAX_RX_QUEUE		1/* MSDU packet queue, Rx Command Queue */
+#define PCI_MAX_RX_COUNT		128
+#ifdef CONFIG_TRX_BD_ARCH
+#define RX_BD_NUM				PCI_MAX_RX_COUNT	/* alias */
+#endif
+
+struct rtw_rx_ring {
+#ifdef CONFIG_TRX_BD_ARCH
+	struct rx_buf_desc	*buf_desc;
+#else
+	struct recv_stat	*desc;
+#endif
+	dma_addr_t		dma;
+	unsigned int		idx;
+	struct sk_buff	*rx_buf[PCI_MAX_RX_COUNT];
+};
+#endif
+
+
+
+/*
+accesser of recv_priv: rtw_recv_entry(dispatch / passive level); recv_thread(passive) ; returnpkt(dispatch)
+; halt(passive) ;
+
+using enter_critical section to protect
+*/
+
+#ifndef DBG_RX_BH_TRACKING
+#define DBG_RX_BH_TRACKING 0
+#endif
+
+struct recv_priv {
+	_lock	lock;
+
+#ifdef CONFIG_RECV_THREAD_MODE
+	_sema	recv_sema;
+
+#endif
+
+	/* _queue	blk_strms[MAX_RX_NUMBLKS];    */ /* keeping the block ack frame until return ack */
+	_queue	free_recv_queue;
+	_queue	recv_pending_queue;
+	_queue	uc_swdec_pending_queue;
+
+
+	u8 *pallocated_frame_buf;
+	u8 *precv_frame_buf;
+
+	uint free_recvframe_cnt;
+
+	#if DBG_RX_BH_TRACKING
+	u32 rx_bh_stage;
+	u32 rx_bh_buf_dq_cnt;
+	void *rx_bh_lbuf;
+	void *rx_bh_cbuf;
+	void *rx_bh_cbuf_data;
+	u32 rx_bh_cbuf_dlen;
+	u32 rx_bh_cbuf_pos;
+	void *rx_bh_cframe;
+	#endif
+
+	_adapter	*adapter;
+
+#ifdef PLATFORM_WINDOWS
+	_nic_hdl  RxPktPoolHdl;
+	_nic_hdl  RxBufPoolHdl;
+
+#ifdef PLATFORM_OS_XP
+	PMDL	pbytecnt_mdl;
+#endif
+	uint	counter; /* record the number that up-layer will return to drv; only when counter==0 can we  release recv_priv */
+	NDIS_EVENT	recv_resource_evt ;
+#endif
+
+
+	u32 is_any_non_be_pkts;
+
+	u64	rx_bytes;
+	u64	rx_pkts;
+	u64	rx_drop;
+
+	u64 dbg_rx_drop_count;
+	u64 dbg_rx_ampdu_drop_count;
+	u64 dbg_rx_ampdu_forced_indicate_count;
+	u64 dbg_rx_ampdu_loss_count;
+	u64 dbg_rx_dup_mgt_frame_drop_count;
+	u64 dbg_rx_ampdu_window_shift_cnt;
+	u64 dbg_rx_conflic_mac_addr_cnt;
+
+	uint  rx_icv_err;
+	uint  rx_largepacket_crcerr;
+	uint  rx_smallpacket_crcerr;
+	uint  rx_middlepacket_crcerr;
+
+#ifdef CONFIG_USB_HCI
+	/* u8 *pallocated_urb_buf; */
+	_sema allrxreturnevt;
+	uint	ff_hwaddr;
+	ATOMIC_T	rx_pending_cnt;
+
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+#ifdef PLATFORM_LINUX
+	PURB	int_in_urb;
+#endif
+
+	u8	*int_in_buf;
+#endif /* CONFIG_USB_INTERRUPT_IN_PIPE */
+
+#endif
+#if defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
+#ifdef PLATFORM_FREEBSD
+	struct task irq_prepare_beacon_tasklet;
+	struct task recv_tasklet;
+#else /* PLATFORM_FREEBSD */
+	struct tasklet_struct irq_prepare_beacon_tasklet;
+	struct tasklet_struct recv_tasklet;
+#endif /* PLATFORM_FREEBSD */
+	struct sk_buff_head free_recv_skb_queue;
+	struct sk_buff_head rx_skb_queue;
+#ifdef CONFIG_RTW_NAPI
+		struct sk_buff_head rx_napi_skb_queue;
+#endif 
+#ifdef CONFIG_RX_INDICATE_QUEUE
+	struct task rx_indicate_tasklet;
+	struct ifqueue rx_indicate_queue;
+#endif /* CONFIG_RX_INDICATE_QUEUE */
+
+#endif /* defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD) */
+
+	u8 *pallocated_recv_buf;
+	u8 *precv_buf;    /* 4 alignment */
+	_queue	free_recv_buf_queue;
+	u32	free_recv_buf_queue_cnt;
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_USB_HCI)
+	_queue	recv_buf_pending_queue;
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	/* Rx */
+	struct rtw_rx_ring	rx_ring[PCI_MAX_RX_QUEUE];
+	int rxringcount;	/* size should be PCI_MAX_RX_QUEUE */
+	u16	rxbuffersize;
+#endif
+
+	/* For display the phy informatiom */
+	u8 is_signal_dbg;	/* for debug */
+	u8 signal_strength_dbg;	/* for debug */
+
+	u8 signal_strength;
+	u8 signal_qual;
+	s8 rssi;	/* translate_percentage_to_dbm(ptarget_wlan->network.PhyInfo.SignalStrength); */
+	struct rx_raw_rssi raw_rssi_info;
+	/* s8 rxpwdb;	 */
+	/* int RxSNRdB[2]; */
+	/* s8 RxRssi[2]; */
+	/* int FalseAlmCnt_all; */
+
+
+#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
+	_timer 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;
+#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+	struct smooth_rssi_data signal_qual_data;
+	struct smooth_rssi_data signal_strength_data;
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+	u16 sink_udpport, pre_rtp_rxseq, cur_rtp_rxseq;
+
+	BOOLEAN store_law_data_flag;
+};
+
+#define RX_BH_STG_UNKNOWN		0
+#define RX_BH_STG_HDL_ENTER		1
+#define RX_BH_STG_HDL_EXIT		2
+#define RX_BH_STG_NEW_BUF		3
+#define RX_BH_STG_NEW_FRAME		4
+#define RX_BH_STG_NORMAL_RX		5
+#define RX_BH_STG_NORMAL_RX_END	6
+#define RX_BH_STG_C2H			7
+#define RX_BH_STG_C2H_END		8
+
+#if DBG_RX_BH_TRACKING
+void rx_bh_tk_set_stage(struct recv_priv *recv, u32 s);
+void rx_bh_tk_set_buf(struct recv_priv *recv, void *buf, void *data, u32 dlen);
+void rx_bh_tk_set_buf_pos(struct recv_priv *recv, void *pos);
+void rx_bh_tk_set_frame(struct recv_priv *recv, void *frame);
+void dump_rx_bh_tk(void *sel, struct recv_priv *recv);
+#else
+#define rx_bh_tk_set_stage(recv, s) do {} while (0)
+#define rx_bh_tk_set_buf(recv, buf, data, dlen) do {} while (0)
+#define rx_bh_tk_set_buf_pos(recv, pos) do {} while (0)
+#define rx_bh_tk_set_frame(recv, frame) do {} while (0)
+#define dump_rx_bh_tk(sel, recv) do {} while (0)
+#endif
+
+#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
+#define rtw_set_signal_stat_timer(recvpriv) _set_timer(&(recvpriv)->signal_stat_timer, (recvpriv)->signal_stat_sampling_interval)
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+
+struct sta_recv_priv {
+
+	_lock	lock;
+	sint	option;
+
+	/* _queue	blk_strms[MAX_RX_NUMBLKS]; */
+	_queue defrag_q;	 /* keeping the fragment frame until defrag */
+
+	struct	stainfo_rxcache rxcache;
+	u16	bmc_tid_rxseq[16];
+
+	/* uint	sta_rx_bytes; */
+	/* uint	sta_rx_pkts; */
+	/* uint	sta_rx_fail; */
+
+};
+
+
+struct recv_buf {
+	_list list;
+
+	_lock recvbuf_lock;
+
+	u32	ref_cnt;
+
+	PADAPTER adapter;
+
+	u8	*pbuf;
+	u8	*pallocated_buf;
+
+	u32	len;
+	u8	*phead;
+	u8	*pdata;
+	u8	*ptail;
+	u8	*pend;
+
+#ifdef CONFIG_USB_HCI
+
+#if defined(PLATFORM_OS_XP) || defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
+	PURB	purb;
+	dma_addr_t dma_transfer_addr;	/* (in) dma addr for transfer_buffer */
+	u32 alloc_sz;
+#endif
+
+#ifdef PLATFORM_OS_XP
+	PIRP		pirp;
+#endif
+
+#ifdef PLATFORM_OS_CE
+	USB_TRANSFER	usb_transfer_read_port;
+#endif
+
+	u8  irp_pending;
+	int  transfer_len;
+
+#endif
+
+#if defined(PLATFORM_LINUX)
+	_pkt *pskb;
+#elif defined(PLATFORM_FREEBSD) /* skb solution */
+	struct sk_buff *pskb;
+#endif
+};
+
+
+/*
+	head  ----->
+
+		data  ----->
+
+			payload
+
+		tail  ----->
+
+
+	end   ----->
+
+	len = (unsigned int )(tail - data);
+
+*/
+struct recv_frame_hdr {
+	_list	list;
+	_pkt *pkt;
+
+	_adapter  *adapter;
+
+	u8 fragcnt;
+
+	int frame_tag;
+
+	struct rx_pkt_attrib attrib;
+
+	uint  len;
+	u8 *rx_head;
+	u8 *rx_data;
+	u8 *rx_tail;
+	u8 *rx_end;
+
+	void *precvbuf;
+
+
+	/*  */
+	struct sta_info *psta;
+
+	/* for A-MPDU Rx reordering buffer control */
+	struct recv_reorder_ctrl *preorder_ctrl;
+
+#ifdef CONFIG_WAPI_SUPPORT
+	u8 UserPriority;
+	u8 WapiTempPN[16];
+	u8 WapiSrcAddr[6];
+	u8 bWapiCheckPNInDecrypt;
+	u8 bIsWaiPacket;
+#endif
+
+};
+
+
+union recv_frame {
+
+	union {
+		_list list;
+		struct recv_frame_hdr hdr;
+		uint mem[RECVFRAME_HDR_ALIGN >> 2];
+	} u;
+
+	/* uint mem[MAX_RXSZ>>2]; */
+
+};
+
+bool rtw_rframe_del_wfd_ie(union recv_frame *rframe, u8 ies_offset);
+
+typedef enum _RX_PACKET_TYPE {
+	NORMAL_RX,/* Normal rx packet */
+	TX_REPORT1,/* CCX */
+	TX_REPORT2,/* TX RPT */
+	HIS_REPORT,/* USB HISR RPT */
+	C2H_PACKET
+} RX_PACKET_TYPE, *PRX_PACKET_TYPE;
+
+extern union recv_frame *_rtw_alloc_recvframe(_queue *pfree_recv_queue);   /* get a free recv_frame from pfree_recv_queue */
+extern union recv_frame *rtw_alloc_recvframe(_queue *pfree_recv_queue);   /* get a free recv_frame from pfree_recv_queue */
+extern void rtw_init_recvframe(union recv_frame *precvframe , struct recv_priv *precvpriv);
+extern int	 rtw_free_recvframe(union recv_frame *precvframe, _queue *pfree_recv_queue);
+
+#define rtw_dequeue_recvframe(queue) rtw_alloc_recvframe(queue)
+extern int _rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue);
+extern int rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue);
+
+extern void rtw_free_recvframe_queue(_queue *pframequeue,  _queue *pfree_recv_queue);
+u32 rtw_free_uc_swdec_pending_queue(_adapter *adapter);
+
+sint rtw_enqueue_recvbuf_to_head(struct recv_buf *precvbuf, _queue *queue);
+sint rtw_enqueue_recvbuf(struct recv_buf *precvbuf, _queue *queue);
+struct recv_buf *rtw_dequeue_recvbuf(_queue *queue);
+
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
+void rtw_reordering_ctrl_timeout_handler(void *pcontext);
+#endif
+
+void rx_query_phy_status(union recv_frame *rframe, u8 *phy_stat);
+int rtw_inc_and_chk_continual_no_rx_packet(struct sta_info *sta, int tid_index);
+void rtw_reset_continual_no_rx_packet(struct sta_info *sta, int tid_index);
+
+#ifdef CONFIG_RECV_THREAD_MODE
+thread_return rtw_recv_thread(thread_context context);
+#endif
+
+__inline static u8 *get_rxmem(union recv_frame *precvframe)
+{
+	/* always return rx_head... */
+	if (precvframe == NULL)
+		return NULL;
+
+	return precvframe->u.hdr.rx_head;
+}
+
+__inline static u8 *get_rx_status(union recv_frame *precvframe)
+{
+
+	return get_rxmem(precvframe);
+
+}
+
+__inline static u8 *get_recvframe_data(union recv_frame *precvframe)
+{
+
+	/* alwasy return rx_data */
+	if (precvframe == NULL)
+		return NULL;
+
+	return precvframe->u.hdr.rx_data;
+
+}
+
+__inline static u8 *recvframe_push(union recv_frame *precvframe, sint sz)
+{
+	/* append data before rx_data */
+
+	/* add data to the start of recv_frame
+	*
+	*      This function extends the used data area of the recv_frame at the buffer
+	*      start. rx_data must be still larger than rx_head, after pushing.
+	*/
+
+	if (precvframe == NULL)
+		return NULL;
+
+
+	precvframe->u.hdr.rx_data -= sz ;
+	if (precvframe->u.hdr.rx_data < precvframe->u.hdr.rx_head) {
+		precvframe->u.hdr.rx_data += sz ;
+		return NULL;
+	}
+
+	precvframe->u.hdr.len += sz;
+
+	return precvframe->u.hdr.rx_data;
+
+}
+
+
+__inline static u8 *recvframe_pull(union recv_frame *precvframe, sint sz)
+{
+	/* rx_data += sz; move rx_data sz bytes  hereafter */
+
+	/* used for extract sz bytes from rx_data, update rx_data and return the updated rx_data to the caller */
+
+
+	if (precvframe == NULL)
+		return NULL;
+
+
+	precvframe->u.hdr.rx_data += sz;
+
+	if (precvframe->u.hdr.rx_data > precvframe->u.hdr.rx_tail) {
+		precvframe->u.hdr.rx_data -= sz;
+		return NULL;
+	}
+
+	precvframe->u.hdr.len -= sz;
+
+	return precvframe->u.hdr.rx_data;
+
+}
+
+__inline static u8 *recvframe_put(union recv_frame *precvframe, sint sz)
+{
+	/* rx_tai += sz; move rx_tail sz bytes  hereafter */
+
+	/* used for append sz bytes from ptr to rx_tail, update rx_tail and return the updated rx_tail to the caller */
+	/* after putting, rx_tail must be still larger than rx_end. */
+	unsigned char *prev_rx_tail;
+
+	/* RTW_INFO("recvframe_put: len=%d\n", sz); */
+
+	if (precvframe == NULL)
+		return NULL;
+
+	prev_rx_tail = precvframe->u.hdr.rx_tail;
+
+	precvframe->u.hdr.rx_tail += sz;
+
+	if (precvframe->u.hdr.rx_tail > precvframe->u.hdr.rx_end) {
+		precvframe->u.hdr.rx_tail -= sz;
+		return NULL;
+	}
+
+	precvframe->u.hdr.len += sz;
+
+	return precvframe->u.hdr.rx_tail;
+
+}
+
+
+
+__inline static u8 *recvframe_pull_tail(union recv_frame *precvframe, sint sz)
+{
+	/* rmv data from rx_tail (by yitsen) */
+
+	/* used for extract sz bytes from rx_end, update rx_end and return the updated rx_end to the caller */
+	/* after pulling, rx_end must be still larger than rx_data. */
+
+	if (precvframe == NULL)
+		return NULL;
+
+	precvframe->u.hdr.rx_tail -= sz;
+
+	if (precvframe->u.hdr.rx_tail < precvframe->u.hdr.rx_data) {
+		precvframe->u.hdr.rx_tail += sz;
+		return NULL;
+	}
+
+	precvframe->u.hdr.len -= sz;
+
+	return precvframe->u.hdr.rx_tail;
+
+}
+
+
+
+__inline static _buffer *get_rxbuf_desc(union recv_frame *precvframe)
+{
+	_buffer *buf_desc;
+
+	if (precvframe == NULL)
+		return NULL;
+#ifdef PLATFORM_WINDOWS
+	NdisQueryPacket(precvframe->u.hdr.pkt, NULL, NULL, &buf_desc, NULL);
+#endif
+
+	return buf_desc;
+}
+
+
+__inline static union recv_frame *rxmem_to_recvframe(u8 *rxmem)
+{
+	/* due to the design of 2048 bytes alignment of recv_frame, we can reference the union recv_frame */
+	/* from any given member of recv_frame. */
+	/* rxmem indicates the any member/address in recv_frame */
+
+	return (union recv_frame *)(((SIZE_PTR)rxmem >> RXFRAME_ALIGN) << RXFRAME_ALIGN);
+
+}
+
+__inline static union recv_frame *pkt_to_recvframe(_pkt *pkt)
+{
+
+	u8 *buf_star;
+	union recv_frame *precv_frame;
+#ifdef PLATFORM_WINDOWS
+	_buffer *buf_desc;
+	uint len;
+
+	NdisQueryPacket(pkt, NULL, NULL, &buf_desc, &len);
+	NdisQueryBufferSafe(buf_desc, &buf_star, &len, HighPagePriority);
+#endif
+	precv_frame = rxmem_to_recvframe((unsigned char *)buf_star);
+
+	return precv_frame;
+}
+
+__inline static u8 *pkt_to_recvmem(_pkt *pkt)
+{
+	/* return the rx_head */
+
+	union recv_frame *precv_frame = pkt_to_recvframe(pkt);
+
+	return	precv_frame->u.hdr.rx_head;
+
+}
+
+__inline static u8 *pkt_to_recvdata(_pkt *pkt)
+{
+	/* return the rx_data */
+
+	union recv_frame *precv_frame = pkt_to_recvframe(pkt);
+
+	return	precv_frame->u.hdr.rx_data;
+
+}
+
+
+__inline static sint get_recvframe_len(union recv_frame *precvframe)
+{
+	return precvframe->u.hdr.len;
+}
+
+
+__inline static s32 translate_percentage_to_dbm(u32 SignalStrengthIndex)
+{
+	s32	SignalPower; /* in dBm. */
+
+#ifdef CONFIG_SIGNAL_SCALE_MAPPING
+	/* Translate to dBm (x=0.5y-95). */
+	SignalPower = (s32)((SignalStrengthIndex + 1) >> 1);
+	SignalPower -= 95;
+#else
+	/* Translate to dBm (x=y-100) */
+	SignalPower = SignalStrengthIndex - 100;
+#endif
+
+	return SignalPower;
+}
+
+struct sta_info;
+
+extern void _rtw_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv);
+
+extern void  mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame);
+
+u8 adapter_allow_bmc_data_rx(_adapter *adapter);
+s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status);
+void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info *sta);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rf.h
new file mode 100644
index 000000000000..e4c80b945112
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rf.h
@@ -0,0 +1,275 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+#define NumRates	(13)
+
+/* slot time for 11g */
+#define SHORT_SLOT_TIME					9
+#define NON_SHORT_SLOT_TIME				20
+
+#define CENTER_CH_2G_40M_NUM	9
+#define CENTER_CH_2G_NUM		14
+#define CENTER_CH_5G_20M_NUM	28	/* 20M center channels */
+#define CENTER_CH_5G_40M_NUM	14	/* 40M center channels */
+#define CENTER_CH_5G_80M_NUM	7	/* 80M center channels */
+#define CENTER_CH_5G_160M_NUM	3	/* 160M center channels */
+#define CENTER_CH_5G_ALL_NUM	(CENTER_CH_5G_20M_NUM + CENTER_CH_5G_40M_NUM + CENTER_CH_5G_80M_NUM)
+
+#define	MAX_CHANNEL_NUM_2G	CENTER_CH_2G_NUM
+#define	MAX_CHANNEL_NUM_5G	CENTER_CH_5G_20M_NUM
+#define	MAX_CHANNEL_NUM		(MAX_CHANNEL_NUM_2G + MAX_CHANNEL_NUM_5G)
+
+extern u8 center_ch_2g[CENTER_CH_2G_NUM];
+extern u8 center_ch_2g_40m[CENTER_CH_2G_40M_NUM];
+
+u8 center_chs_2g_num(u8 bw);
+u8 center_chs_2g(u8 bw, u8 id);
+
+extern u8 center_ch_5g_20m[CENTER_CH_5G_20M_NUM];
+extern u8 center_ch_5g_40m[CENTER_CH_5G_40M_NUM];
+extern u8 center_ch_5g_20m_40m[CENTER_CH_5G_20M_NUM + CENTER_CH_5G_40M_NUM];
+extern u8 center_ch_5g_80m[CENTER_CH_5G_80M_NUM];
+extern u8 center_ch_5g_all[CENTER_CH_5G_ALL_NUM];
+
+u8 center_chs_5g_num(u8 bw);
+u8 center_chs_5g(u8 bw, u8 id);
+
+u8 rtw_get_scch_by_cch_offset(u8 cch, u8 bw, u8 offset);
+
+u8 rtw_get_op_chs_by_cch_bw(u8 cch, u8 bw, u8 **op_chs, u8 *op_ch_num);
+
+u8 rtw_get_ch_group(u8 ch, u8 *group, u8 *cck_group);
+
+typedef enum _CAPABILITY {
+	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,
+} CAPABILITY, *PCAPABILITY;
+
+enum	_REG_PREAMBLE_MODE {
+	PREAMBLE_LONG	= 1,
+	PREAMBLE_AUTO	= 2,
+	PREAMBLE_SHORT	= 3,
+};
+
+#define rf_path_char(path) (((path) >= RF_PATH_MAX) ? 'X' : 'A' + (path))
+
+/* Bandwidth Offset */
+#define HAL_PRIME_CHNL_OFFSET_DONT_CARE	0
+#define HAL_PRIME_CHNL_OFFSET_LOWER	1
+#define HAL_PRIME_CHNL_OFFSET_UPPER	2
+
+typedef enum _BAND_TYPE {
+	BAND_ON_2_4G = 0,
+	BAND_ON_5G = 1,
+	BAND_ON_BOTH = 2,
+	BAND_MAX = 3,
+} BAND_TYPE, *PBAND_TYPE;
+
+extern const char *const _band_str[];
+#define band_str(band) (((band) >= BAND_MAX) ? _band_str[BAND_MAX] : _band_str[(band)])
+
+extern const u8 _band_to_band_cap[];
+#define band_to_band_cap(band) (((band) >= BAND_MAX) ? _band_to_band_cap[BAND_MAX] : _band_to_band_cap[(band)])
+
+
+extern const char *const _ch_width_str[];
+#define ch_width_str(bw) (((bw) < CHANNEL_WIDTH_MAX) ? _ch_width_str[(bw)] : "CHANNEL_WIDTH_MAX")
+
+extern const u8 _ch_width_to_bw_cap[];
+#define ch_width_to_bw_cap(bw) (((bw) < CHANNEL_WIDTH_MAX) ? _ch_width_to_bw_cap[(bw)] : 0)
+
+/*
+ * Represent Extention Channel Offset in HT Capabilities
+ * This is available only in 40Mhz mode.
+ *   */
+typedef enum _EXTCHNL_OFFSET {
+	EXTCHNL_OFFSET_NO_EXT = 0,
+	EXTCHNL_OFFSET_UPPER = 1,
+	EXTCHNL_OFFSET_NO_DEF = 2,
+	EXTCHNL_OFFSET_LOWER = 3,
+} EXTCHNL_OFFSET, *PEXTCHNL_OFFSET;
+
+typedef enum _VHT_DATA_SC {
+	VHT_DATA_SC_DONOT_CARE = 0,
+	VHT_DATA_SC_20_UPPER_OF_80MHZ = 1,
+	VHT_DATA_SC_20_LOWER_OF_80MHZ = 2,
+	VHT_DATA_SC_20_UPPERST_OF_80MHZ = 3,
+	VHT_DATA_SC_20_LOWEST_OF_80MHZ = 4,
+	VHT_DATA_SC_20_RECV1 = 5,
+	VHT_DATA_SC_20_RECV2 = 6,
+	VHT_DATA_SC_20_RECV3 = 7,
+	VHT_DATA_SC_20_RECV4 = 8,
+	VHT_DATA_SC_40_UPPER_OF_80MHZ = 9,
+	VHT_DATA_SC_40_LOWER_OF_80MHZ = 10,
+} VHT_DATA_SC, *PVHT_DATA_SC_E;
+
+typedef enum _PROTECTION_MODE {
+	PROTECTION_MODE_AUTO = 0,
+	PROTECTION_MODE_FORCE_ENABLE = 1,
+	PROTECTION_MODE_FORCE_DISABLE = 2,
+} PROTECTION_MODE, *PPROTECTION_MODE;
+
+#define RF_TYPE_VALID(rf_type) (rf_type < RF_TYPE_MAX)
+
+extern const u8 _rf_type_to_rf_tx_cnt[];
+#define rf_type_to_rf_tx_cnt(rf_type) (RF_TYPE_VALID(rf_type) ? _rf_type_to_rf_tx_cnt[rf_type] : 0)
+
+extern const u8 _rf_type_to_rf_rx_cnt[];
+#define rf_type_to_rf_rx_cnt(rf_type) (RF_TYPE_VALID(rf_type) ? _rf_type_to_rf_rx_cnt[rf_type] : 0)
+
+int rtw_ch2freq(int chan);
+int rtw_freq2ch(int freq);
+bool rtw_chbw_to_freq_range(u8 ch, u8 bw, u8 offset, u32 *hi, u32 *lo);
+
+#define RTW_MODULE_RTL8821AE_HMC_M2		BIT0	/* RTL8821AE(HMC + M.2) */
+#define RTW_MODULE_RTL8821AU			BIT1	/* RTL8821AU */
+#define RTW_MODULE_RTL8812AENF_NGFF		BIT2	/* RTL8812AENF(8812AE+8761)_NGFF */
+#define RTW_MODULE_RTL8812AEBT_HMC		BIT3	/* RTL8812AEBT(8812AE+8761)_HMC */
+#define RTW_MODULE_RTL8188EE_HMC_M2		BIT4	/* RTL8188EE(HMC + M.2) */
+#define RTW_MODULE_RTL8723BE_HMC_M2		BIT5	/* RTL8723BE(HMC + M.2) */
+#define RTW_MODULE_RTL8723BS_NGFF1216	BIT6	/* RTL8723BS(NGFF1216) */
+#define RTW_MODULE_RTL8192EEBT_HMC_M2	BIT7	/* RTL8192EEBT(8192EE+8761AU)_(HMC + M.2) */
+#define RTW_MODULE_RTL8723DE_NGFF1630	BIT8	/* RTL8723DE(NGFF1630) */
+#define RTW_MODULE_RTL8822BE			BIT9	/* RTL8822BE */
+#define RTW_MODULE_RTL8821CE			BIT10	/* RTL8821CE */
+
+#define IS_ALPHA2_NO_SPECIFIED(_alpha2) ((*((u16 *)(_alpha2))) == 0xFFFF)
+
+struct country_chplan {
+	char alpha2[2];
+	u8 chplan;
+#ifdef CONFIG_80211AC_VHT
+	u8 en_11ac;
+#endif
+#if RTW_DEF_MODULE_REGULATORY_CERT
+	u16 def_module_flags; /* RTW_MODULE_RTLXXX */
+#endif
+};
+
+#ifdef CONFIG_80211AC_VHT
+#define COUNTRY_CHPLAN_EN_11AC(_ent) ((_ent)->en_11ac)
+#else
+#define COUNTRY_CHPLAN_EN_11AC(_ent) 0
+#endif
+
+#if RTW_DEF_MODULE_REGULATORY_CERT
+#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) ((_ent)->def_module_flags)
+#else
+#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) 0
+#endif
+
+const struct country_chplan *rtw_get_chplan_from_country(const char *country_code);
+
+struct rf_ctl_t;
+
+typedef enum _REGULATION_TXPWR_LMT {
+	TXPWR_LMT_NONE = 0, /* no limit */
+	TXPWR_LMT_FCC = 1,
+	TXPWR_LMT_MKK = 2,
+	TXPWR_LMT_ETSI = 3,
+	TXPWR_LMT_IC = 4,
+	TXPWR_LMT_KCC = 5,
+	TXPWR_LMT_ACMA = 6,
+	TXPWR_LMT_CHILE = 7,
+	TXPWR_LMT_WW = 8, /* smallest of all available limit, keep last */
+} REGULATION_TXPWR_LMT;
+
+extern const char *const _regd_str[];
+#define regd_str(regd) (((regd) > TXPWR_LMT_WW) ? _regd_str[TXPWR_LMT_WW] : _regd_str[(regd)])
+
+#ifdef CONFIG_TXPWR_LIMIT
+struct regd_exc_ent {
+	_list list;
+	char country[2];
+	u8 domain;
+	char regd_name[0];
+};
+
+void dump_regd_exc_list(void *sel, struct rf_ctl_t *rfctl);
+void rtw_regd_exc_add_with_nlen(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name, u32 nlen);
+void rtw_regd_exc_add(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name);
+struct regd_exc_ent *_rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain);
+struct regd_exc_ent *rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain);
+void rtw_regd_exc_list_free(struct rf_ctl_t *rfctl);
+
+void dump_txpwr_lmt(void *sel, _adapter *adapter);
+void rtw_txpwr_lmt_add_with_nlen(struct rf_ctl_t *rfctl, const char *regd_name, u32 nlen
+	, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt);
+void rtw_txpwr_lmt_add(struct rf_ctl_t *rfctl, const char *regd_name
+	, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt);
+struct txpwr_lmt_ent *_rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name);
+struct txpwr_lmt_ent *rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name);
+void rtw_txpwr_lmt_list_free(struct rf_ctl_t *rfctl);
+#endif /* CONFIG_TXPWR_LIMIT */
+
+#define BB_GAIN_2G 0
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+#define BB_GAIN_5GLB1 1
+#define BB_GAIN_5GLB2 2
+#define BB_GAIN_5GMB1 3
+#define BB_GAIN_5GMB2 4
+#define BB_GAIN_5GHB 5
+#endif
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+#define BB_GAIN_NUM 6
+#else
+#define BB_GAIN_NUM 1
+#endif
+
+int rtw_ch_to_bb_gain_sel(int ch);
+void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset);
+void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch);
+
+/* only check channel ranges */
+#define rtw_is_2g_ch(ch) (ch >= 1 && ch <= 14)
+#define rtw_is_5g_ch(ch) ((ch) >= 36 && (ch) <= 177)
+#define rtw_is_same_band(a, b) \
+	((rtw_is_2g_ch(a) && rtw_is_2g_ch(b)) \
+	|| (rtw_is_5g_ch(a) && rtw_is_5g_ch(b)))
+
+#define rtw_is_5g_band1(ch) ((ch) >= 36 && (ch) <= 48)
+#define rtw_is_5g_band2(ch) ((ch) >= 52 && (ch) <= 64)
+#define rtw_is_5g_band3(ch) ((ch) >= 100 && (ch) <= 144)
+#define rtw_is_5g_band4(ch) ((ch) >= 149 && (ch) <= 177)
+#define rtw_is_same_5g_band(a, b) \
+	((rtw_is_5g_band1(a) && rtw_is_5g_band1(b)) \
+	|| (rtw_is_5g_band2(a) && rtw_is_5g_band2(b)) \
+	|| (rtw_is_5g_band3(a) && rtw_is_5g_band3(b)) \
+	|| (rtw_is_5g_band4(a) && rtw_is_5g_band4(b)))
+
+u8 rtw_is_dfs_range(u32 hi, u32 lo);
+u8 rtw_is_dfs_ch(u8 ch);
+u8 rtw_is_dfs_chbw(u8 ch, u8 bw, u8 offset);
+bool rtw_is_long_cac_range(u32 hi, u32 lo, u8 dfs_region);
+bool rtw_is_long_cac_ch(u8 ch, u8 bw, u8 offset, u8 dfs_region);
+
+#endif /* _RTL8711_RF_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rm.h
new file mode 100644
index 000000000000..9efcf1307106
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rm.h
@@ -0,0 +1,88 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_RM_H_
+#define __RTW_RM_H_
+
+u8 rm_post_event_hdl(_adapter *padapter, u8 *pbuf);
+
+#define RM_TIMER_NUM 		32
+#define RM_ALL_MEAS		BIT(1)
+#define RM_ID_FOR_ALL(aid)	((aid<<16)|RM_ALL_MEAS)
+
+#define RM_CAP_ARG(x) ((u8 *)(x))[4], ((u8 *)(x))[3], ((u8 *)(x))[2], ((u8 *)(x))[1], ((u8 *)(x))[0]
+#define RM_CAP_FMT "%02x %02x%02x %02x%02x"
+
+/* remember to modify rm_event_name() when adding new event */
+enum RM_EV_ID {
+	RM_EV_state_in,
+	RM_EV_busy_timer_expire,
+	RM_EV_delay_timer_expire,
+	RM_EV_meas_timer_expire,
+	RM_EV_retry_timer_expire,
+	RM_EV_repeat_delay_expire,
+	RM_EV_request_timer_expire,
+	RM_EV_wait_report,
+	RM_EV_start_meas,
+	RM_EV_survey_done,
+	RM_EV_recv_rep,
+	RM_EV_cancel,
+	RM_EV_state_out,
+	RM_EV_max
+};
+
+struct rm_event {
+	u32 rmid;
+	enum RM_EV_ID evid;
+	_list list;
+};
+
+#ifdef CONFIG_RTW_80211K
+
+struct rm_clock {
+	struct rm_obj *prm;
+	ATOMIC_T counter;
+	enum RM_EV_ID evid;
+};
+
+struct rm_priv {
+	u8 enable;
+	_queue ev_queue;
+	_queue rm_queue;
+	_timer rm_timer;
+
+	struct rm_clock clock[RM_TIMER_NUM];
+	u8 rm_en_cap_def[5];
+	u8 rm_en_cap_assoc[5];
+
+	/* rm debug */
+	void *prm_sel;
+};
+
+int rtw_init_rm(_adapter *padapter);
+int rtw_free_rm_priv(_adapter *padapter);
+
+unsigned int rm_on_action(_adapter *padapter, union recv_frame *precv_frame);
+void RM_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void rtw_ap_parse_sta_rm_en_cap(_adapter *padapter,
+	struct sta_info *psta, struct rtw_ieee802_11_elems *elems);
+
+int rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid);
+void rm_handler(_adapter *padapter, struct rm_event *pev);
+
+u8 rm_add_nb_req(_adapter *padapter, struct sta_info *psta);
+
+#endif /*CONFIG_RTW_80211K */
+#endif /* __RTW_RM_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rm_fsm.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rm_fsm.h
new file mode 100644
index 000000000000..ba903a9c46bb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rm_fsm.h
@@ -0,0 +1,389 @@
+
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_RM_FSM_H_
+#define __RTW_RM_FSM_H_
+
+#ifdef CONFIG_RTW_80211K
+
+#define RM_SUPPORT_IWPRIV_DBG	1
+#define RM_MORE_DBG_MSG		0
+
+#define DBG_BCN_REQ_DETAIL	0
+#define DBG_BCN_REQ_WILDCARD	0
+#define DBG_BCN_REQ_SSID	0
+#define DBG_BCN_REQ_SSID_NAME	"RealKungFu"
+
+#define RM_REQ_TIMEOUT		10000	/* 10 seconds */
+#define RM_MEAS_TIMEOUT		10000	/* 10 seconds */
+#define RM_REPT_SCAN_INTVL	5000	/*  5 seconds */
+#define RM_REPT_POLL_INTVL	2000	/*  2 seconds */
+#define RM_COND_INTVL		2000	/*  2 seconds */
+#define RM_SCAN_DENY_TIMES	10
+#define RM_BUSY_TRAFFIC_TIMES	10
+#define RM_WAIT_BUSY_TIMEOUT	1000	/*  1 seconds */
+
+#define MEAS_REQ_MOD_PARALLEL	BIT(0)
+#define MEAS_REQ_MOD_ENABLE	BIT(1)
+#define MEAS_REQ_MOD_REQUEST	BIT(2)
+#define MEAS_REQ_MOD_REPORT	BIT(3)
+#define MEAS_REQ_MOD_DUR_MAND	BIT(4)
+
+#define MEAS_REP_MOD_LATE	BIT(0)
+#define MEAS_REP_MOD_INCAP	BIT(1)
+#define MEAS_REP_MOD_REFUSE	BIT(2)
+
+#define RM_MASTER		BIT(0)	/* STA who issue meas_req */
+#define RM_SLAVE		0	/* STA who do measurement */
+
+#define CLOCK_UNIT		10	/* ms */
+#define RTW_MAX_NB_RPT_IE_NUM	16
+
+#define RM_GET_AID(rmid)	((rmid&0xffff0000)>>16)
+#define RM_IS_ID_FOR_ALL(rmid)	(rmid&RM_ALL_MEAS)
+
+/*
+ * define the following channels as the max channels in each channel plan.
+ * 2G, total 14 chnls
+ * {1,2,3,4,5,6,7,8,9,10,11,12,13,14}
+ * 5G, total 25 chnls
+ * {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140,144,149,153,157,161,165}
+ */
+#define	MAX_OP_CHANNEL_SET_NUM	11
+typedef struct _RT_OPERATING_CLASS {
+	int	global_op_class;
+	int	Len;
+	u16	Channel[MAX_OP_CHANNEL_SET_NUM];
+} RT_OPERATING_CLASS, *PRT_OPERATING_CLASS;
+
+/* IEEE 802.11-2012 Table 8-59 Measurement Type definitions
+*  for measurement request
+*  modify rm_meas_type_req_name() when adding new type
+*/
+enum meas_type_of_req {
+	basic_req,	/* spectrum measurement */
+	cca_req,
+	rpi_histo_req,
+	ch_load_req,
+	noise_histo_req,
+	bcn_req,
+	frame_req,
+	sta_statis_req,
+	lci_req,
+	meas_type_req_max,
+};
+
+/* IEEE 802.11-2012 Table 8-81 Measurement Type definitions
+*  for measurement report
+*  modify rm_type_rep_name() when adding new type
+*/
+enum meas_type_of_rep {
+	basic_rep,	/* spectrum measurement */
+	cca_rep,
+	rpi_histo_rep,
+	ch_load_rep,	/* radio measurement */
+	noise_histo_rep,
+	bcn_rep,
+	frame_rep,
+	sta_statis_rep,	/* Radio measurement and WNM */
+	lci_rep,
+	meas_type_rep_max
+};
+
+/*
+* Beacon request
+*/
+/* IEEE 802.11-2012 Table 8-64 Measurement mode for Beacon Request element */
+enum bcn_req_meas_mode {
+	bcn_req_passive,
+	bcn_req_active,
+	bcn_req_bcn_table
+};
+
+/* IEEE 802.11-2012 Table 8-65 optional subelement IDs for Beacon Request */
+enum bcn_req_opt_sub_id{
+	bcn_req_ssid = 0,		/* len 0-32 */
+	bcn_req_rep_info = 1,		/* len 2 */
+	bcn_req_rep_detail = 2,		/* len 1 */
+	bcn_req_req = 10,		/* len 0-237 */
+	bcn_req_ac_ch_rep = 51		/* len 1-237 */
+};
+
+/* IEEE 802.11-2012 Table 8-66 Reporting condition of Beacon Report */
+enum bcn_rep_cound_id{
+	bcn_rep_cond_immediately,	/* default */
+	bcn_req_cond_rcpi_greater,
+	bcn_req_cond_rcpi_less,
+	bcn_req_cond_rsni_greater,
+	bcn_req_cond_rsni_less,
+	bcn_req_cond_max
+};
+
+struct opt_rep_info {
+	u8 cond;
+	u8 threshold;
+};
+
+#define BCN_REQ_OPT_MAX_NUM		16
+struct bcn_req_opt {
+	/* all req cmd id */
+	u8 opt_id[BCN_REQ_OPT_MAX_NUM];
+	u8 opt_id_num;
+	u8 rep_detail;
+	NDIS_802_11_SSID ssid;
+
+	/* bcn report condition */
+	struct opt_rep_info rep_cond;
+
+	/* 0:default(Report to be issued after each measurement) */
+	u8 *req_start;	/*id : 10 request;start  */
+	u8 req_len;	/*id : 10 request;length */
+};
+
+/*
+* channel load
+*/
+/* IEEE 802.11-2012 Table 8-60 optional subelement IDs for channel load request */
+enum ch_load_opt_sub_id{
+	ch_load_rsvd,
+	ch_load_rep_info
+};
+
+/* IEEE 802.11-2012 Table 8-61 Reporting condition for channel load Report */
+enum ch_load_cound_id{
+	ch_load_cond_immediately,	/* default */
+	ch_load_cond_anpi_equal_greater,
+	ch_load_cond_anpi_equal_less,
+	ch_load_cond_max
+};
+
+/*
+* Noise histogram
+*/
+/* IEEE 802.11-2012 Table 8-62 optional subelement IDs for noise histogram */
+enum noise_histo_opt_sub_id{
+	noise_histo_rsvd,
+	noise_histo_rep_info
+};
+
+/* IEEE 802.11-2012 Table 8-63 Reporting condition for noise historgarm Report */
+enum noise_histo_cound_id{
+	noise_histo_cond_immediately,	/* default */
+	noise_histo_cond_anpi_equal_greater,
+	noise_histo_cond_anpi_equal_less,
+	noise_histo_cond_max
+};
+
+struct meas_req_opt {
+	/* report condition */
+	struct opt_rep_info rep_cond;
+};
+
+/*
+* State machine
+*/
+
+enum RM_STATE {
+	RM_ST_IDLE,
+	RM_ST_DO_MEAS,
+	RM_ST_WAIT_MEAS,
+	RM_ST_SEND_REPORT,
+	RM_ST_RECV_REPORT,
+	RM_ST_END,
+	RM_ST_MAX
+};
+
+struct rm_meas_req {
+	u8 category;
+	u8 action_code;		/* T8-206  */
+	u8 diag_token;
+	u16 rpt;
+
+	u8 e_id;
+	u8 len;
+	u8 m_token;
+	u8 m_mode;		/* req:F8-105, rep:F8-141 */
+	u8 m_type;		/* T8-59 */
+	u8 op_class;
+	u8 ch_num;
+	u16 rand_intvl;		/* units of TU */
+	u16 meas_dur;		/* units of TU */
+
+	u8 bssid[6];		/* for bcn_req */
+
+	u8 *pssid;
+	u8 *opt_s_elem_start;
+	int opt_s_elem_len;
+
+	union {
+		struct bcn_req_opt bcn;
+		struct meas_req_opt clm;
+		struct meas_req_opt nhm;
+	}opt;
+
+	struct rtw_ieee80211_channel ch_set[MAX_OP_CHANNEL_SET_NUM];
+	u8 ch_set_ch_amount;
+};
+
+struct rm_meas_rep {
+	u8 category;
+	u8 action_code;		/* T8-206  */
+	u8 diag_token;
+
+	u8 e_id;		/* T8-54, 38 request; 39 report */
+	u8 len;
+	u8 m_token;
+	u8 m_mode;		/* req:F8-105, rep:F8-141 */
+	u8 m_type;		/* T8-59 */
+	u8 op_class;
+	u8 ch_num;
+
+	u8 ch_load;
+	u8 anpi;
+	u8 ipi[11];
+
+	u16 rpt;
+	u8 bssid[6];		/* for bcn_req */
+};
+
+#define MAX_BUF_NUM	128
+struct data_buf {
+	u8 *pbuf;
+	u16 len;
+};
+
+struct rm_obj {
+
+	/* aid << 16 
+		|diag_token << 8
+		|B(1) 1/0:All_AID/UNIC
+		|B(0) 1/0:RM_MASTER/RM_SLAVE */
+	u32 rmid;
+
+	enum RM_STATE state;
+	struct rm_meas_req q;
+	struct rm_meas_rep p;
+	struct sta_info *psta;
+	struct rm_clock *pclock;
+
+	/* meas report */
+	u64 meas_start_time;
+	u64 meas_end_time;
+	int wait_busy;
+	u8 poll_mode;
+
+	struct data_buf buf[MAX_BUF_NUM];
+
+	_list list;
+};
+
+/*
+* Measurement
+*/
+struct opt_subelement {
+	u8 id;
+	u8 length;
+	u8 *data;
+};
+
+/* 802.11-2012 Table 8-206 Radio Measurment Action field */
+enum rm_action_code {
+	RM_ACT_RADIO_MEAS_REQ,
+	RM_ACT_RADIO_MEAS_REP,
+	RM_ACT_LINK_MEAS_REQ,
+	RM_ACT_LINK_MEAS_REP,
+	RM_ACT_NB_REP_REQ,	/* 4 */
+	RM_ACT_NB_REP_RESP,
+	RM_ACT_RESV,
+	RM_ACT_MAX
+};
+
+/* 802.11-2012 Table 8-119 RM Enabled Capabilities definition */
+enum rm_cap_en {
+	RM_LINK_MEAS_CAP_EN,
+	RM_NB_REP_CAP_EN,		/* neighbor report */
+	RM_PARAL_MEAS_CAP_EN,		/* parallel report */
+	RM_REPEAT_MEAS_CAP_EN,
+	RM_BCN_PASSIVE_MEAS_CAP_EN,
+	RM_BCN_ACTIVE_MEAS_CAP_EN,
+	RM_BCN_TABLE_MEAS_CAP_EN,
+	RM_BCN_MEAS_REP_COND_CAP_EN,	/* conditions */
+
+	RM_FRAME_MEAS_CAP_EN,
+	RM_CH_LOAD_CAP_EN,
+	RM_NOISE_HISTO_CAP_EN,		/* noise historgram */
+	RM_STATIS_MEAS_CAP_EN,		/* statistics */
+	RM_LCI_MEAS_CAP_EN,		/* 12 */
+	RM_LCI_AMIMUTH_CAP_EN,
+	RM_TRANS_STREAM_CAT_MEAS_CAP_EN,
+	RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN,
+
+	RM_AP_CH_REP_CAP_EN,
+	RM_RM_MIB_CAP_EN,
+	RM_OP_CH_MAX_MEAS_DUR0,		/* 18-20 */
+	RM_OP_CH_MAX_MEAS_DUR1,
+	RM_OP_CH_MAX_MEAS_DUR2,
+	RM_NONOP_CH_MAX_MEAS_DUR0,	/* 21-23 */
+	RM_NONOP_CH_MAX_MEAS_DUR1,
+	RM_NONOP_CH_MAX_MEAS_DUR2,
+
+	RM_MEAS_PILOT_CAP0,		/* 24-26 */
+	RM_MEAS_PILOT_CAP1,
+	RM_MEAS_PILOT_CAP2,
+	RM_MEAS_PILOT_TRANS_INFO_CAP_EN,
+	RM_NB_REP_TSF_OFFSET_CAP_EN,
+	RM_RCPI_MEAS_CAP_EN,		/* 29 */
+	RM_RSNI_MEAS_CAP_EN,
+	RM_BSS_AVG_ACCESS_DELAY_CAP_EN,
+
+	RM_AVALB_ADMIS_CAPACITY_CAP_EN,
+	RM_ANT_CAP_EN,
+	RM_RSVD,			/* 34-39 */
+	RM_MAX
+};
+
+char *rm_state_name(enum RM_STATE state);
+char *rm_event_name(enum RM_EV_ID evid);
+char *rm_type_req_name(u8 meas_type);
+int _rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid);
+int rm_enqueue_rmobj(_adapter *padapter, struct rm_obj *obj, bool to_head);
+
+void rm_free_rmobj(struct rm_obj *prm);
+struct rm_obj *rm_alloc_rmobj(_adapter *padapter);
+struct rm_obj *rm_get_rmobj(_adapter *padapter, u32 rmid);
+struct sta_info *rm_get_psta(_adapter *padapter, u32 rmid);
+
+int retrieve_radio_meas_result(struct rm_obj *prm);
+int rm_radio_meas_report_cond(struct rm_obj *prm);
+int rm_recv_radio_mens_req(_adapter *padapter,
+	union recv_frame *precv_frame,struct sta_info *psta);
+int rm_recv_radio_mens_rep(_adapter *padapter,
+	union recv_frame *precv_frame, struct sta_info *psta);
+int rm_radio_mens_nb_rep(_adapter *padapter,
+	union recv_frame *precv_frame, struct sta_info *psta);
+int issue_null_reply(struct rm_obj *prm);
+int issue_beacon_rep(struct rm_obj *prm);
+int issue_nb_req(struct rm_obj *prm);
+int issue_radio_meas_req(struct rm_obj *prm);
+int issue_radio_meas_rep(struct rm_obj *prm);
+
+void rm_set_rep_mode(struct rm_obj *prm, u8 mode);
+
+int ready_for_scan(struct rm_obj *prm);
+int rm_sitesurvey(struct rm_obj *prm);
+
+#endif /*CONFIG_RTW_80211K*/
+#endif /*__RTW_RM_FSM_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rson.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rson.h
new file mode 100644
index 000000000000..6996738b071a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_rson.h
@@ -0,0 +1,61 @@
+/******************************************************************************
+ *
+ * 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.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
+ *
+ *
+ ******************************************************************************/
+#ifndef __RTW_RSON_H_
+#define __RTW_RSON_H_
+
+
+#define RTW_RSON_VER						1
+
+#define RTW_RSON_SCORE_NOTSUP			0x0
+#define RTW_RSON_SCORE_NOTCNNT			0x1
+#define RTW_RSON_SCORE_MAX				0xFF
+#define RTW_RSON_HC_NOTREADY			0xFF
+#define RTW_RSON_HC_ROOT				0x0
+#define RTW_RSON_ALLOWCONNECT			0x1
+#define RTW_RSON_DENYCONNECT			0x0
+
+
+
+/*	for rtw self-origanization spec 1	*/
+struct rtw_rson_struct {
+	u8 ver;
+	u32 id;
+	u8 hopcnt;
+	u8 connectible;
+	u8 loading;
+	u8 res[16];
+} __attribute__((__packed__));
+
+void init_rtw_rson_data(struct dvobj_priv *dvobj);
+void rtw_rson_get_property_str(_adapter *padapter, char *rson_data_str);
+int rtw_rson_set_property(_adapter *padapter, char *field, char *value);
+int rtw_rson_choose(struct wlan_network **candidate, struct wlan_network *competitor);
+int rtw_get_rson_struct(WLAN_BSSID_EX *bssid, struct  rtw_rson_struct *rson_data);
+u8 rtw_cal_rson_score(struct rtw_rson_struct *cand_rson_data, NDIS_802_11_RSSI  Rssi);
+void rtw_rson_handle_ie(WLAN_BSSID_EX *bssid, u8 ie_offset);
+u32 rtw_rson_append_ie(_adapter *padapter, unsigned char *pframe, u32 *len);
+void rtw_rson_do_disconnect(_adapter *padapter);
+void rtw_rson_join_done(_adapter *padapter);
+int rtw_rson_isupdate_roamcan(struct mlme_priv *mlme, struct wlan_network **candidate, struct wlan_network *competitor);
+void rtw_rson_show_survey_info(struct seq_file *m, _list *plist, _list *phead);
+u8 rtw_rson_ap_check_sta(_adapter *padapter, u8 *pframe, uint pkt_len, unsigned short ie_offset);
+u8 rtw_rson_scan_wk_cmd(_adapter *padapter, int op);
+void rtw_rson_scan_cmd_hdl(_adapter *padapter, int op);
+#endif /* __RTW_RSON_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_sdio.h
new file mode 100644
index 000000000000..7490b5481328
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_sdio.h
@@ -0,0 +1,26 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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_SDIO_H_
+#define _RTW_SDIO_H_
+
+#include <drv_types.h>		/* struct dvobj_priv and etc. */
+
+u8 rtw_sdio_read_cmd52(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_read_cmd53(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_write_cmd52(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_write_cmd53(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_f0_read(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+
+#endif /* _RTW_SDIO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_security.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_security.h
new file mode 100644
index 000000000000..ac8432e476a9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_security.h
@@ -0,0 +1,497 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#define _NO_PRIVACY_		0x0
+#define _WEP40_				0x1
+#define _TKIP_				0x2
+#define _TKIP_WTMIC_		0x3
+#define _AES_				0x4
+#define _WEP104_			0x5
+#define _SMS4_				0x06
+#define _WEP_WPA_MIXED_		0x07 /* WEP + WPA */
+#define _BIP_				0x8
+
+/* 802.11W use wrong key */
+#define IEEE80211W_RIGHT_KEY	0x0
+#define IEEE80211W_WRONG_KEY	0x1
+#define IEEE80211W_NO_KEY		0x2
+
+#define CCMPH_2_PN(ch)	((ch) & 0x000000000000ffff) \
+			| (((ch) & 0xffffffff00000000) >> 16)
+
+#define is_wep_enc(alg) (((alg) == _WEP40_) || ((alg) == _WEP104_))
+
+const char *security_type_str(u8 value);
+
+#define _WPA_IE_ID_	0xdd
+#define _WPA2_IE_ID_	0x30
+
+#define SHA256_MAC_LEN 32
+#define AES_BLOCK_SIZE 16
+#define AES_PRIV_SIZE (4 * 44)
+
+#define RTW_KEK_LEN 16
+#define RTW_KCK_LEN 16
+#define RTW_TKIP_MIC_LEN 8
+#define RTW_REPLAY_CTR_LEN 8
+
+#define INVALID_SEC_MAC_CAM_ID	0xFF
+
+typedef enum {
+	ENCRYP_PROTOCOL_OPENSYS,   /* open system */
+	ENCRYP_PROTOCOL_WEP,       /* WEP */
+	ENCRYP_PROTOCOL_WPA,       /* WPA */
+	ENCRYP_PROTOCOL_WPA2,      /* WPA2 */
+	ENCRYP_PROTOCOL_WAPI,      /* WAPI: Not support in this version */
+	ENCRYP_PROTOCOL_MAX
+} ENCRYP_PROTOCOL_E;
+
+
+#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 CONFIG_LITTLE_ENDIAN
+
+struct {
+	u8 TSC0;
+	u8 TSC1;
+	u8 TSC2;
+	u8 TSC3;
+	u8 TSC4;
+	u8 TSC5;
+	u8 TSC6;
+	u8 TSC7;
+} _byte_;
+
+#elif defined(CONFIG_BIG_ENDIAN)
+
+struct {
+	u8 TSC7;
+	u8 TSC6;
+	u8 TSC5;
+	u8 TSC4;
+	u8 TSC3;
+	u8 TSC2;
+	u8 TSC1;
+	u8 TSC0;
+} _byte_;
+
+#endif
+
+};
+
+union Keytype {
+	u8   skey[16];
+	u32    lkey[4];
+};
+
+
+typedef struct _RT_PMKID_LIST {
+	u8						bUsed;
+	u8						Bssid[6];
+	u8						PMKID[16];
+	u8						SsidBuf[33];
+	u8						*ssid_octet;
+	u16						ssid_length;
+} RT_PMKID_LIST, *PRT_PMKID_LIST;
+
+
+struct security_priv {
+	u32	  dot11AuthAlgrthm;		/* 802.11 auth, could be open, shared, 8021x and authswitch */
+	u32	  dot11PrivacyAlgrthm;	/* This specify the privacy for shared auth. algorithm. */
+
+	/* WEP */
+	u32	  dot11PrivacyKeyIndex;	/* this is only valid for legendary wep, 0~3 for key id. (tx key index) */
+	union Keytype dot11DefKey[6];			/* this is only valid for def. key	 */
+	u32	dot11DefKeylen[6];
+	u8	dot11Def_camid[6];
+	u8 	key_mask; /* use to restore wep key after hal_init */
+
+	u32 dot118021XGrpPrivacy;	/* This specify the privacy algthm. used for Grp key */
+	u32	dot118021XGrpKeyid;		/* key id used for Grp Key ( tx key index) */
+	union Keytype	dot118021XGrpKey[6];	/* 802.1x Group Key, for inx0 and inx1	 */
+	union Keytype	dot118021XGrptxmickey[6];
+	union Keytype	dot118021XGrprxmickey[6];
+	union pn48		dot11Grptxpn;			/* PN48 used for Grp Key xmit. */
+	union pn48		dot11Grprxpn;			/* PN48 used for Grp Key recv. */
+	u8				iv_seq[4][8];
+#ifdef CONFIG_IEEE80211W
+	u32	dot11wBIPKeyid;						/* key id used for BIP Key ( tx key index) */
+	union Keytype	dot11wBIPKey[6];		/* BIP Key, for index4 and index5 */
+	union pn48		dot11wBIPtxpn;			/* PN48 used for BIP xmit. */
+	union pn48		dot11wBIPrxpn;			/* PN48 used for BIP recv. */
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_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;
+	u8 mfp_opt;
+#endif
+#ifdef CONFIG_CONCURRENT_MODE
+	u8	dot118021x_bmc_cam_id;
+#endif
+	/*IEEE802.11-2012 Std. Table 8-101 AKM Suite Selectors*/
+	u32	rsn_akm_suite_type;
+
+	u8 wps_ie[MAX_WPS_IE_LEN];/* added in assoc req */
+	int wps_ie_len;
+
+
+	u8	binstallGrpkey;
+#ifdef CONFIG_GTK_OL
+	u8	binstallKCK_KEK;
+#endif /* CONFIG_GTK_OL */
+#ifdef CONFIG_IEEE80211W
+	u8	binstallBIPkey;
+#endif /* CONFIG_IEEE80211W */
+	u8	busetkipkey;
+	u8	bcheck_grpkey;
+	u8	bgrpkey_handshake;
+
+	/* u8	packet_cnt; */ /* unused, removed */
+
+	s32	sw_encrypt;/* from registry_priv */
+	s32	sw_decrypt;/* from registry_priv */
+
+	s32 	hw_decrypted;/* if the rx packets is hw_decrypted==_FALSE, it means the hw has not been ready. */
+
+
+	/* keeps the auth_type & enc_status from upper layer ioctl(wpa_supplicant or wzc) */
+	u32 ndisauthtype;	/* NDIS_802_11_AUTHENTICATION_MODE */
+	u32 ndisencryptstatus;	/* NDIS_802_11_ENCRYPTION_STATUS */
+
+	NDIS_802_11_WEP ndiswep;
+#ifdef PLATFORM_WINDOWS
+	u8 KeyMaterial[16];/* variable length depending on above field. */
+#endif
+
+	u8 assoc_info[600];
+	u8 szofcapability[256]; /* for wpa2 usage */
+	u8 oidassociation[512]; /* for wpa/wpa2 usage */
+	u8 authenticator_ie[256];  /* store ap security information element */
+	u8 supplicant_ie[256];  /* store sta security information element */
+
+
+	/* for tkip countermeasure */
+	systime last_mic_err_time;
+	u8	btkip_countermeasure;
+	u8	btkip_wait_report;
+	systime btkip_countermeasure_time;
+
+	/* --------------------------------------------------------------------------- */
+	/* For WPA2 Pre-Authentication. */
+	/* --------------------------------------------------------------------------- */
+	/* u8				RegEnablePreAuth;				 */ /* Default value: Pre-Authentication enabled or not, from registry "EnablePreAuth". Added by Annie, 2005-11-01. */
+	/* u8				EnablePreAuthentication;			 */ /* Current Value: Pre-Authentication enabled or not. */
+	RT_PMKID_LIST		PMKIDList[NUM_PMKID_CACHE];	/* Renamed from PreAuthKey[NUM_PRE_AUTH_KEY]. Annie, 2006-10-13. */
+	u8				PMKIDIndex;
+	/* u32				PMKIDCount;						 */ /* Added by Annie, 2006-10-13. */
+	/* u8				szCapability[256];				 */ /* For WPA2-PSK using zero-config, by Annie, 2005-09-20. */
+
+	u8 bWepDefaultKeyIdxSet;
+
+#define DBG_SW_SEC_CNT
+#ifdef DBG_SW_SEC_CNT
+	u64 wep_sw_enc_cnt_bc;
+	u64 wep_sw_enc_cnt_mc;
+	u64 wep_sw_enc_cnt_uc;
+	u64 wep_sw_dec_cnt_bc;
+	u64 wep_sw_dec_cnt_mc;
+	u64 wep_sw_dec_cnt_uc;
+
+	u64 tkip_sw_enc_cnt_bc;
+	u64 tkip_sw_enc_cnt_mc;
+	u64 tkip_sw_enc_cnt_uc;
+	u64 tkip_sw_dec_cnt_bc;
+	u64 tkip_sw_dec_cnt_mc;
+	u64 tkip_sw_dec_cnt_uc;
+
+	u64 aes_sw_enc_cnt_bc;
+	u64 aes_sw_enc_cnt_mc;
+	u64 aes_sw_enc_cnt_uc;
+	u64 aes_sw_dec_cnt_bc;
+	u64 aes_sw_dec_cnt_mc;
+	u64 aes_sw_dec_cnt_uc;
+#endif /* DBG_SW_SEC_CNT */
+};
+
+#ifdef CONFIG_IEEE80211W
+#define SEC_IS_BIP_KEY_INSTALLED(sec) ((sec)->binstallBIPkey)
+#else
+#define SEC_IS_BIP_KEY_INSTALLED(sec) _FALSE
+#endif
+
+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 = (u8)psecuritypriv->dot11PrivacyAlgrthm;\
+			break;\
+		case dot11AuthAlgrthm_8021X:\
+			if (bmcst)\
+				encry_algo = (u8)psecuritypriv->dot118021XGrpPrivacy;\
+			else\
+				encry_algo = (u8) psta->dot118021XPrivacy;\
+			break;\
+		case dot11AuthAlgrthm_WAPI:\
+			encry_algo = (u8)psecuritypriv->dot11PrivacyAlgrthm;\
+			break;\
+		} \
+	} while (0)
+
+#define _AES_IV_LEN_ 8
+
+#define SET_ICE_IV_LEN(iv_len, icv_len, encrypt)\
+	do {\
+		switch (encrypt) {\
+		case _WEP40_:\
+		case _WEP104_:\
+			iv_len = 4;\
+			icv_len = 4;\
+			break;\
+		case _TKIP_:\
+			iv_len = 8;\
+			icv_len = 4;\
+			break;\
+		case _AES_:\
+			iv_len = 8;\
+			icv_len = 8;\
+			break;\
+		case _SMS4_:\
+			iv_len = 18;\
+			icv_len = 16;\
+			break;\
+		default:\
+			iv_len = 0;\
+			icv_len = 0;\
+			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)
+
+/* 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
+};
+
+
+/* Various logical functions */
+#define RORc(x, y) \
+	(((((unsigned long) (x) & 0xFFFFFFFFUL) >> (unsigned long) ((y) & 31)) | \
+	  ((unsigned long) (x) << (unsigned long) (32 - ((y) & 31)))) & 0xFFFFFFFFUL)
+#define Ch(x, y, z)       (z ^ (x & (y ^ z)))
+#define Maj(x, y, z)      (((x | y) & z) | (x & y))
+#define S(x, n)         RORc((x), (n))
+#define R(x, n)         (((x) & 0xFFFFFFFFUL)>>(n))
+#define Sigma0(x)       (S(x, 2) ^ S(x, 13) ^ S(x, 22))
+#define Sigma1(x)       (S(x, 6) ^ S(x, 11) ^ S(x, 25))
+#define Gamma0(x)       (S(x, 7) ^ S(x, 18) ^ R(x, 3))
+#define Gamma1(x)       (S(x, 17) ^ S(x, 19) ^ R(x, 10))
+#ifndef MIN
+#define MIN(x, y) (((x) < (y)) ? (x) : (y))
+#endif
+#ifdef CONFIG_IEEE80211W
+int omac1_aes_128(const u8 *key, const u8 *data, size_t data_len, u8 *mac);
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_RTW_MESH_AEK
+int aes_siv_encrypt(const u8 *key, const u8 *pw, size_t pwlen
+	, size_t num_elem, const u8 *addr[], const size_t *len, u8 *out);
+int aes_siv_decrypt(const u8 *key, const u8 *iv_crypt, size_t iv_c_len
+	, size_t num_elem, const u8 *addr[], const size_t *len, u8 *out);
+#endif
+void rtw_secmicsetkey(struct mic_data *pmicdata, u8 *key);
+void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b);
+void rtw_secmicappend(struct mic_data *pmicdata, u8 *src, u32 nBytes);
+void rtw_secgetmic(struct mic_data *pmicdata, u8 *dst);
+
+void rtw_seccalctkipmic(
+	u8 *key,
+	u8 *header,
+	u8 *data,
+	u32 data_len,
+	u8 *Miccode,
+	u8   priority);
+
+u32 rtw_aes_encrypt(_adapter *padapter, u8 *pxmitframe);
+u32 rtw_tkip_encrypt(_adapter *padapter, u8 *pxmitframe);
+void rtw_wep_encrypt(_adapter *padapter, u8  *pxmitframe);
+
+u32 rtw_aes_decrypt(_adapter *padapter, u8  *precvframe);
+u32 rtw_tkip_decrypt(_adapter *padapter, u8  *precvframe);
+void rtw_wep_decrypt(_adapter *padapter, u8  *precvframe);
+#ifdef CONFIG_IEEE80211W
+u32	rtw_BIP_verify(_adapter *padapter, u8 *whdr_pos, sint flen
+	, const u8 *key, u16 id, u64* ipn);
+#endif
+#ifdef CONFIG_TDLS
+void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta);
+int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
+			u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie,
+			u8 *mic);
+int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason,
+			u8 dialog_token, u8 trans_seq, u8 *ftie, u8 *mic);
+int tdls_verify_mic(u8 *kck, u8 trans_seq,
+			u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie);
+#endif /* CONFIG_TDLS */
+
+void rtw_sec_restore_wep_key(_adapter *adapter);
+u8 rtw_handle_tkip_countermeasure(_adapter *adapter, const char *caller);
+
+#ifdef CONFIG_WOWLAN
+u16 rtw_calc_crc(u8  *pdata, int length);
+#endif /*CONFIG_WOWLAN*/
+
+#endif /* __RTL871X_SECURITY_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_sreset.h
new file mode 100644
index 000000000000..1fd999a9d76e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_sreset.h
@@ -0,0 +1,66 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_H_
+#define _RTW_SRESET_H_
+
+/* #include <drv_types.h> */
+
+enum {
+	SRESET_TGP_NULL = 0,
+	SRESET_TGP_XMIT_STATUS = 1,
+	SRESET_TGP_LINK_STATUS = 2,
+	SRESET_TGP_INFO = 99,
+};
+
+struct sreset_priv {
+	_mutex	silentreset_mutex;
+	u8	silent_reset_inprogress;
+	u8	Wifi_Error_Status;
+	systime last_tx_time;
+	systime last_tx_complete_time;
+
+	s32 dbg_trigger_point;
+	u64 self_dect_tx_cnt;
+	u64 self_dect_rx_cnt;
+	u64 self_dect_fw_cnt;
+	u64 tx_dma_status_cnt;
+	u64 rx_dma_status_cnt;
+	u8 rx_cnt;
+	u8 self_dect_fw;
+	u8 self_dect_case;
+	u16 last_mac_rxff_ptr;
+	u8 dbg_sreset_ctrl;
+};
+
+
+
+#define	WIFI_STATUS_SUCCESS		0
+#define	USB_VEN_REQ_CMD_FAIL	BIT0
+#define	USB_READ_PORT_FAIL		BIT1
+#define	USB_WRITE_PORT_FAIL		BIT2
+#define	WIFI_MAC_TXDMA_ERROR	BIT3
+#define   WIFI_TX_HANG				BIT4
+#define	WIFI_RX_HANG				BIT5
+#define	WIFI_IF_NOT_EXIST			BIT6
+
+void sreset_init_value(_adapter *padapter);
+void sreset_reset_value(_adapter *padapter);
+u8 sreset_get_wifi_status(_adapter *padapter);
+void sreset_set_wifi_error_status(_adapter *padapter, u32 status);
+void sreset_set_trigger_point(_adapter *padapter, s32 tgp);
+bool sreset_inprogress(_adapter *padapter);
+void sreset_reset(_adapter *padapter);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_tdls.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_tdls.h
new file mode 100644
index 000000000000..5c23e4ea4c2f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_tdls.h
@@ -0,0 +1,185 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_TDLS_H_
+#define __RTW_TDLS_H_
+
+
+#ifdef CONFIG_TDLS
+/* TDLS STA state */
+
+
+/* TDLS Diect Link Establishment */
+#define	TDLS_STATE_NONE				0x00000000		/* Default state */
+#define	TDLS_INITIATOR_STATE		BIT(28)			/* 0x10000000 */
+#define	TDLS_RESPONDER_STATE		BIT(29)			/* 0x20000000 */
+#define	TDLS_LINKED_STATE			BIT(30)			/* 0x40000000 */
+/* TDLS PU Buffer STA */
+#define	TDLS_WAIT_PTR_STATE			BIT(24)			/* 0x01000000 */	/* Waiting peer's TDLS_PEER_TRAFFIC_RESPONSE frame */
+/* TDLS Check ALive */
+#define	TDLS_ALIVE_STATE			BIT(20)			/* 0x00100000 */	/* Check if peer sta is alived. */
+/* TDLS Channel Switch */
+#define	TDLS_CH_SWITCH_PREPARE_STATE	BIT(15)			/* 0x00008000 */
+#define	TDLS_CH_SWITCH_ON_STATE			BIT(16)			/* 0x00010000 */
+#define	TDLS_PEER_AT_OFF_STATE			BIT(17)			/* 0x00020000 */	/* Could send pkt on target ch */
+#define	TDLS_CH_SW_INITIATOR_STATE		BIT(18)			/* 0x00040000 */	/* Avoid duplicated or unconditional ch. switch rsp. */
+#define	TDLS_WAIT_CH_RSP_STATE			BIT(19)			/* 0x00080000 */	/* Wait Ch. response as we are TDLS channel switch initiator */
+
+
+#define	TDLS_TPK_RESEND_COUNT			86400	/*Unit: seconds */
+#define	TDLS_CH_SWITCH_TIME				15
+#define	TDLS_CH_SWITCH_TIMEOUT			30
+#define	TDLS_CH_SWITCH_OPER_OFFLOAD_TIMEOUT	10
+#define	TDLS_SIGNAL_THRESH			0x20
+#define	TDLS_WATCHDOG_PERIOD		10	/* Periodically sending tdls discovery request in TDLS_WATCHDOG_PERIOD * 2 sec */
+#define	TDLS_HANDSHAKE_TIME			3000
+#define	TDLS_PTI_TIME				7000
+
+#define TDLS_CH_SW_STAY_ON_BASE_CHNL_TIMEOUT	20		/* ms */
+#define TDLS_CH_SW_MONITOR_TIMEOUT				2000	/*ms */
+
+#define TDLS_MIC_LEN 16
+#define WPA_NONCE_LEN 32
+#define TDLS_TIMEOUT_LEN 4
+
+enum TDLS_CH_SW_CHNL {
+	TDLS_CH_SW_BASE_CHNL = 0,
+	TDLS_CH_SW_OFF_CHNL
+};
+
+#define TDLS_MIC_CTRL_LEN 2
+#define TDLS_FTIE_DATA_LEN (TDLS_MIC_CTRL_LEN + TDLS_MIC_LEN + \
+							WPA_NONCE_LEN + WPA_NONCE_LEN)
+struct wpa_tdls_ftie {
+	u8 ie_type; /* FTIE */
+	u8 ie_len;
+	union {
+		struct {
+			u8 mic_ctrl[TDLS_MIC_CTRL_LEN];
+			u8 mic[TDLS_MIC_LEN];
+			u8 Anonce[WPA_NONCE_LEN]; /* Responder Nonce in TDLS */
+			u8 Snonce[WPA_NONCE_LEN]; /* Initiator Nonce in TDLS */
+		};
+		struct {
+			u8 data[TDLS_FTIE_DATA_LEN];
+		};
+	};
+	/* followed by optional elements */
+} ;
+
+struct wpa_tdls_lnkid {
+	u8 ie_type; /* Link Identifier IE */
+	u8 ie_len;
+	u8 bssid[ETH_ALEN];
+	u8 init_sta[ETH_ALEN];
+	u8 resp_sta[ETH_ALEN];
+} ;
+
+static u8 TDLS_RSNIE[20] = {	0x01, 0x00,	/* Version shall be set to 1 */
+				0x00, 0x0f, 0xac, 0x07,	/* Group sipher suite */
+				0x01, 0x00,	/* Pairwise cipher suite count */
+	0x00, 0x0f, 0xac, 0x04,	/* Pairwise cipher suite list; CCMP only */
+				0x01, 0x00,	/* AKM suite count */
+				0x00, 0x0f, 0xac, 0x07,	/* TPK Handshake */
+				0x0c, 0x02,
+				/* PMKID shall not be present */
+			   };
+
+static u8 TDLS_WMMIE[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01, 0x00};	/* Qos info all set zero */
+
+static u8 TDLS_WMM_PARAM_IE[] = {0x00, 0x00, 0x03, 0xa4, 0x00, 0x00, 0x27, 0xa4, 0x00, 0x00, 0x42, 0x43, 0x5e, 0x00, 0x62, 0x32, 0x2f, 0x00};
+
+static u8 TDLS_EXT_CAPIE[] = {0x00, 0x00, 0x00, 0x50, 0x20, 0x00, 0x00, 0x00};	/* bit(28), bit(30), bit(37) */
+
+/* SRC: Supported Regulatory Classes */
+static u8 TDLS_SRC[] = { 0x01, 0x01, 0x02, 0x03, 0x04, 0x0c, 0x16, 0x17, 0x18, 0x19, 0x1b, 0x1c, 0x1d, 0x1e, 0x20, 0x21 };
+
+int check_ap_tdls_prohibited(u8 *pframe, u8 pkt_len);
+int check_ap_tdls_ch_switching_prohibited(u8 *pframe, u8 pkt_len);
+
+void rtw_set_tdls_enable(_adapter *padapter, u8 enable);
+u8 rtw_is_tdls_enabled(_adapter *padapter);
+u8 rtw_is_tdls_sta_existed(_adapter *padapter);
+u8 rtw_tdls_is_setup_allowed(_adapter *padapter);
+#ifdef CONFIG_TDLS_CH_SW
+u8 rtw_tdls_is_chsw_allowed(_adapter *padapter);
+#endif
+
+void rtw_tdls_set_link_established(_adapter *adapter, bool en);
+void rtw_reset_tdls_info(_adapter *padapter);
+int rtw_init_tdls_info(_adapter *padapter);
+void rtw_free_tdls_info(struct tdls_info *ptdlsinfo);
+void rtw_free_all_tdls_sta(_adapter *padapter, u8 enqueue_cmd);
+void rtw_enable_tdls_func(_adapter *padapter);
+void rtw_disable_tdls_func(_adapter *padapter, u8 enqueue_cmd);
+int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms);
+void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta);
+void	rtw_cancel_tdls_timer(struct sta_info *psta);
+void rtw_tdls_teardown_pre_hdl(_adapter *padapter, struct sta_info *psta);
+void rtw_tdls_teardown_post_hdl(_adapter *padapter, struct sta_info *psta, u8 enqueue_cmd);
+
+#ifdef CONFIG_TDLS_CH_SW
+void rtw_tdls_set_ch_sw_oper_control(_adapter *padapter, u8 enable);
+void rtw_tdls_ch_sw_back_to_base_chnl(_adapter *padapter);
+s32 rtw_tdls_do_ch_sw(_adapter *padapter, struct sta_info *ptdls_sta, u8 chnl_type, u8 channel, u8 channel_offset, u16 bwmode, u16 ch_switch_time);
+void rtw_tdls_chsw_oper_done(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_WFD
+int issue_tunneled_probe_req(_adapter *padapter);
+int issue_tunneled_probe_rsp(_adapter *padapter, union recv_frame *precv_frame);
+#endif /* CONFIG_WFD */
+int issue_tdls_dis_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack);
+int issue_tdls_setup_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_setup_cfm(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_dis_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 privacy);
+int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack);
+int issue_tdls_peer_traffic_rsp(_adapter *padapter, struct sta_info *psta, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_peer_traffic_indication(_adapter *padapter, struct sta_info *psta);
+#ifdef CONFIG_TDLS_CH_SW
+int issue_tdls_ch_switch_req(_adapter *padapter, struct sta_info *ptdls_sta);
+int issue_tdls_ch_switch_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack);
+#endif
+sint On_TDLS_Dis_Rsp(_adapter *adapter, union recv_frame *precv_frame);
+sint On_TDLS_Setup_Req(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Setup_Rsp(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Setup_Cfm(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Dis_Req(_adapter *adapter, union recv_frame *precv_frame);
+int On_TDLS_Teardown(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Peer_Traffic_Indication(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Peer_Traffic_Rsp(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+#ifdef CONFIG_TDLS_CH_SW
+sint On_TDLS_Ch_Switch_Req(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+sint On_TDLS_Ch_Switch_Rsp(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+void rtw_build_tdls_ch_switch_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_ch_switch_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+#endif
+void rtw_build_tdls_setup_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_setup_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_setup_cfm_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_teardown_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_dis_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
+void rtw_build_tdls_dis_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, u8 privacy);
+void rtw_build_tdls_peer_traffic_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_peer_traffic_indication_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tunneled_probe_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe);
+void rtw_build_tunneled_probe_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe);
+
+int rtw_tdls_is_driver_setup(_adapter *padapter);
+void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta);
+const char *rtw_tdls_action_txt(enum TDLS_ACTION_FIELD action);
+#endif /* CONFIG_TDLS */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_version.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_version.h
new file mode 100644
index 000000000000..7f1171711794
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_version.h
@@ -0,0 +1,2 @@
+#define DRIVERVERSION	"v5.3.1_27678.20180430_COEX20180427-5959"
+#define BTCOEXVERSION	"COEX20180427-5959"
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_vht.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_vht.h
new file mode 100644
index 000000000000..bad14feb8efe
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_vht.h
@@ -0,0 +1,158 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_VHT_H_
+#define _RTW_VHT_H_
+
+#define VHT_CAP_IE_LEN 12
+#define VHT_OP_IE_LEN 5
+
+#define	LDPC_VHT_ENABLE_RX			BIT0
+#define	LDPC_VHT_ENABLE_TX			BIT1
+#define	LDPC_VHT_TEST_TX_ENABLE		BIT2
+#define	LDPC_VHT_CAP_TX				BIT3
+
+#define	STBC_VHT_ENABLE_RX			BIT0
+#define	STBC_VHT_ENABLE_TX			BIT1
+#define	STBC_VHT_TEST_TX_ENABLE		BIT2
+#define	STBC_VHT_CAP_TX				BIT3
+
+/* VHT capability info */
+#define SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 0, 2, _val)
+#define SET_VHT_CAPABILITY_ELE_CHL_WIDTH(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 2, 2, _val)
+#define SET_VHT_CAPABILITY_ELE_RX_LDPC(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 4, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_SHORT_GI80M(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE(_pEleStart, 5, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_SHORT_GI160M(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE(_pEleStart, 6, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_TX_STBC(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE(_pEleStart, 7, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_RX_STBC(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+1, 0, 3, _val)
+#define SET_VHT_CAPABILITY_ELE_SU_BFER(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+1, 3, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_SU_BFEE(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+1, 4, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_BFER_ANT_SUPP(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+1, 5, 3, _val)
+#define SET_VHT_CAPABILITY_ELE_SOUNDING_DIMENSIONS(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 0, 3, _val)
+
+#define SET_VHT_CAPABILITY_ELE_MU_BFER(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 3, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_MU_BFEE(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 4, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_TXOP_PS(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 5, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_HTC_VHT(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 6, 1, _val)
+#define SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(_pEleStart, _val)		SET_BITS_TO_LE_2BYTE((_pEleStart)+2, 7, 3, _val) /* B23~B25 */
+#define SET_VHT_CAPABILITY_ELE_LINK_ADAPTION(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 2, 2, _val)
+#define SET_VHT_CAPABILITY_ELE_MCS_RX_MAP(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+4, 0, 16, _val)   /* B0~B15 indicate Rx MCS MAP, we write 0 to indicate MCS0~7. by page */
+#define SET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+6, 0, 13, _val)
+#define SET_VHT_CAPABILITY_ELE_MCS_TX_MAP(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+8, 0, 16, _val)   /* B0~B15 indicate Tx MCS MAP, we write 0 to indicate MCS0~7. by page */
+#define SET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+10, 0, 13, _val)
+
+
+#define GET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(_pEleStart)			LE_BITS_TO_1BYTE(_pEleStart, 0, 2)
+#define GET_VHT_CAPABILITY_ELE_CHL_WIDTH(_pEleStart)				LE_BITS_TO_1BYTE(_pEleStart, 2, 2)
+#define GET_VHT_CAPABILITY_ELE_RX_LDPC(_pEleStart)			LE_BITS_TO_1BYTE(_pEleStart, 4, 1)
+#define GET_VHT_CAPABILITY_ELE_SHORT_GI80M(_pEleStart)				LE_BITS_TO_1BYTE(_pEleStart, 5, 1)
+#define GET_VHT_CAPABILITY_ELE_SHORT_GI160M(_pEleStart)				LE_BITS_TO_1BYTE(_pEleStart, 6, 1)
+#define GET_VHT_CAPABILITY_ELE_TX_STBC(_pEleStart)				LE_BITS_TO_1BYTE(_pEleStart, 7, 1)
+#define GET_VHT_CAPABILITY_ELE_RX_STBC(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+1, 0, 3)
+#define GET_VHT_CAPABILITY_ELE_SU_BFER(_pEleStart)					LE_BITS_TO_1BYTE((_pEleStart)+1, 3, 1)
+#define GET_VHT_CAPABILITY_ELE_SU_BFEE(_pEleStart)					LE_BITS_TO_1BYTE((_pEleStart)+1, 4, 1)
+/*phydm-beamforming*/
+#define GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(_pEleStart)	LE_BITS_TO_2BYTE((_pEleStart)+1, 5, 3)
+#define GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(_pEleStart)	LE_BITS_TO_2BYTE((_pEleStart)+2, 0, 3)
+#define GET_VHT_CAPABILITY_ELE_MU_BFER(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+2, 3, 1)
+#define GET_VHT_CAPABILITY_ELE_MU_BFEE(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+2, 4, 1)
+#define GET_VHT_CAPABILITY_ELE_TXOP_PS(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+2, 5, 1)
+#define GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(_pEleStart)	LE_BITS_TO_2BYTE((_pEleStart)+2, 7, 3)
+#define GET_VHT_CAPABILITY_ELE_RX_MCS(_pEleStart)					       ((_pEleStart)+4)
+#define GET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(_pEleStart)			LE_BITS_TO_2BYTE((_pEleStart)+6, 0, 13)
+#define GET_VHT_CAPABILITY_ELE_TX_MCS(_pEleStart)					       ((_pEleStart)+8)
+#define GET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(_pEleStart)			LE_BITS_TO_2BYTE((_pEleStart)+10, 0, 13)
+
+
+/* VHT Operation Information Element */
+#define SET_VHT_OPERATION_ELE_CHL_WIDTH(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 0, 8, _val)
+#define SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart+1, 0, 8, _val)
+#define SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart+2, 0, 8, _val)
+#define SET_VHT_OPERATION_ELE_BASIC_MCS_SET(_pEleStart, _val)			SET_BITS_TO_LE_2BYTE((_pEleStart)+3, 0, 16, _val)
+
+#define GET_VHT_OPERATION_ELE_CHL_WIDTH(_pEleStart)		LE_BITS_TO_1BYTE(_pEleStart, 0, 8)
+#define GET_VHT_OPERATION_ELE_CENTER_FREQ1(_pEleStart)	LE_BITS_TO_1BYTE((_pEleStart)+1, 0, 8)
+#define GET_VHT_OPERATION_ELE_CENTER_FREQ2(_pEleStart)     LE_BITS_TO_1BYTE((_pEleStart)+2, 0, 8)
+
+/* VHT Operating Mode */
+#define SET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(_pEleStart, 0, 2, _val)
+#define SET_VHT_OPERATING_MODE_FIELD_RX_NSS(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 4, 3, _val)
+#define SET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(_pEleStart, 7, 1, _val)
+#define GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(_pEleStart)			LE_BITS_TO_1BYTE(_pEleStart, 0, 2)
+#define GET_VHT_OPERATING_MODE_FIELD_RX_NSS(_pEleStart)				LE_BITS_TO_1BYTE(_pEleStart, 4, 3)
+#define GET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE(_pEleStart)		LE_BITS_TO_1BYTE(_pEleStart, 7, 1)
+
+#define SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE((_pEleStart)+7, 6, 1, _val)
+#define GET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+7, 6, 1)
+
+#define VHT_MAX_MPDU_LEN_MAX 3
+extern const u16 _vht_max_mpdu_len[];
+#define vht_max_mpdu_len(val) (((val) >= VHT_MAX_MPDU_LEN_MAX) ? _vht_max_mpdu_len[VHT_MAX_MPDU_LEN_MAX] : _vht_max_mpdu_len[(val)])
+
+#define VHT_SUP_CH_WIDTH_SET_MAX 3
+extern const u8 _vht_sup_ch_width_set_to_bw_cap[];
+#define vht_sup_ch_width_set_to_bw_cap(set) (((set) >= VHT_SUP_CH_WIDTH_SET_MAX) ? _vht_sup_ch_width_set_to_bw_cap[VHT_SUP_CH_WIDTH_SET_MAX] : _vht_sup_ch_width_set_to_bw_cap[(set)])
+extern const char *const _vht_sup_ch_width_set_str[];
+#define vht_sup_ch_width_set_str(set) (((set) >= VHT_SUP_CH_WIDTH_SET_MAX) ? _vht_sup_ch_width_set_str[VHT_SUP_CH_WIDTH_SET_MAX] : _vht_sup_ch_width_set_str[(set)])
+
+#define VHT_MAX_AMPDU_LEN(f) ((1 << (13 + f)) - 1)
+void dump_vht_cap_ie(void *sel, const u8 *ie, u32 ie_len);
+
+#define VHT_OP_CH_WIDTH_MAX 4
+extern const char *const _vht_op_ch_width_str[];
+#define vht_op_ch_width_str(ch_width) (((ch_width) >= VHT_OP_CH_WIDTH_MAX) ? _vht_op_ch_width_str[VHT_OP_CH_WIDTH_MAX] : _vht_op_ch_width_str[(ch_width)])
+
+void dump_vht_op_ie(void *sel, const u8 *ie, u32 ie_len);
+
+struct vht_priv {
+	u8	vht_option;
+
+	u8	ldpc_cap;
+	u8	stbc_cap;
+	u16	beamform_cap;
+
+	u8	sgi_80m;/* short GI */
+	u8	ampdu_len;
+
+	u8	vht_highest_rate;
+	u8	vht_mcs_map[2];
+
+	u8 op_present:1; /* vht_op is present */
+	u8 notify_present:1; /* vht_op_mode_notify is present */
+
+	u8 vht_cap[32];
+	u8 vht_op[VHT_OP_IE_LEN];
+	u8 vht_op_mode_notify;
+};
+
+u8	rtw_get_vht_highest_rate(u8 *pvht_mcs_map);
+u16	rtw_vht_mcs_to_data_rate(u8 bw, u8 short_GI, u8 vht_mcs_rate);
+u64	rtw_vht_mcs_map_to_bitmap(u8 *mcs_map, u8 nss);
+void	rtw_vht_use_default_setting(_adapter *padapter);
+u32	rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel);
+u32	rtw_build_vht_op_mode_notify_ie(_adapter *padapter, u8 *pbuf, u8 bw);
+u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf);
+void	update_sta_vht_info_apmode(_adapter *padapter, PVOID psta);
+void	update_hw_vht_param(_adapter *padapter);
+void	VHT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void	VHT_operation_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void	rtw_process_vht_op_mode_notify(_adapter *padapter, u8 *pframe, PVOID sta);
+u32	rtw_restructure_vht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len);
+void	VHTOnAssocRsp(_adapter *padapter);
+u8	rtw_vht_mcsmap_to_nss(u8 *pvht_mcs_map);
+void rtw_vht_nss_to_mcsmap(u8 nss, u8 *target_mcs_map, u8 *cur_mcs_map);
+void rtw_vht_ies_attach(_adapter *padapter, WLAN_BSSID_EX *pcur_network);
+void rtw_vht_ies_detach(_adapter *padapter, WLAN_BSSID_EX *pcur_network);
+void rtw_check_for_vht20(_adapter *adapter, u8 *ies, int ies_len);
+#endif /* _RTW_VHT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_wapi.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_wapi.h
new file mode 100644
index 000000000000..512bb7f300a2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_wapi.h
@@ -0,0 +1,230 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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_WAPI_H
+#define __INC_WAPI_H
+
+
+#define CONFIG_WAPI_SW_SMS4
+#define WAPI_DEBUG
+
+#define SMS4_MIC_LEN                16
+#define WAPI_EXT_LEN                18
+#define MAX_WAPI_IE_LEN		    256
+#define sMacHdrLng				24		/* octets in data header, no WEP */
+
+#ifdef WAPI_DEBUG
+
+/* WAPI trace debug */
+extern u32 wapi_debug_component;
+
+static inline void dump_buf(u8 *buf, u32 len)
+{
+	u32 i;
+	printk("-----------------Len %d----------------\n", len);
+	for (i = 0; i < len; i++)
+		printk("%2.2x-", *(buf + i));
+	printk("\n");
+}
+
+#define WAPI_TRACE(component, x, args...) \
+	do { if (wapi_debug_component & (component)) \
+			printk(KERN_DEBUG "WAPI" ":" x "" , \
+			       ##args);\
+	} while (0);
+
+#define WAPI_DATA(component, x, buf, len) \
+	do { if (wapi_debug_component & (component)) { \
+			printk("%s:\n", x);\
+			dump_buf((buf), (len)); } \
+	} while (0);
+
+#define RT_ASSERT_RET(_Exp)								\
+	if (!(_Exp)) {									\
+		printk("RTWLAN: ");					\
+		printk("Assertion failed! %s,%s, line=%d\n", \
+		       #_Exp, __FUNCTION__, __LINE__);          \
+		return;						\
+	}
+#define RT_ASSERT_RET_VALUE(_Exp, Ret)								\
+	if (!(_Exp)) {									\
+		printk("RTWLAN: ");					\
+		printk("Assertion failed! %s,%s, line=%d\n", \
+		       #_Exp, __FUNCTION__, __LINE__);          \
+		return Ret;						\
+	}
+
+#else
+#define RT_ASSERT_RET(_Exp) do {} while (0)
+#define RT_ASSERT_RET_VALUE(_Exp, Ret) do {} while (0)
+#define WAPI_TRACE(component, x, args...) do {} while (0)
+#define WAPI_DATA(component, x, buf, len) do {} while (0)
+#endif
+
+
+enum WAPI_DEBUG {
+	WAPI_INIT				= 1,
+	WAPI_API				= 1 << 1,
+	WAPI_TX				= 1 << 2,
+	WAPI_RX				= 1 << 3,
+	WAPI_MLME				= 1 << 4,
+	WAPI_IOCTL				= 1 << 5,
+	WAPI_ERR			= 1 << 31
+};
+
+#define			WAPI_MAX_BKID_NUM				4
+#define			WAPI_MAX_STAINFO_NUM			4
+#define			WAPI_CAM_ENTRY_NUM			14	/* 28/2 = 14 */
+
+typedef struct  _RT_WAPI_BKID {
+	struct list_head	list;
+	u8				bkid[16];
+} RT_WAPI_BKID, *PRT_WAPI_BKID;
+
+typedef struct  _RT_WAPI_KEY {
+	u8			dataKey[16];
+	u8			micKey[16];
+	u8			keyId;
+	bool			bSet;
+	bool             bTxEnable;
+} RT_WAPI_KEY, *PRT_WAPI_KEY;
+
+typedef enum _RT_WAPI_PACKET_TYPE {
+	WAPI_NONE = 0,
+	WAPI_PREAUTHENTICATE = 1,
+	WAPI_STAKEY_REQUEST = 2,
+	WAPI_AUTHENTICATE_ACTIVE = 3,
+	WAPI_ACCESS_AUTHENTICATE_REQUEST = 4,
+	WAPI_ACCESS_AUTHENTICATE_RESPONSE = 5,
+	WAPI_CERTIFICATE_AUTHENTICATE_REQUEST = 6,
+	WAPI_CERTIFICATE_AUTHENTICATE_RESPONSE = 7,
+	WAPI_USK_REQUEST = 8,
+	WAPI_USK_RESPONSE = 9,
+	WAPI_USK_CONFIRM = 10,
+	WAPI_MSK_NOTIFICATION = 11,
+	WAPI_MSK_RESPONSE = 12
+} RT_WAPI_PACKET_TYPE;
+
+typedef struct	_RT_WAPI_STA_INFO {
+	struct list_head		list;
+	u8					PeerMacAddr[6];
+	RT_WAPI_KEY		      wapiUsk;
+	RT_WAPI_KEY		      wapiUskUpdate;
+	RT_WAPI_KEY		      wapiMsk;
+	RT_WAPI_KEY		      wapiMskUpdate;
+	u8					lastRxUnicastPN[16];
+	u8					lastTxUnicastPN[16];
+	u8					lastRxMulticastPN[16];
+	u8					lastRxUnicastPNBEQueue[16];
+	u8					lastRxUnicastPNBKQueue[16];
+	u8					lastRxUnicastPNVIQueue[16];
+	u8					lastRxUnicastPNVOQueue[16];
+	bool					bSetkeyOk;
+	bool					bAuthenticateInProgress;
+	bool					bAuthenticatorInUpdata;
+} RT_WAPI_STA_INFO, *PRT_WAPI_STA_INFO;
+
+/* Added for HW wapi en/decryption */
+typedef struct _RT_WAPI_CAM_ENTRY {
+	/* RT_LIST_ENTRY		list; */
+	u8			IsUsed;
+	u8			entry_idx;/* for cam entry */
+	u8			keyidx;	/* 0 or 1,new or old key */
+	u8			PeerMacAddr[6];
+	u8			type;	/* should be 110,wapi */
+} RT_WAPI_CAM_ENTRY, *PRT_WAPI_CAM_ENTRY;
+
+typedef struct _RT_WAPI_T {
+	/* BKID */
+	RT_WAPI_BKID		wapiBKID[WAPI_MAX_BKID_NUM];
+	struct list_head		wapiBKIDIdleList;
+	struct list_head		wapiBKIDStoreList;
+	/* Key for Tx Multicast/Broadcast */
+	RT_WAPI_KEY		      wapiTxMsk;
+
+	/* sec related */
+	u8				lastTxMulticastPN[16];
+	/* STA list */
+	RT_WAPI_STA_INFO	wapiSta[WAPI_MAX_STAINFO_NUM];
+	struct list_head		wapiSTAIdleList;
+	struct list_head		wapiSTAUsedList;
+	/*  */
+	bool				bWapiEnable;
+
+	/* store WAPI IE */
+	u8				wapiIE[256];
+	u8				wapiIELength;
+	bool				bWapiPSK;
+	/* last sequece number for wai packet */
+	u16				wapiSeqnumAndFragNum;
+	int extra_prefix_len;
+	int extra_postfix_len;
+
+	RT_WAPI_CAM_ENTRY	wapiCamEntry[WAPI_CAM_ENTRY_NUM];
+} RT_WAPI_T, *PRT_WAPI_T;
+
+typedef struct _WLAN_HEADER_WAPI_EXTENSION {
+	u8      KeyIdx;
+	u8      Reserved;
+	u8      PN[16];
+} WLAN_HEADER_WAPI_EXTENSION, *PWLAN_HEADER_WAPI_EXTENSION;
+
+u32 WapiComparePN(u8 *PN1, u8 *PN2);
+
+
+void rtw_wapi_init(_adapter *padapter);
+
+void rtw_wapi_free(_adapter *padapter);
+
+void rtw_wapi_disable_tx(_adapter *padapter);
+
+u8 rtw_wapi_is_wai_packet(_adapter *padapter, u8 *pkt_data);
+
+void rtw_wapi_update_info(_adapter *padapter, union recv_frame *precv_frame);
+
+u8 rtw_wapi_check_for_drop(_adapter *padapter, union recv_frame *precv_frame, u8 *ehdr_ops);
+
+void rtw_build_probe_resp_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
+
+void rtw_build_beacon_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
+
+void rtw_build_assoc_req_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
+
+void rtw_wapi_on_assoc_ok(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+
+void rtw_wapi_return_one_sta_info(_adapter *padapter, u8 *MacAddr);
+
+void rtw_wapi_return_all_sta_info(_adapter *padapter);
+
+void rtw_wapi_clear_cam_entry(_adapter *padapter, u8 *pMacAddr);
+
+void rtw_wapi_clear_all_cam_entry(_adapter *padapter);
+
+void rtw_wapi_set_key(_adapter *padapter, RT_WAPI_KEY *pWapiKey, RT_WAPI_STA_INFO *pWapiSta, u8 bGroupKey, u8 bUseDefaultKey);
+
+int rtw_wapi_create_event_send(_adapter *padapter, u8 EventId, u8 *MacAddr, u8 *Buff, u16 BufLen);
+
+u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe);
+
+u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe);
+
+void rtw_wapi_get_iv(_adapter *padapter, u8 *pRA, u8 *IV);
+
+u8 WapiIncreasePN(u8 *PN, u8 AddCount);
+
+bool rtw_wapi_drop_for_key_absent(_adapter *padapter, u8 *pRA);
+
+void rtw_wapi_set_set_encryption(_adapter *padapter, struct ieee_param *param);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_wifi_regd.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_wifi_regd.h
new file mode 100644
index 000000000000..f56008cf7c4b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_wifi_regd.h
@@ -0,0 +1,34 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2009-2010 - 2017 Realtek Corporation.
+ *
+ * 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_WIFI_REGD_H__
+#define __RTW_WIFI_REGD_H__
+
+struct country_code_to_enum_rd {
+	u16 countrycode;
+	const char *iso_name;
+};
+
+enum country_code_type_t {
+	COUNTRY_CODE_USER = 0,
+
+	/*add new channel plan above this line */
+	COUNTRY_CODE_MAX
+};
+
+int rtw_regd_init(_adapter *padapter);
+void rtw_reg_notify_by_driver(_adapter *adapter);
+
+#endif /* __RTW_WIFI_REGD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_xmit.h
new file mode 100644
index 000000000000..f61288853f68
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/rtw_xmit.h
@@ -0,0 +1,1052 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	#ifdef CONFIG_TX_AGGREGATION
+		#define MAX_XMITBUF_SZ	(20480)	/* 20k */
+		/* #define SDIO_TX_AGG_MAX	5 */
+	#else
+		#define MAX_XMITBUF_SZ (1664)
+		#define SDIO_TX_AGG_MAX	1
+	#endif
+
+	#if defined CONFIG_SDIO_HCI
+		#define NR_XMITBUFF	(16)
+	#endif
+	#if defined(CONFIG_GSPI_HCI)
+		#define NR_XMITBUFF	(128)
+	#endif
+
+#elif defined (CONFIG_USB_HCI)
+
+	#ifdef CONFIG_USB_TX_AGGREGATION
+		#if defined(CONFIG_PLATFORM_ARM_SUNxI) || defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I) || defined(CONFIG_PLATFORM_ARM_SUN8I) || defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+			#define MAX_XMITBUF_SZ (12288)  /* 12k 1536*8 */
+		#elif defined (CONFIG_PLATFORM_MSTAR)
+			#define MAX_XMITBUF_SZ	7680	/* 7.5k */
+		#else
+			#define MAX_XMITBUF_SZ	(20480)	/* 20k */
+		#endif
+	#else
+		#define MAX_XMITBUF_SZ	(2048)
+	#endif
+
+	#ifdef CONFIG_SINGLE_XMIT_BUF
+		#define NR_XMITBUFF	(1)
+	#else
+		#define NR_XMITBUFF	(4)
+	#endif /* CONFIG_SINGLE_XMIT_BUF */
+#elif defined (CONFIG_PCI_HCI)
+#ifdef CONFIG_TX_AMSDU
+	#define MAX_XMITBUF_SZ	(3500)
+#else
+	#define MAX_XMITBUF_SZ	(1664)
+#endif
+	#define NR_XMITBUFF	(128)
+#endif
+
+#ifdef PLATFORM_OS_CE
+	#define XMITBUF_ALIGN_SZ 4
+#else
+	#ifdef CONFIG_PCI_HCI
+		#define XMITBUF_ALIGN_SZ 4
+	#else
+		#ifdef USB_XMITBUF_ALIGN_SZ
+			#define XMITBUF_ALIGN_SZ (USB_XMITBUF_ALIGN_SZ)
+		#else
+			#define XMITBUF_ALIGN_SZ 512
+		#endif
+	#endif
+#endif
+
+/* xmit extension buff defination */
+#define MAX_XMIT_EXTBUF_SZ	(1536)
+
+#ifdef CONFIG_SINGLE_XMIT_BUF
+	#define NR_XMIT_EXTBUFF	(1)
+#else
+	#define NR_XMIT_EXTBUFF	(32)
+#endif
+
+#ifdef CONFIG_RTL8812A
+	#define MAX_CMDBUF_SZ	(512 * 18)
+#elif defined(CONFIG_RTL8723D) && defined(CONFIG_LPS_POFF)
+	#define MAX_CMDBUF_SZ	(128*70) /*(8960)*/
+#else
+	#define MAX_CMDBUF_SZ	(5120)	/* (4096) */
+#endif
+
+#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
+
+#ifdef CONFIG_PCI_HCI
+	#ifdef CONFIG_TRX_BD_ARCH
+		#define TX_BD_NUM			(128+1)	/* +1 result from ring buffer */
+	#else
+		#define TXDESC_NUM			128
+	#endif
+#endif
+
+#define WEP_IV(pattrib_iv, dot11txpn, keyidx)\
+	do {\
+		dot11txpn.val = (dot11txpn.val == 0xffffff) ? 0 : (dot11txpn.val + 1);\
+		pattrib_iv[0] = dot11txpn._byte_.TSC0;\
+		pattrib_iv[1] = dot11txpn._byte_.TSC1;\
+		pattrib_iv[2] = dot11txpn._byte_.TSC2;\
+		pattrib_iv[3] = ((keyidx & 0x3)<<6);\
+	} while (0)
+
+
+#define TKIP_IV(pattrib_iv, dot11txpn, keyidx)\
+	do {\
+		dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 : (dot11txpn.val + 1);\
+		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;\
+	} while (0)
+
+#define AES_IV(pattrib_iv, dot11txpn, keyidx)\
+	do {\
+		dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 : (dot11txpn.val + 1);\
+		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;\
+	} while (0)
+
+/* Check if AMPDU Tx is supported or not. If it is supported,
+* it need to check "amsdu in ampdu" is supported or not.
+* (ampdu_en, amsdu_ampdu_en) =
+* (0, x) : AMPDU is not enable, but AMSDU is valid to send.
+* (1, 0) : AMPDU is enable, AMSDU in AMPDU is not enable. So, AMSDU is not valid to send.
+* (1, 1) : AMPDU and AMSDU in AMPDU are enable. So, AMSDU is valid to send.
+*/
+#define IS_AMSDU_AMPDU_NOT_VALID(pattrib)\
+	 ((pattrib->ampdu_en == _TRUE) && (pattrib->amsdu_ampdu_en == _FALSE))
+
+#define IS_AMSDU_AMPDU_VALID(pattrib)\
+	 !((pattrib->ampdu_en == _TRUE) && (pattrib->amsdu_ampdu_en == _FALSE))
+
+#define HWXMIT_ENTRY	4
+
+/* For Buffer Descriptor ring architecture */
+#if defined(BUF_DESC_ARCH) || defined(CONFIG_TRX_BD_ARCH)
+	#if defined(CONFIG_RTL8192E)
+		#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
+	#elif defined(CONFIG_RTL8814A)
+		#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
+	#else
+		#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
+	#endif
+#endif
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) ||\
+	defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8192E) ||\
+	defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8703B) ||\
+	defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8723D)
+	#define TXDESC_SIZE 40
+#elif defined(CONFIG_RTL8822B)
+	#define TXDESC_SIZE 48		/* HALMAC_TX_DESC_SIZE_8822B */
+#elif defined(CONFIG_RTL8821C)
+	#define TXDESC_SIZE 48		/* HALMAC_TX_DESC_SIZE_8821C */
+#else
+	#define TXDESC_SIZE 32 /* old IC (ex: 8188E) */
+#endif
+
+#ifdef CONFIG_TX_EARLY_MODE
+	#define EARLY_MODE_INFO_SIZE	8
+#endif
+
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	#define TXDESC_OFFSET TXDESC_SIZE
+#endif
+
+#ifdef CONFIG_USB_HCI
+	#ifdef USB_PACKET_OFFSET_SZ
+		#define PACKET_OFFSET_SZ (USB_PACKET_OFFSET_SZ)
+	#else
+		#define PACKET_OFFSET_SZ (8)
+	#endif
+	#define TXDESC_OFFSET (TXDESC_SIZE + PACKET_OFFSET_SZ)
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	#if defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_TRX_BD_ARCH)
+		/* this section is defined for buffer descriptor ring architecture */
+		#define TX_WIFI_INFO_SIZE (TXDESC_SIZE) /* it may add 802.11 hdr or others... */
+		/* tx desc and payload are in the same buf */
+		#define TXDESC_OFFSET (TX_WIFI_INFO_SIZE)
+	#else
+		/* tx desc and payload are NOT in the same buf */
+		#define TXDESC_OFFSET (0)
+		/* 8188ee/8723be/8812ae/8821ae has extra PCI DMA info in tx desc */
+		#define TX_DESC_NEXT_DESC_OFFSET	(TXDESC_SIZE + 8)
+	#endif
+#endif /* CONFIG_PCI_HCI */
+
+enum TXDESC_SC {
+	SC_DONT_CARE = 0x00,
+	SC_UPPER = 0x01,
+	SC_LOWER = 0x02,
+	SC_DUPLICATE = 0x03
+};
+
+#ifdef CONFIG_PCI_HCI
+	#ifndef CONFIG_TRX_BD_ARCH	/* CONFIG_TRX_BD_ARCH doesn't need this */
+		#define TXDESC_64_BYTES
+	#endif
+#elif defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8723B) \
+	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8723D)
+	#define TXDESC_40_BYTES
+#endif
+
+#ifdef CONFIG_TRX_BD_ARCH
+struct tx_buf_desc {
+#ifdef CONFIG_64BIT_DMA
+#define TX_BUFFER_SEG_SIZE	4	/* in unit of DWORD */
+#else
+#define TX_BUFFER_SEG_SIZE	2	/* in unit of DWORD */
+#endif
+	unsigned int dword[TX_BUFFER_SEG_SIZE * (2 << TX_BUFFER_SEG_NUM)];
+} __packed;
+#elif (defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)) && defined(CONFIG_PCI_HCI) /* 8192ee or 8814ae */
+/* 8192EE_TODO */
+struct tx_desc {
+	unsigned int txdw0;
+	unsigned int txdw1;
+	unsigned int txdw2;
+	unsigned int txdw3;
+	unsigned int txdw4;
+	unsigned int txdw5;
+	unsigned int txdw6;
+	unsigned int txdw7;
+};
+#else
+struct tx_desc {
+	unsigned int txdw0;
+	unsigned int txdw1;
+	unsigned int txdw2;
+	unsigned int txdw3;
+	unsigned int txdw4;
+	unsigned int txdw5;
+	unsigned int txdw6;
+	unsigned int txdw7;
+
+#if defined(TXDESC_40_BYTES) || defined(TXDESC_64_BYTES)
+	unsigned int txdw8;
+	unsigned int txdw9;
+#endif /* TXDESC_40_BYTES */
+
+#ifdef TXDESC_64_BYTES
+	unsigned int txdw10;
+	unsigned int txdw11;
+
+	/* 2008/05/15 MH Because PCIE HW memory R/W 4K limit. And now,  our descriptor */
+	/* size is 40 bytes. If you use more than 102 descriptor( 103*40>4096), HW will execute */
+	/* memoryR/W CRC error. And then all DMA fetch will fail. We must decrease descriptor */
+	/* number or enlarge descriptor size as 64 bytes. */
+	unsigned int txdw12;
+	unsigned int txdw13;
+	unsigned int txdw14;
+	unsigned int txdw15;
+#endif
+};
+#endif
+
+#ifndef CONFIG_TRX_BD_ARCH
+union txdesc {
+	struct tx_desc txdesc;
+	unsigned int value[TXDESC_SIZE >> 2];
+};
+#endif
+
+#ifdef CONFIG_PCI_HCI
+#define PCI_MAX_TX_QUEUE_COUNT	8	/* == HW_QUEUE_ENTRY */
+
+struct rtw_tx_ring {
+	unsigned char	qid;
+#ifdef CONFIG_TRX_BD_ARCH
+	struct tx_buf_desc	*buf_desc;
+#else
+	struct tx_desc	*desc;
+#endif
+	dma_addr_t	dma;
+	unsigned int	idx;
+	unsigned int	entries;
+	_queue		queue;
+	u32		qlen;
+#ifdef CONFIG_TRX_BD_ARCH
+	u16		hw_rp_cache;
+#endif
+};
+
+#ifdef DBG_TXBD_DESC_DUMP
+
+#define TX_BAK_FRMAE_CNT	10
+#define TX_BAK_DESC_LEN	48	/* byte */
+#define TX_BAK_DATA_LEN		30	/* byte */
+
+struct rtw_tx_desc_backup {
+	int tx_bak_rp;
+	int tx_bak_wp;
+	u8 tx_bak_desc[TX_BAK_DESC_LEN];
+	u8 tx_bak_data_hdr[TX_BAK_DATA_LEN];
+	u8 tx_desc_size;
+};
+#endif
+#endif
+
+struct	hw_xmit	{
+	/* _lock xmit_lock; */
+	/* _list	pending; */
+	_queue *sta_queue;
+	/* struct hw_txqueue *phwtxqueue; */
+	/* sint	txcmdcnt; */
+	int	accnt;
+};
+
+#if 0
+struct pkt_attrib {
+	u8	type;
+	u8	subtype;
+	u8	bswenc;
+	u8	dhcp_pkt;
+	u16	ether_type;
+	int	pktlen;		/* the original 802.3 pkt raw_data len (not include ether_hdr data) */
+	int	pkt_hdrlen;	/* the original 802.3 pkt header len */
+	int	hdrlen;		/* the WLAN Header Len */
+	int	nr_frags;
+	int	last_txcmdsz;
+	int	encrypt;	/* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith */
+	u8	iv[8];
+	int	iv_len;
+	u8	icv[8];
+	int	icv_len;
+	int	priority;
+	int	ack_policy;
+	int	mac_id;
+	int	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	eosp;
+
+	u8	triggered;/* for ap mode handling Power Saving sta */
+
+	u32	qsel;
+	u16	seqnum;
+
+	struct sta_info *psta;
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+	u8	hw_tcp_csum;
+#endif
+};
+#else
+/* reduce size */
+struct pkt_attrib {
+	u8	type;
+	u8	subtype;
+	u8	bswenc;
+	u8	dhcp_pkt;
+	u16	ether_type;
+	u16	seqnum;
+	u8	hw_ssn_sel;	/* for HW_SEQ0,1,2,3 */
+	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 (not include ether_hdr data) */
+	u32	last_txcmdsz;
+	u8	nr_frags;
+	u8	encrypt;	/* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith */
+#if defined(CONFIG_CONCURRENT_MODE)
+	u8	bmc_camid;
+#endif
+	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];
+#ifdef CONFIG_RTW_MESH
+	u8	mda[ETH_ALEN];	/* mesh da */
+	u8	msa[ETH_ALEN];	/* mesh sa */
+	u8	meshctrl_len;	/* Length of Mesh Control field */
+	u8	mesh_frame_mode;
+	#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	u8 mb2u;
+	#endif
+	u8 mfwd_ttl;
+	u32 mseq;
+#endif
+	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	ampdu_spacing; /* ampdu_min_spacing for peer sta's rx */
+	u8	amsdu;
+	u8	amsdu_ampdu_en;/* tx amsdu in 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	order;/* order bit */
+	u8	eosp;
+	u8	rate;
+	u8	intel_proxim;
+	u8	retry_ctrl;
+	u8   mbssid;
+	u8	ldpc;
+	u8	stbc;
+#ifdef CONFIG_WMMPS_STA
+	u8	trigger_frame;
+#endif /* CONFIG_WMMPS_STA */
+	
+	struct sta_info *psta;
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+	u8	hw_tcp_csum;
+#endif
+
+	u8 rtsen;
+	u8 cts2self;
+	union Keytype	dot11tkiptxmickey;
+	/* union Keytype	dot11tkiprxmickey; */
+	union Keytype	dot118021x_UncstKey;
+
+#ifdef CONFIG_TDLS
+	u8 direct_link;
+	struct sta_info *ptdls_sta;
+#endif /* CONFIG_TDLS */
+	u8 key_type;
+
+	u8 icmp_pkt;
+
+#ifdef CONFIG_BEAMFORMING
+	u16 txbf_p_aid;/*beamforming Partial_AID*/
+	u16 txbf_g_id;/*beamforming Group ID*/
+
+	/*
+	 * 2'b00: Unicast NDPA
+	 * 2'b01: Broadcast NDPA
+	 * 2'b10: Beamforming Report Poll
+	 * 2'b11: Final Beamforming Report Poll
+	 */
+	u8 bf_pkt_type;
+#endif
+
+};
+#endif
+
+#ifdef CONFIG_RTW_MESH
+#define XATTRIB_GET_MCTRL_LEN(xattrib) ((xattrib)->meshctrl_len)
+#else
+#define XATTRIB_GET_MCTRL_LEN(xattrib) 0
+#endif
+
+#ifdef CONFIG_TX_AMSDU
+enum {
+	RTW_AMSDU_TIMER_UNSET = 0,
+	RTW_AMSDU_TIMER_SETTING,
+	RTW_AMSDU_TIMER_TIMEOUT,
+};
+#endif
+
+#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
+
+enum {
+	XMITBUF_DATA = 0,
+	XMITBUF_MGNT = 1,
+	XMITBUF_CMD = 2,
+};
+
+bool rtw_xmit_ac_blocked(_adapter *adapter);
+
+struct  submit_ctx {
+	systime submit_time; /* */
+	u32 timeout_ms; /* <0: not synchronous, 0: wait forever, >0: up to ms waiting */
+	int status; /* status for operation */
+#ifdef PLATFORM_LINUX
+	struct completion done;
+#endif
+};
+
+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,
+	RTW_SCTX_DONE_CMD_ERROR,
+	RTW_SCTX_DONE_CMD_DROP,
+	RTX_SCTX_CSTR_WAIT_RPT2,
+};
+
+
+void rtw_sctx_init(struct submit_ctx *sctx, int timeout_ms);
+int rtw_sctx_wait(struct submit_ctx *sctx, const char *msg);
+void rtw_sctx_done_err(struct submit_ctx **sctx, int status);
+void rtw_sctx_done(struct submit_ctx **sctx);
+
+struct xmit_buf {
+	_list	list;
+
+	_adapter *padapter;
+
+	u8 *pallocated_buf;
+
+	u8 *pbuf;
+
+	void *priv_data;
+
+	u16 buf_tag; /* 0: Normal xmitbuf, 1: extension xmitbuf, 2:cmd xmitbuf */
+	u16 flags;
+	u32 alloc_sz;
+
+	u32  len;
+
+	struct submit_ctx *sctx;
+
+#ifdef CONFIG_USB_HCI
+
+	/* u32 sz[8]; */
+	u32	ff_hwaddr;
+#ifdef RTW_HALMAC
+	u8 bulkout_id; /* for halmac */
+#endif /* RTW_HALMAC */
+
+#if defined(PLATFORM_OS_XP) || defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
+	PURB	pxmit_urb[8];
+	dma_addr_t dma_transfer_addr;	/* (in) dma addr for transfer_buffer */
+#endif
+
+#ifdef PLATFORM_OS_XP
+	PIRP		pxmit_irp[8];
+#endif
+
+#ifdef PLATFORM_OS_CE
+	USB_TRANSFER	usb_transfer_write_port;
+#endif
+
+	u8 bpending[8];
+
+	sint last[8];
+
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	u8 *phead;
+	u8 *pdata;
+	u8 *ptail;
+	u8 *pend;
+	u32 ff_hwaddr;
+	u8	pg_num;
+	u8	agg_num;
+#ifdef PLATFORM_OS_XP
+	PMDL pxmitbuf_mdl;
+	PIRP  pxmitbuf_irp;
+	PSDBUS_REQUEST_PACKET pxmitbuf_sdrp;
+#endif
+#endif
+
+#ifdef CONFIG_PCI_HCI
+#ifdef CONFIG_TRX_BD_ARCH
+	/*struct tx_buf_desc *buf_desc;*/
+#else
+	struct tx_desc *desc;
+#endif
+#endif
+
+#if defined(DBG_XMIT_BUF) || defined(DBG_XMIT_BUF_EXT)
+	u8 no;
+#endif
+
+};
+
+
+struct xmit_frame {
+	_list	list;
+
+	struct pkt_attrib attrib;
+
+	_pkt *pkt;
+
+	int	frame_tag;
+
+	_adapter *padapter;
+
+	u8	*buf_addr;
+
+	struct xmit_buf *pxmitbuf;
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	u8	pg_num;
+	u8	agg_num;
+#endif
+
+#ifdef CONFIG_USB_HCI
+#ifdef CONFIG_USB_TX_AGGREGATION
+	u8	agg_num;
+#endif
+	s8	pkt_offset;
+#endif
+
+#ifdef CONFIG_XMIT_ACK
+	u8 ack_report;
+#endif
+
+	u8 *alloc_addr; /* the actual address this xmitframe allocated */
+	u8 ext_tag; /* 0:data, 1:mgmt */
+
+};
+
+struct tx_servq {
+	_list	tx_pending;
+	_queue	sta_pending;
+	int qcnt;
+};
+
+
+struct sta_xmit_priv {
+	_lock	lock;
+	sint	option;
+	sint	apsd_setting;	/* When bit mask is on, the associated edca queue supports APSD. */
+
+
+	/* struct tx_servq blk_q[MAX_NUMBLKS]; */
+	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 */
+	_list	legacy_dz;
+	_list  apsd;
+
+	u16 txseq_tid[16];
+
+	/* uint	sta_tx_bytes; */
+	/* u64	sta_tx_pkts; */
+	/* uint	sta_tx_fail; */
+
+
+};
+
+
+struct	hw_txqueue	{
+	volatile sint	head;
+	volatile sint	tail;
+	volatile sint 	free_sz;	/* in units of 64 bytes */
+	volatile sint      free_cmdsz;
+	volatile sint	 txsz[8];
+	uint	ff_hwaddr;
+	uint	cmd_hwaddr;
+	sint	ac_tag;
+};
+
+struct agg_pkt_info {
+	u16 offset;
+	u16 pkt_len;
+};
+
+enum cmdbuf_type {
+	CMDBUF_BEACON = 0x00,
+	CMDBUF_RSVD,
+	CMDBUF_MAX
+};
+
+u8 rtw_get_hwseq_no(_adapter *padapter);
+
+struct	xmit_priv	{
+
+	_lock	lock;
+
+	_sema	xmit_sema;
+
+	/* _queue	blk_strms[MAX_NUMBLKS]; */
+	_queue	be_pending;
+	_queue	bk_pending;
+	_queue	vi_pending;
+	_queue	vo_pending;
+	_queue	bm_pending;
+
+	/* _queue	legacy_dz_queue; */
+	/* _queue	apsd_queue; */
+
+	u8 *pallocated_frame_buf;
+	u8 *pxmit_frame_buf;
+	uint free_xmitframe_cnt;
+	_queue	free_xmit_queue;
+
+	/* uint mapping_addr; */
+	/* uint pkt_sz; */
+
+	u8 *xframe_ext_alloc_addr;
+	u8 *xframe_ext;
+	uint free_xframe_ext_cnt;
+	_queue free_xframe_ext_queue;
+
+	/* struct	hw_txqueue	be_txqueue; */
+	/* struct	hw_txqueue	bk_txqueue; */
+	/* struct	hw_txqueue	vi_txqueue; */
+	/* struct	hw_txqueue	vo_txqueue; */
+	/* struct	hw_txqueue	bmc_txqueue; */
+
+	uint	frag_len;
+
+	_adapter	*adapter;
+
+	u8   vcs_setting;
+	u8	vcs;
+	u8	vcs_type;
+	/* u16  rts_thresh; */
+
+	u64	tx_bytes;
+	u64	tx_pkts;
+	u64	tx_drop;
+	u64	last_tx_pkts;
+
+	struct hw_xmit *hwxmits;
+	u8	hwxmit_entry;
+
+	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. */
+
+#ifdef CONFIG_USB_HCI
+	_sema	tx_retevt;/* all tx return event; */
+	u8		txirp_cnt;
+
+#ifdef PLATFORM_OS_CE
+	USB_TRANSFER	usb_transfer_write_port;
+	/*	USB_TRANSFER	usb_transfer_write_mem; */
+#endif
+#ifdef PLATFORM_LINUX
+	struct tasklet_struct xmit_tasklet;
+#endif
+#ifdef PLATFORM_FREEBSD
+	struct task xmit_tasklet;
+#endif
+	/* per AC pending irp */
+	int beq_cnt;
+	int bkq_cnt;
+	int viq_cnt;
+	int voq_cnt;
+
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	/* Tx */
+	struct rtw_tx_ring	tx_ring[PCI_MAX_TX_QUEUE_COUNT];
+	int	txringcount[PCI_MAX_TX_QUEUE_COUNT];
+	u8 	beaconDMAing;		/* flag of indicating beacon is transmiting to HW by DMA */
+#ifdef PLATFORM_LINUX
+	struct tasklet_struct xmit_tasklet;
+#endif
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#ifdef CONFIG_SDIO_TX_TASKLET
+#ifdef PLATFORM_LINUX
+	struct tasklet_struct xmit_tasklet;
+#endif /* PLATFORM_LINUX */
+#else
+	_thread_hdl_	SdioXmitThread;
+	_sema		SdioXmitSema;
+#endif /* CONFIG_SDIO_TX_TASKLET */
+#endif /* CONFIG_SDIO_HCI */
+
+	_queue free_xmitbuf_queue;
+	_queue pending_xmitbuf_queue;
+	u8 *pallocated_xmitbuf;
+	u8 *pxmitbuf;
+	uint free_xmitbuf_cnt;
+
+	_queue free_xmit_extbuf_queue;
+	u8 *pallocated_xmit_extbuf;
+	u8 *pxmit_extbuf;
+	uint free_xmit_extbuf_cnt;
+
+	struct xmit_buf	pcmd_xmitbuf[CMDBUF_MAX];
+	u8   hw_ssn_seq_no;/* mapping to REG_HW_SEQ 0,1,2,3 */
+	u16	nqos_ssn;
+#ifdef CONFIG_TX_EARLY_MODE
+
+#ifdef CONFIG_SDIO_HCI
+#define MAX_AGG_PKT_NUM 20
+#else
+#define MAX_AGG_PKT_NUM 256 /* Max tx ampdu coounts		 */
+#endif
+
+	struct agg_pkt_info agg_pkt[MAX_AGG_PKT_NUM];
+#endif
+
+#ifdef CONFIG_XMIT_ACK
+	int	ack_tx;
+	_mutex ack_tx_mutex;
+	struct submit_ctx ack_tx_ops;
+	u8 seq_no;
+#endif
+
+#ifdef CONFIG_TX_AMSDU
+	_timer amsdu_vo_timer;
+	u8 amsdu_vo_timeout;
+
+	_timer amsdu_vi_timer;
+	u8 amsdu_vi_timeout;
+
+	_timer amsdu_be_timer;
+	u8 amsdu_be_timeout;
+
+	_timer amsdu_bk_timer;
+	u8 amsdu_bk_timeout;
+
+	u32 amsdu_debug_set_timer;
+	u32 amsdu_debug_timeout;
+	u32 amsdu_debug_coalesce_one;
+	u32 amsdu_debug_coalesce_two;
+
+#endif
+#ifdef DBG_TXBD_DESC_DUMP
+	BOOLEAN	 dump_txbd_desc;
+#endif
+	_lock lock_sctx;
+
+};
+
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_cmdxmitframe(p) __rtw_alloc_cmdxmitframe(p, CMDBUF_RSVD)
+#if defined(CONFIG_RTL8192E) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8192ee(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8192ee(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8822B) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8822be(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8822be(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8821C) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8821ce(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8821ce(p, CMDBUF_BEACON)
+#else
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe(p, CMDBUF_BEACON)
+#endif
+
+extern struct xmit_buf *rtw_alloc_xmitbuf_ext(struct xmit_priv *pxmitpriv);
+extern s32 rtw_free_xmitbuf_ext(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+
+extern struct xmit_buf *rtw_alloc_xmitbuf(struct xmit_priv *pxmitpriv);
+extern s32 rtw_free_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+
+void rtw_count_tx_stats(_adapter *padapter, struct xmit_frame *pxmitframe, int sz);
+extern void rtw_update_protection(_adapter *padapter, u8 *ie, uint ie_len);
+static s32 update_attrib_sec_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
+static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
+
+#ifdef CONFIG_WMMPS_STA
+static void update_attrib_trigger_frame_info(_adapter *padapter, struct pkt_attrib *pattrib);
+#endif /* CONFIG_WMMPS_STA */
+
+extern s32 rtw_make_wlanhdr(_adapter *padapter, u8 *hdr, struct pkt_attrib *pattrib);
+extern s32 rtw_put_snap(u8 *data, u16 h_proto);
+
+extern struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv);
+struct xmit_frame *rtw_alloc_xmitframe_ext(struct xmit_priv *pxmitpriv);
+struct xmit_frame *rtw_alloc_xmitframe_once(struct xmit_priv *pxmitpriv);
+extern s32 rtw_free_xmitframe(struct xmit_priv *pxmitpriv, struct xmit_frame *pxmitframe);
+extern void rtw_free_xmitframe_queue(struct xmit_priv *pxmitpriv, _queue *pframequeue);
+struct tx_servq *rtw_get_sta_pending(_adapter *padapter, struct sta_info *psta, sint up, u8 *ac);
+extern s32 rtw_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+extern struct xmit_frame *rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i, sint entry);
+
+extern s32 rtw_xmit_classifier(_adapter *padapter, struct xmit_frame *pxmitframe);
+extern u32 rtw_calculate_wlan_pkt_size_by_attribue(struct pkt_attrib *pattrib);
+#define rtw_wlan_pkt_size(f) rtw_calculate_wlan_pkt_size_by_attribue(&f->attrib)
+extern s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe);
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+extern s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe);
+#endif
+#ifdef CONFIG_TDLS
+extern struct tdls_txmgmt *ptxmgmt;
+s32 rtw_xmit_tdls_coalesce(_adapter *padapter, struct xmit_frame *pxmitframe, struct tdls_txmgmt *ptxmgmt);
+s32 update_tdls_attrib(_adapter *padapter, struct pkt_attrib *pattrib);
+#endif
+s32 _rtw_init_hw_txqueue(struct hw_txqueue *phw_txqueue, u8 ac_tag);
+void _rtw_init_sta_xmit_priv(struct sta_xmit_priv *psta_xmitpriv);
+
+
+s32 rtw_txframes_pending(_adapter *padapter);
+s32 rtw_txframes_sta_ac_pending(_adapter *padapter, struct pkt_attrib *pattrib);
+void rtw_init_hwxmits(struct hw_xmit *phwxmit, sint entry);
+
+
+s32 _rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, _adapter *padapter);
+void _rtw_free_xmit_priv(struct xmit_priv *pxmitpriv);
+
+
+void rtw_alloc_hwxmits(_adapter *padapter);
+void rtw_free_hwxmits(_adapter *padapter);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
+s32 rtw_monitor_xmit_entry(struct sk_buff *skb, struct net_device *ndev);
+#endif
+s32 rtw_xmit_posthandle(_adapter *padapter, struct xmit_frame *pxmitframe, _pkt *pkt);
+s32 rtw_xmit(_adapter *padapter, _pkt **pkt);
+bool xmitframe_hiq_filter(struct xmit_frame *xmitframe);
+#if defined(CONFIG_AP_MODE) || defined(CONFIG_TDLS)
+sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *pxmitframe);
+void stop_sta_xmit(_adapter *padapter, struct sta_info *psta);
+void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta);
+void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta);
+#endif
+
+u8 rtw_get_tx_bw_mode(_adapter *adapter, struct sta_info *sta);
+
+void rtw_get_adapter_tx_rate_bmp_by_bw(_adapter *adapter, u8 bw, u16 *r_bmp_cck_ofdm, u32 *r_bmp_ht, u32 *r_bmp_vht);
+void rtw_update_tx_rate_bmp(struct dvobj_priv *dvobj);
+u16 rtw_get_tx_rate_bmp_cck_ofdm(struct dvobj_priv *dvobj);
+u32 rtw_get_tx_rate_bmp_ht_by_bw(struct dvobj_priv *dvobj, u8 bw);
+u32 rtw_get_tx_rate_bmp_vht_by_bw(struct dvobj_priv *dvobj, u8 bw);
+u8 rtw_get_tx_bw_bmp_of_ht_rate(struct dvobj_priv *dvobj, u8 rate, u8 max_bw);
+u8 rtw_get_tx_bw_bmp_of_vht_rate(struct dvobj_priv *dvobj, u8 rate, u8 max_bw);
+
+u8 query_ra_short_GI(struct sta_info *psta, u8 bw);
+
+u8	qos_acm(u8 acm_mask, u8 priority);
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+void	enqueue_pending_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+void enqueue_pending_xmitbuf_to_head(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+struct xmit_buf	*dequeue_pending_xmitbuf(struct xmit_priv *pxmitpriv);
+struct xmit_buf	*select_and_dequeue_pending_xmitbuf(_adapter *padapter);
+sint	check_pending_xmitbuf(struct xmit_priv *pxmitpriv);
+thread_return	rtw_xmit_thread(thread_context context);
+#endif
+
+#ifdef CONFIG_TX_AMSDU
+extern void rtw_amsdu_vo_timeout_handler(void *FunctionContext);
+extern void rtw_amsdu_vi_timeout_handler(void *FunctionContext);
+extern void rtw_amsdu_be_timeout_handler(void *FunctionContext);
+extern void rtw_amsdu_bk_timeout_handler(void *FunctionContext);
+
+extern u8 rtw_amsdu_get_timer_status(_adapter *padapter, u8 priority);
+extern void rtw_amsdu_set_timer_status(_adapter *padapter, u8 priority, u8 status);
+extern void rtw_amsdu_set_timer(_adapter *padapter, u8 priority);
+extern void rtw_amsdu_cancel_timer(_adapter *padapter, u8 priority);
+
+extern s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitframe, struct xmit_frame *pxmitframe_queue);	
+extern s32 check_amsdu(struct xmit_frame *pxmitframe);
+extern s32 check_amsdu_tx_support(_adapter *padapter);
+extern struct xmit_frame *rtw_get_xframe(struct xmit_priv *pxmitpriv, int *num_frame);
+#endif
+
+#ifdef DBG_TXBD_DESC_DUMP
+void rtw_tx_desc_backup(_adapter *padapter, struct xmit_frame *pxmitframe, u8 desc_size, u8 hwq);
+void rtw_tx_desc_backup_reset(void);
+u8 rtw_get_tx_desc_backup(_adapter *padapter, u8 hwq, struct rtw_tx_desc_backup **pbak);
+#endif
+
+static void do_queue_select(_adapter *padapter, struct pkt_attrib *pattrib);
+u32	rtw_get_ff_hwaddr(struct xmit_frame	*pxmitframe);
+
+#ifdef CONFIG_XMIT_ACK
+int rtw_ack_tx_wait(struct xmit_priv *pxmitpriv, u32 timeout_ms);
+void rtw_ack_tx_done(struct xmit_priv *pxmitpriv, int status);
+#endif /* CONFIG_XMIT_ACK */
+
+enum XMIT_BLOCK_REASON {
+	XMIT_BLOCK_NONE = 0,
+	XMIT_BLOCK_REDLMEM = BIT0, /*LPS-PG*/
+	XMIT_BLOCK_SUSPEND = BIT1, /*WOW*/
+	XMIT_BLOCK_MAX = 0xFF,
+};
+void rtw_init_xmit_block(_adapter *padapter);
+void rtw_deinit_xmit_block(_adapter *padapter);
+
+#ifdef DBG_XMIT_BLOCK
+void dump_xmit_block(void *sel, _adapter *padapter);
+#endif
+void rtw_set_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason);
+void rtw_clr_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason);
+bool rtw_is_xmit_blocked(_adapter *padapter);
+
+/* include after declaring struct xmit_buf, in order to avoid warning */
+#include <xmit_osdep.h>
+
+#endif /* _RTL871X_XMIT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_hal.h
new file mode 100644
index 000000000000..62e7f79d9506
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_hal.h
@@ -0,0 +1,49 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __SDIO_HAL_H__
+#define __SDIO_HAL_H__
+
+void sd_int_dpc(PADAPTER padapter);
+u8 rtw_set_hal_ops(_adapter *padapter);
+
+#ifdef CONFIG_RTL8188E
+void rtl8188es_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8723B
+void rtl8723bs_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8821A
+void rtl8821as_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8192E
+void rtl8192es_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8703B
+void rtl8703bs_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8723D
+void rtl8723ds_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8188F
+void rtl8188fs_set_hal_ops(PADAPTER padapter);
+#endif
+
+#endif /* __SDIO_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops.h
new file mode 100644
index 000000000000..9fc20da272e7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops.h
@@ -0,0 +1,197 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __SDIO_OPS_H__
+#define __SDIO_OPS_H__
+
+
+/* Follow mac team suggestion, default I/O fail return value is 0xFF */
+#define SDIO_ERR_VAL8	0xFF
+#define SDIO_ERR_VAL16	0xFFFF
+#define SDIO_ERR_VAL32	0xFFFFFFFF
+
+#ifdef PLATFORM_LINUX
+#include <sdio_ops_linux.h>
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+#ifdef PLATFORM_OS_XP
+#include <sdio_ops_xp.h>
+struct async_context {
+	PMDL pmdl;
+	PSDBUS_REQUEST_PACKET sdrp;
+	unsigned char *r_buf;
+	unsigned char *padapter;
+};
+#endif
+
+#ifdef PLATFORM_OS_CE
+#include <sdio_ops_ce.h>
+#endif
+
+#endif /* PLATFORM_WINDOWS */
+
+
+extern void sdio_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
+void dump_sdio_card_info(void *sel, struct dvobj_priv *dvobj);
+
+u32 sdio_init(struct dvobj_priv *dvobj);
+void sdio_deinit(struct dvobj_priv *dvobj);
+int sdio_alloc_irq(struct dvobj_priv *dvobj);
+void sdio_free_irq(struct dvobj_priv *dvobj);
+
+#if 0
+extern void sdio_func1cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem);
+extern void sdio_func1cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem);
+#endif
+extern u8 SdioLocalCmd52Read1Byte(PADAPTER padapter, u32 addr);
+extern void SdioLocalCmd52Write1Byte(PADAPTER padapter, u32 addr, u8 v);
+extern s32 _sdio_local_read(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
+extern s32 sdio_local_read(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
+extern s32 _sdio_local_write(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
+extern s32 sdio_local_write(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
+
+u32 _sdio_read32(PADAPTER padapter, u32 addr);
+s32 _sdio_write32(PADAPTER padapter, u32 addr, u32 val);
+
+extern void sd_int_hdl(PADAPTER padapter);
+extern u8 CheckIPSStatus(PADAPTER padapter);
+
+#ifdef CONFIG_RTL8188E
+extern void InitInterrupt8188ESdio(PADAPTER padapter);
+extern void EnableInterrupt8188ESdio(PADAPTER padapter);
+extern void DisableInterrupt8188ESdio(PADAPTER padapter);
+extern void UpdateInterruptMask8188ESdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
+extern u8 HalQueryTxBufferStatus8189ESdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8189ESdio(PADAPTER padapter);
+extern void ClearInterrupt8188ESdio(PADAPTER padapter);
+#endif /* CONFIG_RTL8188E */
+
+#ifdef CONFIG_RTL8821A
+extern void InitInterrupt8821AS(PADAPTER padapter);
+extern void EnableInterrupt8821AS(PADAPTER padapter);
+extern void DisableInterrupt8821AS(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8821AS(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8821ASdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+void ClearInterrupt8821AS(PADAPTER padapter);
+#endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
+#endif /* CONFIG_RTL8821A */
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+#if defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822B)
+u8 rtw_hal_enable_cpwm2(_adapter *adapter);
+#endif
+extern u8 RecvOnePkt(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
+#ifdef CONFIG_RTL8723B
+extern void InitInterrupt8723BSdio(PADAPTER padapter);
+extern void InitSysInterrupt8723BSdio(PADAPTER padapter);
+extern void EnableInterrupt8723BSdio(PADAPTER padapter);
+extern void DisableInterrupt8723BSdio(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8723BSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8723BSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm28723BSdio(PADAPTER padapter);
+extern void ClearInterrupt8723BSdio(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
+#endif
+
+
+#ifdef CONFIG_RTL8192E
+extern void InitInterrupt8192ESdio(PADAPTER padapter);
+extern void EnableInterrupt8192ESdio(PADAPTER padapter);
+extern void DisableInterrupt8192ESdio(PADAPTER padapter);
+extern void UpdateInterruptMask8192ESdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
+extern u8 HalQueryTxBufferStatus8192ESdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8192ESdio(PADAPTER padapter);
+extern void ClearInterrupt8192ESdio(PADAPTER padapter);
+#endif /* CONFIG_RTL8192E */
+
+#ifdef CONFIG_RTL8703B
+extern void InitInterrupt8703BSdio(PADAPTER padapter);
+extern void InitSysInterrupt8703BSdio(PADAPTER padapter);
+extern void EnableInterrupt8703BSdio(PADAPTER padapter);
+extern void DisableInterrupt8703BSdio(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8703BSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8703BSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm28703BSdio(PADAPTER padapter);
+extern void ClearInterrupt8703BSdio(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
+#endif
+
+#ifdef CONFIG_RTL8723D
+extern void InitInterrupt8723DSdio(PADAPTER padapter);
+extern void InitSysInterrupt8723DSdio(PADAPTER padapter);
+extern void EnableInterrupt8723DSdio(PADAPTER padapter);
+extern void DisableInterrupt8723DSdio(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8723DSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8723DSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm28723dSdio(PADAPTER padapter);
+extern void ClearInterrupt8723DSdio(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
+#endif
+
+#ifdef CONFIG_RTL8188F
+extern void InitInterrupt8188FSdio(PADAPTER padapter);
+extern void InitSysInterrupt8188FSdio(PADAPTER padapter);
+extern void EnableInterrupt8188FSdio(PADAPTER padapter);
+extern void DisableInterrupt8188FSdio(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8188FSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8188FSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm28188FSdio(PADAPTER padapter);
+extern void ClearInterrupt8188FSdio(PADAPTER padapter);
+#endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
+#endif
+
+/**
+ * rtw_sdio_get_block_size() - Get block size of SDIO transfer
+ * @d		struct dvobj_priv*
+ *
+ * The unit of return value is byte.
+ */
+static inline u32 rtw_sdio_get_block_size(struct dvobj_priv *d)
+{
+	return d->intf_data.block_transfer_len;
+}
+
+/**
+ * rtw_sdio_cmd53_align_size() - Align size to one CMD53 could complete
+ * @d		struct dvobj_priv*
+ * @len		length to align
+ *
+ * Adjust len to align block size, and the new size could be transfered by one
+ * CMD53.
+ * If len < block size, it would keep original value, otherwise the value
+ * would be rounded up by block size.
+ *
+ * Return adjusted length.
+ */
+static inline size_t rtw_sdio_cmd53_align_size(struct dvobj_priv *d, size_t len)
+{
+	u32 blk_sz;
+
+
+	blk_sz = rtw_sdio_get_block_size(d);
+	if (len <= blk_sz)
+		return len;
+
+	return _RND(len, blk_sz);
+}
+
+#endif /* !__SDIO_OPS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_ce.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_ce.h
new file mode 100644
index 000000000000..d542cb7ea206
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_ce.h
@@ -0,0 +1,49 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _SDIO_OPS_WINCE_H_
+#define _SDIO_OPS_WINCE_H_
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+#include <osdep_intf.h>
+
+
+#ifdef PLATFORM_OS_CE
+
+
+extern u8 sdbus_cmd52r_ce(struct intf_priv *pintfpriv, u32 addr);
+
+
+extern void sdbus_cmd52w_ce(struct intf_priv *pintfpriv, u32 addr, u8 val8);
+
+
+uint sdbus_read_blocks_to_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+
+extern uint sdbus_read_bytes_to_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+
+
+extern uint sdbus_write_blocks_from_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf, u8 async);
+
+extern uint sdbus_write_bytes_from_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+extern u8 sdbus_func1cmd52r_ce(struct intf_priv *pintfpriv, u32 addr);
+extern void sdbus_func1cmd52w_ce(struct intf_priv *pintfpriv, u32 addr, u8 val8);
+extern uint sdbus_read_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern uint sdbus_write_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern void sdio_read_int(_adapter *padapter, u32 addr, u8 sz, void *pdata);
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_linux.h
new file mode 100644
index 000000000000..4bbd8fe7ff68
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_linux.h
@@ -0,0 +1,58 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __SDIO_OPS_LINUX_H__
+#define __SDIO_OPS_LINUX_H__
+
+#ifndef RTW_HALMAC
+u8 sd_f0_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
+void sd_f0_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err);
+
+s32 _sd_cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata);
+s32 _sd_cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata);
+s32 sd_cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata);
+s32 sd_cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata);
+
+u8 _sd_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
+u8 sd_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
+u16 sd_read16(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
+u32 _sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
+u32 sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
+void sd_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err);
+void sd_write16(struct intf_hdl *pintfhdl, u32 addr, u16 v, s32 *err);
+void _sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err);
+void sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err);
+#endif /* RTW_HALMAC */
+
+bool rtw_is_sdio30(_adapter *adapter);
+
+/* The unit of return value is Hz */
+static inline u32 rtw_sdio_get_clock(struct dvobj_priv *d)
+{
+	return d->intf_data.clock;
+}
+
+s32 _sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
+s32 sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
+s32 _sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
+s32 sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
+
+void rtw_sdio_set_irq_thd(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl);
+int __must_check rtw_sdio_raw_read(struct dvobj_priv *d, unsigned int addr,
+				void *buf, size_t len, bool fixed);
+int __must_check rtw_sdio_raw_write(struct dvobj_priv *d, unsigned int addr,
+				void *buf, size_t len, bool fixed);
+
+#endif /* __SDIO_OPS_LINUX_H__ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_xp.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_xp.h
new file mode 100644
index 000000000000..d3d8764d3878
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_ops_xp.h
@@ -0,0 +1,49 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _SDIO_OPS_XP_H_
+#define _SDIO_OPS_XP_H_
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+#include <osdep_intf.h>
+
+
+#ifdef PLATFORM_OS_XP
+
+
+extern u8 sdbus_cmd52r_xp(struct intf_priv *pintfpriv, u32 addr);
+
+
+extern void sdbus_cmd52w_xp(struct intf_priv *pintfpriv, u32 addr, u8 val8);
+
+
+uint sdbus_read_blocks_to_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+
+extern uint sdbus_read_bytes_to_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+
+
+extern uint sdbus_write_blocks_from_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf, u8 async);
+
+extern uint sdbus_write_bytes_from_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+extern u8 sdbus_func1cmd52r_xp(struct intf_priv *pintfpriv, u32 addr);
+extern void sdbus_func1cmd52w_xp(struct intf_priv *pintfpriv, u32 addr, u8 val8);
+extern uint sdbus_read_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern uint sdbus_write_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern void sdio_read_int(_adapter *padapter, u32 addr, u8 sz, void *pdata);
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_osintf.h
new file mode 100644
index 000000000000..7c2abd14d2af
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sdio_osintf.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __SDIO_OSINTF_H__
+#define __SDIO_OSINTF_H__
+
+
+#ifdef PLATFORM_OS_CE
+extern NDIS_STATUS ce_sd_get_dev_hdl(PADAPTER padapter);
+SD_API_STATUS ce_sd_int_callback(SD_DEVICE_HANDLE hDevice, PADAPTER padapter);
+extern void sd_setup_irs(PADAPTER padapter);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sta_info.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sta_info.h
new file mode 100644
index 000000000000..56733a118c95
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/sta_info.h
@@ -0,0 +1,720 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <cmn_info/rtw_sta_info.h>
+
+#define IBSS_START_MAC_ID	2
+#define NUM_STA MACID_NUM_SW_LIMIT
+
+#ifndef CONFIG_RTW_MACADDR_ACL
+	#define CONFIG_RTW_MACADDR_ACL 1
+#endif
+
+#ifndef CONFIG_RTW_PRE_LINK_STA
+	#define CONFIG_RTW_PRE_LINK_STA 0
+#endif
+
+#define NUM_ACL 16
+
+#define RTW_ACL_PERIOD_DEV 0
+#define RTW_ACL_PERIOD_BSS 1
+#define RTW_ACL_PERIOD_NUM 2
+
+#define RTW_ACL_MODE_DISABLED				0
+#define RTW_ACL_MODE_ACCEPT_UNLESS_LISTED	1
+#define RTW_ACL_MODE_DENY_UNLESS_LISTED		2
+#define RTW_ACL_MODE_MAX					3
+
+#if CONFIG_RTW_MACADDR_ACL
+extern const char *const _acl_period_str[RTW_ACL_PERIOD_NUM];
+#define acl_period_str(mode) (((mode) >= RTW_ACL_PERIOD_NUM) ? "INVALID" : _acl_period_str[(mode)])
+extern const char *const _acl_mode_str[RTW_ACL_MODE_MAX];
+#define acl_mode_str(mode) (((mode) >= RTW_ACL_MODE_MAX) ? "INVALID" : _acl_mode_str[(mode)])
+#endif
+
+#ifndef RTW_PRE_LINK_STA_NUM
+	#define RTW_PRE_LINK_STA_NUM 8
+#endif
+
+struct pre_link_sta_node_t {
+	u8 valid;
+	u8 addr[ETH_ALEN];
+};
+
+struct pre_link_sta_ctl_t {
+	_lock lock;
+	u8 num;
+	struct pre_link_sta_node_t node[RTW_PRE_LINK_STA_NUM];
+};
+
+#ifdef CONFIG_TDLS
+#define MAX_ALLOWED_TDLS_STA_NUM	4
+#endif
+
+enum sta_info_update_type {
+	STA_INFO_UPDATE_NONE = 0,
+	STA_INFO_UPDATE_BW = BIT(0),
+	STA_INFO_UPDATE_RATE = BIT(1),
+	STA_INFO_UPDATE_PROTECTION_MODE = BIT(2),
+	STA_INFO_UPDATE_CAP = BIT(3),
+	STA_INFO_UPDATE_HT_CAP = BIT(4),
+	STA_INFO_UPDATE_VHT_CAP = BIT(5),
+	STA_INFO_UPDATE_ALL = STA_INFO_UPDATE_BW
+			      | STA_INFO_UPDATE_RATE
+			      | STA_INFO_UPDATE_PROTECTION_MODE
+			      | STA_INFO_UPDATE_CAP
+			      | STA_INFO_UPDATE_HT_CAP
+			      | STA_INFO_UPDATE_VHT_CAP,
+	STA_INFO_UPDATE_MAX
+};
+
+struct rtw_wlan_acl_node {
+	_list		        list;
+	u8       addr[ETH_ALEN];
+	u8       valid;
+};
+
+struct wlan_acl_pool {
+	int mode;
+	int num;
+	struct rtw_wlan_acl_node aclnode[NUM_ACL];
+	_queue	acl_node_q;
+};
+
+struct	stainfo_stats	{
+	systime last_rx_time;
+
+	u64 rx_mgnt_pkts;
+		u64 rx_beacon_pkts;
+		u64 rx_probereq_pkts;
+		u64 rx_probersp_pkts; /* unicast to self */
+		u64 rx_probersp_bm_pkts;
+		u64 rx_probersp_uo_pkts; /* unicast to others */
+	u64 rx_ctrl_pkts;
+	u64 rx_data_pkts;
+		u64 rx_data_bc_pkts;
+		u64 rx_data_mc_pkts;
+	u64 rx_data_qos_pkts[TID_NUM]; /* unicast only */
+
+	u64	last_rx_mgnt_pkts;
+		u64 last_rx_beacon_pkts;
+		u64 last_rx_probereq_pkts;
+		u64 last_rx_probersp_pkts; /* unicast to self */
+		u64 last_rx_probersp_bm_pkts;
+		u64 last_rx_probersp_uo_pkts; /* unicast to others */
+	u64	last_rx_ctrl_pkts;
+	u64	last_rx_data_pkts;
+		u64 last_rx_data_bc_pkts;
+		u64 last_rx_data_mc_pkts;
+	u64 last_rx_data_qos_pkts[TID_NUM]; /* unicast only */
+
+#ifdef CONFIG_TDLS
+	u64 rx_tdls_disc_rsp_pkts;
+	u64 last_rx_tdls_disc_rsp_pkts;
+#endif
+
+	u64	rx_bytes;
+		u64	rx_bc_bytes;
+		u64	rx_mc_bytes;
+	u64	last_rx_bytes;
+		u64 last_rx_bc_bytes;
+		u64 last_rx_mc_bytes;
+	u64	rx_drops; /* TBD */
+	u16 rx_tp_mbytes;
+
+	u64	tx_pkts;
+	u64	last_tx_pkts;
+
+	u64	tx_bytes;
+	u64	last_tx_bytes;
+	u64 tx_drops; /* TBD */
+	u16 tx_tp_mbytes;
+
+	/* unicast only */
+	u64 last_rx_data_uc_pkts; /* For Read & Clear requirement in proc_get_rx_stat() */
+	u32 duplicate_cnt;	/* Read & Clear, in proc_get_rx_stat() */
+	u32 rxratecnt[128];	/* Read & Clear, in proc_get_rx_stat() */
+	u32 tx_ok_cnt;		/* Read & Clear, in proc_get_tx_stat() */
+	u32 tx_fail_cnt;	/* Read & Clear, in proc_get_tx_stat() */
+	u32 tx_retry_cnt;	/* Read & Clear, in proc_get_tx_stat() */
+};
+
+#ifndef DBG_SESSION_TRACKER
+#define DBG_SESSION_TRACKER 0
+#endif
+
+/* session tracker status */
+#define ST_STATUS_NONE		0
+#define ST_STATUS_CHECK		BIT0
+#define ST_STATUS_ESTABLISH	BIT1
+#define ST_STATUS_EXPIRE	BIT2
+
+#define ST_EXPIRE_MS (10 * 1000)
+
+struct session_tracker {
+	_list list; /* session_tracker_queue */
+	u32 local_naddr;
+	u16 local_port;
+	u32 remote_naddr;
+	u16 remote_port;
+	systime set_time;
+	u8 status;
+};
+
+/* session tracker cmd */
+#define ST_CMD_ADD 0
+#define ST_CMD_DEL 1
+#define ST_CMD_CHK 2
+
+struct st_cmd_parm {
+	u8 cmd;
+	struct sta_info *sta;
+	u32 local_naddr; /* TODO: IPV6 */
+	u16 local_port;
+	u32 remote_naddr; /* TODO: IPV6 */
+	u16 remote_port;
+};
+
+typedef bool (*st_match_rule)(_adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
+
+struct st_register {
+	u8 s_proto;
+	st_match_rule rule;
+};
+
+#define SESSION_TRACKER_REG_ID_WFD 0
+#define SESSION_TRACKER_REG_ID_NUM 1
+
+struct st_ctl_t {
+	struct st_register reg[SESSION_TRACKER_REG_ID_NUM];
+	_queue tracker_q;
+};
+
+void rtw_st_ctl_init(struct st_ctl_t *st_ctl);
+void rtw_st_ctl_deinit(struct st_ctl_t *st_ctl);
+void rtw_st_ctl_register(struct st_ctl_t *st_ctl, u8 st_reg_id, struct st_register *reg);
+void rtw_st_ctl_unregister(struct st_ctl_t *st_ctl, u8 st_reg_id);
+bool rtw_st_ctl_chk_reg_s_proto(struct st_ctl_t *st_ctl, u8 s_proto);
+bool rtw_st_ctl_chk_reg_rule(struct st_ctl_t *st_ctl, _adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
+void rtw_st_ctl_rx(struct sta_info *sta, u8 *ehdr_pos);
+void dump_st_ctl(void *sel, struct st_ctl_t *st_ctl);
+
+#ifdef CONFIG_TDLS
+struct TDLS_PeerKey {
+	u8 kck[16]; /* TPK-KCK */
+	u8 tk[16]; /* TPK-TK; only CCMP will be used */
+} ;
+#endif /* CONFIG_TDLS */
+
+#ifdef DBG_RX_DFRAME_RAW_DATA
+struct sta_recv_dframe_info {
+
+	u8 sta_data_rate;
+	u8 sta_sgi;
+	u8 sta_bw_mode;
+	s8 sta_mimo_signal_strength[4];
+	s8 sta_RxPwr[4];
+	u8 sta_ofdm_snr[4];
+};
+#endif
+
+#ifdef CONFIG_RTW_MESH
+struct mesh_plink_ent;
+struct rtw_ewma_err_rate {
+	unsigned long internal;
+};
+
+/* Mesh airtime link metrics parameters */
+struct rtw_atlm_param {
+	struct rtw_ewma_err_rate err_rate; /* Now is PACKET error rate */
+	u16 data_rate; /* The unit is 100Kbps */
+	u16 total_pkt;
+	u16 overhead; /* Channel access overhead */
+};
+#endif
+
+struct sta_info {
+
+	_lock	lock;
+	_list	list; /* free_sta_queue */
+	_list	hash_list; /* sta_hash */
+	/* _list asoc_list; */ /* 20061114 */
+	/* _list sleep_list; */ /* sleep_q */
+	/* _list wakeup_list; */ /* wakeup_q */
+	_adapter *padapter;
+	struct cmn_sta_info cmn;
+
+	struct sta_xmit_priv sta_xmitpriv;
+	struct sta_recv_priv sta_recvpriv;
+
+#ifdef DBG_RX_DFRAME_RAW_DATA
+	struct sta_recv_dframe_info  sta_dframe_info;
+	struct sta_recv_dframe_info  sta_dframe_info_bmc;
+#endif
+	_queue sleep_q;
+	unsigned int sleepq_len;
+
+	uint state;
+	uint qos_option;
+	u16 hwseq;
+
+#ifdef CONFIG_RTW_80211K
+	u8 rm_en_cap[5];
+	u8 rm_diag_token;
+#endif /* CONFIG_RTW_80211K */
+
+	uint	ieee8021x_blocked;	/* 0: allowed, 1:blocked */
+	uint	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. */
+#ifdef CONFIG_RTW_MESH
+	/* peer's GTK, RX only */
+	u8 group_privacy;
+	u8 gtk_bmp;
+	union Keytype gtk;
+	union pn48 gtk_pn;
+	#ifdef CONFIG_IEEE80211W
+	/* peer's IGTK, RX only */
+	u8 igtk_bmp;
+	u8 igtk_id;
+	union Keytype igtk;
+	union pn48 igtk_pn;
+	#endif /* CONFIG_IEEE80211W */
+#endif /* CONFIG_RTW_MESH */
+#ifdef CONFIG_GTK_OL
+	u8 kek[RTW_KEK_LEN];
+	u8 kck[RTW_KCK_LEN];
+	u8 replay_ctr[RTW_REPLAY_CTR_LEN];
+#endif /* CONFIG_GTK_OL */
+#ifdef CONFIG_IEEE80211W
+	_timer dot11w_expire_timer;
+#endif /* CONFIG_IEEE80211W */
+
+	u8	bssrateset[16];
+	u32	bssratelen;
+
+	u8	cts2self;
+	u8	rtsen;
+
+	u8	init_rate;
+	u8	wireless_mode;	/* NETWORK_TYPE */
+
+	struct stainfo_stats sta_stats;
+
+#ifdef CONFIG_TDLS
+	u32	tdls_sta_state;
+	u8	SNonce[32];
+	u8	ANonce[32];
+	u32	TDLS_PeerKey_Lifetime;
+	u32	TPK_count;
+	_timer	TPK_timer;
+	struct TDLS_PeerKey	tpk;
+#ifdef CONFIG_TDLS_CH_SW
+	u16	ch_switch_time;
+	u16	ch_switch_timeout;
+	/* u8	option; */
+	_timer	ch_sw_timer;
+	_timer	delay_timer;
+	_timer	stay_on_base_chnl_timer;
+	_timer	ch_sw_monitor_timer;
+#endif
+	_timer handshake_timer;
+	u8 alive_count;
+	_timer	pti_timer;
+	u8	TDLS_RSNIE[20];	/* Save peer's RSNIE, used for sending TDLS_SETUP_RSP */
+#endif /* CONFIG_TDLS */
+
+	/* for A-MPDU TX, ADDBA timeout check	 */
+	_timer addba_retry_timer;
+
+	/* for A-MPDU Rx reordering buffer control */
+	struct recv_reorder_ctrl recvreorder_ctrl[TID_NUM];
+	ATOMIC_T continual_no_rx_packet[TID_NUM];
+	/* for A-MPDU Tx */
+	/* unsigned char		ampdu_txen_bitmap; */
+	u16	BA_starting_seqctrl[16];
+
+
+#ifdef CONFIG_80211N_HT
+	struct ht_priv	htpriv;
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+	struct vht_priv	vhtpriv;
+#endif
+
+	/* 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 */
+
+	unsigned int expire_to;
+
+#ifdef CONFIG_AP_MODE
+
+	_list asoc_list;
+	_list auth_list;
+
+	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;
+#ifdef CONFIG_RTW_80211R
+	u8 ft_pairwise_key_installed;
+#endif
+
+#ifdef CONFIG_NATIVEAP_MLME
+	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;
+	u8 ht_40mhz_intolerant;
+#endif /* CONFIG_NATIVEAP_MLME */
+
+#ifdef CONFIG_ATMEL_RC_PATCH
+	u8 flag_atmel_rc;
+#endif
+
+	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;
+
+#ifdef CONFIG_P2P
+	/* p2p priv data */
+	u8 is_p2p_device;
+	u8 p2p_status_code;
+
+	/* p2p client info */
+	u8 dev_addr[ETH_ALEN];
+	/* u8 iface_addr[ETH_ALEN]; */ /* = hwaddr[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];
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_WFD
+	u8 op_wfd_mode;
+#endif
+
+#ifdef CONFIG_TX_MCAST2UNI
+	u8 under_exist_checking;
+#endif /* CONFIG_TX_MCAST2UNI */
+
+	u8 keep_alive_trycnt;
+
+#ifdef CONFIG_AUTO_AP_MODE
+	u8 isrc; /* this device is rc */
+	u16 pid; /* pairing id */
+#endif
+
+#endif /* CONFIG_AP_MODE	 */
+
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink;
+
+	u8 local_mps;
+	u8 peer_mps;
+	u8 nonpeer_mps;
+
+	struct rtw_atlm_param metrics;
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+	u8 *passoc_req;
+	u32 assoc_req_len;
+#endif
+
+	u8		IOTPeer;			/* Enum value.	HT_IOT_PEER_E */
+#ifdef CONFIG_LPS_PG
+	u8		lps_pg_rssi_lv;
+#endif
+
+	/* To store the sequence number of received management frame */
+	u16 RxMgmtFrameSeqNum;
+
+	struct st_ctl_t st_ctl;
+	u8 max_agg_num_minimal_record; /*keep minimal tx desc max_agg_num setting*/
+	u8 curr_rx_rate;
+	u8 curr_rx_rate_bmc;
+};
+
+#ifdef CONFIG_RTW_MESH
+#define STA_SET_MESH_PLINK(sta, link) (sta)->plink = link
+#else
+#define STA_SET_MESH_PLINK(sta, link) do {} while (0)
+#endif
+
+#define sta_tx_pkts(sta) \
+	(sta->sta_stats.tx_pkts)
+
+#define sta_last_tx_pkts(sta) \
+	(sta->sta_stats.last_tx_pkts)
+
+#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_data_uc_pkts(sta) (sta->sta_stats.rx_data_pkts - sta->sta_stats.rx_data_bc_pkts - sta->sta_stats.rx_data_mc_pkts)
+#define sta_last_rx_data_uc_pkts(sta) (sta->sta_stats.last_rx_data_pkts - sta->sta_stats.last_rx_data_bc_pkts - sta->sta_stats.last_rx_data_mc_pkts)
+
+#define sta_rx_data_qos_pkts(sta, i) \
+	(sta->sta_stats.rx_data_qos_pkts[i])
+
+#define sta_last_rx_data_qos_pkts(sta, i) \
+	(sta->sta_stats.last_rx_data_qos_pkts[i])
+
+#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 { \
+		int __i; \
+		\
+		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; \
+		sta->sta_stats.last_rx_data_bc_pkts = sta->sta_stats.rx_data_bc_pkts; \
+		sta->sta_stats.last_rx_data_mc_pkts = sta->sta_stats.rx_data_mc_pkts; \
+		for (__i = 0; __i < TID_NUM; __i++) \
+			sta->sta_stats.last_rx_data_qos_pkts[__i] = sta->sta_stats.rx_data_qos_pkts[__i]; \
+	} 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)"
+
+#define sta_rx_uc_bytes(sta) (sta->sta_stats.rx_bytes - sta->sta_stats.rx_bc_bytes - sta->sta_stats.rx_mc_bytes)
+#define sta_last_rx_uc_bytes(sta) (sta->sta_stats.last_rx_bytes - sta->sta_stats.last_rx_bc_bytes - sta->sta_stats.last_rx_mc_bytes)
+
+#ifdef CONFIG_WFD
+#define STA_OP_WFD_MODE(sta) (sta)->op_wfd_mode
+#define STA_SET_OP_WFD_MODE(sta, mode) (sta)->op_wfd_mode = (mode)
+#else
+#define STA_OP_WFD_MODE(sta) 0
+#define STA_SET_OP_WFD_MODE(sta, mode) do {} while (0)
+#endif
+
+#define AID_BMP_LEN(max_aid) ((max_aid + 1) / 8 + (((max_aid + 1) % 8) ? 1 : 0))
+
+struct	sta_priv {
+
+	u8 *pallocated_stainfo_buf;
+	u8 *pstainfo_buf;
+	_queue	free_sta_queue;
+
+	_lock sta_hash_lock;
+	_list   sta_hash[NUM_STA];
+	int asoc_sta_count;
+	_queue sleep_q;
+	_queue wakeup_q;
+
+	_adapter *padapter;
+
+	u32 adhoc_expire_to;
+
+#ifdef CONFIG_AP_MODE
+	_list asoc_list;
+	_list auth_list;
+	_lock asoc_list_lock;
+	_lock 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
+	*/
+	struct sta_info **sta_aid;
+	u16 max_aid;
+	u16 started_aid; /* started AID for allocation search */
+	bool rr_aid; /* round robin AID allocation, will modify started_aid */
+	u8 aid_bmp_len; /* in byte */
+	u8 *sta_dz_bitmap;
+	u8 *tim_bitmap;
+
+	u16 max_num_sta;
+
+#if CONFIG_RTW_MACADDR_ACL
+	struct wlan_acl_pool acl_list[RTW_ACL_PERIOD_NUM];
+#endif
+
+	#if CONFIG_RTW_PRE_LINK_STA
+	struct pre_link_sta_ctl_t pre_link_sta_ctl;
+	#endif
+
+#endif /* CONFIG_AP_MODE */
+
+#ifdef CONFIG_ATMEL_RC_PATCH
+	u8 atmel_rc_pattern[6];
+#endif
+	u8 c2h_sta_mac[ETH_ALEN];
+	u8 c2h_adapter_id;
+	struct submit_ctx *gotc2h;
+};
+
+
+__inline static 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;
+}
+
+
+extern u32	_rtw_init_sta_priv(struct sta_priv *pstapriv);
+extern u32	_rtw_free_sta_priv(struct sta_priv *pstapriv);
+
+#define stainfo_offset_valid(offset) (offset < NUM_STA && offset >= 0)
+int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta);
+struct sta_info *rtw_get_stainfo_by_offset(struct sta_priv *stapriv, int offset);
+
+extern struct sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, const u8 *hwaddr);
+extern u32	rtw_free_stainfo(_adapter *padapter , struct sta_info *psta);
+extern void rtw_free_all_stainfo(_adapter *padapter);
+extern struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, const u8 *hwaddr);
+extern u32 rtw_init_bcmc_stainfo(_adapter *padapter);
+extern struct sta_info *rtw_get_bcmc_stainfo(_adapter *padapter);
+
+#ifdef CONFIG_AP_MODE
+u16 rtw_aid_alloc(_adapter *adapter, struct sta_info *sta);
+void dump_aid_status(void *sel, _adapter *adapter);
+#endif
+
+#if CONFIG_RTW_MACADDR_ACL
+extern u8 rtw_access_ctrl(_adapter *adapter, const u8 *mac_addr);
+void dump_macaddr_acl(void *sel, _adapter *adapter);
+#endif
+
+bool rtw_is_pre_link_sta(struct sta_priv *stapriv, u8 *addr);
+#if CONFIG_RTW_PRE_LINK_STA
+struct sta_info *rtw_pre_link_sta_add(struct sta_priv *stapriv, u8 *hwaddr);
+void rtw_pre_link_sta_del(struct sta_priv *stapriv, u8 *hwaddr);
+void rtw_pre_link_sta_ctl_reset(struct sta_priv *stapriv);
+void rtw_pre_link_sta_ctl_init(struct sta_priv *stapriv);
+void rtw_pre_link_sta_ctl_deinit(struct sta_priv *stapriv);
+void dump_pre_link_sta_ctl(void *sel, struct sta_priv *stapriv);
+#endif /* CONFIG_RTW_PRE_LINK_STA */
+
+#endif /* _STA_INFO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_hal.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_hal.h
new file mode 100644
index 000000000000..a5af048b4198
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_hal.h
@@ -0,0 +1,62 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL_H__
+#define __USB_HAL_H__
+
+int usb_init_recv_priv(_adapter *padapter, u16 ini_in_buf_sz);
+void usb_free_recv_priv(_adapter *padapter, u16 ini_in_buf_sz);
+#ifdef CONFIG_FW_C2H_REG
+void usb_c2h_hisr_hdl(_adapter *adapter, u8 *buf);
+#endif
+
+u8 rtw_set_hal_ops(_adapter *padapter);
+
+#ifdef CONFIG_RTL8188E
+void rtl8188eu_set_hal_ops(_adapter *padapter);
+#endif
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+void rtl8812au_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8192E
+void rtl8192eu_set_hal_ops(_adapter *padapter);
+#endif
+
+
+#ifdef CONFIG_RTL8723B
+void rtl8723bu_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8814A
+void rtl8814au_set_hal_ops(_adapter *padapter);
+#endif /* CONFIG_RTL8814A */
+
+#ifdef CONFIG_RTL8188F
+void rtl8188fu_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8703B
+void rtl8703bu_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8723D
+void rtl8723du_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_INTEL_PROXIM
+extern _adapter  *rtw_usb_get_sw_pointer(void);
+#endif /* CONFIG_INTEL_PROXIM */
+#endif /* __USB_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_ops.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_ops.h
new file mode 100644
index 000000000000..a0238f142dd8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_ops.h
@@ -0,0 +1,128 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#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
+#define REALTEK_USB_IN_INT_EP_IDX	1
+
+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)
+
+#ifdef PLATFORM_LINUX
+#include <usb_ops_linux.h>
+#endif /* PLATFORM_LINUX */
+
+#ifdef CONFIG_RTL8188E
+void rtl8188eu_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8188eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+#endif
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+void rtl8812au_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8812au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+#endif
+
+#ifdef CONFIG_RTL8814A
+void rtl8814au_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8814au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+#endif /* CONFIG_RTL8814 */
+
+#ifdef CONFIG_RTL8192E
+void rtl8192eu_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8192eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+
+#endif
+
+#ifdef CONFIG_RTL8188F
+void rtl8188fu_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8188fu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+#endif
+
+#ifdef CONFIG_RTL8723B
+void rtl8723bu_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8723bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+#endif
+
+#ifdef CONFIG_RTL8703B
+void rtl8703bu_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8703bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif /* CONFIG_SUPPORT_USB_INT */
+#endif /* CONFIG_RTL8703B */
+
+void usb_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
+
+#ifdef CONFIG_RTL8723D
+void rtl8723du_set_hw_type(struct dvobj_priv *pdvobj);
+void rtl8723du_set_intf_ops(struct _io_ops *pops);
+void rtl8723du_recv_tasklet(void *priv);
+void rtl8723du_xmit_tasklet(void *priv);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8723du(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif /* CONFIG_SUPPORT_USB_INT */
+#endif /* CONFIG_RTL8723D */
+
+enum RTW_USB_SPEED {
+	RTW_USB_SPEED_UNKNOWN	= 0,
+	RTW_USB_SPEED_1_1	= 1,
+	RTW_USB_SPEED_2		= 2,
+	RTW_USB_SPEED_3		= 3,
+};
+
+#define IS_FULL_SPEED_USB(Adapter)	(adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_1_1)
+#define IS_HIGH_SPEED_USB(Adapter)	(adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_2)
+#define IS_SUPER_SPEED_USB(Adapter)	(adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_3)
+
+#define USB_SUPER_SPEED_BULK_SIZE	1024	/* usb 3.0 */
+#define USB_HIGH_SPEED_BULK_SIZE	512		/* usb 2.0 */
+#define USB_FULL_SPEED_BULK_SIZE	64		/* usb 1.1 */
+
+static inline u8 rtw_usb_bulk_size_boundary(_adapter *padapter, int buf_len)
+{
+	u8 rst = _TRUE;
+
+	if (IS_SUPER_SPEED_USB(padapter))
+		rst = (0 == (buf_len) % USB_SUPER_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
+	else if (IS_HIGH_SPEED_USB(padapter))
+		rst = (0 == (buf_len) % USB_HIGH_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
+	else
+		rst = (0 == (buf_len) % USB_FULL_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
+	return rst;
+}
+
+
+#endif /* __USB_OPS_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_ops_linux.h
new file mode 100644
index 000000000000..bf59ca0fa51a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_ops_linux.h
@@ -0,0 +1,98 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 FW_START_ADDRESS	0x1000
+
+#define RTW_USB_CONTROL_MSG_TIMEOUT_TEST	10/* ms */
+#define RTW_USB_CONTROL_MSG_TIMEOUT	500/* ms */
+
+#define RECV_BULK_IN_ADDR		0x80/* assign by drv, not real address */
+#define RECV_INT_IN_ADDR		0x81/* assign by drv, not real address */
+
+#define INTERRUPT_MSG_FORMAT_LEN 60
+
+#if defined(CONFIG_VENDOR_REQ_RETRY) && defined(CONFIG_USB_VENDOR_REQ_MUTEX)
+	/* vendor req retry should be in the situation when each vendor req is atomically submitted from others */
+	#define MAX_USBCTRL_VENDORREQ_TIMES	10
+#else
+	#define MAX_USBCTRL_VENDORREQ_TIMES	1
+#endif
+
+#define RTW_USB_BULKOUT_TIMEOUT	5000/* ms */
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 5, 0)) || (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 18))
+#define _usbctrl_vendorreq_async_callback(urb, regs)	_usbctrl_vendorreq_async_callback(urb)
+#define usb_bulkout_zero_complete(purb, regs)	usb_bulkout_zero_complete(purb)
+#define usb_write_mem_complete(purb, regs)	usb_write_mem_complete(purb)
+#define usb_write_port_complete(purb, regs)	usb_write_port_complete(purb)
+#define usb_read_port_complete(purb, regs)	usb_read_port_complete(purb)
+#define usb_read_interrupt_complete(purb, regs)	usb_read_interrupt_complete(purb)
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 12))
+#define rtw_usb_control_msg(dev, pipe, request, requesttype, value, index, data, size, timeout_ms) \
+	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), (data), (size), (timeout_ms))
+#define rtw_usb_bulk_msg(usb_dev, pipe, data, len, actual_length, timeout_ms) \
+	usb_bulk_msg((usb_dev), (pipe), (data), (len), (actual_length), (timeout_ms))
+#else
+#define rtw_usb_control_msg(dev, pipe, request, requesttype, value, index, data, size, timeout_ms) \
+	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), (data), (size), \
+		((timeout_ms) == 0) || ((timeout_ms) * HZ / 1000 > 0) ? ((timeout_ms) * HZ / 1000) : 1)
+#define rtw_usb_bulk_msg(usb_dev, pipe, data, len, actual_length, timeout_ms) \
+	usb_bulk_msg((usb_dev), (pipe), (data), (len), (actual_length), \
+		((timeout_ms) == 0) || ((timeout_ms) * HZ / 1000 > 0) ? ((timeout_ms) * HZ / 1000) : 1)
+#endif
+
+
+#ifdef CONFIG_USB_SUPPORT_ASYNC_VDN_REQ
+int usb_async_write8(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+int usb_async_write16(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+int usb_async_write32(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+#endif /* CONFIG_USB_SUPPORT_ASYNC_VDN_REQ */
+
+unsigned int ffaddr2pipehdl(struct dvobj_priv *pdvobj, u32 addr);
+
+void usb_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem);
+void usb_write_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem);
+
+void usb_read_port_cancel(struct intf_hdl *pintfhdl);
+
+u32 usb_write_port(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem);
+void usb_write_port_cancel(struct intf_hdl *pintfhdl);
+
+int usbctrl_vendorreq(struct intf_hdl *pintfhdl, u8 request, u16 value, u16 index, void *pdata, u16 len, u8 requesttype);
+#ifdef CONFIG_USB_SUPPORT_ASYNC_VDN_REQ
+int _usbctrl_vendorreq_async_write(struct usb_device *udev, u8 request,
+		u16 value, u16 index, void *pdata, u16 len, u8 requesttype);
+#endif /* CONFIG_USB_SUPPORT_ASYNC_VDN_REQ */
+
+u8 usb_read8(struct intf_hdl *pintfhdl, u32 addr);
+u16 usb_read16(struct intf_hdl *pintfhdl, u32 addr);
+u32 usb_read32(struct intf_hdl *pintfhdl, u32 addr);
+int usb_write8(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+int usb_write16(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+int usb_write32(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+int usb_writeN(struct intf_hdl *pintfhdl, u32 addr, u32 length, u8 *pdata);
+u32 usb_read_port(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem);
+void usb_recv_tasklet(void *priv);
+
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+void usb_read_interrupt_complete(struct urb *purb, struct pt_regs *regs);
+u32 usb_read_interrupt(struct intf_hdl *pintfhdl, u32 addr);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_osintf.h
new file mode 100644
index 000000000000..7e5feed174de
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_osintf.h
@@ -0,0 +1,26 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_OSINTF_H
+#define __USB_OSINTF_H
+
+#include <usb_vendor_req.h>
+
+#define USBD_HALTED(Status) ((ULONG)(Status) >> 30 == 3)
+
+
+u8 usbvendorrequest(struct dvobj_priv *pdvobjpriv, RT_USB_BREQUEST brequest, RT_USB_WVALUE wvalue, u8 windex, void *data, u8 datalen, u8 isdirectionin);
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_vendor_req.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_vendor_req.h
new file mode 100644
index 000000000000..a003bfb8cd2a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/usb_vendor_req.h
@@ -0,0 +1,56 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_VENDOR_REQUEST_H_
+#define _USB_VENDOR_REQUEST_H_
+
+/* 4	Set/Get Register related wIndex/Data */
+#define	RT_USB_RESET_MASK_OFF		0
+#define	RT_USB_RESET_MASK_ON		1
+#define	RT_USB_SLEEP_MASK_OFF		0
+#define	RT_USB_SLEEP_MASK_ON		1
+#define	RT_USB_LDO_ON				1
+#define	RT_USB_LDO_OFF				0
+
+/* 4	Set/Get SYSCLK related	wValue or Data */
+#define	RT_USB_SYSCLK_32KHZ		0
+#define	RT_USB_SYSCLK_40MHZ		1
+#define	RT_USB_SYSCLK_60MHZ		2
+
+
+typedef enum _RT_USB_BREQUEST {
+	RT_USB_SET_REGISTER		= 1,
+	RT_USB_SET_SYSCLK		= 2,
+	RT_USB_GET_SYSCLK		= 3,
+	RT_USB_GET_REGISTER		= 4
+} RT_USB_BREQUEST;
+
+
+typedef enum _RT_USB_WVALUE {
+	RT_USB_RESET_MASK	=	1,
+	RT_USB_SLEEP_MASK	=	2,
+	RT_USB_USB_HRCPWM	=	3,
+	RT_USB_LDO			=	4,
+	RT_USB_BOOT_TYPE	=	5
+} RT_USB_WVALUE;
+
+
+#if 0
+BOOLEAN usbvendorrequest(PCE_USB_DEVICE	CEdevice, RT_USB_BREQUEST bRequest, RT_USB_WVALUE wValue, UCHAR wIndex, PVOID Data, UCHAR DataLength, BOOLEAN isDirectionIn);
+BOOLEAN CEusbGetStatusRequest(PCE_USB_DEVICE CEdevice, IN USHORT Op, IN USHORT Index, PVOID Data);
+BOOLEAN CEusbFeatureRequest(PCE_USB_DEVICE CEdevice, IN USHORT Op, IN USHORT FeatureSelector, IN USHORT Index);
+BOOLEAN CEusbGetDescriptorRequest(PCE_USB_DEVICE CEdevice, IN short urbLength, IN UCHAR DescriptorType, IN UCHAR Index, IN USHORT LanguageId, IN PVOID  TransferBuffer, IN ULONG TransferBufferLength);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/wifi.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/wifi.h
new file mode 100644
index 000000000000..62d55fb2dfc8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/wifi.h
@@ -0,0 +1,1414 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#ifdef BIT
+/* #error	"BIT define occurred earlier elsewhere!\n" */
+#undef BIT
+#endif
+#define BIT(x)	(1 << (x))
+
+
+#define WLAN_ETHHDR_LEN		14
+#define WLAN_ETHADDR_LEN	6
+#define WLAN_IEEE_OUI_LEN	3
+#define WLAN_ADDR_LEN		6
+#define WLAN_CRC_LEN		4
+#define WLAN_BSSID_LEN		6
+#define WLAN_BSS_TS_LEN		8
+#define WLAN_HDR_A3_LEN		24
+#define WLAN_HDR_A4_LEN		30
+#define WLAN_HDR_A3_QOS_LEN	26
+#define WLAN_HDR_A4_QOS_LEN	32
+#define WLAN_SSID_MAXLEN	32
+#define WLAN_DATA_MAXLEN	2312
+
+#define WLAN_A3_PN_OFFSET	24
+#define WLAN_A4_PN_OFFSET	30
+
+#define WLAN_MIN_ETHFRM_LEN	60
+#define WLAN_MAX_ETHFRM_LEN	1514
+#define WLAN_ETHHDR_LEN		14
+#define WLAN_WMM_LEN		24
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+#define WLAN_MAX_VENDOR_IE_LEN 255
+#define WLAN_MAX_VENDOR_IE_NUM 5
+#define WIFI_BEACON_VENDOR_IE_BIT BIT(0)
+#define WIFI_PROBEREQ_VENDOR_IE_BIT BIT(1)
+#define WIFI_PROBERESP_VENDOR_IE_BIT BIT(2)
+#define WIFI_ASSOCREQ_VENDOR_IE_BIT BIT(3)
+#define WIFI_ASSOCRESP_VENDOR_IE_BIT BIT(4)
+#endif
+
+#define P80211CAPTURE_VERSION	0x80211001
+
+/* 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 */
+
+#ifdef GREEN_HILL
+#pragma pack(1)
+#endif
+
+enum WIFI_FRAME_TYPE {
+	WIFI_MGT_TYPE  =	(0),
+	WIFI_CTRL_TYPE =	(BIT(2)),
+	WIFI_DATA_TYPE =	(BIT(3)),
+	WIFI_QOS_DATA_TYPE	= (BIT(7) | BIT(3)),	/* !< QoS Data	 */
+};
+
+enum WIFI_FRAME_SUBTYPE {
+
+	/* below is for mgt frame */
+	WIFI_ASSOCREQ       = (0 | WIFI_MGT_TYPE),
+	WIFI_ASSOCRSP       = (BIT(4) | WIFI_MGT_TYPE),
+	WIFI_REASSOCREQ     = (BIT(5) | WIFI_MGT_TYPE),
+	WIFI_REASSOCRSP     = (BIT(5) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_PROBEREQ       = (BIT(6) | WIFI_MGT_TYPE),
+	WIFI_PROBERSP       = (BIT(6) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_BEACON         = (BIT(7) | WIFI_MGT_TYPE),
+	WIFI_ATIM           = (BIT(7) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_DISASSOC       = (BIT(7) | BIT(5) | WIFI_MGT_TYPE),
+	WIFI_AUTH           = (BIT(7) | BIT(5) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_DEAUTH         = (BIT(7) | BIT(6) | WIFI_MGT_TYPE),
+	WIFI_ACTION         = (BIT(7) | BIT(6) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_ACTION_NOACK = (BIT(7) | BIT(6) | BIT(5) | WIFI_MGT_TYPE),
+
+	/* below is for control frame */
+	WIFI_BF_REPORT_POLL = (BIT(6) | WIFI_CTRL_TYPE),
+	WIFI_NDPA         = (BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
+	WIFI_BAR            = (BIT(7) | WIFI_CTRL_TYPE),
+	WIFI_PSPOLL         = (BIT(7) | BIT(5) | WIFI_CTRL_TYPE),
+	WIFI_RTS            = (BIT(7) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
+	WIFI_CTS            = (BIT(7) | BIT(6) | WIFI_CTRL_TYPE),
+	WIFI_ACK            = (BIT(7) | BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
+	WIFI_CFEND          = (BIT(7) | BIT(6) | BIT(5) | WIFI_CTRL_TYPE),
+	WIFI_CFEND_CFACK    = (BIT(7) | BIT(6) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
+
+	/* below is for data frame */
+	WIFI_DATA           = (0 | WIFI_DATA_TYPE),
+	WIFI_DATA_CFACK     = (BIT(4) | WIFI_DATA_TYPE),
+	WIFI_DATA_CFPOLL    = (BIT(5) | WIFI_DATA_TYPE),
+	WIFI_DATA_CFACKPOLL = (BIT(5) | BIT(4) | WIFI_DATA_TYPE),
+	WIFI_DATA_NULL      = (BIT(6) | WIFI_DATA_TYPE),
+	WIFI_CF_ACK         = (BIT(6) | BIT(4) | WIFI_DATA_TYPE),
+	WIFI_CF_POLL        = (BIT(6) | BIT(5) | WIFI_DATA_TYPE),
+	WIFI_CF_ACKPOLL     = (BIT(6) | BIT(5) | BIT(4) | WIFI_DATA_TYPE),
+	WIFI_QOS_DATA_NULL	= (BIT(6) | WIFI_QOS_DATA_TYPE),
+};
+
+enum WIFI_REASON_CODE	{
+	_RSON_RESERVED_					= 0,
+	_RSON_UNSPECIFIED_				= 1,
+	_RSON_AUTH_NO_LONGER_VALID_		= 2,
+	_RSON_DEAUTH_STA_LEAVING_		= 3,
+	_RSON_INACTIVITY_				= 4,
+	_RSON_UNABLE_HANDLE_			= 5,
+	_RSON_CLS2_						= 6,
+	_RSON_CLS3_						= 7,
+	_RSON_DISAOC_STA_LEAVING_		= 8,
+	_RSON_ASOC_NOT_AUTH_			= 9,
+
+	/* WPA reason */
+	_RSON_INVALID_IE_				= 13,
+	_RSON_MIC_FAILURE_				= 14,
+	_RSON_4WAY_HNDSHK_TIMEOUT_		= 15,
+	_RSON_GROUP_KEY_UPDATE_TIMEOUT_	= 16,
+	_RSON_DIFF_IE_					= 17,
+	_RSON_MLTCST_CIPHER_NOT_VALID_	= 18,
+	_RSON_UNICST_CIPHER_NOT_VALID_	= 19,
+	_RSON_AKMP_NOT_VALID_			= 20,
+	_RSON_UNSUPPORT_RSNE_VER_		= 21,
+	_RSON_INVALID_RSNE_CAP_			= 22,
+	_RSON_IEEE_802DOT1X_AUTH_FAIL_	= 23,
+
+	/* belowing are Realtek definition */
+	_RSON_PMK_NOT_AVAILABLE_		= 24,
+	_RSON_TDLS_TEAR_TOOFAR_			= 25,
+	_RSON_TDLS_TEAR_UN_RSN_			= 26,
+};
+
+/* Reason codes (IEEE 802.11-2007, 7.3.1.7, Table 7-22) */
+#if 0
+#define WLAN_REASON_UNSPECIFIED 1
+#define WLAN_REASON_PREV_AUTH_NOT_VALID 2
+#define WLAN_REASON_DEAUTH_LEAVING 3
+#define WLAN_REASON_DISASSOC_DUE_TO_INACTIVITY 4
+#define WLAN_REASON_DISASSOC_AP_BUSY 5
+#define WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA 6
+#define WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA 7
+#define WLAN_REASON_DISASSOC_STA_HAS_LEFT 8
+#define WLAN_REASON_STA_REQ_ASSOC_WITHOUT_AUTH 9
+#endif
+/* IEEE 802.11h */
+#define WLAN_REASON_PWR_CAPABILITY_NOT_VALID 10
+#define WLAN_REASON_SUPPORTED_CHANNEL_NOT_VALID 11
+#if 0
+/* IEEE 802.11i */
+#define WLAN_REASON_INVALID_IE 13
+#define WLAN_REASON_MICHAEL_MIC_FAILURE 14
+#define WLAN_REASON_4WAY_HANDSHAKE_TIMEOUT 15
+#define WLAN_REASON_GROUP_KEY_UPDATE_TIMEOUT 16
+#define WLAN_REASON_IE_IN_4WAY_DIFFERS 17
+#define WLAN_REASON_GROUP_CIPHER_NOT_VALID 18
+#define WLAN_REASON_PAIRWISE_CIPHER_NOT_VALID 19
+#define WLAN_REASON_AKMP_NOT_VALID 20
+#define WLAN_REASON_UNSUPPORTED_RSN_IE_VERSION 21
+#define WLAN_REASON_INVALID_RSN_IE_CAPAB 22
+#define WLAN_REASON_IEEE_802_1X_AUTH_FAILED 23
+#define WLAN_REASON_CIPHER_SUITE_REJECTED 24
+#endif
+
+enum WIFI_STATUS_CODE {
+	_STATS_SUCCESSFUL_			= 0,
+	_STATS_FAILURE_				= 1,
+	_STATS_SEC_DISABLED_			= 5,
+	_STATS_NOT_IN_SAME_BSS_		= 7,
+	_STATS_CAP_FAIL_			= 10,
+	_STATS_NO_ASOC_				= 11,
+	_STATS_OTHER_				= 12,
+	_STATS_NO_SUPP_ALG_			= 13,
+	_STATS_OUT_OF_AUTH_SEQ_		= 14,
+	_STATS_CHALLENGE_FAIL_		= 15,
+	_STATS_AUTH_TIMEOUT_		= 16,
+	_STATS_UNABLE_HANDLE_STA_	= 17,
+	_STATS_RATE_FAIL_			= 18,
+	_STATS_REFUSED_TEMPORARILY_ = 30,
+	_STATS_DECLINE_REQ_			= 37,
+	_STATS_INVALID_PARAMETERS_	= 38,
+	_STATS_INVALID_RSNIE_			= 72,
+};
+
+/* Status codes (IEEE 802.11-2007, 7.3.1.9, Table 7-23) */
+#if 0
+#define WLAN_STATUS_SUCCESS 0
+#define WLAN_STATUS_UNSPECIFIED_FAILURE 1
+#define WLAN_STATUS_CAPS_UNSUPPORTED 10
+#define WLAN_STATUS_REASSOC_NO_ASSOC 11
+#define WLAN_STATUS_ASSOC_DENIED_UNSPEC 12
+#define WLAN_STATUS_NOT_SUPPORTED_AUTH_ALG 13
+#define WLAN_STATUS_UNKNOWN_AUTH_TRANSACTION 14
+#define WLAN_STATUS_CHALLENGE_FAIL 15
+#define WLAN_STATUS_AUTH_TIMEOUT 16
+#define WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA 17
+#define WLAN_STATUS_ASSOC_DENIED_RATES 18
+#endif
+/* entended */
+/* IEEE 802.11b */
+#define WLAN_STATUS_ASSOC_DENIED_NOSHORT 19
+#define WLAN_STATUS_ASSOC_DENIED_NOPBCC 20
+#define WLAN_STATUS_ASSOC_DENIED_NOAGILITY 21
+/* IEEE 802.11h */
+#define WLAN_STATUS_SPEC_MGMT_REQUIRED 22
+#define WLAN_STATUS_PWR_CAPABILITY_NOT_VALID 23
+#define WLAN_STATUS_SUPPORTED_CHANNEL_NOT_VALID 24
+/* IEEE 802.11g */
+#define WLAN_STATUS_ASSOC_DENIED_NO_SHORT_SLOT_TIME 25
+#define WLAN_STATUS_ASSOC_DENIED_NO_ER_PBCC 26
+#define WLAN_STATUS_ASSOC_DENIED_NO_DSSS_OFDM 27
+/* IEEE 802.11w */
+#define WLAN_STATUS_ASSOC_REJECTED_TEMPORARILY 30
+#define WLAN_STATUS_ROBUST_MGMT_FRAME_POLICY_VIOLATION 31
+/* IEEE 802.11i */
+#define WLAN_STATUS_INVALID_IE 40
+#define WLAN_STATUS_GROUP_CIPHER_NOT_VALID 41
+#define WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID 42
+#define WLAN_STATUS_AKMP_NOT_VALID 43
+#define WLAN_STATUS_UNSUPPORTED_RSN_IE_VERSION 44
+#define WLAN_STATUS_INVALID_RSN_IE_CAPAB 45
+#define WLAN_STATUS_CIPHER_REJECTED_PER_POLICY 46
+#define WLAN_STATUS_TS_NOT_CREATED 47
+#define WLAN_STATUS_DIRECT_LINK_NOT_ALLOWED 48
+#define WLAN_STATUS_DEST_STA_NOT_PRESENT 49
+#define WLAN_STATUS_DEST_STA_NOT_QOS_STA 50
+#define WLAN_STATUS_ASSOC_DENIED_LISTEN_INT_TOO_LARGE 51
+/* IEEE 802.11r */
+#define WLAN_STATUS_INVALID_FT_ACTION_FRAME_COUNT 52
+#define WLAN_STATUS_INVALID_PMKID 53
+#define WLAN_STATUS_INVALID_MDIE 54
+#define WLAN_STATUS_INVALID_FTIE 55
+
+
+enum WIFI_REG_DOMAIN {
+	DOMAIN_FCC		= 1,
+	DOMAIN_IC		= 2,
+	DOMAIN_ETSI		= 3,
+	DOMAIN_SPAIN	= 4,
+	DOMAIN_FRANCE	= 5,
+	DOMAIN_MKK		= 6,
+	DOMAIN_ISRAEL	= 7,
+	DOMAIN_MKK1		= 8,
+	DOMAIN_MKK2		= 9,
+	DOMAIN_MKK3		= 10,
+	DOMAIN_MAX
+};
+
+#define _TO_DS_		BIT(8)
+#define _FROM_DS_	BIT(9)
+#define _MORE_FRAG_	BIT(10)
+#define _RETRY_		BIT(11)
+#define _PWRMGT_	BIT(12)
+#define _MORE_DATA_	BIT(13)
+#define _PRIVACY_	BIT(14)
+#define _ORDER_			BIT(15)
+
+#define SetToDs(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) |= cpu_to_le16(_TO_DS_); \
+	} while (0)
+
+#define GetToDs(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_TO_DS_)) != 0)
+
+#define ClearToDs(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_TO_DS_)); \
+	} while (0)
+
+#define SetFrDs(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) |= cpu_to_le16(_FROM_DS_); \
+	} while (0)
+
+#define GetFrDs(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_FROM_DS_)) != 0)
+
+#define ClearFrDs(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_FROM_DS_)); \
+	} while (0)
+
+#define get_tofr_ds(pframe)	((GetToDs(pframe) << 1) | GetFrDs(pframe))
+
+
+#define SetMFrag(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) |= cpu_to_le16(_MORE_FRAG_); \
+	} while (0)
+
+#define GetMFrag(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_MORE_FRAG_)) != 0)
+
+#define ClearMFrag(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_MORE_FRAG_)); \
+	} while (0)
+
+#define SetRetry(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) |= cpu_to_le16(_RETRY_); \
+	} while (0)
+
+#define GetRetry(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_RETRY_)) != 0)
+
+#define ClearRetry(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_RETRY_)); \
+	} while (0)
+
+#define SetPwrMgt(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) |= cpu_to_le16(_PWRMGT_); \
+	} while (0)
+
+#define GetPwrMgt(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_PWRMGT_)) != 0)
+
+#define ClearPwrMgt(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_PWRMGT_)); \
+	} while (0)
+
+#define SetMData(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) |= cpu_to_le16(_MORE_DATA_); \
+	} while (0)
+
+#define GetMData(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_MORE_DATA_)) != 0)
+
+#define ClearMData(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_MORE_DATA_)); \
+	} while (0)
+
+#define SetPrivacy(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) |= cpu_to_le16(_PRIVACY_); \
+	} while (0)
+
+#define GetPrivacy(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_PRIVACY_)) != 0)
+
+#define ClearPrivacy(pbuf)	\
+	do	{	\
+		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_PRIVACY_)); \
+	} while (0)
+
+
+#define GetOrder(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_ORDER_)) != 0)
+
+#define GetFrameType(pbuf)	(le16_to_cpu(*(unsigned short *)(pbuf)) & (BIT(3) | BIT(2)))
+
+#define SetFrameType(pbuf, type)	\
+	do {	\
+		*(unsigned short *)(pbuf) &= __constant_cpu_to_le16(~(BIT(3) | BIT(2))); \
+		*(unsigned short *)(pbuf) |= __constant_cpu_to_le16(type); \
+	} while (0)
+
+#define get_frame_sub_type(pbuf)	(cpu_to_le16(*(unsigned short *)(pbuf)) & (BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3) | BIT(2)))
+
+
+#define set_frame_sub_type(pbuf, type) \
+	do {    \
+		*(unsigned short *)(pbuf) &= cpu_to_le16(~(BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3) | BIT(2))); \
+		*(unsigned short *)(pbuf) |= cpu_to_le16(type); \
+	} while (0)
+
+
+#define GetSequence(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + 22)) >> 4)
+
+#define GetFragNum(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + 22)) & 0x0f)
+
+#define GetTupleCache(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + 22)))
+
+#define SetFragNum(pbuf, num) \
+	do {    \
+		*(unsigned short *)((SIZE_PTR)(pbuf) + 22) = \
+			((*(unsigned short *)((SIZE_PTR)(pbuf) + 22)) & le16_to_cpu(~(0x000f))) | \
+				cpu_to_le16(0x0f & (num));     \
+	} while (0)
+
+#define SetSeqNum(pbuf, num) \
+	do {    \
+		*(unsigned short *)((SIZE_PTR)(pbuf) + 22) = \
+			((*(unsigned short *)((SIZE_PTR)(pbuf) + 22)) & le16_to_cpu((unsigned short)~0xfff0)) | \
+			le16_to_cpu((unsigned short)(0xfff0 & (num << 4))); \
+	} while (0)
+
+#define set_duration(pbuf, dur) \
+	do {    \
+		*(unsigned short *)((SIZE_PTR)(pbuf) + 2) = cpu_to_le16(0xffff & (dur)); \
+	} while (0)
+
+
+/* QoS control field */
+#define SetPriority(qc, tid)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 0, 4, tid)
+#define SetEOSP(qc, eosp)		SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 4, 1, eosp)
+#define SetAckpolicy(qc, ack)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 5, 2, ack)
+#define SetAMsdu(qc, amsdu)		SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 7, 1, amsdu)
+
+#define GetPriority(qc)		LE_BITS_TO_2BYTE(((u8 *)(qc)), 0, 4)
+#define GetEOSP(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 4, 1)
+#define GetAckpolicy(qc)	LE_BITS_TO_2BYTE(((u8 *)(qc)), 5, 2)
+#define GetAMsdu(qc)		LE_BITS_TO_2BYTE(((u8 *)(qc)), 7, 1)
+
+/* QoS control field (MSTA only) */
+#define set_mctrl_present(qc, p)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 8, 1, p)
+#define set_mps_lv(qc, lv)			SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 9, 1, lv)
+#define set_rspi(qc, rspi)			SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 10, 1, rspi)
+
+#define get_mctrl_present(qc)	LE_BITS_TO_2BYTE(((u8 *)(qc)), 8, 1)
+#define get_mps_lv(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 9, 1)
+#define get_rspi(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 10, 1)
+
+
+#define GetAid(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + 2)) & 0x3fff)
+
+#define GetTid(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + (((GetToDs(pbuf)<<1) | GetFrDs(pbuf)) == 3 ? 30 : 24))) & 0x000f)
+
+#define GetAddr1Ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 4))
+
+#define get_addr2_ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 10))
+
+#define GetAddr3Ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 16))
+
+#define GetAddr4Ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 24))
+
+
+#define MacAddr_isBcst(addr) \
+	(\
+	 ((addr[0] == 0xff) && (addr[1] == 0xff) && \
+	  (addr[2] == 0xff) && (addr[3] == 0xff) && \
+	  (addr[4] == 0xff) && (addr[5] == 0xff)) ? _TRUE : _FALSE \
+	)
+
+__inline static int IS_MCAST(const u8 *da)
+{
+	if ((*da) & 0x01)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+__inline static unsigned char *get_ra(unsigned char *pframe)
+{
+	unsigned char	*ra;
+	ra = GetAddr1Ptr(pframe);
+	return ra;
+}
+__inline static unsigned char *get_ta(unsigned char *pframe)
+{
+	unsigned char	*ta;
+	ta = get_addr2_ptr(pframe);
+	return ta;
+}
+
+/* can't apply to mesh mode */
+__inline static unsigned char *get_da(unsigned char *pframe)
+{
+	unsigned char	*da;
+	unsigned int	to_fr_ds	= (GetToDs(pframe) << 1) | GetFrDs(pframe);
+
+	switch (to_fr_ds) {
+	case 0x00:	/* ToDs=0, FromDs=0 */
+		da = GetAddr1Ptr(pframe);
+		break;
+	case 0x01:	/* ToDs=0, FromDs=1 */
+		da = GetAddr1Ptr(pframe);
+		break;
+	case 0x02:	/* ToDs=1, FromDs=0 */
+		da = GetAddr3Ptr(pframe);
+		break;
+	default:	/* ToDs=1, FromDs=1 */
+		da = GetAddr3Ptr(pframe);
+		break;
+	}
+
+	return da;
+}
+
+/* can't apply to mesh mode */
+__inline static unsigned char *get_sa(unsigned char *pframe)
+{
+	unsigned char	*sa;
+	unsigned int	to_fr_ds	= (GetToDs(pframe) << 1) | GetFrDs(pframe);
+
+	switch (to_fr_ds) {
+	case 0x00:	/* ToDs=0, FromDs=0 */
+		sa = get_addr2_ptr(pframe);
+		break;
+	case 0x01:	/* ToDs=0, FromDs=1 */
+		sa = GetAddr3Ptr(pframe);
+		break;
+	case 0x02:	/* ToDs=1, FromDs=0 */
+		sa = get_addr2_ptr(pframe);
+		break;
+	default:	/* ToDs=1, FromDs=1 */
+		sa = GetAddr4Ptr(pframe);
+		break;
+	}
+
+	return sa;
+}
+
+/* can't apply to mesh mode */
+__inline static unsigned char *get_hdr_bssid(unsigned char *pframe)
+{
+	unsigned char	*sa = NULL;
+	unsigned int	to_fr_ds	= (GetToDs(pframe) << 1) | GetFrDs(pframe);
+
+	switch (to_fr_ds) {
+	case 0x00:	/* ToDs=0, FromDs=0 */
+		sa = GetAddr3Ptr(pframe);
+		break;
+	case 0x01:	/* ToDs=0, FromDs=1 */
+		sa = get_addr2_ptr(pframe);
+		break;
+	case 0x02:	/* ToDs=1, FromDs=0 */
+		sa = GetAddr1Ptr(pframe);
+		break;
+	case 0x03:	/* ToDs=1, FromDs=1 */
+		sa = GetAddr1Ptr(pframe);
+		break;
+	}
+
+	return sa;
+}
+
+
+__inline static int IsFrameTypeCtrl(unsigned char *pframe)
+{
+	if (WIFI_CTRL_TYPE == GetFrameType(pframe))
+		return _TRUE;
+	else
+		return _FALSE;
+}
+static inline int IsFrameTypeMgnt(unsigned char *pframe)
+{
+	if (GetFrameType(pframe) == WIFI_MGT_TYPE)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+static inline int IsFrameTypeData(unsigned char *pframe)
+{
+	if (GetFrameType(pframe) == WIFI_DATA_TYPE)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+
+/*-----------------------------------------------------------------------------
+			Below is for the security related definition
+------------------------------------------------------------------------------*/
+#define _RESERVED_FRAME_TYPE_	0
+#define _SKB_FRAME_TYPE_		2
+#define _PRE_ALLOCMEM_			1
+#define _PRE_ALLOCHDR_			3
+#define _PRE_ALLOCLLCHDR_		4
+#define _PRE_ALLOCICVHDR_		5
+#define _PRE_ALLOCMICHDR_		6
+
+#define _SIFSTIME_				((priv->pmib->dot11BssType.net_work_type&WIRELESS_11A) ? 16 : 10)
+#define _ACKCTSLNG_				14	/* 14 bytes long, including crclng */
+#define _CRCLNG_				4
+
+#define _ASOCREQ_IE_OFFSET_		4	/* excluding wlan_hdr */
+#define	_ASOCRSP_IE_OFFSET_		6
+#define _REASOCREQ_IE_OFFSET_	10
+#define _REASOCRSP_IE_OFFSET_	6
+#define _PROBEREQ_IE_OFFSET_	0
+#define	_PROBERSP_IE_OFFSET_	12
+#define _AUTH_IE_OFFSET_		6
+#define _DEAUTH_IE_OFFSET_		0
+#define _BEACON_IE_OFFSET_		12
+#define _PUBLIC_ACTION_IE_OFFSET_	8
+
+#define _FIXED_IE_LENGTH_			_BEACON_IE_OFFSET_
+
+#define _SSID_IE_				0
+#define _SUPPORTEDRATES_IE_	1
+#define _DSSET_IE_				3
+#define _TIM_IE_					5
+#define _IBSS_PARA_IE_			6
+#define _COUNTRY_IE_			7
+#define _CHLGETXT_IE_			16
+#define _SUPPORTED_CH_IE_		36
+#define _CH_SWTICH_ANNOUNCE_	37	/* Secondary Channel Offset */
+#define	_MEAS_REQ_IE_		38
+#define	_MEAS_RSP_IE_		39
+#define _RSN_IE_2_				48
+#define _SSN_IE_1_					221
+#define _ERPINFO_IE_			42
+#define _EXT_SUPPORTEDRATES_IE_	50
+
+#define _HT_CAPABILITY_IE_			45
+#define _MDIE_					54
+#define _FTIE_					55
+#define _TIMEOUT_ITVL_IE_			56
+#define _SRC_IE_				59
+#define _HT_EXTRA_INFO_IE_			61
+#define _HT_ADD_INFO_IE_			61 /* _HT_EXTRA_INFO_IE_ */
+#define _WAPI_IE_				68
+#define _EID_RRM_EN_CAP_IE_			70
+
+
+/* #define EID_BSSCoexistence			72 */ /* 20/40 BSS Coexistence
+ * #define EID_BSSIntolerantChlReport	73 */
+#define _RIC_Descriptor_IE_			75
+#ifdef CONFIG_IEEE80211W
+#define _MME_IE_					76 /* 802.11w Management MIC element */
+#endif /* CONFIG_IEEE80211W */
+#define _LINK_ID_IE_					101
+#define _CH_SWITCH_TIMING_		104
+#define _PTI_BUFFER_STATUS_		106
+#define _EXT_CAP_IE_				127
+#define _VENDOR_SPECIFIC_IE_		221
+
+#define	_RESERVED47_				47
+
+typedef	enum _ELEMENT_ID {
+	EID_SsId					= 0, /* service set identifier (0:32) */
+	EID_SupRates				= 1, /* supported rates (1:8) */
+	EID_FHParms				= 2, /* FH parameter set (5) */
+	EID_DSParms				= 3, /* DS parameter set (1) */
+	EID_CFParms				= 4, /* CF parameter set (6) */
+	EID_Tim						= 5, /* Traffic Information Map (4:254) */
+	EID_IbssParms				= 6, /* IBSS parameter set (2) */
+	EID_Country					= 7, /* */
+
+	/* Form 7.3.2: Information elements in 802.11E/D13.0, page 46. */
+	EID_QBSSLoad				= 11,
+	EID_EDCAParms				= 12,
+	EID_TSpec					= 13,
+	EID_TClass					= 14,
+	EID_Schedule				= 15,
+	/*  */
+
+	EID_Ctext					= 16, /* challenge text*/
+	EID_POWER_CONSTRAINT		= 32, /* Power Constraint*/
+
+	/* vivi for WIFITest, 802.11h AP, 20100427 */
+	/* 2010/12/26 MH The definition we can declare always!! */
+	EID_PowerCap				= 33,
+	EID_SupportedChannels		= 36,
+	EID_ChlSwitchAnnounce		= 37,
+
+	EID_MeasureRequest			= 38, /* Measurement Request */
+	EID_MeasureReport			= 39, /* Measurement Report */
+
+	EID_ERPInfo				= 42,
+
+	/* Form 7.3.2: Information elements in 802.11E/D13.0, page 46. */
+	EID_TSDelay				= 43,
+	EID_TCLASProc				= 44,
+	EID_HTCapability			= 45,
+	EID_QoSCap					= 46,
+	/*  */
+
+	EID_WPA2					= 48,
+	EID_ExtSupRates			= 50,
+
+	EID_FTIE					= 55, /* Defined in 802.11r */
+	EID_Timeout				= 56, /* Defined in 802.11r */
+
+	EID_SupRegulatory			= 59, /* Supported Requlatory Classes 802.11y */
+	EID_HTInfo					= 61,
+	EID_SecondaryChnlOffset		= 62,
+
+	EID_BSSCoexistence			= 72, /* 20/40 BSS Coexistence */
+	EID_BSSIntolerantChlReport	= 73,
+	EID_OBSS					= 74, /* Overlapping BSS Scan Parameters */
+
+	EID_LinkIdentifier			= 101, /* Defined in 802.11z */
+	EID_WakeupSchedule		= 102, /* Defined in 802.11z */
+	EID_ChnlSwitchTimeing		= 104, /* Defined in 802.11z */
+	EID_PTIControl				= 105, /* Defined in 802.11z */
+	EID_PUBufferStatus			= 106, /* Defined in 802.11z */
+
+	EID_EXTCapability			= 127, /* Extended Capabilities */
+	/* From S19:Aironet IE and S21:AP IP address IE in CCX v1.13, p16 and p18. */
+	EID_Aironet					= 133, /* 0x85: Aironet Element for Cisco CCX */
+	EID_CiscoIP					= 149, /* 0x95: IP Address IE for Cisco CCX */
+
+	EID_CellPwr					= 150, /* 0x96: Cell Power Limit IE. Ref. 0x96. */
+
+	EID_CCKM					= 156,
+
+	EID_Vendor					= 221, /* 0xDD: Vendor Specific */
+
+	EID_WAPI					= 68,
+	EID_VHTCapability 			= 191, /* Based on 802.11ac D2.0 */
+	EID_VHTOperation 			= 192, /* Based on 802.11ac D2.0 */
+	EID_AID						= 197, /* Based on 802.11ac D4.0 */
+	EID_OpModeNotification		= 199, /* Based on 802.11ac D3.0 */
+} ELEMENT_ID, *PELEMENT_ID;
+
+/* ---------------------------------------------------------------------------
+					Below is the fixed elements...
+-----------------------------------------------------------------------------*/
+#define _AUTH_ALGM_NUM_			2
+#define _AUTH_SEQ_NUM_			2
+#define _BEACON_ITERVAL_		2
+#define _CAPABILITY_			2
+#define _CURRENT_APADDR_		6
+#define _LISTEN_INTERVAL_		2
+#define _RSON_CODE_				2
+#define _ASOC_ID_				2
+#define _STATUS_CODE_			2
+#define _TIMESTAMP_				8
+
+#define AUTH_ODD_TO				0
+#define AUTH_EVEN_TO			1
+
+#define WLAN_ETHCONV_ENCAP		1
+#define WLAN_ETHCONV_RFC1042	2
+#define WLAN_ETHCONV_8021h		3
+
+#define cap_ESS BIT(0)
+#define cap_IBSS BIT(1)
+#define cap_CFPollable BIT(2)
+#define cap_CFRequest BIT(3)
+#define cap_Privacy BIT(4)
+#define cap_ShortPremble BIT(5)
+#define cap_PBCC	BIT(6)
+#define cap_ChAgility	BIT(7)
+#define cap_SpecMgmt	BIT(8)
+#define cap_QoS	BIT(9)
+#define cap_ShortSlot	BIT(10)
+
+/*-----------------------------------------------------------------------------
+				Below is the definition for 802.11i / 802.1x
+------------------------------------------------------------------------------*/
+#define _IEEE8021X_MGT_			1		/* WPA */
+#define _IEEE8021X_PSK_			2		/* WPA with pre-shared key */
+
+#if 0
+#define _NO_PRIVACY_			0
+#define _WEP_40_PRIVACY_		1
+#define _TKIP_PRIVACY_			2
+#define _WRAP_PRIVACY_			3
+#define _CCMP_PRIVACY_			4
+#define _WEP_104_PRIVACY_		5
+#define _WEP_WPA_MIXED_PRIVACY_ 6	/*  WEP + WPA */
+#endif
+
+#define _MME_IE_LENGTH_  18
+
+/*-----------------------------------------------------------------------------
+				Below is the definition for WMM
+------------------------------------------------------------------------------*/
+#define _WMM_IE_Length_				7  /* for WMM STA */
+#define _WMM_Para_Element_Length_		24
+
+
+/*-----------------------------------------------------------------------------
+				Below is the definition for 802.11n
+------------------------------------------------------------------------------*/
+
+/* #ifdef CONFIG_80211N_HT */
+
+#define set_order_bit(pbuf)	\
+		do	{	\
+			*(unsigned short *)(pbuf) |= cpu_to_le16(_ORDER_); \
+		} while (0)
+
+
+
+#define GetOrderBit(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_ORDER_)) != 0)
+
+#define ACT_CAT_VENDOR				0x7F/* 127 */
+
+/**
+ * struct rtw_ieee80211_bar - HT Block Ack Request
+ *
+ * This structure refers to "HT BlockAckReq" as
+ * described in 802.11n draft section 7.2.1.7.1
+ */
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8712FW)
+struct rtw_ieee80211_bar {
+	unsigned short frame_control;
+	unsigned short duration;
+	unsigned char ra[6];
+	unsigned char ta[6];
+	unsigned short control;
+	unsigned short start_seq_num;
+} __attribute__((packed));
+#endif
+
+/* 802.11 BAR control masks */
+#define IEEE80211_BAR_CTRL_ACK_POLICY_NORMAL     0x0000
+#define IEEE80211_BAR_CTRL_CBMTID_COMPRESSED_BA  0x0004
+
+
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8712FW) || defined(PLATFORM_FREEBSD)
+
+
+
+/**
+* struct rtw_ieee80211_ht_cap - HT capabilities
+*
+* This structure refers to "HT capabilities element" as
+* described in 802.11n draft section 7.3.2.52
+*/
+
+struct rtw_ieee80211_ht_cap {
+	unsigned short	cap_info;
+	unsigned char	ampdu_params_info;
+	unsigned char	supp_mcs_set[16];
+	unsigned short	extended_ht_cap_info;
+	unsigned int		tx_BF_cap_info;
+	unsigned char	       antenna_selection_info;
+} __attribute__((packed));
+
+/**
+ * struct rtw_ieee80211_ht_cap - HT additional information
+ *
+ * This structure refers to "HT information element" as
+ * described in 802.11n draft section 7.3.2.53
+ */
+#ifndef CONFIG_IEEE80211_HT_ADDT_INFO
+struct ieee80211_ht_addt_info {
+	unsigned char	control_chan;
+	unsigned char		ht_param;
+	unsigned short	operation_mode;
+	unsigned short	stbc_param;
+	unsigned char		basic_set[16];
+} __attribute__((packed));
+#endif
+
+struct HT_caps_element {
+	union {
+		struct {
+			unsigned short	HT_caps_info;
+			unsigned char	AMPDU_para;
+			unsigned char	MCS_rate[16];
+			unsigned short	HT_ext_caps;
+			unsigned int	Beamforming_caps;
+			unsigned char	ASEL_caps;
+		} HT_cap_element;
+		unsigned char HT_cap[26];
+	} u;
+} __attribute__((packed));
+
+struct HT_info_element {
+	unsigned char	primary_channel;
+	unsigned char	infos[5];
+	unsigned char	MCS_rate[16];
+}  __attribute__((packed));
+
+struct AC_param {
+	unsigned char		ACI_AIFSN;
+	unsigned char		CW;
+	unsigned short	TXOP_limit;
+}  __attribute__((packed));
+
+struct WMM_para_element {
+	unsigned char		QoS_info;
+	unsigned char		reserved;
+	struct AC_param	ac_param[4];
+}  __attribute__((packed));
+
+struct ADDBA_request {
+	unsigned char		dialog_token;
+	unsigned short	BA_para_set;
+	unsigned short	BA_timeout_value;
+	unsigned short	BA_starting_seqctrl;
+}  __attribute__((packed));
+
+
+
+#endif
+
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+
+struct rtw_ieee80211_ht_cap {
+	unsigned short	cap_info;
+	unsigned char	ampdu_params_info;
+	unsigned char	supp_mcs_set[16];
+	unsigned short	extended_ht_cap_info;
+	unsigned int		tx_BF_cap_info;
+	unsigned char	       antenna_selection_info;
+};
+
+
+struct ieee80211_ht_addt_info {
+	unsigned char	control_chan;
+	unsigned char		ht_param;
+	unsigned short	operation_mode;
+	unsigned short	stbc_param;
+	unsigned char		basic_set[16];
+};
+
+struct HT_caps_element {
+	union {
+		struct {
+			unsigned short	HT_caps_info;
+			unsigned char	AMPDU_para;
+			unsigned char	MCS_rate[16];
+			unsigned short	HT_ext_caps;
+			unsigned int	Beamforming_caps;
+			unsigned char	ASEL_caps;
+		} HT_cap_element;
+		unsigned char HT_cap[26];
+	};
+};
+
+struct HT_info_element {
+	unsigned char	primary_channel;
+	unsigned char	infos[5];
+	unsigned char	MCS_rate[16];
+};
+
+struct AC_param {
+	unsigned char		ACI_AIFSN;
+	unsigned char		CW;
+	unsigned short	TXOP_limit;
+};
+
+struct WMM_para_element {
+	unsigned char		QoS_info;
+	unsigned char		reserved;
+	struct AC_param	ac_param[4];
+};
+
+struct ADDBA_request {
+	unsigned char		dialog_token;
+	unsigned short	BA_para_set;
+	unsigned short	BA_timeout_value;
+	unsigned short	BA_starting_seqctrl;
+};
+
+
+#pragma pack()
+
+#endif
+
+typedef enum _HT_CAP_AMPDU_FACTOR {
+	MAX_AMPDU_FACTOR_8K		= 0,
+	MAX_AMPDU_FACTOR_16K	= 1,
+	MAX_AMPDU_FACTOR_32K	= 2,
+	MAX_AMPDU_FACTOR_64K	= 3,
+} HT_CAP_AMPDU_FACTOR;
+
+typedef enum _VHT_CAP_AMPDU_FACTOR {
+	MAX_AMPDU_FACTOR_128K = 4,
+	MAX_AMPDU_FACTOR_256K = 5,
+	MAX_AMPDU_FACTOR_512K = 6,
+	MAX_AMPDU_FACTOR_1M = 7,
+} VHT_CAP_AMPDU_FACTOR;
+
+
+typedef enum _HT_CAP_AMPDU_DENSITY {
+	AMPDU_DENSITY_VALUE_0 = 0 , /* For no restriction */
+	AMPDU_DENSITY_VALUE_1 = 1 , /* For 1/4 us */
+	AMPDU_DENSITY_VALUE_2 = 2 , /* For 1/2 us */
+	AMPDU_DENSITY_VALUE_3 = 3 , /* For 1 us */
+	AMPDU_DENSITY_VALUE_4 = 4 , /* For 2 us */
+	AMPDU_DENSITY_VALUE_5 = 5 , /* For 4 us */
+	AMPDU_DENSITY_VALUE_6 = 6 , /* For 8 us */
+	AMPDU_DENSITY_VALUE_7 = 7 , /* For 16 us */
+} HT_CAP_AMPDU_DENSITY;
+
+/* 802.11n HT capabilities masks */
+#define IEEE80211_HT_CAP_LDPC_CODING		0x0001
+#define IEEE80211_HT_CAP_SUP_WIDTH		0x0002
+#define IEEE80211_HT_CAP_SM_PS			0x000C
+#define IEEE80211_HT_CAP_GRN_FLD		0x0010
+#define IEEE80211_HT_CAP_SGI_20			0x0020
+#define IEEE80211_HT_CAP_SGI_40			0x0040
+#define IEEE80211_HT_CAP_TX_STBC			0x0080
+#define IEEE80211_HT_CAP_RX_STBC_1R		0x0100
+#define IEEE80211_HT_CAP_RX_STBC_2R		0x0200
+#define IEEE80211_HT_CAP_RX_STBC_3R		0x0300
+#define IEEE80211_HT_CAP_DELAY_BA		0x0400
+#define IEEE80211_HT_CAP_MAX_AMSDU		0x0800
+#define IEEE80211_HT_CAP_DSSSCCK40		0x1000
+#define RTW_IEEE80211_HT_CAP_40MHZ_INTOLERANT	((u16) BIT(14))
+/* 802.11n HT capability AMPDU settings */
+#define IEEE80211_HT_CAP_AMPDU_FACTOR		0x03
+#define IEEE80211_HT_CAP_AMPDU_DENSITY		0x1C
+/* 802.11n HT capability MSC set */
+#define IEEE80211_SUPP_MCS_SET_UEQM		4
+#define IEEE80211_HT_CAP_MAX_STREAMS		4
+#define IEEE80211_SUPP_MCS_SET_LEN		10
+/* maximum streams the spec allows */
+#define IEEE80211_HT_CAP_MCS_TX_DEFINED		0x01
+#define IEEE80211_HT_CAP_MCS_TX_RX_DIFF		0x02
+#define IEEE80211_HT_CAP_MCS_TX_STREAMS		0x0C
+#define IEEE80211_HT_CAP_MCS_TX_UEQM		0x10
+/* 802.11n HT capability TXBF capability */
+#define IEEE80211_HT_CAP_TXBF_RX_NDP		0x00000008
+#define IEEE80211_HT_CAP_TXBF_TX_NDP		0x00000010
+#define IEEE80211_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP	0x00000400
+
+/* 802.11n HT IE masks */
+#define IEEE80211_HT_IE_CHA_SEC_OFFSET		0x03
+#define IEEE80211_HT_IE_CHA_SEC_NONE		0x00
+#define IEEE80211_HT_IE_CHA_SEC_ABOVE		0x01
+#define IEEE80211_HT_IE_CHA_SEC_BELOW		0x03
+#define IEEE80211_HT_IE_CHA_WIDTH		0x04
+#define IEEE80211_HT_IE_HT_PROTECTION		0x0003
+#define IEEE80211_HT_IE_NON_GF_STA_PRSNT	0x0004
+#define IEEE80211_HT_IE_NON_HT_STA_PRSNT	0x0010
+
+/* block-ack parameters */
+#define IEEE80211_ADDBA_PARAM_POLICY_MASK 0x0002
+#define IEEE80211_ADDBA_PARAM_TID_MASK 0x003C
+#define RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK 0xFFC0
+#define IEEE80211_DELBA_PARAM_TID_MASK 0xF000
+#define IEEE80211_DELBA_PARAM_INITIATOR_MASK 0x0800
+
+/*
+ * A-PMDU buffer sizes
+ * According to IEEE802.11n spec size varies from 8K to 64K (in powers of 2)
+ */
+#define IEEE80211_MIN_AMPDU_BUF 0x8
+#define IEEE80211_MAX_AMPDU_BUF 0x40
+
+
+/* Spatial Multiplexing Power Save Modes */
+#define WLAN_HT_CAP_SM_PS_STATIC		0
+#define WLAN_HT_CAP_SM_PS_DYNAMIC	1
+#define WLAN_HT_CAP_SM_PS_INVALID	2
+#define WLAN_HT_CAP_SM_PS_DISABLED	3
+
+
+#define OP_MODE_PURE                    0
+#define OP_MODE_MAY_BE_LEGACY_STAS      1
+#define OP_MODE_20MHZ_HT_STA_ASSOCED    2
+#define OP_MODE_MIXED                   3
+
+#define HT_INFO_HT_PARAM_SECONDARY_CHNL_OFF_MASK	((u8) BIT(0) | BIT(1))
+#define HT_INFO_HT_PARAM_SECONDARY_CHNL_ABOVE		((u8) BIT(0))
+#define HT_INFO_HT_PARAM_SECONDARY_CHNL_BELOW		((u8) BIT(0) | BIT(1))
+#define HT_INFO_HT_PARAM_REC_TRANS_CHNL_WIDTH		((u8) BIT(2))
+#define HT_INFO_HT_PARAM_RIFS_MODE			((u8) BIT(3))
+#define HT_INFO_HT_PARAM_CTRL_ACCESS_ONLY		((u8) BIT(4))
+#define HT_INFO_HT_PARAM_SRV_INTERVAL_GRANULARITY	((u8) BIT(5))
+
+#define HT_INFO_OPERATION_MODE_OP_MODE_MASK	\
+	((u16) (0x0001 | 0x0002))
+#define HT_INFO_OPERATION_MODE_OP_MODE_OFFSET		0
+#define HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT	((u8) BIT(2))
+#define HT_INFO_OPERATION_MODE_TRANSMIT_BURST_LIMIT	((u8) BIT(3))
+#define HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT	((u8) BIT(4))
+
+#define HT_INFO_STBC_PARAM_DUAL_BEACON			((u16) BIT(6))
+#define HT_INFO_STBC_PARAM_DUAL_STBC_PROTECT		((u16) BIT(7))
+#define HT_INFO_STBC_PARAM_SECONDARY_BCN		((u16) BIT(8))
+#define HT_INFO_STBC_PARAM_LSIG_TXOP_PROTECT_ALLOWED	((u16) BIT(9))
+#define HT_INFO_STBC_PARAM_PCO_ACTIVE			((u16) BIT(10))
+#define HT_INFO_STBC_PARAM_PCO_PHASE			((u16) BIT(11))
+
+
+
+/* #endif */
+
+/*	===============WPS Section=============== */
+/*	For WPSv1.0 */
+#define WPSOUI							0x0050f204
+/*	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
+
+/*	Value of WPS attribute "WPS_ATTR_DEVICE_NAME */
+#define WPS_MAX_DEVICE_NAME_LEN		32
+
+/*	Value of WPS Request Type Attribute */
+#define WPS_REQ_TYPE_ENROLLEE_INFO_ONLY			0x00
+#define WPS_REQ_TYPE_ENROLLEE_OPEN_8021X		0x01
+#define WPS_REQ_TYPE_REGISTRAR					0x02
+#define WPS_REQ_TYPE_WLAN_MANAGER_REGISTRAR	0x03
+
+/*	Value of WPS Response Type Attribute */
+#define WPS_RESPONSE_TYPE_INFO_ONLY	0x00
+#define WPS_RESPONSE_TYPE_8021X		0x01
+#define WPS_RESPONSE_TYPE_REGISTRAR	0x02
+#define WPS_RESPONSE_TYPE_AP			0x03
+
+/*	Value of WPS WiFi Simple Configuration State Attribute */
+#define WPS_WSC_STATE_NOT_CONFIG	0x01
+#define WPS_WSC_STATE_CONFIG			0x02
+
+/*	Value of WPS Version Attribute */
+#define WPS_VERSION_1					0x10
+
+/*	Value of WPS Configuration Method Attribute */
+#define WPS_CONFIG_METHOD_FLASH		0x0001
+#define WPS_CONFIG_METHOD_ETHERNET	0x0002
+#define WPS_CONFIG_METHOD_LABEL		0x0004
+#define WPS_CONFIG_METHOD_DISPLAY	0x0008
+#define WPS_CONFIG_METHOD_E_NFC		0x0010
+#define WPS_CONFIG_METHOD_I_NFC		0x0020
+#define WPS_CONFIG_METHOD_NFC		0x0040
+#define WPS_CONFIG_METHOD_PBC		0x0080
+#define WPS_CONFIG_METHOD_KEYPAD	0x0100
+#define WPS_CONFIG_METHOD_VPBC		0x0280
+#define WPS_CONFIG_METHOD_PPBC		0x0480
+#define WPS_CONFIG_METHOD_VDISPLAY	0x2008
+#define WPS_CONFIG_METHOD_PDISPLAY	0x4008
+
+/*	Value of Category ID of WPS Primary Device Type Attribute */
+#define WPS_PDT_CID_DISPLAYS			0x0007
+#define WPS_PDT_CID_MULIT_MEDIA		0x0008
+#define WPS_PDT_CID_RTK_WIDI			WPS_PDT_CID_MULIT_MEDIA
+
+/*	Value of Sub Category ID of WPS Primary Device Type Attribute */
+#define WPS_PDT_SCID_MEDIA_SERVER	0x0005
+#define WPS_PDT_SCID_RTK_DMP			WPS_PDT_SCID_MEDIA_SERVER
+
+/*	Value of Device Password ID */
+#define WPS_DPID_PIN					0x0000
+#define WPS_DPID_USER_SPEC			0x0001
+#define WPS_DPID_MACHINE_SPEC			0x0002
+#define WPS_DPID_REKEY					0x0003
+#define WPS_DPID_PBC					0x0004
+#define WPS_DPID_REGISTRAR_SPEC		0x0005
+
+/*	Value of WPS RF Bands Attribute */
+#define WPS_RF_BANDS_2_4_GHZ		0x01
+#define WPS_RF_BANDS_5_GHZ		0x02
+
+/*	Value of WPS Association State Attribute */
+#define WPS_ASSOC_STATE_NOT_ASSOCIATED			0x00
+#define WPS_ASSOC_STATE_CONNECTION_SUCCESS		0x01
+#define WPS_ASSOC_STATE_CONFIGURATION_FAILURE	0x02
+#define WPS_ASSOC_STATE_ASSOCIATION_FAILURE		0x03
+#define WPS_ASSOC_STATE_IP_FAILURE				0x04
+
+/*	=====================P2P Section===================== */
+/*	For P2P */
+#define	P2POUI							0x506F9A09
+
+/*	P2P Attribute ID */
+#define	P2P_ATTR_STATUS					0x00
+#define	P2P_ATTR_MINOR_REASON_CODE		0x01
+#define	P2P_ATTR_CAPABILITY				0x02
+#define	P2P_ATTR_DEVICE_ID				0x03
+#define	P2P_ATTR_GO_INTENT				0x04
+#define	P2P_ATTR_CONF_TIMEOUT			0x05
+#define	P2P_ATTR_LISTEN_CH				0x06
+#define	P2P_ATTR_GROUP_BSSID				0x07
+#define	P2P_ATTR_EX_LISTEN_TIMING		0x08
+#define	P2P_ATTR_INTENDED_IF_ADDR		0x09
+#define	P2P_ATTR_MANAGEABILITY			0x0A
+#define	P2P_ATTR_CH_LIST					0x0B
+#define	P2P_ATTR_NOA						0x0C
+#define	P2P_ATTR_DEVICE_INFO				0x0D
+#define	P2P_ATTR_GROUP_INFO				0x0E
+#define	P2P_ATTR_GROUP_ID					0x0F
+#define	P2P_ATTR_INTERFACE				0x10
+#define	P2P_ATTR_OPERATING_CH			0x11
+#define	P2P_ATTR_INVITATION_FLAGS		0x12
+
+/*	Value of Status Attribute */
+#define	P2P_STATUS_SUCCESS						0x00
+#define	P2P_STATUS_FAIL_INFO_UNAVAILABLE		0x01
+#define	P2P_STATUS_FAIL_INCOMPATIBLE_PARAM		0x02
+#define	P2P_STATUS_FAIL_LIMIT_REACHED			0x03
+#define	P2P_STATUS_FAIL_INVALID_PARAM			0x04
+#define	P2P_STATUS_FAIL_REQUEST_UNABLE			0x05
+#define	P2P_STATUS_FAIL_PREVOUS_PROTO_ERR		0x06
+#define	P2P_STATUS_FAIL_NO_COMMON_CH			0x07
+#define	P2P_STATUS_FAIL_UNKNOWN_P2PGROUP		0x08
+#define	P2P_STATUS_FAIL_BOTH_GOINTENT_15		0x09
+#define	P2P_STATUS_FAIL_INCOMPATIBLE_PROVSION	0x0A
+#define	P2P_STATUS_FAIL_USER_REJECT				0x0B
+
+/*	Value of Inviation Flags Attribute */
+#define	P2P_INVITATION_FLAGS_PERSISTENT			BIT(0)
+
+#define	DMP_P2P_DEVCAP_SUPPORT	(P2P_DEVCAP_SERVICE_DISCOVERY | \
+				 P2P_DEVCAP_CLIENT_DISCOVERABILITY | \
+				 P2P_DEVCAP_CONCURRENT_OPERATION | \
+				 P2P_DEVCAP_INVITATION_PROC)
+
+#define	DMP_P2P_GRPCAP_SUPPORT	(P2P_GRPCAP_INTRABSS)
+
+/*	Value of Device Capability Bitmap */
+#define	P2P_DEVCAP_SERVICE_DISCOVERY		BIT(0)
+#define	P2P_DEVCAP_CLIENT_DISCOVERABILITY	BIT(1)
+#define	P2P_DEVCAP_CONCURRENT_OPERATION	BIT(2)
+#define	P2P_DEVCAP_INFRA_MANAGED			BIT(3)
+#define	P2P_DEVCAP_DEVICE_LIMIT				BIT(4)
+#define	P2P_DEVCAP_INVITATION_PROC			BIT(5)
+
+/*	Value of Group Capability Bitmap */
+#define	P2P_GRPCAP_GO							BIT(0)
+#define	P2P_GRPCAP_PERSISTENT_GROUP			BIT(1)
+#define	P2P_GRPCAP_GROUP_LIMIT				BIT(2)
+#define	P2P_GRPCAP_INTRABSS					BIT(3)
+#define	P2P_GRPCAP_CROSS_CONN				BIT(4)
+#define	P2P_GRPCAP_PERSISTENT_RECONN		BIT(5)
+#define	P2P_GRPCAP_GROUP_FORMATION			BIT(6)
+
+/*	P2P Public Action Frame ( Management Frame ) */
+#define	P2P_PUB_ACTION_ACTION				0x09
+
+/*	P2P Public Action Frame Type */
+#define	P2P_GO_NEGO_REQ						0
+#define	P2P_GO_NEGO_RESP						1
+#define	P2P_GO_NEGO_CONF						2
+#define	P2P_INVIT_REQ							3
+#define	P2P_INVIT_RESP							4
+#define	P2P_DEVDISC_REQ						5
+#define	P2P_DEVDISC_RESP						6
+#define	P2P_PROVISION_DISC_REQ				7
+#define	P2P_PROVISION_DISC_RESP				8
+
+/*	P2P Action Frame Type */
+#define	P2P_NOTICE_OF_ABSENCE	0
+#define	P2P_PRESENCE_REQUEST		1
+#define	P2P_PRESENCE_RESPONSE	2
+#define	P2P_GO_DISC_REQUEST		3
+
+
+#define	P2P_MAX_PERSISTENT_GROUP_NUM		10
+
+#define	P2P_PROVISIONING_SCAN_CNT			3
+
+#define	P2P_WILDCARD_SSID_LEN				7
+
+#define	P2P_FINDPHASE_EX_NONE				0	/* default value, used when: (1)p2p disabed or (2)p2p enabled but only do 1 scan phase */
+#define	P2P_FINDPHASE_EX_FULL				1	/* used when p2p enabled and want to do 1 scan phase and P2P_FINDPHASE_EX_MAX-1 find phase */
+#define	P2P_FINDPHASE_EX_SOCIAL_FIRST		(P2P_FINDPHASE_EX_FULL+1)
+#define	P2P_FINDPHASE_EX_MAX					4
+#define	P2P_FINDPHASE_EX_SOCIAL_LAST		P2P_FINDPHASE_EX_MAX
+
+#define	P2P_PROVISION_TIMEOUT				5000	/*	5 seconds timeout for sending the provision discovery request */
+#define	P2P_CONCURRENT_PROVISION_TIMEOUT	3000	/*	3 seconds timeout for sending the provision discovery request under concurrent mode */
+#define	P2P_GO_NEGO_TIMEOUT					5000	/*	5 seconds timeout for receiving the group negotation response */
+#define	P2P_CONCURRENT_GO_NEGO_TIMEOUT		3000	/*	3 seconds timeout for sending the negotiation request under concurrent mode */
+#define	P2P_TX_PRESCAN_TIMEOUT				100		/*	100ms */
+#define	P2P_INVITE_TIMEOUT					5000	/*	5 seconds timeout for sending the invitation request */
+#define	P2P_CONCURRENT_INVITE_TIMEOUT		3000	/*	3 seconds timeout for sending the invitation request under concurrent mode */
+#define	P2P_RESET_SCAN_CH						25000	/*	25 seconds timeout to reset the scan channel (based on channel plan) */
+#define	P2P_MAX_INTENT						15
+
+#define	P2P_MAX_NOA_NUM						2
+
+/*	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
+
+enum P2P_ROLE {
+	P2P_ROLE_DISABLE = 0,
+	P2P_ROLE_DEVICE = 1,
+	P2P_ROLE_CLIENT = 2,
+	P2P_ROLE_GO = 3
+};
+
+enum P2P_STATE {
+	P2P_STATE_NONE = 0,							/*	P2P disable */
+	P2P_STATE_IDLE = 1,								/*	P2P had enabled and do nothing ,  buddy adapters is linked */
+	P2P_STATE_LISTEN = 2,							/*	In pure listen state */
+	P2P_STATE_SCAN = 3,							/*	In scan phase */
+	P2P_STATE_FIND_PHASE_LISTEN = 4,				/*	In the listen state of find phase */
+	P2P_STATE_FIND_PHASE_SEARCH = 5,				/*	In the search state of find phase */
+	P2P_STATE_TX_PROVISION_DIS_REQ = 6,			/*	In P2P provisioning discovery */
+	P2P_STATE_RX_PROVISION_DIS_RSP = 7,
+	P2P_STATE_RX_PROVISION_DIS_REQ = 8,
+	P2P_STATE_GONEGO_ING = 9,						/*	Doing the group owner negoitation handshake */
+	P2P_STATE_GONEGO_OK = 10,						/*	finish the group negoitation handshake with success */
+	P2P_STATE_GONEGO_FAIL = 11,					/*	finish the group negoitation handshake with failure */
+	P2P_STATE_RECV_INVITE_REQ_MATCH = 12,		/*	receiving the P2P Inviation request and match with the profile. */
+	P2P_STATE_PROVISIONING_ING = 13,				/*	Doing the P2P WPS */
+	P2P_STATE_PROVISIONING_DONE = 14,			/*	Finish the P2P WPS */
+	P2P_STATE_TX_INVITE_REQ = 15,					/*	Transmit the P2P Invitation request */
+	P2P_STATE_RX_INVITE_RESP_OK = 16,				/*	Receiving the P2P Invitation response */
+	P2P_STATE_RECV_INVITE_REQ_DISMATCH = 17,	/*	receiving the P2P Inviation request and dismatch with the profile. */
+	P2P_STATE_RECV_INVITE_REQ_GO = 18,			/*	receiving the P2P Inviation request and this wifi is GO. */
+	P2P_STATE_RECV_INVITE_REQ_JOIN = 19,			/*	receiving the P2P Inviation request to join an existing P2P Group. */
+	P2P_STATE_RX_INVITE_RESP_FAIL = 20,			/*	recveing the P2P Inviation response with failure */
+	P2P_STATE_RX_INFOR_NOREADY = 21,			/* receiving p2p negoitation response with information is not available */
+	P2P_STATE_TX_INFOR_NOREADY = 22,			/* sending p2p negoitation response with information is not available */
+};
+
+enum P2P_WPSINFO {
+	P2P_NO_WPSINFO						= 0,
+	P2P_GOT_WPSINFO_PEER_DISPLAY_PIN	= 1,
+	P2P_GOT_WPSINFO_SELF_DISPLAY_PIN	= 2,
+	P2P_GOT_WPSINFO_PBC					= 3,
+};
+
+#define	P2P_PRIVATE_IOCTL_SET_LEN		64
+
+enum P2P_PROTO_WK_ID {
+	P2P_FIND_PHASE_WK = 0,
+	P2P_RESTORE_STATE_WK = 1,
+	P2P_PRE_TX_PROVDISC_PROCESS_WK = 2,
+	P2P_PRE_TX_NEGOREQ_PROCESS_WK = 3,
+	P2P_PRE_TX_INVITEREQ_PROCESS_WK = 4,
+	P2P_AP_P2P_CH_SWITCH_PROCESS_WK = 5,
+	P2P_RO_CH_WK = 6,
+	P2P_CANCEL_RO_CH_WK = 7,
+};
+
+#ifdef CONFIG_P2P_PS
+enum P2P_PS_STATE {
+	P2P_PS_DISABLE = 0,
+	P2P_PS_ENABLE = 1,
+	P2P_PS_SCAN = 2,
+	P2P_PS_SCAN_DONE = 3,
+	P2P_PS_ALLSTASLEEP = 4, /* for P2P GO */
+};
+
+enum P2P_PS_MODE {
+	P2P_PS_NONE = 0,
+	P2P_PS_CTWINDOW = 1,
+	P2P_PS_NOA	 = 2,
+	P2P_PS_MIX = 3, /* CTWindow and NoA */
+};
+#endif /* CONFIG_P2P_PS */
+
+/*	=====================WFD Section=====================
+ *	For Wi-Fi Display */
+#define	WFD_ATTR_DEVICE_INFO			0x00
+#define	WFD_ATTR_ASSOC_BSSID			0x01
+#define	WFD_ATTR_COUPLED_SINK_INFO	0x06
+#define	WFD_ATTR_LOCAL_IP_ADDR		0x08
+#define	WFD_ATTR_SESSION_INFO		0x09
+#define	WFD_ATTR_ALTER_MAC			0x0a
+
+/*	For WFD Device Information Attribute */
+#define	WFD_DEVINFO_SOURCE					0x0000
+#define	WFD_DEVINFO_PSINK					0x0001
+#define	WFD_DEVINFO_SSINK					0x0002
+#define	WFD_DEVINFO_DUAL					0x0003
+
+#define	WFD_DEVINFO_SESSION_AVAIL			0x0010
+#define	WFD_DEVINFO_WSD						0x0040
+#define	WFD_DEVINFO_PC_TDLS					0x0080
+#define	WFD_DEVINFO_HDCP_SUPPORT			0x0100
+
+#define IP_MCAST_MAC(mac)		((mac[0] == 0x01) && (mac[1] == 0x00) && (mac[2] == 0x5e))
+#define ICMPV6_MCAST_MAC(mac)	((mac[0] == 0x33) && (mac[1] == 0x33) && (mac[2] != 0xff))
+
+#ifdef CONFIG_IOCTL_CFG80211
+/* Regulatroy Domain */
+struct regd_pair_mapping {
+	u16 reg_dmnenum;
+	u16 reg_5ghz_ctl;
+	u16 reg_2ghz_ctl;
+};
+
+struct rtw_regulatory {
+	char alpha2[2];
+	u16 country_code;
+	u16 max_power_level;
+	u32 tp_scale;
+	u16 current_rd;
+	u16 current_rd_ext;
+	int16_t power_limit;
+	struct regd_pair_mapping *regpair;
+};
+#endif
+
+#ifdef CONFIG_WAPI_SUPPORT
+#ifndef IW_AUTH_WAPI_VERSION_1
+#define IW_AUTH_WAPI_VERSION_1		0x00000008
+#endif
+#ifndef IW_AUTH_KEY_MGMT_WAPI_PSK
+#define IW_AUTH_KEY_MGMT_WAPI_PSK	0x04
+#endif
+#ifndef IW_AUTH_WAPI_ENABLED
+#define IW_AUTH_WAPI_ENABLED		0x20
+#endif
+#ifndef IW_ENCODE_ALG_SM4
+#define IW_ENCODE_ALG_SM4			0x20
+#endif
+#endif
+
+#endif /* _WIFI_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/wlan_bssdef.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/wlan_bssdef.h
new file mode 100644
index 000000000000..e7ae35915b39
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/wlan_bssdef.h
@@ -0,0 +1,699 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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
+
+
+#ifdef PLATFORM_LINUX
+
+#define NDIS_802_11_LENGTH_SSID         32
+#define NDIS_802_11_LENGTH_RATES        8
+#define NDIS_802_11_LENGTH_RATES_EX     16
+
+typedef unsigned char   NDIS_802_11_MAC_ADDRESS[6];
+typedef long    		NDIS_802_11_RSSI;           /* in dBm */
+typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        /* Set of 8 data rates */
+typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  /* Set of 16 data rates */
+
+
+typedef  ULONG  NDIS_802_11_KEY_INDEX;
+typedef unsigned long long NDIS_802_11_KEY_RSC;
+
+
+typedef struct _NDIS_802_11_SSID {
+	ULONG  SsidLength;
+	UCHAR  Ssid[32];
+} NDIS_802_11_SSID, *PNDIS_802_11_SSID;
+
+typedef enum _NDIS_802_11_NETWORK_TYPE {
+	Ndis802_11FH,
+	Ndis802_11DS,
+	Ndis802_11OFDM5,
+	Ndis802_11OFDM24,
+	Ndis802_11NetworkTypeMax    /* not a real type, defined as an upper bound */
+} NDIS_802_11_NETWORK_TYPE, *PNDIS_802_11_NETWORK_TYPE;
+
+typedef struct _NDIS_802_11_CONFIGURATION_FH {
+	ULONG           Length;             /* Length of structure */
+	ULONG           HopPattern;         /* As defined by 802.11, MSB set */
+	ULONG           HopSet;             /* to one if non-802.11 */
+	ULONG           DwellTime;          /* units are Kusec */
+} NDIS_802_11_CONFIGURATION_FH, *PNDIS_802_11_CONFIGURATION_FH;
+
+
+/*
+	FW will only save the channel number in DSConfig.
+	ODI Handler will convert the channel number to freq. number.
+*/
+typedef struct _NDIS_802_11_CONFIGURATION {
+	ULONG           Length;             /* Length of structure */
+	ULONG           BeaconPeriod;       /* units are Kusec */
+	ULONG           ATIMWindow;         /* units are Kusec */
+	ULONG           DSConfig;           /* channel number */
+	NDIS_802_11_CONFIGURATION_FH    FHConfig;
+} NDIS_802_11_CONFIGURATION, *PNDIS_802_11_CONFIGURATION;
+
+
+
+typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE {
+	Ndis802_11IBSS,
+	Ndis802_11Infrastructure,
+	Ndis802_11AutoUnknown,
+	Ndis802_11InfrastructureMax,     /* Not a real value, defined as upper bound */
+	Ndis802_11APMode,
+	Ndis802_11Monitor,
+	Ndis802_11_mesh,
+} NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;
+
+
+
+
+
+typedef struct _NDIS_802_11_FIXED_IEs {
+	UCHAR  Timestamp[8];
+	USHORT  BeaconInterval;
+	USHORT  Capabilities;
+} NDIS_802_11_FIXED_IEs, *PNDIS_802_11_FIXED_IEs;
+
+
+
+typedef struct _NDIS_802_11_VARIABLE_IEs {
+	UCHAR  ElementID;
+	UCHAR  Length;
+	UCHAR  data[1];
+} NDIS_802_11_VARIABLE_IEs, *PNDIS_802_11_VARIABLE_IEs;
+
+
+
+/*
+
+
+
+Length is the 4 bytes multiples of the sume of
+	sizeof (NDIS_802_11_MAC_ADDRESS) + 2 + sizeof (NDIS_802_11_SSID) + sizeof (ULONG)
++   sizeof (NDIS_802_11_RSSI) + sizeof (NDIS_802_11_NETWORK_TYPE) + sizeof (NDIS_802_11_CONFIGURATION)
++   sizeof (NDIS_802_11_RATES_EX) + IELength
+
+Except the IELength, all other fields are fixed length. Therefore, we can define a marco to present the
+partial sum.
+
+*/
+#if 0
+typedef struct _NDIS_WLAN_BSSID_EX {
+	ULONG  Length;
+	NDIS_802_11_MAC_ADDRESS  MacAddress;
+	UCHAR  Reserved[2];/* [0]: IS beacon frame, [1]:optimum_antenna=>For antenna diversity; */
+	NDIS_802_11_SSID  Ssid;
+	ULONG  Privacy;
+	NDIS_802_11_RSSI  Rssi;
+	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
+	NDIS_802_11_CONFIGURATION  Configuration;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
+	NDIS_802_11_RATES_EX  SupportedRates;
+	ULONG  IELength;
+	UCHAR  IEs[MAX_IE_SZ];	/* (timestamp, beacon interval, and capability information) */
+} NDIS_WLAN_BSSID_EX, *PNDIS_WLAN_BSSID_EX;
+
+
+typedef struct _NDIS_802_11_BSSID_LIST_EX {
+	ULONG  NumberOfItems;
+	NDIS_WLAN_BSSID_EX  Bssid[1];
+} NDIS_802_11_BSSID_LIST_EX, *PNDIS_802_11_BSSID_LIST_EX;
+#endif
+
+typedef enum _NDIS_802_11_AUTHENTICATION_MODE {
+	Ndis802_11AuthModeOpen,
+	Ndis802_11AuthModeShared,
+	Ndis802_11AuthModeAutoSwitch,
+	Ndis802_11AuthModeWPA,
+	Ndis802_11AuthModeWPAPSK,
+	Ndis802_11AuthModeWPANone,
+	Ndis802_11AuthModeWAPI,
+	Ndis802_11AuthModeMax               /* Not a real mode, defined as upper bound */
+} NDIS_802_11_AUTHENTICATION_MODE, *PNDIS_802_11_AUTHENTICATION_MODE;
+
+typedef enum _NDIS_802_11_WEP_STATUS {
+	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,
+	Ndis802_11_EncrypteionWAPI
+} NDIS_802_11_WEP_STATUS, *PNDIS_802_11_WEP_STATUS,
+NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;
+
+
+#define NDIS_802_11_AI_REQFI_CAPABILITIES      1
+#define NDIS_802_11_AI_REQFI_LISTENINTERVAL    2
+#define NDIS_802_11_AI_REQFI_CURRENTAPADDRESS  4
+
+#define NDIS_802_11_AI_RESFI_CAPABILITIES      1
+#define NDIS_802_11_AI_RESFI_STATUSCODE        2
+#define NDIS_802_11_AI_RESFI_ASSOCIATIONID     4
+
+typedef struct _NDIS_802_11_AI_REQFI {
+	USHORT Capabilities;
+	USHORT ListenInterval;
+	NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;
+} NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;
+
+typedef struct _NDIS_802_11_AI_RESFI {
+	USHORT Capabilities;
+	USHORT StatusCode;
+	USHORT AssociationId;
+} NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;
+
+typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION {
+	ULONG                   Length;
+	USHORT                  AvailableRequestFixedIEs;
+	NDIS_802_11_AI_REQFI    RequestFixedIEs;
+	ULONG                   RequestIELength;
+	ULONG                   OffsetRequestIEs;
+	USHORT                  AvailableResponseFixedIEs;
+	NDIS_802_11_AI_RESFI    ResponseFixedIEs;
+	ULONG                   ResponseIELength;
+	ULONG                   OffsetResponseIEs;
+} NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;
+
+typedef enum _NDIS_802_11_RELOAD_DEFAULTS {
+	Ndis802_11ReloadWEPKeys
+} NDIS_802_11_RELOAD_DEFAULTS, *PNDIS_802_11_RELOAD_DEFAULTS;
+
+
+/* Key mapping keys require a BSSID */
+typedef struct _NDIS_802_11_KEY {
+	ULONG           Length;             /* Length of this structure */
+	ULONG           KeyIndex;
+	ULONG           KeyLength;          /* length of key in bytes */
+	NDIS_802_11_MAC_ADDRESS BSSID;
+	NDIS_802_11_KEY_RSC KeyRSC;
+	UCHAR           KeyMaterial[32];     /* variable length depending on above field */
+} NDIS_802_11_KEY, *PNDIS_802_11_KEY;
+
+typedef struct _NDIS_802_11_REMOVE_KEY {
+	ULONG                   Length;        /* Length of this structure */
+	ULONG                   KeyIndex;
+	NDIS_802_11_MAC_ADDRESS BSSID;
+} NDIS_802_11_REMOVE_KEY, *PNDIS_802_11_REMOVE_KEY;
+
+typedef struct _NDIS_802_11_WEP {
+	ULONG     Length;        /* Length of this structure */
+	ULONG     KeyIndex;      /* 0 is the per-client key, 1-N are the global keys */
+	ULONG     KeyLength;     /* length of key in bytes */
+	UCHAR     KeyMaterial[16];/* variable length depending on above field */
+} NDIS_802_11_WEP, *PNDIS_802_11_WEP;
+
+typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST {
+	ULONG Length;            /* Length of structure */
+	NDIS_802_11_MAC_ADDRESS Bssid;
+	ULONG Flags;
+} NDIS_802_11_AUTHENTICATION_REQUEST, *PNDIS_802_11_AUTHENTICATION_REQUEST;
+
+typedef enum _NDIS_802_11_STATUS_TYPE {
+	Ndis802_11StatusType_Authentication,
+	Ndis802_11StatusType_MediaStreamMode,
+	Ndis802_11StatusType_PMKID_CandidateList,
+	Ndis802_11StatusTypeMax    /* not a real type, defined as an upper bound */
+} NDIS_802_11_STATUS_TYPE, *PNDIS_802_11_STATUS_TYPE;
+
+typedef struct _NDIS_802_11_STATUS_INDICATION {
+	NDIS_802_11_STATUS_TYPE StatusType;
+} NDIS_802_11_STATUS_INDICATION, *PNDIS_802_11_STATUS_INDICATION;
+
+/* mask for authentication/integrity fields */
+#define NDIS_802_11_AUTH_REQUEST_AUTH_FIELDS        0x0f
+#define NDIS_802_11_AUTH_REQUEST_REAUTH			0x01
+#define NDIS_802_11_AUTH_REQUEST_KEYUPDATE		0x02
+#define NDIS_802_11_AUTH_REQUEST_PAIRWISE_ERROR		0x06
+#define NDIS_802_11_AUTH_REQUEST_GROUP_ERROR		0x0E
+
+/* MIC check time, 60 seconds. */
+#define MIC_CHECK_TIME	60000000
+
+typedef struct _NDIS_802_11_AUTHENTICATION_EVENT {
+	NDIS_802_11_STATUS_INDICATION       Status;
+	NDIS_802_11_AUTHENTICATION_REQUEST  Request[1];
+} NDIS_802_11_AUTHENTICATION_EVENT, *PNDIS_802_11_AUTHENTICATION_EVENT;
+
+typedef struct _NDIS_802_11_TEST {
+	ULONG Length;
+	ULONG Type;
+	union {
+		NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;
+		NDIS_802_11_RSSI RssiTrigger;
+	} tt;
+} NDIS_802_11_TEST, *PNDIS_802_11_TEST;
+
+
+#endif /* end of #ifdef PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+
+#define NDIS_802_11_LENGTH_SSID         32
+#define NDIS_802_11_LENGTH_RATES        8
+#define NDIS_802_11_LENGTH_RATES_EX     16
+
+typedef unsigned char   NDIS_802_11_MAC_ADDRESS[6];
+typedef long    		NDIS_802_11_RSSI;           /* in dBm */
+typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        /* Set of 8 data rates */
+typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  /* Set of 16 data rates */
+
+
+typedef  ULONG  NDIS_802_11_KEY_INDEX;
+typedef unsigned long long NDIS_802_11_KEY_RSC;
+
+
+typedef struct _NDIS_802_11_SSID {
+	ULONG  SsidLength;
+	UCHAR  Ssid[32];
+} NDIS_802_11_SSID, *PNDIS_802_11_SSID;
+
+typedef enum _NDIS_802_11_NETWORK_TYPE {
+	Ndis802_11FH,
+	Ndis802_11DS,
+	Ndis802_11OFDM5,
+	Ndis802_11OFDM24,
+	Ndis802_11NetworkTypeMax    /* not a real type, defined as an upper bound */
+} NDIS_802_11_NETWORK_TYPE, *PNDIS_802_11_NETWORK_TYPE;
+
+typedef struct _NDIS_802_11_CONFIGURATION_FH {
+	ULONG           Length;             /* Length of structure */
+	ULONG           HopPattern;         /* As defined by 802.11, MSB set */
+	ULONG           HopSet;             /* to one if non-802.11 */
+	ULONG           DwellTime;          /* units are Kusec */
+} NDIS_802_11_CONFIGURATION_FH, *PNDIS_802_11_CONFIGURATION_FH;
+
+
+/*
+	FW will only save the channel number in DSConfig.
+	ODI Handler will convert the channel number to freq. number.
+*/
+typedef struct _NDIS_802_11_CONFIGURATION {
+	ULONG           Length;             /* Length of structure */
+	ULONG           BeaconPeriod;       /* units are Kusec */
+	ULONG           ATIMWindow;         /* units are Kusec */
+	ULONG           DSConfig;           /* channel number */
+	NDIS_802_11_CONFIGURATION_FH    FHConfig;
+} NDIS_802_11_CONFIGURATION, *PNDIS_802_11_CONFIGURATION;
+
+
+
+typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE {
+	Ndis802_11IBSS,
+	Ndis802_11Infrastructure,
+	Ndis802_11AutoUnknown,
+	Ndis802_11InfrastructureMax,     /* Not a real value, defined as upper bound */
+	Ndis802_11APMode
+} NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;
+
+
+
+
+
+typedef struct _NDIS_802_11_FIXED_IEs {
+	UCHAR  Timestamp[8];
+	USHORT  BeaconInterval;
+	USHORT  Capabilities;
+} NDIS_802_11_FIXED_IEs, *PNDIS_802_11_FIXED_IEs;
+
+
+
+typedef struct _NDIS_802_11_VARIABLE_IEs {
+	UCHAR  ElementID;
+	UCHAR  Length;
+	UCHAR  data[1];
+} NDIS_802_11_VARIABLE_IEs, *PNDIS_802_11_VARIABLE_IEs;
+
+
+
+/*
+
+
+
+Length is the 4 bytes multiples of the sume of
+	sizeof (NDIS_802_11_MAC_ADDRESS) + 2 + sizeof (NDIS_802_11_SSID) + sizeof (ULONG)
++   sizeof (NDIS_802_11_RSSI) + sizeof (NDIS_802_11_NETWORK_TYPE) + sizeof (NDIS_802_11_CONFIGURATION)
++   sizeof (NDIS_802_11_RATES_EX) + IELength
+
+Except the IELength, all other fields are fixed length. Therefore, we can define a marco to present the
+partial sum.
+
+*/
+#if 0
+typedef struct _NDIS_WLAN_BSSID_EX {
+	ULONG  Length;
+	NDIS_802_11_MAC_ADDRESS  MacAddress;
+	UCHAR  Reserved[2];/* [0]: IS beacon frame, [1]:optimum_antenna=>For antenna diversity; */
+	NDIS_802_11_SSID  Ssid;
+	ULONG  Privacy;
+	NDIS_802_11_RSSI  Rssi;
+	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
+	NDIS_802_11_CONFIGURATION  Configuration;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
+	NDIS_802_11_RATES_EX  SupportedRates;
+	ULONG  IELength;
+	UCHAR  IEs[MAX_IE_SZ];	/* (timestamp, beacon interval, and capability information) */
+} NDIS_WLAN_BSSID_EX, *PNDIS_WLAN_BSSID_EX;
+
+
+typedef struct _NDIS_802_11_BSSID_LIST_EX {
+	ULONG  NumberOfItems;
+	NDIS_WLAN_BSSID_EX  Bssid[1];
+} NDIS_802_11_BSSID_LIST_EX, *PNDIS_802_11_BSSID_LIST_EX;
+#endif
+
+typedef enum _NDIS_802_11_AUTHENTICATION_MODE {
+	Ndis802_11AuthModeOpen,
+	Ndis802_11AuthModeShared,
+	Ndis802_11AuthModeAutoSwitch,
+	Ndis802_11AuthModeWPA,
+	Ndis802_11AuthModeWPAPSK,
+	Ndis802_11AuthModeWPANone,
+	Ndis802_11AuthModeMax               /* Not a real mode, defined as upper bound */
+} NDIS_802_11_AUTHENTICATION_MODE, *PNDIS_802_11_AUTHENTICATION_MODE;
+
+typedef enum _NDIS_802_11_WEP_STATUS {
+	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
+} NDIS_802_11_WEP_STATUS, *PNDIS_802_11_WEP_STATUS,
+NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;
+
+
+#define NDIS_802_11_AI_REQFI_CAPABILITIES      1
+#define NDIS_802_11_AI_REQFI_LISTENINTERVAL    2
+#define NDIS_802_11_AI_REQFI_CURRENTAPADDRESS  4
+
+#define NDIS_802_11_AI_RESFI_CAPABILITIES      1
+#define NDIS_802_11_AI_RESFI_STATUSCODE        2
+#define NDIS_802_11_AI_RESFI_ASSOCIATIONID     4
+
+typedef struct _NDIS_802_11_AI_REQFI {
+	USHORT Capabilities;
+	USHORT ListenInterval;
+	NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;
+} NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;
+
+typedef struct _NDIS_802_11_AI_RESFI {
+	USHORT Capabilities;
+	USHORT StatusCode;
+	USHORT AssociationId;
+} NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;
+
+typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION {
+	ULONG                   Length;
+	USHORT                  AvailableRequestFixedIEs;
+	NDIS_802_11_AI_REQFI    RequestFixedIEs;
+	ULONG                   RequestIELength;
+	ULONG                   OffsetRequestIEs;
+	USHORT                  AvailableResponseFixedIEs;
+	NDIS_802_11_AI_RESFI    ResponseFixedIEs;
+	ULONG                   ResponseIELength;
+	ULONG                   OffsetResponseIEs;
+} NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;
+
+typedef enum _NDIS_802_11_RELOAD_DEFAULTS {
+	Ndis802_11ReloadWEPKeys
+} NDIS_802_11_RELOAD_DEFAULTS, *PNDIS_802_11_RELOAD_DEFAULTS;
+
+
+/* Key mapping keys require a BSSID */
+typedef struct _NDIS_802_11_KEY {
+	ULONG           Length;             /* Length of this structure */
+	ULONG           KeyIndex;
+	ULONG           KeyLength;          /* length of key in bytes */
+	NDIS_802_11_MAC_ADDRESS BSSID;
+	NDIS_802_11_KEY_RSC KeyRSC;
+	UCHAR           KeyMaterial[32];     /* variable length depending on above field */
+} NDIS_802_11_KEY, *PNDIS_802_11_KEY;
+
+typedef struct _NDIS_802_11_REMOVE_KEY {
+	ULONG                   Length;        /* Length of this structure */
+	ULONG                   KeyIndex;
+	NDIS_802_11_MAC_ADDRESS BSSID;
+} NDIS_802_11_REMOVE_KEY, *PNDIS_802_11_REMOVE_KEY;
+
+typedef struct _NDIS_802_11_WEP {
+	ULONG     Length;        /* Length of this structure */
+	ULONG     KeyIndex;      /* 0 is the per-client key, 1-N are the global keys */
+	ULONG     KeyLength;     /* length of key in bytes */
+	UCHAR     KeyMaterial[16];/* variable length depending on above field */
+} NDIS_802_11_WEP, *PNDIS_802_11_WEP;
+
+typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST {
+	ULONG Length;            /* Length of structure */
+	NDIS_802_11_MAC_ADDRESS Bssid;
+	ULONG Flags;
+} NDIS_802_11_AUTHENTICATION_REQUEST, *PNDIS_802_11_AUTHENTICATION_REQUEST;
+
+typedef enum _NDIS_802_11_STATUS_TYPE {
+	Ndis802_11StatusType_Authentication,
+	Ndis802_11StatusType_MediaStreamMode,
+	Ndis802_11StatusType_PMKID_CandidateList,
+	Ndis802_11StatusTypeMax    /* not a real type, defined as an upper bound */
+} NDIS_802_11_STATUS_TYPE, *PNDIS_802_11_STATUS_TYPE;
+
+typedef struct _NDIS_802_11_STATUS_INDICATION {
+	NDIS_802_11_STATUS_TYPE StatusType;
+} NDIS_802_11_STATUS_INDICATION, *PNDIS_802_11_STATUS_INDICATION;
+
+/* mask for authentication/integrity fields */
+#define NDIS_802_11_AUTH_REQUEST_AUTH_FIELDS        0x0f
+#define NDIS_802_11_AUTH_REQUEST_REAUTH			0x01
+#define NDIS_802_11_AUTH_REQUEST_KEYUPDATE		0x02
+#define NDIS_802_11_AUTH_REQUEST_PAIRWISE_ERROR		0x06
+#define NDIS_802_11_AUTH_REQUEST_GROUP_ERROR		0x0E
+
+/* MIC check time, 60 seconds. */
+#define MIC_CHECK_TIME	60000000
+
+typedef struct _NDIS_802_11_AUTHENTICATION_EVENT {
+	NDIS_802_11_STATUS_INDICATION       Status;
+	NDIS_802_11_AUTHENTICATION_REQUEST  Request[1];
+} NDIS_802_11_AUTHENTICATION_EVENT, *PNDIS_802_11_AUTHENTICATION_EVENT;
+
+typedef struct _NDIS_802_11_TEST {
+	ULONG Length;
+	ULONG Type;
+	union {
+		NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;
+		NDIS_802_11_RSSI RssiTrigger;
+	} tt;
+} NDIS_802_11_TEST, *PNDIS_802_11_TEST;
+
+
+#endif /* PLATFORM_FREEBSD */
+#ifndef Ndis802_11APMode
+#define Ndis802_11APMode (Ndis802_11InfrastructureMax+1)
+#endif
+
+typedef struct _WLAN_PHY_INFO {
+	u8	SignalStrength;/* (in percentage) */
+	u8	SignalQuality;/* (in percentage) */
+	u8	Optimum_antenna;  /* for Antenna diversity */
+	u8	is_cck_rate;	/* 1:cck_rate */
+	s8	rx_snr[4];
+#ifdef CONFIG_RTW_80211K
+	u32	free_cnt; 	/* freerun counter */
+	u8	rm_en_cap[5];
+#endif
+} WLAN_PHY_INFO, *PWLAN_PHY_INFO;
+
+typedef 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/WAPI */
+	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 */
+	unsigned short	ht_cap_info;
+	unsigned char	ht_info_infos_0;
+} WLAN_BCN_INFO, *PWLAN_BCN_INFO;
+
+enum bss_type {
+	BSS_TYPE_UNDEF,
+	BSS_TYPE_BCN = 1,
+	BSS_TYPE_PROB_REQ = 2,
+	BSS_TYPE_PROB_RSP = 3,
+};
+
+/* temporally add #pragma pack for structure alignment issue of
+*   WLAN_BSSID_EX and get_WLAN_BSSID_EX_sz()
+*/
+#ifdef PLATFORM_WINDOWS
+#pragma pack(push)
+#pragma pack(1)
+#endif
+typedef struct _WLAN_BSSID_EX {
+	ULONG  Length;
+	NDIS_802_11_MAC_ADDRESS  MacAddress;
+	UCHAR  Reserved[2];/* [0]: IS beacon frame , bss_type*/
+	NDIS_802_11_SSID  Ssid;
+	NDIS_802_11_SSID  mesh_id;
+	ULONG  Privacy;
+	NDIS_802_11_RSSI  Rssi;/* (in dBM,raw data ,get from PHY) */
+	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
+	NDIS_802_11_CONFIGURATION  Configuration;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
+	NDIS_802_11_RATES_EX  SupportedRates;
+	WLAN_PHY_INFO	PhyInfo;
+	ULONG  IELength;
+	UCHAR  IEs[MAX_IE_SZ];	/* (timestamp, beacon interval, and capability information) */
+}
+#ifndef PLATFORM_WINDOWS
+__attribute__((packed))
+#endif
+WLAN_BSSID_EX, *PWLAN_BSSID_EX;
+#ifdef PLATFORM_WINDOWS
+#pragma pack(pop)
+#endif
+
+#define BSS_EX_IES(bss_ex) ((bss_ex)->IEs)
+#define BSS_EX_IES_LEN(bss_ex) ((bss_ex)->IELength)
+#define BSS_EX_FIXED_IE_OFFSET(bss_ex) ((bss_ex)->Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12)
+#define BSS_EX_TLV_IES(bss_ex) (BSS_EX_IES((bss_ex)) + BSS_EX_FIXED_IE_OFFSET((bss_ex)))
+#define BSS_EX_TLV_IES_LEN(bss_ex) (BSS_EX_IES_LEN((bss_ex)) - BSS_EX_FIXED_IE_OFFSET((bss_ex)))
+
+__inline  static uint get_WLAN_BSSID_EX_sz(WLAN_BSSID_EX *bss)
+{
+#if 0
+	uint t_len;
+
+	t_len = sizeof(ULONG)
+		+ sizeof(NDIS_802_11_MAC_ADDRESS)
+		+ 2
+		+ sizeof(NDIS_802_11_SSID)
+		+ sizeof(ULONG)
+		+ sizeof(NDIS_802_11_RSSI)
+		+ sizeof(NDIS_802_11_NETWORK_TYPE)
+		+ sizeof(NDIS_802_11_CONFIGURATION)
+		+ sizeof(NDIS_802_11_NETWORK_INFRASTRUCTURE)
+		+ sizeof(NDIS_802_11_RATES_EX)
+		/* all new member add here */
+		+ sizeof(WLAN_PHY_INFO)
+		/* all new member add here */
+		+ sizeof(ULONG)
+		+ bss->IELength;
+	return t_len;
+#else
+	return sizeof(WLAN_BSSID_EX) - MAX_IE_SZ + bss->IELength;
+#endif
+}
+
+struct	wlan_network {
+	_list	list;
+	int	network_type;	/* refer to ieee80211.h for WIRELESS_11A/B/G */
+	int	fixed;			/* set to fixed when not to be removed as site-surveying */
+	systime last_scanned; /* timestamp for the network */
+	int	aid;			/* will only be valid when a BSS is joinned. */
+	int	join_res;
+	WLAN_BSSID_EX	network; /* must be the last item */
+	WLAN_BCN_INFO	BcnInfo;
+#ifdef PLATFORM_WINDOWS
+	unsigned char  iebuf[MAX_IE_SZ];
+#endif
+
+};
+
+enum VRTL_CARRIER_SENSE {
+	DISABLE_VCS,
+	ENABLE_VCS,
+	AUTO_VCS
+};
+
+enum VCS_TYPE {
+	NONE_VCS,
+	RTS_CTS,
+	CTS_TO_SELF
+};
+
+
+
+
+#define PWR_CAM 0
+#define PWR_MINPS 1
+#define PWR_MAXPS 2
+#define PWR_UAPSD 3
+#define PWR_VOIP 4
+
+
+enum UAPSD_MAX_SP {
+	NO_LIMIT,
+	TWO_MSDU,
+	FOUR_MSDU,
+	SIX_MSDU
+};
+
+
+/* john */
+#define NUM_PRE_AUTH_KEY 16
+#define NUM_PMKID_CACHE NUM_PRE_AUTH_KEY
+
+/*
+*	WPA2
+*/
+
+#ifndef PLATFORM_OS_CE
+typedef struct _PMKID_CANDIDATE {
+	NDIS_802_11_MAC_ADDRESS BSSID;
+	ULONG Flags;
+} PMKID_CANDIDATE, *PPMKID_CANDIDATE;
+
+typedef struct _NDIS_802_11_PMKID_CANDIDATE_LIST {
+	ULONG Version;       /* Version of the structure */
+	ULONG NumCandidates; /* No. of pmkid candidates */
+	PMKID_CANDIDATE CandidateList[1];
+} NDIS_802_11_PMKID_CANDIDATE_LIST, *PNDIS_802_11_PMKID_CANDIDATE_LIST;
+
+
+typedef struct _NDIS_802_11_AUTHENTICATION_ENCRYPTION {
+	NDIS_802_11_AUTHENTICATION_MODE AuthModeSupported;
+	NDIS_802_11_ENCRYPTION_STATUS EncryptStatusSupported;
+
+} NDIS_802_11_AUTHENTICATION_ENCRYPTION, *PNDIS_802_11_AUTHENTICATION_ENCRYPTION;
+
+typedef struct _NDIS_802_11_CAPABILITY {
+	ULONG  Length;
+	ULONG  Version;
+	ULONG  NoOfPMKIDs;
+	ULONG  NoOfAuthEncryptPairsSupported;
+	NDIS_802_11_AUTHENTICATION_ENCRYPTION AuthenticationEncryptionSupported[1];
+
+} NDIS_802_11_CAPABILITY, *PNDIS_802_11_CAPABILITY;
+#endif
+
+
+#endif /* #ifndef WLAN_BSSDEF_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/xmit_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/xmit_osdep.h
new file mode 100644
index 000000000000..70070a890fa1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/include/xmit_osdep.h
@@ -0,0 +1,94 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+struct pkt_file {
+	_pkt *pkt;
+	SIZE_T pkt_len;	 /* the remainder length of the open_file */
+	_buffer *cur_buffer;
+	u8 *buf_start;
+	u8 *cur_addr;
+	SIZE_T buf_len;
+};
+
+#ifdef PLATFORM_WINDOWS
+
+#ifdef PLATFORM_OS_XP
+#ifdef CONFIG_USB_HCI
+#include <usb.h>
+#include <usbdlib.h>
+#include <usbioctl.h>
+#endif
+#endif
+
+#ifdef CONFIG_GSPI_HCI
+	#define NR_XMITFRAME     64
+#else
+	#define NR_XMITFRAME     128
+#endif
+
+#define ETH_ALEN	6
+
+extern NDIS_STATUS rtw_xmit_entry(
+	IN _nic_hdl		cnxt,
+	IN NDIS_PACKET		*pkt,
+	IN UINT				flags
+);
+
+#endif /* PLATFORM_WINDOWS */
+
+#ifdef PLATFORM_FREEBSD
+#define NR_XMITFRAME	256
+extern int rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev);
+extern void rtw_xmit_entry_wrap(struct ifnet *pifp);
+#endif /* PLATFORM_FREEBSD */
+
+#ifdef PLATFORM_LINUX
+
+#define NR_XMITFRAME	256
+
+struct xmit_priv;
+struct pkt_attrib;
+struct sta_xmit_priv;
+struct xmit_frame;
+struct xmit_buf;
+
+extern int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev);
+extern int rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev);
+
+#endif /* PLATFORM_LINUX */
+
+void rtw_os_xmit_schedule(_adapter *padapter);
+
+int rtw_os_xmit_resource_alloc(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 alloc_sz, u8 flag);
+void rtw_os_xmit_resource_free(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 free_sz, u8 flag);
+
+extern void rtw_set_tx_chksum_offload(_pkt *pkt, struct pkt_attrib *pattrib);
+
+extern uint rtw_remainder_len(struct pkt_file *pfile);
+extern void _rtw_open_pktfile(_pkt *pkt, struct pkt_file *pfile);
+extern uint _rtw_pktfile_read(struct pkt_file *pfile, u8 *rmem, uint rlen);
+extern sint rtw_endofpktfile(struct pkt_file *pfile);
+
+extern void rtw_os_pkt_complete(_adapter *padapter, _pkt *pkt);
+extern void rtw_os_xmit_complete(_adapter *padapter, struct xmit_frame *pxframe);
+
+void rtw_os_wake_queue_at_free_stainfo(_adapter *padapter, int *qcnt_freed);
+
+void dump_os_queue(void *sel, _adapter *padapter);
+
+#endif /* __XMIT_OSDEP_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/custom_gpio_linux.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/custom_gpio_linux.c
new file mode 100644
index 000000000000..23401b7d6b7c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/custom_gpio_linux.c
@@ -0,0 +1,340 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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"
+
+#ifdef CONFIG_PLATFORM_SPRD
+
+/* gspi func & GPIO define */
+#include <mach/gpio.h>/* 0915 */
+#include <mach/board.h>
+
+#if !(defined ANDROID_2X)
+
+#ifdef CONFIG_RTL8188E
+#include <mach/regulator.h>
+#include <linux/regulator/consumer.h>
+#endif /* CONFIG_RTL8188E */
+
+#ifndef GPIO_WIFI_POWER
+#define GPIO_WIFI_POWER -1
+#endif /* !GPIO_WIFI_POWER */
+
+#ifndef GPIO_WIFI_RESET
+#define GPIO_WIFI_RESET -1
+#endif /* !GPIO_WIFI_RESET */
+
+#ifndef GPIO_WIFI_PWDN
+#define GPIO_WIFI_PWDN -1
+#endif /* !GPIO_WIFI_RESET */
+#ifdef CONFIG_GSPI_HCI
+extern unsigned int oob_irq;
+#endif /* CONFIG_GSPI_HCI */
+
+#ifdef CONFIG_SDIO_HCI
+extern int rtw_mp_mode;
+#else /* !CONFIG_SDIO_HCI */
+#endif /* !CONFIG_SDIO_HCI */
+
+int rtw_wifi_gpio_init(void)
+{
+#ifdef CONFIG_GSPI_HCI
+	if (GPIO_WIFI_IRQ > 0) {
+		gpio_request(GPIO_WIFI_IRQ, "oob_irq");
+		gpio_direction_input(GPIO_WIFI_IRQ);
+
+		oob_irq = gpio_to_irq(GPIO_WIFI_IRQ);
+
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
+	}
+#endif
+	if (GPIO_WIFI_RESET > 0)
+		gpio_request(GPIO_WIFI_RESET , "wifi_rst");
+	if (GPIO_WIFI_POWER > 0)
+		gpio_request(GPIO_WIFI_POWER, "wifi_power");
+
+#ifdef CONFIG_SDIO_HCI
+#if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
+	if (rtw_mp_mode == 1) {
+		RTW_INFO("%s GPIO_BT_RESET pin special for mp_test\n", __func__);
+		if (GPIO_BT_RESET > 0)
+			gpio_request(GPIO_BT_RESET , "bt_rst");
+	}
+#endif
+#endif
+	return 0;
+}
+
+int rtw_wifi_gpio_deinit(void)
+{
+#ifdef CONFIG_GSPI_HCI
+	if (GPIO_WIFI_IRQ > 0)
+		gpio_free(GPIO_WIFI_IRQ);
+#endif
+	if (GPIO_WIFI_RESET > 0)
+		gpio_free(GPIO_WIFI_RESET);
+	if (GPIO_WIFI_POWER > 0)
+		gpio_free(GPIO_WIFI_POWER);
+
+#ifdef CONFIG_SDIO_HCI
+#if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
+	if (rtw_mp_mode == 1) {
+		RTW_INFO("%s GPIO_BT_RESET pin special for mp_test\n", __func__);
+		if (GPIO_BT_RESET > 0)
+			gpio_free(GPIO_BT_RESET);
+	}
+#endif
+#endif
+	return 0;
+}
+
+/* Customer function to control hw specific wlan gpios */
+void rtw_wifi_gpio_wlan_ctrl(int onoff)
+{
+	switch (onoff) {
+	case WLAN_PWDN_OFF:
+		RTW_INFO("%s: call customer specific GPIO(%d) to set wifi power down pin to 0\n",
+			 __FUNCTION__, GPIO_WIFI_RESET);
+
+#ifndef CONFIG_DONT_BUS_SCAN
+		if (GPIO_WIFI_RESET > 0)
+			gpio_direction_output(GPIO_WIFI_RESET , 0);
+#endif
+		break;
+
+	case WLAN_PWDN_ON:
+		RTW_INFO("%s: callc customer specific GPIO(%d) to set wifi power down pin to 1\n",
+			 __FUNCTION__, GPIO_WIFI_RESET);
+
+		if (GPIO_WIFI_RESET > 0)
+			gpio_direction_output(GPIO_WIFI_RESET , 1);
+		break;
+
+	case WLAN_POWER_OFF:
+		break;
+
+	case WLAN_POWER_ON:
+		break;
+#ifdef CONFIG_SDIO_HCI
+#if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
+	case WLAN_BT_PWDN_OFF:
+		if (rtw_mp_mode == 1) {
+			RTW_INFO("%s: call customer specific GPIO to set wifi power down pin to 0\n",
+				 __FUNCTION__);
+			if (GPIO_BT_RESET > 0)
+				gpio_direction_output(GPIO_BT_RESET , 0);
+		}
+		break;
+
+	case WLAN_BT_PWDN_ON:
+		if (rtw_mp_mode == 1) {
+			RTW_INFO("%s: callc customer specific GPIO to set wifi power down pin to 1 %x\n",
+				 __FUNCTION__, GPIO_BT_RESET);
+
+			if (GPIO_BT_RESET > 0)
+				gpio_direction_output(GPIO_BT_RESET , 1);
+		}
+		break;
+#endif
+#endif
+	}
+}
+
+#else /* ANDROID_2X */
+
+#include <mach/ldo.h>
+
+#ifdef CONFIG_RTL8188E
+extern int sprd_3rdparty_gpio_wifi_power;
+#endif
+extern int sprd_3rdparty_gpio_wifi_pwd;
+#if  defined(CONFIG_RTL8723B)
+extern int sprd_3rdparty_gpio_bt_reset;
+#endif
+
+int rtw_wifi_gpio_init(void)
+{
+#if defined(CONFIG_RTL8723B)
+	if (sprd_3rdparty_gpio_bt_reset > 0)
+		gpio_direction_output(sprd_3rdparty_gpio_bt_reset, 1);
+#endif
+
+	return 0;
+}
+
+int rtw_wifi_gpio_deinit(void)
+{
+	return 0;
+}
+
+/* Customer function to control hw specific wlan gpios */
+void rtw_wifi_gpio_wlan_ctrl(int onoff)
+{
+	switch (onoff) {
+	case WLAN_PWDN_OFF:
+		RTW_INFO("%s: call customer specific GPIO to set wifi power down pin to 0\n",
+			 __FUNCTION__);
+		if (sprd_3rdparty_gpio_wifi_pwd > 0)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 0);
+
+		if (sprd_3rdparty_gpio_wifi_pwd == 60) {
+			RTW_INFO("%s: turn off VSIM2 2.8V\n", __func__);
+			LDO_TurnOffLDO(LDO_LDO_SIM2);
+		}
+		break;
+
+	case WLAN_PWDN_ON:
+		RTW_INFO("%s: callc customer specific GPIO to set wifi power down pin to 1\n",
+			 __FUNCTION__);
+		if (sprd_3rdparty_gpio_wifi_pwd == 60) {
+			RTW_INFO("%s: turn on VSIM2 2.8V\n", __func__);
+			LDO_SetVoltLevel(LDO_LDO_SIM2, LDO_VOLT_LEVEL0);
+			LDO_TurnOnLDO(LDO_LDO_SIM2);
+		}
+		if (sprd_3rdparty_gpio_wifi_pwd > 0)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 1);
+		break;
+
+	case WLAN_POWER_OFF:
+#ifdef CONFIG_RTL8188E
+#ifdef CONFIG_WIF1_LDO
+		RTW_INFO("%s: turn off VDD-WIFI0 1.2V\n", __FUNCTION__);
+		LDO_TurnOffLDO(LDO_LDO_WIF1);
+#endif /* CONFIG_WIF1_LDO */
+
+		RTW_INFO("%s: turn off VDD-WIFI0 3.3V\n", __FUNCTION__);
+		LDO_TurnOffLDO(LDO_LDO_WIF0);
+
+		RTW_INFO("%s: call customer specific GPIO(%d) to turn off wifi power\n",
+			 __FUNCTION__, sprd_3rdparty_gpio_wifi_power);
+		if (sprd_3rdparty_gpio_wifi_power != 65535)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_power, 0);
+#endif
+		break;
+
+	case WLAN_POWER_ON:
+#ifdef CONFIG_RTL8188E
+		RTW_INFO("%s: call customer specific GPIO(%d) to turn on wifi power\n",
+			 __FUNCTION__, sprd_3rdparty_gpio_wifi_power);
+		if (sprd_3rdparty_gpio_wifi_power != 65535)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_power, 1);
+
+		RTW_INFO("%s: turn on VDD-WIFI0 3.3V\n", __FUNCTION__);
+		LDO_TurnOnLDO(LDO_LDO_WIF0);
+		LDO_SetVoltLevel(LDO_LDO_WIF0, LDO_VOLT_LEVEL1);
+
+#ifdef CONFIG_WIF1_LDO
+		RTW_INFO("%s: turn on VDD-WIFI1 1.2V\n", __func__);
+		LDO_TurnOnLDO(LDO_LDO_WIF1);
+		LDO_SetVoltLevel(LDO_LDO_WIF1, LDO_VOLT_LEVEL3);
+#endif /* CONFIG_WIF1_LDO */
+#endif
+		break;
+
+	case WLAN_BT_PWDN_OFF:
+		RTW_INFO("%s: call customer specific GPIO to set bt power down pin to 0\n",
+			 __FUNCTION__);
+#if defined(CONFIG_RTL8723B)
+		if (sprd_3rdparty_gpio_bt_reset > 0)
+			gpio_set_value(sprd_3rdparty_gpio_bt_reset, 0);
+#endif
+		break;
+
+	case WLAN_BT_PWDN_ON:
+		RTW_INFO("%s: callc customer specific GPIO to set bt power down pin to 1\n",
+			 __FUNCTION__);
+#if defined(CONFIG_RTL8723B)
+		if (sprd_3rdparty_gpio_bt_reset > 0)
+			gpio_set_value(sprd_3rdparty_gpio_bt_reset, 1);
+#endif
+		break;
+	}
+}
+#endif /* ANDROID_2X */
+
+#elif defined(CONFIG_PLATFORM_ARM_RK3066)
+#include <mach/iomux.h>
+
+#define GPIO_WIFI_IRQ		RK30_PIN2_PC2
+extern unsigned int oob_irq;
+int rtw_wifi_gpio_init(void)
+{
+#ifdef CONFIG_GSPI_HCI
+	if (GPIO_WIFI_IRQ > 0) {
+		rk30_mux_api_set(GPIO2C2_LCDC1DATA18_SMCBLSN1_HSADCDATA5_NAME, GPIO2C_GPIO2C2);/* jacky_test */
+		gpio_request(GPIO_WIFI_IRQ, "oob_irq");
+		gpio_direction_input(GPIO_WIFI_IRQ);
+
+		oob_irq = gpio_to_irq(GPIO_WIFI_IRQ);
+
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
+	}
+#endif
+	return 0;
+}
+
+
+int rtw_wifi_gpio_deinit(void)
+{
+#ifdef CONFIG_GSPI_HCI
+	if (GPIO_WIFI_IRQ > 0)
+		gpio_free(GPIO_WIFI_IRQ);
+#endif
+	return 0;
+}
+
+void rtw_wifi_gpio_wlan_ctrl(int onoff)
+{
+}
+
+#ifdef CONFIG_GPIO_API
+/* this is a demo for extending GPIO pin[7] as interrupt mode */
+struct net_device *rtl_net;
+extern int rtw_register_gpio_interrupt(struct net_device *netdev, int gpio_num, void(*callback)(u8 level));
+extern int rtw_disable_gpio_interrupt(struct net_device *netdev, int gpio_num);
+void gpio_int(u8 is_high)
+{
+	RTW_INFO("%s level=%d\n", __func__, is_high);
+}
+int register_net_gpio_init(void)
+{
+	rtl_net = dev_get_by_name(&init_net, "wlan0");
+	if (!rtl_net) {
+		RTW_PRINT("rtl_net init fail!\n");
+		return -1;
+	}
+	return rtw_register_gpio_interrupt(rtl_net, 7, gpio_int);
+}
+int unregister_net_gpio_init(void)
+{
+	rtl_net = dev_get_by_name(&init_net, "wlan0");
+	if (!rtl_net) {
+		RTW_PRINT("rtl_net init fail!\n");
+		return -1;
+	}
+	return rtw_disable_gpio_interrupt(rtl_net, 7);
+}
+#endif
+
+#else
+
+int rtw_wifi_gpio_init(void)
+{
+	return 0;
+}
+
+void rtw_wifi_gpio_wlan_ctrl(int onoff)
+{
+}
+#endif /* CONFIG_PLATFORM_SPRD */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_cfg80211.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_cfg80211.c
new file mode 100644
index 000000000000..e7e893091eef
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_cfg80211.c
@@ -0,0 +1,9674 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+#include <hal_data.h>
+
+#ifdef CONFIG_IOCTL_CFG80211
+
+#ifndef DBG_RTW_CFG80211_STA_PARAM
+#define DBG_RTW_CFG80211_STA_PARAM 0
+#endif
+
+#ifndef DBG_RTW_CFG80211_MESH_CONF
+#define DBG_RTW_CFG80211_MESH_CONF 0
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 0, 0))
+#define STATION_INFO_INACTIVE_TIME	BIT(NL80211_STA_INFO_INACTIVE_TIME)
+#define STATION_INFO_LLID			BIT(NL80211_STA_INFO_LLID)
+#define STATION_INFO_PLID			BIT(NL80211_STA_INFO_PLID)
+#define STATION_INFO_PLINK_STATE	BIT(NL80211_STA_INFO_PLINK_STATE)
+#define STATION_INFO_SIGNAL			BIT(NL80211_STA_INFO_SIGNAL)
+#define STATION_INFO_TX_BITRATE		BIT(NL80211_STA_INFO_TX_BITRATE)
+#define STATION_INFO_RX_PACKETS		BIT(NL80211_STA_INFO_RX_PACKETS)
+#define STATION_INFO_TX_PACKETS		BIT(NL80211_STA_INFO_TX_PACKETS)
+#define STATION_INFO_TX_FAILED		BIT(NL80211_STA_INFO_TX_FAILED)
+#define STATION_INFO_LOCAL_PM		BIT(NL80211_STA_INFO_LOCAL_PM)
+#define STATION_INFO_PEER_PM		BIT(NL80211_STA_INFO_PEER_PM)
+#define STATION_INFO_NONPEER_PM		BIT(NL80211_STA_INFO_NONPEER_PM)
+#define STATION_INFO_ASSOC_REQ_IES	0
+#endif /* Linux kernel >= 4.0.0 */
+
+#include <rtw_wifi_regd.h>
+
+#define RTW_MAX_MGMT_TX_CNT (8)
+#define RTW_MAX_MGMT_TX_MS_GAS (500)
+
+#define RTW_SCAN_IE_LEN_MAX      2304
+#define RTW_MAX_REMAIN_ON_CHANNEL_DURATION 5000 /* ms */
+#define RTW_MAX_NUM_PMKIDS 4
+
+#define RTW_CH_MAX_2G_CHANNEL               14      /* Max channel in 2G band */
+
+#ifdef CONFIG_WAPI_SUPPORT
+
+#ifndef WLAN_CIPHER_SUITE_SMS4
+#define WLAN_CIPHER_SUITE_SMS4          0x00147201
+#endif
+
+#ifndef WLAN_AKM_SUITE_WAPI_PSK
+#define WLAN_AKM_SUITE_WAPI_PSK         0x000FAC04
+#endif
+
+#ifndef WLAN_AKM_SUITE_WAPI_CERT
+#define WLAN_AKM_SUITE_WAPI_CERT        0x000FAC12
+#endif
+
+#ifndef NL80211_WAPI_VERSION_1
+#define NL80211_WAPI_VERSION_1          (1 << 2)
+#endif
+
+#endif /* CONFIG_WAPI_SUPPORT */
+
+#ifdef CONFIG_RTW_80211R
+#define WLAN_AKM_SUITE_FT_8021X		0x000FAC03
+#define WLAN_AKM_SUITE_FT_PSK			0x000FAC04
+#endif
+
+/*
+ * In the current design of Wi-Fi driver, it will return success to the system (e.g. supplicant) 
+ * when Wi-Fi driver decides to abort the scan request in the scan flow by default.
+ * Defining this flag makes Wi-Fi driver to return -EBUSY to the system if Wi-Fi driver is too busy to do the scan.
+ */
+#ifndef CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY
+	#define CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY 0
+#endif
+
+static const u32 rtw_cipher_suites[] = {
+	WLAN_CIPHER_SUITE_WEP40,
+	WLAN_CIPHER_SUITE_WEP104,
+	WLAN_CIPHER_SUITE_TKIP,
+	WLAN_CIPHER_SUITE_CCMP,
+#ifdef CONFIG_WAPI_SUPPORT
+	WLAN_CIPHER_SUITE_SMS4,
+#endif /* CONFIG_WAPI_SUPPORT */
+#ifdef CONFIG_IEEE80211W
+	WLAN_CIPHER_SUITE_AES_CMAC,
+#endif /* CONFIG_IEEE80211W */
+};
+
+#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,				\
+	}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+/* if wowlan is not supported, kernel generate a disconnect at each suspend
+ * cf: /net/wireless/sysfs.c, so register a stub wowlan.
+ * Moreover wowlan has to be enabled via a the nl80211_set_wowlan callback.
+ * (from user space, e.g. iw phy0 wowlan enable)
+ */
+static const struct wiphy_wowlan_support wowlan_stub = {
+	.flags = WIPHY_WOWLAN_ANY,
+	.n_patterns = 0,
+	.pattern_max_len = 0,
+	.pattern_min_len = 0,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	.max_pkt_offset = 0,
+#endif
+};
+#endif
+
+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
+
+/* from center_ch_2g */
+static struct ieee80211_channel rtw_2ghz_channels[MAX_CHANNEL_NUM_2G] = {
+	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),
+};
+
+/* from center_ch_5g_20m */
+static struct ieee80211_channel rtw_5ghz_a_channels[MAX_CHANNEL_NUM_5G] = {
+	CHAN5G(36, 0),	CHAN5G(40, 0),	CHAN5G(44, 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(144, 0),
+
+	CHAN5G(149, 0),	CHAN5G(153, 0),	CHAN5G(157, 0),	CHAN5G(161, 0),
+	CHAN5G(165, 0),	CHAN5G(169, 0),	CHAN5G(173, 0),	CHAN5G(177, 0),
+};
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+static const char *nl80211_channel_type_str(enum nl80211_channel_type ctype)
+{
+	switch (ctype) {
+	case NL80211_CHAN_NO_HT:
+		return "NO_HT";
+	case NL80211_CHAN_HT20:
+		return "HT20";
+	case NL80211_CHAN_HT40MINUS:
+		return "HT40-";
+	case NL80211_CHAN_HT40PLUS:
+		return "HT40+";
+	default:
+		return "INVALID";
+	};
+}
+
+static enum nl80211_channel_type rtw_chbw_to_nl80211_channel_type(u8 ch, u8 bw, u8 offset, u8 ht)
+{
+	rtw_warn_on(!ht && (bw >= CHANNEL_WIDTH_40 || offset != HAL_PRIME_CHNL_OFFSET_DONT_CARE));
+
+	if (!ht)
+		return NL80211_CHAN_NO_HT;
+	if (bw >= CHANNEL_WIDTH_40) {
+		if (offset == HAL_PRIME_CHNL_OFFSET_UPPER)
+			return NL80211_CHAN_HT40MINUS;
+		else if (offset == HAL_PRIME_CHNL_OFFSET_LOWER)
+			return NL80211_CHAN_HT40PLUS;
+		else
+			rtw_warn_on(1);
+	}
+	return NL80211_CHAN_HT20;
+}
+
+static void rtw_get_chbw_from_nl80211_channel_type(struct ieee80211_channel *chan, enum nl80211_channel_type ctype, u8 *ht, u8 *ch, u8 *bw, u8 *offset)
+{
+	int pri_freq;
+
+	pri_freq = rtw_ch2freq(chan->hw_value);
+	if (!pri_freq) {
+		RTW_INFO("invalid channel:%d\n", chan->hw_value);
+		rtw_warn_on(1);
+		*ch = 0;
+		return;
+	}
+	*ch = chan->hw_value;
+
+	switch (ctype) {
+	case NL80211_CHAN_NO_HT:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT20:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT40MINUS:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_40;
+		*offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_HT40PLUS:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_40;
+		*offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+	default:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		RTW_INFO("unsupported ctype:%s\n", nl80211_channel_type_str(ctype));
+		rtw_warn_on(1);
+	};
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29)) */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+static const char *nl80211_chan_width_str(enum nl80211_chan_width cwidth)
+{
+	switch (cwidth) {
+	case NL80211_CHAN_WIDTH_20_NOHT:
+		return "20_NOHT";
+	case NL80211_CHAN_WIDTH_20:
+		return "20";
+	case NL80211_CHAN_WIDTH_40:
+		return "40";
+	case NL80211_CHAN_WIDTH_80:
+		return "80";
+	case NL80211_CHAN_WIDTH_80P80:
+		return "80+80";
+	case NL80211_CHAN_WIDTH_160:
+		return "160";
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	case NL80211_CHAN_WIDTH_5:
+		return "5";
+	case NL80211_CHAN_WIDTH_10:
+		return "10";
+#endif
+	default:
+		return "INVALID";
+	};
+}
+
+static u8 rtw_chbw_to_cfg80211_chan_def(struct wiphy *wiphy, struct cfg80211_chan_def *chdef, u8 ch, u8 bw, u8 offset, u8 ht)
+{
+	int freq, cfreq;
+	struct ieee80211_channel *chan;
+	u8 ret = _FAIL;
+
+	freq = rtw_ch2freq(ch);
+	if (!freq)
+		goto exit;
+
+	cfreq = rtw_get_center_ch(ch, bw, offset);
+	if (!cfreq)
+		goto exit;
+	cfreq = rtw_ch2freq(cfreq);
+	if (!cfreq)
+		goto exit;
+
+	chan = ieee80211_get_channel(wiphy, freq);
+	if (!chan)
+		goto exit;
+
+	if (bw == CHANNEL_WIDTH_20) 
+		chdef->width = ht ? NL80211_CHAN_WIDTH_20 : NL80211_CHAN_WIDTH_20_NOHT;
+	else if (bw == CHANNEL_WIDTH_40)
+		chdef->width = NL80211_CHAN_WIDTH_40;
+	else if (bw == CHANNEL_WIDTH_80)
+		chdef->width = NL80211_CHAN_WIDTH_80;
+	else if (bw == CHANNEL_WIDTH_160)
+		chdef->width = NL80211_CHAN_WIDTH_160;
+	else {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	chdef->chan = chan;
+	chdef->center_freq1 = cfreq;
+	chdef->center_freq2 = 0;
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+static void rtw_get_chbw_from_cfg80211_chan_def(struct cfg80211_chan_def *chdef, u8 *ht, u8 *ch, u8 *bw, u8 *offset)
+{
+	int pri_freq;
+	struct ieee80211_channel *chan = chdef->chan;
+
+	pri_freq = rtw_ch2freq(chan->hw_value);
+	if (!pri_freq) {
+		RTW_INFO("invalid channel:%d\n", chan->hw_value);
+		rtw_warn_on(1);
+		*ch = 0;
+		return;
+	}		
+
+	switch (chdef->width) {
+	case NL80211_CHAN_WIDTH_20_NOHT:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_20:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_40:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_40;
+		*offset = pri_freq > chdef->center_freq1 ? HAL_PRIME_CHNL_OFFSET_UPPER : HAL_PRIME_CHNL_OFFSET_LOWER;
+		if (rtw_get_offset_by_chbw(chan->hw_value, *bw, offset))
+			*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_80:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_80;
+		if (rtw_get_offset_by_chbw(chan->hw_value, *bw, offset))
+			*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_160:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_160;
+		if (rtw_get_offset_by_chbw(chan->hw_value, *bw, offset))
+			*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_80P80:
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	case NL80211_CHAN_WIDTH_5:
+	case NL80211_CHAN_WIDTH_10:
+	#endif
+	default:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		RTW_INFO("unsupported cwidth:%s\n", nl80211_chan_width_str(chdef->width));
+		rtw_warn_on(1);
+	};
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)) */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+u8 rtw_cfg80211_ch_switch_notify(_adapter *adapter, u8 ch, u8 bw, u8 offset, u8 ht)
+{
+	struct wiphy *wiphy = adapter_to_wiphy(adapter);
+	u8 ret = _SUCCESS;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def chdef;
+
+	ret = rtw_chbw_to_cfg80211_chan_def(wiphy, &chdef, ch, bw, offset, ht);
+	if (ret != _SUCCESS)
+		goto exit;
+
+	cfg80211_ch_switch_notify(adapter->pnetdev, &chdef);
+
+#else
+	int freq = rtw_ch2freq(ch);
+	enum nl80211_channel_type ctype;
+
+	if (!freq) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+	ctype = rtw_chbw_to_nl80211_channel_type(ch, bw, offset, ht);
+	cfg80211_ch_switch_notify(adapter->pnetdev, freq, ctype);
+#endif
+
+exit:
+	return ret;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0)) */
+
+void rtw_2g_channels_init(struct ieee80211_channel *channels)
+{
+	_rtw_memcpy((void *)channels, (void *)rtw_2ghz_channels, sizeof(rtw_2ghz_channels));
+}
+
+void rtw_5g_channels_init(struct ieee80211_channel *channels)
+{
+	_rtw_memcpy((void *)channels, (void *)rtw_5ghz_a_channels, sizeof(rtw_5ghz_a_channels));
+}
+
+void rtw_2g_rates_init(struct ieee80211_rate *rates)
+{
+	_rtw_memcpy(rates, rtw_g_rates,
+		sizeof(struct ieee80211_rate) * RTW_G_RATES_NUM
+	);
+}
+
+void rtw_5g_rates_init(struct ieee80211_rate *rates)
+{
+	_rtw_memcpy(rates, rtw_a_rates,
+		sizeof(struct ieee80211_rate) * RTW_A_RATES_NUM
+	);
+}
+
+struct ieee80211_supported_band *rtw_spt_band_alloc(BAND_TYPE band)
+{
+	struct ieee80211_supported_band *spt_band = NULL;
+	int n_channels, n_bitrates;
+
+	if (band == BAND_ON_2_4G) {
+		n_channels = MAX_CHANNEL_NUM_2G;
+		n_bitrates = RTW_G_RATES_NUM;
+	} else if (band == BAND_ON_5G) {
+		n_channels = MAX_CHANNEL_NUM_5G;
+		n_bitrates = RTW_A_RATES_NUM;
+	} else
+		goto exit;
+
+	spt_band = (struct ieee80211_supported_band *)rtw_zmalloc(
+		sizeof(struct ieee80211_supported_band)
+		+ sizeof(struct ieee80211_channel) * n_channels
+		+ sizeof(struct ieee80211_rate) * n_bitrates
+	);
+	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 = rtw_band_to_nl80211_band(band);
+	spt_band->n_channels = n_channels;
+	spt_band->n_bitrates = n_bitrates;
+
+	if (band == BAND_ON_2_4G) {
+		rtw_2g_channels_init(spt_band->channels);
+		rtw_2g_rates_init(spt_band->bitrates);
+	} else if (band == BAND_ON_5G) {
+		rtw_5g_channels_init(spt_band->channels);
+		rtw_5g_rates_init(spt_band->bitrates);
+	}
+
+	/* spt_band.ht_cap */
+
+exit:
+
+	return spt_band;
+}
+
+void rtw_spt_band_free(struct ieee80211_supported_band *spt_band)
+{
+	u32 size = 0;
+
+	if (!spt_band)
+		return;
+
+	if (spt_band->band == NL80211_BAND_2GHZ) {
+		size = sizeof(struct ieee80211_supported_band)
+			+ sizeof(struct ieee80211_channel) * MAX_CHANNEL_NUM_2G
+			+ sizeof(struct ieee80211_rate) * RTW_G_RATES_NUM;
+	} else if (spt_band->band == NL80211_BAND_5GHZ) {
+		size = sizeof(struct ieee80211_supported_band)
+			+ sizeof(struct ieee80211_channel) * MAX_CHANNEL_NUM_5G
+			+ sizeof(struct ieee80211_rate) * RTW_A_RATES_NUM;
+	} else {
+
+	}
+	rtw_mfree((u8 *)spt_band, size);
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+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)
+	},
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+	[NL80211_IFTYPE_P2P_DEVICE] = {
+		.tx = 0xffff,
+		.rx = BIT(IEEE80211_STYPE_ACTION >> 4) |
+			BIT(IEEE80211_STYPE_PROBE_REQ >> 4)
+	},
+#endif
+#if defined(CONFIG_RTW_MESH)
+	[NL80211_IFTYPE_MESH_POINT] = {
+		.tx = 0xffff,
+		.rx = BIT(IEEE80211_STYPE_ACTION >> 4)
+			| BIT(IEEE80211_STYPE_AUTH >> 4)
+	},
+#endif
+
+};
+#endif
+
+NDIS_802_11_NETWORK_INFRASTRUCTURE nl80211_iftype_to_rtw_network_type(enum nl80211_iftype type)
+{
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		return Ndis802_11IBSS;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	#endif
+	case NL80211_IFTYPE_STATION:
+		return Ndis802_11Infrastructure;
+
+#ifdef CONFIG_AP_MODE
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+	#endif
+	case NL80211_IFTYPE_AP:
+		return Ndis802_11APMode;
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		return Ndis802_11_mesh;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		return Ndis802_11Monitor;
+
+	default:
+		return Ndis802_11InfrastructureMax;
+	}
+}
+
+u32 nl80211_iftype_to_rtw_mlme_state(enum nl80211_iftype type)
+{
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		return WIFI_ADHOC_STATE;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	#endif
+	case NL80211_IFTYPE_STATION:
+		return WIFI_STATION_STATE;
+
+#ifdef CONFIG_AP_MODE
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+	#endif
+	case NL80211_IFTYPE_AP:
+		return WIFI_AP_STATE;
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		return WIFI_MESH_STATE;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		return WIFI_MONITOR_STATE;
+
+	default:
+		return WIFI_NULL_STATE;
+	}
+}
+
+static int rtw_cfg80211_sync_iftype(_adapter *adapter)
+{
+	struct wireless_dev *rtw_wdev = adapter->rtw_wdev;
+
+	if (!(nl80211_iftype_to_rtw_mlme_state(rtw_wdev->iftype) & MLME_STATE(adapter))) {
+		/* iftype and mlme state is not syc */
+		NDIS_802_11_NETWORK_INFRASTRUCTURE network_type;
+
+		network_type = nl80211_iftype_to_rtw_network_type(rtw_wdev->iftype);
+		if (network_type != Ndis802_11InfrastructureMax) {
+			if (rtw_pwr_wakeup(adapter) == _FAIL) {
+				RTW_WARN(FUNC_ADPT_FMT" call rtw_pwr_wakeup fail\n", FUNC_ADPT_ARG(adapter));
+				return _FAIL;
+			}
+
+			rtw_set_802_11_infrastructure_mode(adapter, network_type);
+			rtw_setopmode_cmd(adapter, network_type, RTW_CMDF_WAIT_ACK);
+		} else {
+			rtw_warn_on(1);
+			RTW_WARN(FUNC_ADPT_FMT" iftype:%u is not support\n", FUNC_ADPT_ARG(adapter), rtw_wdev->iftype);
+			return _FAIL;
+		}
+	}
+
+	return _SUCCESS;
+}
+
+static u64 rtw_get_systime_us(void)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39))
+	struct timespec ts;
+	get_monotonic_boottime(&ts);
+	return ((u64)ts.tv_sec * 1000000) + ts.tv_nsec / 1000;
+#else
+	struct timeval tv;
+	do_gettimeofday(&tv);
+	return ((u64)tv.tv_sec * 1000000) + tv.tv_usec;
+#endif
+}
+
+/* Try to remove non target BSS's SR to reduce PBC overlap rate */
+static int rtw_cfg80211_clear_wps_sr_of_non_target_bss(_adapter *padapter, struct wlan_network *pnetwork, struct cfg80211_ssid *req_ssid)
+{
+	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(padapter);
+	int ret = 0;
+	u8 *psr = NULL, sr = 0;
+	NDIS_802_11_SSID *pssid = &pnetwork->network.Ssid;
+	u32 wpsielen = 0;
+	u8 *wpsie = NULL;
+
+	if (pssid->SsidLength == req_ssid->ssid_len
+		&& _rtw_memcmp(pssid->Ssid, req_ssid->ssid, req_ssid->ssid_len) == _TRUE)
+		goto exit;
+
+	wpsie = rtw_get_wps_ie(pnetwork->network.IEs + _FIXED_IE_LENGTH_
+		, pnetwork->network.IELength - _FIXED_IE_LENGTH_, NULL, &wpsielen);
+	if (wpsie && wpsielen > 0)
+		psr = rtw_get_wps_attr_content(wpsie, wpsielen, WPS_ATTR_SELECTED_REGISTRAR, &sr, NULL);
+
+	if (psr && sr) {
+		if (0)
+			RTW_INFO("clear sr of non target bss:%s("MAC_FMT")\n"
+				, pssid->Ssid, MAC_ARG(pnetwork->network.MacAddress));
+		*psr = 0; /* clear sr */
+		ret = 1;
+	}
+
+exit:
+	return ret;
+}
+
+#define MAX_BSSINFO_LEN 1000
+struct cfg80211_bss *rtw_cfg80211_inform_bss(_adapter *padapter, struct wlan_network *pnetwork)
+{
+	struct ieee80211_channel *notify_channel;
+	struct cfg80211_bss *bss = NULL;
+	/* struct ieee80211_supported_band *band;       */
+	u16 channel;
+	u32 freq;
+	u64 notify_timestamp;
+	u16 notify_capability;
+	u16 notify_interval;
+	u8 *notify_ie;
+	size_t notify_ielen;
+	s32 notify_signal;
+	/* u8 buf[MAX_BSSINFO_LEN]; */
+
+	u8 *pbuf;
+	size_t buf_size = MAX_BSSINFO_LEN;
+	size_t len, bssinf_len = 0;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	unsigned short *fctrl;
+	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+	struct wireless_dev *wdev = padapter->rtw_wdev;
+	struct wiphy *wiphy = wdev->wiphy;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	pbuf = rtw_zmalloc(buf_size);
+	if (pbuf == NULL) {
+		RTW_INFO("%s pbuf allocate failed  !!\n", __FUNCTION__);
+		return bss;
+	}
+
+	/* RTW_INFO("%s\n", __func__); */
+
+	bssinf_len = pnetwork->network.IELength + sizeof(struct rtw_ieee80211_hdr_3addr);
+	if (bssinf_len > buf_size) {
+		RTW_INFO("%s IE Length too long > %zu byte\n", __FUNCTION__, buf_size);
+		goto exit;
+	}
+
+#ifndef CONFIG_WAPI_SUPPORT
+	{
+		u16 wapi_len = 0;
+
+		if (rtw_get_wapi_ie(pnetwork->network.IEs, pnetwork->network.IELength, NULL, &wapi_len) > 0) {
+			if (wapi_len > 0) {
+				RTW_INFO("%s, no support wapi!\n", __FUNCTION__);
+				goto exit;
+			}
+		}
+	}
+#endif /* !CONFIG_WAPI_SUPPORT */
+
+	channel = pnetwork->network.Configuration.DSConfig;
+	freq = rtw_ch2freq(channel);
+	notify_channel = ieee80211_get_channel(wiphy, freq);
+
+	if (0)
+		notify_timestamp = le64_to_cpu(*(u64 *)rtw_get_timestampe_from_ie(pnetwork->network.IEs));
+	else
+		notify_timestamp = rtw_get_systime_us();
+
+	notify_interval = le16_to_cpu(*(u16 *)rtw_get_beacon_interval_from_ie(pnetwork->network.IEs));
+	notify_capability = le16_to_cpu(*(u16 *)rtw_get_capability_from_ie(pnetwork->network.IEs));
+
+	notify_ie = pnetwork->network.IEs + _FIXED_IE_LENGTH_;
+	notify_ielen = pnetwork->network.IELength - _FIXED_IE_LENGTH_;
+
+	/* We've set wiphy's signal_type as CFG80211_SIGNAL_TYPE_MBM: signal strength in mBm (100*dBm) */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
+		is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
+		notify_signal = 100 * translate_percentage_to_dbm(padapter->recvpriv.signal_strength); /* dbm */
+	} else {
+		notify_signal = 100 * translate_percentage_to_dbm(pnetwork->network.PhyInfo.SignalStrength); /* dbm */
+	}
+
+#if 0
+	RTW_INFO("bssid: "MAC_FMT"\n", MAC_ARG(pnetwork->network.MacAddress));
+	RTW_INFO("Channel: %d(%d)\n", channel, freq);
+	RTW_INFO("Capability: %X\n", notify_capability);
+	RTW_INFO("Beacon interval: %d\n", notify_interval);
+	RTW_INFO("Signal: %d\n", notify_signal);
+	RTW_INFO("notify_timestamp: %llu\n", notify_timestamp);
+#endif
+
+	/* pbuf = buf; */
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pbuf;
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
+	/* pmlmeext->mgnt_seq++; */
+
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_BCN) { /* WIFI_BEACON */
+		_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
+		set_frame_sub_type(pbuf, WIFI_BEACON);
+	} else {
+		_rtw_memcpy(pwlanhdr->addr1, adapter_mac_addr(padapter), ETH_ALEN);
+		set_frame_sub_type(pbuf, WIFI_PROBERSP);
+	}
+
+	_rtw_memcpy(pwlanhdr->addr2, pnetwork->network.MacAddress, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, pnetwork->network.MacAddress, ETH_ALEN);
+
+
+	/* pbuf += sizeof(struct rtw_ieee80211_hdr_3addr); */
+	len = sizeof(struct rtw_ieee80211_hdr_3addr);
+	_rtw_memcpy((pbuf + len), pnetwork->network.IEs, pnetwork->network.IELength);
+	*((u64 *)(pbuf + len)) = cpu_to_le64(notify_timestamp);
+
+	len += pnetwork->network.IELength;
+
+	#if defined(CONFIG_P2P) && 0
+	if(rtw_get_p2p_ie(pnetwork->network.IEs+12, pnetwork->network.IELength-12, NULL, NULL))
+		RTW_INFO("%s, got p2p_ie\n", __func__);
+	#endif
+
+#if 1
+	bss = cfg80211_inform_bss_frame(wiphy, notify_channel, (struct ieee80211_mgmt *)pbuf,
+					len, notify_signal, GFP_ATOMIC);
+#else
+
+	bss = cfg80211_inform_bss(wiphy, notify_channel, (const u8 *)pnetwork->network.MacAddress,
+		notify_timestamp, notify_capability, notify_interval, notify_ie,
+		notify_ielen, notify_signal, GFP_ATOMIC/*GFP_KERNEL*/);
+#endif
+
+	if (unlikely(!bss)) {
+		RTW_INFO(FUNC_ADPT_FMT" bss NULL\n", FUNC_ADPT_ARG(padapter));
+		goto exit;
+	}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 38))
+#ifndef COMPAT_KERNEL_RELEASE
+	/* patch for cfg80211, update beacon ies to information_elements */
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_BCN) { /* WIFI_BEACON */
+
+		if (bss->len_information_elements != bss->len_beacon_ies) {
+			bss->information_elements = bss->beacon_ies;
+			bss->len_information_elements =  bss->len_beacon_ies;
+		}
+	}
+#endif /* COMPAT_KERNEL_RELEASE */
+#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 38) */
+
+#if 0
+	{
+		if (bss->information_elements == bss->proberesp_ies) {
+			if (bss->len_information_elements !=  bss->len_proberesp_ies)
+				RTW_INFO("error!, len_information_elements != bss->len_proberesp_ies\n");
+		} else if (bss->len_information_elements <  bss->len_beacon_ies) {
+			bss->information_elements = bss->beacon_ies;
+			bss->len_information_elements =  bss->len_beacon_ies;
+		}
+	}
+#endif
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
+	cfg80211_put_bss(wiphy, bss);
+#else
+	cfg80211_put_bss(bss);
+#endif
+
+exit:
+	if (pbuf)
+		rtw_mfree(pbuf, buf_size);
+	return bss;
+
+}
+
+/*
+	Check the given bss is valid by kernel API cfg80211_get_bss()
+	@padapter : the given adapter
+
+	return _TRUE if bss is valid,  _FALSE for not found.
+*/
+int rtw_cfg80211_check_bss(_adapter *padapter)
+{
+	WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
+	struct cfg80211_bss *bss = NULL;
+	struct ieee80211_channel *notify_channel = NULL;
+	u32 freq;
+
+	if (!(pnetwork) || !(padapter->rtw_wdev))
+		return _FALSE;
+
+	freq = rtw_ch2freq(pnetwork->Configuration.DSConfig);
+	notify_channel = ieee80211_get_channel(padapter->rtw_wdev->wiphy, freq);
+	bss = cfg80211_get_bss(padapter->rtw_wdev->wiphy, notify_channel,
+			pnetwork->MacAddress, pnetwork->Ssid.Ssid,
+			pnetwork->Ssid.SsidLength,
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0)
+			pnetwork->InfrastructureMode == Ndis802_11Infrastructure?IEEE80211_BSS_TYPE_ESS:IEEE80211_BSS_TYPE_IBSS,
+			IEEE80211_PRIVACY(pnetwork->Privacy));
+#else
+			pnetwork->InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS, pnetwork->InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS);
+#endif
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
+	cfg80211_put_bss(padapter->rtw_wdev->wiphy, bss);
+#else
+	cfg80211_put_bss(bss);
+#endif
+
+	return bss != NULL;
+}
+
+void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct cfg80211_bss *bss = NULL;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	struct wiphy *wiphy = pwdev->wiphy;
+	int freq = 2412;
+	struct ieee80211_channel *notify_channel;
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	freq = rtw_ch2freq(cur_network->network.Configuration.DSConfig);
+
+	if (0)
+		RTW_INFO("chan: %d, freq: %d\n", cur_network->network.Configuration.DSConfig, freq);
+#endif
+
+	if (pwdev->iftype != NL80211_IFTYPE_ADHOC)
+		return;
+
+	if (!rtw_cfg80211_check_bss(padapter)) {
+		WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
+		struct wlan_network *scanned = pmlmepriv->cur_network_scanned;
+
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
+
+			_rtw_memcpy(&cur_network->network, pnetwork, sizeof(WLAN_BSSID_EX));
+			if (cur_network) {
+				if (!rtw_cfg80211_inform_bss(padapter, cur_network))
+					RTW_INFO(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
+				else
+					RTW_INFO(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter));
+			} else {
+				RTW_INFO("cur_network is not exist!!!\n");
+				return ;
+			}
+		} else {
+			if (scanned == NULL)
+				rtw_warn_on(1);
+
+			if (_rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
+				&& _rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
+			) {
+				if (!rtw_cfg80211_inform_bss(padapter, scanned))
+					RTW_INFO(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
+				else {
+					/* RTW_INFO(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter)); */
+				}
+			} else {
+				RTW_INFO("scanned & pnetwork compare fail\n");
+				rtw_warn_on(1);
+			}
+		}
+
+		if (!rtw_cfg80211_check_bss(padapter))
+			RTW_PRINT(FUNC_ADPT_FMT" BSS not found !!\n", FUNC_ADPT_ARG(padapter));
+	}
+	/* notify cfg80211 that device joined an IBSS */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	notify_channel = ieee80211_get_channel(wiphy, freq);
+	cfg80211_ibss_joined(padapter->pnetdev, cur_network->network.MacAddress, notify_channel, GFP_ATOMIC);
+#else
+	cfg80211_ibss_joined(padapter->pnetdev, cur_network->network.MacAddress, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_indicate_connect(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	_irqL irqL;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif
+	struct cfg80211_bss *bss = NULL;
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
+	struct cfg80211_roam_info roam_info ={};
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	if (pwdev->iftype != NL80211_IFTYPE_STATION
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		&& pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT
+		#endif
+	)
+		return;
+
+	if (!MLME_IS_STA(padapter))
+		return;
+
+#ifdef CONFIG_P2P
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		#if !RTW_P2P_GROUP_INTERFACE
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+			rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
+			RTW_INFO("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo), rtw_p2p_pre_state(pwdinfo));
+		}
+		#endif
+	}
+#endif /* CONFIG_P2P */
+
+	if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) != _TRUE) {
+		WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
+		struct wlan_network *scanned = pmlmepriv->cur_network_scanned;
+
+		/* RTW_INFO(FUNC_ADPT_FMT" BSS not found\n", FUNC_ADPT_ARG(padapter)); */
+
+		if (scanned == NULL) {
+			rtw_warn_on(1);
+			goto check_bss;
+		}
+
+		if (_rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
+			&& _rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
+		) {
+			if (!rtw_cfg80211_inform_bss(padapter, scanned))
+				RTW_INFO(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
+			else {
+				/* RTW_INFO(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter)); */
+			}
+		} else {
+			RTW_INFO("scanned: %s("MAC_FMT"), cur: %s("MAC_FMT")\n",
+				scanned->network.Ssid.Ssid, MAC_ARG(scanned->network.MacAddress),
+				pnetwork->Ssid.Ssid, MAC_ARG(pnetwork->MacAddress)
+			);
+			rtw_warn_on(1);
+		}
+	}
+
+check_bss:
+	if (!rtw_cfg80211_check_bss(padapter))
+		RTW_PRINT(FUNC_ADPT_FMT" BSS not found !!\n", FUNC_ADPT_ARG(padapter));
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	if (rtw_to_roam(padapter) > 0) {
+		#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39) || defined(COMPAT_KERNEL_RELEASE)
+		struct wiphy *wiphy = pwdev->wiphy;
+		struct ieee80211_channel *notify_channel;
+		u32 freq;
+		u16 channel = cur_network->network.Configuration.DSConfig;
+
+		freq = rtw_ch2freq(channel);
+		notify_channel = ieee80211_get_channel(wiphy, freq);
+		#endif
+
+		#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
+		roam_info.bssid = cur_network->network.MacAddress;
+		roam_info.req_ie = pmlmepriv->assoc_req + sizeof(struct rtw_ieee80211_hdr_3addr) + 2;
+		roam_info.req_ie_len = pmlmepriv->assoc_req_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
+		roam_info.resp_ie = pmlmepriv->assoc_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6;
+		roam_info.resp_ie_len = pmlmepriv->assoc_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6;
+
+		cfg80211_roamed(padapter->pnetdev, &roam_info, GFP_ATOMIC);
+		#else
+		cfg80211_roamed(padapter->pnetdev
+			#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39) || defined(COMPAT_KERNEL_RELEASE)
+			, notify_channel
+			#endif
+			, cur_network->network.MacAddress
+			, pmlmepriv->assoc_req + sizeof(struct rtw_ieee80211_hdr_3addr) + 2
+			, pmlmepriv->assoc_req_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 2
+			, pmlmepriv->assoc_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6
+			, pmlmepriv->assoc_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6
+			, GFP_ATOMIC);
+		#endif /*LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)*/
+
+		RTW_INFO(FUNC_ADPT_FMT" call cfg80211_roamed\n", FUNC_ADPT_ARG(padapter));
+
+#ifdef CONFIG_RTW_80211R
+		if (rtw_ft_roam(padapter))
+			rtw_ft_set_status(padapter, RTW_FT_ASSOCIATED_STA);
+#endif
+	} else {
+		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)
+		RTW_INFO("pwdev->sme_state(b)=%d\n", pwdev->sme_state);
+		#endif
+
+		if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) != _TRUE)
+			rtw_cfg80211_connect_result(pwdev, cur_network->network.MacAddress
+				, pmlmepriv->assoc_req + sizeof(struct rtw_ieee80211_hdr_3addr) + 2
+				, pmlmepriv->assoc_req_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 2
+				, pmlmepriv->assoc_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6
+				, pmlmepriv->assoc_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6
+				, WLAN_STATUS_SUCCESS, GFP_ATOMIC);
+		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)
+		RTW_INFO("pwdev->sme_state(a)=%d\n", pwdev->sme_state);
+		#endif
+	}
+
+	rtw_wdev_free_connect_req(pwdev_priv);
+
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+}
+
+void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	_irqL irqL;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	/*always replace privated definitions with wifi reserved value 0*/
+	if (WLAN_REASON_IS_PRIVATE(reason))
+		reason = 0;
+
+	if (pwdev->iftype != NL80211_IFTYPE_STATION
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		&& pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT
+		#endif
+	)
+		return;
+
+	if (!MLME_IS_STA(padapter))
+		return;
+
+#ifdef CONFIG_P2P
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
+
+			#if RTW_P2P_GROUP_INTERFACE
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+			if (pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT)
+			#endif
+			#endif
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
+
+			RTW_INFO("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo), rtw_p2p_pre_state(pwdinfo));
+		}
+	}
+#endif /* CONFIG_P2P */
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	if (padapter->ndev_unregistering || !rtw_wdev_not_indic_disco(pwdev_priv)) {
+		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)
+		RTW_INFO("pwdev->sme_state(b)=%d\n", pwdev->sme_state);
+
+		if (pwdev->sme_state == CFG80211_SME_CONNECTING) {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_connect_result\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_connect_result(pwdev, NULL, NULL, 0, NULL, 0,
+				WLAN_STATUS_UNSPECIFIED_FAILURE, GFP_ATOMIC);
+		} else if (pwdev->sme_state == CFG80211_SME_CONNECTED) {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_disconnected(pwdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
+		}
+
+		RTW_INFO("pwdev->sme_state(a)=%d\n", pwdev->sme_state);
+		#else
+		if (pwdev_priv->connect_req) {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_connect_result\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_connect_result(pwdev, NULL, NULL, 0, NULL, 0,
+				WLAN_STATUS_UNSPECIFIED_FAILURE, GFP_ATOMIC);
+		} else {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_disconnected(pwdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
+		}
+		#endif
+	}
+
+	rtw_wdev_free_connect_req(pwdev_priv);
+
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+}
+
+
+#ifdef CONFIG_AP_MODE
+static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_param *param)
+{
+	int ret = 0;
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	struct sta_info *psta = NULL, *pbcmc_sta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	param->u.crypt.err = 0;
+	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
+
+	if (is_broadcast_mac_addr(param->sta_addr)) {
+		if (param->u.crypt.idx >= WEP_KEYS
+			#ifdef CONFIG_IEEE80211W
+			&& param->u.crypt.idx > BIP_MAX_KEYID
+			#endif
+		) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	} else {
+		psta = rtw_get_stainfo(pstapriv, param->sta_addr);
+		if (!psta) {
+			ret = -EINVAL;
+			RTW_INFO(FUNC_ADPT_FMT", sta "MAC_FMT" not found\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(param->sta_addr));
+			goto exit;
+		}
+	}
+
+	if (strcmp(param->u.crypt.alg, "none") == 0 && (psta == NULL)) {
+		/* todo:clear default encryption keys */
+
+		RTW_INFO("clear default encryption keys, keyid=%d\n", param->u.crypt.idx);
+
+		goto exit;
+	}
+
+
+	if (strcmp(param->u.crypt.alg, "WEP") == 0 && (psta == NULL)) {
+		RTW_INFO("r871x_set_encryption, crypt.alg = WEP\n");
+
+		wep_key_idx = param->u.crypt.idx;
+		wep_key_len = param->u.crypt.key_len;
+
+		RTW_INFO("r871x_set_encryption, wep_key_idx=%d, len=%d\n", wep_key_idx, wep_key_len);
+
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		if (wep_key_len > 0)
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+
+		if (psecuritypriv->bWepDefaultKeyIdxSet == 0) {
+			/* wep default key has not been set, so use this key index as default key. */
+
+			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+
+			if (wep_key_len == 13) {
+				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+			}
+
+			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
+		}
+
+		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
+
+		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
+
+		rtw_ap_set_wep_key(padapter, param->u.crypt.key, wep_key_len, wep_key_idx, 1);
+
+		goto exit;
+
+	}
+
+	if (!psta) { /* group key */
+		if (param->u.crypt.set_tx == 0) { /* group key, TX only */
+			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set WEP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+				if (param->u.crypt.key_len == 13)
+					psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+
+			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				/* set mic key */
+				_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
+				_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
+				psecuritypriv->busetkipkey = _TRUE;
+
+			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _AES_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TX IGTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
+				psecuritypriv->dot11wBIPtxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				padapter->securitypriv.binstallBIPkey = _TRUE;
+				goto exit;
+			#endif /* CONFIG_IEEE80211W */
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key, idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx);
+				psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key, not support\n"
+					, FUNC_ADPT_ARG(padapter));
+				goto exit;
+			}
+
+			psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta) {
+				pbcmc_sta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				pbcmc_sta->ieee8021x_blocked = _FALSE;
+				pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
+			}
+			psecuritypriv->binstallGrpkey = _TRUE;
+			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
+
+			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
+		}
+
+		goto exit;
+
+	}
+
+	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) { /* psk/802_1x */
+		if (param->u.crypt.set_tx == 1) {
+			/* pairwise key */
+			_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set WEP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _WEP40_;
+				if (param->u.crypt.key_len == 13)
+					psta->dot118021XPrivacy = _WEP104_;
+
+			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _TKIP_;
+				/* set mic key */
+				_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
+				_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
+				psecuritypriv->busetkipkey = _TRUE;
+
+			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _AES_;
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear pairwise key of "MAC_FMT" idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx);
+				psta->dot118021XPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set pairwise key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
+			}
+
+			psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+			psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+			psta->ieee8021x_blocked = _FALSE;
+			psta->bpairwise_key_installed = _TRUE;
+			rtw_ap_set_pairwise_key(padapter, psta);
+
+		} else {
+			/* peer's group key, RX only */
+			#ifdef CONFIG_RTW_MESH
+			if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP GTK of "MAC_FMT", idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->group_privacy = _AES_;
+				_rtw_memcpy(psta->gtk.skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psta->gtk_bmp |= BIT(param->u.crypt.idx);
+				psta->gtk_pn.val = RTW_GET_LE64(param->u.crypt.seq);
+
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set IGTK of "MAC_FMT", idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(psta->igtk.skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psta->igtk_bmp |= BIT(param->u.crypt.idx);
+				psta->igtk_id = param->u.crypt.idx;
+				psta->igtk_pn.val = RTW_GET_LE64(param->u.crypt.seq);
+				goto exit;
+			#endif /* CONFIG_IEEE80211W */
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key of "MAC_FMT", idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx);
+				psta->group_privacy = _NO_PRIVACY_;
+				psta->gtk_bmp &= ~BIT(param->u.crypt.idx);
+			} else
+			#endif /* CONFIG_RTW_MESH */
+			{
+				RTW_WARN(FUNC_ADPT_FMT" set group key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
+			}
+
+			#ifdef CONFIG_RTW_MESH
+			rtw_ap_set_sta_key(padapter, psta->cmn.mac_addr, psta->group_privacy
+				, param->u.crypt.key, param->u.crypt.idx, 1);
+			#endif
+		}
+
+	}
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_AP_MODE */
+
+static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param *param)
+{
+	int ret = 0;
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
+
+	RTW_INFO("%s\n", __func__);
+
+	param->u.crypt.err = 0;
+	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
+
+	if (is_broadcast_mac_addr(param->sta_addr)) {
+		if (param->u.crypt.idx >= WEP_KEYS
+			#ifdef CONFIG_IEEE80211W
+			&& param->u.crypt.idx > BIP_MAX_KEYID
+			#endif
+		) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	} else {
+#ifdef CONFIG_WAPI_SUPPORT
+		if (strcmp(param->u.crypt.alg, "SMS4"))
+#endif
+		{
+			ret = -EINVAL;
+			goto exit;
+		}
+	}
+
+	if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+		RTW_INFO("wpa_set_encryption, crypt.alg = WEP\n");
+
+		wep_key_idx = param->u.crypt.idx;
+		wep_key_len = param->u.crypt.key_len;
+
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		if (psecuritypriv->bWepDefaultKeyIdxSet == 0) {
+			/* wep default key has not been set, so use this key index as default key. */
+
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+
+			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+
+			if (wep_key_len == 13) {
+				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+			}
+
+			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
+		}
+
+		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
+
+		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
+
+		rtw_set_key(padapter, psecuritypriv, wep_key_idx, 0, _TRUE);
+
+		goto exit;
+	}
+
+	if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) { /* 802_1x */
+		struct sta_info *psta, *pbcmc_sta;
+		struct sta_priv *pstapriv = &padapter->stapriv;
+
+		/* RTW_INFO("%s, : dot11AuthAlgrthm == dot11AuthAlgrthm_8021X\n", __func__); */
+
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_MP_STATE) == _TRUE) { /* sta mode */
+#ifdef CONFIG_RTW_80211R
+			if (rtw_ft_roam(padapter))
+				psta = rtw_get_stainfo(pstapriv, pmlmepriv->assoc_bssid);
+			else
+#endif
+				psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+			if (psta == NULL) {
+				/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
+				RTW_INFO("%s, : Obtain Sta_info fail\n", __func__);
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
+					psta->ieee8021x_blocked = _FALSE;
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
+					psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+
+				if (param->u.crypt.set_tx == 1) { /* pairwise key */
+					RTW_INFO(FUNC_ADPT_FMT" set %s PTK idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0) { /* set mic key */
+						_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
+						_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
+						padapter->securitypriv.busetkipkey = _FALSE;
+					}
+					psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->bpairwise_key_installed = _TRUE;
+					#ifdef CONFIG_RTW_80211R
+					psta->ft_pairwise_key_installed = _TRUE;
+					#endif
+					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
+
+				} else { /* group key */
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set %s GTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
+						padapter->securitypriv.binstallGrpkey = _TRUE;
+						if (param->u.crypt.idx < 4) 
+							_rtw_memcpy(padapter->securitypriv.iv_seq[param->u.crypt.idx], param->u.crypt.seq, 8);							
+						padapter->securitypriv.dot118021XGrpKeyid = param->u.crypt.idx;
+						rtw_set_key(padapter, &padapter->securitypriv, param->u.crypt.idx, 1, _TRUE);
+
+					#ifdef CONFIG_IEEE80211W
+					} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set IGTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+						psecuritypriv->dot11wBIPrxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+						psecuritypriv->binstallBIPkey = _TRUE;
+					#endif /* CONFIG_IEEE80211W */
+
+					}
+
+#ifdef CONFIG_P2P
+					if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+						if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
+							rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_DONE);
+					}
+#endif /* CONFIG_P2P */
+
+				}
+			}
+
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta == NULL) {
+				/* DEBUG_ERR( ("Set OID_802_11_ADD_KEY: bcmc stainfo is null\n")); */
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
+					pbcmc_sta->ieee8021x_blocked = _FALSE;
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
+					pbcmc_sta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+			}
+		} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) { /* adhoc mode */
+		}
+	}
+
+	#ifdef CONFIG_WAPI_SUPPORT
+	if (strcmp(param->u.crypt.alg, "SMS4") == 0)
+		rtw_wapi_set_set_encryption(padapter, param);
+	#endif
+
+exit:
+
+	RTW_INFO("%s, ret=%d\n", __func__, ret);
+
+
+	return ret;
+}
+
+static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev
+	, u8 key_index
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	, bool pairwise
+#endif
+	, const u8 *mac_addr, struct key_params *params)
+{
+	char *alg_name;
+	u32 param_len;
+	struct ieee_param *param = NULL;
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+#ifdef CONFIG_TDLS
+	struct sta_info *ptdls_sta;
+#endif /* CONFIG_TDLS */
+
+	if (mac_addr)
+		RTW_INFO(FUNC_NDEV_FMT" adding key for %pM\n", FUNC_NDEV_ARG(ndev), mac_addr);
+	RTW_INFO(FUNC_NDEV_FMT" cipher=0x%x\n", FUNC_NDEV_ARG(ndev), params->cipher);
+	RTW_INFO(FUNC_NDEV_FMT" key_len=%d, key_index=%d\n", FUNC_NDEV_ARG(ndev), params->key_len, key_index);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	RTW_INFO(FUNC_NDEV_FMT" pairwise=%d\n", FUNC_NDEV_ARG(ndev), pairwise);
+#endif
+
+	if (rtw_cfg80211_sync_iftype(padapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto addkey_end;
+	}
+
+	param_len = sizeof(struct ieee_param) + params->key_len;
+	param = rtw_malloc(param_len);
+	if (param == NULL)
+		return -1;
+
+	_rtw_memset(param, 0, param_len);
+
+	param->cmd = IEEE_CMD_SET_ENCRYPTION;
+	_rtw_memset(param->sta_addr, 0xff, ETH_ALEN);
+
+	switch (params->cipher) {
+	case IW_AUTH_CIPHER_NONE:
+		/* todo: remove key */
+		/* remove = 1;	 */
+		alg_name = "none";
+		break;
+	case WLAN_CIPHER_SUITE_WEP40:
+	case WLAN_CIPHER_SUITE_WEP104:
+		alg_name = "WEP";
+		break;
+	case WLAN_CIPHER_SUITE_TKIP:
+		alg_name = "TKIP";
+		break;
+	case WLAN_CIPHER_SUITE_CCMP:
+		alg_name = "CCMP";
+		break;
+#ifdef CONFIG_IEEE80211W
+	case WLAN_CIPHER_SUITE_AES_CMAC:
+		alg_name = "BIP";
+		break;
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_WAPI_SUPPORT
+	case WLAN_CIPHER_SUITE_SMS4:
+		alg_name = "SMS4";
+		if (pairwise == NL80211_KEYTYPE_PAIRWISE) {
+			if (key_index != 0 && key_index != 1) {
+				ret = -ENOTSUPP;
+				goto addkey_end;
+			}
+			_rtw_memcpy((void *)param->sta_addr, (void *)mac_addr, ETH_ALEN);
+		} else
+			RTW_INFO("mac_addr is null\n");
+		RTW_INFO("rtw_wx_set_enc_ext: SMS4 case\n");
+		break;
+#endif
+
+	default:
+		ret = -ENOTSUPP;
+		goto addkey_end;
+	}
+
+	strncpy((char *)param->u.crypt.alg, alg_name, IEEE_CRYPT_ALG_NAME_LEN);
+
+
+	if (!mac_addr || is_broadcast_ether_addr(mac_addr)
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		|| !pairwise
+		#endif
+	) {
+		param->u.crypt.set_tx = 0; /* for wpa/wpa2 group key */
+	} else {
+		param->u.crypt.set_tx = 1; /* for wpa/wpa2 pairwise key */
+	}
+
+	param->u.crypt.idx = key_index;
+
+	if (params->seq_len && params->seq) {
+		_rtw_memcpy(param->u.crypt.seq, (u8 *)params->seq, params->seq_len);
+		RTW_INFO(FUNC_NDEV_FMT" seq_len:%u, seq:0x%llx\n", FUNC_NDEV_ARG(ndev)
+			, params->seq_len, RTW_GET_LE64(param->u.crypt.seq));
+	}
+
+	if (params->key_len && params->key) {
+		param->u.crypt.key_len = params->key_len;
+		_rtw_memcpy(param->u.crypt.key, (u8 *)params->key, params->key_len);
+	}
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+#ifdef CONFIG_TDLS
+		if (rtw_tdls_is_driver_setup(padapter) == _FALSE && mac_addr) {
+			ptdls_sta = rtw_get_stainfo(&padapter->stapriv, (void *)mac_addr);
+			if (ptdls_sta != NULL && ptdls_sta->tdls_sta_state) {
+				_rtw_memcpy(ptdls_sta->tpk.tk, params->key, params->key_len);
+				rtw_tdls_set_key(padapter, ptdls_sta);
+				goto addkey_end;
+			}
+		}
+#endif /* CONFIG_TDLS */
+		ret = rtw_cfg80211_set_encryption(ndev, param);
+	} else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+#ifdef CONFIG_AP_MODE
+		if (mac_addr)
+			_rtw_memcpy(param->sta_addr, (void *)mac_addr, ETH_ALEN);
+
+		ret = rtw_cfg80211_ap_set_encryption(ndev, param);
+#endif
+	} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE
+		|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE
+	) {
+		/* RTW_INFO("@@@@@@@@@@ fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype); */
+		ret = rtw_cfg80211_set_encryption(ndev, param);
+	} else
+		RTW_INFO("error! fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype);
+
+
+addkey_end:
+	if (param)
+		rtw_mfree(param, param_len);
+
+	return ret;
+
+}
+
+static int cfg80211_rtw_get_key(struct wiphy *wiphy, struct net_device *ndev
+	, u8 keyid
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	, bool pairwise
+#endif
+	, const u8 *mac_addr, void *cookie
+	, void (*callback)(void *cookie, struct key_params *))
+{
+#define GET_KEY_PARAM_FMT_S " keyid=%d"
+#define GET_KEY_PARAM_ARG_S , keyid
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	#define GET_KEY_PARAM_FMT_2_6_37 ", pairwise=%d"
+	#define GET_KEY_PARAM_ARG_2_6_37 , pairwise
+#else
+	#define GET_KEY_PARAM_FMT_2_6_37 ""
+	#define GET_KEY_PARAM_ARG_2_6_37
+#endif
+#define GET_KEY_PARAM_FMT_E ", addr=%pM"
+#define GET_KEY_PARAM_ARG_E , mac_addr
+
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv *sec = &adapter->securitypriv;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta = NULL;
+	u32 cipher = _NO_PRIVACY_;
+	union Keytype *key = NULL;
+	u8 key_len = 0;
+	u64 *pn = NULL;
+	u8 pn_len = 0;
+	u8 pn_val[8] = {0};
+
+	struct key_params params;
+	int ret = -ENOENT;
+
+	if (keyid >= WEP_KEYS
+		#ifdef CONFIG_IEEE80211W
+		&& keyid > BIP_MAX_KEYID
+		#endif
+	)
+		goto exit;
+
+	if (!mac_addr || is_broadcast_ether_addr(mac_addr)
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		|| (MLME_IS_STA(adapter) && !pairwise)
+		#endif
+	) {	
+		/* WEP key, TX GTK/IGTK, RX GTK/IGTK(for STA mode) */
+		if (is_wep_enc(sec->dot118021XGrpPrivacy)) {
+			if (keyid >= WEP_KEYS)
+				goto exit;
+			if (!(sec->key_mask & BIT(keyid)))
+				goto exit;
+			cipher = sec->dot118021XGrpPrivacy;
+			key = &sec->dot11DefKey[keyid];
+		} else {
+			if (keyid < WEP_KEYS) {
+				if (sec->binstallGrpkey != _TRUE)
+					goto exit;
+				cipher = sec->dot118021XGrpPrivacy;
+				key = &sec->dot118021XGrpKey[keyid];
+				sta = rtw_get_bcmc_stainfo(adapter);
+				if (sta)
+					pn = &sta->dot11txpn.val;
+			#ifdef CONFIG_IEEE80211W
+			} else if (keyid < BIP_MAX_KEYID) {
+				if (SEC_IS_BIP_KEY_INSTALLED(sec) != _TRUE)
+					goto exit;
+				cipher = _BIP_;
+				key = &sec->dot11wBIPKey[keyid];
+				pn = &sec->dot11wBIPtxpn.val;
+			#endif
+			}
+		}
+	} else {
+		/* Pairwise key, RX GTK/IGTK for specific peer */
+		sta = rtw_get_stainfo(stapriv, mac_addr);
+		if (!sta)
+			goto exit;
+
+		if (keyid < WEP_KEYS && pairwise) {
+			if (sta->bpairwise_key_installed != _TRUE)
+				goto exit;
+			cipher = sta->dot118021XPrivacy;
+			key = &sta->dot118021x_UncstKey;
+		#ifdef CONFIG_RTW_MESH
+		} else if (keyid < WEP_KEYS && !pairwise) {
+			if (!(sta->gtk_bmp & BIT(keyid)))
+				goto exit;
+			cipher = sta->group_privacy;
+			key = &sta->gtk;
+		#ifdef CONFIG_IEEE80211W
+		} else if (keyid < BIP_MAX_KEYID && !pairwise) {
+			if (!(sta->igtk_bmp & BIT(keyid)))
+				goto exit;
+			cipher = _BIP_;
+			key = &sta->igtk;
+			pn = &sta->igtk_pn.val;
+		#endif
+		#endif /* CONFIG_RTW_MESH */
+		}
+	}
+
+	if (!key)
+		goto exit;
+
+	if (cipher == _WEP40_) {
+		cipher = WLAN_CIPHER_SUITE_WEP40;
+		key_len = sec->dot11DefKeylen[keyid];
+	} else if (cipher == _WEP104_) {
+		cipher = WLAN_CIPHER_SUITE_WEP104;
+		key_len = sec->dot11DefKeylen[keyid];
+	} else if (cipher == _TKIP_) {
+		cipher = WLAN_CIPHER_SUITE_TKIP;
+		key_len = 16;
+	} else if (cipher == _AES_) {
+		cipher = WLAN_CIPHER_SUITE_CCMP;
+		key_len = 16;
+	#ifdef CONFIG_IEEE80211W
+	} else if (cipher == _BIP_) {
+		cipher = WLAN_CIPHER_SUITE_AES_CMAC;
+		key_len = 16;
+	#endif
+	} else {
+		RTW_WARN(FUNC_NDEV_FMT" unknown cipher:%u\n", FUNC_NDEV_ARG(ndev), cipher);
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (pn) {
+		*((u64 *)pn_val) = cpu_to_le64(*pn);
+		pn_len = 6;
+	}
+
+	ret = 0;
+	
+exit:
+	RTW_INFO(FUNC_NDEV_FMT
+		GET_KEY_PARAM_FMT_S
+		GET_KEY_PARAM_FMT_2_6_37
+		GET_KEY_PARAM_FMT_E
+		" ret %d\n", FUNC_NDEV_ARG(ndev)
+		GET_KEY_PARAM_ARG_S
+		GET_KEY_PARAM_ARG_2_6_37
+		GET_KEY_PARAM_ARG_E
+		, ret);
+	if (pn)
+		RTW_INFO(FUNC_NDEV_FMT " seq:0x%llx\n", FUNC_NDEV_ARG(ndev), *pn);
+
+	if (ret == 0) {
+		_rtw_memset(&params, 0, sizeof(params));
+
+		params.cipher = cipher;
+		params.key = key->skey;
+		params.key_len = key_len;
+		if (pn) {
+			params.seq = pn_val;
+			params.seq_len = pn_len;
+		}
+
+		callback(cookie, &params);
+	}
+
+	return ret;
+}
+
+static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+				u8 key_index, bool pairwise, const u8 *mac_addr)
+#else	/* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
+				u8 key_index, const u8 *mac_addr)
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+
+	RTW_INFO(FUNC_NDEV_FMT" key_index=%d, addr=%pM\n", FUNC_NDEV_ARG(ndev), key_index, mac_addr);
+
+	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
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	, bool unicast, bool multicast
+	#endif
+)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+
+#define SET_DEF_KEY_PARAM_FMT " key_index=%d"
+#define SET_DEF_KEY_PARAM_ARG , key_index
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	#define SET_DEF_KEY_PARAM_FMT_2_6_38 ", unicast=%d, multicast=%d"
+	#define SET_DEF_KEY_PARAM_ARG_2_6_38 , unicast, multicast
+#else
+	#define SET_DEF_KEY_PARAM_FMT_2_6_38 ""
+	#define SET_DEF_KEY_PARAM_ARG_2_6_38
+#endif
+
+	RTW_INFO(FUNC_NDEV_FMT
+		SET_DEF_KEY_PARAM_FMT
+		SET_DEF_KEY_PARAM_FMT_2_6_38
+		"\n", FUNC_NDEV_ARG(ndev)
+		SET_DEF_KEY_PARAM_ARG
+		SET_DEF_KEY_PARAM_ARG_2_6_38
+	);
+
+	if ((key_index < WEP_KEYS) && ((psecuritypriv->dot11PrivacyAlgrthm == _WEP40_) || (psecuritypriv->dot11PrivacyAlgrthm == _WEP104_))) { /* set wep default key */
+		psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+
+		psecuritypriv->dot11PrivacyKeyIndex = key_index;
+
+		psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+		psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+		if (psecuritypriv->dot11DefKeylen[key_index] == 13) {
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+		}
+
+		psecuritypriv->bWepDefaultKeyIdxSet = 1; /* set the flag to represent that wep default key has been set */
+	}
+
+	return 0;
+
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 30))
+int cfg80211_rtw_set_default_mgmt_key(struct wiphy *wiphy,
+	struct net_device *ndev, u8 key_index)
+{
+#define SET_DEF_KEY_PARAM_FMT " key_index=%d"
+#define SET_DEF_KEY_PARAM_ARG , key_index
+
+	RTW_INFO(FUNC_NDEV_FMT
+		SET_DEF_KEY_PARAM_FMT
+		"\n", FUNC_NDEV_ARG(ndev)
+		SET_DEF_KEY_PARAM_ARG
+	);
+
+	return 0;
+}
+#endif
+
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
+static int cfg80211_rtw_set_rekey_data(struct wiphy *wiphy,
+	struct net_device *ndev,
+	struct cfg80211_gtk_rekey_data *data)
+{
+	/*int i;*/
+	struct sta_info *psta;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv   *pmlmepriv = &padapter->mlmepriv;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL) {
+		RTW_INFO("%s, : Obtain Sta_info fail\n", __func__);
+		return -1;
+	}
+
+	_rtw_memcpy(psta->kek, data->kek, NL80211_KEK_LEN);
+	/*printk("\ncfg80211_rtw_set_rekey_data KEK:");
+	for(i=0;i<NL80211_KEK_LEN; i++)
+		printk(" %02x ", psta->kek[i]);*/
+	_rtw_memcpy(psta->kck, data->kck, NL80211_KCK_LEN);
+	/*printk("\ncfg80211_rtw_set_rekey_data KCK:");
+	for(i=0;i<NL80211_KCK_LEN; i++)
+		printk(" %02x ", psta->kck[i]);*/
+	_rtw_memcpy(psta->replay_ctr, data->replay_ctr, NL80211_REPLAY_CTR_LEN);
+	psecuritypriv->binstallKCK_KEK = _TRUE;
+	/*printk("\nREPLAY_CTR: ");
+	for(i=0;i<RTW_REPLAY_CTR_LEN; i++)
+		printk(" %02x ", psta->replay_ctr[i]);*/
+
+	return 0;
+}
+#endif /*CONFIG_GTK_OL*/
+
+#ifdef CONFIG_RTW_MESH
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+static enum nl80211_mesh_power_mode rtw_mesh_ps_to_nl80211_mesh_power_mode(u8 ps)
+{
+	if (ps == RTW_MESH_PS_UNKNOWN)
+		return NL80211_MESH_POWER_UNKNOWN;
+	if (ps == RTW_MESH_PS_ACTIVE)
+		return NL80211_MESH_POWER_ACTIVE;
+	if (ps == RTW_MESH_PS_LSLEEP)
+		return NL80211_MESH_POWER_LIGHT_SLEEP;
+	if (ps == RTW_MESH_PS_DSLEEP)
+		return NL80211_MESH_POWER_DEEP_SLEEP;
+
+	rtw_warn_on(1);
+	return NL80211_MESH_POWER_UNKNOWN;
+}
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+enum nl80211_plink_state rtw_plink_state_to_nl80211_plink_state(u8 plink_state)
+{
+	if (plink_state == RTW_MESH_PLINK_UNKNOWN)
+		return NUM_NL80211_PLINK_STATES;
+	if (plink_state == RTW_MESH_PLINK_LISTEN)
+		return NL80211_PLINK_LISTEN;
+	if (plink_state == RTW_MESH_PLINK_OPN_SNT)
+		return NL80211_PLINK_OPN_SNT;
+	if (plink_state == RTW_MESH_PLINK_OPN_RCVD)
+		return NL80211_PLINK_OPN_RCVD;
+	if (plink_state == RTW_MESH_PLINK_CNF_RCVD)
+		return NL80211_PLINK_CNF_RCVD;
+	if (plink_state == RTW_MESH_PLINK_ESTAB)
+		return NL80211_PLINK_ESTAB;
+	if (plink_state == RTW_MESH_PLINK_HOLDING)
+		return NL80211_PLINK_HOLDING;
+	if (plink_state == RTW_MESH_PLINK_BLOCKED)
+		return NL80211_PLINK_BLOCKED;
+
+	rtw_warn_on(1);
+	return NUM_NL80211_PLINK_STATES;
+}
+
+u8 nl80211_plink_state_to_rtw_plink_state(enum nl80211_plink_state plink_state)
+{
+	if (plink_state == NL80211_PLINK_LISTEN)
+		return RTW_MESH_PLINK_LISTEN;
+	if (plink_state == NL80211_PLINK_OPN_SNT)
+		return RTW_MESH_PLINK_OPN_SNT;
+	if (plink_state == NL80211_PLINK_OPN_RCVD)
+		return RTW_MESH_PLINK_OPN_RCVD;
+	if (plink_state == NL80211_PLINK_CNF_RCVD)
+		return RTW_MESH_PLINK_CNF_RCVD;
+	if (plink_state == NL80211_PLINK_ESTAB)
+		return RTW_MESH_PLINK_ESTAB;
+	if (plink_state == NL80211_PLINK_HOLDING)
+		return RTW_MESH_PLINK_HOLDING;
+	if (plink_state == NL80211_PLINK_BLOCKED)
+		return RTW_MESH_PLINK_BLOCKED;
+
+	rtw_warn_on(1);
+	return RTW_MESH_PLINK_UNKNOWN;
+}
+#endif
+
+static void rtw_cfg80211_fill_mesh_only_sta_info(struct mesh_plink_ent *plink, struct sta_info *sta, struct station_info *sinfo)
+{
+	sinfo->filled |= STATION_INFO_LLID;
+	sinfo->llid = plink->llid;
+	sinfo->filled |= STATION_INFO_PLID;
+	sinfo->plid = plink->plid;
+	sinfo->filled |= STATION_INFO_PLINK_STATE;
+	sinfo->plink_state = rtw_plink_state_to_nl80211_plink_state(plink->plink_state);
+	if (!sta && plink->scanned) {
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(plink->scanned->network.PhyInfo.SignalStrength);
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		if (plink->plink_state == RTW_MESH_PLINK_UNKNOWN)
+			sinfo->inactive_time = 0 - 1;
+		else
+			sinfo->inactive_time = rtw_get_passing_time_ms(plink->scanned->last_scanned);
+	}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (sta) {
+		sinfo->filled |= STATION_INFO_LOCAL_PM;
+		sinfo->local_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->local_mps);
+		sinfo->filled |= STATION_INFO_PEER_PM;
+		sinfo->peer_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->peer_mps);
+		sinfo->filled |= STATION_INFO_NONPEER_PM;
+		sinfo->nonpeer_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->nonpeer_mps);
+	}
+#endif
+}
+#endif /* CONFIG_RTW_MESH */
+
+static int cfg80211_rtw_get_station(struct wiphy *wiphy,
+	struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac,
+#else
+	const u8 *mac,
+#endif
+	struct station_info *sinfo)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct sta_info *psta = NULL;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink = NULL;
+#endif
+
+	sinfo->filled = 0;
+
+	if (!mac) {
+		RTW_INFO(FUNC_NDEV_FMT" mac==%p\n", FUNC_NDEV_ARG(ndev), mac);
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	psta = rtw_get_stainfo(pstapriv, mac);
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (!psta)
+			plink = rtw_mesh_plink_get(padapter, mac);
+		else
+			plink = psta->plink;
+	}
+#endif /* CONFIG_RTW_MESH */
+
+	if (!psta
+		#ifdef CONFIG_RTW_MESH
+		&& !plink
+		#endif
+	) {
+		RTW_INFO(FUNC_NDEV_FMT" no sta info for mac="MAC_FMT"\n"
+			, FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+		ret = -ENOENT;
+		goto exit;
+	}
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO(FUNC_NDEV_FMT" mac="MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+#endif
+
+	/* 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 (_rtw_memcmp((u8 *)mac, cur_network->network.MacAddress, ETH_ALEN) == _FALSE) {
+			RTW_INFO("%s, mismatch bssid="MAC_FMT"\n", __func__, MAC_ARG(cur_network->network.MacAddress));
+			ret = -ENOENT;
+			goto exit;
+		}
+
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);
+
+		sinfo->filled |= STATION_INFO_TX_BITRATE;
+		sinfo->txrate.legacy = rtw_get_cur_max_rate(padapter);
+	}
+
+	if (psta) {
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE
+			|| check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE
+		) {
+			sinfo->filled |= STATION_INFO_SIGNAL;
+			sinfo->signal = translate_percentage_to_dbm(psta->cmn.rssi_stat.rssi);
+		}
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		sinfo->inactive_time = rtw_get_passing_time_ms(psta->sta_stats.last_rx_time);
+		sinfo->filled |= STATION_INFO_RX_PACKETS;
+		sinfo->rx_packets = sta_rx_data_pkts(psta);
+		sinfo->filled |= STATION_INFO_TX_PACKETS;
+		sinfo->tx_packets = psta->sta_stats.tx_pkts;
+		sinfo->filled |= STATION_INFO_TX_FAILED;
+		sinfo->tx_failed = psta->sta_stats.tx_fail_cnt;
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_cfg80211_fill_mesh_only_sta_info(plink, psta, sinfo);
+#endif
+
+exit:
+	return ret;
+}
+
+extern int netdev_open(struct net_device *pnetdev);
+
+#if 0
+enum nl80211_iftype {
+	NL80211_IFTYPE_UNSPECIFIED,
+	NL80211_IFTYPE_ADHOC, /* 1 */
+	NL80211_IFTYPE_STATION, /* 2 */
+	NL80211_IFTYPE_AP, /* 3 */
+	NL80211_IFTYPE_AP_VLAN,
+	NL80211_IFTYPE_WDS,
+	NL80211_IFTYPE_MONITOR, /* 6 */
+	NL80211_IFTYPE_MESH_POINT,
+	NL80211_IFTYPE_P2P_CLIENT, /* 8 */
+	NL80211_IFTYPE_P2P_GO, /* 9 */
+	/* keep last */
+	NUM_NL80211_IFTYPES,
+	NL80211_IFTYPE_MAX = NUM_NL80211_IFTYPES - 1
+};
+#endif
+static int cfg80211_rtw_change_iface(struct wiphy *wiphy,
+				     struct net_device *ndev,
+				     enum nl80211_iftype type,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+				     u32 *flags,
+#endif
+				     struct vif_params *params)
+{
+	enum nl80211_iftype old_type;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8 is_p2p = _FALSE;
+#endif
+	int ret = 0;
+	u8 change = _FALSE;
+
+	RTW_INFO(FUNC_NDEV_FMT" type=%d, hw_port:%d\n", FUNC_NDEV_ARG(ndev), type, padapter->hw_port);
+
+	if (adapter_to_dvobj(padapter)->processing_dev_remove == _TRUE) {
+		ret = -EPERM;
+		goto exit;
+	}
+
+
+	RTW_INFO(FUNC_NDEV_FMT" call netdev_open\n", FUNC_NDEV_ARG(ndev));
+	if (netdev_open(ndev) != 0) {
+		RTW_INFO(FUNC_NDEV_FMT" call netdev_open fail\n", FUNC_NDEV_ARG(ndev));
+		ret = -EPERM;
+		goto exit;
+	}
+
+
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		RTW_INFO(FUNC_NDEV_FMT" call rtw_pwr_wakeup fail\n", FUNC_NDEV_ARG(ndev));
+		ret = -EPERM;
+		goto exit;
+	}
+
+	old_type = rtw_wdev->iftype;
+	RTW_INFO(FUNC_NDEV_FMT" old_iftype=%d, new_iftype=%d\n",
+		FUNC_NDEV_ARG(ndev), old_type, type);
+
+	if (old_type != type) {
+		change = _TRUE;
+		pmlmeext->action_public_rxseq = 0xffff;
+		pmlmeext->action_public_dialog_token = 0xff;
+	}
+
+	/* initial default type */
+	ndev->type = ARPHRD_ETHER;
+
+	/*
+	 * Disable Power Save in moniter mode,
+	 * and enable it after leaving moniter mode.
+	 */
+	if (type == NL80211_IFTYPE_MONITOR) {
+		rtw_ps_deny(padapter, PS_DENY_MONITOR_MODE);
+		LeaveAllPowerSaveMode(padapter);
+	} else if (old_type == NL80211_IFTYPE_MONITOR) {
+		/* driver in moniter mode in last time */
+		rtw_ps_deny_cancel(padapter, PS_DENY_MONITOR_MODE);
+	}
+
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		networkType = Ndis802_11IBSS;
+		break;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+		is_p2p = _TRUE;
+	#endif
+	case NL80211_IFTYPE_STATION:
+		networkType = Ndis802_11Infrastructure;
+
+		#ifdef CONFIG_P2P
+		if (change && pwdinfo->driver_interface == DRIVER_CFG80211) {
+			if (is_p2p == _TRUE)
+				rtw_p2p_enable(padapter, P2P_ROLE_CLIENT);
+			#if !RTW_P2P_GROUP_INTERFACE
+			else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)
+					|| rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)
+			) {
+				/* it means remove GC/GO and change mode from GC/GO to station(P2P DEVICE) */
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
+			}
+			#endif
+		}
+		#endif /* CONFIG_P2P */
+
+		break;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+		is_p2p = _TRUE;
+	#endif
+	case NL80211_IFTYPE_AP:
+		networkType = Ndis802_11APMode;
+
+		#ifdef CONFIG_P2P
+		if (change && pwdinfo->driver_interface == DRIVER_CFG80211) {
+			if (is_p2p == _TRUE)
+				rtw_p2p_enable(padapter, P2P_ROLE_GO);
+			#if !RTW_P2P_GROUP_INTERFACE
+			else if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+				/* it means P2P Group created, we will be GO and change mode from  P2P DEVICE to AP(GO) */
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
+			}
+			#endif
+		}
+		#endif /* CONFIG_P2P */
+
+		break;
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		networkType = Ndis802_11_mesh;
+		break;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		networkType = Ndis802_11Monitor;
+#if 0
+		ndev->type = ARPHRD_IEEE80211; /* IEEE 802.11 : 801 */
+#endif
+		ndev->type = ARPHRD_IEEE80211_RADIOTAP; /* IEEE 802.11 + radiotap header : 803 */
+		break;
+	default:
+		ret = -EOPNOTSUPP;
+		goto exit;
+	}
+
+	rtw_wdev->iftype = type;
+
+	if (rtw_set_802_11_infrastructure_mode(padapter, networkType) == _FALSE) {
+		rtw_wdev->iftype = old_type;
+		ret = -EPERM;
+		goto exit;
+	}
+
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
+
+exit:
+
+	RTW_INFO(FUNC_NDEV_FMT" ret:%d\n", FUNC_NDEV_ARG(ndev), ret);
+	return ret;
+}
+
+void rtw_cfg80211_indicate_scan_done(_adapter *adapter, bool aborted)
+{
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	_irqL	irqL;
+
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+	struct cfg80211_scan_info info;
+
+	memset(&info, 0, sizeof(info));
+	info.aborted = aborted;
+#endif
+
+	_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+	if (pwdev_priv->scan_request != NULL) {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("%s with scan req\n", __FUNCTION__);
+		#endif
+
+		/* avoid WARN_ON(request != wiphy_to_dev(request->wiphy)->scan_req); */
+		if (pwdev_priv->scan_request->wiphy != pwdev_priv->rtw_wdev->wiphy)
+			RTW_INFO("error wiphy compare\n");
+		else
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+			cfg80211_scan_done(pwdev_priv->scan_request, &info);
+#else
+			cfg80211_scan_done(pwdev_priv->scan_request, aborted);
+#endif
+
+		pwdev_priv->scan_request = NULL;
+	} else {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("%s without scan req\n", __FUNCTION__);
+		#endif
+	}
+	_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+}
+
+u32 rtw_cfg80211_wait_scan_req_empty(_adapter *adapter, u32 timeout_ms)
+{
+	struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+	u8 empty = _FALSE;
+	systime start;
+	u32 pass_ms;
+
+	start = rtw_get_current_time();
+
+	while (rtw_get_passing_time_ms(start) <= timeout_ms) {
+
+		if (RTW_CANNOT_RUN(adapter))
+			break;
+
+		if (!wdev_priv->scan_request) {
+			empty = _TRUE;
+			break;
+		}
+
+		rtw_msleep_os(10);
+	}
+
+	pass_ms = rtw_get_passing_time_ms(start);
+
+	if (empty == _FALSE && pass_ms > timeout_ms)
+		RTW_PRINT(FUNC_ADPT_FMT" pass_ms:%u, timeout\n"
+			, FUNC_ADPT_ARG(adapter), pass_ms);
+
+	return pass_ms;
+}
+
+void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork)
+{
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct wiphy *wiphy = pwdev->wiphy;
+	struct cfg80211_bss *bss = NULL;
+	WLAN_BSSID_EX select_network = pnetwork->network;
+
+	bss = cfg80211_get_bss(wiphy, NULL/*notify_channel*/,
+		select_network.MacAddress, select_network.Ssid.Ssid,
+		select_network.Ssid.SsidLength,
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0)
+		select_network.InfrastructureMode == Ndis802_11Infrastructure?IEEE80211_BSS_TYPE_ESS:IEEE80211_BSS_TYPE_IBSS,
+		IEEE80211_PRIVACY(select_network.Privacy));
+#else
+		select_network.InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS,
+		select_network.InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS);
+#endif
+
+	if (bss) {
+		cfg80211_unlink_bss(wiphy, bss);
+		RTW_INFO("%s(): cfg80211_unlink %s!!\n", __func__, select_network.Ssid.Ssid);
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
+		cfg80211_put_bss(padapter->rtw_wdev->wiphy, bss);
+#else
+		cfg80211_put_bss(bss);
+#endif
+	}
+	return;
+}
+
+/* if target wps scan ongoing, target_ssid is filled */
+int rtw_cfg80211_is_target_wps_scan(struct cfg80211_scan_request *scan_req, struct cfg80211_ssid *target_ssid)
+{
+	int ret = 0;
+
+	if (scan_req->n_ssids != 1
+		|| scan_req->ssids[0].ssid_len == 0
+		|| scan_req->n_channels != 1
+	)
+		goto exit;
+
+	/* under target WPS scan */
+	_rtw_memcpy(target_ssid, scan_req->ssids, sizeof(struct cfg80211_ssid));
+	ret = 1;
+
+exit:
+	return ret;
+}
+
+static void _rtw_cfg80211_surveydone_event_callback(_adapter *padapter, struct cfg80211_scan_request *scan_req)
+{
+	_irqL	irqL;
+	_list					*plist, *phead;
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	_queue				*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network	*pnetwork = NULL;
+	u32 cnt = 0;
+	u32 wait_for_surveydone;
+	sint wait_status;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct cfg80211_ssid target_ssid;
+	u8 target_wps_scan = 0;
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s\n", __func__);
+#endif
+
+	if (scan_req)
+		target_wps_scan = rtw_cfg80211_is_target_wps_scan(scan_req, &target_ssid);
+	else {
+		_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+		if (pwdev_priv->scan_request != NULL)
+			target_wps_scan = rtw_cfg80211_is_target_wps_scan(pwdev_priv->scan_request, &target_ssid);
+		_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+	}
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		/* report network only if the current channel set contains the channel to which this network belongs */
+		if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
+			&& rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
+			&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
+		) {
+			if (target_wps_scan)
+				rtw_cfg80211_clear_wps_sr_of_non_target_bss(padapter, pnetwork, &target_ssid);
+			rtw_cfg80211_inform_bss(padapter, pnetwork);
+		}
+#if 0
+		/* check ralink testbed RSN IE length */
+		{
+			if (_rtw_memcmp(pnetwork->network.Ssid.Ssid, "Ralink_11n_AP", 13)) {
+				uint ie_len = 0;
+				u8 *p = NULL;
+				p = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
+				RTW_INFO("ie_len=%d\n", ie_len);
+			}
+		}
+#endif
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+}
+
+inline void rtw_cfg80211_surveydone_event_callback(_adapter *padapter)
+{
+	_rtw_cfg80211_surveydone_event_callback(padapter, NULL);
+}
+
+static int rtw_cfg80211_set_probe_req_wpsp2pie(_adapter *padapter, char *buf, int len)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u8 *wps_ie;
+	u32	p2p_ielen = 0;
+	u8 *p2p_ie;
+	u32	wfd_ielen = 0;
+	u8 *wfd_ie;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+#endif
+
+	if (len > 0) {
+		wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen);
+		if (wps_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_req_wps_ielen=%d\n", wps_ielen);
+			#endif
+
+			if (pmlmepriv->wps_probe_req_ie) {
+				u32 free_len = pmlmepriv->wps_probe_req_ie_len;
+				pmlmepriv->wps_probe_req_ie_len = 0;
+				rtw_mfree(pmlmepriv->wps_probe_req_ie, free_len);
+				pmlmepriv->wps_probe_req_ie = NULL;
+			}
+
+			pmlmepriv->wps_probe_req_ie = rtw_malloc(wps_ielen);
+			if (pmlmepriv->wps_probe_req_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+			_rtw_memcpy(pmlmepriv->wps_probe_req_ie, wps_ie, wps_ielen);
+			pmlmepriv->wps_probe_req_ie_len = wps_ielen;
+		}
+
+		/* buf += wps_ielen; */
+		/* len -= wps_ielen; */
+
+		#ifdef CONFIG_P2P
+		p2p_ie = rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			struct wifidirect_info *wdinfo = &padapter->wdinfo;
+			u32 attr_contentlen = 0;
+			u8 listen_ch_attr[5];
+
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_req_p2p_ielen=%d\n", p2p_ielen);
+			#endif
+
+			if (pmlmepriv->p2p_probe_req_ie) {
+				u32 free_len = pmlmepriv->p2p_probe_req_ie_len;
+				pmlmepriv->p2p_probe_req_ie_len = 0;
+				rtw_mfree(pmlmepriv->p2p_probe_req_ie, free_len);
+				pmlmepriv->p2p_probe_req_ie = NULL;
+			}
+
+			pmlmepriv->p2p_probe_req_ie = rtw_malloc(p2p_ielen);
+			if (pmlmepriv->p2p_probe_req_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+			_rtw_memcpy(pmlmepriv->p2p_probe_req_ie, p2p_ie, p2p_ielen);
+			pmlmepriv->p2p_probe_req_ie_len = p2p_ielen;
+
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, (u8 *)listen_ch_attr, (uint *) &attr_contentlen)
+				&& attr_contentlen == 5) {
+				if (wdinfo->listen_channel !=  listen_ch_attr[4]) {
+					RTW_INFO(FUNC_ADPT_FMT" listen channel - country:%c%c%c, class:%u, ch:%u\n",
+						FUNC_ADPT_ARG(padapter), listen_ch_attr[0], listen_ch_attr[1], listen_ch_attr[2],
+						listen_ch_attr[3], listen_ch_attr[4]);
+					wdinfo->listen_channel = listen_ch_attr[4];
+				}
+			}
+		}
+		#endif /* CONFIG_P2P */
+
+		#ifdef CONFIG_WFD
+		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_req_wfd_ielen=%d\n", wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_PROBE_REQ_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				return -EINVAL;
+		}
+		#endif /* CONFIG_WFD */
+	}
+
+	return ret;
+
+}
+
+#ifdef CONFIG_CONCURRENT_MODE
+u8 rtw_cfg80211_scan_via_buddy(_adapter *padapter, struct cfg80211_scan_request *request)
+{
+	int i;
+	u8 ret = _FALSE;
+	_adapter *iface = NULL;
+	_irqL	irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		struct mlme_priv *buddy_mlmepriv;
+		struct rtw_wdev_priv *buddy_wdev_priv;
+
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+
+		if (iface == padapter)
+			continue;
+
+		if (rtw_is_adapter_up(iface) == _FALSE)
+			continue;
+
+		buddy_mlmepriv = &iface->mlmepriv;
+		if (!check_fwstate(buddy_mlmepriv, _FW_UNDER_SURVEY))
+			continue;
+
+		buddy_wdev_priv = adapter_wdev_data(iface);
+		_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+		_enter_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
+		if (buddy_wdev_priv->scan_request) {
+			pmlmepriv->scanning_via_buddy_intf = _TRUE;
+			_enter_critical_bh(&pmlmepriv->lock, &irqL);
+			set_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
+			_exit_critical_bh(&pmlmepriv->lock, &irqL);
+			pwdev_priv->scan_request = request;
+			ret = _TRUE;
+		}
+		_exit_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
+		_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+
+		if (ret == _TRUE)
+			goto exit;
+	}
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_indicate_scan_done_for_buddy(_adapter *padapter, bool bscan_aborted)
+{
+	int i;
+	u8 ret = 0;
+	_adapter *iface = NULL;
+	_irqL	irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mlme_priv *mlmepriv;
+	struct rtw_wdev_priv *wdev_priv;
+	bool indicate_buddy_scan;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+
+			if (iface == padapter)
+				continue;
+
+			mlmepriv = &(iface->mlmepriv);
+			wdev_priv = adapter_wdev_data(iface);
+
+			indicate_buddy_scan = _FALSE;
+			_enter_critical_bh(&wdev_priv->scan_req_lock, &irqL);
+			if (wdev_priv->scan_request && mlmepriv->scanning_via_buddy_intf == _TRUE) {
+				mlmepriv->scanning_via_buddy_intf = _FALSE;
+				clr_fwstate(mlmepriv, _FW_UNDER_SURVEY);
+				indicate_buddy_scan = _TRUE;
+			}
+			_exit_critical_bh(&wdev_priv->scan_req_lock, &irqL);
+
+			if (indicate_buddy_scan == _TRUE) {
+				rtw_cfg80211_surveydone_event_callback(iface);
+				rtw_indicate_scan_done(iface, bscan_aborted);
+			}
+
+		}
+	}
+}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+static int cfg80211_rtw_scan(struct wiphy *wiphy
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+	, struct net_device *ndev
+	#endif
+	, struct cfg80211_scan_request *request)
+{
+	int i, chan_num = 0;
+	u8 _status = _FALSE;
+	int ret = 0;
+	struct sitesurvey_parm parm;
+	_irqL	irqL;
+	u8 *wps_ie = NULL;
+	uint wps_ielen = 0;
+	u8 *p2p_ie = NULL;
+	uint p2p_ielen = 0;
+	u8 survey_times = 3;
+	u8 survey_times_for_one_ch = 6;
+	struct cfg80211_ssid *ssids = request->ssids;
+	int social_channel = 0, j = 0;
+	bool need_indicate_scan_done = _FALSE;
+	bool ps_denied = _FALSE;
+
+	_adapter *padapter;
+	struct wireless_dev *wdev;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct mlme_priv *pmlmepriv;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo;
+#endif /* CONFIG_P2P */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	wdev = request->wdev;
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		ret = -EINVAL;
+		goto exit;
+	}
+#else
+	if (ndev == NULL) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	pwdev_priv = adapter_wdev_data(padapter);
+	pmlmepriv = &padapter->mlmepriv;
+#ifdef CONFIG_P2P
+	pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
+
+	RTW_INFO(FUNC_ADPT_FMT"%s\n", FUNC_ADPT_ARG(padapter)
+		, wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : "");
+
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block Scan request\n");
+		ret = -EPERM;
+		goto exit;
+	}
+#endif
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
+		RTW_INFO(FUNC_ADPT_FMT" blocking scan for under rson scanning process\n", FUNC_ADPT_ARG(padapter));
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+#endif
+
+	if (adapter_wdev_data(padapter)->block_scan == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT" wdev_priv.block_scan is set\n", FUNC_ADPT_ARG(padapter));
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	ps_denied = _TRUE;
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
+#ifdef CONFIG_P2P
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (ssids->ssid != NULL
+			&& _rtw_memcmp(ssids->ssid, "DIRECT-", 7)
+			&& rtw_get_p2p_ie((u8 *)request->ie, request->ie_len, NULL, NULL)
+		) {
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+				rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
+			else {
+				rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+				#ifdef CONFIG_DEBUG_CFG80211
+				RTW_INFO("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
+				#endif
+			}
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
+
+			if (request->n_channels == 3 &&
+				request->channels[0]->hw_value == 1 &&
+				request->channels[1]->hw_value == 6 &&
+				request->channels[2]->hw_value == 11
+			)
+				social_channel = 1;
+		}
+	}
+#endif /*CONFIG_P2P*/
+
+	if (request->ie && request->ie_len > 0)
+		rtw_cfg80211_set_probe_req_wpsp2pie(padapter, (u8 *)request->ie, request->ie_len);
+
+	if (rtw_is_scan_deny(padapter)) {
+		RTW_INFO(FUNC_ADPT_FMT	": scan deny\n", FUNC_ADPT_ARG(padapter));
+#if CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY
+		ret = -EBUSY;
+		goto exit;
+#else
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+#endif
+	}
+
+	/* check fw state*/
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+
+#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO(FUNC_ADPT_FMT" under WIFI_AP_STATE\n", FUNC_ADPT_ARG(padapter));
+#endif
+
+		if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS | _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
+			RTW_INFO("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
+
+			if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
+				RTW_INFO("AP mode process WPS\n");
+
+			need_indicate_scan_done = _TRUE;
+			goto check_need_indicate_scan_done;
+		}
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+		RTW_INFO("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
+		ret = -EBUSY;
+		goto check_need_indicate_scan_done;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
+		RTW_INFO("%s exit due to buddy_intf's mlme state under linking or wps\n", __func__);
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+
+	} else if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_SURVEY)) {
+		bool scan_via_buddy = rtw_cfg80211_scan_via_buddy(padapter, request);
+
+		if (scan_via_buddy == _FALSE)
+			need_indicate_scan_done = _TRUE;
+
+		goto check_need_indicate_scan_done;
+	}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+	/* busy traffic check*/
+	if (rtw_mi_busy_traffic_check(padapter, _TRUE)) {
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
+
+		if (social_channel == 0)
+			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
+		else
+			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_SOCIAL_LAST);
+	}
+#endif /* CONFIG_P2P */
+
+	rtw_init_sitesurvey_parm(padapter, &parm);
+
+	/* parsing request ssids, n_ssids */
+	for (i = 0; i < request->n_ssids && i < RTW_SSID_SCAN_AMOUNT; i++) {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("ssid=%s, len=%d\n", ssids[i].ssid, ssids[i].ssid_len);
+		#endif
+		_rtw_memcpy(&parm.ssid[i].Ssid, ssids[i].ssid, ssids[i].ssid_len);
+		parm.ssid[i].SsidLength = ssids[i].ssid_len;
+	}
+	parm.ssid_num = i;
+
+	/* parsing channels, n_channels */
+	for (i = 0; i < request->n_channels && i < RTW_CHANNEL_SCAN_AMOUNT; i++) {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO(FUNC_ADPT_FMT CHAN_FMT"\n", FUNC_ADPT_ARG(padapter), CHAN_ARG(request->channels[i]));
+		#endif
+		parm.ch[i].hw_value = request->channels[i]->hw_value;
+		parm.ch[i].flags = request->channels[i]->flags;
+	}
+	parm.ch_num = i;
+
+	if (request->n_channels == 1) {
+		for (i = 1; i < survey_times_for_one_ch; i++)
+			_rtw_memcpy(&parm.ch[i], &parm.ch[0], sizeof(struct rtw_ieee80211_channel));
+		parm.ch_num = survey_times_for_one_ch;
+	} else if (request->n_channels <= 4) {
+		for (j = request->n_channels - 1; j >= 0; j--)
+			for (i = 0; i < survey_times; i++)
+				_rtw_memcpy(&parm.ch[j * survey_times + i], &parm.ch[j], sizeof(struct rtw_ieee80211_channel));
+		parm.ch_num = survey_times * request->n_channels;
+	}
+
+	_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	_status = rtw_sitesurvey_cmd(padapter, &parm);
+	if (_status == _SUCCESS)
+		pwdev_priv->scan_request = request;
+	else
+		ret = -1;
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+	_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+
+check_need_indicate_scan_done:
+	if (_TRUE == need_indicate_scan_done) {
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+		struct cfg80211_scan_info info;
+
+		memset(&info, 0, sizeof(info));
+		info.aborted = 0;
+#endif
+
+		_rtw_cfg80211_surveydone_event_callback(padapter, request);
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+		cfg80211_scan_done(request, &info);
+#else
+		cfg80211_scan_done(request, 0);
+#endif
+	}
+
+cancel_ps_deny:
+	if (ps_denied == _TRUE)
+		rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
+
+exit:
+	return ret;
+
+}
+
+static int cfg80211_rtw_set_wiphy_params(struct wiphy *wiphy, u32 changed)
+{
+#if 0
+	struct iwm_priv *iwm = wiphy_to_iwm(wiphy);
+
+	if (changed & WIPHY_PARAM_RTS_THRESHOLD &&
+	    (iwm->conf.rts_threshold != wiphy->rts_threshold)) {
+		int ret;
+
+		iwm->conf.rts_threshold = wiphy->rts_threshold;
+
+		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_CFG_FIX,
+				CFG_RTS_THRESHOLD,
+				iwm->conf.rts_threshold);
+		if (ret < 0)
+			return ret;
+	}
+
+	if (changed & WIPHY_PARAM_FRAG_THRESHOLD &&
+	    (iwm->conf.frag_threshold != wiphy->frag_threshold)) {
+		int ret;
+
+		iwm->conf.frag_threshold = wiphy->frag_threshold;
+
+		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_FA_CFG_FIX,
+				CFG_FRAG_THRESHOLD,
+				iwm->conf.frag_threshold);
+		if (ret < 0)
+			return ret;
+	}
+#endif
+	RTW_INFO("%s\n", __func__);
+	return 0;
+}
+
+
+
+static int rtw_cfg80211_set_wpa_version(struct security_priv *psecuritypriv, u32 wpa_version)
+{
+	RTW_INFO("%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 0
+	if (wpa_version & NL80211_WPA_VERSION_2)
+		psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK;
+#endif
+
+	#ifdef CONFIG_WAPI_SUPPORT
+	if (wpa_version & NL80211_WAPI_VERSION_1)
+		psecuritypriv->ndisauthtype = Ndis802_11AuthModeWAPI;
+	#endif
+
+	return 0;
+
+}
+
+static int rtw_cfg80211_set_auth_type(struct security_priv *psecuritypriv,
+		enum nl80211_auth_type sme_auth_type)
+{
+	RTW_INFO("%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;
+
+#ifdef CONFIG_WAPI_SUPPORT
+		if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWAPI)
+			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+#endif
+
+		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;
+
+	RTW_INFO("%s, ucast=%d, cipher=0x%x\n", __func__, ucast, cipher);
+
+
+	if (!cipher) {
+		*profile_cipher = _NO_PRIVACY_;
+		psecuritypriv->ndisencryptstatus = ndisencryptstatus;
+		return 0;
+	}
+
+	switch (cipher) {
+	case IW_AUTH_CIPHER_NONE:
+		*profile_cipher = _NO_PRIVACY_;
+		ndisencryptstatus = Ndis802_11EncryptionDisabled;
+#ifdef CONFIG_WAPI_SUPPORT
+		if (psecuritypriv->dot11PrivacyAlgrthm == _SMS4_)
+			*profile_cipher = _SMS4_;
+#endif
+		break;
+	case WLAN_CIPHER_SUITE_WEP40:
+		*profile_cipher = _WEP40_;
+		ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WLAN_CIPHER_SUITE_WEP104:
+		*profile_cipher = _WEP104_;
+		ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WLAN_CIPHER_SUITE_TKIP:
+		*profile_cipher = _TKIP_;
+		ndisencryptstatus = Ndis802_11Encryption2Enabled;
+		break;
+	case WLAN_CIPHER_SUITE_CCMP:
+		*profile_cipher = _AES_;
+		ndisencryptstatus = Ndis802_11Encryption3Enabled;
+		break;
+#ifdef CONFIG_WAPI_SUPPORT
+	case WLAN_CIPHER_SUITE_SMS4:
+		*profile_cipher = _SMS4_;
+		ndisencryptstatus = Ndis802_11_EncrypteionWAPI;
+		break;
+#endif
+	default:
+		RTW_INFO("Unsupported cipher: 0x%x\n", cipher);
+		return -ENOTSUPP;
+	}
+
+	if (ucast) {
+		psecuritypriv->ndisencryptstatus = ndisencryptstatus;
+
+		/* if(psecuritypriv->dot11PrivacyAlgrthm >= _AES_) */
+		/*	psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK; */
+	}
+
+	return 0;
+}
+
+static int rtw_cfg80211_set_key_mgt(struct security_priv *psecuritypriv, u32 key_mgt)
+{
+	RTW_INFO("%s, key_mgt=0x%x\n", __func__, key_mgt);
+
+	if (key_mgt == WLAN_AKM_SUITE_8021X) {
+		/* *auth_type = UMAC_AUTH_TYPE_8021X; */
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 1;
+	} else if (key_mgt == WLAN_AKM_SUITE_PSK) {
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 2;
+	}
+#ifdef CONFIG_WAPI_SUPPORT
+	else if (key_mgt == WLAN_AKM_SUITE_WAPI_PSK)
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+	else if (key_mgt == WLAN_AKM_SUITE_WAPI_CERT)
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+#endif
+#ifdef CONFIG_RTW_80211R
+	else if (key_mgt == WLAN_AKM_SUITE_FT_8021X) {
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 3;
+	} else if (key_mgt == WLAN_AKM_SUITE_FT_PSK) {
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 4;
+	}
+#endif
+	else {
+		RTW_INFO("Invalid key mgt: 0x%x\n", key_mgt);
+		/* return -EINVAL; */
+	}
+
+	return 0;
+}
+
+static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)
+{
+	u8 *buf = NULL, *pos = NULL;
+	u32 left;
+	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
+	int ret = 0;
+	int wpa_ielen = 0;
+	int wpa2_ielen = 0;
+	u8 *pwpa, *pwpa2;
+	u8 null_addr[] = {0, 0, 0, 0, 0, 0};
+
+	if (pie == NULL || !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;
+	}
+
+	buf = rtw_zmalloc(ielen);
+	if (buf == NULL) {
+		ret =  -ENOMEM;
+		goto exit;
+	}
+
+	_rtw_memcpy(buf, pie , ielen);
+
+	RTW_INFO("set wpa_ie(length:%zu):\n", ielen);
+	RTW_INFO_DUMP(NULL, buf, ielen);
+
+	pos = buf;
+	if (ielen < RSN_HEADER_LEN) {
+		ret  = -1;
+		goto exit;
+	}
+
+	pwpa = rtw_get_wpa_ie(buf, &wpa_ielen, ielen);
+	if (pwpa && wpa_ielen > 0) {
+		if (rtw_parse_wpa_ie(pwpa, wpa_ielen + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &pwpa[0], wpa_ielen + 2);
+
+			RTW_INFO("got wpa_ie, wpa_ielen:%u\n", wpa_ielen);
+		}
+	}
+
+	pwpa2 = rtw_get_wpa2_ie(buf, &wpa2_ielen, ielen);
+	if (pwpa2 && wpa2_ielen > 0) {
+		if (rtw_parse_wpa2_ie(pwpa2, wpa2_ielen + 2, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &pwpa2[0], wpa2_ielen + 2);
+
+			RTW_INFO("got wpa2_ie, wpa2_ielen:%u\n", wpa2_ielen);
+		}
+	}
+
+	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 = _NO_PRIVACY_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+		break;
+	case WPA_CIPHER_WEP40:
+		padapter->securitypriv.dot118021XGrpPrivacy = _WEP40_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WPA_CIPHER_TKIP:
+		padapter->securitypriv.dot118021XGrpPrivacy = _TKIP_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+		break;
+	case WPA_CIPHER_CCMP:
+		padapter->securitypriv.dot118021XGrpPrivacy = _AES_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+		break;
+	case WPA_CIPHER_WEP104:
+		padapter->securitypriv.dot118021XGrpPrivacy = _WEP104_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	}
+
+	switch (pairwise_cipher) {
+	case WPA_CIPHER_NONE:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+		break;
+	case WPA_CIPHER_WEP40:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WPA_CIPHER_TKIP:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _TKIP_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+		break;
+	case WPA_CIPHER_CCMP:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _AES_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+		break;
+	case WPA_CIPHER_WEP104:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	}
+
+	if (mfp_opt == MFP_INVALID) {
+		RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+		ret = -EINVAL;
+		goto exit;
+	}
+	padapter->securitypriv.mfp_opt = mfp_opt;
+
+	{/* handle wps_ie */
+		uint wps_ielen;
+		u8 *wps_ie;
+
+		wps_ie = rtw_get_wps_ie(buf, ielen, NULL, &wps_ielen);
+		if (wps_ie && wps_ielen > 0) {
+			RTW_INFO("got wps_ie, wps_ielen:%u\n", wps_ielen);
+			padapter->securitypriv.wps_ie_len = wps_ielen < MAX_WPS_IE_LEN ? wps_ielen : MAX_WPS_IE_LEN;
+			_rtw_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);
+	}
+
+	#ifdef CONFIG_P2P
+	{/* check p2p_ie for assoc req; */
+		uint p2p_ielen = 0;
+		u8 *p2p_ie;
+		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+		p2p_ie = rtw_get_p2p_ie(buf, ielen, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s p2p_assoc_req_ielen=%d\n", __FUNCTION__, p2p_ielen);
+			#endif
+
+			if (pmlmepriv->p2p_assoc_req_ie) {
+				u32 free_len = pmlmepriv->p2p_assoc_req_ie_len;
+				pmlmepriv->p2p_assoc_req_ie_len = 0;
+				rtw_mfree(pmlmepriv->p2p_assoc_req_ie, free_len);
+				pmlmepriv->p2p_assoc_req_ie = NULL;
+			}
+
+			pmlmepriv->p2p_assoc_req_ie = rtw_malloc(p2p_ielen);
+			if (pmlmepriv->p2p_assoc_req_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				goto exit;
+			}
+			_rtw_memcpy(pmlmepriv->p2p_assoc_req_ie, p2p_ie, p2p_ielen);
+			pmlmepriv->p2p_assoc_req_ie_len = p2p_ielen;
+		}
+	}
+	#endif /* CONFIG_P2P */
+
+	#ifdef CONFIG_WFD
+	{
+		uint wfd_ielen = 0;
+		u8 *wfd_ie;
+		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+		wfd_ie = rtw_get_wfd_ie(buf, ielen, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s wfd_assoc_req_ielen=%d\n", __FUNCTION__, wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_ASSOC_REQ_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				goto exit;
+		}
+	}
+	#endif /* CONFIG_WFD */
+
+	/* TKIP and AES disallow multicast packets until installing group key */
+	if (padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_
+		|| padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_WTMIC_
+		|| padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)
+		/* WPS open need to enable multicast */
+		/* || check_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS) == _TRUE) */
+		rtw_hal_set_hwreg(padapter, HW_VAR_OFF_RCR_AM, null_addr);
+
+
+exit:
+	if (buf)
+		rtw_mfree(buf, ielen);
+	if (ret)
+		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
+
+	return ret;
+}
+
+static int cfg80211_rtw_join_ibss(struct wiphy *wiphy, struct net_device *ndev,
+				  struct cfg80211_ibss_params *params)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	NDIS_802_11_SSID ndis_ssid;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *pch_def;
+#endif
+	struct ieee80211_channel *pch;
+	int ret = 0;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	pch_def = (struct cfg80211_chan_def *)(&params->chandef);
+	pch = (struct ieee80211_channel *) pch_def->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 31))
+	pch = (struct ieee80211_channel *)(params->channel);
+#endif
+
+	if (!params->ssid || !params->ssid_len) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (params->ssid_len > IW_ESSID_MAX_SIZE) {
+		ret = -E2BIG;
+		goto exit;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_JOIN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EPERM;
+		goto cancel_ps_deny;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING)) {
+		RTW_INFO("%s, but buddy_intf is under linking\n", __FUNCTION__);
+		ret = -EINVAL;
+		goto cancel_ps_deny;
+	}
+	rtw_mi_buddy_scan_abort(padapter, _TRUE); /* OR rtw_mi_scan_abort(padapter, _TRUE);*/
+#endif /*CONFIG_CONCURRENT_MODE*/
+
+
+	_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));
+	ndis_ssid.SsidLength = params->ssid_len;
+	_rtw_memcpy(ndis_ssid.Ssid, (u8 *)params->ssid, params->ssid_len);
+
+	/* RTW_INFO("ssid=%s, len=%zu\n", ndis_ssid.Ssid, params->ssid_len); */
+
+	psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
+	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+	psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
+
+	ret = rtw_cfg80211_set_auth_type(psecuritypriv, NL80211_AUTHTYPE_OPEN_SYSTEM);
+	rtw_set_802_11_authentication_mode(padapter, psecuritypriv->ndisauthtype);
+
+	RTW_INFO("%s: center_freq = %d\n", __func__, pch->center_freq);
+	pmlmeext->cur_channel = rtw_freq2ch(pch->center_freq);
+
+	if (rtw_set_802_11_ssid(padapter, &ndis_ssid) == _FALSE) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_leave_ibss(struct wiphy *wiphy, struct net_device *ndev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	enum nl80211_iftype old_type;
+	int ret = 0;
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	rtw_wdev_set_not_indic_disco(pwdev_priv, 1);
+
+	old_type = rtw_wdev->iftype;
+
+	rtw_set_to_roam(padapter, 0);
+
+	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
+		rtw_scan_abort(padapter);
+		LeaveAllPowerSaveMode(padapter);
+
+		rtw_wdev->iftype = NL80211_IFTYPE_STATION;
+
+		if (rtw_set_802_11_infrastructure_mode(padapter, Ndis802_11Infrastructure) == _FALSE) {
+			rtw_wdev->iftype = old_type;
+			ret = -EPERM;
+			goto leave_ibss;
+		}
+		rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+	}
+
+leave_ibss:
+	rtw_wdev_set_not_indic_disco(pwdev_priv, 0);
+
+	return 0;
+}
+
+bool rtw_cfg80211_is_connect_requested(_adapter *adapter)
+{
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	_irqL irqL;
+	bool requested;
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+	requested = pwdev_priv->connect_req ? 1 : 0;
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	return requested;
+}
+
+static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,
+				struct cfg80211_connect_params *sme)
+{
+	int ret = 0;
+	struct wlan_network *pnetwork = NULL;
+	NDIS_802_11_AUTHENTICATION_MODE authmode;
+	NDIS_802_11_SSID ndis_ssid;
+	u8 *dst_ssid, *src_ssid;
+	u8 *dst_bssid, *src_bssid;
+	/* u8 matched_by_bssid=_FALSE; */
+	/* u8 matched_by_ssid=_FALSE; */
+	u8 matched = _FALSE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	_queue *queue = &pmlmepriv->scanned_queue;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	_irqL irqL;
+
+	rtw_wdev_set_not_indic_disco(pwdev_priv, 1);
+
+	RTW_INFO("=>"FUNC_NDEV_FMT" - Start to Connection\n", FUNC_NDEV_ARG(ndev));
+	RTW_INFO("privacy=%d, key=%p, key_len=%d, key_idx=%d, auth_type=%d\n",
+		sme->privacy, sme->key, sme->key_len, sme->key_idx, sme->auth_type);
+
+
+	if (pwdev_priv->block == _TRUE) {
+		ret = -EBUSY;
+		RTW_INFO("%s wdev_priv.block is set\n", __FUNCTION__);
+		goto exit;
+	}
+
+#ifdef CONFIG_PLATFORM_MSTAR_SCAN_BEFORE_CONNECT
+	printk("MStar Android!\n");
+	if (pwdev_priv->bandroid_scan == _FALSE) {
+#ifdef CONFIG_P2P
+		struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+#endif /* CONFIG_P2P */
+		{
+			ret = -EBUSY;
+			printk("Android hasn't attached yet!\n");
+			goto exit;
+		}
+	}
+#endif
+
+	if (!sme->ssid || !sme->ssid_len) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (sme->ssid_len > IW_ESSID_MAX_SIZE) {
+		ret = -E2BIG;
+		goto exit;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_JOIN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EPERM;
+		goto cancel_ps_deny;
+	}
+
+	rtw_mi_scan_abort(padapter, _TRUE);
+
+	rtw_join_abort_timeout(padapter, 300);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING)) {
+		ret = -EINVAL;
+		goto cancel_ps_deny;
+	}
+#endif
+
+	_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));
+	ndis_ssid.SsidLength = sme->ssid_len;
+	_rtw_memcpy(ndis_ssid.Ssid, (u8 *)sme->ssid, sme->ssid_len);
+
+	RTW_INFO("ssid=%s, len=%zu\n", ndis_ssid.Ssid, sme->ssid_len);
+
+
+	if (sme->bssid)
+		RTW_INFO("bssid="MAC_FMT"\n", MAC_ARG(sme->bssid));
+
+
+	psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
+	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+	psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
+
+#ifdef CONFIG_WAPI_SUPPORT
+	padapter->wapiInfo.bWapiEnable = false;
+#endif
+
+	ret = rtw_cfg80211_set_wpa_version(psecuritypriv, sme->crypto.wpa_versions);
+	if (ret < 0)
+		goto cancel_ps_deny;
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (sme->crypto.wpa_versions & NL80211_WAPI_VERSION_1) {
+		padapter->wapiInfo.bWapiEnable = true;
+		padapter->wapiInfo.extra_prefix_len = WAPI_EXT_LEN;
+		padapter->wapiInfo.extra_postfix_len = SMS4_MIC_LEN;
+	}
+#endif
+
+	ret = rtw_cfg80211_set_auth_type(psecuritypriv, sme->auth_type);
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_WAPI)
+		padapter->mlmeextpriv.mlmext_info.auth_algo = psecuritypriv->dot11AuthAlgrthm;
+#endif
+
+
+	if (ret < 0)
+		goto cancel_ps_deny;
+
+	RTW_INFO("%s, ie_len=%zu\n", __func__, sme->ie_len);
+
+	ret = rtw_cfg80211_set_wpa_ie(padapter, (u8 *)sme->ie, sme->ie_len);
+	if (ret < 0)
+		goto cancel_ps_deny;
+
+	if (sme->crypto.n_ciphers_pairwise) {
+		ret = rtw_cfg80211_set_cipher(psecuritypriv, sme->crypto.ciphers_pairwise[0], _TRUE);
+		if (ret < 0)
+			goto cancel_ps_deny;
+	}
+
+	/* For WEP Shared auth */
+	if (sme->key_len > 0 && sme->key) {
+		u32 wep_key_idx, wep_key_len, wep_total_len;
+		NDIS_802_11_WEP	*pwep = NULL;
+		RTW_INFO("%s(): Shared/Auto WEP\n", __FUNCTION__);
+
+		wep_key_idx = sme->key_idx;
+		wep_key_len = sme->key_len;
+
+		if (sme->key_idx > WEP_KEYS) {
+			ret = -EINVAL;
+			goto cancel_ps_deny;
+		}
+
+		if (wep_key_len > 0) {
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+			wep_total_len = wep_key_len + FIELD_OFFSET(NDIS_802_11_WEP, KeyMaterial);
+			pwep = (NDIS_802_11_WEP *) rtw_malloc(wep_total_len);
+			if (pwep == NULL) {
+				RTW_INFO(" wpa_set_encryption: pwep allocate fail !!!\n");
+				ret = -ENOMEM;
+				goto cancel_ps_deny;
+			}
+
+			_rtw_memset(pwep, 0, wep_total_len);
+
+			pwep->KeyLength = wep_key_len;
+			pwep->Length = wep_total_len;
+
+			if (wep_key_len == 13) {
+				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+				padapter->securitypriv.dot118021XGrpPrivacy = _WEP104_;
+			}
+		} else {
+			ret = -EINVAL;
+			goto cancel_ps_deny;
+		}
+
+		pwep->KeyIndex = wep_key_idx;
+		pwep->KeyIndex |= 0x80000000;
+
+		_rtw_memcpy(pwep->KeyMaterial, (void *)sme->key, pwep->KeyLength);
+
+		if (rtw_set_802_11_add_wep(padapter, pwep) == (u8)_FAIL)
+			ret = -EOPNOTSUPP ;
+
+		if (pwep)
+			rtw_mfree((u8 *)pwep, wep_total_len);
+
+		if (ret < 0)
+			goto cancel_ps_deny;
+	}
+
+	ret = rtw_cfg80211_set_cipher(psecuritypriv, sme->crypto.cipher_group, _FALSE);
+	if (ret < 0)
+		return ret;
+
+	if (sme->crypto.n_akm_suites) {
+		ret = rtw_cfg80211_set_key_mgt(psecuritypriv, sme->crypto.akm_suites[0]);
+		if (ret < 0)
+			goto cancel_ps_deny;
+	}
+#ifdef CONFIG_8011R
+	else {
+		/*It could be a connection without RSN IEs*/
+		psecuritypriv->rsn_akm_suite_type = 0;
+	}
+#endif
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (sme->crypto.akm_suites[0] == WLAN_AKM_SUITE_WAPI_PSK)
+		padapter->wapiInfo.bWapiPSK = true;
+	else if (sme->crypto.akm_suites[0] == WLAN_AKM_SUITE_WAPI_CERT)
+		padapter->wapiInfo.bWapiPSK = false;
+#endif
+
+	authmode = psecuritypriv->ndisauthtype;
+	rtw_set_802_11_authentication_mode(padapter, authmode);
+
+	/* rtw_set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus); */
+
+	if (rtw_set_802_11_connect(padapter, (u8 *)sme->bssid, &ndis_ssid) == _FALSE) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	if (pwdev_priv->connect_req) {
+		rtw_wdev_free_connect_req(pwdev_priv);
+		RTW_INFO(FUNC_NDEV_FMT" free existing connect_req\n", FUNC_NDEV_ARG(ndev));
+	}
+
+	pwdev_priv->connect_req = (struct cfg80211_connect_params *)rtw_malloc(sizeof(*pwdev_priv->connect_req));
+	if (pwdev_priv->connect_req)
+		_rtw_memcpy(pwdev_priv->connect_req, sme, sizeof(*pwdev_priv->connect_req));
+	else
+		RTW_WARN(FUNC_NDEV_FMT" alloc connect_req fail\n", FUNC_NDEV_ARG(ndev));
+
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	RTW_INFO("set ssid:dot11AuthAlgrthm=%d, dot11PrivacyAlgrthm=%d, dot118021XGrpPrivacy=%d\n", psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm,
+		psecuritypriv->dot118021XGrpPrivacy);
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
+
+exit:
+	RTW_INFO("<=%s, ret %d\n", __FUNCTION__, ret);
+
+	rtw_wdev_set_not_indic_disco(pwdev_priv, 0);
+
+	return ret;
+}
+
+static int cfg80211_rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev,
+				   u16 reason_code)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+
+	RTW_INFO(FUNC_NDEV_FMT" - Start to Disconnect\n", FUNC_NDEV_ARG(ndev));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (!wiphy->dev.power.is_prepared)
+#endif
+		rtw_wdev_set_not_indic_disco(pwdev_priv, 1);
+
+	rtw_set_to_roam(padapter, 0);
+
+	/* if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)) */
+	{
+		rtw_scan_abort(padapter);
+		rtw_join_abort_timeout(padapter, 300);
+		LeaveAllPowerSaveMode(padapter);
+		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
+#ifdef CONFIG_RTW_REPEATER_SON
+		rtw_rson_do_disconnect(padapter);
+#endif
+		RTW_INFO("%s...call rtw_indicate_disconnect\n", __func__);
+
+		rtw_free_assoc_resources(padapter, 1);
+		rtw_indicate_disconnect(padapter, 0, wiphy->dev.power.is_prepared ? _FALSE : _TRUE);
+
+		rtw_pwr_wakeup(padapter);
+	}
+
+	rtw_wdev_set_not_indic_disco(pwdev_priv, 0);
+
+	RTW_INFO(FUNC_NDEV_FMT" return 0\n", FUNC_NDEV_ARG(ndev));
+	return 0;
+}
+
+static int cfg80211_rtw_set_txpower(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct wireless_dev *wdev,
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)) || defined(COMPAT_KERNEL_RELEASE)
+	enum nl80211_tx_power_setting type, int mbm)
+#else
+	enum tx_power_setting type, int dbm)
+#endif
+{
+#if 0
+	struct iwm_priv *iwm = wiphy_to_iwm(wiphy);
+	int ret;
+
+	switch (type) {
+	case NL80211_TX_POWER_AUTOMATIC:
+		return 0;
+	case NL80211_TX_POWER_FIXED:
+		if (mbm < 0 || (mbm % 100))
+			return -EOPNOTSUPP;
+
+		if (!test_bit(IWM_STATUS_READY, &iwm->status))
+			return 0;
+
+		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_CFG_FIX,
+					      CFG_TX_PWR_LIMIT_USR,
+					      MBM_TO_DBM(mbm) * 2);
+		if (ret < 0)
+			return ret;
+
+		return iwm_tx_power_trigger(iwm);
+	default:
+		IWM_ERR(iwm, "Unsupported power type: %d\n", type);
+		return -EOPNOTSUPP;
+	}
+#endif
+	RTW_INFO("%s\n", __func__);
+	return 0;
+}
+
+static int cfg80211_rtw_get_txpower(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct wireless_dev *wdev,
+#endif
+	int *dbm)
+{
+	RTW_INFO("%s\n", __func__);
+
+	*dbm = (12);
+
+	return 0;
+}
+
+inline bool rtw_cfg80211_pwr_mgmt(_adapter *adapter)
+{
+	struct rtw_wdev_priv *rtw_wdev_priv = adapter_wdev_data(adapter);
+	return rtw_wdev_priv->power_mgmt;
+}
+
+static int cfg80211_rtw_set_power_mgmt(struct wiphy *wiphy,
+				       struct net_device *ndev,
+				       bool enabled, int timeout)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct rtw_wdev_priv *rtw_wdev_priv = adapter_wdev_data(padapter);
+
+	RTW_INFO(FUNC_NDEV_FMT" enabled:%u, timeout:%d\n", FUNC_NDEV_ARG(ndev),
+		enabled, timeout);
+
+	rtw_wdev_priv->power_mgmt = enabled;
+
+#ifdef CONFIG_LPS
+	if (!enabled)
+		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE_CFG80211_PWRMGMT, 1);
+#endif
+
+	return 0;
+}
+
+static int cfg80211_rtw_set_pmksa(struct wiphy *wiphy,
+				  struct net_device *ndev,
+				  struct cfg80211_pmksa *pmksa)
+{
+	u8	index, blInserted = _FALSE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *mlme = &padapter->mlmepriv;
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+	u8	strZeroMacAddress[ETH_ALEN] = { 0x00 };
+
+	RTW_INFO(FUNC_NDEV_FMT" "MAC_FMT" "KEY_FMT"\n", FUNC_NDEV_ARG(ndev)
+		, MAC_ARG(pmksa->bssid), KEY_ARG(pmksa->pmkid));
+
+	if (_rtw_memcmp((u8 *)pmksa->bssid, strZeroMacAddress, ETH_ALEN) == _TRUE)
+		return -EINVAL;
+
+	if (check_fwstate(mlme, _FW_LINKED) == _FALSE) {
+		RTW_INFO(FUNC_NDEV_FMT" not set pmksa cause not in linked state\n", FUNC_NDEV_ARG(ndev));
+		return -EINVAL;
+	}
+
+	blInserted = _FALSE;
+
+	/* overwrite PMKID */
+	for (index = 0 ; index < NUM_PMKID_CACHE; index++) {
+		if (_rtw_memcmp(psecuritypriv->PMKIDList[index].Bssid, (u8 *)pmksa->bssid, ETH_ALEN) == _TRUE) {
+			/* BSSID is matched, the same AP => rewrite with new PMKID. */
+			RTW_INFO(FUNC_NDEV_FMT" BSSID exists in the PMKList.\n", FUNC_NDEV_ARG(ndev));
+
+			_rtw_memcpy(psecuritypriv->PMKIDList[index].PMKID, (u8 *)pmksa->pmkid, WLAN_PMKID_LEN);
+			psecuritypriv->PMKIDList[index].bUsed = _TRUE;
+			psecuritypriv->PMKIDIndex = index + 1;
+			blInserted = _TRUE;
+			break;
+		}
+	}
+
+	if (!blInserted) {
+		/* Find a new entry */
+		RTW_INFO(FUNC_NDEV_FMT" Use the new entry index = %d for this PMKID.\n",
+			FUNC_NDEV_ARG(ndev), psecuritypriv->PMKIDIndex);
+
+		_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].Bssid, (u8 *)pmksa->bssid, ETH_ALEN);
+		_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].PMKID, (u8 *)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 *ndev,
+				  struct cfg80211_pmksa *pmksa)
+{
+	u8	index, bMatched = _FALSE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+
+	RTW_INFO(FUNC_NDEV_FMT" "MAC_FMT" "KEY_FMT"\n", FUNC_NDEV_ARG(ndev)
+		, MAC_ARG(pmksa->bssid), KEY_ARG(pmksa->pmkid));
+
+	for (index = 0 ; index < NUM_PMKID_CACHE; index++) {
+		if (_rtw_memcmp(psecuritypriv->PMKIDList[index].Bssid, (u8 *)pmksa->bssid, ETH_ALEN) == _TRUE) {
+			/* BSSID is matched, the same AP => Remove this PMKID information and reset it. */
+			_rtw_memset(psecuritypriv->PMKIDList[index].Bssid, 0x00, ETH_ALEN);
+			_rtw_memset(psecuritypriv->PMKIDList[index].PMKID, 0x00, WLAN_PMKID_LEN);
+			psecuritypriv->PMKIDList[index].bUsed = _FALSE;
+			bMatched = _TRUE;
+			RTW_INFO(FUNC_NDEV_FMT" clear id:%hhu\n", FUNC_NDEV_ARG(ndev), index);
+			break;
+		}
+	}
+
+	if (_FALSE == bMatched) {
+		RTW_INFO(FUNC_NDEV_FMT" do not have matched BSSID\n"
+			, FUNC_NDEV_ARG(ndev));
+		return -EINVAL;
+	}
+
+	return 0;
+}
+
+static int cfg80211_rtw_flush_pmksa(struct wiphy *wiphy,
+				    struct net_device *ndev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	_rtw_memset(&psecuritypriv->PMKIDList[0], 0x00, sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
+	psecuritypriv->PMKIDIndex = 0;
+
+	return 0;
+}
+
+#ifdef CONFIG_AP_MODE
+void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len)
+{
+	s32 freq;
+	int channel;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct net_device *ndev = padapter->pnetdev;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#if defined(RTW_USE_CFG80211_STA_EVENT) || defined(COMPAT_KERNEL_RELEASE)
+	{
+		struct station_info sinfo;
+		u8 ie_offset;
+		if (get_frame_sub_type(pmgmt_frame) == WIFI_ASSOCREQ)
+			ie_offset = _ASOCREQ_IE_OFFSET_;
+		else /* WIFI_REASSOCREQ */
+			ie_offset = _REASOCREQ_IE_OFFSET_;
+
+		memset(&sinfo, 0, sizeof(sinfo));
+		sinfo.filled = STATION_INFO_ASSOC_REQ_IES;
+		sinfo.assoc_req_ies = pmgmt_frame + WLAN_HDR_A3_LEN + ie_offset;
+		sinfo.assoc_req_ies_len = frame_len - WLAN_HDR_A3_LEN - ie_offset;
+		cfg80211_new_sta(ndev, get_addr2_ptr(pmgmt_frame), &sinfo, GFP_ATOMIC);
+	}
+#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
+	channel = pmlmeext->cur_channel;
+	freq = rtw_ch2freq(channel);
+
+	#ifdef COMPAT_KERNEL_RELEASE
+	rtw_cfg80211_rx_mgmt(pwdev, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
+	#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
+	rtw_cfg80211_rx_mgmt(pwdev, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
+	#else /* COMPAT_KERNEL_RELEASE */
+	{
+		/* to avoid WARN_ON(wdev->iftype != NL80211_IFTYPE_STATION)  when calling cfg80211_send_rx_assoc() */
+		#ifndef CONFIG_PLATFORM_MSTAR
+		pwdev->iftype = NL80211_IFTYPE_STATION;
+		#endif /* CONFIG_PLATFORM_MSTAR */
+		RTW_INFO("iftype=%d before call cfg80211_send_rx_assoc()\n", pwdev->iftype);
+		rtw_cfg80211_send_rx_assoc(padapter, NULL, pmgmt_frame, frame_len);
+		RTW_INFO("iftype=%d after call cfg80211_send_rx_assoc()\n", pwdev->iftype);
+		pwdev->iftype = NL80211_IFTYPE_AP;
+		/* cfg80211_rx_action(padapter->pnetdev, freq, pmgmt_frame, frame_len, GFP_ATOMIC); */
+	}
+	#endif /* COMPAT_KERNEL_RELEASE */
+#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
+
+}
+
+void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, const u8 *da, unsigned short reason)
+{
+	s32 freq;
+	int channel;
+	u8 *pmgmt_frame;
+	uint frame_len;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	unsigned short *fctrl;
+	u8 mgmt_buf[128] = {0};
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct wireless_dev *wdev = padapter->rtw_wdev;
+	struct net_device *ndev = padapter->pnetdev;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#if defined(RTW_USE_CFG80211_STA_EVENT) || defined(COMPAT_KERNEL_RELEASE)
+	cfg80211_del_sta(ndev, da, GFP_ATOMIC);
+#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
+	channel = pmlmeext->cur_channel;
+	freq = rtw_ch2freq(channel);
+
+	pmgmt_frame = mgmt_buf;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pmgmt_frame;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, da, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pmgmt_frame, WIFI_DEAUTH);
+
+	pmgmt_frame += sizeof(struct rtw_ieee80211_hdr_3addr);
+	frame_len = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	reason = cpu_to_le16(reason);
+	pmgmt_frame = rtw_set_fixed_ie(pmgmt_frame, _RSON_CODE_ , (unsigned char *)&reason, &frame_len);
+
+	#ifdef COMPAT_KERNEL_RELEASE
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, mgmt_buf, frame_len, GFP_ATOMIC);
+	#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, mgmt_buf, frame_len, GFP_ATOMIC);
+	#else /* COMPAT_KERNEL_RELEASE */
+	cfg80211_send_disassoc(padapter->pnetdev, mgmt_buf, frame_len);
+	/* cfg80211_rx_action(padapter->pnetdev, freq, mgmt_buf, frame_len, GFP_ATOMIC); */
+	#endif /* COMPAT_KERNEL_RELEASE */
+#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
+}
+
+static int rtw_cfg80211_monitor_if_open(struct net_device *ndev)
+{
+	int ret = 0;
+
+	RTW_INFO("%s\n", __func__);
+
+	return ret;
+}
+
+static int rtw_cfg80211_monitor_if_close(struct net_device *ndev)
+{
+	int ret = 0;
+
+	RTW_INFO("%s\n", __func__);
+
+	return ret;
+}
+
+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;
+	u16 frame_ctl;
+	unsigned char src_mac_addr[6];
+	unsigned char dst_mac_addr[6];
+	struct rtw_ieee80211_hdr *dot11_hdr;
+	struct ieee80211_radiotap_header *rtap_hdr;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	if (skb)
+		rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
+
+	if (IS_CH_WAITING(rfctl)) {
+		#ifdef CONFIG_DFS_MASTER
+		if (rtw_rfctl_overlap_radar_detect_ch(rfctl))
+			goto fail;
+		#endif
+	}
+
+	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) {
+		RTW_INFO("radiotap len (should be 14): %d\n", rtap_len);
+		goto fail;
+	}
+
+	/* Skip the ratio tap header */
+	skb_pull(skb, rtap_len);
+
+	dot11_hdr = (struct rtw_ieee80211_hdr *)skb->data;
+	frame_ctl = le16_to_cpu(dot11_hdr->frame_ctl);
+	/* Check if the QoS bit is set */
+	if ((frame_ctl & RTW_IEEE80211_FCTL_FTYPE) == RTW_IEEE80211_FTYPE_DATA) {
+		/* Check if this ia a Wireless Distribution System (WDS) frame
+		 * which has 4 MAC addresses
+		 */
+		if (dot11_hdr->frame_ctl & 0x0080)
+			qos_len = 2;
+		if ((dot11_hdr->frame_ctl & 0x0300) == 0x0300)
+			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
+		 * for two MAC addresses
+		 */
+		skb_pull(skb, dot11_hdr_len + qos_len + snap_len - sizeof(src_mac_addr) * 2);
+		pdata = (unsigned char *)skb->data;
+		memcpy(pdata, dst_mac_addr, sizeof(dst_mac_addr));
+		memcpy(pdata + sizeof(dst_mac_addr), src_mac_addr, sizeof(src_mac_addr));
+
+		RTW_INFO("should be eapol packet\n");
+
+		/* Use the real net device to transmit the packet */
+		ret = _rtw_xmit_entry(skb, padapter->pnetdev);
+
+		return ret;
+
+	} else if ((frame_ctl & (RTW_IEEE80211_FCTL_FTYPE | RTW_IEEE80211_FCTL_STYPE))
+		== (RTW_IEEE80211_FTYPE_MGMT | RTW_IEEE80211_STYPE_ACTION)
+	) {
+		/* 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 rtw_ieee80211_hdr *pwlanhdr;
+		struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+		struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+		u8 *buf = skb->data;
+		u32 len = skb->len;
+		u8 category, action;
+		int type = -1;
+
+		if (rtw_action_frame_parse(buf, len, &category, &action) == _FALSE) {
+			RTW_INFO(FUNC_NDEV_FMT" frame_control:0x%x\n", FUNC_NDEV_ARG(ndev),
+				le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl));
+			goto fail;
+		}
+
+		RTW_INFO("RTW_Tx:da="MAC_FMT" via "FUNC_NDEV_FMT"\n",
+			MAC_ARG(GetAddr1Ptr(buf)), FUNC_NDEV_ARG(ndev));
+		#ifdef CONFIG_P2P
+		type = rtw_p2p_check_frames(padapter, buf, len, _TRUE);
+		if (type >= 0)
+			goto dump;
+		#endif
+		if (category == RTW_WLAN_CATEGORY_PUBLIC)
+			RTW_INFO("RTW_Tx:%s\n", action_public_str(action));
+		else
+			RTW_INFO("RTW_Tx:category(%u), action(%u)\n", category, action);
+
+dump:
+		/* starting alloc mgmt frame to dump it */
+		pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+		if (pmgntframe == NULL)
+			goto fail;
+
+		/* update attribute */
+		pattrib = &pmgntframe->attrib;
+		update_mgntframe_attrib(padapter, pattrib);
+		pattrib->retry_ctrl = _FALSE;
+
+		_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+		pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+		_rtw_memcpy(pframe, (void *)buf, len);
+		pattrib->pktlen = len;
+
+#ifdef CONFIG_P2P
+		if (type >= 0)
+			rtw_xframe_chk_wfd_ie(pmgntframe);
+#endif /* CONFIG_P2P */
+
+		pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+		/* update seq number */
+		pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
+		pattrib->seqnum = pmlmeext->mgnt_seq;
+		pmlmeext->mgnt_seq++;
+
+
+		pattrib->last_txcmdsz = pattrib->pktlen;
+
+		dump_mgntframe(padapter, pmgntframe);
+
+	} else
+		RTW_INFO("frame_ctl=0x%x\n", frame_ctl & (RTW_IEEE80211_FCTL_FTYPE | RTW_IEEE80211_FCTL_STYPE));
+
+
+fail:
+
+	rtw_skb_free(skb);
+
+	return 0;
+
+}
+
+static void rtw_cfg80211_monitor_if_set_multicast_list(struct net_device *ndev)
+{
+	RTW_INFO("%s\n", __func__);
+}
+
+static int rtw_cfg80211_monitor_if_set_mac_address(struct net_device *ndev, void *addr)
+{
+	int ret = 0;
+
+	RTW_INFO("%s\n", __func__);
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+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,
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 2, 0))
+	.ndo_set_multicast_list = rtw_cfg80211_monitor_if_set_multicast_list,
+	#endif
+	.ndo_set_mac_address = rtw_cfg80211_monitor_if_set_mac_address,
+};
+#endif
+
+static int rtw_cfg80211_add_monitor_if(_adapter *padapter, char *name, struct net_device **ndev)
+{
+	int ret = 0;
+	struct net_device *mon_ndev = NULL;
+	struct wireless_dev *mon_wdev = NULL;
+	struct rtw_netdev_priv_indicator *pnpi;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+
+	if (!name) {
+		RTW_INFO(FUNC_ADPT_FMT" without specific name\n", FUNC_ADPT_ARG(padapter));
+		ret = -EINVAL;
+		goto out;
+	}
+
+	if (pwdev_priv->pmon_ndev) {
+		RTW_INFO(FUNC_ADPT_FMT" monitor interface exist: "NDEV_FMT"\n",
+			FUNC_ADPT_ARG(padapter), NDEV_ARG(pwdev_priv->pmon_ndev));
+		ret = -EBUSY;
+		goto out;
+	}
+
+	mon_ndev = alloc_etherdev(sizeof(struct rtw_netdev_priv_indicator));
+	if (!mon_ndev) {
+		RTW_INFO(FUNC_ADPT_FMT" allocate ndev fail\n", FUNC_ADPT_ARG(padapter));
+		ret = -ENOMEM;
+		goto out;
+	}
+
+	mon_ndev->type = ARPHRD_IEEE80211_RADIOTAP;
+	strncpy(mon_ndev->name, name, IFNAMSIZ);
+	mon_ndev->name[IFNAMSIZ - 1] = 0;
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(4, 11, 8))
+	mon_ndev->priv_destructor = rtw_ndev_destructor;
+#else
+	mon_ndev->destructor = rtw_ndev_destructor;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+	mon_ndev->netdev_ops = &rtw_cfg80211_monitor_if_ops;
+#else
+	mon_ndev->open = rtw_cfg80211_monitor_if_open;
+	mon_ndev->stop = rtw_cfg80211_monitor_if_close;
+	mon_ndev->hard_start_xmit = rtw_cfg80211_monitor_if_xmit_entry;
+	mon_ndev->set_mac_address = rtw_cfg80211_monitor_if_set_mac_address;
+#endif
+
+	pnpi = netdev_priv(mon_ndev);
+	pnpi->priv = padapter;
+	pnpi->sizeof_priv = sizeof(_adapter);
+
+	/*  wdev */
+	mon_wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
+	if (!mon_wdev) {
+		RTW_INFO(FUNC_ADPT_FMT" allocate mon_wdev fail\n", FUNC_ADPT_ARG(padapter));
+		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;
+	_rtw_memcpy(pwdev_priv->ifname_mon, name, IFNAMSIZ + 1);
+
+out:
+	if (ret && mon_wdev) {
+		rtw_mfree((u8 *)mon_wdev, sizeof(struct wireless_dev));
+		mon_wdev = NULL;
+	}
+
+	if (ret && mon_ndev) {
+		free_netdev(mon_ndev);
+		*ndev = mon_ndev = NULL;
+	}
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+static struct wireless_dev *
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+static struct net_device *
+#else
+static int
+#endif
+	cfg80211_rtw_add_virtual_intf(
+		struct wiphy *wiphy,
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 7, 0))
+		const char *name,
+		#else
+		char *name,
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+		unsigned char name_assign_type,
+		#endif
+		enum nl80211_iftype type,
+		#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+		u32 *flags,
+		#endif
+		struct vif_params *params)
+{
+	int ret = 0;
+	struct wireless_dev *wdev = NULL;
+	struct net_device *ndev = NULL;
+	_adapter *padapter;
+	struct dvobj_priv *dvobj = wiphy_to_dvobj(wiphy);
+
+	rtw_set_rtnl_lock_holder(dvobj, current);
+
+	RTW_INFO(FUNC_WIPHY_FMT" name:%s, type:%d\n", FUNC_WIPHY_ARG(wiphy), name, type);
+
+	switch (type) {
+	case NL80211_IFTYPE_MONITOR:
+		padapter = wiphy_to_adapter(wiphy); /* TODO: get ap iface ? */
+		ret = rtw_cfg80211_add_monitor_if(padapter, (char *)name, &ndev);
+		if (ret == 0)
+			wdev = ndev->ieee80211_ptr;
+		break;
+
+#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	case NL80211_IFTYPE_P2P_GO:
+#endif
+	case NL80211_IFTYPE_STATION:
+	case NL80211_IFTYPE_AP:
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+#endif
+		padapter = dvobj_get_unregisterd_adapter(dvobj);
+		if (!padapter) {
+			RTW_WARN("adapter pool empty!\n");
+			ret = -ENODEV;
+			break;
+		}
+		if (rtw_os_ndev_init(padapter, name) != _SUCCESS) {
+			RTW_WARN("ndev init fail!\n");
+			ret = -ENODEV;
+			break;
+		}
+		#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+		if (type == NL80211_IFTYPE_P2P_CLIENT || type == NL80211_IFTYPE_P2P_GO)
+			rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
+		#endif
+		ndev = padapter->pnetdev;
+		wdev = ndev->ieee80211_ptr;
+		break;
+
+#if defined(CONFIG_P2P) && defined(RTW_DEDICATED_P2P_DEVICE)
+	case NL80211_IFTYPE_P2P_DEVICE:
+		ret = rtw_pd_iface_alloc(wiphy, name, &wdev);
+		break;
+#endif
+
+	case NL80211_IFTYPE_ADHOC:
+	case NL80211_IFTYPE_AP_VLAN:
+	case NL80211_IFTYPE_WDS:
+	default:
+		ret = -ENODEV;
+		RTW_INFO("Unsupported interface type\n");
+		break;
+	}
+
+	if (ndev)
+		RTW_INFO(FUNC_WIPHY_FMT" ndev:%p, ret:%d\n", FUNC_WIPHY_ARG(wiphy), ndev, ret);
+	else
+		RTW_INFO(FUNC_WIPHY_FMT" wdev:%p, ret:%d\n", FUNC_WIPHY_ARG(wiphy), wdev, ret);
+
+	rtw_set_rtnl_lock_holder(dvobj, NULL);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	return wdev ? wdev : ERR_PTR(ret);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	return ndev ? ndev : ERR_PTR(ret);
+#else
+	return ret;
+#endif
+}
+
+static int cfg80211_rtw_del_virtual_intf(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev
+#else
+	struct net_device *ndev
+#endif
+)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct net_device *ndev = wdev_to_ndev(wdev);
+#endif
+	int ret = 0;
+	struct dvobj_priv *dvobj = wiphy_to_dvobj(wiphy);
+	_adapter *adapter;
+	struct rtw_wdev_priv *pwdev_priv;
+
+	rtw_set_rtnl_lock_holder(dvobj, current);
+
+	if (ndev) {
+		adapter = (_adapter *)rtw_netdev_priv(ndev);
+		pwdev_priv = adapter_wdev_data(adapter);
+
+		if (ndev == pwdev_priv->pmon_ndev) {
+			unregister_netdevice(ndev);
+			pwdev_priv->pmon_ndev = NULL;
+			pwdev_priv->ifname_mon[0] = '\0';
+			RTW_INFO(FUNC_NDEV_FMT" remove monitor ndev\n", FUNC_NDEV_ARG(ndev));
+		} else {
+			RTW_INFO(FUNC_NDEV_FMT" unregister ndev\n", FUNC_NDEV_ARG(ndev));
+			rtw_os_ndev_unregister(adapter);
+		}
+	} else
+#if defined(CONFIG_P2P) && defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev->iftype == NL80211_IFTYPE_P2P_DEVICE) {
+		if (wdev == wiphy_to_pd_wdev(wiphy))
+			rtw_pd_iface_free(wiphy);
+		else {
+			RTW_ERR(FUNC_WIPHY_FMT" unknown P2P Device wdev:%p\n", FUNC_WIPHY_ARG(wiphy), wdev);
+			rtw_warn_on(1);
+		}
+	} else
+#endif
+	{
+		ret = -EINVAL;
+		goto exit;
+	}
+
+exit:
+	rtw_set_rtnl_lock_holder(dvobj, NULL);
+	return ret;
+}
+
+static int rtw_add_beacon(_adapter *adapter, const u8 *head, size_t head_len, const u8 *tail, size_t tail_len)
+{
+	int ret = 0;
+	u8 *pbuf = NULL;
+	uint len, wps_ielen = 0;
+	uint p2p_ielen = 0;
+	u8 *p2p_ie;
+	u8 got_p2p_ie = _FALSE;
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	/* struct sta_priv *pstapriv = &padapter->stapriv; */
+
+
+	RTW_INFO("%s beacon_head_len=%zu, beacon_tail_len=%zu\n", __FUNCTION__, head_len, tail_len);
+
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	if (head_len < 24)
+		return -EINVAL;
+
+
+	pbuf = rtw_zmalloc(head_len + tail_len);
+	if (!pbuf)
+		return -ENOMEM;
+
+
+	/* _rtw_memcpy(&pstapriv->max_num_sta, param->u.bcn_ie.reserved, 2); */
+
+	/* if((pstapriv->max_num_sta>NUM_STA) || (pstapriv->max_num_sta<=0)) */
+	/*	pstapriv->max_num_sta = NUM_STA; */
+
+
+	_rtw_memcpy(pbuf, (void *)head + 24, head_len - 24); /* 24=beacon header len. */
+	_rtw_memcpy(pbuf + head_len - 24, (void *)tail, tail_len);
+
+	len = head_len + tail_len - 24;
+
+	/* check wps ie if inclued */
+	if (rtw_get_wps_ie(pbuf + _FIXED_IE_LENGTH_, len - _FIXED_IE_LENGTH_, NULL, &wps_ielen))
+		RTW_INFO("add bcn, wps_ielen=%d\n", wps_ielen);
+
+#ifdef CONFIG_P2P
+	if (adapter->wdinfo.driver_interface == DRIVER_CFG80211) {
+		/* check p2p if enable */
+		if (rtw_get_p2p_ie(pbuf + _FIXED_IE_LENGTH_, len - _FIXED_IE_LENGTH_, NULL, &p2p_ielen)) {
+			struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+			struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
+
+			RTW_INFO("got p2p_ie, len=%d\n", p2p_ielen);
+
+			got_p2p_ie = _TRUE;
+
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+				RTW_INFO("Enable P2P function for the first time\n");
+				rtw_p2p_enable(adapter, P2P_ROLE_GO);
+
+				adapter->stapriv.expire_to = 3; /* 3x2 = 6 sec in p2p mode */
+			} else {
+				RTW_INFO("enter GO Mode, p2p_ielen=%d\n", p2p_ielen);
+
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
+				rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
+				pwdinfo->intent = 15;
+			}
+		}
+	}
+#endif /* CONFIG_P2P */
+
+	/* pbss_network->IEs will not include p2p_ie, wfd ie */
+	rtw_ies_remove_ie(pbuf, &len, _BEACON_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, P2P_OUI, 4);
+	rtw_ies_remove_ie(pbuf, &len, _BEACON_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, WFD_OUI, 4);
+
+	if (rtw_check_beacon_data(adapter, pbuf,  len) == _SUCCESS) {
+#ifdef CONFIG_P2P
+		/* check p2p if enable */
+		if (got_p2p_ie == _TRUE) {
+			struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+			struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
+			pwdinfo->operating_channel = pmlmeext->cur_channel;
+		}
+#endif /* CONFIG_P2P */
+		ret = 0;
+	} else
+		ret = -EINVAL;
+
+
+	rtw_mfree(pbuf, head_len + tail_len);
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) && !defined(COMPAT_KERNEL_RELEASE)
+static int cfg80211_rtw_add_beacon(struct wiphy *wiphy, struct net_device *ndev,
+		struct beacon_parameters *info)
+{
+	int ret = 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+
+	ret = rtw_add_beacon(adapter, info->head, info->head_len, info->tail, info->tail_len);
+
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_set_beacon(struct wiphy *wiphy, struct net_device *ndev,
+		struct beacon_parameters *info)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	pmlmeext->bstart_bss = _TRUE;
+
+	cfg80211_rtw_add_beacon(wiphy, ndev, info);
+
+	return 0;
+}
+
+static int	cfg80211_rtw_del_beacon(struct wiphy *wiphy, struct net_device *ndev)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+#else
+static int cfg80211_rtw_start_ap(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_ap_settings *settings)
+{
+	int ret = 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT" hidden_ssid:%d, auth_type:%d\n", FUNC_NDEV_ARG(ndev),
+		settings->hidden_ssid, settings->auth_type);
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+
+	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) {
+		WLAN_BSSID_EX *pbss_network = &adapter->mlmepriv.cur_network.network;
+		WLAN_BSSID_EX *pbss_network_ext = &adapter->mlmeextpriv.mlmext_info.network;
+
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" ssid:(%s,%zu), from ie:(%s,%d)\n", FUNC_ADPT_ARG(adapter),
+				settings->ssid, settings->ssid_len,
+				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength);
+
+		_rtw_memcpy(pbss_network->Ssid.Ssid, (void *)settings->ssid, settings->ssid_len);
+		pbss_network->Ssid.SsidLength = settings->ssid_len;
+		_rtw_memcpy(pbss_network_ext->Ssid.Ssid, (void *)settings->ssid, settings->ssid_len);
+		pbss_network_ext->Ssid.SsidLength = settings->ssid_len;
+
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" after ssid:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
+				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength,
+				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
+	}
+
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_change_beacon(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_beacon_data *info)
+{
+	int ret = 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	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)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) */
+
+#if CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+static int cfg80211_rtw_set_mac_acl(struct wiphy *wiphy, struct net_device *ndev,
+		const struct cfg80211_acl_data *params)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	u8 acl_mode = RTW_ACL_MODE_DISABLED;
+	int ret = -1;
+	int i;
+
+	if (!params) {
+		RTW_WARN(FUNC_ADPT_FMT" params NULL\n", FUNC_ADPT_ARG(adapter));
+		rtw_macaddr_acl_clear(adapter, RTW_ACL_PERIOD_BSS);
+		goto exit;
+	}
+
+	RTW_INFO(FUNC_ADPT_FMT" acl_policy:%d, entry_num:%d\n"
+		, FUNC_ADPT_ARG(adapter), params->acl_policy, params->n_acl_entries);
+
+	if (params->acl_policy == NL80211_ACL_POLICY_ACCEPT_UNLESS_LISTED)
+		acl_mode = RTW_ACL_MODE_ACCEPT_UNLESS_LISTED;
+	else if (params->acl_policy == NL80211_ACL_POLICY_DENY_UNLESS_LISTED)
+		acl_mode = RTW_ACL_MODE_DENY_UNLESS_LISTED;
+
+	rtw_macaddr_acl_clear(adapter, RTW_ACL_PERIOD_BSS);
+
+	rtw_set_macaddr_acl(adapter, RTW_ACL_PERIOD_BSS, acl_mode);
+
+	for (i = 0; i < params->n_acl_entries; i++)
+		rtw_acl_add_sta(adapter, RTW_ACL_PERIOD_BSS, params->mac_addrs[i].addr);
+
+	ret = 0;
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)) */
+
+const char *_nl80211_sta_flags_str[] = {
+	"INVALID",
+	"AUTHORIZED",
+	"SHORT_PREAMBLE",
+	"WME",
+	"MFP",
+	"AUTHENTICATED",
+	"TDLS_PEER",
+	"ASSOCIATED",
+};
+
+#define nl80211_sta_flags_str(_f) ((_f <= NL80211_STA_FLAG_MAX) ? _nl80211_sta_flags_str[_f] : _nl80211_sta_flags_str[0])
+
+const char *_nl80211_plink_state_str[] = {
+	"LISTEN",
+	"OPN_SNT",
+	"OPN_RCVD",
+	"CNF_RCVD",
+	"ESTAB",
+	"HOLDING",
+	"BLOCKED",
+	"UNKNOWN",
+};
+
+#define nl80211_plink_state_str(_s) ((_s < NUM_NL80211_PLINK_STATES) ? _nl80211_plink_state_str[_s] : _nl80211_plink_state_str[NUM_NL80211_PLINK_STATES])
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
+#define NL80211_PLINK_ACTION_NO_ACTION PLINK_ACTION_INVALID
+#define NL80211_PLINK_ACTION_OPEN PLINK_ACTION_OPEN
+#define NL80211_PLINK_ACTION_BLOCK PLINK_ACTION_BLOCK
+#define NUM_NL80211_PLINK_ACTIONS 3
+#endif
+
+const char *_nl80211_plink_actions_str[] = {
+	"NO_ACTION",
+	"OPEN",
+	"BLOCK",
+	"UNKNOWN",
+};
+
+#define nl80211_plink_actions_str(_a) ((_a < NUM_NL80211_PLINK_ACTIONS) ? _nl80211_plink_actions_str[_a] : _nl80211_plink_actions_str[NUM_NL80211_PLINK_ACTIONS])
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+const char *_nl80211_mesh_power_mode_str[] = {
+	"UNKNOWN",
+	"ACTIVE",
+	"LIGHT_SLEEP",
+	"DEEP_SLEEP",
+};
+
+#define nl80211_mesh_power_mode_str(_p) ((_p <= NL80211_MESH_POWER_MAX) ? _nl80211_mesh_power_mode_str[_p] : _nl80211_mesh_power_mode_str[0])
+#endif
+
+void dump_station_parameters(void *sel, struct wiphy *wiphy, const struct station_parameters *params)
+{
+#if DBG_RTW_CFG80211_STA_PARAM
+	if (params->supported_rates_len) {
+		#define SUPP_RATES_BUF_LEN (3 * RTW_G_RATES_NUM + 1)
+		int i;
+		char supp_rates_buf[SUPP_RATES_BUF_LEN] = {0};
+		u8 cnt = 0;
+
+		rtw_warn_on(params->supported_rates_len > RTW_G_RATES_NUM);
+
+		for (i = 0; i < params->supported_rates_len; i++) {
+			if (i >= RTW_G_RATES_NUM)
+				break;
+			cnt += snprintf(supp_rates_buf + cnt, SUPP_RATES_BUF_LEN - cnt -1
+				, "%02X ", params->supported_rates[i]);
+			if (cnt >= SUPP_RATES_BUF_LEN - 1)
+				break;
+		}
+
+		RTW_PRINT_SEL(sel, "supported_rates:%s\n", supp_rates_buf);
+	}
+
+	if (params->vlan)
+		RTW_PRINT_SEL(sel, "vlan:"NDEV_FMT"\n", NDEV_ARG(params->vlan));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 31))
+	if (params->sta_flags_mask) {
+		#define STA_FLAGS_BUF_LEN 128
+		int i = 0;
+		char sta_flags_buf[STA_FLAGS_BUF_LEN] = {0};
+		u8 cnt = 0;
+
+		for (i = 1; i <= NL80211_STA_FLAG_MAX; i++) {
+			if (params->sta_flags_mask & BIT(i)) {
+				cnt += snprintf(sta_flags_buf + cnt, STA_FLAGS_BUF_LEN - cnt -1, "%s=%u "
+					, nl80211_sta_flags_str(i), (params->sta_flags_set & BIT(i)) >> i);
+				if (cnt >= STA_FLAGS_BUF_LEN - 1)
+					break;
+			}
+		}
+
+		RTW_PRINT_SEL(sel, "sta_flags:%s\n", sta_flags_buf);
+	}
+#else
+	u32 station_flags;
+	#error "TBD\n"
+#endif
+
+	if (params->listen_interval != -1)
+		RTW_PRINT_SEL(sel, "listen_interval:%d\n", params->listen_interval);
+
+	if (params->aid)
+		RTW_PRINT_SEL(sel, "aid:%u\n", params->aid);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 8, 0))
+	if (params->peer_aid)
+		RTW_PRINT_SEL(sel, "peer_aid:%u\n", params->peer_aid);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26))
+	if (params->plink_action != NL80211_PLINK_ACTION_NO_ACTION)
+		RTW_PRINT_SEL(sel, "plink_action:%s\n", nl80211_plink_actions_str(params->plink_action));
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+	#endif
+		RTW_PRINT_SEL(sel, "plink_state:%s\n"
+			, nl80211_plink_state_str(params->plink_state));
+#endif
+
+#if 0 /* TODO */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 28))
+	const struct ieee80211_ht_cap *ht_capa;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	const struct ieee80211_vht_cap *vht_capa;
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_UAPSD)
+		RTW_PRINT_SEL(sel, "uapsd_queues:0x%02x\n", params->uapsd_queues);
+	if (params->max_sp)
+		RTW_PRINT_SEL(sel, "max_sp:%u\n", params->max_sp);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (params->local_pm != NL80211_MESH_POWER_UNKNOWN) {
+		RTW_PRINT_SEL(sel, "local_pm:%s\n"
+			, nl80211_mesh_power_mode_str(params->local_pm));
+	}
+
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_CAPABILITY)
+		RTW_PRINT_SEL(sel, "capability:0x%04x\n", params->capability);
+
+#if 0 /* TODO */
+	const u8 *ext_capab;
+	u8 ext_capab_len;
+#endif
+#endif
+
+#if 0 /* TODO */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0))
+	const u8 *supported_channels;
+	u8 supported_channels_len;
+	const u8 *supported_oper_classes;
+	u8 supported_oper_classes_len;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0))
+	u8 opmode_notif;
+	bool opmode_notif_used;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+	int support_p2p_ps;
+#endif
+#endif
+#endif /* DBG_RTW_CFG80211_STA_PARAM */
+}
+
+static int	cfg80211_rtw_add_station(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac,
+#else
+	const u8 *mac,
+#endif
+	struct station_parameters *params)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+#ifdef CONFIG_TDLS
+	struct sta_info *psta;
+#endif /* CONFIG_TDLS */
+
+	RTW_INFO(FUNC_NDEV_FMT" mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+
+#if CONFIG_RTW_MACADDR_ACL
+	if (rtw_access_ctrl(padapter, mac) == _FALSE) {
+		RTW_INFO(FUNC_NDEV_FMT" deny by macaddr ACL\n", FUNC_NDEV_ARG(ndev));
+		ret = -EINVAL;
+		goto exit;
+	}
+#endif
+
+	dump_station_parameters(RTW_DBGDUMP, wiphy, params);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		struct rtw_mesh_cfg *mcfg = &padapter->mesh_cfg;
+		struct rtw_mesh_info *minfo = &padapter->mesh_info;
+		struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+		struct mesh_plink_ent *plink = NULL;
+		struct wlan_network *scanned = NULL;
+		u8 add_new_sta = 0, probe_req = 0;
+		_irqL irqL;
+
+		if (params->plink_state != NL80211_PLINK_LISTEN) {
+			RTW_WARN(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(ndev), nl80211_plink_state_str(params->plink_state));
+			rtw_warn_on(1);
+		}
+		if (!params->aid || params->aid > pstapriv->max_aid) {
+			RTW_WARN(FUNC_NDEV_FMT" invalid aid:%u\n", FUNC_NDEV_ARG(ndev), params->aid);
+			rtw_warn_on(1);
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL);
+
+		plink = _rtw_mesh_plink_get(padapter, mac);
+		if (plink)
+			goto release_plink_ctl;
+
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		if (rtw_mesh_peer_blacklist_search(padapter, mac)) {
+			RTW_INFO(FUNC_NDEV_FMT" deny by peer blacklist\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+		#endif
+
+		/* wpa_supplicant's auto peer will initiate peering when candidate peer is reported without max_peer_links consideration */
+		if (plink_ctl->num >= mcfg->max_peer_links) {
+			RTW_INFO(FUNC_NDEV_FMT" exceed max_peer_links:%u\n"
+				, FUNC_NDEV_ARG(ndev), mcfg->max_peer_links);
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		scanned = rtw_find_network(&padapter->mlmepriv.scanned_queue, mac);
+		if (!scanned
+			|| rtw_get_passing_time_ms(scanned->last_scanned) >= mcfg->peer_sel_policy.scanr_exp_ms
+		) {
+			if (!scanned)
+				RTW_INFO(FUNC_NDEV_FMT" corresponding network not found\n", FUNC_NDEV_ARG(ndev));
+			else
+				RTW_INFO(FUNC_NDEV_FMT" corresponding network too old\n", FUNC_NDEV_ARG(ndev));
+
+			if (adapter_to_rfctl(padapter)->offch_state == OFFCHS_NONE)
+				probe_req = 1;
+
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		if (!rtw_bss_is_candidate_mesh_peer(&padapter->mlmepriv.cur_network.network, &scanned->network, 1, 1)){
+			RTW_WARN(FUNC_NDEV_FMT" corresponding network is not candidate with same ch\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		if (!rtw_mesh_cto_mgate_network_filter(padapter, scanned)) {
+			RTW_INFO(FUNC_NDEV_FMT" peer filtered out by cto_mgate check\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+		#endif
+
+		if (_rtw_mesh_plink_add(padapter, mac) == _SUCCESS) {
+			/* hook corresponding network in scan queue */
+			plink = _rtw_mesh_plink_get(padapter, mac);
+			plink->aid = params->aid;
+			plink->scanned = scanned;
+
+			add_new_sta = 1;
+		} else {
+			RTW_WARN(FUNC_NDEV_FMT" rtw_mesh_plink_add not success\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+		}
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+		if (probe_req)
+			issue_probereq(padapter, &padapter->mlmepriv.cur_network.network.mesh_id, mac);
+
+		if (add_new_sta) {
+			struct station_info sinfo;
+
+			#ifdef CONFIG_DFS_MASTER
+			if (IS_UNDER_CAC(adapter_to_rfctl(padapter)))
+				rtw_force_stop_cac(padapter, 300);
+			#endif
+
+			/* indicate new sta */
+			_rtw_memset(&sinfo, 0, sizeof(sinfo));
+			cfg80211_new_sta(ndev, mac, &sinfo, GFP_ATOMIC);
+		}
+		goto exit;
+	}
+#endif /* CONFIG_RTW_MESH */
+
+#ifdef CONFIG_TDLS
+	psta = rtw_get_stainfo(pstapriv, (u8 *)mac);
+	if (psta == NULL) {
+		psta = rtw_alloc_stainfo(pstapriv, (u8 *)mac);
+		if (psta == NULL) {
+			RTW_INFO("[%s] Alloc station for "MAC_FMT" fail\n", __FUNCTION__, MAC_ARG(mac));
+			ret = -EOPNOTSUPP;
+			goto exit;
+		}
+	}
+#endif /* CONFIG_TDLS */
+
+exit:
+	return ret;
+}
+
+static int	cfg80211_rtw_del_station(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 19, 0))
+	const u8 *mac
+#else
+	struct station_del_parameters *params
+#endif
+)
+{
+	int ret = 0;
+	_irqL irqL;
+	_list	*phead, *plist;
+	u8 updated = _FALSE;
+	const u8 *target_mac;
+	struct sta_info *psta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 19, 0))
+	target_mac = mac;
+#else
+	target_mac = params->mac;
+#endif
+
+	RTW_INFO("+"FUNC_NDEV_FMT" mac=%pM\n", FUNC_NDEV_ARG(ndev), target_mac);
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE)) != _TRUE) {
+		RTW_INFO("%s, fw_state != FW_LINKED|WIFI_AP_STATE|WIFI_MESH_STATE\n", __func__);
+		return -EINVAL;
+	}
+
+
+	if (!target_mac) {
+		RTW_INFO("flush all sta, and cam_entry\n");
+
+		flush_all_cam_entry(padapter);	/* clear CAM */
+
+#ifdef CONFIG_AP_MODE
+		ret = rtw_sta_flush(padapter, _TRUE);
+#endif
+		return ret;
+	}
+
+
+	RTW_INFO("free sta macaddr =" MAC_FMT "\n", MAC_ARG(target_mac));
+
+	if (target_mac[0] == 0xff && target_mac[1] == 0xff &&
+	    target_mac[2] == 0xff && target_mac[3] == 0xff &&
+	    target_mac[4] == 0xff && target_mac[5] == 0xff)
+		return -EINVAL;
+
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	/* check asoc_queue */
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+
+		plist = get_next(plist);
+
+		if (_rtw_memcmp((u8 *)target_mac, psta->cmn.mac_addr, ETH_ALEN)) {
+			if (psta->dot8021xalg == 1 && psta->bpairwise_key_installed == _FALSE)
+				RTW_INFO("%s, sta's dot8021xalg = 1 and key_installed = _FALSE\n", __func__);
+			else {
+				RTW_INFO("free psta=%p, aid=%d\n", psta, psta->cmn.aid);
+
+				rtw_list_delete(&psta->asoc_list);
+				pstapriv->asoc_list_cnt--;
+				STA_SET_MESH_PLINK(psta, NULL);
+
+				/* _exit_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
+				if (MLME_IS_AP(padapter))
+					updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
+				else
+					updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
+				/* _enter_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
+
+				psta = NULL;
+
+				break;
+			}
+
+		}
+
+	}
+
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_mesh_plink_del(padapter, target_mac);
+#endif
+
+	RTW_INFO("-"FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	return ret;
+
+}
+
+static int	cfg80211_rtw_change_station(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac,
+#else
+	const u8 *mac,
+#endif
+	struct station_parameters *params)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta = NULL;
+	_irqL irqL;
+	int ret = 0;
+
+	RTW_INFO(FUNC_NDEV_FMT" mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+
+	dump_station_parameters(RTW_DBGDUMP, wiphy, params);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		enum cfg80211_station_type sta_type = CFG80211_STA_MESH_PEER_USER;
+		struct rtw_mesh_info *minfo = &adapter->mesh_info;
+		struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+		struct mesh_plink_ent *plink = NULL;
+		_irqL irqL2;
+
+		ret = cfg80211_check_station_change(wiphy, params, sta_type);
+		if (ret) {
+			RTW_INFO("cfg80211_check_station_change return %d\n", ret);
+			goto exit;
+		}
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL2);
+
+		plink = _rtw_mesh_plink_get(adapter, mac);
+		if (!plink) {
+			ret = -ENOENT;
+			goto release_plink_ctl;
+		}
+
+		plink->plink_state = nl80211_plink_state_to_rtw_plink_state(params->plink_state);
+
+		if ((params->plink_state == NL80211_PLINK_OPN_RCVD
+				|| params->plink_state == NL80211_PLINK_CNF_RCVD
+				|| params->plink_state == NL80211_PLINK_ESTAB)
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+			&& (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+			#endif
+		) {
+			sta = rtw_get_stainfo(stapriv, mac);
+			if (!sta) {
+				sta = rtw_alloc_stainfo(stapriv, mac);
+				if (!sta)
+					goto release_plink_ctl;
+			}
+
+			if (params->plink_state == NL80211_PLINK_ESTAB) {
+				if (rtw_mesh_peer_establish(adapter, plink, sta) != _SUCCESS) {
+					rtw_free_stainfo(adapter, sta);
+					ret = -ENOENT;
+					goto release_plink_ctl;
+				}
+			}
+		}
+		else if (params->plink_state == NL80211_PLINK_HOLDING
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+			&& (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+			#endif
+		) {
+			u8 updated = _FALSE;
+
+			sta = rtw_get_stainfo(stapriv, mac);
+			if (!sta)
+				goto release_plink_ctl;
+
+			_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+			if (!rtw_is_list_empty(&sta->asoc_list)) {
+				rtw_list_delete(&sta->asoc_list);
+				stapriv->asoc_list_cnt--;
+				STA_SET_MESH_PLINK(sta, NULL);
+			}
+			_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+			updated = ap_free_sta(adapter, sta, 0, 0, 1);
+			associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
+		}
+
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL2);
+	}
+#endif /* CONFIG_RTW_MESH */
+
+exit:
+	return ret;
+}
+
+struct sta_info *rtw_sta_info_get_by_idx(struct sta_priv *pstapriv, const int idx, u8 *asoc_list_num)
+{
+	_list	*phead, *plist;
+	struct sta_info *psta = NULL;
+	int i = 0;
+
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	/* check asoc_queue */
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		if (idx == i)
+			psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+		i++;
+	}
+
+	if (asoc_list_num)
+		*asoc_list_num = i;
+
+	return psta;
+}
+
+static int	cfg80211_rtw_dump_station(struct wiphy *wiphy, struct net_device *ndev,
+		int idx, u8 *mac, struct station_info *sinfo)
+{
+#define DBG_DUMP_STATION 0
+
+	int ret = 0;
+	_irqL irqL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta = NULL;
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink = NULL;
+#endif
+	u8 asoc_list_num;
+
+	if (DBG_DUMP_STATION)
+		RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	psta = rtw_sta_info_get_by_idx(pstapriv, idx, &asoc_list_num);
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (!psta)
+			plink = rtw_mesh_plink_get_no_estab_by_idx(padapter, idx - asoc_list_num);
+		else
+			plink = psta->plink;
+	}
+#endif /* CONFIG_RTW_MESH */
+
+	if (!psta
+		#ifdef CONFIG_RTW_MESH
+		&& !plink
+		#endif
+	) {
+		if (DBG_DUMP_STATION)
+			RTW_INFO(FUNC_NDEV_FMT" end with idx:%d\n", FUNC_NDEV_ARG(ndev), idx);
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	if (psta)
+		_rtw_memcpy(mac, psta->cmn.mac_addr, ETH_ALEN);
+	#ifdef CONFIG_RTW_MESH
+	else
+		_rtw_memcpy(mac, plink->addr, ETH_ALEN);
+	#endif
+	
+	sinfo->filled = 0;
+
+	if (psta) {
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(psta->cmn.rssi_stat.rssi);
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		sinfo->inactive_time = rtw_get_passing_time_ms(psta->sta_stats.last_rx_time);
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_cfg80211_fill_mesh_only_sta_info(plink, psta, sinfo);
+#endif
+
+exit:
+	return ret;
+}
+
+static int	cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,
+		struct bss_parameters *params)
+{
+	u8 i;
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+/*
+	RTW_INFO("use_cts_prot=%d\n", params->use_cts_prot);
+	RTW_INFO("use_short_preamble=%d\n", params->use_short_preamble);
+	RTW_INFO("use_short_slot_time=%d\n", params->use_short_slot_time);
+	RTW_INFO("ap_isolate=%d\n", params->ap_isolate);
+
+	RTW_INFO("basic_rates_len=%d\n", params->basic_rates_len);
+	for(i = 0; i < params->basic_rates_len; i++)
+		RTW_INFO("basic_rates=%d\n", params->basic_rates[i]);
+*/
+	return 0;
+
+}
+
+static int	cfg80211_rtw_set_channel(struct wiphy *wiphy
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	, struct net_device *ndev
+	#endif
+	, struct ieee80211_channel *chan, enum nl80211_channel_type channel_type)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+#else
+	_adapter *padapter = wiphy_to_adapter(wiphy);
+#endif
+	int chan_target = (u8) ieee80211_frequency_to_channel(chan->center_freq);
+	int chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int chan_width = CHANNEL_WIDTH_20;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+#endif
+
+	switch (channel_type) {
+	case NL80211_CHAN_NO_HT:
+	case NL80211_CHAN_HT20:
+		chan_width = CHANNEL_WIDTH_20;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT40MINUS:
+		chan_width = CHANNEL_WIDTH_40;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_HT40PLUS:
+		chan_width = CHANNEL_WIDTH_40;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+	default:
+		chan_width = CHANNEL_WIDTH_20;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
+
+	RTW_INFO(FUNC_ADPT_FMT" ch:%d bw:%d, offset:%d\n"
+		, FUNC_ADPT_ARG(padapter), chan_target, chan_width, chan_offset);
+
+	rtw_set_chbw_cmd(padapter, chan_target, chan_width, chan_offset, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+
+static int cfg80211_rtw_set_monitor_channel(struct wiphy *wiphy
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	, struct cfg80211_chan_def *chandef
+#else
+	, struct ieee80211_channel *chan
+	, enum nl80211_channel_type channel_type
+#endif
+)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct ieee80211_channel *chan = chandef->chan;
+#endif
+
+	_adapter *padapter = wiphy_to_adapter(wiphy);
+	int target_channal = chan->hw_value;
+	int target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int target_width = CHANNEL_WIDTH_20;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("center_freq %u Mhz ch %u width %u freq1 %u freq2 %u\n"
+		, chan->center_freq
+		, chan->hw_value
+		, chandef->width
+		, chandef->center_freq1
+		, chandef->center_freq2);
+#endif /* CONFIG_DEBUG_CFG80211 */
+
+	switch (chandef->width) {
+	case NL80211_CHAN_WIDTH_20_NOHT:
+	case NL80211_CHAN_WIDTH_20:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_WIDTH_40:
+		target_width = CHANNEL_WIDTH_40;
+		if (chandef->center_freq1 > chan->center_freq)
+			target_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		else
+			target_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_WIDTH_80:
+		target_width = CHANNEL_WIDTH_80;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_WIDTH_80P80:
+		target_width = CHANNEL_WIDTH_80_80;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_WIDTH_160:
+		target_width = CHANNEL_WIDTH_160;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	case NL80211_CHAN_WIDTH_5:
+	case NL80211_CHAN_WIDTH_10:
+#endif
+	default:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
+#else
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("center_freq %u Mhz ch %u channel_type %u\n"
+		, chan->center_freq
+		, chan->hw_value
+		, channel_type);
+#endif /* CONFIG_DEBUG_CFG80211 */
+
+	switch (channel_type) {
+	case NL80211_CHAN_NO_HT:
+	case NL80211_CHAN_HT20:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT40MINUS:
+		target_width = CHANNEL_WIDTH_40;
+		target_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_HT40PLUS:
+		target_width = CHANNEL_WIDTH_40;
+		target_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+	default:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
+#endif
+	RTW_INFO(FUNC_ADPT_FMT" ch:%d bw:%d, offset:%d\n"
+		, FUNC_ADPT_ARG(padapter), target_channal, target_width, target_offset);
+
+	rtw_set_chbw_cmd(padapter, target_channal, target_width, target_offset, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+
+static int	cfg80211_rtw_auth(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_auth_request *req)
+{
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	return 0;
+}
+
+static int	cfg80211_rtw_assoc(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_assoc_request *req)
+{
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	return 0;
+}
+#endif /* CONFIG_AP_MODE */
+
+void rtw_cfg80211_rx_probe_request(_adapter *adapter, union recv_frame *rframe)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("RTW_Rx: probe request, ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_rx_action_p2p(_adapter *adapter, union recv_frame *rframe)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+	u8 category, action;
+	int type;
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+#ifdef CONFIG_P2P
+	type = rtw_p2p_check_frames(adapter, frame, frame_len, _FALSE);
+	if (type >= 0)
+		goto indicate;
+#endif
+	rtw_action_frame_parse(frame, frame_len, &category, &action);
+	RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+
+indicate:
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_rx_p2p_action_public(_adapter *adapter, union recv_frame *rframe)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+	u8 category, action;
+	int type;
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+	#ifdef CONFIG_P2P
+	type = rtw_p2p_check_frames(adapter, frame, frame_len, _FALSE);
+	if (type >= 0) {
+		switch (type) {
+		case P2P_GO_NEGO_CONF:
+			if (0) {
+				RTW_INFO(FUNC_ADPT_FMT" Nego confirm. state=%u, status=%u, iaddr="MAC_FMT"\n"
+					, FUNC_ADPT_ARG(adapter), pwdev_priv->nego_info.state, pwdev_priv->nego_info.status
+					, MAC_ARG(pwdev_priv->nego_info.iface_addr));
+			}
+			if (pwdev_priv->nego_info.state == 2
+				&& pwdev_priv->nego_info.status == 0
+				&& rtw_check_invalid_mac_address(pwdev_priv->nego_info.iface_addr, _FALSE) == _FALSE
+			) {
+				_adapter *intended_iface = dvobj_get_adapter_by_addr(dvobj, pwdev_priv->nego_info.iface_addr);
+
+				if (intended_iface) {
+					RTW_INFO(FUNC_ADPT_FMT" Nego confirm. Allow only "ADPT_FMT" to scan for 2000 ms\n"
+						, FUNC_ADPT_ARG(adapter), ADPT_ARG(intended_iface));
+					/* allow only intended_iface to do scan for 2000 ms */
+					rtw_mi_set_scan_deny(adapter, 2000);
+					rtw_clear_scan_deny(intended_iface);
+				}
+			}
+			break;
+		case P2P_PROVISION_DISC_RESP:
+		case P2P_INVIT_RESP:
+			#if !RTW_P2P_GROUP_INTERFACE
+			rtw_mi_buddy_set_scan_deny(adapter, 2000);
+			#endif
+			break;
+		}
+		goto indicate;
+	}
+	#endif
+	rtw_action_frame_parse(frame, frame_len, &category, &action);
+	RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+
+indicate:
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (rtw_cfg80211_redirect_pd_wdev(dvobj_to_wiphy(dvobj), get_ra(frame), &wdev))
+		if (0)
+			RTW_INFO("redirect to pd_wdev:%p\n", wdev);
+	#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const char *msg)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+	u8 category, action;
+	int type = -1;
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		type = rtw_mesh_check_frames_rx(adapter, frame, frame_len);
+		if (type >= 0)
+			goto indicate;
+	}
+#endif
+	rtw_action_frame_parse(frame, frame_len, &category, &action);
+	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
+		if (action == ACT_PUBLIC_GAS_INITIAL_REQ) {
+			rtw_mi_set_scan_deny(adapter, 200);
+			rtw_mi_scan_abort(adapter, _FALSE); /*rtw_scan_abort_no_wait*/
+		}
+	}
+
+indicate:
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+
+	if (type == -1) {
+		if (msg)
+			RTW_INFO("RTW_Rx:%s\n", msg);
+		else
+			RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+	}
+}
+
+#ifdef CONFIG_RTW_80211K
+void rtw_cfg80211_rx_rrm_action(_adapter *adapter, union recv_frame *rframe)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+}
+#endif /* CONFIG_RTW_80211K */
+
+void rtw_cfg80211_rx_mframe(_adapter *adapter, union recv_frame *rframe, const char *msg)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n", ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+	#ifdef CONFIG_RTW_MESH
+	if (!rtw_sae_check_frames(adapter, frame, frame_len, _FALSE))
+	#endif
+	{
+		if (msg)
+			RTW_INFO("RTW_Rx:%s\n", msg);
+		else
+			RTW_INFO("RTW_Rx:frame_control:0x%02x\n", le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)rframe)->frame_ctl));
+	}
+}
+
+#ifdef CONFIG_P2P
+void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len)
+{
+	u16	wps_devicepassword_id = 0x0000;
+	uint	wps_devicepassword_id_len = 0;
+	u8			wpsie[255] = { 0x00 }, p2p_ie[255] = { 0x00 };
+	uint			p2p_ielen = 0;
+	uint			wpsielen = 0;
+	u32	devinfo_contentlen = 0;
+	u8	devinfo_content[64] = { 0x00 };
+	u16	capability = 0;
+	uint capability_len = 0;
+
+	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
+	u8			action = P2P_PUB_ACTION_ACTION;
+	u8			dialogToken = 1;
+	u32			p2poui = cpu_to_be32(P2POUI);
+	u8			oui_subtype = P2P_PROVISION_DISC_REQ;
+	u32			p2pielen = 0;
+#ifdef CONFIG_WFD
+	u32					wfdielen = 0;
+#endif
+
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	unsigned char					*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	unsigned short				*fctrl;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8 *frame_body = (unsigned char *)(buf + sizeof(struct rtw_ieee80211_hdr_3addr));
+	size_t frame_body_len = len - sizeof(struct rtw_ieee80211_hdr_3addr);
+
+
+	RTW_INFO("[%s] In\n", __FUNCTION__);
+
+	/* prepare for building provision_request frame	 */
+	_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerIFAddr, GetAddr1Ptr(buf), ETH_ALEN);
+	_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerDevAddr, GetAddr1Ptr(buf), ETH_ALEN);
+
+	pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
+
+	rtw_get_wps_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, wpsie, &wpsielen);
+	rtw_get_wps_attr_content(wpsie, wpsielen, WPS_ATTR_DEVICE_PWID, (u8 *) &wps_devicepassword_id, &wps_devicepassword_id_len);
+	wps_devicepassword_id = be16_to_cpu(wps_devicepassword_id);
+
+	switch (wps_devicepassword_id) {
+	case WPS_DPID_PIN:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_LABEL;
+		break;
+	case WPS_DPID_USER_SPEC:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_DISPLYA;
+		break;
+	case WPS_DPID_MACHINE_SPEC:
+		break;
+	case WPS_DPID_REKEY:
+		break;
+	case WPS_DPID_PBC:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
+		break;
+	case WPS_DPID_REGISTRAR_SPEC:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_KEYPAD;
+		break;
+	default:
+		break;
+	}
+
+
+	if (rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, p2p_ie, &p2p_ielen)) {
+
+		rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO, devinfo_content, &devinfo_contentlen);
+		rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&capability, &capability_len);
+
+	}
+
+
+	/* start to build provision_request frame	 */
+	_rtw_memset(wpsie, 0, sizeof(wpsie));
+	_rtw_memset(p2p_ie, 0, sizeof(p2p_ie));
+	p2p_ielen = 0;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return;
+
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, pwdinfo->tx_prov_disc_info.peerDevAddr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, pwdinfo->tx_prov_disc_info.peerDevAddr, ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
+
+
+	/* build_prov_disc_request_p2p_ie	 */
+	/*	P2P OUI */
+	p2pielen = 0;
+	p2p_ie[p2pielen++] = 0x50;
+	p2p_ie[p2pielen++] = 0x6F;
+	p2p_ie[p2pielen++] = 0x9A;
+	p2p_ie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20110301 */
+	/*	According to the P2P Specification, the provision discovery request frame should contain 3 P2P attributes */
+	/*	1. P2P Capability */
+	/*	2. Device Info */
+	/*	3. Group ID ( When joining an operating P2P Group ) */
+
+	/*	P2P Capability ATTR */
+	/*	Type:	 */
+	p2p_ie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+	/*	Length: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 ); */
+	RTW_PUT_LE16(p2p_ie + p2pielen, 0x0002);
+	p2pielen += 2;
+
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
+	/*	Group Capability Bitmap, 1 byte */
+	_rtw_memcpy(p2p_ie + p2pielen, &capability, 2);
+	p2pielen += 2;
+
+
+	/*	Device Info ATTR */
+	/*	Type: */
+	p2p_ie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
+
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len ); */
+	RTW_PUT_LE16(p2p_ie + p2pielen, devinfo_contentlen);
+	p2pielen += 2;
+
+	/*	Value: */
+	_rtw_memcpy(p2p_ie + p2pielen, devinfo_content, devinfo_contentlen);
+	p2pielen += devinfo_contentlen;
+
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2p_ie, &p2p_ielen);
+	/* p2pielen = build_prov_disc_request_p2p_ie( pwdinfo, pframe, NULL, 0, pwdinfo->tx_prov_disc_info.peerDevAddr); */
+	/* pframe += p2pielen; */
+	pattrib->pktlen += p2p_ielen;
+
+	wpsielen = 0;
+	/*	WPS OUI */
+	*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
+	wpsielen += 4;
+
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
+	wpsielen += 2;
+
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
+	wpsielen += 2;
+
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
+
+	/*	Config Method */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
+	wpsielen += 2;
+
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
+	wpsielen += 2;
+
+	/*	Value: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->tx_prov_disc_info.wps_config_method_request);
+	wpsielen += 2;
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
+
+
+#ifdef CONFIG_WFD
+	wfdielen = build_provdisc_req_wfd_ie(pwdinfo, pframe);
+	pframe += wfdielen;
+	pattrib->pktlen += wfdielen;
+#endif
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	/* dump_mgntframe(padapter, pmgntframe); */
+	if (dump_mgntframe_and_wait_ack(padapter, pmgntframe) != _SUCCESS)
+		RTW_INFO("%s, ack to\n", __func__);
+
+	#if 0
+	if(wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC) {
+		RTW_INFO("waiting for p2p peer key-in PIN CODE\n");
+		rtw_msleep_os(15000); /* 15 sec for key in PIN CODE, workaround for GS2 before issuing Nego Req. */
+	}
+	#endif
+
+}
+
+#ifdef CONFIG_RTW_80211R
+static s32 cfg80211_rtw_update_ft_ies(struct wiphy *wiphy,
+	struct net_device *ndev,
+	struct cfg80211_update_ft_ies_params *ftie)
+{
+	_adapter *padapter = NULL;
+	struct mlme_priv *pmlmepriv = NULL;
+	struct ft_roam_info *pft_roam = NULL;
+	_irqL irqL;
+	u8 *p;
+	u8 *pie = NULL;
+	u32 ie_len = 0;
+
+	if (ndev == NULL)
+		return  -EINVAL;
+
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	pmlmepriv = &(padapter->mlmepriv);
+	pft_roam = &(pmlmepriv->ft_roam);
+
+	p = (u8 *)ftie->ie;
+	if (ftie->ie_len <= sizeof(pft_roam->updated_ft_ies)) {
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		_rtw_memcpy(pft_roam->updated_ft_ies, ftie->ie, ftie->ie_len);
+		pft_roam->updated_ft_ies_len = ftie->ie_len;
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+	} else {
+		RTW_ERR("FTIEs parsing fail!\n");
+		return -EINVAL;
+	}
+
+	if (rtw_ft_roam_status(padapter, RTW_FT_AUTHENTICATED_STA)) {
+		RTW_PRINT("auth success, start reassoc\n");
+		rtw_ft_lock_set_status(padapter, RTW_FT_ASSOCIATING_STA, &irqL);
+		start_clnt_assoc(padapter);
+	}
+
+	return 0;
+}
+#endif
+
+inline void rtw_cfg80211_set_is_roch(_adapter *adapter, bool val)
+{
+	adapter->cfg80211_wdinfo.is_ro_ch = val;
+	rtw_mi_update_iface_status(&(adapter->mlmepriv), 0);
+}
+
+inline bool rtw_cfg80211_get_is_roch(_adapter *adapter)
+{
+	return adapter->cfg80211_wdinfo.is_ro_ch;
+}
+
+inline bool rtw_cfg80211_is_ro_ch_once(_adapter *adapter)
+{
+	return adapter->cfg80211_wdinfo.last_ro_ch_time ? 1 : 0;
+}
+
+inline void rtw_cfg80211_set_last_ro_ch_time(_adapter *adapter)
+{
+	adapter->cfg80211_wdinfo.last_ro_ch_time = rtw_get_current_time();
+
+	if (!adapter->cfg80211_wdinfo.last_ro_ch_time)
+		adapter->cfg80211_wdinfo.last_ro_ch_time++;
+}
+
+inline s32 rtw_cfg80211_get_last_ro_ch_passing_ms(_adapter *adapter)
+{
+	return rtw_get_passing_time_ms(adapter->cfg80211_wdinfo.last_ro_ch_time);
+}
+
+static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+	struct ieee80211_channel *channel,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	enum nl80211_channel_type channel_type,
+#endif
+	unsigned int duration, u64 *cookie)
+{
+	s32 err = 0;
+	u8 remain_ch = (u8) ieee80211_frequency_to_channel(channel->center_freq);
+	u8 union_ch = 0, union_bw = 0, union_offset = 0;
+	u8 i;
+	_adapter *padapter = NULL;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct wifidirect_info *pwdinfo;
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
+	u8 is_p2p_find = _FALSE;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		err = -EINVAL;
+		goto exit;
+	}
+#else
+	struct wireless_dev *wdev;
+
+	if (ndev == NULL) {
+		err = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	pwdev_priv = adapter_wdev_data(padapter);
+	pwdinfo = &padapter->wdinfo;
+	pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+#ifdef CONFIG_CONCURRENT_MODE
+	is_p2p_find = (duration < (pwdinfo->ext_listen_interval)) ? _TRUE : _FALSE;
+#endif
+
+	*cookie = ATOMIC_INC_RETURN(&pcfg80211_wdinfo->ro_ch_cookie_gen);
+
+	RTW_INFO(FUNC_ADPT_FMT"%s ch:%u duration:%d, cookie:0x%llx\n"
+		, FUNC_ADPT_ARG(padapter), wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : ""
+		, remain_ch, duration, *cookie);
+
+	if (rtw_chset_search_ch(adapter_to_chset(padapter), remain_ch) < 0) {
+		RTW_WARN(FUNC_ADPT_FMT" invalid ch:%u\n", FUNC_ADPT_ARG(padapter), remain_ch);
+		err = -EFAULT;
+		goto exit;
+	}
+
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block remain_on_channel request\n");
+		err = -EFAULT;
+		goto exit;
+	}
+#endif
+
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		err = -EFAULT;
+		goto exit;
+	}
+
+	rtw_scan_abort(padapter);
+#ifdef CONFIG_CONCURRENT_MODE
+	/*don't scan_abort during p2p_listen.*/
+	if (is_p2p_find)
+		rtw_mi_buddy_scan_abort(padapter, _TRUE);
+#endif /*CONFIG_CONCURRENT_MODE*/
+
+	if (rtw_cfg80211_get_is_roch(padapter) == _TRUE) {
+		_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
+		p2p_cancel_roch_cmd(padapter, 0, NULL, RTW_CMDF_WAIT_ACK);
+	}
+
+	/* if(!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) && !rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) */
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
+		padapter->wdinfo.listen_channel = remain_ch;
+		RTW_INFO(FUNC_ADPT_FMT" init listen_channel %u\n"
+			, FUNC_ADPT_ARG(padapter), padapter->wdinfo.listen_channel);
+	} else if (rtw_p2p_chk_state(pwdinfo , P2P_STATE_LISTEN)
+		&& (time_after_eq(rtw_get_current_time(), pwdev_priv->probe_resp_ie_update_time)
+			&& rtw_get_passing_time_ms(pwdev_priv->probe_resp_ie_update_time) < 50)
+	) {
+		if (padapter->wdinfo.listen_channel != remain_ch) {
+			padapter->wdinfo.listen_channel = remain_ch;
+			RTW_INFO(FUNC_ADPT_FMT" update listen_channel %u\n"
+				, FUNC_ADPT_ARG(padapter), padapter->wdinfo.listen_channel);
+		}
+	} else {
+		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
+#endif
+	}
+
+	rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
+
+	#ifdef RTW_ROCH_DURATION_ENLARGE
+	if (duration < 400)
+		duration = duration * 3; /* extend from exper */
+	#endif
+
+#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_CONCURRENT_MODE)
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		if (is_p2p_find) /* p2p_find , duration<1000 */
+			duration = duration + pwdinfo->ext_listen_interval;
+		else /* p2p_listen, duration=5000 */
+			duration = pwdinfo->ext_listen_interval + (pwdinfo->ext_listen_interval / 4);
+	}
+#endif /*defined (RTW_ROCH_BACK_OP) && defined(CONFIG_CONCURRENT_MODE) */
+
+	rtw_cfg80211_set_is_roch(padapter, _TRUE);
+	pcfg80211_wdinfo->ro_ch_wdev = wdev;
+	pcfg80211_wdinfo->remain_on_ch_cookie = *cookie;
+	rtw_cfg80211_set_last_ro_ch_time(padapter);
+	_rtw_memcpy(&pcfg80211_wdinfo->remain_on_ch_channel, channel, sizeof(struct ieee80211_channel));
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	pcfg80211_wdinfo->remain_on_ch_type = channel_type;
+	#endif
+	pcfg80211_wdinfo->restore_channel = rtw_get_oper_ch(padapter);
+
+	p2p_roch_cmd(padapter, *cookie, wdev, channel, pcfg80211_wdinfo->remain_on_ch_type,
+		duration, RTW_CMDF_WAIT_ACK);
+
+	rtw_cfg80211_ready_on_channel(wdev, *cookie, channel, channel_type, duration, GFP_KERNEL);
+exit:
+	return err;
+}
+
+static s32 cfg80211_rtw_cancel_remain_on_channel(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+	u64 cookie)
+{
+	s32 err = 0;
+	_adapter *padapter;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct wifidirect_info *pwdinfo;
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		err = -EINVAL;
+		goto exit;
+	}
+#else
+	struct wireless_dev *wdev;
+
+	if (ndev == NULL) {
+		err = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	pwdev_priv = adapter_wdev_data(padapter);
+	pwdinfo = &padapter->wdinfo;
+	pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+
+	RTW_INFO(FUNC_ADPT_FMT"%s cookie:0x%llx\n"
+		, FUNC_ADPT_ARG(padapter), wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : ""
+		, cookie);
+
+	if (rtw_cfg80211_get_is_roch(padapter) == _TRUE) {
+		_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
+		p2p_cancel_roch_cmd(padapter, cookie, wdev, RTW_CMDF_WAIT_ACK);
+	}
+
+exit:
+	return err;
+}
+
+inline int rtw_cfg80211_iface_has_p2p_group_cap(_adapter *adapter)
+{
+	struct wiphy *wiphy = adapter_to_wiphy(adapter);
+	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(adapter);
+
+#if RTW_P2P_GROUP_INTERFACE
+	if (is_primary_adapter(adapter))
+		return 0;
+#endif
+	return 1;
+}
+
+inline int rtw_cfg80211_is_p2p_scan(_adapter *adapter)
+{
+#if RTW_P2P_GROUP_INTERFACE
+	if (rtw_cfg80211_iface_has_p2p_group_cap(adapter))
+#endif
+	{
+		struct wifidirect_info *wdinfo = &adapter->wdinfo;
+
+		return rtw_p2p_chk_state(wdinfo, P2P_STATE_SCAN)
+			|| rtw_p2p_chk_state(wdinfo, P2P_STATE_FIND_PHASE_SEARCH);
+	}
+
+#if RTW_P2P_GROUP_INTERFACE
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wiphy_to_pd_wdev(adapter_to_wiphy(adapter))) /* pd_wdev exist */
+		return rtw_cfg80211_is_scan_by_pd_wdev(adapter);
+	#endif
+	{
+		/*
+		* For 2 RTW_P2P_GROUP_INTERFACE cases:
+		* 1. RTW_DEDICATED_P2P_DEVICE defined but upper layer don't use pd_wdev or
+		* 2. RTW_DEDICATED_P2P_DEVICE not defined
+		*/
+		struct rtw_wdev_priv *wdev_data = adapter_wdev_data(adapter);
+		_irqL irqL;
+		int is_p2p_scan = 0;
+
+		_enter_critical_bh(&wdev_data->scan_req_lock, &irqL);
+		if (wdev_data->scan_request
+			&& wdev_data->scan_request->ssids
+			&& wdev_data->scan_request->ie
+		) {
+			if (_rtw_memcmp(wdev_data->scan_request->ssids->ssid, "DIRECT-", 7)
+				&& rtw_get_p2p_ie((u8 *)wdev_data->scan_request->ie, wdev_data->scan_request->ie_len, NULL, NULL))
+				is_p2p_scan = 1;
+		}
+		_exit_critical_bh(&wdev_data->scan_req_lock, &irqL);
+
+		return is_p2p_scan;
+	}
+#endif
+}
+
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+int rtw_pd_iface_alloc(struct wiphy *wiphy, const char *name, struct wireless_dev **pd_wdev)
+{
+	struct rtw_wiphy_data *wiphy_data = rtw_wiphy_priv(wiphy);
+	struct wireless_dev *wdev = NULL;
+	struct rtw_netdev_priv_indicator *npi;
+	_adapter *primary_adpt = wiphy_to_adapter(wiphy);
+	int ret = 0;
+
+	if (wiphy_data->pd_wdev) {
+		RTW_WARN(FUNC_WIPHY_FMT" pd_wdev already exists\n", FUNC_WIPHY_ARG(wiphy));
+		ret = -EBUSY;
+		goto exit;
+	}
+
+	wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
+	if (!wdev) {
+		RTW_WARN(FUNC_WIPHY_FMT" allocate wdev fail\n", FUNC_WIPHY_ARG(wiphy));
+		ret = -ENOMEM;
+		goto exit;
+	}
+
+	wdev->wiphy = wiphy;
+	wdev->iftype = NL80211_IFTYPE_P2P_DEVICE;
+	_rtw_memcpy(wdev->address, adapter_mac_addr(primary_adpt), ETH_ALEN);
+
+	wiphy_data->pd_wdev = wdev;
+	*pd_wdev = wdev;
+
+	RTW_INFO(FUNC_WIPHY_FMT" pd_wdev:%p, addr="MAC_FMT" added\n"
+		, FUNC_WIPHY_ARG(wiphy), wdev, MAC_ARG(wdev_address(wdev)));
+
+exit:
+	if (ret && wdev) {
+		rtw_mfree((u8 *)wdev, sizeof(struct wireless_dev));
+		wdev = NULL;
+	}
+
+	return ret;
+}
+
+void rtw_pd_iface_free(struct wiphy *wiphy)
+{
+	struct dvobj_priv *dvobj = wiphy_to_dvobj(wiphy);
+	struct rtw_wiphy_data *wiphy_data = rtw_wiphy_priv(wiphy);
+	u8 rtnl_lock_needed;
+
+	if (!wiphy_data->pd_wdev)
+		goto exit;
+
+	RTW_INFO(FUNC_WIPHY_FMT" pd_wdev:%p, addr="MAC_FMT"\n"
+		, FUNC_WIPHY_ARG(wiphy), wiphy_data->pd_wdev
+		, MAC_ARG(wdev_address(wiphy_data->pd_wdev)));
+
+	rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+	if (rtnl_lock_needed)
+		rtnl_lock();
+	cfg80211_unregister_wdev(wiphy_data->pd_wdev);
+	if (rtnl_lock_needed)
+		rtnl_unlock();
+
+	rtw_mfree((u8 *)wiphy_data->pd_wdev, sizeof(struct wireless_dev));
+	wiphy_data->pd_wdev = NULL;
+
+exit:
+	return;
+}
+
+static int cfg80211_rtw_start_p2p_device(struct wiphy *wiphy, struct wireless_dev *wdev)
+{
+	_adapter *adapter = wiphy_to_adapter(wiphy);
+
+	RTW_INFO(FUNC_WIPHY_FMT" wdev=%p\n", FUNC_WIPHY_ARG(wiphy), wdev);
+
+	rtw_p2p_enable(adapter, P2P_ROLE_DEVICE);
+	return 0;
+}
+
+static void cfg80211_rtw_stop_p2p_device(struct wiphy *wiphy, struct wireless_dev *wdev)
+{
+	_adapter *adapter = wiphy_to_adapter(wiphy);
+
+	RTW_INFO(FUNC_WIPHY_FMT" wdev=%p\n", FUNC_WIPHY_ARG(wiphy), wdev);
+
+	if (rtw_cfg80211_is_p2p_scan(adapter))
+		rtw_scan_abort(adapter);
+
+	rtw_p2p_enable(adapter, P2P_ROLE_DISABLE);
+}
+
+inline int rtw_cfg80211_redirect_pd_wdev(struct wiphy *wiphy, u8 *ra, struct wireless_dev **wdev)
+{
+	struct wireless_dev *pd_wdev = wiphy_to_pd_wdev(wiphy);
+
+	if (pd_wdev && pd_wdev != *wdev
+		&& _rtw_memcmp(wdev_address(pd_wdev), ra, ETH_ALEN) == _TRUE
+	) {
+		*wdev = pd_wdev;
+		return 1;
+	}
+	return 0;
+}
+
+inline int rtw_cfg80211_is_scan_by_pd_wdev(_adapter *adapter)
+{
+	struct wiphy *wiphy = adapter_to_wiphy(adapter);
+	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(adapter);
+	struct wireless_dev *wdev = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&wdev_data->scan_req_lock, &irqL);
+	if (wdev_data->scan_request)
+		wdev = wdev_data->scan_request->wdev;
+	_exit_critical_bh(&wdev_data->scan_req_lock, &irqL);
+
+	if (wdev && wdev == wiphy_to_pd_wdev(wiphy))
+		return 1;
+
+	return 0;
+}
+#endif /* RTW_DEDICATED_P2P_DEVICE */
+#endif /* CONFIG_P2P */
+
+inline void rtw_cfg80211_set_is_mgmt_tx(_adapter *adapter, u8 val)
+{
+	struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+
+	wdev_priv->is_mgmt_tx = val;
+	rtw_mi_update_iface_status(&(adapter->mlmepriv), 0);
+}
+
+inline u8 rtw_cfg80211_get_is_mgmt_tx(_adapter *adapter)
+{
+	struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+
+	return wdev_priv->is_mgmt_tx;
+}
+
+static int _cfg80211_rtw_mgmt_tx(_adapter *padapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack)
+{
+	struct xmit_frame	*pmgntframe;
+	struct pkt_attrib	*pattrib;
+	unsigned char	*pframe;
+	int ret = _FAIL;
+	bool ack = _TRUE;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	u8 u_ch = rtw_mi_get_union_chan(padapter);
+	u8 leave_op = 0;
+#ifdef CONFIG_P2P
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif
+
+	rtw_cfg80211_set_is_mgmt_tx(padapter, 1);
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_ScanNotify(padapter, _TRUE);
+#endif
+
+#ifdef CONFIG_P2P
+	if (rtw_cfg80211_get_is_roch(padapter) == _TRUE) {
+		#ifdef CONFIG_CONCURRENT_MODE
+		if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
+			RTW_INFO("%s, extend ro ch time\n", __func__);
+			_set_timer(&padapter->cfg80211_wdinfo.remain_on_ch_timer, pwdinfo->ext_listen_period);
+		}
+		#endif /* CONFIG_CONCURRENT_MODE */
+	}
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+			/* don't set channel, issue frame directly */
+			goto issue_mgmt_frame;
+	}
+#endif /* CONFIG_MCC_MODE */
+
+	if (rtw_mi_check_status(padapter, MI_LINKED)
+		&& tx_ch != u_ch
+	) {
+		rtw_leave_opch(padapter);
+		leave_op = 1;
+
+		#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_P2P) && defined(CONFIG_CONCURRENT_MODE)
+		if (rtw_cfg80211_get_is_roch(padapter)
+			&& ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1
+		) {
+			u16 ext_listen_period;
+
+			if (check_fwstate(&padapter->mlmepriv, _FW_LINKED))
+				ext_listen_period = 500;
+			else
+				ext_listen_period = pwdinfo->ext_listen_period;
+			ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
+			_set_timer(&pwdinfo->ap_p2p_switch_timer, ext_listen_period);
+			RTW_INFO("%s, set switch ch timer, period=%d\n", __func__, ext_listen_period);
+		}
+		#endif /* RTW_ROCH_BACK_OP && CONFIG_P2P && CONFIG_CONCURRENT_MODE */
+	}
+
+	if (tx_ch != rtw_get_oper_ch(padapter))
+		set_channel_bwmode(padapter, tx_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+
+issue_mgmt_frame:
+	/* starting alloc mgmt frame to dump it */
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		/* ret = -ENOMEM; */
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+
+	if (no_cck && IS_CCK_RATE(pattrib->rate)) {
+		/* force OFDM 6M rate*/
+		pattrib->rate = MGN_6M;
+		pattrib->raid = rtw_get_mgntframe_raid(padapter, WIRELESS_11G);
+	}
+
+	pattrib->retry_ctrl = _FALSE;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	_rtw_memcpy(pframe, (void *)buf, len);
+	pattrib->pktlen = len;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	/* update seq number */
+	pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
+	pattrib->seqnum = pmlmeext->mgnt_seq;
+	pmlmeext->mgnt_seq++;
+
+#ifdef CONFIG_P2P
+	rtw_xframe_chk_wfd_ie(pmgntframe);
+#endif /* CONFIG_P2P */
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	if (wait_ack) {
+		if (dump_mgntframe_and_wait_ack(padapter, pmgntframe) != _SUCCESS) {
+			ack = _FALSE;
+			ret = _FAIL;
+
+#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s, ack == _FAIL\n", __func__);
+#endif
+		} else {
+
+#ifdef CONFIG_XMIT_ACK
+			if (!MLME_IS_MESH(padapter)) /* TODO: remove this sleep for all mode */
+				rtw_msleep_os(50);
+#endif
+#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s, ack=%d, ok!\n", __func__, ack);
+#endif
+			ret = _SUCCESS;
+		}
+	} else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
+
+exit:
+	#ifdef CONFIG_P2P
+	if (rtw_cfg80211_get_is_roch(padapter)
+		&& !roch_stay_in_cur_chan(padapter)
+		&& pcfg80211_wdinfo->remain_on_ch_channel.hw_value != u_ch
+	) {
+		/* roch is ongoing, switch back to rch */
+		if (pcfg80211_wdinfo->remain_on_ch_channel.hw_value != tx_ch)
+			set_channel_bwmode(padapter, pcfg80211_wdinfo->remain_on_ch_channel.hw_value
+				, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+	} else
+	#endif
+	if (leave_op) {
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 u_bw = rtw_mi_get_union_bw(padapter);
+			u8 u_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, u_ch, u_offset, u_bw);
+		}
+		rtw_back_opch(padapter);
+	}
+
+	rtw_cfg80211_set_is_mgmt_tx(padapter, 0);
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_ScanNotify(padapter, _FALSE);
+#endif
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ret=%d\n", __func__, ret);
+#endif
+
+	return ret;
+
+}
+
+u8 rtw_mgnt_tx_handler(_adapter *adapter, u8 *buf)
+{
+	u8 rst = H2C_CMD_FAIL;
+	struct mgnt_tx_parm *mgnt_parm = (struct mgnt_tx_parm *)buf;
+
+	if (_cfg80211_rtw_mgmt_tx(adapter, mgnt_parm->tx_ch, mgnt_parm->no_cck,
+		mgnt_parm->buf, mgnt_parm->len, mgnt_parm->wait_ack) == _SUCCESS)
+		rst = H2C_SUCCESS;
+
+	return rst;
+}
+
+static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0)) || defined(COMPAT_KERNEL_RELEASE)
+	struct ieee80211_channel *chan,
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	bool offchan,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	enum nl80211_channel_type channel_type,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	bool channel_type_valid,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	unsigned int wait,
+	#endif
+	const u8 *buf, size_t len,
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	bool no_cck,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	bool dont_wait_for_ack,
+	#endif
+#else
+	struct cfg80211_mgmt_tx_params *params,
+#endif
+	u64 *cookie)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(COMPAT_KERNEL_RELEASE)
+	struct ieee80211_channel *chan = params->chan;
+	bool offchan = params->offchan;
+	unsigned int wait = params->wait;
+	const u8 *buf = params->buf;
+	size_t len = params->len;
+	bool no_cck = params->no_cck;
+	bool dont_wait_for_ack = params->dont_wait_for_ack;
+#endif
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 2, 0))
+	bool no_cck = 0;
+#endif
+	int ret = 0;
+	u8 tx_ret;
+	int wait_ack = 1;
+	const u8 *dump_buf = buf;
+	size_t dump_len = len;
+	u32 dump_limit = RTW_MAX_MGMT_TX_CNT;
+	u32 dump_cnt = 0;
+	u32 sleep_ms = 0;
+	u32 retry_guarantee_ms = 0;
+	bool ack = _TRUE;
+	u8 tx_ch;
+	u8 category, action;
+	u8 frame_styp;
+#ifdef CONFIG_P2P
+	u8 is_p2p = 0;
+#endif
+	int type = (-1);
+	systime start = rtw_get_current_time();
+	_adapter *padapter;
+	struct dvobj_priv *dvobj;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct rf_ctl_t *rfctl;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		ret = -EINVAL;
+		goto exit;
+	}
+#else
+	struct wireless_dev *wdev;
+
+	if (ndev == NULL) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	if (chan == NULL) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	rfctl = adapter_to_rfctl(padapter);
+	tx_ch = (u8)ieee80211_frequency_to_channel(chan->center_freq);
+	if (IS_CH_WAITING(rfctl)) {
+		#ifdef CONFIG_DFS_MASTER
+		if (_rtw_rfctl_overlap_radar_detect_ch(rfctl, tx_ch, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+		#endif
+	}
+
+	dvobj = adapter_to_dvobj(padapter);
+	pwdev_priv = adapter_wdev_data(padapter);
+
+	/* cookie generation */
+	*cookie = pwdev_priv->mgmt_tx_cookie++;
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO(FUNC_ADPT_FMT"%s len=%zu, ch=%d"
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		", ch_type=%d"
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		", channel_type_valid=%d"
+		#endif
+		"\n", FUNC_ADPT_ARG(padapter), wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : ""
+		, len, tx_ch
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		, channel_type
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		, channel_type_valid
+		#endif
+	);
+#endif /* CONFIG_DEBUG_CFG80211 */
+
+	/* indicate ack before issue frame to avoid racing with rsp frame */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_mgmt_tx_status(wdev, *cookie, buf, len, ack, GFP_KERNEL);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 36))
+	cfg80211_action_tx_status(ndev, *cookie, buf, len, ack, GFP_KERNEL);
+#endif
+
+	frame_styp = le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl) & IEEE80211_FCTL_STYPE;
+	if (IEEE80211_STYPE_PROBE_RESP == frame_styp) {
+#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("RTW_Tx: probe_resp tx_ch=%d, no_cck=%u, da="MAC_FMT"\n", tx_ch, no_cck, MAC_ARG(GetAddr1Ptr(buf)));
+#endif /* CONFIG_DEBUG_CFG80211 */
+		wait_ack = 0;
+		goto dump;
+	}
+#ifdef CONFIG_RTW_MESH
+	else if (frame_styp == RTW_IEEE80211_STYPE_AUTH) {
+		RTW_INFO("RTW_Tx:tx_ch=%d, no_cck=%u, da="MAC_FMT"\n", tx_ch, no_cck, MAC_ARG(GetAddr1Ptr(buf)));
+		if (!rtw_sae_check_frames(padapter, buf, len, _TRUE))
+			RTW_INFO("RTW_Tx:AUTH\n");
+		dump_limit = 1;
+		goto dump;
+	}
+#endif
+
+	if (rtw_action_frame_parse(buf, len, &category, &action) == _FALSE) {
+		RTW_INFO(FUNC_ADPT_FMT" frame_control:0x%02x\n", FUNC_ADPT_ARG(padapter),
+			le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl));
+		goto exit;
+	}
+
+	RTW_INFO("RTW_Tx:tx_ch=%d, no_cck=%u, da="MAC_FMT"\n", tx_ch, no_cck, MAC_ARG(GetAddr1Ptr(buf)));
+#ifdef CONFIG_P2P
+	type = rtw_p2p_check_frames(padapter, buf, len, _TRUE);
+	if (type >= 0) {
+		is_p2p = 1;
+		no_cck = 1; /* force no CCK for P2P frames */
+		goto dump;
+	}
+#endif
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		type = rtw_mesh_check_frames_tx(padapter, &dump_buf, &dump_len);
+		if (type >= 0) {
+			dump_limit = 1;
+			goto dump;
+		}
+	}
+#endif
+	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
+		RTW_INFO("RTW_Tx:%s\n", action_public_str(action));
+		switch (action) {
+		case ACT_PUBLIC_GAS_INITIAL_REQ:
+		case ACT_PUBLIC_GAS_INITIAL_RSP:
+			sleep_ms = 50;
+			retry_guarantee_ms = RTW_MAX_MGMT_TX_MS_GAS;
+			break;
+		}
+	}
+#ifdef CONFIG_RTW_80211K
+	else if (category == RTW_WLAN_CATEGORY_RADIO_MEAS)
+		RTW_INFO("RTW_Tx: RRM Action\n");
+#endif
+	else
+		RTW_INFO("RTW_Tx:category(%u), action(%u)\n", category, action);
+
+dump:
+
+	rtw_ps_deny(padapter, PS_DENY_MGNT_TX);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EFAULT;
+		goto cancel_ps_deny;
+	}
+
+	while (1) {
+		dump_cnt++;
+
+		rtw_mi_set_scan_deny(padapter, 1000);
+		rtw_mi_scan_abort(padapter, _TRUE);
+		tx_ret = rtw_mgnt_tx_cmd(padapter, tx_ch, no_cck, dump_buf, dump_len, wait_ack, RTW_CMDF_WAIT_ACK);
+		if (tx_ret == _SUCCESS
+			|| (dump_cnt >= dump_limit && rtw_get_passing_time_ms(start) >= retry_guarantee_ms))
+			break;
+
+		if (sleep_ms > 0)
+			rtw_msleep_os(sleep_ms);
+	}
+
+	if (tx_ret != _SUCCESS || dump_cnt > 1) {
+		RTW_INFO(FUNC_ADPT_FMT" %s (%d/%d) in %d ms\n", FUNC_ADPT_ARG(padapter),
+			tx_ret == _SUCCESS ? "OK" : "FAIL", dump_cnt, dump_limit, rtw_get_passing_time_ms(start));
+	}
+
+#ifdef CONFIG_P2P
+	if (is_p2p) {
+		switch (type) {
+		case P2P_GO_NEGO_CONF:
+			if (0) {
+				RTW_INFO(FUNC_ADPT_FMT" Nego confirm. state=%u, status=%u, iaddr="MAC_FMT"\n"
+					, FUNC_ADPT_ARG(padapter), pwdev_priv->nego_info.state, pwdev_priv->nego_info.status
+					, MAC_ARG(pwdev_priv->nego_info.iface_addr));
+			}
+			if (pwdev_priv->nego_info.state == 2
+				&& pwdev_priv->nego_info.status == 0
+				&& rtw_check_invalid_mac_address(pwdev_priv->nego_info.iface_addr, _FALSE) == _FALSE
+			) {
+				_adapter *intended_iface = dvobj_get_adapter_by_addr(dvobj, pwdev_priv->nego_info.iface_addr);
+
+				if (intended_iface) {
+					RTW_INFO(FUNC_ADPT_FMT" Nego confirm. Allow only "ADPT_FMT" to scan for 2000 ms\n"
+						, FUNC_ADPT_ARG(padapter), ADPT_ARG(intended_iface));
+					/* allow only intended_iface to do scan for 2000 ms */
+					rtw_mi_set_scan_deny(padapter, 2000);
+					rtw_clear_scan_deny(intended_iface);
+				}
+			}
+			break;
+		case P2P_INVIT_RESP:
+			if (pwdev_priv->invit_info.flags & BIT(0)
+				&& pwdev_priv->invit_info.status == 0
+			) {
+				RTW_INFO(FUNC_ADPT_FMT" agree with invitation of persistent group\n",
+					FUNC_ADPT_ARG(padapter));
+				#if !RTW_P2P_GROUP_INTERFACE
+				rtw_mi_buddy_set_scan_deny(padapter, 5000);
+				#endif
+				rtw_pwr_wakeup_ex(padapter, 5000);
+			}
+			break;
+		}
+	}
+#endif /* CONFIG_P2P */
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_MGNT_TX);
+
+	if (dump_buf != buf)
+		rtw_mfree((u8 *)dump_buf, dump_len);
+exit:
+	return ret;
+}
+
+static void cfg80211_rtw_mgmt_frame_register(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+	u16 frame_type, bool reg)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct net_device *ndev = wdev_to_ndev(wdev);
+#endif
+	_adapter *adapter;
+
+	struct rtw_wdev_priv *pwdev_priv;
+
+	if (ndev == NULL)
+		goto exit;
+
+	adapter = (_adapter *)rtw_netdev_priv(ndev);
+	pwdev_priv = adapter_wdev_data(adapter);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO(FUNC_ADPT_FMT" frame_type:%x, reg:%d\n", FUNC_ADPT_ARG(adapter),
+		frame_type, reg);
+#endif
+
+	/* Wait QC Verify */
+	return;
+
+	switch (frame_type) {
+	case IEEE80211_STYPE_PROBE_REQ: /* 0x0040 */
+		SET_CFG80211_REPORT_MGMT(pwdev_priv, IEEE80211_STYPE_PROBE_REQ, reg);
+		break;
+	case IEEE80211_STYPE_ACTION: /* 0x00D0 */
+		SET_CFG80211_REPORT_MGMT(pwdev_priv, IEEE80211_STYPE_ACTION, reg);
+		break;
+	default:
+		break;
+	}
+
+exit:
+	return;
+}
+
+#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+static int cfg80211_rtw_tdls_mgmt(struct wiphy *wiphy,
+	struct net_device *ndev,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	const u8 *peer,
+#else
+	u8 *peer,
+#endif
+	u8 action_code,
+	u8 dialog_token,
+	u16 status_code,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	u32 peer_capability,
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 17, 0))
+	bool initiator,
+#endif
+	const u8 *buf,
+	size_t len)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &pmlmeext->mlmext_info;
+	int ret = 0;
+	struct tdls_txmgmt txmgmt;
+
+	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
+		RTW_INFO("Discard tdls action:%d, since hal doesn't support tdls\n", action_code);
+		goto discard;
+	}
+
+	if (rtw_is_tdls_enabled(padapter) == _FALSE) {
+		RTW_INFO("TDLS is not enabled\n");
+		goto discard;
+	}
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		RTW_INFO("Discard tdls action:%d, let driver to set up direct link\n", action_code);
+		goto discard;
+	}
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	_rtw_memcpy(txmgmt.peer, peer, ETH_ALEN);
+	txmgmt.action_code = action_code;
+	txmgmt.dialog_token = dialog_token;
+	txmgmt.status_code = status_code;
+	txmgmt.len = len;
+	txmgmt.buf = (u8 *)rtw_malloc(txmgmt.len);
+	if (txmgmt.buf == NULL) {
+		ret = -ENOMEM;
+		goto bad;
+	}
+	_rtw_memcpy(txmgmt.buf, (void *)buf, txmgmt.len);
+
+	/* Debug purpose */
+#if 1
+	RTW_INFO("%s %d\n", __FUNCTION__, __LINE__);
+	RTW_INFO("peer:"MAC_FMT", action code:%d, dialog:%d, status code:%d\n",
+		MAC_ARG(txmgmt.peer), txmgmt.action_code,
+		txmgmt.dialog_token, txmgmt.status_code);
+	if (txmgmt.len > 0) {
+		int i = 0;
+		for (; i < len; i++)
+			printk("%02x ", *(txmgmt.buf + i));
+		RTW_INFO("len:%d\n", (u32)txmgmt.len);
+	}
+#endif
+
+	switch (txmgmt.action_code) {
+	case TDLS_SETUP_REQUEST:
+		issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+		break;
+	case TDLS_SETUP_RESPONSE:
+		issue_tdls_setup_rsp(padapter, &txmgmt);
+		break;
+	case TDLS_SETUP_CONFIRM:
+		issue_tdls_setup_cfm(padapter, &txmgmt);
+		break;
+	case TDLS_TEARDOWN:
+		issue_tdls_teardown(padapter, &txmgmt, _TRUE);
+		break;
+	case TDLS_DISCOVERY_REQUEST:
+		issue_tdls_dis_req(padapter, &txmgmt);
+		break;
+	case TDLS_DISCOVERY_RESPONSE:
+		issue_tdls_dis_rsp(padapter, &txmgmt, pmlmeinfo->enc_algo ? _TRUE : _FALSE);
+		break;
+	}
+
+bad:
+	if (txmgmt.buf)
+		rtw_mfree(txmgmt.buf, txmgmt.len);
+
+discard:
+	return ret;
+}
+
+static int cfg80211_rtw_tdls_oper(struct wiphy *wiphy,
+	struct net_device *ndev,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	const u8 *peer,
+#else
+	u8 *peer,
+#endif
+	enum nl80211_tdls_operation oper)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct tdls_txmgmt	txmgmt;
+	struct sta_info *ptdls_sta = NULL;
+
+	RTW_INFO(FUNC_NDEV_FMT", nl80211_tdls_operation:%d\n", FUNC_NDEV_ARG(ndev), oper);
+
+	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
+		RTW_INFO("Discard tdls oper:%d, since hal doesn't support tdls\n", oper);
+		return 0;
+	}
+
+	if (rtw_is_tdls_enabled(padapter) == _FALSE) {
+		RTW_INFO("TDLS is not enabled\n");
+		return 0;
+	}
+
+#ifdef CONFIG_LPS
+	rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1);
+#endif /* CONFIG_LPS */
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	if (peer)
+		_rtw_memcpy(txmgmt.peer, peer, ETH_ALEN);
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		/* these two cases are done by driver itself */
+		if (oper == NL80211_TDLS_ENABLE_LINK || oper == NL80211_TDLS_DISABLE_LINK)
+			return 0;
+	}
+
+	switch (oper) {
+	case NL80211_TDLS_DISCOVERY_REQ:
+		issue_tdls_dis_req(padapter, &txmgmt);
+		break;
+	case NL80211_TDLS_SETUP:
+#ifdef CONFIG_WFD
+		if (_AES_ != padapter->securitypriv.dot11PrivacyAlgrthm) {
+			if (padapter->wdinfo.wfd_tdls_weaksec == _TRUE)
+				issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+			else
+				RTW_INFO("[%s] Current link is not AES, SKIP sending the tdls setup request!!\n", __FUNCTION__);
+		} else
+#endif /* CONFIG_WFD */
+		{
+			issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+		}
+		break;
+	case NL80211_TDLS_TEARDOWN:
+		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), txmgmt.peer);
+		if (ptdls_sta != NULL) {
+			txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
+			issue_tdls_teardown(padapter, &txmgmt, _TRUE);
+		} else
+			RTW_INFO("TDLS peer not found\n");
+		break;
+	case NL80211_TDLS_ENABLE_LINK:
+		RTW_INFO(FUNC_NDEV_FMT", NL80211_TDLS_ENABLE_LINK;mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(peer));
+		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), (u8 *)peer);
+		if (ptdls_sta != NULL) {
+			rtw_tdls_set_link_established(padapter, _TRUE);
+			ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
+			ptdls_sta->state |= _FW_LINKED;
+			rtw_tdls_cmd(padapter, txmgmt.peer, TDLS_ESTABLISHED);
+		}
+		break;
+	case NL80211_TDLS_DISABLE_LINK:
+		RTW_INFO(FUNC_NDEV_FMT", NL80211_TDLS_DISABLE_LINK;mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(peer));
+		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), (u8 *)peer);
+		if (ptdls_sta != NULL) {
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+			rtw_tdls_cmd(padapter, (u8 *)peer, TDLS_TEARDOWN_STA_LOCALLY_POST);
+		}
+		break;
+	}
+	return 0;
+}
+#endif /* CONFIG_TDLS */
+
+#if defined(CONFIG_RTW_MESH) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38))
+
+#if DBG_RTW_CFG80211_MESH_CONF
+#define LEGACY_RATES_STR_LEN (RTW_G_RATES_NUM * 5 + 1)
+int get_legacy_rates_str(struct wiphy *wiphy, enum nl80211_band band, u32 mask, char *buf)
+{
+	int i;
+	int cnt = 0;
+
+	for (i = 0; i < wiphy->bands[band]->n_bitrates; i++) {
+		if (mask & BIT(i)) {
+			cnt += snprintf(buf + cnt, LEGACY_RATES_STR_LEN - cnt -1, "%d.%d "
+				, wiphy->bands[band]->bitrates[i].bitrate / 10
+				, wiphy->bands[band]->bitrates[i].bitrate % 10);
+			if (cnt >= LEGACY_RATES_STR_LEN - 1)
+				break;
+		}
+	}
+
+	return cnt;
+}
+
+void dump_mesh_setup(void *sel, struct wiphy *wiphy, const struct mesh_setup *setup)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *chdef = (struct cfg80211_chan_def *)(&setup->chandef);
+#endif
+	struct ieee80211_channel *chan;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	chan = (struct ieee80211_channel *)chdef->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	chan = (struct ieee80211_channel *)setup->channel;
+#endif
+
+	RTW_PRINT_SEL(sel, "mesh_id:\"%s\", len:%u\n", setup->mesh_id, setup->mesh_id_len);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "sync_method:%u\n", setup->sync_method);
+#endif
+	RTW_PRINT_SEL(sel, "path_sel_proto:%u, path_metric:%u\n", setup->path_sel_proto, setup->path_metric);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	RTW_PRINT_SEL(sel, "auth_id:%u\n", setup->auth_id);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	if (setup->ie && setup->ie_len) {
+		RTW_PRINT_SEL(sel, "ie:%p, len:%u\n", setup->ie, setup->ie_len);
+		dump_ies(RTW_DBGDUMP, setup->ie, setup->ie_len);
+	}
+#else
+	if (setup->vendor_ie && setup->vendor_ie_len) {
+		RTW_PRINT_SEL(sel, "ie:%p, len:%u\n", setup->vendor_ie, setup->vendor_ie_len);
+		dump_ies(RTW_DBGDUMP, setup->vendor_ie, setup->vendor_ie_len);
+	}
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	RTW_PRINT_SEL(sel, "is_authenticated:%d, is_secure:%d\n", setup->is_authenticated, setup->is_secure);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	RTW_PRINT_SEL(sel, "user_mpm:%d\n", setup->user_mpm);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	RTW_PRINT_SEL(sel, "dtim_period:%u, beacon_interval:%u\n", setup->dtim_period, setup->beacon_interval);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	RTW_PRINT_SEL(sel, "center_freq:%u, ch:%u, width:%s, cfreq1:%u, cfreq2:%u\n"
+		, chan->center_freq, chan->hw_value, nl80211_chan_width_str(chdef->width), chdef->center_freq1, chdef->center_freq2);
+#else
+	RTW_PRINT_SEL(sel, "center_freq:%u, ch:%u, channel_type:%s\n"
+		, chan->center_freq, chan->hw_value, nl80211_channel_type_str(setup->channel_type));
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	if (setup->mcast_rate[chan->band]) {
+		RTW_PRINT_SEL(sel, "mcast_rate:%d.%d\n"
+			, wiphy->bands[chan->band]->bitrates[setup->mcast_rate[chan->band] - 1].bitrate / 10
+			, wiphy->bands[chan->band]->bitrates[setup->mcast_rate[chan->band] - 1].bitrate % 10
+		);
+	}
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (setup->basic_rates) {
+		char buf[LEGACY_RATES_STR_LEN] = {0};
+
+		get_legacy_rates_str(wiphy, chan->band, setup->basic_rates, buf);
+		RTW_PRINT_SEL(sel, "basic_rates:%s\n", buf);
+	}
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 9, 0))
+	if (setup->beacon_rate.control[chan->band].legacy) {
+		char buf[LEGACY_RATES_STR_LEN] = {0};
+
+		get_legacy_rates_str(wiphy, chan->band, setup->beacon_rate.control[chan->band].legacy, buf);
+		RTW_PRINT_SEL(sel, "beacon_rate.legacy:%s\n", buf);
+	}
+	if (*((u32 *)&(setup->beacon_rate.control[chan->band].ht_mcs[0]))
+		|| *((u32 *)&(setup->beacon_rate.control[chan->band].ht_mcs[4]))
+		|| *((u16 *)&(setup->beacon_rate.control[chan->band].ht_mcs[8]))
+	) {
+		RTW_PRINT_SEL(sel, "beacon_rate.ht_mcs:"HT_RX_MCS_BMP_FMT"\n"
+			, HT_RX_MCS_BMP_ARG(setup->beacon_rate.control[chan->band].ht_mcs));
+	}
+
+	if (setup->beacon_rate.control[chan->band].vht_mcs[0]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[1]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[2]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[3]
+	) {
+		int i;
+
+		for (i = 0; i < 4; i++) {/* parsing up to 4SS */
+			u16 mcs_mask = setup->beacon_rate.control[chan->band].vht_mcs[i];
+
+			RTW_PRINT_SEL(sel, "beacon_rate.vht_mcs[%d]:%s\n", i
+				, mcs_mask == 0x00FF ? "0~7" : mcs_mask == 0x01FF ? "0~8" : mcs_mask == 0x03FF ? "0~9" : "invalid");
+		}
+	}
+
+	if (setup->beacon_rate.control[chan->band].gi) {
+		RTW_PRINT_SEL(sel, "beacon_rate.gi:%s\n"
+			, setup->beacon_rate.control[chan->band].gi == NL80211_TXRATE_FORCE_SGI ? "SGI" :
+				setup->beacon_rate.control[chan->band].gi == NL80211_TXRATE_FORCE_LGI ? "LGI" : "invalid"
+		);
+	}
+#endif
+}
+
+void dump_mesh_config(void *sel, const struct mesh_config *conf)
+{
+	RTW_PRINT_SEL(sel, "dot11MeshRetryTimeout:%u\n", conf->dot11MeshRetryTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshConfirmTimeout:%u\n", conf->dot11MeshConfirmTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHoldingTimeout:%u\n", conf->dot11MeshHoldingTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshMaxPeerLinks:%u\n", conf->dot11MeshMaxPeerLinks);
+	RTW_PRINT_SEL(sel, "dot11MeshMaxRetries:%u\n", conf->dot11MeshMaxRetries);
+	RTW_PRINT_SEL(sel, "dot11MeshTTL:%u\n", conf->dot11MeshTTL);
+	RTW_PRINT_SEL(sel, "element_ttl:%u\n", conf->element_ttl);
+	RTW_PRINT_SEL(sel, "auto_open_plinks:%d\n", conf->auto_open_plinks);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshNbrOffsetMaxNeighbor:%u\n", conf->dot11MeshNbrOffsetMaxNeighbor);
+#endif
+
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPmaxPREQretries:%u\n", conf->dot11MeshHWMPmaxPREQretries);
+	RTW_PRINT_SEL(sel, "path_refresh_time:%u\n", conf->path_refresh_time);
+	RTW_PRINT_SEL(sel, "min_discovery_timeout:%u\n", conf->min_discovery_timeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPactivePathTimeout:%u\n", conf->dot11MeshHWMPactivePathTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPpreqMinInterval:%u\n", conf->dot11MeshHWMPpreqMinInterval);	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPperrMinInterval:%u\n", conf->dot11MeshHWMPperrMinInterval);
+#endif
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPnetDiameterTraversalTime:%u\n", conf->dot11MeshHWMPnetDiameterTraversalTime);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPRootMode:%u\n", conf->dot11MeshHWMPRootMode);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPRannInterval:%u\n", conf->dot11MeshHWMPRannInterval);
+	RTW_PRINT_SEL(sel, "dot11MeshGateAnnouncementProtocol:%d\n", conf->dot11MeshGateAnnouncementProtocol);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshForwarding:%d\n", conf->dot11MeshForwarding);
+	RTW_PRINT_SEL(sel, "rssi_threshold:%d\n", conf->rssi_threshold);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "ht_opmode:0x%04x\n", conf->ht_opmode);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPactivePathToRootTimeout:%u\n", conf->dot11MeshHWMPactivePathToRootTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMProotInterval:%u\n", conf->dot11MeshHWMProotInterval);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPconfirmationInterval:%u\n", conf->dot11MeshHWMPconfirmationInterval);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	RTW_PRINT_SEL(sel, "power_mode:%s\n", nl80211_mesh_power_mode_str(conf->power_mode));
+	RTW_PRINT_SEL(sel, "dot11MeshAwakeWindowDuration:%u\n", conf->dot11MeshAwakeWindowDuration);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	RTW_PRINT_SEL(sel, "plink_timeout:%u\n", conf->plink_timeout);
+#endif
+}
+#endif /* DBG_RTW_CFG80211_MESH_CONF */
+
+static void rtw_cfg80211_mesh_info_set_profile(struct rtw_mesh_info *minfo, const struct mesh_setup *setup)
+{
+	_rtw_memcpy(minfo->mesh_id, setup->mesh_id, setup->mesh_id_len);
+	minfo->mesh_id_len = setup->mesh_id_len;
+	minfo->mesh_pp_id = setup->path_sel_proto;
+	minfo->mesh_pm_id = setup->path_metric;
+	minfo->mesh_cc_id = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	minfo->mesh_sp_id = setup->sync_method;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	minfo->mesh_auth_id = setup->auth_id;
+#else
+	if (setup->is_authenticated) {
+		u8 *rsn_ie;
+		sint rsn_ie_len;
+		struct rsne_info info;
+		u8 *akm;
+		u8 AKM_SUITE_SAE[4] = {0x00, 0x0F, 0xAC, 0x08};
+
+		rsn_ie = rtw_get_ie(setup->ie, WLAN_EID_RSN, &rsn_ie_len, setup->ie_len);
+		if (!rsn_ie || !rsn_ie_len) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		if (rtw_rsne_info_parse(rsn_ie, rsn_ie_len + 2, &info) != _SUCCESS) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		if (!info.akm_list || !info.akm_cnt) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		akm = info.akm_list;
+		while (akm < info.akm_list + info.akm_cnt * 4) {
+			if (_rtw_memcmp(akm, AKM_SUITE_SAE, 4) == _TRUE) {
+				minfo->mesh_auth_id = 0x01;
+				break;
+			}
+		}
+
+		if (!minfo->mesh_auth_id) {
+			rtw_warn_on(1);
+			return;
+		}
+	}
+#endif
+}
+
+static inline bool chk_mesh_attr(enum nl80211_meshconf_params parm, u32 mask)
+{
+	return (mask >> (parm - 1)) & 0x1;
+}
+
+static void rtw_cfg80211_mesh_cfg_set(_adapter *adapter, const struct mesh_config *conf, u32 mask)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+#if 0 /* driver MPM */
+	if (chk_mesh_attr(NL80211_MESHCONF_RETRY_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_CONFIRM_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_HOLDING_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_MAX_PEER_LINKS, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_MAX_RETRIES, mask));
+#endif
+
+	if (chk_mesh_attr(NL80211_MESHCONF_TTL, mask))
+		mcfg->dot11MeshTTL = conf->dot11MeshTTL;
+	if (chk_mesh_attr(NL80211_MESHCONF_ELEMENT_TTL, mask))
+		mcfg->element_ttl = conf->element_ttl;
+
+#if 0 /* driver MPM */
+	if (chk_mesh_attr(NL80211_MESHCONF_AUTO_OPEN_PLINKS, mask));
+#endif
+
+#if 0 /* TBD: synchronization */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_SYNC_OFFSET_MAX_NEIGHBOR, mask));
+#endif
+#endif
+
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_MAX_PREQ_RETRIES, mask))
+		mcfg->dot11MeshHWMPmaxPREQretries = conf->dot11MeshHWMPmaxPREQretries;
+	if (chk_mesh_attr(NL80211_MESHCONF_PATH_REFRESH_TIME, mask))
+		mcfg->path_refresh_time = conf->path_refresh_time;
+	if (chk_mesh_attr(NL80211_MESHCONF_MIN_DISCOVERY_TIMEOUT, mask))
+		mcfg->min_discovery_timeout = conf->min_discovery_timeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ACTIVE_PATH_TIMEOUT, mask))
+		mcfg->dot11MeshHWMPactivePathTimeout = conf->dot11MeshHWMPactivePathTimeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PREQ_MIN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPpreqMinInterval = conf->dot11MeshHWMPpreqMinInterval;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PERR_MIN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPperrMinInterval = conf->dot11MeshHWMPperrMinInterval;
+#endif
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_NET_DIAM_TRVS_TIME, mask))
+		mcfg->dot11MeshHWMPnetDiameterTraversalTime = conf->dot11MeshHWMPnetDiameterTraversalTime;
+
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ROOTMODE, mask))
+		mcfg->dot11MeshHWMPRootMode = conf->dot11MeshHWMPRootMode;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_GATE_ANNOUNCEMENTS, mask))
+		mcfg->dot11MeshGateAnnouncementProtocol = conf->dot11MeshGateAnnouncementProtocol;
+	/* our current gate annc implementation rides on root annc with gate annc bit in PREQ flags */
+	if (mcfg->dot11MeshGateAnnouncementProtocol
+		&& mcfg->dot11MeshHWMPRootMode <= RTW_IEEE80211_ROOTMODE_ROOT
+	) {
+		mcfg->dot11MeshHWMPRootMode = RTW_IEEE80211_PROACTIVE_RANN;
+		RTW_INFO(ADPT_FMT" enable PROACTIVE_RANN becaue gate annc is needed\n", ADPT_ARG(adapter));
+	}
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_RANN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPRannInterval = conf->dot11MeshHWMPRannInterval;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_FORWARDING, mask))
+		mcfg->dot11MeshForwarding = conf->dot11MeshForwarding;
+
+	if (chk_mesh_attr(NL80211_MESHCONF_RSSI_THRESHOLD, mask))
+		mcfg->rssi_threshold = conf->rssi_threshold;
+#endif
+
+#if 0 /* controlled by driver */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HT_OPMODE, mask));
+#endif
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PATH_TO_ROOT_TIMEOUT, mask))
+		mcfg->dot11MeshHWMPactivePathToRootTimeout = conf->dot11MeshHWMPactivePathToRootTimeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ROOT_INTERVAL, mask))
+		mcfg->dot11MeshHWMProotInterval = conf->dot11MeshHWMProotInterval;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_CONFIRMATION_INTERVAL, mask))
+		mcfg->dot11MeshHWMPconfirmationInterval = conf->dot11MeshHWMPconfirmationInterval;	
+#endif
+
+#if 0 /* TBD */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_POWER_MODE, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_AWAKE_WINDOW, mask));
+#endif
+#endif
+
+#if 0 /* driver MPM */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_PLINK_TIMEOUT, mask));
+#endif
+#endif
+}
+
+u8 *rtw_cfg80211_construct_mesh_beacon_ies(struct wiphy *wiphy, _adapter *adapter
+	, const struct mesh_config *conf, const struct mesh_setup *setup
+	, uint *ies_len)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *chdef = (struct cfg80211_chan_def *)(&setup->chandef);
+#endif
+	struct ieee80211_channel *chan;
+	u8 ch, bw, offset;
+#endif
+	uint len;
+	u8 n_bitrates;
+	u8 ht = 0;
+	u8 vht = 0;
+	u8 *rsn_ie = NULL;
+	sint rsn_ie_len = 0;
+	u8 *ies = NULL, *c;
+	u8 supported_rates[RTW_G_RATES_NUM] = {0};
+	int i;
+
+	*ies_len = 0;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	chan = (struct ieee80211_channel *)chdef->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	chan = (struct ieee80211_channel *)setup->channel;
+#endif
+
+	n_bitrates = wiphy->bands[chan->band]->n_bitrates;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	rtw_get_chbw_from_cfg80211_chan_def(chdef, &ht, &ch, &bw, &offset);
+#else
+	rtw_get_chbw_from_nl80211_channel_type(chan, setup->channel_type, &ht, &ch, &bw, &offset);
+#endif
+	if (!ch)
+		goto exit;
+	
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	vht = ht && ch > 14 && bw >= CHANNEL_WIDTH_80; /* VHT40/VHT20? */
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT" => ch:%u,%u,%u, ht:%u, vht:%u\n"
+		, FUNC_ADPT_ARG(adapter), ch, bw, offset, ht, vht);
+#endif
+
+	rsn_ie = rtw_get_ie(setup->ie, WLAN_EID_RSN, &rsn_ie_len, setup->ie_len);
+	if (rsn_ie && !rsn_ie_len) {
+		rtw_warn_on(1);
+		rsn_ie = NULL;
+	}
+
+	len = _BEACON_IE_OFFSET_
+		+ 2 /* 0-length SSID */
+		+ (n_bitrates >= 8 ? 8 : n_bitrates) + 2 /* Supported Rates */
+		+ 3 /* DS parameter set */
+		+ 6 /* TIM  */
+		+ (n_bitrates > 8 ? n_bitrates - 8 + 2 : 0) /* Extended Supported Rates */
+		+ (rsn_ie ? rsn_ie_len + 2 : 0) /* RSN */
+		#if defined(CONFIG_80211N_HT)
+		+ (ht ? HT_CAP_IE_LEN + 2 + HT_OP_IE_LEN + 2 : 0) /* HT */
+		#endif
+		#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+		+ (vht ? VHT_CAP_IE_LEN + 2 + VHT_OP_IE_LEN + 2 : 0) /* VHT */
+		#endif
+		+ minfo->mesh_id_len + 2 /* Mesh ID */
+		+ 9 /* Mesh configuration */
+		;
+
+	ies = rtw_zmalloc(len);
+	if (!ies)
+		goto exit;
+
+	/* timestamp */
+	c = ies + 8;
+
+	/* beacon interval */
+	RTW_PUT_LE16(c , setup->beacon_interval);
+	c += 2;
+
+	/* capability */
+	if (rsn_ie)
+		*((u16 *)c) |= cpu_to_le16(cap_Privacy);
+	c += 2;
+
+	/* SSID */
+	c = rtw_set_ie(c, WLAN_EID_SSID, 0, NULL, NULL);
+
+	/* Supported Rates */
+	for (i = 0; i < n_bitrates; i++) {
+		supported_rates[i] = wiphy->bands[chan->band]->bitrates[i].bitrate / 5;
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+		if (setup->basic_rates & BIT(i))
+		#else
+		if (rtw_is_basic_rate_mix(supported_rates[i]))
+		#endif
+			supported_rates[i] |= IEEE80211_BASIC_RATE_MASK;
+	}
+	c = rtw_set_ie(c, WLAN_EID_SUPP_RATES, (n_bitrates >= 8 ? 8 : n_bitrates), supported_rates, NULL);
+
+	/* DS parameter set */
+	c = rtw_set_ie(c, WLAN_EID_DS_PARAMS, 1, &ch, NULL);
+
+	/* TIM */
+	*c = WLAN_EID_TIM;
+	*(c + 1) = 4;
+	c += 6;
+	//c = rtw_set_ie(c, _TIM_IE_, 4, NULL, NULL);
+
+	/* Extended Supported Rates */
+	if (n_bitrates > 8)
+		c = rtw_set_ie(c, WLAN_EID_EXT_SUPP_RATES, n_bitrates - 8, supported_rates + 8, NULL);
+
+	/* RSN */
+	if (rsn_ie)
+		c = rtw_set_ie(c, WLAN_EID_RSN, rsn_ie_len, rsn_ie + 2, NULL);
+
+#if defined(CONFIG_80211N_HT)
+	if (ht) {
+		struct ieee80211_sta_ht_cap *sta_ht_cap = &wiphy->bands[chan->band]->ht_cap;
+		u8 ht_cap[HT_CAP_IE_LEN];
+		u8 ht_op[HT_OP_IE_LEN];
+
+		_rtw_memset(ht_cap, 0, HT_CAP_IE_LEN);
+		_rtw_memset(ht_op, 0, HT_OP_IE_LEN);
+
+		/* WLAN_EID_HT_CAP */
+		RTW_PUT_LE16(HT_CAP_ELE_CAP_INFO(ht_cap), sta_ht_cap->cap);
+		SET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(ht_cap, sta_ht_cap->ampdu_factor);
+		SET_HT_CAP_ELE_MIN_MPDU_S_SPACE(ht_cap, sta_ht_cap->ampdu_density);
+		_rtw_memcpy(HT_CAP_ELE_SUP_MCS_SET(ht_cap), &sta_ht_cap->mcs, 16);
+		c = rtw_set_ie(c, WLAN_EID_HT_CAP, HT_CAP_IE_LEN, ht_cap, NULL);
+
+		/* WLAN_EID_HT_OPERATION */
+		SET_HT_OP_ELE_PRI_CHL(ht_op, ch);
+		switch (offset) {
+		case HAL_PRIME_CHNL_OFFSET_LOWER:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCA);
+			break;
+		case HAL_PRIME_CHNL_OFFSET_UPPER:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCB);
+			break;
+		case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
+		default:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCN);
+			break;
+		}
+		if (bw >= CHANNEL_WIDTH_40)
+			SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op, 1);
+		else
+			SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op, 0);
+		c = rtw_set_ie(c, WLAN_EID_HT_OPERATION, HT_OP_IE_LEN, ht_op, NULL);
+	}
+#endif /* defined(CONFIG_80211N_HT) */
+
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	if (vht) {
+		struct ieee80211_sta_vht_cap *sta_vht_cap = &wiphy->bands[chan->band]->vht_cap;
+		u8 vht_cap[VHT_CAP_IE_LEN];
+		u8 vht_op[VHT_OP_IE_LEN];
+		u8 cch = rtw_get_center_ch(ch, bw, offset);
+
+		_rtw_memset(vht_op, 0, VHT_OP_IE_LEN);
+
+		/* WLAN_EID_VHT_CAPABILITY */
+		_rtw_memcpy(vht_cap, &sta_vht_cap->cap, 4);
+		_rtw_memcpy(vht_cap + 4, &sta_vht_cap->vht_mcs, 8);
+		c = rtw_set_ie(c, WLAN_EID_VHT_CAPABILITY, VHT_CAP_IE_LEN, vht_cap, NULL);
+
+		/* WLAN_EID_VHT_OPERATION */
+		if (bw < CHANNEL_WIDTH_80) {
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op, 0);
+		} else if (bw == CHANNEL_WIDTH_80) {
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op, 1);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op, cch);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op, 0);
+		} else {
+			RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(adapter), bw);
+			rtw_warn_on(1);
+			rtw_mfree(ies, len);
+			goto exit;
+		}
+
+		/* Hard code 1 stream, MCS0-7 is a min Basic VHT MCS rates */
+		vht_op[3] = 0xfc;
+		vht_op[4] = 0xff;
+		c = rtw_set_ie(c, WLAN_EID_VHT_OPERATION, VHT_OP_IE_LEN, vht_op, NULL);
+	}
+#endif /* defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)) */
+
+	/* Mesh ID */
+	c = rtw_set_ie_mesh_id(c, NULL, minfo->mesh_id, minfo->mesh_id_len);
+
+	/* Mesh configuration */
+	c = rtw_set_ie_mesh_config(c, NULL
+		, minfo->mesh_pp_id
+		, minfo->mesh_pm_id
+		, minfo->mesh_cc_id
+		, minfo->mesh_sp_id
+		, minfo->mesh_auth_id
+		, 0, 0, 0
+		, 1
+		, 0, 0
+		, mcfg->dot11MeshForwarding
+		, 0, 0, 0
+	);
+
+#if DBG_RTW_CFG80211_MESH_CONF
+	RTW_INFO(FUNC_ADPT_FMT" ies_len:%u\n", FUNC_ADPT_ARG(adapter), len);
+	dump_ies(RTW_DBGDUMP, ies + _BEACON_IE_OFFSET_, len - _BEACON_IE_OFFSET_);
+#endif
+
+exit:
+	if (ies)
+		*ies_len = len;
+	return ies;
+}
+
+static int cfg80211_rtw_get_mesh_config(struct wiphy *wiphy, struct net_device *dev
+	, struct mesh_config *conf)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_cfg *mesh_cfg = &adapter->mesh_cfg;
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+	/* driver MPM */
+	conf->dot11MeshRetryTimeout = 0;
+	conf->dot11MeshConfirmTimeout = 0;
+	conf->dot11MeshHoldingTimeout = 0;
+	conf->dot11MeshMaxPeerLinks = mesh_cfg->max_peer_links;
+	conf->dot11MeshMaxRetries = 0;
+
+	conf->dot11MeshTTL = mesh_cfg->dot11MeshTTL;
+	conf->element_ttl = mesh_cfg->element_ttl;
+
+	/* driver MPM */
+	conf->auto_open_plinks = 0;
+
+	/* TBD: synchronization */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	conf->dot11MeshNbrOffsetMaxNeighbor = 0;
+#endif
+
+	conf->dot11MeshHWMPmaxPREQretries = mesh_cfg->dot11MeshHWMPmaxPREQretries;
+	conf->path_refresh_time = mesh_cfg->path_refresh_time;
+	conf->min_discovery_timeout = mesh_cfg->min_discovery_timeout;
+	conf->dot11MeshHWMPactivePathTimeout = mesh_cfg->dot11MeshHWMPactivePathTimeout;
+	conf->dot11MeshHWMPpreqMinInterval = mesh_cfg->dot11MeshHWMPpreqMinInterval;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	conf->dot11MeshHWMPperrMinInterval = mesh_cfg->dot11MeshHWMPperrMinInterval;
+#endif
+	conf->dot11MeshHWMPnetDiameterTraversalTime = mesh_cfg->dot11MeshHWMPnetDiameterTraversalTime;
+	conf->dot11MeshHWMPRootMode = mesh_cfg->dot11MeshHWMPRootMode;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	conf->dot11MeshHWMPRannInterval = mesh_cfg->dot11MeshHWMPRannInterval;
+#endif
+	conf->dot11MeshGateAnnouncementProtocol = mesh_cfg->dot11MeshGateAnnouncementProtocol;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	conf->dot11MeshForwarding = mesh_cfg->dot11MeshForwarding;
+	conf->rssi_threshold = mesh_cfg->rssi_threshold;
+#endif
+
+	/* TBD */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	conf->ht_opmode = 0xffff;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	conf->dot11MeshHWMPactivePathToRootTimeout = mesh_cfg->dot11MeshHWMPactivePathToRootTimeout;
+	conf->dot11MeshHWMProotInterval = mesh_cfg->dot11MeshHWMProotInterval;
+	conf->dot11MeshHWMPconfirmationInterval = mesh_cfg->dot11MeshHWMPconfirmationInterval;
+#endif
+
+	/* TBD: power save */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	conf->power_mode = NL80211_MESH_POWER_ACTIVE;
+	conf->dot11MeshAwakeWindowDuration = 0;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	conf->plink_timeout = mesh_cfg->plink_timeout;
+#endif
+
+	return ret;
+}
+
+static void rtw_mbss_info_change_notify(_adapter *adapter, bool minfo_changed, bool need_work)
+{
+	if (need_work)
+		rtw_mesh_work(&adapter->mesh_work);
+}
+
+static int cfg80211_rtw_update_mesh_config(struct wiphy *wiphy, struct net_device *dev
+	, u32 mask, const struct mesh_config *nconf)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+	bool minfo_changed = _FALSE, need_work = _FALSE;
+
+	RTW_INFO(FUNC_ADPT_FMT" mask:0x%08x\n", FUNC_ADPT_ARG(adapter), mask);
+
+	rtw_cfg80211_mesh_cfg_set(adapter, nconf, mask);
+	update_beacon(adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE);
+	need_work = rtw_ieee80211_mesh_root_setup(adapter);
+
+	rtw_mbss_info_change_notify(adapter, minfo_changed, need_work);
+
+	return ret;
+}
+
+static int cfg80211_rtw_join_mesh(struct wiphy *wiphy, struct net_device *dev,
+	const struct mesh_config *conf, const struct mesh_setup *setup)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 *ies = NULL;
+	uint ies_len;
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+#if DBG_RTW_CFG80211_MESH_CONF
+	RTW_INFO(FUNC_ADPT_FMT" mesh_setup:\n", FUNC_ADPT_ARG(adapter));
+	dump_mesh_setup(RTW_DBGDUMP, wiphy, setup);
+	RTW_INFO(FUNC_ADPT_FMT" mesh_config:\n", FUNC_ADPT_ARG(adapter));
+	dump_mesh_config(RTW_DBGDUMP, conf);
+#endif
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+
+	/* initialization */
+	rtw_mesh_init_mesh_info(adapter);
+
+	/* apply cfg80211 settings*/
+	rtw_cfg80211_mesh_info_set_profile(&adapter->mesh_info, setup);
+	rtw_cfg80211_mesh_cfg_set(adapter, conf, 0xFFFFFFFF);
+
+	/* apply cfg80211 settings (join only) */
+	rtw_mesh_cfg_init_max_peer_links(adapter, conf->dot11MeshMaxPeerLinks);
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	rtw_mesh_cfg_init_plink_timeout(adapter, conf->plink_timeout);
+	#endif
+
+	rtw_ieee80211_mesh_root_setup(adapter);
+
+	ies = rtw_cfg80211_construct_mesh_beacon_ies(wiphy, adapter, conf, setup, &ies_len);
+	if (!ies) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	/* start mbss */
+	if (rtw_check_beacon_data(adapter, ies,  ies_len) != _SUCCESS) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	
+	rtw_mesh_work(&adapter->mesh_work);
+
+exit:
+	if (ies)
+		rtw_mfree(ies, ies_len);
+	if (ret)
+		rtw_mesh_deinit_mesh_info(adapter);
+
+	return ret;
+}
+
+static int cfg80211_rtw_leave_mesh(struct wiphy *wiphy, struct net_device *dev)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+	rtw_mesh_deinit_mesh_info(adapter);
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
+	return ret;
+}
+
+static int cfg80211_rtw_add_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst, const u8 *next_hop
+	#else
+	, u8 *dst, u8 *next_hop
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	sta = rtw_get_stainfo(stapriv, next_hop);
+	if (!sta) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	mpath = rtw_mesh_path_add(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_mesh_path_fix_nexthop(mpath, sta);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_del_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst
+	#else
+	, u8 *dst
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+
+	if (dst) {
+		if (rtw_mesh_path_del(adapter, dst)) {
+			ret = -ENOENT;
+			goto exit;
+		}
+	} else {
+		rtw_mesh_path_flush_by_iface(adapter);
+	}	
+
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_change_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst, const u8 *next_hop
+	#else
+	, u8 *dst, u8 *next_hop
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	sta = rtw_get_stainfo(stapriv, next_hop);
+	if (!sta) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	mpath = rtw_mesh_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_mesh_path_fix_nexthop(mpath, sta);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static void rtw_cfg80211_mpath_set_pinfo(struct rtw_mesh_path *mpath, u8 *next_hop, struct mpath_info *pinfo)
+{
+	struct sta_info *next_hop_sta = rtw_rcu_dereference(mpath->next_hop);
+
+	if (next_hop_sta)
+		_rtw_memcpy(next_hop, next_hop_sta->cmn.mac_addr, ETH_ALEN);
+	else
+		_rtw_memset(next_hop, 0, ETH_ALEN);
+
+	_rtw_memset(pinfo, 0, sizeof(*pinfo));
+
+	pinfo->generation = mpath->adapter->mesh_info.mesh_paths_generation;
+
+	pinfo->filled = 0
+		| MPATH_INFO_FRAME_QLEN
+		| MPATH_INFO_SN
+		| MPATH_INFO_METRIC
+		| MPATH_INFO_EXPTIME
+		| MPATH_INFO_DISCOVERY_TIMEOUT
+		| MPATH_INFO_DISCOVERY_RETRIES
+		| MPATH_INFO_FLAGS
+		;
+
+	pinfo->frame_qlen = mpath->frame_queue_len;
+	pinfo->sn = mpath->sn;
+	pinfo->metric = mpath->metric;
+	if (rtw_time_after(mpath->exp_time, rtw_get_current_time()))
+		pinfo->exptime = rtw_get_remaining_time_ms(mpath->exp_time);
+	pinfo->discovery_timeout = rtw_systime_to_ms(mpath->discovery_timeout);
+	pinfo->discovery_retries = mpath->discovery_retries;
+	if (mpath->flags & RTW_MESH_PATH_ACTIVE)
+		pinfo->flags |= NL80211_MPATH_FLAG_ACTIVE;
+	if (mpath->flags & RTW_MESH_PATH_RESOLVING)
+		pinfo->flags |= NL80211_MPATH_FLAG_RESOLVING;
+	if (mpath->flags & RTW_MESH_PATH_SN_VALID)
+		pinfo->flags |= NL80211_MPATH_FLAG_SN_VALID;
+	if (mpath->flags & RTW_MESH_PATH_FIXED)
+		pinfo->flags |= NL80211_MPATH_FLAG_FIXED;
+	if (mpath->flags & RTW_MESH_PATH_RESOLVED)
+		pinfo->flags |= NL80211_MPATH_FLAG_RESOLVED;
+}
+
+static int cfg80211_rtw_get_mpath(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mesh_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_cfg80211_mpath_set_pinfo(mpath, next_hop, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_dump_mpath(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mesh_path_lookup_by_idx(adapter, idx);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+	rtw_cfg80211_mpath_set_pinfo(mpath, next_hop, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+static void rtw_cfg80211_mpp_set_pinfo(struct rtw_mesh_path *mpath, u8 *mpp, struct mpath_info *pinfo)
+{
+	_rtw_memcpy(mpp, mpath->mpp, ETH_ALEN);
+
+	_rtw_memset(pinfo, 0, sizeof(*pinfo));
+	pinfo->generation = mpath->adapter->mesh_info.mpp_paths_generation;
+}
+
+static int cfg80211_rtw_get_mpp(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mpp_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_cfg80211_mpp_set_pinfo(mpath, mpp, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_dump_mpp(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mpp_path_lookup_by_idx(adapter, idx);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+	rtw_cfg80211_mpp_set_pinfo(mpath, mpp, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0)) */
+
+#endif /* defined(CONFIG_RTW_MESH) */
+
+#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+static int cfg80211_rtw_sched_scan_start(struct wiphy *wiphy,
+		struct net_device *dev,
+		struct cfg80211_sched_scan_request *request)
+{
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct cfg80211_ssid *ssids;
+	int n_ssids = 0;
+	int interval = 0;
+	int i = 0;
+	u8 ret;
+
+	if (padapter->bup == _FALSE) {
+		RTW_INFO("%s: net device is down.\n", __func__);
+		return -EIO;
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE ||
+		check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE  ||
+		check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("%s: device is busy.\n", __func__);
+		rtw_scan_abort(padapter);
+	}
+
+	if (request == NULL) {
+		RTW_INFO("%s: invalid cfg80211_requests parameters.\n", __func__);
+		return -EINVAL;
+	}
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
+	interval = request->interval;
+	n_ssids = request->n_match_sets;
+	ssids = (struct cfg80211_ssid *)rtw_zmalloc(n_ssids * sizeof(struct cfg80211_ssid));
+	if(ssids == NULL) {
+		RTW_ERR("Fail to allocate ssids for PNO\n");
+		return -ENOMEM;
+	}
+	for (i=0;i<request->n_match_sets;i++) {
+			ssids[i].ssid_len = request->match_sets[i].ssid.ssid_len;
+			memcpy(ssids[i].ssid, request->match_sets[i].ssid.ssid,
+					request->match_sets[i].ssid.ssid_len);
+	}
+#else
+	interval = request->interval;
+	n_ssids = request->n_ssids;
+	ssids = request->ssids;
+#endif
+ret = rtw_android_cfg80211_pno_setup(dev, ssids,
+			n_ssids, interval);
+	if (ret < 0) {
+		RTW_INFO("%s ret: %d\n", __func__, ret);
+		goto exit;
+	}
+
+	ret = rtw_android_pno_enable(dev, _TRUE);
+	if (ret < 0) {
+		RTW_INFO("%s ret: %d\n", __func__, ret);
+		goto exit;
+	}
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_sched_scan_stop(struct wiphy *wiphy,
+		struct net_device *dev)
+{
+	return rtw_android_pno_enable(dev, _FALSE);
+}
+
+int	cfg80211_rtw_suspend(struct wiphy *wiphy, struct cfg80211_wowlan *wow) {
+	RTW_DBG("==> %s\n",__func__);
+	RTW_DBG("<== %s\n",__func__);
+	return 0;
+}
+
+int	cfg80211_rtw_resume(struct wiphy *wiphy) {
+
+	_adapter *padapter;
+	struct pwrctrl_priv *pwrpriv;
+	struct mlme_priv *pmlmepriv;
+	padapter = wiphy_to_adapter(wiphy);
+	pwrpriv = adapter_to_pwrctl(padapter);
+	pmlmepriv = &padapter->mlmepriv;
+	struct sitesurvey_parm parm;
+	int i, len;
+
+
+	RTW_DBG("==> %s\n",__func__);
+	if (pwrpriv->wowlan_last_wake_reason == RX_PNO) {
+
+		struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+		_irqL irqL;
+		int PNOWakeupScanWaitCnt = 0;
+
+		rtw_cfg80211_disconnected(padapter->rtw_wdev, 0, NULL, 0, 1, GFP_ATOMIC);
+
+		rtw_init_sitesurvey_parm(padapter, &parm);
+		for (i=0;i<pwrpriv->pnlo_info->ssid_num && i < RTW_SSID_SCAN_AMOUNT; i++) {
+			len = pwrpriv->pno_ssid_list->node[i].SSID_len;
+			_rtw_memcpy(&parm.ssid[i].Ssid, pwrpriv->pno_ssid_list->node[i].SSID, len);
+			parm->ssid[i].SsidLength = len;
+		}
+		prm->ssid_num = pwrpriv->pnlo_info->ssid_num;
+
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		//This modification fix PNO wakeup reconnect issue with hidden SSID AP.
+		//rtw_sitesurvey_cmd(padapter, NULL);
+		rtw_sitesurvey_cmd(padapter, &parm);
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+		
+		for (PNOWakeupScanWaitCnt = 0; PNOWakeupScanWaitCnt < 10; PNOWakeupScanWaitCnt++) {
+			if(check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _FALSE)
+				break;
+			rtw_msleep_os(1000);
+		}
+		
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		cfg80211_sched_scan_results(padapter->rtw_wdev->wiphy);
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+
+	}
+	RTW_DBG("<== %s\n",__func__);
+	return 0;
+	
+}
+#endif /* CONFIG_PNO_SUPPORT */
+
+static int rtw_cfg80211_set_beacon_wpsp2pie(struct net_device *ndev, char *buf, int len)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u8 *wps_ie;
+	u32	p2p_ielen = 0;
+	u8 wps_oui[8] = {0x0, 0x50, 0xf2, 0x04};
+	u8 *p2p_ie;
+	u32	wfd_ielen = 0;
+	u8 *wfd_ie;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+
+	RTW_INFO(FUNC_NDEV_FMT" ielen=%d\n", FUNC_NDEV_ARG(ndev), len);
+
+	if (len > 0) {
+		wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen);
+		if (wps_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("bcn_wps_ielen=%d\n", wps_ielen);
+			#endif
+
+			if (pmlmepriv->wps_beacon_ie) {
+				u32 free_len = pmlmepriv->wps_beacon_ie_len;
+				pmlmepriv->wps_beacon_ie_len = 0;
+				rtw_mfree(pmlmepriv->wps_beacon_ie, free_len);
+				pmlmepriv->wps_beacon_ie = NULL;
+			}
+
+			pmlmepriv->wps_beacon_ie = rtw_malloc(wps_ielen);
+			if (pmlmepriv->wps_beacon_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+
+			_rtw_memcpy(pmlmepriv->wps_beacon_ie, wps_ie, wps_ielen);
+			pmlmepriv->wps_beacon_ie_len = wps_ielen;
+
+			update_beacon(padapter, _VENDOR_SPECIFIC_IE_, wps_oui, _TRUE);
+
+		}
+
+		/* buf += wps_ielen; */
+		/* len -= wps_ielen; */
+
+		#ifdef CONFIG_P2P
+		p2p_ie = rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("bcn_p2p_ielen=%d\n", p2p_ielen);
+			#endif
+
+			if (pmlmepriv->p2p_beacon_ie) {
+				u32 free_len = pmlmepriv->p2p_beacon_ie_len;
+				pmlmepriv->p2p_beacon_ie_len = 0;
+				rtw_mfree(pmlmepriv->p2p_beacon_ie, free_len);
+				pmlmepriv->p2p_beacon_ie = NULL;
+			}
+
+			pmlmepriv->p2p_beacon_ie = rtw_malloc(p2p_ielen);
+			if (pmlmepriv->p2p_beacon_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+
+			_rtw_memcpy(pmlmepriv->p2p_beacon_ie, p2p_ie, p2p_ielen);
+			pmlmepriv->p2p_beacon_ie_len = p2p_ielen;
+
+		}
+		#endif /* CONFIG_P2P */
+
+
+		#ifdef CONFIG_WFD
+		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("bcn_wfd_ielen=%d\n", wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_BEACON_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				return -EINVAL;
+		}
+		#endif /* CONFIG_WFD */
+
+		pmlmeext->bstart_bss = _TRUE;
+
+	}
+
+	return ret;
+
+}
+
+static int rtw_cfg80211_set_probe_resp_wpsp2pie(struct net_device *net, char *buf, int len)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u8 *wps_ie;
+	u32	p2p_ielen = 0;
+	u8 *p2p_ie;
+	u32	wfd_ielen = 0;
+	u8 *wfd_ie;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+#endif
+
+	if (len > 0) {
+		wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen);
+		if (wps_ie) {
+			uint	attr_contentlen = 0;
+			u16	uconfig_method, *puconfig_method = NULL;
+
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_resp_wps_ielen=%d\n", wps_ielen);
+			#endif
+
+			if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+				u8 sr = 0;
+				rtw_get_wps_attr_content(wps_ie,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
+
+				if (sr != 0)
+					RTW_INFO("%s, got sr\n", __func__);
+				else {
+					RTW_INFO("GO mode process WPS under site-survey,  sr no set\n");
+					return ret;
+				}
+			}
+
+			if (pmlmepriv->wps_probe_resp_ie) {
+				u32 free_len = pmlmepriv->wps_probe_resp_ie_len;
+				pmlmepriv->wps_probe_resp_ie_len = 0;
+				rtw_mfree(pmlmepriv->wps_probe_resp_ie, free_len);
+				pmlmepriv->wps_probe_resp_ie = NULL;
+			}
+
+			pmlmepriv->wps_probe_resp_ie = rtw_malloc(wps_ielen);
+			if (pmlmepriv->wps_probe_resp_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+
+			/* add PUSH_BUTTON config_method by driver self in wpsie of probe_resp at GO Mode */
+			puconfig_method = (u16 *)rtw_get_wps_attr_content(wps_ie, wps_ielen, WPS_ATTR_CONF_METHOD , NULL, &attr_contentlen);
+			if (puconfig_method != NULL) {
+				/* struct registry_priv *pregistrypriv = &padapter->registrypriv; */
+				struct wireless_dev *wdev = padapter->rtw_wdev;
+
+				#ifdef CONFIG_DEBUG_CFG80211
+				/* printk("config_method in wpsie of probe_resp = 0x%x\n", be16_to_cpu(*puconfig_method)); */
+				#endif
+
+				#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+				/* for WIFI-DIRECT LOGO 4.2.2, AUTO GO can't set PUSH_BUTTON flags */
+				if (wdev->iftype == NL80211_IFTYPE_P2P_GO) {
+					uconfig_method = WPS_CM_PUSH_BUTTON;
+					uconfig_method = cpu_to_be16(uconfig_method);
+
+					*puconfig_method &= ~uconfig_method;
+				}
+				#endif
+			}
+
+			_rtw_memcpy(pmlmepriv->wps_probe_resp_ie, wps_ie, wps_ielen);
+			pmlmepriv->wps_probe_resp_ie_len = wps_ielen;
+
+		}
+
+		/* buf += wps_ielen; */
+		/* len -= wps_ielen; */
+
+		#ifdef CONFIG_P2P
+		p2p_ie = rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			u8 is_GO = _FALSE;
+			u32 attr_contentlen = 0;
+			u16 cap_attr = 0;
+
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_resp_p2p_ielen=%d\n", p2p_ielen);
+			#endif
+
+			/* Check P2P Capability ATTR */
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *) &attr_contentlen)) {
+				u8 grp_cap = 0;
+				/* RTW_INFO( "[%s] Got P2P Capability Attr!!\n", __FUNCTION__ ); */
+				cap_attr = le16_to_cpu(cap_attr);
+				grp_cap = (u8)((cap_attr >> 8) & 0xff);
+
+				is_GO = (grp_cap & BIT(0)) ? _TRUE : _FALSE;
+
+				if (is_GO)
+					RTW_INFO("Got P2P Capability Attr, grp_cap=0x%x, is_GO\n", grp_cap);
+			}
+
+
+			if (is_GO == _FALSE) {
+				if (pmlmepriv->p2p_probe_resp_ie) {
+					u32 free_len = pmlmepriv->p2p_probe_resp_ie_len;
+					pmlmepriv->p2p_probe_resp_ie_len = 0;
+					rtw_mfree(pmlmepriv->p2p_probe_resp_ie, free_len);
+					pmlmepriv->p2p_probe_resp_ie = NULL;
+				}
+
+				pmlmepriv->p2p_probe_resp_ie = rtw_malloc(p2p_ielen);
+				if (pmlmepriv->p2p_probe_resp_ie == NULL) {
+					RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+					return -EINVAL;
+
+				}
+				_rtw_memcpy(pmlmepriv->p2p_probe_resp_ie, p2p_ie, p2p_ielen);
+				pmlmepriv->p2p_probe_resp_ie_len = p2p_ielen;
+			} else {
+				if (pmlmepriv->p2p_go_probe_resp_ie) {
+					u32 free_len = pmlmepriv->p2p_go_probe_resp_ie_len;
+					pmlmepriv->p2p_go_probe_resp_ie_len = 0;
+					rtw_mfree(pmlmepriv->p2p_go_probe_resp_ie, free_len);
+					pmlmepriv->p2p_go_probe_resp_ie = NULL;
+				}
+
+				pmlmepriv->p2p_go_probe_resp_ie = rtw_malloc(p2p_ielen);
+				if (pmlmepriv->p2p_go_probe_resp_ie == NULL) {
+					RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+					return -EINVAL;
+
+				}
+				_rtw_memcpy(pmlmepriv->p2p_go_probe_resp_ie, p2p_ie, p2p_ielen);
+				pmlmepriv->p2p_go_probe_resp_ie_len = p2p_ielen;
+			}
+
+		}
+		#endif /* CONFIG_P2P */
+
+
+		#ifdef CONFIG_WFD
+		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_resp_wfd_ielen=%d\n", wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_PROBE_RESP_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				return -EINVAL;
+		}
+		#endif /* CONFIG_WFD */
+
+	}
+
+	return ret;
+
+}
+
+static int rtw_cfg80211_set_assoc_resp_wpsp2pie(struct net_device *net, char *buf, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u8 *ie;
+	u32 ie_len;
+
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+
+	if (len <= 0)
+		goto exit;
+
+	ie = rtw_get_wps_ie(buf, len, NULL, &ie_len);
+	if (ie && ie_len) {
+		if (pmlmepriv->wps_assoc_resp_ie) {
+			u32 free_len = pmlmepriv->wps_assoc_resp_ie_len;
+
+			pmlmepriv->wps_assoc_resp_ie_len = 0;
+			rtw_mfree(pmlmepriv->wps_assoc_resp_ie, free_len);
+			pmlmepriv->wps_assoc_resp_ie = NULL;
+		}
+
+		pmlmepriv->wps_assoc_resp_ie = rtw_malloc(ie_len);
+		if (pmlmepriv->wps_assoc_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+			return -EINVAL;
+		}
+		_rtw_memcpy(pmlmepriv->wps_assoc_resp_ie, ie, ie_len);
+		pmlmepriv->wps_assoc_resp_ie_len = ie_len;
+	}
+
+	ie = rtw_get_p2p_ie(buf, len, NULL, &ie_len);
+	if (ie && ie_len) {
+		if (pmlmepriv->p2p_assoc_resp_ie) {
+			u32 free_len = pmlmepriv->p2p_assoc_resp_ie_len;
+
+			pmlmepriv->p2p_assoc_resp_ie_len = 0;
+			rtw_mfree(pmlmepriv->p2p_assoc_resp_ie, free_len);
+			pmlmepriv->p2p_assoc_resp_ie = NULL;
+		}
+
+		pmlmepriv->p2p_assoc_resp_ie = rtw_malloc(ie_len);
+		if (pmlmepriv->p2p_assoc_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+			return -EINVAL;
+		}
+		_rtw_memcpy(pmlmepriv->p2p_assoc_resp_ie, ie, ie_len);
+		pmlmepriv->p2p_assoc_resp_ie_len = ie_len;
+	}
+
+#ifdef CONFIG_WFD
+	ie = rtw_get_wfd_ie(buf, len, NULL, &ie_len);
+	if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_ASSOC_RESP_IE, ie, ie_len) != _SUCCESS)
+		return -EINVAL;
+#endif
+
+exit:
+	return ret;
+}
+
+int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len,
+	int type)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u32	p2p_ielen = 0;
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+#endif
+
+	if ((rtw_get_wps_ie(buf, len, NULL, &wps_ielen) && (wps_ielen > 0))
+		#ifdef CONFIG_P2P
+		|| (rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen) && (p2p_ielen > 0))
+		#endif
+	) {
+		if (net != NULL) {
+			switch (type) {
+			case 0x1: /* BEACON */
+				ret = rtw_cfg80211_set_beacon_wpsp2pie(net, buf, len);
+				break;
+			case 0x2: /* PROBE_RESP */
+				ret = rtw_cfg80211_set_probe_resp_wpsp2pie(net, buf, len);
+				#ifdef CONFIG_P2P
+				if (ret == 0)
+					adapter_wdev_data((_adapter *)rtw_netdev_priv(net))->probe_resp_ie_update_time = rtw_get_current_time();
+				#endif
+				break;
+			case 0x4: /* ASSOC_RESP */
+				ret = rtw_cfg80211_set_assoc_resp_wpsp2pie(net, buf, len);
+				break;
+			}
+		}
+	}
+
+	return ret;
+
+}
+
+#ifdef CONFIG_80211N_HT
+static void rtw_cfg80211_init_ht_capab_ex(_adapter *padapter
+	, struct ieee80211_sta_ht_cap *ht_cap, BAND_TYPE band, u8 rf_type)
+{
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
+	u8 stbc_rx_enable = _FALSE;
+
+	rtw_ht_use_default_setting(padapter);
+
+	/* RX LDPC */
+	if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX))
+		ht_cap->cap |= IEEE80211_HT_CAP_LDPC_CODING;
+
+	/* TX STBC */
+	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX))
+		ht_cap->cap |= IEEE80211_HT_CAP_TX_STBC;
+
+	/* RX STBC */
+	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX)) {
+		/*rtw_rx_stbc 0: disable, bit(0):enable 2.4g, bit(1):enable 5g*/
+		if (band == BAND_ON_2_4G)
+			stbc_rx_enable = (pregistrypriv->rx_stbc & BIT(0)) ? _TRUE : _FALSE;
+		if (band == BAND_ON_5G)
+			stbc_rx_enable = (pregistrypriv->rx_stbc & BIT(1)) ? _TRUE : _FALSE;
+
+		if (stbc_rx_enable) {
+			switch (rf_type) {
+			case RF_1T1R:
+				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/*RX STBC One spatial stream*/
+				break;
+
+			case RF_2T2R:
+			case RF_1T2R:
+				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/* Only one spatial-stream STBC RX is supported */
+				break;
+			case RF_3T3R:
+			case RF_3T4R:
+			case RF_4T4R:
+				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/* Only one spatial-stream STBC RX is supported */
+				break;
+			default:
+				RTW_INFO("[warning] rf_type %d is not expected\n", rf_type);
+				break;
+			}
+		}
+	}
+}
+
+static void rtw_cfg80211_init_ht_capab(_adapter *padapter
+	, struct ieee80211_sta_ht_cap *ht_cap, BAND_TYPE band, u8 rf_type)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	u8 rx_nss = 0;
+
+	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;
+	rtw_cfg80211_init_ht_capab_ex(padapter, ht_cap, band, rf_type);
+
+	/*
+	 *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;
+
+	rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
+	switch (rx_nss) {
+	case 1:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		break;
+	case 2:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		ht_cap->mcs.rx_mask[1] = 0xFF;
+		break;
+	case 3:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		ht_cap->mcs.rx_mask[1] = 0xFF;
+		ht_cap->mcs.rx_mask[2] = 0xFF;
+		break;
+	case 4:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		ht_cap->mcs.rx_mask[1] = 0xFF;
+		ht_cap->mcs.rx_mask[2] = 0xFF;
+		ht_cap->mcs.rx_mask[3] = 0xFF;
+		break;
+	default:
+		rtw_warn_on(1);
+		RTW_INFO("%s, error rf_type=%d\n", __func__, rf_type);
+	};
+
+	ht_cap->mcs.rx_highest = cpu_to_le16(
+		rtw_mcs_rate(rf_type
+			, hal_is_bw_support(padapter, CHANNEL_WIDTH_40)
+			, hal_is_bw_support(padapter, CHANNEL_WIDTH_40) ? ht_cap->cap & IEEE80211_HT_CAP_SGI_40 : ht_cap->cap & IEEE80211_HT_CAP_SGI_20
+			, ht_cap->mcs.rx_mask) / 10);
+}
+#endif /* CONFIG_80211N_HT */
+
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+static void rtw_cfg80211_init_vht_capab(_adapter *padapter
+	, struct ieee80211_sta_vht_cap *sta_vht_cap, BAND_TYPE band, u8 rf_type)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	struct registry_priv *regsty = &padapter->registrypriv;
+	struct vht_priv *vhtpriv = &padapter->mlmepriv.vhtpriv;
+	u8 vht_cap_ie[2 + 12] = {0};
+	u8 bw;
+
+	if (!REGSTY_IS_11AC_ENABLE(regsty)
+		|| !hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	) {
+		sta_vht_cap->vht_supported = 0;
+		return;
+	}
+
+	rtw_vht_use_default_setting(padapter);
+	rtw_build_vht_cap_ie(padapter, vht_cap_ie);
+
+	sta_vht_cap->vht_supported = 1;
+
+	_rtw_memcpy(&sta_vht_cap->cap, vht_cap_ie + 2, 4);
+	_rtw_memcpy(&sta_vht_cap->vht_mcs, vht_cap_ie + 2 + 4, 8);
+}
+#endif /* defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)) */
+
+void rtw_cfg80211_init_wdev_data(_adapter *padapter)
+{
+#ifdef CONFIG_CONCURRENT_MODE
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+
+	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
+#endif
+}
+
+void rtw_cfg80211_init_wiphy(_adapter *padapter)
+{
+	u8 rf_type;
+	struct ieee80211_supported_band *band;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct wiphy *wiphy = pwdev->wiphy;
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+
+	RTW_INFO("%s:rf_type=%d\n", __func__, rf_type);
+
+	if (IsSupported24G(padapter->registrypriv.wireless_mode)) {
+		band = wiphy->bands[NL80211_BAND_2GHZ];
+		if (band) {
+			#if defined(CONFIG_80211N_HT)
+			rtw_cfg80211_init_ht_capab(padapter, &band->ht_cap, BAND_ON_2_4G, rf_type);
+			#endif
+		}
+	}
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (is_supported_5g(padapter->registrypriv.wireless_mode)) {
+		band = wiphy->bands[NL80211_BAND_5GHZ];
+		if (band) {
+			#if defined(CONFIG_80211N_HT)
+			rtw_cfg80211_init_ht_capab(padapter, &band->ht_cap, BAND_ON_5G, rf_type);
+			#endif
+			#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+			rtw_cfg80211_init_vht_capab(padapter, &band->vht_cap, BAND_ON_5G, rf_type);
+			#endif
+		}
+	}
+#endif
+	/* init regulary domain */
+	rtw_regd_init(padapter);
+
+	/* copy mac_addr to wiphy */
+	_rtw_memcpy(wiphy->perm_addr, adapter_mac_addr(padapter), ETH_ALEN);
+
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+struct ieee80211_iface_limit rtw_limits[] = {
+	{
+		.max = 2,
+		.types = BIT(NL80211_IFTYPE_STATION)
+			#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+			| BIT(NL80211_IFTYPE_P2P_CLIENT)
+			#endif
+	},
+	#ifdef CONFIG_AP_MODE
+	{
+		.max = 1,
+		.types = BIT(NL80211_IFTYPE_AP)
+			#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+			| BIT(NL80211_IFTYPE_P2P_GO)
+			#endif
+	},
+	#endif
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	{
+		.max = 1,
+		.types = BIT(NL80211_IFTYPE_P2P_DEVICE)
+	},
+	#endif
+	#if defined(CONFIG_RTW_MESH)
+	{
+		.max = 1,
+		.types = BIT(NL80211_IFTYPE_MESH_POINT)
+	},
+	#endif
+};
+
+struct ieee80211_iface_combination rtw_combinations[] = {
+	{
+		.limits = rtw_limits,
+		.n_limits = ARRAY_SIZE(rtw_limits),
+		#if defined(RTW_DEDICATED_P2P_DEVICE)
+		.max_interfaces = 3,
+		#else
+		.max_interfaces = 2,
+		#endif
+		.num_different_channels = 1,
+	},
+};
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)) */
+
+static void rtw_cfg80211_preinit_wiphy(_adapter *adapter, struct wiphy *wiphy)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
+
+	wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM;
+
+	wiphy->max_scan_ssids = RTW_SSID_SCAN_AMOUNT;
+	wiphy->max_scan_ie_len = RTW_SCAN_IE_LEN_MAX;
+	wiphy->max_num_pmkids = RTW_MAX_NUM_PMKIDS;
+
+#if CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	wiphy->max_acl_mac_addrs = NUM_ACL;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	wiphy->max_remain_on_channel_duration = RTW_MAX_REMAIN_ON_CHANNEL_DURATION;
+#endif
+
+	wiphy->interface_modes =	BIT(NL80211_IFTYPE_STATION)
+								| BIT(NL80211_IFTYPE_ADHOC)
+#ifdef CONFIG_AP_MODE
+								| BIT(NL80211_IFTYPE_AP)
+								#ifdef CONFIG_WIFI_MONITOR
+								| BIT(NL80211_IFTYPE_MONITOR)
+								#endif
+#endif
+#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+								| BIT(NL80211_IFTYPE_P2P_CLIENT)
+								| BIT(NL80211_IFTYPE_P2P_GO)
+								#if defined(RTW_DEDICATED_P2P_DEVICE)
+								| BIT(NL80211_IFTYPE_P2P_DEVICE)
+								#endif
+#endif
+#ifdef CONFIG_RTW_MESH
+								| BIT(NL80211_IFTYPE_MESH_POINT) /* 2.6.26 */
+#endif
+								;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+#ifdef CONFIG_AP_MODE
+	wiphy->mgmt_stypes = rtw_cfg80211_default_mgmt_stypes;
+#endif /* CONFIG_AP_MODE */
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	#ifdef CONFIG_WIFI_MONITOR
+	wiphy->software_iftypes |= BIT(NL80211_IFTYPE_MONITOR);
+	#endif
+#endif
+
+#if defined(RTW_SINGLE_WIPHY) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	wiphy->iface_combinations = rtw_combinations;
+	wiphy->n_iface_combinations = ARRAY_SIZE(rtw_combinations);
+#endif
+
+	wiphy->cipher_suites = rtw_cipher_suites;
+	wiphy->n_cipher_suites = ARRAY_SIZE(rtw_cipher_suites);
+
+	if (IsSupported24G(adapter->registrypriv.wireless_mode))
+		wiphy->bands[NL80211_BAND_2GHZ] = rtw_spt_band_alloc(BAND_ON_2_4G);
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (is_supported_5g(adapter->registrypriv.wireless_mode))
+		wiphy->bands[NL80211_BAND_5GHZ] = rtw_spt_band_alloc(BAND_ON_5G);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38) && LINUX_VERSION_CODE < KERNEL_VERSION(3, 0, 0))
+	wiphy->flags |= WIPHY_FLAG_SUPPORTS_SEPARATE_DEFAULT_KEYS;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
+	wiphy->flags |= WIPHY_FLAG_HAVE_AP_SME;
+	/* remove WIPHY_FLAG_OFFCHAN_TX, because we not support this feature */
+	/* wiphy->flags |= WIPHY_FLAG_OFFCHAN_TX | WIPHY_FLAG_HAVE_AP_SME; */
+#endif
+
+#if defined(CONFIG_PM) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0) && \
+			   LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+	wiphy->flags |= WIPHY_FLAG_SUPPORTS_SCHED_SCAN;
+#ifdef CONFIG_PNO_SUPPORT
+	wiphy->max_sched_scan_ssids = MAX_PNO_LIST_COUNT;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
+	wiphy->max_match_sets = MAX_PNO_LIST_COUNT;
+#endif
+#endif
+#endif
+
+#if defined(CONFIG_PM) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0))
+	wiphy->wowlan = wowlan_stub;
+#else
+	wiphy->wowlan = &wowlan_stub;
+#endif
+#endif
+
+#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	wiphy->flags |= WIPHY_FLAG_SUPPORTS_TDLS;
+#ifndef CONFIG_TDLS_DRIVER_SETUP
+	wiphy->flags |= WIPHY_FLAG_TDLS_EXTERNAL_SETUP;	/* Driver handles key exchange */
+	wiphy->flags |= NL80211_ATTR_HT_CAPABILITY;
+#endif /* CONFIG_TDLS_DRIVER_SETUP */
+#endif /* CONFIG_TDLS */
+
+	if (regsty->power_mgnt != PS_MODE_ACTIVE)
+		wiphy->flags |= WIPHY_FLAG_PS_ON_BY_DEFAULT;
+	else
+		wiphy->flags &= ~WIPHY_FLAG_PS_ON_BY_DEFAULT;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	/* wiphy->flags |= WIPHY_FLAG_SUPPORTS_FW_ROAM; */
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	wiphy->flags |= 0
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+		| WIPHY_FLAG_IBSS_RSN
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+		| WIPHY_FLAG_MESH_AUTH
+		#endif
+		;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	wiphy->features |= 0
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+		| NL80211_FEATURE_USERSPACE_MPM
+		#endif
+		;
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0)) */
+#endif /* CONFIG_RTW_MESH */
+}
+
+#ifdef CONFIG_RFKILL_POLL
+void rtw_cfg80211_init_rfkill(struct wiphy *wiphy)
+{
+	wiphy_rfkill_set_hw_state(wiphy, 0);
+	wiphy_rfkill_start_polling(wiphy);
+}
+
+void rtw_cfg80211_deinit_rfkill(struct wiphy *wiphy)
+{
+	wiphy_rfkill_stop_polling(wiphy);
+}
+
+static void cfg80211_rtw_rfkill_poll(struct wiphy *wiphy)
+{
+	_adapter *padapter = NULL;
+	bool blocked = _FALSE;
+	u8 valid = 0;
+
+	padapter = wiphy_to_adapter(wiphy);
+
+	if (adapter_to_dvobj(padapter)->processing_dev_remove == _TRUE) {
+		/*RTW_INFO("cfg80211_rtw_rfkill_poll: device is removed!\n");*/
+		return;
+	}
+
+	blocked = rtw_hal_rfkill_poll(padapter, &valid);
+	/*RTW_INFO("cfg80211_rtw_rfkill_poll: valid=%d, blocked=%d\n",
+			valid, blocked);*/
+
+	if (valid)
+		wiphy_rfkill_set_hw_state(wiphy, blocked);
+}
+#endif
+
+#if defined(CONFIG_RTW_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+#define SURVEY_INFO_TIME			SURVEY_INFO_CHANNEL_TIME
+#define SURVEY_INFO_TIME_BUSY		SURVEY_INFO_CHANNEL_TIME_BUSY
+#define SURVEY_INFO_TIME_EXT_BUSY	SURVEY_INFO_CHANNEL_TIME_EXT_BUSY
+#define SURVEY_INFO_TIME_RX			SURVEY_INFO_CHANNEL_TIME_RX
+#define SURVEY_INFO_TIME_TX			SURVEY_INFO_CHANNEL_TIME_TX
+#endif
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+static void rtw_cfg80211_set_survey_info_with_find_best_channel(struct wiphy *wiphy
+	, struct net_device *netdev, int idx, struct survey_info *info)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	RT_CHANNEL_INFO *ch_set = rfctl->channel_set;
+	u8 ch_num = rfctl->max_chan_nums;
+	u32 total_rx_cnt = 0;
+	int i;
+
+	s8 noise = -50;		/*channel noise in dBm. This and all following fields are optional */
+	u64 time = 100;		/*amount of time in ms the radio was turn on (on the channel)*/
+	u64 time_busy = 0;	/*amount of time the primary channel was sensed busy*/
+
+	info->filled  = SURVEY_INFO_NOISE_DBM
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+		| SURVEY_INFO_TIME | SURVEY_INFO_TIME_BUSY
+		#endif
+		;
+
+	for (i = 0; i < ch_num; i++)
+		total_rx_cnt += ch_set[i].rx_count;
+
+	time_busy = ch_set[idx].rx_count * time / total_rx_cnt;
+	noise += ch_set[idx].rx_count * 50 / total_rx_cnt;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+	info->channel_time = time;
+	info->channel_time_busy = time_busy;
+	#else
+	info->time = time;
+	info->time_busy = time_busy;
+	#endif
+#endif
+	info->noise = noise;
+
+	/* reset if final channel is got */
+	if (idx == ch_num - 1) {
+		for (i = 0; i < ch_num; i++)
+			ch_set[i].rx_count = 0;
+	}
+}
+#endif /* CONFIG_FIND_BEST_CHANNEL */
+
+#if defined(CONFIG_RTW_ACS) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
+static void rtw_cfg80211_set_survey_info_with_clm(PADAPTER padapter, int idx, struct survey_info *pinfo)
+{
+	s8 noise = -50;			/*channel noise in dBm. This and all following fields are optional */
+	u64 time = SURVEY_TO;	/*amount of time in ms the radio was turn on (on the channel)*/
+	u64 time_busy = 0;		/*amount of time the primary channel was sensed busy*/
+	u8 chan = (u8)idx;
+
+	if ((idx < 0) || (pinfo == NULL))
+		return;
+
+	pinfo->filled  = SURVEY_INFO_NOISE_DBM
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+		| SURVEY_INFO_TIME | SURVEY_INFO_TIME_BUSY
+		#endif
+		;
+
+	time_busy = rtw_acs_get_clm_ratio_by_ch_idx(padapter, chan);
+	noise = rtw_noise_query_by_chan_idx(padapter, chan);
+	/* RTW_INFO("%s: ch-idx:%d time=%llu(ms), time_busy=%llu(ms), noise=%d(dbm)\n", __func__, idx, time, time_busy, noise); */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+	pinfo->channel_time = time;
+	pinfo->channel_time_busy = time_busy;
+	#else
+	pinfo->time = time;
+	pinfo->time_busy = time_busy;
+	#endif
+#endif
+	pinfo->noise = noise;
+}
+#endif
+
+int rtw_hostapd_acs_dump_survey(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info)
+{
+	PADAPTER padapter = (_adapter *)rtw_netdev_priv(netdev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	RT_CHANNEL_INFO *pch_set = rfctl->channel_set;
+	u8 max_chan_nums = rfctl->max_chan_nums;
+	u32 freq = 0;
+	u8 ret = 0;
+	u16 channel = 0;
+
+	if (!netdev || !info) {
+		RTW_INFO("%s: invial parameters.\n", __func__);
+		return -EINVAL;
+	}
+
+	_rtw_memset(info, 0, sizeof(struct survey_info));
+	if (padapter->bup == _FALSE) {
+		RTW_INFO("%s: net device is down.\n", __func__);
+		return -EIO;
+	}
+
+	if (idx >= max_chan_nums)
+		return -ENOENT;
+
+	channel = pch_set[idx].ChannelNum;
+	freq = rtw_ch2freq(channel);
+	info->channel = ieee80211_get_channel(wiphy, freq);
+	/* RTW_INFO("%s: channel %d, freq %d\n", __func__, channel, freq); */
+
+	if (!info->channel)
+		return -EINVAL;
+
+	if (info->channel->flags == IEEE80211_CHAN_DISABLED)
+		return ret;
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	rtw_cfg80211_set_survey_info_with_find_best_channel(wiphy, netdev, idx, info);
+#elif defined(CONFIG_RTW_ACS) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
+	rtw_cfg80211_set_survey_info_with_clm(padapter, idx, info);
+#else
+	RTW_ERR("%s: unknown acs operation!\n", __func__); 
+#endif
+
+	return ret;
+}
+#endif /* defined(CONFIG_RTW_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33)) */
+
+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,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 30))
+	.set_default_mgmt_key = cfg80211_rtw_set_default_mgmt_key,
+#endif
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
+	.set_rekey_data = cfg80211_rtw_set_rekey_data,
+#endif /*CONFIG_GTK_OL*/
+	.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_AP_MODE
+	.add_virtual_intf = cfg80211_rtw_add_virtual_intf,
+	.del_virtual_intf = cfg80211_rtw_del_virtual_intf,
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) && !defined(COMPAT_KERNEL_RELEASE)
+	.add_beacon = cfg80211_rtw_add_beacon,
+	.set_beacon = cfg80211_rtw_set_beacon,
+	.del_beacon = cfg80211_rtw_del_beacon,
+#else
+	.start_ap = cfg80211_rtw_start_ap,
+	.change_beacon = cfg80211_rtw_change_beacon,
+	.stop_ap = cfg80211_rtw_stop_ap,
+#endif
+
+#if CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	.set_mac_acl = cfg80211_rtw_set_mac_acl,
+#endif
+
+	.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,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+	.set_channel = cfg80211_rtw_set_channel,
+#endif
+	/* .auth = cfg80211_rtw_auth, */
+	/* .assoc = cfg80211_rtw_assoc,	 */
+#endif /* CONFIG_AP_MODE */
+
+#if defined(CONFIG_RTW_MESH) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38))
+	.get_mesh_config = cfg80211_rtw_get_mesh_config,
+	.update_mesh_config = cfg80211_rtw_update_mesh_config,
+	.join_mesh = cfg80211_rtw_join_mesh,
+	.leave_mesh = cfg80211_rtw_leave_mesh,
+	.add_mpath = cfg80211_rtw_add_mpath,
+	.del_mpath = cfg80211_rtw_del_mpath,
+	.change_mpath = cfg80211_rtw_change_mpath,
+	.get_mpath = cfg80211_rtw_get_mpath,
+	.dump_mpath = cfg80211_rtw_dump_mpath,
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+	.get_mpp = cfg80211_rtw_get_mpp,
+	.dump_mpp = cfg80211_rtw_dump_mpp,
+	#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	.set_monitor_channel = cfg80211_rtw_set_monitor_channel,
+#endif
+
+#ifdef CONFIG_P2P
+	.remain_on_channel = cfg80211_rtw_remain_on_channel,
+	.cancel_remain_on_channel = cfg80211_rtw_cancel_remain_on_channel,
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	.start_p2p_device = cfg80211_rtw_start_p2p_device,
+	.stop_p2p_device = cfg80211_rtw_stop_p2p_device,
+	#endif
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_RTW_80211R
+	.update_ft_ies = cfg80211_rtw_update_ft_ies,
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	.mgmt_tx = cfg80211_rtw_mgmt_tx,
+	.mgmt_frame_register = cfg80211_rtw_mgmt_frame_register,
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+	.action = cfg80211_rtw_mgmt_tx,
+#endif
+
+#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	.tdls_mgmt = cfg80211_rtw_tdls_mgmt,
+	.tdls_oper = cfg80211_rtw_tdls_oper,
+#endif /* CONFIG_TDLS */
+
+#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	.sched_scan_start = cfg80211_rtw_sched_scan_start,
+	.sched_scan_stop = cfg80211_rtw_sched_scan_stop,
+	.suspend = cfg80211_rtw_suspend,
+	.resume = cfg80211_rtw_resume,
+#endif /* CONFIG_PNO_SUPPORT */
+#ifdef CONFIG_RFKILL_POLL
+	.rfkill_poll = cfg80211_rtw_rfkill_poll,
+#endif
+#if defined(CONFIG_RTW_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+	.dump_survey = rtw_hostapd_acs_dump_survey,
+#endif
+};
+
+struct wiphy *rtw_wiphy_alloc(_adapter *padapter, struct device *dev)
+{
+	struct wiphy *wiphy;
+	struct rtw_wiphy_data *wiphy_data;
+
+	/* wiphy */
+	wiphy = wiphy_new(&rtw_cfg80211_ops, sizeof(struct rtw_wiphy_data));
+	if (!wiphy) {
+		RTW_INFO("Couldn't allocate wiphy device\n");
+		goto exit;
+	}
+	set_wiphy_dev(wiphy, dev);
+
+	/* wiphy_data */
+	wiphy_data = rtw_wiphy_priv(wiphy);
+	wiphy_data->dvobj = adapter_to_dvobj(padapter);
+#ifndef RTW_SINGLE_WIPHY
+	wiphy_data->adapter = padapter;
+#endif
+
+	rtw_cfg80211_preinit_wiphy(padapter, wiphy);
+
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+exit:
+	return wiphy;
+}
+
+void rtw_wiphy_free(struct wiphy *wiphy)
+{
+	if (!wiphy)
+		return;
+
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+	if (wiphy->bands[NL80211_BAND_2GHZ]) {
+		rtw_spt_band_free(wiphy->bands[NL80211_BAND_2GHZ]);
+		wiphy->bands[NL80211_BAND_2GHZ] = NULL;
+	}
+	if (wiphy->bands[NL80211_BAND_5GHZ]) {
+		rtw_spt_band_free(wiphy->bands[NL80211_BAND_5GHZ]);
+		wiphy->bands[NL80211_BAND_5GHZ] = NULL;
+	}
+
+	wiphy_free(wiphy);
+}
+
+int rtw_wiphy_register(struct wiphy *wiphy)
+{
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
+	rtw_cfgvendor_attach(wiphy);
+#endif
+
+	return wiphy_register(wiphy);
+}
+
+void rtw_wiphy_unregister(struct wiphy *wiphy)
+{
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
+	rtw_cfgvendor_detach(wiphy);
+#endif
+
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	rtw_pd_iface_free(wiphy);
+	#endif
+
+	return wiphy_unregister(wiphy);
+}
+
+int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy)
+{
+	int ret = 0;
+	struct net_device *pnetdev = padapter->pnetdev;
+	struct wireless_dev *wdev;
+	struct rtw_wdev_priv *pwdev_priv;
+
+	RTW_INFO("%s(padapter=%p)\n", __func__, padapter);
+
+	/*  wdev */
+	wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
+	if (!wdev) {
+		RTW_INFO("Couldn't allocate wireless device\n");
+		ret = -ENOMEM;
+		goto exit;
+	}
+	wdev->wiphy = wiphy;
+	wdev->netdev = pnetdev;
+
+	wdev->iftype = NL80211_IFTYPE_STATION;	/* will be init in rtw_hal_init() */
+											/* Must sync with _rtw_init_mlme_priv() */
+											/* pmlmepriv->fw_state = WIFI_STATION_STATE */
+	/* wdev->iftype = NL80211_IFTYPE_MONITOR; */ /* for rtw_setopmode_cmd() in cfg80211_rtw_change_iface() */
+	padapter->rtw_wdev = wdev;
+	pnetdev->ieee80211_ptr = wdev;
+
+	/* init pwdev_priv */
+	pwdev_priv = adapter_wdev_data(padapter);
+	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;
+	_rtw_spinlock_init(&pwdev_priv->scan_req_lock);
+	pwdev_priv->connect_req = NULL;
+	_rtw_spinlock_init(&pwdev_priv->connect_req_lock);
+
+	pwdev_priv->p2p_enabled = _FALSE;
+	pwdev_priv->probe_resp_ie_update_time = rtw_get_current_time();
+	pwdev_priv->provdisc_req_issued = _FALSE;
+	rtw_wdev_invit_info_init(&pwdev_priv->invit_info);
+	rtw_wdev_nego_info_init(&pwdev_priv->nego_info);
+
+	pwdev_priv->bandroid_scan = _FALSE;
+
+	if (padapter->registrypriv.power_mgnt != PS_MODE_ACTIVE)
+		pwdev_priv->power_mgmt = _TRUE;
+	else
+		pwdev_priv->power_mgmt = _FALSE;
+
+	_rtw_mutex_init(&pwdev_priv->roch_mutex);
+
+#ifdef CONFIG_CONCURRENT_MODE
+	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
+#endif
+
+exit:
+	return ret;
+}
+
+void rtw_wdev_free(struct wireless_dev *wdev)
+{
+	if (!wdev)
+		return;
+
+	RTW_INFO("%s(wdev=%p)\n", __func__, wdev);
+
+	if (wdev_to_ndev(wdev)) {
+		_adapter *adapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+		struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+		_irqL irqL;
+
+		_rtw_spinlock_free(&wdev_priv->scan_req_lock);
+
+		_enter_critical_bh(&wdev_priv->connect_req_lock, &irqL);
+		rtw_wdev_free_connect_req(wdev_priv);
+		_exit_critical_bh(&wdev_priv->connect_req_lock, &irqL);
+		_rtw_spinlock_free(&wdev_priv->connect_req_lock);
+
+		_rtw_mutex_free(&wdev_priv->roch_mutex);
+	}
+
+	rtw_mfree((u8 *)wdev, sizeof(struct wireless_dev));
+}
+
+void rtw_wdev_unregister(struct wireless_dev *wdev)
+{
+	struct net_device *ndev;
+	_adapter *adapter;
+	struct rtw_wdev_priv *pwdev_priv;
+
+	if (!wdev)
+		return;
+
+	RTW_INFO("%s(wdev=%p)\n", __func__, wdev);
+
+	ndev = wdev_to_ndev(wdev);
+	if (!ndev)
+		return;
+
+	adapter = (_adapter *)rtw_netdev_priv(ndev);
+	pwdev_priv = adapter_wdev_data(adapter);
+
+	rtw_cfg80211_indicate_scan_done(adapter, _TRUE);
+
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)) || defined(COMPAT_KERNEL_RELEASE)
+	if (wdev->current_bss) {
+		RTW_INFO(FUNC_ADPT_FMT" clear current_bss by cfg80211_disconnected\n", FUNC_ADPT_ARG(adapter));
+		rtw_cfg80211_indicate_disconnect(adapter, 0, 1);
+	}
+	#endif
+
+	if (pwdev_priv->pmon_ndev) {
+		RTW_INFO("%s, unregister monitor interface\n", __func__);
+		unregister_netdev(pwdev_priv->pmon_ndev);
+	}
+}
+
+int rtw_cfg80211_ndev_res_alloc(_adapter *adapter)
+{
+	int ret = _FAIL;
+
+#if !defined(RTW_SINGLE_WIPHY)
+	struct wiphy *wiphy;
+	struct device *dev = dvobj_to_dev(adapter_to_dvobj(adapter));
+
+	wiphy = rtw_wiphy_alloc(adapter, dev);
+	if (wiphy == NULL)
+		goto exit;
+
+	adapter->wiphy = wiphy;
+#endif
+
+	if (rtw_wdev_alloc(adapter, adapter_to_wiphy(adapter)) == 0)
+		ret = _SUCCESS;
+
+#if !defined(RTW_SINGLE_WIPHY)
+	if (ret != _SUCCESS) {
+		rtw_wiphy_free(wiphy);
+		adapter->wiphy = NULL;
+	}
+#endif
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_ndev_res_free(_adapter *adapter)
+{
+	rtw_wdev_free(adapter->rtw_wdev);
+	adapter->rtw_wdev = NULL;
+#if !defined(RTW_SINGLE_WIPHY)
+	rtw_wiphy_free(adapter_to_wiphy(adapter));
+	adapter->wiphy = NULL;
+#endif
+}
+
+int rtw_cfg80211_ndev_res_register(_adapter *adapter)
+{
+	int ret = _FAIL;
+
+#if !defined(RTW_SINGLE_WIPHY)
+	if (rtw_wiphy_register(adapter_to_wiphy(adapter)) < 0) {
+		RTW_INFO("%s rtw_wiphy_register fail for if%d\n", __func__, (adapter->iface_id + 1));
+		goto exit;
+	}
+
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_init_rfkill(adapter_to_wiphy(adapter));
+#endif
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_ndev_res_unregister(_adapter *adapter)
+{
+	rtw_wdev_unregister(adapter->rtw_wdev);
+}
+
+int rtw_cfg80211_dev_res_alloc(struct dvobj_priv *dvobj)
+{
+	int ret = _FAIL;
+
+#if defined(RTW_SINGLE_WIPHY)
+	struct wiphy *wiphy;
+	struct device *dev = dvobj_to_dev(dvobj);
+
+	wiphy = rtw_wiphy_alloc(dvobj_get_primary_adapter(dvobj), dev);
+	if (wiphy == NULL)
+		goto exit;
+
+	dvobj->wiphy = wiphy;
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_dev_res_free(struct dvobj_priv *dvobj)
+{
+#if defined(RTW_SINGLE_WIPHY)
+	rtw_wiphy_free(dvobj_to_wiphy(dvobj));
+	dvobj->wiphy = NULL;
+#endif
+}
+
+int rtw_cfg80211_dev_res_register(struct dvobj_priv *dvobj)
+{
+	int ret = _FAIL;
+
+#if defined(RTW_SINGLE_WIPHY)
+	if (rtw_wiphy_register(dvobj_to_wiphy(dvobj)) != 0)
+		goto exit;
+
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_init_rfkill(dvobj_to_wiphy(dvobj));
+#endif
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_dev_res_unregister(struct dvobj_priv *dvobj)
+{
+#if defined(RTW_SINGLE_WIPHY)
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_deinit_rfkill(dvobj_to_wiphy(dvobj));
+#endif
+	rtw_wiphy_unregister(dvobj_to_wiphy(dvobj));
+#endif
+}
+
+#endif /* CONFIG_IOCTL_CFG80211 */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_cfg80211.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_cfg80211.h
new file mode 100644
index 000000000000..54a319f2dcd7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_cfg80211.h
@@ -0,0 +1,395 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+#ifndef RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
+#define RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT 1
+#else
+#define RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT 0
+#endif
+#endif
+
+#if defined(RTW_USE_CFG80211_STA_EVENT)
+	#undef CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER
+#endif
+
+#ifndef RTW_P2P_GROUP_INTERFACE
+	#define RTW_P2P_GROUP_INTERFACE 0
+#endif
+
+/*
+* (RTW_P2P_GROUP_INTERFACE, RTW_DEDICATED_P2P_DEVICE)
+* (0, 0): wlan0 + p2p0(PD+PG)
+* (1, 0): wlan0(with PD) + dynamic PGs
+* (1, 1): wlan0 (with dynamic PD wdev) + dynamic PGs
+*/
+
+#if RTW_P2P_GROUP_INTERFACE
+	#ifndef CONFIG_RTW_DYNAMIC_NDEV
+		#define CONFIG_RTW_DYNAMIC_NDEV
+	#endif
+	#ifndef RTW_SINGLE_WIPHY
+		#define RTW_SINGLE_WIPHY
+	#endif
+	#ifndef CONFIG_RADIO_WORK
+		#define CONFIG_RADIO_WORK
+	#endif
+	#ifndef RTW_DEDICATED_P2P_DEVICE
+		#define RTW_DEDICATED_P2P_DEVICE
+	#endif
+#endif
+
+#ifndef CONFIG_RADIO_WORK
+#define RTW_ROCH_DURATION_ENLARGE
+#define RTW_ROCH_BACK_OP
+#endif
+
+#if !defined(CONFIG_P2P) && RTW_P2P_GROUP_INTERFACE
+	#error "RTW_P2P_GROUP_INTERFACE can't be enabled when CONFIG_P2P is disabled\n"
+#endif
+
+#if !RTW_P2P_GROUP_INTERFACE && defined(RTW_DEDICATED_P2P_DEVICE)
+	#error "RTW_DEDICATED_P2P_DEVICE can't be enabled when RTW_P2P_GROUP_INTERFACE is disabled\n"
+#endif
+
+#if defined(RTW_DEDICATED_P2P_DEVICE) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 7, 0))
+	#error "RTW_DEDICATED_P2P_DEVICE can't be enabled when kernel < 3.7.0\n"
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
+		#error "CONFIG_RTW_MESH can't be enabled when kernel < 3.10.0\n"
+	#endif
+#endif
+
+struct rtw_wdev_invit_info {
+	u8 state; /* 0: req, 1:rep */
+	u8 peer_mac[ETH_ALEN];
+	u8 group_bssid[ETH_ALEN];
+	u8 active;
+	u8 token;
+	u8 flags;
+	u8 status;
+	u8 req_op_ch;
+	u8 rsp_op_ch;
+};
+
+#define rtw_wdev_invit_info_init(invit_info) \
+	do { \
+		(invit_info)->state = 0xff; \
+		_rtw_memset((invit_info)->peer_mac, 0, ETH_ALEN); \
+		_rtw_memset((invit_info)->group_bssid, 0, ETH_ALEN); \
+		(invit_info)->active = 0xff; \
+		(invit_info)->token = 0; \
+		(invit_info)->flags = 0x00; \
+		(invit_info)->status = 0xff; \
+		(invit_info)->req_op_ch = 0; \
+		(invit_info)->rsp_op_ch = 0; \
+	} while (0)
+
+struct rtw_wdev_nego_info {
+	u8 state; /* 0: req, 1:rep, 2:conf */
+	u8 iface_addr[ETH_ALEN];
+	u8 peer_mac[ETH_ALEN];
+	u8 peer_iface_addr[ETH_ALEN];
+	u8 active;
+	u8 token;
+	u8 status;
+	u8 req_intent;
+	u8 req_op_ch;
+	u8 req_listen_ch;
+	u8 rsp_intent;
+	u8 rsp_op_ch;
+	u8 conf_op_ch;
+};
+
+#define rtw_wdev_nego_info_init(nego_info) \
+	do { \
+		(nego_info)->state = 0xff; \
+		_rtw_memset((nego_info)->iface_addr, 0, ETH_ALEN); \
+		_rtw_memset((nego_info)->peer_mac, 0, ETH_ALEN); \
+		_rtw_memset((nego_info)->peer_iface_addr, 0, ETH_ALEN); \
+		(nego_info)->active = 0xff; \
+		(nego_info)->token = 0; \
+		(nego_info)->status = 0xff; \
+		(nego_info)->req_intent = 0xff; \
+		(nego_info)->req_op_ch = 0; \
+		(nego_info)->req_listen_ch = 0; \
+		(nego_info)->rsp_intent = 0xff; \
+		(nego_info)->rsp_op_ch = 0; \
+		(nego_info)->conf_op_ch = 0; \
+	} while (0)
+
+struct rtw_wdev_priv {
+	struct wireless_dev *rtw_wdev;
+
+	_adapter *padapter;
+
+	#if !RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT
+	u8 not_indic_disco;
+	#endif
+
+	struct cfg80211_scan_request *scan_request;
+	_lock scan_req_lock;
+
+	struct cfg80211_connect_params *connect_req;
+	_lock connect_req_lock;
+
+	struct net_device *pmon_ndev;/* for monitor interface */
+	char ifname_mon[IFNAMSIZ + 1]; /* interface name for monitor interface */
+
+	u8 p2p_enabled;
+	systime probe_resp_ie_update_time;
+
+	u8 provdisc_req_issued;
+
+	struct rtw_wdev_invit_info invit_info;
+	struct rtw_wdev_nego_info nego_info;
+
+	u8 bandroid_scan;
+	bool block;
+	bool block_scan;
+	bool power_mgmt;
+
+	/* report mgmt_frame registered */
+	u16 report_mgmt;
+
+	u8 is_mgmt_tx;
+	u16 mgmt_tx_cookie;
+
+	_mutex roch_mutex;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	ATOMIC_T switch_ch_to;
+#endif
+
+};
+
+bool rtw_cfg80211_is_connect_requested(_adapter *adapter);
+
+#if RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT
+#define rtw_wdev_not_indic_disco(rtw_wdev_data) 0
+#define rtw_wdev_set_not_indic_disco(rtw_wdev_data, val) do {} while (0)
+#else
+#define rtw_wdev_not_indic_disco(rtw_wdev_data) ((rtw_wdev_data)->not_indic_disco)
+#define rtw_wdev_set_not_indic_disco(rtw_wdev_data, val) do { (rtw_wdev_data)->not_indic_disco = (val); } while (0)
+#endif
+
+#define rtw_wdev_free_connect_req(rtw_wdev_data) \
+	do { \
+		if ((rtw_wdev_data)->connect_req) { \
+			rtw_mfree((u8 *)(rtw_wdev_data)->connect_req, sizeof(*(rtw_wdev_data)->connect_req)); \
+			(rtw_wdev_data)->connect_req = NULL; \
+		} \
+	} while (0)
+
+#define wdev_to_ndev(w) ((w)->netdev)
+#define wdev_to_wiphy(w) ((w)->wiphy)
+#define ndev_to_wdev(n) ((n)->ieee80211_ptr)
+
+struct rtw_wiphy_data {
+	struct dvobj_priv *dvobj;
+
+#ifndef RTW_SINGLE_WIPHY
+	_adapter *adapter;
+#endif
+
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+	struct wireless_dev *pd_wdev; /* P2P device wdev */
+#endif
+};
+
+#define rtw_wiphy_priv(wiphy) ((struct rtw_wiphy_data *)wiphy_priv(wiphy))
+#define wiphy_to_dvobj(wiphy) (((struct rtw_wiphy_data *)wiphy_priv(wiphy))->dvobj)
+#ifdef RTW_SINGLE_WIPHY
+#define wiphy_to_adapter(wiphy) (dvobj_get_primary_adapter(wiphy_to_dvobj(wiphy)))
+#else
+#define wiphy_to_adapter(wiphy) (((struct rtw_wiphy_data *)wiphy_priv(wiphy))->adapter)
+#endif
+
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+#define wiphy_to_pd_wdev(wiphy) (rtw_wiphy_priv(wiphy)->pd_wdev)
+#else
+#define wiphy_to_pd_wdev(wiphy) NULL
+#endif
+
+#define WIPHY_FMT "%s"
+#define WIPHY_ARG(wiphy) wiphy_name(wiphy)
+#define FUNC_WIPHY_FMT "%s("WIPHY_FMT")"
+#define FUNC_WIPHY_ARG(wiphy) __func__, WIPHY_ARG(wiphy)
+
+#define SET_CFG80211_REPORT_MGMT(w, t, v) (w->report_mgmt |= (v ? BIT(t >> 4) : 0))
+#define GET_CFG80211_REPORT_MGMT(w, t) ((w->report_mgmt & BIT(t >> 4)) > 0)
+
+struct wiphy *rtw_wiphy_alloc(_adapter *padapter, struct device *dev);
+void rtw_wiphy_free(struct wiphy *wiphy);
+int rtw_wiphy_register(struct wiphy *wiphy);
+void rtw_wiphy_unregister(struct wiphy *wiphy);
+
+int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy);
+void rtw_wdev_free(struct wireless_dev *wdev);
+void rtw_wdev_unregister(struct wireless_dev *wdev);
+
+int rtw_cfg80211_ndev_res_alloc(_adapter *adapter);
+void rtw_cfg80211_ndev_res_free(_adapter *adapter);
+int rtw_cfg80211_ndev_res_register(_adapter *adapter);
+void rtw_cfg80211_ndev_res_unregister(_adapter *adapter);
+
+int rtw_cfg80211_dev_res_alloc(struct dvobj_priv *dvobj);
+void rtw_cfg80211_dev_res_free(struct dvobj_priv *dvobj);
+int rtw_cfg80211_dev_res_register(struct dvobj_priv *dvobj);
+void rtw_cfg80211_dev_res_unregister(struct dvobj_priv *dvobj);
+
+void rtw_cfg80211_init_wdev_data(_adapter *padapter);
+void rtw_cfg80211_init_wiphy(_adapter *padapter);
+
+void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork);
+void rtw_cfg80211_surveydone_event_callback(_adapter *padapter);
+struct cfg80211_bss *rtw_cfg80211_inform_bss(_adapter *padapter, struct wlan_network *pnetwork);
+int rtw_cfg80211_check_bss(_adapter *padapter);
+void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter);
+void rtw_cfg80211_indicate_connect(_adapter *padapter);
+void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated);
+void rtw_cfg80211_indicate_scan_done(_adapter *adapter, bool aborted);
+u32 rtw_cfg80211_wait_scan_req_empty(_adapter *adapter, u32 timeout_ms);
+
+#ifdef CONFIG_CONCURRENT_MODE
+u8 rtw_cfg80211_scan_via_buddy(_adapter *padapter, struct cfg80211_scan_request *request);
+void rtw_cfg80211_indicate_scan_done_for_buddy(_adapter *padapter, bool bscan_aborted);
+#endif
+
+#ifdef CONFIG_AP_MODE
+void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len);
+void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, const u8 *da, unsigned short reason);
+#endif /* CONFIG_AP_MODE */
+
+#ifdef CONFIG_P2P
+void rtw_cfg80211_set_is_roch(_adapter *adapter, bool val);
+bool rtw_cfg80211_get_is_roch(_adapter *adapter);
+bool rtw_cfg80211_is_ro_ch_once(_adapter *adapter);
+void rtw_cfg80211_set_last_ro_ch_time(_adapter *adapter);
+s32 rtw_cfg80211_get_last_ro_ch_passing_ms(_adapter *adapter);
+
+int rtw_cfg80211_iface_has_p2p_group_cap(_adapter *adapter);
+int rtw_cfg80211_is_p2p_scan(_adapter *adapter);
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+int rtw_cfg80211_redirect_pd_wdev(struct wiphy *wiphy, u8 *ra, struct wireless_dev **wdev);
+int rtw_cfg80211_is_scan_by_pd_wdev(_adapter *adapter);
+int rtw_pd_iface_alloc(struct wiphy *wiphy, const char *name, struct wireless_dev **pd_wdev);
+void rtw_pd_iface_free(struct wiphy *wiphy);
+#endif
+#endif /* CONFIG_P2P */
+
+void rtw_cfg80211_set_is_mgmt_tx(_adapter *adapter, u8 val);
+u8 rtw_cfg80211_get_is_mgmt_tx(_adapter *adapter);
+u8 rtw_mgnt_tx_handler(_adapter *adapter, u8 *buf);
+
+void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len);
+
+void rtw_cfg80211_rx_p2p_action_public(_adapter *padapter, union recv_frame *rframe);
+void rtw_cfg80211_rx_action_p2p(_adapter *padapter, union recv_frame *rframe);
+void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const char *msg);
+void rtw_cfg80211_rx_mframe(_adapter *adapter, union recv_frame *rframe, const char *msg);
+void rtw_cfg80211_rx_probe_request(_adapter *padapter, union recv_frame *rframe);
+
+int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len, int type);
+
+bool rtw_cfg80211_pwr_mgmt(_adapter *adapter);
+#ifdef CONFIG_RTW_80211K
+void rtw_cfg80211_rx_rrm_action(_adapter *adapter, union recv_frame *rframe);
+#endif
+
+#ifdef CONFIG_RFKILL_POLL
+void rtw_cfg80211_init_rfkill(struct wiphy *wiphy);
+void rtw_cfg80211_deinit_rfkill(struct wiphy *wiphy);
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0))  && !defined(COMPAT_KERNEL_RELEASE)
+#define rtw_cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt(wdev_to_ndev(wdev), freq, buf, len, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+#define rtw_cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt(wdev_to_ndev(wdev), freq, sig_dbm, buf, len, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 12, 0))
+#define rtw_cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3 , 18 , 0))
+#define rtw_cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , gfp) cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , 0 , gfp)
+#else
+#define rtw_cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , gfp) cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , 0)
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0))  && !defined(COMPAT_KERNEL_RELEASE)
+#define rtw_cfg80211_send_rx_assoc(adapter, bss, buf, len) cfg80211_send_rx_assoc((adapter)->pnetdev, buf, len)
+#else
+#define rtw_cfg80211_send_rx_assoc(adapter, bss, buf, len) cfg80211_send_rx_assoc((adapter)->pnetdev, bss, buf, len)
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+#define rtw_cfg80211_mgmt_tx_status(wdev, cookie, buf, len, ack, gfp) cfg80211_mgmt_tx_status(wdev_to_ndev(wdev), cookie, buf, len, ack, gfp)
+#else
+#define rtw_cfg80211_mgmt_tx_status(wdev, cookie, buf, len, ack, gfp) cfg80211_mgmt_tx_status(wdev, cookie, buf, len, ack, gfp)
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+#define rtw_cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel(wdev_to_ndev(wdev), cookie, chan, channel_type, duration, gfp)
+#define rtw_cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired(wdev_to_ndev(wdev), cookie, chan, chan_type, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+#define rtw_cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)
+#define rtw_cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp)
+#else
+#define rtw_cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel(wdev, cookie, chan, duration, gfp)
+#define rtw_cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired(wdev, cookie, chan, gfp)
+#endif
+
+#define rtw_cfg80211_connect_result(wdev, bssid, req_ie, req_ie_len, resp_ie, resp_ie_len, status, gfp) cfg80211_connect_result(wdev_to_ndev(wdev), bssid, req_ie, req_ie_len, resp_ie, resp_ie_len, status, gfp)
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 2, 0))
+#define rtw_cfg80211_disconnected(wdev, reason, ie, ie_len, locally_generated, gfp) cfg80211_disconnected(wdev_to_ndev(wdev), reason, ie, ie_len, gfp)
+#else
+#define rtw_cfg80211_disconnected(wdev, reason, ie, ie_len, locally_generated, gfp) cfg80211_disconnected(wdev_to_ndev(wdev), reason, ie, ie_len, locally_generated, gfp)
+#endif
+
+#ifdef CONFIG_RTW_80211R
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+#define rtw_cfg80211_ft_event(adapter, parm)  cfg80211_ft_event((adapter)->pnetdev, parm)
+#else
+	#error "Cannot support FT for KERNEL_VERSION < 3.10\n"
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+#define rtw_cfg80211_notify_new_peer_candidate(wdev, addr, ie, ie_len, gfp) cfg80211_notify_new_peer_candidate(wdev_to_ndev(wdev), addr, ie, ie_len, gfp)
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+u8 rtw_cfg80211_ch_switch_notify(_adapter *adapter, u8 ch, u8 bw, u8 offset, u8 ht);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 7, 0))
+#define NL80211_BAND_2GHZ IEEE80211_BAND_2GHZ
+#define NL80211_BAND_5GHZ IEEE80211_BAND_5GHZ
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#define NL80211_BAND_60GHZ IEEE80211_BAND_60GHZ
+#endif
+#define NUM_NL80211_BANDS IEEE80211_NUM_BANDS
+#endif
+
+#define rtw_band_to_nl80211_band(band) \
+	(band == BAND_ON_2_4G) ? NL80211_BAND_2GHZ : \
+	(band == BAND_ON_5G) ? NL80211_BAND_5GHZ : NUM_NL80211_BANDS
+
+#include "rtw_cfgvendor.h"
+
+#endif /* __IOCTL_CFG80211_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_linux.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_linux.c
new file mode 100644
index 000000000000..3ff1564a3432
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_linux.c
@@ -0,0 +1,12841 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_LINUX_C_
+
+#include <drv_types.h>
+#include <rtw_mp.h>
+#include <rtw_mp_ioctl.h>
+#include "../../hal/phydm/phydm_precomp.h"
+#ifdef RTW_HALMAC
+#include "../../hal/hal_halmac.h"
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27))
+#define  iwe_stream_add_event(a, b, c, d, e)  iwe_stream_add_event(b, c, d, e)
+#define  iwe_stream_add_point(a, b, c, d, e)  iwe_stream_add_point(b, c, d, e)
+#endif
+
+#ifdef CONFIG_80211N_HT
+extern int rtw_ht_enable;
+#endif
+
+
+#define RTL_IOCTL_WPA_SUPPLICANT	(SIOCIWFIRSTPRIV+30)
+
+#define SCAN_ITEM_SIZE 768
+#define MAX_CUSTOM_LEN 64
+#define RATE_COUNT 4
+
+#ifdef CONFIG_GLOBAL_UI_PID
+extern int ui_pid[3];
+#endif
+
+/* combo scan */
+#define WEXT_CSCAN_AMOUNT 9
+#define WEXT_CSCAN_BUF_LEN		360
+#define WEXT_CSCAN_HEADER		"CSCAN S\x01\x00\x00S\x00"
+#define WEXT_CSCAN_HEADER_SIZE		12
+#define WEXT_CSCAN_SSID_SECTION		'S'
+#define WEXT_CSCAN_CHANNEL_SECTION	'C'
+#define WEXT_CSCAN_NPROBE_SECTION	'N'
+#define WEXT_CSCAN_ACTV_DWELL_SECTION	'A'
+#define WEXT_CSCAN_PASV_DWELL_SECTION	'P'
+#define WEXT_CSCAN_HOME_DWELL_SECTION	'H'
+#define WEXT_CSCAN_TYPE_SECTION		'T'
+
+
+extern u8 key_2char2num(u8 hch, u8 lch);
+extern u8 str_2char2num(u8 hch, u8 lch);
+extern void macstr2num(u8 *dst, u8 *src);
+extern u8 convert_ip_addr(u8 hch, u8 mch, u8 lch);
+
+u32 rtw_rates[] = {1000000, 2000000, 5500000, 11000000,
+	6000000, 9000000, 12000000, 18000000, 24000000, 36000000, 48000000, 54000000};
+
+static const char *const iw_operation_mode[] = {
+	"Auto", "Ad-Hoc", "Managed",  "Master", "Repeater", "Secondary", "Monitor"
+};
+
+/**
+ * hwaddr_aton - Convert ASCII string to MAC address
+ * @txt: MAC address as a string (e.g., "00:11:22:33:44:55")
+ * @addr: Buffer for the MAC address (ETH_ALEN = 6 bytes)
+ * Returns: 0 on success, -1 on failure (e.g., string not a MAC address)
+ */
+static int hwaddr_aton_i(const char *txt, u8 *addr)
+{
+	int i;
+
+	for (i = 0; i < 6; i++) {
+		int a, b;
+
+		a = hex2num_i(*txt++);
+		if (a < 0)
+			return -1;
+		b = hex2num_i(*txt++);
+		if (b < 0)
+			return -1;
+		*addr++ = (a << 4) | b;
+		if (i < 5 && *txt++ != ':')
+			return -1;
+	}
+
+	return 0;
+}
+
+static void indicate_wx_custom_event(_adapter *padapter, char *msg)
+{
+	u8 *buff, *p;
+	union iwreq_data wrqu;
+
+	if (strlen(msg) > IW_CUSTOM_MAX) {
+		RTW_INFO("%s strlen(msg):%zu > IW_CUSTOM_MAX:%u\n", __FUNCTION__ , strlen(msg), IW_CUSTOM_MAX);
+		return;
+	}
+
+	buff = rtw_zmalloc(IW_CUSTOM_MAX + 1);
+	if (!buff)
+		return;
+
+	_rtw_memcpy(buff, msg, strlen(msg));
+
+	_rtw_memset(&wrqu, 0, sizeof(wrqu));
+	wrqu.data.length = strlen(msg);
+
+	RTW_INFO("%s %s\n", __FUNCTION__, buff);
+#ifndef CONFIG_IOCTL_CFG80211
+	wireless_send_event(padapter->pnetdev, IWEVCUSTOM, &wrqu, buff);
+#endif
+
+	rtw_mfree(buff, IW_CUSTOM_MAX + 1);
+
+}
+
+
+static void request_wps_pbc_event(_adapter *padapter)
+{
+	u8 *buff, *p;
+	union iwreq_data wrqu;
+
+
+	buff = rtw_malloc(IW_CUSTOM_MAX);
+	if (!buff)
+		return;
+
+	_rtw_memset(buff, 0, IW_CUSTOM_MAX);
+
+	p = buff;
+
+	p += sprintf(p, "WPS_PBC_START.request=TRUE");
+
+	_rtw_memset(&wrqu, 0, sizeof(wrqu));
+
+	wrqu.data.length = p - buff;
+
+	wrqu.data.length = (wrqu.data.length < IW_CUSTOM_MAX) ? wrqu.data.length : IW_CUSTOM_MAX;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+#ifndef CONFIG_IOCTL_CFG80211
+	wireless_send_event(padapter->pnetdev, IWEVCUSTOM, &wrqu, buff);
+#endif
+
+	if (buff)
+		rtw_mfree(buff, IW_CUSTOM_MAX);
+
+}
+
+#ifdef CONFIG_SUPPORT_HW_WPS_PBC
+void rtw_request_wps_pbc_event(_adapter *padapter)
+{
+#ifdef RTK_DMP_PLATFORM
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
+	kobject_uevent(&padapter->pnetdev->dev.kobj, KOBJ_NET_PBC);
+#else
+	kobject_hotplug(&padapter->pnetdev->class_dev.kobj, KOBJ_NET_PBC);
+#endif
+#else
+
+	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;
+	}
+
+	rtw_signal_process(padapter->pid[0], SIGUSR1);
+
+#endif
+
+	rtw_led_control(padapter, LED_CTL_START_WPS_BOTTON);
+}
+#endif/* #ifdef CONFIG_SUPPORT_HW_WPS_PBC */
+
+void indicate_wx_scan_complete_event(_adapter *padapter)
+{
+	union iwreq_data wrqu;
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	_rtw_memset(&wrqu, 0, sizeof(union iwreq_data));
+
+	/* RTW_INFO("+rtw_indicate_wx_scan_complete_event\n"); */
+#ifndef CONFIG_IOCTL_CFG80211
+	wireless_send_event(padapter->pnetdev, SIOCGIWSCAN, &wrqu, NULL);
+#endif
+}
+
+
+void rtw_indicate_wx_assoc_event(_adapter *padapter)
+{
+	union iwreq_data wrqu;
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+
+	_rtw_memset(&wrqu, 0, sizeof(union iwreq_data));
+
+	wrqu.ap_addr.sa_family = ARPHRD_ETHER;
+
+	if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)
+		_rtw_memcpy(wrqu.ap_addr.sa_data, pnetwork->MacAddress, ETH_ALEN);
+	else
+		_rtw_memcpy(wrqu.ap_addr.sa_data, pmlmepriv->cur_network.network.MacAddress, ETH_ALEN);
+
+	RTW_PRINT("assoc success\n");
+#ifndef CONFIG_IOCTL_CFG80211
+	wireless_send_event(padapter->pnetdev, SIOCGIWAP, &wrqu, NULL);
+#endif
+}
+
+void rtw_indicate_wx_disassoc_event(_adapter *padapter)
+{
+	union iwreq_data wrqu;
+
+	_rtw_memset(&wrqu, 0, sizeof(union iwreq_data));
+
+	wrqu.ap_addr.sa_family = ARPHRD_ETHER;
+	_rtw_memset(wrqu.ap_addr.sa_data, 0, ETH_ALEN);
+
+#ifndef CONFIG_IOCTL_CFG80211
+	RTW_PRINT("indicate disassoc\n");
+	wireless_send_event(padapter->pnetdev, SIOCGIWAP, &wrqu, NULL);
+#endif
+}
+
+/*
+uint	rtw_is_cckrates_included(u8 *rate)
+{
+		u32	i = 0;
+
+		while(rate[i]!=0)
+		{
+			if  (  (((rate[i]) & 0x7f) == 2)	|| (((rate[i]) & 0x7f) == 4) ||
+			(((rate[i]) & 0x7f) == 11)  || (((rate[i]) & 0x7f) == 22) )
+			return _TRUE;
+			i++;
+		}
+
+		return _FALSE;
+}
+
+uint	rtw_is_cckratesonly_included(u8 *rate)
+{
+	u32 i = 0;
+
+	while(rate[i]!=0)
+	{
+			if  (  (((rate[i]) & 0x7f) != 2) && (((rate[i]) & 0x7f) != 4) &&
+				(((rate[i]) & 0x7f) != 11)  && (((rate[i]) & 0x7f) != 22) )
+			return _FALSE;
+			i++;
+	}
+
+	return _TRUE;
+}
+*/
+
+static int search_p2p_wfd_ie(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop)
+{
+#ifdef CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
+#ifdef CONFIG_WFD
+	if (SCAN_RESULT_ALL == pwdinfo->wfd_info->scan_result_type) {
+
+	} else if ((SCAN_RESULT_P2P_ONLY == pwdinfo->wfd_info->scan_result_type) ||
+		(SCAN_RESULT_WFD_TYPE == pwdinfo->wfd_info->scan_result_type))
+#endif /* CONFIG_WFD */
+	{
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			u32	blnGotP2PIE = _FALSE;
+
+			/*	User is doing the P2P device discovery */
+			/*	The prefix of SSID should be "DIRECT-" and the IE should contains the P2P IE. */
+			/*	If not, the driver should ignore this AP and go to the next AP. */
+
+			/*	Verifying the SSID */
+			if (_rtw_memcmp(pnetwork->network.Ssid.Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN)) {
+				u32	p2pielen = 0;
+
+				/*	Verifying the P2P IE */
+				if (rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen))
+					blnGotP2PIE = _TRUE;
+			}
+
+			if (blnGotP2PIE == _FALSE)
+				return _FALSE;
+
+		}
+	}
+
+#ifdef CONFIG_WFD
+	if (SCAN_RESULT_WFD_TYPE == pwdinfo->wfd_info->scan_result_type) {
+		u32	blnGotWFD = _FALSE;
+		u8 *wfd_ie;
+		uint wfd_ielen = 0;
+
+		wfd_ie = rtw_bss_ex_get_wfd_ie(&pnetwork->network, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			u8 *wfd_devinfo;
+			uint wfd_devlen;
+
+			wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
+			if (wfd_devinfo) {
+				if (pwdinfo->wfd_info->wfd_device_type == WFD_DEVINFO_PSINK) {
+					/*	the first two bits will indicate the WFD device type */
+					if ((wfd_devinfo[1] & 0x03) == WFD_DEVINFO_SOURCE) {
+						/*	If this device is Miracast PSink device, the scan reuslt should just provide the Miracast source. */
+						blnGotWFD = _TRUE;
+					}
+				} else if (pwdinfo->wfd_info->wfd_device_type == WFD_DEVINFO_SOURCE) {
+					/*	the first two bits will indicate the WFD device type */
+					if ((wfd_devinfo[1] & 0x03) == WFD_DEVINFO_PSINK) {
+						/*	If this device is Miracast source device, the scan reuslt should just provide the Miracast PSink. */
+						/*	Todo: How about the SSink?! */
+						blnGotWFD = _TRUE;
+					}
+				}
+			}
+		}
+
+		if (blnGotWFD == _FALSE)
+			return _FALSE;
+	}
+#endif /* CONFIG_WFD */
+
+#endif /* CONFIG_P2P */
+	return _TRUE;
+}
+static inline char *iwe_stream_mac_addr_proess(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	/*  AP MAC address */
+	iwe->cmd = SIOCGIWAP;
+	iwe->u.ap_addr.sa_family = ARPHRD_ETHER;
+
+	_rtw_memcpy(iwe->u.ap_addr.sa_data, pnetwork->network.MacAddress, ETH_ALEN);
+	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_ADDR_LEN);
+	return start;
+}
+static inline char *iwe_stream_essid_proess(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+
+	/* Add the ESSID */
+	iwe->cmd = SIOCGIWESSID;
+	iwe->u.data.flags = 1;
+	iwe->u.data.length = min((u16)pnetwork->network.Ssid.SsidLength, (u16)32);
+	start = iwe_stream_add_point(info, start, stop, iwe, pnetwork->network.Ssid.Ssid);
+	return start;
+}
+
+static inline char *iwe_stream_chan_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	if (pnetwork->network.Configuration.DSConfig < 1 /*|| pnetwork->network.Configuration.DSConfig>14*/)
+		pnetwork->network.Configuration.DSConfig = 1;
+
+	/* Add frequency/channel */
+	iwe->cmd = SIOCGIWFREQ;
+	iwe->u.freq.m = rtw_ch2freq(pnetwork->network.Configuration.DSConfig) * 100000;
+	iwe->u.freq.e = 1;
+	iwe->u.freq.i = pnetwork->network.Configuration.DSConfig;
+	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_FREQ_LEN);
+	return start;
+}
+static inline char *iwe_stream_mode_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe, u16 cap)
+{
+	/* Add mode */
+	if (cap & (WLAN_CAPABILITY_IBSS | WLAN_CAPABILITY_BSS)) {
+		iwe->cmd = SIOCGIWMODE;
+		if (cap & WLAN_CAPABILITY_BSS)
+			iwe->u.mode = IW_MODE_MASTER;
+		else
+			iwe->u.mode = IW_MODE_ADHOC;
+
+		start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_UINT_LEN);
+	}
+	return start;
+}
+static inline char *iwe_stream_encryption_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe, u16 cap)
+{
+
+	/* Add encryption capability */
+	iwe->cmd = SIOCGIWENCODE;
+	if (cap & WLAN_CAPABILITY_PRIVACY)
+		iwe->u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY;
+	else
+		iwe->u.data.flags = IW_ENCODE_DISABLED;
+	iwe->u.data.length = 0;
+	start = iwe_stream_add_point(info, start, stop, iwe, pnetwork->network.Ssid.Ssid);
+	return start;
+
+}
+
+static inline char *iwe_stream_protocol_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	u16 ht_cap = _FALSE, vht_cap = _FALSE;
+	u32 ht_ielen = 0, vht_ielen = 0;
+	char *p;
+	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12); /* Probe Request	 */
+
+	/* parsing HT_CAP_IE	 */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && ht_ielen > 0)
+		ht_cap = _TRUE;
+
+#ifdef CONFIG_80211AC_VHT
+	/* parsing VHT_CAP_IE */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && vht_ielen > 0)
+		vht_cap = _TRUE;
+#endif
+	/* Add the protocol name */
+	iwe->cmd = SIOCGIWNAME;
+	if ((rtw_is_cckratesonly_included((u8 *)&pnetwork->network.SupportedRates)) == _TRUE) {
+		if (ht_cap == _TRUE)
+			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11bn");
+		else
+			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11b");
+	} else if ((rtw_is_cckrates_included((u8 *)&pnetwork->network.SupportedRates)) == _TRUE) {
+		if (ht_cap == _TRUE)
+			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11bgn");
+		else
+			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11bg");
+	} else {
+		if (pnetwork->network.Configuration.DSConfig > 14) {
+			#ifdef CONFIG_80211AC_VHT
+			if (vht_cap == _TRUE)
+				snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11AC");
+			else
+			#endif
+			{
+				if (ht_cap == _TRUE)
+					snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11an");
+				else
+					snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11a");
+			}
+		} else {
+			if (ht_cap == _TRUE)
+				snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11gn");
+			else
+				snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11g");
+		}
+	}
+	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_CHAR_LEN);
+	return start;
+}
+
+static inline char *iwe_stream_rate_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	u32 ht_ielen = 0, vht_ielen = 0;
+	char *p;
+	u16 max_rate = 0, rate, ht_cap = _FALSE, vht_cap = _FALSE;
+	u32 i = 0;
+	u8 bw_40MHz = 0, short_GI = 0, bw_160MHz = 0, vht_highest_rate = 0;
+	u16 mcs_rate = 0, vht_data_rate = 0;
+	char custom[MAX_CUSTOM_LEN] = {0};
+	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12); /* Probe Request	 */
+
+	/* parsing HT_CAP_IE	 */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && ht_ielen > 0) {
+		struct rtw_ieee80211_ht_cap *pht_capie;
+		ht_cap = _TRUE;
+		pht_capie = (struct rtw_ieee80211_ht_cap *)(p + 2);
+		_rtw_memcpy(&mcs_rate , pht_capie->supp_mcs_set, 2);
+		bw_40MHz = (pht_capie->cap_info & IEEE80211_HT_CAP_SUP_WIDTH) ? 1 : 0;
+		short_GI = (pht_capie->cap_info & (IEEE80211_HT_CAP_SGI_20 | IEEE80211_HT_CAP_SGI_40)) ? 1 : 0;
+	}
+
+#ifdef CONFIG_80211AC_VHT
+	/* parsing VHT_CAP_IE */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && vht_ielen > 0) {
+		u8	mcs_map[2];
+
+		vht_cap = _TRUE;
+		bw_160MHz = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p + 2);
+		if (bw_160MHz)
+			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI160M(p + 2);
+		else
+			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI80M(p + 2);
+
+		_rtw_memcpy(mcs_map, GET_VHT_CAPABILITY_ELE_TX_MCS(p + 2), 2);
+
+		vht_highest_rate = rtw_get_vht_highest_rate(mcs_map);
+		vht_data_rate = rtw_vht_mcs_to_data_rate(CHANNEL_WIDTH_80, short_GI, vht_highest_rate);
+	}
+#endif
+
+	/*Add basic and extended rates */
+	p = custom;
+	p += snprintf(p, MAX_CUSTOM_LEN - (p - custom), " Rates (Mb/s): ");
+	while (pnetwork->network.SupportedRates[i] != 0) {
+		rate = pnetwork->network.SupportedRates[i] & 0x7F;
+		if (rate > max_rate)
+			max_rate = rate;
+		p += snprintf(p, MAX_CUSTOM_LEN - (p - custom),
+			      "%d%s ", rate >> 1, (rate & 1) ? ".5" : "");
+		i++;
+	}
+#ifdef CONFIG_80211AC_VHT
+	if (vht_cap == _TRUE)
+		max_rate = vht_data_rate;
+	else
+#endif
+		if (ht_cap == _TRUE) {
+			if (mcs_rate & 0x8000) /* MCS15 */
+				max_rate = (bw_40MHz) ? ((short_GI) ? 300 : 270) : ((short_GI) ? 144 : 130);
+
+			else if (mcs_rate & 0x0080) /* MCS7 */
+				max_rate = (bw_40MHz) ? ((short_GI) ? 150 : 135) : ((short_GI) ? 72 : 65);
+			else { /* default MCS7 */
+				/* RTW_INFO("wx_get_scan, mcs_rate_bitmap=0x%x\n", mcs_rate); */
+				max_rate = (bw_40MHz) ? ((short_GI) ? 150 : 135) : ((short_GI) ? 72 : 65);
+			}
+
+			max_rate = max_rate * 2; /* Mbps/2;		 */
+		}
+
+	iwe->cmd = SIOCGIWRATE;
+	iwe->u.bitrate.fixed = iwe->u.bitrate.disabled = 0;
+	iwe->u.bitrate.value = max_rate * 500000;
+	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_PARAM_LEN);
+	return start ;
+}
+
+static inline char *iwe_stream_wpa_wpa2_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	int buf_size = MAX_WPA_IE_LEN * 2;
+	/* u8 pbuf[buf_size]={0};	 */
+	u8 *pbuf = rtw_zmalloc(buf_size);
+
+	u8 wpa_ie[255] = {0}, rsn_ie[255] = {0};
+	u16 i, wpa_len = 0, rsn_len = 0;
+	u8 *p;
+	sint out_len = 0;
+
+
+	if (pbuf) {
+		p = pbuf;
+
+		/* parsing WPA/WPA2 IE */
+		if (pnetwork->network.Reserved[0] != BSS_TYPE_PROB_REQ) { /* Probe Request */
+			out_len = rtw_get_sec_ie(pnetwork->network.IEs , pnetwork->network.IELength, rsn_ie, &rsn_len, wpa_ie, &wpa_len);
+
+			if (wpa_len > 0) {
+
+				_rtw_memset(pbuf, 0, buf_size);
+				p += sprintf(p, "wpa_ie=");
+				for (i = 0; i < wpa_len; i++)
+					p += sprintf(p, "%02x", wpa_ie[i]);
+
+				if (wpa_len > 100) {
+					printk("-----------------Len %d----------------\n", wpa_len);
+					for (i = 0; i < wpa_len; i++)
+						printk("%02x ", wpa_ie[i]);
+					printk("\n");
+					printk("-----------------Len %d----------------\n", wpa_len);
+				}
+
+				_rtw_memset(iwe, 0, sizeof(*iwe));
+				iwe->cmd = IWEVCUSTOM;
+				iwe->u.data.length = strlen(pbuf);
+				start = iwe_stream_add_point(info, start, stop, iwe, pbuf);
+
+				_rtw_memset(iwe, 0, sizeof(*iwe));
+				iwe->cmd = IWEVGENIE;
+				iwe->u.data.length = wpa_len;
+				start = iwe_stream_add_point(info, start, stop, iwe, wpa_ie);
+			}
+			if (rsn_len > 0) {
+
+				_rtw_memset(pbuf, 0, buf_size);
+				p += sprintf(p, "rsn_ie=");
+				for (i = 0; i < rsn_len; i++)
+					p += sprintf(p, "%02x", rsn_ie[i]);
+				_rtw_memset(iwe, 0, sizeof(*iwe));
+				iwe->cmd = IWEVCUSTOM;
+				iwe->u.data.length = strlen(pbuf);
+				start = iwe_stream_add_point(info, start, stop, iwe, pbuf);
+
+				_rtw_memset(iwe, 0, sizeof(*iwe));
+				iwe->cmd = IWEVGENIE;
+				iwe->u.data.length = rsn_len;
+				start = iwe_stream_add_point(info, start, stop, iwe, rsn_ie);
+			}
+		}
+
+		rtw_mfree(pbuf, buf_size);
+	}
+	return start;
+}
+
+static inline char *iwe_stream_wps_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	/* parsing WPS IE */
+	uint cnt = 0, total_ielen;
+	u8 *wpsie_ptr = NULL;
+	uint wps_ielen = 0;
+	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12);
+
+	u8 *ie_ptr = pnetwork->network.IEs + ie_offset;
+	total_ielen = pnetwork->network.IELength - ie_offset;
+
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ) { /* Probe Request */
+		ie_ptr = pnetwork->network.IEs;
+		total_ielen = pnetwork->network.IELength;
+	} else { /* Beacon or Probe Respones */
+		ie_ptr = pnetwork->network.IEs + _FIXED_IE_LENGTH_;
+		total_ielen = pnetwork->network.IELength - _FIXED_IE_LENGTH_;
+	}
+	while (cnt < total_ielen) {
+		if (rtw_is_wps_ie(&ie_ptr[cnt], &wps_ielen) && (wps_ielen > 2)) {
+			wpsie_ptr = &ie_ptr[cnt];
+			iwe->cmd = IWEVGENIE;
+			iwe->u.data.length = (u16)wps_ielen;
+			start = iwe_stream_add_point(info, start, stop, iwe, wpsie_ptr);
+		}
+		cnt += ie_ptr[cnt + 1] + 2; /* goto next */
+	}
+	return start;
+}
+
+static inline char *iwe_stream_wapi_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+#ifdef CONFIG_WAPI_SUPPORT
+	char *p;
+
+	if (pnetwork->network.Reserved[0] != BSS_TYPE_PROB_REQ) { /* Probe Request */
+		sint out_len_wapi = 0;
+		/* here use static for stack size */
+		static u8 buf_wapi[MAX_WAPI_IE_LEN * 2] = {0};
+		static u8 wapi_ie[MAX_WAPI_IE_LEN] = {0};
+		u16 wapi_len = 0;
+		u16  i;
+
+		out_len_wapi = rtw_get_wapi_ie(pnetwork->network.IEs , pnetwork->network.IELength, wapi_ie, &wapi_len);
+
+		RTW_INFO("rtw_wx_get_scan: %s ", pnetwork->network.Ssid.Ssid);
+		RTW_INFO("rtw_wx_get_scan: ssid = %d ", wapi_len);
+
+
+		if (wapi_len > 0) {
+			p = buf_wapi;
+			/* _rtw_memset(buf_wapi, 0, MAX_WAPI_IE_LEN*2); */
+			p += sprintf(p, "wapi_ie=");
+			for (i = 0; i < wapi_len; i++)
+				p += sprintf(p, "%02x", wapi_ie[i]);
+
+			_rtw_memset(iwe, 0, sizeof(*iwe));
+			iwe->cmd = IWEVCUSTOM;
+			iwe->u.data.length = strlen(buf_wapi);
+			start = iwe_stream_add_point(info, start, stop, iwe, buf_wapi);
+
+			_rtw_memset(iwe, 0, sizeof(*iwe));
+			iwe->cmd = IWEVGENIE;
+			iwe->u.data.length = wapi_len;
+			start = iwe_stream_add_point(info, start, stop, iwe, wapi_ie);
+		}
+	}
+#endif/* #ifdef CONFIG_WAPI_SUPPORT */
+	return start;
+}
+
+static inline char   *iwe_stream_rssi_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	u8 ss, sq;
+	s16 noise = 0;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	/* Add quality statistics */
+	iwe->cmd = IWEVQUAL;
+	iwe->u.qual.updated = IW_QUAL_QUAL_UPDATED | IW_QUAL_LEVEL_UPDATED
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+			      | IW_QUAL_NOISE_UPDATED
+#else
+			      | IW_QUAL_NOISE_INVALID
+#endif
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+			      | IW_QUAL_DBM
+#endif
+			      ;
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
+	    is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
+		ss = padapter->recvpriv.signal_strength;
+		sq = padapter->recvpriv.signal_qual;
+	} else {
+		ss = pnetwork->network.PhyInfo.SignalStrength;
+		sq = pnetwork->network.PhyInfo.SignalQuality;
+	}
+
+
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+	iwe->u.qual.level = (u8) translate_percentage_to_dbm(ss); /* dbm */
+#else
+#ifdef CONFIG_SIGNAL_SCALE_MAPPING
+	iwe->u.qual.level = (u8)ss; /* % */
+#else
+	{
+		/* Do signal scale mapping when using percentage as the unit of signal strength, since the scale mapping is skipped in odm */
+
+		HAL_DATA_TYPE *pHal = GET_HAL_DATA(padapter);
+
+		iwe->u.qual.level = (u8)phydm_signal_scale_mapping(&pHal->odmpriv, ss);
+	}
+#endif
+#endif
+
+	iwe->u.qual.qual = (u8)sq;   /* signal quality */
+
+#ifdef CONFIG_PLATFORM_ROCKCHIPS
+	iwe->u.qual.noise = -100; /* noise level suggest by zhf@rockchips */
+#else
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	if (IS_NM_ENABLE(padapter)) {
+		noise = rtw_noise_query_by_chan_num(padapter, pnetwork->network.Configuration.DSConfig);
+		#ifndef CONFIG_SIGNAL_DISPLAY_DBM
+		noise = translate_dbm_to_percentage(noise);/*percentage*/
+		#endif
+		iwe->u.qual.noise = noise;
+	}
+#else
+	iwe->u.qual.noise = 0; /* noise level */
+#endif
+#endif /* CONFIG_PLATFORM_ROCKCHIPS */
+
+	/* RTW_INFO("iqual=%d, ilevel=%d, inoise=%d, iupdated=%d\n", iwe.u.qual.qual, iwe.u.qual.level , iwe.u.qual.noise, iwe.u.qual.updated); */
+
+	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_QUAL_LEN);
+	return start;
+}
+
+static inline char   *iwe_stream_net_rsv_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	u8 buf[32] = {0};
+	u8 *p, *pos;
+	int len;
+	p = buf;
+	pos = pnetwork->network.Reserved;
+
+	p += sprintf(p, "fm=%02X%02X", pos[1], pos[0]);
+	_rtw_memset(iwe, 0, sizeof(*iwe));
+	iwe->cmd = IWEVCUSTOM;
+	iwe->u.data.length = strlen(buf);
+	start = iwe_stream_add_point(info, start, stop, iwe, buf);
+	return start;
+}
+
+static char *translate_scan(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop)
+{
+	struct iw_event iwe;
+	u16 cap = 0;
+	_rtw_memset(&iwe, 0, sizeof(iwe));
+
+	if (_FALSE == search_p2p_wfd_ie(padapter, info, pnetwork, start, stop))
+		return start;
+
+	start = iwe_stream_mac_addr_proess(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_essid_proess(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_protocol_process(padapter, info, pnetwork, start, stop, &iwe);
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ) /* Probe Request */
+		cap = 0;
+	else {
+		_rtw_memcpy((u8 *)&cap, rtw_get_capability_from_ie(pnetwork->network.IEs), 2);
+		cap = le16_to_cpu(cap);
+	}
+
+	start = iwe_stream_mode_process(padapter, info, pnetwork, start, stop, &iwe, cap);
+	start = iwe_stream_chan_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_encryption_process(padapter, info, pnetwork, start, stop, &iwe, cap);
+	start = iwe_stream_rate_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_wpa_wpa2_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_wps_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_wapi_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_rssi_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_net_rsv_process(padapter, info, pnetwork, start, stop, &iwe);
+
+	return start;
+}
+
+static int wpa_set_auth_algs(struct net_device *dev, u32 value)
+{
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	int ret = 0;
+
+	if ((value & AUTH_ALG_SHARED_KEY) && (value & AUTH_ALG_OPEN_SYSTEM)) {
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_SHARED_KEY and  AUTH_ALG_OPEN_SYSTEM [value:0x%x]\n", value);
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+	} else if (value & AUTH_ALG_SHARED_KEY) {
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_SHARED_KEY  [value:0x%x]\n", value);
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+
+#ifdef CONFIG_PLATFORM_MT53XX
+		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+#else
+		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeShared;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Shared;
+#endif
+	} else if (value & AUTH_ALG_OPEN_SYSTEM) {
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_OPEN_SYSTEM\n");
+		/* padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled; */
+		if (padapter->securitypriv.ndisauthtype < Ndis802_11AuthModeWPAPSK) {
+#ifdef CONFIG_PLATFORM_MT53XX
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+#else
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
+#endif
+		}
+
+	} else if (value & AUTH_ALG_LEAP)
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_LEAP\n");
+	else {
+		RTW_INFO("wpa_set_auth_algs, error!\n");
+		ret = -EINVAL;
+	}
+
+	return ret;
+
+}
+
+static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
+{
+	int ret = 0;
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
+
+
+	param->u.crypt.err = 0;
+	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
+
+	if (param_len < (u32)((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len) {
+		ret =  -EINVAL;
+		goto exit;
+	}
+
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) {
+
+		if (param->u.crypt.idx >= WEP_KEYS
+#ifdef CONFIG_IEEE80211W
+		    && param->u.crypt.idx > BIP_MAX_KEYID
+#endif /* CONFIG_IEEE80211W */
+		   ) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	} else {
+#ifdef CONFIG_WAPI_SUPPORT
+		if (strcmp(param->u.crypt.alg, "SMS4"))
+#endif
+		{
+			ret = -EINVAL;
+			goto exit;
+		}
+	}
+
+	if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+		RTW_INFO("wpa_set_encryption, crypt.alg = WEP\n");
+
+		wep_key_idx = param->u.crypt.idx;
+		wep_key_len = param->u.crypt.key_len;
+
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		if (psecuritypriv->bWepDefaultKeyIdxSet == 0) {
+			/* wep default key has not been set, so use this key index as default key.*/
+
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+
+			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+
+			if (wep_key_len == 13) {
+				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+			}
+
+			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
+		}
+
+		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
+
+		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
+
+		psecuritypriv->key_mask |= BIT(wep_key_idx);
+
+		padapter->mlmeextpriv.mlmext_info.key_index = wep_key_idx;
+		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) == _TRUE) { /* sta mode */
+			psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+			if (psta == NULL) {
+				/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
+					psta->ieee8021x_blocked = _FALSE;
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
+					psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+
+				if (param->u.crypt.set_tx == 1) { /* pairwise key */
+					RTW_INFO(FUNC_ADPT_FMT" set %s PTK idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0) { /* set mic key */
+						_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
+						_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
+						padapter->securitypriv.busetkipkey = _FALSE;
+					}
+					psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->bpairwise_key_installed = _TRUE;
+					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
+
+				} else { /* group key */
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set %s GTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						/* only TKIP group key need to install this */
+						if (param->u.crypt.key_len > 16) {
+							_rtw_memcpy(padapter->securitypriv.dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
+							_rtw_memcpy(padapter->securitypriv.dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
+						}
+						padapter->securitypriv.binstallGrpkey = _TRUE;
+						if (param->u.crypt.idx < 4)
+							_rtw_memcpy(padapter->securitypriv.iv_seq[param->u.crypt.idx], param->u.crypt.seq, 8);
+						padapter->securitypriv.dot118021XGrpKeyid = param->u.crypt.idx;
+						rtw_set_key(padapter, &padapter->securitypriv, param->u.crypt.idx, 1, _TRUE);
+
+					#ifdef CONFIG_IEEE80211W
+					} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set IGTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+						psecuritypriv->dot11wBIPrxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+						psecuritypriv->binstallBIPkey = _TRUE;
+					#endif /* CONFIG_IEEE80211W */
+
+					}
+
+#ifdef CONFIG_P2P
+					if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
+						rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_DONE);
+#endif /* CONFIG_P2P */
+
+				}
+			}
+
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta == NULL) {
+				/* DEBUG_ERR( ("Set OID_802_11_ADD_KEY: bcmc stainfo is null\n")); */
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
+					pbcmc_sta->ieee8021x_blocked = _FALSE;
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
+					pbcmc_sta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+			}
+		} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) { /* adhoc mode */
+		}
+	}
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (strcmp(param->u.crypt.alg, "SMS4") == 0)
+		rtw_wapi_set_set_encryption(padapter, param);
+#endif
+
+exit:
+
+
+	return ret;
+}
+
+static int rtw_set_wpa_ie(_adapter *padapter, char *pie, unsigned short ielen)
+{
+	u8 *buf = NULL, *pos = NULL;
+	u32 left;
+	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
+	int ret = 0;
+	u8 null_addr[] = {0, 0, 0, 0, 0, 0};
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
+
+	if ((ielen > MAX_WPA_IE_LEN) || (pie == NULL)) {
+		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
+		if (pie == NULL)
+			return ret;
+		else
+			return -EINVAL;
+	}
+
+	if (ielen) {
+		buf = rtw_zmalloc(ielen);
+		if (buf == NULL) {
+			ret =  -ENOMEM;
+			goto exit;
+		}
+
+		_rtw_memcpy(buf, pie , ielen);
+
+		/* dump */
+		{
+			int i;
+			RTW_INFO("\n wpa_ie(length:%d):\n", ielen);
+			for (i = 0; i < ielen; i = i + 8)
+				RTW_INFO("0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x\n", buf[i], buf[i + 1], buf[i + 2], buf[i + 3], buf[i + 4], buf[i + 5], buf[i + 6], buf[i + 7]);
+		}
+
+		pos = buf;
+		if (ielen < RSN_HEADER_LEN) {
+			ret  = -1;
+			goto exit;
+		}
+
+		if (rtw_parse_wpa_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);
+		}
+
+		if (rtw_parse_wpa2_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);
+		}
+
+		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 = _NO_PRIVACY_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+			break;
+		case WPA_CIPHER_WEP40:
+			padapter->securitypriv.dot118021XGrpPrivacy = _WEP40_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
+		case WPA_CIPHER_TKIP:
+			padapter->securitypriv.dot118021XGrpPrivacy = _TKIP_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+			break;
+		case WPA_CIPHER_CCMP:
+			padapter->securitypriv.dot118021XGrpPrivacy = _AES_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+			break;
+		case WPA_CIPHER_WEP104:
+			padapter->securitypriv.dot118021XGrpPrivacy = _WEP104_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
+		}
+
+		switch (pairwise_cipher) {
+		case WPA_CIPHER_NONE:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+			break;
+		case WPA_CIPHER_WEP40:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
+		case WPA_CIPHER_TKIP:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _TKIP_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+			break;
+		case WPA_CIPHER_CCMP:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _AES_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+			break;
+		case WPA_CIPHER_WEP104:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
+		}
+
+		if (mfp_opt == MFP_INVALID) {
+			RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+			ret = -EINVAL;
+			goto exit;
+		}
+		padapter->securitypriv.mfp_opt = mfp_opt;
+
+		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
+		{/* set wps_ie	 */
+			u16 cnt = 0;
+			u8 eid, wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
+
+			while (cnt < ielen) {
+				eid = buf[cnt];
+
+				if ((eid == _VENDOR_SPECIFIC_IE_) && (_rtw_memcmp(&buf[cnt + 2], wps_oui, 4) == _TRUE)) {
+					RTW_INFO("SET WPS_IE\n");
+
+					padapter->securitypriv.wps_ie_len = ((buf[cnt + 1] + 2) < MAX_WPS_IE_LEN) ? (buf[cnt + 1] + 2) : MAX_WPS_IE_LEN;
+
+					_rtw_memcpy(padapter->securitypriv.wps_ie, &buf[cnt], padapter->securitypriv.wps_ie_len);
+
+					set_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS);
+
+#ifdef CONFIG_P2P
+					if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_OK))
+						rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_ING);
+#endif /* CONFIG_P2P */
+					cnt += buf[cnt + 1] + 2;
+
+					break;
+				} else {
+					cnt += buf[cnt + 1] + 2; /* goto next	 */
+				}
+			}
+		}
+	}
+
+	/* TKIP and AES disallow multicast packets until installing group key */
+	if (padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_
+	    || padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_WTMIC_
+	    || padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)
+		/* WPS open need to enable multicast
+		 * || check_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS) == _TRUE) */
+		rtw_hal_set_hwreg(padapter, HW_VAR_OFF_RCR_AM, null_addr);
+
+
+exit:
+
+	if (buf)
+		rtw_mfree(buf, ielen);
+
+	return ret;
+}
+
+static int rtw_wx_get_name(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u16 cap;
+	u32 ht_ielen = 0;
+	char *p;
+	u8 ht_cap = _FALSE, vht_cap = _FALSE;
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;
+	NDIS_802_11_RATES_EX *prates = NULL;
+
+
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED | WIFI_ADHOC_MASTER_STATE) == _TRUE) {
+		/* parsing HT_CAP_IE */
+		p = rtw_get_ie(&pcur_bss->IEs[12], _HT_CAPABILITY_IE_, &ht_ielen, pcur_bss->IELength - 12);
+		if (p && ht_ielen > 0)
+			ht_cap = _TRUE;
+
+#ifdef CONFIG_80211AC_VHT
+		if (pmlmepriv->vhtpriv.vht_option == _TRUE)
+			vht_cap = _TRUE;
+#endif
+
+		prates = &pcur_bss->SupportedRates;
+
+		if (rtw_is_cckratesonly_included((u8 *)prates) == _TRUE) {
+			if (ht_cap == _TRUE)
+				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bn");
+			else
+				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11b");
+		} else if ((rtw_is_cckrates_included((u8 *)prates)) == _TRUE) {
+			if (ht_cap == _TRUE)
+				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bgn");
+			else
+				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bg");
+		} else {
+			if (pcur_bss->Configuration.DSConfig > 14) {
+#ifdef CONFIG_80211AC_VHT
+				if (vht_cap == _TRUE)
+					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11AC");
+				else
+#endif
+				{
+					if (ht_cap == _TRUE)
+						snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11an");
+					else
+						snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11a");
+				}
+			} else {
+				if (ht_cap == _TRUE)
+					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11gn");
+				else
+					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11g");
+			}
+		}
+	} else {
+		/* prates = &padapter->registrypriv.dev_network.SupportedRates; */
+		/* snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11g"); */
+		snprintf(wrqu->name, IFNAMSIZ, "unassociated");
+	}
+
+
+	return 0;
+}
+
+static int rtw_wx_set_freq(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
+	int exp = 1, freq = 0, div = 0;
+
+
+	rtw_ps_deny(padapter, PS_DENY_IOCTL);
+	if (rtw_pwr_wakeup(padapter) == _FALSE)
+		goto exit;
+	if (wrqu->freq.m <= 1000) {
+		if (wrqu->freq.flags == IW_FREQ_AUTO) {
+			if (rtw_chset_search_ch(adapter_to_chset(padapter), wrqu->freq.m) > 0) {
+				padapter->mlmeextpriv.cur_channel = wrqu->freq.m;
+				RTW_INFO("%s: channel is auto, set to channel %d\n", __func__, wrqu->freq.m);
+			} else {
+				padapter->mlmeextpriv.cur_channel = 1;
+				RTW_INFO("%s: channel is auto, Channel Plan don't match just set to channel 1\n", __func__);
+			}
+		} else {
+			padapter->mlmeextpriv.cur_channel = wrqu->freq.m;
+			RTW_INFO("%s: set to channel %d\n", __func__, padapter->mlmeextpriv.cur_channel);
+		}
+	} else {
+		while (wrqu->freq.e) {
+			exp *= 10;
+			wrqu->freq.e--;
+		}
+
+		freq = wrqu->freq.m;
+
+		while (!(freq % 10)) {
+			freq /= 10;
+			exp *= 10;
+		}
+
+		/* freq unit is MHz here */
+		div = 1000000 / exp;
+
+		if (div)
+			freq /= div;
+		else {
+			div = exp / 1000000;
+			freq *= div;
+		}
+
+		/* If freq is invalid, rtw_freq2ch() will return channel 1 */
+		padapter->mlmeextpriv.cur_channel = rtw_freq2ch(freq);
+		RTW_INFO("%s: set to channel %d\n", __func__, padapter->mlmeextpriv.cur_channel);
+	}
+	set_channel_bwmode(padapter, padapter->mlmeextpriv.cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+exit:
+	rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+
+	return 0;
+}
+
+static int rtw_wx_get_freq(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE && check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) != _TRUE) {
+
+		wrqu->freq.m = rtw_ch2freq(pcur_bss->Configuration.DSConfig) * 100000;
+		wrqu->freq.e = 1;
+		wrqu->freq.i = pcur_bss->Configuration.DSConfig;
+
+	} else {
+		wrqu->freq.m = rtw_ch2freq(padapter->mlmeextpriv.cur_channel) * 100000;
+		wrqu->freq.e = 1;
+		wrqu->freq.i = padapter->mlmeextpriv.cur_channel;
+	}
+
+	return 0;
+}
+
+static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,
+			   union iwreq_data *wrqu, char *b)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType ;
+	int ret = 0;
+
+
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EPERM;
+		goto exit;
+	}
+
+	if (!rtw_is_hw_init_completed(padapter)) {
+		ret = -EPERM;
+		goto exit;
+	}
+
+	/* initial default type */
+	dev->type = ARPHRD_ETHER;
+
+	if (wrqu->mode == IW_MODE_MONITOR) {
+		rtw_ps_deny(padapter, PS_DENY_MONITOR_MODE);
+		LeaveAllPowerSaveMode(padapter);
+	} else {
+		rtw_ps_deny_cancel(padapter, PS_DENY_MONITOR_MODE);
+	}
+
+	switch (wrqu->mode) {
+	case IW_MODE_MONITOR:
+		networkType = Ndis802_11Monitor;
+#if 0
+		dev->type = ARPHRD_IEEE80211; /* IEEE 802.11 : 801 */
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
+		dev->type = ARPHRD_IEEE80211_RADIOTAP; /* IEEE 802.11 + radiotap header : 803 */
+		RTW_INFO("set_mode = IW_MODE_MONITOR\n");
+#else
+		RTW_INFO("kernel version < 2.6.24 not support IW_MODE_MONITOR\n");
+#endif
+		break;
+
+	case IW_MODE_AUTO:
+		networkType = Ndis802_11AutoUnknown;
+		RTW_INFO("set_mode = IW_MODE_AUTO\n");
+		break;
+	case IW_MODE_ADHOC:
+		networkType = Ndis802_11IBSS;
+		RTW_INFO("set_mode = IW_MODE_ADHOC\n");
+		break;
+	case IW_MODE_MASTER:
+		networkType = Ndis802_11APMode;
+		RTW_INFO("set_mode = IW_MODE_MASTER\n");
+		break;
+	case IW_MODE_INFRA:
+		networkType = Ndis802_11Infrastructure;
+		RTW_INFO("set_mode = IW_MODE_INFRA\n");
+		break;
+
+	default:
+		ret = -EINVAL;;
+		goto exit;
+	}
+
+	if (rtw_set_802_11_infrastructure_mode(padapter, networkType) == _FALSE) {
+
+		ret = -EPERM;
+		goto exit;
+
+	}
+
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
+
+	if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE)
+		rtw_indicate_connect(padapter);
+
+exit:
+
+
+	return ret;
+
+}
+
+static int rtw_wx_get_mode(struct net_device *dev, struct iw_request_info *a,
+			   union iwreq_data *wrqu, char *b)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+
+
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+		wrqu->mode = IW_MODE_INFRA;
+	else if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
+		 (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
+
+		wrqu->mode = IW_MODE_ADHOC;
+	else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
+		wrqu->mode = IW_MODE_MASTER;
+	else if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE)
+		wrqu->mode = IW_MODE_MONITOR;
+	else
+		wrqu->mode = IW_MODE_AUTO;
+
+
+	return 0;
+
+}
+
+
+static int rtw_wx_set_pmkid(struct net_device *dev,
+			    struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8          j, blInserted = _FALSE;
+	int         intReturn = _FALSE;
+	struct mlme_priv  *pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct iw_pmksa  *pPMK = (struct iw_pmksa *) extra;
+	u8     strZeroMacAddress[ETH_ALEN] = { 0x00 };
+	u8     strIssueBssid[ETH_ALEN] = { 0x00 };
+
+#if 0
+	struct iw_pmksa {
+		__u32   cmd;
+		struct sockaddr bssid;
+		__u8    pmkid[IW_PMKID_LEN];   /* IW_PMKID_LEN=16 */
+	}
+	There are the BSSID information in the bssid.sa_data array.
+	If cmd is IW_PMKSA_FLUSH, it means the wpa_suppplicant wants to clear all the PMKID information.
+	If cmd is IW_PMKSA_ADD, it means the wpa_supplicant wants to add a PMKID / BSSID to driver.
+	If cmd is IW_PMKSA_REMOVE, it means the wpa_supplicant wants to remove a PMKID / BSSID from driver.
+#endif
+
+	_rtw_memcpy(strIssueBssid, pPMK->bssid.sa_data, ETH_ALEN);
+	if (pPMK->cmd == IW_PMKSA_ADD) {
+		RTW_INFO("[rtw_wx_set_pmkid] IW_PMKSA_ADD!\n");
+		if (_rtw_memcmp(strIssueBssid, strZeroMacAddress, ETH_ALEN) == _TRUE)
+			return intReturn ;
+		else
+			intReturn = _TRUE;
+		blInserted = _FALSE;
+
+		/* overwrite PMKID */
+		for (j = 0 ; j < NUM_PMKID_CACHE; j++) {
+			if (_rtw_memcmp(psecuritypriv->PMKIDList[j].Bssid, strIssueBssid, ETH_ALEN) == _TRUE) {
+				/* BSSID is matched, the same AP => rewrite with new PMKID. */
+
+				RTW_INFO("[rtw_wx_set_pmkid] BSSID exists in the PMKList.\n");
+
+				_rtw_memcpy(psecuritypriv->PMKIDList[j].PMKID, pPMK->pmkid, IW_PMKID_LEN);
+				psecuritypriv->PMKIDList[j].bUsed = _TRUE;
+				psecuritypriv->PMKIDIndex = j + 1;
+				blInserted = _TRUE;
+				break;
+			}
+		}
+
+		if (!blInserted) {
+			/* Find a new entry */
+			RTW_INFO("[rtw_wx_set_pmkid] Use the new entry index = %d for this PMKID.\n",
+				 psecuritypriv->PMKIDIndex);
+
+			_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].Bssid, strIssueBssid, ETH_ALEN);
+			_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].PMKID, pPMK->pmkid, IW_PMKID_LEN);
+
+			psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].bUsed = _TRUE;
+			psecuritypriv->PMKIDIndex++ ;
+			if (psecuritypriv->PMKIDIndex == 16)
+				psecuritypriv->PMKIDIndex = 0;
+		}
+	} else if (pPMK->cmd == IW_PMKSA_REMOVE) {
+		RTW_INFO("[rtw_wx_set_pmkid] IW_PMKSA_REMOVE!\n");
+		intReturn = _TRUE;
+		for (j = 0 ; j < NUM_PMKID_CACHE; j++) {
+			if (_rtw_memcmp(psecuritypriv->PMKIDList[j].Bssid, strIssueBssid, ETH_ALEN) == _TRUE) {
+				/* BSSID is matched, the same AP => Remove this PMKID information and reset it. */
+				_rtw_memset(psecuritypriv->PMKIDList[j].Bssid, 0x00, ETH_ALEN);
+				psecuritypriv->PMKIDList[j].bUsed = _FALSE;
+				break;
+			}
+		}
+	} else if (pPMK->cmd == IW_PMKSA_FLUSH) {
+		RTW_INFO("[rtw_wx_set_pmkid] IW_PMKSA_FLUSH!\n");
+		_rtw_memset(&psecuritypriv->PMKIDList[0], 0x00, sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
+		psecuritypriv->PMKIDIndex = 0;
+		intReturn = _TRUE;
+	}
+	return intReturn ;
+}
+
+static int rtw_wx_get_sens(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+#ifdef CONFIG_PLATFORM_ROCKCHIPS
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	/*
+	*  20110311 Commented by Jeff
+	*  For rockchip platform's wpa_driver_wext_get_rssi
+	*/
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		/* wrqu->sens.value=-padapter->recvpriv.signal_strength; */
+		wrqu->sens.value = -padapter->recvpriv.rssi;
+		/* RTW_INFO("%s: %d\n", __FUNCTION__, wrqu->sens.value); */
+		wrqu->sens.fixed = 0; /* no auto select */
+	} else
+#endif
+	{
+		wrqu->sens.value = 0;
+		wrqu->sens.fixed = 0;	/* no auto select */
+		wrqu->sens.disabled = 1;
+	}
+	return 0;
+}
+
+static int rtw_wx_get_range(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+	struct iw_range *range = (struct iw_range *)extra;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+
+	u16 val;
+	int i;
+
+
+
+	wrqu->data.length = sizeof(*range);
+	_rtw_memset(range, 0, sizeof(*range));
+
+	/* Let's try to keep this struct in the same order as in
+	 * linux/include/wireless.h
+	 */
+
+	/* TODO: See what values we can set, and remove the ones we can't
+	 * set, or fill them with some default data.
+	 */
+
+	/* ~5 Mb/s real (802.11b) */
+	range->throughput = 5 * 1000 * 1000;
+
+	/* TODO: Not used in 802.11b?
+	*	range->min_nwid;	 Minimal NWID we are able to set  */
+	/* TODO: Not used in 802.11b?
+	*	range->max_nwid;	 Maximal NWID we are able to set  */
+
+	/* Old Frequency (backward compat - moved lower ) */
+	/*	range->old_num_channels;
+	 *	range->old_num_frequency;
+	 * 	range->old_freq[6];  Filler to keep "version" at the same offset  */
+
+	/* signal level threshold range */
+
+	/* Quality of link & SNR stuff */
+	/* Quality range (link, level, noise)
+	 * If the quality is absolute, it will be in the range [0 ; max_qual],
+	 * if the quality is dBm, it will be in the range [max_qual ; 0].
+	 * Don't forget that we use 8 bit arithmetics...
+	 *
+	 * If percentage range is 0~100
+	 * Signal strength dbm range logical is -100 ~ 0
+	 * but usually value is -90 ~ -20
+	 * When CONFIG_SIGNAL_SCALE_MAPPING is defined, dbm range is -95 ~ -45
+	 */
+	range->max_qual.qual = 100;
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+	range->max_qual.level = (u8)-100;
+	range->max_qual.noise = (u8)-100;
+	range->max_qual.updated = IW_QUAL_ALL_UPDATED; /* Updated all three */
+	range->max_qual.updated |= IW_QUAL_DBM;
+#else /* !CONFIG_SIGNAL_DISPLAY_DBM */
+	/* percent values between 0 and 100. */
+	range->max_qual.level = 100;
+	range->max_qual.noise = 100;
+	range->max_qual.updated = IW_QUAL_ALL_UPDATED; /* Updated all three */
+#endif /* !CONFIG_SIGNAL_DISPLAY_DBM */
+
+	/* This should contain the average/typical values of the quality
+	 * indicator. This should be the threshold between a "good" and
+	 * a "bad" link (example : monitor going from green to orange).
+	 * Currently, user space apps like quality monitors don't have any
+	 * way to calibrate the measurement. With this, they can split
+	 * the range between 0 and max_qual in different quality level
+	 * (using a geometric subdivision centered on the average).
+	 * I expect that people doing the user space apps will feedback
+	 * us on which value we need to put in each driver... */
+	range->avg_qual.qual = 92; /* > 8% missed beacons is 'bad' */
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+	/* TODO: Find real 'good' to 'bad' threshold value for RSSI */
+	range->avg_qual.level = (u8)-70;
+	range->avg_qual.noise = 0;
+	range->avg_qual.updated = IW_QUAL_ALL_UPDATED; /* Updated all three */
+	range->avg_qual.updated |= IW_QUAL_DBM;
+#else /* !CONFIG_SIGNAL_DISPLAY_DBM */
+	/* TODO: Find real 'good' to 'bad' threshol value for RSSI */
+	range->avg_qual.level = 30;
+	range->avg_qual.noise = 100;
+	range->avg_qual.updated = IW_QUAL_ALL_UPDATED; /* Updated all three */
+#endif /* !CONFIG_SIGNAL_DISPLAY_DBM */
+
+	range->num_bitrates = RATE_COUNT;
+
+	for (i = 0; i < RATE_COUNT && i < IW_MAX_BITRATES; i++)
+		range->bitrate[i] = rtw_rates[i];
+
+	range->min_frag = MIN_FRAG_THRESHOLD;
+	range->max_frag = MAX_FRAG_THRESHOLD;
+
+	range->pm_capa = 0;
+
+	range->we_version_compiled = WIRELESS_EXT;
+	range->we_version_source = 16;
+
+	/*	range->retry_capa;	 What retry options are supported
+	 *	range->retry_flags;	 How to decode max/min retry limit
+	 *	range->r_time_flags;	 How to decode max/min retry life
+	 *	range->min_retry;	 Minimal number of retries
+	 *	range->max_retry;	 Maximal number of retries
+	 *	range->min_r_time;	 Minimal retry lifetime
+	 *	range->max_r_time;	 Maximal retry lifetime  */
+
+	for (i = 0, val = 0; i < rfctl->max_chan_nums; i++) {
+
+		/* Include only legal frequencies for some countries */
+		if (rfctl->channel_set[i].ChannelNum != 0) {
+			range->freq[val].i = rfctl->channel_set[i].ChannelNum;
+			range->freq[val].m = rtw_ch2freq(rfctl->channel_set[i].ChannelNum) * 100000;
+			range->freq[val].e = 1;
+			val++;
+		}
+
+		if (val == IW_MAX_FREQUENCIES)
+			break;
+	}
+
+	range->num_channels = val;
+	range->num_frequency = val;
+
+	/* Commented by Albert 2009/10/13
+	 * The following code will proivde the security capability to network manager.
+	 * If the driver doesn't provide this capability to network manager,
+	 * the WPA/WPA2 routers can't be choosen in the network manager. */
+
+	/*
+	#define IW_SCAN_CAPA_NONE		0x00
+	#define IW_SCAN_CAPA_ESSID		0x01
+	#define IW_SCAN_CAPA_BSSID		0x02
+	#define IW_SCAN_CAPA_CHANNEL	0x04
+	#define IW_SCAN_CAPA_MODE		0x08
+	#define IW_SCAN_CAPA_RATE		0x10
+	#define IW_SCAN_CAPA_TYPE		0x20
+	#define IW_SCAN_CAPA_TIME		0x40
+	*/
+
+#if WIRELESS_EXT > 17
+	range->enc_capa = IW_ENC_CAPA_WPA | IW_ENC_CAPA_WPA2 |
+			  IW_ENC_CAPA_CIPHER_TKIP | IW_ENC_CAPA_CIPHER_CCMP;
+#endif
+
+#ifdef IW_SCAN_CAPA_ESSID /* WIRELESS_EXT > 21 */
+	range->scan_capa = IW_SCAN_CAPA_ESSID | IW_SCAN_CAPA_TYPE | IW_SCAN_CAPA_BSSID |
+		   IW_SCAN_CAPA_CHANNEL | IW_SCAN_CAPA_MODE | IW_SCAN_CAPA_RATE;
+#endif
+
+
+
+	return 0;
+
+}
+
+/* set bssid flow
+ * s1. rtw_set_802_11_infrastructure_mode()
+ * s2. rtw_set_802_11_authentication_mode()
+ * s3. set_802_11_encryption_mode()
+ * s4. rtw_set_802_11_bssid() */
+static int rtw_wx_set_wap(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *awrq,
+			  char *extra)
+{
+	_irqL	irqL;
+	uint ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sockaddr *temp = (struct sockaddr *)awrq;
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	_list	*phead;
+	u8 *dst_bssid, *src_bssid;
+	_queue	*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network	*pnetwork = NULL;
+	NDIS_802_11_AUTHENTICATION_MODE	authmode;
+
+	/*
+	#ifdef CONFIG_CONCURRENT_MODE
+		if(padapter->adapter_type > PRIMARY_IFACE)
+		{
+			ret = -EINVAL;
+			goto exit;
+		}
+	#endif
+	*/
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("set bssid, but buddy_intf is under scanning or linking\n");
+
+		ret = -EINVAL;
+
+		goto exit;
+	}
+#endif
+
+	rtw_ps_deny(padapter, PS_DENY_JOIN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+	if (!padapter->bup) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+
+	if (temp->sa_family != ARPHRD_ETHER) {
+		ret = -EINVAL;
+		goto cancel_ps_deny;
+	}
+
+	authmode = padapter->securitypriv.ndisauthtype;
+	_enter_critical_bh(&queue->lock, &irqL);
+	phead = get_list_head(queue);
+	pmlmepriv->pscanned = get_next(phead);
+
+	while (1) {
+
+		if ((rtw_end_of_queue_search(phead, pmlmepriv->pscanned)) == _TRUE) {
+#if 0
+			ret = -EINVAL;
+			goto cancel_ps_deny;
+
+			if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+				rtw_set_802_11_bssid(padapter, temp->sa_data);
+				goto cancel_ps_deny;
+			} else {
+				ret = -EINVAL;
+				goto cancel_ps_deny;
+			}
+#endif
+
+			break;
+		}
+
+		pnetwork = LIST_CONTAINOR(pmlmepriv->pscanned, struct wlan_network, list);
+
+		pmlmepriv->pscanned = get_next(pmlmepriv->pscanned);
+
+		dst_bssid = pnetwork->network.MacAddress;
+
+		src_bssid = temp->sa_data;
+
+		if ((_rtw_memcmp(dst_bssid, src_bssid, ETH_ALEN)) == _TRUE) {
+			if (!rtw_set_802_11_infrastructure_mode(padapter, pnetwork->network.InfrastructureMode)) {
+				ret = -1;
+				_exit_critical_bh(&queue->lock, &irqL);
+				goto cancel_ps_deny;
+			}
+
+			break;
+		}
+
+	}
+	_exit_critical_bh(&queue->lock, &irqL);
+
+	rtw_set_802_11_authentication_mode(padapter, authmode);
+	/* set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus); */
+	if (rtw_set_802_11_bssid(padapter, temp->sa_data) == _FALSE) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
+
+exit:
+	return ret;
+}
+
+static int rtw_wx_get_wap(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;
+
+	wrqu->ap_addr.sa_family = ARPHRD_ETHER;
+
+	_rtw_memset(wrqu->ap_addr.sa_data, 0, ETH_ALEN);
+
+
+
+	if (((check_fwstate(pmlmepriv, _FW_LINKED)) == _TRUE) ||
+	    ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) == _TRUE) ||
+	    ((check_fwstate(pmlmepriv, WIFI_AP_STATE)) == _TRUE))
+
+		_rtw_memcpy(wrqu->ap_addr.sa_data, pcur_bss->MacAddress, ETH_ALEN);
+	else
+		_rtw_memset(wrqu->ap_addr.sa_data, 0, ETH_ALEN);
+
+
+	return 0;
+
+}
+
+static int rtw_wx_set_mlme(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+#if 0
+	/* SIOCSIWMLME data */
+	struct	iw_mlme {
+		__u16		cmd; /* IW_MLME_* */
+		__u16		reason_code;
+		struct sockaddr	addr;
+	};
+#endif
+
+	int ret = 0;
+	u16 reason;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_mlme *mlme = (struct iw_mlme *) extra;
+
+
+	if (mlme == NULL)
+		return -1;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	reason = cpu_to_le16(mlme->reason_code);
+
+
+	RTW_INFO("%s, cmd=%d, reason=%d\n", __FUNCTION__, mlme->cmd, reason);
+
+
+	switch (mlme->cmd) {
+	case IW_MLME_DEAUTH:
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
+		break;
+
+	case IW_MLME_DISASSOC:
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
+
+		break;
+
+	default:
+		return -EOPNOTSUPP;
+	}
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_do_disconnect(padapter);
+#endif
+	return ret;
+}
+
+static int rtw_wx_set_scan(struct net_device *dev, struct iw_request_info *a,
+			   union iwreq_data *wrqu, char *extra)
+{
+	u8 _status = _FALSE;
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct sitesurvey_parm parm;
+
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
+
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d\n", __FUNCTION__, __LINE__);
+#endif
+
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block Scan request\n");
+		ret = -EPERM;
+		goto exit;
+	}
+#endif
+	if (rtw_is_scan_deny(padapter)) {
+		indicate_wx_scan_complete_event(padapter);
+		goto exit;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+	if (!rtw_is_adapter_up(padapter)) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+#ifndef CONFIG_DOSCAN_IN_BUSYTRAFFIC
+	/* When Busy Traffic, driver do not site survey. So driver return success. */
+	/* wpa_supplicant will not issue SIOCSIWSCAN cmd again after scan timeout. */
+	/* modify by thomas 2011-02-22. */
+	if (rtw_mi_busy_traffic_check(padapter, _FALSE)) {
+		indicate_wx_scan_complete_event(padapter);
+		goto cancel_ps_deny;
+	}
+#endif
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
+		RTW_INFO(FUNC_ADPT_FMT" blocking scan for under rson scanning process\n", FUNC_ADPT_ARG(padapter));
+		indicate_wx_scan_complete_event(padapter);
+		goto cancel_ps_deny;
+	}
+#endif
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) && check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+		RTW_INFO("AP mode process WPS\n");
+		indicate_wx_scan_complete_event(padapter);
+		goto cancel_ps_deny;
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
+		indicate_wx_scan_complete_event(padapter);
+		goto cancel_ps_deny;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter,
+		       _FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
+
+		indicate_wx_scan_complete_event(padapter);
+		goto cancel_ps_deny;
+	}
+#endif
+
+#ifdef CONFIG_P2P
+	if (pwdinfo->p2p_state != P2P_STATE_NONE) {
+		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
+		rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_FULL);
+		rtw_free_network_queue(padapter, _TRUE);
+	}
+#endif /* CONFIG_P2P */
+
+#if WIRELESS_EXT >= 17
+	if (wrqu->data.length == sizeof(struct iw_scan_req)) {
+		struct iw_scan_req *req = (struct iw_scan_req *)extra;
+
+		if (wrqu->data.flags & IW_SCAN_THIS_ESSID) {
+			int len = min((int)req->essid_len, IW_ESSID_MAX_SIZE);
+
+			rtw_init_sitesurvey_parm(padapter, &parm);
+			_rtw_memcpy(&parm.ssid[0].Ssid, &req->essid, len);
+			parm.ssid[0].SsidLength = len;
+			parm.ssid_num = 1;
+
+			RTW_INFO("IW_SCAN_THIS_ESSID, ssid=%s, len=%d\n", req->essid, req->essid_len);
+
+			_status = rtw_set_802_11_bssid_list_scan(padapter, &parm);
+
+		} else if (req->scan_type == IW_SCAN_TYPE_PASSIVE)
+			RTW_INFO("rtw_wx_set_scan, req->scan_type == IW_SCAN_TYPE_PASSIVE\n");
+
+	} else
+#endif
+
+		if (wrqu->data.length >= WEXT_CSCAN_HEADER_SIZE
+		    && _rtw_memcmp(extra, WEXT_CSCAN_HEADER, WEXT_CSCAN_HEADER_SIZE) == _TRUE
+		   ) {
+			int len = wrqu->data.length - WEXT_CSCAN_HEADER_SIZE;
+			char *pos = extra + WEXT_CSCAN_HEADER_SIZE;
+			char section;
+			char sec_len;
+			int ssid_index = 0;
+
+			/* RTW_INFO("%s COMBO_SCAN header is recognized\n", __FUNCTION__); */
+			rtw_init_sitesurvey_parm(padapter, &parm);
+
+			while (len >= 1) {
+				section = *(pos++);
+				len -= 1;
+
+				switch (section) {
+				case WEXT_CSCAN_SSID_SECTION:
+					/* RTW_INFO("WEXT_CSCAN_SSID_SECTION\n"); */
+					if (len < 1) {
+						len = 0;
+						break;
+					}
+
+					sec_len = *(pos++);
+					len -= 1;
+
+					if (sec_len > 0 && sec_len <= len) {
+
+						parm.ssid[ssid_index].SsidLength = sec_len;
+						_rtw_memcpy(&parm.ssid[ssid_index].Ssid, pos, sec_len);
+
+						/* RTW_INFO("%s COMBO_SCAN with specific parm.ssid:%s, %d\n", __FUNCTION__ */
+						/*	, parm.ssid[ssid_index].Ssid, parm.ssid[ssid_index].SsidLength); */
+						ssid_index++;
+					}
+
+					pos += sec_len;
+					len -= sec_len;
+					break;
+
+
+				case WEXT_CSCAN_CHANNEL_SECTION:
+					/* RTW_INFO("WEXT_CSCAN_CHANNEL_SECTION\n"); */
+					pos += 1;
+					len -= 1;
+					break;
+				case WEXT_CSCAN_ACTV_DWELL_SECTION:
+					/* RTW_INFO("WEXT_CSCAN_ACTV_DWELL_SECTION\n"); */
+					pos += 2;
+					len -= 2;
+					break;
+				case WEXT_CSCAN_PASV_DWELL_SECTION:
+					/* RTW_INFO("WEXT_CSCAN_PASV_DWELL_SECTION\n"); */
+					pos += 2;
+					len -= 2;
+					break;
+				case WEXT_CSCAN_HOME_DWELL_SECTION:
+					/* RTW_INFO("WEXT_CSCAN_HOME_DWELL_SECTION\n"); */
+					pos += 2;
+					len -= 2;
+					break;
+				case WEXT_CSCAN_TYPE_SECTION:
+					/* RTW_INFO("WEXT_CSCAN_TYPE_SECTION\n"); */
+					pos += 1;
+					len -= 1;
+					break;
+#if 0
+				case WEXT_CSCAN_NPROBE_SECTION:
+					RTW_INFO("WEXT_CSCAN_NPROBE_SECTION\n");
+					break;
+#endif
+
+				default:
+					/* RTW_INFO("Unknown CSCAN section %c\n", section); */
+					len = 0; /* stop parsing */
+				}
+				/* RTW_INFO("len:%d\n", len); */
+
+			}
+			parm.ssid_num = ssid_index;
+
+			/* jeff: it has still some scan paramater to parse, we only do this now... */
+			_status = rtw_set_802_11_bssid_list_scan(padapter, &parm);
+
+		} else
+
+			_status = rtw_set_802_11_bssid_list_scan(padapter, NULL);
+
+	if (_status == _FALSE)
+		ret = -1;
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
+
+exit:
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d return %d\n", __FUNCTION__, __LINE__, ret);
+#endif
+
+	return ret;
+}
+
+static int rtw_wx_get_scan(struct net_device *dev, struct iw_request_info *a,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_irqL	irqL;
+	_list					*plist, *phead;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	_queue				*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network	*pnetwork = NULL;
+	char *ev = extra;
+	char *stop = ev + wrqu->data.length;
+	u32 ret = 0;
+	u32 cnt = 0;
+	u32 wait_for_surveydone;
+	sint wait_status;
+
+#ifdef CONFIG_P2P
+	struct	wifidirect_info	*pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
+
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d\n", __FUNCTION__, __LINE__);
+#endif
+
+	if (adapter_to_pwrctl(padapter)->brfoffbyhw && rtw_is_drv_stopped(padapter)) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+		wait_for_surveydone = 200;
+	else {
+		/*	P2P is disabled */
+		wait_for_surveydone = 100;
+	}
+#else
+	{
+		wait_for_surveydone = 100;
+	}
+#endif /* CONFIG_P2P */
+
+#if 1 /* Wireless Extension use EAGAIN to try */
+	wait_status = _FW_UNDER_SURVEY
+#ifndef CONFIG_ANDROID
+		      | _FW_UNDER_LINKING
+#endif
+		      ;
+
+	while (check_fwstate(pmlmepriv, wait_status) == _TRUE)
+		return -EAGAIN;
+#else
+	wait_status = _FW_UNDER_SURVEY
+#ifndef CONFIG_ANDROID
+		      | _FW_UNDER_LINKING
+#endif
+		      ;
+
+	while (check_fwstate(pmlmepriv, wait_status) == _TRUE) {
+		rtw_msleep_os(30);
+		cnt++;
+		if (cnt > wait_for_surveydone)
+			break;
+	}
+#endif
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		if ((stop - ev) < SCAN_ITEM_SIZE) {
+			ret = -E2BIG;
+			break;
+		}
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		/* report network only if the current channel set contains the channel to which this network belongs */
+		if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
+		    && rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
+		    && _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
+		   )
+			ev = translate_scan(padapter, a, pnetwork, ev, stop);
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	wrqu->data.length = ev - extra;
+	wrqu->data.flags = 0;
+
+exit:
+
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d return %d\n", __FUNCTION__, __LINE__, ret);
+#endif
+
+	return ret ;
+
+}
+
+/* set ssid flow
+ * s1. rtw_set_802_11_infrastructure_mode()
+ * s2. set_802_11_authenticaion_mode()
+ * s3. set_802_11_encryption_mode()
+ * s4. rtw_set_802_11_ssid() */
+static int rtw_wx_set_essid(struct net_device *dev,
+			    struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *extra)
+{
+	_irqL irqL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	_queue *queue = &pmlmepriv->scanned_queue;
+	_list *phead;
+	s8 status = _TRUE;
+	struct wlan_network *pnetwork = NULL;
+	NDIS_802_11_AUTHENTICATION_MODE authmode;
+	NDIS_802_11_SSID ndis_ssid;
+	u8 *dst_ssid, *src_ssid;
+
+	uint ret = 0, len;
+
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d\n", __FUNCTION__, __LINE__);
+#endif
+#ifdef CONFIG_WEXT_DONT_JOIN_BYSSID
+	RTW_INFO("%s: CONFIG_WEXT_DONT_JOIN_BYSSID be defined!! only allow bssid joining\n", __func__);
+	return -EPERM;
+#endif
+
+#if WIRELESS_EXT <= 20
+	if ((wrqu->essid.length - 1) > IW_ESSID_MAX_SIZE) {
+#else
+	if (wrqu->essid.length > IW_ESSID_MAX_SIZE) {
+#endif
+		ret = -E2BIG;
+		goto exit;
+	}
+
+
+
+	rtw_ps_deny(padapter, PS_DENY_JOIN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+	if (!padapter->bup) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_SURVEY | _FW_UNDER_LINKING)) {
+		RTW_INFO("set ssid, but buddy_intf is under scanning or linking\n");
+		ret = -EINVAL;
+		goto cancel_ps_deny;
+	}
+#endif
+	authmode = padapter->securitypriv.ndisauthtype;
+	RTW_INFO("=>%s\n", __FUNCTION__);
+	if (wrqu->essid.flags && wrqu->essid.length) {
+		/* Commented by Albert 20100519 */
+		/* We got the codes in "set_info" function of iwconfig source code. */
+		/*	========================================= */
+		/*	wrq.u.essid.length = strlen(essid) + 1; */
+		/*	if(we_kernel_version > 20) */
+		/*		wrq.u.essid.length--; */
+		/*	========================================= */
+		/*	That means, if the WIRELESS_EXT less than or equal to 20, the correct ssid len should subtract 1. */
+#if WIRELESS_EXT <= 20
+		len = ((wrqu->essid.length - 1) < IW_ESSID_MAX_SIZE) ? (wrqu->essid.length - 1) : IW_ESSID_MAX_SIZE;
+#else
+		len = (wrqu->essid.length < IW_ESSID_MAX_SIZE) ? wrqu->essid.length : IW_ESSID_MAX_SIZE;
+#endif
+
+		if (wrqu->essid.length != 33)
+			RTW_INFO("ssid=%s, len=%d\n", extra, wrqu->essid.length);
+
+		_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));
+		ndis_ssid.SsidLength = len;
+		_rtw_memcpy(ndis_ssid.Ssid, extra, len);
+		src_ssid = ndis_ssid.Ssid;
+
+		_enter_critical_bh(&queue->lock, &irqL);
+		phead = get_list_head(queue);
+		pmlmepriv->pscanned = get_next(phead);
+
+		while (1) {
+			if (rtw_end_of_queue_search(phead, pmlmepriv->pscanned) == _TRUE) {
+#if 0
+				if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+					rtw_set_802_11_ssid(padapter, &ndis_ssid);
+
+					goto cancel_ps_deny;
+				} else {
+					ret = -EINVAL;
+					goto cancel_ps_deny;
+				}
+#endif
+
+				break;
+			}
+
+			pnetwork = LIST_CONTAINOR(pmlmepriv->pscanned, struct wlan_network, list);
+
+			pmlmepriv->pscanned = get_next(pmlmepriv->pscanned);
+
+			dst_ssid = pnetwork->network.Ssid.Ssid;
+
+
+			if ((_rtw_memcmp(dst_ssid, src_ssid, ndis_ssid.SsidLength) == _TRUE) &&
+			    (pnetwork->network.Ssid.SsidLength == ndis_ssid.SsidLength)) {
+
+				if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+					if (pnetwork->network.InfrastructureMode != pmlmepriv->cur_network.network.InfrastructureMode)
+						continue;
+				}
+
+				if (rtw_set_802_11_infrastructure_mode(padapter, pnetwork->network.InfrastructureMode) == _FALSE) {
+					ret = -1;
+					_exit_critical_bh(&queue->lock, &irqL);
+					goto cancel_ps_deny;
+				}
+
+				break;
+			}
+		}
+		_exit_critical_bh(&queue->lock, &irqL);
+		rtw_set_802_11_authentication_mode(padapter, authmode);
+		/* set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus); */
+		if (rtw_set_802_11_ssid(padapter, &ndis_ssid) == _FALSE) {
+			ret = -1;
+			goto cancel_ps_deny;
+		}
+	}
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
+
+exit:
+	RTW_INFO("<=%s, ret %d\n", __FUNCTION__, ret);
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d return %d\n", __FUNCTION__, __LINE__, ret);
+#endif
+
+
+	return ret;
+}
+
+static int rtw_wx_get_essid(struct net_device *dev,
+			    struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *extra)
+{
+	u32 len, ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;
+
+
+
+	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
+		len = pcur_bss->Ssid.SsidLength;
+
+		wrqu->essid.length = len;
+
+		_rtw_memcpy(extra, pcur_bss->Ssid.Ssid, len);
+
+		wrqu->essid.flags = 1;
+	} else {
+		ret = -1;
+		goto exit;
+	}
+
+exit:
+
+
+	return ret;
+
+}
+
+static int rtw_wx_set_rate(struct net_device *dev,
+			   struct iw_request_info *a,
+			   union iwreq_data *wrqu, char *extra)
+{
+	int	i, ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8	datarates[NumRates];
+	u32	target_rate = wrqu->bitrate.value;
+	u32	fixed = wrqu->bitrate.fixed;
+	u32	ratevalue = 0;
+	u8 mpdatarate[NumRates] = {11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 0xff};
+
+
+
+	if (target_rate == -1) {
+		ratevalue = 11;
+		goto set_rate;
+	}
+	target_rate = target_rate / 100000;
+
+	switch (target_rate) {
+	case 10:
+		ratevalue = 0;
+		break;
+	case 20:
+		ratevalue = 1;
+		break;
+	case 55:
+		ratevalue = 2;
+		break;
+	case 60:
+		ratevalue = 3;
+		break;
+	case 90:
+		ratevalue = 4;
+		break;
+	case 110:
+		ratevalue = 5;
+		break;
+	case 120:
+		ratevalue = 6;
+		break;
+	case 180:
+		ratevalue = 7;
+		break;
+	case 240:
+		ratevalue = 8;
+		break;
+	case 360:
+		ratevalue = 9;
+		break;
+	case 480:
+		ratevalue = 10;
+		break;
+	case 540:
+		ratevalue = 11;
+		break;
+	default:
+		ratevalue = 11;
+		break;
+	}
+
+set_rate:
+
+	for (i = 0; i < NumRates; i++) {
+		if (ratevalue == mpdatarate[i]) {
+			datarates[i] = mpdatarate[i];
+			if (fixed == 0)
+				break;
+		} else
+			datarates[i] = 0xff;
+
+	}
+
+	if (rtw_setdatarate_cmd(padapter, datarates) != _SUCCESS) {
+		ret = -1;
+	}
+
+
+	return ret;
+}
+
+static int rtw_wx_get_rate(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	u16 max_rate = 0;
+
+	max_rate = rtw_get_cur_max_rate((_adapter *)rtw_netdev_priv(dev));
+
+	if (max_rate == 0)
+		return -EPERM;
+
+	wrqu->bitrate.fixed = 0;	/* no auto select */
+	wrqu->bitrate.value = max_rate * 100000;
+
+	return 0;
+}
+
+static int rtw_wx_set_rts(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+
+	if (wrqu->rts.disabled)
+		padapter->registrypriv.rts_thresh = 2347;
+	else {
+		if (wrqu->rts.value < 0 ||
+		    wrqu->rts.value > 2347)
+			return -EINVAL;
+
+		padapter->registrypriv.rts_thresh = wrqu->rts.value;
+	}
+
+	RTW_INFO("%s, rts_thresh=%d\n", __func__, padapter->registrypriv.rts_thresh);
+
+
+	return 0;
+
+}
+
+static int rtw_wx_get_rts(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+
+	RTW_INFO("%s, rts_thresh=%d\n", __func__, padapter->registrypriv.rts_thresh);
+
+	wrqu->rts.value = padapter->registrypriv.rts_thresh;
+	wrqu->rts.fixed = 0;	/* no auto select */
+	/* wrqu->rts.disabled = (wrqu->rts.value == DEFAULT_RTS_THRESHOLD); */
+
+
+	return 0;
+}
+
+static int rtw_wx_set_frag(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+
+	if (wrqu->frag.disabled)
+		padapter->xmitpriv.frag_len = MAX_FRAG_THRESHOLD;
+	else {
+		if (wrqu->frag.value < MIN_FRAG_THRESHOLD ||
+		    wrqu->frag.value > MAX_FRAG_THRESHOLD)
+			return -EINVAL;
+
+		padapter->xmitpriv.frag_len = wrqu->frag.value & ~0x1;
+	}
+
+	RTW_INFO("%s, frag_len=%d\n", __func__, padapter->xmitpriv.frag_len);
+
+
+	return 0;
+
+}
+
+static int rtw_wx_get_frag(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+
+	RTW_INFO("%s, frag_len=%d\n", __func__, padapter->xmitpriv.frag_len);
+
+	wrqu->frag.value = padapter->xmitpriv.frag_len;
+	wrqu->frag.fixed = 0;	/* no auto select */
+	/* wrqu->frag.disabled = (wrqu->frag.value == DEFAULT_FRAG_THRESHOLD); */
+
+
+	return 0;
+}
+
+static int rtw_wx_get_retry(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev); */
+
+
+	wrqu->retry.value = 7;
+	wrqu->retry.fixed = 0;	/* no auto select */
+	wrqu->retry.disabled = 1;
+
+	return 0;
+
+}
+
+#if 0
+	#define IW_ENCODE_INDEX		0x00FF	/* Token index (if needed) */
+	#define IW_ENCODE_FLAGS		0xFF00	/* Flags defined below */
+	#define IW_ENCODE_MODE		0xF000	/* Modes defined below */
+	#define IW_ENCODE_DISABLED	0x8000	/* Encoding disabled */
+	#define IW_ENCODE_ENABLED	0x0000	/* Encoding enabled */
+	#define IW_ENCODE_RESTRICTED	0x4000	/* Refuse non-encoded packets */
+	#define IW_ENCODE_OPEN		0x2000	/* Accept non-encoded packets */
+	#define IW_ENCODE_NOKEY		0x0800  /* Key is write only, so not present */
+	#define IW_ENCODE_TEMP		0x0400  /* Temporary key */
+	/*
+	iwconfig wlan0 key on->flags = 0x6001->maybe it means auto
+	iwconfig wlan0 key off->flags = 0x8800
+	iwconfig wlan0 key open->flags = 0x2800
+	iwconfig wlan0 key open 1234567890->flags = 0x2000
+	iwconfig wlan0 key restricted->flags = 0x4800
+	iwconfig wlan0 key open [3] 1234567890->flags = 0x2003
+	iwconfig wlan0 key restricted [2] 1234567890->flags = 0x4002
+	iwconfig wlan0 key open [3] -> flags = 0x2803
+	iwconfig wlan0 key restricted [2] -> flags = 0x4802
+	*/
+#endif
+
+static int rtw_wx_set_enc(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *keybuf)
+{
+	u32 key, ret = 0;
+	u32 keyindex_provided;
+	NDIS_802_11_WEP	 wep;
+	NDIS_802_11_AUTHENTICATION_MODE authmode;
+
+	struct iw_point *erq = &(wrqu->encoding);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	RTW_INFO("+rtw_wx_set_enc, flags=0x%x\n", erq->flags);
+
+	_rtw_memset(&wep, 0, sizeof(NDIS_802_11_WEP));
+
+	key = erq->flags & IW_ENCODE_INDEX;
+
+
+	if (erq->flags & IW_ENCODE_DISABLED) {
+		RTW_INFO("EncryptionDisabled\n");
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+		authmode = Ndis802_11AuthModeOpen;
+		padapter->securitypriv.ndisauthtype = authmode;
+
+		goto exit;
+	}
+
+	if (key) {
+		if (key > WEP_KEYS)
+			return -EINVAL;
+		key--;
+		keyindex_provided = 1;
+	} else {
+		keyindex_provided = 0;
+		key = padapter->securitypriv.dot11PrivacyKeyIndex;
+		RTW_INFO("rtw_wx_set_enc, key=%d\n", key);
+	}
+
+	/* set authentication mode	 */
+	if (erq->flags & IW_ENCODE_OPEN) {
+		RTW_INFO("rtw_wx_set_enc():IW_ENCODE_OPEN\n");
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;/* Ndis802_11EncryptionDisabled; */
+
+#ifdef CONFIG_PLATFORM_MT53XX
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+#else
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
+#endif
+
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+		authmode = Ndis802_11AuthModeOpen;
+		padapter->securitypriv.ndisauthtype = authmode;
+	} else if (erq->flags & IW_ENCODE_RESTRICTED) {
+		RTW_INFO("rtw_wx_set_enc():IW_ENCODE_RESTRICTED\n");
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+
+#ifdef CONFIG_PLATFORM_MT53XX
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+#else
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Shared;
+#endif
+
+		padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _WEP40_;
+		authmode = Ndis802_11AuthModeShared;
+		padapter->securitypriv.ndisauthtype = authmode;
+	} else {
+		RTW_INFO("rtw_wx_set_enc():erq->flags=0x%x\n", erq->flags);
+
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;/* Ndis802_11EncryptionDisabled; */
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+		authmode = Ndis802_11AuthModeOpen;
+		padapter->securitypriv.ndisauthtype = authmode;
+	}
+
+	wep.KeyIndex = key;
+	if (erq->length > 0) {
+		wep.KeyLength = erq->length <= 5 ? 5 : 13;
+
+		wep.Length = wep.KeyLength + FIELD_OFFSET(NDIS_802_11_WEP, KeyMaterial);
+	} else {
+		wep.KeyLength = 0 ;
+
+		if (keyindex_provided == 1) { /* set key_id only, no given KeyMaterial(erq->length==0). */
+			padapter->securitypriv.dot11PrivacyKeyIndex = key;
+
+			RTW_INFO("(keyindex_provided == 1), keyid=%d, key_len=%d\n", key, padapter->securitypriv.dot11DefKeylen[key]);
+
+			switch (padapter->securitypriv.dot11DefKeylen[key]) {
+			case 5:
+				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+				break;
+			case 13:
+				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+				break;
+			default:
+				padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+				break;
+			}
+
+			goto exit;
+
+		}
+
+	}
+
+	wep.KeyIndex |= 0x80000000;
+
+	_rtw_memcpy(wep.KeyMaterial, keybuf, wep.KeyLength);
+
+	if (rtw_set_802_11_add_wep(padapter, &wep) == _FALSE) {
+		if (rf_on == pwrpriv->rf_pwrstate)
+			ret = -EOPNOTSUPP;
+		goto exit;
+	}
+
+exit:
+
+
+	return ret;
+
+}
+
+static int rtw_wx_get_enc(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *keybuf)
+{
+	uint key, ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *erq = &(wrqu->encoding);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED) != _TRUE) {
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) != _TRUE) {
+			erq->length = 0;
+			erq->flags |= IW_ENCODE_DISABLED;
+			return 0;
+		}
+	}
+
+
+	key = erq->flags & IW_ENCODE_INDEX;
+
+	if (key) {
+		if (key > WEP_KEYS)
+			return -EINVAL;
+		key--;
+	} else
+		key = padapter->securitypriv.dot11PrivacyKeyIndex;
+
+	erq->flags = key + 1;
+
+	/* if(padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeOpen) */
+	/* { */
+	/* erq->flags |= IW_ENCODE_OPEN; */
+	/* }	  */
+
+	switch (padapter->securitypriv.ndisencryptstatus) {
+	case Ndis802_11EncryptionNotSupported:
+	case Ndis802_11EncryptionDisabled:
+
+		erq->length = 0;
+		erq->flags |= IW_ENCODE_DISABLED;
+
+		break;
+
+	case Ndis802_11Encryption1Enabled:
+
+		erq->length = padapter->securitypriv.dot11DefKeylen[key];
+
+		if (erq->length) {
+			_rtw_memcpy(keybuf, padapter->securitypriv.dot11DefKey[key].skey, padapter->securitypriv.dot11DefKeylen[key]);
+
+			erq->flags |= IW_ENCODE_ENABLED;
+
+			if (padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeOpen)
+				erq->flags |= IW_ENCODE_OPEN;
+			else if (padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeShared)
+				erq->flags |= IW_ENCODE_RESTRICTED;
+		} else {
+			erq->length = 0;
+			erq->flags |= IW_ENCODE_DISABLED;
+		}
+
+		break;
+
+	case Ndis802_11Encryption2Enabled:
+	case Ndis802_11Encryption3Enabled:
+
+		erq->length = 16;
+		erq->flags |= (IW_ENCODE_ENABLED | IW_ENCODE_OPEN | IW_ENCODE_NOKEY);
+
+		break;
+
+	default:
+		erq->length = 0;
+		erq->flags |= IW_ENCODE_DISABLED;
+
+		break;
+
+	}
+
+
+	return ret;
+
+}
+
+static int rtw_wx_get_power(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev); */
+
+	wrqu->power.value = 0;
+	wrqu->power.fixed = 0;	/* no auto select */
+	wrqu->power.disabled = 1;
+
+	return 0;
+
+}
+
+static int rtw_wx_set_gen_ie(struct net_device *dev,
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
+{
+	int ret;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	ret = rtw_set_wpa_ie(padapter, extra, wrqu->data.length);
+
+	return ret;
+}
+
+static int rtw_wx_set_auth(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_param *param = (struct iw_param *)&(wrqu->param);
+	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);
+	u32 value = param->value;
+	int ret = 0;
+
+	switch (param->flags & IW_AUTH_INDEX) {
+
+	case IW_AUTH_WPA_VERSION:
+#ifdef CONFIG_WAPI_SUPPORT
+#ifndef CONFIG_IOCTL_CFG80211
+		padapter->wapiInfo.bWapiEnable = false;
+		if (value == IW_AUTH_WAPI_VERSION_1) {
+			padapter->wapiInfo.bWapiEnable = true;
+			psecuritypriv->dot11PrivacyAlgrthm = _SMS4_;
+			psecuritypriv->dot118021XGrpPrivacy = _SMS4_;
+			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+			pmlmeinfo->auth_algo = psecuritypriv->dot11AuthAlgrthm;
+			padapter->wapiInfo.extra_prefix_len = WAPI_EXT_LEN;
+			padapter->wapiInfo.extra_postfix_len = SMS4_MIC_LEN;
+		}
+#endif
+#endif
+		break;
+	case IW_AUTH_CIPHER_PAIRWISE:
+
+		break;
+	case IW_AUTH_CIPHER_GROUP:
+
+		break;
+	case IW_AUTH_KEY_MGMT:
+#ifdef CONFIG_WAPI_SUPPORT
+#ifndef CONFIG_IOCTL_CFG80211
+		RTW_INFO("rtw_wx_set_auth: IW_AUTH_KEY_MGMT case\n");
+		if (value == IW_AUTH_KEY_MGMT_WAPI_PSK)
+			padapter->wapiInfo.bWapiPSK = true;
+		else
+			padapter->wapiInfo.bWapiPSK = false;
+		RTW_INFO("rtw_wx_set_auth: IW_AUTH_KEY_MGMT bwapipsk %d\n", padapter->wapiInfo.bWapiPSK);
+#endif
+#endif
+		/*
+		 *  ??? does not use these parameters
+		 */
+		break;
+
+	case IW_AUTH_TKIP_COUNTERMEASURES: {
+		if (param->value) {
+			/* wpa_supplicant is enabling the tkip countermeasure. */
+			padapter->securitypriv.btkip_countermeasure = _TRUE;
+		} else {
+			/* wpa_supplicant is disabling the tkip countermeasure. */
+			padapter->securitypriv.btkip_countermeasure = _FALSE;
+		}
+		break;
+	}
+	case IW_AUTH_DROP_UNENCRYPTED: {
+		/* HACK:
+		 *
+		 * wpa_supplicant calls set_wpa_enabled when the driver
+		 * is loaded and unloaded, regardless of if WPA is being
+		 * used.  No other calls are made which can be used to
+		 * determine if encryption will be used or not prior to
+		 * association being expected.  If encryption is not being
+		 * used, drop_unencrypted is set to false, else true -- we
+		 * can use this to determine if the CAP_PRIVACY_ON bit should
+		 * be set.
+		 */
+
+		if (padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption1Enabled) {
+			break;/* it means init value, or using wep, ndisencryptstatus = Ndis802_11Encryption1Enabled, */
+			/* then it needn't reset it; */
+		}
+
+		if (param->value) {
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+			padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+			padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
+		}
+
+		break;
+	}
+
+	case IW_AUTH_80211_AUTH_ALG:
+
+#if defined(CONFIG_ANDROID) || 1
+		/*
+		 *  It's the starting point of a link layer connection using wpa_supplicant
+		*/
+		if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
+			LeaveAllPowerSaveMode(padapter);
+			rtw_disassoc_cmd(padapter, 500, RTW_CMDF_DIRECTLY);
+			RTW_INFO("%s...call rtw_indicate_disconnect\n ", __FUNCTION__);
+			rtw_indicate_disconnect(padapter, 0, _FALSE);
+			rtw_free_assoc_resources(padapter, 1);
+		}
+#endif
+
+
+		ret = wpa_set_auth_algs(dev, (u32)param->value);
+
+		break;
+
+	case IW_AUTH_WPA_ENABLED:
+
+		/* if(param->value) */
+		/* padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X; */ /* 802.1x */
+		/* else */
+		/* padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; */ /* open system */
+
+		/* _disassociate(priv); */
+
+		break;
+
+	case IW_AUTH_RX_UNENCRYPTED_EAPOL:
+		/* ieee->ieee802_1x = param->value; */
+		break;
+
+	case IW_AUTH_PRIVACY_INVOKED:
+		/* ieee->privacy_invoked = param->value; */
+		break;
+
+#ifdef CONFIG_WAPI_SUPPORT
+#ifndef CONFIG_IOCTL_CFG80211
+	case IW_AUTH_WAPI_ENABLED:
+		break;
+#endif
+#endif
+
+	default:
+		return -EOPNOTSUPP;
+
+	}
+
+	return ret;
+
+}
+
+static int rtw_wx_set_enc_ext(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	char *alg_name;
+	u32 param_len;
+	struct ieee_param *param = NULL;
+	struct iw_point *pencoding = &wrqu->encoding;
+	struct iw_encode_ext *pext = (struct iw_encode_ext *)extra;
+	int ret = 0;
+
+	param_len = sizeof(struct ieee_param) + pext->key_len;
+	param = (struct ieee_param *)rtw_malloc(param_len);
+	if (param == NULL)
+		return -1;
+
+	_rtw_memset(param, 0, param_len);
+
+	param->cmd = IEEE_CMD_SET_ENCRYPTION;
+	_rtw_memset(param->sta_addr, 0xff, ETH_ALEN);
+
+
+	switch (pext->alg) {
+	case IW_ENCODE_ALG_NONE:
+		/* todo: remove key */
+		/* remove = 1;	 */
+		alg_name = "none";
+		break;
+	case IW_ENCODE_ALG_WEP:
+		alg_name = "WEP";
+		break;
+	case IW_ENCODE_ALG_TKIP:
+		alg_name = "TKIP";
+		break;
+	case IW_ENCODE_ALG_CCMP:
+		alg_name = "CCMP";
+		break;
+#ifdef CONFIG_IEEE80211W
+	case IW_ENCODE_ALG_AES_CMAC:
+		alg_name = "BIP";
+		break;
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_WAPI_SUPPORT
+#ifndef CONFIG_IOCTL_CFG80211
+	case IW_ENCODE_ALG_SM4:
+		alg_name = "SMS4";
+		_rtw_memcpy(param->sta_addr, pext->addr.sa_data, ETH_ALEN);
+		RTW_INFO("rtw_wx_set_enc_ext: SMS4 case\n");
+		break;
+#endif
+#endif
+	default:
+		ret = -1;
+		goto exit;
+	}
+
+	strncpy((char *)param->u.crypt.alg, alg_name, IEEE_CRYPT_ALG_NAME_LEN);
+
+	if (pext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY)
+		param->u.crypt.set_tx = 1;
+
+	/* cliW: WEP does not have group key
+	 * just not checking GROUP key setting
+	 */
+	if ((pext->alg != IW_ENCODE_ALG_WEP) &&
+	    ((pext->ext_flags & IW_ENCODE_EXT_GROUP_KEY)
+#ifdef CONFIG_IEEE80211W
+	     || (pext->ext_flags & IW_ENCODE_ALG_AES_CMAC)
+#endif /* CONFIG_IEEE80211W */
+	    ))
+		param->u.crypt.set_tx = 0;
+
+	param->u.crypt.idx = (pencoding->flags & 0x00FF) - 1 ;
+
+	if (pext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID) {
+#ifdef CONFIG_WAPI_SUPPORT
+#ifndef CONFIG_IOCTL_CFG80211
+		if (pext->alg == IW_ENCODE_ALG_SM4)
+			_rtw_memcpy(param->u.crypt.seq, pext->rx_seq, 16);
+		else
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_WAPI_SUPPORT */
+			_rtw_memcpy(param->u.crypt.seq, pext->rx_seq, 8);
+	}
+
+	if (pext->key_len) {
+		param->u.crypt.key_len = pext->key_len;
+		/* _rtw_memcpy(param + 1, pext + 1, pext->key_len); */
+		_rtw_memcpy(param->u.crypt.key, pext + 1, pext->key_len);
+	}
+
+	if (pencoding->flags & IW_ENCODE_DISABLED) {
+		/* todo: remove key */
+		/* remove = 1; */
+	}
+
+	ret =  wpa_set_encryption(dev, param, param_len);
+
+exit:
+	if (param)
+		rtw_mfree((u8 *)param, param_len);
+
+	return ret;
+}
+
+
+static int rtw_wx_get_nick(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev); */
+	/* struct mlme_priv *pmlmepriv = &(padapter->mlmepriv); */
+	/* struct security_priv *psecuritypriv = &padapter->securitypriv; */
+
+	if (extra) {
+		wrqu->data.length = 14;
+		wrqu->data.flags = 1;
+		_rtw_memcpy(extra, "<WIFI@REALTEK>", 14);
+	}
+
+	/* rtw_signal_process(pid, SIGUSR1); */ /* for test */
+
+	/* dump debug info here	 */
+#if 0
+	u32 dot11AuthAlgrthm;		/*  802.11 auth, could be open, shared, and 8021x */
+	u32 dot11PrivacyAlgrthm;	/*  This specify the privacy for shared auth. algorithm. */
+	u32 dot118021XGrpPrivacy;	/*  This specify the privacy algthm. used for Grp key */
+	u32 ndisauthtype;
+	u32 ndisencryptstatus;
+#endif
+
+	/* RTW_INFO("auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n",  */
+	/*		psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm, */
+	/*		psecuritypriv->ndisauthtype, psecuritypriv->ndisencryptstatus); */
+
+	/* RTW_INFO("enc_alg=0x%x\n", psecuritypriv->dot11PrivacyAlgrthm); */
+	/* RTW_INFO("auth_type=0x%x\n", psecuritypriv->ndisauthtype); */
+	/* RTW_INFO("enc_type=0x%x\n", psecuritypriv->ndisencryptstatus); */
+
+#if 0
+	RTW_INFO("dbg(0x210)=0x%x\n", rtw_read32(padapter, 0x210));
+	RTW_INFO("dbg(0x608)=0x%x\n", rtw_read32(padapter, 0x608));
+	RTW_INFO("dbg(0x280)=0x%x\n", rtw_read32(padapter, 0x280));
+	RTW_INFO("dbg(0x284)=0x%x\n", rtw_read32(padapter, 0x284));
+	RTW_INFO("dbg(0x288)=0x%x\n", rtw_read32(padapter, 0x288));
+
+	RTW_INFO("dbg(0x664)=0x%x\n", rtw_read32(padapter, 0x664));
+
+
+	RTW_INFO("\n");
+
+	RTW_INFO("dbg(0x430)=0x%x\n", rtw_read32(padapter, 0x430));
+	RTW_INFO("dbg(0x438)=0x%x\n", rtw_read32(padapter, 0x438));
+
+	RTW_INFO("dbg(0x440)=0x%x\n", rtw_read32(padapter, 0x440));
+
+	RTW_INFO("dbg(0x458)=0x%x\n", rtw_read32(padapter, 0x458));
+
+	RTW_INFO("dbg(0x484)=0x%x\n", rtw_read32(padapter, 0x484));
+	RTW_INFO("dbg(0x488)=0x%x\n", rtw_read32(padapter, 0x488));
+
+	RTW_INFO("dbg(0x444)=0x%x\n", rtw_read32(padapter, 0x444));
+	RTW_INFO("dbg(0x448)=0x%x\n", rtw_read32(padapter, 0x448));
+	RTW_INFO("dbg(0x44c)=0x%x\n", rtw_read32(padapter, 0x44c));
+	RTW_INFO("dbg(0x450)=0x%x\n", rtw_read32(padapter, 0x450));
+#endif
+
+	return 0;
+
+}
+
+static int rtw_wx_read32(struct net_device *dev,
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter;
+	struct iw_point *p;
+	u16 len;
+	u32 addr;
+	u32 data32;
+	u32 bytes;
+	u8 *ptmp;
+	int ret;
+
+
+	ret = 0;
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+	p = &wrqu->data;
+	len = p->length;
+	if (0 == len)
+		return -EINVAL;
+
+	ptmp = (u8 *)rtw_malloc(len);
+	if (NULL == ptmp)
+		return -ENOMEM;
+
+	if (copy_from_user(ptmp, p->pointer, len)) {
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	bytes = 0;
+	addr = 0;
+	sscanf(ptmp, "%d,%x", &bytes, &addr);
+
+	switch (bytes) {
+	case 1:
+		data32 = rtw_read8(padapter, addr);
+		sprintf(extra, "0x%02X", data32);
+		break;
+	case 2:
+		data32 = rtw_read16(padapter, addr);
+		sprintf(extra, "0x%04X", data32);
+		break;
+	case 4:
+		data32 = rtw_read32(padapter, addr);
+		sprintf(extra, "0x%08X", data32);
+		break;
+
+	#if defined(CONFIG_SDIO_HCI) && defined(CONFIG_SDIO_INDIRECT_ACCESS) && defined(DBG_SDIO_INDIRECT_ACCESS)
+	case 11:
+		data32 = rtw_sd_iread8(padapter, addr);
+		sprintf(extra, "0x%02X", data32);
+		break;
+	case 12:
+		data32 = rtw_sd_iread16(padapter, addr);
+		sprintf(extra, "0x%04X", data32);
+		break;
+	case 14:
+		data32 = rtw_sd_iread32(padapter, addr);
+		sprintf(extra, "0x%08X", data32);
+		break;
+	#endif
+	default:
+		RTW_INFO("%s: usage> read [bytes],[address(hex)]\n", __func__);
+		ret = -EINVAL;
+		goto exit;
+	}
+	RTW_INFO("%s: addr=0x%08X data=%s\n", __func__, addr, extra);
+
+exit:
+	rtw_mfree(ptmp, len);
+
+	return 0;
+}
+
+static int rtw_wx_write32(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	u32 addr;
+	u32 data32;
+	u32 bytes;
+
+
+	bytes = 0;
+	addr = 0;
+	data32 = 0;
+	sscanf(extra, "%d,%x,%x", &bytes, &addr, &data32);
+
+	switch (bytes) {
+	case 1:
+		rtw_write8(padapter, addr, (u8)data32);
+		RTW_INFO("%s: addr=0x%08X data=0x%02X\n", __func__, addr, (u8)data32);
+		break;
+	case 2:
+		rtw_write16(padapter, addr, (u16)data32);
+		RTW_INFO("%s: addr=0x%08X data=0x%04X\n", __func__, addr, (u16)data32);
+		break;
+	case 4:
+		rtw_write32(padapter, addr, data32);
+		RTW_INFO("%s: addr=0x%08X data=0x%08X\n", __func__, addr, data32);
+		break;
+	default:
+		RTW_INFO("%s: usage> write [bytes],[address(hex)],[data(hex)]\n", __func__);
+		return -EINVAL;
+	}
+
+	return 0;
+}
+
+static int rtw_wx_read_rf(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u32 path, addr, data32;
+
+
+	path = *(u32 *)extra;
+	addr = *((u32 *)extra + 1);
+	data32 = rtw_hal_read_rfreg(padapter, path, addr, 0xFFFFF);
+	/*	RTW_INFO("%s: path=%d addr=0x%02x data=0x%05x\n", __func__, path, addr, data32); */
+	/*
+	 * IMPORTANT!!
+	 * Only when wireless private ioctl is at odd order,
+	 * "extra" would be copied to user space.
+	 */
+	sprintf(extra, "0x%05x", data32);
+
+	return 0;
+}
+
+static int rtw_wx_write_rf(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u32 path, addr, data32;
+
+
+	path = *(u32 *)extra;
+	addr = *((u32 *)extra + 1);
+	data32 = *((u32 *)extra + 2);
+	/*	RTW_INFO("%s: path=%d addr=0x%02x data=0x%05x\n", __func__, path, addr, data32); */
+	rtw_hal_write_rfreg(padapter, path, addr, 0xFFFFF, data32);
+
+	return 0;
+}
+
+static int rtw_wx_priv_null(struct net_device *dev, struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *b)
+{
+	return -1;
+}
+
+#ifdef CONFIG_RTW_80211K
+extern void rm_dbg_cmd(_adapter *padapter, char *s);
+static int rtw_wx_priv_rrm(struct net_device *dev, struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *b)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u32 path, addr, data32;
+
+
+	rm_dbg_cmd(padapter, b);
+	wrqu->data.length = strlen(b);
+
+	return 0;
+}
+#endif
+
+static int dummy(struct net_device *dev, struct iw_request_info *a,
+		 union iwreq_data *wrqu, char *b)
+{
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	 */
+	/* struct mlme_priv *pmlmepriv = &(padapter->mlmepriv); */
+
+	/* RTW_INFO("cmd_code=%x, fwstate=0x%x\n", a->cmd, get_fwstate(pmlmepriv)); */
+
+	return -1;
+
+}
+
+static int rtw_wx_set_channel_plan(struct net_device *dev,
+				   struct iw_request_info *info,
+				   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 channel_plan_req = (u8)(*((int *)wrqu));
+
+	if (_SUCCESS != rtw_set_channel_plan(padapter, channel_plan_req))
+		return -EPERM;
+
+	return 0;
+}
+
+static int rtw_wx_set_mtk_wps_probe_ie(struct net_device *dev,
+				       struct iw_request_info *a,
+				       union iwreq_data *wrqu, char *b)
+{
+#ifdef CONFIG_PLATFORM_MT53XX
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+#endif
+	return 0;
+}
+
+static int rtw_wx_get_sensitivity(struct net_device *dev,
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *buf)
+{
+#ifdef CONFIG_PLATFORM_MT53XX
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	/*	Modified by Albert 20110914 */
+	/*	This is in dbm format for MTK platform. */
+	wrqu->qual.level = padapter->recvpriv.rssi;
+	RTW_INFO(" level = %u\n",  wrqu->qual.level);
+#endif
+	return 0;
+}
+
+static int rtw_wx_set_mtk_wps_ie(struct net_device *dev,
+				 struct iw_request_info *info,
+				 union iwreq_data *wrqu, char *extra)
+{
+#ifdef CONFIG_PLATFORM_MT53XX
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	return rtw_set_wpa_ie(padapter, wrqu->data.pointer, wrqu->data.length);
+#else
+	return 0;
+#endif
+}
+
+static void rtw_dbg_mode_hdl(_adapter *padapter, u32 id, u8 *pdata, u32 len)
+{
+	pRW_Reg	RegRWStruct;
+	struct rf_reg_param *prfreg;
+	u8 path;
+	u8 offset;
+	u32 value;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	switch (id) {
+	case GEN_MP_IOCTL_SUBCODE(MP_START):
+		RTW_INFO("871x_driver is only for normal mode, can't enter mp mode\n");
+		break;
+	case GEN_MP_IOCTL_SUBCODE(READ_REG):
+		RegRWStruct = (pRW_Reg)pdata;
+		switch (RegRWStruct->width) {
+		case 1:
+			RegRWStruct->value = rtw_read8(padapter, RegRWStruct->offset);
+			break;
+		case 2:
+			RegRWStruct->value = rtw_read16(padapter, RegRWStruct->offset);
+			break;
+		case 4:
+			RegRWStruct->value = rtw_read32(padapter, RegRWStruct->offset);
+			break;
+		default:
+			break;
+		}
+
+		break;
+	case GEN_MP_IOCTL_SUBCODE(WRITE_REG):
+		RegRWStruct = (pRW_Reg)pdata;
+		switch (RegRWStruct->width) {
+		case 1:
+			rtw_write8(padapter, RegRWStruct->offset, (u8)RegRWStruct->value);
+			break;
+		case 2:
+			rtw_write16(padapter, RegRWStruct->offset, (u16)RegRWStruct->value);
+			break;
+		case 4:
+			rtw_write32(padapter, RegRWStruct->offset, (u32)RegRWStruct->value);
+			break;
+		default:
+			break;
+		}
+
+		break;
+	case GEN_MP_IOCTL_SUBCODE(READ_RF_REG):
+
+		prfreg = (struct rf_reg_param *)pdata;
+
+		path = (u8)prfreg->path;
+		offset = (u8)prfreg->offset;
+
+		value = rtw_hal_read_rfreg(padapter, path, offset, 0xffffffff);
+
+		prfreg->value = value;
+
+		break;
+	case GEN_MP_IOCTL_SUBCODE(WRITE_RF_REG):
+
+		prfreg = (struct rf_reg_param *)pdata;
+
+		path = (u8)prfreg->path;
+		offset = (u8)prfreg->offset;
+		value = prfreg->value;
+
+		rtw_hal_write_rfreg(padapter, path, offset, 0xffffffff, value);
+
+		break;
+	case GEN_MP_IOCTL_SUBCODE(TRIGGER_GPIO):
+		RTW_INFO("==> trigger gpio 0\n");
+		rtw_hal_set_hwreg(padapter, HW_VAR_TRIGGER_GPIO_0, 0);
+		break;
+#ifdef CONFIG_BT_COEXIST
+	case GEN_MP_IOCTL_SUBCODE(SET_DM_BT):
+		RTW_INFO("==> set dm_bt_coexist:%x\n", *(u8 *)pdata);
+		rtw_hal_set_hwreg(padapter, HW_VAR_BT_SET_COEXIST, pdata);
+		break;
+	case GEN_MP_IOCTL_SUBCODE(DEL_BA):
+		RTW_INFO("==> delete ba:%x\n", *(u8 *)pdata);
+		rtw_hal_set_hwreg(padapter, HW_VAR_BT_ISSUE_DELBA, pdata);
+		break;
+#endif
+#ifdef DBG_CONFIG_ERROR_DETECT
+	case GEN_MP_IOCTL_SUBCODE(GET_WIFI_STATUS):
+		*pdata = rtw_hal_sreset_get_wifi_status(padapter);
+		break;
+#endif
+
+	default:
+		break;
+	}
+
+}
+#ifdef MP_IOCTL_HDL
+static int rtw_mp_ioctl_hdl(struct net_device *dev, struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+	u32 BytesRead, BytesWritten, BytesNeeded;
+	struct oid_par_priv	oid_par;
+	struct mp_ioctl_handler	*phandler;
+	struct mp_ioctl_param	*poidparam;
+	uint status = 0;
+	u16 len;
+	u8 *pparmbuf = NULL, bset;
+	PADAPTER padapter = (PADAPTER)rtw_netdev_priv(dev);
+	struct iw_point *p = &wrqu->data;
+
+	/* RTW_INFO("+rtw_mp_ioctl_hdl\n"); */
+
+	/* mutex_lock(&ioctl_mutex); */
+
+	if ((!p->length) || (!p->pointer)) {
+		ret = -EINVAL;
+		goto _rtw_mp_ioctl_hdl_exit;
+	}
+
+	pparmbuf = NULL;
+	bset = (u8)(p->flags & 0xFFFF);
+	len = p->length;
+	pparmbuf = (u8 *)rtw_malloc(len);
+	if (pparmbuf == NULL) {
+		ret = -ENOMEM;
+		goto _rtw_mp_ioctl_hdl_exit;
+	}
+
+	if (copy_from_user(pparmbuf, p->pointer, len)) {
+		ret = -EFAULT;
+		goto _rtw_mp_ioctl_hdl_exit;
+	}
+
+	poidparam = (struct mp_ioctl_param *)pparmbuf;
+
+	if (poidparam->subcode >= MAX_MP_IOCTL_SUBCODE) {
+		ret = -EINVAL;
+		goto _rtw_mp_ioctl_hdl_exit;
+	}
+
+	/* RTW_INFO("%s: %d\n", __func__, poidparam->subcode); */
+#ifdef CONFIG_MP_INCLUDED
+	if (padapter->registrypriv.mp_mode == 1) {
+		phandler = mp_ioctl_hdl + poidparam->subcode;
+
+		if ((phandler->paramsize != 0) && (poidparam->len < phandler->paramsize)) {
+			ret = -EINVAL;
+			goto _rtw_mp_ioctl_hdl_exit;
+		}
+
+		if (phandler->handler) {
+			oid_par.adapter_context = padapter;
+			oid_par.oid = phandler->oid;
+			oid_par.information_buf = poidparam->data;
+			oid_par.information_buf_len = poidparam->len;
+			oid_par.dbg = 0;
+
+			BytesWritten = 0;
+			BytesNeeded = 0;
+
+			if (bset) {
+				oid_par.bytes_rw = &BytesRead;
+				oid_par.bytes_needed = &BytesNeeded;
+				oid_par.type_of_oid = SET_OID;
+			} else {
+				oid_par.bytes_rw = &BytesWritten;
+				oid_par.bytes_needed = &BytesNeeded;
+				oid_par.type_of_oid = QUERY_OID;
+			}
+
+			status = phandler->handler(&oid_par);
+
+			/* todo:check status, BytesNeeded, etc. */
+		} else {
+			RTW_INFO("rtw_mp_ioctl_hdl(): err!, subcode=%d, oid=%d, handler=%p\n",
+				poidparam->subcode, phandler->oid, phandler->handler);
+			ret = -EFAULT;
+			goto _rtw_mp_ioctl_hdl_exit;
+		}
+	} else
+#endif
+	{
+		rtw_dbg_mode_hdl(padapter, poidparam->subcode, poidparam->data, poidparam->len);
+	}
+
+	if (bset == 0x00) {/* query info */
+		if (copy_to_user(p->pointer, pparmbuf, len))
+			ret = -EFAULT;
+	}
+
+	if (status) {
+		ret = -EFAULT;
+		goto _rtw_mp_ioctl_hdl_exit;
+	}
+
+_rtw_mp_ioctl_hdl_exit:
+
+	if (pparmbuf)
+		rtw_mfree(pparmbuf, len);
+
+	/* mutex_unlock(&ioctl_mutex); */
+
+	return ret;
+}
+#endif
+static int rtw_get_ap_info(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	int bssid_match, ret = 0;
+	u32 cnt = 0, wpa_ielen;
+	_irqL	irqL;
+	_list	*plist, *phead;
+	unsigned char *pbuf;
+	u8 bssid[ETH_ALEN];
+	char data[32];
+	struct wlan_network *pnetwork = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	_queue *queue = &(pmlmepriv->scanned_queue);
+	struct iw_point *pdata = &wrqu->data;
+
+	RTW_INFO("+rtw_get_aplist_info\n");
+
+	if (rtw_is_drv_stopped(padapter) || (pdata == NULL)) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	while ((check_fwstate(pmlmepriv, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING))) == _TRUE) {
+		rtw_msleep_os(30);
+		cnt++;
+		if (cnt > 100)
+			break;
+	}
+
+
+	/* pdata->length = 0; */ /* ?	 */
+	pdata->flags = 0;
+	if (pdata->length >= 32) {
+		if (copy_from_user(data, pdata->pointer, 32)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	} else {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		/* if(hwaddr_aton_i(pdata->pointer, bssid)) */
+		if (hwaddr_aton_i(data, bssid)) {
+			RTW_INFO("Invalid BSSID '%s'.\n", (u8 *)data);
+			_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+			return -EINVAL;
+		}
+
+
+		if (_rtw_memcmp(bssid, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE) { /* BSSID match, then check if supporting wpa/wpa2 */
+			RTW_INFO("BSSID:" MAC_FMT "\n", MAC_ARG(bssid));
+
+			pbuf = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
+			if (pbuf && (wpa_ielen > 0)) {
+				pdata->flags = 1;
+				break;
+			}
+
+			pbuf = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
+			if (pbuf && (wpa_ielen > 0)) {
+				pdata->flags = 2;
+				break;
+			}
+
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (pdata->length >= 34) {
+		if (copy_to_user((u8 *)pdata->pointer + 32, (u8 *)&pdata->flags, 1)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	}
+
+exit:
+
+	return ret;
+
+}
+
+static int rtw_set_pid(struct net_device *dev,
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = rtw_netdev_priv(dev);
+	int *pdata = (int *)wrqu;
+	int selector;
+
+	if (rtw_is_drv_stopped(padapter) || (pdata == NULL)) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	selector = *pdata;
+	if (selector < 3 && selector >= 0) {
+		padapter->pid[selector] = *(pdata + 1);
+#ifdef CONFIG_GLOBAL_UI_PID
+		ui_pid[selector] = *(pdata + 1);
+#endif
+		RTW_INFO("%s set pid[%d]=%d\n", __FUNCTION__, selector , padapter->pid[selector]);
+	} else
+		RTW_INFO("%s selector %d error\n", __FUNCTION__, selector);
+
+exit:
+
+	return ret;
+
+}
+
+static int rtw_wps_start(struct net_device *dev,
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	u32   u32wps_start = 0;
+	unsigned int uintRet = 0;
+
+	if (RTW_CANNOT_RUN(padapter) || (NULL == pdata)) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	uintRet = copy_from_user((void *) &u32wps_start, pdata->pointer, 4);
+	if (u32wps_start == 0)
+		u32wps_start = *extra;
+
+	RTW_INFO("[%s] wps_start = %d\n", __FUNCTION__, u32wps_start);
+
+	if (u32wps_start == 1)   /* WPS Start */
+		rtw_led_control(padapter, LED_CTL_START_WPS);
+	else if (u32wps_start == 2)   /* WPS Stop because of wps success */
+		rtw_led_control(padapter, LED_CTL_STOP_WPS);
+	else if (u32wps_start == 3)   /* WPS Stop because of wps fail */
+		rtw_led_control(padapter, LED_CTL_STOP_WPS_FAIL);
+
+#ifdef CONFIG_INTEL_WIDI
+	process_intel_widi_wps_status(padapter, u32wps_start);
+#endif /* CONFIG_INTEL_WIDI */
+
+exit:
+
+	return ret;
+
+}
+
+#ifdef CONFIG_P2P
+static int rtw_wext_p2p_enable(struct net_device *dev,
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	enum P2P_ROLE init_role = P2P_ROLE_DISABLE;
+
+	if (*extra == '0')
+		init_role = P2P_ROLE_DISABLE;
+	else if (*extra == '1')
+		init_role = P2P_ROLE_DEVICE;
+	else if (*extra == '2')
+		init_role = P2P_ROLE_CLIENT;
+	else if (*extra == '3')
+		init_role = P2P_ROLE_GO;
+
+	if (_FAIL == rtw_p2p_enable(padapter, init_role)) {
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	/* set channel/bandwidth */
+	if (init_role != P2P_ROLE_DISABLE) {
+		u8 channel, ch_offset;
+		u16 bwmode;
+
+		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN)) {
+			/*	Stay at the listen state and wait for discovery. */
+			channel = pwdinfo->listen_channel;
+			pwdinfo->operating_channel = pwdinfo->listen_channel;
+			ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			bwmode = CHANNEL_WIDTH_20;
+		}
+#ifdef CONFIG_CONCURRENT_MODE
+		else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
+
+			_set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_interval);
+
+			channel = rtw_mi_get_union_chan(padapter);
+			ch_offset = rtw_mi_get_union_offset(padapter);
+			bwmode = rtw_mi_get_union_bw(padapter);
+
+			pwdinfo->operating_channel = channel;
+		}
+#endif
+		else {
+			pwdinfo->operating_channel = pmlmeext->cur_channel;
+
+			channel = pwdinfo->operating_channel;
+			ch_offset = pmlmeext->cur_ch_offset;
+			bwmode = pmlmeext->cur_bwmode;
+		}
+
+		set_channel_bwmode(padapter, channel, ch_offset, bwmode);
+	}
+
+exit:
+	return ret;
+
+}
+
+static int rtw_p2p_set_go_nego_ssid(struct net_device *dev,
+				    struct iw_request_info *info,
+				    union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] ssid = %s, len = %zu\n", __FUNCTION__, extra, strlen(extra));
+	_rtw_memcpy(pwdinfo->nego_ssid, extra, strlen(extra));
+	pwdinfo->nego_ssidlen = strlen(extra);
+
+	return ret;
+
+}
+
+
+static int rtw_p2p_set_intent(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	int							ret = 0;
+	_adapter						*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info			*pwdinfo = &(padapter->wdinfo);
+	u8							intent = pwdinfo->intent;
+
+	extra[wrqu->data.length] = 0x00;
+
+	intent = rtw_atoi(extra);
+
+	if (intent <= 15)
+		pwdinfo->intent = intent;
+	else
+		ret = -1;
+
+	RTW_INFO("[%s] intent = %d\n", __FUNCTION__, intent);
+
+	return ret;
+
+}
+
+static int rtw_p2p_set_listen_ch(struct net_device *dev,
+				 struct iw_request_info *info,
+				 union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8	listen_ch = pwdinfo->listen_channel;	/*	Listen channel number */
+
+	extra[wrqu->data.length] = 0x00;
+	listen_ch = rtw_atoi(extra);
+
+	if ((listen_ch == 1) || (listen_ch == 6) || (listen_ch == 11)) {
+		pwdinfo->listen_channel = listen_ch;
+		set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+	} else
+		ret = -1;
+
+	RTW_INFO("[%s] listen_ch = %d\n", __FUNCTION__, pwdinfo->listen_channel);
+
+	return ret;
+
+}
+
+static int rtw_p2p_set_op_ch(struct net_device *dev,
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
+{
+	/*	Commented by Albert 20110524
+	 *	This function is used to set the operating channel if the driver will become the group owner */
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8	op_ch = pwdinfo->operating_channel;	/*	Operating channel number */
+
+	extra[wrqu->data.length] = 0x00;
+
+	op_ch = (u8) rtw_atoi(extra);
+	if (op_ch > 0)
+		pwdinfo->operating_channel = op_ch;
+	else
+		ret = -1;
+
+	RTW_INFO("[%s] op_ch = %d\n", __FUNCTION__, pwdinfo->operating_channel);
+
+	return ret;
+
+}
+
+
+static int rtw_p2p_profilefound(struct net_device *dev,
+				struct iw_request_info *info,
+				union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+
+	/*	Comment by Albert 2010/10/13 */
+	/*	Input data format: */
+	/*	Ex:  0 */
+	/*	Ex:  1XX:XX:XX:XX:XX:XXYYSSID */
+	/*	0 => Reflush the profile record list. */
+	/*	1 => Add the profile list */
+	/*	XX:XX:XX:XX:XX:XX => peer's MAC Address ( ex: 00:E0:4C:00:00:01 ) */
+	/*	YY => SSID Length */
+	/*	SSID => SSID for persistence group */
+
+	RTW_INFO("[%s] In value = %s, len = %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+
+	/*	The upper application should pass the SSID to driver by using this rtw_p2p_profilefound function. */
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		if (extra[0] == '0') {
+			/*	Remove all the profile information of wifidirect_info structure. */
+			_rtw_memset(&pwdinfo->profileinfo[0], 0x00, sizeof(struct profile_info) * P2P_MAX_PERSISTENT_GROUP_NUM);
+			pwdinfo->profileindex = 0;
+		} else {
+			if (pwdinfo->profileindex >= P2P_MAX_PERSISTENT_GROUP_NUM)
+				ret = -1;
+			else {
+				int jj, kk;
+
+				/*	Add this profile information into pwdinfo->profileinfo */
+				/*	Ex:  1XX:XX:XX:XX:XX:XXYYSSID */
+				for (jj = 0, kk = 1; jj < ETH_ALEN; jj++, kk += 3)
+					pwdinfo->profileinfo[pwdinfo->profileindex].peermac[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+				/* pwdinfo->profileinfo[pwdinfo->profileindex].ssidlen = ( extra[18] - '0' ) * 10 + ( extra[19] - '0' ); */
+				/* _rtw_memcpy( pwdinfo->profileinfo[pwdinfo->profileindex].ssid, &extra[20], pwdinfo->profileinfo[pwdinfo->profileindex].ssidlen ); */
+				pwdinfo->profileindex++;
+			}
+		}
+	}
+
+	return ret;
+
+}
+
+static int rtw_p2p_setDN(struct net_device *dev,
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+	_rtw_memset(pwdinfo->device_name, 0x00, WPS_MAX_DEVICE_NAME_LEN);
+	_rtw_memcpy(pwdinfo->device_name, extra, wrqu->data.length - 1);
+	pwdinfo->device_name_len = wrqu->data.length - 1;
+
+	return ret;
+
+}
+
+
+static int rtw_p2p_get_status(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	if (padapter->bShowGetP2PState) {
+		RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+			pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+			pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
+	}
+
+	/*	Commented by Albert 2010/10/12 */
+	/*	Because of the output size limitation, I had removed the "Role" information. */
+	/*	About the "Role" information, we will use the new private IOCTL to get the "Role" information. */
+	sprintf(extra, "\n\nStatus=%.2d\n", rtw_p2p_state(pwdinfo));
+	wrqu->data.length = strlen(extra);
+
+	return ret;
+
+}
+
+/*	Commented by Albert 20110520
+ *	This function will return the config method description
+ *	This config method description will show us which config method the remote P2P device is intented to use
+ *	by sending the provisioning discovery request frame. */
+
+static int rtw_p2p_get_req_cm(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	sprintf(extra, "\n\nCM=%s\n", pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req);
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+
+static int rtw_p2p_get_role(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+		pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
+
+	sprintf(extra, "\n\nRole=%.2d\n", rtw_p2p_role(pwdinfo));
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+
+static int rtw_p2p_get_peer_ifaddr(struct net_device *dev,
+				   struct iw_request_info *info,
+				   union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+		pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
+
+	sprintf(extra, "\nMAC %.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
+		pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+		pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+static int rtw_p2p_get_peer_devaddr(struct net_device *dev,
+				    struct iw_request_info *info,
+				    union iwreq_data *wrqu, char *extra)
+
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->rx_prov_disc_info.peerDevAddr[0], pwdinfo->rx_prov_disc_info.peerDevAddr[1],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[2], pwdinfo->rx_prov_disc_info.peerDevAddr[3],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[4], pwdinfo->rx_prov_disc_info.peerDevAddr[5]);
+	sprintf(extra, "\n%.2X%.2X%.2X%.2X%.2X%.2X",
+		pwdinfo->rx_prov_disc_info.peerDevAddr[0], pwdinfo->rx_prov_disc_info.peerDevAddr[1],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[2], pwdinfo->rx_prov_disc_info.peerDevAddr[3],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[4], pwdinfo->rx_prov_disc_info.peerDevAddr[5]);
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+static int rtw_p2p_get_peer_devaddr_by_invitation(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
+
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->p2p_peer_device_addr[0], pwdinfo->p2p_peer_device_addr[1],
+		pwdinfo->p2p_peer_device_addr[2], pwdinfo->p2p_peer_device_addr[3],
+		pwdinfo->p2p_peer_device_addr[4], pwdinfo->p2p_peer_device_addr[5]);
+	sprintf(extra, "\nMAC %.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
+		pwdinfo->p2p_peer_device_addr[0], pwdinfo->p2p_peer_device_addr[1],
+		pwdinfo->p2p_peer_device_addr[2], pwdinfo->p2p_peer_device_addr[3],
+		pwdinfo->p2p_peer_device_addr[4], pwdinfo->p2p_peer_device_addr[5]);
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+static int rtw_p2p_get_groupid(struct net_device *dev,
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
+
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	sprintf(extra, "\n%.2X:%.2X:%.2X:%.2X:%.2X:%.2X %s",
+		pwdinfo->groupid_info.go_device_addr[0], pwdinfo->groupid_info.go_device_addr[1],
+		pwdinfo->groupid_info.go_device_addr[2], pwdinfo->groupid_info.go_device_addr[3],
+		pwdinfo->groupid_info.go_device_addr[4], pwdinfo->groupid_info.go_device_addr[5],
+		pwdinfo->groupid_info.ssid);
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+static int rtw_p2p_get_op_ch(struct net_device *dev,
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
+
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+
+	RTW_INFO("[%s] Op_ch = %02x\n", __FUNCTION__, pwdinfo->operating_channel);
+
+	sprintf(extra, "\n\nOp_ch=%.2d\n", pwdinfo->operating_channel);
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+static int rtw_p2p_get_wps_configmethod(struct net_device *dev,
+					struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 peerMAC[ETH_ALEN] = { 0x00 };
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	_irqL irqL;
+	_list *plist, *phead;
+	_queue *queue = &(pmlmepriv->scanned_queue);
+	struct wlan_network *pnetwork = NULL;
+	u8 blnMatch = 0;
+	u16	attr_content = 0;
+	uint attr_contentlen = 0;
+	u8	attr_content_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
+
+	/*	Commented by Albert 20110727 */
+	/*	The input data is the MAC address which the application wants to know its WPS config method. */
+	/*	After knowing its WPS config method, the application can decide the config method for provisioning discovery. */
+	/*	Format: iwpriv wlanx p2p_get_wpsCM 00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
+
+	macstr2num(peerMAC, subcmd);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			u8 *wpsie;
+			uint	wpsie_len = 0;
+
+			/*	The mac address is matched. */
+
+			wpsie = rtw_get_wps_ie_from_scan_queue(&pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0]);
+			if (wpsie) {
+				rtw_get_wps_attr_content(wpsie, wpsie_len, WPS_ATTR_CONF_METHOD, (u8 *)&attr_content, &attr_contentlen);
+				if (attr_contentlen) {
+					attr_content = be16_to_cpu(attr_content);
+					sprintf(attr_content_str, "\n\nM=%.4d", attr_content);
+					blnMatch = 1;
+				}
+			}
+
+			break;
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (!blnMatch)
+		sprintf(attr_content_str, "\n\nM=0000");
+
+	wrqu->data.length = strlen(attr_content_str);
+	_rtw_memcpy(extra, attr_content_str, wrqu->data.length);
+
+	return ret;
+
+}
+
+#ifdef CONFIG_WFD
+static int rtw_p2p_get_peer_wfd_port(struct net_device *dev,
+				     struct iw_request_info *info,
+				     union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] p2p_state = %d\n", __FUNCTION__, rtw_p2p_state(pwdinfo));
+
+	sprintf(extra, "\n\nPort=%d\n", pwdinfo->wfd_info->peer_rtsp_ctrlport);
+	RTW_INFO("[%s] remote port = %d\n", __FUNCTION__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
+
+	wrqu->data.length = strlen(extra);
+	return ret;
+
+}
+
+static int rtw_p2p_get_peer_wfd_preferred_connection(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	sprintf(extra, "\n\nwfd_pc=%d\n", pwdinfo->wfd_info->wfd_pc);
+	RTW_INFO("[%s] wfd_pc = %d\n", __FUNCTION__, pwdinfo->wfd_info->wfd_pc);
+
+	wrqu->data.length = strlen(extra);
+	pwdinfo->wfd_info->wfd_pc = _FALSE;	/*	Reset the WFD preferred connection to P2P */
+	return ret;
+
+}
+
+static int rtw_p2p_get_peer_wfd_session_available(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	sprintf(extra, "\n\nwfd_sa=%d\n", pwdinfo->wfd_info->peer_session_avail);
+	RTW_INFO("[%s] wfd_sa = %d\n", __FUNCTION__, pwdinfo->wfd_info->peer_session_avail);
+
+	wrqu->data.length = strlen(extra);
+	pwdinfo->wfd_info->peer_session_avail = _TRUE;	/*	Reset the WFD session available */
+	return ret;
+
+}
+#endif /* CONFIG_WFD */
+
+static int rtw_p2p_get_go_device_address(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 peerMAC[ETH_ALEN] = { 0x00 };
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	_irqL irqL;
+	_list *plist, *phead;
+	_queue *queue	= &(pmlmepriv->scanned_queue);
+	struct wlan_network *pnetwork = NULL;
+	u8 blnMatch = 0;
+	u8 *p2pie;
+	uint p2pielen = 0, attr_contentlen = 0;
+	u8 attr_content[100] = { 0x00 };
+	u8 go_devadd_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
+
+	/*	Commented by Albert 20121209 */
+	/*	The input data is the GO's interface address which the application wants to know its device address. */
+	/*	Format: iwpriv wlanx p2p_get2 go_devadd=00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
+
+	macstr2num(peerMAC, subcmd);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			/*	Commented by Albert 2011/05/18 */
+			/*	Match the device address located in the P2P IE */
+			/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
+
+			p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
+			if (p2pie) {
+				while (p2pie) {
+					/*	The P2P Device ID attribute is included in the Beacon frame. */
+					/*	The P2P Device Info attribute is included in the probe response frame. */
+
+					_rtw_memset(attr_content, 0x00, 100);
+					if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+						/*	Handle the P2P Device ID attribute of Beacon first */
+						blnMatch = 1;
+						break;
+
+					} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+						/*	Handle the P2P Device Info attribute of probe response */
+						blnMatch = 1;
+						break;
+					}
+
+					/* Get the next P2P IE */
+					p2pie = rtw_get_p2p_ie(p2pie + p2pielen, BSS_EX_TLV_IES_LEN(&pnetwork->network) - (p2pie + p2pielen - BSS_EX_TLV_IES(&pnetwork->network)), NULL, &p2pielen);
+				}
+			}
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (!blnMatch)
+		sprintf(go_devadd_str, "\n\ndev_add=NULL");
+	else {
+		sprintf(go_devadd_str, "\n\ndev_add=%.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
+			attr_content[0], attr_content[1], attr_content[2], attr_content[3], attr_content[4], attr_content[5]);
+	}
+
+	wrqu->data.length = strlen(go_devadd_str);
+	_rtw_memcpy(extra, go_devadd_str, wrqu->data.length);
+
+	return ret;
+
+}
+
+static int rtw_p2p_get_device_type(struct net_device *dev,
+				   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 peerMAC[ETH_ALEN] = { 0x00 };
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	_irqL irqL;
+	_list *plist, *phead;
+	_queue *queue = &(pmlmepriv->scanned_queue);
+	struct wlan_network *pnetwork = NULL;
+	u8 blnMatch = 0;
+	u8 dev_type[8] = { 0x00 };
+	uint dev_type_len = 0;
+	u8 dev_type_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };    /* +9 is for the str "dev_type=", we have to clear it at wrqu->data.pointer */
+
+	/*	Commented by Albert 20121209 */
+	/*	The input data is the MAC address which the application wants to know its device type. */
+	/*	Such user interface could know the device type. */
+	/*	Format: iwpriv wlanx p2p_get2 dev_type=00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
+
+	macstr2num(peerMAC, subcmd);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			u8 *wpsie;
+			uint	wpsie_len = 0;
+
+			/*	The mac address is matched. */
+
+			wpsie = rtw_get_wps_ie_from_scan_queue(&pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0]);
+			if (wpsie) {
+				rtw_get_wps_attr_content(wpsie, wpsie_len, WPS_ATTR_PRIMARY_DEV_TYPE, dev_type, &dev_type_len);
+				if (dev_type_len) {
+					u16	type = 0;
+
+					_rtw_memcpy(&type, dev_type, 2);
+					type = be16_to_cpu(type);
+					sprintf(dev_type_str, "\n\nN=%.2d", type);
+					blnMatch = 1;
+				}
+			}
+			break;
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (!blnMatch)
+		sprintf(dev_type_str, "\n\nN=00");
+
+	wrqu->data.length = strlen(dev_type_str);
+	_rtw_memcpy(extra, dev_type_str, wrqu->data.length);
+
+	return ret;
+
+}
+
+static int rtw_p2p_get_device_name(struct net_device *dev,
+				   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 peerMAC[ETH_ALEN] = { 0x00 };
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	_irqL irqL;
+	_list *plist, *phead;
+	_queue *queue = &(pmlmepriv->scanned_queue);
+	struct wlan_network *pnetwork = NULL;
+	u8 blnMatch = 0;
+	u8 dev_name[WPS_MAX_DEVICE_NAME_LEN] = { 0x00 };
+	uint dev_len = 0;
+	u8 dev_name_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
+
+	/*	Commented by Albert 20121225 */
+	/*	The input data is the MAC address which the application wants to know its device name. */
+	/*	Such user interface could show peer device's device name instead of ssid. */
+	/*	Format: iwpriv wlanx p2p_get2 devN=00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
+
+	macstr2num(peerMAC, subcmd);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			u8 *wpsie;
+			uint	wpsie_len = 0;
+
+			/*	The mac address is matched. */
+
+			wpsie = rtw_get_wps_ie_from_scan_queue(&pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0]);
+			if (wpsie) {
+				rtw_get_wps_attr_content(wpsie, wpsie_len, WPS_ATTR_DEVICE_NAME, dev_name, &dev_len);
+				if (dev_len) {
+					sprintf(dev_name_str, "\n\nN=%s", dev_name);
+					blnMatch = 1;
+				}
+			}
+			break;
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (!blnMatch)
+		sprintf(dev_name_str, "\n\nN=0000");
+
+	wrqu->data.length = strlen(dev_name_str);
+	_rtw_memcpy(extra, dev_name_str, wrqu->data.length);
+
+	return ret;
+
+}
+
+static int rtw_p2p_get_invitation_procedure(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 peerMAC[ETH_ALEN] = { 0x00 };
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	_irqL irqL;
+	_list *plist, *phead;
+	_queue *queue	= &(pmlmepriv->scanned_queue);
+	struct wlan_network *pnetwork = NULL;
+	u8 blnMatch = 0;
+	u8 *p2pie;
+	uint p2pielen = 0, attr_contentlen = 0;
+	u8 attr_content[2] = { 0x00 };
+	u8 inv_proc_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
+
+	/*	Commented by Ouden 20121226 */
+	/*	The application wants to know P2P initation procedure is support or not. */
+	/*	Format: iwpriv wlanx p2p_get2 InvProc=00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
+
+	macstr2num(peerMAC, subcmd);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			/*	Commented by Albert 20121226 */
+			/*	Match the device address located in the P2P IE */
+			/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
+
+			p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
+			if (p2pie) {
+				while (p2pie) {
+					/* _rtw_memset( attr_content, 0x00, 2); */
+					if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_CAPABILITY, attr_content, &attr_contentlen)) {
+						/*	Handle the P2P capability attribute */
+						blnMatch = 1;
+						break;
+
+					}
+
+					/* Get the next P2P IE */
+					p2pie = rtw_get_p2p_ie(p2pie + p2pielen, BSS_EX_TLV_IES_LEN(&pnetwork->network) - (p2pie + p2pielen - BSS_EX_TLV_IES(&pnetwork->network)), NULL, &p2pielen);
+				}
+			}
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (!blnMatch)
+		sprintf(inv_proc_str, "\nIP=-1");
+	else {
+		if ((attr_content[0] & 0x20) == 0x20)
+			sprintf(inv_proc_str, "\nIP=1");
+		else
+			sprintf(inv_proc_str, "\nIP=0");
+	}
+
+	wrqu->data.length = strlen(inv_proc_str);
+	_rtw_memcpy(extra, inv_proc_str, wrqu->data.length);
+
+	return ret;
+
+}
+
+static int rtw_p2p_connect(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					peerMAC[ETH_ALEN] = { 0x00 };
+	int					jj, kk;
+	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	_irqL				irqL;
+	_list					*plist, *phead;
+	_queue				*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network	*pnetwork = NULL;
+	uint					uintPeerChannel = 0;
+
+	/*	Commented by Albert 20110304 */
+	/*	The input data contains two informations. */
+	/*	1. First information is the MAC address which wants to formate with */
+	/*	2. Second information is the WPS PINCode or "pbc" string for push button method */
+	/*	Format: 00:E0:4C:00:00:05 */
+	/*	Format: 00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (pwdinfo->p2p_state == P2P_STATE_NONE) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
+		return ret;
+	}
+
+#ifdef CONFIG_INTEL_WIDI
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+		RTW_INFO("[%s] WiFi is under survey!\n", __FUNCTION__);
+		return ret;
+	}
+#endif /* CONFIG_INTEL_WIDI	 */
+
+	if (pwdinfo->ui_got_wps_info == P2P_NO_WPSINFO)
+		return -1;
+
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		peerMAC[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			if (pnetwork->network.Configuration.DSConfig != 0)
+				uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+			else if (pwdinfo->nego_req_info.peer_ch != 0)
+				uintPeerChannel = pnetwork->network.Configuration.DSConfig = pwdinfo->nego_req_info.peer_ch;
+			else {
+				/* Unexpected case */
+				uintPeerChannel = 0;
+				RTW_INFO("%s  uintPeerChannel = 0\n", __func__);
+			}
+			break;
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (uintPeerChannel) {
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif /* CONFIG_CONCURRENT_MODE */
+
+		_rtw_memset(&pwdinfo->nego_req_info, 0x00, sizeof(struct tx_nego_req_info));
+		_rtw_memset(&pwdinfo->groupid_info, 0x00, sizeof(struct group_id_info));
+
+		pwdinfo->nego_req_info.peer_channel_num[0] = uintPeerChannel;
+		_rtw_memcpy(pwdinfo->nego_req_info.peerDevAddr, pnetwork->network.MacAddress, ETH_ALEN);
+		pwdinfo->nego_req_info.benable = _TRUE;
+
+		_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+		if (rtw_p2p_state(pwdinfo) != P2P_STATE_GONEGO_OK) {
+			/*	Restore to the listen state if the current p2p state is not nego OK */
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
+		}
+
+		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_ING);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
+			u8 union_bw = rtw_mi_get_union_bw(padapter);
+			u8 union_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_leave_opch(padapter);
+		}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+		RTW_INFO("[%s] Start PreTx Procedure!\n", __FUNCTION__);
+		_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_GO_NEGO_TIMEOUT);
+		else
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_GO_NEGO_TIMEOUT);
+#else
+		_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_GO_NEGO_TIMEOUT);
+#endif /* CONFIG_CONCURRENT_MODE		 */
+
+	} else {
+		RTW_INFO("[%s] Not Found in Scanning Queue~\n", __FUNCTION__);
+#ifdef CONFIG_INTEL_WIDI
+		_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
+		rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
+		rtw_free_network_queue(padapter, _TRUE);
+		/**
+		 * For WiDi, if we can't find candidate device in scanning queue,
+		 * driver will do scanning itself
+		 */
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		rtw_sitesurvey_cmd(padapter, NULL);
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+#endif /* CONFIG_INTEL_WIDI */
+		ret = -1;
+	}
+exit:
+	return ret;
+}
+
+static int rtw_p2p_invite_req(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
+	int						jj, kk;
+	u8						peerMACStr[ETH_ALEN * 2] = { 0x00 };
+	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
+	_list						*plist, *phead;
+	_queue					*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network		*pnetwork = NULL;
+	uint						uintPeerChannel = 0;
+	u8						attr_content[50] = { 0x00 }, _status = 0;
+	u8						*p2pie;
+	uint						p2pielen = 0, attr_contentlen = 0;
+	_irqL					irqL;
+	struct tx_invite_req_info	*pinvite_req_info = &pwdinfo->invitereq_info;
+
+	/*	Commented by Albert 20120321 */
+	/*	The input data contains two informations. */
+	/*	1. First information is the P2P device address which you want to send to.	 */
+	/*	2. Second information is the group id which combines with GO's mac address, space and GO's ssid. */
+	/*	Command line sample: iwpriv wlan0 p2p_set invite="00:11:22:33:44:55 00:E0:4C:00:00:05 DIRECT-xy" */
+	/*	Format: 00:11:22:33:44:55 00:E0:4C:00:00:05 DIRECT-xy */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (wrqu->data.length <=  37) {
+		RTW_INFO("[%s] Wrong format!\n", __FUNCTION__);
+		return ret;
+	}
+
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
+		return ret;
+	} else {
+		/*	Reset the content of struct tx_invite_req_info */
+		pinvite_req_info->benable = _FALSE;
+		_rtw_memset(pinvite_req_info->go_bssid, 0x00, ETH_ALEN);
+		_rtw_memset(pinvite_req_info->go_ssid, 0x00, WLAN_SSID_MAXLEN);
+		pinvite_req_info->ssidlen = 0x00;
+		pinvite_req_info->operating_ch = pwdinfo->operating_channel;
+		_rtw_memset(pinvite_req_info->peer_macaddr, 0x00, ETH_ALEN);
+		pinvite_req_info->token = 3;
+	}
+
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		pinvite_req_info->peer_macaddr[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		/*	Commented by Albert 2011/05/18 */
+		/*	Match the device address located in the P2P IE */
+		/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
+
+		p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
+		if (p2pie) {
+			/*	The P2P Device ID attribute is included in the Beacon frame. */
+			/*	The P2P Device Info attribute is included in the probe response frame. */
+
+			if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device ID attribute of Beacon first */
+				if (_rtw_memcmp(attr_content, pinvite_req_info->peer_macaddr, ETH_ALEN)) {
+					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+					break;
+				}
+			} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device Info attribute of probe response */
+				if (_rtw_memcmp(attr_content, pinvite_req_info->peer_macaddr, ETH_ALEN)) {
+					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+					break;
+				}
+			}
+
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+#ifdef CONFIG_WFD
+	if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST) && uintPeerChannel) {
+		struct wifi_display_info *pwfd_info = pwdinfo->wfd_info;
+		u8 *wfd_ie;
+		uint wfd_ielen = 0;
+
+		wfd_ie = rtw_bss_ex_get_wfd_ie(&pnetwork->network, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			u8 *wfd_devinfo;
+			uint wfd_devlen;
+
+			RTW_INFO("[%s] Found WFD IE!\n", __FUNCTION__);
+			wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
+			if (wfd_devinfo) {
+				u16	wfd_devinfo_field = 0;
+
+				/*	Commented by Albert 20120319 */
+				/*	The first two bytes are the WFD device information field of WFD device information subelement. */
+				/*	In big endian format. */
+				wfd_devinfo_field = RTW_GET_BE16(wfd_devinfo);
+				if (wfd_devinfo_field & WFD_DEVINFO_SESSION_AVAIL)
+					pwfd_info->peer_session_avail = _TRUE;
+				else
+					pwfd_info->peer_session_avail = _FALSE;
+			}
+		}
+
+		if (_FALSE == pwfd_info->peer_session_avail) {
+			RTW_INFO("[%s] WFD Session not avaiable!\n", __FUNCTION__);
+			goto exit;
+		}
+	}
+#endif /* CONFIG_WFD */
+
+	if (uintPeerChannel) {
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif /* CONFIG_CONCURRENT_MODE */
+
+		/*	Store the GO's bssid */
+		for (jj = 0, kk = 18; jj < ETH_ALEN; jj++, kk += 3)
+			pinvite_req_info->go_bssid[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+		/*	Store the GO's ssid */
+		pinvite_req_info->ssidlen = wrqu->data.length - 36;
+		_rtw_memcpy(pinvite_req_info->go_ssid, &extra[36], (u32) pinvite_req_info->ssidlen);
+		pinvite_req_info->benable = _TRUE;
+		pinvite_req_info->peer_ch = uintPeerChannel;
+
+		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_TX_INVITE_REQ);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
+			u8 union_bw = rtw_mi_get_union_bw(padapter);
+			u8 union_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_leave_opch(padapter);
+
+		} else
+			set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+#else
+		set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+#endif/*CONFIG_CONCURRENT_MODE*/
+
+		_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_INVITE_TIMEOUT);
+		else
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_INVITE_TIMEOUT);
+#else
+		_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_INVITE_TIMEOUT);
+#endif /* CONFIG_CONCURRENT_MODE		 */
+
+
+	} else
+		RTW_INFO("[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__);
+exit:
+
+	return ret;
+
+}
+
+static int rtw_p2p_set_persistent(struct net_device *dev,
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
+	int						jj, kk;
+	u8						peerMACStr[ETH_ALEN * 2] = { 0x00 };
+	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
+	_list						*plist, *phead;
+	_queue					*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network		*pnetwork = NULL;
+	uint						uintPeerChannel = 0;
+	u8						attr_content[50] = { 0x00 }, _status = 0;
+	u8						*p2pie;
+	uint						p2pielen = 0, attr_contentlen = 0;
+	_irqL					irqL;
+	struct tx_invite_req_info	*pinvite_req_info = &pwdinfo->invitereq_info;
+
+	/*	Commented by Albert 20120328 */
+	/*	The input data is 0 or 1 */
+	/*	0: disable persistent group functionality */
+	/*	1: enable persistent group founctionality */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
+		return ret;
+	} else {
+		if (extra[0] == '0')	/*	Disable the persistent group function. */
+			pwdinfo->persistent_supported = _FALSE;
+		else if (extra[0] == '1')	/*	Enable the persistent group function. */
+			pwdinfo->persistent_supported = _TRUE;
+		else
+			pwdinfo->persistent_supported = _FALSE;
+	}
+	printk("[%s] persistent_supported = %d\n", __FUNCTION__, pwdinfo->persistent_supported);
+
+exit:
+
+	return ret;
+
+}
+
+static int uuid_str2bin(const char *str, u8 *bin)
+{
+	const char *pos;
+	u8 *opos;
+
+	pos = str;
+	opos = bin;
+
+	if (hexstr2bin(pos, opos, 4))
+		return -1;
+	pos += 8;
+	opos += 4;
+
+	if (*pos++ != '-' || hexstr2bin(pos, opos, 2))
+		return -1;
+	pos += 4;
+	opos += 2;
+
+	if (*pos++ != '-' || hexstr2bin(pos, opos, 2))
+		return -1;
+	pos += 4;
+	opos += 2;
+
+	if (*pos++ != '-' || hexstr2bin(pos, opos, 2))
+		return -1;
+	pos += 4;
+	opos += 2;
+
+	if (*pos++ != '-' || hexstr2bin(pos, opos, 6))
+		return -1;
+
+	return 0;
+}
+
+static int rtw_p2p_set_wps_uuid(struct net_device *dev,
+				struct iw_request_info *info,
+				union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info			*pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if ((36 == strlen(extra)) && (uuid_str2bin(extra, pwdinfo->uuid) == 0))
+		pwdinfo->external_uuid = 1;
+	else {
+		pwdinfo->external_uuid = 0;
+		ret = -EINVAL;
+	}
+
+	return ret;
+
+}
+#ifdef CONFIG_WFD
+static int rtw_p2p_set_pc(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point		*pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					peerMAC[ETH_ALEN] = { 0x00 };
+	int					jj, kk;
+	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	_list					*plist, *phead;
+	_queue				*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network	*pnetwork = NULL;
+	u8					attr_content[50] = { 0x00 }, _status = 0;
+	u8 *p2pie;
+	uint					p2pielen = 0, attr_contentlen = 0;
+	_irqL				irqL;
+	uint					uintPeerChannel = 0;
+
+	struct wifi_display_info	*pwfd_info = pwdinfo->wfd_info;
+
+	/*	Commented by Albert 20120512 */
+	/*	1. Input information is the MAC address which wants to know the Preferred Connection bit (PC bit) */
+	/*	Format: 00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
+		return ret;
+	}
+
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		peerMAC[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		/*	Commented by Albert 2011/05/18 */
+		/*	Match the device address located in the P2P IE */
+		/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
+
+		p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
+		if (p2pie) {
+			/*	The P2P Device ID attribute is included in the Beacon frame. */
+			/*	The P2P Device Info attribute is included in the probe response frame. */
+			printk("[%s] Got P2P IE\n", __FUNCTION__);
+			if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device ID attribute of Beacon first */
+				printk("[%s] P2P_ATTR_DEVICE_ID\n", __FUNCTION__);
+				if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
+					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+					break;
+				}
+			} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device Info attribute of probe response */
+				printk("[%s] P2P_ATTR_DEVICE_INFO\n", __FUNCTION__);
+				if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
+					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+					break;
+				}
+			}
+
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+	printk("[%s] channel = %d\n", __FUNCTION__, uintPeerChannel);
+
+	if (uintPeerChannel) {
+		u8 *wfd_ie;
+		uint wfd_ielen = 0;
+
+		wfd_ie = rtw_bss_ex_get_wfd_ie(&pnetwork->network, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			u8 *wfd_devinfo;
+			uint wfd_devlen;
+
+			RTW_INFO("[%s] Found WFD IE!\n", __FUNCTION__);
+			wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
+			if (wfd_devinfo) {
+				u16	wfd_devinfo_field = 0;
+
+				/*	Commented by Albert 20120319 */
+				/*	The first two bytes are the WFD device information field of WFD device information subelement. */
+				/*	In big endian format. */
+				wfd_devinfo_field = RTW_GET_BE16(wfd_devinfo);
+				if (wfd_devinfo_field & WFD_DEVINFO_PC_TDLS)
+					pwfd_info->wfd_pc = _TRUE;
+				else
+					pwfd_info->wfd_pc = _FALSE;
+			}
+		}
+	} else
+		RTW_INFO("[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__);
+
+exit:
+
+	return ret;
+
+}
+
+static int rtw_p2p_set_wfd_device_type(struct net_device *dev,
+				       struct iw_request_info *info,
+				       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
+	struct wifi_display_info		*pwfd_info = pwdinfo->wfd_info;
+
+	/*	Commented by Albert 20120328 */
+	/*	The input data is 0 or 1 */
+	/*	0: specify to Miracast source device */
+	/*	1 or others: specify to Miracast sink device (display device) */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (extra[0] == '0')	/*	Set to Miracast source device. */
+		pwfd_info->wfd_device_type = WFD_DEVINFO_SOURCE;
+	else					/*	Set to Miracast sink device. */
+		pwfd_info->wfd_device_type = WFD_DEVINFO_PSINK;
+
+exit:
+
+	return ret;
+
+}
+
+static int rtw_p2p_set_wfd_enable(struct net_device *dev,
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
+{
+	/*	Commented by Kurt 20121206
+	 *	This function is used to set wfd enabled */
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+
+	if (*extra == '0')
+		rtw_wfd_enable(padapter, 0);
+	else if (*extra == '1')
+		rtw_wfd_enable(padapter, 1);
+
+	RTW_INFO("[%s] wfd_enable = %d\n", __FUNCTION__, pwdinfo->wfd_info->wfd_enable);
+
+	return ret;
+
+}
+
+static int rtw_p2p_set_driver_iface(struct net_device *dev,
+				    struct iw_request_info *info,
+				    union iwreq_data *wrqu, char *extra)
+{
+	/*	Commented by Kurt 20121206
+	 *	This function is used to set driver iface is WEXT or CFG80211 */
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+
+	if (*extra == '1') {
+		pwdinfo->driver_interface = DRIVER_WEXT;
+		RTW_INFO("[%s] driver_interface = WEXT\n", __FUNCTION__);
+	} else if (*extra == '2') {
+		pwdinfo->driver_interface = DRIVER_CFG80211;
+		RTW_INFO("[%s] driver_interface = CFG80211\n", __FUNCTION__);
+	}
+
+	return ret;
+
+}
+
+/*	To set the WFD session available to enable or disable */
+static int rtw_p2p_set_sa(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
+	struct wifi_display_info		*pwfd_info = pwdinfo->wfd_info;
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (0) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
+		return ret;
+	} else {
+		if (extra[0] == '0')	/*	Disable the session available. */
+			pwdinfo->session_available = _FALSE;
+		else if (extra[0] == '1')	/*	Enable the session available. */
+			pwdinfo->session_available = _TRUE;
+		else
+			pwdinfo->session_available = _FALSE;
+	}
+	printk("[%s] session available = %d\n", __FUNCTION__, pwdinfo->session_available);
+
+exit:
+
+	return ret;
+
+}
+#endif /* CONFIG_WFD */
+
+static int rtw_p2p_prov_disc(struct net_device *dev,
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					peerMAC[ETH_ALEN] = { 0x00 };
+	int					jj, kk;
+	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	_list					*plist, *phead;
+	_queue				*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network	*pnetwork = NULL;
+	uint					uintPeerChannel = 0;
+	u8					attr_content[100] = { 0x00 }, _status = 0;
+	u8 *p2pie;
+	uint					p2pielen = 0, attr_contentlen = 0;
+	_irqL				irqL;
+
+	/*	Commented by Albert 20110301 */
+	/*	The input data contains two informations. */
+	/*	1. First information is the MAC address which wants to issue the provisioning discovery request frame. */
+	/*	2. Second information is the WPS configuration method which wants to discovery */
+	/*	Format: 00:E0:4C:00:00:05_display */
+	/*	Format: 00:E0:4C:00:00:05_keypad */
+	/*	Format: 00:E0:4C:00:00:05_pbc */
+	/*	Format: 00:E0:4C:00:00:05_label */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (pwdinfo->p2p_state == P2P_STATE_NONE) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
+		return ret;
+	} else {
+#ifdef CONFIG_INTEL_WIDI
+		if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+			RTW_INFO("[%s] WiFi is under survey!\n", __FUNCTION__);
+			return ret;
+		}
+#endif /* CONFIG_INTEL_WIDI */
+
+		/*	Reset the content of struct tx_provdisc_req_info excluded the wps_config_method_request. */
+		_rtw_memset(pwdinfo->tx_prov_disc_info.peerDevAddr, 0x00, ETH_ALEN);
+		_rtw_memset(pwdinfo->tx_prov_disc_info.peerIFAddr, 0x00, ETH_ALEN);
+		_rtw_memset(&pwdinfo->tx_prov_disc_info.ssid, 0x00, sizeof(NDIS_802_11_SSID));
+		pwdinfo->tx_prov_disc_info.peer_channel_num[0] = 0;
+		pwdinfo->tx_prov_disc_info.peer_channel_num[1] = 0;
+		pwdinfo->tx_prov_disc_info.benable = _FALSE;
+	}
+
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		peerMAC[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+	if (_rtw_memcmp(&extra[18], "display", 7))
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_DISPLYA;
+	else if (_rtw_memcmp(&extra[18], "keypad", 7))
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_KEYPAD;
+	else if (_rtw_memcmp(&extra[18], "pbc", 3))
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
+	else if (_rtw_memcmp(&extra[18], "label", 5))
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_LABEL;
+	else {
+		RTW_INFO("[%s] Unknown WPS config methodn", __FUNCTION__);
+		return ret ;
+	}
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		if (uintPeerChannel != 0)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		/*	Commented by Albert 2011/05/18 */
+		/*	Match the device address located in the P2P IE */
+		/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
+
+		p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
+		if (p2pie) {
+			while (p2pie) {
+				/*	The P2P Device ID attribute is included in the Beacon frame. */
+				/*	The P2P Device Info attribute is included in the probe response frame. */
+
+				if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+					/*	Handle the P2P Device ID attribute of Beacon first */
+					if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
+						uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+						break;
+					}
+				} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+					/*	Handle the P2P Device Info attribute of probe response */
+					if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
+						uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+						break;
+					}
+				}
+
+				/* Get the next P2P IE */
+				p2pie = rtw_get_p2p_ie(p2pie + p2pielen, BSS_EX_TLV_IES_LEN(&pnetwork->network) - (p2pie + p2pielen - BSS_EX_TLV_IES(&pnetwork->network)), NULL, &p2pielen);
+			}
+
+		}
+
+#ifdef CONFIG_INTEL_WIDI
+		/* Some Intel WiDi source may not provide P2P IE, */
+		/* so we could only compare mac addr by 802.11 Source Address */
+		if (pmlmepriv->widi_state == INTEL_WIDI_STATE_WFD_CONNECTION
+		    && uintPeerChannel == 0) {
+			if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+				uintPeerChannel = pnetwork->network.Configuration.DSConfig;
+				break;
+			}
+		}
+#endif /* CONFIG_INTEL_WIDI */
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (uintPeerChannel) {
+#ifdef CONFIG_WFD
+		if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
+			struct wifi_display_info *pwfd_info = pwdinfo->wfd_info;
+			u8 *wfd_ie;
+			uint wfd_ielen = 0;
+
+			wfd_ie = rtw_bss_ex_get_wfd_ie(&pnetwork->network, NULL, &wfd_ielen);
+			if (wfd_ie) {
+				u8 *wfd_devinfo;
+				uint wfd_devlen;
+
+				RTW_INFO("[%s] Found WFD IE!\n", __FUNCTION__);
+				wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
+				if (wfd_devinfo) {
+					u16	wfd_devinfo_field = 0;
+
+					/*	Commented by Albert 20120319 */
+					/*	The first two bytes are the WFD device information field of WFD device information subelement. */
+					/*	In big endian format. */
+					wfd_devinfo_field = RTW_GET_BE16(wfd_devinfo);
+					if (wfd_devinfo_field & WFD_DEVINFO_SESSION_AVAIL)
+						pwfd_info->peer_session_avail = _TRUE;
+					else
+						pwfd_info->peer_session_avail = _FALSE;
+				}
+			}
+
+			if (_FALSE == pwfd_info->peer_session_avail) {
+				RTW_INFO("[%s] WFD Session not avaiable!\n", __FUNCTION__);
+				goto exit;
+			}
+		}
+#endif /* CONFIG_WFD */
+
+		RTW_INFO("[%s] peer channel: %d!\n", __FUNCTION__, uintPeerChannel);
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif /* CONFIG_CONCURRENT_MODE */
+		_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerIFAddr, pnetwork->network.MacAddress, ETH_ALEN);
+		_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerDevAddr, peerMAC, ETH_ALEN);
+		pwdinfo->tx_prov_disc_info.peer_channel_num[0] = (u16) uintPeerChannel;
+		pwdinfo->tx_prov_disc_info.benable = _TRUE;
+		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ);
+
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT))
+			_rtw_memcpy(&pwdinfo->tx_prov_disc_info.ssid, &pnetwork->network.Ssid, sizeof(NDIS_802_11_SSID));
+		else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+			_rtw_memcpy(pwdinfo->tx_prov_disc_info.ssid.Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN);
+			pwdinfo->tx_prov_disc_info.ssid.SsidLength = P2P_WILDCARD_SSID_LEN;
+		}
+
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
+			u8 union_bw = rtw_mi_get_union_bw(padapter);
+			u8 union_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_leave_opch(padapter);
+
+		} else
+			set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+#else
+		set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+#endif
+
+		_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_PROVISION_TIMEOUT);
+		else
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
+#else
+		_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
+#endif /* CONFIG_CONCURRENT_MODE		 */
+
+	} else {
+		RTW_INFO("[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__);
+#ifdef CONFIG_INTEL_WIDI
+		_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
+		rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
+		rtw_free_network_queue(padapter, _TRUE);
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		rtw_sitesurvey_cmd(padapter, NULL);
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+#endif /* CONFIG_INTEL_WIDI */
+	}
+exit:
+
+	return ret;
+
+}
+
+/*	Added by Albert 20110328
+ *	This function is used to inform the driver the user had specified the pin code value or pbc
+ *	to application. */
+
+static int rtw_p2p_got_wpsinfo(struct net_device *dev,
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+	/*	Added by Albert 20110328 */
+	/*	if the input data is P2P_NO_WPSINFO -> reset the wpsinfo */
+	/*	if the input data is P2P_GOT_WPSINFO_PEER_DISPLAY_PIN -> the utility just input the PIN code got from the peer P2P device. */
+	/*	if the input data is P2P_GOT_WPSINFO_SELF_DISPLAY_PIN -> the utility just got the PIN code from itself. */
+	/*	if the input data is P2P_GOT_WPSINFO_PBC -> the utility just determine to use the PBC */
+
+	if (*extra == '0')
+		pwdinfo->ui_got_wps_info = P2P_NO_WPSINFO;
+	else if (*extra == '1')
+		pwdinfo->ui_got_wps_info = P2P_GOT_WPSINFO_PEER_DISPLAY_PIN;
+	else if (*extra == '2')
+		pwdinfo->ui_got_wps_info = P2P_GOT_WPSINFO_SELF_DISPLAY_PIN;
+	else if (*extra == '3')
+		pwdinfo->ui_got_wps_info = P2P_GOT_WPSINFO_PBC;
+	else
+		pwdinfo->ui_got_wps_info = P2P_NO_WPSINFO;
+
+	return ret;
+
+}
+
+#endif /* CONFIG_P2P */
+
+static int rtw_p2p_set(struct net_device *dev,
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+#ifdef CONFIG_P2P
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, extra);
+
+	if (_rtw_memcmp(extra, "enable=", 7))
+		rtw_wext_p2p_enable(dev, info, wrqu, &extra[7]);
+	else if (_rtw_memcmp(extra, "setDN=", 6)) {
+		wrqu->data.length -= 6;
+		rtw_p2p_setDN(dev, info, wrqu, &extra[6]);
+	} else if (_rtw_memcmp(extra, "profilefound=", 13)) {
+		wrqu->data.length -= 13;
+		rtw_p2p_profilefound(dev, info, wrqu, &extra[13]);
+	} else if (_rtw_memcmp(extra, "prov_disc=", 10)) {
+		wrqu->data.length -= 10;
+		rtw_p2p_prov_disc(dev, info, wrqu, &extra[10]);
+	} else if (_rtw_memcmp(extra, "nego=", 5)) {
+		wrqu->data.length -= 5;
+		rtw_p2p_connect(dev, info, wrqu, &extra[5]);
+	} else if (_rtw_memcmp(extra, "intent=", 7)) {
+		/*	Commented by Albert 2011/03/23 */
+		/*	The wrqu->data.length will include the null character */
+		/*	So, we will decrease 7 + 1 */
+		wrqu->data.length -= 8;
+		rtw_p2p_set_intent(dev, info, wrqu, &extra[7]);
+	} else if (_rtw_memcmp(extra, "ssid=", 5)) {
+		wrqu->data.length -= 5;
+		rtw_p2p_set_go_nego_ssid(dev, info, wrqu, &extra[5]);
+	} else if (_rtw_memcmp(extra, "got_wpsinfo=", 12)) {
+		wrqu->data.length -= 12;
+		rtw_p2p_got_wpsinfo(dev, info, wrqu, &extra[12]);
+	} else if (_rtw_memcmp(extra, "listen_ch=", 10)) {
+		/*	Commented by Albert 2011/05/24 */
+		/*	The wrqu->data.length will include the null character */
+		/*	So, we will decrease (10 + 1)	 */
+		wrqu->data.length -= 11;
+		rtw_p2p_set_listen_ch(dev, info, wrqu, &extra[10]);
+	} else if (_rtw_memcmp(extra, "op_ch=", 6)) {
+		/*	Commented by Albert 2011/05/24 */
+		/*	The wrqu->data.length will include the null character */
+		/*	So, we will decrease (6 + 1)	 */
+		wrqu->data.length -= 7;
+		rtw_p2p_set_op_ch(dev, info, wrqu, &extra[6]);
+	} else if (_rtw_memcmp(extra, "invite=", 7)) {
+		wrqu->data.length -= 8;
+		rtw_p2p_invite_req(dev, info, wrqu, &extra[7]);
+	} else if (_rtw_memcmp(extra, "persistent=", 11)) {
+		wrqu->data.length -= 11;
+		rtw_p2p_set_persistent(dev, info, wrqu, &extra[11]);
+	} else if (_rtw_memcmp(extra, "uuid=", 5)) {
+		wrqu->data.length -= 5;
+		ret = rtw_p2p_set_wps_uuid(dev, info, wrqu, &extra[5]);
+	}
+
+#ifdef CONFIG_WFD
+	if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
+		if (_rtw_memcmp(extra, "sa=", 3)) {
+			/* sa: WFD Session Available information */
+			wrqu->data.length -= 3;
+			rtw_p2p_set_sa(dev, info, wrqu, &extra[3]);
+		} else if (_rtw_memcmp(extra, "pc=", 3)) {
+			/* pc: WFD Preferred Connection */
+			wrqu->data.length -= 3;
+			rtw_p2p_set_pc(dev, info, wrqu, &extra[3]);
+		} else if (_rtw_memcmp(extra, "wfd_type=", 9)) {
+			wrqu->data.length -= 9;
+			rtw_p2p_set_wfd_device_type(dev, info, wrqu, &extra[9]);
+		} else if (_rtw_memcmp(extra, "wfd_enable=", 11)) {
+			wrqu->data.length -= 11;
+			rtw_p2p_set_wfd_enable(dev, info, wrqu, &extra[11]);
+		} else if (_rtw_memcmp(extra, "driver_iface=", 13)) {
+			wrqu->data.length -= 13;
+			rtw_p2p_set_driver_iface(dev, info, wrqu, &extra[13]);
+		}
+	}
+#endif /* CONFIG_WFD */
+
+#endif /* CONFIG_P2P */
+
+	return ret;
+
+}
+
+static int rtw_p2p_get(struct net_device *dev,
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+
+#ifdef CONFIG_P2P
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+
+	if (padapter->bShowGetP2PState)
+		RTW_INFO("[%s] extra = %s\n", __FUNCTION__, (char *) wrqu->data.pointer);
+
+	if (_rtw_memcmp(wrqu->data.pointer, "status", 6))
+		rtw_p2p_get_status(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "role", 4))
+		rtw_p2p_get_role(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "peer_ifa", 8))
+		rtw_p2p_get_peer_ifaddr(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "req_cm", 6))
+		rtw_p2p_get_req_cm(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "peer_deva", 9)) {
+		/*	Get the P2P device address when receiving the provision discovery request frame. */
+		rtw_p2p_get_peer_devaddr(dev, info, wrqu, extra);
+	} else if (_rtw_memcmp(wrqu->data.pointer, "group_id", 8))
+		rtw_p2p_get_groupid(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "inv_peer_deva", 13)) {
+		/*	Get the P2P device address when receiving the P2P Invitation request frame. */
+		rtw_p2p_get_peer_devaddr_by_invitation(dev, info, wrqu, extra);
+	} else if (_rtw_memcmp(wrqu->data.pointer, "op_ch", 5))
+		rtw_p2p_get_op_ch(dev, info, wrqu, extra);
+
+#ifdef CONFIG_WFD
+	if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
+		if (_rtw_memcmp(wrqu->data.pointer, "peer_port", 9))
+			rtw_p2p_get_peer_wfd_port(dev, info, wrqu, extra);
+		else if (_rtw_memcmp(wrqu->data.pointer, "wfd_sa", 6))
+			rtw_p2p_get_peer_wfd_session_available(dev, info, wrqu, extra);
+		else if (_rtw_memcmp(wrqu->data.pointer, "wfd_pc", 6))
+			rtw_p2p_get_peer_wfd_preferred_connection(dev, info, wrqu, extra);
+	}
+#endif /* CONFIG_WFD */
+
+#endif /* CONFIG_P2P */
+
+	return ret;
+
+}
+
+static int rtw_p2p_get2(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+
+#ifdef CONFIG_P2P
+
+	int length = wrqu->data.length;
+	char *buffer = (u8 *)rtw_malloc(length);
+
+	if (buffer == NULL) {
+		ret = -ENOMEM;
+		goto bad;
+	}
+
+	if (copy_from_user(buffer, wrqu->data.pointer, wrqu->data.length)) {
+		ret = -EFAULT;
+		goto bad;
+	}
+
+	RTW_INFO("[%s] buffer = %s\n", __FUNCTION__, buffer);
+
+	if (_rtw_memcmp(buffer, "wpsCM=", 6))
+		ret = rtw_p2p_get_wps_configmethod(dev, info, wrqu, extra, &buffer[6]);
+	else if (_rtw_memcmp(buffer, "devN=", 5))
+		ret = rtw_p2p_get_device_name(dev, info, wrqu, extra, &buffer[5]);
+	else if (_rtw_memcmp(buffer, "dev_type=", 9))
+		ret = rtw_p2p_get_device_type(dev, info, wrqu, extra, &buffer[9]);
+	else if (_rtw_memcmp(buffer, "go_devadd=", 10))
+		ret = rtw_p2p_get_go_device_address(dev, info, wrqu, extra, &buffer[10]);
+	else if (_rtw_memcmp(buffer, "InvProc=", 8))
+		ret = rtw_p2p_get_invitation_procedure(dev, info, wrqu, extra, &buffer[8]);
+	else {
+		snprintf(extra, sizeof("Command not found."), "Command not found.");
+		wrqu->data.length = strlen(extra);
+	}
+
+bad:
+	if (buffer)
+		rtw_mfree(buffer, length);
+
+#endif /* CONFIG_P2P */
+
+	return ret;
+
+}
+
+static int rtw_cta_test_start(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+	_adapter	*padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
+
+	RTW_INFO("%s %s\n", __func__, extra);
+	if (!strcmp(extra, "1"))
+		hal_data->in_cta_test = 1;
+	else
+		hal_data->in_cta_test = 0;
+
+	rtw_hal_rcr_set_chk_bssid(padapter, MLME_ACTION_NONE);
+
+	return ret;
+}
+
+extern int rtw_change_ifname(_adapter *padapter, const char *ifname);
+static int rtw_rereg_nd_name(struct net_device *dev,
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+	_adapter *padapter = rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct rereg_nd_name_data *rereg_priv = &padapter->rereg_nd_name_priv;
+	char new_ifname[IFNAMSIZ];
+
+	if (rereg_priv->old_ifname[0] == 0) {
+		char *reg_ifname;
+#ifdef CONFIG_CONCURRENT_MODE
+		if (padapter->isprimary)
+			reg_ifname = padapter->registrypriv.ifname;
+		else
+#endif
+			reg_ifname = padapter->registrypriv.if2name;
+
+		strncpy(rereg_priv->old_ifname, reg_ifname, IFNAMSIZ);
+		rereg_priv->old_ifname[IFNAMSIZ - 1] = 0;
+	}
+
+	/* RTW_INFO("%s wrqu->data.length:%d\n", __FUNCTION__, wrqu->data.length); */
+	if (wrqu->data.length > IFNAMSIZ)
+		return -EFAULT;
+
+	if (copy_from_user(new_ifname, wrqu->data.pointer, IFNAMSIZ))
+		return -EFAULT;
+
+	if (0 == strcmp(rereg_priv->old_ifname, new_ifname))
+		return ret;
+
+	RTW_INFO("%s new_ifname:%s\n", __FUNCTION__, new_ifname);
+	rtw_set_rtnl_lock_holder(dvobj, current);
+	ret = rtw_change_ifname(padapter, new_ifname);
+	rtw_set_rtnl_lock_holder(dvobj, NULL);
+	if (0 != ret)
+		goto exit;
+
+	if (_rtw_memcmp(rereg_priv->old_ifname, "disable%d", 9) == _TRUE) {
+		/* rtw_ips_mode_req(&padapter->pwrctrlpriv, rereg_priv->old_ips_mode); */
+	}
+
+	strncpy(rereg_priv->old_ifname, new_ifname, IFNAMSIZ);
+	rereg_priv->old_ifname[IFNAMSIZ - 1] = 0;
+
+	if (_rtw_memcmp(new_ifname, "disable%d", 9) == _TRUE) {
+
+		RTW_INFO("%s disable\n", __FUNCTION__);
+		/* free network queue for Android's timming issue */
+		rtw_free_network_queue(padapter, _TRUE);
+
+		/* the interface is being "disabled", we can do deeper IPS */
+		/* rereg_priv->old_ips_mode = rtw_get_ips_mode_req(&padapter->pwrctrlpriv); */
+		/* rtw_ips_mode_req(&padapter->pwrctrlpriv, IPS_NORMAL); */
+	}
+exit:
+	return ret;
+
+}
+
+#ifdef CONFIG_IOL
+#include <rtw_iol.h>
+#endif
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+#include "../../hal/hal_dm_acs.h"
+#endif
+#ifdef DBG_CMD_QUEUE
+u8 dump_cmd_id = 0;
+#endif
+/*
+#ifdef DBG_DUMP_TSF_BY_PORT
+extern void get_tsf_by_port(_adapter *adapter, u8 *tsftr, u8 hw_port);
+#endif
+*/
+static int rtw_dbg_port(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	_irqL irqL;
+	int ret = 0;
+	u8 major_cmd, minor_cmd;
+	u16 arg;
+	u32 extra_arg, *pdata, val32;
+	struct sta_info *psta;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+
+	pdata = (u32 *)&wrqu->data;
+
+	val32 = *pdata;
+	arg = (u16)(val32 & 0x0000ffff);
+	major_cmd = (u8)(val32 >> 24);
+	minor_cmd = (u8)((val32 >> 16) & 0x00ff);
+
+	extra_arg = *(pdata + 1);
+
+	switch (major_cmd) {
+	case 0x70: /* read_reg */
+		switch (minor_cmd) {
+		case 1:
+			RTW_INFO("rtw_read8(0x%x)=0x%02x\n", arg, rtw_read8(padapter, arg));
+			break;
+		case 2:
+			RTW_INFO("rtw_read16(0x%x)=0x%04x\n", arg, rtw_read16(padapter, arg));
+			break;
+		case 4:
+			RTW_INFO("rtw_read32(0x%x)=0x%08x\n", arg, rtw_read32(padapter, arg));
+			break;
+		}
+		break;
+	case 0x71: /* write_reg */
+		switch (minor_cmd) {
+		case 1:
+			rtw_write8(padapter, arg, extra_arg);
+			RTW_INFO("rtw_write8(0x%x)=0x%02x\n", arg, rtw_read8(padapter, arg));
+			break;
+		case 2:
+			rtw_write16(padapter, arg, extra_arg);
+			RTW_INFO("rtw_write16(0x%x)=0x%04x\n", arg, rtw_read16(padapter, arg));
+			break;
+		case 4:
+			rtw_write32(padapter, arg, extra_arg);
+			RTW_INFO("rtw_write32(0x%x)=0x%08x\n", arg, rtw_read32(padapter, arg));
+			break;
+		}
+		break;
+	case 0x72: /* read_bb */
+		RTW_INFO("read_bbreg(0x%x)=0x%x\n", arg, rtw_hal_read_bbreg(padapter, arg, 0xffffffff));
+		break;
+	case 0x73: /* write_bb */
+		rtw_hal_write_bbreg(padapter, arg, 0xffffffff, extra_arg);
+		RTW_INFO("write_bbreg(0x%x)=0x%x\n", arg, rtw_hal_read_bbreg(padapter, arg, 0xffffffff));
+		break;
+	case 0x74: /* read_rf */
+		RTW_INFO("read RF_reg path(0x%02x),offset(0x%x),value(0x%08x)\n", minor_cmd, arg, rtw_hal_read_rfreg(padapter, minor_cmd, arg, 0xffffffff));
+		break;
+	case 0x75: /* write_rf */
+		rtw_hal_write_rfreg(padapter, minor_cmd, arg, 0xffffffff, extra_arg);
+		RTW_INFO("write RF_reg path(0x%02x),offset(0x%x),value(0x%08x)\n", minor_cmd, arg, rtw_hal_read_rfreg(padapter, minor_cmd, arg, 0xffffffff));
+		break;
+
+	case 0x76:
+		switch (minor_cmd) {
+		case 0x00: /* normal mode, */
+			padapter->recvpriv.is_signal_dbg = 0;
+			break;
+		case 0x01: /* dbg mode */
+			padapter->recvpriv.is_signal_dbg = 1;
+			extra_arg = extra_arg > 100 ? 100 : extra_arg;
+			padapter->recvpriv.signal_strength_dbg = extra_arg;
+			break;
+		}
+		break;
+	case 0x78: /* IOL test */
+		switch (minor_cmd) {
+		#ifdef CONFIG_IOL
+		case 0x04: { /* LLT table initialization test */
+			u8 page_boundary = 0xf9;
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
+					break;
+				}
+
+				rtw_IOL_append_LLT_cmd(xmit_frame, page_boundary);
+
+
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 500, 0))
+					ret = -EPERM;
+			}
+		}
+			break;
+		case 0x05: { /* blink LED test */
+			u16 reg = 0x4c;
+			u32 blink_num = 50;
+			u32 blink_delay_ms = 200;
+			int i;
+
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
+					break;
+				}
+
+				for (i = 0; i < blink_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x00, 0xff);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x08, 0xff);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					#else
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x00);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x08);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					#endif
+				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, (blink_delay_ms * blink_num * 2) + 200, 0))
+					ret = -EPERM;
+			}
+		}
+			break;
+
+		case 0x06: { /* continuous wirte byte test */
+			u16 reg = arg;
+			u16 start_value = 0;
+			u32 write_num = extra_arg;
+			int i;
+			u8 final;
+
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
+					break;
+				}
+
+				for (i = 0; i < write_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, i + start_value, 0xFF);
+					#else
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, i + start_value);
+					#endif
+				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000, 0))
+					ret = -EPERM;
+			}
+
+			final = rtw_read8(padapter, reg);
+			if (start_value + write_num - 1 == final)
+				RTW_INFO("continuous IOL_CMD_WB_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
+			else
+				RTW_INFO("continuous IOL_CMD_WB_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
+		}
+			break;
+
+		case 0x07: { /* continuous wirte word test */
+			u16 reg = arg;
+			u16 start_value = 200;
+			u32 write_num = extra_arg;
+
+			int i;
+			u16 final;
+
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
+					break;
+				}
+
+				for (i = 0; i < write_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WW_cmd(xmit_frame, reg, i + start_value, 0xFFFF);
+					#else
+					rtw_IOL_append_WW_cmd(xmit_frame, reg, i + start_value);
+					#endif
+				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000, 0))
+					ret = -EPERM;
+			}
+
+			final = rtw_read16(padapter, reg);
+			if (start_value + write_num - 1 == final)
+				RTW_INFO("continuous IOL_CMD_WW_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
+			else
+				RTW_INFO("continuous IOL_CMD_WW_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
+		}
+			break;
+
+		case 0x08: { /* continuous wirte dword test */
+			u16 reg = arg;
+			u32 start_value = 0x110000c7;
+			u32 write_num = extra_arg;
+
+			int i;
+			u32 final;
+
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
+					break;
+				}
+
+				for (i = 0; i < write_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WD_cmd(xmit_frame, reg, i + start_value, 0xFFFFFFFF);
+					#else
+					rtw_IOL_append_WD_cmd(xmit_frame, reg, i + start_value);
+					#endif
+				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000, 0))
+					ret = -EPERM;
+
+			}
+
+			final = rtw_read32(padapter, reg);
+			if (start_value + write_num - 1 == final)
+				RTW_INFO("continuous IOL_CMD_WD_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
+			else
+				RTW_INFO("continuous IOL_CMD_WD_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
+		}
+			break;
+		#endif /* CONFIG_IOL */
+		}
+		break;
+	case 0x79: {
+		/*
+		* dbg 0x79000000 [value], set RESP_TXAGC to + value, value:0~15
+		* dbg 0x79010000 [value], set RESP_TXAGC to - value, value:0~15
+		*/
+		u8 value =  extra_arg & 0x0f;
+		u8 sign = minor_cmd;
+		u16 write_value = 0;
+
+		RTW_INFO("%s set RESP_TXAGC to %s %u\n", __func__, sign ? "minus" : "plus", value);
+
+		if (sign)
+			value = value | 0x10;
+
+		write_value = value | (value << 5);
+		rtw_write16(padapter, 0x6d9, write_value);
+	}
+		break;
+	case 0x7a:
+		receive_disconnect(padapter, pmlmeinfo->network.MacAddress
+				   , WLAN_REASON_EXPIRATION_CHK, _FALSE);
+		break;
+	case 0x7F:
+		switch (minor_cmd) {
+		case 0x0:
+			RTW_INFO("fwstate=0x%x\n", get_fwstate(pmlmepriv));
+			break;
+		case 0x01:
+			RTW_INFO("auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n",
+				psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm,
+				psecuritypriv->ndisauthtype, psecuritypriv->ndisencryptstatus);
+			break;
+		case 0x02:
+			RTW_INFO("pmlmeinfo->state=0x%x\n", pmlmeinfo->state);
+			RTW_INFO("DrvBcnEarly=%d\n", pmlmeext->DrvBcnEarly);
+			RTW_INFO("DrvBcnTimeOut=%d\n", pmlmeext->DrvBcnTimeOut);
+			break;
+		case 0x03:
+			RTW_INFO("qos_option=%d\n", pmlmepriv->qospriv.qos_option);
+#ifdef CONFIG_80211N_HT
+			RTW_INFO("ht_option=%d\n", pmlmepriv->htpriv.ht_option);
+#endif /* CONFIG_80211N_HT */
+			break;
+		case 0x04:
+			RTW_INFO("cur_ch=%d\n", pmlmeext->cur_channel);
+			RTW_INFO("cur_bw=%d\n", pmlmeext->cur_bwmode);
+			RTW_INFO("cur_ch_off=%d\n", pmlmeext->cur_ch_offset);
+
+			RTW_INFO("oper_ch=%d\n", rtw_get_oper_ch(padapter));
+			RTW_INFO("oper_bw=%d\n", rtw_get_oper_bw(padapter));
+			RTW_INFO("oper_ch_offet=%d\n", rtw_get_oper_choffset(padapter));
+
+			break;
+		case 0x05:
+			psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
+			if (psta) {
+				RTW_INFO("SSID=%s\n", cur_network->network.Ssid.Ssid);
+				RTW_INFO("sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+				RTW_INFO("cur_channel=%d, cur_bwmode=%d, cur_ch_offset=%d\n", pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
+				RTW_INFO("rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
+				RTW_INFO("state=0x%x, aid=%d, macid=%d, raid=%d\n",
+					psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
+#ifdef CONFIG_80211N_HT
+				RTW_INFO("qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
+				RTW_INFO("bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n"
+					, psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
+				RTW_INFO("ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
+				RTW_INFO("agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
+#endif /* CONFIG_80211N_HT */
+
+				sta_rx_reorder_ctl_dump(RTW_DBGDUMP, psta);
+			} else
+				RTW_INFO("can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
+			break;
+		case 0x06: {
+				#ifdef DBG_DUMP_TSF_BY_PORT
+				u64 tsf = 0;
+
+				get_tsf_by_port(padapter, (u8 *)&tsf, extra_arg);
+				RTW_INFO(" PORT-%d TSF :%lld\n", extra_arg, tsf);
+				#endif
+		}
+			break;
+		case 0x07:
+			RTW_INFO("bSurpriseRemoved=%s, bDriverStopped=%s\n"
+				, rtw_is_surprise_removed(padapter) ? "True" : "False"
+				, rtw_is_drv_stopped(padapter) ? "True" : "False");
+			break;
+		case 0x08: {
+			struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+			struct recv_priv  *precvpriv = &padapter->recvpriv;
+
+			RTW_INFO("free_xmitbuf_cnt=%d, free_xmitframe_cnt=%d"
+				", free_xmit_extbuf_cnt=%d, free_xframe_ext_cnt=%d"
+				 ", free_recvframe_cnt=%d\n",
+				pxmitpriv->free_xmitbuf_cnt, pxmitpriv->free_xmitframe_cnt,
+				pxmitpriv->free_xmit_extbuf_cnt, pxmitpriv->free_xframe_ext_cnt,
+				 precvpriv->free_recvframe_cnt);
+#ifdef CONFIG_USB_HCI
+			RTW_INFO("rx_urb_pending_cn=%d\n", ATOMIC_READ(&(precvpriv->rx_pending_cnt)));
+#endif
+		}
+			break;
+		case 0x09: {
+			int i;
+			_list	*plist, *phead;
+
+#ifdef CONFIG_AP_MODE
+			RTW_INFO_DUMP("sta_dz_bitmap:", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+			RTW_INFO_DUMP("tim_bitmap:", pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
+#endif
+			_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+			for (i = 0; i < NUM_STA; i++) {
+				phead = &(pstapriv->sta_hash[i]);
+				plist = get_next(phead);
+
+				while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+					psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+
+					plist = get_next(plist);
+
+					if (extra_arg == psta->cmn.aid) {
+						RTW_INFO("sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+						RTW_INFO("rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
+						RTW_INFO("state=0x%x, aid=%d, macid=%d, raid=%d\n",
+							psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
+#ifdef CONFIG_80211N_HT
+						RTW_INFO("qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
+						RTW_INFO("bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n",
+							psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m,
+							psta->htpriv.sgi_40m);
+						RTW_INFO("ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
+						RTW_INFO("agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_AP_MODE
+						RTW_INFO("capability=0x%x\n", psta->capability);
+						RTW_INFO("flags=0x%x\n", psta->flags);
+						RTW_INFO("wpa_psk=0x%x\n", psta->wpa_psk);
+						RTW_INFO("wpa2_group_cipher=0x%x\n", psta->wpa2_group_cipher);
+						RTW_INFO("wpa2_pairwise_cipher=0x%x\n", psta->wpa2_pairwise_cipher);
+						RTW_INFO("qos_info=0x%x\n", psta->qos_info);
+#endif
+						RTW_INFO("dot118021XPrivacy=0x%x\n", psta->dot118021XPrivacy);
+
+						sta_rx_reorder_ctl_dump(RTW_DBGDUMP, psta);
+					}
+
+				}
+			}
+
+			_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+		}
+			break;
+
+		case 0x0b: { /* Enable=1, Disable=0 driver control vrtl_carrier_sense. */
+			/* u8 driver_vcs_en; */ /* Enable=1, Disable=0 driver control vrtl_carrier_sense. */
+			/* u8 driver_vcs_type; */ /* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. */
+
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl vcs\n");
+				padapter->driver_vcs_en = 0;
+			} else if (arg == 1) {
+				RTW_INFO("enable driver ctrl vcs = %d\n", extra_arg);
+				padapter->driver_vcs_en = 1;
+
+				if (extra_arg > 2)
+					padapter->driver_vcs_type = 1;
+				else
+					padapter->driver_vcs_type = extra_arg;
+			}
+		}
+			break;
+		case 0x0c: { /* dump rx/tx packet */
+			if (arg == 0) {
+				RTW_INFO("dump rx packet (%d)\n", extra_arg);
+				/* pHalData->bDumpRxPkt =extra_arg;						 */
+				rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DUMP_RXPKT, &(extra_arg));
+			} else if (arg == 1) {
+				RTW_INFO("dump tx packet (%d)\n", extra_arg);
+				rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DUMP_TXPKT, &(extra_arg));
+			}
+		}
+			break;
+		case 0x0e: {
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl rx_ampdu_factor\n");
+				padapter->driver_rx_ampdu_factor = 0xFF;
+			} else if (arg == 1) {
+
+				RTW_INFO("enable driver ctrl rx_ampdu_factor = %d\n", extra_arg);
+
+				if (extra_arg > 0x03)
+					padapter->driver_rx_ampdu_factor = 0xFF;
+				else
+					padapter->driver_rx_ampdu_factor = extra_arg;
+			}
+		}
+			break;
+		#ifdef DBG_CONFIG_ERROR_DETECT
+		case 0x0f: {
+			if (extra_arg == 0) {
+				RTW_INFO("###### silent reset test.......#####\n");
+				rtw_hal_sreset_reset(padapter);
+			} else {
+				HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+				struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+				psrtpriv->dbg_trigger_point = extra_arg;
+			}
+
+		}
+			break;
+		case 0x15: {
+			struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+			RTW_INFO("==>silent resete cnts:%d\n", pwrpriv->ips_enter_cnts);
+		}
+			break;
+
+		#endif
+
+		case 0x10: /* driver version display */
+			dump_drv_version(RTW_DBGDUMP);
+			break;
+		case 0x11: { /* dump linked status */
+			int pre_mode;
+			pre_mode = padapter->bLinkInfoDump;
+			/* linked_info_dump(padapter,extra_arg); */
+			if (extra_arg == 1 || (extra_arg == 0 && pre_mode == 1)) /* not consider pwr_saving 0: */
+				padapter->bLinkInfoDump = extra_arg;
+
+			else if ((extra_arg == 2) || (extra_arg == 0 && pre_mode == 2)) { /* consider power_saving */
+				/* RTW_INFO("linked_info_dump =%s\n", (padapter->bLinkInfoDump)?"enable":"disable") */
+				linked_info_dump(padapter, extra_arg);
+			}
+
+
+
+		}
+			break;
+#ifdef CONFIG_80211N_HT
+		case 0x12: { /* set rx_stbc */
+			struct registry_priv	*pregpriv = &padapter->registrypriv;
+			/* 0: disable, bit(0):enable 2.4g, bit(1):enable 5g, 0x3: enable both 2.4g and 5g */
+			/* default is set to enable 2.4GHZ for IOT issue with bufflao's AP at 5GHZ */
+			if (pregpriv && (extra_arg == 0 || extra_arg == 1 || extra_arg == 2 || extra_arg == 3)) {
+				pregpriv->rx_stbc = extra_arg;
+				RTW_INFO("set rx_stbc=%d\n", pregpriv->rx_stbc);
+			} else
+				RTW_INFO("get rx_stbc=%d\n", pregpriv->rx_stbc);
+
+		}
+			break;
+		case 0x13: { /* set ampdu_enable */
+			struct registry_priv	*pregpriv = &padapter->registrypriv;
+			/* 0: disable, 0x1:enable */
+			if (pregpriv && extra_arg < 2) {
+				pregpriv->ampdu_enable = extra_arg;
+				RTW_INFO("set ampdu_enable=%d\n", pregpriv->ampdu_enable);
+			} else
+				RTW_INFO("get ampdu_enable=%d\n", pregpriv->ampdu_enable);
+
+		}
+			break;
+#endif
+		case 0x14: { /* get wifi_spec */
+			struct registry_priv	*pregpriv = &padapter->registrypriv;
+			RTW_INFO("get wifi_spec=%d\n", pregpriv->wifi_spec);
+
+		}
+			break;
+
+#ifdef DBG_FIXED_CHAN
+		case 0x17: {
+			struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+			printk("===>  Fixed channel to %d\n", extra_arg);
+			pmlmeext->fixed_chan = extra_arg;
+
+		}
+			break;
+#endif
+#ifdef CONFIG_80211N_HT
+		case 0x19: {
+			struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+			/* extra_arg : */
+			/* BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, */
+			/* BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx */
+			if (arg == 0) {
+				RTW_INFO("driver disable LDPC\n");
+				pregistrypriv->ldpc_cap = 0x00;
+			} else if (arg == 1) {
+				RTW_INFO("driver set LDPC cap = 0x%x\n", extra_arg);
+				pregistrypriv->ldpc_cap = (u8)(extra_arg & 0x33);
+			}
+		}
+			break;
+		case 0x1a: {
+			struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+			/* extra_arg : */
+			/* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, */
+			/* BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
+			if (arg == 0) {
+				RTW_INFO("driver disable STBC\n");
+				pregistrypriv->stbc_cap = 0x00;
+			} else if (arg == 1) {
+				RTW_INFO("driver set STBC cap = 0x%x\n", extra_arg);
+				pregistrypriv->stbc_cap = (u8)(extra_arg & 0x33);
+			}
+		}
+			break;
+#endif /* CONFIG_80211N_HT */
+		case 0x1b: {
+			struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl max_rx_rate, reset to default_rate_set\n");
+				init_mlme_default_rate_set(padapter);
+#ifdef CONFIG_80211N_HT
+				pregistrypriv->ht_enable = (u8)rtw_ht_enable;
+#endif /* CONFIG_80211N_HT */
+			} else if (arg == 1) {
+
+				int i;
+				u8 max_rx_rate;
+
+				RTW_INFO("enable driver ctrl max_rx_rate = 0x%x\n", extra_arg);
+
+				max_rx_rate = (u8)extra_arg;
+
+				if (max_rx_rate < 0xc) { /* max_rx_rate < MSC0->B or G -> disable HT */
+#ifdef CONFIG_80211N_HT
+					pregistrypriv->ht_enable = 0;
+#endif /* CONFIG_80211N_HT */
+					for (i = 0; i < NumRates; i++) {
+						if (pmlmeext->datarate[i] > max_rx_rate)
+							pmlmeext->datarate[i] = 0xff;
+					}
+
+				}
+#ifdef CONFIG_80211N_HT
+				else if (max_rx_rate < 0x1c) { /* mcs0~mcs15 */
+					u32 mcs_bitmap = 0x0;
+
+					for (i = 0; i < ((max_rx_rate + 1) - 0xc); i++)
+						mcs_bitmap |= BIT(i);
+
+					set_mcs_rate_by_mask(pmlmeext->default_supported_mcs_set, mcs_bitmap);
+				}
+#endif /* CONFIG_80211N_HT							 */
+			}
+		}
+			break;
+		case 0x1c: { /* enable/disable driver control AMPDU Density for peer sta's rx */
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl ampdu density\n");
+				padapter->driver_ampdu_spacing = 0xFF;
+			} else if (arg == 1) {
+
+				RTW_INFO("enable driver ctrl ampdu density = %d\n", extra_arg);
+
+				if (extra_arg > 0x07)
+					padapter->driver_ampdu_spacing = 0xFF;
+				else
+					padapter->driver_ampdu_spacing = extra_arg;
+			}
+		}
+			break;
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+		case 0x1e: {
+			RTW_INFO("===========================================\n");
+			rtw_noise_measure_curchan(padapter);
+			RTW_INFO("===========================================\n");
+		}
+			break;
+#endif
+
+
+#if defined(CONFIG_SDIO_HCI) && defined(CONFIG_SDIO_INDIRECT_ACCESS) && defined(DBG_SDIO_INDIRECT_ACCESS)
+		case 0x1f:
+			{
+				int i, j = 0, test_cnts = 0;
+				static u8 test_code = 0x5A;
+				static u32 data_misatch_cnt = 0, d_acc_err_cnt = 0;
+
+				u32 d_data, i_data;
+				u32 imr;
+
+				test_cnts = extra_arg;
+				for (i = 0; i < test_cnts; i++) {
+					if (RTW_CANNOT_IO(padapter))
+						break;
+
+					rtw_write8(padapter, 0x07, test_code);
+
+					d_data = rtw_read32(padapter, 0x04);
+					imr =  rtw_read32(padapter, 0x10250014);
+					rtw_write32(padapter, 0x10250014, 0);
+					rtw_msleep_os(50);
+
+					i_data = rtw_sd_iread32(padapter, 0x04);
+
+					rtw_write32(padapter, 0x10250014, imr);
+
+					if (d_data != i_data) {
+						data_misatch_cnt++;
+						RTW_ERR("d_data :0x%08x, i_data : 0x%08x\n", d_data, i_data);
+					}
+
+					if (test_code != (i_data >> 24)) {
+						d_acc_err_cnt++;
+						rtw_write8(padapter, 0x07, 0xAA);
+						RTW_ERR("test_code :0x%02x, i_data : 0x%08x\n", test_code, i_data);
+					}
+					if ((j++) == 100) {
+						rtw_msleep_os(2000);
+						RTW_INFO(" Indirect access testing..........%d/%d\n", i, test_cnts);
+						j = 0;
+					}
+
+					test_code = ~test_code;
+					rtw_msleep_os(50);
+				}
+				RTW_INFO("========Indirect access test=========\n");
+				RTW_INFO(" test_cnts = %d\n", test_cnts);
+				RTW_INFO(" direct & indirect read32 data missatch cnts = %d\n", data_misatch_cnt);
+				RTW_INFO(" indirect rdata is not equal to wdata cnts = %d\n", d_acc_err_cnt);
+				RTW_INFO("========Indirect access test=========\n\n");
+				data_misatch_cnt = d_acc_err_cnt = 0;
+
+			}
+			break;
+#endif
+		case 0x20:
+			{
+				if (arg == 0xAA) {
+					u8 page_offset, page_num;
+					u32 page_size = 0;
+					u8 *buffer = NULL;
+					u32 buf_size = 0;
+
+					page_offset = (u8)(extra_arg >> 16);
+					page_num = (u8)(extra_arg & 0xFF);
+					rtw_dump_rsvd_page(RTW_DBGDUMP, padapter, page_offset, page_num);
+				}
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+				else {
+					u8 fifo_sel;
+					u32 addr, size;
+
+					fifo_sel = (u8)(arg & 0x0F);
+					addr = (extra_arg >> 16) & 0xFFFF;
+					size = extra_arg & 0xFFFF;
+					rtw_dump_fifo(RTW_DBGDUMP, padapter, fifo_sel, addr, size);
+				}
+#endif
+			}
+			break;
+
+		case 0x23: {
+			RTW_INFO("turn %s the bNotifyChannelChange Variable\n", (extra_arg == 1) ? "on" : "off");
+			padapter->bNotifyChannelChange = extra_arg;
+			break;
+		}
+		case 0x24: {
+#ifdef CONFIG_P2P
+			RTW_INFO("turn %s the bShowGetP2PState Variable\n", (extra_arg == 1) ? "on" : "off");
+			padapter->bShowGetP2PState = extra_arg;
+#endif /* CONFIG_P2P */
+			break;
+		}
+#ifdef CONFIG_GPIO_API
+		case 0x25: { /* Get GPIO register */
+			/*
+			* dbg 0x7f250000 [gpio_num], Get gpio value, gpio_num:0~7
+			*/
+
+			u8 value;
+			RTW_INFO("Read GPIO Value  extra_arg = %d\n", extra_arg);
+			value = rtw_hal_get_gpio(padapter, extra_arg);
+			RTW_INFO("Read GPIO Value = %d\n", value);
+			break;
+		}
+		case 0x26: { /* Set GPIO direction */
+
+			/* dbg 0x7f26000x [y], Set gpio direction,
+			* x: gpio_num,4~7  y: indicate direction, 0~1
+			*/
+
+			int value;
+			RTW_INFO("Set GPIO Direction! arg = %d ,extra_arg=%d\n", arg , extra_arg);
+			value = rtw_hal_config_gpio(padapter, arg, extra_arg);
+			RTW_INFO("Set GPIO Direction %s\n", (value == -1) ? "Fail!!!" : "Success");
+			break;
+		}
+		case 0x27: { /* Set GPIO output direction value */
+			/*
+			* dbg 0x7f27000x [y], Set gpio output direction value,
+			* x: gpio_num,4~7  y: indicate direction, 0~1
+			*/
+
+			int value;
+			RTW_INFO("Set GPIO Value! arg = %d ,extra_arg=%d\n", arg , extra_arg);
+			value = rtw_hal_set_gpio_output_value(padapter, arg, extra_arg);
+			RTW_INFO("Set GPIO Value %s\n", (value == -1) ? "Fail!!!" : "Success");
+			break;
+		}
+#endif
+#ifdef DBG_CMD_QUEUE
+		case 0x28: {
+			dump_cmd_id = extra_arg;
+			RTW_INFO("dump_cmd_id:%d\n", dump_cmd_id);
+		}
+			break;
+#endif /* DBG_CMD_QUEUE */
+		case 0xaa: {
+			if ((extra_arg & 0x7F) > 0x3F)
+				extra_arg = 0xFF;
+			RTW_INFO("chang data rate to :0x%02x\n", extra_arg);
+			padapter->fix_rate = extra_arg;
+		}
+			break;
+		case 0xdd: { /* registers dump , 0 for mac reg,1 for bb reg, 2 for rf reg */
+			if (extra_arg == 0)
+				mac_reg_dump(RTW_DBGDUMP, padapter);
+			else if (extra_arg == 1)
+				bb_reg_dump(RTW_DBGDUMP, padapter);
+			else if (extra_arg == 2)
+				rf_reg_dump(RTW_DBGDUMP, padapter);
+			else if (extra_arg == 11)
+				bb_reg_dump_ex(RTW_DBGDUMP, padapter);
+		}
+			break;
+
+		case 0xee: {
+			RTW_INFO(" === please control /proc  to trun on/off PHYDM func ===\n");
+		}
+			break;
+
+		case 0xfd:
+			rtw_write8(padapter, 0xc50, arg);
+			RTW_INFO("wr(0xc50)=0x%x\n", rtw_read8(padapter, 0xc50));
+			rtw_write8(padapter, 0xc58, arg);
+			RTW_INFO("wr(0xc58)=0x%x\n", rtw_read8(padapter, 0xc58));
+			break;
+		case 0xfe:
+			RTW_INFO("rd(0xc50)=0x%x\n", rtw_read8(padapter, 0xc50));
+			RTW_INFO("rd(0xc58)=0x%x\n", rtw_read8(padapter, 0xc58));
+			break;
+		case 0xff: {
+			RTW_INFO("dbg(0x210)=0x%x\n", rtw_read32(padapter, 0x210));
+			RTW_INFO("dbg(0x608)=0x%x\n", rtw_read32(padapter, 0x608));
+			RTW_INFO("dbg(0x280)=0x%x\n", rtw_read32(padapter, 0x280));
+			RTW_INFO("dbg(0x284)=0x%x\n", rtw_read32(padapter, 0x284));
+			RTW_INFO("dbg(0x288)=0x%x\n", rtw_read32(padapter, 0x288));
+
+			RTW_INFO("dbg(0x664)=0x%x\n", rtw_read32(padapter, 0x664));
+
+
+			RTW_INFO("\n");
+
+			RTW_INFO("dbg(0x430)=0x%x\n", rtw_read32(padapter, 0x430));
+			RTW_INFO("dbg(0x438)=0x%x\n", rtw_read32(padapter, 0x438));
+
+			RTW_INFO("dbg(0x440)=0x%x\n", rtw_read32(padapter, 0x440));
+
+			RTW_INFO("dbg(0x458)=0x%x\n", rtw_read32(padapter, 0x458));
+
+			RTW_INFO("dbg(0x484)=0x%x\n", rtw_read32(padapter, 0x484));
+			RTW_INFO("dbg(0x488)=0x%x\n", rtw_read32(padapter, 0x488));
+
+			RTW_INFO("dbg(0x444)=0x%x\n", rtw_read32(padapter, 0x444));
+			RTW_INFO("dbg(0x448)=0x%x\n", rtw_read32(padapter, 0x448));
+			RTW_INFO("dbg(0x44c)=0x%x\n", rtw_read32(padapter, 0x44c));
+			RTW_INFO("dbg(0x450)=0x%x\n", rtw_read32(padapter, 0x450));
+		}
+			break;
+		}
+		break;
+	default:
+		RTW_INFO("error dbg cmd!\n");
+		break;
+	}
+
+
+	return ret;
+
+}
+
+static int wpa_set_param(struct net_device *dev, u8 name, u32 value)
+{
+	uint ret = 0;
+	u32 flags;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	switch (name) {
+	case IEEE_PARAM_WPA_ENABLED:
+
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X; /* 802.1x */
+
+		/* ret = ieee80211_wpa_enable(ieee, value); */
+
+		switch ((value) & 0xff) {
+		case 1: /* WPA */
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK; /* WPA_PSK */
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+			break;
+		case 2: /* WPA2 */
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK; /* WPA2_PSK */
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+			break;
+		}
+
+
+		break;
+
+	case IEEE_PARAM_TKIP_COUNTERMEASURES:
+		/* ieee->tkip_countermeasures=value; */
+		break;
+
+	case IEEE_PARAM_DROP_UNENCRYPTED: {
+		/* HACK:
+		 *
+		 * wpa_supplicant calls set_wpa_enabled when the driver
+		 * is loaded and unloaded, regardless of if WPA is being
+		 * used.  No other calls are made which can be used to
+		 * determine if encryption will be used or not prior to
+		 * association being expected.  If encryption is not being
+		 * used, drop_unencrypted is set to false, else true -- we
+		 * can use this to determine if the CAP_PRIVACY_ON bit should
+		 * be set.
+		 */
+
+#if 0
+		struct ieee80211_security sec = {
+			.flags = SEC_ENABLED,
+			.enabled = value,
+		};
+		ieee->drop_unencrypted = value;
+		/* We only change SEC_LEVEL for open mode. Others
+		 * are set by ipw_wpa_set_encryption.
+		 */
+		if (!value) {
+			sec.flags |= SEC_LEVEL;
+			sec.level = SEC_LEVEL_0;
+		} else {
+			sec.flags |= SEC_LEVEL;
+			sec.level = SEC_LEVEL_1;
+		}
+		if (ieee->set_security)
+			ieee->set_security(ieee->dev, &sec);
+#endif
+		break;
+
+	}
+	case IEEE_PARAM_PRIVACY_INVOKED:
+
+		/* ieee->privacy_invoked=value; */
+
+		break;
+
+	case IEEE_PARAM_AUTH_ALGS:
+
+		ret = wpa_set_auth_algs(dev, value);
+
+		break;
+
+	case IEEE_PARAM_IEEE_802_1X:
+
+		/* ieee->ieee802_1x=value;		 */
+
+		break;
+
+	case IEEE_PARAM_WPAX_SELECT:
+
+		/* added for WPA2 mixed mode */
+		/*RTW_WARN("------------------------>wpax value = %x\n", value);*/
+		/*
+		spin_lock_irqsave(&ieee->wpax_suitlist_lock,flags);
+		ieee->wpax_type_set = 1;
+		ieee->wpax_type_notify = value;
+		spin_unlock_irqrestore(&ieee->wpax_suitlist_lock,flags);
+		*/
+
+		break;
+
+	default:
+
+
+
+		ret = -EOPNOTSUPP;
+
+
+		break;
+
+	}
+
+	return ret;
+
+}
+
+static int wpa_mlme(struct net_device *dev, u32 command, u32 reason)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	switch (command) {
+	case IEEE_MLME_STA_DEAUTH:
+
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
+
+		break;
+
+	case IEEE_MLME_STA_DISASSOC:
+
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
+
+		break;
+
+	default:
+		ret = -EOPNOTSUPP;
+		break;
+	}
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_do_disconnect(padapter);
+#endif
+	return ret;
+
+}
+
+static int wpa_supplicant_ioctl(struct net_device *dev, struct iw_point *p)
+{
+	struct ieee_param *param;
+	uint ret = 0;
+
+	/* down(&ieee->wx_sem);	 */
+
+	if (p->length < sizeof(struct ieee_param) || !p->pointer) {
+		ret = -EINVAL;
+		goto out;
+	}
+
+	param = (struct ieee_param *)rtw_malloc(p->length);
+	if (param == NULL) {
+		ret = -ENOMEM;
+		goto out;
+	}
+
+	if (copy_from_user(param, p->pointer, p->length)) {
+		rtw_mfree((u8 *)param, p->length);
+		ret = -EFAULT;
+		goto out;
+	}
+
+	switch (param->cmd) {
+
+	case IEEE_CMD_SET_WPA_PARAM:
+		ret = wpa_set_param(dev, param->u.wpa_param.name, param->u.wpa_param.value);
+		break;
+
+	case IEEE_CMD_SET_WPA_IE:
+		/* ret = wpa_set_wpa_ie(dev, param, p->length); */
+		ret =  rtw_set_wpa_ie((_adapter *)rtw_netdev_priv(dev), (char *)param->u.wpa_ie.data, (u16)param->u.wpa_ie.len);
+		break;
+
+	case IEEE_CMD_SET_ENCRYPTION:
+		ret = wpa_set_encryption(dev, param, p->length);
+		break;
+
+	case IEEE_CMD_MLME:
+		ret = wpa_mlme(dev, param->u.mlme.command, param->u.mlme.reason_code);
+		break;
+
+	default:
+		RTW_INFO("Unknown WPA supplicant request: %d\n", param->cmd);
+		ret = -EOPNOTSUPP;
+		break;
+
+	}
+
+	if (ret == 0 && copy_to_user(p->pointer, param, p->length))
+		ret = -EFAULT;
+
+	rtw_mfree((u8 *)param, p->length);
+
+out:
+
+	/* up(&ieee->wx_sem); */
+
+	return ret;
+
+}
+
+#ifdef CONFIG_AP_MODE
+static int rtw_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
+{
+	int ret = 0;
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	NDIS_802_11_WEP	*pwep = NULL;
+	struct sta_info *psta = NULL, *pbcmc_sta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	param->u.crypt.err = 0;
+	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
+
+	/* sizeof(struct ieee_param) = 64 bytes; */
+	/* if (param_len !=  (u32) ((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len) */
+	if (param_len !=  sizeof(struct ieee_param) + param->u.crypt.key_len) {
+		ret =  -EINVAL;
+		goto exit;
+	}
+
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) {
+		if (param->u.crypt.idx >= WEP_KEYS
+#ifdef CONFIG_IEEE80211W
+		    && param->u.crypt.idx > BIP_MAX_KEYID
+#endif /* CONFIG_IEEE80211W */
+		   ) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	} else {
+		psta = rtw_get_stainfo(pstapriv, param->sta_addr);
+		if (!psta) {
+			/* ret = -EINVAL; */
+			RTW_INFO("rtw_set_encryption(), sta has already been removed or never been added\n");
+			goto exit;
+		}
+	}
+
+	if (strcmp(param->u.crypt.alg, "none") == 0 && (psta == NULL)) {
+		/* todo:clear default encryption keys */
+
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
+		psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
+		psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+
+		RTW_INFO("clear default encryption keys, keyid=%d\n", param->u.crypt.idx);
+
+		goto exit;
+	}
+
+
+	if (strcmp(param->u.crypt.alg, "WEP") == 0 && (psta == NULL)) {
+		RTW_INFO("r871x_set_encryption, crypt.alg = WEP\n");
+
+		wep_key_idx = param->u.crypt.idx;
+		wep_key_len = param->u.crypt.key_len;
+
+		RTW_INFO("r871x_set_encryption, wep_key_idx=%d, len=%d\n", wep_key_idx, wep_key_len);
+
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+
+
+		if (wep_key_len > 0) {
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+			wep_total_len = wep_key_len + FIELD_OFFSET(NDIS_802_11_WEP, KeyMaterial);
+			pwep = (NDIS_802_11_WEP *)rtw_malloc(wep_total_len);
+			if (pwep == NULL) {
+				RTW_INFO(" r871x_set_encryption: pwep allocate fail !!!\n");
+				goto exit;
+			}
+
+			_rtw_memset(pwep, 0, wep_total_len);
+
+			pwep->KeyLength = wep_key_len;
+			pwep->Length = wep_total_len;
+
+		}
+
+		pwep->KeyIndex = wep_key_idx;
+
+		_rtw_memcpy(pwep->KeyMaterial,  param->u.crypt.key, pwep->KeyLength);
+
+		if (param->u.crypt.set_tx) {
+			RTW_INFO("wep, set_tx=1\n");
+
+			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+
+			if (pwep->KeyLength == 13) {
+				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+			}
+
+
+			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
+
+			_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), pwep->KeyMaterial, pwep->KeyLength);
+
+			psecuritypriv->dot11DefKeylen[wep_key_idx] = pwep->KeyLength;
+
+			rtw_ap_set_wep_key(padapter, pwep->KeyMaterial, pwep->KeyLength, wep_key_idx, 1);
+		} else {
+			RTW_INFO("wep, set_tx=0\n");
+
+			/* don't update "psecuritypriv->dot11PrivacyAlgrthm" and  */
+			/* "psecuritypriv->dot11PrivacyKeyIndex=keyid", but can rtw_set_key to cam */
+
+			_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), pwep->KeyMaterial, pwep->KeyLength);
+
+			psecuritypriv->dot11DefKeylen[wep_key_idx] = pwep->KeyLength;
+
+			rtw_ap_set_wep_key(padapter, pwep->KeyMaterial, pwep->KeyLength, wep_key_idx, 0);
+		}
+
+		goto exit;
+
+	}
+
+
+	if (!psta && check_fwstate(pmlmepriv, WIFI_AP_STATE)) /*  */ { /* group key */
+		if (param->u.crypt.set_tx == 1) {
+			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set WEP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+				if (param->u.crypt.key_len == 13)
+					psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+
+			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				/* set mic key */
+				_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
+				_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
+				psecuritypriv->busetkipkey = _TRUE;
+
+			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _AES_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TX IGTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+				psecuritypriv->dot11wBIPtxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psecuritypriv->binstallBIPkey = _TRUE;
+				goto exit;
+			#endif /* CONFIG_IEEE80211W */
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key, idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx);
+				psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key, not support\n"
+					, FUNC_ADPT_ARG(padapter));
+				goto exit;
+			}
+
+			psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta) {
+				pbcmc_sta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				pbcmc_sta->ieee8021x_blocked = _FALSE;
+				pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
+			}
+			psecuritypriv->binstallGrpkey = _TRUE;
+			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
+
+			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
+		}
+
+		goto exit;
+
+	}
+
+	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) { /* psk/802_1x */
+		if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
+			if (param->u.crypt.set_tx == 1) {
+				_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+				if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" set WEP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
+					psta->dot118021XPrivacy = _WEP40_;
+					if (param->u.crypt.key_len == 13)
+						psta->dot118021XPrivacy = _WEP104_;
+
+				} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" set TKIP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
+					psta->dot118021XPrivacy = _TKIP_;
+					/* set mic key */
+					_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
+					_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
+					psecuritypriv->busetkipkey = _TRUE;
+
+				} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" set CCMP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
+					psta->dot118021XPrivacy = _AES_;
+
+				} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" clear pairwise key of "MAC_FMT" idx:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx);
+					psta->dot118021XPrivacy = _NO_PRIVACY_;
+
+				} else {
+					RTW_WARN(FUNC_ADPT_FMT" set pairwise key of "MAC_FMT", not support\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+					goto exit;
+				}
+
+				psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psta->ieee8021x_blocked = _FALSE;
+				psta->bpairwise_key_installed = _TRUE;
+				rtw_ap_set_pairwise_key(padapter, psta);
+
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
+			}
+
+		}
+
+	}
+
+exit:
+
+	if (pwep)
+		rtw_mfree((u8 *)pwep, wep_total_len);
+
+	return ret;
+
+}
+
+static int rtw_set_beacon(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	unsigned char *pbuf = param->u.bcn_ie.buf;
+
+
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	_rtw_memcpy(&pstapriv->max_num_sta, param->u.bcn_ie.reserved, 2);
+
+	if ((pstapriv->max_num_sta > NUM_STA) || (pstapriv->max_num_sta <= 0))
+		pstapriv->max_num_sta = NUM_STA;
+
+
+	if (rtw_check_beacon_data(padapter, pbuf, (len - 12 - 2)) == _SUCCESS) /* 12 = param header, 2:no packed */
+		ret = 0;
+	else
+		ret = -EINVAL;
+
+
+	return ret;
+
+}
+
+static int rtw_hostapd_sta_flush(struct net_device *dev)
+{
+	/* _irqL irqL; */
+	/* _list	*phead, *plist; */
+	int ret = 0;
+	/* struct sta_info *psta = NULL; */
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	/* struct sta_priv *pstapriv = &padapter->stapriv; */
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	flush_all_cam_entry(padapter);	/* clear CAM */
+#ifdef CONFIG_AP_MODE
+	ret = rtw_sta_flush(padapter, _TRUE);
+#endif
+	return ret;
+
+}
+
+static int rtw_add_sta(struct net_device *dev, struct ieee_param *param)
+{
+	_irqL irqL;
+	int ret = 0;
+	struct sta_info *psta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	RTW_INFO("rtw_add_sta(aid=%d)=" MAC_FMT "\n", param->u.add_sta.aid, MAC_ARG(param->sta_addr));
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
+
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
+
+#if 0
+	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
+	if (psta) {
+		RTW_INFO("rtw_add_sta(), free has been added psta=%p\n", psta);
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
+		rtw_free_stainfo(padapter,  psta);
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
+
+		psta = NULL;
+	}
+#endif
+	/* psta = rtw_alloc_stainfo(pstapriv, param->sta_addr); */
+	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
+	if (psta) {
+		int flags = param->u.add_sta.flags;
+
+		/* RTW_INFO("rtw_add_sta(), init sta's variables, psta=%p\n", psta); */
+
+		psta->cmn.aid = param->u.add_sta.aid;/* aid=1~2007 */
+
+		_rtw_memcpy(psta->bssrateset, param->u.add_sta.tx_supp_rates, 16);
+
+
+		/* check wmm cap. */
+		if (WLAN_STA_WME & flags)
+			psta->qos_option = 1;
+		else
+			psta->qos_option = 0;
+
+		if (pmlmepriv->qospriv.qos_option == 0)
+			psta->qos_option = 0;
+
+
+#ifdef CONFIG_80211N_HT
+		/* chec 802.11n ht cap. */
+		if (WLAN_STA_HT & flags) {
+			psta->htpriv.ht_option = _TRUE;
+			psta->qos_option = 1;
+			_rtw_memcpy((void *)&psta->htpriv.ht_cap, (void *)&param->u.add_sta.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
+		} else
+			psta->htpriv.ht_option = _FALSE;
+
+		if (pmlmepriv->htpriv.ht_option == _FALSE)
+			psta->htpriv.ht_option = _FALSE;
+#endif
+
+
+		update_sta_info_apmode(padapter, psta);
+
+
+	} else
+		ret = -ENOMEM;
+
+	return ret;
+
+}
+
+static int rtw_del_sta(struct net_device *dev, struct ieee_param *param)
+{
+	_irqL irqL;
+	int ret = 0;
+	struct sta_info *psta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	RTW_INFO("rtw_del_sta=" MAC_FMT "\n", MAC_ARG(param->sta_addr));
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
+
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
+
+	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
+	if (psta) {
+		u8 updated = _FALSE;
+
+		/* RTW_INFO("free psta=%p, aid=%d\n", psta, psta->cmn.aid); */
+
+		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+		if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
+			rtw_list_delete(&psta->asoc_list);
+			pstapriv->asoc_list_cnt--;
+			updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
+
+		}
+		_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+		associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
+
+		psta = NULL;
+
+	} else {
+		RTW_INFO("rtw_del_sta(), sta has already been removed or never been added\n");
+
+		/* ret = -1; */
+	}
+
+
+	return ret;
+
+}
+
+static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	struct sta_info *psta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct ieee_param_ex *param_ex = (struct ieee_param_ex *)param;
+	struct sta_data *psta_data = (struct sta_data *)param_ex->data;
+
+	RTW_INFO("rtw_ioctl_get_sta_info, sta_addr: " MAC_FMT "\n", MAC_ARG(param_ex->sta_addr));
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
+
+	if (param_ex->sta_addr[0] == 0xff && param_ex->sta_addr[1] == 0xff &&
+	    param_ex->sta_addr[2] == 0xff && param_ex->sta_addr[3] == 0xff &&
+	    param_ex->sta_addr[4] == 0xff && param_ex->sta_addr[5] == 0xff)
+		return -EINVAL;
+
+	psta = rtw_get_stainfo(pstapriv, param_ex->sta_addr);
+	if (psta) {
+#if 0
+		struct {
+			u16 aid;
+			u16 capability;
+			int flags;
+			u32 sta_set;
+			u8 tx_supp_rates[16];
+			u32 tx_supp_rates_len;
+			struct rtw_ieee80211_ht_cap ht_cap;
+			u64	rx_pkts;
+			u64	rx_bytes;
+			u64	rx_drops;
+			u64	tx_pkts;
+			u64	tx_bytes;
+			u64	tx_drops;
+		} get_sta;
+#endif
+		psta_data->aid = (u16)psta->cmn.aid;
+		psta_data->capability = psta->capability;
+		psta_data->flags = psta->flags;
+
+		/*
+				nonerp_set : BIT(0)
+				no_short_slot_time_set : BIT(1)
+				no_short_preamble_set : BIT(2)
+				no_ht_gf_set : BIT(3)
+				no_ht_set : BIT(4)
+				ht_20mhz_set : BIT(5)
+		*/
+
+		psta_data->sta_set = ((psta->nonerp_set) |
+				      (psta->no_short_slot_time_set << 1) |
+				      (psta->no_short_preamble_set << 2) |
+				      (psta->no_ht_gf_set << 3) |
+				      (psta->no_ht_set << 4) |
+				      (psta->ht_20mhz_set << 5));
+
+		psta_data->tx_supp_rates_len =  psta->bssratelen;
+		_rtw_memcpy(psta_data->tx_supp_rates, psta->bssrateset, psta->bssratelen);
+#ifdef CONFIG_80211N_HT
+		_rtw_memcpy(&psta_data->ht_cap, &psta->htpriv.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
+#endif /* CONFIG_80211N_HT */
+		psta_data->rx_pkts = psta->sta_stats.rx_data_pkts;
+		psta_data->rx_bytes = psta->sta_stats.rx_bytes;
+		psta_data->rx_drops = psta->sta_stats.rx_drops;
+
+		psta_data->tx_pkts = psta->sta_stats.tx_pkts;
+		psta_data->tx_bytes = psta->sta_stats.tx_bytes;
+		psta_data->tx_drops = psta->sta_stats.tx_drops;
+
+
+	} else
+		ret = -1;
+
+	return ret;
+
+}
+
+static int rtw_get_sta_wpaie(struct net_device *dev, struct ieee_param *param)
+{
+	int ret = 0;
+	struct sta_info *psta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	RTW_INFO("rtw_get_sta_wpaie, sta_addr: " MAC_FMT "\n", MAC_ARG(param->sta_addr));
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
+
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
+
+	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
+	if (psta) {
+		if ((psta->wpa_ie[0] == WLAN_EID_RSN) || (psta->wpa_ie[0] == WLAN_EID_GENERIC)) {
+			int wpa_ie_len;
+			int copy_len;
+
+			wpa_ie_len = psta->wpa_ie[1];
+
+			copy_len = ((wpa_ie_len + 2) > sizeof(psta->wpa_ie)) ? (sizeof(psta->wpa_ie)) : (wpa_ie_len + 2);
+
+			param->u.wpa_ie.len = copy_len;
+
+			_rtw_memcpy(param->u.wpa_ie.reserved, psta->wpa_ie, copy_len);
+		} else {
+			/* ret = -1; */
+			RTW_INFO("sta's wpa_ie is NONE\n");
+		}
+	} else
+		ret = -1;
+
+	return ret;
+
+}
+
+static int rtw_set_wps_beacon(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	unsigned char wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	int ie_len;
+
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
+
+
+	if (pmlmepriv->wps_beacon_ie) {
+		rtw_mfree(pmlmepriv->wps_beacon_ie, pmlmepriv->wps_beacon_ie_len);
+		pmlmepriv->wps_beacon_ie = NULL;
+	}
+
+	if (ie_len > 0) {
+		pmlmepriv->wps_beacon_ie = rtw_malloc(ie_len);
+		pmlmepriv->wps_beacon_ie_len = ie_len;
+		if (pmlmepriv->wps_beacon_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+			return -EINVAL;
+		}
+
+		_rtw_memcpy(pmlmepriv->wps_beacon_ie, param->u.bcn_ie.buf, ie_len);
+
+		update_beacon(padapter, _VENDOR_SPECIFIC_IE_, wps_oui, _TRUE);
+
+		pmlmeext->bstart_bss = _TRUE;
+
+	}
+
+
+	return ret;
+
+}
+
+static int rtw_set_wps_probe_resp(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	int ie_len;
+
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
+
+
+	if (pmlmepriv->wps_probe_resp_ie) {
+		rtw_mfree(pmlmepriv->wps_probe_resp_ie, pmlmepriv->wps_probe_resp_ie_len);
+		pmlmepriv->wps_probe_resp_ie = NULL;
+	}
+
+	if (ie_len > 0) {
+		pmlmepriv->wps_probe_resp_ie = rtw_malloc(ie_len);
+		pmlmepriv->wps_probe_resp_ie_len = ie_len;
+		if (pmlmepriv->wps_probe_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+			return -EINVAL;
+		}
+		_rtw_memcpy(pmlmepriv->wps_probe_resp_ie, param->u.bcn_ie.buf, ie_len);
+	}
+
+
+	return ret;
+
+}
+
+static int rtw_set_wps_assoc_resp(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	int ie_len;
+
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
+
+
+	if (pmlmepriv->wps_assoc_resp_ie) {
+		rtw_mfree(pmlmepriv->wps_assoc_resp_ie, pmlmepriv->wps_assoc_resp_ie_len);
+		pmlmepriv->wps_assoc_resp_ie = NULL;
+	}
+
+	if (ie_len > 0) {
+		pmlmepriv->wps_assoc_resp_ie = rtw_malloc(ie_len);
+		pmlmepriv->wps_assoc_resp_ie_len = ie_len;
+		if (pmlmepriv->wps_assoc_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+			return -EINVAL;
+		}
+
+		_rtw_memcpy(pmlmepriv->wps_assoc_resp_ie, param->u.bcn_ie.buf, ie_len);
+	}
+
+
+	return ret;
+
+}
+
+static int rtw_set_hidden_ssid(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *mlmepriv = &(adapter->mlmepriv);
+	struct mlme_ext_priv	*mlmeext = &(adapter->mlmeextpriv);
+	struct mlme_ext_info	*mlmeinfo = &(mlmeext->mlmext_info);
+	int ie_len;
+	u8 *ssid_ie;
+	char ssid[NDIS_802_11_LENGTH_SSID + 1];
+	sint ssid_len = 0;
+	u8 ignore_broadcast_ssid;
+
+	if (check_fwstate(mlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EPERM;
+
+	if (param->u.bcn_ie.reserved[0] != 0xea)
+		return -EINVAL;
+
+	mlmeinfo->hidden_ssid_mode = ignore_broadcast_ssid = param->u.bcn_ie.reserved[1];
+
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
+	ssid_ie = rtw_get_ie(param->u.bcn_ie.buf,  WLAN_EID_SSID, &ssid_len, ie_len);
+
+	if (ssid_ie && ssid_len > 0 && ssid_len <= NDIS_802_11_LENGTH_SSID) {
+		WLAN_BSSID_EX *pbss_network = &mlmepriv->cur_network.network;
+		WLAN_BSSID_EX *pbss_network_ext = &mlmeinfo->network;
+
+		_rtw_memcpy(ssid, ssid_ie + 2, ssid_len);
+		ssid[ssid_len] = 0x0;
+
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" ssid:(%s,%d), from ie:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
+				ssid, ssid_len,
+				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength,
+				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
+
+		_rtw_memcpy(pbss_network->Ssid.Ssid, (void *)ssid, ssid_len);
+		pbss_network->Ssid.SsidLength = ssid_len;
+		_rtw_memcpy(pbss_network_ext->Ssid.Ssid, (void *)ssid, ssid_len);
+		pbss_network_ext->Ssid.SsidLength = ssid_len;
+
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" after ssid:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
+				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength,
+				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
+	}
+
+	RTW_INFO(FUNC_ADPT_FMT" ignore_broadcast_ssid:%d, %s,%d\n", FUNC_ADPT_ARG(adapter),
+		ignore_broadcast_ssid, ssid, ssid_len);
+
+	return ret;
+}
+
+#if CONFIG_RTW_MACADDR_ACL
+static int rtw_ioctl_acl_remove_sta(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
+
+	ret = rtw_acl_remove_sta(padapter, RTW_ACL_PERIOD_BSS, param->sta_addr);
+
+	return ret;
+
+}
+
+static int rtw_ioctl_acl_add_sta(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
+
+	ret = rtw_acl_add_sta(padapter, RTW_ACL_PERIOD_BSS, param->sta_addr);
+
+	return ret;
+
+}
+
+static int rtw_ioctl_set_macaddr_acl(struct net_device *dev, struct ieee_param *param, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	rtw_set_macaddr_acl(padapter, RTW_ACL_PERIOD_BSS, param->u.mlme.command);
+
+	return ret;
+}
+#endif /* CONFIG_RTW_MACADDR_ACL */
+
+static int rtw_hostapd_ioctl(struct net_device *dev, struct iw_point *p)
+{
+	struct ieee_param *param;
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+	/*
+	* this function is expect to call in master mode, which allows no power saving
+	* so, we just check hw_init_completed
+	*/
+
+	if (!rtw_is_hw_init_completed(padapter)) {
+		ret = -EPERM;
+		goto out;
+	}
+
+
+	/* if (p->length < sizeof(struct ieee_param) || !p->pointer){ */
+	if (!p->pointer) {
+		ret = -EINVAL;
+		goto out;
+	}
+
+	param = (struct ieee_param *)rtw_malloc(p->length);
+	if (param == NULL) {
+		ret = -ENOMEM;
+		goto out;
+	}
+
+	if (copy_from_user(param, p->pointer, p->length)) {
+		rtw_mfree((u8 *)param, p->length);
+		ret = -EFAULT;
+		goto out;
+	}
+
+	/* RTW_INFO("%s, cmd=%d\n", __FUNCTION__, param->cmd); */
+
+	switch (param->cmd) {
+	case RTL871X_HOSTAPD_FLUSH:
+
+		ret = rtw_hostapd_sta_flush(dev);
+
+		break;
+
+	case RTL871X_HOSTAPD_ADD_STA:
+
+		ret = rtw_add_sta(dev, param);
+
+		break;
+
+	case RTL871X_HOSTAPD_REMOVE_STA:
+
+		ret = rtw_del_sta(dev, param);
+
+		break;
+
+	case RTL871X_HOSTAPD_SET_BEACON:
+
+		ret = rtw_set_beacon(dev, param, p->length);
+
+		break;
+
+	case RTL871X_SET_ENCRYPTION:
+
+		ret = rtw_set_encryption(dev, param, p->length);
+
+		break;
+
+	case RTL871X_HOSTAPD_GET_WPAIE_STA:
+
+		ret = rtw_get_sta_wpaie(dev, param);
+
+		break;
+
+	case RTL871X_HOSTAPD_SET_WPS_BEACON:
+
+		ret = rtw_set_wps_beacon(dev, param, p->length);
+
+		break;
+
+	case RTL871X_HOSTAPD_SET_WPS_PROBE_RESP:
+
+		ret = rtw_set_wps_probe_resp(dev, param, p->length);
+
+		break;
+
+	case RTL871X_HOSTAPD_SET_WPS_ASSOC_RESP:
+
+		ret = rtw_set_wps_assoc_resp(dev, param, p->length);
+
+		break;
+
+	case RTL871X_HOSTAPD_SET_HIDDEN_SSID:
+
+		ret = rtw_set_hidden_ssid(dev, param, p->length);
+
+		break;
+
+	case RTL871X_HOSTAPD_GET_INFO_STA:
+
+		ret = rtw_ioctl_get_sta_data(dev, param, p->length);
+
+		break;
+
+#if CONFIG_RTW_MACADDR_ACL
+	case RTL871X_HOSTAPD_SET_MACADDR_ACL:
+		ret = rtw_ioctl_set_macaddr_acl(dev, param, p->length);
+		break;
+	case RTL871X_HOSTAPD_ACL_ADD_STA:
+		ret = rtw_ioctl_acl_add_sta(dev, param, p->length);
+		break;
+	case RTL871X_HOSTAPD_ACL_REMOVE_STA:
+		ret = rtw_ioctl_acl_remove_sta(dev, param, p->length);
+		break;
+#endif /* CONFIG_RTW_MACADDR_ACL */
+
+	default:
+		RTW_INFO("Unknown hostapd request: %d\n", param->cmd);
+		ret = -EOPNOTSUPP;
+		break;
+
+	}
+
+	if (ret == 0 && copy_to_user(p->pointer, param, p->length))
+		ret = -EFAULT;
+
+
+	rtw_mfree((u8 *)param, p->length);
+
+out:
+
+	return ret;
+
+}
+#endif
+
+static int rtw_wx_set_priv(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *awrq,
+			   char *extra)
+{
+
+#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+	char *ext_dbg;
+#endif
+
+	int ret = 0;
+	int len = 0;
+	char *ext;
+	int i;
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point *dwrq = (struct iw_point *)awrq;
+
+	if (dwrq->length == 0)
+		return -EFAULT;
+
+	len = dwrq->length;
+	ext = rtw_vmalloc(len);
+	if (!ext)
+		return -ENOMEM;
+
+	if (copy_from_user(ext, dwrq->pointer, len)) {
+		rtw_vmfree(ext, len);
+		return -EFAULT;
+	}
+
+
+
+#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+	ext_dbg = rtw_vmalloc(len);
+	if (!ext_dbg) {
+		rtw_vmfree(ext, len);
+		return -ENOMEM;
+	}
+
+	_rtw_memcpy(ext_dbg, ext, len);
+#endif
+
+	/* added for wps2.0 @20110524 */
+	if (dwrq->flags == 0x8766 && len > 8) {
+		u32 cp_sz;
+		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+		u8 *probereq_wpsie = ext;
+		int probereq_wpsie_len = len;
+		u8 wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
+
+		if ((_VENDOR_SPECIFIC_IE_ == probereq_wpsie[0]) &&
+		    (_rtw_memcmp(&probereq_wpsie[2], wps_oui, 4) == _TRUE)) {
+			cp_sz = probereq_wpsie_len > MAX_WPS_IE_LEN ? MAX_WPS_IE_LEN : probereq_wpsie_len;
+
+			if (pmlmepriv->wps_probe_req_ie) {
+				u32 free_len = pmlmepriv->wps_probe_req_ie_len;
+				pmlmepriv->wps_probe_req_ie_len = 0;
+				rtw_mfree(pmlmepriv->wps_probe_req_ie, free_len);
+				pmlmepriv->wps_probe_req_ie = NULL;
+			}
+
+			pmlmepriv->wps_probe_req_ie = rtw_malloc(cp_sz);
+			if (pmlmepriv->wps_probe_req_ie == NULL) {
+				printk("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				ret =  -EINVAL;
+				goto FREE_EXT;
+
+			}
+
+			_rtw_memcpy(pmlmepriv->wps_probe_req_ie, probereq_wpsie, cp_sz);
+			pmlmepriv->wps_probe_req_ie_len = cp_sz;
+
+		}
+
+		goto FREE_EXT;
+
+	}
+
+	if (len >= WEXT_CSCAN_HEADER_SIZE
+		&& _rtw_memcmp(ext, WEXT_CSCAN_HEADER, WEXT_CSCAN_HEADER_SIZE) == _TRUE
+	) {
+		ret = rtw_wx_set_scan(dev, info, awrq, ext);
+		goto FREE_EXT;
+	}
+
+#ifdef CONFIG_ANDROID
+	/* RTW_INFO("rtw_wx_set_priv: %s req=%s\n", dev->name, ext); */
+
+	i = rtw_android_cmdstr_to_num(ext);
+
+	switch (i) {
+	case ANDROID_WIFI_CMD_START:
+		indicate_wx_custom_event(padapter, "START");
+		break;
+	case ANDROID_WIFI_CMD_STOP:
+		indicate_wx_custom_event(padapter, "STOP");
+		break;
+	case ANDROID_WIFI_CMD_RSSI: {
+		struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+		struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
+
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+			sprintf(ext, "%s rssi %d", pcur_network->network.Ssid.Ssid, padapter->recvpriv.rssi);
+		else
+			sprintf(ext, "OK");
+	}
+		break;
+	case ANDROID_WIFI_CMD_LINKSPEED: {
+		u16 mbps = rtw_get_cur_max_rate(padapter) / 10;
+		sprintf(ext, "LINKSPEED %d", mbps);
+	}
+		break;
+	case ANDROID_WIFI_CMD_MACADDR:
+		sprintf(ext, "MACADDR = " MAC_FMT, MAC_ARG(dev->dev_addr));
+		break;
+	case ANDROID_WIFI_CMD_SCAN_ACTIVE: {
+		/* rtw_set_scan_mode(padapter, SCAN_ACTIVE); */
+		sprintf(ext, "OK");
+	}
+		break;
+	case ANDROID_WIFI_CMD_SCAN_PASSIVE: {
+		/* rtw_set_scan_mode(padapter, SCAN_PASSIVE); */
+		sprintf(ext, "OK");
+	}
+		break;
+
+	case ANDROID_WIFI_CMD_COUNTRY: {
+		char country_code[10];
+		sscanf(ext, "%*s %s", country_code);
+		rtw_set_country(padapter, country_code);
+		sprintf(ext, "OK");
+	}
+		break;
+	default:
+		#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+		RTW_INFO("%s: %s unknowned req=%s\n", __FUNCTION__,
+			dev->name, ext_dbg);
+		#endif
+
+		sprintf(ext, "OK");
+
+	}
+
+	if (copy_to_user(dwrq->pointer, ext, min(dwrq->length, (u16)(strlen(ext) + 1))))
+		ret = -EFAULT;
+
+#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+	RTW_INFO("%s: %s req=%s rep=%s dwrq->length=%d, strlen(ext)+1=%d\n", __FUNCTION__,
+		dev->name, ext_dbg , ext, dwrq->length, (u16)(strlen(ext) + 1));
+#endif
+#endif /* end of CONFIG_ANDROID */
+
+
+FREE_EXT:
+
+	rtw_vmfree(ext, len);
+	#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+	rtw_vmfree(ext_dbg, len);
+	#endif
+
+	/* RTW_INFO("rtw_wx_set_priv: (SIOCSIWPRIV) %s ret=%d\n",  */
+	/*		dev->name, ret); */
+
+	return ret;
+
+}
+#ifdef CONFIG_WOWLAN
+static int rtw_wowlan_ctrl(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wowlan_ioctl_param poidparam;
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct sta_info	*psta = NULL;
+	int ret = 0;
+	systime start_time = rtw_get_current_time();
+	poidparam.subcode = 0;
+
+	RTW_INFO("+rtw_wowlan_ctrl: %s\n", extra);
+
+	if (!check_fwstate(pmlmepriv, _FW_LINKED) &&
+	    check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+#ifdef CONFIG_PNO_SUPPORT
+		pwrctrlpriv->wowlan_pno_enable = _TRUE;
+#else
+		RTW_INFO("[%s] WARNING: Please Connect With AP First!!\n", __func__);
+		goto _rtw_wowlan_ctrl_exit_free;
+#endif /* CONFIG_PNO_SUPPORT */
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
+		rtw_scan_abort(padapter);
+
+	if (_rtw_memcmp(extra, "enable", 6))
+
+
+		rtw_suspend_common(padapter);
+
+	else if (_rtw_memcmp(extra, "disable", 7)) {
+#ifdef CONFIG_USB_HCI
+		RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
+		RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
+#endif
+		rtw_resume_common(padapter);
+
+#ifdef CONFIG_PNO_SUPPORT
+		pwrctrlpriv->wowlan_pno_enable = _FALSE;
+#endif /* CONFIG_PNO_SUPPORT */
+
+	} else {
+		RTW_INFO("[%s] Invalid Parameter.\n", __func__);
+		goto _rtw_wowlan_ctrl_exit_free;
+	}
+	/* mutex_lock(&ioctl_mutex); */
+_rtw_wowlan_ctrl_exit_free:
+	RTW_INFO("-rtw_wowlan_ctrl( subcode = %d)\n", poidparam.subcode);
+	RTW_PRINT("%s in %d ms\n", __func__,
+		  rtw_get_passing_time_ms(start_time));
+_rtw_wowlan_ctrl_exit:
+	return ret;
+}
+
+/*
+ * IP filter This pattern if for a frame containing a ip packet:
+ * AA:AA:AA:AA:AA:AA:BB:BB:BB:BB:BB:BB:CC:CC:DD:-:-:-:-:-:-:-:-:EE:-:-:FF:FF:FF:FF:GG:GG:GG:GG:HH:HH:II:II
+ *
+ * A: Ethernet destination address
+ * B: Ethernet source address
+ * C: Ethernet protocol type
+ * D: IP header VER+Hlen, use: 0x45 (4 is for ver 4, 5 is for len 20)
+ * E: IP protocol
+ * F: IP source address ( 192.168.0.4: C0:A8:00:2C )
+ * G: IP destination address ( 192.168.0.4: C0:A8:00:2C )
+ * H: Source port (1024: 04:00)
+ * I: Destination port (1024: 04:00)
+ */
+
+static int rtw_wowlan_set_pattern(struct net_device *dev,
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct wowlan_ioctl_param poidparam;
+	int ret = 0, len = 0, i = 0;
+	systime start_time = rtw_get_current_time();
+	u8 input[wrqu->data.length];
+	u8 index = 0;
+
+	poidparam.subcode = 0;
+
+	if (!check_fwstate(pmlmepriv, _FW_LINKED) &&
+	    check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+		ret = -EFAULT;
+		RTW_INFO("Please Connect With AP First!!\n");
+		goto _rtw_wowlan_set_pattern_exit;
+	}
+
+	if (wrqu->data.length <= 0) {
+		ret = -EFAULT;
+		RTW_INFO("ERROR: parameter length <= 0\n");
+		goto _rtw_wowlan_set_pattern_exit;
+	} else {
+		/* set pattern */
+		if (copy_from_user(input,
+				   wrqu->data.pointer, wrqu->data.length))
+			return -EFAULT;
+		/* leave PS first */
+		rtw_ps_deny(padapter, PS_DENY_IOCTL);
+		LeaveAllPowerSaveModeDirect(padapter);
+		if (strncmp(input, "pattern=", 8) == 0) {
+			if (pwrpriv->wowlan_pattern_idx >= MAX_WKFM_CAM_NUM) {
+				RTW_INFO("WARNING: priv-pattern is full(idx: %d)\n",
+					 pwrpriv->wowlan_pattern_idx);
+				RTW_INFO("WARNING: please clean priv-pattern first\n");
+				ret = -EINVAL;
+				goto _rtw_wowlan_set_pattern_exit;
+			} else {
+				index = pwrpriv->wowlan_pattern_idx;
+				ret = rtw_wowlan_parser_pattern_cmd(input,
+					    pwrpriv->patterns[index].content,
+					    &pwrpriv->patterns[index].len,
+					    pwrpriv->patterns[index].mask);
+
+				if (ret == _TRUE)
+					pwrpriv->wowlan_pattern_idx++;
+			}
+		} else if (strncmp(input, "clean", 5) == 0) {
+			poidparam.subcode = WOWLAN_PATTERN_CLEAN;
+			rtw_hal_set_hwreg(padapter,
+					  HW_VAR_WOWLAN, (u8 *)&poidparam);
+		} else if (strncmp(input, "show", 4) == 0) {
+			rtw_wow_pattern_cam_dump(padapter);
+			rtw_wow_pattern_sw_dump(padapter);
+		} else {
+			RTW_INFO("ERROR: incorrect parameter!\n");
+			ret = -EINVAL;
+		}
+		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+	}
+_rtw_wowlan_set_pattern_exit:
+	return ret;
+}
+#endif /* CONFIG_WOWLAN */
+
+#ifdef CONFIG_AP_WOWLAN
+static int rtw_ap_wowlan_ctrl(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wowlan_ioctl_param poidparam;
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct sta_info	*psta = NULL;
+	int ret = 0;
+	systime start_time = rtw_get_current_time();
+	poidparam.subcode = 0;
+
+	RTW_INFO("+rtw_ap_wowlan_ctrl: %s\n", extra);
+
+	if (!check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
+		RTW_INFO("[%s] It is not AP mode!!\n", __func__);
+		goto _rtw_ap_wowlan_ctrl_exit_free;
+	}
+
+	if (_rtw_memcmp(extra, "enable", 6)) {
+
+		pwrctrlpriv->wowlan_ap_mode = _TRUE;
+
+		rtw_suspend_common(padapter);
+	} else if (_rtw_memcmp(extra, "disable", 7)) {
+#ifdef CONFIG_USB_HCI
+		RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
+		RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
+#endif
+		rtw_resume_common(padapter);
+	} else {
+		RTW_INFO("[%s] Invalid Parameter.\n", __func__);
+		goto _rtw_ap_wowlan_ctrl_exit_free;
+	}
+	/* mutex_lock(&ioctl_mutex); */
+_rtw_ap_wowlan_ctrl_exit_free:
+	RTW_INFO("-rtw_ap_wowlan_ctrl( subcode = %d)\n", poidparam.subcode);
+	RTW_PRINT("%s in %d ms\n", __func__,
+		  rtw_get_passing_time_ms(start_time));
+_rtw_ap_wowlan_ctrl_exit:
+	return ret;
+}
+#endif /* CONFIG_AP_WOWLAN */
+
+static int rtw_pm_set(struct net_device *dev,
+		      struct iw_request_info *info,
+		      union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+	unsigned	mode = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, extra);
+
+	if (_rtw_memcmp(extra, "lps=", 4)) {
+		sscanf(extra + 4, "%u", &mode);
+		ret = rtw_pm_set_lps(padapter, mode);
+	} else if (_rtw_memcmp(extra, "ips=", 4)) {
+		sscanf(extra + 4, "%u", &mode);
+		ret = rtw_pm_set_ips(padapter, mode);
+	} else if (_rtw_memcmp(extra, "lps_level=", 10)) {
+		if (sscanf(extra + 10, "%u", &mode) > 0)
+			ret = rtw_pm_set_lps_level(padapter, mode);
+	} else
+		ret = -EINVAL;
+
+	return ret;
+}
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+
+int rtw_vendor_ie_get_raw_data(struct net_device *dev, u32 vendor_ie_num,
+							   char *extra, u32 length)
+{
+	int j;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 vendor_ie_mask = 0;
+	char *pstring;
+
+	if (vendor_ie_num >= WLAN_MAX_VENDOR_IE_NUM) {
+		RTW_INFO("[%s] only support %d vendor ie\n", __func__ ,
+				 WLAN_MAX_VENDOR_IE_NUM);
+		return -EFAULT;
+	}
+
+	if (pmlmepriv->vendor_ielen[vendor_ie_num] == 0) {
+		RTW_INFO("[%s]  Fail, vendor_ie_num: %d is not set\n", __func__,
+				 vendor_ie_num);
+		return -EFAULT;
+	}
+
+	if (length < 2 * pmlmepriv->vendor_ielen[vendor_ie_num] + 5) {
+		RTW_INFO("[%s]  Fail, buffer size is too small\n", __func__);
+		return -EFAULT;
+	}
+
+	vendor_ie_mask = pmlmepriv->vendor_ie_mask[vendor_ie_num];
+	_rtw_memset(extra, 0, length);
+
+	pstring = extra;
+	pstring += sprintf(pstring, "%d,%x,", vendor_ie_num, vendor_ie_mask);
+
+	for (j = 0; j < pmlmepriv->vendor_ielen[vendor_ie_num]; j++)
+		pstring += sprintf(pstring, "%02x", pmlmepriv->vendor_ie[vendor_ie_num][j]);
+
+	length = pstring - extra;
+	return length;
+}
+
+int rtw_vendor_ie_get_data(struct net_device *dev, int vendor_ie_num, char *extra)
+{
+	int j;
+	char *pstring;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 vendor_ie_mask = 0;
+	__u16 length = 0;
+
+	vendor_ie_mask = pmlmepriv->vendor_ie_mask[vendor_ie_num];
+	pstring = extra;
+	pstring += sprintf(pstring , "\nVendor IE num %d , Mask:%x " , vendor_ie_num , vendor_ie_mask);
+
+	if (vendor_ie_mask & WIFI_BEACON_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Beacon]");
+	if (vendor_ie_mask & WIFI_PROBEREQ_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Probe Req]");
+	if (vendor_ie_mask & WIFI_PROBERESP_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Probe Resp]");
+	if (vendor_ie_mask & WIFI_ASSOCREQ_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Assoc Req]");
+	if (vendor_ie_mask & WIFI_ASSOCRESP_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Assoc Resp]");
+
+	pstring += sprintf(pstring , "\nVendor IE:\n");
+	for (j = 0 ; j < pmlmepriv->vendor_ielen[vendor_ie_num]  ; j++)
+		pstring += sprintf(pstring , "%02x" , pmlmepriv->vendor_ie[vendor_ie_num][j]);
+
+	length = pstring - extra;
+	return length;
+
+}
+
+int rtw_vendor_ie_get(struct net_device *dev, struct iw_request_info *info, union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0, vendor_ie_num = 0, cmdlen;
+	struct iw_point *p;
+	u8 *ptmp;
+
+	p = &wrqu->data;
+	cmdlen = p->length;
+	if (0 == cmdlen)
+		return -EINVAL;
+
+	ptmp = (u8 *)rtw_malloc(cmdlen);
+	if (NULL == ptmp)
+		return -ENOMEM;
+
+	if (copy_from_user(ptmp, p->pointer, cmdlen)) {
+		ret = -EFAULT;
+		goto exit;
+	}
+	ret = sscanf(ptmp , "%d", &vendor_ie_num);
+	if (vendor_ie_num > WLAN_MAX_VENDOR_IE_NUM - 1) {
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	wrqu->data.length = rtw_vendor_ie_get_data(dev, vendor_ie_num, extra);
+
+exit:
+	rtw_mfree(ptmp, cmdlen);
+
+	return 0;
+}
+
+int rtw_vendor_ie_set(struct net_device *dev, struct iw_request_info *info, union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0, i , len = 0 , totoal_ie_len = 0 , total_ie_len_byte = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 vendor_ie_mask = 0;
+	u32 vendor_ie_num = 0;
+	u32 id, elen;
+
+	ret = sscanf(extra, "%d,%x,%*s", &vendor_ie_num , &vendor_ie_mask);
+	if (strrchr(extra , ','))
+		extra = strrchr(extra , ',') + 1;
+	else
+		return -EINVAL;
+	totoal_ie_len = strlen(extra);
+	RTW_INFO("[%s] vendor_ie_num = %d , vendor_ie_mask = %x , vendor_ie = %s , len = %d\n", __func__ , vendor_ie_num , vendor_ie_mask , extra  , totoal_ie_len);
+
+	if (vendor_ie_num  > WLAN_MAX_VENDOR_IE_NUM - 1) {
+		RTW_INFO("[%s] only support %d vendor ie\n", __func__ , WLAN_MAX_VENDOR_IE_NUM);
+		return -EFAULT;
+	}
+
+	if (totoal_ie_len > WLAN_MAX_VENDOR_IE_LEN) {
+		RTW_INFO("[%s] Fail , not support ie length extend %d\n", __func__ , WLAN_MAX_VENDOR_IE_LEN);
+		return -EFAULT;
+	}
+
+	if (vendor_ie_mask == 0) {
+		RTW_INFO("[%s] Clear vendor_ie_num %d group\n", __func__ , vendor_ie_num);
+		goto _clear_path;
+	}
+
+	if (totoal_ie_len % 2 != 0) {
+		RTW_INFO("[%s]  Fail , IE length = %zu is odd\n" , __func__ , strlen(extra));
+		return -EFAULT;
+	}
+
+	if (totoal_ie_len > 0) {
+		for (i = 0  ; i < strlen(extra) ; i += 2) {
+			pmlmepriv->vendor_ie[vendor_ie_num][len] = key_2char2num(extra[i] , extra[i + 1]);
+			if (len == 0) {
+				id = pmlmepriv->vendor_ie[vendor_ie_num][len];
+				if (id != WLAN_EID_VENDOR_SPECIFIC) {
+					RTW_INFO("[%s] Fail , VENDOR SPECIFIC IE ID \"%x\" was not correct\n", __func__ , id);
+					goto _clear_path;
+				}
+			} else if (len == 1) {
+				total_ie_len_byte = (totoal_ie_len / 2) - 2;
+				elen = pmlmepriv->vendor_ie[vendor_ie_num][len];
+				if (elen != total_ie_len_byte) {
+					RTW_INFO("[%s] Fail , Input IE length = \"%d\"(hex:%x) bytes , not match input total IE context length \"%d\" bytes\n", __func__ , elen , elen ,
+						 total_ie_len_byte);
+					goto _clear_path;
+				}
+			}
+			len++;
+		}
+		pmlmepriv->vendor_ielen[vendor_ie_num] = len;
+	} else
+		pmlmepriv->vendor_ielen[vendor_ie_num] = 0;
+
+
+
+	if (vendor_ie_mask & WIFI_BEACON_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Beacon append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_PROBEREQ_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Probe Req append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_PROBERESP_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Probe Resp  append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_ASSOCREQ_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Assoc Req append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_ASSOCRESP_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Assoc Resp append vendor ie\n", __func__);
+
+	pmlmepriv->vendor_ie_mask[vendor_ie_num] = vendor_ie_mask;
+
+	return ret;
+
+_clear_path:
+	_rtw_memset(pmlmepriv->vendor_ie[vendor_ie_num] , 0 , sizeof(u32) * WLAN_MAX_VENDOR_IE_LEN);
+	pmlmepriv->vendor_ielen[vendor_ie_num] = 0;
+	pmlmepriv->vendor_ie_mask[vendor_ie_num] = 0;
+	return -EFAULT;
+}
+#endif
+
+static int rtw_mp_efuse_get(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wdata, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	PEFUSE_HAL pEfuseHal;
+	struct iw_point *wrqu;
+
+	u8	*PROMContent = pHalData->efuse_eeprom_data;
+	u8 ips_mode = IPS_NUM; /* init invalid value */
+	u8 lps_mode = PS_MODE_NUM; /* init invalid value */
+	struct pwrctrl_priv *pwrctrlpriv ;
+	u8 *data = NULL;
+	u8 *rawdata = NULL;
+	char *pch, *ptmp, *token, *tmp[3] = {0x00, 0x00, 0x00};
+	u16 i = 0, j = 0, mapLen = 0, addr = 0, cnts = 0;
+	u16 max_available_len = 0, raw_cursize = 0, raw_maxsize = 0;
+	u16 mask_len;
+	u8 mask_buf[64] = "";
+	int err;
+	char *pextra = NULL;
+#ifdef CONFIG_IOL
+	u8 org_fw_iol = padapter->registrypriv.fw_iol;/* 0:Disable, 1:enable, 2:by usb speed */
+#endif
+
+	wrqu = (struct iw_point *)wdata;
+	pwrctrlpriv = adapter_to_pwrctl(padapter);
+	pEfuseHal = &pHalData->EfuseHal;
+
+	err = 0;
+	data = rtw_zmalloc(EFUSE_BT_MAX_MAP_LEN);
+	if (data == NULL) {
+		err = -ENOMEM;
+		goto exit;
+	}
+	rawdata = rtw_zmalloc(EFUSE_BT_MAX_MAP_LEN);
+	if (rawdata == NULL) {
+		err = -ENOMEM;
+		goto exit;
+	}
+
+	if (copy_from_user(extra, wrqu->pointer, wrqu->length)) {
+		err = -EFAULT;
+		goto exit;
+	}
+
+	*(extra + wrqu->length) = '\0';
+
+#ifdef CONFIG_LPS
+	lps_mode = pwrctrlpriv->power_mgnt;/* keep org value */
+	rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
+#endif
+
+#ifdef CONFIG_IPS
+	ips_mode = pwrctrlpriv->ips_mode;/* keep org value */
+	rtw_pm_set_ips(padapter, IPS_NONE);
+#endif
+
+	pch = extra;
+	RTW_INFO("%s: in=%s\n", __FUNCTION__, extra);
+
+	i = 0;
+	/* mac 16 "00e04c871200" rmap,00,2 */
+	while ((token = strsep(&pch, ",")) != NULL) {
+		if (i > 2)
+			break;
+		tmp[i] = token;
+		i++;
+	}
+#ifdef CONFIG_IOL
+	padapter->registrypriv.fw_iol = 0;/* 0:Disable, 1:enable, 2:by usb speed */
+#endif
+
+	if (strcmp(tmp[0], "status") == 0) {
+		sprintf(extra, "Load File efuse=%s,Load File MAC=%s"
+			, pHalData->efuse_file_status == EFUSE_FILE_FAILED ? "FAIL" : "OK"
+			, pHalData->macaddr_file_status == MACADDR_FILE_FAILED ? "FAIL" : "OK"
+		       );
+		goto exit;
+	} else if (strcmp(tmp[0], "drvmap") == 0) {
+		static u8 drvmaporder = 0;
+		u8 *efuse;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
+
+		efuse = pHalData->efuse_eeprom_data;
+
+		shift = blksz * drvmaporder;
+		efuse += shift;
+		cnt = mapLen - shift;
+
+		if (cnt > blksz) {
+			cnt = blksz;
+			drvmaporder++;
+		} else
+			drvmaporder = 0;
+
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
+
+	} else if (strcmp(tmp[0], "realmap") == 0) {
+		static u8 order = 0;
+		u8 *efuse;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&mapLen, _FALSE);
+		efuse = pEfuseHal->fakeEfuseInitMap;
+		if (rtw_efuse_mask_map_read(padapter, 0, mapLen, efuse) == _FAIL) {
+			RTW_INFO("%s: read realmap Fail!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+#if 0
+		RTW_INFO("OFFSET\tVALUE(hex)\n");
+		for (i = 0; i < mapLen; i += 16) {
+			RTW_INFO("0x%02x\t", i);
+			for (j = 0; j < 8; j++)
+				RTW_INFO("%02X ", efuse[i + j]);
+			RTW_INFO("\t");
+			for (; j < 16; j++)
+				RTW_INFO("%02X ", efuse[i + j]);
+			RTW_INFO("\n");
+		}
+		RTW_INFO("\n");
+#endif
+
+		shift = blksz * order;
+		efuse += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			order++;
+		} else
+			order = 0;
+
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
+	} else if (strcmp(tmp[0], "rmap") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			RTW_INFO("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+
+		/* rmap addr cnts */
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		RTW_INFO("%s: addr=%x\n", __FUNCTION__, addr);
+
+		cnts = simple_strtoul(tmp[2], &ptmp, 10);
+		if (cnts == 0) {
+			RTW_INFO("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (PVOID)&max_available_len, _FALSE);
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EINVAL;
+			goto exit;
+		}
+
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_mask_map_read error!\n", __func__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		/*		RTW_INFO("%s: data={", __FUNCTION__); */
+		*extra = 0;
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("0x%02x ", data[i]); */
+			pextra += sprintf(pextra, "0x%02X ", data[i]);
+		}
+		/*		RTW_INFO("}\n"); */
+	} else if (strcmp(tmp[0], "realraw") == 0) {
+		static u8 raw_order = 0;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+
+		addr = 0;
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_REAL_CONTENT_LEN , (PVOID)&mapLen, _FALSE);
+		RTW_INFO("Real content len = %d\n",mapLen );
+
+		if (rtw_efuse_access(padapter, _FALSE, addr, mapLen, rawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access Fail!!\n", __func__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		_rtw_memset(extra, '\0', strlen(extra));
+
+		shift = blksz * raw_order;
+		rawdata += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			raw_order++;
+		} else
+			raw_order = 0;
+
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
+
+	} else if (strcmp(tmp[0], "btrealraw") == 0) {
+		static u8 bt_raw_order = 0;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+
+		addr = 0;
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_REAL_CONTENT_LEN, (PVOID)&mapLen, _FALSE);
+		RTW_INFO("Real content len = %d\n", mapLen);
+#ifdef RTW_HALMAC
+		if (rtw_efuse_bt_access(padapter, _FALSE, 0, mapLen, rawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access Fail!!\n", __func__);
+			err = -EFAULT;
+			goto exit;
+		}
+#else
+		rtw_write8(padapter, 0x35, 0x1);
+
+		if (rtw_efuse_access(padapter, _FALSE, addr, mapLen, rawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access Fail!!\n", __func__);
+			err = -EFAULT;
+			goto exit;
+		}
+#endif
+		_rtw_memset(extra, '\0', strlen(extra));
+
+		shift = blksz * bt_raw_order;
+		rawdata += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			bt_raw_order++;
+		} else
+			bt_raw_order = 0;
+
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
+
+	} else if (strcmp(tmp[0], "mac") == 0) {
+		if (hal_efuse_macaddr_offset(padapter) == -1) {
+			err = -EFAULT;
+			goto exit;
+		}
+
+		addr = hal_efuse_macaddr_offset(padapter);
+		cnts = 6;
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%02x)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_mask_map_read error!\n", __func__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		/*		RTW_INFO("%s: MAC address={", __FUNCTION__); */
+		*extra = 0;
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("%02X", data[i]); */
+			pextra += sprintf(pextra, "%02X", data[i]);
+			if (i != (cnts - 1)) {
+				/*				RTW_INFO(":"); */
+				pextra += sprintf(pextra, ":");
+			}
+		}
+		/*		RTW_INFO("}\n"); */
+	} else if (strcmp(tmp[0], "vidpid") == 0) {
+#ifdef CONFIG_RTL8188E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_88EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_88EE;
+#endif
+#endif /* CONFIG_RTL8188E */
+
+#ifdef CONFIG_RTL8192E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8192EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_8192EE;
+#endif
+#endif /* CONFIG_RTL8192E */
+#ifdef CONFIG_RTL8723B
+		addr = EEPROM_VID_8723BU;
+#endif /* CONFIG_RTL8192E */
+
+#ifdef CONFIG_RTL8188F
+		addr = EEPROM_VID_8188FU;
+#endif /* CONFIG_RTL8188F */
+
+#ifdef CONFIG_RTL8703B
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8703BU;
+#endif
+#endif /* CONFIG_RTL8703B */
+
+#ifdef CONFIG_RTL8723D
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8723DU;
+#endif /* CONFIG_USB_HCI */
+#endif /* CONFIG_RTL8723D */
+
+		cnts = 4;
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%02x)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EFAULT;
+			goto exit;
+		}
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		/*		RTW_INFO("%s: {VID,PID}={", __FUNCTION__); */
+		*extra = 0;
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("0x%02x", data[i]); */
+			pextra += sprintf(pextra, "0x%02X", data[i]);
+			if (i != (cnts - 1)) {
+				/*				RTW_INFO(","); */
+				pextra += sprintf(pextra, ",");
+			}
+		}
+		/*		RTW_INFO("}\n"); */
+	} else if (strcmp(tmp[0], "ableraw") == 0) {
+#ifdef RTW_HALMAC
+		raw_maxsize = efuse_GetavailableSize(padapter);
+#else
+		efuse_GetCurrentSize(padapter, &raw_cursize);
+		raw_maxsize = efuse_GetMaxSize(padapter);
+#endif
+		sprintf(extra, "[available raw size]= %d bytes\n", raw_maxsize - raw_cursize);
+	} else if (strcmp(tmp[0], "btableraw") == 0) {
+		efuse_bt_GetCurrentSize(padapter, &raw_cursize);
+		raw_maxsize = efuse_bt_GetMaxSize(padapter);
+		sprintf(extra, "[available raw size]= %d bytes\n", raw_maxsize - raw_cursize);
+	} else if (strcmp(tmp[0], "btfmap") == 0) {
+
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+
+		mapLen = EFUSE_BT_MAX_MAP_LEN;
+		if (rtw_BT_efuse_map_read(padapter, 0, mapLen, pEfuseHal->BTEfuseInitMap) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_read Fail!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
+		sprintf(extra, "\n");
+		for (i = 0; i < 512; i += 16) { /* set 512 because the iwpriv's extra size have limit 0x7FF */
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->BTEfuseInitMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
+			}
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->BTEfuseInitMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
+			}
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
+		}
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "btbmap") == 0) {
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+
+		mapLen = EFUSE_BT_MAX_MAP_LEN;
+		if (rtw_BT_efuse_map_read(padapter, 0, mapLen, pEfuseHal->BTEfuseInitMap) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_read Fail!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
+		sprintf(extra, "\n");
+		for (i = 512; i < 1024 ; i += 16) {
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", data[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
+			}
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", data[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
+			}
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
+		}
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "btrmap") == 0) {
+		u8 BTStatus;
+
+		rtw_write8(padapter, 0xa3, 0x05); /* For 8723AB ,8821S ? */
+		BTStatus = rtw_read8(padapter, 0xa0);
+
+		RTW_INFO("%s: Check 0xa0 BT Status =0x%x\n", __FUNCTION__, BTStatus);
+		if (BTStatus != 0x04) {
+			sprintf(extra, "BT Status not Active ,can't to read BT eFuse\n");
+			goto exit;
+		}
+
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+
+		/* rmap addr cnts */
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+
+		cnts = simple_strtoul(tmp[2], &ptmp, 10);
+		if (cnts == 0) {
+			RTW_INFO("%s: btrmap Fail!! cnts error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+#ifndef RTW_HALMAC
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EFAULT;
+			goto exit;
+		}
+#endif
+		if (rtw_BT_efuse_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_read error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		*extra = 0;
+		pextra = extra;
+		/*		RTW_INFO("%s: bt efuse data={", __FUNCTION__); */
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("0x%02x ", data[i]); */
+			pextra += sprintf(pextra, " 0x%02X ", data[i]);
+		}
+		/*		RTW_INFO("}\n"); */
+		RTW_INFO(FUNC_ADPT_FMT ": BT MAC=[%s]\n", FUNC_ADPT_ARG(padapter), extra);
+	} else if (strcmp(tmp[0], "btffake") == 0) {
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
+		sprintf(extra, "\n");
+		for (i = 0; i < 512; i += 16) {
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+			}
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+			}
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
+		}
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "btbfake") == 0) {
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
+		sprintf(extra, "\n");
+		for (i = 512; i < 1024; i += 16) {
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+			}
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+			}
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
+		}
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "wlrfkmap") == 0) {
+		static u8 fk_order = 0;
+		u8 *efuse;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&mapLen, _FALSE);
+		efuse = pEfuseHal->fakeEfuseModifiedMap;
+
+		shift = blksz * fk_order;
+		efuse += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			fk_order++;
+		} else
+			fk_order = 0;
+
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more\n");
+
+	} else if (strcmp(tmp[0], "wlrfkrmap") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			RTW_INFO("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		/* rmap addr cnts */
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		RTW_INFO("%s: addr=%x\n", __FUNCTION__, addr);
+
+		cnts = simple_strtoul(tmp[2], &ptmp, 10);
+		if (cnts == 0) {
+			RTW_INFO("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+
+		/*		RTW_INFO("%s: data={", __FUNCTION__); */
+		*extra = 0;
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			RTW_INFO("wlrfkrmap = 0x%02x\n", pEfuseHal->fakeEfuseModifiedMap[addr + i]);
+			pextra += sprintf(pextra, "0x%02X ", pEfuseHal->fakeEfuseModifiedMap[addr+i]);
+		}
+	} else if (strcmp(tmp[0], "btrfkrmap") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			RTW_INFO("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		/* rmap addr cnts */
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		RTW_INFO("%s: addr=%x\n", __FUNCTION__, addr);
+
+		cnts = simple_strtoul(tmp[2], &ptmp, 10);
+		if (cnts == 0) {
+			RTW_INFO("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+
+		/*		RTW_INFO("%s: data={", __FUNCTION__); */
+		*extra = 0;
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			RTW_INFO("wlrfkrmap = 0x%02x\n", pEfuseHal->fakeBTEfuseModifiedMap[addr + i]);
+			pextra += sprintf(pextra, "0x%02X ", pEfuseHal->fakeBTEfuseModifiedMap[addr+i]);
+		}
+	} else if (strcmp(tmp[0], "mask") == 0) {
+		*extra = 0;
+		mask_len = sizeof(u8) * rtw_get_efuse_mask_arraylen(padapter);
+		rtw_efuse_mask_array(padapter, mask_buf);
+
+		if (padapter->registrypriv.bFileMaskEfuse == _TRUE)
+			_rtw_memcpy(mask_buf, maskfileBuffer, mask_len);
+
+		sprintf(extra, "\n");
+		pextra = extra + strlen(extra);
+		for (i = 0; i < mask_len; i++)
+			pextra += sprintf(pextra, "0x%02X\n", mask_buf[i]);
+
+	} else
+		sprintf(extra, "Command not found!");
+
+exit:
+	if (data)
+		rtw_mfree(data, EFUSE_BT_MAX_MAP_LEN);
+	if (rawdata)
+		rtw_mfree(rawdata, EFUSE_BT_MAX_MAP_LEN);
+	if (!err)
+		wrqu->length = strlen(extra);
+
+	if (padapter->registrypriv.mp_mode == 0) {
+#ifdef CONFIG_IPS
+		rtw_pm_set_ips(padapter, ips_mode);
+#endif /* CONFIG_IPS */
+
+#ifdef CONFIG_LPS
+		rtw_pm_set_lps(padapter, lps_mode);
+#endif /* CONFIG_LPS */
+	}
+
+#ifdef CONFIG_IOL
+	padapter->registrypriv.fw_iol = org_fw_iol;/* 0:Disable, 1:enable, 2:by usb speed */
+#endif
+	return err;
+}
+
+
+#ifdef CONFIG_MP_INCLUDED
+static int rtw_mp_efuse_set(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wdata, char *extra)
+{
+	struct iw_point *wrqu;
+	PADAPTER padapter;
+	struct pwrctrl_priv *pwrctrlpriv ;
+	PHAL_DATA_TYPE pHalData;
+	PEFUSE_HAL pEfuseHal;
+	struct hal_ops *pHalFunc;
+	struct mp_priv *pmp_priv;
+
+	u8 ips_mode = IPS_NUM; /* init invalid value */
+	u8 lps_mode = PS_MODE_NUM; /* init invalid value */
+	u32 i = 0, j = 0, jj, kk;
+	u8 *setdata = NULL;
+	u8 *ShadowMapBT = NULL;
+	u8 *ShadowMapWiFi = NULL;
+	u8 *setrawdata = NULL;
+	char *pch, *ptmp, *token, *tmp[3] = {0x00, 0x00, 0x00};
+	u16 addr = 0xFF, cnts = 0, BTStatus = 0 , max_available_len = 0;
+	u16 wifimaplen;
+	int err;
+
+	wrqu = (struct iw_point *)wdata;
+	padapter = rtw_netdev_priv(dev);
+	pwrctrlpriv = adapter_to_pwrctl(padapter);
+	pHalData = GET_HAL_DATA(padapter);
+	pEfuseHal = &pHalData->EfuseHal;
+	pHalFunc = &padapter->hal_func;
+	pmp_priv = &padapter->mppriv;
+
+	err = 0;
+
+	if (copy_from_user(extra, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	*(extra + wrqu->length) = '\0';
+
+	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&wifimaplen, _FALSE);
+
+	setdata = rtw_zmalloc(1024);
+	if (setdata == NULL) {
+		err = -ENOMEM;
+		goto exit;
+	}
+	ShadowMapBT = rtw_malloc(EFUSE_BT_MAX_MAP_LEN);
+	if (ShadowMapBT == NULL) {
+		err = -ENOMEM;
+		goto exit;
+	}
+	ShadowMapWiFi = rtw_malloc(wifimaplen);
+	if (ShadowMapWiFi == NULL) {
+		err = -ENOMEM;
+		goto exit;
+	}
+	setrawdata = rtw_malloc(EFUSE_MAX_SIZE);
+	if (setrawdata == NULL) {
+		err = -ENOMEM;
+		goto exit;
+	}
+
+#ifdef CONFIG_LPS
+	lps_mode = pwrctrlpriv->power_mgnt;/* keep org value */
+	rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
+#endif
+
+#ifdef CONFIG_IPS
+	ips_mode = pwrctrlpriv->ips_mode;/* keep org value */
+	rtw_pm_set_ips(padapter, IPS_NONE);
+#endif
+
+	pch = extra;
+	RTW_INFO("%s: in=%s\n", __FUNCTION__, extra);
+
+	i = 0;
+	while ((token = strsep(&pch, ",")) != NULL) {
+		if (i > 2)
+			break;
+		tmp[i] = token;
+		i++;
+	}
+
+	/* tmp[0],[1],[2] */
+	/* wmap,addr,00e04c871200 */
+	if (strcmp(tmp[0], "wmap") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+#ifndef RTW_HALMAC
+		/* unknown bug workaround, need to fix later */
+		addr = 0x1ff;
+		rtw_write8(padapter, EFUSE_CTRL + 1, (addr & 0xff));
+		rtw_msleep_os(10);
+		rtw_write8(padapter, EFUSE_CTRL + 2, ((addr >> 8) & 0x03));
+		rtw_msleep_os(10);
+		rtw_write8(padapter, EFUSE_CTRL + 3, 0x72);
+		rtw_msleep_os(10);
+		rtw_read8(padapter, EFUSE_CTRL);
+#endif /* RTW_HALMAC */
+
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		addr &= 0xFFF;
+
+		cnts = strlen(tmp[2]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: map data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
+
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+		*extra = 0;
+		RTW_INFO("%s: after rtw_efuse_map_write to _rtw_memcmp\n", __func__);
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, ShadowMapWiFi) == _SUCCESS) {
+			if (_rtw_memcmp((void *)ShadowMapWiFi , (void *)setdata, cnts)) {
+				RTW_INFO("%s: WiFi write map afterf compare success\n", __FUNCTION__);
+				sprintf(extra, "WiFi write map compare OK\n");
+				err = 0;
+				goto exit;
+			} else {
+				sprintf(extra, "WiFi write map compare FAIL\n");
+				RTW_INFO("%s: WiFi write map compare Fail\n", __FUNCTION__);
+				err = 0;
+				goto exit;
+			}
+		}
+	} else if (strcmp(tmp[0], "wraw") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		addr &= 0xFFF;
+
+		cnts = strlen(tmp[2]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: raw data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setrawdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+
+		if (rtw_efuse_access(padapter, _TRUE, addr, cnts, setrawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+	} else if (strcmp(tmp[0], "btwraw") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		addr &= 0xFFF;
+
+		cnts = strlen(tmp[2]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: raw data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setrawdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+#ifdef RTW_HALMAC
+		if (rtw_efuse_bt_access(padapter, _TRUE, addr, cnts, setrawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+#else
+		rtw_write8(padapter, 0x35, 1); /* switch bank 1 (BT)*/
+		if (rtw_efuse_access(padapter, _TRUE, addr, cnts, setrawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+			rtw_write8(padapter, 0x35, 0); /* switch bank 0 (WiFi)*/
+			err = -EFAULT;
+			goto exit;
+		}
+		rtw_write8(padapter, 0x35, 0); /* switch bank 0 (WiFi)*/
+#endif
+	} else if (strcmp(tmp[0], "mac") == 0) {
+		if (tmp[1] == NULL) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		/* mac,00e04c871200 */
+
+		if (hal_efuse_macaddr_offset(padapter) == -1) {
+			err = -EFAULT;
+			goto exit;
+		}
+
+		addr = hal_efuse_macaddr_offset(padapter);
+		cnts = strlen(tmp[1]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+		if (cnts > 6) {
+			RTW_INFO("%s: error data for mac addr=\"%s\"\n", __FUNCTION__, tmp[1]);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: MAC address=%s\n", __FUNCTION__, tmp[1]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
+
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+	} else if (strcmp(tmp[0], "vidpid") == 0) {
+		if (tmp[1] == NULL) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		/* pidvid,da0b7881		 */
+#ifdef CONFIG_RTL8188E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_88EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_88EE;
+#endif
+#endif /* CONFIG_RTL8188E */
+
+#ifdef CONFIG_RTL8192E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8192EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_8192EE;
+#endif
+#endif /* CONFIG_RTL8188E */
+
+#ifdef CONFIG_RTL8723B
+		addr = EEPROM_VID_8723BU;
+#endif
+
+#ifdef CONFIG_RTL8188F
+		addr = EEPROM_VID_8188FU;
+#endif
+
+#ifdef CONFIG_RTL8703B
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8703BU;
+#endif /* CONFIG_USB_HCI */
+#endif /* CONFIG_RTL8703B */
+
+#ifdef CONFIG_RTL8723D
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8723DU;
+#endif /* CONFIG_USB_HCI */
+#endif /* CONFIG_RTL8723D */
+
+		cnts = strlen(tmp[1]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: VID/PID=%s\n", __FUNCTION__, tmp[1]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+	} else if (strcmp(tmp[0], "wldumpfake") == 0) {
+		if (wifimaplen > EFUSE_MAX_MAP_LEN)
+			cnts = EFUSE_MAX_MAP_LEN;
+		else
+			cnts = wifimaplen;
+		if (rtw_efuse_mask_map_read(padapter, 0, cnts, pEfuseHal->fakeEfuseModifiedMap) == _SUCCESS)
+			RTW_INFO("%s: WiFi hw efuse dump to Fake map success\n", __func__);
+		else {
+			RTW_INFO("%s: WiFi hw efuse dump to Fake map Fail\n", __func__);
+			err = -EFAULT;
+		}
+	} else if (strcmp(tmp[0], "btwmap") == 0) {
+		rtw_write8(padapter, 0xa3, 0x05); /* For 8723AB ,8821S ? */
+		BTStatus = rtw_read8(padapter, 0xa0);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __FUNCTION__, BTStatus);
+		if (BTStatus != 0x04) {
+			sprintf(extra, "BT Status not Active ,can't do Write\n");
+			goto exit;
+		}
+
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+#ifndef RTW_HALMAC
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+		addr = 0x1ff;
+		rtw_write8(padapter, EFUSE_CTRL + 1, (addr & 0xff));
+		rtw_msleep_os(10);
+		rtw_write8(padapter, EFUSE_CTRL + 2, ((addr >> 8) & 0x03));
+		rtw_msleep_os(10);
+		rtw_write8(padapter, EFUSE_CTRL + 3, 0x72);
+		rtw_msleep_os(10);
+		rtw_read8(padapter, EFUSE_CTRL);
+		BTEfuse_PowerSwitch(padapter, 1, _FALSE);
+#endif /* RTW_HALMAC */
+
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		addr &= 0xFFF;
+
+		cnts = strlen(tmp[2]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: BT data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+#ifndef RTW_HALMAC
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			err = -EFAULT;
+			goto exit;
+		}
+#endif
+		if (rtw_BT_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_write error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+		*extra = 0;
+		RTW_INFO("%s: after rtw_BT_efuse_map_write to _rtw_memcmp\n", __FUNCTION__);
+		if ((rtw_BT_efuse_map_read(padapter, addr, cnts, ShadowMapBT) == _SUCCESS)) {
+			if (_rtw_memcmp((void *)ShadowMapBT , (void *)setdata, cnts)) {
+				RTW_INFO("%s: BT write map compare OK BTStatus=0x%x\n", __FUNCTION__, BTStatus);
+				sprintf(extra, "BT write map compare OK");
+				err = 0;
+				goto exit;
+			} else {
+				sprintf(extra, "BT write map compare FAIL");
+				RTW_INFO("%s: BT write map compare FAIL BTStatus=0x%x\n", __FUNCTION__, BTStatus);
+				err = 0;
+				goto exit;
+			}
+		}
+	} else if (strcmp(tmp[0], "btwfake") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		addr &= 0xFFF;
+
+		cnts = strlen(tmp[2]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: BT tmp data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			pEfuseHal->fakeBTEfuseModifiedMap[addr + jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+	} else if (strcmp(tmp[0], "btdumpfake") == 0) {
+		if (rtw_BT_efuse_map_read(padapter, 0, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _SUCCESS)
+			RTW_INFO("%s: BT read all map success\n", __FUNCTION__);
+		else {
+			RTW_INFO("%s: BT read all map Fail!\n", __FUNCTION__);
+			err = -EFAULT;
+		}
+	} else if (strcmp(tmp[0], "btfk2map") == 0) {
+		rtw_write8(padapter, 0xa3, 0x05);
+		BTStatus = rtw_read8(padapter, 0xa0);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __FUNCTION__, BTStatus);
+		if (BTStatus != 0x04) {
+			sprintf(extra, "BT Status not Active Write FAIL\n");
+			goto exit;
+		}
+#ifndef RTW_HALMAC
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+		addr = 0x1ff;
+		rtw_write8(padapter, EFUSE_CTRL + 1, (addr & 0xff));
+		rtw_msleep_os(10);
+		rtw_write8(padapter, EFUSE_CTRL + 2, ((addr >> 8) & 0x03));
+		rtw_msleep_os(10);
+		rtw_write8(padapter, EFUSE_CTRL + 3, 0x72);
+		rtw_msleep_os(10);
+		rtw_read8(padapter, EFUSE_CTRL);
+		BTEfuse_PowerSwitch(padapter, 1, _FALSE);
+#endif /* RTW_HALMAC */
+		_rtw_memcpy(pEfuseHal->BTEfuseModifiedMap, pEfuseHal->fakeBTEfuseModifiedMap, EFUSE_BT_MAX_MAP_LEN);
+
+		if (rtw_BT_efuse_map_write(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_write error!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		RTW_INFO("pEfuseHal->fakeBTEfuseModifiedMap OFFSET\tVALUE(hex)\n");
+		for (i = 0; i < EFUSE_BT_MAX_MAP_LEN; i += 16) {
+			printk("0x%02x\t", i);
+			for (j = 0; j < 8; j++)
+				printk("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i + j]);
+			printk("\t");
+
+			for (; j < 16; j++)
+				printk("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i + j]);
+			printk("\n");
+		}
+		printk("\n");
+#if 1
+		err = -EFAULT;
+		RTW_INFO("%s: rtw_BT_efuse_map_read _rtw_memcmp\n", __FUNCTION__);
+		if ((rtw_BT_efuse_map_read(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseInitMap) == _SUCCESS)) {
+			if (_rtw_memcmp((void *)pEfuseHal->fakeBTEfuseModifiedMap, (void *)pEfuseHal->fakeBTEfuseInitMap, EFUSE_BT_MAX_MAP_LEN)) {
+				sprintf(extra, "BT write map compare OK");
+				RTW_INFO("%s: BT write map afterf compare success BTStatus=0x%x\n", __FUNCTION__, BTStatus);
+				err = 0;
+				goto exit;
+			} else {
+				sprintf(extra, "BT write map compare FAIL");
+				if (rtw_BT_efuse_map_write(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _FAIL)
+					RTW_INFO("%s: rtw_BT_efuse_map_write compare error,retry = %d!\n", __FUNCTION__, i);
+
+				if (rtw_BT_efuse_map_read(padapter, EFUSE_BT, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseInitMap) == _SUCCESS) {
+					RTW_INFO("pEfuseHal->fakeBTEfuseInitMap OFFSET\tVALUE(hex)\n");
+
+					for (i = 0; i < EFUSE_BT_MAX_MAP_LEN; i += 16) {
+						printk("0x%02x\t", i);
+						for (j = 0; j < 8; j++)
+							printk("%02X ", pEfuseHal->fakeBTEfuseInitMap[i + j]);
+						printk("\t");
+						for (; j < 16; j++)
+							printk("%02X ", pEfuseHal->fakeBTEfuseInitMap[i + j]);
+						printk("\n");
+					}
+					printk("\n");
+				}
+				RTW_INFO("%s: BT write map afterf compare not match to write efuse try write Map again , BTStatus=0x%x\n", __FUNCTION__, BTStatus);
+				goto exit;
+			}
+		}
+#endif
+
+	} else if (strcmp(tmp[0], "wlfk2map") == 0) {
+		*extra = 0;
+
+		if (padapter->registrypriv.bFileMaskEfuse != _TRUE && pmp_priv->bloadefusemap == _TRUE) {
+			RTW_INFO("%s: File eFuse mask file not to be loaded\n", __FUNCTION__);
+			sprintf(extra, "Not load eFuse mask file yet, Please use the efuse_mask CMD, now remove the interface !!!!\n");
+			rtw_set_surprise_removed(padapter);
+			err = 0;
+			goto exit;
+		}
+
+		if (wifimaplen > EFUSE_MAX_MAP_LEN)
+			cnts = EFUSE_MAX_MAP_LEN;
+		else
+			cnts = wifimaplen;
+		if (rtw_efuse_map_write(padapter, 0x00, cnts, pEfuseHal->fakeEfuseModifiedMap) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write fakeEfuseModifiedMap error!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		if (rtw_efuse_mask_map_read(padapter, 0x00, wifimaplen, ShadowMapWiFi) == _SUCCESS) {
+			if (_rtw_memcmp((void *)ShadowMapWiFi , (void *)pEfuseHal->fakeEfuseModifiedMap, cnts)) {
+				RTW_INFO("%s: WiFi write map afterf compare OK\n", __FUNCTION__);
+				sprintf(extra, "WiFi write map compare OK\n");
+				err = 0;
+				goto exit;
+			} else {
+				sprintf(extra, "WiFi write map compare FAIL\n");
+				RTW_INFO("%s: WiFi write map compare Fail\n", __FUNCTION__);
+				err = 0;
+				goto exit;
+			}
+		}
+	} else if (strcmp(tmp[0], "wlwfake") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		addr &= 0xFFF;
+
+		cnts = strlen(tmp[2]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: map tmp data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			pEfuseHal->fakeEfuseModifiedMap[addr + jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+		_rtw_memset(extra, '\0', strlen(extra));
+		sprintf(extra, "wlwfake OK\n");
+
+	}
+	else if (strcmp(tmp[0], "wfakemac") == 0) {
+		if (tmp[1] == NULL) {
+			err = -EINVAL;
+			goto exit;
+		}
+		/* wfakemac,00e04c871200 */
+		if (hal_efuse_macaddr_offset(padapter) == -1) {
+			err = -EFAULT;
+			goto exit;
+		}
+
+		addr = hal_efuse_macaddr_offset(padapter);
+		cnts = strlen(tmp[1]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+		if (cnts > 6) {
+			RTW_INFO("%s: error data for mac addr=\"%s\"\n", __FUNCTION__, tmp[1]);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: MAC address=%s\n", __FUNCTION__, tmp[1]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			pEfuseHal->fakeEfuseModifiedMap[addr + jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
+
+		_rtw_memset(extra, '\0', strlen(extra));
+		sprintf(extra, "write mac addr to fake map OK\n");
+	} else if(strcmp(tmp[0], "update") == 0) {
+		RTW_INFO("To Use new eFuse map\n");
+		/*step read efuse/eeprom data and get mac_addr*/
+		rtw_hal_read_chip_info(padapter);
+		/* set mac addr*/
+		rtw_macaddr_cfg(adapter_mac_addr(padapter), get_hal_mac_addr(padapter));
+		_rtw_memcpy(padapter->pnetdev->dev_addr, get_hal_mac_addr(padapter), ETH_ALEN); /* set mac addr to net_device */
+
+#ifdef CONFIG_P2P
+		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+#endif
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_hal_change_macaddr_mbid(padapter, adapter_mac_addr(padapter));
+#else
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, adapter_mac_addr(padapter)); /* set mac addr to mac register */
+#endif
+		/*pHalFunc->hal_deinit(padapter);*/
+		if (pHalFunc->hal_init(padapter) == _FAIL) {
+			err = -EINVAL;
+			goto exit;
+		}
+		_rtw_memset(extra, '\0', strlen(extra));
+		sprintf(extra, "eFuse Update OK\n");
+	} else if (strcmp(tmp[0], "analyze") == 0) {
+
+		rtw_efuse_analyze(padapter, EFUSE_WIFI, 0);
+		_rtw_memset(extra, '\0', strlen(extra));
+		sprintf(extra, "eFuse Analyze OK,please to check kernel log\n");
+	}
+exit:
+	if (setdata)
+		rtw_mfree(setdata, 1024);
+	if (ShadowMapBT)
+		rtw_mfree(ShadowMapBT, EFUSE_BT_MAX_MAP_LEN);
+	if (ShadowMapWiFi)
+		rtw_mfree(ShadowMapWiFi, wifimaplen);
+	if (setrawdata)
+		rtw_mfree(setrawdata, EFUSE_MAX_SIZE);
+
+	wrqu->length = strlen(extra);
+
+	if (padapter->registrypriv.mp_mode == 0) {
+#ifdef CONFIG_IPS
+		rtw_pm_set_ips(padapter, ips_mode);
+#endif /* CONFIG_IPS */
+
+#ifdef CONFIG_LPS
+		rtw_pm_set_lps(padapter, lps_mode);
+#endif /* CONFIG_LPS */
+	}
+
+	return err;
+}
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+static int rtw_mp_customer_str(
+	struct net_device *dev,
+	struct iw_request_info *info,
+	union iwreq_data *wrqu, char *extra)
+{
+	_adapter *adapter = rtw_netdev_priv(dev);
+	u32 len;
+	u8 *pbuf = NULL, *pch;
+	char *ptmp;
+	u8 param[RTW_CUSTOMER_STR_LEN];
+	u8 count = 0;
+	u8 tmp;
+	u8 i;
+	u32 pos;
+	u8 ret;
+	u8 read = 0;
+
+	if (adapter->registrypriv.mp_mode != 1
+		|| !adapter->registrypriv.mp_customer_str)
+		return -EFAULT;
+
+	len = wrqu->data.length;
+
+	pbuf = (u8 *)rtw_zmalloc(len);
+	if (pbuf == NULL) {
+		RTW_WARN("%s: no memory!\n", __func__);
+		return -ENOMEM;
+	}
+
+	if (copy_from_user(pbuf, wrqu->data.pointer, len)) {
+		rtw_mfree(pbuf, len);
+		RTW_WARN("%s: copy from user fail!\n", __func__);
+		return -EFAULT;
+	}
+	RTW_INFO("%s: string=\"%s\"\n", __func__, pbuf);
+
+	ptmp = (char *)pbuf;
+	pch = strsep(&ptmp, ",");
+	if ((pch == NULL) || (strlen(pch) == 0)) {
+		rtw_mfree(pbuf, len);
+		RTW_INFO("%s: parameter error(no cmd)!\n", __func__);
+		return -EFAULT;
+	}
+
+	_rtw_memset(param, 0xFF, RTW_CUSTOMER_STR_LEN);
+
+	if (strcmp(pch, "read") == 0) {
+		read = 1;
+		ret = rtw_hal_customer_str_read(adapter, param);
+
+	} else if (strcmp(pch, "write") == 0) {
+		do {
+			pch = strsep(&ptmp, ":");
+			if ((pch == NULL) || (strlen(pch) == 0))
+				break;
+			if (strlen(pch) != 2
+				|| IsHexDigit(*pch) == _FALSE
+				|| IsHexDigit(*(pch + 1)) == _FALSE
+				|| sscanf(pch, "%hhx", &tmp) != 1
+			) {
+				RTW_WARN("%s: invalid 8-bit hex!\n", __func__);
+				rtw_mfree(pbuf, len);
+				return -EFAULT;
+			}
+
+			param[count++] = tmp;
+
+		} while (count < RTW_CUSTOMER_STR_LEN);
+
+		if (count == 0) {
+			rtw_mfree(pbuf, len);
+			RTW_WARN("%s: no input!\n", __func__);
+			return -EFAULT;
+		}
+		ret = rtw_hal_customer_str_write(adapter, param);
+	} else {
+		rtw_mfree(pbuf, len);
+		RTW_INFO("%s: parameter error(unknown cmd)!\n", __func__);
+		return -EFAULT;
+	}
+
+	pos = sprintf(extra, "%s: ", read ? "read" : "write");
+	if (read == 0 || ret == _SUCCESS) {
+		for (i = 0; i < RTW_CUSTOMER_STR_LEN; i++)
+			pos += sprintf(extra + pos, "%02x:", param[i]);
+		extra[pos] = 0;
+		pos--;
+	}
+	pos += sprintf(extra + pos, " %s", ret == _SUCCESS ? "OK" : "FAIL");
+
+	wrqu->data.length = strlen(extra) + 1;
+
+free_buf:
+	rtw_mfree(pbuf, len);
+	return 0;
+}
+#endif /* CONFIG_RTW_CUSTOMER_STR */
+
+static int rtw_priv_mp_set(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wdata, char *extra)
+{
+
+	struct iw_point *wrqu = (struct iw_point *)wdata;
+	u32 subcmd = wrqu->flags;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (!is_primary_adapter(padapter)) {
+		RTW_INFO("MP mode only primary Adapter support\n");
+		return -EIO;
+	}
+
+	switch (subcmd) {
+	case CTA_TEST:
+		RTW_INFO("set CTA_TEST\n");
+		rtw_cta_test_start(dev, info, wdata, extra);
+		break;
+	case MP_DISABLE_BT_COEXIST:
+		RTW_INFO("set case MP_DISABLE_BT_COEXIST\n");
+		rtw_mp_disable_bt_coexist(dev, info, wdata, extra);
+		break;
+	case MP_IQK:
+		RTW_INFO("set MP_IQK\n");
+		rtw_mp_iqk(dev, info, wrqu, extra);
+		break;
+	case MP_LCK:
+		RTW_INFO("set MP_LCK\n");
+		rtw_mp_lck(dev, info, wrqu, extra);
+	break;
+
+	default:
+		return -EIO;
+	}
+
+	return 0;
+}
+
+static int rtw_priv_mp_get(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wdata, char *extra)
+{
+
+	struct iw_point *wrqu = (struct iw_point *)wdata;
+	u32 subcmd = wrqu->flags;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (!is_primary_adapter(padapter)) {
+		RTW_INFO("MP mode only primary Adapter support\n");
+		return -EIO;
+	}
+
+	switch (subcmd) {
+	case MP_START:
+		RTW_INFO("set case mp_start\n");
+		rtw_mp_start(dev, info, wrqu, extra);
+		break;
+	case MP_STOP:
+		RTW_INFO("set case mp_stop\n");
+		rtw_mp_stop(dev, info, wrqu, extra);
+		break;
+	case MP_BANDWIDTH:
+		RTW_INFO("set case mp_bandwidth\n");
+		rtw_mp_bandwidth(dev, info, wrqu, extra);
+		break;
+	case MP_RESET_STATS:
+		RTW_INFO("set case MP_RESET_STATS\n");
+		rtw_mp_reset_stats(dev, info, wrqu, extra);
+		break;
+	case MP_SetRFPathSwh:
+		RTW_INFO("set MP_SetRFPathSwitch\n");
+		rtw_mp_SetRFPath(dev, info, wrqu, extra);
+		break;
+	case WRITE_REG:
+		rtw_mp_write_reg(dev, info, wrqu, extra);
+		break;
+	case WRITE_RF:
+		rtw_mp_write_rf(dev, info, wrqu, extra);
+		break;
+	case MP_PHYPARA:
+		RTW_INFO("mp_get  MP_PHYPARA\n");
+		rtw_mp_phypara(dev, info, wrqu, extra);
+		break;
+	case MP_CHANNEL:
+		RTW_INFO("set case mp_channel\n");
+		rtw_mp_channel(dev , info, wrqu, extra);
+		break;
+    	case  MP_CHL_OFFSET:
+       		RTW_INFO("set case mp_ch_offset\n");
+        	rtw_mp_ch_offset(dev , info, wrqu, extra);
+        	break;
+	case READ_REG:
+		RTW_INFO("mp_get  READ_REG\n");
+		rtw_mp_read_reg(dev, info, wrqu, extra);
+		break;
+	case READ_RF:
+		RTW_INFO("mp_get  READ_RF\n");
+		rtw_mp_read_rf(dev, info, wrqu, extra);
+		break;
+	case MP_RATE:
+		RTW_INFO("set case mp_rate\n");
+		rtw_mp_rate(dev, info, wrqu, extra);
+		break;
+	case MP_TXPOWER:
+		RTW_INFO("set case MP_TXPOWER\n");
+		rtw_mp_txpower(dev, info, wrqu, extra);
+		break;
+	case MP_ANT_TX:
+		RTW_INFO("set case MP_ANT_TX\n");
+		rtw_mp_ant_tx(dev, info, wrqu, extra);
+		break;
+	case MP_ANT_RX:
+		RTW_INFO("set case MP_ANT_RX\n");
+		rtw_mp_ant_rx(dev, info, wrqu, extra);
+		break;
+	case MP_QUERY:
+		rtw_mp_trx_query(dev, info, wrqu, extra);
+		break;
+	case MP_CTX:
+		RTW_INFO("set case MP_CTX\n");
+		rtw_mp_ctx(dev, info, wrqu, extra);
+		break;
+	case MP_ARX:
+		RTW_INFO("set case MP_ARX\n");
+		rtw_mp_arx(dev, info, wrqu, extra);
+		break;
+	case MP_DUMP:
+		RTW_INFO("set case MP_DUMP\n");
+		rtw_mp_dump(dev, info, wrqu, extra);
+		break;
+	case MP_PSD:
+		RTW_INFO("set case MP_PSD\n");
+		rtw_mp_psd(dev, info, wrqu, extra);
+		break;
+	case MP_THER:
+		RTW_INFO("set case MP_THER\n");
+		rtw_mp_thermal(dev, info, wrqu, extra);
+		break;
+	case MP_PwrCtlDM:
+		RTW_INFO("set MP_PwrCtlDM\n");
+		rtw_mp_PwrCtlDM(dev, info, wrqu, extra);
+		break;
+	case MP_QueryDrvStats:
+		RTW_INFO("mp_get MP_QueryDrvStats\n");
+		rtw_mp_QueryDrv(dev, info, wdata, extra);
+		break;
+	case MP_PWRTRK:
+		RTW_INFO("set case MP_PWRTRK\n");
+		rtw_mp_pwrtrk(dev, info, wrqu, extra);
+		break;
+#ifdef CONFIG_MP_INCLUDED
+	case EFUSE_SET:
+		RTW_INFO("set case efuse set\n");
+		rtw_mp_efuse_set(dev, info, wdata, extra);
+		break;
+#endif
+	case EFUSE_GET:
+		RTW_INFO("efuse get EFUSE_GET\n");
+		rtw_mp_efuse_get(dev, info, wdata, extra);
+		break;
+	case MP_GET_TXPOWER_INX:
+		RTW_INFO("mp_get MP_GET_TXPOWER_INX\n");
+		rtw_mp_txpower_index(dev, info, wrqu, extra);
+		break;
+	case MP_GETVER:
+		RTW_INFO("mp_get MP_GETVER\n");
+		rtw_mp_getver(dev, info, wdata, extra);
+		break;
+	case MP_MON:
+		RTW_INFO("mp_get MP_MON\n");
+		rtw_mp_mon(dev, info, wdata, extra);
+		break;
+	case EFUSE_MASK:
+		RTW_INFO("mp_get EFUSE_MASK\n");
+		rtw_efuse_mask_file(dev, info, wdata, extra);
+		break;
+	case  EFUSE_FILE:
+		RTW_INFO("mp_get EFUSE_FILE\n");
+		rtw_efuse_file_map(dev, info, wdata, extra);
+		break;
+	case  MP_TX:
+		RTW_INFO("mp_get MP_TX\n");
+		rtw_mp_tx(dev, info, wdata, extra);
+		break;
+	case  MP_RX:
+		RTW_INFO("mp_get MP_RX\n");
+		rtw_mp_rx(dev, info, wdata, extra);
+		break;
+	case MP_HW_TX_MODE:
+		RTW_INFO("mp_get MP_HW_TX_MODE\n");
+		rtw_mp_hwtx(dev, info, wdata, extra);
+		break;
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	case MP_CUSTOMER_STR:
+		RTW_INFO("customer str\n");
+		rtw_mp_customer_str(dev, info, wdata, extra);
+		break;
+#endif
+	case MP_PWRLMT:
+		RTW_INFO("mp_get MP_SETPWRLMT\n");
+		rtw_mp_pwrlmt(dev, info, wdata, extra);
+		break;
+	case MP_PWRBYRATE:
+		RTW_INFO("mp_get MP_SETPWRBYRATE\n");
+		rtw_mp_pwrbyrate(dev, info, wdata, extra);
+		break;
+	case  BT_EFUSE_FILE:
+		RTW_INFO("mp_get BT EFUSE_FILE\n");
+		rtw_bt_efuse_file_map(dev, info, wdata, extra);
+		break;
+	case  MP_SWRFPath:
+		RTW_INFO("mp_get MP_SWRFPath\n");
+		rtw_mp_switch_rf_path(dev, info, wrqu, extra);
+		break;
+	default:
+		return -EIO;
+	}
+
+	return 0;
+}
+#endif /*#if defined(CONFIG_MP_INCLUDED)*/
+
+
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+#define DBG_MP_SDIO_INDIRECT_ACCESS 1
+static int rtw_mp_sd_iread(struct net_device *dev
+			   , struct iw_request_info *info
+			   , struct iw_point *wrqu
+			   , char *extra)
+{
+	char input[16];
+	u8 width;
+	unsigned long addr;
+	u32 ret = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (wrqu->length > 16) {
+		RTW_INFO(FUNC_ADPT_FMT" wrqu->length:%d\n", FUNC_ADPT_ARG(padapter), wrqu->length);
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length)) {
+		RTW_INFO(FUNC_ADPT_FMT" copy_from_user fail\n", FUNC_ADPT_ARG(padapter));
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	_rtw_memset(extra, 0, wrqu->length);
+
+	if (sscanf(input, "%hhu,%lx", &width, &addr) != 2) {
+		RTW_INFO(FUNC_ADPT_FMT" sscanf fail\n", FUNC_ADPT_ARG(padapter));
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (addr > 0x3FFF) {
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%lx\n", FUNC_ADPT_ARG(padapter), addr);
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (DBG_MP_SDIO_INDIRECT_ACCESS)
+		RTW_INFO(FUNC_ADPT_FMT" width:%u, addr:0x%lx\n", FUNC_ADPT_ARG(padapter), width, addr);
+
+	switch (width) {
+	case 1:
+		sprintf(extra, "0x%02x", rtw_sd_iread8(padapter, addr));
+		wrqu->length = strlen(extra);
+		break;
+	case 2:
+		sprintf(extra, "0x%04x", rtw_sd_iread16(padapter, addr));
+		wrqu->length = strlen(extra);
+		break;
+	case 4:
+		sprintf(extra, "0x%08x", rtw_sd_iread32(padapter, addr));
+		wrqu->length = strlen(extra);
+		break;
+	default:
+		wrqu->length = 0;
+		ret = -EINVAL;
+		break;
+	}
+
+exit:
+	return ret;
+}
+
+static int rtw_mp_sd_iwrite(struct net_device *dev
+			    , struct iw_request_info *info
+			    , struct iw_point *wrqu
+			    , char *extra)
+{
+	char width;
+	unsigned long addr, data;
+	int ret = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char input[32];
+
+	if (wrqu->length > 32) {
+		RTW_INFO(FUNC_ADPT_FMT" wrqu->length:%d\n", FUNC_ADPT_ARG(padapter), wrqu->length);
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length)) {
+		RTW_INFO(FUNC_ADPT_FMT" copy_from_user fail\n", FUNC_ADPT_ARG(padapter));
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	_rtw_memset(extra, 0, wrqu->length);
+
+	if (sscanf(input, "%hhu,%lx,%lx", &width, &addr, &data) != 3) {
+		RTW_INFO(FUNC_ADPT_FMT" sscanf fail\n", FUNC_ADPT_ARG(padapter));
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (addr > 0x3FFF) {
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%lx\n", FUNC_ADPT_ARG(padapter), addr);
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (DBG_MP_SDIO_INDIRECT_ACCESS)
+		RTW_INFO(FUNC_ADPT_FMT" width:%u, addr:0x%lx, data:0x%lx\n", FUNC_ADPT_ARG(padapter), width, addr, data);
+
+	switch (width) {
+	case 1:
+		if (data > 0xFF) {
+			ret = -EINVAL;
+			break;
+		}
+		rtw_sd_iwrite8(padapter, addr, data);
+		break;
+	case 2:
+		if (data > 0xFFFF) {
+			ret = -EINVAL;
+			break;
+		}
+		rtw_sd_iwrite16(padapter, addr, data);
+		break;
+	case 4:
+		rtw_sd_iwrite32(padapter, addr, data);
+		break;
+	default:
+		wrqu->length = 0;
+		ret = -EINVAL;
+		break;
+	}
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+
+static int rtw_priv_set(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wdata, char *extra)
+{
+	struct iw_point *wrqu = (struct iw_point *)wdata;
+	u32 subcmd = wrqu->flags;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (padapter == NULL)
+		return -ENETDOWN;
+
+	if (padapter->bup == _FALSE) {
+		RTW_INFO(" %s fail =>(padapter->bup == _FALSE )\n", __FUNCTION__);
+		return -ENETDOWN;
+	}
+
+	if (RTW_CANNOT_RUN(padapter)) {
+		RTW_INFO("%s fail =>(bSurpriseRemoved == _TRUE) || ( bDriverStopped == _TRUE)\n", __func__);
+		return -ENETDOWN;
+	}
+
+	if (extra == NULL) {
+		wrqu->length = 0;
+		return -EIO;
+	}
+
+	if (subcmd < MP_NULL) {
+#ifdef CONFIG_MP_INCLUDED
+		rtw_priv_mp_set(dev, info, wdata, extra);
+#endif
+		return 0;
+	}
+
+	switch (subcmd) {
+#ifdef CONFIG_WOWLAN
+	case MP_WOW_ENABLE:
+		RTW_INFO("set case MP_WOW_ENABLE: %s\n", extra);
+
+		rtw_wowlan_ctrl(dev, info, wdata, extra);
+		break;
+	case MP_WOW_SET_PATTERN:
+		RTW_INFO("set case MP_WOW_SET_PATTERN: %s\n", extra);
+		rtw_wowlan_set_pattern(dev, info, wdata, extra);
+		break;
+#endif
+#ifdef CONFIG_AP_WOWLAN
+	case MP_AP_WOW_ENABLE:
+		RTW_INFO("set case MP_AP_WOW_ENABLE: %s\n", extra);
+		rtw_ap_wowlan_ctrl(dev, info, wdata, extra);
+		break;
+#endif
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	case VENDOR_IE_SET:
+		RTW_INFO("set case VENDOR_IE_SET\n");
+		rtw_vendor_ie_set(dev , info , wdata , extra);
+		break;
+#endif
+	default:
+		return -EIO;
+	}
+
+	return 0;
+}
+
+
+static int rtw_priv_get(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wdata, char *extra)
+{
+	struct iw_point *wrqu = (struct iw_point *)wdata;
+	u32 subcmd = wrqu->flags;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+
+	if (padapter == NULL)
+		return -ENETDOWN;
+
+	if (padapter->bup == _FALSE) {
+		RTW_INFO(" %s fail =>(padapter->bup == _FALSE )\n", __FUNCTION__);
+		return -ENETDOWN;
+	}
+
+	if (RTW_CANNOT_RUN(padapter)) {
+		RTW_INFO("%s fail =>(padapter->bSurpriseRemoved == _TRUE) || ( padapter->bDriverStopped == _TRUE)\n", __func__);
+		return -ENETDOWN;
+	}
+
+	if (extra == NULL) {
+		wrqu->length = 0;
+		return -EIO;
+	}
+
+	if (subcmd < MP_NULL) {
+#ifdef CONFIG_MP_INCLUDED
+		rtw_priv_mp_get(dev, info, wdata, extra);
+#endif
+		return 0;
+	}
+
+	switch (subcmd) {
+#if defined(CONFIG_RTL8723B)
+	case MP_SetBT:
+		RTW_INFO("set MP_SetBT\n");
+		rtw_mp_SetBT(dev, info, wdata, extra);
+		break;
+#endif
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+	case MP_SD_IREAD:
+		rtw_mp_sd_iread(dev, info, wrqu, extra);
+		break;
+	case MP_SD_IWRITE:
+		rtw_mp_sd_iwrite(dev, info, wrqu, extra);
+		break;
+#endif
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	case VENDOR_IE_GET:
+		RTW_INFO("get case VENDOR_IE_GET\n");
+		rtw_vendor_ie_get(dev , info , wdata , extra);
+		break;
+#endif
+	default:
+		return -EIO;
+	}
+
+	rtw_msleep_os(10); /* delay 5ms for sending pkt before exit adb shell operation */
+	return 0;
+}
+
+
+
+static int rtw_wx_tdls_wfd_enable(struct net_device *dev,
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_WFD
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (extra[0] == '0')
+		rtw_tdls_wfd_enable(padapter, 0);
+	else
+		rtw_tdls_wfd_enable(padapter, 1);
+
+#endif /* CONFIG_WFD */
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_weaksec(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	u8 i, j;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (extra[0] == '0')
+		padapter->wdinfo.wfd_tdls_weaksec = 0;
+	else
+		padapter->wdinfo.wfd_tdls_weaksec = 1;
+
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+
+static int rtw_tdls_enable(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (extra[0] == '0')
+		rtw_disable_tdls_func(padapter, _TRUE);
+	else if (extra[0] == '1')
+		rtw_enable_tdls_func(padapter);
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_setup(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+#ifdef CONFIG_TDLS
+	u8 i, j;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_txmgmt txmgmt;
+#ifdef CONFIG_WFD
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_WFD */
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (wrqu->data.length - 1 != 17) {
+		RTW_INFO("[%s] length:%d != 17\n", __FUNCTION__, (wrqu->data.length - 1));
+		return ret;
+	}
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		txmgmt.peer[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+
+#ifdef CONFIG_WFD
+	if (_AES_ != padapter->securitypriv.dot11PrivacyAlgrthm) {
+		/* Weak Security situation with AP. */
+		if (0 == pwdinfo->wfd_tdls_weaksec)	{
+			/* Can't send the tdls setup request out!! */
+			RTW_INFO("[%s] Current link is not AES, "
+				"SKIP sending the tdls setup request!!\n", __FUNCTION__);
+		} else
+			issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+	} else
+#endif /* CONFIG_WFD */
+	{
+		issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+	}
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_teardown(struct net_device *dev,
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	u8 i, j;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_info *ptdls_sta = NULL;
+	struct tdls_txmgmt txmgmt;
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (wrqu->data.length - 1 != 17 && wrqu->data.length - 1 != 19) {
+		RTW_INFO("[%s] length:%d != 17 or 19\n",
+			 __FUNCTION__, (wrqu->data.length - 1));
+		return ret;
+	}
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	for (i = 0, j = 0; i < ETH_ALEN; i++, j += 3)
+		txmgmt.peer[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+
+	ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), txmgmt.peer);
+
+	if (ptdls_sta != NULL) {
+		txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
+		if (wrqu->data.length - 1 == 19)
+			issue_tdls_teardown(padapter, &txmgmt, _FALSE);
+		else
+			issue_tdls_teardown(padapter, &txmgmt, _TRUE);
+	} else
+		RTW_INFO("TDLS peer not found\n");
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_discovery(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_txmgmt	txmgmt;
+	int i = 0, j = 0;
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		txmgmt.peer[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+
+	issue_tdls_dis_req(padapter, &txmgmt);
+
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_ch_switch(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+	u8 i, j;
+	struct sta_info *ptdls_sta = NULL;
+	u8 take_care_iqk;
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("TDLS channel switch is not allowed\n");
+		return ret;
+	}
+
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		pchsw_info->addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+
+	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pchsw_info->addr);
+	if (ptdls_sta == NULL)
+		return ret;
+
+	pchsw_info->ch_sw_state |= TDLS_CH_SW_INITIATOR_STATE;
+
+	if (ptdls_sta != NULL) {
+		if (pchsw_info->off_ch_num == 0)
+			pchsw_info->off_ch_num = 11;
+	} else
+		RTW_INFO("TDLS peer not found\n");
+
+	rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
+	if (take_care_iqk == _TRUE) {
+		u8 central_chnl;
+		u8 bw_mode;
+
+		bw_mode = (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20;
+		central_chnl = rtw_get_center_ch(pchsw_info->off_ch_num, bw_mode, pchsw_info->ch_offset);
+		if (rtw_hal_ch_sw_iqk_info_search(padapter, central_chnl, bw_mode) >= 0)
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
+		else
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_PREPARE);
+	} else
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
+
+	/* issue_tdls_ch_switch_req(padapter, ptdls_sta); */
+	/* RTW_INFO("issue tdls ch switch req\n"); */
+
+#endif /* CONFIG_TDLS_CH_SW */
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_ch_switch_off(struct net_device *dev,
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+	u8 i, j, mac_addr[ETH_ALEN];
+	struct sta_info *ptdls_sta = NULL;
+	struct tdls_txmgmt txmgmt;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("TDLS channel switch is not allowed\n");
+		return ret;
+	}
+
+	if (wrqu->data.length >= 17) {
+		for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+			mac_addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+		ptdls_sta = rtw_get_stainfo(&padapter->stapriv, mac_addr);
+	}
+
+	if (ptdls_sta == NULL)
+		return ret;
+
+	rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END_TO_BASE_CHNL);
+
+	pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE |
+				     TDLS_CH_SWITCH_ON_STATE |
+				     TDLS_PEER_AT_OFF_STATE);
+	_rtw_memset(pchsw_info->addr, 0x00, ETH_ALEN);
+
+	ptdls_sta->ch_switch_time = 0;
+	ptdls_sta->ch_switch_timeout = 0;
+	_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
+	_cancel_timer_ex(&ptdls_sta->delay_timer);
+	_cancel_timer_ex(&ptdls_sta->stay_on_base_chnl_timer);
+	_cancel_timer_ex(&ptdls_sta->ch_sw_monitor_timer);
+
+	rtw_pm_set_lps(padapter, PS_MODE_MAX);
+#endif /* CONFIG_TDLS_CH_SW */
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_dump_ch(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	RTW_INFO("[%s] dump_stack:%s\n", __FUNCTION__, extra);
+
+	extra[wrqu->data.length] = 0x00;
+	ptdlsinfo->chsw_info.dump_stack = rtw_atoi(extra);
+
+	return ret;
+
+#endif
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_off_ch_num(struct net_device *dev,
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	RTW_INFO("[%s] off_ch_num:%s\n", __FUNCTION__, extra);
+
+	extra[wrqu->data.length] = 0x00;
+	ptdlsinfo->chsw_info.off_ch_num = rtw_atoi(extra);
+
+	return ret;
+
+#endif
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_ch_offset(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	RTW_INFO("[%s] ch_offset:%s\n", __FUNCTION__, extra);
+
+	extra[wrqu->data.length] = 0x00;
+	switch (rtw_atoi(extra)) {
+	case SCA:
+		ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+
+	case SCB:
+		ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+
+	default:
+		ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
+
+	return ret;
+
+#endif
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_pson(struct net_device *dev,
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 i, j, mac_addr[ETH_ALEN];
+	struct sta_info *ptdls_sta = NULL;
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	for (i = 0, j = 0; i < ETH_ALEN; i++, j += 3)
+		mac_addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+
+	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, mac_addr);
+
+	issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 1, 3, 500);
+
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_psoff(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 i, j, mac_addr[ETH_ALEN];
+	struct sta_info *ptdls_sta = NULL;
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	for (i = 0, j = 0; i < ETH_ALEN; i++, j += 3)
+		mac_addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+
+	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, mac_addr);
+
+	if (ptdls_sta)
+		issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 0, 3, 500);
+
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_setip(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_WFD
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct wifi_display_info *pwfd_info = ptdlsinfo->wfd_info;
+	u8 i = 0, j = 0, k = 0, tag = 0;
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	while (i < 4) {
+		for (j = 0; j < 4; j++) {
+			if (*(extra + j + tag) == '.' || *(extra + j + tag) == '\0') {
+				if (j == 1)
+					pwfd_info->ip_address[i] = convert_ip_addr('0', '0', *(extra + (j - 1) + tag));
+				if (j == 2)
+					pwfd_info->ip_address[i] = convert_ip_addr('0', *(extra + (j - 2) + tag), *(extra + (j - 1) + tag));
+				if (j == 3)
+					pwfd_info->ip_address[i] = convert_ip_addr(*(extra + (j - 3) + tag), *(extra + (j - 2) + tag), *(extra + (j - 1) + tag));
+
+				tag += j + 1;
+				break;
+			}
+		}
+		i++;
+	}
+
+	RTW_INFO("[%s] Set IP = %u.%u.%u.%u\n", __FUNCTION__,
+		 ptdlsinfo->wfd_info->ip_address[0],
+		 ptdlsinfo->wfd_info->ip_address[1],
+		 ptdlsinfo->wfd_info->ip_address[2],
+		 ptdlsinfo->wfd_info->ip_address[3]);
+
+#endif /* CONFIG_WFD */
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_getip(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_WFD
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct wifi_display_info *pwfd_info = ptdlsinfo->wfd_info;
+
+	RTW_INFO("[%s]\n", __FUNCTION__);
+
+	sprintf(extra, "\n\n%u.%u.%u.%u\n",
+		pwfd_info->peer_ip_address[0], pwfd_info->peer_ip_address[1],
+		pwfd_info->peer_ip_address[2], pwfd_info->peer_ip_address[3]);
+
+	RTW_INFO("[%s] IP=%u.%u.%u.%u\n", __FUNCTION__,
+		 pwfd_info->peer_ip_address[0], pwfd_info->peer_ip_address[1],
+		 pwfd_info->peer_ip_address[2], pwfd_info->peer_ip_address[3]);
+
+	wrqu->data.length = strlen(extra);
+
+#endif /* CONFIG_WFD */
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+static int rtw_tdls_getport(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_WFD
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct wifi_display_info *pwfd_info = ptdlsinfo->wfd_info;
+
+	RTW_INFO("[%s]\n", __FUNCTION__);
+
+	sprintf(extra, "\n\n%d\n", pwfd_info->peer_rtsp_ctrlport);
+	RTW_INFO("[%s] remote port = %d\n",
+		 __FUNCTION__, pwfd_info->peer_rtsp_ctrlport);
+
+	wrqu->data.length = strlen(extra);
+
+#endif /* CONFIG_WFD */
+#endif /* CONFIG_TDLS */
+
+	return ret;
+
+}
+
+/* WFDTDLS, for sigma test */
+static int rtw_tdls_dis_result(struct net_device *dev,
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_WFD
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	RTW_INFO("[%s]\n", __FUNCTION__);
+
+	if (ptdlsinfo->dev_discovered == _TRUE) {
+		sprintf(extra, "\n\nDis=1\n");
+		ptdlsinfo->dev_discovered = _FALSE;
+	}
+
+	wrqu->data.length = strlen(extra);
+
+#endif /* CONFIG_WFD */
+#endif /* CONFIG_TDLS */
+
+	return ret;
+
+}
+
+/* WFDTDLS, for sigma test */
+static int rtw_wfd_tdls_status(struct net_device *dev,
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	RTW_INFO("[%s]\n", __FUNCTION__);
+
+	sprintf(extra, "\nlink_established:%d\n"
+		"sta_cnt:%d\n"
+		"sta_maximum:%d\n"
+		"cur_channel:%d\n"
+		"tdls_enable:%d"
+#ifdef CONFIG_TDLS_CH_SW
+		"ch_sw_state:%08x\n"
+		"chsw_on:%d\n"
+		"off_ch_num:%d\n"
+		"cur_time:%d\n"
+		"ch_offset:%d\n"
+		"delay_swtich_back:%d"
+#endif
+		,
+		ptdlsinfo->link_established, ptdlsinfo->sta_cnt,
+		ptdlsinfo->sta_maximum, ptdlsinfo->cur_channel,
+		rtw_is_tdls_enabled(padapter)
+#ifdef CONFIG_TDLS_CH_SW
+		,
+		ptdlsinfo->chsw_info.ch_sw_state,
+		ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on),
+		ptdlsinfo->chsw_info.off_ch_num,
+		ptdlsinfo->chsw_info.cur_time,
+		ptdlsinfo->chsw_info.ch_offset,
+		ptdlsinfo->chsw_info.delay_switch_back
+#endif
+	       );
+
+	wrqu->data.length = strlen(extra);
+
+#endif /* CONFIG_TDLS */
+
+	return ret;
+
+}
+
+static int rtw_tdls_getsta(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+#ifdef CONFIG_TDLS
+	u8 i, j;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 addr[ETH_ALEN] = {0};
+	char charmac[17];
+	struct sta_info *ptdls_sta = NULL;
+
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__,
+		 (char *)wrqu->data.pointer, wrqu->data.length - 1);
+
+	if (copy_from_user(charmac, wrqu->data.pointer + 9, 17)) {
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	RTW_INFO("[%s] %d, charmac:%s\n", __FUNCTION__, __LINE__, charmac);
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		addr[i] = key_2char2num(*(charmac + j), *(charmac + j + 1));
+
+	RTW_INFO("[%s] %d, charmac:%s, addr:"MAC_FMT"\n",
+		 __FUNCTION__, __LINE__, charmac, MAC_ARG(addr));
+	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, addr);
+	if (ptdls_sta) {
+		sprintf(extra, "\n\ntdls_sta_state=0x%08x\n", ptdls_sta->tdls_sta_state);
+		RTW_INFO("\n\ntdls_sta_state=%d\n", ptdls_sta->tdls_sta_state);
+	} else {
+		sprintf(extra, "\n\nNot found this sta\n");
+		RTW_INFO("\n\nNot found this sta\n");
+	}
+	wrqu->data.length = strlen(extra);
+
+#endif /* CONFIG_TDLS */
+exit:
+	return ret;
+
+}
+
+static int rtw_tdls_get_best_ch(struct net_device *dev,
+				struct iw_request_info *info,
+				union iwreq_data *wrqu, char *extra)
+{
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	u32 i, best_channel_24G = 1, best_channel_5G = 36, index_24G = 0, index_5G = 0;
+
+	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
+		if (rfctl->channel_set[i].ChannelNum == 1)
+			index_24G = i;
+		if (rfctl->channel_set[i].ChannelNum == 36)
+			index_5G = i;
+	}
+
+	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
+		/* 2.4G */
+		if (rfctl->channel_set[i].ChannelNum == 6 || rfctl->channel_set[i].ChannelNum == 11) {
+			if (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_24G].rx_count) {
+				index_24G = i;
+				best_channel_24G = rfctl->channel_set[i].ChannelNum;
+			}
+		}
+
+		/* 5G */
+		if (rfctl->channel_set[i].ChannelNum >= 36
+		    && rfctl->channel_set[i].ChannelNum < 140) {
+			/* Find primary channel */
+			if (((rfctl->channel_set[i].ChannelNum - 36) % 8 == 0)
+			    && (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
+				index_5G = i;
+				best_channel_5G = rfctl->channel_set[i].ChannelNum;
+			}
+		}
+
+		if (rfctl->channel_set[i].ChannelNum >= 149
+		    && rfctl->channel_set[i].ChannelNum < 165) {
+			/* Find primary channel */
+			if (((rfctl->channel_set[i].ChannelNum - 149) % 8 == 0)
+			    && (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
+				index_5G = i;
+				best_channel_5G = rfctl->channel_set[i].ChannelNum;
+			}
+		}
+#if 1 /* debug */
+		RTW_INFO("The rx cnt of channel %3d = %d\n",
+			 rfctl->channel_set[i].ChannelNum,
+			 rfctl->channel_set[i].rx_count);
+#endif
+	}
+
+	sprintf(extra, "\nbest_channel_24G = %d\n", best_channel_24G);
+	RTW_INFO("best_channel_24G = %d\n", best_channel_24G);
+
+	if (index_5G != 0) {
+		sprintf(extra, "best_channel_5G = %d\n", best_channel_5G);
+		RTW_INFO("best_channel_5G = %d\n", best_channel_5G);
+	}
+
+	wrqu->data.length = strlen(extra);
+
+#endif
+
+	return 0;
+
+}
+
+static int rtw_tdls(struct net_device *dev,
+		    struct iw_request_info *info,
+		    union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, extra);
+
+	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
+		RTW_INFO("Discard tdls oper since hal doesn't support tdls\n");
+		return 0;
+	}
+
+	if (rtw_is_tdls_enabled(padapter) == _FALSE) {
+		RTW_INFO("TDLS is not enabled\n");
+		return 0;
+	}
+
+	/* WFD Sigma will use the tdls enable command to let the driver know we want to test the tdls now! */
+
+	if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
+		if (_rtw_memcmp(extra, "wfdenable=", 10)) {
+			wrqu->data.length -= 10;
+			rtw_wx_tdls_wfd_enable(dev, info, wrqu, &extra[10]);
+			return ret;
+		}
+	}
+
+	if (_rtw_memcmp(extra, "weaksec=", 8)) {
+		wrqu->data.length -= 8;
+		rtw_tdls_weaksec(dev, info, wrqu, &extra[8]);
+		return ret;
+	} else if (_rtw_memcmp(extra, "tdlsenable=", 11)) {
+		wrqu->data.length -= 11;
+		rtw_tdls_enable(dev, info, wrqu, &extra[11]);
+		return ret;
+	}
+
+	if (_rtw_memcmp(extra, "setup=", 6)) {
+		wrqu->data.length -= 6;
+		rtw_tdls_setup(dev, info, wrqu, &extra[6]);
+	} else if (_rtw_memcmp(extra, "tear=", 5)) {
+		wrqu->data.length -= 5;
+		rtw_tdls_teardown(dev, info, wrqu, &extra[5]);
+	} else if (_rtw_memcmp(extra, "dis=", 4)) {
+		wrqu->data.length -= 4;
+		rtw_tdls_discovery(dev, info, wrqu, &extra[4]);
+	} else if (_rtw_memcmp(extra, "swoff=", 6)) {
+		wrqu->data.length -= 6;
+		rtw_tdls_ch_switch_off(dev, info, wrqu, &extra[6]);
+	} else if (_rtw_memcmp(extra, "sw=", 3)) {
+		wrqu->data.length -= 3;
+		rtw_tdls_ch_switch(dev, info, wrqu, &extra[3]);
+	} else if (_rtw_memcmp(extra, "dumpstack=", 10)) {
+		wrqu->data.length -= 10;
+		rtw_tdls_dump_ch(dev, info, wrqu, &extra[10]);
+	} else if (_rtw_memcmp(extra, "offchnum=", 9)) {
+		wrqu->data.length -= 9;
+		rtw_tdls_off_ch_num(dev, info, wrqu, &extra[9]);
+	} else if (_rtw_memcmp(extra, "choffset=", 9)) {
+		wrqu->data.length -= 9;
+		rtw_tdls_ch_offset(dev, info, wrqu, &extra[9]);
+	} else if (_rtw_memcmp(extra, "pson=", 5)) {
+		wrqu->data.length -= 5;
+		rtw_tdls_pson(dev, info, wrqu, &extra[5]);
+	} else if (_rtw_memcmp(extra, "psoff=", 6)) {
+		wrqu->data.length -= 6;
+		rtw_tdls_psoff(dev, info, wrqu, &extra[6]);
+	}
+
+#ifdef CONFIG_WFD
+	if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
+		if (_rtw_memcmp(extra, "setip=", 6)) {
+			wrqu->data.length -= 6;
+			rtw_tdls_setip(dev, info, wrqu, &extra[6]);
+		} else if (_rtw_memcmp(extra, "tprobe=", 6))
+			issue_tunneled_probe_req((_adapter *)rtw_netdev_priv(dev));
+	}
+#endif /* CONFIG_WFD */
+
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+
+static int rtw_tdls_get(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+
+#ifdef CONFIG_TDLS
+
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, (char *) wrqu->data.pointer);
+
+	if (_rtw_memcmp(wrqu->data.pointer, "ip", 2))
+		rtw_tdls_getip(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "port", 4))
+		rtw_tdls_getport(dev, info, wrqu, extra);
+	/* WFDTDLS, for sigma test */
+	else if (_rtw_memcmp(wrqu->data.pointer, "dis", 3))
+		rtw_tdls_dis_result(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "status", 6))
+		rtw_wfd_tdls_status(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "tdls_sta=", 9))
+		rtw_tdls_getsta(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "best_ch", 7))
+		rtw_tdls_get_best_ch(dev, info, wrqu, extra);
+#endif /* CONFIG_TDLS */
+
+	return ret;
+}
+
+
+
+
+
+#ifdef CONFIG_INTEL_WIDI
+static int rtw_widi_set(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	process_intel_widi_cmd(padapter, extra);
+
+	return ret;
+}
+
+static int rtw_widi_set_probe_request(struct net_device *dev,
+				      struct iw_request_info *info,
+				      union iwreq_data *wrqu, char *extra)
+{
+	int	ret = 0;
+	u8	*pbuf = NULL;
+	_adapter	*padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	pbuf = rtw_malloc(sizeof(l2_msg_t));
+	if (pbuf) {
+		if (copy_from_user(pbuf, wrqu->data.pointer, wrqu->data.length))
+			ret = -EFAULT;
+		/* _rtw_memcpy(pbuf, wrqu->data.pointer, wrqu->data.length); */
+
+		if (wrqu->data.flags == 0)
+			intel_widi_wk_cmd(padapter, INTEL_WIDI_ISSUE_PROB_WK, pbuf, sizeof(l2_msg_t));
+		else if (wrqu->data.flags == 1)
+			rtw_set_wfd_rds_sink_info(padapter, (l2_msg_t *)pbuf);
+	}
+	return ret;
+}
+#endif /* CONFIG_INTEL_WIDI */
+
+#ifdef CONFIG_MAC_LOOPBACK_DRIVER
+
+#if defined(CONFIG_RTL8188E)
+#include <rtl8188e_hal.h>
+extern void rtl8188e_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+#define cal_txdesc_chksum rtl8188e_cal_txdesc_chksum
+#ifdef CONFIG_SDIO_HCI || defined(CONFIG_GSPI_HCI)
+extern void rtl8188es_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf);
+#define fill_default_txdesc rtl8188es_fill_default_txdesc
+#endif /* CONFIG_SDIO_HCI */
+#endif /* CONFIG_RTL8188E */
+#if defined(CONFIG_RTL8723B)
+extern void rtl8723b_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+#define cal_txdesc_chksum rtl8723b_cal_txdesc_chksum
+extern void rtl8723b_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf);
+#define fill_default_txdesc rtl8723b_fill_default_txdesc
+#endif /* CONFIG_RTL8723B */
+
+#if defined(CONFIG_RTL8703B)
+/* extern void rtl8703b_cal_txdesc_chksum(struct tx_desc *ptxdesc); */
+#define cal_txdesc_chksum rtl8703b_cal_txdesc_chksum
+/* extern void rtl8703b_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf); */
+#define fill_default_txdesc rtl8703b_fill_default_txdesc
+#endif /* CONFIG_RTL8703B */
+
+#if defined(CONFIG_RTL8723D)
+/* extern void rtl8723d_cal_txdesc_chksum(struct tx_desc *ptxdesc); */
+#define cal_txdesc_chksum rtl8723d_cal_txdesc_chksum
+/* extern void rtl8723d_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf); */
+#define fill_default_txdesc rtl8723d_fill_default_txdesc
+#endif /* CONFIG_RTL8723D */
+
+#if defined(CONFIG_RTL8192E)
+extern void rtl8192e_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+#define cal_txdesc_chksum rtl8192e_cal_txdesc_chksum
+#ifdef CONFIG_SDIO_HCI || defined(CONFIG_GSPI_HCI)
+extern void rtl8192es_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf);
+#define fill_default_txdesc rtl8192es_fill_default_txdesc
+#endif /* CONFIG_SDIO_HCI */
+#endif /* CONFIG_RTL8192E */
+
+static s32 initLoopback(PADAPTER padapter)
+{
+	PLOOPBACKDATA ploopback;
+
+
+	if (padapter->ploopback == NULL) {
+		ploopback = (PLOOPBACKDATA)rtw_zmalloc(sizeof(LOOPBACKDATA));
+		if (ploopback == NULL)
+			return -ENOMEM;
+
+		_rtw_init_sema(&ploopback->sema, 0);
+		ploopback->bstop = _TRUE;
+		ploopback->cnt = 0;
+		ploopback->size = 300;
+		_rtw_memset(ploopback->msg, 0, sizeof(ploopback->msg));
+
+		padapter->ploopback = ploopback;
+	}
+
+	return 0;
+}
+
+static void freeLoopback(PADAPTER padapter)
+{
+	PLOOPBACKDATA ploopback;
+
+
+	ploopback = padapter->ploopback;
+	if (ploopback) {
+		rtw_mfree((u8 *)ploopback, sizeof(LOOPBACKDATA));
+		padapter->ploopback = NULL;
+	}
+}
+
+static s32 initpseudoadhoc(PADAPTER padapter)
+{
+	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType;
+	s32 err;
+
+	networkType = Ndis802_11IBSS;
+	err = rtw_set_802_11_infrastructure_mode(padapter, networkType);
+	if (err == _FALSE)
+		return _FAIL;
+
+	err = rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
+	if (err == _FAIL)
+		return _FAIL;
+
+	return _SUCCESS;
+}
+
+static s32 createpseudoadhoc(PADAPTER padapter)
+{
+	NDIS_802_11_AUTHENTICATION_MODE authmode;
+	struct mlme_priv *pmlmepriv;
+	NDIS_802_11_SSID *passoc_ssid;
+	WLAN_BSSID_EX *pdev_network;
+	u8 *pibss;
+	u8 ssid[] = "pseduo_ad-hoc";
+	s32 err;
+	_irqL irqL;
+
+
+	pmlmepriv = &padapter->mlmepriv;
+
+	authmode = Ndis802_11AuthModeOpen;
+	err = rtw_set_802_11_authentication_mode(padapter, authmode);
+	if (err == _FALSE)
+		return _FAIL;
+
+	passoc_ssid = &pmlmepriv->assoc_ssid;
+	_rtw_memset(passoc_ssid, 0, sizeof(NDIS_802_11_SSID));
+	passoc_ssid->SsidLength = sizeof(ssid) - 1;
+	_rtw_memcpy(passoc_ssid->Ssid, ssid, passoc_ssid->SsidLength);
+
+	pdev_network = &padapter->registrypriv.dev_network;
+	pibss = padapter->registrypriv.dev_network.MacAddress;
+	_rtw_memcpy(&pdev_network->Ssid, passoc_ssid, sizeof(NDIS_802_11_SSID));
+
+	rtw_update_registrypriv_dev_network(padapter);
+	rtw_generate_random_ibss(pibss);
+
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	/*pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;*/
+	init_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
+
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+
+#if 0
+	err = rtw_create_ibss_cmd(padapter, 0);
+	if (err == _FAIL)
+		return _FAIL;
+#else
+	{
+		struct wlan_network *pcur_network;
+		struct sta_info *psta;
+
+		/* 3  create a new psta */
+		pcur_network = &pmlmepriv->cur_network;
+
+		/* clear psta in the cur_network, if any */
+		psta = rtw_get_stainfo(&padapter->stapriv, pcur_network->network.MacAddress);
+		if (psta)
+			rtw_free_stainfo(padapter, psta);
+
+		psta = rtw_alloc_stainfo(&padapter->stapriv, pibss);
+		if (psta == NULL)
+			return _FAIL;
+
+		/* 3  join psudo AdHoc */
+		pcur_network->join_res = 1;
+		pcur_network->aid = psta->cmn.aid = 1;
+		_rtw_memcpy(&pcur_network->network, pdev_network, get_WLAN_BSSID_EX_sz(pdev_network));
+
+		/* set msr to WIFI_FW_ADHOC_STATE */
+		padapter->hw_port = HW_PORT0;
+		Set_MSR(padapter, WIFI_FW_ADHOC_STATE);
+
+	}
+#endif
+
+	return _SUCCESS;
+}
+
+static struct xmit_frame *createloopbackpkt(PADAPTER padapter, u32 size)
+{
+	struct xmit_priv *pxmitpriv;
+	struct xmit_frame *pframe;
+	struct xmit_buf *pxmitbuf;
+	struct pkt_attrib *pattrib;
+	struct tx_desc *desc;
+	u8 *pkt_start, *pkt_end, *ptr;
+	struct rtw_ieee80211_hdr *hdr;
+	s32 bmcast;
+	_irqL irqL;
+
+
+	if ((TXDESC_SIZE + WLANHDR_OFFSET + size) > MAX_XMITBUF_SZ)
+		return NULL;
+
+	pxmitpriv = &padapter->xmitpriv;
+	pframe = NULL;
+
+	/* 2 1. allocate xmit frame */
+	pframe = rtw_alloc_xmitframe(pxmitpriv);
+	if (pframe == NULL)
+		return NULL;
+	pframe->padapter = padapter;
+
+	/* 2 2. allocate xmit buffer */
+	_enter_critical_bh(&pxmitpriv->lock, &irqL);
+	pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
+	_exit_critical_bh(&pxmitpriv->lock, &irqL);
+	if (pxmitbuf == NULL) {
+		rtw_free_xmitframe(pxmitpriv, pframe);
+		return NULL;
+	}
+
+	pframe->pxmitbuf = pxmitbuf;
+	pframe->buf_addr = pxmitbuf->pbuf;
+	pxmitbuf->priv_data = pframe;
+
+	/* 2 3. update_attrib() */
+	pattrib = &pframe->attrib;
+
+	/* init xmitframe attribute */
+	_rtw_memset(pattrib, 0, sizeof(struct pkt_attrib));
+
+	pattrib->ether_type = 0x8723;
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+	_rtw_memset(pattrib->dst, 0xFF, ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
+
+	/*	pattrib->dhcp_pkt = 0;
+	 *	pattrib->pktlen = 0; */
+	pattrib->ack_policy = 0;
+	/*	pattrib->pkt_hdrlen = ETH_HLEN; */
+	pattrib->hdrlen = WLAN_HDR_A3_LEN;
+	pattrib->subtype = WIFI_DATA;
+	pattrib->priority = 0;
+	pattrib->qsel = pattrib->priority;
+	/*	do_queue_select(padapter, pattrib); */
+	pattrib->nr_frags = 1;
+	pattrib->encrypt = 0;
+	pattrib->bswenc = _FALSE;
+	pattrib->qos_en = _FALSE;
+
+	bmcast = IS_MCAST(pattrib->ra);
+	if (bmcast)
+		pattrib->psta = rtw_get_bcmc_stainfo(padapter);
+	else
+		pattrib->psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
+
+	pattrib->mac_id = pattrib->psta->cmn.mac_id;
+	pattrib->pktlen = size;
+	pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->pktlen;
+
+	/* 2 4. fill TX descriptor */
+	desc = (struct tx_desc *)pframe->buf_addr;
+	_rtw_memset(desc, 0, TXDESC_SIZE);
+
+	fill_default_txdesc(pframe, (u8 *)desc);
+
+	/* Hw set sequence number */
+	((PTXDESC)desc)->hwseq_en = 0; /* HWSEQ_EN, 0:disable, 1:enable
+ * ((PTXDESC)desc)->hwseq_sel = 0;  */ /* HWSEQ_SEL */
+
+	((PTXDESC)desc)->disdatafb = 1;
+
+	/* convert to little endian */
+	desc->txdw0 = cpu_to_le32(desc->txdw0);
+	desc->txdw1 = cpu_to_le32(desc->txdw1);
+	desc->txdw2 = cpu_to_le32(desc->txdw2);
+	desc->txdw3 = cpu_to_le32(desc->txdw3);
+	desc->txdw4 = cpu_to_le32(desc->txdw4);
+	desc->txdw5 = cpu_to_le32(desc->txdw5);
+	desc->txdw6 = cpu_to_le32(desc->txdw6);
+	desc->txdw7 = cpu_to_le32(desc->txdw7);
+#ifdef CONFIG_PCI_HCI
+	desc->txdw8 = cpu_to_le32(desc->txdw8);
+	desc->txdw9 = cpu_to_le32(desc->txdw9);
+	desc->txdw10 = cpu_to_le32(desc->txdw10);
+	desc->txdw11 = cpu_to_le32(desc->txdw11);
+	desc->txdw12 = cpu_to_le32(desc->txdw12);
+	desc->txdw13 = cpu_to_le32(desc->txdw13);
+	desc->txdw14 = cpu_to_le32(desc->txdw14);
+	desc->txdw15 = cpu_to_le32(desc->txdw15);
+#endif
+
+	cal_txdesc_chksum(desc);
+
+	/* 2 5. coalesce */
+	pkt_start = pframe->buf_addr + TXDESC_SIZE;
+	pkt_end = pkt_start + pattrib->last_txcmdsz;
+
+	/* 3 5.1. make wlan header, make_wlanhdr() */
+	hdr = (struct rtw_ieee80211_hdr *)pkt_start;
+	set_frame_sub_type(&hdr->frame_ctl, pattrib->subtype);
+	_rtw_memcpy(hdr->addr1, pattrib->dst, ETH_ALEN); /* DA */
+	_rtw_memcpy(hdr->addr2, pattrib->src, ETH_ALEN); /* SA */
+	_rtw_memcpy(hdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN); /* RA, BSSID */
+
+	/* 3 5.2. make payload */
+	ptr = pkt_start + pattrib->hdrlen;
+	get_random_bytes(ptr, pkt_end - ptr);
+
+	pxmitbuf->len = TXDESC_SIZE + pattrib->last_txcmdsz;
+	pxmitbuf->ptail += pxmitbuf->len;
+
+	return pframe;
+}
+
+static void freeloopbackpkt(PADAPTER padapter, struct xmit_frame *pframe)
+{
+	struct xmit_priv *pxmitpriv;
+	struct xmit_buf *pxmitbuf;
+
+
+	pxmitpriv = &padapter->xmitpriv;
+	pxmitbuf = pframe->pxmitbuf;
+
+	rtw_free_xmitframe(pxmitpriv, pframe);
+	rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
+}
+
+static void printdata(u8 *pbuf, u32 len)
+{
+	u32 i, val;
+
+
+	for (i = 0; (i + 4) <= len; i += 4) {
+		printk("%08X", *(u32 *)(pbuf + i));
+		if ((i + 4) & 0x1F)
+			printk(" ");
+		else
+			printk("\n");
+	}
+
+	if (i < len) {
+#ifdef CONFIG_BIG_ENDIAN
+		for (; i < len, i++)
+			printk("%02X", pbuf + i);
+#else /* CONFIG_LITTLE_ENDIAN */
+#if 0
+		val = 0;
+		_rtw_memcpy(&val, pbuf + i, len - i);
+		printk("%8X", val);
+#else
+		u8 str[9];
+		u8 n;
+		val = 0;
+		n = len - i;
+		_rtw_memcpy(&val, pbuf + i, n);
+		sprintf(str, "%08X", val);
+		n = (4 - n) * 2;
+		printk("%8s", str + n);
+#endif
+#endif /* CONFIG_LITTLE_ENDIAN */
+	}
+	printk("\n");
+}
+
+static u8 pktcmp(PADAPTER padapter, u8 *txbuf, u32 txsz, u8 *rxbuf, u32 rxsz)
+{
+	PHAL_DATA_TYPE phal;
+	struct recv_stat *prxstat;
+	struct recv_stat report;
+	PRXREPORT prxreport;
+	u32 drvinfosize;
+	u32 rxpktsize;
+	u8 fcssize;
+	u8 ret = _FALSE;
+
+	prxstat = (struct recv_stat *)rxbuf;
+	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 = (PRXREPORT)&report;
+	drvinfosize = prxreport->drvinfosize << 3;
+	rxpktsize = prxreport->pktlen;
+
+	phal = GET_HAL_DATA(padapter);
+	if (rtw_hal_rcr_check(padapter, RCR_APPFCS))
+		fcssize = IEEE80211_FCS_LEN;
+	else
+		fcssize = 0;
+
+	if ((txsz - TXDESC_SIZE) != (rxpktsize - fcssize)) {
+		RTW_INFO("%s: ERROR! size not match tx/rx=%d/%d !\n",
+			 __func__, txsz - TXDESC_SIZE, rxpktsize - fcssize);
+		ret = _FALSE;
+	} else {
+		ret = _rtw_memcmp(txbuf + TXDESC_SIZE, \
+				  rxbuf + RXDESC_SIZE + drvinfosize, \
+				  txsz - TXDESC_SIZE);
+		if (ret == _FALSE)
+			RTW_INFO("%s: ERROR! pkt content mismatch!\n", __func__);
+	}
+
+	if (ret == _FALSE) {
+		RTW_INFO("\n%s: TX PKT total=%d, desc=%d, content=%d\n",
+			 __func__, txsz, TXDESC_SIZE, txsz - TXDESC_SIZE);
+		RTW_INFO("%s: TX DESC size=%d\n", __func__, TXDESC_SIZE);
+		printdata(txbuf, TXDESC_SIZE);
+		RTW_INFO("%s: TX content size=%d\n", __func__, txsz - TXDESC_SIZE);
+		printdata(txbuf + TXDESC_SIZE, txsz - TXDESC_SIZE);
+
+		RTW_INFO("\n%s: RX PKT read=%d offset=%d(%d,%d) content=%d\n",
+			__func__, rxsz, RXDESC_SIZE + drvinfosize, RXDESC_SIZE, drvinfosize, rxpktsize);
+		if (rxpktsize != 0) {
+			RTW_INFO("%s: RX DESC size=%d\n", __func__, RXDESC_SIZE);
+			printdata(rxbuf, RXDESC_SIZE);
+			RTW_INFO("%s: RX drvinfo size=%d\n", __func__, drvinfosize);
+			printdata(rxbuf + RXDESC_SIZE, drvinfosize);
+			RTW_INFO("%s: RX content size=%d\n", __func__, rxpktsize);
+			printdata(rxbuf + RXDESC_SIZE + drvinfosize, rxpktsize);
+		} else {
+			RTW_INFO("%s: RX data size=%d\n", __func__, rxsz);
+			printdata(rxbuf, rxsz);
+		}
+	}
+
+	return ret;
+}
+
+thread_return lbk_thread(thread_context context)
+{
+	s32 err;
+	PADAPTER padapter;
+	PLOOPBACKDATA ploopback;
+	struct xmit_frame *pxmitframe;
+	u32 cnt, ok, fail, headerlen;
+	u32 pktsize;
+	u32 ff_hwaddr;
+
+
+	padapter = (PADAPTER)context;
+	ploopback = padapter->ploopback;
+	if (ploopback == NULL)
+		return -1;
+	cnt = 0;
+	ok = 0;
+	fail = 0;
+
+	daemonize("%s", "RTW_LBK_THREAD");
+	allow_signal(SIGTERM);
+
+	do {
+		if (ploopback->size == 0) {
+			get_random_bytes(&pktsize, 4);
+			pktsize = (pktsize % 1535) + 1; /* 1~1535 */
+		} else
+			pktsize = ploopback->size;
+
+		pxmitframe = createloopbackpkt(padapter, pktsize);
+		if (pxmitframe == NULL) {
+			sprintf(ploopback->msg, "loopback FAIL! 3. create Packet FAIL!");
+			break;
+		}
+
+		ploopback->txsize = TXDESC_SIZE + pxmitframe->attrib.last_txcmdsz;
+		_rtw_memcpy(ploopback->txbuf, pxmitframe->buf_addr, ploopback->txsize);
+		ff_hwaddr = rtw_get_ff_hwaddr(pxmitframe);
+		cnt++;
+		RTW_INFO("%s: wirte port cnt=%d size=%d\n", __func__, cnt, ploopback->txsize);
+		pxmitframe->pxmitbuf->pdata = ploopback->txbuf;
+		rtw_write_port(padapter, ff_hwaddr, ploopback->txsize, (u8 *)pxmitframe->pxmitbuf);
+
+		/* wait for rx pkt */
+		_rtw_down_sema(&ploopback->sema);
+
+		err = pktcmp(padapter, ploopback->txbuf, ploopback->txsize, ploopback->rxbuf, ploopback->rxsize);
+		if (err == _TRUE)
+			ok++;
+		else
+			fail++;
+
+		ploopback->txsize = 0;
+		_rtw_memset(ploopback->txbuf, 0, 0x8000);
+		ploopback->rxsize = 0;
+		_rtw_memset(ploopback->rxbuf, 0, 0x8000);
+
+		freeloopbackpkt(padapter, pxmitframe);
+		pxmitframe = NULL;
+
+		flush_signals_thread();
+
+		if ((ploopback->bstop == _TRUE) ||
+		    ((ploopback->cnt != 0) && (ploopback->cnt == cnt))) {
+			u32 ok_rate, fail_rate, all;
+			all = cnt;
+			ok_rate = (ok * 100) / all;
+			fail_rate = (fail * 100) / all;
+			sprintf(ploopback->msg, \
+				"loopback result: ok=%d%%(%d/%d),error=%d%%(%d/%d)", \
+				ok_rate, ok, all, fail_rate, fail, all);
+			break;
+		}
+	} while (1);
+
+	ploopback->bstop = _TRUE;
+
+	thread_exit(NULL);
+	return 0;
+}
+
+static void loopbackTest(PADAPTER padapter, u32 cnt, u32 size, u8 *pmsg)
+{
+	PLOOPBACKDATA ploopback;
+	u32 len;
+	s32 err;
+
+
+	ploopback = padapter->ploopback;
+
+	if (ploopback) {
+		if (ploopback->bstop == _FALSE) {
+			ploopback->bstop = _TRUE;
+			_rtw_up_sema(&ploopback->sema);
+		}
+		len = 0;
+		do {
+			len = strlen(ploopback->msg);
+			if (len)
+				break;
+			rtw_msleep_os(1);
+		} while (1);
+		_rtw_memcpy(pmsg, ploopback->msg, len + 1);
+		freeLoopback(padapter);
+
+		return;
+	}
+
+	/* disable dynamic algorithm	 */
+	rtw_phydm_ability_backup(padapter);
+	rtw_phydm_func_disable_all(padapter);
+
+	/* create pseudo ad-hoc connection */
+	err = initpseudoadhoc(padapter);
+	if (err == _FAIL) {
+		sprintf(pmsg, "loopback FAIL! 1.1 init ad-hoc FAIL!");
+		return;
+	}
+
+	err = createpseudoadhoc(padapter);
+	if (err == _FAIL) {
+		sprintf(pmsg, "loopback FAIL! 1.2 create ad-hoc master FAIL!");
+		return;
+	}
+
+	err = initLoopback(padapter);
+	if (err) {
+		sprintf(pmsg, "loopback FAIL! 2. init FAIL! error code=%d", err);
+		return;
+	}
+
+	ploopback = padapter->ploopback;
+
+	ploopback->bstop = _FALSE;
+	ploopback->cnt = cnt;
+	ploopback->size = size;
+	ploopback->lbkthread = kthread_run(lbk_thread, padapter, "RTW_LBK_THREAD");
+	if (IS_ERR(padapter->lbkthread)) {
+		freeLoopback(padapter);
+		ploopback->lbkthread = NULL;
+		sprintf(pmsg, "loopback start FAIL! cnt=%d", cnt);
+		return;
+	}
+
+	sprintf(pmsg, "loopback start! cnt=%d", cnt);
+}
+#endif /* CONFIG_MAC_LOOPBACK_DRIVER */
+
+static int rtw_test(
+	struct net_device *dev,
+	struct iw_request_info *info,
+	union iwreq_data *wrqu, char *extra)
+{
+	u32 len;
+	u8 *pbuf, *pch;
+	char *ptmp;
+	u8 *delim = ",";
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+
+	RTW_INFO("+%s\n", __func__);
+	len = wrqu->data.length;
+
+	pbuf = (u8 *)rtw_zmalloc(len + 1);
+	if (pbuf == NULL) {
+		RTW_INFO("%s: no memory!\n", __func__);
+		return -ENOMEM;
+	}
+
+	if (copy_from_user(pbuf, wrqu->data.pointer, len)) {
+		rtw_mfree(pbuf, len + 1);
+		RTW_INFO("%s: copy from user fail!\n", __func__);
+		return -EFAULT;
+	}
+
+	pbuf[len] = '\0';
+
+	RTW_INFO("%s: string=\"%s\"\n", __func__, pbuf);
+
+	ptmp = (char *)pbuf;
+	pch = strsep(&ptmp, delim);
+	if ((pch == NULL) || (strlen(pch) == 0)) {
+		rtw_mfree(pbuf, len);
+		RTW_INFO("%s: parameter error(level 1)!\n", __func__);
+		return -EFAULT;
+	}
+
+#ifdef CONFIG_MAC_LOOPBACK_DRIVER
+	if (strcmp(pch, "loopback") == 0) {
+		s32 cnt = 0;
+		u32 size = 64;
+
+		pch = strsep(&ptmp, delim);
+		if ((pch == NULL) || (strlen(pch) == 0)) {
+			rtw_mfree(pbuf, len);
+			RTW_INFO("%s: parameter error(level 2)!\n", __func__);
+			return -EFAULT;
+		}
+
+		sscanf(pch, "%d", &cnt);
+		RTW_INFO("%s: loopback cnt=%d\n", __func__, cnt);
+
+		pch = strsep(&ptmp, delim);
+		if ((pch == NULL) || (strlen(pch) == 0)) {
+			rtw_mfree(pbuf, len);
+			RTW_INFO("%s: parameter error(level 2)!\n", __func__);
+			return -EFAULT;
+		}
+
+		sscanf(pch, "%d", &size);
+		RTW_INFO("%s: loopback size=%d\n", __func__, size);
+
+		loopbackTest(padapter, cnt, size, extra);
+		wrqu->data.length = strlen(extra) + 1;
+
+		goto free_buf;
+	}
+#endif
+
+
+#ifdef CONFIG_BT_COEXIST
+	if (strcmp(pch, "bton") == 0) {
+		rtw_btcoex_SetManualControl(padapter, _FALSE);
+		goto free_buf;
+	} else if (strcmp(pch, "btoff") == 0) {
+		rtw_btcoex_SetManualControl(padapter, _TRUE);
+		goto free_buf;
+	}
+#endif
+
+	if (strcmp(pch, "h2c") == 0) {
+		u8 param[8];
+		u8 count = 0;
+		u32 tmp;
+		u8 i;
+		u32 pos;
+		u8 ret;
+
+		do {
+			pch = strsep(&ptmp, delim);
+			if ((pch == NULL) || (strlen(pch) == 0))
+				break;
+
+			sscanf(pch, "%x", &tmp);
+			param[count++] = (u8)tmp;
+		} while (count < 8);
+
+		if (count == 0) {
+			rtw_mfree(pbuf, len);
+			RTW_INFO("%s: parameter error(level 2)!\n", __func__);
+			return -EFAULT;
+		}
+
+		ret = rtw_test_h2c_cmd(padapter, param, count);
+
+		pos = sprintf(extra, "H2C ID=0x%02x content=", param[0]);
+		for (i = 1; i < count; i++)
+			pos += sprintf(extra + pos, "%02x,", param[i]);
+		extra[pos] = 0;
+		pos--;
+		pos += sprintf(extra + pos, " %s", ret == _FAIL ? "FAIL" : "OK");
+
+		wrqu->data.length = strlen(extra) + 1;
+
+		goto free_buf;
+	}
+
+free_buf:
+	rtw_mfree(pbuf, len);
+	return 0;
+}
+
+static iw_handler rtw_handlers[] = {
+	NULL,					/* SIOCSIWCOMMIT */
+	rtw_wx_get_name,		/* SIOCGIWNAME */
+	dummy,					/* SIOCSIWNWID */
+	dummy,					/* SIOCGIWNWID */
+	rtw_wx_set_freq,		/* SIOCSIWFREQ */
+	rtw_wx_get_freq,		/* SIOCGIWFREQ */
+	rtw_wx_set_mode,		/* SIOCSIWMODE */
+	rtw_wx_get_mode,		/* SIOCGIWMODE */
+	dummy,					/* SIOCSIWSENS */
+	rtw_wx_get_sens,		/* SIOCGIWSENS */
+	NULL,					/* SIOCSIWRANGE */
+	rtw_wx_get_range,		/* SIOCGIWRANGE */
+	rtw_wx_set_priv,		/* SIOCSIWPRIV */
+	NULL,					/* SIOCGIWPRIV */
+	NULL,					/* SIOCSIWSTATS */
+	NULL,					/* SIOCGIWSTATS */
+	dummy,					/* SIOCSIWSPY */
+	dummy,					/* SIOCGIWSPY */
+	NULL,					/* SIOCGIWTHRSPY */
+	NULL,					/* SIOCWIWTHRSPY */
+	rtw_wx_set_wap,		/* SIOCSIWAP */
+	rtw_wx_get_wap,		/* SIOCGIWAP */
+	rtw_wx_set_mlme,		/* request MLME operation; uses struct iw_mlme */
+	dummy,					/* SIOCGIWAPLIST -- depricated */
+	rtw_wx_set_scan,		/* SIOCSIWSCAN */
+	rtw_wx_get_scan,		/* SIOCGIWSCAN */
+	rtw_wx_set_essid,		/* SIOCSIWESSID */
+	rtw_wx_get_essid,		/* SIOCGIWESSID */
+	dummy,					/* SIOCSIWNICKN */
+	rtw_wx_get_nick,		/* SIOCGIWNICKN */
+	NULL,					/* -- hole -- */
+	NULL,					/* -- hole -- */
+	rtw_wx_set_rate,		/* SIOCSIWRATE */
+	rtw_wx_get_rate,		/* SIOCGIWRATE */
+	rtw_wx_set_rts,			/* SIOCSIWRTS */
+	rtw_wx_get_rts,			/* SIOCGIWRTS */
+	rtw_wx_set_frag,		/* SIOCSIWFRAG */
+	rtw_wx_get_frag,		/* SIOCGIWFRAG */
+	dummy,					/* SIOCSIWTXPOW */
+	dummy,					/* SIOCGIWTXPOW */
+	dummy,					/* SIOCSIWRETRY */
+	rtw_wx_get_retry,		/* SIOCGIWRETRY */
+	rtw_wx_set_enc,			/* SIOCSIWENCODE */
+	rtw_wx_get_enc,			/* SIOCGIWENCODE */
+	dummy,					/* SIOCSIWPOWER */
+	rtw_wx_get_power,		/* SIOCGIWPOWER */
+	NULL,					/*---hole---*/
+	NULL,					/*---hole---*/
+	rtw_wx_set_gen_ie,		/* SIOCSIWGENIE */
+	NULL,					/* SIOCGWGENIE */
+	rtw_wx_set_auth,		/* SIOCSIWAUTH */
+	NULL,					/* SIOCGIWAUTH */
+	rtw_wx_set_enc_ext,		/* SIOCSIWENCODEEXT */
+	NULL,					/* SIOCGIWENCODEEXT */
+	rtw_wx_set_pmkid,		/* SIOCSIWPMKSA */
+	NULL,					/*---hole---*/
+};
+
+
+static const struct iw_priv_args rtw_private_args[] = {
+	{
+		SIOCIWFIRSTPRIV + 0x0,
+		IW_PRIV_TYPE_CHAR | 0x7FF, 0, "write"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x1,
+		IW_PRIV_TYPE_CHAR | 0x7FF,
+		IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_FIXED | IFNAMSIZ, "read"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x2, 0, 0, "driver_ext"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x3, 0, 0, "mp_ioctl"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x4,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "apinfo"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x5,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 2, 0, "setpid"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x6,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "wps_start"
+	},
+	/* for PLATFORM_MT53XX	 */
+	{
+		SIOCIWFIRSTPRIV + 0x7,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "get_sensitivity"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x8,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "wps_prob_req_ie"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x9,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "wps_assoc_req_ie"
+	},
+
+	/* for RTK_DMP_PLATFORM	 */
+	{
+		SIOCIWFIRSTPRIV + 0xA,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "channel_plan"
+	},
+
+	{
+		SIOCIWFIRSTPRIV + 0xB,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 2, 0, "dbg"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0xC,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 3, 0, "rfw"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0xD,
+		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 2, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_FIXED | IFNAMSIZ, "rfr"
+	},
+#if 0
+	{
+		SIOCIWFIRSTPRIV + 0xE, 0, 0, "wowlan_ctrl"
+	},
+#endif
+	{
+		SIOCIWFIRSTPRIV + 0x10,
+		IW_PRIV_TYPE_CHAR | 1024, 0, "p2p_set"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x11,
+		IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK , "p2p_get"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x12, 0, 0, "NULL"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x13,
+		IW_PRIV_TYPE_CHAR | 64, IW_PRIV_TYPE_CHAR | 64 , "p2p_get2"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x14,
+		IW_PRIV_TYPE_CHAR  | 64, 0, "tdls"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x15,
+		IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024 , "tdls_get"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x16,
+		IW_PRIV_TYPE_CHAR | 64, 0, "pm_set"
+	},
+#ifdef CONFIG_RTW_80211K
+	{
+		SIOCIWFIRSTPRIV + 0x17,
+		IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024 , "rrm"
+	},
+#endif
+	{SIOCIWFIRSTPRIV + 0x18, IW_PRIV_TYPE_CHAR | IFNAMSIZ , 0 , "rereg_nd_name"},
+#ifdef CONFIG_MP_INCLUDED
+	{SIOCIWFIRSTPRIV + 0x1A, IW_PRIV_TYPE_CHAR | 1024, 0,  "NULL"},
+	{SIOCIWFIRSTPRIV + 0x1B, IW_PRIV_TYPE_CHAR | 128, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "NULL"},
+#else
+	{SIOCIWFIRSTPRIV + 0x1A, IW_PRIV_TYPE_CHAR | 1024, 0,  "NULL"},
+	{SIOCIWFIRSTPRIV + 0x1B, IW_PRIV_TYPE_CHAR | 128, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_get"},
+#endif
+	{
+		SIOCIWFIRSTPRIV + 0x1D,
+		IW_PRIV_TYPE_CHAR | 40, IW_PRIV_TYPE_CHAR | 0x7FF, "test"
+	},
+
+#ifdef CONFIG_INTEL_WIDI
+	{
+		SIOCIWFIRSTPRIV + 0x1E,
+		IW_PRIV_TYPE_CHAR | 1024, 0, "widi_set"
+	},
+	{
+		SIOCIWFIRSTPRIV + 0x1F,
+		IW_PRIV_TYPE_CHAR | 128, 0, "widi_prob_req"
+	},
+#endif /* CONFIG_INTEL_WIDI */
+
+	{ SIOCIWFIRSTPRIV + 0x0E, IW_PRIV_TYPE_CHAR | 1024, 0 , ""},  /* set  */
+	{ SIOCIWFIRSTPRIV + 0x0F, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK , ""},/* get
+ * --- sub-ioctls definitions --- */
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	{ VENDOR_IE_SET, IW_PRIV_TYPE_CHAR | 1024 , 0 , "vendor_ie_set" },
+	{ VENDOR_IE_GET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "vendor_ie_get" },
+#endif
+#if defined(CONFIG_RTL8723B)
+	{ MP_SetBT, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_setbt" },
+	{ MP_DISABLE_BT_COEXIST, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_disa_btcoex"},
+#endif
+#ifdef CONFIG_WOWLAN
+	{ MP_WOW_ENABLE , IW_PRIV_TYPE_CHAR | 1024, 0, "wow_mode" },
+	{ MP_WOW_SET_PATTERN , IW_PRIV_TYPE_CHAR | 1024, 0, "wow_set_pattern" },
+#endif
+#ifdef CONFIG_AP_WOWLAN
+	{ MP_AP_WOW_ENABLE , IW_PRIV_TYPE_CHAR | 1024, 0, "ap_wow_mode" }, /* set  */
+#endif
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+	{ MP_SD_IREAD, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "sd_iread" },
+	{ MP_SD_IWRITE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "sd_iwrite" },
+#endif
+};
+
+
+static const struct iw_priv_args rtw_mp_private_args[] = {
+	/* --- sub-ioctls definitions --- */
+#ifdef CONFIG_MP_INCLUDED
+	{ MP_START , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_start" },
+	{ MP_PHYPARA, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_phypara" },
+	{ MP_STOP , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_stop" },
+	{ MP_CHANNEL , IW_PRIV_TYPE_CHAR | 1024 , IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_channel" },
+	{ MP_CHL_OFFSET , IW_PRIV_TYPE_CHAR | 1024 , IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ch_offset" },
+	{ MP_BANDWIDTH , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_bandwidth"},
+	{ MP_RATE , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rate" },
+	{ MP_RESET_STATS , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_reset_stats"},
+	{ MP_QUERY , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK , "mp_query"},
+	{ READ_REG , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "read_reg" },
+	{ MP_RATE , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rate" },
+	{ READ_RF , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "read_rf" },
+	{ MP_PSD , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_psd"},
+	{ MP_DUMP, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_dump" },
+	{ MP_TXPOWER , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_txpower"},
+	{ MP_ANT_TX , IW_PRIV_TYPE_CHAR | 1024,  IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ant_tx"},
+	{ MP_ANT_RX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ant_rx"},
+	{ WRITE_REG , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "write_reg" },
+	{ WRITE_RF , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "write_rf" },
+	{ MP_CTX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ctx"},
+	{ MP_ARX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_arx"},
+	{ MP_THER , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ther"},
+	{ EFUSE_SET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_set" },
+	{ EFUSE_GET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_get" },
+	{ MP_PWRTRK , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrtrk"},
+	{ MP_QueryDrvStats, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_drvquery" },
+	{ MP_IOCTL, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_ioctl"},
+	{ MP_SetRFPathSwh, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_setrfpath" },
+	{ MP_PwrCtlDM, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrctldm" },
+	{ MP_GET_TXPOWER_INX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_get_txpower" },
+	{ MP_GETVER, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_priv_ver" },
+	{ MP_MON, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_mon" },
+	{ EFUSE_MASK, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_mask" },
+	{ EFUSE_FILE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_file" },
+	{ MP_TX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_tx" },
+	{ MP_RX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rx" },
+	{ MP_HW_TX_MODE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_hxtx" },
+	{ MP_PWRLMT, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrlmt" },
+	{ MP_PWRBYRATE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrbyrate" },
+	{ CTA_TEST, IW_PRIV_TYPE_CHAR | 1024, 0, "cta_test"},
+	{ MP_IQK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_iqk"},
+	{ MP_LCK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_lck"},
+	{ BT_EFUSE_FILE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "bt_efuse_file" },
+	{ MP_SWRFPath, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_swrfpath" },
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	{ MP_CUSTOMER_STR, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "customer_str" },
+#endif
+
+#endif /* CONFIG_MP_INCLUDED */
+};
+
+static iw_handler rtw_private_handler[] = {
+	rtw_wx_write32,					/* 0x00 */
+	rtw_wx_read32,					/* 0x01 */
+	NULL,					/* 0x02 */
+#ifdef MP_IOCTL_HDL
+	rtw_mp_ioctl_hdl,				/* 0x03 */
+#else
+	rtw_wx_priv_null,
+#endif
+	/* for MM DTV platform */
+	rtw_get_ap_info,					/* 0x04 */
+
+	rtw_set_pid,						/* 0x05 */
+	rtw_wps_start,					/* 0x06 */
+
+	/* for PLATFORM_MT53XX */
+	rtw_wx_get_sensitivity,			/* 0x07 */
+	rtw_wx_set_mtk_wps_probe_ie,	/* 0x08 */
+	rtw_wx_set_mtk_wps_ie,			/* 0x09 */
+
+	/* for RTK_DMP_PLATFORM
+	 * Set Channel depend on the country code */
+	rtw_wx_set_channel_plan,		/* 0x0A */
+
+	rtw_dbg_port,					/* 0x0B */
+	rtw_wx_write_rf,					/* 0x0C */
+	rtw_wx_read_rf,					/* 0x0D */
+
+	rtw_priv_set,					/*0x0E*/
+	rtw_priv_get,					/*0x0F*/
+
+	rtw_p2p_set,					/* 0x10 */
+	rtw_p2p_get,					/* 0x11 */
+	NULL,							/* 0x12 */
+	rtw_p2p_get2,					/* 0x13 */
+
+	rtw_tdls,						/* 0x14 */
+	rtw_tdls_get,					/* 0x15 */
+
+	rtw_pm_set,						/* 0x16 */
+#ifdef CONFIG_RTW_80211K
+	rtw_wx_priv_rrm,				/* 0x17 */
+#else
+	rtw_wx_priv_null,				/* 0x17 */
+#endif
+	rtw_rereg_nd_name,				/* 0x18 */
+	rtw_wx_priv_null,				/* 0x19 */
+#ifdef CONFIG_MP_INCLUDED
+	rtw_wx_priv_null,				/* 0x1A */
+	rtw_wx_priv_null,				/* 0x1B */
+#else
+	rtw_wx_priv_null,				/* 0x1A */
+	rtw_mp_efuse_get,				/* 0x1B */
+#endif
+	NULL,							/* 0x1C is reserved for hostapd */
+	rtw_test,						/* 0x1D */
+#ifdef CONFIG_INTEL_WIDI
+	rtw_widi_set,					/* 0x1E */
+	rtw_widi_set_probe_request,		/* 0x1F */
+#endif /* CONFIG_INTEL_WIDI */
+};
+
+#if WIRELESS_EXT >= 17
+static struct iw_statistics *rtw_get_wireless_stats(struct net_device *dev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_statistics *piwstats = &padapter->iwstats;
+	int tmp_level = 0;
+	int tmp_qual = 0;
+	int tmp_noise = 0;
+
+	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) != _TRUE) {
+		piwstats->qual.qual = 0;
+		piwstats->qual.level = 0;
+		piwstats->qual.noise = 0;
+		/* RTW_INFO("No link  level:%d, qual:%d, noise:%d\n", tmp_level, tmp_qual, tmp_noise); */
+	} else {
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+		tmp_level = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);
+#else
+#ifdef CONFIG_SIGNAL_SCALE_MAPPING
+		tmp_level = padapter->recvpriv.signal_strength;
+#else
+		{
+			/* Do signal scale mapping when using percentage as the unit of signal strength, since the scale mapping is skipped in odm */
+
+			HAL_DATA_TYPE *pHal = GET_HAL_DATA(padapter);
+
+			tmp_level = (u8)phydm_signal_scale_mapping(&pHal->odmpriv, padapter->recvpriv.signal_strength);
+		}
+#endif
+#endif
+
+		tmp_qual = padapter->recvpriv.signal_qual;
+		#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+		if (IS_NM_ENABLE(padapter)) {
+			tmp_noise = rtw_noise_measure_curchan(padapter);
+			#ifndef CONFIG_SIGNAL_DISPLAY_DBM
+			tmp_noise = translate_dbm_to_percentage(tmp_noise);/*percentage*/
+			#endif
+		}
+		#endif
+		/* RTW_INFO("level:%d, qual:%d, noise:%d, rssi (%d)\n", tmp_level, tmp_qual, tmp_noise,padapter->recvpriv.rssi); */
+
+		piwstats->qual.level = tmp_level;
+		piwstats->qual.qual = tmp_qual;
+		piwstats->qual.noise = tmp_noise;
+	}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 14))
+	piwstats->qual.updated = IW_QUAL_ALL_UPDATED ;/* |IW_QUAL_DBM; */
+#else
+#ifdef RTK_DMP_PLATFORM
+	/* IW_QUAL_DBM= 0x8, if driver use this flag, wireless extension will show value of dbm. */
+	/* remove this flag for show percentage 0~100 */
+	piwstats->qual.updated = 0x07;
+#else
+	piwstats->qual.updated = 0x0f;
+#endif
+#endif
+
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+	piwstats->qual.updated = piwstats->qual.updated | IW_QUAL_DBM;
+#endif
+
+	return &padapter->iwstats;
+}
+#endif
+
+#ifdef CONFIG_WIRELESS_EXT
+struct iw_handler_def rtw_handlers_def = {
+	.standard = rtw_handlers,
+	.num_standard = sizeof(rtw_handlers) / sizeof(iw_handler),
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 33)) || defined(CONFIG_WEXT_PRIV)
+	.private = rtw_private_handler,
+	.private_args = (struct iw_priv_args *)rtw_private_args,
+	.num_private = sizeof(rtw_private_handler) / sizeof(iw_handler),
+	.num_private_args = sizeof(rtw_private_args) / sizeof(struct iw_priv_args),
+#endif
+#if WIRELESS_EXT >= 17
+	.get_wireless_stats = rtw_get_wireless_stats,
+#endif
+};
+#endif
+
+/* copy from net/wireless/wext.c start
+ * ----------------------------------------------------------------
+ *
+ * Calculate size of private arguments
+ */
+static const char iw_priv_type_size[] = {
+	0,                              /* IW_PRIV_TYPE_NONE */
+	1,                              /* IW_PRIV_TYPE_BYTE */
+	1,                              /* IW_PRIV_TYPE_CHAR */
+	0,                              /* Not defined */
+	sizeof(__u32),                  /* IW_PRIV_TYPE_INT */
+	sizeof(struct iw_freq),         /* IW_PRIV_TYPE_FLOAT */
+	sizeof(struct sockaddr),        /* IW_PRIV_TYPE_ADDR */
+	0,                              /* Not defined */
+};
+
+static int get_priv_size(__u16 args)
+{
+	int num = args & IW_PRIV_SIZE_MASK;
+	int type = (args & IW_PRIV_TYPE_MASK) >> 12;
+
+	return num * iw_priv_type_size[type];
+}
+/* copy from net/wireless/wext.c end */
+
+
+static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq_data)
+{
+	int err = 0;
+	u8 *input = NULL;
+	u32 input_len = 0;
+	const char delim[] = " ";
+	u8 *output = NULL;
+	u32 output_len = 0;
+	u32 count = 0;
+	u8 *buffer = NULL;
+	u32 buffer_len = 0;
+	char *ptr = NULL;
+	u8 cmdname[17] = {0}; /* IFNAMSIZ+1 */
+	u32 cmdlen;
+	s32 len;
+	u8 *extra = NULL;
+	u32 extra_size = 0;
+
+	s32 k;
+	const iw_handler *priv;		/* Private ioctl */
+	const struct iw_priv_args *priv_args;	/* Private ioctl description */
+	const struct iw_priv_args *mp_priv_args;	/*MP Private ioctl description */
+	const struct iw_priv_args *sel_priv_args;	/*Selected Private ioctl description */
+	u32 num_priv;				/* Number of ioctl */
+	u32 num_priv_args;			/* Number of descriptions */
+	u32 num_mp_priv_args;			/*Number of MP descriptions */
+	u32 num_sel_priv_args;			/*Number of Selected descriptions */
+	iw_handler handler;
+	int temp;
+	int subcmd = 0;				/* sub-ioctl index */
+	int offset = 0;				/* Space for sub-ioctl index */
+
+	union iwreq_data wdata;
+
+	_rtw_memcpy(&wdata, wrq_data, sizeof(wdata));
+
+	input_len = wdata.data.length;
+	if (!input_len)
+		return -EINVAL;
+	input = rtw_zmalloc(input_len);
+	if (NULL == input)
+		return -ENOMEM;
+	if (copy_from_user(input, wdata.data.pointer, input_len)) {
+		err = -EFAULT;
+		goto exit;
+	}
+	input[input_len - 1] = '\0';
+	ptr = input;
+	len = input_len;
+
+	if (ptr == NULL) {
+		err = -EOPNOTSUPP;
+		goto exit;
+	}
+
+	sscanf(ptr, "%16s", cmdname);
+	cmdlen = strlen(cmdname);
+	RTW_INFO("%s: cmd=%s\n", __func__, cmdname);
+
+	/* skip command string */
+	if (cmdlen > 0)
+		cmdlen += 1; /* skip one space */
+	ptr += cmdlen;
+	len -= cmdlen;
+	RTW_INFO("%s: parameters=%s\n", __func__, ptr);
+
+	priv = rtw_private_handler;
+	priv_args = rtw_private_args;
+	mp_priv_args = rtw_mp_private_args;
+	num_priv = sizeof(rtw_private_handler) / sizeof(iw_handler);
+	num_priv_args = sizeof(rtw_private_args) / sizeof(struct iw_priv_args);
+	num_mp_priv_args = sizeof(rtw_mp_private_args) / sizeof(struct iw_priv_args);
+
+	if (num_priv_args == 0) {
+		err = -EOPNOTSUPP;
+		goto exit;
+	}
+
+	/* Search the correct ioctl */
+	k = -1;
+	sel_priv_args = priv_args;
+	num_sel_priv_args = num_priv_args;
+	while
+	((++k < num_sel_priv_args) && strcmp(sel_priv_args[k].name, cmdname))
+		;
+
+	/* If not found... */
+	if (k == num_sel_priv_args) {
+		k = -1;
+		sel_priv_args = mp_priv_args;
+		num_sel_priv_args = num_mp_priv_args;
+		while
+		((++k < num_sel_priv_args) && strcmp(sel_priv_args[k].name, cmdname))
+			;
+
+		if (k == num_sel_priv_args) {
+			err = -EOPNOTSUPP;
+			goto exit;
+		}
+	}
+
+	/* Watch out for sub-ioctls ! */
+	if (sel_priv_args[k].cmd < SIOCDEVPRIVATE) {
+		int j = -1;
+
+		/* Find the matching *real* ioctl */
+		while ((++j < num_priv_args) && ((priv_args[j].name[0] != '\0') ||
+			 (priv_args[j].set_args != sel_priv_args[k].set_args) ||
+			 (priv_args[j].get_args != sel_priv_args[k].get_args)))
+			;
+
+		/* If not found... */
+		if (j == num_priv_args) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		/* Save sub-ioctl number */
+		subcmd = sel_priv_args[k].cmd;
+		/* Reserve one int (simplify alignment issues) */
+		offset = sizeof(__u32);
+		/* Use real ioctl definition from now on */
+		k = j;
+	}
+
+	buffer = rtw_zmalloc(4096);
+	if (NULL == buffer) {
+		err = -ENOMEM;
+		goto exit;
+	}
+
+	if (k >= num_priv_args) {
+		err = -EINVAL;
+		goto exit;
+	}
+
+	/* If we have to set some data */
+	if ((priv_args[k].set_args & IW_PRIV_TYPE_MASK) &&
+	    (priv_args[k].set_args & IW_PRIV_SIZE_MASK)) {
+		u8 *str;
+
+		switch (priv_args[k].set_args & IW_PRIV_TYPE_MASK) {
+		case IW_PRIV_TYPE_BYTE:
+			/* Fetch args */
+			count = 0;
+			do {
+				str = strsep(&ptr, delim);
+				if (NULL == str)
+					break;
+				sscanf(str, "%i", &temp);
+				buffer[count++] = (u8)temp;
+			} while (1);
+			buffer_len = count;
+
+			/* Number of args to fetch */
+			wdata.data.length = count;
+			if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
+				wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
+
+			break;
+
+		case IW_PRIV_TYPE_INT:
+			/* Fetch args */
+			count = 0;
+			do {
+				str = strsep(&ptr, delim);
+				if (NULL == str)
+					break;
+				sscanf(str, "%i", &temp);
+				((s32 *)buffer)[count++] = (s32)temp;
+			} while (1);
+			buffer_len = count * sizeof(s32);
+
+			/* Number of args to fetch */
+			wdata.data.length = count;
+			if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
+				wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
+
+			break;
+
+		case IW_PRIV_TYPE_CHAR:
+			if (len > 0) {
+				/* Size of the string to fetch */
+				wdata.data.length = len;
+				if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
+					wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
+
+				/* Fetch string */
+				_rtw_memcpy(buffer, ptr, wdata.data.length);
+			} else {
+				wdata.data.length = 1;
+				buffer[0] = '\0';
+			}
+			buffer_len = wdata.data.length;
+			break;
+
+		default:
+			RTW_INFO("%s: Not yet implemented...\n", __func__);
+			err = -1;
+			goto exit;
+		}
+
+		if ((priv_args[k].set_args & IW_PRIV_SIZE_FIXED) &&
+		    (wdata.data.length != (priv_args[k].set_args & IW_PRIV_SIZE_MASK))) {
+			RTW_INFO("%s: The command %s needs exactly %d argument(s)...\n",
+				__func__, cmdname, priv_args[k].set_args & IW_PRIV_SIZE_MASK);
+			err = -EINVAL;
+			goto exit;
+		}
+	}   /* if args to set */
+	else
+		wdata.data.length = 0L;
+
+	/* Those two tests are important. They define how the driver
+	* will have to handle the data */
+	if ((priv_args[k].set_args & IW_PRIV_SIZE_FIXED) &&
+	    ((get_priv_size(priv_args[k].set_args) + offset) <= IFNAMSIZ)) {
+		/* First case : all SET args fit within wrq */
+		if (offset)
+			wdata.mode = subcmd;
+		_rtw_memcpy(wdata.name + offset, buffer, IFNAMSIZ - offset);
+	} else {
+		if ((priv_args[k].set_args == 0) &&
+		    (priv_args[k].get_args & IW_PRIV_SIZE_FIXED) &&
+		    (get_priv_size(priv_args[k].get_args) <= IFNAMSIZ)) {
+			/* Second case : no SET args, GET args fit within wrq */
+			if (offset)
+				wdata.mode = subcmd;
+		} else {
+			/* Third case : args won't fit in wrq, or variable number of args */
+			if (copy_to_user(wdata.data.pointer, buffer, buffer_len)) {
+				err = -EFAULT;
+				goto exit;
+			}
+			wdata.data.flags = subcmd;
+		}
+	}
+
+	rtw_mfree(input, input_len);
+	input = NULL;
+
+	extra_size = 0;
+	if (IW_IS_SET(priv_args[k].cmd)) {
+		/* Size of set arguments */
+		extra_size = get_priv_size(priv_args[k].set_args);
+
+		/* Does it fits in iwr ? */
+		if ((priv_args[k].set_args & IW_PRIV_SIZE_FIXED) &&
+		    ((extra_size + offset) <= IFNAMSIZ))
+			extra_size = 0;
+	} else {
+		/* Size of get arguments */
+		extra_size = get_priv_size(priv_args[k].get_args);
+
+		/* Does it fits in iwr ? */
+		if ((priv_args[k].get_args & IW_PRIV_SIZE_FIXED) &&
+		    (extra_size <= IFNAMSIZ))
+			extra_size = 0;
+	}
+
+	if (extra_size == 0) {
+		extra = (u8 *)&wdata;
+		rtw_mfree(buffer, 4096);
+		buffer = NULL;
+	} else
+		extra = buffer;
+
+	handler = priv[priv_args[k].cmd - SIOCIWFIRSTPRIV];
+	err = handler(dev, NULL, &wdata, extra);
+
+	/* If we have to get some data */
+	if ((priv_args[k].get_args & IW_PRIV_TYPE_MASK) &&
+	    (priv_args[k].get_args & IW_PRIV_SIZE_MASK)) {
+		int j;
+		int n = 0;	/* number of args */
+		u8 str[20] = {0};
+
+		/* Check where is the returned data */
+		if ((priv_args[k].get_args & IW_PRIV_SIZE_FIXED) &&
+		    (get_priv_size(priv_args[k].get_args) <= IFNAMSIZ))
+			n = priv_args[k].get_args & IW_PRIV_SIZE_MASK;
+		else
+			n = wdata.data.length;
+
+		output = rtw_zmalloc(4096);
+		if (NULL == output) {
+			err =  -ENOMEM;
+			goto exit;
+		}
+
+		switch (priv_args[k].get_args & IW_PRIV_TYPE_MASK) {
+		case IW_PRIV_TYPE_BYTE:
+			/* Display args */
+			for (j = 0; j < n; j++) {
+				sprintf(str, "%d  ", extra[j]);
+				len = strlen(str);
+				output_len = strlen(output);
+				if ((output_len + len + 1) > 4096) {
+					err = -E2BIG;
+					goto exit;
+				}
+				_rtw_memcpy(output + output_len, str, len);
+			}
+			break;
+
+		case IW_PRIV_TYPE_INT:
+			/* Display args */
+			for (j = 0; j < n; j++) {
+				sprintf(str, "%d  ", ((__s32 *)extra)[j]);
+				len = strlen(str);
+				output_len = strlen(output);
+				if ((output_len + len + 1) > 4096) {
+					err = -E2BIG;
+					goto exit;
+				}
+				_rtw_memcpy(output + output_len, str, len);
+			}
+			break;
+
+		case IW_PRIV_TYPE_CHAR:
+			/* Display args */
+			_rtw_memcpy(output, extra, n);
+			break;
+
+		default:
+			RTW_INFO("%s: Not yet implemented...\n", __func__);
+			err = -1;
+			goto exit;
+		}
+
+		output_len = strlen(output) + 1;
+		wrq_data->data.length = output_len;
+		if (copy_to_user(wrq_data->data.pointer, output, output_len)) {
+			err = -EFAULT;
+			goto exit;
+		}
+	}   /* if args to set */
+	else
+		wrq_data->data.length = 0;
+
+exit:
+	if (input)
+		rtw_mfree(input, input_len);
+	if (buffer)
+		rtw_mfree(buffer, 4096);
+	if (output)
+		rtw_mfree(output, 4096);
+
+	return err;
+}
+
+#ifdef CONFIG_COMPAT
+static int rtw_ioctl_compat_wext_private(struct net_device *dev, struct ifreq *rq)
+{
+	struct compat_iw_point iwp_compat;
+	union iwreq_data wrq_data;
+	int err = 0;
+	RTW_INFO("%s:...\n", __func__);
+	if (copy_from_user(&iwp_compat, rq->ifr_ifru.ifru_data, sizeof(struct compat_iw_point)))
+		return -EFAULT;
+
+	wrq_data.data.pointer = compat_ptr(iwp_compat.pointer);
+	wrq_data.data.length = iwp_compat.length;
+	wrq_data.data.flags = iwp_compat.flags;
+
+	err = _rtw_ioctl_wext_private(dev, &wrq_data);
+
+	iwp_compat.pointer = ptr_to_compat(wrq_data.data.pointer);
+	iwp_compat.length = wrq_data.data.length;
+	iwp_compat.flags = wrq_data.data.flags;
+	if (copy_to_user(rq->ifr_ifru.ifru_data, &iwp_compat, sizeof(struct compat_iw_point)))
+		return -EFAULT;
+
+	return err;
+}
+#endif /* CONFIG_COMPAT */
+
+static int rtw_ioctl_standard_wext_private(struct net_device *dev, struct ifreq *rq)
+{
+	struct iw_point *iwp;
+	struct ifreq ifrq;
+	union iwreq_data wrq_data;
+	int err = 0;
+	iwp = &wrq_data.data;
+	RTW_INFO("%s:...\n", __func__);
+	if (copy_from_user(iwp, rq->ifr_ifru.ifru_data, sizeof(struct iw_point)))
+		return -EFAULT;
+
+	err = _rtw_ioctl_wext_private(dev, &wrq_data);
+
+	if (copy_to_user(rq->ifr_ifru.ifru_data, iwp, sizeof(struct iw_point)))
+		return -EFAULT;
+
+	return err;
+}
+
+static int rtw_ioctl_wext_private(struct net_device *dev, struct ifreq *rq)
+{
+#ifdef CONFIG_COMPAT
+#if (KERNEL_VERSION(4, 6, 0) > LINUX_VERSION_CODE)
+	if (is_compat_task())
+#else
+	if (in_compat_syscall())
+#endif
+		return rtw_ioctl_compat_wext_private(dev, rq);
+	else
+#endif /* CONFIG_COMPAT */
+		return rtw_ioctl_standard_wext_private(dev, rq);
+}
+
+int rtw_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
+{
+	struct iwreq *wrq = (struct iwreq *)rq;
+	int ret = 0;
+
+	switch (cmd) {
+	case RTL_IOCTL_WPA_SUPPLICANT:
+		ret = wpa_supplicant_ioctl(dev, &wrq->u.data);
+		break;
+#ifdef CONFIG_AP_MODE
+	case RTL_IOCTL_HOSTAPD:
+		ret = rtw_hostapd_ioctl(dev, &wrq->u.data);
+		break;
+#ifdef CONFIG_WIRELESS_EXT
+	case SIOCSIWMODE:
+		ret = rtw_wx_set_mode(dev, NULL, &wrq->u, NULL);
+		break;
+#endif
+#endif /* CONFIG_AP_MODE */
+	case SIOCDEVPRIVATE:
+		ret = rtw_ioctl_wext_private(dev, rq);
+		break;
+	case (SIOCDEVPRIVATE+1):
+		ret = rtw_android_priv_cmd(dev, rq, cmd);
+		break;
+	default:
+		ret = -EOPNOTSUPP;
+		break;
+	}
+
+	return ret;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_mp.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_mp.c
new file mode 100644
index 000000000000..e82c39f6262c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/ioctl_mp.c
@@ -0,0 +1,2636 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#if defined(CONFIG_MP_INCLUDED)
+
+#include <drv_types.h>
+#include <rtw_mp.h>
+#include <rtw_mp_ioctl.h>
+#include "../../hal/phydm/phydm_precomp.h"
+
+
+#if defined(CONFIG_RTL8723B)
+	#include <rtw_bt_mp.h>
+#endif
+
+/*
+ * Input Format: %s,%d,%d
+ *	%s is width, could be
+ *		"b" for 1 byte
+ *		"w" for WORD (2 bytes)
+ *		"dw" for DWORD (4 bytes)
+ *	1st %d is address(offset)
+ *	2st %d is data to write
+ */
+int rtw_mp_write_reg(struct net_device *dev,
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
+{
+	char *pch, *pnext, *ptmp;
+	char *width_str;
+	char width, buf[5];
+	u32 addr, data;
+	int ret;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char input[wrqu->length + 1];
+
+	_rtw_memset(input, 0, sizeof(input));
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+
+	_rtw_memset(extra, 0, wrqu->length);
+
+	pch = input;
+
+	pnext = strpbrk(pch, " ,.-");
+	if (pnext == NULL)
+		return -EINVAL;
+	*pnext = 0;
+	width_str = pch;
+
+	pch = pnext + 1;
+	pnext = strpbrk(pch, " ,.-");
+	if (pnext == NULL)
+		return -EINVAL;
+	*pnext = 0;
+	/*addr = simple_strtoul(pch, &ptmp, 16);
+	_rtw_memset(buf, '\0', sizeof(buf));
+	_rtw_memcpy(buf, pch, pnext-pch);
+	ret = kstrtoul(buf, 16, &addr);*/
+	ret = sscanf(pch, "%x", &addr);
+	if (addr > 0x3FFF)
+		return -EINVAL;
+
+	pch = pnext + 1;
+	pnext = strpbrk(pch, " ,.-");
+	if ((pch - input) >= wrqu->length)
+		return -EINVAL;
+	/*data = simple_strtoul(pch, &ptmp, 16);*/
+	ret = sscanf(pch, "%x", &data);
+	RTW_INFO("data=%x,addr=%x\n", (u32)data, (u32)addr);
+	ret = 0;
+	width = width_str[0];
+	switch (width) {
+	case 'b':
+		/* 1 byte*/
+		if (data > 0xFF) {
+			ret = -EINVAL;
+			break;
+		}
+		rtw_write8(padapter, addr, data);
+		break;
+	case 'w':
+		/* 2 bytes*/
+		if (data > 0xFFFF) {
+			ret = -EINVAL;
+			break;
+		}
+		rtw_write16(padapter, addr, data);
+		break;
+	case 'd':
+		/* 4 bytes*/
+		rtw_write32(padapter, addr, data);
+		break;
+	default:
+		ret = -EINVAL;
+		break;
+	}
+
+	return ret;
+}
+
+
+/*
+ * Input Format: %s,%d
+ *	%s is width, could be
+ *		"b" for 1 byte
+ *		"w" for WORD (2 bytes)
+ *		"dw" for DWORD (4 bytes)
+ *	%d is address(offset)
+ *
+ * Return:
+ *	%d for data readed
+ */
+int rtw_mp_read_reg(struct net_device *dev,
+		    struct iw_request_info *info,
+		    struct iw_point *wrqu, char *extra)
+{
+	char input[wrqu->length + 1];
+	char *pch, *pnext, *ptmp;
+	char *width_str;
+	char width;
+	char data[20], tmp[20], buf[3];
+	u32 addr = 0, strtout = 0;
+	u32 i = 0, j = 0, ret = 0, data32 = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char *pextra = extra;
+
+	if (wrqu->length > 128)
+		return -EFAULT;
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	_rtw_memset(extra, 0, wrqu->length);
+	_rtw_memset(data, '\0', sizeof(data));
+	_rtw_memset(tmp, '\0', sizeof(tmp));
+	pch = input;
+	pnext = strpbrk(pch, " ,.-");
+	if (pnext == NULL)
+		return -EINVAL;
+	*pnext = 0;
+	width_str = pch;
+
+	pch = pnext + 1;
+
+	ret = sscanf(pch, "%x", &addr);
+	if (addr > 0x3FFF)
+		return -EINVAL;
+
+	ret = 0;
+	width = width_str[0];
+
+	switch (width) {
+	case 'b':
+		data32 = rtw_read8(padapter, addr);
+		RTW_INFO("%x\n", data32);
+		sprintf(extra, "%d", data32);
+		wrqu->length = strlen(extra);
+		break;
+	case 'w':
+		/* 2 bytes*/
+		sprintf(data, "%04x\n", rtw_read16(padapter, addr));
+
+		for (i = 0 ; i <= strlen(data) ; i++) {
+			if (i % 2 == 0) {
+				tmp[j] = ' ';
+				j++;
+			}
+			if (data[i] != '\0')
+				tmp[j] = data[i];
+
+			j++;
+		}
+		pch = tmp;
+		RTW_INFO("pch=%s", pch);
+
+		while (*pch != '\0') {
+			pnext = strpbrk(pch, " ");
+			if (!pnext || ((pnext - tmp) > 4))
+				break;
+
+			pnext++;
+			if (*pnext != '\0') {
+				/*strtout = simple_strtoul(pnext , &ptmp, 16);*/
+				ret = sscanf(pnext, "%x", &strtout);
+				pextra += sprintf(pextra, " %d", strtout);
+			} else
+				break;
+			pch = pnext;
+		}
+		wrqu->length = strlen(extra);
+		break;
+	case 'd':
+		/* 4 bytes */
+		sprintf(data, "%08x", rtw_read32(padapter, addr));
+		/*add read data format blank*/
+		for (i = 0 ; i <= strlen(data) ; i++) {
+			if (i % 2 == 0) {
+				tmp[j] = ' ';
+				j++;
+			}
+			if (data[i] != '\0')
+				tmp[j] = data[i];
+
+			j++;
+		}
+		pch = tmp;
+		RTW_INFO("pch=%s", pch);
+
+		while (*pch != '\0') {
+			pnext = strpbrk(pch, " ");
+			if (!pnext)
+				break;
+
+			pnext++;
+			if (*pnext != '\0') {
+				ret = sscanf(pnext, "%x", &strtout);
+				pextra += sprintf(pextra, " %d", strtout);
+			} else
+				break;
+			pch = pnext;
+		}
+		wrqu->length = strlen(extra);
+		break;
+
+	default:
+		wrqu->length = 0;
+		ret = -EINVAL;
+		break;
+	}
+
+	return ret;
+}
+
+
+/*
+ * Input Format: %d,%x,%x
+ *	%d is RF path, should be smaller than MAX_RF_PATH_NUMS
+ *	1st %x is address(offset)
+ *	2st %x is data to write
+ */
+int rtw_mp_write_rf(struct net_device *dev,
+		    struct iw_request_info *info,
+		    struct iw_point *wrqu, char *extra)
+{
+
+	u32 path, addr, data;
+	int ret;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char input[wrqu->length];
+
+
+	_rtw_memset(input, 0, wrqu->length);
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+
+	ret = sscanf(input, "%d,%x,%x", &path, &addr, &data);
+	if (ret < 3)
+		return -EINVAL;
+
+	if (path >= GET_HAL_RFPATH_NUM(padapter))
+		return -EINVAL;
+	if (addr > 0xFF)
+		return -EINVAL;
+	if (data > 0xFFFFF)
+		return -EINVAL;
+
+	_rtw_memset(extra, 0, wrqu->length);
+
+	write_rfreg(padapter, path, addr, data);
+
+	sprintf(extra, "write_rf completed\n");
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+/*
+ * Input Format: %d,%x
+ *	%d is RF path, should be smaller than MAX_RF_PATH_NUMS
+ *	%x is address(offset)
+ *
+ * Return:
+ *	%d for data readed
+ */
+int rtw_mp_read_rf(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+	char input[wrqu->length];
+	char *pch, *pnext, *ptmp;
+	char data[20], tmp[20], buf[3];
+	u32 path, addr, strtou;
+	u32 ret, i = 0 , j = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char *pextra = extra;
+
+	if (wrqu->length > 128)
+		return -EFAULT;
+	_rtw_memset(input, 0, wrqu->length);
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	ret = sscanf(input, "%d,%x", &path, &addr);
+	if (ret < 2)
+		return -EINVAL;
+
+	if (path >= GET_HAL_RFPATH_NUM(padapter))
+		return -EINVAL;
+	if (addr > 0xFF)
+		return -EINVAL;
+
+	_rtw_memset(extra, 0, wrqu->length);
+
+	sprintf(data, "%08x", read_rfreg(padapter, path, addr));
+	/*add read data format blank*/
+	for (i = 0 ; i <= strlen(data) ; i++) {
+		if (i % 2 == 0) {
+			tmp[j] = ' ';
+			j++;
+		}
+		tmp[j] = data[i];
+		j++;
+	}
+	pch = tmp;
+	RTW_INFO("pch=%s", pch);
+
+	while (*pch != '\0') {
+		pnext = strpbrk(pch, " ");
+		if (!pnext)
+			break;
+		pnext++;
+		if (*pnext != '\0') {
+			/*strtou =simple_strtoul(pnext , &ptmp, 16);*/
+			ret = sscanf(pnext, "%x", &strtou);
+			pextra += sprintf(pextra, " %d", strtou);
+		} else
+			break;
+		pch = pnext;
+	}
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+int rtw_mp_start(struct net_device *dev,
+		 struct iw_request_info *info,
+		 struct iw_point *wrqu, char *extra)
+{
+	int ret = 0;
+	u8 val8;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct hal_ops *pHalFunc = &padapter->hal_func;
+
+	rtw_pm_set_ips(padapter, IPS_NONE);
+	LeaveAllPowerSaveMode(padapter);
+
+	if (rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY))
+		rtw_mi_scan_abort(padapter, _FALSE);
+
+	if (rtw_mp_cmd(padapter, MP_START, RTW_CMDF_WAIT_ACK) != _SUCCESS)
+		ret = -EPERM;
+
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "mp_start %s\n", ret == 0 ? "ok" : "fail");
+	wrqu->length = strlen(extra);
+
+	return ret;
+}
+
+
+
+int rtw_mp_stop(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra)
+{
+	int ret = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct hal_ops *pHalFunc = &padapter->hal_func;
+
+	if (rtw_mp_cmd(padapter, MP_STOP, RTW_CMDF_WAIT_ACK) != _SUCCESS)
+		ret = -EPERM;
+
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "mp_stop %s\n", ret == 0 ? "ok" : "fail");
+	wrqu->length = strlen(extra);
+
+	return ret;
+}
+
+
+int rtw_mp_rate(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra)
+{
+	u32 rate = MPT_RATE_1M;
+	u8		input[wrqu->length + 1];
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	rate = rtw_mpRateParseFunc(padapter, input);
+	padapter->mppriv.rateidx = rate;
+
+	if (rate == 0 && strcmp(input, "1M") != 0) {
+		rate = rtw_atoi(input);
+		padapter->mppriv.rateidx = MRateToHwRate(rate);
+		/*if (rate <= 0x7f)
+			rate = wifirate2_ratetbl_inx((u8)rate);
+		else if (rate < 0xC8)
+			rate = (rate - 0x79 + MPT_RATE_MCS0);
+		HT  rate 0x80(MCS0)  ~ 0x8F(MCS15) ~ 0x9F(MCS31) 128~159
+		VHT1SS~2SS rate 0xA0 (VHT1SS_MCS0 44) ~ 0xB3 (VHT2SS_MCS9 #63) 160~179
+		VHT rate 0xB4 (VHT3SS_MCS0 64) ~ 0xC7 (VHT2SS_MCS9 #83) 180~199
+		else
+		VHT rate 0x90(VHT1SS_MCS0) ~ 0x99(VHT1SS_MCS9) 144~153
+		rate =(rate - MPT_RATE_VHT1SS_MCS0);
+		*/
+	}
+	_rtw_memset(extra, 0, wrqu->length);
+
+	sprintf(extra, "Set data rate to %s index %d" , input, padapter->mppriv.rateidx);
+	RTW_INFO("%s: %s rate index=%d\n", __func__, input, padapter->mppriv.rateidx);
+
+	if (padapter->mppriv.rateidx >= DESC_RATEVHTSS4MCS9)
+		return -EINVAL;
+
+	pMptCtx->mpt_rate_index = HwRateToMPTRate(padapter->mppriv.rateidx);
+	SetDataRate(padapter);
+
+	wrqu->length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_channel(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	u8		input[wrqu->length + 1];
+	u32	channel = 1;
+	int cur_ch_offset;
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	channel = rtw_atoi(input);
+	/*RTW_INFO("%s: channel=%d\n", __func__, channel);*/
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "Change channel %d to channel %d", padapter->mppriv.channel , channel);
+	padapter->mppriv.channel = channel;
+	SetChannel(padapter);
+	pHalData->current_channel = channel;
+
+	wrqu->length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_ch_offset(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	u8		input[wrqu->length + 1];
+	u32	ch_offset = 0;
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	ch_offset = rtw_atoi(input);
+	/*RTW_INFO("%s: channel=%d\n", __func__, channel);*/
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "Change prime channel offset %d to %d", padapter->mppriv.prime_channel_offset , ch_offset);
+	padapter->mppriv.prime_channel_offset = ch_offset;
+	SetChannel(padapter);
+
+	wrqu->length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_bandwidth(struct net_device *dev,
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
+{
+	u32 bandwidth = 0, sg = 0;
+	int cur_ch_offset;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	u8		input[wrqu->length];
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	if (sscanf(input, "40M=%d,shortGI=%d", &bandwidth, &sg) > 0)
+		RTW_INFO("%s: bw=%d sg=%d\n", __func__, bandwidth , sg);
+
+	if (bandwidth == 1)
+		bandwidth = CHANNEL_WIDTH_40;
+	else if (bandwidth == 2)
+		bandwidth = CHANNEL_WIDTH_80;
+
+	padapter->mppriv.bandwidth = (u8)bandwidth;
+	padapter->mppriv.preamble = sg;
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "Change BW %d to BW %d\n", pHalData->current_channel_bw , bandwidth);
+
+	SetBandwidth(padapter);
+	pHalData->current_channel_bw = bandwidth;
+
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+int rtw_mp_txpower_index(struct net_device *dev,
+			 struct iw_request_info *info,
+			 struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char input[wrqu->length + 1];
+	u32 rfpath;
+	u32 txpower_inx;
+
+	if (wrqu->length > 128)
+		return -EFAULT;
+
+	_rtw_memset(input, 0, sizeof(input));
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+
+	rfpath = rtw_atoi(input);
+	txpower_inx = mpt_ProQueryCalTxPower(padapter, rfpath);
+	sprintf(extra, " %d", txpower_inx);
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+int rtw_mp_txpower(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+	u32 idx_a = 0, idx_b = 0, idx_c = 0, idx_d = 0, status = 0;
+	int MsetPower = 1;
+	u8		input[wrqu->length];
+
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	MsetPower = strncmp(input, "off", 3);
+	if (MsetPower == 0) {
+		padapter->mppriv.bSetTxPower = 0;
+		sprintf(extra, "MP Set power off");
+	} else {
+		if (sscanf(input, "patha=%d,pathb=%d,pathc=%d,pathd=%d", &idx_a, &idx_b, &idx_c, &idx_d) < 3)
+			RTW_INFO("Invalid format on line %s ,patha=%d,pathb=%d,pathc=%d,pathd=%d\n", input , idx_a , idx_b , idx_c , idx_d);
+
+		sprintf(extra, "Set power level path_A:%d path_B:%d path_C:%d path_D:%d", idx_a , idx_b , idx_c , idx_d);
+		padapter->mppriv.txpoweridx = (u8)idx_a;
+
+		pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)idx_a;
+		pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)idx_b;
+		pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)idx_c;
+		pMptCtx->TxPwrLevel[RF_PATH_D]  = (u8)idx_d;
+		padapter->mppriv.bSetTxPower = 1;
+
+		SetTxPower(padapter);
+	}
+
+	wrqu->length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_ant_tx(struct net_device *dev,
+		  struct iw_request_info *info,
+		  struct iw_point *wrqu, char *extra)
+{
+	u8 i;
+	u8		input[wrqu->length + 1];
+	u16 antenna = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	sprintf(extra, "switch Tx antenna to %s", input);
+
+	for (i = 0; i < strlen(input); i++) {
+		switch (input[i]) {
+		case 'a':
+			antenna |= ANTENNA_A;
+			break;
+		case 'b':
+			antenna |= ANTENNA_B;
+			break;
+		case 'c':
+			antenna |= ANTENNA_C;
+			break;
+		case 'd':
+			antenna |= ANTENNA_D;
+			break;
+		}
+	}
+	/*antenna |= BIT(extra[i]-'a');*/
+	RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
+	padapter->mppriv.antenna_tx = antenna;
+	padapter->mppriv.antenna_rx = antenna;
+	/*RTW_INFO("%s:mppriv.antenna_rx=%d\n", __func__, padapter->mppriv.antenna_tx);*/
+	pHalData->antenna_tx_path = antenna;
+
+	SetAntenna(padapter);
+
+	wrqu->length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_ant_rx(struct net_device *dev,
+		  struct iw_request_info *info,
+		  struct iw_point *wrqu, char *extra)
+{
+	u8 i;
+	u16 antenna = 0;
+	u8		input[wrqu->length + 1];
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	/*RTW_INFO("%s: input=%s\n", __func__, input);*/
+	_rtw_memset(extra, 0, wrqu->length);
+
+	sprintf(extra, "switch Rx antenna to %s", input);
+
+	for (i = 0; i < strlen(input); i++) {
+		switch (input[i]) {
+		case 'a':
+			antenna |= ANTENNA_A;
+			break;
+		case 'b':
+			antenna |= ANTENNA_B;
+			break;
+		case 'c':
+			antenna |= ANTENNA_C;
+			break;
+		case 'd':
+			antenna |= ANTENNA_D;
+			break;
+		}
+	}
+
+	RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
+	padapter->mppriv.antenna_tx = antenna;
+	padapter->mppriv.antenna_rx = antenna;
+	pHalData->AntennaRxPath = antenna;
+	/*RTW_INFO("%s:mppriv.antenna_rx=%d\n", __func__, padapter->mppriv.antenna_rx);*/
+	SetAntenna(padapter);
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+int rtw_set_ctx_destAddr(struct net_device *dev,
+			 struct iw_request_info *info,
+			 struct iw_point *wrqu, char *extra)
+{
+	int jj, kk = 0;
+
+	struct pkt_attrib *pattrib;
+	struct mp_priv *pmp_priv;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	pmp_priv = &padapter->mppriv;
+	pattrib = &pmp_priv->tx.attrib;
+
+	if (strlen(extra) < 5)
+		return _FAIL;
+
+	RTW_INFO("%s: in=%s\n", __func__, extra);
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		pattrib->dst[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+	RTW_INFO("pattrib->dst:%x %x %x %x %x %x\n", pattrib->dst[0], pattrib->dst[1], pattrib->dst[2], pattrib->dst[3], pattrib->dst[4], pattrib->dst[5]);
+	return 0;
+}
+
+
+
+int rtw_mp_ctx(struct net_device *dev,
+	       struct iw_request_info *info,
+	       struct iw_point *wrqu, char *extra)
+{
+	u32 pkTx = 1;
+	int countPkTx = 1, cotuTx = 1, CarrSprTx = 1, scTx = 1, sgleTx = 1, stop = 1;
+	u32 bStartTest = 1;
+	u32 count = 0, pktinterval = 0, pktlen = 0;
+	u8 status;
+	struct mp_priv *pmp_priv;
+	struct pkt_attrib *pattrib;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	pmp_priv = &padapter->mppriv;
+	pattrib = &pmp_priv->tx.attrib;
+
+	if (copy_from_user(extra, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	*(extra + wrqu->length) = '\0';
+	RTW_INFO("%s: in=%s\n", __func__, extra);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (!is_primary_adapter(padapter)) {
+		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
+		wrqu->length = strlen(extra);
+		return 0;
+	}
+#endif
+	countPkTx = strncmp(extra, "count=", 5); /* strncmp TRUE is 0*/
+	cotuTx = strncmp(extra, "background", 20);
+	CarrSprTx = strncmp(extra, "background,cs", 20);
+	scTx = strncmp(extra, "background,sc", 20);
+	sgleTx = strncmp(extra, "background,stone", 20);
+	pkTx = strncmp(extra, "background,pkt", 20);
+	stop = strncmp(extra, "stop", 4);
+	if (sscanf(extra, "count=%d,pkt", &count) > 0)
+		RTW_INFO("count= %d\n", count);
+	if (sscanf(extra, "pktinterval=%d", &pktinterval) > 0)
+		RTW_INFO("pktinterval= %d\n", pktinterval);
+
+	if (sscanf(extra, "pktlen=%d", &pktlen) > 0)
+		RTW_INFO("pktlen= %d\n", pktlen);
+
+	if (_rtw_memcmp(extra, "destmac=", 8)) {
+		wrqu->length -= 8;
+		rtw_set_ctx_destAddr(dev, info, wrqu, &extra[8]);
+		sprintf(extra, "Set dest mac OK !\n");
+		return 0;
+	}
+
+	/*RTW_INFO("%s: count=%d countPkTx=%d cotuTx=%d CarrSprTx=%d scTx=%d sgleTx=%d pkTx=%d stop=%d\n", __func__, count, countPkTx, cotuTx, CarrSprTx, pkTx, sgleTx, scTx, stop);*/
+	_rtw_memset(extra, '\0', strlen(extra));
+
+	if (pktinterval != 0) {
+		sprintf(extra, "Pkt Interval = %d", pktinterval);
+		padapter->mppriv.pktInterval = pktinterval;
+		wrqu->length = strlen(extra);
+		return 0;
+	}
+	if (pktlen != 0) {
+		sprintf(extra, "Pkt len = %d", pktlen);
+		pattrib->pktlen = pktlen;
+		wrqu->length = strlen(extra);
+		return 0;
+	}
+	if (stop == 0) {
+		bStartTest = 0; /* To set Stop*/
+		pmp_priv->tx.stop = 1;
+		sprintf(extra, "Stop continuous Tx");
+		odm_write_dig(&pHalData->odmpriv, 0x20);
+	} else {
+		bStartTest = 1;
+		odm_write_dig(&pHalData->odmpriv, 0x7f);
+		if (pmp_priv->mode != MP_ON) {
+			if (pmp_priv->tx.stop != 1) {
+				RTW_INFO("%s: MP_MODE != ON %d\n", __func__, pmp_priv->mode);
+				return	-EFAULT;
+			}
+		}
+	}
+
+	pmp_priv->tx.count = count;
+
+	if (pkTx == 0 || countPkTx == 0)
+		pmp_priv->mode = MP_PACKET_TX;
+	if (sgleTx == 0)
+		pmp_priv->mode = MP_SINGLE_TONE_TX;
+	if (cotuTx == 0)
+		pmp_priv->mode = MP_CONTINUOUS_TX;
+	if (CarrSprTx == 0)
+		pmp_priv->mode = MP_CARRIER_SUPPRISSION_TX;
+	if (scTx == 0)
+		pmp_priv->mode = MP_SINGLE_CARRIER_TX;
+
+	status = rtw_mp_pretx_proc(padapter, bStartTest, extra);
+
+	wrqu->length = strlen(extra);
+	return status;
+}
+
+
+
+int rtw_mp_disable_bt_coexist(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = (PADAPTER)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct hal_ops *pHalFunc = &padapter->hal_func;
+
+	u8 input[wrqu->data.length + 1];
+	u32 bt_coexist;
+
+	_rtw_memset(input, 0, sizeof(input));
+
+	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	input[wrqu->data.length] = '\0';
+
+	bt_coexist = rtw_atoi(input);
+
+	if (bt_coexist == 0) {
+		RTW_INFO("Set OID_RT_SET_DISABLE_BT_COEXIST: disable BT_COEXIST\n");
+#ifdef CONFIG_BT_COEXIST
+		rtw_btcoex_HaltNotify(padapter);
+		rtw_btcoex_SetManualControl(padapter, _TRUE);
+		/* Force to switch Antenna to WiFi*/
+		rtw_write16(padapter, 0x870, 0x300);
+		rtw_write16(padapter, 0x860, 0x110);
+#endif
+		/* CONFIG_BT_COEXIST */
+	} else {
+#ifdef CONFIG_BT_COEXIST
+		rtw_btcoex_SetManualControl(padapter, _FALSE);
+#endif
+	}
+
+	return 0;
+}
+
+
+int rtw_mp_arx(struct net_device *dev,
+	       struct iw_request_info *info,
+	       struct iw_point *wrqu, char *extra)
+{
+	int bStartRx = 0, bStopRx = 0, bQueryPhy = 0, bQueryMac = 0, bSetBssid = 0;
+	int bmac_filter = 0, bfilter_init = 0, bmon = 0, bSmpCfg = 0, bloopbk = 0;
+	u8		input[wrqu->length];
+	char *pch, *ptmp, *token, *tmp[2] = {0x00, 0x00};
+	u32 i = 0, ii = 0, jj = 0, kk = 0, cnts = 0, ret;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct mp_priv *pmppriv = &padapter->mppriv;
+	struct dbg_rx_counter rx_counter;
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	RTW_INFO("%s: %s\n", __func__, input);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (!is_primary_adapter(padapter)) {
+		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
+		wrqu->length = strlen(extra);
+		return 0;
+	}
+#endif
+	bStartRx = (strncmp(input, "start", 5) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
+	bStopRx = (strncmp(input, "stop", 5) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
+	bQueryPhy = (strncmp(input, "phy", 3) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
+	bQueryMac = (strncmp(input, "mac", 3) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
+	bSetBssid = (strncmp(input, "setbssid=", 8) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
+	/*bfilter_init = (strncmp(input, "filter_init",11)==0)?1:0;*/
+	bmac_filter = (strncmp(input, "accept_mac", 10) == 0) ? 1 : 0;
+	bmon = (strncmp(input, "mon=", 4) == 0) ? 1 : 0;
+	bSmpCfg = (strncmp(input , "smpcfg=" , 7) == 0) ? 1 : 0;
+	pmppriv->bloopback = (strncmp(input, "loopbk", 6) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
+
+	if (bSetBssid == 1) {
+		pch = input;
+		while ((token = strsep(&pch, "=")) != NULL) {
+			if (i > 1)
+				break;
+			tmp[i] = token;
+			i++;
+		}
+		if ((tmp[0] != NULL) && (tmp[1] != NULL)) {
+			cnts = strlen(tmp[1]) / 2;
+			if (cnts < 1)
+				return -EFAULT;
+			RTW_INFO("%s: cnts=%d\n", __func__, cnts);
+			RTW_INFO("%s: data=%s\n", __func__, tmp[1]);
+			for (jj = 0, kk = 0; jj < cnts ; jj++, kk += 2) {
+				pmppriv->network_macaddr[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
+				RTW_INFO("network_macaddr[%d]=%x\n", jj, pmppriv->network_macaddr[jj]);
+			}
+		} else
+			return -EFAULT;
+
+		pmppriv->bSetRxBssid = _TRUE;
+	}
+
+	if (bmac_filter) {
+		pmppriv->bmac_filter = bmac_filter;
+		pch = input;
+		while ((token = strsep(&pch, "=")) != NULL) {
+			if (i > 1)
+				break;
+			tmp[i] = token;
+			i++;
+		}
+		if ((tmp[0] != NULL) && (tmp[1] != NULL)) {
+			cnts = strlen(tmp[1]) / 2;
+			if (cnts < 1)
+				return -EFAULT;
+			RTW_INFO("%s: cnts=%d\n", __func__, cnts);
+			RTW_INFO("%s: data=%s\n", __func__, tmp[1]);
+			for (jj = 0, kk = 0; jj < cnts ; jj++, kk += 2) {
+				pmppriv->mac_filter[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
+				RTW_INFO("%s mac_filter[%d]=%x\n", __func__, jj, pmppriv->mac_filter[jj]);
+			}
+		} else
+			return -EFAULT;
+
+	}
+
+	if (bStartRx) {
+		sprintf(extra, "start");
+		SetPacketRx(padapter, bStartRx, _FALSE);
+	} else if (bStopRx) {
+		SetPacketRx(padapter, bStartRx, _FALSE);
+		pmppriv->bmac_filter = _FALSE;
+		pmppriv->bSetRxBssid = _FALSE;
+		sprintf(extra, "Received packet OK:%d CRC error:%d ,Filter out:%d", padapter->mppriv.rx_pktcount, padapter->mppriv.rx_crcerrpktcount, padapter->mppriv.rx_pktcount_filter_out);
+	} else if (bQueryPhy) {
+		_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
+		rtw_dump_phy_rx_counters(padapter, &rx_counter);
+
+		RTW_INFO("%s: OFDM_FA =%d\n", __func__, rx_counter.rx_ofdm_fa);
+		RTW_INFO("%s: CCK_FA =%d\n", __func__, rx_counter.rx_cck_fa);
+		sprintf(extra, "Phy Received packet OK:%d CRC error:%d FA Counter: %d", rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error, rx_counter.rx_cck_fa + rx_counter.rx_ofdm_fa);
+
+
+	} else if (bQueryMac) {
+		_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
+		rtw_dump_mac_rx_counters(padapter, &rx_counter);
+		sprintf(extra, "Mac Received packet OK: %d , CRC error: %d , Drop Packets: %d\n",
+			rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error, rx_counter.rx_pkt_drop);
+
+	}
+
+	if (bmon == 1) {
+		ret = sscanf(input, "mon=%d", &bmon);
+
+		if (bmon == 1) {
+			pmppriv->rx_bindicatePkt = _TRUE;
+			sprintf(extra, "Indicating Receive Packet to network start\n");
+		} else {
+			pmppriv->rx_bindicatePkt = _FALSE;
+			sprintf(extra, "Indicating Receive Packet to network Stop\n");
+		}
+	}
+	if (bSmpCfg == 1) {
+		ret = sscanf(input, "smpcfg=%d", &bSmpCfg);
+
+		if (bSmpCfg == 1) {
+			pmppriv->bRTWSmbCfg = _TRUE;
+			sprintf(extra , "Indicate By Simple Config Format\n");
+			SetPacketRx(padapter, _TRUE, _TRUE);
+		} else {
+			pmppriv->bRTWSmbCfg = _FALSE;
+			sprintf(extra , "Indicate By Normal Format\n");
+			SetPacketRx(padapter, _TRUE, _FALSE);
+		}
+	}
+
+	if (pmppriv->bloopback == _TRUE) {
+		sprintf(extra , "Enter MAC LoopBack mode\n");
+		_rtw_write32(padapter, 0x100, 0xB0106FF);
+		RTW_INFO("0x100 :0x%x" , _rtw_read32(padapter, 0x100));
+		_rtw_write16(padapter, 0x608, 0x30c);
+		RTW_INFO("0x100 :0x%x" , _rtw_read32(padapter, 0x608));
+	}
+
+	wrqu->length = strlen(extra) + 1;
+
+	return 0;
+}
+
+
+int rtw_mp_trx_query(struct net_device *dev,
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
+{
+	u32 txok, txfail, rxok, rxfail, rxfilterout;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	PMPT_CONTEXT	pMptCtx		=	&(padapter->mppriv.mpt_ctx);
+	RT_PMAC_TX_INFO	PMacTxInfo	=	pMptCtx->PMacTxInfo;
+
+	if (PMacTxInfo.bEnPMacTx == TRUE)
+		txok = hal_mpt_query_phytxok(padapter);
+	else
+		txok = padapter->mppriv.tx.sended;
+
+	txfail = 0;
+	rxok = padapter->mppriv.rx_pktcount;
+	rxfail = padapter->mppriv.rx_crcerrpktcount;
+	rxfilterout = padapter->mppriv.rx_pktcount_filter_out;
+
+	_rtw_memset(extra, '\0', 128);
+
+	sprintf(extra, "Tx OK:%d, Tx Fail:%d, Rx OK:%d, CRC error:%d ,Rx Filter out:%d\n", txok, txfail, rxok, rxfail, rxfilterout);
+
+	wrqu->length = strlen(extra) + 1;
+
+	return 0;
+}
+
+
+int rtw_mp_pwrtrk(struct net_device *dev,
+		  struct iw_request_info *info,
+		  struct iw_point *wrqu, char *extra)
+{
+	u8 enable;
+	u32 thermal;
+	s32 ret;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(padapter);
+	u8		input[wrqu->length];
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	_rtw_memset(extra, 0, wrqu->length);
+
+	enable = 1;
+	if (wrqu->length > 1) {
+		/* not empty string*/
+		if (strncmp(input, "stop", 4) == 0) {
+			enable = 0;
+			sprintf(extra, "mp tx power tracking stop");
+		} else if (sscanf(input, "ther=%d", &thermal) == 1) {
+			ret = SetThermalMeter(padapter, (u8)thermal);
+			if (ret == _FAIL)
+				return -EPERM;
+			sprintf(extra, "mp tx power tracking start,target value=%d ok", thermal);
+		} else
+			return -EINVAL;
+	}
+
+	ret = SetPowerTracking(padapter, enable);
+	if (ret == _FAIL)
+		return -EPERM;
+
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+
+int rtw_mp_psd(struct net_device *dev,
+	       struct iw_request_info *info,
+	       struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	u8		input[wrqu->length + 1];
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	strcpy(extra, input);
+
+	wrqu->length = mp_query_psd(padapter, extra);
+
+	return 0;
+}
+
+
+int rtw_mp_thermal(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+	u8 val;
+	int bwrite = 1;
+
+#ifdef CONFIG_RTL8188E
+	u16 addr = EEPROM_THERMAL_METER_88E;
+#endif
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
+	u16 addr = EEPROM_THERMAL_METER_8812;
+#endif
+#ifdef CONFIG_RTL8192E
+	u16 addr = EEPROM_THERMAL_METER_8192E;
+#endif
+#ifdef CONFIG_RTL8723B
+	u16 addr = EEPROM_THERMAL_METER_8723B;
+#endif
+#ifdef CONFIG_RTL8703B
+	u16 addr = EEPROM_THERMAL_METER_8703B;
+#endif
+#ifdef CONFIG_RTL8723D
+	u16 addr = EEPROM_THERMAL_METER_8723D;
+#endif
+#ifdef CONFIG_RTL8188F
+	u16 addr = EEPROM_THERMAL_METER_8188F;
+#endif
+#ifdef CONFIG_RTL8822B
+	u16 addr = EEPROM_THERMAL_METER_8822B;
+#endif
+#ifdef CONFIG_RTL8821C
+	u16 addr = EEPROM_THERMAL_METER_8821C;
+#endif
+	u16 cnt = 1;
+	u16 max_available_size = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (copy_from_user(extra, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	bwrite = strncmp(extra, "write", 6);/* strncmp TRUE is 0*/
+
+	GetThermalMeter(padapter, &val);
+
+	if (bwrite == 0) {
+		/*RTW_INFO("to write val:%d",val);*/
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (PVOID)&max_available_size, _FALSE);
+		if (2 > max_available_size) {
+			RTW_INFO("no available efuse!\n");
+			return -EFAULT;
+		}
+		if (rtw_efuse_map_write(padapter, addr, cnt, &val) == _FAIL) {
+			RTW_INFO("rtw_efuse_map_write error\n");
+			return -EFAULT;
+		}
+		sprintf(extra, " efuse write ok :%d", val);
+	} else
+		sprintf(extra, "%d", val);
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+
+int rtw_mp_reset_stats(struct net_device *dev,
+		       struct iw_request_info *info,
+		       struct iw_point *wrqu, char *extra)
+{
+	struct mp_priv *pmp_priv;
+	struct pkt_attrib *pattrib;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	pmp_priv = &padapter->mppriv;
+
+	pmp_priv->tx.sended = 0;
+	pmp_priv->tx_pktcount = 0;
+	pmp_priv->rx_pktcount = 0;
+	pmp_priv->rx_pktcount_filter_out = 0;
+	pmp_priv->rx_crcerrpktcount = 0;
+
+	rtw_reset_phy_rx_counters(padapter);
+	rtw_reset_mac_rx_counters(padapter);
+
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "mp_reset_stats ok\n");
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+int rtw_mp_dump(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra)
+{
+	struct mp_priv *pmp_priv;
+	struct pkt_attrib *pattrib;
+	u32 value;
+	u8		input[wrqu->length];
+	u8 rf_type, path_nums = 0;
+	u32 i, j = 1, path;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	pmp_priv = &padapter->mppriv;
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	if (strncmp(input, "all", 4) == 0) {
+		mac_reg_dump(RTW_DBGDUMP, padapter);
+		bb_reg_dump(RTW_DBGDUMP, padapter);
+		rf_reg_dump(RTW_DBGDUMP, padapter);
+	}
+	return 0;
+}
+
+
+int rtw_mp_phypara(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	char	input[wrqu->length];
+	u32		valxcap, ret;
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, input);
+
+	ret = sscanf(input, "xcap=%d", &valxcap);
+
+	pHalData->crystal_cap = (u8)valxcap;
+	hal_set_crystal_cap(padapter , valxcap);
+
+	sprintf(extra, "Set xcap=%d", valxcap);
+	wrqu->length = strlen(extra) + 1;
+
+	return 0;
+
+}
+
+
+int rtw_mp_SetRFPath(struct net_device *dev,
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char	input[wrqu->length];
+	int		bMain = 1, bTurnoff = 1;
+	u8 ret = _TRUE;
+
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, input);
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	bMain = strncmp(input, "1", 2); /* strncmp TRUE is 0*/
+	bTurnoff = strncmp(input, "0", 3); /* strncmp TRUE is 0*/
+
+	_rtw_memset(extra, 0, wrqu->length);
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	if (bMain == 0)
+		ret = rtw_mp_set_antdiv(padapter, _TRUE);
+	else
+		ret = rtw_mp_set_antdiv(padapter, _FALSE);
+	if (ret == _FALSE)
+		RTW_INFO("%s:ANTENNA_DIVERSITY FAIL\n", __func__);
+#endif
+
+	if (bMain == 0) {
+		MP_PHY_SetRFPathSwitch(padapter, _TRUE);
+		RTW_INFO("%s:PHY_SetRFPathSwitch=TRUE\n", __func__);
+		sprintf(extra, "mp_setrfpath Main\n");
+
+	} else if (bTurnoff == 0) {
+		MP_PHY_SetRFPathSwitch(padapter, _FALSE);
+		RTW_INFO("%s:PHY_SetRFPathSwitch=FALSE\n", __func__);
+		sprintf(extra, "mp_setrfpath Aux\n");
+	} else {
+		bMain = MP_PHY_QueryRFPathSwitch(padapter);
+		RTW_INFO("%s:PHY_SetRFPathSwitch = %s\n", __func__, (bMain ? "Main":"Aux"));
+		sprintf(extra, "mp_setrfpath %s\n" , (bMain ? "Main":"Aux"));
+	}
+
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+
+int rtw_mp_switch_rf_path(struct net_device *dev,
+			struct iw_request_info *info,
+			struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct mp_priv *pmp_priv;
+	char	input[wrqu->length];
+	int		bwlg = 1, bwla = 1, btg = 1, bbt=1;
+	u8 ret = 0;
+
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	pmp_priv = &padapter->mppriv;
+
+	RTW_INFO("%s: in=%s\n", __func__, input);
+
+	bwlg = strncmp(input, "WLG", 3); /* strncmp TRUE is 0*/
+	bwla = strncmp(input, "WLA", 3); /* strncmp TRUE is 0*/
+	btg = strncmp(input, "BTG", 3); /* strncmp TRUE is 0*/
+	bbt = strncmp(input, "BT", 3); /* strncmp TRUE is 0*/
+
+	_rtw_memset(extra, 0, wrqu->length);
+#ifdef CONFIG_RTL8821C /* only support for 8821c wlg/wla/btg/bt RF switch path */
+	if (bwlg == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_WLG;
+		sprintf(extra, "switch rf path WLG\n");
+	} else if (bwla == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_WLA;
+		sprintf(extra, "switch rf path WLA\n");
+	} else if (btg == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_BTG;
+		sprintf(extra, "switch rf path BTG\n");
+	} else if (bbt == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_BT;
+		sprintf(extra, "switch rf path BG\n");
+	} else {
+		sprintf(extra, "Error set %s\n", __func__);
+		return -EFAULT;
+	}
+
+	mp_phy_switch_rf_path_set(padapter, &pmp_priv->rf_path_cfg);
+#endif
+
+	wrqu->length = strlen(extra);
+
+	return ret;
+
+}
+int rtw_mp_QueryDrv(struct net_device *dev,
+		    struct iw_request_info *info,
+		    union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	char	input[wrqu->data.length];
+	int	qAutoLoad = 1;
+
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+
+	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, input);
+
+	qAutoLoad = strncmp(input, "autoload", 8); /* strncmp TRUE is 0*/
+
+	if (qAutoLoad == 0) {
+		RTW_INFO("%s:qAutoLoad\n", __func__);
+
+		if (pHalData->bautoload_fail_flag)
+			sprintf(extra, "fail");
+		else
+			sprintf(extra, "ok");
+	}
+	wrqu->data.length = strlen(extra) + 1;
+	return 0;
+}
+
+
+int rtw_mp_PwrCtlDM(struct net_device *dev,
+		    struct iw_request_info *info,
+		    struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	u8		input[wrqu->length];
+	int		bstart = 1;
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	bstart = strncmp(input, "start", 5); /* strncmp TRUE is 0*/
+	if (bstart == 0) {
+		sprintf(extra, "PwrCtlDM start\n");
+		MPT_PwrCtlDM(padapter, 1);
+	} else {
+		sprintf(extra, "PwrCtlDM stop\n");
+		MPT_PwrCtlDM(padapter, 0);
+	}
+	wrqu->length = strlen(extra);
+
+	return 0;
+}
+
+int rtw_mp_iqk(struct net_device *dev,
+		 struct iw_request_info *info,
+		 struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	rtw_mp_trigger_iqk(padapter);
+
+	return 0;
+}
+
+int rtw_mp_lck(struct net_device *dev,
+		 struct iw_request_info *info,
+		 struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	rtw_mp_trigger_lck(padapter);
+
+	return 0;
+}
+
+int rtw_mp_getver(struct net_device *dev,
+		  struct iw_request_info *info,
+		  union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct mp_priv *pmp_priv;
+
+	pmp_priv = &padapter->mppriv;
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	sprintf(extra, "rtwpriv=%d\n", RTWPRIV_VER_INFO);
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_mon(struct net_device *dev,
+	       struct iw_request_info *info,
+	       union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType;
+	int bstart = 1, bstop = 1;
+
+	networkType = Ndis802_11Infrastructure;
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+	rtw_pm_set_ips(padapter, IPS_NONE);
+	LeaveAllPowerSaveMode(padapter);
+
+#ifdef CONFIG_MP_INCLUDED
+	if (init_mp_priv(padapter) == _FAIL)
+		RTW_INFO("%s: initialize MP private data Fail!\n", __func__);
+	padapter->mppriv.channel = 6;
+
+	bstart = strncmp(extra, "start", 5); /* strncmp TRUE is 0*/
+	bstop = strncmp(extra, "stop", 4); /* strncmp TRUE is 0*/
+	if (bstart == 0) {
+		mp_join(padapter, WIFI_FW_ADHOC_STATE);
+		SetPacketRx(padapter, _TRUE, _FALSE);
+		SetChannel(padapter);
+		pmp_priv->rx_bindicatePkt = _TRUE;
+		pmp_priv->bRTWSmbCfg = _TRUE;
+		sprintf(extra, "monitor mode start\n");
+	} else if (bstop == 0) {
+		SetPacketRx(padapter, _FALSE, _FALSE);
+		pmp_priv->rx_bindicatePkt = _FALSE;
+		pmp_priv->bRTWSmbCfg = _FALSE;
+		padapter->registrypriv.mp_mode = 1;
+		pHalFunc->hal_deinit(padapter);
+		padapter->registrypriv.mp_mode = 0;
+		pHalFunc->hal_init(padapter);
+		/*rtw_disassoc_cmd(padapter, 0, 0);*/
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+			rtw_disassoc_cmd(padapter, 500, 0);
+			rtw_indicate_disconnect(padapter, 0, _FALSE);
+			/*rtw_free_assoc_resources(padapter, 1);*/
+		}
+		rtw_pm_set_ips(padapter, IPS_NORMAL);
+		sprintf(extra, "monitor mode Stop\n");
+	}
+#endif
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra)
+{
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+	char *pextra = extra;
+
+	switch (pmp_priv->mode) {
+
+	case MP_PACKET_TX:
+		if (bStartTest == 0) {
+			pmp_priv->tx.stop = 1;
+			pmp_priv->mode = MP_ON;
+			sprintf(extra, "Stop continuous Tx");
+		} else if (pmp_priv->tx.stop == 1) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "\nStart continuous DA=ffffffffffff len=1500 count=%u\n", pmp_priv->tx.count);
+			pmp_priv->tx.stop = 0;
+			SetPacketTx(padapter);
+		} else
+			return -EFAULT;
+		return 0;
+	case MP_SINGLE_TONE_TX:
+		if (bStartTest != 0)
+			strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+		SetSingleToneTx(padapter, (u8)bStartTest);
+		break;
+	case MP_CONTINUOUS_TX:
+		if (bStartTest != 0)
+			strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+		SetContinuousTx(padapter, (u8)bStartTest);
+		break;
+	case MP_CARRIER_SUPPRISSION_TX:
+		if (bStartTest != 0) {
+			if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_11M)
+				strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+			else
+				strcat(extra, "\nSpecify carrier suppression but not CCK rate");
+		}
+		SetCarrierSuppressionTx(padapter, (u8)bStartTest);
+		break;
+	case MP_SINGLE_CARRIER_TX:
+		if (bStartTest != 0)
+			strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+		SetSingleCarrierTx(padapter, (u8)bStartTest);
+		break;
+
+	default:
+		sprintf(extra, "Error! Continuous-Tx is not on-going.");
+		return -EFAULT;
+	}
+
+	if (bStartTest == 1 && pmp_priv->mode != MP_ON) {
+		struct mp_priv *pmp_priv = &padapter->mppriv;
+
+		if (pmp_priv->tx.stop == 0) {
+			pmp_priv->tx.stop = 1;
+			rtw_msleep_os(5);
+		}
+#ifdef CONFIG_80211N_HT
+		pmp_priv->tx.attrib.ht_en = 1;
+#endif
+		pmp_priv->tx.stop = 0;
+		pmp_priv->tx.count = 1;
+		SetPacketTx(padapter);
+	} else
+		pmp_priv->mode = MP_ON;
+
+#if defined(CONFIG_RTL8812A)
+	if (IS_HARDWARE_TYPE_8812AU(padapter)) {
+		/* <20130425, Kordan> Turn off OFDM Rx to prevent from CCA causing Tx hang.*/
+		if (pmp_priv->mode == MP_PACKET_TX)
+			phy_set_bb_reg(padapter, rCCAonSec_Jaguar, BIT3, 1);
+		else
+			phy_set_bb_reg(padapter, rCCAonSec_Jaguar, BIT3, 0);
+	}
+#endif
+
+	return 0;
+}
+
+
+int rtw_mp_tx(struct net_device *dev,
+	      struct iw_request_info *info,
+	      union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	char *pextra = extra;
+	u32 bandwidth = 0, sg = 0, channel = 6, txpower = 40, rate = 108, ant = 0, txmode = 1, count = 0;
+	u8 i = 0, j = 0, bStartTest = 1, status = 0, Idx = 0, tmpU1B = 0;
+	u16 antenna = 0;
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+	RTW_INFO("extra = %s\n", extra);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (!is_primary_adapter(padapter)) {
+		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
+#endif
+
+	if (strncmp(extra, "stop", 3) == 0) {
+		bStartTest = 0; /* To set Stop*/
+		pmp_priv->tx.stop = 1;
+		sprintf(extra, "Stop continuous Tx");
+		status = rtw_mp_pretx_proc(padapter, bStartTest, extra);
+		wrqu->data.length = strlen(extra);
+		return status;
+	} else if (strncmp(extra, "count", 5) == 0) {
+		if (sscanf(extra, "count=%d", &count) < 1)
+			RTW_INFO("Got Count=%d]\n", count);
+		pmp_priv->tx.count = count;
+		return 0;
+	} else if (strncmp(extra, "setting", 7) == 0) {
+		_rtw_memset(extra, 0, wrqu->data.length);
+		pextra += sprintf(pextra, "Current Setting :\n Channel:%d", pmp_priv->channel);
+		pextra += sprintf(pextra, "\n Bandwidth:%d", pmp_priv->bandwidth);
+		pextra += sprintf(pextra, "\n Rate index:%d", pmp_priv->rateidx);
+		pextra += sprintf(pextra, "\n TxPower index:%d", pmp_priv->txpoweridx);
+		pextra += sprintf(pextra, "\n Antenna TxPath:%d", pmp_priv->antenna_tx);
+		pextra += sprintf(pextra, "\n Antenna RxPath:%d", pmp_priv->antenna_rx);
+		pextra += sprintf(pextra, "\n MP Mode:%d", pmp_priv->mode);
+		wrqu->data.length = strlen(extra);
+		return 0;
+#ifdef CONFIG_MP_VHT_HW_TX_MODE
+	} else if (strncmp(extra, "pmact", 5) == 0) {
+		if (strncmp(extra, "pmact=", 6) == 0) {
+			_rtw_memset(&pMptCtx->PMacTxInfo, 0, sizeof(pMptCtx->PMacTxInfo));
+			if (strncmp(extra, "pmact=start", 11) == 0) {
+				pMptCtx->PMacTxInfo.bEnPMacTx = _TRUE;
+				sprintf(extra, "Set PMac Tx Mode start\n");
+			} else {
+				pMptCtx->PMacTxInfo.bEnPMacTx = _FALSE;
+				sprintf(extra, "Set PMac Tx Mode Stop\n");
+			}
+			if (pMptCtx->bldpc == TRUE)
+				pMptCtx->PMacTxInfo.bLDPC = _TRUE;
+
+			if (pMptCtx->bstbc == TRUE)
+				pMptCtx->PMacTxInfo.bSTBC = _TRUE;
+
+			pMptCtx->PMacTxInfo.bSPreamble = pmp_priv->preamble;
+			pMptCtx->PMacTxInfo.bSGI = pmp_priv->preamble;
+			pMptCtx->PMacTxInfo.BandWidth = pmp_priv->bandwidth;
+			pMptCtx->PMacTxInfo.TX_RATE = HwRateToMPTRate(pmp_priv->rateidx);
+
+			pMptCtx->PMacTxInfo.Mode = pMptCtx->HWTxmode;
+
+			pMptCtx->PMacTxInfo.NDP_sound = FALSE;/*(Adapter.PacketType == NDP_PKT)?TRUE:FALSE;*/
+
+			if (padapter->mppriv.pktInterval == 0)
+				pMptCtx->PMacTxInfo.PacketPeriod = 100;
+			else
+				pMptCtx->PMacTxInfo.PacketPeriod = padapter->mppriv.pktInterval;
+
+			if (padapter->mppriv.pktLength < 1000)
+				pMptCtx->PMacTxInfo.PacketLength = 1000;
+			else
+				pMptCtx->PMacTxInfo.PacketLength = padapter->mppriv.pktLength;
+
+			pMptCtx->PMacTxInfo.PacketPattern  = rtw_random32() % 0xFF;
+
+			if (padapter->mppriv.tx_pktcount != 0)
+				pMptCtx->PMacTxInfo.PacketCount = padapter->mppriv.tx_pktcount;
+
+			pMptCtx->PMacTxInfo.Ntx = 0;
+			for (Idx = 16; Idx < 20; Idx++) {
+				tmpU1B = (padapter->mppriv.antenna_tx >> Idx) & 1;
+				if (tmpU1B)
+					pMptCtx->PMacTxInfo.Ntx++;
+			}
+
+			_rtw_memset(pMptCtx->PMacTxInfo.MacAddress, 0xFF, ETH_ALEN);
+
+			PMAC_Get_Pkt_Param(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+
+			if (MPT_IS_CCK_RATE(pMptCtx->PMacTxInfo.TX_RATE))
+
+				CCK_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+			else {
+				PMAC_Nsym_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+				/* 24 BIT*/
+				L_SIG_generator(pMptCtx->PMacPktInfo.N_sym, &pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+			}
+			/*	48BIT*/
+			if (MPT_IS_HT_RATE(pMptCtx->PMacTxInfo.TX_RATE))
+				HT_SIG_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+			else if (MPT_IS_VHT_RATE(pMptCtx->PMacTxInfo.TX_RATE)) {
+				/*	48BIT*/
+				VHT_SIG_A_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+
+				/*	26/27/29 BIT  & CRC 8 BIT*/
+				VHT_SIG_B_generator(&pMptCtx->PMacTxInfo);
+
+				/* 32 BIT*/
+				VHT_Delimiter_generator(&pMptCtx->PMacTxInfo);
+			}
+
+			mpt_ProSetPMacTx(padapter);
+
+		} else if (strncmp(extra, "pmact,mode=", 11) == 0) {
+			int txmode = 0;
+
+			if (sscanf(extra, "pmact,mode=%d", &txmode) > 0) {
+				if (txmode == 1) {
+					pMptCtx->HWTxmode = CONTINUOUS_TX;
+					sprintf(extra, "\t Config HW Tx mode = CONTINUOUS_TX\n");
+				} else if (txmode == 2) {
+					pMptCtx->HWTxmode = OFDM_Single_Tone_TX;
+					sprintf(extra, "\t Config HW Tx mode = OFDM_Single_Tone_TX\n");
+				} else {
+					pMptCtx->HWTxmode = PACKETS_TX;
+					sprintf(extra, "\t Config HW Tx mode = PACKETS_TX\n");
+				}
+			} else {
+				pMptCtx->HWTxmode = PACKETS_TX;
+				sprintf(extra, "\t Config HW Tx mode=\n 0 = PACKETS_TX\n 1 = CONTINUOUS_TX\n 2 = OFDM_Single_Tone_TX");
+			}
+		} else if (strncmp(extra, "pmact,", 6) == 0) {
+			int PacketPeriod = 0, PacketLength = 0, PacketCout = 0;
+			int bldpc = 0, bstbc = 0;
+
+			if (sscanf(extra, "pmact,period=%d", &PacketPeriod) > 0) {
+				padapter->mppriv.pktInterval = PacketPeriod;
+				RTW_INFO("PacketPeriod=%d\n", padapter->mppriv.pktInterval);
+				sprintf(extra, "PacketPeriod [1~255]= %d\n", padapter->mppriv.pktInterval);
+
+			} else if (sscanf(extra, "pmact,length=%d", &PacketLength) > 0) {
+				padapter->mppriv.pktLength = PacketLength;
+				RTW_INFO("PacketPeriod=%d\n", padapter->mppriv.pktLength);
+				sprintf(extra, "PacketLength[~65535]=%d\n", padapter->mppriv.pktLength);
+
+			} else if (sscanf(extra, "pmact,count=%d", &PacketCout) > 0) {
+				padapter->mppriv.tx_pktcount = PacketCout;
+				RTW_INFO("Packet Cout =%d\n", padapter->mppriv.tx_pktcount);
+				sprintf(extra, "Packet Cout =%d\n", padapter->mppriv.tx_pktcount);
+
+			} else if (sscanf(extra, "pmact,ldpc=%d", &bldpc) > 0) {
+				pMptCtx->bldpc = bldpc;
+				RTW_INFO("Set LDPC =%d\n", pMptCtx->bldpc);
+				sprintf(extra, "Set LDPC =%d\n", pMptCtx->bldpc);
+
+			} else if (sscanf(extra, "pmact,stbc=%d", &bstbc) > 0) {
+				pMptCtx->bstbc = bstbc;
+				RTW_INFO("Set STBC =%d\n", pMptCtx->bstbc);
+				sprintf(extra, "Set STBC =%d\n", pMptCtx->bstbc);
+			} else
+				sprintf(extra, "\n period={1~255}\n length={1000~65535}\n count={0~}\n ldpc={0/1}\n stbc={0/1}");
+
+		}
+
+		wrqu->data.length = strlen(extra);
+		return 0;
+#endif
+	} else {
+
+		if (sscanf(extra, "ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d", &channel, &bandwidth, &rate, &txpower, &ant, &txmode) < 6) {
+			RTW_INFO("Invalid format [ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d]\n", channel, bandwidth, rate, txpower, ant, txmode);
+			_rtw_memset(extra, 0, wrqu->data.length);
+			pextra += sprintf(pextra, "\n Please input correct format as bleow:\n");
+			pextra += sprintf(pextra, "\t ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d\n", channel, bandwidth, rate, txpower, ant, txmode);
+			pextra += sprintf(pextra, "\n [ ch : BGN = <1~14> , A or AC = <36~165> ]");
+			pextra += sprintf(pextra, "\n [ bw : Bandwidth: 0 = 20M, 1 = 40M, 2 = 80M ]");
+			pextra += sprintf(pextra, "\n [ rate :	CCK: 1 2 5.5 11M X 2 = < 2 4 11 22 >]");
+			pextra += sprintf(pextra, "\n [		OFDM: 6 9 12 18 24 36 48 54M X 2 = < 12 18 24 36 48 72 96 108>");
+			pextra += sprintf(pextra, "\n [		HT 1S2SS MCS0 ~ MCS15 : < [MCS0]=128 ~ [MCS7]=135 ~ [MCS15]=143 >");
+			pextra += sprintf(pextra, "\n [		HT 3SS MCS16 ~ MCS32 : < [MCS16]=144 ~ [MCS23]=151 ~ [MCS32]=159 >");
+			pextra += sprintf(pextra, "\n [		VHT 1SS MCS0 ~ MCS9 : < [MCS0]=160 ~ [MCS9]=169 >");
+			pextra += sprintf(pextra, "\n [ txpower : 1~63 power index");
+			pextra += sprintf(pextra, "\n [ ant : <A = 1, B = 2, C = 4, D = 8> ,2T ex: AB=3 BC=6 CD=12");
+			pextra += sprintf(pextra, "\n [ txmode : < 0 = CONTINUOUS_TX, 1 = PACKET_TX, 2 = SINGLE_TONE_TX, 3 = CARRIER_SUPPRISSION_TX, 4 = SINGLE_CARRIER_TX>\n");
+			wrqu->data.length = strlen(extra);
+			return status;
+
+		} else {
+			char *pextra = extra;
+			RTW_INFO("Got format [ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d]\n", channel, bandwidth, rate, txpower, ant, txmode);
+			_rtw_memset(extra, 0, wrqu->data.length);
+			sprintf(extra, "Change Current channel %d to channel %d", padapter->mppriv.channel , channel);
+			padapter->mppriv.channel = channel;
+			SetChannel(padapter);
+			pHalData->current_channel = channel;
+
+			if (bandwidth == 1)
+				bandwidth = CHANNEL_WIDTH_40;
+			else if (bandwidth == 2)
+				bandwidth = CHANNEL_WIDTH_80;
+			pextra = extra + strlen(pextra);
+			pextra += sprintf(pextra, "\nChange Current Bandwidth %d to Bandwidth %d", padapter->mppriv.bandwidth, bandwidth);
+			padapter->mppriv.bandwidth = (u8)bandwidth;
+			padapter->mppriv.preamble = sg;
+			SetBandwidth(padapter);
+			pHalData->current_channel_bw = bandwidth;
+
+			pextra += sprintf(pextra, "\nSet power level :%d", txpower);
+			padapter->mppriv.txpoweridx = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_D]  = (u8)txpower;
+			SetTxPower(padapter);
+
+			RTW_INFO("%s: bw=%d sg=%d\n", __func__, bandwidth, sg);
+
+			if (rate <= 0x7f)
+				rate = wifirate2_ratetbl_inx((u8)rate);
+			else if (rate < 0xC8)
+				rate = (rate - 0x80 + MPT_RATE_MCS0);
+			/*HT  rate 0x80(MCS0)  ~ 0x8F(MCS15) ~ 0x9F(MCS31) 128~159
+			VHT1SS~2SS rate 0xA0 (VHT1SS_MCS0 44) ~ 0xB3 (VHT2SS_MCS9 #63) 160~179
+			VHT rate 0xB4 (VHT3SS_MCS0 64) ~ 0xC7 (VHT2SS_MCS9 #83) 180~199
+			else
+			VHT rate 0x90(VHT1SS_MCS0) ~ 0x99(VHT1SS_MCS9) 144~153
+			rate =(rate - MPT_RATE_VHT1SS_MCS0);
+			*/
+			RTW_INFO("%s: rate index=%d\n", __func__, rate);
+			if (rate >= MPT_RATE_LAST)
+				return -EINVAL;
+			pextra += sprintf(pextra, "\nSet data rate to %d index %d", padapter->mppriv.rateidx, rate);
+
+			padapter->mppriv.rateidx = rate;
+			pMptCtx->mpt_rate_index = rate;
+			SetDataRate(padapter);
+
+			pextra += sprintf(pextra, "\nSet Antenna Path :%d", ant);
+			switch (ant) {
+			case 1:
+				antenna = ANTENNA_A;
+				break;
+			case 2:
+				antenna = ANTENNA_B;
+				break;
+			case 4:
+				antenna = ANTENNA_C;
+				break;
+			case 8:
+				antenna = ANTENNA_D;
+				break;
+			case 3:
+				antenna = ANTENNA_AB;
+				break;
+			case 5:
+				antenna = ANTENNA_AC;
+				break;
+			case 9:
+				antenna = ANTENNA_AD;
+				break;
+			case 6:
+				antenna = ANTENNA_BC;
+				break;
+			case 10:
+				antenna = ANTENNA_BD;
+				break;
+			case 12:
+				antenna = ANTENNA_CD;
+				break;
+			case 7:
+				antenna = ANTENNA_ABC;
+				break;
+			case 14:
+				antenna = ANTENNA_BCD;
+				break;
+			case 11:
+				antenna = ANTENNA_ABD;
+				break;
+			case 15:
+				antenna = ANTENNA_ABCD;
+				break;
+			}
+			RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
+			padapter->mppriv.antenna_tx = antenna;
+			padapter->mppriv.antenna_rx = antenna;
+			pHalData->antenna_tx_path = antenna;
+			SetAntenna(padapter);
+
+			if (txmode == 0)
+				pmp_priv->mode = MP_CONTINUOUS_TX;
+			else if (txmode == 1) {
+				pmp_priv->mode = MP_PACKET_TX;
+				pmp_priv->tx.count = count;
+			} else if (txmode == 2)
+				pmp_priv->mode = MP_SINGLE_TONE_TX;
+			else if (txmode == 3)
+				pmp_priv->mode = MP_CARRIER_SUPPRISSION_TX;
+			else if (txmode == 4)
+				pmp_priv->mode = MP_SINGLE_CARRIER_TX;
+
+			status = rtw_mp_pretx_proc(padapter, bStartTest, extra);
+		}
+
+	}
+
+	wrqu->data.length = strlen(extra);
+	return status;
+}
+
+
+int rtw_mp_rx(struct net_device *dev,
+	      struct iw_request_info *info,
+	      union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+	char *pextra = extra;
+	u32 bandwidth = 0, sg = 0, channel = 6, ant = 0;
+	u16 antenna = 0;
+	u8 bStartRx = 0;
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (!is_primary_adapter(padapter)) {
+		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
+#endif
+
+	if (strncmp(extra, "stop", 4) == 0) {
+		_rtw_memset(extra, 0, wrqu->data.length);
+		SetPacketRx(padapter, bStartRx, _FALSE);
+		pmp_priv->bmac_filter = _FALSE;
+		sprintf(extra, "Received packet OK:%d CRC error:%d ,Filter out:%d", padapter->mppriv.rx_pktcount, padapter->mppriv.rx_crcerrpktcount, padapter->mppriv.rx_pktcount_filter_out);
+		wrqu->data.length = strlen(extra);
+		return 0;
+
+	} else if (sscanf(extra, "ch=%d,bw=%d,ant=%d", &channel, &bandwidth, &ant) < 3) {
+		RTW_INFO("Invalid format [ch=%d,bw=%d,ant=%d]\n", channel, bandwidth, ant);
+		_rtw_memset(extra, 0, wrqu->data.length);
+		pextra += sprintf(pextra, "\n Please input correct format as bleow:\n");
+		pextra += sprintf(pextra, "\t ch=%d,bw=%d,ant=%d\n", channel, bandwidth, ant);
+		pextra += sprintf(pextra, "\n [ ch : BGN = <1~14> , A or AC = <36~165> ]");
+		pextra += sprintf(pextra, "\n [ bw : Bandwidth: 0 = 20M, 1 = 40M, 2 = 80M ]");
+		pextra += sprintf(pextra, "\n [ ant : <A = 1, B = 2, C = 4, D = 8> ,2T ex: AB=3 BC=6 CD=12");
+		wrqu->data.length = strlen(extra);
+		return 0;
+
+	} else {
+		char *pextra = extra;
+		bStartRx = 1;
+		RTW_INFO("Got format [ch=%d,bw=%d,ant=%d]\n", channel, bandwidth, ant);
+		_rtw_memset(extra, 0, wrqu->data.length);
+		sprintf(extra, "Change Current channel %d to channel %d", padapter->mppriv.channel , channel);
+		padapter->mppriv.channel = channel;
+		SetChannel(padapter);
+		pHalData->current_channel = channel;
+
+		if (bandwidth == 1)
+			bandwidth = CHANNEL_WIDTH_40;
+		else if (bandwidth == 2)
+			bandwidth = CHANNEL_WIDTH_80;
+		pextra = extra + strlen(extra);
+		pextra += sprintf(pextra, "\nChange Current Bandwidth %d to Bandwidth %d", padapter->mppriv.bandwidth, bandwidth);
+		padapter->mppriv.bandwidth = (u8)bandwidth;
+		padapter->mppriv.preamble = sg;
+		SetBandwidth(padapter);
+		pHalData->current_channel_bw = bandwidth;
+
+		pextra += sprintf(pextra, "\nSet Antenna Path :%d", ant);
+		switch (ant) {
+		case 1:
+			antenna = ANTENNA_A;
+			break;
+		case 2:
+			antenna = ANTENNA_B;
+			break;
+		case 4:
+			antenna = ANTENNA_C;
+			break;
+		case 8:
+			antenna = ANTENNA_D;
+			break;
+		case 3:
+			antenna = ANTENNA_AB;
+			break;
+		case 5:
+			antenna = ANTENNA_AC;
+			break;
+		case 9:
+			antenna = ANTENNA_AD;
+			break;
+		case 6:
+			antenna = ANTENNA_BC;
+			break;
+		case 10:
+			antenna = ANTENNA_BD;
+			break;
+		case 12:
+			antenna = ANTENNA_CD;
+			break;
+		case 7:
+			antenna = ANTENNA_ABC;
+			break;
+		case 14:
+			antenna = ANTENNA_BCD;
+			break;
+		case 11:
+			antenna = ANTENNA_ABD;
+			break;
+		case 15:
+			antenna = ANTENNA_ABCD;
+			break;
+		}
+		RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
+		padapter->mppriv.antenna_tx = antenna;
+		padapter->mppriv.antenna_rx = antenna;
+		pHalData->antenna_tx_path = antenna;
+		SetAntenna(padapter);
+
+		strcat(extra, "\nstart Rx");
+		SetPacketRx(padapter, bStartRx, _FALSE);
+	}
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_hwtx(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8821B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	u8		input[wrqu->data.length];
+
+	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	_rtw_memset(&pMptCtx->PMacTxInfo, 0, sizeof(RT_PMAC_TX_INFO));
+	_rtw_memcpy((void *)&pMptCtx->PMacTxInfo, (void *)input, sizeof(RT_PMAC_TX_INFO));
+	_rtw_memset(wrqu->data.pointer, 0, wrqu->data.length);
+
+	if (pMptCtx->PMacTxInfo.bEnPMacTx == 1 && pmp_priv->mode != MP_ON) {
+		sprintf(extra, "MP Tx Running, Please Set PMac Tx Mode Stop\n");
+		RTW_INFO("Error !!! MP Tx Running, Please Set PMac Tx Mode Stop\n");
+	} else {
+		RTW_INFO("To set MAC Tx mode\n");
+		mpt_ProSetPMacTx(padapter);
+		sprintf(extra, "Set PMac Tx Mode OK\n");
+	}
+	wrqu->data.length = strlen(extra);
+#endif
+	return 0;
+
+}
+
+int rtw_mp_pwrlmt(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct registry_priv  *registry_par = &padapter->registrypriv;
+	u8 pwrlimtstat = 0;
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+#ifdef CONFIG_TXPWR_LIMIT
+	pwrlimtstat = registry_par->RegEnableTxPowerLimit;
+	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
+		padapter->registrypriv.RegEnableTxPowerLimit = 0;
+		sprintf(extra, "Turn off Power Limit\n");
+
+	} else if (strncmp(extra, "on", 2) == 0 && strlen(extra) < 3) {
+		padapter->registrypriv.RegEnableTxPowerLimit = 1;
+		sprintf(extra, "Turn on Power Limit\n");
+
+	} else
+#endif
+		sprintf(extra, "Get Power Limit Status:%s\n", (pwrlimtstat == 1) ? "ON" : "OFF");
+
+
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+int rtw_mp_pwrbyrate(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
+		padapter->registrypriv.RegEnableTxPowerByRate = 0;
+		sprintf(extra, "Turn off Tx Power by Rate\n");
+
+	} else if (strncmp(extra, "on", 2) == 0 && strlen(extra) < 3) {
+		padapter->registrypriv.RegEnableTxPowerByRate = 1;
+		sprintf(extra, "Turn On Tx Power by Rate\n");
+
+	} else {
+		sprintf(extra, "Get Power by Rate Status:%s\n", (padapter->registrypriv.RegEnableTxPowerByRate == 1) ? "ON" : "OFF");
+	}
+
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+int rtw_efuse_mask_file(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	char *rtw_efuse_mask_file_path;
+	u8 Status;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	_rtw_memset(maskfileBuffer, 0x00, sizeof(maskfileBuffer));
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
+		padapter->registrypriv.boffefusemask = 1;
+		sprintf(extra, "Turn off Efuse Mask\n");
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
+	if (strncmp(extra, "on", 2) == 0 && strlen(extra) < 3) {
+		padapter->registrypriv.boffefusemask = 0;
+		sprintf(extra, "Turn on Efuse Mask\n");
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
+	if (strncmp(extra, "data,", 5) == 0) {
+		u8	*pch, *pdata;
+		char	*ptmp, tmp;
+		u8	count = 0;
+		u8	i = 0;
+		u32	datalen = 0;
+
+		ptmp = extra;
+		pch = strsep(&ptmp, ",");
+
+		if ((pch == NULL) || (strlen(pch) == 0)) {
+			RTW_INFO("%s: parameter error(no cmd)!\n", __func__);
+			return -EFAULT;
+		}
+
+		do {
+			pch = strsep(&ptmp, ":");
+			if ((pch == NULL) || (strlen(pch) == 0))
+				break;
+			if (strlen(pch) != 2
+				|| IsHexDigit(*pch) == _FALSE
+				|| IsHexDigit(*(pch + 1)) == _FALSE
+				|| sscanf(pch, "%hhx", &tmp) != 1
+			) {
+				RTW_INFO("%s: invalid 8-bit hex! input format: data,01:23:45:67:89:ab:cd:ef...\n", __func__);
+				return -EFAULT;
+			}
+			maskfileBuffer[count++] = tmp;
+
+		 } while (count < 64);
+
+		for (i = 0; i < count; i++)
+			sprintf(extra, "%s:%02x", extra, maskfileBuffer[i]);
+
+		padapter->registrypriv.bFileMaskEfuse = _TRUE;
+
+		sprintf(extra, "%s\nLoad Efuse Mask data %d hex ok\n", extra, count);
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
+	rtw_efuse_mask_file_path = extra;
+
+	if (rtw_is_file_readable(rtw_efuse_mask_file_path) == _TRUE) {
+		RTW_INFO("%s do rtw_efuse_mask_file_read = %s! ,sizeof maskfileBuffer %zu\n", __func__, rtw_efuse_mask_file_path, sizeof(maskfileBuffer));
+		Status = rtw_efuse_file_read(padapter, rtw_efuse_mask_file_path, maskfileBuffer, sizeof(maskfileBuffer));
+		if (Status == _TRUE) {
+			padapter->registrypriv.bFileMaskEfuse = _TRUE;
+			sprintf(extra, "efuse mask file read OK\n");
+		} else {
+			padapter->registrypriv.bFileMaskEfuse = _FALSE;
+			sprintf(extra, "read efuse mask file FAIL\n");
+			RTW_INFO("%s rtw_efuse_file_read mask fail!\n", __func__);
+		}
+	} else {
+		padapter->registrypriv.bFileMaskEfuse = _FALSE;
+		sprintf(extra, "efuse mask file readable FAIL\n");
+		RTW_INFO("%s rtw_is_file_readable fail!\n", __func__);
+	}
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_efuse_file_map(struct net_device *dev,
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
+{
+	char *rtw_efuse_file_map_path;
+	u8 Status;
+	PEFUSE_HAL pEfuseHal;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+
+	pEfuseHal = &pHalData->EfuseHal;
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	rtw_efuse_file_map_path = extra;
+
+	_rtw_memset(pEfuseHal->fakeEfuseModifiedMap, 0xFF, EFUSE_MAX_MAP_LEN);
+
+	if (rtw_is_file_readable(rtw_efuse_file_map_path) == _TRUE) {
+		RTW_INFO("%s do rtw_efuse_mask_file_read = %s!\n", __func__, rtw_efuse_file_map_path);
+		Status = rtw_efuse_file_read(padapter, rtw_efuse_file_map_path, pEfuseHal->fakeEfuseModifiedMap, sizeof(pEfuseHal->fakeEfuseModifiedMap));
+		if (Status == _TRUE) {
+			pmp_priv->bloadefusemap = _TRUE;
+			sprintf(extra, "efuse file file_read OK\n");
+		} else {
+			pmp_priv->bloadefusemap = _FALSE;
+			sprintf(extra, "efuse file file_read FAIL\n");
+		}
+	} else {
+		sprintf(extra, "efuse file readable FAIL\n");
+		RTW_INFO("%s rtw_is_file_readable fail!\n", __func__);
+	}
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+int rtw_bt_efuse_file_map(struct net_device *dev,
+				struct iw_request_info *info,
+				union iwreq_data *wrqu, char *extra)
+{
+	char *rtw_efuse_file_map_path;
+	u8 Status;
+	PEFUSE_HAL pEfuseHal;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+
+	pEfuseHal = &pHalData->EfuseHal;
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	rtw_efuse_file_map_path = extra;
+
+	_rtw_memset(pEfuseHal->fakeBTEfuseModifiedMap, 0xFF, EFUSE_BT_MAX_MAP_LEN);
+
+	if (rtw_is_file_readable(rtw_efuse_file_map_path) == _TRUE) {
+		RTW_INFO("%s do rtw_efuse_mask_file_read = %s!\n", __func__, rtw_efuse_file_map_path);
+		Status = rtw_efuse_file_read(padapter, rtw_efuse_file_map_path, pEfuseHal->fakeBTEfuseModifiedMap, sizeof(pEfuseHal->fakeBTEfuseModifiedMap));
+		if (Status == _TRUE) {
+			pmp_priv->bloadBTefusemap = _TRUE;
+			sprintf(extra, "BT efuse file file_read OK\n");
+		} else {
+			pmp_priv->bloadBTefusemap = _FALSE;
+			sprintf(extra, "BT efuse file file_read FAIL\n");
+		}
+	} else {
+		sprintf(extra, "BT efuse file readable FAIL\n");
+		RTW_INFO("%s rtw_is_file_readable fail!\n", __func__);
+	}
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+#if defined(CONFIG_RTL8723B)
+int rtw_mp_SetBT(struct net_device *dev,
+		 struct iw_request_info *info,
+		 union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct hal_ops *pHalFunc = &padapter->hal_func;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	BT_REQ_CMD	BtReq;
+	PMPT_CONTEXT	pMptCtx = &(padapter->mppriv.mpt_ctx);
+	PBT_RSP_CMD	pBtRsp = (PBT_RSP_CMD)&pMptCtx->mptOutBuf[0];
+	char	input[128];
+	char *pch, *ptmp, *token, *tmp[2] = {0x00, 0x00};
+	u8 setdata[100];
+	u8 resetbt = 0x00;
+	u8 tempval, BTStatus;
+	u8 H2cSetbtmac[6];
+	u8 u1H2CBtMpOperParm[4] = {0x01};
+	int testmode = 1, ready = 1, trxparam = 1, setgen = 1, getgen = 1, testctrl = 1, testbt = 1, readtherm = 1, setbtmac = 1;
+	u32 i = 0, ii = 0, jj = 0, kk = 0, cnts = 0, status = 0;
+	PRT_MP_FIRMWARE pBTFirmware = NULL;
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+
+	if (strlen(extra) < 1)
+		return -EFAULT;
+
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, extra);
+	ready = strncmp(extra, "ready", 5);
+	testmode = strncmp(extra, "testmode", 8); /* strncmp TRUE is 0*/
+	trxparam = strncmp(extra, "trxparam", 8);
+	setgen = strncmp(extra, "setgen", 6);
+	getgen = strncmp(extra, "getgen", 6);
+	testctrl = strncmp(extra, "testctrl", 8);
+	testbt = strncmp(extra, "testbt", 6);
+	readtherm = strncmp(extra, "readtherm", 9);
+	setbtmac = strncmp(extra, "setbtmac", 8);
+
+	if (strncmp(extra, "dlbt", 4) == 0) {
+		pHalData->LastHMEBoxNum = 0;
+		pHalData->bBTFWReady = _FALSE;
+		rtw_write8(padapter, 0xa3, 0x05);
+		BTStatus = rtw_read8(padapter, 0xa0);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __func__, BTStatus);
+		if (BTStatus != 0x04) {
+			sprintf(extra, "BT Status not Active DLFW FAIL\n");
+			goto exit;
+		}
+
+		tempval = rtw_read8(padapter, 0x6B);
+		tempval |= BIT7;
+		rtw_write8(padapter, 0x6B, tempval);
+
+		/* Attention!! Between 0x6A[14] and 0x6A[15] setting need 100us delay*/
+		/* So don't write 0x6A[14]=1 and 0x6A[15]=0 together!*/
+		rtw_usleep_os(100);
+		/* disable BT power cut*/
+		/* 0x6A[14] = 0*/
+		tempval = rtw_read8(padapter, 0x6B);
+		tempval &= ~BIT6;
+		rtw_write8(padapter, 0x6B, tempval);
+		rtw_usleep_os(100);
+		MPT_PwrCtlDM(padapter, 0);
+		rtw_write32(padapter, 0xcc, (rtw_read32(padapter, 0xcc) | 0x00000004));
+		rtw_write32(padapter, 0x6b, (rtw_read32(padapter, 0x6b) & 0xFFFFFFEF));
+		rtw_msleep_os(600);
+		rtw_write32(padapter, 0x6b, (rtw_read32(padapter, 0x6b) | 0x00000010));
+		rtw_write32(padapter, 0xcc, (rtw_read32(padapter, 0xcc) & 0xFFFFFFFB));
+		rtw_msleep_os(1200);
+		pBTFirmware = (PRT_MP_FIRMWARE)rtw_zmalloc(sizeof(RT_MP_FIRMWARE));
+		if (pBTFirmware == NULL)
+			goto exit;
+		pHalData->bBTFWReady = _FALSE;
+		FirmwareDownloadBT(padapter, pBTFirmware);
+		if (pBTFirmware)
+			rtw_mfree((u8 *)pBTFirmware, sizeof(RT_MP_FIRMWARE));
+
+		RTW_INFO("Wait for FirmwareDownloadBT fw boot!\n");
+		rtw_msleep_os(2000);
+		_rtw_memset(extra, '\0', wrqu->data.length);
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 0;
+		BtReq.paraLength = 0;
+		mptbt_BtControlProcess(padapter, &BtReq);
+		rtw_msleep_os(100);
+
+		RTW_INFO("FirmwareDownloadBT ready = 0x%x 0x%x", pMptCtx->mptOutBuf[4], pMptCtx->mptOutBuf[5]);
+		if ((pMptCtx->mptOutBuf[4] == 0x00) && (pMptCtx->mptOutBuf[5] == 0x00)) {
+
+			if (padapter->mppriv.bTxBufCkFail == _TRUE)
+				sprintf(extra, "check TxBuf Fail.\n");
+			else
+				sprintf(extra, "download FW Fail.\n");
+		} else {
+			sprintf(extra, "download FW OK.\n");
+			goto exit;
+		}
+		goto exit;
+	}
+	if (strncmp(extra, "dlfw", 4) == 0) {
+		pHalData->LastHMEBoxNum = 0;
+		pHalData->bBTFWReady = _FALSE;
+		rtw_write8(padapter, 0xa3, 0x05);
+		BTStatus = rtw_read8(padapter, 0xa0);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __func__, BTStatus);
+		if (BTStatus != 0x04) {
+			sprintf(extra, "BT Status not Active DLFW FAIL\n");
+			goto exit;
+		}
+
+		tempval = rtw_read8(padapter, 0x6B);
+		tempval |= BIT7;
+		rtw_write8(padapter, 0x6B, tempval);
+
+		/* Attention!! Between 0x6A[14] and 0x6A[15] setting need 100us delay*/
+		/* So don't write 0x6A[14]=1 and 0x6A[15]=0 together!*/
+		rtw_usleep_os(100);
+		/* disable BT power cut*/
+		/* 0x6A[14] = 0*/
+		tempval = rtw_read8(padapter, 0x6B);
+		tempval &= ~BIT6;
+		rtw_write8(padapter, 0x6B, tempval);
+		rtw_usleep_os(100);
+
+		MPT_PwrCtlDM(padapter, 0);
+		rtw_write32(padapter, 0xcc, (rtw_read32(padapter, 0xcc) | 0x00000004));
+		rtw_write32(padapter, 0x6b, (rtw_read32(padapter, 0x6b) & 0xFFFFFFEF));
+		rtw_msleep_os(600);
+		rtw_write32(padapter, 0x6b, (rtw_read32(padapter, 0x6b) | 0x00000010));
+		rtw_write32(padapter, 0xcc, (rtw_read32(padapter, 0xcc) & 0xFFFFFFFB));
+		rtw_msleep_os(1200);
+
+#if defined(CONFIG_PLATFORM_SPRD) && (MP_DRIVER == 1)
+		/* Pull up BT reset pin.*/
+		RTW_INFO("%s: pull up BT reset pin when bt start mp test\n", __func__);
+		rtw_wifi_gpio_wlan_ctrl(WLAN_BT_PWDN_ON);
+#endif
+		RTW_INFO(" FirmwareDownload!\n");
+
+#if defined(CONFIG_RTL8723B)
+		status = rtl8723b_FirmwareDownload(padapter, _FALSE);
+#endif
+		RTW_INFO("Wait for FirmwareDownloadBT fw boot!\n");
+		rtw_msleep_os(1000);
+#ifdef CONFIG_BT_COEXIST
+		rtw_btcoex_HaltNotify(padapter);
+		RTW_INFO("SetBT btcoex HaltNotify !\n");
+		/*hal_btcoex1ant_SetAntPath(padapter);*/
+		rtw_btcoex_SetManualControl(padapter, _TRUE);
+#endif
+		_rtw_memset(extra, '\0', wrqu->data.length);
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 0;
+		BtReq.paraLength = 0;
+		mptbt_BtControlProcess(padapter, &BtReq);
+		rtw_msleep_os(200);
+
+		RTW_INFO("FirmwareDownloadBT ready = 0x%x 0x%x", pMptCtx->mptOutBuf[4], pMptCtx->mptOutBuf[5]);
+		if ((pMptCtx->mptOutBuf[4] == 0x00) && (pMptCtx->mptOutBuf[5] == 0x00)) {
+			if (padapter->mppriv.bTxBufCkFail == _TRUE)
+				sprintf(extra, "check TxBuf Fail.\n");
+			else
+				sprintf(extra, "download FW Fail.\n");
+		} else {
+#ifdef CONFIG_BT_COEXIST
+			rtw_btcoex_SwitchBtTRxMask(padapter);
+#endif
+			rtw_msleep_os(200);
+			sprintf(extra, "download FW OK.\n");
+			goto exit;
+		}
+		goto exit;
+	}
+
+	if (strncmp(extra, "down", 4) == 0) {
+		RTW_INFO("SetBT down for to hal_init !\n");
+#ifdef CONFIG_BT_COEXIST
+		rtw_btcoex_SetManualControl(padapter, _FALSE);
+		rtw_btcoex_Initialize(padapter);
+#endif
+		pHalFunc->read_adapter_info(padapter);
+		pHalFunc->hal_deinit(padapter);
+		pHalFunc->hal_init(padapter);
+		rtw_pm_set_ips(padapter, IPS_NONE);
+		LeaveAllPowerSaveMode(padapter);
+		MPT_PwrCtlDM(padapter, 0);
+		rtw_write32(padapter, 0xcc, (rtw_read32(padapter, 0xcc) | 0x00000004));
+		rtw_write32(padapter, 0x6b, (rtw_read32(padapter, 0x6b) & 0xFFFFFFEF));
+		rtw_msleep_os(600);
+		/*rtw_write32(padapter, 0x6a, (rtw_read32(padapter, 0x6a)& 0xFFFFFFFE));*/
+		rtw_write32(padapter, 0x6b, (rtw_read32(padapter, 0x6b) | 0x00000010));
+		rtw_write32(padapter, 0xcc, (rtw_read32(padapter, 0xcc) & 0xFFFFFFFB));
+		rtw_msleep_os(1200);
+		goto exit;
+	}
+	if (strncmp(extra, "disable", 7) == 0) {
+		RTW_INFO("SetBT disable !\n");
+		rtw_write32(padapter, 0x6a, (rtw_read32(padapter, 0x6a) & 0xFFFFFFFB));
+		rtw_msleep_os(500);
+		goto exit;
+	}
+	if (strncmp(extra, "enable", 6) == 0) {
+		RTW_INFO("SetBT enable !\n");
+		rtw_write32(padapter, 0x6a, (rtw_read32(padapter, 0x6a) | 0x00000004));
+		rtw_msleep_os(500);
+		goto exit;
+	}
+	if (strncmp(extra, "h2c", 3) == 0) {
+		RTW_INFO("SetBT h2c !\n");
+		pHalData->bBTFWReady = _TRUE;
+		rtw_hal_fill_h2c_cmd(padapter, 0x63, 1, u1H2CBtMpOperParm);
+		goto exit;
+	}
+	if (strncmp(extra, "2ant", 4) == 0) {
+		RTW_INFO("Set BT 2ant use!\n");
+		phy_set_mac_reg(padapter, 0x67, BIT5, 0x1);
+		rtw_write32(padapter, 0x948, 0000);
+
+		goto exit;
+	}
+
+	if (ready != 0 && testmode != 0 && trxparam != 0 && setgen != 0 && getgen != 0 && testctrl != 0 && testbt != 0 && readtherm != 0 && setbtmac != 0)
+		return -EFAULT;
+
+	if (testbt == 0) {
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 6;
+		BtReq.paraLength = cnts / 2;
+		goto todo;
+	}
+	if (ready == 0) {
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 0;
+		BtReq.paraLength = 0;
+		goto todo;
+	}
+
+	pch = extra;
+	i = 0;
+	while ((token = strsep(&pch, ",")) != NULL) {
+		if (i > 1)
+			break;
+		tmp[i] = token;
+		i++;
+	}
+
+	if ((tmp[0] != NULL) && (tmp[1] != NULL)) {
+		cnts = strlen(tmp[1]);
+		if (cnts < 1)
+			return -EFAULT;
+
+		RTW_INFO("%s: cnts=%d\n", __func__, cnts);
+		RTW_INFO("%s: data=%s\n", __func__, tmp[1]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2) {
+			BtReq.pParamStart[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
+			/*			RTW_INFO("BtReq.pParamStart[%d]=0x%02x\n", jj, BtReq.pParamStart[jj]);*/
+		}
+	} else
+		return -EFAULT;
+
+	if (testmode == 0) {
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 1;
+		BtReq.paraLength = 1;
+	}
+	if (trxparam == 0) {
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 2;
+		BtReq.paraLength = cnts / 2;
+	}
+	if (setgen == 0) {
+		RTW_INFO("%s: BT_SET_GENERAL\n", __func__);
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 3;/*BT_SET_GENERAL	3*/
+		BtReq.paraLength = cnts / 2;
+	}
+	if (getgen == 0) {
+		RTW_INFO("%s: BT_GET_GENERAL\n", __func__);
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 4;/*BT_GET_GENERAL	4*/
+		BtReq.paraLength = cnts / 2;
+	}
+	if (readtherm == 0) {
+		RTW_INFO("%s: BT_GET_GENERAL\n", __func__);
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 4;/*BT_GET_GENERAL	4*/
+		BtReq.paraLength = cnts / 2;
+	}
+
+	if (testctrl == 0) {
+		RTW_INFO("%s: BT_TEST_CTRL\n", __func__);
+		BtReq.opCodeVer = 1;
+		BtReq.OpCode = 5;/*BT_TEST_CTRL	5*/
+		BtReq.paraLength = cnts / 2;
+	}
+
+	RTW_INFO("%s: Req opCodeVer=%d OpCode=%d paraLength=%d\n",
+		 __func__, BtReq.opCodeVer, BtReq.OpCode, BtReq.paraLength);
+
+	if (BtReq.paraLength < 1)
+		goto todo;
+	for (i = 0; i < BtReq.paraLength; i++) {
+		RTW_INFO("%s: BtReq.pParamStart[%d] = 0x%02x\n",
+			 __func__, i, BtReq.pParamStart[i]);
+	}
+
+todo:
+	_rtw_memset(extra, '\0', wrqu->data.length);
+
+	if (pHalData->bBTFWReady == _FALSE) {
+		sprintf(extra, "BTFWReady = FALSE.\n");
+		goto exit;
+	}
+
+	mptbt_BtControlProcess(padapter, &BtReq);
+
+	if (readtherm == 0) {
+		sprintf(extra, "BT thermal=");
+		for (i = 4; i < pMptCtx->mptOutLen; i++) {
+			if ((pMptCtx->mptOutBuf[i] == 0x00) && (pMptCtx->mptOutBuf[i + 1] == 0x00))
+				goto exit;
+
+			sprintf(extra, "%s %d ", extra, (pMptCtx->mptOutBuf[i] & 0x1f));
+		}
+	} else {
+		for (i = 4; i < pMptCtx->mptOutLen; i++)
+			sprintf(extra, "%s 0x%x ", extra, pMptCtx->mptOutBuf[i]);
+	}
+
+exit:
+	wrqu->data.length = strlen(extra) + 1;
+	RTW_INFO("-%s: output len=%d data=%s\n", __func__, wrqu->data.length, extra);
+
+	return status;
+}
+
+#endif /*#ifdef CONFIG_RTL8723B*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/mlme_linux.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/mlme_linux.c
new file mode 100644
index 000000000000..418fd693173d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/mlme_linux.c
@@ -0,0 +1,430 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+
+
+#ifdef RTK_DMP_PLATFORM
+void Linkup_workitem_callback(struct work_struct *work)
+{
+	struct mlme_priv *pmlmepriv = container_of(work, struct mlme_priv, Linkup_workitem);
+	_adapter *padapter = container_of(pmlmepriv, _adapter, mlmepriv);
+
+
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
+	kobject_uevent(&padapter->pnetdev->dev.kobj, KOBJ_LINKUP);
+#else
+	kobject_hotplug(&padapter->pnetdev->class_dev.kobj, KOBJ_LINKUP);
+#endif
+
+}
+
+void Linkdown_workitem_callback(struct work_struct *work)
+{
+	struct mlme_priv *pmlmepriv = container_of(work, struct mlme_priv, Linkdown_workitem);
+	_adapter *padapter = container_of(pmlmepriv, _adapter, mlmepriv);
+
+
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
+	kobject_uevent(&padapter->pnetdev->dev.kobj, KOBJ_LINKDOWN);
+#else
+	kobject_hotplug(&padapter->pnetdev->class_dev.kobj, KOBJ_LINKDOWN);
+#endif
+
+}
+#endif
+
+extern void rtw_indicate_wx_assoc_event(_adapter *padapter);
+extern void rtw_indicate_wx_disassoc_event(_adapter *padapter);
+
+void rtw_os_indicate_connect(_adapter *adapter)
+{
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+
+#ifdef CONFIG_IOCTL_CFG80211
+	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
+		rtw_cfg80211_ibss_indicate_connect(adapter);
+	else
+		rtw_cfg80211_indicate_connect(adapter);
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+	rtw_indicate_wx_assoc_event(adapter);
+	rtw_netif_carrier_on(adapter->pnetdev);
+
+	if (adapter->pid[2] != 0)
+		rtw_signal_process(adapter->pid[2], SIGALRM);
+
+#ifdef RTK_DMP_PLATFORM
+	_set_workitem(&adapter->mlmepriv.Linkup_workitem);
+#endif
+
+
+}
+
+extern void indicate_wx_scan_complete_event(_adapter *padapter);
+void rtw_os_indicate_scan_done(_adapter *padapter, bool aborted)
+{
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_indicate_scan_done(padapter, aborted);
+#endif
+	indicate_wx_scan_complete_event(padapter);
+}
+
+static RT_PMKID_LIST   backupPMKIDList[NUM_PMKID_CACHE];
+void rtw_reset_securitypriv(_adapter *adapter)
+{
+	u8	backupPMKIDIndex = 0;
+	u8	backupTKIPCountermeasure = 0x00;
+	u32	backupTKIPcountermeasure_time = 0;
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
+	_irqL irqL;
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+
+	_enter_critical_bh(&adapter->security_key_mutex, &irqL);
+
+	if (adapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) { /* 802.1x */
+		/* Added by Albert 2009/02/18 */
+		/* 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. */
+
+		_rtw_memset(&backupPMKIDList[0], 0x00, sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
+
+		_rtw_memcpy(&backupPMKIDList[0], &adapter->securitypriv.PMKIDList[0], sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
+		backupPMKIDIndex = adapter->securitypriv.PMKIDIndex;
+		backupTKIPCountermeasure = adapter->securitypriv.btkip_countermeasure;
+		backupTKIPcountermeasure_time = adapter->securitypriv.btkip_countermeasure_time;
+		_rtw_memset((unsigned char *)&adapter->securitypriv, 0, sizeof(struct security_priv));
+
+		/* Added by Albert 2009/02/18 */
+		/* Restore the PMK information to securitypriv structure for the following connection. */
+		_rtw_memcpy(&adapter->securitypriv.PMKIDList[0], &backupPMKIDList[0], sizeof(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 */
+		/* if(adapter->mlmepriv.fw_state & WIFI_STATION_STATE) */
+		/* { */
+		struct security_priv *psec_priv = &adapter->securitypriv;
+
+		psec_priv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+		psec_priv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		psec_priv->dot11PrivacyKeyIndex = 0;
+
+		psec_priv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+		psec_priv->dot118021XGrpKeyid = 1;
+
+		psec_priv->ndisauthtype = Ndis802_11AuthModeOpen;
+		psec_priv->ndisencryptstatus = Ndis802_11WEPDisabled;
+		/* } */
+	}
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
+	_exit_critical_bh(&adapter->security_key_mutex, &irqL);
+
+	RTW_INFO(FUNC_ADPT_FMT" - End to Disconnect\n", FUNC_ADPT_ARG(adapter));
+}
+
+void rtw_os_indicate_disconnect(_adapter *adapter,  u16 reason, u8 locally_generated)
+{
+	/* RT_PMKID_LIST   backupPMKIDList[NUM_PMKID_CACHE]; */
+
+
+	rtw_netif_carrier_off(adapter->pnetdev); /* Do it first for tx broadcast pkt after disconnection issue! */
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_indicate_disconnect(adapter,  reason, locally_generated);
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+	rtw_indicate_wx_disassoc_event(adapter);
+
+#ifdef RTK_DMP_PLATFORM
+	_set_workitem(&adapter->mlmepriv.Linkdown_workitem);
+#endif
+	/* modify for CONFIG_IEEE80211W, none 11w also can use the same command */
+	rtw_reset_securitypriv_cmd(adapter);
+
+
+}
+
+void rtw_report_sec_ie(_adapter *adapter, u8 authmode, u8 *sec_ie)
+{
+	uint	len;
+	u8	*buff, *p, i;
+	union iwreq_data wrqu;
+
+
+
+	buff = NULL;
+	if (authmode == _WPA_IE_ID_) {
+
+		buff = rtw_zmalloc(IW_CUSTOM_MAX);
+		if (NULL == buff) {
+			RTW_INFO(FUNC_ADPT_FMT ": alloc memory FAIL!!\n",
+				 FUNC_ADPT_ARG(adapter));
+			return;
+		}
+		p = buff;
+
+		p += sprintf(p, "ASSOCINFO(ReqIEs=");
+
+		len = sec_ie[1] + 2;
+		len = (len < IW_CUSTOM_MAX) ? len : IW_CUSTOM_MAX;
+
+		for (i = 0; i < len; i++)
+			p += sprintf(p, "%02x", sec_ie[i]);
+
+		p += sprintf(p, ")");
+
+		_rtw_memset(&wrqu, 0, sizeof(wrqu));
+
+		wrqu.data.length = p - buff;
+
+		wrqu.data.length = (wrqu.data.length < IW_CUSTOM_MAX) ? wrqu.data.length : IW_CUSTOM_MAX;
+
+#ifndef CONFIG_IOCTL_CFG80211
+		wireless_send_event(adapter->pnetdev, IWEVCUSTOM, &wrqu, buff);
+#endif
+
+		rtw_mfree(buff, IW_CUSTOM_MAX);
+	}
+
+
+}
+
+#ifdef CONFIG_AP_MODE
+
+void rtw_indicate_sta_assoc_event(_adapter *padapter, struct sta_info *psta)
+{
+	union iwreq_data wrqu;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	if (psta == NULL)
+		return;
+
+	if (psta->cmn.aid > pstapriv->max_aid)
+		return;
+
+	if (pstapriv->sta_aid[psta->cmn.aid - 1] != psta)
+		return;
+
+
+	wrqu.addr.sa_family = ARPHRD_ETHER;
+
+	_rtw_memcpy(wrqu.addr.sa_data, psta->cmn.mac_addr, ETH_ALEN);
+
+	RTW_INFO("+rtw_indicate_sta_assoc_event\n");
+
+#ifndef CONFIG_IOCTL_CFG80211
+	wireless_send_event(padapter->pnetdev, IWEVREGISTERED, &wrqu, NULL);
+#endif
+
+}
+
+void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info *psta)
+{
+	union iwreq_data wrqu;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	if (psta == NULL)
+		return;
+
+	if (psta->cmn.aid > pstapriv->max_aid)
+		return;
+
+	if (pstapriv->sta_aid[psta->cmn.aid - 1] != psta)
+		return;
+
+
+	wrqu.addr.sa_family = ARPHRD_ETHER;
+
+	_rtw_memcpy(wrqu.addr.sa_data, psta->cmn.mac_addr, ETH_ALEN);
+
+	RTW_INFO("+rtw_indicate_sta_disassoc_event\n");
+
+#ifndef CONFIG_IOCTL_CFG80211
+	wireless_send_event(padapter->pnetdev, IWEVEXPIRED, &wrqu, NULL);
+#endif
+
+}
+
+
+#ifdef CONFIG_HOSTAPD_MLME
+
+static int mgnt_xmit_entry(struct sk_buff *skb, struct net_device *pnetdev)
+{
+	struct hostapd_priv *phostapdpriv = rtw_netdev_priv(pnetdev);
+	_adapter *padapter = (_adapter *)phostapdpriv->padapter;
+
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+	return rtw_hal_hostap_mgnt_xmit_entry(padapter, skb);
+}
+
+static int mgnt_netdev_open(struct net_device *pnetdev)
+{
+	struct hostapd_priv *phostapdpriv = rtw_netdev_priv(pnetdev);
+
+	RTW_INFO("mgnt_netdev_open: MAC Address:" MAC_FMT "\n", MAC_ARG(pnetdev->dev_addr));
+
+
+	init_usb_anchor(&phostapdpriv->anchored);
+
+	rtw_netif_wake_queue(pnetdev);
+
+	rtw_netif_carrier_on(pnetdev);
+
+	/* rtw_write16(phostapdpriv->padapter, 0x0116, 0x0100); */ /* only excluding beacon */
+
+	return 0;
+}
+static int mgnt_netdev_close(struct net_device *pnetdev)
+{
+	struct hostapd_priv *phostapdpriv = rtw_netdev_priv(pnetdev);
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	usb_kill_anchored_urbs(&phostapdpriv->anchored);
+
+	rtw_netif_carrier_off(pnetdev);
+
+	rtw_netif_stop_queue(pnetdev);
+
+	/* rtw_write16(phostapdpriv->padapter, 0x0116, 0x3f3f); */
+
+	return 0;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+static const struct net_device_ops rtl871x_mgnt_netdev_ops = {
+	.ndo_open = mgnt_netdev_open,
+	.ndo_stop = mgnt_netdev_close,
+	.ndo_start_xmit = mgnt_xmit_entry,
+	#if 0
+	.ndo_set_mac_address = r871x_net_set_mac_address,
+	.ndo_get_stats = r871x_net_get_stats,
+	.ndo_do_ioctl = r871x_mp_ioctl,
+	#endif
+};
+#endif
+
+int hostapd_mode_init(_adapter *padapter)
+{
+	unsigned char mac[ETH_ALEN];
+	struct hostapd_priv *phostapdpriv;
+	struct net_device *pnetdev;
+
+	pnetdev = rtw_alloc_etherdev(sizeof(struct hostapd_priv));
+	if (!pnetdev)
+		return -ENOMEM;
+
+	/* SET_MODULE_OWNER(pnetdev); */
+	ether_setup(pnetdev);
+
+	/* pnetdev->type = ARPHRD_IEEE80211; */
+
+	phostapdpriv = rtw_netdev_priv(pnetdev);
+	phostapdpriv->pmgnt_netdev = pnetdev;
+	phostapdpriv->padapter = padapter;
+	padapter->phostapdpriv = phostapdpriv;
+
+	/* pnetdev->init = NULL; */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+
+	RTW_INFO("register rtl871x_mgnt_netdev_ops to netdev_ops\n");
+
+	pnetdev->netdev_ops = &rtl871x_mgnt_netdev_ops;
+
+#else
+
+	pnetdev->open = mgnt_netdev_open;
+
+	pnetdev->stop = mgnt_netdev_close;
+
+	pnetdev->hard_start_xmit = mgnt_xmit_entry;
+
+	/* pnetdev->set_mac_address = r871x_net_set_mac_address; */
+
+	/* pnetdev->get_stats = r871x_net_get_stats; */
+
+	/* pnetdev->do_ioctl = r871x_mp_ioctl; */
+
+#endif
+
+	pnetdev->watchdog_timeo = HZ; /* 1 second timeout */
+
+	/* pnetdev->wireless_handlers = NULL; */
+
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+	pnetdev->features |= NETIF_F_IP_CSUM;
+#endif
+
+
+
+	if (dev_alloc_name(pnetdev, "mgnt.wlan%d") < 0)
+		RTW_INFO("hostapd_mode_init(): dev_alloc_name, fail!\n");
+
+
+	/* SET_NETDEV_DEV(pnetdev, pintfpriv->udev); */
+
+
+	mac[0] = 0x00;
+	mac[1] = 0xe0;
+	mac[2] = 0x4c;
+	mac[3] = 0x87;
+	mac[4] = 0x11;
+	mac[5] = 0x12;
+
+	_rtw_memcpy(pnetdev->dev_addr, mac, ETH_ALEN);
+
+
+	rtw_netif_carrier_off(pnetdev);
+
+
+	/* Tell the network stack we exist */
+	if (register_netdev(pnetdev) != 0) {
+		RTW_INFO("hostapd_mode_init(): register_netdev fail!\n");
+
+		if (pnetdev)
+			rtw_free_netdev(pnetdev);
+	}
+
+	return 0;
+
+}
+
+void hostapd_mode_unload(_adapter *padapter)
+{
+	struct hostapd_priv *phostapdpriv = padapter->phostapdpriv;
+	struct net_device *pnetdev = phostapdpriv->pmgnt_netdev;
+
+	unregister_netdev(pnetdev);
+	rtw_free_netdev(pnetdev);
+
+}
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/os_intfs.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/os_intfs.c
new file mode 100644
index 000000000000..21497ee17d8e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/os_intfs.c
@@ -0,0 +1,4871 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+#include <hal_data.h>
+
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+
+	#error "Shall be Linux or Windows, but not both!\n"
+
+#endif
+
+
+MODULE_LICENSE("GPL");
+MODULE_DESCRIPTION("Realtek Wireless Lan Driver");
+MODULE_AUTHOR("Realtek Semiconductor Corp.");
+MODULE_VERSION(DRIVERVERSION);
+
+/* module param defaults */
+int rtw_chip_version = 0x00;
+int rtw_rfintfs = HWPI;
+int rtw_lbkmode = 0;/* RTL8712_AIR_TRX; */
+
+
+int rtw_network_mode = Ndis802_11IBSS;/* Ndis802_11Infrastructure; */ /* infra, ad-hoc, auto */
+/* NDIS_802_11_SSID	ssid; */
+int rtw_channel = 1;/* ad-hoc support requirement */
+int rtw_wireless_mode = WIRELESS_MODE_MAX;
+int rtw_vrtl_carrier_sense = AUTO_VCS;
+int rtw_vcs_type = RTS_CTS;
+int rtw_rts_thresh = 2347;
+int rtw_frag_thresh = 2346;
+int rtw_preamble = PREAMBLE_LONG;/* long, short, auto */
+int rtw_scan_mode = 1;/* active, passive */
+int rtw_adhoc_tx_pwr = 1;
+int rtw_soft_ap = 0;
+/* int smart_ps = 1; */
+#ifdef CONFIG_POWER_SAVING
+	int rtw_power_mgnt = PS_MODE_MAX;
+	#ifdef CONFIG_IPS_LEVEL_2
+		int rtw_ips_mode = IPS_LEVEL_2;
+	#else
+		int rtw_ips_mode = IPS_NORMAL;
+	#endif /*CONFIG_IPS_LEVEL_2*/
+
+	#ifdef CONFIG_USB_HCI
+		int rtw_lps_level = LPS_NORMAL; /*USB default LPS level*/
+	#else /*SDIO,PCIE*/
+		#if defined(CONFIG_LPS_PG)
+			/*int rtw_lps_level = LPS_PG;*//*FW not support yet*/
+			int rtw_lps_level = LPS_LCLK;
+		#elif defined(CONFIG_LPS_LCLK)
+			int rtw_lps_level = LPS_LCLK;
+		#else
+			int rtw_lps_level = LPS_NORMAL;
+		#endif
+	#endif/*CONFIG_USB_HCI*/
+#else /* !CONFIG_POWER_SAVING */
+	int rtw_power_mgnt = PS_MODE_ACTIVE;
+	int rtw_ips_mode = IPS_NONE;
+	int rtw_lps_level = LPS_NORMAL;
+#endif /* CONFIG_POWER_SAVING */
+
+
+module_param(rtw_ips_mode, int, 0644);
+MODULE_PARM_DESC(rtw_ips_mode, "The default IPS mode");
+
+module_param(rtw_lps_level, int, 0644);
+MODULE_PARM_DESC(rtw_lps_level, "The default LPS level");
+
+/* LPS: 
+ * rtw_smart_ps = 0 => TX: pwr bit = 1, RX: PS_Poll
+ * rtw_smart_ps = 1 => TX: pwr bit = 0, RX: PS_Poll
+ * rtw_smart_ps = 2 => TX: pwr bit = 0, RX: NullData with pwr bit = 0
+*/
+int rtw_smart_ps = 2;
+
+#ifdef CONFIG_WMMPS_STA	
+/* WMMPS: 
+ * rtw_smart_ps = 0 => Only for fw test
+ * rtw_smart_ps = 1 => Refer to Beacon's TIM Bitmap
+ * rtw_smart_ps = 2 => Don't refer to Beacon's TIM Bitmap
+*/
+int rtw_wmm_smart_ps = 2;
+#endif /* CONFIG_WMMPS_STA */
+
+int rtw_check_fw_ps = 1;
+
+#ifdef CONFIG_TX_EARLY_MODE
+int rtw_early_mode = 1;
+#endif
+
+int rtw_usb_rxagg_mode = 2;/* RX_AGG_DMA=1, RX_AGG_USB=2 */
+module_param(rtw_usb_rxagg_mode, int, 0644);
+
+int rtw_dynamic_agg_enable = 1;
+module_param(rtw_dynamic_agg_enable, int, 0644);
+
+/* set log level when inserting driver module, default log level is _DRV_INFO_ = 4,
+* please refer to "How_to_set_driver_debug_log_level.doc" to set the available level.
+*/
+#ifdef RTW_LOG_LEVEL
+	uint rtw_drv_log_level = (uint)RTW_LOG_LEVEL; /* from Makefile */
+#else
+	uint rtw_drv_log_level = _DRV_INFO_;
+#endif
+module_param(rtw_drv_log_level, uint, 0644);
+MODULE_PARM_DESC(rtw_drv_log_level, "set log level when insert driver module, default log level is _DRV_INFO_ = 4");
+
+int rtw_radio_enable = 1;
+int rtw_long_retry_lmt = 7;
+int rtw_short_retry_lmt = 7;
+int rtw_busy_thresh = 40;
+/* int qos_enable = 0; */ /* * */
+int rtw_ack_policy = NORMAL_ACK;
+
+int rtw_mp_mode = 0;
+
+#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
+uint rtw_mp_customer_str = 0;
+module_param(rtw_mp_customer_str, uint, 0644);
+MODULE_PARM_DESC(rtw_mp_customer_str, "Whether or not to enable customer str support on MP mode");
+#endif
+
+int rtw_software_encrypt = 0;
+int rtw_software_decrypt = 0;
+
+int rtw_acm_method = 0;/* 0:By SW 1:By HW. */
+
+int rtw_wmm_enable = 1;/* default is set to enable the wmm. */
+
+#ifdef CONFIG_WMMPS_STA
+/* uapsd (unscheduled automatic power-save delivery) = a kind of wmmps */
+/* 0: NO_LIMIT, 1: TWO_MSDU, 2: FOUR_MSDU, 3: SIX_MSDU */
+int rtw_uapsd_max_sp = NO_LIMIT;
+/* BIT0: AC_VO UAPSD, BIT1: AC_VI UAPSD, BIT2: AC_BK UAPSD, BIT3: AC_BE UAPSD */
+int rtw_uapsd_ac_enable = 0x0;
+#endif /* CONFIG_WMMPS_STA */
+
+#if defined(CONFIG_RTL8814A)
+	int rtw_pwrtrim_enable = 2; /* disable kfree , rename to power trim disable */
+#elif defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822B)
+	/*PHYDM API, must enable by default*/
+	int rtw_pwrtrim_enable = 1;
+#else
+	int rtw_pwrtrim_enable = 0; /* Default Enalbe  power trim by efuse config */
+#endif
+
+uint rtw_tx_bw_mode = 0x21;
+module_param(rtw_tx_bw_mode, uint, 0644);
+MODULE_PARM_DESC(rtw_tx_bw_mode, "The max tx bw for 2.4G and 5G. format is the same as rtw_bw_mode");
+
+#ifdef CONFIG_80211N_HT
+int rtw_ht_enable = 1;
+/* 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz, 4: 80+80MHz
+* 2.4G use bit 0 ~ 3, 5G use bit 4 ~ 7
+* 0x21 means enable 2.4G 40MHz & 5G 80MHz */
+#ifdef CONFIG_RTW_CUSTOMIZE_BWMODE
+int rtw_bw_mode = CONFIG_RTW_CUSTOMIZE_BWMODE;
+#else
+int rtw_bw_mode = 0x21;
+#endif
+int rtw_ampdu_enable = 1;/* for enable tx_ampdu , */ /* 0: disable, 0x1:enable */
+int rtw_rx_stbc = 1;/* 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 */
+#if (defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)) && defined(CONFIG_PCI_HCI)
+int rtw_rx_ampdu_amsdu = 2;/* 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on */
+#else
+int rtw_rx_ampdu_amsdu;/* 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on */
+#endif
+/*
+* 2: Follow the AMSDU filed in ADDBA Resp. (Deault)
+* 0: Force the AMSDU filed in ADDBA Resp. to be disabled.
+* 1: Force the AMSDU filed in ADDBA Resp. to be enabled.
+*/
+int rtw_tx_ampdu_amsdu = 2;
+
+static uint rtw_rx_ampdu_sz_limit_1ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS;
+static uint rtw_rx_ampdu_sz_limit_1ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_1ss, uint, &rtw_rx_ampdu_sz_limit_1ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_1ss, "RX AMPDU size limit for 1SS link of each BW, 0xFF: no limitation");
+
+static uint rtw_rx_ampdu_sz_limit_2ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_2SS;
+static uint rtw_rx_ampdu_sz_limit_2ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_2ss, uint, &rtw_rx_ampdu_sz_limit_2ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_2ss, "RX AMPDU size limit for 2SS link of each BW, 0xFF: no limitation");
+
+static uint rtw_rx_ampdu_sz_limit_3ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_3SS;
+static uint rtw_rx_ampdu_sz_limit_3ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_3ss, uint, &rtw_rx_ampdu_sz_limit_3ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_3ss, "RX AMPDU size limit for 3SS link of each BW, 0xFF: no limitation");
+
+static uint rtw_rx_ampdu_sz_limit_4ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_4SS;
+static uint rtw_rx_ampdu_sz_limit_4ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_4ss, uint, &rtw_rx_ampdu_sz_limit_4ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_4ss, "RX AMPDU size limit for 4SS link of each BW, 0xFF: no limitation");
+
+/* Short GI support Bit Map
+* BIT0 - 20MHz, 0: non-support, 1: support
+* BIT1 - 40MHz, 0: non-support, 1: support
+* BIT2 - 80MHz, 0: non-support, 1: support
+* BIT3 - 160MHz, 0: non-support, 1: support */
+int rtw_short_gi = 0xf;
+/* BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx */
+int rtw_ldpc_cap = 0x33;
+/* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
+int rtw_stbc_cap = 0x13;
+/*
+* BIT0: Enable VHT SU Beamformer
+* BIT1: Enable VHT SU Beamformee
+* BIT2: Enable VHT MU Beamformer, depend on VHT SU Beamformer
+* BIT3: Enable VHT MU Beamformee, depend on VHT SU Beamformee
+* BIT4: Enable HT Beamformer
+* BIT5: Enable HT Beamformee
+*/
+int rtw_beamform_cap = BIT(1) | BIT(3);
+int rtw_bfer_rf_number = 0; /*BeamformerCapRfNum Rf path number, 0 for auto, others for manual*/
+int rtw_bfee_rf_number = 0; /*BeamformeeCapRfNum  Rf path number, 0 for auto, others for manual*/
+
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_80211AC_VHT
+int rtw_vht_enable = 1; /* 0:disable, 1:enable, 2:force auto enable */
+module_param(rtw_vht_enable, int, 0644);
+
+int rtw_ampdu_factor = 7;
+
+uint rtw_vht_rx_mcs_map = 0xaaaa;
+module_param(rtw_vht_rx_mcs_map, uint, 0644);
+MODULE_PARM_DESC(rtw_vht_rx_mcs_map, "VHT RX MCS map");
+#endif /* CONFIG_80211AC_VHT */
+
+int rtw_lowrate_two_xmit = 1;/* Use 2 path Tx to transmit MCS0~7 and legacy mode */
+
+int rtw_rf_config = RF_TYPE_MAX;
+module_param(rtw_rf_config, int, 0644);
+
+/* 0: not check in watch dog, 1: check in watch dog  */
+int rtw_check_hw_status = 0;
+
+int rtw_low_power = 0;
+#ifdef CONFIG_WIFI_TEST
+	int rtw_wifi_spec = 1;/* for wifi test */
+#else
+	int rtw_wifi_spec = 0;
+#endif
+
+int rtw_special_rf_path = 0; /* 0: 2T2R ,1: only turn on path A 1T1R */
+
+char rtw_country_unspecified[] = {0xFF, 0xFF, 0x00};
+char *rtw_country_code = rtw_country_unspecified;
+module_param(rtw_country_code, charp, 0644);
+MODULE_PARM_DESC(rtw_country_code, "The default country code (in alpha2)");
+
+int rtw_channel_plan = CONFIG_RTW_CHPLAN;
+module_param(rtw_channel_plan, int, 0644);
+MODULE_PARM_DESC(rtw_channel_plan, "The default chplan ID when rtw_alpha2 is not specified or valid");
+
+static uint rtw_excl_chs[MAX_CHANNEL_NUM] = CONFIG_RTW_EXCL_CHS;
+static int rtw_excl_chs_num = 0;
+module_param_array(rtw_excl_chs, uint, &rtw_excl_chs_num, 0644);
+MODULE_PARM_DESC(rtw_excl_chs, "exclusive channel array");
+
+/*if concurrent softap + p2p(GO) is needed, this param lets p2p response full channel list.
+But Softap must be SHUT DOWN once P2P decide to set up connection and become a GO.*/
+#ifdef CONFIG_FULL_CH_IN_P2P_HANDSHAKE
+	int rtw_full_ch_in_p2p_handshake = 1; /* reply full channel list*/
+#else
+	int rtw_full_ch_in_p2p_handshake = 0; /* reply only softap channel*/
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+int rtw_btcoex_enable = 2;
+module_param(rtw_btcoex_enable, int, 0644);
+MODULE_PARM_DESC(rtw_btcoex_enable, "BT co-existence on/off, 0:off, 1:on, 2:by efuse");
+
+int rtw_ant_num = 0;
+module_param(rtw_ant_num, int, 0644);
+MODULE_PARM_DESC(rtw_ant_num, "Antenna number setting, 0:by efuse");
+
+int rtw_bt_iso = 2;/* 0:Low, 1:High, 2:From Efuse */
+int rtw_bt_sco = 3;/* 0:Idle, 1:None-SCO, 2:SCO, 3:From Counter, 4.Busy, 5.OtherBusy */
+int rtw_bt_ampdu = 1 ; /* 0:Disable BT control A-MPDU, 1:Enable BT control A-MPDU. */
+#endif /* CONFIG_BT_COEXIST */
+
+int rtw_AcceptAddbaReq = _TRUE;/* 0:Reject AP's Add BA req, 1:Accept AP's Add BA req. */
+
+int rtw_antdiv_cfg = 2; /* 0:OFF , 1:ON, 2:decide by Efuse config */
+int rtw_antdiv_type = 0
+	; /* 0:decide by efuse  1: for 88EE, 1Tx and 1RxCG are diversity.(2 Ant with SPDT), 2:  for 88EE, 1Tx and 2Rx are diversity.( 2 Ant, Tx and RxCG are both on aux port, RxCS is on main port ), 3: for 88EE, 1Tx and 1RxCG are fixed.(1Ant, Tx and RxCG are both on aux port) */
+
+int rtw_drv_ant_band_switch = 1; /* 0:OFF , 1:ON, Driver control antenna band switch*/
+
+int rtw_single_ant_path; /*0:main ant , 1:aux ant , Fixed single antenna path, default main ant*/
+
+/* 0: doesn't switch, 1: switch from usb2.0 to usb 3.0 2: switch from usb3.0 to usb 2.0 */
+int rtw_switch_usb_mode = 0;
+
+#ifdef CONFIG_USB_AUTOSUSPEND
+int rtw_enusbss = 1;/* 0:disable,1:enable */
+#else
+int rtw_enusbss = 0;/* 0:disable,1:enable */
+#endif
+
+int rtw_hwpdn_mode = 2; /* 0:disable,1:enable,2: by EFUSE config */
+
+#ifdef CONFIG_HW_PWRP_DETECTION
+int rtw_hwpwrp_detect = 1;
+#else
+int rtw_hwpwrp_detect = 0; /* HW power  ping detect 0:disable , 1:enable */
+#endif
+
+#ifdef CONFIG_USB_HCI
+int rtw_hw_wps_pbc = 1;
+#else
+int rtw_hw_wps_pbc = 0;
+#endif
+
+#ifdef CONFIG_TX_MCAST2UNI
+int rtw_mc2u_disable = 0;
+#endif /* CONFIG_TX_MCAST2UNI */
+
+#ifdef CONFIG_80211D
+int rtw_80211d = 0;
+#endif
+
+#ifdef CONFIG_PCI_ASPM
+/* CLK_REQ:BIT0 L0s:BIT1 ASPM_L1:BIT2 L1Off:BIT3*/
+int	rtw_pci_aspm_enable = 0x5;
+#else
+int	rtw_pci_aspm_enable;
+#endif
+
+#ifdef CONFIG_QOS_OPTIMIZATION
+int rtw_qos_opt_enable = 1; /* 0: disable,1:enable */
+#else
+int rtw_qos_opt_enable = 0; /* 0: disable,1:enable */
+#endif
+module_param(rtw_qos_opt_enable, int, 0644);
+
+#ifdef CONFIG_RTW_ACS
+int rtw_acs_auto_scan = 0; /*0:disable, 1:enable*/
+module_param(rtw_acs_auto_scan, int, 0644);
+
+int rtw_acs = 1;
+module_param(rtw_acs, int, 0644);
+#endif
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+int rtw_nm = 1;/*noise monitor*/
+module_param(rtw_nm, int, 0644);
+#endif
+
+char *ifname = "wlan%d";
+module_param(ifname, charp, 0644);
+MODULE_PARM_DESC(ifname, "The default name to allocate for first interface");
+
+#ifdef CONFIG_PLATFORM_ANDROID
+	char *if2name = "p2p%d";
+#else /* CONFIG_PLATFORM_ANDROID */
+	char *if2name = "wlan%d";
+#endif /* CONFIG_PLATFORM_ANDROID */
+module_param(if2name, charp, 0644);
+MODULE_PARM_DESC(if2name, "The default name to allocate for second interface");
+
+char *rtw_initmac = 0;  /* temp mac address if users want to use instead of the mac address in Efuse */
+
+#ifdef CONFIG_CONCURRENT_MODE
+
+	#if (CONFIG_IFACE_NUMBER > 2)
+		int rtw_virtual_iface_num = CONFIG_IFACE_NUMBER - 1;
+		module_param(rtw_virtual_iface_num, int, 0644);
+	#else
+		int rtw_virtual_iface_num = 1;
+	#endif
+
+#endif
+#ifdef CONFIG_AP_MODE
+u8 rtw_bmc_tx_rate = MGN_UNKNOWN;
+#endif
+module_param(rtw_pwrtrim_enable, int, 0644);
+module_param(rtw_initmac, charp, 0644);
+module_param(rtw_special_rf_path, int, 0644);
+module_param(rtw_chip_version, int, 0644);
+module_param(rtw_rfintfs, int, 0644);
+module_param(rtw_lbkmode, int, 0644);
+module_param(rtw_network_mode, int, 0644);
+module_param(rtw_channel, int, 0644);
+module_param(rtw_mp_mode, int, 0644);
+module_param(rtw_wmm_enable, int, 0644);
+#ifdef CONFIG_WMMPS_STA
+module_param(rtw_uapsd_max_sp, int, 0644);
+module_param(rtw_uapsd_ac_enable, int, 0644);
+module_param(rtw_wmm_smart_ps, int, 0644);
+#endif /* CONFIG_WMMPS_STA */
+module_param(rtw_vrtl_carrier_sense, int, 0644);
+module_param(rtw_vcs_type, int, 0644);
+module_param(rtw_busy_thresh, int, 0644);
+
+#ifdef CONFIG_80211N_HT
+module_param(rtw_ht_enable, int, 0644);
+module_param(rtw_bw_mode, int, 0644);
+module_param(rtw_ampdu_enable, int, 0644);
+module_param(rtw_rx_stbc, int, 0644);
+module_param(rtw_rx_ampdu_amsdu, int, 0644);
+module_param(rtw_tx_ampdu_amsdu, int, 0644);
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_BEAMFORMING
+module_param(rtw_beamform_cap, int, 0644);
+#endif
+module_param(rtw_lowrate_two_xmit, 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_full_ch_in_p2p_handshake, int, 0644);
+module_param(rtw_antdiv_cfg, int, 0644);
+module_param(rtw_antdiv_type, int, 0644);
+
+module_param(rtw_drv_ant_band_switch, int, 0644);
+module_param(rtw_single_ant_path, int, 0644);
+
+module_param(rtw_switch_usb_mode, 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);
+module_param(rtw_check_hw_status, int, 0644);
+
+#ifdef CONFIG_PCI_HCI
+module_param(rtw_pci_aspm_enable, int, 0644);
+#endif
+
+#ifdef CONFIG_TX_EARLY_MODE
+module_param(rtw_early_mode, int, 0644);
+#endif
+#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
+char *rtw_adaptor_info_caching_file_path = "/data/misc/wifi/rtw_cache";
+module_param(rtw_adaptor_info_caching_file_path, charp, 0644);
+MODULE_PARM_DESC(rtw_adaptor_info_caching_file_path, "The path of adapter info cache file");
+#endif /* CONFIG_ADAPTOR_INFO_CACHING_FILE */
+
+#ifdef CONFIG_LAYER2_ROAMING
+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");
+#endif /* CONFIG_LAYER2_ROAMING */
+
+#ifdef CONFIG_IOL
+int rtw_fw_iol = 1;
+module_param(rtw_fw_iol, int, 0644);
+MODULE_PARM_DESC(rtw_fw_iol, "FW IOL. 0:Disable, 1:enable, 2:by usb speed");
+#endif /* CONFIG_IOL */
+
+#ifdef CONFIG_FILE_FWIMG
+char *rtw_fw_file_path = "/system/etc/firmware/rtlwifi/FW_NIC.BIN";
+module_param(rtw_fw_file_path, charp, 0644);
+MODULE_PARM_DESC(rtw_fw_file_path, "The path of fw image");
+
+char *rtw_fw_wow_file_path = "/system/etc/firmware/rtlwifi/FW_WoWLAN.BIN";
+module_param(rtw_fw_wow_file_path, charp, 0644);
+MODULE_PARM_DESC(rtw_fw_wow_file_path, "The path of fw for Wake on Wireless image");
+
+#ifdef CONFIG_MP_INCLUDED
+char *rtw_fw_mp_bt_file_path = "";
+module_param(rtw_fw_mp_bt_file_path, charp, 0644);
+MODULE_PARM_DESC(rtw_fw_mp_bt_file_path, "The path of fw for MP-BT image");
+#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
+
+#ifdef CONFIG_TX_MCAST2UNI
+module_param(rtw_mc2u_disable, int, 0644);
+#endif /* CONFIG_TX_MCAST2UNI */
+
+#ifdef CONFIG_80211D
+module_param(rtw_80211d, int, 0644);
+MODULE_PARM_DESC(rtw_80211d, "Enable 802.11d mechanism");
+#endif
+
+#ifdef CONFIG_ADVANCE_OTA
+/*	BIT(0): OTA continuous rotated test within low RSSI,1R CCA in path B
+	BIT(1) & BIT(2): OTA continuous rotated test with low high RSSI */
+/* Experimental environment: shielding room with half of absorber and 2~3 rotation per minute */
+int rtw_advnace_ota;
+module_param(rtw_advnace_ota, int, 0644);
+#endif
+
+uint rtw_notch_filter = 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");
+
+uint rtw_hiq_filter = CONFIG_RTW_HIQ_FILTER;
+module_param(rtw_hiq_filter, uint, 0644);
+MODULE_PARM_DESC(rtw_hiq_filter, "0:allow all, 1:allow special, 2:deny all");
+
+uint rtw_adaptivity_en = CONFIG_RTW_ADAPTIVITY_EN;
+module_param(rtw_adaptivity_en, uint, 0644);
+MODULE_PARM_DESC(rtw_adaptivity_en, "0:disable, 1:enable");
+
+uint rtw_adaptivity_mode = CONFIG_RTW_ADAPTIVITY_MODE;
+module_param(rtw_adaptivity_mode, uint, 0644);
+MODULE_PARM_DESC(rtw_adaptivity_mode, "0:normal, 1:carrier sense");
+
+uint rtw_adaptivity_dml = CONFIG_RTW_ADAPTIVITY_DML;
+module_param(rtw_adaptivity_dml, uint, 0644);
+MODULE_PARM_DESC(rtw_adaptivity_dml, "0:disable, 1:enable");
+
+uint rtw_adaptivity_dc_backoff = CONFIG_RTW_ADAPTIVITY_DC_BACKOFF;
+module_param(rtw_adaptivity_dc_backoff, uint, 0644);
+MODULE_PARM_DESC(rtw_adaptivity_dc_backoff, "DC backoff for Adaptivity");
+
+int rtw_adaptivity_th_l2h_ini = CONFIG_RTW_ADAPTIVITY_TH_L2H_INI;
+module_param(rtw_adaptivity_th_l2h_ini, int, 0644);
+MODULE_PARM_DESC(rtw_adaptivity_th_l2h_ini, "th_l2h_ini for Adaptivity");
+
+int rtw_adaptivity_th_edcca_hl_diff = CONFIG_RTW_ADAPTIVITY_TH_EDCCA_HL_DIFF;
+module_param(rtw_adaptivity_th_edcca_hl_diff, int, 0644);
+MODULE_PARM_DESC(rtw_adaptivity_th_edcca_hl_diff, "th_edcca_hl_diff for Adaptivity");
+
+#ifdef CONFIG_DFS_MASTER
+uint rtw_dfs_region_domain = CONFIG_RTW_DFS_REGION_DOMAIN;
+module_param(rtw_dfs_region_domain, uint, 0644);
+MODULE_PARM_DESC(rtw_dfs_region_domain, "0:UNKNOWN, 1:FCC, 2:MKK, 3:ETSI");
+#endif
+
+uint rtw_amplifier_type_2g = CONFIG_RTW_AMPLIFIER_TYPE_2G;
+module_param(rtw_amplifier_type_2g, uint, 0644);
+MODULE_PARM_DESC(rtw_amplifier_type_2g, "BIT3:2G ext-PA, BIT4:2G ext-LNA");
+
+uint rtw_amplifier_type_5g = CONFIG_RTW_AMPLIFIER_TYPE_5G;
+module_param(rtw_amplifier_type_5g, uint, 0644);
+MODULE_PARM_DESC(rtw_amplifier_type_5g, "BIT6:5G ext-PA, BIT7:5G ext-LNA");
+
+uint rtw_RFE_type = CONFIG_RTW_RFE_TYPE;
+module_param(rtw_RFE_type, uint, 0644);
+MODULE_PARM_DESC(rtw_RFE_type, "default init value:64");
+
+uint rtw_powertracking_type = 64;
+module_param(rtw_powertracking_type, uint, 0644);
+MODULE_PARM_DESC(rtw_powertracking_type, "default init value:64");
+
+uint rtw_GLNA_type = CONFIG_RTW_GLNA_TYPE;
+module_param(rtw_GLNA_type, uint, 0644);
+MODULE_PARM_DESC(rtw_GLNA_type, "default init value:0");
+
+uint rtw_TxBBSwing_2G = 0xFF;
+module_param(rtw_TxBBSwing_2G, uint, 0644);
+MODULE_PARM_DESC(rtw_TxBBSwing_2G, "default init value:0xFF");
+
+uint rtw_TxBBSwing_5G = 0xFF;
+module_param(rtw_TxBBSwing_5G, uint, 0644);
+MODULE_PARM_DESC(rtw_TxBBSwing_5G, "default init value:0xFF");
+
+uint rtw_OffEfuseMask = 0;
+module_param(rtw_OffEfuseMask, uint, 0644);
+MODULE_PARM_DESC(rtw_OffEfuseMask, "default open Efuse Mask value:0");
+
+uint rtw_FileMaskEfuse = 0;
+module_param(rtw_FileMaskEfuse, uint, 0644);
+MODULE_PARM_DESC(rtw_FileMaskEfuse, "default drv Mask Efuse value:0");
+
+uint rtw_rxgain_offset_2g = 0;
+module_param(rtw_rxgain_offset_2g, uint, 0644);
+MODULE_PARM_DESC(rtw_rxgain_offset_2g, "default RF Gain 2G Offset value:0");
+
+uint rtw_rxgain_offset_5gl = 0;
+module_param(rtw_rxgain_offset_5gl, uint, 0644);
+MODULE_PARM_DESC(rtw_rxgain_offset_5gl, "default RF Gain 5GL Offset value:0");
+
+uint rtw_rxgain_offset_5gm = 0;
+module_param(rtw_rxgain_offset_5gm, uint, 0644);
+MODULE_PARM_DESC(rtw_rxgain_offset_5gm, "default RF Gain 5GM Offset value:0");
+
+uint rtw_rxgain_offset_5gh = 0;
+module_param(rtw_rxgain_offset_5gh, uint, 0644);
+MODULE_PARM_DESC(rtw_rxgain_offset_5gm, "default RF Gain 5GL Offset value:0");
+
+uint rtw_pll_ref_clk_sel = CONFIG_RTW_PLL_REF_CLK_SEL;
+module_param(rtw_pll_ref_clk_sel, uint, 0644);
+MODULE_PARM_DESC(rtw_pll_ref_clk_sel, "force pll_ref_clk_sel, 0xF:use autoload value");
+
+int rtw_tx_pwr_by_rate = CONFIG_TXPWR_BY_RATE_EN;
+module_param(rtw_tx_pwr_by_rate, int, 0644);
+MODULE_PARM_DESC(rtw_tx_pwr_by_rate, "0:Disable, 1:Enable, 2: Depend on efuse");
+
+#ifdef CONFIG_TXPWR_LIMIT
+int rtw_tx_pwr_lmt_enable = CONFIG_TXPWR_LIMIT_EN;
+module_param(rtw_tx_pwr_lmt_enable, int, 0644);
+MODULE_PARM_DESC(rtw_tx_pwr_lmt_enable, "0:Disable, 1:Enable, 2: Depend on efuse");
+#endif
+
+static int rtw_target_tx_pwr_2g_a[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_A;
+static int rtw_target_tx_pwr_2g_a_num = 0;
+module_param_array(rtw_target_tx_pwr_2g_a, int, &rtw_target_tx_pwr_2g_a_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_2g_a, "2.4G target tx power (unit:dBm) of RF path A for each rate section, should match the real calibrate power, -1: undefined");
+
+static int rtw_target_tx_pwr_2g_b[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_B;
+static int rtw_target_tx_pwr_2g_b_num = 0;
+module_param_array(rtw_target_tx_pwr_2g_b, int, &rtw_target_tx_pwr_2g_b_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_2g_b, "2.4G target tx power (unit:dBm) of RF path B for each rate section, should match the real calibrate power, -1: undefined");
+
+static int rtw_target_tx_pwr_2g_c[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_C;
+static int rtw_target_tx_pwr_2g_c_num = 0;
+module_param_array(rtw_target_tx_pwr_2g_c, int, &rtw_target_tx_pwr_2g_c_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_2g_c, "2.4G target tx power (unit:dBm) of RF path C for each rate section, should match the real calibrate power, -1: undefined");
+
+static int rtw_target_tx_pwr_2g_d[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_D;
+static int rtw_target_tx_pwr_2g_d_num = 0;
+module_param_array(rtw_target_tx_pwr_2g_d, int, &rtw_target_tx_pwr_2g_d_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_2g_d, "2.4G target tx power (unit:dBm) of RF path D for each rate section, should match the real calibrate power, -1: undefined");
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+static int rtw_target_tx_pwr_5g_a[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_A;
+static int rtw_target_tx_pwr_5g_a_num = 0;
+module_param_array(rtw_target_tx_pwr_5g_a, int, &rtw_target_tx_pwr_5g_a_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_5g_a, "5G target tx power (unit:dBm) of RF path A for each rate section, should match the real calibrate power, -1: undefined");
+
+static int rtw_target_tx_pwr_5g_b[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_B;
+static int rtw_target_tx_pwr_5g_b_num = 0;
+module_param_array(rtw_target_tx_pwr_5g_b, int, &rtw_target_tx_pwr_5g_b_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_5g_b, "5G target tx power (unit:dBm) of RF path B for each rate section, should match the real calibrate power, -1: undefined");
+
+static int rtw_target_tx_pwr_5g_c[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_C;
+static int rtw_target_tx_pwr_5g_c_num = 0;
+module_param_array(rtw_target_tx_pwr_5g_c, int, &rtw_target_tx_pwr_5g_c_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_5g_c, "5G target tx power (unit:dBm) of RF path C for each rate section, should match the real calibrate power, -1: undefined");
+
+static int rtw_target_tx_pwr_5g_d[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_D;
+static int rtw_target_tx_pwr_5g_d_num = 0;
+module_param_array(rtw_target_tx_pwr_5g_d, int, &rtw_target_tx_pwr_5g_d_num, 0644);
+MODULE_PARM_DESC(rtw_target_tx_pwr_5g_d, "5G target tx power (unit:dBm) of RF path D for each rate section, should match the real calibrate power, -1: undefined");
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
+
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+char *rtw_phy_file_path = REALTEK_CONFIG_PATH;
+module_param(rtw_phy_file_path, charp, 0644);
+MODULE_PARM_DESC(rtw_phy_file_path, "The path of phy parameter");
+/* PHY FILE Bit Map
+* BIT0 - MAC,				0: non-support, 1: support
+* BIT1 - BB,					0: non-support, 1: support
+* BIT2 - BB_PG,				0: non-support, 1: support
+* BIT3 - BB_MP,				0: non-support, 1: support
+* BIT4 - RF,					0: non-support, 1: support
+* BIT5 - RF_TXPWR_TRACK,	0: non-support, 1: support
+* BIT6 - RF_TXPWR_LMT,		0: non-support, 1: support */
+int rtw_load_phy_file = (BIT2 | BIT6);
+module_param(rtw_load_phy_file, int, 0644);
+MODULE_PARM_DESC(rtw_load_phy_file, "PHY File Bit Map");
+int rtw_decrypt_phy_file = 0;
+module_param(rtw_decrypt_phy_file, int, 0644);
+MODULE_PARM_DESC(rtw_decrypt_phy_file, "Enable Decrypt PHY File");
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#ifdef DFT_TRX_SHARE_MODE
+int rtw_trx_share_mode = DFT_TRX_SHARE_MODE;
+#else
+int rtw_trx_share_mode = 0;
+#endif
+module_param(rtw_trx_share_mode, int, 0644);
+MODULE_PARM_DESC(rtw_trx_share_mode, "TRx FIFO Shared");
+#endif
+
+#ifdef CONFIG_DYNAMIC_SOML
+uint rtw_dynamic_soml_en = 1;
+module_param(rtw_dynamic_soml_en, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_en, "0: disable, 1: enable with default param, 2: enable with specified param.");
+
+uint rtw_dynamic_soml_train_num = 0;
+module_param(rtw_dynamic_soml_train_num, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_train_num, "SOML training number");
+
+uint rtw_dynamic_soml_interval = 0;
+module_param(rtw_dynamic_soml_interval, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_interval, "SOML training interval");
+
+uint rtw_dynamic_soml_period = 0;
+module_param(rtw_dynamic_soml_period, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_period, "SOML training period");
+
+uint rtw_dynamic_soml_delay = 0;
+module_param(rtw_dynamic_soml_delay, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_delay, "SOML training delay");
+#endif
+
+
+int _netdev_open(struct net_device *pnetdev);
+int netdev_open(struct net_device *pnetdev);
+static int netdev_close(struct net_device *pnetdev);
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+extern int rtw_sdio_set_power(int on);
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+
+#ifdef CONFIG_MCC_MODE
+/* enable MCC mode or not */
+int rtw_en_mcc = 1;
+/* can referece following value before insmod driver */
+int rtw_mcc_ap_bw20_target_tx_tp = MCC_AP_BW20_TARGET_TX_TP;
+int rtw_mcc_ap_bw40_target_tx_tp = MCC_AP_BW40_TARGET_TX_TP;
+int rtw_mcc_ap_bw80_target_tx_tp = MCC_AP_BW80_TARGET_TX_TP;
+int rtw_mcc_sta_bw20_target_tx_tp = MCC_STA_BW20_TARGET_TX_TP;
+int rtw_mcc_sta_bw40_target_tx_tp = MCC_STA_BW40_TARGET_TX_TP;
+int rtw_mcc_sta_bw80_target_tx_tp = MCC_STA_BW80_TARGET_TX_TP;
+int rtw_mcc_single_tx_cri = MCC_SINGLE_TX_CRITERIA;
+int rtw_mcc_policy_table_idx = 0;
+int rtw_mcc_duration = 0;
+int rtw_mcc_enable_runtime_duration = 1;
+module_param(rtw_en_mcc, int, 0644);
+module_param(rtw_mcc_single_tx_cri, int, 0644);
+module_param(rtw_mcc_ap_bw20_target_tx_tp, int, 0644);
+module_param(rtw_mcc_ap_bw40_target_tx_tp, int, 0644);
+module_param(rtw_mcc_ap_bw80_target_tx_tp, int, 0644);
+module_param(rtw_mcc_sta_bw20_target_tx_tp, int, 0644);
+module_param(rtw_mcc_sta_bw40_target_tx_tp, int, 0644);
+module_param(rtw_mcc_sta_bw80_target_tx_tp, int, 0644);
+module_param(rtw_mcc_policy_table_idx, int, 0644);
+module_param(rtw_mcc_duration, int, 0644);
+#endif /*CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_NAPI
+/*following setting should define NAPI in Makefile
+enable napi only = 1, disable napi = 0*/
+int rtw_en_napi = 1;
+module_param(rtw_en_napi, int, 0644);
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+int rtw_napi_threshold = 100; /* unit: Mbps */
+module_param(rtw_napi_threshold, int, 0644);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#ifdef CONFIG_RTW_GRO
+/*following setting should define GRO in Makefile
+enable gro = 1, disable gro = 0*/
+int rtw_en_gro = 1;
+module_param(rtw_en_gro, int, 0644);
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+#ifdef RTW_IQK_FW_OFFLOAD
+int rtw_iqk_fw_offload = 1;
+#else
+int rtw_iqk_fw_offload;
+#endif /* RTW_IQK_FW_OFFLOAD */
+module_param(rtw_iqk_fw_offload, int, 0644);
+
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+int rtw_ch_switch_offload = 0;
+#else
+int rtw_ch_switch_offload;
+#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+module_param(rtw_ch_switch_offload, int, 0644);
+
+#ifdef CONFIG_TDLS
+int rtw_en_tdls = 1;
+module_param(rtw_en_tdls, int, 0644);
+#endif
+
+#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+int rtw_fw_param_init = 1;
+module_param(rtw_fw_param_init, int, 0644);
+#endif
+
+#ifdef CONFIG_WOWLAN
+/*
+ * bit[0]: magic packet wake up
+ * bit[1]: unucast packet(HW/FW unuicast)
+ * bit[2]: deauth wake up
+ */
+uint rtw_wakeup_event = RTW_WAKEUP_EVENT;
+module_param(rtw_wakeup_event, uint, 0644);
+#endif
+
+void rtw_regsty_load_target_tx_power(struct registry_priv *regsty)
+{
+	int path, rs;
+	int *target_tx_pwr;
+
+	for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
+		if (path == RF_PATH_A)
+			target_tx_pwr = rtw_target_tx_pwr_2g_a;
+		else if (path == RF_PATH_B)
+			target_tx_pwr = rtw_target_tx_pwr_2g_b;
+		else if (path == RF_PATH_C)
+			target_tx_pwr = rtw_target_tx_pwr_2g_c;
+		else if (path == RF_PATH_D)
+			target_tx_pwr = rtw_target_tx_pwr_2g_d;
+
+		for (rs = CCK; rs < RATE_SECTION_NUM; rs++)
+			regsty->target_tx_pwr_2g[path][rs] = target_tx_pwr[rs];
+	}
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
+		if (path == RF_PATH_A)
+			target_tx_pwr = rtw_target_tx_pwr_5g_a;
+		else if (path == RF_PATH_B)
+			target_tx_pwr = rtw_target_tx_pwr_5g_b;
+		else if (path == RF_PATH_C)
+			target_tx_pwr = rtw_target_tx_pwr_5g_c;
+		else if (path == RF_PATH_D)
+			target_tx_pwr = rtw_target_tx_pwr_5g_d;
+
+		for (rs = OFDM; rs < RATE_SECTION_NUM; rs++)
+			regsty->target_tx_pwr_5g[path][rs - 1] = target_tx_pwr[rs - 1];
+	}
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
+}
+
+inline void rtw_regsty_load_excl_chs(struct registry_priv *regsty)
+{
+	int i;
+	int ch_num = 0;
+
+	for (i = 0; i < MAX_CHANNEL_NUM; i++)
+		if (((u8)rtw_excl_chs[i]) != 0)
+			regsty->excl_chs[ch_num++] = (u8)rtw_excl_chs[i];
+
+	if (ch_num < MAX_CHANNEL_NUM)
+		regsty->excl_chs[ch_num] = 0;
+}
+
+#ifdef CONFIG_80211N_HT
+inline void rtw_regsty_init_rx_ampdu_sz_limit(struct registry_priv *regsty)
+{
+	int i, j;
+	uint *sz_limit;
+
+	for (i = 0; i < 4; i++) {
+		if (i == 0)
+			sz_limit = rtw_rx_ampdu_sz_limit_1ss;
+		else if (i == 1)
+			sz_limit = rtw_rx_ampdu_sz_limit_2ss;
+		else if (i == 2)
+			sz_limit = rtw_rx_ampdu_sz_limit_3ss;
+		else if (i == 3)
+			sz_limit = rtw_rx_ampdu_sz_limit_4ss;
+
+		for (j = 0; j < 4; j++)
+			regsty->rx_ampdu_sz_limit_by_nss_bw[i][j] = sz_limit[j];
+	}
+}
+#endif /* CONFIG_80211N_HT */
+
+uint loadparam(_adapter *padapter)
+{
+	uint status = _SUCCESS;
+	struct registry_priv  *registry_par = &padapter->registrypriv;
+
+
+#ifdef CONFIG_RTW_DEBUG
+	if (rtw_drv_log_level >= _DRV_MAX_)
+		rtw_drv_log_level = _DRV_DEBUG_;
+#endif
+
+	registry_par->chip_version = (u8)rtw_chip_version;
+	registry_par->rfintfs = (u8)rtw_rfintfs;
+	registry_par->lbkmode = (u8)rtw_lbkmode;
+	/* registry_par->hci = (u8)hci; */
+	registry_par->network_mode  = (u8)rtw_network_mode;
+
+	_rtw_memcpy(registry_par->ssid.Ssid, "ANY", 3);
+	registry_par->ssid.SsidLength = 3;
+
+	registry_par->channel = (u8)rtw_channel;
+	registry_par->wireless_mode = (u8)rtw_wireless_mode;
+
+	if (IsSupported24G(registry_par->wireless_mode) && (!is_supported_5g(registry_par->wireless_mode))
+	    && (registry_par->channel > 14))
+		registry_par->channel = 1;
+	else if (is_supported_5g(registry_par->wireless_mode) && (!IsSupported24G(registry_par->wireless_mode))
+		 && (registry_par->channel <= 14))
+		registry_par->channel = 36;
+
+	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->check_fw_ps = (u8)rtw_check_fw_ps;
+	registry_par->power_mgnt = (u8)rtw_power_mgnt;
+	registry_par->ips_mode = (u8)rtw_ips_mode;
+	registry_par->lps_level = (u8)rtw_lps_level;
+	registry_par->radio_enable = (u8)rtw_radio_enable;
+	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->qos_enable = (u8)rtw_qos_enable; */
+	registry_par->ack_policy = (u8)rtw_ack_policy;
+	registry_par->mp_mode = (u8)rtw_mp_mode;
+#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
+	registry_par->mp_customer_str = (u8)rtw_mp_customer_str;
+#endif
+	registry_par->software_encrypt = (u8)rtw_software_encrypt;
+	registry_par->software_decrypt = (u8)rtw_software_decrypt;
+
+	registry_par->acm_method = (u8)rtw_acm_method;
+	registry_par->usb_rxagg_mode = (u8)rtw_usb_rxagg_mode;
+	registry_par->dynamic_agg_enable = (u8)rtw_dynamic_agg_enable;
+
+	/* WMM */
+	registry_par->wmm_enable = (u8)rtw_wmm_enable;
+
+#ifdef CONFIG_WMMPS_STA
+	/* UAPSD */
+	registry_par->uapsd_max_sp_len= (u8)rtw_uapsd_max_sp;
+	registry_par->uapsd_ac_enable = (u8)rtw_uapsd_ac_enable;
+	registry_par->wmm_smart_ps = (u8)rtw_wmm_smart_ps;
+#endif /* CONFIG_WMMPS_STA */
+
+	registry_par->RegPwrTrimEnable = (u8)rtw_pwrtrim_enable;
+
+	registry_par->tx_bw_mode = (u8)rtw_tx_bw_mode;
+
+#ifdef CONFIG_80211N_HT
+	registry_par->ht_enable = (u8)rtw_ht_enable;
+	registry_par->bw_mode = (u8)rtw_bw_mode;
+	registry_par->ampdu_enable = (u8)rtw_ampdu_enable;
+	registry_par->rx_stbc = (u8)rtw_rx_stbc;
+	registry_par->rx_ampdu_amsdu = (u8)rtw_rx_ampdu_amsdu;
+	registry_par->tx_ampdu_amsdu = (u8)rtw_tx_ampdu_amsdu;
+	registry_par->short_gi = (u8)rtw_short_gi;
+	registry_par->ldpc_cap = (u8)rtw_ldpc_cap;
+	registry_par->stbc_cap = (u8)rtw_stbc_cap;
+	registry_par->beamform_cap = (u8)rtw_beamform_cap;
+	registry_par->beamformer_rf_num = (u8)rtw_bfer_rf_number;
+	registry_par->beamformee_rf_num = (u8)rtw_bfee_rf_number;
+	rtw_regsty_init_rx_ampdu_sz_limit(registry_par);
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+	registry_par->vht_enable = (u8)rtw_vht_enable;
+	registry_par->ampdu_factor = (u8)rtw_ampdu_factor;
+	registry_par->vht_rx_mcs_map[0] = (u8)(rtw_vht_rx_mcs_map & 0xFF);
+	registry_par->vht_rx_mcs_map[1] = (u8)((rtw_vht_rx_mcs_map & 0xFF00) >> 8);
+#endif
+
+#ifdef CONFIG_TX_EARLY_MODE
+	registry_par->early_mode = (u8)rtw_early_mode;
+#endif
+	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->check_hw_status = (u8)rtw_check_hw_status;
+
+	registry_par->wifi_spec = (u8)rtw_wifi_spec;
+
+	if (strlen(rtw_country_code) != 2
+		|| is_alpha(rtw_country_code[0]) == _FALSE
+		|| is_alpha(rtw_country_code[1]) == _FALSE
+	) {
+		if (rtw_country_code != rtw_country_unspecified)
+			RTW_ERR("%s discard rtw_country_code not in alpha2\n", __func__);
+		_rtw_memset(registry_par->alpha2, 0xFF, 2);
+	} else
+		_rtw_memcpy(registry_par->alpha2, rtw_country_code, 2);
+
+	registry_par->channel_plan = (u8)rtw_channel_plan;
+	rtw_regsty_load_excl_chs(registry_par);
+
+	registry_par->special_rf_path = (u8)rtw_special_rf_path;
+
+	registry_par->full_ch_in_p2p_handshake = (u8)rtw_full_ch_in_p2p_handshake;
+#ifdef CONFIG_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;
+	registry_par->ant_num = (u8)rtw_ant_num;
+	registry_par->single_ant_path = (u8) rtw_single_ant_path;
+#endif
+
+	registry_par->bAcceptAddbaReq = (u8)rtw_AcceptAddbaReq;
+
+	registry_par->antdiv_cfg = (u8)rtw_antdiv_cfg;
+	registry_par->antdiv_type = (u8)rtw_antdiv_type;
+
+	registry_par->drv_ant_band_switch = (u8) rtw_drv_ant_band_switch;
+
+	registry_par->switch_usb_mode = (u8)rtw_switch_usb_mode;
+
+#ifdef CONFIG_AUTOSUSPEND
+	registry_par->usbss_enable = (u8)rtw_enusbss;/* 0:disable,1:enable */
+#endif
+#ifdef SUPPORT_HW_RFOFF_DETECTED
+	registry_par->hwpdn_mode = (u8)rtw_hwpdn_mode;/* 0:disable,1:enable,2:by EFUSE config */
+	registry_par->hwpwrp_detect = (u8)rtw_hwpwrp_detect;/* 0:disable,1:enable */
+#endif
+
+	registry_par->hw_wps_pbc = (u8)rtw_hw_wps_pbc;
+
+#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
+	snprintf(registry_par->adaptor_info_caching_file_path, PATH_LENGTH_MAX, "%s", rtw_adaptor_info_caching_file_path);
+	registry_par->adaptor_info_caching_file_path[PATH_LENGTH_MAX - 1] = 0;
+#endif
+
+#ifdef CONFIG_LAYER2_ROAMING
+	registry_par->max_roaming_times = (u8)rtw_max_roaming_times;
+#ifdef CONFIG_INTEL_WIDI
+	registry_par->max_roaming_times = (u8)rtw_max_roaming_times + 2;
+#endif /* CONFIG_INTEL_WIDI */
+#endif
+
+#ifdef CONFIG_IOL
+	registry_par->fw_iol = rtw_fw_iol;
+#endif
+
+#ifdef CONFIG_80211D
+	registry_par->enable80211d = (u8)rtw_80211d;
+#endif
+
+	snprintf(registry_par->ifname, 16, "%s", ifname);
+	snprintf(registry_par->if2name, 16, "%s", if2name);
+
+	registry_par->notch_filter = (u8)rtw_notch_filter;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	registry_par->virtual_iface_num = (u8)rtw_virtual_iface_num;
+#endif
+	registry_par->pll_ref_clk_sel = (u8)rtw_pll_ref_clk_sel;
+
+#ifdef CONFIG_TXPWR_LIMIT
+	registry_par->RegEnableTxPowerLimit = (u8)rtw_tx_pwr_lmt_enable;
+#endif
+	registry_par->RegEnableTxPowerByRate = (u8)rtw_tx_pwr_by_rate;
+
+	rtw_regsty_load_target_tx_power(registry_par);
+
+	registry_par->TxBBSwing_2G = (s8)rtw_TxBBSwing_2G;
+	registry_par->TxBBSwing_5G = (s8)rtw_TxBBSwing_5G;
+	registry_par->bEn_RFE = 1;
+	registry_par->RFE_Type = (u8)rtw_RFE_type;
+	registry_par->PowerTracking_Type = (u8)rtw_powertracking_type;
+	registry_par->AmplifierType_2G = (u8)rtw_amplifier_type_2g;
+	registry_par->AmplifierType_5G = (u8)rtw_amplifier_type_5g;
+	registry_par->GLNA_Type = (u8)rtw_GLNA_type;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	registry_par->load_phy_file = (u8)rtw_load_phy_file;
+	registry_par->RegDecryptCustomFile = (u8)rtw_decrypt_phy_file;
+#endif
+	registry_par->qos_opt_enable = (u8)rtw_qos_opt_enable;
+
+	registry_par->hiq_filter = (u8)rtw_hiq_filter;
+
+	registry_par->adaptivity_en = (u8)rtw_adaptivity_en;
+	registry_par->adaptivity_mode = (u8)rtw_adaptivity_mode;
+	registry_par->adaptivity_dml = (u8)rtw_adaptivity_dml;
+	registry_par->adaptivity_dc_backoff = (u8)rtw_adaptivity_dc_backoff;
+	registry_par->adaptivity_th_l2h_ini = (s8)rtw_adaptivity_th_l2h_ini;
+	registry_par->adaptivity_th_edcca_hl_diff = (s8)rtw_adaptivity_th_edcca_hl_diff;
+
+#ifdef CONFIG_DYNAMIC_SOML
+	registry_par->dyn_soml_en = (u8)rtw_dynamic_soml_en;
+	registry_par->dyn_soml_train_num = (u8)rtw_dynamic_soml_train_num;
+	registry_par->dyn_soml_interval = (u8)rtw_dynamic_soml_interval;
+	registry_par->dyn_soml_period = (u8)rtw_dynamic_soml_period;
+	registry_par->dyn_soml_delay = (u8)rtw_dynamic_soml_delay;
+#endif
+
+	registry_par->boffefusemask = (u8)rtw_OffEfuseMask;
+	registry_par->bFileMaskEfuse = (u8)rtw_FileMaskEfuse;
+
+#ifdef CONFIG_RTW_ACS
+	registry_par->acs_mode = (u8)rtw_acs;
+	registry_par->acs_auto_scan = (u8)rtw_acs_auto_scan;
+#endif
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	registry_par->nm_mode = (u8)rtw_nm;
+#endif
+	registry_par->reg_rxgain_offset_2g = (u32) rtw_rxgain_offset_2g;
+	registry_par->reg_rxgain_offset_5gl = (u32) rtw_rxgain_offset_5gl;
+	registry_par->reg_rxgain_offset_5gm = (u32) rtw_rxgain_offset_5gm;
+	registry_par->reg_rxgain_offset_5gh = (u32) rtw_rxgain_offset_5gh;
+
+#ifdef CONFIG_DFS_MASTER
+	registry_par->dfs_region_domain = (u8)rtw_dfs_region_domain;
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	registry_par->en_mcc = (u8)rtw_en_mcc;
+	registry_par->rtw_mcc_ap_bw20_target_tx_tp = (u32)rtw_mcc_ap_bw20_target_tx_tp;
+	registry_par->rtw_mcc_ap_bw40_target_tx_tp = (u32)rtw_mcc_ap_bw40_target_tx_tp;
+	registry_par->rtw_mcc_ap_bw80_target_tx_tp = (u32)rtw_mcc_ap_bw80_target_tx_tp;
+	registry_par->rtw_mcc_sta_bw20_target_tx_tp = (u32)rtw_mcc_sta_bw20_target_tx_tp;
+	registry_par->rtw_mcc_sta_bw40_target_tx_tp = (u32)rtw_mcc_sta_bw40_target_tx_tp;
+	registry_par->rtw_mcc_sta_bw80_target_tx_tp = (u32)rtw_mcc_sta_bw80_target_tx_tp;
+	registry_par->rtw_mcc_single_tx_cri = (u32)rtw_mcc_single_tx_cri;
+	registry_par->rtw_mcc_policy_table_idx = rtw_mcc_policy_table_idx;
+	registry_par->rtw_mcc_duration = (u8)rtw_mcc_duration;
+	registry_par->rtw_mcc_enable_runtime_duration = rtw_mcc_enable_runtime_duration;
+#endif /*CONFIG_MCC_MODE */
+
+#ifdef CONFIG_WOWLAN
+	registry_par->wakeup_event = rtw_wakeup_event;
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	registry_par->trx_share_mode = rtw_trx_share_mode;
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	registry_par->pci_aspm_config = rtw_pci_aspm_enable;
+#endif
+
+#ifdef CONFIG_RTW_NAPI
+	registry_par->en_napi = (u8)rtw_en_napi;
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	registry_par->napi_threshold = (u32)rtw_napi_threshold;
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#ifdef CONFIG_RTW_GRO
+	registry_par->en_gro = (u8)rtw_en_gro;
+	if (!registry_par->en_napi && registry_par->en_gro) {
+		registry_par->en_gro = 0;
+		RTW_WARN("Disable GRO because NAPI is not enabled\n");
+	}
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+	registry_par->iqk_fw_offload = (u8)rtw_iqk_fw_offload;
+	registry_par->ch_switch_offload = (u8)rtw_ch_switch_offload;
+
+#ifdef CONFIG_TDLS
+	registry_par->en_tdls = rtw_en_tdls;
+#endif
+
+#ifdef CONFIG_ADVANCE_OTA
+	registry_par->adv_ota = rtw_advnace_ota;
+#endif
+#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+	registry_par->fw_param_init = rtw_fw_param_init;
+#endif
+#ifdef CONFIG_AP_MODE
+	registry_par->bmc_tx_rate = rtw_bmc_tx_rate;
+#endif
+	return status;
+}
+
+/**
+ * rtw_net_set_mac_address
+ * This callback function is used for the Media Access Control address
+ * of each net_device needs to be changed.
+ *
+ * Arguments:
+ * @pnetdev: net_device pointer.
+ * @addr: new MAC address.
+ *
+ * Return:
+ * ret = 0: Permit to change net_device's MAC address.
+ * ret = -1 (Default): Operation not permitted.
+ *
+ * Auther: Arvin Liu
+ * Date: 2015/05/29
+ */
+static int rtw_net_set_mac_address(struct net_device *pnetdev, void *addr)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct sockaddr *sa = (struct sockaddr *)addr;
+	int ret = -1;
+
+	/* only the net_device is in down state to permit modifying mac addr */
+	if ((pnetdev->flags & IFF_UP) == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT": The net_device's is not in down state\n"
+			 , FUNC_ADPT_ARG(padapter));
+
+		return ret;
+	}
+
+	/* if the net_device is linked, it's not permit to modify mac addr */
+	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) ||
+	    check_fwstate(pmlmepriv, _FW_LINKED) ||
+	    check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
+		RTW_INFO(FUNC_ADPT_FMT": The net_device's is not idle currently\n"
+			 , FUNC_ADPT_ARG(padapter));
+
+		return ret;
+	}
+
+	/* check whether the input mac address is valid to permit modifying mac addr */
+	if (rtw_check_invalid_mac_address(sa->sa_data, _FALSE) == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT": Invalid Mac Addr for "MAC_FMT"\n"
+			 , FUNC_ADPT_ARG(padapter), MAC_ARG(sa->sa_data));
+
+		return ret;
+	}
+
+	_rtw_memcpy(adapter_mac_addr(padapter), sa->sa_data, ETH_ALEN); /* set mac addr to adapter */
+	_rtw_memcpy(pnetdev->dev_addr, sa->sa_data, ETH_ALEN); /* set mac addr to net_device */
+
+#if 0
+	if (rtw_is_hw_init_completed(padapter)) {
+		rtw_ps_deny(padapter, PS_DENY_IOCTL);
+		LeaveAllPowerSaveModeDirect(padapter); /* leave PS mode for guaranteeing to access hw register successfully */
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_hal_change_macaddr_mbid(padapter, sa->sa_data);
+#else
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, sa->sa_data); /* set mac addr to mac register */
+#endif
+
+		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+	}
+#else
+	rtw_ps_deny(padapter, PS_DENY_IOCTL);
+	LeaveAllPowerSaveModeDirect(padapter); /* leave PS mode for guaranteeing to access hw register successfully */
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_hal_change_macaddr_mbid(padapter, sa->sa_data);
+#else
+	rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, sa->sa_data); /* set mac addr to mac register */
+#endif
+	rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT": Set Mac Addr to "MAC_FMT" Successfully\n"
+		 , FUNC_ADPT_ARG(padapter), MAC_ARG(sa->sa_data));
+
+	ret = 0;
+
+	return ret;
+}
+
+static struct net_device_stats *rtw_net_get_stats(struct net_device *pnetdev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+
+	padapter->stats.tx_packets = pxmitpriv->tx_pkts;/* pxmitpriv->tx_pkts++; */
+	padapter->stats.rx_packets = precvpriv->rx_pkts;/* 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;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+/*
+ * 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. */
+unsigned int rtw_classify8021d(struct sk_buff *skb)
+{
+	unsigned int 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
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0)
+	, void *accel_priv
+	#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
+	, select_queue_fallback_t fallback
+	#endif
+#endif
+)
+{
+	_adapter	*padapter = rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	skb->priority = rtw_classify8021d(skb);
+
+	if (pmlmepriv->acm_mask != 0)
+		skb->priority = qos_acm(pmlmepriv->acm_mask, skb->priority);
+
+	return rtw_1d_to_queue[skb->priority];
+}
+
+u16 rtw_recv_select_queue(struct sk_buff *skb)
+{
+	struct iphdr *piphdr;
+	unsigned int dscp;
+	u16	eth_type;
+	u32 priority;
+	u8 *pdata = skb->data;
+
+	_rtw_memcpy(&eth_type, pdata + (ETH_ALEN << 1), 2);
+
+	switch (eth_type) {
+	case htons(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];
+
+}
+
+#endif
+
+static u8 is_rtw_ndev(struct net_device *ndev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+	return ndev->netdev_ops
+		&& ndev->netdev_ops->ndo_do_ioctl
+		&& ndev->netdev_ops->ndo_do_ioctl == rtw_ioctl;
+#else
+	return ndev->do_ioctl
+		&& ndev->do_ioctl == rtw_ioctl;
+#endif
+}
+
+static int rtw_ndev_notifier_call(struct notifier_block *nb, unsigned long state, void *ptr)
+{
+	struct net_device *ndev;
+
+	if (ptr == NULL)
+		return NOTIFY_DONE;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	ndev = netdev_notifier_info_to_dev(ptr);
+#else
+	ndev = ptr;
+#endif
+
+	if (ndev == NULL)
+		return NOTIFY_DONE;
+
+	if (!is_rtw_ndev(ndev))
+		return NOTIFY_DONE;
+
+	RTW_INFO(FUNC_NDEV_FMT" state:%lu\n", FUNC_NDEV_ARG(ndev), state);
+
+	switch (state) {
+	case NETDEV_CHANGENAME:
+		rtw_adapter_proc_replace(ndev);
+		break;
+	}
+
+	return NOTIFY_DONE;
+}
+
+static struct notifier_block rtw_ndev_notifier = {
+	.notifier_call = rtw_ndev_notifier_call,
+};
+
+int rtw_ndev_notifier_register(void)
+{
+	return register_netdevice_notifier(&rtw_ndev_notifier);
+}
+
+void rtw_ndev_notifier_unregister(void)
+{
+	unregister_netdevice_notifier(&rtw_ndev_notifier);
+}
+
+int rtw_ndev_init(struct net_device *dev)
+{
+	_adapter *adapter = rtw_netdev_priv(dev);
+
+	RTW_PRINT(FUNC_ADPT_FMT" if%d mac_addr="MAC_FMT"\n"
+		, FUNC_ADPT_ARG(adapter), (adapter->iface_id + 1), MAC_ARG(dev->dev_addr));
+	strncpy(adapter->old_ifname, dev->name, IFNAMSIZ);
+	adapter->old_ifname[IFNAMSIZ - 1] = '\0';
+	rtw_adapter_proc_init(dev);
+
+	return 0;
+}
+
+void rtw_ndev_uninit(struct net_device *dev)
+{
+	_adapter *adapter = rtw_netdev_priv(dev);
+
+	RTW_PRINT(FUNC_ADPT_FMT" if%d\n"
+		  , FUNC_ADPT_ARG(adapter), (adapter->iface_id + 1));
+	rtw_adapter_proc_deinit(dev);
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+static const struct net_device_ops rtw_netdev_ops = {
+	.ndo_init = rtw_ndev_init,
+	.ndo_uninit = rtw_ndev_uninit,
+	.ndo_open = netdev_open,
+	.ndo_stop = netdev_close,
+	.ndo_start_xmit = rtw_xmit_entry,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	.ndo_select_queue	= rtw_select_queue,
+#endif
+	.ndo_set_mac_address = rtw_net_set_mac_address,
+	.ndo_get_stats = rtw_net_get_stats,
+	.ndo_do_ioctl = rtw_ioctl,
+};
+#endif
+
+int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname)
+{
+	_adapter *padapter = rtw_netdev_priv(pnetdev);
+
+#ifdef CONFIG_EASY_REPLACEMENT
+	struct net_device	*TargetNetdev = NULL;
+	_adapter			*TargetAdapter = NULL;
+	struct net		*devnet = NULL;
+
+	if (padapter->bDongle == 1) {
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+		TargetNetdev = dev_get_by_name("wlan0");
+#else
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
+		devnet = pnetdev->nd_net;
+#else
+		devnet = dev_net(pnetdev);
+#endif
+		TargetNetdev = dev_get_by_name(devnet, "wlan0");
+#endif
+		if (TargetNetdev) {
+			RTW_INFO("Force onboard module driver disappear !!!\n");
+			TargetAdapter = rtw_netdev_priv(TargetNetdev);
+			TargetAdapter->DriverState = DRIVER_DISAPPEAR;
+
+			padapter->pid[0] = TargetAdapter->pid[0];
+			padapter->pid[1] = TargetAdapter->pid[1];
+			padapter->pid[2] = TargetAdapter->pid[2];
+
+			dev_put(TargetNetdev);
+			unregister_netdev(TargetNetdev);
+
+			padapter->DriverState = DRIVER_REPLACE_DONGLE;
+		}
+	}
+#endif /* CONFIG_EASY_REPLACEMENT */
+
+	if (dev_alloc_name(pnetdev, ifname) < 0)
+		RTW_ERR("dev_alloc_name, fail!\n");
+
+	rtw_netif_carrier_off(pnetdev);
+	/* rtw_netif_stop_queue(pnetdev); */
+
+	return 0;
+}
+
+void rtw_hook_if_ops(struct net_device *ndev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+	ndev->netdev_ops = &rtw_netdev_ops;
+#else
+	ndev->init = rtw_ndev_init;
+	ndev->uninit = rtw_ndev_uninit;
+	ndev->open = netdev_open;
+	ndev->stop = netdev_close;
+	ndev->hard_start_xmit = rtw_xmit_entry;
+	ndev->set_mac_address = rtw_net_set_mac_address;
+	ndev->get_stats = rtw_net_get_stats;
+	ndev->do_ioctl = rtw_ioctl;
+#endif
+}
+
+#ifdef CONFIG_CONCURRENT_MODE
+static void rtw_hook_vir_if_ops(struct net_device *ndev);
+#endif
+struct net_device *rtw_init_netdev(_adapter *old_padapter)
+{
+	_adapter *padapter;
+	struct net_device *pnetdev;
+
+	if (old_padapter != NULL) {
+		rtw_os_ndev_free(old_padapter);
+		pnetdev = rtw_alloc_etherdev_with_old_priv(sizeof(_adapter), (void *)old_padapter);
+	} else
+		pnetdev = rtw_alloc_etherdev(sizeof(_adapter));
+
+	if (!pnetdev)
+		return NULL;
+
+	padapter = rtw_netdev_priv(pnetdev);
+	padapter->pnetdev = pnetdev;
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24)
+	SET_MODULE_OWNER(pnetdev);
+#endif
+
+	rtw_hook_if_ops(pnetdev);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (!is_primary_adapter(padapter))
+		rtw_hook_vir_if_ops(pnetdev);
+#endif /* CONFIG_CONCURRENT_MODE */
+
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+	pnetdev->features |= NETIF_F_IP_CSUM;
+#endif
+
+#ifdef CONFIG_RTW_NETIF_SG
+		pnetdev->features |= NETIF_F_SG;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
+		pnetdev->hw_features |= NETIF_F_SG;
+#endif
+#endif
+
+	/* pnetdev->tx_timeout = NULL; */
+	pnetdev->watchdog_timeo = HZ * 3; /* 3 second timeout */
+
+#ifdef CONFIG_WIRELESS_EXT
+	pnetdev->wireless_handlers = (struct iw_handler_def *)&rtw_handlers_def;
+#endif
+
+#ifdef WIRELESS_SPY
+	/* priv->wireless_data.spy_data = &priv->spy_data; */
+	/* pnetdev->wireless_data = &priv->wireless_data; */
+#endif
+
+	return pnetdev;
+}
+
+int rtw_os_ndev_alloc(_adapter *adapter)
+{
+	int ret = _FAIL;
+	struct net_device *ndev = NULL;
+
+	ndev = rtw_init_netdev(adapter);
+	if (ndev == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 0)
+	SET_NETDEV_DEV(ndev, dvobj_to_dev(adapter_to_dvobj(adapter)));
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	if (adapter_to_dvobj(adapter)->bdma64)
+		ndev->features |= NETIF_F_HIGHDMA;
+	ndev->irq = adapter_to_dvobj(adapter)->irq;
+#endif
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	if (rtw_cfg80211_ndev_res_alloc(adapter) != _SUCCESS) {
+		rtw_warn_on(1);
+		goto free_ndev;
+	}
+#endif
+
+	ret = _SUCCESS;
+
+free_ndev:
+	if (ret != _SUCCESS && ndev)
+		rtw_free_netdev(ndev);
+exit:
+	return ret;
+}
+
+void rtw_os_ndev_free(_adapter *adapter)
+{
+#if defined(CONFIG_IOCTL_CFG80211)
+	rtw_cfg80211_ndev_res_free(adapter);
+#endif
+
+	if (adapter->pnetdev) {
+		rtw_free_netdev(adapter->pnetdev);
+		adapter->pnetdev = NULL;
+	}
+}
+
+int rtw_os_ndev_register(_adapter *adapter, const char *name)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	int ret = _SUCCESS;
+	struct net_device *ndev = adapter->pnetdev;
+	u8 rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+
+#ifdef CONFIG_RTW_NAPI
+	netif_napi_add(ndev, &adapter->napi, rtw_recv_napi_poll, RTL_NAPI_WEIGHT);
+#endif /* CONFIG_RTW_NAPI */
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	if (rtw_cfg80211_ndev_res_register(adapter) != _SUCCESS) {
+		rtw_warn_on(1);
+		ret = _FAIL;
+		goto exit;
+	}
+#endif
+
+	/* alloc netdev name */
+	rtw_init_netdev_name(ndev, name);
+
+	_rtw_memcpy(ndev->dev_addr, adapter_mac_addr(adapter), ETH_ALEN);
+
+	/* Tell the network stack we exist */
+
+	if (rtnl_lock_needed)
+		ret = (register_netdev(ndev) == 0) ? _SUCCESS : _FAIL;
+	else
+		ret = (register_netdevice(ndev) == 0) ? _SUCCESS : _FAIL;
+
+	if (ret == _SUCCESS)
+		adapter->registered = 1;
+	else
+		RTW_INFO(FUNC_NDEV_FMT" if%d Failed!\n", FUNC_NDEV_ARG(ndev), (adapter->iface_id + 1));
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	if (ret != _SUCCESS) {
+		rtw_cfg80211_ndev_res_unregister(adapter);
+		#if !defined(RTW_SINGLE_WIPHY)
+		rtw_wiphy_unregister(adapter_to_wiphy(adapter));
+		#endif
+	}
+#endif
+
+exit:
+#ifdef CONFIG_RTW_NAPI
+	if (ret != _SUCCESS)
+		netif_napi_del(&adapter->napi);
+#endif /* CONFIG_RTW_NAPI */
+
+	return ret;
+}
+
+void rtw_os_ndev_unregister(_adapter *adapter)
+{
+	struct net_device *netdev = NULL;
+
+	if (adapter == NULL || adapter->registered == 0)
+		return;
+
+	adapter->ndev_unregistering = 1;
+
+	netdev = adapter->pnetdev;
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	rtw_cfg80211_ndev_res_unregister(adapter);
+#endif
+
+	if ((adapter->DriverState != DRIVER_DISAPPEAR) && netdev) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+		u8 rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+
+		if (rtnl_lock_needed)
+			unregister_netdev(netdev);
+		else
+			unregister_netdevice(netdev);
+	}
+
+#if defined(CONFIG_IOCTL_CFG80211) && !defined(RTW_SINGLE_WIPHY)
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_deinit_rfkill(adapter_to_wiphy(adapter));
+#endif
+	rtw_wiphy_unregister(adapter_to_wiphy(adapter));
+#endif
+
+#ifdef CONFIG_RTW_NAPI
+	if (adapter->napi_state == NAPI_ENABLE) {
+		napi_disable(&adapter->napi);
+		adapter->napi_state = NAPI_DISABLE;
+	}
+	netif_napi_del(&adapter->napi);
+#endif /* CONFIG_RTW_NAPI */
+
+	adapter->registered = 0;
+	adapter->ndev_unregistering = 0;
+}
+
+/**
+ * rtw_os_ndev_init - Allocate and register OS layer net device and relating structures for @adapter
+ * @adapter: the adapter on which this function applies
+ * @name: the requesting net device name
+ *
+ * Returns:
+ * _SUCCESS or _FAIL
+ */
+int rtw_os_ndev_init(_adapter *adapter, const char *name)
+{
+	int ret = _FAIL;
+
+	if (rtw_os_ndev_alloc(adapter) != _SUCCESS)
+		goto exit;
+
+	if (rtw_os_ndev_register(adapter, name) != _SUCCESS)
+		goto os_ndev_free;
+
+	ret = _SUCCESS;
+
+os_ndev_free:
+	if (ret != _SUCCESS)
+		rtw_os_ndev_free(adapter);
+exit:
+	return ret;
+}
+
+/**
+ * rtw_os_ndev_deinit - Unregister and free OS layer net device and relating structures for @adapter
+ * @adapter: the adapter on which this function applies
+ */
+void rtw_os_ndev_deinit(_adapter *adapter)
+{
+	rtw_os_ndev_unregister(adapter);
+	rtw_os_ndev_free(adapter);
+}
+
+int rtw_os_ndevs_alloc(struct dvobj_priv *dvobj)
+{
+	int i, status = _SUCCESS;
+	_adapter *adapter;
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	if (rtw_cfg80211_dev_res_alloc(dvobj) != _SUCCESS) {
+		rtw_warn_on(1);
+		status = _FAIL;
+		goto exit;
+	}
+#endif
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+
+		if (i >= CONFIG_IFACE_NUMBER) {
+			RTW_ERR("%s %d >= CONFIG_IFACE_NUMBER(%d)\n", __func__, i, CONFIG_IFACE_NUMBER);
+			rtw_warn_on(1);
+			continue;
+		}
+
+		adapter = dvobj->padapters[i];
+		if (adapter && !adapter->pnetdev) {
+
+			#ifdef CONFIG_RTW_DYNAMIC_NDEV
+			if (!is_primary_adapter(adapter))
+				continue;
+			#endif
+
+			status = rtw_os_ndev_alloc(adapter);
+			if (status != _SUCCESS) {
+				rtw_warn_on(1);
+				break;
+			}
+		}
+	}
+
+	if (status != _SUCCESS) {
+		for (; i >= 0; i--) {
+			adapter = dvobj->padapters[i];
+			if (adapter && adapter->pnetdev)
+				rtw_os_ndev_free(adapter);
+		}
+	}
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	if (status != _SUCCESS)
+		rtw_cfg80211_dev_res_free(dvobj);
+#endif
+exit:
+	return status;
+}
+
+void rtw_os_ndevs_free(struct dvobj_priv *dvobj)
+{
+	int i;
+	_adapter *adapter = NULL;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+
+		if (i >= CONFIG_IFACE_NUMBER) {
+			RTW_ERR("%s %d >= CONFIG_IFACE_NUMBER(%d)\n", __func__, i, CONFIG_IFACE_NUMBER);
+			rtw_warn_on(1);
+			continue;
+		}
+
+		adapter = dvobj->padapters[i];
+
+		if (adapter == NULL)
+			continue;
+
+		rtw_os_ndev_free(adapter);
+	}
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	rtw_cfg80211_dev_res_free(dvobj);
+#endif
+}
+
+u32 rtw_start_drv_threads(_adapter *padapter)
+{
+	u32 _status = _SUCCESS;
+
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+#if defined(CONFIG_SDIO_HCI)
+	if (is_primary_adapter(padapter))
+#endif
+	{
+		if (padapter->xmitThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_XMIT_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->xmitThread = kthread_run(rtw_xmit_thread, padapter, "RTW_XMIT_THREAD");
+			if (IS_ERR(padapter->xmitThread)) {
+				padapter->xmitThread = NULL;
+				_status = _FAIL;
+			}
+		}
+	}
+#endif /* #ifdef CONFIG_XMIT_THREAD_MODE */
+
+#ifdef CONFIG_RECV_THREAD_MODE
+	if (is_primary_adapter(padapter)) {
+		if (padapter->recvThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_RECV_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->recvThread = kthread_run(rtw_recv_thread, padapter, "RTW_RECV_THREAD");
+			if (IS_ERR(padapter->recvThread)) {
+				padapter->recvThread = NULL;
+				_status = _FAIL;
+			}
+		}
+	}
+#endif
+
+	if (is_primary_adapter(padapter)) {
+		if (padapter->cmdThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_CMD_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->cmdThread = kthread_run(rtw_cmd_thread, padapter, "RTW_CMD_THREAD");
+			if (IS_ERR(padapter->cmdThread)) {
+				padapter->cmdThread = NULL;
+				_status = _FAIL;
+			}
+			else
+				_rtw_down_sema(&padapter->cmdpriv.start_cmdthread_sema); /* wait for cmd_thread to run */
+		}
+	}
+
+
+#ifdef CONFIG_EVENT_THREAD_MODE
+	if (padapter->evtThread == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT " start RTW_EVENT_THREAD\n", FUNC_ADPT_ARG(padapter));
+		padapter->evtThread = kthread_run(event_thread, padapter, "RTW_EVENT_THREAD");
+		if (IS_ERR(padapter->evtThread)) {
+			padapter->evtThread = NULL;
+			_status = _FAIL;
+		}
+	}
+#endif
+
+	rtw_hal_start_thread(padapter);
+	return _status;
+
+}
+
+void rtw_stop_drv_threads(_adapter *padapter)
+{
+
+	if (is_primary_adapter(padapter))
+		rtw_stop_cmd_thread(padapter);
+
+#ifdef CONFIG_EVENT_THREAD_MODE
+	if (padapter->evtThread) {
+		_rtw_up_sema(&padapter->evtpriv.evt_notify);
+		rtw_thread_stop(padapter->evtThread);
+		padapter->evtThread = NULL;
+	}
+#endif
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+	/* Below is to termindate tx_thread... */
+#if defined(CONFIG_SDIO_HCI)
+	/* Only wake-up primary adapter */
+	if (is_primary_adapter(padapter))
+#endif  /*SDIO_HCI */
+	{
+		if (padapter->xmitThread) {
+			_rtw_up_sema(&padapter->xmitpriv.xmit_sema);
+			rtw_thread_stop(padapter->xmitThread);
+			padapter->xmitThread = NULL;
+		}
+	}
+#endif
+
+#ifdef CONFIG_RECV_THREAD_MODE
+	if (is_primary_adapter(padapter) && padapter->recvThread) {
+		/* Below is to termindate rx_thread... */
+		_rtw_up_sema(&padapter->recvpriv.recv_sema);
+		rtw_thread_stop(padapter->recvThread);
+		padapter->recvThread = NULL;
+	}
+#endif
+
+	rtw_hal_stop_thread(padapter);
+}
+
+u8 rtw_init_default_value(_adapter *padapter);
+u8 rtw_init_default_value(_adapter *padapter)
+{
+	u8 ret  = _SUCCESS;
+	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_setting = pregistrypriv->vrtl_carrier_sense;
+	pxmitpriv->vcs = pregistrypriv->vcs_type;
+	pxmitpriv->vcs_type = pregistrypriv->vcs_type;
+	/* pxmitpriv->rts_thresh = pregistrypriv->rts_thresh; */
+	pxmitpriv->frag_len = pregistrypriv->frag_thresh;
+
+	/* security_priv */
+	/* rtw_get_encrypt_decrypt_from_registrypriv(padapter); */
+	psecuritypriv->binstallGrpkey = _FAIL;
+#ifdef CONFIG_GTK_OL
+	psecuritypriv->binstallKCK_KEK = _FAIL;
+#endif /* CONFIG_GTK_OL */
+	psecuritypriv->sw_encrypt = pregistrypriv->software_encrypt;
+	psecuritypriv->sw_decrypt = pregistrypriv->software_decrypt;
+
+	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+
+	psecuritypriv->dot11PrivacyKeyIndex = 0;
+
+	psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+	psecuritypriv->dot118021XGrpKeyid = 1;
+
+	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
+	psecuritypriv->ndisencryptstatus = Ndis802_11WEPDisabled;
+#ifdef CONFIG_CONCURRENT_MODE
+	psecuritypriv->dot118021x_bmc_cam_id = INVALID_SEC_MAC_CAM_ID;
+#endif
+
+
+	/* pwrctrl_priv */
+
+
+	/* registry_priv */
+	rtw_init_registrypriv_dev_network(padapter);
+	rtw_update_registrypriv_dev_network(padapter);
+
+
+	/* hal_priv */
+	rtw_hal_def_value_init(padapter);
+
+#ifdef CONFIG_MCC_MODE
+	/* MCC parameter */
+	rtw_hal_mcc_parameter_init(padapter);
+#endif /* CONFIG_MCC_MODE */
+
+	/* misc. */
+	RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
+	RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
+	padapter->bLinkInfoDump = 0;
+	padapter->bNotifyChannelChange = _FALSE;
+#ifdef CONFIG_P2P
+	padapter->bShowGetP2PState = 1;
+#endif
+
+	/* for debug purpose */
+	padapter->fix_rate = 0xFF;
+	padapter->data_fb = 0;
+	padapter->fix_bw = 0xFF;
+	padapter->power_offset = 0;
+	padapter->rsvd_page_offset = 0;
+	padapter->rsvd_page_num = 0;
+#ifdef CONFIG_AP_MODE
+	padapter->bmc_tx_rate = pregistrypriv->bmc_tx_rate;
+#endif
+	padapter->driver_tx_bw_mode = pregistrypriv->tx_bw_mode;
+
+	padapter->driver_ampdu_spacing = 0xFF;
+	padapter->driver_rx_ampdu_factor =  0xFF;
+	padapter->driver_rx_ampdu_spacing = 0xFF;
+	padapter->fix_rx_ampdu_accept = RX_AMPDU_ACCEPT_INVALID;
+	padapter->fix_rx_ampdu_size = RX_AMPDU_SIZE_INVALID;
+#ifdef CONFIG_TX_AMSDU
+	padapter->tx_amsdu = 2;
+	padapter->tx_amsdu_rate = 400;
+#endif
+	padapter->driver_tx_max_agg_num = 0xFF;
+#ifdef DBG_RX_COUNTER_DUMP
+	padapter->dump_rx_cnt_mode = 0;
+	padapter->drv_rx_cnt_ok = 0;
+	padapter->drv_rx_cnt_crcerror = 0;
+	padapter->drv_rx_cnt_drop = 0;
+#endif
+#ifdef CONFIG_RTW_NAPI
+	padapter->napi_state = NAPI_DISABLE;
+#endif
+	padapter->tsf.sync_port =  MAX_HW_PORT;
+	padapter->tsf.offset = 0;
+
+#ifdef CONFIG_RTW_ACS
+	if (pregistrypriv->acs_mode)
+		rtw_acs_start(padapter);
+	else
+		rtw_acs_stop(padapter);
+#endif
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	if (pregistrypriv->nm_mode)
+		rtw_nm_enable(padapter);
+	else
+		rtw_nm_disable(padapter);
+#endif
+	return ret;
+}
+
+struct dvobj_priv *devobj_init(void)
+{
+	struct dvobj_priv *pdvobj = NULL;
+
+	pdvobj = (struct dvobj_priv *)rtw_zmalloc(sizeof(*pdvobj));
+	if (pdvobj == NULL)
+		return NULL;
+
+	_rtw_mutex_init(&pdvobj->hw_init_mutex);
+	_rtw_mutex_init(&pdvobj->h2c_fwcmd_mutex);
+	_rtw_mutex_init(&pdvobj->setch_mutex);
+	_rtw_mutex_init(&pdvobj->setbw_mutex);
+	_rtw_mutex_init(&pdvobj->rf_read_reg_mutex);
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+	_rtw_mutex_init(&pdvobj->sd_indirect_access_mutex);
+#endif
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	_rtw_mutex_init(&pdvobj->customer_str_mutex);
+	_rtw_memset(pdvobj->customer_str, 0xFF, RTW_CUSTOMER_STR_LEN);
+#endif
+
+	pdvobj->processing_dev_remove = _FALSE;
+
+	ATOMIC_SET(&pdvobj->disable_func, 0);
+
+	rtw_macid_ctl_init(&pdvobj->macid_ctl);
+	_rtw_spinlock_init(&pdvobj->cam_ctl.lock);
+	_rtw_mutex_init(&pdvobj->cam_ctl.sec_cam_access_mutex);
+#if defined(RTK_129X_PLATFORM) && defined(CONFIG_PCI_HCI)
+	_rtw_spinlock_init(&pdvobj->io_reg_lock);
+#endif
+#ifdef CONFIG_MBSSID_CAM
+	rtw_mbid_cam_init(pdvobj);
+#endif
+
+#ifdef CONFIG_AP_MODE
+	pdvobj->nr_ap_if = 0;
+	pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL; /* default value is equal to the default beacon_interval (100ms) */
+	_rtw_init_queue(&pdvobj->ap_if_q);
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	rtw_init_timer(&(pdvobj->txbcn_timer), NULL, tx_beacon_timer_handlder, pdvobj);
+#endif
+#endif
+
+	rtw_init_timer(&(pdvobj->dynamic_chk_timer), NULL, rtw_dynamic_check_timer_handlder, pdvobj);
+
+#ifdef CONFIG_MCC_MODE
+	_rtw_mutex_init(&(pdvobj->mcc_objpriv.mcc_mutex));
+	_rtw_spinlock_init(&pdvobj->mcc_objpriv.mcc_lock);
+#endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	pdvobj->en_napi_dynamic = 0;
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+
+
+	return pdvobj;
+
+}
+
+void devobj_deinit(struct dvobj_priv *pdvobj)
+{
+	if (!pdvobj)
+		return;
+
+	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
+#if defined(CONFIG_IOCTL_CFG80211)
+	rtw_cfg80211_dev_res_free(pdvobj);
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	_rtw_mutex_free(&(pdvobj->mcc_objpriv.mcc_mutex));
+	_rtw_spinlock_free(&pdvobj->mcc_objpriv.mcc_lock);
+#endif /* CONFIG_MCC_MODE */
+
+	_rtw_mutex_free(&pdvobj->hw_init_mutex);
+	_rtw_mutex_free(&pdvobj->h2c_fwcmd_mutex);
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	_rtw_mutex_free(&pdvobj->customer_str_mutex);
+#endif
+
+	_rtw_mutex_free(&pdvobj->setch_mutex);
+	_rtw_mutex_free(&pdvobj->setbw_mutex);
+	_rtw_mutex_free(&pdvobj->rf_read_reg_mutex);
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+	_rtw_mutex_free(&pdvobj->sd_indirect_access_mutex);
+#endif
+
+	rtw_macid_ctl_deinit(&pdvobj->macid_ctl);
+	_rtw_spinlock_free(&pdvobj->cam_ctl.lock);
+	_rtw_mutex_free(&pdvobj->cam_ctl.sec_cam_access_mutex);
+
+#if defined(RTK_129X_PLATFORM) && defined(CONFIG_PCI_HCI)
+	_rtw_spinlock_free(&pdvobj->io_reg_lock);
+#endif
+#ifdef CONFIG_MBSSID_CAM
+	rtw_mbid_cam_deinit(pdvobj);
+#endif
+
+	_rtw_spinlock_free(&(pdvobj->ap_if_q.lock));
+
+	rtw_mfree((u8 *)pdvobj, sizeof(*pdvobj));
+}
+
+inline u8 rtw_rtnl_lock_needed(struct dvobj_priv *dvobj)
+{
+	if (dvobj->rtnl_lock_holder && dvobj->rtnl_lock_holder == current)
+		return 0;
+	return 1;
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
+static inline int rtnl_is_locked(void)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 17))
+	if (unlikely(rtnl_trylock())) {
+		rtnl_unlock();
+#else
+	if (unlikely(down_trylock(&rtnl_sem) == 0)) {
+		up(&rtnl_sem);
+#endif
+		return 0;
+	}
+	return 1;
+}
+#endif
+
+inline void rtw_set_rtnl_lock_holder(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl)
+{
+	rtw_warn_on(!rtnl_is_locked());
+
+	if (!thd_hdl || rtnl_is_locked())
+		dvobj->rtnl_lock_holder = thd_hdl;
+
+	if (dvobj->rtnl_lock_holder && 0)
+		RTW_INFO("rtnl_lock_holder: %s:%d\n", current->comm, current->pid);
+}
+
+u8 rtw_reset_drv_sw(_adapter *padapter)
+{
+	u8	ret8 = _SUCCESS;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+
+	/* hal_priv */
+	if (is_primary_adapter(padapter))
+		rtw_hal_def_value_init(padapter);
+
+	RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
+	RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
+
+	padapter->tsf.sync_port =  MAX_HW_PORT;
+	padapter->tsf.offset = 0;
+
+	padapter->bLinkInfoDump = 0;
+
+	padapter->xmitpriv.tx_pkts = 0;
+	padapter->recvpriv.rx_pkts = 0;
+
+	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
+
+	/* pmlmepriv->LinkDetectInfo.TrafficBusyState = _FALSE; */
+	pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
+	pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
+
+	_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING);
+
+#ifdef CONFIG_AUTOSUSPEND
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 34))
+	adapter_to_dvobj(padapter)->pusbdev->autosuspend_disabled = 1;/* autosuspend disabled by the user */
+#endif
+#endif
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	if (is_primary_adapter(padapter))
+		rtw_hal_sreset_reset_value(padapter);
+#endif
+	pwrctrlpriv->pwr_state_check_cnts = 0;
+
+	/* mlmeextpriv */
+	mlmeext_set_scan_state(&padapter->mlmeextpriv, SCAN_DISABLE);
+
+#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
+	rtw_set_signal_stat_timer(&padapter->recvpriv);
+#endif
+
+	return ret8;
+}
+
+
+u8 rtw_init_drv_sw(_adapter *padapter)
+{
+
+	u8	ret8 = _SUCCESS;
+
+
+
+	_rtw_init_listhead(&padapter->list);
+
+	ret8 = rtw_init_default_value(padapter);
+
+	if ((rtw_init_cmd_priv(&padapter->cmdpriv)) == _FAIL) {
+		ret8 = _FAIL;
+		goto exit;
+	}
+
+	padapter->cmdpriv.padapter = padapter;
+
+	if ((rtw_init_evt_priv(&padapter->evtpriv)) == _FAIL) {
+		ret8 = _FAIL;
+		goto exit;
+	}
+
+	if (is_primary_adapter(padapter))
+		rtw_rfctl_init(padapter);
+
+	if (rtw_init_mlme_priv(padapter) == _FAIL) {
+		ret8 = _FAIL;
+		goto exit;
+	}
+
+#ifdef CONFIG_P2P
+	rtw_init_wifidirect_timers(padapter);
+	init_wifidirect_info(padapter, P2P_ROLE_DISABLE);
+	reset_global_wifidirect_info(padapter);
+	#ifdef CONFIG_IOCTL_CFG80211
+	rtw_init_cfg80211_wifidirect_info(padapter);
+	#endif
+#ifdef CONFIG_WFD
+	if (rtw_init_wifi_display_info(padapter) == _FAIL)
+		RTW_ERR("Can't init init_wifi_display_info\n");
+#endif
+#endif /* CONFIG_P2P */
+
+	if (init_mlme_ext_priv(padapter) == _FAIL) {
+		ret8 = _FAIL;
+		goto exit;
+	}
+
+#ifdef CONFIG_TDLS
+	if (rtw_init_tdls_info(padapter) == _FAIL) {
+		RTW_INFO("Can't rtw_init_tdls_info\n");
+		ret8 = _FAIL;
+		goto exit;
+	}
+#endif /* CONFIG_TDLS */
+
+#ifdef CONFIG_RTW_MESH
+	rtw_mesh_cfg_init(padapter);
+#endif
+
+	if (_rtw_init_xmit_priv(&padapter->xmitpriv, padapter) == _FAIL) {
+		RTW_INFO("Can't _rtw_init_xmit_priv\n");
+		ret8 = _FAIL;
+		goto exit;
+	}
+
+	if (_rtw_init_recv_priv(&padapter->recvpriv, padapter) == _FAIL) {
+		RTW_INFO("Can't _rtw_init_recv_priv\n");
+		ret8 = _FAIL;
+		goto exit;
+	}
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
+	_rtw_spinlock_init(&padapter->security_key_mutex);
+
+	/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
+	/* _rtw_memset((unsigned char *)&padapter->securitypriv, 0, sizeof (struct security_priv)); */
+
+	if (_rtw_init_sta_priv(&padapter->stapriv) == _FAIL) {
+		RTW_INFO("Can't _rtw_init_sta_priv\n");
+		ret8 = _FAIL;
+		goto exit;
+	}
+
+	padapter->setband = WIFI_FREQUENCY_BAND_AUTO;
+	padapter->fix_rate = 0xFF;
+	padapter->power_offset = 0;
+	padapter->rsvd_page_offset = 0;
+	padapter->rsvd_page_num = 0;
+
+	padapter->data_fb = 0;
+	padapter->fix_rx_ampdu_accept = RX_AMPDU_ACCEPT_INVALID;
+	padapter->fix_rx_ampdu_size = RX_AMPDU_SIZE_INVALID;
+#ifdef DBG_RX_COUNTER_DUMP
+	padapter->dump_rx_cnt_mode = 0;
+	padapter->drv_rx_cnt_ok = 0;
+	padapter->drv_rx_cnt_crcerror = 0;
+	padapter->drv_rx_cnt_drop = 0;
+#endif
+	rtw_init_bcmc_stainfo(padapter);
+
+	rtw_init_pwrctrl_priv(padapter);
+
+	/* _rtw_memset((u8 *)&padapter->qospriv, 0, sizeof (struct qos_priv)); */ /* move to mlme_priv */
+
+#ifdef CONFIG_MP_INCLUDED
+	if (init_mp_priv(padapter) == _FAIL)
+		RTW_INFO("%s: initialize MP private data Fail!\n", __func__);
+#endif
+
+	rtw_hal_dm_init(padapter);
+#ifdef CONFIG_RTW_SW_LED
+	rtw_hal_sw_led_init(padapter);
+#endif
+#ifdef DBG_CONFIG_ERROR_DETECT
+	rtw_hal_sreset_init(padapter);
+#endif
+
+#ifdef CONFIG_INTEL_WIDI
+	if (rtw_init_intel_widi(padapter) == _FAIL) {
+		RTW_INFO("Can't rtw_init_intel_widi\n");
+		ret8 = _FAIL;
+		goto exit;
+	}
+#endif /* CONFIG_INTEL_WIDI */
+
+#ifdef CONFIG_WAPI_SUPPORT
+	padapter->WapiSupport = true; /* set true temp, will revise according to Efuse or Registry value later. */
+	rtw_wapi_init(padapter);
+#endif
+
+#ifdef CONFIG_BR_EXT
+	_rtw_spinlock_init(&padapter->br_ext_lock);
+#endif /* CONFIG_BR_EXT */
+
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+	rtw_bf_init(padapter);
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	init_rtw_rson_data(adapter_to_dvobj(padapter));
+#endif
+
+#ifdef CONFIG_RTW_80211K
+	rtw_init_rm(padapter);
+#endif
+
+exit:
+
+
+
+	return ret8;
+
+}
+
+#ifdef CONFIG_WOWLAN
+void rtw_cancel_dynamic_chk_timer(_adapter *padapter)
+{
+	_cancel_timer_ex(&adapter_to_dvobj(padapter)->dynamic_chk_timer);
+}
+#endif
+
+void rtw_cancel_all_timer(_adapter *padapter)
+{
+
+	_cancel_timer_ex(&padapter->mlmepriv.assoc_timer);
+
+	_cancel_timer_ex(&padapter->mlmepriv.scan_to_timer);
+
+#ifdef CONFIG_DFS_MASTER
+	_cancel_timer_ex(&padapter->mlmepriv.dfs_master_timer);
+#endif
+
+	_cancel_timer_ex(&adapter_to_dvobj(padapter)->dynamic_chk_timer);
+#ifdef CONFIG_RTW_SW_LED
+	/* cancel sw led timer */
+	rtw_hal_sw_led_deinit(padapter);
+#endif
+	_cancel_timer_ex(&(adapter_to_pwrctl(padapter)->pwr_state_check_timer));
+
+#ifdef CONFIG_TX_AMSDU
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_bk_timer);
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_be_timer);
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_vo_timer);
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_vi_timer);
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+#ifdef CONFIG_P2P
+	_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
+#endif /* CONFIG_P2P */
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
+	_cancel_timer_ex(&padapter->mlmepriv.set_scan_deny_timer);
+	rtw_clear_scan_deny(padapter);
+#endif
+
+#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
+	_cancel_timer_ex(&padapter->recvpriv.signal_stat_timer);
+#endif
+
+#ifdef CONFIG_LPS_RPWM_TIMER
+	_cancel_timer_ex(&(adapter_to_pwrctl(padapter)->pwr_rpwm_timer));
+#endif /* CONFIG_LPS_RPWM_TIMER */
+
+	/* cancel dm timer */
+	rtw_hal_dm_deinit(padapter);
+
+#ifdef CONFIG_PLATFORM_FS_MX61
+	msleep(50);
+#endif
+}
+
+u8 rtw_free_drv_sw(_adapter *padapter)
+{
+
+#ifdef CONFIG_WAPI_SUPPORT
+	rtw_wapi_free(padapter);
+#endif
+
+	/* we can call rtw_p2p_enable here, but: */
+	/* 1. rtw_p2p_enable may have IO operation */
+	/* 2. rtw_p2p_enable is bundled with wext interface */
+	#ifdef CONFIG_P2P
+	{
+		struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			_cancel_timer_ex(&pwdinfo->find_phase_timer);
+			_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+			_cancel_timer_ex(&pwdinfo->pre_tx_scan_timer);
+			#ifdef CONFIG_CONCURRENT_MODE
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+			#endif /* CONFIG_CONCURRENT_MODE */
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_NONE);
+		}
+	}
+	#endif
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
+	_rtw_spinlock_free(&padapter->security_key_mutex);
+
+#ifdef CONFIG_BR_EXT
+	_rtw_spinlock_free(&padapter->br_ext_lock);
+#endif /* CONFIG_BR_EXT */
+
+#ifdef CONFIG_INTEL_WIDI
+	rtw_free_intel_widi(padapter);
+#endif /* CONFIG_INTEL_WIDI */
+
+	free_mlme_ext_priv(&padapter->mlmeextpriv);
+
+#ifdef CONFIG_TDLS
+	/* rtw_free_tdls_info(&padapter->tdlsinfo); */
+#endif /* CONFIG_TDLS */
+
+#ifdef CONFIG_RTW_80211K
+	rtw_free_rm_priv(padapter);
+#endif
+
+	rtw_free_cmd_priv(&padapter->cmdpriv);
+
+	rtw_free_evt_priv(&padapter->evtpriv);
+
+	rtw_free_mlme_priv(&padapter->mlmepriv);
+
+	if (is_primary_adapter(padapter))
+		rtw_rfctl_deinit(padapter);
+
+	/* free_io_queue(padapter); */
+
+	_rtw_free_xmit_priv(&padapter->xmitpriv);
+
+	_rtw_free_sta_priv(&padapter->stapriv); /* will free bcmc_stainfo here */
+
+	_rtw_free_recv_priv(&padapter->recvpriv);
+
+	rtw_free_pwrctrl_priv(padapter);
+
+	/* rtw_mfree((void *)padapter, sizeof (padapter)); */
+
+	rtw_hal_free_data(padapter);
+
+
+	/* free the old_pnetdev */
+	if (padapter->rereg_nd_name_priv.old_pnetdev) {
+		free_netdev(padapter->rereg_nd_name_priv.old_pnetdev);
+		padapter->rereg_nd_name_priv.old_pnetdev = NULL;
+	}
+
+	return _SUCCESS;
+
+}
+void rtw_intf_start(_adapter *adapter)
+{
+	if (adapter->intf_start)
+		adapter->intf_start(adapter);
+}
+void rtw_intf_stop(_adapter *adapter)
+{
+	if (adapter->intf_stop)
+		adapter->intf_stop(adapter);
+}
+
+#ifdef CONFIG_CONCURRENT_MODE
+int _netdev_vir_if_open(struct net_device *pnetdev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	_adapter *primary_padapter = GET_PRIMARY_ADAPTER(padapter);
+
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+
+	if (!primary_padapter)
+		goto _netdev_virtual_iface_open_error;
+
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+	if (padapter->bup == _FALSE) {
+		u8 mac[ETH_ALEN];
+
+		/* get mac address from primary_padapter */
+		if (primary_padapter->bup == _FALSE)
+			rtw_macaddr_cfg(adapter_mac_addr(primary_padapter), get_hal_mac_addr(primary_padapter));
+
+		_rtw_memcpy(mac, adapter_mac_addr(primary_padapter), ETH_ALEN);
+
+		/*
+		* If the BIT1 is 0, the address is universally administered.
+		* If it is 1, the address is locally administered
+		*/
+		mac[0] |= BIT(1);
+
+		_rtw_memcpy(adapter_mac_addr(padapter), mac, ETH_ALEN);
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
+		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+		_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
+	}
+#endif /*CONFIG_PLATFORM_INTEL_BYT*/
+
+	if (primary_padapter->bup == _FALSE || !rtw_is_hw_init_completed(primary_padapter))
+		_netdev_open(primary_padapter->pnetdev);
+
+	if (padapter->bup == _FALSE && primary_padapter->bup == _TRUE &&
+	    rtw_is_hw_init_completed(primary_padapter)) {
+#if 0 /*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, adapter_mac_addr(padapter)); /* set mac addr to mac register */
+#endif
+
+	}
+
+	if (padapter->bup == _FALSE) {
+		if (rtw_start_drv_threads(padapter) == _FAIL)
+			goto _netdev_virtual_iface_open_error;
+	}
+
+#ifdef CONFIG_RTW_NAPI
+	if (padapter->napi_state == NAPI_DISABLE) {
+		napi_enable(&padapter->napi);
+		padapter->napi_state = NAPI_ENABLE;
+	}
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_init_wiphy(padapter);
+	rtw_cfg80211_init_wdev_data(padapter);
+#endif
+
+	padapter->bup = _TRUE;
+
+	padapter->net_closed = _FALSE;
+
+	rtw_netif_wake_queue(pnetdev);
+
+	RTW_INFO(FUNC_NDEV_FMT" (bup=%d) exit\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+
+	return 0;
+
+_netdev_virtual_iface_open_error:
+
+	padapter->bup = _FALSE;
+
+#ifdef CONFIG_RTW_NAPI
+	if(padapter->napi_state == NAPI_ENABLE) {
+		napi_disable(&padapter->napi);
+		padapter->napi_state = NAPI_DISABLE;
+	}
+#endif
+
+	rtw_netif_carrier_off(pnetdev);
+	rtw_netif_stop_queue(pnetdev);
+
+	return -1;
+
+}
+
+int netdev_vir_if_open(struct net_device *pnetdev)
+{
+	int ret;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+
+	_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+	ret = _netdev_vir_if_open(pnetdev);
+	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+
+#ifdef CONFIG_AUTO_AP_MODE
+	/* if(padapter->iface_id == 2) */
+	/*	rtw_start_auto_ap(padapter); */
+#endif
+
+	return ret;
+}
+
+static int netdev_vir_if_close(struct net_device *pnetdev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+	padapter->net_closed = _TRUE;
+	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
+
+	if (pnetdev)
+		rtw_netif_stop_queue(pnetdev);
+
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_role(&padapter->wdinfo, P2P_ROLE_DISABLE))
+		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_scan_abort(padapter);
+	rtw_cfg80211_wait_scan_req_empty(padapter, 200);
+	adapter_wdev_data(padapter)->bandroid_scan = _FALSE;
+#endif
+
+	return 0;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+static const struct net_device_ops rtw_netdev_vir_if_ops = {
+	.ndo_init = rtw_ndev_init,
+	.ndo_uninit = rtw_ndev_uninit,
+	.ndo_open = netdev_vir_if_open,
+	.ndo_stop = netdev_vir_if_close,
+	.ndo_start_xmit = rtw_xmit_entry,
+	.ndo_set_mac_address = rtw_net_set_mac_address,
+	.ndo_get_stats = rtw_net_get_stats,
+	.ndo_do_ioctl = rtw_ioctl,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	.ndo_select_queue	= rtw_select_queue,
+#endif
+};
+#endif
+
+static void rtw_hook_vir_if_ops(struct net_device *ndev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+	ndev->netdev_ops = &rtw_netdev_vir_if_ops;
+#else
+	ndev->init = rtw_ndev_init;
+	ndev->uninit = rtw_ndev_uninit;
+	ndev->open = netdev_vir_if_open;
+	ndev->stop = netdev_vir_if_close;
+	ndev->set_mac_address = rtw_net_set_mac_address;
+#endif
+}
+_adapter *rtw_drv_add_vir_if(_adapter *primary_padapter,
+	void (*set_intf_ops)(_adapter *primary_padapter, struct _io_ops *pops))
+{
+	int res = _FAIL;
+	_adapter *padapter = NULL;
+	struct dvobj_priv *pdvobjpriv;
+	u8 mac[ETH_ALEN];
+
+	/****** init adapter ******/
+	padapter = (_adapter *)rtw_zvmalloc(sizeof(*padapter));
+	if (padapter == NULL)
+		goto exit;
+
+	if (loadparam(padapter) != _SUCCESS)
+		goto free_adapter;
+
+	_rtw_memcpy(padapter, primary_padapter, sizeof(_adapter));
+
+	/*  */
+	padapter->bup = _FALSE;
+	padapter->net_closed = _TRUE;
+	padapter->dir_dev = NULL;
+	padapter->dir_odm = NULL;
+
+	/*set adapter_type/iface type*/
+	padapter->isprimary = _FALSE;
+	padapter->adapter_type = VIRTUAL_ADAPTER;
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	padapter->hw_port = HW_PORT0;
+#else
+	padapter->hw_port = HW_PORT1;
+#endif
+
+
+	/****** hook vir if into dvobj ******/
+	pdvobjpriv = adapter_to_dvobj(padapter);
+	padapter->iface_id = pdvobjpriv->iface_nums;
+	pdvobjpriv->padapters[pdvobjpriv->iface_nums++] = padapter;
+
+	padapter->intf_start = primary_padapter->intf_start;
+	padapter->intf_stop = primary_padapter->intf_stop;
+
+	/* step init_io_priv */
+	if ((rtw_init_io_priv(padapter, set_intf_ops)) == _FAIL) {
+		goto free_adapter;
+	}
+
+	/*init drv data*/
+	if (rtw_init_drv_sw(padapter) != _SUCCESS)
+		goto free_drv_sw;
+
+
+	/*get mac address from primary_padapter*/
+	_rtw_memcpy(mac, adapter_mac_addr(primary_padapter), ETH_ALEN);
+
+	/*
+	* If the BIT1 is 0, the address is universally administered.
+	* If it is 1, the address is locally administered
+	*/
+	mac[0] |= BIT(1);
+	if (padapter->iface_id > IFACE_ID1)
+		mac[4] ^= BIT(padapter->iface_id);
+
+	_rtw_memcpy(adapter_mac_addr(padapter), mac, ETH_ALEN);
+	/* update mac-address to mbsid-cam cache*/
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
+	RTW_INFO("%s if%d mac_addr : "MAC_FMT"\n", __func__, padapter->iface_id + 1, MAC_ARG(adapter_mac_addr(padapter)));
+#ifdef CONFIG_P2P
+	rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+#endif
+
+	rtw_led_set_ctl_en_mask_virtual(padapter);
+	rtw_led_set_iface_en(padapter, 1);
+
+	res = _SUCCESS;
+
+free_drv_sw:
+	if (res != _SUCCESS && padapter)
+		rtw_free_drv_sw(padapter);
+free_adapter:
+	if (res != _SUCCESS && padapter) {
+		rtw_vmfree((u8 *)padapter, sizeof(*padapter));
+		padapter = NULL;
+	}
+exit:
+	return padapter;
+}
+
+void rtw_drv_stop_vir_if(_adapter *padapter)
+{
+	struct net_device *pnetdev = NULL;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	if (padapter == NULL)
+		return;
+
+	pnetdev = padapter->pnetdev;
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED))
+		rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
+
+#ifdef CONFIG_AP_MODE
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+		free_mlme_ap_info(padapter);
+		#ifdef CONFIG_HOSTAPD_MLME
+		hostapd_mode_unload(padapter);
+		#endif
+	}
+#endif
+
+	if (padapter->bup == _TRUE) {
+		#ifdef CONFIG_XMIT_ACK
+		if (padapter->xmitpriv.ack_tx)
+			rtw_ack_tx_done(&padapter->xmitpriv, RTW_SCTX_DONE_DRV_STOP);
+		#endif
+
+		rtw_intf_stop(padapter);
+
+		rtw_stop_drv_threads(padapter);
+
+		padapter->bup = _FALSE;
+	}
+	/* cancel timer after thread stop */
+	rtw_cancel_all_timer(padapter);
+}
+
+void rtw_drv_free_vir_if(_adapter *padapter)
+{
+	if (padapter == NULL)
+		return;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	rtw_free_drv_sw(padapter);
+
+	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
+	rtw_os_ndev_free(padapter);
+
+	rtw_vmfree((u8 *)padapter, sizeof(_adapter));
+}
+
+
+void rtw_drv_stop_vir_ifaces(struct dvobj_priv *dvobj)
+{
+	int i;
+
+	for (i = VIF_START_ID; i < dvobj->iface_nums; i++)
+		rtw_drv_stop_vir_if(dvobj->padapters[i]);
+}
+
+void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj)
+{
+	int i;
+
+	for (i = VIF_START_ID; i < dvobj->iface_nums; i++)
+		rtw_drv_free_vir_if(dvobj->padapters[i]);
+}
+
+void rtw_drv_del_vir_if(_adapter *padapter)
+{
+	rtw_drv_stop_vir_if(padapter);
+	rtw_drv_free_vir_if(padapter);
+}
+
+void rtw_drv_del_vir_ifaces(_adapter *primary_padapter)
+{
+	int i;
+	struct dvobj_priv *dvobj = primary_padapter->dvobj;
+
+	for (i = VIF_START_ID; i < dvobj->iface_nums; i++)
+		rtw_drv_del_vir_if(dvobj->padapters[i]);
+
+}
+
+#endif /*end of CONFIG_CONCURRENT_MODE*/
+
+/* IPv4, IPv6 IP addr notifier */
+static int rtw_inetaddr_notifier_call(struct notifier_block *nb,
+				      unsigned long action, void *data)
+{
+	struct in_ifaddr *ifa = (struct in_ifaddr *)data;
+	struct net_device *ndev;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	_adapter *adapter = NULL;
+
+	if (!ifa || !ifa->ifa_dev || !ifa->ifa_dev->dev)
+		return NOTIFY_DONE;
+
+	ndev = ifa->ifa_dev->dev;
+
+	if (!is_rtw_ndev(ndev))
+		return NOTIFY_DONE;
+
+	adapter = (_adapter *)rtw_netdev_priv(ifa->ifa_dev->dev);
+
+	if (adapter == NULL)
+		return NOTIFY_DONE;
+
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+
+	switch (action) {
+	case NETDEV_UP:
+		_rtw_memcpy(pmlmeinfo->ip_addr, &ifa->ifa_address,
+					RTW_IP_ADDR_LEN);
+		RTW_DBG("%s[%s]: up IP: %pI4\n", __func__,
+					ifa->ifa_label, pmlmeinfo->ip_addr);
+	break;
+	case NETDEV_DOWN:
+		_rtw_memset(pmlmeinfo->ip_addr, 0, RTW_IP_ADDR_LEN);
+		RTW_DBG("%s[%s]: down IP: %pI4\n", __func__,
+					ifa->ifa_label, pmlmeinfo->ip_addr);
+	break;
+	default:
+		RTW_DBG("%s: default action\n", __func__);
+	break;
+	}
+	return NOTIFY_DONE;
+}
+
+#ifdef CONFIG_IPV6
+static int rtw_inet6addr_notifier_call(struct notifier_block *nb,
+				       unsigned long action, void *data)
+{
+	struct inet6_ifaddr *inet6_ifa = data;
+	struct net_device *ndev;
+	struct ipv6_addr *_ipv6_addr = NULL;
+	struct pwrctrl_priv *pwrctl = NULL;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	_adapter *adapter = NULL;
+
+	if (!inet6_ifa || !inet6_ifa->idev || !inet6_ifa->idev->dev)
+		return NOTIFY_DONE;
+
+	ndev = inet6_ifa->idev->dev;
+
+	if (!is_rtw_ndev(ndev))
+		return NOTIFY_DONE;
+
+	adapter = (_adapter *)rtw_netdev_priv(inet6_ifa->idev->dev);
+
+	if (adapter == NULL)
+		return NOTIFY_DONE;
+
+	pmlmeext =  &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+	pwrctl = adapter_to_pwrctl(adapter);
+
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+
+	switch (action) {
+	case NETDEV_UP:
+#ifdef CONFIG_WOWLAN
+		pwrctl->wowlan_ns_offload_en = _TRUE;
+#endif
+		_rtw_memcpy(pmlmeinfo->ip6_addr, &inet6_ifa->addr,
+					RTW_IPv6_ADDR_LEN);
+		RTW_DBG("%s: up IPv6 addrs: %pI6\n", __func__,
+					pmlmeinfo->ip6_addr);
+			break;
+	case NETDEV_DOWN:
+#ifdef CONFIG_WOWLAN
+		pwrctl->wowlan_ns_offload_en = _FALSE;
+#endif
+		_rtw_memset(pmlmeinfo->ip6_addr, 0, RTW_IPv6_ADDR_LEN);
+		RTW_DBG("%s: down IPv6 addrs: %pI6\n", __func__,
+					pmlmeinfo->ip6_addr);
+		break;
+	default:
+		RTW_DBG("%s: default action\n", __func__);
+		break;
+	}
+	return NOTIFY_DONE;
+}
+#endif
+
+static struct notifier_block rtw_inetaddr_notifier = {
+	.notifier_call = rtw_inetaddr_notifier_call
+};
+
+#ifdef CONFIG_IPV6
+static struct notifier_block rtw_inet6addr_notifier = {
+	.notifier_call = rtw_inet6addr_notifier_call
+};
+#endif
+
+void rtw_inetaddr_notifier_register(void)
+{
+	RTW_INFO("%s\n", __func__);
+	register_inetaddr_notifier(&rtw_inetaddr_notifier);
+#ifdef CONFIG_IPV6
+	register_inet6addr_notifier(&rtw_inet6addr_notifier);
+#endif
+}
+
+void rtw_inetaddr_notifier_unregister(void)
+{
+	RTW_INFO("%s\n", __func__);
+	unregister_inetaddr_notifier(&rtw_inetaddr_notifier);
+#ifdef CONFIG_IPV6
+	unregister_inet6addr_notifier(&rtw_inet6addr_notifier);
+#endif
+}
+
+int rtw_os_ndevs_register(struct dvobj_priv *dvobj)
+{
+	int i, status = _SUCCESS;
+	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
+	_adapter *adapter;
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	if (rtw_cfg80211_dev_res_register(dvobj) != _SUCCESS) {
+		rtw_warn_on(1);
+		status = _FAIL;
+		goto exit;
+	}
+#endif
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+
+		if (i >= CONFIG_IFACE_NUMBER) {
+			RTW_ERR("%s %d >= CONFIG_IFACE_NUMBER(%d)\n", __func__, i, CONFIG_IFACE_NUMBER);
+			rtw_warn_on(1);
+			continue;
+		}
+
+		adapter = dvobj->padapters[i];
+		if (adapter) {
+			char *name;
+
+			#ifdef CONFIG_RTW_DYNAMIC_NDEV
+			if (!is_primary_adapter(adapter))
+				continue;
+			#endif
+
+			if (adapter->iface_id == IFACE_ID0)
+				name = regsty->ifname;
+			else if (adapter->iface_id == IFACE_ID1)
+				name = regsty->if2name;
+			else
+				name = "wlan%d";
+
+			status = rtw_os_ndev_register(adapter, name);
+
+			if (status != _SUCCESS) {
+				rtw_warn_on(1);
+				break;
+			}
+		}
+	}
+
+	if (status != _SUCCESS) {
+		for (; i >= 0; i--) {
+			adapter = dvobj->padapters[i];
+			if (adapter)
+				rtw_os_ndev_unregister(adapter);
+		}
+	}
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	if (status != _SUCCESS)
+		rtw_cfg80211_dev_res_unregister(dvobj);
+#endif
+exit:
+	return status;
+}
+
+void rtw_os_ndevs_unregister(struct dvobj_priv *dvobj)
+{
+	int i;
+	_adapter *adapter = NULL;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		adapter = dvobj->padapters[i];
+
+		if (adapter == NULL)
+			continue;
+
+		rtw_os_ndev_unregister(adapter);
+	}
+
+#if defined(CONFIG_IOCTL_CFG80211)
+	rtw_cfg80211_dev_res_unregister(dvobj);
+#endif
+}
+
+/**
+ * rtw_os_ndevs_init - Allocate and register OS layer net devices and relating structures for @dvobj
+ * @dvobj: the dvobj on which this function applies
+ *
+ * Returns:
+ * _SUCCESS or _FAIL
+ */
+int rtw_os_ndevs_init(struct dvobj_priv *dvobj)
+{
+	int ret = _FAIL;
+
+	if (rtw_os_ndevs_alloc(dvobj) != _SUCCESS)
+		goto exit;
+
+	if (rtw_os_ndevs_register(dvobj) != _SUCCESS)
+		goto os_ndevs_free;
+
+	ret = _SUCCESS;
+
+os_ndevs_free:
+	if (ret != _SUCCESS)
+		rtw_os_ndevs_free(dvobj);
+exit:
+	return ret;
+}
+
+/**
+ * rtw_os_ndevs_deinit - Unregister and free OS layer net devices and relating structures for @dvobj
+ * @dvobj: the dvobj on which this function applies
+ */
+void rtw_os_ndevs_deinit(struct dvobj_priv *dvobj)
+{
+	rtw_os_ndevs_unregister(dvobj);
+	rtw_os_ndevs_free(dvobj);
+}
+
+#ifdef CONFIG_BR_EXT
+void netdev_br_init(struct net_device *netdev)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
+	rcu_read_lock();
+#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
+
+	/* if(check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE) */
+	{
+		/* struct net_bridge	*br = netdev->br_port->br; */ /* ->dev->dev_addr; */
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+		if (netdev->br_port)
+#else   /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
+		if (rcu_dereference(adapter->pnetdev->rx_handler_data))
+#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
+		{
+			struct net_device *br_netdev;
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+			br_netdev = dev_get_by_name(CONFIG_BR_EXT_BRNAME);
+#else	/* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24)) */
+			struct net *devnet = NULL;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
+			devnet = netdev->nd_net;
+#else	/* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26)) */
+			devnet = dev_net(netdev);
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26)) */
+
+			br_netdev = dev_get_by_name(devnet, CONFIG_BR_EXT_BRNAME);
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24)) */
+
+			if (br_netdev) {
+				memcpy(adapter->br_mac, br_netdev->dev_addr, ETH_ALEN);
+				dev_put(br_netdev);
+			} else
+				printk("%s()-%d: dev_get_by_name(%s) failed!", __FUNCTION__, __LINE__, CONFIG_BR_EXT_BRNAME);
+		}
+
+		adapter->ethBrExtInfo.addPPPoETag = 1;
+	}
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
+	rcu_read_unlock();
+#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
+}
+#endif /* CONFIG_BR_EXT */
+
+int _netdev_open(struct net_device *pnetdev)
+{
+	uint status;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+
+	padapter->netif_up = _TRUE;
+
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+	rtw_sdio_set_power(1);
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+
+	#ifdef CONFIG_AUTOSUSPEND
+	if (pwrctrlpriv->ps_flag == _TRUE) {
+		padapter->net_closed = _FALSE;
+		goto netdev_open_normal_process;
+	}
+	#endif
+
+	if (padapter->bup == _FALSE) {
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+		rtw_macaddr_cfg(adapter_mac_addr(padapter),  get_hal_mac_addr(padapter));
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
+		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+		_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+
+		rtw_clr_surprise_removed(padapter);
+		rtw_clr_drv_stopped(padapter);
+
+		status = rtw_hal_init(padapter);
+		if (status == _FAIL) {
+			goto netdev_open_error;
+		}
+#if 0/*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, adapter_mac_addr(padapter)); /* set mac addr to mac register */
+#endif
+
+		RTW_INFO("MAC Address = "MAC_FMT"\n", MAC_ARG(pnetdev->dev_addr));
+
+#ifndef RTW_HALMAC
+		status = rtw_start_drv_threads(padapter);
+		if (status == _FAIL) {
+			RTW_INFO("Initialize driver software resource Failed!\n");
+			goto netdev_open_error;
+		}
+#endif /* !RTW_HALMAC */
+
+#ifdef CONFIG_RTW_NAPI
+		if(padapter->napi_state == NAPI_DISABLE) {
+			napi_enable(&padapter->napi);
+			padapter->napi_state = NAPI_ENABLE;
+		}
+#endif
+
+#ifndef RTW_HALMAC
+		rtw_intf_start(padapter);
+#endif /* !RTW_HALMAC */
+
+#ifdef CONFIG_IOCTL_CFG80211
+		rtw_cfg80211_init_wiphy(padapter);
+		rtw_cfg80211_init_wdev_data(padapter);
+#endif
+
+		rtw_led_control(padapter, LED_CTL_NO_LINK);
+
+		padapter->bup = _TRUE;
+		pwrctrlpriv->bips_processing = _FALSE;
+
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+#ifdef CONFIG_BT_COEXIST
+		rtw_btcoex_IpsNotify(padapter, IPS_NONE);
+#endif /* CONFIG_BT_COEXIST */
+#endif /* CONFIG_PLATFORM_INTEL_BYT		 */
+	}
+	padapter->net_closed = _FALSE;
+
+	_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
+
+#ifndef CONFIG_IPS_CHECK_IN_WD
+	rtw_set_pwr_state_check_timer(pwrctrlpriv);
+#endif
+
+	/* rtw_netif_carrier_on(pnetdev); */ /* call this func when rtw_joinbss_event_callback return success */
+	rtw_netif_wake_queue(pnetdev);
+
+#ifdef CONFIG_BR_EXT
+	netdev_br_init(pnetdev);
+#endif /* CONFIG_BR_EXT */
+
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	if (is_primary_adapter(padapter) && (_TRUE == pHalData->EEPROMBluetoothCoexist)) {
+		rtw_btcoex_init_socket(padapter);
+		padapter->coex_info.BtMgnt.ExtConfig.HCIExtensionVer = 0x04;
+		rtw_btcoex_SetHciVersion(padapter, 0x04);
+	} else
+		RTW_INFO("CONFIG_BT_COEXIST: VIRTUAL_ADAPTER\n");
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+
+netdev_open_normal_process:
+
+#ifdef CONFIG_CONCURRENT_MODE
+	{
+		_adapter *sec_adapter = adapter_to_dvobj(padapter)->padapters[IFACE_ID1];
+
+		#ifndef CONFIG_RTW_DYNAMIC_NDEV
+		if (sec_adapter && (sec_adapter->bup == _FALSE))
+			_netdev_vir_if_open(sec_adapter->pnetdev);
+		#endif
+	}
+#endif
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	pwrctrlpriv->radio_on_start_time = rtw_get_current_time();
+	pwrctrlpriv->pwr_saving_start_time = rtw_get_current_time();
+	pwrctrlpriv->pwr_saving_time = 0;
+	pwrctrlpriv->on_time = 0;
+	pwrctrlpriv->tx_time = 0;
+	pwrctrlpriv->rx_time = 0;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+	RTW_INFO("-871x_drv - drv_open, bup=%d\n", padapter->bup);
+
+	return 0;
+
+netdev_open_error:
+
+	padapter->bup = _FALSE;
+
+#ifdef CONFIG_RTW_NAPI
+	if(padapter->napi_state == NAPI_ENABLE) {
+		napi_disable(&padapter->napi);
+		padapter->napi_state = NAPI_DISABLE;
+	}
+#endif
+
+	rtw_netif_carrier_off(pnetdev);
+	rtw_netif_stop_queue(pnetdev);
+
+	RTW_INFO("-871x_drv - drv_open fail, bup=%d\n", padapter->bup);
+
+	return -1;
+
+}
+
+int netdev_open(struct net_device *pnetdev)
+{
+	int ret = _FALSE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+
+	if (pwrctrlpriv->bInSuspend == _TRUE) {
+		RTW_INFO(" [WARN] "ADPT_FMT" %s  failed, bInSuspend=%d\n", ADPT_ARG(padapter), __func__, pwrctrlpriv->bInSuspend);
+		return 0;
+	}
+
+	_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+	if (is_primary_adapter(padapter))
+		ret = _netdev_open(pnetdev);
+#ifdef CONFIG_CONCURRENT_MODE
+	else
+		ret = _netdev_vir_if_open(pnetdev);
+#endif
+	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+
+
+#ifdef CONFIG_AUTO_AP_MODE
+	if (padapter->iface_id == IFACE_ID2)
+		rtw_start_auto_ap(padapter);
+#endif
+
+	return ret;
+}
+
+#ifdef CONFIG_IPS
+int  ips_netdrv_open(_adapter *padapter)
+{
+	int status = _SUCCESS;
+	/* struct pwrctrl_priv	*pwrpriv = adapter_to_pwrctl(padapter); */
+
+	padapter->net_closed = _FALSE;
+
+	RTW_INFO("===> %s.........\n", __FUNCTION__);
+
+
+	rtw_clr_drv_stopped(padapter);
+	/* padapter->bup = _TRUE; */
+
+	status = rtw_hal_init(padapter);
+	if (status == _FAIL) {
+		goto netdev_open_error;
+	}
+#if 0
+	rtw_restore_mac_addr(padapter);
+#endif
+#ifndef RTW_HALMAC
+	rtw_intf_start(padapter);
+#endif /* !RTW_HALMAC */
+
+#ifndef CONFIG_IPS_CHECK_IN_WD
+	rtw_set_pwr_state_check_timer(adapter_to_pwrctl(padapter));
+#endif
+	_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
+
+	return _SUCCESS;
+
+netdev_open_error:
+	/* padapter->bup = _FALSE; */
+	RTW_INFO("-ips_netdrv_open - drv_open failure, bup=%d\n", padapter->bup);
+
+	return _FAIL;
+}
+
+int rtw_ips_pwr_up(_adapter *padapter)
+{
+	int result;
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+#ifdef DBG_CONFIG_ERROR_DETECT
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+	systime start_time = rtw_get_current_time();
+	RTW_INFO("===>  rtw_ips_pwr_up..............\n");
+
+#if defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
+#ifdef DBG_CONFIG_ERROR_DETECT
+	if (psrtpriv->silent_reset_inprogress == _TRUE)
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+#endif /* defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS) */
+		rtw_reset_drv_sw(padapter);
+
+	result = ips_netdrv_open(padapter);
+
+	rtw_led_control(padapter, LED_CTL_NO_LINK);
+
+	RTW_INFO("<===  rtw_ips_pwr_up.............. in %dms\n", rtw_get_passing_time_ms(start_time));
+	return result;
+
+}
+
+void rtw_ips_pwr_down(_adapter *padapter)
+{
+	systime start_time = rtw_get_current_time();
+	RTW_INFO("===> rtw_ips_pwr_down...................\n");
+
+	padapter->net_closed = _TRUE;
+
+	rtw_ips_dev_unload(padapter);
+	RTW_INFO("<=== rtw_ips_pwr_down..................... in %dms\n", rtw_get_passing_time_ms(start_time));
+}
+#endif
+void rtw_ips_dev_unload(_adapter *padapter)
+{
+	struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+#ifdef DBG_CONFIG_ERROR_DETECT
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+	RTW_INFO("====> %s...\n", __FUNCTION__);
+
+
+#if defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
+#ifdef DBG_CONFIG_ERROR_DETECT
+	if (psrtpriv->silent_reset_inprogress == _TRUE)
+#endif /* #ifdef DBG_CONFIG_ERROR_DETECT */
+#endif /* defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS) */
+	{
+		rtw_hal_set_hwreg(padapter, HW_VAR_FIFO_CLEARN_UP, 0);
+		rtw_intf_stop(padapter);
+	}
+
+	if (!rtw_is_surprise_removed(padapter))
+		rtw_hal_deinit(padapter);
+
+}
+
+int pm_netdev_open(struct net_device *pnetdev, u8 bnormal)
+{
+	int status = 0;
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+
+	if (_TRUE == bnormal) {
+		_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+		status = _netdev_open(pnetdev);
+#if 0
+		rtw_restore_mac_addr(padapter);
+#endif
+		_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+	}
+#ifdef CONFIG_IPS
+	else
+		status = (_SUCCESS == ips_netdrv_open(padapter)) ? (0) : (-1);
+#endif
+
+	return status;
+}
+
+static int netdev_close(struct net_device *pnetdev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+#ifndef CONFIG_PLATFORM_INTEL_BYT
+	#ifdef CONFIG_AUTOSUSPEND
+	if (pwrctl->bInternalAutoSuspend == _TRUE) {
+		/* rtw_pwr_wakeup(padapter); */
+		if (pwrctl->rf_pwrstate == rf_off)
+			pwrctl->ps_flag = _TRUE;
+	}
+	#endif
+	padapter->net_closed = _TRUE;
+	padapter->netif_up = _FALSE;
+	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
+
+	/*	if (!rtw_is_hw_init_completed(padapter)) {
+			RTW_INFO("(1)871x_drv - drv_close, bup=%d, hw_init_completed=%s\n", padapter->bup, rtw_is_hw_init_completed(padapter)?"_TRUE":"_FALSE");
+
+			rtw_set_drv_stopped(padapter);
+
+			rtw_dev_unload(padapter);
+		}
+		else*/
+	if (pwrctl->rf_pwrstate == rf_on) {
+		RTW_INFO("(2)871x_drv - drv_close, bup=%d, hw_init_completed=%s\n", padapter->bup, rtw_is_hw_init_completed(padapter) ? "_TRUE" : "_FALSE");
+
+		/* s1. */
+		if (pnetdev)
+			rtw_netif_stop_queue(pnetdev);
+
+#ifndef CONFIG_ANDROID
+		/* s2. */
+		LeaveAllPowerSaveMode(padapter);
+		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_DIRECTLY);
+		/* s2-2.  indicate disconnect to os */
+		rtw_indicate_disconnect(padapter, 0, _FALSE);
+		/* s2-3. */
+		rtw_free_assoc_resources(padapter, 1);
+		/* s2-4. */
+		rtw_free_network_queue(padapter, _TRUE);
+#endif
+	}
+
+#ifdef CONFIG_BR_EXT
+	/* if (OPMODE & (WIFI_STATION_STATE | WIFI_ADHOC_STATE)) */
+	{
+		/* void nat25_db_cleanup(_adapter *priv); */
+		nat25_db_cleanup(padapter);
+	}
+#endif /* CONFIG_BR_EXT */
+
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_role(&padapter->wdinfo, P2P_ROLE_DISABLE))
+		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_scan_abort(padapter);
+	rtw_cfg80211_wait_scan_req_empty(padapter, 200);
+	adapter_wdev_data(padapter)->bandroid_scan = _FALSE;
+	/* padapter->rtw_wdev->iftype = NL80211_IFTYPE_MONITOR; */ /* set this at the end */
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+#ifdef CONFIG_WAPI_SUPPORT
+	rtw_wapi_disable_tx(padapter);
+#endif
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	if (is_primary_adapter(padapter) && (_TRUE == pHalData->EEPROMBluetoothCoexist))
+		rtw_btcoex_close_socket(padapter);
+	else
+		RTW_INFO("CONFIG_BT_COEXIST: VIRTUAL_ADAPTER\n");
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+#else /* !CONFIG_PLATFORM_INTEL_BYT */
+
+	if (pwrctl->bInSuspend == _TRUE) {
+		RTW_INFO("+871x_drv - drv_close, bInSuspend=%d\n", pwrctl->bInSuspend);
+		return 0;
+	}
+
+	rtw_scan_abort(padapter); /* stop scanning process before wifi is going to down */
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_wait_scan_req_empty(padapter, 200);
+#endif
+
+	RTW_INFO("netdev_close, bips_processing=%d\n", pwrctl->bips_processing);
+	while (pwrctl->bips_processing == _TRUE) /* waiting for ips_processing done before call rtw_dev_unload() */
+		rtw_msleep_os(1);
+
+	rtw_dev_unload(padapter);
+	rtw_sdio_set_power(0);
+
+#endif /* !CONFIG_PLATFORM_INTEL_BYT */
+
+	RTW_INFO("-871x_drv - drv_close, bup=%d\n", padapter->bup);
+
+	return 0;
+
+}
+
+int pm_netdev_close(struct net_device *pnetdev, u8 bnormal)
+{
+	int status = 0;
+
+	status = netdev_close(pnetdev);
+
+	return status;
+}
+
+void rtw_ndev_destructor(struct net_device *ndev)
+{
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+#ifdef CONFIG_IOCTL_CFG80211
+	if (ndev->ieee80211_ptr)
+		rtw_mfree((u8 *)ndev->ieee80211_ptr, sizeof(struct wireless_dev));
+#endif
+	free_netdev(ndev);
+}
+
+#ifdef CONFIG_ARP_KEEP_ALIVE
+struct route_info {
+	struct in_addr dst_addr;
+	struct in_addr src_addr;
+	struct in_addr gateway;
+	unsigned int dev_index;
+};
+
+static void parse_routes(struct nlmsghdr *nl_hdr, struct route_info *rt_info)
+{
+	struct rtmsg *rt_msg;
+	struct rtattr *rt_attr;
+	int rt_len;
+
+	rt_msg = (struct rtmsg *) NLMSG_DATA(nl_hdr);
+	if ((rt_msg->rtm_family != AF_INET) || (rt_msg->rtm_table != RT_TABLE_MAIN))
+		return;
+
+	rt_attr = (struct rtattr *) RTM_RTA(rt_msg);
+	rt_len = RTM_PAYLOAD(nl_hdr);
+
+	for (; RTA_OK(rt_attr, rt_len); rt_attr = RTA_NEXT(rt_attr, rt_len)) {
+		switch (rt_attr->rta_type) {
+		case RTA_OIF:
+			rt_info->dev_index = *(int *) RTA_DATA(rt_attr);
+			break;
+		case RTA_GATEWAY:
+			rt_info->gateway.s_addr = *(u_int *) RTA_DATA(rt_attr);
+			break;
+		case RTA_PREFSRC:
+			rt_info->src_addr.s_addr = *(u_int *) RTA_DATA(rt_attr);
+			break;
+		case RTA_DST:
+			rt_info->dst_addr.s_addr = *(u_int *) RTA_DATA(rt_attr);
+			break;
+		}
+	}
+}
+
+static int route_dump(u32 *gw_addr , int *gw_index)
+{
+	int err = 0;
+	struct socket *sock;
+	struct {
+		struct nlmsghdr nlh;
+		struct rtgenmsg g;
+	} req;
+	struct msghdr msg;
+	struct iovec iov;
+	struct sockaddr_nl nladdr;
+	mm_segment_t oldfs;
+	char *pg;
+	int size = 0;
+
+	err = sock_create(AF_NETLINK, SOCK_DGRAM, NETLINK_ROUTE, &sock);
+	if (err) {
+		printk(": Could not create a datagram socket, error = %d\n", -ENXIO);
+		return err;
+	}
+
+	memset(&nladdr, 0, sizeof(nladdr));
+	nladdr.nl_family = AF_NETLINK;
+
+	req.nlh.nlmsg_len = sizeof(req);
+	req.nlh.nlmsg_type = RTM_GETROUTE;
+	req.nlh.nlmsg_flags = NLM_F_ROOT | NLM_F_MATCH | NLM_F_REQUEST;
+	req.nlh.nlmsg_pid = 0;
+	req.g.rtgen_family = AF_INET;
+
+	iov.iov_base = &req;
+	iov.iov_len = sizeof(req);
+
+	msg.msg_name = &nladdr;
+	msg.msg_namelen = sizeof(nladdr);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+	/* referece:sock_xmit in kernel code
+	 * WRITE for sock_sendmsg, READ for sock_recvmsg
+	 * third parameter for msg_iovlen
+	 * last parameter for iov_len
+	 */
+	iov_iter_init(&msg.msg_iter, WRITE, &iov, 1, sizeof(req));
+#else
+	msg.msg_iov = &iov;
+	msg.msg_iovlen = 1;
+#endif
+	msg.msg_control = NULL;
+	msg.msg_controllen = 0;
+	msg.msg_flags = MSG_DONTWAIT;
+
+	oldfs = get_fs();
+	set_fs(KERNEL_DS);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+	err = sock_sendmsg(sock, &msg);
+#else
+	err = sock_sendmsg(sock, &msg, sizeof(req));
+#endif
+	set_fs(oldfs);
+
+	if (err < 0)
+		goto out_sock;
+
+	pg = (char *) __get_free_page(GFP_KERNEL);
+	if (pg == NULL) {
+		err = -ENOMEM;
+		goto out_sock;
+	}
+
+#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
+restart:
+#endif
+
+	for (;;) {
+		struct nlmsghdr *h;
+
+		iov.iov_base = pg;
+		iov.iov_len = PAGE_SIZE;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+		iov_iter_init(&msg.msg_iter, READ, &iov, 1, PAGE_SIZE);
+#endif
+
+		oldfs = get_fs();
+		set_fs(KERNEL_DS);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+		err = sock_recvmsg(sock, &msg, MSG_DONTWAIT);
+#else
+		err = sock_recvmsg(sock, &msg, PAGE_SIZE, MSG_DONTWAIT);
+#endif
+		set_fs(oldfs);
+
+		if (err < 0)
+			goto out_sock_pg;
+
+		if (msg.msg_flags & MSG_TRUNC) {
+			err = -ENOBUFS;
+			goto out_sock_pg;
+		}
+
+		h = (struct nlmsghdr *) pg;
+
+		while (NLMSG_OK(h, err)) {
+			struct route_info rt_info;
+			if (h->nlmsg_type == NLMSG_DONE) {
+				err = 0;
+				goto done;
+			}
+
+			if (h->nlmsg_type == NLMSG_ERROR) {
+				struct nlmsgerr *errm = (struct nlmsgerr *) NLMSG_DATA(h);
+				err = errm->error;
+				printk("NLMSG error: %d\n", errm->error);
+				goto done;
+			}
+
+			if (h->nlmsg_type == RTM_GETROUTE)
+				printk("RTM_GETROUTE: NLMSG: %d\n", h->nlmsg_type);
+			if (h->nlmsg_type != RTM_NEWROUTE) {
+				printk("NLMSG: %d\n", h->nlmsg_type);
+				err = -EINVAL;
+				goto done;
+			}
+
+			memset(&rt_info, 0, sizeof(struct route_info));
+			parse_routes(h, &rt_info);
+			if (!rt_info.dst_addr.s_addr && rt_info.gateway.s_addr && rt_info.dev_index) {
+				*gw_addr = rt_info.gateway.s_addr;
+				*gw_index = rt_info.dev_index;
+
+			}
+			h = NLMSG_NEXT(h, err);
+		}
+
+		if (err) {
+			printk("!!!Remnant of size %d %d %d\n", err, h->nlmsg_len, h->nlmsg_type);
+			err = -EINVAL;
+			break;
+		}
+	}
+
+done:
+#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
+	if (!err && req.g.rtgen_family == AF_INET) {
+		req.g.rtgen_family = AF_INET6;
+
+		iov.iov_base = &req;
+		iov.iov_len = sizeof(req);
+
+		msg.msg_name = &nladdr;
+		msg.msg_namelen = sizeof(nladdr);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+		iov_iter_init(&msg.msg_iter, WRITE, &iov, 1, sizeof(req));
+#else
+		msg.msg_iov = &iov;
+		msg.msg_iovlen = 1;
+#endif
+		msg.msg_control = NULL;
+		msg.msg_controllen = 0;
+		msg.msg_flags = MSG_DONTWAIT;
+
+		oldfs = get_fs();
+		set_fs(KERNEL_DS);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+		err = sock_sendmsg(sock, &msg);
+#else
+		err = sock_sendmsg(sock, &msg, sizeof(req));
+#endif
+		set_fs(oldfs);
+
+		if (err > 0)
+			goto restart;
+	}
+#endif
+
+out_sock_pg:
+	free_page((unsigned long) pg);
+
+out_sock:
+	sock_release(sock);
+	return err;
+}
+
+static int arp_query(unsigned char *haddr, u32 paddr,
+		     struct net_device *dev)
+{
+	struct neighbour *neighbor_entry;
+	int	ret = 0;
+
+	neighbor_entry = neigh_lookup(&arp_tbl, &paddr, dev);
+
+	if (neighbor_entry != NULL) {
+		neighbor_entry->used = jiffies;
+		if (neighbor_entry->nud_state & NUD_VALID) {
+			_rtw_memcpy(haddr, neighbor_entry->ha, dev->addr_len);
+			ret = 1;
+		}
+		neigh_release(neighbor_entry);
+	}
+	return ret;
+}
+
+static int get_defaultgw(u32 *ip_addr , char mac[])
+{
+	int gw_index = 0; /* oif device index */
+	struct net_device *gw_dev = NULL; /* oif device */
+
+	route_dump(ip_addr, &gw_index);
+
+	if (!(*ip_addr) || !gw_index) {
+		/* RTW_INFO("No default GW\n"); */
+		return -1;
+	}
+
+	gw_dev = dev_get_by_index(&init_net, gw_index);
+
+	if (gw_dev == NULL) {
+		/* RTW_INFO("get Oif Device Fail\n"); */
+		return -1;
+	}
+
+	if (!arp_query(mac, *ip_addr, gw_dev)) {
+		/* RTW_INFO( "arp query failed\n"); */
+		dev_put(gw_dev);
+		return -1;
+
+	}
+	dev_put(gw_dev);
+
+	return 0;
+}
+
+int	rtw_gw_addr_query(_adapter *padapter)
+{
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+	u32 gw_addr = 0; /* default gw address */
+	unsigned char gw_mac[32] = {0}; /* default gw mac */
+	int i;
+	int res;
+
+	res = get_defaultgw(&gw_addr, gw_mac);
+	if (!res) {
+		pmlmepriv->gw_ip[0] = gw_addr & 0xff;
+		pmlmepriv->gw_ip[1] = (gw_addr & 0xff00) >> 8;
+		pmlmepriv->gw_ip[2] = (gw_addr & 0xff0000) >> 16;
+		pmlmepriv->gw_ip[3] = (gw_addr & 0xff000000) >> 24;
+		_rtw_memcpy(pmlmepriv->gw_mac_addr, gw_mac, 6);
+		RTW_INFO("%s Gateway Mac:\t" MAC_FMT "\n", __FUNCTION__, MAC_ARG(pmlmepriv->gw_mac_addr));
+		RTW_INFO("%s Gateway IP:\t" IP_FMT "\n", __FUNCTION__, IP_ARG(pmlmepriv->gw_ip));
+	} else
+		RTW_INFO("Get Gateway IP/MAC fail!\n");
+
+	return res;
+}
+#endif
+
+void rtw_dev_unload(PADAPTER padapter)
+{
+	struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+	struct dvobj_priv *pobjpriv = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &pobjpriv->drv_dbg;
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	u8 cnt = 0;
+
+
+	if (padapter->bup == _TRUE) {
+		RTW_INFO("==> "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#ifdef CONFIG_WOWLAN
+#ifdef CONFIG_GPIO_WAKEUP
+		/*default wake up pin change to BT*/
+		RTW_INFO("%s:default wake up pin change to BT\n", __FUNCTION__);
+		rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _FALSE);
+#endif /* CONFIG_GPIO_WAKEUP */
+#endif /* CONFIG_WOWLAN */
+
+		rtw_set_drv_stopped(padapter);
+#ifdef CONFIG_XMIT_ACK
+		if (padapter->xmitpriv.ack_tx)
+			rtw_ack_tx_done(&padapter->xmitpriv, RTW_SCTX_DONE_DRV_STOP);
+#endif
+
+		rtw_intf_stop(padapter);
+
+		#ifdef CONFIG_AUTOSUSPEND
+		if (!pwrctl->bInternalAutoSuspend)
+		#endif
+		{
+			rtw_stop_drv_threads(padapter);
+
+			if (ATOMIC_READ(&(pcmdpriv->cmdthd_running)) == _TRUE) {
+				RTW_ERR("cmd_thread not stop !!\n");
+				rtw_warn_on(1);
+			}
+		}
+		/* check the status of IPS */
+		if (rtw_hal_check_ips_status(padapter) == _TRUE || pwrctl->rf_pwrstate == rf_off) { /* check HW status and SW state */
+			RTW_PRINT("%s: driver in IPS-FWLPS\n", __func__);
+			pdbgpriv->dbg_dev_unload_inIPS_cnt++;
+		} else
+			RTW_PRINT("%s: driver not in IPS\n", __func__);
+
+		if (!rtw_is_surprise_removed(padapter)) {
+#ifdef CONFIG_BT_COEXIST
+			rtw_btcoex_IpsNotify(padapter, pwrctl->ips_mode_req);
+#endif
+#ifdef CONFIG_WOWLAN
+			if (pwrctl->bSupportRemoteWakeup == _TRUE &&
+			    pwrctl->wowlan_mode == _TRUE)
+				RTW_PRINT("%s bSupportRemoteWakeup==_TRUE  do not run rtw_hal_deinit()\n", __FUNCTION__);
+			else
+#endif
+			{
+				/* amy modify 20120221 for power seq is different between driver open and ips */
+				rtw_hal_deinit(padapter);
+			}
+			rtw_set_surprise_removed(padapter);
+		}
+
+		padapter->bup = _FALSE;
+
+		RTW_INFO("<== "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	} else {
+		RTW_INFO("%s: bup==_FALSE\n", __FUNCTION__);
+	}
+	rtw_cancel_all_timer(padapter);
+}
+
+int rtw_suspend_free_assoc_resource(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct net_device *pnetdev = padapter->pnetdev;
+#ifdef CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+	if (rtw_chk_roam_flags(padapter, RTW_ROAM_ON_RESUME)) {
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
+			&& check_fwstate(pmlmepriv, _FW_LINKED)
+			#ifdef CONFIG_P2P
+			&& (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
+				#if defined(CONFIG_IOCTL_CFG80211) && RTW_P2P_GROUP_INTERFACE
+				|| rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)
+				#endif
+				)
+			#endif /* CONFIG_P2P */
+		) {
+			RTW_INFO("%s %s(" MAC_FMT "), length:%d assoc_ssid.length:%d\n", __FUNCTION__,
+				pmlmepriv->cur_network.network.Ssid.Ssid,
+				MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
+				pmlmepriv->cur_network.network.Ssid.SsidLength,
+				pmlmepriv->assoc_ssid.SsidLength);
+			rtw_set_to_roam(padapter, 1);
+		}
+	}
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) && check_fwstate(pmlmepriv, _FW_LINKED)) {
+		rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
+		/* s2-2.  indicate disconnect to os */
+		rtw_indicate_disconnect(padapter, 0, _FALSE);
+	}
+#ifdef CONFIG_AP_MODE
+	else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter))
+		rtw_sta_flush(padapter, _TRUE);
+#endif
+
+	/* s2-3. */
+	rtw_free_assoc_resources(padapter, 1);
+
+	/* s2-4. */
+#ifdef CONFIG_AUTOSUSPEND
+	if (is_primary_adapter(padapter) && (!adapter_to_pwrctl(padapter)->bInternalAutoSuspend))
+#endif
+		rtw_free_network_queue(padapter, _TRUE);
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
+		RTW_PRINT("%s: fw_under_survey\n", __func__);
+		rtw_indicate_scan_done(padapter, 1);
+		clr_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+		RTW_PRINT("%s: fw_under_linking\n", __FUNCTION__);
+		rtw_indicate_disconnect(padapter, 0, _FALSE);
+	}
+
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	return _SUCCESS;
+}
+
+#ifdef CONFIG_WOWLAN
+int rtw_suspend_wow(_adapter *padapter)
+{
+	u8 ch, bw, offset;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct wowlan_ioctl_param poidparam;
+	u8 ps_mode;
+	int ret = _SUCCESS;
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+
+	RTW_INFO("wowlan_mode: %d\n", pwrpriv->wowlan_mode);
+	RTW_INFO("wowlan_pno_enable: %d\n", pwrpriv->wowlan_pno_enable);
+#ifdef CONFIG_P2P_WOWLAN
+	RTW_INFO("wowlan_p2p_enable: %d\n", pwrpriv->wowlan_p2p_enable);
+#endif
+
+	if (pwrpriv->wowlan_mode == _TRUE) {
+		rtw_mi_netif_stop_queue(padapter);
+		#ifdef CONFIG_CONCURRENT_MODE
+		rtw_mi_buddy_netif_carrier_off(padapter);
+		#endif
+
+		/* 0. Power off LED */
+		rtw_led_control(padapter, LED_CTL_POWER_OFF);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+		/* 2.only for SDIO disable interrupt */
+		rtw_intf_stop(padapter);
+
+		/* 2.1 clean interrupt */
+		rtw_hal_clear_interrupt(padapter);
+#endif /* CONFIG_SDIO_HCI */
+
+		/* 1. stop thread */
+		rtw_set_drv_stopped(padapter);	/*for stop thread*/
+		rtw_mi_stop_drv_threads(padapter);
+
+		rtw_clr_drv_stopped(padapter);	/*for 32k command*/
+
+		/* #ifdef CONFIG_LPS */
+		/* rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "WOWLAN"); */
+		/* #endif */
+
+		#ifdef CONFIG_SDIO_HCI
+		/* 2.2 free irq */
+		#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+		sdio_free_irq(adapter_to_dvobj(padapter));
+		#endif
+		#endif/*CONFIG_SDIO_HCI*/
+
+#ifdef CONFIG_RUNTIME_PORT_SWITCH
+		if (rtw_port_switch_chk(padapter)) {
+			RTW_INFO(" ### PORT SWITCH ###\n");
+			rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
+		}
+#endif
+
+		poidparam.subcode = WOWLAN_ENABLE;
+		rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
+		if (rtw_chk_roam_flags(padapter, RTW_ROAM_ON_RESUME)) {
+			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
+			    && check_fwstate(pmlmepriv, _FW_LINKED)) {
+				RTW_INFO("%s %s(" MAC_FMT "), length:%d assoc_ssid.length:%d\n", __FUNCTION__,
+					pmlmepriv->cur_network.network.Ssid.Ssid,
+					MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
+					pmlmepriv->cur_network.network.Ssid.SsidLength,
+					 pmlmepriv->assoc_ssid.SsidLength);
+
+				rtw_set_to_roam(padapter, 0);
+			}
+		}
+
+		RTW_PRINT("%s: wowmode suspending\n", __func__);
+
+		if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+			RTW_PRINT("%s: fw_under_survey\n", __func__);
+			rtw_indicate_scan_done(padapter, 1);
+			clr_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
+		}
+
+#if 1
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			ch =  rtw_mi_get_union_chan(padapter);
+			bw = rtw_mi_get_union_bw(padapter);
+			offset = rtw_mi_get_union_offset(padapter);
+			RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
+				 FUNC_ADPT_ARG(padapter), ch, bw, offset);
+			set_channel_bwmode(padapter, ch, offset, bw);
+		}
+#else
+		if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
+			RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
+				 FUNC_ADPT_ARG(padapter), ch, bw, offset);
+			set_channel_bwmode(padapter, ch, offset, bw);
+			rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
+		}
+#endif
+#ifdef CONFIG_CONCURRENT_MODE
+		rtw_mi_buddy_suspend_free_assoc_resource(padapter);
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+		rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT);
+#endif
+
+		if (pwrpriv->wowlan_pno_enable) {
+			RTW_PRINT("%s: pno: %d\n", __func__,
+				  pwrpriv->wowlan_pno_enable);
+#ifdef CONFIG_FWLPS_IN_IPS
+			rtw_set_fw_in_ips_mode(padapter, _TRUE);
+#endif
+		}
+#ifdef CONFIG_LPS
+		else {
+			if (!(pwrpriv->wowlan_dis_lps)) {
+				rtw_wow_lps_level_decide(padapter, _TRUE);
+				rtw_set_ps_mode(padapter, PS_MODE_MAX, 0, 0, "WOWLAN");
+			}
+		}
+#endif /* #ifdef CONFIG_LPS */
+
+	} else
+		RTW_PRINT("%s: ### ERROR ### wowlan_mode=%d\n", __FUNCTION__, pwrpriv->wowlan_mode);
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	return ret;
+}
+#endif /* #ifdef CONFIG_WOWLAN */
+
+#ifdef CONFIG_AP_WOWLAN
+int rtw_suspend_ap_wow(_adapter *padapter)
+{
+	u8 ch, bw, offset;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct wowlan_ioctl_param poidparam;
+	u8 ps_mode;
+	int ret = _SUCCESS;
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+	pwrpriv->wowlan_ap_mode = _TRUE;
+
+	RTW_INFO("wowlan_ap_mode: %d\n", pwrpriv->wowlan_ap_mode);
+
+	rtw_mi_netif_stop_queue(padapter);
+
+	/* 0. Power off LED */
+	rtw_led_control(padapter, LED_CTL_POWER_OFF);
+#ifdef CONFIG_SDIO_HCI
+	/* 2.only for SDIO disable interrupt*/
+	rtw_intf_stop(padapter);
+
+	/* 2.1 clean interrupt */
+	rtw_hal_clear_interrupt(padapter);
+#endif /* CONFIG_SDIO_HCI */
+
+	/* 1. stop thread */
+	rtw_set_drv_stopped(padapter);	/*for stop thread*/
+	rtw_mi_stop_drv_threads(padapter);
+	rtw_clr_drv_stopped(padapter);	/*for 32k command*/
+
+	#ifdef CONFIG_SDIO_HCI
+	/* 2.2 free irq */
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	sdio_free_irq(adapter_to_dvobj(padapter));
+	#endif
+	#endif/*CONFIG_SDIO_HCI*/
+
+#ifdef CONFIG_RUNTIME_PORT_SWITCH
+	if (rtw_port_switch_chk(padapter)) {
+		RTW_INFO(" ### PORT SWITCH ###\n");
+		rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
+	}
+#endif
+
+	poidparam.subcode = WOWLAN_AP_ENABLE;
+	rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
+
+	RTW_PRINT("%s: wowmode suspending\n", __func__);
+#if 1
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		ch =  rtw_mi_get_union_chan(padapter);
+		bw = rtw_mi_get_union_bw(padapter);
+		offset = rtw_mi_get_union_offset(padapter);
+		RTW_INFO("back to linked/linking union - ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
+		set_channel_bwmode(padapter, ch, offset, bw);
+	}
+#else
+	if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
+		RTW_INFO("back to linked/linking union - ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
+		set_channel_bwmode(padapter, ch, offset, bw);
+		rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
+	}
+#endif
+
+	/*FOR ONE AP - TODO :Multi-AP*/
+	{
+		int i;
+		_adapter *iface;
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if ((iface) && rtw_is_adapter_up(iface)) {
+				if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE) == _FALSE)
+					rtw_suspend_free_assoc_resource(iface);
+			}
+		}
+
+	}
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT);
+#endif
+
+#ifdef CONFIG_LPS
+	if (!(pwrpriv->wowlan_dis_lps)) {
+		rtw_wow_lps_level_decide(padapter, _TRUE);
+		rtw_set_ps_mode(padapter, PS_MODE_MIN, 0, 0, "AP-WOWLAN");
+	}
+#endif
+
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	return ret;
+}
+#endif /* #ifdef CONFIG_AP_WOWLAN */
+
+
+int rtw_suspend_normal(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	int ret = _SUCCESS;
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_SUSPEND);
+#endif
+	rtw_mi_netif_caroff_qstop(padapter);
+
+	rtw_mi_suspend_free_assoc_resource(padapter);
+
+	rtw_led_control(padapter, LED_CTL_POWER_OFF);
+
+	if ((rtw_hal_check_ips_status(padapter) == _TRUE)
+	    || (adapter_to_pwrctl(padapter)->rf_pwrstate == rf_off))
+		RTW_PRINT("%s: ### ERROR #### driver in IPS ####ERROR###!!!\n", __FUNCTION__);
+
+
+#ifdef CONFIG_CONCURRENT_MODE
+	rtw_set_drv_stopped(padapter);	/*for stop thread*/
+	rtw_stop_cmd_thread(padapter);
+	rtw_drv_stop_vir_ifaces(adapter_to_dvobj(padapter));
+#endif
+	rtw_dev_unload(padapter);
+
+	#ifdef CONFIG_SDIO_HCI
+	sdio_deinit(adapter_to_dvobj(padapter));
+
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	sdio_free_irq(adapter_to_dvobj(padapter));
+	#endif
+	#endif /*CONFIG_SDIO_HCI*/
+
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	return ret;
+}
+
+int rtw_suspend_common(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	int ret = 0;
+	systime start_time = rtw_get_current_time();
+
+	RTW_PRINT(" suspend start\n");
+	RTW_INFO("==> %s (%s:%d)\n", __FUNCTION__, current->comm, current->pid);
+
+	pdbgpriv->dbg_suspend_cnt++;
+
+	pwrpriv->bInSuspend = _TRUE;
+
+	while (pwrpriv->bips_processing == _TRUE)
+		rtw_msleep_os(1);
+
+#ifdef CONFIG_IOL_READ_EFUSE_MAP
+	if (!padapter->bup) {
+		u8 bMacPwrCtrlOn = _FALSE;
+		rtw_hal_get_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
+		if (bMacPwrCtrlOn)
+			rtw_hal_power_off(padapter);
+	}
+#endif
+
+	if ((!padapter->bup) || RTW_CANNOT_RUN(padapter)) {
+		RTW_INFO("%s bup=%d bDriverStopped=%s bSurpriseRemoved = %s\n", __func__
+			 , padapter->bup
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+		pdbgpriv->dbg_suspend_error_cnt++;
+		goto exit;
+	}
+	rtw_ps_deny(padapter, PS_DENY_SUSPEND);
+
+	rtw_mi_cancel_all_timer(padapter);
+	LeaveAllPowerSaveModeDirect(padapter);
+
+	rtw_ps_deny_cancel(padapter, PS_DENY_SUSPEND);
+
+	if (rtw_mi_check_status(padapter, MI_AP_MODE) == _FALSE) {
+#ifdef CONFIG_WOWLAN
+		if (check_fwstate(pmlmepriv, _FW_LINKED))
+			pwrpriv->wowlan_mode = _TRUE;
+		else if (pwrpriv->wowlan_pno_enable == _TRUE)
+			pwrpriv->wowlan_mode |= pwrpriv->wowlan_pno_enable;
+
+#ifdef CONFIG_P2P_WOWLAN
+		if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE) || P2P_ROLE_DISABLE != padapter->wdinfo.role)
+			pwrpriv->wowlan_p2p_mode = _TRUE;
+		if (_TRUE == pwrpriv->wowlan_p2p_mode)
+			pwrpriv->wowlan_mode |= pwrpriv->wowlan_p2p_mode;
+#endif /* CONFIG_P2P_WOWLAN */
+
+		if (pwrpriv->wowlan_mode == _TRUE)
+			rtw_suspend_wow(padapter);
+		else
+#endif /* CONFIG_WOWLAN */
+			rtw_suspend_normal(padapter);
+	} else if (rtw_mi_check_status(padapter, MI_AP_MODE)) {
+#ifdef CONFIG_AP_WOWLAN
+		rtw_suspend_ap_wow(padapter);
+#else
+		rtw_suspend_normal(padapter);
+#endif /*CONFIG_AP_WOWLAN*/
+	}
+
+
+	RTW_PRINT("rtw suspend success in %d ms\n",
+		  rtw_get_passing_time_ms(start_time));
+
+exit:
+	RTW_INFO("<===  %s return %d.............. in %dms\n", __FUNCTION__
+		 , ret, rtw_get_passing_time_ms(start_time));
+
+	return ret;
+}
+
+#ifdef CONFIG_WOWLAN
+int rtw_resume_process_wow(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct dvobj_priv *psdpriv = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	struct wowlan_ioctl_param poidparam;
+	struct sta_info	*psta = NULL;
+	int ret = _SUCCESS;
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+	if (padapter) {
+		pwrpriv = adapter_to_pwrctl(padapter);
+	} else {
+		pdbgpriv->dbg_resume_error_cnt++;
+		ret = -1;
+		goto exit;
+	}
+
+	if (RTW_CANNOT_RUN(padapter)) {
+		RTW_INFO("%s pdapter %p bDriverStopped %s bSurpriseRemoved %s\n"
+			 , __func__, padapter
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+		goto exit;
+	}
+
+	pwrpriv->wowlan_in_resume = _TRUE;
+#ifdef CONFIG_PNO_SUPPORT
+#ifdef CONFIG_FWLPS_IN_IPS
+	if (pwrpriv->wowlan_pno_enable)
+		rtw_set_fw_in_ips_mode(padapter, _FALSE);
+#endif /* CONFIG_FWLPS_IN_IPS */
+#endif/* CONFIG_PNO_SUPPORT */
+
+	if (pwrpriv->wowlan_mode == _TRUE) {
+#ifdef CONFIG_LPS
+		if (!(pwrpriv->wowlan_dis_lps)) {
+			rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "WOWLAN");
+			rtw_wow_lps_level_decide(padapter, _FALSE);
+		}
+#endif /* CONFIG_LPS */
+
+		pwrpriv->bFwCurrentInPSMode = _FALSE;
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_PCI_HCI)
+		rtw_mi_intf_stop(padapter);
+		rtw_hal_clear_interrupt(padapter);
+#endif
+
+		#ifdef CONFIG_SDIO_HCI
+		#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+		if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {
+			ret = -1;
+			goto exit;
+		}
+		#endif
+		#endif/*CONFIG_SDIO_HCI*/
+
+		/* Disable WOW, set H2C command */
+		poidparam.subcode = WOWLAN_DISABLE;
+		rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		rtw_mi_buddy_reset_drv_sw(padapter);
+#endif
+
+		psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
+		if (psta)
+			set_sta_rate(padapter, psta);
+
+
+		rtw_clr_drv_stopped(padapter);
+		RTW_INFO("%s: wowmode resuming, DriverStopped:%s\n", __func__, rtw_is_drv_stopped(padapter) ? "True" : "False");
+
+		rtw_mi_start_drv_threads(padapter);
+
+		rtw_mi_intf_start(padapter);
+
+#ifdef CONFIG_CONCURRENT_MODE
+		rtw_mi_buddy_netif_carrier_on(padapter);
+#endif
+
+		/* start netif queue */
+		rtw_mi_netif_wake_queue(padapter);
+
+	} else
+
+		RTW_PRINT("%s: ### ERROR ### wowlan_mode=%d\n", __FUNCTION__, pwrpriv->wowlan_mode);
+
+	if (padapter->pid[1] != 0) {
+		RTW_INFO("pid[1]:%d\n", padapter->pid[1]);
+		rtw_signal_process(padapter->pid[1], SIGUSR2);
+	}
+
+	if (rtw_chk_roam_flags(padapter, RTW_ROAM_ON_RESUME)) {
+		if (pwrpriv->wowlan_wake_reason == FW_DECISION_DISCONNECT ||
+		    pwrpriv->wowlan_wake_reason == RX_DISASSOC||
+		    pwrpriv->wowlan_wake_reason == RX_DEAUTH) {
+
+			RTW_INFO("%s: disconnect reason: %02x\n", __func__,
+				 pwrpriv->wowlan_wake_reason);
+			rtw_indicate_disconnect(padapter, 0, _FALSE);
+
+			rtw_sta_media_status_rpt(padapter,
+					 rtw_get_stainfo(&padapter->stapriv,
+					 get_bssid(&padapter->mlmepriv)), 0);
+
+			rtw_free_assoc_resources(padapter, 1);
+			pmlmeinfo->state = WIFI_FW_NULL_STATE;
+
+		} else {
+			RTW_INFO("%s: do roaming\n", __func__);
+			rtw_roaming(padapter, NULL);
+		}
+	}
+
+	if (pwrpriv->wowlan_mode == _TRUE) {
+		pwrpriv->bips_processing = _FALSE;
+		_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
+#ifndef CONFIG_IPS_CHECK_IN_WD
+		rtw_set_pwr_state_check_timer(pwrpriv);
+#endif
+	} else
+		RTW_PRINT("do not reset timer\n");
+
+	pwrpriv->wowlan_mode = _FALSE;
+
+	/* Power On LED */
+#ifdef CONFIG_RTW_SW_LED
+
+	if (pwrpriv->wowlan_wake_reason == RX_DISASSOC||
+	    pwrpriv->wowlan_wake_reason == RX_DEAUTH||
+	    pwrpriv->wowlan_wake_reason == FW_DECISION_DISCONNECT)
+		rtw_led_control(padapter, LED_CTL_NO_LINK);
+	else
+		rtw_led_control(padapter, LED_CTL_LINK);
+#endif
+	/* clean driver side wake up reason. */
+	pwrpriv->wowlan_last_wake_reason = pwrpriv->wowlan_wake_reason;
+	pwrpriv->wowlan_wake_reason = 0;
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_RESUME);
+#endif /* CONFIG_BT_COEXIST */
+
+exit:
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	return ret;
+}
+#endif /* #ifdef CONFIG_WOWLAN */
+
+#ifdef CONFIG_AP_WOWLAN
+int rtw_resume_process_ap_wow(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct dvobj_priv *psdpriv = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	struct wowlan_ioctl_param poidparam;
+	struct sta_info	*psta = NULL;
+	int ret = _SUCCESS;
+	u8 ch, bw, offset;
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+	if (padapter) {
+		pwrpriv = adapter_to_pwrctl(padapter);
+	} else {
+		pdbgpriv->dbg_resume_error_cnt++;
+		ret = -1;
+		goto exit;
+	}
+
+
+#ifdef CONFIG_LPS
+	if (!(pwrpriv->wowlan_dis_lps)) {
+		rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "AP-WOWLAN");
+		rtw_wow_lps_level_decide(padapter, _FALSE);
+	}
+#endif /* CONFIG_LPS */
+
+	pwrpriv->bFwCurrentInPSMode = _FALSE;
+
+	rtw_hal_disable_interrupt(padapter);
+
+	rtw_hal_clear_interrupt(padapter);
+
+	#ifdef CONFIG_SDIO_HCI
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {
+		ret = -1;
+		goto exit;
+	}
+	#endif
+	#endif/*CONFIG_SDIO_HCI*/
+	/* Disable WOW, set H2C command */
+	poidparam.subcode = WOWLAN_AP_DISABLE;
+	rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
+	pwrpriv->wowlan_ap_mode = _FALSE;
+
+	rtw_clr_drv_stopped(padapter);
+	RTW_INFO("%s: wowmode resuming, DriverStopped:%s\n", __func__, rtw_is_drv_stopped(padapter) ? "True" : "False");
+
+	rtw_mi_start_drv_threads(padapter);
+
+#if 1
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		ch =  rtw_mi_get_union_chan(padapter);
+		bw = rtw_mi_get_union_bw(padapter);
+		offset = rtw_mi_get_union_offset(padapter);
+		RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n", FUNC_ADPT_ARG(padapter), ch, bw, offset);
+		set_channel_bwmode(padapter, ch, offset, bw);
+	}
+#else
+	if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
+		RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n", FUNC_ADPT_ARG(padapter), ch, bw, offset);
+		set_channel_bwmode(padapter, ch, offset, bw);
+		rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
+	}
+#endif
+
+	/*FOR ONE AP - TODO :Multi-AP*/
+	{
+		int i;
+		_adapter *iface;
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if ((iface) && rtw_is_adapter_up(iface)) {
+				if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE | _FW_LINKED))
+					rtw_reset_drv_sw(iface);
+			}
+		}
+
+	}
+	rtw_mi_intf_start(padapter);
+
+	/* start netif queue */
+	rtw_mi_netif_wake_queue(padapter);
+
+	if (padapter->pid[1] != 0) {
+		RTW_INFO("pid[1]:%d\n", padapter->pid[1]);
+		rtw_signal_process(padapter->pid[1], SIGUSR2);
+	}
+
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+	/* rtw_unlock_suspend(); */
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
+
+	pwrpriv->bips_processing = _FALSE;
+	_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
+#ifndef CONFIG_IPS_CHECK_IN_WD
+	rtw_set_pwr_state_check_timer(pwrpriv);
+#endif
+	/* clean driver side wake up reason. */
+	pwrpriv->wowlan_wake_reason = 0;
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_RESUME);
+#endif /* CONFIG_BT_COEXIST */
+
+	/* Power On LED */
+#ifdef CONFIG_RTW_SW_LED
+
+	rtw_led_control(padapter, LED_CTL_LINK);
+#endif
+exit:
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	return ret;
+}
+#endif /* #ifdef CONFIG_APWOWLAN */
+
+void rtw_mi_resume_process_normal(_adapter *padapter)
+{
+	int i;
+	_adapter *iface;
+	struct mlme_priv *pmlmepriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			pmlmepriv = &iface->mlmepriv;
+
+			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+				RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(iface), get_fwstate(pmlmepriv));
+
+				if (rtw_chk_roam_flags(iface, RTW_ROAM_ON_RESUME))
+					rtw_roaming(iface, NULL);
+
+			} else if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
+				RTW_INFO(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(iface), MLME_IS_AP(iface) ? "AP" : "MESH");
+				rtw_ap_restore_network(iface);
+			} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE))
+				RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(iface), get_fwstate(pmlmepriv));
+			else
+				RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(iface), get_fwstate(pmlmepriv));
+		}
+	}
+}
+
+int rtw_resume_process_normal(_adapter *padapter)
+{
+	struct net_device *pnetdev;
+	struct pwrctrl_priv *pwrpriv;
+	struct dvobj_priv *psdpriv;
+	struct debug_priv *pdbgpriv;
+
+	int ret = _SUCCESS;
+
+	if (!padapter) {
+		ret = -1;
+		goto exit;
+	}
+
+	pnetdev = padapter->pnetdev;
+	pwrpriv = adapter_to_pwrctl(padapter);
+	psdpriv = padapter->dvobj;
+	pdbgpriv = &psdpriv->drv_dbg;
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+	#ifdef CONFIG_SDIO_HCI
+	/* interface init */
+	if (sdio_init(adapter_to_dvobj(padapter)) != _SUCCESS) {
+		ret = -1;
+		goto exit;
+	}
+	#endif/*CONFIG_SDIO_HCI*/
+
+	rtw_clr_surprise_removed(padapter);
+	rtw_hal_disable_interrupt(padapter);
+
+	#ifdef CONFIG_SDIO_HCI
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {
+		ret = -1;
+		goto exit;
+	}
+	#endif
+	#endif/*CONFIG_SDIO_HCI*/
+
+	rtw_mi_reset_drv_sw(padapter);
+
+	pwrpriv->bkeepfwalive = _FALSE;
+
+	RTW_INFO("bkeepfwalive(%x)\n", pwrpriv->bkeepfwalive);
+	if (pm_netdev_open(pnetdev, _TRUE) != 0) {
+		ret = -1;
+		pdbgpriv->dbg_resume_error_cnt++;
+		goto exit;
+	}
+
+	rtw_mi_netif_caron_qstart(padapter);
+
+	if (padapter->pid[1] != 0) {
+		RTW_INFO("pid[1]:%d\n", padapter->pid[1]);
+		rtw_signal_process(padapter->pid[1], SIGUSR2);
+	}
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_RESUME);
+#endif /* CONFIG_BT_COEXIST */
+
+	rtw_mi_resume_process_normal(padapter);
+
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+	/* rtw_unlock_suspend(); */
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+
+exit:
+	return ret;
+}
+
+int rtw_resume_common(_adapter *padapter)
+{
+	int ret = 0;
+	systime start_time = rtw_get_current_time();
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+
+	if (pwrpriv->bInSuspend == _FALSE)
+		return 0;
+
+	RTW_PRINT("resume start\n");
+	RTW_INFO("==> %s (%s:%d)\n", __FUNCTION__, current->comm, current->pid);
+
+	if (rtw_mi_check_status(padapter, WIFI_AP_STATE) == _FALSE) {
+#ifdef CONFIG_WOWLAN
+		if (pwrpriv->wowlan_mode == _TRUE)
+			rtw_resume_process_wow(padapter);
+		else
+#endif
+			rtw_resume_process_normal(padapter);
+
+	} else if (rtw_mi_check_status(padapter, WIFI_AP_STATE)) {
+#ifdef CONFIG_AP_WOWLAN
+		rtw_resume_process_ap_wow(padapter);
+#else
+		rtw_resume_process_normal(padapter);
+#endif /* CONFIG_AP_WOWLAN */
+	}
+
+	if (pwrpriv) {
+		pwrpriv->bInSuspend = _FALSE;
+		pwrpriv->wowlan_in_resume = _FALSE;
+	}
+	RTW_PRINT("%s:%d in %d ms\n", __FUNCTION__ , ret,
+		  rtw_get_passing_time_ms(start_time));
+
+
+	return ret;
+}
+
+#ifdef CONFIG_GPIO_API
+u8 rtw_get_gpio(struct net_device *netdev, u8 gpio_num)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	return rtw_hal_get_gpio(adapter, gpio_num);
+}
+EXPORT_SYMBOL(rtw_get_gpio);
+
+int  rtw_set_gpio_output_value(struct net_device *netdev, u8 gpio_num, bool isHigh)
+{
+	u8 direction = 0;
+	u8 res = -1;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	return rtw_hal_set_gpio_output_value(adapter, gpio_num, isHigh);
+}
+EXPORT_SYMBOL(rtw_set_gpio_output_value);
+
+int rtw_config_gpio(struct net_device *netdev, u8 gpio_num, bool isOutput)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	return rtw_hal_config_gpio(adapter, gpio_num, isOutput);
+}
+EXPORT_SYMBOL(rtw_config_gpio);
+int rtw_register_gpio_interrupt(struct net_device *netdev, int gpio_num, void(*callback)(u8 level))
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	return rtw_hal_register_gpio_interrupt(adapter, gpio_num, callback);
+}
+EXPORT_SYMBOL(rtw_register_gpio_interrupt);
+
+int rtw_disable_gpio_interrupt(struct net_device *netdev, int gpio_num)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	return rtw_hal_disable_gpio_interrupt(adapter, gpio_num);
+}
+EXPORT_SYMBOL(rtw_disable_gpio_interrupt);
+
+#endif /* #ifdef CONFIG_GPIO_API */
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+
+int rtw_vendor_ie_get_api(struct net_device *dev, int ie_num, char *extra,
+		u16 extra_len)
+{
+	int ret = 0;
+
+	ret = rtw_vendor_ie_get_raw_data(dev, ie_num, extra, extra_len);
+	return ret;
+}
+EXPORT_SYMBOL(rtw_vendor_ie_get_api);
+
+int rtw_vendor_ie_set_api(struct net_device *dev, char *extra)
+{
+	return rtw_vendor_ie_set(dev, NULL, NULL, extra);
+}
+EXPORT_SYMBOL(rtw_vendor_ie_set_api);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/recv_linux.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/recv_linux.c
new file mode 100644
index 000000000000..d099f69a33b6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/recv_linux.c
@@ -0,0 +1,732 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+
+int rtw_os_recvframe_duplicate_skb(_adapter *padapter, union recv_frame *pcloneframe, _pkt *pskb)
+{
+	int res = _SUCCESS;
+	_pkt	*pkt_copy = NULL;
+	struct rx_pkt_attrib *pattrib = &pcloneframe->u.hdr.attrib;
+
+	if (pskb == NULL) {
+		RTW_INFO("%s [WARN] skb == NULL, drop frag frame\n", __func__);
+		return _FAIL;
+	}
+#if 1
+	pkt_copy = rtw_skb_copy(pskb);
+
+	if (pkt_copy == NULL) {
+		RTW_INFO("%s [WARN] rtw_skb_copy fail , drop frag frame\n", __func__);
+		return _FAIL;
+	}
+#else
+	pkt_copy = rtw_skb_clone(pskb);
+
+	if (pkt_copy == NULL) {
+		RTW_INFO("%s [WARN] rtw_skb_clone fail , drop frag frame\n", __func__);
+		return _FAIL;
+	}
+#endif
+	pkt_copy->dev = padapter->pnetdev;
+
+	pcloneframe->u.hdr.pkt = pkt_copy;
+	pcloneframe->u.hdr.rx_head = pkt_copy->head;
+	pcloneframe->u.hdr.rx_data = pkt_copy->data;
+	pcloneframe->u.hdr.rx_end = skb_end_pointer(pkt_copy);
+	pcloneframe->u.hdr.rx_tail = skb_tail_pointer(pkt_copy);
+	pcloneframe->u.hdr.len = pkt_copy->len;
+
+	return res;
+}
+
+int rtw_os_alloc_recvframe(_adapter *padapter, union recv_frame *precvframe, u8 *pdata, _pkt *pskb)
+{
+	int res = _SUCCESS;
+	u8	shift_sz = 0;
+	u32	skb_len, alloc_sz;
+	_pkt	*pkt_copy = NULL;
+	struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
+
+
+	if (pdata == NULL) {
+		precvframe->u.hdr.pkt = NULL;
+		res = _FAIL;
+		return res;
+	}
+
+
+	/*	Modified by Albert 20101213 */
+	/*	For 8 bytes IP header alignment. */
+	shift_sz = pattrib->qos ? 6 : 0; /*	Qos data, wireless lan header length is 26 */
+
+	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. */
+		alloc_sz = (skb_len <= 1650) ? 1664 : (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 = rtw_skb_alloc(alloc_sz);
+
+	if (pkt_copy) {
+		pkt_copy->dev = padapter->pnetdev;
+		pkt_copy->len = skb_len;
+		precvframe->u.hdr.pkt = pkt_copy;
+		precvframe->u.hdr.rx_head = pkt_copy->head;
+		precvframe->u.hdr.rx_end = pkt_copy->data + alloc_sz;
+		skb_reserve(pkt_copy, 8 - ((SIZE_PTR)(pkt_copy->data) & 7));  /* force pkt_copy->data at 8-byte alignment address */
+		skb_reserve(pkt_copy, shift_sz);/* force ip_hdr at 8-byte alignment address according to shift_sz. */
+		_rtw_memcpy(pkt_copy->data, pdata, skb_len);
+		precvframe->u.hdr.rx_data = precvframe->u.hdr.rx_tail = pkt_copy->data;
+	} else {
+#if 0
+		{
+			rtw_free_recvframe(precvframe_if2, &precvpriv->free_recv_queue);
+			rtw_enqueue_recvbuf_to_head(precvbuf, &precvpriv->recv_buf_pending_queue);
+
+			/* The case of can't allocate skb is serious and may never be recovered,
+			 once bDriverStopped is enable, this task should be stopped.*/
+			if (!rtw_is_drv_stopped(secondary_padapter))
+#ifdef PLATFORM_LINUX
+				tasklet_schedule(&precvpriv->recv_tasklet);
+#endif
+			return ret;
+		}
+
+#endif
+
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+		RTW_INFO("%s:can not allocate memory for skb copy\n", __func__);
+
+		precvframe->u.hdr.pkt = NULL;
+
+		/* rtw_free_recvframe(precvframe, pfree_recv_queue); */
+		/*exit_rtw_os_recv_resource_alloc;*/
+
+		res = _FAIL;
+#else
+		if ((pattrib->mfrag == 1) && (pattrib->frag_num == 0)) {
+			RTW_INFO("%s: alloc_skb fail , drop frag frame\n", __FUNCTION__);
+			/* rtw_free_recvframe(precvframe, pfree_recv_queue); */
+			res = _FAIL;
+			goto exit_rtw_os_recv_resource_alloc;
+		}
+
+		if (pskb == NULL) {
+			res = _FAIL;
+			goto exit_rtw_os_recv_resource_alloc;
+		}
+
+		precvframe->u.hdr.pkt = rtw_skb_clone(pskb);
+		if (precvframe->u.hdr.pkt) {
+			precvframe->u.hdr.pkt->dev = padapter->pnetdev;
+			precvframe->u.hdr.rx_head = precvframe->u.hdr.rx_data = precvframe->u.hdr.rx_tail = pdata;
+			precvframe->u.hdr.rx_end =  pdata + alloc_sz;
+		} else {
+			RTW_INFO("%s: rtw_skb_clone fail\n", __FUNCTION__);
+			/* rtw_free_recvframe(precvframe, pfree_recv_queue); */
+			/*exit_rtw_os_recv_resource_alloc;*/
+			res = _FAIL;
+		}
+#endif
+	}
+
+exit_rtw_os_recv_resource_alloc:
+
+	return res;
+
+}
+
+void rtw_os_free_recvframe(union recv_frame *precvframe)
+{
+	if (precvframe->u.hdr.pkt) {
+		rtw_os_pkt_free(precvframe->u.hdr.pkt);
+		precvframe->u.hdr.pkt = NULL;
+	}
+}
+
+/* init os related resource in struct recv_priv */
+int rtw_os_recv_resource_init(struct recv_priv *precvpriv, _adapter *padapter)
+{
+	int	res = _SUCCESS;
+
+
+#ifdef CONFIG_RTW_NAPI
+	skb_queue_head_init(&precvpriv->rx_napi_skb_queue);
+#endif /* CONFIG_RTW_NAPI */
+
+	return res;
+}
+
+/* alloc os related resource in union recv_frame */
+int rtw_os_recv_resource_alloc(_adapter *padapter, union recv_frame *precvframe)
+{
+	int	res = _SUCCESS;
+
+	precvframe->u.hdr.pkt = NULL;
+
+	return res;
+}
+
+/* free os related resource in union recv_frame */
+void rtw_os_recv_resource_free(struct recv_priv *precvpriv)
+{
+	sint i;
+	union recv_frame *precvframe;
+	precvframe = (union recv_frame *) precvpriv->precv_frame_buf;
+
+
+#ifdef CONFIG_RTW_NAPI
+	if (skb_queue_len(&precvpriv->rx_napi_skb_queue))
+		RTW_WARN("rx_napi_skb_queue not empty\n");
+	rtw_skb_queue_purge(&precvpriv->rx_napi_skb_queue);
+#endif /* CONFIG_RTW_NAPI */
+
+	for (i = 0; i < NR_RECVFRAME; i++) {
+		rtw_os_free_recvframe(precvframe);
+		precvframe++;
+	}
+}
+
+/* alloc os related resource in struct recv_buf */
+int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf)
+{
+	int res = _SUCCESS;
+
+#ifdef CONFIG_USB_HCI
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	struct usb_device	*pusbd = pdvobjpriv->pusbdev;
+
+	precvbuf->irp_pending = _FALSE;
+	precvbuf->purb = usb_alloc_urb(0, GFP_KERNEL);
+	if (precvbuf->purb == NULL)
+		res = _FAIL;
+
+	precvbuf->pskb = NULL;
+
+	precvbuf->pallocated_buf  = precvbuf->pbuf = NULL;
+
+	precvbuf->pdata = precvbuf->phead = precvbuf->ptail = precvbuf->pend = NULL;
+
+	precvbuf->transfer_len = 0;
+
+	precvbuf->len = 0;
+
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+	precvbuf->pallocated_buf = rtw_usb_buffer_alloc(pusbd, (size_t)precvbuf->alloc_sz, &precvbuf->dma_transfer_addr);
+	precvbuf->pbuf = precvbuf->pallocated_buf;
+	if (precvbuf->pallocated_buf == NULL)
+		return _FAIL;
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
+
+#endif /* CONFIG_USB_HCI */
+
+	return res;
+}
+
+/* free os related resource in struct recv_buf */
+int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf)
+{
+	int ret = _SUCCESS;
+
+#ifdef CONFIG_USB_HCI
+
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	struct usb_device	*pusbd = pdvobjpriv->pusbdev;
+
+	rtw_usb_buffer_free(pusbd, (size_t)precvbuf->alloc_sz, precvbuf->pallocated_buf, precvbuf->dma_transfer_addr);
+	precvbuf->pallocated_buf =  NULL;
+	precvbuf->dma_transfer_addr = 0;
+
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
+
+	if (precvbuf->purb) {
+		/* usb_kill_urb(precvbuf->purb); */
+		usb_free_urb(precvbuf->purb);
+	}
+
+#endif /* CONFIG_USB_HCI */
+
+
+	if (precvbuf->pskb) {
+#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+		if (rtw_free_skb_premem(precvbuf->pskb) != 0)
+#endif
+			rtw_skb_free(precvbuf->pskb);
+	}
+	return ret;
+
+}
+
+_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, const u8 *da, const u8 *sa, u8 *msdu ,u16 msdu_len)
+{
+	u16	eth_type;
+	u8	*data_ptr;
+	_pkt *sub_skb;
+	struct rx_pkt_attrib *pattrib;
+
+	pattrib = &prframe->u.hdr.attrib;
+
+#ifdef CONFIG_SKB_COPY
+	sub_skb = rtw_skb_alloc(msdu_len + 14);
+	if (sub_skb) {
+		skb_reserve(sub_skb, 14);
+		data_ptr = (u8 *)skb_put(sub_skb, msdu_len);
+		_rtw_memcpy(data_ptr, msdu, msdu_len);
+	} else
+#endif /* CONFIG_SKB_COPY */
+	{
+		sub_skb = rtw_skb_clone(prframe->u.hdr.pkt);
+		if (sub_skb) {
+			sub_skb->data = msdu;
+			sub_skb->len = msdu_len;
+			skb_set_tail_pointer(sub_skb, msdu_len);
+		} else {
+			RTW_INFO("%s(): rtw_skb_clone() Fail!!!\n", __FUNCTION__);
+			return NULL;
+		}
+	}
+
+	eth_type = RTW_GET_BE16(&sub_skb->data[6]);
+
+	if (sub_skb->len >= 8
+		&& ((_rtw_memcmp(sub_skb->data, rtw_rfc1042_header, SNAP_SIZE)
+				&& eth_type != ETH_P_AARP && eth_type != ETH_P_IPX)
+			|| _rtw_memcmp(sub_skb->data, rtw_bridge_tunnel_header, SNAP_SIZE))
+	) {
+		/* remove RFC1042 or Bridge-Tunnel encapsulation and replace EtherType */
+		skb_pull(sub_skb, SNAP_SIZE);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), sa, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), da, ETH_ALEN);
+	} else {
+		/* Leave Ethernet header part of hdr and full payload */
+		u16 len;
+
+		len = htons(sub_skb->len);
+		_rtw_memcpy(skb_push(sub_skb, 2), &len, 2);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), sa, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), da, ETH_ALEN);
+	}
+
+	return sub_skb;
+}
+
+#ifdef CONFIG_RTW_NAPI
+static int napi_recv(_adapter *padapter, int budget)
+{
+	_pkt *pskb;
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	int work_done = 0;
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
+	u8 rx_ok;
+
+
+	while ((work_done < budget) &&
+	       (!skb_queue_empty(&precvpriv->rx_napi_skb_queue))) {
+		pskb = skb_dequeue(&precvpriv->rx_napi_skb_queue);
+		if (!pskb)
+			break;
+
+		rx_ok = _FALSE;
+
+#ifdef CONFIG_RTW_GRO
+		if (pregistrypriv->en_gro) {
+			if (rtw_napi_gro_receive(&padapter->napi, pskb) != GRO_DROP)
+				rx_ok = _TRUE;
+			goto next;
+		}
+#endif /* CONFIG_RTW_GRO */
+
+		if (rtw_netif_receive_skb(padapter->pnetdev, pskb) == NET_RX_SUCCESS)
+			rx_ok = _TRUE;
+
+next:
+		if (rx_ok == _TRUE) {
+			work_done++;
+			DBG_COUNTER(padapter->rx_logs.os_netif_ok);
+		} else {
+			DBG_COUNTER(padapter->rx_logs.os_netif_err);
+		}
+	}
+
+	return work_done;
+}
+
+int rtw_recv_napi_poll(struct napi_struct *napi, int budget)
+{
+	_adapter *padapter = container_of(napi, _adapter, napi);
+	int work_done = 0;
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+
+
+	work_done = napi_recv(padapter, budget);
+	if (work_done < budget) {
+		napi_complete(napi);
+		if (!skb_queue_empty(&precvpriv->rx_napi_skb_queue))
+			napi_schedule(napi);
+	}
+
+	return work_done;
+}
+
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+void dynamic_napi_th_chk (_adapter *adapter)
+{
+
+	if (adapter->registrypriv.en_napi) {
+		struct dvobj_priv *dvobj;
+		struct registry_priv *registry;
+	
+		dvobj = adapter_to_dvobj(adapter);
+		registry = &adapter->registrypriv;
+		if (dvobj->traffic_stat.cur_rx_tp > registry->napi_threshold)
+			dvobj->en_napi_dynamic = 1;
+		else
+			dvobj->en_napi_dynamic = 0;
+	}
+
+}
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#endif /* CONFIG_RTW_NAPI */
+
+void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, union recv_frame *rframe)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+#ifdef CONFIG_BR_EXT
+	void *br_port = NULL;
+#endif
+	int ret;
+
+	/* Indicat the packets to upper layer */
+	if (pkt) {
+		struct ethhdr *ehdr = (struct ethhdr *)pkt->data;
+
+		DBG_COUNTER(padapter->rx_logs.os_indicate);
+
+		if (MLME_IS_AP(padapter)) {
+			_pkt *pskb2 = NULL;
+			struct sta_info *psta = NULL;
+			struct sta_priv *pstapriv = &padapter->stapriv;
+			int bmcast = IS_MCAST(ehdr->h_dest);
+
+			/* RTW_INFO("bmcast=%d\n", bmcast); */
+
+			if (_rtw_memcmp(ehdr->h_dest, adapter_mac_addr(padapter), ETH_ALEN) == _FALSE) {
+				/* RTW_INFO("not ap psta=%p, addr=%pM\n", psta, ehdr->h_dest); */
+
+				if (bmcast) {
+					psta = rtw_get_bcmc_stainfo(padapter);
+					pskb2 = rtw_skb_clone(pkt);
+				} else
+					psta = rtw_get_stainfo(pstapriv, ehdr->h_dest);
+
+				if (psta) {
+					struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
+
+					/* RTW_INFO("directly forwarding to the rtw_xmit_entry\n"); */
+
+					/* skb->ip_summed = CHECKSUM_NONE; */
+					pkt->dev = pnetdev;
+					#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+					skb_set_queue_mapping(pkt, rtw_recv_select_queue(pkt));
+					#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35) */
+
+					_rtw_xmit_entry(pkt, pnetdev);
+
+					if (bmcast && (pskb2 != NULL)) {
+						pkt = pskb2;
+						DBG_COUNTER(padapter->rx_logs.os_indicate_ap_mcast);
+					} else {
+						DBG_COUNTER(padapter->rx_logs.os_indicate_ap_forward);
+						return;
+					}
+				}
+			} else { /* to APself */
+				/* RTW_INFO("to APSelf\n"); */
+				DBG_COUNTER(padapter->rx_logs.os_indicate_ap_self);
+			}
+		}
+
+#ifdef CONFIG_BR_EXT
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE) {
+			/* Insert NAT2.5 RX here! */
+			#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+			br_port = padapter->pnetdev->br_port;
+			#else
+			rcu_read_lock();
+			br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
+			rcu_read_unlock();
+			#endif
+
+			if (br_port) {
+				int nat25_handle_frame(_adapter *priv, struct sk_buff *skb);
+
+				if (nat25_handle_frame(padapter, pkt) == -1) {
+					/* priv->ext_stats.rx_data_drops++; */
+					/* DEBUG_ERR("RX DROP: nat25_handle_frame fail!\n"); */
+					/* return FAIL; */
+
+					#if 1
+					/* bypass this frame to upper layer!! */
+					#else
+					rtw_skb_free(sub_skb);
+					continue;
+					#endif
+				}
+			}
+		}
+#endif /* CONFIG_BR_EXT */
+
+		/* After eth_type_trans process , pkt->data pointer will move from ethrnet header to ip header */
+		pkt->protocol = eth_type_trans(pkt, padapter->pnetdev);
+		pkt->dev = padapter->pnetdev;
+		pkt->ip_summed = CHECKSUM_NONE; /* CONFIG_TCP_CSUM_OFFLOAD_RX */
+
+#ifdef CONFIG_RTW_NAPI
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+		if (!skb_queue_empty(&precvpriv->rx_napi_skb_queue)
+			&& !adapter_to_dvobj(padapter)->en_napi_dynamic			
+			)
+			napi_recv(padapter, RTL_NAPI_WEIGHT);
+#endif
+
+		if (pregistrypriv->en_napi
+			#ifdef CONFIG_RTW_NAPI_DYNAMIC
+			&& adapter_to_dvobj(padapter)->en_napi_dynamic
+			#endif
+		) {
+			skb_queue_tail(&precvpriv->rx_napi_skb_queue, pkt);
+			#ifndef CONFIG_RTW_NAPI_V2
+			napi_schedule(&padapter->napi);
+			#endif
+			return;
+		}
+#endif /* CONFIG_RTW_NAPI */
+
+		ret = rtw_netif_rx(padapter->pnetdev, pkt);
+		if (ret == NET_RX_SUCCESS)
+			DBG_COUNTER(padapter->rx_logs.os_netif_ok);
+		else
+			DBG_COUNTER(padapter->rx_logs.os_netif_err);
+	}
+}
+
+void rtw_handle_tkip_mic_err(_adapter *padapter, struct sta_info *sta, u8 bgroup)
+{
+#ifdef CONFIG_IOCTL_CFG80211
+	enum nl80211_key_type key_type = 0;
+#endif
+	union iwreq_data wrqu;
+	struct iw_michaelmicfailure    ev;
+	struct mlme_priv              *pmlmepriv  = &padapter->mlmepriv;
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+	systime cur_time = 0;
+
+	if (psecuritypriv->last_mic_err_time == 0)
+		psecuritypriv->last_mic_err_time = rtw_get_current_time();
+	else {
+		cur_time = rtw_get_current_time();
+
+		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 = rtw_get_current_time();
+	}
+
+#ifdef CONFIG_IOCTL_CFG80211
+	if (bgroup)
+		key_type |= NL80211_KEYTYPE_GROUP;
+	else
+		key_type |= NL80211_KEYTYPE_PAIRWISE;
+
+	cfg80211_michael_mic_failure(padapter->pnetdev, sta->cmn.mac_addr, key_type, -1, NULL, GFP_ATOMIC);
+#endif
+
+	_rtw_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;
+	_rtw_memcpy(ev.src_addr.sa_data, sta->cmn.mac_addr, ETH_ALEN);
+
+	_rtw_memset(&wrqu, 0x00, sizeof(wrqu));
+	wrqu.data.length = sizeof(ev);
+
+#ifndef CONFIG_IOCTL_CFG80211
+	wireless_send_event(padapter->pnetdev, IWEVMICHAELMICFAILURE, &wrqu, (char *) &ev);
+#endif
+}
+
+#ifdef CONFIG_HOSTAPD_MLME
+void rtw_hostapd_mlme_rx(_adapter *padapter, union recv_frame *precv_frame)
+{
+	_pkt *skb;
+	struct hostapd_priv *phostapdpriv  = padapter->phostapdpriv;
+	struct net_device *pmgnt_netdev = phostapdpriv->pmgnt_netdev;
+
+
+	skb = precv_frame->u.hdr.pkt;
+
+	if (skb == NULL)
+		return;
+
+	skb->data = precv_frame->u.hdr.rx_data;
+	skb->tail = precv_frame->u.hdr.rx_tail;
+	skb->len = precv_frame->u.hdr.len;
+
+	/* pskb_copy = rtw_skb_copy(skb);
+	*	if(skb == NULL) goto _exit; */
+
+	skb->dev = pmgnt_netdev;
+	skb->ip_summed = CHECKSUM_NONE;
+	skb->pkt_type = PACKET_OTHERHOST;
+	/* skb->protocol = __constant_htons(0x0019); ETH_P_80211_RAW */
+	skb->protocol = __constant_htons(0x0003); /*ETH_P_80211_RAW*/
+
+	/* RTW_INFO("(1)data=0x%x, head=0x%x, tail=0x%x, mac_header=0x%x, len=%d\n", skb->data, skb->head, skb->tail, skb->mac_header, skb->len); */
+
+	/* skb->mac.raw = skb->data; */
+	skb_reset_mac_header(skb);
+
+	/* skb_pull(skb, 24); */
+	_rtw_memset(skb->cb, 0, sizeof(skb->cb));
+
+	rtw_netif_rx(pmgnt_netdev, skb);
+
+	precv_frame->u.hdr.pkt = NULL; /* set pointer to NULL before rtw_free_recvframe() if call rtw_netif_rx() */
+}
+#endif /* CONFIG_HOSTAPD_MLME */
+
+int rtw_recv_monitor(_adapter *padapter, union recv_frame *precv_frame)
+{
+	int ret = _FAIL;
+	struct recv_priv *precvpriv;
+	_queue	*pfree_recv_queue;
+	_pkt *skb;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct rx_pkt_attrib *pattrib;
+
+	if (NULL == precv_frame)
+		goto _recv_drop;
+
+	pattrib = &precv_frame->u.hdr.attrib;
+	precvpriv = &(padapter->recvpriv);
+	pfree_recv_queue = &(precvpriv->free_recv_queue);
+
+	skb = precv_frame->u.hdr.pkt;
+	if (skb == NULL) {
+		RTW_INFO("%s :skb==NULL something wrong!!!!\n", __func__);
+		goto _recv_drop;
+	}
+
+	skb->data = precv_frame->u.hdr.rx_data;
+	skb_set_tail_pointer(skb, precv_frame->u.hdr.len);
+	skb->len = precv_frame->u.hdr.len;
+	skb->ip_summed = CHECKSUM_NONE;
+	skb->pkt_type = PACKET_OTHERHOST;
+	skb->protocol = htons(0x0019); /* ETH_P_80211_RAW */
+
+	rtw_netif_rx(padapter->pnetdev, skb);
+
+	/* pointers to NULL before rtw_free_recvframe() */
+	precv_frame->u.hdr.pkt = NULL;
+
+	ret = _SUCCESS;
+
+_recv_drop:
+
+	/* enqueue back to free_recv_queue */
+	if (precv_frame)
+		rtw_free_recvframe(precv_frame, pfree_recv_queue);
+
+	return ret;
+
+}
+
+inline void rtw_rframe_set_os_pkt(union recv_frame *rframe)
+{
+	_pkt *skb = rframe->u.hdr.pkt;
+
+	skb->data = rframe->u.hdr.rx_data;
+	skb_set_tail_pointer(skb, rframe->u.hdr.len);
+	skb->len = rframe->u.hdr.len;
+}
+
+int rtw_recv_indicatepkt(_adapter *padapter, union recv_frame *precv_frame)
+{
+	struct recv_priv *precvpriv;
+	_queue	*pfree_recv_queue;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	precvpriv = &(padapter->recvpriv);
+	pfree_recv_queue = &(precvpriv->free_recv_queue);
+
+	if (precv_frame->u.hdr.pkt == NULL)
+		goto _recv_indicatepkt_drop;
+
+	rtw_os_recv_indicate_pkt(padapter, precv_frame->u.hdr.pkt, precv_frame);
+
+_recv_indicatepkt_end:
+	precv_frame->u.hdr.pkt = NULL;
+	rtw_free_recvframe(precv_frame, pfree_recv_queue);
+	return _SUCCESS;
+
+_recv_indicatepkt_drop:
+	rtw_free_recvframe(precv_frame, pfree_recv_queue);
+	DBG_COUNTER(padapter->rx_logs.os_indicate_err);
+	return _FAIL;
+}
+
+void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf)
+{
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+
+#ifdef CONFIG_USB_HCI
+
+	precvbuf->ref_cnt--;
+
+	/* free skb in recv_buf */
+	rtw_skb_free(precvbuf->pskb);
+
+	precvbuf->pskb = NULL;
+
+	if (precvbuf->irp_pending == _FALSE)
+		rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+
+
+#endif
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	precvbuf->pskb = NULL;
+#endif
+
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rhashtable.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rhashtable.c
new file mode 100644
index 000000000000..af9c9aec8a1e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rhashtable.c
@@ -0,0 +1,844 @@
+/*
+ * Resizable, Scalable, Concurrent Hash Table
+ *
+ * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au>
+ * Copyright (c) 2014-2015 Thomas Graf <tgraf@suug.ch>
+ * Copyright (c) 2008-2014 Patrick McHardy <kaber@trash.net>
+ *
+ * Code partially derived from nft_hash
+ * Rewritten with rehash code from br_multicast plus single list
+ * pointer as suggested by Josh Triplett
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#include <linux/atomic.h>
+#include <linux/kernel.h>
+#include <linux/init.h>
+#include <linux/log2.h>
+#include <linux/sched.h>
+#include <linux/slab.h>
+#include <linux/vmalloc.h>
+#include <linux/mm.h>
+#include <linux/jhash.h>
+#include <linux/random.h>
+#include <linux/err.h>
+#include <linux/export.h>
+
+#define HASH_DEFAULT_SIZE	64UL
+#define HASH_MIN_SIZE		4U
+#define BUCKET_LOCKS_PER_CPU   128UL
+
+static u32 head_hashfn(struct rhashtable *ht,
+		       const struct bucket_table *tbl,
+		       const struct rhash_head *he)
+{
+	return rht_head_hashfn(ht, tbl, he, ht->p);
+}
+
+#ifdef CONFIG_PROVE_LOCKING
+#define ASSERT_RHT_MUTEX(HT) BUG_ON(!lockdep_rht_mutex_is_held(HT))
+
+int lockdep_rht_mutex_is_held(struct rhashtable *ht)
+{
+	return (debug_locks) ? lockdep_is_held(&ht->mutex) : 1;
+}
+
+int lockdep_rht_bucket_is_held(const struct bucket_table *tbl, u32 hash)
+{
+	spinlock_t *lock = rht_bucket_lock(tbl, hash);
+
+	return (debug_locks) ? lockdep_is_held(lock) : 1;
+}
+#else
+#define ASSERT_RHT_MUTEX(HT)
+#endif
+
+
+static int alloc_bucket_locks(struct rhashtable *ht, struct bucket_table *tbl,
+			      gfp_t gfp)
+{
+	unsigned int i, size;
+#if defined(CONFIG_PROVE_LOCKING)
+	unsigned int nr_pcpus = 2;
+#else
+	unsigned int nr_pcpus = num_possible_cpus();
+#endif
+
+	nr_pcpus = min_t(unsigned int, nr_pcpus, 32UL);
+	size = roundup_pow_of_two(nr_pcpus * ht->p.locks_mul);
+
+	/* Never allocate more than 0.5 locks per bucket */
+	size = min_t(unsigned int, size, tbl->size >> 1);
+
+	if (sizeof(spinlock_t) != 0) {
+#ifdef CONFIG_NUMA
+		if (size * sizeof(spinlock_t) > PAGE_SIZE &&
+		    gfp == GFP_KERNEL)
+			tbl->locks = vmalloc(size * sizeof(spinlock_t));
+		else
+#endif
+		tbl->locks = kmalloc_array(size, sizeof(spinlock_t),
+					   gfp);
+		if (!tbl->locks)
+			return -ENOMEM;
+		for (i = 0; i < size; i++)
+			spin_lock_init(&tbl->locks[i]);
+	}
+	tbl->locks_mask = size - 1;
+
+	return 0;
+}
+
+static void bucket_table_free(const struct bucket_table *tbl)
+{
+	if (tbl)
+		kvfree(tbl->locks);
+
+	kvfree(tbl);
+}
+
+static void bucket_table_free_rcu(struct rcu_head *head)
+{
+	bucket_table_free(container_of(head, struct bucket_table, rcu));
+}
+
+static struct bucket_table *bucket_table_alloc(struct rhashtable *ht,
+					       size_t nbuckets,
+					       gfp_t gfp)
+{
+	struct bucket_table *tbl = NULL;
+	size_t size;
+	int i;
+
+	size = sizeof(*tbl) + nbuckets * sizeof(tbl->buckets[0]);
+	if (size <= (PAGE_SIZE << PAGE_ALLOC_COSTLY_ORDER) ||
+	    gfp != GFP_KERNEL)
+		tbl = kzalloc(size, gfp | __GFP_NOWARN | __GFP_NORETRY);
+	if (tbl == NULL && gfp == GFP_KERNEL)
+		tbl = vzalloc(size);
+	if (tbl == NULL)
+		return NULL;
+
+	tbl->size = nbuckets;
+
+	if (alloc_bucket_locks(ht, tbl, gfp) < 0) {
+		bucket_table_free(tbl);
+		return NULL;
+	}
+
+	INIT_LIST_HEAD(&tbl->walkers);
+
+	get_random_bytes(&tbl->hash_rnd, sizeof(tbl->hash_rnd));
+
+	for (i = 0; i < nbuckets; i++)
+		INIT_RHT_NULLS_HEAD(tbl->buckets[i], ht, i);
+
+	return tbl;
+}
+
+static struct bucket_table *rhashtable_last_table(struct rhashtable *ht,
+						  struct bucket_table *tbl)
+{
+	struct bucket_table *new_tbl;
+
+	do {
+		new_tbl = tbl;
+		tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	} while (tbl);
+
+	return new_tbl;
+}
+
+static int rhashtable_rehash_one(struct rhashtable *ht, unsigned int old_hash)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	struct bucket_table *new_tbl = rhashtable_last_table(ht,
+		rht_dereference_rcu(old_tbl->future_tbl, ht));
+	struct rhash_head __rcu **pprev = &old_tbl->buckets[old_hash];
+	int err = -ENOENT;
+	struct rhash_head *head, *next, *entry;
+	spinlock_t *new_bucket_lock;
+	unsigned int new_hash;
+
+	rht_for_each(entry, old_tbl, old_hash) {
+		err = 0;
+		next = rht_dereference_bucket(entry->next, old_tbl, old_hash);
+
+		if (rht_is_a_nulls(next))
+			break;
+
+		pprev = &entry->next;
+	}
+
+	if (err)
+		goto out;
+
+	new_hash = head_hashfn(ht, new_tbl, entry);
+
+	new_bucket_lock = rht_bucket_lock(new_tbl, new_hash);
+
+	spin_lock_nested(new_bucket_lock, SINGLE_DEPTH_NESTING);
+	head = rht_dereference_bucket(new_tbl->buckets[new_hash],
+				      new_tbl, new_hash);
+
+	RCU_INIT_POINTER(entry->next, head);
+
+	rcu_assign_pointer(new_tbl->buckets[new_hash], entry);
+	spin_unlock(new_bucket_lock);
+
+	rcu_assign_pointer(*pprev, next);
+
+out:
+	return err;
+}
+
+static void rhashtable_rehash_chain(struct rhashtable *ht,
+				    unsigned int old_hash)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	spinlock_t *old_bucket_lock;
+
+	old_bucket_lock = rht_bucket_lock(old_tbl, old_hash);
+
+	spin_lock_bh(old_bucket_lock);
+	while (!rhashtable_rehash_one(ht, old_hash))
+		;
+	old_tbl->rehash++;
+	spin_unlock_bh(old_bucket_lock);
+}
+
+static int rhashtable_rehash_attach(struct rhashtable *ht,
+				    struct bucket_table *old_tbl,
+				    struct bucket_table *new_tbl)
+{
+	/* Protect future_tbl using the first bucket lock. */
+	spin_lock_bh(old_tbl->locks);
+
+	/* Did somebody beat us to it? */
+	if (rcu_access_pointer(old_tbl->future_tbl)) {
+		spin_unlock_bh(old_tbl->locks);
+		return -EEXIST;
+	}
+
+	/* Make insertions go into the new, empty table right away. Deletions
+	 * and lookups will be attempted in both tables until we synchronize.
+	 */
+	rcu_assign_pointer(old_tbl->future_tbl, new_tbl);
+
+	/* Ensure the new table is visible to readers. */
+	smp_wmb();
+
+	spin_unlock_bh(old_tbl->locks);
+
+	return 0;
+}
+
+static int rhashtable_rehash_table(struct rhashtable *ht)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	struct bucket_table *new_tbl;
+	struct rhashtable_walker *walker;
+	unsigned int old_hash;
+
+	new_tbl = rht_dereference(old_tbl->future_tbl, ht);
+	if (!new_tbl)
+		return 0;
+
+	for (old_hash = 0; old_hash < old_tbl->size; old_hash++)
+		rhashtable_rehash_chain(ht, old_hash);
+
+	/* Publish the new table pointer. */
+	rcu_assign_pointer(ht->tbl, new_tbl);
+
+	spin_lock(&ht->lock);
+	list_for_each_entry(walker, &old_tbl->walkers, list)
+		walker->tbl = NULL;
+	spin_unlock(&ht->lock);
+
+	/* Wait for readers. All new readers will see the new
+	 * table, and thus no references to the old table will
+	 * remain.
+	 */
+	call_rcu(&old_tbl->rcu, bucket_table_free_rcu);
+
+	return rht_dereference(new_tbl->future_tbl, ht) ? -EAGAIN : 0;
+}
+
+/**
+ * rhashtable_expand - Expand hash table while allowing concurrent lookups
+ * @ht:		the hash table to expand
+ *
+ * A secondary bucket array is allocated and the hash entries are migrated.
+ *
+ * This function may only be called in a context where it is safe to call
+ * synchronize_rcu(), e.g. not within a rcu_read_lock() section.
+ *
+ * The caller must ensure that no concurrent resizing occurs by holding
+ * ht->mutex.
+ *
+ * It is valid to have concurrent insertions and deletions protected by per
+ * bucket locks or concurrent RCU protected lookups and traversals.
+ */
+static int rhashtable_expand(struct rhashtable *ht)
+{
+	struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht);
+	int err;
+
+	ASSERT_RHT_MUTEX(ht);
+
+	old_tbl = rhashtable_last_table(ht, old_tbl);
+
+	new_tbl = bucket_table_alloc(ht, old_tbl->size * 2, GFP_KERNEL);
+	if (new_tbl == NULL)
+		return -ENOMEM;
+
+	err = rhashtable_rehash_attach(ht, old_tbl, new_tbl);
+	if (err)
+		bucket_table_free(new_tbl);
+
+	return err;
+}
+
+/**
+ * rhashtable_shrink - Shrink hash table while allowing concurrent lookups
+ * @ht:		the hash table to shrink
+ *
+ * This function shrinks the hash table to fit, i.e., the smallest
+ * size would not cause it to expand right away automatically.
+ *
+ * The caller must ensure that no concurrent resizing occurs by holding
+ * ht->mutex.
+ *
+ * The caller must ensure that no concurrent table mutations take place.
+ * It is however valid to have concurrent lookups if they are RCU protected.
+ *
+ * It is valid to have concurrent insertions and deletions protected by per
+ * bucket locks or concurrent RCU protected lookups and traversals.
+ */
+static int rhashtable_shrink(struct rhashtable *ht)
+{
+	struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht);
+	unsigned int size;
+	int err;
+
+	ASSERT_RHT_MUTEX(ht);
+
+	size = roundup_pow_of_two(atomic_read(&ht->nelems) * 3 / 2);
+	if (size < ht->p.min_size)
+		size = ht->p.min_size;
+
+	if (old_tbl->size <= size)
+		return 0;
+
+	if (rht_dereference(old_tbl->future_tbl, ht))
+		return -EEXIST;
+
+	new_tbl = bucket_table_alloc(ht, size, GFP_KERNEL);
+	if (new_tbl == NULL)
+		return -ENOMEM;
+
+	err = rhashtable_rehash_attach(ht, old_tbl, new_tbl);
+	if (err)
+		bucket_table_free(new_tbl);
+
+	return err;
+}
+
+static void rht_deferred_worker(struct work_struct *work)
+{
+	struct rhashtable *ht;
+	struct bucket_table *tbl;
+	int err = 0;
+
+	ht = container_of(work, struct rhashtable, run_work);
+	mutex_lock(&ht->mutex);
+
+	tbl = rht_dereference(ht->tbl, ht);
+	tbl = rhashtable_last_table(ht, tbl);
+
+	if (rht_grow_above_75(ht, tbl))
+		rhashtable_expand(ht);
+	else if (ht->p.automatic_shrinking && rht_shrink_below_30(ht, tbl))
+		rhashtable_shrink(ht);
+
+	err = rhashtable_rehash_table(ht);
+
+	mutex_unlock(&ht->mutex);
+
+	if (err)
+		schedule_work(&ht->run_work);
+}
+
+static bool rhashtable_check_elasticity(struct rhashtable *ht,
+					struct bucket_table *tbl,
+					unsigned int hash)
+{
+	unsigned int elasticity = ht->elasticity;
+	struct rhash_head *head;
+
+	rht_for_each(head, tbl, hash)
+		if (!--elasticity)
+			return true;
+
+	return false;
+}
+
+int rhashtable_insert_rehash(struct rhashtable *ht,
+			     struct bucket_table *tbl)
+{
+	struct bucket_table *old_tbl;
+	struct bucket_table *new_tbl;
+	unsigned int size;
+	int err;
+
+	old_tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	size = tbl->size;
+
+	err = -EBUSY;
+
+	if (rht_grow_above_75(ht, tbl))
+		size *= 2;
+	/* Do not schedule more than one rehash */
+	else if (old_tbl != tbl)
+		goto fail;
+
+	err = -ENOMEM;
+
+	new_tbl = bucket_table_alloc(ht, size, GFP_ATOMIC);
+	if (new_tbl == NULL)
+		goto fail;
+
+	err = rhashtable_rehash_attach(ht, tbl, new_tbl);
+	if (err) {
+		bucket_table_free(new_tbl);
+		if (err == -EEXIST)
+			err = 0;
+	} else
+		schedule_work(&ht->run_work);
+
+	return err;
+
+fail:
+	/* Do not fail the insert if someone else did a rehash. */
+	if (likely(rcu_dereference_raw(tbl->future_tbl)))
+		return 0;
+
+	/* Schedule async rehash to retry allocation in process context. */
+	if (err == -ENOMEM)
+		schedule_work(&ht->run_work);
+
+	return err;
+}
+
+struct bucket_table *rhashtable_insert_slow(struct rhashtable *ht,
+					    const void *key,
+					    struct rhash_head *obj,
+					    struct bucket_table *tbl)
+{
+	struct rhash_head *head;
+	unsigned int hash;
+	int err;
+
+	tbl = rhashtable_last_table(ht, tbl);
+	hash = head_hashfn(ht, tbl, obj);
+	spin_lock_nested(rht_bucket_lock(tbl, hash), SINGLE_DEPTH_NESTING);
+
+	err = -EEXIST;
+	if (key && rhashtable_lookup_fast(ht, key, ht->p))
+		goto exit;
+
+	err = -E2BIG;
+	if (unlikely(rht_grow_above_max(ht, tbl)))
+		goto exit;
+
+	err = -EAGAIN;
+	if (rhashtable_check_elasticity(ht, tbl, hash) ||
+	    rht_grow_above_100(ht, tbl))
+		goto exit;
+
+	err = 0;
+
+	head = rht_dereference_bucket(tbl->buckets[hash], tbl, hash);
+
+	RCU_INIT_POINTER(obj->next, head);
+
+	rcu_assign_pointer(tbl->buckets[hash], obj);
+
+	atomic_inc(&ht->nelems);
+
+exit:
+	spin_unlock(rht_bucket_lock(tbl, hash));
+
+	if (err == 0)
+		return NULL;
+	else if (err == -EAGAIN)
+		return tbl;
+	else
+		return ERR_PTR(err);
+}
+
+/**
+ * rhashtable_walk_init - Initialise an iterator
+ * @ht:		Table to walk over
+ * @iter:	Hash table Iterator
+ *
+ * This function prepares a hash table walk.
+ *
+ * Note that if you restart a walk after rhashtable_walk_stop you
+ * may see the same object twice.  Also, you may miss objects if
+ * there are removals in between rhashtable_walk_stop and the next
+ * call to rhashtable_walk_start.
+ *
+ * For a completely stable walk you should construct your own data
+ * structure outside the hash table.
+ *
+ * This function may sleep so you must not call it from interrupt
+ * context or with spin locks held.
+ *
+ * You must call rhashtable_walk_exit if this function returns
+ * successfully.
+ */
+int rhashtable_walk_init(struct rhashtable *ht, struct rhashtable_iter *iter)
+{
+	iter->ht = ht;
+	iter->p = NULL;
+	iter->slot = 0;
+	iter->skip = 0;
+
+	iter->walker = kmalloc(sizeof(*iter->walker), GFP_KERNEL);
+	if (!iter->walker)
+		return -ENOMEM;
+
+	spin_lock(&ht->lock);
+	iter->walker->tbl =
+		rcu_dereference_protected(ht->tbl, lockdep_is_held(&ht->lock));
+	list_add(&iter->walker->list, &iter->walker->tbl->walkers);
+	spin_unlock(&ht->lock);
+
+	return 0;
+}
+
+/**
+ * rhashtable_walk_exit - Free an iterator
+ * @iter:	Hash table Iterator
+ *
+ * This function frees resources allocated by rhashtable_walk_init.
+ */
+void rhashtable_walk_exit(struct rhashtable_iter *iter)
+{
+	spin_lock(&iter->ht->lock);
+	if (iter->walker->tbl)
+		list_del(&iter->walker->list);
+	spin_unlock(&iter->ht->lock);
+	kfree(iter->walker);
+}
+
+/**
+ * rhashtable_walk_start - Start a hash table walk
+ * @iter:	Hash table iterator
+ *
+ * Start a hash table walk.  Note that we take the RCU lock in all
+ * cases including when we return an error.  So you must always call
+ * rhashtable_walk_stop to clean up.
+ *
+ * Returns zero if successful.
+ *
+ * Returns -EAGAIN if resize event occured.  Note that the iterator
+ * will rewind back to the beginning and you may use it immediately
+ * by calling rhashtable_walk_next.
+ */
+int rhashtable_walk_start(struct rhashtable_iter *iter)
+	__acquires(RCU)
+{
+	struct rhashtable *ht = iter->ht;
+
+	rcu_read_lock();
+
+	spin_lock(&ht->lock);
+	if (iter->walker->tbl)
+		list_del(&iter->walker->list);
+	spin_unlock(&ht->lock);
+
+	if (!iter->walker->tbl) {
+		iter->walker->tbl = rht_dereference_rcu(ht->tbl, ht);
+		return -EAGAIN;
+	}
+
+	return 0;
+}
+
+/**
+ * rhashtable_walk_next - Return the next object and advance the iterator
+ * @iter:	Hash table iterator
+ *
+ * Note that you must call rhashtable_walk_stop when you are finished
+ * with the walk.
+ *
+ * Returns the next object or NULL when the end of the table is reached.
+ *
+ * Returns -EAGAIN if resize event occured.  Note that the iterator
+ * will rewind back to the beginning and you may continue to use it.
+ */
+void *rhashtable_walk_next(struct rhashtable_iter *iter)
+{
+	struct bucket_table *tbl = iter->walker->tbl;
+	struct rhashtable *ht = iter->ht;
+	struct rhash_head *p = iter->p;
+
+	if (p) {
+		p = rht_dereference_bucket_rcu(p->next, tbl, iter->slot);
+		goto next;
+	}
+
+	for (; iter->slot < tbl->size; iter->slot++) {
+		int skip = iter->skip;
+
+		rht_for_each_rcu(p, tbl, iter->slot) {
+			if (!skip)
+				break;
+			skip--;
+		}
+
+next:
+		if (!rht_is_a_nulls(p)) {
+			iter->skip++;
+			iter->p = p;
+			return rht_obj(ht, p);
+		}
+
+		iter->skip = 0;
+	}
+
+	iter->p = NULL;
+
+	/* Ensure we see any new tables. */
+	smp_rmb();
+
+	iter->walker->tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (iter->walker->tbl) {
+		iter->slot = 0;
+		iter->skip = 0;
+		return ERR_PTR(-EAGAIN);
+	}
+
+	return NULL;
+}
+
+/**
+ * rhashtable_walk_stop - Finish a hash table walk
+ * @iter:	Hash table iterator
+ *
+ * Finish a hash table walk.
+ */
+void rhashtable_walk_stop(struct rhashtable_iter *iter)
+	__releases(RCU)
+{
+	struct rhashtable *ht;
+	struct bucket_table *tbl = iter->walker->tbl;
+
+	if (!tbl)
+		goto out;
+
+	ht = iter->ht;
+
+	spin_lock(&ht->lock);
+	if (tbl->rehash < tbl->size)
+		list_add(&iter->walker->list, &tbl->walkers);
+	else
+		iter->walker->tbl = NULL;
+	spin_unlock(&ht->lock);
+
+	iter->p = NULL;
+
+out:
+	rcu_read_unlock();
+}
+
+static size_t rounded_hashtable_size(const struct rhashtable_params *params)
+{
+	return max(roundup_pow_of_two(params->nelem_hint * 4 / 3),
+		   (unsigned long)params->min_size);
+}
+
+static u32 rhashtable_jhash2(const void *key, u32 length, u32 seed)
+{
+	return jhash2(key, length, seed);
+}
+
+/**
+ * rhashtable_init - initialize a new hash table
+ * @ht:		hash table to be initialized
+ * @params:	configuration parameters
+ *
+ * Initializes a new hash table based on the provided configuration
+ * parameters. A table can be configured either with a variable or
+ * fixed length key:
+ *
+ * Configuration Example 1: Fixed length keys
+ * struct test_obj {
+ *	int			key;
+ *	void *			my_member;
+ *	struct rhash_head	node;
+ * };
+ *
+ * struct rhashtable_params params = {
+ *	.head_offset = offsetof(struct test_obj, node),
+ *	.key_offset = offsetof(struct test_obj, key),
+ *	.key_len = sizeof(int),
+ *	.hashfn = jhash,
+ *	.nulls_base = (1U << RHT_BASE_SHIFT),
+ * };
+ *
+ * Configuration Example 2: Variable length keys
+ * struct test_obj {
+ *	[...]
+ *	struct rhash_head	node;
+ * };
+ *
+ * u32 my_hash_fn(const void *data, u32 len, u32 seed)
+ * {
+ *	struct test_obj *obj = data;
+ *
+ *	return [... hash ...];
+ * }
+ *
+ * struct rhashtable_params params = {
+ *	.head_offset = offsetof(struct test_obj, node),
+ *	.hashfn = jhash,
+ *	.obj_hashfn = my_hash_fn,
+ * };
+ */
+int rhashtable_init(struct rhashtable *ht,
+		    const struct rhashtable_params *params)
+{
+	struct bucket_table *tbl;
+	size_t size;
+
+	size = HASH_DEFAULT_SIZE;
+
+	if ((!params->key_len && !params->obj_hashfn) ||
+	    (params->obj_hashfn && !params->obj_cmpfn))
+		return -EINVAL;
+
+	if (params->nulls_base && params->nulls_base < (1U << RHT_BASE_SHIFT))
+		return -EINVAL;
+
+	memset(ht, 0, sizeof(*ht));
+	mutex_init(&ht->mutex);
+	spin_lock_init(&ht->lock);
+	memcpy(&ht->p, params, sizeof(*params));
+
+	if (params->min_size)
+		ht->p.min_size = roundup_pow_of_two(params->min_size);
+
+	if (params->max_size)
+		ht->p.max_size = rounddown_pow_of_two(params->max_size);
+
+	if (params->insecure_max_entries)
+		ht->p.insecure_max_entries =
+			rounddown_pow_of_two(params->insecure_max_entries);
+	else
+		ht->p.insecure_max_entries = ht->p.max_size * 2;
+
+	ht->p.min_size = max(ht->p.min_size, HASH_MIN_SIZE);
+
+	if (params->nelem_hint)
+		size = rounded_hashtable_size(&ht->p);
+
+	/* The maximum (not average) chain length grows with the
+	 * size of the hash table, at a rate of (log N)/(log log N).
+	 * The value of 16 is selected so that even if the hash
+	 * table grew to 2^32 you would not expect the maximum
+	 * chain length to exceed it unless we are under attack
+	 * (or extremely unlucky).
+	 *
+	 * As this limit is only to detect attacks, we don't need
+	 * to set it to a lower value as you'd need the chain
+	 * length to vastly exceed 16 to have any real effect
+	 * on the system.
+	 */
+	if (!params->insecure_elasticity)
+		ht->elasticity = 16;
+
+	if (params->locks_mul)
+		ht->p.locks_mul = roundup_pow_of_two(params->locks_mul);
+	else
+		ht->p.locks_mul = BUCKET_LOCKS_PER_CPU;
+
+	ht->key_len = ht->p.key_len;
+	if (!params->hashfn) {
+		ht->p.hashfn = jhash;
+
+		if (!(ht->key_len & (sizeof(u32) - 1))) {
+			ht->key_len /= sizeof(u32);
+			ht->p.hashfn = rhashtable_jhash2;
+		}
+	}
+
+	tbl = bucket_table_alloc(ht, size, GFP_KERNEL);
+	if (tbl == NULL)
+		return -ENOMEM;
+
+	atomic_set(&ht->nelems, 0);
+
+	RCU_INIT_POINTER(ht->tbl, tbl);
+
+	INIT_WORK(&ht->run_work, rht_deferred_worker);
+
+	return 0;
+}
+
+/**
+ * rhashtable_free_and_destroy - free elements and destroy hash table
+ * @ht:		the hash table to destroy
+ * @free_fn:	callback to release resources of element
+ * @arg:	pointer passed to free_fn
+ *
+ * Stops an eventual async resize. If defined, invokes free_fn for each
+ * element to releasal resources. Please note that RCU protected
+ * readers may still be accessing the elements. Releasing of resources
+ * must occur in a compatible manner. Then frees the bucket array.
+ *
+ * This function will eventually sleep to wait for an async resize
+ * to complete. The caller is responsible that no further write operations
+ * occurs in parallel.
+ */
+void rhashtable_free_and_destroy(struct rhashtable *ht,
+				 void (*free_fn)(void *ptr, void *arg),
+				 void *arg)
+{
+	const struct bucket_table *tbl;
+	unsigned int i;
+
+	cancel_work_sync(&ht->run_work);
+
+	mutex_lock(&ht->mutex);
+	tbl = rht_dereference(ht->tbl, ht);
+	if (free_fn) {
+		for (i = 0; i < tbl->size; i++) {
+			struct rhash_head *pos, *next;
+
+			for (pos = rht_dereference(tbl->buckets[i], ht),
+			     next = !rht_is_a_nulls(pos) ?
+					rht_dereference(pos->next, ht) : NULL;
+			     !rht_is_a_nulls(pos);
+			     pos = next,
+			     next = !rht_is_a_nulls(pos) ?
+					rht_dereference(pos->next, ht) : NULL)
+				free_fn(rht_obj(ht, pos), arg);
+		}
+	}
+
+	bucket_table_free(tbl);
+	mutex_unlock(&ht->mutex);
+}
+
+void rhashtable_destroy(struct rhashtable *ht)
+{
+	return rhashtable_free_and_destroy(ht, NULL, NULL);
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rhashtable.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rhashtable.h
new file mode 100644
index 000000000000..a6db3257bc48
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rhashtable.h
@@ -0,0 +1,827 @@
+/*
+ * Resizable, Scalable, Concurrent Hash Table
+ *
+ * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au>
+ * Copyright (c) 2014-2015 Thomas Graf <tgraf@suug.ch>
+ * Copyright (c) 2008-2014 Patrick McHardy <kaber@trash.net>
+ *
+ * Code partially derived from nft_hash
+ * Rewritten with rehash code from br_multicast plus single list
+ * pointer as suggested by Josh Triplett
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#ifndef _LINUX_RHASHTABLE_H
+#define _LINUX_RHASHTABLE_H
+
+#include <linux/atomic.h>
+#include <linux/compiler.h>
+#include <linux/err.h>
+#include <linux/errno.h>
+#include <linux/jhash.h>
+#include <linux/list_nulls.h>
+#include <linux/workqueue.h>
+#include <linux/mutex.h>
+#include <linux/rcupdate.h>
+
+/*
+ * The end of the chain is marked with a special nulls marks which has
+ * the following format:
+ *
+ * +-------+-----------------------------------------------------+-+
+ * | Base  |                      Hash                           |1|
+ * +-------+-----------------------------------------------------+-+
+ *
+ * Base (4 bits) : Reserved to distinguish between multiple tables.
+ *                 Specified via &struct rhashtable_params.nulls_base.
+ * Hash (27 bits): Full hash (unmasked) of first element added to bucket
+ * 1 (1 bit)     : Nulls marker (always set)
+ *
+ * The remaining bits of the next pointer remain unused for now.
+ */
+#define RHT_BASE_BITS		4
+#define RHT_HASH_BITS		27
+#define RHT_BASE_SHIFT		RHT_HASH_BITS
+
+/* Base bits plus 1 bit for nulls marker */
+#define RHT_HASH_RESERVED_SPACE	(RHT_BASE_BITS + 1)
+
+struct rhash_head {
+	struct rhash_head __rcu		*next;
+};
+
+/**
+ * struct bucket_table - Table of hash buckets
+ * @size: Number of hash buckets
+ * @rehash: Current bucket being rehashed
+ * @hash_rnd: Random seed to fold into hash
+ * @locks_mask: Mask to apply before accessing locks[]
+ * @locks: Array of spinlocks protecting individual buckets
+ * @walkers: List of active walkers
+ * @rcu: RCU structure for freeing the table
+ * @future_tbl: Table under construction during rehashing
+ * @buckets: size * hash buckets
+ */
+struct bucket_table {
+	unsigned int		size;
+	unsigned int		rehash;
+	u32			hash_rnd;
+	unsigned int		locks_mask;
+	spinlock_t		*locks;
+	struct list_head	walkers;
+	struct rcu_head		rcu;
+
+	struct bucket_table __rcu *future_tbl;
+
+	struct rhash_head __rcu	*buckets[] ____cacheline_aligned_in_smp;
+};
+
+/**
+ * struct rhashtable_compare_arg - Key for the function rhashtable_compare
+ * @ht: Hash table
+ * @key: Key to compare against
+ */
+struct rhashtable_compare_arg {
+	struct rhashtable *ht;
+	const void *key;
+};
+
+typedef u32 (*rht_hashfn_t)(const void *data, u32 len, u32 seed);
+typedef u32 (*rht_obj_hashfn_t)(const void *data, u32 len, u32 seed);
+typedef int (*rht_obj_cmpfn_t)(struct rhashtable_compare_arg *arg,
+			       const void *obj);
+
+struct rhashtable;
+
+/**
+ * struct rhashtable_params - Hash table construction parameters
+ * @nelem_hint: Hint on number of elements, should be 75% of desired size
+ * @key_len: Length of key
+ * @key_offset: Offset of key in struct to be hashed
+ * @head_offset: Offset of rhash_head in struct to be hashed
+ * @insecure_max_entries: Maximum number of entries (may be exceeded)
+ * @max_size: Maximum size while expanding
+ * @min_size: Minimum size while shrinking
+ * @nulls_base: Base value to generate nulls marker
+ * @insecure_elasticity: Set to true to disable chain length checks
+ * @automatic_shrinking: Enable automatic shrinking of tables
+ * @locks_mul: Number of bucket locks to allocate per cpu (default: 128)
+ * @hashfn: Hash function (default: jhash2 if !(key_len % 4), or jhash)
+ * @obj_hashfn: Function to hash object
+ * @obj_cmpfn: Function to compare key with object
+ */
+struct rhashtable_params {
+	size_t			nelem_hint;
+	size_t			key_len;
+	size_t			key_offset;
+	size_t			head_offset;
+	unsigned int		insecure_max_entries;
+	unsigned int		max_size;
+	unsigned int		min_size;
+	u32			nulls_base;
+	bool			insecure_elasticity;
+	bool			automatic_shrinking;
+	size_t			locks_mul;
+	rht_hashfn_t		hashfn;
+	rht_obj_hashfn_t	obj_hashfn;
+	rht_obj_cmpfn_t		obj_cmpfn;
+};
+
+/**
+ * struct rhashtable - Hash table handle
+ * @tbl: Bucket table
+ * @nelems: Number of elements in table
+ * @key_len: Key length for hashfn
+ * @elasticity: Maximum chain length before rehash
+ * @p: Configuration parameters
+ * @run_work: Deferred worker to expand/shrink asynchronously
+ * @mutex: Mutex to protect current/future table swapping
+ * @lock: Spin lock to protect walker list
+ */
+struct rhashtable {
+	struct bucket_table __rcu	*tbl;
+	atomic_t			nelems;
+	unsigned int			key_len;
+	unsigned int			elasticity;
+	struct rhashtable_params	p;
+	struct work_struct		run_work;
+	struct mutex                    mutex;
+	spinlock_t			lock;
+};
+
+/**
+ * struct rhashtable_walker - Hash table walker
+ * @list: List entry on list of walkers
+ * @tbl: The table that we were walking over
+ */
+struct rhashtable_walker {
+	struct list_head list;
+	struct bucket_table *tbl;
+};
+
+/**
+ * struct rhashtable_iter - Hash table iterator, fits into netlink cb
+ * @ht: Table to iterate through
+ * @p: Current pointer
+ * @walker: Associated rhashtable walker
+ * @slot: Current slot
+ * @skip: Number of entries to skip in slot
+ */
+struct rhashtable_iter {
+	struct rhashtable *ht;
+	struct rhash_head *p;
+	struct rhashtable_walker *walker;
+	unsigned int slot;
+	unsigned int skip;
+};
+
+static inline unsigned long rht_marker(const struct rhashtable *ht, u32 hash)
+{
+	return NULLS_MARKER(ht->p.nulls_base + hash);
+}
+
+#define INIT_RHT_NULLS_HEAD(ptr, ht, hash) \
+	((ptr) = (typeof(ptr)) rht_marker(ht, hash))
+
+static inline bool rht_is_a_nulls(const struct rhash_head *ptr)
+{
+	return ((unsigned long) ptr & 1);
+}
+
+static inline unsigned long rht_get_nulls_value(const struct rhash_head *ptr)
+{
+	return ((unsigned long) ptr) >> 1;
+}
+
+static inline void *rht_obj(const struct rhashtable *ht,
+			    const struct rhash_head *he)
+{
+	return (char *)he - ht->p.head_offset;
+}
+
+static inline unsigned int rht_bucket_index(const struct bucket_table *tbl,
+					    unsigned int hash)
+{
+	return (hash >> RHT_HASH_RESERVED_SPACE) & (tbl->size - 1);
+}
+
+static inline unsigned int rht_key_hashfn(
+	struct rhashtable *ht, const struct bucket_table *tbl,
+	const void *key, const struct rhashtable_params params)
+{
+	unsigned int hash;
+
+	/* params must be equal to ht->p if it isn't constant. */
+	if (!__builtin_constant_p(params.key_len))
+		hash = ht->p.hashfn(key, ht->key_len, tbl->hash_rnd);
+	else if (params.key_len) {
+		unsigned int key_len = params.key_len;
+
+		if (params.hashfn)
+			hash = params.hashfn(key, key_len, tbl->hash_rnd);
+		else if (key_len & (sizeof(u32) - 1))
+			hash = jhash(key, key_len, tbl->hash_rnd);
+		else
+			hash = jhash2(key, key_len / sizeof(u32),
+				      tbl->hash_rnd);
+	} else {
+		unsigned int key_len = ht->p.key_len;
+
+		if (params.hashfn)
+			hash = params.hashfn(key, key_len, tbl->hash_rnd);
+		else
+			hash = jhash(key, key_len, tbl->hash_rnd);
+	}
+
+	return rht_bucket_index(tbl, hash);
+}
+
+static inline unsigned int rht_head_hashfn(
+	struct rhashtable *ht, const struct bucket_table *tbl,
+	const struct rhash_head *he, const struct rhashtable_params params)
+{
+	const char *ptr = rht_obj(ht, he);
+
+	return likely(params.obj_hashfn) ?
+	       rht_bucket_index(tbl, params.obj_hashfn(ptr, params.key_len ?:
+							    ht->p.key_len,
+						       tbl->hash_rnd)) :
+	       rht_key_hashfn(ht, tbl, ptr + params.key_offset, params);
+}
+
+/**
+ * rht_grow_above_75 - returns true if nelems > 0.75 * table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_75(const struct rhashtable *ht,
+				     const struct bucket_table *tbl)
+{
+	/* Expand table when exceeding 75% load */
+	return atomic_read(&ht->nelems) > (tbl->size / 4 * 3) &&
+	       (!ht->p.max_size || tbl->size < ht->p.max_size);
+}
+
+/**
+ * rht_shrink_below_30 - returns true if nelems < 0.3 * table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_shrink_below_30(const struct rhashtable *ht,
+				       const struct bucket_table *tbl)
+{
+	/* Shrink table beneath 30% load */
+	return atomic_read(&ht->nelems) < (tbl->size * 3 / 10) &&
+	       tbl->size > ht->p.min_size;
+}
+
+/**
+ * rht_grow_above_100 - returns true if nelems > table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_100(const struct rhashtable *ht,
+				      const struct bucket_table *tbl)
+{
+	return atomic_read(&ht->nelems) > tbl->size &&
+		(!ht->p.max_size || tbl->size < ht->p.max_size);
+}
+
+/**
+ * rht_grow_above_max - returns true if table is above maximum
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_max(const struct rhashtable *ht,
+				      const struct bucket_table *tbl)
+{
+	return ht->p.insecure_max_entries &&
+	       atomic_read(&ht->nelems) >= ht->p.insecure_max_entries;
+}
+
+/* The bucket lock is selected based on the hash and protects mutations
+ * on a group of hash buckets.
+ *
+ * A maximum of tbl->size/2 bucket locks is allocated. This ensures that
+ * a single lock always covers both buckets which may both contains
+ * entries which link to the same bucket of the old table during resizing.
+ * This allows to simplify the locking as locking the bucket in both
+ * tables during resize always guarantee protection.
+ *
+ * IMPORTANT: When holding the bucket lock of both the old and new table
+ * during expansions and shrinking, the old bucket lock must always be
+ * acquired first.
+ */
+static inline spinlock_t *rht_bucket_lock(const struct bucket_table *tbl,
+					  unsigned int hash)
+{
+	return &tbl->locks[hash & tbl->locks_mask];
+}
+
+#ifdef CONFIG_PROVE_LOCKING
+int lockdep_rht_mutex_is_held(struct rhashtable *ht);
+int lockdep_rht_bucket_is_held(const struct bucket_table *tbl, u32 hash);
+#else
+static inline int lockdep_rht_mutex_is_held(struct rhashtable *ht)
+{
+	return 1;
+}
+
+static inline int lockdep_rht_bucket_is_held(const struct bucket_table *tbl,
+					     u32 hash)
+{
+	return 1;
+}
+#endif /* CONFIG_PROVE_LOCKING */
+
+int rhashtable_init(struct rhashtable *ht,
+		    const struct rhashtable_params *params);
+
+struct bucket_table *rhashtable_insert_slow(struct rhashtable *ht,
+					    const void *key,
+					    struct rhash_head *obj,
+					    struct bucket_table *old_tbl);
+int rhashtable_insert_rehash(struct rhashtable *ht, struct bucket_table *tbl);
+
+int rhashtable_walk_init(struct rhashtable *ht, struct rhashtable_iter *iter);
+void rhashtable_walk_exit(struct rhashtable_iter *iter);
+int rhashtable_walk_start(struct rhashtable_iter *iter) __acquires(RCU);
+void *rhashtable_walk_next(struct rhashtable_iter *iter);
+void rhashtable_walk_stop(struct rhashtable_iter *iter) __releases(RCU);
+
+void rhashtable_free_and_destroy(struct rhashtable *ht,
+				 void (*free_fn)(void *ptr, void *arg),
+				 void *arg);
+void rhashtable_destroy(struct rhashtable *ht);
+
+#define rht_dereference(p, ht) \
+	rcu_dereference_protected(p, lockdep_rht_mutex_is_held(ht))
+
+#define rht_dereference_rcu(p, ht) \
+	rcu_dereference_check(p, lockdep_rht_mutex_is_held(ht))
+
+#define rht_dereference_bucket(p, tbl, hash) \
+	rcu_dereference_protected(p, lockdep_rht_bucket_is_held(tbl, hash))
+
+#define rht_dereference_bucket_rcu(p, tbl, hash) \
+	rcu_dereference_check(p, lockdep_rht_bucket_is_held(tbl, hash))
+
+#define rht_entry(tpos, pos, member) \
+	({ tpos = container_of(pos, typeof(*tpos), member); 1; })
+
+/**
+ * rht_for_each_continue - continue iterating over hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ */
+#define rht_for_each_continue(pos, head, tbl, hash) \
+	for (pos = rht_dereference_bucket(head, tbl, hash); \
+	     !rht_is_a_nulls(pos); \
+	     pos = rht_dereference_bucket((pos)->next, tbl, hash))
+
+/**
+ * rht_for_each - iterate over hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ */
+#define rht_for_each(pos, tbl, hash) \
+	rht_for_each_continue(pos, (tbl)->buckets[hash], tbl, hash)
+
+/**
+ * rht_for_each_entry_continue - continue iterating over hash chain
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ */
+#define rht_for_each_entry_continue(tpos, pos, head, tbl, hash, member)	\
+	for (pos = rht_dereference_bucket(head, tbl, hash);		\
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	\
+	     pos = rht_dereference_bucket((pos)->next, tbl, hash))
+
+/**
+ * rht_for_each_entry - iterate over hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ */
+#define rht_for_each_entry(tpos, pos, tbl, hash, member)		\
+	rht_for_each_entry_continue(tpos, pos, (tbl)->buckets[hash],	\
+				    tbl, hash, member)
+
+/**
+ * rht_for_each_entry_safe - safely iterate over hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @next:	the &struct rhash_head to use as next in loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive allows for the looped code to
+ * remove the loop cursor from the list.
+ */
+#define rht_for_each_entry_safe(tpos, pos, next, tbl, hash, member)	    \
+	for (pos = rht_dereference_bucket((tbl)->buckets[hash], tbl, hash), \
+	     next = !rht_is_a_nulls(pos) ?				    \
+		       rht_dereference_bucket(pos->next, tbl, hash) : NULL; \
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	    \
+	     pos = next,						    \
+	     next = !rht_is_a_nulls(pos) ?				    \
+		       rht_dereference_bucket(pos->next, tbl, hash) : NULL)
+
+/**
+ * rht_for_each_rcu_continue - continue iterating over rcu hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_rcu_continue(pos, head, tbl, hash)			\
+	for (({barrier(); }),						\
+	     pos = rht_dereference_bucket_rcu(head, tbl, hash);		\
+	     !rht_is_a_nulls(pos);					\
+	     pos = rcu_dereference_raw(pos->next))
+
+/**
+ * rht_for_each_rcu - iterate over rcu hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_rcu(pos, tbl, hash)				\
+	rht_for_each_rcu_continue(pos, (tbl)->buckets[hash], tbl, hash)
+
+/**
+ * rht_for_each_entry_rcu_continue - continue iterating over rcu hash chain
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_entry_rcu_continue(tpos, pos, head, tbl, hash, member) \
+	for (({barrier(); }),						    \
+	     pos = rht_dereference_bucket_rcu(head, tbl, hash);		    \
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	    \
+	     pos = rht_dereference_bucket_rcu(pos->next, tbl, hash))
+
+/**
+ * rht_for_each_entry_rcu - iterate over rcu hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_entry_rcu(tpos, pos, tbl, hash, member)		\
+	rht_for_each_entry_rcu_continue(tpos, pos, (tbl)->buckets[hash],\
+					tbl, hash, member)
+
+static inline int rhashtable_compare(struct rhashtable_compare_arg *arg,
+				     const void *obj)
+{
+	struct rhashtable *ht = arg->ht;
+	const char *ptr = obj;
+
+	return memcmp(ptr + ht->p.key_offset, arg->key, ht->p.key_len);
+}
+
+/**
+ * rhashtable_lookup_fast - search hash table, inlined version
+ * @ht:		hash table
+ * @key:	the pointer to the key
+ * @params:	hash table parameters
+ *
+ * Computes the hash value for the key and traverses the bucket chain looking
+ * for a entry with an identical key. The first matching entry is returned.
+ *
+ * Returns the first entry on which the compare function returned true.
+ */
+static inline void *rhashtable_lookup_fast(
+	struct rhashtable *ht, const void *key,
+	const struct rhashtable_params params)
+{
+	struct rhashtable_compare_arg arg = {
+		.ht = ht,
+		.key = key,
+	};
+	const struct bucket_table *tbl;
+	struct rhash_head *he;
+	unsigned int hash;
+
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+restart:
+	hash = rht_key_hashfn(ht, tbl, key, params);
+	rht_for_each_rcu(he, tbl, hash) {
+		if (params.obj_cmpfn ?
+		    params.obj_cmpfn(&arg, rht_obj(ht, he)) :
+		    rhashtable_compare(&arg, rht_obj(ht, he)))
+			continue;
+		rcu_read_unlock();
+		return rht_obj(ht, he);
+	}
+
+	/* Ensure we see any new tables. */
+	smp_rmb();
+
+	tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (unlikely(tbl))
+		goto restart;
+	rcu_read_unlock();
+
+	return NULL;
+}
+
+/* Internal function, please use rhashtable_insert_fast() instead */
+static inline int __rhashtable_insert_fast(
+	struct rhashtable *ht, const void *key, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	struct rhashtable_compare_arg arg = {
+		.ht = ht,
+		.key = key,
+	};
+	struct bucket_table *tbl, *new_tbl;
+	struct rhash_head *head;
+	spinlock_t *lock;
+	unsigned int elasticity;
+	unsigned int hash;
+	int err;
+
+restart:
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	/* All insertions must grab the oldest table containing
+	 * the hashed bucket that is yet to be rehashed.
+	 */
+	for (;;) {
+		hash = rht_head_hashfn(ht, tbl, obj, params);
+		lock = rht_bucket_lock(tbl, hash);
+		spin_lock_bh(lock);
+
+		if (tbl->rehash <= hash)
+			break;
+
+		spin_unlock_bh(lock);
+		tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	}
+
+	new_tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (unlikely(new_tbl)) {
+		tbl = rhashtable_insert_slow(ht, key, obj, new_tbl);
+		if (!IS_ERR_OR_NULL(tbl))
+			goto slow_path;
+
+		err = PTR_ERR(tbl);
+		goto out;
+	}
+
+	err = -E2BIG;
+	if (unlikely(rht_grow_above_max(ht, tbl)))
+		goto out;
+
+	if (unlikely(rht_grow_above_100(ht, tbl))) {
+slow_path:
+		spin_unlock_bh(lock);
+		err = rhashtable_insert_rehash(ht, tbl);
+		rcu_read_unlock();
+		if (err)
+			return err;
+
+		goto restart;
+	}
+
+	err = -EEXIST;
+	elasticity = ht->elasticity;
+	rht_for_each(head, tbl, hash) {
+		if (key &&
+		    unlikely(!(params.obj_cmpfn ?
+			       params.obj_cmpfn(&arg, rht_obj(ht, head)) :
+			       rhashtable_compare(&arg, rht_obj(ht, head)))))
+			goto out;
+		if (!--elasticity)
+			goto slow_path;
+	}
+
+	err = 0;
+
+	head = rht_dereference_bucket(tbl->buckets[hash], tbl, hash);
+
+	RCU_INIT_POINTER(obj->next, head);
+
+	rcu_assign_pointer(tbl->buckets[hash], obj);
+
+	atomic_inc(&ht->nelems);
+	if (rht_grow_above_75(ht, tbl))
+		schedule_work(&ht->run_work);
+
+out:
+	spin_unlock_bh(lock);
+	rcu_read_unlock();
+
+	return err;
+}
+
+/**
+ * rhashtable_insert_fast - insert object into hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Will take a per bucket spinlock to protect against mutual mutations
+ * on the same bucket. Multiple insertions may occur in parallel unless
+ * they map to the same bucket lock.
+ *
+ * It is safe to call this function from atomic context.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ */
+static inline int rhashtable_insert_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	return __rhashtable_insert_fast(ht, NULL, obj, params);
+}
+
+/**
+ * rhashtable_lookup_insert_fast - lookup and insert object into hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Locks down the bucket chain in both the old and new table if a resize
+ * is in progress to ensure that writers can't remove from the old table
+ * and can't insert to the new table during the atomic operation of search
+ * and insertion. Searches for duplicates in both the old and new table if
+ * a resize is in progress.
+ *
+ * This lookup function may only be used for fixed key hash table (key_len
+ * parameter set). It will BUG() if used inappropriately.
+ *
+ * It is safe to call this function from atomic context.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ */
+static inline int rhashtable_lookup_insert_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	const char *key = rht_obj(ht, obj);
+
+	BUG_ON(ht->p.obj_hashfn);
+
+	return __rhashtable_insert_fast(ht, key + ht->p.key_offset, obj,
+					params);
+}
+
+/**
+ * rhashtable_lookup_insert_key - search and insert object to hash table
+ *				  with explicit key
+ * @ht:		hash table
+ * @key:	key
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Locks down the bucket chain in both the old and new table if a resize
+ * is in progress to ensure that writers can't remove from the old table
+ * and can't insert to the new table during the atomic operation of search
+ * and insertion. Searches for duplicates in both the old and new table if
+ * a resize is in progress.
+ *
+ * Lookups may occur in parallel with hashtable mutations and resizing.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ *
+ * Returns zero on success.
+ */
+static inline int rhashtable_lookup_insert_key(
+	struct rhashtable *ht, const void *key, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	BUG_ON(!ht->p.obj_hashfn || !key);
+
+	return __rhashtable_insert_fast(ht, key, obj, params);
+}
+
+/* Internal function, please use rhashtable_remove_fast() instead */
+static inline int __rhashtable_remove_fast(
+	struct rhashtable *ht, struct bucket_table *tbl,
+	struct rhash_head *obj, const struct rhashtable_params params)
+{
+	struct rhash_head __rcu **pprev;
+	struct rhash_head *he;
+	spinlock_t * lock;
+	unsigned int hash;
+	int err = -ENOENT;
+
+	hash = rht_head_hashfn(ht, tbl, obj, params);
+	lock = rht_bucket_lock(tbl, hash);
+
+	spin_lock_bh(lock);
+
+	pprev = &tbl->buckets[hash];
+	rht_for_each(he, tbl, hash) {
+		if (he != obj) {
+			pprev = &he->next;
+			continue;
+		}
+
+		rcu_assign_pointer(*pprev, obj->next);
+		err = 0;
+		break;
+	}
+
+	spin_unlock_bh(lock);
+
+	return err;
+}
+
+/**
+ * rhashtable_remove_fast - remove object from hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Since the hash chain is single linked, the removal operation needs to
+ * walk the bucket chain upon removal. The removal operation is thus
+ * considerable slow if the hash table is not correctly sized.
+ *
+ * Will automatically shrink the table via rhashtable_expand() if the
+ * shrink_decision function specified at rhashtable_init() returns true.
+ *
+ * Returns zero on success, -ENOENT if the entry could not be found.
+ */
+static inline int rhashtable_remove_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	struct bucket_table *tbl;
+	int err;
+
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	/* Because we have already taken (and released) the bucket
+	 * lock in old_tbl, if we find that future_tbl is not yet
+	 * visible then that guarantees the entry to still be in
+	 * the old tbl if it exists.
+	 */
+	while ((err = __rhashtable_remove_fast(ht, tbl, obj, params)) &&
+	       (tbl = rht_dereference_rcu(tbl->future_tbl, ht)))
+		;
+
+	if (err)
+		goto out;
+
+	atomic_dec(&ht->nelems);
+	if (unlikely(ht->p.automatic_shrinking &&
+		     rht_shrink_below_30(ht, tbl)))
+		schedule_work(&ht->run_work);
+
+out:
+	rcu_read_unlock();
+
+	return err;
+}
+
+#endif /* _LINUX_RHASHTABLE_H */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_android.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_android.c
new file mode 100644
index 000000000000..b8b43772ddd3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_android.c
@@ -0,0 +1,1320 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#ifdef CONFIG_GPIO_WAKEUP
+#include <linux/gpio.h>
+#endif
+
+#include <drv_types.h>
+
+#if defined(RTW_ENABLE_WIFI_CONTROL_FUNC)
+#include <linux/platform_device.h>
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	#include <linux/wlan_plat.h>
+#else
+	#include <linux/wifi_tiwlan.h>
+#endif
+#endif /* defined(RTW_ENABLE_WIFI_CONTROL_FUNC) */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 0, 0))
+#define strnicmp	strncasecmp
+#endif /* Linux kernel >= 4.0.0 */
+
+#ifdef CONFIG_GPIO_WAKEUP
+#include <linux/interrupt.h>
+#include <linux/irq.h>
+#endif
+
+#include "rtw_version.h"
+
+extern void macstr2num(u8 *dst, u8 *src);
+
+const char *android_wifi_cmd_str[ANDROID_WIFI_CMD_MAX] = {
+	"START",
+	"STOP",
+	"SCAN-ACTIVE",
+	"SCAN-PASSIVE",
+	"RSSI",
+	"LINKSPEED",
+	"RXFILTER-START",
+	"RXFILTER-STOP",
+	"RXFILTER-ADD",
+	"RXFILTER-REMOVE",
+	"BTCOEXSCAN-START",
+	"BTCOEXSCAN-STOP",
+	"BTCOEXMODE",
+	"SETSUSPENDOPT",
+	"P2P_DEV_ADDR",
+	"SETFWPATH",
+	"SETBAND",
+	"GETBAND",
+	"COUNTRY",
+	"P2P_SET_NOA",
+	"P2P_GET_NOA",
+	"P2P_SET_PS",
+	"SET_AP_WPS_P2P_IE",
+
+	"MIRACAST",
+
+#ifdef CONFIG_PNO_SUPPORT
+	"PNOSSIDCLR",
+	"PNOSETUP",
+	"PNOFORCE",
+	"PNODEBUG",
+#endif
+
+	"MACADDR",
+
+	"BLOCK_SCAN",
+	"BLOCK",
+	"WFD-ENABLE",
+	"WFD-DISABLE",
+	"WFD-SET-TCPPORT",
+	"WFD-SET-MAXTPUT",
+	"WFD-SET-DEVTYPE",
+	"SET_DTIM",
+	"HOSTAPD_SET_MACADDR_ACL",
+	"HOSTAPD_ACL_ADD_STA",
+	"HOSTAPD_ACL_REMOVE_STA",
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
+	"GTK_REKEY_OFFLOAD",
+#endif /* CONFIG_GTK_OL */
+/*	Private command for	P2P disable*/
+	"P2P_DISABLE",
+	"SET_AEK",
+	"DRIVER_VERSION"
+};
+
+#ifdef CONFIG_PNO_SUPPORT
+#define PNO_TLV_PREFIX			'S'
+#define PNO_TLV_VERSION			'1'
+#define PNO_TLV_SUBVERSION		'2'
+#define PNO_TLV_RESERVED		'0'
+#define PNO_TLV_TYPE_SSID_IE	'S'
+#define PNO_TLV_TYPE_TIME		'T'
+#define PNO_TLV_FREQ_REPEAT		'R'
+#define PNO_TLV_FREQ_EXPO_MAX	'M'
+
+typedef struct cmd_tlv {
+	char prefix;
+	char version;
+	char subver;
+	char reserved;
+} cmd_tlv_t;
+
+#ifdef CONFIG_PNO_SET_DEBUG
+char pno_in_example[] = {
+	'P', 'N', 'O', 'S', 'E', 'T', 'U', 'P', ' ',
+	'S', '1', '2', '0',
+	'S',	/* 1 */
+	0x05,
+	'd', 'l', 'i', 'n', 'k',
+	'S',	/* 2 */
+	0x06,
+	'B', 'U', 'F', 'B', 'U', 'F',
+	'S',	/* 3 */
+	0x20,
+	'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '!', '@', '#', '$', '%', '^',
+	'S',	/* 4 */
+	0x0a,
+	'!', '@', '#', '$', '%', '^', '&', '*', '(', ')',
+	'T',
+	'0', '5',
+	'R',
+	'2',
+	'M',
+	'2',
+	0x00
+};
+#endif /* CONFIG_PNO_SET_DEBUG */
+#endif /* PNO_SUPPORT */
+
+typedef struct android_wifi_priv_cmd {
+	char *buf;
+	int used_len;
+	int total_len;
+} android_wifi_priv_cmd;
+
+#ifdef CONFIG_COMPAT
+typedef struct compat_android_wifi_priv_cmd {
+	compat_uptr_t buf;
+	int used_len;
+	int total_len;
+} compat_android_wifi_priv_cmd;
+#endif /* CONFIG_COMPAT */
+
+/**
+ * Local (static) functions and variables
+ */
+
+/* Initialize g_wifi_on to 1 so dhd_bus_start will be called for the first
+ * time (only) in dhd_open, subsequential wifi on will be handled by
+ * wl_android_wifi_on
+ */
+static int g_wifi_on = _TRUE;
+
+unsigned int oob_irq = 0;
+unsigned int oob_gpio = 0;
+
+#ifdef CONFIG_PNO_SUPPORT
+/*
+ * rtw_android_pno_setup
+ * Description:
+ * This is used for private command.
+ *
+ * Parameter:
+ * net: net_device
+ * command: parameters from private command
+ * total_len: the length of the command.
+ *
+ * */
+static int rtw_android_pno_setup(struct net_device *net, char *command, int total_len)
+{
+	pno_ssid_t pno_ssids_local[MAX_PNO_LIST_COUNT];
+	int res = -1;
+	int nssid = 0;
+	cmd_tlv_t *cmd_tlv_temp;
+	char *str_ptr;
+	int tlv_size_left;
+	int pno_time = 0;
+	int pno_repeat = 0;
+	int pno_freq_expo_max = 0;
+	int cmdlen = strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_PNOSETUP_SET]) + 1;
+
+#ifdef CONFIG_PNO_SET_DEBUG
+	int i;
+	char *p;
+	p = pno_in_example;
+
+	total_len = sizeof(pno_in_example);
+	str_ptr = p + cmdlen;
+#else
+	str_ptr = command + cmdlen;
+#endif
+
+	if (total_len < (cmdlen + sizeof(cmd_tlv_t))) {
+		RTW_INFO("%s argument=%d less min size\n", __func__, total_len);
+		goto exit_proc;
+	}
+
+	tlv_size_left = total_len - cmdlen;
+
+	cmd_tlv_temp = (cmd_tlv_t *)str_ptr;
+	memset(pno_ssids_local, 0, sizeof(pno_ssids_local));
+
+	if ((cmd_tlv_temp->prefix == PNO_TLV_PREFIX) &&
+	    (cmd_tlv_temp->version == PNO_TLV_VERSION) &&
+	    (cmd_tlv_temp->subver == PNO_TLV_SUBVERSION)) {
+
+		str_ptr += sizeof(cmd_tlv_t);
+		tlv_size_left -= sizeof(cmd_tlv_t);
+
+		nssid = rtw_parse_ssid_list_tlv(&str_ptr, pno_ssids_local,
+			     MAX_PNO_LIST_COUNT, &tlv_size_left);
+		if (nssid <= 0) {
+			RTW_INFO("SSID is not presented or corrupted ret=%d\n", nssid);
+			goto exit_proc;
+		} else {
+			if ((str_ptr[0] != PNO_TLV_TYPE_TIME) || (tlv_size_left <= 1)) {
+				RTW_INFO("%s scan duration corrupted field size %d\n",
+					 __func__, tlv_size_left);
+				goto exit_proc;
+			}
+			str_ptr++;
+			pno_time = simple_strtoul(str_ptr, &str_ptr, 16);
+			RTW_INFO("%s: pno_time=%d\n", __func__, pno_time);
+
+			if (str_ptr[0] != 0) {
+				if ((str_ptr[0] != PNO_TLV_FREQ_REPEAT)) {
+					RTW_INFO("%s pno repeat : corrupted field\n",
+						 __func__);
+					goto exit_proc;
+				}
+				str_ptr++;
+				pno_repeat = simple_strtoul(str_ptr, &str_ptr, 16);
+				RTW_INFO("%s :got pno_repeat=%d\n", __FUNCTION__, pno_repeat);
+				if (str_ptr[0] != PNO_TLV_FREQ_EXPO_MAX) {
+					RTW_INFO("%s FREQ_EXPO_MAX corrupted field size\n",
+						 __func__);
+					goto exit_proc;
+				}
+				str_ptr++;
+				pno_freq_expo_max = simple_strtoul(str_ptr, &str_ptr, 16);
+				RTW_INFO("%s: pno_freq_expo_max=%d\n",
+					 __func__, pno_freq_expo_max);
+			}
+		}
+	} else {
+		RTW_INFO("%s get wrong TLV command\n", __FUNCTION__);
+		goto exit_proc;
+	}
+
+	res = rtw_dev_pno_set(net, pno_ssids_local, nssid, pno_time, pno_repeat, pno_freq_expo_max);
+
+#ifdef CONFIG_PNO_SET_DEBUG
+	rtw_dev_pno_debug(net);
+#endif
+
+exit_proc:
+	return res;
+}
+
+/*
+ * rtw_android_cfg80211_pno_setup
+ * Description:
+ * This is used for cfg80211 sched_scan.
+ *
+ * Parameter:
+ * net: net_device
+ * request: cfg80211_request
+ * */
+
+int rtw_android_cfg80211_pno_setup(struct net_device *net,
+		   struct cfg80211_ssid *ssids, int n_ssids, int interval)
+{
+	int res = -1;
+	int nssid = 0;
+	int pno_time = 0;
+	int pno_repeat = 0;
+	int pno_freq_expo_max = 0;
+	int index = 0;
+	pno_ssid_t pno_ssids_local[MAX_PNO_LIST_COUNT];
+
+	if (n_ssids > MAX_PNO_LIST_COUNT || n_ssids < 0) {
+		RTW_INFO("%s: nssids(%d) is invalid.\n", __func__, n_ssids);
+		return -EINVAL;
+	}
+
+	memset(pno_ssids_local, 0, sizeof(pno_ssids_local));
+
+	nssid = n_ssids;
+
+	for (index = 0 ; index < nssid ; index++) {
+		pno_ssids_local[index].SSID_len = ssids[index].ssid_len;
+		memcpy(pno_ssids_local[index].SSID, ssids[index].ssid,
+		       ssids[index].ssid_len);
+	}
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
+	if(ssids)
+		rtw_mfree((u8 *)ssids, (n_ssids * sizeof(struct cfg80211_ssid)));
+#endif
+	pno_time = (interval / 1000);
+
+	RTW_INFO("%s: nssids: %d, pno_time=%d\n", __func__, nssid, pno_time);
+
+	res = rtw_dev_pno_set(net, pno_ssids_local, nssid, pno_time,
+			      pno_repeat, pno_freq_expo_max);
+
+#ifdef CONFIG_PNO_SET_DEBUG
+	rtw_dev_pno_debug(net);
+#endif
+exit_proc:
+	return res;
+}
+
+int rtw_android_pno_enable(struct net_device *net, int pno_enable)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+
+	if (pwrctl) {
+		pwrctl->wowlan_pno_enable = pno_enable;
+		RTW_INFO("%s: wowlan_pno_enable: %d\n", __func__, pwrctl->wowlan_pno_enable);
+		if (pwrctl->wowlan_pno_enable == 0) {
+			if (pwrctl->pnlo_info != NULL) {
+				rtw_mfree((u8 *)pwrctl->pnlo_info, sizeof(pno_nlo_info_t));
+				pwrctl->pnlo_info = NULL;
+			}
+			if (pwrctl->pno_ssid_list != NULL) {
+				rtw_mfree((u8 *)pwrctl->pno_ssid_list, sizeof(pno_ssid_list_t));
+				pwrctl->pno_ssid_list = NULL;
+			}
+			if (pwrctl->pscan_info != NULL) {
+				rtw_mfree((u8 *)pwrctl->pscan_info, sizeof(pno_scan_info_t));
+				pwrctl->pscan_info = NULL;
+			}
+		}
+		return 0;
+	} else
+		return -1;
+}
+#endif /* CONFIG_PNO_SUPPORT */
+
+int rtw_android_cmdstr_to_num(char *cmdstr)
+{
+	int cmd_num;
+	for (cmd_num = 0 ; cmd_num < ANDROID_WIFI_CMD_MAX; cmd_num++)
+		if (0 == strnicmp(cmdstr , android_wifi_cmd_str[cmd_num], strlen(android_wifi_cmd_str[cmd_num])))
+			break;
+
+	return cmd_num;
+}
+
+int rtw_android_get_rssi(struct net_device *net, char *command, int total_len)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
+	int bytes_written = 0;
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		bytes_written += snprintf(&command[bytes_written], total_len, "%s rssi %d",
+			pcur_network->network.Ssid.Ssid, padapter->recvpriv.rssi);
+	}
+
+	return bytes_written;
+}
+
+int rtw_android_get_link_speed(struct net_device *net, char *command, int total_len)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
+	int bytes_written = 0;
+	u16 link_speed = 0;
+
+	link_speed = rtw_get_cur_max_rate(padapter) / 10;
+	bytes_written = snprintf(command, total_len, "LinkSpeed %d", link_speed);
+
+	return bytes_written;
+}
+
+int rtw_android_get_macaddr(struct net_device *net, char *command, int total_len)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
+	int bytes_written = 0;
+
+	bytes_written = snprintf(command, total_len, "Macaddr = "MAC_FMT, MAC_ARG(net->dev_addr));
+	return bytes_written;
+}
+
+int rtw_android_set_country(struct net_device *net, char *command, int total_len)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
+	char *country_code = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_COUNTRY]) + 1;
+	int ret = _FAIL;
+
+	ret = rtw_set_country(adapter, country_code);
+
+	return (ret == _SUCCESS) ? 0 : -1;
+}
+
+int rtw_android_get_p2p_dev_addr(struct net_device *net, char *command, int total_len)
+{
+	int bytes_written = 0;
+
+	/* We use the same address as our HW MAC address */
+	_rtw_memcpy(command, net->dev_addr, ETH_ALEN);
+
+	bytes_written = ETH_ALEN;
+	return bytes_written;
+}
+
+int rtw_android_set_block_scan(struct net_device *net, char *command, int total_len)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
+	char *block_value = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_BLOCK_SCAN]) + 1;
+
+#ifdef CONFIG_IOCTL_CFG80211
+	adapter_wdev_data(adapter)->block_scan = (*block_value == '0') ? _FALSE : _TRUE;
+#endif
+
+	return 0;
+}
+
+int rtw_android_set_block(struct net_device *net, char *command, int total_len)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
+	char *block_value = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_BLOCK]) + 1;
+
+#ifdef CONFIG_IOCTL_CFG80211
+	adapter_wdev_data(adapter)->block = (*block_value == '0') ? _FALSE : _TRUE;
+#endif
+
+	return 0;
+}
+
+int rtw_android_setband(struct net_device *net, char *command, int total_len)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
+	char *arg = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SETBAND]) + 1;
+	u32 band = WIFI_FREQUENCY_BAND_AUTO;
+	int ret = _FAIL;
+
+	if (sscanf(arg, "%u", &band) >= 1)
+		ret = rtw_set_band(adapter, band);
+
+	return (ret == _SUCCESS) ? 0 : -1;
+}
+
+int rtw_android_getband(struct net_device *net, char *command, int total_len)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
+	int bytes_written = 0;
+
+	bytes_written = snprintf(command, total_len, "%u", adapter->setband);
+
+	return bytes_written;
+}
+
+#ifdef CONFIG_WFD
+int rtw_android_set_miracast_mode(struct net_device *net, char *command, int total_len)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
+	struct wifi_display_info *wfd_info = &adapter->wfd_info;
+	char *arg = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_MIRACAST]) + 1;
+	u8 mode;
+	int num;
+	int ret = _FAIL;
+
+	num = sscanf(arg, "%hhu", &mode);
+
+	if (num < 1)
+		goto exit;
+
+	switch (mode) {
+	case 1: /* soruce */
+		mode = MIRACAST_SOURCE;
+		break;
+	case 2: /* sink */
+		mode = MIRACAST_SINK;
+		break;
+	case 0: /* disabled */
+	default:
+		mode = MIRACAST_DISABLED;
+		break;
+	}
+	wfd_info->stack_wfd_mode = mode;
+	RTW_INFO("stack miracast mode: %s\n", get_miracast_mode_str(wfd_info->stack_wfd_mode));
+
+	ret = _SUCCESS;
+
+exit:
+	return (ret == _SUCCESS) ? 0 : -1;
+}
+#endif /* CONFIG_WFD */
+
+int get_int_from_command(char *pcmd)
+{
+	int i = 0;
+
+	for (i = 0; i < strlen(pcmd); i++) {
+		if (pcmd[i] == '=') {
+			/*	Skip the '=' and space characters. */
+			i += 2;
+			break;
+		}
+	}
+	return rtw_atoi(pcmd + i) ;
+}
+
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
+int rtw_gtk_offload(struct net_device *net, u8 *cmd_ptr)
+{
+	int i;
+	/* u8 *cmd_ptr = priv_cmd.buf; */
+	struct sta_info *psta;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+
+
+	if (psta == NULL)
+		RTW_INFO("%s, : Obtain Sta_info fail\n", __func__);
+	else {
+		/* string command length of "GTK_REKEY_OFFLOAD" */
+		cmd_ptr += 18;
+
+		_rtw_memcpy(psta->kek, cmd_ptr, RTW_KEK_LEN);
+		cmd_ptr += RTW_KEK_LEN;
+		/*
+		printk("supplicant KEK: ");
+		for(i=0;i<RTW_KEK_LEN; i++)
+			printk(" %02x ", psta->kek[i]);
+		printk("\n supplicant KCK: ");
+		*/
+		_rtw_memcpy(psta->kck, cmd_ptr, RTW_KCK_LEN);
+		cmd_ptr += RTW_KCK_LEN;
+		/*
+		for(i=0;i<RTW_KEK_LEN; i++)
+			printk(" %02x ", psta->kck[i]);
+		*/
+		_rtw_memcpy(psta->replay_ctr, cmd_ptr, RTW_REPLAY_CTR_LEN);
+		psecuritypriv->binstallKCK_KEK = _TRUE;
+
+		/* printk("\nREPLAY_CTR: "); */
+		/* for(i=0;i<RTW_REPLAY_CTR_LEN; i++) */
+		/* printk(" %02x ", psta->replay_ctr[i]); */
+	}
+
+	return _SUCCESS;
+}
+#endif /* CONFIG_GTK_OL */
+
+#ifdef CONFIG_RTW_MESH_AEK
+static int rtw_android_set_aek(struct net_device *ndev, char *command, int total_len)
+{
+#define SET_AEK_DATA_LEN (ETH_ALEN + 32)
+
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	u8 *addr;
+	u8 *aek;
+	int err = 0;
+
+	if (total_len - strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AEK]) - 1 != SET_AEK_DATA_LEN) {
+		err = -EINVAL;
+		goto exit;
+	}
+
+	addr = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AEK]) + 1;
+	aek = addr + ETH_ALEN;
+
+	RTW_PRINT(FUNC_NDEV_FMT" addr="MAC_FMT"\n"
+		, FUNC_NDEV_ARG(ndev), MAC_ARG(addr));
+	if (0)
+		RTW_PRINT(FUNC_NDEV_FMT" aek="KEY_FMT KEY_FMT"\n"
+			, FUNC_NDEV_ARG(ndev), KEY_ARG(aek), KEY_ARG(aek + 16));
+
+	if (rtw_mesh_plink_set_aek(adapter, addr, aek) != _SUCCESS)
+		err = -ENOENT;
+
+exit:
+	return err;
+}
+#endif /* CONFIG_RTW_MESH_AEK */
+
+int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
+{
+	int ret = 0;
+	char *command = NULL;
+	int cmd_num;
+	int bytes_written = 0;
+#ifdef CONFIG_PNO_SUPPORT
+	uint cmdlen = 0;
+	uint pno_enable = 0;
+#endif
+	android_wifi_priv_cmd priv_cmd;
+	_adapter	*padapter = (_adapter *) rtw_netdev_priv(net);
+#ifdef CONFIG_WFD
+	struct wifi_display_info		*pwfd_info;
+#endif
+
+	rtw_lock_suspend();
+
+	if (!ifr->ifr_data) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	if (padapter->registrypriv.mp_mode == 1) {
+		ret = -EINVAL;
+		goto exit;
+	}
+#ifdef CONFIG_COMPAT
+#if (KERNEL_VERSION(4, 6, 0) > LINUX_VERSION_CODE)
+	if (is_compat_task()) {
+#else
+	if (in_compat_syscall()) {
+#endif
+		/* User space is 32-bit, use compat ioctl */
+		compat_android_wifi_priv_cmd compat_priv_cmd;
+
+		if (copy_from_user(&compat_priv_cmd, ifr->ifr_data, sizeof(compat_android_wifi_priv_cmd))) {
+			ret = -EFAULT;
+			goto exit;
+		}
+		priv_cmd.buf = compat_ptr(compat_priv_cmd.buf);
+		priv_cmd.used_len = compat_priv_cmd.used_len;
+		priv_cmd.total_len = compat_priv_cmd.total_len;
+	} else
+#endif /* CONFIG_COMPAT */
+		if (copy_from_user(&priv_cmd, ifr->ifr_data, sizeof(android_wifi_priv_cmd))) {
+			ret = -EFAULT;
+			goto exit;
+		}
+	if (padapter->registrypriv.mp_mode == 1) {
+		ret = -EFAULT;
+		goto exit;
+	}
+	/*RTW_INFO("%s priv_cmd.buf=%p priv_cmd.total_len=%d  priv_cmd.used_len=%d\n",__func__,priv_cmd.buf,priv_cmd.total_len,priv_cmd.used_len);*/
+	command = rtw_zmalloc(priv_cmd.total_len);
+	if (!command) {
+		RTW_INFO("%s: failed to allocate memory\n", __FUNCTION__);
+		ret = -ENOMEM;
+		goto exit;
+	}
+
+	if (!access_ok(VERIFY_READ, priv_cmd.buf, priv_cmd.total_len)) {
+		RTW_INFO("%s: failed to access memory\n", __FUNCTION__);
+		ret = -EFAULT;
+		goto exit;
+	}
+	if (copy_from_user(command, (void *)priv_cmd.buf, priv_cmd.total_len)) {
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	RTW_INFO("%s: Android private cmd \"%s\" on %s\n"
+		 , __FUNCTION__, command, ifr->ifr_name);
+
+	cmd_num = rtw_android_cmdstr_to_num(command);
+
+	switch (cmd_num) {
+	case ANDROID_WIFI_CMD_START:
+		/* bytes_written = wl_android_wifi_on(net); */
+		goto response;
+	case ANDROID_WIFI_CMD_SETFWPATH:
+		goto response;
+	}
+
+	if (!g_wifi_on) {
+		RTW_INFO("%s: Ignore private cmd \"%s\" - iface %s is down\n"
+			 , __FUNCTION__, command, ifr->ifr_name);
+		ret = 0;
+		goto exit;
+	}
+
+	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
+		switch (cmd_num) {
+		case ANDROID_WIFI_CMD_WFD_ENABLE:
+		case ANDROID_WIFI_CMD_WFD_DISABLE:
+		case ANDROID_WIFI_CMD_WFD_SET_TCPPORT:
+		case ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT:
+		case ANDROID_WIFI_CMD_WFD_SET_DEVTYPE:
+			goto response;
+		}
+	}
+
+	switch (cmd_num) {
+
+	case ANDROID_WIFI_CMD_STOP:
+		/* bytes_written = wl_android_wifi_off(net); */
+		break;
+
+	case ANDROID_WIFI_CMD_SCAN_ACTIVE:
+		/* rtw_set_scan_mode((_adapter *)rtw_netdev_priv(net), SCAN_ACTIVE); */
+#ifdef CONFIG_PLATFORM_MSTAR
+#ifdef CONFIG_IOCTL_CFG80211
+		adapter_wdev_data((_adapter *)rtw_netdev_priv(net))->bandroid_scan = _TRUE;
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_PLATFORM_MSTAR */
+		break;
+	case ANDROID_WIFI_CMD_SCAN_PASSIVE:
+		/* rtw_set_scan_mode((_adapter *)rtw_netdev_priv(net), SCAN_PASSIVE); */
+		break;
+
+	case ANDROID_WIFI_CMD_RSSI:
+		bytes_written = rtw_android_get_rssi(net, command, priv_cmd.total_len);
+		break;
+	case ANDROID_WIFI_CMD_LINKSPEED:
+		bytes_written = rtw_android_get_link_speed(net, command, priv_cmd.total_len);
+		break;
+
+	case ANDROID_WIFI_CMD_MACADDR:
+		bytes_written = rtw_android_get_macaddr(net, command, priv_cmd.total_len);
+		break;
+
+	case ANDROID_WIFI_CMD_BLOCK_SCAN:
+		bytes_written = rtw_android_set_block_scan(net, command, priv_cmd.total_len);
+		break;
+
+	case ANDROID_WIFI_CMD_BLOCK:
+		bytes_written = rtw_android_set_block(net, command, priv_cmd.total_len);
+		break;
+
+	case ANDROID_WIFI_CMD_RXFILTER_START:
+		/* bytes_written = net_os_set_packet_filter(net, 1); */
+		break;
+	case ANDROID_WIFI_CMD_RXFILTER_STOP:
+		/* bytes_written = net_os_set_packet_filter(net, 0); */
+		break;
+	case ANDROID_WIFI_CMD_RXFILTER_ADD:
+		/* int filter_num = *(command + strlen(CMD_RXFILTER_ADD) + 1) - '0'; */
+		/* bytes_written = net_os_rxfilter_add_remove(net, TRUE, filter_num); */
+		break;
+	case ANDROID_WIFI_CMD_RXFILTER_REMOVE:
+		/* int filter_num = *(command + strlen(CMD_RXFILTER_REMOVE) + 1) - '0'; */
+		/* bytes_written = net_os_rxfilter_add_remove(net, FALSE, filter_num); */
+		break;
+
+	case ANDROID_WIFI_CMD_BTCOEXSCAN_START:
+		/* TBD: BTCOEXSCAN-START */
+		break;
+	case ANDROID_WIFI_CMD_BTCOEXSCAN_STOP:
+		/* TBD: BTCOEXSCAN-STOP */
+		break;
+	case ANDROID_WIFI_CMD_BTCOEXMODE:
+#if 0
+		uint mode = *(command + strlen(CMD_BTCOEXMODE) + 1) - '0';
+		if (mode == 1)
+			net_os_set_packet_filter(net, 0); /* DHCP starts */
+		else
+			net_os_set_packet_filter(net, 1); /* DHCP ends */
+#ifdef WL_CFG80211
+		bytes_written = wl_cfg80211_set_btcoex_dhcp(net, command);
+#endif
+#endif
+		break;
+
+	case ANDROID_WIFI_CMD_SETSUSPENDOPT:
+		/* bytes_written = wl_android_set_suspendopt(net, command, priv_cmd.total_len); */
+		break;
+
+	case ANDROID_WIFI_CMD_SETBAND:
+		bytes_written = rtw_android_setband(net, command, priv_cmd.total_len);
+		break;
+
+	case ANDROID_WIFI_CMD_GETBAND:
+		bytes_written = rtw_android_getband(net, command, priv_cmd.total_len);
+		break;
+
+	case ANDROID_WIFI_CMD_COUNTRY:
+		bytes_written = rtw_android_set_country(net, command, priv_cmd.total_len);
+		break;
+
+#ifdef CONFIG_PNO_SUPPORT
+	case ANDROID_WIFI_CMD_PNOSSIDCLR_SET:
+		/* bytes_written = dhd_dev_pno_reset(net); */
+		break;
+	case ANDROID_WIFI_CMD_PNOSETUP_SET:
+		bytes_written = rtw_android_pno_setup(net, command, priv_cmd.total_len);
+		break;
+	case ANDROID_WIFI_CMD_PNOENABLE_SET:
+		cmdlen = strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_PNOENABLE_SET]);
+		pno_enable = *(command + cmdlen + 1) - '0';
+		bytes_written = rtw_android_pno_enable(net, pno_enable);
+		break;
+#endif
+
+	case ANDROID_WIFI_CMD_P2P_DEV_ADDR:
+		bytes_written = rtw_android_get_p2p_dev_addr(net, command, priv_cmd.total_len);
+		break;
+	case ANDROID_WIFI_CMD_P2P_SET_NOA:
+		/* int skip = strlen(CMD_P2P_SET_NOA) + 1; */
+		/* bytes_written = wl_cfg80211_set_p2p_noa(net, command + skip, priv_cmd.total_len - skip); */
+		break;
+	case ANDROID_WIFI_CMD_P2P_GET_NOA:
+		/* bytes_written = wl_cfg80211_get_p2p_noa(net, command, priv_cmd.total_len); */
+		break;
+	case ANDROID_WIFI_CMD_P2P_SET_PS:
+		/* int skip = strlen(CMD_P2P_SET_PS) + 1; */
+		/* bytes_written = wl_cfg80211_set_p2p_ps(net, command + skip, priv_cmd.total_len - skip); */
+		break;
+
+#ifdef CONFIG_IOCTL_CFG80211
+	case ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE: {
+		int skip = strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE]) + 3;
+		bytes_written = rtw_cfg80211_set_mgnt_wpsp2pie(net, command + skip, priv_cmd.total_len - skip, *(command + skip - 2) - '0');
+		break;
+	}
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+#ifdef CONFIG_WFD
+
+	case ANDROID_WIFI_CMD_MIRACAST:
+		bytes_written = rtw_android_set_miracast_mode(net, command, priv_cmd.total_len);
+		break;
+
+	case ANDROID_WIFI_CMD_WFD_ENABLE: {
+		/*	Commented by Albert 2012/07/24 */
+		/*	We can enable the WFD function by using the following command: */
+		/*	wpa_cli driver wfd-enable */
+
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
+			rtw_wfd_enable(padapter, 1);
+		break;
+	}
+
+	case ANDROID_WIFI_CMD_WFD_DISABLE: {
+		/*	Commented by Albert 2012/07/24 */
+		/*	We can disable the WFD function by using the following command: */
+		/*	wpa_cli driver wfd-disable */
+
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
+			rtw_wfd_enable(padapter, 0);
+		break;
+	}
+	case ANDROID_WIFI_CMD_WFD_SET_TCPPORT: {
+		/*	Commented by Albert 2012/07/24 */
+		/*	We can set the tcp port number by using the following command: */
+		/*	wpa_cli driver wfd-set-tcpport = 554 */
+
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
+			rtw_wfd_set_ctrl_port(padapter, (u16)get_int_from_command(priv_cmd.buf));
+		break;
+	}
+	case ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT: {
+		break;
+	}
+	case ANDROID_WIFI_CMD_WFD_SET_DEVTYPE: {
+		/*	Commented by Albert 2012/08/28 */
+		/*	Specify the WFD device type ( WFD source/primary sink ) */
+
+		pwfd_info = &padapter->wfd_info;
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
+			pwfd_info->wfd_device_type = (u8) get_int_from_command(priv_cmd.buf);
+			pwfd_info->wfd_device_type &= WFD_DEVINFO_DUAL;
+		}
+		break;
+	}
+#endif
+	case ANDROID_WIFI_CMD_CHANGE_DTIM: {
+#ifdef CONFIG_LPS
+		u8 dtim;
+		u8 *ptr = (u8 *) &priv_cmd.buf;
+
+		ptr += 9;/* string command length of  "SET_DTIM"; */
+
+		dtim = rtw_atoi(ptr);
+
+		RTW_INFO("DTIM=%d\n", dtim);
+
+		rtw_lps_change_dtim_cmd(padapter, dtim);
+#endif
+	}
+	break;
+
+#if CONFIG_RTW_MACADDR_ACL
+	case ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL: {
+		rtw_set_macaddr_acl(padapter, RTW_ACL_PERIOD_BSS, get_int_from_command(command));
+		break;
+	}
+	case ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA: {
+		u8 addr[ETH_ALEN] = {0x00};
+		macstr2num(addr, command + strlen("HOSTAPD_ACL_ADD_STA") + 3);	/* 3 is space bar + "=" + space bar these 3 chars */
+		rtw_acl_add_sta(padapter, RTW_ACL_PERIOD_BSS, addr);
+		break;
+	}
+	case ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA: {
+		u8 addr[ETH_ALEN] = {0x00};
+		macstr2num(addr, command + strlen("HOSTAPD_ACL_REMOVE_STA") + 3);	/* 3 is space bar + "=" + space bar these 3 chars */
+		rtw_acl_remove_sta(padapter, RTW_ACL_PERIOD_BSS, addr);
+		break;
+	}
+#endif /* CONFIG_RTW_MACADDR_ACL */
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
+	case ANDROID_WIFI_CMD_GTK_REKEY_OFFLOAD:
+		rtw_gtk_offload(net, (u8 *)command);
+		break;
+#endif /* CONFIG_GTK_OL		 */
+	case ANDROID_WIFI_CMD_P2P_DISABLE: {
+#ifdef CONFIG_P2P
+		struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+		u8 channel, ch_offset;
+		u16 bwmode;
+
+		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
+#endif /* CONFIG_P2P */
+		break;
+	}
+
+#ifdef CONFIG_RTW_MESH_AEK
+	case ANDROID_WIFI_CMD_SET_AEK:
+		bytes_written = rtw_android_set_aek(net, command, priv_cmd.total_len);
+		break;
+#endif
+	
+	case ANDROID_WIFI_CMD_DRIVERVERSION: {
+		bytes_written = strlen(DRIVERVERSION);
+		snprintf(command, bytes_written + 1, DRIVERVERSION);
+		break;
+	}
+	default:
+		RTW_INFO("Unknown PRIVATE command %s - ignored\n", command);
+		snprintf(command, 3, "OK");
+		bytes_written = strlen("OK");
+	}
+
+response:
+	if (bytes_written >= 0) {
+		if ((bytes_written == 0) && (priv_cmd.total_len > 0))
+			command[0] = '\0';
+		if (bytes_written >= priv_cmd.total_len) {
+			RTW_INFO("%s: bytes_written = %d\n", __FUNCTION__, bytes_written);
+			bytes_written = priv_cmd.total_len;
+		} else
+			bytes_written++;
+		priv_cmd.used_len = bytes_written;
+		if (copy_to_user((void *)priv_cmd.buf, command, bytes_written)) {
+			RTW_INFO("%s: failed to copy data to user buffer\n", __FUNCTION__);
+			ret = -EFAULT;
+		}
+	} else
+		ret = bytes_written;
+
+exit:
+	rtw_unlock_suspend();
+	if (command)
+		rtw_mfree(command, priv_cmd.total_len);
+
+	return ret;
+}
+
+
+/**
+ * Functions for Android WiFi card detection
+ */
+#if defined(RTW_ENABLE_WIFI_CONTROL_FUNC)
+
+static int g_wifidev_registered = 0;
+static struct semaphore wifi_control_sem;
+static struct wifi_platform_data *wifi_control_data = NULL;
+static struct resource *wifi_irqres = NULL;
+
+static int wifi_add_dev(void);
+static void wifi_del_dev(void);
+
+int rtw_android_wifictrl_func_add(void)
+{
+	int ret = 0;
+	sema_init(&wifi_control_sem, 0);
+
+	ret = wifi_add_dev();
+	if (ret) {
+		RTW_INFO("%s: platform_driver_register failed\n", __FUNCTION__);
+		return ret;
+	}
+	g_wifidev_registered = 1;
+
+	/* Waiting callback after platform_driver_register is done or exit with error */
+	if (down_timeout(&wifi_control_sem,  msecs_to_jiffies(1000)) != 0) {
+		ret = -EINVAL;
+		RTW_INFO("%s: platform_driver_register timeout\n", __FUNCTION__);
+	}
+
+	return ret;
+}
+
+void rtw_android_wifictrl_func_del(void)
+{
+	if (g_wifidev_registered) {
+		wifi_del_dev();
+		g_wifidev_registered = 0;
+	}
+}
+
+void *wl_android_prealloc(int section, unsigned long size)
+{
+	void *alloc_ptr = NULL;
+	if (wifi_control_data && wifi_control_data->mem_prealloc) {
+		alloc_ptr = wifi_control_data->mem_prealloc(section, size);
+		if (alloc_ptr) {
+			RTW_INFO("success alloc section %d\n", section);
+			if (size != 0L)
+				memset(alloc_ptr, 0, size);
+			return alloc_ptr;
+		}
+	}
+
+	RTW_INFO("can't alloc section %d\n", section);
+	return NULL;
+}
+
+int wifi_get_irq_number(unsigned long *irq_flags_ptr)
+{
+	if (wifi_irqres) {
+		*irq_flags_ptr = wifi_irqres->flags & IRQF_TRIGGER_MASK;
+		return (int)wifi_irqres->start;
+	}
+#ifdef CUSTOM_OOB_GPIO_NUM
+	return CUSTOM_OOB_GPIO_NUM;
+#else
+	return -1;
+#endif
+}
+
+int wifi_set_power(int on, unsigned long msec)
+{
+	RTW_INFO("%s = %d\n", __FUNCTION__, on);
+	if (wifi_control_data && wifi_control_data->set_power)
+		wifi_control_data->set_power(on);
+	if (msec)
+		msleep(msec);
+	return 0;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+int wifi_get_mac_addr(unsigned char *buf)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+	if (!buf)
+		return -EINVAL;
+	if (wifi_control_data && wifi_control_data->get_mac_addr)
+		return wifi_control_data->get_mac_addr(buf);
+	return -EOPNOTSUPP;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35)) */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)) || defined(COMPAT_KERNEL_RELEASE)
+void *wifi_get_country_code(char *ccode)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+	if (!ccode)
+		return NULL;
+	if (wifi_control_data && wifi_control_data->get_country_code)
+		return wifi_control_data->get_country_code(ccode);
+	return NULL;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)) */
+
+static int wifi_set_carddetect(int on)
+{
+	RTW_INFO("%s = %d\n", __FUNCTION__, on);
+	if (wifi_control_data && wifi_control_data->set_carddetect)
+		wifi_control_data->set_carddetect(on);
+	return 0;
+}
+
+static int wifi_probe(struct platform_device *pdev)
+{
+	struct wifi_platform_data *wifi_ctrl =
+		(struct wifi_platform_data *)(pdev->dev.platform_data);
+	int wifi_wake_gpio = 0;
+
+	RTW_INFO("## %s\n", __FUNCTION__);
+	wifi_irqres = platform_get_resource_byname(pdev, IORESOURCE_IRQ, "bcmdhd_wlan_irq");
+
+	if (wifi_irqres == NULL)
+		wifi_irqres = platform_get_resource_byname(pdev,
+				IORESOURCE_IRQ, "bcm4329_wlan_irq");
+	else
+		wifi_wake_gpio = wifi_irqres->start;
+
+#ifdef CONFIG_GPIO_WAKEUP
+	RTW_INFO("%s: gpio:%d wifi_wake_gpio:%d\n", __func__,
+	       (int)wifi_irqres->start, wifi_wake_gpio);
+
+	if (wifi_wake_gpio > 0) {
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+		wifi_configure_gpio();
+#else /* CONFIG_PLATFORM_INTEL_BYT */
+		gpio_request(wifi_wake_gpio, "oob_irq");
+		gpio_direction_input(wifi_wake_gpio);
+		oob_irq = gpio_to_irq(wifi_wake_gpio);
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
+	} else if (wifi_irqres) {
+		oob_irq = wifi_irqres->start;
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
+	}
+#endif
+	wifi_control_data = wifi_ctrl;
+
+	wifi_set_power(1, 0);	/* Power On */
+	wifi_set_carddetect(1);	/* CardDetect (0->1) */
+
+	up(&wifi_control_sem);
+	return 0;
+}
+
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+extern PADAPTER g_test_adapter;
+
+static void shutdown_card(void)
+{
+	u32 addr;
+	u8 tmp8, cnt = 0;
+
+	if (NULL == g_test_adapter) {
+		RTW_INFO("%s: padapter==NULL\n", __FUNCTION__);
+		return;
+	}
+
+#ifdef CONFIG_FWLPS_IN_IPS
+	LeaveAllPowerSaveMode(g_test_adapter);
+#endif /* CONFIG_FWLPS_IN_IPS */
+
+#ifdef CONFIG_WOWLAN
+#ifdef CONFIG_GPIO_WAKEUP
+	/*default wake up pin change to BT*/
+	RTW_INFO("%s:default wake up pin change to BT\n", __FUNCTION__);
+	rtw_hal_switch_gpio_wl_ctrl(g_test_adapter, WAKEUP_GPIO_IDX, _FALSE);
+#endif /* CONFIG_GPIO_WAKEUP */
+#endif /* CONFIG_WOWLAN */
+
+	/* Leave SDIO HCI Suspend */
+	addr = 0x10250086;
+	rtw_write8(g_test_adapter, addr, 0);
+	do {
+		tmp8 = rtw_read8(g_test_adapter, addr);
+		cnt++;
+		RTW_INFO(FUNC_ADPT_FMT ": polling SDIO_HSUS_CTRL(0x%x)=0x%x, cnt=%d\n",
+			 FUNC_ADPT_ARG(g_test_adapter), addr, tmp8, cnt);
+
+		if (tmp8 & BIT(1))
+			break;
+
+		if (cnt >= 100) {
+			RTW_INFO(FUNC_ADPT_FMT ": polling 0x%x[1]==1 FAIL!!\n",
+				 FUNC_ADPT_ARG(g_test_adapter), addr);
+			break;
+		}
+
+		rtw_mdelay_os(10);
+	} while (1);
+
+	/* unlock register I/O */
+	rtw_write8(g_test_adapter, 0x1C, 0);
+
+	/* enable power down function */
+	/* 0x04[4] = 1 */
+	/* 0x05[7] = 1 */
+	addr = 0x04;
+	tmp8 = rtw_read8(g_test_adapter, addr);
+	tmp8 |= BIT(4);
+	rtw_write8(g_test_adapter, addr, tmp8);
+	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
+		FUNC_ADPT_ARG(g_test_adapter), addr, rtw_read8(g_test_adapter, addr));
+
+	addr = 0x05;
+	tmp8 = rtw_read8(g_test_adapter, addr);
+	tmp8 |= BIT(7);
+	rtw_write8(g_test_adapter, addr, tmp8);
+	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
+		FUNC_ADPT_ARG(g_test_adapter), addr, rtw_read8(g_test_adapter, addr));
+
+	/* lock register page0 0x0~0xB read/write */
+	rtw_write8(g_test_adapter, 0x1C, 0x0E);
+
+	rtw_set_surprise_removed(g_test_adapter);
+	RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=%s\n",
+		FUNC_ADPT_ARG(g_test_adapter), rtw_is_surprise_removed(g_test_adapter) ? "True" : "False");
+}
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
+
+static int wifi_remove(struct platform_device *pdev)
+{
+	struct wifi_platform_data *wifi_ctrl =
+		(struct wifi_platform_data *)(pdev->dev.platform_data);
+
+	RTW_INFO("## %s\n", __FUNCTION__);
+	wifi_control_data = wifi_ctrl;
+
+	wifi_set_power(0, 0);	/* Power Off */
+	wifi_set_carddetect(0);	/* CardDetect (1->0) */
+
+	up(&wifi_control_sem);
+	return 0;
+}
+
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+static void wifi_shutdown(struct platform_device *pdev)
+{
+	struct wifi_platform_data *wifi_ctrl =
+		(struct wifi_platform_data *)(pdev->dev.platform_data);
+
+
+	RTW_INFO("## %s\n", __FUNCTION__);
+
+	wifi_control_data = wifi_ctrl;
+
+	shutdown_card();
+	wifi_set_power(0, 0);	/* Power Off */
+	wifi_set_carddetect(0);	/* CardDetect (1->0) */
+}
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
+
+static int wifi_suspend(struct platform_device *pdev, pm_message_t state)
+{
+	RTW_INFO("##> %s\n", __FUNCTION__);
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 39)) && defined(OOB_INTR_ONLY)
+	bcmsdh_oob_intr_set(0);
+#endif
+	return 0;
+}
+
+static int wifi_resume(struct platform_device *pdev)
+{
+	RTW_INFO("##> %s\n", __FUNCTION__);
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 39)) && defined(OOB_INTR_ONLY)
+	if (dhd_os_check_if_up(bcmsdh_get_drvdata()))
+		bcmsdh_oob_intr_set(1);
+#endif
+	return 0;
+}
+
+/* temporarily use these two */
+static struct platform_driver wifi_device = {
+	.probe          = wifi_probe,
+	.remove         = wifi_remove,
+	.suspend        = wifi_suspend,
+	.resume         = wifi_resume,
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+	.shutdown       = wifi_shutdown,
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
+	.driver         = {
+		.name   = "bcmdhd_wlan",
+	}
+};
+
+static struct platform_driver wifi_device_legacy = {
+	.probe          = wifi_probe,
+	.remove         = wifi_remove,
+	.suspend        = wifi_suspend,
+	.resume         = wifi_resume,
+	.driver         = {
+		.name   = "bcm4329_wlan",
+	}
+};
+
+static int wifi_add_dev(void)
+{
+	RTW_INFO("## Calling platform_driver_register\n");
+	platform_driver_register(&wifi_device);
+	platform_driver_register(&wifi_device_legacy);
+	return 0;
+}
+
+static void wifi_del_dev(void)
+{
+	RTW_INFO("## Unregister platform_driver_register\n");
+	platform_driver_unregister(&wifi_device);
+	platform_driver_unregister(&wifi_device_legacy);
+}
+#endif /* defined(RTW_ENABLE_WIFI_CONTROL_FUNC) */
+
+#ifdef CONFIG_GPIO_WAKEUP
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+int wifi_configure_gpio(void)
+{
+	if (gpio_request(oob_gpio, "oob_irq")) {
+		RTW_INFO("## %s Cannot request GPIO\n", __FUNCTION__);
+		return -1;
+	}
+	gpio_export(oob_gpio, 0);
+	if (gpio_direction_input(oob_gpio)) {
+		RTW_INFO("## %s Cannot set GPIO direction input\n", __FUNCTION__);
+		return -1;
+	}
+	oob_irq = gpio_to_irq(oob_gpio);
+	if (oob_irq < 0) {
+		RTW_INFO("## %s Cannot convert GPIO to IRQ\n", __FUNCTION__);
+		return -1;
+	}
+
+	RTW_INFO("## %s OOB_IRQ=%d\n", __FUNCTION__, oob_irq);
+
+	return 0;
+}
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+void wifi_free_gpio(unsigned int gpio)
+{
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+	if (gpio)
+		gpio_free(gpio);
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+}
+#endif /* CONFIG_GPIO_WAKEUP */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_cfgvendor.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_cfgvendor.c
new file mode 100644
index 000000000000..0f0f24ffa1fe
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_cfgvendor.c
@@ -0,0 +1,1481 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+#ifdef CONFIG_IOCTL_CFG80211
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
+
+/*
+#include <linux/kernel.h>
+#include <linux/if_arp.h>
+#include <asm/uaccess.h>
+
+#include <linux/kernel.h>
+#include <linux/kthread.h>
+#include <linux/netdevice.h>
+#include <linux/sched.h>
+#include <linux/etherdevice.h>
+#include <linux/wireless.h>
+#include <linux/ieee80211.h>
+#include <linux/wait.h>
+#include <net/cfg80211.h>
+*/
+
+#include <net/rtnetlink.h>
+
+#ifdef DBG_MEM_ALLOC
+extern bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size);
+struct sk_buff *dbg_rtw_cfg80211_vendor_event_alloc(struct wiphy *wiphy, struct wireless_dev *wdev, int len, int event_id, gfp_t gfp
+		, const enum mstat_f flags, const char *func, const int line)
+{
+	struct sk_buff *skb;
+	unsigned int truesize = 0;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 1, 0))
+	skb = cfg80211_vendor_event_alloc(wiphy, len, event_id, gfp);
+#else
+	skb = cfg80211_vendor_event_alloc(wiphy, wdev, len, event_id, gfp);
+#endif
+
+	if (skb)
+		truesize = skb->truesize;
+
+	if (!skb || truesize < len || match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, len, skb, truesize);
+
+	rtw_mstat_update(
+		flags
+		, skb ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, truesize
+	);
+
+	return skb;
+}
+
+void dbg_rtw_cfg80211_vendor_event(struct sk_buff *skb, gfp_t gfp
+		   , const enum mstat_f flags, const char *func, const int line)
+{
+	unsigned int truesize = skb->truesize;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	cfg80211_vendor_event(skb, gfp);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+}
+
+struct sk_buff *dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb(struct wiphy *wiphy, int len
+		, const enum mstat_f flags, const char *func, const int line)
+{
+	struct sk_buff *skb;
+	unsigned int truesize = 0;
+
+	skb = cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len);
+
+	if (skb)
+		truesize = skb->truesize;
+
+	if (!skb || truesize < len || match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, len, skb, truesize);
+
+	rtw_mstat_update(
+		flags
+		, skb ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, truesize
+	);
+
+	return skb;
+}
+
+int dbg_rtw_cfg80211_vendor_cmd_reply(struct sk_buff *skb
+	      , const enum mstat_f flags, const char *func, const int line)
+{
+	unsigned int truesize = skb->truesize;
+	int ret;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	ret = cfg80211_vendor_cmd_reply(skb);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+
+	return ret;
+}
+
+#define rtw_cfg80211_vendor_event_alloc(wiphy, wdev, len, event_id, gfp) \
+	dbg_rtw_cfg80211_vendor_event_alloc(wiphy, wdev, len, event_id, gfp, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+
+#define rtw_cfg80211_vendor_event(skb, gfp) \
+	dbg_rtw_cfg80211_vendor_event(skb, gfp, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+
+#define rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len) \
+	dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+
+#define rtw_cfg80211_vendor_cmd_reply(skb) \
+	dbg_rtw_cfg80211_vendor_cmd_reply(skb, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#else
+
+struct sk_buff *rtw_cfg80211_vendor_event_alloc(
+	struct wiphy *wiphy, struct wireless_dev *wdev, int len, int event_id, gfp_t gfp)
+{
+	struct sk_buff *skb;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 1, 0))
+	skb = cfg80211_vendor_event_alloc(wiphy, len, event_id, gfp);
+#else
+	skb = cfg80211_vendor_event_alloc(wiphy, wdev, len, event_id, gfp);
+#endif
+	return skb;
+}
+
+#define rtw_cfg80211_vendor_event(skb, gfp) \
+	cfg80211_vendor_event(skb, gfp)
+
+#define rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len) \
+	cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len)
+
+#define rtw_cfg80211_vendor_cmd_reply(skb) \
+	cfg80211_vendor_cmd_reply(skb)
+#endif /* DBG_MEM_ALLOC */
+
+/*
+ * This API is to be used for asynchronous vendor events. This
+ * shouldn't be used in response to a vendor command from its
+ * do_it handler context (instead rtw_cfgvendor_send_cmd_reply should
+ * be used).
+ */
+int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,
+	   struct net_device *dev, int event_id, const void  *data, int len)
+{
+	u16 kflags;
+	struct sk_buff *skb;
+
+	kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+
+	/* Alloc the SKB for vendor_event */
+	skb = rtw_cfg80211_vendor_event_alloc(wiphy, ndev_to_wdev(dev), len, event_id, kflags);
+	if (!skb) {
+		RTW_ERR(FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(dev));
+		return -ENOMEM;
+	}
+
+	/* Push the data to the skb */
+	nla_put_nohdr(skb, len, data);
+
+	rtw_cfg80211_vendor_event(skb, kflags);
+
+	return 0;
+}
+
+static int rtw_cfgvendor_send_cmd_reply(struct wiphy *wiphy,
+			struct net_device *dev, const void  *data, int len)
+{
+	struct sk_buff *skb;
+
+	/* Alloc the SKB for vendor_event */
+	skb = rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len);
+	if (unlikely(!skb)) {
+		RTW_ERR(FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(dev));
+		return -ENOMEM;
+	}
+
+	/* Push the data to the skb */
+	nla_put_nohdr(skb, len, data);
+
+	return rtw_cfg80211_vendor_cmd_reply(skb);
+}
+
+/* Feature enums */
+#define WIFI_FEATURE_INFRA              0x0001      // Basic infrastructure mode
+#define WIFI_FEATURE_INFRA_5G           0x0002      // Support for 5 GHz Band
+#define WIFI_FEATURE_HOTSPOT            0x0004      // Support for GAS/ANQP
+#define WIFI_FEATURE_P2P                0x0008      // Wifi-Direct
+#define WIFI_FEATURE_SOFT_AP            0x0010      // Soft AP
+#define WIFI_FEATURE_GSCAN              0x0020      // Google-Scan APIs
+#define WIFI_FEATURE_NAN                0x0040      // Neighbor Awareness Networking
+#define WIFI_FEATURE_D2D_RTT            0x0080      // Device-to-device RTT
+#define WIFI_FEATURE_D2AP_RTT           0x0100      // Device-to-AP RTT
+#define WIFI_FEATURE_BATCH_SCAN         0x0200      // Batched Scan (legacy)
+#define WIFI_FEATURE_PNO                0x0400      // Preferred network offload
+#define WIFI_FEATURE_ADDITIONAL_STA     0x0800      // Support for two STAs
+#define WIFI_FEATURE_TDLS               0x1000      // Tunnel directed link setup
+#define WIFI_FEATURE_TDLS_OFFCHANNEL    0x2000      // Support for TDLS off channel
+#define WIFI_FEATURE_EPR                0x4000      // Enhanced power reporting
+#define WIFI_FEATURE_AP_STA             0x8000      // Support for AP STA Concurrency
+#define WIFI_FEATURE_LINK_LAYER_STATS   0x10000     // Link layer stats collection
+#define WIFI_FEATURE_LOGGER             0x20000     // WiFi Logger
+#define WIFI_FEATURE_HAL_EPNO           0x40000     // WiFi PNO enhanced
+#define WIFI_FEATURE_RSSI_MONITOR       0x80000     // RSSI Monitor
+#define WIFI_FEATURE_MKEEP_ALIVE        0x100000    // WiFi mkeep_alive
+#define WIFI_FEATURE_CONFIG_NDO         0x200000    // ND offload configure
+#define WIFI_FEATURE_TX_TRANSMIT_POWER  0x400000    // Capture Tx transmit power levels
+#define WIFI_FEATURE_CONTROL_ROAMING    0x800000    // Enable/Disable firmware roaming
+#define WIFI_FEATURE_IE_WHITELIST       0x1000000   // Support Probe IE white listing
+#define WIFI_FEATURE_SCAN_RAND          0x2000000   // Support MAC & Probe Sequence Number randomization
+// Add more features here
+
+#define MAX_FEATURE_SET_CONCURRRENT_GROUPS  3
+
+#include <hal_data.h>
+int rtw_dev_get_feature_set(struct net_device *dev)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
+	HAL_VERSION *hal_ver = &HalData->version_id;
+
+	int feature_set = 0;
+
+	feature_set |= WIFI_FEATURE_INFRA;
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (is_supported_5g(adapter_to_regsty(adapter)->wireless_mode)
+		&& hal_chk_band_cap(adapter, BAND_CAP_5G)) /* v5.3 has no rtw_init_wireless_mode(), need checking hal spec here */
+		feature_set |= WIFI_FEATURE_INFRA_5G;
+#endif
+
+	feature_set |= WIFI_FEATURE_P2P;
+	feature_set |= WIFI_FEATURE_SOFT_AP;
+
+	feature_set |= WIFI_FEATURE_ADDITIONAL_STA;
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	feature_set |= WIFI_FEATURE_LINK_LAYER_STATS;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+	return feature_set;
+}
+
+int *rtw_dev_get_feature_set_matrix(struct net_device *dev, int *num)
+{
+	int feature_set_full, mem_needed;
+	int *ret;
+
+	*num = 0;
+	mem_needed = sizeof(int) * MAX_FEATURE_SET_CONCURRRENT_GROUPS;
+	ret = (int *)rtw_malloc(mem_needed);
+
+	if (!ret) {
+		RTW_ERR(FUNC_NDEV_FMT" failed to allocate %d bytes\n"
+			, FUNC_NDEV_ARG(dev), mem_needed);
+		return ret;
+	}
+
+	feature_set_full = rtw_dev_get_feature_set(dev);
+
+	ret[0] = (feature_set_full & WIFI_FEATURE_INFRA) |
+		 (feature_set_full & WIFI_FEATURE_INFRA_5G) |
+		 (feature_set_full & WIFI_FEATURE_NAN) |
+		 (feature_set_full & WIFI_FEATURE_D2D_RTT) |
+		 (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
+		 (feature_set_full & WIFI_FEATURE_PNO) |
+		 (feature_set_full & WIFI_FEATURE_BATCH_SCAN) |
+		 (feature_set_full & WIFI_FEATURE_GSCAN) |
+		 (feature_set_full & WIFI_FEATURE_HOTSPOT) |
+		 (feature_set_full & WIFI_FEATURE_ADDITIONAL_STA) |
+		 (feature_set_full & WIFI_FEATURE_EPR);
+
+	ret[1] = (feature_set_full & WIFI_FEATURE_INFRA) |
+		 (feature_set_full & WIFI_FEATURE_INFRA_5G) |
+		 /* Not yet verified NAN with P2P */
+		 /* (feature_set_full & WIFI_FEATURE_NAN) | */
+		 (feature_set_full & WIFI_FEATURE_P2P) |
+		 (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
+		 (feature_set_full & WIFI_FEATURE_D2D_RTT) |
+		 (feature_set_full & WIFI_FEATURE_EPR);
+
+	ret[2] = (feature_set_full & WIFI_FEATURE_INFRA) |
+		 (feature_set_full & WIFI_FEATURE_INFRA_5G) |
+		 (feature_set_full & WIFI_FEATURE_NAN) |
+		 (feature_set_full & WIFI_FEATURE_D2D_RTT) |
+		 (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
+		 (feature_set_full & WIFI_FEATURE_TDLS) |
+		 (feature_set_full & WIFI_FEATURE_TDLS_OFFCHANNEL) |
+		 (feature_set_full & WIFI_FEATURE_EPR);
+	*num = MAX_FEATURE_SET_CONCURRRENT_GROUPS;
+
+	return ret;
+}
+
+static int rtw_cfgvendor_get_feature_set(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	int reply;
+
+	reply = rtw_dev_get_feature_set(wdev_to_ndev(wdev));
+
+	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), &reply, sizeof(int));
+
+	if (unlikely(err))
+		RTW_ERR(FUNC_NDEV_FMT" Vendor Command reply failed ret:%d\n"
+			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
+
+	return err;
+}
+
+static int rtw_cfgvendor_get_feature_set_matrix(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct sk_buff *skb;
+	int *reply;
+	int num, mem_needed, i;
+
+	reply = rtw_dev_get_feature_set_matrix(wdev_to_ndev(wdev), &num);
+
+	if (!reply) {
+		RTW_ERR(FUNC_NDEV_FMT" Could not get feature list matrix\n"
+			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)));
+		err = -EINVAL;
+		return err;
+	}
+
+	mem_needed = VENDOR_REPLY_OVERHEAD + (ATTRIBUTE_U32_LEN * num) +
+		     ATTRIBUTE_U32_LEN;
+
+	/* Alloc the SKB for vendor_event */
+	skb = rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, mem_needed);
+	if (unlikely(!skb)) {
+		RTW_ERR(FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(wdev_to_ndev(wdev)));
+		err = -ENOMEM;
+		goto exit;
+	}
+
+	nla_put_u32(skb, ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET, num);
+	for (i = 0; i < num; i++)
+		nla_put_u32(skb, ANDR_WIFI_ATTRIBUTE_FEATURE_SET, reply[i]);
+
+	err =  rtw_cfg80211_vendor_cmd_reply(skb);
+
+	if (unlikely(err))
+		RTW_ERR(FUNC_NDEV_FMT" Vendor Command reply failed ret:%d\n"
+			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
+exit:
+	rtw_mfree((u8 *)reply, sizeof(int) * num);
+	return err;
+}
+
+#if defined(GSCAN_SUPPORT) && 0
+int rtw_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
+	struct net_device *dev, void  *data, int len, rtw_vendor_event_t event)
+{
+	u16 kflags;
+	const void *ptr;
+	struct sk_buff *skb;
+	int malloc_len, total, iter_cnt_to_send, cnt;
+	gscan_results_cache_t *cache = (gscan_results_cache_t *)data;
+
+	total = len / sizeof(wifi_gscan_result_t);
+	while (total > 0) {
+		malloc_len = (total * sizeof(wifi_gscan_result_t)) + VENDOR_DATA_OVERHEAD;
+		if (malloc_len > NLMSG_DEFAULT_SIZE)
+			malloc_len = NLMSG_DEFAULT_SIZE;
+		iter_cnt_to_send =
+			(malloc_len - VENDOR_DATA_OVERHEAD) / sizeof(wifi_gscan_result_t);
+		total = total - iter_cnt_to_send;
+
+		kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+
+		/* Alloc the SKB for vendor_event */
+		skb = rtw_cfg80211_vendor_event_alloc(wiphy, ndev_to_wdev(dev), malloc_len, event, kflags);
+		if (!skb) {
+			WL_ERR(("skb alloc failed"));
+			return -ENOMEM;
+		}
+
+		while (cache && iter_cnt_to_send) {
+			ptr = (const void *) &cache->results[cache->tot_consumed];
+
+			if (iter_cnt_to_send < (cache->tot_count - cache->tot_consumed))
+				cnt = iter_cnt_to_send;
+			else
+				cnt = (cache->tot_count - cache->tot_consumed);
+
+			iter_cnt_to_send -= cnt;
+			cache->tot_consumed += cnt;
+			/* Push the data to the skb */
+			nla_append(skb, cnt * sizeof(wifi_gscan_result_t), ptr);
+			if (cache->tot_consumed == cache->tot_count)
+				cache = cache->next;
+
+		}
+
+		rtw_cfg80211_vendor_event(skb, kflags);
+	}
+
+	return 0;
+}
+
+
+static int rtw_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	dhd_pno_gscan_capabilities_t *reply = NULL;
+	uint32 reply_len = 0;
+
+
+	reply = dhd_dev_pno_get_gscan(bcmcfg_to_prmry_ndev(cfg),
+			      DHD_PNO_GET_CAPABILITIES, NULL, &reply_len);
+	if (!reply) {
+		WL_ERR(("Could not get capabilities\n"));
+		err = -EINVAL;
+		return err;
+	}
+
+	err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
+					    reply, reply_len);
+
+	if (unlikely(err))
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
+
+	kfree(reply);
+	return err;
+}
+
+static int rtw_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0, type, band;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	uint16 *reply = NULL;
+	uint32 reply_len = 0, num_channels, mem_needed;
+	struct sk_buff *skb;
+
+	type = nla_type(data);
+
+	if (type == GSCAN_ATTRIBUTE_BAND)
+		band = nla_get_u32(data);
+	else
+		return -1;
+
+	reply = dhd_dev_pno_get_gscan(bcmcfg_to_prmry_ndev(cfg),
+			      DHD_PNO_GET_CHANNEL_LIST, &band, &reply_len);
+
+	if (!reply) {
+		WL_ERR(("Could not get channel list\n"));
+		err = -EINVAL;
+		return err;
+	}
+	num_channels =  reply_len / sizeof(uint32);
+	mem_needed = reply_len + VENDOR_REPLY_OVERHEAD + (ATTRIBUTE_U32_LEN * 2);
+
+	/* Alloc the SKB for vendor_event */
+	skb = rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, mem_needed);
+	if (unlikely(!skb)) {
+		WL_ERR(("skb alloc failed"));
+		err = -ENOMEM;
+		goto exit;
+	}
+
+	nla_put_u32(skb, GSCAN_ATTRIBUTE_NUM_CHANNELS, num_channels);
+	nla_put(skb, GSCAN_ATTRIBUTE_CHANNEL_LIST, reply_len, reply);
+
+	err =  rtw_cfg80211_vendor_cmd_reply(skb);
+
+	if (unlikely(err))
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
+exit:
+	kfree(reply);
+	return err;
+}
+
+static int rtw_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	gscan_results_cache_t *results, *iter;
+	uint32 reply_len, complete = 0, num_results_iter;
+	int32 mem_needed;
+	wifi_gscan_result_t *ptr;
+	uint16 num_scan_ids, num_results;
+	struct sk_buff *skb;
+	struct nlattr *scan_hdr;
+
+	dhd_dev_wait_batch_results_complete(bcmcfg_to_prmry_ndev(cfg));
+	dhd_dev_pno_lock_access_batch_results(bcmcfg_to_prmry_ndev(cfg));
+	results = dhd_dev_pno_get_gscan(bcmcfg_to_prmry_ndev(cfg),
+				DHD_PNO_GET_BATCH_RESULTS, NULL, &reply_len);
+
+	if (!results) {
+		WL_ERR(("No results to send %d\n", err));
+		err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
+						    results, 0);
+
+		if (unlikely(err))
+			WL_ERR(("Vendor Command reply failed ret:%d\n", err));
+		dhd_dev_pno_unlock_access_batch_results(bcmcfg_to_prmry_ndev(cfg));
+		return err;
+	}
+	num_scan_ids = reply_len & 0xFFFF;
+	num_results = (reply_len & 0xFFFF0000) >> 16;
+	mem_needed = (num_results * sizeof(wifi_gscan_result_t)) +
+		     (num_scan_ids * GSCAN_BATCH_RESULT_HDR_LEN) +
+		     VENDOR_REPLY_OVERHEAD + SCAN_RESULTS_COMPLETE_FLAG_LEN;
+
+	if (mem_needed > (int32)NLMSG_DEFAULT_SIZE) {
+		mem_needed = (int32)NLMSG_DEFAULT_SIZE;
+		complete = 0;
+	} else
+		complete = 1;
+
+	WL_TRACE(("complete %d mem_needed %d max_mem %d\n", complete, mem_needed,
+		  (int)NLMSG_DEFAULT_SIZE));
+	/* Alloc the SKB for vendor_event */
+	skb = rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, mem_needed);
+	if (unlikely(!skb)) {
+		WL_ERR(("skb alloc failed"));
+		dhd_dev_pno_unlock_access_batch_results(bcmcfg_to_prmry_ndev(cfg));
+		return -ENOMEM;
+	}
+	iter = results;
+
+	nla_put_u32(skb, GSCAN_ATTRIBUTE_SCAN_RESULTS_COMPLETE, complete);
+
+	mem_needed = mem_needed - (SCAN_RESULTS_COMPLETE_FLAG_LEN + VENDOR_REPLY_OVERHEAD);
+
+	while (iter && ((mem_needed - GSCAN_BATCH_RESULT_HDR_LEN)  > 0)) {
+		scan_hdr = nla_nest_start(skb, GSCAN_ATTRIBUTE_SCAN_RESULTS);
+		nla_put_u32(skb, GSCAN_ATTRIBUTE_SCAN_ID, iter->scan_id);
+		nla_put_u8(skb, GSCAN_ATTRIBUTE_SCAN_FLAGS, iter->flag);
+		num_results_iter =
+			(mem_needed - GSCAN_BATCH_RESULT_HDR_LEN) / sizeof(wifi_gscan_result_t);
+
+		if ((iter->tot_count - iter->tot_consumed) < num_results_iter)
+			num_results_iter = iter->tot_count - iter->tot_consumed;
+
+		nla_put_u32(skb, GSCAN_ATTRIBUTE_NUM_OF_RESULTS, num_results_iter);
+		if (num_results_iter) {
+			ptr = &iter->results[iter->tot_consumed];
+			iter->tot_consumed += num_results_iter;
+			nla_put(skb, GSCAN_ATTRIBUTE_SCAN_RESULTS,
+				num_results_iter * sizeof(wifi_gscan_result_t), ptr);
+		}
+		nla_nest_end(skb, scan_hdr);
+		mem_needed -= GSCAN_BATCH_RESULT_HDR_LEN +
+			      (num_results_iter * sizeof(wifi_gscan_result_t));
+		iter = iter->next;
+	}
+
+	dhd_dev_gscan_batch_cache_cleanup(bcmcfg_to_prmry_ndev(cfg));
+	dhd_dev_pno_unlock_access_batch_results(bcmcfg_to_prmry_ndev(cfg));
+
+	return rtw_cfg80211_vendor_cmd_reply(skb);
+}
+
+static int rtw_cfgvendor_initiate_gscan(struct wiphy *wiphy,
+		       struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	int type, tmp = len;
+	int run = 0xFF;
+	int flush = 0;
+	const struct nlattr *iter;
+
+	nla_for_each_attr(iter, data, len, tmp) {
+		type = nla_type(iter);
+		if (type == GSCAN_ATTRIBUTE_ENABLE_FEATURE)
+			run = nla_get_u32(iter);
+		else if (type == GSCAN_ATTRIBUTE_FLUSH_FEATURE)
+			flush = nla_get_u32(iter);
+	}
+
+	if (run != 0xFF) {
+		err = dhd_dev_pno_run_gscan(bcmcfg_to_prmry_ndev(cfg), run, flush);
+
+		if (unlikely(err))
+			WL_ERR(("Could not run gscan:%d\n", err));
+		return err;
+	} else
+		return -1;
+
+
+}
+
+static int rtw_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	int type;
+	bool real_time = FALSE;
+
+	type = nla_type(data);
+
+	if (type == GSCAN_ATTRIBUTE_ENABLE_FULL_SCAN_RESULTS) {
+		real_time = nla_get_u32(data);
+
+		err = dhd_dev_pno_enable_full_scan_result(bcmcfg_to_prmry_ndev(cfg), real_time);
+
+		if (unlikely(err))
+			WL_ERR(("Could not run gscan:%d\n", err));
+
+	} else
+		err = -1;
+
+	return err;
+}
+
+static int rtw_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
+		     struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	gscan_scan_params_t *scan_param;
+	int j = 0;
+	int type, tmp, tmp1, tmp2, k = 0;
+	const struct nlattr *iter, *iter1, *iter2;
+	struct dhd_pno_gscan_channel_bucket  *ch_bucket;
+
+	scan_param = kzalloc(sizeof(gscan_scan_params_t), GFP_KERNEL);
+	if (!scan_param) {
+		WL_ERR(("Could not set GSCAN scan cfg, mem alloc failure\n"));
+		err = -EINVAL;
+		return err;
+
+	}
+
+	scan_param->scan_fr = PNO_SCAN_MIN_FW_SEC;
+	nla_for_each_attr(iter, data, len, tmp) {
+		type = nla_type(iter);
+
+		if (j >= GSCAN_MAX_CH_BUCKETS)
+			break;
+
+		switch (type) {
+		case GSCAN_ATTRIBUTE_BASE_PERIOD:
+			scan_param->scan_fr = nla_get_u32(iter) / 1000;
+			break;
+		case GSCAN_ATTRIBUTE_NUM_BUCKETS:
+			scan_param->nchannel_buckets = nla_get_u32(iter);
+			break;
+		case GSCAN_ATTRIBUTE_CH_BUCKET_1:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_2:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_3:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_4:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_5:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_6:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_7:
+			nla_for_each_nested(iter1, iter, tmp1) {
+				type = nla_type(iter1);
+				ch_bucket =
+					scan_param->channel_bucket;
+
+				switch (type) {
+				case GSCAN_ATTRIBUTE_BUCKET_ID:
+					break;
+				case GSCAN_ATTRIBUTE_BUCKET_PERIOD:
+					ch_bucket[j].bucket_freq_multiple =
+						nla_get_u32(iter1) / 1000;
+					break;
+				case GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS:
+					ch_bucket[j].num_channels =
+						nla_get_u32(iter1);
+					break;
+				case GSCAN_ATTRIBUTE_BUCKET_CHANNELS:
+					nla_for_each_nested(iter2, iter1, tmp2) {
+						if (k >= PFN_SWC_RSSI_WINDOW_MAX)
+							break;
+						ch_bucket[j].chan_list[k] =
+							nla_get_u32(iter2);
+						k++;
+					}
+					k = 0;
+					break;
+				case GSCAN_ATTRIBUTE_BUCKETS_BAND:
+					ch_bucket[j].band = (uint16)
+							    nla_get_u32(iter1);
+					break;
+				case GSCAN_ATTRIBUTE_REPORT_EVENTS:
+					ch_bucket[j].report_flag = (uint8)
+							   nla_get_u32(iter1);
+					break;
+				}
+			}
+			j++;
+			break;
+		}
+	}
+
+	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
+				      DHD_PNO_SCAN_CFG_ID, scan_param, 0) < 0) {
+		WL_ERR(("Could not set GSCAN scan cfg\n"));
+		err = -EINVAL;
+	}
+
+	kfree(scan_param);
+	return err;
+
+}
+
+static int rtw_cfgvendor_hotlist_cfg(struct wiphy *wiphy,
+		    struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	gscan_hotlist_scan_params_t *hotlist_params;
+	int tmp, tmp1, tmp2, type, j = 0, dummy;
+	const struct nlattr *outer, *inner, *iter;
+	uint8 flush = 0;
+	struct bssid_t *pbssid;
+
+	hotlist_params = (gscan_hotlist_scan_params_t *)kzalloc(len, GFP_KERNEL);
+	if (!hotlist_params) {
+		WL_ERR(("Cannot Malloc mem to parse config commands size - %d bytes\n", len));
+		return -1;
+	}
+
+	hotlist_params->lost_ap_window = GSCAN_LOST_AP_WINDOW_DEFAULT;
+
+	nla_for_each_attr(iter, data, len, tmp2) {
+		type = nla_type(iter);
+		switch (type) {
+		case GSCAN_ATTRIBUTE_HOTLIST_BSSIDS:
+			pbssid = hotlist_params->bssid;
+			nla_for_each_nested(outer, iter, tmp) {
+				nla_for_each_nested(inner, outer, tmp1) {
+					type = nla_type(inner);
+
+					switch (type) {
+					case GSCAN_ATTRIBUTE_BSSID:
+						memcpy(&(pbssid[j].macaddr),
+						       nla_data(inner), ETHER_ADDR_LEN);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_LOW:
+						pbssid[j].rssi_reporting_threshold =
+							(int8) nla_get_u8(inner);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_HIGH:
+						dummy = (int8) nla_get_u8(inner);
+						break;
+					}
+				}
+				j++;
+			}
+			hotlist_params->nbssid = j;
+			break;
+		case GSCAN_ATTRIBUTE_HOTLIST_FLUSH:
+			flush = nla_get_u8(iter);
+			break;
+		case GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE:
+			hotlist_params->lost_ap_window = nla_get_u32(iter);
+			break;
+		}
+
+	}
+
+	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
+		DHD_PNO_GEOFENCE_SCAN_CFG_ID, hotlist_params, flush) < 0) {
+		WL_ERR(("Could not set GSCAN HOTLIST cfg\n"));
+		err = -EINVAL;
+		goto exit;
+	}
+exit:
+	kfree(hotlist_params);
+	return err;
+}
+static int rtw_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0, tmp, type;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	gscan_batch_params_t batch_param;
+	const struct nlattr *iter;
+
+	batch_param.mscan = batch_param.bestn = 0;
+	batch_param.buffer_threshold = GSCAN_BATCH_NO_THR_SET;
+
+	nla_for_each_attr(iter, data, len, tmp) {
+		type = nla_type(iter);
+
+		switch (type) {
+		case GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN:
+			batch_param.bestn = nla_get_u32(iter);
+			break;
+		case GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE:
+			batch_param.mscan = nla_get_u32(iter);
+			break;
+		case GSCAN_ATTRIBUTE_REPORT_THRESHOLD:
+			batch_param.buffer_threshold = nla_get_u32(iter);
+			break;
+		}
+	}
+
+	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
+			      DHD_PNO_BATCH_SCAN_CFG_ID, &batch_param, 0) < 0) {
+		WL_ERR(("Could not set batch cfg\n"));
+		err = -EINVAL;
+		return err;
+	}
+
+	return err;
+}
+
+static int rtw_cfgvendor_significant_change_cfg(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	gscan_swc_params_t *significant_params;
+	int tmp, tmp1, tmp2, type, j = 0;
+	const struct nlattr *outer, *inner, *iter;
+	uint8 flush = 0;
+	wl_pfn_significant_bssid_t *pbssid;
+
+	significant_params = (gscan_swc_params_t *) kzalloc(len, GFP_KERNEL);
+	if (!significant_params) {
+		WL_ERR(("Cannot Malloc mem to parse config commands size - %d bytes\n", len));
+		return -1;
+	}
+
+
+	nla_for_each_attr(iter, data, len, tmp2) {
+		type = nla_type(iter);
+
+		switch (type) {
+		case GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH:
+			flush = nla_get_u8(iter);
+			break;
+		case GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE:
+			significant_params->rssi_window = nla_get_u16(iter);
+			break;
+		case GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE:
+			significant_params->lost_ap_window = nla_get_u16(iter);
+			break;
+		case GSCAN_ATTRIBUTE_MIN_BREACHING:
+			significant_params->swc_threshold = nla_get_u16(iter);
+			break;
+		case GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS:
+			pbssid = significant_params->bssid_elem_list;
+			nla_for_each_nested(outer, iter, tmp) {
+				nla_for_each_nested(inner, outer, tmp1) {
+					switch (nla_type(inner)) {
+					case GSCAN_ATTRIBUTE_BSSID:
+						memcpy(&(pbssid[j].macaddr),
+						       nla_data(inner),
+						       ETHER_ADDR_LEN);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_HIGH:
+						pbssid[j].rssi_high_threshold =
+							(int8) nla_get_u8(inner);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_LOW:
+						pbssid[j].rssi_low_threshold =
+							(int8) nla_get_u8(inner);
+						break;
+					}
+				}
+				j++;
+			}
+			break;
+		}
+	}
+	significant_params->nbssid = j;
+
+	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
+		DHD_PNO_SIGNIFICANT_SCAN_CFG_ID, significant_params, flush) < 0) {
+		WL_ERR(("Could not set GSCAN significant cfg\n"));
+		err = -EINVAL;
+		goto exit;
+	}
+exit:
+	kfree(significant_params);
+	return err;
+}
+#endif /* GSCAN_SUPPORT */
+
+#if defined(RTT_SUPPORT) && 0
+void rtw_cfgvendor_rtt_evt(void *ctx, void *rtt_data)
+{
+	struct wireless_dev *wdev = (struct wireless_dev *)ctx;
+	struct wiphy *wiphy;
+	struct sk_buff *skb;
+	uint32 tot_len = NLMSG_DEFAULT_SIZE, entry_len = 0;
+	gfp_t kflags;
+	rtt_report_t *rtt_report = NULL;
+	rtt_result_t *rtt_result = NULL;
+	struct list_head *rtt_list;
+	wiphy = wdev->wiphy;
+
+	WL_DBG(("In\n"));
+	/* Push the data to the skb */
+	if (!rtt_data) {
+		WL_ERR(("rtt_data is NULL\n"));
+		goto exit;
+	}
+	rtt_list = (struct list_head *)rtt_data;
+	kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	/* Alloc the SKB for vendor_event */
+	skb = rtw_cfg80211_vendor_event_alloc(wiphy, wdev, tot_len, GOOGLE_RTT_COMPLETE_EVENT, kflags);
+	if (!skb) {
+		WL_ERR(("skb alloc failed"));
+		goto exit;
+	}
+	/* fill in the rtt results on each entry */
+	list_for_each_entry(rtt_result, rtt_list, list) {
+		entry_len = 0;
+		if (rtt_result->TOF_type == TOF_TYPE_ONE_WAY) {
+			entry_len = sizeof(rtt_report_t);
+			rtt_report = kzalloc(entry_len, kflags);
+			if (!rtt_report) {
+				WL_ERR(("rtt_report alloc failed"));
+				goto exit;
+			}
+			rtt_report->addr = rtt_result->peer_mac;
+			rtt_report->num_measurement = 1; /* ONE SHOT */
+			rtt_report->status = rtt_result->err_code;
+			rtt_report->type = (rtt_result->TOF_type == TOF_TYPE_ONE_WAY) ? RTT_ONE_WAY : RTT_TWO_WAY;
+			rtt_report->peer = rtt_result->target_info->peer;
+			rtt_report->channel = rtt_result->target_info->channel;
+			rtt_report->rssi = rtt_result->avg_rssi;
+			/* tx_rate */
+			rtt_report->tx_rate = rtt_result->tx_rate;
+			/* RTT */
+			rtt_report->rtt = rtt_result->meanrtt;
+			rtt_report->rtt_sd = rtt_result->sdrtt;
+			/* convert to centi meter */
+			if (rtt_result->distance != 0xffffffff)
+				rtt_report->distance = (rtt_result->distance >> 2) * 25;
+			else /* invalid distance */
+				rtt_report->distance = -1;
+
+			rtt_report->ts = rtt_result->ts;
+			nla_append(skb, entry_len, rtt_report);
+			kfree(rtt_report);
+		}
+	}
+	rtw_cfg80211_vendor_event(skb, kflags);
+exit:
+	return;
+}
+
+static int rtw_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev *wdev,
+				       const void *data, int len)
+{
+	int err = 0, rem, rem1, rem2, type;
+	rtt_config_params_t rtt_param;
+	rtt_target_info_t *rtt_target = NULL;
+	const struct nlattr *iter, *iter1, *iter2;
+	int8 eabuf[ETHER_ADDR_STR_LEN];
+	int8 chanbuf[CHANSPEC_STR_LEN];
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+
+	WL_DBG(("In\n"));
+	err = dhd_dev_rtt_register_noti_callback(wdev->netdev, wdev, wl_cfgvendor_rtt_evt);
+	if (err < 0) {
+		WL_ERR(("failed to register rtt_noti_callback\n"));
+		goto exit;
+	}
+	memset(&rtt_param, 0, sizeof(rtt_param));
+	nla_for_each_attr(iter, data, len, rem) {
+		type = nla_type(iter);
+		switch (type) {
+		case RTT_ATTRIBUTE_TARGET_CNT:
+			rtt_param.rtt_target_cnt = nla_get_u8(iter);
+			if (rtt_param.rtt_target_cnt > RTT_MAX_TARGET_CNT) {
+				WL_ERR(("exceed max target count : %d\n",
+					rtt_param.rtt_target_cnt));
+				err = BCME_RANGE;
+			}
+			break;
+		case RTT_ATTRIBUTE_TARGET_INFO:
+			rtt_target = rtt_param.target_info;
+			nla_for_each_nested(iter1, iter, rem1) {
+				nla_for_each_nested(iter2, iter1, rem2) {
+					type = nla_type(iter2);
+					switch (type) {
+					case RTT_ATTRIBUTE_TARGET_MAC:
+						memcpy(&rtt_target->addr, nla_data(iter2), ETHER_ADDR_LEN);
+						break;
+					case RTT_ATTRIBUTE_TARGET_TYPE:
+						rtt_target->type = nla_get_u8(iter2);
+						break;
+					case RTT_ATTRIBUTE_TARGET_PEER:
+						rtt_target->peer = nla_get_u8(iter2);
+						break;
+					case RTT_ATTRIBUTE_TARGET_CHAN:
+						memcpy(&rtt_target->channel, nla_data(iter2),
+						       sizeof(rtt_target->channel));
+						break;
+					case RTT_ATTRIBUTE_TARGET_MODE:
+						rtt_target->continuous = nla_get_u8(iter2);
+						break;
+					case RTT_ATTRIBUTE_TARGET_INTERVAL:
+						rtt_target->interval = nla_get_u32(iter2);
+						break;
+					case RTT_ATTRIBUTE_TARGET_NUM_MEASUREMENT:
+						rtt_target->measure_cnt = nla_get_u32(iter2);
+						break;
+					case RTT_ATTRIBUTE_TARGET_NUM_PKT:
+						rtt_target->ftm_cnt = nla_get_u32(iter2);
+						break;
+					case RTT_ATTRIBUTE_TARGET_NUM_RETRY:
+						rtt_target->retry_cnt = nla_get_u32(iter2);
+					}
+				}
+				/* convert to chanspec value */
+				rtt_target->chanspec = dhd_rtt_convert_to_chspec(rtt_target->channel);
+				if (rtt_target->chanspec == 0) {
+					WL_ERR(("Channel is not valid\n"));
+					goto exit;
+				}
+				WL_INFORM(("Target addr %s, Channel : %s for RTT\n",
+					bcm_ether_ntoa((const struct ether_addr *)&rtt_target->addr, eabuf),
+					wf_chspec_ntoa(rtt_target->chanspec, chanbuf)));
+				rtt_target++;
+			}
+			break;
+		}
+	}
+	WL_DBG(("leave :target_cnt : %d\n", rtt_param.rtt_target_cnt));
+	if (dhd_dev_rtt_set_cfg(bcmcfg_to_prmry_ndev(cfg), &rtt_param) < 0) {
+		WL_ERR(("Could not set RTT configuration\n"));
+		err = -EINVAL;
+	}
+exit:
+	return err;
+}
+
+static int rtw_cfgvendor_rtt_cancel_config(struct wiphy *wiphy, struct wireless_dev *wdev,
+		const void *data, int len)
+{
+	int err = 0, rem, type, target_cnt = 0;
+	const struct nlattr *iter;
+	struct ether_addr *mac_list = NULL, *mac_addr = NULL;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+
+	nla_for_each_attr(iter, data, len, rem) {
+		type = nla_type(iter);
+		switch (type) {
+		case RTT_ATTRIBUTE_TARGET_CNT:
+			target_cnt = nla_get_u8(iter);
+			mac_list = (struct ether_addr *)kzalloc(target_cnt * ETHER_ADDR_LEN , GFP_KERNEL);
+			if (mac_list == NULL) {
+				WL_ERR(("failed to allocate mem for mac list\n"));
+				goto exit;
+			}
+			mac_addr = &mac_list[0];
+			break;
+		case RTT_ATTRIBUTE_TARGET_MAC:
+			if (mac_addr)
+				memcpy(mac_addr++, nla_data(iter), ETHER_ADDR_LEN);
+			else {
+				WL_ERR(("mac_list is NULL\n"));
+				goto exit;
+			}
+			break;
+		}
+		if (dhd_dev_rtt_cancel_cfg(bcmcfg_to_prmry_ndev(cfg), mac_list, target_cnt) < 0) {
+			WL_ERR(("Could not cancel RTT configuration\n"));
+			err = -EINVAL;
+			goto exit;
+		}
+	}
+exit:
+	if (mac_list)
+		kfree(mac_list);
+	return err;
+}
+static int rtw_cfgvendor_rtt_get_capability(struct wiphy *wiphy, struct wireless_dev *wdev,
+		const void *data, int len)
+{
+	int err = 0;
+	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	rtt_capabilities_t capability;
+
+	err = dhd_dev_rtt_capability(bcmcfg_to_prmry_ndev(cfg), &capability);
+	if (unlikely(err)) {
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
+		goto exit;
+	}
+	err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
+					    &capability, sizeof(capability));
+
+	if (unlikely(err))
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
+exit:
+	return err;
+}
+
+#endif /* RTT_SUPPORT */
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+enum {
+    LSTATS_SUBCMD_GET_INFO = ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START,
+	LSTATS_SUBCMD_SET_INFO,
+	LSTATS_SUBCMD_CLEAR_INFO,
+};
+static void LinkLayerStats(_adapter *padapter)
+{
+	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
+	struct recv_priv		*precvpriv = &(padapter->recvpriv);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	u32 ps_time, trx_total_time;
+	u64 tx_bytes, rx_bytes, trx_total_bytes = 0;
+	u64 tmp = 0;
+	
+	RTW_DBG("%s adapter type : %u\n", __func__, padapter->adapter_type);
+
+	tx_bytes = 0;
+	rx_bytes = 0;
+	ps_time = 0;
+	trx_total_time = 0;
+
+	if ( padapter->netif_up == _TRUE ) {
+
+		pwrpriv->on_time = rtw_get_passing_time_ms(pwrpriv->radio_on_start_time);
+
+		if (rtw_mi_check_fwstate(padapter, _FW_LINKED)) {
+			if ( pwrpriv->bpower_saving == _TRUE ) {
+				pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+			}
+		} else {		
+#ifdef CONFIG_IPS
+			if ( pwrpriv->bpower_saving == _TRUE ) {
+				pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+			}
+#else
+			pwrpriv->pwr_saving_time = pwrpriv->on_time;
+#endif
+		}
+
+		ps_time = pwrpriv->pwr_saving_time;
+
+		/* Deviation caused by caculation start time */
+		if ( ps_time > pwrpriv->on_time )
+			ps_time = pwrpriv->on_time;
+
+		tx_bytes = pdvobjpriv->traffic_stat.last_tx_bytes;
+		rx_bytes = pdvobjpriv->traffic_stat.last_rx_bytes;		
+		trx_total_bytes = tx_bytes + rx_bytes;
+
+		trx_total_time = pwrpriv->on_time - ps_time;
+		
+		if ( trx_total_bytes == 0) {
+			pwrpriv->tx_time = 0;
+			pwrpriv->rx_time = 0;
+		} else {
+
+			/* tx_time = (trx_total_time * tx_total_bytes) / trx_total_bytes; */
+			/* rx_time = (trx_total_time * rx_total_bytes) / trx_total_bytes; */
+		
+			tmp = (tx_bytes * trx_total_time);
+			tmp = rtw_division64(tmp, trx_total_bytes);
+			pwrpriv->tx_time = tmp;
+
+			tmp = (rx_bytes * trx_total_time);
+			tmp = rtw_division64(tmp, trx_total_bytes);
+			pwrpriv->rx_time = tmp;		
+
+		}
+		
+	}
+	else {
+			pwrpriv->on_time = 0;
+			pwrpriv->tx_time = 0;
+			pwrpriv->rx_time = 0;	
+	}
+
+#ifdef CONFIG_RTW_WIFI_HAL_DEBUG
+		RTW_INFO("- tx_bytes : %llu rx_bytes : %llu total bytes : %llu\n", tx_bytes, rx_bytes, trx_total_bytes);
+		RTW_INFO("- netif_up=%s, on_time : %u ms\n", padapter->netif_up ? "1":"0", pwrpriv->on_time);
+		RTW_INFO("- pwr_saving_time : %u (%u) ms\n", pwrpriv->pwr_saving_time, ps_time);
+		RTW_INFO("- trx_total_time : %u ms\n", trx_total_time);		
+		RTW_INFO("- tx_time : %u ms\n", pwrpriv->tx_time);
+		RTW_INFO("- rx_time : %u ms\n", pwrpriv->rx_time);
+#endif /* CONFIG_RTW_WIFI_HAL_DEBUG */
+
+}
+
+#define DUMMY_TIME_STATICS 99
+static int rtw_cfgvendor_lstats_get_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	_adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	wifi_radio_stat *radio;
+	wifi_iface_stat *iface;
+	char *output;
+
+	output = rtw_malloc(sizeof(wifi_radio_stat) + sizeof(wifi_iface_stat)+1);
+	if (output == NULL) {
+		RTW_DBG("Allocate lstats info buffer fail!\n");
+}
+
+	radio = (wifi_radio_stat *)output;
+
+	radio->num_channels = 0;
+	radio->radio = 1;
+
+	/* to get on_time, tx_time, rx_time */
+	LinkLayerStats(padapter); 
+	
+	radio->on_time = pwrpriv->on_time;
+	radio->tx_time = pwrpriv->tx_time;
+	radio->rx_time = pwrpriv->rx_time;
+	
+	radio->num_tx_levels = 1;
+	radio->tx_time_per_levels = NULL;
+	radio->tx_time_per_levels = (u32*)(output+sizeof(wifi_radio_stat) + sizeof(wifi_iface_stat));
+	*(radio->tx_time_per_levels) = DUMMY_TIME_STATICS;
+
+	radio->on_time_scan = 0;
+	radio->on_time_nbd = 0;
+	radio->on_time_gscan = 0;
+	radio->on_time_pno_scan = 0;
+	radio->on_time_hs20 = 0;
+	#ifdef CONFIG_RTW_WIFI_HAL_DEBUG
+	RTW_INFO("==== %s ====\n", __func__);
+	RTW_INFO("radio->radio : %d\n", (radio->radio));
+	RTW_INFO("pwrpriv->on_time : %u ms\n", (pwrpriv->on_time));
+	RTW_INFO("pwrpriv->tx_time :  %u ms\n", (pwrpriv->tx_time));
+	RTW_INFO("pwrpriv->rx_time :  %u ms\n", (pwrpriv->rx_time));
+	RTW_INFO("radio->on_time :  %u ms\n", (radio->on_time));
+	RTW_INFO("radio->tx_time :  %u ms\n", (radio->tx_time));
+	RTW_INFO("radio->rx_time :  %u ms\n", (radio->rx_time));
+	RTW_INFO("radio->tx_time_per_levels value :  %u ms\n", *(radio->tx_time_per_levels));
+	#endif /* CONFIG_RTW_WIFI_HAL_DEBUG */
+	
+	RTW_DBG(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
+	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), 
+		output, sizeof(wifi_iface_stat) + sizeof(wifi_radio_stat)+1);
+	if (unlikely(err))
+		RTW_ERR(FUNC_NDEV_FMT"Vendor Command reply failed ret:%d \n"
+			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
+	rtw_mfree(output, sizeof(wifi_iface_stat) + sizeof(wifi_radio_stat)+1);
+	return err;
+}
+static int rtw_cfgvendor_lstats_set_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	RTW_INFO("%s\n", __func__);
+	return err;
+}
+static int rtw_cfgvendor_lstats_clear_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	RTW_INFO("%s\n", __func__);
+	return err;
+}
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
+#if defined(GSCAN_SUPPORT) && 0
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_GET_CAPABILITIES
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_gscan_get_capabilities
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_SET_CONFIG
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_set_scan_cfg
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_SET_SCAN_CONFIG
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_set_batch_scan_cfg
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_ENABLE_GSCAN
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_initiate_gscan
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_enable_full_scan_result
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_SET_HOTLIST
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_hotlist_cfg
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_significant_change_cfg
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_GET_SCAN_RESULTS
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_gscan_get_batch_results
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = GSCAN_SUBCMD_GET_CHANNEL_LIST
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_gscan_get_channel_list
+	},
+#endif /* GSCAN_SUPPORT */
+#if defined(RTT_SUPPORT) && 0
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = RTT_SUBCMD_SET_CONFIG
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_rtt_set_config
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = RTT_SUBCMD_CANCEL_CONFIG
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_rtt_cancel_config
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = RTT_SUBCMD_GETCAPABILITY
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_rtt_get_capability
+	},
+#endif /* RTT_SUPPORT */
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LSTATS_SUBCMD_GET_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_get_info
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LSTATS_SUBCMD_SET_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_set_info
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LSTATS_SUBCMD_CLEAR_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_clear_info
+	},
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_GET_FEATURE_SET
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_get_feature_set
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_GET_FEATURE_SET_MATRIX
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_get_feature_set_matrix
+	}
+};
+
+static const struct  nl80211_vendor_cmd_info rtw_vendor_events[] = {
+#if defined(GSCAN_SUPPORT) && 0
+	{ OUI_GOOGLE, GSCAN_EVENT_SIGNIFICANT_CHANGE_RESULTS },
+	{ OUI_GOOGLE, GSCAN_EVENT_HOTLIST_RESULTS_FOUND },
+	{ OUI_GOOGLE, GSCAN_EVENT_SCAN_RESULTS_AVAILABLE },
+	{ OUI_GOOGLE, GSCAN_EVENT_FULL_SCAN_RESULTS },
+#endif /* GSCAN_SUPPORT */
+#if defined(RTT_SUPPORT) && 0
+	{ OUI_GOOGLE, RTT_EVENT_COMPLETE },
+#endif /* RTT_SUPPORT */
+#if defined(GSCAN_SUPPORT) && 0
+	{ OUI_GOOGLE, GSCAN_EVENT_COMPLETE_SCAN },
+	{ OUI_GOOGLE, GSCAN_EVENT_HOTLIST_RESULTS_LOST }
+#endif /* GSCAN_SUPPORT */
+};
+
+int rtw_cfgvendor_attach(struct wiphy *wiphy)
+{
+
+	RTW_INFO("Register RTW cfg80211 vendor cmd(0x%x) interface\n", NL80211_CMD_VENDOR);
+
+	wiphy->vendor_commands	= rtw_vendor_cmds;
+	wiphy->n_vendor_commands = ARRAY_SIZE(rtw_vendor_cmds);
+	wiphy->vendor_events	= rtw_vendor_events;
+	wiphy->n_vendor_events	= ARRAY_SIZE(rtw_vendor_events);
+
+	return 0;
+}
+
+int rtw_cfgvendor_detach(struct wiphy *wiphy)
+{
+	RTW_INFO("Vendor: Unregister RTW cfg80211 vendor interface\n");
+
+	wiphy->vendor_commands  = NULL;
+	wiphy->vendor_events    = NULL;
+	wiphy->n_vendor_commands = 0;
+	wiphy->n_vendor_events  = 0;
+
+	return 0;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT) */
+
+#endif /* CONFIG_IOCTL_CFG80211 */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_cfgvendor.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_cfgvendor.h
new file mode 100644
index 000000000000..d5157b3b4602
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_cfgvendor.h
@@ -0,0 +1,559 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_CFGVENDOR_H_
+#define _RTW_CFGVENDOR_H_
+
+#define OUI_GOOGLE  0x001A11
+#define ATTRIBUTE_U32_LEN                  (NLA_HDRLEN  + 4)
+#define VENDOR_ID_OVERHEAD                 ATTRIBUTE_U32_LEN
+#define VENDOR_SUBCMD_OVERHEAD             ATTRIBUTE_U32_LEN
+#define VENDOR_DATA_OVERHEAD               (NLA_HDRLEN)
+
+#define SCAN_RESULTS_COMPLETE_FLAG_LEN       ATTRIBUTE_U32_LEN
+#define SCAN_INDEX_HDR_LEN                   (NLA_HDRLEN)
+#define SCAN_ID_HDR_LEN                      ATTRIBUTE_U32_LEN
+#define SCAN_FLAGS_HDR_LEN                   ATTRIBUTE_U32_LEN
+#define GSCAN_NUM_RESULTS_HDR_LEN            ATTRIBUTE_U32_LEN
+#define GSCAN_RESULTS_HDR_LEN                (NLA_HDRLEN)
+#define GSCAN_BATCH_RESULT_HDR_LEN  (SCAN_INDEX_HDR_LEN + SCAN_ID_HDR_LEN + \
+				     SCAN_FLAGS_HDR_LEN + \
+				     GSCAN_NUM_RESULTS_HDR_LEN + \
+				     GSCAN_RESULTS_HDR_LEN)
+
+#define VENDOR_REPLY_OVERHEAD       (VENDOR_ID_OVERHEAD + \
+				     VENDOR_SUBCMD_OVERHEAD + \
+				     VENDOR_DATA_OVERHEAD)
+typedef enum {
+    /* don't use 0 as a valid subcommand */
+    VENDOR_NL80211_SUBCMD_UNSPECIFIED,
+
+    /* define all vendor startup commands between 0x0 and 0x0FFF */
+    VENDOR_NL80211_SUBCMD_RANGE_START = 0x0001,
+    VENDOR_NL80211_SUBCMD_RANGE_END   = 0x0FFF,
+
+    /* define all GScan related commands between 0x1000 and 0x10FF */
+    ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START = 0x1000,
+    ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END   = 0x10FF,
+
+    /* define all NearbyDiscovery related commands between 0x1100 and 0x11FF */
+    ANDROID_NL80211_SUBCMD_NBD_RANGE_START = 0x1100,
+    ANDROID_NL80211_SUBCMD_NBD_RANGE_END   = 0x11FF,
+
+    /* define all RTT related commands between 0x1100 and 0x11FF */
+    ANDROID_NL80211_SUBCMD_RTT_RANGE_START = 0x1100,
+    ANDROID_NL80211_SUBCMD_RTT_RANGE_END   = 0x11FF,
+
+    ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START = 0x1200,
+    ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END   = 0x12FF,
+
+    /* define all Logger related commands between 0x1400 and 0x14FF */
+    ANDROID_NL80211_SUBCMD_DEBUG_RANGE_START = 0x1400,
+    ANDROID_NL80211_SUBCMD_DEBUG_RANGE_END   = 0x14FF,
+
+    /* define all wifi offload related commands between 0x1600 and 0x16FF */
+    ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_START = 0x1600,
+    ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_END   = 0x16FF,
+
+    /* define all NAN related commands between 0x1700 and 0x17FF */
+    ANDROID_NL80211_SUBCMD_NAN_RANGE_START = 0x1700,
+    ANDROID_NL80211_SUBCMD_NAN_RANGE_END   = 0x17FF,
+
+    /* define all Android Packet Filter related commands between 0x1800 and 0x18FF */
+    ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START = 0x1800,
+    ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_END   = 0x18FF,
+
+    /* This is reserved for future usage */
+
+} ANDROID_VENDOR_SUB_COMMAND;
+
+enum rtw_vendor_subcmd {
+    GSCAN_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START,
+
+    GSCAN_SUBCMD_SET_CONFIG,                            /* 0x1001 */
+
+    GSCAN_SUBCMD_SET_SCAN_CONFIG,                       /* 0x1002 */
+    GSCAN_SUBCMD_ENABLE_GSCAN,                          /* 0x1003 */
+    GSCAN_SUBCMD_GET_SCAN_RESULTS,                      /* 0x1004 */
+    GSCAN_SUBCMD_SCAN_RESULTS,                          /* 0x1005 */
+
+    GSCAN_SUBCMD_SET_HOTLIST,                           /* 0x1006 */
+
+    GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG,         /* 0x1007 */
+    GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS,              /* 0x1008 */
+    GSCAN_SUBCMD_GET_CHANNEL_LIST,                       /* 0x1009 */
+
+    WIFI_SUBCMD_GET_FEATURE_SET,                         /* 0x100A */
+    WIFI_SUBCMD_GET_FEATURE_SET_MATRIX,                  /* 0x100B */
+    WIFI_SUBCMD_SET_PNO_RANDOM_MAC_OUI,                  /* 0x100C */
+    WIFI_SUBCMD_NODFS_SET,                               /* 0x100D */
+    WIFI_SUBCMD_SET_COUNTRY_CODE,                             /* 0x100E */
+    /* Add more sub commands here */
+    GSCAN_SUBCMD_SET_EPNO_SSID,                          /* 0x100F */
+
+    WIFI_SUBCMD_SET_SSID_WHITE_LIST,                    /* 0x1010 */
+    WIFI_SUBCMD_SET_ROAM_PARAMS,                        /* 0x1011 */
+    WIFI_SUBCMD_ENABLE_LAZY_ROAM,                       /* 0x1012 */
+    WIFI_SUBCMD_SET_BSSID_PREF,                         /* 0x1013 */
+    WIFI_SUBCMD_SET_BSSID_BLACKLIST,                     /* 0x1014 */
+
+    GSCAN_SUBCMD_ANQPO_CONFIG,                          /* 0x1015 */
+    WIFI_SUBCMD_SET_RSSI_MONITOR,                       /* 0x1016 */
+    WIFI_SUBCMD_CONFIG_ND_OFFLOAD,                      /* 0x1017 */
+    /* Add more sub commands here */
+
+    GSCAN_SUBCMD_MAX,
+
+	RTT_SUBCMD_SET_CONFIG = ANDROID_NL80211_SUBCMD_RTT_RANGE_START,
+	RTT_SUBCMD_CANCEL_CONFIG,
+	RTT_SUBCMD_GETCAPABILITY,
+
+    APF_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START,
+    APF_SUBCMD_SET_FILTER,
+};
+
+enum gscan_attributes {
+	GSCAN_ATTRIBUTE_NUM_BUCKETS = 10,
+	GSCAN_ATTRIBUTE_BASE_PERIOD,
+	GSCAN_ATTRIBUTE_BUCKETS_BAND,
+	GSCAN_ATTRIBUTE_BUCKET_ID,
+	GSCAN_ATTRIBUTE_BUCKET_PERIOD,
+	GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS,
+	GSCAN_ATTRIBUTE_BUCKET_CHANNELS,
+	GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN,
+	GSCAN_ATTRIBUTE_REPORT_THRESHOLD,
+	GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE,
+	GSCAN_ATTRIBUTE_BAND = GSCAN_ATTRIBUTE_BUCKETS_BAND,
+
+	GSCAN_ATTRIBUTE_ENABLE_FEATURE = 20,
+	GSCAN_ATTRIBUTE_SCAN_RESULTS_COMPLETE,
+	GSCAN_ATTRIBUTE_FLUSH_FEATURE,
+	GSCAN_ATTRIBUTE_ENABLE_FULL_SCAN_RESULTS,
+	GSCAN_ATTRIBUTE_REPORT_EVENTS,
+	/* remaining reserved for additional attributes */
+	GSCAN_ATTRIBUTE_NUM_OF_RESULTS = 30,
+	GSCAN_ATTRIBUTE_FLUSH_RESULTS,
+	GSCAN_ATTRIBUTE_SCAN_RESULTS,                       /* flat array of wifi_scan_result */
+	GSCAN_ATTRIBUTE_SCAN_ID,                            /* indicates scan number */
+	GSCAN_ATTRIBUTE_SCAN_FLAGS,                         /* indicates if scan was aborted */
+	GSCAN_ATTRIBUTE_AP_FLAGS,                           /* flags on significant change event */
+	GSCAN_ATTRIBUTE_NUM_CHANNELS,
+	GSCAN_ATTRIBUTE_CHANNEL_LIST,
+
+	/* remaining reserved for additional attributes */
+
+	GSCAN_ATTRIBUTE_SSID = 40,
+	GSCAN_ATTRIBUTE_BSSID,
+	GSCAN_ATTRIBUTE_CHANNEL,
+	GSCAN_ATTRIBUTE_RSSI,
+	GSCAN_ATTRIBUTE_TIMESTAMP,
+	GSCAN_ATTRIBUTE_RTT,
+	GSCAN_ATTRIBUTE_RTTSD,
+
+	/* remaining reserved for additional attributes */
+
+	GSCAN_ATTRIBUTE_HOTLIST_BSSIDS = 50,
+	GSCAN_ATTRIBUTE_RSSI_LOW,
+	GSCAN_ATTRIBUTE_RSSI_HIGH,
+	GSCAN_ATTRIBUTE_HOSTLIST_BSSID_ELEM,
+	GSCAN_ATTRIBUTE_HOTLIST_FLUSH,
+
+	/* remaining reserved for additional attributes */
+	GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE = 60,
+	GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE,
+	GSCAN_ATTRIBUTE_MIN_BREACHING,
+	GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS,
+	GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH,
+	GSCAN_ATTRIBUTE_MAX
+};
+
+enum gscan_bucket_attributes {
+	GSCAN_ATTRIBUTE_CH_BUCKET_1,
+	GSCAN_ATTRIBUTE_CH_BUCKET_2,
+	GSCAN_ATTRIBUTE_CH_BUCKET_3,
+	GSCAN_ATTRIBUTE_CH_BUCKET_4,
+	GSCAN_ATTRIBUTE_CH_BUCKET_5,
+	GSCAN_ATTRIBUTE_CH_BUCKET_6,
+	GSCAN_ATTRIBUTE_CH_BUCKET_7
+};
+
+enum gscan_ch_attributes {
+	GSCAN_ATTRIBUTE_CH_ID_1,
+	GSCAN_ATTRIBUTE_CH_ID_2,
+	GSCAN_ATTRIBUTE_CH_ID_3,
+	GSCAN_ATTRIBUTE_CH_ID_4,
+	GSCAN_ATTRIBUTE_CH_ID_5,
+	GSCAN_ATTRIBUTE_CH_ID_6,
+	GSCAN_ATTRIBUTE_CH_ID_7
+};
+
+enum rtt_attributes {
+	RTT_ATTRIBUTE_TARGET_CNT,
+	RTT_ATTRIBUTE_TARGET_INFO,
+	RTT_ATTRIBUTE_TARGET_MAC,
+	RTT_ATTRIBUTE_TARGET_TYPE,
+	RTT_ATTRIBUTE_TARGET_PEER,
+	RTT_ATTRIBUTE_TARGET_CHAN,
+	RTT_ATTRIBUTE_TARGET_MODE,
+	RTT_ATTRIBUTE_TARGET_INTERVAL,
+	RTT_ATTRIBUTE_TARGET_NUM_MEASUREMENT,
+	RTT_ATTRIBUTE_TARGET_NUM_PKT,
+	RTT_ATTRIBUTE_TARGET_NUM_RETRY
+};
+
+typedef enum rtw_vendor_event {
+    RTK_RESERVED1,
+    RTK_RESERVED2,
+    GSCAN_EVENT_SIGNIFICANT_CHANGE_RESULTS ,
+    GSCAN_EVENT_HOTLIST_RESULTS_FOUND,
+    GSCAN_EVENT_SCAN_RESULTS_AVAILABLE,
+    GSCAN_EVENT_FULL_SCAN_RESULTS,
+    RTT_EVENT_COMPLETE,
+    GSCAN_EVENT_COMPLETE_SCAN,
+    GSCAN_EVENT_HOTLIST_RESULTS_LOST,
+    GSCAN_EVENT_EPNO_EVENT,
+    GOOGLE_DEBUG_RING_EVENT,
+    GOOGLE_DEBUG_MEM_DUMP_EVENT,
+    GSCAN_EVENT_ANQPO_HOTSPOT_MATCH,
+    GOOGLE_RSSI_MONITOR_EVENT
+} rtw_vendor_event_t;
+
+enum andr_wifi_feature_set_attr {
+	ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET,
+	ANDR_WIFI_ATTRIBUTE_FEATURE_SET
+};
+
+typedef enum rtw_vendor_gscan_attribute {
+	ATTR_START_GSCAN,
+	ATTR_STOP_GSCAN,
+	ATTR_SET_SCAN_BATCH_CFG_ID, /* set batch scan params */
+	ATTR_SET_SCAN_GEOFENCE_CFG_ID, /* set list of bssids to track */
+	ATTR_SET_SCAN_SIGNIFICANT_CFG_ID, /* set list of bssids, rssi threshold etc.. */
+	ATTR_SET_SCAN_CFG_ID, /* set common scan config params here */
+	ATTR_GET_GSCAN_CAPABILITIES_ID,
+	/* Add more sub commands here */
+	ATTR_GSCAN_MAX
+} rtw_vendor_gscan_attribute_t;
+
+typedef enum gscan_batch_attribute {
+	ATTR_GSCAN_BATCH_BESTN,
+	ATTR_GSCAN_BATCH_MSCAN,
+	ATTR_GSCAN_BATCH_BUFFER_THRESHOLD
+} gscan_batch_attribute_t;
+
+typedef enum gscan_geofence_attribute {
+	ATTR_GSCAN_NUM_HOTLIST_BSSID,
+	ATTR_GSCAN_HOTLIST_BSSID
+} gscan_geofence_attribute_t;
+
+typedef enum gscan_complete_event {
+	WIFI_SCAN_BUFFER_FULL,
+	WIFI_SCAN_COMPLETE
+} gscan_complete_event_t;
+/* wifi_hal.h */
+/* WiFi Common definitions */
+typedef unsigned char byte;
+typedef int wifi_request_id;
+typedef int wifi_channel;                       // indicates channel frequency in MHz
+typedef int wifi_rssi;
+typedef byte mac_addr[6];
+typedef byte oui[3];
+typedef int64_t wifi_timestamp;                 // In microseconds (us)
+typedef int64_t wifi_timespan;                  // In picoseconds  (ps)
+
+struct wifi_info;
+struct wifi_interface_info;
+typedef struct wifi_info *wifi_handle;
+typedef struct wifi_interface_info *wifi_interface_handle;
+
+/* channel operating width */
+typedef enum {
+    WIFI_CHAN_WIDTH_20    = 0,
+    WIFI_CHAN_WIDTH_40    = 1,
+    WIFI_CHAN_WIDTH_80    = 2,
+    WIFI_CHAN_WIDTH_160   = 3,
+    WIFI_CHAN_WIDTH_80P80 = 4,
+    WIFI_CHAN_WIDTH_5     = 5,
+    WIFI_CHAN_WIDTH_10    = 6,
+    WIFI_CHAN_WIDTH_INVALID = -1
+} wifi_channel_width;
+
+typedef int wifi_radio;
+
+typedef struct {
+    wifi_channel_width width;
+    int center_frequency0;
+    int center_frequency1;
+    int primary_frequency;
+} wifi_channel_spec;
+
+typedef enum {
+    WIFI_SUCCESS = 0,
+    WIFI_ERROR_NONE = 0,
+    WIFI_ERROR_UNKNOWN = -1,
+    WIFI_ERROR_UNINITIALIZED = -2,
+    WIFI_ERROR_NOT_SUPPORTED = -3,
+    WIFI_ERROR_NOT_AVAILABLE = -4,              // Not available right now, but try later
+    WIFI_ERROR_INVALID_ARGS = -5,
+    WIFI_ERROR_INVALID_REQUEST_ID = -6,
+    WIFI_ERROR_TIMED_OUT = -7,
+    WIFI_ERROR_TOO_MANY_REQUESTS = -8,          // Too many instances of this request
+    WIFI_ERROR_OUT_OF_MEMORY = -9,
+    WIFI_ERROR_BUSY = -10,
+} wifi_error;
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+#define STATS_MAJOR_VERSION      1
+#define STATS_MINOR_VERSION      0
+#define STATS_MICRO_VERSION      0
+
+typedef enum {
+    WIFI_DISCONNECTED = 0,
+    WIFI_AUTHENTICATING = 1,
+    WIFI_ASSOCIATING = 2,
+    WIFI_ASSOCIATED = 3,
+    WIFI_EAPOL_STARTED = 4,   // if done by firmware/driver
+    WIFI_EAPOL_COMPLETED = 5, // if done by firmware/driver
+} wifi_connection_state;
+
+typedef enum {
+    WIFI_ROAMING_IDLE = 0,
+    WIFI_ROAMING_ACTIVE = 1,
+} wifi_roam_state;
+
+typedef enum {
+    WIFI_INTERFACE_STA = 0,
+    WIFI_INTERFACE_SOFTAP = 1,
+    WIFI_INTERFACE_IBSS = 2,
+    WIFI_INTERFACE_P2P_CLIENT = 3,
+    WIFI_INTERFACE_P2P_GO = 4,
+    WIFI_INTERFACE_NAN = 5,
+    WIFI_INTERFACE_MESH = 6,
+    WIFI_INTERFACE_UNKNOWN = -1
+ } wifi_interface_mode;
+
+#define WIFI_CAPABILITY_QOS          0x00000001     // set for QOS association
+#define WIFI_CAPABILITY_PROTECTED    0x00000002     // set for protected association (802.11 beacon frame control protected bit set)
+#define WIFI_CAPABILITY_INTERWORKING 0x00000004     // set if 802.11 Extended Capabilities element interworking bit is set
+#define WIFI_CAPABILITY_HS20         0x00000008     // set for HS20 association
+#define WIFI_CAPABILITY_SSID_UTF8    0x00000010     // set is 802.11 Extended Capabilities element UTF-8 SSID bit is set
+#define WIFI_CAPABILITY_COUNTRY      0x00000020     // set is 802.11 Country Element is present
+
+typedef struct {
+   wifi_interface_mode mode;     // interface mode
+   u8 mac_addr[6];               // interface mac address (self)
+   wifi_connection_state state;  // connection state (valid for STA, CLI only)
+   wifi_roam_state roaming;      // roaming state
+   u32 capabilities;             // WIFI_CAPABILITY_XXX (self)
+   u8 ssid[33];                  // null terminated SSID
+   u8 bssid[6];                  // bssid
+   u8 ap_country_str[3];         // country string advertised by AP
+   u8 country_str[3];            // country string for this association
+} wifi_interface_link_layer_info;
+
+/* channel information */
+typedef struct {
+   wifi_channel_width width;   // channel width (20, 40, 80, 80+80, 160)
+   wifi_channel center_freq;   // primary 20 MHz channel
+   wifi_channel center_freq0;  // center frequency (MHz) first segment
+   wifi_channel center_freq1;  // center frequency (MHz) second segment
+} wifi_channel_info;
+
+/* wifi rate */
+typedef struct {
+   u32 preamble   :3;   // 0: OFDM, 1:CCK, 2:HT 3:VHT 4..7 reserved
+   u32 nss        :2;   // 0:1x1, 1:2x2, 3:3x3, 4:4x4
+   u32 bw         :3;   // 0:20MHz, 1:40Mhz, 2:80Mhz, 3:160Mhz
+   u32 rateMcsIdx :8;   // OFDM/CCK rate code would be as per ieee std in the units of 0.5mbps
+                        // HT/VHT it would be mcs index
+   u32 reserved  :16;   // reserved
+   u32 bitrate;         // units of 100 Kbps
+} wifi_rate;
+
+/* channel statistics */
+typedef struct {
+   wifi_channel_info channel;  // channel
+   u32 on_time;                // msecs the radio is awake (32 bits number accruing over time)
+   u32 cca_busy_time;          // msecs the CCA register is busy (32 bits number accruing over time)
+} wifi_channel_stat;
+
+// Max number of tx power levels. The actual number vary per device and is specified by |num_tx_levels|
+#define RADIO_STAT_MAX_TX_LEVELS 256
+
+/* radio statistics */
+typedef struct {
+   wifi_radio radio;                      // wifi radio (if multiple radio supported)
+   u32 on_time;                           // msecs the radio is awake (32 bits number accruing over time)
+   u32 tx_time;                           // msecs the radio is transmitting (32 bits number accruing over time)
+   u32 num_tx_levels;                     // number of radio transmit power levels
+   u32* tx_time_per_levels;               // pointer to an array of radio transmit per power levels in
+                                          // msecs accured over time
+   u32 rx_time;                           // msecs the radio is in active receive (32 bits number accruing over time)
+   u32 on_time_scan;                      // msecs the radio is awake due to all scan (32 bits number accruing over time)
+   u32 on_time_nbd;                       // msecs the radio is awake due to NAN (32 bits number accruing over time)
+   u32 on_time_gscan;                     // msecs the radio is awake due to G?scan (32 bits number accruing over time)
+   u32 on_time_roam_scan;                 // msecs the radio is awake due to roam?scan (32 bits number accruing over time)
+   u32 on_time_pno_scan;                  // msecs the radio is awake due to PNO scan (32 bits number accruing over time)
+   u32 on_time_hs20;                      // msecs the radio is awake due to HS2.0 scans and GAS exchange (32 bits number accruing over time)
+   u32 num_channels;                      // number of channels
+   wifi_channel_stat channels[];          // channel statistics
+} wifi_radio_stat;
+
+/**
+ * Packet statistics reporting by firmware is performed on MPDU basi (i.e. counters increase by 1 for each MPDU)
+ * As well, "data packet" in associated comments, shall be interpreted as 802.11 data packet,
+ * that is, 802.11 frame control subtype == 2 and excluding management and control frames.
+ *
+ * As an example, in the case of transmission of an MSDU fragmented in 16 MPDUs which are transmitted
+ * OTA in a 16 units long a-mpdu, for which a block ack is received with 5 bits set:
+ *          tx_mpdu : shall increase by 5
+ *          retries : shall increase by 16
+ *          tx_ampdu : shall increase by 1
+ * data packet counters shall not increase regardless of the number of BAR potentially sent by device for this a-mpdu
+ * data packet counters shall not increase regardless of the number of BA received by device for this a-mpdu
+ *
+ * For each subsequent retransmission of the 11 remaining non ACK'ed mpdus
+ * (regardless of the fact that they are transmitted in a-mpdu or not)
+ *          retries : shall increase by 1
+ *
+ * If no subsequent BA or ACK are received from AP, until packet lifetime expires for those 11 packet that were not ACK'ed
+ *          mpdu_lost : shall increase by 11
+ */
+
+/* per rate statistics */
+typedef struct {
+   wifi_rate rate;     // rate information
+   u32 tx_mpdu;        // number of successfully transmitted data pkts (ACK rcvd)
+   u32 rx_mpdu;        // number of received data pkts
+   u32 mpdu_lost;      // number of data packet losses (no ACK)
+   u32 retries;        // total number of data pkt retries
+   u32 retries_short;  // number of short data pkt retries
+   u32 retries_long;   // number of long data pkt retries
+} wifi_rate_stat;
+
+/* access categories */
+typedef enum {
+   WIFI_AC_VO  = 0,
+   WIFI_AC_VI  = 1,
+   WIFI_AC_BE  = 2,
+   WIFI_AC_BK  = 3,
+   WIFI_AC_MAX = 4,
+} wifi_traffic_ac;
+
+/* wifi peer type */
+typedef enum
+{
+   WIFI_PEER_STA,
+   WIFI_PEER_AP,
+   WIFI_PEER_P2P_GO,
+   WIFI_PEER_P2P_CLIENT,
+   WIFI_PEER_NAN,
+   WIFI_PEER_TDLS,
+   WIFI_PEER_INVALID,
+} wifi_peer_type;
+
+/* per peer statistics */
+typedef struct {
+   wifi_peer_type type;           // peer type (AP, TDLS, GO etc.)
+   u8 peer_mac_address[6];        // mac address
+   u32 capabilities;              // peer WIFI_CAPABILITY_XXX
+   u32 num_rate;                  // number of rates
+   wifi_rate_stat rate_stats[];   // per rate statistics, number of entries  = num_rate
+} wifi_peer_info;
+
+/* Per access category statistics */
+typedef struct {
+   wifi_traffic_ac ac;             // access category (VI, VO, BE, BK)
+   u32 tx_mpdu;                    // number of successfully transmitted unicast data pkts (ACK rcvd)
+   u32 rx_mpdu;                    // number of received unicast data packets
+   u32 tx_mcast;                   // number of succesfully transmitted multicast data packets
+                                   // STA case: implies ACK received from AP for the unicast packet in which mcast pkt was sent
+   u32 rx_mcast;                   // number of received multicast data packets
+   u32 rx_ampdu;                   // number of received unicast a-mpdus; support of this counter is optional
+   u32 tx_ampdu;                   // number of transmitted unicast a-mpdus; support of this counter is optional
+   u32 mpdu_lost;                  // number of data pkt losses (no ACK)
+   u32 retries;                    // total number of data pkt retries
+   u32 retries_short;              // number of short data pkt retries
+   u32 retries_long;               // number of long data pkt retries
+   u32 contention_time_min;        // data pkt min contention time (usecs)
+   u32 contention_time_max;        // data pkt max contention time (usecs)
+   u32 contention_time_avg;        // data pkt avg contention time (usecs)
+   u32 contention_num_samples;     // num of data pkts used for contention statistics
+} wifi_wmm_ac_stat;
+
+/* interface statistics */
+typedef struct {
+   wifi_interface_handle iface;          // wifi interface
+   wifi_interface_link_layer_info info;  // current state of the interface
+   u32 beacon_rx;                        // access point beacon received count from connected AP
+   u64 average_tsf_offset;               // average beacon offset encountered (beacon_TSF - TBTT)
+                                         // The average_tsf_offset field is used so as to calculate the
+                                         // typical beacon contention time on the channel as well may be
+                                         // used to debug beacon synchronization and related power consumption issue
+   u32 leaky_ap_detected;                // indicate that this AP typically leaks packets beyond the driver guard time.
+   u32 leaky_ap_avg_num_frames_leaked;  // average number of frame leaked by AP after frame with PM bit set was ACK'ed by AP
+   u32 leaky_ap_guard_time;              // guard time currently in force (when implementing IEEE power management based on
+                                         // frame control PM bit), How long driver waits before shutting down the radio and
+                                         // after receiving an ACK for a data frame with PM bit set)
+   u32 mgmt_rx;                          // access point mgmt frames received count from connected AP (including Beacon)
+   u32 mgmt_action_rx;                   // action frames received count
+   u32 mgmt_action_tx;                   // action frames transmit count
+   wifi_rssi rssi_mgmt;                  // access Point Beacon and Management frames RSSI (averaged)
+   wifi_rssi rssi_data;                  // access Point Data Frames RSSI (averaged) from connected AP
+   wifi_rssi rssi_ack;                   // access Point ACK RSSI (averaged) from connected AP
+   wifi_wmm_ac_stat ac[WIFI_AC_MAX];     // per ac data packet statistics
+   u32 num_peers;                        // number of peers
+   wifi_peer_info peer_info[];           // per peer statistics
+} wifi_iface_stat;
+
+/* configuration params */
+typedef struct {
+   u32 mpdu_size_threshold;             // threshold to classify the pkts as short or long
+                                        // packet size < mpdu_size_threshold => short
+   u32 aggressive_statistics_gathering; // set for field debug mode. Driver should collect all statistics regardless of performance impact.
+} wifi_link_layer_params;
+
+/* callback for reporting link layer stats */
+typedef struct {
+  void (*on_link_stats_results) (wifi_request_id id, wifi_iface_stat *iface_stat,
+         int num_radios, wifi_radio_stat *radio_stat);
+} wifi_stats_result_handler;
+
+
+/* wifi statistics bitmap  */
+#define WIFI_STATS_RADIO              0x00000001      // all radio statistics
+#define WIFI_STATS_RADIO_CCA          0x00000002      // cca_busy_time (within radio statistics)
+#define WIFI_STATS_RADIO_CHANNELS     0x00000004      // all channel statistics (within radio statistics)
+#define WIFI_STATS_RADIO_SCAN         0x00000008      // all scan statistics (within radio statistics)
+#define WIFI_STATS_IFACE              0x00000010      // all interface statistics
+#define WIFI_STATS_IFACE_TXRATE       0x00000020      // all tx rate statistics (within interface statistics)
+#define WIFI_STATS_IFACE_AC           0x00000040      // all ac statistics (within interface statistics)
+#define WIFI_STATS_IFACE_CONTENTION   0x00000080      // all contention (min, max, avg) statistics (within ac statisctics)
+
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
+extern int rtw_cfgvendor_attach(struct wiphy *wiphy);
+extern int rtw_cfgvendor_detach(struct wiphy *wiphy);
+extern int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,
+	struct net_device *dev, int event_id, const void  *data, int len);
+#if defined(GSCAN_SUPPORT) && 0
+extern int rtw_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
+	struct net_device *dev, void  *data, int len, rtw_vendor_event_t event);
+#endif
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT) */
+
+#endif /* _RTW_CFGVENDOR_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_proc.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_proc.c
new file mode 100644
index 000000000000..e5577debf9b3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_proc.c
@@ -0,0 +1,4007 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <linux/ctype.h>	/* tolower() */
+#include <drv_types.h>
+#include <hal_data.h>
+#include "rtw_proc.h"
+#include <rtw_btcoex.h>
+
+#ifdef CONFIG_PROC_DEBUG
+
+static struct proc_dir_entry *rtw_proc = NULL;
+
+inline struct proc_dir_entry *get_rtw_drv_proc(void)
+{
+	return rtw_proc;
+}
+
+#define RTW_PROC_NAME DRV_NAME
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
+#define file_inode(file) ((file)->f_dentry->d_inode)
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
+#define PDE_DATA(inode) PDE((inode))->data
+#define proc_get_parent_data(inode) PDE((inode))->parent->data
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+#define get_proc_net proc_net
+#else
+#define get_proc_net init_net.proc_net
+#endif
+
+inline struct proc_dir_entry *rtw_proc_create_dir(const char *name, struct proc_dir_entry *parent, void *data)
+{
+	struct proc_dir_entry *entry;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	entry = proc_mkdir_data(name, S_IRUGO | S_IXUGO, parent, data);
+#else
+	/* entry = proc_mkdir_mode(name, S_IRUGO|S_IXUGO, parent); */
+	entry = proc_mkdir(name, parent);
+	if (entry)
+		entry->data = data;
+#endif
+
+	return entry;
+}
+
+inline struct proc_dir_entry *rtw_proc_create_entry(const char *name, struct proc_dir_entry *parent,
+	const struct file_operations *fops, void * data)
+{
+	struct proc_dir_entry *entry;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26))
+	entry = proc_create_data(name,  S_IFREG | S_IRUGO | S_IWUGO, parent, fops, data);
+#else
+	entry = create_proc_entry(name, S_IFREG | S_IRUGO | S_IWUGO, parent);
+	if (entry) {
+		entry->data = data;
+		entry->proc_fops = fops;
+	}
+#endif
+
+	return entry;
+}
+
+static int proc_get_dummy(struct seq_file *m, void *v)
+{
+	return 0;
+}
+
+static int proc_get_drv_version(struct seq_file *m, void *v)
+{
+	dump_drv_version(m);
+	return 0;
+}
+
+static int proc_get_log_level(struct seq_file *m, void *v)
+{
+	dump_log_level(m);
+	return 0;
+}
+
+static int proc_get_drv_cfg(struct seq_file *m, void *v)
+{
+	dump_drv_cfg(m);
+	return 0;
+}
+
+static ssize_t proc_set_log_level(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	char tmp[32];
+	int log_level;
+
+	if (count < 1)
+		return -EINVAL;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+#ifdef CONFIG_RTW_DEBUG
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &log_level);
+
+		if (log_level >= _DRV_NONE_ && log_level <= _DRV_MAX_) {
+			rtw_drv_log_level = log_level;
+			printk("rtw_drv_log_level:%d\n", rtw_drv_log_level);
+		}
+	} else
+		return -EFAULT;
+#else
+	printk("CONFIG_RTW_DEBUG is disabled\n");
+#endif
+
+	return count;
+}
+
+#ifdef DBG_MEM_ALLOC
+static int proc_get_mstat(struct seq_file *m, void *v)
+{
+	rtw_mstat_dump(m);
+	return 0;
+}
+#endif /* DBG_MEM_ALLOC */
+
+static int proc_get_country_chplan_map(struct seq_file *m, void *v)
+{
+	dump_country_chplan_map(m);
+	return 0;
+}
+
+static int proc_get_chplan_id_list(struct seq_file *m, void *v)
+{
+	dump_chplan_id_list(m);
+	return 0;
+}
+
+static int proc_get_chplan_test(struct seq_file *m, void *v)
+{
+	dump_chplan_test(m);
+	return 0;
+}
+
+#ifdef RTW_HALMAC
+extern void rtw_halmac_get_version(char *str, u32 len);
+
+static int proc_get_halmac_info(struct seq_file *m, void *v)
+{
+	char ver[30] = {0};
+
+
+	rtw_halmac_get_version(ver, 30);
+	RTW_PRINT_SEL(m, "version: %s\n", ver);
+
+	return 0;
+}
+#endif
+
+/*
+* rtw_drv_proc:
+* init/deinit when register/unregister driver
+*/
+const struct rtw_proc_hdl drv_proc_hdls[] = {
+	RTW_PROC_HDL_SSEQ("ver_info", proc_get_drv_version, NULL),
+	RTW_PROC_HDL_SSEQ("log_level", proc_get_log_level, proc_set_log_level),
+	RTW_PROC_HDL_SSEQ("drv_cfg", proc_get_drv_cfg, NULL),
+#ifdef DBG_MEM_ALLOC
+	RTW_PROC_HDL_SSEQ("mstat", proc_get_mstat, NULL),
+#endif /* DBG_MEM_ALLOC */
+	RTW_PROC_HDL_SSEQ("country_chplan_map", proc_get_country_chplan_map, NULL),
+	RTW_PROC_HDL_SSEQ("chplan_id_list", proc_get_chplan_id_list, NULL),
+	RTW_PROC_HDL_SSEQ("chplan_test", proc_get_chplan_test, NULL),
+#ifdef RTW_HALMAC
+	RTW_PROC_HDL_SSEQ("halmac_info", proc_get_halmac_info, NULL),
+#endif /* RTW_HALMAC */
+};
+
+const int drv_proc_hdls_num = sizeof(drv_proc_hdls) / sizeof(struct rtw_proc_hdl);
+
+static int rtw_drv_proc_open(struct inode *inode, struct file *file)
+{
+	/* struct net_device *dev = proc_get_parent_data(inode); */
+	ssize_t index = (ssize_t)PDE_DATA(inode);
+	const struct rtw_proc_hdl *hdl = drv_proc_hdls + index;
+	void *private = NULL;
+
+	if (hdl->type == RTW_PROC_HDL_TYPE_SEQ) {
+		int res = seq_open(file, hdl->u.seq_op);
+
+		if (res == 0)
+			((struct seq_file *)file->private_data)->private = private;
+
+		return res;
+	} else if (hdl->type == RTW_PROC_HDL_TYPE_SSEQ) {
+		int (*show)(struct seq_file *, void *) = hdl->u.show ? hdl->u.show : proc_get_dummy;
+
+		return single_open(file, show, private);
+	} else {
+		return -EROFS;
+	}
+}
+
+static ssize_t rtw_drv_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)
+{
+	ssize_t index = (ssize_t)PDE_DATA(file_inode(file));
+	const struct rtw_proc_hdl *hdl = drv_proc_hdls + index;
+	ssize_t (*write)(struct file *, const char __user *, size_t, loff_t *, void *) = hdl->write;
+
+	if (write)
+		return write(file, buffer, count, pos, NULL);
+
+	return -EROFS;
+}
+
+static const struct file_operations rtw_drv_proc_seq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_drv_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = seq_release,
+	.write = rtw_drv_proc_write,
+};
+
+static const struct file_operations rtw_drv_proc_sseq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_drv_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = single_release,
+	.write = rtw_drv_proc_write,
+};
+
+int rtw_drv_proc_init(void)
+{
+	int ret = _FAIL;
+	ssize_t i;
+	struct proc_dir_entry *entry = NULL;
+
+	if (rtw_proc != NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	rtw_proc = rtw_proc_create_dir(RTW_PROC_NAME, get_proc_net, NULL);
+
+	if (rtw_proc == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	for (i = 0; i < drv_proc_hdls_num; i++) {
+		if (drv_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SEQ)
+			entry = rtw_proc_create_entry(drv_proc_hdls[i].name, rtw_proc, &rtw_drv_proc_seq_fops, (void *)i);
+		else if (drv_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SSEQ)
+			entry = rtw_proc_create_entry(drv_proc_hdls[i].name, rtw_proc, &rtw_drv_proc_sseq_fops, (void *)i);
+		else
+			entry = NULL;
+
+		if (!entry) {
+			rtw_warn_on(1);
+			goto exit;
+		}
+	}
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_drv_proc_deinit(void)
+{
+	int i;
+
+	if (rtw_proc == NULL)
+		return;
+
+	for (i = 0; i < drv_proc_hdls_num; i++)
+		remove_proc_entry(drv_proc_hdls[i].name, rtw_proc);
+
+	remove_proc_entry(RTW_PROC_NAME, get_proc_net);
+	rtw_proc = NULL;
+}
+
+#ifndef RTW_SEQ_FILE_TEST
+#define RTW_SEQ_FILE_TEST 0
+#endif
+
+#if RTW_SEQ_FILE_TEST
+#define RTW_SEQ_FILE_TEST_SHOW_LIMIT 300
+static void *proc_start_seq_file_test(struct seq_file *m, loff_t *pos)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+	if (*pos >= RTW_SEQ_FILE_TEST_SHOW_LIMIT) {
+		RTW_PRINT(FUNC_ADPT_FMT" pos:%llu, out of range return\n", FUNC_ADPT_ARG(adapter), *pos);
+		return NULL;
+	}
+
+	RTW_PRINT(FUNC_ADPT_FMT" return pos:%lld\n", FUNC_ADPT_ARG(adapter), *pos);
+	return pos;
+}
+void proc_stop_seq_file_test(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+}
+
+void *proc_next_seq_file_test(struct seq_file *m, void *v, loff_t *pos)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	(*pos)++;
+	if (*pos >= RTW_SEQ_FILE_TEST_SHOW_LIMIT) {
+		RTW_PRINT(FUNC_ADPT_FMT" pos:%lld, out of range return\n", FUNC_ADPT_ARG(adapter), *pos);
+		return NULL;
+	}
+
+	RTW_PRINT(FUNC_ADPT_FMT" return pos:%lld\n", FUNC_ADPT_ARG(adapter), *pos);
+	return pos;
+}
+
+static int proc_get_seq_file_test(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	u32 pos = *((loff_t *)(v));
+	RTW_PRINT(FUNC_ADPT_FMT" pos:%d\n", FUNC_ADPT_ARG(adapter), pos);
+	RTW_PRINT_SEL(m, FUNC_ADPT_FMT" pos:%d\n", FUNC_ADPT_ARG(adapter), pos);
+	return 0;
+}
+
+struct seq_operations seq_file_test = {
+	.start = proc_start_seq_file_test,
+	.stop  = proc_stop_seq_file_test,
+	.next  = proc_next_seq_file_test,
+	.show  = proc_get_seq_file_test,
+};
+#endif /* RTW_SEQ_FILE_TEST */
+
+#ifdef CONFIG_SDIO_HCI
+static int proc_get_sd_f0_reg_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	sd_f0_reg_dump(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_sdio_local_reg_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	sdio_local_reg_dump(m, adapter);
+
+	return 0;
+}
+static int proc_get_sdio_card_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_sdio_card_info(m, adapter_to_dvobj(adapter));
+
+	return 0;
+}
+#endif /* CONFIG_SDIO_HCI */
+
+static int proc_get_fw_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_dump_fw_info(m, adapter);
+	return 0;
+}
+static int proc_get_mac_reg_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	mac_reg_dump(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_bb_reg_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	bb_reg_dump(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_bb_reg_dump_ex(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	bb_reg_dump_ex(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_rf_reg_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rf_reg_dump(m, adapter);
+
+	return 0;
+}
+
+#ifdef CONFIG_RTW_LED
+int proc_get_led_config(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_led_config(m, adapter);
+
+	return 0;
+}
+
+ssize_t proc_set_led_config(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32];
+	u8 strategy;
+	u8 iface_en_mask;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhx", &strategy, &iface_en_mask);
+
+		if (num >= 1)
+			rtw_led_set_strategy(adapter, strategy);
+		if (num >= 2)
+			rtw_led_set_iface_en_mask(adapter, iface_en_mask);
+	}
+
+	return count;
+}
+#endif /* CONFIG_RTW_LED */
+
+#ifdef CONFIG_AP_MODE
+int proc_get_aid_status(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_aid_status(m, adapter);
+
+	return 0;
+}
+
+ssize_t proc_set_aid_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+
+	char tmp[32];
+	u8 rr;
+	u16 started_aid;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hu", &rr, &started_aid);
+
+		if (num >= 1)
+			stapriv->rr_aid = rr ? 1 : 0;
+		if (num >= 2) {
+			started_aid = started_aid % (stapriv->max_aid + 1);
+			stapriv->started_aid = started_aid ? started_aid : 1;
+		}
+	}
+
+	return count;
+}
+#endif /* CONFIG_AP_MODE */
+
+static int proc_get_dump_tx_rate_bmp(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_tx_rate_bmp(m, adapter_to_dvobj(adapter));
+
+	return 0;
+}
+
+static int proc_get_dump_adapters_status(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_adapters_status(m, adapter_to_dvobj(adapter));
+
+	return 0;
+}
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+static int proc_get_customer_str(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 cstr[RTW_CUSTOMER_STR_LEN];
+
+	rtw_ps_deny(adapter, PS_DENY_IOCTL);
+	if (rtw_pwr_wakeup(adapter) == _FAIL)
+		goto exit;
+
+	if (rtw_hal_customer_str_read(adapter, cstr) != _SUCCESS)
+		goto exit;
+
+	RTW_PRINT_SEL(m, RTW_CUSTOMER_STR_FMT"\n", RTW_CUSTOMER_STR_ARG(cstr));
+
+exit:
+	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+	return 0;
+}
+#endif /* CONFIG_RTW_CUSTOMER_STR */
+
+/* gpio setting */
+#ifdef CONFIG_GPIO_API
+static ssize_t proc_set_config_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32] = {0};
+	int num = 0, gpio_pin = 0, gpio_mode = 0; /* gpio_mode:0 input  1:output; */
+
+	if (count < 2)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		num	= sscanf(tmp, "%d %d", &gpio_pin, &gpio_mode);
+		RTW_INFO("num=%d gpio_pin=%d mode=%d\n", num, gpio_pin, gpio_mode);
+		padapter->pre_gpio_pin = gpio_pin;
+
+		if (gpio_mode == 0 || gpio_mode == 1)
+			rtw_hal_config_gpio(padapter, gpio_pin, gpio_mode);
+	}
+	return count;
+
+}
+static ssize_t proc_set_gpio_output_value(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32] = {0};
+	int num = 0, gpio_pin = 0, pin_mode = 0; /* pin_mode: 1 high         0:low */
+
+	if (count < 2)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		num	= sscanf(tmp, "%d %d", &gpio_pin, &pin_mode);
+		RTW_INFO("num=%d gpio_pin=%d pin_high=%d\n", num, gpio_pin, pin_mode);
+		padapter->pre_gpio_pin = gpio_pin;
+
+		if (pin_mode == 0 || pin_mode == 1)
+			rtw_hal_set_gpio_output_value(padapter, gpio_pin, pin_mode);
+	}
+	return count;
+}
+static int proc_get_gpio(struct seq_file *m, void *v)
+{
+	u8 gpioreturnvalue = 0;
+	struct net_device *dev = m->private;
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	if (!padapter)
+		return -EFAULT;
+	gpioreturnvalue = rtw_hal_get_gpio(padapter, padapter->pre_gpio_pin);
+	RTW_PRINT_SEL(m, "get_gpio %d:%d\n", padapter->pre_gpio_pin, gpioreturnvalue);
+
+	return 0;
+
+}
+static ssize_t proc_set_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32] = {0};
+	int num = 0, gpio_pin = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		num	= sscanf(tmp, "%d", &gpio_pin);
+		RTW_INFO("num=%d gpio_pin=%d\n", num, gpio_pin);
+		padapter->pre_gpio_pin = gpio_pin;
+
+	}
+	return count;
+}
+#endif
+
+static ssize_t proc_set_rx_info_msg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	char tmp[32] = {0};
+	int phy_info_flag = 0;
+
+	if (!padapter)
+		return -EFAULT;
+
+	if (count < 1) {
+		RTW_INFO("argument size is less than 1\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%d", &phy_info_flag);
+
+		precvpriv->store_law_data_flag = (BOOLEAN) phy_info_flag;
+
+		/*RTW_INFO("precvpriv->store_law_data_flag = %d\n",( BOOLEAN )(precvpriv->store_law_data_flag));*/
+	}
+	return count;
+}
+static int proc_get_rx_info_msg(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_hal_set_odm_var(padapter, HAL_ODM_RX_Dframe_INFO, m, _FALSE);
+	return 0;
+}
+static int proc_get_tx_info_msg(struct seq_file *m, void *v)
+{
+	_irqL irqL;
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *psta;
+	u8 bc_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	int i;
+	_list	*plist, *phead;
+	u8 current_rate_id = 0, current_sgi = 0;
+
+	char *BW, *status;
+
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+	if (MLME_IS_STA(padapter))
+		status = "station mode";
+	else if (MLME_IS_AP(padapter))
+		status = "AP mode";
+	else if (MLME_IS_MESH(padapter))
+		status = "mesh mode";
+	else
+		status = " ";
+	_RTW_PRINT_SEL(m, "status=%s\n", status);
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
+
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+
+			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+
+			plist = get_next(plist);
+
+			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6)  !=  _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) != _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), 6) != _TRUE)) {
+
+				switch (psta->cmn.bw_mode) {
+
+				case CHANNEL_WIDTH_20:
+					BW = "20M";
+					break;
+
+				case CHANNEL_WIDTH_40:
+					BW = "40M";
+					break;
+
+				case CHANNEL_WIDTH_80:
+					BW = "80M";
+					break;
+
+				case CHANNEL_WIDTH_160:
+					BW = "160M";
+					break;
+
+				default:
+					BW = "";
+					break;
+				}
+				current_rate_id = rtw_get_current_tx_rate(adapter, psta);
+				current_sgi = rtw_get_current_tx_sgi(adapter, psta);
+
+				RTW_PRINT_SEL(m, "==============================\n");
+				_RTW_PRINT_SEL(m, "macaddr=" MAC_FMT"\n", MAC_ARG(psta->cmn.mac_addr));
+				_RTW_PRINT_SEL(m, "Tx_Data_Rate=%s\n", HDATA_RATE(current_rate_id));
+				_RTW_PRINT_SEL(m, "BW=%s,sgi=%u\n", BW, current_sgi);
+
+			}
+		}
+	}
+
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+	return 0;
+
+}
+
+
+static int proc_get_linked_info_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	if (padapter)
+		RTW_PRINT_SEL(m, "linked_info_dump :%s\n", (padapter->bLinkInfoDump) ? "enable" : "disable");
+
+	return 0;
+}
+
+
+static ssize_t proc_set_linked_info_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32] = {0};
+	int mode = 0, pre_mode = 0;
+	int num = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	pre_mode = padapter->bLinkInfoDump;
+	RTW_INFO("pre_mode=%d\n", pre_mode);
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		num	= sscanf(tmp, "%d ", &mode);
+		RTW_INFO("num=%d mode=%d\n", num, mode);
+
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
+		}
+
+		if (mode == 1 || (mode == 0 && pre_mode == 1)) /* not consider pwr_saving 0: */
+			padapter->bLinkInfoDump = mode;
+
+		else if ((mode == 2) || (mode == 0 && pre_mode == 2)) { /* consider power_saving */
+			/* RTW_INFO("linked_info_dump =%s\n", (padapter->bLinkInfoDump)?"enable":"disable") */
+			linked_info_dump(padapter, mode);
+		}
+	}
+	return count;
+}
+
+
+static int proc_get_sta_tp_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (padapter)
+		RTW_PRINT_SEL(m, "sta_tp_dump :%s\n", (padapter->bsta_tp_dump) ? "enable" : "disable");
+
+	return 0;
+}
+
+static ssize_t proc_set_sta_tp_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32] = {0};
+	int mode = 0;
+	int num = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		num	= sscanf(tmp, "%d ", &mode);
+
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
+		}
+		if (padapter)
+			padapter->bsta_tp_dump = mode;
+	}
+	return count;
+}
+
+static int proc_get_sta_tp_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (padapter)
+		rtw_sta_traffic_info(m, padapter);
+
+	return 0;
+}
+
+static int proc_get_turboedca_ctrl(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
+
+	if (hal_data)
+		RTW_PRINT_SEL(m, "Turbo-EDCA :%s\n", (hal_data->dis_turboedca) ? "Disable" : "Enable");
+
+	return 0;
+}
+
+static ssize_t proc_set_turboedca_ctrl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
+
+	char tmp[32] = {0};
+	int mode = 0, num = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp))
+		return -EFAULT;
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		num	= sscanf(tmp, "%d ", &mode);
+
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
+		}
+		hal_data->dis_turboedca = mode;
+	}
+	return count;
+}
+#ifdef CONFIG_WOWLAN
+static int proc_get_wow_lps_ctrl(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+
+	if (pwrctl)
+		RTW_PRINT_SEL(m, "WOW lps :%s\n", (pwrctl->wowlan_dis_lps) ? "Disable" : "Enable");
+
+	return 0;
+}
+
+static ssize_t proc_set_wow_lps_ctrl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+
+	char tmp[32] = {0};
+	int mode = 0, num = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp))
+		return -EFAULT;
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		num	= sscanf(tmp, "%d ", &mode);
+
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
+		}
+		pwrctl->wowlan_dis_lps = mode;
+		RTW_INFO("WOW lps :%s\n", (pwrctl->wowlan_dis_lps) ? "Disable" : "Enable");
+	}
+	return count;
+}
+#endif
+
+static int proc_get_mac_qinfo(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_hal_get_hwreg(adapter, HW_VAR_DUMP_MAC_QUEUE_INFO, (u8 *)m);
+
+	return 0;
+}
+
+int proc_get_wifi_spec(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+
+	RTW_PRINT_SEL(m, "wifi_spec=%d\n", pregpriv->wifi_spec);
+	return 0;
+}
+
+static int proc_get_chan_plan(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_cur_chset(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_chan_plan(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 chan_plan = RTW_CHPLAN_UNSPECIFIED;
+
+	if (!padapter)
+		return -EFAULT;
+
+	if (count < 1) {
+		RTW_INFO("argument size is less than 1\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%hhx", &chan_plan);
+		if (num !=  1)
+			return count;
+	}
+
+	rtw_set_channel_plan(padapter, chan_plan);
+
+	return count;
+}
+
+static int proc_get_country_code(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	if (rfctl->country_ent)
+		dump_country_chplan(m, rfctl->country_ent);
+	else
+		RTW_PRINT_SEL(m, "unspecified\n");
+
+	return 0;
+}
+
+static ssize_t proc_set_country_code(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	char alpha2[2];
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%c%c", &alpha2[0], &alpha2[1]);
+	if (num !=	2)
+		return count;
+
+	rtw_set_country(padapter, alpha2);
+
+exit:
+	return count;
+}
+
+#if CONFIG_RTW_MACADDR_ACL
+static int proc_get_macaddr_acl(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_macaddr_acl(m, adapter);
+	return 0;
+}
+
+ssize_t proc_set_macaddr_acl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	char tmp[17 * NUM_ACL + 32] = {0};
+	u8 period;
+	char cmd[32];
+	u8 mode;
+	u8 addr[ETH_ALEN];
+
+#define MAC_ACL_CMD_MODE	0
+#define MAC_ACL_CMD_ADD		1
+#define MAC_ACL_CMD_DEL		2
+#define MAC_ACL_CMD_CLR		3
+#define MAC_ACL_CMD_NUM		4
+	
+	static const char * const mac_acl_cmd_str[] = {
+		"mode",
+		"add",
+		"del",
+		"clr",
+	};
+	u8 cmd_id = MAC_ACL_CMD_NUM;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		/*
+		* <period> mode <mode> <macaddr> [<macaddr>]
+		* <period> mode <mode>
+		* <period> add <macaddr> [<macaddr>]
+		* <period> del <macaddr> [<macaddr>]
+		* <period> clr
+		*/
+		char *c, *next;
+		int i;
+		u8 is_bcast;
+
+		next = tmp;
+		c = strsep(&next, " \t");
+		if (!c || sscanf(c, "%hhu", &period) != 1)
+			goto exit;
+
+		if (period >= RTW_ACL_PERIOD_NUM) {
+			RTW_WARN(FUNC_ADPT_FMT" invalid period:%u", FUNC_ADPT_ARG(adapter), period);
+			goto exit;
+		}
+
+		c = strsep(&next, " \t");
+		if (!c || sscanf(c, "%s", cmd) != 1)
+			goto exit;
+
+		for (i = 0; i < MAC_ACL_CMD_NUM; i++)
+			if (strcmp(mac_acl_cmd_str[i], cmd) == 0)
+				cmd_id = i;
+
+		switch (cmd_id) {
+		case MAC_ACL_CMD_MODE:
+			c = strsep(&next, " \t");
+			if (!c || sscanf(c, "%hhu", &mode) != 1)
+				goto exit;
+
+			if (mode >= RTW_ACL_MODE_MAX) {
+				RTW_WARN(FUNC_ADPT_FMT" invalid mode:%u", FUNC_ADPT_ARG(adapter), mode);
+				goto exit;
+			}
+			break;
+
+		case MAC_ACL_CMD_ADD:
+		case MAC_ACL_CMD_DEL:
+			break;
+
+		case MAC_ACL_CMD_CLR:
+			/* clear settings */
+			rtw_macaddr_acl_clear(adapter, period);
+			goto exit;
+
+		default:
+			RTW_WARN(FUNC_ADPT_FMT" invalid cmd:\"%s\"", FUNC_ADPT_ARG(adapter), cmd);
+			goto exit;
+		}
+
+		/* check for macaddr list */
+		c = strsep(&next, " \t");
+		if (!c && cmd_id == MAC_ACL_CMD_MODE) {
+			/* set mode only  */
+			rtw_set_macaddr_acl(adapter, period, mode);
+			goto exit;
+		}
+
+		if (cmd_id == MAC_ACL_CMD_MODE) {
+			/* set mode and entire macaddr list */
+			rtw_macaddr_acl_clear(adapter, period);
+			rtw_set_macaddr_acl(adapter, period, mode);
+		}
+
+		while (c != NULL) {
+			if (sscanf(c, MAC_SFMT, MAC_SARG(addr)) != 6)
+				break;
+
+			is_bcast = is_broadcast_mac_addr(addr);
+			if (is_bcast
+				|| rtw_check_invalid_mac_address(addr, 0) == _FALSE
+			) {
+				if (cmd_id == MAC_ACL_CMD_DEL) {
+					rtw_acl_remove_sta(adapter, period, addr);
+					if (is_bcast)
+						break;
+				 } else if (!is_bcast)
+					rtw_acl_add_sta(adapter, period, addr);
+			}
+		
+			c = strsep(&next, " \t");
+		}
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MACADDR_ACL */
+
+#if CONFIG_RTW_PRE_LINK_STA
+static int proc_get_pre_link_sta(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_pre_link_sta_ctl(m, &adapter->stapriv);
+	return 0;
+}
+
+ssize_t proc_set_pre_link_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	char tmp[17 * RTW_PRE_LINK_STA_NUM + 32] = {0};
+	char arg0[16] = {0};
+	u8 addr[ETH_ALEN];
+
+#define PRE_LINK_STA_CMD_RESET	0
+#define PRE_LINK_STA_CMD_ADD	1
+#define PRE_LINK_STA_CMD_DEL	2
+#define PRE_LINK_STA_CMD_NUM	3
+
+	static const char * const pre_link_sta_cmd_str[] = {
+		"reset",
+		"add",
+		"del"
+	};
+	u8 cmd_id = PRE_LINK_STA_CMD_NUM;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		/* cmd [<macaddr>] */
+		char *c, *next;
+		int i;
+
+		next = tmp;
+		c = strsep(&next, " \t");
+
+		if (sscanf(c, "%s", arg0) != 1)
+			goto exit;
+
+		for (i = 0; i < PRE_LINK_STA_CMD_NUM; i++)
+			if (strcmp(pre_link_sta_cmd_str[i], arg0) == 0)
+				cmd_id = i;
+
+		switch (cmd_id) {
+		case PRE_LINK_STA_CMD_RESET:
+			rtw_pre_link_sta_ctl_reset(&adapter->stapriv);
+			goto exit;
+		case PRE_LINK_STA_CMD_ADD:
+		case PRE_LINK_STA_CMD_DEL:
+			break;
+		default:
+			goto exit;
+		}
+
+		/* macaddr list */
+		c = strsep(&next, " \t");
+		while (c != NULL) {
+			if (sscanf(c, MAC_SFMT, MAC_SARG(addr)) != 6)
+				break;
+
+			if (rtw_check_invalid_mac_address(addr, 0) == _FALSE) {
+				if (cmd_id == PRE_LINK_STA_CMD_ADD)
+					rtw_pre_link_sta_add(&adapter->stapriv, addr);
+				else
+					rtw_pre_link_sta_del(&adapter->stapriv, addr);
+			}
+
+			c = strsep(&next, " \t");
+		}
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_PRE_LINK_STA */
+
+static int proc_get_ch_sel_policy(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "%-16s\n", "same_band_prefer");
+
+	RTW_PRINT_SEL(m, "%16u\n", rfctl->ch_sel_same_band_prefer);
+
+	return 0;
+}
+
+static ssize_t proc_set_ch_sel_policy(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 sb_prefer;
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%hhu", &sb_prefer);
+	if (num >=	1)
+		rfctl->ch_sel_same_band_prefer = sb_prefer;
+
+exit:
+	return count;
+}
+
+#ifdef CONFIG_DFS_MASTER
+int proc_get_dfs_master_test_case(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "%-24s %-19s\n", "radar_detect_trigger_non", "choose_dfs_ch_first");
+	RTW_PRINT_SEL(m, "%24hhu %19hhu\n"
+		, rfctl->dbg_dfs_master_radar_detect_trigger_non
+		, rfctl->dbg_dfs_master_choose_dfs_ch_first
+	);
+
+	return 0;
+}
+
+ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 radar_detect_trigger_non;
+	u8 choose_dfs_ch_first;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%hhu %hhu", &radar_detect_trigger_non, &choose_dfs_ch_first);
+
+		if (num >= 1)
+			rfctl->dbg_dfs_master_radar_detect_trigger_non = radar_detect_trigger_non;
+		if (num >= 2)
+			rfctl->dbg_dfs_master_choose_dfs_ch_first = choose_dfs_ch_first;
+	}
+
+	return count;
+}
+
+ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 ch, bw = CHANNEL_WIDTH_20, offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int ms = -1;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhu %hhu %d", &ch, &bw, &offset, &ms);
+
+		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
+			goto exit;
+
+		if (bw == CHANNEL_WIDTH_20)
+			rtw_chset_update_non_ocp_ms(rfctl->channel_set
+				, ch, bw, HAL_PRIME_CHNL_OFFSET_DONT_CARE, ms);
+		else
+			rtw_chset_update_non_ocp_ms(rfctl->channel_set
+				, ch, bw, offset, ms);
+	}
+
+exit:
+	return count;
+}
+
+ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 fake_radar_detect_cnt = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu", &fake_radar_detect_cnt);
+
+		if (num < 1)
+			goto exit;
+
+		rfctl->dbg_dfs_master_fake_radar_detect_cnt = fake_radar_detect_cnt;
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_dfs_ch_sel_d_flags(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "0x%02x\n", rfctl->dfs_ch_sel_d_flags);
+
+	return 0;
+}
+
+static ssize_t proc_set_dfs_ch_sel_d_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 d_flags;
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%hhx", &d_flags);
+	if (num !=	1)
+		goto exit;
+
+	rfctl->dfs_ch_sel_d_flags = d_flags;
+
+exit:
+	return count;
+}
+#endif /* CONFIG_DFS_MASTER */
+
+#ifdef CONFIG_80211N_HT
+int proc_get_rx_ampdu_size_limit(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_regsty_rx_ampdu_size_limit(m, adapter);
+
+	return 0;
+}
+
+ssize_t proc_set_rx_ampdu_size_limit(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv *regsty = adapter_to_regsty(adapter);
+	char tmp[32];
+	u8 nss;
+	u8 limit_by_bw[4] = {0xFF};
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int i;
+		int num = sscanf(tmp, "%hhu %hhu %hhu %hhu %hhu"
+			, &nss, &limit_by_bw[0], &limit_by_bw[1], &limit_by_bw[2], &limit_by_bw[3]);
+
+		if (num < 2)
+			goto exit;
+		if (nss == 0 || nss > 4)
+			goto exit;
+
+		for (i = 0; i < num - 1; i++)
+			regsty->rx_ampdu_sz_limit_by_nss_bw[nss - 1][i] = limit_by_bw[i];
+
+		rtw_rx_ampdu_apply(adapter);
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_80211N_HT */
+
+static int proc_get_udpport(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+
+	RTW_PRINT_SEL(m, "%d\n", precvpriv->sink_udpport);
+	return 0;
+}
+static ssize_t proc_set_udpport(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	int sink_udpport = 0;
+	char tmp[32];
+
+
+	if (!padapter)
+		return -EFAULT;
+
+	if (count < 1) {
+		RTW_INFO("argument size is less than 1\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d", &sink_udpport);
+
+		if (num !=  1) {
+			RTW_INFO("invalid input parameter number!\n");
+			return count;
+		}
+
+	}
+	precvpriv->sink_udpport = sink_udpport;
+
+	return count;
+
+}
+
+static int proc_get_mi_ap_bc_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	u8 i;
+
+	for (i = 0; i < dvobj->iface_nums; i++)
+		RTW_PRINT_SEL(m, "iface_id:%d, mac_id && sec_cam_id = %d\n", i, macid_ctl->iface_bmc[i]);
+
+	return 0;
+}
+static int proc_get_macid_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	u8 i;
+	u8 null_addr[ETH_ALEN] = {0};
+	u8 *macaddr;
+
+	RTW_PRINT_SEL(m, "max_num:%u\n", macid_ctl->num);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "used:\n");
+	dump_macid_map(m, &macid_ctl->used, macid_ctl->num);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "%-3s %-3s %-5s %-4s %-17s %-6s %-3s"
+		, "id", "bmc", "ifbmp", "ch_g", "macaddr", "bw", "vht");
+
+	if (hal_spec->tx_nss_num > 2)
+		_RTW_PRINT_SEL(m, " %-10s", "rate_bmp1");
+
+	_RTW_PRINT_SEL(m, " %-10s %s\n", "rate_bmp0", "status");
+
+	for (i = 0; i < macid_ctl->num; i++) {
+		if (rtw_macid_is_used(macid_ctl, i)
+			|| macid_ctl->h2c_msr[i]
+		) {
+			if (macid_ctl->sta[i])
+				macaddr = macid_ctl->sta[i]->cmn.mac_addr;
+			else
+				macaddr = null_addr;
+
+			RTW_PRINT_SEL(m, "%3u %3u  0x%02x %4d "MAC_FMT" %6s %3u"
+				, i
+				, rtw_macid_is_bmc(macid_ctl, i)
+				, rtw_macid_get_iface_bmp(macid_ctl, i)
+				, rtw_macid_get_ch_g(macid_ctl, i)
+				, MAC_ARG(macaddr)
+				, ch_width_str(macid_ctl->bw[i])
+				, macid_ctl->vht_en[i]
+			);
+
+			if (hal_spec->tx_nss_num > 2)
+				_RTW_PRINT_SEL(m, " 0x%08X", macid_ctl->rate_bmp1[i]);
+
+			_RTW_PRINT_SEL(m, " 0x%08X "H2C_MSR_FMT" %s\n"
+				, macid_ctl->rate_bmp0[i]
+				, H2C_MSR_ARG(&macid_ctl->h2c_msr[i])
+				, rtw_macid_is_used(macid_ctl, i) ? "" : "[unused]"
+			);
+		}
+	}
+
+	return 0;
+}
+
+static int proc_get_sec_cam(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+
+	RTW_PRINT_SEL(m, "sec_cap:0x%02x\n", cam_ctl->sec_cap);
+	RTW_PRINT_SEL(m, "flags:0x%08x\n", cam_ctl->flags);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "max_num:%u\n", cam_ctl->num);
+	RTW_PRINT_SEL(m, "used:\n");
+	dump_sec_cam_map(m, &cam_ctl->used, cam_ctl->num);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "reg_scr:0x%04x\n", rtw_read16(adapter, 0x680));
+	RTW_PRINT_SEL(m, "\n");
+
+	dump_sec_cam(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_sec_cam(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	char tmp[32] = {0};
+	char cmd[4];
+	u8 id_1 = 0, id_2 = 0;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		/* c <id_1>: clear specific cam entry */
+		/* wfc <id_1>: write specific cam entry from cam cache */
+		/* sw <id_1> <id_2>: sec_cam 1/2 swap */
+
+		int num = sscanf(tmp, "%s %hhu %hhu", cmd, &id_1, &id_2);
+
+		if (num < 2)
+			return count;
+
+		if ((id_1 >= cam_ctl->num) || (id_2 >= cam_ctl->num)) {
+			RTW_ERR(FUNC_ADPT_FMT" invalid id_1:%u id_2:%u\n", FUNC_ADPT_ARG(adapter), id_1, id_2);
+			return count;
+		}
+
+		if (strcmp("c", cmd) == 0) {
+			_clear_cam_entry(adapter, id_1);
+			adapter->securitypriv.hw_decrypted = _FALSE; /* temporarily set this for TX path to use SW enc */
+		} else if (strcmp("wfc", cmd) == 0)
+			write_cam_from_cache(adapter, id_1);
+		else if (strcmp("sw", cmd) == 0)
+			rtw_sec_cam_swap(adapter, id_1, id_2);
+		else if (strcmp("cdk", cmd) == 0)
+			rtw_clean_dk_section(adapter);
+#ifdef DBG_SEC_CAM_MOVE
+		else if (strcmp("sgd", cmd) == 0)
+			rtw_hal_move_sta_gk_to_dk(adapter);
+		else if (strcmp("rsd", cmd) == 0)
+			rtw_hal_read_sta_dk_key(adapter, id_1);
+#endif
+	}
+
+	return count;
+}
+
+static int proc_get_sec_cam_cache(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_sec_cam_cache(m, adapter);
+	return 0;
+}
+
+static ssize_t proc_set_change_bss_chbw(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
+	char tmp[32];
+	s16 ch;
+	s8 bw = -1, offset = -1;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hd %hhd %hhd", &ch, &bw, &offset);
+
+		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
+			goto exit;
+
+		if ((MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))
+			&& check_fwstate(mlme, WIFI_ASOC_STATE))
+			rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_WAIT_ACK, ch, bw, offset);
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_tx_bw_mode(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "0x%02x\n", adapter->driver_tx_bw_mode);
+	RTW_PRINT_SEL(m, "2.4G:%s\n", ch_width_str(ADAPTER_TX_BW_2G(adapter)));
+	RTW_PRINT_SEL(m, "5G:%s\n", ch_width_str(ADAPTER_TX_BW_5G(adapter)));
+
+	return 0;
+}
+
+static ssize_t proc_set_tx_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
+	char tmp[32];
+	u8 bw_mode;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		u8 update = _FALSE;
+		int num = sscanf(tmp, "%hhx", &bw_mode);
+
+		if (num < 1 || bw_mode == adapter->driver_tx_bw_mode)
+			goto exit;
+
+		if ((MLME_STATE(adapter) & WIFI_ASOC_STATE)
+			&& ((mlmeext->cur_channel <= 14 && BW_MODE_2G(bw_mode) != ADAPTER_TX_BW_2G(adapter))
+				|| (mlmeext->cur_channel >= 36 && BW_MODE_5G(bw_mode) != ADAPTER_TX_BW_5G(adapter)))
+		) {
+			/* RA mask update needed */
+			update = _TRUE;
+		}
+		adapter->driver_tx_bw_mode = bw_mode;
+
+		if (update == _TRUE) {
+			struct sta_info *sta;
+			int i;
+
+			for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
+				sta = macid_ctl->sta[i];
+				if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr))
+					rtw_dm_ra_mask_wk_cmd(adapter, (u8 *)sta);
+			}
+		}
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_hal_txpwr_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+
+	if (hal_is_band_support(adapter, BAND_ON_2_4G))
+		dump_hal_txpwr_info_2g(m, adapter, hal_spec->rfpath_num_2g, hal_spec->max_tx_cnt);
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (hal_is_band_support(adapter, BAND_ON_5G))
+		dump_hal_txpwr_info_5g(m, adapter, hal_spec->rfpath_num_5g, hal_spec->max_tx_cnt);
+#endif
+
+	return 0;
+}
+
+static int proc_get_target_tx_power(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_target_tx_power(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_tx_power_by_rate(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_tx_power_by_rate(m, adapter);
+
+	return 0;
+}
+
+#ifdef CONFIG_TXPWR_LIMIT
+static int proc_get_tx_power_limit(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_txpwr_lmt(m, adapter);
+
+	return 0;
+}
+#endif /* CONFIG_TXPWR_LIMIT */
+
+static int proc_get_tx_power_ext_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_tx_power_ext_info(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_tx_power_ext_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32] = {0};
+	char cmd[16] = {0};
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%s", cmd);
+
+		if (num < 1)
+			return count;
+
+		#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+		phy_free_filebuf_mask(adapter, LOAD_BB_PG_PARA_FILE | LOAD_RF_TXPWR_LMT_PARA_FILE);
+		#endif
+
+		rtw_ps_deny(adapter, PS_DENY_IOCTL);
+		if (rtw_pwr_wakeup(adapter) == _FALSE)
+			goto clear_ps_deny;
+
+		if (strcmp("default", cmd) == 0)
+			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_default_tx_power_ext_info)), adapter);
+		else
+			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_tx_power_ext_info)), adapter);
+
+clear_ps_deny:
+		rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+	}
+
+	return count;
+}
+
+static void *proc_start_tx_power_idx(struct seq_file *m, loff_t *pos)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 path = ((*pos) & 0xFF00) >> 8;
+	u8 rs = *pos & 0xFF;
+
+	if (path >= RF_PATH_MAX)
+		return NULL;
+
+	return pos;
+}
+static void proc_stop_tx_power_idx(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+}
+
+static void *proc_next_tx_power_idx(struct seq_file *m, void *v, loff_t *pos)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 path = ((*pos) & 0xFF00) >> 8;
+	u8 rs = *pos & 0xFF;
+
+	rs++;
+	if (rs >= RATE_SECTION_NUM) {
+		rs = 0;
+		path++;
+	}
+
+	if (path >= RF_PATH_MAX)
+		return NULL;
+
+	*pos = (path << 8) | rs;
+
+	return pos;
+}
+
+static int proc_get_tx_power_idx(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u32 pos = *((loff_t *)(v));
+	u8 path = (pos & 0xFF00) >> 8;
+	u8 rs = pos & 0xFF;
+
+	if (0)
+		RTW_INFO("%s path=%u, rs=%u\n", __func__, path, rs);
+
+	if (path == RF_PATH_A && rs == CCK)
+		dump_tx_power_idx_title(m, adapter);
+	dump_tx_power_idx_by_path_rs(m, adapter, path, rs);
+
+	return 0;
+}
+
+static struct seq_operations seq_ops_tx_power_idx = {
+	.start = proc_start_tx_power_idx,
+	.stop  = proc_stop_tx_power_idx,
+	.next  = proc_next_tx_power_idx,
+	.show  = proc_get_tx_power_idx,
+};
+
+#ifdef CONFIG_RF_POWER_TRIM
+static int proc_get_kfree_flag(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+
+	RTW_PRINT_SEL(m, "0x%02x\n", kfree_data->flag);
+
+	return 0;
+}
+
+static ssize_t proc_set_kfree_flag(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	char tmp[32] = {0};
+	u8 flag;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &flag);
+
+		if (num < 1)
+			return count;
+
+		kfree_data->flag = flag;
+	}
+
+	return count;
+}
+
+static int proc_get_kfree_bb_gain(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	u8 i, j;
+
+	for (i = 0; i < BB_GAIN_NUM; i++) {
+		if (i == 0)
+			_RTW_PRINT_SEL(m, "2G: ");
+		else if (i == 1)
+			_RTW_PRINT_SEL(m, "5GLB1: ");
+		else if (i == 2)
+			_RTW_PRINT_SEL(m, "5GLB2: ");
+		else if (i == 3)
+			_RTW_PRINT_SEL(m, "5GMB1: ");
+		else if (i == 4)
+			_RTW_PRINT_SEL(m, "5GMB2: ");
+		else if (i == 5)
+			_RTW_PRINT_SEL(m, "5GHB: ");
+
+		for (j = 0; j < hal_data->NumTotalRFPath; j++)
+			_RTW_PRINT_SEL(m, "%d ", kfree_data->bb_gain[i][j]);
+		_RTW_PRINT_SEL(m, "\n");
+	}
+
+	return 0;
+}
+
+static ssize_t proc_set_kfree_bb_gain(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	char tmp[BB_GAIN_NUM * RF_PATH_MAX] = {0};
+	u8 path, chidx;
+	s8 bb_gain[BB_GAIN_NUM];
+	char ch_band_Group[6];
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		char *c, *next;
+		int i = 0;
+
+		next = tmp;
+		c = strsep(&next, " \t");
+
+		if (sscanf(c, "%s", ch_band_Group) != 1) {
+			RTW_INFO("Error Head Format, channel Group select\n,Please input:\t 2G , 5GLB1 , 5GLB2 , 5GMB1 , 5GMB2 , 5GHB\n");
+			return count;
+		}
+		if (strcmp("2G", ch_band_Group) == 0)
+			chidx = BB_GAIN_2G;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		else if (strcmp("5GLB1", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GLB1;
+		else if (strcmp("5GLB2", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GLB2;
+		else if (strcmp("5GMB1", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GMB1;
+		else if (strcmp("5GMB2", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GMB2;
+		else if (strcmp("5GHB", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GHB;
+#endif /*CONFIG_IEEE80211_BAND_5GHZ*/
+		else {
+			RTW_INFO("Error Head Format, channel Group select\n,Please input:\t 2G , 5GLB1 , 5GLB2 , 5GMB1 , 5GMB2 , 5GHB\n");
+			return count;
+		}
+		c = strsep(&next, " \t");
+
+		while (c != NULL) {
+			if (sscanf(c, "%hhx", &bb_gain[i]) != 1)
+				break;
+
+			kfree_data->bb_gain[chidx][i] = bb_gain[i];
+			RTW_INFO("%s,kfree_data->bb_gain[%d][%d]=%x\n", __func__, chidx, i, kfree_data->bb_gain[chidx][i]);
+
+			c = strsep(&next, " \t");
+			i++;
+		}
+
+	}
+
+	return count;
+
+}
+
+static int proc_get_kfree_thermal(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+
+	_RTW_PRINT_SEL(m, "%d\n", kfree_data->thermal);
+
+	return 0;
+}
+
+static ssize_t proc_set_kfree_thermal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	char tmp[32] = {0};
+	s8 thermal;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhd", &thermal);
+
+		if (num < 1)
+			return count;
+
+		kfree_data->thermal = thermal;
+	}
+
+	return count;
+}
+
+static ssize_t proc_set_tx_gain_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter;
+	char tmp[32] = {0};
+	u8 rf_path;
+	s8 offset;
+
+	adapter = (_adapter *)rtw_netdev_priv(dev);
+	if (!adapter)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		u8 write_value;
+		int num = sscanf(tmp, "%hhu %hhd", &rf_path, &offset);
+
+		if (num < 2)
+			return count;
+
+		RTW_INFO("write rf_path:%u tx gain offset:%d\n", rf_path, offset);
+		rtw_rf_set_tx_gain_offset(adapter, rf_path, offset);
+	}
+
+	return count;
+}
+#endif /* CONFIG_RF_POWER_TRIM */
+
+#ifdef CONFIG_BT_COEXIST
+ssize_t proc_set_btinfo_evt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 btinfo[8];
+
+	if (count < 6)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = 0;
+
+		_rtw_memset(btinfo, 0, 8);
+
+		num = sscanf(tmp, "%hhx %hhx %hhx %hhx %hhx %hhx %hhx %hhx"
+			, &btinfo[0], &btinfo[1], &btinfo[2], &btinfo[3]
+			, &btinfo[4], &btinfo[5], &btinfo[6], &btinfo[7]);
+
+		if (num < 6)
+			return -EINVAL;
+
+		btinfo[1] = num - 2;
+
+		rtw_btinfo_cmd(padapter, btinfo, btinfo[1] + 2);
+	}
+
+	return count;
+}
+
+static u8 btreg_read_type = 0;
+static u16 btreg_read_addr = 0;
+static int btreg_read_error = 0;
+static u8 btreg_write_type = 0;
+static u16 btreg_write_addr = 0;
+static int btreg_write_error = 0;
+
+static u8 *btreg_type[] = {
+	"rf",
+	"modem",
+	"bluewize",
+	"vendor",
+	"le"
+};
+
+static int btreg_parse_str(char const *input, u8 *type, u16 *addr, u16 *val)
+{
+	u32 num;
+	u8 str[80] = {0};
+	u8 t = 0;
+	u32 a, v;
+	u8 i, n;
+	u8 *p;
+
+
+	num = sscanf(input, "%s %x %x", str, &a, &v);
+	if (num < 2) {
+		RTW_INFO("%s: INVALID input!(%s)\n", __FUNCTION__, input);
+		return -EINVAL;
+	}
+	if ((num < 3) && val) {
+		RTW_INFO("%s: INVALID input!(%s)\n", __FUNCTION__, input);
+		return -EINVAL;
+	}
+
+	/* convert to lower case for following type compare */
+	p = str;
+	for (; *p; ++p)
+		*p = tolower(*p);
+	n = sizeof(btreg_type) / sizeof(btreg_type[0]);
+	for (i = 0; i < n; i++) {
+		if (!strcmp(str, btreg_type[i])) {
+			t = i;
+			break;
+		}
+	}
+	if (i == n) {
+		RTW_INFO("%s: unknown type(%s)!\n", __FUNCTION__, str);
+		return -EINVAL;
+	}
+
+	switch (t) {
+	case 0:
+		/* RF */
+		if (a & 0xFFFFFF80) {
+			RTW_INFO("%s: INVALID address(0x%X) for type %s(%d)!\n",
+				 __FUNCTION__, a, btreg_type[t], t);
+			return -EINVAL;
+		}
+		break;
+	case 1:
+		/* Modem */
+		if (a & 0xFFFFFE00) {
+			RTW_INFO("%s: INVALID address(0x%X) for type %s(%d)!\n",
+				 __FUNCTION__, a, btreg_type[t], t);
+			return -EINVAL;
+		}
+		break;
+	default:
+		/* Others(Bluewize, Vendor, LE) */
+		if (a & 0xFFFFF000) {
+			RTW_INFO("%s: INVALID address(0x%X) for type %s(%d)!\n",
+				 __FUNCTION__, a, btreg_type[t], t);
+			return -EINVAL;
+		}
+		break;
+	}
+
+	if (val) {
+		if (v & 0xFFFF0000) {
+			RTW_INFO("%s: INVALID value(0x%x)!\n", __FUNCTION__, v);
+			return -EINVAL;
+		}
+		*val = (u16)v;
+	}
+
+	*type = (u8)t;
+	*addr = (u16)a;
+
+	return 0;
+}
+
+int proc_get_btreg_read(struct seq_file *m, void *v)
+{
+	struct net_device *dev;
+	PADAPTER padapter;
+	u16 ret;
+	u32 data;
+
+
+	if (btreg_read_error)
+		return btreg_read_error;
+
+	dev = m->private;
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	ret = rtw_btcoex_btreg_read(padapter, btreg_read_type, btreg_read_addr, &data);
+	if (CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X = 0x%08x\n", btreg_type[btreg_read_type], btreg_read_addr, data);
+	else
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X read fail. error code = 0x%04x.\n", btreg_type[btreg_read_type], btreg_read_addr, ret);
+
+	return 0;
+}
+
+ssize_t proc_set_btreg_read(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	PADAPTER padapter;
+	u8 tmp[80] = {0};
+	u32 num;
+	int err;
+
+
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	num = count;
+	if (num > (sizeof(tmp) - 1))
+		num = (sizeof(tmp) - 1);
+
+	if (copy_from_user(tmp, buffer, num)) {
+		RTW_INFO(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+	/* [Coverity] sure tmp end with '\0'(string terminal) */
+	tmp[sizeof(tmp) - 1] = 0;
+
+	err = btreg_parse_str(tmp, &btreg_read_type, &btreg_read_addr, NULL);
+	if (err)
+		goto exit;
+
+	RTW_INFO(FUNC_ADPT_FMT ": addr=(%s)0x%X\n",
+		FUNC_ADPT_ARG(padapter), btreg_type[btreg_read_type], btreg_read_addr);
+
+exit:
+	btreg_read_error = err;
+
+	return count;
+}
+
+int proc_get_btreg_write(struct seq_file *m, void *v)
+{
+	struct net_device *dev;
+	PADAPTER padapter;
+	u16 ret;
+	u32 data;
+
+
+	if (btreg_write_error < 0)
+		return btreg_write_error;
+	else if (btreg_write_error > 0) {
+		RTW_PRINT_SEL(m, "BTREG write: (%s)0x%04X write fail. error code = 0x%04x.\n", btreg_type[btreg_write_type], btreg_write_addr, btreg_write_error);
+		return 0;
+	}
+
+	dev = m->private;
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	ret = rtw_btcoex_btreg_read(padapter, btreg_write_type, btreg_write_addr, &data);
+	if (CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X = 0x%08x\n", btreg_type[btreg_write_type], btreg_write_addr, data);
+	else
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X read fail. error code = 0x%04x.\n", btreg_type[btreg_write_type], btreg_write_addr, ret);
+
+	return 0;
+}
+
+ssize_t proc_set_btreg_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	PADAPTER padapter;
+	u8 tmp[80] = {0};
+	u32 num;
+	u16 val;
+	u16 ret;
+	int err;
+
+
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	num = count;
+	if (num > (sizeof(tmp) - 1))
+		num = (sizeof(tmp) - 1);
+
+	if (copy_from_user(tmp, buffer, num)) {
+		RTW_INFO(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	err = btreg_parse_str(tmp, &btreg_write_type, &btreg_write_addr, &val);
+	if (err)
+		goto exit;
+
+	RTW_INFO(FUNC_ADPT_FMT ": Set (%s)0x%X = 0x%x\n",
+		FUNC_ADPT_ARG(padapter), btreg_type[btreg_write_type], btreg_write_addr, val);
+
+	ret = rtw_btcoex_btreg_write(padapter, btreg_write_type, btreg_write_addr, val);
+	if (!CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
+		err = ret;
+
+exit:
+	btreg_write_error = err;
+
+	return count;
+}
+#endif /* CONFIG_BT_COEXIST */
+
+#ifdef CONFIG_MBSSID_CAM
+int proc_get_mbid_cam_cache(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_mbid_cam_cache_dump(m, __func__, adapter);
+	rtw_mbid_cam_dump(m, __func__, adapter);
+	return 0;
+}
+#endif /* CONFIG_MBSSID_CAM */
+
+int proc_get_mac_addr(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_hal_dump_macaddr(m, adapter);
+	return 0;
+}
+
+static int proc_get_skip_band(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int bandskip;
+
+	bandskip = RTW_GET_SCAN_BAND_SKIP(adapter);
+	RTW_PRINT_SEL(m, "bandskip:0x%02x\n", bandskip);
+	return 0;
+}
+
+static ssize_t proc_set_skip_band(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[6];
+	u8 skip_band;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu", &skip_band);
+
+		if (num < 1)
+			return -EINVAL;
+
+		if (1 == skip_band)
+			RTW_SET_SCAN_BAND_SKIP(padapter, BAND_24G);
+		else if (2 == skip_band)
+			RTW_SET_SCAN_BAND_SKIP(padapter, BAND_5G);
+		else if (3 == skip_band)
+			RTW_CLR_SCAN_BAND_SKIP(padapter, BAND_24G);
+		else if (4 == skip_band)
+			RTW_CLR_SCAN_BAND_SKIP(padapter, BAND_5G);
+	}
+	return count;
+
+}
+
+#ifdef CONFIG_RTW_ACS
+static int proc_get_chan_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_acs_chan_info_dump(m, adapter);
+	return 0;
+}
+
+static int proc_get_best_chan(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (IS_ACS_ENABLE(adapter))
+		rtw_acs_info_dump(m, adapter);
+	else
+		_RTW_PRINT_SEL(m,"ACS disabled\n");
+	return 0;
+}
+
+static ssize_t proc_set_acs(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+#ifdef CONFIG_RTW_ACS_DBG
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 acs_state = 0;
+	u16 scan_ch_ms= 0, acs_scan_ch_ms = 0;
+	u8 scan_type = SCAN_ACTIVE, igi= 0, bw = 0;
+	u8 acs_scan_type = SCAN_ACTIVE, acs_igi= 0, acs_bw = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhu %hu %hhx %hhu",
+			&acs_state, &scan_type, &scan_ch_ms, &igi, &bw);
+
+		if (num < 1)
+			return -EINVAL;
+
+		if (acs_state)
+			rtw_acs_start(padapter);
+		else
+			rtw_acs_stop(padapter);
+		num = num -1;
+
+		if(num) {
+			if (num-- > 0)
+				acs_scan_type = scan_type;
+			if (num-- > 0)
+				acs_scan_ch_ms = scan_ch_ms;
+			if (num-- > 0)
+				acs_igi = igi;
+			if (num-- > 0)
+				acs_bw = bw;
+			rtw_acs_adv_setting(padapter, acs_scan_type, acs_scan_ch_ms, acs_igi, acs_bw);
+		}
+	}
+#endif /*CONFIG_RTW_ACS_DBG*/
+	return count;
+}
+#endif /*CONFIG_RTW_ACS*/
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+static int proc_get_nm(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_noise_info_dump(m, adapter);
+	return 0;
+}
+
+static ssize_t proc_set_nm(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 nm_state = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu", &nm_state);
+
+		if (num < 1)
+			return -EINVAL;
+
+		if (nm_state)
+			rtw_nm_enable(padapter);
+		else
+			rtw_nm_disable(padapter);
+
+	}
+	return count;
+}
+#endif /*CONFIG_RTW_ACS*/
+
+static int proc_get_hal_spec(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_hal_spec(m, adapter);
+	return 0;
+}
+
+static int proc_get_phy_cap(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_dump_phy_cap(m, adapter);
+	rtw_dump_drv_phy_cap(m, adapter);
+	rtw_get_dft_phy_cap(m, adapter);
+	return 0;
+}
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#include "../../hal/hal_halmac.h"
+static int proc_get_trx_share_mode(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_trx_share_mode(m, adapter);
+	return 0;
+}
+#endif
+
+static int proc_dump_rsvd_page(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_dump_rsvd_page(m, adapter, adapter->rsvd_page_offset, adapter->rsvd_page_num);
+	return 0;
+}
+static ssize_t proc_set_rsvd_page_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 page_offset, page_num;
+
+	if (count < 2)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhu", &page_offset, &page_num);
+
+		if (num < 2)
+			return -EINVAL;
+		padapter->rsvd_page_offset = page_offset;
+		padapter->rsvd_page_num = page_num;
+	}
+	return count;
+}
+
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+static int proc_dump_fifo(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_dump_fifo(m, adapter, adapter->fifo_sel, adapter->fifo_addr, adapter->fifo_size);
+	return 0;
+}
+static ssize_t proc_set_fifo_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 fifo_sel = 0;
+	u32 fifo_addr = 0;
+	u32 fifo_size = 0;
+
+	if (count < 3)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %x %d", &fifo_sel, &fifo_addr, &fifo_size);
+
+		if (num < 3)
+			return -EINVAL;
+
+		padapter->fifo_sel = fifo_sel;
+		padapter->fifo_addr = fifo_addr;
+		padapter->fifo_size = fifo_size;
+	}
+	return count;
+}
+#endif
+
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+int proc_dump_pattern_cam(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	int i;
+	struct  rtl_wow_pattern context;
+
+	for (i = 0 ; i < pwrpriv->wowlan_pattern_idx; i++) {
+		rtw_wow_pattern_read_cam_ent(padapter, i, &context);
+		rtw_dump_wow_pattern(m, &context, i);
+	}
+
+	return 0;
+}
+#endif
+
+static int proc_get_napi_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv *pregistrypriv = &adapter->registrypriv;
+	u8 napi = 0, gro = 0;
+	u32 weight = 0;
+	struct dvobj_priv *d;
+	d = adapter_to_dvobj(adapter);
+
+
+#ifdef CONFIG_RTW_NAPI
+	if (pregistrypriv->en_napi) {
+		napi = 1;
+		weight = RTL_NAPI_WEIGHT;
+	}
+
+#ifdef CONFIG_RTW_GRO
+	if (pregistrypriv->en_gro)
+		gro = 1;
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+	if (napi) {
+		RTW_PRINT_SEL(m, "NAPI enable, weight=%d\n", weight);
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+		RTW_PRINT_SEL(m, "Dynamaic NAPI mechanism is on, current NAPI %s\n",
+			      d->en_napi_dynamic ? "enable" : "disable");
+		RTW_PRINT_SEL(m, "Dynamaic NAPI info:\n"
+				 "\ttcp_rx_threshold = %d Mbps\n"
+				 "\tcur_rx_tp = %d Mbps\n",
+			      pregistrypriv->napi_threshold,
+			      d->traffic_stat.cur_rx_tp);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+	} else {
+		RTW_PRINT_SEL(m, "NAPI disable\n");
+	}
+	RTW_PRINT_SEL(m, "GRO %s\n", gro?"enable":"disable");
+
+	return 0;
+
+}
+
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+static ssize_t proc_set_napi_th(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	struct _ADAPTER *adapter = (struct _ADAPTER *)rtw_netdev_priv(dev);
+	struct registry_priv *registry = &adapter->registrypriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	PADAPTER iface = NULL;
+	char tmp[32] = {0};
+	int thrshld = 0;
+	int num = 0, i = 0;
+
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	RTW_INFO("%s: Last threshold = %d Mbps\n", __FUNCTION__, registry->napi_threshold);
+
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {	
+			if (buffer && !copy_from_user(tmp, buffer, count)) {
+				registry = &iface->registrypriv;
+				num = sscanf(tmp, "%d", &thrshld);
+				if (num > 0) {
+					if (thrshld > 0)
+						registry->napi_threshold = thrshld;
+				}
+			}
+		}
+	}
+	RTW_INFO("%s: New threshold = %d Mbps\n", __FUNCTION__, registry->napi_threshold);
+	RTW_INFO("%s: Current RX throughput = %d Mbps\n",
+		 __FUNCTION__, adapter_to_dvobj(adapter)->traffic_stat.cur_rx_tp);
+
+	return count;
+}
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+
+
+ssize_t proc_set_dynamic_agg_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	int enable = 0, i = 0;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+		PADAPTER iface = NULL;
+		int num = sscanf(tmp, "%d", &enable);
+
+		if (num !=  1) {
+			RTW_INFO("invalid parameter!\n");
+			return count;
+		}
+
+		RTW_INFO("dynamic_agg_enable:%d\n", enable);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface)
+				iface->registrypriv.dynamic_agg_enable = enable;
+		}
+
+	}
+
+	return count;
+
+}
+
+static int proc_get_dynamic_agg_enable(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv *pregistrypriv = &adapter->registrypriv;
+
+	RTW_PRINT_SEL(m, "dynamic_agg_enable:%d\n", pregistrypriv->dynamic_agg_enable);
+
+	return 0;
+}
+
+#ifdef CONFIG_RTW_MESH
+static int proc_get_mesh_peer_sel_policy(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_mesh_peer_sel_policy(m, adapter);
+
+	return 0;
+}
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+static int proc_get_mesh_peer_blacklist(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter)) {
+		dump_mesh_peer_blacklist_settings(m, adapter);
+		if (MLME_IS_ASOC(adapter))
+			dump_mesh_peer_blacklist(m, adapter);
+	}
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_peer_blacklist(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u32 conf_timeout_ms;
+		u32 blacklist_timeout_ms;
+		int num = sscanf(tmp, "%u %u", &conf_timeout_ms, &blacklist_timeout_ms);
+
+		if (num >= 1)
+			peer_sel_policy->peer_conf_timeout_ms = conf_timeout_ms;
+		if (num >= 2)
+			peer_sel_policy->peer_blacklist_timeout_ms = blacklist_timeout_ms;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+static int proc_get_mesh_cto_mgate_blacklist(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter)) {
+		dump_mesh_cto_mgate_blacklist_settings(m, adapter);
+		if (MLME_IS_ASOC(adapter))
+			dump_mesh_cto_mgate_blacklist(m, adapter);
+	}
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_cto_mgate_blacklist(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u8 require;
+		u32 conf_timeout_ms;
+		u32 blacklist_timeout_ms;
+		int num = sscanf(tmp, "%hhx %u %u", &require, &conf_timeout_ms, &blacklist_timeout_ms);
+
+		if (num >= 1)
+			peer_sel_policy->cto_mgate_require = require;
+		if (num >= 2)
+			peer_sel_policy->cto_mgate_conf_timeout_ms = conf_timeout_ms;
+		if (num >= 3)
+			peer_sel_policy->cto_mgate_blacklist_timeout_ms = blacklist_timeout_ms;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+static int proc_get_mesh_networks(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_mesh_networks(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_mesh_plink_ctl(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_plink_ctl(m, adapter);
+
+	return 0;
+}
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+static int proc_get_mesh_b2u_flags(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_b2u_flags(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_b2u_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+		u8 msrc, mfwd;
+		int num = sscanf(tmp, "%hhx %hhx", &msrc, &mfwd);
+
+		if (num >= 1)
+			mcfg->b2u_flags_msrc = msrc;
+		if (num >= 2)
+			mcfg->b2u_flags_mfwd = mfwd;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
+
+static int proc_get_mesh_stats(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_stats(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_mesh_gate_timeout(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		RTW_PRINT_SEL(m, "%u factor\n",
+			       adapter->mesh_cfg.path_gate_timeout_factor);
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_gate_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+		u32 timeout;
+		int num = sscanf(tmp, "%u", &timeout);
+
+		if (num < 1)
+			goto exit;
+
+		mcfg->path_gate_timeout_factor = timeout;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH */
+
+/*
+* rtw_adapter_proc:
+* init/deinit when register/unregister net_device
+*/
+const struct rtw_proc_hdl adapter_proc_hdls[] = {
+#if RTW_SEQ_FILE_TEST
+	RTW_PROC_HDL_SEQ("seq_file_test", &seq_file_test, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("write_reg", NULL, proc_set_write_reg),
+	RTW_PROC_HDL_SSEQ("read_reg", proc_get_read_reg, proc_set_read_reg),
+	RTW_PROC_HDL_SSEQ("tx_rate_bmp", proc_get_dump_tx_rate_bmp, NULL),
+	RTW_PROC_HDL_SSEQ("adapters_status", proc_get_dump_adapters_status, NULL),
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	RTW_PROC_HDL_SSEQ("customer_str", proc_get_customer_str, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("fwstate", proc_get_fwstate, NULL),
+	RTW_PROC_HDL_SSEQ("sec_info", proc_get_sec_info, NULL),
+	RTW_PROC_HDL_SSEQ("mlmext_state", proc_get_mlmext_state, NULL),
+	RTW_PROC_HDL_SSEQ("qos_option", proc_get_qos_option, NULL),
+	RTW_PROC_HDL_SSEQ("ht_option", proc_get_ht_option, NULL),
+	RTW_PROC_HDL_SSEQ("rf_info", proc_get_rf_info, NULL),
+	RTW_PROC_HDL_SSEQ("scan_param", proc_get_scan_param, proc_set_scan_param),
+	RTW_PROC_HDL_SSEQ("scan_abort", proc_get_scan_abort, NULL),
+#ifdef CONFIG_SCAN_BACKOP
+	RTW_PROC_HDL_SSEQ("backop_flags_sta", proc_get_backop_flags_sta, proc_set_backop_flags_sta),
+	RTW_PROC_HDL_SSEQ("backop_flags_ap", proc_get_backop_flags_ap, proc_set_backop_flags_ap),
+#endif
+#ifdef CONFIG_RTW_REPEATER_SON
+	RTW_PROC_HDL_SSEQ("rson_data", proc_get_rson_data, proc_set_rson_data),
+#endif
+	RTW_PROC_HDL_SSEQ("survey_info", proc_get_survey_info, proc_set_survey_info),
+	RTW_PROC_HDL_SSEQ("ap_info", proc_get_ap_info, NULL),
+	RTW_PROC_HDL_SSEQ("trx_info", proc_get_trx_info, proc_reset_trx_info),
+	RTW_PROC_HDL_SSEQ("tx_power_offset", proc_get_tx_power_offset, proc_set_tx_power_offset),
+	RTW_PROC_HDL_SSEQ("rate_ctl", proc_get_rate_ctl, proc_set_rate_ctl),
+	RTW_PROC_HDL_SSEQ("bw_ctl", proc_get_bw_ctl, proc_set_bw_ctl),
+	RTW_PROC_HDL_SSEQ("mac_qinfo", proc_get_mac_qinfo, NULL),
+	RTW_PROC_HDL_SSEQ("macid_info", proc_get_macid_info, NULL),
+	RTW_PROC_HDL_SSEQ("bcmc_info", proc_get_mi_ap_bc_info, NULL),
+	RTW_PROC_HDL_SSEQ("sec_cam", proc_get_sec_cam, proc_set_sec_cam),
+	RTW_PROC_HDL_SSEQ("sec_cam_cache", proc_get_sec_cam_cache, NULL),
+	RTW_PROC_HDL_SSEQ("ps_dbg_info", proc_get_ps_dbg_info, proc_set_ps_dbg_info),
+	RTW_PROC_HDL_SSEQ("wifi_spec", proc_get_wifi_spec, NULL),
+#ifdef CONFIG_LAYER2_ROAMING
+	RTW_PROC_HDL_SSEQ("roam_flags", proc_get_roam_flags, proc_set_roam_flags),
+	RTW_PROC_HDL_SSEQ("roam_param", proc_get_roam_param, proc_set_roam_param),
+	RTW_PROC_HDL_SSEQ("roam_tgt_addr", NULL, proc_set_roam_tgt_addr),
+#endif /* CONFIG_LAYER2_ROAMING */
+
+#ifdef CONFIG_RTW_80211R
+	RTW_PROC_HDL_SSEQ("ft_flags", proc_get_ft_flags, proc_set_ft_flags),
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+	RTW_PROC_HDL_SSEQ("sd_f0_reg_dump", proc_get_sd_f0_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("sdio_local_reg_dump", proc_get_sdio_local_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("sdio_card_info", proc_get_sdio_card_info, NULL),
+#endif /* CONFIG_SDIO_HCI */
+
+	RTW_PROC_HDL_SSEQ("fwdl_test_case", NULL, proc_set_fwdl_test_case),
+	RTW_PROC_HDL_SSEQ("del_rx_ampdu_test_case", NULL, proc_set_del_rx_ampdu_test_case),
+	RTW_PROC_HDL_SSEQ("wait_hiq_empty", NULL, proc_set_wait_hiq_empty),
+	RTW_PROC_HDL_SSEQ("sta_linking_test", NULL, proc_set_sta_linking_test),
+
+	RTW_PROC_HDL_SSEQ("mac_reg_dump", proc_get_mac_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("bb_reg_dump", proc_get_bb_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("bb_reg_dump_ex", proc_get_bb_reg_dump_ex, NULL),
+	RTW_PROC_HDL_SSEQ("rf_reg_dump", proc_get_rf_reg_dump, NULL),
+
+#ifdef CONFIG_RTW_LED
+	RTW_PROC_HDL_SSEQ("led_config", proc_get_led_config, proc_set_led_config),
+#endif
+
+#ifdef CONFIG_AP_MODE
+	RTW_PROC_HDL_SSEQ("aid_status", proc_get_aid_status, proc_set_aid_status),
+	RTW_PROC_HDL_SSEQ("all_sta_info", proc_get_all_sta_info, NULL),
+	RTW_PROC_HDL_SSEQ("bmc_tx_rate", proc_get_bmc_tx_rate, proc_set_bmc_tx_rate),
+#endif /* CONFIG_AP_MODE */
+
+#ifdef DBG_MEMORY_LEAK
+	RTW_PROC_HDL_SSEQ("_malloc_cnt", proc_get_malloc_cnt, NULL),
+#endif /* DBG_MEMORY_LEAK */
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	RTW_PROC_HDL_SSEQ("best_channel", proc_get_best_channel, proc_set_best_channel),
+#endif
+
+	RTW_PROC_HDL_SSEQ("rx_signal", proc_get_rx_signal, proc_set_rx_signal),
+	RTW_PROC_HDL_SSEQ("hw_info", proc_get_hw_status, proc_set_hw_status),
+
+#ifdef CONFIG_80211N_HT
+	RTW_PROC_HDL_SSEQ("ht_enable", proc_get_ht_enable, proc_set_ht_enable),
+	RTW_PROC_HDL_SSEQ("bw_mode", proc_get_bw_mode, proc_set_bw_mode),
+	RTW_PROC_HDL_SSEQ("ampdu_enable", proc_get_ampdu_enable, proc_set_ampdu_enable),
+	RTW_PROC_HDL_SSEQ("rx_ampdu", proc_get_rx_ampdu, proc_set_rx_ampdu),
+	RTW_PROC_HDL_SSEQ("rx_ampdu_size_limit", proc_get_rx_ampdu_size_limit, proc_set_rx_ampdu_size_limit),
+	RTW_PROC_HDL_SSEQ("rx_ampdu_factor", proc_get_rx_ampdu_factor, proc_set_rx_ampdu_factor),
+	RTW_PROC_HDL_SSEQ("rx_ampdu_density", proc_get_rx_ampdu_density, proc_set_rx_ampdu_density),
+	RTW_PROC_HDL_SSEQ("tx_ampdu_density", proc_get_tx_ampdu_density, proc_set_tx_ampdu_density),
+#ifdef CONFIG_TX_AMSDU
+	RTW_PROC_HDL_SSEQ("tx_amsdu", proc_get_tx_amsdu, proc_set_tx_amsdu),
+	RTW_PROC_HDL_SSEQ("tx_amsdu_rate", proc_get_tx_amsdu_rate, proc_set_tx_amsdu_rate),
+#endif
+#endif /* CONFIG_80211N_HT */
+	RTW_PROC_HDL_SSEQ("tx_max_agg_num", proc_get_tx_max_agg_num, proc_set_tx_max_agg_num),
+
+	RTW_PROC_HDL_SSEQ("en_fwps", proc_get_en_fwps, proc_set_en_fwps),
+	RTW_PROC_HDL_SSEQ("mac_rptbuf", proc_get_mac_rptbuf, NULL),
+
+	/* RTW_PROC_HDL_SSEQ("path_rssi", proc_get_two_path_rssi, NULL),
+	* 	RTW_PROC_HDL_SSEQ("rssi_disp",proc_get_rssi_disp, proc_set_rssi_disp), */
+
+#ifdef CONFIG_BT_COEXIST
+	RTW_PROC_HDL_SSEQ("btcoex_dbg", proc_get_btcoex_dbg, proc_set_btcoex_dbg),
+	RTW_PROC_HDL_SSEQ("btcoex", proc_get_btcoex_info, NULL),
+	RTW_PROC_HDL_SSEQ("btinfo_evt", NULL, proc_set_btinfo_evt),
+	RTW_PROC_HDL_SSEQ("btreg_read", proc_get_btreg_read, proc_set_btreg_read),
+	RTW_PROC_HDL_SSEQ("btreg_write", proc_get_btreg_write, proc_set_btreg_write),
+#ifdef CONFIG_RF4CE_COEXIST
+	RTW_PROC_HDL_SSEQ("rf4ce_state", proc_get_rf4ce_state, proc_set_rf4ce_state),
+#endif
+#endif /* CONFIG_BT_COEXIST */
+
+#if defined(DBG_CONFIG_ERROR_DETECT)
+	RTW_PROC_HDL_SSEQ("sreset", proc_get_sreset, proc_set_sreset),
+#endif /* DBG_CONFIG_ERROR_DETECT */
+	RTW_PROC_HDL_SSEQ("trx_info_debug", proc_get_trx_info_debug, NULL),
+	RTW_PROC_HDL_SSEQ("linked_info_dump", proc_get_linked_info_dump, proc_set_linked_info_dump),
+	RTW_PROC_HDL_SSEQ("sta_tp_dump", proc_get_sta_tp_dump, proc_set_sta_tp_dump),
+	RTW_PROC_HDL_SSEQ("sta_tp_info", proc_get_sta_tp_info, NULL),
+	RTW_PROC_HDL_SSEQ("dis_turboedca", proc_get_turboedca_ctrl, proc_set_turboedca_ctrl),
+	RTW_PROC_HDL_SSEQ("tx_info_msg", proc_get_tx_info_msg, NULL),
+	RTW_PROC_HDL_SSEQ("rx_info_msg", proc_get_rx_info_msg, proc_set_rx_info_msg),
+
+#ifdef CONFIG_GPIO_API
+	RTW_PROC_HDL_SSEQ("gpio_info", proc_get_gpio, proc_set_gpio),
+	RTW_PROC_HDL_SSEQ("gpio_set_output_value", NULL, proc_set_gpio_output_value),
+	RTW_PROC_HDL_SSEQ("gpio_set_direction", NULL, proc_set_config_gpio),
+#endif
+
+#ifdef CONFIG_DBG_COUNTER
+	RTW_PROC_HDL_SSEQ("rx_logs", proc_get_rx_logs, NULL),
+	RTW_PROC_HDL_SSEQ("tx_logs", proc_get_tx_logs, NULL),
+	RTW_PROC_HDL_SSEQ("int_logs", proc_get_int_logs, NULL),
+#endif
+
+#ifdef CONFIG_DBG_RF_CAL
+	RTW_PROC_HDL_SSEQ("iqk", proc_get_iqk_info, proc_set_iqk),
+	RTW_PROC_HDL_SSEQ("lck", proc_get_lck_info, proc_set_lck),
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	RTW_PROC_HDL_SSEQ("rx_ring", proc_get_rx_ring, NULL),
+	RTW_PROC_HDL_SSEQ("tx_ring", proc_get_tx_ring, NULL),
+#ifdef DBG_TXBD_DESC_DUMP
+	RTW_PROC_HDL_SSEQ("tx_ring_ext", proc_get_tx_ring_ext, proc_set_tx_ring_ext),
+#endif
+	RTW_PROC_HDL_SSEQ("pci_aspm", proc_get_pci_aspm, NULL),
+#endif
+
+#ifdef CONFIG_WOWLAN
+	RTW_PROC_HDL_SSEQ("wow_pattern_info", proc_get_pattern_info, proc_set_pattern_info),
+	RTW_PROC_HDL_SSEQ("wow_wakeup_event", proc_get_wakeup_event,
+			  proc_set_wakeup_event),
+	RTW_PROC_HDL_SSEQ("wowlan_last_wake_reason", proc_get_wakeup_reason, NULL),
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+	RTW_PROC_HDL_SSEQ("wow_pattern_cam", proc_dump_pattern_cam, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("dis_wow_lps", proc_get_wow_lps_ctrl, proc_set_wow_lps_ctrl),
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	RTW_PROC_HDL_SSEQ("wowlan_gpio_info", proc_get_wowlan_gpio_info, proc_set_wowlan_gpio_info),
+#endif
+#ifdef CONFIG_P2P_WOWLAN
+	RTW_PROC_HDL_SSEQ("p2p_wowlan_info", proc_get_p2p_wowlan_info, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("country_code", proc_get_country_code, proc_set_country_code),
+	RTW_PROC_HDL_SSEQ("chan_plan", proc_get_chan_plan, proc_set_chan_plan),
+#if CONFIG_RTW_MACADDR_ACL
+	RTW_PROC_HDL_SSEQ("macaddr_acl", proc_get_macaddr_acl, proc_set_macaddr_acl),
+#endif
+#if CONFIG_RTW_PRE_LINK_STA
+	RTW_PROC_HDL_SSEQ("pre_link_sta", proc_get_pre_link_sta, proc_set_pre_link_sta),
+#endif
+	RTW_PROC_HDL_SSEQ("ch_sel_policy", proc_get_ch_sel_policy, proc_set_ch_sel_policy),
+#ifdef CONFIG_DFS_MASTER
+	RTW_PROC_HDL_SSEQ("dfs_master_test_case", proc_get_dfs_master_test_case, proc_set_dfs_master_test_case),
+	RTW_PROC_HDL_SSEQ("update_non_ocp", NULL, proc_set_update_non_ocp),
+	RTW_PROC_HDL_SSEQ("radar_detect", NULL, proc_set_radar_detect),
+	RTW_PROC_HDL_SSEQ("dfs_ch_sel_d_flags", proc_get_dfs_ch_sel_d_flags, proc_set_dfs_ch_sel_d_flags),
+#endif
+	RTW_PROC_HDL_SSEQ("new_bcn_max", proc_get_new_bcn_max, proc_set_new_bcn_max),
+	RTW_PROC_HDL_SSEQ("sink_udpport", proc_get_udpport, proc_set_udpport),
+#ifdef DBG_RX_COUNTER_DUMP
+	RTW_PROC_HDL_SSEQ("dump_rx_cnt_mode", proc_get_rx_cnt_dump, proc_set_rx_cnt_dump),
+#endif
+	RTW_PROC_HDL_SSEQ("change_bss_chbw", NULL, proc_set_change_bss_chbw),
+	RTW_PROC_HDL_SSEQ("tx_bw_mode", proc_get_tx_bw_mode, proc_set_tx_bw_mode),
+	RTW_PROC_HDL_SSEQ("hal_txpwr_info", proc_get_hal_txpwr_info, NULL),
+	RTW_PROC_HDL_SSEQ("target_tx_power", proc_get_target_tx_power, NULL),
+	RTW_PROC_HDL_SSEQ("tx_power_by_rate", proc_get_tx_power_by_rate, NULL),
+#ifdef CONFIG_TXPWR_LIMIT
+	RTW_PROC_HDL_SSEQ("tx_power_limit", proc_get_tx_power_limit, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("tx_power_ext_info", proc_get_tx_power_ext_info, proc_set_tx_power_ext_info),
+	RTW_PROC_HDL_SEQ("tx_power_idx", &seq_ops_tx_power_idx, NULL),
+#ifdef CONFIG_RF_POWER_TRIM
+	RTW_PROC_HDL_SSEQ("tx_gain_offset", NULL, proc_set_tx_gain_offset),
+	RTW_PROC_HDL_SSEQ("kfree_flag", proc_get_kfree_flag, proc_set_kfree_flag),
+	RTW_PROC_HDL_SSEQ("kfree_bb_gain", proc_get_kfree_bb_gain, proc_set_kfree_bb_gain),
+	RTW_PROC_HDL_SSEQ("kfree_thermal", proc_get_kfree_thermal, proc_set_kfree_thermal),
+#endif
+#ifdef CONFIG_POWER_SAVING
+	RTW_PROC_HDL_SSEQ("ps_info", proc_get_ps_info, NULL),
+#ifdef CONFIG_WMMPS_STA
+	RTW_PROC_HDL_SSEQ("wmmps_info", proc_get_wmmps_info, proc_set_wmmps_info),
+#endif /* CONFIG_WMMPS_STA */	
+#endif
+#ifdef CONFIG_TDLS
+	RTW_PROC_HDL_SSEQ("tdls_info", proc_get_tdls_info, NULL),
+	RTW_PROC_HDL_SSEQ("tdls_enable", proc_get_tdls_enable, proc_set_tdls_enable),
+#endif
+	RTW_PROC_HDL_SSEQ("monitor", proc_get_monitor, proc_set_monitor),
+
+#ifdef CONFIG_RTW_ACS
+	RTW_PROC_HDL_SSEQ("acs", proc_get_best_chan, proc_set_acs),
+	RTW_PROC_HDL_SSEQ("chan_info", proc_get_chan_info, NULL),
+#endif
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	RTW_PROC_HDL_SSEQ("noise_monitor", proc_get_nm, proc_set_nm),
+#endif
+
+#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+	RTW_PROC_HDL_SSEQ("rtkm_info", proc_get_rtkm_info, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("efuse_map", proc_get_efuse_map, NULL),
+#ifdef CONFIG_IEEE80211W
+	RTW_PROC_HDL_SSEQ("11w_tx_sa_query", proc_get_tx_sa_query, proc_set_tx_sa_query),
+	RTW_PROC_HDL_SSEQ("11w_tx_deauth", proc_get_tx_deauth, proc_set_tx_deauth),
+	RTW_PROC_HDL_SSEQ("11w_tx_auth", proc_get_tx_auth, proc_set_tx_auth),
+#endif /* CONFIG_IEEE80211W */
+
+#ifdef CONFIG_MBSSID_CAM
+	RTW_PROC_HDL_SSEQ("mbid_cam", proc_get_mbid_cam_cache, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("mac_addr", proc_get_mac_addr, NULL),
+	RTW_PROC_HDL_SSEQ("skip_band", proc_get_skip_band, proc_set_skip_band),
+	RTW_PROC_HDL_SSEQ("hal_spec", proc_get_hal_spec, NULL),
+
+	RTW_PROC_HDL_SSEQ("rx_stat", proc_get_rx_stat, NULL),
+
+	RTW_PROC_HDL_SSEQ("tx_stat", proc_get_tx_stat, NULL),
+	/**** PHY Capability ****/
+	RTW_PROC_HDL_SSEQ("phy_cap", proc_get_phy_cap, NULL),
+
+	RTW_PROC_HDL_SSEQ("rx_stbc", proc_get_rx_stbc, proc_set_rx_stbc),
+	RTW_PROC_HDL_SSEQ("stbc_cap", proc_get_stbc_cap, proc_set_stbc_cap),
+	RTW_PROC_HDL_SSEQ("ldpc_cap", proc_get_ldpc_cap, proc_set_ldpc_cap),
+#ifdef CONFIG_BEAMFORMING
+	RTW_PROC_HDL_SSEQ("txbf_cap", proc_get_txbf_cap, proc_set_txbf_cap),
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	RTW_PROC_HDL_SSEQ("trx_share_mode", proc_get_trx_share_mode, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("napi_info", proc_get_napi_info, NULL),
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	RTW_PROC_HDL_SSEQ("napi_th", proc_get_napi_info, proc_set_napi_th),
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+
+	RTW_PROC_HDL_SSEQ("rsvd_page", proc_dump_rsvd_page, proc_set_rsvd_page_info),
+
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+	RTW_PROC_HDL_SSEQ("fifo_dump", proc_dump_fifo, proc_set_fifo_info),
+#endif
+	RTW_PROC_HDL_SSEQ("fw_info", proc_get_fw_info, NULL),
+
+#ifdef DBG_XMIT_BLOCK
+	RTW_PROC_HDL_SSEQ("xmit_block", proc_get_xmit_block, proc_set_xmit_block),
+#endif
+
+	RTW_PROC_HDL_SSEQ("ack_timeout", proc_get_ack_timeout, proc_set_ack_timeout),
+
+	RTW_PROC_HDL_SSEQ("dynamic_agg_enable", proc_get_dynamic_agg_enable, proc_set_dynamic_agg_enable),
+	RTW_PROC_HDL_SSEQ("fw_offload", proc_get_fw_offload, proc_set_fw_offload),
+
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	RTW_PROC_HDL_SSEQ("mesh_peer_blacklist", proc_get_mesh_peer_blacklist, proc_set_mesh_peer_blacklist),
+	#endif
+	#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	RTW_PROC_HDL_SSEQ("mesh_cto_mgate_blacklist", proc_get_mesh_cto_mgate_blacklist, proc_set_mesh_cto_mgate_blacklist),
+	#endif
+	RTW_PROC_HDL_SSEQ("mesh_peer_sel_policy", proc_get_mesh_peer_sel_policy, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_networks", proc_get_mesh_networks, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_plink_ctl", proc_get_mesh_plink_ctl, NULL),
+	#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	RTW_PROC_HDL_SSEQ("mesh_b2u_flags", proc_get_mesh_b2u_flags, proc_set_mesh_b2u_flags),
+	#endif
+	RTW_PROC_HDL_SSEQ("mesh_stats", proc_get_mesh_stats, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_gate_timeout_factor", proc_get_mesh_gate_timeout, proc_set_mesh_gate_timeout),
+#endif
+};
+
+const int adapter_proc_hdls_num = sizeof(adapter_proc_hdls) / sizeof(struct rtw_proc_hdl);
+
+static int rtw_adapter_proc_open(struct inode *inode, struct file *file)
+{
+	ssize_t index = (ssize_t)PDE_DATA(inode);
+	const struct rtw_proc_hdl *hdl = adapter_proc_hdls + index;
+	void *private = proc_get_parent_data(inode);
+
+	if (hdl->type == RTW_PROC_HDL_TYPE_SEQ) {
+		int res = seq_open(file, hdl->u.seq_op);
+
+		if (res == 0)
+			((struct seq_file *)file->private_data)->private = private;
+
+		return res;
+	} else if (hdl->type == RTW_PROC_HDL_TYPE_SSEQ) {
+		int (*show)(struct seq_file *, void *) = hdl->u.show ? hdl->u.show : proc_get_dummy;
+
+		return single_open(file, show, private);
+	} else {
+		return -EROFS;
+	}
+}
+
+static ssize_t rtw_adapter_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)
+{
+	ssize_t index = (ssize_t)PDE_DATA(file_inode(file));
+	const struct rtw_proc_hdl *hdl = adapter_proc_hdls + index;
+	ssize_t (*write)(struct file *, const char __user *, size_t, loff_t *, void *) = hdl->write;
+
+	if (write)
+		return write(file, buffer, count, pos, ((struct seq_file *)file->private_data)->private);
+
+	return -EROFS;
+}
+
+static const struct file_operations rtw_adapter_proc_seq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_adapter_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = seq_release,
+	.write = rtw_adapter_proc_write,
+};
+
+static const struct file_operations rtw_adapter_proc_sseq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_adapter_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = single_release,
+	.write = rtw_adapter_proc_write,
+};
+
+int proc_get_odm_adaptivity(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_odm_adaptivity_parm_msg(m, padapter);
+
+	return 0;
+}
+
+ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u32 th_l2h_ini;
+	u32 th_l2h_ini_mode2;
+	s8 th_edcca_hl_diff;
+	s8 th_edcca_hl_diff_mode2;
+	u8 edcca_enable;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%x %hhd %x %hhd %hhu", &th_l2h_ini, &th_edcca_hl_diff, &th_l2h_ini_mode2, &th_edcca_hl_diff_mode2, &edcca_enable);
+
+		if (num != 5)
+			return count;
+
+		rtw_odm_adaptivity_parm_set(padapter, (s8)th_l2h_ini, th_edcca_hl_diff, (s8)th_l2h_ini_mode2, th_edcca_hl_diff_mode2, edcca_enable);
+	}
+
+	return count;
+}
+
+static char *phydm_msg = NULL;
+#define PHYDM_MSG_LEN	80*24
+
+int proc_get_phydm_cmd(struct seq_file *m, void *v)
+{
+	struct net_device *netdev;
+	PADAPTER padapter;
+	struct dm_struct *phydm;
+
+
+	netdev = m->private;
+	padapter = (PADAPTER)rtw_netdev_priv(netdev);
+	phydm = adapter_to_phydm(padapter);
+
+	if (NULL == phydm_msg) {
+		phydm_msg = rtw_zmalloc(PHYDM_MSG_LEN);
+		if (NULL == phydm_msg)
+			return -ENOMEM;
+
+		phydm_cmd(phydm, NULL, 0, 0, phydm_msg, PHYDM_MSG_LEN);
+	}
+
+	_RTW_PRINT_SEL(m, "%s\n", phydm_msg);
+
+	rtw_mfree(phydm_msg, PHYDM_MSG_LEN);
+	phydm_msg = NULL;
+
+	return 0;
+}
+
+ssize_t proc_set_phydm_cmd(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *netdev;
+	PADAPTER padapter;
+	struct dm_struct *phydm;
+	char tmp[64] = {0};
+
+
+	netdev = (struct net_device *)data;
+	padapter = (PADAPTER)rtw_netdev_priv(netdev);
+	phydm = adapter_to_phydm(padapter);
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp))
+		return -EFAULT;
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		if (NULL == phydm_msg) {
+			phydm_msg = rtw_zmalloc(PHYDM_MSG_LEN);
+			if (NULL == phydm_msg)
+				return -ENOMEM;
+		} else
+			_rtw_memset(phydm_msg, 0, PHYDM_MSG_LEN);
+
+		phydm_cmd(phydm, tmp, count, 1, phydm_msg, PHYDM_MSG_LEN);
+
+		if (strlen(phydm_msg) == 0) {
+			rtw_mfree(phydm_msg, PHYDM_MSG_LEN);
+			phydm_msg = NULL;
+		}
+	}
+
+	return count;
+}
+
+/*
+* rtw_odm_proc:
+* init/deinit when register/unregister net_device, along with rtw_adapter_proc
+*/
+const struct rtw_proc_hdl odm_proc_hdls[] = {
+	RTW_PROC_HDL_SSEQ("adaptivity", proc_get_odm_adaptivity, proc_set_odm_adaptivity),
+	RTW_PROC_HDL_SSEQ("cmd", proc_get_phydm_cmd, proc_set_phydm_cmd),
+};
+
+const int odm_proc_hdls_num = sizeof(odm_proc_hdls) / sizeof(struct rtw_proc_hdl);
+
+static int rtw_odm_proc_open(struct inode *inode, struct file *file)
+{
+	ssize_t index = (ssize_t)PDE_DATA(inode);
+	const struct rtw_proc_hdl *hdl = odm_proc_hdls + index;
+	void *private = proc_get_parent_data(inode);
+
+	if (hdl->type == RTW_PROC_HDL_TYPE_SEQ) {
+		int res = seq_open(file, hdl->u.seq_op);
+
+		if (res == 0)
+			((struct seq_file *)file->private_data)->private = private;
+
+		return res;
+	} else if (hdl->type == RTW_PROC_HDL_TYPE_SSEQ) {
+		int (*show)(struct seq_file *, void *) = hdl->u.show ? hdl->u.show : proc_get_dummy;
+
+		return single_open(file, show, private);
+	} else {
+		return -EROFS;
+	}
+}
+
+static ssize_t rtw_odm_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)
+{
+	ssize_t index = (ssize_t)PDE_DATA(file_inode(file));
+	const struct rtw_proc_hdl *hdl = odm_proc_hdls + index;
+	ssize_t (*write)(struct file *, const char __user *, size_t, loff_t *, void *) = hdl->write;
+
+	if (write)
+		return write(file, buffer, count, pos, ((struct seq_file *)file->private_data)->private);
+
+	return -EROFS;
+}
+
+static const struct file_operations rtw_odm_proc_seq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_odm_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = seq_release,
+	.write = rtw_odm_proc_write,
+};
+
+static const struct file_operations rtw_odm_proc_sseq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_odm_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = single_release,
+	.write = rtw_odm_proc_write,
+};
+
+struct proc_dir_entry *rtw_odm_proc_init(struct net_device *dev)
+{
+	struct proc_dir_entry *dir_odm = NULL;
+	struct proc_dir_entry *entry = NULL;
+	_adapter	*adapter = rtw_netdev_priv(dev);
+	ssize_t i;
+
+	if (adapter->dir_dev == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (adapter->dir_odm != NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	dir_odm = rtw_proc_create_dir("odm", adapter->dir_dev, dev);
+	if (dir_odm == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	adapter->dir_odm = dir_odm;
+
+	for (i = 0; i < odm_proc_hdls_num; i++) {
+		if (odm_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SEQ)
+			entry = rtw_proc_create_entry(odm_proc_hdls[i].name, dir_odm, &rtw_odm_proc_seq_fops, (void *)i);
+		else if (odm_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SSEQ)
+			entry = rtw_proc_create_entry(odm_proc_hdls[i].name, dir_odm, &rtw_odm_proc_sseq_fops, (void *)i);
+		else
+			entry = NULL;
+
+		if (!entry) {
+			rtw_warn_on(1);
+			goto exit;
+		}
+	}
+
+exit:
+	return dir_odm;
+}
+
+void rtw_odm_proc_deinit(_adapter	*adapter)
+{
+	struct proc_dir_entry *dir_odm = NULL;
+	int i;
+
+	dir_odm = adapter->dir_odm;
+
+	if (dir_odm == NULL) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	for (i = 0; i < odm_proc_hdls_num; i++)
+		remove_proc_entry(odm_proc_hdls[i].name, dir_odm);
+
+	remove_proc_entry("odm", adapter->dir_dev);
+
+	adapter->dir_odm = NULL;
+
+	if (phydm_msg) {
+		rtw_mfree(phydm_msg, PHYDM_MSG_LEN);
+		phydm_msg = NULL;
+	}
+}
+
+#ifdef CONFIG_MCC_MODE
+/*
+* rtw_mcc_proc:
+* init/deinit when register/unregister net_device, along with rtw_adapter_proc
+*/
+const struct rtw_proc_hdl mcc_proc_hdls[] = {
+	RTW_PROC_HDL_SSEQ("mcc_info", proc_get_mcc_info, NULL),
+	RTW_PROC_HDL_SSEQ("mcc_enable", proc_get_mcc_info, proc_set_mcc_enable),
+	RTW_PROC_HDL_SSEQ("mcc_duration", proc_get_mcc_info, proc_set_mcc_duration),
+	RTW_PROC_HDL_SSEQ("mcc_single_tx_criteria", proc_get_mcc_info, proc_set_mcc_single_tx_criteria),
+	RTW_PROC_HDL_SSEQ("mcc_ap_bw20_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw20_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_ap_bw40_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw40_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_ap_bw80_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw80_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_sta_bw20_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw20_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_sta_bw40_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw40_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_sta_bw80_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw80_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_policy_table", proc_get_mcc_policy_table, NULL),
+};
+
+const int mcc_proc_hdls_num = sizeof(mcc_proc_hdls) / sizeof(struct rtw_proc_hdl);
+
+static int rtw_mcc_proc_open(struct inode *inode, struct file *file)
+{
+	ssize_t index = (ssize_t)PDE_DATA(inode);
+	const struct rtw_proc_hdl *hdl = mcc_proc_hdls + index;
+	void *private = proc_get_parent_data(inode);
+
+	if (hdl->type == RTW_PROC_HDL_TYPE_SEQ) {
+		int res = seq_open(file, hdl->u.seq_op);
+
+		if (res == 0)
+			((struct seq_file *)file->private_data)->private = private;
+
+		return res;
+	} else if (hdl->type == RTW_PROC_HDL_TYPE_SSEQ) {
+		int (*show)(struct seq_file *, void *) = hdl->u.show ? hdl->u.show : proc_get_dummy;
+
+		return single_open(file, show, private);
+	} else {
+		return -EROFS;
+	}
+}
+
+static ssize_t rtw_mcc_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)
+{
+	ssize_t index = (ssize_t)PDE_DATA(file_inode(file));
+	const struct rtw_proc_hdl *hdl = mcc_proc_hdls + index;
+	ssize_t (*write)(struct file *, const char __user *, size_t, loff_t *, void *) = hdl->write;
+
+	if (write)
+		return write(file, buffer, count, pos, ((struct seq_file *)file->private_data)->private);
+
+	return -EROFS;
+}
+
+static const struct file_operations rtw_mcc_proc_seq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_mcc_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = seq_release,
+	.write = rtw_mcc_proc_write,
+};
+
+static const struct file_operations rtw_mcc_proc_sseq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_mcc_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = single_release,
+	.write = rtw_mcc_proc_write,
+};
+
+struct proc_dir_entry *rtw_mcc_proc_init(struct net_device *dev)
+{
+	struct proc_dir_entry *dir_mcc = NULL;
+	struct proc_dir_entry *entry = NULL;
+	_adapter	*adapter = rtw_netdev_priv(dev);
+	ssize_t i;
+
+	if (adapter->dir_dev == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (adapter->dir_mcc != NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	dir_mcc = rtw_proc_create_dir("mcc", adapter->dir_dev, dev);
+	if (dir_mcc == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	adapter->dir_mcc = dir_mcc;
+
+	for (i = 0; i < mcc_proc_hdls_num; i++) {
+		if (mcc_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SEQ)
+			entry = rtw_proc_create_entry(mcc_proc_hdls[i].name, dir_mcc, &rtw_mcc_proc_seq_fops, (void *)i);
+		else if (mcc_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SSEQ)
+			entry = rtw_proc_create_entry(mcc_proc_hdls[i].name, dir_mcc, &rtw_mcc_proc_sseq_fops, (void *)i);
+		else
+			entry = NULL;
+
+		if (!entry) {
+			rtw_warn_on(1);
+			goto exit;
+		}
+	}
+
+exit:
+	return dir_mcc;
+}
+
+void rtw_mcc_proc_deinit(_adapter	*adapter)
+{
+	struct proc_dir_entry *dir_mcc = NULL;
+	int i;
+
+	dir_mcc = adapter->dir_mcc;
+
+	if (dir_mcc == NULL) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	for (i = 0; i < mcc_proc_hdls_num; i++)
+		remove_proc_entry(mcc_proc_hdls[i].name, dir_mcc);
+
+	remove_proc_entry("mcc", adapter->dir_dev);
+
+	adapter->dir_mcc = NULL;
+}
+#endif /* CONFIG_MCC_MODE */
+
+struct proc_dir_entry *rtw_adapter_proc_init(struct net_device *dev)
+{
+	struct proc_dir_entry *drv_proc = get_rtw_drv_proc();
+	struct proc_dir_entry *dir_dev = NULL;
+	struct proc_dir_entry *entry = NULL;
+	_adapter *adapter = rtw_netdev_priv(dev);
+	u8 rf_type;
+	ssize_t i;
+
+	if (drv_proc == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (adapter->dir_dev != NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	dir_dev = rtw_proc_create_dir(dev->name, drv_proc, dev);
+	if (dir_dev == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	adapter->dir_dev = dir_dev;
+
+	for (i = 0; i < adapter_proc_hdls_num; i++) {
+		if (adapter_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SEQ)
+			entry = rtw_proc_create_entry(adapter_proc_hdls[i].name, dir_dev, &rtw_adapter_proc_seq_fops, (void *)i);
+		else if (adapter_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SSEQ)
+			entry = rtw_proc_create_entry(adapter_proc_hdls[i].name, dir_dev, &rtw_adapter_proc_sseq_fops, (void *)i);
+		else
+			entry = NULL;
+
+		if (!entry) {
+			rtw_warn_on(1);
+			goto exit;
+		}
+	}
+
+	rtw_odm_proc_init(dev);
+
+#ifdef CONFIG_MCC_MODE
+	rtw_mcc_proc_init(dev);
+#endif /* CONFIG_MCC_MODE */
+
+exit:
+	return dir_dev;
+}
+
+void rtw_adapter_proc_deinit(struct net_device *dev)
+{
+	struct proc_dir_entry *drv_proc = get_rtw_drv_proc();
+	struct proc_dir_entry *dir_dev = NULL;
+	_adapter *adapter = rtw_netdev_priv(dev);
+	int i;
+
+	dir_dev = adapter->dir_dev;
+
+	if (dir_dev == NULL) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	for (i = 0; i < adapter_proc_hdls_num; i++)
+		remove_proc_entry(adapter_proc_hdls[i].name, dir_dev);
+
+	rtw_odm_proc_deinit(adapter);
+
+#ifdef CONFIG_MCC_MODE
+	rtw_mcc_proc_deinit(adapter);
+#endif /* CONFIG_MCC_MODE */
+
+	remove_proc_entry(dev->name, drv_proc);
+
+	adapter->dir_dev = NULL;
+}
+
+void rtw_adapter_proc_replace(struct net_device *dev)
+{
+	struct proc_dir_entry *drv_proc = get_rtw_drv_proc();
+	struct proc_dir_entry *dir_dev = NULL;
+	_adapter *adapter = rtw_netdev_priv(dev);
+	int i;
+
+	dir_dev = adapter->dir_dev;
+
+	if (dir_dev == NULL) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	for (i = 0; i < adapter_proc_hdls_num; i++)
+		remove_proc_entry(adapter_proc_hdls[i].name, dir_dev);
+
+	rtw_odm_proc_deinit(adapter);
+
+#ifdef CONFIG_MCC_MODE
+	rtw_mcc_proc_deinit(adapter);
+#endif /* CONIG_MCC_MODE */
+
+	remove_proc_entry(adapter->old_ifname, drv_proc);
+
+	adapter->dir_dev = NULL;
+
+	rtw_adapter_proc_init(dev);
+
+}
+
+#endif /* CONFIG_PROC_DEBUG */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_proc.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_proc.h
new file mode 100644
index 000000000000..c2c7c8ed8b8e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_proc.h
@@ -0,0 +1,60 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PROC_H__
+#define __RTW_PROC_H__
+
+#include <linux/proc_fs.h>
+#include <linux/seq_file.h>
+
+#define RTW_PROC_HDL_TYPE_SEQ	0
+#define RTW_PROC_HDL_TYPE_SSEQ	1
+
+struct rtw_proc_hdl {
+	char *name;
+	u8 type;
+	union {
+		int (*show)(struct seq_file *, void *);
+		struct seq_operations *seq_op;
+	} u;
+	ssize_t (*write)(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+};
+
+#define RTW_PROC_HDL_SEQ(_name, _seq_op, _write) \
+	{ .name = _name, .type = RTW_PROC_HDL_TYPE_SEQ, .u.seq_op = _seq_op, .write = _write}
+
+#define RTW_PROC_HDL_SSEQ(_name, _show, _write) \
+	{ .name = _name, .type = RTW_PROC_HDL_TYPE_SSEQ, .u.show = _show, .write = _write}
+
+#ifdef CONFIG_PROC_DEBUG
+
+struct proc_dir_entry *get_rtw_drv_proc(void);
+int rtw_drv_proc_init(void);
+void rtw_drv_proc_deinit(void);
+struct proc_dir_entry *rtw_adapter_proc_init(struct net_device *dev);
+void rtw_adapter_proc_deinit(struct net_device *dev);
+void rtw_adapter_proc_replace(struct net_device *dev);
+
+#else /* !CONFIG_PROC_DEBUG */
+
+#define get_rtw_drv_proc() NULL
+#define rtw_drv_proc_init() 0
+#define rtw_drv_proc_deinit() do {} while (0)
+#define rtw_adapter_proc_init(dev) NULL
+#define rtw_adapter_proc_deinit(dev) do {} while (0)
+#define rtw_adapter_proc_replace(dev) do {} while (0)
+
+#endif /* !CONFIG_PROC_DEBUG */
+
+#endif /* __RTW_PROC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_rhashtable.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_rhashtable.c
new file mode 100644
index 000000000000..4d51f048227c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_rhashtable.c
@@ -0,0 +1,74 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#ifdef CONFIG_RTW_MESH /* for now, only promised for kernel versions we support mesh */
+
+#include <drv_types.h>
+
+int rtw_rhashtable_walk_enter(rtw_rhashtable *ht, rtw_rhashtable_iter *iter)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+	return rhashtable_walk_init((ht), (iter), GFP_ATOMIC);
+#else
+	/* kernel >= 4.4.0 rhashtable_walk_init use GFP_KERNEL to alloc, spin_lock for assignment */
+	iter->ht = ht;
+	iter->p = NULL;
+	iter->slot = 0;
+	iter->skip = 0;
+
+	iter->walker = kmalloc(sizeof(*iter->walker), GFP_ATOMIC);
+	if (!iter->walker)
+		return -ENOMEM;
+
+	spin_lock(&ht->lock);
+	iter->walker->tbl =
+		rcu_dereference_protected(ht->tbl, lockdep_is_held(&ht->lock));
+	list_add(&iter->walker->list, &iter->walker->tbl->walkers);
+	spin_unlock(&ht->lock);
+
+	return 0;
+#endif
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25))
+static inline int is_vmalloc_addr(const void *x)
+{
+#ifdef CONFIG_MMU
+	unsigned long addr = (unsigned long)x;
+
+	return addr >= VMALLOC_START && addr < VMALLOC_END;
+#else
+	return 0;
+#endif
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25)) */
+
+void kvfree(const void *addr)
+{
+	if (is_vmalloc_addr(addr))
+		vfree(addr);
+	else
+		kfree(addr);
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0)) */
+
+#include "rhashtable.c"
+
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0)) */
+
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_rhashtable.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_rhashtable.h
new file mode 100644
index 000000000000..567ab39104a4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/rtw_rhashtable.h
@@ -0,0 +1,55 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_RHASHTABLE_H__
+#define __RTW_RHASHTABLE_H__
+
+#ifdef CONFIG_RTW_MESH /* for now, only promised for kernel versions we support mesh */
+
+/* directly reference rhashtable in kernel */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0))
+#include <linux/rhashtable.h>
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0)) */
+
+/* Use rhashtable from kernel 4.4 */
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+#define NULLS_MARKER(value) (1UL | (((long)value) << 1))
+#endif
+#include "rhashtable.h"
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0)) */
+
+typedef struct rhashtable rtw_rhashtable;
+typedef struct rhash_head rtw_rhash_head;
+typedef struct rhashtable_params rtw_rhashtable_params;
+
+#define rtw_rhashtable_init(ht, params) rhashtable_init(ht, params)
+
+typedef struct rhashtable_iter rtw_rhashtable_iter;
+
+int rtw_rhashtable_walk_enter(rtw_rhashtable *ht, rtw_rhashtable_iter *iter);
+#define rtw_rhashtable_walk_exit(iter) rhashtable_walk_exit(iter)
+#define rtw_rhashtable_walk_start(iter) rhashtable_walk_start(iter)
+#define rtw_rhashtable_walk_next(iter) rhashtable_walk_next(iter)
+#define rtw_rhashtable_walk_stop(iter) rhashtable_walk_stop(iter)
+
+#define rtw_rhashtable_free_and_destroy(ht, free_fn, arg) rhashtable_free_and_destroy((ht), (free_fn), (arg))
+#define rtw_rhashtable_lookup_fast(ht, key, params) rhashtable_lookup_fast((ht), (key), (params))
+#define rtw_rhashtable_lookup_insert_fast(ht, obj, params) rhashtable_lookup_insert_fast((ht), (obj), (params))
+#define rtw_rhashtable_remove_fast(ht, obj, params) rhashtable_remove_fast((ht), (obj), (params))
+
+#endif /* CONFIG_RTW_MESH */
+
+#endif /* __RTW_RHASHTABLE_H__ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/usb_intf.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/usb_intf.c
new file mode 100644
index 000000000000..1f014d1bed48
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/usb_intf.c
@@ -0,0 +1,1691 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+#include <hal_data.h>
+
+#include <platform_ops.h>
+
+#ifndef CONFIG_USB_HCI
+#error "CONFIG_USB_HCI shall be on!\n"
+#endif
+
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+#error "Shall be Linux or Windows, but not both!\n"
+#endif
+
+#ifdef CONFIG_80211N_HT
+extern int rtw_ht_enable;
+extern int rtw_bw_mode;
+extern int rtw_ampdu_enable;/* for enable tx_ampdu */
+#endif
+
+#ifdef CONFIG_GLOBAL_UI_PID
+int ui_pid[3] = {0, 0, 0};
+#endif
+
+
+extern int pm_netdev_open(struct net_device *pnetdev, u8 bnormal);
+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_dev_remove(struct usb_interface *pusb_intf);
+
+static void rtw_dev_shutdown(struct device *dev)
+{
+	struct usb_interface *usb_intf = container_of(dev, struct usb_interface, dev);
+	struct dvobj_priv *dvobj = NULL;
+	_adapter *adapter = NULL;
+	int i;
+
+	RTW_INFO("%s\n", __func__);
+
+	if (usb_intf) {
+		dvobj = usb_get_intfdata(usb_intf);
+		if (dvobj) {
+			adapter = dvobj_get_primary_adapter(dvobj);
+			if (adapter) {
+				if (!rtw_is_surprise_removed(adapter)) {
+					struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+					#ifdef CONFIG_WOWLAN
+					#ifdef CONFIG_GPIO_WAKEUP
+					/*default wake up pin change to BT*/
+					RTW_INFO("%s:default wake up pin change to BT\n", __FUNCTION__);
+					rtw_hal_switch_gpio_wl_ctrl(adapter, WAKEUP_GPIO_IDX, _FALSE);
+					#endif /* CONFIG_GPIO_WAKEUP */
+
+					if (pwrctl->wowlan_mode == _TRUE)
+						RTW_PRINT("%s wowlan_mode ==_TRUE do not run rtw_hal_deinit()\n", __FUNCTION__);
+					else
+					#endif
+					{
+						rtw_hal_deinit(adapter);
+						rtw_set_surprise_removed(adapter);
+					}
+				}
+			}
+			ATOMIC_SET(&dvobj->continual_io_error, MAX_CONTINUAL_IO_ERR + 1);
+		}
+	}
+}
+
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 23))
+/* Some useful macros to use to create struct usb_device_id */
+#define USB_DEVICE_ID_MATCH_VENDOR			 0x0001
+#define USB_DEVICE_ID_MATCH_PRODUCT			 0x0002
+#define USB_DEVICE_ID_MATCH_DEV_LO			 0x0004
+#define USB_DEVICE_ID_MATCH_DEV_HI			 0x0008
+#define USB_DEVICE_ID_MATCH_DEV_CLASS			 0x0010
+#define USB_DEVICE_ID_MATCH_DEV_SUBCLASS		 0x0020
+#define USB_DEVICE_ID_MATCH_DEV_PROTOCOL		 0x0040
+#define USB_DEVICE_ID_MATCH_INT_CLASS			 0x0080
+#define USB_DEVICE_ID_MATCH_INT_SUBCLASS		 0x0100
+#define USB_DEVICE_ID_MATCH_INT_PROTOCOL		 0x0200
+#define USB_DEVICE_ID_MATCH_INT_NUMBER		 0x0400
+
+
+#define USB_DEVICE_ID_MATCH_INT_INFO \
+	(USB_DEVICE_ID_MATCH_INT_CLASS | \
+	 USB_DEVICE_ID_MATCH_INT_SUBCLASS | \
+	 USB_DEVICE_ID_MATCH_INT_PROTOCOL)
+
+
+#define USB_DEVICE_AND_INTERFACE_INFO(vend, prod, cl, sc, pr) \
+	.match_flags = USB_DEVICE_ID_MATCH_INT_INFO \
+		       | USB_DEVICE_ID_MATCH_DEVICE, \
+		       .idVendor = (vend), \
+				   .idProduct = (prod), \
+						.bInterfaceClass = (cl), \
+						.bInterfaceSubClass = (sc), \
+						.bInterfaceProtocol = (pr)
+
+/**
+ * USB_VENDOR_AND_INTERFACE_INFO - describe a specific usb vendor with a class of usb interfaces
+ * @vend: the 16 bit USB Vendor ID
+ * @cl: bInterfaceClass value
+ * @sc: bInterfaceSubClass value
+ * @pr: bInterfaceProtocol value
+ *
+ * This macro is used to create a struct usb_device_id that matches a
+ * specific vendor with a specific class of interfaces.
+ *
+ * This is especially useful when explicitly matching devices that have
+ * vendor specific bDeviceClass values, but standards-compliant interfaces.
+ */
+#define USB_VENDOR_AND_INTERFACE_INFO(vend, cl, sc, pr) \
+	.match_flags = USB_DEVICE_ID_MATCH_INT_INFO \
+		       | USB_DEVICE_ID_MATCH_VENDOR, \
+		       .idVendor = (vend), \
+				   .bInterfaceClass = (cl), \
+						   .bInterfaceSubClass = (sc), \
+						   .bInterfaceProtocol = (pr)
+
+/* ----------------------------------------------------------------------- */
+#endif
+
+
+#define USB_VENDER_ID_REALTEK		0x0BDA
+
+
+/* DID_USB_v916_20130116 */
+static struct usb_device_id rtw_usb_id_tbl[] = {
+#ifdef CONFIG_RTL8188E
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x8179), .driver_info = RTL8188E}, /* 8188EUS */
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x0179), .driver_info = RTL8188E}, /* 8188ETV */
+	/*=== Customer ID ===*/
+	/****** 8188EUS ********/
+	{USB_DEVICE(0x07B8, 0x8179), .driver_info = RTL8188E}, /* Abocom - Abocom */
+#endif
+
+#ifdef CONFIG_RTL8812A
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x8812), .driver_info = RTL8812}, /* Default ID */
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x881A), .driver_info = RTL8812}, /* Default ID */
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x881B), .driver_info = RTL8812}, /* Default ID */
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x881C), .driver_info = RTL8812}, /* Default ID */
+	/*=== Customer ID ===*/
+	{USB_DEVICE(0x050D, 0x1106), .driver_info = RTL8812}, /* Belkin - sercomm */
+	{USB_DEVICE(0x2001, 0x330E), .driver_info = RTL8812}, /* D-Link - ALPHA */
+	{USB_DEVICE(0x7392, 0xA822), .driver_info = RTL8812}, /* Edimax - Edimax */
+	{USB_DEVICE(0x0DF6, 0x0074), .driver_info = RTL8812}, /* Sitecom - Edimax */
+	{USB_DEVICE(0x04BB, 0x0952), .driver_info = RTL8812}, /* I-O DATA - Edimax */
+	{USB_DEVICE(0x0789, 0x016E), .driver_info = RTL8812}, /* Logitec - Edimax */
+	{USB_DEVICE(0x0409, 0x0408), .driver_info = RTL8812}, /* NEC - */
+	{USB_DEVICE(0x0B05, 0x17D2), .driver_info = RTL8812}, /* ASUS - Edimax */
+	{USB_DEVICE(0x0E66, 0x0022), .driver_info = RTL8812}, /* HAWKING - Edimax */
+	{USB_DEVICE(0x0586, 0x3426), .driver_info = RTL8812}, /* ZyXEL - */
+	{USB_DEVICE(0x2001, 0x3313), .driver_info = RTL8812}, /* D-Link - ALPHA */
+	{USB_DEVICE(0x1058, 0x0632), .driver_info = RTL8812}, /* WD - Cybertan*/
+	{USB_DEVICE(0x1740, 0x0100), .driver_info = RTL8812}, /* EnGenius - EnGenius */
+	{USB_DEVICE(0x2019, 0xAB30), .driver_info = RTL8812}, /* Planex - Abocom */
+	{USB_DEVICE(0x07B8, 0x8812), .driver_info = RTL8812}, /* Abocom - Abocom */
+	{USB_DEVICE(0x2001, 0x3315), .driver_info = RTL8812}, /* D-Link - Cameo */
+	{USB_DEVICE(0x2001, 0x3316), .driver_info = RTL8812}, /* D-Link - Cameo */
+#endif
+
+#ifdef CONFIG_RTL8821A
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x0811), .driver_info = RTL8821}, /* Default ID */
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x0821), .driver_info = RTL8821}, /* Default ID */
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x8822), .driver_info = RTL8821}, /* Default ID */
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0xA811) , .driver_info = RTL8821},/* Default ID */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x0820, 0xff, 0xff, 0xff), .driver_info = RTL8821}, /* 8821AU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x0823, 0xff, 0xff, 0xff), .driver_info = RTL8821}, /* 8821AU */
+	/*=== Customer ID ===*/
+	{USB_DEVICE(0x7392, 0xA811), .driver_info = RTL8821}, /* Edimax - Edimax */
+	{USB_DEVICE(0x04BB, 0x0953), .driver_info = RTL8821}, /* I-O DATA - Edimax */
+	{USB_DEVICE(0x2001, 0x3314), .driver_info = RTL8821}, /* D-Link - Cameo */
+	{USB_DEVICE(0x2001, 0x3318), .driver_info = RTL8821}, /* D-Link - Cameo */
+	{USB_DEVICE(0x0E66, 0x0023), .driver_info = RTL8821}, /* HAWKING - Edimax */
+	{USB_DEVICE(0x056E, 0x400E) , .driver_info = RTL8821}, /* ELECOM -  ELECOM */
+	{USB_DEVICE(0x056E, 0x400F) , .driver_info = RTL8821}, /* ELECOM -  ELECOM */
+#endif
+
+#ifdef CONFIG_RTL8192E
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x818B, 0xff, 0xff, 0xff), .driver_info = RTL8192E}, /* Default ID */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x818C, 0xff, 0xff, 0xff), .driver_info = RTL8192E}, /* Default ID */
+#endif
+
+#ifdef CONFIG_RTL8723B
+	/* === Realtek demoboard === */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xB720, 0xff, 0xff, 0xff), .driver_info = RTL8723B}, /* 8723BU 1*1 */
+	/* {USB_DEVICE(USB_VENDER_ID_REALTEK, 0xB720),.driver_info = RTL8723B},  8723BU */
+#endif
+
+#ifdef CONFIG_RTL8703B
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xB703, 0xff, 0xff, 0xff), .driver_info = RTL8703B}, /* 8723CU 1*1 */
+	/* {USB_DEVICE(USB_VENDER_ID_REALTEK, 0xB703), .driver_info = RTL723C}, */ /* 8723CU 1*1 */
+#endif /* CONFIG_RTL8703B */
+
+#ifdef CONFIG_RTL8814A
+
+	{USB_DEVICE(USB_VENDER_ID_REALTEK, 0x8813), .driver_info = RTL8814A},
+	{USB_DEVICE(0x2001, 0x331a), .driver_info = RTL8814A}, /* D-Link - D-Link */
+	{USB_DEVICE(0x0b05, 0x1817), .driver_info = RTL8814A}, /* ASUS - ASUSTeK */
+	{USB_DEVICE(0x056E, 0x400B), .driver_info = RTL8814A}, /* ELECOM - ELECOM */
+	{USB_DEVICE(0x056E, 0x400D), .driver_info = RTL8814A}, /* ELECOM - ELECOM */
+	{USB_DEVICE(0x7392, 0xA834), .driver_info = RTL8814A}, /* Edimax - Edimax */
+#endif /* CONFIG_RTL8814A */
+
+#ifdef CONFIG_RTL8188F
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xF179, 0xff, 0xff, 0xff), .driver_info = RTL8188F}, /* 8188FU 1*1 */
+#endif
+
+#ifdef CONFIG_RTL8822B
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xB82C, 0xff, 0xff, 0xff), .driver_info = RTL8822B}, /* Default ID for USB multi-function */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xB812, 0xff, 0xff, 0xff), .driver_info = RTL8822B}, /* Default ID for USB Single-function, WiFi only */
+	/*=== Customer ID ===*/
+	{USB_DEVICE_AND_INTERFACE_INFO(0x13b1, 0x0043, 0xff, 0xff, 0xff), .driver_info = RTL8822B}, /* Alpha - Alpha*/
+#endif /* CONFIG_RTL8822B */
+
+#ifdef CONFIG_RTL8723D
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xD723, 0xff, 0xff, 0xff), .driver_info = RTL8723D}, /* 8723DU 1*1 */
+#endif
+
+#ifdef CONFIG_RTL8821C
+	/*=== Realtek demoboard ===*/
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xb82b, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8821CU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xb820, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8821CU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xC821, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8821CU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xC820, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8821CU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xC82A, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8821CU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xC82B, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8821CU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0xC811, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8811CU */
+	{USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x8811, 0xff, 0xff, 0xff), .driver_info = RTL8821C}, /* 8811CU */	
+	/*=== Customer ID ===*/
+#endif
+
+	{}	/* Terminating entry */
+};
+
+MODULE_DEVICE_TABLE(usb, rtw_usb_id_tbl);
+
+int const rtw_usb_id_len = sizeof(rtw_usb_id_tbl) / sizeof(struct usb_device_id);
+
+static struct specific_device_id specific_device_id_tbl[] = {
+	{.idVendor = USB_VENDER_ID_REALTEK, .idProduct = 0x8177, .flags = SPEC_DEV_ID_DISABLE_HT}, /* 8188cu 1*1 dongole, (b/g mode only) */
+	{.idVendor = USB_VENDER_ID_REALTEK, .idProduct = 0x817E, .flags = SPEC_DEV_ID_DISABLE_HT}, /* 8188CE-VAU USB minCard (b/g mode only) */
+	{.idVendor = 0x0b05, .idProduct = 0x1791, .flags = SPEC_DEV_ID_DISABLE_HT},
+	{.idVendor = 0x13D3, .idProduct = 0x3311, .flags = SPEC_DEV_ID_DISABLE_HT},
+	{.idVendor = 0x13D3, .idProduct = 0x3359, .flags = SPEC_DEV_ID_DISABLE_HT}, /* Russian customer -Azwave (8188CE-VAU  g mode) */
+#ifdef RTK_DMP_PLATFORM
+	{.idVendor = USB_VENDER_ID_REALTEK, .idProduct = 0x8111, .flags = SPEC_DEV_ID_ASSIGN_IFNAME}, /* Realtek 5G dongle for WiFi Display */
+	{.idVendor = 0x2019, .idProduct = 0xAB2D, .flags = SPEC_DEV_ID_ASSIGN_IFNAME}, /* PCI-Abocom 5G dongle for WiFi Display */
+#endif /* RTK_DMP_PLATFORM */
+	{}
+};
+
+struct rtw_usb_drv {
+	struct usb_driver usbdrv;
+	int drv_registered;
+	u8 hw_type;
+};
+
+struct rtw_usb_drv usb_drv = {
+	.usbdrv.name = (char *)DRV_NAME,
+	.usbdrv.probe = rtw_drv_init,
+	.usbdrv.disconnect = rtw_dev_remove,
+	.usbdrv.id_table = rtw_usb_id_tbl,
+	.usbdrv.suspend =  rtw_suspend,
+	.usbdrv.resume = rtw_resume,
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 22))
+	.usbdrv.reset_resume   = rtw_resume,
+#endif
+#ifdef CONFIG_AUTOSUSPEND
+	.usbdrv.supports_autosuspend = 1,
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19))
+	.usbdrv.drvwrap.driver.shutdown = rtw_dev_shutdown,
+#else
+	.usbdrv.driver.shutdown = rtw_dev_shutdown,
+#endif
+};
+
+static inline int RT_usb_endpoint_dir_in(const struct usb_endpoint_descriptor *epd)
+{
+	return (epd->bEndpointAddress & USB_ENDPOINT_DIR_MASK) == USB_DIR_IN;
+}
+
+static inline int RT_usb_endpoint_dir_out(const struct usb_endpoint_descriptor *epd)
+{
+	return (epd->bEndpointAddress & USB_ENDPOINT_DIR_MASK) == USB_DIR_OUT;
+}
+
+static inline int RT_usb_endpoint_xfer_int(const struct usb_endpoint_descriptor *epd)
+{
+	return (epd->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) == USB_ENDPOINT_XFER_INT;
+}
+
+static inline int RT_usb_endpoint_xfer_bulk(const struct usb_endpoint_descriptor *epd)
+{
+	return (epd->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) == USB_ENDPOINT_XFER_BULK;
+}
+
+static inline int RT_usb_endpoint_is_bulk_in(const struct usb_endpoint_descriptor *epd)
+{
+	return RT_usb_endpoint_xfer_bulk(epd) && RT_usb_endpoint_dir_in(epd);
+}
+
+static inline int RT_usb_endpoint_is_bulk_out(const struct usb_endpoint_descriptor *epd)
+{
+	return RT_usb_endpoint_xfer_bulk(epd) && RT_usb_endpoint_dir_out(epd);
+}
+
+static inline int RT_usb_endpoint_is_int_in(const struct usb_endpoint_descriptor *epd)
+{
+	return RT_usb_endpoint_xfer_int(epd) && RT_usb_endpoint_dir_in(epd);
+}
+
+static inline int RT_usb_endpoint_num(const struct usb_endpoint_descriptor *epd)
+{
+	return epd->bEndpointAddress & USB_ENDPOINT_NUMBER_MASK;
+}
+
+static u8 rtw_init_intf_priv(struct dvobj_priv *dvobj)
+{
+	u8 rst = _SUCCESS;
+
+#ifdef CONFIG_USB_VENDOR_REQ_MUTEX
+	_rtw_mutex_init(&dvobj->usb_vendor_req_mutex);
+#endif
+
+
+#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC
+	dvobj->usb_alloc_vendor_req_buf = rtw_zmalloc(MAX_USB_IO_CTL_SIZE);
+	if (dvobj->usb_alloc_vendor_req_buf == NULL) {
+		RTW_INFO("alloc usb_vendor_req_buf failed... /n");
+		rst = _FAIL;
+		goto exit;
+	}
+	dvobj->usb_vendor_req_buf  =
+		(u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(dvobj->usb_alloc_vendor_req_buf), ALIGNMENT_UNIT);
+exit:
+#endif
+
+	return rst;
+
+}
+
+static u8 rtw_deinit_intf_priv(struct dvobj_priv *dvobj)
+{
+	u8 rst = _SUCCESS;
+
+#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC
+	if (dvobj->usb_vendor_req_buf)
+		rtw_mfree(dvobj->usb_alloc_vendor_req_buf, MAX_USB_IO_CTL_SIZE);
+#endif
+
+#ifdef CONFIG_USB_VENDOR_REQ_MUTEX
+	_rtw_mutex_free(&dvobj->usb_vendor_req_mutex);
+#endif
+
+	return rst;
+}
+static void rtw_decide_chip_type_by_usb_info(struct dvobj_priv *pdvobjpriv, const struct usb_device_id *pdid)
+{
+	pdvobjpriv->chip_type = pdid->driver_info;
+
+#ifdef CONFIG_RTL8188E
+	if (pdvobjpriv->chip_type == RTL8188E)
+		rtl8188eu_set_hw_type(pdvobjpriv);
+#endif
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+	if (pdvobjpriv->chip_type == RTL8812 || pdvobjpriv->chip_type == RTL8821)
+		rtl8812au_set_hw_type(pdvobjpriv);
+#endif
+
+#ifdef CONFIG_RTL8192E
+	if (pdvobjpriv->chip_type == RTL8192E)
+		rtl8192eu_set_hw_type(pdvobjpriv);
+#endif
+
+#ifdef CONFIG_RTL8723B
+	if (pdvobjpriv->chip_type == RTL8723B)
+		rtl8723bu_set_hw_type(pdvobjpriv);
+#endif
+
+#ifdef CONFIG_RTL8814A
+	if (pdvobjpriv->chip_type == RTL8814A)
+		rtl8814au_set_hw_type(pdvobjpriv);
+#endif /* CONFIG_RTL8814A */
+
+#ifdef CONFIG_RTL8188F
+	if (pdvobjpriv->chip_type == RTL8188F)
+		rtl8188fu_set_hw_type(pdvobjpriv);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	if (pdvobjpriv->chip_type == RTL8703B)
+		rtl8703bu_set_hw_type(pdvobjpriv);
+#endif /* CONFIG_RTL8703B */
+
+#ifdef CONFIG_RTL8822B
+	if (pdvobjpriv->chip_type == RTL8822B)
+		rtl8822bu_set_hw_type(pdvobjpriv);
+#endif /* CONFIG_RTL8822B */
+
+#ifdef CONFIG_RTL8723D
+	if (pdvobjpriv->chip_type == RTL8723D)
+		rtl8723du_set_hw_type(pdvobjpriv);
+#endif /* CONFIG_RTL8723D */
+
+#ifdef CONFIG_RTL8821C
+	if (pdvobjpriv->chip_type == RTL8821C)
+		rtl8821cu_set_hw_type(pdvobjpriv);
+#endif /* CONFIG_RTL8821C */
+}
+
+static struct dvobj_priv *usb_dvobj_init(struct usb_interface *usb_intf, const struct usb_device_id *pdid)
+{
+	int	i;
+	u8	val8;
+	int	status = _FAIL;
+	struct dvobj_priv *pdvobjpriv;
+	struct usb_device_descriptor	*pdev_desc;
+	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_host_endpoint		*phost_endp;
+	struct usb_endpoint_descriptor	*pendp_desc;
+	struct usb_device				*pusbd;
+
+
+
+	pdvobjpriv = devobj_init();
+	if (pdvobjpriv == NULL)
+		goto exit;
+
+
+	pdvobjpriv->pusbintf = usb_intf ;
+	pusbd = pdvobjpriv->pusbdev = interface_to_usbdev(usb_intf);
+	usb_set_intfdata(usb_intf, pdvobjpriv);
+
+	pdvobjpriv->RtNumInPipes = 0;
+	pdvobjpriv->RtNumOutPipes = 0;
+
+	/* padapter->EepromAddressSize = 6; */
+	/* pdvobjpriv->nr_endpoint = 6; */
+
+	pdev_desc = &pusbd->descriptor;
+
+#if 0
+	RTW_INFO("\n8712_usb_device_descriptor:\n");
+	RTW_INFO("bLength=%x\n", pdev_desc->bLength);
+	RTW_INFO("bDescriptorType=%x\n", pdev_desc->bDescriptorType);
+	RTW_INFO("bcdUSB=%x\n", pdev_desc->bcdUSB);
+	RTW_INFO("bDeviceClass=%x\n", pdev_desc->bDeviceClass);
+	RTW_INFO("bDeviceSubClass=%x\n", pdev_desc->bDeviceSubClass);
+	RTW_INFO("bDeviceProtocol=%x\n", pdev_desc->bDeviceProtocol);
+	RTW_INFO("bMaxPacketSize0=%x\n", pdev_desc->bMaxPacketSize0);
+	RTW_INFO("idVendor=%x\n", pdev_desc->idVendor);
+	RTW_INFO("idProduct=%x\n", pdev_desc->idProduct);
+	RTW_INFO("bcdDevice=%x\n", pdev_desc->bcdDevice);
+	RTW_INFO("iManufacturer=%x\n", pdev_desc->iManufacturer);
+	RTW_INFO("iProduct=%x\n", pdev_desc->iProduct);
+	RTW_INFO("iSerialNumber=%x\n", pdev_desc->iSerialNumber);
+	RTW_INFO("bNumConfigurations=%x\n", pdev_desc->bNumConfigurations);
+#endif
+
+	phost_conf = pusbd->actconfig;
+	pconf_desc = &phost_conf->desc;
+
+#if 0
+	RTW_INFO("\n8712_usb_configuration_descriptor:\n");
+	RTW_INFO("bLength=%x\n", pconf_desc->bLength);
+	RTW_INFO("bDescriptorType=%x\n", pconf_desc->bDescriptorType);
+	RTW_INFO("wTotalLength=%x\n", pconf_desc->wTotalLength);
+	RTW_INFO("bNumInterfaces=%x\n", pconf_desc->bNumInterfaces);
+	RTW_INFO("bConfigurationValue=%x\n", pconf_desc->bConfigurationValue);
+	RTW_INFO("iConfiguration=%x\n", pconf_desc->iConfiguration);
+	RTW_INFO("bmAttributes=%x\n", pconf_desc->bmAttributes);
+	RTW_INFO("bMaxPower=%x\n", pconf_desc->bMaxPower);
+#endif
+
+	/* RTW_INFO("\n***** num of altsetting = (%d) *****\n", pusb_interface->num_altsetting); */
+
+	phost_iface = &usb_intf->altsetting[0];
+	piface_desc = &phost_iface->desc;
+
+#if 0
+	RTW_INFO("\n8712_usb_interface_descriptor:\n");
+	RTW_INFO("bLength=%x\n", piface_desc->bLength);
+	RTW_INFO("bDescriptorType=%x\n", piface_desc->bDescriptorType);
+	RTW_INFO("bInterfaceNumber=%x\n", piface_desc->bInterfaceNumber);
+	RTW_INFO("bAlternateSetting=%x\n", piface_desc->bAlternateSetting);
+	RTW_INFO("bNumEndpoints=%x\n", piface_desc->bNumEndpoints);
+	RTW_INFO("bInterfaceClass=%x\n", piface_desc->bInterfaceClass);
+	RTW_INFO("bInterfaceSubClass=%x\n", piface_desc->bInterfaceSubClass);
+	RTW_INFO("bInterfaceProtocol=%x\n", piface_desc->bInterfaceProtocol);
+	RTW_INFO("iInterface=%x\n", piface_desc->iInterface);
+#endif
+
+	pdvobjpriv->NumInterfaces = pconf_desc->bNumInterfaces;
+	pdvobjpriv->InterfaceNumber = piface_desc->bInterfaceNumber;
+	pdvobjpriv->nr_endpoint = piface_desc->bNumEndpoints;
+
+	/* RTW_INFO("\ndump usb_endpoint_descriptor:\n"); */
+
+	for (i = 0; i < pdvobjpriv->nr_endpoint; i++) {
+		phost_endp = phost_iface->endpoint + i;
+		if (phost_endp) {
+			pendp_desc = &phost_endp->desc;
+
+			RTW_INFO("\nusb_endpoint_descriptor(%d):\n", i);
+			RTW_INFO("bLength=%x\n", pendp_desc->bLength);
+			RTW_INFO("bDescriptorType=%x\n", pendp_desc->bDescriptorType);
+			RTW_INFO("bEndpointAddress=%x\n", pendp_desc->bEndpointAddress);
+			/* RTW_INFO("bmAttributes=%x\n",pendp_desc->bmAttributes); */
+			RTW_INFO("wMaxPacketSize=%d\n", le16_to_cpu(pendp_desc->wMaxPacketSize));
+			RTW_INFO("bInterval=%x\n", pendp_desc->bInterval);
+			/* RTW_INFO("bRefresh=%x\n",pendp_desc->bRefresh); */
+			/* RTW_INFO("bSynchAddress=%x\n",pendp_desc->bSynchAddress); */
+
+			if (RT_usb_endpoint_is_bulk_in(pendp_desc)) {
+				RTW_INFO("RT_usb_endpoint_is_bulk_in = %x\n", RT_usb_endpoint_num(pendp_desc));
+				pdvobjpriv->RtInPipe[pdvobjpriv->RtNumInPipes] = RT_usb_endpoint_num(pendp_desc);
+				pdvobjpriv->RtNumInPipes++;
+			} else if (RT_usb_endpoint_is_int_in(pendp_desc)) {
+				RTW_INFO("RT_usb_endpoint_is_int_in = %x, Interval = %x\n", RT_usb_endpoint_num(pendp_desc), pendp_desc->bInterval);
+				pdvobjpriv->RtInPipe[pdvobjpriv->RtNumInPipes] = RT_usb_endpoint_num(pendp_desc);
+				pdvobjpriv->RtNumInPipes++;
+			} else if (RT_usb_endpoint_is_bulk_out(pendp_desc)) {
+				RTW_INFO("RT_usb_endpoint_is_bulk_out = %x\n", RT_usb_endpoint_num(pendp_desc));
+				pdvobjpriv->RtOutPipe[pdvobjpriv->RtNumOutPipes] = RT_usb_endpoint_num(pendp_desc);
+				pdvobjpriv->RtNumOutPipes++;
+			}
+			pdvobjpriv->ep_num[i] = RT_usb_endpoint_num(pendp_desc);
+		}
+	}
+
+	RTW_INFO("nr_endpoint=%d, in_num=%d, out_num=%d\n\n", pdvobjpriv->nr_endpoint, pdvobjpriv->RtNumInPipes, pdvobjpriv->RtNumOutPipes);
+
+	switch (pusbd->speed) {
+	case USB_SPEED_LOW:
+		RTW_INFO("USB_SPEED_LOW\n");
+		pdvobjpriv->usb_speed = RTW_USB_SPEED_1_1;
+		break;
+	case USB_SPEED_FULL:
+		RTW_INFO("USB_SPEED_FULL\n");
+		pdvobjpriv->usb_speed = RTW_USB_SPEED_1_1;
+		break;
+	case USB_SPEED_HIGH:
+		RTW_INFO("USB_SPEED_HIGH\n");
+		pdvobjpriv->usb_speed = RTW_USB_SPEED_2;
+		break;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 31))
+	case USB_SPEED_SUPER:
+		RTW_INFO("USB_SPEED_SUPER\n");
+		pdvobjpriv->usb_speed = RTW_USB_SPEED_3;
+		break;
+#endif
+	default:
+		RTW_INFO("USB_SPEED_UNKNOWN(%x)\n", pusbd->speed);
+		pdvobjpriv->usb_speed = RTW_USB_SPEED_UNKNOWN;
+		break;
+	}
+
+	if (pdvobjpriv->usb_speed == RTW_USB_SPEED_UNKNOWN) {
+		RTW_INFO("UNKNOWN USB SPEED MODE, ERROR !!!\n");
+		goto free_dvobj;
+	}
+
+	if (rtw_init_intf_priv(pdvobjpriv) == _FAIL) {
+		goto free_dvobj;
+	}
+
+	/*step 1-1., decide the chip_type via driver_info*/
+	pdvobjpriv->interface_type = RTW_USB;
+	rtw_decide_chip_type_by_usb_info(pdvobjpriv, pdid);
+
+	/* .3 misc */
+	_rtw_init_sema(&(pdvobjpriv->usb_suspend_sema), 0);
+	rtw_reset_continual_io_error(pdvobjpriv);
+
+	usb_get_dev(pusbd);
+
+	status = _SUCCESS;
+
+free_dvobj:
+	if (status != _SUCCESS && pdvobjpriv) {
+		usb_set_intfdata(usb_intf, NULL);
+
+		devobj_deinit(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 modlue, driver fails on sitesurvey for the first time when device is up . */
+				/* Reset usb port for sitesurvey fail issue. 2009.8.13, by Thomas */
+				RTW_INFO("usb attached..., try to reset usb device\n");
+				usb_reset_device(interface_to_usbdev(usb_intf));
+			}
+		}
+
+		rtw_deinit_intf_priv(dvobj);
+
+		devobj_deinit(dvobj);
+	}
+
+	/* RTW_INFO("%s %d\n", __func__, ATOMIC_READ(&usb_intf->dev.kobj.kref.refcount)); */
+	usb_put_dev(interface_to_usbdev(usb_intf));
+
+}
+
+static int usb_reprobe_switch_usb_mode(PADAPTER Adapter)
+{
+	struct registry_priv *registry_par = &Adapter->registrypriv;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
+	u8 ret = _FALSE;
+
+	/* efuse not allow driver to switch usb mode */
+	if (pHalData->EEPROMUsbSwitch == _FALSE)
+		goto exit;
+
+	/* registry not allow driver to switch usb mode */
+	if (registry_par->switch_usb_mode == 0)
+		goto exit;
+
+	rtw_hal_set_hwreg(Adapter, HW_VAR_USB_MODE, &ret);
+
+exit:
+	return ret;
+}
+
+u8 rtw_set_hal_ops(_adapter *padapter)
+{
+	/* alloc memory for HAL DATA */
+	if (rtw_hal_data_init(padapter) == _FAIL)
+		return _FAIL;
+
+#ifdef CONFIG_RTL8188E
+	if (rtw_get_chip_type(padapter) == RTL8188E)
+		rtl8188eu_set_hal_ops(padapter);
+#endif
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+	if (rtw_get_chip_type(padapter) == RTL8812 || rtw_get_chip_type(padapter) == RTL8821)
+		rtl8812au_set_hal_ops(padapter);
+#endif
+
+#ifdef CONFIG_RTL8192E
+	if (rtw_get_chip_type(padapter) == RTL8192E)
+		rtl8192eu_set_hal_ops(padapter);
+#endif
+#ifdef CONFIG_RTL8723B
+	if (rtw_get_chip_type(padapter) == RTL8723B)
+		rtl8723bu_set_hal_ops(padapter);
+#endif
+#ifdef CONFIG_RTL8814A
+	if (rtw_get_chip_type(padapter) == RTL8814A)
+		rtl8814au_set_hal_ops(padapter);
+#endif /* CONFIG_RTL8814A */
+
+#ifdef CONFIG_RTL8188F
+	if (rtw_get_chip_type(padapter) == RTL8188F)
+		rtl8188fu_set_hal_ops(padapter);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	if (rtw_get_chip_type(padapter) == RTL8703B)
+		rtl8703bu_set_hal_ops(padapter);
+#endif /* CONFIG_RTL8703B */
+
+#ifdef CONFIG_RTL8822B
+	if (rtw_get_chip_type(padapter) == RTL8822B)
+		rtl8822bu_set_hal_ops(padapter);
+#endif /* CONFIG_RTL8822B */
+
+#ifdef CONFIG_RTL8723D
+	if (rtw_get_chip_type(padapter) == RTL8723D)
+		rtl8723du_set_hal_ops(padapter);
+#endif /* CONFIG_RTL8723D */
+
+
+#ifdef CONFIG_RTL8821C
+	if (rtw_get_chip_type(padapter) == RTL8821C) {
+		if (rtl8821cu_set_hal_ops(padapter) == _FAIL)
+			return _FAIL;
+	}
+#endif
+
+	if (_FAIL == rtw_hal_ops_check(padapter))
+		return _FAIL;
+
+	if (hal_spec_init(padapter) == _FAIL)
+		return _FAIL;
+
+	return _SUCCESS;
+}
+
+static void usb_intf_start(_adapter *padapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+
+	rtw_hal_inirp_init(padapter);
+	hal->usb_intf_start = _TRUE;
+
+
+}
+
+static void usb_intf_stop(_adapter *padapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+
+	/* disabel_hw_interrupt */
+	if (!rtw_is_surprise_removed(padapter)) {
+		/* device still exists, so driver can do i/o operation */
+		/* TODO: */
+	}
+
+	/* cancel in irp */
+	rtw_hal_inirp_deinit(padapter);
+
+	/* cancel out irp */
+	rtw_write_port_cancel(padapter);
+
+	/* todo:cancel other irps */
+
+	hal->usb_intf_start = _FALSE;
+
+}
+
+static void process_spec_devid(const struct usb_device_id *pdid)
+{
+	u16 vid, pid;
+	u32 flags;
+	int i;
+	int num = sizeof(specific_device_id_tbl) / sizeof(struct specific_device_id);
+
+	for (i = 0; i < num; i++) {
+		vid = specific_device_id_tbl[i].idVendor;
+		pid = specific_device_id_tbl[i].idProduct;
+		flags = specific_device_id_tbl[i].flags;
+
+#ifdef CONFIG_80211N_HT
+		if ((pdid->idVendor == vid) && (pdid->idProduct == pid) && (flags & SPEC_DEV_ID_DISABLE_HT)) {
+			rtw_ht_enable = 0;
+			rtw_bw_mode = 0;
+			rtw_ampdu_enable = 0;
+		}
+#endif
+
+#ifdef RTK_DMP_PLATFORM
+		/* Change the ifname to wlan10 when PC side WFD dongle plugin on DMP platform. */
+		/* It is used to distinguish between normal and PC-side wifi dongle/module. */
+		if ((pdid->idVendor == vid) && (pdid->idProduct == pid) && (flags & SPEC_DEV_ID_ASSIGN_IFNAME)) {
+			extern char *ifname;
+			strncpy(ifname, "wlan10", 6);
+			/* RTW_INFO("%s()-%d: ifname=%s, vid=%04X, pid=%04X\n", __FUNCTION__, __LINE__, ifname, vid, pid); */
+		}
+#endif /* RTK_DMP_PLATFORM */
+
+	}
+}
+
+#ifdef SUPPORT_HW_RFOFF_DETECTED
+int rtw_hw_suspend(_adapter *padapter)
+{
+	struct pwrctrl_priv *pwrpriv;
+	struct usb_interface *pusb_intf;
+	struct net_device *pnetdev;
+
+	if (NULL == padapter)
+		goto error_exit;
+
+	if ((_FALSE == padapter->bup) || RTW_CANNOT_RUN(padapter)) {
+		RTW_INFO("padapter->bup=%d bDriverStopped=%s bSurpriseRemoved = %s\n"
+			 , padapter->bup
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+		goto error_exit;
+	}
+
+	pwrpriv = adapter_to_pwrctl(padapter);
+	pusb_intf = adapter_to_dvobj(padapter)->pusbintf;
+	pnetdev = padapter->pnetdev;
+
+	LeaveAllPowerSaveMode(padapter);
+
+	RTW_INFO("==> rtw_hw_suspend\n");
+	_enter_pwrlock(&pwrpriv->lock);
+	pwrpriv->bips_processing = _TRUE;
+	/* padapter->net_closed = _TRUE; */
+	/* s1. */
+	if (pnetdev) {
+		rtw_netif_carrier_off(pnetdev);
+		rtw_netif_stop_queue(pnetdev);
+	}
+
+	/* s2. */
+	rtw_disassoc_cmd(padapter, 500, RTW_CMDF_DIRECTLY);
+
+	/* s2-2.  indicate disconnect to os */
+	/* rtw_indicate_disconnect(padapter); */
+	{
+		struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+		if (check_fwstate(pmlmepriv, _FW_LINKED)) {
+			_clr_fwstate_(pmlmepriv, _FW_LINKED);
+			rtw_led_control(padapter, LED_CTL_NO_LINK);
+
+			rtw_os_indicate_disconnect(padapter, 0, _FALSE);
+
+#ifdef CONFIG_LPS
+			/* donnot enqueue cmd */
+			rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_DISCONNECT, 0);
+#endif
+		}
+	}
+	/* s2-3. */
+	rtw_free_assoc_resources(padapter, 1);
+
+	/* s2-4. */
+	rtw_free_network_queue(padapter, _TRUE);
+#ifdef CONFIG_IPS
+	rtw_ips_dev_unload(padapter);
+#endif
+	pwrpriv->rf_pwrstate = rf_off;
+	pwrpriv->bips_processing = _FALSE;
+	_exit_pwrlock(&pwrpriv->lock);
+
+	return 0;
+
+error_exit:
+	RTW_INFO("%s, failed\n", __FUNCTION__);
+	return -1;
+
+}
+
+int rtw_hw_resume(_adapter *padapter)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct usb_interface *pusb_intf = adapter_to_dvobj(padapter)->pusbintf;
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	RTW_INFO("==> rtw_hw_resume\n");
+	_enter_pwrlock(&pwrpriv->lock);
+	pwrpriv->bips_processing = _TRUE;
+	rtw_reset_drv_sw(padapter);
+
+	if (pm_netdev_open(pnetdev, _FALSE) != 0) {
+		_exit_pwrlock(&pwrpriv->lock);
+		goto error_exit;
+	}
+	rtw_netif_device_attach(pnetdev);
+	rtw_netif_carrier_on(pnetdev);
+
+	rtw_netif_wake_queue(pnetdev);
+
+	pwrpriv->bkeepfwalive = _FALSE;
+	pwrpriv->brfoffbyhw = _FALSE;
+
+	pwrpriv->rf_pwrstate = rf_on;
+	pwrpriv->bips_processing = _FALSE;
+	_exit_pwrlock(&pwrpriv->lock);
+
+
+	return 0;
+error_exit:
+	RTW_INFO("%s, Open net dev failed\n", __FUNCTION__);
+	return -1;
+}
+#endif
+
+static int rtw_suspend(struct usb_interface *pusb_intf, pm_message_t message)
+{
+	struct dvobj_priv *dvobj;
+	struct pwrctrl_priv *pwrpriv;
+	struct debug_priv *pdbgpriv;
+	PADAPTER padapter;
+	int ret = 0;
+
+
+	dvobj = usb_get_intfdata(pusb_intf);
+	pwrpriv = dvobj_to_pwrctl(dvobj);
+	pdbgpriv = &dvobj->drv_dbg;
+	padapter = dvobj_get_primary_adapter(dvobj);
+
+	if (pwrpriv->bInSuspend == _TRUE) {
+		RTW_INFO("%s bInSuspend = %d\n", __FUNCTION__, pwrpriv->bInSuspend);
+		pdbgpriv->dbg_suspend_error_cnt++;
+		goto exit;
+	}
+
+	if ((padapter->bup) || !rtw_is_drv_stopped(padapter) || !rtw_is_surprise_removed(padapter)) {
+#ifdef CONFIG_AUTOSUSPEND
+		if (pwrpriv->bInternalAutoSuspend) {
+
+#ifdef SUPPORT_HW_RFOFF_DETECTED
+			/* The FW command register update must after MAC and FW init ready. */
+			if ((GET_HAL_DATA(padapter)->bFWReady) && (pwrpriv->bHWPwrPindetect) && (padapter->registrypriv.usbss_enable)) {
+				u8 bOpen = _TRUE;
+				rtw_interface_ps_func(padapter, HAL_USB_SELECT_SUSPEND, &bOpen);
+			}
+#endif/* SUPPORT_HW_RFOFF_DETECTED */
+		}
+#endif/* CONFIG_AUTOSUSPEND */
+	}
+
+	ret =  rtw_suspend_common(padapter);
+
+exit:
+	return ret;
+}
+
+int rtw_resume_process(_adapter *padapter)
+{
+	int ret, pm_cnt = 0;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct dvobj_priv *pdvobj = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &pdvobj->drv_dbg;
+
+
+	if (pwrpriv->bInSuspend == _FALSE) {
+		pdbgpriv->dbg_resume_error_cnt++;
+		RTW_INFO("%s bInSuspend = %d\n", __FUNCTION__, pwrpriv->bInSuspend);
+		return -1;
+	}
+
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_AUTOSUSPEND) /* add by amy for 8723as-vau */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
+	RTW_INFO("%s...pm_usage_cnt(%d)  pwrpriv->bAutoResume=%x.  ....\n", __func__, atomic_read(&(adapter_to_dvobj(padapter)->pusbintf->pm_usage_cnt)), pwrpriv->bAutoResume);
+	pm_cnt = atomic_read(&(adapter_to_dvobj(padapter)->pusbintf->pm_usage_cnt));
+#else /* kernel < 2.6.32 */
+	RTW_INFO("...pm_usage_cnt(%d).....\n", adapter_to_dvobj(padapter)->pusbintf->pm_usage_cnt);
+	pm_cnt = adapter_to_dvobj(padapter)->pusbintf->pm_usage_cnt;
+#endif /* kernel < 2.6.32 */
+
+	RTW_INFO("pwrpriv->bAutoResume (%x)\n", pwrpriv->bAutoResume);
+	if (_TRUE == pwrpriv->bAutoResume) {
+		pwrpriv->bInternalAutoSuspend = _FALSE;
+		pwrpriv->bAutoResume = _FALSE;
+		RTW_INFO("pwrpriv->bAutoResume (%x)  pwrpriv->bInternalAutoSuspend(%x)\n", pwrpriv->bAutoResume, pwrpriv->bInternalAutoSuspend);
+
+	}
+#endif /* #ifdef CONFIG_BT_COEXIST &CONFIG_AUTOSUSPEND& */
+
+	/*
+	 * Due to usb wow suspend flow will cancel read/write port via intf_stop and
+	 * bReadPortCancel and bWritePortCancel are set _TRUE in intf_stop.
+	 * But they will not be clear in intf_start during wow resume flow.
+	 * It should move to os_intf in the feature.
+	 */
+	RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
+	RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
+
+	ret =  rtw_resume_common(padapter);
+
+#ifdef CONFIG_AUTOSUSPEND
+	if (pwrpriv->bInternalAutoSuspend) {
+#ifdef SUPPORT_HW_RFOFF_DETECTED
+		/* The FW command register update must after MAC and FW init ready. */
+		if ((GET_HAL_DATA(padapter)->bFWReady) && (pwrpriv->bHWPwrPindetect) && (padapter->registrypriv.usbss_enable)) {
+			u8 bOpen = _FALSE;
+			rtw_interface_ps_func(padapter, HAL_USB_SELECT_SUSPEND, &bOpen);
+		}
+#endif
+#ifdef CONFIG_BT_COEXIST /* for 8723as-vau */
+		RTW_INFO("pwrpriv->bAutoResume (%x)\n", pwrpriv->bAutoResume);
+		if (_TRUE == pwrpriv->bAutoResume) {
+			pwrpriv->bInternalAutoSuspend = _FALSE;
+			pwrpriv->bAutoResume = _FALSE;
+			RTW_INFO("pwrpriv->bAutoResume (%x)  pwrpriv->bInternalAutoSuspend(%x)\n", pwrpriv->bAutoResume, pwrpriv->bInternalAutoSuspend);
+		}
+
+#else	/* #ifdef CONFIG_BT_COEXIST */
+		pwrpriv->bInternalAutoSuspend = _FALSE;
+#endif	/* #ifdef CONFIG_BT_COEXIST */
+		pwrpriv->brfoffbyhw = _FALSE;
+	}
+#endif/* CONFIG_AUTOSUSPEND */
+
+
+	return ret;
+}
+
+static int rtw_resume(struct usb_interface *pusb_intf)
+{
+	struct dvobj_priv *dvobj;
+	struct pwrctrl_priv *pwrpriv;
+	struct debug_priv *pdbgpriv;
+	PADAPTER padapter;
+	struct mlme_ext_priv *pmlmeext;
+	int ret = 0;
+
+
+	dvobj = usb_get_intfdata(pusb_intf);
+	pwrpriv = dvobj_to_pwrctl(dvobj);
+	pdbgpriv = &dvobj->drv_dbg;
+	padapter = dvobj_get_primary_adapter(dvobj);
+	pmlmeext = &padapter->mlmeextpriv;
+
+	RTW_INFO("==> %s (%s:%d)\n", __FUNCTION__, current->comm, current->pid);
+	pdbgpriv->dbg_resume_cnt++;
+
+	#ifdef CONFIG_AUTOSUSPEND
+	if (pwrpriv->bInternalAutoSuspend)
+		ret = rtw_resume_process(padapter);
+	else 
+	#endif
+	{
+		if (pwrpriv->wowlan_mode || pwrpriv->wowlan_ap_mode) {
+			rtw_resume_lock_suspend();
+			ret = rtw_resume_process(padapter);
+			rtw_resume_unlock_suspend();
+		} else {
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+			rtw_resume_in_workqueue(pwrpriv);
+#else
+			if (rtw_is_earlysuspend_registered(pwrpriv)) {
+				/* jeff: bypass resume here, do in late_resume */
+				rtw_set_do_late_resume(pwrpriv, _TRUE);
+			} else {
+				rtw_resume_lock_suspend();
+				ret = rtw_resume_process(padapter);
+				rtw_resume_unlock_suspend();
+			}
+#endif
+		}
+	}
+
+	pmlmeext->last_scan_time = rtw_get_current_time();
+	RTW_INFO("<========  %s return %d\n", __FUNCTION__, ret);
+
+	return ret;
+}
+
+
+
+#ifdef CONFIG_AUTOSUSPEND
+void autosuspend_enter(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+
+	RTW_INFO("==>autosuspend_enter...........\n");
+
+	pwrpriv->bInternalAutoSuspend = _TRUE;
+	pwrpriv->bips_processing = _TRUE;
+
+	if (rf_off == pwrpriv->change_rfpwrstate) {
+#ifndef	CONFIG_BT_COEXIST
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+		usb_enable_autosuspend(dvobj->pusbdev);
+#else
+		dvobj->pusbdev->autosuspend_disabled = 0;/* autosuspend disabled by the user */
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+		usb_autopm_put_interface(dvobj->pusbintf);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
+		usb_autopm_enable(dvobj->pusbintf);
+#else
+		usb_autosuspend_device(dvobj->pusbdev, 1);
+#endif
+#else	/* #ifndef	CONFIG_BT_COEXIST */
+		if (1 == pwrpriv->autopm_cnt) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+			usb_enable_autosuspend(dvobj->pusbdev);
+#else
+			dvobj->pusbdev->autosuspend_disabled = 0;/* autosuspend disabled by the user */
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+			usb_autopm_put_interface(dvobj->pusbintf);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
+			usb_autopm_enable(dvobj->pusbintf);
+#else
+			usb_autosuspend_device(dvobj->pusbdev, 1);
+#endif
+			pwrpriv->autopm_cnt--;
+		} else
+			RTW_INFO("0!=pwrpriv->autopm_cnt[%d]   didn't usb_autopm_put_interface\n", pwrpriv->autopm_cnt);
+
+#endif	/* #ifndef	CONFIG_BT_COEXIST */
+	}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
+	RTW_INFO("...pm_usage_cnt(%d).....\n", atomic_read(&(dvobj->pusbintf->pm_usage_cnt)));
+#else
+	RTW_INFO("...pm_usage_cnt(%d).....\n", dvobj->pusbintf->pm_usage_cnt);
+#endif
+
+}
+
+int autoresume_enter(_adapter *padapter)
+{
+	int result = _SUCCESS;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+
+	RTW_INFO("====> autoresume_enter\n");
+
+	if (rf_off == pwrpriv->rf_pwrstate) {
+		pwrpriv->ps_flag = _FALSE;
+#ifndef	CONFIG_BT_COEXIST
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+		if (usb_autopm_get_interface(dvobj->pusbintf) < 0) {
+			RTW_INFO("can't get autopm: %d\n", result);
+			result = _FAIL;
+			goto error_exit;
+		}
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
+		usb_autopm_disable(dvobj->pusbintf);
+#else
+		usb_autoresume_device(dvobj->pusbdev, 1);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
+		RTW_INFO("...pm_usage_cnt(%d).....\n", atomic_read(&(dvobj->pusbintf->pm_usage_cnt)));
+#else
+		RTW_INFO("...pm_usage_cnt(%d).....\n", dvobj->pusbintf->pm_usage_cnt);
+#endif
+#else	/* #ifndef	CONFIG_BT_COEXIST */
+		pwrpriv->bAutoResume = _TRUE;
+		if (0 == pwrpriv->autopm_cnt) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+			if (usb_autopm_get_interface(dvobj->pusbintf) < 0) {
+				RTW_INFO("can't get autopm: %d\n", result);
+				result = _FAIL;
+				goto error_exit;
+			}
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
+			usb_autopm_disable(dvobj->pusbintf);
+#else
+			usb_autoresume_device(dvobj->pusbdev, 1);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
+			RTW_INFO("...pm_usage_cnt(%d).....\n", atomic_read(&(dvobj->pusbintf->pm_usage_cnt)));
+#else
+			RTW_INFO("...pm_usage_cnt(%d).....\n", dvobj->pusbintf->pm_usage_cnt);
+#endif
+			pwrpriv->autopm_cnt++;
+		} else
+			RTW_INFO("0!=pwrpriv->autopm_cnt[%d]   didn't usb_autopm_get_interface\n", pwrpriv->autopm_cnt);
+#endif /* #ifndef	CONFIG_BT_COEXIST */
+	}
+	RTW_INFO("<==== autoresume_enter\n");
+error_exit:
+
+	return result;
+}
+#endif
+
+#ifdef CONFIG_PLATFORM_RTD2880B
+extern void rtd2885_wlan_netlink_sendMsg(char *action_string, char *name);
+#endif
+
+/*
+ * 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.
+*/
+
+_adapter  *rtw_sw_export = NULL;
+
+_adapter *rtw_usb_primary_adapter_init(struct dvobj_priv *dvobj,
+	struct usb_interface *pusb_intf)
+{
+	_adapter *padapter = NULL;
+	int status = _FAIL;
+
+	padapter = (_adapter *)rtw_zvmalloc(sizeof(*padapter));
+	if (padapter == NULL)
+		goto exit;
+
+	if (loadparam(padapter) != _SUCCESS)
+		goto free_adapter;
+
+	padapter->dvobj = dvobj;
+
+
+	rtw_set_drv_stopped(padapter);/*init*/
+
+	dvobj->padapters[dvobj->iface_nums++] = padapter;
+	padapter->iface_id = IFACE_ID0;
+
+	/* set adapter_type/iface type for primary padapter */
+	padapter->isprimary = _TRUE;
+	padapter->adapter_type = PRIMARY_ADAPTER;
+#ifdef CONFIG_MI_WITH_MBSSID_CAM/*Configure all IFACE to PORT0-MBSSID*/
+	padapter->hw_port = HW_PORT0;
+#else
+	padapter->hw_port = HW_PORT0;
+#endif
+
+	/* step init_io_priv */
+	if (rtw_init_io_priv(padapter, usb_set_intf_ops) == _FAIL)
+		goto free_adapter;
+
+	/* step 2. hook HalFunc, allocate HalData */
+	if (rtw_set_hal_ops(padapter) == _FAIL)
+		goto free_hal_data;
+
+
+	padapter->intf_start = &usb_intf_start;
+	padapter->intf_stop = &usb_intf_stop;
+
+	/* step read_chip_version */
+	rtw_hal_read_chip_version(padapter);
+
+	/* step usb endpoint mapping */
+	rtw_hal_chip_configure(padapter);
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_Initialize(padapter);
+#endif
+	rtw_btcoex_wifionly_initialize(padapter);
+
+	/* step read efuse/eeprom data and get mac_addr */
+	if (rtw_hal_read_chip_info(padapter) == _FAIL)
+		goto free_hal_data;
+
+	/* step 5. */
+	if (rtw_init_drv_sw(padapter) == _FAIL) {
+		goto free_hal_data;
+	}
+
+#ifdef CONFIG_PM
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 18))
+	if (dvobj_to_pwrctl(dvobj)->bSupportRemoteWakeup) {
+		dvobj->pusbdev->do_remote_wakeup = 1;
+		pusb_intf->needs_remote_wakeup = 1;
+		device_init_wakeup(&pusb_intf->dev, 1);
+		RTW_INFO("pwrctrlpriv.bSupportRemoteWakeup~~~~~~\n");
+		RTW_INFO("pwrctrlpriv.bSupportRemoteWakeup~~~[%d]~~~\n", device_may_wakeup(&pusb_intf->dev));
+	}
+#endif
+#endif
+
+#ifdef CONFIG_AUTOSUSPEND
+	if (padapter->registrypriv.power_mgnt != PS_MODE_ACTIVE) {
+		if (padapter->registrypriv.usbss_enable) {	/* autosuspend (2s delay) */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38))
+			dvobj->pusbdev->dev.power.autosuspend_delay = 0 * HZ;/* 15 * HZ; idle-delay time */
+#else
+			dvobj->pusbdev->autosuspend_delay = 0 * HZ;/* 15 * HZ; idle-delay time */
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+			usb_enable_autosuspend(dvobj->pusbdev);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 34))
+			padapter->bDisableAutosuspend = dvobj->pusbdev->autosuspend_disabled ;
+			dvobj->pusbdev->autosuspend_disabled = 0;/* autosuspend disabled by the user */
+#endif
+
+			/* usb_autopm_get_interface(adapter_to_dvobj(padapter)->pusbintf ); */ /* init pm_usage_cnt ,let it start from 1 */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
+			RTW_INFO("%s...pm_usage_cnt(%d).....\n", __FUNCTION__, atomic_read(&(dvobj->pusbintf->pm_usage_cnt)));
+#else
+			RTW_INFO("%s...pm_usage_cnt(%d).....\n", __FUNCTION__, dvobj->pusbintf->pm_usage_cnt);
+#endif
+		}
+	}
+#endif
+	/* 2012-07-11 Move here to prevent the 8723AS-VAU BT auto suspend influence */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+	if (usb_autopm_get_interface(pusb_intf) < 0)
+		RTW_INFO("can't get autopm:\n");
+#endif
+#ifdef CONFIG_BT_COEXIST
+	dvobj_to_pwrctl(dvobj)->autopm_cnt = 1;
+#endif
+
+	/* set mac addr */
+	rtw_macaddr_cfg(adapter_mac_addr(padapter), get_hal_mac_addr(padapter));
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
+
+#ifdef CONFIG_P2P
+	rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+#endif /* CONFIG_P2P */
+	RTW_INFO("bDriverStopped:%s, bSurpriseRemoved:%s, bup:%d, hw_init_completed:%d\n"
+		 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+		 , rtw_is_surprise_removed(padapter) ? "True" : "False"
+		 , padapter->bup
+		 , rtw_get_hw_init_completed(padapter)
+		);
+
+	status = _SUCCESS;
+
+free_hal_data:
+	if (status != _SUCCESS && padapter->HalData)
+		rtw_hal_free_data(padapter);
+free_adapter:
+	if (status != _SUCCESS && padapter) {
+		rtw_vmfree((u8 *)padapter, sizeof(*padapter));
+		padapter = NULL;
+	}
+exit:
+	return padapter;
+}
+
+static void rtw_usb_primary_adapter_deinit(_adapter *padapter)
+{
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED))
+		rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
+
+#ifdef CONFIG_AP_MODE
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+		free_mlme_ap_info(padapter);
+		#ifdef CONFIG_HOSTAPD_MLME
+		hostapd_mode_unload(padapter);
+		#endif
+	}
+#endif
+
+	/*rtw_cancel_all_timer(if1);*/
+
+#ifdef CONFIG_WOWLAN
+	pwrctl->wowlan_mode = _FALSE;
+#endif /* CONFIG_WOWLAN */
+
+	rtw_dev_unload(padapter);
+
+	RTW_INFO("+r871xu_dev_remove, hw_init_completed=%d\n", rtw_get_hw_init_completed(padapter));
+
+#ifdef CONFIG_BT_COEXIST
+	if (1 == pwrctl->autopm_cnt) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+		usb_autopm_put_interface(adapter_to_dvobj(padapter)->pusbintf);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
+		usb_autopm_enable(adapter_to_dvobj(padapter)->pusbintf);
+#else
+		usb_autosuspend_device(adapter_to_dvobj(padapter)->pusbdev, 1);
+#endif
+		pwrctl->autopm_cnt--;
+	}
+#endif
+
+	rtw_free_drv_sw(padapter);
+
+	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
+	rtw_os_ndev_free(padapter);
+
+#ifdef RTW_HALMAC
+	rtw_halmac_deinit_adapter(adapter_to_dvobj(padapter));
+#endif /* RTW_HALMAC */
+
+	rtw_vmfree((u8 *)padapter, sizeof(_adapter));
+
+#ifdef CONFIG_PLATFORM_RTD2880B
+	RTW_INFO("wlan link down\n");
+	rtd2885_wlan_netlink_sendMsg("linkdown", "8712");
+#endif
+
+}
+
+static int rtw_drv_init(struct usb_interface *pusb_intf, const struct usb_device_id *pdid)
+{
+	_adapter *padapter = NULL;
+	int status = _FAIL;
+	struct dvobj_priv *dvobj;
+#ifdef CONFIG_CONCURRENT_MODE
+	int i;
+#endif
+
+	/* RTW_INFO("+rtw_drv_init\n"); */
+
+	/* step 0. */
+	process_spec_devid(pdid);
+
+	/* Initialize dvobj_priv */
+	dvobj = usb_dvobj_init(pusb_intf, pdid);
+	if (dvobj == NULL) {
+		goto exit;
+	}
+
+	padapter = rtw_usb_primary_adapter_init(dvobj, pusb_intf);
+	if (padapter == NULL) {
+		RTW_INFO("rtw_usb_primary_adapter_init Failed!\n");
+		goto free_dvobj;
+	}
+
+	if (usb_reprobe_switch_usb_mode(padapter) == _TRUE)
+		goto free_if_prim;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (padapter->registrypriv.virtual_iface_num > (CONFIG_IFACE_NUMBER - 1))
+		padapter->registrypriv.virtual_iface_num = (CONFIG_IFACE_NUMBER - 1);
+
+	for (i = 0; i < padapter->registrypriv.virtual_iface_num; i++) {
+		if (rtw_drv_add_vir_if(padapter, usb_set_intf_ops) == NULL) {
+			RTW_INFO("rtw_drv_add_iface failed! (%d)\n", i);
+			goto free_if_vir;
+		}
+	}
+#endif
+
+#ifdef CONFIG_INTEL_PROXIM
+	rtw_sw_export = padapter;
+#endif
+
+#ifdef CONFIG_GLOBAL_UI_PID
+	if (ui_pid[1] != 0) {
+		RTW_INFO("ui_pid[1]:%d\n", ui_pid[1]);
+		rtw_signal_process(ui_pid[1], SIGUSR2);
+	}
+#endif
+
+	/* dev_alloc_name && register_netdev */
+	if (rtw_os_ndevs_init(dvobj) != _SUCCESS)
+		goto free_if_vir;
+
+#ifdef CONFIG_HOSTAPD_MLME
+	hostapd_mode_init(padapter);
+#endif
+
+#ifdef CONFIG_PLATFORM_RTD2880B
+	RTW_INFO("wlan link up\n");
+	rtd2885_wlan_netlink_sendMsg("linkup", "8712");
+#endif
+
+
+	status = _SUCCESS;
+
+#if 0 /* not used now */
+os_ndevs_deinit:
+	if (status != _SUCCESS)
+		rtw_os_ndevs_deinit(dvobj);
+#endif
+free_if_vir:
+	if (status != _SUCCESS) {
+		#ifdef CONFIG_CONCURRENT_MODE
+		rtw_drv_stop_vir_ifaces(dvobj);
+		rtw_drv_free_vir_ifaces(dvobj);
+		#endif
+	}
+
+free_if_prim:
+	if (status != _SUCCESS && padapter)
+		rtw_usb_primary_adapter_deinit(padapter);
+
+free_dvobj:
+	if (status != _SUCCESS)
+		usb_dvobj_deinit(pusb_intf);
+exit:
+	return status == _SUCCESS ? 0 : -ENODEV;
+}
+
+/*
+ * dev_remove() - our device is being removed
+*/
+/* rmmod module & unplug(SurpriseRemoved) will call r871xu_dev_remove() => how to recognize both */
+static void rtw_dev_remove(struct usb_interface *pusb_intf)
+{
+	struct dvobj_priv *dvobj = usb_get_intfdata(pusb_intf);
+	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(dvobj);
+	_adapter *padapter = dvobj_get_primary_adapter(dvobj);
+	struct net_device *pnetdev = padapter->pnetdev;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+
+	RTW_INFO("+rtw_dev_remove\n");
+
+	dvobj->processing_dev_remove = _TRUE;
+
+	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
+	rtw_os_ndevs_unregister(dvobj);
+
+	if (usb_drv.drv_registered == _TRUE) {
+		/* RTW_INFO("r871xu_dev_remove():padapter->bSurpriseRemoved == _TRUE\n"); */
+		rtw_set_surprise_removed(padapter);
+	}
+	/*else
+	{
+
+		rtw_set_hw_init_completed(padapter, _FALSE);
+	}*/
+
+
+#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
+	rtw_unregister_early_suspend(pwrctl);
+#endif
+
+	if (GET_HAL_DATA(padapter)->bFWReady == _TRUE) {
+		rtw_pm_set_ips(padapter, IPS_NONE);
+		rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
+
+		LeaveAllPowerSaveMode(padapter);
+	}
+	rtw_set_drv_stopped(padapter);	/*for stop thread*/
+	rtw_stop_cmd_thread(padapter);
+#ifdef CONFIG_CONCURRENT_MODE
+	rtw_drv_stop_vir_ifaces(dvobj);
+#endif /* CONFIG_CONCURRENT_MODE */
+
+#ifdef CONFIG_BT_COEXIST
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	if (GET_HAL_DATA(padapter)->EEPROMBluetoothCoexist)
+		rtw_btcoex_close_socket(padapter);
+#endif
+	rtw_btcoex_HaltNotify(padapter);
+#endif
+
+	rtw_usb_primary_adapter_deinit(padapter);
+
+#ifdef CONFIG_CONCURRENT_MODE
+	rtw_drv_free_vir_ifaces(dvobj);
+#endif /* CONFIG_CONCURRENT_MODE */
+
+	usb_dvobj_deinit(pusb_intf);
+
+	RTW_INFO("-r871xu_dev_remove, done\n");
+
+
+#ifdef CONFIG_INTEL_PROXIM
+	rtw_sw_export = NULL;
+#endif
+
+
+	return;
+
+}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
+extern int console_suspend_enabled;
+#endif
+
+static int /*__init*/ rtw_drv_entry(void)
+{
+	int ret = 0;
+
+	RTW_PRINT("module init start\n");
+	dump_drv_version(RTW_DBGDUMP);
+#ifdef BTCOEXVERSION
+	RTW_PRINT(DRV_NAME" BT-Coex version = %s\n", BTCOEXVERSION);
+#endif /* BTCOEXVERSION */
+
+	ret = platform_wifi_power_on();
+	if (ret != 0) {
+		RTW_INFO("%s: power on failed!!(%d)\n", __FUNCTION__, ret);
+		ret = -1;
+		goto exit;
+	}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
+	/* console_suspend_enabled=0; */
+#endif
+
+	usb_drv.drv_registered = _TRUE;
+	rtw_suspend_lock_init();
+	rtw_drv_proc_init();
+	rtw_ndev_notifier_register();
+	rtw_inetaddr_notifier_register();
+
+	ret = usb_register(&usb_drv.usbdrv);
+
+	if (ret != 0) {
+		usb_drv.drv_registered = _FALSE;
+		rtw_suspend_lock_uninit();
+		rtw_drv_proc_deinit();
+		rtw_ndev_notifier_unregister();
+		rtw_inetaddr_notifier_unregister();
+		goto exit;
+	}
+
+exit:
+	RTW_PRINT("module init ret=%d\n", ret);
+	return ret;
+}
+
+static void /*__exit*/ rtw_drv_halt(void)
+{
+	RTW_PRINT("module exit start\n");
+
+	usb_drv.drv_registered = _FALSE;
+
+	usb_deregister(&usb_drv.usbdrv);
+
+	platform_wifi_power_off();
+
+	rtw_suspend_lock_uninit();
+	rtw_drv_proc_deinit();
+	rtw_ndev_notifier_unregister();
+	rtw_inetaddr_notifier_unregister();
+
+	RTW_PRINT("module exit success\n");
+
+	rtw_mstat_dump(RTW_DBGDUMP);
+}
+
+
+
+#include <linux/rfkill-wlan.h>
+extern int get_wifi_chip_type(void);
+extern int rockchip_wifi_power(int on);
+extern int rockchip_wifi_set_carddetect(int val);
+
+int rockchip_wifi_init_module_rtkwifi(void)
+{
+#ifdef CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP
+    int type = get_wifi_chip_type();
+    if (type < WIFI_AP6XXX_SERIES || type == WIFI_ESP8089) return 0;
+#endif
+    printk("\n");
+    printk("=======================================================\n");
+    printk("==== Launching Wi-Fi driver! (Powered by Rockchip) ====\n");
+    printk("=======================================================\n");
+    printk("Realtek 8812BU/8822BU USB WiFi driver (Powered by Rockchip,Ver %s) init.\n", DRIVERVERSION);
+    rockchip_wifi_power(1);
+    return rtw_drv_entry();
+}
+
+void rockchip_wifi_exit_module_rtkwifi(void)
+{
+#ifdef CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP
+    int type = get_wifi_chip_type();
+    if (type < WIFI_AP6XXX_SERIES || type == WIFI_ESP8089) return;
+#endif
+    printk("\n");
+    printk("=======================================================\n");
+    printk("==== Dislaunching Wi-Fi driver! (Powered by Rockchip) ====\n");
+    printk("=======================================================\n");
+    printk("Realtek 8812BU/8822BU USB WiFi driver (Powered by Rockchip,Ver %s) init.\n", DRIVERVERSION);
+    rtw_drv_halt();
+    rockchip_wifi_power(0);
+}
+#ifdef CONFIG_WIFI_BUILD_MODULE
+module_init(rockchip_wifi_init_module_rtkwifi);
+module_exit(rockchip_wifi_exit_module_rtkwifi);
+#else
+#ifdef CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP
+late_initcall(rockchip_wifi_init_module_rtkwifi);
+module_exit(rockchip_wifi_exit_module_rtkwifi);
+#else
+EXPORT_SYMBOL(rockchip_wifi_init_module_rtkwifi);
+EXPORT_SYMBOL(rockchip_wifi_exit_module_rtkwifi);
+#endif
+#endif
+#ifdef CONFIG_INTEL_PROXIM
+_adapter  *rtw_usb_get_sw_pointer(void)
+{
+	return rtw_sw_export;
+}
+EXPORT_SYMBOL(rtw_usb_get_sw_pointer);
+#endif /* CONFIG_INTEL_PROXIM */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/usb_ops_linux.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/usb_ops_linux.c
new file mode 100644
index 000000000000..20af2be35a42
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/usb_ops_linux.c
@@ -0,0 +1,1138 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+#include <rtw_sreset.h>
+
+struct rtw_async_write_data {
+	u8 data[VENDOR_CMD_MAX_DATA_LEN];
+	struct usb_ctrlrequest dr;
+};
+
+int usbctrl_vendorreq(struct intf_hdl *pintfhdl, u8 request, u16 value, u16 index, void *pdata, u16 len, u8 requesttype)
+{
+	_adapter	*padapter = pintfhdl->padapter;
+	struct dvobj_priv  *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(pdvobjpriv);
+	struct usb_device *udev = pdvobjpriv->pusbdev;
+
+	unsigned int pipe;
+	int status = 0;
+	u32 tmp_buflen = 0;
+	u8 reqtype;
+	u8 *pIo_buf;
+	int vendorreq_times = 0;
+
+#if (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+#define REG_ON_SEC 0x00
+#define REG_OFF_SEC 0x01
+#define REG_LOCAL_SEC 0x02
+	u8 current_reg_sec = REG_LOCAL_SEC;
+#endif
+
+#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_DYNAMIC_ALLOCATE
+	u8 *tmp_buf;
+#else /* use stack memory */
+	u8 tmp_buf[MAX_USB_IO_CTL_SIZE];
+#endif
+
+	/* RTW_INFO("%s %s:%d\n",__FUNCTION__, current->comm, current->pid); */
+
+	if (RTW_CANNOT_IO(padapter)) {
+		status = -EPERM;
+		goto exit;
+	}
+
+	if (len > MAX_VENDOR_REQ_CMD_SIZE) {
+		RTW_INFO("[%s] Buffer len error ,vendor request failed\n", __FUNCTION__);
+		status = -EINVAL;
+		goto exit;
+	}
+
+#ifdef CONFIG_USB_VENDOR_REQ_MUTEX
+	_enter_critical_mutex_lock(&pdvobjpriv->usb_vendor_req_mutex, NULL);
+#endif
+
+
+	/* Acquire IO memory for vendorreq */
+#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC
+	pIo_buf = pdvobjpriv->usb_vendor_req_buf;
+#else
+	#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_DYNAMIC_ALLOCATE
+	tmp_buf = rtw_malloc((u32) len + ALIGNMENT_UNIT);
+	tmp_buflen = (u32)len + ALIGNMENT_UNIT;
+	#else /* use stack memory */
+	tmp_buflen = MAX_USB_IO_CTL_SIZE;
+	#endif
+
+	/* Added by Albert 2010/02/09 */
+	/* For mstar platform, mstar suggests the address for USB IO should be 16 bytes alignment. */
+	/* Trying to fix it here. */
+	pIo_buf = (tmp_buf == NULL) ? NULL : tmp_buf + ALIGNMENT_UNIT - ((SIZE_PTR)(tmp_buf) & 0x0f);
+#endif
+
+	if (pIo_buf == NULL) {
+		RTW_INFO("[%s] pIo_buf == NULL\n", __FUNCTION__);
+		status = -ENOMEM;
+		goto release_mutex;
+	}
+
+	while (++vendorreq_times <= MAX_USBCTRL_VENDORREQ_TIMES) {
+		_rtw_memset(pIo_buf, 0, len);
+
+		if (requesttype == 0x01) {
+			pipe = usb_rcvctrlpipe(udev, 0);/* read_in */
+			reqtype =  REALTEK_USB_VENQT_READ;
+		} else {
+			pipe = usb_sndctrlpipe(udev, 0);/* write_out */
+			reqtype =  REALTEK_USB_VENQT_WRITE;
+			_rtw_memcpy(pIo_buf, pdata, len);
+		}
+
+		status = rtw_usb_control_msg(udev, pipe, request, reqtype, value, index, pIo_buf, len, RTW_USB_CONTROL_MSG_TIMEOUT);
+
+		if (status == len) {  /* Success this control transfer. */
+			rtw_reset_continual_io_error(pdvobjpriv);
+			if (requesttype == 0x01) {
+				/* For Control read transfer, we have to copy the read data from pIo_buf to pdata. */
+				_rtw_memcpy(pdata, pIo_buf,  len);
+			}
+		} else { /* error cases */
+			RTW_INFO("reg 0x%x, usb %s %u fail, status:%d value=0x%x, vendorreq_times:%d\n"
+				, value, (requesttype == 0x01) ? "read" : "write" , len, status, *(u32 *)pdata, vendorreq_times);
+
+			if (status < 0) {
+				if (status == (-ESHUTDOWN)	|| status == -ENODEV)
+					rtw_set_surprise_removed(padapter);
+				else {
+					#ifdef DBG_CONFIG_ERROR_DETECT
+					{
+						HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+						pHalData->srestpriv.Wifi_Error_Status = USB_VEN_REQ_CMD_FAIL;
+					}
+					#endif
+				}
+			} else { /* status != len && status >= 0 */
+				if (status > 0) {
+					if (requesttype == 0x01) {
+						/* For Control read transfer, we have to copy the read data from pIo_buf to pdata. */
+						_rtw_memcpy(pdata, pIo_buf,  len);
+					}
+				}
+			}
+
+			if (rtw_inc_and_chk_continual_io_error(pdvobjpriv) == _TRUE) {
+				rtw_set_surprise_removed(padapter);
+				break;
+			}
+
+		}
+
+		/* firmware download is checksumed, don't retry */
+		if ((value >= FW_START_ADDRESS) || status == len)
+			break;
+
+	}
+
+#if (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+	if (value < 0xFE00) {
+		if (0x00 <= value && value <= 0xff)
+			current_reg_sec = REG_ON_SEC;
+		else if (0x1000 <= value && value <= 0x10ff)
+			current_reg_sec = REG_ON_SEC;
+		else
+			current_reg_sec = REG_OFF_SEC;
+	} else {
+		current_reg_sec = REG_LOCAL_SEC;
+	}
+
+	if (current_reg_sec == REG_ON_SEC) {
+		unsigned int t_pipe = usb_sndctrlpipe(udev, 0);/* write_out */
+		u8 t_reqtype =  REALTEK_USB_VENQT_WRITE;
+		u8 t_len = 1;
+		u8 t_req = 0x05;
+		u16 t_reg = 0;
+		u16 t_index = 0;
+
+		t_reg = 0x4e0;
+
+		status = rtw_usb_control_msg(udev, t_pipe, t_req, t_reqtype, t_reg, t_index, pIo_buf, t_len, RTW_USB_CONTROL_MSG_TIMEOUT);
+
+		if (status == t_len)
+			rtw_reset_continual_io_error(pdvobjpriv);
+		else
+			RTW_INFO("reg 0x%x, usb %s %u fail, status:%d\n", t_reg, "write" , t_len, status);
+
+	}
+#endif
+
+	/* release IO memory used by vendorreq */
+#ifdef CONFIG_USB_VENDOR_REQ_BUFFER_DYNAMIC_ALLOCATE
+	rtw_mfree(tmp_buf, tmp_buflen);
+#endif
+
+release_mutex:
+#ifdef CONFIG_USB_VENDOR_REQ_MUTEX
+	_exit_critical_mutex(&pdvobjpriv->usb_vendor_req_mutex, NULL);
+#endif
+exit:
+	return status;
+
+}
+
+#ifdef CONFIG_USB_SUPPORT_ASYNC_VDN_REQ
+static void _usbctrl_vendorreq_async_callback(struct urb *urb, struct pt_regs *regs)
+{
+	if (urb) {
+		if (urb->context)
+			rtw_mfree(urb->context, sizeof(struct rtw_async_write_data));
+		usb_free_urb(urb);
+	}
+}
+
+int _usbctrl_vendorreq_async_write(struct usb_device *udev, u8 request,
+	u16 value, u16 index, void *pdata, u16 len, u8 requesttype)
+{
+	int rc;
+	unsigned int pipe;
+	u8 reqtype;
+	struct usb_ctrlrequest *dr;
+	struct urb *urb;
+	struct rtw_async_write_data *buf;
+
+
+	if (requesttype == VENDOR_READ) {
+		pipe = usb_rcvctrlpipe(udev, 0);/* read_in */
+		reqtype =  REALTEK_USB_VENQT_READ;
+	} else {
+		pipe = usb_sndctrlpipe(udev, 0);/* write_out */
+		reqtype =  REALTEK_USB_VENQT_WRITE;
+	}
+
+	buf = (struct rtl819x_async_write_data *)rtw_zmalloc(sizeof(*buf));
+	if (!buf) {
+		rc = -ENOMEM;
+		goto exit;
+	}
+
+	urb = usb_alloc_urb(0, GFP_ATOMIC);
+	if (!urb) {
+		rtw_mfree((u8 *)buf, sizeof(*buf));
+		rc = -ENOMEM;
+		goto exit;
+	}
+
+	dr = &buf->dr;
+
+	dr->bRequestType = reqtype;
+	dr->bRequest = request;
+	dr->wValue = cpu_to_le16(value);
+	dr->wIndex = cpu_to_le16(index);
+	dr->wLength = cpu_to_le16(len);
+
+	_rtw_memcpy(buf, pdata, len);
+
+	usb_fill_control_urb(urb, udev, pipe, (unsigned char *)dr, buf, len,
+		_usbctrl_vendorreq_async_callback, buf);
+
+	rc = usb_submit_urb(urb, GFP_ATOMIC);
+	if (rc < 0) {
+		rtw_mfree((u8 *)buf, sizeof(*buf));
+		usb_free_urb(urb);
+	}
+
+exit:
+	return rc;
+}
+
+
+#endif /* CONFIG_USB_SUPPORT_ASYNC_VDN_REQ */
+
+unsigned int ffaddr2pipehdl(struct dvobj_priv *pdvobj, u32 addr)
+{
+	unsigned int pipe = 0, ep_num = 0;
+	struct usb_device *pusbd = pdvobj->pusbdev;
+
+	if (addr == RECV_BULK_IN_ADDR)
+		pipe = usb_rcvbulkpipe(pusbd, pdvobj->RtInPipe[0]);
+
+	else if (addr == RECV_INT_IN_ADDR)
+		pipe = usb_rcvintpipe(pusbd, pdvobj->RtInPipe[1]);
+
+	else if (addr < HW_QUEUE_ENTRY) {
+#ifdef RTW_HALMAC
+		/* halmac already translate queue id to bulk out id */
+		ep_num = pdvobj->RtOutPipe[addr];
+#else
+		ep_num = pdvobj->Queue2Pipe[addr];
+#endif
+		pipe = usb_sndbulkpipe(pusbd, ep_num);
+	}
+
+	return pipe;
+}
+
+struct zero_bulkout_context {
+	void *pbuf;
+	void *purb;
+	void *pirp;
+	void *padapter;
+};
+
+static void usb_bulkout_zero_complete(struct urb *purb, struct pt_regs *regs)
+{
+	struct zero_bulkout_context *pcontext = (struct zero_bulkout_context *)purb->context;
+
+	/* RTW_INFO("+usb_bulkout_zero_complete\n"); */
+
+	if (pcontext) {
+		if (pcontext->pbuf)
+			rtw_mfree(pcontext->pbuf, sizeof(int));
+
+		if (pcontext->purb && (pcontext->purb == purb))
+			usb_free_urb(pcontext->purb);
+
+
+		rtw_mfree((u8 *)pcontext, sizeof(struct zero_bulkout_context));
+	}
+
+
+}
+
+static u32 usb_bulkout_zero(struct intf_hdl *pintfhdl, u32 addr)
+{
+	int pipe, status, len;
+	u32 ret;
+	unsigned char *pbuf;
+	struct zero_bulkout_context *pcontext;
+	PURB	purb = NULL;
+	_adapter *padapter = (_adapter *)pintfhdl->padapter;
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(pdvobj);
+	struct usb_device *pusbd = pdvobj->pusbdev;
+
+	/* RTW_INFO("%s\n", __func__); */
+
+
+	if (RTW_CANNOT_TX(padapter))
+		return _FAIL;
+
+
+	pcontext = (struct zero_bulkout_context *)rtw_zmalloc(sizeof(struct zero_bulkout_context));
+	if (pcontext == NULL)
+		return _FAIL;
+
+	pbuf = (unsigned char *)rtw_zmalloc(sizeof(int));
+	purb = usb_alloc_urb(0, GFP_ATOMIC);
+
+	/* translate DMA FIFO addr to pipehandle */
+	pipe = ffaddr2pipehdl(pdvobj, addr);
+
+	len = 0;
+	pcontext->pbuf = pbuf;
+	pcontext->purb = purb;
+	pcontext->pirp = NULL;
+	pcontext->padapter = padapter;
+
+
+	/* translate DMA FIFO addr to pipehandle */
+	/* pipe = ffaddr2pipehdl(pdvobj, addr);	 */
+
+	usb_fill_bulk_urb(purb, pusbd, pipe,
+			  pbuf,
+			  len,
+			  usb_bulkout_zero_complete,
+			  pcontext);/* context is pcontext */
+
+	status = usb_submit_urb(purb, GFP_ATOMIC);
+
+	if (!status)
+		ret = _SUCCESS;
+	else
+		ret = _FAIL;
+
+
+	return _SUCCESS;
+
+}
+
+void usb_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem)
+{
+
+}
+
+void usb_write_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem)
+{
+
+}
+
+
+void usb_read_port_cancel(struct intf_hdl *pintfhdl)
+{
+	int i;
+	struct recv_buf *precvbuf;
+	_adapter	*padapter = pintfhdl->padapter;
+	precvbuf = (struct recv_buf *)padapter->recvpriv.precv_buf;
+
+	RTW_INFO("%s\n", __func__);
+
+	for (i = 0; i < NR_RECVBUFF ; i++) {
+
+		if (precvbuf->purb)	 {
+			/* RTW_INFO("usb_read_port_cancel : usb_kill_urb\n"); */
+			usb_kill_urb(precvbuf->purb);
+		}
+		precvbuf++;
+	}
+
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+	usb_kill_urb(padapter->recvpriv.int_in_urb);
+#endif
+}
+
+static void usb_write_port_complete(struct urb *purb, struct pt_regs *regs)
+{
+	_irqL irqL;
+	int i;
+	struct xmit_buf *pxmitbuf = (struct xmit_buf *)purb->context;
+	/* struct xmit_frame *pxmitframe = (struct xmit_frame *)pxmitbuf->priv_data; */
+	/* _adapter			*padapter = pxmitframe->padapter; */
+	_adapter	*padapter = pxmitbuf->padapter;
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+	/* struct pkt_attrib *pattrib = &pxmitframe->attrib; */
+
+
+	switch (pxmitbuf->flags) {
+	case VO_QUEUE_INX:
+		pxmitpriv->voq_cnt--;
+		break;
+	case VI_QUEUE_INX:
+		pxmitpriv->viq_cnt--;
+		break;
+	case BE_QUEUE_INX:
+		pxmitpriv->beq_cnt--;
+		break;
+	case BK_QUEUE_INX:
+		pxmitpriv->bkq_cnt--;
+		break;
+	default:
+		break;
+	}
+
+
+	/*
+		_enter_critical(&pxmitpriv->lock, &irqL);
+
+		pxmitpriv->txirp_cnt--;
+
+		switch(pattrib->priority)
+		{
+			case 1:
+			case 2:
+				pxmitpriv->bkq_cnt--;
+
+				break;
+			case 4:
+			case 5:
+				pxmitpriv->viq_cnt--;
+
+				break;
+			case 6:
+			case 7:
+				pxmitpriv->voq_cnt--;
+
+				break;
+			case 0:
+			case 3:
+			default:
+				pxmitpriv->beq_cnt--;
+
+				break;
+
+		}
+
+		_exit_critical(&pxmitpriv->lock, &irqL);
+
+
+		if(pxmitpriv->txirp_cnt==0)
+		{
+			_rtw_up_sema(&(pxmitpriv->tx_retevt));
+		}
+	*/
+	/* rtw_free_xmitframe(pxmitpriv, pxmitframe); */
+
+	if (RTW_CANNOT_TX(padapter)) {
+		RTW_INFO("%s(): TX Warning! bDriverStopped(%s) OR bSurpriseRemoved(%s) pxmitbuf->buf_tag(%x)\n"
+			 , __func__
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			 , rtw_is_surprise_removed(padapter) ? "True" : "False"
+			 , pxmitbuf->buf_tag);
+
+		goto check_completion;
+	}
+
+
+	if (purb->status == 0) {
+
+	} else {
+		RTW_INFO("###=> urb_write_port_complete status(%d)\n", purb->status);
+		if ((purb->status == -EPIPE) || (purb->status == -EPROTO)) {
+			/* usb_clear_halt(pusbdev, purb->pipe);	 */
+			/* msleep(10); */
+			sreset_set_wifi_error_status(padapter, USB_WRITE_PORT_FAIL);
+		} else if (purb->status == -EINPROGRESS) {
+			goto check_completion;
+
+		} else if (purb->status == -ENOENT) {
+			RTW_INFO("%s: -ENOENT\n", __func__);
+			goto check_completion;
+
+		} else if (purb->status == -ECONNRESET) {
+			RTW_INFO("%s: -ECONNRESET\n", __func__);
+			goto check_completion;
+
+		} else if (purb->status == -ESHUTDOWN) {
+			rtw_set_drv_stopped(padapter);
+
+			goto check_completion;
+		} else {
+			rtw_set_surprise_removed(padapter);
+			RTW_INFO("bSurpriseRemoved=TRUE\n");
+
+			goto check_completion;
+		}
+	}
+
+	#ifdef DBG_CONFIG_ERROR_DETECT
+	{
+		HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+		pHalData->srestpriv.last_tx_complete_time = rtw_get_current_time();
+	}
+	#endif
+
+check_completion:
+	_enter_critical(&pxmitpriv->lock_sctx, &irqL);
+	rtw_sctx_done_err(&pxmitbuf->sctx,
+		purb->status ? RTW_SCTX_DONE_WRITE_PORT_ERR : RTW_SCTX_DONE_SUCCESS);
+	_exit_critical(&pxmitpriv->lock_sctx, &irqL);
+
+	rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
+
+	/* if(rtw_txframes_pending(padapter))	 */
+	{
+		tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
+	}
+
+
+}
+
+u32 usb_write_port(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem)
+{
+	_irqL irqL;
+	unsigned int pipe;
+	int status;
+	u32 ret = _FAIL, bwritezero = _FALSE;
+	PURB	purb = NULL;
+	_adapter *padapter = (_adapter *)pintfhdl->padapter;
+	struct dvobj_priv	*pdvobj = adapter_to_dvobj(padapter);
+	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(pdvobj);
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+	struct xmit_buf *pxmitbuf = (struct xmit_buf *)wmem;
+	struct xmit_frame *pxmitframe = (struct xmit_frame *)pxmitbuf->priv_data;
+	struct usb_device *pusbd = pdvobj->pusbdev;
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
+
+
+
+	if (RTW_CANNOT_TX(padapter)) {
+#ifdef DBG_TX
+		RTW_INFO(" DBG_TX %s:%d bDriverStopped%s, bSurpriseRemoved:%s\n", __func__, __LINE__
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+#endif
+		rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_TX_DENY);
+		goto exit;
+	}
+
+	_enter_critical(&pxmitpriv->lock, &irqL);
+
+	switch (addr) {
+	case VO_QUEUE_INX:
+		pxmitpriv->voq_cnt++;
+		pxmitbuf->flags = VO_QUEUE_INX;
+		break;
+	case VI_QUEUE_INX:
+		pxmitpriv->viq_cnt++;
+		pxmitbuf->flags = VI_QUEUE_INX;
+		break;
+	case BE_QUEUE_INX:
+		pxmitpriv->beq_cnt++;
+		pxmitbuf->flags = BE_QUEUE_INX;
+		break;
+	case BK_QUEUE_INX:
+		pxmitpriv->bkq_cnt++;
+		pxmitbuf->flags = BK_QUEUE_INX;
+		break;
+	case HIGH_QUEUE_INX:
+		pxmitbuf->flags = HIGH_QUEUE_INX;
+		break;
+	default:
+		pxmitbuf->flags = MGT_QUEUE_INX;
+		break;
+	}
+
+	_exit_critical(&pxmitpriv->lock, &irqL);
+
+	purb	= pxmitbuf->pxmit_urb[0];
+
+	/* translate DMA FIFO addr to pipehandle */
+#ifdef RTW_HALMAC
+	pipe = ffaddr2pipehdl(pdvobj, pxmitbuf->bulkout_id);
+#else
+	pipe = ffaddr2pipehdl(pdvobj, addr);
+#endif
+
+#ifdef CONFIG_REDUCE_USB_TX_INT
+	if ((pxmitpriv->free_xmitbuf_cnt % NR_XMITBUFF == 0)
+	    || (pxmitbuf->buf_tag > XMITBUF_DATA))
+		purb->transfer_flags  &= (~URB_NO_INTERRUPT);
+	else {
+		purb->transfer_flags  |=  URB_NO_INTERRUPT;
+		/* RTW_INFO("URB_NO_INTERRUPT "); */
+	}
+#endif
+
+
+	usb_fill_bulk_urb(purb, pusbd, pipe,
+			  pxmitframe->buf_addr, /* = pxmitbuf->pbuf */
+			  cnt,
+			  usb_write_port_complete,
+			  pxmitbuf);/* context is pxmitbuf */
+
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_TX
+	purb->transfer_dma = pxmitbuf->dma_transfer_addr;
+	purb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
+	purb->transfer_flags |= URB_ZERO_PACKET;
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+
+#ifdef USB_PACKET_OFFSET_SZ
+#if (USB_PACKET_OFFSET_SZ == 0)
+	purb->transfer_flags |= URB_ZERO_PACKET;
+#endif
+#endif
+
+#if 0
+	if (bwritezero)
+		purb->transfer_flags |= URB_ZERO_PACKET;
+#endif
+
+	status = usb_submit_urb(purb, GFP_ATOMIC);
+	if (!status) {
+		#ifdef DBG_CONFIG_ERROR_DETECT
+		{
+			HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+			pHalData->srestpriv.last_tx_time = rtw_get_current_time();
+		}
+		#endif
+	} else {
+		rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_WRITE_PORT_ERR);
+		RTW_INFO("usb_write_port, status=%d\n", status);
+
+		switch (status) {
+		case -ENODEV:
+			rtw_set_drv_stopped(padapter);
+			break;
+		default:
+			break;
+		}
+		goto exit;
+	}
+
+	ret = _SUCCESS;
+
+	/* Commented by Albert 2009/10/13
+	 * We add the URB_ZERO_PACKET flag to urb so that the host will send the zero packet automatically. */
+	/*
+		if(bwritezero == _TRUE)
+		{
+			usb_bulkout_zero(pintfhdl, addr);
+		}
+	*/
+
+
+exit:
+	if (ret != _SUCCESS)
+		rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
+	return ret;
+
+}
+
+void usb_write_port_cancel(struct intf_hdl *pintfhdl)
+{
+	int i, j;
+	_adapter	*padapter = pintfhdl->padapter;
+	struct xmit_buf *pxmitbuf = (struct xmit_buf *)padapter->xmitpriv.pxmitbuf;
+
+	RTW_INFO("%s\n", __func__);
+
+	for (i = 0; i < NR_XMITBUFF; i++) {
+		for (j = 0; j < 8; j++) {
+			if (pxmitbuf->pxmit_urb[j])
+				usb_kill_urb(pxmitbuf->pxmit_urb[j]);
+		}
+		pxmitbuf++;
+	}
+
+	pxmitbuf = (struct xmit_buf *)padapter->xmitpriv.pxmit_extbuf;
+	for (i = 0; i < NR_XMIT_EXTBUFF ; i++) {
+		for (j = 0; j < 8; j++) {
+			if (pxmitbuf->pxmit_urb[j])
+				usb_kill_urb(pxmitbuf->pxmit_urb[j]);
+		}
+		pxmitbuf++;
+	}
+}
+
+void usb_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf)
+{
+
+	precvbuf->transfer_len = 0;
+
+	precvbuf->len = 0;
+
+	precvbuf->ref_cnt = 0;
+
+	if (precvbuf->pbuf) {
+		precvbuf->pdata = precvbuf->phead = precvbuf->ptail = precvbuf->pbuf;
+		precvbuf->pend = precvbuf->pdata + MAX_RECVBUF_SZ;
+	}
+
+}
+
+int recvbuf2recvframe(PADAPTER padapter, void *ptr);
+
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+void usb_recv_tasklet(void *priv)
+{
+	struct recv_buf *precvbuf = NULL;
+	_adapter	*padapter = (_adapter *)priv;
+	struct recv_priv	*precvpriv = &padapter->recvpriv;
+
+	while (NULL != (precvbuf = rtw_dequeue_recvbuf(&precvpriv->recv_buf_pending_queue))) {
+		if (RTW_CANNOT_RUN(padapter)) {
+			RTW_INFO("recv_tasklet => bDriverStopped(%s) OR bSurpriseRemoved(%s)\n"
+				, rtw_is_drv_stopped(padapter)? "True" : "False"
+				, rtw_is_surprise_removed(padapter)? "True" : "False");
+			break;
+		}
+
+		recvbuf2recvframe(padapter, precvbuf);
+
+		rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+	}
+}
+
+void usb_read_port_complete(struct urb *purb, struct pt_regs *regs)
+{
+	struct recv_buf	*precvbuf = (struct recv_buf *)purb->context;
+	_adapter			*padapter = (_adapter *)precvbuf->adapter;
+	struct recv_priv	*precvpriv = &padapter->recvpriv;
+
+	ATOMIC_DEC(&(precvpriv->rx_pending_cnt));
+
+	if (RTW_CANNOT_RX(padapter)) {
+		RTW_INFO("%s() RX Warning! bDriverStopped(%s) OR bSurpriseRemoved(%s)\n"
+			 , __func__
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+		return;
+	}
+
+	if (purb->status == 0) {
+
+		if ((purb->actual_length > MAX_RECVBUF_SZ) || (purb->actual_length < RXDESC_SIZE)) {
+			RTW_INFO("%s()-%d: urb->actual_length:%u, MAX_RECVBUF_SZ:%u, RXDESC_SIZE:%u\n"
+				, __FUNCTION__, __LINE__, purb->actual_length, MAX_RECVBUF_SZ, RXDESC_SIZE);
+			rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+		} else {
+			rtw_reset_continual_io_error(adapter_to_dvobj(padapter));
+
+			precvbuf->transfer_len = purb->actual_length;
+
+			rtw_enqueue_recvbuf(precvbuf, &precvpriv->recv_buf_pending_queue);
+
+			tasklet_schedule(&precvpriv->recv_tasklet);
+		}
+	} else {
+
+		RTW_INFO("###=> usb_read_port_complete => urb.status(%d)\n", purb->status);
+
+		if (rtw_inc_and_chk_continual_io_error(adapter_to_dvobj(padapter)) == _TRUE)
+			rtw_set_surprise_removed(padapter);
+
+		switch (purb->status) {
+		case -EINVAL:
+		case -EPIPE:
+		case -ENODEV:
+		case -ESHUTDOWN:
+		case -ENOENT:
+			rtw_set_drv_stopped(padapter);
+			break;
+		case -EPROTO:
+		case -EILSEQ:
+		case -ETIME:
+		case -ECOMM:
+		case -EOVERFLOW:
+			#ifdef DBG_CONFIG_ERROR_DETECT
+			{
+				HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+				pHalData->srestpriv.Wifi_Error_Status = USB_READ_PORT_FAIL;
+			}
+			#endif
+			rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+			break;
+		case -EINPROGRESS:
+			RTW_INFO("ERROR: URB IS IN PROGRESS!/n");
+			break;
+		default:
+			break;
+		}
+	}
+
+}
+
+u32 usb_read_port(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem)
+{
+	int err;
+	unsigned int pipe;
+	u32 ret = _SUCCESS;
+	PURB purb = NULL;
+	struct recv_buf	*precvbuf = (struct recv_buf *)rmem;
+	_adapter		*adapter = pintfhdl->padapter;
+	struct dvobj_priv	*pdvobj = adapter_to_dvobj(adapter);
+	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(pdvobj);
+	struct recv_priv	*precvpriv = &adapter->recvpriv;
+	struct usb_device	*pusbd = pdvobj->pusbdev;
+
+
+	if (RTW_CANNOT_RX(adapter) || (precvbuf == NULL)) {
+		return _FAIL;
+	}
+
+	usb_init_recvbuf(adapter, precvbuf);
+
+	if (precvbuf->pbuf) {
+		ATOMIC_INC(&(precvpriv->rx_pending_cnt));
+		purb = precvbuf->purb;
+
+		/* translate DMA FIFO addr to pipehandle */
+		pipe = ffaddr2pipehdl(pdvobj, addr);
+
+		usb_fill_bulk_urb(purb, pusbd, pipe,
+			precvbuf->pbuf,
+			MAX_RECVBUF_SZ,
+			usb_read_port_complete,
+			precvbuf);/* context is precvbuf */
+
+		purb->transfer_dma = precvbuf->dma_transfer_addr;
+		purb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
+
+		err = usb_submit_urb(purb, GFP_ATOMIC);
+		if ((err) && (err != (-EPERM))) {
+			RTW_INFO("cannot submit rx in-token(err = 0x%08x),urb_status = %d\n", err, purb->status);
+			ret = _FAIL;
+		}
+
+	}
+
+
+	return ret;
+}
+#else	/* CONFIG_USE_USB_BUFFER_ALLOC_RX */
+
+void usb_recv_tasklet(void *priv)
+{
+	_pkt			*pskb;
+	_adapter		*padapter = (_adapter *)priv;
+	struct recv_priv	*precvpriv = &padapter->recvpriv;
+	struct recv_buf	*precvbuf = NULL;
+
+	while (NULL != (pskb = skb_dequeue(&precvpriv->rx_skb_queue))) {
+
+		if (RTW_CANNOT_RUN(padapter)) {
+			RTW_INFO("recv_tasklet => bDriverStopped(%s) OR bSurpriseRemoved(%s)\n"
+				, rtw_is_drv_stopped(padapter) ? "True" : "False"
+				, rtw_is_surprise_removed(padapter) ? "True" : "False");
+			#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+			if (rtw_free_skb_premem(pskb) != 0)
+			#endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
+				rtw_skb_free(pskb);
+			break;
+		}
+
+		recvbuf2recvframe(padapter, pskb);
+
+		skb_reset_tail_pointer(pskb);
+		pskb->len = 0;
+
+		skb_queue_tail(&precvpriv->free_recv_skb_queue, pskb);
+
+		precvbuf = rtw_dequeue_recvbuf(&precvpriv->recv_buf_pending_queue);
+		if (NULL != precvbuf) {
+			precvbuf->pskb = NULL;
+			rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+		}
+	}
+}
+
+void usb_read_port_complete(struct urb *purb, struct pt_regs *regs)
+{
+	struct recv_buf	*precvbuf = (struct recv_buf *)purb->context;
+	_adapter			*padapter = (_adapter *)precvbuf->adapter;
+	struct recv_priv	*precvpriv = &padapter->recvpriv;
+
+	ATOMIC_DEC(&(precvpriv->rx_pending_cnt));
+
+	if (RTW_CANNOT_RX(padapter)) {
+		RTW_INFO("%s() RX Warning! bDriverStopped(%s) OR bSurpriseRemoved(%s)\n"
+			, __func__
+			, rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+		goto exit;
+	}
+
+	if (purb->status == 0) {
+
+		if ((purb->actual_length > MAX_RECVBUF_SZ) || (purb->actual_length < RXDESC_SIZE)) {
+			RTW_INFO("%s()-%d: urb->actual_length:%u, MAX_RECVBUF_SZ:%u, RXDESC_SIZE:%u\n"
+				, __FUNCTION__, __LINE__, purb->actual_length, MAX_RECVBUF_SZ, RXDESC_SIZE);
+			rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+		} else {
+			rtw_reset_continual_io_error(adapter_to_dvobj(padapter));
+
+			precvbuf->transfer_len = purb->actual_length;
+			skb_put(precvbuf->pskb, purb->actual_length);
+			skb_queue_tail(&precvpriv->rx_skb_queue, precvbuf->pskb);
+
+			#ifndef CONFIG_FIX_NR_BULKIN_BUFFER
+			if (skb_queue_len(&precvpriv->rx_skb_queue) <= 1)
+			#endif
+				tasklet_schedule(&precvpriv->recv_tasklet);
+
+			precvbuf->pskb = NULL;
+			rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+		}
+	} else {
+
+		RTW_INFO("###=> usb_read_port_complete => urb.status(%d)\n", purb->status);
+
+		if (rtw_inc_and_chk_continual_io_error(adapter_to_dvobj(padapter)) == _TRUE)
+			rtw_set_surprise_removed(padapter);
+
+		switch (purb->status) {
+		case -EINVAL:
+		case -EPIPE:
+		case -ENODEV:
+		case -ESHUTDOWN:
+		case -ENOENT:
+			rtw_set_drv_stopped(padapter);
+			break;
+		case -EPROTO:
+		case -EILSEQ:
+		case -ETIME:
+		case -ECOMM:
+		case -EOVERFLOW:
+			#ifdef DBG_CONFIG_ERROR_DETECT
+			{
+				HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+				pHalData->srestpriv.Wifi_Error_Status = USB_READ_PORT_FAIL;
+			}
+			#endif
+			rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
+			break;
+		case -EINPROGRESS:
+			RTW_INFO("ERROR: URB IS IN PROGRESS!/n");
+			break;
+		default:
+			break;
+		}
+	}
+
+exit:
+	return;
+}
+
+u32 usb_read_port(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem)
+{
+	int err;
+	unsigned int pipe;
+	u32 ret = _FAIL;
+	PURB purb = NULL;
+	struct recv_buf	*precvbuf = (struct recv_buf *)rmem;
+	_adapter		*adapter = pintfhdl->padapter;
+	struct dvobj_priv	*pdvobj = adapter_to_dvobj(adapter);
+	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(pdvobj);
+	struct recv_priv	*precvpriv = &adapter->recvpriv;
+	struct usb_device	*pusbd = pdvobj->pusbdev;
+
+
+	if (RTW_CANNOT_RX(adapter) || (precvbuf == NULL)) {
+		goto exit;
+	}
+
+	usb_init_recvbuf(adapter, precvbuf);
+
+	if (precvbuf->pskb == NULL) {
+		SIZE_PTR tmpaddr = 0;
+		SIZE_PTR alignment = 0;
+
+		precvbuf->pskb = skb_dequeue(&precvpriv->free_recv_skb_queue);
+		if (NULL != precvbuf->pskb)
+			goto recv_buf_hook;
+
+		#ifndef CONFIG_FIX_NR_BULKIN_BUFFER
+		precvbuf->pskb = rtw_skb_alloc(MAX_RECVBUF_SZ + RECVBUFF_ALIGN_SZ);
+		#endif
+
+		if (precvbuf->pskb == NULL) {
+			if (0)
+				RTW_INFO("usb_read_port() enqueue precvbuf=%p\n", precvbuf);
+			/* enqueue precvbuf and wait for free skb */
+			rtw_enqueue_recvbuf(precvbuf, &precvpriv->recv_buf_pending_queue);
+			goto exit;
+		}
+
+		tmpaddr = (SIZE_PTR)precvbuf->pskb->data;
+		alignment = tmpaddr & (RECVBUFF_ALIGN_SZ - 1);
+		skb_reserve(precvbuf->pskb, (RECVBUFF_ALIGN_SZ - alignment));
+	}
+
+recv_buf_hook:
+	precvbuf->phead = precvbuf->pskb->head;
+	precvbuf->pdata = precvbuf->pskb->data;
+	precvbuf->ptail = skb_tail_pointer(precvbuf->pskb);
+	precvbuf->pend = skb_end_pointer(precvbuf->pskb);
+	precvbuf->pbuf = precvbuf->pskb->data;
+
+	purb = precvbuf->purb;
+
+	/* translate DMA FIFO addr to pipehandle */
+	pipe = ffaddr2pipehdl(pdvobj, addr);
+
+	usb_fill_bulk_urb(purb, pusbd, pipe,
+		precvbuf->pbuf,
+		MAX_RECVBUF_SZ,
+		usb_read_port_complete,
+		precvbuf);
+
+	err = usb_submit_urb(purb, GFP_ATOMIC);
+	if (err && err != (-EPERM)) {
+		RTW_INFO("cannot submit rx in-token(err = 0x%08x),urb_status = %d\n"
+			, err, purb->status);
+		goto exit;
+	}
+
+	ATOMIC_INC(&(precvpriv->rx_pending_cnt));
+	ret = _SUCCESS;
+
+exit:
+
+
+	return ret;
+}
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
+
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+void usb_read_interrupt_complete(struct urb *purb, struct pt_regs *regs)
+{
+	int	err;
+	_adapter	*padapter = (_adapter *)purb->context;
+
+	if (RTW_CANNOT_RX(padapter)) {
+		RTW_INFO("%s() RX Warning! bDriverStopped(%s) OR bSurpriseRemoved(%s)\n"
+			, __func__
+			, rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+
+		return;
+	}
+
+	if (purb->status == 0) {/*SUCCESS*/
+		if (purb->actual_length > INTERRUPT_MSG_FORMAT_LEN)
+			RTW_INFO("usb_read_interrupt_complete: purb->actual_length > INTERRUPT_MSG_FORMAT_LEN(%d)\n", INTERRUPT_MSG_FORMAT_LEN);
+
+		rtw_hal_interrupt_handler(padapter, purb->actual_length, purb->transfer_buffer);
+
+		err = usb_submit_urb(purb, GFP_ATOMIC);
+		if ((err) && (err != (-EPERM)))
+			RTW_INFO("cannot submit interrupt in-token(err = 0x%08x),urb_status = %d\n", err, purb->status);
+	} else {
+		RTW_INFO("###=> usb_read_interrupt_complete => urb status(%d)\n", purb->status);
+
+		switch (purb->status) {
+		case -EINVAL:
+		case -EPIPE:
+		case -ENODEV:
+		case -ESHUTDOWN:
+		case -ENOENT:
+			rtw_set_drv_stopped(padapter);
+			break;
+		case -EPROTO:
+			break;
+		case -EINPROGRESS:
+			RTW_INFO("ERROR: URB IS IN PROGRESS!/n");
+			break;
+		default:
+			break;
+		}
+	}
+}
+
+u32 usb_read_interrupt(struct intf_hdl *pintfhdl, u32 addr)
+{
+	int	err;
+	unsigned int pipe;
+	u32	ret = _SUCCESS;
+	_adapter			*adapter = pintfhdl->padapter;
+	struct dvobj_priv	*pdvobj = adapter_to_dvobj(adapter);
+	struct recv_priv	*precvpriv = &adapter->recvpriv;
+	struct usb_device	*pusbd = pdvobj->pusbdev;
+
+
+	if (RTW_CANNOT_RX(adapter)) {
+		return _FAIL;
+	}
+
+	/*translate DMA FIFO addr to pipehandle*/
+	pipe = ffaddr2pipehdl(pdvobj, addr);
+
+	usb_fill_int_urb(precvpriv->int_in_urb, pusbd, pipe,
+			precvpriv->int_in_buf,
+			INTERRUPT_MSG_FORMAT_LEN,
+			usb_read_interrupt_complete,
+			adapter,
+			1);
+
+	err = usb_submit_urb(precvpriv->int_in_urb, GFP_ATOMIC);
+	if ((err) && (err != (-EPERM))) {
+		RTW_INFO("cannot submit interrupt in-token(err = 0x%08x), urb_status = %d\n", err, precvpriv->int_in_urb->status);
+		ret = _FAIL;
+	}
+
+	return ret;
+}
+#endif /* CONFIG_USB_INTERRUPT_IN_PIPE */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/wifi_regd.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/wifi_regd.c
new file mode 100644
index 000000000000..c710b25b0d83
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/wifi_regd.c
@@ -0,0 +1,553 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2009-2010 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+#ifdef CONFIG_IOCTL_CFG80211
+
+#include <rtw_wifi_regd.h>
+
+static struct country_code_to_enum_rd allCountries[] = {
+	{COUNTRY_CODE_USER, "RD"},
+};
+
+/*
+ * REG_RULE(freq start, freq end, bandwidth, max gain, eirp, reg_flags)
+ */
+
+/*
+ *Only these channels all allow active
+ *scan on all world regulatory domains
+ */
+
+/* 2G chan 01 - chan 11 */
+#define RTW_2GHZ_CH01_11	\
+	REG_RULE(2412-10, 2462+10, 40, 0, 20, 0)
+
+/*
+ *We enable active scan on these a case
+ *by case basis by regulatory domain
+ */
+
+/* 2G chan 12 - chan 13, PASSIV SCAN */
+#define RTW_2GHZ_CH12_13	\
+	REG_RULE(2467-10, 2472+10, 40, 0, 20,	\
+		 NL80211_RRF_PASSIVE_SCAN)
+
+/* 2G chan 14, PASSIVS SCAN, NO OFDM (B only) */
+#define RTW_2GHZ_CH14	\
+	REG_RULE(2484-10, 2484+10, 40, 0, 20,	\
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_OFDM)
+
+/* 5G chan 36 - chan 64 */
+#define RTW_5GHZ_5150_5350	\
+	REG_RULE(5150-10, 5350+10, 40, 0, 30,	\
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+
+/* 5G chan 100 - chan 165 */
+#define RTW_5GHZ_5470_5850	\
+	REG_RULE(5470-10, 5850+10, 40, 0, 30, \
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+
+/* 5G chan 149 - chan 165 */
+#define RTW_5GHZ_5725_5850	\
+	REG_RULE(5725-10, 5850+10, 40, 0, 30, \
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+
+/* 5G chan 36 - chan 165 */
+#define RTW_5GHZ_5150_5850	\
+	REG_RULE(5150-10, 5850+10, 40, 0, 30,	\
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+
+static const struct ieee80211_regdomain rtw_regdom_rd = {
+	.n_reg_rules = 3,
+	.alpha2 = "99",
+	.reg_rules = {
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_5GHZ_5150_5850,
+	}
+};
+
+static const struct ieee80211_regdomain rtw_regdom_11 = {
+	.n_reg_rules = 1,
+	.alpha2 = "99",
+	.reg_rules = {
+		RTW_2GHZ_CH01_11,
+	}
+};
+
+static const struct ieee80211_regdomain rtw_regdom_12_13 = {
+	.n_reg_rules = 2,
+	.alpha2 = "99",
+	.reg_rules = {
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+	}
+};
+
+static const struct ieee80211_regdomain rtw_regdom_no_midband = {
+	.n_reg_rules = 3,
+	.alpha2 = "99",
+	.reg_rules = {
+		RTW_2GHZ_CH01_11,
+		RTW_5GHZ_5150_5350,
+		RTW_5GHZ_5725_5850,
+	}
+};
+
+static const struct ieee80211_regdomain rtw_regdom_60_64 = {
+	.n_reg_rules = 3,
+	.alpha2 = "99",
+	.reg_rules = {
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_5GHZ_5725_5850,
+	}
+};
+
+static const struct ieee80211_regdomain rtw_regdom_14_60_64 = {
+	.n_reg_rules = 4,
+	.alpha2 = "99",
+	.reg_rules = {
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_2GHZ_CH14,
+		RTW_5GHZ_5725_5850,
+	}
+};
+
+static const struct ieee80211_regdomain rtw_regdom_14 = {
+	.n_reg_rules = 3,
+	.alpha2 = "99",
+	.reg_rules = {
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_2GHZ_CH14,
+	}
+};
+
+#if 0
+static struct rtw_regulatory *rtw_regd;
+#endif
+
+#if 0 /* not_yet */
+static void _rtw_reg_apply_beaconing_flags(struct wiphy *wiphy,
+		enum nl80211_reg_initiator initiator)
+{
+	enum nl80211_band band;
+	struct ieee80211_supported_band *sband;
+	const struct ieee80211_reg_rule *reg_rule;
+	struct ieee80211_channel *ch;
+	unsigned int i;
+	u32 bandwidth = 0;
+	int r;
+
+	for (band = 0; band < NUM_NL80211_BANDS; band++) {
+
+		if (!wiphy->bands[band])
+			continue;
+
+		sband = wiphy->bands[band];
+
+		for (i = 0; i < sband->n_channels; i++) {
+			ch = &sband->channels[i];
+			if (rtw_is_dfs_ch(ch->hw_value) ||
+			    (ch->flags & IEEE80211_CHAN_RADAR))
+				continue;
+			if (initiator == NL80211_REGDOM_SET_BY_COUNTRY_IE) {
+				r = freq_reg_info(wiphy, ch->center_freq,
+						  bandwidth, &reg_rule);
+				if (r)
+					continue;
+
+				/*
+				 *If 11d had a rule for this channel ensure
+				 *we enable adhoc/beaconing if it allows us to
+				 *use it. Note that we would have disabled it
+				 *by applying our static world regdomain by
+				 *default during init, prior to calling our
+				 *regulatory_hint().
+				 */
+
+				if (!(reg_rule->flags & NL80211_RRF_NO_IBSS))
+					ch->flags &= ~IEEE80211_CHAN_NO_IBSS;
+				if (!
+				    (reg_rule->flags &
+				     NL80211_RRF_PASSIVE_SCAN))
+					ch->flags &=
+						~IEEE80211_CHAN_PASSIVE_SCAN;
+			} else {
+				if (ch->beacon_found)
+					ch->flags &= ~(IEEE80211_CHAN_NO_IBSS |
+						IEEE80211_CHAN_PASSIVE_SCAN);
+			}
+		}
+	}
+}
+
+/* Allows active scan scan on Ch 12 and 13 */
+static void _rtw_reg_apply_active_scan_flags(struct wiphy *wiphy,
+		enum nl80211_reg_initiator
+		initiator)
+{
+	struct ieee80211_supported_band *sband;
+	struct ieee80211_channel *ch;
+	const struct ieee80211_reg_rule *reg_rule;
+	u32 bandwidth = 0;
+	int r;
+
+	if (!wiphy->bands[NL80211_BAND_2GHZ])
+		return;
+	sband = wiphy->bands[NL80211_BAND_2GHZ];
+
+	/*
+	 * If no country IE has been received always enable active scan
+	 * on these channels. This is only done for specific regulatory SKUs
+	 */
+	if (initiator != NL80211_REGDOM_SET_BY_COUNTRY_IE) {
+		ch = &sband->channels[11];	/* CH 12 */
+		if (ch->flags & IEEE80211_CHAN_PASSIVE_SCAN)
+			ch->flags &= ~IEEE80211_CHAN_PASSIVE_SCAN;
+		ch = &sband->channels[12];	/* CH 13 */
+		if (ch->flags & IEEE80211_CHAN_PASSIVE_SCAN)
+			ch->flags &= ~IEEE80211_CHAN_PASSIVE_SCAN;
+		return;
+	}
+
+	/*
+	 * If a country IE has been received check its rule for this
+	 * channel first before enabling active scan. The passive scan
+	 * would have been enforced by the initial processing of our
+	 * custom regulatory domain.
+	 */
+
+	ch = &sband->channels[11];	/* CH 12 */
+	r = freq_reg_info(wiphy, ch->center_freq, bandwidth, &reg_rule);
+	if (!r) {
+		if (!(reg_rule->flags & NL80211_RRF_PASSIVE_SCAN))
+			if (ch->flags & IEEE80211_CHAN_PASSIVE_SCAN)
+				ch->flags &= ~IEEE80211_CHAN_PASSIVE_SCAN;
+	}
+
+	ch = &sband->channels[12];	/* CH 13 */
+	r = freq_reg_info(wiphy, ch->center_freq, bandwidth, &reg_rule);
+	if (!r) {
+		if (!(reg_rule->flags & NL80211_RRF_PASSIVE_SCAN))
+			if (ch->flags & IEEE80211_CHAN_PASSIVE_SCAN)
+				ch->flags &= ~IEEE80211_CHAN_PASSIVE_SCAN;
+	}
+}
+#endif
+
+/*
+ * Always apply Radar/DFS rules on
+ * freq range 5260 MHz - 5700 MHz
+ */
+static void _rtw_reg_apply_radar_flags(struct wiphy *wiphy)
+{
+	struct ieee80211_supported_band *sband;
+	struct ieee80211_channel *ch;
+	unsigned int i;
+
+	if (!wiphy->bands[NL80211_BAND_5GHZ])
+		return;
+
+	sband = wiphy->bands[NL80211_BAND_5GHZ];
+
+	for (i = 0; i < sband->n_channels; i++) {
+		ch = &sband->channels[i];
+		if (!rtw_is_dfs_ch(ch->hw_value))
+			continue;
+#ifdef CONFIG_DFS
+		if (!(ch->flags & IEEE80211_CHAN_DISABLED)
+			#if defined(CONFIG_DFS_MASTER)
+			&& rtw_odm_dfs_domain_unknown(wiphy_to_adapter(wiphy))
+			#endif
+		) {
+			ch->flags |= IEEE80211_CHAN_RADAR;
+			#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+			ch->flags |= (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
+			#else
+			ch->flags |= IEEE80211_CHAN_NO_IR;
+			#endif
+		}
+#endif /* CONFIG_DFS */
+
+#if 0
+		/*
+		 * We always enable radar detection/DFS on this
+		 * frequency range. Additionally we also apply on
+		 * this frequency range:
+		 * - If STA mode does not yet have DFS supports disable
+		 *  active scanning
+		 * - If adhoc mode does not support DFS yet then disable
+		 *  adhoc in the frequency.
+		 * - If AP mode does not yet support radar detection/DFS
+		 *  do not allow AP mode
+		 */
+		if (!(ch->flags & IEEE80211_CHAN_DISABLED))
+			ch->flags |= IEEE80211_CHAN_RADAR |
+				     IEEE80211_CHAN_NO_IBSS |
+				     IEEE80211_CHAN_PASSIVE_SCAN;
+#endif
+	}
+}
+
+static void _rtw_reg_apply_flags(struct wiphy *wiphy)
+{
+#if 1				/* by channel plan */
+	_adapter *padapter = wiphy_to_adapter(wiphy);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	u8 channel_plan = rfctl->ChannelPlan;
+	RT_CHANNEL_INFO *channel_set = rfctl->channel_set;
+	u8 max_chan_nums = rfctl->max_chan_nums;
+
+	struct ieee80211_supported_band *sband;
+	struct ieee80211_channel *ch;
+	unsigned int i, j;
+	u16 channel;
+	u32 freq;
+
+	/* all channels disable */
+	for (i = 0; i < NUM_NL80211_BANDS; i++) {
+		sband = wiphy->bands[i];
+
+		if (sband) {
+			for (j = 0; j < sband->n_channels; j++) {
+				ch = &sband->channels[j];
+
+				if (ch)
+					ch->flags = IEEE80211_CHAN_DISABLED;
+			}
+		}
+	}
+
+	/* channels apply by channel plans. */
+	for (i = 0; i < max_chan_nums; i++) {
+		channel = channel_set[i].ChannelNum;
+		freq = rtw_ch2freq(channel);
+
+		ch = ieee80211_get_channel(wiphy, freq);
+		if (ch) {
+			if (channel_set[i].ScanType == SCAN_PASSIVE
+				#if defined(CONFIG_DFS_MASTER)
+				&& rtw_odm_dfs_domain_unknown(wiphy_to_adapter(wiphy))
+				#endif
+			) {
+				#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+				ch->flags = (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
+				#else
+				ch->flags = IEEE80211_CHAN_NO_IR;
+				#endif
+			} else
+				ch->flags = 0;
+		}
+	}
+
+#else
+	struct ieee80211_supported_band *sband;
+	struct ieee80211_channel *ch;
+	unsigned int i, j;
+	u16 channels[37] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56,
+		60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140,
+		149, 153,
+		157, 161, 165
+	};
+	u16 channel;
+	u32 freq;
+
+	for (i = 0; i < NUM_NL80211_BANDS; i++) {
+		sband = wiphy->bands[i];
+
+		if (sband)
+			for (j = 0; j < sband->n_channels; j++) {
+				ch = &sband->channels[j];
+
+				if (ch)
+					ch->flags = IEEE80211_CHAN_DISABLED;
+			}
+	}
+
+	for (i = 0; i < 37; i++) {
+		channel = channels[i];
+		freq = rtw_ch2freq(channel);
+
+		ch = ieee80211_get_channel(wiphy, freq);
+		if (ch) {
+			if (channel <= 11)
+				ch->flags = 0;
+			else
+				ch->flags = 0;	/* IEEE80211_CHAN_PASSIVE_SCAN; */
+		}
+		/* printk("%s: freq %d(%d) flag 0x%02X\n", __func__, freq, channel, ch->flags); */
+	}
+#endif
+}
+
+static void _rtw_reg_apply_world_flags(struct wiphy *wiphy,
+				       enum nl80211_reg_initiator initiator,
+				       struct rtw_regulatory *reg)
+{
+	/* _rtw_reg_apply_beaconing_flags(wiphy, initiator); */
+	/* _rtw_reg_apply_active_scan_flags(wiphy, initiator); */
+	return;
+}
+
+static int _rtw_reg_notifier_apply(struct wiphy *wiphy,
+				   struct regulatory_request *request,
+				   struct rtw_regulatory *reg)
+{
+
+	/* Hard code flags */
+	_rtw_reg_apply_flags(wiphy);
+
+	/* We always apply this */
+	_rtw_reg_apply_radar_flags(wiphy);
+
+	switch (request->initiator) {
+	case NL80211_REGDOM_SET_BY_DRIVER:
+		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_DRIVER");
+		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
+					   reg);
+		break;
+	case NL80211_REGDOM_SET_BY_CORE:
+		RTW_INFO("%s: %s\n", __func__,
+			 "NL80211_REGDOM_SET_BY_CORE to DRV");
+		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
+					   reg);
+		break;
+	case NL80211_REGDOM_SET_BY_USER:
+		RTW_INFO("%s: %s\n", __func__,
+			 "NL80211_REGDOM_SET_BY_USER to DRV");
+		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
+					   reg);
+		break;
+	case NL80211_REGDOM_SET_BY_COUNTRY_IE:
+		RTW_INFO("%s: %s\n", __func__,
+			 "NL80211_REGDOM_SET_BY_COUNTRY_IE");
+		_rtw_reg_apply_world_flags(wiphy, request->initiator, reg);
+		break;
+	}
+
+	return 0;
+}
+
+static const struct ieee80211_regdomain *_rtw_regdomain_select(struct
+		rtw_regulatory
+		*reg)
+{
+#if 0
+	switch (reg->country_code) {
+	case COUNTRY_CODE_USER:
+	default:
+		return &rtw_regdom_rd;
+	}
+#else
+	return &rtw_regdom_rd;
+#endif
+}
+
+void _rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
+{
+	struct rtw_regulatory *reg = NULL;
+
+	RTW_INFO("%s\n", __func__);
+
+	_rtw_reg_notifier_apply(wiphy, request, reg);
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
+int rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
+#else
+void rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
+#endif
+{
+	_rtw_reg_notifier(wiphy, request);
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
+	return 0;
+#endif
+}
+
+void rtw_reg_notify_by_driver(_adapter *adapter)
+{
+	if ((adapter->rtw_wdev != NULL) && (adapter->rtw_wdev->wiphy)) {
+		struct regulatory_request request;
+		request.initiator = NL80211_REGDOM_SET_BY_DRIVER;
+		rtw_reg_notifier(adapter->rtw_wdev->wiphy, &request);
+	}
+}
+
+static void _rtw_regd_init_wiphy(struct rtw_regulatory *reg, struct wiphy *wiphy)
+{
+	const struct ieee80211_regdomain *regd;
+
+	wiphy->reg_notifier = rtw_reg_notifier;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+	wiphy->flags |= WIPHY_FLAG_CUSTOM_REGULATORY;
+	wiphy->flags &= ~WIPHY_FLAG_STRICT_REGULATORY;
+	wiphy->flags &= ~WIPHY_FLAG_DISABLE_BEACON_HINTS;
+#else
+	wiphy->regulatory_flags |= REGULATORY_CUSTOM_REG;
+	wiphy->regulatory_flags &= ~REGULATORY_STRICT_REG;
+	wiphy->regulatory_flags &= ~REGULATORY_DISABLE_BEACON_HINTS;
+#endif
+
+	regd = _rtw_regdomain_select(reg);
+	wiphy_apply_custom_regulatory(wiphy, regd);
+
+	/* Hard code flags */
+	_rtw_reg_apply_flags(wiphy);
+	_rtw_reg_apply_radar_flags(wiphy);
+	_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER, reg);
+}
+
+static struct country_code_to_enum_rd *_rtw_regd_find_country(u16 countrycode)
+{
+	int i;
+
+	for (i = 0; i < ARRAY_SIZE(allCountries); i++) {
+		if (allCountries[i].countrycode == countrycode)
+			return &allCountries[i];
+	}
+	return NULL;
+}
+
+int rtw_regd_init(_adapter *padapter)
+{
+	struct wiphy *wiphy = padapter->rtw_wdev->wiphy;
+
+#if 0
+	if (rtw_regd == NULL) {
+		rtw_regd = (struct rtw_regulatory *)
+			   rtw_malloc(sizeof(struct rtw_regulatory));
+
+		rtw_regd->alpha2[0] = '9';
+		rtw_regd->alpha2[1] = '9';
+
+		rtw_regd->country_code = COUNTRY_CODE_USER;
+	}
+
+	RTW_INFO("%s: Country alpha2 being used: %c%c\n",
+		 __func__, rtw_regd->alpha2[0], rtw_regd->alpha2[1]);
+#endif
+
+	_rtw_regd_init_wiphy(NULL, wiphy);
+
+	return 0;
+}
+#endif /* CONFIG_IOCTL_CFG80211 */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/xmit_linux.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/xmit_linux.c
new file mode 100644
index 000000000000..6ddb0fe035f5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/linux/xmit_linux.c
@@ -0,0 +1,536 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+
+#define DBG_DUMP_OS_QUEUE_CTL 0
+
+uint rtw_remainder_len(struct pkt_file *pfile)
+{
+	return pfile->buf_len - ((SIZE_PTR)(pfile->cur_addr) - (SIZE_PTR)(pfile->buf_start));
+}
+
+void _rtw_open_pktfile(_pkt *pktptr, struct pkt_file *pfile)
+{
+
+	pfile->pkt = pktptr;
+	pfile->cur_addr = pfile->buf_start = pktptr->data;
+	pfile->pkt_len = pfile->buf_len = pktptr->len;
+
+	pfile->cur_buffer = pfile->buf_start ;
+
+}
+
+uint _rtw_pktfile_read(struct pkt_file *pfile, u8 *rmem, uint rlen)
+{
+	uint	len = 0;
+
+
+	len =  rtw_remainder_len(pfile);
+	len = (rlen > len) ? len : rlen;
+
+	if (rmem)
+		skb_copy_bits(pfile->pkt, pfile->buf_len - pfile->pkt_len, rmem, len);
+
+	pfile->cur_addr += len;
+	pfile->pkt_len -= len;
+
+
+	return len;
+}
+
+sint rtw_endofpktfile(struct pkt_file *pfile)
+{
+
+	if (pfile->pkt_len == 0) {
+		return _TRUE;
+	}
+
+
+	return _FALSE;
+}
+
+void rtw_set_tx_chksum_offload(_pkt *pkt, struct pkt_attrib *pattrib)
+{
+
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+	struct sk_buff *skb = (struct sk_buff *)pkt;
+	pattrib->hw_tcp_csum = 0;
+
+	if (skb->ip_summed == CHECKSUM_PARTIAL) {
+		if (skb_shinfo(skb)->nr_frags == 0) {
+			const struct iphdr *ip = ip_hdr(skb);
+			if (ip->protocol == IPPROTO_TCP) {
+				/* TCP checksum offload by HW */
+				RTW_INFO("CHECKSUM_PARTIAL TCP\n");
+				pattrib->hw_tcp_csum = 1;
+				/* skb_checksum_help(skb); */
+			} else if (ip->protocol == IPPROTO_UDP) {
+				/* RTW_INFO("CHECKSUM_PARTIAL UDP\n"); */
+#if 1
+				skb_checksum_help(skb);
+#else
+				/* Set UDP checksum = 0 to skip checksum check */
+				struct udphdr *udp = skb_transport_header(skb);
+				udp->check = 0;
+#endif
+			} else {
+				RTW_INFO("%s-%d TCP CSUM offload Error!!\n", __FUNCTION__, __LINE__);
+				WARN_ON(1);     /* we need a WARN() */
+			}
+		} else { /* IP fragmentation case */
+			RTW_INFO("%s-%d nr_frags != 0, using skb_checksum_help(skb);!!\n", __FUNCTION__, __LINE__);
+			skb_checksum_help(skb);
+		}
+	}
+#endif
+
+}
+
+int rtw_os_xmit_resource_alloc(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 alloc_sz, u8 flag)
+{
+	if (alloc_sz > 0) {
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_TX
+		struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+		struct usb_device	*pusbd = pdvobjpriv->pusbdev;
+
+		pxmitbuf->pallocated_buf = rtw_usb_buffer_alloc(pusbd, (size_t)alloc_sz, &pxmitbuf->dma_transfer_addr);
+		pxmitbuf->pbuf = pxmitbuf->pallocated_buf;
+		if (pxmitbuf->pallocated_buf == NULL)
+			return _FAIL;
+#else /* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+
+		pxmitbuf->pallocated_buf = rtw_zmalloc(alloc_sz);
+		if (pxmitbuf->pallocated_buf == NULL)
+			return _FAIL;
+
+		pxmitbuf->pbuf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitbuf->pallocated_buf), XMITBUF_ALIGN_SZ);
+
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+	}
+
+	if (flag) {
+#ifdef CONFIG_USB_HCI
+		int i;
+		for (i = 0; i < 8; i++) {
+			pxmitbuf->pxmit_urb[i] = usb_alloc_urb(0, GFP_KERNEL);
+			if (pxmitbuf->pxmit_urb[i] == NULL) {
+				RTW_INFO("pxmitbuf->pxmit_urb[i]==NULL");
+				return _FAIL;
+			}
+		}
+#endif
+	}
+
+	return _SUCCESS;
+}
+
+void rtw_os_xmit_resource_free(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 free_sz, u8 flag)
+{
+	if (flag) {
+#ifdef CONFIG_USB_HCI
+		int i;
+
+		for (i = 0; i < 8; i++) {
+			if (pxmitbuf->pxmit_urb[i]) {
+				/* usb_kill_urb(pxmitbuf->pxmit_urb[i]); */
+				usb_free_urb(pxmitbuf->pxmit_urb[i]);
+			}
+		}
+#endif
+	}
+
+	if (free_sz > 0) {
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_TX
+		struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+		struct usb_device	*pusbd = pdvobjpriv->pusbdev;
+
+		rtw_usb_buffer_free(pusbd, (size_t)free_sz, pxmitbuf->pallocated_buf, pxmitbuf->dma_transfer_addr);
+		pxmitbuf->pallocated_buf =  NULL;
+		pxmitbuf->dma_transfer_addr = 0;
+#else	/* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+		if (pxmitbuf->pallocated_buf)
+			rtw_mfree(pxmitbuf->pallocated_buf, free_sz);
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+	}
+}
+
+void dump_os_queue(void *sel, _adapter *padapter)
+{
+	struct net_device *ndev = padapter->pnetdev;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	int i;
+
+	for (i = 0; i < 4; i++) {
+		RTW_PRINT_SEL(sel, "os_queue[%d]:%s\n"
+			, i, __netif_subqueue_stopped(ndev, i) ? "stopped" : "waked");
+	}
+#else
+	RTW_PRINT_SEL(sel, "os_queue:%s\n"
+		      , netif_queue_stopped(ndev) ? "stopped" : "waked");
+#endif
+}
+
+#define WMM_XMIT_THRESHOLD	(NR_XMITFRAME*2/5)
+
+static inline bool rtw_os_need_wake_queue(_adapter *padapter, u16 qidx)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+
+	if (padapter->registrypriv.wifi_spec) {
+		if (pxmitpriv->hwxmits[qidx].accnt < WMM_XMIT_THRESHOLD)
+			return _TRUE;
+#ifdef DBG_CONFIG_ERROR_DETECT
+#ifdef DBG_CONFIG_ERROR_RESET
+	} else if (rtw_hal_sreset_inprogress(padapter) == _TRUE) {
+		return _FALSE;
+#endif/* #ifdef DBG_CONFIG_ERROR_RESET */
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+	} else {
+#ifdef CONFIG_MCC_MODE
+		if (MCC_EN(padapter)) {
+			if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)
+			    && MCC_STOP(padapter))
+				return _FALSE;
+		}
+#endif /* CONFIG_MCC_MODE */
+		return _TRUE;
+	}
+	return _FALSE;
+#else
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)
+		    && MCC_STOP(padapter))
+			return _FALSE;
+	}
+#endif /* CONFIG_MCC_MODE */
+	return _TRUE;
+#endif
+}
+
+static inline bool rtw_os_need_stop_queue(_adapter *padapter, u16 qidx)
+{
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	if (padapter->registrypriv.wifi_spec) {
+		/* No free space for Tx, tx_worker is too slow */
+		if (pxmitpriv->hwxmits[qidx].accnt > WMM_XMIT_THRESHOLD)
+			return _TRUE;
+	} else {
+		if (pxmitpriv->free_xmitframe_cnt <= 4)
+			return _TRUE;
+	}
+#else
+	if (pxmitpriv->free_xmitframe_cnt <= 4)
+		return _TRUE;
+#endif
+	return _FALSE;
+}
+
+void rtw_os_pkt_complete(_adapter *padapter, _pkt *pkt)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	u16	qidx;
+
+	qidx = skb_get_queue_mapping(pkt);
+	if (rtw_os_need_wake_queue(padapter, qidx)) {
+		if (DBG_DUMP_OS_QUEUE_CTL)
+			RTW_INFO(FUNC_ADPT_FMT": netif_wake_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), qidx);
+		netif_wake_subqueue(padapter->pnetdev, qidx);
+	}
+#else
+	if (rtw_os_need_wake_queue(padapter, 0)) {
+		if (DBG_DUMP_OS_QUEUE_CTL)
+			RTW_INFO(FUNC_ADPT_FMT": netif_wake_queue\n", FUNC_ADPT_ARG(padapter));
+		netif_wake_queue(padapter->pnetdev);
+	}
+#endif
+
+	rtw_skb_free(pkt);
+}
+
+void rtw_os_xmit_complete(_adapter *padapter, struct xmit_frame *pxframe)
+{
+	if (pxframe->pkt)
+		rtw_os_pkt_complete(padapter, pxframe->pkt);
+
+	pxframe->pkt = NULL;
+}
+
+void rtw_os_xmit_schedule(_adapter *padapter)
+{
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(padapter);
+
+	if (!padapter)
+		return;
+
+	if (_rtw_queue_empty(&padapter->xmitpriv.pending_xmitbuf_queue) == _FALSE)
+		_rtw_up_sema(&pri_adapter->xmitpriv.xmit_sema);
+
+
+#else
+	_irqL  irqL;
+	struct xmit_priv *pxmitpriv;
+
+	if (!padapter)
+		return;
+
+	pxmitpriv = &padapter->xmitpriv;
+
+	_enter_critical_bh(&pxmitpriv->lock, &irqL);
+
+	if (rtw_txframes_pending(padapter))
+		tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
+
+	_exit_critical_bh(&pxmitpriv->lock, &irqL);
+	
+#if defined(CONFIG_PCI_HCI) && defined(CONFIG_XMIT_THREAD_MODE)
+	if (_rtw_queue_empty(&padapter->xmitpriv.pending_xmitbuf_queue) == _FALSE)
+		_rtw_up_sema(&padapter->xmitpriv.xmit_sema);
+#endif
+	
+
+#endif
+}
+
+static bool rtw_check_xmit_resource(_adapter *padapter, _pkt *pkt)
+{
+	bool busy = _FALSE;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	u16	qidx;
+
+	qidx = skb_get_queue_mapping(pkt);
+	if (rtw_os_need_stop_queue(padapter, qidx)) {
+		if (DBG_DUMP_OS_QUEUE_CTL)
+			RTW_INFO(FUNC_ADPT_FMT": netif_stop_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), qidx);
+		netif_stop_subqueue(padapter->pnetdev, qidx);
+		busy = _TRUE;
+	}
+#else
+	if (rtw_os_need_stop_queue(padapter, 0)) {
+		if (DBG_DUMP_OS_QUEUE_CTL)
+			RTW_INFO(FUNC_ADPT_FMT": netif_stop_queue\n", FUNC_ADPT_ARG(padapter));
+		rtw_netif_stop_queue(padapter->pnetdev);
+		busy = _TRUE;
+	}
+#endif
+	return busy;
+}
+
+void rtw_os_wake_queue_at_free_stainfo(_adapter *padapter, int *qcnt_freed)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	int i;
+
+	for (i = 0; i < 4; i++) {
+		if (qcnt_freed[i] == 0)
+			continue;
+
+		if (rtw_os_need_wake_queue(padapter, i)) {
+			if (DBG_DUMP_OS_QUEUE_CTL)
+				RTW_INFO(FUNC_ADPT_FMT": netif_wake_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), i);
+			netif_wake_subqueue(padapter->pnetdev, i);
+		}
+	}
+#else
+	if (qcnt_freed[0] || qcnt_freed[1] || qcnt_freed[2] || qcnt_freed[3]) {
+		if (rtw_os_need_wake_queue(padapter, 0)) {
+			if (DBG_DUMP_OS_QUEUE_CTL)
+				RTW_INFO(FUNC_ADPT_FMT": netif_wake_queue\n", FUNC_ADPT_ARG(padapter));
+			netif_wake_queue(padapter->pnetdev);
+		}
+	}
+#endif
+}
+
+#ifdef CONFIG_TX_MCAST2UNI
+int rtw_mlcst2unicst(_adapter *padapter, struct sk_buff *skb)
+{
+	struct	sta_priv *pstapriv = &padapter->stapriv;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	_irqL	irqL;
+	_list	*phead, *plist;
+	struct sk_buff *newskb;
+	struct sta_info *psta = NULL;
+	u8 chk_alive_num = 0;
+	char chk_alive_list[NUM_STA];
+	u8 bc_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+
+	int i;
+	s32	res;
+
+	DBG_COUNTER(padapter->tx_logs.os_tx_m2u);
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	/* free sta asoc_queue */
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		int stainfo_offset;
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+
+		stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
+		if (stainfo_offset_valid(stainfo_offset))
+			chk_alive_list[chk_alive_num++] = stainfo_offset;
+	}
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	for (i = 0; i < chk_alive_num; i++) {
+		psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
+		if (!(psta->state & _FW_LINKED)) {
+			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_ignore_fw_linked);
+			continue;
+		}
+
+		/* avoid come from STA1 and send back STA1 */
+		if (_rtw_memcmp(psta->cmn.mac_addr, &skb->data[6], 6) == _TRUE
+			|| _rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) == _TRUE
+			|| _rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6) == _TRUE
+		) {
+			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_ignore_self);
+			continue;
+		}
+
+		DBG_COUNTER(padapter->tx_logs.os_tx_m2u_entry);
+
+		newskb = rtw_skb_copy(skb);
+
+		if (newskb) {
+			_rtw_memcpy(newskb->data, psta->cmn.mac_addr, 6);
+			res = rtw_xmit(padapter, &newskb);
+			if (res < 0) {
+				DBG_COUNTER(padapter->tx_logs.os_tx_m2u_entry_err_xmit);
+				RTW_INFO("%s()-%d: rtw_xmit() return error! res=%d\n", __FUNCTION__, __LINE__, res);
+				pxmitpriv->tx_drop++;
+				rtw_skb_free(newskb);
+			}
+		} else {
+			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_entry_err_skb);
+			RTW_INFO("%s-%d: rtw_skb_copy() failed!\n", __FUNCTION__, __LINE__);
+			pxmitpriv->tx_drop++;
+			/* rtw_skb_free(skb); */
+			return _FALSE;	/* Caller shall tx this multicast frame via normal way. */
+		}
+	}
+
+	rtw_skb_free(skb);
+	return _TRUE;
+}
+#endif /* CONFIG_TX_MCAST2UNI */
+
+
+int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+#ifdef CONFIG_TX_MCAST2UNI
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	extern int rtw_mc2u_disable;
+#endif /* CONFIG_TX_MCAST2UNI	 */
+	s32 res = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	u16 queue;
+#endif
+
+
+	if (padapter->registrypriv.mp_mode) {
+		RTW_INFO("MP_TX_DROP_OS_FRAME\n");
+		goto drop_packet;
+	}
+	DBG_COUNTER(padapter->tx_logs.os_tx);
+
+	if (rtw_if_up(padapter) == _FALSE) {
+		DBG_COUNTER(padapter->tx_logs.os_tx_err_up);
+		#ifdef DBG_TX_DROP_FRAME
+		RTW_INFO("DBG_TX_DROP_FRAME %s if_up fail\n", __FUNCTION__);
+		#endif
+		goto drop_packet;
+	}
+
+	rtw_check_xmit_resource(padapter, pkt);
+
+#ifdef CONFIG_TX_MCAST2UNI
+	if (!rtw_mc2u_disable
+		&& MLME_IS_AP(padapter)
+		&& (IP_MCAST_MAC(pkt->data)
+			|| ICMPV6_MCAST_MAC(pkt->data)
+			#ifdef CONFIG_TX_BCAST2UNI
+			|| is_broadcast_mac_addr(pkt->data)
+			#endif
+			)
+		&& (padapter->registrypriv.wifi_spec == 0)
+	) {
+		if (pxmitpriv->free_xmitframe_cnt > (NR_XMITFRAME / 4)) {
+			res = rtw_mlcst2unicst(padapter, pkt);
+			if (res == _TRUE)
+				goto exit;
+		} else {
+			/* RTW_INFO("Stop M2U(%d, %d)! ", pxmitpriv->free_xmitframe_cnt, pxmitpriv->free_xmitbuf_cnt); */
+			/* RTW_INFO("!m2u ); */
+			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_stop);
+		}
+	}
+#endif /* CONFIG_TX_MCAST2UNI	 */
+
+	res = rtw_xmit(padapter, &pkt);
+	if (res < 0) {
+		#ifdef DBG_TX_DROP_FRAME
+		RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit fail\n", __FUNCTION__);
+		#endif
+		goto drop_packet;
+	}
+
+	goto exit;
+
+drop_packet:
+	pxmitpriv->tx_drop++;
+	rtw_os_pkt_complete(padapter, pkt);
+
+exit:
+
+
+	return 0;
+}
+
+int rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	int ret = 0;
+
+	if (pkt) {
+		if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
+			rtw_monitor_xmit_entry((struct sk_buff *)pkt, pnetdev);
+#endif
+		}
+		else {
+			rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, pkt->truesize);
+			ret = _rtw_xmit_entry(pkt, pnetdev);
+		}
+
+	}
+
+	return ret;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/osdep_service.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/osdep_service.c
new file mode 100644
index 000000000000..2dca00723d81
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/os_dep/osdep_service.c
@@ -0,0 +1,3122 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _OSDEP_SERVICE_C_
+
+#include <drv_types.h>
+
+#define RT_TAG	'1178'
+
+#ifdef DBG_MEMORY_LEAK
+#ifdef PLATFORM_LINUX
+atomic_t _malloc_cnt = ATOMIC_INIT(0);
+atomic_t _malloc_size = ATOMIC_INIT(0);
+#endif
+#endif /* DBG_MEMORY_LEAK */
+
+
+#if defined(PLATFORM_LINUX)
+/*
+* Translate the OS dependent @param error_code to OS independent RTW_STATUS_CODE
+* @return: one of RTW_STATUS_CODE
+*/
+inline int RTW_STATUS_CODE(int error_code)
+{
+	if (error_code >= 0)
+		return _SUCCESS;
+
+	switch (error_code) {
+	/* case -ETIMEDOUT: */
+	/*	return RTW_STATUS_TIMEDOUT; */
+	default:
+		return _FAIL;
+	}
+}
+#else
+inline int RTW_STATUS_CODE(int error_code)
+{
+	return error_code;
+}
+#endif
+
+u32 rtw_atoi(u8 *s)
+{
+
+	int num = 0, flag = 0;
+	int i;
+	for (i = 0; i <= strlen(s); i++) {
+		if (s[i] >= '0' && s[i] <= '9')
+			num = num * 10 + s[i] - '0';
+		else if (s[0] == '-' && i == 0)
+			flag = 1;
+		else
+			break;
+	}
+
+	if (flag == 1)
+		num = num * -1;
+
+	return num;
+
+}
+
+inline void *_rtw_vmalloc(u32 sz)
+{
+	void *pbuf;
+#ifdef PLATFORM_LINUX
+	pbuf = vmalloc(sz);
+#endif
+#ifdef PLATFORM_FREEBSD
+	pbuf = malloc(sz, M_DEVBUF, M_NOWAIT);
+#endif
+
+#ifdef PLATFORM_WINDOWS
+	NdisAllocateMemoryWithTag(&pbuf, sz, RT_TAG);
+#endif
+
+#ifdef DBG_MEMORY_LEAK
+#ifdef PLATFORM_LINUX
+	if (pbuf != NULL) {
+		atomic_inc(&_malloc_cnt);
+		atomic_add(sz, &_malloc_size);
+	}
+#endif
+#endif /* DBG_MEMORY_LEAK */
+
+	return pbuf;
+}
+
+inline void *_rtw_zvmalloc(u32 sz)
+{
+	void *pbuf;
+#ifdef PLATFORM_LINUX
+	pbuf = _rtw_vmalloc(sz);
+	if (pbuf != NULL)
+		memset(pbuf, 0, sz);
+#endif
+#ifdef PLATFORM_FREEBSD
+	pbuf = malloc(sz, M_DEVBUF, M_ZERO | M_NOWAIT);
+#endif
+#ifdef PLATFORM_WINDOWS
+	NdisAllocateMemoryWithTag(&pbuf, sz, RT_TAG);
+	if (pbuf != NULL)
+		NdisFillMemory(pbuf, sz, 0);
+#endif
+
+	return pbuf;
+}
+
+inline void _rtw_vmfree(void *pbuf, u32 sz)
+{
+#ifdef PLATFORM_LINUX
+	vfree(pbuf);
+#endif
+#ifdef PLATFORM_FREEBSD
+	free(pbuf, M_DEVBUF);
+#endif
+#ifdef PLATFORM_WINDOWS
+	NdisFreeMemory(pbuf, sz, 0);
+#endif
+
+#ifdef DBG_MEMORY_LEAK
+#ifdef PLATFORM_LINUX
+	atomic_dec(&_malloc_cnt);
+	atomic_sub(sz, &_malloc_size);
+#endif
+#endif /* DBG_MEMORY_LEAK */
+}
+
+void *_rtw_malloc(u32 sz)
+{
+	void *pbuf = NULL;
+
+#ifdef PLATFORM_LINUX
+#ifdef RTK_DMP_PLATFORM
+	if (sz > 0x4000)
+		pbuf = dvr_malloc(sz);
+	else
+#endif
+		pbuf = kmalloc(sz, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	pbuf = malloc(sz, M_DEVBUF, M_NOWAIT);
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisAllocateMemoryWithTag(&pbuf, sz, RT_TAG);
+
+#endif
+
+#ifdef DBG_MEMORY_LEAK
+#ifdef PLATFORM_LINUX
+	if (pbuf != NULL) {
+		atomic_inc(&_malloc_cnt);
+		atomic_add(sz, &_malloc_size);
+	}
+#endif
+#endif /* DBG_MEMORY_LEAK */
+
+	return pbuf;
+
+}
+
+
+void *_rtw_zmalloc(u32 sz)
+{
+#ifdef PLATFORM_FREEBSD
+	return malloc(sz, M_DEVBUF, M_ZERO | M_NOWAIT);
+#else /* PLATFORM_FREEBSD */
+	void *pbuf = _rtw_malloc(sz);
+
+	if (pbuf != NULL) {
+
+#ifdef PLATFORM_LINUX
+		memset(pbuf, 0, sz);
+#endif
+
+#ifdef PLATFORM_WINDOWS
+		NdisFillMemory(pbuf, sz, 0);
+#endif
+
+	}
+
+	return pbuf;
+#endif /* PLATFORM_FREEBSD */
+}
+
+void _rtw_mfree(void *pbuf, u32 sz)
+{
+
+#ifdef PLATFORM_LINUX
+#ifdef RTK_DMP_PLATFORM
+	if (sz > 0x4000)
+		dvr_free(pbuf);
+	else
+#endif
+		kfree(pbuf);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	free(pbuf, M_DEVBUF);
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisFreeMemory(pbuf, sz, 0);
+
+#endif
+
+#ifdef DBG_MEMORY_LEAK
+#ifdef PLATFORM_LINUX
+	atomic_dec(&_malloc_cnt);
+	atomic_sub(sz, &_malloc_size);
+#endif
+#endif /* DBG_MEMORY_LEAK */
+
+}
+
+#ifdef PLATFORM_FREEBSD
+/* review again */
+struct sk_buff *dev_alloc_skb(unsigned int size)
+{
+	struct sk_buff *skb = NULL;
+	u8 *data = NULL;
+
+	/* skb = _rtw_zmalloc(sizeof(struct sk_buff)); */ /* for skb->len, etc. */
+	skb = _rtw_malloc(sizeof(struct sk_buff));
+	if (!skb)
+		goto out;
+	data = _rtw_malloc(size);
+	if (!data)
+		goto nodata;
+
+	skb->head = (unsigned char *)data;
+	skb->data = (unsigned char *)data;
+	skb->tail = (unsigned char *)data;
+	skb->end = (unsigned char *)data + size;
+	skb->len = 0;
+	/* printf("%s()-%d: skb=%p, skb->head = %p\n", __FUNCTION__, __LINE__, skb, skb->head); */
+
+out:
+	return skb;
+nodata:
+	_rtw_mfree(skb, sizeof(struct sk_buff));
+	skb = NULL;
+	goto out;
+
+}
+
+void dev_kfree_skb_any(struct sk_buff *skb)
+{
+	/* printf("%s()-%d: skb->head = %p\n", __FUNCTION__, __LINE__, skb->head); */
+	if (skb->head)
+		_rtw_mfree(skb->head, 0);
+	/* printf("%s()-%d: skb = %p\n", __FUNCTION__, __LINE__, skb); */
+	if (skb)
+		_rtw_mfree(skb, 0);
+}
+struct sk_buff *skb_clone(const struct sk_buff *skb)
+{
+	return NULL;
+}
+
+#endif /* PLATFORM_FREEBSD */
+
+inline struct sk_buff *_rtw_skb_alloc(u32 sz)
+{
+#ifdef PLATFORM_LINUX
+	return __dev_alloc_skb(sz, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+#endif /* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	return dev_alloc_skb(sz);
+#endif /* PLATFORM_FREEBSD */
+}
+
+inline void _rtw_skb_free(struct sk_buff *skb)
+{
+	dev_kfree_skb_any(skb);
+}
+
+inline struct sk_buff *_rtw_skb_copy(const struct sk_buff *skb)
+{
+#ifdef PLATFORM_LINUX
+	return skb_copy(skb, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+#endif /* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	return NULL;
+#endif /* PLATFORM_FREEBSD */
+}
+
+inline struct sk_buff *_rtw_skb_clone(struct sk_buff *skb)
+{
+#ifdef PLATFORM_LINUX
+	return skb_clone(skb, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+#endif /* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	return skb_clone(skb);
+#endif /* PLATFORM_FREEBSD */
+}
+inline struct sk_buff *_rtw_pskb_copy(struct sk_buff *skb)
+{
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
+	return pskb_copy(skb, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+#else
+	return skb_clone(skb, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+#endif
+#endif /* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	return NULL;
+#endif /* PLATFORM_FREEBSD */
+}
+
+inline int _rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb)
+{
+#if defined(PLATFORM_LINUX)
+	skb->dev = ndev;
+	return netif_rx(skb);
+#elif defined(PLATFORM_FREEBSD)
+	return (*ndev->if_input)(ndev, skb);
+#else
+	rtw_warn_on(1);
+	return -1;
+#endif
+}
+
+#ifdef CONFIG_RTW_NAPI
+inline int _rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb)
+{
+#if defined(PLATFORM_LINUX)
+	skb->dev = ndev;
+	return netif_receive_skb(skb);
+#else
+	rtw_warn_on(1);
+	return -1;
+#endif
+}
+
+#ifdef CONFIG_RTW_GRO
+inline gro_result_t _rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb)
+{
+#if defined(PLATFORM_LINUX)
+	return napi_gro_receive(napi, skb);
+#else
+	rtw_warn_on(1);
+	return -1;
+#endif
+}
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+void _rtw_skb_queue_purge(struct sk_buff_head *list)
+{
+	struct sk_buff *skb;
+
+	while ((skb = skb_dequeue(list)) != NULL)
+		_rtw_skb_free(skb);
+}
+
+#ifdef CONFIG_USB_HCI
+inline void *_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma)
+{
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	return usb_alloc_coherent(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);
+#else
+	return usb_buffer_alloc(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);
+#endif
+#endif /* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	return malloc(size, M_USBDEV, M_NOWAIT | M_ZERO);
+#endif /* PLATFORM_FREEBSD */
+}
+inline void _rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma)
+{
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	usb_free_coherent(dev, size, addr, dma);
+#else
+	usb_buffer_free(dev, size, addr, dma);
+#endif
+#endif /* PLATFORM_LINUX */
+
+#ifdef PLATFORM_FREEBSD
+	free(addr, M_USBDEV);
+#endif /* PLATFORM_FREEBSD */
+}
+#endif /* CONFIG_USB_HCI */
+
+#if defined(DBG_MEM_ALLOC)
+
+struct rtw_mem_stat {
+	ATOMIC_T alloc; /* the memory bytes we allocate currently */
+	ATOMIC_T peak; /* the peak memory bytes we allocate */
+	ATOMIC_T alloc_cnt; /* the alloc count for alloc currently */
+	ATOMIC_T alloc_err_cnt; /* the error times we fail to allocate memory */
+};
+
+struct rtw_mem_stat rtw_mem_type_stat[mstat_tf_idx(MSTAT_TYPE_MAX)];
+#ifdef RTW_MEM_FUNC_STAT
+struct rtw_mem_stat rtw_mem_func_stat[mstat_ff_idx(MSTAT_FUNC_MAX)];
+#endif
+
+char *MSTAT_TYPE_str[] = {
+	"VIR",
+	"PHY",
+	"SKB",
+	"USB",
+};
+
+#ifdef RTW_MEM_FUNC_STAT
+char *MSTAT_FUNC_str[] = {
+	"UNSP",
+	"IO",
+	"TXIO",
+	"RXIO",
+	"TX",
+	"RX",
+};
+#endif
+
+void rtw_mstat_dump(void *sel)
+{
+	int i;
+	int value_t[4][mstat_tf_idx(MSTAT_TYPE_MAX)];
+#ifdef RTW_MEM_FUNC_STAT
+	int value_f[4][mstat_ff_idx(MSTAT_FUNC_MAX)];
+#endif
+
+	int vir_alloc, vir_peak, vir_alloc_err, phy_alloc, phy_peak, phy_alloc_err;
+	int tx_alloc, tx_peak, tx_alloc_err, rx_alloc, rx_peak, rx_alloc_err;
+
+	for (i = 0; i < mstat_tf_idx(MSTAT_TYPE_MAX); i++) {
+		value_t[0][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].alloc));
+		value_t[1][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].peak));
+		value_t[2][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].alloc_cnt));
+		value_t[3][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].alloc_err_cnt));
+	}
+
+#ifdef RTW_MEM_FUNC_STAT
+	for (i = 0; i < mstat_ff_idx(MSTAT_FUNC_MAX); i++) {
+		value_f[0][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].alloc));
+		value_f[1][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].peak));
+		value_f[2][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].alloc_cnt));
+		value_f[3][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].alloc_err_cnt));
+	}
+#endif
+
+	RTW_PRINT_SEL(sel, "===================== MSTAT =====================\n");
+	RTW_PRINT_SEL(sel, "%4s %10s %10s %10s %10s\n", "TAG", "alloc", "peak", "aloc_cnt", "err_cnt");
+	RTW_PRINT_SEL(sel, "-------------------------------------------------\n");
+	for (i = 0; i < mstat_tf_idx(MSTAT_TYPE_MAX); i++)
+		RTW_PRINT_SEL(sel, "%4s %10d %10d %10d %10d\n", MSTAT_TYPE_str[i], value_t[0][i], value_t[1][i], value_t[2][i], value_t[3][i]);
+#ifdef RTW_MEM_FUNC_STAT
+	RTW_PRINT_SEL(sel, "-------------------------------------------------\n");
+	for (i = 0; i < mstat_ff_idx(MSTAT_FUNC_MAX); i++)
+		RTW_PRINT_SEL(sel, "%4s %10d %10d %10d %10d\n", MSTAT_FUNC_str[i], value_f[0][i], value_f[1][i], value_f[2][i], value_f[3][i]);
+#endif
+}
+
+void rtw_mstat_update(const enum mstat_f flags, const MSTAT_STATUS status, u32 sz)
+{
+	static systime update_time = 0;
+	int peak, alloc;
+	int i;
+
+	/* initialization */
+	if (!update_time) {
+		for (i = 0; i < mstat_tf_idx(MSTAT_TYPE_MAX); i++) {
+			ATOMIC_SET(&(rtw_mem_type_stat[i].alloc), 0);
+			ATOMIC_SET(&(rtw_mem_type_stat[i].peak), 0);
+			ATOMIC_SET(&(rtw_mem_type_stat[i].alloc_cnt), 0);
+			ATOMIC_SET(&(rtw_mem_type_stat[i].alloc_err_cnt), 0);
+		}
+		#ifdef RTW_MEM_FUNC_STAT
+		for (i = 0; i < mstat_ff_idx(MSTAT_FUNC_MAX); i++) {
+			ATOMIC_SET(&(rtw_mem_func_stat[i].alloc), 0);
+			ATOMIC_SET(&(rtw_mem_func_stat[i].peak), 0);
+			ATOMIC_SET(&(rtw_mem_func_stat[i].alloc_cnt), 0);
+			ATOMIC_SET(&(rtw_mem_func_stat[i].alloc_err_cnt), 0);
+		}
+		#endif
+	}
+
+	switch (status) {
+	case MSTAT_ALLOC_SUCCESS:
+		ATOMIC_INC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_cnt));
+		alloc = ATOMIC_ADD_RETURN(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc), sz);
+		peak = ATOMIC_READ(&(rtw_mem_type_stat[mstat_tf_idx(flags)].peak));
+		if (peak < alloc)
+			ATOMIC_SET(&(rtw_mem_type_stat[mstat_tf_idx(flags)].peak), alloc);
+
+		#ifdef RTW_MEM_FUNC_STAT
+		ATOMIC_INC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_cnt));
+		alloc = ATOMIC_ADD_RETURN(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc), sz);
+		peak = ATOMIC_READ(&(rtw_mem_func_stat[mstat_ff_idx(flags)].peak));
+		if (peak < alloc)
+			ATOMIC_SET(&(rtw_mem_func_stat[mstat_ff_idx(flags)].peak), alloc);
+		#endif
+		break;
+
+	case MSTAT_ALLOC_FAIL:
+		ATOMIC_INC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_err_cnt));
+		#ifdef RTW_MEM_FUNC_STAT
+		ATOMIC_INC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_err_cnt));
+		#endif
+		break;
+
+	case MSTAT_FREE:
+		ATOMIC_DEC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_cnt));
+		ATOMIC_SUB(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc), sz);
+		#ifdef RTW_MEM_FUNC_STAT
+		ATOMIC_DEC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_cnt));
+		ATOMIC_SUB(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc), sz);
+		#endif
+		break;
+	};
+
+	/* if (rtw_get_passing_time_ms(update_time) > 5000) { */
+	/*	rtw_mstat_dump(RTW_DBGDUMP); */
+	update_time = rtw_get_current_time();
+	/* } */
+}
+
+#ifndef SIZE_MAX
+	#define SIZE_MAX (~(size_t)0)
+#endif
+
+struct mstat_sniff_rule {
+	enum mstat_f flags;
+	size_t lb;
+	size_t hb;
+};
+
+struct mstat_sniff_rule mstat_sniff_rules[] = {
+	{MSTAT_TYPE_PHY, 4097, SIZE_MAX},
+};
+
+int mstat_sniff_rule_num = sizeof(mstat_sniff_rules) / sizeof(struct mstat_sniff_rule);
+
+bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size)
+{
+	int i;
+	for (i = 0; i < mstat_sniff_rule_num; i++) {
+		if (mstat_sniff_rules[i].flags == flags
+			&& mstat_sniff_rules[i].lb <= size
+			&& mstat_sniff_rules[i].hb >= size)
+			return _TRUE;
+	}
+
+	return _FALSE;
+}
+
+inline void *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+{
+	void *p;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+
+	p = _rtw_vmalloc((sz));
+
+	rtw_mstat_update(
+		flags
+		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, sz
+	);
+
+	return p;
+}
+
+inline void *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+{
+	void *p;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+
+	p = _rtw_zvmalloc((sz));
+
+	rtw_mstat_update(
+		flags
+		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, sz
+	);
+
+	return p;
+}
+
+inline void dbg_rtw_vmfree(void *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
+{
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+
+	_rtw_vmfree((pbuf), (sz));
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, sz
+	);
+}
+
+inline void *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+{
+	void *p;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+
+	p = _rtw_malloc((sz));
+
+	rtw_mstat_update(
+		flags
+		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, sz
+	);
+
+	return p;
+}
+
+inline void *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+{
+	void *p;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+
+	p = _rtw_zmalloc((sz));
+
+	rtw_mstat_update(
+		flags
+		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, sz
+	);
+
+	return p;
+}
+
+inline void dbg_rtw_mfree(void *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
+{
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+
+	_rtw_mfree((pbuf), (sz));
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, sz
+	);
+}
+
+inline struct sk_buff *dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, int line)
+{
+	struct sk_buff *skb;
+	unsigned int truesize = 0;
+
+	skb = _rtw_skb_alloc(size);
+
+	if (skb)
+		truesize = skb->truesize;
+
+	if (!skb || truesize < size || match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, size, skb, truesize);
+
+	rtw_mstat_update(
+		flags
+		, skb ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, truesize
+	);
+
+	return skb;
+}
+
+inline void dbg_rtw_skb_free(struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)
+{
+	unsigned int truesize = skb->truesize;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	_rtw_skb_free(skb);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+}
+
+inline struct sk_buff *dbg_rtw_skb_copy(const struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line)
+{
+	struct sk_buff *skb_cp;
+	unsigned int truesize = skb->truesize;
+	unsigned int cp_truesize = 0;
+
+	skb_cp = _rtw_skb_copy(skb);
+	if (skb_cp)
+		cp_truesize = skb_cp->truesize;
+
+	if (!skb_cp || cp_truesize < truesize || match_mstat_sniff_rules(flags, cp_truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u), skb_cp:%p, cp_truesize=%u\n", func, line, __FUNCTION__, truesize, skb_cp, cp_truesize);
+
+	rtw_mstat_update(
+		flags
+		, skb_cp ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, cp_truesize
+	);
+
+	return skb_cp;
+}
+
+inline struct sk_buff *dbg_rtw_skb_clone(struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line)
+{
+	struct sk_buff *skb_cl;
+	unsigned int truesize = skb->truesize;
+	unsigned int cl_truesize = 0;
+
+	skb_cl = _rtw_skb_clone(skb);
+	if (skb_cl)
+		cl_truesize = skb_cl->truesize;
+
+	if (!skb_cl || cl_truesize < truesize || match_mstat_sniff_rules(flags, cl_truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u), skb_cl:%p, cl_truesize=%u\n", func, line, __FUNCTION__, truesize, skb_cl, cl_truesize);
+
+	rtw_mstat_update(
+		flags
+		, skb_cl ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, cl_truesize
+	);
+
+	return skb_cl;
+}
+
+inline int dbg_rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)
+{
+	int ret;
+	unsigned int truesize = skb->truesize;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	ret = _rtw_netif_rx(ndev, skb);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+
+	return ret;
+}
+
+#ifdef CONFIG_RTW_NAPI
+inline int dbg_rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)
+{
+	int ret;
+	unsigned int truesize = skb->truesize;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	ret = _rtw_netif_receive_skb(ndev, skb);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+
+	return ret;
+}
+
+#ifdef CONFIG_RTW_GRO
+inline gro_result_t dbg_rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)
+{
+	int ret;
+	unsigned int truesize = skb->truesize;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	ret = _rtw_napi_gro_receive(napi, skb);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+
+	return ret;
+}
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+inline void dbg_rtw_skb_queue_purge(struct sk_buff_head *list, enum mstat_f flags, const char *func, int line)
+{
+	struct sk_buff *skb;
+
+	while ((skb = skb_dequeue(list)) != NULL)
+		dbg_rtw_skb_free(skb, flags, func, line);
+}
+
+#ifdef CONFIG_USB_HCI
+inline void *dbg_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma, const enum mstat_f flags, const char *func, int line)
+{
+	void *p;
+
+	if (match_mstat_sniff_rules(flags, size))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%zu)\n", func, line, __FUNCTION__, size);
+
+	p = _rtw_usb_buffer_alloc(dev, size, dma);
+
+	rtw_mstat_update(
+		flags
+		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, size
+	);
+
+	return p;
+}
+
+inline void dbg_rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma, const enum mstat_f flags, const char *func, int line)
+{
+
+	if (match_mstat_sniff_rules(flags, size))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%zu)\n", func, line, __FUNCTION__, size);
+
+	_rtw_usb_buffer_free(dev, size, addr, dma);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, size
+	);
+}
+#endif /* CONFIG_USB_HCI */
+
+#endif /* defined(DBG_MEM_ALLOC) */
+
+void *rtw_malloc2d(int h, int w, size_t size)
+{
+	int j;
+
+	void **a = (void **) rtw_zmalloc(h * sizeof(void *) + h * w * size);
+	if (a == NULL) {
+		RTW_INFO("%s: alloc memory fail!\n", __FUNCTION__);
+		return NULL;
+	}
+
+	for (j = 0; j < h; j++)
+		a[j] = ((char *)(a + h)) + j * w * size;
+
+	return a;
+}
+
+void rtw_mfree2d(void *pbuf, int h, int w, int size)
+{
+	rtw_mfree((u8 *)pbuf, h * sizeof(void *) + w * h * size);
+}
+
+inline void rtw_os_pkt_free(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	rtw_skb_free(pkt);
+#elif defined(PLATFORM_FREEBSD)
+	m_freem(pkt);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline _pkt *rtw_os_pkt_copy(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	return rtw_skb_copy(pkt);
+#elif defined(PLATFORM_FREEBSD)
+	return m_dup(pkt, M_NOWAIT);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void *rtw_os_pkt_data(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	return pkt->data;
+#elif defined(PLATFORM_FREEBSD)
+	return pkt->m_data;
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline u32 rtw_os_pkt_len(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	return pkt->len;
+#elif defined(PLATFORM_FREEBSD)
+	return pkt->m_pkthdr.len;
+#else
+	#error "TBD\n"
+#endif
+}
+
+void _rtw_memcpy(void *dst, const void *src, u32 sz)
+{
+
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_FREEBSD)
+
+	memcpy(dst, src, sz);
+
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+	NdisMoveMemory(dst, src, sz);
+
+#endif
+
+}
+
+inline void _rtw_memmove(void *dst, const void *src, u32 sz)
+{
+#if defined(PLATFORM_LINUX)
+	memmove(dst, src, sz);
+#else
+	#error "TBD\n"
+#endif
+}
+
+int	_rtw_memcmp(const void *dst, const void *src, u32 sz)
+{
+
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_FREEBSD)
+	/* under Linux/GNU/GLibc, the return value of memcmp for two same mem. chunk is 0 */
+
+	if (!(memcmp(dst, src, sz)))
+		return _TRUE;
+	else
+		return _FALSE;
+#endif
+
+
+#ifdef PLATFORM_WINDOWS
+	/* under Windows, the return value of NdisEqualMemory for two same mem. chunk is 1 */
+
+	if (NdisEqualMemory(dst, src, sz))
+		return _TRUE;
+	else
+		return _FALSE;
+
+#endif
+
+
+
+}
+
+void _rtw_memset(void *pbuf, int c, u32 sz)
+{
+
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_FREEBSD)
+
+	memset(pbuf, c, sz);
+
+#endif
+
+#ifdef PLATFORM_WINDOWS
+#if 0
+	NdisZeroMemory(pbuf, sz);
+	if (c != 0)
+		memset(pbuf, c, sz);
+#else
+	NdisFillMemory(pbuf, sz, c);
+#endif
+#endif
+
+}
+
+#ifdef PLATFORM_FREEBSD
+static inline void __list_add(_list *pnew, _list *pprev, _list *pnext)
+{
+	pnext->prev = pnew;
+	pnew->next = pnext;
+	pnew->prev = pprev;
+	pprev->next = pnew;
+}
+#endif /* PLATFORM_FREEBSD */
+
+
+void _rtw_init_listhead(_list *list)
+{
+
+#ifdef PLATFORM_LINUX
+
+	INIT_LIST_HEAD(list);
+
+#endif
+
+#ifdef PLATFORM_FREEBSD
+	list->next = list;
+	list->prev = list;
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisInitializeListHead(list);
+
+#endif
+
+}
+
+
+/*
+For the following list_xxx operations,
+caller must guarantee the atomic context.
+Otherwise, there will be racing condition.
+*/
+u32	rtw_is_list_empty(_list *phead)
+{
+
+#ifdef PLATFORM_LINUX
+
+	if (list_empty(phead))
+		return _TRUE;
+	else
+		return _FALSE;
+
+#endif
+#ifdef PLATFORM_FREEBSD
+
+	if (phead->next == phead)
+		return _TRUE;
+	else
+		return _FALSE;
+
+#endif
+
+
+#ifdef PLATFORM_WINDOWS
+
+	if (IsListEmpty(phead))
+		return _TRUE;
+	else
+		return _FALSE;
+
+#endif
+
+
+}
+
+void rtw_list_insert_head(_list *plist, _list *phead)
+{
+
+#ifdef PLATFORM_LINUX
+	list_add(plist, phead);
+#endif
+
+#ifdef PLATFORM_FREEBSD
+	__list_add(plist, phead, phead->next);
+#endif
+
+#ifdef PLATFORM_WINDOWS
+	InsertHeadList(phead, plist);
+#endif
+}
+
+void rtw_list_insert_tail(_list *plist, _list *phead)
+{
+
+#ifdef PLATFORM_LINUX
+
+	list_add_tail(plist, phead);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+
+	__list_add(plist, phead->prev, phead);
+
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	InsertTailList(phead, plist);
+
+#endif
+
+}
+
+inline void rtw_list_splice(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	list_splice(list, head);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_list_splice_init(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	list_splice_init(list, head);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_list_splice_tail(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27))
+	if (!list_empty(list))
+		__list_splice(list, head);
+	#else
+	list_splice_tail(list, head);
+	#endif
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_head_init(rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	INIT_HLIST_HEAD(h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_add_head(rtw_hlist_node *n, rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	hlist_add_head(n, h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_del(rtw_hlist_node *n)
+{
+#ifdef PLATFORM_LINUX
+	hlist_del(n);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_add_head_rcu(rtw_hlist_node *n, rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	hlist_add_head_rcu(n, h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_del_rcu(rtw_hlist_node *n)
+{
+#ifdef PLATFORM_LINUX
+	hlist_del_rcu(n);
+#else
+	#error "TBD\n"
+#endif
+}
+
+void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc, void *ctx)
+{
+	_adapter *adapter = (_adapter *)padapter;
+
+#ifdef PLATFORM_LINUX
+	_init_timer(ptimer, adapter->pnetdev, pfunc, ctx);
+#endif
+#ifdef PLATFORM_FREEBSD
+	_init_timer(ptimer, adapter->pifp, pfunc, ctx);
+#endif
+#ifdef PLATFORM_WINDOWS
+	_init_timer(ptimer, adapter->hndis_adapter, pfunc, ctx);
+#endif
+}
+
+/*
+
+Caller must check if the list is empty before calling rtw_list_delete
+
+*/
+
+
+void _rtw_init_sema(_sema	*sema, int init_val)
+{
+
+#ifdef PLATFORM_LINUX
+
+	sema_init(sema, init_val);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	sema_init(sema, init_val, "rtw_drv");
+#endif
+#ifdef PLATFORM_OS_XP
+
+	KeInitializeSemaphore(sema, init_val,  SEMA_UPBND); /* count=0; */
+
+#endif
+
+#ifdef PLATFORM_OS_CE
+	if (*sema == NULL)
+		*sema = CreateSemaphore(NULL, init_val, SEMA_UPBND, NULL);
+#endif
+
+}
+
+void _rtw_free_sema(_sema	*sema)
+{
+#ifdef PLATFORM_FREEBSD
+	sema_destroy(sema);
+#endif
+#ifdef PLATFORM_OS_CE
+	CloseHandle(*sema);
+#endif
+
+}
+
+void _rtw_up_sema(_sema	*sema)
+{
+
+#ifdef PLATFORM_LINUX
+
+	up(sema);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	sema_post(sema);
+#endif
+#ifdef PLATFORM_OS_XP
+
+	KeReleaseSemaphore(sema, IO_NETWORK_INCREMENT, 1,  FALSE);
+
+#endif
+
+#ifdef PLATFORM_OS_CE
+	ReleaseSemaphore(*sema,  1,  NULL);
+#endif
+}
+
+u32 _rtw_down_sema(_sema *sema)
+{
+
+#ifdef PLATFORM_LINUX
+
+	if (down_interruptible(sema))
+		return _FAIL;
+	else
+		return _SUCCESS;
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	sema_wait(sema);
+	return  _SUCCESS;
+#endif
+#ifdef PLATFORM_OS_XP
+
+	if (STATUS_SUCCESS == KeWaitForSingleObject(sema, Executive, KernelMode, TRUE, NULL))
+		return  _SUCCESS;
+	else
+		return _FAIL;
+#endif
+
+#ifdef PLATFORM_OS_CE
+	if (WAIT_OBJECT_0 == WaitForSingleObject(*sema, INFINITE))
+		return _SUCCESS;
+	else
+		return _FAIL;
+#endif
+}
+
+inline void thread_exit(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	complete_and_exit(comp, 0);
+#endif
+
+#ifdef PLATFORM_FREEBSD
+	printf("%s", "RTKTHREAD_exit");
+#endif
+
+#ifdef PLATFORM_OS_CE
+	ExitThread(STATUS_SUCCESS);
+#endif
+
+#ifdef PLATFORM_OS_XP
+	PsTerminateSystemThread(STATUS_SUCCESS);
+#endif
+}
+
+inline void _rtw_init_completion(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	init_completion(comp);
+#endif
+}
+inline void _rtw_wait_for_comp_timeout(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	wait_for_completion_timeout(comp, msecs_to_jiffies(3000));
+#endif
+}
+inline void _rtw_wait_for_comp(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	wait_for_completion(comp);
+#endif
+}
+
+void	_rtw_mutex_init(_mutex *pmutex)
+{
+#ifdef PLATFORM_LINUX
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	mutex_init(pmutex);
+#else
+	init_MUTEX(pmutex);
+#endif
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	mtx_init(pmutex, "", NULL, MTX_DEF | MTX_RECURSE);
+#endif
+#ifdef PLATFORM_OS_XP
+
+	KeInitializeMutex(pmutex, 0);
+
+#endif
+
+#ifdef PLATFORM_OS_CE
+	*pmutex =  CreateMutex(NULL, _FALSE, NULL);
+#endif
+}
+
+void	_rtw_mutex_free(_mutex *pmutex);
+void	_rtw_mutex_free(_mutex *pmutex)
+{
+#ifdef PLATFORM_LINUX
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	mutex_destroy(pmutex);
+#else
+#endif
+
+#ifdef PLATFORM_FREEBSD
+	sema_destroy(pmutex);
+#endif
+
+#endif
+
+#ifdef PLATFORM_OS_XP
+
+#endif
+
+#ifdef PLATFORM_OS_CE
+
+#endif
+}
+
+void	_rtw_spinlock_init(_lock *plock)
+{
+
+#ifdef PLATFORM_LINUX
+
+	spin_lock_init(plock);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	mtx_init(plock, "", NULL, MTX_DEF | MTX_RECURSE);
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisAllocateSpinLock(plock);
+
+#endif
+
+}
+
+void	_rtw_spinlock_free(_lock *plock)
+{
+#ifdef PLATFORM_FREEBSD
+	mtx_destroy(plock);
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+	NdisFreeSpinLock(plock);
+
+#endif
+
+}
+#ifdef PLATFORM_FREEBSD
+extern PADAPTER prtw_lock;
+
+void rtw_mtx_lock(_lock *plock)
+{
+	if (prtw_lock)
+		mtx_lock(&prtw_lock->glock);
+	else
+		printf("%s prtw_lock==NULL", __FUNCTION__);
+}
+void rtw_mtx_unlock(_lock *plock)
+{
+	if (prtw_lock)
+		mtx_unlock(&prtw_lock->glock);
+	else
+		printf("%s prtw_lock==NULL", __FUNCTION__);
+
+}
+#endif /* PLATFORM_FREEBSD */
+
+
+void	_rtw_spinlock(_lock	*plock)
+{
+
+#ifdef PLATFORM_LINUX
+
+	spin_lock(plock);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	mtx_lock(plock);
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisAcquireSpinLock(plock);
+
+#endif
+
+}
+
+void	_rtw_spinunlock(_lock *plock)
+{
+
+#ifdef PLATFORM_LINUX
+
+	spin_unlock(plock);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	mtx_unlock(plock);
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisReleaseSpinLock(plock);
+
+#endif
+}
+
+
+void	_rtw_spinlock_ex(_lock	*plock)
+{
+
+#ifdef PLATFORM_LINUX
+
+	spin_lock(plock);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	mtx_lock(plock);
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisDprAcquireSpinLock(plock);
+
+#endif
+
+}
+
+void	_rtw_spinunlock_ex(_lock *plock)
+{
+
+#ifdef PLATFORM_LINUX
+
+	spin_unlock(plock);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	mtx_unlock(plock);
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisDprReleaseSpinLock(plock);
+
+#endif
+}
+
+
+
+void _rtw_init_queue(_queue *pqueue)
+{
+	_rtw_init_listhead(&(pqueue->queue));
+	_rtw_spinlock_init(&(pqueue->lock));
+}
+
+void _rtw_deinit_queue(_queue *pqueue)
+{
+	_rtw_spinlock_free(&(pqueue->lock));
+}
+
+u32	  _rtw_queue_empty(_queue	*pqueue)
+{
+	return rtw_is_list_empty(&(pqueue->queue));
+}
+
+
+u32 rtw_end_of_queue_search(_list *head, _list *plist)
+{
+	if (head == plist)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+
+systime _rtw_get_current_time(void)
+{
+
+#ifdef PLATFORM_LINUX
+	return jiffies;
+#endif
+#ifdef PLATFORM_FREEBSD
+	struct timeval tvp;
+	getmicrotime(&tvp);
+	return tvp.tv_sec;
+#endif
+#ifdef PLATFORM_WINDOWS
+	LARGE_INTEGER	SystemTime;
+	NdisGetCurrentSystemTime(&SystemTime);
+	return SystemTime.LowPart;/* count of 100-nanosecond intervals */
+#endif
+}
+
+inline u32 _rtw_systime_to_ms(systime stime)
+{
+#ifdef PLATFORM_LINUX
+	return jiffies_to_msecs(stime);
+#endif
+#ifdef PLATFORM_FREEBSD
+	return stime * 1000;
+#endif
+#ifdef PLATFORM_WINDOWS
+	return stime / 10000 ;
+#endif
+}
+
+inline systime _rtw_ms_to_systime(u32 ms)
+{
+#ifdef PLATFORM_LINUX
+	return msecs_to_jiffies(ms);
+#endif
+#ifdef PLATFORM_FREEBSD
+	return ms / 1000;
+#endif
+#ifdef PLATFORM_WINDOWS
+	return ms * 10000 ;
+#endif
+}
+
+inline systime _rtw_us_to_systime(u32 us)
+{
+#ifdef PLATFORM_LINUX
+	return usecs_to_jiffies(us);
+#else
+	#error "TBD\n"
+#endif
+}
+
+/* the input parameter start use the same unit as returned by rtw_get_current_time */
+inline s32 _rtw_get_passing_time_ms(systime start)
+{
+	return _rtw_systime_to_ms(_rtw_get_current_time() - start);
+}
+
+inline s32 _rtw_get_remaining_time_ms(systime end)
+{
+	return _rtw_systime_to_ms(end - _rtw_get_current_time());
+}
+
+inline s32 _rtw_get_time_interval_ms(systime start, systime end)
+{
+	return _rtw_systime_to_ms(end - start);
+}
+
+inline bool _rtw_time_after(systime a, systime b)
+{
+#ifdef PLATFORM_LINUX
+	return time_after(a, b);
+#else
+	#error "TBD\n"
+#endif
+}
+
+void rtw_sleep_schedulable(int ms)
+{
+
+#ifdef PLATFORM_LINUX
+
+	u32 delta;
+
+	delta = (ms * HZ) / 1000; /* (ms) */
+	if (delta == 0) {
+		delta = 1;/* 1 ms */
+	}
+	set_current_state(TASK_INTERRUPTIBLE);
+	if (schedule_timeout(delta) != 0)
+		return ;
+	return;
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	DELAY(ms * 1000);
+	return ;
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+	NdisMSleep(ms * 1000); /* (us)*1000=(ms) */
+
+#endif
+
+}
+
+
+void rtw_msleep_os(int ms)
+{
+
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
+	if (ms < 20) {
+		unsigned long us = ms * 1000UL;
+		usleep_range(us, us + 1000UL);
+	} else
+#endif
+		msleep((unsigned int)ms);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	/* Delay for delay microseconds */
+	DELAY(ms * 1000);
+	return ;
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisMSleep(ms * 1000); /* (us)*1000=(ms) */
+
+#endif
+
+
+}
+void rtw_usleep_os(int us)
+{
+#ifdef PLATFORM_LINUX
+
+	/* msleep((unsigned int)us); */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
+	usleep_range(us, us + 1);
+#else
+	if (1 < (us / 1000))
+		msleep(1);
+	else
+		msleep((us / 1000) + 1);
+#endif
+#endif
+
+#ifdef PLATFORM_FREEBSD
+	/* Delay for delay microseconds */
+	DELAY(us);
+
+	return ;
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisMSleep(us); /* (us) */
+
+#endif
+
+
+}
+
+
+#ifdef DBG_DELAY_OS
+void _rtw_mdelay_os(int ms, const char *func, const int line)
+{
+#if 0
+	if (ms > 10)
+		RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, ms);
+	rtw_msleep_os(ms);
+	return;
+#endif
+
+
+	RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, ms);
+
+#if defined(PLATFORM_LINUX)
+
+	mdelay((unsigned long)ms);
+
+#elif defined(PLATFORM_WINDOWS)
+
+	NdisStallExecution(ms * 1000); /* (us)*1000=(ms) */
+
+#endif
+
+
+}
+void _rtw_udelay_os(int us, const char *func, const int line)
+{
+
+#if 0
+	if (us > 1000) {
+		RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, us);
+		rtw_usleep_os(us);
+		return;
+	}
+#endif
+
+
+	RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, us);
+
+
+#if defined(PLATFORM_LINUX)
+
+	udelay((unsigned long)us);
+
+#elif defined(PLATFORM_WINDOWS)
+
+	NdisStallExecution(us); /* (us) */
+
+#endif
+
+}
+#else
+void rtw_mdelay_os(int ms)
+{
+
+#ifdef PLATFORM_LINUX
+
+	mdelay((unsigned long)ms);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	DELAY(ms * 1000);
+	return ;
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisStallExecution(ms * 1000); /* (us)*1000=(ms) */
+
+#endif
+
+
+}
+void rtw_udelay_os(int us)
+{
+
+#ifdef PLATFORM_LINUX
+
+	udelay((unsigned long)us);
+
+#endif
+#ifdef PLATFORM_FREEBSD
+	/* Delay for delay microseconds */
+	DELAY(us);
+	return ;
+#endif
+#ifdef PLATFORM_WINDOWS
+
+	NdisStallExecution(us); /* (us) */
+
+#endif
+
+}
+#endif
+
+void rtw_yield_os(void)
+{
+#ifdef PLATFORM_LINUX
+	yield();
+#endif
+#ifdef PLATFORM_FREEBSD
+	yield();
+#endif
+#ifdef PLATFORM_WINDOWS
+	SwitchToThread();
+#endif
+}
+
+#define RTW_SUSPEND_LOCK_NAME "rtw_wifi"
+#define RTW_SUSPEND_TRAFFIC_LOCK_NAME "rtw_wifi_traffic"
+#define RTW_SUSPEND_RESUME_LOCK_NAME "rtw_wifi_resume"
+#ifdef CONFIG_WAKELOCK
+static struct wake_lock rtw_suspend_lock;
+static struct wake_lock rtw_suspend_traffic_lock;
+static struct wake_lock rtw_suspend_resume_lock;
+#elif defined(CONFIG_ANDROID_POWER)
+static android_suspend_lock_t rtw_suspend_lock = {
+	.name = RTW_SUSPEND_LOCK_NAME
+};
+static android_suspend_lock_t rtw_suspend_traffic_lock = {
+	.name = RTW_SUSPEND_TRAFFIC_LOCK_NAME
+};
+static android_suspend_lock_t rtw_suspend_resume_lock = {
+	.name = RTW_SUSPEND_RESUME_LOCK_NAME
+};
+#endif
+
+inline void rtw_suspend_lock_init(void)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_lock_init(&rtw_suspend_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_LOCK_NAME);
+	wake_lock_init(&rtw_suspend_traffic_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_TRAFFIC_LOCK_NAME);
+	wake_lock_init(&rtw_suspend_resume_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_RESUME_LOCK_NAME);
+#elif defined(CONFIG_ANDROID_POWER)
+	android_init_suspend_lock(&rtw_suspend_lock);
+	android_init_suspend_lock(&rtw_suspend_traffic_lock);
+	android_init_suspend_lock(&rtw_suspend_resume_lock);
+#endif
+}
+
+inline void rtw_suspend_lock_uninit(void)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_lock_destroy(&rtw_suspend_lock);
+	wake_lock_destroy(&rtw_suspend_traffic_lock);
+	wake_lock_destroy(&rtw_suspend_resume_lock);
+#elif defined(CONFIG_ANDROID_POWER)
+	android_uninit_suspend_lock(&rtw_suspend_lock);
+	android_uninit_suspend_lock(&rtw_suspend_traffic_lock);
+	android_uninit_suspend_lock(&rtw_suspend_resume_lock);
+#endif
+}
+
+inline void rtw_lock_suspend(void)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_lock(&rtw_suspend_lock);
+#elif defined(CONFIG_ANDROID_POWER)
+	android_lock_suspend(&rtw_suspend_lock);
+#endif
+
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
+}
+
+inline void rtw_unlock_suspend(void)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_unlock(&rtw_suspend_lock);
+#elif defined(CONFIG_ANDROID_POWER)
+	android_unlock_suspend(&rtw_suspend_lock);
+#endif
+
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
+}
+
+inline void rtw_resume_lock_suspend(void)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_lock(&rtw_suspend_resume_lock);
+#elif defined(CONFIG_ANDROID_POWER)
+	android_lock_suspend(&rtw_suspend_resume_lock);
+#endif
+
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
+}
+
+inline void rtw_resume_unlock_suspend(void)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_unlock(&rtw_suspend_resume_lock);
+#elif defined(CONFIG_ANDROID_POWER)
+	android_unlock_suspend(&rtw_suspend_resume_lock);
+#endif
+
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
+}
+
+inline void rtw_lock_suspend_timeout(u32 timeout_ms)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_lock_timeout(&rtw_suspend_lock, rtw_ms_to_systime(timeout_ms));
+#elif defined(CONFIG_ANDROID_POWER)
+	android_lock_suspend_auto_expire(&rtw_suspend_lock, rtw_ms_to_systime(timeout_ms));
+#endif
+}
+
+
+inline void rtw_lock_traffic_suspend_timeout(u32 timeout_ms)
+{
+#ifdef CONFIG_WAKELOCK
+	wake_lock_timeout(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
+#elif defined(CONFIG_ANDROID_POWER)
+	android_lock_suspend_auto_expire(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
+#endif
+	/* RTW_INFO("traffic lock timeout:%d\n", timeout_ms); */
+}
+
+inline void rtw_set_bit(int nr, unsigned long *addr)
+{
+#ifdef PLATFORM_LINUX
+	set_bit(nr, addr);
+#else
+	#error "TBD\n";
+#endif
+}
+
+inline void rtw_clear_bit(int nr, unsigned long *addr)
+{
+#ifdef PLATFORM_LINUX
+	clear_bit(nr, addr);
+#else
+	#error "TBD\n";
+#endif
+}
+
+inline int rtw_test_and_clear_bit(int nr, unsigned long *addr)
+{
+#ifdef PLATFORM_LINUX
+	return test_and_clear_bit(nr, addr);
+#else
+	#error "TBD\n";
+#endif
+}
+
+inline void ATOMIC_SET(ATOMIC_T *v, int i)
+{
+#ifdef PLATFORM_LINUX
+	atomic_set(v, i);
+#elif defined(PLATFORM_WINDOWS)
+	*v = i; /* other choice???? */
+#elif defined(PLATFORM_FREEBSD)
+	atomic_set_int(v, i);
+#endif
+}
+
+inline int ATOMIC_READ(ATOMIC_T *v)
+{
+#ifdef PLATFORM_LINUX
+	return atomic_read(v);
+#elif defined(PLATFORM_WINDOWS)
+	return *v; /* other choice???? */
+#elif defined(PLATFORM_FREEBSD)
+	return atomic_load_acq_32(v);
+#endif
+}
+
+inline void ATOMIC_ADD(ATOMIC_T *v, int i)
+{
+#ifdef PLATFORM_LINUX
+	atomic_add(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	InterlockedAdd(v, i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, i);
+#endif
+}
+inline void ATOMIC_SUB(ATOMIC_T *v, int i)
+{
+#ifdef PLATFORM_LINUX
+	atomic_sub(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	InterlockedAdd(v, -i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, i);
+#endif
+}
+
+inline void ATOMIC_INC(ATOMIC_T *v)
+{
+#ifdef PLATFORM_LINUX
+	atomic_inc(v);
+#elif defined(PLATFORM_WINDOWS)
+	InterlockedIncrement(v);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, 1);
+#endif
+}
+
+inline void ATOMIC_DEC(ATOMIC_T *v)
+{
+#ifdef PLATFORM_LINUX
+	atomic_dec(v);
+#elif defined(PLATFORM_WINDOWS)
+	InterlockedDecrement(v);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, 1);
+#endif
+}
+
+inline int ATOMIC_ADD_RETURN(ATOMIC_T *v, int i)
+{
+#ifdef PLATFORM_LINUX
+	return atomic_add_return(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	return InterlockedAdd(v, i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, i);
+	return atomic_load_acq_32(v);
+#endif
+}
+
+inline int ATOMIC_SUB_RETURN(ATOMIC_T *v, int i)
+{
+#ifdef PLATFORM_LINUX
+	return atomic_sub_return(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	return InterlockedAdd(v, -i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, i);
+	return atomic_load_acq_32(v);
+#endif
+}
+
+inline int ATOMIC_INC_RETURN(ATOMIC_T *v)
+{
+#ifdef PLATFORM_LINUX
+	return atomic_inc_return(v);
+#elif defined(PLATFORM_WINDOWS)
+	return InterlockedIncrement(v);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, 1);
+	return atomic_load_acq_32(v);
+#endif
+}
+
+inline int ATOMIC_DEC_RETURN(ATOMIC_T *v)
+{
+#ifdef PLATFORM_LINUX
+	return atomic_dec_return(v);
+#elif defined(PLATFORM_WINDOWS)
+	return InterlockedDecrement(v);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, 1);
+	return atomic_load_acq_32(v);
+#endif
+}
+
+inline bool ATOMIC_INC_UNLESS(ATOMIC_T *v, int u)
+{
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 15))
+	return atomic_add_unless(v, 1, u);
+#else
+	/* only make sure not exceed after this function */
+	if (ATOMIC_INC_RETURN(v) > u) {
+		ATOMIC_DEC(v);
+		return 0;
+	}
+	return 1;
+#endif
+#else
+	#error "TBD\n"
+#endif
+}
+
+#ifdef PLATFORM_LINUX
+/*
+* Open a file with the specific @param path, @param flag, @param mode
+* @param fpp the pointer of struct file pointer to get struct file pointer while file opening is success
+* @param path the path of the file to open
+* @param flag file operation flags, please refer to linux document
+* @param mode please refer to linux document
+* @return Linux specific error code
+*/
+static int openFile(struct file **fpp, const char *path, int flag, int mode)
+{
+	struct file *fp;
+
+	fp = filp_open(path, flag, mode);
+	if (IS_ERR(fp)) {
+		*fpp = NULL;
+		return PTR_ERR(fp);
+	} else {
+		*fpp = fp;
+		return 0;
+	}
+}
+
+/*
+* Close the file with the specific @param fp
+* @param fp the pointer of struct file to close
+* @return always 0
+*/
+static int closeFile(struct file *fp)
+{
+	filp_close(fp, NULL);
+	return 0;
+}
+
+static int readFile(struct file *fp, char *buf, int len)
+{
+	int rlen = 0, sum = 0;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+	if (!(fp->f_mode & FMODE_CAN_READ))
+#else
+	if (!fp->f_op || !fp->f_op->read)
+#endif
+		return -EPERM;
+
+	while (sum < len) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+		rlen = kernel_read(fp, buf + sum, len - sum, &fp->f_pos);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+		rlen = __vfs_read(fp, buf + sum, len - sum, &fp->f_pos);
+#else
+		rlen = fp->f_op->read(fp, buf + sum, len - sum, &fp->f_pos);
+#endif
+		if (rlen > 0)
+			sum += rlen;
+		else if (0 != rlen)
+			return rlen;
+		else
+			break;
+	}
+
+	return  sum;
+
+}
+
+static int writeFile(struct file *fp, char *buf, int len)
+{
+	int wlen = 0, sum = 0;
+
+	if (!fp->f_op || !fp->f_op->write)
+		return -EPERM;
+
+	while (sum < len) {
+		wlen = fp->f_op->write(fp, buf + sum, len - sum, &fp->f_pos);
+		if (wlen > 0)
+			sum += wlen;
+		else if (0 != wlen)
+			return wlen;
+		else
+			break;
+	}
+
+	return sum;
+
+}
+
+/*
+* Test if the specifi @param path is a file and readable
+* If readable, @param sz is got
+* @param path the path of the file to test
+* @return Linux specific error code
+*/
+static int isFileReadable(const char *path, u32 *sz)
+{
+	struct file *fp;
+	int ret = 0;
+	mm_segment_t oldfs;
+	char buf;
+
+	fp = filp_open(path, O_RDONLY, 0);
+	if (IS_ERR(fp))
+		ret = PTR_ERR(fp);
+	else {
+		oldfs = get_fs();
+		set_fs(get_ds());
+
+		if (1 != readFile(fp, &buf, 1))
+			ret = PTR_ERR(fp);
+
+		if (ret == 0 && sz) {
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+			*sz = i_size_read(fp->f_path.dentry->d_inode);
+			#else
+			*sz = i_size_read(fp->f_dentry->d_inode);
+			#endif
+		}
+
+		set_fs(oldfs);
+		filp_close(fp, NULL);
+	}
+	return ret;
+}
+
+/*
+* Open the file with @param path and retrive the file content into memory starting from @param buf for @param sz at most
+* @param path the path of the file to open and read
+* @param buf the starting address of the buffer to store file content
+* @param sz how many bytes to read at most
+* @return the byte we've read, or Linux specific error code
+*/
+static int retriveFromFile(const char *path, u8 *buf, u32 sz)
+{
+	int ret = -1;
+	mm_segment_t oldfs;
+	struct file *fp;
+
+	if (path && buf) {
+		ret = openFile(&fp, path, O_RDONLY, 0);
+		if (0 == ret) {
+			RTW_INFO("%s openFile path:%s fp=%p\n", __FUNCTION__, path , fp);
+
+			oldfs = get_fs();
+			set_fs(get_ds());
+			ret = readFile(fp, buf, sz);
+			set_fs(oldfs);
+			closeFile(fp);
+
+			RTW_INFO("%s readFile, ret:%d\n", __FUNCTION__, ret);
+
+		} else
+			RTW_INFO("%s openFile path:%s Fail, ret:%d\n", __FUNCTION__, path, ret);
+	} else {
+		RTW_INFO("%s NULL pointer\n", __FUNCTION__);
+		ret =  -EINVAL;
+	}
+	return ret;
+}
+
+/*
+* Open the file with @param path and wirte @param sz byte of data starting from @param buf into the file
+* @param path the path of the file to open and write
+* @param buf the starting address of the data to write into file
+* @param sz how many bytes to write at most
+* @return the byte we've written, or Linux specific error code
+*/
+static int storeToFile(const char *path, u8 *buf, u32 sz)
+{
+	int ret = 0;
+	mm_segment_t oldfs;
+	struct file *fp;
+
+	if (path && buf) {
+		ret = openFile(&fp, path, O_CREAT | O_WRONLY, 0666);
+		if (0 == ret) {
+			RTW_INFO("%s openFile path:%s fp=%p\n", __FUNCTION__, path , fp);
+
+			oldfs = get_fs();
+			set_fs(get_ds());
+			ret = writeFile(fp, buf, sz);
+			set_fs(oldfs);
+			closeFile(fp);
+
+			RTW_INFO("%s writeFile, ret:%d\n", __FUNCTION__, ret);
+
+		} else
+			RTW_INFO("%s openFile path:%s Fail, ret:%d\n", __FUNCTION__, path, ret);
+	} else {
+		RTW_INFO("%s NULL pointer\n", __FUNCTION__);
+		ret =  -EINVAL;
+	}
+	return ret;
+}
+#endif /* PLATFORM_LINUX */
+
+/*
+* Test if the specifi @param path is a file and readable
+* @param path the path of the file to test
+* @return _TRUE or _FALSE
+*/
+int rtw_is_file_readable(const char *path)
+{
+#ifdef PLATFORM_LINUX
+	if (isFileReadable(path, NULL) == 0)
+		return _TRUE;
+	else
+		return _FALSE;
+#else
+	/* Todo... */
+	return _FALSE;
+#endif
+}
+
+/*
+* Test if the specifi @param path is a file and readable.
+* If readable, @param sz is got
+* @param path the path of the file to test
+* @return _TRUE or _FALSE
+*/
+int rtw_is_file_readable_with_size(const char *path, u32 *sz)
+{
+#ifdef PLATFORM_LINUX
+	if (isFileReadable(path, sz) == 0)
+		return _TRUE;
+	else
+		return _FALSE;
+#else
+	/* Todo... */
+	return _FALSE;
+#endif
+}
+
+/*
+* Open the file with @param path and retrive the file content into memory starting from @param buf for @param sz at most
+* @param path the path of the file to open and read
+* @param buf the starting address of the buffer to store file content
+* @param sz how many bytes to read at most
+* @return the byte we've read
+*/
+int rtw_retrieve_from_file(const char *path, u8 *buf, u32 sz)
+{
+#ifdef PLATFORM_LINUX
+	int ret = retriveFromFile(path, buf, sz);
+	return ret >= 0 ? ret : 0;
+#else
+	/* Todo... */
+	return 0;
+#endif
+}
+
+/*
+* Open the file with @param path and wirte @param sz byte of data starting from @param buf into the file
+* @param path the path of the file to open and write
+* @param buf the starting address of the data to write into file
+* @param sz how many bytes to write at most
+* @return the byte we've written
+*/
+int rtw_store_to_file(const char *path, u8 *buf, u32 sz)
+{
+#ifdef PLATFORM_LINUX
+	int ret = storeToFile(path, buf, sz);
+	return ret >= 0 ? ret : 0;
+#else
+	/* Todo... */
+	return 0;
+#endif
+}
+
+#ifdef PLATFORM_LINUX
+struct net_device *rtw_alloc_etherdev_with_old_priv(int sizeof_priv, void *old_priv)
+{
+	struct net_device *pnetdev;
+	struct rtw_netdev_priv_indicator *pnpi;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	pnetdev = alloc_etherdev_mq(sizeof(struct rtw_netdev_priv_indicator), 4);
+#else
+	pnetdev = alloc_etherdev(sizeof(struct rtw_netdev_priv_indicator));
+#endif
+	if (!pnetdev)
+		goto RETURN;
+
+	pnpi = netdev_priv(pnetdev);
+	pnpi->priv = old_priv;
+	pnpi->sizeof_priv = sizeof_priv;
+
+RETURN:
+	return pnetdev;
+}
+
+struct net_device *rtw_alloc_etherdev(int sizeof_priv)
+{
+	struct net_device *pnetdev;
+	struct rtw_netdev_priv_indicator *pnpi;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	pnetdev = alloc_etherdev_mq(sizeof(struct rtw_netdev_priv_indicator), 4);
+#else
+	pnetdev = alloc_etherdev(sizeof(struct rtw_netdev_priv_indicator));
+#endif
+	if (!pnetdev)
+		goto RETURN;
+
+	pnpi = netdev_priv(pnetdev);
+
+	pnpi->priv = rtw_zvmalloc(sizeof_priv);
+	if (!pnpi->priv) {
+		free_netdev(pnetdev);
+		pnetdev = NULL;
+		goto RETURN;
+	}
+
+	pnpi->sizeof_priv = sizeof_priv;
+RETURN:
+	return pnetdev;
+}
+
+void rtw_free_netdev(struct net_device *netdev)
+{
+	struct rtw_netdev_priv_indicator *pnpi;
+
+	if (!netdev)
+		goto RETURN;
+
+	pnpi = netdev_priv(netdev);
+
+	if (!pnpi->priv)
+		goto RETURN;
+
+	free_netdev(netdev);
+
+RETURN:
+	return;
+}
+
+int rtw_change_ifname(_adapter *padapter, const char *ifname)
+{
+	struct dvobj_priv *dvobj;
+	struct net_device *pnetdev;
+	struct net_device *cur_pnetdev;
+	struct rereg_nd_name_data *rereg_priv;
+	int ret;
+	u8 rtnl_lock_needed;
+
+	if (!padapter)
+		goto error;
+
+	dvobj = adapter_to_dvobj(padapter);
+	cur_pnetdev = padapter->pnetdev;
+	rereg_priv = &padapter->rereg_nd_name_priv;
+
+	/* free the old_pnetdev */
+	if (rereg_priv->old_pnetdev) {
+		free_netdev(rereg_priv->old_pnetdev);
+		rereg_priv->old_pnetdev = NULL;
+	}
+
+	rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+
+	if (rtnl_lock_needed)
+		unregister_netdev(cur_pnetdev);
+	else
+		unregister_netdevice(cur_pnetdev);
+
+	rereg_priv->old_pnetdev = cur_pnetdev;
+
+	pnetdev = rtw_init_netdev(padapter);
+	if (!pnetdev)  {
+		ret = -1;
+		goto error;
+	}
+
+	SET_NETDEV_DEV(pnetdev, dvobj_to_dev(adapter_to_dvobj(padapter)));
+
+	rtw_init_netdev_name(pnetdev, ifname);
+
+	_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
+
+	if (rtnl_lock_needed)
+		ret = register_netdev(pnetdev);
+	else
+		ret = register_netdevice(pnetdev);
+
+	if (ret != 0) {
+		goto error;
+	}
+
+	return 0;
+
+error:
+
+	return -1;
+
+}
+#endif
+
+#ifdef PLATFORM_FREEBSD
+/*
+ * Copy a buffer from userspace and write into kernel address
+ * space.
+ *
+ * This emulation just calls the FreeBSD copyin function (to
+ * copy data from user space buffer into a kernel space buffer)
+ * and is designed to be used with the above io_write_wrapper.
+ *
+ * This function should return the number of bytes not copied.
+ * I.e. success results in a zero value.
+ * Negative error values are not returned.
+ */
+unsigned long
+copy_from_user(void *to, const void *from, unsigned long n)
+{
+	if (copyin(from, to, n) != 0) {
+		/* Any errors will be treated as a failure
+		   to copy any of the requested bytes */
+		return n;
+	}
+
+	return 0;
+}
+
+unsigned long
+copy_to_user(void *to, const void *from, unsigned long n)
+{
+	if (copyout(from, to, n) != 0) {
+		/* Any errors will be treated as a failure
+		   to copy any of the requested bytes */
+		return n;
+	}
+
+	return 0;
+}
+
+
+/*
+ * The usb_register and usb_deregister functions are used to register
+ * usb drivers with the usb subsystem. In this compatibility layer
+ * emulation a list of drivers (struct usb_driver) is maintained
+ * and is used for probing/attaching etc.
+ *
+ * usb_register and usb_deregister simply call these functions.
+ */
+int
+usb_register(struct usb_driver *driver)
+{
+	rtw_usb_linux_register(driver);
+	return 0;
+}
+
+
+int
+usb_deregister(struct usb_driver *driver)
+{
+	rtw_usb_linux_deregister(driver);
+	return 0;
+}
+
+void module_init_exit_wrapper(void *arg)
+{
+	int (*func)(void) = arg;
+	func();
+	return;
+}
+
+#endif /* PLATFORM_FREEBSD */
+
+#ifdef CONFIG_PLATFORM_SPRD
+	#ifdef do_div
+		#undef do_div
+	#endif
+	#include <asm-generic/div64.h>
+#endif
+
+u64 rtw_modular64(u64 x, u64 y)
+{
+#ifdef PLATFORM_LINUX
+	return do_div(x, y);
+#elif defined(PLATFORM_WINDOWS)
+	return x % y;
+#elif defined(PLATFORM_FREEBSD)
+	return x % y;
+#endif
+}
+
+u64 rtw_division64(u64 x, u64 y)
+{
+#ifdef PLATFORM_LINUX
+	do_div(x, y);
+	return x;
+#elif defined(PLATFORM_WINDOWS)
+	return x / y;
+#elif defined(PLATFORM_FREEBSD)
+	return x / y;
+#endif
+}
+
+inline u32 rtw_random32(void)
+{
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	return prandom_u32();
+#elif (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 18))
+	u32 random_int;
+	get_random_bytes(&random_int , 4);
+	return random_int;
+#else
+	return random32();
+#endif
+#elif defined(PLATFORM_WINDOWS)
+#error "to be implemented\n"
+#elif defined(PLATFORM_FREEBSD)
+#error "to be implemented\n"
+#endif
+}
+
+void rtw_buf_free(u8 **buf, u32 *buf_len)
+{
+	u32 ori_len;
+
+	if (!buf || !buf_len)
+		return;
+
+	ori_len = *buf_len;
+
+	if (*buf) {
+		u32 tmp_buf_len = *buf_len;
+		*buf_len = 0;
+		rtw_mfree(*buf, tmp_buf_len);
+		*buf = NULL;
+	}
+}
+
+void rtw_buf_update(u8 **buf, u32 *buf_len, u8 *src, u32 src_len)
+{
+	u32 ori_len = 0, dup_len = 0;
+	u8 *ori = NULL;
+	u8 *dup = NULL;
+
+	if (!buf || !buf_len)
+		return;
+
+	if (!src || !src_len)
+		goto keep_ori;
+
+	/* duplicate src */
+	dup = rtw_malloc(src_len);
+	if (dup) {
+		dup_len = src_len;
+		_rtw_memcpy(dup, src, dup_len);
+	}
+
+keep_ori:
+	ori = *buf;
+	ori_len = *buf_len;
+
+	/* replace buf with dup */
+	*buf_len = 0;
+	*buf = dup;
+	*buf_len = dup_len;
+
+	/* free ori */
+	if (ori && ori_len > 0)
+		rtw_mfree(ori, ori_len);
+}
+
+
+/**
+ * rtw_cbuf_full - test if cbuf is full
+ * @cbuf: pointer of struct rtw_cbuf
+ *
+ * Returns: _TRUE if cbuf is full
+ */
+inline bool rtw_cbuf_full(struct rtw_cbuf *cbuf)
+{
+	return (cbuf->write == cbuf->read - 1) ? _TRUE : _FALSE;
+}
+
+/**
+ * rtw_cbuf_empty - test if cbuf is empty
+ * @cbuf: pointer of struct rtw_cbuf
+ *
+ * Returns: _TRUE if cbuf is empty
+ */
+inline bool rtw_cbuf_empty(struct rtw_cbuf *cbuf)
+{
+	return (cbuf->write == cbuf->read) ? _TRUE : _FALSE;
+}
+
+/**
+ * rtw_cbuf_push - push a pointer into cbuf
+ * @cbuf: pointer of struct rtw_cbuf
+ * @buf: pointer to push in
+ *
+ * Lock free operation, be careful of the use scheme
+ * Returns: _TRUE push success
+ */
+bool rtw_cbuf_push(struct rtw_cbuf *cbuf, void *buf)
+{
+	if (rtw_cbuf_full(cbuf))
+		return _FAIL;
+
+	if (0)
+		RTW_INFO("%s on %u\n", __func__, cbuf->write);
+	cbuf->bufs[cbuf->write] = buf;
+	cbuf->write = (cbuf->write + 1) % cbuf->size;
+
+	return _SUCCESS;
+}
+
+/**
+ * rtw_cbuf_pop - pop a pointer from cbuf
+ * @cbuf: pointer of struct rtw_cbuf
+ *
+ * Lock free operation, be careful of the use scheme
+ * Returns: pointer popped out
+ */
+void *rtw_cbuf_pop(struct rtw_cbuf *cbuf)
+{
+	void *buf;
+	if (rtw_cbuf_empty(cbuf))
+		return NULL;
+
+	if (0)
+		RTW_INFO("%s on %u\n", __func__, cbuf->read);
+	buf = cbuf->bufs[cbuf->read];
+	cbuf->read = (cbuf->read + 1) % cbuf->size;
+
+	return buf;
+}
+
+/**
+ * rtw_cbuf_alloc - allocte a rtw_cbuf with given size and do initialization
+ * @size: size of pointer
+ *
+ * Returns: pointer of srtuct rtw_cbuf, NULL for allocation failure
+ */
+struct rtw_cbuf *rtw_cbuf_alloc(u32 size)
+{
+	struct rtw_cbuf *cbuf;
+
+	cbuf = (struct rtw_cbuf *)rtw_malloc(sizeof(*cbuf) + sizeof(void *) * size);
+
+	if (cbuf) {
+		cbuf->write = cbuf->read = 0;
+		cbuf->size = size;
+	}
+
+	return cbuf;
+}
+
+/**
+ * rtw_cbuf_free - free the given rtw_cbuf
+ * @cbuf: pointer of struct rtw_cbuf to free
+ */
+void rtw_cbuf_free(struct rtw_cbuf *cbuf)
+{
+	rtw_mfree((u8 *)cbuf, sizeof(*cbuf) + sizeof(void *) * cbuf->size);
+}
+
+/**
+ * map_readN - read a range of map data
+ * @map: map to read
+ * @offset: start address to read
+ * @len: length to read
+ * @buf: pointer of buffer to store data read
+ *
+ * Returns: _SUCCESS or _FAIL
+ */
+int map_readN(const struct map_t *map, u16 offset, u16 len, u8 *buf)
+{
+	const struct map_seg_t *seg;
+	int ret = _FAIL;
+	int i;
+
+	if (len == 0) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (offset + len > map->len) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	_rtw_memset(buf, map->init_value, len);
+
+	for (i = 0; i < map->seg_num; i++) {
+		u8 *c_dst, *c_src;
+		u16 c_len;
+
+		seg = map->segs + i;
+		if (seg->sa + seg->len <= offset || seg->sa >= offset + len)
+			continue;
+
+		if (seg->sa >= offset) {
+			c_dst = buf + (seg->sa - offset);
+			c_src = seg->c;
+			if (seg->sa + seg->len <= offset + len)
+				c_len = seg->len;
+			else
+				c_len = offset + len - seg->sa;
+		} else {
+			c_dst = buf;
+			c_src = seg->c + (offset - seg->sa);
+			if (seg->sa + seg->len >= offset + len)
+				c_len = len;
+			else
+				c_len = seg->sa + seg->len - offset;
+		}
+			
+		_rtw_memcpy(c_dst, c_src, c_len);
+	}
+
+exit:
+	return ret;
+}
+
+/**
+ * map_read8 - read 1 byte of map data
+ * @map: map to read
+ * @offset: address to read
+ *
+ * Returns: value of data of specified offset. map.init_value if offset is out of range
+ */
+u8 map_read8(const struct map_t *map, u16 offset)
+{
+	const struct map_seg_t *seg;
+	u8 val = map->init_value;
+	int i;
+
+	if (offset + 1 > map->len) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	for (i = 0; i < map->seg_num; i++) {
+		seg = map->segs + i;
+		if (seg->sa + seg->len <= offset || seg->sa >= offset + 1)
+			continue;
+
+		val = *(seg->c + offset - seg->sa);
+		break;
+	}
+
+exit:
+	return val;
+}
+
+int rtw_blacklist_add(_queue *blist, const u8 *addr, u32 timeout_ms)
+{
+	struct blacklist_ent *ent;
+	_list *list, *head;
+	u8 exist = _FALSE, timeout = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			exist = _TRUE;
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time))
+				timeout = _TRUE;
+			ent->exp_time = rtw_get_current_time()
+				+ rtw_ms_to_systime(timeout_ms);
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	if (exist == _FALSE) {
+		ent = rtw_malloc(sizeof(struct blacklist_ent));
+		if (ent) {
+			_rtw_memcpy(ent->addr, addr, ETH_ALEN);
+			ent->exp_time = rtw_get_current_time()
+				+ rtw_ms_to_systime(timeout_ms);
+			rtw_list_insert_tail(&ent->list, head);
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return (exist == _TRUE && timeout == _FALSE) ? RTW_ALREADY : (ent ? _SUCCESS : _FAIL);
+}
+
+int rtw_blacklist_del(_queue *blist, const u8 *addr)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+	u8 exist = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+			exist = _TRUE;
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return exist == _TRUE ? _SUCCESS : RTW_ALREADY;
+}
+
+int rtw_blacklist_search(_queue *blist, const u8 *addr)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+	u8 exist = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+				rtw_list_delete(&ent->list);
+				rtw_mfree(ent, sizeof(struct blacklist_ent));
+			} else
+				exist = _TRUE;
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return exist;
+}
+
+void rtw_blacklist_flush(_queue *blist)
+{
+	struct blacklist_ent *ent;
+	_list *list, *head;
+	_list tmp;
+
+	_rtw_init_listhead(&tmp);
+
+	enter_critical_bh(&blist->lock);
+	rtw_list_splice_init(&blist->queue, &tmp);
+	exit_critical_bh(&blist->lock);
+
+	head = &tmp;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+		rtw_list_delete(&ent->list);
+		rtw_mfree(ent, sizeof(struct blacklist_ent));
+	}
+}
+
+void dump_blacklist(void *sel, _queue *blist, const char *title)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+
+	if (rtw_end_of_queue_search(head, list) == _FALSE) {
+		if (title)
+			RTW_PRINT_SEL(sel, "%s:\n", title);
+	
+		while (rtw_end_of_queue_search(head, list) == _FALSE) {
+			ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+			list = get_next(list);
+
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time))
+				RTW_PRINT_SEL(sel, MAC_FMT" expired\n", MAC_ARG(ent->addr));
+			else
+				RTW_PRINT_SEL(sel, MAC_FMT" %u\n", MAC_ARG(ent->addr)
+					, rtw_get_remaining_time_ms(ent->exp_time));
+		}
+
+	}
+	exit_critical_bh(&blist->lock);
+}
+
+/**
+* is_null -
+*
+* Return	TRUE if c is null character
+*		FALSE otherwise.
+*/
+inline BOOLEAN is_null(char c)
+{
+	if (c == '\0')
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+inline BOOLEAN is_all_null(char *c, int len)
+{
+	for (; len > 0; len--)
+		if (c[len - 1] != '\0')
+			return _FALSE;
+
+	return _TRUE;
+}
+
+/**
+* is_eol -
+*
+* Return	TRUE if c is represent for EOL (end of line)
+*		FALSE otherwise.
+*/
+inline BOOLEAN is_eol(char c)
+{
+	if (c == '\r' || c == '\n')
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+/**
+* is_space -
+*
+* Return	TRUE if c is represent for space
+*		FALSE otherwise.
+*/
+inline BOOLEAN is_space(char c)
+{
+	if (c == ' ' || c == '\t')
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+/**
+* IsHexDigit -
+*
+* Return	TRUE if chTmp is represent for hex digit
+*		FALSE otherwise.
+*/
+inline BOOLEAN IsHexDigit(char chTmp)
+{
+	if ((chTmp >= '0' && chTmp <= '9') ||
+		(chTmp >= 'a' && chTmp <= 'f') ||
+		(chTmp >= 'A' && chTmp <= 'F'))
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+/**
+* is_alpha -
+*
+* Return	TRUE if chTmp is represent for alphabet
+*		FALSE otherwise.
+*/
+inline BOOLEAN is_alpha(char chTmp)
+{
+	if ((chTmp >= 'a' && chTmp <= 'z') ||
+		(chTmp >= 'A' && chTmp <= 'Z'))
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+inline char alpha_to_upper(char c)
+{
+	if ((c >= 'a' && c <= 'z'))
+		c = 'A' + (c - 'a');
+	return c;
+}
+
+int hex2num_i(char c)
+{
+	if (c >= '0' && c <= '9')
+		return c - '0';
+	if (c >= 'a' && c <= 'f')
+		return c - 'a' + 10;
+	if (c >= 'A' && c <= 'F')
+		return c - 'A' + 10;
+	return -1;
+}
+
+int hex2byte_i(const char *hex)
+{
+	int a, b;
+	a = hex2num_i(*hex++);
+	if (a < 0)
+		return -1;
+	b = hex2num_i(*hex++);
+	if (b < 0)
+		return -1;
+	return (a << 4) | b;
+}
+
+int hexstr2bin(const char *hex, u8 *buf, size_t len)
+{
+	size_t i;
+	int a;
+	const char *ipos = hex;
+	u8 *opos = buf;
+
+	for (i = 0; i < len; i++) {
+		a = hex2byte_i(ipos);
+		if (a < 0)
+			return -1;
+		*opos++ = a;
+		ipos += 2;
+	}
+	return 0;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/custom_country_chplan.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/custom_country_chplan.h
new file mode 100644
index 000000000000..f8cc13bf10c3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/custom_country_chplan.h
@@ -0,0 +1,22 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#error "You have defined CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP to use a customized map of your own instead of the default one"
+#error "Before removing these error notifications, please make sure regulatory certification requirements of your target markets"
+
+static const struct country_chplan CUSTOMIZED_country_chplan_map[] = {
+	COUNTRY_CHPLAN_ENT("TW", 0x76, 1, 0x3FF), /* Taiwan */
+};
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUN50IW1P1_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUN50IW1P1_sdio.c
new file mode 100644
index 000000000000..2586455de8c3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUN50IW1P1_sdio.c
@@ -0,0 +1,86 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 can be applied to following platforms:
+ *	CONFIG_PLATFORM_ARM_SUN50IW1P1
+ */
+#include <drv_types.h>
+#ifdef CONFIG_GPIO_WAKEUP
+#include <linux/gpio.h>
+#endif
+
+#ifdef CONFIG_MMC
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+extern void sunxi_mmc_rescan_card(unsigned ids);
+extern void sunxi_wlan_set_power(int on);
+extern int sunxi_wlan_get_bus_index(void);
+extern int sunxi_wlan_get_oob_irq(void);
+extern int sunxi_wlan_get_oob_irq_flags(void);
+#endif
+#ifdef CONFIG_GPIO_WAKEUP
+extern unsigned int oob_irq;
+#endif
+#endif /* CONFIG_MMC */
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#ifdef CONFIG_MMC
+	{
+
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+		int wlan_bus_index = sunxi_wlan_get_bus_index();
+		if (wlan_bus_index < 0)
+			return wlan_bus_index;
+
+		sunxi_wlan_set_power(1);
+		mdelay(100);
+		sunxi_mmc_rescan_card(wlan_bus_index);
+#endif
+		RTW_INFO("%s: power up, rescan card.\n", __FUNCTION__);
+
+#ifdef CONFIG_GPIO_WAKEUP
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+		oob_irq = sunxi_wlan_get_oob_irq();
+#endif
+#endif /* CONFIG_GPIO_WAKEUP */
+	}
+#endif /* CONFIG_MMC */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#ifdef CONFIG_MMC
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+	int wlan_bus_index = sunxi_wlan_get_bus_index();
+	if (wlan_bus_index < 0)
+		return;
+
+	sunxi_mmc_rescan_card(wlan_bus_index);
+	mdelay(100);
+	sunxi_wlan_set_power(0);
+#endif
+	RTW_INFO("%s: remove card, power off.\n", __FUNCTION__);
+#endif /* CONFIG_MMC */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNnI_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNnI_sdio.c
new file mode 100644
index 000000000000..8a52aa90cb0d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNnI_sdio.c
@@ -0,0 +1,130 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 can be applied to following platforms:
+ *	CONFIG_PLATFORM_ARM_SUN6I
+ *	CONFIG_PLATFORM_ARM_SUN7I
+ *	CONFIG_PLATFORM_ARM_SUN8I
+ */
+#include <drv_types.h>
+#include <mach/sys_config.h>
+#ifdef CONFIG_GPIO_WAKEUP
+#include <linux/gpio.h>
+#endif
+
+#ifdef CONFIG_MMC
+static int sdc_id = -1;
+static signed int gpio_eint_wlan = -1;
+static u32 eint_wlan_handle = 0;
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+extern void sw_mci_rescan_card(unsigned id, unsigned insert);
+#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
+extern void sunxi_mci_rescan_card(unsigned id, unsigned insert);
+#endif
+
+#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
+extern int get_rf_mod_type(void);
+#else
+extern int wifi_pm_get_mod_type(void);
+#endif
+
+extern void wifi_pm_power(int on);
+#ifdef CONFIG_GPIO_WAKEUP
+extern unsigned int oob_irq;
+#endif
+#endif /* CONFIG_MMC */
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#ifdef CONFIG_MMC
+	{
+		script_item_u val;
+		script_item_value_type_e type;
+
+#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
+		unsigned int mod_sel = get_rf_mod_type();
+#else
+		unsigned int mod_sel = wifi_pm_get_mod_type();
+#endif
+
+		type = script_get_item("wifi_para", "wifi_sdc_id", &val);
+		if (SCIRPT_ITEM_VALUE_TYPE_INT != type) {
+			RTW_INFO("get wifi_sdc_id failed\n");
+			ret = -1;
+		} else {
+			sdc_id = val.val;
+			RTW_INFO("----- %s sdc_id: %d, mod_sel: %d\n", __FUNCTION__, sdc_id, mod_sel);
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+			sw_mci_rescan_card(sdc_id, 1);
+#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
+			sunxi_mci_rescan_card(sdc_id, 1);
+#endif
+			mdelay(100);
+			wifi_pm_power(1);
+
+			RTW_INFO("%s: power up, rescan card.\n", __FUNCTION__);
+		}
+
+#ifdef CONFIG_GPIO_WAKEUP
+#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
+		type = script_get_item("wifi_para", "wl_host_wake", &val);
+#else
+#ifdef CONFIG_RTL8723B
+		type = script_get_item("wifi_para", "rtl8723bs_wl_host_wake", &val);
+#endif
+#ifdef CONFIG_RTL8188E
+		type = script_get_item("wifi_para", "rtl8189es_host_wake", &val);
+#endif
+#endif /* CONFIG_PLATFORM_ARM_SUN8I_W5P1 */
+		if (SCIRPT_ITEM_VALUE_TYPE_PIO != type) {
+			RTW_INFO("No definition of wake up host PIN\n");
+			ret = -1;
+		} else {
+			gpio_eint_wlan = val.gpio.gpio;
+#ifdef CONFIG_PLATFORM_ARM_SUN8I
+			oob_irq = gpio_to_irq(gpio_eint_wlan);
+#endif
+		}
+#endif /* CONFIG_GPIO_WAKEUP */
+	}
+#endif /* CONFIG_MMC */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#ifdef CONFIG_MMC
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+	sw_mci_rescan_card(sdc_id, 0);
+#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
+	sunxi_mci_rescan_card(sdc_id, 0);
+#endif
+	mdelay(100);
+	wifi_pm_power(0);
+
+	RTW_INFO("%s: remove card, power off.\n", __FUNCTION__);
+#endif /* CONFIG_MMC */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNxI_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNxI_sdio.c
new file mode 100644
index 000000000000..795b7e7f7998
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNxI_sdio.c
@@ -0,0 +1,90 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+#ifdef CONFIG_WITS_EVB_V13
+	#define SDIOID	0
+#else /* !CONFIG_WITS_EVB_V13 */
+	#define SDIOID (CONFIG_CHIP_ID == 1123 ? 3 : 1)
+#endif /* !CONFIG_WITS_EVB_V13 */
+
+#define SUNXI_SDIO_WIFI_NUM_RTL8189ES  10
+extern void sunximmc_rescan_card(unsigned id, unsigned insert);
+extern int mmc_pm_get_mod_type(void);
+extern int mmc_pm_gpio_ctrl(char *name, int level);
+/*
+ *	rtl8189es_shdn	= port:PH09<1><default><default><0>
+ *	rtl8189es_wakeup	= port:PH10<1><default><default><1>
+ *	rtl8189es_vdd_en  = port:PH11<1><default><default><0>
+ *	rtl8189es_vcc_en  = port:PH12<1><default><default><0>
+ */
+
+int rtl8189es_sdio_powerup(void)
+{
+	mmc_pm_gpio_ctrl("rtl8189es_vdd_en", 1);
+	udelay(100);
+	mmc_pm_gpio_ctrl("rtl8189es_vcc_en", 1);
+	udelay(50);
+	mmc_pm_gpio_ctrl("rtl8189es_shdn", 1);
+	return 0;
+}
+
+int rtl8189es_sdio_poweroff(void)
+{
+	mmc_pm_gpio_ctrl("rtl8189es_shdn", 0);
+	mmc_pm_gpio_ctrl("rtl8189es_vcc_en", 0);
+	mmc_pm_gpio_ctrl("rtl8189es_vdd_en", 0);
+	return 0;
+}
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+	unsigned int mod_sel = mmc_pm_get_mod_type();
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+
+
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+	if (mod_sel == SUNXI_SDIO_WIFI_NUM_RTL8189ES) {
+		rtl8189es_sdio_powerup();
+		sunximmc_rescan_card(SDIOID, 1);
+		printk("[rtl8189es] %s: power up, rescan card.\n", __FUNCTION__);
+	} else {
+		ret = -1;
+		printk("[rtl8189es] %s: mod_sel = %d is incorrect.\n", __FUNCTION__, mod_sel);
+	}
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+	sunximmc_rescan_card(SDIOID, 0);
+#ifdef CONFIG_RTL8188E
+	rtl8189es_sdio_poweroff();
+	printk("[rtl8189es] %s: remove card, power off.\n", __FUNCTION__);
+#endif /* CONFIG_RTL8188E */
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNxI_usb.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNxI_usb.c
new file mode 100644
index 000000000000..9c2abc4f6f44
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_SUNxI_usb.c
@@ -0,0 +1,136 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 can be applied to following platforms:
+ *	CONFIG_PLATFORM_ARM_SUNXI Series platform
+ *
+ */
+
+#include <drv_types.h>
+#include <mach/sys_config.h>
+
+#ifdef CONFIG_PLATFORM_ARM_SUNxI
+extern int sw_usb_disable_hcd(__u32 usbc_no);
+extern int sw_usb_enable_hcd(__u32 usbc_no);
+static int usb_wifi_host = 2;
+#endif
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+extern int sw_usb_disable_hcd(__u32 usbc_no);
+extern int sw_usb_enable_hcd(__u32 usbc_no);
+extern void wifi_pm_power(int on);
+static script_item_u item;
+#endif
+
+#ifdef CONFIG_PLATFORM_ARM_SUN8I
+extern int sunxi_usb_disable_hcd(__u32 usbc_no);
+extern int sunxi_usb_enable_hcd(__u32 usbc_no);
+extern void wifi_pm_power(int on);
+static script_item_u item;
+#endif
+
+
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#ifdef CONFIG_PLATFORM_ARM_SUNxI
+#ifndef CONFIG_RTL8723A
+	{
+		/* ----------get usb_wifi_usbc_num------------- */
+		ret = script_parser_fetch("usb_wifi_para", "usb_wifi_usbc_num", (int *)&usb_wifi_host, 64);
+		if (ret != 0) {
+			RTW_INFO("ERR: script_parser_fetch usb_wifi_usbc_num failed\n");
+			ret = -ENOMEM;
+			goto exit;
+		}
+		RTW_INFO("sw_usb_enable_hcd: usbc_num = %d\n", usb_wifi_host);
+		sw_usb_enable_hcd(usb_wifi_host);
+	}
+#endif /* CONFIG_RTL8723A */
+#endif /* CONFIG_PLATFORM_ARM_SUNxI */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+	{
+		script_item_value_type_e type;
+
+		type = script_get_item("wifi_para", "wifi_usbc_id", &item);
+		if (SCIRPT_ITEM_VALUE_TYPE_INT != type) {
+			printk("ERR: script_get_item wifi_usbc_id failed\n");
+			ret = -ENOMEM;
+			goto exit;
+		}
+
+		printk("sw_usb_enable_hcd: usbc_num = %d\n", item.val);
+		wifi_pm_power(1);
+		mdelay(10);
+
+#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+		sw_usb_enable_hcd(item.val);
+#endif
+	}
+#endif /* defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I) */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN8I)
+	{
+		script_item_value_type_e type;
+
+		type = script_get_item("wifi_para", "wifi_usbc_id", &item);
+		if (SCIRPT_ITEM_VALUE_TYPE_INT != type) {
+			printk("ERR: script_get_item wifi_usbc_id failed\n");
+			ret = -ENOMEM;
+			goto exit;
+		}
+
+		printk("sw_usb_enable_hcd: usbc_num = %d\n", item.val);
+		wifi_pm_power(1);
+		mdelay(10);
+
+#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+		sunxi_usb_enable_hcd(item.val);
+#endif
+	}
+#endif /* CONFIG_PLATFORM_ARM_SUN8I */
+
+exit:
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+
+#ifdef CONFIG_PLATFORM_ARM_SUNxI
+#ifndef CONFIG_RTL8723A
+	RTW_INFO("sw_usb_disable_hcd: usbc_num = %d\n", usb_wifi_host);
+	sw_usb_disable_hcd(usb_wifi_host);
+#endif /* ifndef CONFIG_RTL8723A */
+#endif /* CONFIG_PLATFORM_ARM_SUNxI */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+	#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+	sw_usb_disable_hcd(item.val);
+	#endif
+	wifi_pm_power(0);
+#endif /* defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I) */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN8I)
+	#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+	sunxi_usb_disable_hcd(item.val);
+	#endif
+	wifi_pm_power(0);
+#endif /* defined(CONFIG_PLATFORM_ARM_SUN8I) */
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_WMT_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_WMT_sdio.c
new file mode 100644
index 000000000000..d85002c15fd3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ARM_WMT_sdio.c
@@ -0,0 +1,46 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 <mach/wmt_iomux.h>
+#include <linux/gpio.h>
+
+extern void wmt_detect_sdio2(void);
+extern void force_remove_sdio2(void);
+
+int platform_wifi_power_on(void)
+{
+	int err = 0;
+	err = gpio_request(WMT_PIN_GP62_SUSGPIO1, "wifi_chip_en");
+	if (err < 0) {
+		printk("request gpio for rtl8188eu failed!\n");
+		return err;
+	}
+	gpio_direction_output(WMT_PIN_GP62_SUSGPIO1, 0);/* pull sus_gpio1 to 0 to open vcc_wifi. */
+	printk("power on rtl8189.\n");
+	msleep(500);
+	wmt_detect_sdio2();
+	printk("[rtl8189es] %s: new card, power on.\n", __FUNCTION__);
+	return err;
+}
+
+void platform_wifi_power_off(void)
+{
+	force_remove_sdio2();
+
+	gpio_direction_output(WMT_PIN_GP62_SUSGPIO1, 1);/* pull sus_gpio1 to 1 to close vcc_wifi. */
+	printk("power off rtl8189.\n");
+	gpio_free(WMT_PIN_GP62_SUSGPIO1);
+	printk("[rtl8189es] %s: remove card, power off.\n", __FUNCTION__);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_RTK_DMP_usb.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_RTK_DMP_usb.c
new file mode 100644
index 000000000000..cb740b2eebb5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_RTK_DMP_usb.c
@@ -0,0 +1,30 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+	u32 tmp;
+	tmp = readl((volatile unsigned int *)0xb801a608);
+	tmp &= 0xffffff00;
+	tmp |= 0x55;
+	writel(tmp, (volatile unsigned int *)0xb801a608); /* write dummy register for 1055 */
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_aml_s905_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_aml_s905_sdio.c
new file mode 100644
index 000000000000..334ca03c9801
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_aml_s905_sdio.c
@@ -0,0 +1,54 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/printk.h>		/* pr_info(() */
+#include <linux/delay.h>		/* msleep() */
+#include "platform_aml_s905_sdio.h"	/* sdio_reinit() and etc */
+
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+	ret = wifi_setup_dt();
+	if (ret) {
+		pr_err("%s: setup dt failed!!(%d)\n", __func__, ret);
+		return -1;
+	}
+#endif /* kernel < 3.14.0 */
+
+#if 0 /* Seems redundancy? Already done before insert driver */
+	pr_info("######%s:\n", __func__);
+	extern_wifi_set_enable(0);
+	msleep(500);
+	extern_wifi_set_enable(1);
+	msleep(500);
+	sdio_reinit();
+#endif
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+	wifi_teardown_dt();
+#endif /* kernel < 3.14.0 */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_aml_s905_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_aml_s905_sdio.h
new file mode 100644
index 000000000000..2b87576dd629
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_aml_s905_sdio.h
@@ -0,0 +1,28 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_AML_S905_SDIO_H__
+#define __PLATFORM_AML_S905_SDIO_H__
+
+#include <linux/version.h>	/* Linux vresion */
+
+extern void sdio_reinit(void);
+extern void extern_wifi_set_enable(int is_on);
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+extern void wifi_teardown_dt(void);
+extern int wifi_setup_dt(void);
+#endif /* kernel < 3.14.0 */
+
+#endif /* __PLATFORM_AML_S905_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_arm_act_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_arm_act_sdio.c
new file mode 100644
index 000000000000..ad7b6cfed455
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_arm_act_sdio.c
@@ -0,0 +1,53 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 can be applied to following platforms:
+ *    CONFIG_PLATFORM_ACTIONS_ATM703X
+ */
+#include <drv_types.h>
+
+#ifdef CONFIG_PLATFORM_ACTIONS_ATM705X
+extern int acts_wifi_init(void);
+extern void acts_wifi_cleanup(void);
+#endif
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#ifdef CONFIG_PLATFORM_ACTIONS_ATM705X
+	ret = acts_wifi_init();
+	if (unlikely(ret < 0)) {
+		pr_err("%s Failed to register the power control driver.\n", __FUNCTION__);
+		goto exit;
+	}
+#endif
+
+exit:
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#ifdef CONFIG_PLATFORM_ACTIONS_ATM705X
+	acts_wifi_cleanup();
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_hisilicon_hi3798_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_hisilicon_hi3798_sdio.c
new file mode 100644
index 000000000000..11a08320ed82
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_hisilicon_hi3798_sdio.c
@@ -0,0 +1,110 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/delay.h>		/* mdelay() */
+#include <mach/hardware.h>		/* __io_address(), readl(), writel() */
+#include "platform_hisilicon_hi3798_sdio.h"	/* HI_S32() and etc. */
+
+typedef enum hi_GPIO_DIR_E {
+	HI_DIR_OUT = 0,
+	HI_DIR_IN  = 1,
+} HI_GPIO_DIR_E;
+
+#define RTL_REG_ON_GPIO		(4*8 + 3)
+
+#define REG_BASE_CTRL		__io_address(0xf8a20008)
+
+int gpio_wlan_reg_on = RTL_REG_ON_GPIO;
+#if 0
+module_param(gpio_wlan_reg_on, uint, 0644);
+MODULE_PARM_DESC(gpio_wlan_reg_on, "wlan reg_on gpio num (default:gpio4_3)");
+#endif
+
+static int hi_gpio_set_value(u32 gpio, u32 value)
+{
+	HI_S32 s32Status;
+
+	s32Status = HI_DRV_GPIO_SetDirBit(gpio, HI_DIR_OUT);
+	if (s32Status != HI_SUCCESS) {
+		pr_err("gpio(%d) HI_DRV_GPIO_SetDirBit HI_DIR_OUT failed\n",
+			gpio);
+		return -1;
+	}
+
+	s32Status = HI_DRV_GPIO_WriteBit(gpio, value);
+	if (s32Status != HI_SUCCESS) {
+		pr_err("gpio(%d) HI_DRV_GPIO_WriteBit value(%d) failed\n",
+			gpio, value);
+		return -1;
+	}
+
+	return 0;
+}
+
+static int hisi_wlan_set_carddetect(bool present)
+{
+	u32 regval;
+	u32 mask;
+
+
+#ifndef CONFIG_HISI_SDIO_ID
+	return;
+#endif
+	pr_info("SDIO ID=%d\n", CONFIG_HISI_SDIO_ID);
+#if (CONFIG_HISI_SDIO_ID == 1)
+	mask = 1;
+#elif (CONFIG_HISI_SDIO_ID == 0)
+	mask = 2;
+#endif
+
+	regval = readl(REG_BASE_CTRL);
+	if (present) {
+		pr_info("====== Card detection to detect SDIO card! ======\n");
+		/* set card_detect low to detect card */
+		regval |= mask;
+	} else {
+		pr_info("====== Card detection to remove SDIO card! ======\n");
+		/* set card_detect high to remove card */
+		regval &= ~(mask);
+	}
+	writel(regval, REG_BASE_CTRL);
+
+	return 0;
+}
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+
+	hi_gpio_set_value(gpio_wlan_reg_on, 1);
+	mdelay(100);
+	hisi_wlan_set_carddetect(1);
+	mdelay(2000);
+	pr_info("======== set_carddetect delay 2s! ========\n");
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	hisi_wlan_set_carddetect(0);
+	mdelay(100);
+	hi_gpio_set_value(gpio_wlan_reg_on, 0);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_hisilicon_hi3798_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_hisilicon_hi3798_sdio.h
new file mode 100644
index 000000000000..1ad42406f014
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_hisilicon_hi3798_sdio.h
@@ -0,0 +1,28 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_HISILICON_HI3798_SDIO_H__
+#define __PLATFORM_HISILICON_HI3798_SDIO_H__
+
+typedef unsigned int	HI_U32;
+
+typedef int		HI_S32;
+
+#define HI_SUCCESS	0
+#define HI_FAILURE	(-1)
+
+extern HI_S32 HI_DRV_GPIO_SetDirBit(HI_U32 u32GpioNo, HI_U32 u32DirBit);
+extern HI_S32 HI_DRV_GPIO_WriteBit(HI_U32 u32GpioNo, HI_U32 u32BitValue);
+
+#endif /* __PLATFORM_HISILICON_HI3798_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ops.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ops.c
new file mode 100644
index 000000000000..10766aad8e3b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ops.c
@@ -0,0 +1,32 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 CONFIG_PLATFORM_OPS
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+}
+#endif /* !CONFIG_PLATFORM_OPS */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ops.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ops.h
new file mode 100644
index 000000000000..12caf3c853a1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_ops.h
@@ -0,0 +1,26 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 __PLATFORM_OPS_H__
+#define __PLATFORM_OPS_H__
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void);
+void platform_wifi_power_off(void);
+
+#endif /* __PLATFORM_OPS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_sprd_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_sprd_sdio.c
new file mode 100644
index 000000000000..34061d05d428
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_sprd_sdio.c
@@ -0,0 +1,84 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+extern void sdhci_bus_scan(void);
+#ifndef ANDROID_2X
+extern int sdhci_device_attached(void);
+#endif
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+
+#ifdef CONFIG_RTL8188E
+	rtw_wifi_gpio_wlan_ctrl(WLAN_POWER_ON);
+#endif /* CONFIG_RTL8188E */
+
+	/* Pull up pwd pin, make wifi leave power down mode. */
+	rtw_wifi_gpio_init();
+	rtw_wifi_gpio_wlan_ctrl(WLAN_PWDN_ON);
+
+#if (MP_DRIVER == 1) && (defined(CONFIG_RTL8723A) || defined(CONFIG_RTL8723B))
+	/* Pull up BT reset pin. */
+	rtw_wifi_gpio_wlan_ctrl(WLAN_BT_PWDN_ON);
+#endif
+	rtw_mdelay_os(5);
+
+	sdhci_bus_scan();
+#ifdef CONFIG_RTL8723B
+	/* YJ,test,130305 */
+	rtw_mdelay_os(1000);
+#endif
+#ifdef ANDROID_2X
+	rtw_mdelay_os(200);
+#else /* !ANDROID_2X */
+	if (1) {
+		int i = 0;
+
+		for (i = 0; i <= 50; i++) {
+			msleep(10);
+			if (sdhci_device_attached())
+				break;
+			printk("%s delay times:%d\n", __func__, i);
+		}
+	}
+#endif /* !ANDROID_2X */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	/* Pull down pwd pin, make wifi enter power down mode. */
+	rtw_wifi_gpio_wlan_ctrl(WLAN_PWDN_OFF);
+	rtw_mdelay_os(5);
+	rtw_wifi_gpio_deinit();
+
+#ifdef CONFIG_RTL8188E
+	rtw_wifi_gpio_wlan_ctrl(WLAN_POWER_OFF);
+#endif /* CONFIG_RTL8188E */
+
+#ifdef CONFIG_WOWLAN
+	if (mmc_host)
+		mmc_host->pm_flags &= ~MMC_PM_KEEP_POWER;
+#endif /* CONFIG_WOWLAN */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_zte_zx296716_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_zte_zx296716_sdio.c
new file mode 100644
index 000000000000..472d24d8563c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_zte_zx296716_sdio.c
@@ -0,0 +1,53 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/printk.h>		/* pr_info(() */
+#include <linux/delay.h>		/* msleep() */
+#include "platform_zte_zx296716_sdio.h"	/* sdio_reinit() and etc */
+
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+	pr_info("######%s: disable--1--\n", __func__);
+	extern_wifi_set_enable(0);
+	/*msleep(500);*/ /* add in function:extern_wifi_set_enable */
+	pr_info("######%s: enable--2---\n", __func__);
+	extern_wifi_set_enable(1);
+	/*msleep(500);*/
+	sdio_reinit();
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	int card_val;
+
+	pr_info("######%s:\n", __func__);
+#ifdef CONFIG_A16T03_BOARD
+	card_val = sdio_host_is_null();
+	if (card_val)
+		remove_card();
+#endif /* CONFIG_A16T03_BOARD */
+	extern_wifi_set_enable(0);
+
+	/*msleep(500);*/
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_zte_zx296716_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_zte_zx296716_sdio.h
new file mode 100644
index 000000000000..3a4fba1a5743
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/platform/platform_zte_zx296716_sdio.h
@@ -0,0 +1,25 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_ZTE_ZX296716_SDIO_H__
+#define __PLATFORM_ZTE_ZX296716_SDIO_H__
+
+extern void sdio_reinit(void);
+extern void extern_wifi_set_enable(int val);
+#ifdef CONFIG_A16T03_BOARD
+extern int sdio_host_is_null(void);
+extern void remove_card(void);
+#endif /* CONFIG_A16T03_BOARD */
+
+#endif /* __PLATFORM_ZTE_ZX296716_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/rtl8822b.mk b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/rtl8822b.mk
new file mode 100644
index 000000000000..e9f556c99929
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/rtl8822b.mk
@@ -0,0 +1,83 @@
+EXTRA_CFLAGS += -DCONFIG_RTL8822B
+
+ifeq ($(CONFIG_MP_INCLUDED), y)
+### 8822B Default Enable VHT MP HW TX MODE ###
+#EXTRA_CFLAGS += -DCONFIG_MP_VHT_HW_TX_MODE
+#CONFIG_MP_VHT_HW_TX_MODE = y
+endif
+
+_HAL_HALMAC_FILES +=	hal/halmac/halmac_api.o
+
+_HAL_HALMAC_FILES +=	hal/halmac/halmac_88xx/halmac_bb_rf_88xx.o \
+			hal/halmac/halmac_88xx/halmac_cfg_wmac_88xx.o \
+			hal/halmac/halmac_88xx/halmac_common_88xx.o \
+			hal/halmac/halmac_88xx/halmac_efuse_88xx.o \
+			hal/halmac/halmac_88xx/halmac_flash_88xx.o \
+			hal/halmac/halmac_88xx/halmac_fw_88xx.o \
+			hal/halmac/halmac_88xx/halmac_gpio_88xx.o \
+			hal/halmac/halmac_88xx/halmac_init_88xx.o \
+			hal/halmac/halmac_88xx/halmac_mimo_88xx.o \
+			hal/halmac/halmac_88xx/halmac_pcie_88xx.o \
+			hal/halmac/halmac_88xx/halmac_sdio_88xx.o \
+			hal/halmac/halmac_88xx/halmac_usb_88xx.o
+
+_HAL_HALMAC_FILES +=	hal/halmac/halmac_88xx/halmac_8822b/halmac_cfg_wmac_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_common_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_gpio_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_init_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_pcie_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_phy_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_pwr_seq_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_sdio_8822b.o \
+			hal/halmac/halmac_88xx/halmac_8822b/halmac_usb_8822b.o
+
+_HAL_INTFS_FILES +=	hal/hal_halmac.o
+
+_HAL_INTFS_FILES +=	hal/rtl8822b/rtl8822b_halinit.o \
+			hal/rtl8822b/rtl8822b_mac.o \
+			hal/rtl8822b/rtl8822b_cmd.o \
+			hal/rtl8822b/rtl8822b_phy.o \
+			hal/rtl8822b/rtl8822b_ops.o \
+			hal/rtl8822b/hal8822b_fw.o
+
+ifeq ($(CONFIG_USB_HCI), y)
+_HAL_INTFS_FILES +=	hal/rtl8822b/$(HCI_NAME)/rtl8822bu_halinit.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bu_halmac.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bu_io.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bu_xmit.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bu_recv.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bu_led.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bu_ops.o
+
+_HAL_INTFS_FILES +=hal/efuse/rtl8822b/HalEfuseMask8822B_USB.o
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+_HAL_INTFS_FILES +=	hal/rtl8822b/$(HCI_NAME)/rtl8822be_halinit.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822be_halmac.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822be_io.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822be_xmit.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822be_recv.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822be_led.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822be_ops.o
+
+_HAL_INTFS_FILES +=hal/efuse/rtl8822b/HalEfuseMask8822B_PCIE.o
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+_HAL_INTFS_FILES +=	hal/rtl8822b/$(HCI_NAME)/rtl8822bs_halinit.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bs_halmac.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bs_io.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bs_xmit.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bs_recv.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bs_led.o \
+			hal/rtl8822b/$(HCI_NAME)/rtl8822bs_ops.o
+
+_HAL_INTFS_FILES +=hal/efuse/rtl8822b/HalEfuseMask8822B_SDIO.o
+endif
+
+_HAL_INTFS_FILES += $(_HAL_HALMAC_FILES)
+
+_BTC_FILES += hal/btc/halbtc8822bwifionly.o
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8822b1ant.o \
+				hal/btc/halbtc8822b2ant.o
+endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/runwpa b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/runwpa
new file mode 100644
index 000000000000..f825e8bdb123
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/runwpa
@@ -0,0 +1,20 @@
+#!/bin/bash
+
+if [ "`which iwconfig`" = "" ] ; then 
+	echo "WARNING:Wireless tool not exist!"
+	echo "        Please install it!"
+	exit
+else
+	if [ `uname -r | cut -d. -f2` -eq 4 ]; then
+		wpa_supplicant -D ipw -c wpa1.conf -i wlan0	
+	else
+	if [ `iwconfig -v |awk '{print $4}' | head -n 1` -lt  18 ] ; then
+		wpa_supplicant -D ipw -c wpa1.conf -i wlan0  
+	else	  
+		wpa_supplicant -D wext -c wpa1.conf -i wlan0 
+	fi
+
+	fi
+fi
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl88x2bu/wlan0dhcp b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/wlan0dhcp
new file mode 100644
index 000000000000..60433829cfe6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl88x2bu/wlan0dhcp
@@ -0,0 +1,16 @@
+#!/bin/bash
+
+var0=`ps aux|awk '/dhclient wlan0/'|awk '$11!="awk"{print $2}'`
+
+kill $var0
+cp ifcfg-wlan0 /etc/sysconfig/network-scripts/
+
+dhclient wlan0
+
+var1=`ifconfig wlan0 |awk '/inet/{print $2}'|awk -F: '{print $2}'`
+
+
+rm -f /etc/sysconfig/network-scripts/ifcfg-wlan0
+
+echo "get ip: $var1"
+
diff --git a/logo.bmp b/logo.bmp
index 6457146cfcc6..f90c2b97329f 100644
Binary files a/logo.bmp and b/logo.bmp differ
diff --git a/logo_kernel.bmp b/logo_kernel.bmp
index 191bcec3d963..c4013cf1578e 100644
Binary files a/logo_kernel.bmp and b/logo_kernel.bmp differ
diff --git a/scripts/gcc-wrapper.py b/scripts/gcc-wrapper.py
index f78df1d27a17..b995e6620c9f 100755
--- a/scripts/gcc-wrapper.py
+++ b/scripts/gcc-wrapper.py
@@ -95,7 +95,7 @@ def run_gcc():
         proc = subprocess.Popen(args, stderr=subprocess.PIPE, env=env)
         for line in proc.stderr:
             print (line.decode("utf-8"), end="")
-            interpret_warning(line.decode("utf-8"))
+            #interpret_warning(line.decode("utf-8"))
         if do_exit:
             sys.exit(1)
 

commit 59f9a0dee11b4a3751fd08fce69b6936d0623eb8
Author: Liang Chen <cl@rock-chips.com>
Date:   Tue Aug 27 16:37:39 2019 +0800

    arm64: dts: rockchip: rk3328: adjust opp-table for dmc
    
    Change-Id: I2d65e2f03519e3a98d9f9e0fe0bc10ae601237cf
    Signed-off-by: Liang Chen <cl@rock-chips.com>
    (cherry picked from commit 956d7ac8d14a73a16ca563aa806be6b0bff32c62)

diff --git a/arch/arm64/boot/dts/rockchip/rk3328.dtsi b/arch/arm64/boot/dts/rockchip/rk3328.dtsi
index 71dc6f114cc8..17c6a0940635 100644
--- a/arch/arm64/boot/dts/rockchip/rk3328.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3328.dtsi
@@ -1504,15 +1504,17 @@
 		};
 		opp-933000000 {
 			opp-hz = /bits/ 64 <933000000>;
-			opp-microvolt = <1100000>;
-			opp-microvolt-L0 = <1100000>;
-			opp-microvolt-L1 = <1075000>;
+			opp-microvolt = <1125000>;
+			opp-microvolt-L0 = <1125000>;
+			opp-microvolt-L1 = <1100000>;
 		};
+		/* 1066M is only for ddr4 */
 		opp-1066000000 {
 			opp-hz = /bits/ 64 <1066000000>;
 			opp-microvolt = <1175000>;
 			opp-microvolt-L0 = <1175000>;
 			opp-microvolt-L1 = <1150000>;
+			status = "disabled";
 		};
 	};
 

commit 3fafb42e657f22685fe540807a43f2306a82beeb
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Sat Aug 3 18:07:37 2019 +0800

    net: stmmac: never call stmmac_init_tx_coalesce from stmmac_resume
    
    stmmac_init_tx_coalesce will reinit timer when timer is running.
    
    Change-Id: I9db89510858f773a2681f0cd5da22526058a295f
    Signed-off-by: Tao Huang <huangtao@rock-chips.com>
    (cherry picked from commit 72cb0efd5933d337df720059d5143769192fe972)

diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
index ec453e07b316..91844836de35 100644
--- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
+++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
@@ -3138,7 +3138,6 @@ int stmmac_resume(struct device *dev)
 	stmmac_clear_descriptors(priv);
 
 	stmmac_hw_setup(ndev, false);
-	stmmac_init_tx_coalesce(priv);
 	stmmac_set_rx_mode(ndev);
 
 	napi_enable(&priv->napi);

commit 2ee3f55e07a017a9de59320ecd70149f96a2c86f
Author: Zhangbin Tong <zebulun.tong@rock-chips.com>
Date:   Fri Aug 9 11:10:18 2019 +0800

    arm64: rockchip_defconfig: enable CONFIG_ROCKCHIP_VENDOR_STORAGE_UPDATE_LOADER
    
    Change-Id: Id8fbca50a18f2044d95a9eadeecd0b3a32680890
    Signed-off-by: Zhangbin Tong <zebulun.tong@rock-chips.com>

diff --git a/arch/arm64/configs/rockchip_defconfig b/arch/arm64/configs/rockchip_defconfig
index d6aaf1274ed2..a8e16cab5e2c 100644
--- a/arch/arm64/configs/rockchip_defconfig
+++ b/arch/arm64/configs/rockchip_defconfig
@@ -734,6 +734,7 @@ CONFIG_ANDROID_VERSION=0x09000000
 CONFIG_ROCKCHIP_PM_DOMAINS=y
 CONFIG_ROCKCHIP_PVTM=y
 CONFIG_ROCKCHIP_SUSPEND_MODE=y
+CONFIG_ROCKCHIP_VENDOR_STORAGE_UPDATE_LOADER=y
 CONFIG_PM_DEVFREQ=y
 CONFIG_DEVFREQ_GOV_PERFORMANCE=y
 CONFIG_DEVFREQ_GOV_POWERSAVE=y

commit a4607654aa5baaf30bd0185610b1241641430a7e
Author: Shixiang Zheng <shixiang.zheng@rock-chips.com>
Date:   Wed Aug 7 08:51:37 2019 +0800

    scripts/bmpconvert: force the height of bmp to negative
    
    in this way logo can show normally in windows, and the uboot
    code can deal with the case of negative height.
    
    Change-Id: I5b1d84763a36be235b18a13651bba43a3fbd3005
    Signed-off-by: Shixiang Zheng <shixiang.zheng@rock-chips.com>
    (cherry picked from commit db61654129bc183853e0c26ad484acddb87d581b)
    Signed-off-by: Zhangbin Tong <zebulun.tong@rock-chips.com>

diff --git a/scripts/bmpconvert b/scripts/bmpconvert
index d660bb4c762e..9863444da093 100755
--- a/scripts/bmpconvert
+++ b/scripts/bmpconvert
@@ -62,9 +62,6 @@ class BMPFile:
         if self.bfReserved1 != 8399 and self.biHeight > 0:
             self.reverse_bmp_data()
             print("reverse data at first time")
-        if self.bfReserved1 != 8399:
-            self.rb_swap = 1
-            print("swap bgr to rgb at first time")
         if self.force_revers:
             self.reverse_bmp_data()
             print("reverse data by force")
@@ -254,11 +251,12 @@ class BMPFile:
         self.file.write(pack("<i", 54))  # bfOffBits
         self.file.write(pack("<i", 40))  # biSize
         self.file.write(pack("<i", self.biWidth))
-        # force height to positive for vop not support negative height
+        # force height to negative let logo show normal in windows
+        # the uboot code can deal with negative height
         if self.biHeight < 0:
-            self.file.write(pack("<i", self.biHeight * -1))
-        else:
             self.file.write(pack("<i", self.biHeight))
+        else:
+            self.file.write(pack("<i", self.biHeight * -1))
         self.file.write(pack("<h", self.biPlanes))
         self.file.write(pack("<h", 24))  # biBitCount
         self.file.write(pack("<i", 0))  # biCompression

commit ba0abcbb86fa1ef49e7ca76f45f3177ebcca4141
Author: Zhangbin Tong <zebulun.tong@rock-chips.com>
Date:   Fri Jul 19 08:27:02 2019 +0800

    Revert "FROMRKLIST: arm64: dts: rockchip: rk3328-android-avb: Reserve some DDR RAM for secure use"
    
    This reverts commit 1a9fbca4f3d18c402b99d85933d926c61b087107.

diff --git a/arch/arm64/boot/dts/rockchip/rk3328-box-liantong-avb.dts b/arch/arm64/boot/dts/rockchip/rk3328-box-liantong-avb.dts
index 7db4ad47028e..6b3e68bd2805 100644
--- a/arch/arm64/boot/dts/rockchip/rk3328-box-liantong-avb.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3328-box-liantong-avb.dts
@@ -30,11 +30,3 @@
 		};
 	};
 };
-
-&secure_memory {
-	/*
-	 * enable like this:
-	 * reg = <0x0 0x20000000 0x0 0x10000000>;
-	 */
-	reg = <0x0 0x20000000 0x0 0x10000000>;
-};
diff --git a/arch/arm64/boot/dts/rockchip/rk3328-evb-android-avb.dts b/arch/arm64/boot/dts/rockchip/rk3328-evb-android-avb.dts
index 59009ae9efa2..5e2eb30322f5 100644
--- a/arch/arm64/boot/dts/rockchip/rk3328-evb-android-avb.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3328-evb-android-avb.dts
@@ -30,11 +30,3 @@
 		};
 	};
 };
-
-&secure_memory {
-	/*
-	 * enable like this:
-	 * reg = <0x0 0x20000000 0x0 0x10000000>;
-	 */
-	reg = <0x0 0x20000000 0x0 0x10000000>;
-};
\ No newline at end of file
diff --git a/arch/arm64/boot/dts/rockchip/rk3328-rock64-android-avb.dts b/arch/arm64/boot/dts/rockchip/rk3328-rock64-android-avb.dts
index c3c82fe990a7..adc1dd7cd4da 100644
--- a/arch/arm64/boot/dts/rockchip/rk3328-rock64-android-avb.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3328-rock64-android-avb.dts
@@ -30,11 +30,3 @@
 		};
 	};
 };
-
-&secure_memory {
-	/*
-	 * enable like this:
-	 * reg = <0x0 0x20000000 0x0 0x10000000>;
-	 */
-	reg = <0x0 0x20000000 0x0 0x10000000>;
-};

commit f6957f32ff468b51d66fa498f52d8033d3eab2aa
Author: Algea Cao <algea.cao@rock-chips.com>
Date:   Tue Jul 9 09:10:04 2019 +0800

    drm/bridge: synopsys: dw-hdmi: Fix yuv422 display err
    
    When switching from another color to yuv422, neither
    encoder input color nor encoder output color is rgb.
    CSC coeff will be incorrectly selected as
    csc_coeff_full_to_limited, which causes the display
    turn to green. To solve this problem, choose
    csc_coeff_full_to_limited only if the input and output
    colors are both RGB.
    
    Change-Id: I080e18eb8fcca975cd0e6c46d2ed9e7513a26609
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>
    (cherry picked from commit 1992cb696610b0499275aba3287a8ec28c92e274)
    Signed-off-by: Zhangbin Tong <zebulun.tong@rock-chips.com>

diff --git a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
index 8fbc50cb3887..5195807f1f3d 100644
--- a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
+++ b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
@@ -1088,7 +1088,7 @@ static void dw_hdmi_update_csc_coeffs(struct dw_hdmi *hdmi)
 	enc_in_rgb = hdmi_bus_fmt_is_rgb(hdmi->hdmi_data.enc_in_bus_format);
 
 	if (is_color_space_conversion(hdmi)) {
-		if (enc_out_rgb == enc_in_rgb) {
+		if (enc_out_rgb && enc_in_rgb) {
 			csc_coeff = &csc_coeff_full_to_limited;
 			csc_scale = 0;
 		} else if (enc_out_rgb) {

commit a3aeca341b4803fff0867c48de3af58f766a5101
Author: Zhangbin Tong <zebulun.tong@rock-chips.com>
Date:   Fri Jul 12 08:12:59 2019 +0800

    Revert "drm: set wait_for_completion_timeout for commit clean up"
    
    This reverts commit 4cd2da42a7b08a891dcefbe14ea31506aa831328.
    
    Signed-off-by: Zhangbin Tong <zebulun.tong@rock-chips.com>

diff --git a/drivers/gpu/drm/drm_atomic_helper.c b/drivers/gpu/drm/drm_atomic_helper.c
index a30621abfee1..f77d4aa1e58b 100644
--- a/drivers/gpu/drm/drm_atomic_helper.c
+++ b/drivers/gpu/drm/drm_atomic_helper.c
@@ -1446,7 +1446,7 @@ void drm_atomic_helper_commit_cleanup_done(struct drm_atomic_state *state)
 		 * before releasing our reference, since the vblank work does
 		 * not hold a reference of its own. */
 		ret = wait_for_completion_timeout(&commit->flip_done,
-						  msecs_to_jiffies(100));
+						  10*HZ);
 		if (ret == 0)
 			DRM_ERROR("[CRTC:%d] flip_done timed out\n",
 				  crtc->base.id);

commit 481e85d2c811e88d67e0e15d5cb7cd93422bf9eb
Author: Zhangbin Tong <zebulun.tong@rock-chips.com>
Date:   Fri Jul 12 08:12:05 2019 +0800

    Revert "drm/rockchip: framebuffer: add rockchip_fbdev_blank"
    
    This reverts commit 2d36048f1c1f038938dc8e3f012dbf8c0e320d3c.
    
    Signed-off-by: Zhangbin Tong <zebulun.tong@rock-chips.com>

diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_fbdev.c b/drivers/gpu/drm/rockchip/rockchip_drm_fbdev.c
index a779826d30f4..c86ac833a9db 100644
--- a/drivers/gpu/drm/rockchip/rockchip_drm_fbdev.c
+++ b/drivers/gpu/drm/rockchip/rockchip_drm_fbdev.c
@@ -50,15 +50,6 @@ static struct dma_buf *rockchip_fbdev_get_dma_buf(struct fb_info *info)
 	return buf;
 }
 
-static int rockchip_fbdev_blank(int blank, struct fb_info *info)
-{
-	struct drm_fb_helper *helper = info->par;
-
-	drm_fb_helper_restore_fbdev_mode_unlocked(helper);
-
-	return drm_fb_helper_blank(blank, info);
-}
-
 static struct fb_ops rockchip_drm_fbdev_ops = {
 	.owner		= THIS_MODULE,
 	.fb_mmap	= rockchip_fbdev_mmap,
@@ -67,7 +58,7 @@ static struct fb_ops rockchip_drm_fbdev_ops = {
 	.fb_imageblit	= drm_fb_helper_cfb_imageblit,
 	.fb_check_var	= drm_fb_helper_check_var,
 	.fb_set_par	= drm_fb_helper_set_par,
-	.fb_blank	= rockchip_fbdev_blank,
+	.fb_blank	= drm_fb_helper_blank,
 	.fb_pan_display	= drm_fb_helper_pan_display,
 	.fb_read	= drm_fb_helper_sys_read,
 	.fb_write	= drm_fb_helper_sys_write,

commit d9c329165a9ca9f00e91f0b98ec13f6b6136417a
Author: Zhangbin Tong <zebulun.tong@rock-chips.com>
Date:   Tue Jul 9 15:31:04 2019 +0800

    Revert "bluetooth: rfkill-bt: fix bt irq cannot wake host."
    
    This reverts commit 5f582e90ef69cfda3266cd68f619381eb05ae6c3.
    
    Signed-off-by: Zhangbin Tong <zebulun.tong@rock-chips.com>

diff --git a/net/rfkill/rfkill-bt.c b/net/rfkill/rfkill-bt.c
index d74e03574da4..29d88313e4a8 100644
--- a/net/rfkill/rfkill-bt.c
+++ b/net/rfkill/rfkill-bt.c
@@ -264,6 +264,7 @@ int rfkill_get_bt_power_state(int *power, bool *toggle)
 static int rfkill_rk_set_power(void *data, bool blocked)
 {
 	struct rfkill_rk_data *rfkill = data;
+	struct rfkill_rk_gpio *wake_host = &rfkill->pdata->wake_host_irq.gpio;
     struct rfkill_rk_gpio *poweron = &rfkill->pdata->poweron_gpio;
     struct rfkill_rk_gpio *reset = &rfkill->pdata->reset_gpio;
     struct rfkill_rk_gpio* rts = &rfkill->pdata->rts_gpio;
@@ -289,13 +290,20 @@ static int rfkill_rk_set_power(void *data, bool blocked)
 	if (false == blocked) { 
 
         rfkill_rk_sleep_bt(BT_WAKEUP); // ensure bt is wakeup
+	if (gpio_is_valid(wake_host->io)) {
+		LOG("%s: set bt wake_host pin output high!\n", __func__);
+		gpio_direction_output(wake_host->io, 1);
+		msleep(20);
+	}
 
-	if (gpio_is_valid(poweron->io)) {
+	if (gpio_is_valid(poweron->io) && gpio_is_valid(wake_host->io)) {
 		if (gpio_get_value(poweron->io) == !poweron->enable) {
 			gpio_direction_output(poweron->io, !poweron->enable);
 			msleep(20);
 			gpio_direction_output(poweron->io, poweron->enable);
 			msleep(20);
+			gpio_direction_input(wake_host->io);
+			LOG("%s: set bt wake_host pin input!\n", __func__);
 		}
         }
 

commit cf15108ebbf3d6fe66852ee42ae367eaef262bdc
Merge: a15984754717 79bca8aa2a68
Author: Zhangbin Tong <zebulun.tong@rock-chips.com>
Date:   Tue Jul 2 15:00:42 2019 +0800

    Merge branch 'develop-4.4' into stable-4.4-rk3328-box-9.0
    
    Signed-off-by: Zhangbin Tong <zebulun.tong@rock-chips.com>
    
    Conflicts:
            arch/arm64/Makefile
            arch/arm64/boot/dts/rockchip/rk3328-android.dtsi
            arch/arm64/boot/dts/rockchip/rk3328-rock64.dts
            arch/arm64/boot/dts/rockchip/rk3399-rockpro64.dts
            drivers/cpufreq/cpufreq-dt.c
            drivers/gpu/arm/midgard/backend/gpu/mali_kbase_devfreq.c
            drivers/gpu/arm/midgard_for_linux/backend/gpu/mali_kbase_devfreq.c
            drivers/gpu/arm/midgard_for_linux/mali_kbase_core_linux.c
            drivers/gpu/arm/midgard_for_linux/mali_kbase_mem.c
            drivers/gpu/arm/midgard_for_linux/mali_kbase_mem_linux.c
            drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
            drivers/soc/rockchip/Kconfig
            drivers/soc/rockchip/rockchip_ipa.c
            include/soc/rockchip/rockchip_ipa.h
            logo.bmp
    
    Change-Id: I05af689863c50934c359d7269c14db8923a19e05

commit 79bca8aa2a68fdbebbd8bd4f5bab79739c3d35c1
Author: Sandy Huang <hjc@rock-chips.com>
Date:   Fri May 10 10:46:35 2019 +0800

    drm/rockchip: csi tx: add yuv422 8bit format support
    
    Change-Id: Ied49010c2cee137e66783237af863e5b6946186d
    Signed-off-by: Sandy Huang <hjc@rock-chips.com>

diff --git a/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.c b/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.c
index 74e700cb7e63..137c4470208e 100644
--- a/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.c
+++ b/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.c
@@ -449,6 +449,7 @@ static inline int mipi_csi_pixel_format_to_bpp(int fmt)
 {
 	switch (fmt) {
 	case MIPI_CSI_FMT_RAW8:
+	case MIPI_CSI_FMT_YUV422_8BIT:
 		return 8;
 	case MIPI_CSI_FMT_RAW10:
 		return 10;
@@ -603,6 +604,10 @@ static void rockchip_mipi_csi_path_config(struct rockchip_mipi_csi *csi)
 		vop_wc = csi->mode.hdisplay * 5 / 4;
 		data_type = 0x2b;
 		break;
+	case MIPI_CSI_FMT_YUV422_8BIT:
+		vop_wc = csi->mode.hdisplay;
+		data_type = 0x1e;
+		break;
 	default:
 		vop_wc = csi->mode.hdisplay;
 		data_type = 0x2a;
@@ -907,6 +912,7 @@ rockchip_mipi_csi_encoder_atomic_check(struct drm_encoder *encoder,
 
 	switch (csi->format) {
 	case MIPI_CSI_FMT_RAW8:
+	case MIPI_CSI_FMT_YUV422_8BIT:
 		s->output_mode = ROCKCHIP_OUT_MODE_P888;
 		break;
 	case MIPI_CSI_FMT_RAW10:
diff --git a/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.h b/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.h
index a4330df85b33..15516e0a61b3 100644
--- a/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.h
+++ b/drivers/gpu/drm/rockchip/rockchip-mipi-csi-tx.h
@@ -194,6 +194,8 @@ enum CONFIG_DONE_MODE {
 
 #define MIPI_CSI_FMT_RAW8		0x10
 #define MIPI_CSI_FMT_RAW10		0x11
+#define MIPI_CSI_FMT_YUV420_8BIT	0x12
+#define MIPI_CSI_FMT_YUV422_8BIT	0x13
 
 #define PHY_STATUS_TIMEOUT_US		10000
 #define CMD_PKT_STATUS_TIMEOUT_US	20000
diff --git a/include/dt-bindings/display/drm_mipi_dsi.h b/include/dt-bindings/display/drm_mipi_dsi.h
index bc24ce4ddd08..9356331a44ce 100644
--- a/include/dt-bindings/display/drm_mipi_dsi.h
+++ b/include/dt-bindings/display/drm_mipi_dsi.h
@@ -49,5 +49,7 @@
 
 #define MIPI_CSI_FMT_RAW8		0x10
 #define MIPI_CSI_FMT_RAW10		0x11
+#define MIPI_CSI_FMT_YUV420_8BIT	0x12
+#define MIPI_CSI_FMT_YUV422_8BIT	0x13
 
 #endif /* __DRM_MIPI_DSI__ */

commit 77ec271b9f697326c567e64713e3d8c91b05e1ba
Author: Weixin Zhou <zwx@rock-chips.com>
Date:   Fri Jun 28 17:40:20 2019 +0800

    arm64: dts: rockchip: rk3399pro-evb-v13-multi-cam-avb: for multi camera board
    
    Change-Id: I8a5a6cbb2b3f6d34c571df73a85b97cbaced3909
    Signed-off-by: Weixin Zhou <zwx@rock-chips.com>

diff --git a/Documentation/devicetree/bindings/arm/rockchip.txt b/Documentation/devicetree/bindings/arm/rockchip.txt
index 5b509c18599d..3ede2e8192ae 100644
--- a/Documentation/devicetree/bindings/arm/rockchip.txt
+++ b/Documentation/devicetree/bindings/arm/rockchip.txt
@@ -128,14 +128,14 @@ Rockchip platforms device tree bindings
       - compatible = "rockchip,rk3399pro-evb-v10", "rockchip,rk3399pro";
       - compatible = "rockchip,rk3399pro-evb-v10-linux", "rockchip,rk3399pro";
       - compatible = "rockchip,rk3399pro-evb-v11-linux", "rockchip,rk3399pro";
+      - compatible = "rockchip,rk3399pro-evb-v13-multi-cam", "rockchip,rk3399pro";
 
 - Rockchip RK3399pro evb avb:
     Required root node properties:
       - compatible = "rockchip,rk3399pro-evb-v10-avb", "rockchip,rk3399pro";
       - compatible = "rockchip,rk3399pro-evb-v11-avb", "rockchip,rk3399pro";
       - compatible = "rockchip,rk3399pro-evb-lp4-v11-avb", "rockchip,rk3399pro";
-      - compatible = "rockchip,rk3399pro-evb-v11-multi-cam-avb", "rockchip,rk3399pro";
-      - compatible = "rockchip,rk3399pro-evb-v13-multi-cam", "rockchip,rk3399pro";
+      - compatible = "rockchip,rk3399pro-evb-v13-multi-cam-avb", "rockchip,rk3399pro";
 
 - Rockchip RK3326 f863 board:
     Required root node properties:
diff --git a/arch/arm64/boot/dts/rockchip/Makefile b/arch/arm64/boot/dts/rockchip/Makefile
index 41f10b33278e..d4836787973b 100644
--- a/arch/arm64/boot/dts/rockchip/Makefile
+++ b/arch/arm64/boot/dts/rockchip/Makefile
@@ -119,7 +119,7 @@ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v10-linux.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11-avb.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11-linux.dtb
-dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11-multi-cam-avb.dtb
+dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v13-multi-cam-avb.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v13-multi-cam.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-npu-evb-v10.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-npu-evb-v10-multi-cam.dtb
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-multi-cam-avb.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-multi-cam-avb.dts
deleted file mode 100644
index 727cf46e5bce..000000000000
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-multi-cam-avb.dts
+++ /dev/null
@@ -1,17 +0,0 @@
-// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
-/*
- * Copyright (c) 2018 Fuzhou Rockchip Electronics Co., Ltd
- *
- */
-
-/dts-v1/;
-#include "rk3399pro-evb-v11-avb.dts"
-
-/ {
-	model = "Rockchip RK3399pro evb v11 multi camera avb board";
-	compatible = "rockchip,rk3399pro-evb-v11-multi-cam-avb", "rockchip,rk3399pro";
-};
-
-&pcie0 {
-	/delete-property/ ep-gpios;
-};
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v13-multi-cam-avb.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v13-multi-cam-avb.dts
new file mode 100644
index 000000000000..1d333a93af32
--- /dev/null
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v13-multi-cam-avb.dts
@@ -0,0 +1,35 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Fuzhou Rockchip Electronics Co., Ltd
+ *
+ */
+
+/dts-v1/;
+#include "rk3399pro-evb-v11-avb.dts"
+
+/ {
+	model = "Rockchip RK3399pro evb v13 multi camera avb board";
+	compatible = "rockchip,rk3399pro-evb-v13-multi-cam-avb", "rockchip,rk3399pro";
+
+	dma_trans: dma_trans@3c000000 {
+		//no-map;
+		reg = <0x0 0x3c000000 0x0 0x04000000>;
+	};
+};
+
+&pcie_phy {
+	status = "okay";
+};
+
+&pcie0 {
+	/delete-property/ ep-gpios;
+	num-lanes = <4>;
+	pinctrl-names = "default";
+	pinctrl-0 = <&pcie_clkreqn_cpm>;
+	max-link-speed = <2>;
+	memory-region = <&dma_trans>;
+	busno = <0>;
+	rockchip,dma_trx_enabled = <1>;
+	rockchip,deferred = <1>;
+	status = "okay";
+};

commit d550e0e6147b80240a414e734c5b214e3830334b
Author: Liang Chen <cl@rock-chips.com>
Date:   Fri Jun 28 17:41:07 2019 +0800

    arm64: dts: rockchip: initial voltage of vdd_npu to 0.88V for rk3399pro boards
    
    The max voltage of vdd_npu is 0.88V.
    
    Change-Id: I182f0262ac0f3b208a37bc25930659d82c7ba584
    Signed-off-by: Liang Chen <cl@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
index 419a5f684e6a..30a9b52c47ea 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
@@ -207,6 +207,7 @@
 		regulator-name = "vdd_npu";
 		regulator-min-microvolt = <750000>;
 		regulator-max-microvolt = <880000>;
+		regulator-init-microvolt = <880000>;
 		regulator-ramp-delay = <2300>;
 		fcs,suspend-voltage-selector = <1>;
 		regulator-always-on;
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
index 7490ce2a2f43..9fe514e81aa6 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
@@ -82,6 +82,7 @@
 		regulator-name = "vdd_npu";
 		regulator-min-microvolt = <750000>;
 		regulator-max-microvolt = <880000>;
+		regulator-init-microvolt = <880000>;
 		regulator-ramp-delay = <2300>;
 		fcs,suspend-voltage-selector = <1>;
 		regulator-always-on;

commit 55b8a53c7ae7cab1ae9be9018e882a07699adb4b
Author: Liang Chen <cl@rock-chips.com>
Date:   Fri Jun 28 17:31:02 2019 +0800

    arm64: dts: rockchip: initial voltage of vdd_npu to 0.88V for rk1808 boards
    
    The max voltage of vdd_npu is 0.88V.
    
    Change-Id: I5f1ec522734e48b6a9443b48692690410c020167
    Signed-off-by: Liang Chen <cl@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi b/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi
index 1a600b2a3918..f9ec2d1cedb5 100644
--- a/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi
@@ -43,6 +43,7 @@
 			regulator-name = "vdd_npu";
 			regulator-min-microvolt = <750000>;
 			regulator-max-microvolt = <880000>;
+			regulator-init-microvolt = <880000>;
 			regulator-ramp-delay = <2300>;
 			fcs,suspend-voltage-selector = <0>;
 			regulator-boot-on;
diff --git a/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi b/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi
index 4ae1c2c3a1e2..d3eb4ca6b78c 100644
--- a/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi
@@ -278,6 +278,7 @@
 		regulator-name = "vdd_npu";
 		regulator-min-microvolt = <750000>;
 		regulator-max-microvolt = <880000>;
+		regulator-init-microvolt = <880000>;
 		regulator-ramp-delay = <2300>;
 		fcs,suspend-voltage-selector = <0>;
 		regulator-boot-on;

commit f6ffcfd8636a30c636d5a84d4cd9b75bbba84a49
Author: Lin Huang <hl@rock-chips.com>
Date:   Thu Jun 27 17:44:51 2019 +0800

    ARM64: configs: rk1808_linux_defconfig: enable usb ethernet config
    
    Change-Id: I23d1f7b687e366cf729dab45930af497ead5b5ee
    Signed-off-by: Lin Huang <hl@rock-chips.com>

diff --git a/arch/arm64/configs/rk1808_linux_defconfig b/arch/arm64/configs/rk1808_linux_defconfig
index 15dc801b85ae..789f4852baf0 100644
--- a/arch/arm64/configs/rk1808_linux_defconfig
+++ b/arch/arm64/configs/rk1808_linux_defconfig
@@ -154,6 +154,14 @@ CONFIG_STMMAC_ETH=y
 # CONFIG_NET_VENDOR_VIA is not set
 # CONFIG_NET_VENDOR_WIZNET is not set
 CONFIG_ROCKCHIP_PHY=y
+CONFIG_USB_RTL8150=y
+CONFIG_USB_RTL8152=y
+CONFIG_USB_NET_CDC_MBIM=y
+# CONFIG_USB_NET_NET1080 is not set
+# CONFIG_USB_NET_CDC_SUBSET is not set
+# CONFIG_USB_NET_ZAURUS is not set
+CONFIG_LIBERTAS_THINFIRM=y
+CONFIG_USB_NET_RNDIS_WLAN=y
 CONFIG_WL_ROCKCHIP=y
 CONFIG_WIFI_BUILD_MODULE=y
 CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP=y

commit ca537f043047f2c980268816166dda0723e23e78
Author: Caesar Wang <wxt@rock-chips.com>
Date:   Fri Jun 28 10:48:38 2019 +0800

    arm64: config: add CONFIG_PINCTRL_RK805 for rockchip_linux_defconfig
    
    The Linux SDK have a common issue with rk809/rk805/rk817..etc, the
    regulator can't be disabled during suspending since the linux config
    hadn't enable the CONFIG_PINCTRL_RK805 pinctrl for PMIC.
    
    This config include the rk805/rk809/rk809..pinctrl to control for
    pmic. So the related config need be enabled by default.
    
    Change-Id: I284976df9d9d95d8a0104ba96a27464883c8b8e1
    Signed-off-by: Caesar Wang <wxt@rock-chips.com>

diff --git a/arch/arm64/configs/px30_linux_defconfig b/arch/arm64/configs/px30_linux_defconfig
index 8c51ca9c7036..180e81bb6d71 100644
--- a/arch/arm64/configs/px30_linux_defconfig
+++ b/arch/arm64/configs/px30_linux_defconfig
@@ -197,6 +197,7 @@ CONFIG_SPI=y
 CONFIG_SPI_BITBANG=y
 CONFIG_SPI_ROCKCHIP=y
 CONFIG_SPI_SPIDEV=y
+CONFIG_PINCTRL_RK805=y
 CONFIG_DEBUG_GPIO=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_GPIO_GENERIC_PLATFORM=y
diff --git a/arch/arm64/configs/px30_linux_robot_defconfig b/arch/arm64/configs/px30_linux_robot_defconfig
index 153d4c2424d5..b9231764959b 100644
--- a/arch/arm64/configs/px30_linux_robot_defconfig
+++ b/arch/arm64/configs/px30_linux_robot_defconfig
@@ -141,6 +141,7 @@ CONFIG_SPI_BITBANG=y
 CONFIG_SPI_ROCKCHIP=y
 CONFIG_SPI_SPIDEV=y
 CONFIG_PTP_1588_CLOCK=y
+CONFIG_PINCTRL_RK805=y
 CONFIG_DEBUG_GPIO=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_GPIO_GENERIC_PLATFORM=y
diff --git a/arch/arm64/configs/rk1808_x4_linux_defconfig b/arch/arm64/configs/rk1808_x4_linux_defconfig
index ae1b1d065d1c..5daece1620d9 100644
--- a/arch/arm64/configs/rk1808_x4_linux_defconfig
+++ b/arch/arm64/configs/rk1808_x4_linux_defconfig
@@ -98,6 +98,7 @@ CONFIG_SERIAL_8250_DW=y
 CONFIG_HW_RANDOM=y
 CONFIG_HW_RANDOM_ROCKCHIP=y
 CONFIG_I2C_RK3X=y
+CONFIG_PINCTRL_RK805=y
 CONFIG_DEBUG_GPIO=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_POWER_AVS=y
diff --git a/arch/arm64/configs/rk3326_linux_defconfig b/arch/arm64/configs/rk3326_linux_defconfig
index ec3cb91bdc72..1c49279fa793 100644
--- a/arch/arm64/configs/rk3326_linux_defconfig
+++ b/arch/arm64/configs/rk3326_linux_defconfig
@@ -178,6 +178,7 @@ CONFIG_SPI_BITBANG=y
 CONFIG_SPI_ROCKCHIP=y
 CONFIG_SPI_SPIDEV=y
 CONFIG_PTP_1588_CLOCK=y
+CONFIG_PINCTRL_RK805=y
 CONFIG_DEBUG_GPIO=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_GPIO_GENERIC_PLATFORM=y
diff --git a/arch/arm64/configs/rk3326_linux_robot_defconfig b/arch/arm64/configs/rk3326_linux_robot_defconfig
index 0876e951258e..43cab4ca8846 100644
--- a/arch/arm64/configs/rk3326_linux_robot_defconfig
+++ b/arch/arm64/configs/rk3326_linux_robot_defconfig
@@ -141,6 +141,7 @@ CONFIG_SPI_BITBANG=y
 CONFIG_SPI_ROCKCHIP=y
 CONFIG_SPI_SPIDEV=y
 CONFIG_PTP_1588_CLOCK=y
+CONFIG_PINCTRL_RK805=y
 CONFIG_DEBUG_GPIO=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_GPIO_GENERIC_PLATFORM=y
diff --git a/arch/arm64/configs/rockchip_linux_defconfig b/arch/arm64/configs/rockchip_linux_defconfig
index ad72e09a6940..c1569990ca2b 100644
--- a/arch/arm64/configs/rockchip_linux_defconfig
+++ b/arch/arm64/configs/rockchip_linux_defconfig
@@ -235,6 +235,7 @@ CONFIG_SPI=y
 CONFIG_SPI_BITBANG=y
 CONFIG_SPI_ROCKCHIP=y
 CONFIG_SPI_SPIDEV=y
+CONFIG_PINCTRL_RK805=y
 CONFIG_DEBUG_GPIO=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_GPIO_GENERIC_PLATFORM=y

commit 2312882d4f46c6c0a4e52b8e0af4464382c60d12
Author: Finley Xiao <finley.xiao@rock-chips.com>
Date:   Thu May 30 11:42:11 2019 +0800

    MALI: utgard: Add private data for governor
    
    This adds support to get simple_ondemand governor data from devicetree.
    
    Change-Id: Ic897ad6227152c4ce695d6cee8085b4d303339bf
    Signed-off-by: Finley Xiao <finley.xiao@rock-chips.com>

diff --git a/drivers/gpu/arm/mali400/mali/linux/mali_devfreq.c b/drivers/gpu/arm/mali400/mali/linux/mali_devfreq.c
index d96841a197cc..306f6ab79659 100644
--- a/drivers/gpu/arm/mali400/mali/linux/mali_devfreq.c
+++ b/drivers/gpu/arm/mali400/mali/linux/mali_devfreq.c
@@ -45,6 +45,8 @@ static struct monitor_dev_profile mali_mdevp = {
 	.high_temp_adjust = rockchip_monitor_dev_high_temp_adjust,
 };
 
+static struct devfreq_simple_ondemand_data ondemand_data;
+
 static int
 mali_devfreq_target(struct device *dev, unsigned long *target_freq, u32 flags)
 {
@@ -232,6 +234,7 @@ static void mali_devfreq_exit(struct device *dev)
 
 int mali_devfreq_init(struct mali_device *mdev)
 {
+	struct device_node *np = mdev->dev->of_node;
 #ifdef CONFIG_DEVFREQ_THERMAL
 	struct devfreq_cooling_power *callbacks = NULL;
 	_mali_osk_device_data data;
@@ -259,8 +262,13 @@ int mali_devfreq_init(struct mali_device *mdev)
 	if (mali_devfreq_init_freq_table(mdev, dp))
 		return -EFAULT;
 
+	of_property_read_u32(np, "upthreshold",
+			     &ondemand_data.upthreshold);
+	of_property_read_u32(np, "downdifferential",
+			     &ondemand_data.downdifferential);
+
 	mdev->devfreq = devfreq_add_device(mdev->dev, dp,
-					   "simple_ondemand", NULL);
+					   "simple_ondemand", &ondemand_data);
 	if (IS_ERR(mdev->devfreq)) {
 		mali_devfreq_term_freq_table(mdev);
 		return PTR_ERR(mdev->devfreq);

commit 8412825f2e52fb422b3353af8fec6ea873c8a44a
Author: Liang Chen <cl@rock-chips.com>
Date:   Thu Jun 27 21:21:12 2019 +0800

    arm64: dts: rockchip: limit vdd_npu to 0.88V for rk3399pro evaluation boards
    
    Change-Id: I93b5e13291e52270ca79a625e968d7b34cd5985c
    Signed-off-by: Liang Chen <cl@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
index 6d94385ec575..419a5f684e6a 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
@@ -206,7 +206,7 @@
 		vsel-gpios = <&gpio0 RK_PC6 GPIO_ACTIVE_HIGH>;
 		regulator-name = "vdd_npu";
 		regulator-min-microvolt = <750000>;
-		regulator-max-microvolt = <800000>;
+		regulator-max-microvolt = <880000>;
 		regulator-ramp-delay = <2300>;
 		fcs,suspend-voltage-selector = <1>;
 		regulator-always-on;
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
index 44d39a95a812..7490ce2a2f43 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
@@ -81,7 +81,7 @@
 		vsel-gpios = <&gpio0 RK_PC6 GPIO_ACTIVE_HIGH>;
 		regulator-name = "vdd_npu";
 		regulator-min-microvolt = <750000>;
-		regulator-max-microvolt = <800000>;
+		regulator-max-microvolt = <880000>;
 		regulator-ramp-delay = <2300>;
 		fcs,suspend-voltage-selector = <1>;
 		regulator-always-on;

commit 3619f7b10d16d2aa05025975242772042595124e
Author: Liang Chen <cl@rock-chips.com>
Date:   Thu Jun 27 21:19:39 2019 +0800

    arm64: dts: rockchip: limit vdd_npu to 0.88V for rk3399pro-npu
    
    The recommended max voltage of vdd_npu is 0.88V in the datasheet.
    
    Change-Id: I9713810692c5d32b8c41b0b0e0d02405c01dd0b7
    Signed-off-by: Liang Chen <cl@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi b/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi
index 22b1557accc3..11fa2340e858 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi
@@ -999,7 +999,7 @@
 	npu_opp_table: npu-opp-table {
 		compatible = "operating-points-v2";
 
-		rockchip,max-volt = <950000>;
+		rockchip,max-volt = <880000>;
 		rockchip,evb-irdrop = <37500>;
 
 		rockchip,pvtm-voltage-sel = <
@@ -1022,26 +1022,26 @@
 
 		opp-200000000 {
 			opp-hz = /bits/ 64 <200000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-297000000 {
 			opp-hz = /bits/ 64 <297000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-400000000 {
 			opp-hz = /bits/ 64 <400000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-594000000 {
 			opp-hz = /bits/ 64 <594000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-792000000 {
 			opp-hz = /bits/ 64 <792000000>;
-			opp-microvolt = <825000 825000 950000>;
-			opp-microvolt-L0 = <825000 825000 950000>;
-			opp-microvolt-L1 = <800000 800000 950000>;
-			opp-microvolt-L2 = <775000 775000 950000>;
+			opp-microvolt = <825000 825000 880000>;
+			opp-microvolt-L0 = <825000 825000 880000>;
+			opp-microvolt-L1 = <800000 800000 880000>;
+			opp-microvolt-L2 = <775000 775000 880000>;
 		};
 	};
 

commit 71d6828ea2996ee08447085da40f0caf859e0c47
Author: Liang Chen <cl@rock-chips.com>
Date:   Thu Jun 27 21:08:07 2019 +0800

    arm64: dts: rockchip: limit vdd_npu to 0.88V for rk1808 boards
    
    Change-Id: I4475ab82bf5f7f05c1b7bcccadf6f37151bd6412
    Signed-off-by: Liang Chen <cl@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi b/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi
index 26a041bf1eb4..1a600b2a3918 100644
--- a/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk1808-compute.dtsi
@@ -42,7 +42,7 @@
 			vsel-gpios = <&gpio0 5 GPIO_ACTIVE_HIGH>;
 			regulator-name = "vdd_npu";
 			regulator-min-microvolt = <750000>;
-			regulator-max-microvolt = <950000>;
+			regulator-max-microvolt = <880000>;
 			regulator-ramp-delay = <2300>;
 			fcs,suspend-voltage-selector = <0>;
 			regulator-boot-on;
diff --git a/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi b/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi
index cfe7f84bbaa8..4ae1c2c3a1e2 100644
--- a/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk1808-evb.dtsi
@@ -277,7 +277,7 @@
 		vsel-gpios = <&gpio0 5 GPIO_ACTIVE_HIGH>;
 		regulator-name = "vdd_npu";
 		regulator-min-microvolt = <750000>;
-		regulator-max-microvolt = <950000>;
+		regulator-max-microvolt = <880000>;
 		regulator-ramp-delay = <2300>;
 		fcs,suspend-voltage-selector = <0>;
 		regulator-boot-on;

commit 864bbd1197387c0df68011014e85ef4d29e430c8
Author: Liang Chen <cl@rock-chips.com>
Date:   Wed Jun 26 16:22:39 2019 +0800

    arm64: dts: rockchip: limit vdd_npu to 0.88V for rk1808 SoCs
    
    The recommended max voltage of vdd_npu is 0.88V in the datasheet.
    
    Change-Id: Id29b97b82ea35f3db03140ebdd8bab85e3f375df
    Signed-off-by: Liang Chen <cl@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk1808.dtsi b/arch/arm64/boot/dts/rockchip/rk1808.dtsi
index bb5ec66ce28a..209004b53616 100644
--- a/arch/arm64/boot/dts/rockchip/rk1808.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk1808.dtsi
@@ -1717,7 +1717,7 @@
 			   0      792   50000
 		>;
 
-		rockchip,max-volt = <950000>;
+		rockchip,max-volt = <880000>;
 		rockchip,evb-irdrop = <37500>;
 		nvmem-cells = <&npu_leakage>;
 		nvmem-cell-names = "leakage";
@@ -1731,26 +1731,26 @@
 
 		opp-200000000 {
 			opp-hz = /bits/ 64 <200000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-297000000 {
 			opp-hz = /bits/ 64 <297000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-400000000 {
 			opp-hz = /bits/ 64 <400000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-594000000 {
 			opp-hz = /bits/ 64 <594000000>;
-			opp-microvolt = <750000 750000 950000>;
+			opp-microvolt = <750000 750000 880000>;
 		};
 		opp-792000000 {
 			opp-hz = /bits/ 64 <792000000>;
-			opp-microvolt = <825000 825000 950000>;
-			opp-microvolt-L0 = <825000 825000 950000>;
-			opp-microvolt-L1 = <800000 800000 950000>;
-			opp-microvolt-L2 = <775000 775000 950000>;
+			opp-microvolt = <825000 825000 880000>;
+			opp-microvolt-L0 = <825000 825000 880000>;
+			opp-microvolt-L1 = <800000 800000 880000>;
+			opp-microvolt-L2 = <775000 775000 880000>;
 		};
 	};
 

commit cf626b1c4bb8957c1d212278f6ed8bf70d965637
Author: Caesar Wang <wxt@rock-chips.com>
Date:   Wed Jun 26 15:08:46 2019 +0800

    arm64: dts: rockchip: fixes the irq of BT on rk3399pro linux
    
    There is an obvious mistake defined on rk3399pro linux.
    
    Change-Id: I89c5589175fa5c8b712d856647442e96330bc669
    Signed-off-by: Caesar Wang <wxt@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
index 43c039b9018b..a077bbe433c6 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
@@ -226,8 +226,8 @@
 		clocks = <&rk809 1>;
 		clock-names = "ext_clock";
 		uart_rts_gpios = <&gpio2 RK_PC3 GPIO_ACTIVE_LOW>;
-		pinctrl-names = "default", "rts_gpio", <&bt_irq_gpio>;
-		pinctrl-0 = <&uart0_rts>;
+		pinctrl-names = "default", "rts_gpio";
+		pinctrl-0 = <&uart0_rts>, <&bt_irq_gpio>;
 		pinctrl-1 = <&uart0_gpios>;
 		BT,reset_gpio    = <&gpio2 RK_PD4 GPIO_ACTIVE_HIGH>;
 		BT,wake_gpio     = <&gpio2 RK_PD2 GPIO_ACTIVE_HIGH>;
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
index a9eb4f01a43c..8350a2671da4 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
@@ -226,8 +226,8 @@
 		clocks = <&rk809 1>;
 		clock-names = "ext_clock";
 		uart_rts_gpios = <&gpio2 RK_PC3 GPIO_ACTIVE_LOW>;
-		pinctrl-names = "default", "rts_gpio", <&bt_irq_gpio>;
-		pinctrl-0 = <&uart0_rts>;
+		pinctrl-names = "default", "rts_gpio";
+		pinctrl-0 = <&uart0_rts>, <&bt_irq_gpio>;
 		pinctrl-1 = <&uart0_gpios>;
 		BT,reset_gpio    = <&gpio2 RK_PD4 GPIO_ACTIVE_HIGH>;
 		BT,wake_gpio     = <&gpio2 RK_PD2 GPIO_ACTIVE_HIGH>;

commit a530326a0f12b0b1515b76fa0944dddeb55e5dfd
Author: Nickey Yang <nickey.yang@rock-chips.com>
Date:   Wed Jun 26 14:23:31 2019 +0800

    drm/rockchip: vop: adjust the layers in RK3399's VOBL
    
    AFAWK, there are four layers in RK3399's VOPB, and two layers for
    RK3399's VOPL.
    
    And RK3399's VOBL has the win0 and win2 layers, the formats they support
    as below.
    win0:
        XR24 AR24 XB24 AB24 RG24 BG24 RG16 BG16 NV12 NV16 NV24 NA12 NA16 NA24
    win2:
        XR24 AR24 XB24 AB24 RG24 BG24 RG16 BG16
    So only win0 layer supports NV12 format (for video decode format),
    adjust the overlay for video and primary layer for display.
    
    It didn't care this case if some platforms had handled the display in
    application (e.g android), then on the Linux platform, it's hard to handle
    the all kinds of cases in Display application, perhaps the linux needn't
    this patch fixes it in the future.
    
    Depend-CL:76144
    Fixes: d82f1d3e5800
    ("arm64: dts: rockchip: reasonable alllcation of VOP on rk3399 linux")
    
    Change-Id: Id93b315b6e3ae670bf5ea4dc0a64e140c6e37e80
    Signed-off-by: Caesar Wang <wxt@rock-chips.com>
    Signed-off-by: Nickey Yang <nickey.yang@rock-chips.com>

diff --git a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c
index 5ea33c412489..ead313b8387c 100644
--- a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c
+++ b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c
@@ -627,11 +627,11 @@ static const struct vop_data rk3399_vop_big = {
 
 static const struct vop_win_data rk3399_vop_lit_win_data[] = {
 	{ .base = 0x00, .phy = &rk3288_win01_data, .csc = &rk3399_win0_csc,
-	  .type = DRM_PLANE_TYPE_PRIMARY,
+	  .type = DRM_PLANE_TYPE_OVERLAY,
 	  .feature = WIN_FEATURE_AFBDC },
 	{ .phy = NULL },
 	{ .base = 0x00, .phy = &rk3368_win23_data, .csc = &rk3399_win2_csc,
-	  .type = DRM_PLANE_TYPE_CURSOR,
+	  .type = DRM_PLANE_TYPE_PRIMARY,
 	  .feature = WIN_FEATURE_AFBDC,
 	  .area = rk3368_area_data,
 	  .area_size = ARRAY_SIZE(rk3368_area_data), },

commit 22e74fc83b514136fe28837e6cc2a6c11387250f
Author: Nickey Yang <nickey.yang@rock-chips.com>
Date:   Wed Jun 26 14:06:52 2019 +0800

    drm/rockchip: vop: set plane's zpos according to type
    
    The zpos currently configure is the order in vop_win_data array,
    which is related to the actual hardware plane.
    But in the Linux platform, such as video hardware and camera preview,
    it can only be played on the nv12 plane.
    So set the order of zpos to PRIMARY < OVERLAY (if have) < CURSOR (if have).
    
    Change-Id: Ia9ab3cb9225fd2c385703109afbfbb42a1564110
    Signed-off-by: Nickey Yang <nickey.yang@rock-chips.com>

diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c
index becaf7640be7..3ee544bcac48 100644
--- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c
+++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c
@@ -197,6 +197,7 @@ struct vop_win {
 
 	int win_id;
 	int area_id;
+	int zpos;
 	uint32_t offset;
 	enum drm_plane_type type;
 	const struct vop_win_phy *phy;
@@ -1852,7 +1853,7 @@ static void vop_atomic_plane_reset(struct drm_plane *plane)
 	if (!vop_plane_state)
 		return;
 
-	vop_plane_state->zpos = win->win_id;
+	vop_plane_state->zpos = win->zpos;
 	vop_plane_state->global_alpha = 0xff;
 	plane->state = &vop_plane_state->base;
 	plane->state->plane = plane;
@@ -4295,6 +4296,26 @@ static void vop_destroy_crtc(struct vop *vop)
 	drm_flip_work_cleanup(&vop->fb_unref_work);
 }
 
+/*
+ * Win_id is the order in vop_win_data array.
+ * This is related to the actual hardware plane.
+ * But in the Linux platform, such as video hardware and camera preview,
+ * it can only be played on the nv12 plane.
+ * So set the order of zpos to PRIMARY < OVERLAY (if have) < CURSOR (if have).
+ */
+static int vop_plane_get_zpos(enum drm_plane_type type, unsigned int size)
+{
+	switch (type) {
+	case DRM_PLANE_TYPE_PRIMARY:
+		return 0;
+	case DRM_PLANE_TYPE_OVERLAY:
+		return 1;
+	case DRM_PLANE_TYPE_CURSOR:
+		return size - 1;
+	}
+	return 0;
+}
+
 /*
  * Initialize the vop->win array elements.
  */
@@ -4333,6 +4354,9 @@ static int vop_win_init(struct vop *vop)
 		vop_win->vop = vop;
 		vop_win->win_id = i;
 		vop_win->area_id = 0;
+		vop_win->zpos = vop_plane_get_zpos(win_data->type,
+						   vop_data->win_size);
+
 		num_wins++;
 
 		for (j = 0; j < win_data->area_size; j++) {
@@ -4353,7 +4377,7 @@ static int vop_win_init(struct vop *vop)
 	}
 
 	prop = drm_property_create_range(vop->drm_dev, DRM_MODE_PROP_ATOMIC,
-					 "ZPOS", 0, vop->data->win_size);
+					 "ZPOS", 0, vop->data->win_size - 1);
 	if (!prop) {
 		DRM_ERROR("failed to create zpos property\n");
 		return -EINVAL;

commit e6099b435aa88cf6dcd724f7fdcc71ba5410f1ea
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Wed Jun 26 17:10:24 2019 +0800

    arm64: rockchip_defconfig: enable KEYBOARD_GPIO
    
    Change-Id: Ifef084fdf287faee25cc91adc4c90708c535b72c
    Signed-off-by: Tao Huang <huangtao@rock-chips.com>

diff --git a/arch/arm64/configs/rockchip_defconfig b/arch/arm64/configs/rockchip_defconfig
index 01b19ea8da2b..fd49401520d5 100644
--- a/arch/arm64/configs/rockchip_defconfig
+++ b/arch/arm64/configs/rockchip_defconfig
@@ -370,6 +370,7 @@ CONFIG_INPUT_EVDEV=y
 CONFIG_INPUT_KEYRESET=y
 CONFIG_KEYBOARD_ADC=y
 # CONFIG_KEYBOARD_ATKBD is not set
+CONFIG_KEYBOARD_GPIO=y
 CONFIG_KEYBOARD_ROCKCHIP=y
 # CONFIG_INPUT_MOUSE is not set
 CONFIG_INPUT_JOYSTICK=y

commit 73c345775400b5b2b779daf0752f72fb508ee47b
Author: Ziyuan Xu <xzy.xu@rock-chips.com>
Date:   Thu Jun 20 16:20:33 2019 +0800

    arm64: rk3326_linux_defconfig: support MTP feature
    
    Change-Id: Ia7f5fafa3aaa36e1a7261d75d13598c08cea1259
    Signed-off-by: Ziyuan Xu <xzy.xu@rock-chips.com>

diff --git a/arch/arm64/configs/rk3326_linux_defconfig b/arch/arm64/configs/rk3326_linux_defconfig
index 3f316b097386..ec3cb91bdc72 100644
--- a/arch/arm64/configs/rk3326_linux_defconfig
+++ b/arch/arm64/configs/rk3326_linux_defconfig
@@ -318,6 +318,7 @@ CONFIG_USB_CONFIGFS=y
 CONFIG_USB_CONFIGFS_ACM=y
 CONFIG_USB_CONFIGFS_MASS_STORAGE=y
 CONFIG_USB_CONFIGFS_F_FS=y
+CONFIG_USB_CONFIGFS_F_MTP=y
 CONFIG_USB_CONFIGFS_UEVENT=y
 CONFIG_MMC=y
 CONFIG_MMC_BLOCK_MINORS=32

commit 672455b29c95f5a7018e53a12a3ffcb241b7f1cc
Author: Ziyuan Xu <xzy.xu@rock-chips.com>
Date:   Tue Jun 25 10:19:44 2019 +0800

    arm64: config: disable fb_console for px30/rk3326 linux
    
    Change-Id: Ie78ca02941eeeb4b87c21eef819b97a0077ec881
    Signed-off-by: Ziyuan Xu <xzy.xu@rock-chips.com>

diff --git a/arch/arm64/configs/px30_linux_defconfig b/arch/arm64/configs/px30_linux_defconfig
index 409a3df84cdd..8c51ca9c7036 100644
--- a/arch/arm64/configs/px30_linux_defconfig
+++ b/arch/arm64/configs/px30_linux_defconfig
@@ -177,6 +177,7 @@ CONFIG_INPUT_RK8XX_PWRKEY=y
 CONFIG_INPUT_UINPUT=y
 CONFIG_INPUT_GPIO=y
 # CONFIG_SERIO is not set
+CONFIG_VT_HW_CONSOLE_BINDING=y
 CONFIG_DEVPTS_MULTIPLE_INSTANCES=y
 # CONFIG_LEGACY_PTYS is not set
 # CONFIG_DEVKMEM is not set
@@ -281,7 +282,6 @@ CONFIG_BACKLIGHT_PWM=y
 CONFIG_RK_VCODEC=y
 CONFIG_ROCKCHIP_MPP_SERVICE=y
 CONFIG_ROCKCHIP_MPP_DEVICE=y
-CONFIG_FRAMEBUFFER_CONSOLE=y
 CONFIG_SOUND=y
 CONFIG_SND=y
 CONFIG_SND_SEQUENCER=y
diff --git a/arch/arm64/configs/rk3326_linux_defconfig b/arch/arm64/configs/rk3326_linux_defconfig
index d972b91f40c1..3f316b097386 100644
--- a/arch/arm64/configs/rk3326_linux_defconfig
+++ b/arch/arm64/configs/rk3326_linux_defconfig
@@ -157,6 +157,7 @@ CONFIG_INPUT_RK8XX_PWRKEY=y
 CONFIG_INPUT_UINPUT=y
 CONFIG_INPUT_GPIO=y
 # CONFIG_SERIO is not set
+CONFIG_VT_HW_CONSOLE_BINDING=y
 CONFIG_DEVPTS_MULTIPLE_INSTANCES=y
 # CONFIG_LEGACY_PTYS is not set
 # CONFIG_DEVKMEM is not set
@@ -263,7 +264,6 @@ CONFIG_BACKLIGHT_PWM=y
 CONFIG_RK_VCODEC=y
 CONFIG_ROCKCHIP_MPP_SERVICE=y
 CONFIG_ROCKCHIP_MPP_DEVICE=y
-CONFIG_FRAMEBUFFER_CONSOLE=y
 CONFIG_SOUND=y
 CONFIG_SND=y
 CONFIG_SND_SEQUENCER=y

commit 33f0e21e7c0a19dbc38992c9000bcf6a66010e3d
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Fri Jun 21 14:42:57 2019 +0800

    arm64: dts: rockchip: rk3308: add 'io-multiplex' property for i2s_8ch_1
    
    Change-Id: If68fccdf180d54f017e1d6836f4d663ae2635085
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3308.dtsi b/arch/arm64/boot/dts/rockchip/rk3308.dtsi
index 3d9cbd985b34..fe2ba30415c9 100644
--- a/arch/arm64/boot/dts/rockchip/rk3308.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3308.dtsi
@@ -996,6 +996,7 @@
 		rockchip,cru = <&cru>;
 		rockchip,grf = <&grf>;
 		rockchip,mclk-calibrate;
+		rockchip,io-multiplex;
 		status = "disabled";
 	};
 

commit 2ab4121a3edb30f15cde08447be58139277b5c74
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Thu May 23 20:14:19 2019 +0800

    ASoC: rk3308_codec: add support ADC grps and DAC endisable for testing
    
    Some times, we need to enable/disable ADC grps or DAC
    directly to debug.
    
    Change-Id: I53b9fa94733d84f7101e299d3fcb6f9160e36112
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/sound/soc/codecs/rk3308_codec.c b/sound/soc/codecs/rk3308_codec.c
index aadcd7f698fb..815e22fc346c 100644
--- a/sound/soc/codecs/rk3308_codec.c
+++ b/sound/soc/codecs/rk3308_codec.c
@@ -111,6 +111,7 @@ enum {
 enum {
 	ADC_TYPE_NORMAL = 0,
 	ADC_TYPE_LOOPBACK,
+	ADC_TYPE_DBG,
 	ADC_TYPE_ALL,
 };
 
@@ -171,6 +172,7 @@ struct rk3308_codec_priv {
 	u32 used_adc_grps;
 	/* The ADC group which is used for loop back */
 	u32 loopback_grp;
+	u32 cur_dbg_grp;
 	u32 en_always_grps[ADC_LR_GROUP_MAX];
 	u32 en_always_grps_num;
 	u32 skip_grps[ADC_LR_GROUP_MAX];
@@ -211,6 +213,8 @@ struct rk3308_codec_priv {
 	unsigned int hpout_l_dgain;
 	unsigned int hpout_r_dgain;
 
+	bool adc_grps_endisable[ADC_LR_GROUP_MAX];
+	bool dac_endisable;
 	bool enable_all_adcs;
 	bool enable_micbias;
 	bool micbias1;
@@ -1341,6 +1345,18 @@ static bool adc_for_each_grp(struct rk3308_codec_priv *rk3308,
 		dev_dbg(rk3308->plat_dev,
 			"ADC_TYPE_ALL, idx: %d, get grp: %d\n",
 			idx, *grp);
+	} else if (type == ADC_TYPE_DBG) {
+		if (idx >= ADC_LR_GROUP_MAX)
+			return false;
+
+		if (idx == (int)rk3308->cur_dbg_grp)
+			*grp = idx;
+		else
+			*grp = ADC_GRP_SKIP_MAGIC;
+
+		dev_dbg(rk3308->plat_dev,
+			"ADC_TYPE_DBG, idx: %d, get grp: %d\n",
+			idx, *grp);
 	} else {
 		if (idx >= 1)
 			return false;
@@ -2265,6 +2281,8 @@ static int rk3308_codec_dac_enable(struct rk3308_codec_priv *rk3308)
 		rk3308_codec_digital_fadein(rk3308);
 	}
 
+	rk3308->dac_endisable = true;
+
 	/* TODO: TRY TO TEST DRIVE STRENGTH */
 
 	return 0;
@@ -2417,6 +2435,8 @@ static int rk3308_codec_dac_disable(struct rk3308_codec_priv *rk3308)
 	 * rk3308_codec_adc_ana_disable(rk3308, type);
 	 */
 
+	rk3308->dac_endisable = false;
+
 	return 0;
 }
 
@@ -3226,6 +3246,13 @@ static int rk3308_codec_adc_ana_enable(struct rk3308_codec_priv *rk3308,
 		}
 	}
 
+	for (idx = 0; adc_for_each_grp(rk3308, type, idx, &grp); idx++) {
+		if (grp < 0 || grp > ADC_LR_GROUP_MAX - 1)
+			continue;
+
+		rk3308->adc_grps_endisable[grp] = true;
+	}
+
 	return 0;
 }
 
@@ -3352,6 +3379,13 @@ static int rk3308_codec_adc_ana_disable(struct rk3308_codec_priv *rk3308,
 				   RK3308_ADC_CH2_MIC_INIT);
 	}
 
+	for (idx = 0; adc_for_each_grp(rk3308, type, idx, &grp); idx++) {
+		if (grp < 0 || grp > ADC_LR_GROUP_MAX - 1)
+			continue;
+
+		rk3308->adc_grps_endisable[grp] = false;
+	}
+
 	return 0;
 }
 
@@ -3441,6 +3475,20 @@ static void rk3308_codec_dac_mclk_enable(struct rk3308_codec_priv *rk3308)
 	udelay(20);
 }
 
+static int rk3308_codec_open_dbg_capture(struct rk3308_codec_priv *rk3308)
+{
+	rk3308_codec_adc_ana_enable(rk3308, ADC_TYPE_DBG);
+
+	return 0;
+}
+
+static int rk3308_codec_close_dbg_capture(struct rk3308_codec_priv *rk3308)
+{
+	rk3308_codec_adc_ana_disable(rk3308, ADC_TYPE_DBG);
+
+	return 0;
+}
+
 static int rk3308_codec_close_all_capture(struct rk3308_codec_priv *rk3308)
 {
 	rk3308_codec_adc_ana_disable(rk3308, ADC_TYPE_ALL);
@@ -4506,6 +4554,85 @@ static ssize_t adc_zerocross_store(struct device *dev,
 	return count;
 }
 
+static ssize_t adc_grps_endisable_show(struct device *dev,
+				    struct device_attribute *attr,
+				    char *buf)
+{
+	struct rk3308_codec_priv *rk3308 =
+		container_of(dev, struct rk3308_codec_priv, dev);
+	int count = 0, i;
+
+	count += sprintf(buf + count, "enabled adc grps:");
+	for (i = 0; i < ADC_LR_GROUP_MAX; i++)
+		count += sprintf(buf + count, "%d ",
+				 rk3308->adc_grps_endisable[i]);
+
+	count += sprintf(buf + count, "\n");
+	return count;
+}
+
+static ssize_t adc_grps_endisable_store(struct device *dev,
+				struct device_attribute *attr,
+				const char *buf, size_t count)
+{
+	struct rk3308_codec_priv *rk3308 =
+		container_of(dev, struct rk3308_codec_priv, dev);
+	int grp, endisable, ret;
+
+	ret = sscanf(buf, "%d,%d", &grp, &endisable);
+	if (ret != 2) {
+		dev_err(rk3308->plat_dev, "%s sscanf failed: %d\n",
+			__func__, ret);
+		return -EFAULT;
+	}
+
+	rk3308->cur_dbg_grp = grp;
+
+	if (endisable)
+		rk3308_codec_open_dbg_capture(rk3308);
+	else
+		rk3308_codec_close_dbg_capture(rk3308);
+
+	dev_info(dev, "ADC grp %d endisable: %d\n", grp, endisable);
+
+	return count;
+}
+
+static ssize_t dac_endisable_show(struct device *dev,
+				    struct device_attribute *attr,
+				    char *buf)
+{
+	struct rk3308_codec_priv *rk3308 =
+		container_of(dev, struct rk3308_codec_priv, dev);
+
+	return sprintf(buf, "%d\n", rk3308->dac_endisable);
+}
+
+static ssize_t dac_endisable_store(struct device *dev,
+				struct device_attribute *attr,
+				const char *buf, size_t count)
+{
+	struct rk3308_codec_priv *rk3308 =
+		container_of(dev, struct rk3308_codec_priv, dev);
+	unsigned long endisable;
+	int ret = kstrtoul(buf, 10, &endisable);
+
+	if (ret < 0) {
+		dev_err(dev, "Invalid endisable: %ld, ret: %d\n",
+			endisable, ret);
+		return -EINVAL;
+	}
+
+	if (endisable)
+		rk3308_codec_open_playback(rk3308);
+	else
+		rk3308_codec_close_playback(rk3308);
+
+	dev_info(dev, "DAC endisable: %ld\n", endisable);
+
+	return count;
+}
+
 static ssize_t dac_output_show(struct device *dev,
 			       struct device_attribute *attr,
 			       char *buf)
@@ -4587,9 +4714,11 @@ static ssize_t enable_all_adcs_store(struct device *dev,
 
 static const struct device_attribute acodec_attrs[] = {
 	__ATTR_RW(adc_grps),
+	__ATTR_RW(adc_grps_endisable),
 	__ATTR_RW(adc_grps_route),
 	__ATTR_RW(adc_grp0_in),
 	__ATTR_RW(adc_zerocross),
+	__ATTR_RW(dac_endisable),
 	__ATTR_RW(dac_output),
 	__ATTR_RW(enable_all_adcs),
 	__ATTR_RW(pm_state),

commit 2a2fdd32427a2e114d0e385ce2054820a4d06a90
Author: Caesar Wang <wxt@rock-chips.com>
Date:   Wed Jun 26 09:14:14 2019 +0800

    arm64: dts: rockchip: support the rockchip_suspend on rk3399pro-npu
    
    In general, the kernel dts hadn't defined the rockchip_suspend parameters.
    The ARM Trusted Firmware (ATF) had a configure been used by default.
    
    As far, the rockchip_suspend can be configured in kernel when someone need
    configure it by themselevs.
    
    Change-Id: Id1b4b79609c3ce345aad946e07105d96f62c04f8
    Signed-off-by: Caesar Wang <wxt@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
index 01d92f98e680..44d39a95a812 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10.dts
@@ -98,6 +98,10 @@
 	status = "okay";
 };
 
+&rockchip_suspend {
+	status = "okay";
+};
+
 &combphy {
 	status = "okay";
 };
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi b/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi
index a1512d9d52b5..22b1557accc3 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu.dtsi
@@ -7,6 +7,7 @@
 #include <dt-bindings/pinctrl/rockchip.h>
 #include <dt-bindings/power/rk1808-power.h>
 #include <dt-bindings/phy/phy.h>
+#include <dt-bindings/suspend/rockchip-rk1808.h>
 #include <dt-bindings/thermal/thermal.h>
 
 / {
@@ -102,6 +103,25 @@
 		method = "smc";
 	};
 
+	rockchip_suspend: rockchip-suspend {
+		compatible = "rockchip,pm-rk1808";
+		status = "disabled";
+		rockchip,sleep-debug-en = <0>;
+		rockchip,sleep-mode-config = <
+			(0
+			| RKPM_SLP_ARMOFF
+			| RKPM_SLP_PMU_PMUALIVE_32K
+			| RKPM_SLP_PMU_DIS_OSC
+			| RKPM_SLP_32K_EXT
+			)
+		>;
+		rockchip,wakeup-config = <
+			(0
+			| RKPM_GPIO_WKUP_EN
+			)
+		>;
+	};
+
 	timer {
 		compatible = "arm,armv8-timer";
 		interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>,

commit 75a70678702804ff6b0802cc1ad687fa99be6ec2
Author: Weixin Zhou <zwx@rock-chips.com>
Date:   Thu Jun 20 19:12:33 2019 +0800

    arm64: rk3399pro_npu_pcie_defconfig: for multi camera board
    
    Change-Id: Id09443ea66a77732873e615e341dcc4a03275ba1
    Signed-off-by: Weixin Zhou <zwx@rock-chips.com>

diff --git a/arch/arm64/configs/rk3399pro_npu_pcie_defconfig b/arch/arm64/configs/rk3399pro_npu_pcie_defconfig
new file mode 100644
index 000000000000..286c8a49969a
--- /dev/null
+++ b/arch/arm64/configs/rk3399pro_npu_pcie_defconfig
@@ -0,0 +1,396 @@
+# CONFIG_LOCALVERSION_AUTO is not set
+CONFIG_DEFAULT_HOSTNAME="localhost"
+# CONFIG_SWAP is not set
+CONFIG_SYSVIPC=y
+CONFIG_FHANDLE=y
+CONFIG_NO_HZ=y
+CONFIG_HIGH_RES_TIMERS=y
+CONFIG_LOG_BUF_SHIFT=18
+CONFIG_BLK_DEV_INITRD=y
+# CONFIG_RD_BZIP2 is not set
+# CONFIG_RD_LZMA is not set
+# CONFIG_RD_XZ is not set
+# CONFIG_RD_LZO is not set
+# CONFIG_RD_LZ4 is not set
+CONFIG_CC_OPTIMIZE_FOR_SIZE=y
+CONFIG_EMBEDDED=y
+# CONFIG_SLUB_DEBUG is not set
+# CONFIG_COMPAT_BRK is not set
+CONFIG_PROFILING=y
+CONFIG_JUMP_LABEL=y
+CONFIG_MODULES=y
+CONFIG_MODULE_UNLOAD=y
+# CONFIG_BLK_DEV_BSG is not set
+CONFIG_PARTITION_ADVANCED=y
+# CONFIG_RK_PARTITION is not set
+# CONFIG_IOSCHED_DEADLINE is not set
+# CONFIG_IOSCHED_CFQ is not set
+CONFIG_ARCH_ROCKCHIP=y
+CONFIG_PCI=y
+CONFIG_PCI_MSI=y
+CONFIG_PCIE_DW_ROCKCHIP=y
+CONFIG_ROCKCHIP_PCIE_DMA_OBJ=y
+CONFIG_PCIE_ROCKCHIP=y
+CONFIG_PCIEPORTBUS=y
+CONFIG_PCIEASPM_POWERSAVE=y
+# CONFIG_ARM64_ERRATUM_826319 is not set
+# CONFIG_ARM64_ERRATUM_827319 is not set
+# CONFIG_ARM64_ERRATUM_824069 is not set
+# CONFIG_ARM64_ERRATUM_819472 is not set
+# CONFIG_ARM64_ERRATUM_832075 is not set
+# CONFIG_ARM64_ERRATUM_845719 is not set
+# CONFIG_ARM64_ERRATUM_843419 is not set
+# CONFIG_CAVIUM_ERRATUM_22375 is not set
+# CONFIG_CAVIUM_ERRATUM_23154 is not set
+# CONFIG_CAVIUM_ERRATUM_27456 is not set
+CONFIG_SCHED_MC=y
+CONFIG_NR_CPUS=2
+CONFIG_PREEMPT=y
+CONFIG_HZ_1000=y
+# CONFIG_SPARSEMEM_VMEMMAP is not set
+# CONFIG_COMPACTION is not set
+# CONFIG_BOUNCE is not set
+CONFIG_DEFAULT_MMAP_MIN_ADDR=32768
+# CONFIG_UNMAP_KERNEL_AT_EL0 is not set
+# CONFIG_ARM64_HW_AFDBM is not set
+# CONFIG_ARM64_PAN is not set
+# CONFIG_ARM64_UAO is not set
+# CONFIG_EFI is not set
+CONFIG_COMPAT=y
+CONFIG_PM_DEBUG=y
+CONFIG_PM_ADVANCED_DEBUG=y
+CONFIG_WQ_POWER_EFFICIENT_DEFAULT=y
+CONFIG_CPU_IDLE=y
+# CONFIG_CPU_IDLE_GOV_LADDER is not set
+CONFIG_ARM_CPUIDLE=y
+CONFIG_CPU_FREQ=y
+CONFIG_CPU_FREQ_DEFAULT_GOV_INTERACTIVE=y
+CONFIG_CPU_FREQ_GOV_USERSPACE=y
+CONFIG_CPU_FREQ_GOV_ONDEMAND=y
+CONFIG_CPUFREQ_DT=y
+CONFIG_ARM_ROCKCHIP_CPUFREQ=y
+CONFIG_NET=y
+CONFIG_PACKET=y
+CONFIG_UNIX=y
+CONFIG_NET_KEY=y
+CONFIG_INET=y
+CONFIG_SYN_COOKIES=y
+# CONFIG_INET_XFRM_MODE_TRANSPORT is not set
+# CONFIG_INET_XFRM_MODE_TUNNEL is not set
+# CONFIG_INET_XFRM_MODE_BEET is not set
+# CONFIG_INET_LRO is not set
+# CONFIG_INET_DIAG is not set
+# CONFIG_INET6_XFRM_MODE_TRANSPORT is not set
+# CONFIG_INET6_XFRM_MODE_TUNNEL is not set
+# CONFIG_INET6_XFRM_MODE_BEET is not set
+# CONFIG_IPV6_SIT is not set
+# CONFIG_ANDROID_PARANOID_NETWORK is not set
+CONFIG_BT=y
+CONFIG_BT_RFCOMM=y
+CONFIG_BT_RFCOMM_TTY=y
+CONFIG_BT_HIDP=y
+CONFIG_BT_HCIUART=y
+CONFIG_BT_HCIUART_H4=y
+CONFIG_BT_HCIUART_LL=y
+CONFIG_RFKILL=y
+CONFIG_DEVTMPFS=y
+CONFIG_DEVTMPFS_MOUNT=y
+# CONFIG_ALLOW_DEV_COREDUMP is not set
+# CONFIG_BLK_DEV is not set
+CONFIG_SRAM=y
+CONFIG_SCSI=y
+CONFIG_BLK_DEV_SD=y
+CONFIG_CHR_DEV_SG=y
+CONFIG_CHR_DEV_SCH=y
+CONFIG_SCSI_CONSTANTS=y
+CONFIG_SCSI_LOGGING=y
+CONFIG_SCSI_SCAN_ASYNC=y
+CONFIG_NETDEVICES=y
+# CONFIG_NET_CORE is not set
+# CONFIG_NET_VENDOR_3COM is not set
+# CONFIG_NET_VENDOR_ADAPTEC is not set
+# CONFIG_NET_VENDOR_AGERE is not set
+# CONFIG_NET_VENDOR_ALTEON is not set
+# CONFIG_NET_VENDOR_AMD is not set
+# CONFIG_NET_VENDOR_ARC is not set
+# CONFIG_NET_VENDOR_ATHEROS is not set
+# CONFIG_NET_CADENCE is not set
+# CONFIG_NET_VENDOR_BROADCOM is not set
+# CONFIG_NET_VENDOR_BROCADE is not set
+# CONFIG_NET_VENDOR_CAVIUM is not set
+# CONFIG_NET_VENDOR_CHELSIO is not set
+# CONFIG_NET_VENDOR_CISCO is not set
+# CONFIG_NET_VENDOR_DEC is not set
+# CONFIG_NET_VENDOR_DLINK is not set
+# CONFIG_NET_VENDOR_EMULEX is not set
+# CONFIG_NET_VENDOR_EZCHIP is not set
+# CONFIG_NET_VENDOR_EXAR is not set
+# CONFIG_NET_VENDOR_HISILICON is not set
+# CONFIG_NET_VENDOR_HP is not set
+# CONFIG_NET_VENDOR_INTEL is not set
+# CONFIG_NET_VENDOR_MARVELL is not set
+# CONFIG_NET_VENDOR_MELLANOX is not set
+# CONFIG_NET_VENDOR_MICREL is not set
+# CONFIG_NET_VENDOR_MICROCHIP is not set
+# CONFIG_NET_VENDOR_MYRI is not set
+# CONFIG_NET_VENDOR_NATSEMI is not set
+# CONFIG_NET_VENDOR_NVIDIA is not set
+# CONFIG_NET_VENDOR_OKI is not set
+# CONFIG_NET_PACKET_ENGINE is not set
+# CONFIG_NET_VENDOR_QLOGIC is not set
+# CONFIG_NET_VENDOR_QUALCOMM is not set
+# CONFIG_NET_VENDOR_REALTEK is not set
+# CONFIG_NET_VENDOR_RENESAS is not set
+# CONFIG_NET_VENDOR_RDC is not set
+# CONFIG_NET_VENDOR_ROCKER is not set
+# CONFIG_NET_VENDOR_SAMSUNG is not set
+# CONFIG_NET_VENDOR_SEEQ is not set
+# CONFIG_NET_VENDOR_SILAN is not set
+# CONFIG_NET_VENDOR_SIS is not set
+# CONFIG_NET_VENDOR_SMSC is not set
+CONFIG_STMMAC_ETH=y
+# CONFIG_DWMAC_GENERIC is not set
+# CONFIG_NET_VENDOR_SUN is not set
+# CONFIG_NET_VENDOR_SYNOPSYS is not set
+# CONFIG_NET_VENDOR_TEHUTI is not set
+# CONFIG_NET_VENDOR_TI is not set
+# CONFIG_NET_VENDOR_VIA is not set
+# CONFIG_NET_VENDOR_WIZNET is not set
+CONFIG_ROCKCHIP_PHY=y
+CONFIG_WL_ROCKCHIP=y
+CONFIG_WIFI_BUILD_MODULE=y
+CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP=y
+CONFIG_AP6XXX=m
+# CONFIG_RTL_WIRELESS_SOLUTION is not set
+# CONFIG_INPUT_MOUSEDEV is not set
+CONFIG_INPUT_EVDEV=y
+CONFIG_KEYBOARD_ADC=y
+# CONFIG_KEYBOARD_ATKBD is not set
+CONFIG_KEYBOARD_GPIO=y
+# CONFIG_INPUT_MOUSE is not set
+CONFIG_INPUT_TOUCHSCREEN=y
+CONFIG_TOUCHSCREEN_GT1X=y
+CONFIG_INPUT_MISC=y
+CONFIG_INPUT_RK8XX_PWRKEY=y
+CONFIG_INPUT_GPIO_ROTARY_ENCODER=y
+# CONFIG_SERIO is not set
+# CONFIG_VT is not set
+# CONFIG_LEGACY_PTYS is not set
+# CONFIG_DEVKMEM is not set
+CONFIG_SERIAL_8250=y
+# CONFIG_SERIAL_8250_DEPRECATED_OPTIONS is not set
+CONFIG_SERIAL_8250_CONSOLE=y
+# CONFIG_SERIAL_8250_PCI is not set
+CONFIG_SERIAL_8250_NR_UARTS=5
+CONFIG_SERIAL_8250_RUNTIME_UARTS=5
+CONFIG_SERIAL_8250_DW=y
+CONFIG_HW_RANDOM=y
+CONFIG_HW_RANDOM_ROCKCHIP=y
+# CONFIG_DEVPORT is not set
+CONFIG_I2C_CHARDEV=y
+CONFIG_I2C_RK3X=y
+CONFIG_I2C_GPIO=y
+CONFIG_SPI=y
+CONFIG_SPI_ROCKCHIP=y
+CONFIG_SPI_SPIDEV=y
+CONFIG_DEBUG_GPIO=y
+CONFIG_GPIO_SYSFS=y
+CONFIG_SYSCON_REBOOT_MODE=y
+CONFIG_POWER_AVS=y
+CONFIG_ROCKCHIP_IODOMAIN=y
+# CONFIG_HWMON is not set
+CONFIG_THERMAL=y
+CONFIG_THERMAL_WRITABLE_TRIPS=y
+CONFIG_THERMAL_DEFAULT_GOV_POWER_ALLOCATOR=y
+CONFIG_THERMAL_GOV_USER_SPACE=y
+CONFIG_CPU_THERMAL=y
+CONFIG_DEVFREQ_THERMAL=y
+CONFIG_ROCKCHIP_THERMAL=y
+CONFIG_WATCHDOG=y
+CONFIG_DW_WATCHDOG=y
+CONFIG_MFD_RK808=y
+CONFIG_REGULATOR=y
+CONFIG_REGULATOR_FIXED_VOLTAGE=y
+CONFIG_REGULATOR_FAN53555=y
+CONFIG_REGULATOR_GPIO=y
+CONFIG_REGULATOR_PWM=y
+CONFIG_REGULATOR_RK808=y
+CONFIG_MEDIA_SUPPORT=y
+CONFIG_MEDIA_CAMERA_SUPPORT=y
+CONFIG_MEDIA_RC_SUPPORT=y
+CONFIG_MEDIA_CONTROLLER=y
+CONFIG_VIDEO_V4L2_SUBDEV_API=y
+CONFIG_MEDIA_USB_SUPPORT=y
+CONFIG_USB_VIDEO_CLASS=y
+CONFIG_V4L_PLATFORM_DRIVERS=y
+CONFIG_SOC_CAMERA=y
+CONFIG_VIDEO_ROCKCHIP_CIF=y
+CONFIG_VIDEO_ROCKCHIP_ISP1=y
+CONFIG_V4L_MEM2MEM_DRIVERS=y
+# CONFIG_MEDIA_SUBDRV_AUTOSELECT is not set
+CONFIG_VIDEO_IMX327=y
+# CONFIG_VIDEO_SC031GS is not set
+# CONFIG_VGA_ARB is not set
+CONFIG_DRM=y
+CONFIG_DRM_ROCKCHIP=y
+CONFIG_ROCKCHIP_DRM_DEBUG=y
+CONFIG_ROCKCHIP_DW_MIPI_DSI=y
+CONFIG_ROCKCHIP_MIPI_CSI_TX=y
+CONFIG_ROCKCHIP_RGB=y
+CONFIG_DRM_PANEL_SIMPLE=y
+CONFIG_MALI_MIDGARD_FOR_LINUX=y
+CONFIG_BACKLIGHT_LCD_SUPPORT=y
+# CONFIG_LCD_CLASS_DEVICE is not set
+CONFIG_BACKLIGHT_CLASS_DEVICE=y
+# CONFIG_BACKLIGHT_GENERIC is not set
+CONFIG_BACKLIGHT_PWM=y
+CONFIG_ROCKCHIP_RGA2=y
+CONFIG_RK_VCODEC=y
+CONFIG_SOUND=y
+CONFIG_SND=y
+CONFIG_SND_HRTIMER=y
+# CONFIG_SND_SUPPORT_OLD_API is not set
+CONFIG_SND_ALOOP=y
+# CONFIG_SND_PCI is not set
+# CONFIG_SND_SPI is not set
+CONFIG_SND_SOC=y
+CONFIG_SND_SOC_ROCKCHIP=y
+CONFIG_SND_SOC_ROCKCHIP_I2S=y
+CONFIG_SND_SOC_ROCKCHIP_I2S_TDM=y
+CONFIG_SND_SOC_ROCKCHIP_MULTI_DAIS=y
+CONFIG_SND_SOC_ROCKCHIP_PDM=y
+CONFIG_SND_SOC_ROCKCHIP_VAD=y
+CONFIG_SND_SOC_ROCKCHIP_MULTICODECS=y
+CONFIG_SND_SOC_DUMMY_CODEC=y
+CONFIG_SND_SOC_RK817=y
+CONFIG_SND_SOC_TAS571X=y
+CONFIG_SND_SIMPLE_CARD=y
+# CONFIG_HID_GENERIC is not set
+CONFIG_USB=y
+CONFIG_USB_ANNOUNCE_NEW_DEVICES=y
+CONFIG_USB_XHCI_HCD=y
+CONFIG_USB_EHCI_HCD=y
+CONFIG_USB_EHCI_HCD_PLATFORM=y
+CONFIG_USB_OHCI_HCD=y
+# CONFIG_USB_OHCI_HCD_PCI is not set
+CONFIG_USB_OHCI_HCD_PLATFORM=y
+CONFIG_USB_STORAGE=y
+CONFIG_USB_DWC3=y
+# CONFIG_USB_DWC3_PCI is not set
+CONFIG_USB_GADGET=y
+CONFIG_USB_GADGET_DEBUG_FILES=y
+CONFIG_USB_GADGET_VBUS_DRAW=500
+CONFIG_USB_CONFIGFS=y
+CONFIG_USB_CONFIGFS_ACM=y
+CONFIG_USB_CONFIGFS_F_FS=y
+CONFIG_USB_CONFIGFS_UEVENT=y
+CONFIG_USB_CONFIGFS_F_UVC=y
+CONFIG_USB_CONFIGFS_F_UVC_ROCKCHIP=y
+CONFIG_MMC=y
+CONFIG_MMC_BLOCK_MINORS=32
+# CONFIG_MMC_BLOCK_BOUNCE is not set
+CONFIG_MMC_DW=y
+CONFIG_MMC_DW_ROCKCHIP=y
+CONFIG_NEW_LEDS=y
+CONFIG_LEDS_CLASS=y
+CONFIG_LEDS_GPIO=y
+CONFIG_LEDS_IS31FL32XX=y
+CONFIG_LEDS_TRIGGERS=y
+CONFIG_LEDS_TRIGGER_TIMER=y
+CONFIG_LEDS_TRIGGER_ONESHOT=y
+CONFIG_LEDS_TRIGGER_HEARTBEAT=y
+CONFIG_LEDS_TRIGGER_DEFAULT_ON=y
+CONFIG_LEDS_TRIGGER_MULTI_CTRL=y
+CONFIG_RTC_CLASS=y
+CONFIG_RTC_DRV_RK808=y
+CONFIG_DMADEVICES=y
+CONFIG_PL330_DMA=y
+CONFIG_STAGING=y
+# CONFIG_ANDROID_TIMED_OUTPUT is not set
+CONFIG_FIQ_DEBUGGER=y
+CONFIG_FIQ_DEBUGGER_NO_SLEEP=y
+CONFIG_FIQ_DEBUGGER_CONSOLE=y
+CONFIG_FIQ_DEBUGGER_CONSOLE_DEFAULT_ENABLE=y
+CONFIG_FIQ_DEBUGGER_TRUST_ZONE=y
+CONFIG_RK_CONSOLE_THREAD=y
+# CONFIG_COMMON_CLK_XGENE is not set
+# CONFIG_ARM_ARCH_TIMER_EVTSTREAM is not set
+CONFIG_ROCKCHIP_IOMMU=y
+# CONFIG_CPU_PX30 is not set
+CONFIG_CPU_RK1808=y
+# CONFIG_CPU_RK3328 is not set
+# CONFIG_CPU_RK3368 is not set
+# CONFIG_CPU_RK3399 is not set
+CONFIG_ROCKCHIP_PM_DOMAINS=y
+CONFIG_ROCKCHIP_PVTM=y
+CONFIG_ROCKCHIP_SUSPEND_MODE=y
+CONFIG_PM_DEVFREQ=y
+CONFIG_DEVFREQ_GOV_USERSPACE=y
+CONFIG_ARM_ROCKCHIP_BUS_DEVFREQ=y
+CONFIG_ARM_ROCKCHIP_DMC_DEVFREQ=y
+CONFIG_PM_DEVFREQ_EVENT=y
+CONFIG_DEVFREQ_EVENT_ROCKCHIP_NOCP=y
+CONFIG_IIO=y
+CONFIG_IIO_BUFFER=y
+CONFIG_IIO_KFIFO_BUF=y
+CONFIG_IIO_TRIGGER=y
+CONFIG_ROCKCHIP_SARADC=y
+CONFIG_PWM=y
+CONFIG_PWM_ROCKCHIP=y
+CONFIG_PHY_ROCKCHIP_USB=y
+CONFIG_PHY_ROCKCHIP_INNO_COMBPHY=y
+CONFIG_PHY_ROCKCHIP_INNO_USB2=y
+CONFIG_PHY_ROCKCHIP_INNO_USB3=y
+CONFIG_PHY_ROCKCHIP_INNO_MIPI_DPHY=y
+CONFIG_PHY_ROCKCHIP_PCIE=y
+CONFIG_ANDROID=y
+CONFIG_NVMEM=y
+CONFIG_ROCKCHIP_EFUSE=y
+CONFIG_RK_FLASH=y
+CONFIG_RK_NANDC_NAND=y
+CONFIG_RK_SFC_NAND=y
+CONFIG_RK_SFC_NOR=y
+CONFIG_ROCKCHIP_SIP=y
+# CONFIG_ACPI is not set
+CONFIG_EXT4_FS=y
+# CONFIG_DNOTIFY is not set
+CONFIG_VFAT_FS=y
+CONFIG_NTFS_FS=y
+CONFIG_TMPFS=y
+CONFIG_SQUASHFS=y
+CONFIG_SQUASHFS_DECOMP_MULTI_PERCPU=y
+CONFIG_SQUASHFS_LZ4=y
+CONFIG_SQUASHFS_4K_DEVBLK_SIZE=y
+CONFIG_PSTORE=y
+CONFIG_PSTORE_CONSOLE=y
+CONFIG_PSTORE_RAM=y
+# CONFIG_NETWORK_FILESYSTEMS is not set
+CONFIG_NLS_CODEPAGE_437=y
+CONFIG_NLS_ISO8859_1=y
+CONFIG_PRINTK_TIME=y
+CONFIG_DEBUG_INFO=y
+CONFIG_DEBUG_FS=y
+CONFIG_MAGIC_SYSRQ=y
+CONFIG_MAGIC_SYSRQ_DEFAULT_ENABLE=0
+CONFIG_LOCKUP_DETECTOR=y
+CONFIG_BOOTPARAM_HARDLOCKUP_PANIC=y
+CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC=y
+CONFIG_BOOTPARAM_HUNG_TASK_PANIC=y
+CONFIG_PANIC_ON_OOPS=y
+CONFIG_PANIC_TIMEOUT=1
+# CONFIG_SCHED_DEBUG is not set
+# CONFIG_DEBUG_PREEMPT is not set
+CONFIG_RCU_CPU_STALL_TIMEOUT=60
+# CONFIG_FTRACE is not set
+CONFIG_DEBUG_SET_MODULE_RONX=y
+# CONFIG_CRYPTO_ECHAINIV is not set
+# CONFIG_CRYPTO_HW is not set
+CONFIG_ARM64_CRYPTO=y
+CONFIG_CRYPTO_SHA1_ARM64_CE=y
+CONFIG_CRYPTO_SHA2_ARM64_CE=y
+CONFIG_CRYPTO_GHASH_ARM64_CE=y
+CONFIG_CRYPTO_POLY_HASH_ARM64_CE=y
+CONFIG_CRYPTO_AES_ARM64_CE_CCM=y
+CONFIG_CRYPTO_AES_ARM64_CE_BLK=y
+CONFIG_CRYPTO_AES_ARM64_NEON_BLK=y
+CONFIG_CRYPTO_CRC32_ARM64=y

commit 7946cf8991942027f14dd4b60d0c75586b428e77
Author: Weixin Zhou <zwx@rock-chips.com>
Date:   Wed Jun 19 21:31:12 2019 +0800

    arm64: rockchip_defconfig: enable CONFIG_ROCKCHIP_PCIE_DMA_OBJ
    
    for multi camera board, connect npu by pcie,
    depend on rockchip,dma_trx_enabled = <1> on dts
    
    Change-Id: I244fdeddd0e64ab35bdb5a63655a3216292bbf34
    Signed-off-by: Weixin Zhou <zwx@rock-chips.com>

diff --git a/arch/arm64/configs/rockchip_defconfig b/arch/arm64/configs/rockchip_defconfig
index f8ce3be94d2b..01b19ea8da2b 100644
--- a/arch/arm64/configs/rockchip_defconfig
+++ b/arch/arm64/configs/rockchip_defconfig
@@ -48,6 +48,7 @@ CONFIG_CMDLINE_PARTITION=y
 CONFIG_ARCH_ROCKCHIP=y
 CONFIG_PCI=y
 CONFIG_PCI_MSI=y
+CONFIG_ROCKCHIP_PCIE_DMA_OBJ=y
 CONFIG_PCIE_ROCKCHIP=y
 CONFIG_PCIEPORTBUS=y
 CONFIG_PCIEASPM_POWERSAVE=y

commit 30897bb88408751c1eb79ae568b028156c4b169f
Author: Simon Xue <xxm@rock-chips.com>
Date:   Wed Jun 26 13:39:06 2019 +0800

    PCI: rockchip: pcie dma transfer function only enabled when "rockchip,dma_trx_enabled" set
    
    Change-Id: I8ae69ac649c15bd4920621d6db27173a7cb36b4a
    Signed-off-by: Simon Xue <xxm@rock-chips.com>

diff --git a/drivers/pci/host/pcie-rockchip.c b/drivers/pci/host/pcie-rockchip.c
index d64ca56964d3..707b5bafb679 100644
--- a/drivers/pci/host/pcie-rockchip.c
+++ b/drivers/pci/host/pcie-rockchip.c
@@ -1617,6 +1617,9 @@ static int rockchip_pcie_probe(struct platform_device *pdev)
 		}
 	}
 
+	if (rockchip->dma_trx_enabled == 0)
+		return 0;
+
 	rockchip->dma_obj = rk_pcie_dma_obj_probe(dev);
 	if (IS_ERR(rockchip->dma_obj)) {
 		dev_err(dev, "failed to prepare dma object\n");

commit ba72b31499809c80bf3127583626c7a4e14c6905
Author: Frank Wang <frank.wang@rock-chips.com>
Date:   Tue Jun 25 08:38:20 2019 +0800

    phy: phy-rockchip-inno-usb2: add exception handling for wakelock
    
    The "OTG wakelock" should be destroyed if otg port was initialized
    failed, in case of its memory allocate for other module and the
    "wakeup_sources" list would be broken.
    
    Change-Id: Ic478e7297e36def8e105a0736beb86c99ca6261d
    Signed-off-by: Frank Wang <frank.wang@rock-chips.com>

diff --git a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
index 34f28a3dee17..747a39c0c3a9 100644
--- a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
+++ b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
@@ -1652,13 +1652,14 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 		if (ret) {
 			dev_err(rphy->dev,
 				"failed to request otg-mux irq handle\n");
-			return ret;
+			goto err;
 		}
 	} else {
 		rport->bvalid_irq = of_irq_get_byname(child_np, "otg-bvalid");
 		if (rport->bvalid_irq <= 0) {
 			dev_err(rphy->dev, "no vbus valid irq provided\n");
-			return -EINVAL;
+			ret = -EINVAL;
+			goto err;
 		}
 
 		ret = devm_request_threaded_irq(rphy->dev, rport->bvalid_irq,
@@ -1670,13 +1671,14 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 		if (ret) {
 			dev_err(rphy->dev,
 				"failed to request otg-bvalid irq handle\n");
-			return ret;
+			goto err;
 		}
 
 		rport->ls_irq = of_irq_get_byname(child_np, "linestate");
 		if (rport->ls_irq <= 0) {
 			dev_err(rphy->dev, "no linestate irq provided\n");
-			return -EINVAL;
+			ret = -EINVAL;
+			goto err;
 		}
 
 		ret = devm_request_threaded_irq(rphy->dev, rport->ls_irq, NULL,
@@ -1685,14 +1687,15 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 						"rockchip_usb2phy", rport);
 		if (ret) {
 			dev_err(rphy->dev, "failed to request linestate irq handle\n");
-			return ret;
+			goto err;
 		}
 
 		if (rphy->edev_self) {
 			rport->id_irq = of_irq_get_byname(child_np, "otg-id");
 			if (rport->id_irq <= 0) {
 				dev_err(rphy->dev, "no otg id irq provided\n");
-				return -EINVAL;
+				ret = -EINVAL;
+				goto err;
 			}
 
 			ret = devm_request_threaded_irq(rphy->dev,
@@ -1703,7 +1706,7 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 							rport);
 			if (ret) {
 				dev_err(rphy->dev, "failed to request otg-id irq handle\n");
-				return ret;
+				goto err;
 			}
 		}
 	}
@@ -1717,7 +1720,7 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 			/* Enable VBUS supply */
 			ret = rockchip_set_vbus_power(rport, true);
 			if (ret)
-				return ret;
+				goto err;
 		}
 	}
 
@@ -1728,7 +1731,7 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 					       &rport->event_nb);
 		if (ret < 0) {
 			dev_err(rphy->dev, "register USB HOST notifier failed\n");
-			return ret;
+			goto err;
 		}
 	}
 
@@ -1744,6 +1747,10 @@ out:
 	rport->suspended = true;
 
 	return 0;
+
+err:
+	wake_lock_destroy(&rport->wakelock);
+	return ret;
 }
 
 static int rockchip_usb2phy_probe(struct platform_device *pdev)

commit ee35bc3e7100898556d7810401c5212e267f75f0
Author: Frank Wang <frank.wang@rock-chips.com>
Date:   Mon Jun 24 17:56:51 2019 +0800

    phy: phy-rockchip-inno-usb2: fix otg-id irq error
    
    For the 'otg-mux' irq in SoC should include 'otg-bvalid', 'linestate',
    and 'otg-id'. This change fix the previous error condition.
    
    Change-Id: I8fe46c8c9efd6ce04eead89c276227d4cc70902e
    Signed-off-by: Frank Wang <frank.wang@rock-chips.com>

diff --git a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
index 3341c8afed30..34f28a3dee17 100644
--- a/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
+++ b/drivers/phy/rockchip/phy-rockchip-inno-usb2.c
@@ -1468,17 +1468,6 @@ static irqreturn_t rockchip_usb2phy_bvalid_irq(int irq, void *data)
 	return IRQ_HANDLED;
 }
 
-static irqreturn_t rockchip_usb2phy_otg_mux_irq(int irq, void *data)
-{
-	struct rockchip_usb2phy_port *rport = data;
-	struct rockchip_usb2phy *rphy = dev_get_drvdata(rport->phy->dev.parent);
-
-	if (property_enabled(rphy->grf, &rport->port_cfg->bvalid_det_st))
-		return rockchip_usb2phy_bvalid_irq(irq, data);
-	else
-		return IRQ_NONE;
-}
-
 static irqreturn_t rockchip_usb2phy_id_irq(int irq, void *data)
 {
 	struct rockchip_usb2phy_port *rport = data;
@@ -1515,6 +1504,17 @@ static irqreturn_t rockchip_usb2phy_id_irq(int irq, void *data)
 	return IRQ_HANDLED;
 }
 
+static irqreturn_t rockchip_usb2phy_otg_mux_irq(int irq, void *data)
+{
+	irqreturn_t ret = IRQ_NONE;
+
+	ret  = rockchip_usb2phy_id_irq(irq, data);
+	ret |= rockchip_usb2phy_bvalid_irq(irq, data);
+	ret |= rockchip_usb2phy_linestate_irq(irq, data);
+
+	return ret;
+}
+
 static int rockchip_usb2phy_host_port_init(struct rockchip_usb2phy *rphy,
 					   struct rockchip_usb2phy_port *rport,
 					   struct device_node *child_np)
@@ -1533,9 +1533,9 @@ static int rockchip_usb2phy_host_port_init(struct rockchip_usb2phy *rphy,
 	INIT_DELAYED_WORK(&rport->sm_work, rockchip_usb2phy_sm_work);
 
 	rport->ls_irq = of_irq_get_byname(child_np, "linestate");
-	if (rport->ls_irq < 0) {
+	if (rport->ls_irq <= 0) {
 		dev_err(rphy->dev, "no linestate irq provided\n");
-		return rport->ls_irq;
+		return -EINVAL;
 	}
 
 	ret = devm_request_threaded_irq(rphy->dev, rport->ls_irq, NULL,
@@ -1656,9 +1656,9 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 		}
 	} else {
 		rport->bvalid_irq = of_irq_get_byname(child_np, "otg-bvalid");
-		if (rport->bvalid_irq < 0) {
+		if (rport->bvalid_irq <= 0) {
 			dev_err(rphy->dev, "no vbus valid irq provided\n");
-			return rport->bvalid_irq;
+			return -EINVAL;
 		}
 
 		ret = devm_request_threaded_irq(rphy->dev, rport->bvalid_irq,
@@ -1674,9 +1674,9 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 		}
 
 		rport->ls_irq = of_irq_get_byname(child_np, "linestate");
-		if (rport->ls_irq < 0) {
+		if (rport->ls_irq <= 0) {
 			dev_err(rphy->dev, "no linestate irq provided\n");
-			return rport->ls_irq;
+			return -EINVAL;
 		}
 
 		ret = devm_request_threaded_irq(rphy->dev, rport->ls_irq, NULL,
@@ -1687,24 +1687,28 @@ static int rockchip_usb2phy_otg_port_init(struct rockchip_usb2phy *rphy,
 			dev_err(rphy->dev, "failed to request linestate irq handle\n");
 			return ret;
 		}
-	}
 
-	if (rphy->edev_self) {
-		rport->id_irq = of_irq_get_byname(child_np, "otg-id");
-		if (rport->id_irq < 0) {
-			dev_err(rphy->dev, "no otg id irq provided\n");
-			return rport->id_irq;
-		}
+		if (rphy->edev_self) {
+			rport->id_irq = of_irq_get_byname(child_np, "otg-id");
+			if (rport->id_irq <= 0) {
+				dev_err(rphy->dev, "no otg id irq provided\n");
+				return -EINVAL;
+			}
 
-		ret = devm_request_threaded_irq(rphy->dev, rport->id_irq, NULL,
-						rockchip_usb2phy_id_irq,
-						IRQF_ONESHOT,
-						"rockchip_usb2phy_id", rport);
-		if (ret) {
-			dev_err(rphy->dev, "failed to request otg-id irq handle\n");
-			return ret;
+			ret = devm_request_threaded_irq(rphy->dev,
+							rport->id_irq, NULL,
+							rockchip_usb2phy_id_irq,
+							IRQF_ONESHOT,
+							"rockchip_usb2phy_id",
+							rport);
+			if (ret) {
+				dev_err(rphy->dev, "failed to request otg-id irq handle\n");
+				return ret;
+			}
 		}
+	}
 
+	if (rphy->edev_self) {
 		iddig = property_enabled(rphy->grf, &rport->port_cfg->utmi_iddig);
 		if (!iddig) {
 			extcon_set_state(rphy->edev, EXTCON_USB, false);

commit d69af8ab6534bb28c1556076f08d2a5ab4935d95
Author: David Wu <david.wu@rock-chips.com>
Date:   Wed May 29 10:57:50 2019 +0800

    pinctrl: rockchip: Add iomux recalculated for rk3328 GPIO2B0~GPIO2B6
    
    The pins from GPIO2B0 to GPIO2B6 are located at GRF_GPIO2BL_IOMUX,
    they are recalculated to get correct iomux.
    
    Change-Id: I1e46697c4508c396b5e8140c32c4185925a040ea
    Signed-off-by: David Wu <david.wu@rock-chips.com>

diff --git a/drivers/pinctrl/pinctrl-rockchip.c b/drivers/pinctrl/pinctrl-rockchip.c
index 6a7a11e488bd..016c54bc1050 100644
--- a/drivers/pinctrl/pinctrl-rockchip.c
+++ b/drivers/pinctrl/pinctrl-rockchip.c
@@ -887,11 +887,47 @@ static struct rockchip_mux_recalced_data rk3308b_mux_recalced_data[] = {
 
 static struct rockchip_mux_recalced_data rk3328_mux_recalced_data[] = {
 	{
+		.num = 2,
+		.pin = 8,
+		.reg = 0x24,
+		.bit = 0,
+		.mask = 0x3
+	}, {
+		.num = 2,
+		.pin = 9,
+		.reg = 0x24,
+		.bit = 2,
+		.mask = 0x3
+	}, {
+		.num = 2,
+		.pin = 10,
+		.reg = 0x24,
+		.bit = 4,
+		.mask = 0x3
+	}, {
+		.num = 2,
+		.pin = 11,
+		.reg = 0x24,
+		.bit = 6,
+		.mask = 0x3
+	}, {
 		.num = 2,
 		.pin = 12,
 		.reg = 0x24,
 		.bit = 8,
 		.mask = 0x3
+	}, {
+		.num = 2,
+		.pin = 13,
+		.reg = 0x24,
+		.bit = 10,
+		.mask = 0x3
+	}, {
+		.num = 2,
+		.pin = 14,
+		.reg = 0x24,
+		.bit = 12,
+		.mask = 0x3
 	}, {
 		.num = 2,
 		.pin = 15,

commit e0169571c2effbbe7428e3e1f207671295dd7bfc
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Tue Jun 25 09:45:02 2019 +0800

    arm64: rockchip_linux_defconfig: the CONFIG_SND_SOC_RK3308 is unnecessary
    
    Change-Id: Ic91e129dd0a95dfdb1178cfd46395dc2917de1bb
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/arch/arm64/configs/rockchip_linux_defconfig b/arch/arm64/configs/rockchip_linux_defconfig
index 3f86be119970..ad72e09a6940 100644
--- a/arch/arm64/configs/rockchip_linux_defconfig
+++ b/arch/arm64/configs/rockchip_linux_defconfig
@@ -365,7 +365,6 @@ CONFIG_SND_SOC_ROCKCHIP_MAX98090=y
 CONFIG_SND_SOC_ROCKCHIP_MULTICODECS=y
 CONFIG_SND_SOC_ROCKCHIP_RT5645=y
 CONFIG_SND_SOC_ES8316=y
-CONFIG_SND_SOC_RK3308=y
 CONFIG_SND_SOC_RK3328=y
 CONFIG_SND_SOC_RK817=y
 CONFIG_SND_SOC_RT5616=y

commit fae9e5d462687f6c6c6fb164f63ac8e5c0b06669
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Mon Jun 24 18:34:48 2019 +0800

    ASoC: multicodecs&rk3308_codec: handle the request during no codec instance and hp det
    
    If there is no codec instance or headphone jack, we
    should not request headphone jack from machine driver.
    
    Change-Id: If05ac2f4bbfd3fc495a75c0701a44a325e5010cd
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/sound/soc/codecs/rk3308_codec.c b/sound/soc/codecs/rk3308_codec.c
index 82eeedf1fe4c..aadcd7f698fb 100644
--- a/sound/soc/codecs/rk3308_codec.c
+++ b/sound/soc/codecs/rk3308_codec.c
@@ -4251,7 +4251,11 @@ static irqreturn_t rk3308_codec_hpdet_isr(int irq, void *data)
 	return IRQ_HANDLED;
 }
 
-void rk3308_codec_set_jack_detect(struct snd_soc_codec *codec,
+void (*rk3308_codec_set_jack_detect_cb)(struct snd_soc_codec *codec,
+					struct snd_soc_jack *hpdet_jack);
+EXPORT_SYMBOL_GPL(rk3308_codec_set_jack_detect_cb);
+
+static void rk3308_codec_set_jack_detect(struct snd_soc_codec *codec,
 				  struct snd_soc_jack *hpdet_jack)
 {
 	struct rk3308_codec_priv *rk3308 = snd_soc_codec_get_drvdata(codec);
@@ -4262,8 +4266,10 @@ void rk3308_codec_set_jack_detect(struct snd_soc_codec *codec,
 	disable_irq_nosync(rk3308->irq);
 	queue_delayed_work(system_power_efficient_wq,
 			   &rk3308->hpdet_work, msecs_to_jiffies(10));
+
+	dev_info(rk3308->plat_dev, "%s: Request detect hp jack once\n",
+		 __func__);
 }
-EXPORT_SYMBOL_GPL(rk3308_codec_set_jack_detect);
 
 static const struct regmap_config rk3308_codec_regmap_config = {
 	.reg_bits = 32,
@@ -4964,6 +4970,8 @@ static int rk3308_platform_probe(struct platform_device *pdev)
 				     (HPDET_BOTH_NEG_POS << 16) |
 				      HPDET_BOTH_NEG_POS);
 		}
+
+		rk3308_codec_set_jack_detect_cb = rk3308_codec_set_jack_detect;
 	}
 
 	if (rk3308->codec_ver == ACODEC_VERSION_A)
diff --git a/sound/soc/codecs/rk3308_codec_provider.h b/sound/soc/codecs/rk3308_codec_provider.h
index a447f3a92ff4..68042b1328dc 100644
--- a/sound/soc/codecs/rk3308_codec_provider.h
+++ b/sound/soc/codecs/rk3308_codec_provider.h
@@ -21,13 +21,8 @@
 #define __RK3308_CODEC_PROVIDER_H__
 
 #ifdef CONFIG_SND_SOC_RK3308
-void rk3308_codec_set_jack_detect(struct snd_soc_codec *codec,
-				  struct snd_soc_jack *hpdet_jack);
-#else
-static inline void rk3308_codec_set_jack_detect(struct snd_soc_codec *codec,
-						struct snd_soc_jack *hpdet_jack)
-{
-}
+extern void (*rk3308_codec_set_jack_detect_cb)(struct snd_soc_codec *codec,
+					       struct snd_soc_jack *hpdet_jack);
 #endif
 
 #endif /* __RK3308_CODEC_PROVIDER_H__ */
diff --git a/sound/soc/rockchip/rockchip_multicodecs.c b/sound/soc/rockchip/rockchip_multicodecs.c
index 70b640131b8c..9b2a953f82a7 100644
--- a/sound/soc/rockchip/rockchip_multicodecs.c
+++ b/sound/soc/rockchip/rockchip_multicodecs.c
@@ -104,7 +104,8 @@ static int rk_dailink_init(struct snd_soc_pcm_runtime *rtd)
 				      ARRAY_SIZE(mc_hp_jack_pins));
 
 #ifdef CONFIG_SND_SOC_RK3308
-		rk3308_codec_set_jack_detect(rtd->codec, &mc_hp_jack);
+		if (rk3308_codec_set_jack_detect_cb)
+			rk3308_codec_set_jack_detect_cb(rtd->codec, &mc_hp_jack);
 #endif
 
 #ifdef CONFIG_RK_HEADSET

commit c30a2677148ad272553b5bb9647c8968571b3e06
Author: William Wu <william.wu@rock-chips.com>
Date:   Fri Jun 21 09:00:08 2019 +0800

    usb: dwc3: rockchip: fix host mode resume fail for rk3399
    
    Some of the RK3399 sapphire excavator boards have a
    suspend/resume issue with the following error log:
    
    dpm_run_callback(): usb_dev_suspend+0x0/0x30 returns -16
    PM: Device usb6 failed to suspend async: error -16
    PM: Some devices failed to suspend, or early wake event detected
    
    If this error happens, the USB port can't recognize
    any USB device with the failed log:
    
    usb usb5-port1: connect-debounce failed
    
    It's because that the Type-A USB3 port which belongs
    to fe900000.dwc3 is in abnormal state. We can check
    the link state easily via the debug node:
    
    cat /sys/kernel/debug/fe900000.dwc3/link_state
    
    The normal link state is Rx.Detect if no USB device plug
    in. But after resume, the link state will change to Polling.
    According to the USB 3.1 Spec, the link state can change
    from Rx.Detect to Polling state if the USB3 PHY detect
    the far end receiver termination. From that we infer that
    the USB3 PHY affects the USB3 controller link state since
    the USB3 PHY is in power on state when enter suspend.
    
    Actually, it's a common problem if the DWC3 work as Host
    mode in the following cases, and it only happens if system
    enter suspend/resume without any USB device conneted.
    
    Case1. Type-A USB 3.0 interface with dr_mode = "host";
    Case2. Type-A USB 3.0 interface with dr_mode = "otg",
           and set DWC3 to host mode via "dwc3_mode";
    Case3. Type-C USB 3.0 interface with dr_mode = "host";
    Case4. Type-C USB 3.0 interface with dr_mode = "otg",
           and plug in Type-C to Host cable;
    Case5. Type-C USB 3.0 interface with dr_mode = "otg",
           and set DWC3 to host mode via "dwc3_mode";
    
    This patch power off the USB3 PHY if no USB device connect
    with the DWC3 Host port before enter suspend, and power on
    the USB3 PHY again upon resum.
    
    Fixes: 323ccc364014 ("usb: dwc3: rockchip: fix rk3399 dwc3 host power on fail")
    Change-Id: Ifd7805e1f4accb281dd047445d97f4cc954eb5ac
    Signed-off-by: William Wu <william.wu@rock-chips.com>

diff --git a/drivers/usb/dwc3/dwc3-rockchip.c b/drivers/usb/dwc3/dwc3-rockchip.c
index 3fb684235a90..539b89a265ef 100644
--- a/drivers/usb/dwc3/dwc3-rockchip.c
+++ b/drivers/usb/dwc3/dwc3-rockchip.c
@@ -51,6 +51,7 @@ struct dwc3_rockchip {
 	bool			suspended;
 	bool			force_mode;
 	bool			reset_on_resume;
+	bool			is_phy_on;
 	enum usb_dr_mode	original_dr_mode;
 	struct device		*dev;
 	struct clk		**clks;
@@ -497,6 +498,8 @@ static void dwc3_rockchip_otg_extcon_evt_work(struct work_struct *work)
 		if (ret < 0) {
 			phy_power_off(dwc->usb2_generic_phy);
 			dev_err(dwc->dev, "Failed to power on usb3 phy\n");
+		} else {
+			rockchip->is_phy_on = true;
 		}
 
 		pm_runtime_get_sync(dwc->dev);
@@ -586,8 +589,11 @@ disconnect:
 				usb_remove_hcd(hcd);
 			}
 
-			phy_power_off(dwc->usb2_generic_phy);
-			phy_power_off(dwc->usb3_generic_phy);
+			if (rockchip->is_phy_on) {
+				phy_power_off(dwc->usb2_generic_phy);
+				phy_power_off(dwc->usb3_generic_phy);
+				rockchip->is_phy_on = false;
+			}
 		}
 
 		if (DWC3_GCTL_PRTCAP(reg) == DWC3_GCTL_PRTCAP_DEVICE) {
@@ -697,18 +703,29 @@ static void dwc3_rockchip_async_probe(void *data, async_cookie_t cookie)
 		rockchip->connected = true;
 
 		if (!rockchip->reset_on_resume &&
-		    of_machine_is_compatible("rockchip,rk3399")) {
+		    of_machine_is_compatible("rockchip,rk3399") &&
+		    rockchip->dwc->dr_mode == USB_DR_MODE_HOST) {
 			/*
 			 * RK3399 USB 3.0 PHY is Type-C PHY, needs to
 			 * power on USB 3.0 PHY here in addition to
 			 * dwc3_core_init() to prevent it powering
-			 * off USB 3.0 PHY during suspend.
+			 * off USB 3.0 PHY during suspend with USB
+			 * Device connect to the DWC3 Host.
 			 */
+			ret = phy_power_on(dwc->usb2_generic_phy);
+			if (ret < 0) {
+				dev_err(dwc->dev, "Failed to power on usb2 phy\n");
+				goto err;
+			}
+
 			ret = phy_power_on(dwc->usb3_generic_phy);
 			if (ret < 0) {
+				phy_power_off(dwc->usb2_generic_phy);
 				dev_err(dwc->dev, "Failed to power on usb3 phy\n");
 				goto err;
 			}
+
+			rockchip->is_phy_on = true;
 		}
 	}
 
@@ -940,19 +957,33 @@ static int __maybe_unused dwc3_rockchip_suspend(struct device *dev)
 	rockchip->suspended = true;
 	cancel_work_sync(&rockchip->otg_work);
 
-	if (rockchip->edev && dwc->dr_mode != USB_DR_MODE_PERIPHERAL) {
+	/*
+	 * The flag of is_phy_on is only true if
+	 * the DWC3 is in Host mode.
+	 */
+	if (rockchip->is_phy_on) {
+		phy_power_off(dwc->usb2_generic_phy);
+
 		/*
-		 * If USB HOST connected, we will do phy power
-		 * on in extcon evt work, so need to do phy
-		 * power off in suspend. And we just power off
-		 * USB2 PHY here because USB3 PHY power on operation
-		 * need to be done while DWC3 controller is in P2
-		 * state, but after resume DWC3 controller is in
-		 * P0 state. So we put USB3 PHY in power on state.
+		 * If link state is Rx.Detect, it means that
+		 * no usb device is connecting with the DWC3
+		 * Host, and need to power off the USB3 PHY.
+		 *
+		 * If link state is in other state, like U0
+		 * or U3 state, it means that at least one
+		 * USB3 device is connecting with the Host
+		 * port, in this case, we don't power off
+		 * the USB3 PHY because some USB3 PHYs (like
+		 * RK3399 Type-C USB3 PHY) require that the
+		 * power on operation must be done while the
+		 * DWC3 controller is in P2 state, but the
+		 * state is in P0 after resume with a USB3
+		 * device connected. So we set the USB3 PHY
+		 * in power on state in this case.
 		 */
-		if (extcon_get_cable_state_(rockchip->edev,
-					    EXTCON_USB_HOST) > 0)
-			phy_power_off(dwc->usb2_generic_phy);
+		dwc->link_state = dwc3_gadget_get_link_state(dwc);
+		if (dwc->link_state == DWC3_LINK_STATE_RX_DET)
+			phy_power_off(dwc->usb3_generic_phy);
 	}
 
 	return 0;
@@ -971,15 +1002,16 @@ static int __maybe_unused dwc3_rockchip_resume(struct device *dev)
 
 	rockchip->suspended = false;
 
-	if (rockchip->edev)
-		schedule_work(&rockchip->otg_work);
+	if (rockchip->is_phy_on) {
+		phy_power_on(dwc->usb2_generic_phy);
 
-	if (rockchip->edev && dwc->dr_mode != USB_DR_MODE_PERIPHERAL) {
-		if (extcon_get_cable_state_(rockchip->edev,
-					    EXTCON_USB_HOST) > 0)
-			phy_power_on(dwc->usb2_generic_phy);
+		if (dwc->link_state == DWC3_LINK_STATE_RX_DET)
+			phy_power_on(dwc->usb3_generic_phy);
 	}
 
+	if (rockchip->edev)
+		schedule_work(&rockchip->otg_work);
+
 	return 0;
 }
 

commit e8b9e4c471ffcdcd634b3185b956f1c23b20a0ec
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Fri Jun 21 14:57:32 2019 +0800

    dt-bindings: sound: rockchip: i2s-tdm: add 'rockchip,io-multiplex' property
    
    Change-Id: I417d438ca727d030c743e96767a049e095755b3e
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/Documentation/devicetree/bindings/sound/rockchip,i2s-tdm.txt b/Documentation/devicetree/bindings/sound/rockchip,i2s-tdm.txt
index db130be87d47..c4fcbe501885 100644
--- a/Documentation/devicetree/bindings/sound/rockchip,i2s-tdm.txt
+++ b/Documentation/devicetree/bindings/sound/rockchip,i2s-tdm.txt
@@ -20,6 +20,8 @@ Required properties:
 - rockchip,cru: cru phandle.
 - rockchip,grf: the phandle of the syscon node for GRF register.
 - rockchip,mclk-calibrate: enable mclk source calibration.
+- rockchip,io-multiplex: This is a boolean property. If present, the driver will
+  handle the IO multiplex during playback and capture.
 - rockchip,clk-trcm: tx and rx lrck/bclk common use.
    - 0: both tx_lrck/bclk and rx_lrck/bclk are used
    - 1: only tx_lrck/bclk is used

commit 2e9ef0327a4819b8a27715383e23496903be7a0e
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Thu Jun 20 01:08:18 2019 +0800

    ASoC: rockchip: i2s_tdm: add support handle 'io-multiplex' property
    
    Some i2s bus GPIOs maybe designed multiplex, the default
    is input, we need to configure IN/OUT dynamically.
    
    Change-Id: I2e0f0f972d6f9fa3fc8e8fc9f5dfd5d4e6deaee1
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/sound/soc/rockchip/rockchip_i2s_tdm.c b/sound/soc/rockchip/rockchip_i2s_tdm.c
index a4ebb32da83d..ad2aaec71cc4 100644
--- a/sound/soc/rockchip/rockchip_i2s_tdm.c
+++ b/sound/soc/rockchip/rockchip_i2s_tdm.c
@@ -31,6 +31,7 @@
 
 #define DEFAULT_MCLK_FS				256
 #define CH_GRP_MAX				4  /* The max channel 8 / 2 */
+#define MULTIPLEX_CH_MAX			10
 
 struct txrx_config {
 	u32 addr;
@@ -41,6 +42,8 @@ struct txrx_config {
 
 struct rk_i2s_soc_data {
 	u32 softrst_offset;
+	u32 grf_reg_offset;
+	u32 grf_shift;
 	int tx_reset_id;
 	int rx_reset_id;
 	int config_count;
@@ -76,6 +79,7 @@ struct rk_i2s_tdm_dev {
 	struct rk_i2s_soc_data *soc_data;
 	void __iomem *cru_base;
 	bool is_master_mode;
+	bool io_multiplex;
 	bool mclk_calibrate;
 	bool tdm_mode;
 	unsigned int mclk_rx_freq;
@@ -88,6 +92,28 @@ struct rk_i2s_tdm_dev {
 	spinlock_t lock; /* xfer lock */
 };
 
+static int to_ch_num(unsigned int val)
+{
+	int chs;
+
+	switch (val) {
+	case I2S_CHN_4:
+		chs = 4;
+		break;
+	case I2S_CHN_6:
+		chs = 6;
+		break;
+	case I2S_CHN_8:
+		chs = 8;
+		break;
+	default:
+		chs = 2;
+		break;
+	}
+
+	return chs;
+}
+
 static int i2s_tdm_runtime_suspend(struct device *dev)
 {
 	struct rk_i2s_tdm_dev *i2s_tdm = dev_get_drvdata(dev);
@@ -846,6 +872,86 @@ static int rockchip_i2s_tdm_hw_params(struct snd_pcm_substream *substream,
 				   I2S_TXCR_VDW_MASK | I2S_TXCR_CSR_MASK,
 				   val);
 
+	if (i2s_tdm->io_multiplex) {
+		int usable_chs = MULTIPLEX_CH_MAX;
+
+		if (substream->stream == SNDRV_PCM_STREAM_CAPTURE) {
+			struct snd_pcm_str *playback_str =
+				&substream->pcm->streams[SNDRV_PCM_STREAM_PLAYBACK];
+
+			if (playback_str->substream_opened) {
+				regmap_read(i2s_tdm->regmap, I2S_TXCR, &val);
+				val &= I2S_TXCR_CSR_MASK;
+				usable_chs = MULTIPLEX_CH_MAX - to_ch_num(val);
+			}
+
+			regmap_read(i2s_tdm->regmap, I2S_RXCR, &val);
+			val &= I2S_RXCR_CSR_MASK;
+
+			if (to_ch_num(val) > usable_chs) {
+				dev_err(i2s_tdm->dev,
+					"Capture chs(%d) > usable chs(%d)\n",
+					to_ch_num(val), usable_chs);
+				ret = -EINVAL;
+				goto err;
+			}
+
+			switch (val) {
+			case I2S_CHN_4:
+				val = I2S_IO_6CH_OUT_4CH_IN;
+				break;
+			case I2S_CHN_6:
+				val = I2S_IO_4CH_OUT_6CH_IN;
+				break;
+			case I2S_CHN_8:
+				val = I2S_IO_2CH_OUT_8CH_IN;
+				break;
+			default:
+				val = I2S_IO_8CH_OUT_2CH_IN;
+				break;
+			}
+		} else {
+			struct snd_pcm_str *capture_str =
+				&substream->pcm->streams[SNDRV_PCM_STREAM_CAPTURE];
+
+			if (capture_str->substream_opened) {
+				regmap_read(i2s_tdm->regmap, I2S_RXCR, &val);
+				val &= I2S_RXCR_CSR_MASK;
+				usable_chs = MULTIPLEX_CH_MAX - to_ch_num(val);
+			}
+
+			regmap_read(i2s_tdm->regmap, I2S_TXCR, &val);
+			val &= I2S_TXCR_CSR_MASK;
+
+			if (to_ch_num(val) > usable_chs) {
+				dev_err(i2s_tdm->dev,
+					"Playback chs(%d) > usable chs(%d)\n",
+					to_ch_num(val), usable_chs);
+				ret = -EINVAL;
+				goto err;
+			}
+
+			switch (val) {
+			case I2S_CHN_4:
+				val = I2S_IO_4CH_OUT_6CH_IN;
+				break;
+			case I2S_CHN_6:
+				val = I2S_IO_6CH_OUT_4CH_IN;
+				break;
+			case I2S_CHN_8:
+				val = I2S_IO_8CH_OUT_2CH_IN;
+				break;
+			default:
+				val = I2S_IO_2CH_OUT_8CH_IN;
+				break;
+			}
+		}
+
+		val <<= i2s_tdm->soc_data->grf_shift;
+		val |= (I2S_IO_DIRECTION_MASK << i2s_tdm->soc_data->grf_shift) << 16;
+		regmap_write(i2s_tdm->grf, i2s_tdm->soc_data->grf_reg_offset, val);
+	}
+
 	regmap_update_bits(i2s_tdm->regmap, I2S_DMACR, I2S_DMACR_TDL_MASK,
 			   I2S_DMACR_TDL(16));
 	regmap_update_bits(i2s_tdm->regmap, I2S_DMACR, I2S_DMACR_RDL_MASK,
@@ -1119,6 +1225,8 @@ static struct rk_i2s_soc_data rk1808_i2s_soc_data = {
 
 static struct rk_i2s_soc_data rk3308_i2s_soc_data = {
 	.softrst_offset = 0x0400,
+	.grf_reg_offset = 0x0308,
+	.grf_shift = 5,
 	.configs = rk3308_txrx_config,
 	.config_count = ARRAY_SIZE(rk3308_txrx_config),
 	.init = common_soc_init,
@@ -1354,7 +1462,13 @@ static int rockchip_i2s_tdm_probe(struct platform_device *pdev)
 
 	i2s_tdm->dev = &pdev->dev;
 
+	of_id = of_match_device(rockchip_i2s_tdm_match, &pdev->dev);
+	if (!of_id || !of_id->data)
+		return -EINVAL;
+
 	spin_lock_init(&i2s_tdm->lock);
+	i2s_tdm->soc_data = (struct rk_i2s_soc_data *)of_id->data;
+
 	i2s_tdm->bclk_fs = 64;
 	if (!of_property_read_u32(node, "rockchip,bclk-fs", &val)) {
 		if ((val >= 32) && (val % 2 == 0))
@@ -1379,11 +1493,7 @@ static int rockchip_i2s_tdm_probe(struct platform_device *pdev)
 		i2s_tdm->cru_base = of_iomap(cru_node, 0);
 		if (!i2s_tdm->cru_base)
 			return -ENOENT;
-		of_id = of_match_device(rockchip_i2s_tdm_match, &pdev->dev);
-		if (!of_id || !of_id->data)
-			return -EINVAL;
 
-		i2s_tdm->soc_data = (struct rk_i2s_soc_data *)of_id->data;
 		i2s_tdm->soc_data->tx_reset_id = of_i2s_resetid_get(node, "tx-m");
 		if (i2s_tdm->soc_data->tx_reset_id < 0)
 			return -EINVAL;
@@ -1422,6 +1532,9 @@ static int rockchip_i2s_tdm_probe(struct platform_device *pdev)
 	if (IS_ERR(i2s_tdm->mclk_rx))
 		return PTR_ERR(i2s_tdm->mclk_rx);
 
+	i2s_tdm->io_multiplex =
+		of_property_read_bool(node, "rockchip,io-multiplex");
+
 	i2s_tdm->mclk_calibrate =
 		of_property_read_bool(node, "rockchip,mclk-calibrate");
 	if (i2s_tdm->mclk_calibrate) {
diff --git a/sound/soc/rockchip/rockchip_i2s_tdm.h b/sound/soc/rockchip/rockchip_i2s_tdm.h
index 888ae02106ee..3a69fa276f8f 100644
--- a/sound/soc/rockchip/rockchip_i2s_tdm.h
+++ b/sound/soc/rockchip/rockchip_i2s_tdm.h
@@ -263,6 +263,13 @@ enum {
 #define I2S_CHN_6	(2 << I2S_CSR_SHIFT)
 #define I2S_CHN_8	(3 << I2S_CSR_SHIFT)
 
+/* io direction cfg register */
+#define I2S_IO_DIRECTION_MASK	(7)
+#define I2S_IO_8CH_OUT_2CH_IN	(7)
+#define I2S_IO_6CH_OUT_4CH_IN	(3)
+#define I2S_IO_4CH_OUT_6CH_IN	(1)
+#define I2S_IO_2CH_OUT_8CH_IN	(0)
+
 /* I2S REGS */
 #define I2S_TXCR	(0x0000)
 #define I2S_RXCR	(0x0004)

commit fff810ec2917033374c28487face986ce3c21c40
Author: Weixin Zhou <zwx@rock-chips.com>
Date:   Wed Jun 19 22:29:40 2019 +0800

    PCI: rockchip: DW PCIe controller support reset-gpio undefined case
    
    Change-Id: Ib1e641633b09af9ddea3dc4b0e93a93668a723b2
    Signed-off-by: Weixin Zhou <zwx@rock-chips.com>

diff --git a/drivers/pci/host/pcie-dw-rockchip.c b/drivers/pci/host/pcie-dw-rockchip.c
index a4f7aeafbb9b..a7e8d4b8efe1 100644
--- a/drivers/pci/host/pcie-dw-rockchip.c
+++ b/drivers/pci/host/pcie-dw-rockchip.c
@@ -849,9 +849,9 @@ static int rk_pcie_resource_get(struct platform_device *pdev,
 	if (IS_ERR(rk_pcie->apb_base))
 		return PTR_ERR(rk_pcie->apb_base);
 
-	rk_pcie->rst_gpio = devm_gpiod_get(&pdev->dev, "reset", GPIOD_OUT_HIGH);
+	rk_pcie->rst_gpio = devm_gpiod_get_optional(&pdev->dev, "reset", GPIOD_OUT_HIGH);
 	if (IS_ERR(rk_pcie->rst_gpio)) {
-		dev_err(&pdev->dev, "missing reset-gpios property in node\n");
+		dev_err(&pdev->dev, "invalid reset-gpios property in node\n");
 		return PTR_ERR(rk_pcie->rst_gpio);
 	}
 

commit 639cc5284a055492cd7abe940285bf682b5d7664
Author: Rimon Xu <rimon.xu@rock-chips.com>
Date:   Fri Jun 21 08:46:11 2019 +0800

    video: rockchip: vpu: buffer list max nums up to 50.
    
    If the number of buffers in Import exceeds the original set of 30,
    it will result in each import buffer kicking out the original stored
    buffers, and all subsequent buffers need attachments.
    
    Change-Id: I6e547e1f8943d54995077827ae0d1019e659d797
    Signed-off-by: Rimon Xu <rimon.xu@rock-chips.com>

diff --git a/drivers/video/rockchip/vcodec/vcodec_iommu_ops.h b/drivers/video/rockchip/vcodec/vcodec_iommu_ops.h
index ead745fde2b2..f55a45cc551e 100644
--- a/drivers/video/rockchip/vcodec/vcodec_iommu_ops.h
+++ b/drivers/video/rockchip/vcodec/vcodec_iommu_ops.h
@@ -19,7 +19,7 @@
 #include <linux/platform_device.h>
 #include "vcodec_service.h"
 
-#define BUFFER_LIST_MAX_NUMS	30
+#define BUFFER_LIST_MAX_NUMS	50
 
 #define ALLOCATOR_USE_ION		0x00000000
 #define ALLOCATOR_USE_DRM		0x00000001

commit bdde6c77bb1c46ba41ea9c794402dd05499daebf
Author: Weixin Zhou <zwx@rock-chips.com>
Date:   Fri Jun 21 09:17:10 2019 +0800

    arm64: dts: rockchip: rk3399pro-evb-v13-multi-cam: for multi camera board
    
    Change-Id: I82bd22191a61523bfeec11218fd36a856e9265dc
    Signed-off-by: Weixin Zhou <zwx@rock-chips.com>

diff --git a/Documentation/devicetree/bindings/arm/rockchip.txt b/Documentation/devicetree/bindings/arm/rockchip.txt
index 4066ad478d2a..5b509c18599d 100644
--- a/Documentation/devicetree/bindings/arm/rockchip.txt
+++ b/Documentation/devicetree/bindings/arm/rockchip.txt
@@ -134,7 +134,8 @@ Rockchip platforms device tree bindings
       - compatible = "rockchip,rk3399pro-evb-v10-avb", "rockchip,rk3399pro";
       - compatible = "rockchip,rk3399pro-evb-v11-avb", "rockchip,rk3399pro";
       - compatible = "rockchip,rk3399pro-evb-lp4-v11-avb", "rockchip,rk3399pro";
-      - compatible = "rockchip,rk3399pro-evb-lp4-v11-multi-cam-avb", "rockchip,rk3399pro";
+      - compatible = "rockchip,rk3399pro-evb-v11-multi-cam-avb", "rockchip,rk3399pro";
+      - compatible = "rockchip,rk3399pro-evb-v13-multi-cam", "rockchip,rk3399pro";
 
 - Rockchip RK3326 f863 board:
     Required root node properties:
diff --git a/arch/arm64/boot/dts/rockchip/Makefile b/arch/arm64/boot/dts/rockchip/Makefile
index b878c2377174..41f10b33278e 100644
--- a/arch/arm64/boot/dts/rockchip/Makefile
+++ b/arch/arm64/boot/dts/rockchip/Makefile
@@ -120,6 +120,7 @@ dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11-avb.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11-linux.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v11-multi-cam-avb.dtb
+dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-evb-v13-multi-cam.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-npu-evb-v10.dtb
 dtb-$(CONFIG_ARCH_ROCKCHIP) += rk3399pro-npu-evb-v10-multi-cam.dtb
 
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v13-multi-cam.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v13-multi-cam.dts
new file mode 100644
index 000000000000..70eceacafa78
--- /dev/null
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v13-multi-cam.dts
@@ -0,0 +1,31 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+// Copyright (c) 2018 Fuzhou Rockchip Electronics Co., Ltd.
+
+#include "rk3399pro-evb-v11.dts"
+
+/ {
+	model = "Rockchip RK3399pro evb v13 multi camera board";
+	compatible = "rockchip,rk3399pro-evb-v13-multi-cam", "rockchip,rk3399pro";
+
+	dma_trans: dma_trans@3c000000 {
+		//no-map;
+		reg = <0x0 0x3c000000 0x0 0x04000000>;
+	};
+};
+
+&pcie_phy {
+	status = "okay";
+};
+
+&pcie0 {
+	/delete-property/ ep-gpios;
+	num-lanes = <4>;
+	pinctrl-names = "default";
+	pinctrl-0 = <&pcie_clkreqn_cpm>;
+	max-link-speed = <2>;
+	memory-region = <&dma_trans>;
+	busno = <0>;
+	rockchip,dma_trx_enabled = <1>;
+	rockchip,deferred = <1>;
+	status = "okay";
+};

commit b45124d8885964b1dec3135d04dd0f87381cd799
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Fri May 17 12:13:31 2019 +0800

    dt-bindings: sound: rk3308_codec: add 'rockchip,hp-jack-reversed;' property
    
    Change-Id: I90ded394e8351a8cddd5703268529871f21dfac7
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/Documentation/devicetree/bindings/sound/rockchip,rk3308-codec.txt b/Documentation/devicetree/bindings/sound/rockchip,rk3308-codec.txt
index e1ad7010cab9..e20bbd73e37e 100644
--- a/Documentation/devicetree/bindings/sound/rockchip,rk3308-codec.txt
+++ b/Documentation/devicetree/bindings/sound/rockchip,rk3308-codec.txt
@@ -51,6 +51,7 @@ Optional properties:
   enable headphone detection.
 - rockchip,micbias1: Using internal micbias1 supply which are from codec.
 - rockchip,micbias2: Using internal micbias2 supply which are from codec.
+- rockchip,hp-jack-reversed;: To detect headphone via the reversed jack.
 - hp-ctl-gpios: The gpio of head phone controller.
 - pa-drv-gpios: The gpio of poweramplifier controller
 - rockchip,delay-pa-drv-ms: This property points out that the delay for

commit 484463f3425656d76532b6f461ac1d57ef33e300
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Fri May 17 12:08:26 2019 +0800

    ASoC: rk3308_codec: add support reversed headphone jack
    
    Change-Id: I4752c935684e3b745185cc43b826cad06ff429c5
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/sound/soc/codecs/rk3308_codec.c b/sound/soc/codecs/rk3308_codec.c
index 31ebbcbc249c..82eeedf1fe4c 100644
--- a/sound/soc/codecs/rk3308_codec.c
+++ b/sound/soc/codecs/rk3308_codec.c
@@ -215,6 +215,7 @@ struct rk3308_codec_priv {
 	bool enable_micbias;
 	bool micbias1;
 	bool micbias2;
+	bool hp_jack_reversed;
 	bool hp_plugged;
 	bool loopback_dacs_enabled;
 	bool no_deep_low_power;
@@ -4119,13 +4120,26 @@ static void rk3308_codec_hpdetect_work(struct work_struct *work)
 		regmap_write(rk3308->detect_grf,
 			     DETECT_GRF_ACODEC_HPDET_STATUS_CLR, val);
 
-		switch (val) {
-		case 0x1:
-			dac_output = DAC_HPOUT;
-			report_type = SND_JACK_HEADPHONE;
-			break;
-		default:
-			break;
+		if (rk3308->hp_jack_reversed) {
+			switch (val) {
+			case 0x0:
+			case 0x2:
+				dac_output = DAC_HPOUT;
+				report_type = SND_JACK_HEADPHONE;
+				break;
+			default:
+				break;
+			}
+		} else {
+			switch (val) {
+			case 0x1:
+				dac_output = DAC_HPOUT;
+				report_type = SND_JACK_HEADPHONE;
+				break;
+			default:
+				/* Includes val == 2 or others. */
+				break;
+			}
 		}
 
 		rk3308_codec_dac_switch(rk3308, dac_output);
@@ -4141,18 +4155,35 @@ static void rk3308_codec_hpdetect_work(struct work_struct *work)
 
 	/* Check headphone unplugged via poll. */
 	regmap_read(rk3308->regmap, RK3308_DAC_DIG_CON14, &val);
-	if (!val) {
-		rk3308->hp_plugged = false;
 
-		need_report = 1;
-		need_irq = 1;
-	} else {
-		if (!rk3308->hp_plugged) {
+	if (rk3308->hp_jack_reversed) {
+		if (!val) {
 			rk3308->hp_plugged = true;
 			report_type = SND_JACK_HEADPHONE;
+
 			need_report = 1;
+			need_irq = 1;
+		} else {
+			if (rk3308->hp_plugged) {
+				rk3308->hp_plugged = false;
+				need_report = 1;
+			}
+			need_poll = 1;
+		}
+	} else {
+		if (!val) {
+			rk3308->hp_plugged = false;
+
+			need_report = 1;
+			need_irq = 1;
+		} else {
+			if (!rk3308->hp_plugged) {
+				rk3308->hp_plugged = true;
+				report_type = SND_JACK_HEADPHONE;
+				need_report = 1;
+			}
+			need_poll = 1;
 		}
-		need_poll = 1;
 	}
 
 	if (need_poll)
@@ -4226,6 +4257,11 @@ void rk3308_codec_set_jack_detect(struct snd_soc_codec *codec,
 	struct rk3308_codec_priv *rk3308 = snd_soc_codec_get_drvdata(codec);
 
 	rk3308->hpdet_jack = hpdet_jack;
+
+	/* To detect jack once during startup */
+	disable_irq_nosync(rk3308->irq);
+	queue_delayed_work(system_power_efficient_wq,
+			   &rk3308->hpdet_work, msecs_to_jiffies(10));
 }
 EXPORT_SYMBOL_GPL(rk3308_codec_set_jack_detect);
 
@@ -4819,6 +4855,9 @@ static int rk3308_platform_probe(struct platform_device *pdev)
 	rk3308->enable_all_adcs =
 		of_property_read_bool(np, "rockchip,enable-all-adcs");
 
+	rk3308->hp_jack_reversed =
+		of_property_read_bool(np, "rockchip,hp-jack-reversed");
+
 	rk3308->no_deep_low_power =
 		of_property_read_bool(np, "rockchip,no-deep-low-power");
 

commit 12992228b67ec8fbba3281b492e1191c0c2dd1c2
Author: Cliff Chen <cliff.chen@rock-chips.com>
Date:   Mon Jun 24 08:51:09 2019 +0800

    f2fs: Fix recovery is too slow when power fail on much fsync
    
    By default fsync option, if fsync is called frequently, and suddenly
    lost power, the POR will consume too much memory at mounting, this
    process may be very slow due to a large number of swapping.
    
    Change-Id: I8235098cca062d7ab58af4ebed414aed9aba6c75
    Signed-off-by: Cliff Chen <cliff.chen@rock-chips.com>

diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h
index 2c10b09d9bcf..fb96427997f4 100644
--- a/fs/f2fs/f2fs.h
+++ b/fs/f2fs/f2fs.h
@@ -1335,6 +1335,8 @@ struct f2fs_sb_info {
 	/* migration granularity of garbage collection, unit: segment */
 	unsigned int migration_granularity;
 
+	atomic_t no_cp_fsync_pages;
+
 	/*
 	 * for stat information.
 	 * one is for the LFS mode, and the other is for the SSR mode.
diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
index 637a9dfbd578..78f0c3b78427 100644
--- a/fs/f2fs/file.c
+++ b/fs/f2fs/file.c
@@ -198,6 +198,25 @@ static void try_to_fix_pino(struct inode *inode)
 	up_write(&fi->i_sem);
 }
 
+static bool f2fs_update_fsync_count(struct f2fs_sb_info *sbi,
+					unsigned int npages)
+{
+	struct sysinfo val;
+	unsigned long avail_ram;
+
+	si_meminfo(&val);
+
+	/* only uses low memory */
+	avail_ram = val.totalram - val.totalhigh;
+	avail_ram = (avail_ram * DEF_RAM_THRESHOLD) / 100;
+
+	if ((atomic_read(&sbi->no_cp_fsync_pages) + npages) > avail_ram)
+		return false;
+
+	atomic_add(npages, &sbi->no_cp_fsync_pages);
+	return true;
+}
+
 static int f2fs_do_sync_file(struct file *file, loff_t start, loff_t end,
 						int datasync, bool atomic)
 {
@@ -205,6 +224,7 @@ static int f2fs_do_sync_file(struct file *file, loff_t start, loff_t end,
 	struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
 	nid_t ino = inode->i_ino;
 	int ret = 0;
+	unsigned int npages = 0;
 	enum cp_reason_type cp_reason = 0;
 	struct writeback_control wbc = {
 		.sync_mode = WB_SYNC_ALL,
@@ -223,6 +243,7 @@ static int f2fs_do_sync_file(struct file *file, loff_t start, loff_t end,
 		goto go_write;
 
 	/* if fdatasync is triggered, let's do in-place-update */
+	npages = get_dirty_pages(inode);
 	if (datasync || get_dirty_pages(inode) <= SM_I(sbi)->min_fsync_blocks)
 		set_inode_flag(inode, FI_NEED_IPU);
 	ret = filemap_write_and_wait_range(inode->i_mapping, start, end);
@@ -263,7 +284,7 @@ go_write:
 	cp_reason = need_do_checkpoint(inode);
 	up_read(&F2FS_I(inode)->i_sem);
 
-	if (cp_reason) {
+	if (cp_reason || !f2fs_update_fsync_count(sbi, npages)) {
 		/* all the dirty node pages should be flushed for POR */
 		ret = f2fs_sync_fs(inode->i_sb, 1);
 
diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c
index 463b21e3cd78..84eaa5e76d69 100644
--- a/fs/f2fs/super.c
+++ b/fs/f2fs/super.c
@@ -1140,6 +1140,7 @@ int f2fs_sync_fs(struct super_block *sb, int sync)
 
 		cpc.reason = __get_cp_reason(sbi);
 
+		atomic_set(&sbi->no_cp_fsync_pages, 0);
 		mutex_lock(&sbi->gc_mutex);
 		err = f2fs_write_checkpoint(sbi, &cpc);
 		mutex_unlock(&sbi->gc_mutex);
@@ -3305,6 +3306,8 @@ try_onemore:
 
 	f2fs_build_gc_manager(sbi);
 
+	atomic_set(&sbi->no_cp_fsync_pages, 0);
+
 	err = f2fs_build_stats(sbi);
 	if (err)
 		goto free_nm;

commit a1a13306a4a8f8f78a8cf0cdd4b26322a0ce667d
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Mon Jun 24 10:47:11 2019 +0800

    input: touchscreen: gt9xx: avoid clang warning
    
    drivers/input/touchscreen/gt9xx/gt9xx_update.c:2744:19: warning: equality comparison with extraneous parentheses [-Wparentheses-equality]
     while ((ready == 0)) //Wait for measurement complete
             ~~~~~~^~~~
    
    Change-Id: I6954c7cd8867e1d85d435a23ee857cd4e3c58b4b
    Signed-off-by: Tao Huang <huangtao@rock-chips.com>

diff --git a/drivers/input/touchscreen/gt9xx/gt9xx_update.c b/drivers/input/touchscreen/gt9xx/gt9xx_update.c
index 974d8d829d1a..0cfbf11b9a51 100644
--- a/drivers/input/touchscreen/gt9xx/gt9xx_update.c
+++ b/drivers/input/touchscreen/gt9xx/gt9xx_update.c
@@ -2741,7 +2741,7 @@ static u32 gup_clk_count_get(void)
     s32 temp;
     s8  buf[4];
 
-    while ((ready == 0)) //Wait for measurement complete
+    while (ready == 0) //Wait for measurement complete
     {
         i2c_read_bytes(i2c_connect_client, _bRO_MISCTL__MEA_RDY, buf, 1);
         ready = buf[0];

commit 586f045a76f79d98cbd6f291b5c34c8ffc843649
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Fri Jun 21 18:55:11 2019 +0800

    drivers: rk_nand: include seq_file.h for rk_nand_blk.c
    
    Change-Id: I2736a432c071fae0ff47f7015a87c39a39e07095
    Signed-off-by: Tao Huang <huangtao@rock-chips.com>

diff --git a/drivers/rk_nand/rk_nand_blk.c b/drivers/rk_nand/rk_nand_blk.c
index e35130b4741a..56f698c84496 100644
--- a/drivers/rk_nand/rk_nand_blk.c
+++ b/drivers/rk_nand/rk_nand_blk.c
@@ -29,6 +29,7 @@
 #include <linux/freezer.h>
 #include <linux/kthread.h>
 #include <linux/proc_fs.h>
+#include <linux/seq_file.h>
 #include <linux/version.h>
 #include <linux/soc/rockchip/rk_vendor_storage.h>
 

commit 4b3a2fba5ed0c5c91c4e9f6d980631dd332782cd
Author: Weixin Zhou <zwx@rock-chips.com>
Date:   Thu Jun 20 17:04:25 2019 +0800

    arm64: dts: rockchip: rk3399pro-npu-evb-v10-multi-cam: dma address needs to match the host
    
    Change-Id: If541d9d3343abb6090026aa1bae1c842e17b601b
    Signed-off-by: Weixin Zhou <zwx@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
index 8e522053b48c..6d94385ec575 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
@@ -22,8 +22,8 @@
 		#size-cells = <2>;
 		ranges;
 
-		dma_trans: dma_trans@70000000 {
-			reg = <0x0 0x70000000 0x0 0x04000000>;
+		dma_trans: dma_trans@3c000000 {
+			reg = <0x0 0x3c000000 0x0 0x04000000>;
 		};
 	};
 

commit e4c8c984c81c639f6485a47c65f5754d9dc7a074
Author: Yifeng Zhao <zyf@rock-chips.com>
Date:   Thu Jun 20 14:08:52 2019 +0800

    Revert "drivers: mtd: nand: fix cs configuration error during nand initialization"
    
    This reverts commit 362a761161cbea16cb30cdbd53071c08c5ba95ed.
    
    Change-Id: I492d2e15b0d948921613a56e61b920d0885d6699
    Signed-off-by: Yifeng Zhao <zyf@rock-chips.com>

diff --git a/drivers/mtd/nand/rockchip_nand_v6.c b/drivers/mtd/nand/rockchip_nand_v6.c
index 6fcf2fefd866..f1ba2cd00c94 100644
--- a/drivers/mtd/nand/rockchip_nand_v6.c
+++ b/drivers/mtd/nand/rockchip_nand_v6.c
@@ -637,7 +637,7 @@ static int rk_nandc_chips_init(struct device *dev, struct rk_nandc *nandc)
 			nand_dev_id = chip->read_byte(mtd);
 			chip->select_chip(mtd, -1);
 		} else {
-			chip->select_chip(mtd, bank_idx);
+			chip->select_chip(mtd, chipnr);
 			chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
 			chip->cmdfunc(mtd, NAND_CMD_READID, 0x00, -1);
 			if (nand_maf_id != chip->read_byte(mtd) ||
diff --git a/drivers/mtd/nand/rockchip_nand_v9.c b/drivers/mtd/nand/rockchip_nand_v9.c
index b2ff9d1d1365..9e6591d3e069 100644
--- a/drivers/mtd/nand/rockchip_nand_v9.c
+++ b/drivers/mtd/nand/rockchip_nand_v9.c
@@ -622,7 +622,7 @@ static int rk_nandc_chips_init(struct device *dev, struct rk_nandc *nandc)
 			nand_dev_id = chip->read_byte(mtd);
 			chip->select_chip(mtd, -1);
 		} else {
-			chip->select_chip(mtd, bank_idx);
+			chip->select_chip(mtd, chipnr);
 			chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
 			chip->cmdfunc(mtd, NAND_CMD_READID, 0x00, -1);
 			if (nand_maf_id != chip->read_byte(mtd) ||

commit 3060dc302c00a59d74975a6dbb24bfb68ba4c3ec
Author: Wyon Bi <bivvy.bi@rock-chips.com>
Date:   Wed Jun 19 08:58:20 2019 +0800

    drm/rockchip: dsi: do turnaround request manually is only required for rk3288 dsi1
    
    Test on RK3399
    
    Fixes: f324dff25289 ("drm/rockchip: dsi: Send turnaround request after a read request for dsi1")
    Change-Id: Id1fad1e8c7c742291bdbd77082dd872093ad549e
    Signed-off-by: Wyon Bi <bivvy.bi@rock-chips.com>

diff --git a/drivers/gpu/drm/rockchip/dw-mipi-dsi.c b/drivers/gpu/drm/rockchip/dw-mipi-dsi.c
index 4b5a685355c6..2d1db3983d40 100644
--- a/drivers/gpu/drm/rockchip/dw-mipi-dsi.c
+++ b/drivers/gpu/drm/rockchip/dw-mipi-dsi.c
@@ -605,7 +605,7 @@ static int dw_mipi_dsi_turn_around_request(struct dw_mipi_dsi *dsi)
 	 * assign dphy_tx1_phyturnrequest = grf_dphy_tx1rx1_basedir ?
 	 * dphy_tx1_phyturnrequest_i : grf_dphy_tx1rx1_turnrequest[0]
 	 */
-	if (!IS_DSI1(dsi))
+	if (!IS_DSI1(dsi) || dsi->pdata->soc_type != RK3288)
 		return 0;
 
 	/* Set TURNREQUEST_N = 1'b1 */

commit 892eacb3b5de2d1b96634ddb3d88fb865b0d9922
Author: Finley Xiao <finley.xiao@rock-chips.com>
Date:   Tue Jun 18 09:32:32 2019 +0800

    cpufreq: dt: Fix memory leak when cpu on/off
    
    Fixes: e51ed31ccd0f ("cpufreq: dt: Add support to get static power")
    Change-Id: I613a14a061490fb69e913b8c2cf6677757c73ced
    Signed-off-by: Finley Xiao <finley.xiao@rock-chips.com>

diff --git a/drivers/cpufreq/cpufreq-dt.c b/drivers/cpufreq/cpufreq-dt.c
index 4768d24f98b8..b88cafc8b1cf 100644
--- a/drivers/cpufreq/cpufreq-dt.c
+++ b/drivers/cpufreq/cpufreq-dt.c
@@ -367,6 +367,7 @@ static int cpufreq_exit(struct cpufreq_policy *policy)
 	rockchip_cpufreq_set_scale_rate(priv->cpu_dev, 0);
 	rockchip_system_monitor_unregister(priv->mdev_info);
 	kfree(priv->mdevp);
+	kfree(priv->model_data);
 #endif
 	cpufreq_cooling_unregister(priv->cdev);
 	dev_pm_opp_free_cpufreq_table(priv->cpu_dev, &policy->freq_table);
@@ -410,7 +411,6 @@ static void cpufreq_ready(struct cpufreq_policy *policy)
 {
 	struct private_data *priv = policy->driver_data;
 	struct device_node *np = of_node_get(priv->cpu_dev->of_node);
-	int ret;
 
 	if (WARN_ON(!np))
 		return;
@@ -426,14 +426,14 @@ static void cpufreq_ready(struct cpufreq_policy *policy)
 				     &power_coefficient);
 
 #ifdef CONFIG_ARCH_ROCKCHIP
-		ret = rockchip_ipa_power_model_init(priv->cpu_dev,
-						    "cpu_leakage",
-						    &priv->model_data);
-		if (!ret) {
+		priv->model_data = rockchip_ipa_power_model_init(priv->cpu_dev,
+								 "cpu_leakage");
+		if (!IS_ERR_OR_NULL(priv->model_data)) {
 			priv->cdev = of_cpufreq_power_cooling_register(np,
 					policy->related_cpus, power_coefficient,
 					cpufreq_get_static_power);
 		} else {
+			priv->model_data = NULL;
 			priv->cdev = of_cpufreq_power_cooling_register(np,
 					policy->related_cpus, power_coefficient,
 					NULL);
diff --git a/drivers/soc/rockchip/rockchip_ipa.c b/drivers/soc/rockchip/rockchip_ipa.c
index 5c5be82aefeb..d0f707d4fcd0 100644
--- a/drivers/soc/rockchip/rockchip_ipa.c
+++ b/drivers/soc/rockchip/rockchip_ipa.c
@@ -4,6 +4,7 @@
  */
 #include <linux/kernel.h>
 #include <linux/of.h>
+#include <linux/slab.h>
 #include <linux/thermal.h>
 #include <soc/rockchip/rockchip_ipa.h>
 #include <soc/rockchip/rockchip_opp_select.h>
@@ -11,17 +12,26 @@
 
 #define FALLBACK_STATIC_TEMPERATURE 55000
 
-int rockchip_ipa_power_model_init(struct device *dev, char *lkg_name,
-				  struct ipa_power_model_data **data)
+/**
+ * rockchip_ipa_power_model_init() - initialise ipa power model parameter
+ * @dev:	device for which we do this operation
+ * @lkg_name:	nvmem cell name from nvmem-cell-names property
+ *
+ * Return: a valid struct ipa_power_model_data pointer on success, and the onwer
+ * should use kfree to release the memory by itself. on failure, it returns a
+ * corresponding ERR_PTR().
+ */
+struct ipa_power_model_data *rockchip_ipa_power_model_init(struct device *dev,
+							   char *lkg_name)
 {
 	struct device_node *model_node;
 	struct ipa_power_model_data *model_data;
 	const char *tz_name;
 	int ret;
 
-	model_data = devm_kzalloc(dev, sizeof(*model_data), GFP_KERNEL);
+	model_data = kzalloc(sizeof(*model_data), GFP_KERNEL);
 	if (!model_data)
-		return -ENOMEM;
+		return ERR_PTR(-ENOMEM);
 
 	model_node = of_find_compatible_node(dev->of_node,
 					     NULL, "simple-power-model");
@@ -61,13 +71,12 @@ int rockchip_ipa_power_model_init(struct device *dev, char *lkg_name,
 	rockchip_of_get_leakage(dev, lkg_name, &model_data->leakage);
 	of_property_read_u32(model_node, "ref-leakage",
 			     &model_data->ref_leakage);
-	*data = model_data;
 
-	return 0;
+	return model_data;
 err:
-	devm_kfree(dev, model_data);
+	kfree(model_data);
 
-	return ret;
+	return ERR_PTR(ret);
 }
 EXPORT_SYMBOL(rockchip_ipa_power_model_init);
 
diff --git a/include/soc/rockchip/rockchip_ipa.h b/include/soc/rockchip/rockchip_ipa.h
index a8589c023868..896bc7cc760b 100644
--- a/include/soc/rockchip/rockchip_ipa.h
+++ b/include/soc/rockchip/rockchip_ipa.h
@@ -15,17 +15,16 @@ struct ipa_power_model_data {
 };
 
 #ifdef CONFIG_ROCKCHIP_IPA
-int rockchip_ipa_power_model_init(struct device *dev, char *lkg_name,
-				  struct ipa_power_model_data **data);
+struct ipa_power_model_data *rockchip_ipa_power_model_init(struct device *dev,
+							   char *lkg_name);
 unsigned long
 rockchip_ipa_get_static_power(struct ipa_power_model_data *model_data,
 			      unsigned long voltage_mv);
 #else
-static inline int
-rockchip_ipa_power_model_init(struct device *dev, char *lkg_name,
-			      struct ipa_power_model_data **data)
+static inline struct ipa_power_model_data *
+rockchip_ipa_power_model_init(struct device *dev, char *lkg_name)
 {
-	return -ENOTSUPP;
+	return ERR_PTR(-ENOTSUPP);
 };
 
 static inline unsigned long

commit 408ea389fba2b4711cd4fef0c5c5e4b54744bcd7
Author: Finley Xiao <finley.xiao@rock-chips.com>
Date:   Wed May 29 15:50:20 2019 +0800

    soc: rockchip: ipa: Get leakage when ipa power model init
    
    Change-Id: Ib0f7855c6faa54fa5ca28010d1c05da8ba478d7e
    Signed-off-by: Finley Xiao <finley.xiao@rock-chips.com>

diff --git a/drivers/cpufreq/cpufreq-dt.c b/drivers/cpufreq/cpufreq-dt.c
index 3eb90d6ab49d..4768d24f98b8 100644
--- a/drivers/cpufreq/cpufreq-dt.c
+++ b/drivers/cpufreq/cpufreq-dt.c
@@ -427,10 +427,9 @@ static void cpufreq_ready(struct cpufreq_policy *policy)
 
 #ifdef CONFIG_ARCH_ROCKCHIP
 		ret = rockchip_ipa_power_model_init(priv->cpu_dev,
+						    "cpu_leakage",
 						    &priv->model_data);
 		if (!ret) {
-			rockchip_of_get_leakage(priv->cpu_dev, "cpu_leakage",
-						&priv->model_data->leakage);
 			priv->cdev = of_cpufreq_power_cooling_register(np,
 					policy->related_cpus, power_coefficient,
 					cpufreq_get_static_power);
diff --git a/drivers/soc/rockchip/rockchip_ipa.c b/drivers/soc/rockchip/rockchip_ipa.c
index 37ee0dbe1e5b..5c5be82aefeb 100644
--- a/drivers/soc/rockchip/rockchip_ipa.c
+++ b/drivers/soc/rockchip/rockchip_ipa.c
@@ -6,11 +6,12 @@
 #include <linux/of.h>
 #include <linux/thermal.h>
 #include <soc/rockchip/rockchip_ipa.h>
+#include <soc/rockchip/rockchip_opp_select.h>
 #include <trace/events/thermal.h>
 
 #define FALLBACK_STATIC_TEMPERATURE 55000
 
-int rockchip_ipa_power_model_init(struct device *dev,
+int rockchip_ipa_power_model_init(struct device *dev, char *lkg_name,
 				  struct ipa_power_model_data **data)
 {
 	struct device_node *model_node;
@@ -57,6 +58,7 @@ int rockchip_ipa_power_model_init(struct device *dev,
 		ret = -EINVAL;
 		goto err;
 	}
+	rockchip_of_get_leakage(dev, lkg_name, &model_data->leakage);
 	of_property_read_u32(model_node, "ref-leakage",
 			     &model_data->ref_leakage);
 	*data = model_data;
diff --git a/include/soc/rockchip/rockchip_ipa.h b/include/soc/rockchip/rockchip_ipa.h
index 9525f45a17c1..a8589c023868 100644
--- a/include/soc/rockchip/rockchip_ipa.h
+++ b/include/soc/rockchip/rockchip_ipa.h
@@ -15,14 +15,14 @@ struct ipa_power_model_data {
 };
 
 #ifdef CONFIG_ROCKCHIP_IPA
-int rockchip_ipa_power_model_init(struct device *dev,
+int rockchip_ipa_power_model_init(struct device *dev, char *lkg_name,
 				  struct ipa_power_model_data **data);
 unsigned long
 rockchip_ipa_get_static_power(struct ipa_power_model_data *model_data,
 			      unsigned long voltage_mv);
 #else
 static inline int
-rockchip_ipa_power_model_init(struct device *dev,
+rockchip_ipa_power_model_init(struct device *dev, char *lkg_name,
 			      struct ipa_power_model_data **data)
 {
 	return -ENOTSUPP;

commit 5e7bba81599ef19dcae6bc63e3f3c159b3a2827c
Author: William Wu <william.wu@rock-chips.com>
Date:   Mon Jun 17 20:26:17 2019 +0800

    usb: gadget: rndis: fix class definitions for windows
    
    The RNDIS gadget function has USB class of 2 and subclass
    of 2, which matches "USB\Class_02&SubClass_02" in the
    usbser.inf file in the Windows system, so the device is
    initially detected as a COM port instead of RNDIS. This
    is why we need to install RNDIS manually.
    
    Refer to Defined Class Codes [1] and rndis_host of Linux [2],
    this patch sets the RNDIS gadget with base class of 0xE0h
    (Wireless Controller) and subclass of 0x01h and protocol
    of 0x03h.
    
    [1] https://www.usb.org/defined-class-codes
    [2] http://www.embedded-os.de/en/proto-rndis_host.shtml
    
    Change-Id: Ida366749f378a0ce770d707b4ba56b87f9e188cf
    Signed-off-by: William Wu <william.wu@rock-chips.com>

diff --git a/drivers/usb/gadget/function/f_rndis.c b/drivers/usb/gadget/function/f_rndis.c
index 3a28d8ac3b3d..39c6c56447ef 100644
--- a/drivers/usb/gadget/function/f_rndis.c
+++ b/drivers/usb/gadget/function/f_rndis.c
@@ -127,9 +127,9 @@ static struct usb_interface_descriptor rndis_control_intf = {
 	/* .bInterfaceNumber = DYNAMIC */
 	/* status endpoint is optional; this could be patched later */
 	.bNumEndpoints =	1,
-	.bInterfaceClass =	USB_CLASS_COMM,
-	.bInterfaceSubClass =   USB_CDC_SUBCLASS_ACM,
-	.bInterfaceProtocol =   USB_CDC_ACM_PROTO_VENDOR,
+	.bInterfaceClass =	USB_CLASS_WIRELESS_CONTROLLER,
+	.bInterfaceSubClass =	1,
+	.bInterfaceProtocol =   3,
 	/* .iInterface = DYNAMIC */
 };
 
@@ -188,9 +188,9 @@ rndis_iad_descriptor = {
 
 	.bFirstInterface =	0, /* XXX, hardcoded */
 	.bInterfaceCount = 	2,	// control + data
-	.bFunctionClass =	USB_CLASS_COMM,
-	.bFunctionSubClass =	USB_CDC_SUBCLASS_ETHERNET,
-	.bFunctionProtocol =	USB_CDC_PROTO_NONE,
+	.bFunctionClass =	USB_CLASS_WIRELESS_CONTROLLER,
+	.bFunctionSubClass =	1,
+	.bFunctionProtocol =	3,
 	/* .iFunction = DYNAMIC */
 };
 

commit cb63e4cc13ae85f5e2449f238270e6b49f3baca8
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Wed Jun 19 11:20:26 2019 +0800

    arm64: dts: rk3399pro: using multicodec sound for rt5651 codec
    
    We need to export Headphone Jack snd ctl to userspace
    on linux platform via multicodec machine driver.
    
    Change-Id: I5664a0b29dfda2ed8cc450a5f0fd388d32dfdd48
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
index c1e0fe456798..43c039b9018b 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
@@ -148,25 +148,13 @@
 		};
 	};
 
-	rk809-sound {
-		compatible = "simple-audio-card";
-		simple-audio-card,format = "i2s";
-		simple-audio-card,name = "rockchip,rk809-codec";
-		simple-audio-card,mclk-fs = <256>;
-		simple-audio-card,widgets =
-			"Microphone", "Mic Jack",
-			"Headphone", "Headphone Jack";
-		simple-audio-card,routing =
-			"Mic Jack", "MICBIAS1",
-			"IN1P", "Mic Jack",
-			"Headphone Jack", "HPOL",
-			"Headphone Jack", "HPOR";
-		simple-audio-card,cpu {
-			sound-dai = <&i2s1>;
-		};
-		simple-audio-card,codec {
-			sound-dai = <&rk809_codec>;
-		};
+	rk809_sound: rk809-sound {
+		compatible = "rockchip,multicodecs-card";
+		rockchip,card-name = "rockchip,rk809-codec";
+		rockchip,codec-hp-det;
+		rockchip,mclk-fs = <256>;
+		rockchip,cpu = <&i2s1>;
+		rockchip,codec = <&rk809_codec>;
 	};
 
 	hdmi_sound: hdmi-sound {
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
index 8d62062eb966..a9eb4f01a43c 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
@@ -148,25 +148,13 @@
 		};
 	};
 
-	rk809-sound {
-		compatible = "simple-audio-card";
-		simple-audio-card,format = "i2s";
-		simple-audio-card,name = "rockchip,rk809-codec";
-		simple-audio-card,mclk-fs = <256>;
-		simple-audio-card,widgets =
-			"Microphone", "Mic Jack",
-			"Headphone", "Headphone Jack";
-		simple-audio-card,routing =
-			"Mic Jack", "MICBIAS1",
-			"IN1P", "Mic Jack",
-			"Headphone Jack", "HPOL",
-			"Headphone Jack", "HPOR";
-		simple-audio-card,cpu {
-			sound-dai = <&i2s1>;
-		};
-		simple-audio-card,codec {
-			sound-dai = <&rk809_codec>;
-		};
+	rk809_sound: rk809-sound {
+		compatible = "rockchip,multicodecs-card";
+		rockchip,card-name = "rockchip,rk809-codec";
+		rockchip,codec-hp-det;
+		rockchip,mclk-fs = <256>;
+		rockchip,cpu = <&i2s1>;
+		rockchip,codec = <&rk809_codec>;
 	};
 
 	hdmi_sound: hdmi-sound {

commit bb94c30573fdfdf010ac5b068b24cff7fd84b09a
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Wed Jun 19 11:02:16 2019 +0800

    arm64: dts: rk3399: using multicodec sound for rt5651 codec
    
    We need to export Headphone Jack snd ctl to userspace
    on linux platform via multicodec machine driver.
    
    Change-Id: I1d042b080ab45f303f7c1a4100a2dd8014d923bc
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi b/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi
index 9b19576a7d43..441d46a595ec 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi
@@ -69,7 +69,7 @@
 		};
 	};
 
-	rt5651-sound {
+	rt5651_sound: rt5651-sound {
 		status = "okay";
 		compatible = "simple-audio-card";
 		simple-audio-card,format = "i2s";
diff --git a/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
index 7c69075f9515..1836dbc6a7dc 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
@@ -406,6 +406,15 @@
 	status = "okay";
 };
 
+&rt5651_sound {
+	compatible = "rockchip,multicodecs-card";
+	rockchip,card-name = "rockchip,rt5651-codec";
+	rockchip,codec-hp-det;
+	rockchip,mclk-fs = <256>;
+	rockchip,cpu = <&i2s0>;
+	rockchip,codec = <&rt5651>;
+};
+
 &saradc {
 	vref-supply = <&vccadc_ref>;
 };

commit 150909a9b354fca74b11cc4ea6f08c8fc64dd533
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Wed Jun 19 10:31:56 2019 +0800

    ASoC: rockchip: multicodecs: update headphone jack
    
    We need to specify a pin description to create a
    new soc jack kctl and report to userspace.
    
    Change-Id: I46f665bd4009c0779a5c9cc3f6b9d43123b54883
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/sound/soc/rockchip/rockchip_multicodecs.c b/sound/soc/rockchip/rockchip_multicodecs.c
index ff4fcf3e0022..70b640131b8c 100644
--- a/sound/soc/rockchip/rockchip_multicodecs.c
+++ b/sound/soc/rockchip/rockchip_multicodecs.c
@@ -48,6 +48,17 @@ struct multicodecs_data {
 };
 
 static struct snd_soc_jack mc_hp_jack;
+static struct snd_soc_jack_pin mc_hp_jack_pins[] = {
+	{
+		/*
+		 * The name of pin must be 'Headphone', it will be combine
+		 * 'Jack' as 'Headphone Jack', then, the ALSA UCM will identify
+		 * it.
+		 */
+		.pin = "Headphone",
+		.mask = SND_JACK_HEADPHONE,
+	},
+};
 
 static int rk_multicodecs_hw_params(struct snd_pcm_substream *substream,
 				    struct snd_pcm_hw_params *params)
@@ -86,9 +97,11 @@ static int rk_dailink_init(struct snd_soc_pcm_runtime *rtd)
 	struct multicodecs_data *mc_data = snd_soc_card_get_drvdata(rtd->card);
 
 	if (mc_data->codec_hp_det) {
-		snd_soc_card_jack_new(rtd->card, "Headphones",
+		snd_soc_card_jack_new(rtd->card, "Headphone Jack",
 				      SND_JACK_HEADPHONE,
-				      &mc_hp_jack, NULL, 0);
+				      &mc_hp_jack,
+				      mc_hp_jack_pins,
+				      ARRAY_SIZE(mc_hp_jack_pins));
 
 #ifdef CONFIG_SND_SOC_RK3308
 		rk3308_codec_set_jack_detect(rtd->codec, &mc_hp_jack);

commit 480771a97d9f8523b6d8054f2d1defd0374b1acc
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Tue Jun 18 19:19:32 2019 +0800

    ASoC: rockchip: multicodecs: add rk_headset_set_jack_detect
    
    For the legacy issues, we still need to call rk_headset
    on some linux platform.
    
    Change-Id: I395de2b8c1300b1cd7cb429dce852ef12bfe2f4c
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/sound/soc/rockchip/rockchip_multicodecs.c b/sound/soc/rockchip/rockchip_multicodecs.c
index 517d081abac8..ff4fcf3e0022 100644
--- a/sound/soc/rockchip/rockchip_multicodecs.c
+++ b/sound/soc/rockchip/rockchip_multicodecs.c
@@ -36,6 +36,10 @@
 #define WAIT_CARDS	(SNDRV_CARDS - 1)
 #define DEFAULT_MCLK_FS	256
 
+#ifdef CONFIG_RK_HEADSET
+extern void rk_headset_set_jack_detect(struct snd_soc_jack *jack);
+#endif
+
 struct multicodecs_data {
 	struct snd_soc_card snd_card;
 	struct snd_soc_dai_link dai_link;
@@ -89,6 +93,10 @@ static int rk_dailink_init(struct snd_soc_pcm_runtime *rtd)
 #ifdef CONFIG_SND_SOC_RK3308
 		rk3308_codec_set_jack_detect(rtd->codec, &mc_hp_jack);
 #endif
+
+#ifdef CONFIG_RK_HEADSET
+		rk_headset_set_jack_detect(&mc_hp_jack);
+#endif
 	}
 
 	return 0;

commit e8949686cbfe60048567e11884c5b2ba9a433959
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Mon Jun 17 19:14:39 2019 +0800

    rk_headset: add support jack report
    
    This patch supports Jack's event report switching Audio
    paths on public platforms.
    
    Change-Id: I83e395f81fb60a2b446a309fae820d26d7df4661
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/drivers/headset_observe/rk_headset_irq_hook_adc.c b/drivers/headset_observe/rk_headset_irq_hook_adc.c
index 53a0525f7bd0..e75880ebfa77 100644
--- a/drivers/headset_observe/rk_headset_irq_hook_adc.c
+++ b/drivers/headset_observe/rk_headset_irq_hook_adc.c
@@ -35,6 +35,8 @@
 #include <linux/wakelock.h>
 #include <linux/gpio.h>
 
+#include <sound/jack.h>
+#include <sound/soc.h>
 #include <asm/atomic.h>
 
 #include "rk_headset.h"
@@ -109,6 +111,17 @@ struct headset_priv {
 };
 static struct headset_priv *headset_info;
 
+static struct snd_soc_jack *hpdet_jack;
+
+void rk_headset_set_jack_detect(struct snd_soc_jack *jack)
+{
+	hpdet_jack = jack;
+
+	/* Send an initial empty report */
+	snd_soc_jack_report(jack, 0, SND_JACK_HEADSET);
+}
+EXPORT_SYMBOL_GPL(rk_headset_set_jack_detect);
+
 //1
 static irqreturn_t headset_interrupt(int irq, void *dev_id)
 {
@@ -224,6 +237,27 @@ static irqreturn_t headset_interrupt(int irq, void *dev_id)
 
 		switch_set_state(&headset_info->sdev, headset_info->cur_headset_status);	
 		DBG("headset notice android headset status = %d\n",headset_info->cur_headset_status);		
+
+		if (hpdet_jack) {
+			int report_type = 0;
+
+			switch (headset_info->cur_headset_status) {
+			case BIT_HEADSET:
+				report_type = SND_JACK_HEADSET;
+				break;
+			case BIT_HEADSET_NO_MIC:
+				report_type = SND_JACK_HEADPHONE;
+				break;
+			default:
+				break;
+			}
+
+			DBG("%s: report type: 0x%x\n", __func__, report_type);
+
+			snd_soc_jack_report(hpdet_jack,
+					    report_type,
+					    SND_JACK_HEADPHONE);
+		}
 	}	
 //	rk_send_wakeup_key();	
 out:
@@ -308,6 +342,27 @@ static void hook_once_work(struct work_struct *work)
 	
 	switch_set_state(&headset_info->sdev, headset_info->cur_headset_status);	
 	DBG("%s notice android headset status = %d\n",__func__,headset_info->cur_headset_status);
+
+	if (hpdet_jack) {
+		int report_type = 0;
+
+		switch (headset_info->cur_headset_status) {
+		case BIT_HEADSET:
+			report_type = SND_JACK_HEADSET;
+			break;
+		case BIT_HEADSET_NO_MIC:
+			report_type = SND_JACK_HEADPHONE;
+			break;
+		default:
+			break;
+		}
+
+		DBG("%s: report type: 0x%x\n", __func__, report_type);
+
+		snd_soc_jack_report(hpdet_jack,
+				    report_type,
+				    SND_JACK_HEADPHONE);
+	}
 }
 
 //2

commit 48a7471142d1d8f009e6ae505f00070ceb146957
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Wed Jun 19 13:11:03 2019 +0800

    arm64: rockchip_linux_defconfig: enable rockchip multicodec machine driver
    
    Change-Id: Ib0bfe4cd980ca983ef32ee8cb2267b27f7505161
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/arch/arm64/configs/rockchip_linux_defconfig b/arch/arm64/configs/rockchip_linux_defconfig
index 8f0b4808b31d..3f86be119970 100644
--- a/arch/arm64/configs/rockchip_linux_defconfig
+++ b/arch/arm64/configs/rockchip_linux_defconfig
@@ -362,6 +362,7 @@ CONFIG_SND_SOC=y
 CONFIG_SND_SOC_ROCKCHIP=y
 CONFIG_SND_SOC_ROCKCHIP_SPDIF=y
 CONFIG_SND_SOC_ROCKCHIP_MAX98090=y
+CONFIG_SND_SOC_ROCKCHIP_MULTICODECS=y
 CONFIG_SND_SOC_ROCKCHIP_RT5645=y
 CONFIG_SND_SOC_ES8316=y
 CONFIG_SND_SOC_RK3308=y

commit 1f50b7dbea57321115f579f347e905f9a06379a4
Author: Xing Zheng <zhengxing@rock-chips.com>
Date:   Tue Jun 18 11:11:00 2019 +0800

    arm64: rockchip_linux_defconfig: enable rkheadset and switch
    
    Some legacy hardware reference designs are based on the
    driver configuration of rk_headset, we need to open it
    by default.
    
    Change-Id: I15758e15da3a6c76f8cc021749ce9fee1905f72a
    Signed-off-by: Xing Zheng <zhengxing@rock-chips.com>

diff --git a/arch/arm64/configs/rockchip_linux_defconfig b/arch/arm64/configs/rockchip_linux_defconfig
index bb677542693d..8f0b4808b31d 100644
--- a/arch/arm64/configs/rockchip_linux_defconfig
+++ b/arch/arm64/configs/rockchip_linux_defconfig
@@ -426,6 +426,7 @@ CONFIG_NEW_LEDS=y
 CONFIG_LEDS_CLASS=y
 CONFIG_LEDS_GPIO=y
 CONFIG_LEDS_IS31FL32XX=y
+CONFIG_SWITCH=y
 CONFIG_RTC_CLASS=y
 CONFIG_RTC_DRV_HYM8563=y
 CONFIG_RTC_DRV_RK808=y
@@ -474,6 +475,7 @@ CONFIG_PHY_ROCKCHIP_PCIE=y
 CONFIG_ANDROID=y
 CONFIG_NVMEM=y
 CONFIG_ROCKCHIP_EFUSE=y
+CONFIG_RK_HEADSET=y
 CONFIG_ROCKCHIP_SIP=y
 # CONFIG_ACPI is not set
 CONFIG_EXT4_FS=y

commit 51632dfbbeee873d17eb6073a7d8982a8f0d048c
Author: Weixin Zhou <zwx@rock-chips.com>
Date:   Thu May 30 11:35:44 2019 +0800

    arm64: dts: rockchip: rk3399pro-npu-evb-v10-multi-cam: enable pcie
    
    Change-Id: I4bfd9ff8ca44956641e94ce977c0a338f3347b1e
    Signed-off-by: Weixin Zhou <zwx@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
index b2f96fd68d6f..8e522053b48c 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-npu-evb-v10-multi-cam.dts
@@ -17,6 +17,16 @@
 		bootargs = "earlycon=uart8250,mmio32,0xff550000 console=ttyFIQ0 init=/init swiotlb=1 kpti=0";
 	};
 
+	reserved-memory {
+		#address-cells = <2>;
+		#size-cells = <2>;
+		ranges;
+
+		dma_trans: dma_trans@70000000 {
+			reg = <0x0 0x70000000 0x0 0x04000000>;
+		};
+	};
+
 	keys: gpio-keys {
 		compatible = "gpio-keys";
 		pinctrl-names = "default";
@@ -213,6 +223,13 @@
 	status = "okay";
 };
 
+&pcie0 {
+	/delete-property/ reset-gpios;
+	memory-region = <&dma_trans>;
+	busno = <1>;
+	status = "okay";
+};
+
 &rk_rga {
 	status =  "okay";
 };
@@ -238,10 +255,13 @@
 };
 
 &usbdrd3 {
+	extcon = <&u2phy>;
 	status = "okay";
 };
 
 &usbdrd_dwc3 {
+	phys = <&u2phy_otg>;
+	phy-names = "usb2-phy";
 	status = "okay";
 };
 

commit 82a27d2c88dc59615eee98a17db1ba98dfef0a67
Author: Allon Huang <allon.huang@rock-chips.com>
Date:   Mon Jun 10 14:54:50 2019 +0800

    media: i2c: gc2145: Fix code style issue
    
    Change-Id: Iba67ab5db9589983e8f3bf544f8fb6d5ce6d2fb2
    Signed-off-by: Allon Huang <allon.huang@rock-chips.com>

diff --git a/drivers/media/i2c/gc2145.c b/drivers/media/i2c/gc2145.c
index 64fe3196fd28..00e39e72c39d 100644
--- a/drivers/media/i2c/gc2145.c
+++ b/drivers/media/i2c/gc2145.c
@@ -1821,11 +1821,11 @@ static const struct sensor_register gc2145_mipi_svga_30fps[] = {
 	{0x25, 0x01},
 	{0x26, 0xac},
 
-	{0x27, 0x05},//4e2 pad
+	{0x27, 0x05},/* 4e2 pad */
 	{0x28, 0x04},
-	{0x29, 0x05},//6d6 pad
+	{0x29, 0x05},/* 6d6 pad */
 	{0x2a, 0x04},
-	{0x2b, 0x05},//7d0 pad
+	{0x2b, 0x05},/* 7d0 pad */
 	{0x2c, 0x04},
 	{0x2d, 0x05},
 	{0x2e, 0x04},
@@ -2214,7 +2214,6 @@ static int gc2145_set_fmt(struct v4l2_subdev *sd,
 
 		gc2145->frame_size = size;
 		gc2145->format = fmt->format;
-
 	}
 
 	mutex_unlock(&gc2145->lock);
@@ -2228,9 +2227,9 @@ static int gc2145_s_stream(struct v4l2_subdev *sd, int on)
 	int ret = 0;
 
 	dev_info(&client->dev, "%s: on: %d, %dx%d@%d\n", __func__, on,
-				gc2145->frame_size->width,
-				gc2145->frame_size->height,
-				gc2145->frame_size->fps);
+		 gc2145->frame_size->width,
+		 gc2145->frame_size->height,
+		 gc2145->frame_size->fps);
 
 	mutex_lock(&gc2145->lock);
 
@@ -2349,7 +2348,7 @@ static int gc2145_s_frame_interval(struct v4l2_subdev *sd,
 	int ret = 0;
 
 	dev_dbg(&client->dev, "Setting %d/%d frame interval\n",
-		 fi->interval.numerator, fi->interval.denominator);
+		fi->interval.numerator, fi->interval.denominator);
 
 	mutex_lock(&gc2145->lock);
 
@@ -2363,7 +2362,7 @@ static int gc2145_s_frame_interval(struct v4l2_subdev *sd,
 
 	if (gc2145->frame_size != size) {
 		dev_info(&client->dev, "%s match wxh@FPS is %dx%d@%d\n",
-			   __func__, size->width, size->height, size->fps);
+			 __func__, size->width, size->height, size->fps);
 		ret = gc2145_write_array(client, size->regs);
 		if (ret)
 			goto unlock;
@@ -2585,7 +2584,7 @@ static int __gc2145_power_on(struct gc2145 *gc2145)
 
 	if (!IS_ERR(gc2145->supplies)) {
 		ret = regulator_bulk_enable(GC2145_NUM_SUPPLIES,
-			gc2145->supplies);
+					    gc2145->supplies);
 		if (ret < 0)
 			dev_info(dev, "Failed to enable regulators\n");
 
@@ -2645,7 +2644,7 @@ static int gc2145_parse_of(struct gc2145 *gc2145)
 	}
 
 	ret = v4l2_fwnode_endpoint_parse(of_fwnode_handle(endpoint),
-		&gc2145->bus_cfg);
+					 &gc2145->bus_cfg);
 	if (ret) {
 		dev_err(dev, "Failed to parse endpoint\n");
 		of_node_put(endpoint);
@@ -2684,9 +2683,9 @@ static int gc2145_probe(struct i2c_client *client,
 	int ret;
 
 	dev_info(dev, "driver version: %02x.%02x.%02x",
-		DRIVER_VERSION >> 16,
-		(DRIVER_VERSION & 0xff00) >> 8,
-		DRIVER_VERSION & 0x00ff);
+		 DRIVER_VERSION >> 16,
+		 (DRIVER_VERSION & 0xff00) >> 8,
+		 DRIVER_VERSION & 0x00ff);
 
 	gc2145 = devm_kzalloc(&client->dev, sizeof(*gc2145), GFP_KERNEL);
 	if (!gc2145)

commit 48eade26ad008125d7b9e44955d30b637b5f02f9
Author: Allon Huang <allon.huang@rock-chips.com>
Date:   Wed Jun 5 19:56:20 2019 +0800

    media: rockchip: cif: support mipi channel and work mode switching
    
    rk3288 cif can work with mipi channel and switch work mode
    
    Change-Id: Ie8a49cf787617ff5d98ef84cdac761c3ece761c9
    Signed-off-by: Allon Huang <allon.huang@rock-chips.com>

diff --git a/drivers/media/platform/rockchip/cif/Kconfig b/drivers/media/platform/rockchip/cif/Kconfig
index 019cb33fde57..d00d847bb66e 100644
--- a/drivers/media/platform/rockchip/cif/Kconfig
+++ b/drivers/media/platform/rockchip/cif/Kconfig
@@ -10,3 +10,16 @@ config VIDEO_ROCKCHIP_CIF
 	default n
 	help
 	  Support for CIF on the rockchip SoCs like rk312x, rk3288.
+
+choice
+	prompt "rockchip camera sensor interface work mode"
+	depends on VIDEO_ROCKCHIP_CIF
+	default ROCKCHIP_CIF_WORKMODE_PINGPONG
+
+config ROCKCHIP_CIF_WORKMODE_PINGPONG
+	bool "interface works in pingpong mode"
+
+config ROCKCHIP_CIF_WORKMODE_ONEFRAME
+	bool "interface works in oneframe mode"
+
+endchoice
diff --git a/drivers/media/platform/rockchip/cif/capture.c b/drivers/media/platform/rockchip/cif/capture.c
index c83aade86f5a..201ea212e410 100644
--- a/drivers/media/platform/rockchip/cif/capture.c
+++ b/drivers/media/platform/rockchip/cif/capture.c
@@ -31,12 +31,6 @@
 #define STREAM_PAD_SINK				0
 #define STREAM_PAD_SOURCE			1
 
-#define CIF_FETCH_Y_LAST_LINE(VAL) ((VAL) & 0x1fff)
-/* Check if swap y and c in bt1120 mode */
-#define CIF_FETCH_IS_Y_FIRST(VAL) ((VAL) & 0xf)
-
-/* TODO: pingpong mode is not yet supported */
-
 /* Get xsubs and ysubs for fourcc formats
  *
  * @xsubs: horizontal color samples in a 4*4 matrix, for yuv
@@ -367,7 +361,7 @@ static struct v4l2_subdev *get_remote_sensor(struct rkcif_stream *stream)
 static struct rkcif_sensor_info *sd_to_sensor(struct rkcif_device *dev,
 					      struct v4l2_subdev *sd)
 {
-	int i;
+	u32 i;
 
 	for (i = 0; i < dev->num_sensors; ++i)
 		if (dev->sensors[i].sd == sd)
@@ -500,38 +494,81 @@ cif_output_fmt *find_output_fmt(struct rkcif_stream *stream, u32 pixelfmt)
 }
 
 /***************************** stream operations ******************************/
-static void rkcif_assign_new_buffer_oneframe(struct rkcif_stream *stream)
+static void rkcif_assign_new_buffer_oneframe(struct rkcif_stream *stream,
+					     enum rkcif_yuvaddr_state stat)
 {
 	struct rkcif_dummy_buffer *dummy_buf = &stream->dummy_buf;
 	struct rkcif_device *dev = stream->cifdev;
+	struct rkcif_buffer *buffer = NULL;
 	void __iomem *base = dev->base_addr;
+	u32 frm_addr_y, frm_addr_uv;
 
 	/* Set up an empty buffer for the next frame */
 	spin_lock(&stream->vbq_lock);
 	if (!list_empty(&stream->buf_head)) {
-		stream->curr_buf = list_first_entry(&stream->buf_head,
-					struct rkcif_buffer, queue);
-		list_del(&stream->curr_buf->queue);
+		if (stream->frame_phase == CIF_CSI_FRAME0_READY ||
+		    stat == RKCIF_YUV_ADDR_STATE_INIT) {
+			stream->curr_buf = list_first_entry(&stream->buf_head,
+						struct rkcif_buffer, queue);
+			list_del(&stream->curr_buf->queue);
+			buffer = stream->curr_buf;
+		}
+		if (stream->frame_phase == CIF_CSI_FRAME1_READY ||
+		    stat == RKCIF_YUV_ADDR_STATE_INIT) {
+			stream->next_buf = list_first_entry(&stream->buf_head,
+						struct rkcif_buffer, queue);
+			list_del(&stream->next_buf->queue);
+			buffer = stream->next_buf;
+		}
 	} else {
-		stream->curr_buf = NULL;
+		if (stream->frame_phase == CIF_CSI_FRAME0_READY)
+			stream->curr_buf = NULL;
+		if (stream->frame_phase == CIF_CSI_FRAME1_READY)
+			stream->next_buf = NULL;
+		buffer = NULL;
 	}
 	spin_unlock(&stream->vbq_lock);
 
-	if (stream->curr_buf) {
-		write_cif_reg(base, CIF_FRM0_ADDR_Y,
-			      stream->curr_buf->buff_addr[RKCIF_PLANE_Y]);
-		write_cif_reg(base, CIF_FRM0_ADDR_UV,
-			      stream->curr_buf->buff_addr[RKCIF_PLANE_CBCR]);
-		write_cif_reg(base, CIF_FRM1_ADDR_Y,
-			      stream->curr_buf->buff_addr[RKCIF_PLANE_Y]);
-		write_cif_reg(base, CIF_FRM1_ADDR_UV,
-			      stream->curr_buf->buff_addr[RKCIF_PLANE_CBCR]);
+	if (stat == RKCIF_YUV_ADDR_STATE_INIT) {
+		if (stream->curr_buf && stream->next_buf) {
+			write_cif_reg(base, CIF_FRM0_ADDR_Y,
+				      stream->curr_buf->buff_addr[RKCIF_PLANE_Y]);
+			write_cif_reg(base, CIF_FRM0_ADDR_UV,
+				      stream->curr_buf->buff_addr[RKCIF_PLANE_CBCR]);
+			write_cif_reg(base, CIF_FRM1_ADDR_Y,
+				      stream->next_buf->buff_addr[RKCIF_PLANE_Y]);
+			write_cif_reg(base, CIF_FRM1_ADDR_UV,
+				      stream->next_buf->buff_addr[RKCIF_PLANE_CBCR]);
+		} else {
+			v4l2_dbg(1, rkcif_debug, &dev->v4l2_dev, "Drop to dummy buf\n");
+			write_cif_reg(base, CIF_FRM0_ADDR_Y, dummy_buf->dma_addr);
+			write_cif_reg(base, CIF_FRM0_ADDR_UV, dummy_buf->dma_addr);
+			write_cif_reg(base, CIF_FRM1_ADDR_Y, dummy_buf->dma_addr);
+			write_cif_reg(base, CIF_FRM1_ADDR_UV, dummy_buf->dma_addr);
+		}
+
 	} else {
-		v4l2_dbg(1, rkcif_debug, &dev->v4l2_dev, "Buf dropped\n");
-		write_cif_reg(base, CIF_FRM0_ADDR_Y, dummy_buf->dma_addr);
-		write_cif_reg(base, CIF_FRM0_ADDR_UV, dummy_buf->dma_addr);
-		write_cif_reg(base, CIF_FRM1_ADDR_Y, dummy_buf->dma_addr);
-		write_cif_reg(base, CIF_FRM1_ADDR_UV, dummy_buf->dma_addr);
+		if (stream->frame_phase == CIF_CSI_FRAME0_READY) {
+			frm_addr_y = CIF_FRM0_ADDR_Y;
+			frm_addr_uv = CIF_FRM0_ADDR_UV;
+		}
+
+		if (stream->frame_phase == CIF_CSI_FRAME1_READY) {
+			frm_addr_y = CIF_FRM1_ADDR_Y;
+			frm_addr_uv = CIF_FRM1_ADDR_UV;
+		}
+
+		if (buffer) {
+			write_cif_reg(base, frm_addr_y,
+				      buffer->buff_addr[RKCIF_PLANE_Y]);
+			write_cif_reg(base, frm_addr_uv,
+				      buffer->buff_addr[RKCIF_PLANE_CBCR]);
+		} else {
+			write_cif_reg(base, frm_addr_y, dummy_buf->dma_addr);
+			write_cif_reg(base, frm_addr_uv, dummy_buf->dma_addr);
+			v4l2_dbg(1, rkcif_debug, &dev->v4l2_dev,
+				 "frame Drop to dummy buf\n");
+		}
 	}
 }
 
@@ -668,8 +705,6 @@ static void rkcif_csi_get_vc_num(struct rkcif_device *dev,
 	dev->num_channels = vc_num ? vc_num : 1;
 	if (dev->num_channels == 1)
 		dev->channels[0].vc = 0;
-
-	return;
 }
 
 static int rkcif_csi_channel_init(struct rkcif_stream *stream,
@@ -783,7 +818,7 @@ static int rkcif_csi_channel_set(struct rkcif_stream *stream,
 static int rkcif_csi_stream_start(struct rkcif_stream *stream)
 {
 	struct rkcif_device *dev = stream->cifdev;
-	unsigned flags = dev->active_sensor->mbus.flags;
+	unsigned int flags = dev->active_sensor->mbus.flags;
 	struct csi_channel_info *channel;
 
 	stream->frame_idx = 0;
@@ -796,6 +831,7 @@ static int rkcif_csi_stream_start(struct rkcif_stream *stream)
 	rkcif_csi_channel_set(stream, channel);
 
 	stream->state = RKCIF_STATE_STREAMING;
+	dev->workmode = RKCIF_WORKMODE_PINGPONG;
 
 	return 0;
 }
@@ -1067,7 +1103,8 @@ static inline u32 rkcif_scl_ctl(struct rkcif_stream *stream)
 static int rkcif_stream_start(struct rkcif_stream *stream)
 {
 	u32 val, mbus_flags, href_pol, vsync_pol,
-	    xfer_mode = 0, yc_swap = 0, skip_top = 0;
+	    xfer_mode = 0, yc_swap = 0, skip_top = 0,
+	    inputmode = 0, mipimode = 0, workmode = 0;
 	struct rkcif_device *dev = stream->cifdev;
 	struct rkcif_sensor_info *sensor_info;
 	void __iomem *base = dev->base_addr;
@@ -1090,10 +1127,32 @@ static int rkcif_stream_start(struct rkcif_stream *stream)
 			yc_swap = BT1120_YC_SWAP;
 	}
 
-	val = vsync_pol | href_pol | rkcif_determine_input_mode(stream) |
-	      stream->cif_fmt_out->fmt_val | stream->cif_fmt_in->dvp_fmt_val |
-	      xfer_mode | yc_swap;
+	if (dev->active_sensor->mbus.type == V4L2_MBUS_CSI2) {
+		inputmode = INPUT_MODE_MIPI;
+
+		/* if cif is linked with mipi,
+		 * href pol must be set as high active,
+		 * vsyn pol must be set as low active.
+		 */
+		href_pol = HSY_HIGH_ACTIVE;
+		vsync_pol = VSY_LOW_ACTIVE;
+
+		if (stream->cif_fmt_in->fmt_type == CIF_FMT_TYPE_YUV)
+			mipimode = MIPI_MODE_YUV;
+		else if (stream->cif_fmt_in->fmt_type == CIF_FMT_TYPE_RAW)
+			mipimode = MIPI_MODE_RGB;
+		else
+			mipimode = MIPI_MODE_32BITS_BYPASS;
+	} else {
+		inputmode = rkcif_determine_input_mode(stream);
+	}
+
+	val = vsync_pol | href_pol | inputmode | mipimode
+	      | stream->cif_fmt_out->fmt_val
+	      | stream->cif_fmt_in->dvp_fmt_val
+	      | xfer_mode | yc_swap;
 	write_cif_reg(base, CIF_FOR, val);
+
 	val = stream->pixm.width;
 	if (stream->cif_fmt_in->fmt_type == CIF_FMT_TYPE_RAW)
 		val = stream->pixm.width * 2;
@@ -1114,16 +1173,26 @@ static int rkcif_stream_start(struct rkcif_stream *stream)
 		rkcif_assign_new_buffer_pingpong(stream, 1, 0);
 	else
 		/* Set up an buffer for the next frame */
-		rkcif_assign_new_buffer_oneframe(stream);
+		rkcif_assign_new_buffer_oneframe(stream,
+						 RKCIF_YUV_ADDR_STATE_INIT);
 
 	write_cif_reg(base, CIF_INTEN, FRAME_END_EN | PST_INF_FRAME_END);
+
+	if (dev->workmode == RKCIF_WORKMODE_ONEFRAME)
+		workmode = MODE_ONEFRAME;
+	else if (dev->workmode == RKCIF_WORKMODE_PINGPONG)
+		workmode = MODE_PINGPONG;
+	else
+		workmode = MODE_LINELOOP;
+
 	if (dev->chip_id == CHIP_RK1808_CIF &&
 	    rkcif_determine_input_mode(stream) == INPUT_MODE_BT1120) {
+		dev->workmode = RKCIF_WORKMODE_PINGPONG;
 		write_cif_reg(base, CIF_CTRL,
 			      AXI_BURST_16 | MODE_PINGPONG | ENABLE_CAPTURE);
 	} else {
 		write_cif_reg(base, CIF_CTRL,
-			      AXI_BURST_16 | MODE_ONEFRAME | ENABLE_CAPTURE);
+			      AXI_BURST_16 | workmode | ENABLE_CAPTURE);
 	}
 
 	stream->state = RKCIF_STATE_STREAMING;
@@ -1222,8 +1291,11 @@ static int rkcif_start_streaming(struct vb2_queue *queue, unsigned int count)
 		goto destroy_buf;
 	}
 
-	if (dev->active_sensor->mbus.type == V4L2_MBUS_CSI2) {
-		ret = rkcif_csi_stream_start(stream);
+	if (dev->chip_id == CHIP_RK1808_CIF) {
+		if (dev->active_sensor->mbus.type == V4L2_MBUS_CSI2)
+			ret = rkcif_csi_stream_start(stream);
+		else
+			ret = rkcif_stream_start(stream);
 	} else {
 		ret = rkcif_stream_start(stream);
 	}
@@ -1718,7 +1790,7 @@ static void rkcif_vb_done_oneframe(struct rkcif_stream *stream,
 	/* Dequeue a filled buffer */
 	for (i = 0; i < fmt->mplanes; i++) {
 		vb2_set_plane_payload(&vb_done->vb2_buf, i,
-			stream->pixm.plane_fmt[i].sizeimage);
+				      stream->pixm.plane_fmt[i].sizeimage);
 	}
 	vb_done->timestamp = ns_to_timeval(ktime_get_ns());
 	vb2_buffer_done(&vb_done->vb2_buf, VB2_BUF_STATE_DONE);
@@ -1727,8 +1799,8 @@ static void rkcif_vb_done_oneframe(struct rkcif_stream *stream,
 void rkcif_irq_oneframe(struct rkcif_device *cif_dev)
 {
 	/* TODO: xuhf-debug: add stream type */
-	struct rkcif_stream *stream = &cif_dev->stream[0];
-	u32 lastline, lastpix, ctl, cif_frmst, intstat;
+	struct rkcif_stream *stream;
+	u32 lastline, lastpix, ctl, cif_frmst, intstat, frmid;
 	void __iomem *base = cif_dev->base_addr;
 
 	intstat = read_cif_reg(base, CIF_INTSTAT);
@@ -1736,11 +1808,16 @@ void rkcif_irq_oneframe(struct rkcif_device *cif_dev)
 	lastline = read_cif_reg(base, CIF_LAST_LINE);
 	lastpix = read_cif_reg(base, CIF_LAST_PIX);
 	ctl = read_cif_reg(base, CIF_CTRL);
+	frmid = CIF_GET_FRAME_ID(cif_frmst);
 
 	/* There are two irqs enabled:
 	 *  - PST_INF_FRAME_END: cif FIFO is ready, this is prior to FRAME_END
 	 *  -         FRAME_END: cif has saved frame to memory, a frame ready
 	 */
+	if (cif_dev->chip_id == CHIP_RK1808_CIF)
+		stream = &cif_dev->stream[RKCIF_STREAM_DVP];
+	else
+		stream = &cif_dev->stream[RKCIF_STREAM_CIF];
 
 	if ((intstat & PST_INF_FRAME_END)) {
 		write_cif_reg(base, CIF_INTSTAT, PST_INF_FRAME_END_CLR);
@@ -1754,7 +1831,6 @@ void rkcif_irq_oneframe(struct rkcif_device *cif_dev)
 		struct vb2_v4l2_buffer *vb_done = NULL;
 
 		write_cif_reg(base, CIF_INTSTAT, FRAME_END_CLR);
-
 		if (stream->stopping) {
 			rkcif_stream_stop(stream);
 			stream->stopping = false;
@@ -1764,22 +1840,40 @@ void rkcif_irq_oneframe(struct rkcif_device *cif_dev)
 
 		if (lastline != stream->pixm.height ||
 		    !(cif_frmst & CIF_F0_READY)) {
+			/* Clearing status must be complete before fe packet
+			 * arrives while cif is connected with mipi,
+			 * so it should be placed before printing log here,
+			 * otherwise it would be delayed.
+			 * At the same time, don't clear the frame id
+			 * for switching address.
+			 */
+			write_cif_reg(base, CIF_FRAME_STATUS, FRM0_STAT_CLS);
 			v4l2_err(&cif_dev->v4l2_dev,
 				 "Bad frame, irq:0x%x frmst:0x%x size:%dx%d\n",
 				 intstat, cif_frmst, lastline, lastpix);
-			/* Clear status to receive into the same buffer */
-			write_cif_reg(base, CIF_FRAME_STATUS, FRM0_STAT_CLS);
+
 			return;
 		}
 
-		if (stream->curr_buf)
-			vb_done = &stream->curr_buf->vb;
-		rkcif_assign_new_buffer_oneframe(stream);
+		if (frmid % 2 != 0) {
+			stream->frame_phase = CIF_CSI_FRAME0_READY;
+			if (stream->curr_buf)
+				vb_done = &stream->curr_buf->vb;
+		} else {
+			stream->frame_phase = CIF_CSI_FRAME1_READY;
+			if (stream->next_buf)
+				vb_done = &stream->next_buf->vb;
+		}
+
+		rkcif_assign_new_buffer_oneframe(stream,
+						 RKCIF_YUV_ADDR_STATE_UPDATE);
 
-		/* In one-frame mode, must clear status manually to enable
-		 * the next frame end irq
+		/* In one-frame mode:
+		 * 1,must clear status manually by writing 0 to enable
+		 * the next frame end irq;
+		 * 2,do not clear the frame id for switching address.
 		 */
-		write_cif_reg(base, CIF_FRAME_STATUS, FRM0_STAT_CLS);
+		write_cif_reg(base, CIF_FRAME_STATUS, cif_frmst & FRM0_STAT_CLS);
 
 		if (vb_done)
 			rkcif_vb_done_oneframe(stream, vb_done);
@@ -1829,7 +1923,8 @@ void rkcif_irq_pingpong(struct rkcif_device *cif_dev)
 	void __iomem *base = cif_dev->base_addr;
 	unsigned int intstat, i;
 
-	if (cif_dev->active_sensor->mbus.type == V4L2_MBUS_CSI2) {
+	if (cif_dev->active_sensor->mbus.type == V4L2_MBUS_CSI2 &&
+	    cif_dev->chip_id == CHIP_RK1808_CIF) {
 		int mipi_id;
 		struct vb2_v4l2_buffer *vb_done = NULL;
 		u32 lastline = 0;
@@ -1855,8 +1950,8 @@ void rkcif_irq_pingpong(struct rkcif_device *cif_dev)
 		mipi_id = rkcif_csi_g_mipi_id(&cif_dev->v4l2_dev, intstat);
 		if (mipi_id < 0) {
 			v4l2_err(&cif_dev->v4l2_dev,
-					"ERROR: irq[%d] is invalid: 0x%x, lastline: %d, return!!!\n",
-					i, intstat, lastline & 0x3fff);
+				 "ERROR: irq[%d] is invalid: 0x%x, lastline: %d, return!!!\n",
+				 i, intstat, lastline & 0x3fff);
 			return;
 		}
 
@@ -1879,26 +1974,26 @@ void rkcif_irq_pingpong(struct rkcif_device *cif_dev)
 				continue;
 
 			switch (mipi_id) {
-				case RKCIF_STREAM_MIPI_ID0:
-					stream->frame_phase =
-						 SW_FRM_END_ID0(intstat);
-					intstat &= ~CSI_FRAME_END_ID0;
-					break;
-				case RKCIF_STREAM_MIPI_ID1:
-					stream->frame_phase =
-						 SW_FRM_END_ID1(intstat);
-					intstat &= ~CSI_FRAME_END_ID1;
-					break;
-				case RKCIF_STREAM_MIPI_ID2:
-					stream->frame_phase =
-						 SW_FRM_END_ID2(intstat);
-					intstat &= ~CSI_FRAME_END_ID2;
-					break;
-				case RKCIF_STREAM_MIPI_ID3:
-					stream->frame_phase =
-						 SW_FRM_END_ID3(intstat);
-					intstat &= ~CSI_FRAME_END_ID3;
-					break;
+			case RKCIF_STREAM_MIPI_ID0:
+				stream->frame_phase =
+							SW_FRM_END_ID0(intstat);
+				intstat &= ~CSI_FRAME_END_ID0;
+				break;
+			case RKCIF_STREAM_MIPI_ID1:
+				stream->frame_phase =
+							SW_FRM_END_ID1(intstat);
+				intstat &= ~CSI_FRAME_END_ID1;
+				break;
+			case RKCIF_STREAM_MIPI_ID2:
+				stream->frame_phase =
+							SW_FRM_END_ID2(intstat);
+				intstat &= ~CSI_FRAME_END_ID2;
+				break;
+			case RKCIF_STREAM_MIPI_ID3:
+				stream->frame_phase =
+							SW_FRM_END_ID3(intstat);
+				intstat &= ~CSI_FRAME_END_ID3;
+				break;
 			}
 
 			if (stream->frame_phase & CIF_CSI_FRAME1_READY) {
@@ -1919,6 +2014,7 @@ void rkcif_irq_pingpong(struct rkcif_device *cif_dev)
 	} else {
 		u32 lastline, lastpix, ctl, cif_frmst;
 		void __iomem *base = cif_dev->base_addr;
+		struct rkcif_stream *stream;
 
 		intstat = read_cif_reg(base, CIF_INTSTAT);
 		cif_frmst = read_cif_reg(base, CIF_FRAME_STATUS);
@@ -1926,6 +2022,11 @@ void rkcif_irq_pingpong(struct rkcif_device *cif_dev)
 		lastpix = read_cif_reg(base, CIF_LAST_PIX);
 		ctl = read_cif_reg(base, CIF_CTRL);
 
+		if (cif_dev->chip_id == CHIP_RK1808_CIF)
+			stream = &cif_dev->stream[RKCIF_STREAM_DVP];
+		else
+			stream = &cif_dev->stream[RKCIF_STREAM_CIF];
+
 		/* There are two irqs enabled:
 		 *  - PST_INF_FRAME_END: cif FIFO is ready,
 		 *    this is prior to FRAME_END
@@ -1958,7 +2059,7 @@ void rkcif_irq_pingpong(struct rkcif_device *cif_dev)
 			    (!(cif_frmst & CIF_F0_READY) &&
 			     !(cif_frmst & CIF_F1_READY))) {
 				v4l2_err(&cif_dev->v4l2_dev,
-					 "Bad frame, irq:0x%x frmst:0x%x size:%dx%d\n",
+					 "Bad frame, pp irq:0x%x frmst:0x%x size:%dx%d\n",
 					 intstat, cif_frmst, lastline, lastpix);
 				return;
 			}
@@ -1966,14 +2067,15 @@ void rkcif_irq_pingpong(struct rkcif_device *cif_dev)
 			if (cif_frmst & CIF_F0_READY) {
 				if (stream->curr_buf)
 					vb_done = &stream->curr_buf->vb;
-				stream->frame_phase = 0;
+				stream->frame_phase = CIF_CSI_FRAME0_READY;
 			} else if (cif_frmst & CIF_F1_READY) {
 				if (stream->next_buf)
 					vb_done = &stream->next_buf->vb;
-				stream->frame_phase = 1;
+				stream->frame_phase = CIF_CSI_FRAME1_READY;
 			}
 
-			rkcif_assign_new_buffer_pingpong(stream, 0, 0);
+			rkcif_assign_new_buffer_oneframe(stream,
+							 RKCIF_YUV_ADDR_STATE_UPDATE);
 
 			if (vb_done)
 				rkcif_vb_done_oneframe(stream, vb_done);
diff --git a/drivers/media/platform/rockchip/cif/dev.c b/drivers/media/platform/rockchip/cif/dev.c
index 58e0bd29d7fd..73fb4a00b14e 100644
--- a/drivers/media/platform/rockchip/cif/dev.c
+++ b/drivers/media/platform/rockchip/cif/dev.c
@@ -45,8 +45,6 @@ static char rkcif_version[RKCIF_VERNO_LEN];
 module_param_string(version, rkcif_version, RKCIF_VERNO_LEN, 0444);
 MODULE_PARM_DESC(version, "version number");
 
-int using_pingpong;
-
 static DEFINE_MUTEX(rkcif_dev_mutex);
 static LIST_HEAD(rkcif_device_list);
 
@@ -184,7 +182,7 @@ static int rkcif_pipeline_set_stream(struct rkcif_pipeline *p, bool on)
 		rockchip_set_system_status(SYS_STATUS_CIF0);
 
 	/* phy -> sensor */
-	for (i = p->num_subdevs; i > -1; --i) {
+	for (i = p->num_subdevs - 1; i > -1; --i) {
 		ret = v4l2_subdev_call(p->subdevs[i], video, s_stream, on);
 		if (on && ret < 0 && ret != -ENOIOCTLCMD && ret != -ENODEV)
 			goto err_stream_off;
@@ -229,13 +227,13 @@ static int rkcif_create_links(struct rkcif_device *dev)
 				}
 
 				for (id = 0; id < stream_num; id++) {
-					ret = media_entity_create_link(
-							&sensor->sd->entity,
-							pad,
-							&dev->stream[id].vnode.vdev.entity,
-							0,
-							(dev->chip_id != CHIP_RK1808_CIF) | (id == pad - 1) ?
-							MEDIA_LNK_FL_ENABLED : 0);
+					ret = media_entity_create_link(&sensor->sd->entity,
+								       pad,
+								       &dev->stream[id].vnode.vdev.entity,
+								       0,
+								       (dev->chip_id != CHIP_RK1808_CIF) |
+								       (id == pad - 1) ?
+								       MEDIA_LNK_FL_ENABLED : 0);
 					if (ret) {
 						dev_err(dev->dev,
 							"failed to create link for %s\n",
@@ -311,8 +309,8 @@ static int subdev_notifier_bound(struct v4l2_async_notifier *notifier,
 }
 
 static int rkcif_fwnode_parse(struct device *dev,
-			       struct v4l2_fwnode_endpoint *vep,
-			       struct v4l2_async_subdev *asd)
+			      struct v4l2_fwnode_endpoint *vep,
+			      struct v4l2_async_subdev *asd)
 {
 	struct rkcif_async_subdev *rk_asd =
 			container_of(asd, struct rkcif_async_subdev, asd);
@@ -347,7 +345,7 @@ static int cif_subdev_notifier(struct rkcif_device *cif_dev)
 	int ret;
 
 	ret = v4l2_async_notifier_parse_fwnode_endpoints(dev, ntf,
-			sizeof(struct rkcif_async_subdev), rkcif_fwnode_parse);
+							 sizeof(struct rkcif_async_subdev), rkcif_fwnode_parse);
 
 	if (ret < 0)
 		return ret;
@@ -441,7 +439,6 @@ static const char * const rk3288_cif_clks[] = {
 	"aclk_cif0",
 	"hclk_cif0",
 	"cif0_in",
-	"cif0_out",
 };
 
 static const char * const rk3288_cif_rsts[] = {
@@ -505,7 +502,7 @@ static irqreturn_t rkcif_irq_handler(int irq, void *ctx)
 	struct device *dev = ctx;
 	struct rkcif_device *cif_dev = dev_get_drvdata(dev);
 
-	if (using_pingpong)
+	if (cif_dev->workmode == RKCIF_WORKMODE_PINGPONG)
 		rkcif_irq_pingpong(cif_dev);
 	else
 		rkcif_irq_oneframe(cif_dev);
@@ -680,15 +677,13 @@ static int rkcif_plat_probe(struct platform_device *pdev)
 	data = match->data;
 	cif_dev->chip_id = data->chip_id;
 	if (data->chip_id == CHIP_RK1808_CIF) {
-		using_pingpong = 1;
-
-		res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "cif_regs");
+		res = platform_get_resource_byname(pdev,
+						   IORESOURCE_MEM,
+						   "cif_regs");
 		cif_dev->base_addr = devm_ioremap_resource(dev, res);
 		if (IS_ERR(cif_dev->base_addr))
 			return PTR_ERR(cif_dev->base_addr);
 	} else {
-		using_pingpong = 0;
-
 		res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
 		cif_dev->base_addr = devm_ioremap_resource(dev, res);
 		if (IS_ERR(cif_dev->base_addr))
@@ -696,7 +691,7 @@ static int rkcif_plat_probe(struct platform_device *pdev)
 	}
 
 	if (data->clks_num > RKCIF_MAX_BUS_CLK ||
-		data->rsts_num > RKCIF_MAX_RESET) {
+	    data->rsts_num > RKCIF_MAX_RESET) {
 		dev_err(dev, "out of range: clks(%d %d) rsts(%d %d)\n",
 			data->clks_num, RKCIF_MAX_BUS_CLK,
 			data->rsts_num, RKCIF_MAX_RESET);
@@ -704,6 +699,7 @@ static int rkcif_plat_probe(struct platform_device *pdev)
 	}
 	for (i = 0; i < data->clks_num; i++) {
 		struct clk *clk = devm_clk_get(dev, data->clks[i]);
+
 		if (IS_ERR(clk)) {
 			dev_err(dev, "failed to get %s\n", data->clks[i]);
 			return PTR_ERR(clk);
@@ -740,6 +736,14 @@ static int rkcif_plat_probe(struct platform_device *pdev)
 		rkcif_stream_init(cif_dev, RKCIF_STREAM_CIF);
 	}
 
+#if defined(CONFIG_ROCKCHIP_CIF_WORKMODE_PINGPONG)
+	cif_dev->workmode = RKCIF_WORKMODE_PINGPONG;
+#elif defined(CONFIG_ROCKCHIP_CIF_WORKMODE_ONEFRAME)
+	cif_dev->workmode = RKCIF_WORKMODE_ONEFRAME;
+#else
+	cif_dev->workmode = RKCIF_WORKMODE_PINGPONG;
+#endif
+
 	strlcpy(cif_dev->media_dev.model, "rkcif",
 		sizeof(cif_dev->media_dev.model));
 	cif_dev->media_dev.dev = &pdev->dev;
diff --git a/drivers/media/platform/rockchip/cif/dev.h b/drivers/media/platform/rockchip/cif/dev.h
index eaaec9c77223..99150071f722 100644
--- a/drivers/media/platform/rockchip/cif/dev.h
+++ b/drivers/media/platform/rockchip/cif/dev.h
@@ -54,6 +54,17 @@
 #define write_cif_reg_and(base, addr, val) \
 	writel(readl((addr) + (base)) & (val), (addr) + (base))
 
+enum rkcif_workmode {
+	RKCIF_WORKMODE_ONEFRAME = 0x00,
+	RKCIF_WORKMODE_PINGPONG = 0x01,
+	RKCIF_WORKMODE_LINELOOP = 0x02
+};
+
+enum rkcif_yuvaddr_state {
+	RKCIF_YUV_ADDR_STATE_UPDATE = 0x0,
+	RKCIF_YUV_ADDR_STATE_INIT = 0x1
+};
+
 enum rkcif_state {
 	RKCIF_STATE_DISABLED,
 	RKCIF_STATE_READY,
@@ -293,6 +304,7 @@ struct rkcif_device {
 	atomic_t			stream_cnt;
 	atomic_t			fh_cnt;
 	struct mutex                    stream_lock; /* lock between streams */
+	enum rkcif_workmode		workmode;
 };
 
 void rkcif_unregister_stream_vdevs(struct rkcif_device *dev,
diff --git a/drivers/media/platform/rockchip/cif/regs.h b/drivers/media/platform/rockchip/cif/regs.h
index 3ff91189fc83..dc4ed448ea7a 100644
--- a/drivers/media/platform/rockchip/cif/regs.h
+++ b/drivers/media/platform/rockchip/cif/regs.h
@@ -36,6 +36,9 @@
 #define CIF_CUR_DST			0x64
 #define CIF_LAST_LINE			0x68
 #define CIF_LAST_PIX			0x6c
+#define CIF_FETCH_Y_LAST_LINE(val)	((val) & 0x1fff)
+/* Check if swap y and c in bt1120 mode */
+#define CIF_FETCH_IS_Y_FIRST(val)	((val) & 0xf)
 
 /* RK1808 CIF CSI Registers Offset */
 #define CIF_CSI_ID0_CTRL0		0x80
@@ -117,7 +120,11 @@
 
 /* FRAME STATUS */
 #define FRAME_STAT_CLS			0x00
-#define FRM0_STAT_CLS			0x20	/* write 0 to clear frame 0 */
+/* write 0 to clear frame 0 */
+#define FRM0_STAT_CLS			0xfffffffe
+#define FRAME_NUM_SHIFT			(16U)
+#define FRAME_NUM_MASK			(0xffff << FRAME_NUM_SHIFT)
+#define CIF_GET_FRAME_ID(val)		(((val) & FRAME_NUM_MASK) >> FRAME_NUM_SHIFT)
 
 /* CIF FORMAT */
 #define VSY_HIGH_ACTIVE			(0x01 << 0)
@@ -144,6 +151,9 @@
 #define RAW_DATA_WIDTH_8		(0x00 << 11)
 #define RAW_DATA_WIDTH_10		(0x01 << 11)
 #define RAW_DATA_WIDTH_12		(0x02 << 11)
+#define MIPI_MODE_32BITS_BYPASS		(0x00 << 13)
+#define MIPI_MODE_RGB			(0x01 << 13)
+#define MIPI_MODE_YUV			(0x02 << 13)
 #define YUV_OUTPUT_422			(0x00 << 16)
 #define YUV_OUTPUT_420			(0x01 << 16)
 #define OUTPUT_420_ORDER_EVEN		(0x00 << 17)
diff --git a/drivers/media/platform/rockchip/cif/version.h b/drivers/media/platform/rockchip/cif/version.h
index c754b60ea769..6459cc6ed322 100644
--- a/drivers/media/platform/rockchip/cif/version.h
+++ b/drivers/media/platform/rockchip/cif/version.h
@@ -11,12 +11,12 @@
  *v0.1.0:
  *1. First version;
  *v0.1.1
- *support the mipi vc multi-channel input in cif driver for rk1808
+ *1. Support the mipi vc multi-channel input in cif driver for rk1808
  *v0.1.2
- *Compatible with cif only have single dma mode in driver
- *v0.1.2
- *support output yuyv fmt by setting the input mode to raw8
- *
+ *1. support output yuyv fmt by setting the input mode to raw8
+ *2. Compatible with cif only have single dma mode in driver
+ *3. Support cif works with mipi channel for rk3288
+ *4. Support switching between oneframe and pingpong for cif
  */
 
 #define RKCIF_DRIVER_VERSION KERNEL_VERSION(0, 1, 0x2)

commit 8fb5906e02ba97a07196718b8f0715e6c13e9970
Author: Allon Huang <allon.huang@rock-chips.com>
Date:   Wed Jun 5 19:54:50 2019 +0800

    phy: rockchip: mipi-rx: distinguish control object for txrx
    
    txrx can be linked with isp or csi-host, so separate it
    
    Change-Id: I41d81770c53008bdf9703f92834cc41d9724a563
    Signed-off-by: Allon Huang <allon.huang@rock-chips.com>

diff --git a/drivers/phy/rockchip/phy-rockchip-mipi-rx.c b/drivers/phy/rockchip/phy-rockchip-mipi-rx.c
index 5d9c45b338f8..90f241f8d918 100644
--- a/drivers/phy/rockchip/phy-rockchip-mipi-rx.c
+++ b/drivers/phy/rockchip/phy-rockchip-mipi-rx.c
@@ -77,6 +77,8 @@
 #define RK3288_PHY_TEST_CTRL1	0x34
 #define RK3288_PHY_SHUTDOWNZ	0x08
 #define RK3288_PHY_RSTZ		0x0c
+#define RK3288_PHY_N_LANES	0x04
+#define RK3288_PHY_RESETN	0x10
 
 #define RK3399_PHY_TEST_CTRL0	0xb4
 #define RK3399_PHY_TEST_CTRL1	0xb8
@@ -261,6 +263,9 @@ enum txrx_reg_id {
 	TXRX_PHY_TEST_CTRL1,
 	TXRX_PHY_SHUTDOWNZ,
 	TXRX_PHY_RSTZ,
+	TXRX_PHY_N_LANES,
+	TXRX_PHY_ENABLECLK,
+	TXRX_PHY_RESETN
 };
 
 struct dphy_reg {
@@ -370,6 +375,8 @@ static const struct txrx_reg rk3288_txrx_regs[] = {
 	[TXRX_PHY_TEST_CTRL1] = TXRX_REG(RK3288_PHY_TEST_CTRL1),
 	[TXRX_PHY_SHUTDOWNZ] = TXRX_REG(RK3288_PHY_SHUTDOWNZ),
 	[TXRX_PHY_RSTZ] = TXRX_REG(RK3288_PHY_RSTZ),
+	[TXRX_PHY_N_LANES] = TXRX_REG(RK3288_PHY_N_LANES),
+	[TXRX_PHY_RESETN] = TXRX_REG(RK3288_PHY_RESETN),
 };
 
 static const struct txrx_reg rk3399_txrx_regs[] = {
@@ -548,7 +555,7 @@ static inline void write_csiphy_reg(struct mipidphy_priv *priv,
 }
 
 static inline void read_csiphy_reg(struct mipidphy_priv *priv,
-				    int index, u32 *value)
+				   int index, u32 *value)
 {
 	const struct csiphy_reg *reg = &priv->csiphy_regs[index];
 
@@ -587,6 +594,24 @@ static void csi_mipidphy_wr_ths_settle(struct mipidphy_priv *priv, int hsfreq,
 	write_csiphy_reg(priv, offset, val);
 }
 
+static struct v4l2_subdev *get_remote_sink_dev(struct v4l2_subdev *sd)
+{
+	struct media_pad *local, *remote;
+	struct media_entity *sink_me;
+
+	local = &sd->entity.pads[MIPI_DPHY_RX_PAD_SOURCE];
+	remote = media_entity_remote_pad(local);
+	if (!remote) {
+		v4l2_warn(sd, "No link between dphy and cif or isp\n");
+
+		return NULL;
+	}
+
+	sink_me = media_entity_remote_pad(local)->entity;
+
+	return media_entity_to_v4l2_subdev(sink_me);
+}
+
 static struct v4l2_subdev *get_remote_sensor(struct v4l2_subdev *sd)
 {
 	struct media_pad *local, *remote;
@@ -608,9 +633,10 @@ static struct mipidphy_sensor *sd_to_sensor(struct mipidphy_priv *priv,
 {
 	int i;
 
-	for (i = 0; i < priv->num_sensors; ++i)
+	for (i = 0; i < priv->num_sensors; ++i) {
 		if (priv->sensors[i].sd == sd)
 			return &priv->sensors[i];
+	}
 
 	return NULL;
 }
@@ -1007,11 +1033,18 @@ static int mipidphy_txrx_stream_on(struct mipidphy_priv *priv,
 				   struct v4l2_subdev *sd)
 {
 	struct v4l2_subdev *sensor_sd = get_remote_sensor(sd);
+	struct v4l2_subdev *sink_sd = get_remote_sink_dev(sd);
 	struct mipidphy_sensor *sensor = sd_to_sensor(priv, sensor_sd);
 	const struct dphy_drv_data *drv_data = priv->drv_data;
 	const struct hsfreq_range *hsfreq_ranges = drv_data->hsfreq_ranges;
 	int num_hsfreq_ranges = drv_data->num_hsfreq_ranges;
 	int i, hsfreq = 0;
+	bool is_linked_isp;
+
+	if (strstr(sink_sd->name, "csi2"))
+		is_linked_isp = false;
+	else
+		is_linked_isp = true;
 
 	for (i = 0; i < num_hsfreq_ranges; i++) {
 		if (hsfreq_ranges[i].range_h >= priv->data_rate_mbps) {
@@ -1035,7 +1068,10 @@ static int mipidphy_txrx_stream_on(struct mipidphy_priv *priv,
 	 */
 	write_grf_reg(priv, GRF_CON_ISP_DPHY_SEL, 1);
 	write_grf_reg(priv, GRF_DSI_CSI_TESTBUS_SEL, 1);
-	write_grf_reg(priv, GRF_DPHY_RX1_SRC_SEL, 1);
+	if (is_linked_isp)
+		write_grf_reg(priv, GRF_DPHY_RX1_SRC_SEL, 1);
+	else
+		write_grf_reg(priv, GRF_DPHY_RX1_SRC_SEL, 0);
 
 	/*
 	 * Config rk3399嚗?@@ -1047,6 +1083,10 @@ static int mipidphy_txrx_stream_on(struct mipidphy_priv *priv,
 	/* Step1: set RSTZ = 1'b0, phy1-rx controlled by isp */
 
 	/* Step2: set SHUTDOWNZ = 1'b0, phy1-rx controlled by isp */
+	if (!is_linked_isp) {
+		write_txrx_reg(priv, TXRX_PHY_RSTZ, 0);
+		write_txrx_reg(priv, TXRX_PHY_SHUTDOWNZ, 0);
+	}
 
 	/* Step3: set TESTCLR= 1'b1,TESTCLK=1'b1 */
 	write_txrx_reg(priv, TXRX_PHY_TEST_CTRL0, PHY_TESTCLR | PHY_TESTCLK);
@@ -1102,8 +1142,13 @@ static int mipidphy_txrx_stream_on(struct mipidphy_priv *priv,
 	 * is set by isp1,
 	 * if run 3399 here operates grf_soc_con23[0:3]
 	 */
-	write_grf_reg(priv, GRF_DPHY_TX1RX1_ENABLE,
-		      GENMASK(sensor->lanes - 1, 0));
+	if (is_linked_isp) {
+		write_grf_reg(priv, GRF_DPHY_TX1RX1_ENABLE,
+			      GENMASK(sensor->lanes - 1, 0));
+	} else {
+		write_grf_reg(priv, GRF_DPHY_TX1RX1_ENABLECLK, 1);
+		write_txrx_reg(priv, TXRX_PHY_N_LANES, sensor->lanes - 1);
+	}
 
 	/*
 	 * Step13:Set SHUTDOWNZ=1'b1, phy1-rx controlled by isp,
@@ -1111,6 +1156,12 @@ static int mipidphy_txrx_stream_on(struct mipidphy_priv *priv,
 	 */
 
 	/* Step14:Set RSTZ=1'b1, phy1-rx controlled by isp*/
+	if (!is_linked_isp) {
+		write_txrx_reg(priv, TXRX_PHY_SHUTDOWNZ, 1);
+		usleep_range(100, 150);
+		write_txrx_reg(priv, TXRX_PHY_RSTZ, 1);
+		write_txrx_reg(priv, TXRX_PHY_RESETN, 1);
+	}
 
 	/*
 	 * Step15:Wait until STOPSTATEDATA_N & STOPSTATECLK
@@ -1139,8 +1190,9 @@ static int csi_mipidphy_stream_on(struct mipidphy_priv *priv,
 
 	/* set data lane num and enable clock lane */
 	write_csiphy_reg(priv, CSIPHY_CTRL_LANE_ENABLE,
-		((GENMASK(sensor->lanes - 1, 0) << MIPI_CSI_DPHY_CTRL_DATALANE_ENABLE_OFFSET_BIT) |
-		(0x1 << MIPI_CSI_DPHY_CTRL_CLKLANE_ENABLE_OFFSET_BIT) | 0x1));
+			 ((GENMASK(sensor->lanes - 1, 0) <<
+			  MIPI_CSI_DPHY_CTRL_DATALANE_ENABLE_OFFSET_BIT) |
+			  (0x1 << MIPI_CSI_DPHY_CTRL_CLKLANE_ENABLE_OFFSET_BIT) | 0x1));
 
 	/* Reset dphy analog part */
 	write_csiphy_reg(priv, CSIPHY_CTRL_PWRCTL, 0xe0);
@@ -1325,10 +1377,11 @@ rockchip_mipidphy_notifier_bound(struct v4l2_async_notifier *notifier,
 		return -ENXIO;
 	}
 
-	ret = media_entity_create_link(
-			&sensor->sd->entity, pad,
-			&priv->sd.entity, MIPI_DPHY_RX_PAD_SINK,
-			priv->num_sensors != 1 ? 0 : MEDIA_LNK_FL_ENABLED);
+	ret = media_entity_create_link(&sensor->sd->entity, pad,
+				       &priv->sd.entity,
+				       MIPI_DPHY_RX_PAD_SINK,
+				       priv->num_sensors != 1 ? 0 :
+				       MEDIA_LNK_FL_ENABLED);
 	if (ret) {
 		dev_err(priv->dev,
 			"failed to create link for %s\n",
@@ -1415,10 +1468,11 @@ static int rockchip_mipidphy_media_init(struct mipidphy_priv *priv)
 	if (ret < 0)
 		return ret;
 
-	ret = v4l2_async_notifier_parse_fwnode_endpoints_by_port(
-		priv->dev, &priv->notifier,
-		sizeof(struct sensor_async_subdev), 0,
-		rockchip_mipidphy_fwnode_parse);
+	ret = v4l2_async_notifier_parse_fwnode_endpoints_by_port(priv->dev,
+								 &priv->notifier,
+								 sizeof(struct sensor_async_subdev),
+								 0,
+								 rockchip_mipidphy_fwnode_parse);
 	if (ret < 0)
 		return ret;
 
@@ -1490,9 +1544,15 @@ static int rockchip_mipidphy_probe(struct platform_device *pdev)
 		priv->stream_on = mipidphy_txrx_stream_on;
 		priv->txrx_base_addr = NULL;
 		res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
-		priv->txrx_base_addr = devm_ioremap_resource(dev, res);
-		if (IS_ERR(priv->txrx_base_addr))
+		if (res) {
+			priv->txrx_base_addr = devm_ioremap_resource(dev, res);
+			if (IS_ERR(priv->txrx_base_addr)) {
+				dev_err(dev, "Failed to ioremap resource\n");
+				return PTR_ERR(priv->txrx_base_addr);
+			}
+		} else {
 			priv->stream_on = mipidphy_rx_stream_on;
+		}
 		priv->stream_off = NULL;
 	}
 

commit e4ab186bd4e045d84eac603c00c79c082a75c616
Author: Allon Huang <allon.huang@rock-chips.com>
Date:   Wed Jun 5 19:53:45 2019 +0800

    media: rockchip: cif: csi-host compatible with rk3288
    
    Change-Id: I59abdf5088622ba6e556912f5fef39ad75893b11
    Signed-off-by: Allon Huang <allon.huang@rock-chips.com>

diff --git a/drivers/media/platform/rockchip/cif/mipi-csi2.c b/drivers/media/platform/rockchip/cif/mipi-csi2.c
index 25a117678888..f19e3bb88608 100644
--- a/drivers/media/platform/rockchip/cif/mipi-csi2.c
+++ b/drivers/media/platform/rockchip/cif/mipi-csi2.c
@@ -11,6 +11,7 @@
 #include <linux/iopoll.h>
 #include <linux/irq.h>
 #include <linux/module.h>
+#include <linux/of.h>
 #include <linux/of_graph.h>
 #include <linux/platform_device.h>
 #include <media/v4l2-device.h>
@@ -21,11 +22,12 @@
  * there must be 5 pads: 1 input pad from sensor, and
  * the 4 virtual channel output pads
  */
-#define CSI2_SINK_PAD       0
-#define CSI2_NUM_SINK_PADS  1
-#define CSI2_NUM_SRC_PADS   4
-#define CSI2_NUM_PADS       5
-#define MAX_CSI2_SENSORS	2
+#define CSI2_SINK_PAD			0
+#define CSI2_NUM_SINK_PADS		1
+#define CSI2_NUM_SRC_PADS		4
+#define CSI2_NUM_PADS			5
+#define CSI2_NUM_PADS_SINGLE_LINK	2
+#define MAX_CSI2_SENSORS		2
 
 /*
  * The default maximum bit-rate per lane in Mbps, if the
@@ -36,6 +38,13 @@
 #define IMX_MEDIA_GRP_ID_CSI2      BIT(8)
 #define CSIHOST_MAX_ERRINT_COUNT	10
 
+enum rkcsi2_chip_id {
+	CHIP_PX30_CSI2,
+	CHIP_RK1808_CSI2,
+	CHIP_RK3128_CSI2,
+	CHIP_RK3288_CSI2
+};
+
 enum csi2_pads {
 	RK_CSI2_PAD_SINK = 0,
 	RK_CSI2X_PAD_SOURCE0,
@@ -49,6 +58,11 @@ enum host_type_t {
 	RK_DSI_RXHOST
 };
 
+struct csi2_match_data {
+	int chip_id;
+	int num_pads;
+};
+
 struct csi2_sensor {
 	struct v4l2_subdev *sd;
 	struct v4l2_mbus_config mbus;
@@ -73,6 +87,7 @@ struct csi2_dev {
 	struct v4l2_subdev      *src_sd;
 	bool                    sink_linked[CSI2_NUM_SRC_PADS];
 	struct csi2_sensor	sensors[MAX_CSI2_SENSORS];
+	const struct csi2_match_data	*match_data;
 	int num_sensors;
 };
 
@@ -292,9 +307,11 @@ out:
 static int csi2_media_init(struct v4l2_subdev *sd)
 {
 	struct csi2_dev *csi2 = sd_to_dev(sd);
-	int i;
+	int i = 0, num_pads = 0;
 
-	for (i = 0; i < CSI2_NUM_PADS; i++) {
+	num_pads = csi2->match_data->num_pads;
+
+	for (i = 0; i < num_pads; i++) {
 		csi2->pad[i].flags = (i == CSI2_SINK_PAD) ?
 		MEDIA_PAD_FL_SINK : MEDIA_PAD_FL_SOURCE;
 	}
@@ -311,7 +328,7 @@ static int csi2_media_init(struct v4l2_subdev *sd)
 	csi2->format_mbus.height = 1080;
 
 	v4l2_err(&csi2->sd, "media entry init\n");
-	return media_entity_init(&sd->entity, CSI2_NUM_PADS, csi2->pad, 0);
+	return media_entity_init(&sd->entity, num_pads, csi2->pad, 0);
 }
 
 /* csi2 accepts all fmt/size from sensor */
@@ -411,10 +428,9 @@ csi2_notifier_bound(struct v4l2_async_notifier *notifier,
 		return -ENXIO;
 	}
 
-	ret = media_entity_create_link(
-			&sensor->sd->entity, pad,
-			&csi2->sd.entity, RK_CSI2_PAD_SINK,
-			0/* csi2->num_sensors != 1 ? 0 : MEDIA_LNK_FL_ENABLED */);
+	ret = media_entity_create_link(&sensor->sd->entity, pad,
+				       &csi2->sd.entity, RK_CSI2_PAD_SINK,
+				       0/* csi2->num_sensors != 1 ? 0 : MEDIA_LNK_FL_ENABLED */);
 	if (ret) {
 		dev_err(csi2->dev,
 			"failed to create link for %s\n",
@@ -523,17 +539,49 @@ static int csi2_notifier(struct csi2_dev *csi2)
 	return v4l2_async_register_subdev(&csi2->sd);
 }
 
+static const struct csi2_match_data rk1808_csi2_match_data = {
+	.chip_id = CHIP_RK1808_CSI2,
+	.num_pads = CSI2_NUM_PADS
+};
+
+static const struct csi2_match_data rk3288_csi2_match_data = {
+	.chip_id = CHIP_RK3288_CSI2,
+	.num_pads = CSI2_NUM_PADS_SINGLE_LINK
+};
+
+static const struct of_device_id csi2_dt_ids[] = {
+	{
+		.compatible = "rockchip,rk1808-mipi-csi2",
+		.data = &rk1808_csi2_match_data,
+	},
+	{
+		.compatible = "rockchip,rk3288-mipi-csi2",
+		.data = &rk3288_csi2_match_data,
+	},
+	{ /* sentinel */ }
+};
+MODULE_DEVICE_TABLE(of, csi2_dt_ids);
+
 static int csi2_probe(struct platform_device *pdev)
 {
+	const struct of_device_id *match;
+	struct device_node *node = pdev->dev.of_node;
 	struct csi2_dev *csi2 = NULL;
 	struct resource *res;
+	const struct csi2_match_data *data;
 	int ret, irq;
 
+	match = of_match_node(csi2_dt_ids, node);
+	if (IS_ERR(match))
+		return PTR_ERR(match);
+	data = match->data;
+
 	csi2 = devm_kzalloc(&pdev->dev, sizeof(*csi2), GFP_KERNEL);
 	if (!csi2)
 		return -ENOMEM;
 
 	csi2->dev = &pdev->dev;
+	csi2->match_data = data;
 
 	v4l2_subdev_init(&csi2->sd, &csi2_subdev_ops);
 	v4l2_set_subdevdata(&csi2->sd, &pdev->dev);
@@ -555,8 +603,19 @@ static int csi2_probe(struct platform_device *pdev)
 
 	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
 	csi2->base = devm_ioremap_resource(&pdev->dev, res);
-	if (IS_ERR(csi2->base))
-		return PTR_ERR(csi2->base);
+	if (IS_ERR(csi2->base)) {
+		resource_size_t offset = res->start;
+		resource_size_t size = resource_size(res);
+
+		dev_warn(&pdev->dev, "avoid secondary mipi resource check!\n");
+
+		csi2->base = devm_ioremap(&pdev->dev, offset, size);
+		if (IS_ERR(csi2->base)) {
+			dev_err(&pdev->dev, "Failed to ioremap resource\n");
+
+			return PTR_ERR(csi2->base);
+		}
+	}
 
 	irq = platform_get_irq_byname(pdev, "csi-intr1");
 	if (irq > 0) {
@@ -613,14 +672,6 @@ static int csi2_remove(struct platform_device *pdev)
 	return 0;
 }
 
-static const struct of_device_id csi2_dt_ids[] = {
-	{
-		.compatible = "rockchip,rk1808-mipi-csi2",
-	},
-	{ /* sentinel */ }
-};
-MODULE_DEVICE_TABLE(of, csi2_dt_ids);
-
 static struct platform_driver csi2_driver = {
 	.driver = {
 		.name = DEVICE_NAME,

commit 49af652f8d7737a950ba60277c5999efb08cc689
Author: Allon Huang <allon.huang@rock-chips.com>
Date:   Wed Jun 5 19:51:50 2019 +0800

    ARM: dts: rk3288: combine mipi with cif to work
    
    Link mipi with cif to work.
    Meanwhile,replace isp node with rkisp1 node to use
    rkisp driver and remove edp-panel enable pin due to
    it conflicts with dvp pwdn pin on rk3288-evb-v11.
    
    Change-Id: If8125d2173c7340d7d702294ab55ee2f0c433663
    Signed-off-by: Allon Huang <allon.huang@rock-chips.com>

diff --git a/arch/arm/boot/dts/rk3288-evb-rk808-linux.dts b/arch/arm/boot/dts/rk3288-evb-rk808-linux.dts
index d4ab7824205b..93086552b68a 100644
--- a/arch/arm/boot/dts/rk3288-evb-rk808-linux.dts
+++ b/arch/arm/boot/dts/rk3288-evb-rk808-linux.dts
@@ -41,7 +41,6 @@
 /dts-v1/;
 #include "rk3288-evb.dtsi"
 #include "rk3288-linux.dtsi"
-#include "rk3288-rkisp1.dtsi"
 
 / {
 	compatible = "rockchip,rk3288-evb-rk808-linux", "rockchip,rk3288";
@@ -199,10 +198,52 @@
 	};
 };
 
+&cif {
+	status = "okay";
+	port {
+		/* Parallel bus endpoint */
+		/* cif_para_in: endpoint {
+		 *	remote-endpoint = <&cam_para_out1>;
+		 *	bus-width = <8>;
+		 *	hsync-active = <1>;
+		 *	vsync-active = <0>;
+		 * };
+		 */
+
+		/* MIPI CSI-2 endpoint */
+		cif_mipi_in: endpoint {
+			remote-endpoint = <&csi_host_output>;
+		};
+	};
+};
+
 &cpu0 {
 	cpu0-supply = <&vdd_cpu>;
 };
 
+&csi_host {
+	status = "okay";
+	ports {
+		#address-cells = <1>;
+		#size-cells = <0>;
+
+		port@0 {
+			reg = <0>;
+			csi_host_input: endpoint {
+				remote-endpoint = <&dphy_txrx1_out>;
+				data-lanes = <1>;
+			};
+		};
+
+		port@1 {
+			reg = <1>;
+			csi_host_output: endpoint {
+				remote-endpoint = <&cif_mipi_in>;
+			};
+		};
+	};
+};
+
 &dfi {
 	status = "okay";
 };
@@ -219,7 +260,6 @@
 &edp_panel {
 	compatible ="lg,lp079qx1-sp0v", "simple-panel";
 	backlight = <&backlight>;
-	enable-gpios = <&gpio7 4 GPIO_ACTIVE_HIGH>;
 	enable-delay-ms = <120>;
 	pinctrl-0 = <&lcd_cs>;
 	power-supply = <&vcc_lcd>;
@@ -503,6 +543,48 @@
 		rockchip,camera-module-facing = "back";
 	};
 
+	gc2145: gc2145@3c {
+		status = "okay";
+		compatible = "galaxycore,gc2145";
+		reg = <0x3c>;
+		pinctrl-names = "default";
+		pinctrl-0 = <&cif_dvp_d2d9>;
+
+		/* reset-gpios = <&gpio7 5 GPIO_ACTIVE_LOW>; */
+
+		/* pwdn gpio:
+		 * for cam_para_out1: <&gpio2 14 GPIO_ACTIVE_HIGHT>
+		 * for cam_mipi_out1(txrx1): <&gpio7 4 GPIO_ACTIVE_HIGH>
+		 */
+		pwdn-gpios = <&gpio7 4 GPIO_ACTIVE_HIGH>;
+		rockchip,camera-module-index = <1>;
+		rockchip,camera-module-facing = "back";
+		rockchip,camera-module-name = "CMK-OT1055-FG1";
+		rockchip,camera-module-lens-name = "NC";
+
+		clocks = <&cru SCLK_VIP_OUT>;
+		clock-names = "xvclk";
+
+		port {
+			/* Parallel bus endpoint */
+			/* cam_para_out1: endpoint {
+			 *	remote-endpoint = <&cif_para_in>;
+			 *	bus-width = <8>;
+			 *	hsync-active = <1>;
+			 *	vsync-active = <0>;
+			 * };
+			 */
+
+			/* MIPI CSI-2 endpoint */
+			cam_mipi_out1: endpoint {
+				remote-endpoint = <&mipi_sensor_input>;
+				data-lanes = <1>;
+				clock-lanes = <0>;
+				clock-noncontinuous;
+			};
+		};
+	};
+
 	ov13850: ov13850@10 {
 		compatible = "ovti,ov13850";
 		status = "okay";
@@ -527,16 +609,6 @@
 	};
 };
 
-&isp {
-	status = "okay";
-
-	port {
-		isp_mipi_in: endpoint {
-			remote-endpoint = <&dphy_rx0_out>;
-		};
-	};
-};
-
 &isp_mmu {
 	status = "okay";
 };
@@ -567,10 +639,44 @@
 	};
 };
 
+&mipi_phy_tx1rx1 {
+	status = "okay";
+
+	ports {
+		#address-cells = <1>;
+		#size-cells = <0>;
+
+		port@0 {
+			reg = <0>;
+			mipi_sensor_input: endpoint {
+				remote-endpoint = <&cam_mipi_out1>;
+				data-lanes = <1>;
+			};
+		};
+
+		port@1 {
+			reg = <1>;
+			dphy_txrx1_out: endpoint {
+				remote-endpoint = <&csi_host_input>;
+			};
+		};
+	};
+};
+
 &rga {
 	status = "okay";
 };
 
+&rkisp1 {
+	status = "okay";
+
+	port {
+		isp_mipi_in: endpoint {
+			remote-endpoint = <&dphy_rx0_out>;
+		};
+	};
+};
+
 &rockchip_suspend {
 	rockchip,pwm-regulator-config = <
 	(0

commit 27f3f830a96a7239013d2b910320fc5e82368257
Author: Allon Huang <allon.huang@rock-chips.com>
Date:   Wed Jun 5 19:49:21 2019 +0800

    ARM: dts: rk3288: add csi_host and cif_pin
    
    Change-Id: I43f289d3de897ef16098639a57b140c9554de3cd
    Signed-off-by: Allon Huang <allon.huang@rock-chips.com>

diff --git a/arch/arm/boot/dts/rk3288.dtsi b/arch/arm/boot/dts/rk3288.dtsi
index 5c5de01f0c31..9b3d37d6f903 100644
--- a/arch/arm/boot/dts/rk3288.dtsi
+++ b/arch/arm/boot/dts/rk3288.dtsi
@@ -1500,7 +1500,7 @@
 	};
 
 	cif: cif@ff950000 {
-		compatible = "rockchip,cif";
+		compatible = "rockchip,cif", "rockchip,rk3288-cif";
 		reg = <0x0 0xff950000 0x0 0x400>;
 		interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
 		clocks = <&cru ACLK_VIP>, <&cru HCLK_VIP>,
@@ -1594,6 +1594,17 @@
 		status = "disabled";
 	};
 
+	csi_host: mipi-csi-host@ff968000 {
+		compatible = "rockchip,rk3288-mipi-csi2";
+		reg = <0x0 0xff968000 0x0 0x4000>;
+		interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>,
+			     <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>;
+		interrupt-names = "csi-intr1", "csi-intr2";
+		clocks = <&cru PCLK_MIPI_CSI>;
+		clock-names = "pclk_csi2host";
+		status = "disabled";
+	};
+
 	edp: dp@ff970000 {
 		compatible = "rockchip,rk3288-dp";
 		reg = <0x0 0xff970000 0x0 0x4000>;
@@ -2511,22 +2522,6 @@
 			};
 		};
 
-		cif {
-			cif_dvp_d2d9: cif-dvp-d2d9 {
-				rockchip,pins = <2 0 RK_FUNC_1 &pcfg_pull_none>,
-						<2 1 RK_FUNC_1 &pcfg_pull_none>,
-						<2 2 RK_FUNC_1 &pcfg_pull_none>,
-						<2 3 RK_FUNC_1 &pcfg_pull_none>,
-						<2 4 RK_FUNC_1 &pcfg_pull_none>,
-						<2 5 RK_FUNC_1 &pcfg_pull_none>,
-						<2 6 RK_FUNC_1 &pcfg_pull_none>,
-						<2 7 RK_FUNC_1 &pcfg_pull_none>,
-						<2 8 RK_FUNC_1 &pcfg_pull_none>,
-						<2 9 RK_FUNC_1 &pcfg_pull_none>,
-						<2 11 RK_FUNC_1 &pcfg_pull_none>;
-			};
-		};
-
 		isp_pin {
 			isp_mipi: isp-mipi {
 				rockchip,pins =
@@ -2605,7 +2600,35 @@
 			};
 		};
 
+		cif_pin {
+			cif_dvp_d0d1: cif-dvp-d0d1 {
+				rockchip,pins =	<2 12 RK_FUNC_1 &pcfg_pull_none>, /* cif_data0 */
+						<2 13 RK_FUNC_1 &pcfg_pull_none>; /* cif_data1 */
+			};
+
+			cif_dvp_d2d9: cif-dvp-d2d9 {
+				rockchip,pins =	<2 0 RK_FUNC_1 &pcfg_pull_none>, /* cif_data2 */
+						<2 1 RK_FUNC_1 &pcfg_pull_none>, /* cif_data3 */
+						<2 2 RK_FUNC_1 &pcfg_pull_none>, /* cif_data4 */
+						<2 3 RK_FUNC_1 &pcfg_pull_none>, /* cif_data5 */
+						<2 4 RK_FUNC_1 &pcfg_pull_none>, /* cif_data6 */
+						<2 5 RK_FUNC_1 &pcfg_pull_none>, /* cif_data7 */
+						<2 6 RK_FUNC_1 &pcfg_pull_none>, /* cif_data8 */
+						<2 7 RK_FUNC_1 &pcfg_pull_none>, /* cif_data9 */
+						<2 8 RK_FUNC_1 &pcfg_pull_none>, /* cif_sync */
+						<2 9 RK_FUNC_1 &pcfg_pull_none>, /* cif_href */
+						<2 10 RK_FUNC_1 &pcfg_pull_none>, /* cif_clkin */
+						<2 11 RK_FUNC_1 &pcfg_pull_none>; /* cif_clkout */
+			};
+
+			cif_dvp_d10d11: cif-dvp-d10d11 {
+				rockchip,pins = <2 14 RK_FUNC_1 &pcfg_pull_none>, /* cif_data10 */
+						<2 15 RK_FUNC_1 &pcfg_pull_none>; /* cif_data11 */
+			};
+		};
+
 	};
+
 	rockchip_suspend: rockchip-suspend {
 		compatible = "rockchip,pm-rk3288";
 		status = "disabled";

commit f4cd5c18fe39cf69d917a82b5ff76ea0adcb9b4c
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Tue Jun 18 15:20:55 2019 +0800

    video/rockchip: rga2: coding style rm ^M
    
    Change-Id: I6e571211f8fee9f66c3b97b620f13606fc3604ac
    Signed-off-by: Shixiang Zheng <shixiang.zheng@rock-chips.com>

diff --git a/drivers/video/rockchip/rga2/RGA2_API.c b/drivers/video/rockchip/rga2/RGA2_API.c
index 177bad648b0b..0be2c1ae64b6 100644
--- a/drivers/video/rockchip/rga2/RGA2_API.c
+++ b/drivers/video/rockchip/rga2/RGA2_API.c
@@ -1,23 +1,23 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-
-#include <linux/memory.h>
-#include "RGA2_API.h"
-#include "rga2.h"
-//#include "rga_angle.h"
-
-#define IS_YUV_420(format) \
-     ((format == RK_FORMAT_YCbCr_420_P) | (format == RK_FORMAT_YCbCr_420_SP) | \
-      (format == RK_FORMAT_YCrCb_420_P) | (format == RK_FORMAT_YCrCb_420_SP))
-
-#define IS_YUV_422(format) \
-     ((format == RK_FORMAT_YCbCr_422_P) | (format == RK_FORMAT_YCbCr_422_SP) | \
-      (format == RK_FORMAT_YCrCb_422_P) | (format == RK_FORMAT_YCrCb_422_SP))
-
-#define IS_YUV(format) \
-     ((format == RK_FORMAT_YCbCr_420_P) | (format == RK_FORMAT_YCbCr_420_SP) | \
-      (format == RK_FORMAT_YCrCb_420_P) | (format == RK_FORMAT_YCrCb_420_SP) | \
-      (format == RK_FORMAT_YCbCr_422_P) | (format == RK_FORMAT_YCbCr_422_SP) | \
-      (format == RK_FORMAT_YCrCb_422_P) | (format == RK_FORMAT_YCrCb_422_SP))
-
-
-
+
+#include <linux/memory.h>
+#include "RGA2_API.h"
+#include "rga2.h"
+//#include "rga_angle.h"
+
+#define IS_YUV_420(format) \
+     ((format == RK_FORMAT_YCbCr_420_P) | (format == RK_FORMAT_YCbCr_420_SP) | \
+      (format == RK_FORMAT_YCrCb_420_P) | (format == RK_FORMAT_YCrCb_420_SP))
+
+#define IS_YUV_422(format) \
+     ((format == RK_FORMAT_YCbCr_422_P) | (format == RK_FORMAT_YCbCr_422_SP) | \
+      (format == RK_FORMAT_YCrCb_422_P) | (format == RK_FORMAT_YCrCb_422_SP))
+
+#define IS_YUV(format) \
+     ((format == RK_FORMAT_YCbCr_420_P) | (format == RK_FORMAT_YCbCr_420_SP) | \
+      (format == RK_FORMAT_YCrCb_420_P) | (format == RK_FORMAT_YCrCb_420_SP) | \
+      (format == RK_FORMAT_YCbCr_422_P) | (format == RK_FORMAT_YCbCr_422_SP) | \
+      (format == RK_FORMAT_YCrCb_422_P) | (format == RK_FORMAT_YCrCb_422_SP))
+
+
+
diff --git a/drivers/video/rockchip/rga2/RGA2_API.h b/drivers/video/rockchip/rga2/RGA2_API.h
index 2f15e08e5d51..e180b40ac457 100644
--- a/drivers/video/rockchip/rga2/RGA2_API.h
+++ b/drivers/video/rockchip/rga2/RGA2_API.h
@@ -1,13 +1,13 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __RGA_API_H__
-#define __RGA_API_H__
-
-#include "rga2_reg_info.h"
-#include "rga2.h"
-
-#define ENABLE      1
-#define DISABLE     0
-
-
-
-#endif
+#ifndef __RGA_API_H__
+#define __RGA_API_H__
+
+#include "rga2_reg_info.h"
+#include "rga2.h"
+
+#define ENABLE      1
+#define DISABLE     0
+
+
+
+#endif
diff --git a/drivers/video/rockchip/rga2/rga2.h b/drivers/video/rockchip/rga2/rga2.h
index dfd5d76023e5..6b553903ef2f 100644
--- a/drivers/video/rockchip/rga2/rga2.h
+++ b/drivers/video/rockchip/rga2/rga2.h
@@ -1,107 +1,107 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef _RGA_DRIVER_H_
-#define _RGA_DRIVER_H_
-
-#include <linux/mutex.h>
-#include <linux/scatterlist.h>
+#ifndef _RGA_DRIVER_H_
+#define _RGA_DRIVER_H_
+
+#include <linux/mutex.h>
+#include <linux/scatterlist.h>
 #include <linux/dma-buf.h>
-
-
-#define RGA_BLIT_SYNC	0x5017
-#define RGA_BLIT_ASYNC  0x5018
-#define RGA_FLUSH       0x5019
-#define RGA_GET_RESULT  0x501a
-#define RGA_GET_VERSION 0x501b
+
+
+#define RGA_BLIT_SYNC	0x5017
+#define RGA_BLIT_ASYNC  0x5018
+#define RGA_FLUSH       0x5019
+#define RGA_GET_RESULT  0x501a
+#define RGA_GET_VERSION 0x501b
 #define RGA_CACHE_FLUSH 0x501c
-
-#define RGA2_BLIT_SYNC	 0x6017
-#define RGA2_BLIT_ASYNC  0x6018
-#define RGA2_FLUSH       0x6019
-#define RGA2_GET_RESULT  0x601a
-#define RGA2_GET_VERSION 0x601b
-
-
-#define RGA2_REG_CTRL_LEN    0x8    /* 8  */
-#define RGA2_REG_CMD_LEN     0x20   /* 32 */
-#define RGA2_CMD_BUF_SIZE    0x700  /* 16*28*4 */
-
-#define RGA2_OUT_OF_RESOURCES    -10
-#define RGA2_MALLOC_ERROR        -11
-
-#define SCALE_DOWN_LARGE 1
-
-#define rgaIS_ERROR(status)			(status < 0)
-#define rgaNO_ERROR(status)			(status >= 0)
-#define rgaIS_SUCCESS(status)		(status == 0)
-
+
+#define RGA2_BLIT_SYNC	 0x6017
+#define RGA2_BLIT_ASYNC  0x6018
+#define RGA2_FLUSH       0x6019
+#define RGA2_GET_RESULT  0x601a
+#define RGA2_GET_VERSION 0x601b
+
+
+#define RGA2_REG_CTRL_LEN    0x8    /* 8  */
+#define RGA2_REG_CMD_LEN     0x20   /* 32 */
+#define RGA2_CMD_BUF_SIZE    0x700  /* 16*28*4 */
+
+#define RGA2_OUT_OF_RESOURCES    -10
+#define RGA2_MALLOC_ERROR        -11
+
+#define SCALE_DOWN_LARGE 1
+
+#define rgaIS_ERROR(status)			(status < 0)
+#define rgaNO_ERROR(status)			(status >= 0)
+#define rgaIS_SUCCESS(status)		(status == 0)
+
 #define RGA_BUF_GEM_TYPE_MASK      0xC0
 #define RGA_BUF_GEM_TYPE_DMA       0x80
 #define RGA2_MAJOR_VERSION_MASK     (0xFF000000)
 #define RGA2_MINOR_VERSION_MASK     (0x00F00000)
 
-/* RGA2 process mode enum */
-enum
-{
-    bitblt_mode               = 0x0,
-    color_palette_mode        = 0x1,
-    color_fill_mode           = 0x2,
-    update_palette_table_mode = 0x3,
-    update_patten_buff_mode   = 0x4,
-};  /*render mode*/
-
-enum
-{
-    A_B_B =0x0,
-    A_B_C =0x1,
-};  //bitblt_mode select
-
-enum
-{
-    rop_enable_mask          = 0x2,
-    dither_enable_mask       = 0x8,
-    fading_enable_mask       = 0x10,
-    PD_enbale_mask           = 0x20,
-};
-
-
-
-/*
-//          Alpha    Red     Green   Blue
-{  4, 32, {{32,24,   8, 0,  16, 8,  24,16 }}, GGL_RGBA },   // RK_FORMAT_RGBA_8888
-{  4, 24, {{ 0, 0,   8, 0,  16, 8,  24,16 }}, GGL_RGB  },   // RK_FORMAT_RGBX_8888
-{  3, 24, {{ 0, 0,   8, 0,  16, 8,  24,16 }}, GGL_RGB  },   // RK_FORMAT_RGB_888
-{  4, 32, {{32,24,  24,16,  16, 8,   8, 0 }}, GGL_BGRA },   // RK_FORMAT_BGRA_8888
-{  2, 16, {{ 0, 0,  16,11,  11, 5,   5, 0 }}, GGL_RGB  },   // RK_FORMAT_RGB_565
-{  2, 16, {{ 1, 0,  16,11,  11, 6,   6, 1 }}, GGL_RGBA },   // RK_FORMAT_RGBA_5551
-{  2, 16, {{ 4, 0,  16,12,  12, 8,   8, 4 }}, GGL_RGBA },   // RK_FORMAT_RGBA_4444
-{  2, 16, {{ 0, 0,   5, 0   11, 5,   16,11}}, GGL_BGR  },   // RK_FORMAT_BGR_565
-{  2, 16, {{ 1, 0,   6, 1,  11, 6,   16,11}}, GGL_BGRA },   // RK_FORMAT_BGRA_5551
-{  2, 16, {{ 4, 0,   8, 4,  12, 8,   16,12}}, GGL_BGRA },   // RK_FORMAT_BGRA_4444
-
-*/
-enum
-{
-	RGA2_FORMAT_RGBA_8888    = 0x0,
-    RGA2_FORMAT_RGBX_8888    = 0x1,
-    RGA2_FORMAT_RGB_888      = 0x2,
-    RGA2_FORMAT_BGRA_8888    = 0x3,
-    RGA2_FORMAT_BGRX_8888    = 0x4,
-    RGA2_FORMAT_BGR_888      = 0x5,
-    RGA2_FORMAT_RGB_565      = 0x6,
-    RGA2_FORMAT_RGBA_5551    = 0x7,
-    RGA2_FORMAT_RGBA_4444    = 0x8,
-    RGA2_FORMAT_BGR_565      = 0x9,
-    RGA2_FORMAT_BGRA_5551    = 0xa,
-    RGA2_FORMAT_BGRA_4444    = 0xb,
-
-    RGA2_FORMAT_YCbCr_422_SP = 0x10,
-    RGA2_FORMAT_YCbCr_422_P  = 0x11,
-    RGA2_FORMAT_YCbCr_420_SP = 0x12,
-    RGA2_FORMAT_YCbCr_420_P  = 0x13,
-    RGA2_FORMAT_YCrCb_422_SP = 0x14,
-    RGA2_FORMAT_YCrCb_422_P  = 0x15,
-    RGA2_FORMAT_YCrCb_420_SP = 0x16,
-    RGA2_FORMAT_YCrCb_420_P  = 0x17,
+/* RGA2 process mode enum */
+enum
+{
+    bitblt_mode               = 0x0,
+    color_palette_mode        = 0x1,
+    color_fill_mode           = 0x2,
+    update_palette_table_mode = 0x3,
+    update_patten_buff_mode   = 0x4,
+};  /*render mode*/
+
+enum
+{
+    A_B_B =0x0,
+    A_B_C =0x1,
+};  //bitblt_mode select
+
+enum
+{
+    rop_enable_mask          = 0x2,
+    dither_enable_mask       = 0x8,
+    fading_enable_mask       = 0x10,
+    PD_enbale_mask           = 0x20,
+};
+
+
+
+/*
+//          Alpha    Red     Green   Blue
+{  4, 32, {{32,24,   8, 0,  16, 8,  24,16 }}, GGL_RGBA },   // RK_FORMAT_RGBA_8888
+{  4, 24, {{ 0, 0,   8, 0,  16, 8,  24,16 }}, GGL_RGB  },   // RK_FORMAT_RGBX_8888
+{  3, 24, {{ 0, 0,   8, 0,  16, 8,  24,16 }}, GGL_RGB  },   // RK_FORMAT_RGB_888
+{  4, 32, {{32,24,  24,16,  16, 8,   8, 0 }}, GGL_BGRA },   // RK_FORMAT_BGRA_8888
+{  2, 16, {{ 0, 0,  16,11,  11, 5,   5, 0 }}, GGL_RGB  },   // RK_FORMAT_RGB_565
+{  2, 16, {{ 1, 0,  16,11,  11, 6,   6, 1 }}, GGL_RGBA },   // RK_FORMAT_RGBA_5551
+{  2, 16, {{ 4, 0,  16,12,  12, 8,   8, 4 }}, GGL_RGBA },   // RK_FORMAT_RGBA_4444
+{  2, 16, {{ 0, 0,   5, 0   11, 5,   16,11}}, GGL_BGR  },   // RK_FORMAT_BGR_565
+{  2, 16, {{ 1, 0,   6, 1,  11, 6,   16,11}}, GGL_BGRA },   // RK_FORMAT_BGRA_5551
+{  2, 16, {{ 4, 0,   8, 4,  12, 8,   16,12}}, GGL_BGRA },   // RK_FORMAT_BGRA_4444
+
+*/
+enum
+{
+	RGA2_FORMAT_RGBA_8888    = 0x0,
+    RGA2_FORMAT_RGBX_8888    = 0x1,
+    RGA2_FORMAT_RGB_888      = 0x2,
+    RGA2_FORMAT_BGRA_8888    = 0x3,
+    RGA2_FORMAT_BGRX_8888    = 0x4,
+    RGA2_FORMAT_BGR_888      = 0x5,
+    RGA2_FORMAT_RGB_565      = 0x6,
+    RGA2_FORMAT_RGBA_5551    = 0x7,
+    RGA2_FORMAT_RGBA_4444    = 0x8,
+    RGA2_FORMAT_BGR_565      = 0x9,
+    RGA2_FORMAT_BGRA_5551    = 0xa,
+    RGA2_FORMAT_BGRA_4444    = 0xb,
+
+    RGA2_FORMAT_YCbCr_422_SP = 0x10,
+    RGA2_FORMAT_YCbCr_422_P  = 0x11,
+    RGA2_FORMAT_YCbCr_420_SP = 0x12,
+    RGA2_FORMAT_YCbCr_420_P  = 0x13,
+    RGA2_FORMAT_YCrCb_422_SP = 0x14,
+    RGA2_FORMAT_YCrCb_422_P  = 0x15,
+    RGA2_FORMAT_YCrCb_420_SP = 0x16,
+    RGA2_FORMAT_YCrCb_420_P  = 0x17,
 
 	RGA2_FORMAT_YVYU_422 = 0x18,
 	RGA2_FORMAT_YVYU_420 = 0x19,
@@ -112,434 +112,434 @@ enum
 	RGA2_FORMAT_UYVY_422 = 0x1e,
 	RGA2_FORMAT_UYVY_420 = 0x1f,
 
-    RGA2_FORMAT_YCbCr_420_SP_10B = 0x20,
-    RGA2_FORMAT_YCrCb_420_SP_10B = 0x21,
-    RGA2_FORMAT_YCbCr_422_SP_10B = 0x22,
-    RGA2_FORMAT_YCrCb_422_SP_10B = 0x23,
-};
-
-typedef struct mdp_img
-{
-    u16 width;
-    u16 height;
-    u32 format;
-    u32 mem_addr;
-}
-mdp_img;
-
-typedef struct mdp_img_act
-{
-    u16 width;     // width
-    u16 height;    // height
-    s16 x_off;     // x offset for the vir
-    s16 y_off;     // y offset for the vir
-    s16 uv_x_off;
-    s16 uv_y_off;
-}
-mdp_img_act;
-
-typedef struct mdp_img_vir
-{
-    u16 width;
-    u16 height;
-    u32 format;
-    u32 mem_addr;
-    u32 uv_addr;
-    u32 v_addr;
-}
-mdp_img_vir;
-
-
-typedef struct MMU_INFO
-{
-    unsigned long src0_base_addr;
-    unsigned long src1_base_addr;
-    unsigned long dst_base_addr;
-    unsigned long els_base_addr;
-
-    u8 src0_mmu_flag;     /* [0] src0 mmu enable [1] src0_flush [2] src0_prefetch_en [3] src0_prefetch dir */
-    u8 src1_mmu_flag;     /* [0] src1 mmu enable [1] src1_flush [2] src1_prefetch_en [3] src1_prefetch dir */
-    u8 dst_mmu_flag;      /* [0] dst  mmu enable [1] dst_flush  [2] dst_prefetch_en  [3] dst_prefetch dir  */
-    u8 els_mmu_flag;      /* [0] els  mmu enable [1] els_flush  [2] els_prefetch_en  [3] els_prefetch dir  */
-} MMU_INFO;
-
-
-enum
-{
-	MMU_DIS = 0x0,
-	MMU_EN  = 0x1
-};
-enum
-{
-	MMU_FLUSH_DIS = 0x0,
-	MMU_FLUSH_EN  = 0x2
-};
-enum
-{
-	MMU_PRE_DIS = 0x0,
-	MMU_PRE_EN  = 0x4
-};
-enum
-{
-	MMU_PRE_DIR_FORW  = 0x0,
-	MMU_PRE_DIR_BACK  = 0x8
-};
-typedef struct COLOR_FILL
-{
-    s16 gr_x_a;
-    s16 gr_y_a;
-    s16 gr_x_b;
-    s16 gr_y_b;
-    s16 gr_x_g;
-    s16 gr_y_g;
-    s16 gr_x_r;
-    s16 gr_y_r;
-}
-COLOR_FILL;
-
-enum
-{
-	ALPHA_ORIGINAL = 0x0,
-	ALPHA_NO_128   = 0x1
-};
-
-enum
-{
-	R2_BLACK       = 0x00,
-	R2_COPYPEN     = 0xf0,
-	R2_MASKNOTPEN  = 0x0a,
-	R2_MASKPEN     = 0xa0,
-	R2_MASKPENNOT  = 0x50,
-	R2_MERGENOTPEN = 0xaf,
-	R2_MERGEPEN    = 0xfa,
-	R2_MERGEPENNOT = 0xf5,
-	R2_NOP         = 0xaa,
-	R2_NOT         = 0x55,
-	R2_NOTCOPYPEN  = 0x0f,
-	R2_NOTMASKPEN  = 0x5f,
-	R2_NOTMERGEPEN = 0x05,
-	R2_NOTXORPEN   = 0xa5,
-	R2_WHITE       = 0xff,
-	R2_XORPEN      = 0x5a
-};
-
-
-/***************************************/
-/* porting from rga.h for msg convert  */
-/***************************************/
-
-typedef struct FADING
-{
-    uint8_t b;
-    uint8_t g;
-    uint8_t r;
-    uint8_t res;
-}
-FADING;
-
-typedef struct MMU
-{
-    unsigned char mmu_en;
-    unsigned long base_addr;
-    uint32_t mmu_flag;     /* [0] mmu enable [1] src_flush [2] dst_flush [3] CMD_flush [4~5] page size*/
-} MMU;
-
-typedef struct MMU_32
-{
-    unsigned char mmu_en;
-    uint32_t base_addr;
-    uint32_t mmu_flag;     /* [0] mmu enable [1] src_flush [2] dst_flush [3] CMD_flush [4~5] page size*/
-} MMU_32;
-
-typedef struct RECT
-{
-    unsigned short xmin;
-    unsigned short xmax; // width - 1
-    unsigned short ymin;
-    unsigned short ymax; // height - 1
-} RECT;
-
-typedef struct POINT
-{
-    unsigned short x;
-    unsigned short y;
-}
-POINT;
-
-typedef struct line_draw_t
-{
-    POINT start_point;              /* LineDraw_start_point                */
-    POINT end_point;                /* LineDraw_end_point                  */
-    uint32_t   color;               /* LineDraw_color                      */
-    uint32_t   flag;                /* (enum) LineDrawing mode sel         */
-    uint32_t   line_width;          /* range 1~16 */
-}
-line_draw_t;
-
-typedef struct rga_img_info_t
-{
-    unsigned long yrgb_addr;      /* yrgb    mem addr         */
-    unsigned long uv_addr;        /* cb/cr   mem addr         */
-    unsigned long v_addr;         /* cr      mem addr         */
-    unsigned int format;         //definition by RK_FORMAT
-
-    unsigned short act_w;
-    unsigned short act_h;
-    unsigned short x_offset;
-    unsigned short y_offset;
-
-    unsigned short vir_w;
-    unsigned short vir_h;
-
-    unsigned short endian_mode; //for BPP
-    unsigned short alpha_swap;
-}
-rga_img_info_t;
-
-typedef struct rga_img_info_32_t
-{
-    uint32_t yrgb_addr;      /* yrgb    mem addr         */
-    uint32_t uv_addr;        /* cb/cr   mem addr         */
-    uint32_t v_addr;         /* cr      mem addr         */
-    unsigned int format;         //definition by RK_FORMAT
-    unsigned short act_w;
-    unsigned short act_h;
-    unsigned short x_offset;
-    unsigned short y_offset;
-    unsigned short vir_w;
-    unsigned short vir_h;
-    unsigned short endian_mode; //for BPP
-    unsigned short alpha_swap;
-}
-rga_img_info_32_t;
-
-struct rga_req {
-    uint8_t render_mode;            /* (enum) process mode sel */
-
-    rga_img_info_t src;             /* src image info */
-    rga_img_info_t dst;             /* dst image info */
-    rga_img_info_t pat;             /* patten image info */
-
-    unsigned long rop_mask_addr;         /* rop4 mask addr */
-    unsigned long LUT_addr;              /* LUT addr */
-
-    RECT clip;                      /* dst clip window default value is dst_vir */
-                                    /* value from [0, w-1] / [0, h-1]*/
-
-    int32_t sina;                   /* dst angle  default value 0  16.16 scan from table */
-    int32_t cosa;                   /* dst angle  default value 0  16.16 scan from table */
-
-    uint16_t alpha_rop_flag;        /* alpha rop process flag           */
-                                    /* ([0] = 1 alpha_rop_enable)       */
-                                    /* ([1] = 1 rop enable)             */
-                                    /* ([2] = 1 fading_enable)          */
-                                    /* ([3] = 1 PD_enable)              */
-                                    /* ([4] = 1 alpha cal_mode_sel)     */
-                                    /* ([5] = 1 dither_enable)          */
-                                    /* ([6] = 1 gradient fill mode sel) */
-                                    /* ([7] = 1 AA_enable)              */
-
-    uint8_t  scale_mode;            /* 0 nearst / 1 bilnear / 2 bicubic */
-
-    uint32_t color_key_max;         /* color key max */
-    uint32_t color_key_min;         /* color key min */
-
-    uint32_t fg_color;              /* foreground color */
-    uint32_t bg_color;              /* background color */
-
-    COLOR_FILL gr_color;            /* color fill use gradient */
-
-    line_draw_t line_draw_info;
-
-    FADING fading;
-
-    uint8_t PD_mode;                /* porter duff alpha mode sel */
-
-    uint8_t alpha_global_value;     /* global alpha value */
-
-    uint16_t rop_code;              /* rop2/3/4 code  scan from rop code table*/
-
-    uint8_t bsfilter_flag;          /* [2] 0 blur 1 sharp / [1:0] filter_type*/
-
-    uint8_t palette_mode;           /* (enum) color palatte  0/1bpp, 1/2bpp 2/4bpp 3/8bpp*/
-
-    uint8_t yuv2rgb_mode;           /* (enum) BT.601 MPEG / BT.601 JPEG / BT.709  */
-
-    uint8_t endian_mode;            /* 0/big endian 1/little endian*/
-
-    uint8_t rotate_mode;            /* (enum) rotate mode  */
-                                    /* 0x0,     no rotate  */
-                                    /* 0x1,     rotate     */
-                                    /* 0x2,     x_mirror   */
-                                    /* 0x3,     y_mirror   */
-
-    uint8_t color_fill_mode;        /* 0 solid color / 1 patten color */
-
-    MMU mmu_info;                   /* mmu information */
-
-    uint8_t  alpha_rop_mode;        /* ([0~1] alpha mode)            */
-                                    /* ([2~3] rop   mode)            */
-                                    /* ([4]   zero  mode en)         */
-                                    /* ([5]   dst   alpha mode)      */
-                                    /* ([6]   alpha output mode sel) 0 src / 1 dst*/
-
-    uint8_t  src_trans_mode;
-};
-struct rga_req_32
-{
-    uint8_t render_mode;            /* (enum) process mode sel */
-    rga_img_info_32_t src;             /* src image info */
-    rga_img_info_32_t dst;             /* dst image info */
-    rga_img_info_32_t pat;             /* patten image info */
-    uint32_t rop_mask_addr;         /* rop4 mask addr */
-    uint32_t LUT_addr;              /* LUT addr */
-    RECT clip;                      /* dst clip window default value is dst_vir */
-                                    /* value from [0, w-1] / [0, h-1]*/
-    int32_t sina;                   /* dst angle  default value 0  16.16 scan from table */
-    int32_t cosa;                   /* dst angle  default value 0  16.16 scan from table */
-    uint16_t alpha_rop_flag;        /* alpha rop process flag           */
-                                    /* ([0] = 1 alpha_rop_enable)       */
-                                    /* ([1] = 1 rop enable)             */
-                                    /* ([2] = 1 fading_enable)          */
-                                    /* ([3] = 1 PD_enable)              */
-                                    /* ([4] = 1 alpha cal_mode_sel)     */
-                                    /* ([5] = 1 dither_enable)          */
-                                    /* ([6] = 1 gradient fill mode sel) */
-                                    /* ([7] = 1 AA_enable)              */
-    uint8_t  scale_mode;            /* 0 nearst / 1 bilnear / 2 bicubic */
-    uint32_t color_key_max;         /* color key max */
-    uint32_t color_key_min;         /* color key min */
-    uint32_t fg_color;              /* foreground color */
-    uint32_t bg_color;              /* background color */
-    COLOR_FILL gr_color;            /* color fill use gradient */
-    line_draw_t line_draw_info;
-    FADING fading;
-    uint8_t PD_mode;                /* porter duff alpha mode sel */
-    uint8_t alpha_global_value;     /* global alpha value */
-    uint16_t rop_code;              /* rop2/3/4 code  scan from rop code table*/
-    uint8_t bsfilter_flag;          /* [2] 0 blur 1 sharp / [1:0] filter_type*/
-    uint8_t palette_mode;           /* (enum) color palatte  0/1bpp, 1/2bpp 2/4bpp 3/8bpp*/
-    uint8_t yuv2rgb_mode;           /* (enum) BT.601 MPEG / BT.601 JPEG / BT.709  */
-    uint8_t endian_mode;            /* 0/big endian 1/little endian*/
-    uint8_t rotate_mode;            /* (enum) rotate mode  */
-                                    /* 0x0,     no rotate  */
-                                    /* 0x1,     rotate     */
-                                    /* 0x2,     x_mirror   */
-                                    /* 0x3,     y_mirror   */
-    uint8_t color_fill_mode;        /* 0 solid color / 1 patten color */
-    MMU_32 mmu_info;                   /* mmu information */
-    uint8_t  alpha_rop_mode;        /* ([0~1] alpha mode)            */
-                                    /* ([2~3] rop   mode)            */
-                                    /* ([4]   zero  mode en)         */
-                                    /* ([5]   dst   alpha mode)      */
-                                    /* ([6]   alpha output mode sel) 0 src / 1 dst*/
-    uint8_t  src_trans_mode;
-};
-
-
-
-struct rga2_req
-{
-    u8 render_mode;          /* (enum) process mode sel */
-
-    rga_img_info_t src;    // src  active window
-    rga_img_info_t src1;   // src1 active window
-    rga_img_info_t dst;    // dst  active window
-    rga_img_info_t pat;    // patten active window
-
-    unsigned long rop_mask_addr;       // rop4 mask addr
-    unsigned long LUT_addr;            // LUT addr
-
-    u32 rop_mask_stride;
-
-    u8 bitblt_mode;          /* 0: SRC + DST  => DST     */
-                             /* 1: SRC + SRC1 => DST     */
-
-    u8 rotate_mode;          /* [1:0]                           */
-                             /* 0   degree 0x0                  */
-                             /* 90  degree 0x1                  */
-                             /* 180 degree 0x2                  */
-                             /* 270 degree 0x3                  */
-                             /* [5:4]                           */
-                             /* none                0x0         */
-                             /* x_mirror            0x1         */
-                             /* y_mirror            0x2         */
-                             /* x_mirror + y_mirror 0x3         */
-
-    u16 alpha_rop_flag;         /* alpha rop process flag           */
-                                /* ([0] = 1 alpha_rop_enable)       */
-                                /* ([1] = 1 rop enable)             */
-                                /* ([2] = 1 fading_enable)          */
-                                /* ([3] = 1 alpha cal_mode_sel)     */
-                                /* ([4] = 1 src_dither_up_enable)   */
-                                /* ([5] = 1 dst_dither_up_enable)   */
-                                /* ([6] = 1 dither_down_enable)     */
-                                /* ([7] = 1 gradient fill mode sel) */
-
-
-    u16 alpha_mode_0;           /* [0]     SrcAlphaMode0          */
-                                /* [2:1]   SrcGlobalAlphaMode0    */
-                                /* [3]     SrcAlphaSelectMode0    */
-                                /* [6:4]   SrcFactorMode0         */
-                                /* [7]     SrcColorMode           */
-
-                                /* [8]     DstAlphaMode0          */
-                                /* [10:9]  DstGlobalAlphaMode0    */
-                                /* [11]    DstAlphaSelectMode0    */
-                                /* [14:12] DstFactorMode0         */
-                                /* [15]    DstColorMode0          */
-
-    u16 alpha_mode_1;           /* [0]     SrcAlphaMode1          */
-                                /* [2:1]   SrcGlobalAlphaMode1    */
-                                /* [3]     SrcAlphaSelectMode1    */
-                                /* [6:4]   SrcFactorMode1         */
-
-                                /* [8]     DstAlphaMode1          */
-                                /* [10:9]  DstGlobalAlphaMode1    */
-                                /* [11]    DstAlphaSelectMode1    */
-                                /* [14:12] DstFactorMode1         */
-
-    u8  scale_bicu_mode;    /* 0   1   2  3 */
-
-    u32 color_key_max;      /* color key max */
-    u32 color_key_min;      /* color key min */
-
-    u32 fg_color;           /* foreground color */
-    u32 bg_color;           /* background color */
-
-    u8 color_fill_mode;
-    COLOR_FILL gr_color;    /* color fill use gradient */
-
-    u8 fading_alpha_value;  /* Fading value */
-    u8 fading_r_value;
-    u8 fading_g_value;
-    u8 fading_b_value;
-
-    u8 src_a_global_val;    /* src global alpha value        */
-    u8 dst_a_global_val;    /* dst global alpha value        */
-
-
-    u8  rop_mode;
-    u16 rop_code;           /* rop2/3/4 code */
-
-    u8 palette_mode;        /* (enum) color palatte  0/1bpp, 1/2bpp 2/4bpp 3/8bpp*/
-
-    u8 yuv2rgb_mode;        /* (enum) BT.601 MPEG / BT.601 JPEG / BT.709  */
-
-    u8 endian_mode;         /* 0/little endian 1/big endian */
-
-    u8 CMD_fin_int_enable;
-
-    MMU_INFO mmu_info;               /* mmu infomation */
-
-    u8 alpha_zero_key;
-    u8 src_trans_mode;
-
-    u8 alpha_swp;
-    u8 dither_mode;
-
-    u8 rgb2yuv_mode;
-
+    RGA2_FORMAT_YCbCr_420_SP_10B = 0x20,
+    RGA2_FORMAT_YCrCb_420_SP_10B = 0x21,
+    RGA2_FORMAT_YCbCr_422_SP_10B = 0x22,
+    RGA2_FORMAT_YCrCb_422_SP_10B = 0x23,
+};
+
+typedef struct mdp_img
+{
+    u16 width;
+    u16 height;
+    u32 format;
+    u32 mem_addr;
+}
+mdp_img;
+
+typedef struct mdp_img_act
+{
+    u16 width;     // width
+    u16 height;    // height
+    s16 x_off;     // x offset for the vir
+    s16 y_off;     // y offset for the vir
+    s16 uv_x_off;
+    s16 uv_y_off;
+}
+mdp_img_act;
+
+typedef struct mdp_img_vir
+{
+    u16 width;
+    u16 height;
+    u32 format;
+    u32 mem_addr;
+    u32 uv_addr;
+    u32 v_addr;
+}
+mdp_img_vir;
+
+
+typedef struct MMU_INFO
+{
+    unsigned long src0_base_addr;
+    unsigned long src1_base_addr;
+    unsigned long dst_base_addr;
+    unsigned long els_base_addr;
+
+    u8 src0_mmu_flag;     /* [0] src0 mmu enable [1] src0_flush [2] src0_prefetch_en [3] src0_prefetch dir */
+    u8 src1_mmu_flag;     /* [0] src1 mmu enable [1] src1_flush [2] src1_prefetch_en [3] src1_prefetch dir */
+    u8 dst_mmu_flag;      /* [0] dst  mmu enable [1] dst_flush  [2] dst_prefetch_en  [3] dst_prefetch dir  */
+    u8 els_mmu_flag;      /* [0] els  mmu enable [1] els_flush  [2] els_prefetch_en  [3] els_prefetch dir  */
+} MMU_INFO;
+
+
+enum
+{
+	MMU_DIS = 0x0,
+	MMU_EN  = 0x1
+};
+enum
+{
+	MMU_FLUSH_DIS = 0x0,
+	MMU_FLUSH_EN  = 0x2
+};
+enum
+{
+	MMU_PRE_DIS = 0x0,
+	MMU_PRE_EN  = 0x4
+};
+enum
+{
+	MMU_PRE_DIR_FORW  = 0x0,
+	MMU_PRE_DIR_BACK  = 0x8
+};
+typedef struct COLOR_FILL
+{
+    s16 gr_x_a;
+    s16 gr_y_a;
+    s16 gr_x_b;
+    s16 gr_y_b;
+    s16 gr_x_g;
+    s16 gr_y_g;
+    s16 gr_x_r;
+    s16 gr_y_r;
+}
+COLOR_FILL;
+
+enum
+{
+	ALPHA_ORIGINAL = 0x0,
+	ALPHA_NO_128   = 0x1
+};
+
+enum
+{
+	R2_BLACK       = 0x00,
+	R2_COPYPEN     = 0xf0,
+	R2_MASKNOTPEN  = 0x0a,
+	R2_MASKPEN     = 0xa0,
+	R2_MASKPENNOT  = 0x50,
+	R2_MERGENOTPEN = 0xaf,
+	R2_MERGEPEN    = 0xfa,
+	R2_MERGEPENNOT = 0xf5,
+	R2_NOP         = 0xaa,
+	R2_NOT         = 0x55,
+	R2_NOTCOPYPEN  = 0x0f,
+	R2_NOTMASKPEN  = 0x5f,
+	R2_NOTMERGEPEN = 0x05,
+	R2_NOTXORPEN   = 0xa5,
+	R2_WHITE       = 0xff,
+	R2_XORPEN      = 0x5a
+};
+
+
+/***************************************/
+/* porting from rga.h for msg convert  */
+/***************************************/
+
+typedef struct FADING
+{
+    uint8_t b;
+    uint8_t g;
+    uint8_t r;
+    uint8_t res;
+}
+FADING;
+
+typedef struct MMU
+{
+    unsigned char mmu_en;
+    unsigned long base_addr;
+    uint32_t mmu_flag;     /* [0] mmu enable [1] src_flush [2] dst_flush [3] CMD_flush [4~5] page size*/
+} MMU;
+
+typedef struct MMU_32
+{
+    unsigned char mmu_en;
+    uint32_t base_addr;
+    uint32_t mmu_flag;     /* [0] mmu enable [1] src_flush [2] dst_flush [3] CMD_flush [4~5] page size*/
+} MMU_32;
+
+typedef struct RECT
+{
+    unsigned short xmin;
+    unsigned short xmax; // width - 1
+    unsigned short ymin;
+    unsigned short ymax; // height - 1
+} RECT;
+
+typedef struct POINT
+{
+    unsigned short x;
+    unsigned short y;
+}
+POINT;
+
+typedef struct line_draw_t
+{
+    POINT start_point;              /* LineDraw_start_point                */
+    POINT end_point;                /* LineDraw_end_point                  */
+    uint32_t   color;               /* LineDraw_color                      */
+    uint32_t   flag;                /* (enum) LineDrawing mode sel         */
+    uint32_t   line_width;          /* range 1~16 */
+}
+line_draw_t;
+
+typedef struct rga_img_info_t
+{
+    unsigned long yrgb_addr;      /* yrgb    mem addr         */
+    unsigned long uv_addr;        /* cb/cr   mem addr         */
+    unsigned long v_addr;         /* cr      mem addr         */
+    unsigned int format;         //definition by RK_FORMAT
+
+    unsigned short act_w;
+    unsigned short act_h;
+    unsigned short x_offset;
+    unsigned short y_offset;
+
+    unsigned short vir_w;
+    unsigned short vir_h;
+
+    unsigned short endian_mode; //for BPP
+    unsigned short alpha_swap;
+}
+rga_img_info_t;
+
+typedef struct rga_img_info_32_t
+{
+    uint32_t yrgb_addr;      /* yrgb    mem addr         */
+    uint32_t uv_addr;        /* cb/cr   mem addr         */
+    uint32_t v_addr;         /* cr      mem addr         */
+    unsigned int format;         //definition by RK_FORMAT
+    unsigned short act_w;
+    unsigned short act_h;
+    unsigned short x_offset;
+    unsigned short y_offset;
+    unsigned short vir_w;
+    unsigned short vir_h;
+    unsigned short endian_mode; //for BPP
+    unsigned short alpha_swap;
+}
+rga_img_info_32_t;
+
+struct rga_req {
+    uint8_t render_mode;            /* (enum) process mode sel */
+
+    rga_img_info_t src;             /* src image info */
+    rga_img_info_t dst;             /* dst image info */
+    rga_img_info_t pat;             /* patten image info */
+
+    unsigned long rop_mask_addr;         /* rop4 mask addr */
+    unsigned long LUT_addr;              /* LUT addr */
+
+    RECT clip;                      /* dst clip window default value is dst_vir */
+                                    /* value from [0, w-1] / [0, h-1]*/
+
+    int32_t sina;                   /* dst angle  default value 0  16.16 scan from table */
+    int32_t cosa;                   /* dst angle  default value 0  16.16 scan from table */
+
+    uint16_t alpha_rop_flag;        /* alpha rop process flag           */
+                                    /* ([0] = 1 alpha_rop_enable)       */
+                                    /* ([1] = 1 rop enable)             */
+                                    /* ([2] = 1 fading_enable)          */
+                                    /* ([3] = 1 PD_enable)              */
+                                    /* ([4] = 1 alpha cal_mode_sel)     */
+                                    /* ([5] = 1 dither_enable)          */
+                                    /* ([6] = 1 gradient fill mode sel) */
+                                    /* ([7] = 1 AA_enable)              */
+
+    uint8_t  scale_mode;            /* 0 nearst / 1 bilnear / 2 bicubic */
+
+    uint32_t color_key_max;         /* color key max */
+    uint32_t color_key_min;         /* color key min */
+
+    uint32_t fg_color;              /* foreground color */
+    uint32_t bg_color;              /* background color */
+
+    COLOR_FILL gr_color;            /* color fill use gradient */
+
+    line_draw_t line_draw_info;
+
+    FADING fading;
+
+    uint8_t PD_mode;                /* porter duff alpha mode sel */
+
+    uint8_t alpha_global_value;     /* global alpha value */
+
+    uint16_t rop_code;              /* rop2/3/4 code  scan from rop code table*/
+
+    uint8_t bsfilter_flag;          /* [2] 0 blur 1 sharp / [1:0] filter_type*/
+
+    uint8_t palette_mode;           /* (enum) color palatte  0/1bpp, 1/2bpp 2/4bpp 3/8bpp*/
+
+    uint8_t yuv2rgb_mode;           /* (enum) BT.601 MPEG / BT.601 JPEG / BT.709  */
+
+    uint8_t endian_mode;            /* 0/big endian 1/little endian*/
+
+    uint8_t rotate_mode;            /* (enum) rotate mode  */
+                                    /* 0x0,     no rotate  */
+                                    /* 0x1,     rotate     */
+                                    /* 0x2,     x_mirror   */
+                                    /* 0x3,     y_mirror   */
+
+    uint8_t color_fill_mode;        /* 0 solid color / 1 patten color */
+
+    MMU mmu_info;                   /* mmu information */
+
+    uint8_t  alpha_rop_mode;        /* ([0~1] alpha mode)            */
+                                    /* ([2~3] rop   mode)            */
+                                    /* ([4]   zero  mode en)         */
+                                    /* ([5]   dst   alpha mode)      */
+                                    /* ([6]   alpha output mode sel) 0 src / 1 dst*/
+
+    uint8_t  src_trans_mode;
+};
+struct rga_req_32
+{
+    uint8_t render_mode;            /* (enum) process mode sel */
+    rga_img_info_32_t src;             /* src image info */
+    rga_img_info_32_t dst;             /* dst image info */
+    rga_img_info_32_t pat;             /* patten image info */
+    uint32_t rop_mask_addr;         /* rop4 mask addr */
+    uint32_t LUT_addr;              /* LUT addr */
+    RECT clip;                      /* dst clip window default value is dst_vir */
+                                    /* value from [0, w-1] / [0, h-1]*/
+    int32_t sina;                   /* dst angle  default value 0  16.16 scan from table */
+    int32_t cosa;                   /* dst angle  default value 0  16.16 scan from table */
+    uint16_t alpha_rop_flag;        /* alpha rop process flag           */
+                                    /* ([0] = 1 alpha_rop_enable)       */
+                                    /* ([1] = 1 rop enable)             */
+                                    /* ([2] = 1 fading_enable)          */
+                                    /* ([3] = 1 PD_enable)              */
+                                    /* ([4] = 1 alpha cal_mode_sel)     */
+                                    /* ([5] = 1 dither_enable)          */
+                                    /* ([6] = 1 gradient fill mode sel) */
+                                    /* ([7] = 1 AA_enable)              */
+    uint8_t  scale_mode;            /* 0 nearst / 1 bilnear / 2 bicubic */
+    uint32_t color_key_max;         /* color key max */
+    uint32_t color_key_min;         /* color key min */
+    uint32_t fg_color;              /* foreground color */
+    uint32_t bg_color;              /* background color */
+    COLOR_FILL gr_color;            /* color fill use gradient */
+    line_draw_t line_draw_info;
+    FADING fading;
+    uint8_t PD_mode;                /* porter duff alpha mode sel */
+    uint8_t alpha_global_value;     /* global alpha value */
+    uint16_t rop_code;              /* rop2/3/4 code  scan from rop code table*/
+    uint8_t bsfilter_flag;          /* [2] 0 blur 1 sharp / [1:0] filter_type*/
+    uint8_t palette_mode;           /* (enum) color palatte  0/1bpp, 1/2bpp 2/4bpp 3/8bpp*/
+    uint8_t yuv2rgb_mode;           /* (enum) BT.601 MPEG / BT.601 JPEG / BT.709  */
+    uint8_t endian_mode;            /* 0/big endian 1/little endian*/
+    uint8_t rotate_mode;            /* (enum) rotate mode  */
+                                    /* 0x0,     no rotate  */
+                                    /* 0x1,     rotate     */
+                                    /* 0x2,     x_mirror   */
+                                    /* 0x3,     y_mirror   */
+    uint8_t color_fill_mode;        /* 0 solid color / 1 patten color */
+    MMU_32 mmu_info;                   /* mmu information */
+    uint8_t  alpha_rop_mode;        /* ([0~1] alpha mode)            */
+                                    /* ([2~3] rop   mode)            */
+                                    /* ([4]   zero  mode en)         */
+                                    /* ([5]   dst   alpha mode)      */
+                                    /* ([6]   alpha output mode sel) 0 src / 1 dst*/
+    uint8_t  src_trans_mode;
+};
+
+
+
+struct rga2_req
+{
+    u8 render_mode;          /* (enum) process mode sel */
+
+    rga_img_info_t src;    // src  active window
+    rga_img_info_t src1;   // src1 active window
+    rga_img_info_t dst;    // dst  active window
+    rga_img_info_t pat;    // patten active window
+
+    unsigned long rop_mask_addr;       // rop4 mask addr
+    unsigned long LUT_addr;            // LUT addr
+
+    u32 rop_mask_stride;
+
+    u8 bitblt_mode;          /* 0: SRC + DST  => DST     */
+                             /* 1: SRC + SRC1 => DST     */
+
+    u8 rotate_mode;          /* [1:0]                           */
+                             /* 0   degree 0x0                  */
+                             /* 90  degree 0x1                  */
+                             /* 180 degree 0x2                  */
+                             /* 270 degree 0x3                  */
+                             /* [5:4]                           */
+                             /* none                0x0         */
+                             /* x_mirror            0x1         */
+                             /* y_mirror            0x2         */
+                             /* x_mirror + y_mirror 0x3         */
+
+    u16 alpha_rop_flag;         /* alpha rop process flag           */
+                                /* ([0] = 1 alpha_rop_enable)       */
+                                /* ([1] = 1 rop enable)             */
+                                /* ([2] = 1 fading_enable)          */
+                                /* ([3] = 1 alpha cal_mode_sel)     */
+                                /* ([4] = 1 src_dither_up_enable)   */
+                                /* ([5] = 1 dst_dither_up_enable)   */
+                                /* ([6] = 1 dither_down_enable)     */
+                                /* ([7] = 1 gradient fill mode sel) */
+
+
+    u16 alpha_mode_0;           /* [0]     SrcAlphaMode0          */
+                                /* [2:1]   SrcGlobalAlphaMode0    */
+                                /* [3]     SrcAlphaSelectMode0    */
+                                /* [6:4]   SrcFactorMode0         */
+                                /* [7]     SrcColorMode           */
+
+                                /* [8]     DstAlphaMode0          */
+                                /* [10:9]  DstGlobalAlphaMode0    */
+                                /* [11]    DstAlphaSelectMode0    */
+                                /* [14:12] DstFactorMode0         */
+                                /* [15]    DstColorMode0          */
+
+    u16 alpha_mode_1;           /* [0]     SrcAlphaMode1          */
+                                /* [2:1]   SrcGlobalAlphaMode1    */
+                                /* [3]     SrcAlphaSelectMode1    */
+                                /* [6:4]   SrcFactorMode1         */
+
+                                /* [8]     DstAlphaMode1          */
+                                /* [10:9]  DstGlobalAlphaMode1    */
+                                /* [11]    DstAlphaSelectMode1    */
+                                /* [14:12] DstFactorMode1         */
+
+    u8  scale_bicu_mode;    /* 0   1   2  3 */
+
+    u32 color_key_max;      /* color key max */
+    u32 color_key_min;      /* color key min */
+
+    u32 fg_color;           /* foreground color */
+    u32 bg_color;           /* background color */
+
+    u8 color_fill_mode;
+    COLOR_FILL gr_color;    /* color fill use gradient */
+
+    u8 fading_alpha_value;  /* Fading value */
+    u8 fading_r_value;
+    u8 fading_g_value;
+    u8 fading_b_value;
+
+    u8 src_a_global_val;    /* src global alpha value        */
+    u8 dst_a_global_val;    /* dst global alpha value        */
+
+
+    u8  rop_mode;
+    u16 rop_code;           /* rop2/3/4 code */
+
+    u8 palette_mode;        /* (enum) color palatte  0/1bpp, 1/2bpp 2/4bpp 3/8bpp*/
+
+    u8 yuv2rgb_mode;        /* (enum) BT.601 MPEG / BT.601 JPEG / BT.709  */
+
+    u8 endian_mode;         /* 0/little endian 1/big endian */
+
+    u8 CMD_fin_int_enable;
+
+    MMU_INFO mmu_info;               /* mmu infomation */
+
+    u8 alpha_zero_key;
+    u8 src_trans_mode;
+
+    u8 alpha_swp;
+    u8 dither_mode;
+
+    u8 rgb2yuv_mode;
+
 	u8 buf_type;
 	struct sg_table *sg_src0;
 	struct sg_table *sg_src1;
@@ -548,125 +548,125 @@ struct rga2_req
 	struct dma_buf_attachment *attach_src0;
 	struct dma_buf_attachment *attach_src1;
 	struct dma_buf_attachment *attach_dst;
-};
-
-struct rga2_mmu_buf_t {
-    int32_t front;
-    int32_t back;
-    int32_t size;
-    int32_t curr;
-    unsigned int *buf;
-    unsigned int *buf_virtual;
-
-    struct page **pages;
-};
-
-enum
-{
-    BB_ROTATE_OFF   = 0x0,     /* no rotate  */
-    BB_ROTATE_90    = 0x1,     /* rotate 90  */
-    BB_ROTATE_180   = 0x2,     /* rotate 180 */
-    BB_ROTATE_270   = 0x3,     /* rotate 270 */
-};  /*rotate mode*/
-
-enum
-{
-    BB_MIRROR_OFF   = (0x0 << 4),     /* no mirror  */
-    BB_MIRROR_X     = (0x1 << 4),     /* x  mirror  */
-    BB_MIRROR_Y     = (0x2 << 4),     /* y  mirror  */
-    BB_MIRROR_XY    = (0x3 << 4),     /* xy mirror  */
-};  /*mirror mode*/
-
-enum
-{
-    BB_COPY_USE_TILE = (0x1 << 6),    /* bitblt mode copy but use Tile mode */
-};
-
-enum
-{
-	//BYPASS        = 0x0,
-    BT_601_RANGE0   = 0x1,
-    BT_601_RANGE1   = 0x2,
-    BT_709_RANGE0   = 0x3,
-}; /*yuv2rgb_mode*/
-
-enum
-{
-    BPP1        = 0x0,     /* BPP1 */
-    BPP2        = 0x1,     /* BPP2 */
-    BPP4        = 0x2,     /* BPP4 */
-    BPP8        = 0x3      /* BPP8 */
-}; /*palette_mode*/
-
-enum
-{
-	SOLID_COLOR   = 0x0, //color fill mode; ROP4: SOLID_rop4_mask_addr COLOR
-	PATTERN_COLOR = 0x1  //pattern_fill_mode;ROP4:PATTERN_COLOR
-};  /*color fill mode*/
-
-enum
-{
-	COLOR_FILL_CLIP     = 0x0,
-	COLOR_FILL_NOT_CLIP = 0x1
-};
-
-enum
-{
-    CATROM    = 0x0,
-    MITCHELL  = 0x1,
-    HERMITE   = 0x2,
-    B_SPLINE  = 0x3,
-};  /*bicubic coefficient*/
-
-enum
-{
-	ROP2 = 0x0,
-	ROP3 = 0x1,
-	ROP4 = 0x2
-};  /*ROP mode*/
-
-enum
-{
-	BIG_ENDIAN    = 0x0,
-	LITTLE_ENDIAN = 0x1
-};  /*endian mode*/
-
-enum
-{
-	MMU_TABLE_4KB  = 0x0,
-	MMU_TABLE_64KB = 0x1,
-};  /*MMU table size*/
-
-enum
-{
-    RGB_2_666 = 0x0,
-    RGB_2_565 = 0x1,
-    RGB_2_555 = 0x2,
-    RGB_2_444 = 0x3,
-};  /*dither down mode*/
-
-
-
-/**
- * struct for process session which connect to rga
- *
- * @author ZhangShengqin (2012-2-15)
- */
-typedef struct rga2_session {
-	/* a linked list of data so we can access them for debugging */
-	struct list_head    list_session;
-	/* a linked list of register data waiting for process */
-	struct list_head    waiting;
-	/* a linked list of register data in processing */
-	struct list_head    running;
-	/* all coommand this thread done */
-    atomic_t            done;
-	wait_queue_head_t   wait;
-	pid_t           pid;
-	atomic_t        task_running;
-    atomic_t        num_done;
-} rga2_session;
-
+};
+
+struct rga2_mmu_buf_t {
+    int32_t front;
+    int32_t back;
+    int32_t size;
+    int32_t curr;
+    unsigned int *buf;
+    unsigned int *buf_virtual;
+
+    struct page **pages;
+};
+
+enum
+{
+    BB_ROTATE_OFF   = 0x0,     /* no rotate  */
+    BB_ROTATE_90    = 0x1,     /* rotate 90  */
+    BB_ROTATE_180   = 0x2,     /* rotate 180 */
+    BB_ROTATE_270   = 0x3,     /* rotate 270 */
+};  /*rotate mode*/
+
+enum
+{
+    BB_MIRROR_OFF   = (0x0 << 4),     /* no mirror  */
+    BB_MIRROR_X     = (0x1 << 4),     /* x  mirror  */
+    BB_MIRROR_Y     = (0x2 << 4),     /* y  mirror  */
+    BB_MIRROR_XY    = (0x3 << 4),     /* xy mirror  */
+};  /*mirror mode*/
+
+enum
+{
+    BB_COPY_USE_TILE = (0x1 << 6),    /* bitblt mode copy but use Tile mode */
+};
+
+enum
+{
+	//BYPASS        = 0x0,
+    BT_601_RANGE0   = 0x1,
+    BT_601_RANGE1   = 0x2,
+    BT_709_RANGE0   = 0x3,
+}; /*yuv2rgb_mode*/
+
+enum
+{
+    BPP1        = 0x0,     /* BPP1 */
+    BPP2        = 0x1,     /* BPP2 */
+    BPP4        = 0x2,     /* BPP4 */
+    BPP8        = 0x3      /* BPP8 */
+}; /*palette_mode*/
+
+enum
+{
+	SOLID_COLOR   = 0x0, //color fill mode; ROP4: SOLID_rop4_mask_addr COLOR
+	PATTERN_COLOR = 0x1  //pattern_fill_mode;ROP4:PATTERN_COLOR
+};  /*color fill mode*/
+
+enum
+{
+	COLOR_FILL_CLIP     = 0x0,
+	COLOR_FILL_NOT_CLIP = 0x1
+};
+
+enum
+{
+    CATROM    = 0x0,
+    MITCHELL  = 0x1,
+    HERMITE   = 0x2,
+    B_SPLINE  = 0x3,
+};  /*bicubic coefficient*/
+
+enum
+{
+	ROP2 = 0x0,
+	ROP3 = 0x1,
+	ROP4 = 0x2
+};  /*ROP mode*/
+
+enum
+{
+	BIG_ENDIAN    = 0x0,
+	LITTLE_ENDIAN = 0x1
+};  /*endian mode*/
+
+enum
+{
+	MMU_TABLE_4KB  = 0x0,
+	MMU_TABLE_64KB = 0x1,
+};  /*MMU table size*/
+
+enum
+{
+    RGB_2_666 = 0x0,
+    RGB_2_565 = 0x1,
+    RGB_2_555 = 0x2,
+    RGB_2_444 = 0x3,
+};  /*dither down mode*/
+
+
+
+/**
+ * struct for process session which connect to rga
+ *
+ * @author ZhangShengqin (2012-2-15)
+ */
+typedef struct rga2_session {
+	/* a linked list of data so we can access them for debugging */
+	struct list_head    list_session;
+	/* a linked list of register data waiting for process */
+	struct list_head    waiting;
+	/* a linked list of register data in processing */
+	struct list_head    running;
+	/* all coommand this thread done */
+    atomic_t            done;
+	wait_queue_head_t   wait;
+	pid_t           pid;
+	atomic_t        task_running;
+    atomic_t        num_done;
+} rga2_session;
+
 struct rga2_reg {
 	rga2_session		*session;
 	struct list_head	session_link;
@@ -686,46 +686,46 @@ struct rga2_reg {
 	struct dma_buf_attachment *attach_dst;
 };
 
-struct rga2_service_info {
-    struct mutex	lock;
-    struct timer_list	timer;			/* timer for power off */
-    struct list_head	waiting;		/* link to link_reg in struct vpu_reg */
-    struct list_head	running;		/* link to link_reg in struct vpu_reg */
-    struct list_head	done;			/* link to link_reg in struct vpu_reg */
-    struct list_head	session;		/* link to list_session in struct vpu_session */
-    atomic_t		total_running;
-
-    struct rga2_reg        *reg;
-
-    uint32_t            cmd_buff[32*8];/* cmd_buff for rga */
-    uint32_t            *pre_scale_buf;
-    atomic_t            int_disable;     /* 0 int enable 1 int disable  */
-    atomic_t            cmd_num;
-    atomic_t            src_format_swt;
-    int                 last_prc_src_format;
-    atomic_t            rga_working;
-    bool                enable;
-    uint32_t            dev_mode;
-
-    //struct rga_req      req[10];
-
-    struct mutex	mutex;	// mutex
-};
-
-#define RGA2_TEST_CASE 0
+struct rga2_service_info {
+    struct mutex	lock;
+    struct timer_list	timer;			/* timer for power off */
+    struct list_head	waiting;		/* link to link_reg in struct vpu_reg */
+    struct list_head	running;		/* link to link_reg in struct vpu_reg */
+    struct list_head	done;			/* link to link_reg in struct vpu_reg */
+    struct list_head	session;		/* link to list_session in struct vpu_session */
+    atomic_t		total_running;
+
+    struct rga2_reg        *reg;
+
+    uint32_t            cmd_buff[32*8];/* cmd_buff for rga */
+    uint32_t            *pre_scale_buf;
+    atomic_t            int_disable;     /* 0 int enable 1 int disable  */
+    atomic_t            cmd_num;
+    atomic_t            src_format_swt;
+    int                 last_prc_src_format;
+    atomic_t            rga_working;
+    bool                enable;
+    uint32_t            dev_mode;
+
+    //struct rga_req      req[10];
+
+    struct mutex	mutex;	// mutex
+};
+
+#define RGA2_TEST_CASE 0
 #define RGA2_DEBUGFS 1
-
-//General Registers
-#define RGA2_SYS_CTRL             0x000
-#define RGA2_CMD_CTRL             0x004
-#define RGA2_CMD_BASE             0x008
-#define RGA2_STATUS               0x00c
-#define RGA2_INT                  0x010
-#define RGA2_MMU_CTRL0            0x018
-#define RGA2_MMU_CMD_BASE         0x01c
-
-//Command code start
-#define RGA2_MODE_CTRL            0x100
-#define RGA_BLIT_COMPLETE_EVENT 1
-
-#endif /*_RK29_IPP_DRIVER_H_*/
+
+//General Registers
+#define RGA2_SYS_CTRL             0x000
+#define RGA2_CMD_CTRL             0x004
+#define RGA2_CMD_BASE             0x008
+#define RGA2_STATUS               0x00c
+#define RGA2_INT                  0x010
+#define RGA2_MMU_CTRL0            0x018
+#define RGA2_MMU_CMD_BASE         0x01c
+
+//Command code start
+#define RGA2_MODE_CTRL            0x100
+#define RGA_BLIT_COMPLETE_EVENT 1
+
+#endif /*_RK29_IPP_DRIVER_H_*/
diff --git a/drivers/video/rockchip/rga2/rga2_mmu_info.c b/drivers/video/rockchip/rga2/rga2_mmu_info.c
index 63337753d578..7836a6c50c81 100644
--- a/drivers/video/rockchip/rga2/rga2_mmu_info.c
+++ b/drivers/video/rockchip/rga2/rga2_mmu_info.c
@@ -1,43 +1,43 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-
-
-#include <linux/version.h>
-#include <linux/init.h>
-#include <linux/module.h>
-#include <linux/fs.h>
-#include <linux/sched.h>
-#include <linux/signal.h>
-#include <linux/pagemap.h>
-#include <linux/seq_file.h>
-#include <linux/mm.h>
-#include <linux/mman.h>
-#include <linux/sched.h>
-#include <linux/slab.h>
-#include <linux/memory.h>
-#include <linux/dma-mapping.h>
-#include <linux/scatterlist.h>
-#include <asm/memory.h>
-#include <asm/atomic.h>
-#include <asm/cacheflush.h>
-#include "rga2_mmu_info.h"
+
+
+#include <linux/version.h>
+#include <linux/init.h>
+#include <linux/module.h>
+#include <linux/fs.h>
+#include <linux/sched.h>
+#include <linux/signal.h>
+#include <linux/pagemap.h>
+#include <linux/seq_file.h>
+#include <linux/mm.h>
+#include <linux/mman.h>
+#include <linux/sched.h>
+#include <linux/slab.h>
+#include <linux/memory.h>
+#include <linux/dma-mapping.h>
+#include <linux/scatterlist.h>
+#include <asm/memory.h>
+#include <asm/atomic.h>
+#include <asm/cacheflush.h>
+#include "rga2_mmu_info.h"
 #if RGA2_DEBUGFS
 extern int RGA2_CHECK_MODE;
 #endif
-extern struct rga2_service_info rga2_service;
-extern struct rga2_mmu_buf_t rga2_mmu_buf;
-
-//extern int mmu_buff_temp[1024];
-
-#define KERNEL_SPACE_VALID    0xc0000000
-
-#define V7_VATOPA_SUCESS_MASK	(0x1)
-#define V7_VATOPA_GET_PADDR(X)	(X & 0xFFFFF000)
-#define V7_VATOPA_GET_INER(X)		((X>>4) & 7)
-#define V7_VATOPA_GET_OUTER(X)		((X>>2) & 3)
-#define V7_VATOPA_GET_SH(X)		((X>>7) & 1)
-#define V7_VATOPA_GET_NS(X)		((X>>9) & 1)
-#define V7_VATOPA_GET_SS(X)		((X>>1) & 1)
-
+extern struct rga2_service_info rga2_service;
+extern struct rga2_mmu_buf_t rga2_mmu_buf;
+
+//extern int mmu_buff_temp[1024];
+
+#define KERNEL_SPACE_VALID    0xc0000000
+
+#define V7_VATOPA_SUCESS_MASK	(0x1)
+#define V7_VATOPA_GET_PADDR(X)	(X & 0xFFFFF000)
+#define V7_VATOPA_GET_INER(X)		((X>>4) & 7)
+#define V7_VATOPA_GET_OUTER(X)		((X>>2) & 3)
+#define V7_VATOPA_GET_SH(X)		((X>>7) & 1)
+#define V7_VATOPA_GET_NS(X)		((X>>9) & 1)
+#define V7_VATOPA_GET_SS(X)		((X>>1) & 1)
+
 static void rga_dma_flush_range(void *pstart, void *pend)
 {
 #ifdef CONFIG_ARM
@@ -77,34 +77,34 @@ static void rga_dma_flush_page(struct page *page)
 #endif
 }
 
-#if 0
-static unsigned int armv7_va_to_pa(unsigned int v_addr)
-{
-	unsigned int p_addr;
-	__asm__ volatile (	"mcr p15, 0, %1, c7, c8, 0\n"
-						"isb\n"
-						"dsb\n"
-						"mrc p15, 0, %0, c7, c4, 0\n"
-						: "=r" (p_addr)
-						: "r" (v_addr)
-						: "cc");
-
-	if (p_addr & V7_VATOPA_SUCESS_MASK)
-		return 0xFFFFFFFF;
-	else
-		return (V7_VATOPA_GET_SS(p_addr) ? 0xFFFFFFFF : V7_VATOPA_GET_PADDR(p_addr));
-}
-#endif
-
-static int rga2_mmu_buf_get(struct rga2_mmu_buf_t *t, uint32_t size)
-{
-    mutex_lock(&rga2_service.lock);
-    t->front += size;
-    mutex_unlock(&rga2_service.lock);
-
-    return 0;
-}
-
+#if 0
+static unsigned int armv7_va_to_pa(unsigned int v_addr)
+{
+	unsigned int p_addr;
+	__asm__ volatile (	"mcr p15, 0, %1, c7, c8, 0\n"
+						"isb\n"
+						"dsb\n"
+						"mrc p15, 0, %0, c7, c4, 0\n"
+						: "=r" (p_addr)
+						: "r" (v_addr)
+						: "cc");
+
+	if (p_addr & V7_VATOPA_SUCESS_MASK)
+		return 0xFFFFFFFF;
+	else
+		return (V7_VATOPA_GET_SS(p_addr) ? 0xFFFFFFFF : V7_VATOPA_GET_PADDR(p_addr));
+}
+#endif
+
+static int rga2_mmu_buf_get(struct rga2_mmu_buf_t *t, uint32_t size)
+{
+    mutex_lock(&rga2_service.lock);
+    t->front += size;
+    mutex_unlock(&rga2_service.lock);
+
+    return 0;
+}
+
 static int rga2_mmu_buf_get_try(struct rga2_mmu_buf_t *t, uint32_t size)
 {
 	int ret = 0;
@@ -140,142 +140,142 @@ out:
 	return ret;
 }
 
-static int rga2_mem_size_cal(unsigned long Mem, uint32_t MemSize, unsigned long *StartAddr)
-{
-    unsigned long start, end;
-    uint32_t pageCount;
-
-    end = (Mem + (MemSize + PAGE_SIZE - 1)) >> PAGE_SHIFT;
-    start = Mem >> PAGE_SHIFT;
-    pageCount = end - start;
-    *StartAddr = start;
-    return pageCount;
-}
-
-static int rga2_buf_size_cal(unsigned long yrgb_addr, unsigned long uv_addr, unsigned long v_addr,
-                                        int format, uint32_t w, uint32_t h, unsigned long *StartAddr )
-{
-    uint32_t size_yrgb = 0;
-    uint32_t size_uv = 0;
-    uint32_t size_v = 0;
-    uint32_t stride = 0;
-    unsigned long start, end;
-    uint32_t pageCount;
-
-    switch(format)
-    {
-        case RGA2_FORMAT_RGBA_8888 :
-            stride = (w * 4 + 3) & (~3);
-            size_yrgb = stride*h;
-            start = yrgb_addr >> PAGE_SHIFT;
+static int rga2_mem_size_cal(unsigned long Mem, uint32_t MemSize, unsigned long *StartAddr)
+{
+    unsigned long start, end;
+    uint32_t pageCount;
+
+    end = (Mem + (MemSize + PAGE_SIZE - 1)) >> PAGE_SHIFT;
+    start = Mem >> PAGE_SHIFT;
+    pageCount = end - start;
+    *StartAddr = start;
+    return pageCount;
+}
+
+static int rga2_buf_size_cal(unsigned long yrgb_addr, unsigned long uv_addr, unsigned long v_addr,
+                                        int format, uint32_t w, uint32_t h, unsigned long *StartAddr )
+{
+    uint32_t size_yrgb = 0;
+    uint32_t size_uv = 0;
+    uint32_t size_v = 0;
+    uint32_t stride = 0;
+    unsigned long start, end;
+    uint32_t pageCount;
+
+    switch(format)
+    {
+        case RGA2_FORMAT_RGBA_8888 :
+            stride = (w * 4 + 3) & (~3);
+            size_yrgb = stride*h;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-        case RGA2_FORMAT_RGBX_8888 :
-            stride = (w * 4 + 3) & (~3);
-            size_yrgb = stride*h;
-            start = yrgb_addr >> PAGE_SHIFT;
+            break;
+        case RGA2_FORMAT_RGBX_8888 :
+            stride = (w * 4 + 3) & (~3);
+            size_yrgb = stride*h;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-        case RGA2_FORMAT_RGB_888 :
-            stride = (w * 3 + 3) & (~3);
-            size_yrgb = stride*h;
-            start = yrgb_addr >> PAGE_SHIFT;
+            break;
+        case RGA2_FORMAT_RGB_888 :
+            stride = (w * 3 + 3) & (~3);
+            size_yrgb = stride*h;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-        case RGA2_FORMAT_BGRA_8888 :
+            break;
+        case RGA2_FORMAT_BGRA_8888 :
             stride = (w * 4 + 3) & (~3);
             size_yrgb = stride * h;
-            start = yrgb_addr >> PAGE_SHIFT;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-        case RGA2_FORMAT_RGB_565 :
-            stride = (w*2 + 3) & (~3);
-            size_yrgb = stride * h;
-            start = yrgb_addr >> PAGE_SHIFT;
+            break;
+        case RGA2_FORMAT_RGB_565 :
+            stride = (w*2 + 3) & (~3);
+            size_yrgb = stride * h;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-        case RGA2_FORMAT_RGBA_5551 :
-            stride = (w*2 + 3) & (~3);
-            size_yrgb = stride * h;
-            start = yrgb_addr >> PAGE_SHIFT;
+            break;
+        case RGA2_FORMAT_RGBA_5551 :
+            stride = (w*2 + 3) & (~3);
+            size_yrgb = stride * h;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-        case RGA2_FORMAT_RGBA_4444 :
-            stride = (w*2 + 3) & (~3);
-            size_yrgb = stride * h;
-            start = yrgb_addr >> PAGE_SHIFT;
+            break;
+        case RGA2_FORMAT_RGBA_4444 :
+            stride = (w*2 + 3) & (~3);
+            size_yrgb = stride * h;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-        case RGA2_FORMAT_BGR_888 :
-            stride = (w*3 + 3) & (~3);
-            size_yrgb = stride * h;
-            start = yrgb_addr >> PAGE_SHIFT;
+            break;
+        case RGA2_FORMAT_BGR_888 :
+            stride = (w*3 + 3) & (~3);
+            size_yrgb = stride * h;
+            start = yrgb_addr >> PAGE_SHIFT;
 	    end = yrgb_addr + size_yrgb;
 	    end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 	    pageCount = end - start;
-            break;
-
-        /* YUV FORMAT */
-        case RGA2_FORMAT_YCbCr_422_SP :
-        case RGA2_FORMAT_YCrCb_422_SP :
-            stride = (w + 3) & (~3);
-            size_yrgb = stride * h;
-            size_uv = stride * h;
-            start = MIN(yrgb_addr, uv_addr);
-            start >>= PAGE_SHIFT;
-            end = MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv));
-            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
-            pageCount = end - start;
-            break;
-        case RGA2_FORMAT_YCbCr_422_P :
-        case RGA2_FORMAT_YCrCb_422_P :
-            stride = (w + 3) & (~3);
-            size_yrgb = stride * h;
-            size_uv = ((stride >> 1) * h);
-            size_v = ((stride >> 1) * h);
-            start = MIN(MIN(yrgb_addr, uv_addr), v_addr);
-            start = start >> PAGE_SHIFT;
-            end = MAX(MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv)), (v_addr + size_v));
-            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
-            pageCount = end - start;
-            break;
-        case RGA2_FORMAT_YCbCr_420_SP :
-        case RGA2_FORMAT_YCrCb_420_SP :
-            stride = (w + 3) & (~3);
-            size_yrgb = stride * h;
-            size_uv = (stride * (h >> 1));
-            start = MIN(yrgb_addr, uv_addr);
-            start >>= PAGE_SHIFT;
-            end = MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv));
-            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
-            pageCount = end - start;
-            break;
-        case RGA2_FORMAT_YCbCr_420_P :
-        case RGA2_FORMAT_YCrCb_420_P :
-            stride = (w + 3) & (~3);
-            size_yrgb = stride * h;
-            size_uv = ((stride >> 1) * (h >> 1));
-            size_v = ((stride >> 1) * (h >> 1));
-            start = MIN(MIN(yrgb_addr, uv_addr), v_addr);
-            start >>= PAGE_SHIFT;
-            end = MAX(MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv)), (v_addr + size_v));
-            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
-            pageCount = end - start;
-            break;
+            break;
+
+        /* YUV FORMAT */
+        case RGA2_FORMAT_YCbCr_422_SP :
+        case RGA2_FORMAT_YCrCb_422_SP :
+            stride = (w + 3) & (~3);
+            size_yrgb = stride * h;
+            size_uv = stride * h;
+            start = MIN(yrgb_addr, uv_addr);
+            start >>= PAGE_SHIFT;
+            end = MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv));
+            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
+            pageCount = end - start;
+            break;
+        case RGA2_FORMAT_YCbCr_422_P :
+        case RGA2_FORMAT_YCrCb_422_P :
+            stride = (w + 3) & (~3);
+            size_yrgb = stride * h;
+            size_uv = ((stride >> 1) * h);
+            size_v = ((stride >> 1) * h);
+            start = MIN(MIN(yrgb_addr, uv_addr), v_addr);
+            start = start >> PAGE_SHIFT;
+            end = MAX(MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv)), (v_addr + size_v));
+            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
+            pageCount = end - start;
+            break;
+        case RGA2_FORMAT_YCbCr_420_SP :
+        case RGA2_FORMAT_YCrCb_420_SP :
+            stride = (w + 3) & (~3);
+            size_yrgb = stride * h;
+            size_uv = (stride * (h >> 1));
+            start = MIN(yrgb_addr, uv_addr);
+            start >>= PAGE_SHIFT;
+            end = MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv));
+            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
+            pageCount = end - start;
+            break;
+        case RGA2_FORMAT_YCbCr_420_P :
+        case RGA2_FORMAT_YCrCb_420_P :
+            stride = (w + 3) & (~3);
+            size_yrgb = stride * h;
+            size_uv = ((stride >> 1) * (h >> 1));
+            size_v = ((stride >> 1) * (h >> 1));
+            start = MIN(MIN(yrgb_addr, uv_addr), v_addr);
+            start >>= PAGE_SHIFT;
+            end = MAX(MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv)), (v_addr + size_v));
+            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
+            pageCount = end - start;
+            break;
 	case RGA2_FORMAT_YVYU_422:
 	case RGA2_FORMAT_VYUY_422:
 	case RGA2_FORMAT_YUYV_422:
@@ -302,38 +302,38 @@ static int rga2_buf_size_cal(unsigned long yrgb_addr, unsigned long uv_addr, uns
 		end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
 		pageCount = end - start;
 		break;
-        #if 0
-        case RK_FORMAT_BPP1 :
-            break;
-        case RK_FORMAT_BPP2 :
-            break;
-        case RK_FORMAT_BPP4 :
-            break;
-        case RK_FORMAT_BPP8 :
-            break;
-        #endif
-        case RGA2_FORMAT_YCbCr_420_SP_10B:
-        case RGA2_FORMAT_YCrCb_420_SP_10B:
-            stride = (w + 3) & (~3);
-            stride = stride;
-            size_yrgb = stride * h;
-            size_uv = (stride * (h >> 1));
-            start = MIN(yrgb_addr, uv_addr);
-            start >>= PAGE_SHIFT;
-            end = MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv));
-            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
-            pageCount = end - start;
-            break;
-        default :
-            pageCount = 0;
-            start = 0;
-            break;
-    }
-
-    *StartAddr = start;
-    return pageCount;
-}
-
+        #if 0
+        case RK_FORMAT_BPP1 :
+            break;
+        case RK_FORMAT_BPP2 :
+            break;
+        case RK_FORMAT_BPP4 :
+            break;
+        case RK_FORMAT_BPP8 :
+            break;
+        #endif
+        case RGA2_FORMAT_YCbCr_420_SP_10B:
+        case RGA2_FORMAT_YCrCb_420_SP_10B:
+            stride = (w + 3) & (~3);
+            stride = stride;
+            size_yrgb = stride * h;
+            size_uv = (stride * (h >> 1));
+            start = MIN(yrgb_addr, uv_addr);
+            start >>= PAGE_SHIFT;
+            end = MAX((yrgb_addr + size_yrgb), (uv_addr + size_uv));
+            end = (end + (PAGE_SIZE - 1)) >> PAGE_SHIFT;
+            pageCount = end - start;
+            break;
+        default :
+            pageCount = 0;
+            start = 0;
+            break;
+    }
+
+    *StartAddr = start;
+    return pageCount;
+}
+
 #if RGA2_DEBUGFS
 static int rga2_UserMemory_cheeck(struct page **pages, u32 w, u32 h, u32 format, int flag)
 {
@@ -498,43 +498,43 @@ static int rga2_MapUserMemory(struct page **pages, uint32_t *pageTable,
 	return status;
 }
 
-static int rga2_MapION(struct sg_table *sg,
-                               uint32_t *Memory,
-                               int32_t  pageCount)
-{
-    uint32_t i;
-    uint32_t status;
-    unsigned long Address;
-    uint32_t mapped_size = 0;
-    uint32_t len;
-    struct scatterlist *sgl = sg->sgl;
-    uint32_t sg_num = 0;
-    uint32_t break_flag = 0;
-
-    status = 0;
-    Address = 0;
-    do {
-        len = sg_dma_len(sgl) >> PAGE_SHIFT;
-        Address = sg_phys(sgl);
-
-        for(i=0; i<len; i++) {
-            if (mapped_size + i >= pageCount) {
-                break_flag = 1;
-                break;
-            }
-            Memory[mapped_size + i] = (uint32_t)(Address + (i << PAGE_SHIFT));
-        }
-        if (break_flag)
-            break;
-        mapped_size += len;
-        sg_num += 1;
-    }
-    while((sgl = sg_next(sgl)) && (mapped_size < pageCount) && (sg_num < sg->nents));
-
-    return 0;
-}
-
-
+static int rga2_MapION(struct sg_table *sg,
+                               uint32_t *Memory,
+                               int32_t  pageCount)
+{
+    uint32_t i;
+    uint32_t status;
+    unsigned long Address;
+    uint32_t mapped_size = 0;
+    uint32_t len;
+    struct scatterlist *sgl = sg->sgl;
+    uint32_t sg_num = 0;
+    uint32_t break_flag = 0;
+
+    status = 0;
+    Address = 0;
+    do {
+        len = sg_dma_len(sgl) >> PAGE_SHIFT;
+        Address = sg_phys(sgl);
+
+        for(i=0; i<len; i++) {
+            if (mapped_size + i >= pageCount) {
+                break_flag = 1;
+                break;
+            }
+            Memory[mapped_size + i] = (uint32_t)(Address + (i << PAGE_SHIFT));
+        }
+        if (break_flag)
+            break;
+        mapped_size += len;
+        sg_num += 1;
+    }
+    while((sgl = sg_next(sgl)) && (mapped_size < pageCount) && (sg_num < sg->nents));
+
+    return 0;
+}
+
+
 static int rga2_mmu_info_BitBlt_mode(struct rga2_reg *reg, struct rga2_req *req)
 {
 	int Src0MemSize, DstMemSize, Src1MemSize;
@@ -710,340 +710,340 @@ out:
 	return status;
 }
 
-static int rga2_mmu_info_color_palette_mode(struct rga2_reg *reg, struct rga2_req *req)
-{
-    int SrcMemSize, DstMemSize;
-    unsigned long SrcStart, DstStart;
-    struct page **pages = NULL;
-    uint32_t AllSize;
-    uint32_t *MMU_Base = NULL, *MMU_Base_phys;
-    int ret, status;
-    uint32_t stride;
-
-    uint8_t shift;
-    uint16_t sw, byte_num;
-
-    shift = 3 - (req->palette_mode & 3);
-    sw = req->src.vir_w*req->src.vir_h;
-    byte_num = sw >> shift;
-    stride = (byte_num + 3) & (~3);
-
+static int rga2_mmu_info_color_palette_mode(struct rga2_reg *reg, struct rga2_req *req)
+{
+    int SrcMemSize, DstMemSize;
+    unsigned long SrcStart, DstStart;
+    struct page **pages = NULL;
+    uint32_t AllSize;
+    uint32_t *MMU_Base = NULL, *MMU_Base_phys;
+    int ret, status;
+    uint32_t stride;
+
+    uint8_t shift;
+    uint16_t sw, byte_num;
+
+    shift = 3 - (req->palette_mode & 3);
+    sw = req->src.vir_w*req->src.vir_h;
+    byte_num = sw >> shift;
+    stride = (byte_num + 3) & (~3);
+
     SrcStart = 0;
     DstStart = 0;
-    SrcMemSize = 0;
-    DstMemSize = 0;
-
-    do {
-        if (req->mmu_info.src0_mmu_flag) {
-            SrcMemSize = rga2_mem_size_cal(req->src.yrgb_addr, stride, &SrcStart);
-            if(SrcMemSize == 0) {
-                return -EINVAL;
-            }
-        }
-
-        if (req->mmu_info.dst_mmu_flag) {
-            DstMemSize = rga2_buf_size_cal(req->dst.yrgb_addr, req->dst.uv_addr, req->dst.v_addr,
-                                            req->dst.format, req->dst.vir_w, req->dst.vir_h,
-                                            &DstStart);
-            if(DstMemSize == 0) {
-                return -EINVAL;
-            }
-        }
-
-        SrcMemSize = (SrcMemSize + 15) & (~15);
-        DstMemSize = (DstMemSize + 15) & (~15);
-
-        AllSize = SrcMemSize + DstMemSize;
-
-        if (rga2_mmu_buf_get_try(&rga2_mmu_buf, AllSize)) {
-            pr_err("RGA2 Get MMU mem failed\n");
-            status = RGA2_MALLOC_ERROR;
-            break;
-        }
-
-        pages = rga2_mmu_buf.pages;
-        if(pages == NULL) {
-            pr_err("RGA MMU malloc pages mem failed\n");
-            return -EINVAL;
-        }
-
-        mutex_lock(&rga2_service.lock);
-        MMU_Base = rga2_mmu_buf.buf_virtual + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
-        MMU_Base_phys = rga2_mmu_buf.buf + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
-        mutex_unlock(&rga2_service.lock);
-
-        if(SrcMemSize) {
+    SrcMemSize = 0;
+    DstMemSize = 0;
+
+    do {
+        if (req->mmu_info.src0_mmu_flag) {
+            SrcMemSize = rga2_mem_size_cal(req->src.yrgb_addr, stride, &SrcStart);
+            if(SrcMemSize == 0) {
+                return -EINVAL;
+            }
+        }
+
+        if (req->mmu_info.dst_mmu_flag) {
+            DstMemSize = rga2_buf_size_cal(req->dst.yrgb_addr, req->dst.uv_addr, req->dst.v_addr,
+                                            req->dst.format, req->dst.vir_w, req->dst.vir_h,
+                                            &DstStart);
+            if(DstMemSize == 0) {
+                return -EINVAL;
+            }
+        }
+
+        SrcMemSize = (SrcMemSize + 15) & (~15);
+        DstMemSize = (DstMemSize + 15) & (~15);
+
+        AllSize = SrcMemSize + DstMemSize;
+
+        if (rga2_mmu_buf_get_try(&rga2_mmu_buf, AllSize)) {
+            pr_err("RGA2 Get MMU mem failed\n");
+            status = RGA2_MALLOC_ERROR;
+            break;
+        }
+
+        pages = rga2_mmu_buf.pages;
+        if(pages == NULL) {
+            pr_err("RGA MMU malloc pages mem failed\n");
+            return -EINVAL;
+        }
+
+        mutex_lock(&rga2_service.lock);
+        MMU_Base = rga2_mmu_buf.buf_virtual + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
+        MMU_Base_phys = rga2_mmu_buf.buf + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
+        mutex_unlock(&rga2_service.lock);
+
+        if(SrcMemSize) {
 		ret = rga2_MapUserMemory(&pages[0], &MMU_Base[0],
 					 SrcStart, SrcMemSize, 0);
-            if (ret < 0) {
-                pr_err("rga2 map src0 memory failed\n");
-                status = ret;
-                break;
-            }
-
-            /* change the buf address in req struct */
-            req->mmu_info.src0_base_addr = (((unsigned long)MMU_Base_phys));
-            req->src.yrgb_addr = (req->src.yrgb_addr & (~PAGE_MASK));
-        }
-
-        if(DstMemSize) {
+            if (ret < 0) {
+                pr_err("rga2 map src0 memory failed\n");
+                status = ret;
+                break;
+            }
+
+            /* change the buf address in req struct */
+            req->mmu_info.src0_base_addr = (((unsigned long)MMU_Base_phys));
+            req->src.yrgb_addr = (req->src.yrgb_addr & (~PAGE_MASK));
+        }
+
+        if(DstMemSize) {
 		ret = rga2_MapUserMemory(&pages[0], MMU_Base + SrcMemSize,
 					 DstStart, DstMemSize, 1);
-            if (ret < 0) {
-                pr_err("rga2 map dst memory failed\n");
-                status = ret;
-                break;
-            }
-
-            /* change the buf address in req struct */
-            req->mmu_info.dst_base_addr  = ((unsigned long)(MMU_Base_phys + SrcMemSize));
-            req->dst.yrgb_addr = (req->dst.yrgb_addr & (~PAGE_MASK));
-        }
-
-        /* flush data to DDR */
+            if (ret < 0) {
+                pr_err("rga2 map dst memory failed\n");
+                status = ret;
+                break;
+            }
+
+            /* change the buf address in req struct */
+            req->mmu_info.dst_base_addr  = ((unsigned long)(MMU_Base_phys + SrcMemSize));
+            req->dst.yrgb_addr = (req->dst.yrgb_addr & (~PAGE_MASK));
+        }
+
+        /* flush data to DDR */
         rga_dma_flush_range(MMU_Base, (MMU_Base + AllSize));
-        rga2_mmu_buf_get(&rga2_mmu_buf, AllSize);
-        reg->MMU_len = AllSize;
-
-        return 0;
-    }
-    while(0);
-
-    return 0;
-}
-
-static int rga2_mmu_info_color_fill_mode(struct rga2_reg *reg, struct rga2_req *req)
-{
-    int DstMemSize;
-    unsigned long DstStart;
-    struct page **pages = NULL;
-    uint32_t AllSize;
-    uint32_t *MMU_Base, *MMU_Base_phys;
-    int ret;
-    int status;
-
+        rga2_mmu_buf_get(&rga2_mmu_buf, AllSize);
+        reg->MMU_len = AllSize;
+
+        return 0;
+    }
+    while(0);
+
+    return 0;
+}
+
+static int rga2_mmu_info_color_fill_mode(struct rga2_reg *reg, struct rga2_req *req)
+{
+    int DstMemSize;
+    unsigned long DstStart;
+    struct page **pages = NULL;
+    uint32_t AllSize;
+    uint32_t *MMU_Base, *MMU_Base_phys;
+    int ret;
+    int status;
+
     DstMemSize = 0;
-    MMU_Base = NULL;
-
-    do {
-        if(req->mmu_info.dst_mmu_flag & 1) {
-            DstMemSize = rga2_buf_size_cal(req->dst.yrgb_addr, req->dst.uv_addr, req->dst.v_addr,
-                                        req->dst.format, req->dst.vir_w, req->dst.vir_h,
-                                        &DstStart);
-            if(DstMemSize == 0) {
-                return -EINVAL;
-            }
-        }
-
-        AllSize = (DstMemSize + 15) & (~15);
-
-        pages = rga2_mmu_buf.pages;
-
-        if(rga2_mmu_buf_get_try(&rga2_mmu_buf, AllSize)) {
-           pr_err("RGA2 Get MMU mem failed\n");
-           status = RGA2_MALLOC_ERROR;
-           break;
-        }
-
-        mutex_lock(&rga2_service.lock);
-        MMU_Base_phys = rga2_mmu_buf.buf + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
-        MMU_Base = rga2_mmu_buf.buf_virtual + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
-        mutex_unlock(&rga2_service.lock);
-
-        if (DstMemSize) {
-            if (req->sg_dst) {
-                ret = rga2_MapION(req->sg_dst, &MMU_Base[0], DstMemSize);
-            }
-            else {
+    MMU_Base = NULL;
+
+    do {
+        if(req->mmu_info.dst_mmu_flag & 1) {
+            DstMemSize = rga2_buf_size_cal(req->dst.yrgb_addr, req->dst.uv_addr, req->dst.v_addr,
+                                        req->dst.format, req->dst.vir_w, req->dst.vir_h,
+                                        &DstStart);
+            if(DstMemSize == 0) {
+                return -EINVAL;
+            }
+        }
+
+        AllSize = (DstMemSize + 15) & (~15);
+
+        pages = rga2_mmu_buf.pages;
+
+        if(rga2_mmu_buf_get_try(&rga2_mmu_buf, AllSize)) {
+           pr_err("RGA2 Get MMU mem failed\n");
+           status = RGA2_MALLOC_ERROR;
+           break;
+        }
+
+        mutex_lock(&rga2_service.lock);
+        MMU_Base_phys = rga2_mmu_buf.buf + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
+        MMU_Base = rga2_mmu_buf.buf_virtual + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
+        mutex_unlock(&rga2_service.lock);
+
+        if (DstMemSize) {
+            if (req->sg_dst) {
+                ret = rga2_MapION(req->sg_dst, &MMU_Base[0], DstMemSize);
+            }
+            else {
 		    ret = rga2_MapUserMemory(&pages[0], &MMU_Base[0],
 					     DstStart, DstMemSize, 1);
-            }
-            if (ret < 0) {
-                pr_err("rga2 map dst memory failed\n");
-                status = ret;
-                break;
-            }
-
-            /* change the buf address in req struct */
-            req->mmu_info.dst_base_addr = ((unsigned long)MMU_Base_phys);
-            req->dst.yrgb_addr = (req->dst.yrgb_addr & (~PAGE_MASK));
-        }
-
-        /* flush data to DDR */
+            }
+            if (ret < 0) {
+                pr_err("rga2 map dst memory failed\n");
+                status = ret;
+                break;
+            }
+
+            /* change the buf address in req struct */
+            req->mmu_info.dst_base_addr = ((unsigned long)MMU_Base_phys);
+            req->dst.yrgb_addr = (req->dst.yrgb_addr & (~PAGE_MASK));
+        }
+
+        /* flush data to DDR */
         rga_dma_flush_range(MMU_Base, (MMU_Base + AllSize + 1));
-        rga2_mmu_buf_get(&rga2_mmu_buf, AllSize);
+        rga2_mmu_buf_get(&rga2_mmu_buf, AllSize);
 	reg->MMU_len = AllSize;
 
-        return 0;
-    }
-    while(0);
-
-    return status;
-}
-
-
-static int rga2_mmu_info_update_palette_table_mode(struct rga2_reg *reg, struct rga2_req *req)
-{
-    int SrcMemSize;
-    unsigned long SrcStart;
-    struct page **pages = NULL;
-    uint32_t AllSize;
-    uint32_t *MMU_Base, *MMU_Base_phys;
-    int ret, status;
-
-    MMU_Base = NULL;
-
-    do {
-        /* cal src buf mmu info */
-        SrcMemSize = rga2_mem_size_cal(req->pat.yrgb_addr, req->pat.vir_w * req->pat.vir_h, &SrcStart);
-        if(SrcMemSize == 0) {
-            return -EINVAL;
-        }
-
-        SrcMemSize = (SrcMemSize + 15) & (~15);
-        AllSize = SrcMemSize;
-
-        if (rga2_mmu_buf_get_try(&rga2_mmu_buf, AllSize)) {
-            pr_err("RGA2 Get MMU mem failed\n");
-            status = RGA2_MALLOC_ERROR;
-            break;
-        }
-
-        mutex_lock(&rga2_service.lock);
-        MMU_Base = rga2_mmu_buf.buf_virtual + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
-        MMU_Base_phys = rga2_mmu_buf.buf + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
-        mutex_unlock(&rga2_service.lock);
-
-        pages = kzalloc(AllSize * sizeof(struct page *), GFP_KERNEL);
-
-        if(SrcMemSize) {
+        return 0;
+    }
+    while(0);
+
+    return status;
+}
+
+
+static int rga2_mmu_info_update_palette_table_mode(struct rga2_reg *reg, struct rga2_req *req)
+{
+    int SrcMemSize;
+    unsigned long SrcStart;
+    struct page **pages = NULL;
+    uint32_t AllSize;
+    uint32_t *MMU_Base, *MMU_Base_phys;
+    int ret, status;
+
+    MMU_Base = NULL;
+
+    do {
+        /* cal src buf mmu info */
+        SrcMemSize = rga2_mem_size_cal(req->pat.yrgb_addr, req->pat.vir_w * req->pat.vir_h, &SrcStart);
+        if(SrcMemSize == 0) {
+            return -EINVAL;
+        }
+
+        SrcMemSize = (SrcMemSize + 15) & (~15);
+        AllSize = SrcMemSize;
+
+        if (rga2_mmu_buf_get_try(&rga2_mmu_buf, AllSize)) {
+            pr_err("RGA2 Get MMU mem failed\n");
+            status = RGA2_MALLOC_ERROR;
+            break;
+        }
+
+        mutex_lock(&rga2_service.lock);
+        MMU_Base = rga2_mmu_buf.buf_virtual + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
+        MMU_Base_phys = rga2_mmu_buf.buf + (rga2_mmu_buf.front & (rga2_mmu_buf.size - 1));
+        mutex_unlock(&rga2_service.lock);
+
+        pages = kzalloc(AllSize * sizeof(struct page *), GFP_KERNEL);
+
+        if(SrcMemSize) {
 		ret = rga2_MapUserMemory(&pages[0], &MMU_Base[0],
 					 SrcStart, SrcMemSize, 0);
-            if (ret < 0) {
-                pr_err("rga2 map palette memory failed\n");
-                status = ret;
-                break;
-            }
-
-            /* change the buf address in req struct */
-            req->mmu_info.src0_base_addr = (((unsigned long)MMU_Base_phys));
-            req->pat.yrgb_addr = (req->pat.yrgb_addr & (~PAGE_MASK));
-        }
-
-        /* flush data to DDR */
+            if (ret < 0) {
+                pr_err("rga2 map palette memory failed\n");
+                status = ret;
+                break;
+            }
+
+            /* change the buf address in req struct */
+            req->mmu_info.src0_base_addr = (((unsigned long)MMU_Base_phys));
+            req->pat.yrgb_addr = (req->pat.yrgb_addr & (~PAGE_MASK));
+        }
+
+        /* flush data to DDR */
         rga_dma_flush_range(MMU_Base, (MMU_Base + AllSize));
-        rga2_mmu_buf_get(&rga2_mmu_buf, AllSize);
-        reg->MMU_len = AllSize;
-
-        return 0;
-    }
-    while(0);
-
-    return status;
-}
-
-static int rga2_mmu_info_update_patten_buff_mode(struct rga2_reg *reg, struct rga2_req *req)
-{
-    int SrcMemSize, CMDMemSize;
-    unsigned long SrcStart, CMDStart;
-    struct page **pages = NULL;
-    uint32_t i;
-    uint32_t AllSize;
-    uint32_t *MMU_Base, *MMU_p;
-    int ret, status;
-
-    MMU_Base = MMU_p = 0;
-
-    do {
-        /* cal src buf mmu info */
-        SrcMemSize = rga2_mem_size_cal(req->pat.yrgb_addr, req->pat.act_w * req->pat.act_h * 4, &SrcStart);
-        if(SrcMemSize == 0) {
-            return -EINVAL;
-        }
-
-        /* cal cmd buf mmu info */
-        CMDMemSize = rga2_mem_size_cal((unsigned long)rga2_service.cmd_buff, RGA2_CMD_BUF_SIZE, &CMDStart);
-        if(CMDMemSize == 0) {
-            return -EINVAL;
-        }
-
-        AllSize = SrcMemSize + CMDMemSize;
-
-        pages = rga2_mmu_buf.pages;
-
-        MMU_Base = kzalloc(AllSize * sizeof(uint32_t), GFP_KERNEL);
-
-        for(i=0; i<CMDMemSize; i++) {
-            MMU_Base[i] = virt_to_phys((uint32_t *)((CMDStart + i) << PAGE_SHIFT));
-        }
-
-        if (req->src.yrgb_addr < KERNEL_SPACE_VALID)
-        {
+        rga2_mmu_buf_get(&rga2_mmu_buf, AllSize);
+        reg->MMU_len = AllSize;
+
+        return 0;
+    }
+    while(0);
+
+    return status;
+}
+
+static int rga2_mmu_info_update_patten_buff_mode(struct rga2_reg *reg, struct rga2_req *req)
+{
+    int SrcMemSize, CMDMemSize;
+    unsigned long SrcStart, CMDStart;
+    struct page **pages = NULL;
+    uint32_t i;
+    uint32_t AllSize;
+    uint32_t *MMU_Base, *MMU_p;
+    int ret, status;
+
+    MMU_Base = MMU_p = 0;
+
+    do {
+        /* cal src buf mmu info */
+        SrcMemSize = rga2_mem_size_cal(req->pat.yrgb_addr, req->pat.act_w * req->pat.act_h * 4, &SrcStart);
+        if(SrcMemSize == 0) {
+            return -EINVAL;
+        }
+
+        /* cal cmd buf mmu info */
+        CMDMemSize = rga2_mem_size_cal((unsigned long)rga2_service.cmd_buff, RGA2_CMD_BUF_SIZE, &CMDStart);
+        if(CMDMemSize == 0) {
+            return -EINVAL;
+        }
+
+        AllSize = SrcMemSize + CMDMemSize;
+
+        pages = rga2_mmu_buf.pages;
+
+        MMU_Base = kzalloc(AllSize * sizeof(uint32_t), GFP_KERNEL);
+
+        for(i=0; i<CMDMemSize; i++) {
+            MMU_Base[i] = virt_to_phys((uint32_t *)((CMDStart + i) << PAGE_SHIFT));
+        }
+
+        if (req->src.yrgb_addr < KERNEL_SPACE_VALID)
+        {
 		ret = rga2_MapUserMemory(&pages[CMDMemSize],
 					 &MMU_Base[CMDMemSize],
 					 SrcStart, SrcMemSize, 1);
-            if (ret < 0) {
-                pr_err("rga map src memory failed\n");
-                status = ret;
-                break;
-            }
-        }
-        else
-        {
-            MMU_p = MMU_Base + CMDMemSize;
-
-            for(i=0; i<SrcMemSize; i++)
-            {
-                MMU_p[i] = (uint32_t)virt_to_phys((uint32_t *)((SrcStart + i) << PAGE_SHIFT));
-            }
-        }
-
-        /* zsq
-         * change the buf address in req struct
-         * for the reason of lie to MMU
-         */
-        req->mmu_info.src0_base_addr = (virt_to_phys(MMU_Base) >> 2);
-
-        req->src.yrgb_addr = (req->src.yrgb_addr & (~PAGE_MASK)) | (CMDMemSize << PAGE_SHIFT);
-
-        /*record the malloc buf for the cmd end to release*/
-        reg->MMU_base = MMU_Base;
-
-        /* flush data to DDR */
+            if (ret < 0) {
+                pr_err("rga map src memory failed\n");
+                status = ret;
+                break;
+            }
+        }
+        else
+        {
+            MMU_p = MMU_Base + CMDMemSize;
+
+            for(i=0; i<SrcMemSize; i++)
+            {
+                MMU_p[i] = (uint32_t)virt_to_phys((uint32_t *)((SrcStart + i) << PAGE_SHIFT));
+            }
+        }
+
+        /* zsq
+         * change the buf address in req struct
+         * for the reason of lie to MMU
+         */
+        req->mmu_info.src0_base_addr = (virt_to_phys(MMU_Base) >> 2);
+
+        req->src.yrgb_addr = (req->src.yrgb_addr & (~PAGE_MASK)) | (CMDMemSize << PAGE_SHIFT);
+
+        /*record the malloc buf for the cmd end to release*/
+        reg->MMU_base = MMU_Base;
+
+        /* flush data to DDR */
         rga_dma_flush_range(MMU_Base, (MMU_Base + AllSize));
-        return 0;
-
-    }
-    while(0);
-
-    return status;
-}
-
-int rga2_set_mmu_info(struct rga2_reg *reg, struct rga2_req *req)
-{
-    int ret;
-
-    switch (req->render_mode) {
-        case bitblt_mode :
-            ret = rga2_mmu_info_BitBlt_mode(reg, req);
-            break;
-        case color_palette_mode :
-            ret = rga2_mmu_info_color_palette_mode(reg, req);
-            break;
-        case color_fill_mode :
-            ret = rga2_mmu_info_color_fill_mode(reg, req);
-            break;
-        case update_palette_table_mode :
-            ret = rga2_mmu_info_update_palette_table_mode(reg, req);
-            break;
-        case update_patten_buff_mode :
-            ret = rga2_mmu_info_update_patten_buff_mode(reg, req);
-            break;
-        default :
-            ret = -1;
-            break;
-    }
-
-    return ret;
-}
-
+        return 0;
+
+    }
+    while(0);
+
+    return status;
+}
+
+int rga2_set_mmu_info(struct rga2_reg *reg, struct rga2_req *req)
+{
+    int ret;
+
+    switch (req->render_mode) {
+        case bitblt_mode :
+            ret = rga2_mmu_info_BitBlt_mode(reg, req);
+            break;
+        case color_palette_mode :
+            ret = rga2_mmu_info_color_palette_mode(reg, req);
+            break;
+        case color_fill_mode :
+            ret = rga2_mmu_info_color_fill_mode(reg, req);
+            break;
+        case update_palette_table_mode :
+            ret = rga2_mmu_info_update_palette_table_mode(reg, req);
+            break;
+        case update_patten_buff_mode :
+            ret = rga2_mmu_info_update_patten_buff_mode(reg, req);
+            break;
+        default :
+            ret = -1;
+            break;
+    }
+
+    return ret;
+}
+
diff --git a/drivers/video/rockchip/rga2/rga2_mmu_info.h b/drivers/video/rockchip/rga2/rga2_mmu_info.h
index f342b68caf77..6e91373764d6 100644
--- a/drivers/video/rockchip/rga2/rga2_mmu_info.h
+++ b/drivers/video/rockchip/rga2/rga2_mmu_info.h
@@ -1,21 +1,21 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __RGA_MMU_INFO_H__
-#define __RGA_MMU_INFO_H__
-
-#include "rga2.h"
-
-#ifndef MIN
-#define MIN(X, Y)           ((X)<(Y)?(X):(Y))
-#endif
-
-#ifndef MAX
-#define MAX(X, Y)           ((X)>(Y)?(X):(Y))
-#endif
-
-
-int rga2_set_mmu_info(struct rga2_reg *reg, struct rga2_req *req);
-
-
-#endif
-
-
+#ifndef __RGA_MMU_INFO_H__
+#define __RGA_MMU_INFO_H__
+
+#include "rga2.h"
+
+#ifndef MIN
+#define MIN(X, Y)           ((X)<(Y)?(X):(Y))
+#endif
+
+#ifndef MAX
+#define MAX(X, Y)           ((X)>(Y)?(X):(Y))
+#endif
+
+
+int rga2_set_mmu_info(struct rga2_reg *reg, struct rga2_req *req);
+
+
+#endif
+
+
diff --git a/drivers/video/rockchip/rga2/rga2_reg_info.c b/drivers/video/rockchip/rga2/rga2_reg_info.c
index 5f231d6f3e24..33befdb2437d 100644
--- a/drivers/video/rockchip/rga2/rga2_reg_info.c
+++ b/drivers/video/rockchip/rga2/rga2_reg_info.c
@@ -1,398 +1,398 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-
-//#include <linux/kernel.h>
-#include <linux/memory.h>
-#include <linux/kernel.h>
-#include <linux/init.h>
-#include <linux/module.h>
-#include <linux/platform_device.h>
-#include <linux/sched.h>
-#include <linux/mutex.h>
-#include <linux/err.h>
-#include <linux/clk.h>
-#include <asm/delay.h>
-#include <linux/dma-mapping.h>
-#include <linux/delay.h>
-#include <asm/io.h>
-#include <linux/irq.h>
-#include <linux/interrupt.h>
-#include <linux/fs.h>
-#include <asm/uaccess.h>
-#include <linux/miscdevice.h>
-#include <linux/poll.h>
-#include <linux/delay.h>
-#include <linux/wait.h>
-#include <linux/syscalls.h>
-#include <linux/timer.h>
-#include <linux/time.h>
-#include <asm/cacheflush.h>
-#include <linux/slab.h>
-#include <linux/fb.h>
-#include <linux/wakelock.h>
+
+//#include <linux/kernel.h>
+#include <linux/memory.h>
+#include <linux/kernel.h>
+#include <linux/init.h>
+#include <linux/module.h>
+#include <linux/platform_device.h>
+#include <linux/sched.h>
+#include <linux/mutex.h>
+#include <linux/err.h>
+#include <linux/clk.h>
+#include <asm/delay.h>
+#include <linux/dma-mapping.h>
+#include <linux/delay.h>
+#include <asm/io.h>
+#include <linux/irq.h>
+#include <linux/interrupt.h>
+#include <linux/fs.h>
+#include <asm/uaccess.h>
+#include <linux/miscdevice.h>
+#include <linux/poll.h>
+#include <linux/delay.h>
+#include <linux/wait.h>
+#include <linux/syscalls.h>
+#include <linux/timer.h>
+#include <linux/time.h>
+#include <asm/cacheflush.h>
+#include <linux/slab.h>
+#include <linux/fb.h>
+#include <linux/wakelock.h>
 #include <linux/version.h>
-
-#include "rga2_reg_info.h"
+
+#include "rga2_reg_info.h"
 #include "rga2_type.h"
 #include "rga2_rop.h"
-#include "rga2.h"
-
+#include "rga2.h"
+
 static void RGA2_reg_get_param(unsigned char *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_SRC_INFO;
-    RK_U32 *bRGA_SRC_X_FACTOR;
-    RK_U32 *bRGA_SRC_Y_FACTOR;
-    RK_U32 sw, sh;
-    RK_U32 dw, dh;
-    RK_U32 param_x, param_y;
-    RK_U8 x_flag, y_flag;
-
-    RK_U32 reg;
-
-    bRGA_SRC_INFO = (RK_U32 *)(base + RGA2_SRC_INFO_OFFSET);
-    reg = *bRGA_SRC_INFO;
-
-    bRGA_SRC_X_FACTOR = (RK_U32 *)(base + RGA2_SRC_X_FACTOR_OFFSET);
-    bRGA_SRC_Y_FACTOR = (RK_U32 *)(base + RGA2_SRC_Y_FACTOR_OFFSET);
-
-    x_flag = y_flag = 0;
-
-    if(((msg->rotate_mode & 0x3) == 1) || ((msg->rotate_mode & 0x3) == 3))
-    {
-        dw = msg->dst.act_h;
-        dh = msg->dst.act_w;
-    }
-    else
-    {
-        dw = msg->dst.act_w;
-        dh = msg->dst.act_h;
-    }
-
-    sw = msg->src.act_w;
-    sh = msg->src.act_h;
-
-    if (sw > dw)
-    {
-        x_flag = 1;
-        #if SCALE_DOWN_LARGE
-        param_x = ((dw) << 16) / (sw) + 1;
-		#else
-        param_x = ((dw) << 16) / (sw);
-        #endif
-        *bRGA_SRC_X_FACTOR |= ((param_x & 0xffff) << 0 );
-    }
-    else if (sw < dw)
-    {
-        x_flag = 2;
-        #if 1//SCALE_MINUS1
-        param_x = ((sw - 1) << 16) / (dw - 1);
-        #else
-        param_x = ((sw) << 16) / (dw);
-		#endif
-        *bRGA_SRC_X_FACTOR |= ((param_x & 0xffff) << 16);
-    }
-    else
-    {
-        *bRGA_SRC_X_FACTOR = 0;//((1 << 14) << 16) | (1 << 14);
-    }
-
-    if (sh > dh)
-    {
-        y_flag = 1;
-        #if SCALE_DOWN_LARGE
-        param_y = ((dh) << 16) / (sh) + 1;
-		#else
-        param_y = ((dh) << 16) / (sh);
-        #endif
-        *bRGA_SRC_Y_FACTOR |= ((param_y & 0xffff) << 0 );
-    }
-    else if (sh < dh)
-    {
-        y_flag = 2;
-        #if 1//SCALE_MINUS1
-        param_y = ((sh - 1) << 16) / (dh - 1);
-        #else
-        param_y = ((sh) << 16) / (dh);
-		#endif
-        *bRGA_SRC_Y_FACTOR |= ((param_y & 0xffff) << 16);
-    }
-    else
-    {
-        *bRGA_SRC_Y_FACTOR = 0;//((1 << 14) << 16) | (1 << 14);
-    }
-
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE(x_flag)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE(y_flag)));
-}
-
+{
+    RK_U32 *bRGA_SRC_INFO;
+    RK_U32 *bRGA_SRC_X_FACTOR;
+    RK_U32 *bRGA_SRC_Y_FACTOR;
+    RK_U32 sw, sh;
+    RK_U32 dw, dh;
+    RK_U32 param_x, param_y;
+    RK_U8 x_flag, y_flag;
+
+    RK_U32 reg;
+
+    bRGA_SRC_INFO = (RK_U32 *)(base + RGA2_SRC_INFO_OFFSET);
+    reg = *bRGA_SRC_INFO;
+
+    bRGA_SRC_X_FACTOR = (RK_U32 *)(base + RGA2_SRC_X_FACTOR_OFFSET);
+    bRGA_SRC_Y_FACTOR = (RK_U32 *)(base + RGA2_SRC_Y_FACTOR_OFFSET);
+
+    x_flag = y_flag = 0;
+
+    if(((msg->rotate_mode & 0x3) == 1) || ((msg->rotate_mode & 0x3) == 3))
+    {
+        dw = msg->dst.act_h;
+        dh = msg->dst.act_w;
+    }
+    else
+    {
+        dw = msg->dst.act_w;
+        dh = msg->dst.act_h;
+    }
+
+    sw = msg->src.act_w;
+    sh = msg->src.act_h;
+
+    if (sw > dw)
+    {
+        x_flag = 1;
+        #if SCALE_DOWN_LARGE
+        param_x = ((dw) << 16) / (sw) + 1;
+		#else
+        param_x = ((dw) << 16) / (sw);
+        #endif
+        *bRGA_SRC_X_FACTOR |= ((param_x & 0xffff) << 0 );
+    }
+    else if (sw < dw)
+    {
+        x_flag = 2;
+        #if 1//SCALE_MINUS1
+        param_x = ((sw - 1) << 16) / (dw - 1);
+        #else
+        param_x = ((sw) << 16) / (dw);
+		#endif
+        *bRGA_SRC_X_FACTOR |= ((param_x & 0xffff) << 16);
+    }
+    else
+    {
+        *bRGA_SRC_X_FACTOR = 0;//((1 << 14) << 16) | (1 << 14);
+    }
+
+    if (sh > dh)
+    {
+        y_flag = 1;
+        #if SCALE_DOWN_LARGE
+        param_y = ((dh) << 16) / (sh) + 1;
+		#else
+        param_y = ((dh) << 16) / (sh);
+        #endif
+        *bRGA_SRC_Y_FACTOR |= ((param_y & 0xffff) << 0 );
+    }
+    else if (sh < dh)
+    {
+        y_flag = 2;
+        #if 1//SCALE_MINUS1
+        param_y = ((sh - 1) << 16) / (dh - 1);
+        #else
+        param_y = ((sh) << 16) / (dh);
+		#endif
+        *bRGA_SRC_Y_FACTOR |= ((param_y & 0xffff) << 16);
+    }
+    else
+    {
+        *bRGA_SRC_Y_FACTOR = 0;//((1 << 14) << 16) | (1 << 14);
+    }
+
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE(x_flag)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE(y_flag)));
+}
+
 static void RGA2_set_mode_ctrl(u8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_MODE_CTL;
-    RK_U32 reg = 0;
-    RK_U32 render_mode = msg->render_mode;
-
-    bRGA_MODE_CTL = (u32 *)(base + RGA2_MODE_CTRL_OFFSET);
-
-    if(msg->render_mode == 4)
-    {
-        render_mode = 3;
-    }
-
-    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_RENDER_MODE)) | (s_RGA2_MODE_CTRL_SW_RENDER_MODE(render_mode)));
-    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_BITBLT_MODE)) | (s_RGA2_MODE_CTRL_SW_BITBLT_MODE(msg->bitblt_mode)));
-    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_CF_ROP4_PAT)) | (s_RGA2_MODE_CTRL_SW_CF_ROP4_PAT(msg->color_fill_mode)));
-    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET)) | (s_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET(msg->alpha_zero_key)));
-    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_GRADIENT_SAT)) | (s_RGA2_MODE_CTRL_SW_GRADIENT_SAT(msg->alpha_rop_flag >> 7)));
-    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_INTR_CF_E)) | (s_RGA2_MODE_CTRL_SW_INTR_CF_E(msg->CMD_fin_int_enable)));
-
-    *bRGA_MODE_CTL = reg;
-}
-
+{
+    RK_U32 *bRGA_MODE_CTL;
+    RK_U32 reg = 0;
+    RK_U32 render_mode = msg->render_mode;
+
+    bRGA_MODE_CTL = (u32 *)(base + RGA2_MODE_CTRL_OFFSET);
+
+    if(msg->render_mode == 4)
+    {
+        render_mode = 3;
+    }
+
+    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_RENDER_MODE)) | (s_RGA2_MODE_CTRL_SW_RENDER_MODE(render_mode)));
+    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_BITBLT_MODE)) | (s_RGA2_MODE_CTRL_SW_BITBLT_MODE(msg->bitblt_mode)));
+    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_CF_ROP4_PAT)) | (s_RGA2_MODE_CTRL_SW_CF_ROP4_PAT(msg->color_fill_mode)));
+    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET)) | (s_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET(msg->alpha_zero_key)));
+    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_GRADIENT_SAT)) | (s_RGA2_MODE_CTRL_SW_GRADIENT_SAT(msg->alpha_rop_flag >> 7)));
+    reg = ((reg & (~m_RGA2_MODE_CTRL_SW_INTR_CF_E)) | (s_RGA2_MODE_CTRL_SW_INTR_CF_E(msg->CMD_fin_int_enable)));
+
+    *bRGA_MODE_CTL = reg;
+}
+
 static void RGA2_set_reg_src_info(RK_U8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_SRC_INFO;
-    RK_U32 *bRGA_SRC_BASE0, *bRGA_SRC_BASE1, *bRGA_SRC_BASE2;
-    RK_U32 *bRGA_SRC_VIR_INFO;
-    RK_U32 *bRGA_SRC_ACT_INFO;
-    RK_U32 *bRGA_MASK_ADDR;
-	RK_U32 *bRGA_SRC_TR_COLOR0, *bRGA_SRC_TR_COLOR1;
-
-    RK_U32 reg = 0;
-    RK_U8 src0_format = 0;
-
-    RK_U8 src0_rb_swp = 0;
-    RK_U8 src0_rgb_pack = 0;
-
-    RK_U8 src0_cbcr_swp = 0;
-    RK_U8 pixel_width = 1;
-    RK_U32 stride = 0;
-    RK_U32 uv_stride = 0;
-    RK_U32 mask_stride = 0;
-    RK_U32 ydiv = 1, xdiv = 2;
-    RK_U8  yuv10 = 0;
-
-    RK_U32 sw, sh;
-    RK_U32 dw, dh;
-    RK_U8 rotate_mode;
-    RK_U8 scale_w_flag, scale_h_flag;
-
-    bRGA_SRC_INFO = (RK_U32 *)(base + RGA2_SRC_INFO_OFFSET);
-
-    bRGA_SRC_BASE0 = (RK_U32 *)(base + RGA2_SRC_BASE0_OFFSET);
-    bRGA_SRC_BASE1 = (RK_U32 *)(base + RGA2_SRC_BASE1_OFFSET);
-    bRGA_SRC_BASE2 = (RK_U32 *)(base + RGA2_SRC_BASE2_OFFSET);
-
-    bRGA_SRC_VIR_INFO = (RK_U32 *)(base + RGA2_SRC_VIR_INFO_OFFSET);
-    bRGA_SRC_ACT_INFO = (RK_U32 *)(base + RGA2_SRC_ACT_INFO_OFFSET);
-
-    bRGA_MASK_ADDR = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
-
-    bRGA_SRC_TR_COLOR0 = (RK_U32 *)(base + RGA2_SRC_TR_COLOR0_OFFSET);
-    bRGA_SRC_TR_COLOR1 = (RK_U32 *)(base + RGA2_SRC_TR_COLOR1_OFFSET);
-
-    if (msg->src.format == RGA2_FORMAT_YCbCr_420_SP_10B ||
-        msg->src.format == RGA2_FORMAT_YCrCb_420_SP_10B) {
-       if ((msg->src.act_w == msg->dst.act_w) &&
-           (msg->src.act_h == msg->dst.act_h) &&
-           (msg->rotate_mode == 0))
-           msg->rotate_mode = 1 << 6;
-    }
-
-    {
-        rotate_mode = msg->rotate_mode & 0x3;
-
-        sw = msg->src.act_w;
-        sh = msg->src.act_h;
-
-        if((rotate_mode == 1) | (rotate_mode == 3))
-        {
-            dw = msg->dst.act_h;
-            dh = msg->dst.act_w;
-        }
-        else
-        {
-            dw = msg->dst.act_w;
-            dh = msg->dst.act_h;
-        }
-
-        if(sw > dw)
-            scale_w_flag = 1;
-        else if (sw < dw)
-            scale_w_flag = 2;
-        else {
-            scale_w_flag = 0;
-            if(msg->rotate_mode >> 6)
-                scale_w_flag = 3;
-        }
-
-        if(sh > dh)
-            scale_h_flag = 1;
-        else if (sh < dh)
-            scale_h_flag = 2;
-        else {
-            scale_h_flag = 0;
-            if(msg->rotate_mode >> 6)
-                scale_h_flag = 3;
-        }
-    }
-
-    switch (msg->src.format)
-    {
-        case RGA2_FORMAT_RGBA_8888    : src0_format = 0x0; pixel_width = 4; break;
-        case RGA2_FORMAT_BGRA_8888    : src0_format = 0x0; src0_rb_swp = 0x1; pixel_width = 4; break;
-        case RGA2_FORMAT_RGBX_8888    : src0_format = 0x1; pixel_width = 4; msg->src_trans_mode &= 0x07; break;
-        case RGA2_FORMAT_BGRX_8888    : src0_format = 0x1; src0_rb_swp = 0x1; pixel_width = 4; msg->src_trans_mode &= 0x07; break;
-        case RGA2_FORMAT_RGB_888      : src0_format = 0x2; src0_rgb_pack = 1; pixel_width = 3; msg->src_trans_mode &= 0x07; break;
-        case RGA2_FORMAT_BGR_888      : src0_format = 0x2; src0_rgb_pack = 1; src0_rb_swp = 1; pixel_width = 3; msg->src_trans_mode &= 0x07; break;
-        case RGA2_FORMAT_RGB_565      : src0_format = 0x4; pixel_width = 2; msg->src_trans_mode &= 0x07; src0_rb_swp = 0x1; break;
-        case RGA2_FORMAT_RGBA_5551    : src0_format = 0x5; pixel_width = 2; src0_rb_swp = 0x1; break;
-        case RGA2_FORMAT_RGBA_4444    : src0_format = 0x6; pixel_width = 2; src0_rb_swp = 0x1; break;
-        case RGA2_FORMAT_BGR_565      : src0_format = 0x4; pixel_width = 2; msg->src_trans_mode &= 0x07; break;
-        case RGA2_FORMAT_BGRA_5551    : src0_format = 0x5; pixel_width = 2; break;
-        case RGA2_FORMAT_BGRA_4444    : src0_format = 0x6; pixel_width = 2; break;
-
-        case RGA2_FORMAT_YCbCr_422_SP : src0_format = 0x8; xdiv = 1; ydiv = 1; break;
-        case RGA2_FORMAT_YCbCr_422_P  : src0_format = 0x9; xdiv = 2; ydiv = 1; break;
-        case RGA2_FORMAT_YCbCr_420_SP : src0_format = 0xa; xdiv = 1; ydiv = 2; break;
-        case RGA2_FORMAT_YCbCr_420_P  : src0_format = 0xb; xdiv = 2; ydiv = 2; break;
-        case RGA2_FORMAT_YCrCb_422_SP : src0_format = 0x8; xdiv = 1; ydiv = 1; src0_cbcr_swp = 1; break;
-        case RGA2_FORMAT_YCrCb_422_P  : src0_format = 0x9; xdiv = 2; ydiv = 1; src0_cbcr_swp = 1; break;
-        case RGA2_FORMAT_YCrCb_420_SP : src0_format = 0xa; xdiv = 1; ydiv = 2; src0_cbcr_swp = 1; break;
-        case RGA2_FORMAT_YCrCb_420_P  : src0_format = 0xb; xdiv = 2; ydiv = 2; src0_cbcr_swp = 1; break;
-        case RGA2_FORMAT_YCbCr_420_SP_10B : src0_format = 0xa; xdiv = 1; ydiv = 2; yuv10 = 1; break;
-        case RGA2_FORMAT_YCrCb_420_SP_10B : src0_format = 0xa; xdiv = 1; ydiv = 2; src0_cbcr_swp = 1; yuv10 = 1; break;
-    };
-
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SRC_FMT)) | (s_RGA2_SRC_INFO_SW_SRC_FMT(src0_format)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP)) | (s_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP(src0_rb_swp)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP)) | (s_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP(msg->alpha_swp)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP)) | (s_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP(src0_cbcr_swp)));
-    if(msg->src.format <= RGA2_FORMAT_BGRA_4444)
-    	reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(0)));
-    else
-        if(msg->dst.format >= RGA2_FORMAT_YCbCr_422_SP)
-            reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(0)));
-        else
-    	    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(msg->yuv2rgb_mode)));
-
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE(msg->rotate_mode & 0x3)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE((msg->rotate_mode >> 4) & 0x3)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE((scale_w_flag))));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE((scale_h_flag))));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER)) | (s_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER((msg->scale_bicu_mode))));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE(msg->src_trans_mode)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E)) | (s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E(msg->src_trans_mode >> 1)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E)) | (s_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E((msg->alpha_rop_flag >> 4) & 0x1)));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL)) | (s_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL((msg->scale_bicu_mode>>4))));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_YUV10_E)) | (s_RGA2_SRC_INFO_SW_SW_YUV10_E((yuv10))));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E)) | (s_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E((yuv10))));
-    RGA2_reg_get_param(base, msg);
-
-    stride = (((msg->src.vir_w * pixel_width) + 3) & ~3) >> 2;
-    uv_stride = ((msg->src.vir_w / xdiv + 3) & ~3);
-
-    *bRGA_SRC_BASE0 = (RK_U32)(msg->src.yrgb_addr + msg->src.y_offset * (stride<<2) + msg->src.x_offset * pixel_width);
-    *bRGA_SRC_BASE1 = (RK_U32)(msg->src.uv_addr + (msg->src.y_offset / ydiv) * uv_stride + (msg->src.x_offset / xdiv));
-    *bRGA_SRC_BASE2 = (RK_U32)(msg->src.v_addr + (msg->src.y_offset / ydiv) * uv_stride + (msg->src.x_offset / xdiv));
-
-    //mask_stride = ((msg->src0_act.width + 31) & ~31) >> 5;
-    mask_stride = msg->rop_mask_stride;
-
-    *bRGA_SRC_VIR_INFO = stride | (mask_stride << 16);
-
-    *bRGA_SRC_ACT_INFO = (msg->src.act_w - 1) | ((msg->src.act_h - 1) << 16);
-
-    *bRGA_MASK_ADDR = (RK_U32)msg->rop_mask_addr;
-
-    *bRGA_SRC_INFO = reg;
-
-	*bRGA_SRC_TR_COLOR0 = msg->color_key_min;
-    *bRGA_SRC_TR_COLOR1 = msg->color_key_max;
-}
-
+{
+    RK_U32 *bRGA_SRC_INFO;
+    RK_U32 *bRGA_SRC_BASE0, *bRGA_SRC_BASE1, *bRGA_SRC_BASE2;
+    RK_U32 *bRGA_SRC_VIR_INFO;
+    RK_U32 *bRGA_SRC_ACT_INFO;
+    RK_U32 *bRGA_MASK_ADDR;
+	RK_U32 *bRGA_SRC_TR_COLOR0, *bRGA_SRC_TR_COLOR1;
+
+    RK_U32 reg = 0;
+    RK_U8 src0_format = 0;
+
+    RK_U8 src0_rb_swp = 0;
+    RK_U8 src0_rgb_pack = 0;
+
+    RK_U8 src0_cbcr_swp = 0;
+    RK_U8 pixel_width = 1;
+    RK_U32 stride = 0;
+    RK_U32 uv_stride = 0;
+    RK_U32 mask_stride = 0;
+    RK_U32 ydiv = 1, xdiv = 2;
+    RK_U8  yuv10 = 0;
+
+    RK_U32 sw, sh;
+    RK_U32 dw, dh;
+    RK_U8 rotate_mode;
+    RK_U8 scale_w_flag, scale_h_flag;
+
+    bRGA_SRC_INFO = (RK_U32 *)(base + RGA2_SRC_INFO_OFFSET);
+
+    bRGA_SRC_BASE0 = (RK_U32 *)(base + RGA2_SRC_BASE0_OFFSET);
+    bRGA_SRC_BASE1 = (RK_U32 *)(base + RGA2_SRC_BASE1_OFFSET);
+    bRGA_SRC_BASE2 = (RK_U32 *)(base + RGA2_SRC_BASE2_OFFSET);
+
+    bRGA_SRC_VIR_INFO = (RK_U32 *)(base + RGA2_SRC_VIR_INFO_OFFSET);
+    bRGA_SRC_ACT_INFO = (RK_U32 *)(base + RGA2_SRC_ACT_INFO_OFFSET);
+
+    bRGA_MASK_ADDR = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
+
+    bRGA_SRC_TR_COLOR0 = (RK_U32 *)(base + RGA2_SRC_TR_COLOR0_OFFSET);
+    bRGA_SRC_TR_COLOR1 = (RK_U32 *)(base + RGA2_SRC_TR_COLOR1_OFFSET);
+
+    if (msg->src.format == RGA2_FORMAT_YCbCr_420_SP_10B ||
+        msg->src.format == RGA2_FORMAT_YCrCb_420_SP_10B) {
+       if ((msg->src.act_w == msg->dst.act_w) &&
+           (msg->src.act_h == msg->dst.act_h) &&
+           (msg->rotate_mode == 0))
+           msg->rotate_mode = 1 << 6;
+    }
+
+    {
+        rotate_mode = msg->rotate_mode & 0x3;
+
+        sw = msg->src.act_w;
+        sh = msg->src.act_h;
+
+        if((rotate_mode == 1) | (rotate_mode == 3))
+        {
+            dw = msg->dst.act_h;
+            dh = msg->dst.act_w;
+        }
+        else
+        {
+            dw = msg->dst.act_w;
+            dh = msg->dst.act_h;
+        }
+
+        if(sw > dw)
+            scale_w_flag = 1;
+        else if (sw < dw)
+            scale_w_flag = 2;
+        else {
+            scale_w_flag = 0;
+            if(msg->rotate_mode >> 6)
+                scale_w_flag = 3;
+        }
+
+        if(sh > dh)
+            scale_h_flag = 1;
+        else if (sh < dh)
+            scale_h_flag = 2;
+        else {
+            scale_h_flag = 0;
+            if(msg->rotate_mode >> 6)
+                scale_h_flag = 3;
+        }
+    }
+
+    switch (msg->src.format)
+    {
+        case RGA2_FORMAT_RGBA_8888    : src0_format = 0x0; pixel_width = 4; break;
+        case RGA2_FORMAT_BGRA_8888    : src0_format = 0x0; src0_rb_swp = 0x1; pixel_width = 4; break;
+        case RGA2_FORMAT_RGBX_8888    : src0_format = 0x1; pixel_width = 4; msg->src_trans_mode &= 0x07; break;
+        case RGA2_FORMAT_BGRX_8888    : src0_format = 0x1; src0_rb_swp = 0x1; pixel_width = 4; msg->src_trans_mode &= 0x07; break;
+        case RGA2_FORMAT_RGB_888      : src0_format = 0x2; src0_rgb_pack = 1; pixel_width = 3; msg->src_trans_mode &= 0x07; break;
+        case RGA2_FORMAT_BGR_888      : src0_format = 0x2; src0_rgb_pack = 1; src0_rb_swp = 1; pixel_width = 3; msg->src_trans_mode &= 0x07; break;
+        case RGA2_FORMAT_RGB_565      : src0_format = 0x4; pixel_width = 2; msg->src_trans_mode &= 0x07; src0_rb_swp = 0x1; break;
+        case RGA2_FORMAT_RGBA_5551    : src0_format = 0x5; pixel_width = 2; src0_rb_swp = 0x1; break;
+        case RGA2_FORMAT_RGBA_4444    : src0_format = 0x6; pixel_width = 2; src0_rb_swp = 0x1; break;
+        case RGA2_FORMAT_BGR_565      : src0_format = 0x4; pixel_width = 2; msg->src_trans_mode &= 0x07; break;
+        case RGA2_FORMAT_BGRA_5551    : src0_format = 0x5; pixel_width = 2; break;
+        case RGA2_FORMAT_BGRA_4444    : src0_format = 0x6; pixel_width = 2; break;
+
+        case RGA2_FORMAT_YCbCr_422_SP : src0_format = 0x8; xdiv = 1; ydiv = 1; break;
+        case RGA2_FORMAT_YCbCr_422_P  : src0_format = 0x9; xdiv = 2; ydiv = 1; break;
+        case RGA2_FORMAT_YCbCr_420_SP : src0_format = 0xa; xdiv = 1; ydiv = 2; break;
+        case RGA2_FORMAT_YCbCr_420_P  : src0_format = 0xb; xdiv = 2; ydiv = 2; break;
+        case RGA2_FORMAT_YCrCb_422_SP : src0_format = 0x8; xdiv = 1; ydiv = 1; src0_cbcr_swp = 1; break;
+        case RGA2_FORMAT_YCrCb_422_P  : src0_format = 0x9; xdiv = 2; ydiv = 1; src0_cbcr_swp = 1; break;
+        case RGA2_FORMAT_YCrCb_420_SP : src0_format = 0xa; xdiv = 1; ydiv = 2; src0_cbcr_swp = 1; break;
+        case RGA2_FORMAT_YCrCb_420_P  : src0_format = 0xb; xdiv = 2; ydiv = 2; src0_cbcr_swp = 1; break;
+        case RGA2_FORMAT_YCbCr_420_SP_10B : src0_format = 0xa; xdiv = 1; ydiv = 2; yuv10 = 1; break;
+        case RGA2_FORMAT_YCrCb_420_SP_10B : src0_format = 0xa; xdiv = 1; ydiv = 2; src0_cbcr_swp = 1; yuv10 = 1; break;
+    };
+
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SRC_FMT)) | (s_RGA2_SRC_INFO_SW_SRC_FMT(src0_format)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP)) | (s_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP(src0_rb_swp)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP)) | (s_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP(msg->alpha_swp)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP)) | (s_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP(src0_cbcr_swp)));
+    if(msg->src.format <= RGA2_FORMAT_BGRA_4444)
+    	reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(0)));
+    else
+        if(msg->dst.format >= RGA2_FORMAT_YCbCr_422_SP)
+            reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(0)));
+        else
+    	    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(msg->yuv2rgb_mode)));
+
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE(msg->rotate_mode & 0x3)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE((msg->rotate_mode >> 4) & 0x3)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE((scale_w_flag))));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE((scale_h_flag))));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER)) | (s_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER((msg->scale_bicu_mode))));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE)) | (s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE(msg->src_trans_mode)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E)) | (s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E(msg->src_trans_mode >> 1)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E)) | (s_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E((msg->alpha_rop_flag >> 4) & 0x1)));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL)) | (s_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL((msg->scale_bicu_mode>>4))));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_YUV10_E)) | (s_RGA2_SRC_INFO_SW_SW_YUV10_E((yuv10))));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E)) | (s_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E((yuv10))));
+    RGA2_reg_get_param(base, msg);
+
+    stride = (((msg->src.vir_w * pixel_width) + 3) & ~3) >> 2;
+    uv_stride = ((msg->src.vir_w / xdiv + 3) & ~3);
+
+    *bRGA_SRC_BASE0 = (RK_U32)(msg->src.yrgb_addr + msg->src.y_offset * (stride<<2) + msg->src.x_offset * pixel_width);
+    *bRGA_SRC_BASE1 = (RK_U32)(msg->src.uv_addr + (msg->src.y_offset / ydiv) * uv_stride + (msg->src.x_offset / xdiv));
+    *bRGA_SRC_BASE2 = (RK_U32)(msg->src.v_addr + (msg->src.y_offset / ydiv) * uv_stride + (msg->src.x_offset / xdiv));
+
+    //mask_stride = ((msg->src0_act.width + 31) & ~31) >> 5;
+    mask_stride = msg->rop_mask_stride;
+
+    *bRGA_SRC_VIR_INFO = stride | (mask_stride << 16);
+
+    *bRGA_SRC_ACT_INFO = (msg->src.act_w - 1) | ((msg->src.act_h - 1) << 16);
+
+    *bRGA_MASK_ADDR = (RK_U32)msg->rop_mask_addr;
+
+    *bRGA_SRC_INFO = reg;
+
+	*bRGA_SRC_TR_COLOR0 = msg->color_key_min;
+    *bRGA_SRC_TR_COLOR1 = msg->color_key_max;
+}
+
 static void RGA2_set_reg_dst_info(u8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_DST_INFO;
-    RK_U32 *bRGA_DST_BASE0, *bRGA_DST_BASE1, *bRGA_DST_BASE2, *bRGA_SRC_BASE3;
-    RK_U32 *bRGA_DST_VIR_INFO;
-    RK_U32 *bRGA_DST_ACT_INFO;
-
-    RK_U8 src1_format = 0;
-    RK_U8 src1_rb_swp = 0;
-    RK_U8 src1_rgb_pack = 0;
-    RK_U8 dst_format = 0;
-    RK_U8 dst_rb_swp = 0;
-    RK_U8 dst_rgb_pack = 0;
-    RK_U8 dst_cbcr_swp = 0;
-    RK_U32 reg = 0;
-    RK_U8 spw, dpw;
-    RK_U32 s_stride, d_stride;
-    RK_U32 x_mirr, y_mirr, rot_90_flag;
-    RK_U32 yrgb_addr, u_addr, v_addr, s_yrgb_addr;
-    RK_U32 d_uv_stride, x_div, y_div;
-    RK_U32 y_lt_addr, y_ld_addr, y_rt_addr, y_rd_addr;
-    RK_U32 u_lt_addr, u_ld_addr, u_rt_addr, u_rd_addr;
-    RK_U32 v_lt_addr, v_ld_addr, v_rt_addr, v_rd_addr;
-
-    RK_U32 s_y_lt_addr, s_y_ld_addr, s_y_rt_addr, s_y_rd_addr;
-
-    dpw = 1;
-    x_div = y_div = 1;
-
-    bRGA_DST_INFO = (RK_U32 *)(base + RGA2_DST_INFO_OFFSET);
-    bRGA_DST_BASE0 = (RK_U32 *)(base + RGA2_DST_BASE0_OFFSET);
-    bRGA_DST_BASE1 = (RK_U32 *)(base + RGA2_DST_BASE1_OFFSET);
-    bRGA_DST_BASE2 = (RK_U32 *)(base + RGA2_DST_BASE2_OFFSET);
-
-    bRGA_SRC_BASE3 = (RK_U32 *)(base + RGA2_SRC_BASE3_OFFSET);
-
-    bRGA_DST_VIR_INFO = (RK_U32 *)(base + RGA2_DST_VIR_INFO_OFFSET);
-    bRGA_DST_ACT_INFO = (RK_U32 *)(base + RGA2_DST_ACT_INFO_OFFSET);
-
-    switch (msg->src1.format)
-    {
-        case RGA2_FORMAT_RGBA_8888    : src1_format = 0x0; spw = 4; break;
-        case RGA2_FORMAT_BGRA_8888    : src1_format = 0x0; src1_rb_swp = 0x1; spw = 4; break;
-        case RGA2_FORMAT_RGBX_8888    : src1_format = 0x1; spw = 4; break;
-        case RGA2_FORMAT_BGRX_8888    : src1_format = 0x1; src1_rb_swp = 0x1; spw = 4; break;
-        case RGA2_FORMAT_RGB_888      : src1_format = 0x2; src1_rgb_pack = 1; spw = 3; break;
-        case RGA2_FORMAT_BGR_888      : src1_format = 0x2; src1_rgb_pack = 1; src1_rb_swp = 1; spw = 3; break;
-        case RGA2_FORMAT_RGB_565      : src1_format = 0x4; spw = 2; src1_rb_swp = 0x1; break;
-        case RGA2_FORMAT_RGBA_5551    : src1_format = 0x5; spw = 2; src1_rb_swp = 0x1; break;
-        case RGA2_FORMAT_RGBA_4444    : src1_format = 0x6; spw = 2; src1_rb_swp = 0x1; break;
-        case RGA2_FORMAT_BGR_565      : src1_format = 0x4; spw = 2; break;
-        case RGA2_FORMAT_BGRA_5551    : src1_format = 0x5; spw = 2; break;
-        case RGA2_FORMAT_BGRA_4444    : src1_format = 0x6; spw = 2; break;
-        default                       : spw = 4; break;
-    };
-
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_SRC1_FMT)) | (s_RGA2_DST_INFO_SW_SRC1_FMT(src1_format)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_SRC1_RB_SWP)) | (s_RGA2_DST_INFO_SW_SRC1_RB_SWP(src1_rb_swp)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP)) | (s_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP(msg->alpha_swp >> 1)));
-
-
-    switch (msg->dst.format)
-    {
-        case RGA2_FORMAT_RGBA_8888    : dst_format = 0x0; dpw = 4; break;
-        case RGA2_FORMAT_BGRA_8888    : dst_format = 0x0; dst_rb_swp = 0x1; dpw = 4; break;
-        case RGA2_FORMAT_RGBX_8888    : dst_format = 0x1; dpw = 4; break;
-        case RGA2_FORMAT_BGRX_8888    : dst_format = 0x1; dst_rb_swp = 0x1; dpw = 4; break;
-        case RGA2_FORMAT_RGB_888      : dst_format = 0x2; dst_rgb_pack = 1; dpw = 3; break;
-        case RGA2_FORMAT_BGR_888      : dst_format = 0x2; dst_rgb_pack = 1; dst_rb_swp = 1; dpw = 3; break;
-        case RGA2_FORMAT_RGB_565      : dst_format = 0x4; dpw = 2; dst_rb_swp = 0x1; break;
-        case RGA2_FORMAT_RGBA_5551    : dst_format = 0x5; dpw = 2; dst_rb_swp = 0x1; break;
-        case RGA2_FORMAT_RGBA_4444    : dst_format = 0x6; dpw = 2; dst_rb_swp = 0x1; break;
-        case RGA2_FORMAT_BGR_565      : dst_format = 0x4; dpw = 2; break;
-        case RGA2_FORMAT_BGRA_5551    : dst_format = 0x5; dpw = 2; break;
-        case RGA2_FORMAT_BGRA_4444    : dst_format = 0x6; dpw = 2; break;
-
-        case RGA2_FORMAT_YCbCr_422_SP : dst_format = 0x8; x_div = 1; y_div = 1; break;
-        case RGA2_FORMAT_YCbCr_422_P  : dst_format = 0x9; x_div = 2; y_div = 1; break;
-        case RGA2_FORMAT_YCbCr_420_SP : dst_format = 0xa; x_div = 1; y_div = 2; break;
-        case RGA2_FORMAT_YCbCr_420_P  : dst_format = 0xb; x_div = 2; y_div = 2; break;
-        case RGA2_FORMAT_YCrCb_422_SP : dst_format = 0x8; dst_cbcr_swp = 1; x_div = 1; y_div = 1; break;
-        case RGA2_FORMAT_YCrCb_422_P  : dst_format = 0x9; dst_cbcr_swp = 1; x_div = 2; y_div = 1; break;
-        case RGA2_FORMAT_YCrCb_420_SP : dst_format = 0xa; dst_cbcr_swp = 1; x_div = 1; y_div = 2; break;
-        case RGA2_FORMAT_YCrCb_420_P  : dst_format = 0xb; dst_cbcr_swp = 1; x_div = 2; y_div = 2; break;
+{
+    RK_U32 *bRGA_DST_INFO;
+    RK_U32 *bRGA_DST_BASE0, *bRGA_DST_BASE1, *bRGA_DST_BASE2, *bRGA_SRC_BASE3;
+    RK_U32 *bRGA_DST_VIR_INFO;
+    RK_U32 *bRGA_DST_ACT_INFO;
+
+    RK_U8 src1_format = 0;
+    RK_U8 src1_rb_swp = 0;
+    RK_U8 src1_rgb_pack = 0;
+    RK_U8 dst_format = 0;
+    RK_U8 dst_rb_swp = 0;
+    RK_U8 dst_rgb_pack = 0;
+    RK_U8 dst_cbcr_swp = 0;
+    RK_U32 reg = 0;
+    RK_U8 spw, dpw;
+    RK_U32 s_stride, d_stride;
+    RK_U32 x_mirr, y_mirr, rot_90_flag;
+    RK_U32 yrgb_addr, u_addr, v_addr, s_yrgb_addr;
+    RK_U32 d_uv_stride, x_div, y_div;
+    RK_U32 y_lt_addr, y_ld_addr, y_rt_addr, y_rd_addr;
+    RK_U32 u_lt_addr, u_ld_addr, u_rt_addr, u_rd_addr;
+    RK_U32 v_lt_addr, v_ld_addr, v_rt_addr, v_rd_addr;
+
+    RK_U32 s_y_lt_addr, s_y_ld_addr, s_y_rt_addr, s_y_rd_addr;
+
+    dpw = 1;
+    x_div = y_div = 1;
+
+    bRGA_DST_INFO = (RK_U32 *)(base + RGA2_DST_INFO_OFFSET);
+    bRGA_DST_BASE0 = (RK_U32 *)(base + RGA2_DST_BASE0_OFFSET);
+    bRGA_DST_BASE1 = (RK_U32 *)(base + RGA2_DST_BASE1_OFFSET);
+    bRGA_DST_BASE2 = (RK_U32 *)(base + RGA2_DST_BASE2_OFFSET);
+
+    bRGA_SRC_BASE3 = (RK_U32 *)(base + RGA2_SRC_BASE3_OFFSET);
+
+    bRGA_DST_VIR_INFO = (RK_U32 *)(base + RGA2_DST_VIR_INFO_OFFSET);
+    bRGA_DST_ACT_INFO = (RK_U32 *)(base + RGA2_DST_ACT_INFO_OFFSET);
+
+    switch (msg->src1.format)
+    {
+        case RGA2_FORMAT_RGBA_8888    : src1_format = 0x0; spw = 4; break;
+        case RGA2_FORMAT_BGRA_8888    : src1_format = 0x0; src1_rb_swp = 0x1; spw = 4; break;
+        case RGA2_FORMAT_RGBX_8888    : src1_format = 0x1; spw = 4; break;
+        case RGA2_FORMAT_BGRX_8888    : src1_format = 0x1; src1_rb_swp = 0x1; spw = 4; break;
+        case RGA2_FORMAT_RGB_888      : src1_format = 0x2; src1_rgb_pack = 1; spw = 3; break;
+        case RGA2_FORMAT_BGR_888      : src1_format = 0x2; src1_rgb_pack = 1; src1_rb_swp = 1; spw = 3; break;
+        case RGA2_FORMAT_RGB_565      : src1_format = 0x4; spw = 2; src1_rb_swp = 0x1; break;
+        case RGA2_FORMAT_RGBA_5551    : src1_format = 0x5; spw = 2; src1_rb_swp = 0x1; break;
+        case RGA2_FORMAT_RGBA_4444    : src1_format = 0x6; spw = 2; src1_rb_swp = 0x1; break;
+        case RGA2_FORMAT_BGR_565      : src1_format = 0x4; spw = 2; break;
+        case RGA2_FORMAT_BGRA_5551    : src1_format = 0x5; spw = 2; break;
+        case RGA2_FORMAT_BGRA_4444    : src1_format = 0x6; spw = 2; break;
+        default                       : spw = 4; break;
+    };
+
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_SRC1_FMT)) | (s_RGA2_DST_INFO_SW_SRC1_FMT(src1_format)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_SRC1_RB_SWP)) | (s_RGA2_DST_INFO_SW_SRC1_RB_SWP(src1_rb_swp)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP)) | (s_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP(msg->alpha_swp >> 1)));
+
+
+    switch (msg->dst.format)
+    {
+        case RGA2_FORMAT_RGBA_8888    : dst_format = 0x0; dpw = 4; break;
+        case RGA2_FORMAT_BGRA_8888    : dst_format = 0x0; dst_rb_swp = 0x1; dpw = 4; break;
+        case RGA2_FORMAT_RGBX_8888    : dst_format = 0x1; dpw = 4; break;
+        case RGA2_FORMAT_BGRX_8888    : dst_format = 0x1; dst_rb_swp = 0x1; dpw = 4; break;
+        case RGA2_FORMAT_RGB_888      : dst_format = 0x2; dst_rgb_pack = 1; dpw = 3; break;
+        case RGA2_FORMAT_BGR_888      : dst_format = 0x2; dst_rgb_pack = 1; dst_rb_swp = 1; dpw = 3; break;
+        case RGA2_FORMAT_RGB_565      : dst_format = 0x4; dpw = 2; dst_rb_swp = 0x1; break;
+        case RGA2_FORMAT_RGBA_5551    : dst_format = 0x5; dpw = 2; dst_rb_swp = 0x1; break;
+        case RGA2_FORMAT_RGBA_4444    : dst_format = 0x6; dpw = 2; dst_rb_swp = 0x1; break;
+        case RGA2_FORMAT_BGR_565      : dst_format = 0x4; dpw = 2; break;
+        case RGA2_FORMAT_BGRA_5551    : dst_format = 0x5; dpw = 2; break;
+        case RGA2_FORMAT_BGRA_4444    : dst_format = 0x6; dpw = 2; break;
+
+        case RGA2_FORMAT_YCbCr_422_SP : dst_format = 0x8; x_div = 1; y_div = 1; break;
+        case RGA2_FORMAT_YCbCr_422_P  : dst_format = 0x9; x_div = 2; y_div = 1; break;
+        case RGA2_FORMAT_YCbCr_420_SP : dst_format = 0xa; x_div = 1; y_div = 2; break;
+        case RGA2_FORMAT_YCbCr_420_P  : dst_format = 0xb; x_div = 2; y_div = 2; break;
+        case RGA2_FORMAT_YCrCb_422_SP : dst_format = 0x8; dst_cbcr_swp = 1; x_div = 1; y_div = 1; break;
+        case RGA2_FORMAT_YCrCb_422_P  : dst_format = 0x9; dst_cbcr_swp = 1; x_div = 2; y_div = 1; break;
+        case RGA2_FORMAT_YCrCb_420_SP : dst_format = 0xa; dst_cbcr_swp = 1; x_div = 1; y_div = 2; break;
+        case RGA2_FORMAT_YCrCb_420_P  : dst_format = 0xb; dst_cbcr_swp = 1; x_div = 2; y_div = 2; break;
 
 	case RGA2_FORMAT_YUYV_422     : dst_format = 0xc; dpw = 2; break;
 	case RGA2_FORMAT_YVYU_422     : dst_format = 0xc; dpw = 2; dst_cbcr_swp = 1; break;
@@ -402,60 +402,60 @@ static void RGA2_set_reg_dst_info(u8 *base, struct rga2_req *msg)
 	case RGA2_FORMAT_VYUY_422     : dst_format = 0xe; dpw = 2; dst_cbcr_swp = 1; break;
 	case RGA2_FORMAT_UYVY_420     : dst_format = 0xf; dpw = 2; break;
 	case RGA2_FORMAT_VYUY_420     : dst_format = 0xf; dpw = 2; dst_cbcr_swp = 1; break;
-    };
-
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_FMT)) | (s_RGA2_DST_INFO_SW_DST_FMT(dst_format)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_RB_SWAP)) | (s_RGA2_DST_INFO_SW_DST_RB_SWAP(dst_rb_swp)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_ALPHA_SWAP)) | (s_RGA2_DST_INFO_SW_ALPHA_SWAP(msg->alpha_swp >> 2)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_UV_SWAP)) | (s_RGA2_DST_INFO_SW_DST_UV_SWAP(dst_cbcr_swp)));
-
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_DITHER_UP_E)) | (s_RGA2_DST_INFO_SW_DITHER_UP_E(msg->alpha_rop_flag >> 5)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_DITHER_DOWN_E)) | (s_RGA2_DST_INFO_SW_DITHER_DOWN_E(msg->alpha_rop_flag >> 6)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_DITHER_MODE)) | (s_RGA2_DST_INFO_SW_DITHER_MODE(msg->dither_mode)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_CSC_MODE)) | (s_RGA2_DST_INFO_SW_DST_CSC_MODE(msg->yuv2rgb_mode >> 4)));
-    reg = ((reg & (~m_RGA2_DST_INFO_SW_CSC_CLIP_MODE)) | (s_RGA2_DST_INFO_SW_CSC_CLIP_MODE(msg->yuv2rgb_mode >> 6)));
-
-
-    *bRGA_DST_INFO = reg;
-
-    s_stride = ((msg->src1.vir_w * spw + 3) & ~3) >> 2;
-    d_stride = ((msg->dst.vir_w * dpw + 3) & ~3) >> 2;
-    d_uv_stride = (d_stride << 2) / x_div;
-
-    *bRGA_DST_VIR_INFO = d_stride | (s_stride << 16);
-    *bRGA_DST_ACT_INFO = (msg->dst.act_w - 1) | ((msg->dst.act_h - 1) << 16);
-    s_stride <<= 2;
-	d_stride <<= 2;
-
-    if(((msg->rotate_mode & 0xf) == 0) || ((msg->rotate_mode & 0xf) == 1))
-    {
-        x_mirr = 0;
-        y_mirr = 0;
-    }
-    else
-    {
-        x_mirr = 1;
-        y_mirr = 1;
-    }
-
-    rot_90_flag = msg->rotate_mode & 1;
-    x_mirr = (x_mirr + ((msg->rotate_mode >> 4) & 1)) & 1;
-    y_mirr = (y_mirr + ((msg->rotate_mode >> 5) & 1)) & 1;
-
-    yrgb_addr = (RK_U32)msg->src1.yrgb_addr + (msg->src1.y_offset * s_stride) + (msg->src1.x_offset * spw);
-
-    s_y_lt_addr = yrgb_addr;
-    s_y_ld_addr = yrgb_addr + (msg->src1.act_h - 1) * s_stride;
-    s_y_rt_addr = yrgb_addr + (msg->dst.act_w - 1) * spw;
-    s_y_rd_addr = s_y_ld_addr + (msg->dst.act_w - 1) * spw;
-
-    yrgb_addr = (RK_U32)msg->dst.yrgb_addr + (msg->dst.y_offset * d_stride) + (msg->dst.x_offset * dpw);
-    u_addr = (RK_U32)msg->dst.uv_addr + (msg->dst.y_offset / y_div) * d_uv_stride + msg->dst.x_offset / x_div;
-    v_addr = (RK_U32)msg->dst.v_addr + (msg->dst.y_offset / y_div) * d_uv_stride + msg->dst.x_offset / x_div;
-
-    y_lt_addr = yrgb_addr;
-    u_lt_addr = u_addr;
-    v_lt_addr = v_addr;
+    };
+
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_FMT)) | (s_RGA2_DST_INFO_SW_DST_FMT(dst_format)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_RB_SWAP)) | (s_RGA2_DST_INFO_SW_DST_RB_SWAP(dst_rb_swp)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_ALPHA_SWAP)) | (s_RGA2_DST_INFO_SW_ALPHA_SWAP(msg->alpha_swp >> 2)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_UV_SWAP)) | (s_RGA2_DST_INFO_SW_DST_UV_SWAP(dst_cbcr_swp)));
+
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_DITHER_UP_E)) | (s_RGA2_DST_INFO_SW_DITHER_UP_E(msg->alpha_rop_flag >> 5)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_DITHER_DOWN_E)) | (s_RGA2_DST_INFO_SW_DITHER_DOWN_E(msg->alpha_rop_flag >> 6)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_DITHER_MODE)) | (s_RGA2_DST_INFO_SW_DITHER_MODE(msg->dither_mode)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_DST_CSC_MODE)) | (s_RGA2_DST_INFO_SW_DST_CSC_MODE(msg->yuv2rgb_mode >> 4)));
+    reg = ((reg & (~m_RGA2_DST_INFO_SW_CSC_CLIP_MODE)) | (s_RGA2_DST_INFO_SW_CSC_CLIP_MODE(msg->yuv2rgb_mode >> 6)));
+
+
+    *bRGA_DST_INFO = reg;
+
+    s_stride = ((msg->src1.vir_w * spw + 3) & ~3) >> 2;
+    d_stride = ((msg->dst.vir_w * dpw + 3) & ~3) >> 2;
+    d_uv_stride = (d_stride << 2) / x_div;
+
+    *bRGA_DST_VIR_INFO = d_stride | (s_stride << 16);
+    *bRGA_DST_ACT_INFO = (msg->dst.act_w - 1) | ((msg->dst.act_h - 1) << 16);
+    s_stride <<= 2;
+	d_stride <<= 2;
+
+    if(((msg->rotate_mode & 0xf) == 0) || ((msg->rotate_mode & 0xf) == 1))
+    {
+        x_mirr = 0;
+        y_mirr = 0;
+    }
+    else
+    {
+        x_mirr = 1;
+        y_mirr = 1;
+    }
+
+    rot_90_flag = msg->rotate_mode & 1;
+    x_mirr = (x_mirr + ((msg->rotate_mode >> 4) & 1)) & 1;
+    y_mirr = (y_mirr + ((msg->rotate_mode >> 5) & 1)) & 1;
+
+    yrgb_addr = (RK_U32)msg->src1.yrgb_addr + (msg->src1.y_offset * s_stride) + (msg->src1.x_offset * spw);
+
+    s_y_lt_addr = yrgb_addr;
+    s_y_ld_addr = yrgb_addr + (msg->src1.act_h - 1) * s_stride;
+    s_y_rt_addr = yrgb_addr + (msg->dst.act_w - 1) * spw;
+    s_y_rd_addr = s_y_ld_addr + (msg->dst.act_w - 1) * spw;
+
+    yrgb_addr = (RK_U32)msg->dst.yrgb_addr + (msg->dst.y_offset * d_stride) + (msg->dst.x_offset * dpw);
+    u_addr = (RK_U32)msg->dst.uv_addr + (msg->dst.y_offset / y_div) * d_uv_stride + msg->dst.x_offset / x_div;
+    v_addr = (RK_U32)msg->dst.v_addr + (msg->dst.y_offset / y_div) * d_uv_stride + msg->dst.x_offset / x_div;
+
+    y_lt_addr = yrgb_addr;
+    u_lt_addr = u_addr;
+    v_lt_addr = v_addr;
 
 	if (msg->dst.format < 0x18) {
 		/* 270 degree & Mirror V*/
@@ -486,504 +486,504 @@ static void RGA2_set_reg_dst_info(u8 *base, struct rga2_req *msg)
 			y_rd_addr = y_ld_addr + (msg->dst.act_w - 1);
 		}
 	}
-    if(rot_90_flag == 0)
-    {
-        if(y_mirr == 1)
-        {
-            if(x_mirr == 1)
-            {
-                yrgb_addr = y_rd_addr;
-                u_addr = u_rd_addr;
-                v_addr = v_rd_addr;
-
-                s_yrgb_addr = s_y_rd_addr;
-            }
-            else
-            {
-                yrgb_addr = y_ld_addr;
-                u_addr = u_ld_addr;
-                v_addr = v_ld_addr;
-
-                s_yrgb_addr = s_y_ld_addr;
-            }
-        }
-        else
-        {
-            if(x_mirr == 1)
-            {
-                yrgb_addr = y_rt_addr;
-                u_addr = u_rt_addr;
-                v_addr = v_rt_addr;
-
-                s_yrgb_addr = s_y_rt_addr;
-            }
-            else
-            {
-                yrgb_addr = y_lt_addr;
-                u_addr = u_lt_addr;
-                v_addr = v_lt_addr;
-
-                s_yrgb_addr = s_y_lt_addr;
-            }
-        }
-    }
-    else
-    {
-        if(y_mirr == 1)
-        {
-            if(x_mirr == 1)
-            {
-                yrgb_addr = y_ld_addr;
-                u_addr = u_ld_addr;
-                v_addr = v_ld_addr;
-
-                s_yrgb_addr = s_y_ld_addr;
-            }
-            else
-            {
-                yrgb_addr = y_rd_addr;
-                u_addr = u_rd_addr;
-                v_addr = v_rd_addr;
-
-                s_yrgb_addr = s_y_rd_addr;
-            }
-        }
-        else
-        {
-            if(x_mirr == 1)
-            {
-                yrgb_addr = y_lt_addr;
-                u_addr = u_lt_addr;
-                v_addr = v_lt_addr;
-
-                s_yrgb_addr = s_y_lt_addr;
-            }
-            else
-            {
-                yrgb_addr = y_rt_addr;
-                u_addr = u_rt_addr;
-                v_addr = v_rt_addr;
-
-                s_yrgb_addr = s_y_rt_addr;
-            }
-        }
-    }
-
-    *bRGA_DST_BASE0 = (RK_U32)yrgb_addr;
-
-    if((msg->dst.format == RGA2_FORMAT_YCbCr_420_P) || (msg->dst.format == RGA2_FORMAT_YCrCb_420_P))
-    {
-        if(dst_cbcr_swp == 0) {
-            *bRGA_DST_BASE1 = (RK_U32)v_addr;
-            *bRGA_DST_BASE2 = (RK_U32)u_addr;
-        }
-        else {
-            *bRGA_DST_BASE1 = (RK_U32)u_addr;
-            *bRGA_DST_BASE2 = (RK_U32)v_addr;
-        }
-    }
-    else {
-        *bRGA_DST_BASE1 = (RK_U32)u_addr;
-        *bRGA_DST_BASE2 = (RK_U32)v_addr;
-    }
+    if(rot_90_flag == 0)
+    {
+        if(y_mirr == 1)
+        {
+            if(x_mirr == 1)
+            {
+                yrgb_addr = y_rd_addr;
+                u_addr = u_rd_addr;
+                v_addr = v_rd_addr;
+
+                s_yrgb_addr = s_y_rd_addr;
+            }
+            else
+            {
+                yrgb_addr = y_ld_addr;
+                u_addr = u_ld_addr;
+                v_addr = v_ld_addr;
+
+                s_yrgb_addr = s_y_ld_addr;
+            }
+        }
+        else
+        {
+            if(x_mirr == 1)
+            {
+                yrgb_addr = y_rt_addr;
+                u_addr = u_rt_addr;
+                v_addr = v_rt_addr;
+
+                s_yrgb_addr = s_y_rt_addr;
+            }
+            else
+            {
+                yrgb_addr = y_lt_addr;
+                u_addr = u_lt_addr;
+                v_addr = v_lt_addr;
+
+                s_yrgb_addr = s_y_lt_addr;
+            }
+        }
+    }
+    else
+    {
+        if(y_mirr == 1)
+        {
+            if(x_mirr == 1)
+            {
+                yrgb_addr = y_ld_addr;
+                u_addr = u_ld_addr;
+                v_addr = v_ld_addr;
+
+                s_yrgb_addr = s_y_ld_addr;
+            }
+            else
+            {
+                yrgb_addr = y_rd_addr;
+                u_addr = u_rd_addr;
+                v_addr = v_rd_addr;
+
+                s_yrgb_addr = s_y_rd_addr;
+            }
+        }
+        else
+        {
+            if(x_mirr == 1)
+            {
+                yrgb_addr = y_lt_addr;
+                u_addr = u_lt_addr;
+                v_addr = v_lt_addr;
+
+                s_yrgb_addr = s_y_lt_addr;
+            }
+            else
+            {
+                yrgb_addr = y_rt_addr;
+                u_addr = u_rt_addr;
+                v_addr = v_rt_addr;
+
+                s_yrgb_addr = s_y_rt_addr;
+            }
+        }
+    }
+
+    *bRGA_DST_BASE0 = (RK_U32)yrgb_addr;
+
+    if((msg->dst.format == RGA2_FORMAT_YCbCr_420_P) || (msg->dst.format == RGA2_FORMAT_YCrCb_420_P))
+    {
+        if(dst_cbcr_swp == 0) {
+            *bRGA_DST_BASE1 = (RK_U32)v_addr;
+            *bRGA_DST_BASE2 = (RK_U32)u_addr;
+        }
+        else {
+            *bRGA_DST_BASE1 = (RK_U32)u_addr;
+            *bRGA_DST_BASE2 = (RK_U32)v_addr;
+        }
+    }
+    else {
+        *bRGA_DST_BASE1 = (RK_U32)u_addr;
+        *bRGA_DST_BASE2 = (RK_U32)v_addr;
+    }
 
 	if (msg->dst.format >= 0x18) {
 		*bRGA_DST_BASE1 = msg->dst.x_offset;
 	}
-    *bRGA_SRC_BASE3 = (RK_U32)s_y_lt_addr;
-}
-
+    *bRGA_SRC_BASE3 = (RK_U32)s_y_lt_addr;
+}
+
 static void RGA2_set_reg_alpha_info(u8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_ALPHA_CTRL0;
-    RK_U32 *bRGA_ALPHA_CTRL1;
-    RK_U32 *bRGA_FADING_CTRL;
-    RK_U32 reg0 = 0;
-    RK_U32 reg1 = 0;
-
-    bRGA_ALPHA_CTRL0 = (RK_U32 *)(base + RGA2_ALPHA_CTRL0_OFFSET);
-    bRGA_ALPHA_CTRL1 = (RK_U32 *)(base + RGA2_ALPHA_CTRL1_OFFSET);
-    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
-
-    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0)) | (s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0(msg->alpha_rop_flag)));
-    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL)) | (s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL(msg->alpha_rop_flag >> 1)));
-    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_ROP_MODE)) | (s_RGA2_ALPHA_CTRL0_SW_ROP_MODE(msg->rop_mode)));
-    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA)) | (s_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA(msg->src_a_global_val)));
-    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA)) | (s_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA(msg->dst_a_global_val)));
-
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0(msg->alpha_mode_0 >> 15)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0(msg->alpha_mode_0 >> 7)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0(msg->alpha_mode_0 >> 12)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0(msg->alpha_mode_0 >> 4)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0(msg->alpha_mode_0 >> 11)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0(msg->alpha_mode_0 >> 3)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0(msg->alpha_mode_0 >> 9)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0(msg->alpha_mode_0 >> 1)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0(msg->alpha_mode_0 >> 8)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0(msg->alpha_mode_0 >> 0)));
-
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1(msg->alpha_mode_1 >> 12)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1(msg->alpha_mode_1 >> 4)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1(msg->alpha_mode_1 >> 11)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1(msg->alpha_mode_1 >> 3)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1(msg->alpha_mode_1 >> 9)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1(msg->alpha_mode_1 >> 1)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1(msg->alpha_mode_1 >> 8)));
-    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1(msg->alpha_mode_1 >> 0)));
-
-    *bRGA_ALPHA_CTRL0 = reg0;
-    *bRGA_ALPHA_CTRL1 = reg1;
-
-    if((msg->alpha_rop_flag>>2)&1)
-    {
-        *bRGA_FADING_CTRL = (1<<24) | (msg->fading_b_value<<16) | (msg->fading_g_value<<8) | (msg->fading_r_value);
-    }
-}
-
+{
+    RK_U32 *bRGA_ALPHA_CTRL0;
+    RK_U32 *bRGA_ALPHA_CTRL1;
+    RK_U32 *bRGA_FADING_CTRL;
+    RK_U32 reg0 = 0;
+    RK_U32 reg1 = 0;
+
+    bRGA_ALPHA_CTRL0 = (RK_U32 *)(base + RGA2_ALPHA_CTRL0_OFFSET);
+    bRGA_ALPHA_CTRL1 = (RK_U32 *)(base + RGA2_ALPHA_CTRL1_OFFSET);
+    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
+
+    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0)) | (s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0(msg->alpha_rop_flag)));
+    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL)) | (s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL(msg->alpha_rop_flag >> 1)));
+    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_ROP_MODE)) | (s_RGA2_ALPHA_CTRL0_SW_ROP_MODE(msg->rop_mode)));
+    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA)) | (s_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA(msg->src_a_global_val)));
+    reg0 = ((reg0 & (~m_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA)) | (s_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA(msg->dst_a_global_val)));
+
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0(msg->alpha_mode_0 >> 15)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0(msg->alpha_mode_0 >> 7)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0(msg->alpha_mode_0 >> 12)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0(msg->alpha_mode_0 >> 4)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0(msg->alpha_mode_0 >> 11)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0(msg->alpha_mode_0 >> 3)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0(msg->alpha_mode_0 >> 9)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0(msg->alpha_mode_0 >> 1)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0(msg->alpha_mode_0 >> 8)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0(msg->alpha_mode_0 >> 0)));
+
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1(msg->alpha_mode_1 >> 12)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1(msg->alpha_mode_1 >> 4)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1(msg->alpha_mode_1 >> 11)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1(msg->alpha_mode_1 >> 3)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1(msg->alpha_mode_1 >> 9)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1(msg->alpha_mode_1 >> 1)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1)) | (s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1(msg->alpha_mode_1 >> 8)));
+    reg1 = ((reg1 & (~m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1)) | (s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1(msg->alpha_mode_1 >> 0)));
+
+    *bRGA_ALPHA_CTRL0 = reg0;
+    *bRGA_ALPHA_CTRL1 = reg1;
+
+    if((msg->alpha_rop_flag>>2)&1)
+    {
+        *bRGA_FADING_CTRL = (1<<24) | (msg->fading_b_value<<16) | (msg->fading_g_value<<8) | (msg->fading_r_value);
+    }
+}
+
 static void RGA2_set_reg_rop_info(u8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_ALPHA_CTRL0;
-    RK_U32 *bRGA_ROP_CTRL0;
-    RK_U32 *bRGA_ROP_CTRL1;
-    RK_U32 *bRGA_MASK_ADDR;
-    RK_U32 *bRGA_FG_COLOR;
-    RK_U32 *bRGA_PAT_CON;
-
-    RK_U32 rop_code0 = 0;
-    RK_U32 rop_code1 = 0;
-
-    bRGA_ALPHA_CTRL0 = (RK_U32 *)(base + RGA2_ALPHA_CTRL0_OFFSET);
-    bRGA_ROP_CTRL0 = (RK_U32 *)(base + RGA2_ROP_CTRL0_OFFSET);
-    bRGA_ROP_CTRL1 = (RK_U32 *)(base + RGA2_ROP_CTRL1_OFFSET);
-	bRGA_MASK_ADDR = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
-    bRGA_FG_COLOR  = (RK_U32 *)(base + RGA2_SRC_FG_COLOR_OFFSET);
-    bRGA_PAT_CON   = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
-
-    if(msg->rop_mode == 0) {
+{
+    RK_U32 *bRGA_ALPHA_CTRL0;
+    RK_U32 *bRGA_ROP_CTRL0;
+    RK_U32 *bRGA_ROP_CTRL1;
+    RK_U32 *bRGA_MASK_ADDR;
+    RK_U32 *bRGA_FG_COLOR;
+    RK_U32 *bRGA_PAT_CON;
+
+    RK_U32 rop_code0 = 0;
+    RK_U32 rop_code1 = 0;
+
+    bRGA_ALPHA_CTRL0 = (RK_U32 *)(base + RGA2_ALPHA_CTRL0_OFFSET);
+    bRGA_ROP_CTRL0 = (RK_U32 *)(base + RGA2_ROP_CTRL0_OFFSET);
+    bRGA_ROP_CTRL1 = (RK_U32 *)(base + RGA2_ROP_CTRL1_OFFSET);
+	bRGA_MASK_ADDR = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
+    bRGA_FG_COLOR  = (RK_U32 *)(base + RGA2_SRC_FG_COLOR_OFFSET);
+    bRGA_PAT_CON   = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
+
+    if(msg->rop_mode == 0) {
 	rop_code0 = RGA2_ROP3_code[(msg->rop_code & 0xff)];
-    }
-    else if(msg->rop_mode == 1) {
+    }
+    else if(msg->rop_mode == 1) {
 	rop_code0 = RGA2_ROP3_code[(msg->rop_code & 0xff)];
-    }
-    else if(msg->rop_mode == 2) {
+    }
+    else if(msg->rop_mode == 2) {
 	rop_code0 = RGA2_ROP3_code[(msg->rop_code & 0xff)];
 	rop_code1 = RGA2_ROP3_code[(msg->rop_code & 0xff00)>>8];
-    }
-
-    *bRGA_ROP_CTRL0 = rop_code0;
-    *bRGA_ROP_CTRL1 = rop_code1;
-    *bRGA_FG_COLOR = msg->fg_color;
-    *bRGA_MASK_ADDR = (RK_U32)msg->rop_mask_addr;
-    *bRGA_PAT_CON = (msg->pat.act_w-1) | ((msg->pat.act_h-1) << 8)
-                     | (msg->pat.x_offset << 16) | (msg->pat.y_offset << 24);
-    *bRGA_ALPHA_CTRL0 = *bRGA_ALPHA_CTRL0 | (((msg->endian_mode >> 1) & 1) << 20);
-
-}
-
+    }
+
+    *bRGA_ROP_CTRL0 = rop_code0;
+    *bRGA_ROP_CTRL1 = rop_code1;
+    *bRGA_FG_COLOR = msg->fg_color;
+    *bRGA_MASK_ADDR = (RK_U32)msg->rop_mask_addr;
+    *bRGA_PAT_CON = (msg->pat.act_w-1) | ((msg->pat.act_h-1) << 8)
+                     | (msg->pat.x_offset << 16) | (msg->pat.y_offset << 24);
+    *bRGA_ALPHA_CTRL0 = *bRGA_ALPHA_CTRL0 | (((msg->endian_mode >> 1) & 1) << 20);
+
+}
+
 static void RGA2_set_reg_color_palette(RK_U8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_SRC_BASE0, *bRGA_SRC_INFO, *bRGA_SRC_VIR_INFO, *bRGA_SRC_ACT_INFO, *bRGA_SRC_FG_COLOR, *bRGA_SRC_BG_COLOR;
-    RK_U32  *p;
-    RK_S16  x_off, y_off;
-    RK_U16  src_stride;
-    RK_U8   shift;
-    RK_U32  sw;
-    RK_U32  byte_num;
-    RK_U32 reg;
-
-    bRGA_SRC_BASE0 = (RK_U32 *)(base + RGA2_SRC_BASE0_OFFSET);
-	bRGA_SRC_INFO = (RK_U32 *)(base + RGA2_SRC_INFO_OFFSET);
-    bRGA_SRC_VIR_INFO = (RK_U32 *)(base + RGA2_SRC_VIR_INFO_OFFSET);
-    bRGA_SRC_ACT_INFO = (RK_U32 *)(base + RGA2_SRC_ACT_INFO_OFFSET);
-    bRGA_SRC_FG_COLOR = (RK_U32 *)(base + RGA2_SRC_FG_COLOR_OFFSET);
-    bRGA_SRC_BG_COLOR = (RK_U32 *)(base + RGA2_SRC_BG_COLOR_OFFSET);
-
-    reg = 0;
-
-    shift = 3 - msg->palette_mode;
-
-    x_off = msg->src.x_offset;
-    y_off = msg->src.y_offset;
-
-    sw = msg->src.vir_w;
-    byte_num = sw >> shift;
-
-    src_stride = (byte_num + 3) & (~3);
-
-    p = (RK_U32 *)((unsigned long)msg->src.yrgb_addr);
-
-    #if 0
-    if(endian_mode)
-    {
-        p = p + (x_off>>shift) + y_off*src_stride;
-    }
-    else
-    {
-        p = p + (((x_off>>shift)>>2)<<2) + (3 - ((x_off>>shift) & 3)) + y_off*src_stride;
-    }
-    #endif
-
-    p = p + (x_off>>shift) + y_off*src_stride;
-
-
-    *bRGA_SRC_BASE0 = (unsigned long)p;
-
-	reg = ((reg & (~m_RGA2_SRC_INFO_SW_SRC_FMT)) | (s_RGA2_SRC_INFO_SW_SRC_FMT((msg->palette_mode | 0xc))));
-    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_CP_ENDAIN)) | (s_RGA2_SRC_INFO_SW_SW_CP_ENDAIN(msg->endian_mode & 1)));
-    *bRGA_SRC_VIR_INFO = src_stride >> 2;
-    *bRGA_SRC_ACT_INFO = (msg->src.act_w - 1) | ((msg->src.act_h - 1) << 16);
-    *bRGA_SRC_INFO = reg;
-
-    *bRGA_SRC_FG_COLOR = msg->fg_color;
-    *bRGA_SRC_BG_COLOR = msg->bg_color;
-
-}
-
+{
+    RK_U32 *bRGA_SRC_BASE0, *bRGA_SRC_INFO, *bRGA_SRC_VIR_INFO, *bRGA_SRC_ACT_INFO, *bRGA_SRC_FG_COLOR, *bRGA_SRC_BG_COLOR;
+    RK_U32  *p;
+    RK_S16  x_off, y_off;
+    RK_U16  src_stride;
+    RK_U8   shift;
+    RK_U32  sw;
+    RK_U32  byte_num;
+    RK_U32 reg;
+
+    bRGA_SRC_BASE0 = (RK_U32 *)(base + RGA2_SRC_BASE0_OFFSET);
+	bRGA_SRC_INFO = (RK_U32 *)(base + RGA2_SRC_INFO_OFFSET);
+    bRGA_SRC_VIR_INFO = (RK_U32 *)(base + RGA2_SRC_VIR_INFO_OFFSET);
+    bRGA_SRC_ACT_INFO = (RK_U32 *)(base + RGA2_SRC_ACT_INFO_OFFSET);
+    bRGA_SRC_FG_COLOR = (RK_U32 *)(base + RGA2_SRC_FG_COLOR_OFFSET);
+    bRGA_SRC_BG_COLOR = (RK_U32 *)(base + RGA2_SRC_BG_COLOR_OFFSET);
+
+    reg = 0;
+
+    shift = 3 - msg->palette_mode;
+
+    x_off = msg->src.x_offset;
+    y_off = msg->src.y_offset;
+
+    sw = msg->src.vir_w;
+    byte_num = sw >> shift;
+
+    src_stride = (byte_num + 3) & (~3);
+
+    p = (RK_U32 *)((unsigned long)msg->src.yrgb_addr);
+
+    #if 0
+    if(endian_mode)
+    {
+        p = p + (x_off>>shift) + y_off*src_stride;
+    }
+    else
+    {
+        p = p + (((x_off>>shift)>>2)<<2) + (3 - ((x_off>>shift) & 3)) + y_off*src_stride;
+    }
+    #endif
+
+    p = p + (x_off>>shift) + y_off*src_stride;
+
+
+    *bRGA_SRC_BASE0 = (unsigned long)p;
+
+	reg = ((reg & (~m_RGA2_SRC_INFO_SW_SRC_FMT)) | (s_RGA2_SRC_INFO_SW_SRC_FMT((msg->palette_mode | 0xc))));
+    reg = ((reg & (~m_RGA2_SRC_INFO_SW_SW_CP_ENDAIN)) | (s_RGA2_SRC_INFO_SW_SW_CP_ENDAIN(msg->endian_mode & 1)));
+    *bRGA_SRC_VIR_INFO = src_stride >> 2;
+    *bRGA_SRC_ACT_INFO = (msg->src.act_w - 1) | ((msg->src.act_h - 1) << 16);
+    *bRGA_SRC_INFO = reg;
+
+    *bRGA_SRC_FG_COLOR = msg->fg_color;
+    *bRGA_SRC_BG_COLOR = msg->bg_color;
+
+}
+
 static void RGA2_set_reg_color_fill(u8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_CF_GR_A;
-    RK_U32 *bRGA_CF_GR_B;
-    RK_U32 *bRGA_CF_GR_G;
-    RK_U32 *bRGA_CF_GR_R;
-    RK_U32 *bRGA_SRC_FG_COLOR;
-    RK_U32 *bRGA_MASK_ADDR;
-    RK_U32 *bRGA_PAT_CON;
-
-    RK_U32 mask_stride;
-    RK_U32 *bRGA_SRC_VIR_INFO;
-
-    bRGA_SRC_FG_COLOR = (RK_U32 *)(base + RGA2_SRC_FG_COLOR_OFFSET);
-
-    bRGA_CF_GR_A = (RK_U32 *)(base + RGA2_CF_GR_A_OFFSET);
-    bRGA_CF_GR_B = (RK_U32 *)(base + RGA2_CF_GR_B_OFFSET);
-    bRGA_CF_GR_G = (RK_U32 *)(base + RGA2_CF_GR_G_OFFSET);
-    bRGA_CF_GR_R = (RK_U32 *)(base + RGA2_CF_GR_R_OFFSET);
-
-    bRGA_MASK_ADDR = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
-    bRGA_PAT_CON = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
-
-    bRGA_SRC_VIR_INFO = (RK_U32 *)(base + RGA2_SRC_VIR_INFO_OFFSET);
-
-    mask_stride = msg->rop_mask_stride;
-
-    if(msg->color_fill_mode == 0)
-    {
-        /* solid color */
-        *bRGA_CF_GR_A = (msg->gr_color.gr_x_a & 0xffff) | (msg->gr_color.gr_y_a << 16);
-        *bRGA_CF_GR_B = (msg->gr_color.gr_x_b & 0xffff) | (msg->gr_color.gr_y_b << 16);
-        *bRGA_CF_GR_G = (msg->gr_color.gr_x_g & 0xffff) | (msg->gr_color.gr_y_g << 16);
-        *bRGA_CF_GR_R = (msg->gr_color.gr_x_r & 0xffff) | (msg->gr_color.gr_y_r << 16);
-
-        *bRGA_SRC_FG_COLOR = msg->fg_color;
-    }
-    else
-    {
-        /* patten color */
-        *bRGA_MASK_ADDR = (RK_U32)msg->pat.yrgb_addr;
-        *bRGA_PAT_CON = (msg->pat.act_w - 1) | ((msg->pat.act_h - 1) << 8)
-                       | (msg->pat.x_offset << 16) | (msg->pat.y_offset << 24);
-    }
-	*bRGA_SRC_VIR_INFO = mask_stride << 16;
-}
-
+{
+    RK_U32 *bRGA_CF_GR_A;
+    RK_U32 *bRGA_CF_GR_B;
+    RK_U32 *bRGA_CF_GR_G;
+    RK_U32 *bRGA_CF_GR_R;
+    RK_U32 *bRGA_SRC_FG_COLOR;
+    RK_U32 *bRGA_MASK_ADDR;
+    RK_U32 *bRGA_PAT_CON;
+
+    RK_U32 mask_stride;
+    RK_U32 *bRGA_SRC_VIR_INFO;
+
+    bRGA_SRC_FG_COLOR = (RK_U32 *)(base + RGA2_SRC_FG_COLOR_OFFSET);
+
+    bRGA_CF_GR_A = (RK_U32 *)(base + RGA2_CF_GR_A_OFFSET);
+    bRGA_CF_GR_B = (RK_U32 *)(base + RGA2_CF_GR_B_OFFSET);
+    bRGA_CF_GR_G = (RK_U32 *)(base + RGA2_CF_GR_G_OFFSET);
+    bRGA_CF_GR_R = (RK_U32 *)(base + RGA2_CF_GR_R_OFFSET);
+
+    bRGA_MASK_ADDR = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
+    bRGA_PAT_CON = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
+
+    bRGA_SRC_VIR_INFO = (RK_U32 *)(base + RGA2_SRC_VIR_INFO_OFFSET);
+
+    mask_stride = msg->rop_mask_stride;
+
+    if(msg->color_fill_mode == 0)
+    {
+        /* solid color */
+        *bRGA_CF_GR_A = (msg->gr_color.gr_x_a & 0xffff) | (msg->gr_color.gr_y_a << 16);
+        *bRGA_CF_GR_B = (msg->gr_color.gr_x_b & 0xffff) | (msg->gr_color.gr_y_b << 16);
+        *bRGA_CF_GR_G = (msg->gr_color.gr_x_g & 0xffff) | (msg->gr_color.gr_y_g << 16);
+        *bRGA_CF_GR_R = (msg->gr_color.gr_x_r & 0xffff) | (msg->gr_color.gr_y_r << 16);
+
+        *bRGA_SRC_FG_COLOR = msg->fg_color;
+    }
+    else
+    {
+        /* patten color */
+        *bRGA_MASK_ADDR = (RK_U32)msg->pat.yrgb_addr;
+        *bRGA_PAT_CON = (msg->pat.act_w - 1) | ((msg->pat.act_h - 1) << 8)
+                       | (msg->pat.x_offset << 16) | (msg->pat.y_offset << 24);
+    }
+	*bRGA_SRC_VIR_INFO = mask_stride << 16;
+}
+
 static void RGA2_set_reg_update_palette_table(RK_U8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_MASK_BASE;
-    RK_U32 *bRGA_FADING_CTRL;
-
-    bRGA_MASK_BASE  = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
-    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
-
-    *bRGA_FADING_CTRL = msg->fading_g_value << 8;
-    *bRGA_MASK_BASE = (RK_U32)msg->pat.yrgb_addr;
-}
-
-
+{
+    RK_U32 *bRGA_MASK_BASE;
+    RK_U32 *bRGA_FADING_CTRL;
+
+    bRGA_MASK_BASE  = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
+    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
+
+    *bRGA_FADING_CTRL = msg->fading_g_value << 8;
+    *bRGA_MASK_BASE = (RK_U32)msg->pat.yrgb_addr;
+}
+
+
 static void RGA2_set_reg_update_patten_buff(RK_U8 *base, struct rga2_req *msg)
-{
-    u32 *bRGA_PAT_MST;
-    u32 *bRGA_PAT_CON;
-    u32 *bRGA_PAT_START_POINT;
-    RK_U32 *bRGA_FADING_CTRL;
-    u32 reg = 0;
-    rga_img_info_t *pat;
-
-    RK_U32 num, offset;
-
-    pat = &msg->pat;
-
-    num = (pat->act_w * pat->act_h) - 1;
-
-    offset = pat->act_w * pat->y_offset + pat->x_offset;
-
-    bRGA_PAT_START_POINT = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
-    bRGA_PAT_MST = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
-    bRGA_PAT_CON = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
-    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
-
-    *bRGA_PAT_MST = (RK_U32)msg->pat.yrgb_addr;
-    *bRGA_PAT_START_POINT = (pat->act_w * pat->y_offset) + pat->x_offset;
-
-    reg = (pat->act_w-1) | ((pat->act_h-1) << 8) | (pat->x_offset << 16) | (pat->y_offset << 24);
-    *bRGA_PAT_CON = reg;
-
-    *bRGA_FADING_CTRL = (num << 8) | offset;
-}
-
+{
+    u32 *bRGA_PAT_MST;
+    u32 *bRGA_PAT_CON;
+    u32 *bRGA_PAT_START_POINT;
+    RK_U32 *bRGA_FADING_CTRL;
+    u32 reg = 0;
+    rga_img_info_t *pat;
+
+    RK_U32 num, offset;
+
+    pat = &msg->pat;
+
+    num = (pat->act_w * pat->act_h) - 1;
+
+    offset = pat->act_w * pat->y_offset + pat->x_offset;
+
+    bRGA_PAT_START_POINT = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
+    bRGA_PAT_MST = (RK_U32 *)(base + RGA2_MASK_BASE_OFFSET);
+    bRGA_PAT_CON = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
+    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
+
+    *bRGA_PAT_MST = (RK_U32)msg->pat.yrgb_addr;
+    *bRGA_PAT_START_POINT = (pat->act_w * pat->y_offset) + pat->x_offset;
+
+    reg = (pat->act_w-1) | ((pat->act_h-1) << 8) | (pat->x_offset << 16) | (pat->y_offset << 24);
+    *bRGA_PAT_CON = reg;
+
+    *bRGA_FADING_CTRL = (num << 8) | offset;
+}
+
 static void RGA2_set_pat_info(RK_U8 *base, struct rga2_req *msg)
-{
-    u32 *bRGA_PAT_CON;
-    u32 *bRGA_FADING_CTRL;
-    u32 reg = 0;
-    rga_img_info_t *pat;
-
-    RK_U32 num, offset;
-
-    pat = &msg->pat;
-
-    num = ((pat->act_w * pat->act_h) - 1) & 0xff;
-
-    offset = (pat->act_w * pat->y_offset) + pat->x_offset;
-
-    bRGA_PAT_CON     = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
-    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
-
-    reg = (pat->act_w-1) | ((pat->act_h-1) << 8) | (pat->x_offset << 16) | (pat->y_offset << 24);
-    *bRGA_PAT_CON = reg;
-    *bRGA_FADING_CTRL = (num << 8) | offset;
-}
-
+{
+    u32 *bRGA_PAT_CON;
+    u32 *bRGA_FADING_CTRL;
+    u32 reg = 0;
+    rga_img_info_t *pat;
+
+    RK_U32 num, offset;
+
+    pat = &msg->pat;
+
+    num = ((pat->act_w * pat->act_h) - 1) & 0xff;
+
+    offset = (pat->act_w * pat->y_offset) + pat->x_offset;
+
+    bRGA_PAT_CON     = (RK_U32 *)(base + RGA2_PAT_CON_OFFSET);
+    bRGA_FADING_CTRL = (RK_U32 *)(base + RGA2_FADING_CTRL_OFFSET);
+
+    reg = (pat->act_w-1) | ((pat->act_h-1) << 8) | (pat->x_offset << 16) | (pat->y_offset << 24);
+    *bRGA_PAT_CON = reg;
+    *bRGA_FADING_CTRL = (num << 8) | offset;
+}
+
 static void RGA2_set_mmu_info(RK_U8 *base, struct rga2_req *msg)
-{
-    RK_U32 *bRGA_MMU_CTRL1;
-    RK_U32 *bRGA_MMU_SRC_BASE;
-    RK_U32 *bRGA_MMU_SRC1_BASE;
-    RK_U32 *bRGA_MMU_DST_BASE;
-    RK_U32 *bRGA_MMU_ELS_BASE;
-
-    RK_U32 reg;
-
-    bRGA_MMU_CTRL1 = (RK_U32 *)(base + RGA2_MMU_CTRL1_OFFSET);
-    bRGA_MMU_SRC_BASE = (RK_U32 *)(base + RGA2_MMU_SRC_BASE_OFFSET);
-    bRGA_MMU_SRC1_BASE = (RK_U32 *)(base + RGA2_MMU_SRC1_BASE_OFFSET);
-    bRGA_MMU_DST_BASE = (RK_U32 *)(base + RGA2_MMU_DST_BASE_OFFSET);
-    bRGA_MMU_ELS_BASE = (RK_U32 *)(base + RGA2_MMU_ELS_BASE_OFFSET);
-
-    reg = (msg->mmu_info.src0_mmu_flag & 0xf) | ((msg->mmu_info.src1_mmu_flag & 0xf) << 4)
-         | ((msg->mmu_info.dst_mmu_flag & 0xf) << 8) | ((msg->mmu_info.els_mmu_flag & 0x3) << 12);
-
-    *bRGA_MMU_CTRL1 = reg;
-    *bRGA_MMU_SRC_BASE  = (RK_U32)(msg->mmu_info.src0_base_addr) >> 4;
-    *bRGA_MMU_SRC1_BASE = (RK_U32)(msg->mmu_info.src1_base_addr) >> 4;
-    *bRGA_MMU_DST_BASE  = (RK_U32)(msg->mmu_info.dst_base_addr)  >> 4;
-    *bRGA_MMU_ELS_BASE  = (RK_U32)(msg->mmu_info.els_base_addr)  >> 4;
-}
-
-
-int
-RGA2_gen_reg_info(RK_U8 *base , struct rga2_req *msg)
-{
-
-    RGA2_set_mode_ctrl(base, msg);
-
-    RGA2_set_pat_info(base, msg);
-
-    switch(msg->render_mode)
-    {
-        case bitblt_mode:
-            RGA2_set_reg_src_info(base, msg);
-            RGA2_set_reg_dst_info(base, msg);
-            RGA2_set_reg_alpha_info(base, msg);
-            RGA2_set_reg_rop_info(base, msg);
-            break;
-        case color_fill_mode :
-            RGA2_set_reg_color_fill(base, msg);
-            RGA2_set_reg_dst_info(base, msg);
-            RGA2_set_reg_alpha_info(base, msg);
-            break;
-        case color_palette_mode :
-            RGA2_set_reg_color_palette(base, msg);
-            RGA2_set_reg_dst_info(base, msg);
-            break;
-        case update_palette_table_mode :
-            RGA2_set_reg_update_palette_table(base, msg);
-            break;
-        case update_patten_buff_mode :
-            RGA2_set_reg_update_patten_buff(base, msg);
-            break;
-        default :
-            printk("RGA2 ERROR msg render mode %d \n", msg->render_mode);
-            break;
-
-    }
-
-    RGA2_set_mmu_info(base, msg);
-
-    return 0;
-
-}
-
+{
+    RK_U32 *bRGA_MMU_CTRL1;
+    RK_U32 *bRGA_MMU_SRC_BASE;
+    RK_U32 *bRGA_MMU_SRC1_BASE;
+    RK_U32 *bRGA_MMU_DST_BASE;
+    RK_U32 *bRGA_MMU_ELS_BASE;
+
+    RK_U32 reg;
+
+    bRGA_MMU_CTRL1 = (RK_U32 *)(base + RGA2_MMU_CTRL1_OFFSET);
+    bRGA_MMU_SRC_BASE = (RK_U32 *)(base + RGA2_MMU_SRC_BASE_OFFSET);
+    bRGA_MMU_SRC1_BASE = (RK_U32 *)(base + RGA2_MMU_SRC1_BASE_OFFSET);
+    bRGA_MMU_DST_BASE = (RK_U32 *)(base + RGA2_MMU_DST_BASE_OFFSET);
+    bRGA_MMU_ELS_BASE = (RK_U32 *)(base + RGA2_MMU_ELS_BASE_OFFSET);
+
+    reg = (msg->mmu_info.src0_mmu_flag & 0xf) | ((msg->mmu_info.src1_mmu_flag & 0xf) << 4)
+         | ((msg->mmu_info.dst_mmu_flag & 0xf) << 8) | ((msg->mmu_info.els_mmu_flag & 0x3) << 12);
+
+    *bRGA_MMU_CTRL1 = reg;
+    *bRGA_MMU_SRC_BASE  = (RK_U32)(msg->mmu_info.src0_base_addr) >> 4;
+    *bRGA_MMU_SRC1_BASE = (RK_U32)(msg->mmu_info.src1_base_addr) >> 4;
+    *bRGA_MMU_DST_BASE  = (RK_U32)(msg->mmu_info.dst_base_addr)  >> 4;
+    *bRGA_MMU_ELS_BASE  = (RK_U32)(msg->mmu_info.els_base_addr)  >> 4;
+}
+
+
+int
+RGA2_gen_reg_info(RK_U8 *base , struct rga2_req *msg)
+{
+
+    RGA2_set_mode_ctrl(base, msg);
+
+    RGA2_set_pat_info(base, msg);
+
+    switch(msg->render_mode)
+    {
+        case bitblt_mode:
+            RGA2_set_reg_src_info(base, msg);
+            RGA2_set_reg_dst_info(base, msg);
+            RGA2_set_reg_alpha_info(base, msg);
+            RGA2_set_reg_rop_info(base, msg);
+            break;
+        case color_fill_mode :
+            RGA2_set_reg_color_fill(base, msg);
+            RGA2_set_reg_dst_info(base, msg);
+            RGA2_set_reg_alpha_info(base, msg);
+            break;
+        case color_palette_mode :
+            RGA2_set_reg_color_palette(base, msg);
+            RGA2_set_reg_dst_info(base, msg);
+            break;
+        case update_palette_table_mode :
+            RGA2_set_reg_update_palette_table(base, msg);
+            break;
+        case update_patten_buff_mode :
+            RGA2_set_reg_update_patten_buff(base, msg);
+            break;
+        default :
+            printk("RGA2 ERROR msg render mode %d \n", msg->render_mode);
+            break;
+
+    }
+
+    RGA2_set_mmu_info(base, msg);
+
+    return 0;
+
+}
+
 static void format_name_convert(uint32_t *df, uint32_t sf)
-{
-    /*
-    RK_FORMAT_RGBA_8888    = 0x0,
-    RK_FORMAT_RGBX_8888    = 0x1,
-    RK_FORMAT_RGB_888      = 0x2,
-    RK_FORMAT_BGRA_8888    = 0x3,
-    RK_FORMAT_RGB_565      = 0x4,
-    RK_FORMAT_RGBA_5551    = 0x5,
-    RK_FORMAT_RGBA_4444    = 0x6,
-    RK_FORMAT_BGR_888      = 0x7,
-
-    RK_FORMAT_YCbCr_422_SP = 0x8,
-    RK_FORMAT_YCbCr_422_P  = 0x9,
-    RK_FORMAT_YCbCr_420_SP = 0xa,
-    RK_FORMAT_YCbCr_420_P  = 0xb,
-
-    RK_FORMAT_YCrCb_422_SP = 0xc,
-    RK_FORMAT_YCrCb_422_P  = 0xd,
-    RK_FORMAT_YCrCb_420_SP = 0xe,
-    RK_FORMAT_YCrCb_420_P  = 0xf,
-
-    RGA2_FORMAT_RGBA_8888    = 0x0,
-    RGA2_FORMAT_RGBX_8888    = 0x1,
-    RGA2_FORMAT_RGB_888      = 0x2,
-    RGA2_FORMAT_BGRA_8888    = 0x3,
-    RGA2_FORMAT_BGRX_8888    = 0x4,
-    RGA2_FORMAT_BGR_888      = 0x5,
-    RGA2_FORMAT_RGB_565      = 0x6,
-    RGA2_FORMAT_RGBA_5551    = 0x7,
-    RGA2_FORMAT_RGBA_4444    = 0x8,
-    RGA2_FORMAT_BGR_565      = 0x9,
-    RGA2_FORMAT_BGRA_5551    = 0xa,
-    RGA2_FORMAT_BGRA_4444    = 0xb,
-
-    RGA2_FORMAT_YCbCr_422_SP = 0x10,
-    RGA2_FORMAT_YCbCr_422_P  = 0x11,
-    RGA2_FORMAT_YCbCr_420_SP = 0x12,
-    RGA2_FORMAT_YCbCr_420_P  = 0x13,
-    RGA2_FORMAT_YCrCb_422_SP = 0x14,
-    RGA2_FORMAT_YCrCb_422_P  = 0x15,
-    RGA2_FORMAT_YCrCb_420_SP = 0x16,
-    RGA2_FORMAT_YCrCb_420_P  = 0x17,*/
-    switch(sf)
-    {
-        case 0x0: *df = RGA2_FORMAT_RGBA_8888; break;
-        case 0x1: *df = RGA2_FORMAT_RGBX_8888; break;
-        case 0x2: *df = RGA2_FORMAT_RGB_888; break;
-        case 0x3: *df = RGA2_FORMAT_BGRA_8888; break;
-        case 0x4: *df = RGA2_FORMAT_RGB_565; break;
-        case 0x5: *df = RGA2_FORMAT_RGBA_5551; break;
-        case 0x6: *df = RGA2_FORMAT_RGBA_4444; break;
-        case 0x7: *df = RGA2_FORMAT_BGR_888; break;
-        case 0x8: *df = RGA2_FORMAT_YCbCr_422_SP; break;
-        case 0x9: *df = RGA2_FORMAT_YCbCr_422_P; break;
-        case 0xa: *df = RGA2_FORMAT_YCbCr_420_SP; break;
-        case 0xb: *df = RGA2_FORMAT_YCbCr_420_P; break;
-        case 0xc: *df = RGA2_FORMAT_YCrCb_422_SP; break;
-        case 0xd: *df = RGA2_FORMAT_YCrCb_422_P; break;
-        case 0xe: *df = RGA2_FORMAT_YCrCb_420_SP; break;
-        case 0xf: *df = RGA2_FORMAT_YCrCb_420_P; break;
+{
+    /*
+    RK_FORMAT_RGBA_8888    = 0x0,
+    RK_FORMAT_RGBX_8888    = 0x1,
+    RK_FORMAT_RGB_888      = 0x2,
+    RK_FORMAT_BGRA_8888    = 0x3,
+    RK_FORMAT_RGB_565      = 0x4,
+    RK_FORMAT_RGBA_5551    = 0x5,
+    RK_FORMAT_RGBA_4444    = 0x6,
+    RK_FORMAT_BGR_888      = 0x7,
+
+    RK_FORMAT_YCbCr_422_SP = 0x8,
+    RK_FORMAT_YCbCr_422_P  = 0x9,
+    RK_FORMAT_YCbCr_420_SP = 0xa,
+    RK_FORMAT_YCbCr_420_P  = 0xb,
+
+    RK_FORMAT_YCrCb_422_SP = 0xc,
+    RK_FORMAT_YCrCb_422_P  = 0xd,
+    RK_FORMAT_YCrCb_420_SP = 0xe,
+    RK_FORMAT_YCrCb_420_P  = 0xf,
+
+    RGA2_FORMAT_RGBA_8888    = 0x0,
+    RGA2_FORMAT_RGBX_8888    = 0x1,
+    RGA2_FORMAT_RGB_888      = 0x2,
+    RGA2_FORMAT_BGRA_8888    = 0x3,
+    RGA2_FORMAT_BGRX_8888    = 0x4,
+    RGA2_FORMAT_BGR_888      = 0x5,
+    RGA2_FORMAT_RGB_565      = 0x6,
+    RGA2_FORMAT_RGBA_5551    = 0x7,
+    RGA2_FORMAT_RGBA_4444    = 0x8,
+    RGA2_FORMAT_BGR_565      = 0x9,
+    RGA2_FORMAT_BGRA_5551    = 0xa,
+    RGA2_FORMAT_BGRA_4444    = 0xb,
+
+    RGA2_FORMAT_YCbCr_422_SP = 0x10,
+    RGA2_FORMAT_YCbCr_422_P  = 0x11,
+    RGA2_FORMAT_YCbCr_420_SP = 0x12,
+    RGA2_FORMAT_YCbCr_420_P  = 0x13,
+    RGA2_FORMAT_YCrCb_422_SP = 0x14,
+    RGA2_FORMAT_YCrCb_422_P  = 0x15,
+    RGA2_FORMAT_YCrCb_420_SP = 0x16,
+    RGA2_FORMAT_YCrCb_420_P  = 0x17,*/
+    switch(sf)
+    {
+        case 0x0: *df = RGA2_FORMAT_RGBA_8888; break;
+        case 0x1: *df = RGA2_FORMAT_RGBX_8888; break;
+        case 0x2: *df = RGA2_FORMAT_RGB_888; break;
+        case 0x3: *df = RGA2_FORMAT_BGRA_8888; break;
+        case 0x4: *df = RGA2_FORMAT_RGB_565; break;
+        case 0x5: *df = RGA2_FORMAT_RGBA_5551; break;
+        case 0x6: *df = RGA2_FORMAT_RGBA_4444; break;
+        case 0x7: *df = RGA2_FORMAT_BGR_888; break;
+        case 0x8: *df = RGA2_FORMAT_YCbCr_422_SP; break;
+        case 0x9: *df = RGA2_FORMAT_YCbCr_422_P; break;
+        case 0xa: *df = RGA2_FORMAT_YCbCr_420_SP; break;
+        case 0xb: *df = RGA2_FORMAT_YCbCr_420_P; break;
+        case 0xc: *df = RGA2_FORMAT_YCrCb_422_SP; break;
+        case 0xd: *df = RGA2_FORMAT_YCrCb_422_P; break;
+        case 0xe: *df = RGA2_FORMAT_YCrCb_420_SP; break;
+        case 0xf: *df = RGA2_FORMAT_YCrCb_420_P; break;
 
 	case 0x18: *df = RGA2_FORMAT_YVYU_422; break;
 	case 0x19: *df = RGA2_FORMAT_YVYU_420; break;
@@ -994,13 +994,13 @@ static void format_name_convert(uint32_t *df, uint32_t sf)
 	case 0x1e: *df = RGA2_FORMAT_UYVY_422; break;
 	case 0x1f: *df = RGA2_FORMAT_UYVY_420; break;
 
-        case 0x20:*df = RGA2_FORMAT_YCbCr_420_SP_10B; break;
-        case 0x21:*df = RGA2_FORMAT_YCrCb_420_SP_10B; break;
+        case 0x20:*df = RGA2_FORMAT_YCbCr_420_SP_10B; break;
+        case 0x21:*df = RGA2_FORMAT_YCrCb_420_SP_10B; break;
+
+    }
+}
 
-    }
-}
-
-void RGA_MSG_2_RGA2_MSG(struct rga_req *req_rga, struct rga2_req *req)
+void RGA_MSG_2_RGA2_MSG(struct rga_req *req_rga, struct rga2_req *req)
 {
 	u16 alpha_mode_0, alpha_mode_1;
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0))
@@ -1010,221 +1010,221 @@ void RGA_MSG_2_RGA2_MSG(struct rga_req *req_rga, struct rga2_req *req)
 	req_rga->render_mode &= (~RGA_BUF_GEM_TYPE_MASK);
 #endif
 
-    if (req_rga->render_mode == 6)
-        req->render_mode = update_palette_table_mode;
-    else if (req_rga->render_mode == 7)
-        req->render_mode = update_patten_buff_mode;
-    else if (req_rga->render_mode == 5)
-        req->render_mode = bitblt_mode;
-    else
-        req->render_mode = req_rga->render_mode;
-
-    memcpy(&req->src, &req_rga->src, sizeof(req_rga->src));
-    memcpy(&req->dst, &req_rga->dst, sizeof(req_rga->dst));
-    memcpy(&req->pat, &req_rga->pat, sizeof(req_rga->pat));
-    memcpy(&req->src1,&req_rga->pat, sizeof(req_rga->pat));
-
-    format_name_convert(&req->src.format, req_rga->src.format);
-    format_name_convert(&req->dst.format, req_rga->dst.format);
-
-    if(req_rga->rotate_mode == 1) {
-        if(req_rga->sina == 0 && req_rga->cosa == 65536) {
-            /* rotate 0 */
-            req->rotate_mode = 0;
-        }
-        else if (req_rga->sina == 65536 && req_rga->cosa == 0) {
-            /* rotate 90 */
-            req->rotate_mode = 1;
-            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_h + 1;
-            req->dst.act_w = req_rga->dst.act_h;
-            req->dst.act_h = req_rga->dst.act_w;
-        }
-        else if (req_rga->sina == 0 && req_rga->cosa == -65536) {
-            /* rotate 180 */
-            req->rotate_mode = 2;
-            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_w + 1;
-            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_h + 1;
-        }
-        else if (req_rga->sina == -65536 && req_rga->cosa == 0) {
-            /* totate 270 */
-            req->rotate_mode = 3;
-            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_w + 1;
-            req->dst.act_w = req_rga->dst.act_h;
-            req->dst.act_h = req_rga->dst.act_w;
-        }
-    }
-    else if (req_rga->rotate_mode == 2)
-    {
-        //x_mirror
-        req->rotate_mode |= (1 << 4);
-    }
-    else if (req_rga->rotate_mode == 3)
-    {
-        //y_mirror
-        req->rotate_mode |= (2 << 4);
-    }
-    else {
-        req->rotate_mode = 0;
-    }
-
-    if((req->dst.act_w > 2048) && (req->src.act_h < req->dst.act_h))
-        req->scale_bicu_mode |= (1<<4);
-
-    req->LUT_addr = req_rga->LUT_addr;
-    req->rop_mask_addr = req_rga->rop_mask_addr;
-
-    req->bitblt_mode = req_rga->bsfilter_flag;
-
-    req->src_a_global_val = req_rga->alpha_global_value;
-    req->dst_a_global_val = req_rga->alpha_global_value;
-    req->rop_code = req_rga->rop_code;
-    req->rop_mode = 0;
-
-    req->color_fill_mode = req_rga->color_fill_mode;
-    req->color_key_min   = req_rga->color_key_min;
-    req->color_key_max   = req_rga->color_key_max;
-
-    req->fg_color = req_rga->fg_color;
-    req->bg_color = req_rga->bg_color;
-    memcpy(&req->gr_color, &req_rga->gr_color, sizeof(req_rga->gr_color));
-
-    req->palette_mode = req_rga->palette_mode;
-    req->yuv2rgb_mode = req_rga->yuv2rgb_mode + 1;
-    req->endian_mode = req_rga->endian_mode;
-    req->rgb2yuv_mode = 0;
-
-    req->fading_alpha_value = 0;
-    req->fading_r_value = req_rga->fading.r;
-    req->fading_g_value = req_rga->fading.g;
-    req->fading_b_value = req_rga->fading.b;
-
-    /* alpha mode set */
-    req->alpha_rop_flag = 0;
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag & 1)));           // alpha_rop_enable
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 1) & 1) << 1); // rop_enable
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 2) & 1) << 2); // fading_enable
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 4) & 1) << 3); // alpha_cal_mode_sel
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 5) & 1) << 6); // dst_dither_down
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 6) & 1) << 7); // gradient fill mode sel
-
-    if (((req_rga->alpha_rop_flag) & 1)) {
-        if ((req_rga->alpha_rop_flag >> 3) & 1) {
-            /* porter duff alpha enable */
-            switch (req_rga->PD_mode)
-            {
-                case 0: //dst = 0
-                    break;
-                case 1: //dst = src
-                    break;
-                case 2: //dst = dst
-                    break;
-                case 3: //dst = (256*sc + (256 - sa)*dc) >> 8
-                    if((req_rga->alpha_rop_mode & 3) == 0) {
-                        alpha_mode_0 = 0x3818;
-                        alpha_mode_1 = 0x3818;
-                    }
-                    else if ((req_rga->alpha_rop_mode & 3) == 1) {
-                        alpha_mode_0 = 0x381A;
-                        alpha_mode_1 = 0x381A;
-                    }
-                    else if ((req_rga->alpha_rop_mode & 3) == 2) {
-                        alpha_mode_0 = 0x381C;
-                        alpha_mode_1 = 0x381C;
-                    }
-                    else {
-                        alpha_mode_0 = 0x381A;
-                        alpha_mode_1 = 0x381A;
-                    }
-                    req->alpha_mode_0 = alpha_mode_0;
-                    req->alpha_mode_1 = alpha_mode_1;
-                    break;
-                case 4: //dst = (sc*(256-da) + 256*dc) >> 8
-                    break;
-                case 5: //dst = (da*sc) >> 8
-                    break;
-                case 6: //dst = (sa*dc) >> 8
-                    break;
-                case 7: //dst = ((256-da)*sc) >> 8
-                    break;
-                case 8: //dst = ((256-sa)*dc) >> 8
-                    break;
-                case 9: //dst = (da*sc + (256-sa)*dc) >> 8
-                    req->alpha_mode_0 = 0x3848;
-                    req->alpha_mode_1 = 0x3848;
-                    break;
-                case 10://dst = ((256-da)*sc + (sa*dc)) >> 8
-                    break;
-                case 11://dst = ((256-da)*sc + (256-sa)*dc) >> 8;
-                    break;
-		case 12:
-		    req->alpha_mode_0 = 0x0010;
-		    req->alpha_mode_1 = 0x0820;
-		    break;
-                default:
-                    break;
-            }
-        }
-        else {
-            if((req_rga->alpha_rop_mode & 3) == 0) {
-                req->alpha_mode_0 = 0x3848;
-                req->alpha_mode_1 = 0x3848;
-            }
-            else if ((req_rga->alpha_rop_mode & 3) == 1) {
+    if (req_rga->render_mode == 6)
+        req->render_mode = update_palette_table_mode;
+    else if (req_rga->render_mode == 7)
+        req->render_mode = update_patten_buff_mode;
+    else if (req_rga->render_mode == 5)
+        req->render_mode = bitblt_mode;
+    else
+        req->render_mode = req_rga->render_mode;
+
+    memcpy(&req->src, &req_rga->src, sizeof(req_rga->src));
+    memcpy(&req->dst, &req_rga->dst, sizeof(req_rga->dst));
+    memcpy(&req->pat, &req_rga->pat, sizeof(req_rga->pat));
+    memcpy(&req->src1,&req_rga->pat, sizeof(req_rga->pat));
+
+    format_name_convert(&req->src.format, req_rga->src.format);
+    format_name_convert(&req->dst.format, req_rga->dst.format);
+
+    if(req_rga->rotate_mode == 1) {
+        if(req_rga->sina == 0 && req_rga->cosa == 65536) {
+            /* rotate 0 */
+            req->rotate_mode = 0;
+        }
+        else if (req_rga->sina == 65536 && req_rga->cosa == 0) {
+            /* rotate 90 */
+            req->rotate_mode = 1;
+            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_h + 1;
+            req->dst.act_w = req_rga->dst.act_h;
+            req->dst.act_h = req_rga->dst.act_w;
+        }
+        else if (req_rga->sina == 0 && req_rga->cosa == -65536) {
+            /* rotate 180 */
+            req->rotate_mode = 2;
+            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_w + 1;
+            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_h + 1;
+        }
+        else if (req_rga->sina == -65536 && req_rga->cosa == 0) {
+            /* totate 270 */
+            req->rotate_mode = 3;
+            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_w + 1;
+            req->dst.act_w = req_rga->dst.act_h;
+            req->dst.act_h = req_rga->dst.act_w;
+        }
+    }
+    else if (req_rga->rotate_mode == 2)
+    {
+        //x_mirror
+        req->rotate_mode |= (1 << 4);
+    }
+    else if (req_rga->rotate_mode == 3)
+    {
+        //y_mirror
+        req->rotate_mode |= (2 << 4);
+    }
+    else {
+        req->rotate_mode = 0;
+    }
+
+    if((req->dst.act_w > 2048) && (req->src.act_h < req->dst.act_h))
+        req->scale_bicu_mode |= (1<<4);
+
+    req->LUT_addr = req_rga->LUT_addr;
+    req->rop_mask_addr = req_rga->rop_mask_addr;
+
+    req->bitblt_mode = req_rga->bsfilter_flag;
+
+    req->src_a_global_val = req_rga->alpha_global_value;
+    req->dst_a_global_val = req_rga->alpha_global_value;
+    req->rop_code = req_rga->rop_code;
+    req->rop_mode = 0;
+
+    req->color_fill_mode = req_rga->color_fill_mode;
+    req->color_key_min   = req_rga->color_key_min;
+    req->color_key_max   = req_rga->color_key_max;
+
+    req->fg_color = req_rga->fg_color;
+    req->bg_color = req_rga->bg_color;
+    memcpy(&req->gr_color, &req_rga->gr_color, sizeof(req_rga->gr_color));
+
+    req->palette_mode = req_rga->palette_mode;
+    req->yuv2rgb_mode = req_rga->yuv2rgb_mode + 1;
+    req->endian_mode = req_rga->endian_mode;
+    req->rgb2yuv_mode = 0;
+
+    req->fading_alpha_value = 0;
+    req->fading_r_value = req_rga->fading.r;
+    req->fading_g_value = req_rga->fading.g;
+    req->fading_b_value = req_rga->fading.b;
+
+    /* alpha mode set */
+    req->alpha_rop_flag = 0;
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag & 1)));           // alpha_rop_enable
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 1) & 1) << 1); // rop_enable
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 2) & 1) << 2); // fading_enable
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 4) & 1) << 3); // alpha_cal_mode_sel
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 5) & 1) << 6); // dst_dither_down
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 6) & 1) << 7); // gradient fill mode sel
+
+    if (((req_rga->alpha_rop_flag) & 1)) {
+        if ((req_rga->alpha_rop_flag >> 3) & 1) {
+            /* porter duff alpha enable */
+            switch (req_rga->PD_mode)
+            {
+                case 0: //dst = 0
+                    break;
+                case 1: //dst = src
+                    break;
+                case 2: //dst = dst
+                    break;
+                case 3: //dst = (256*sc + (256 - sa)*dc) >> 8
+                    if((req_rga->alpha_rop_mode & 3) == 0) {
+                        alpha_mode_0 = 0x3818;
+                        alpha_mode_1 = 0x3818;
+                    }
+                    else if ((req_rga->alpha_rop_mode & 3) == 1) {
+                        alpha_mode_0 = 0x381A;
+                        alpha_mode_1 = 0x381A;
+                    }
+                    else if ((req_rga->alpha_rop_mode & 3) == 2) {
+                        alpha_mode_0 = 0x381C;
+                        alpha_mode_1 = 0x381C;
+                    }
+                    else {
+                        alpha_mode_0 = 0x381A;
+                        alpha_mode_1 = 0x381A;
+                    }
+                    req->alpha_mode_0 = alpha_mode_0;
+                    req->alpha_mode_1 = alpha_mode_1;
+                    break;
+                case 4: //dst = (sc*(256-da) + 256*dc) >> 8
+                    break;
+                case 5: //dst = (da*sc) >> 8
+                    break;
+                case 6: //dst = (sa*dc) >> 8
+                    break;
+                case 7: //dst = ((256-da)*sc) >> 8
+                    break;
+                case 8: //dst = ((256-sa)*dc) >> 8
+                    break;
+                case 9: //dst = (da*sc + (256-sa)*dc) >> 8
+                    req->alpha_mode_0 = 0x3848;
+                    req->alpha_mode_1 = 0x3848;
+                    break;
+                case 10://dst = ((256-da)*sc + (sa*dc)) >> 8
+                    break;
+                case 11://dst = ((256-da)*sc + (256-sa)*dc) >> 8;
+                    break;
+		case 12:
+		    req->alpha_mode_0 = 0x0010;
+		    req->alpha_mode_1 = 0x0820;
+		    break;
+                default:
+                    break;
+            }
+        }
+        else {
+            if((req_rga->alpha_rop_mode & 3) == 0) {
+                req->alpha_mode_0 = 0x3848;
+                req->alpha_mode_1 = 0x3848;
+            }
+            else if ((req_rga->alpha_rop_mode & 3) == 1) {
 		req->alpha_mode_0 = 0x384A;
 		req->alpha_mode_1 = 0x3A4A;
-            }
-            else if ((req_rga->alpha_rop_mode & 3) == 2) {
-                req->alpha_mode_0 = 0x384C;
-                req->alpha_mode_1 = 0x384C;
-            }
-        }
-    }
-
-    if (req_rga->mmu_info.mmu_en && (req_rga->mmu_info.mmu_flag & 1) == 1) {
-        req->mmu_info.src0_mmu_flag = 1;
-        req->mmu_info.dst_mmu_flag = 1;
-
-        if (req_rga->mmu_info.mmu_flag >> 31) {
-            req->mmu_info.src0_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 8)  & 1);
-            req->mmu_info.src1_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 9)  & 1);
-            req->mmu_info.dst_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 10) & 1);
-            req->mmu_info.els_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 11) & 1);
-        }
-        else {
-            if (req_rga->src.yrgb_addr >= 0xa0000000) {
-               req->mmu_info.src0_mmu_flag = 0;
-               req->src.yrgb_addr = req_rga->src.yrgb_addr - 0x60000000;
-               req->src.uv_addr   = req_rga->src.uv_addr - 0x60000000;
-               req->src.v_addr    = req_rga->src.v_addr - 0x60000000;
-            }
-
-            if (req_rga->dst.yrgb_addr >= 0xa0000000) {
-               req->mmu_info.dst_mmu_flag = 0;
-               req->dst.yrgb_addr = req_rga->dst.yrgb_addr - 0x60000000;
-            }
-        }
-    }
-}
-
+            }
+            else if ((req_rga->alpha_rop_mode & 3) == 2) {
+                req->alpha_mode_0 = 0x384C;
+                req->alpha_mode_1 = 0x384C;
+            }
+        }
+    }
+
+    if (req_rga->mmu_info.mmu_en && (req_rga->mmu_info.mmu_flag & 1) == 1) {
+        req->mmu_info.src0_mmu_flag = 1;
+        req->mmu_info.dst_mmu_flag = 1;
+
+        if (req_rga->mmu_info.mmu_flag >> 31) {
+            req->mmu_info.src0_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 8)  & 1);
+            req->mmu_info.src1_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 9)  & 1);
+            req->mmu_info.dst_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 10) & 1);
+            req->mmu_info.els_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 11) & 1);
+        }
+        else {
+            if (req_rga->src.yrgb_addr >= 0xa0000000) {
+               req->mmu_info.src0_mmu_flag = 0;
+               req->src.yrgb_addr = req_rga->src.yrgb_addr - 0x60000000;
+               req->src.uv_addr   = req_rga->src.uv_addr - 0x60000000;
+               req->src.v_addr    = req_rga->src.v_addr - 0x60000000;
+            }
+
+            if (req_rga->dst.yrgb_addr >= 0xa0000000) {
+               req->mmu_info.dst_mmu_flag = 0;
+               req->dst.yrgb_addr = req_rga->dst.yrgb_addr - 0x60000000;
+            }
+        }
+    }
+}
+
 static void memcpy_img_info(struct rga_img_info_t *dst, struct rga_img_info_32_t *src)
-{
-    dst->yrgb_addr = src->yrgb_addr;      /* yrgb    mem addr         */
-    dst->uv_addr = src->uv_addr;        /* cb/cr   mem addr         */
-    dst->v_addr = src->v_addr;         /* cr      mem addr         */
-    dst->format = src->format;         //definition by RK_FORMAT
-
-    dst->act_w = src->act_w;
-    dst->act_h = src->act_h;
-    dst->x_offset = src->x_offset;
-    dst->y_offset = src->y_offset;
-
-    dst->vir_w = src->vir_w;
-    dst->vir_h = src->vir_h;
-    dst->endian_mode = src->endian_mode; //for BPP
-    dst->alpha_swap = src->alpha_swap;
+{
+    dst->yrgb_addr = src->yrgb_addr;      /* yrgb    mem addr         */
+    dst->uv_addr = src->uv_addr;        /* cb/cr   mem addr         */
+    dst->v_addr = src->v_addr;         /* cr      mem addr         */
+    dst->format = src->format;         //definition by RK_FORMAT
+
+    dst->act_w = src->act_w;
+    dst->act_h = src->act_h;
+    dst->x_offset = src->x_offset;
+    dst->y_offset = src->y_offset;
+
+    dst->vir_w = src->vir_w;
+    dst->vir_h = src->vir_h;
+    dst->endian_mode = src->endian_mode; //for BPP
+    dst->alpha_swap = src->alpha_swap;
 }
 
-void RGA_MSG_2_RGA2_MSG_32(struct rga_req_32 *req_rga, struct rga2_req *req)
+void RGA_MSG_2_RGA2_MSG_32(struct rga_req_32 *req_rga, struct rga2_req *req)
 {
 	u16 alpha_mode_0, alpha_mode_1;
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0))
@@ -1233,174 +1233,174 @@ void RGA_MSG_2_RGA2_MSG_32(struct rga_req_32 *req_rga, struct rga2_req *req)
 
 	req_rga->render_mode &= (~RGA_BUF_GEM_TYPE_MASK);
 #endif
-    if (req_rga->render_mode == 6)
-        req->render_mode = update_palette_table_mode;
-    else if (req_rga->render_mode == 7)
-        req->render_mode = update_patten_buff_mode;
-    else if (req_rga->render_mode == 5)
-        req->render_mode = bitblt_mode;
-    else
-        req->render_mode = req_rga->render_mode;
-    memcpy_img_info(&req->src, &req_rga->src);
-    memcpy_img_info(&req->dst, &req_rga->dst);
-    memcpy_img_info(&req->pat, &req_rga->pat);
-    memcpy_img_info(&req->src1,&req_rga->pat);
-    format_name_convert(&req->src.format, req_rga->src.format);
-    format_name_convert(&req->dst.format, req_rga->dst.format);
-    if(req_rga->rotate_mode == 1) {
-        if(req_rga->sina == 0 && req_rga->cosa == 65536) {
-            req->rotate_mode = 0;
-        }
-        else if (req_rga->sina == 65536 && req_rga->cosa == 0) {
-            req->rotate_mode = 1;
-            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_h + 1;
-            req->dst.act_w = req_rga->dst.act_h;
-            req->dst.act_h = req_rga->dst.act_w;
-        }
-        else if (req_rga->sina == 0 && req_rga->cosa == -65536) {
-            req->rotate_mode = 2;
-            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_w + 1;
-            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_h + 1;
-        }
-        else if (req_rga->sina == -65536 && req_rga->cosa == 0) {
-            req->rotate_mode = 3;
-            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_w + 1;
-            req->dst.act_w = req_rga->dst.act_h;
-            req->dst.act_h = req_rga->dst.act_w;
-        }
-    }
-    else if (req_rga->rotate_mode == 2)
-    {
-        req->rotate_mode = (1 << 4);
-    }
-    else if (req_rga->rotate_mode == 3)
-    {
-        req->rotate_mode = (2 << 4);
-    }
-    else {
-        req->rotate_mode = 0;
-    }
-    if((req->dst.act_w > 2048) && (req->src.act_h < req->dst.act_h))
-        req->scale_bicu_mode |= (1<<4);
-    req->LUT_addr = req_rga->LUT_addr;
-    req->rop_mask_addr = req_rga->rop_mask_addr;
-    req->bitblt_mode = req_rga->bsfilter_flag;
-    req->src_a_global_val = req_rga->alpha_global_value;
-    req->dst_a_global_val = req_rga->alpha_global_value;
-    req->rop_code = req_rga->rop_code;
-    req->rop_mode = 0;
-    req->color_fill_mode = req_rga->color_fill_mode;
-    req->color_key_min   = req_rga->color_key_min;
-    req->color_key_max   = req_rga->color_key_max;
-    req->fg_color = req_rga->fg_color;
-    req->bg_color = req_rga->bg_color;
-    memcpy(&req->gr_color, &req_rga->gr_color, sizeof(req_rga->gr_color));
-    req->palette_mode = req_rga->palette_mode;
-    req->yuv2rgb_mode = req_rga->yuv2rgb_mode + 1;
-    req->endian_mode = req_rga->endian_mode;
-    req->rgb2yuv_mode = 0;
-    req->fading_alpha_value = 0;
-    req->fading_r_value = req_rga->fading.r;
-    req->fading_g_value = req_rga->fading.g;
-    req->fading_b_value = req_rga->fading.b;
-    req->alpha_rop_flag = 0;
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag & 1)));           // alpha_rop_enable
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 1) & 1) << 1); // rop_enable
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 2) & 1) << 2); // fading_enable
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 4) & 1) << 3); // alpha_cal_mode_sel
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 5) & 1) << 6); // dst_dither_down
-    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 6) & 1) << 7); // gradient fill mode sel
-    if(((req_rga->alpha_rop_flag) & 1)) {
-        if((req_rga->alpha_rop_flag >> 3) & 1) {
-            switch(req_rga->PD_mode)
-            {
-                case 0: //dst = 0
-                    break;
-                case 1: //dst = src
-                    break;
-                case 2: //dst = dst
-                    break;
-                case 3: //dst = (256*sc + (256 - sa)*dc) >> 8
-                    if((req_rga->alpha_rop_mode & 3) == 0) {
-                        alpha_mode_0 = 0x3818;
-                        alpha_mode_1 = 0x3818;
-                    }
-                    else if ((req_rga->alpha_rop_mode & 3) == 1) {
-                        alpha_mode_0 = 0x381A;
-                        alpha_mode_1 = 0x381A;
-                    }
-                    else if ((req_rga->alpha_rop_mode & 3) == 2) {
-                        alpha_mode_0 = 0x381C;
-                        alpha_mode_1 = 0x381C;
-                    }
-                    else {
-                        alpha_mode_0 = 0x381A;
-                        alpha_mode_1 = 0x381A;
-                    }
-                    req->alpha_mode_0 = alpha_mode_0;
-                    req->alpha_mode_1 = alpha_mode_1;
-                    break;
-                case 4: //dst = (sc*(256-da) + 256*dc) >> 8
-                    break;
-                case 5: //dst = (da*sc) >> 8
-                    break;
-                case 6: //dst = (sa*dc) >> 8
-                    break;
-                case 7: //dst = ((256-da)*sc) >> 8
-                    break;
-                case 8: //dst = ((256-sa)*dc) >> 8
-                    break;
-                case 9: //dst = (da*sc + (256-sa)*dc) >> 8
-                    req->alpha_mode_0 = 0x3848;
-                    req->alpha_mode_1 = 0x3848;
-                    break;
-                case 10://dst = ((256-da)*sc + (sa*dc)) >> 8
-                    break;
-                case 11://dst = ((256-da)*sc + (256-sa)*dc) >> 8;
-                    break;
-		case 12:
-		    req->alpha_mode_0 = 0x0010;
-		    req->alpha_mode_1 = 0x0820;
-		    break;
-                default:
-                    break;
-            }
-        }
-        else {
-            if((req_rga->alpha_rop_mode & 3) == 0) {
-                req->alpha_mode_0 = 0x3848;
-                req->alpha_mode_1 = 0x3848;
-            }
-            else if ((req_rga->alpha_rop_mode & 3) == 1) {
+    if (req_rga->render_mode == 6)
+        req->render_mode = update_palette_table_mode;
+    else if (req_rga->render_mode == 7)
+        req->render_mode = update_patten_buff_mode;
+    else if (req_rga->render_mode == 5)
+        req->render_mode = bitblt_mode;
+    else
+        req->render_mode = req_rga->render_mode;
+    memcpy_img_info(&req->src, &req_rga->src);
+    memcpy_img_info(&req->dst, &req_rga->dst);
+    memcpy_img_info(&req->pat, &req_rga->pat);
+    memcpy_img_info(&req->src1,&req_rga->pat);
+    format_name_convert(&req->src.format, req_rga->src.format);
+    format_name_convert(&req->dst.format, req_rga->dst.format);
+    if(req_rga->rotate_mode == 1) {
+        if(req_rga->sina == 0 && req_rga->cosa == 65536) {
+            req->rotate_mode = 0;
+        }
+        else if (req_rga->sina == 65536 && req_rga->cosa == 0) {
+            req->rotate_mode = 1;
+            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_h + 1;
+            req->dst.act_w = req_rga->dst.act_h;
+            req->dst.act_h = req_rga->dst.act_w;
+        }
+        else if (req_rga->sina == 0 && req_rga->cosa == -65536) {
+            req->rotate_mode = 2;
+            req->dst.x_offset = req_rga->dst.x_offset - req_rga->dst.act_w + 1;
+            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_h + 1;
+        }
+        else if (req_rga->sina == -65536 && req_rga->cosa == 0) {
+            req->rotate_mode = 3;
+            req->dst.y_offset = req_rga->dst.y_offset - req_rga->dst.act_w + 1;
+            req->dst.act_w = req_rga->dst.act_h;
+            req->dst.act_h = req_rga->dst.act_w;
+        }
+    }
+    else if (req_rga->rotate_mode == 2)
+    {
+        req->rotate_mode = (1 << 4);
+    }
+    else if (req_rga->rotate_mode == 3)
+    {
+        req->rotate_mode = (2 << 4);
+    }
+    else {
+        req->rotate_mode = 0;
+    }
+    if((req->dst.act_w > 2048) && (req->src.act_h < req->dst.act_h))
+        req->scale_bicu_mode |= (1<<4);
+    req->LUT_addr = req_rga->LUT_addr;
+    req->rop_mask_addr = req_rga->rop_mask_addr;
+    req->bitblt_mode = req_rga->bsfilter_flag;
+    req->src_a_global_val = req_rga->alpha_global_value;
+    req->dst_a_global_val = req_rga->alpha_global_value;
+    req->rop_code = req_rga->rop_code;
+    req->rop_mode = 0;
+    req->color_fill_mode = req_rga->color_fill_mode;
+    req->color_key_min   = req_rga->color_key_min;
+    req->color_key_max   = req_rga->color_key_max;
+    req->fg_color = req_rga->fg_color;
+    req->bg_color = req_rga->bg_color;
+    memcpy(&req->gr_color, &req_rga->gr_color, sizeof(req_rga->gr_color));
+    req->palette_mode = req_rga->palette_mode;
+    req->yuv2rgb_mode = req_rga->yuv2rgb_mode + 1;
+    req->endian_mode = req_rga->endian_mode;
+    req->rgb2yuv_mode = 0;
+    req->fading_alpha_value = 0;
+    req->fading_r_value = req_rga->fading.r;
+    req->fading_g_value = req_rga->fading.g;
+    req->fading_b_value = req_rga->fading.b;
+    req->alpha_rop_flag = 0;
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag & 1)));           // alpha_rop_enable
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 1) & 1) << 1); // rop_enable
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 2) & 1) << 2); // fading_enable
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 4) & 1) << 3); // alpha_cal_mode_sel
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 5) & 1) << 6); // dst_dither_down
+    req->alpha_rop_flag |= (((req_rga->alpha_rop_flag >> 6) & 1) << 7); // gradient fill mode sel
+    if(((req_rga->alpha_rop_flag) & 1)) {
+        if((req_rga->alpha_rop_flag >> 3) & 1) {
+            switch(req_rga->PD_mode)
+            {
+                case 0: //dst = 0
+                    break;
+                case 1: //dst = src
+                    break;
+                case 2: //dst = dst
+                    break;
+                case 3: //dst = (256*sc + (256 - sa)*dc) >> 8
+                    if((req_rga->alpha_rop_mode & 3) == 0) {
+                        alpha_mode_0 = 0x3818;
+                        alpha_mode_1 = 0x3818;
+                    }
+                    else if ((req_rga->alpha_rop_mode & 3) == 1) {
+                        alpha_mode_0 = 0x381A;
+                        alpha_mode_1 = 0x381A;
+                    }
+                    else if ((req_rga->alpha_rop_mode & 3) == 2) {
+                        alpha_mode_0 = 0x381C;
+                        alpha_mode_1 = 0x381C;
+                    }
+                    else {
+                        alpha_mode_0 = 0x381A;
+                        alpha_mode_1 = 0x381A;
+                    }
+                    req->alpha_mode_0 = alpha_mode_0;
+                    req->alpha_mode_1 = alpha_mode_1;
+                    break;
+                case 4: //dst = (sc*(256-da) + 256*dc) >> 8
+                    break;
+                case 5: //dst = (da*sc) >> 8
+                    break;
+                case 6: //dst = (sa*dc) >> 8
+                    break;
+                case 7: //dst = ((256-da)*sc) >> 8
+                    break;
+                case 8: //dst = ((256-sa)*dc) >> 8
+                    break;
+                case 9: //dst = (da*sc + (256-sa)*dc) >> 8
+                    req->alpha_mode_0 = 0x3848;
+                    req->alpha_mode_1 = 0x3848;
+                    break;
+                case 10://dst = ((256-da)*sc + (sa*dc)) >> 8
+                    break;
+                case 11://dst = ((256-da)*sc + (256-sa)*dc) >> 8;
+                    break;
+		case 12:
+		    req->alpha_mode_0 = 0x0010;
+		    req->alpha_mode_1 = 0x0820;
+		    break;
+                default:
+                    break;
+            }
+        }
+        else {
+            if((req_rga->alpha_rop_mode & 3) == 0) {
+                req->alpha_mode_0 = 0x3848;
+                req->alpha_mode_1 = 0x3848;
+            }
+            else if ((req_rga->alpha_rop_mode & 3) == 1) {
 		req->alpha_mode_0 = 0x384A;
 		req->alpha_mode_1 = 0x3A4A;
-            }
-            else if ((req_rga->alpha_rop_mode & 3) == 2) {
-                req->alpha_mode_0 = 0x384C;
-                req->alpha_mode_1 = 0x384C;
-            }
-        }
-    }
-    if (req_rga->mmu_info.mmu_en && (req_rga->mmu_info.mmu_flag & 1) == 1) {
-        req->mmu_info.src0_mmu_flag = 1;
-        req->mmu_info.dst_mmu_flag = 1;
-        if (req_rga->mmu_info.mmu_flag >> 31) {
-            req->mmu_info.src0_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 8)  & 1);
-            req->mmu_info.src1_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 9)  & 1);
-            req->mmu_info.dst_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 10) & 1);
-            req->mmu_info.els_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 11) & 1);
-        }
-        else {
-            if (req_rga->src.yrgb_addr >= 0xa0000000) {
-               req->mmu_info.src0_mmu_flag = 0;
-               req->src.yrgb_addr = req_rga->src.yrgb_addr - 0x60000000;
-               req->src.uv_addr   = req_rga->src.uv_addr - 0x60000000;
-               req->src.v_addr    = req_rga->src.v_addr - 0x60000000;
-            }
-            if (req_rga->dst.yrgb_addr >= 0xa0000000) {
-               req->mmu_info.dst_mmu_flag = 0;
-               req->dst.yrgb_addr = req_rga->dst.yrgb_addr - 0x60000000;
-            }
-        }
-    }
-}
+            }
+            else if ((req_rga->alpha_rop_mode & 3) == 2) {
+                req->alpha_mode_0 = 0x384C;
+                req->alpha_mode_1 = 0x384C;
+            }
+        }
+    }
+    if (req_rga->mmu_info.mmu_en && (req_rga->mmu_info.mmu_flag & 1) == 1) {
+        req->mmu_info.src0_mmu_flag = 1;
+        req->mmu_info.dst_mmu_flag = 1;
+        if (req_rga->mmu_info.mmu_flag >> 31) {
+            req->mmu_info.src0_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 8)  & 1);
+            req->mmu_info.src1_mmu_flag = ((req_rga->mmu_info.mmu_flag >> 9)  & 1);
+            req->mmu_info.dst_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 10) & 1);
+            req->mmu_info.els_mmu_flag  = ((req_rga->mmu_info.mmu_flag >> 11) & 1);
+        }
+        else {
+            if (req_rga->src.yrgb_addr >= 0xa0000000) {
+               req->mmu_info.src0_mmu_flag = 0;
+               req->src.yrgb_addr = req_rga->src.yrgb_addr - 0x60000000;
+               req->src.uv_addr   = req_rga->src.uv_addr - 0x60000000;
+               req->src.v_addr    = req_rga->src.v_addr - 0x60000000;
+            }
+            if (req_rga->dst.yrgb_addr >= 0xa0000000) {
+               req->mmu_info.dst_mmu_flag = 0;
+               req->dst.yrgb_addr = req_rga->dst.yrgb_addr - 0x60000000;
+            }
+        }
+    }
+}
diff --git a/drivers/video/rockchip/rga2/rga2_reg_info.h b/drivers/video/rockchip/rga2/rga2_reg_info.h
index 422c96e33e7f..586603e5ca92 100644
--- a/drivers/video/rockchip/rga2/rga2_reg_info.h
+++ b/drivers/video/rockchip/rga2/rga2_reg_info.h
@@ -1,302 +1,302 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __REG2_INFO_H__
-#define __REG2_INFO_H__
-
-
-//#include "chip_register.h"
-
-//#include "rga_struct.h"
-#include "rga2.h"
-
-#ifndef MIN
-#define MIN(X, Y)           ((X)<(Y)?(X):(Y))
-#endif
-
-#ifndef MAX
-#define MAX(X, Y)           ((X)>(Y)?(X):(Y))
-#endif
-
-#ifndef ABS
-#define ABS(X)              (((X) < 0) ? (-(X)) : (X))
-#endif
-
-#ifndef CLIP
-#define CLIP(x, a,  b)				((x) < (a)) ? (a) : (((x) > (b)) ? (b) : (x))
-#endif
-
-#define rRGA_SYS_CTRL             (*(volatile u32 *)(RGA2_BASE + RGA2_SYS_CTRL_OFFSET    ))
-#define rRGA_CMD_CTRL             (*(volatile u32 *)(RGA2_BASE + RGA2_CMD_CTRL_OFFSET    ))
-#define rRGA_CMD_BASE             (*(volatile u32 *)(RGA2_BASE + RGA2_CMD_BASE_OFFSET    ))
-#define rRGA_STATUS               (*(volatile u32 *)(RGA2_BASE + RGA2_STATUS_OFFSET      ))
-#define rRGA_INT                  (*(volatile u32 *)(RGA2_BASE + RGA2_INT_OFFSET         ))
-#define rRGA_MMU_CTRL0            (*(volatile u32 *)(RGA2_BASE + RGA2_MMU_CTRL0_OFFSET   ))
-#define rRGA_MMU_CMD_BASE         (*(volatile u32 *)(RGA2_BASE + RGA2_MMU_CMD_BASE_OFFSET))
-#define rRGA_CMD_ADDR             (*(volatile u32 *)(RGA2_BASE + RGA2_CMD_ADDR))
-
-/*RGA_INT*/
-#define m_RGA2_INT_ALL_CMD_DONE_INT_EN             ( 1<<10 )
-#define m_RGA2_INT_MMU_INT_EN                      ( 1<<9  )
-#define m_RGA2_INT_ERROR_INT_EN                    ( 1<<8  )
-#define m_RGA2_INT_NOW_CMD_DONE_INT_CLEAR          ( 1<<7  )
-#define m_RGA2_INT_ALL_CMD_DONE_INT_CLEAR          ( 1<<6  )
-#define m_RGA2_INT_MMU_INT_CLEAR                   ( 1<<5  )
-#define m_RGA2_INT_ERROR_INT_CLEAR                 ( 1<<4  )
-#define m_RGA2_INT_CUR_CMD_DONE_INT_FLAG           ( 1<<3  )
-#define m_RGA2_INT_ALL_CMD_DONE_INT_FLAG           ( 1<<2  )
-#define m_RGA2_INT_MMU_INT_FLAG                    ( 1<<1  )
-#define m_RGA2_INT_ERROR_INT_FLAG                  ( 1<<0  )
-
-#define s_RGA2_INT_ALL_CMD_DONE_INT_EN(x)          ( (x&0x1)<<10 )
-#define s_RGA2_INT_MMU_INT_EN(x)                   ( (x&0x1)<<9  )
-#define s_RGA2_INT_ERROR_INT_EN(x)                 ( (x&0x1)<<8  )
-#define s_RGA2_INT_NOW_CMD_DONE_INT_CLEAR(x)       ( (x&0x1)<<7  )
-#define s_RGA2_INT_ALL_CMD_DONE_INT_CLEAR(x)       ( (x&0x1)<<6  )
-#define s_RGA2_INT_MMU_INT_CLEAR(x)                ( (x&0x1)<<5  )
-#define s_RGA2_INT_ERROR_INT_CLEAR(x)              ( (x&0x1)<<4  )
-
-
-
-/* RGA_MODE_CTRL */
-#define m_RGA2_MODE_CTRL_SW_RENDER_MODE         (  0x7<<0  )
-#define m_RGA2_MODE_CTRL_SW_BITBLT_MODE         (  0x1<<3  )
-#define m_RGA2_MODE_CTRL_SW_CF_ROP4_PAT         (  0x1<<4  )
-#define m_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET      (  0x1<<5  )
-#define m_RGA2_MODE_CTRL_SW_GRADIENT_SAT        (  0x1<<6  )
-#define m_RGA2_MODE_CTRL_SW_INTR_CF_E           (  0x1<<7  )
-
-#define s_RGA2_MODE_CTRL_SW_RENDER_MODE(x)      (  (x&0x7)<<0  )
-#define s_RGA2_MODE_CTRL_SW_BITBLT_MODE(x)      (  (x&0x1)<<3  )
-#define s_RGA2_MODE_CTRL_SW_CF_ROP4_PAT(x)      (  (x&0x1)<<4  )
-#define s_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET(x)   (  (x&0x1)<<5  )
-#define s_RGA2_MODE_CTRL_SW_GRADIENT_SAT(x)     (  (x&0x1)<<6  )
-#define s_RGA2_MODE_CTRL_SW_INTR_CF_E(x)        (  (x&0x1)<<7  )
-
-/* RGA_SRC_INFO */
-#define m_RGA2_SRC_INFO_SW_SRC_FMT                (   0xf<<0   )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP         (   0x1<<4   )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP      (   0x1<<5   )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP         (   0x1<<6   )
-#define m_RGA2_SRC_INFO_SW_SW_CP_ENDAIN           (   0x1<<7   )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE        (   0x3<<8   )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE        (   0x3<<10  )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE        (   0x3<<12  )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE       (   0x3<<14  )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE       (   0x3<<16  )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE      (   0x1<<18  )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E         (   0xf<<19  )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E     (   0x1<<23  )
-#define m_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER      (   0x3<<24  )
-#define m_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL        (   0x1<<26  )
-#define m_RGA2_SRC_INFO_SW_SW_YUV10_E             (   0x1<<27  )
-#define m_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E       (   0x1<<28  )
-
-
-
-
-
-#define s_RGA2_SRC_INFO_SW_SRC_FMT(x)                (   (x&0xf)<<0   )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP(x)         (   (x&0x1)<<4   )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP(x)      (   (x&0x1)<<5   )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP(x)         (   (x&0x1)<<6   )
-#define s_RGA2_SRC_INFO_SW_SW_CP_ENDAIN(x)           (   (x&0x1)<<7   )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(x)        (   (x&0x3)<<8   )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE(x)        (   (x&0x3)<<10  )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE(x)        (   (x&0x3)<<12  )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE(x)       (   (x&0x3)<<14  )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE(x)       (   (x&0x3)<<16  )
-
-#define s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE(x)      (   (x&0x1)<<18  )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E(x)         (   (x&0xf)<<19  )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E(x)     (   (x&0x1)<<23  )
-#define s_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER(x)      (   (x&0x3)<<24  )
-#define s_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL(x)        (   (x&0x1)<<26  )
-#define s_RGA2_SRC_INFO_SW_SW_YUV10_E(x)             (   (x&0x1)<<27  )
-#define s_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E(x)       (   (x&0x1)<<28  )
-
-/* RGA_SRC_VIR_INFO */
-#define m_RGA2_SRC_VIR_INFO_SW_SRC_VIR_STRIDE        (  0x7fff<<0  )         //modify
-#define m_RGA2_SRC_VIR_INFO_SW_MASK_VIR_STRIDE       (   0x3ff<<16 )         //modify
-
-#define s_RGA2_SRC_VIR_INFO_SW_SRC_VIR_STRIDE(x)        ( (x&0x7fff)<<0  )   //modify
-#define s_RGA2_SRC_VIR_INFO_SW_MASK_VIR_STRIDE(x)       (   (x&0x3ff)<<16 )  //modify
-
-
-/* RGA_SRC_ACT_INFO */
-#define m_RGA2_SRC_ACT_INFO_SW_SRC_ACT_WIDTH        (  0x1fff<<0  )
-#define m_RGA2_SRC_ACT_INFO_SW_SRC_ACT_HEIGHT       (  0x1fff<<16  )
-
-#define s_RGA2_SRC_ACT_INFO_SW_SRC_ACT_WIDTH(x)        (  (x&0x1fff)<<0  )
-#define s_RGA2_SRC_ACT_INFO_SW_SRC_ACT_HEIGHT(x)       (  (x&0x1fff<)<16  )
-
-
-/* RGA_DST_INFO */
-#define m_RGA2_DST_INFO_SW_DST_FMT                   (  0xf<<0 )
-#define m_RGA2_DST_INFO_SW_DST_RB_SWAP               (  0x1<<4 )
-#define m_RGA2_DST_INFO_SW_ALPHA_SWAP                (  0x1<<5 )
-#define m_RGA2_DST_INFO_SW_DST_UV_SWAP               (  0x1<<6 )
-#define m_RGA2_DST_INFO_SW_SRC1_FMT                  (  0x7<<7 )
-#define m_RGA2_DST_INFO_SW_SRC1_RB_SWP               (  0x1<<10)
-#define m_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP            (  0x1<<11)
-#define m_RGA2_DST_INFO_SW_DITHER_UP_E               (  0x1<<12)
-#define m_RGA2_DST_INFO_SW_DITHER_DOWN_E             (  0x1<<13)
-#define m_RGA2_DST_INFO_SW_DITHER_MODE               (  0x3<<14)
-#define m_RGA2_DST_INFO_SW_DST_CSC_MODE              (  0x3<<16)    //add
-#define m_RGA2_DST_INFO_SW_CSC_CLIP_MODE             (  0x1<<18)
-
-#define s_RGA2_DST_INFO_SW_DST_FMT(x)                   (  (x&0xf)<<0 )
-#define s_RGA2_DST_INFO_SW_DST_RB_SWAP(x)               (  (x&0x1)<<4 )
-#define s_RGA2_DST_INFO_SW_ALPHA_SWAP(x)                (  (x&0x1)<<5 )
-#define s_RGA2_DST_INFO_SW_DST_UV_SWAP(x)               (  (x&0x1)<<6 )
-#define s_RGA2_DST_INFO_SW_SRC1_FMT(x)                  (  (x&0x7)<<7 )
-#define s_RGA2_DST_INFO_SW_SRC1_RB_SWP(x)               (  (x&0x1)<<10)
-#define s_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP(x)            (  (x&0x1)<<11)
-#define s_RGA2_DST_INFO_SW_DITHER_UP_E(x)               (  (x&0x1)<<12)
-#define s_RGA2_DST_INFO_SW_DITHER_DOWN_E(x)             (  (x&0x1)<<13)
-#define s_RGA2_DST_INFO_SW_DITHER_MODE(x)               (  (x&0x3)<<14)
-#define s_RGA2_DST_INFO_SW_DST_CSC_MODE(x)              (  (x&0x3)<<16)    //add
-#define s_RGA2_DST_INFO_SW_CSC_CLIP_MODE(x)             (  (x&0x1)<<18)
-
-
-/* RGA_ALPHA_CTRL0 */
-#define m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0             (  0x1<<0  )
-#define m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL           (  0x1<<1  )
-#define m_RGA2_ALPHA_CTRL0_SW_ROP_MODE                (  0x3<<2  )
-#define m_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA        ( 0xff<<4  )
-#define m_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA        ( 0xff<<12 )
-#define m_RGA2_ALPHA_CTRLO_SW_MASK_ENDIAN             (  0x1<<20 )         //add
-
-#define s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0(x)             (  (x&0x1)<<0  )
-#define s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL(x)           (  (x&0x1)<<1  )
-#define s_RGA2_ALPHA_CTRL0_SW_ROP_MODE(x)                (  (x&0x3)<<2  )
-#define s_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA(x)        ( (x&0xff)<<4  )
-#define s_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA(x)        ( (x&0xff)<<12 )
-#define s_RGA2_ALPHA_CTRLO_SW_MASK_ENDIAN(x)             (  (x&0x1)<<20 )  //add
-
-
-
-/* RGA_ALPHA_CTRL1 */
-#define m_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0            ( 0x1<<0 )
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0            ( 0x1<<1 )
-#define m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0           ( 0x7<<2 )
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0           ( 0x7<<5 )
-#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0        ( 0x1<<8 )
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0        ( 0x1<<9 )
-#define m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0            ( 0x3<<10)
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0            ( 0x3<<12)
-#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0            ( 0x1<<14)
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0            ( 0x1<<15)
-#define m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1           ( 0x7<<16)
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1           ( 0x7<<19)
-#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1        ( 0x1<<22)
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1        ( 0x1<<23)
-#define m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1            ( 0x3<<24)
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1            ( 0x3<<26)
-#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1            ( 0x1<<28)
-#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1            ( 0x1<<29)
-
-#define s_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0(x)            ( (x&0x1)<<0 )
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0(x)            ( (x&0x1)<<1 )
-#define s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0(x)           ( (x&0x7)<<2 )
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0(x)           ( (x&0x7)<<5 )
-#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0(x)        ( (x&0x1)<<8 )
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0(x)        ( (x&0x1)<<9 )
-#define s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0(x)            ( (x&0x3)<<10)
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0(x)            ( (x&0x3)<<12)
-#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0(x)            ( (x&0x1)<<14)
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0(x)            ( (x&0x1)<<15)
-#define s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1(x)           ( (x&0x7)<<16)
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1(x)           ( (x&0x7)<<19)
-#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1(x)        ( (x&0x1)<<22)
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1(x)        ( (x&0x1)<<23)
-#define s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1(x)            ( (x&0x3)<<24)
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1(x)            ( (x&0x3)<<26)
-#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1(x)            ( (x&0x1)<<28)
-#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1(x)            ( (x&0x1)<<29)
-
-
-
-/* RGA_MMU_CTRL1 */
-#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_EN                  (  0x1<<0 )
-#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_FLUSH               (  0x1<<1 )
-#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_EN         (  0x1<<2 )
-#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_DIR        (  0x1<<3 )
-#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_EN                 (  0x1<<4 )
-#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_FLUSH              (  0x1<<5 )
-#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_EN        (  0x1<<6 )
-#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_DIR       (  0x1<<7 )
-#define m_RGA2_MMU_CTRL1_SW_DST_MMU_EN                  (  0x1<<8 )
-#define m_RGA2_MMU_CTRL1_SW_DST_MMU_FLUSH               (  0x1<<9 )
-#define m_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_EN         (  0x1<<10 )
-#define m_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_DIR        (  0x1<<11 )
-#define m_RGA2_MMU_CTRL1_SW_ELS_MMU_EN                  (  0x1<<12 )
-#define m_RGA2_MMU_CTRL1_SW_ELS_MMU_FLUSH               (  0x1<<13 )
-
-#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_EN(x)                  (  (x&0x1)<<0 )
-#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_FLUSH(x)               (  (x&0x1)<<1 )
-#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_EN(x)         (  (x&0x1)<<2 )
-#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_DIR(x)        (  (x&0x1)<<3 )
-#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_EN(x)                 (  (x&0x1)<<4 )
-#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_FLUSH(x)              (  (x&0x1)<<5 )
-#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_EN(x)        (  (x&0x1)<<6 )
-#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_DIR(x)       (  (x&0x1)<<7 )
-#define s_RGA2_MMU_CTRL1_SW_DST_MMU_EN(x)                  (  (x&0x1)<<8 )
-#define s_RGA2_MMU_CTRL1_SW_DST_MMU_FLUSH(x)               (  (x&0x1)<<9 )
-#define s_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_EN(x)         (  (x&0x1)<<10 )
-#define s_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_DIR(x)        (  (x&0x1)<<11 )
-#define s_RGA2_MMU_CTRL1_SW_ELS_MMU_EN(x)                  (  (x&0x1)<<12 )
-#define s_RGA2_MMU_CTRL1_SW_ELS_MMU_FLUSH(x)               (  (x&0x1)<<13 )
-
-
-#define RGA2_SYS_CTRL_OFFSET             0x0
-#define RGA2_CMD_CTRL_OFFSET             0x4
-#define RGA2_CMD_BASE_OFFSET             0x8
-#define RGA2_STATUS_OFFSET               0xc
-#define RGA2_INT_OFFSET                  0x10
-#define RGA2_MMU_CTRL0_OFFSET            0x14
-#define RGA2_MMU_CMD_BASE_OFFSET         0x18
-
-#define RGA2_MODE_CTRL_OFFSET                   0x00
-#define RGA2_SRC_INFO_OFFSET                    0x04
-#define RGA2_SRC_BASE0_OFFSET                   0x08
-#define RGA2_SRC_BASE1_OFFSET                   0x0c
-#define RGA2_SRC_BASE2_OFFSET                   0x10
-#define RGA2_SRC_BASE3_OFFSET                   0x14
-#define RGA2_SRC_VIR_INFO_OFFSET                0x18
-#define RGA2_SRC_ACT_INFO_OFFSET                0x1c
-#define RGA2_SRC_X_FACTOR_OFFSET                0x20
-#define RGA2_SRC_Y_FACTOR_OFFSET                0x24
-#define RGA2_SRC_BG_COLOR_OFFSET                0x28
-#define RGA2_SRC_FG_COLOR_OFFSET                0x2c
-#define RGA2_SRC_TR_COLOR0_OFFSET               0x30
-#define RGA2_CF_GR_A_OFFSET                     0x30 // repeat
-#define RGA2_SRC_TR_COLOR1_OFFSET               0x34
-#define RGA2_CF_GR_B_OFFSET                     0x34 // repeat
-#define RGA2_DST_INFO_OFFSET                    0x38
-#define RGA2_DST_BASE0_OFFSET                   0x3c
-#define RGA2_DST_BASE1_OFFSET                   0x40
-#define RGA2_DST_BASE2_OFFSET                   0x44
-#define RGA2_DST_VIR_INFO_OFFSET                0x48
-#define RGA2_DST_ACT_INFO_OFFSET                0x4c
-#define RGA2_ALPHA_CTRL0_OFFSET                 0x50
-#define RGA2_ALPHA_CTRL1_OFFSET                 0x54
-#define RGA2_FADING_CTRL_OFFSET                 0x58
-#define RGA2_PAT_CON_OFFSET                     0x5c
-#define RGA2_ROP_CTRL0_OFFSET                   0x60
-#define RGA2_CF_GR_G_OFFSET                     0x60 // repeat
-#define RGA2_ROP_CTRL1_OFFSET                   0x64
-#define RGA2_CF_GR_R_OFFSET                     0x64 // repeat
-#define RGA2_MASK_BASE_OFFSET                   0x68
-#define RGA2_MMU_CTRL1_OFFSET                   0x6c
-#define RGA2_MMU_SRC_BASE_OFFSET                0x70
-#define RGA2_MMU_SRC1_BASE_OFFSET               0x74
-#define RGA2_MMU_DST_BASE_OFFSET                0x78
-#define RGA2_MMU_ELS_BASE_OFFSET                0x7c
-
-int RGA2_gen_reg_info(unsigned char *base, struct rga2_req *msg);
-void RGA_MSG_2_RGA2_MSG(struct rga_req *req_rga, struct rga2_req *req);
-void RGA_MSG_2_RGA2_MSG_32(struct rga_req_32 *req_rga, struct rga2_req *req);
-
-
-
-#endif
-
+#ifndef __REG2_INFO_H__
+#define __REG2_INFO_H__
+
+
+//#include "chip_register.h"
+
+//#include "rga_struct.h"
+#include "rga2.h"
+
+#ifndef MIN
+#define MIN(X, Y)           ((X)<(Y)?(X):(Y))
+#endif
+
+#ifndef MAX
+#define MAX(X, Y)           ((X)>(Y)?(X):(Y))
+#endif
+
+#ifndef ABS
+#define ABS(X)              (((X) < 0) ? (-(X)) : (X))
+#endif
+
+#ifndef CLIP
+#define CLIP(x, a,  b)				((x) < (a)) ? (a) : (((x) > (b)) ? (b) : (x))
+#endif
+
+#define rRGA_SYS_CTRL             (*(volatile u32 *)(RGA2_BASE + RGA2_SYS_CTRL_OFFSET    ))
+#define rRGA_CMD_CTRL             (*(volatile u32 *)(RGA2_BASE + RGA2_CMD_CTRL_OFFSET    ))
+#define rRGA_CMD_BASE             (*(volatile u32 *)(RGA2_BASE + RGA2_CMD_BASE_OFFSET    ))
+#define rRGA_STATUS               (*(volatile u32 *)(RGA2_BASE + RGA2_STATUS_OFFSET      ))
+#define rRGA_INT                  (*(volatile u32 *)(RGA2_BASE + RGA2_INT_OFFSET         ))
+#define rRGA_MMU_CTRL0            (*(volatile u32 *)(RGA2_BASE + RGA2_MMU_CTRL0_OFFSET   ))
+#define rRGA_MMU_CMD_BASE         (*(volatile u32 *)(RGA2_BASE + RGA2_MMU_CMD_BASE_OFFSET))
+#define rRGA_CMD_ADDR             (*(volatile u32 *)(RGA2_BASE + RGA2_CMD_ADDR))
+
+/*RGA_INT*/
+#define m_RGA2_INT_ALL_CMD_DONE_INT_EN             ( 1<<10 )
+#define m_RGA2_INT_MMU_INT_EN                      ( 1<<9  )
+#define m_RGA2_INT_ERROR_INT_EN                    ( 1<<8  )
+#define m_RGA2_INT_NOW_CMD_DONE_INT_CLEAR          ( 1<<7  )
+#define m_RGA2_INT_ALL_CMD_DONE_INT_CLEAR          ( 1<<6  )
+#define m_RGA2_INT_MMU_INT_CLEAR                   ( 1<<5  )
+#define m_RGA2_INT_ERROR_INT_CLEAR                 ( 1<<4  )
+#define m_RGA2_INT_CUR_CMD_DONE_INT_FLAG           ( 1<<3  )
+#define m_RGA2_INT_ALL_CMD_DONE_INT_FLAG           ( 1<<2  )
+#define m_RGA2_INT_MMU_INT_FLAG                    ( 1<<1  )
+#define m_RGA2_INT_ERROR_INT_FLAG                  ( 1<<0  )
+
+#define s_RGA2_INT_ALL_CMD_DONE_INT_EN(x)          ( (x&0x1)<<10 )
+#define s_RGA2_INT_MMU_INT_EN(x)                   ( (x&0x1)<<9  )
+#define s_RGA2_INT_ERROR_INT_EN(x)                 ( (x&0x1)<<8  )
+#define s_RGA2_INT_NOW_CMD_DONE_INT_CLEAR(x)       ( (x&0x1)<<7  )
+#define s_RGA2_INT_ALL_CMD_DONE_INT_CLEAR(x)       ( (x&0x1)<<6  )
+#define s_RGA2_INT_MMU_INT_CLEAR(x)                ( (x&0x1)<<5  )
+#define s_RGA2_INT_ERROR_INT_CLEAR(x)              ( (x&0x1)<<4  )
+
+
+
+/* RGA_MODE_CTRL */
+#define m_RGA2_MODE_CTRL_SW_RENDER_MODE         (  0x7<<0  )
+#define m_RGA2_MODE_CTRL_SW_BITBLT_MODE         (  0x1<<3  )
+#define m_RGA2_MODE_CTRL_SW_CF_ROP4_PAT         (  0x1<<4  )
+#define m_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET      (  0x1<<5  )
+#define m_RGA2_MODE_CTRL_SW_GRADIENT_SAT        (  0x1<<6  )
+#define m_RGA2_MODE_CTRL_SW_INTR_CF_E           (  0x1<<7  )
+
+#define s_RGA2_MODE_CTRL_SW_RENDER_MODE(x)      (  (x&0x7)<<0  )
+#define s_RGA2_MODE_CTRL_SW_BITBLT_MODE(x)      (  (x&0x1)<<3  )
+#define s_RGA2_MODE_CTRL_SW_CF_ROP4_PAT(x)      (  (x&0x1)<<4  )
+#define s_RGA2_MODE_CTRL_SW_ALPHA_ZERO_KET(x)   (  (x&0x1)<<5  )
+#define s_RGA2_MODE_CTRL_SW_GRADIENT_SAT(x)     (  (x&0x1)<<6  )
+#define s_RGA2_MODE_CTRL_SW_INTR_CF_E(x)        (  (x&0x1)<<7  )
+
+/* RGA_SRC_INFO */
+#define m_RGA2_SRC_INFO_SW_SRC_FMT                (   0xf<<0   )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP         (   0x1<<4   )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP      (   0x1<<5   )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP         (   0x1<<6   )
+#define m_RGA2_SRC_INFO_SW_SW_CP_ENDAIN           (   0x1<<7   )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE        (   0x3<<8   )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE        (   0x3<<10  )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE        (   0x3<<12  )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE       (   0x3<<14  )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE       (   0x3<<16  )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE      (   0x1<<18  )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E         (   0xf<<19  )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E     (   0x1<<23  )
+#define m_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER      (   0x3<<24  )
+#define m_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL        (   0x1<<26  )
+#define m_RGA2_SRC_INFO_SW_SW_YUV10_E             (   0x1<<27  )
+#define m_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E       (   0x1<<28  )
+
+
+
+
+
+#define s_RGA2_SRC_INFO_SW_SRC_FMT(x)                (   (x&0xf)<<0   )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_RB_SWAP(x)         (   (x&0x1)<<4   )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_ALPHA_SWAP(x)      (   (x&0x1)<<5   )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_UV_SWAP(x)         (   (x&0x1)<<6   )
+#define s_RGA2_SRC_INFO_SW_SW_CP_ENDAIN(x)           (   (x&0x1)<<7   )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_CSC_MODE(x)        (   (x&0x3)<<8   )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_ROT_MODE(x)        (   (x&0x3)<<10  )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_MIR_MODE(x)        (   (x&0x3)<<12  )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_HSCL_MODE(x)       (   (x&0x3)<<14  )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_VSCL_MODE(x)       (   (x&0x3)<<16  )
+
+#define s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_MODE(x)      (   (x&0x1)<<18  )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_TRANS_E(x)         (   (x&0xf)<<19  )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_DITHER_UP_E(x)     (   (x&0x1)<<23  )
+#define s_RGA2_SRC_INFO_SW_SW_SRC_SCL_FILTER(x)      (   (x&0x3)<<24  )
+#define s_RGA2_SRC_INFO_SW_SW_VSP_MODE_SEL(x)        (   (x&0x1)<<26  )
+#define s_RGA2_SRC_INFO_SW_SW_YUV10_E(x)             (   (x&0x1)<<27  )
+#define s_RGA2_SRC_INFO_SW_SW_YUV10_ROUND_E(x)       (   (x&0x1)<<28  )
+
+/* RGA_SRC_VIR_INFO */
+#define m_RGA2_SRC_VIR_INFO_SW_SRC_VIR_STRIDE        (  0x7fff<<0  )         //modify
+#define m_RGA2_SRC_VIR_INFO_SW_MASK_VIR_STRIDE       (   0x3ff<<16 )         //modify
+
+#define s_RGA2_SRC_VIR_INFO_SW_SRC_VIR_STRIDE(x)        ( (x&0x7fff)<<0  )   //modify
+#define s_RGA2_SRC_VIR_INFO_SW_MASK_VIR_STRIDE(x)       (   (x&0x3ff)<<16 )  //modify
+
+
+/* RGA_SRC_ACT_INFO */
+#define m_RGA2_SRC_ACT_INFO_SW_SRC_ACT_WIDTH        (  0x1fff<<0  )
+#define m_RGA2_SRC_ACT_INFO_SW_SRC_ACT_HEIGHT       (  0x1fff<<16  )
+
+#define s_RGA2_SRC_ACT_INFO_SW_SRC_ACT_WIDTH(x)        (  (x&0x1fff)<<0  )
+#define s_RGA2_SRC_ACT_INFO_SW_SRC_ACT_HEIGHT(x)       (  (x&0x1fff<)<16  )
+
+
+/* RGA_DST_INFO */
+#define m_RGA2_DST_INFO_SW_DST_FMT                   (  0xf<<0 )
+#define m_RGA2_DST_INFO_SW_DST_RB_SWAP               (  0x1<<4 )
+#define m_RGA2_DST_INFO_SW_ALPHA_SWAP                (  0x1<<5 )
+#define m_RGA2_DST_INFO_SW_DST_UV_SWAP               (  0x1<<6 )
+#define m_RGA2_DST_INFO_SW_SRC1_FMT                  (  0x7<<7 )
+#define m_RGA2_DST_INFO_SW_SRC1_RB_SWP               (  0x1<<10)
+#define m_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP            (  0x1<<11)
+#define m_RGA2_DST_INFO_SW_DITHER_UP_E               (  0x1<<12)
+#define m_RGA2_DST_INFO_SW_DITHER_DOWN_E             (  0x1<<13)
+#define m_RGA2_DST_INFO_SW_DITHER_MODE               (  0x3<<14)
+#define m_RGA2_DST_INFO_SW_DST_CSC_MODE              (  0x3<<16)    //add
+#define m_RGA2_DST_INFO_SW_CSC_CLIP_MODE             (  0x1<<18)
+
+#define s_RGA2_DST_INFO_SW_DST_FMT(x)                   (  (x&0xf)<<0 )
+#define s_RGA2_DST_INFO_SW_DST_RB_SWAP(x)               (  (x&0x1)<<4 )
+#define s_RGA2_DST_INFO_SW_ALPHA_SWAP(x)                (  (x&0x1)<<5 )
+#define s_RGA2_DST_INFO_SW_DST_UV_SWAP(x)               (  (x&0x1)<<6 )
+#define s_RGA2_DST_INFO_SW_SRC1_FMT(x)                  (  (x&0x7)<<7 )
+#define s_RGA2_DST_INFO_SW_SRC1_RB_SWP(x)               (  (x&0x1)<<10)
+#define s_RGA2_DST_INFO_SW_SRC1_ALPHA_SWP(x)            (  (x&0x1)<<11)
+#define s_RGA2_DST_INFO_SW_DITHER_UP_E(x)               (  (x&0x1)<<12)
+#define s_RGA2_DST_INFO_SW_DITHER_DOWN_E(x)             (  (x&0x1)<<13)
+#define s_RGA2_DST_INFO_SW_DITHER_MODE(x)               (  (x&0x3)<<14)
+#define s_RGA2_DST_INFO_SW_DST_CSC_MODE(x)              (  (x&0x3)<<16)    //add
+#define s_RGA2_DST_INFO_SW_CSC_CLIP_MODE(x)             (  (x&0x1)<<18)
+
+
+/* RGA_ALPHA_CTRL0 */
+#define m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0             (  0x1<<0  )
+#define m_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL           (  0x1<<1  )
+#define m_RGA2_ALPHA_CTRL0_SW_ROP_MODE                (  0x3<<2  )
+#define m_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA        ( 0xff<<4  )
+#define m_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA        ( 0xff<<12 )
+#define m_RGA2_ALPHA_CTRLO_SW_MASK_ENDIAN             (  0x1<<20 )         //add
+
+#define s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_0(x)             (  (x&0x1)<<0  )
+#define s_RGA2_ALPHA_CTRL0_SW_ALPHA_ROP_SEL(x)           (  (x&0x1)<<1  )
+#define s_RGA2_ALPHA_CTRL0_SW_ROP_MODE(x)                (  (x&0x3)<<2  )
+#define s_RGA2_ALPHA_CTRL0_SW_SRC_GLOBAL_ALPHA(x)        ( (x&0xff)<<4  )
+#define s_RGA2_ALPHA_CTRL0_SW_DST_GLOBAL_ALPHA(x)        ( (x&0xff)<<12 )
+#define s_RGA2_ALPHA_CTRLO_SW_MASK_ENDIAN(x)             (  (x&0x1)<<20 )  //add
+
+
+
+/* RGA_ALPHA_CTRL1 */
+#define m_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0            ( 0x1<<0 )
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0            ( 0x1<<1 )
+#define m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0           ( 0x7<<2 )
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0           ( 0x7<<5 )
+#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0        ( 0x1<<8 )
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0        ( 0x1<<9 )
+#define m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0            ( 0x3<<10)
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0            ( 0x3<<12)
+#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0            ( 0x1<<14)
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0            ( 0x1<<15)
+#define m_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1           ( 0x7<<16)
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1           ( 0x7<<19)
+#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1        ( 0x1<<22)
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1        ( 0x1<<23)
+#define m_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1            ( 0x3<<24)
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1            ( 0x3<<26)
+#define m_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1            ( 0x1<<28)
+#define m_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1            ( 0x1<<29)
+
+#define s_RGA2_ALPHA_CTRL1_SW_DST_COLOR_M0(x)            ( (x&0x1)<<0 )
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_COLOR_M0(x)            ( (x&0x1)<<1 )
+#define s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M0(x)           ( (x&0x7)<<2 )
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M0(x)           ( (x&0x7)<<5 )
+#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M0(x)        ( (x&0x1)<<8 )
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M0(x)        ( (x&0x1)<<9 )
+#define s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M0(x)            ( (x&0x3)<<10)
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M0(x)            ( (x&0x3)<<12)
+#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M0(x)            ( (x&0x1)<<14)
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M0(x)            ( (x&0x1)<<15)
+#define s_RGA2_ALPHA_CTRL1_SW_DST_FACTOR_M1(x)           ( (x&0x7)<<16)
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_FACTOR_M1(x)           ( (x&0x7)<<19)
+#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_CAL_M1(x)        ( (x&0x1)<<22)
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_CAL_M1(x)        ( (x&0x1)<<23)
+#define s_RGA2_ALPHA_CTRL1_SW_DST_BLEND_M1(x)            ( (x&0x3)<<24)
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_BLEND_M1(x)            ( (x&0x3)<<26)
+#define s_RGA2_ALPHA_CTRL1_SW_DST_ALPHA_M1(x)            ( (x&0x1)<<28)
+#define s_RGA2_ALPHA_CTRL1_SW_SRC_ALPHA_M1(x)            ( (x&0x1)<<29)
+
+
+
+/* RGA_MMU_CTRL1 */
+#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_EN                  (  0x1<<0 )
+#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_FLUSH               (  0x1<<1 )
+#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_EN         (  0x1<<2 )
+#define m_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_DIR        (  0x1<<3 )
+#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_EN                 (  0x1<<4 )
+#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_FLUSH              (  0x1<<5 )
+#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_EN        (  0x1<<6 )
+#define m_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_DIR       (  0x1<<7 )
+#define m_RGA2_MMU_CTRL1_SW_DST_MMU_EN                  (  0x1<<8 )
+#define m_RGA2_MMU_CTRL1_SW_DST_MMU_FLUSH               (  0x1<<9 )
+#define m_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_EN         (  0x1<<10 )
+#define m_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_DIR        (  0x1<<11 )
+#define m_RGA2_MMU_CTRL1_SW_ELS_MMU_EN                  (  0x1<<12 )
+#define m_RGA2_MMU_CTRL1_SW_ELS_MMU_FLUSH               (  0x1<<13 )
+
+#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_EN(x)                  (  (x&0x1)<<0 )
+#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_FLUSH(x)               (  (x&0x1)<<1 )
+#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_EN(x)         (  (x&0x1)<<2 )
+#define s_RGA2_MMU_CTRL1_SW_SRC_MMU_PREFETCH_DIR(x)        (  (x&0x1)<<3 )
+#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_EN(x)                 (  (x&0x1)<<4 )
+#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_FLUSH(x)              (  (x&0x1)<<5 )
+#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_EN(x)        (  (x&0x1)<<6 )
+#define s_RGA2_MMU_CTRL1_SW_SRC1_MMU_PREFETCH_DIR(x)       (  (x&0x1)<<7 )
+#define s_RGA2_MMU_CTRL1_SW_DST_MMU_EN(x)                  (  (x&0x1)<<8 )
+#define s_RGA2_MMU_CTRL1_SW_DST_MMU_FLUSH(x)               (  (x&0x1)<<9 )
+#define s_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_EN(x)         (  (x&0x1)<<10 )
+#define s_RGA2_MMU_CTRL1_SW_DST_MMU_PREFETCH_DIR(x)        (  (x&0x1)<<11 )
+#define s_RGA2_MMU_CTRL1_SW_ELS_MMU_EN(x)                  (  (x&0x1)<<12 )
+#define s_RGA2_MMU_CTRL1_SW_ELS_MMU_FLUSH(x)               (  (x&0x1)<<13 )
+
+
+#define RGA2_SYS_CTRL_OFFSET             0x0
+#define RGA2_CMD_CTRL_OFFSET             0x4
+#define RGA2_CMD_BASE_OFFSET             0x8
+#define RGA2_STATUS_OFFSET               0xc
+#define RGA2_INT_OFFSET                  0x10
+#define RGA2_MMU_CTRL0_OFFSET            0x14
+#define RGA2_MMU_CMD_BASE_OFFSET         0x18
+
+#define RGA2_MODE_CTRL_OFFSET                   0x00
+#define RGA2_SRC_INFO_OFFSET                    0x04
+#define RGA2_SRC_BASE0_OFFSET                   0x08
+#define RGA2_SRC_BASE1_OFFSET                   0x0c
+#define RGA2_SRC_BASE2_OFFSET                   0x10
+#define RGA2_SRC_BASE3_OFFSET                   0x14
+#define RGA2_SRC_VIR_INFO_OFFSET                0x18
+#define RGA2_SRC_ACT_INFO_OFFSET                0x1c
+#define RGA2_SRC_X_FACTOR_OFFSET                0x20
+#define RGA2_SRC_Y_FACTOR_OFFSET                0x24
+#define RGA2_SRC_BG_COLOR_OFFSET                0x28
+#define RGA2_SRC_FG_COLOR_OFFSET                0x2c
+#define RGA2_SRC_TR_COLOR0_OFFSET               0x30
+#define RGA2_CF_GR_A_OFFSET                     0x30 // repeat
+#define RGA2_SRC_TR_COLOR1_OFFSET               0x34
+#define RGA2_CF_GR_B_OFFSET                     0x34 // repeat
+#define RGA2_DST_INFO_OFFSET                    0x38
+#define RGA2_DST_BASE0_OFFSET                   0x3c
+#define RGA2_DST_BASE1_OFFSET                   0x40
+#define RGA2_DST_BASE2_OFFSET                   0x44
+#define RGA2_DST_VIR_INFO_OFFSET                0x48
+#define RGA2_DST_ACT_INFO_OFFSET                0x4c
+#define RGA2_ALPHA_CTRL0_OFFSET                 0x50
+#define RGA2_ALPHA_CTRL1_OFFSET                 0x54
+#define RGA2_FADING_CTRL_OFFSET                 0x58
+#define RGA2_PAT_CON_OFFSET                     0x5c
+#define RGA2_ROP_CTRL0_OFFSET                   0x60
+#define RGA2_CF_GR_G_OFFSET                     0x60 // repeat
+#define RGA2_ROP_CTRL1_OFFSET                   0x64
+#define RGA2_CF_GR_R_OFFSET                     0x64 // repeat
+#define RGA2_MASK_BASE_OFFSET                   0x68
+#define RGA2_MMU_CTRL1_OFFSET                   0x6c
+#define RGA2_MMU_SRC_BASE_OFFSET                0x70
+#define RGA2_MMU_SRC1_BASE_OFFSET               0x74
+#define RGA2_MMU_DST_BASE_OFFSET                0x78
+#define RGA2_MMU_ELS_BASE_OFFSET                0x7c
+
+int RGA2_gen_reg_info(unsigned char *base, struct rga2_req *msg);
+void RGA_MSG_2_RGA2_MSG(struct rga_req *req_rga, struct rga2_req *req);
+void RGA_MSG_2_RGA2_MSG_32(struct rga_req_32 *req_rga, struct rga2_req *req);
+
+
+
+#endif
+
diff --git a/drivers/video/rockchip/rga2/rga2_type.h b/drivers/video/rockchip/rga2/rga2_type.h
index ce3610ab9b67..30f5df2f38e5 100644
--- a/drivers/video/rockchip/rga2/rga2_type.h
+++ b/drivers/video/rockchip/rga2/rga2_type.h
@@ -1,49 +1,49 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __RGA_TYPE_H__
-#define __RGA_TYPE_H__
-
-
-#ifdef __cplusplus
-#if __cplusplus
-}
-#endif
-#endif /* __cplusplus */
-
-typedef  unsigned int     UWORD32;
-typedef  unsigned int     uint32;
-typedef  unsigned int     RK_U32;
-
-typedef  unsigned short   UWORD16;
-typedef  unsigned short   RK_U16;
-
-typedef  unsigned char    UBYTE;
-typedef  unsigned char    RK_U8;
-
-typedef  int              WORD32;
-typedef  int              RK_S32;
-
-typedef  short            WORD16;
-typedef  short            RK_S16;
-
-typedef  char             BYTE;
-typedef  char             RK_S8;
-
-
-#ifndef NULL
-#define NULL              0L
-#endif
-
-#ifndef TRUE
-#define TRUE              1L
-#endif
-
-
-#ifdef __cplusplus
-#if __cplusplus
-}
-#endif
-#endif /* __cplusplus */
-
-
-#endif /* __RGA_TYPR_H__ */
-
+#ifndef __RGA_TYPE_H__
+#define __RGA_TYPE_H__
+
+
+#ifdef __cplusplus
+#if __cplusplus
+}
+#endif
+#endif /* __cplusplus */
+
+typedef  unsigned int     UWORD32;
+typedef  unsigned int     uint32;
+typedef  unsigned int     RK_U32;
+
+typedef  unsigned short   UWORD16;
+typedef  unsigned short   RK_U16;
+
+typedef  unsigned char    UBYTE;
+typedef  unsigned char    RK_U8;
+
+typedef  int              WORD32;
+typedef  int              RK_S32;
+
+typedef  short            WORD16;
+typedef  short            RK_S16;
+
+typedef  char             BYTE;
+typedef  char             RK_S8;
+
+
+#ifndef NULL
+#define NULL              0L
+#endif
+
+#ifndef TRUE
+#define TRUE              1L
+#endif
+
+
+#ifdef __cplusplus
+#if __cplusplus
+}
+#endif
+#endif /* __cplusplus */
+
+
+#endif /* __RGA_TYPR_H__ */
+

commit 3e12c17be45b1862bbed7663b1f9539c7bb77c41
Author: Jos矇 Roberto de Souza <jose.souza@intel.com>
Date:   Wed Oct 10 17:44:39 2018 -0700

    UPSTREAM: drm: Do not call drm_dp_cec_set_edid() while registering DP connectors
    
    drm_dp_cec_register_connector() is called when registering each DP
    connector in DRM, while sounds a good idea register CEC adapters as
    earlier as possible, it causes some driver initialization delay
    trying to do DPCD transactions in disconnected connectors.
    
    This change will cause no regressions as drm_dp_cec_set_edid() will
    still be called in further detection of connected connectors with a
    valid edid parameter.
    
    This change reduced the module load of i915 by average 0.5sec in a
    machine with just one DP port disconnected while reducing more than
    3sec in a machine with 4 DP ports disconnected.
    
    Cc: Hans Verkuil <hans.verkuil@cisco.com>
    Signed-off-by: Jos矇 Roberto de Souza <jose.souza@intel.com>
    Acked-by: Hans Verkuil <hans.verkuil@cisco.com>
    Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
    Link: https://patchwork.freedesktop.org/patch/msgid/20181011004439.4482-1-jose.souza@intel.com
    (cherry picked from commit 7323001549804be70b179a8b636f78e758aeb28d)
    
    Change-Id: I815948f733719705bbc576fc1ca723fb5a59fe6b
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/drivers/gpu/drm/drm_dp_cec.c b/drivers/gpu/drm/drm_dp_cec.c
index 8a718f85079a..b15cee85b702 100644
--- a/drivers/gpu/drm/drm_dp_cec.c
+++ b/drivers/gpu/drm/drm_dp_cec.c
@@ -424,8 +424,6 @@ void drm_dp_cec_register_connector(struct drm_dp_aux *aux, const char *name,
 	aux->cec.parent = parent;
 	INIT_DELAYED_WORK(&aux->cec.unregister_work,
 			  drm_dp_cec_unregister_work);
-
-	drm_dp_cec_set_edid(aux, NULL);
 }
 EXPORT_SYMBOL(drm_dp_cec_register_connector);
 

commit 349e07ffdfc1b33f14a81ac8d8f1524726210f4e
Author: Hans Verkuil <hans.verkuil@cisco.com>
Date:   Mon Aug 27 09:58:17 2018 +0200

    UPSTREAM: drm_dp_cec: add note about good MegaChips 2900 CEC support
    
    A big problem with DP CEC-Tunneling-over-AUX is that it is tricky
    to find adapters with a chipset that supports this AND where the
    manufacturer actually connected the HDMI CEC line to the chipset.
    
    Add a mention of the MegaChips 2900 chipset which seems to support
    this feature well.
    
    Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
    Reviewed-by: Lyude Paul <lyude@redhat.com>
    Acked-by: Alex Deucher <alexander.deucher@amd.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/20180827075820.41109-3-hverkuil@xs4all.nl
    (cherry picked from commit 9bcf6d9868ae95fc7e5eda3dae5200f234ea5623)
    
    Change-Id: Idd9a225357a5b3bbb14287cc1f5b13630d0bd449
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/drivers/gpu/drm/drm_dp_cec.c b/drivers/gpu/drm/drm_dp_cec.c
index 1407b13a8d5d..8a718f85079a 100644
--- a/drivers/gpu/drm/drm_dp_cec.c
+++ b/drivers/gpu/drm/drm_dp_cec.c
@@ -16,7 +16,9 @@
  * here. Quite a few active (mini-)DP-to-HDMI or USB-C-to-HDMI adapters
  * have a converter chip that supports CEC-Tunneling-over-AUX (usually the
  * Parade PS176), but they do not wire up the CEC pin, thus making CEC
- * useless.
+ * useless. Note that MegaChips 2900-based adapters appear to have good
+ * support for CEC tunneling. Those adapters that I have tested using
+ * this chipset all have the CEC line connected.
  *
  * Sadly there is no way for this driver to know this. What happens is
  * that a /dev/cecX device is created that is isolated and unable to see

commit 51b3852a7f552e813980a757c5262f2b5bf8348f
Author: Hans Verkuil <hans.verkuil@cisco.com>
Date:   Mon Aug 27 09:58:16 2018 +0200

    UPSTREAM: drm_dp_cec: check that aux has a transfer function
    
    If aux->transfer == NULL, then just return without doing
    anything. In that case the function is likely called for
    a non-(e)DP connector.
    
    This never happened for the i915 driver, but the nouveau and amdgpu
    drivers need this check.
    
    The alternative would be to add this check in those drivers before
    every drm_dp_cec call, but it makes sense to check it in the
    drm_dp_cec functions to prevent a kernel oops.
    
    Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
    Reviewed-by: Lyude Paul <lyude@redhat.com>
    Acked-by: Alex Deucher <alexander.deucher@amd.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/20180827075820.41109-2-hverkuil@xs4all.nl
    (cherry picked from commit 5ce70c799ac22c142061c71aaeae518f04283472)
    
    Change-Id: I8a56122cc777e17c2b303120372f7087a94c5083
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/drivers/gpu/drm/drm_dp_cec.c b/drivers/gpu/drm/drm_dp_cec.c
index 988513346e9c..1407b13a8d5d 100644
--- a/drivers/gpu/drm/drm_dp_cec.c
+++ b/drivers/gpu/drm/drm_dp_cec.c
@@ -238,6 +238,10 @@ void drm_dp_cec_irq(struct drm_dp_aux *aux)
 	u8 cec_irq;
 	int ret;
 
+	/* No transfer function was set, so not a DP connector */
+	if (!aux->transfer)
+		return;
+
 	mutex_lock(&aux->cec.lock);
 	if (!aux->cec.adap)
 		goto unlock;
@@ -293,6 +297,10 @@ void drm_dp_cec_set_edid(struct drm_dp_aux *aux, const struct edid *edid)
 	unsigned int num_las = 1;
 	u8 cap;
 
+	/* No transfer function was set, so not a DP connector */
+	if (!aux->transfer)
+		return;
+
 #ifndef CONFIG_MEDIA_CEC_RC
 	/*
 	 * CEC_CAP_RC is part of CEC_CAP_DEFAULTS, but it is stripped by
@@ -361,6 +369,10 @@ EXPORT_SYMBOL(drm_dp_cec_set_edid);
  */
 void drm_dp_cec_unset_edid(struct drm_dp_aux *aux)
 {
+	/* No transfer function was set, so not a DP connector */
+	if (!aux->transfer)
+		return;
+
 	cancel_delayed_work_sync(&aux->cec.unregister_work);
 
 	mutex_lock(&aux->cec.lock);
@@ -404,6 +416,8 @@ void drm_dp_cec_register_connector(struct drm_dp_aux *aux, const char *name,
 				   struct device *parent)
 {
 	WARN_ON(aux->cec.adap);
+	if (WARN_ON(!aux->transfer))
+		return;
 	aux->cec.name = name;
 	aux->cec.parent = parent;
 	INIT_DELAYED_WORK(&aux->cec.unregister_work,

commit d18dae4b02dbd27d3383d05804516ea14fffaafa
Author: Hans Verkuil <hverkuil@xs4all.nl>
Date:   Tue Jul 24 21:20:28 2018 +0200

    UPSTREAM: drm_dp_cec.c: fix formatting typo: %pdH -> %phD
    
    This caused a kernel oops since %pdH interpreted the pointer
    as a struct file.
    
    Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
    Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/f3720ddf-ec0f-cd22-46b6-720a5e2098f2@xs4all.nl
    (cherry picked from commit ea5569ecd6b81232eb536017b627c417befc1acb)
    
    Change-Id: I9780212b39185e8b87b74d0216538378f16baf58
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/drivers/gpu/drm/drm_dp_cec.c b/drivers/gpu/drm/drm_dp_cec.c
index ddb1c5adebb9..988513346e9c 100644
--- a/drivers/gpu/drm/drm_dp_cec.c
+++ b/drivers/gpu/drm/drm_dp_cec.c
@@ -157,7 +157,7 @@ static void drm_dp_cec_adap_status(struct cec_adapter *adap,
 
 	if (drm_dp_read_desc(aux, &desc, true))
 		return;
-	seq_printf(file, "OUI: %*pdH\n",
+	seq_printf(file, "OUI: %*phD\n",
 		   (int)sizeof(id->oui), id->oui);
 	seq_printf(file, "ID: %*pE\n",
 		   (int)strnlen(id->device_id, sizeof(id->device_id)),

commit 883524f8fbd0f5d24b4dc3324fa013b214e148f9
Author: Hans Verkuil <hans.verkuil@cisco.com>
Date:   Wed Jul 11 15:29:07 2018 +0200

    UPSTREAM: drm: add support for DisplayPort CEC-Tunneling-over-AUX
    
    This adds support for the DisplayPort CEC-Tunneling-over-AUX
    feature that is part of the DisplayPort 1.3 standard.
    
    Unfortunately, not all DisplayPort/USB-C to HDMI adapters with a
    chip that has this capability actually hook up the CEC pin, so
    even though a CEC device is created, it may not actually work.
    
    Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
    Reviewed-by: Ville Syrj瓣l瓣 <ville.syrjala@linux.intel.com>
    Signed-off-by: Ville Syrj瓣l瓣 <ville.syrjala@linux.intel.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/20180711132909.25409-2-hverkuil@xs4all.nl
    (cherry picked from commit 2c6d1fffa1d9b0a5b5ac1a23be9ad64abe60910d)
    
    Conflicts:
            drivers/gpu/drm/Makefile
            drivers/gpu/drm/drm_dp_helper.c
            include/drm/drm_dp_helper.h
    
    Change-Id: I63df93f87cc521c148b6a999de9459577680a4f6
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
index bc44ea5105fe..9f1219ee6bca 100644
--- a/drivers/gpu/drm/Kconfig
+++ b/drivers/gpu/drm/Kconfig
@@ -77,6 +77,16 @@ config DRM_LOAD_EDID_FIRMWARE
 	  default case is N. Details and instructions how to build your own
 	  EDID data are given in Documentation/EDID/HOWTO.txt.
 
+config DRM_DP_CEC
+	bool "Enable DisplayPort CEC-Tunneling-over-AUX HDMI support"
+	select CEC_CORE
+	help
+	  Choose this option if you want to enable HDMI CEC support for
+	  DisplayPort/USB-C to HDMI adapters.
+
+	  Note: not all adapters support this feature, and even for those
+	  that do support this they often do not hook up the CEC pin.
+
 config DRM_TTM
 	tristate
 	depends on DRM
diff --git a/drivers/gpu/drm/Makefile b/drivers/gpu/drm/Makefile
index 319356ffdf76..9e5268a0100d 100644
--- a/drivers/gpu/drm/Makefile
+++ b/drivers/gpu/drm/Makefile
@@ -29,6 +29,7 @@ drm_kms_helper-y := drm_crtc_helper.o drm_dp_helper.o drm_probe_helper.o \
 drm_kms_helper-$(CONFIG_DRM_LOAD_EDID_FIRMWARE) += drm_edid_load.o
 drm_kms_helper-$(CONFIG_DRM_FBDEV_EMULATION) += drm_fb_helper.o
 drm_kms_helper-$(CONFIG_DRM_KMS_CMA_HELPER) += drm_fb_cma_helper.o
+drm_kms_helper-$(CONFIG_DRM_DP_CEC) += drm_dp_cec.o
 
 obj-$(CONFIG_DRM_KMS_HELPER) += drm_kms_helper.o
 
diff --git a/drivers/gpu/drm/drm_dp_cec.c b/drivers/gpu/drm/drm_dp_cec.c
new file mode 100644
index 000000000000..ddb1c5adebb9
--- /dev/null
+++ b/drivers/gpu/drm/drm_dp_cec.c
@@ -0,0 +1,428 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * DisplayPort CEC-Tunneling-over-AUX support
+ *
+ * Copyright 2018 Cisco Systems, Inc. and/or its affiliates. All rights reserved.
+ */
+
+#include <linux/kernel.h>
+#include <linux/module.h>
+#include <linux/slab.h>
+#include <drm/drm_dp_helper.h>
+#include <media/cec.h>
+
+/*
+ * Unfortunately it turns out that we have a chicken-and-egg situation
+ * here. Quite a few active (mini-)DP-to-HDMI or USB-C-to-HDMI adapters
+ * have a converter chip that supports CEC-Tunneling-over-AUX (usually the
+ * Parade PS176), but they do not wire up the CEC pin, thus making CEC
+ * useless.
+ *
+ * Sadly there is no way for this driver to know this. What happens is
+ * that a /dev/cecX device is created that is isolated and unable to see
+ * any of the other CEC devices. Quite literally the CEC wire is cut
+ * (or in this case, never connected in the first place).
+ *
+ * The reason so few adapters support this is that this tunneling protocol
+ * was never supported by any OS. So there was no easy way of testing it,
+ * and no incentive to correctly wire up the CEC pin.
+ *
+ * Hopefully by creating this driver it will be easier for vendors to
+ * finally fix their adapters and test the CEC functionality.
+ *
+ * I keep a list of known working adapters here:
+ *
+ * https://hverkuil.home.xs4all.nl/cec-status.txt
+ *
+ * Please mail me (hverkuil@xs4all.nl) if you find an adapter that works
+ * and is not yet listed there.
+ *
+ * Note that the current implementation does not support CEC over an MST hub.
+ * As far as I can see there is no mechanism defined in the DisplayPort
+ * standard to transport CEC interrupts over an MST device. It might be
+ * possible to do this through polling, but I have not been able to get that
+ * to work.
+ */
+
+/**
+ * DOC: dp cec helpers
+ *
+ * These functions take care of supporting the CEC-Tunneling-over-AUX
+ * feature of DisplayPort-to-HDMI adapters.
+ */
+
+/*
+ * When the EDID is unset because the HPD went low, then the CEC DPCD registers
+ * typically can no longer be read (true for a DP-to-HDMI adapter since it is
+ * powered by the HPD). However, some displays toggle the HPD off and on for a
+ * short period for one reason or another, and that would cause the CEC adapter
+ * to be removed and added again, even though nothing else changed.
+ *
+ * This module parameter sets a delay in seconds before the CEC adapter is
+ * actually unregistered. Only if the HPD does not return within that time will
+ * the CEC adapter be unregistered.
+ *
+ * If it is set to a value >= NEVER_UNREG_DELAY, then the CEC adapter will never
+ * be unregistered for as long as the connector remains registered.
+ *
+ * If it is set to 0, then the CEC adapter will be unregistered immediately as
+ * soon as the HPD disappears.
+ *
+ * The default is one second to prevent short HPD glitches from unregistering
+ * the CEC adapter.
+ *
+ * Note that for integrated HDMI branch devices that support CEC the DPCD
+ * registers remain available even if the HPD goes low since it is not powered
+ * by the HPD. In that case the CEC adapter will never be unregistered during
+ * the life time of the connector. At least, this is the theory since I do not
+ * have hardware with an integrated HDMI branch device that supports CEC.
+ */
+#define NEVER_UNREG_DELAY 1000
+static unsigned int drm_dp_cec_unregister_delay = 1;
+module_param(drm_dp_cec_unregister_delay, uint, 0600);
+MODULE_PARM_DESC(drm_dp_cec_unregister_delay,
+		 "CEC unregister delay in seconds, 0: no delay, >= 1000: never unregister");
+
+static int drm_dp_cec_adap_enable(struct cec_adapter *adap, bool enable)
+{
+	struct drm_dp_aux *aux = cec_get_drvdata(adap);
+	u32 val = enable ? DP_CEC_TUNNELING_ENABLE : 0;
+	ssize_t err = 0;
+
+	err = drm_dp_dpcd_writeb(aux, DP_CEC_TUNNELING_CONTROL, val);
+	return (enable && err < 0) ? err : 0;
+}
+
+static int drm_dp_cec_adap_log_addr(struct cec_adapter *adap, u8 addr)
+{
+	struct drm_dp_aux *aux = cec_get_drvdata(adap);
+	/* Bit 15 (logical address 15) should always be set */
+	u16 la_mask = 1 << CEC_LOG_ADDR_BROADCAST;
+	u8 mask[2];
+	ssize_t err;
+
+	if (addr != CEC_LOG_ADDR_INVALID)
+		la_mask |= adap->log_addrs.log_addr_mask | (1 << addr);
+	mask[0] = la_mask & 0xff;
+	mask[1] = la_mask >> 8;
+	err = drm_dp_dpcd_write(aux, DP_CEC_LOGICAL_ADDRESS_MASK, mask, 2);
+	return (addr != CEC_LOG_ADDR_INVALID && err < 0) ? err : 0;
+}
+
+static int drm_dp_cec_adap_transmit(struct cec_adapter *adap, u8 attempts,
+				    u32 signal_free_time, struct cec_msg *msg)
+{
+	struct drm_dp_aux *aux = cec_get_drvdata(adap);
+	unsigned int retries = min(5, attempts - 1);
+	ssize_t err;
+
+	err = drm_dp_dpcd_write(aux, DP_CEC_TX_MESSAGE_BUFFER,
+				msg->msg, msg->len);
+	if (err < 0)
+		return err;
+
+	err = drm_dp_dpcd_writeb(aux, DP_CEC_TX_MESSAGE_INFO,
+				 (msg->len - 1) | (retries << 4) |
+				 DP_CEC_TX_MESSAGE_SEND);
+	return err < 0 ? err : 0;
+}
+
+static int drm_dp_cec_adap_monitor_all_enable(struct cec_adapter *adap,
+					      bool enable)
+{
+	struct drm_dp_aux *aux = cec_get_drvdata(adap);
+	ssize_t err;
+	u8 val;
+
+	if (!(adap->capabilities & CEC_CAP_MONITOR_ALL))
+		return 0;
+
+	err = drm_dp_dpcd_readb(aux, DP_CEC_TUNNELING_CONTROL, &val);
+	if (err >= 0) {
+		if (enable)
+			val |= DP_CEC_SNOOPING_ENABLE;
+		else
+			val &= ~DP_CEC_SNOOPING_ENABLE;
+		err = drm_dp_dpcd_writeb(aux, DP_CEC_TUNNELING_CONTROL, val);
+	}
+	return (enable && err < 0) ? err : 0;
+}
+
+static void drm_dp_cec_adap_status(struct cec_adapter *adap,
+				   struct seq_file *file)
+{
+	struct drm_dp_aux *aux = cec_get_drvdata(adap);
+	struct drm_dp_desc desc;
+	struct drm_dp_dpcd_ident *id = &desc.ident;
+
+	if (drm_dp_read_desc(aux, &desc, true))
+		return;
+	seq_printf(file, "OUI: %*pdH\n",
+		   (int)sizeof(id->oui), id->oui);
+	seq_printf(file, "ID: %*pE\n",
+		   (int)strnlen(id->device_id, sizeof(id->device_id)),
+		   id->device_id);
+	seq_printf(file, "HW Rev: %d.%d\n", id->hw_rev >> 4, id->hw_rev & 0xf);
+	/*
+	 * Show this both in decimal and hex: at least one vendor
+	 * always reports this in hex.
+	 */
+	seq_printf(file, "FW/SW Rev: %d.%d (0x%02x.0x%02x)\n",
+		   id->sw_major_rev, id->sw_minor_rev,
+		   id->sw_major_rev, id->sw_minor_rev);
+}
+
+static const struct cec_adap_ops drm_dp_cec_adap_ops = {
+	.adap_enable = drm_dp_cec_adap_enable,
+	.adap_log_addr = drm_dp_cec_adap_log_addr,
+	.adap_transmit = drm_dp_cec_adap_transmit,
+	.adap_monitor_all_enable = drm_dp_cec_adap_monitor_all_enable,
+	.adap_status = drm_dp_cec_adap_status,
+};
+
+static int drm_dp_cec_received(struct drm_dp_aux *aux)
+{
+	struct cec_adapter *adap = aux->cec.adap;
+	struct cec_msg msg;
+	u8 rx_msg_info;
+	ssize_t err;
+
+	err = drm_dp_dpcd_readb(aux, DP_CEC_RX_MESSAGE_INFO, &rx_msg_info);
+	if (err < 0)
+		return err;
+
+	if (!(rx_msg_info & DP_CEC_RX_MESSAGE_ENDED))
+		return 0;
+
+	msg.len = (rx_msg_info & DP_CEC_RX_MESSAGE_LEN_MASK) + 1;
+	err = drm_dp_dpcd_read(aux, DP_CEC_RX_MESSAGE_BUFFER, msg.msg, msg.len);
+	if (err < 0)
+		return err;
+
+	cec_received_msg(adap, &msg);
+	return 0;
+}
+
+static void drm_dp_cec_handle_irq(struct drm_dp_aux *aux)
+{
+	struct cec_adapter *adap = aux->cec.adap;
+	u8 flags;
+
+	if (drm_dp_dpcd_readb(aux, DP_CEC_TUNNELING_IRQ_FLAGS, &flags) < 0)
+		return;
+
+	if (flags & DP_CEC_RX_MESSAGE_INFO_VALID)
+		drm_dp_cec_received(aux);
+
+	if (flags & DP_CEC_TX_MESSAGE_SENT)
+		cec_transmit_attempt_done(adap, CEC_TX_STATUS_OK);
+	else if (flags & DP_CEC_TX_LINE_ERROR)
+		cec_transmit_attempt_done(adap, CEC_TX_STATUS_ERROR |
+						CEC_TX_STATUS_MAX_RETRIES);
+	else if (flags &
+		 (DP_CEC_TX_ADDRESS_NACK_ERROR | DP_CEC_TX_DATA_NACK_ERROR))
+		cec_transmit_attempt_done(adap, CEC_TX_STATUS_NACK |
+						CEC_TX_STATUS_MAX_RETRIES);
+	drm_dp_dpcd_writeb(aux, DP_CEC_TUNNELING_IRQ_FLAGS, flags);
+}
+
+/**
+ * drm_dp_cec_irq() - handle CEC interrupt, if any
+ * @aux: DisplayPort AUX channel
+ *
+ * Should be called when handling an IRQ_HPD request. If CEC-tunneling-over-AUX
+ * is present, then it will check for a CEC_IRQ and handle it accordingly.
+ */
+void drm_dp_cec_irq(struct drm_dp_aux *aux)
+{
+	u8 cec_irq;
+	int ret;
+
+	mutex_lock(&aux->cec.lock);
+	if (!aux->cec.adap)
+		goto unlock;
+
+	ret = drm_dp_dpcd_readb(aux, DP_DEVICE_SERVICE_IRQ_VECTOR_ESI1,
+				&cec_irq);
+	if (ret < 0 || !(cec_irq & DP_CEC_IRQ))
+		goto unlock;
+
+	drm_dp_cec_handle_irq(aux);
+	drm_dp_dpcd_writeb(aux, DP_DEVICE_SERVICE_IRQ_VECTOR_ESI1, DP_CEC_IRQ);
+unlock:
+	mutex_unlock(&aux->cec.lock);
+}
+EXPORT_SYMBOL(drm_dp_cec_irq);
+
+static bool drm_dp_cec_cap(struct drm_dp_aux *aux, u8 *cec_cap)
+{
+	u8 cap = 0;
+
+	if (drm_dp_dpcd_readb(aux, DP_CEC_TUNNELING_CAPABILITY, &cap) != 1 ||
+	    !(cap & DP_CEC_TUNNELING_CAPABLE))
+		return false;
+	if (cec_cap)
+		*cec_cap = cap;
+	return true;
+}
+
+/*
+ * Called if the HPD was low for more than drm_dp_cec_unregister_delay
+ * seconds. This unregisters the CEC adapter.
+ */
+static void drm_dp_cec_unregister_work(struct work_struct *work)
+{
+	struct drm_dp_aux *aux = container_of(work, struct drm_dp_aux,
+					      cec.unregister_work.work);
+
+	mutex_lock(&aux->cec.lock);
+	cec_unregister_adapter(aux->cec.adap);
+	aux->cec.adap = NULL;
+	mutex_unlock(&aux->cec.lock);
+}
+
+/*
+ * A new EDID is set. If there is no CEC adapter, then create one. If
+ * there was a CEC adapter, then check if the CEC adapter properties
+ * were unchanged and just update the CEC physical address. Otherwise
+ * unregister the old CEC adapter and create a new one.
+ */
+void drm_dp_cec_set_edid(struct drm_dp_aux *aux, const struct edid *edid)
+{
+	u32 cec_caps = CEC_CAP_DEFAULTS | CEC_CAP_NEEDS_HPD;
+	unsigned int num_las = 1;
+	u8 cap;
+
+#ifndef CONFIG_MEDIA_CEC_RC
+	/*
+	 * CEC_CAP_RC is part of CEC_CAP_DEFAULTS, but it is stripped by
+	 * cec_allocate_adapter() if CONFIG_MEDIA_CEC_RC is undefined.
+	 *
+	 * Do this here as well to ensure the tests against cec_caps are
+	 * correct.
+	 */
+	cec_caps &= ~CEC_CAP_RC;
+#endif
+	cancel_delayed_work_sync(&aux->cec.unregister_work);
+
+	mutex_lock(&aux->cec.lock);
+	if (!drm_dp_cec_cap(aux, &cap)) {
+		/* CEC is not supported, unregister any existing adapter */
+		cec_unregister_adapter(aux->cec.adap);
+		aux->cec.adap = NULL;
+		goto unlock;
+	}
+
+	if (cap & DP_CEC_SNOOPING_CAPABLE)
+		cec_caps |= CEC_CAP_MONITOR_ALL;
+	if (cap & DP_CEC_MULTIPLE_LA_CAPABLE)
+		num_las = CEC_MAX_LOG_ADDRS;
+
+	if (aux->cec.adap) {
+		if (aux->cec.adap->capabilities == cec_caps &&
+		    aux->cec.adap->available_log_addrs == num_las) {
+			/* Unchanged, so just set the phys addr */
+			cec_s_phys_addr_from_edid(aux->cec.adap, edid);
+			goto unlock;
+		}
+		/*
+		 * The capabilities changed, so unregister the old
+		 * adapter first.
+		 */
+		cec_unregister_adapter(aux->cec.adap);
+	}
+
+	/* Create a new adapter */
+	aux->cec.adap = cec_allocate_adapter(&drm_dp_cec_adap_ops,
+					     aux, aux->cec.name, cec_caps,
+					     num_las);
+	if (IS_ERR(aux->cec.adap)) {
+		aux->cec.adap = NULL;
+		goto unlock;
+	}
+	if (cec_register_adapter(aux->cec.adap, aux->cec.parent)) {
+		cec_delete_adapter(aux->cec.adap);
+		aux->cec.adap = NULL;
+	} else {
+		/*
+		 * Update the phys addr for the new CEC adapter. When called
+		 * from drm_dp_cec_register_connector() edid == NULL, so in
+		 * that case the phys addr is just invalidated.
+		 */
+		cec_s_phys_addr_from_edid(aux->cec.adap, edid);
+	}
+unlock:
+	mutex_unlock(&aux->cec.lock);
+}
+EXPORT_SYMBOL(drm_dp_cec_set_edid);
+
+/*
+ * The EDID disappeared (likely because of the HPD going down).
+ */
+void drm_dp_cec_unset_edid(struct drm_dp_aux *aux)
+{
+	cancel_delayed_work_sync(&aux->cec.unregister_work);
+
+	mutex_lock(&aux->cec.lock);
+	if (!aux->cec.adap)
+		goto unlock;
+
+	cec_phys_addr_invalidate(aux->cec.adap);
+	/*
+	 * We're done if we want to keep the CEC device
+	 * (drm_dp_cec_unregister_delay is >= NEVER_UNREG_DELAY) or if the
+	 * DPCD still indicates the CEC capability (expected for an integrated
+	 * HDMI branch device).
+	 */
+	if (drm_dp_cec_unregister_delay < NEVER_UNREG_DELAY &&
+	    !drm_dp_cec_cap(aux, NULL)) {
+		/*
+		 * Unregister the CEC adapter after drm_dp_cec_unregister_delay
+		 * seconds. This to debounce short HPD off-and-on cycles from
+		 * displays.
+		 */
+		schedule_delayed_work(&aux->cec.unregister_work,
+				      drm_dp_cec_unregister_delay * HZ);
+	}
+unlock:
+	mutex_unlock(&aux->cec.lock);
+}
+EXPORT_SYMBOL(drm_dp_cec_unset_edid);
+
+/**
+ * drm_dp_cec_register_connector() - register a new connector
+ * @aux: DisplayPort AUX channel
+ * @name: name of the CEC device
+ * @parent: parent device
+ *
+ * A new connector was registered with associated CEC adapter name and
+ * CEC adapter parent device. After registering the name and parent
+ * drm_dp_cec_set_edid() is called to check if the connector supports
+ * CEC and to register a CEC adapter if that is the case.
+ */
+void drm_dp_cec_register_connector(struct drm_dp_aux *aux, const char *name,
+				   struct device *parent)
+{
+	WARN_ON(aux->cec.adap);
+	aux->cec.name = name;
+	aux->cec.parent = parent;
+	INIT_DELAYED_WORK(&aux->cec.unregister_work,
+			  drm_dp_cec_unregister_work);
+
+	drm_dp_cec_set_edid(aux, NULL);
+}
+EXPORT_SYMBOL(drm_dp_cec_register_connector);
+
+/**
+ * drm_dp_cec_unregister_connector() - unregister the CEC adapter, if any
+ * @aux: DisplayPort AUX channel
+ */
+void drm_dp_cec_unregister_connector(struct drm_dp_aux *aux)
+{
+	if (!aux->cec.adap)
+		return;
+	cancel_delayed_work_sync(&aux->cec.unregister_work);
+	cec_unregister_adapter(aux->cec.adap);
+	aux->cec.adap = NULL;
+}
+EXPORT_SYMBOL(drm_dp_cec_unregister_connector);
diff --git a/drivers/gpu/drm/drm_dp_helper.c b/drivers/gpu/drm/drm_dp_helper.c
index ae5f99dc0433..7331cea1c687 100644
--- a/drivers/gpu/drm/drm_dp_helper.c
+++ b/drivers/gpu/drm/drm_dp_helper.c
@@ -762,6 +762,7 @@ static const struct i2c_algorithm drm_dp_i2c_algo = {
 int drm_dp_aux_register(struct drm_dp_aux *aux)
 {
 	mutex_init(&aux->hw_mutex);
+	mutex_init(&aux->cec.lock);
 
 	aux->ddc.algo = &drm_dp_i2c_algo;
 	aux->ddc.algo_data = aux;
diff --git a/include/drm/drm_dp_helper.h b/include/drm/drm_dp_helper.h
index 961c8fa5ffba..f59218734d12 100644
--- a/include/drm/drm_dp_helper.h
+++ b/include/drm/drm_dp_helper.h
@@ -743,6 +743,25 @@ struct drm_dp_aux_msg {
 	size_t size;
 };
 
+struct cec_adapter;
+struct edid;
+
+/**
+ * struct drm_dp_aux_cec - DisplayPort CEC-Tunneling-over-AUX
+ * @lock: mutex protecting this struct
+ * @adap: the CEC adapter for CEC-Tunneling-over-AUX support.
+ * @name: name of the CEC adapter
+ * @parent: parent device of the CEC adapter
+ * @unregister_work: unregister the CEC adapter
+ */
+struct drm_dp_aux_cec {
+	struct mutex lock;
+	struct cec_adapter *adap;
+	const char *name;
+	struct device *parent;
+	struct delayed_work unregister_work;
+};
+
 /**
  * struct drm_dp_aux - DisplayPort AUX channel
  * @name: user-visible name of this AUX channel and the I2C-over-AUX adapter
@@ -789,7 +808,18 @@ struct drm_dp_aux {
 	struct mutex hw_mutex;
 	ssize_t (*transfer)(struct drm_dp_aux *aux,
 			    struct drm_dp_aux_msg *msg);
-	unsigned i2c_nack_count, i2c_defer_count;
+	/**
+	 * @i2c_nack_count: Counts I2C NACKs, used for DP validation.
+	 */
+	unsigned i2c_nack_count;
+	/**
+	 * @i2c_defer_count: Counts I2C DEFERs, used for DP validation.
+	 */
+	unsigned i2c_defer_count;
+	/**
+	 * @cec: struct containing fields used for CEC-Tunneling-over-AUX.
+	 */
+	struct drm_dp_aux_cec cec;
 };
 
 ssize_t drm_dp_dpcd_read(struct drm_dp_aux *aux, unsigned int offset,
@@ -901,4 +931,37 @@ drm_dp_has_quirk(const struct drm_dp_desc *desc, enum drm_dp_quirk quirk)
 	return desc->quirks & BIT(quirk);
 }
 
+#ifdef CONFIG_DRM_DP_CEC
+void drm_dp_cec_irq(struct drm_dp_aux *aux);
+void drm_dp_cec_register_connector(struct drm_dp_aux *aux, const char *name,
+				   struct device *parent);
+void drm_dp_cec_unregister_connector(struct drm_dp_aux *aux);
+void drm_dp_cec_set_edid(struct drm_dp_aux *aux, const struct edid *edid);
+void drm_dp_cec_unset_edid(struct drm_dp_aux *aux);
+#else
+static inline void drm_dp_cec_irq(struct drm_dp_aux *aux)
+{
+}
+
+static inline void drm_dp_cec_register_connector(struct drm_dp_aux *aux,
+						 const char *name,
+						 struct device *parent)
+{
+}
+
+static inline void drm_dp_cec_unregister_connector(struct drm_dp_aux *aux)
+{
+}
+
+static inline void drm_dp_cec_set_edid(struct drm_dp_aux *aux,
+				       const struct edid *edid)
+{
+}
+
+static inline void drm_dp_cec_unset_edid(struct drm_dp_aux *aux)
+{
+}
+
+#endif
+
 #endif /* _DRM_DP_HELPER_H_ */

commit 4b24894a731689f713545b5278a74777ff627553
Author: Jani Nikula <jani.nikula@intel.com>
Date:   Thu May 18 14:10:24 2017 +0300

    UPSTREAM: drm/dp: start a DPCD based DP sink/branch device quirk database
    
    Face the fact, there are Display Port sink and branch devices out there
    in the wild that don't follow the Display Port specifications, or they
    have bugs, or just otherwise require special treatment. Start a common
    quirk database the drivers can query based on the DP device
    identification. At least for now, we leave the workarounds for the
    drivers to implement as they see fit.
    
    For starters, add a branch device that can't handle full 24-bit main
    link Mdiv and Ndiv main link attributes properly. Naturally, the
    workaround of reducing main link attributes for all devices ended up in
    regressions for other devices. So here we are.
    
    v2: Rebase on DRM DP desc read helpers
    
    v3: Fix the OUI memcmp blunder (Clint)
    
    Cc: Ville Syrj瓣l瓣 <ville.syrjala@linux.intel.com>
    Cc: Dhinakaran Pandiyan <dhinakaran.pandiyan@intel.com>
    Cc: Clint Taylor <clinton.a.taylor@intel.com>
    Cc: Adam Jackson <ajax@redhat.com>
    Cc: Harry Wentland <harry.wentland@amd.com>
    Tested-by: Clinton Taylor <clinton.a.taylor@intel.com>
    Reviewed-by: Clinton Taylor <clinton.a.taylor@intel.com>
    Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch> # v2
    Signed-off-by: Jani Nikula <jani.nikula@intel.com>
    Link: http://patchwork.freedesktop.org/patch/msgid/91ec198dd95258dbf3bee2f6be739e0da73b4fdd.1495105635.git.jani.nikula@intel.com
    (cherry picked from commit 76fa998acd86b6b40d0217e12af39c2406bdcd2b)
    
    Conflicts:
            drivers/gpu/drm/drm_dp_helper.c
    
    Change-Id: Ic51b5355c7bd1a8d81689755ebd8d14f74bb67ce
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/drivers/gpu/drm/drm_dp_helper.c b/drivers/gpu/drm/drm_dp_helper.c
index b709d5618638..ae5f99dc0433 100644
--- a/drivers/gpu/drm/drm_dp_helper.c
+++ b/drivers/gpu/drm/drm_dp_helper.c
@@ -789,6 +789,51 @@ void drm_dp_aux_unregister(struct drm_dp_aux *aux)
 }
 EXPORT_SYMBOL(drm_dp_aux_unregister);
 
+struct dpcd_quirk {
+	u8 oui[3];
+	bool is_branch;
+	u32 quirks;
+};
+
+#define OUI(first, second, third) { (first), (second), (third) }
+
+static const struct dpcd_quirk dpcd_quirk_list[] = {
+	/* Analogix 7737 needs reduced M and N at HBR2 link rates */
+	{ OUI(0x00, 0x22, 0xb9), true, BIT(DP_DPCD_QUIRK_LIMITED_M_N) },
+};
+
+#undef OUI
+
+/*
+ * Get a bit mask of DPCD quirks for the sink/branch device identified by
+ * ident. The quirk data is shared but it's up to the drivers to act on the
+ * data.
+ *
+ * For now, only the OUI (first three bytes) is used, but this may be extended
+ * to device identification string and hardware/firmware revisions later.
+ */
+static u32
+drm_dp_get_quirks(const struct drm_dp_dpcd_ident *ident, bool is_branch)
+{
+	const struct dpcd_quirk *quirk;
+	u32 quirks = 0;
+	int i;
+
+	for (i = 0; i < ARRAY_SIZE(dpcd_quirk_list); i++) {
+		quirk = &dpcd_quirk_list[i];
+
+		if (quirk->is_branch != is_branch)
+			continue;
+
+		if (memcmp(quirk->oui, ident->oui, sizeof(ident->oui)) != 0)
+			continue;
+
+		quirks |= quirk->quirks;
+	}
+
+	return quirks;
+}
+
 /**
  * drm_dp_read_desc - read sink/branch descriptor from DPCD
  * @aux: DisplayPort AUX channel
@@ -811,14 +856,17 @@ int drm_dp_read_desc(struct drm_dp_aux *aux, struct drm_dp_desc *desc,
 	if (ret < 0)
 		return ret;
 
+	desc->quirks = drm_dp_get_quirks(ident, is_branch);
+
 	dev_id_len = strnlen(ident->device_id, sizeof(ident->device_id));
 
-	DRM_DEBUG_KMS("DP %s: OUI %*phD dev-ID %*pE HW-rev %d.%d SW-rev %d.%d\n",
+	DRM_DEBUG_KMS("DP %s: OUI %*phD dev-ID %*pE HW-rev %d.%d SW-rev %d.%d quirks 0x%04x\n",
 		      is_branch ? "branch" : "sink",
 		      (int)sizeof(ident->oui), ident->oui,
 		      dev_id_len, ident->device_id,
 		      ident->hw_rev >> 4, ident->hw_rev & 0xf,
-		      ident->sw_major_rev, ident->sw_minor_rev);
+		      ident->sw_major_rev, ident->sw_minor_rev,
+		      desc->quirks);
 
 	return 0;
 }
diff --git a/include/drm/drm_dp_helper.h b/include/drm/drm_dp_helper.h
index f0823c6b1952..961c8fa5ffba 100644
--- a/include/drm/drm_dp_helper.h
+++ b/include/drm/drm_dp_helper.h
@@ -861,12 +861,44 @@ struct drm_dp_dpcd_ident {
 /**
  * struct drm_dp_desc - DP branch/sink device descriptor
  * @ident: DP device identification from DPCD 0x400 (sink) or 0x500 (branch).
+ * @quirks: Quirks; use drm_dp_has_quirk() to query for the quirks.
  */
 struct drm_dp_desc {
 	struct drm_dp_dpcd_ident ident;
+	u32 quirks;
 };
 
 int drm_dp_read_desc(struct drm_dp_aux *aux, struct drm_dp_desc *desc,
 		     bool is_branch);
 
+/**
+ * enum drm_dp_quirk - Display Port sink/branch device specific quirks
+ *
+ * Display Port sink and branch devices in the wild have a variety of bugs, try
+ * to collect them here. The quirks are shared, but it's up to the drivers to
+ * implement workarounds for them.
+ */
+enum drm_dp_quirk {
+	/**
+	 * @DP_DPCD_QUIRK_LIMITED_M_N:
+	 *
+	 * The device requires main link attributes Mvid and Nvid to be limited
+	 * to 16 bits.
+	 */
+	DP_DPCD_QUIRK_LIMITED_M_N,
+};
+
+/**
+ * drm_dp_has_quirk() - does the DP device have a specific quirk
+ * @desc: Device decriptor filled by drm_dp_read_desc()
+ * @quirk: Quirk to query for
+ *
+ * Return true if DP device identified by @desc has @quirk.
+ */
+static inline bool
+drm_dp_has_quirk(const struct drm_dp_desc *desc, enum drm_dp_quirk quirk)
+{
+	return desc->quirks & BIT(quirk);
+}
+
 #endif /* _DRM_DP_HELPER_H_ */

commit dd630b568adf7a1eeafeb9edcf6ef701b93a1a73
Author: Jani Nikula <jani.nikula@intel.com>
Date:   Thu May 18 14:10:22 2017 +0300

    UPSTREAM: drm/dp: add helper for reading DP sink/branch device desc from DPCD
    
    Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
    Signed-off-by: Jani Nikula <jani.nikula@intel.com>
    Link: http://patchwork.freedesktop.org/patch/msgid/acba54da7d80eafea9e59a893e27e3c31028c0ba.1495105635.git.jani.nikula@intel.com
    (cherry picked from commit 118b90f3f18e733c99f0e8b98ea31a815ffc4d14)
    
    Conflicts:
            drivers/gpu/drm/drm_dp_helper.c
            include/drm/drm_dp_helper.h
    
    Change-Id: I963d96c824c086035cdbdd6ffc0f2ca4d64967e1
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/drivers/gpu/drm/drm_dp_helper.c b/drivers/gpu/drm/drm_dp_helper.c
index 7e5a97204051..b709d5618638 100644
--- a/drivers/gpu/drm/drm_dp_helper.c
+++ b/drivers/gpu/drm/drm_dp_helper.c
@@ -788,3 +788,38 @@ void drm_dp_aux_unregister(struct drm_dp_aux *aux)
 	i2c_del_adapter(&aux->ddc);
 }
 EXPORT_SYMBOL(drm_dp_aux_unregister);
+
+/**
+ * drm_dp_read_desc - read sink/branch descriptor from DPCD
+ * @aux: DisplayPort AUX channel
+ * @desc: Device decriptor to fill from DPCD
+ * @is_branch: true for branch devices, false for sink devices
+ *
+ * Read DPCD 0x400 (sink) or 0x500 (branch) into @desc. Also debug log the
+ * identification.
+ *
+ * Returns 0 on success or a negative error code on failure.
+ */
+int drm_dp_read_desc(struct drm_dp_aux *aux, struct drm_dp_desc *desc,
+		     bool is_branch)
+{
+	struct drm_dp_dpcd_ident *ident = &desc->ident;
+	unsigned int offset = is_branch ? DP_BRANCH_OUI : DP_SINK_OUI;
+	int ret, dev_id_len;
+
+	ret = drm_dp_dpcd_read(aux, offset, ident, sizeof(*ident));
+	if (ret < 0)
+		return ret;
+
+	dev_id_len = strnlen(ident->device_id, sizeof(ident->device_id));
+
+	DRM_DEBUG_KMS("DP %s: OUI %*phD dev-ID %*pE HW-rev %d.%d SW-rev %d.%d\n",
+		      is_branch ? "branch" : "sink",
+		      (int)sizeof(ident->oui), ident->oui,
+		      dev_id_len, ident->device_id,
+		      ident->hw_rev >> 4, ident->hw_rev & 0xf,
+		      ident->sw_major_rev, ident->sw_minor_rev);
+
+	return 0;
+}
+EXPORT_SYMBOL(drm_dp_read_desc);
diff --git a/include/drm/drm_dp_helper.h b/include/drm/drm_dp_helper.h
index a91c32a997eb..f0823c6b1952 100644
--- a/include/drm/drm_dp_helper.h
+++ b/include/drm/drm_dp_helper.h
@@ -850,4 +850,23 @@ int drm_dp_link_configure(struct drm_dp_aux *aux, struct drm_dp_link *link);
 int drm_dp_aux_register(struct drm_dp_aux *aux);
 void drm_dp_aux_unregister(struct drm_dp_aux *aux);
 
+struct drm_dp_dpcd_ident {
+	u8 oui[3];
+	u8 device_id[6];
+	u8 hw_rev;
+	u8 sw_major_rev;
+	u8 sw_minor_rev;
+} __packed;
+
+/**
+ * struct drm_dp_desc - DP branch/sink device descriptor
+ * @ident: DP device identification from DPCD 0x400 (sink) or 0x500 (branch).
+ */
+struct drm_dp_desc {
+	struct drm_dp_dpcd_ident ident;
+};
+
+int drm_dp_read_desc(struct drm_dp_aux *aux, struct drm_dp_desc *desc,
+		     bool is_branch);
+
 #endif /* _DRM_DP_HELPER_H_ */

commit 224c96067dec2e59578b496fccf77b8c32ff4189
Author: Hans Verkuil <hans.verkuil@cisco.com>
Date:   Fri Aug 4 06:41:51 2017 -0400

    UPSTREAM: media: media/cec.h: add CEC_CAP_DEFAULTS
    
    The CEC_CAP_LOG_ADDRS, CEC_CAP_TRANSMIT, CEC_CAP_PASSTHROUGH and
    CEC_CAP_RC capabilities are normally always present.
    
    Add a CEC_CAP_DEFAULTS define that ORs these four caps to simplify
    drivers.
    
    Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
    Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
    (cherry picked from commit ee0c503eacfb97e1d443baf5a03939201d0244f5)
    
    Change-Id: Ic3221f5c676f2159dbe65115e38dfae5a8b6712e
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/include/media/cec.h b/include/media/cec.h
index 940776f91742..f4a05206f1f1 100644
--- a/include/media/cec.h
+++ b/include/media/cec.h
@@ -31,6 +31,9 @@
 #include <media/rc-core.h>
 #include <media/cec-notifier.h>
 
+#define CEC_CAP_DEFAULTS (CEC_CAP_LOG_ADDRS | CEC_CAP_TRANSMIT | \
+			  CEC_CAP_PASSTHROUGH | CEC_CAP_RC)
+
 /**
  * struct cec_devnode - cec device node
  * @dev:	cec device

commit a392ef306ffab5150bec64fca553987776486380
Author: Hans Verkuil <hans.verkuil@cisco.com>
Date:   Wed Jun 7 11:46:09 2017 -0300

    UPSTREAM: [media] cec: add cec_phys_addr_invalidate() helper function
    
    Simplifies setting the physical address to CEC_PHYS_ADDR_INVALID.
    
    Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
    Signed-off-by: Hans Verkuil <hansverk@cisco.com>
    Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
    (cherry picked from commit 135327899d2874f2b65b3a3626b37d87df9e6a05)
    
    Change-Id: I707856bd288cfc43c5f8f32e109586a7e790ba1c
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/include/media/cec.h b/include/media/cec.h
index 1048888a96c2..940776f91742 100644
--- a/include/media/cec.h
+++ b/include/media/cec.h
@@ -429,4 +429,17 @@ static inline int cec_phys_addr_validate(u16 phys_addr, u16 *parent, u16 *port)
 
 #endif
 
+/**
+ * cec_phys_addr_invalidate() - set the physical address to INVALID
+ *
+ * @adap:	the CEC adapter
+ *
+ * This is a simple helper function to invalidate the physical
+ * address.
+ */
+static inline void cec_phys_addr_invalidate(struct cec_adapter *adap)
+{
+	cec_s_phys_addr(adap, CEC_PHYS_ADDR_INVALID, false);
+}
+
 #endif /* _MEDIA_CEC_H */

commit bf98f0d72caa3857c4efe2a194a1089dec7b1c65
Author: Clint Taylor <clinton.a.taylor@intel.com>
Date:   Thu Apr 20 08:47:43 2017 -0700

    UPSTREAM: drm/cec: Add CEC over Aux register definitions
    
    Adding DPCD register definitions from the DP 1.3 specification for CEC
    over AUX support.
    
    V2: Add DP_ prefix to all defines.
    V3: missed prefixes from the ESI1 defines
    
    Cc: Jani Nikula <jani.nikula@linux.intel.com>
    
    Reviewed-by: Jani Nikula <jani.nikula@intel.com>
    Signed-off-by: Clint Taylor <clinton.a.taylor@intel.com>
    Signed-off-by: Jani Nikula <jani.nikula@intel.com>
    Link: http://patchwork.freedesktop.org/patch/msgid/1492703263-11494-1-git-send-email-clinton.a.taylor@intel.com
    (cherry picked from commit d753e41d475421543eaaea5f0feadba827f5fa01)
    
    Change-Id: I74173aeeda01c561cbb64834aaa0573289497ac8
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/include/drm/drm_dp_helper.h b/include/drm/drm_dp_helper.h
index eb03131a3813..a91c32a997eb 100644
--- a/include/drm/drm_dp_helper.h
+++ b/include/drm/drm_dp_helper.h
@@ -505,6 +505,9 @@
 #define DP_DEVICE_SERVICE_IRQ_VECTOR_ESI0   0x2003   /* 1.2 */
 
 #define DP_DEVICE_SERVICE_IRQ_VECTOR_ESI1   0x2004   /* 1.2 */
+# define DP_RX_GTC_MSTR_REQ_STATUS_CHANGE    (1 << 0)
+# define DP_LOCK_ACQUISITION_REQUEST         (1 << 1)
+# define DP_CEC_IRQ                          (1 << 2)
 
 #define DP_LINK_SERVICE_IRQ_VECTOR_ESI0     0x2005   /* 1.2 */
 
@@ -545,6 +548,62 @@
 #define DP_AUX_HDCP_KSV_FIFO		0x6802C
 #define DP_AUX_HDCP_AINFO		0x6803B
 
+/* HDMI CEC tunneling over AUX DP 1.3 section 5.3.3.3.1 DPCD 1.4+ */
+#define DP_CEC_TUNNELING_CAPABILITY            0x3000
+# define DP_CEC_TUNNELING_CAPABLE               (1 << 0)
+# define DP_CEC_SNOOPING_CAPABLE                (1 << 1)
+# define DP_CEC_MULTIPLE_LA_CAPABLE             (1 << 2)
+
+#define DP_CEC_TUNNELING_CONTROL               0x3001
+# define DP_CEC_TUNNELING_ENABLE                (1 << 0)
+# define DP_CEC_SNOOPING_ENABLE                 (1 << 1)
+
+#define DP_CEC_RX_MESSAGE_INFO                 0x3002
+# define DP_CEC_RX_MESSAGE_LEN_MASK             (0xf << 0)
+# define DP_CEC_RX_MESSAGE_LEN_SHIFT            0
+# define DP_CEC_RX_MESSAGE_HPD_STATE            (1 << 4)
+# define DP_CEC_RX_MESSAGE_HPD_LOST             (1 << 5)
+# define DP_CEC_RX_MESSAGE_ACKED                (1 << 6)
+# define DP_CEC_RX_MESSAGE_ENDED                (1 << 7)
+
+#define DP_CEC_TX_MESSAGE_INFO                 0x3003
+# define DP_CEC_TX_MESSAGE_LEN_MASK             (0xf << 0)
+# define DP_CEC_TX_MESSAGE_LEN_SHIFT            0
+# define DP_CEC_TX_RETRY_COUNT_MASK             (0x7 << 4)
+# define DP_CEC_TX_RETRY_COUNT_SHIFT            4
+# define DP_CEC_TX_MESSAGE_SEND                 (1 << 7)
+
+#define DP_CEC_TUNNELING_IRQ_FLAGS             0x3004
+# define DP_CEC_RX_MESSAGE_INFO_VALID           (1 << 0)
+# define DP_CEC_RX_MESSAGE_OVERFLOW             (1 << 1)
+# define DP_CEC_TX_MESSAGE_SENT                 (1 << 4)
+# define DP_CEC_TX_LINE_ERROR                   (1 << 5)
+# define DP_CEC_TX_ADDRESS_NACK_ERROR           (1 << 6)
+# define DP_CEC_TX_DATA_NACK_ERROR              (1 << 7)
+
+#define DP_CEC_LOGICAL_ADDRESS_MASK            0x300E /* 0x300F word */
+# define DP_CEC_LOGICAL_ADDRESS_0               (1 << 0)
+# define DP_CEC_LOGICAL_ADDRESS_1               (1 << 1)
+# define DP_CEC_LOGICAL_ADDRESS_2               (1 << 2)
+# define DP_CEC_LOGICAL_ADDRESS_3               (1 << 3)
+# define DP_CEC_LOGICAL_ADDRESS_4               (1 << 4)
+# define DP_CEC_LOGICAL_ADDRESS_5               (1 << 5)
+# define DP_CEC_LOGICAL_ADDRESS_6               (1 << 6)
+# define DP_CEC_LOGICAL_ADDRESS_7               (1 << 7)
+#define DP_CEC_LOGICAL_ADDRESS_MASK_2          0x300F /* 0x300E word */
+# define DP_CEC_LOGICAL_ADDRESS_8               (1 << 0)
+# define DP_CEC_LOGICAL_ADDRESS_9               (1 << 1)
+# define DP_CEC_LOGICAL_ADDRESS_10              (1 << 2)
+# define DP_CEC_LOGICAL_ADDRESS_11              (1 << 3)
+# define DP_CEC_LOGICAL_ADDRESS_12              (1 << 4)
+# define DP_CEC_LOGICAL_ADDRESS_13              (1 << 5)
+# define DP_CEC_LOGICAL_ADDRESS_14              (1 << 6)
+# define DP_CEC_LOGICAL_ADDRESS_15              (1 << 7)
+
+#define DP_CEC_RX_MESSAGE_BUFFER               0x3010
+#define DP_CEC_TX_MESSAGE_BUFFER               0x3020
+#define DP_CEC_MESSAGE_BUFFER_LENGTH             0x10
+
 /* DP 1.2 Sideband message defines */
 /* peer device type - DP 1.2a Table 2-92 */
 #define DP_PEER_DEVICE_NONE		0x0

commit ff2d12fa32ae354f673048066e5e33eb2dff1fe3
Author: Tomeu Vizoso <tomeu.vizoso@collabora.com>
Date:   Fri Mar 3 14:39:33 2017 +0100

    UPSTREAM: drm/dp: add crtc backpointer to drm_dp_aux
    
    This backpointer allows DP helpers to access the crtc it's currently
    being used for.
    
    v6: Have the backpointer be to drm_crtc (Sean Paul)
    
    Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com>
    Signed-off-by: Sean Paul <seanpaul@chromium.org>
    Link: http://patchwork.freedesktop.org/patch/msgid/20170303133936.14964-2-tomeu.vizoso@collabora.com
    (cherry picked from commit 4bb310fd9eea254b68b2f48b376fe149f65e3fbb)
    
    Change-Id: I61ac0aca125b5f5eea5f1c9471d63f7f94e86039
    Signed-off-by: Algea Cao <algea.cao@rock-chips.com>

diff --git a/include/drm/drm_dp_helper.h b/include/drm/drm_dp_helper.h
index f30553dbac03..eb03131a3813 100644
--- a/include/drm/drm_dp_helper.h
+++ b/include/drm/drm_dp_helper.h
@@ -689,6 +689,7 @@ struct drm_dp_aux_msg {
  * @name: user-visible name of this AUX channel and the I2C-over-AUX adapter
  * @ddc: I2C adapter that can be used for I2C-over-AUX communication
  * @dev: pointer to struct device that is the parent for this AUX channel
+ * @crtc: backpointer to the crtc that is currently using this AUX channel
  * @hw_mutex: internal mutex used for locking transfers
  * @transfer: transfers a message representing a single AUX transaction
  *
@@ -725,6 +726,7 @@ struct drm_dp_aux {
 	const char *name;
 	struct i2c_adapter ddc;
 	struct device *dev;
+	struct drm_crtc *crtc;
 	struct mutex hw_mutex;
 	ssize_t (*transfer)(struct drm_dp_aux *aux,
 			    struct drm_dp_aux_msg *msg);

commit 4b00ec7c60d66c36608504d9f453e4799f6cf122
Author: Cai YiWei <cyw@rock-chips.com>
Date:   Mon Jun 17 08:53:27 2019 +0800

    media: rockchip: isp1: fix isp iommu work after suspend
    
    Change-Id: Ie89ec58c6f99a751bc1fdf681a85a6595716c649
    Signed-off-by: Cai YiWei <cyw@rock-chips.com>

diff --git a/drivers/media/platform/rockchip/isp1/dev.c b/drivers/media/platform/rockchip/isp1/dev.c
index 2614900cbd6b..8bfd9c37cace 100644
--- a/drivers/media/platform/rockchip/isp1/dev.c
+++ b/drivers/media/platform/rockchip/isp1/dev.c
@@ -1273,6 +1273,25 @@ static int rkisp1_plat_remove(struct platform_device *pdev)
 	return 0;
 }
 
+static int __maybe_unused rkisp1_suspend(struct device *dev)
+{
+	struct rkisp1_device *isp_dev = dev_get_drvdata(dev);
+
+	rkisp1_dma_detach_device(isp_dev);
+	return pm_runtime_force_suspend(dev);
+}
+
+static int __maybe_unused rkisp1_resume(struct device *dev)
+{
+	struct rkisp1_device *isp_dev = dev_get_drvdata(dev);
+	int ret;
+
+	ret = pm_runtime_force_resume(dev);
+	if (ret < 0)
+		return ret;
+	return rkisp1_dma_attach_device(isp_dev);
+}
+
 static int __maybe_unused rkisp1_runtime_suspend(struct device *dev)
 {
 	struct rkisp1_device *isp_dev = dev_get_drvdata(dev);
@@ -1308,8 +1327,7 @@ static int __init rkisp1_clr_unready_dev(void)
 late_initcall_sync(rkisp1_clr_unready_dev);
 
 static const struct dev_pm_ops rkisp1_plat_pm_ops = {
-	SET_SYSTEM_SLEEP_PM_OPS(pm_runtime_force_suspend,
-				pm_runtime_force_resume)
+	SET_SYSTEM_SLEEP_PM_OPS(rkisp1_suspend, rkisp1_resume)
 	SET_RUNTIME_PM_OPS(rkisp1_runtime_suspend, rkisp1_runtime_resume, NULL)
 };
 

commit 8fe3b381025605ab6fccc1219db8ff1a640b3a14
Author: Terin Stock <terin@terinstock.com>
Date:   Sun Sep 9 21:24:31 2018 -0700

    UPSTREAM: usb: dwc2: host: use hrtimer for NAK retries
    
    Modify the wait delay utilize the high resolution timer API to allow for
    more precisely scheduled callbacks.
    
    A previous commit added a 1ms retry delay after multiple consecutive
    NAKed transactions using jiffies. On systems with a low timer interrupt
    frequency, this delay may be significantly longer than specified,
    resulting in misbehavior with some USB devices.
    
    This scenario was reached on a Raspberry Pi 3B with a Macally FDD-USB
    floppy drive (identified as 0424:0fdc Standard Microsystems Corp.
    Floppy, based on the USB97CFDC USB FDC). With the relay delay, the drive
    would be unable to mount a disk, replying with NAKs until the device was
    reset.
    
    Using ktime, the delta between starting the timer (in dwc2_hcd_qh_add)
    and the callback function can be determined. With the original delay
    implementation, this value was consistently approximately 12ms. (output
    in us).
    
        <idle>-0     [000] ..s.  1600.559974: dwc2_wait_timer_fn: wait_timer delta: 11976
        <idle>-0     [000] ..s.  1600.571974: dwc2_wait_timer_fn: wait_timer delta: 11977
        <idle>-0     [000] ..s.  1600.583974: dwc2_wait_timer_fn: wait_timer delta: 11976
        <idle>-0     [000] ..s.  1600.595974: dwc2_wait_timer_fn: wait_timer delta: 11977
    
    After converting the relay delay to using a higher resolution timer, the
    delay was much closer to 1ms.
    
        <idle>-0     [000] d.h.  1956.553017: dwc2_wait_timer_fn: wait_timer delta: 1002
        <idle>-0     [000] d.h.  1956.554114: dwc2_wait_timer_fn: wait_timer delta: 1002
        <idle>-0     [000] d.h.  1957.542660: dwc2_wait_timer_fn: wait_timer delta: 1004
        <idle>-0     [000] d.h.  1957.543701: dwc2_wait_timer_fn: wait_timer delta: 1002
    
    The floppy drive operates properly with delays up to approximately 5ms,
    and sends NAKs for any delays that are longer.
    
    Change-Id: I54987bfcab6d874b017bdcc8641e886ea4b626f7
    Fixes: 38d2b5fb75c1 ("usb: dwc2: host: Don't retry NAKed transactions right away")
    Cc: <stable@vger.kernel.org>
    Reviewed-by: Douglas Anderson <dianders@chromium.org>
    Acked-by: Minas Harutyunyan <hminas@synopsys.com>
    Signed-off-by: Terin Stock <terin@terinstock.com>
    Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
    Signed-off-by: William Wu <william.wu@rock-chips.com>
    (cherry picked from commit 6ed30a7d8ec29d3aba46e47aa8b4a44f077dda4e)

diff --git a/drivers/usb/dwc2/hcd.h b/drivers/usb/dwc2/hcd.h
index e0ffec28ac0e..78fc0bdfcb34 100644
--- a/drivers/usb/dwc2/hcd.h
+++ b/drivers/usb/dwc2/hcd.h
@@ -365,7 +365,7 @@ struct dwc2_qh {
 	u32 desc_list_sz;
 	u32 *n_bytes;
 	struct timer_list unreserve_timer;
-	struct timer_list wait_timer;
+	struct hrtimer wait_timer;
 	struct dwc2_tt *dwc_tt;
 	int ttport;
 	unsigned tt_buffer_dirty:1;
diff --git a/drivers/usb/dwc2/hcd_queue.c b/drivers/usb/dwc2/hcd_queue.c
index 8c1f37176e21..0f124b79c10e 100644
--- a/drivers/usb/dwc2/hcd_queue.c
+++ b/drivers/usb/dwc2/hcd_queue.c
@@ -58,7 +58,7 @@
 #define DWC2_UNRESERVE_DELAY (msecs_to_jiffies(5))
 
 /* If we get a NAK, wait this long before retrying */
-#define DWC2_RETRY_WAIT_DELAY (msecs_to_jiffies(1))
+#define DWC2_RETRY_WAIT_DELAY 1*1E6L
 
 /**
  * dwc2_periodic_channel_available() - Checks that a channel is available for a
@@ -1462,10 +1462,12 @@ static void dwc2_deschedule_periodic(struct dwc2_hsotg *hsotg,
  * qh back to the "inactive" list, then queues transactions.
  *
  * @t: Pointer to wait_timer in a qh.
+ *
+ * Return: HRTIMER_NORESTART to not automatically restart this timer.
  */
-static void dwc2_wait_timer_fn(unsigned long data)
+static enum hrtimer_restart dwc2_wait_timer_fn(struct hrtimer *t)
 {
-	struct dwc2_qh *qh = (struct dwc2_qh *)data;
+	struct dwc2_qh *qh = container_of(t, struct dwc2_qh, wait_timer);
 	struct dwc2_hsotg *hsotg = qh->hsotg;
 	unsigned long flags;
 
@@ -1489,6 +1491,7 @@ static void dwc2_wait_timer_fn(unsigned long data)
 	}
 
 	spin_unlock_irqrestore(&hsotg->lock, flags);
+	return HRTIMER_NORESTART;
 }
 
 /**
@@ -1520,8 +1523,8 @@ static void dwc2_qh_init(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh,
 	qh->hsotg = hsotg;
 	setup_timer(&qh->unreserve_timer, dwc2_unreserve_timer_fn,
 		    (unsigned long)qh);
-	setup_timer(&qh->wait_timer, dwc2_wait_timer_fn,
-		    (unsigned long)qh);
+	hrtimer_init(&qh->wait_timer, CLOCK_MONOTONIC, HRTIMER_MODE_REL);
+	qh->wait_timer.function = &dwc2_wait_timer_fn;
 	qh->ep_type = ep_type;
 	qh->ep_is_in = ep_is_in;
 
@@ -1691,7 +1694,7 @@ void dwc2_hcd_qh_free(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
 	 * won't do anything anyway, but we want it to finish before we free
 	 * memory.
 	 */
-	del_timer_sync(&qh->wait_timer);
+	hrtimer_cancel(&qh->wait_timer);
 
 	dwc2_host_put_tt_info(hsotg, qh->dwc_tt);
 
@@ -1717,6 +1720,7 @@ int dwc2_hcd_qh_add(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
 {
 	int status;
 	u32 intr_mask;
+	ktime_t delay;
 
 	if (dbg_qh(qh))
 		dev_vdbg(hsotg->dev, "%s()\n", __func__);
@@ -1735,8 +1739,8 @@ int dwc2_hcd_qh_add(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
 			list_add_tail(&qh->qh_list_entry,
 				      &hsotg->non_periodic_sched_waiting);
 			qh->wait_timer_cancel = false;
-			mod_timer(&qh->wait_timer,
-				  jiffies + DWC2_RETRY_WAIT_DELAY + 1);
+			delay = ktime_set(0, DWC2_RETRY_WAIT_DELAY);
+			hrtimer_start(&qh->wait_timer, delay, HRTIMER_MODE_REL);
 		} else {
 			list_add_tail(&qh->qh_list_entry,
 				      &hsotg->non_periodic_sched_inactive);

commit f0f11406914bf1069e5b01ffda1a22d6a37c8fee
Author: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Date:   Fri Jun 15 15:01:29 2018 -0700

    UPSTREAM: usb: dwc2: host: do not delay retries for CONTROL IN transfers
    
    When handling split transactions we will try to delay retry after
    getting a NAK from the device. This works well for BULK transfers that
    can be polled for essentially forever. Unfortunately, on slower systems
    at boot time, when the kernel is busy enumerating all the devices (USB
    or not), we issue a bunch of control requests (reading device
    descriptors, etc). If we get a NAK for the IN part of the control
    request and delay retry for too long (because the system is busy), we
    may confuse the device when we finally get to reissue SSPLIT/CSPLIT IN
    and the device will respond with STALL. As a result we end up with
    failure to get device descriptor and will fail to enumerate the device:
    
    [    3.428801] usb 2-1.2.1: new full-speed USB device number 9 using dwc2
    [    3.508576] usb 2-1.2.1: device descriptor read/8, error -32
    [    3.699150] usb 2-1.2.1: device descriptor read/8, error -32
    [    3.891653] usb 2-1.2.1: new full-speed USB device number 10 using dwc2
    [    3.968859] usb 2-1.2.1: device descriptor read/8, error -32
    ...
    
    Let's not delay retries of split CONTROL IN transfers, as this allows us
    to reliably enumerate devices at boot time.
    
    Change-Id: If24ce2df467cd07e11d28baa01cdbe334fd7b592
    Fixes: 38d2b5fb75c1 ("usb: dwc2: host: Don't retry NAKed transactions right away")
    Reviewed-by: Douglas Anderson <dianders@chromium.org>
    Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
    Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
    Signed-off-by: William Wu <william.wu@rock-chips.com>
    (cherry picked from commit b3eb981be74867af7dbf099df340ad864a91740e)

diff --git a/drivers/usb/dwc2/hcd_intr.c b/drivers/usb/dwc2/hcd_intr.c
index d97e3a416fa5..73e7c0a8bbb6 100644
--- a/drivers/usb/dwc2/hcd_intr.c
+++ b/drivers/usb/dwc2/hcd_intr.c
@@ -1218,7 +1218,10 @@ static void dwc2_hc_nak_intr(struct dwc2_hsotg *hsotg,
 	 * avoid interrupt storms we'll wait before retrying if we've got
 	 * several NAKs. If we didn't do this we'd retry directly from the
 	 * interrupt handler and could end up quickly getting another
-	 * interrupt (another NAK), which we'd retry.
+	 * interrupt (another NAK), which we'd retry. Note that we do not
+	 * delay retries for IN parts of control requests, as those are expected
+	 * to complete fairly quickly, and if we delay them we risk confusing
+	 * the device and cause it issue STALL.
 	 *
 	 * Note that in DMA mode software only gets involved to re-send NAKed
 	 * transfers for split transactions, so we only need to apply this
@@ -1231,7 +1234,9 @@ static void dwc2_hc_nak_intr(struct dwc2_hsotg *hsotg,
 			qtd->error_count = 0;
 		qtd->complete_split = 0;
 		qtd->num_naks++;
-		qtd->qh->want_wait = qtd->num_naks >= DWC2_NAKS_BEFORE_DELAY;
+		qtd->qh->want_wait = qtd->num_naks >= DWC2_NAKS_BEFORE_DELAY &&
+				!(chan->ep_type == USB_ENDPOINT_XFER_CONTROL &&
+				  chan->ep_is_in);
 		dwc2_halt_channel(hsotg, chan, qtd, DWC2_HC_XFER_NAK);
 		goto handle_nak_done;
 	}

commit 02d6972affafebd9849d94cd283bb70eb62f7531
Author: Yao Xiao <xiaoyao@rock-chips.com>
Date:   Sat Jun 15 17:18:27 2019 +0800

    net: rockchip_wlan: cywdhd: add platform modifications for rockchip
    
    Change-Id: I4c16f82ae6179054d852fad912caf1a71498d6e8
    Signed-off-by: Yao Xiao <xiaoyao@rock-chips.com>

diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile
index 2b321e9192e5..85cca194d5f9 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile
@@ -125,7 +125,7 @@ DHDCFLAGS += -DWL_CFG80211_ACL
 # m: module type driver
 # y: built-in type driver
 ##########################
-DRIVER_TYPE ?= m
+DRIVER_TYPE ?= $(CONFIG_CYW_BCMDHD)
 
 #########################
 # Chip dependent feature
@@ -149,7 +149,7 @@ DHD_PLATFORM ?= rockchip
 ifeq ($(DHD_PLATFORM), rockchip)
   CONFIG_BCMDHD_SDIO = y
   CONFIG_BCMDHD_OOB = y
-
+  DHDCFLAGS += -DANDROID_SDIO_RESET
   ## We only add here for the flags in our rockchip code
   DHDCFLAGS += -DCUSTOM_SDIO_F2_BLKSIZE=256
   DHDCFLAGS += -DDHD_OF_SUPPORT 
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c
index 71c83e05a954..32f0321dd840 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c
@@ -34,7 +34,7 @@ struct resource dhd_wlan_resources = {
 		.name	= "bcmdhd_wlan_irq",
 		.start	= 0,
 		.end	= 0,
-		.flags	= IORESOURCE_IRQ | IORESOURCE_IRQ_SHAREABLE	| IORESOURCE_IRQ_HIGHLEVEL,
+		.flags	= IORESOURCE_IRQ | IORESOURCE_IRQ_SHAREABLE,
 };
 
 static struct cntry_locales_custom brcm_wlan_translate_custom_table[] = {
@@ -106,6 +106,7 @@ static void *dhd_wlan_get_country_code(char *ccode
 int dhd_wlan_init_plat_data(void)
 {
     uint irq;
+	int irq_flags = -1;
 
     irq = rockchip_wifi_get_oob_irq();
 
@@ -114,5 +115,13 @@ int dhd_wlan_init_plat_data(void)
     dhd_wlan_resources.start = irq;
     dhd_wlan_resources.end = irq;
 
+	irq_flags = rockchip_wifi_get_oob_irq_flag();
+	if (irq_flags == 1)
+		dhd_wlan_resources.flags |= IORESOURCE_IRQ_HIGHLEVEL;
+	else if (irq_flags == 0)
+		dhd_wlan_resources.flags |= IORESOURCE_IRQ_LOWLEVEL;
+	else
+		pr_warn("%s: unknown oob irqflags !\n", __func__);
+
 	return 0;
 }
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c
index 5e4e5b2d5f15..f50757aec0e4 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c
@@ -10146,7 +10146,7 @@ dhd_module_cleanup(void)
 	dhd_wifi_platform_unregister_drv();
 }
 
-static void __exit
+static void
 dhd_module_exit(void)
 {
 	dhd_buzzz_detach();
@@ -10154,7 +10154,7 @@ dhd_module_exit(void)
 	unregister_reboot_notifier(&dhd_reboot_notifier);
 }
 
-static int __init
+static int
 dhd_module_init(void)
 {
 	int err;
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c
index 011ffc493521..654057946801 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c
@@ -898,6 +898,10 @@ dhdsdio_clk_kso_init(dhd_bus_t *bus)
 #define KSO_WAKE_RETRY_COUNT 100
 #define ERROR_BCME_NODEVICE_MAX 1
 
+#include <linux/mmc/sdio_func.h>
+#include <linux/mmc/host.h>
+#include "bcmsdh_sdmmc.h"
+
 #define MAX_KSO_ATTEMPTS (PMU_MAX_TRANSITION_DLY/KSO_WAIT_US)
 static int
 dhdsdio_clk_kso_enab(dhd_bus_t *bus, bool on)
@@ -905,6 +909,12 @@ dhdsdio_clk_kso_enab(dhd_bus_t *bus, bool on)
 	uint8 wr_val = 0, rd_val, cmp_val, bmask;
 	int err = 0;
 	int try_cnt = 0;
+	struct mmc_host *host;
+	struct sdioh_info *sd = (struct sdioh_info *)(bus->sdh->sdioh);
+	struct sdio_func *func = sd->func[SDIO_FUNC_0];
+
+	host = func->card->host;
+	mmc_retune_disable(host);
 
 	KSO_DBG(("%s> op:%s\n", __FUNCTION__, (on ? "KSO_SET" : "KSO_CLR")));
 
@@ -918,6 +928,7 @@ dhdsdio_clk_kso_enab(dhd_bus_t *bus, bool on)
 	 * after clearing KSO bit, to avoid polling of KSO bit.
 	 */
 	if ((!on) && (bus->sih->chip == BCM43012_CHIP_ID)) {
+		mmc_retune_enable(host);
 		return err;
 	}
 
@@ -958,6 +969,8 @@ dhdsdio_clk_kso_enab(dhd_bus_t *bus, bool on)
 			__FUNCTION__, (on ? "KSO_SET" : "KSO_CLR"), try_cnt, rd_val, err));
 	}
 
+	mmc_retune_enable(host);
+
 	return err;
 }
 

commit ca86b1b13419a762ae2bbbf0e73dd05efce20442
Author: Caesar Wang <wxt@rock-chips.com>
Date:   Mon Jun 17 09:09:50 2019 +0800

    arm64/configs: support NTFS filesystem for rockchip_linux_defconfig
    
    Change-Id: Id0b3bbdd5566a883c060e546c3f69f60b5ca40f4
    Signed-off-by: Caesar Wang <wxt@rock-chips.com>

diff --git a/arch/arm64/configs/rockchip_linux_defconfig b/arch/arm64/configs/rockchip_linux_defconfig
index 45dfa1fc673d..bb677542693d 100644
--- a/arch/arm64/configs/rockchip_linux_defconfig
+++ b/arch/arm64/configs/rockchip_linux_defconfig
@@ -488,6 +488,7 @@ CONFIG_ZISOFS=y
 CONFIG_VFAT_FS=y
 CONFIG_FAT_DEFAULT_CODEPAGE=936
 CONFIG_FAT_DEFAULT_IOCHARSET="utf8"
+CONFIG_NTFS_FS=y
 CONFIG_TMPFS=y
 CONFIG_TMPFS_POSIX_ACL=y
 CONFIG_SQUASHFS=y

commit 196c3e8ab14672b86c10fc004afef84193698552
Author: Jon Lin <jon.lin@rock-chips.com>
Date:   Tue May 28 22:11:22 2019 +0800

    drivers: rkflash: adjust rkflash_debug print
    
    unicom debug print of rkflash.
    
    Change-Id: I59a04f6fdc9219f33fb37723851e87c55ace1f86
    Signed-off-by: Jon Lin <jon.lin@rock-chips.com>

diff --git a/drivers/rkflash/flash.c b/drivers/rkflash/flash.c
index 40625cd84e85..e9758f034769 100644
--- a/drivers/rkflash/flash.c
+++ b/drivers/rkflash/flash.c
@@ -72,9 +72,9 @@ static void flash_read_id_raw(u8 cs, u8 *buf)
 
 	nandc_flash_de_cs(cs);
 	if (ptr[0] != 0xFF && ptr[0] && ptr[1] != 0xFF)
-		PRINT_NANDC_E("No.%d FLASH ID:%x %x %x %x %x %x\n",
-			      cs + 1, ptr[0], ptr[1], ptr[2],
-			      ptr[3], ptr[4], ptr[5]);
+		rkflash_print_error("No.%d FLASH ID:%x %x %x %x %x %x\n",
+				    cs + 1, ptr[0], ptr[1], ptr[2],
+				    ptr[3], ptr[4], ptr[5]);
 }
 
 static void flash_bch_sel(u8 bits)
@@ -167,8 +167,9 @@ static u32 flash_read_ecc(u8 cs)
 
 static u32 flash_read_page_raw(u8 cs, u32 page_addr, u32 *p_data, u32 *p_spare)
 {
-	u32 error_ecc_bits;
+	u32 error_ecc_bits, ret;
 	u32 sec_per_page = nand_para.sec_per_page;
+	u32 nand_ecc = 0;
 
 	nandc_wait_flash_ready(cs);
 	nandc_flash_cs(cs);
@@ -184,39 +185,48 @@ static u32 flash_read_page_raw(u8 cs, u32 page_addr, u32 *p_data, u32 *p_spare)
 
 	if (error_ecc_bits != NAND_STS_ECC_ERR) {
 		if (error_ecc_bits >= (u32)nand_para.ecc_bits - 3) {
-			error_ecc_bits = NAND_STS_REFRESH;
+			ret = NAND_STS_REFRESH;
 		} else {
-			error_ecc_bits = NAND_STS_OK;
+			ret = NAND_STS_OK;
 			if (g_nand_ecc_en) {
-				u32 nand_ecc = flash_read_ecc(cs);
+				nand_ecc = flash_read_ecc(cs);
 
 				if (nand_ecc >= 6) {
-					PRINT_NANDC_E("%s nand ecc %x ecc %d\n",
-						      __func__, page_addr, nand_ecc);
-					error_ecc_bits = NAND_STS_REFRESH;
+					rkflash_print_error("%s nand ecc %x ecc %d\n",
+							    __func__, page_addr, nand_ecc);
+					ret = NAND_STS_REFRESH;
 				}
 			}
 		}
+	} else {
+		ret = NAND_STS_ECC_ERR;
 	}
+	if (nand_ecc > 4 || error_ecc_bits > 4)
+		rkflash_print_info("%s %x %x nandc ecc= %d, internal ecc= %d\n",
+				   __func__, cs, page_addr, error_ecc_bits, nand_ecc);
 
-	return error_ecc_bits;
+	return ret;
 }
 
 static u32 flash_read_page(u8 cs, u32 page_addr, u32 *p_data, u32 *p_spare)
 {
-	u32 ret, i;
+	u32 ret, i = 0;
 
 	ret = flash_read_page_raw(cs, page_addr, p_data, p_spare);
 	if (ret == NAND_STS_ECC_ERR) {
-		for (i = 0; i < 50; i++) {
+		for (; i < 50; i++) {
 			ret = flash_read_page_raw(cs, page_addr, p_data, p_spare);
 			if (ret != NAND_STS_ECC_ERR) {
 				ret = NAND_STS_REFRESH;
 				break;
 			}
 		}
-		PRINT_NANDC_E("flash_read_page %x err_ecc %d\n", page_addr, ret);
+		rkflash_print_error("%s %x err_ecc %d\n",
+				    __func__, page_addr, ret);
 	}
+	rkflash_print_dio("%s %x %x retry=%x\n",
+			   __func__, page_addr, p_data[0], i);
+
 	return ret;
 }
 
@@ -225,6 +235,7 @@ static u32 flash_prog_page(u8 cs, u32 page_addr, u32 *p_data, u32 *p_spare)
 	u32 status;
 	u32 sec_per_page = nand_para.sec_per_page;
 
+	rkflash_print_dio("%s %x %x\n", __func__, page_addr, p_data[0]);
 	nandc_wait_flash_ready(cs);
 	nandc_flash_cs(cs);
 	flash_prog_first_cmd(cs, page_addr);
@@ -234,10 +245,10 @@ static u32 flash_prog_page(u8 cs, u32 page_addr, u32 *p_data, u32 *p_spare)
 	status = flash_read_status(cs, page_addr);
 	nandc_flash_de_cs(cs);
 	status &= 0x01;
-	if (status) {
-		PRINT_NANDC_I("%s addr=%x status=%x\n",
-			      __func__, page_addr, status);
-	}
+	if (status)
+		rkflash_print_info("%s addr=%x status=%x\n",
+				   __func__, page_addr, status);
+
 	return status;
 }
 
@@ -245,6 +256,7 @@ static u32 flash_erase_block(u8 cs, u32 page_addr)
 {
 	u32 status;
 
+	rkflash_print_dio("%s %x\n", __func__, page_addr);
 	nandc_wait_flash_ready(cs);
 	nandc_flash_cs(cs);
 	flash_erase_cmd(cs, page_addr);
@@ -252,10 +264,10 @@ static u32 flash_erase_block(u8 cs, u32 page_addr)
 	status = flash_read_status(cs, page_addr);
 	nandc_flash_de_cs(cs);
 	status &= 0x01;
-	if (status) {
-		PRINT_NANDC_I("%s pageadd=%x status=%x\n",
-			      __func__, page_addr, status);
-	}
+	if (status)
+		rkflash_print_info("%s pageadd=%x status=%x\n",
+				   __func__, page_addr, status);
+
 	return status;
 }
 
@@ -304,7 +316,7 @@ static s32 get_bad_blk_list(u16 *table, u32 die)
 		    bad_flag1 != 0xFF ||
 		    bad_flag2 != 0xFF) {
 			table[bad_cnt++] = blk;
-			PRINT_NANDC_E("die[%d], bad_blk[%d]\n", die, blk);
+			rkflash_print_error("die[%d], bad_blk[%d]\n", die, blk);
 		}
 	}
 	return bad_cnt;
@@ -334,7 +346,7 @@ static void flash_test(void)
 	pwrite = kzalloc(FLASH_PAGE_SIZE, GFP_KERNEL | GFP_DMA);
 	pread = kzalloc(FLASH_PAGE_SIZE, GFP_KERNEL | GFP_DMA);
 
-	PRINT_NANDC_E("%s\n", __func__);
+	rkflash_print_error("%s\n", __func__);
 	bad_blk_num = 0;
 	bad_page_num = 0;
 	bad_cnt	= get_bad_blk_list(bad_blk_list, 0);
@@ -347,7 +359,7 @@ static void flash_test(void)
 		if (i < bad_cnt)
 			continue;
 		is_bad_blk = 0;
-		PRINT_NANDC_E("Flash prog block: %x\n", blk);
+		rkflash_print_error("Flash prog block: %x\n", blk);
 		flash_erase_block(0, blk * blk_addr);
 		for (page = 0; page < pages_num; page++) {
 			page_addr = blk * blk_addr + page;
@@ -376,13 +388,13 @@ static void flash_test(void)
 			}
 			if (is_bad_blk) {
 				bad_page_num++;
-				PRINT_NANDC_E("ERR:page %x, ret= %x\n",
-					      page_addr,
-					      ret);
-				PRINT_NANDC_HEX("w data:", pwrite, 4, 512);
-				PRINT_NANDC_HEX("w spare:", pspare_write, 4, 4);
-				PRINT_NANDC_HEX("r data:", pread, 4, 512);
-				PRINT_NANDC_HEX("r spare:", pspare_read, 4, 5);
+				rkflash_print_error("ERR:page %x, ret= %x\n",
+						    page_addr,
+						    ret);
+				rkflash_print_hex("w data:", pwrite, 4, 512);
+				rkflash_print_hex("w spare:", pspare_write, 4, 4);
+				rkflash_print_hex("r data:", pread, 4, 512);
+				rkflash_print_hex("r spare:", pspare_read, 4, 5);
 				while (1)
 					;
 			}
@@ -391,10 +403,10 @@ static void flash_test(void)
 		if (is_bad_blk)
 			bad_blk_num++;
 	}
-	PRINT_NANDC_E("bad_blk_num = %d, bad_page_num = %d\n",
-		      bad_blk_num, bad_page_num);
+	rkflash_print_error("bad_blk_num = %d, bad_page_num = %d\n",
+			    bad_blk_num, bad_page_num);
 
-	PRINT_NANDC_E("Flash Test Finish!!!\n");
+	rkflash_print_error("Flash Test Finish!!!\n");
 	kfree(pwrite);
 	kfree(pread);
 	while (1)
@@ -417,58 +429,58 @@ static void flash_die_info_init(void)
 			nand_para.blk_per_plane;
 }
 
-static void nandc_flash_print_info(void)
+static void flash_rkflash_print_info(void)
 {
-	PRINT_NANDC_I("No.0 FLASH ID: %x %x %x %x %x %x\n",
-		      nand_para.nand_id[0],
-		      nand_para.nand_id[1],
-		      nand_para.nand_id[2],
-		      nand_para.nand_id[3],
-		      nand_para.nand_id[4],
-		      nand_para.nand_id[5]);
-	PRINT_NANDC_I("die_per_chip: %x\n", nand_para.die_per_chip);
-	PRINT_NANDC_I("sec_per_page: %x\n", nand_para.sec_per_page);
-	PRINT_NANDC_I("page_per_blk: %x\n", nand_para.page_per_blk);
-	PRINT_NANDC_I("cell: %x\n", nand_para.cell);
-	PRINT_NANDC_I("plane_per_die: %x\n", nand_para.plane_per_die);
-	PRINT_NANDC_I("blk_per_plane: %x\n", nand_para.blk_per_plane);
-	PRINT_NANDC_I("TotleBlock: %x\n", g_totle_block);
-	PRINT_NANDC_I("die gap: %x\n", nand_para.die_gap);
-	PRINT_NANDC_I("lsb_mode: %x\n", nand_para.lsb_mode);
-	PRINT_NANDC_I("read_retry_mode: %x\n", nand_para.read_retry_mode);
-	PRINT_NANDC_I("ecc_bits: %x\n", nand_para.ecc_bits);
-	PRINT_NANDC_I("Use ecc_bits: %x\n", g_nand_flash_ecc_bits);
-	PRINT_NANDC_I("access_freq: %x\n", nand_para.access_freq);
-	PRINT_NANDC_I("opt_mode: %x\n", nand_para.opt_mode);
-
-	PRINT_NANDC_I("Cache read enable: %x\n",
-		      nand_para.operation_opt & NAND_CACHE_READ_EN ? 1 : 0);
-	PRINT_NANDC_I("Cache random read enable: %x\n",
-		      nand_para.operation_opt &
-			NAND_CACHE_RANDOM_READ_EN ? 1 : 0);
-	PRINT_NANDC_I("Cache prog enable: %x\n",
-		      nand_para.operation_opt & NAND_CACHE_PROG_EN ? 1 : 0);
-	PRINT_NANDC_I("multi read enable: %x\n",
-		      nand_para.operation_opt & NAND_MULTI_READ_EN ? 1 : 0);
-
-	PRINT_NANDC_I("multi prog enable: %x\n",
-		      nand_para.operation_opt & NAND_MULTI_PROG_EN ? 1 : 0);
-	PRINT_NANDC_I("interleave enable: %x\n",
-		      nand_para.operation_opt & NAND_INTERLEAVE_EN ? 1 : 0);
-
-	PRINT_NANDC_I("read retry enable: %x\n",
-		      nand_para.operation_opt & NAND_READ_RETRY_EN ? 1 : 0);
-	PRINT_NANDC_I("randomizer enable: %x\n",
-		      nand_para.operation_opt & NAND_RANDOMIZER_EN ? 1 : 0);
-
-	PRINT_NANDC_I("SDR enable: %x\n",
-		      nand_para.operation_opt & NAND_SDR_EN ? 1 : 0);
-	PRINT_NANDC_I("ONFI enable: %x\n",
-		      nand_para.operation_opt & NAND_ONFI_EN ? 1 : 0);
-	PRINT_NANDC_I("TOGGLE enable: %x\n",
-		      nand_para.operation_opt & NAND_TOGGLE_EN ? 1 : 0);
-
-	PRINT_NANDC_I("g_nand_idb_res_blk_num: %x\n", g_nand_idb_res_blk_num);
+	rkflash_print_info("No.0 FLASH ID: %x %x %x %x %x %x\n",
+			   nand_para.nand_id[0],
+			   nand_para.nand_id[1],
+			   nand_para.nand_id[2],
+			   nand_para.nand_id[3],
+			   nand_para.nand_id[4],
+			   nand_para.nand_id[5]);
+	rkflash_print_info("die_per_chip: %x\n", nand_para.die_per_chip);
+	rkflash_print_info("sec_per_page: %x\n", nand_para.sec_per_page);
+	rkflash_print_info("page_per_blk: %x\n", nand_para.page_per_blk);
+	rkflash_print_info("cell: %x\n", nand_para.cell);
+	rkflash_print_info("plane_per_die: %x\n", nand_para.plane_per_die);
+	rkflash_print_info("blk_per_plane: %x\n", nand_para.blk_per_plane);
+	rkflash_print_info("TotleBlock: %x\n", g_totle_block);
+	rkflash_print_info("die gap: %x\n", nand_para.die_gap);
+	rkflash_print_info("lsb_mode: %x\n", nand_para.lsb_mode);
+	rkflash_print_info("read_retry_mode: %x\n", nand_para.read_retry_mode);
+	rkflash_print_info("ecc_bits: %x\n", nand_para.ecc_bits);
+	rkflash_print_info("Use ecc_bits: %x\n", g_nand_flash_ecc_bits);
+	rkflash_print_info("access_freq: %x\n", nand_para.access_freq);
+	rkflash_print_info("opt_mode: %x\n", nand_para.opt_mode);
+
+	rkflash_print_info("Cache read enable: %x\n",
+			   nand_para.operation_opt & NAND_CACHE_READ_EN ? 1 : 0);
+	rkflash_print_info("Cache random read enable: %x\n",
+			   nand_para.operation_opt &
+			   NAND_CACHE_RANDOM_READ_EN ? 1 : 0);
+	rkflash_print_info("Cache prog enable: %x\n",
+			   nand_para.operation_opt & NAND_CACHE_PROG_EN ? 1 : 0);
+	rkflash_print_info("multi read enable: %x\n",
+			   nand_para.operation_opt & NAND_MULTI_READ_EN ? 1 : 0);
+
+	rkflash_print_info("multi prog enable: %x\n",
+			   nand_para.operation_opt & NAND_MULTI_PROG_EN ? 1 : 0);
+	rkflash_print_info("interleave enable: %x\n",
+			   nand_para.operation_opt & NAND_INTERLEAVE_EN ? 1 : 0);
+
+	rkflash_print_info("read retry enable: %x\n",
+			   nand_para.operation_opt & NAND_READ_RETRY_EN ? 1 : 0);
+	rkflash_print_info("randomizer enable: %x\n",
+			   nand_para.operation_opt & NAND_RANDOMIZER_EN ? 1 : 0);
+
+	rkflash_print_info("SDR enable: %x\n",
+			   nand_para.operation_opt & NAND_SDR_EN ? 1 : 0);
+	rkflash_print_info("ONFI enable: %x\n",
+			   nand_para.operation_opt & NAND_ONFI_EN ? 1 : 0);
+	rkflash_print_info("TOGGLE enable: %x\n",
+			   nand_para.operation_opt & NAND_TOGGLE_EN ? 1 : 0);
+
+	rkflash_print_info("g_nand_idb_res_blk_num: %x\n", g_nand_idb_res_blk_num);
 }
 
 static void ftl_flash_init(void)
@@ -507,7 +519,7 @@ u32 nandc_flash_init(void __iomem *nandc_addr)
 {
 	u32 cs;
 
-	PRINT_NANDC_I("...%s enter...\n", __func__);
+	rkflash_print_info("...%s enter...\n", __func__);
 	g_nand_idb_res_blk_num = MAX_IDB_RESERVED_BLOCK;
 	g_nand_ecc_en = 0;
 
@@ -557,8 +569,7 @@ u32 nandc_flash_init(void __iomem *nandc_addr)
 	}
 	flash_die_info_init();
 	flash_bch_sel(nand_para.ecc_bits);
-	nandc_flash_print_info();
-	/* flash_print_info(); */
+	flash_rkflash_print_info();
 	ftl_flash_init();
 
 	#if FLASH_STRESS_TEST_EN
diff --git a/drivers/rkflash/rkflash_blk.c b/drivers/rkflash/rkflash_blk.c
index e970d7fe07df..c9f5d90687e9 100644
--- a/drivers/rkflash/rkflash_blk.c
+++ b/drivers/rkflash/rkflash_blk.c
@@ -29,6 +29,7 @@
 
 #include "rkflash_api.h"
 #include "rkflash_blk.h"
+#include "rkflash_debug.h"
 #include "rk_sftl.h"
 
 #include "../soc/rockchip/flash_vendor_storage.h"
@@ -293,6 +294,8 @@ static int rkflash_xfer(struct flash_blk_dev *dev,
 		totle_read_data += nsector;
 		totle_read_count++;
 		mutex_lock(&g_flash_ops_mutex);
+		rkflash_print_bio("rkflash r sec= %lx, n_sec= %lx\n",
+				  start, nsector);
 		ret = g_boot_ops[g_flash_type]->read(start, nsector, buf);
 		mutex_unlock(&g_flash_ops_mutex);
 		if (ret)
@@ -303,6 +306,8 @@ static int rkflash_xfer(struct flash_blk_dev *dev,
 		totle_write_data += nsector;
 		totle_write_count++;
 		mutex_lock(&g_flash_ops_mutex);
+		rkflash_print_bio("rkflash w sec= %lx, n_sec= %lx\n",
+				  start, nsector);
 		ret = g_boot_ops[g_flash_type]->write(start, nsector, buf);
 		mutex_unlock(&g_flash_ops_mutex);
 		if (ret)
diff --git a/drivers/rkflash/rkflash_debug.c b/drivers/rkflash/rkflash_debug.c
index e49d73f6c0fd..ce742b0382ef 100644
--- a/drivers/rkflash/rkflash_debug.c
+++ b/drivers/rkflash/rkflash_debug.c
@@ -2,6 +2,115 @@
 
 /* Copyright (c) 2018 Rockchip Electronics Co. Ltd. */
 
+#include <linux/kernel.h>
+#include <linux/module.h>
+#include <linux/printk.h>
+#include <linux/slab.h>
+
 #include "rkflash_debug.h"
 
-unsigned int rkflash_debug = PRINT_BIT_SFC | PRINT_BIT_NANDC;
+static unsigned int rkflash_debug;
+
+__printf(1, 2) int rkflash_print_dio(const char *fmt, ...)
+{
+	int nret = 0;
+#if PRINT_SWI_CON_IO
+	if (rkflash_debug & PRINT_BIT_CON_IO)  {
+		va_list args;
+
+		if (!fmt)
+			return nret;
+
+		va_start(args, fmt);
+		nret = vprintk(fmt, args);
+		va_end(args);
+	}
+#endif
+	return nret;
+}
+
+__printf(1, 2) int rkflash_print_bio(const char *fmt, ...)
+{
+	int nret = 0;
+#if PRINT_SWI_BLK_IO
+	if (rkflash_debug & PRINT_BIT_BLK_IO)  {
+		va_list args;
+
+		if (!fmt)
+			return nret;
+
+		va_start(args, fmt);
+		nret = vprintk(fmt, args);
+		va_end(args);
+	}
+#endif
+	return nret;
+}
+
+__printf(1, 2) int rkflash_print_info(const char *fmt, ...)
+{
+	int nret = 0;
+#if PRINT_SWI_INFO
+	va_list args;
+
+	if (!fmt)
+		return nret;
+
+	va_start(args, fmt);
+	nret = vprintk(fmt, args);
+	va_end(args);
+#endif
+	return nret;
+}
+
+__printf(1, 2) int rkflash_print_error(const char *fmt, ...)
+{
+	int nret = 0;
+#if PRINT_SWI_ERROR
+	va_list args;
+
+	if (!fmt)
+		return nret;
+
+	va_start(args, fmt);
+	nret = vprintk(fmt, args);
+	va_end(args);
+#endif
+	return nret;
+}
+
+void rkflash_print_hex(const char *s, const void *buf, int w, size_t len)
+{
+#if PRINT_SWI_ERROR
+	return print_hex_dump(KERN_WARNING, s, DUMP_PREFIX_OFFSET, 4, w,
+			      buf, (len) * w, 0);
+#endif
+}
+
+static int set_val(const char *val, const struct kernel_param *kp)
+{
+	char *tmp = kzalloc(8, GFP_KERNEL);
+
+	strncpy(tmp, val, 8);
+	if (!strncmp(tmp, "0", 1)) {
+		rkflash_debug = 0;
+	} else if (!strncmp(tmp, "blk_io", 6)) {
+		rkflash_debug |= PRINT_BIT_BLK_IO;
+	} else if (!strncmp(tmp, "con_io", 6)) {
+		rkflash_debug |= PRINT_BIT_CON_IO;
+	} else {
+		pr_info("input error, support 0, blk_io, con_io\n");
+		rkflash_debug = 0;
+	}
+	kfree(tmp);
+
+	return 0;
+}
+
+static struct kernel_param_ops rkflash_debug_param_ops = {
+	.set = set_val,
+	.get = param_get_uint,
+};
+
+module_param_cb(rkflash_debug, &rkflash_debug_param_ops, &rkflash_debug, 0644);
+MODULE_PARM_DESC(rkflash_debug, "config rkflash_debug module");
diff --git a/drivers/rkflash/rkflash_debug.h b/drivers/rkflash/rkflash_debug.h
index edd609c071d3..e260ca6a3a88 100644
--- a/drivers/rkflash/rkflash_debug.h
+++ b/drivers/rkflash/rkflash_debug.h
@@ -16,80 +16,27 @@
 /*
  * Printing-adding
  */
-extern unsigned int rkflash_debug;
+#define	PRINT_SWI_INFO		1
+#define	PRINT_SWI_ERROR		1
+#define PRINT_SWI_HEX		1
 
-#define	PRINT_SWI_SFC_I		1
-#define	PRINT_SWI_SFC_E		1
-#define PRINT_SWI_SFC_HEX	1
-
-#define	PRINT_SWI_NANDC_I	1
-#define	PRINT_SWI_NANDC_E	1
-#define PRINT_SWI_NANDC_HEX	1
+#define	PRINT_SWI_CON_IO	1
+#define	PRINT_SWI_BLK_IO	1
 
 /*
- * Print switch, set var rkflash_debug corresponding bit to
- * 1 if needed.
+ * Print switch, set var rkflash_debug corresponding bit to 1 if needed.
  * I - info
- * E - error
- * HEX - multiline print
+ * IO - IO request about
  */
-#define	PRINT_BIT_SFC_I		BIT(0)
-#define	PRINT_BIT_SFC_E		BIT(1)
-#define PRINT_BIT_SFC_HEX	BIT(2)
-#define	PRINT_BIT_SFC\
-		(PRINT_BIT_SFC_E | PRINT_BIT_SFC_HEX)
-
-#define	PRINT_BIT_NANDC_I	BIT(4)
-#define	PRINT_BIT_NANDC_E	BIT(5)
-#define PRINT_BIT_NANDC_HEX	BIT(5)
-#define	PRINT_BIT_NANDC\
-		(PRINT_BIT_NANDC_E | PRINT_BIT_NANDC_HEX)
-
-#if (PRINT_SWI_SFC_I)
-#define PRINT_SFC_I(...) {if (rkflash_debug & PRINT_BIT_SFC_I)\
-				pr_info(__VA_ARGS__); }
-#else
-#define PRINT_SFC_I(...)
-#endif
+#define	PRINT_BIT_CON_IO	BIT(0)
+#define	PRINT_BIT_BLK_IO	BIT(4)
 
-#if (PRINT_SWI_SFC_E)
-#define PRINT_SFC_E(...) {if (rkflash_debug & PRINT_BIT_SFC_E)\
-				pr_info(__VA_ARGS__); }
-#else
-#define PRINT_SFC_E(...)
-#endif
-
-#if (PRINT_SWI_SFC_HEX)
-#define PRINT_SFC_HEX(s, buf, width, len)\
-		rkflash_print_hex(s, buf, width, len)
-#else
-#define PRINT_SFC_HEX(s, buf, width, len)
-#endif
-
-#if (PRINT_SWI_NANDC_I)
-#define PRINT_NANDC_I(...) {if (rkflash_debug & PRINT_BIT_NANDC_I)\
-				pr_info(__VA_ARGS__); }
-#else
-#define PRINT_NANDC_I(...)
-#endif
-
-#if (PRINT_SWI_NANDC_E)
-#define PRINT_NANDC_E(...) {if (rkflash_debug & PRINT_BIT_NANDC_E)\
-				pr_info(__VA_ARGS__); }
-#else
-#define PRINT_NANDC_E(...)
-#endif
-
-#if (PRINT_SWI_NANDC_HEX)
-#define PRINT_NANDC_HEX(s, buf, width, len)\
-		(rkflash_print_hex(s, buf, width, len))
-#else
-#define PRINT_NANDC_HEX(s, buf, width, len)
-#endif
+__printf(1, 2) int rkflash_print_info(const char *fmt, ...);
+__printf(1, 2) int rkflash_print_error(const char *fmt, ...);
+void rkflash_print_hex(const char *s, const void *buf, int w, size_t len);
 
-#define rkflash_print_hex(s, buf, w, len)\
-		print_hex_dump(KERN_WARNING, s, DUMP_PREFIX_OFFSET,\
-			       4, w, buf, (len) * w, 0)
+__printf(1, 2) int rkflash_print_dio(const char *fmt, ...);
+__printf(1, 2) int rkflash_print_bio(const char *fmt, ...);
 
 #endif
 
diff --git a/drivers/rkflash/sfc_nand.c b/drivers/rkflash/sfc_nand.c
index 9e377c4d671c..db71efed4303 100644
--- a/drivers/rkflash/sfc_nand.c
+++ b/drivers/rkflash/sfc_nand.c
@@ -370,6 +370,7 @@ static u32 sfc_nand_erase_block(u8 cs, u32 addr)
 	union SFCCMD_DATA sfcmd;
 	u8 status;
 
+	rkflash_print_dio("%s %x\n", __func__, addr);
 	sfcmd.d32 = 0;
 	sfcmd.b.cmd = p_nand_info->block_erase_cmd;
 	sfcmd.b.addrbits = SFC_ADDR_24BITS;
@@ -395,7 +396,7 @@ static u32 sfc_nand_prog_page(u8 cs, u32 addr, u32 *p_data, u32 *p_spare)
 	u32 spare_offs_2 = p_nand_info->spare_offs_2;
 	u32 data_size = sec_per_page * 512;
 
-	PRINT_SFC_I("%s %x %x %x\n", __func__, addr, p_data[0], p_spare[0]);
+	rkflash_print_dio("%s %x %x\n", __func__, addr, p_data[0]);
 	memcpy(gp_page_buf, p_data, data_size);
 	ftl_memset(&gp_page_buf[data_size / 4], 0xff, sec_per_page * 16);
 	gp_page_buf[(data_size + spare_offs_1) / 4] = p_spare[0];
@@ -448,7 +449,6 @@ static u32 sfc_nand_read_page(u8 cs, u32 addr, u32 *p_data, u32 *p_spare)
 	u32 sec_per_page = p_nand_info->sec_per_page;
 	u32 data_size = sec_per_page * 512;
 
-	PRINT_SFC_I("%s %x %x %x\n", __func__, addr, p_data[0], p_spare[0]);
 	sfcmd.d32 = 0;
 	sfcmd.b.cmd = p_nand_info->page_read_cmd;
 	sfcmd.b.datasize = 0;
@@ -481,15 +481,16 @@ static u32 sfc_nand_read_page(u8 cs, u32 addr, u32 *p_data, u32 *p_spare)
 		p_spare[2] = gp_page_buf[(data_size + spare_offs_1) / 4 + 1];
 		p_spare[3] = gp_page_buf[(data_size + spare_offs_2) / 4 + 1];
 	}
+	rkflash_print_dio("%s %x %x\n", __func__, addr, p_data[0]);
 	if (ret != SFC_OK)
 		return SFC_NAND_ECC_ERROR;
 
 	if (ecc_result != SFC_NAND_ECC_OK) {
-		PRINT_SFC_E("%s[0x%x], ret=0x%x\n", __func__, addr, ecc_result);
+		rkflash_print_error("%s[0x%x], ret=0x%x\n", __func__, addr, ecc_result);
 		if (p_data)
-			PRINT_SFC_HEX("data:", p_data, 4, 8);
+			rkflash_print_hex("data:", p_data, 4, 8);
 		if (p_spare)
-			PRINT_SFC_HEX("spare:", p_spare, 4, 2);
+			rkflash_print_hex("spare:", p_spare, 4, 2);
 	}
 
 	return ecc_result;
@@ -522,7 +523,7 @@ static int sfc_nand_get_bad_block_list(u16 *table, u32 die)
 	u32 *pread;
 	u32 *pspare_read;
 
-	PRINT_SFC_E("%s\n", __func__);
+	rkflash_print_info("%s\n", __func__);
 	pread = ftl_malloc(2048);
 	pspare_read = ftl_malloc(8);
 	bad_cnt = 0;
@@ -536,11 +537,12 @@ static int sfc_nand_get_bad_block_list(u16 *table, u32 die)
 		if (pread[0] != 0xFFFFFFFF ||
 		    pspare_read[0] != 0xFFFFFFFF) {
 			table[bad_cnt++] = blk;
-			PRINT_SFC_E("die[%d], bad_blk[%d]\n", die, blk);
+			rkflash_print_error("die[%d], bad_blk[%d]\n", die, blk);
 		}
 	}
 	ftl_free(pread);
 	ftl_free(pspare_read);
+
 	return (int)bad_cnt;
 }
 
@@ -565,7 +567,7 @@ static void sfc_nand_test(void)
 	u32 blk_addr = 64;
 	u32 is_bad_blk = 0;
 
-	PRINT_SFC_E("%s\n", __func__);
+	rkflash_print_info("%s\n", __func__);
 
 	bad_blk_num = 0;
 	bad_page_num = 0;
@@ -579,7 +581,7 @@ static void sfc_nand_test(void)
 		if (i < bad_cnt)
 			continue;
 		is_bad_blk = 0;
-		PRINT_SFC_E("Flash prog block: %x\n", blk);
+		rkflash_print_info("Flash prog block: %x\n", blk);
 		sfc_nand_erase_block(0, blk * blk_addr);
 		for (page = 0; page < pages_num; page++) {
 			page_addr = blk * blk_addr + page;
@@ -608,20 +610,20 @@ static void sfc_nand_test(void)
 			}
 			if (is_bad_blk) {
 				bad_page_num++;
-				PRINT_SFC_E("ERR:page%x, ret=%x\n",
-					    page_addr, ret);
-				PRINT_SFC_HEX("data:", pread, 4, 8);
-				PRINT_SFC_HEX("spare:", pspare_read, 4, 2);
+				rkflash_print_error("ERR:page%x, ret=%x\n",
+						    page_addr, ret);
+				rkflash_print_hex("data:", pread, 4, 8);
+				rkflash_print_hex("spare:", pspare_read, 4, 2);
 			}
 		}
 		sfc_nand_erase_block(0, blk * blk_addr);
 		if (is_bad_blk)
 			bad_blk_num++;
 	}
-	PRINT_SFC_E("bad_blk_num = %d, bad_page_num = %d\n",
-		    bad_blk_num, bad_page_num);
+	rkflash_print_info("bad_blk_num = %d, bad_page_num = %d\n",
+		   bad_blk_num, bad_page_num);
 
-	PRINT_SFC_E("Flash Test Finish!!!\n");
+	rkflash_print_info("Flash Test Finish!!!\n");
 	while (1)
 		;
 }
@@ -677,11 +679,11 @@ static int spi_nand_enable_QE(void)
 
 u32 sfc_nand_init(void)
 {
-	PRINT_SFC_I("...%s enter...\n", __func__);
+	rkflash_print_info("...%s enter...\n", __func__);
 
 	sfc_nand_read_id_raw(id_byte);
-	PRINT_SFC_E("sfc_nand id: %x %x %x\n",
-		    id_byte[0], id_byte[1], id_byte[2]);
+	rkflash_print_info("sfc_nand id: %x %x %x\n",
+		   id_byte[0], id_byte[1], id_byte[2]);
 	if (id_byte[0] == 0xFF || id_byte[0] == 0x00)
 		return FTL_NO_FLASH;
 
@@ -716,15 +718,15 @@ u32 sfc_nand_init(void)
 		u8 status;
 
 		sfc_nand_read_feature(0xA0, &status);
-		PRINT_SFC_I("sfc_nand A0 = 0x%x\n", status);
+		rkflash_print_info("sfc_nand A0 = 0x%x\n", status);
 		sfc_nand_read_feature(0xB0, &status);
-		PRINT_SFC_I("sfc_nand B0 = 0x%x\n", status);
+		rkflash_print_info("sfc_nand B0 = 0x%x\n", status);
 		sfc_nand_read_feature(0xC0, &status);
-		PRINT_SFC_I("sfc_nand C0 = 0x%x\n", status);
-		PRINT_SFC_I("read_lines = %x\n", sfc_nand_dev.read_lines);
-		PRINT_SFC_I("prog_lines = %x\n", sfc_nand_dev.prog_lines);
-		PRINT_SFC_I("page_read_cmd = %x\n", sfc_nand_dev.page_read_cmd);
-		PRINT_SFC_I("page_prog_cmd = %x\n", sfc_nand_dev.page_prog_cmd);
+		rkflash_print_info("sfc_nand C0 = 0x%x\n", status);
+		rkflash_print_info("read_lines = %x\n", sfc_nand_dev.read_lines);
+		rkflash_print_info("prog_lines = %x\n", sfc_nand_dev.prog_lines);
+		rkflash_print_info("page_read_cmd = %x\n", sfc_nand_dev.page_read_cmd);
+		rkflash_print_info("page_prog_cmd = %x\n", sfc_nand_dev.page_prog_cmd);
 	}
 	ftl_flash_init();
 
diff --git a/drivers/rkflash/sfc_nor.c b/drivers/rkflash/sfc_nor.c
index b391657a7a72..f2d41f4ce8ca 100644
--- a/drivers/rkflash/sfc_nor.c
+++ b/drivers/rkflash/sfc_nor.c
@@ -146,7 +146,7 @@ static int snor_wait_busy(int timeout)
 
 		sfc_delay(1);
 	}
-	PRINT_SFC_E("%s  error %x\n", __func__, timeout);
+	rkflash_print_error("%s  error %x\n", __func__, timeout);
 
 	return SFC_BUSY_TIMEOUT;
 }
@@ -431,8 +431,8 @@ int snor_read(struct SFNOR_DEV *p_dev, u32 sec, u32 n_sec, void *p_data)
 		len = size < SFC_MAX_IOSIZE ? size : SFC_MAX_IOSIZE;
 		ret = snor_read_data(p_dev, addr, p_buf, len);
 		if (ret != SFC_OK) {
-			PRINT_SFC_E("snor_read_data %x ret= %x\n",
-				    addr >> 9, ret);
+			rkflash_print_error("snor_read_data %x ret= %x\n",
+					    addr >> 9, ret);
 			goto out;
 		}
 
@@ -470,8 +470,8 @@ int snor_write(struct SFNOR_DEV *p_dev, u32 sec, u32 n_sec, void *p_data)
 			ret = snor_erase(p_dev, sec << 9, (blk_size == 8) ?
 				ERASE_SECTOR : ERASE_BLOCK64K);
 			if (ret != SFC_OK) {
-				PRINT_SFC_E("snor_erase %x ret= %x\n",
-					    sec, ret);
+				rkflash_print_error("snor_erase %x ret= %x\n",
+						    sec, ret);
 				goto out;
 			}
 		}
@@ -479,7 +479,7 @@ int snor_write(struct SFNOR_DEV *p_dev, u32 sec, u32 n_sec, void *p_data)
 		      (blk_size - offset) : n_sec;
 		ret = snor_prog(p_dev, sec << 9, p_buf, len << 9);
 		if (ret != SFC_OK) {
-			PRINT_SFC_E("snor_prog %x ret= %x\n", sec, ret);
+			rkflash_print_error("snor_prog %x ret= %x\n", sec, ret);
 			goto out;
 		}
 		n_sec -= len;
@@ -531,13 +531,13 @@ u32 snor_get_capacity(struct SFNOR_DEV *p_dev)
 
 static void snor_print_spi_chip_info(struct SFNOR_DEV *p_dev)
 {
-	PRINT_SFC_I("addr_mode: %x\n", p_dev->addr_mode);
-	PRINT_SFC_I("read_lines: %x\n", p_dev->read_lines);
-	PRINT_SFC_I("prog_lines: %x\n", p_dev->prog_lines);
-	PRINT_SFC_I("read_cmd: %x\n", p_dev->read_cmd);
-	PRINT_SFC_I("prog_cmd: %x\n", p_dev->prog_cmd);
-	PRINT_SFC_I("blk_erase_cmd: %x\n", p_dev->blk_erase_cmd);
-	PRINT_SFC_I("sec_erase_cmd: %x\n", p_dev->sec_erase_cmd);
+	rkflash_print_info("addr_mode: %x\n", p_dev->addr_mode);
+	rkflash_print_info("read_lines: %x\n", p_dev->read_lines);
+	rkflash_print_info("prog_lines: %x\n", p_dev->prog_lines);
+	rkflash_print_info("read_cmd: %x\n", p_dev->read_cmd);
+	rkflash_print_info("prog_cmd: %x\n", p_dev->prog_cmd);
+	rkflash_print_info("blk_erase_cmd: %x\n", p_dev->blk_erase_cmd);
+	rkflash_print_info("sec_erase_cmd: %x\n", p_dev->sec_erase_cmd);
 }
 
 static struct flash_info *snor_get_flash_info(u8 *flash_id)
@@ -577,8 +577,8 @@ int snor_init(struct SFNOR_DEV *p_dev)
 
 	memset(p_dev, 0, sizeof(struct SFNOR_DEV));
 	snor_read_id(id_byte);
-	PRINT_SFC_E("sfc nor id: %x %x %x\n",
-		    id_byte[0], id_byte[1], id_byte[2]);
+	rkflash_print_info("sfc nor id: %x %x %x\n",
+			   id_byte[0], id_byte[1], id_byte[2]);
 	if (0xFF == id_byte[0] || 0x00 == id_byte[0]) {
 		err = SFC_ERROR;
 		goto err_out;
diff --git a/drivers/rkflash/sfc_nor_mtd.c b/drivers/rkflash/sfc_nor_mtd.c
index a4d729be3526..7c95c6653582 100644
--- a/drivers/rkflash/sfc_nor_mtd.c
+++ b/drivers/rkflash/sfc_nor_mtd.c
@@ -43,8 +43,8 @@ static int sfc_erase_mtd(struct mtd_info *mtd, struct erase_info *instr)
 	if (len == p_dev->mtd.size) {
 		ret = snor_erase(p_dev, 0, CMD_CHIP_ERASE);
 		if (ret) {
-			PRINT_SFC_E("snor_erase CHIP 0x%x ret=%d\n",
-				    addr, ret);
+			rkflash_print_error("snor_erase CHIP 0x%x ret=%d\n",
+					    addr, ret);
 			instr->state = MTD_ERASE_FAILED;
 			mutex_unlock(&p_dev->lock);
 			return -EIO;
@@ -53,8 +53,8 @@ static int sfc_erase_mtd(struct mtd_info *mtd, struct erase_info *instr)
 		while (len > 0) {
 			ret = snor_erase(p_dev, addr, ERASE_BLOCK64K);
 			if (ret) {
-				PRINT_SFC_E("snor_erase 0x%x ret=%d\n",
-					    addr, ret);
+				rkflash_print_error("snor_erase 0x%x ret=%d\n",
+						    addr, ret);
 				instr->state = MTD_ERASE_FAILED;
 				mutex_unlock(&p_dev->lock);
 				return -EIO;
@@ -103,8 +103,8 @@ static int sfc_write_mtd(struct mtd_info *mtd, loff_t to, size_t len,
 		status = snor_prog_page(p_dev, addr, p_dev->dma_buf,
 					chunk + padding);
 		if (status != SFC_OK) {
-			PRINT_SFC_E("snor_prog_page %x ret= %d\n",
-				    addr, status);
+			rkflash_print_error("snor_prog_page %x ret= %d\n",
+					    addr, status);
 			*retlen = len - size;
 			mutex_unlock(&p_dev->lock);
 			return status;
@@ -141,7 +141,7 @@ static int sfc_read_mtd(struct mtd_info *mtd, loff_t from, size_t len,
 		chunk = (size < NOR_PAGE_SIZE) ? size : NOR_PAGE_SIZE;
 		ret = snor_read_data(p_dev, addr, p_dev->dma_buf, chunk);
 		if (ret != SFC_OK) {
-			PRINT_SFC_E("snor_read_data %x ret=%d\n", addr, ret);
+			rkflash_print_error("snor_read_data %x ret=%d\n", addr, ret);
 			*retlen = len - size;
 			mutex_unlock(&p_dev->lock);
 			return ret;
@@ -189,7 +189,7 @@ int sfc_nor_mtd_init(struct SFNOR_DEV *p_dev)
 
 	p_dev->dma_buf = kmalloc(NOR_PAGE_SIZE, GFP_KERNEL | GFP_DMA);
 	if (!p_dev->dma_buf) {
-		PRINT_SFC_E("kmalloc size=0x%x failed\n", NOR_PAGE_SIZE);
+		rkflash_print_error("kmalloc size=0x%x failed\n", NOR_PAGE_SIZE);
 		ret = -ENOMEM;
 		goto out;
 	}

commit 6c0c0289162871a4270eef401ae6a3f62862cdfc
Author: Yifeng Zhao <zyf@rock-chips.com>
Date:   Wed Apr 24 14:30:50 2019 +0800

    drivers: spi: rockchip: config spi rx dma burst size depend on xfer length
    
    Change-Id: I54c855fc2ed4ccfbed6c011ae10bebc9829dc4d7
    Signed-off-by: Yifeng Zhao <zyf@rock-chips.com>

diff --git a/drivers/spi/spi-rockchip.c b/drivers/spi/spi-rockchip.c
index 6f4189f3f315..a9a63396392a 100644
--- a/drivers/spi/spi-rockchip.c
+++ b/drivers/spi/spi-rockchip.c
@@ -433,6 +433,19 @@ static void rockchip_spi_dma_txcb(void *data)
 	spin_unlock_irqrestore(&rs->lock, flags);
 }
 
+static u32 rockchip_spi_calc_burst_size(u32 data_len)
+{
+	u32 i;
+
+	/* burst size: 1, 2, 4, 8 */
+	for (i = 1; i < 8; i <<= 1) {
+		if (data_len & i)
+			break;
+	}
+
+	return i;
+}
+
 static int rockchip_spi_prepare_dma(struct rockchip_spi *rs)
 {
 	unsigned long flags;
@@ -452,7 +465,7 @@ static int rockchip_spi_prepare_dma(struct rockchip_spi *rs)
 		rxconf.direction = rs->dma_rx.direction;
 		rxconf.src_addr = rs->dma_rx.addr;
 		rxconf.src_addr_width = rs->n_bytes;
-		rxconf.src_maxburst = 1;
+		rxconf.src_maxburst = rockchip_spi_calc_burst_size(rs->len / rs->n_bytes);
 		dmaengine_slave_config(rs->dma_rx.ch, &rxconf);
 
 		rxdesc = dmaengine_prep_slave_sg(
@@ -585,7 +598,8 @@ static void rockchip_spi_config(struct rockchip_spi *rs)
 	writel_relaxed(rs->fifo_len / 2 - 1, rs->regs + ROCKCHIP_SPI_RXFTLR);
 
 	writel_relaxed(rs->fifo_len / 2 - 1, rs->regs + ROCKCHIP_SPI_DMATDLR);
-	writel_relaxed(0, rs->regs + ROCKCHIP_SPI_DMARDLR);
+	writel_relaxed(rockchip_spi_calc_burst_size(rs->len / rs->n_bytes) - 1,
+		       rs->regs + ROCKCHIP_SPI_DMARDLR);
 	writel_relaxed(dmacr, rs->regs + ROCKCHIP_SPI_DMACR);
 
 	spi_set_clk(rs, div);

commit 362a761161cbea16cb30cdbd53071c08c5ba95ed
Author: Yifeng Zhao <zyf@rock-chips.com>
Date:   Thu Jun 13 09:23:31 2019 +0800

    drivers: mtd: nand: fix cs configuration error during nand initialization
    
    Change-Id: I200c5b00b1a900a4a6d95ed6a409e0409bb2c058
    Signed-off-by: Yifeng Zhao <zyf@rock-chips.com>

diff --git a/drivers/mtd/nand/rockchip_nand_v6.c b/drivers/mtd/nand/rockchip_nand_v6.c
index f1ba2cd00c94..6fcf2fefd866 100644
--- a/drivers/mtd/nand/rockchip_nand_v6.c
+++ b/drivers/mtd/nand/rockchip_nand_v6.c
@@ -637,7 +637,7 @@ static int rk_nandc_chips_init(struct device *dev, struct rk_nandc *nandc)
 			nand_dev_id = chip->read_byte(mtd);
 			chip->select_chip(mtd, -1);
 		} else {
-			chip->select_chip(mtd, chipnr);
+			chip->select_chip(mtd, bank_idx);
 			chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
 			chip->cmdfunc(mtd, NAND_CMD_READID, 0x00, -1);
 			if (nand_maf_id != chip->read_byte(mtd) ||
diff --git a/drivers/mtd/nand/rockchip_nand_v9.c b/drivers/mtd/nand/rockchip_nand_v9.c
index 9e6591d3e069..b2ff9d1d1365 100644
--- a/drivers/mtd/nand/rockchip_nand_v9.c
+++ b/drivers/mtd/nand/rockchip_nand_v9.c
@@ -622,7 +622,7 @@ static int rk_nandc_chips_init(struct device *dev, struct rk_nandc *nandc)
 			nand_dev_id = chip->read_byte(mtd);
 			chip->select_chip(mtd, -1);
 		} else {
-			chip->select_chip(mtd, chipnr);
+			chip->select_chip(mtd, bank_idx);
 			chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
 			chip->cmdfunc(mtd, NAND_CMD_READID, 0x00, -1);
 			if (nand_maf_id != chip->read_byte(mtd) ||

commit d82f1d3e5800f36a8488925edc534d3883a441d1
Author: Caesar Wang <wxt@rock-chips.com>
Date:   Fri Jun 14 10:10:28 2019 +0800

    arm64: dts: rockchip: reasonable alllcation of VOP on rk3399 linux
    
    Most users used 4K monitors with HDMI on RK3399/RK3399PRO platform, but no
    more than 2K monitors on EDP/DSI panels.
    
    So the reasonable that HDMI connected to VOPB control, and EDP/DSI shound
    be connected to VOPL.
    
    Change-Id: Id97efc5d6d534c302aa52ad00e705c093457f41e
    Signed-off-by: Caesar Wang <wxt@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399-linux.dtsi b/arch/arm64/boot/dts/rockchip/rk3399-linux.dtsi
index a57b3724cc57..45e9575576d7 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-linux.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3399-linux.dtsi
@@ -166,7 +166,7 @@
 			logo,kernel = "logo_kernel.bmp";
 			logo,mode = "center";
 			charge_logo,mode = "center";
-			connect = <&vopl_out_hdmi>;
+			connect = <&vopb_out_hdmi>;
 		};
 
 		route_dsi: route-dsi {
@@ -175,7 +175,7 @@
 			logo,kernel = "logo_kernel.bmp";
 			logo,mode = "center";
 			charge_logo,mode = "center";
-			connect = <&vopb_out_dsi>;
+			connect = <&vopl_out_dsi>;
 		};
 
 		route_edp: route-edp {
@@ -184,7 +184,7 @@
 			logo,kernel = "logo_kernel.bmp";
 			logo,mode = "center";
 			charge_logo,mode = "center";
-			connect = <&vopb_out_edp>;
+			connect = <&vopl_out_edp>;
 		};
 	};
 };
diff --git a/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
index ecd40b1e02b6..7c69075f9515 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
@@ -193,7 +193,7 @@
 	};
 };
 
-&edp_in_vopl {
+&edp_in_vopb {
 	status = "disabled";
 };
 
@@ -206,7 +206,7 @@
 	status = "okay";
 };
 
-&hdmi_in_vopb {
+&hdmi_in_vopl {
 	status = "disabled";
 };
 
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
index 3624158c3440..c1e0fe456798 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v10-linux.dts
@@ -301,7 +301,7 @@
 	};
 };
 
-&edp_in_vopl {
+&edp_in_vopb {
 	status = "disabled";
 };
 
@@ -345,7 +345,7 @@
 		<000000000 0x0000 0x0000 0x0000>;
 };
 
-&hdmi_in_vopb {
+&hdmi_in_vopl {
 	status = "disabled";
 };
 
diff --git a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
index 9d6cbc2c057f..8d62062eb966 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399pro-evb-v11-linux.dts
@@ -306,7 +306,7 @@
 	};
 };
 
-&edp_in_vopl {
+&edp_in_vopb {
 	status = "disabled";
 };
 
@@ -350,7 +350,7 @@
 		<000000000 0x0000 0x0000 0x0000>;
 };
 
-&hdmi_in_vopb {
+&hdmi_in_vopl {
 	status = "disabled";
 };
 

commit 805e544f539b96de96388960173bb673dab5a9dd
Author: Sandy Huang <hjc@rock-chips.com>
Date:   Thu Jun 13 21:09:01 2019 +0800

    drm/rockchip: vop: disable afbdc before close crtc
    
    afbdc should be closed before vop disable, otherwise will
    abfdc will access AXI with error address, this will lead to
    appear vop post empty or iommu pagefault error.
    
    Change-Id: Ia811d629d12aa7fff8bb26ead4c97cc84b35e9b6
    Signed-off-by: Sandy Huang <hjc@rock-chips.com>

diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c
index 1c7f78f3380b..becaf7640be7 100644
--- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c
+++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c
@@ -1393,6 +1393,7 @@ static void vop_crtc_disable(struct drm_crtc *crtc)
 	VOP_CTRL_SET(vop, reg_done_frm, 1);
 	VOP_CTRL_SET(vop, dsp_interlace, 0);
 	drm_crtc_vblank_off(crtc);
+	VOP_CTRL_SET(vop, afbdc_en, 0);
 	vop_disable_all_planes(vop);
 
 	/*

commit d4b4a0299cad6e09421a9a9254e89dc86ec9ae9e
Author: William Wu <william.wu@rock-chips.com>
Date:   Wed Jun 12 15:21:46 2019 +0800

    usb: dwc3: gadget: avoid multiple calls to free_irq
    
    When we use /sys/class/udc/<udc>/soft_connect to do
    a logical disconnection from the USB Host, the func
    usb_udc_softconn_store嚗? anusb_gadget_remove_driver嚗?    both call dwc3_gadget_stop(). This results in a
    'Trying to free already-free IRQ' warning and stack
    trace. To solve the problem, don't call free_irq()
    in dwc3_gadget_stop() if dwc->gadget_driver is NULL.
    
    Change-Id: I9d5b5b354612c3ce3677b3d15cf6af1fcbf3f399
    Signed-off-by: William Wu <william.wu@rock-chips.com>

diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c
index 831e31ec46ee..adf7b07f820a 100644
--- a/drivers/usb/dwc3/gadget.c
+++ b/drivers/usb/dwc3/gadget.c
@@ -1836,12 +1836,19 @@ static int dwc3_gadget_stop(struct usb_gadget *g)
 	unsigned long		flags;
 
 	spin_lock_irqsave(&dwc->lock, flags);
+	if (!dwc->gadget_driver) {
+		spin_unlock_irqrestore(&dwc->lock, flags);
+		dev_warn(dwc->dev, "%s is already stopped\n",
+			 dwc->gadget.name);
+		goto out;
+	}
 	__dwc3_gadget_stop(dwc);
 	dwc->gadget_driver	= NULL;
 	spin_unlock_irqrestore(&dwc->lock, flags);
 
 	free_irq(dwc->irq_gadget, dwc->ev_buf);
 
+out:
 	return 0;
 }
 

commit 20fe938d82746bdc3cebf85707169993ceab2c67
Author: William Wu <william.wu@rock-chips.com>
Date:   Wed Jun 12 15:04:06 2019 +0800

    usb: gadget: udc: core: fix uvc gadget disconnect issue
    
    This patch fix the issue that users fail to do a logical
    disconnection from the USB Host via the kernel node:
    
    /sys/class/udc/<udc>/soft_connect
    
    Fixes: 3099e13bdb21 ("usb: gadget: f_uvc: support uvc and adb use independently")
    Change-Id: I2a19f72dc0a5dc34e430d384f5b475b488731311
    Signed-off-by: William Wu <william.wu@rock-chips.com>

diff --git a/drivers/usb/gadget/udc/core.c b/drivers/usb/gadget/udc/core.c
index d4ce9ca37f1d..d48877e73478 100644
--- a/drivers/usb/gadget/udc/core.c
+++ b/drivers/usb/gadget/udc/core.c
@@ -682,11 +682,9 @@ int usb_gadget_disconnect(struct usb_gadget *gadget)
 		goto out;
 	}
 
-	if (!gadget->uvc_enabled) {
-		ret = gadget->ops->pullup(gadget, 0);
-		if (!ret)
-			gadget->connected = 0;
-	}
+	ret = gadget->ops->pullup(gadget, 0);
+	if (!ret)
+		gadget->connected = 0;
 
 out:
 	trace_usb_gadget_disconnect(gadget, ret);
@@ -713,7 +711,7 @@ int usb_gadget_deactivate(struct usb_gadget *gadget)
 	if (gadget->deactivated)
 		goto out;
 
-	if (gadget->connected) {
+	if (gadget->connected && !gadget->uvc_enabled) {
 		ret = usb_gadget_disconnect(gadget);
 		if (ret)
 			goto out;

commit 3b6867a5a9132601cb13dc60be3f929a116f4a41
Author: Shixiang Zheng <shixiang.zheng@rock-chips.com>
Date:   Fri Jun 14 10:07:01 2019 +0800

    video/rockchip: rga2 fix alpha blend 405 mode not working issue
    
    Change-Id: Id8c7d8b9b3021cbae79001aa565b6e7d7e5556f7
    Signed-off-by: Shixiang Zheng <shixiang.zheng@rock-chips.com>

diff --git a/drivers/video/rockchip/rga2/rga2_reg_info.c b/drivers/video/rockchip/rga2/rga2_reg_info.c
index 378394cf33f9..5f231d6f3e24 100644
--- a/drivers/video/rockchip/rga2/rga2_reg_info.c
+++ b/drivers/video/rockchip/rga2/rga2_reg_info.c
@@ -1170,8 +1170,8 @@ void RGA_MSG_2_RGA2_MSG(struct rga_req *req_rga, struct rga2_req *req)
                 req->alpha_mode_1 = 0x3848;
             }
             else if ((req_rga->alpha_rop_mode & 3) == 1) {
-                req->alpha_mode_0 = 0x483A;
-                req->alpha_mode_1 = 0x483A;
+		req->alpha_mode_0 = 0x384A;
+		req->alpha_mode_1 = 0x3A4A;
             }
             else if ((req_rga->alpha_rop_mode & 3) == 2) {
                 req->alpha_mode_0 = 0x384C;
@@ -1372,8 +1372,8 @@ void RGA_MSG_2_RGA2_MSG_32(struct rga_req_32 *req_rga, struct rga2_req *req)
                 req->alpha_mode_1 = 0x3848;
             }
             else if ((req_rga->alpha_rop_mode & 3) == 1) {
-                req->alpha_mode_0 = 0x483A;
-                req->alpha_mode_1 = 0x483A;
+		req->alpha_mode_0 = 0x384A;
+		req->alpha_mode_1 = 0x3A4A;
             }
             else if ((req_rga->alpha_rop_mode & 3) == 2) {
                 req->alpha_mode_0 = 0x384C;

commit cbbc5861c769a214a05e533b9d637f52e23a7fc8
Author: Yao Xiao <xiaoyao@rock-chips.com>
Date:   Wed Jun 12 11:52:58 2019 +0800

    net: rockchip_wlan: update rtl8189fs to "v5.3.12_28613"
    
    Change-Id: I36061e358a3549f3924abdda4724c88b031162a3
    Signed-off-by: Yao Xiao <xiaoyao@rock-chips.com>

diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/Makefile b/drivers/net/wireless/rockchip_wlan/rtl8189fs/Makefile
index 4bb099292b19..469f05712859 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/Makefile
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/Makefile
@@ -22,13 +22,9 @@ EXTRA_CFLAGS += -Wno-date-time	# Fix compile error && warning on gcc 4.9 and lat
 endif
 
 EXTRA_CFLAGS += -I$(src)/include
-EXTRA_CFLAGS += -I$(src)/hal/phydm
 
 EXTRA_LDFLAGS += --strip-debug
 
-CONFIG_ANDROID_4_2 = n
-CONFIG_ANDROID_4_4_Kernel_3_0 = n
-
 CONFIG_AUTOCFG_CP = n
 
 ########################## WIFI IC ############################
@@ -41,6 +37,10 @@ CONFIG_RTL8723B = n
 CONFIG_RTL8814A = n
 CONFIG_RTL8723C = n
 CONFIG_RTL8188F = y
+CONFIG_RTL8188GTV = n
+CONFIG_RTL8822B = n
+CONFIG_RTL8723D = n
+CONFIG_RTL8821C = n
 ######################### Interface ###########################
 CONFIG_USB_HCI = n
 CONFIG_PCI_HCI = n
@@ -57,22 +57,36 @@ CONFIG_INTEL_WIDI = n
 CONFIG_WAPI_SUPPORT = n
 CONFIG_EFUSE_CONFIG_FILE = y
 CONFIG_EXT_CLK = n
-CONFIG_TRAFFIC_PROTECT = y
+CONFIG_TRAFFIC_PROTECT = n
 CONFIG_LOAD_PHY_PARA_FROM_FILE = y
 CONFIG_TXPWR_BY_RATE_EN = y
 CONFIG_TXPWR_LIMIT_EN = n
+CONFIG_RTW_CHPLAN = 0xFF
 CONFIG_RTW_ADAPTIVITY_EN = disable
 CONFIG_RTW_ADAPTIVITY_MODE = normal
 CONFIG_SIGNAL_SCALE_MAPPING = n
 CONFIG_80211W = n
 CONFIG_REDUCE_TX_CPU_LOADING = n
 CONFIG_BR_EXT = y
-CONFIG_ANTENNA_DIVERSITY = n
 CONFIG_TDLS = n
 CONFIG_WIFI_MONITOR = n
+CONFIG_MCC_MODE = n
+CONFIG_APPEND_VENDOR_IE_ENABLE = n
+CONFIG_RTW_NAPI = y
+CONFIG_RTW_GRO = y
+CONFIG_RTW_NETIF_SG = y
+CONFIG_RTW_IPCAM_APPLICATION = n
+CONFIG_RTW_REPEATER_SON = n
+CONFIG_RTW_WIFI_HAL = y
+########################## Debug ###########################
+CONFIG_RTW_DEBUG = y
+# default log level is _DRV_INFO_ = 4,
+# please refer to "How_to_set_driver_debug_log_level.doc" to set the available level.
+CONFIG_RTW_LOG_LEVEL = 4
 ######################## Wake On Lan ##########################
-CONFIG_WOWLAN = y
-CONFIG_GPIO_WAKEUP = y
+CONFIG_WOWLAN = n
+CONFIG_WAKEUP_TYPE = 0x7 #bit2: deauth, bit1: unicast, bit0: magic pkt.
+CONFIG_GPIO_WAKEUP = n
 CONFIG_WAKEUP_GPIO_IDX = default
 CONFIG_HIGH_ACTIVE = n
 CONFIG_PNO_SUPPORT = n
@@ -132,8 +146,16 @@ CONFIG_PLATFORM_ARM_WMT = n
 CONFIG_PLATFORM_TI_DM365 = n
 CONFIG_PLATFORM_MOZART = n
 CONFIG_PLATFORM_RTK119X = n
+CONFIG_PLATFORM_RTK129X = n
+CONFIG_PLATFORM_RTK390X = n
 CONFIG_PLATFORM_NOVATEK_NT72668 = n
 CONFIG_PLATFORM_HISILICON = n
+CONFIG_PLATFORM_HISILICON_HI3798 = n
+CONFIG_PLATFORM_NV_TK1 = n
+CONFIG_PLATFORM_NV_TK1_UBUNTU = n
+CONFIG_PLATFORM_RTL8197D = n
+CONFIG_PLATFORM_AML_S905 = n
+CONFIG_PLATFORM_ZTE_ZX296716 = n
 ###############################################################
 
 CONFIG_DRVEXT_MODULE = n
@@ -170,7 +192,8 @@ _OS_INTFS_FILES :=	os_dep/osdep_service.o \
 			os_dep/linux/rtw_cfgvendor.o \
 			os_dep/linux/wifi_regd.o \
 			os_dep/linux/rtw_android.o \
-			os_dep/linux/rtw_proc.o
+			os_dep/linux/rtw_proc.o \
+			os_dep/linux/rtw_rhashtable.o
 
 ifeq ($(CONFIG_MP_INCLUDED), y)
 _OS_INTFS_FILES += os_dep/linux/ioctl_mp.o
@@ -192,53 +215,20 @@ _HAL_INTFS_FILES :=	hal/hal_intf.o \
 			hal/hal_com_phycfg.o \
 			hal/hal_phy.o \
 			hal/hal_dm.o \
+			hal/hal_dm_acs.o \
+			hal/hal_btcoex_wifionly.o \
 			hal/hal_btcoex.o \
 			hal/hal_mp.o \
+			hal/hal_mcc.o \
 			hal/hal_hci/hal_$(HCI_NAME).o \
+			hal/led/hal_led.o \
 			hal/led/hal_$(HCI_NAME)_led.o
 
-			
-_OUTSRC_FILES := hal/phydm/phydm_debug.o	\
-		hal/phydm/phydm_antdiv.o\
-		hal/phydm/phydm_antdect.o\
-		hal/phydm/phydm_interface.o\
-		hal/phydm/phydm_hwconfig.o\
-		hal/phydm/phydm.o\
-		hal/phydm/halphyrf_ce.o\
-		hal/phydm/phydm_edcaturbocheck.o\
-		hal/phydm/phydm_dig.o\
-		hal/phydm/phydm_pathdiv.o\
-		hal/phydm/phydm_rainfo.o\
-		hal/phydm/phydm_dynamicbbpowersaving.o\
-		hal/phydm/phydm_powertracking_ce.o\
-		hal/phydm/phydm_dynamictxpower.o\
-		hal/phydm/phydm_adaptivity.o\
-		hal/phydm/phydm_cfotracking.o\
-		hal/phydm/phydm_noisemonitor.o\
-		hal/phydm/phydm_acs.o\
-		hal/phydm/phydm_beamforming.o\
-		hal/phydm/txbf/halcomtxbf.o\
-		hal/phydm/txbf/haltxbfinterface.o
-
 
 EXTRA_CFLAGS += -I$(src)/platform
 _PLATFORM_FILES := platform/platform_ops.o
 
-ifeq ($(CONFIG_BT_COEXIST), y)
 EXTRA_CFLAGS += -I$(src)/hal/btc
-_OUTSRC_FILES += hal/btc/HalBtc8192e1Ant.o \
-				hal/btc/HalBtc8192e2Ant.o \
-				hal/btc/HalBtc8723b1Ant.o \
-				hal/btc/HalBtc8723b2Ant.o \
-				hal/btc/HalBtc8812a1Ant.o \
-				hal/btc/HalBtc8812a2Ant.o \
-				hal/btc/HalBtc8821a1Ant.o \
-				hal/btc/HalBtc8821a2Ant.o \
-				hal/btc/HalBtc8821aCsr2Ant.o \
-				hal/btc/HalBtc8703b1Ant.o \
-				hal/btc/HalBtc8703b2Ant.o 
-endif
-
 
 ########### HAL_RTL8188E #################################
 ifeq ($(CONFIG_RTL8188E), y)
@@ -272,6 +262,8 @@ _HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
 			hal/$(RTL871X)/$(RTL871X)_dm.o \
 			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
 			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8188e_s_fw.o \
+			hal/$(RTL871X)/hal8188e_t_fw.o \
 			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
 			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
 			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
@@ -297,17 +289,6 @@ ifeq ($(CONFIG_SDIO_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188E_SDIO.o
 endif
 
-#hal/OUTSRC/$(RTL871X)/Hal8188EFWImg_CE.o
-_OUTSRC_FILES += hal/phydm/$(RTL871X)/halhwimg8188e_mac.o\
-		hal/phydm/$(RTL871X)/halhwimg8188e_bb.o\
-		hal/phydm/$(RTL871X)/halhwimg8188e_rf.o\
-		hal/phydm/$(RTL871X)/halhwimg8188e_t_fw.o\
-		hal/phydm/$(RTL871X)/halhwimg8188e_s_fw.o\
-		hal/phydm/$(RTL871X)/halphyrf_8188e_ce.o\
-		hal/phydm/$(RTL871X)/phydm_regconfig8188e.o\
-		hal/phydm/$(RTL871X)/hal8188erateadaptive.o\
-		hal/phydm/$(RTL871X)/phydm_rtl8188e.o
-
 endif
 
 ########### HAL_RTL8192E #################################
@@ -337,6 +318,7 @@ _HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
 			hal/$(RTL871X)/$(RTL871X)_dm.o \
 			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
 			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8192e_fw.o \
 			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
 			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
 			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
@@ -358,15 +340,14 @@ endif
 ifeq ($(CONFIG_PCI_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8192E_PCIE.o
 endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8192E_SDIO.o
+endif
 
-#hal/OUTSRC/$(RTL871X)/HalHWImg8188E_FW.o
-_OUTSRC_FILES += hal/phydm/$(RTL871X)/halhwimg8192e_mac.o\
-		hal/phydm/$(RTL871X)/halhwimg8192e_bb.o\
-		hal/phydm/$(RTL871X)/halhwimg8192e_rf.o\
-		hal/phydm/$(RTL871X)/halhwimg8192e_fw.o\
-		hal/phydm/$(RTL871X)/halphyrf_8192e_ce.o\
-		hal/phydm/$(RTL871X)/phydm_regconfig8192e.o\
-		hal/phydm/$(RTL871X)/phydm_rtl8192e.o
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8192e1ant.o \
+				hal/btc/halbtc8192e2ant.o
+endif
 
 endif
 
@@ -427,18 +408,14 @@ endif
 ifeq ($(CONFIG_PCI_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8821A_PCIE.o
 endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8821A_SDIO.o
+endif
 endif
 
 ifeq ($(CONFIG_RTL8812A), y)
 EXTRA_CFLAGS += -DCONFIG_RTL8812A
-_OUTSRC_FILES += hal/phydm/$(RTL871X)/halhwimg8812a_fw.o\
-		hal/phydm/$(RTL871X)/halhwimg8812a_mac.o\
-		hal/phydm/$(RTL871X)/halhwimg8812a_bb.o\
-		hal/phydm/$(RTL871X)/halhwimg8812a_rf.o\
-		hal/phydm/$(RTL871X)/halphyrf_8812a_ce.o\
-		hal/phydm/$(RTL871X)/phydm_regconfig8812a.o\
-		hal/phydm/$(RTL871X)/phydm_rtl8812a.o\
-		hal/phydm/txbf/haltxbfjaguar.o
+_HAL_INTFS_FILES +=	hal/rtl8812a/hal8812a_fw.o
 endif
 
 ifeq ($(CONFIG_RTL8821A), y)
@@ -463,19 +440,22 @@ endif
 endif
 
 EXTRA_CFLAGS += -DCONFIG_RTL8821A
-_OUTSRC_FILES += hal/phydm/rtl8821a/halhwimg8821a_fw.o\
-		hal/phydm/rtl8821a/halhwimg8821a_mac.o\
-		hal/phydm/rtl8821a/halhwimg8821a_bb.o\
-		hal/phydm/rtl8821a/halhwimg8821a_rf.o\
-		hal/phydm/rtl8812a/halphyrf_8812a_ce.o\
-		hal/phydm/rtl8821a/halphyrf_8821a_ce.o\
-		hal/phydm/rtl8821a/phydm_regconfig8821a.o\
-		hal/phydm/rtl8821a/phydm_rtl8821a.o\
-		hal/phydm/rtl8821a/phydm_iqk_8821a_ce.o\
-		hal/phydm/txbf/haltxbfjaguar.o
+
+_HAL_INTFS_FILES +=	hal/rtl8812a/hal8821a_fw.o
 		
 endif
 
+ifeq ($(CONFIG_BT_COEXIST), y)
+ifeq ($(CONFIG_RTL8812A), y)
+_BTC_FILES += hal/btc/halbtc8812a1ant.o \
+				hal/btc/halbtc8812a2ant.o
+endif
+ifeq ($(CONFIG_RTL8821A), y)
+_BTC_FILES += hal/btc/halbtc8821a1ant.o \
+				hal/btc/halbtc8821a2ant.o
+endif
+endif
+
 endif
 
 ########### HAL_RTL8723B #################################
@@ -504,7 +484,7 @@ _HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
 			hal/$(RTL871X)/$(RTL871X)_dm.o \
 			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
 			hal/$(RTL871X)/$(RTL871X)_cmd.o \
-
+			hal/$(RTL871X)/hal8723b_fw.o
 
 _HAL_INTFS_FILES +=	\
 			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
@@ -524,23 +504,23 @@ endif
 ifeq ($(CONFIG_PCI_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723B_PCIE.o
 endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723B_SDIO.o
+endif
 
-_OUTSRC_FILES += hal/phydm/$(RTL871X)/halhwimg8723b_bb.o\
-								hal/phydm/$(RTL871X)/halhwimg8723b_mac.o\
-								hal/phydm/$(RTL871X)/halhwimg8723b_rf.o\
-								hal/phydm/$(RTL871X)/halhwimg8723b_fw.o\
-								hal/phydm/$(RTL871X)/halhwimg8723b_mp.o\
-								hal/phydm/$(RTL871X)/phydm_regconfig8723b.o\
-								hal/phydm/$(RTL871X)/halphyrf_8723b_ce.o\
-								hal/phydm/$(RTL871X)/phydm_rtl8723b.o
+_BTC_FILES += hal/btc/halbtc8723bwifionly.o
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8723b1ant.o \
+				hal/btc/halbtc8723b2ant.o
+endif
 
 endif
 
 ########### HAL_RTL8814A #################################
 ifeq ($(CONFIG_RTL8814A), y)
 ## ADD NEW VHT MP HW TX MODE ##
-EXTRA_CFLAGS += -DCONFIG_MP_VHT_HW_TX_MODE
-CONFIG_MP_VHT_HW_TX_MODE = y
+#EXTRA_CFLAGS += -DCONFIG_MP_VHT_HW_TX_MODE
+#CONFIG_MP_VHT_HW_TX_MODE = y
 ##########################################
 RTL871X = rtl8814a
 ifeq ($(CONFIG_USB_HCI), y)
@@ -566,6 +546,7 @@ _HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
 			hal/$(RTL871X)/$(RTL871X)_dm.o \
 			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
 			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8814a_fw.o
 
 
 _HAL_INTFS_FILES +=	\
@@ -591,16 +572,6 @@ ifeq ($(CONFIG_PCI_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8814A_PCIE.o
 endif
 
-_OUTSRC_FILES += hal/phydm/$(RTL871X)/halhwimg8814a_bb.o\
-								hal/phydm/$(RTL871X)/halhwimg8814a_mac.o\
-								hal/phydm/$(RTL871X)/halhwimg8814a_rf.o\
-								hal/phydm/$(RTL871X)/halhwimg8814a_fw.o\
-								hal/phydm/$(RTL871X)/phydm_iqk_8814a.o\
-								hal/phydm/$(RTL871X)/phydm_regconfig8814a.o\
-								hal/phydm/$(RTL871X)/halphyrf_8814a_ce.o\
-								hal/phydm/$(RTL871X)/phydm_rtl8814a.o\
-								hal/phydm/txbf/haltxbf8814a.o
-
 endif
 
 ########### HAL_RTL8723C #################################
@@ -632,7 +603,7 @@ _HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
 			hal/$(RTL871X)/$(RTL871X)_dm.o \
 			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
 			hal/$(RTL871X)/$(RTL871X)_cmd.o \
-
+			hal/$(RTL871X)/hal8703b_fw.o
 
 _HAL_INTFS_FILES +=	\
 			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
@@ -653,12 +624,69 @@ ifeq ($(CONFIG_PCI_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8703B_PCIE.o
 endif
 
-_OUTSRC_FILES += hal/phydm/$(RTL871X)/halhwimg8703b_bb.o\
-								hal/phydm/$(RTL871X)/halhwimg8703b_mac.o\
-								hal/phydm/$(RTL871X)/halhwimg8703b_rf.o\
-								hal/phydm/$(RTL871X)/halhwimg8703b_fw.o\
-								hal/phydm/$(RTL871X)/phydm_regconfig8703b.o\
-								hal/phydm/$(RTL871X)/halphyrf_8703b.o
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8703b1ant.o
+endif
+
+endif
+
+########### HAL_RTL8723D #################################
+ifeq ($(CONFIG_RTL8723D), y)
+
+RTL871X = rtl8723d
+ifeq ($(CONFIG_USB_HCI), y)
+MODULE_NAME = 8723du
+MODULE_SUB_NAME = 8723du
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+MODULE_NAME = 8723de
+MODULE_SUB_NAME = 8723de
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 8723ds
+MODULE_SUB_NAME = 8723ds
+endif
+
+EXTRA_CFLAGS += -DCONFIG_RTL8723D
+
+_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
+					hal/$(RTL871X)/Hal8723DPwrSeq.o\
+					hal/$(RTL871X)/$(RTL871X)_sreset.o
+
+_HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
+			hal/$(RTL871X)/$(RTL871X)_phycfg.o \
+			hal/$(RTL871X)/$(RTL871X)_rf6052.o \
+			hal/$(RTL871X)/$(RTL871X)_dm.o \
+			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
+			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8723d_fw.o \
+			hal/$(RTL871X)/$(RTL871X)_lps_poff.o
+
+
+_HAL_INTFS_FILES +=	\
+			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_led.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_xmit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_recv.o
+
+ifeq ($(CONFIG_PCI_HCI), y)
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
+else
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
+endif
+
+ifeq ($(CONFIG_USB_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723D_USB.o
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723D_PCIE.o
+endif
+
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8723d1ant.o \
+				hal/btc/halbtc8723d2ant.o
+endif
+
 endif
 
 ########### HAL_RTL8188F #################################
@@ -687,7 +715,7 @@ _HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
 			hal/$(RTL871X)/$(RTL871X)_dm.o \
 			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
 			hal/$(RTL871X)/$(RTL871X)_cmd.o \
-
+			hal/$(RTL871X)/hal8188f_fw.o
 
 _HAL_INTFS_FILES +=	\
 			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
@@ -709,16 +737,87 @@ ifeq ($(CONFIG_SDIO_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188F_SDIO.o
 endif
 
-_OUTSRC_FILES += hal/phydm/$(RTL871X)/halhwimg8188f_bb.o\
-								hal/phydm/$(RTL871X)/halhwimg8188f_mac.o\
-								hal/phydm/$(RTL871X)/halhwimg8188f_rf.o\
-								hal/phydm/$(RTL871X)/halhwimg8188f_fw.o\
-								hal/phydm/$(RTL871X)/phydm_regconfig8188f.o\
-								hal/phydm/$(RTL871X)/halphyrf_8188f.o \
-								hal/phydm/$(RTL871X)/phydm_rtl8188f.o
+endif
+
+########### HAL_RTL8188GTV #################################
+ifeq ($(CONFIG_RTL8188GTV), y)
+
+RTL871X = rtl8188gtv
+ifeq ($(CONFIG_USB_HCI), y)
+MODULE_NAME = 8188gtvu
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 8189gtvs
+endif
+
+EXTRA_CFLAGS += -DCONFIG_RTL8188GTV
+
+_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
+					hal/$(RTL871X)/Hal8188GTVPwrSeq.o\
+					hal/$(RTL871X)/$(RTL871X)_sreset.o
+
+_HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
+			hal/$(RTL871X)/$(RTL871X)_phycfg.o \
+			hal/$(RTL871X)/$(RTL871X)_rf6052.o \
+			hal/$(RTL871X)/$(RTL871X)_dm.o \
+			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
+			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8188gtv_fw.o
+
+_HAL_INTFS_FILES +=	\
+			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
+
+ifeq ($(CONFIG_PCI_HCI), y)
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
+else
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
+endif
+
+ifeq ($(CONFIG_USB_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188GTV_USB.o
+endif
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188GTV_SDIO.o
+endif
 
 endif
 
+########### HAL_RTL8822B #################################
+ifeq ($(CONFIG_RTL8822B), y)
+RTL871X := rtl8822b
+ifeq ($(CONFIG_USB_HCI), y)
+ifeq ($(CONFIG_BT_COEXIST), n)
+MODULE_NAME = 8812bu
+else
+MODULE_NAME = 88x2bu
+endif
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+MODULE_NAME = 88x2be
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 88x2bs
+endif
+
+endif
+########### HAL_RTL8821C #################################
+ifeq ($(CONFIG_RTL8821C), y)
+RTL871X := rtl8821c
+ifeq ($(CONFIG_USB_HCI), y)
+MODULE_NAME = 8821cu
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+MODULE_NAME = 8821ce
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 8821cs
+endif
+
+endif
 ########### AUTO_CFG  #################################
 
 ifeq ($(CONFIG_AUTOCFG_CP), y)
@@ -741,7 +840,6 @@ endif
 
 ########### END OF PATH  #################################
 
-
 ifeq ($(CONFIG_USB_HCI), y)
 ifeq ($(CONFIG_USB_AUTOSUSPEND), y)
 EXTRA_CFLAGS += -DCONFIG_USB_AUTOSUSPEND
@@ -814,8 +912,7 @@ endif
 ifeq ($(CONFIG_LOAD_PHY_PARA_FROM_FILE), y)
 EXTRA_CFLAGS += -DCONFIG_LOAD_PHY_PARA_FROM_FILE
 #EXTRA_CFLAGS += -DREALTEK_CONFIG_PATH_WITH_IC_NAME_FOLDER
-#EXTRA_CFLAGS += -DREALTEK_CONFIG_PATH=\"/lib/firmware/\"
-EXTRA_CFLAGS += -DREALTEK_CONFIG_PATH=\"\"
+EXTRA_CFLAGS += -DREALTEK_CONFIG_PATH=\"/lib/firmware/\"
 endif
 
 ifeq ($(CONFIG_TXPWR_BY_RATE_EN), n)
@@ -834,6 +931,10 @@ else ifeq ($(CONFIG_TXPWR_LIMIT_EN), auto)
 EXTRA_CFLAGS += -DCONFIG_TXPWR_LIMIT_EN=2
 endif
 
+ifneq ($(CONFIG_RTW_CHPLAN), 0xFF)
+EXTRA_CFLAGS += -DCONFIG_RTW_CHPLAN=$(CONFIG_RTW_CHPLAN)
+endif
+
 ifeq ($(CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY), y)
 EXTRA_CFLAGS += -DCONFIG_CALIBRATE_TX_POWER_BY_REGULATORY
 endif
@@ -863,7 +964,7 @@ EXTRA_CFLAGS += -DCONFIG_IEEE80211W
 endif
 
 ifeq ($(CONFIG_WOWLAN), y)
-EXTRA_CFLAGS += -DCONFIG_WOWLAN
+EXTRA_CFLAGS += -DCONFIG_WOWLAN -DRTW_WAKEUP_EVENT=$(CONFIG_WAKEUP_TYPE)
 ifeq ($(CONFIG_SDIO_HCI), y)
 EXTRA_CFLAGS += -DCONFIG_RTW_SDIO_PM_KEEP_POWER
 endif
@@ -912,9 +1013,6 @@ EXTRA_CFLAGS += -DCONFIG_BR_EXT
 EXTRA_CFLAGS += '-DCONFIG_BR_EXT_BRNAME="'$(BR_NAME)'"'
 endif
 
-ifeq ($(CONFIG_ANTENNA_DIVERSITY), y)
-EXTRA_CFLAGS += -DCONFIG_ANTENNA_DIVERSITY
-endif
 
 ifeq ($(CONFIG_TDLS), y)
 EXTRA_CFLAGS += -DCONFIG_TDLS
@@ -924,6 +1022,39 @@ ifeq ($(CONFIG_WIFI_MONITOR), y)
 EXTRA_CFLAGS += -DCONFIG_WIFI_MONITOR
 endif
 
+ifeq ($(CONFIG_MCC_MODE), y)
+EXTRA_CFLAGS += -DCONFIG_MCC_MODE
+endif
+
+ifeq ($(CONFIG_RTW_NAPI), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_NAPI
+endif
+
+ifeq ($(CONFIG_RTW_GRO), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_GRO
+endif
+
+ifeq ($(CONFIG_RTW_REPEATER_SON), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_REPEATER_SON
+endif
+
+ifeq ($(CONFIG_RTW_IPCAM_APPLICATION), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_IPCAM_APPLICATION
+ifeq ($(CONFIG_WIFI_MONITOR), n)
+EXTRA_CFLAGS += -DCONFIG_WIFI_MONITOR
+endif
+endif
+
+ifeq ($(CONFIG_RTW_NETIF_SG), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_NETIF_SG
+endif
+
+ifeq ($(CONFIG_RTW_WIFI_HAL), y)
+#EXTRA_CFLAGS += -DCONFIG_RTW_WIFI_HAL_DEBUG
+EXTRA_CFLAGS += -DCONFIG_RTW_WIFI_HAL
+EXTRA_CFLAGS += -DCONFIG_RTW_CFGVEDNOR_LLSTATS
+endif
+
 ifeq ($(CONFIG_MP_VHT_HW_TX_MODE), y)
 EXTRA_CFLAGS += -DCONFIG_MP_VHT_HW_TX_MODE
 ifeq ($(CONFIG_PLATFORM_I386_PC), y)
@@ -935,6 +1066,15 @@ EXTRA_CFLAGS += -mfloat-abi=hard
 endif
 endif
 
+ifeq ($(CONFIG_APPEND_VENDOR_IE_ENABLE), y)
+EXTRA_CFLAGS += -DCONFIG_APPEND_VENDOR_IE_ENABLE
+endif
+
+ifeq ($(CONFIG_RTW_DEBUG), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_DEBUG
+EXTRA_CFLAGS += -DRTW_LOG_LEVEL=$(CONFIG_RTW_LOG_LEVEL)
+endif
+
 EXTRA_CFLAGS += -DDM_ODM_SUPPORT_TYPE=0x04
 
 ifeq ($(CONFIG_PLATFORM_I386_PC), y)
@@ -947,6 +1087,39 @@ KVER  := $(shell uname -r)
 KSRC := /lib/modules/$(KVER)/build
 MODDESTDIR := /lib/modules/$(KVER)/kernel/drivers/net/wireless/
 INSTALL_PREFIX :=
+STAGINGMODDIR := /lib/modules/$(KVER)/kernel/drivers/staging
+endif
+
+ifeq ($(CONFIG_PLATFORM_NV_TK1), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_NV_TK1
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+# default setting for Android 4.1, 4.2
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_P2P_IPS -DCONFIG_PLATFORM_ANDROID
+# Enable this for Android 5.0
+EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+EXTRA_CFLAGS += -DRTW_VENDOR_EXT_SUPPORT
+EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
+ARCH ?= arm
+
+CROSS_COMPILE := /mnt/newdisk/android_sdk/nvidia_tk1/android_L/prebuilts/gcc/linux-x86/arm/arm-eabi-4.8/bin/arm-eabi-
+KSRC :=/mnt/newdisk/android_sdk/nvidia_tk1/android_L/out/target/product/shieldtablet/obj/KERNEL/
+MODULE_NAME = wlan
+endif
+
+ifeq ($(CONFIG_PLATFORM_NV_TK1_UBUNTU), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_NV_TK1
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+
+ARCH ?= arm
+
+CROSS_COMPILE ?=
+KVER := $(shell uname -r)
+KSRC := /lib/modules/$(KVER)/build
+MODDESTDIR := /lib/modules/$(KVER)/kernel/drivers/net/wireless/
+INSTALL_PREFIX :=
 endif
 
 ifeq ($(CONFIG_PLATFORM_ACTIONS_ATM702X), y)
@@ -1028,8 +1201,12 @@ endif
 ifeq ($(CONFIG_PLATFORM_MSTAR), y)
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
-EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_MSTAR -DCONFIG_USE_USB_BUFFER_ALLOC_TX -DCONFIG_FIX_NR_BULKIN_BUFFER -DCONFIG_PREALLOC_RX_SKB_BUFFER
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_MSTAR
 EXTRA_CFLAGS += -DCONFIG_PLATFORM_MSTAR_HIGH
+ifeq ($(CONFIG_USB_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX -DCONFIG_FIX_NR_BULKIN_BUFFER
+endif
 ARCH:=arm
 CROSS_COMPILE:= /usr/src/bin/arm-none-linux-gnueabi-
 KVER:= 3.1.10
@@ -1271,28 +1448,18 @@ EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID -DCONFIG_PLATFO
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
 # default setting for Power control
-#EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
+EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
 #EXTRA_CFLAGS += -DRTW_SUPPORT_PLATFORM_SHUTDOWN
 # default setting for Special function
-
-ifeq ($(CONFIG_ANDROID_4_2), y)
-EXTRA_CFLAGS += -DCONFIG_ANDROID_4_2 -DCONFIG_MINIMAL_MEMORY_USAGE
-else
-ifeq ($(CONFIG_ANDROID_4_4_Kernel_3_0), y)
-else
-EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
-endif
-endif
 ARCH := arm
 CROSS_COMPILE := /home/android_sdk/Rockchip/Rk3188/prebuilts/gcc/linux-x86/arm/arm-eabi-4.6/bin/arm-eabi-
 KSRC := /home/android_sdk/Rockchip/Rk3188/kernel
-MODULE_NAME := 8189fs
+MODULE_NAME := wlan
 endif
 
 ifeq ($(CONFIG_PLATFORM_ARM_RK3066), y)
 EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_RK3066
-EXTRA_CFLAGS += -DCONFIG_PLATFORM_ROCKCHIPS -DCONFIG_PLATFORM_ANDROID
-#EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
+EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
@@ -1340,17 +1507,6 @@ KVER:= 2.6.31.6
 KSRC:= ../code/linux-2.6.31.6-2020/
 endif
 
-#Add setting for MN10300
-ifeq ($(CONFIG_PLATFORM_MN10300), y)
-EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_MN10300
-ARCH := mn10300
-CROSS_COMPILE := mn10300-linux-
-KVER := 2.6.32.2
-KSRC := /home/winuser/work/Plat_sLD2T_V3010/usr/src/linux-2.6.32.2
-INSTALL_PREFIX :=
-endif
-
-
 ifeq ($(CONFIG_PLATFORM_ARM_SUNxI), y)
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
 EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUNxI
@@ -1504,10 +1660,9 @@ endif
 
 ifeq ($(CONFIG_PLATFORM_ARM_RTD299X), y)
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
-EXTRA_CFLAGS += -DUSB_XMITBUF_ALIGN_SZ=1024 -DUSB_PACKET_OFFSET_SZ=0
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
-ifeq ($(CONFIG_ANDROID), y)
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+ifeq ($(CONFIG_ANDROID), y)
 # Enable this for Android 5.0
 EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
 endif
@@ -1531,6 +1686,39 @@ ifeq ($(KSRC),)
 endif
 endif
 
+ifeq ($(CONFIG_PLATFORM_HISILICON_HI3798), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON_HI3798
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+# default setting for Android
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
+EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
+# default setting for Android 5.x and later
+#EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
+_PLATFORM_FILES += platform/platform_hisilicon_hi3798_sdio.o
+EXTRA_CFLAGS += -DCONFIG_HISI_SDIO_ID=1
+endif
+
+ARCH ?= arm
+CROSS_COMPILE ?= /HiSTBAndroidV600R003C00SPC021_git_0512/device/hisilicon/bigfish/sdk/tools/linux/toolchains/arm-histbv310-linux/bin/arm-histbv310-linux-
+ifndef KSRC
+KSRC := /HiSTBAndroidV600R003C00SPC021_git_0512/device/hisilicon/bigfish/sdk/source/kernel/linux-3.18.y
+KSRC += O=/HiSTBAndroidV600R003C00SPC021_git_0512/out/target/product/Hi3798MV200/obj/KERNEL_OBJ
+endif
+
+ifeq ($(CONFIG_RTL8822B), y)
+ifeq ($(CONFIG_SDIO_HCI), y)
+CONFIG_RTL8822BS ?= m
+USER_MODULE_NAME := rtl8822bs
+endif
+endif
+
+endif
+
 # Platform setting
 ifeq ($(CONFIG_PLATFORM_ARM_SPREADTRUM_6820), y)
 ifeq ($(CONFIG_ANDROID_2X), y)
@@ -1584,6 +1772,7 @@ EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
 EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
 # default setting for Android 4.1, 4.2
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IFACE_NUMBER=3
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
 #EXTRA_CFLAGS +=  -DCONFIG_QOS_OPTIMIZATION
 EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
@@ -1609,6 +1798,58 @@ MODULE_NAME := 8192eu
 
 endif
 
+ifeq ($(CONFIG_PLATFORM_RTK129X), y)
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DRTK_129X_PLATFORM
+EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
+# default setting for Android 4.1, 4.2
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+#EXTRA_CFLAGS += -DCONFIG_P2P_IPS -DCONFIG_QOS_OPTIMIZATION
+EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
+# Enable this for Android 5.0
+EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+ifeq ($(CONFIG_RTL8821C)$(CONFIG_SDIO_HCI),yy)
+EXTRA_CFLAGS += -DCONFIG_WAKEUP_GPIO_INPUT_MODE
+EXTRA_CFLAGS += -DCONFIG_BT_WAKE_HST_OPEN_DRAIN
+endif
+EXTRA_CFLAGS += -Wno-error=date-time
+# default setting for Android 7.0
+ifeq ($(RTK_ANDROID_VERSION), nougat)
+EXTRA_CFLAGS += -DRTW_P2P_GROUP_INTERFACE=1
+endif
+#EXTRA_CFLAGS += -DCONFIG_#PLATFORM_OPS
+ifeq ($(CONFIG_USB_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
+endif
+
+ARCH := arm64
+
+# ==== Cross compile setting for Android 4.4 SDK =====
+#CROSS_COMPILE := arm-linux-gnueabihf-
+#KVER  := 4.1.10
+#CROSS_COMPILE := $(CROSS)
+#KSRC := $(LINUX_KERNEL_PATH)
+CROSS_COMPILE := /home/android_sdk/DHC/trunk-6.0.0_r1-QA160627/phoenix/toolchain/asdk64-4.9.4-a53-EL-3.10-g2.19-a64nt-160307/bin/asdk64-linux-
+KSRC := /home/android_sdk/DHC/trunk-6.0.0_r1-QA160627/linux-kernel
+endif
+
+ifeq ($(CONFIG_PLATFORM_RTK390X), y)
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_RTK390X
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+EXTRA_CFLAGS += -DCONFIG_RTW_NETIF_SG
+ifeq ($(CONFIG_USB_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
+endif
+
+ARCH:=rlx
+
+CROSS_COMPILE:=mips-linux-
+KSRC:= /home/realtek/share/Develop/IPCAM_SDK/RealSil/rts3901_sdk_v1.2_vanilla/linux-3.10
+
+endif
+
 ifeq ($(CONFIG_PLATFORM_NOVATEK_NT72668), y)
 EXTRA_CFLAGS += -DCONFIG_PLATFORM_NOVATEK_NT72668
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
@@ -1634,6 +1875,76 @@ KSRC := /home/android_sdk/Telechips/v13.05_r1-tcc-android-4.2.2_tcc893x-evm_buil
 MODULE_NAME := wlan
 endif 
 
+ifeq ($(CONFIG_PLATFORM_RTL8197D), y)
+EXTRA_CFLAGS += -DCONFIG_BIG_ENDIAN -DCONFIG_PLATFORM_RTL8197D
+export DIR_LINUX=$(shell pwd)/../SDK/rlxlinux-sdk321-v50/linux-2.6.30
+ARCH ?= rlx
+CROSS_COMPILE:= $(DIR_LINUX)/../toolchain/rsdk-1.5.5-5281-EB-2.6.30-0.9.30.3-110714/bin/rsdk-linux-
+KSRC := $(DIR_LINUX)
+endif
+
+ifeq ($(CONFIG_PLATFORM_AML_S905), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_AML_S905
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -fno-pic
+# default setting for Android
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
+EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
+# default setting for Android 5.x and later
+EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
+_PLATFORM_FILES += platform/platform_aml_s905_sdio.o
+endif
+
+ARCH ?= arm64
+CROSS_COMPILE ?= /4.4_S905L_8822bs_compile/gcc-linaro-aarch64-linux-gnu-4.9-2014.09_linux/bin/aarch64-linux-gnu-
+ifndef KSRC
+KSRC := /4.4_S905L_8822bs_compile/common
+# To locate output files in a separate directory.
+KSRC += O=/4.4_S905L_8822bs_compile/KERNEL_OBJ
+endif
+
+ifeq ($(CONFIG_RTL8822B), y)
+ifeq ($(CONFIG_SDIO_HCI), y)
+CONFIG_RTL8822BS ?= m
+USER_MODULE_NAME := 8822bs
+endif
+endif
+
+endif
+
+ifeq ($(CONFIG_PLATFORM_ZTE_ZX296716), y)
+EXTRA_CFLAGS += -Wno-error=date-time
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_ZTE_ZX296716
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+# default setting for Android
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
+EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
+# default setting for Android 5.x and later
+#EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+# mark this temporarily
+#EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
+#_PLATFORM_FILES += platform/platform_zte_zx296716_sdio.o
+endif
+
+ARCH ?= arm64
+CROSS_COMPILE ?=
+KSRC ?=
+
+ifeq ($(CONFIG_RTL8822B), y)
+ifeq ($(CONFIG_SDIO_HCI), y)
+CONFIG_RTL8822BS ?= m
+USER_MODULE_NAME := 8822bs
+endif
+endif
+
+endif
+
 ifeq ($(CONFIG_MULTIDRV), y)
 
 ifeq ($(CONFIG_SDIO_HCI), y)
@@ -1658,6 +1969,19 @@ endif
 
 ifneq ($(KERNELRELEASE),)
 
+########### this part for *.mk ############################
+include $(src)/hal/phydm/phydm.mk
+
+########### HAL_RTL8822B #################################
+ifeq ($(CONFIG_RTL8822B), y)
+include $(src)/rtl8822b.mk
+endif
+
+########### HAL_RTL8821C #################################
+ifeq ($(CONFIG_RTL8821C), y)
+include $(src)/rtl8821c.mk
+endif
+
 rtk_core :=	core/rtw_cmd.o \
 		core/rtw_security.o \
 		core/rtw_debug.o \
@@ -1667,6 +1991,7 @@ rtk_core :=	core/rtw_cmd.o \
 		core/rtw_ieee80211.o \
 		core/rtw_mlme.o \
 		core/rtw_mlme_ext.o \
+		core/rtw_mi.o \
 		core/rtw_wlan_util.o \
 		core/rtw_vht.o \
 		core/rtw_pwrctrl.o \
@@ -1674,17 +1999,28 @@ rtk_core :=	core/rtw_cmd.o \
 		core/rtw_recv.o \
 		core/rtw_sta_mgt.o \
 		core/rtw_ap.o \
+		core/mesh/rtw_mesh.o \
+		core/mesh/rtw_mesh_pathtbl.o \
+		core/mesh/rtw_mesh_hwmp.o \
 		core/rtw_xmit.o	\
 		core/rtw_p2p.o \
+		core/rtw_rson.o \
 		core/rtw_tdls.o \
 		core/rtw_br_ext.o \
 		core/rtw_iol.o \
 		core/rtw_sreset.o \
+		core/rtw_btcoex_wifionly.o \
 		core/rtw_btcoex.o \
 		core/rtw_beamforming.o \
 		core/rtw_odm.o \
+		core/rtw_rm.o \
+		core/rtw_rm_fsm.o \
 		core/efuse/rtw_efuse.o 
 
+ifeq ($(CONFIG_SDIO_HCI), y)
+rtk_core += core/rtw_sdio.o
+endif
+
 $(MODULE_NAME)-y += $(rtk_core)
 
 $(MODULE_NAME)-$(CONFIG_INTEL_WIDI) += core/rtw_intel_widi.o
@@ -1694,11 +2030,11 @@ $(MODULE_NAME)-$(CONFIG_WAPI_SUPPORT) += core/rtw_wapi.o	\
 
 $(MODULE_NAME)-y += $(_OS_INTFS_FILES)
 $(MODULE_NAME)-y += $(_HAL_INTFS_FILES)
-$(MODULE_NAME)-y += $(_OUTSRC_FILES)
+$(MODULE_NAME)-y += $(_PHYDM_FILES)
+$(MODULE_NAME)-y += $(_BTC_FILES)
 $(MODULE_NAME)-y += $(_PLATFORM_FILES)
 
-$(MODULE_NAME)-$(CONFIG_MP_INCLUDED) += core/rtw_mp.o \
-					core/rtw_mp_ioctl.o
+$(MODULE_NAME)-$(CONFIG_MP_INCLUDED) += core/rtw_mp.o
 
 ifeq ($(CONFIG_RTL8723B), y)
 $(MODULE_NAME)-$(CONFIG_MP_INCLUDED)+= core/rtw_bt_mp.o
@@ -1726,6 +2062,40 @@ uninstall:
 	rm -f $(MODDESTDIR)/$(MODULE_NAME).ko
 	/sbin/depmod -a ${KVER}
 
+backup_rtlwifi:
+	@echo "Making backup rtlwifi drivers"
+ifneq (,$(wildcard $(STAGINGMODDIR)/rtl*))
+	@tar cPf $(wildcard $(STAGINGMODDIR))/backup_rtlwifi_driver.tar $(wildcard $(STAGINGMODDIR)/rtl*)
+	@rm -rf $(wildcard $(STAGINGMODDIR)/rtl*)
+endif
+ifneq (,$(wildcard $(MODDESTDIR)realtek))
+	@tar cPf $(MODDESTDIR)backup_rtlwifi_driver.tar $(MODDESTDIR)realtek
+	@rm -fr $(MODDESTDIR)realtek
+endif
+ifneq (,$(wildcard $(MODDESTDIR)rtl*))
+	@tar cPf $(MODDESTDIR)../backup_rtlwifi_driver.tar $(wildcard $(MODDESTDIR)rtl*)
+	@rm -fr $(wildcard $(MODDESTDIR)rtl*)
+endif
+	@/sbin/depmod -a ${KVER}
+	@echo "Please reboot your system"
+
+restore_rtlwifi:
+	@echo "Restoring backups"
+ifneq (,$(wildcard $(STAGINGMODDIR)/backup_rtlwifi_driver.tar))
+	@tar xPf $(STAGINGMODDIR)/backup_rtlwifi_driver.tar
+	@rm $(STAGINGMODDIR)/backup_rtlwifi_driver.tar
+endif
+ifneq (,$(wildcard $(MODDESTDIR)backup_rtlwifi_driver.tar))
+	@tar xPf $(MODDESTDIR)backup_rtlwifi_driver.tar
+	@rm $(MODDESTDIR)backup_rtlwifi_driver.tar
+endif
+ifneq (,$(wildcard $(MODDESTDIR)../backup_rtlwifi_driver.tar))
+	@tar xPf $(MODDESTDIR)../backup_rtlwifi_driver.tar
+	@rm $(MODDESTDIR)../backup_rtlwifi_driver.tar
+endif
+	@/sbin/depmod -a ${KVER}
+	@echo "Please reboot your system"
+
 config_r:
 	@echo "make config"
 	/bin/bash script/Configure script/config.in
@@ -1734,13 +2104,12 @@ config_r:
 .PHONY: modules clean
 
 clean:
-	cd hal/phydm/ ; rm -fr */*.mod.c */*.mod */*.o */.*.cmd */*.ko
-	cd hal/phydm/ ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
-	cd hal/led ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
+	#$(MAKE) -C $(KSRC) M=$(shell pwd) clean
+	cd hal ; rm -fr */*/*/*.mod.c */*/*/*.mod */*/*/*.o */*/*/.*.cmd */*/*/*.ko
 	cd hal ; rm -fr */*/*.mod.c */*/*.mod */*/*.o */*/.*.cmd */*/*.ko
 	cd hal ; rm -fr */*.mod.c */*.mod */*.o */.*.cmd */*.ko
 	cd hal ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
-	cd core/efuse ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
+	cd core ; rm -fr */*.mod.c */*.mod */*.o */.*.cmd */*.ko
 	cd core ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
 	cd os_dep/linux ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
 	cd os_dep ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/efuse/rtw_efuse.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/efuse/rtw_efuse.c
index 06e34f2ef51f..84e27657e30f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/efuse/rtw_efuse.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/efuse/rtw_efuse.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,64 +12,1791 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_EFUSE_C_
 
-#include <drv_types.h>
-#include <hal_data.h>
+#include <drv_types.h>
+#include <hal_data.h>
+
+#include "../hal/efuse/efuse_mask.h"
+
+/*------------------------Define local variable------------------------------*/
+u8	fakeEfuseBank = {0};
+u32	fakeEfuseUsedBytes = {0};
+u8	fakeEfuseContent[EFUSE_MAX_HW_SIZE] = {0};
+u8	fakeEfuseInitMap[EFUSE_MAX_MAP_LEN] = {0};
+u8	fakeEfuseModifiedMap[EFUSE_MAX_MAP_LEN] = {0};
+
+u32	BTEfuseUsedBytes = {0};
+u8	BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
+u8	BTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN] = {0};
+u8	BTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN] = {0};
+
+u32	fakeBTEfuseUsedBytes = {0};
+u8	fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
+u8	fakeBTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN] = {0};
+u8	fakeBTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN] = {0};
+
+u8	maskfileBuffer[64];
+/*------------------------Define local variable------------------------------*/
+BOOLEAN rtw_file_efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
+{
+	int r = Offset / 16;
+	int c = (Offset % 16) / 2;
+	int result = 0;
+
+	if (pAdapter->registrypriv.boffefusemask)
+		return FALSE;
+
+	if (c < 4) /* Upper double word */
+		result = (maskfileBuffer[r] & (0x10 << c));
+	else
+		result = (maskfileBuffer[r] & (0x01 << (c - 4)));
+
+	return (result > 0) ? 0 : 1;
+}
+
+BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
+{
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
+
+	if (pAdapter->registrypriv.boffefusemask)
+		return FALSE;
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		return (IS_MASKED(8188E, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8812A)
+	if (IS_HARDWARE_TYPE_8812(pAdapter))
+		return (IS_MASKED(8812A, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8821A)
+#if 0
+	if (IS_HARDWARE_TYPE_8811AU(pAdapter))
+		return (IS_MASKED(8811A, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+	if (IS_HARDWARE_TYPE_8821(pAdapter))
+		return (IS_MASKED(8821A, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192E(pAdapter))
+		return (IS_MASKED(8192E, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723B(pAdapter))
+		return (IS_MASKED(8723B, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8703B)
+	if (IS_HARDWARE_TYPE_8703B(pAdapter))
+		return (IS_MASKED(8703B, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8814A)
+	if (IS_HARDWARE_TYPE_8814A(pAdapter))
+		return (IS_MASKED(8814A, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8188F)
+	if (IS_HARDWARE_TYPE_8188F(pAdapter))
+		return (IS_MASKED(8188F, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return (IS_MASKED(8188GTV, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		return (IS_MASKED(8822B, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8723D)
+	if (IS_HARDWARE_TYPE_8723D(pAdapter))
+		return (IS_MASKED(8723D, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CU(pAdapter))
+		return (IS_MASKED(8821C, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+
+#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		return (IS_MASKED(8188E, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192E(pAdapter))
+		return (IS_MASKED(8192E, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8812A)
+	if (IS_HARDWARE_TYPE_8812(pAdapter))
+		return (IS_MASKED(8812A, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821(pAdapter))
+		return (IS_MASKED(8821A, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723B(pAdapter))
+		return (IS_MASKED(8723B, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8814A)
+	if (IS_HARDWARE_TYPE_8814A(pAdapter))
+		return (IS_MASKED(8814A, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		return (IS_MASKED(8822B, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CE(pAdapter))
+		return (IS_MASKED(8821C, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+
+#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+#ifdef CONFIG_RTL8188E_SDIO
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		return (IS_MASKED(8188E, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#ifdef CONFIG_RTL8723B
+	if (IS_HARDWARE_TYPE_8723BS(pAdapter))
+		return (IS_MASKED(8723B, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#ifdef CONFIG_RTL8188F
+	if (IS_HARDWARE_TYPE_8188F(pAdapter))
+		return (IS_MASKED(8188F, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#ifdef CONFIG_RTL8188GTV
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return (IS_MASKED(8188GTV, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#ifdef CONFIG_RTL8192E
+	if (IS_HARDWARE_TYPE_8192ES(pAdapter))
+		return (IS_MASKED(8192E, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821S(pAdapter))
+		return (IS_MASKED(8821A, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CS(pAdapter))
+		return (IS_MASKED(8821C, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		return (IS_MASKED(8822B, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
+#endif
+
+	return FALSE;
+}
+
+void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
+{
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		GET_MASK_ARRAY(8188E, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8812A)
+	if (IS_HARDWARE_TYPE_8812(pAdapter))
+		GET_MASK_ARRAY(8812A, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821(pAdapter))
+		GET_MASK_ARRAY(8821A, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192E(pAdapter))
+		GET_MASK_ARRAY(8192E, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723B(pAdapter))
+		GET_MASK_ARRAY(8723B, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8703B)
+	if (IS_HARDWARE_TYPE_8703B(pAdapter))
+		GET_MASK_ARRAY(8703B, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8188F)
+	if (IS_HARDWARE_TYPE_8188F(pAdapter))
+		GET_MASK_ARRAY(8188F, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		GET_MASK_ARRAY(8188GTV, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8814A)
+	if (IS_HARDWARE_TYPE_8814A(pAdapter))
+		GET_MASK_ARRAY(8814A, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		GET_MASK_ARRAY(8822B, _MUSB, pArray);
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CU(pAdapter))
+		GET_MASK_ARRAY(8821C, _MUSB, pArray);
+#endif
+
+
+#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		GET_MASK_ARRAY(8188E, _MPCIE, pArray);
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192E(pAdapter))
+		GET_MASK_ARRAY(8192E, _MPCIE, pArray);
+#endif
+#if defined(CONFIG_RTL8812A)
+	if (IS_HARDWARE_TYPE_8812(pAdapter))
+		GET_MASK_ARRAY(8812A, _MPCIE, pArray);
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821(pAdapter))
+		GET_MASK_ARRAY(8821A, _MPCIE, pArray);
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723B(pAdapter))
+		GET_MASK_ARRAY(8723B, _MPCIE, pArray);
+#endif
+#if defined(CONFIG_RTL8814A)
+	if (IS_HARDWARE_TYPE_8814A(pAdapter))
+		GET_MASK_ARRAY(8814A, _MPCIE, pArray);
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		GET_MASK_ARRAY(8822B, _MPCIE, pArray);
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CE(pAdapter))
+		GET_MASK_ARRAY(8821C, _MPCIE, pArray);
+#endif
+
+
+#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		GET_MASK_ARRAY(8188E, _MSDIO, pArray);
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723BS(pAdapter))
+		GET_MASK_ARRAY(8723B, _MSDIO, pArray);
+#endif
+#if defined(CONFIG_RTL8188F)
+	if (IS_HARDWARE_TYPE_8188F(pAdapter))
+		GET_MASK_ARRAY(8188F, _MSDIO, pArray);
+#endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		GET_MASK_ARRAY(8188GTV, _MSDIO, pArray);
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192ES(pAdapter))
+		GET_MASK_ARRAY(8192E, _MSDIO, pArray);
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821S(pAdapter))
+		GET_MASK_ARRAY(8821A, _MSDIO, pArray);
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CS(pAdapter))
+		GET_MASK_ARRAY(8821C , _MSDIO, pArray);
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		GET_MASK_ARRAY(8822B , _MSDIO, pArray);
+#endif
+#endif /*#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE*/
+}
+
+u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188E, _MUSB);
+#endif
+#if defined(CONFIG_RTL8812A)
+	if (IS_HARDWARE_TYPE_8812(pAdapter))
+		return GET_MASK_ARRAY_LEN(8812A, _MUSB);
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821(pAdapter))
+		return GET_MASK_ARRAY_LEN(8821A, _MUSB);
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192E(pAdapter))
+		return GET_MASK_ARRAY_LEN(8192E, _MUSB);
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723B(pAdapter))
+		return GET_MASK_ARRAY_LEN(8723B, _MUSB);
+#endif
+#if defined(CONFIG_RTL8703B)
+	if (IS_HARDWARE_TYPE_8703B(pAdapter))
+		return GET_MASK_ARRAY_LEN(8703B, _MUSB);
+#endif
+#if defined(CONFIG_RTL8188F)
+	if (IS_HARDWARE_TYPE_8188F(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188F, _MUSB);
+#endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188GTV, _MUSB);
+#endif
+#if defined(CONFIG_RTL8814A)
+	if (IS_HARDWARE_TYPE_8814A(pAdapter))
+		return GET_MASK_ARRAY_LEN(8814A, _MUSB);
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		return GET_MASK_ARRAY_LEN(8822B, _MUSB);
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CU(pAdapter))
+		return GET_MASK_ARRAY_LEN(8821C, _MUSB);
+#endif
+
+
+#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188E, _MPCIE);
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192E(pAdapter))
+		return GET_MASK_ARRAY_LEN(8192E, _MPCIE);
+#endif
+#if defined(CONFIG_RTL8812A)
+	if (IS_HARDWARE_TYPE_8812(pAdapter))
+		return GET_MASK_ARRAY_LEN(8812A, _MPCIE);
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821(pAdapter))
+		return GET_MASK_ARRAY_LEN(8821A, _MPCIE);
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723B(pAdapter))
+		return GET_MASK_ARRAY_LEN(8723B, _MPCIE);
+#endif
+#if defined(CONFIG_RTL8814A)
+	if (IS_HARDWARE_TYPE_8814A(pAdapter))
+		return GET_MASK_ARRAY_LEN(8814A, _MPCIE);
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		return GET_MASK_ARRAY_LEN(8822B, _MPCIE);
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CE(pAdapter))
+		return GET_MASK_ARRAY_LEN(8821C, _MPCIE);
+#endif
+
+
+#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+#if defined(CONFIG_RTL8188E)
+	if (IS_HARDWARE_TYPE_8188E(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188E, _MSDIO);
+#endif
+#if defined(CONFIG_RTL8723B)
+	if (IS_HARDWARE_TYPE_8723BS(pAdapter))
+		return GET_MASK_ARRAY_LEN(8723B, _MSDIO);
+#endif
+#if defined(CONFIG_RTL8188F)
+	if (IS_HARDWARE_TYPE_8188F(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188F, _MSDIO);
+#endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188GTV, _MSDIO);
+#endif
+#if defined(CONFIG_RTL8192E)
+	if (IS_HARDWARE_TYPE_8192ES(pAdapter))
+		return GET_MASK_ARRAY_LEN(8192E, _MSDIO);
+#endif
+#if defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_8821S(pAdapter))
+		return GET_MASK_ARRAY_LEN(8821A, _MSDIO);
+#endif
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821CS(pAdapter))
+		return GET_MASK_ARRAY_LEN(8821C, _MSDIO);
+#endif
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(pAdapter))
+		return GET_MASK_ARRAY_LEN(8822B, _MSDIO);
+#endif
+#endif
+	return 0;
+}
+
+static void rtw_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
+{
+	u16 i = 0;
+
+	if (padapter->registrypriv.boffefusemask == 0) {
+
+			for (i = 0; i < cnts; i++) {
+				if (padapter->registrypriv.bFileMaskEfuse == _TRUE) {
+					if (rtw_file_efuse_IsMasked(padapter, addr + i)) /*use file efuse mask.*/
+						data[i] = 0xff;
+				} else {
+					/*RTW_INFO(" %s , data[%d] = %x\n", __func__, i, data[i]);*/
+					if (efuse_IsMasked(padapter, addr + i)) {
+						data[i] = 0xff;
+						/*RTW_INFO(" %s ,mask data[%d] = %x\n", __func__, i, data[i]);*/
+					}
+				}
+			}
+
+	}
+}
+
+u8 rtw_efuse_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
+{
+	u8	ret = _SUCCESS;
+	u16	mapLen = 0;
+
+	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, _FALSE);
+
+	ret = rtw_efuse_map_read(padapter, addr, cnts , data);
+
+	rtw_mask_map_read(padapter, addr, cnts , data);
+
+	return ret;
+
+}
+
+/* ***********************************************************
+ *				Efuse related code
+ * *********************************************************** */
+static u8 hal_EfuseSwitchToBank(
+	PADAPTER	padapter,
+	u8			bank,
+	u8			bPseudoTest)
+{
+	u8 bRet = _FALSE;
+	u32 value32 = 0;
+#ifdef HAL_EFUSE_MEMORY
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+	PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
+#endif
+
+
+	RTW_INFO("%s: Efuse switch bank to %d\n", __FUNCTION__, bank);
+	if (bPseudoTest) {
+#ifdef HAL_EFUSE_MEMORY
+		pEfuseHal->fakeEfuseBank = bank;
+#else
+		fakeEfuseBank = bank;
+#endif
+		bRet = _TRUE;
+	} else {
+		value32 = rtw_read32(padapter, 0x34);
+		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;
+		}
+		rtw_write32(padapter, 0x34, value32);
+	}
+
+	return bRet;
+}
+
+void rtw_efuse_analyze(PADAPTER	padapter, u8 Type, u8 Fake)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	PEFUSE_HAL		pEfuseHal = &(pHalData->EfuseHal);
+	u16	eFuse_Addr = 0;
+	u8 offset, wden;
+	u16	 i, j;
+	u8	u1temp = 0;
+	u8	efuseHeader = 0, efuseExtHdr = 0, efuseData[EFUSE_MAX_WORD_UNIT*2] = {0}, dataCnt = 0;
+	u16	efuseHeader2Byte = 0;
+	u8	*eFuseWord = NULL;// [EFUSE_MAX_SECTION_NUM][EFUSE_MAX_WORD_UNIT];
+	u8	offset_2_0 = 0;
+	u8	pgSectionCnt = 0;
+	u8	wd_cnt = 0;
+	u8	max_section = 64;
+	u16	mapLen = 0, maprawlen = 0;
+	boolean	bExtHeader = _FALSE;
+	u8	efuseType = EFUSE_WIFI;
+	boolean	bPseudoTest = _FALSE;
+	u8	bank = 0, startBank = 0, endBank = 1-1;
+	boolean	bCheckNextBank = FALSE;
+	u8	protectBytesBank = 0;
+	u16	efuse_max = 0;
+	u8	ParseEfuseExtHdr, ParseEfuseHeader, ParseOffset, ParseWDEN, ParseOffset2_0;
+
+	eFuseWord = rtw_zmalloc(EFUSE_MAX_SECTION_NUM * (EFUSE_MAX_WORD_UNIT * 2));
+
+	RTW_INFO("\n");
+	if (Type == 0) {
+		if (Fake == 0) {
+			RTW_INFO("\n\tEFUSE_Analyze Wifi Content\n");
+			efuseType = EFUSE_WIFI;
+			bPseudoTest = FALSE;
+			startBank = 0;
+			endBank = 0;
+		} else {
+			RTW_INFO("\n\tEFUSE_Analyze Wifi Pseudo Content\n");
+			efuseType = EFUSE_WIFI;
+			bPseudoTest = TRUE;
+			startBank = 0;
+			endBank = 0;
+		}
+	} else {
+		if (Fake == 0) {
+			RTW_INFO("\n\tEFUSE_Analyze BT Content\n");
+			efuseType = EFUSE_BT;
+			bPseudoTest = FALSE;
+			startBank = 1;
+			endBank = EFUSE_MAX_BANK - 1;
+		} else {
+			RTW_INFO("\n\tEFUSE_Analyze BT Pseudo Content\n");
+			efuseType = EFUSE_BT;
+			bPseudoTest = TRUE;
+			startBank = 1;
+			endBank = EFUSE_MAX_BANK - 1;
+			if (IS_HARDWARE_TYPE_8821(padapter))
+				endBank = 3 - 1;/*EFUSE_MAX_BANK_8821A - 1;*/
+		}
+	}
+
+	RTW_INFO("\n\r 1Byte header, [7:4]=offset, [3:0]=word enable\n");
+	RTW_INFO("\n\r 2Byte header, header[7:5]=offset[2:0], header[4:0]=0x0F\n");
+	RTW_INFO("\n\r 2Byte header, extHeader[7:4]=offset[6:3], extHeader[3:0]=word enable\n");
+
+	EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, bPseudoTest);
+	EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_MAX_SECTION, (PVOID)&max_section, bPseudoTest);
+	EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_PROTECT_BYTES_BANK, (PVOID)&protectBytesBank, bPseudoTest);
+	EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_CONTENT_LEN_BANK, (PVOID)&efuse_max, bPseudoTest);
+	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_REAL_CONTENT_LEN, (PVOID)&maprawlen, _FALSE);
+
+	_rtw_memset(eFuseWord, 0xff, EFUSE_MAX_SECTION_NUM * (EFUSE_MAX_WORD_UNIT * 2));
+	_rtw_memset(pEfuseHal->fakeEfuseInitMap, 0xff, EFUSE_MAX_MAP_LEN);
+
+	if (IS_HARDWARE_TYPE_8821(padapter))
+		endBank = 3 - 1;/*EFUSE_MAX_BANK_8821A - 1;*/
+
+	for (bank = startBank; bank <= endBank; bank++) {
+		if (!hal_EfuseSwitchToBank(padapter, bank, bPseudoTest)) {
+			RTW_INFO("EFUSE_SwitchToBank() Fail!!\n");
+			return;
+		}
+
+		eFuse_Addr = bank * EFUSE_MAX_BANK_SIZE;
+
+		efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
+
+		if (efuseHeader == 0xFF && bank == startBank && Fake != TRUE) {
+			RTW_INFO("Non-PGed Efuse\n");
+			return;
+		}
+		RTW_INFO("EFUSE_REAL_CONTENT_LEN = %d\n", maprawlen);
+
+		while ((efuseHeader != 0xFF) && ((efuseType == EFUSE_WIFI && (eFuse_Addr < maprawlen)) || (efuseType == EFUSE_BT && (eFuse_Addr < (endBank + 1) * EFUSE_MAX_BANK_SIZE)))) {
+
+			RTW_INFO("Analyzing: Offset: 0x%X\n", eFuse_Addr);
+
+			/* Check PG header for section num.*/
+			if (EXT_HEADER(efuseHeader)) {
+				bExtHeader = TRUE;
+				offset_2_0 = GET_HDR_OFFSET_2_0(efuseHeader);
+				efuse_OneByteRead(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest);
+
+				if (efuseExtHdr != 0xff) {
+					if (ALL_WORDS_DISABLED(efuseExtHdr)) {
+						/* Read next pg header*/
+						efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
+						continue;
+					} else {
+						offset = ((efuseExtHdr & 0xF0) >> 1) | offset_2_0;
+						wden = (efuseExtHdr & 0x0F);
+						efuseHeader2Byte = (efuseExtHdr<<8)|efuseHeader;
+						RTW_INFO("Find efuseHeader2Byte = 0x%04X, offset=%d, wden=0x%x\n",
+										efuseHeader2Byte, offset, wden);
+					}
+				} else {
+					RTW_INFO("Error, efuse[%d]=0xff, efuseExtHdr=0xff\n", eFuse_Addr-1);
+					break;
+				}
+			} else {
+				offset = ((efuseHeader >> 4) & 0x0f);
+				wden = (efuseHeader & 0x0f);
+			}
+
+			_rtw_memset(efuseData, '\0', EFUSE_MAX_WORD_UNIT * 2);
+			dataCnt = 0;
+
+			if (offset < max_section) {
+				for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
+					/* Check word enable condition in the section	*/
+					if (!(wden & (0x01<<i))) {
+						if (!((efuseType == EFUSE_WIFI && (eFuse_Addr + 2 < maprawlen)) ||
+								(efuseType == EFUSE_BT && (eFuse_Addr + 2 < (endBank + 1) * EFUSE_MAX_BANK_SIZE)))) {
+							RTW_INFO("eFuse_Addr exceeds, break\n");
+							break;
+						}
+						efuse_OneByteRead(padapter, eFuse_Addr++, &efuseData[dataCnt++], bPseudoTest);
+						eFuseWord[(offset * 8) + (i * 2)] = (efuseData[dataCnt - 1]);
+						efuse_OneByteRead(padapter, eFuse_Addr++, &efuseData[dataCnt++], bPseudoTest);
+						eFuseWord[(offset * 8) + (i * 2 + 1)] = (efuseData[dataCnt - 1]);
+					}
+				}
+			}
+
+			if (bExtHeader) {
+				RTW_INFO("Efuse PG Section (%d) = ", pgSectionCnt);
+				RTW_INFO("[ %04X ], [", efuseHeader2Byte);
+
+			} else {
+				RTW_INFO("Efuse PG Section (%d) = ", pgSectionCnt);
+				RTW_INFO("[ %02X ], [", efuseHeader);
+			}
+
+			for (j = 0; j < dataCnt; j++)
+				RTW_INFO(" %02X ", efuseData[j]);
+
+			RTW_INFO("]\n");
+
+
+			if (bExtHeader) {
+				ParseEfuseExtHdr = (efuseHeader2Byte & 0xff00) >> 8;
+				ParseEfuseHeader = (efuseHeader2Byte & 0xff);
+				ParseOffset2_0 = GET_HDR_OFFSET_2_0(ParseEfuseHeader);
+				ParseOffset = ((ParseEfuseExtHdr & 0xF0) >> 1) | ParseOffset2_0;
+				ParseWDEN = (ParseEfuseExtHdr & 0x0F);
+				RTW_INFO("Header=0x%x, ExtHeader=0x%x, ", ParseEfuseHeader, ParseEfuseExtHdr);
+			} else {
+				ParseEfuseHeader = efuseHeader;
+				ParseOffset = ((ParseEfuseHeader >> 4) & 0x0f);
+				ParseWDEN = (ParseEfuseHeader & 0x0f);
+				RTW_INFO("Header=0x%x, ", ParseEfuseHeader);
+			}
+			RTW_INFO("offset=0x%x(%d), word enable=0x%x\n", ParseOffset, ParseOffset, ParseWDEN);
+
+			wd_cnt = 0;
+			for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
+				if (!(wden & (0x01 << i))) {
+					RTW_INFO("Map[ %02X ] = %02X %02X\n", ((offset * EFUSE_MAX_WORD_UNIT * 2) + (i * 2)), efuseData[wd_cnt * 2 + 0], efuseData[wd_cnt * 2 + 1]);
+					wd_cnt++;
+				}
+			}
+
+			pgSectionCnt++;
+			bExtHeader = FALSE;
+			efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
+			if (efuseHeader == 0xFF) {
+				if ((eFuse_Addr + protectBytesBank) >= efuse_max)
+					bCheckNextBank = TRUE;
+				else
+					bCheckNextBank = FALSE;
+			}
+		}
+		if (!bCheckNextBank) {
+			RTW_INFO("Not need to check next bank, eFuse_Addr=%d, protectBytesBank=%d, efuse_max=%d\n",
+				eFuse_Addr, protectBytesBank, efuse_max);
+			break;
+		}
+	}
+	/* switch bank back to 0 for BT/wifi later use*/
+	hal_EfuseSwitchToBank(padapter, 0, bPseudoTest);
+
+	/* 3. Collect 16 sections and 4 word unit into Efuse map.*/
+	for (i = 0; i < max_section; i++) {
+		for (j = 0; j < EFUSE_MAX_WORD_UNIT; j++) {
+			pEfuseHal->fakeEfuseInitMap[(i*8)+(j*2)] = (eFuseWord[(i*8)+(j*2)]);
+			pEfuseHal->fakeEfuseInitMap[(i*8)+((j*2)+1)] =  (eFuseWord[(i*8)+((j*2)+1)]);
+		}
+	}
+
+	RTW_INFO("\n\tEFUSE Analyze Map\n");
+	i = 0;
+	j = 0;
+
+	for (i = 0; i < mapLen; i++) {
+		if (i % 16 == 0)
+			RTW_PRINT_SEL(RTW_DBGDUMP, "0x%03x: ", i);
+			_RTW_PRINT_SEL(RTW_DBGDUMP, "%02X%s"
+				, pEfuseHal->fakeEfuseInitMap[i]
+				, ((i + 1) % 16 == 0) ? "\n" : (((i + 1) % 8 == 0) ? "	  " : " ")
+			);
+		}
+	_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
+	if (eFuseWord)
+		rtw_mfree((u8 *)eFuseWord, EFUSE_MAX_SECTION_NUM * (EFUSE_MAX_WORD_UNIT * 2));
+}
+
+VOID efuse_PreUpdateAction(
+	PADAPTER	pAdapter,
+	pu4Byte	BackupRegs)
+{
+	if (IS_HARDWARE_TYPE_8812AU(pAdapter) || IS_HARDWARE_TYPE_8822BU(pAdapter)) {
+		/* <20131115, Kordan> Turn off Rx to prevent from being busy when writing the EFUSE. (Asked by Chunchu.)*/
+		BackupRegs[0] = phy_query_mac_reg(pAdapter, REG_RCR, bMaskDWord);
+		BackupRegs[1] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord);
+		BackupRegs[2] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord);
+#ifdef CONFIG_RTL8812A
+		BackupRegs[3] = phy_query_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord);
+#endif
+		PlatformEFIOWrite4Byte(pAdapter, REG_RCR, 0x1);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+1, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+2, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+3, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+4, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+5, 0);
+#ifdef CONFIG_RTL8812A
+		/* <20140410, Kordan> 0x11 = 0x4E, lower down LX_SPS0 voltage. (Asked by Chunchu)*/
+		phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskByte1, 0x4E);
+#endif
+		RTW_INFO(" %s , done\n", __func__);
+
+		}
+}
+
+
+VOID efuse_PostUpdateAction(
+	PADAPTER	pAdapter,
+	pu4Byte	BackupRegs)
+{
+	if (IS_HARDWARE_TYPE_8812AU(pAdapter) || IS_HARDWARE_TYPE_8822BU(pAdapter)) {
+		/* <20131115, Kordan> Turn on Rx and restore the registers. (Asked by Chunchu.)*/
+		phy_set_mac_reg(pAdapter, REG_RCR, bMaskDWord, BackupRegs[0]);
+		phy_set_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord, BackupRegs[1]);
+		phy_set_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord, BackupRegs[2]);
+#ifdef CONFIG_RTL8812A
+		phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord, BackupRegs[3]);
+#endif
+	RTW_INFO(" %s , done\n", __func__);
+	}
+}
+
+
+#ifdef RTW_HALMAC
+#include "../../hal/hal_halmac.h"
+
+void Efuse_PowerSwitch(PADAPTER adapter, u8 write, u8 pwrstate)
+{
+}
+
+void BTEfuse_PowerSwitch(PADAPTER adapter, u8 write, u8 pwrstate)
+{
+}
+
+u8 efuse_GetCurrentSize(PADAPTER adapter, u16 *size)
+{
+	*size = 0;
+
+	return _FAIL;
+}
+
+u16 efuse_GetMaxSize(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	u32 size = 0;
+	int err;
+
+	d = adapter_to_dvobj(adapter);
+	err = rtw_halmac_get_physical_efuse_size(d, &size);
+	if (err)
+		return 0;
+
+	return size;
+}
+
+u16 efuse_GetavailableSize(PADAPTER adapter)
+{
+	struct dvobj_priv *d;
+	u32 size = 0;
+	int err;
+
+	d = adapter_to_dvobj(adapter);
+	err = rtw_halmac_get_available_efuse_size(d, &size);
+	if (err)
+		return 0;
+
+	return size;
+}
+
+
+u8 efuse_bt_GetCurrentSize(PADAPTER adapter, u16 *usesize)
+{
+	u8 *efuse_map;
+
+	*usesize = 0;
+	efuse_map = rtw_malloc(EFUSE_BT_MAP_LEN);
+	if (efuse_map == NULL) {
+		RTW_DBG("%s: malloc FAIL\n", __FUNCTION__);
+		return _FAIL;
+	}
+
+	/* for get bt phy efuse last use byte */
+	hal_ReadEFuse_BT_logic_map(adapter, 0x00, EFUSE_BT_MAP_LEN, efuse_map);
+	*usesize = fakeBTEfuseUsedBytes;
+
+	if (efuse_map)
+		rtw_mfree(efuse_map, EFUSE_BT_MAP_LEN);
+
+	return _SUCCESS;
+}
+
+u16 efuse_bt_GetMaxSize(PADAPTER adapter)
+{
+	return EFUSE_BT_REAL_CONTENT_LEN;
+}
+
+void EFUSE_GetEfuseDefinition(PADAPTER adapter, u8 efusetype, u8 type, void *out, BOOLEAN test)
+{
+	struct dvobj_priv *d;
+	u32 v32 = 0;
+
+
+	d = adapter_to_dvobj(adapter);
+
+	if (adapter->hal_func.EFUSEGetEfuseDefinition) {
+		adapter->hal_func.EFUSEGetEfuseDefinition(adapter, efusetype, type, out, test);
+		return;
+	}
+
+	if (EFUSE_WIFI == efusetype) {
+		switch (type) {
+		case TYPE_EFUSE_MAP_LEN:
+			rtw_halmac_get_logical_efuse_size(d, &v32);
+			*(u16 *)out = (u16)v32;
+			return;
+
+		case TYPE_EFUSE_REAL_CONTENT_LEN:	
+			rtw_halmac_get_physical_efuse_size(d, &v32);
+			*(u16 *)out = (u16)v32;
+			return;
+		}
+	} else if (EFUSE_BT == efusetype) {
+		switch (type) {
+		case TYPE_EFUSE_MAP_LEN:
+			*(u16 *)out = EFUSE_BT_MAP_LEN;
+			return;
+
+		case TYPE_EFUSE_REAL_CONTENT_LEN:
+			*(u16 *)out = EFUSE_BT_REAL_CONTENT_LEN;
+			return;
+		}
+	}
+}
+
+/*
+ * read/write raw efuse data
+ */
+u8 rtw_efuse_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data)
+{
+	struct dvobj_priv *d;
+	u8 *efuse = NULL;
+	u32 size, i;
+	int err;
+
+
+	d = adapter_to_dvobj(adapter);
+	err = rtw_halmac_get_physical_efuse_size(d, &size);
+	if (err)
+		size = EFUSE_MAX_SIZE;
+
+	if ((addr + cnts) > size)
+		return _FAIL;
+
+	if (_TRUE == write) {
+		err = rtw_halmac_write_physical_efuse(d, addr, cnts, data);
+		if (err)
+			return _FAIL;
+	} else {
+		if (cnts > 16)
+			efuse = rtw_zmalloc(size);
+
+		if (efuse) {
+			err = rtw_halmac_read_physical_efuse_map(d, efuse, size);
+			if (err) {
+				rtw_mfree(efuse, size);
+				return _FAIL;
+			}
+
+			_rtw_memcpy(data, efuse + addr, cnts);
+			rtw_mfree(efuse, size);
+		} else {
+			err = rtw_halmac_read_physical_efuse(d, addr, cnts, data);
+			if (err)
+				return _FAIL;
+		}
+	}
+
+	return _SUCCESS;
+}
+
+static inline void dump_buf(u8 *buf, u32 len)
+{
+	u32 i;
+
+	RTW_INFO("-----------------Len %d----------------\n", len);
+	for (i = 0; i < len; i++)
+		printk("%2.2x-", *(buf + i));
+	printk("\n");
+}
+
+/*
+ * read/write raw efuse data
+ */
+u8 rtw_efuse_bt_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data)
+{
+	struct dvobj_priv *d;
+	u8 *efuse = NULL;
+	u32 size, i;
+	int err = _FAIL;
+
+
+	d = adapter_to_dvobj(adapter);
+
+	size = EFUSE_BT_REAL_CONTENT_LEN;
+
+	if ((addr + cnts) > size)
+		return _FAIL;
+
+	if (_TRUE == write) {
+		err = rtw_halmac_write_bt_physical_efuse(d, addr, cnts, data);
+		if (err == -1) {
+			RTW_ERR("%s: rtw_halmac_write_bt_physical_efuse fail!\n", __FUNCTION__);
+			return _FAIL;
+		}
+		RTW_INFO("%s: rtw_halmac_write_bt_physical_efuse OK! data 0x%x\n", __FUNCTION__, *data);
+	} else {
+		efuse = rtw_zmalloc(size);
+
+		if (efuse) {
+			err = rtw_halmac_read_bt_physical_efuse_map(d, efuse, size);
+			
+			if (err == -1) {
+				RTW_ERR("%s: rtw_halmac_read_bt_physical_efuse_map fail!\n", __FUNCTION__);
+				rtw_mfree(efuse, size);
+				return _FAIL;
+			}
+			dump_buf(efuse + addr, cnts);
+
+			_rtw_memcpy(data, efuse + addr, cnts);
+
+			RTW_INFO("%s: rtw_halmac_read_bt_physical_efuse_map ok! data 0x%x\n", __FUNCTION__, *data);
+			rtw_mfree(efuse, size);
+		}
+	}
+
+	return _SUCCESS;
+}
+
+u8 rtw_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
+{
+	struct dvobj_priv *d;
+	u8 *efuse = NULL;
+	u32 size, i;
+	int err;
+	u32	backupRegs[4] = {0};
+	u8 status = _SUCCESS;
+
+	efuse_PreUpdateAction(adapter, backupRegs);
+
+	d = adapter_to_dvobj(adapter);
+	err = rtw_halmac_get_logical_efuse_size(d, &size);
+	if (err) {
+		status = _FAIL;
+		goto exit;
+	}
+	/* size error handle */
+	if ((addr + cnts) > size) {
+		if (addr < size)
+			cnts = size - addr;
+		else {
+			status = _FAIL;
+			goto exit;
+		}
+	}
+
+	if (cnts > 16)
+		efuse = rtw_zmalloc(size);
+
+	if (efuse) {
+		err = rtw_halmac_read_logical_efuse_map(d, efuse, size, NULL, 0);
+		if (err) {
+			rtw_mfree(efuse, size);
+			status = _FAIL;
+			goto exit;
+		}
+
+		_rtw_memcpy(data, efuse + addr, cnts);
+		rtw_mfree(efuse, size);
+	} else {
+		err = rtw_halmac_read_logical_efuse(d, addr, cnts, data);
+		if (err) {
+			status = _FAIL;
+			goto exit;
+		}
+	}
+	status = _SUCCESS;
+exit:
+	efuse_PostUpdateAction(adapter, backupRegs);
+
+	return status;
+}
+
+u8 rtw_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
+{
+	struct dvobj_priv *d;
+	u8 *efuse = NULL;
+	u32 size, i;
+	int err;
+	u8 mask_buf[64] = "";
+	u16 mask_len = sizeof(u8) * rtw_get_efuse_mask_arraylen(adapter);
+	u32 backupRegs[4] = {0};
+	u8 status = _SUCCESS;;
+
+	efuse_PreUpdateAction(adapter, backupRegs);
+
+	d = adapter_to_dvobj(adapter);
+	err = rtw_halmac_get_logical_efuse_size(d, &size);
+	if (err) {
+		status = _FAIL;
+		goto exit;
+	}
+
+	if ((addr + cnts) > size) {
+		status = _FAIL;
+		goto exit;
+	}
+
+	efuse = rtw_zmalloc(size);
+	if (!efuse) {
+		status = _FAIL;
+		goto exit;
+	}
+
+	err = rtw_halmac_read_logical_efuse_map(d, efuse, size, NULL, 0);
+	if (err) {
+		rtw_mfree(efuse, size);
+		status = _FAIL;
+		goto exit;
+	}
+
+	_rtw_memcpy(efuse + addr, data, cnts);
+
+	if (adapter->registrypriv.boffefusemask == 0) {
+		RTW_INFO("Use mask Array Len: %d\n", mask_len);
+
+		if (mask_len != 0) {
+			if (adapter->registrypriv.bFileMaskEfuse == _TRUE)
+				_rtw_memcpy(mask_buf, maskfileBuffer, mask_len);
+			else
+				rtw_efuse_mask_array(adapter, mask_buf);
+
+			err = rtw_halmac_write_logical_efuse_map(d, efuse, size, mask_buf, mask_len);
+		} else
+			err = rtw_halmac_write_logical_efuse_map(d, efuse, size, NULL, 0);
+	} else {
+		_rtw_memset(mask_buf, 0xFF, sizeof(mask_buf));
+		RTW_INFO("Efuse mask off\n");
+		err = rtw_halmac_write_logical_efuse_map(d, efuse, size, mask_buf, size/16);
+	}
+
+	if (err) {
+		rtw_mfree(efuse, size);
+		status = _FAIL;
+		goto exit;
+	}
+
+	rtw_mfree(efuse, size);
+	status = _SUCCESS;
+exit :
+	efuse_PostUpdateAction(adapter, backupRegs);
+
+	return status;
+}
+
+int Efuse_PgPacketRead(PADAPTER adapter, u8 offset, u8 *data, BOOLEAN test)
+{
+	return _FALSE;
+}
+
+int Efuse_PgPacketWrite(PADAPTER adapter, u8 offset, u8 word_en, u8 *data, BOOLEAN test)
+{
+	return _FALSE;
+}
+
+u8 rtw_BT_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
+{
+	hal_ReadEFuse_BT_logic_map(adapter,addr, cnts, data);
+
+	return _SUCCESS;
+}
+
+u8 rtw_BT_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
+{
+#define RT_ASSERT_RET(expr)									\
+	if (!(expr)) {										\
+		printk("Assertion failed! %s at ......\n", #expr);				\
+		printk("	  ......%s,%s, line=%d\n",__FILE__, __FUNCTION__, __LINE__);	\
+		return _FAIL;	\
+	}
+
+	u8	offset, word_en;
+	u8	*map;
+	u8	newdata[PGPKT_DATA_SIZE];
+	s32 i = 0, j = 0, idx;
+	u8	ret = _SUCCESS;
+	u16 mapLen = 1024;
+
+	if ((addr + cnts) > mapLen)
+		return _FAIL;
+
+	RT_ASSERT_RET(PGPKT_DATA_SIZE == 8); /* have to be 8 byte alignment */
+	RT_ASSERT_RET((mapLen & 0x7) == 0); /* have to be PGPKT_DATA_SIZE alignment for memcpy */
+
+	map = rtw_zmalloc(mapLen);
+	if (map == NULL)
+		return _FAIL;
+
+	ret = rtw_BT_efuse_map_read(adapter, 0, mapLen, map);
+	if (ret == _FAIL)
+		goto exit;
+	RTW_INFO("OFFSET\tVALUE(hex)\n");
+	for (i = 0; i < mapLen; i += 16) { /* set 512 because the iwpriv's extra size have limit 0x7FF */
+		RTW_INFO("0x%03x\t", i);
+		for (j = 0; j < 8; j++)
+			RTW_INFO("%02X ", map[i + j]);
+		RTW_INFO("\t");
+		for (; j < 16; j++)
+			RTW_INFO("%02X ", map[i + j]);
+		RTW_INFO("\n");
+	}
+	RTW_INFO("\n");
+
+	idx = 0;
+	offset = (addr >> 3);
+	while (idx < cnts) {
+		word_en = 0xF;
+		j = (addr + idx) & 0x7;
+		_rtw_memcpy(newdata, &map[offset << 3], PGPKT_DATA_SIZE);
+		for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
+			if (data[idx] != map[addr + idx]) {
+				word_en &= ~BIT(i >> 1);
+				newdata[i] = data[idx];
+			}
+		}
+
+		if (word_en != 0xF) {
+			ret = EfusePgPacketWrite_BT(adapter, offset, word_en, newdata, _FALSE);
+			RTW_INFO("offset=%x\n", offset);
+			RTW_INFO("word_en=%x\n", word_en);
+			RTW_INFO("%s: data=", __FUNCTION__);
+			for (i = 0; i < PGPKT_DATA_SIZE; i++)
+				RTW_INFO("0x%02X ", newdata[i]);
+			RTW_INFO("\n");
+			if (ret == _FAIL)
+				break;
+		}
+		offset++;
+	}
+exit:
+	rtw_mfree(map, mapLen);
+	return _SUCCESS;
+}
+
+VOID hal_ReadEFuse_BT_logic_map(
+	PADAPTER	padapter,
+	u16			_offset,
+	u16			_size_byte,
+	u8			*pbuf
+)
+{
+
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	PEFUSE_HAL		pEfuseHal = &pHalData->EfuseHal;
+
+	u8	*efuseTbl, *phyefuse;
+	u8	bank;
+	u16	eFuse_Addr = 0;
+	u8	efuseHeader, efuseExtHdr, efuseData;
+	u8	offset, wden;
+	u16	i, total, used;
+	u8	efuse_usage;
+
+
+	/* */
+	/* Do NOT excess total size of EFuse table. Added by Roger, 2008.11.10. */
+	/* */
+	if ((_offset + _size_byte) > EFUSE_BT_MAP_LEN) {
+		RTW_INFO("%s: Invalid offset(%#x) with read bytes(%#x)!!\n", __FUNCTION__, _offset, _size_byte);
+		return;
+	}
+
+	efuseTbl = rtw_malloc(EFUSE_BT_MAP_LEN);
+	phyefuse = rtw_malloc(EFUSE_BT_REAL_CONTENT_LEN);
+	if (efuseTbl == NULL || phyefuse == NULL) {
+		RTW_INFO("%s: efuseTbl or phyefuse malloc fail!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	/* 0xff will be efuse default value instead of 0x00. */
+	_rtw_memset(efuseTbl, 0xFF, EFUSE_BT_MAP_LEN);
+	_rtw_memset(phyefuse, 0xFF, EFUSE_BT_REAL_CONTENT_LEN);
+
+	if (rtw_efuse_bt_access(padapter, _FALSE, 0, EFUSE_BT_REAL_CONTENT_LEN, phyefuse))
+		dump_buf(phyefuse, EFUSE_BT_REAL_BANK_CONTENT_LEN);
+	
+	total = BANK_NUM;
+	for (bank = 1; bank <= total; bank++) { /* 8723d Max bake 0~2 */
+		eFuse_Addr = 0;
+
+		while (AVAILABLE_EFUSE_ADDR(eFuse_Addr)) {
+			/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest); */
+			efuseHeader = phyefuse[eFuse_Addr++];
+
+			if (efuseHeader == 0xFF)
+				break;
+			RTW_INFO("%s: efuse[%#X]=0x%02x (header)\n", __FUNCTION__, (((bank - 1) * EFUSE_BT_REAL_CONTENT_LEN) + eFuse_Addr - 1), efuseHeader);
+
+			/* Check PG header for section num. */
+			if (EXT_HEADER(efuseHeader)) {	/* extended header */
+				offset = GET_HDR_OFFSET_2_0(efuseHeader);
+				RTW_INFO("%s: extended header offset_2_0=0x%X\n", __FUNCTION__, offset);
+
+				/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest); */
+				efuseExtHdr = phyefuse[eFuse_Addr++];
+
+				RTW_INFO("%s: efuse[%#X]=0x%02x (ext header)\n", __FUNCTION__, (((bank - 1) * EFUSE_BT_REAL_CONTENT_LEN) + eFuse_Addr - 1), 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 */
+				RTW_INFO("%s: Offset=%d Worden=%#X\n", __FUNCTION__, offset, wden);
+
+				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))) {
+						efuseData = 0;
+						/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
+						efuseData = phyefuse[eFuse_Addr++];
+
+						RTW_INFO("%s: efuse[%#X]=0x%02X\n", __FUNCTION__, eFuse_Addr - 1, efuseData);
+						efuseTbl[addr] = efuseData;
+
+						efuseData = 0;
+						/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
+						efuseData = phyefuse[eFuse_Addr++];
+
+						RTW_INFO("%s: efuse[%#X]=0x%02X\n", __FUNCTION__, eFuse_Addr - 1, efuseData);
+						efuseTbl[addr + 1] = efuseData;
+					}
+					addr += 2;
+				}
+			} else {
+				RTW_INFO("%s: offset(%d) is illegal!!\n", __FUNCTION__, offset);
+				eFuse_Addr += Efuse_CalculateWordCnts(wden) * 2;
+			}
+		}
+
+		if ((eFuse_Addr - 1) < total) {
+			RTW_INFO("%s: bank(%d) data end at %#x\n", __FUNCTION__, bank, eFuse_Addr - 1);
+			break;
+		}
+	}
+
+	/* switch bank back to bank 0 for later BT and wifi use. */
+	//hal_EfuseSwitchToBank(padapter, 0, bPseudoTest);
+
+	/* Copy from Efuse map to output pointer memory!!! */
+	for (i = 0; i < _size_byte; i++)
+		pbuf[i] = efuseTbl[_offset + i];
+	/* Calculate Efuse utilization */
+	total = EFUSE_BT_REAL_BANK_CONTENT_LEN;
+
+	used = eFuse_Addr - 1;
+
+	if (total)
+		efuse_usage = (u8)((used * 100) / total);
+	else
+		efuse_usage = 100;
+
+	fakeBTEfuseUsedBytes = used;
+	RTW_INFO("%s: BTEfuseUsed last Bytes = %#x\n", __FUNCTION__, fakeBTEfuseUsedBytes);
+
+exit:
+	if (efuseTbl)
+		rtw_mfree(efuseTbl, EFUSE_BT_MAP_LEN);
+	if (phyefuse)
+		rtw_mfree(phyefuse, EFUSE_BT_REAL_BANK_CONTENT_LEN);
+}
+
+
+static u8 hal_EfusePartialWriteCheck(
+	PADAPTER		padapter,
+	u8				efuseType,
+	u16				*pAddr,
+	PPGPKT_STRUCT	pTargetPkt,
+	u8				bPseudoTest)
+{
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	PEFUSE_HAL		pEfuseHal = &pHalData->EfuseHal;
+	u8	bRet = _FALSE;
+	u16	startAddr = 0, efuse_max_available_len = EFUSE_BT_REAL_BANK_CONTENT_LEN, efuse_max = EFUSE_BT_REAL_BANK_CONTENT_LEN;
+	u8	efuse_data = 0;
+
+	startAddr = (u16)fakeBTEfuseUsedBytes;
+
+	startAddr %= efuse_max;
+	RTW_INFO("%s: startAddr=%#X\n", __FUNCTION__, startAddr);
+
+	while (1) {
+		if (startAddr >= efuse_max_available_len) {
+			bRet = _FALSE;
+			RTW_INFO("%s: startAddr(%d) >= efuse_max_available_len(%d)\n",
+				__FUNCTION__, startAddr, efuse_max_available_len);
+			break;
+		}
+		if (rtw_efuse_bt_access(padapter, _FALSE, startAddr, 1, &efuse_data)&& (efuse_data != 0xFF)) {
+			bRet = _FALSE;
+			RTW_INFO("%s: Something Wrong! last bytes(%#X=0x%02X) is not 0xFF\n",
+				 __FUNCTION__, startAddr, efuse_data);
+			break;
+		} else {
+			/* not used header, 0xff */
+			*pAddr = startAddr;
+			/*			RTW_INFO("%s: Started from unused header offset=%d\n", __FUNCTION__, startAddr)); */
+			bRet = _TRUE;
+			break;
+		}
+	}
+
+	return bRet;
+}
+
+
+static u8 hal_EfusePgPacketWrite2ByteHeader(
+	PADAPTER		padapter,
+	u8				efuseType,
+	u16				*pAddr,
+	PPGPKT_STRUCT	pTargetPkt,
+	u8				bPseudoTest)
+{
+	u16	efuse_addr, efuse_max_available_len = EFUSE_BT_REAL_BANK_CONTENT_LEN;
+	u8	pg_header = 0, tmp_header = 0;
+	u8	repeatcnt = 0;
+
+	/*	RTW_INFO("%s\n", __FUNCTION__); */
+
+	efuse_addr = *pAddr;
+	if (efuse_addr >= efuse_max_available_len) {
+		RTW_INFO("%s: addr(%d) over avaliable(%d)!!\n", __FUNCTION__, efuse_addr, efuse_max_available_len);
+		return _FALSE;
+	}
+
+	pg_header = ((pTargetPkt->offset & 0x07) << 5) | 0x0F;
+	/*	RTW_INFO("%s: pg_header=0x%x\n", __FUNCTION__, pg_header); */
+
+	do {
+		
+		rtw_efuse_bt_access(padapter, _TRUE, efuse_addr, 1, &pg_header);
+		rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &tmp_header);
+
+		if (tmp_header != 0xFF)
+			break;
+		if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
+			RTW_INFO("%s: Repeat over limit for pg_header!!\n", __FUNCTION__);
+			return _FALSE;
+		}
+	} while (1);
+
+	if (tmp_header != pg_header) {
+		RTW_ERR("%s: PG Header Fail!!(pg=0x%02X read=0x%02X)\n", __FUNCTION__, pg_header, tmp_header);
+		return _FALSE;
+	}
+
+	/* to write ext_header */
+	efuse_addr++;
+	pg_header = ((pTargetPkt->offset & 0x78) << 1) | pTargetPkt->word_en;
+
+	do {
+		rtw_efuse_bt_access(padapter, _TRUE, efuse_addr, 1, &pg_header);
+		rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &tmp_header);
+
+		if (tmp_header != 0xFF)
+			break;
+		if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
+			RTW_INFO("%s: Repeat over limit for ext_header!!\n", __FUNCTION__);
+			return _FALSE;
+		}
+	} while (1);
+
+	if (tmp_header != pg_header) {	/* offset PG fail */
+		RTW_ERR("%s: PG EXT Header Fail!!(pg=0x%02X read=0x%02X)\n", __FUNCTION__, pg_header, tmp_header);
+		return _FALSE;
+	}
 
-#include "../hal/efuse/efuse_mask.h"
+	*pAddr = efuse_addr;
 
-/*------------------------Define local variable------------------------------*/
-u8	fakeEfuseBank=0;
-u32	fakeEfuseUsedBytes=0;
-u8	fakeEfuseContent[EFUSE_MAX_HW_SIZE]={0};
-u8	fakeEfuseInitMap[EFUSE_MAX_MAP_LEN]={0};
-u8	fakeEfuseModifiedMap[EFUSE_MAX_MAP_LEN]={0};
+	return _TRUE;
+}
 
-u32	BTEfuseUsedBytes=0;
-u8	BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
-u8	BTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN]={0};
-u8	BTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN]={0};
 
-u32	fakeBTEfuseUsedBytes=0;
-u8	fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
-u8	fakeBTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN]={0};
-u8	fakeBTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN]={0};
+static u8 hal_EfusePgPacketWrite1ByteHeader(
+	PADAPTER		pAdapter,
+	u8				efuseType,
+	u16				*pAddr,
+	PPGPKT_STRUCT	pTargetPkt,
+	u8				bPseudoTest)
+{
+	u8	bRet = _FALSE;
+	u8	pg_header = 0, tmp_header = 0;
+	u16	efuse_addr = *pAddr;
+	u8	repeatcnt = 0;
 
-u8 	maskfileBuffer[32];
-/*------------------------Define local variable------------------------------*/
 
-//------------------------------------------------------------------------------
+	/*	RTW_INFO("%s\n", __FUNCTION__); */
+	pg_header = ((pTargetPkt->offset << 4) & 0xf0) | pTargetPkt->word_en;
+
+	do {
+		rtw_efuse_bt_access(pAdapter, _TRUE, efuse_addr, 1, &pg_header);
+		rtw_efuse_bt_access(pAdapter, _FALSE, efuse_addr, 1, &tmp_header);
+
+		if (tmp_header != 0xFF)
+			break;
+		if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
+			RTW_INFO("%s: Repeat over limit for pg_header!!\n", __FUNCTION__);
+			return _FALSE;
+		}
+	} while (1);
+
+	if (tmp_header != pg_header) {
+		RTW_ERR("%s: PG Header Fail!!(pg=0x%02X read=0x%02X)\n", __FUNCTION__, pg_header, tmp_header);
+		return _FALSE;
+	}
+
+	*pAddr = efuse_addr;
+
+	return _TRUE;
+}
+
+static u8 hal_EfusePgPacketWriteHeader(
+	PADAPTER		padapter,
+	u8				efuseType,
+	u16				*pAddr,
+	PPGPKT_STRUCT	pTargetPkt,
+	u8				bPseudoTest)
+{
+	u8 bRet = _FALSE;
+
+	if (pTargetPkt->offset >= EFUSE_MAX_SECTION_BASE)
+		bRet = hal_EfusePgPacketWrite2ByteHeader(padapter, efuseType, pAddr, pTargetPkt, bPseudoTest);
+	else
+		bRet = hal_EfusePgPacketWrite1ByteHeader(padapter, efuseType, pAddr, pTargetPkt, bPseudoTest);
+
+	return bRet;
+}
+
+
+static u8
+Hal_EfuseWordEnableDataWrite(
+	PADAPTER	padapter,
+	u16			efuse_addr,
+	u8			word_en,
+	u8			*data,
+	u8			bPseudoTest)
+{
+	u16	tmpaddr = 0;
+	u16	start_addr = efuse_addr;
+	u8	badworden = 0x0F;
+	u8	tmpdata[PGPKT_DATA_SIZE];
+
+
+	/*	RTW_INFO("%s: efuse_addr=%#x word_en=%#x\n", __FUNCTION__, efuse_addr, word_en); */
+	_rtw_memset(tmpdata, 0xFF, PGPKT_DATA_SIZE);
+
+	if (!(word_en & BIT(0))) {
+		tmpaddr = start_addr;
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[0]);
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[1]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[0]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[1]);
+		if ((data[0] != tmpdata[0]) || (data[1] != tmpdata[1]))
+			badworden &= (~BIT(0));
+	}
+	if (!(word_en & BIT(1))) {
+		tmpaddr = start_addr;
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[2]);
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[3]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[2]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[3]);
+		if ((data[2] != tmpdata[2]) || (data[3] != tmpdata[3]))
+			badworden &= (~BIT(1));
+	}
+	if (!(word_en & BIT(2))) {
+		tmpaddr = start_addr;
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[4]);
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[5]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[4]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[5]);
+		if ((data[4] != tmpdata[4]) || (data[5] != tmpdata[5]))
+			badworden &= (~BIT(2));
+	}
+	if (!(word_en & BIT(3))) {
+		tmpaddr = start_addr;
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[6]);
+		rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[7]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[6]);
+		rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[7]);
+
+		if ((data[6] != tmpdata[6]) || (data[7] != tmpdata[7]))
+			badworden &= (~BIT(3));
+	}
+
+	return badworden;
+}
+
+static void
+hal_EfuseConstructPGPkt(
+	u8				offset,
+	u8				word_en,
+	u8				*pData,
+	PPGPKT_STRUCT	pTargetPkt)
+{
+	_rtw_memset(pTargetPkt->data, 0xFF, PGPKT_DATA_SIZE);
+	pTargetPkt->offset = offset;
+	pTargetPkt->word_en = word_en;
+	efuse_WordEnableDataRead(word_en, pData, pTargetPkt->data);
+	pTargetPkt->word_cnts = Efuse_CalculateWordCnts(pTargetPkt->word_en);
+}
+
+static u8
+hal_EfusePgPacketWriteData(
+	PADAPTER		pAdapter,
+	u8				efuseType,
+	u16				*pAddr,
+	PPGPKT_STRUCT	pTargetPkt,
+	u8				bPseudoTest)
+{
+	u16	efuse_addr;
+	u8	badworden;
+
+	efuse_addr = *pAddr;
+	badworden = Hal_EfuseWordEnableDataWrite(pAdapter, efuse_addr + 1, pTargetPkt->word_en, pTargetPkt->data, bPseudoTest);
+	if (badworden != 0x0F) {
+		RTW_INFO("%s: Fail!!\n", __FUNCTION__);
+		return _FALSE;
+	} else
+		RTW_INFO("%s: OK!!\n", __FUNCTION__);
+
+	return _TRUE;
+}
+
+u8 efuse_OneByteRead(struct _ADAPTER *a, u16 addr, u8 *data, u8 bPseudoTest)
+{
+		struct dvobj_priv *d;
+		int err;
+		u8 ret = _TRUE;
+
+		d = adapter_to_dvobj(a);
+		err = rtw_halmac_read_physical_efuse(d, addr, 1, data);
+		if (err) {
+			RTW_ERR("%s: addr=0x%x FAIL!!!\n", __FUNCTION__, addr);
+			ret = _FALSE;
+		}
+
+		return ret;
+	
+}
+
+static u16
+hal_EfuseGetCurrentSize_BT(
+	PADAPTER	padapter,
+	u8			bPseudoTest)
+{
+#ifdef HAL_EFUSE_MEMORY
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	PEFUSE_HAL		pEfuseHal = &pHalData->EfuseHal;
+#endif
+	u16 btusedbytes;
+	u16	efuse_addr;
+	u8	bank, startBank;
+	u8	hoffset = 0, hworden = 0;
+	u8	efuse_data, word_cnts = 0;
+	u16	retU2 = 0;
+	u8 bContinual = _TRUE;
+
+
+	btusedbytes = fakeBTEfuseUsedBytes;
+
+	efuse_addr = (u16)((btusedbytes % EFUSE_BT_REAL_BANK_CONTENT_LEN));
+	startBank = (u8)(1 + (btusedbytes / EFUSE_BT_REAL_BANK_CONTENT_LEN));
+
+	RTW_INFO("%s: start from bank=%d addr=0x%X\n", __FUNCTION__, startBank, efuse_addr);
+	retU2 = EFUSE_BT_REAL_CONTENT_LEN - EFUSE_PROTECT_BYTES_BANK;
+
+	for (bank = startBank; bank < 3; bank++) {
+		if (hal_EfuseSwitchToBank(padapter, bank, bPseudoTest) == _FALSE) {
+			RTW_ERR("%s: switch bank(%d) Fail!!\n", __FUNCTION__, 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 (rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &efuse_data) == _FALSE) {
+				RTW_ERR("%s: efuse_OneByteRead Fail! addr=0x%X !!\n", __FUNCTION__, efuse_addr);
+				/* bank = EFUSE_MAX_BANK; */
+				break;
+			}
+			RTW_INFO("%s: efuse_OneByteRead ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __FUNCTION__, efuse_addr, efuse_data, bank);
+
+			if (efuse_data == 0xFF)
+				break;
+
+			if (EXT_HEADER(efuse_data)) {
+				hoffset = GET_HDR_OFFSET_2_0(efuse_data);
+				efuse_addr++;
+				rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &efuse_data);
+				RTW_INFO("%s: efuse_OneByteRead EXT_HEADER ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __FUNCTION__, efuse_addr, efuse_data, bank);
+
+				if (ALL_WORDS_DISABLED(efuse_data)) {
+					efuse_addr++;
+					continue;
+				}
+
+				/*				hoffset = ((hoffset & 0xE0) >> 5) | ((efuse_data & 0xF0) >> 1); */
+				hoffset |= ((efuse_data & 0xF0) >> 1);
+				hworden = efuse_data & 0x0F;
+			} else {
+				hoffset = (efuse_data >> 4) & 0x0F;
+				hworden =  efuse_data & 0x0F;
+			}
+
+			RTW_INFO(FUNC_ADPT_FMT": Offset=%d Worden=%#X\n",
+				 FUNC_ADPT_ARG(padapter), hoffset, hworden);
+
+			word_cnts = Efuse_CalculateWordCnts(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;
+
+	fakeBTEfuseUsedBytes = retU2;
+	RTW_INFO("%s: CurrentSize=%d\n", __FUNCTION__, retU2);
+	return retU2;
+}
+
+
+static u8
+hal_BT_EfusePgCheckAvailableAddr(
+	PADAPTER	pAdapter,
+	u8		bPseudoTest)
+{
+	u16	max_available = EFUSE_BT_REAL_CONTENT_LEN - EFUSE_PROTECT_BYTES_BANK;
+	u16	current_size = 0;
+
+	 RTW_INFO("%s: max_available=%d\n", __FUNCTION__, max_available);
+	current_size = hal_EfuseGetCurrentSize_BT(pAdapter, bPseudoTest);
+	if (current_size >= max_available) {
+		RTW_INFO("%s: Error!! current_size(%d)>max_available(%d)\n", __FUNCTION__, current_size, max_available);
+		return _FALSE;
+	}
+	return _TRUE;
+}
+
+u8 EfusePgPacketWrite_BT(
+	PADAPTER	pAdapter,
+	u8			offset,
+	u8			word_en,
+	u8			*pData,
+	u8			bPseudoTest)
+{
+	PGPKT_STRUCT targetPkt;
+	u16 startAddr = 0;
+	u8 efuseType = EFUSE_BT;
+
+	if (!hal_BT_EfusePgCheckAvailableAddr(pAdapter, bPseudoTest))
+		return _FALSE;
+
+	hal_EfuseConstructPGPkt(offset, word_en, pData, &targetPkt);
+
+	if (!hal_EfusePartialWriteCheck(pAdapter, efuseType, &startAddr, &targetPkt, bPseudoTest))
+		return _FALSE;
+
+	if (!hal_EfusePgPacketWriteHeader(pAdapter, efuseType, &startAddr, &targetPkt, bPseudoTest))
+		return _FALSE;
+
+	if (!hal_EfusePgPacketWriteData(pAdapter, efuseType, &startAddr, &targetPkt, bPseudoTest))
+		return _FALSE;
+
+	return _TRUE;
+}
+
+
+#else /* !RTW_HALMAC */
+/* ------------------------------------------------------------------------------ */
 #define REG_EFUSE_CTRL		0x0030
-#define EFUSE_CTRL			REG_EFUSE_CTRL		// E-Fuse Control.
-//------------------------------------------------------------------------------
+#define EFUSE_CTRL			REG_EFUSE_CTRL		/* E-Fuse Control. */
+/* ------------------------------------------------------------------------------ */
+
 
 BOOLEAN
 Efuse_Read1ByteFromFakeContent(
 	IN		PADAPTER	pAdapter,
 	IN		u16		Offset,
-	IN OUT	u8		*Value	);
+	IN OUT	u8		*Value);
 BOOLEAN
 Efuse_Read1ByteFromFakeContent(
 	IN		PADAPTER	pAdapter,
 	IN		u16		Offset,
-	IN OUT	u8		*Value	)
+	IN OUT	u8		*Value)
 {
-	if(Offset >= EFUSE_MAX_HW_SIZE)
-	{
+	if (Offset >= EFUSE_MAX_HW_SIZE)
 		return _FALSE;
-	}
-	//DbgPrint("Read fake content, offset = %d\n", Offset);
-	if(fakeEfuseBank == 0)
+	/* DbgPrint("Read fake content, offset = %d\n", Offset); */
+	if (fakeEfuseBank == 0)
 		*Value = fakeEfuseContent[Offset];
 	else
-		*Value = fakeBTEfuseContent[fakeEfuseBank-1][Offset];
+		*Value = fakeBTEfuseContent[fakeEfuseBank - 1][Offset];
 	return _TRUE;
 }
 
@@ -76,30 +1804,26 @@ BOOLEAN
 Efuse_Write1ByteToFakeContent(
 	IN		PADAPTER	pAdapter,
 	IN		u16		Offset,
-	IN 		u8		Value	);
+	IN		u8		Value);
 BOOLEAN
 Efuse_Write1ByteToFakeContent(
 	IN		PADAPTER	pAdapter,
 	IN		u16		Offset,
-	IN 		u8		Value	)
+	IN		u8		Value)
 {
-	if(Offset >= EFUSE_MAX_HW_SIZE)
-	{
+	if (Offset >= EFUSE_MAX_HW_SIZE)
 		return _FALSE;
-	}
-	if(fakeEfuseBank == 0)
+	if (fakeEfuseBank == 0)
 		fakeEfuseContent[Offset] = Value;
 	else
-	{
-		fakeBTEfuseContent[fakeEfuseBank-1][Offset] = Value;
-	}
+		fakeBTEfuseContent[fakeEfuseBank - 1][Offset] = Value;
 	return _TRUE;
 }
 
 /*-----------------------------------------------------------------------------
  * Function:	Efuse_PowerSwitch
  *
- * Overview:	When we want to enable write operation, we should change to 
+ * Overview:	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.
  *
@@ -111,7 +1835,7 @@ Efuse_Write1ByteToFakeContent(
  *
  * Revised History:
  * When			Who		Remark
- * 11/17/2008 	MHC		Create Version 0.
+ * 11/17/2008	MHC		Create Version 0.
  *
  *---------------------------------------------------------------------------*/
 VOID
@@ -120,7 +1844,7 @@ Efuse_PowerSwitch(
 	IN	u8		bWrite,
 	IN	u8		PwrState)
 {
-	pAdapter->HalFunc.EfusePowerSwitch(pAdapter, bWrite, PwrState);
+	pAdapter->hal_func.EfusePowerSwitch(pAdapter, bWrite, PwrState);
 }
 
 VOID
@@ -129,8 +1853,8 @@ BTEfuse_PowerSwitch(
 	IN	u8		bWrite,
 	IN	u8		PwrState)
 {
-	if(pAdapter->HalFunc.BTEfusePowerSwitch)
-		pAdapter->HalFunc.BTEfusePowerSwitch(pAdapter, bWrite, PwrState);
+	if (pAdapter->hal_func.BTEfusePowerSwitch)
+		pAdapter->hal_func.BTEfusePowerSwitch(pAdapter, bWrite, PwrState);
 }
 
 /*-----------------------------------------------------------------------------
@@ -146,7 +1870,7 @@ BTEfuse_PowerSwitch(
  *
  * Revised History:
  * When			Who		Remark
- * 11/16/2008 	MHC		Create Version 0.
+ * 11/16/2008	MHC		Create Version 0.
  *
  *---------------------------------------------------------------------------*/
 u16
@@ -155,128 +1879,113 @@ Efuse_GetCurrentSize(
 	IN u8			efuseType,
 	IN BOOLEAN		bPseudoTest)
 {
-	u16 ret=0;
+	u16 ret = 0;
 
-	ret = pAdapter->HalFunc.EfuseGetCurrentSize(pAdapter, efuseType, bPseudoTest);
+	ret = pAdapter->hal_func.EfuseGetCurrentSize(pAdapter, efuseType, bPseudoTest);
 
 	return ret;
 }
 
-/*  11/16/2008 MH Add description. Get current efuse area enabled word!!. */
-u8
-Efuse_CalculateWordCnts(IN u8	word_en)
-{
-	u8 word_cnts = 0;
-	if(!(word_en & BIT(0)))	word_cnts++; // 0 : write enable
-	if(!(word_en & BIT(1)))	word_cnts++;
-	if(!(word_en & BIT(2)))	word_cnts++;
-	if(!(word_en & BIT(3)))	word_cnts++;
-	return word_cnts;
-}
-
-//
-//	Description:
-//		Execute E-Fuse read byte operation.
-//		Refered from SD1 Richard.
-//
-//	Assumption:
-//		1. Boot from E-Fuse and successfully auto-load.
-//		2. PASSIVE_LEVEL (USB interface)
-//
-//	Created by Roger, 2008.10.21.
-//
+/*
+ *	Description:
+ *		Execute E-Fuse read byte operation.
+ *		Refered from SD1 Richard.
+ *
+ *	Assumption:
+ *		1. Boot from E-Fuse and successfully auto-load.
+ *		2. PASSIVE_LEVEL (USB interface)
+ *
+ *	Created by Roger, 2008.10.21.
+ *   */
 VOID
 ReadEFuseByte(
-		PADAPTER	Adapter,
-		u16 			_offset, 
-		u8 			*pbuf, 
-		IN BOOLEAN	bPseudoTest) 
+	PADAPTER	Adapter,
+	u16			_offset,
+	u8			*pbuf,
+	IN BOOLEAN	bPseudoTest)
 {
 	u32	value32;
 	u8	readbyte;
 	u16	retry;
-	//u32 start=rtw_get_current_time();
+	/* systime start=rtw_get_current_time(); */
 
-	if(bPseudoTest)
-	{
+	if (bPseudoTest) {
 		Efuse_Read1ByteFromFakeContent(Adapter, _offset, pbuf);
 		return;
 	}
-	if (IS_HARDWARE_TYPE_8723B(Adapter))
-	{
-		// <20130121, Kordan> For SMIC S55 EFUSE specificatoin.
-		//0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8])
-		PHY_SetMacReg(Adapter, EFUSE_TEST, BIT11, 0);
+	if (IS_HARDWARE_TYPE_8723B(Adapter)) {
+		/* <20130121, Kordan> For SMIC S55 EFUSE specificatoin. */
+		/* 0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8]) */
+		phy_set_mac_reg(Adapter, EFUSE_TEST, BIT11, 0);
 	}
-	//Write Address
-	rtw_write8(Adapter, EFUSE_CTRL+1, (_offset & 0xff));  		
-	readbyte = rtw_read8(Adapter, EFUSE_CTRL+2);
-	rtw_write8(Adapter, EFUSE_CTRL+2, ((_offset >> 8) & 0x03) | (readbyte & 0xfc));  		
+	/* Write Address */
+	rtw_write8(Adapter, EFUSE_CTRL + 1, (_offset & 0xff));
+	readbyte = rtw_read8(Adapter, EFUSE_CTRL + 2);
+	rtw_write8(Adapter, EFUSE_CTRL + 2, ((_offset >> 8) & 0x03) | (readbyte & 0xfc));
 
-	//Write bit 32 0
-	readbyte = rtw_read8(Adapter, EFUSE_CTRL+3);		
-	rtw_write8(Adapter, EFUSE_CTRL+3, (readbyte & 0x7f));  	
-	
-	//Check bit 32 read-ready
+	/* Write bit 32 0 */
+	readbyte = rtw_read8(Adapter, EFUSE_CTRL + 3);
+	rtw_write8(Adapter, EFUSE_CTRL + 3, (readbyte & 0x7f));
+
+	/* Check bit 32 read-ready */
 	retry = 0;
 	value32 = rtw_read32(Adapter, EFUSE_CTRL);
-	//while(!(((value32 >> 24) & 0xff) & 0x80)  && (retry<10))
-	while(!(((value32 >> 24) & 0xff) & 0x80)  && (retry<10000))
-	{
+	/* while(!(((value32 >> 24) & 0xff) & 0x80)  && (retry<10)) */
+	while (!(((value32 >> 24) & 0xff) & 0x80)  && (retry < 10000)) {
 		value32 = rtw_read32(Adapter, EFUSE_CTRL);
 		retry++;
 	}
 
-	// 20100205 Joseph: Add delay suggested by SD1 Victor.
-	// This fix 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.
+	/* 20100205 Joseph: Add delay suggested by SD1 Victor. */
+	/* This fix 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. */
 	rtw_udelay_os(50);
 	value32 = rtw_read32(Adapter, EFUSE_CTRL);
-	
+
 	*pbuf = (u8)(value32 & 0xff);
-	//DBG_871X("ReadEFuseByte _offset:%08u, in %d ms\n",_offset ,rtw_get_passing_time_ms(start));
-	
+	/* RTW_INFO("ReadEFuseByte _offset:%08u, in %d ms\n",_offset ,rtw_get_passing_time_ms(start)); */
+
 }
 
-//
-//	Description:
-//		1. Execute E-Fuse read byte operation according as map offset and 
-//		    save to E-Fuse table.
-//		2. Refered from SD1 Richard.
-//
-//	Assumption:
-//		1. Boot from E-Fuse and successfully auto-load.
-//		2. PASSIVE_LEVEL (USB interface)
-//
-//	Created by Roger, 2008.10.21.
-//
-//	2008/12/12 MH 	1. Reorganize code flow and reserve bytes. and add description.
-//					2. Add efuse utilization collect.
-//	2008/12/22 MH	Read Efuse must check if we write section 1 data again!!! Sec1
-//					write addr must be after sec5.
-//
+/*
+ *	Description:
+ *		1. Execute E-Fuse read byte operation according as map offset and
+ *		    save to E-Fuse table.
+ *		2. Refered from SD1 Richard.
+ *
+ *	Assumption:
+ *		1. Boot from E-Fuse and successfully auto-load.
+ *		2. PASSIVE_LEVEL (USB interface)
+ *
+ *	Created by Roger, 2008.10.21.
+ *
+ *	2008/12/12 MH	1. Reorganize code flow and reserve bytes. and add description.
+ *					2. Add efuse utilization collect.
+ *	2008/12/22 MH	Read Efuse must check if we write section 1 data again!!! Sec1
+ *					write addr must be after sec5.
+ *   */
 
 VOID
 efuse_ReadEFuse(
 	PADAPTER	Adapter,
 	u8		efuseType,
 	u16		_offset,
-	u16 		_size_byte,
-	u8      	*pbuf,
+	u16		_size_byte,
+	u8	*pbuf,
 	IN	BOOLEAN	bPseudoTest
-	);
+);
 VOID
 efuse_ReadEFuse(
 	PADAPTER	Adapter,
 	u8		efuseType,
 	u16		_offset,
-	u16 		_size_byte,
-	u8      	*pbuf,
+	u16		_size_byte,
+	u8	*pbuf,
 	IN	BOOLEAN	bPseudoTest
-	)
+)
 {
-	Adapter->HalFunc.ReadEFuse(Adapter, efuseType, _offset, _size_byte, pbuf, bPseudoTest);
+	Adapter->hal_func.ReadEFuse(Adapter, efuseType, _offset, _size_byte, pbuf, bPseudoTest);
 }
 
 VOID
@@ -286,149 +1995,16 @@ EFUSE_GetEfuseDefinition(
 	IN		u8		type,
 	OUT		void		*pOut,
 	IN		BOOLEAN		bPseudoTest
-	)
+)
 {
-	pAdapter->HalFunc.EFUSEGetEfuseDefinition(pAdapter, efuseType, type, pOut, bPseudoTest);
+	pAdapter->hal_func.EFUSEGetEfuseDefinition(pAdapter, efuseType, type, pOut, bPseudoTest);
 }
 
-/*-----------------------------------------------------------------------------
- * Function:	EFUSE_Read1Byte
- *
- * Overview:	Copy from WMAC fot EFUSE read 1 byte.
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When			Who		Remark
- * 09/23/2008 	MHC		Copy from WMAC.
- *
- *---------------------------------------------------------------------------*/
-u8
-EFUSE_Read1Byte(	
-	IN	PADAPTER	Adapter, 
-	IN	u16		Address)
-{
-	u8	data;
-	u8	Bytetemp = {0x00};
-	u8	temp = {0x00};
-	u32	k=0;
-	u16	contentLen=0;
-
-	EFUSE_GetEfuseDefinition(Adapter, EFUSE_WIFI , TYPE_EFUSE_REAL_CONTENT_LEN, (PVOID)&contentLen, _FALSE);
-
-	if (Address < contentLen)	//E-fuse 512Byte
-	{
-		//Write E-fuse Register address bit0~7
-		temp = Address & 0xFF;	
-		rtw_write8(Adapter, EFUSE_CTRL+1, temp);	
-		Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+2);	
-		//Write E-fuse Register address bit8~9
-		temp = ((Address >> 8) & 0x03) | (Bytetemp & 0xFC);	
-		rtw_write8(Adapter, EFUSE_CTRL+2, temp);	
-
-		//Write 0x30[31]=0
-		Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+3);
-		temp = Bytetemp & 0x7F;
-		rtw_write8(Adapter, EFUSE_CTRL+3, temp);
-
-		//Wait Write-ready (0x30[31]=1)
-		Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+3);
-		while(!(Bytetemp & 0x80))
-		{				
-			Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+3);
-			k++;
-			if(k==1000)
-			{
-				k=0;
-				break;
-			}
-		}
-		data=rtw_read8(Adapter, EFUSE_CTRL);
-		return data;
-	}
-	else
-		return 0xFF;
-	
-}/* EFUSE_Read1Byte */
-
-/*-----------------------------------------------------------------------------
- * Function:	EFUSE_Write1Byte
- *
- * Overview:	Copy from WMAC fot EFUSE write 1 byte.
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When			Who		Remark
- * 09/23/2008 	MHC		Copy from WMAC.
- *
- *---------------------------------------------------------------------------*/
-
-void	
-EFUSE_Write1Byte(	
-	IN	PADAPTER	Adapter, 
-	IN	u16		Address,
-	IN	u8		Value);
-void	
-EFUSE_Write1Byte(	
-	IN	PADAPTER	Adapter, 
-	IN	u16		Address,
-	IN	u8		Value)
-{
-	u8	Bytetemp = {0x00};
-	u8	temp = {0x00};
-	u32	k=0;
-	u16	contentLen=0;
-
-	//RT_TRACE(COMP_EFUSE, DBG_LOUD, ("Addr=%x Data =%x\n", Address, Value));
-	EFUSE_GetEfuseDefinition(Adapter, EFUSE_WIFI , TYPE_EFUSE_REAL_CONTENT_LEN, (PVOID)&contentLen, _FALSE);
-
-	if( Address < contentLen)	//E-fuse 512Byte
-	{
-		rtw_write8(Adapter, EFUSE_CTRL, Value);
-
-		//Write E-fuse Register address bit0~7
-		temp = Address & 0xFF;	
-		rtw_write8(Adapter, EFUSE_CTRL+1, temp);	
-		Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+2);	
-		
-		//Write E-fuse Register address bit8~9
-		temp = ((Address >> 8) & 0x03) | (Bytetemp & 0xFC);	
-		rtw_write8(Adapter, EFUSE_CTRL+2, temp);	
-
-		//Write 0x30[31]=1
-		Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+3);
-		temp = Bytetemp | 0x80;
-		rtw_write8(Adapter, EFUSE_CTRL+3, temp);
-
-		//Wait Write-ready (0x30[31]=0)
-		Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+3);
-		while(Bytetemp & 0x80)
-		{
-			Bytetemp = rtw_read8(Adapter, EFUSE_CTRL+3);			
-			k++;
-			if(k==100)
-			{
-				k=0;
-				break;
-			}
-		}
-	}
-}/* EFUSE_Write1Byte */
-
 
 /*  11/16/2008 MH Read one byte from real Efuse. */
 u8
 efuse_OneByteRead(
-	IN	PADAPTER	pAdapter, 
+	IN	PADAPTER	pAdapter,
 	IN	u16			addr,
 	IN	u8			*data,
 	IN	BOOLEAN		bPseudoTest)
@@ -437,132 +2013,120 @@ efuse_OneByteRead(
 	u8	bResult;
 	u8	readbyte;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	
-	//DBG_871X("===> EFUSE_OneByteRead(), addr = %x\n", addr);
-	//DBG_871X("===> EFUSE_OneByteRead() start, 0x34 = 0x%X\n", rtw_read32(pAdapter, EFUSE_TEST));
 
-	if(bPseudoTest)
-	{
+	/* RTW_INFO("===> EFUSE_OneByteRead(), addr = %x\n", addr); */
+	/* RTW_INFO("===> EFUSE_OneByteRead() start, 0x34 = 0x%X\n", rtw_read32(pAdapter, EFUSE_TEST)); */
+
+	if (bPseudoTest) {
 		bResult = Efuse_Read1ByteFromFakeContent(pAdapter, addr, data);
 		return bResult;
 	}
-	
-	if(	IS_HARDWARE_TYPE_8723B(pAdapter) ||
-		(IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->VersionID))) ||
-		(IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->VersionID))
-	  )
-	{
-		// <20130121, Kordan> For SMIC EFUSE specificatoin.
-		//0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8])	
-		//PHY_SetMacReg(pAdapter, 0x34, BIT11, 0);
-		rtw_write16(pAdapter, 0x34, rtw_read16(pAdapter,0x34)& (~BIT11) ); 
-	}
-
-	// -----------------e-fuse reg ctrl ---------------------------------
-	//address			
-	rtw_write8(pAdapter, EFUSE_CTRL+1, (u8)(addr&0xff));		
-	rtw_write8(pAdapter, EFUSE_CTRL+2, ((u8)((addr>>8) &0x03) ) |
-	(rtw_read8(pAdapter, EFUSE_CTRL+2)&0xFC ));	
-
-	//rtw_write8(pAdapter, EFUSE_CTRL+3,  0x72);//read cmd	
-	//Write bit 32 0
-	readbyte = rtw_read8(pAdapter, EFUSE_CTRL+3);		
-	rtw_write8(pAdapter, EFUSE_CTRL+3, (readbyte & 0x7f));
-
-	while(!(0x80 &rtw_read8(pAdapter, EFUSE_CTRL+3))&&(tmpidx<1000))
-	{
+
+	if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
+	    (IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
+	    (IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
+	   ) {
+		/* <20130121, Kordan> For SMIC EFUSE specificatoin. */
+		/* 0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8])	 */
+		/* phy_set_mac_reg(pAdapter, 0x34, BIT11, 0); */
+		rtw_write16(pAdapter, 0x34, rtw_read16(pAdapter, 0x34) & (~BIT11));
+	}
+
+	/* -----------------e-fuse reg ctrl --------------------------------- */
+	/* address			 */
+	rtw_write8(pAdapter, EFUSE_CTRL + 1, (u8)(addr & 0xff));
+	rtw_write8(pAdapter, EFUSE_CTRL + 2, ((u8)((addr >> 8) & 0x03)) |
+		   (rtw_read8(pAdapter, EFUSE_CTRL + 2) & 0xFC));
+
+	/* rtw_write8(pAdapter, EFUSE_CTRL+3,  0x72); */ /* read cmd	 */
+	/* Write bit 32 0 */
+	readbyte = rtw_read8(pAdapter, EFUSE_CTRL + 3);
+	rtw_write8(pAdapter, EFUSE_CTRL + 3, (readbyte & 0x7f));
+
+	while (!(0x80 & rtw_read8(pAdapter, EFUSE_CTRL + 3)) && (tmpidx < 1000)) {
 		rtw_mdelay_os(1);
 		tmpidx++;
 	}
-	if(tmpidx<100)
-	{			
-		*data=rtw_read8(pAdapter, EFUSE_CTRL);		
+	if (tmpidx < 100) {
+		*data = rtw_read8(pAdapter, EFUSE_CTRL);
 		bResult = _TRUE;
-	}
-	else
-	{
-		*data = 0xff;	
+	} else {
+		*data = 0xff;
 		bResult = _FALSE;
-		DBG_871X("%s: [ERROR] addr=0x%x bResult=%d time out 1s !!!\n", __FUNCTION__, addr, bResult);
-		DBG_871X("%s: [ERROR] EFUSE_CTRL =0x%08x !!!\n", __FUNCTION__, rtw_read32(pAdapter, EFUSE_CTRL));
+		RTW_INFO("%s: [ERROR] addr=0x%x bResult=%d time out 1s !!!\n", __FUNCTION__, addr, bResult);
+		RTW_INFO("%s: [ERROR] EFUSE_CTRL =0x%08x !!!\n", __FUNCTION__, rtw_read32(pAdapter, EFUSE_CTRL));
 	}
 
 	return bResult;
 }
-		
+
 /*  11/16/2008 MH Write one byte to reald Efuse. */
 u8
 efuse_OneByteWrite(
-	IN	PADAPTER	pAdapter,  
-	IN	u16			addr, 
+	IN	PADAPTER	pAdapter,
+	IN	u16			addr,
 	IN	u8			data,
 	IN	BOOLEAN		bPseudoTest)
 {
 	u8	tmpidx = 0;
-	u8	bResult=_FALSE;
+	u8	bResult = _FALSE;
 	u32 efuseValue = 0;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	
-	//DBG_871X("===> EFUSE_OneByteWrite(), addr = %x data=%x\n", addr, data);
-	//DBG_871X("===> EFUSE_OneByteWrite() start, 0x34 = 0x%X\n", rtw_read32(pAdapter, EFUSE_TEST));
 
-	if(bPseudoTest)
-	{
+	/* RTW_INFO("===> EFUSE_OneByteWrite(), addr = %x data=%x\n", addr, data); */
+	/* RTW_INFO("===> EFUSE_OneByteWrite() start, 0x34 = 0x%X\n", rtw_read32(pAdapter, EFUSE_TEST)); */
+
+	if (bPseudoTest) {
 		bResult = Efuse_Write1ByteToFakeContent(pAdapter, addr, data);
 		return bResult;
 	}
 
 	Efuse_PowerSwitch(pAdapter, _TRUE, _TRUE);
 
-	// -----------------e-fuse reg ctrl ---------------------------------	
-	//address			
+	/* -----------------e-fuse reg ctrl ---------------------------------	 */
+	/* address			 */
+
 
-	
 	efuseValue = rtw_read32(pAdapter, EFUSE_CTRL);
-	efuseValue |= (BIT21|BIT31);
+	efuseValue |= (BIT21 | BIT31);
 	efuseValue &= ~(0x3FFFF);
-	efuseValue |= ((addr<<8 | data) & 0x3FFFF);
-
-	// <20130227, Kordan> 8192E MP chip A-cut had better not set 0x34[11] until B-Cut.
-	if (	IS_HARDWARE_TYPE_8723B(pAdapter) ||
-		(IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->VersionID))) ||
-		(IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->VersionID))
-		) {
-		// <20130121, Kordan> For SMIC EFUSE specificatoin.
-		//0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8])
-		//PHY_SetMacReg(pAdapter, 0x34, BIT11, 1);
-		rtw_write16(pAdapter, 0x34, rtw_read16(pAdapter,0x34)| (BIT11) );
-		rtw_write32(pAdapter, EFUSE_CTRL, 0x90600000|((addr<<8 | data)) );
-	}
-	else
-	{
+	efuseValue |= ((addr << 8 | data) & 0x3FFFF);
+
+	/* <20130227, Kordan> 8192E MP chip A-cut had better not set 0x34[11] until B-Cut. */
+	if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
+	    (IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
+	    (IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
+	   ) {
+		/* <20130121, Kordan> For SMIC EFUSE specificatoin. */
+		/* 0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8]) */
+		/* phy_set_mac_reg(pAdapter, 0x34, BIT11, 1); */
+		rtw_write16(pAdapter, 0x34, rtw_read16(pAdapter, 0x34) | (BIT11));
+		rtw_write32(pAdapter, EFUSE_CTRL, 0x90600000 | ((addr << 8 | data)));
+	} else
 		rtw_write32(pAdapter, EFUSE_CTRL, efuseValue);
-	}
 
-	while((0x80 &  rtw_read8(pAdapter, EFUSE_CTRL+3)) && (tmpidx<100) ){
+	rtw_mdelay_os(1);
+
+	while ((0x80 &  rtw_read8(pAdapter, EFUSE_CTRL + 3)) && (tmpidx < 100)) {
 		rtw_mdelay_os(1);
 		tmpidx++;
 	}
 
-	if(tmpidx<100)
-	{
+	if (tmpidx < 100)
 		bResult = _TRUE;
-	}
-	else
-	{
+	else {
 		bResult = _FALSE;
-		DBG_871X("%s: [ERROR] addr=0x%x ,efuseValue=0x%x ,bResult=%d time out 1s !!! \n",
-					__FUNCTION__, addr, efuseValue, bResult);
-		DBG_871X("%s: [ERROR] EFUSE_CTRL =0x%08x !!!\n", __FUNCTION__, rtw_read32(pAdapter, EFUSE_CTRL));
+		RTW_INFO("%s: [ERROR] addr=0x%x ,efuseValue=0x%x ,bResult=%d time out 1s !!!\n",
+			 __FUNCTION__, addr, efuseValue, bResult);
+		RTW_INFO("%s: [ERROR] EFUSE_CTRL =0x%08x !!!\n", __FUNCTION__, rtw_read32(pAdapter, EFUSE_CTRL));
 	}
 
-	// disable Efuse program enable
-	if (	IS_HARDWARE_TYPE_8723B(pAdapter) ||
-		(IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->VersionID))) ||
-		(IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->VersionID))
-		) {
-		PHY_SetMacReg(pAdapter, EFUSE_TEST, BIT(11), 0);
-	}
+	/* disable Efuse program enable */
+	if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
+	    (IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
+	    (IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
+	   )
+		phy_set_mac_reg(pAdapter, EFUSE_TEST, BIT(11), 0);
 
 	Efuse_PowerSwitch(pAdapter, _TRUE, _FALSE);
 
@@ -570,114 +2134,70 @@ efuse_OneByteWrite(
 }
 
 int
-Efuse_PgPacketRead(	IN	PADAPTER	pAdapter,
-					IN	u8			offset,
-					IN	u8			*data,
-					IN	BOOLEAN		bPseudoTest)
-{
-	int	ret=0;
-
-	ret =  pAdapter->HalFunc.Efuse_PgPacketRead(pAdapter, offset, data, bPseudoTest);
-
-	return ret;
-}
-
-int 
-Efuse_PgPacketWrite(IN	PADAPTER	pAdapter, 
-					IN	u8 			offset,
-					IN	u8			word_en,
-					IN	u8			*data,
-					IN	BOOLEAN		bPseudoTest)
+Efuse_PgPacketRead(IN	PADAPTER	pAdapter,
+		   IN	u8			offset,
+		   IN	u8			*data,
+		   IN	BOOLEAN		bPseudoTest)
 {
-	int ret;
+	int	ret = 0;
 
-	ret =  pAdapter->HalFunc.Efuse_PgPacketWrite(pAdapter, offset, word_en, data, bPseudoTest);
+	ret =  pAdapter->hal_func.Efuse_PgPacketRead(pAdapter, offset, data, bPseudoTest);
 
 	return ret;
 }
 
-
-int 
-Efuse_PgPacketWrite_BT(IN	PADAPTER	pAdapter, 
-					IN	u8 			offset,
-					IN	u8			word_en,
-					IN	u8			*data,
-					IN	BOOLEAN		bPseudoTest)
+int
+Efuse_PgPacketWrite(IN	PADAPTER	pAdapter,
+		    IN	u8			offset,
+		    IN	u8			word_en,
+		    IN	u8			*data,
+		    IN	BOOLEAN		bPseudoTest)
 {
 	int ret;
-
-	ret =  pAdapter->HalFunc.Efuse_PgPacketWrite_BT(pAdapter, offset, word_en, data, bPseudoTest);
-
-	return ret;
-}
-
-/*-----------------------------------------------------------------------------
- * Function:	efuse_WordEnableDataRead
- *
- * Overview:	Read allowed word in current efuse section data.
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When			Who		Remark
- * 11/16/2008 	MHC		Create Version 0.
- * 11/21/2008 	MHC		Fix Write bug when we only enable late word.
- *
- *---------------------------------------------------------------------------*/
-void
-efuse_WordEnableDataRead(IN	u8	word_en,
-							IN	u8	*sourdata,
-							IN	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];
-	}
+
+	ret =  pAdapter->hal_func.Efuse_PgPacketWrite(pAdapter, offset, word_en, data, bPseudoTest);
+
+	return ret;
+}
+
+
+int
+Efuse_PgPacketWrite_BT(IN	PADAPTER	pAdapter,
+		       IN	u8			offset,
+		       IN	u8			word_en,
+		       IN	u8			*data,
+		       IN	BOOLEAN		bPseudoTest)
+{
+	int ret;
+
+	ret =  pAdapter->hal_func.Efuse_PgPacketWrite_BT(pAdapter, offset, word_en, data, bPseudoTest);
+
+	return ret;
 }
 
 
 u8
-Efuse_WordEnableDataWrite(	IN	PADAPTER	pAdapter,
-							IN	u16		efuse_addr,
-							IN	u8		word_en, 
-							IN	u8		*data,
-							IN	BOOLEAN		bPseudoTest)
+Efuse_WordEnableDataWrite(IN	PADAPTER	pAdapter,
+			  IN	u16		efuse_addr,
+			  IN	u8		word_en,
+			  IN	u8		*data,
+			  IN	BOOLEAN		bPseudoTest)
 {
-	u8	ret=0;
+	u8	ret = 0;
+
+	ret =  pAdapter->hal_func.Efuse_WordEnableDataWrite(pAdapter, efuse_addr, word_en, data, bPseudoTest);
 
-	ret =  pAdapter->HalFunc.Efuse_WordEnableDataWrite(pAdapter, efuse_addr, word_en, data, bPseudoTest);
-	
 	return ret;
 }
 
 static u8 efuse_read8(PADAPTER padapter, u16 address, u8 *value)
 {
-	return efuse_OneByteRead(padapter,address, value, _FALSE);
+	return efuse_OneByteRead(padapter, address, value, _FALSE);
 }
 
 static u8 efuse_write8(PADAPTER padapter, u16 address, u8 *value)
 {
-	return efuse_OneByteWrite(padapter,address, *value, _FALSE);
+	return efuse_OneByteWrite(padapter, address, *value, _FALSE);
 }
 
 /*
@@ -688,7 +2208,9 @@ u8 rtw_efuse_access(PADAPTER padapter, u8 bWrite, u16 start_addr, u16 cnts, u8 *
 	int i = 0;
 	u16	real_content_len = 0, max_available_size = 0;
 	u8 res = _FAIL ;
-	u8 (*rw8)(PADAPTER, u16, u8*);
+	u8(*rw8)(PADAPTER, u16, u8 *);
+	u32	backupRegs[4] = {0};
+
 
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_REAL_CONTENT_LEN, (PVOID)&real_content_len, _FALSE);
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (PVOID)&max_available_size, _FALSE);
@@ -703,9 +2225,11 @@ u8 rtw_efuse_access(PADAPTER padapter, u8 bWrite, u16 start_addr, u16 cnts, u8 *
 	} else
 		rw8 = &efuse_read8;
 
+	efuse_PreUpdateAction(padapter, backupRegs);
+
 	Efuse_PowerSwitch(padapter, bWrite, _TRUE);
 
-	// e-fuse one byte read / write
+	/* e-fuse one byte read / write */
 	for (i = 0; i < cnts; i++) {
 		if (start_addr >= real_content_len) {
 			res = _FAIL;
@@ -713,14 +2237,17 @@ u8 rtw_efuse_access(PADAPTER padapter, u8 bWrite, u16 start_addr, u16 cnts, u8 *
 		}
 
 		res = rw8(padapter, start_addr++, data++);
-		if (_FAIL == res) break;
+		if (_FAIL == res)
+			break;
 	}
 
 	Efuse_PowerSwitch(padapter, bWrite, _FALSE);
 
+	efuse_PostUpdateAction(padapter, backupRegs);
+
 	return res;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 u16 efuse_GetMaxSize(PADAPTER padapter)
 {
 	u16	max_size;
@@ -729,7 +2256,7 @@ u16 efuse_GetMaxSize(PADAPTER padapter)
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI , TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (PVOID)&max_size, _FALSE);
 	return max_size;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 u8 efuse_GetCurrentSize(PADAPTER padapter, u16 *size)
 {
 	Efuse_PowerSwitch(padapter, _FALSE, _TRUE);
@@ -738,7 +2265,7 @@ u8 efuse_GetCurrentSize(PADAPTER padapter, u16 *size)
 
 	return _SUCCESS;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 u16 efuse_bt_GetMaxSize(PADAPTER padapter)
 {
 	u16	max_size;
@@ -759,7 +2286,7 @@ u8 efuse_bt_GetCurrentSize(PADAPTER padapter, u16 *size)
 
 u8 rtw_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 {
-	u16	mapLen=0;
+	u16	mapLen = 0;
 
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, _FALSE);
 
@@ -777,7 +2304,7 @@ u8 rtw_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 
 u8 rtw_BT_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 {
-	u16	mapLen=0;
+	u16	mapLen = 0;
 
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, _FALSE);
 
@@ -793,165 +2320,7 @@ u8 rtw_BT_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 	return _SUCCESS;
 }
 
-BOOLEAN rtw_file_efuse_IsMasked(
-	PADAPTER	pAdapter,
-	u16		Offset
-	)
-{
-	int r = Offset/16;
-	int c = (Offset%16) / 2;
-	int result = 0;
-	
-	if(pAdapter->registrypriv.boffefusemask)
-		return FALSE;
-
-	//DBG_871X(" %s ,Offset=%x r= %d , c=%d , maskfileBuffer[r]= %x \n",__func__,Offset,r,c,maskfileBuffer[r]);
-	if (c < 4) // Upper double word
-	    result = (maskfileBuffer[r] & (0x10 << c));
-	else
-	    result = (maskfileBuffer[r] & (0x01 << (c-4)));
-	
-	return (result > 0) ? 0 : 1;
-
-}
-
-
-u8 rtw_efuse_file_read(PADAPTER padapter,u8 *filepatch,u8 *buf,u32 len)
-{
-	char *ptmp;
-	char *ptmpbuf=NULL;
-	u32 rtStatus;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-
-	ptmpbuf = rtw_zmalloc(2048);
-
-	if (ptmpbuf == NULL)
-		return _FALSE;
-
-	_rtw_memset(ptmpbuf,'\0',2048);
-	
-	rtStatus = rtw_retrieve_from_file(filepatch, ptmpbuf, 2048);
-
-	if( rtStatus > 100 )
-	{
-		u32 i,j;
-		for(i=0,j=0;j<len;i+=2,j++)
-		{
-			if (( ptmpbuf[i] == ' ' ) && (ptmpbuf[i+1] != '\n' && ptmpbuf[i+1] != '\0')) {
-				i++;
-			}
-			if( (ptmpbuf[i+1] != '\n' && ptmpbuf[i+1] != '\0'))
-			{
-					buf[j] = simple_strtoul(&ptmpbuf[i],&ptmp, 16);
-					DBG_871X(" i=%d,j=%d, %x \n",i,j,buf[j]);
-
-			} else {
-				j--;
-			}
-			
-		}
-
-	} else {
-		DBG_871X(" %s ,filepatch %s , FAIL %d\n", __func__, filepatch, rtStatus);
-		return _FALSE;
-	}
-	rtw_mfree(ptmpbuf, 2048);
-	DBG_871X(" %s ,filepatch %s , done %d\n", __func__, filepatch, rtStatus);
-	return _TRUE;
-}
-
-
-BOOLEAN 
-efuse_IsMasked(
-	PADAPTER	pAdapter,
-	u16		Offset
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	
-
-	//if (bEfuseMaskOFF(pAdapter))
-	if(pAdapter->registrypriv.boffefusemask)
-		return FALSE;
-		
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-#if defined(CONFIG_RTL8188E)
-	if (IS_HARDWARE_TYPE_8188E(pAdapter))  
-		return (IS_MASKED(8188E,_MUSB,Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8812A)
-	if (IS_HARDWARE_TYPE_8812(pAdapter))  
-		return (IS_MASKED(8812A,_MUSB,Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8821A)
-	//if (IS_HARDWARE_TYPE_8811AU(pAdapter))  
-	//	return (IS_MASKED(8811A,_MUSB,Offset)) ? TRUE : FALSE;
-	if (IS_HARDWARE_TYPE_8821(pAdapter))  
-		return (IS_MASKED(8821A,_MUSB,Offset)) ? TRUE : FALSE;		
-#endif		
-#if defined(CONFIG_RTL8192E)
-	if (IS_HARDWARE_TYPE_8192E(pAdapter))  
-		return (IS_MASKED(8192E,_MUSB,Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8723B)
-	if (IS_HARDWARE_TYPE_8723B(pAdapter))  
-		return (IS_MASKED(8723B,_MUSB,Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8703B)
-	if (IS_HARDWARE_TYPE_8703B(pAdapter))
-		return (IS_MASKED(8703B, _MUSB, Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8814A)
-	if (IS_HARDWARE_TYPE_8814A(pAdapter))
-		return (IS_MASKED(8814A, _MUSB, Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8188F)
-	if (IS_HARDWARE_TYPE_8188F(pAdapter))
-		return (IS_MASKED(8188F, _MUSB, Offset)) ? TRUE : FALSE;
-#endif
-#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
-#if defined(CONFIG_RTL8188E)
-	if (IS_HARDWARE_TYPE_8188E(pAdapter))  
-		return (IS_MASKED(8188E,_MPCIE,Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8192E)
-   	if (IS_HARDWARE_TYPE_8192E(pAdapter))	
-		return (IS_MASKED(8192E,_MPCIE,Offset)) ? TRUE : FALSE;
-#endif	
-#if defined(CONFIG_RTL8812A)
-	if (IS_HARDWARE_TYPE_8812(pAdapter))  
-		return (IS_MASKED(8812A,_MPCIE,Offset)) ? TRUE : FALSE;
-#endif	
-#if defined(CONFIG_RTL8821A)
-	if (IS_HARDWARE_TYPE_8821(pAdapter))  
-		return (IS_MASKED(8821A,_MPCIE,Offset)) ? TRUE : FALSE;
-#endif
-#if defined(CONFIG_RTL8723B)
-	if (IS_HARDWARE_TYPE_8723B(pAdapter))  
-		return (IS_MASKED(8723B,_MPCIE,Offset)) ? TRUE : FALSE; 
-#endif
-#if defined(CONFIG_RTL8814A)
-	if (IS_HARDWARE_TYPE_8814A(pAdapter))
-		return (IS_MASKED(8814A, _MPCIE, Offset)) ? TRUE : FALSE;
-#endif
-	//else if (IS_HARDWARE_TYPE_8821B(pAdapter))  
-	//	return (IS_MASKED(8821B,_MPCIE,Offset)) ? TRUE : FALSE; 
-
-#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
-#ifdef CONFIG_RTL8188E_SDIO
-	if (IS_HARDWARE_TYPE_8188E(pAdapter))  
-		return (IS_MASKED(8188E,_MSDIO,Offset)) ? TRUE : FALSE;
-#endif
-#ifdef CONFIG_RTL8188F_SDIO
-	if (IS_HARDWARE_TYPE_8188F(pAdapter))  
-		return (IS_MASKED(8188F, _MSDIO, Offset)) ? TRUE : FALSE;
-#endif
-#endif
-
-	return FALSE;	
-}
-
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 {
 #define RT_ASSERT_RET(expr)												\
@@ -961,15 +2330,18 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 		return _FAIL;	\
 	}
 
+	u8 *efuse = NULL;
 	u8	offset, word_en;
-	u8	*map;
+	u8	*map = NULL;
 	u8	newdata[PGPKT_DATA_SIZE];
 	s32	i, j, idx, chk_total_byte;
 	u8	ret = _SUCCESS;
 	u16	mapLen = 0, startAddr = 0, efuse_max_available_len = 0;
+	u32	backupRegs[4] = {0};
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	PEFUSE_HAL	pEfuseHal = &pHalData->EfuseHal;
 
+
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, _FALSE);
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, &efuse_max_available_len, _FALSE);
 
@@ -979,9 +2351,15 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 	RT_ASSERT_RET(PGPKT_DATA_SIZE == 8); /* have to be 8 byte alignment */
 	RT_ASSERT_RET((mapLen & 0x7) == 0); /* have to be PGPKT_DATA_SIZE alignment for memcpy */
 
+	efuse = rtw_zmalloc(mapLen);
+	if (!efuse)
+		return _FAIL;
+
 	map = rtw_zmalloc(mapLen);
-	if (map == NULL)
+	if (map == NULL) {
+		rtw_mfree(efuse, mapLen);
 		return _FAIL;
+	}
 
 	_rtw_memset(map, 0xFF, mapLen);
 
@@ -989,16 +2367,19 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 	if (ret == _FAIL)
 		goto exit;
 
+	_rtw_memcpy(efuse , map, mapLen);
+	_rtw_memcpy(efuse + addr, data, cnts);
+
 	if (padapter->registrypriv.boffefusemask == 0) {
 		for (i = 0; i < cnts; i++) {
 			if (padapter->registrypriv.bFileMaskEfuse == _TRUE) {
 				if (rtw_file_efuse_IsMasked(padapter, addr + i))	/*use file efuse mask. */
-					data[i] = map[addr + i];
+					efuse[addr + i] = map[addr + i];
 			} else {
 				if (efuse_IsMasked(padapter, addr + i))
-					data[i] = map[addr + i];
+					efuse[addr + i] = map[addr + i];
 			}
-			RTW_INFO("%s , data[%d] = %x, map[addr+i]= %x\n", __func__, i, data[i], map[addr + i]);
+			RTW_INFO("%s , data[%d] = %x, map[addr+i]= %x\n", __func__, addr + i, efuse[ addr + i], map[addr + i]);
 		}
 	}
 	/*Efuse_PowerSwitch(padapter, _TRUE, _TRUE);*/
@@ -1011,7 +2392,7 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 		word_en = 0xF;
 		j = (addr + idx) & 0x7;
 		for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
-			if (data[idx] != map[addr + idx])
+			if (efuse[addr + idx] != map[addr + idx])
 				word_en &= ~BIT(i >> 1);
 		}
 
@@ -1034,7 +2415,7 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 		startAddr = Efuse_GetCurrentSize(padapter, EFUSE_WIFI, _FALSE);
 		RTW_INFO("%s: Efuse_GetCurrentSize startAddr=%#X\n", __func__, startAddr);
 	}
-	/* RTW_DBG("%s: startAddr=%#X\n", __func__, startAddr); */
+	RTW_DBG("%s: startAddr=%#X\n", __func__, startAddr);
 
 	if ((startAddr + chk_total_byte) >= efuse_max_available_len) {
 		RTW_INFO("%s: startAddr(0x%X) + PG data len %d >= efuse_max_available_len(0x%X)\n",
@@ -1043,6 +2424,7 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 		goto exit;
 	}
 
+	efuse_PreUpdateAction(padapter, backupRegs);
 
 	idx = 0;
 	offset = (addr >> 3);
@@ -1051,12 +2433,12 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 		j = (addr + idx) & 0x7;
 		_rtw_memcpy(newdata, &map[offset << 3], PGPKT_DATA_SIZE);
 		for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
-			if (data[idx] != map[addr + idx]) {
+			if (efuse[addr + idx] != map[addr + idx]) {
 				word_en &= ~BIT(i >> 1);
-				newdata[i] = data[idx];
+				newdata[i] = efuse[addr + idx];
 #ifdef CONFIG_RTL8723B
 				if (addr + idx == 0x8) {
-					if (IS_C_CUT(pHalData->VersionID) || IS_B_CUT(pHalData->VersionID)) {
+					if (IS_C_CUT(pHalData->version_id) || IS_B_CUT(pHalData->version_id)) {
 						if (pHalData->adjuseVoltageVal == 6) {
 							newdata[i] = map[addr + idx];
 							RTW_INFO(" %s ,\n adjuseVoltageVal = %d ,newdata[%d] = %x\n", __func__, pHalData->adjuseVoltageVal, i, newdata[i]);
@@ -1083,41 +2465,16 @@ u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 
 	/*Efuse_PowerSwitch(padapter, _TRUE, _FALSE);*/
 
+	efuse_PostUpdateAction(padapter, backupRegs);
+
 exit:
 
 	rtw_mfree(map, mapLen);
+	rtw_mfree(efuse, mapLen);
 
 	return ret;
 }
 
-u8 rtw_efuse_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
-{
-	u8	ret = _SUCCESS;
-	u16	mapLen = 0, i = 0;
-	
-	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, _FALSE);
-	
-	ret = rtw_efuse_map_read(padapter, addr, cnts , data);
-
-	if (padapter->registrypriv.boffefusemask == 0) {
-
-			for (i = 0; i < cnts; i++) { 
-				if (padapter->registrypriv.bFileMaskEfuse == _TRUE) {
-					if (rtw_file_efuse_IsMasked(padapter, addr+i)) /*use file efuse mask.*/ 
-							data[i] = 0xff;
-				} else {
-					/*DBG_8192C(" %s , data[%d] = %x\n", __func__, i, data[i]);*/
-					if (efuse_IsMasked(padapter, addr+i)) {
-						data[i] = 0xff;
-						/*DBG_8192C(" %s ,mask data[%d] = %x\n", __func__, i, data[i]);*/
-					}
-				}
-			}
-	
-	}
-	return ret;
-
-}
 
 u8 rtw_BT_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 {
@@ -1131,68 +2488,61 @@ u8 rtw_BT_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
 	u8	offset, word_en;
 	u8	*map;
 	u8	newdata[PGPKT_DATA_SIZE];
-	s32	i=0, j=0, idx;
+	s32	i = 0, j = 0, idx;
 	u8	ret = _SUCCESS;
-	u16	mapLen=0;
+	u16	mapLen = 0;
 
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, _FALSE);
 
 	if ((addr + cnts) > mapLen)
 		return _FAIL;
 
-	RT_ASSERT_RET(PGPKT_DATA_SIZE == 8); // have to be 8 byte alignment
-	RT_ASSERT_RET((mapLen & 0x7) == 0); // have to be PGPKT_DATA_SIZE alignment for memcpy
+	RT_ASSERT_RET(PGPKT_DATA_SIZE == 8); /* have to be 8 byte alignment */
+	RT_ASSERT_RET((mapLen & 0x7) == 0); /* have to be PGPKT_DATA_SIZE alignment for memcpy */
 
 	map = rtw_zmalloc(mapLen);
-	if(map == NULL){
+	if (map == NULL)
 		return _FAIL;
-	}
 
 	ret = rtw_BT_efuse_map_read(padapter, 0, mapLen, map);
-	if (ret == _FAIL) goto exit;
-	DBG_871X("OFFSET\tVALUE(hex)\n");
-	for (i=0; i<1024; i+=16) // set 512 because the iwpriv's extra size have limit 0x7FF
-	{
-			DBG_871X("0x%03x\t", i);
-			for (j=0; j<8; j++) {
-				DBG_871X("%02X ", map[i+j]);
-			}
-			DBG_871X("\t");
-			for (; j<16; j++) {
-				DBG_871X("%02X ", map[i+j]);
-			}
-			DBG_871X("\n");
+	if (ret == _FAIL)
+		goto exit;
+	RTW_INFO("OFFSET\tVALUE(hex)\n");
+	for (i = 0; i < 1024; i += 16) { /* set 512 because the iwpriv's extra size have limit 0x7FF */
+		RTW_INFO("0x%03x\t", i);
+		for (j = 0; j < 8; j++)
+			RTW_INFO("%02X ", map[i + j]);
+		RTW_INFO("\t");
+		for (; j < 16; j++)
+			RTW_INFO("%02X ", map[i + j]);
+		RTW_INFO("\n");
 	}
-	DBG_871X("\n");
+	RTW_INFO("\n");
 	Efuse_PowerSwitch(padapter, _TRUE, _TRUE);
 
 	idx = 0;
 	offset = (addr >> 3);
-	while (idx < cnts)
-	{
+	while (idx < cnts) {
 		word_en = 0xF;
 		j = (addr + idx) & 0x7;
 		_rtw_memcpy(newdata, &map[offset << 3], PGPKT_DATA_SIZE);
-		for (i = j; i<PGPKT_DATA_SIZE && idx < cnts; i++, idx++)
-		{
-			if (data[idx] != map[addr + idx])
-			{
+		for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
+			if (data[idx] != map[addr + idx]) {
 				word_en &= ~BIT(i >> 1);
 				newdata[i] = data[idx];
 			}
 		}
 
 		if (word_en != 0xF) {
-			DBG_871X("offset=%x \n",offset);
-			DBG_871X("word_en=%x \n",word_en);
-			DBG_871X("%s: data=", __FUNCTION__);
-			for(i=0;i<PGPKT_DATA_SIZE;i++)
-			{
-				DBG_871X("0x%02X ", newdata[i]);
-			}
-			DBG_871X("\n");
+			RTW_INFO("offset=%x\n", offset);
+			RTW_INFO("word_en=%x\n", word_en);
+			RTW_INFO("%s: data=", __FUNCTION__);
+			for (i = 0; i < PGPKT_DATA_SIZE; i++)
+				RTW_INFO("0x%02X ", newdata[i]);
+			RTW_INFO("\n");
 			ret = Efuse_PgPacketWrite_BT(padapter, offset, word_en, newdata, _FALSE);
-			if (ret == _FAIL) break;
+			if (ret == _FAIL)
+				break;
 		}
 
 		offset++;
@@ -1220,33 +2570,174 @@ exit:
  *
  * Revised History:
  * When			Who		Remark
- * 11/11/2008 	MHC		Create Version 0.
+ * 11/11/2008	MHC		Create Version 0.
  *
  *---------------------------------------------------------------------------*/
-VOID 
+VOID
 Efuse_ReadAllMap(
-	IN		PADAPTER	pAdapter, 
+	IN		PADAPTER	pAdapter,
 	IN		u8		efuseType,
 	IN OUT	u8		*Efuse,
 	IN		BOOLEAN		bPseudoTest);
-VOID 
+VOID
 Efuse_ReadAllMap(
-	IN		PADAPTER	pAdapter, 
+	IN		PADAPTER	pAdapter,
 	IN		u8		efuseType,
 	IN OUT	u8		*Efuse,
 	IN		BOOLEAN		bPseudoTest)
 {
-	u16	mapLen=0;
+	u16	mapLen = 0;
+
+	Efuse_PowerSwitch(pAdapter, _FALSE, _TRUE);
+
+	EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, bPseudoTest);
+
+	efuse_ReadEFuse(pAdapter, efuseType, 0, mapLen, Efuse, bPseudoTest);
+
+	Efuse_PowerSwitch(pAdapter, _FALSE, _FALSE);
+}
+
+/*-----------------------------------------------------------------------------
+ * Function:	efuse_ShadowWrite1Byte
+ *			efuse_ShadowWrite2Byte
+ *			efuse_ShadowWrite4Byte
+ *
+ * Overview:	Write efuse modify map by one/two/four byte.
+ *
+ * Input:       NONE
+ *
+ * Output:      NONE
+ *
+ * Return:      NONE
+ *
+ * Revised History:
+ * When			Who		Remark
+ * 11/12/2008	MHC		Create Version 0.
+ *
+ *---------------------------------------------------------------------------*/
+#ifdef PLATFORM
+static VOID
+efuse_ShadowWrite1Byte(
+	IN	PADAPTER	pAdapter,
+	IN	u16		Offset,
+	IN	u8		Value);
+#endif /* PLATFORM */
+static VOID
+efuse_ShadowWrite1Byte(
+	IN	PADAPTER	pAdapter,
+	IN	u16		Offset,
+	IN	u8		Value)
+{
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
+
+	pHalData->efuse_eeprom_data[Offset] = Value;
+
+}	/* efuse_ShadowWrite1Byte */
+
+/* ---------------Write Two Bytes */
+static VOID
+efuse_ShadowWrite2Byte(
+	IN	PADAPTER	pAdapter,
+	IN	u16		Offset,
+	IN	u16		Value)
+{
+
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
+
+
+	pHalData->efuse_eeprom_data[Offset] = Value & 0x00FF;
+	pHalData->efuse_eeprom_data[Offset + 1] = Value >> 8;
+
+}	/* efuse_ShadowWrite1Byte */
+
+/* ---------------Write Four Bytes */
+static VOID
+efuse_ShadowWrite4Byte(
+	IN	PADAPTER	pAdapter,
+	IN	u16		Offset,
+	IN	u32		Value)
+{
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
+
+	pHalData->efuse_eeprom_data[Offset] = (u8)(Value & 0x000000FF);
+	pHalData->efuse_eeprom_data[Offset + 1] = (u8)((Value >> 8) & 0x0000FF);
+	pHalData->efuse_eeprom_data[Offset + 2] = (u8)((Value >> 16) & 0x00FF);
+	pHalData->efuse_eeprom_data[Offset + 3] = (u8)((Value >> 24) & 0xFF);
+
+}	/* efuse_ShadowWrite1Byte */
+
+
+/*-----------------------------------------------------------------------------
+ * Function:	EFUSE_ShadowWrite
+ *
+ * Overview:	Write efuse modify map for later update operation to use!!!!!
+ *
+ * Input:       NONE
+ *
+ * Output:      NONE
+ *
+ * Return:      NONE
+ *
+ * Revised History:
+ * When			Who		Remark
+ * 11/12/2008	MHC		Create Version 0.
+ *
+ *---------------------------------------------------------------------------*/
+VOID
+EFUSE_ShadowWrite(
+	IN	PADAPTER	pAdapter,
+	IN	u8		Type,
+	IN	u16		Offset,
+	IN OUT	u32		Value);
+VOID
+EFUSE_ShadowWrite(
+	IN	PADAPTER	pAdapter,
+	IN	u8		Type,
+	IN	u16		Offset,
+	IN OUT	u32		Value)
+{
+#if (MP_DRIVER == 0)
+	return;
+#endif
+	if (pAdapter->registrypriv.mp_mode == 0)
+		return;
+
+
+	if (Type == 1)
+		efuse_ShadowWrite1Byte(pAdapter, Offset, (u8)Value);
+	else if (Type == 2)
+		efuse_ShadowWrite2Byte(pAdapter, Offset, (u16)Value);
+	else if (Type == 4)
+		efuse_ShadowWrite4Byte(pAdapter, Offset, (u32)Value);
 
-	Efuse_PowerSwitch(pAdapter,_FALSE, _TRUE);
+}	/* EFUSE_ShadowWrite */
 
-	EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, bPseudoTest);
+VOID
+Efuse_InitSomeVar(
+	IN		PADAPTER	pAdapter
+);
+VOID
+Efuse_InitSomeVar(
+	IN		PADAPTER	pAdapter
+)
+{
+	u8 i;
 
-	efuse_ReadEFuse(pAdapter, efuseType, 0, mapLen, Efuse, bPseudoTest);
+	_rtw_memset((PVOID)&fakeEfuseContent[0], 0xff, EFUSE_MAX_HW_SIZE);
+	_rtw_memset((PVOID)&fakeEfuseInitMap[0], 0xff, EFUSE_MAX_MAP_LEN);
+	_rtw_memset((PVOID)&fakeEfuseModifiedMap[0], 0xff, EFUSE_MAX_MAP_LEN);
 
-	Efuse_PowerSwitch(pAdapter,_FALSE, _FALSE);
-}
+	for (i = 0; i < EFUSE_MAX_BT_BANK; i++)
+		_rtw_memset((PVOID)&BTEfuseContent[i][0], EFUSE_MAX_HW_SIZE, 0xff);
+	_rtw_memset((PVOID)&BTEfuseInitMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
+	_rtw_memset((PVOID)&BTEfuseModifiedMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
 
+	for (i = 0; i < EFUSE_MAX_BT_BANK; i++)
+		_rtw_memset((PVOID)&fakeBTEfuseContent[i][0], 0xff, EFUSE_MAX_HW_SIZE);
+	_rtw_memset((PVOID)&fakeBTEfuseInitMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
+	_rtw_memset((PVOID)&fakeBTEfuseModifiedMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
+}
+#endif /* !RTW_HALMAC */
 /*-----------------------------------------------------------------------------
  * Function:	efuse_ShadowRead1Byte
  *			efuse_ShadowRead2Byte
@@ -1262,7 +2753,7 @@ Efuse_ReadAllMap(
  *
  * Revised History:
  * When			Who		Remark
- * 11/12/2008 	MHC		Create Version 0.
+ * 11/12/2008	MHC		Create Version 0.
  *
  *---------------------------------------------------------------------------*/
 static VOID
@@ -1275,9 +2766,9 @@ efuse_ShadowRead1Byte(
 
 	*Value = pHalData->efuse_eeprom_data[Offset];
 
-}	// EFUSE_ShadowRead1Byte
+}	/* EFUSE_ShadowRead1Byte */
 
-//---------------Read Two Bytes
+/* ---------------Read Two Bytes */
 static VOID
 efuse_ShadowRead2Byte(
 	IN	PADAPTER	pAdapter,
@@ -1287,11 +2778,11 @@ efuse_ShadowRead2Byte(
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
 
 	*Value = pHalData->efuse_eeprom_data[Offset];
-	*Value |= pHalData->efuse_eeprom_data[Offset+1]<<8;
+	*Value |= pHalData->efuse_eeprom_data[Offset + 1] << 8;
 
-}	// EFUSE_ShadowRead2Byte
+}	/* EFUSE_ShadowRead2Byte */
 
-//---------------Read Four Bytes
+/* ---------------Read Four Bytes */
 static VOID
 efuse_ShadowRead4Byte(
 	IN	PADAPTER	pAdapter,
@@ -1301,19 +2792,53 @@ efuse_ShadowRead4Byte(
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
 
 	*Value = pHalData->efuse_eeprom_data[Offset];
-	*Value |= pHalData->efuse_eeprom_data[Offset+1]<<8;
-	*Value |= pHalData->efuse_eeprom_data[Offset+2]<<16;
-	*Value |= pHalData->efuse_eeprom_data[Offset+3]<<24;
+	*Value |= pHalData->efuse_eeprom_data[Offset + 1] << 8;
+	*Value |= pHalData->efuse_eeprom_data[Offset + 2] << 16;
+	*Value |= pHalData->efuse_eeprom_data[Offset + 3] << 24;
+
+}	/* efuse_ShadowRead4Byte */
+
+/*-----------------------------------------------------------------------------
+ * Function:	EFUSE_ShadowRead
+ *
+ * Overview:	Read from pHalData->efuse_eeprom_data
+ *---------------------------------------------------------------------------*/
+void
+EFUSE_ShadowRead(
+	IN		PADAPTER	pAdapter,
+	IN		u8		Type,
+	IN		u16		Offset,
+	IN OUT	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);
 
-}	// efuse_ShadowRead4Byte
+}	/* EFUSE_ShadowRead */
 
+/*  11/16/2008 MH Add description. Get current efuse area enabled word!!. */
+u8
+Efuse_CalculateWordCnts(IN u8	word_en)
+{
+	u8 word_cnts = 0;
+	if (!(word_en & BIT(0)))
+		word_cnts++; /* 0 : write enable */
+	if (!(word_en & BIT(1)))
+		word_cnts++;
+	if (!(word_en & BIT(2)))
+		word_cnts++;
+	if (!(word_en & BIT(3)))
+		word_cnts++;
+	return word_cnts;
+}
 
 /*-----------------------------------------------------------------------------
- * Function:	efuse_ShadowWrite1Byte
- *			efuse_ShadowWrite2Byte
- *			efuse_ShadowWrite4Byte
+ * Function:	efuse_WordEnableDataRead
  *
- * Overview:	Write efuse modify map by one/two/four byte.
+ * Overview:	Read allowed word in current efuse section data.
  *
  * Input:       NONE
  *
@@ -1323,59 +2848,32 @@ efuse_ShadowRead4Byte(
  *
  * Revised History:
  * When			Who		Remark
- * 11/12/2008 	MHC		Create Version 0.
+ * 11/16/2008	MHC		Create Version 0.
+ * 11/21/2008	MHC		Fix Write bug when we only enable late word.
  *
  *---------------------------------------------------------------------------*/
-#ifdef PLATFORM
-static VOID
-efuse_ShadowWrite1Byte(
-	IN	PADAPTER	pAdapter,
-	IN	u16		Offset,
-	IN 	u8		Value);
-#endif //PLATFORM
-static VOID
-efuse_ShadowWrite1Byte(
-	IN	PADAPTER	pAdapter,
-	IN	u16		Offset,
-	IN 	u8		Value)
-{
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
-
-	pHalData->efuse_eeprom_data[Offset] = Value;
-
-}	// efuse_ShadowWrite1Byte
-
-//---------------Write Two Bytes
-static VOID
-efuse_ShadowWrite2Byte(
-	IN	PADAPTER	pAdapter,
-	IN	u16		Offset,
-	IN 	u16		Value)
-{
-	
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
-	
-
-	pHalData->efuse_eeprom_data[Offset] = Value&0x00FF;
-	pHalData->efuse_eeprom_data[Offset+1] = Value>>8;
-
-}	// efuse_ShadowWrite1Byte
-
-//---------------Write Four Bytes
-static VOID
-efuse_ShadowWrite4Byte(
-	IN	PADAPTER	pAdapter,
-	IN	u16		Offset,
-	IN	u32		Value)
+void
+efuse_WordEnableDataRead(IN	u8	word_en,
+			 IN	u8	*sourdata,
+			 IN	u8	*targetdata)
 {
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
-
-	pHalData->efuse_eeprom_data[Offset] = (u8)(Value&0x000000FF);
-	pHalData->efuse_eeprom_data[Offset+1] = (u8)((Value>>8)&0x0000FF);
-	pHalData->efuse_eeprom_data[Offset+2] = (u8)((Value>>16)&0x00FF);
-	pHalData->efuse_eeprom_data[Offset+3] = (u8)((Value>>24)&0xFF);
-
-}	// efuse_ShadowWrite1Byte
+	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];
+	}
+}
 
 /*-----------------------------------------------------------------------------
  * Function:	EFUSE_ShadowMapUpdate
@@ -1390,7 +2888,7 @@ efuse_ShadowWrite4Byte(
  *
  * Revised History:
  * When			Who		Remark
- * 11/13/2008 	MHC		Create Version 0.
+ * 11/13/2008	MHC		Create Version 0.
  *
  *---------------------------------------------------------------------------*/
 void EFUSE_ShadowMapUpdate(
@@ -1399,158 +2897,76 @@ void EFUSE_ShadowMapUpdate(
 	IN BOOLEAN	bPseudoTest)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
-	u16	mapLen=0;
+	u16	mapLen = 0;
+#ifdef RTW_HALMAC
+	u8 *efuse_map = NULL;
+	int err;
 
-	EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, bPseudoTest);
 
-	if (pHalData->bautoload_fail_flag == _TRUE)
-	{
-		_rtw_memset(pHalData->efuse_eeprom_data, 0xFF, mapLen);
+	mapLen = EEPROM_MAX_SIZE;
+	efuse_map = pHalData->efuse_eeprom_data;
+	/* efuse default content is 0xFF */
+	_rtw_memset(efuse_map, 0xFF, EEPROM_MAX_SIZE);
+
+	EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, bPseudoTest);
+	if (!mapLen) {
+		RTW_WARN("%s: <ERROR> fail to get efuse size!\n", __FUNCTION__);
+		mapLen = EEPROM_MAX_SIZE;
 	}
-	else
-	{
-		#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE			
-		if(_SUCCESS != retriveAdaptorInfoFile(pAdapter->registrypriv.adaptor_info_caching_file_path, pHalData->efuse_eeprom_data)) {
-		#endif
-		
-		Efuse_ReadAllMap(pAdapter, efuseType, pHalData->efuse_eeprom_data, bPseudoTest);
-		
-		#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
-			storeAdaptorInfoFile(pAdapter->registrypriv.adaptor_info_caching_file_path, pHalData->efuse_eeprom_data);
-		}
-		#endif
+	if (mapLen > EEPROM_MAX_SIZE) {
+		RTW_WARN("%s: <ERROR> size of efuse data(%d) is large than expected(%d)!\n",
+			 __FUNCTION__, mapLen, EEPROM_MAX_SIZE);
+		mapLen = EEPROM_MAX_SIZE;
 	}
 
-	//PlatformMoveMemory((PVOID)&pHalData->EfuseMap[EFUSE_MODIFY_MAP][0], 
-	//(PVOID)&pHalData->EfuseMap[EFUSE_INIT_MAP][0], mapLen);
-
-	rtw_dump_cur_efuse(pAdapter);
-}// EFUSE_ShadowMapUpdate
-
-
-/*-----------------------------------------------------------------------------
- * Function:	EFUSE_ShadowRead
- *
- * Overview:	Read from efuse init map !!!!!
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When			Who		Remark
- * 11/12/2008 	MHC		Create Version 0.
- *
- *---------------------------------------------------------------------------*/
-void
-EFUSE_ShadowRead(
-	IN		PADAPTER	pAdapter,
-	IN		u8		Type,
-	IN		u16		Offset,
-	IN OUT	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);
-	
-}	// EFUSE_ShadowRead
+	if (pHalData->bautoload_fail_flag == _FALSE) {
+		err = rtw_halmac_read_logical_efuse_map(adapter_to_dvobj(pAdapter), efuse_map, mapLen, NULL, 0);
+		if (err)
+			RTW_ERR("%s: <ERROR> fail to get efuse map!\n", __FUNCTION__);
+	}
+#else /* !RTW_HALMAC */
+	EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, bPseudoTest);
 
-/*-----------------------------------------------------------------------------
- * Function:	EFUSE_ShadowWrite
- *
- * Overview:	Write efuse modify map for later update operation to use!!!!!
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When			Who		Remark
- * 11/12/2008 	MHC		Create Version 0.
- *
- *---------------------------------------------------------------------------*/
-VOID
-EFUSE_ShadowWrite(
-	IN	PADAPTER	pAdapter,
-	IN	u8		Type,
-	IN	u16		Offset,
-	IN OUT	u32		Value);
-VOID
-EFUSE_ShadowWrite(
-	IN	PADAPTER	pAdapter,
-	IN	u8		Type,
-	IN	u16		Offset,
-	IN OUT	u32		Value)
-{
-#if (MP_DRIVER == 0)
-	return;
+	if (pHalData->bautoload_fail_flag == _TRUE)
+		_rtw_memset(pHalData->efuse_eeprom_data, 0xFF, mapLen);
+	else {
+#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
+		if (_SUCCESS != retriveAdaptorInfoFile(pAdapter->registrypriv.adaptor_info_caching_file_path, pHalData->efuse_eeprom_data)) {
 #endif
-	if ( pAdapter->registrypriv.mp_mode == 0)
-		return;
-
 
-	if (Type == 1)
-		efuse_ShadowWrite1Byte(pAdapter, Offset, (u8)Value);
-	else if (Type == 2)
-		efuse_ShadowWrite2Byte(pAdapter, Offset, (u16)Value);
-	else if (Type == 4)
-		efuse_ShadowWrite4Byte(pAdapter, Offset, (u32)Value);
+			Efuse_ReadAllMap(pAdapter, efuseType, pHalData->efuse_eeprom_data, bPseudoTest);
 
-}	// EFUSE_ShadowWrite
+#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
+			storeAdaptorInfoFile(pAdapter->registrypriv.adaptor_info_caching_file_path, pHalData->efuse_eeprom_data);
+		}
+#endif
+	}
 
-VOID
-Efuse_InitSomeVar(
-	IN		PADAPTER	pAdapter
-	);
-VOID
-Efuse_InitSomeVar(
-	IN		PADAPTER	pAdapter
-	)
-{
-	u8 i;
-	
-	_rtw_memset((PVOID)&fakeEfuseContent[0], 0xff, EFUSE_MAX_HW_SIZE);
-	_rtw_memset((PVOID)&fakeEfuseInitMap[0], 0xff, EFUSE_MAX_MAP_LEN);
-	_rtw_memset((PVOID)&fakeEfuseModifiedMap[0], 0xff, EFUSE_MAX_MAP_LEN);
+	/* PlatformMoveMemory((PVOID)&pHalData->EfuseMap[EFUSE_MODIFY_MAP][0], */
+	/* (PVOID)&pHalData->EfuseMap[EFUSE_INIT_MAP][0], mapLen); */
+#endif /* !RTW_HALMAC */
 
-	for(i=0; i<EFUSE_MAX_BT_BANK; i++)
-	{
-		_rtw_memset((PVOID)&BTEfuseContent[i][0], EFUSE_MAX_HW_SIZE, 0xff);
-	}
-	_rtw_memset((PVOID)&BTEfuseInitMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
-	_rtw_memset((PVOID)&BTEfuseModifiedMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
+	rtw_mask_map_read(pAdapter, 0x00, mapLen, pHalData->efuse_eeprom_data);
 
-	for(i=0; i<EFUSE_MAX_BT_BANK; i++)
-	{
-		_rtw_memset((PVOID)&fakeBTEfuseContent[i][0], 0xff, EFUSE_MAX_HW_SIZE);
-	}
-	_rtw_memset((PVOID)&fakeBTEfuseInitMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
-	_rtw_memset((PVOID)&fakeBTEfuseModifiedMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
-}
+	rtw_dump_cur_efuse(pAdapter);
+} /* EFUSE_ShadowMapUpdate */
 
 const u8 _mac_hidden_max_bw_to_hal_bw_cap[MAC_HIDDEN_MAX_BW_NUM] = {
 	0,
 	0,
-	(BW_CAP_160M|BW_CAP_80M|BW_CAP_40M|BW_CAP_20M|BW_CAP_10M|BW_CAP_5M),
+	(BW_CAP_160M | BW_CAP_80M | BW_CAP_40M | BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
 	(BW_CAP_5M),
-	(BW_CAP_10M|BW_CAP_5M),
-	(BW_CAP_20M|BW_CAP_10M|BW_CAP_5M),
-	(BW_CAP_40M|BW_CAP_20M|BW_CAP_10M|BW_CAP_5M),
-	(BW_CAP_80M|BW_CAP_40M|BW_CAP_20M|BW_CAP_10M|BW_CAP_5M),
+	(BW_CAP_10M | BW_CAP_5M),
+	(BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
+	(BW_CAP_40M | BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
+	(BW_CAP_80M | BW_CAP_40M | BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
 };
 
 const u8 _mac_hidden_proto_to_hal_proto_cap[MAC_HIDDEN_PROTOCOL_NUM] = {
 	0,
 	0,
-	(PROTO_CAP_11N|PROTO_CAP_11G|PROTO_CAP_11B),
-	(PROTO_CAP_11AC|PROTO_CAP_11N|PROTO_CAP_11G|PROTO_CAP_11B),
+	(PROTO_CAP_11N | PROTO_CAP_11G | PROTO_CAP_11B),
+	(PROTO_CAP_11AC | PROTO_CAP_11N | PROTO_CAP_11G | PROTO_CAP_11B),
 };
 
 u8 mac_hidden_wl_func_to_hal_wl_func(u8 func)
@@ -1571,61 +2987,116 @@ u8 mac_hidden_wl_func_to_hal_wl_func(u8 func)
 
 #ifdef PLATFORM_LINUX
 #ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
-//#include <rtw_eeprom.h>
+/* #include <rtw_eeprom.h> */
 
- int isAdaptorInfoFileValid(void)
+int isAdaptorInfoFileValid(void)
 {
 	return _TRUE;
 }
 
-int storeAdaptorInfoFile(char *path, u8* efuse_data)
+int storeAdaptorInfoFile(char *path, u8 *efuse_data)
 {
-	int ret =_SUCCESS;
+	int ret = _SUCCESS;
 
-	if(path && efuse_data) {
+	if (path && efuse_data) {
 		ret = rtw_store_to_file(path, efuse_data, EEPROM_MAX_SIZE_512);
-		if(ret == EEPROM_MAX_SIZE)
+		if (ret == EEPROM_MAX_SIZE)
 			ret = _SUCCESS;
 		else
 			ret = _FAIL;
 	} else {
-		DBG_871X("%s NULL pointer\n",__FUNCTION__);
+		RTW_INFO("%s NULL pointer\n", __FUNCTION__);
 		ret =  _FAIL;
 	}
 	return ret;
 }
 
-int retriveAdaptorInfoFile(char *path, u8* efuse_data)
+int retriveAdaptorInfoFile(char *path, u8 *efuse_data)
 {
 	int ret = _SUCCESS;
 	mm_segment_t oldfs;
 	struct file *fp;
-	
-	if(path && efuse_data) {
+
+	if (path && efuse_data) {
 
 		ret = rtw_retrieve_from_file(path, efuse_data, EEPROM_MAX_SIZE);
-		
-		if(ret == EEPROM_MAX_SIZE)
+
+		if (ret == EEPROM_MAX_SIZE)
 			ret = _SUCCESS;
 		else
 			ret = _FAIL;
 
-		#if 0
-		if(isAdaptorInfoFileValid()) {	
+#if 0
+		if (isAdaptorInfoFileValid())
 			return 0;
-		} else {
+		else
 			return _FAIL;
-		}
-		#endif
-		
+#endif
+
 	} else {
-		DBG_871X("%s NULL pointer\n",__FUNCTION__);
+		RTW_INFO("%s NULL pointer\n", __FUNCTION__);
 		ret = _FAIL;
 	}
 	return ret;
 }
 #endif /* CONFIG_ADAPTOR_INFO_CACHING_FILE */
 
+u8 rtw_efuse_file_read(PADAPTER padapter, u8 *filepatch, u8 *buf, u32 len)
+{
+	char *ptmpbuf = NULL, *ptr;
+	u8 val8;
+	u32 count, i, j;
+	int err;
+	u32 bufsize = 4096;
+
+	ptmpbuf = rtw_zmalloc(bufsize);
+	if (ptmpbuf == NULL)
+		return _FALSE;
+
+	count = rtw_retrieve_from_file(filepatch, ptmpbuf, bufsize);
+	if (count <= 90) {
+		rtw_mfree(ptmpbuf, bufsize);
+		RTW_ERR("%s, filepatch %s, size=%d, FAIL!!\n", __FUNCTION__, filepatch, count);
+		return _FALSE;
+	}
+
+	i = 0;
+	j = 0;
+	ptr = ptmpbuf;
+	while ((j < len) && (i < count)) {
+		if (ptmpbuf[i] == '\0')
+			break;
+	
+		ptr = strpbrk(&ptmpbuf[i], " \t\n\r");
+		if (ptr) {
+			if (ptr == &ptmpbuf[i]) {
+				i++;
+				continue;
+			}
+
+			/* Add string terminating null */
+			*ptr = 0;
+		} else {
+			ptr = &ptmpbuf[count-1];
+		}
+
+		err = sscanf(&ptmpbuf[i], "%hhx", &val8);
+		if (err != 1) {
+			RTW_WARN("Something wrong to parse efuse file, string=%s\n", &ptmpbuf[i]);
+		} else {
+			buf[j] = val8;
+			RTW_DBG("i=%d, j=%d, 0x%02x\n", i, j, buf[j]);
+			j++;
+		}
+
+		i = ptr - ptmpbuf + 1;
+	}
+
+	rtw_mfree(ptmpbuf, bufsize);
+	RTW_INFO("%s, filepatch %s, size=%d, done\n", __FUNCTION__, filepatch, count);
+	return _TRUE;
+}
+
 #ifdef CONFIG_EFUSE_CONFIG_FILE
 u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size)
 {
@@ -1641,25 +3112,25 @@ u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size)
 	u8 *map = NULL;
 
 	if (rtw_is_file_readable_with_size(path, &file_size) != _TRUE) {
-		DBG_871X_LEVEL(_drv_always_, "%s %s is not readable\n", __func__, path);
+		RTW_PRINT("%s %s is not readable\n", __func__, path);
 		goto exit;
 	}
 
 	file_data = rtw_vmalloc(file_size);
 	if (!file_data) {
-		DBG_871X_LEVEL(_drv_err_, "%s rtw_vmalloc(%d) fail\n", __func__, file_size);
+		RTW_ERR("%s rtw_vmalloc(%d) fail\n", __func__, file_size);
 		goto exit;
 	}
 
 	read_size = rtw_retrieve_from_file(path, file_data, file_size);
 	if (read_size == 0) {
-		DBG_871X_LEVEL(_drv_err_, "%s read from %s fail\n", __func__, path);
+		RTW_ERR("%s read from %s fail\n", __func__, path);
 		goto exit;
 	}
 
 	map = rtw_vmalloc(map_size);
 	if (!map) {
-		DBG_871X_LEVEL(_drv_err_, "%s rtw_vmalloc(%d) fail\n", __func__, map_size);
+		RTW_ERR("%s rtw_vmalloc(%d) fail\n", __func__, map_size);
 		goto exit;
 	}
 	_rtw_memset(map, 0xff, map_size);
@@ -1681,7 +3152,7 @@ u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size)
 				continue;
 
 			if (IsHexDigit(c) == _FALSE) {
-				DBG_871X_LEVEL(_drv_err_, "%s invalid 8-bit hex format for offset:0x%03x\n", __func__, i);
+				RTW_ERR("%s invalid 8-bit hex format for offset:0x%03x\n", __func__, i);
 				goto exit;
 			}
 
@@ -1690,7 +3161,7 @@ u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size)
 			if (temp_i == 2) {
 				/* parse value */
 				if (sscanf(temp, "%hhx", &map[i]) != 1) {
-					DBG_871X_LEVEL(_drv_err_, "%s sscanf fail for offset:0x%03x\n", __func__, i);
+					RTW_ERR("%s sscanf fail for offset:0x%03x\n", __func__, i);
 					goto exit;
 				}
 				break;
@@ -1699,14 +3170,14 @@ u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size)
 
 		if (end == _TRUE) {
 			if (temp_i != 0) {
-				DBG_871X_LEVEL(_drv_err_, "%s incomplete 8-bit hex format for offset:0x%03x\n", __func__, i);
+				RTW_ERR("%s incomplete 8-bit hex format for offset:0x%03x\n", __func__, i);
 				goto exit;
 			}
 			break;
 		}
 	}
 
-	DBG_871X_LEVEL(_drv_always_, "efuse file:%s, 0x%03x byte content read\n", path, i);
+	RTW_PRINT("efuse file:%s, 0x%03x byte content read\n", path, i);
 
 	_rtw_memcpy(buf, map, map_size);
 
@@ -1732,13 +3203,13 @@ u32 rtw_read_macaddr_from_file(const char *path, u8 *buf)
 	u8 addr[ETH_ALEN];
 
 	if (rtw_is_file_readable(path) != _TRUE) {
-		DBG_871X_LEVEL(_drv_always_, "%s %s is not readable\n", __func__, path);
+		RTW_PRINT("%s %s is not readable\n", __func__, path);
 		goto exit;
 	}
 
 	read_size = rtw_retrieve_from_file(path, file_data, 17);
 	if (read_size != 17) {
-		DBG_871X_LEVEL(_drv_err_, "%s read from %s fail\n", __func__, path);
+		RTW_ERR("%s read from %s fail\n", __func__, path);
 		goto exit;
 	}
 
@@ -1746,28 +3217,28 @@ u32 rtw_read_macaddr_from_file(const char *path, u8 *buf)
 
 	for (i = 0 ; i < ETH_ALEN ; i++) {
 		if (IsHexDigit(file_data[i * 3]) == _FALSE || IsHexDigit(file_data[i * 3 + 1]) == _FALSE) {
-			DBG_871X_LEVEL(_drv_err_, "%s invalid 8-bit hex format for address offset:%u\n", __func__, i);
+			RTW_ERR("%s invalid 8-bit hex format for address offset:%u\n", __func__, i);
 			goto exit;
 		}
 
 		if (i < ETH_ALEN - 1 && file_data[i * 3 + 2] != ':') {
-			DBG_871X_LEVEL(_drv_err_, "%s invalid separator after address offset:%u\n", __func__, i);
+			RTW_ERR("%s invalid separator after address offset:%u\n", __func__, i);
 			goto exit;
 		}
 
 		temp[0] = file_data[i * 3];
 		temp[1] = file_data[i * 3 + 1];
 		if (sscanf(temp, "%hhx", &addr[i]) != 1) {
-			DBG_871X_LEVEL(_drv_err_, "%s sscanf fail for address offset:0x%03x\n", __func__, i);
+			RTW_ERR("%s sscanf fail for address offset:0x%03x\n", __func__, i);
 			goto exit;
 		}
 	}
 
 	_rtw_memcpy(buf, addr, ETH_ALEN);
 
-	DBG_871X_LEVEL(_drv_always_, "wifi_mac file: %s\n", path);
-#ifdef CONFIG_DEBUG
-	DBG_871X_LEVEL(_drv_always_, MAC_FMT"\n", MAC_ARG(buf));
+	RTW_PRINT("wifi_mac file: %s\n", path);
+#ifdef CONFIG_RTW_DEBUG
+	RTW_INFO(MAC_FMT"\n", MAC_ARG(buf));
 #endif
 
 	ret = _SUCCESS;
@@ -1778,4 +3249,3 @@ exit:
 #endif /* CONFIG_EFUSE_CONFIG_FILE */
 
 #endif /* PLATFORM_LINUX */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh.c
new file mode 100644
index 000000000000..8bc89734b82f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh.c
@@ -0,0 +1,3669 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_C_
+
+#ifdef CONFIG_RTW_MESH
+#include <drv_types.h>
+
+const char *_rtw_mesh_plink_str[] = {
+	"UNKNOWN",
+	"LISTEN",
+	"OPN_SNT",
+	"OPN_RCVD",
+	"CNF_RCVD",
+	"ESTAB",
+	"HOLDING",
+	"BLOCKED",
+};
+
+const char *_rtw_mesh_ps_str[] = {
+	"UNKNOWN",
+	"ACTIVE",
+	"LSLEEP",
+	"DSLEEP",
+};
+
+const char *_action_self_protected_str[] = {
+	"ACT_SELF_PROTECTED_RSVD",
+	"MESH_OPEN",
+	"MESH_CONF",
+	"MESH_CLOSE",
+	"MESH_GK_INFORM",
+	"MESH_GK_ACK",
+};
+
+inline u8 *rtw_set_ie_mesh_id(u8 *buf, u32 *buf_len, const char *mesh_id, u8 id_len)
+{
+	return rtw_set_ie(buf, WLAN_EID_MESH_ID, id_len, mesh_id, buf_len);
+}
+
+inline u8 *rtw_set_ie_mesh_config(u8 *buf, u32 *buf_len
+	, u8 path_sel_proto, u8 path_sel_metric, u8 congest_ctl_mode, u8 sync_method, u8 auth_proto
+	, u8 num_of_peerings, bool cto_mgate, bool cto_as
+	, bool accept_peerings, bool mcca_sup, bool mcca_en, bool forwarding
+	, bool mbca_en, bool tbtt_adj, bool ps_level)
+{
+
+	u8 conf[7] = {0};
+
+	SET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(conf, path_sel_proto);
+	SET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(conf, path_sel_metric);
+	SET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(conf, congest_ctl_mode);
+	SET_MESH_CONF_ELE_SYNC_METHOD_ID(conf, sync_method);
+	SET_MESH_CONF_ELE_AUTH_PROTO_ID(conf, auth_proto);
+
+	SET_MESH_CONF_ELE_CTO_MGATE(conf, cto_mgate);
+	SET_MESH_CONF_ELE_NUM_OF_PEERINGS(conf, num_of_peerings);
+	SET_MESH_CONF_ELE_CTO_AS(conf, cto_as);
+
+	SET_MESH_CONF_ELE_ACCEPT_PEERINGS(conf, accept_peerings);
+	SET_MESH_CONF_ELE_MCCA_SUP(conf, mcca_sup);
+	SET_MESH_CONF_ELE_MCCA_EN(conf, mcca_en);
+	SET_MESH_CONF_ELE_FORWARDING(conf, forwarding);
+	SET_MESH_CONF_ELE_MBCA_EN(conf, mbca_en);
+	SET_MESH_CONF_ELE_TBTT_ADJ(conf, tbtt_adj);
+	SET_MESH_CONF_ELE_PS_LEVEL(conf, ps_level);
+
+	return rtw_set_ie(buf, WLAN_EID_MESH_CONFIG, 7, conf, buf_len);
+}
+
+inline u8 *rtw_set_ie_mpm(u8 *buf, u32 *buf_len
+	, u8 proto_id, u16 llid, u16 *plid, u16 *reason, u8 *chosen_pmk)
+{
+	u8 data[24] = {0};
+	u8 *pos = data;
+
+	RTW_PUT_LE16(pos, proto_id);
+	pos += 2;
+
+	RTW_PUT_LE16(pos, llid);
+	pos += 2;
+
+	if (plid) {
+		RTW_PUT_LE16(pos, *plid);
+		pos += 2;
+	}
+
+	if (reason) {
+		RTW_PUT_LE16(pos, *reason);
+		pos += 2;
+	}
+
+	if (chosen_pmk) {
+		_rtw_memcpy(pos, chosen_pmk, 16);
+		pos += 16;
+	}
+
+	return rtw_set_ie(buf, WLAN_EID_MPM, pos - data, data, buf_len);
+}
+
+bool rtw_bss_is_forwarding(WLAN_BSSID_EX *bss)
+{
+	u8 *ie;
+	int ie_len;
+	bool ret = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7)
+		goto exit;
+
+	ret = GET_MESH_CONF_ELE_FORWARDING(ie + 2);
+
+exit:
+	return ret;
+}
+
+bool rtw_bss_is_cto_mgate(WLAN_BSSID_EX *bss)
+{
+	u8 *ie;
+	int ie_len;
+	bool ret = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7)
+		goto exit;
+
+	ret = GET_MESH_CONF_ELE_CTO_MGATE(ie + 2);
+
+exit:
+	return ret;
+}
+
+int rtw_bss_is_same_mbss(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b)
+{
+	int ret = 0;
+	u8 *a_mconf_ie, *b_mconf_ie;
+	sint a_mconf_ie_len, b_mconf_ie_len;
+
+	if (a->InfrastructureMode != Ndis802_11_mesh)
+		goto exit;
+	a_mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(a), WLAN_EID_MESH_CONFIG, &a_mconf_ie_len, BSS_EX_TLV_IES_LEN(a));
+	if (!a_mconf_ie || a_mconf_ie_len != 7)
+		goto exit;
+	if (b->InfrastructureMode != Ndis802_11_mesh)
+		goto exit;
+	b_mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(b), WLAN_EID_MESH_CONFIG, &b_mconf_ie_len, BSS_EX_TLV_IES_LEN(b));
+	if (!b_mconf_ie || b_mconf_ie_len != 7)
+		goto exit;
+
+	if (a->mesh_id.SsidLength != b->mesh_id.SsidLength
+		|| _rtw_memcmp(a->mesh_id.Ssid, b->mesh_id.Ssid, a->mesh_id.SsidLength) == _FALSE)
+		goto exit;
+
+	if (_rtw_memcmp(a_mconf_ie + 2, b_mconf_ie + 2, 5) == _FALSE)
+		goto exit;
+
+	ret = 1;
+
+exit:
+	return ret;
+}
+
+int rtw_bss_is_candidate_mesh_peer(WLAN_BSSID_EX *self, WLAN_BSSID_EX *target, u8 ch, u8 add_peer)
+{
+	int ret = 0;
+	u8 *mconf_ie;
+	sint mconf_ie_len;
+	int i, j;
+
+	if (!rtw_bss_is_same_mbss(self, target))
+		goto exit;
+
+	if (ch && self->Configuration.DSConfig != target->Configuration.DSConfig)
+		goto exit;
+
+	if (add_peer) {
+		/* Accept additional mesh peerings */
+		mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(target), WLAN_EID_MESH_CONFIG, &mconf_ie_len, BSS_EX_TLV_IES_LEN(target));
+		if (!mconf_ie || mconf_ie_len != 7)
+			goto exit;
+		if (GET_MESH_CONF_ELE_ACCEPT_PEERINGS(mconf_ie + 2) == 0)
+			goto exit;
+	}
+
+	/* BSSBasicRateSet */
+	for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
+		if (target->SupportedRates[i] == 0)
+			break;	
+		if (target->SupportedRates[i] & 0x80) {
+			u8 match = 0;
+
+			if (!ch) {
+				/* off-channel, check target with our hardcode capability */
+				if (target->Configuration.DSConfig > 14)
+					match = rtw_is_basic_rate_ofdm(target->SupportedRates[i]);
+				else
+					match = rtw_is_basic_rate_mix(target->SupportedRates[i]);
+			} else { 
+				for (j = 0; j < NDIS_802_11_LENGTH_RATES_EX; j++) {
+					if (self->SupportedRates[j] == 0)
+						break;
+					if (self->SupportedRates[j] == target->SupportedRates[i]) {
+						match = 1;
+						break;
+					}
+				}
+			}
+			if (!match)
+				goto exit;
+		}
+	}
+
+
+	/* BSSBasicMCSSet */
+
+	/* 802.1X connected to AS ? */
+
+	ret = 1;
+
+exit:
+	return ret;
+}
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_peer_blacklist_add(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_add(&plink_ctl->peer_blacklist, addr
+		, mcfg->peer_sel_policy.peer_blacklist_timeout_ms);
+}
+
+int rtw_mesh_peer_blacklist_del(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_del(&plink_ctl->peer_blacklist, addr);
+}
+
+int rtw_mesh_peer_blacklist_search(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_search(&plink_ctl->peer_blacklist, addr);
+}
+
+void rtw_mesh_peer_blacklist_flush(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	rtw_blacklist_flush(&plink_ctl->peer_blacklist);
+}
+
+void dump_mesh_peer_blacklist(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	dump_blacklist(sel, &plink_ctl->peer_blacklist, "blacklist");
+}
+
+void dump_mesh_peer_blacklist_settings(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+	RTW_PRINT_SEL(sel, "%-12s %-17s\n"
+		, "conf_timeout", "blacklist_timeout");
+	RTW_PRINT_SEL(sel, "%12u %17u\n"
+		, peer_sel_policy->peer_conf_timeout_ms
+		, peer_sel_policy->peer_blacklist_timeout_ms);
+}
+#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+u8 rtw_mesh_cto_mgate_required(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	return mcfg->peer_sel_policy.cto_mgate_require
+		&& !rtw_bss_is_cto_mgate(&(mlmeext->mlmext_info.network));
+}
+
+u8 rtw_mesh_cto_mgate_network_filter(_adapter *adapter, struct wlan_network *scanned)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	return !rtw_mesh_cto_mgate_required(adapter)
+			|| (rtw_bss_is_cto_mgate(&scanned->network)
+				&& !rtw_mesh_cto_mgate_blacklist_search(adapter, scanned->network.MacAddress));
+}
+
+int rtw_mesh_cto_mgate_blacklist_add(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_add(&plink_ctl->cto_mgate_blacklist, addr
+		, mcfg->peer_sel_policy.cto_mgate_blacklist_timeout_ms);
+}
+
+int rtw_mesh_cto_mgate_blacklist_del(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_del(&plink_ctl->cto_mgate_blacklist, addr);
+}
+
+int rtw_mesh_cto_mgate_blacklist_search(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_search(&plink_ctl->cto_mgate_blacklist, addr);
+}
+
+void rtw_mesh_cto_mgate_blacklist_flush(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	rtw_blacklist_flush(&plink_ctl->cto_mgate_blacklist);
+}
+
+void dump_mesh_cto_mgate_blacklist(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	dump_blacklist(sel, &plink_ctl->cto_mgate_blacklist, "blacklist");
+}
+
+void dump_mesh_cto_mgate_blacklist_settings(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+	RTW_PRINT_SEL(sel, "%-12s %-17s\n"
+		, "conf_timeout", "blacklist_timeout");
+	RTW_PRINT_SEL(sel, "%12u %17u\n"
+		, peer_sel_policy->cto_mgate_conf_timeout_ms
+		, peer_sel_policy->cto_mgate_blacklist_timeout_ms);
+}
+
+static void rtw_mesh_cto_mgate_blacklist_chk(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	_queue *blist = &plink_ctl->cto_mgate_blacklist;
+	_list *list, *head;
+	struct blacklist_ent *ent = NULL;
+	struct wlan_network *scanned = NULL;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+			continue;
+		}
+
+		scanned = rtw_find_network(&adapter->mlmepriv.scanned_queue, ent->addr);
+		if (!scanned)
+			continue;
+
+		if (rtw_bss_is_forwarding(&scanned->network)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+}
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+void rtw_chk_candidate_peer_notify(_adapter *adapter, struct wlan_network *scanned)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	if (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl))
+		goto exit;
+
+	if (plink_ctl->num >= RTW_MESH_MAX_PEER_CANDIDATES)
+		goto exit;
+
+	/* wpa_supplicant's auto peer will initiate peering when candidate peer is reported without max_peer_links consideration */
+	if (plink_ctl->num >= mcfg->max_peer_links)
+		goto exit;
+
+	if (rtw_get_passing_time_ms(scanned->last_scanned) >= mcfg->peer_sel_policy.scanr_exp_ms
+		|| (mcfg->rssi_threshold && mcfg->rssi_threshold > scanned->network.Rssi)
+		|| !rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
+		#if CONFIG_RTW_MACADDR_ACL
+		|| rtw_access_ctrl(adapter, scanned->network.MacAddress) == _FALSE
+		#endif
+		|| rtw_mesh_plink_get(adapter, scanned->network.MacAddress)
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		|| rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
+		#endif
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		|| !rtw_mesh_cto_mgate_network_filter(adapter, scanned)
+		#endif
+	)
+		goto exit;
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_notify_new_peer_candidate(adapter->rtw_wdev
+		, scanned->network.MacAddress
+		, BSS_EX_TLV_IES(&scanned->network)
+		, BSS_EX_TLV_IES_LEN(&scanned->network)
+		, GFP_ATOMIC
+	);
+#endif
+
+exit:
+	return;
+}
+
+void rtw_mesh_peer_status_chk(_adapter *adapter)
+{
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *plink;
+	_list *head, *list;
+	struct sta_info *sta = NULL;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	int stainfo_offset;
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	u8 cto_mgate, forwarding, mgate;
+#endif
+	u8 flush;
+	char flush_list[NUM_STA];
+	u8 flush_num = 0;
+	int i;
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	if (rtw_mesh_cto_mgate_required(adapter)) {
+		/* active scan on operating channel */
+		issue_probereq_ex(adapter, &adapter->mlmepriv.cur_network.network.mesh_id, NULL, 0, 0, 0, 0);
+	}
+#endif
+
+	enter_critical_bh(&(plink_ctl->lock));
+
+	/* check established peers */
+	enter_critical_bh(&stapriv->asoc_list_lock);
+
+	head = &stapriv->asoc_list;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
+		list = get_next(list);
+
+		if (!sta->plink || !sta->plink->scanned) {
+			rtw_warn_on(1);
+			continue;
+		}
+		plink = sta->plink;
+		flush = 0;
+
+		/* remove unsuitable peer */
+		if (!rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &plink->scanned->network, 1, 0)
+			#if CONFIG_RTW_MACADDR_ACL
+			|| rtw_access_ctrl(adapter, plink->addr) == _FALSE
+			#endif
+		) {
+			flush = 1;
+			goto flush_add;
+		}
+
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		cto_mgate = rtw_bss_is_cto_mgate(&(plink->scanned->network));
+		forwarding = rtw_bss_is_forwarding(&(plink->scanned->network));
+		mgate = rtw_mesh_gate_search(minfo->mesh_paths, sta->cmn.mac_addr);
+
+		/* CTO_MGATE required, remove peer without CTO_MGATE */
+		if (rtw_mesh_cto_mgate_required(adapter) && !cto_mgate) {
+			flush = 1;
+			goto flush_add;
+		}
+
+		/* cto_mgate_conf status update */
+		if (IS_CTO_MGATE_CONF_DISABLED(plink)) {
+			if (cto_mgate && !forwarding && !mgate)
+				SET_CTO_MGATE_CONF_END_TIME(plink, mcfg->peer_sel_policy.cto_mgate_conf_timeout_ms);
+			else
+				rtw_mesh_cto_mgate_blacklist_del(adapter, sta->cmn.mac_addr);
+		} else {
+			/* cto_mgate_conf ongoing */
+			if (cto_mgate && !forwarding && !mgate) {
+				if (IS_CTO_MGATE_CONF_TIMEOUT(plink)) {
+					rtw_mesh_cto_mgate_blacklist_add(adapter, sta->cmn.mac_addr);
+
+					/* CTO_MGATE required, remove peering can't achieve CTO_MGATE */
+					if (rtw_mesh_cto_mgate_required(adapter)) {
+						flush = 1;
+						goto flush_add;
+					}	
+				}
+			} else {
+				SET_CTO_MGATE_CONF_DISABLED(plink);
+				rtw_mesh_cto_mgate_blacklist_del(adapter, sta->cmn.mac_addr);
+			}
+		}
+		#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+flush_add:
+		if (flush) {
+			rtw_list_delete(&sta->asoc_list);
+			stapriv->asoc_list_cnt--;
+			STA_SET_MESH_PLINK(sta, NULL);
+
+			stainfo_offset = rtw_stainfo_offset(stapriv, sta);
+			if (stainfo_offset_valid(stainfo_offset))
+				flush_list[flush_num++] = stainfo_offset;
+			else
+				rtw_warn_on(1);
+		}
+	}
+
+	exit_critical_bh(&stapriv->asoc_list_lock);
+
+	/* check non-established peers */
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		plink = &plink_ctl->ent[i];
+		if (plink->valid != _TRUE || plink->plink_state == RTW_MESH_PLINK_ESTAB)
+			continue;
+
+		/* remove unsuitable peer */
+		if (!rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &plink->scanned->network, 1, 1)
+			#if CONFIG_RTW_MACADDR_ACL
+			|| rtw_access_ctrl(adapter, plink->addr) == _FALSE
+			#endif
+		) {
+			_rtw_mesh_expire_peer_ent(adapter, plink);
+			continue;
+		}
+
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		/* peer confirm check timeout, add to black list */
+		if (IS_PEER_CONF_TIMEOUT(plink)) {
+			rtw_mesh_peer_blacklist_add(adapter, plink->addr);
+			_rtw_mesh_expire_peer_ent(adapter, plink);
+		}
+		#endif
+	}
+
+	exit_critical_bh(&(plink_ctl->lock));
+
+	for (i = 0; i < flush_num; i++) {
+		u8 sta_addr[ETH_ALEN];
+
+		sta = rtw_get_stainfo_by_offset(stapriv, flush_list[i]);
+		_rtw_memcpy(sta_addr, sta->cmn.mac_addr, ETH_ALEN);
+
+		ap_free_sta(adapter, sta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _FALSE);
+		rtw_mesh_expire_peer(adapter, sta_addr);
+	}
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	/* loop cto_mgate_blacklist to remove ent according to scan_r */
+	rtw_mesh_cto_mgate_blacklist_chk(adapter);
+#endif
+
+	return;
+}
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+static u8 rtw_mesh_offch_cto_mgate_required(_adapter *adapter)
+{
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	_queue *queue = &(mlme->scanned_queue);
+	_list *head, *pos;
+	struct wlan_network *scanned = NULL;
+	u8 ret = 0;
+
+	if (!rtw_mesh_cto_mgate_required(adapter))
+		goto exit;
+
+	enter_critical_bh(&(mlme->scanned_queue.lock));
+
+	head = get_list_head(queue);
+	pos = get_next(head);
+	while (!rtw_end_of_queue_search(head, pos)) {
+		scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
+
+		if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
+			&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
+			#if CONFIG_RTW_MACADDR_ACL
+			&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
+			#endif
+			&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
+			&& rtw_bss_is_cto_mgate(&scanned->network)
+			#if CONFIG_RTW_MESH_PEER_BLACKLIST
+			&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
+			#endif
+			&& !rtw_mesh_cto_mgate_blacklist_search(adapter, scanned->network.MacAddress)
+		)
+			break;
+
+		pos = get_next(pos);
+	}
+
+	if (rtw_end_of_queue_search(head, pos))
+		ret = 1;
+
+	exit_critical_bh(&(mlme->scanned_queue.lock));
+
+exit:
+	return ret;
+#else
+	return 0;
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+}
+
+u8 rtw_mesh_offch_candidate_accepted(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	u8 ret;
+
+	ret = MLME_IS_MESH(adapter)
+		&& check_fwstate(&adapter->mlmepriv, WIFI_ASOC_STATE) == _TRUE
+		&& (!plink_ctl->num || rtw_mesh_offch_cto_mgate_required(adapter))
+		;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (ret) {
+		struct mi_state mstate_no_self;
+
+		rtw_mi_status_no_self(adapter, &mstate_no_self);
+		if (MSTATE_STA_LD_NUM(&mstate_no_self) || MSTATE_AP_LD_NUM(&mstate_no_self)
+			|| MSTATE_ADHOC_LD_NUM(&mstate_no_self) || MSTATE_MESH_LD_NUM(&mstate_no_self))
+			ret = 0;
+	}
+#endif
+
+	return ret;
+}
+
+/*
+ * this function is called under off channel candidate is required 
+ * the channel with maximum candidate count is selected
+*/
+u8 rtw_mesh_select_operating_ch(_adapter *adapter)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	_queue *queue = &(mlme->scanned_queue);
+	_list *head, *pos;
+	_irqL irqL;
+	struct wlan_network *scanned = NULL;
+	int i;
+	u8 max_cand_ch = 0;
+	u8 max_cand_cnt = 0;
+
+	for (i = 0; i < rfctl->max_chan_nums; i++)
+		rfctl->channel_set[i].mesh_candidate_cnt = 0;
+
+	_enter_critical_bh(&(mlme->scanned_queue.lock), &irqL);
+
+	head = get_list_head(queue);
+	pos = get_next(head);
+	while (!rtw_end_of_queue_search(head, pos)) {
+		scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
+		pos = get_next(pos);
+
+		if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
+			&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
+			#if CONFIG_RTW_MACADDR_ACL
+			&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
+			#endif
+			&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 0, 1)
+			#if CONFIG_RTW_MESH_PEER_BLACKLIST
+			&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
+			#endif
+			#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+			&& rtw_mesh_cto_mgate_network_filter(adapter, scanned)
+			#endif
+		) {
+			int ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, scanned->network.Configuration.DSConfig);
+
+			if (ch_set_idx >= 0
+				&& !CH_IS_NON_OCP(&rfctl->channel_set[ch_set_idx])
+			) {
+				rfctl->channel_set[ch_set_idx].mesh_candidate_cnt++;
+				if (max_cand_cnt < rfctl->channel_set[ch_set_idx].mesh_candidate_cnt) {
+					max_cand_cnt = rfctl->channel_set[ch_set_idx].mesh_candidate_cnt;
+					max_cand_ch = rfctl->channel_set[ch_set_idx].ChannelNum;
+				}
+			}
+		}
+	}
+
+	_exit_critical_bh(&(mlme->scanned_queue.lock), &irqL);
+
+	return max_cand_ch;
+}
+#endif /* CONFIG_RTW_MESH_OFFCH_CAND */
+
+void dump_mesh_peer_sel_policy(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+#define OFFCH_CAND_TITLE_FMT " %-17s"
+#define OFFCH_CAND_VALUE_FMT " %17u"
+#define OFFCH_CAND_TITLE_ARG , "offch_find_int_ms"
+#define OFFCH_CAND_VALUE_ARG , peer_sel_policy->offch_find_int_ms
+#else
+#define OFFCH_CAND_TITLE_FMT ""
+#define OFFCH_CAND_VALUE_FMT ""
+#define OFFCH_CAND_TITLE_ARG
+#define OFFCH_CAND_VALUE_ARG
+#endif
+
+	RTW_PRINT_SEL(sel,
+		"%-12s"
+		OFFCH_CAND_TITLE_FMT
+		"\n"
+		, "scanr_exp_ms"
+		OFFCH_CAND_TITLE_ARG
+	);
+	RTW_PRINT_SEL(sel,
+		"%12u"
+		OFFCH_CAND_VALUE_FMT
+		"\n"
+		, peer_sel_policy->scanr_exp_ms
+		OFFCH_CAND_VALUE_ARG
+	);
+}
+
+void dump_mesh_networks(void *sel, _adapter *adapter)
+{
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	_queue *queue = &(mlme->scanned_queue);
+	struct wlan_network	*network;
+	_list *list, *head;
+	u8 same_mbss;
+	u8 candidate;
+	struct mesh_plink_ent *plink;
+	u8 blocked;
+	u8 established;
+	s32 age_ms;
+	u8 *mesh_conf_ie;
+	sint mesh_conf_ie_len;
+	struct wlan_network **mesh_networks;
+	u8 mesh_network_cnt = 0;
+	int i;
+
+	mesh_networks = rtw_zvmalloc(mlme->max_bss_cnt * sizeof(struct wlan_network *));
+	if (!mesh_networks)
+		return;
+
+	enter_critical_bh(&queue->lock);
+	head = get_list_head(queue);
+	list = get_next(head);
+
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		network = LIST_CONTAINOR(list, struct wlan_network, list);
+		list = get_next(list);
+
+		if (network->network.InfrastructureMode != Ndis802_11_mesh)
+			continue;
+
+		mesh_conf_ie = rtw_get_ie(BSS_EX_TLV_IES(&network->network), WLAN_EID_MESH_CONFIG
+			, &mesh_conf_ie_len, BSS_EX_TLV_IES_LEN(&network->network));
+		if (!mesh_conf_ie || mesh_conf_ie_len != 7)
+			continue;
+
+		mesh_networks[mesh_network_cnt++] = network;
+	}
+
+	exit_critical_bh(&queue->lock);
+
+	RTW_PRINT_SEL(sel, "  %-17s %-3s %-4s %-5s %-32s %-3s %-3s %-3s\n"
+		, "bssid", "ch", "rssi", "age", "mesh_id", "nop", "fwd", "cto");
+
+
+	for (i = 0; i < mesh_network_cnt; i++) {
+		network = mesh_networks[i];
+
+		if (network->network.InfrastructureMode != Ndis802_11_mesh)
+			continue;
+
+		mesh_conf_ie = rtw_get_ie(BSS_EX_TLV_IES(&network->network), WLAN_EID_MESH_CONFIG
+			, &mesh_conf_ie_len, BSS_EX_TLV_IES_LEN(&network->network));
+		if (!mesh_conf_ie || mesh_conf_ie_len != 7)
+			continue;
+
+		age_ms = rtw_get_passing_time_ms(network->last_scanned);
+		same_mbss = 0;
+		candidate = 0;
+		plink = NULL;
+		blocked = 0;
+		established = 0;
+
+		if (MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)) {
+			plink = rtw_mesh_plink_get(adapter, network->network.MacAddress);
+			if (plink && plink->plink_state == RTW_MESH_PLINK_ESTAB)
+				established = 1;
+			else if (plink && plink->plink_state == RTW_MESH_PLINK_BLOCKED)
+				blocked = 1;
+			else if (plink)
+				;
+			else if (rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &network->network, 0, 1))
+				candidate = 1;
+			else if (rtw_bss_is_same_mbss(&mlme->cur_network.network, &network->network))
+				same_mbss = 1;
+		}
+
+		RTW_PRINT_SEL(sel, "%c "MAC_FMT" %3d %4ld %5d %-32s %c%2u %3u %c%c \n"
+			, established ? 'E' : (blocked ? 'B' : (plink ? 'N' : (candidate ? 'C' : (same_mbss ? 'S' : ' '))))
+			, MAC_ARG(network->network.MacAddress)
+			, network->network.Configuration.DSConfig
+			, network->network.Rssi
+			, age_ms < 99999 ? age_ms : 99999
+			, network->network.mesh_id.Ssid
+			, GET_MESH_CONF_ELE_ACCEPT_PEERINGS(mesh_conf_ie + 2) ? '+' : ' '
+			, GET_MESH_CONF_ELE_NUM_OF_PEERINGS(mesh_conf_ie + 2)
+			, GET_MESH_CONF_ELE_FORWARDING(mesh_conf_ie + 2)
+			, GET_MESH_CONF_ELE_CTO_MGATE(mesh_conf_ie + 2) ? 'G' : ' '
+			, GET_MESH_CONF_ELE_CTO_AS(mesh_conf_ie + 2) ? 'A' : ' '
+		);
+	}
+
+	rtw_vmfree(mesh_networks, mlme->max_bss_cnt * sizeof(struct wlan_network *));
+}
+
+int rtw_sae_check_frames(_adapter *adapter, const u8 *buf, u32 len, u8 tx)
+{
+	const u8 *frame_body = buf + sizeof(struct rtw_ieee80211_hdr_3addr);
+	u16 alg;
+	u16 seq;
+	u16 status;
+	int ret = 0;
+
+	alg = RTW_GET_LE16(frame_body);
+	if (alg != 3)
+		goto exit;
+
+	seq = RTW_GET_LE16(frame_body + 2);
+	status = RTW_GET_LE16(frame_body + 4);
+
+	RTW_INFO("RTW_%s:AUTH alg:0x%04x, seq:0x%04x, status:0x%04x\n"
+		, (tx == _TRUE) ? "Tx" : "Rx", alg, seq, status);
+
+	ret = 1;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	if (tx && seq == 1)
+		rtw_mesh_plink_set_peer_conf_timeout(adapter, GetAddr1Ptr(buf));
+#endif
+
+exit:
+	return ret;
+}
+
+#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+#ifdef CONFIG_RTW_MESH_AEK
+static int rtw_mpm_ampe_dec(_adapter *adapter, struct mesh_plink_ent *plink
+	, u8 *fhead, size_t flen, u8* fbody, u8 *mic_ie, u8 *ampe_buf)
+{	
+	int ret = _FAIL, verify_ret;
+	const u8 *aad[] = {adapter_mac_addr(adapter), plink->addr, fbody};
+	const size_t aad_len[] = {ETH_ALEN, ETH_ALEN, mic_ie - fbody};
+	u8 *iv_crypt;
+	size_t iv_crypt_len = flen - (mic_ie + 2 - fhead);
+
+	iv_crypt = rtw_malloc(iv_crypt_len);
+	if (!iv_crypt)
+		goto exit;
+
+	_rtw_memcpy(iv_crypt, mic_ie + 2, iv_crypt_len);
+
+	verify_ret = aes_siv_decrypt(plink->aek, iv_crypt, iv_crypt_len
+		, 3, aad, aad_len, ampe_buf);
+
+	rtw_mfree(iv_crypt, iv_crypt_len);
+
+	if (verify_ret) {
+		RTW_WARN("verify error, aek_valid=%u\n", plink->aek_valid);
+		goto exit;
+	} else if (*ampe_buf != WLAN_EID_AMPE) {
+		RTW_WARN("plaintext is not AMPE IE\n");
+		goto exit;
+	} else if (AES_BLOCK_SIZE + 2 + *(ampe_buf + 1) > iv_crypt_len) {
+		RTW_WARN("plaintext AMPE IE length is not valid\n");
+		goto exit;
+	}
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+static int rtw_mpm_ampe_enc(_adapter *adapter, struct mesh_plink_ent *plink
+	, u8* fbody, u8 *mic_ie, u8 *ampe_buf, bool inverse)
+{
+	int ret = _FAIL, protect_ret;
+	const u8 *aad[3];
+	const size_t aad_len[3] = {ETH_ALEN, ETH_ALEN, mic_ie - fbody};
+	u8 *ampe_ie;
+	size_t ampe_ie_len = *(ampe_buf + 1) + 2; /* including id & len */
+
+	if (inverse) {
+		aad[0] = plink->addr;
+		aad[1] = adapter_mac_addr(adapter);
+	} else {
+		aad[0] = adapter_mac_addr(adapter);
+		aad[1] = plink->addr;
+	}
+	aad[2] = fbody;
+
+	ampe_ie = rtw_malloc(ampe_ie_len);
+	if (!ampe_ie)
+		goto exit;
+
+	_rtw_memcpy(ampe_ie, ampe_buf, ampe_ie_len);
+
+	protect_ret = aes_siv_encrypt(plink->aek, ampe_ie, ampe_ie_len
+		, 3, aad, aad_len, mic_ie + 2);
+
+	rtw_mfree(ampe_ie, ampe_ie_len);
+
+	if (protect_ret) {
+		RTW_WARN("protect error, aek_valid=%u\n", plink->aek_valid);
+		goto exit;
+	}
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_RTW_MESH_AEK */
+
+static int rtw_mpm_tx_ies_sync_bss(_adapter *adapter, struct mesh_plink_ent *plink
+	, u8 *fhead, size_t flen, u8* fbody, u8 tlv_ies_offset, u8 *mpm_ie, u8 *mic_ie
+	, u8 **nbuf, size_t *nlen)
+{
+	int ret = _FAIL;
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
+	WLAN_BSSID_EX *network = &(mlmeinfo->network);
+	uint left;
+	u8 *pos;
+
+	uint mpm_ielen = *(mpm_ie + 1);
+	u8 *fpos;
+	u8 *new_buf = NULL;
+	size_t new_len = 0;
+
+	u8 *new_fhead;
+	size_t new_flen;
+	u8 *new_fbody;
+	u8 *new_mic_ie;
+
+#ifdef CONFIG_RTW_MESH_AEK
+	u8 *ampe_buf = NULL;
+	size_t ampe_buf_len = 0;
+
+	/* decode */
+	if (mic_ie) {
+		ampe_buf_len = flen - (mic_ie + 2 + AES_BLOCK_SIZE - fhead);
+		ampe_buf = rtw_malloc(ampe_buf_len);
+		if (!ampe_buf)
+			goto exit;
+
+		if (rtw_mpm_ampe_dec(adapter, plink, fhead, flen, fbody, mic_ie, ampe_buf) != _SUCCESS)
+			goto exit;
+
+		if (*(ampe_buf + 1) >= 68) {
+			_rtw_memcpy(plink->sel_pcs, ampe_buf + 2, 4);
+			_rtw_memcpy(plink->l_nonce, ampe_buf + 6, 32);
+			_rtw_memcpy(plink->p_nonce, ampe_buf + 38, 32);
+		}
+	}
+#endif
+
+	/* count for new frame length  */
+	new_len = sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset;
+	left = BSS_EX_TLV_IES_LEN(network);
+	pos = BSS_EX_TLV_IES(network);
+	while (left >= 2) {
+		u8 id, elen;
+	
+		id = *pos++;
+		elen = *pos++;
+		left -= 2;
+
+		if (elen > left)
+			break;
+
+		switch (id) {
+		case WLAN_EID_SSID:
+		case WLAN_EID_DS_PARAMS:
+		case WLAN_EID_TIM:
+			break;
+		default:
+			new_len += 2 + elen;
+		}
+
+		left -= elen;
+		pos += elen;
+	}
+	new_len += mpm_ielen + 2;
+	if (mic_ie)
+		new_len += AES_BLOCK_SIZE + 2 + ampe_buf_len;
+
+	/* alloc new frame */
+	new_buf = rtw_malloc(new_len);
+	if (!new_buf) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	/* build new frame  */
+	_rtw_memcpy(new_buf, fhead, sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset);
+	new_fhead = new_buf;
+	new_flen = new_len;
+	new_fbody = new_fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	fpos = new_fbody + tlv_ies_offset;
+	left = BSS_EX_TLV_IES_LEN(network);
+	pos = BSS_EX_TLV_IES(network);
+	while (left >= 2) {
+		u8 id, elen;
+	
+		id = *pos++;
+		elen = *pos++;
+		left -= 2;
+
+		if (elen > left)
+			break;
+
+		switch (id) {
+		case WLAN_EID_SSID:
+		case WLAN_EID_DS_PARAMS:
+		case WLAN_EID_TIM:
+			break;
+		default:
+			fpos = rtw_set_ie(fpos, id, elen, pos, NULL);
+			if (id == WLAN_EID_MESH_CONFIG)
+				fpos = rtw_set_ie(fpos, WLAN_EID_MPM, mpm_ielen, mpm_ie + 2, NULL);
+		}
+
+		left -= elen;
+		pos += elen;
+	}
+	if (mic_ie) {
+		new_mic_ie = fpos;
+		*fpos++ = WLAN_EID_MIC;
+		*fpos++ = AES_BLOCK_SIZE;
+	}
+
+#ifdef CONFIG_RTW_MESH_AEK
+	/* encode */
+	if (mic_ie) {
+		int enc_ret = rtw_mpm_ampe_enc(adapter, plink, new_fbody, new_mic_ie, ampe_buf, 0);
+		if (enc_ret != _SUCCESS)
+			goto exit;
+	}
+#endif
+
+	*nlen = new_len;
+	*nbuf = new_buf;
+
+	ret = _SUCCESS;
+
+exit:
+	if (ret != _SUCCESS && new_buf)
+		rtw_mfree(new_buf, new_len);
+
+#ifdef CONFIG_RTW_MESH_AEK
+	if (ampe_buf)
+		rtw_mfree(ampe_buf, ampe_buf_len);
+#endif
+
+	return ret;
+}
+#endif /* CONFIG_RTW_MPM_TX_IES_SYNC_BSS */
+
+struct mpm_frame_info {
+	u8 *aid;
+	u16 aid_v;
+	u8 *pid;
+	u16 pid_v;
+	u8 *llid;
+	u16 llid_v;
+	u8 *plid;
+	u16 plid_v;
+	u8 *reason;
+	u16 reason_v;
+	u8 *chosen_pmk;
+};
+
+/*
+* pid:0x0000 llid:0x0000 chosen_pmk:0x00000000000000000000000000000000
+* aid:0x0000 pid:0x0000 llid:0x0000 plid:0x0000 chosen_pmk:0x00000000000000000000000000000000
+* pid:0x0000 llid:0x0000 plid:0x0000 reason:0x0000 chosen_pmk:0x00000000000000000000000000000000
+*/
+#define MPM_LOG_BUF_LEN 96 /* this length is limited for legal combination */
+static void rtw_mpm_info_msg(struct mpm_frame_info *mpm_info, u8 *mpm_log_buf)
+{
+	int cnt = 0;
+
+	if (mpm_info->aid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "aid:0x%04x ", mpm_info->aid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->pid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "pid:0x%04x ", mpm_info->pid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->llid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "llid:0x%04x ", mpm_info->llid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->plid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "plid:0x%04x ", mpm_info->plid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->reason) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "reason:0x%04x ", mpm_info->reason_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->chosen_pmk) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "chosen_pmk:0x"KEY_FMT, KEY_ARG(mpm_info->chosen_pmk));
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+
+exit:
+	return;
+}
+
+static int rtw_mpm_check_frames(_adapter *adapter, u8 action, const u8 **buf, size_t *len, u8 tx)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *plink = NULL;
+	u8 *nbuf = NULL;
+	size_t nlen = 0;
+	u8 *fhead = (u8 *)*buf;
+	size_t flen = *len;
+	u8 *peer_addr = tx ? GetAddr1Ptr(fhead) : get_addr2_ptr(fhead);
+	u8 *frame_body = fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
+	struct mpm_frame_info mpm_info;
+	u8 tlv_ies_offset;
+	u8 *mpm_ie = NULL;
+	uint mpm_ielen = 0;
+	u8 *mic_ie = NULL;
+	uint mic_ielen = 0;
+	int ret = 0;
+	u8 mpm_log_buf[MPM_LOG_BUF_LEN] = {0};
+
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_OPEN)
+		tlv_ies_offset = 4;
+	else if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF)
+		tlv_ies_offset = 6;
+	else if (action == RTW_ACT_SELF_PROTECTED_MESH_CLOSE)
+		tlv_ies_offset = 2;
+	else {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	plink = rtw_mesh_plink_get(adapter, peer_addr);
+	if (!plink && (tx == _TRUE || action == RTW_ACT_SELF_PROTECTED_MESH_CONF)) {
+		/* warning message if no plink when: 1.TX all MPM or 2.RX CONF */
+		RTW_WARN("RTW_%s:%s without plink of "MAC_FMT"\n"
+			, (tx == _TRUE) ? "Tx" : "Rx", action_self_protected_str(action), MAC_ARG(peer_addr));
+		goto exit;
+	}
+
+	_rtw_memset(&mpm_info, 0, sizeof(struct mpm_frame_info));
+
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF) {
+		mpm_info.aid = (u8 *)frame_body + 4;
+		mpm_info.aid_v = RTW_GET_LE16(mpm_info.aid);
+	}
+
+	mpm_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+		, WLAN_EID_MPM, &mpm_ielen
+		, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+	if (!mpm_ie || mpm_ielen < 2 + 2)
+		goto exit;
+
+	mpm_info.pid = mpm_ie + 2;
+	mpm_info.pid_v = RTW_GET_LE16(mpm_info.pid);
+	mpm_info.llid = mpm_info.pid + 2;
+	mpm_info.llid_v = RTW_GET_LE16(mpm_info.llid);
+
+	switch (action) {
+	case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
+		/* pid:2, llid:2, (chosen_pmk:16) */
+		if (mpm_info.pid_v == 0 && mpm_ielen == 4)
+			;
+		else if (mpm_info.pid_v == 1 && mpm_ielen == 20)
+			mpm_info.chosen_pmk = mpm_info.llid + 2;
+		else
+			goto exit;
+		break;
+	case RTW_ACT_SELF_PROTECTED_MESH_CONF:
+		/* pid:2, llid:2, plid:2, (chosen_pmk:16) */
+		mpm_info.plid = mpm_info.llid + 2;
+		mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
+		if (mpm_info.pid_v == 0 && mpm_ielen == 6)
+			;
+		else if (mpm_info.pid_v == 1 && mpm_ielen == 22)
+			mpm_info.chosen_pmk = mpm_info.plid + 2;
+		else
+			goto exit;
+		break;
+	case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
+		/* pid:2, llid:2, (plid:2), reason:2, (chosen_pmk:16) */
+		if (mpm_info.pid_v == 0 && mpm_ielen == 6) {
+			/* MPM, without plid */
+			mpm_info.reason = mpm_info.llid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+		} else if (mpm_info.pid_v == 0 && mpm_ielen == 8) {
+			/* MPM, with plid */
+			mpm_info.plid = mpm_info.llid + 2;
+			mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
+			mpm_info.reason = mpm_info.plid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+		} else if (mpm_info.pid_v == 1 && mpm_ielen == 22) {
+			/* AMPE, without plid */
+			mpm_info.reason = mpm_info.llid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+			mpm_info.chosen_pmk = mpm_info.reason + 2;
+		} else if (mpm_info.pid_v == 1 && mpm_ielen == 24) {
+			/* AMPE, with plid */
+			mpm_info.plid = mpm_info.llid + 2;
+			mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
+			mpm_info.reason = mpm_info.plid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+			mpm_info.chosen_pmk = mpm_info.reason + 2;
+		} else
+			goto exit;
+		break;
+	};
+
+	if (mpm_info.pid_v == 1) {
+		mic_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+			, WLAN_EID_MIC, &mic_ielen
+			, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		if (!mic_ie || mic_ielen != AES_BLOCK_SIZE)
+			goto exit;
+	}
+
+#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+	if ((action == RTW_ACT_SELF_PROTECTED_MESH_OPEN || action == RTW_ACT_SELF_PROTECTED_MESH_CONF)
+		&& tx == _TRUE
+	) {
+#define DBG_RTW_MPM_TX_IES_SYNC_BSS 0
+
+		if (mpm_info.pid_v == 1 && (!plink || !MESH_PLINK_AEK_VALID(plink))) {
+			RTW_WARN("AEK not ready, IEs can't sync with BSS\n");
+			goto bypass_sync_bss;
+		}
+
+		if (DBG_RTW_MPM_TX_IES_SYNC_BSS) {
+			RTW_INFO(FUNC_ADPT_FMT" before:\n", FUNC_ADPT_ARG(adapter));
+			dump_ies(RTW_DBGDUMP
+				, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+				, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		}
+
+		rtw_mpm_tx_ies_sync_bss(adapter, plink
+			, fhead, flen, frame_body, tlv_ies_offset, mpm_ie, mic_ie
+			, &nbuf, &nlen);
+		if (!nbuf)
+			goto exit;
+
+		/* update pointer & len for new frame */
+		fhead = nbuf;
+		flen = nlen;
+		frame_body = fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
+		if (mpm_info.pid_v == 1) {
+			mic_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+				, WLAN_EID_MIC, &mic_ielen
+				, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		}
+
+		if (DBG_RTW_MPM_TX_IES_SYNC_BSS) {
+			RTW_INFO(FUNC_ADPT_FMT" after:\n", FUNC_ADPT_ARG(adapter));
+			dump_ies(RTW_DBGDUMP
+				, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+				, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		}
+	}
+bypass_sync_bss:
+#endif /* CONFIG_RTW_MPM_TX_IES_SYNC_BSS */
+
+	if (!plink)
+		goto mpm_log;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_OPEN) {
+		if (tx)
+			rtw_mesh_plink_set_peer_conf_timeout(adapter, peer_addr);
+
+	} else
+#endif
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF) {
+		_irqL irqL;
+		u8 *ies = NULL;
+		u16 ies_len = 0;
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL);
+
+		plink = _rtw_mesh_plink_get(adapter, peer_addr);
+		if (!plink)
+			goto release_plink_ctl;
+
+		if (tx == _FALSE) {
+			ies = plink->rx_conf_ies;
+			ies_len = plink->rx_conf_ies_len;
+			plink->rx_conf_ies = NULL;
+			plink->rx_conf_ies_len = 0;
+
+			plink->llid = mpm_info.plid_v;
+			plink->plid = mpm_info.llid_v;
+			plink->peer_aid = mpm_info.aid_v;
+			if (mpm_info.pid_v == 1)
+				_rtw_memcpy(plink->chosen_pmk, mpm_info.chosen_pmk, 16);
+		}
+		#ifdef CONFIG_RTW_MESH_DRIVER_AID
+		else {
+			ies = plink->tx_conf_ies;
+			ies_len = plink->tx_conf_ies_len;
+			plink->tx_conf_ies = NULL;
+			plink->tx_conf_ies_len = 0;
+		}
+		#endif
+
+		if (ies && ies_len)
+			rtw_mfree(ies, ies_len);
+
+		#ifndef CONFIG_RTW_MESH_DRIVER_AID
+		if (tx == _TRUE)
+			goto release_plink_ctl; /* no need to copy tx conf ies */
+		#endif
+
+		/* copy mesh confirm IEs */
+		if (mpm_info.pid_v == 1) /* not include MIC & encrypted AMPE */
+			ies_len = (mic_ie - fhead) - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
+		else
+			ies_len = flen - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
+
+		ies = rtw_zmalloc(ies_len);
+		if (ies) {
+			_rtw_memcpy(ies, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + 2, ies_len);
+			if (tx == _FALSE) {
+				plink->rx_conf_ies = ies;
+				plink->rx_conf_ies_len = ies_len;
+			}
+			#ifdef CONFIG_RTW_MESH_DRIVER_AID	
+			else {
+				plink->tx_conf_ies = ies;
+				plink->tx_conf_ies_len = ies_len;
+			}
+			#endif
+		}
+
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL);
+	}
+
+mpm_log:
+	rtw_mpm_info_msg(&mpm_info, mpm_log_buf);
+	RTW_INFO("RTW_%s:%s %s\n"
+		, (tx == _TRUE) ? "Tx" : "Rx"
+		, action_self_protected_str(action)
+		, mpm_log_buf
+	);
+
+	ret = 1;
+
+exit:
+	if (nbuf) {
+		if (ret == 1) {
+			*buf = nbuf;
+			*len = nlen;
+		} else
+			rtw_mfree(nbuf, nlen);
+	}
+
+	return ret;
+}
+
+static int rtw_mesh_check_frames(_adapter *adapter, const u8 **buf, size_t *len, u8 tx)
+{
+	int is_mesh_frame = -1;
+	const u8 *frame_body;
+	u8 category, action;
+
+	frame_body = *buf + sizeof(struct rtw_ieee80211_hdr_3addr);
+	category = frame_body[0];
+
+	if (category == RTW_WLAN_CATEGORY_SELF_PROTECTED) {
+		action = frame_body[1];
+		switch (action) {
+		case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
+		case RTW_ACT_SELF_PROTECTED_MESH_CONF:
+		case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
+			rtw_mpm_check_frames(adapter, action, buf, len, tx);
+			is_mesh_frame = action;
+			break;
+		case RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM:
+		case RTW_ACT_SELF_PROTECTED_MESH_GK_ACK:
+			RTW_INFO("RTW_%s:%s\n", (tx == _TRUE) ? "Tx" : "Rx", action_self_protected_str(action));
+			is_mesh_frame = action;
+			break;
+		default:
+			break;
+		};
+	}
+
+exit:
+	return is_mesh_frame;
+}
+
+int rtw_mesh_check_frames_tx(_adapter *adapter, const u8 **buf, size_t *len)
+{
+	return rtw_mesh_check_frames(adapter, buf, len, _TRUE);
+}
+
+int rtw_mesh_check_frames_rx(_adapter *adapter, const u8 *buf, size_t len)
+{
+	return rtw_mesh_check_frames(adapter, &buf, &len, _FALSE);
+}
+
+unsigned int on_action_self_protected(_adapter *adapter, union recv_frame *rframe)
+{
+	unsigned int ret = _FAIL;
+	struct sta_info *sta = NULL;
+	u8 *pframe = rframe->u.hdr.rx_data;
+	uint frame_len = rframe->u.hdr.len;
+	u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+	u8 category;
+	u8 action;
+
+	/* check RA matches or not */
+	if (!_rtw_memcmp(adapter_mac_addr(adapter), GetAddr1Ptr(pframe), ETH_ALEN))
+		goto exit;
+
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_SELF_PROTECTED)
+		goto exit;
+
+	action = frame_body[1];
+	switch (action) {
+	case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
+	case RTW_ACT_SELF_PROTECTED_MESH_CONF:
+	case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
+	case RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM:
+	case RTW_ACT_SELF_PROTECTED_MESH_GK_ACK:
+		if (!(MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)))
+			goto exit;
+#ifdef CONFIG_IOCTL_CFG80211
+		#if CONFIG_RTW_MACADDR_ACL
+		if (rtw_access_ctrl(adapter, get_addr2_ptr(pframe)) == _FALSE)
+			goto exit;
+		#endif
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		if (rtw_mesh_cto_mgate_required(adapter)
+			/* only peer being added (checked by notify conditions) is allowed */
+			&& !rtw_mesh_plink_get(adapter, get_addr2_ptr(pframe)))
+			goto exit;
+		#endif
+		rtw_cfg80211_rx_action(adapter, rframe, NULL);
+		ret = _SUCCESS;
+#endif /* CONFIG_IOCTL_CFG80211 */
+		break;
+	default:
+		break;
+	}
+
+exit:
+	return ret;
+}
+
+const u8 ae_to_mesh_ctrl_len[] = {
+	6,
+	12, /* MESH_FLAGS_AE_A4 */
+	18, /* MESH_FLAGS_AE_A5_A6 */
+	0,
+};
+
+unsigned int on_action_mesh(_adapter *adapter, union recv_frame *rframe)
+{
+	unsigned int ret = _FAIL;
+	struct sta_info *sta = NULL;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u8 *pframe = rframe->u.hdr.rx_data;
+	uint frame_len = rframe->u.hdr.len;
+	u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+	u8 category;
+	u8 action;
+
+	if (!MLME_IS_MESH(adapter))
+		goto exit;
+
+	/* check stainfo exist? */
+
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_MESH)
+		goto exit;
+
+	action = frame_body[1];
+	switch (action) {
+	case RTW_ACT_MESH_HWMP_PATH_SELECTION:
+		rtw_mesh_rx_path_sel_frame(adapter, rframe);
+		ret = _SUCCESS;
+		break;
+	default:
+		break;
+	}
+
+exit:
+	return ret;
+}
+
+bool rtw_mesh_update_bss_peering_status(_adapter *adapter, WLAN_BSSID_EX *bss)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	u8 num_of_peerings = stapriv->asoc_list_cnt;
+	bool accept_peerings = stapriv->asoc_list_cnt < mcfg->max_peer_links;
+	u8 *ie;
+	int ie_len;
+	bool updated = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len, BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (GET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2) != num_of_peerings) {
+		SET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2, num_of_peerings);
+		updated = 1;
+	}
+
+	if (GET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2) != accept_peerings) {
+		SET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2, accept_peerings);
+		updated = 1;
+	}
+
+exit:
+	return updated;
+}
+
+bool rtw_mesh_update_bss_formation_info(_adapter *adapter, WLAN_BSSID_EX *bss)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u8 cto_mgate = (minfo->num_gates || mcfg->dot11MeshGateAnnouncementProtocol);
+	u8 cto_as = 0;
+	u8 *ie;
+	int ie_len;
+	bool updated = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (GET_MESH_CONF_ELE_CTO_MGATE(ie + 2) != cto_mgate) {
+		SET_MESH_CONF_ELE_CTO_MGATE(ie + 2, cto_mgate);
+		updated = 1;
+	}
+
+	if (GET_MESH_CONF_ELE_CTO_AS(ie + 2) != cto_as) {
+		SET_MESH_CONF_ELE_CTO_AS(ie + 2, cto_as);
+		updated = 1;
+	}
+
+exit:
+	return updated;
+}
+
+bool rtw_mesh_update_bss_forwarding_state(_adapter *adapter, WLAN_BSSID_EX *bss)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	u8 forward = mcfg->dot11MeshForwarding;
+	u8 *ie;
+	int ie_len;
+	bool updated = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (GET_MESH_CONF_ELE_FORWARDING(ie + 2) != forward) {
+		SET_MESH_CONF_ELE_FORWARDING(ie + 2, forward);
+		updated = 1;
+	}
+
+exit:
+	return updated;
+}
+
+struct mesh_plink_ent *_rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	int i;
+
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			ent = &plink_ctl->ent[i];
+			break;
+		}
+	}
+
+exit:
+	return ent;
+}
+
+struct mesh_plink_ent *rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent;
+}
+
+struct mesh_plink_ent *rtw_mesh_plink_get_no_estab_by_idx(_adapter *adapter, u8 idx)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	int i, j = 0;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& plink_ctl->ent[i].plink_state != RTW_MESH_PLINK_ESTAB
+		) {
+			if (j == idx) {
+				ent = &plink_ctl->ent[i];
+				break;
+			}
+			j++;
+		}
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+	return ent;
+}
+
+int _rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	u8 exist = _FALSE;
+	int i;
+
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			ent = &plink_ctl->ent[i];
+			exist = _TRUE;
+			break;
+		}
+
+		if (ent == NULL && plink_ctl->ent[i].valid == _FALSE)
+			ent = &plink_ctl->ent[i];
+	}
+
+	if (exist == _FALSE && ent) {
+		_rtw_memcpy(ent->addr, hwaddr, ETH_ALEN);
+		ent->valid = _TRUE;
+		#ifdef CONFIG_RTW_MESH_AEK
+		ent->aek_valid = 0;
+		#endif
+		ent->llid = 0;
+		ent->plid = 0;
+		_rtw_memset(ent->chosen_pmk, 0, 16);
+		#ifdef CONFIG_RTW_MESH_AEK
+		_rtw_memset(ent->sel_pcs, 0, 4);
+		_rtw_memset(ent->l_nonce, 0, 32);
+		_rtw_memset(ent->p_nonce, 0, 32);
+		#endif
+		ent->plink_state = RTW_MESH_PLINK_LISTEN;
+		#ifndef CONFIG_RTW_MESH_DRIVER_AID
+		ent->aid = 0;
+		#endif
+		ent->peer_aid = 0;
+		SET_PEER_CONF_DISABLED(ent);
+		SET_CTO_MGATE_CONF_DISABLED(ent);
+		plink_ctl->num++;
+	}
+
+exit:
+	return exist == _TRUE ? RTW_ALREADY : (ent ? _SUCCESS : _FAIL);
+}
+
+int rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	_irqL irqL;
+	int ret;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ret = _rtw_mesh_plink_add(adapter, hwaddr);
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+	return ret;
+}
+
+int rtw_mesh_plink_set_state(_adapter *adapter, const u8 *hwaddr, u8 state)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	if (ent)
+		ent->plink_state = state;
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent ? _SUCCESS : _FAIL;
+}
+
+#ifdef CONFIG_RTW_MESH_AEK
+int rtw_mesh_plink_set_aek(_adapter *adapter, const u8 *hwaddr, const u8 *aek)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	if (ent) {
+		_rtw_memcpy(ent->aek, aek, 32);
+		ent->aek_valid = 1;
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent ? _SUCCESS : _FAIL;
+}
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_plink_set_peer_conf_timeout(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	if (ent) {
+		if (IS_PEER_CONF_DISABLED(ent))
+			SET_PEER_CONF_END_TIME(ent, mcfg->peer_sel_policy.peer_conf_timeout_ms);
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent ? _SUCCESS : _FAIL;
+}
+#endif
+
+void _rtw_mesh_plink_del_ent(_adapter *adapter, struct mesh_plink_ent *ent)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	ent->valid = _FALSE;
+	#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	if (ent->tx_conf_ies && ent->tx_conf_ies_len)
+		rtw_mfree(ent->tx_conf_ies, ent->tx_conf_ies_len);
+	ent->tx_conf_ies = NULL;
+	ent->tx_conf_ies_len = 0;
+	#endif
+	if (ent->rx_conf_ies && ent->rx_conf_ies_len)
+		rtw_mfree(ent->rx_conf_ies, ent->rx_conf_ies_len);
+	ent->rx_conf_ies = NULL;
+	ent->rx_conf_ies_len = 0;
+	if (ent->scanned)
+		ent->scanned = NULL;
+	plink_ctl->num--;
+}
+
+int rtw_mesh_plink_del(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	u8 exist = _FALSE;
+	int i;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			ent = &plink_ctl->ent[i];
+			exist = _TRUE;
+			break;
+		}
+	}
+
+	if (exist == _TRUE)
+		_rtw_mesh_plink_del_ent(adapter, ent);
+
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return exist == _TRUE ? _SUCCESS : RTW_ALREADY;
+}
+
+void rtw_mesh_plink_ctl_init(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	int i;
+
+	_rtw_spinlock_init(&plink_ctl->lock);
+	plink_ctl->num = 0;
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++)
+		plink_ctl->ent[i].valid = _FALSE;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	_rtw_init_queue(&plink_ctl->peer_blacklist);
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	_rtw_init_queue(&plink_ctl->cto_mgate_blacklist);
+#endif
+}
+
+void rtw_mesh_plink_ctl_deinit(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent;
+	int i;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		ent = &plink_ctl->ent[i];
+		#ifdef CONFIG_RTW_MESH_DRIVER_AID
+		if (ent->tx_conf_ies && ent->tx_conf_ies_len)
+			rtw_mfree(ent->tx_conf_ies, ent->tx_conf_ies_len);
+		#endif
+		if (ent->rx_conf_ies && ent->rx_conf_ies_len)
+			rtw_mfree(ent->rx_conf_ies, ent->rx_conf_ies_len);
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+	_rtw_spinlock_free(&plink_ctl->lock);
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	rtw_mesh_peer_blacklist_flush(adapter);
+	_rtw_deinit_queue(&plink_ctl->peer_blacklist);
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	rtw_mesh_cto_mgate_blacklist_flush(adapter);
+	_rtw_deinit_queue(&plink_ctl->cto_mgate_blacklist);
+#endif
+}
+
+void dump_mesh_plink_ctl(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent;
+	int i;
+
+	RTW_PRINT_SEL(sel, "num:%u\n", plink_ctl->num);
+
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++)  {
+		ent = &plink_ctl->ent[i];
+		if (!ent->valid)
+			continue;
+
+		RTW_PRINT_SEL(sel, "\n");
+		RTW_PRINT_SEL(sel, "peer:"MAC_FMT"\n", MAC_ARG(ent->addr));
+		RTW_PRINT_SEL(sel, "plink_state:%s\n", rtw_mesh_plink_str(ent->plink_state));
+
+		#ifdef CONFIG_RTW_MESH_AEK
+		if (ent->aek_valid)
+			RTW_PRINT_SEL(sel, "aek:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->aek), KEY_ARG(ent->aek + 16));
+		#endif
+
+		RTW_PRINT_SEL(sel, "llid:%u, plid:%u\n", ent->llid, ent->plid);
+		#ifndef CONFIG_RTW_MESH_DRIVER_AID
+		RTW_PRINT_SEL(sel, "aid:%u\n", ent->aid);
+		#endif
+		RTW_PRINT_SEL(sel, "peer_aid:%u\n", ent->peer_aid);
+
+		RTW_PRINT_SEL(sel, "chosen_pmk:"KEY_FMT"\n", KEY_ARG(ent->chosen_pmk));
+
+		#ifdef CONFIG_RTW_MESH_AEK
+		RTW_PRINT_SEL(sel, "sel_pcs:%02x%02x%02x%02x\n"
+			, ent->sel_pcs[0], ent->sel_pcs[1], ent->sel_pcs[2], ent->sel_pcs[3]);
+		RTW_PRINT_SEL(sel, "l_nonce:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->l_nonce), KEY_ARG(ent->l_nonce + 16));
+		RTW_PRINT_SEL(sel, "p_nonce:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->p_nonce), KEY_ARG(ent->p_nonce + 16));
+		#endif
+
+		#ifdef CONFIG_RTW_MESH_DRIVER_AID
+		RTW_PRINT_SEL(sel, "tx_conf_ies:%p, len:%u\n", ent->tx_conf_ies, ent->tx_conf_ies_len);
+		#endif
+		RTW_PRINT_SEL(sel, "rx_conf_ies:%p, len:%u\n", ent->rx_conf_ies, ent->rx_conf_ies_len);
+		RTW_PRINT_SEL(sel, "scanned:%p\n", ent->scanned);
+
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		if (!IS_PEER_CONF_DISABLED(ent)) {
+			if (!IS_PEER_CONF_TIMEOUT(ent))
+				RTW_PRINT_SEL(sel, "peer_conf:%d\n", rtw_systime_to_ms(ent->peer_conf_end_time - rtw_get_current_time()));
+			else
+				RTW_PRINT_SEL(sel, "peer_conf:TIMEOUT\n");
+		}
+		#endif
+
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		if (!IS_CTO_MGATE_CONF_DISABLED(ent)) {
+			if (!IS_CTO_MGATE_CONF_TIMEOUT(ent))
+				RTW_PRINT_SEL(sel, "cto_mgate_conf:%d\n", rtw_systime_to_ms(ent->cto_mgate_conf_end_time - rtw_get_current_time()));
+			else
+				RTW_PRINT_SEL(sel, "cto_mgate_conf:TIMEOUT\n");
+		}
+		#endif
+	}
+}
+
+/* this function is called with plink_ctl being locked */
+int rtw_mesh_peer_establish(_adapter *adapter, struct mesh_plink_ent *plink, struct sta_info *sta)
+{
+#ifndef DBG_RTW_MESH_PEER_ESTABLISH
+#define DBG_RTW_MESH_PEER_ESTABLISH 0
+#endif
+
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	u8 *tlv_ies;
+	u16 tlv_ieslen;
+	struct rtw_ieee802_11_elems elems;
+	_irqL irqL;
+	int i;
+	int ret = _FAIL;
+
+	if (!plink->rx_conf_ies || !plink->rx_conf_ies_len) {
+		RTW_INFO(FUNC_ADPT_FMT" no rx confirm from sta "MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+	if (plink->rx_conf_ies_len < 4) {
+		RTW_INFO(FUNC_ADPT_FMT" confirm from sta "MAC_FMT" too short\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	if (!plink->tx_conf_ies || !plink->tx_conf_ies_len) {
+		RTW_INFO(FUNC_ADPT_FMT" no tx confirm to sta "MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+	if (plink->tx_conf_ies_len < 4) {
+		RTW_INFO(FUNC_ADPT_FMT" confirm to sta "MAC_FMT" too short\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+#endif
+
+	tlv_ies = plink->rx_conf_ies + 4;
+	tlv_ieslen = plink->rx_conf_ies_len - 4;
+
+	if (DBG_RTW_MESH_PEER_ESTABLISH)
+		dump_ies(RTW_DBGDUMP, tlv_ies, tlv_ieslen);
+
+	if (rtw_ieee802_11_parse_elems(tlv_ies, tlv_ieslen, &elems, 1) == ParseFailed) {
+		RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" sent invalid confirm\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+	SET_PEER_CONF_DISABLED(plink);
+	if (rtw_bss_is_cto_mgate(&plink->scanned->network)
+		&& !rtw_bss_is_forwarding(&plink->scanned->network))
+		SET_CTO_MGATE_CONF_END_TIME(plink, mcfg->peer_sel_policy.cto_mgate_conf_timeout_ms);
+	else
+		SET_CTO_MGATE_CONF_DISABLED(plink);
+
+	sta->state &= (~WIFI_FW_AUTH_SUCCESS);
+	sta->state |= WIFI_FW_ASSOC_STATE;
+
+	rtw_ap_parse_sta_capability(adapter, sta, plink->rx_conf_ies);
+
+	if (rtw_ap_parse_sta_supported_rates(adapter, sta, tlv_ies, tlv_ieslen) != _STATS_SUCCESSFUL_)
+		goto exit;
+	
+	if (rtw_ap_parse_sta_security_ie(adapter, sta, &elems) != _STATS_SUCCESSFUL_)
+		goto exit;
+
+	rtw_ap_parse_sta_wmm_ie(adapter, sta, tlv_ies, tlv_ieslen);
+
+	rtw_ap_parse_sta_ht_ie(adapter, sta, &elems);
+	rtw_ap_parse_sta_vht_ie(adapter, sta, &elems);
+
+	/* AID */
+#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	sta->cmn.aid = RTW_GET_LE16(plink->tx_conf_ies + 2);
+#else
+	sta->cmn.aid = plink->aid;
+#endif
+	stapriv->sta_aid[sta->cmn.aid - 1] = sta;
+	RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" aid:%u\n"
+		, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr), sta->cmn.aid);
+
+	sta->state &= (~WIFI_FW_ASSOC_STATE);
+	sta->state |= WIFI_FW_ASSOC_SUCCESS;
+
+	sta->local_mps = RTW_MESH_PS_ACTIVE;
+
+	rtw_ewma_err_rate_init(&sta->metrics.err_rate);
+	rtw_ewma_err_rate_add(&sta->metrics.err_rate, 1);
+	/* init data_rate to 1M */
+	sta->metrics.data_rate = 10;
+
+	_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+	if (rtw_is_list_empty(&sta->asoc_list)) {
+		STA_SET_MESH_PLINK(sta, plink);
+		/* TBD: up layer timeout mechanism */
+		/* sta->expire_to = mcfg->plink_timeout / 2; */
+		rtw_list_insert_tail(&sta->asoc_list, &stapriv->asoc_list);
+		stapriv->asoc_list_cnt++;
+	}
+	_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	bss_cap_update_on_sta_join(adapter, sta);
+	sta_info_update(adapter, sta);
+	report_add_sta_event(adapter, sta->cmn.mac_addr);
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_mesh_expire_peer_notify(_adapter *adapter, const u8 *peer_addr)
+{
+	u8 null_ssid[2] = {0, 0};
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_notify_new_peer_candidate(adapter->rtw_wdev
+		, peer_addr
+		, null_ssid
+		, 2
+		, GFP_ATOMIC
+	);
+#endif
+
+exit:
+	return;
+}
+
+static u8 *rtw_mesh_construct_peer_mesh_close(_adapter *adapter, struct mesh_plink_ent *plink, u16 reason, u32 *len)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u8 *frame = NULL, *pos;
+	u32 flen;
+	struct rtw_ieee80211_hdr *whdr;
+
+	if (minfo->mesh_auth_id && !MESH_PLINK_AEK_VALID(plink))
+		goto exit;
+
+	flen = sizeof(struct rtw_ieee80211_hdr_3addr)
+		+ 2 /* category, action */
+		+ 2 + minfo->mesh_id_len /* mesh id */
+		+ 2 + 8 + (minfo->mesh_auth_id ? 16 : 0) /* mpm */
+		+ (minfo->mesh_auth_id ? 2 + AES_BLOCK_SIZE : 0) /* mic */
+		+ (minfo->mesh_auth_id ? 70 : 0) /* ampe */
+		;
+
+	pos = frame = rtw_zmalloc(flen);
+	if (!frame)
+		goto exit;
+
+	whdr = (struct rtw_ieee80211_hdr *)frame;
+	_rtw_memcpy(whdr->addr1, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memcpy(whdr->addr2, plink->addr, ETH_ALEN);
+	_rtw_memcpy(whdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
+
+	set_frame_sub_type(frame, WIFI_ACTION);
+
+	pos += sizeof(struct rtw_ieee80211_hdr_3addr);
+	*(pos++) = RTW_WLAN_CATEGORY_SELF_PROTECTED;
+	*(pos++) = RTW_ACT_SELF_PROTECTED_MESH_CLOSE;
+
+	pos = rtw_set_ie_mesh_id(pos, NULL, minfo->mesh_id, minfo->mesh_id_len);
+
+	pos = rtw_set_ie_mpm(pos, NULL
+		, minfo->mesh_auth_id ? 1 : 0
+		, plink->plid
+		, &plink->llid
+		, &reason
+		, minfo->mesh_auth_id ? plink->chosen_pmk : NULL);
+
+#ifdef CONFIG_RTW_MESH_AEK
+	if (minfo->mesh_auth_id) {
+		u8 ampe_buf[70];
+		int enc_ret;
+
+		*pos = WLAN_EID_MIC;
+		*(pos + 1) = AES_BLOCK_SIZE;
+
+		ampe_buf[0] = WLAN_EID_AMPE;
+		ampe_buf[1] = 68;
+		_rtw_memcpy(ampe_buf + 2, plink->sel_pcs, 4);
+		_rtw_memcpy(ampe_buf + 6, plink->p_nonce, 32);
+		_rtw_memcpy(ampe_buf + 38, plink->l_nonce, 32);
+
+		enc_ret = rtw_mpm_ampe_enc(adapter, plink
+			, frame + sizeof(struct rtw_ieee80211_hdr_3addr)
+			, pos, ampe_buf, 1);
+		if (enc_ret != _SUCCESS) {
+			rtw_mfree(frame, flen);
+			frame = NULL;
+			goto exit;
+		}
+	}
+#endif
+
+	*len = flen;
+
+exit:
+	return frame;
+}
+
+void _rtw_mesh_expire_peer_ent(_adapter *adapter, struct mesh_plink_ent *plink)
+{
+#if defined(CONFIG_RTW_MESH_STA_DEL_DISASOC)
+	_rtw_mesh_plink_del_ent(adapter, plink);
+	rtw_cfg80211_indicate_sta_disassoc(adapter, plink->addr, 0);
+#else
+	u8 *frame = NULL;
+	u32 flen;
+
+	if (plink->plink_state == RTW_MESH_PLINK_ESTAB)
+		frame = rtw_mesh_construct_peer_mesh_close(adapter, plink, WLAN_REASON_MESH_CLOSE, &flen);
+
+	if (frame) {
+		struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+		struct wireless_dev *wdev = adapter->rtw_wdev;
+		s32 freq = rtw_ch2freq(mlmeext->cur_channel);
+
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, flen, GFP_ATOMIC);
+		#else
+		cfg80211_rx_action(adapter->pnetdev, freq, frame, flen, GFP_ATOMIC);
+		#endif
+
+		rtw_mfree(frame, flen);
+	} else {
+		rtw_mesh_expire_peer_notify(adapter, plink->addr);
+		RTW_INFO(FUNC_ADPT_FMT" set "MAC_FMT" plink unknown\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(plink->addr));
+		plink->plink_state = RTW_MESH_PLINK_UNKNOWN;
+	}
+#endif
+}
+
+void rtw_mesh_expire_peer(_adapter *adapter, const u8 *peer_addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *plink;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+
+	plink = _rtw_mesh_plink_get(adapter, peer_addr);
+	if (!plink)
+		goto exit;
+
+	_rtw_mesh_expire_peer_ent(adapter, plink);
+
+exit:
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+}
+
+u8 rtw_mesh_ps_annc(_adapter *adapter, u8 ps)
+{
+	_irqL irqL;
+	_list *head, *list;
+	struct sta_info *sta;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u8 sta_alive_num = 0, i;
+	char sta_alive_list[NUM_STA];
+	u8 annc_cnt = 0;
+
+	if (rtw_linked_check(adapter) == _FALSE)
+		goto exit;
+
+	_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	head = &stapriv->asoc_list;
+	list = get_next(head);
+	while ((rtw_end_of_queue_search(head, list)) == _FALSE) {
+		int stainfo_offset;
+
+		sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
+		list = get_next(list);
+
+		stainfo_offset = rtw_stainfo_offset(stapriv, sta);
+		if (stainfo_offset_valid(stainfo_offset))
+			sta_alive_list[sta_alive_num++] = stainfo_offset;
+	}
+	_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	for (i = 0; i < sta_alive_num; i++) {
+		sta = rtw_get_stainfo_by_offset(stapriv, sta_alive_list[i]);
+		if (!sta)
+			continue;
+
+		issue_qos_nulldata(adapter, sta->cmn.mac_addr, 7, ps, 3, 500);
+		annc_cnt++;
+	}
+
+exit:
+	return annc_cnt;
+}
+
+static void mpath_tx_tasklet_hdl(void *priv)
+{
+	_adapter *adapter = (_adapter *)priv;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct xmit_frame *xframe;
+	_list *list, *head;
+	_list tmp;
+	u32 tmp_len;
+	s32 res;
+
+	_rtw_init_listhead(&tmp);
+
+	while (1) {
+		tmp_len = 0;
+		enter_critical_bh(&minfo->mpath_tx_queue.lock);
+		if (minfo->mpath_tx_queue_len) {
+			rtw_list_splice_init(&minfo->mpath_tx_queue.queue, &tmp);
+			tmp_len = minfo->mpath_tx_queue_len;
+			minfo->mpath_tx_queue_len = 0;
+		}
+		exit_critical_bh(&minfo->mpath_tx_queue.lock);
+
+		if (!tmp_len)
+			break;
+
+		head = &tmp;
+		list = get_next(head);
+		while (rtw_end_of_queue_search(head, list) == _FALSE) {
+			xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+			list = get_next(list);
+			rtw_list_delete(&xframe->list);
+			res = rtw_xmit_posthandle(adapter, xframe, xframe->pkt);
+			if (res < 0) {
+				#ifdef DBG_TX_DROP_FRAME
+				RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit fail\n", __FUNCTION__);
+				#endif
+				adapter->xmitpriv.tx_drop++;
+			}
+		}
+	}
+}
+
+static void rtw_mpath_tx_queue_flush(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct xmit_frame *xframe;
+	_list *list, *head;
+	_list tmp;
+
+	_rtw_init_listhead(&tmp);
+
+	enter_critical_bh(&minfo->mpath_tx_queue.lock);
+	rtw_list_splice_init(&minfo->mpath_tx_queue.queue, &tmp);
+	minfo->mpath_tx_queue_len = 0;
+	exit_critical_bh(&minfo->mpath_tx_queue.lock);
+
+	head = &tmp;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+		rtw_list_delete(&xframe->list);
+		rtw_free_xmitframe(&adapter->xmitpriv, xframe);
+	}
+}
+
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+#if defined(CONFIG_SLUB)
+#include <linux/slub_def.h>
+#elif defined(CONFIG_SLAB)
+#include <linux/slab_def.h>
+#endif
+typedef struct kmem_cache rtw_mcache;
+#endif
+
+rtw_mcache *rtw_mcache_create(const char *name, size_t size)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	return kmem_cache_create(name, size, 0, 0, NULL);
+#else
+	#error "TBD\n";
+#endif
+}
+
+void rtw_mcache_destroy(rtw_mcache *s)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	kmem_cache_destroy(s);
+#else
+	#error "TBD\n";
+#endif
+}
+
+void *_rtw_mcache_alloc(rtw_mcache *cachep)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	return kmem_cache_alloc(cachep, GFP_ATOMIC);
+#else
+	#error "TBD\n";
+#endif
+}
+
+void _rtw_mcache_free(rtw_mcache *cachep, void *objp)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	kmem_cache_free(cachep, objp);
+#else
+	#error "TBD\n";
+#endif
+}
+
+#ifdef DBG_MEM_ALLOC
+inline void *dbg_rtw_mcache_alloc(rtw_mcache *cachep, const enum mstat_f flags, const char *func, const int line)
+{
+	void *p;
+	u32 sz = cachep->size;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u)\n", func, line, __func__, sz);
+
+	p = _rtw_mcache_alloc(cachep);
+
+	rtw_mstat_update(
+		flags
+		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, sz
+	);
+
+	return p;
+}
+
+inline void dbg_rtw_mcache_free(rtw_mcache *cachep, void *pbuf, const enum mstat_f flags, const char *func, const int line)
+{
+	u32 sz = cachep->size;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u)\n", func, line, __func__, sz);
+
+	_rtw_mcache_free(cachep, pbuf);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, sz
+	);
+}
+
+#define rtw_mcache_alloc(cachep) dbg_rtw_mcache_alloc(cachep, MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_mcache_free(cachep, objp) dbg_rtw_mcache_free(cachep, objp, MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#else
+#define rtw_mcache_alloc(cachep) _rtw_mcache_alloc(cachep)
+#define rtw_mcache_free(cachep, objp) _rtw_mcache_free(cachep, objp)
+#endif /* DBG_MEM_ALLOC */
+
+/* Mesh Received Cache */
+#define RTW_MRC_BUCKETS			256 /* must be a power of 2 */
+#define RTW_MRC_QUEUE_MAX_LEN	4
+#define RTW_MRC_TIMEOUT_MS		(3 * 1000)
+
+/**
+ * struct rtw_mrc_entry - entry in the Mesh Received Cache
+ *
+ * @seqnum: mesh sequence number of the frame
+ * @exp_time: expiration time of the entry
+ * @msa: mesh source address of the frame
+ * @list: hashtable list pointer
+ *
+ * The Mesh Received Cache keeps track of the latest received frames that
+ * have been received by a mesh interface and discards received frames
+ * that are found in the cache.
+ */
+struct rtw_mrc_entry {
+	rtw_hlist_node list;
+	systime exp_time;
+	u32 seqnum;
+	u8 msa[ETH_ALEN];
+};
+
+struct rtw_mrc {
+	rtw_hlist_head bucket[RTW_MRC_BUCKETS];
+	u32 idx_mask;
+	rtw_mcache *cache;
+};
+
+static int rtw_mrc_init(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	char cache_name[IFNAMSIZ + 8 + 1];
+	int i;
+
+	minfo->mrc = rtw_malloc(sizeof(struct rtw_mrc));
+	if (!minfo->mrc)
+		return -ENOMEM;
+	minfo->mrc->idx_mask = RTW_MRC_BUCKETS - 1;
+	for (i = 0; i < RTW_MRC_BUCKETS; i++)
+		rtw_hlist_head_init(&minfo->mrc->bucket[i]);
+
+	sprintf(cache_name, "rtw_mrc_%s", ADPT_ARG(adapter));
+	minfo->mrc->cache = rtw_mcache_create(cache_name, sizeof(struct rtw_mrc_entry));
+
+	return 0;
+}
+
+static void rtw_mrc_free(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mrc *mrc = minfo->mrc;
+	struct rtw_mrc_entry *p;
+	rtw_hlist_node *np, *n;
+	int i;
+
+	if (!mrc)
+		return;
+
+	for (i = 0; i < RTW_MRC_BUCKETS; i++) {
+		rtw_hlist_for_each_entry_safe(p, np, n, &mrc->bucket[i], list) {
+			rtw_hlist_del(&p->list);
+			rtw_mcache_free(mrc->cache, p);
+		}
+	}
+
+	rtw_mcache_destroy(mrc->cache);
+
+	rtw_mfree(mrc, sizeof(struct rtw_mrc));
+	minfo->mrc = NULL;
+}
+
+/**
+ * rtw_mrc_check - Check frame in mesh received cache and add if absent.
+ *
+ * @adapter:	interface
+ * @msa:		mesh source address
+ * @seq:		mesh seq number
+ *
+ * Returns: 0 if the frame is not in the cache, nonzero otherwise.
+ *
+ * Checks using the mesh source address and the mesh sequence number if we have
+ * received this frame lately. If the frame is not in the cache, it is added to
+ * it.
+ */
+static int rtw_mrc_check(_adapter *adapter, const u8 *msa, u32 seq)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mrc *mrc = minfo->mrc;
+	int entries = 0;
+	u8 idx;
+	struct rtw_mrc_entry *p;
+	rtw_hlist_node *np, *n;
+	u8 timeout;
+
+	if (!mrc)
+		return -1;
+
+	idx = seq & mrc->idx_mask;
+	rtw_hlist_for_each_entry_safe(p, np, n, &mrc->bucket[idx], list) {
+		++entries;
+		timeout = rtw_time_after(rtw_get_current_time(), p->exp_time);
+		if (timeout || entries == RTW_MRC_QUEUE_MAX_LEN) {
+			if (!timeout)
+				minfo->mshstats.mrc_del_qlen++;
+
+			rtw_hlist_del(&p->list);
+			rtw_mcache_free(mrc->cache, p);
+			--entries;
+		} else if ((seq == p->seqnum) && _rtw_memcmp(msa, p->msa, ETH_ALEN) == _TRUE)
+			return -1;
+	}
+
+	p = rtw_mcache_alloc(mrc->cache);
+	if (!p)
+		return 0;
+
+	p->seqnum = seq;
+	p->exp_time = rtw_get_current_time() + rtw_ms_to_systime(RTW_MRC_TIMEOUT_MS);
+	_rtw_memcpy(p->msa, msa, ETH_ALEN);
+	rtw_hlist_add_head(&p->list, &mrc->bucket[idx]);
+	return 0;
+}
+
+static int rtw_mesh_decache(_adapter *adapter, const u8 *msa, u32 seq)
+{
+	return rtw_mrc_check(adapter, msa, seq);
+}
+
+void rtw_mesh_cfg_init_peer_sel_policy(struct rtw_mesh_cfg *mcfg)
+{
+	struct mesh_peer_sel_policy *sel_policy = &mcfg->peer_sel_policy;
+
+	sel_policy->scanr_exp_ms = RTW_MESH_SCAN_RESULT_EXP_MS;
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+	sel_policy->offch_find_int_ms = RTW_MESH_OFFCH_CAND_FIND_INT_MS;
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	sel_policy->peer_conf_timeout_ms = RTW_MESH_PEER_CONF_TIMEOUT_MS;
+	sel_policy->peer_blacklist_timeout_ms = RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS;
+#endif
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	sel_policy->cto_mgate_require = 0;
+	sel_policy->cto_mgate_conf_timeout_ms = RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS;
+	sel_policy->cto_mgate_blacklist_timeout_ms = RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS;
+#endif
+}
+
+void rtw_mesh_cfg_init(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	mcfg->max_peer_links = RTW_MESH_MAX_PEER_LINKS;
+	mcfg->plink_timeout = RTW_MESH_PEER_LINK_TIMEOUT;
+
+	mcfg->dot11MeshTTL = RTW_MESH_TTL;
+	mcfg->element_ttl = RTW_MESH_DEFAULT_ELEMENT_TTL;
+	mcfg->dot11MeshHWMPmaxPREQretries = RTW_MESH_MAX_PREQ_RETRIES;
+	mcfg->path_refresh_time = RTW_MESH_PATH_REFRESH_TIME;
+	mcfg->min_discovery_timeout = RTW_MESH_MIN_DISCOVERY_TIMEOUT;
+	mcfg->dot11MeshHWMPactivePathTimeout = RTW_MESH_PATH_TIMEOUT;
+	mcfg->dot11MeshHWMPpreqMinInterval = RTW_MESH_PREQ_MIN_INT;
+	mcfg->dot11MeshHWMPperrMinInterval = RTW_MESH_PERR_MIN_INT;
+	mcfg->dot11MeshHWMPnetDiameterTraversalTime = RTW_MESH_DIAM_TRAVERSAL_TIME;
+	mcfg->dot11MeshHWMPRootMode = RTW_IEEE80211_ROOTMODE_NO_ROOT;
+	mcfg->dot11MeshHWMPRannInterval = RTW_MESH_RANN_INTERVAL;
+	mcfg->dot11MeshGateAnnouncementProtocol = _FALSE;
+	mcfg->dot11MeshForwarding = _TRUE;
+	mcfg->rssi_threshold = 0;
+	mcfg->dot11MeshHWMPactivePathToRootTimeout = RTW_MESH_PATH_TO_ROOT_TIMEOUT;
+	mcfg->dot11MeshHWMProotInterval = RTW_MESH_ROOT_INTERVAL;
+	mcfg->dot11MeshHWMPconfirmationInterval = RTW_MESH_ROOT_CONFIRMATION_INTERVAL;
+	mcfg->path_gate_timeout_factor = 3;
+	rtw_mesh_cfg_init_peer_sel_policy(mcfg);
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	mcfg->sane_metric_delta = RTW_MESH_SANE_METRIC_DELTA;
+	mcfg->max_root_add_chk_cnt = RTW_MESH_MAX_ROOT_ADD_CHK_CNT;
+#endif
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	mcfg->b2u_flags_msrc = 0;
+	mcfg->b2u_flags_mfwd = RTW_MESH_B2U_GA_UCAST;
+#endif
+}
+
+void rtw_mesh_cfg_init_max_peer_links(_adapter *adapter, u8 stack_conf)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	mcfg->max_peer_links = RTW_MESH_MAX_PEER_LINKS;
+
+	if (mcfg->max_peer_links > stack_conf)
+		mcfg->max_peer_links = stack_conf;
+}
+
+void rtw_mesh_cfg_init_plink_timeout(_adapter *adapter, u32 stack_conf)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	mcfg->plink_timeout = stack_conf;
+}
+
+void rtw_mesh_init_mesh_info(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+
+	_rtw_memset(minfo, 0, sizeof(struct rtw_mesh_info));
+
+	rtw_mesh_plink_ctl_init(adapter);
+	
+	minfo->last_preq = rtw_get_current_time();
+	/* minfo->last_sn_update = rtw_get_current_time(); */
+	minfo->next_perr = rtw_get_current_time();
+	
+	ATOMIC_SET(&minfo->mpaths, 0);
+	rtw_mesh_pathtbl_init(adapter);
+
+	_rtw_init_queue(&minfo->mpath_tx_queue);
+	tasklet_init(&minfo->mpath_tx_tasklet
+		, (void(*)(unsigned long))mpath_tx_tasklet_hdl
+		, (unsigned long)adapter);
+
+	rtw_mrc_init(adapter);
+
+	_rtw_init_listhead(&minfo->preq_queue.list);
+	_rtw_spinlock_init(&minfo->mesh_preq_queue_lock);
+	
+	rtw_init_timer(&adapter->mesh_path_timer, adapter, rtw_ieee80211_mesh_path_timer, adapter);
+	rtw_init_timer(&adapter->mesh_path_root_timer, adapter, rtw_ieee80211_mesh_path_root_timer, adapter);
+	rtw_init_timer(&adapter->mesh_atlm_param_req_timer, adapter, rtw_mesh_atlm_param_req_timer, adapter);
+	_init_workitem(&adapter->mesh_work, rtw_mesh_work_hdl, NULL);
+}
+
+void rtw_mesh_deinit_mesh_info(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+
+	tasklet_kill(&minfo->mpath_tx_tasklet);
+	rtw_mpath_tx_queue_flush(adapter);
+	_rtw_deinit_queue(&adapter->mesh_info.mpath_tx_queue);
+
+	rtw_mrc_free(adapter);
+
+	rtw_mesh_pathtbl_unregister(adapter);
+
+	rtw_mesh_plink_ctl_deinit(adapter);
+
+	_cancel_workitem_sync(&adapter->mesh_work);
+	_cancel_timer_ex(&adapter->mesh_path_timer);
+	_cancel_timer_ex(&adapter->mesh_path_root_timer);
+	_cancel_timer_ex(&adapter->mesh_atlm_param_req_timer);
+}
+
+/**
+ * rtw_mesh_nexthop_resolve - lookup next hop; conditionally start path discovery
+ *
+ * @skb: 802.11 frame to be sent
+ * @sdata: network subif the frame will be sent through
+ *
+ * Lookup next hop for given skb and start path discovery if no
+ * forwarding information is found.
+ *
+ * Returns: 0 if the next hop was found and -ENOENT if the frame was queued.
+ * skb is freeed here if no mpath could be allocated.
+ */
+int rtw_mesh_nexthop_resolve(_adapter *adapter,
+			struct xmit_frame *xframe)
+{
+	struct pkt_attrib *attrib = &xframe->attrib;
+	struct rtw_mesh_path *mpath;
+	struct xmit_frame *xframe_to_free = NULL;
+	u8 *target_addr = attrib->mda;
+	int err = 0;
+	int ret = _SUCCESS;
+
+	rtw_rcu_read_lock();
+	err = rtw_mesh_nexthop_lookup(adapter, target_addr, attrib->msa, attrib->ra);
+	if (!err)
+		goto endlookup;
+
+	/* no nexthop found, start resolving */
+	mpath = rtw_mesh_path_lookup(adapter, target_addr);
+	if (!mpath) {
+		mpath = rtw_mesh_path_add(adapter, target_addr);
+		if (IS_ERR(mpath)) {
+			xframe->pkt = NULL; /* free pkt outside */
+			rtw_mesh_path_discard_frame(adapter, xframe);
+			err = PTR_ERR(mpath);
+			ret = _FAIL;
+			goto endlookup;
+		}
+	}
+
+	if (!(mpath->flags & RTW_MESH_PATH_RESOLVING))
+		rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START);
+
+	enter_critical_bh(&mpath->frame_queue.lock);
+
+	if (mpath->frame_queue_len >= RTW_MESH_FRAME_QUEUE_LEN) {
+		xframe_to_free = LIST_CONTAINOR(get_next(get_list_head(&mpath->frame_queue)), struct xmit_frame, list);
+		rtw_list_delete(&(xframe_to_free->list));
+		mpath->frame_queue_len--;
+	}
+
+	rtw_list_insert_tail(&xframe->list, get_list_head(&mpath->frame_queue));
+	mpath->frame_queue_len++;
+
+	exit_critical_bh(&mpath->frame_queue.lock);
+
+	ret = RTW_RA_RESOLVING;
+	if (xframe_to_free)
+		rtw_mesh_path_discard_frame(adapter, xframe_to_free);
+
+endlookup:
+	rtw_rcu_read_unlock();
+	return ret;
+}
+
+/**
+ * rtw_mesh_nexthop_lookup - put the appropriate next hop on a mesh frame. Calling
+ * this function is considered "using" the associated mpath, so preempt a path
+ * refresh if this mpath expires soon.
+ *
+ * @skb: 802.11 frame to be sent
+ * @sdata: network subif the frame will be sent through
+ *
+ * Returns: 0 if the next hop was found. Nonzero otherwise.
+ */
+int rtw_mesh_nexthop_lookup(_adapter *adapter,
+	const u8 *mda, const u8 *msa, u8 *ra)
+{
+	struct rtw_mesh_path *mpath;
+	struct sta_info *next_hop;
+	const u8 *target_addr = mda;
+	int err = -ENOENT;
+
+	rtw_rcu_read_lock();
+	mpath = rtw_mesh_path_lookup(adapter, target_addr);
+
+	if (!mpath || !(mpath->flags & RTW_MESH_PATH_ACTIVE))
+		goto endlookup;
+
+	if (rtw_time_after(rtw_get_current_time(),
+		       mpath->exp_time -
+		       rtw_ms_to_systime(adapter->mesh_cfg.path_refresh_time)) &&
+	    _rtw_memcmp(adapter_mac_addr(adapter), msa, ETH_ALEN) == _TRUE &&
+	    !(mpath->flags & RTW_MESH_PATH_RESOLVING) &&
+	    !(mpath->flags & RTW_MESH_PATH_FIXED)) {
+		rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH);
+	}
+
+	next_hop = rtw_rcu_dereference(mpath->next_hop);
+	if (next_hop) {
+		_rtw_memcpy(ra, next_hop->cmn.mac_addr, ETH_ALEN);
+		err = 0;
+	}
+
+endlookup:
+	rtw_rcu_read_unlock();
+	return err;
+}
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+static bool rtw_mesh_data_bmc_to_uc(_adapter *adapter
+	, const u8 *da, const u8 *sa, const u8 *mda, const u8 *msa
+	, u8 ae_need, const u8 *ori_ta, u8 mfwd_ttl
+	, _list *b2u_list, u8 *b2u_num, u32 *b2u_mseq)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct xmit_priv *xmitpriv = &adapter->xmitpriv;
+	_irqL irqL;
+	_list *head, *list;
+	struct sta_info *sta;
+	char b2u_sta_id[NUM_STA];
+	u8 b2u_sta_num = 0;
+	bool bmc_need = _FALSE;
+	int i;
+
+	_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+	head = &stapriv->asoc_list;
+	list = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, list)) == _FALSE) {
+		int stainfo_offset;
+
+		sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
+		list = get_next(list);
+	
+		stainfo_offset = rtw_stainfo_offset(stapriv, sta);
+		if (stainfo_offset_valid(stainfo_offset))
+			b2u_sta_id[b2u_sta_num++] = stainfo_offset;
+	}
+	_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	if (!b2u_sta_num)
+		goto exit;
+
+	for (i = 0; i < b2u_sta_num; i++) {
+		struct xmit_frame *b2uframe;
+		struct pkt_attrib *attrib;
+
+		sta = rtw_get_stainfo_by_offset(stapriv, b2u_sta_id[i]);
+		if (!(sta->state & _FW_LINKED)
+			|| _rtw_memcmp(sta->cmn.mac_addr, msa, ETH_ALEN) == _TRUE
+			|| (ori_ta && _rtw_memcmp(sta->cmn.mac_addr, ori_ta, ETH_ALEN) == _TRUE)
+			|| is_broadcast_mac_addr(sta->cmn.mac_addr)
+			|| is_zero_mac_addr(sta->cmn.mac_addr))
+			continue;
+
+		b2uframe = rtw_alloc_xmitframe(xmitpriv);
+		if (!b2uframe) {
+			bmc_need = _TRUE;
+			break;
+		}
+
+		if ((*b2u_num)++ == 0 && !ori_ta) {
+			*b2u_mseq = (cpu_to_le32(adapter->mesh_info.mesh_seqnum));
+			adapter->mesh_info.mesh_seqnum++;
+		}
+
+		attrib = &b2uframe->attrib;
+
+		attrib->mb2u = 1;
+		attrib->mseq = *b2u_mseq;
+		attrib->mfwd_ttl = ori_ta ? mfwd_ttl : 0;
+		_rtw_memcpy(attrib->ra, sta->cmn.mac_addr, ETH_ALEN);
+		_rtw_memcpy(attrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
+		_rtw_memcpy(attrib->mda, mda, ETH_ALEN);
+		_rtw_memcpy(attrib->msa, msa, ETH_ALEN);
+		_rtw_memcpy(attrib->dst, da, ETH_ALEN);
+		_rtw_memcpy(attrib->src, sa, ETH_ALEN);
+		attrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
+
+		rtw_list_insert_tail(&b2uframe->list, b2u_list);
+	}
+
+exit:
+	return bmc_need;
+}
+
+void dump_mesh_b2u_flags(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	RTW_PRINT_SEL(sel, "%4s %4s\n", "msrc", "mfwd");
+	RTW_PRINT_SEL(sel, "0x%02x 0x%02x\n", mcfg->b2u_flags_msrc, mcfg->b2u_flags_mfwd);
+}
+#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
+
+int rtw_mesh_addr_resolve(_adapter *adapter, struct xmit_frame *xframe, _pkt *pkt, _list *b2u_list)
+{
+	struct pkt_file pktfile;
+	struct ethhdr etherhdr;
+	struct pkt_attrib *attrib;
+	struct rtw_mesh_path *mpath = NULL, *mppath = NULL;
+	u8 is_da_mcast;
+	u8 ae_need;
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	bool bmc_need = _TRUE;
+	u8 b2u_num = 0;
+	u32 b2u_mseq = 0;
+#endif
+	int res = _SUCCESS;
+
+	_rtw_open_pktfile(pkt, &pktfile);
+	if (_rtw_pktfile_read(&pktfile, (u8 *)&etherhdr, ETH_HLEN) != ETH_HLEN) {
+		res = _FAIL;
+		goto exit;
+	}
+	
+	xframe->pkt = pkt;
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	_rtw_init_listhead(b2u_list);
+#endif
+
+	is_da_mcast = IS_MCAST(etherhdr.h_dest);
+	if (!is_da_mcast) {
+		struct sta_info *next_hop; 
+		bool mpp_lookup = 1;
+	
+		mpath = rtw_mesh_path_lookup(adapter, etherhdr.h_dest);
+		if (mpath) {
+			mpp_lookup = 0;
+			next_hop = rtw_rcu_dereference(mpath->next_hop);
+			if (!next_hop
+				|| !(mpath->flags & (RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVING))
+			) {
+				/* mpath is not valid, search mppath */
+				mpp_lookup = 1;
+			}
+		}
+
+		if (mpp_lookup) {
+			mppath = rtw_mpp_path_lookup(adapter, etherhdr.h_dest);
+			if (mppath)
+				mppath->exp_time = rtw_get_current_time();
+		}
+
+		if (mppath && mpath)
+			rtw_mesh_path_del(adapter, mpath->dst);
+
+		ae_need = _rtw_memcmp(adapter_mac_addr(adapter), etherhdr.h_source, ETH_ALEN) == _FALSE
+			|| (mppath && _rtw_memcmp(mppath->mpp, etherhdr.h_dest, ETH_ALEN) == _FALSE);
+	} else {
+		ae_need = _rtw_memcmp(adapter_mac_addr(adapter), etherhdr.h_source, ETH_ALEN) == _FALSE;
+
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (rtw_msrc_b2u_policy_chk(adapter->mesh_cfg.b2u_flags_msrc, etherhdr.h_dest)) {
+			bmc_need = rtw_mesh_data_bmc_to_uc(adapter
+				, etherhdr.h_dest, etherhdr.h_source
+				, etherhdr.h_dest, adapter_mac_addr(adapter), ae_need, NULL, 0
+				, b2u_list, &b2u_num, &b2u_mseq);
+			if (bmc_need == _FALSE) {
+				res = RTW_BMC_NO_NEED;
+				goto exit;
+			}
+		}
+		#endif
+	}
+
+	attrib = &xframe->attrib;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (b2u_num) {
+		attrib->mb2u = 1;
+		attrib->mseq = b2u_mseq;
+	} else
+		attrib->mb2u = 0;
+#endif
+
+	attrib->mfwd_ttl = 0;
+	_rtw_memcpy(attrib->dst, etherhdr.h_dest, ETH_ALEN);
+	_rtw_memcpy(attrib->src, etherhdr.h_source, ETH_ALEN);
+	_rtw_memcpy(attrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
+
+	if (is_da_mcast) {
+		attrib->mesh_frame_mode = ae_need ? MESH_BMCAST_PX_DATA : MESH_BMCAST_DATA;
+		_rtw_memcpy(attrib->ra, attrib->dst, ETH_ALEN);
+		_rtw_memcpy(attrib->msa, adapter_mac_addr(adapter), ETH_ALEN);
+	} else {
+		attrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
+		_rtw_memcpy(attrib->mda, (mppath && ae_need) ? mppath->mpp : attrib->dst, ETH_ALEN);
+		_rtw_memcpy(attrib->msa, adapter_mac_addr(adapter), ETH_ALEN);
+		/* RA needs to be resolved */
+		res = rtw_mesh_nexthop_resolve(adapter, xframe);
+	}
+
+exit:
+	return res;
+}
+
+s8 rtw_mesh_tx_set_whdr_mctrl_len(u8 mesh_frame_mode, struct pkt_attrib *attrib)
+{
+	u8 ret = 0;
+	switch (mesh_frame_mode) {
+	case MESH_UCAST_DATA:
+		attrib->hdrlen = WLAN_HDR_A4_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN. no ext addr. */
+		attrib->meshctrl_len = 6;
+		break;
+	case MESH_BMCAST_DATA:
+		attrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN. no ext addr. */
+		attrib->meshctrl_len = 6;
+		break;
+	case MESH_UCAST_PX_DATA:
+		attrib->hdrlen = WLAN_HDR_A4_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN + extaddr1 + extaddr2. */
+		attrib->meshctrl_len = 18;
+		break;
+	case MESH_BMCAST_PX_DATA:
+		attrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN + extaddr1 */
+		attrib->meshctrl_len = 12;
+		break;
+	default:
+		RTW_WARN("Invalid mesh frame mode:%u\n", mesh_frame_mode);
+		ret = -1;
+		break;
+	}				
+
+	return ret;
+}
+
+void rtw_mesh_tx_build_mctrl(_adapter *adapter, struct pkt_attrib *attrib, u8 *buf)
+{
+	struct rtw_ieee80211s_hdr *mctrl = (struct rtw_ieee80211s_hdr *)buf;
+
+	_rtw_memset(mctrl, 0, XATTRIB_GET_MCTRL_LEN(attrib));
+
+	if (attrib->mfwd_ttl
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		|| attrib->mb2u
+		#endif
+	) {
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (!attrib->mfwd_ttl)
+			mctrl->ttl = adapter->mesh_cfg.dot11MeshTTL;
+		else
+		#endif
+			mctrl->ttl = attrib->mfwd_ttl;
+
+		mctrl->seqnum = (cpu_to_le32(attrib->mseq));
+	} else {
+		mctrl->ttl = adapter->mesh_cfg.dot11MeshTTL;
+		mctrl->seqnum = (cpu_to_le32(adapter->mesh_info.mesh_seqnum));
+		adapter->mesh_info.mesh_seqnum++;
+	}
+
+	switch (attrib->mesh_frame_mode){
+	case MESH_UCAST_DATA:
+	case MESH_BMCAST_DATA:
+		break;
+	case MESH_UCAST_PX_DATA:
+		mctrl->flags |= MESH_FLAGS_AE_A5_A6;
+		_rtw_memcpy(mctrl->eaddr1, attrib->dst, ETH_ALEN);
+		_rtw_memcpy(mctrl->eaddr2, attrib->src, ETH_ALEN);
+		break;
+	case MESH_BMCAST_PX_DATA:
+		mctrl->flags |= MESH_FLAGS_AE_A4;
+		_rtw_memcpy(mctrl->eaddr1, attrib->src, ETH_ALEN);
+		break;
+	case MESH_MHOP_UCAST_ACT:
+		/* TBD */
+		break;
+	case MESH_MHOP_BMCAST_ACT:
+		/* TBD */
+		break;
+	default:
+		break;
+	}
+}
+
+u8 rtw_mesh_tx_build_whdr(_adapter *adapter, struct pkt_attrib *attrib
+	, u16 *fctrl, struct rtw_ieee80211_hdr *whdr)
+{
+	switch (attrib->mesh_frame_mode) {
+	case MESH_UCAST_DATA:		/* 1, 1, RA, TA, mDA(=DA),	mSA(=SA) */
+	case MESH_UCAST_PX_DATA:	/* 1, 1, RA, TA, mDA,		mSA,		[DA, SA] */
+		SetToDs(fctrl);
+		SetFrDs(fctrl);
+		_rtw_memcpy(whdr->addr1, attrib->ra, ETH_ALEN);
+		_rtw_memcpy(whdr->addr2, attrib->ta, ETH_ALEN);
+		_rtw_memcpy(whdr->addr3, attrib->mda, ETH_ALEN);
+		_rtw_memcpy(whdr->addr4, attrib->msa, ETH_ALEN);
+		break;
+	case MESH_BMCAST_DATA:		/* 0, 1, RA(DA), TA, mSA(SA) */
+	case MESH_BMCAST_PX_DATA:	/* 0, 1, RA(DA), TA, mSA,		[SA] */
+		SetFrDs(fctrl);
+		_rtw_memcpy(whdr->addr1, attrib->ra, ETH_ALEN);
+		_rtw_memcpy(whdr->addr2, attrib->ta, ETH_ALEN);
+		_rtw_memcpy(whdr->addr3, attrib->msa, ETH_ALEN);
+		break;
+	case MESH_MHOP_UCAST_ACT:
+		/* TBD */
+		RTW_INFO("MESH_MHOP_UCAST_ACT\n");
+		break;
+	case MESH_MHOP_BMCAST_ACT:
+		/* TBD */
+		RTW_INFO("MESH_MHOP_BMCAST_ACT\n");
+		break;
+	default:
+		RTW_WARN("Invalid mesh frame mode\n");
+		break;
+	}
+	
+	return 0;
+}
+
+int rtw_mesh_rx_data_validate_hdr(_adapter *adapter, union recv_frame *rframe, struct sta_info **sta)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	u8 *whdr = get_recvframe_data(rframe);
+	u8 is_ra_bmc = 0;
+	u8 a4_shift = 0;
+	u8 ps;
+	u8 *qc;
+	u8 mps_mode = RTW_MESH_PS_UNKNOWN;
+	sint ret = _FAIL;
+
+	if (!(MLME_STATE(adapter) & WIFI_ASOC_STATE))
+		goto exit;
+
+	if (!rattrib->qos)
+		goto exit;
+
+	switch (rattrib->to_fr_ds) {
+	case 1:
+		if (!IS_MCAST(GetAddr1Ptr(whdr)))
+			goto exit;
+		*sta = rtw_get_stainfo(stapriv, get_addr2_ptr(whdr));
+		if (*sta == NULL) {
+			ret = _SUCCESS; /* return _SUCCESS to drop at sta checking */
+			goto exit;
+		}
+		_rtw_memcpy(rattrib->ra, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->ta, get_addr2_ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->mda, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->msa, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
+		_rtw_memcpy(rattrib->dst, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->src, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
+		_rtw_memcpy(rattrib->bssid, get_addr2_ptr(whdr), ETH_ALEN);
+		is_ra_bmc = 1;
+		break;
+	case 3:
+		if (IS_MCAST(GetAddr1Ptr(whdr)))
+			goto exit;
+		*sta = rtw_get_stainfo(stapriv, get_addr2_ptr(whdr));
+		if (*sta == NULL) {
+			ret = _SUCCESS; /* return _SUCCESS to drop at sta checking */
+			goto exit;
+		}
+		_rtw_memcpy(rattrib->ra, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->ta, get_addr2_ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->mda, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
+		_rtw_memcpy(rattrib->msa, GetAddr4Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
+		_rtw_memcpy(rattrib->dst, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
+		_rtw_memcpy(rattrib->src, GetAddr4Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
+		_rtw_memcpy(rattrib->bssid, get_addr2_ptr(whdr), ETH_ALEN);
+		a4_shift = ETH_ALEN;
+		break;
+	default:
+		goto exit;
+	}
+
+	qc = whdr + WLAN_HDR_A3_LEN + a4_shift;
+	ps = GetPwrMgt(whdr);
+	mps_mode = ps ? (is_ra_bmc || (get_mps_lv(qc)) ? RTW_MESH_PS_DSLEEP : RTW_MESH_PS_LSLEEP) : RTW_MESH_PS_ACTIVE;
+
+	if (ps) {
+		if (!((*sta)->state & WIFI_SLEEP_STATE))
+			stop_sta_xmit(adapter, *sta);
+	} else {
+		if ((*sta)->state & WIFI_SLEEP_STATE)
+			wakeup_sta_to_xmit(adapter, *sta);
+	}
+
+	if (is_ra_bmc)
+		(*sta)->nonpeer_mps = mps_mode;
+	else {
+		(*sta)->peer_mps = mps_mode;
+		if (mps_mode != RTW_MESH_PS_ACTIVE && (*sta)->nonpeer_mps == RTW_MESH_PS_ACTIVE)
+			(*sta)->nonpeer_mps = RTW_MESH_PS_DSLEEP;
+	}
+
+	if (get_frame_sub_type(whdr) & BIT(6)) {
+		/* No data, will not indicate to upper layer, temporily count it here */
+		count_rx_stats(adapter, rframe, *sta);
+		ret = RTW_RX_HANDLED;
+		goto exit;
+	}
+
+	rattrib->mesh_ctrl_present = get_mctrl_present(qc) ? 1 : 0;
+	if (!rattrib->mesh_ctrl_present)
+		goto exit;
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+int rtw_mesh_rx_data_validate_mctrl(_adapter *adapter, union recv_frame *rframe
+	, const struct rtw_ieee80211s_hdr *mctrl, const u8 *mda, const u8 *msa
+	, u8 *mctrl_len
+	, const u8 **da, const u8 **sa)
+{
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	u8 mlen;
+	u8 ae;
+	int ret = _SUCCESS;
+
+	ae = mctrl->flags & MESH_FLAGS_AE;
+	mlen = ae_to_mesh_ctrl_len[ae];
+	switch (rattrib->to_fr_ds) {
+	case 1:
+		*da = mda;
+		if (ae == MESH_FLAGS_AE_A4)
+			*sa = mctrl->eaddr1;
+		else if (ae == 0)
+			*sa = msa;
+		else
+			ret = _FAIL;
+		break;
+	case 3:
+		if (ae == MESH_FLAGS_AE_A5_A6) {
+			*da = mctrl->eaddr1;
+			*sa = mctrl->eaddr2;
+		} else if (ae == 0) {
+			*da = mda;
+			*sa = msa;
+		} else
+			ret = _FAIL;
+		break;
+	default:
+		ret = _FAIL;
+	}
+
+	if (ret == _FAIL) {
+		#ifdef DBG_RX_DROP_FRAME
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" invalid tfDS:%u AE:%u combination ra="MAC_FMT" ta="MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), rattrib->to_fr_ds, ae, MAC_ARG(rattrib->ra), MAC_ARG(rattrib->ta));
+		#endif
+		*mctrl_len = 0;
+	} else
+		*mctrl_len = mlen;
+
+	return ret;	
+}
+
+inline int rtw_mesh_rx_validate_mctrl_non_amsdu(_adapter *adapter, union recv_frame *rframe)
+{
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	const u8 *da, *sa;
+	int ret;
+
+	ret = rtw_mesh_rx_data_validate_mctrl(adapter, rframe
+			, (struct rtw_ieee80211s_hdr *)(get_recvframe_data(rframe) + rattrib->hdrlen + rattrib->iv_len)
+			, rattrib->mda, rattrib->msa
+			, &rattrib->mesh_ctrl_len
+			, &da, &sa);
+
+	if (ret == _SUCCESS) {
+		_rtw_memcpy(rattrib->dst, da, ETH_ALEN);
+		_rtw_memcpy(rattrib->src, sa, ETH_ALEN);
+	}
+
+	return ret;
+}
+
+/**
+ * rtw_mesh_rx_nexthop_resolve - lookup next hop; conditionally start path discovery
+ *
+ * @skb: 802.11 frame to be sent
+ * @sdata: network subif the frame will be sent through
+ *
+ * Lookup next hop for given skb and start path discovery if no
+ * forwarding information is found.
+ *
+ * Returns: 0 if the next hop was found and -ENOENT if the frame was queued.
+ * skb is freeed here if no mpath could be allocated.
+ */
+static int rtw_mesh_rx_nexthop_resolve(_adapter *adapter,
+	const u8 *mda, const u8 *msa, u8 *ra)
+{
+	struct rtw_mesh_path *mpath;
+	struct xmit_frame *xframe_to_free = NULL;
+	int err = 0;
+	int ret = _SUCCESS;
+
+	rtw_rcu_read_lock();
+	err = rtw_mesh_nexthop_lookup(adapter, mda, msa, ra);
+	if (!err)
+		goto endlookup;
+
+	/* no nexthop found, start resolving */
+	mpath = rtw_mesh_path_lookup(adapter, mda);
+	if (!mpath) {
+		mpath = rtw_mesh_path_add(adapter, mda);
+		if (IS_ERR(mpath)) {
+			err = PTR_ERR(mpath);
+			ret = _FAIL;
+			goto endlookup;
+		}
+	}
+
+	if (!(mpath->flags & RTW_MESH_PATH_RESOLVING))
+		rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START);
+
+	ret = _FAIL;
+
+endlookup:
+	rtw_rcu_read_unlock();
+	return ret;
+}
+
+#define RTW_MESH_DECACHE_BMC 1
+#define RTW_MESH_DECACHE_UC 0
+
+#define RTW_MESH_FORWARD_MDA_SELF_COND 0
+#define DBG_RTW_MESH_FORWARD_MDA_SELF_COND 0
+int rtw_mesh_rx_msdu_act_check(union recv_frame *rframe
+	, const u8 *mda, const u8 *msa
+	, const u8 *da, const u8 *sa
+	, struct rtw_ieee80211s_hdr *mctrl
+	, struct xmit_frame **fwd_frame, _list *b2u_list)
+{
+	_adapter *adapter = rframe->u.hdr.adapter;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	struct rtw_mesh_path *mppath;
+	u8 is_mda_bmc = IS_MCAST(mda); 
+	u8 is_mda_self = !is_mda_bmc && _rtw_memcmp(mda, adapter_mac_addr(adapter), ETH_ALEN);
+	struct xmit_frame *xframe;
+	struct pkt_attrib *xattrib;
+	u8 fwd_ra[ETH_ALEN] = {0};
+	u8 fwd_mpp[ETH_ALEN] = {0}; /* forward to other gate */
+	u32 fwd_mseq;
+	int act = 0;
+	u8 ae_need;
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	bool bmc_need = _TRUE;
+	u8 b2u_num = 0;
+#endif
+
+	/* fwd info lifetime update */
+	#if 0
+	if (!is_mda_self)
+		mDA(A3) fwinfo.lifetime
+	mSA(A4) fwinfo.lifetime
+	Precursor-to-mDA(A2) fwinfo.lifetime
+	#endif
+
+	/* update/create pxoxy info for SA, mSA */
+	if ((mctrl->flags & MESH_FLAGS_AE)
+		&& sa != msa && _rtw_memcmp(sa, msa, ETH_ALEN) == _FALSE
+	) {
+		const u8 *proxied_addr = sa;
+		const u8 *mpp_addr = msa;
+
+		rtw_rcu_read_lock();
+		mppath = rtw_mpp_path_lookup(adapter, proxied_addr);
+		if (!mppath)
+			rtw_mpp_path_add(adapter, proxied_addr, mpp_addr);
+		else {
+			enter_critical_bh(&mppath->state_lock);
+			if (_rtw_memcmp(mppath->mpp, mpp_addr, ETH_ALEN) == _FALSE)
+				_rtw_memcpy(mppath->mpp, mpp_addr, ETH_ALEN);
+			mppath->exp_time = rtw_get_current_time();
+			exit_critical_bh(&mppath->state_lock);
+		}
+		rtw_rcu_read_unlock();
+	}
+
+	/* mSA is self, need no further process */
+	if (_rtw_memcmp(msa, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
+		goto exit;
+
+	fwd_mseq = le32_to_cpu(mctrl->seqnum);
+
+	/* check duplicate MSDU from mSA */
+	if (((RTW_MESH_DECACHE_BMC && is_mda_bmc)
+			|| (RTW_MESH_DECACHE_UC && !is_mda_bmc))
+		&& rtw_mesh_decache(adapter, msa, fwd_mseq)
+	) {
+		minfo->mshstats.dropped_frames_duplicate++;
+		goto exit;
+	}
+
+	if (is_mda_bmc) {
+		/* mDA is bmc addr */
+		act |= RTW_RX_MSDU_ACT_INDICATE;
+		if (!mcfg->dot11MeshForwarding)
+			goto exit;
+		goto fwd_chk;
+
+	} else if (!is_mda_self) {
+		/* mDA is unicast but not self */
+		if (!mcfg->dot11MeshForwarding) {
+			rtw_mesh_path_error_tx(adapter
+				, adapter->mesh_cfg.element_ttl
+				, mda, 0
+				, WLAN_REASON_MESH_PATH_NOFORWARD
+				, rattrib->ta
+			);
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" mDA("MAC_FMT") not self, !dot11MeshForwarding\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(mda));
+			#endif
+			goto exit;
+		}
+
+		if (rtw_mesh_rx_nexthop_resolve(adapter, mda, msa, fwd_ra) != _SUCCESS) {
+			/* mDA is unknown */
+			rtw_mesh_path_error_tx(adapter
+				, adapter->mesh_cfg.element_ttl
+				, mda, 0
+				, WLAN_REASON_MESH_PATH_NOFORWARD
+				, rattrib->ta
+			);
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" mDA("MAC_FMT") unknown\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(mda));
+			#endif
+			minfo->mshstats.dropped_frames_no_route++;
+			goto exit;
+
+		} else {
+			/* mDA is known in fwd info */
+			#if 0
+			if	(TA is not in precursors)
+				goto exit;
+			#endif
+			goto fwd_chk;
+		}
+
+	} else {
+		/* mDA is self */
+		#if RTW_MESH_FORWARD_MDA_SELF_COND
+		if (da == mda
+			|| _rtw_memcmp(da, adapter_mac_addr(adapter), ETH_ALEN)
+		) {
+			/* DA is self, indicate */
+			act |= RTW_RX_MSDU_ACT_INDICATE;
+			goto exit;
+		}
+
+		if (rtw_get_iface_by_macddr(adapter, da)) {
+			/* DA is buddy, indicate */
+			act |= RTW_RX_MSDU_ACT_INDICATE;
+			#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+			RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is buddy("ADPT_FMT")\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(da), ADPT_ARG(rtw_get_iface_by_macddr(adapter, da)));
+			#endif
+			goto exit;
+		}
+
+		/* DA is not self or buddy */
+		if (rtw_mesh_nexthop_lookup(adapter, da, msa, fwd_ra) == 0) {
+			/* DA is known in fwd info */
+			if (!mcfg->dot11MeshForwarding) {
+				/* path error to? */
+				#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+				RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") not self, !dot11MeshForwarding\n"
+					, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
+				#endif
+				goto exit;
+			}
+			mda = da;
+			#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+			RTW_INFO(FUNC_ADPT_FMT" fwd to DA("MAC_FMT"), fwd_RA("MAC_FMT")\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(fwd_ra));
+			#endif
+			goto fwd_chk;
+		}
+
+		rtw_rcu_read_lock();
+		mppath = rtw_mpp_path_lookup(adapter, da);
+		if (mppath) {
+			if (_rtw_memcmp(mppath->mpp, adapter_mac_addr(adapter), ETH_ALEN) == _FALSE) {
+				/* DA is proxied by others */
+				if (!mcfg->dot11MeshForwarding) {
+					/* path error to? */
+					#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+					RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), !dot11MeshForwarding\n"
+						, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp));
+					#endif
+					rtw_rcu_read_unlock();
+					goto exit;
+				}
+				_rtw_memcpy(fwd_mpp, mppath->mpp, ETH_ALEN);
+				mda = fwd_mpp;
+				msa = adapter_mac_addr(adapter);
+				rtw_rcu_read_unlock();
+
+				/* resolve RA */
+				if (rtw_mesh_nexthop_lookup(adapter, mda, msa, fwd_ra) != 0) {
+					minfo->mshstats.dropped_frames_no_route++;
+					#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+					RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), RA resolve fail\n"
+						, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp));
+					#endif
+					goto exit;
+				}
+				#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+				RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), fwd_RA("MAC_FMT")\n"
+					, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp), MAC_ARG(fwd_ra));
+				#endif
+				goto fwd_chk; /*  forward to other gate */
+			} else {
+				#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+				RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by self\n"
+					, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
+				#endif
+			}
+		}
+		rtw_rcu_read_unlock();
+
+		if (!mppath) {
+			#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+			RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") unknown\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
+			#endif
+			/* DA is unknown */
+			#if 0 /* TODO: flags with AE bit */
+			rtw_mesh_path_error_tx(adapter
+				, adapter->mesh_cfg.element_ttl
+				, mda, adapter->mesh_info.last_sn_update
+				, WLAN_REASON_MESH_PATH_NOPROXY
+				, msa
+			);
+			#endif
+		}
+
+		/*
+		* indicate to DS for both cases:
+		* 1.) DA is proxied by self
+		* 2.) DA is unknown
+		*/
+		#endif /* RTW_MESH_FORWARD_MDA_SELF_COND */
+		act |= RTW_RX_MSDU_ACT_INDICATE;
+		goto exit;
+	}
+
+fwd_chk:
+
+	if (adapter->stapriv.asoc_list_cnt <= 1)
+		goto exit;
+
+	if (mctrl->ttl == 1) {
+		minfo->mshstats.dropped_frames_ttl++;
+		if (!act) {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" ttl reaches 0, not forwarding\n"
+				, FUNC_ADPT_ARG(adapter));
+			#endif
+		}
+		goto exit;
+	}
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	_rtw_init_listhead(b2u_list);
+#endif
+
+	ae_need = _rtw_memcmp(da , mda, ETH_ALEN) == _FALSE
+		|| _rtw_memcmp(sa , msa, ETH_ALEN) == _FALSE;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (is_mda_bmc
+		&& rtw_mfwd_b2u_policy_chk(mcfg->b2u_flags_mfwd, mda, rattrib->to_fr_ds == 3)
+	) {
+		bmc_need = rtw_mesh_data_bmc_to_uc(adapter
+			, da, sa, mda, msa, ae_need, rframe->u.hdr.psta->cmn.mac_addr, mctrl->ttl - 1
+			, b2u_list, &b2u_num, &fwd_mseq);
+	}
+
+	if (bmc_need == _TRUE)
+#endif
+	{
+		xframe = rtw_alloc_xmitframe(&adapter->xmitpriv);
+		if (!xframe) {
+			#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME "FUNC_ADPT_FMT" rtw_alloc_xmitframe fail\n"
+				, FUNC_ADPT_ARG(adapter));
+			#endif
+			goto exit;
+		}
+
+		xattrib = &xframe->attrib;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (b2u_num)
+			xattrib->mb2u = 1;
+		else
+			xattrib->mb2u = 0;
+#endif
+		xattrib->mfwd_ttl = mctrl->ttl - 1;
+		xattrib->mseq = fwd_mseq;
+		_rtw_memcpy(xattrib->dst, da, ETH_ALEN);
+		_rtw_memcpy(xattrib->src, sa, ETH_ALEN);
+		_rtw_memcpy(xattrib->mda, mda, ETH_ALEN);
+		_rtw_memcpy(xattrib->msa, msa, ETH_ALEN);
+		_rtw_memcpy(xattrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
+
+		if (is_mda_bmc) {
+			xattrib->mesh_frame_mode = ae_need ? MESH_BMCAST_PX_DATA : MESH_BMCAST_DATA;
+			_rtw_memcpy(xattrib->ra, mda, ETH_ALEN);
+		} else {
+			xattrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
+			_rtw_memcpy(xattrib->ra, fwd_ra, ETH_ALEN);
+		}
+
+		*fwd_frame = xframe;
+	}
+
+	act |= RTW_RX_MSDU_ACT_FORWARD;
+	if (is_mda_bmc)
+		minfo->mshstats.fwded_mcast++;
+	else
+		minfo->mshstats.fwded_unicast++;
+	minfo->mshstats.fwded_frames++;
+
+exit:
+	return act;
+}
+
+void dump_mesh_stats(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_stats *stats = &minfo->mshstats;
+
+	RTW_PRINT_SEL(sel, "fwd_bmc:%u\n", stats->fwded_mcast);
+	RTW_PRINT_SEL(sel, "fwd_uc:%u\n", stats->fwded_unicast);
+
+	RTW_PRINT_SEL(sel, "drop_ttl:%u\n", stats->dropped_frames_ttl);
+	RTW_PRINT_SEL(sel, "drop_no_route:%u\n", stats->dropped_frames_no_route);
+	RTW_PRINT_SEL(sel, "drop_congestion:%u\n", stats->dropped_frames_congestion);
+	RTW_PRINT_SEL(sel, "drop_dup:%u\n", stats->dropped_frames_duplicate);
+
+	RTW_PRINT_SEL(sel, "mrc_del_qlen:%u\n", stats->mrc_del_qlen);
+}
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh.h
new file mode 100644
index 000000000000..deb5b08cc993
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh.h
@@ -0,0 +1,523 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_H_
+#define __RTW_MESH_H_
+
+#ifndef CONFIG_AP_MODE
+	#error "CONFIG_RTW_MESH can't be enabled when CONFIG_AP_MODE is not defined\n"
+#endif
+
+#ifndef RTW_MESH_SCAN_RESULT_EXP_MS
+#define RTW_MESH_SCAN_RESULT_EXP_MS (10 * 1000)
+#endif
+#ifndef RTW_MESH_OFFCH_CAND_FIND_INT_MS
+#define RTW_MESH_OFFCH_CAND_FIND_INT_MS (10 * 1000)
+#endif
+#define RTW_MESH_TTL				31
+#define RTW_MESH_PERR_MIN_INT			100
+#define RTW_MESH_DEFAULT_ELEMENT_TTL		31
+#define RTW_MESH_RANN_INTERVAL			5000
+#define RTW_MESH_PATH_TO_ROOT_TIMEOUT		6000
+#define RTW_MESH_DIAM_TRAVERSAL_TIME		50
+#define RTW_MESH_PATH_TIMEOUT			5000
+#define RTW_MESH_PREQ_MIN_INT			10
+#define RTW_MESH_MAX_PREQ_RETRIES		4
+#define RTW_MESH_MIN_DISCOVERY_TIMEOUT 		(2 * RTW_MESH_DIAM_TRAVERSAL_TIME)
+#define RTW_MESH_ROOT_CONFIRMATION_INTERVAL	2000
+#define RTW_MESH_PATH_REFRESH_TIME		1000
+#define RTW_MESH_ROOT_INTERVAL			5000
+
+#define RTW_MESH_SANE_METRIC_DELTA		100
+#define RTW_MESH_MAX_ROOT_ADD_CHK_CNT		2
+
+#define RTW_MESH_PLINK_UNKNOWN	0
+#define RTW_MESH_PLINK_LISTEN	1
+#define RTW_MESH_PLINK_OPN_SNT	2
+#define RTW_MESH_PLINK_OPN_RCVD 3
+#define RTW_MESH_PLINK_CNF_RCVD 4
+#define RTW_MESH_PLINK_ESTAB	5
+#define RTW_MESH_PLINK_HOLDING	6
+#define RTW_MESH_PLINK_BLOCKED	7
+
+extern const char *_rtw_mesh_plink_str[];
+#define rtw_mesh_plink_str(s) ((s <= RTW_MESH_PLINK_BLOCKED) ? _rtw_mesh_plink_str[s] : _rtw_mesh_plink_str[RTW_MESH_PLINK_UNKNOWN])
+
+#define RTW_MESH_PS_UNKNOWN 0
+#define RTW_MESH_PS_ACTIVE 1
+#define RTW_MESH_PS_LSLEEP 2
+#define RTW_MESH_PS_DSLEEP 3
+
+extern const char *_rtw_mesh_ps_str[];
+#define rtw_mesh_ps_str(mps) ((mps <= RTW_MESH_PS_DSLEEP) ? _rtw_mesh_ps_str[mps] : _rtw_mesh_ps_str[RTW_MESH_PS_UNKNOWN])
+
+#define GET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(_iec)		LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 0, 0, 8)
+#define GET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(_iec)		LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 1, 0, 8)
+#define GET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(_iec)	LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 2, 0, 8)
+#define GET_MESH_CONF_ELE_SYNC_METHOD_ID(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 3, 0, 8)
+#define GET_MESH_CONF_ELE_AUTH_PROTO_ID(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 4, 0, 8)
+
+#define GET_MESH_CONF_ELE_MESH_FORMATION(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 0, 8)
+#define GET_MESH_CONF_ELE_CTO_MGATE(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 0, 1)
+#define GET_MESH_CONF_ELE_NUM_OF_PEERINGS(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 1, 6)
+#define GET_MESH_CONF_ELE_CTO_AS(_iec)					LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 7, 1)
+
+#define GET_MESH_CONF_ELE_MESH_CAP(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 0, 8)
+#define GET_MESH_CONF_ELE_ACCEPT_PEERINGS(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 0, 1)
+#define GET_MESH_CONF_ELE_MCCA_SUP(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 1, 1)
+#define GET_MESH_CONF_ELE_MCCA_EN(_iec)					LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 2, 1)
+#define GET_MESH_CONF_ELE_FORWARDING(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 3, 1)
+#define GET_MESH_CONF_ELE_MBCA_EN(_iec)					LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 4, 1)
+#define GET_MESH_CONF_ELE_TBTT_ADJ(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 5, 1)
+#define GET_MESH_CONF_ELE_PS_LEVEL(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 6, 1)
+
+#define SET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 0, 0, 8, _val)
+#define SET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(_iec, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 1, 0, 8, _val)
+#define SET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(_iec, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 2, 0, 8, _val)
+#define SET_MESH_CONF_ELE_SYNC_METHOD_ID(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 3, 0, 8, _val)
+#define SET_MESH_CONF_ELE_AUTH_PROTO_ID(_iec, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 4, 0, 8, _val)
+
+#define SET_MESH_CONF_ELE_CTO_MGATE(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 0, 1, _val)
+#define SET_MESH_CONF_ELE_NUM_OF_PEERINGS(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 1, 6, _val)
+#define SET_MESH_CONF_ELE_CTO_AS(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 7, 1, _val)
+
+#define SET_MESH_CONF_ELE_ACCEPT_PEERINGS(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 0, 1, _val)
+#define SET_MESH_CONF_ELE_MCCA_SUP(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 1, 1, _val)
+#define SET_MESH_CONF_ELE_MCCA_EN(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 2, 1, _val)
+#define SET_MESH_CONF_ELE_FORWARDING(_iec, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 3, 1, _val)
+#define SET_MESH_CONF_ELE_MBCA_EN(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 4, 1, _val)
+#define SET_MESH_CONF_ELE_TBTT_ADJ(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 5, 1, _val)
+#define SET_MESH_CONF_ELE_PS_LEVEL(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 6, 1, _val)
+
+/* Mesh flags */
+#define MESH_FLAGS_AE		0x3 /* mask */
+#define MESH_FLAGS_AE_A4 	0x1
+#define MESH_FLAGS_AE_A5_A6	0x2
+
+/* Max number of paths */
+#define RTW_MESH_MAX_PATHS 1024
+
+#define RTW_PREQ_Q_F_START	0x1
+#define RTW_PREQ_Q_F_REFRESH	0x2
+#define RTW_PREQ_Q_F_CHK	0x4
+#define RTW_PREQ_Q_F_PEER_AKA	0x8
+struct rtw_mesh_preq_queue {
+	_list list;
+	u8 dst[ETH_ALEN];
+	u8 flags;
+};
+
+extern const u8 ae_to_mesh_ctrl_len[];
+
+enum mesh_frame_type {
+	MESH_UCAST_DATA		= 0x0,
+	MESH_BMCAST_DATA	= 0x1,
+	MESH_UCAST_PX_DATA	= 0x2,
+	MESH_BMCAST_PX_DATA	= 0x3,
+	MESH_MHOP_UCAST_ACT	= 0x4,
+	MESH_MHOP_BMCAST_ACT	= 0x5,
+};
+
+enum mpath_sel_frame_type {
+	MPATH_PREQ = 0,
+	MPATH_PREP,
+	MPATH_PERR,
+	MPATH_RANN
+};
+
+/**
+ * enum rtw_mesh_deferred_task_flags - mesh deferred tasks
+ *
+ *
+ *
+ * @RTW_MESH_WORK_HOUSEKEEPING: run the periodic mesh housekeeping tasks
+ * @RTW_MESH_WORK_ROOT: the mesh root station needs to send a frame
+ * @RTW_MESH_WORK_DRIFT_ADJUST: time to compensate for clock drift relative to other
+ * mesh nodes
+ * @RTW_MESH_WORK_MBSS_CHANGED: rebuild beacon and notify driver of BSS changes
+ */
+enum rtw_mesh_deferred_task_flags {
+	RTW_MESH_WORK_HOUSEKEEPING,
+	RTW_MESH_WORK_ROOT,
+	RTW_MESH_WORK_DRIFT_ADJUST,
+	RTW_MESH_WORK_MBSS_CHANGED,
+};
+
+#define RTW_MESH_MAX_PEER_CANDIDATES 15 /* aid consideration */
+#define RTW_MESH_MAX_PEER_LINKS 8
+#define RTW_MESH_PEER_LINK_TIMEOUT 20
+
+#define RTW_MESH_PEER_CONF_DISABLED 0 /* special time value means no confirmation ongoing */
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+#define IS_PEER_CONF_DISABLED(plink) ((plink)->peer_conf_end_time == RTW_MESH_PEER_CONF_DISABLED)
+#define IS_PEER_CONF_TIMEOUT(plink)(!IS_PEER_CONF_DISABLED(plink) && rtw_time_after(rtw_get_current_time(), (plink)->peer_conf_end_time))
+#define SET_PEER_CONF_DISABLED(plink) (plink)->peer_conf_end_time = RTW_MESH_PEER_CONF_DISABLED
+#define SET_PEER_CONF_END_TIME(plink, timeout_ms) \
+	do { \
+		(plink)->peer_conf_end_time = rtw_get_current_time() + rtw_ms_to_systime(timeout_ms); \
+		if ((plink)->peer_conf_end_time == RTW_MESH_PEER_CONF_DISABLED) \
+			(plink)->peer_conf_end_time++; \
+	} while (0)
+#else
+#define IS_PEER_CONF_DISABLED(plink) 1
+#define IS_PEER_CONF_TIMEOUT(plink) 0
+#define SET_PEER_CONF_DISABLED(plink) do {} while (0)
+#define SET_PEER_CONF_END_TIME(plink, timeout_ms) do {} while (0)
+#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
+
+#define RTW_MESH_CTO_MGATE_CONF_DISABLED 0 /* special time value means no confirmation ongoing */
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+#define IS_CTO_MGATE_CONF_DISABLED(plink) ((plink)->cto_mgate_conf_end_time == RTW_MESH_CTO_MGATE_CONF_DISABLED)
+#define IS_CTO_MGATE_CONF_TIMEOUT(plink)(!IS_CTO_MGATE_CONF_DISABLED(plink) && rtw_time_after(rtw_get_current_time(), (plink)->cto_mgate_conf_end_time))
+#define SET_CTO_MGATE_CONF_DISABLED(plink) (plink)->cto_mgate_conf_end_time = RTW_MESH_CTO_MGATE_CONF_DISABLED
+#define SET_CTO_MGATE_CONF_END_TIME(plink, timeout_ms) \
+	do { \
+		(plink)->cto_mgate_conf_end_time = rtw_get_current_time() + rtw_ms_to_systime(timeout_ms); \
+		if ((plink)->cto_mgate_conf_end_time == RTW_MESH_CTO_MGATE_CONF_DISABLED) \
+			(plink)->cto_mgate_conf_end_time++; \
+	} while (0)
+#else
+#define IS_CTO_MGATE_CONF_DISABLED(plink) 1
+#define IS_CTO_MGATE_CONF_TIMEOUT(plink) 0
+#define SET_CTO_MGATE_CONF_DISABLED(plink) do {} while (0)
+#define SET_CTO_MGATE_CONF_END_TIME(plink, timeout_ms) do {} while (0)
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+struct mesh_plink_ent {
+	u8 valid;
+	u8 addr[ETH_ALEN];
+	u8 plink_state;
+
+#ifdef CONFIG_RTW_MESH_AEK
+	u8 aek_valid;
+	u8 aek[32];
+#endif
+
+	u16 llid;
+	u16 plid;
+#ifndef CONFIG_RTW_MESH_DRIVER_AID
+	u16 aid; /* aid assigned from upper layer */
+#endif
+	u16 peer_aid; /* aid assigned from peer */
+
+	u8 chosen_pmk[16];
+
+#ifdef CONFIG_RTW_MESH_AEK
+	u8 sel_pcs[4];
+	u8 l_nonce[32];
+	u8 p_nonce[32];
+#endif
+
+#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	u8 *tx_conf_ies;
+	u16 tx_conf_ies_len;
+#endif
+	u8 *rx_conf_ies;
+	u16 rx_conf_ies_len;
+
+	struct wlan_network *scanned;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	systime peer_conf_end_time;
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	systime cto_mgate_conf_end_time;
+#endif
+};
+
+#ifdef CONFIG_RTW_MESH_AEK
+#define MESH_PLINK_AEK_VALID(ent) ent->aek_valid
+#else
+#define MESH_PLINK_AEK_VALID(ent) 0
+#endif
+
+struct mesh_plink_pool {
+	_lock lock;
+	u8 num; /* current ent being used */
+	struct mesh_plink_ent ent[RTW_MESH_MAX_PEER_CANDIDATES];
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	_queue peer_blacklist;
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	_queue cto_mgate_blacklist;
+#endif
+};
+
+#define RTW_MESH_PEER_CONF_TIMEOUT_MS (20 * 1000)
+#define RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS (20 * 1000)
+#define RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS (20 * 1000)
+#define RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS (20 * 1000)
+
+struct mesh_peer_sel_policy {
+	u32 scanr_exp_ms;
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+	u32 offch_find_int_ms; /* 0 means no offch find by driver */
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	u32 peer_conf_timeout_ms;
+	u32 peer_blacklist_timeout_ms;
+#endif
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	u8 cto_mgate_require;
+	u32 cto_mgate_conf_timeout_ms;
+	u32 cto_mgate_blacklist_timeout_ms;
+#endif
+};
+
+/* b2u flags */
+#define RTW_MESH_B2U_ALL		BIT0
+#define RTW_MESH_B2U_GA_UCAST	BIT1 /* Group addressed unicast frame, forward only */
+#define RTW_MESH_B2U_BCAST		BIT2
+#define RTW_MESH_B2U_IP_MCAST	BIT3
+
+#define rtw_msrc_b2u_policy_chk(flags, mda) ( \
+	(flags & RTW_MESH_B2U_ALL) \
+	|| ((flags & RTW_MESH_B2U_BCAST) && is_broadcast_mac_addr(mda)) \
+	|| ((flags & RTW_MESH_B2U_IP_MCAST) && (IP_MCAST_MAC(mda) || ICMPV6_MCAST_MAC(mda))) \
+	)
+
+#define rtw_mfwd_b2u_policy_chk(flags, mda, ucst) ( \
+	(flags & RTW_MESH_B2U_ALL) \
+	|| ((flags & RTW_MESH_B2U_GA_UCAST) && ucst) \
+	|| ((flags & RTW_MESH_B2U_BCAST) && is_broadcast_mac_addr(mda)) \
+	|| ((flags & RTW_MESH_B2U_IP_MCAST) && (IP_MCAST_MAC(mda) || ICMPV6_MCAST_MAC(mda))) \
+	)
+
+/**
+ * @sane_metric_delta: Controlling if trigger additional path check mechanism
+ * @max_root_add_chk_cnt: The retry cnt to send additional root confirmation
+ *	PREQ through old(last) path
+ */
+struct rtw_mesh_cfg {
+	u8 max_peer_links; /* peering limit */
+	u32 plink_timeout; /* seconds */
+
+	u8 dot11MeshTTL;
+	u8 element_ttl;
+	u32 path_refresh_time;
+	u16 dot11MeshHWMPpreqMinInterval;
+	u16 dot11MeshHWMPnetDiameterTraversalTime;
+	u32 dot11MeshHWMPactivePathTimeout;
+	u8 dot11MeshHWMPmaxPREQretries;
+	u16 min_discovery_timeout;
+	u16 dot11MeshHWMPconfirmationInterval;
+	u16 dot11MeshHWMPperrMinInterval;
+	u8 dot11MeshHWMPRootMode;
+	BOOLEAN dot11MeshForwarding;
+	s32 rssi_threshold; /* in dBm, 0: no specified */
+	u16 dot11MeshHWMPRannInterval;
+	BOOLEAN dot11MeshGateAnnouncementProtocol;
+	u32 dot11MeshHWMPactivePathToRootTimeout;
+	u16 dot11MeshHWMProotInterval;
+	u8 path_gate_timeout_factor;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	u16 sane_metric_delta;
+	u8 max_root_add_chk_cnt;
+#endif
+
+	struct mesh_peer_sel_policy peer_sel_policy;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	u8 b2u_flags_msrc;
+	u8 b2u_flags_mfwd;
+#endif
+};
+
+struct rtw_mesh_stats {
+	u32 fwded_mcast;		/* Mesh forwarded multicast frames */
+	u32 fwded_unicast;		/* Mesh forwarded unicast frames */
+	u32 fwded_frames;		/* Mesh total forwarded frames */
+	u32 dropped_frames_ttl;	/* Not transmitted since mesh_ttl == 0*/
+	u32 dropped_frames_no_route;	/* Not transmitted, no route found */
+	u32 dropped_frames_congestion;/* Not forwarded due to congestion */
+	u32 dropped_frames_duplicate;
+
+	u32 mrc_del_qlen; /* MRC entry deleted cause by queue length limit */
+};
+
+struct rtw_mrc;
+
+struct rtw_mesh_info {
+	u8 mesh_id[NDIS_802_11_LENGTH_SSID];
+	size_t mesh_id_len;
+	/* Active Path Selection Protocol Identifier */
+	u8 mesh_pp_id;
+	/* Active Path Selection Metric Identifier */
+	u8 mesh_pm_id;
+	/* Congestion Control Mode Identifier */
+	u8 mesh_cc_id;
+	/* Synchronization Protocol Identifier */
+	u8 mesh_sp_id;
+	/* Authentication Protocol Identifier */
+	u8 mesh_auth_id;
+
+	struct mesh_plink_pool plink_ctl;
+
+	u32 mesh_seqnum;
+	/* MSTA's own hwmp sequence number */
+	u32 sn;
+	systime last_preq;
+	systime last_sn_update;
+	systime next_perr;
+	/* Last used Path Discovery ID */
+	u32 preq_id;
+	
+	ATOMIC_T mpaths;
+	struct rtw_mesh_table *mesh_paths;
+	struct rtw_mesh_table *mpp_paths;
+	int mesh_paths_generation;
+	int mpp_paths_generation;
+
+	int num_gates;
+	struct rtw_mesh_path *max_addr_gate;
+	bool max_addr_gate_is_larger_than_self;
+
+	struct rtw_mesh_stats mshstats;
+
+	_queue mpath_tx_queue;
+	u32 mpath_tx_queue_len;
+	struct tasklet_struct mpath_tx_tasklet;
+
+	struct rtw_mrc *mrc;
+
+	_lock mesh_preq_queue_lock;
+	struct rtw_mesh_preq_queue preq_queue;
+	int preq_queue_len;
+};
+
+extern const char *_action_self_protected_str[];
+#define action_self_protected_str(action) ((action < RTW_ACT_SELF_PROTECTED_NUM) ? _action_self_protected_str[action] : _action_self_protected_str[0])
+
+u8 *rtw_set_ie_mesh_id(u8 *buf, u32 *buf_len, const char *mesh_id, u8 id_len);
+u8 *rtw_set_ie_mesh_config(u8 *buf, u32 *buf_len
+	, u8 path_sel_proto, u8 path_sel_metric, u8 congest_ctl_mode, u8 sync_method, u8 auth_proto
+	, u8 num_of_peerings, bool cto_mgate, bool cto_as
+	, bool accept_peerings, bool mcca_sup, bool mcca_en, bool forwarding
+	, bool mbca_en, bool tbtt_adj, bool ps_level);
+
+int rtw_bss_is_same_mbss(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b);
+int rtw_bss_is_candidate_mesh_peer(WLAN_BSSID_EX *self, WLAN_BSSID_EX *target, u8 ch, u8 add_peer);
+
+void rtw_chk_candidate_peer_notify(_adapter *adapter, struct wlan_network *scanned);
+
+void rtw_mesh_peer_status_chk(_adapter *adapter);
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+u8 rtw_mesh_offch_candidate_accepted(_adapter *adapter);
+u8 rtw_mesh_select_operating_ch(_adapter *adapter);
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_peer_blacklist_add(_adapter *adapter, const u8 *addr);
+int rtw_mesh_peer_blacklist_del(_adapter *adapter, const u8 *addr);
+int rtw_mesh_peer_blacklist_search(_adapter *adapter, const u8 *addr);
+void rtw_mesh_peer_blacklist_flush(_adapter *adapter);
+void dump_mesh_peer_blacklist(void *sel, _adapter *adapter);
+void dump_mesh_peer_blacklist_settings(void *sel, _adapter *adapter);
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+u8 rtw_mesh_cto_mgate_required(_adapter *adapter);
+u8 rtw_mesh_cto_mgate_network_filter(_adapter *adapter, struct wlan_network *scanned);
+int rtw_mesh_cto_mgate_blacklist_add(_adapter *adapter, const u8 *addr);
+int rtw_mesh_cto_mgate_blacklist_del(_adapter *adapter, const u8 *addr);
+int rtw_mesh_cto_mgate_blacklist_search(_adapter *adapter, const u8 *addr);
+void rtw_mesh_cto_mgate_blacklist_flush(_adapter *adapter);
+void dump_mesh_cto_mgate_blacklist(void *sel, _adapter *adapter);
+void dump_mesh_cto_mgate_blacklist_settings(void *sel, _adapter *adapter);
+#endif
+void dump_mesh_peer_sel_policy(void *sel, _adapter *adapter);
+void dump_mesh_networks(void *sel, _adapter *adapter);
+
+int rtw_sae_check_frames(_adapter *adapter, const u8 *buf, u32 len, u8 tx);
+int rtw_mesh_check_frames_tx(_adapter *adapter, const u8 **buf, size_t *len);
+int rtw_mesh_check_frames_rx(_adapter *adapter, const u8 *buf, size_t len);
+
+unsigned int on_action_self_protected(_adapter *adapter, union recv_frame *rframe);
+
+bool rtw_mesh_update_bss_peering_status(_adapter *adapter, WLAN_BSSID_EX *bss);
+bool rtw_mesh_update_bss_formation_info(_adapter *adapter, WLAN_BSSID_EX *bss);
+bool rtw_mesh_update_bss_forwarding_state(_adapter *adapter, WLAN_BSSID_EX *bss);
+
+struct mesh_plink_ent *_rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr);
+struct mesh_plink_ent *rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr);
+struct mesh_plink_ent *rtw_mesh_plink_get_no_estab_by_idx(_adapter *adapter, u8 idx);
+int _rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr);
+int rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr);
+int rtw_mesh_plink_set_state(_adapter *adapter, const u8 *hwaddr, u8 state);
+#ifdef CONFIG_RTW_MESH_AEK
+int rtw_mesh_plink_set_aek(_adapter *adapter, const u8 *hwaddr, const u8 *aek);
+#endif
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_plink_set_peer_conf_timeout(_adapter *adapter, const u8 *hwaddr);
+#endif
+void _rtw_mesh_plink_del_ent(_adapter *adapter, struct mesh_plink_ent *ent);
+int rtw_mesh_plink_del(_adapter *adapter, const u8 *hwaddr);
+void rtw_mesh_plink_ctl_init(_adapter *adapter);
+void rtw_mesh_plink_ctl_deinit(_adapter *adapter);
+void dump_mesh_plink_ctl(void *sel, _adapter *adapter);
+
+int rtw_mesh_peer_establish(_adapter *adapter, struct mesh_plink_ent *plink, struct sta_info *sta);
+void _rtw_mesh_expire_peer_ent(_adapter *adapter, struct mesh_plink_ent *plink);
+void rtw_mesh_expire_peer(_adapter *adapter, const u8 *peer_addr);
+u8 rtw_mesh_ps_annc(_adapter *adapter, u8 ps);
+
+unsigned int on_action_mesh(_adapter *adapter, union recv_frame *rframe);
+
+void rtw_mesh_cfg_init(_adapter *adapter);
+void rtw_mesh_cfg_init_max_peer_links(_adapter *adapter, u8 stack_conf);
+void rtw_mesh_cfg_init_plink_timeout(_adapter *adapter, u32 stack_conf);
+void rtw_mesh_init_mesh_info(_adapter *adapter);
+void rtw_mesh_deinit_mesh_info(_adapter *adapter);
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+void dump_mesh_b2u_flags(void *sel, _adapter *adapter);
+#endif
+
+int rtw_mesh_addr_resolve(_adapter *adapter, struct xmit_frame *xframe, _pkt *pkt, _list *b2u_list);
+
+s8 rtw_mesh_tx_set_whdr_mctrl_len(u8 mesh_frame_mode, struct pkt_attrib *attrib);
+void rtw_mesh_tx_build_mctrl(_adapter *adapter, struct pkt_attrib *attrib, u8 *buf);
+u8 rtw_mesh_tx_build_whdr(_adapter *adapter, struct pkt_attrib *attrib
+	, u16 *fctrl, struct rtw_ieee80211_hdr *whdr);
+
+int rtw_mesh_rx_data_validate_hdr(_adapter *adapter, union recv_frame *rframe, struct sta_info **sta);
+int rtw_mesh_rx_data_validate_mctrl(_adapter *adapter, union recv_frame *rframe
+	, const struct rtw_ieee80211s_hdr *mctrl, const u8 *mda, const u8 *msa
+	, u8 *mctrl_len, const u8 **da, const u8 **sa);
+int rtw_mesh_rx_validate_mctrl_non_amsdu(_adapter *adapter, union recv_frame *rframe);
+
+int rtw_mesh_rx_msdu_act_check(union recv_frame *rframe
+	, const u8 *mda, const u8 *msa
+	, const u8 *da, const u8 *sa
+	, struct rtw_ieee80211s_hdr *mctrl
+	, struct xmit_frame **fwd_frame, _list *b2u_list);
+
+void dump_mesh_stats(void *sel, _adapter *adapter);
+
+#if defined(PLATFORM_LINUX) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
+#define rtw_lockdep_assert_held(l) lockdep_assert_held(l)
+#define rtw_lockdep_is_held(l) lockdep_is_held(l)
+#else
+#error "TBD\n"
+#endif
+
+#include "rtw_mesh_pathtbl.h"
+#include "rtw_mesh_hwmp.h"
+#endif /* __RTW_MESH_H_ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_hwmp.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_hwmp.c
new file mode 100644
index 000000000000..f838d1c508fa
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_hwmp.c
@@ -0,0 +1,1657 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HWMP_C_
+
+#ifdef CONFIG_RTW_MESH
+#include <drv_types.h>
+#include <hal_data.h>
+
+#define RTW_TEST_FRAME_LEN	8192
+#define RTW_MAX_METRIC	0xffffffff
+#define RTW_ARITH_SHIFT	8
+#define RTW_LINK_FAIL_THRESH 95
+#define RTW_MAX_PREQ_QUEUE_LEN	64
+#define RTW_ATLM_REQ_CYCLE 1000
+
+#define rtw_ilog2(n)			\
+(					\
+	(n) < 2 ? 0 :			\
+	(n) & (1ULL << 63) ? 63 :	\
+	(n) & (1ULL << 62) ? 62 :	\
+	(n) & (1ULL << 61) ? 61 :	\
+	(n) & (1ULL << 60) ? 60 :	\
+	(n) & (1ULL << 59) ? 59 :	\
+	(n) & (1ULL << 58) ? 58 :	\
+	(n) & (1ULL << 57) ? 57 :	\
+	(n) & (1ULL << 56) ? 56 :	\
+	(n) & (1ULL << 55) ? 55 :	\
+	(n) & (1ULL << 54) ? 54 :	\
+	(n) & (1ULL << 53) ? 53 :	\
+	(n) & (1ULL << 52) ? 52 :	\
+	(n) & (1ULL << 51) ? 51 :	\
+	(n) & (1ULL << 50) ? 50 :	\
+	(n) & (1ULL << 49) ? 49 :	\
+	(n) & (1ULL << 48) ? 48 :	\
+	(n) & (1ULL << 47) ? 47 :	\
+	(n) & (1ULL << 46) ? 46 :	\
+	(n) & (1ULL << 45) ? 45 :	\
+	(n) & (1ULL << 44) ? 44 :	\
+	(n) & (1ULL << 43) ? 43 :	\
+	(n) & (1ULL << 42) ? 42 :	\
+	(n) & (1ULL << 41) ? 41 :	\
+	(n) & (1ULL << 40) ? 40 :	\
+	(n) & (1ULL << 39) ? 39 :	\
+	(n) & (1ULL << 38) ? 38 :	\
+	(n) & (1ULL << 37) ? 37 :	\
+	(n) & (1ULL << 36) ? 36 :	\
+	(n) & (1ULL << 35) ? 35 :	\
+	(n) & (1ULL << 34) ? 34 :	\
+	(n) & (1ULL << 33) ? 33 :	\
+	(n) & (1ULL << 32) ? 32 :	\
+	(n) & (1ULL << 31) ? 31 :	\
+	(n) & (1ULL << 30) ? 30 :	\
+	(n) & (1ULL << 29) ? 29 :	\
+	(n) & (1ULL << 28) ? 28 :	\
+	(n) & (1ULL << 27) ? 27 :	\
+	(n) & (1ULL << 26) ? 26 :	\
+	(n) & (1ULL << 25) ? 25 :	\
+	(n) & (1ULL << 24) ? 24 :	\
+	(n) & (1ULL << 23) ? 23 :	\
+	(n) & (1ULL << 22) ? 22 :	\
+	(n) & (1ULL << 21) ? 21 :	\
+	(n) & (1ULL << 20) ? 20 :	\
+	(n) & (1ULL << 19) ? 19 :	\
+	(n) & (1ULL << 18) ? 18 :	\
+	(n) & (1ULL << 17) ? 17 :	\
+	(n) & (1ULL << 16) ? 16 :	\
+	(n) & (1ULL << 15) ? 15 :	\
+	(n) & (1ULL << 14) ? 14 :	\
+	(n) & (1ULL << 13) ? 13 :	\
+	(n) & (1ULL << 12) ? 12 :	\
+	(n) & (1ULL << 11) ? 11 :	\
+	(n) & (1ULL << 10) ? 10 :	\
+	(n) & (1ULL <<  9) ?  9 :	\
+	(n) & (1ULL <<  8) ?  8 :	\
+	(n) & (1ULL <<  7) ?  7 :	\
+	(n) & (1ULL <<  6) ?  6 :	\
+	(n) & (1ULL <<  5) ?  5 :	\
+	(n) & (1ULL <<  4) ?  4 :	\
+	(n) & (1ULL <<  3) ?  3 :	\
+	(n) & (1ULL <<  2) ?  2 :	\
+	1				\
+)
+
+enum rtw_mpath_frame_type {
+	RTW_MPATH_PREQ = 0,
+	RTW_MPATH_PREP,
+	RTW_MPATH_PERR,
+	RTW_MPATH_RANN
+};
+
+static inline u32 rtw_u32_field_get(const u8 *preq_elem, int shift, BOOLEAN ae)
+{
+	if (ae)
+		shift += 6;
+	return LE_BITS_TO_4BYTE(preq_elem + shift, 0, 32);
+}
+
+static inline u16 rtw_u16_field_get(const u8 *preq_elem, int shift, BOOLEAN ae)
+{
+	if (ae)
+		shift += 6;
+	return LE_BITS_TO_2BYTE(preq_elem + shift, 0, 16);
+}
+
+/* HWMP IE processing macros */
+#define RTW_AE_F			(1<<6)
+#define RTW_AE_F_SET(x)			(*x & RTW_AE_F)
+#define RTW_PREQ_IE_FLAGS(x)		(*(x))
+#define RTW_PREQ_IE_HOPCOUNT(x)		(*(x + 1))
+#define RTW_PREQ_IE_TTL(x)		(*(x + 2))
+#define RTW_PREQ_IE_PREQ_ID(x)		rtw_u32_field_get(x, 3, 0)
+#define RTW_PREQ_IE_ORIG_ADDR(x)	(x + 7)
+#define RTW_PREQ_IE_ORIG_SN(x)		rtw_u32_field_get(x, 13, 0)
+#define RTW_PREQ_IE_LIFETIME(x)		rtw_u32_field_get(x, 17, RTW_AE_F_SET(x))
+#define RTW_PREQ_IE_METRIC(x) 		rtw_u32_field_get(x, 21, RTW_AE_F_SET(x))
+#define RTW_PREQ_IE_TARGET_F(x)		(*(RTW_AE_F_SET(x) ? x + 32 : x + 26))
+#define RTW_PREQ_IE_TARGET_ADDR(x) 	(RTW_AE_F_SET(x) ? x + 33 : x + 27)
+#define RTW_PREQ_IE_TARGET_SN(x) 	rtw_u32_field_get(x, 33, RTW_AE_F_SET(x))
+
+#define RTW_PREP_IE_FLAGS(x)		RTW_PREQ_IE_FLAGS(x)
+#define RTW_PREP_IE_HOPCOUNT(x)		RTW_PREQ_IE_HOPCOUNT(x)
+#define RTW_PREP_IE_TTL(x)		RTW_PREQ_IE_TTL(x)
+#define RTW_PREP_IE_ORIG_ADDR(x)	(RTW_AE_F_SET(x) ? x + 27 : x + 21)
+#define RTW_PREP_IE_ORIG_SN(x)		rtw_u32_field_get(x, 27, RTW_AE_F_SET(x))
+#define RTW_PREP_IE_LIFETIME(x)		rtw_u32_field_get(x, 13, RTW_AE_F_SET(x))
+#define RTW_PREP_IE_METRIC(x)		rtw_u32_field_get(x, 17, RTW_AE_F_SET(x))
+#define RTW_PREP_IE_TARGET_ADDR(x)	(x + 3)
+#define RTW_PREP_IE_TARGET_SN(x)	rtw_u32_field_get(x, 9, 0)
+
+#define RTW_PERR_IE_TTL(x)		(*(x))
+#define RTW_PERR_IE_TARGET_FLAGS(x)	(*(x + 2))
+#define RTW_PERR_IE_TARGET_ADDR(x)	(x + 3)
+#define RTW_PERR_IE_TARGET_SN(x)	rtw_u32_field_get(x, 9, 0)
+#define RTW_PERR_IE_TARGET_RCODE(x)	rtw_u16_field_get(x, 13, 0)
+
+#define RTW_TU_TO_SYSTIME(x)	(rtw_us_to_systime((x) * 1024))
+#define RTW_TU_TO_EXP_TIME(x)	(rtw_get_current_time() + RTW_TU_TO_SYSTIME(x))
+#define RTW_MSEC_TO_TU(x) (x*1000/1024)
+#define RTW_SN_GT(x, y) ((s32)(y - x) < 0)
+#define RTW_SN_LT(x, y) ((s32)(x - y) < 0)
+#define RTW_MAX_SANE_SN_DELTA 32
+
+static inline u32 RTW_SN_DELTA(u32 x, u32 y)
+{
+	return x >= y ? x - y : y - x;
+}
+
+#define rtw_net_traversal_jiffies(adapter) \
+	rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPnetDiameterTraversalTime)
+#define rtw_default_lifetime(adapter) \
+	RTW_MSEC_TO_TU(adapter->mesh_cfg.dot11MeshHWMPactivePathTimeout)
+#define rtw_min_preq_int_jiff(adapter) \
+	(rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPpreqMinInterval))
+#define rtw_max_preq_retries(adapter) (adapter->mesh_cfg.dot11MeshHWMPmaxPREQretries)
+#define rtw_disc_timeout_jiff(adapter) \
+	rtw_ms_to_systime(adapter->mesh_cfg.min_discovery_timeout)
+#define rtw_root_path_confirmation_jiffies(adapter) \
+	rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPconfirmationInterval)
+
+static inline BOOLEAN rtw_ether_addr_equal(const u8 *addr1, const u8 *addr2)
+{
+	return _rtw_memcmp(addr1, addr2, ETH_ALEN);
+}
+
+#ifdef PLATFORM_LINUX
+#define rtw_print_ratelimit()	printk_ratelimit()
+#define rtw_mod_timer(ptimer, expires) mod_timer(&(ptimer)->timer, expires)
+#else
+
+#endif
+
+#define RTW_MESH_EWMA_PRECISION 20
+#define RTW_MESH_EWMA_WEIGHT_RCP 8
+#define RTW_TOTAL_PKT_MIN_THRESHOLD 1
+inline void rtw_ewma_err_rate_init(struct rtw_ewma_err_rate *e)
+{
+	e->internal = 0;
+}
+inline unsigned long rtw_ewma_err_rate_read(struct rtw_ewma_err_rate *e)
+{
+	return e->internal >> (RTW_MESH_EWMA_PRECISION);
+}
+inline void rtw_ewma_err_rate_add(struct rtw_ewma_err_rate *e,
+				  unsigned long val)
+{
+	unsigned long internal = e->internal;
+	unsigned long weight_rcp = rtw_ilog2(RTW_MESH_EWMA_WEIGHT_RCP);
+	unsigned long precision = RTW_MESH_EWMA_PRECISION;
+
+	(e->internal) = internal ? (((internal << weight_rcp) - internal) +
+			(val << precision)) >> weight_rcp :
+			(val << precision);
+}
+
+static const u8 bcast_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+static int rtw_mesh_path_sel_frame_tx(enum rtw_mpath_frame_type mpath_action, u8 flags,
+				      const u8 *originator_addr, u32 originator_sn,
+				      u8 target_flags, const u8 *target,
+				      u32 target_sn, const u8 *da, u8 hopcount, u8 ttl,
+				      u32 lifetime, u32 metric, u32 preq_id, 
+				      _adapter *adapter)
+{
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct xmit_frame *pmgntframe = NULL;
+	struct rtw_ieee80211_hdr *pwlanhdr = NULL;
+	struct pkt_attrib *pattrib = NULL;
+	u8 category = RTW_WLAN_CATEGORY_MESH;
+	u8 action = RTW_ACT_MESH_HWMP_PATH_SELECTION;
+	u16 *fctrl = NULL;
+	u8 *pos, ie_len;
+
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return -1;
+
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pos = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pos;
+
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pos, WIFI_ACTION);
+
+	pos += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	pos = rtw_set_fixed_ie(pos, 1, &(category), &(pattrib->pktlen));
+	pos = rtw_set_fixed_ie(pos, 1, &(action), &(pattrib->pktlen));
+
+	switch (mpath_action) {
+	case RTW_MPATH_PREQ:
+		RTW_HWMP_DBG("sending PREQ to "MAC_FMT"\n", MAC_ARG(target));
+		ie_len = 37;
+		pattrib->pktlen += (ie_len + 2);
+		*pos++ = WLAN_EID_PREQ;
+		break;
+	case RTW_MPATH_PREP:
+		RTW_HWMP_DBG("sending PREP to "MAC_FMT"\n", MAC_ARG(originator_addr));
+		ie_len = 31;
+		pattrib->pktlen += (ie_len + 2);
+		*pos++ = WLAN_EID_PREP;
+		break;
+	case RTW_MPATH_RANN:
+		RTW_HWMP_DBG("sending RANN from "MAC_FMT"\n", MAC_ARG(originator_addr));
+		ie_len = sizeof(struct rtw_ieee80211_rann_ie);
+		pattrib->pktlen += (ie_len + 2);
+		*pos++ = WLAN_EID_RANN;
+		break;
+	default:
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		return _FAIL;
+	}
+	*pos++ = ie_len;
+	*pos++ = flags;
+	*pos++ = hopcount;
+	*pos++ = ttl;
+	if (mpath_action == RTW_MPATH_PREP) {
+		_rtw_memcpy(pos, target, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(target_sn);
+		pos += 4;
+	} else {
+		if (mpath_action == RTW_MPATH_PREQ) {
+			*(u32 *)pos = cpu_to_le32(preq_id);
+			pos += 4;
+		}
+		_rtw_memcpy(pos, originator_addr, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(originator_sn);
+		pos += 4;
+	}
+	*(u32 *)pos = cpu_to_le32(lifetime);
+	pos += 4;
+	*(u32 *)pos = cpu_to_le32(metric);
+	pos += 4;
+	if (mpath_action == RTW_MPATH_PREQ) {
+		*pos++ = 1; /* support only 1 destination now */
+		*pos++ = target_flags;
+		_rtw_memcpy(pos, target, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(target_sn);
+		pos += 4;
+	} else if (mpath_action == RTW_MPATH_PREP) {
+		_rtw_memcpy(pos, originator_addr, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(originator_sn);
+		pos += 4;
+	}
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	dump_mgntframe(adapter, pmgntframe);
+	return 0;
+}
+
+int rtw_mesh_path_error_tx(_adapter *adapter,
+			   u8 ttl, const u8 *target, u32 target_sn,
+			   u16 perr_reason_code, const u8 *ra)
+{
+
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct xmit_frame *pmgntframe = NULL;
+	struct rtw_ieee80211_hdr *pwlanhdr = NULL;
+	struct pkt_attrib *pattrib = NULL;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u8 category = RTW_WLAN_CATEGORY_MESH;
+	u8 action = RTW_ACT_MESH_HWMP_PATH_SELECTION;
+	u8 *pos, ie_len;
+	u16 *fctrl = NULL;
+
+	if (rtw_time_before(rtw_get_current_time(), minfo->next_perr))
+		return -1;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return -1;
+
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pos = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pos;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pos, WIFI_ACTION);
+
+	pos += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	pos = rtw_set_fixed_ie(pos, 1, &(category), &(pattrib->pktlen));
+	pos = rtw_set_fixed_ie(pos, 1, &(action), &(pattrib->pktlen));
+
+	ie_len = 15;
+	pattrib->pktlen += (2 + ie_len);
+	*pos++ = WLAN_EID_PERR;
+	*pos++ = ie_len;
+	/* ttl */
+	*pos++ = ttl;
+	/* The Number of Destinations N */
+	*pos++ = 1;
+	/* Flags format | B7 | B6 | B5:B0 | = | rsvd | AE | rsvd | */
+	*pos = 0;
+	pos++;
+	_rtw_memcpy(pos, target, ETH_ALEN);
+	pos += ETH_ALEN;
+	*(u32 *)pos = cpu_to_le32(target_sn);
+	pos += 4;
+	*(u16 *)pos = cpu_to_le16(perr_reason_code);
+
+	adapter->mesh_info.next_perr = RTW_TU_TO_EXP_TIME(
+				adapter->mesh_cfg.dot11MeshHWMPperrMinInterval);
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	/* Send directly. Rewrite it if deferred tx is needed */
+	dump_mgntframe(adapter, pmgntframe);
+
+	RTW_HWMP_DBG("TX PERR toward "MAC_FMT", ra = "MAC_FMT"\n", MAC_ARG(target), MAC_ARG(ra));
+	
+	return 0;
+}
+
+static u32 rtw_get_vht_bitrate(u8 mcs, u8 bw, u8 nss, u8 sgi)
+{
+	static const u32 base[4][10] = {
+		{   6500000,
+		   13000000,
+		   19500000,
+		   26000000,
+		   39000000,
+		   52000000,
+		   58500000,
+		   65000000,
+		   78000000,
+		/* not in the spec, but some devices use this: */
+		   86500000,
+		},
+		{  13500000,
+		   27000000,
+		   40500000,
+		   54000000,
+		   81000000,
+		  108000000,
+		  121500000,
+		  135000000,
+		  162000000,
+		  180000000,
+		},
+		{  29300000,
+		   58500000,
+		   87800000,
+		  117000000,
+		  175500000,
+		  234000000,
+		  263300000,
+		  292500000,
+		  351000000,
+		  390000000,
+		},
+		{  58500000,
+		  117000000,
+		  175500000,
+		  234000000,
+		  351000000,
+		  468000000,
+		  526500000,
+		  585000000,
+		  702000000,
+		  780000000,
+		},
+	};
+	u32 bitrate;
+	int bw_idx;
+
+	if (mcs > 9) {
+		RTW_HWMP_INFO("Invalid mcs = %d\n", mcs);
+		return 0;
+	}
+
+	if (nss > 4 || nss < 1) {
+		RTW_HWMP_INFO("Now only support nss = 1, 2, 3, 4\n");
+	}
+
+	switch (bw) {
+	case CHANNEL_WIDTH_160:
+		bw_idx = 3;
+		break;
+	case CHANNEL_WIDTH_80:
+		bw_idx = 2;
+		break;
+	case CHANNEL_WIDTH_40:
+		bw_idx = 1;
+		break;
+	case CHANNEL_WIDTH_20:
+		bw_idx = 0;
+		break;
+	default:
+		RTW_HWMP_INFO("bw = %d currently not supported\n", bw);
+		return 0;
+	}
+
+	bitrate = base[bw_idx][mcs];
+	bitrate *= nss;
+
+	if (sgi)
+		bitrate = (bitrate / 9) * 10;
+
+	/* do NOT round down here */
+	return (bitrate + 50000) / 100000;
+}
+
+static u32 rtw_get_ht_bitrate(u8 mcs, u8 bw, u8 sgi)
+{
+	int modulation, streams, bitrate;
+
+	/* the formula below does only work for MCS values smaller than 32 */
+	if (mcs >= 32) {
+		RTW_HWMP_INFO("Invalid mcs = %d\n", mcs);
+		return 0;
+	}
+
+	if (bw > 1) {
+		RTW_HWMP_INFO("Now HT only support bw = 0(20Mhz), 1(40Mhz)\n");
+		return 0;
+	}
+
+	modulation = mcs & 7;
+	streams = (mcs >> 3) + 1;
+
+	bitrate = (bw == 1) ? 13500000 : 6500000;
+
+	if (modulation < 4)
+		bitrate *= (modulation + 1);
+	else if (modulation == 4)
+		bitrate *= (modulation + 2);
+	else
+		bitrate *= (modulation + 3);
+
+	bitrate *= streams;
+
+	if (sgi)
+		bitrate = (bitrate / 9) * 10;
+
+	/* do NOT round down here */
+	return (bitrate + 50000) / 100000;
+}
+
+/**
+ * @bw: 0(20Mhz), 1(40Mhz), 2(80Mhz), 3(160Mhz)
+ * @rate_idx: DESC_RATEXXXX & 0x7f
+ * @sgi: DESC_RATEXXXX >> 7
+ * Returns: bitrate in 100kbps
+ */
+static u32 rtw_desc_rate_to_bitrate(u8 bw, u8 rate_idx, u8 sgi)
+{
+	u32 bitrate;
+
+	if (rate_idx <= DESC_RATE54M){
+		u16 ofdm_rate[12] = {10, 20, 55, 110,
+			60, 90, 120, 180, 240, 360, 480, 540};
+		bitrate = ofdm_rate[rate_idx];
+	} else if ((DESC_RATEMCS0 <= rate_idx) &&
+		   (rate_idx <= DESC_RATEMCS31)) {
+		u8 mcs = rate_idx - DESC_RATEMCS0;
+		bitrate = rtw_get_ht_bitrate(mcs, bw, sgi);
+	} else if ((DESC_RATEVHTSS1MCS0 <= rate_idx) &&
+		   (rate_idx <= DESC_RATEVHTSS4MCS9)) {
+		u8 mcs = (rate_idx - DESC_RATEVHTSS1MCS0) % 10;
+		u8 nss = ((rate_idx - DESC_RATEVHTSS1MCS0) / 10) + 1;
+		bitrate = rtw_get_vht_bitrate(mcs, bw, nss, sgi);
+	} else {
+		/* 60Ghz ??? */
+		bitrate = 1;
+	}
+
+	return bitrate;
+}
+
+static u32 rtw_airtime_link_metric_get(_adapter *adapter, struct sta_info *sta)
+{
+	struct dm_struct *dm = adapter_to_phydm(adapter);
+	int device_constant = phydm_get_plcp(dm, sta->cmn.mac_id) << RTW_ARITH_SHIFT;
+	u32 test_frame_len = RTW_TEST_FRAME_LEN << RTW_ARITH_SHIFT;
+	u32 s_unit = 1 << RTW_ARITH_SHIFT;
+	u32 err;
+	u16 rate;
+	u32 tx_time, estimated_retx;
+	u64 result;
+	/* The fail_avg should <= 100 here */
+	u32 fail_avg = (u32)rtw_ewma_err_rate_read(&sta->metrics.err_rate);
+
+	if (fail_avg > RTW_LINK_FAIL_THRESH)
+		return RTW_MAX_METRIC;
+
+	rate = sta->metrics.data_rate;
+	/* rate unit is 100Kbps, min rate = 10 */
+	if (rate < 10) {
+		RTW_HWMP_INFO("rate = %d\n", rate);
+		return RTW_MAX_METRIC;
+	}
+
+	err = (fail_avg << RTW_ARITH_SHIFT) / 100;
+
+	/* test_frame_len*10 to adjust the unit of rate(100kbps/unit) */
+	tx_time = (device_constant + 10 * test_frame_len / rate);
+	estimated_retx = ((1 << (2 * RTW_ARITH_SHIFT)) / (s_unit - err));
+	result = (tx_time * estimated_retx) >> (2 * RTW_ARITH_SHIFT);
+	/* Convert us to 0.01 TU(10.24us). x/10.24 = x*100/1024 */
+	result = (result * 100) >> 10;
+
+	return (u32)result;
+}
+
+void rtw_ieee80211s_update_metric(_adapter *adapter, u8 mac_id,
+				  u8 per, u8 rate,
+				  u8 bw, u8 total_pkt)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *sta;
+	u8 rate_idx;
+	u8 sgi;
+
+	sta = macid_ctl->sta[mac_id];
+	if (!sta)
+		return;
+
+	/* if RA, use reported rate */
+	if (adapter->fix_rate == 0xff) {
+		rate_idx = rate & 0x7f;
+		sgi = rate >> 7;
+	} else {
+		rate_idx = adapter->fix_rate & 0x7f;
+		sgi = adapter->fix_rate >> 7;
+	}
+	sta->metrics.data_rate = rtw_desc_rate_to_bitrate(bw, rate_idx, sgi);
+
+	if (total_pkt < RTW_TOTAL_PKT_MIN_THRESHOLD)
+		return;
+
+	/* TBD: sta->metrics.overhead = phydm_get_plcp(void *dm_void, u16 macid); */
+	sta->metrics.total_pkt = total_pkt;
+
+	rtw_ewma_err_rate_add(&sta->metrics.err_rate, per);
+	if (rtw_ewma_err_rate_read(&sta->metrics.err_rate) > 
+			RTW_LINK_FAIL_THRESH)
+		rtw_mesh_plink_broken(sta);
+}
+
+static void rtw_hwmp_preq_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const u8 *preq_elem, u32 originator_metric)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_path *path = NULL;
+	const u8 *target_addr, *originator_addr;
+	const u8 *da;
+	u8 target_flags, ttl, flags, to_gate_ask = 0;
+	u32 originator_sn, target_sn, lifetime, target_metric = 0;
+	BOOLEAN reply = _FALSE;
+	BOOLEAN forward = _TRUE;
+	BOOLEAN preq_is_gate;
+
+	/* Update target SN, if present */
+	target_addr = RTW_PREQ_IE_TARGET_ADDR(preq_elem);
+	originator_addr = RTW_PREQ_IE_ORIG_ADDR(preq_elem);
+	target_sn = RTW_PREQ_IE_TARGET_SN(preq_elem);
+	originator_sn = RTW_PREQ_IE_ORIG_SN(preq_elem);
+	target_flags = RTW_PREQ_IE_TARGET_F(preq_elem);
+	/* PREQ gate announcements */
+	flags = RTW_PREQ_IE_FLAGS(preq_elem);
+	preq_is_gate = !!(flags & RTW_IEEE80211_PREQ_IS_GATE_FLAG);
+
+	RTW_HWMP_DBG("received PREQ from "MAC_FMT"\n", MAC_ARG(originator_addr));
+
+	if (rtw_ether_addr_equal(target_addr, adapter_mac_addr(adapter))) {
+		RTW_HWMP_DBG("PREQ is for us\n");
+#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
+		rtw_rcu_read_lock();
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			if (preq_is_gate)
+				rtw_mesh_path_add_gate(path);
+			else if (path->is_gate) {
+				enter_critical_bh(&path->state_lock);
+				rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+				exit_critical_bh(&path->state_lock);
+			}
+		}
+		path = NULL;
+		rtw_rcu_read_unlock();
+#endif
+		forward = _FALSE;
+		reply = _TRUE;
+		to_gate_ask = 1;
+		target_metric = 0;
+		if (rtw_time_after(rtw_get_current_time(), minfo->last_sn_update +
+					rtw_net_traversal_jiffies(adapter)) ||
+		    rtw_time_before(rtw_get_current_time(), minfo->last_sn_update)) {
+			++minfo->sn;
+			minfo->last_sn_update = rtw_get_current_time();
+		}
+		target_sn = minfo->sn;
+	} else if (is_broadcast_mac_addr(target_addr) &&
+		   (target_flags & RTW_IEEE80211_PREQ_TO_FLAG)) {
+		rtw_rcu_read_lock();
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			if (flags & RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG) {
+				reply = _TRUE;
+				target_addr = adapter_mac_addr(adapter);
+				target_sn = ++minfo->sn;
+				target_metric = 0;
+				minfo->last_sn_update = rtw_get_current_time();
+			}
+
+			if (preq_is_gate) {
+				lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
+				path->gate_ann_int = lifetime;
+				path->gate_asked = false;
+				rtw_mesh_path_add_gate(path);
+			} else if (path->is_gate) {
+				enter_critical_bh(&path->state_lock);
+				rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+				exit_critical_bh(&path->state_lock);
+			}
+		}
+		rtw_rcu_read_unlock();
+	} else {
+		rtw_rcu_read_lock();
+#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			if (preq_is_gate)
+				rtw_mesh_path_add_gate(path);
+			else if (path->is_gate) {
+				enter_critical_bh(&path->state_lock);
+				rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+				exit_critical_bh(&path->state_lock);
+			}
+		}
+		path = NULL;
+#endif
+		path = rtw_mesh_path_lookup(adapter, target_addr);
+		if (path) {
+			if ((!(path->flags & RTW_MESH_PATH_SN_VALID)) ||
+					RTW_SN_LT(path->sn, target_sn)) {
+				path->sn = target_sn;
+				path->flags |= RTW_MESH_PATH_SN_VALID;
+			} else if ((!(target_flags & RTW_IEEE80211_PREQ_TO_FLAG)) &&
+					(path->flags & RTW_MESH_PATH_ACTIVE)) {
+				reply = _TRUE;
+				target_metric = path->metric;
+				target_sn = path->sn;
+				/* Case E2 of sec 13.10.9.3 IEEE 802.11-2012*/
+				target_flags |= RTW_IEEE80211_PREQ_TO_FLAG;
+			}
+		}
+		rtw_rcu_read_unlock();
+	}
+
+	if (reply) {
+		lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
+		ttl = mshcfg->element_ttl;
+		if (ttl != 0 && !to_gate_ask) {
+			RTW_HWMP_DBG("replying to the PREQ\n");
+			rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, 0, originator_addr,
+						   originator_sn, 0, target_addr,
+						   target_sn, mgmt->addr2, 0, ttl,
+						   lifetime, target_metric, 0,
+						   adapter);
+		} else if (ttl != 0 && to_gate_ask) {
+			RTW_HWMP_DBG("replying to the PREQ (PREQ for us)\n");
+			if (mshcfg->dot11MeshGateAnnouncementProtocol) {
+				/* BIT 7 is used to identify the prep is from mesh gate */
+				to_gate_ask = RTW_IEEE80211_PREQ_IS_GATE_FLAG | BIT(7);
+			} else {
+				to_gate_ask = 0;
+			}
+
+			rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, to_gate_ask, originator_addr,
+						   originator_sn, 0, target_addr,
+						   target_sn, mgmt->addr2, 0, ttl,
+						   lifetime, target_metric, 0,
+						   adapter);
+		} else {
+			minfo->mshstats.dropped_frames_ttl++;
+		}
+	}
+
+	if (forward && mshcfg->dot11MeshForwarding) {
+		u32 preq_id;
+		u8 hopcount;
+
+		ttl = RTW_PREQ_IE_TTL(preq_elem);
+		lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
+		if (ttl <= 1) {
+			minfo->mshstats.dropped_frames_ttl++;
+			return;
+		}
+		RTW_HWMP_DBG("forwarding the PREQ from "MAC_FMT"\n", MAC_ARG(originator_addr));
+		--ttl;
+		preq_id = RTW_PREQ_IE_PREQ_ID(preq_elem);
+		hopcount = RTW_PREQ_IE_HOPCOUNT(preq_elem) + 1;
+		da = (path && path->is_root) ?
+			path->rann_snd_addr : bcast_addr;
+
+		if (flags & RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG) {
+			target_addr = RTW_PREQ_IE_TARGET_ADDR(preq_elem);
+			target_sn = RTW_PREQ_IE_TARGET_SN(preq_elem);
+		}
+
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, originator_addr,
+					   originator_sn, target_flags, target_addr,
+					   target_sn, da, hopcount, ttl, lifetime,
+					   originator_metric, preq_id, adapter);
+		if (!is_multicast_mac_addr(da))
+			minfo->mshstats.fwded_unicast++;
+		else
+			minfo->mshstats.fwded_mcast++;
+		minfo->mshstats.fwded_frames++;
+	}
+}
+
+static inline struct sta_info *
+rtw_next_hop_deref_protected(struct rtw_mesh_path *path)
+{
+	return rtw_rcu_dereference_protected(path->next_hop,
+					 rtw_lockdep_is_held(&path->state_lock));
+}
+
+static void rtw_hwmp_prep_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const u8 *prep_elem, u32 metric)
+{
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
+	struct rtw_mesh_path *path;
+	const u8 *target_addr, *originator_addr;
+	u8 ttl, hopcount, flags;
+	u8 next_hop[ETH_ALEN];
+	u32 target_sn, originator_sn, lifetime;
+
+	RTW_HWMP_DBG("received PREP from "MAC_FMT"\n",
+		  MAC_ARG(RTW_PREP_IE_TARGET_ADDR(prep_elem)));
+
+	originator_addr = RTW_PREP_IE_ORIG_ADDR(prep_elem);
+	if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter))) {
+		/* destination, no forwarding required */
+		rtw_rcu_read_lock();
+		target_addr = RTW_PREP_IE_TARGET_ADDR(prep_elem);
+		path = rtw_mesh_path_lookup(adapter, target_addr);
+		if (path && path->gate_asked) {
+			flags = RTW_PREP_IE_FLAGS(prep_elem);
+			if (flags & BIT(7)) {
+				enter_critical_bh(&path->state_lock);
+				path->gate_asked = false;
+				exit_critical_bh(&path->state_lock);
+				if (!(flags & RTW_IEEE80211_PREQ_IS_GATE_FLAG)) {
+					enter_critical_bh(&path->state_lock);
+					rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+					exit_critical_bh(&path->state_lock);
+				}
+			}
+		}
+
+		rtw_rcu_read_unlock();
+		return;
+	}
+
+	if (!mshcfg->dot11MeshForwarding)
+		return;
+
+	ttl = RTW_PREP_IE_TTL(prep_elem);
+	if (ttl <= 1) {
+		mshstats->dropped_frames_ttl++;
+		return;
+	}
+
+	rtw_rcu_read_lock();
+	path = rtw_mesh_path_lookup(adapter, originator_addr);
+	if (path)
+		enter_critical_bh(&path->state_lock);
+	else
+		goto fail;
+	if (!(path->flags & RTW_MESH_PATH_ACTIVE)) {
+		exit_critical_bh(&path->state_lock);
+		goto fail;
+	}
+	_rtw_memcpy(next_hop, rtw_next_hop_deref_protected(path)->cmn.mac_addr, ETH_ALEN);
+	exit_critical_bh(&path->state_lock);
+	--ttl;
+	flags = RTW_PREP_IE_FLAGS(prep_elem);
+	lifetime = RTW_PREP_IE_LIFETIME(prep_elem);
+	hopcount = RTW_PREP_IE_HOPCOUNT(prep_elem) + 1;
+	target_addr = RTW_PREP_IE_TARGET_ADDR(prep_elem);
+	target_sn = RTW_PREP_IE_TARGET_SN(prep_elem);
+	originator_sn = RTW_PREP_IE_ORIG_SN(prep_elem);
+
+	rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, flags, originator_addr, originator_sn, 0,
+				   target_addr, target_sn, next_hop, hopcount,
+				   ttl, lifetime, metric, 0, adapter);
+	rtw_rcu_read_unlock();
+
+	mshstats->fwded_unicast++;
+	mshstats->fwded_frames++;
+	return;
+
+fail:
+	rtw_rcu_read_unlock();
+	mshstats->dropped_frames_no_route++;
+}
+
+static void rtw_hwmp_perr_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const u8 *perr_elem)
+{
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
+	struct rtw_mesh_path *path;
+	u8 ttl;
+	const u8 *ta, *target_addr;
+	u32 target_sn;
+	u16 perr_reason_code;
+
+	ta = mgmt->addr2;
+	ttl = RTW_PERR_IE_TTL(perr_elem);
+	if (ttl <= 1) {
+		mshstats->dropped_frames_ttl++;
+		return;
+	}
+	ttl--;
+	target_addr = RTW_PERR_IE_TARGET_ADDR(perr_elem);
+	target_sn = RTW_PERR_IE_TARGET_SN(perr_elem);
+	perr_reason_code = RTW_PERR_IE_TARGET_RCODE(perr_elem);
+
+	RTW_HWMP_DBG("received PERR toward target "MAC_FMT"\n", MAC_ARG(target_addr));
+
+	rtw_rcu_read_lock();
+	path = rtw_mesh_path_lookup(adapter, target_addr);
+	if (path) {
+		struct sta_info *sta;
+
+		enter_critical_bh(&path->state_lock);
+		sta = rtw_next_hop_deref_protected(path);
+		if (path->flags & RTW_MESH_PATH_ACTIVE &&
+		    rtw_ether_addr_equal(ta, sta->cmn.mac_addr) &&
+		    !(path->flags & RTW_MESH_PATH_FIXED) &&
+		    (!(path->flags & RTW_MESH_PATH_SN_VALID) ||
+		    RTW_SN_GT(target_sn, path->sn)  || target_sn == 0)) {
+			path->flags &= ~RTW_MESH_PATH_ACTIVE;
+			if (target_sn != 0)
+				path->sn = target_sn;
+			else
+				path->sn += 1;
+			exit_critical_bh(&path->state_lock);
+			if (!mshcfg->dot11MeshForwarding)
+				goto endperr;
+			rtw_mesh_path_error_tx(adapter, ttl, target_addr,
+					       target_sn, perr_reason_code,
+					       bcast_addr);
+		} else
+			exit_critical_bh(&path->state_lock);
+	}
+endperr:
+	rtw_rcu_read_unlock();
+}
+
+static void rtw_hwmp_rann_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const struct rtw_ieee80211_rann_ie *rann)
+{
+	struct sta_info *sta;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
+	struct rtw_mesh_path *path;
+	u8 ttl, flags, hopcount;
+	const u8 *originator_addr;
+	u32 originator_sn, metric, metric_txsta, interval;
+	BOOLEAN root_is_gate;
+
+	ttl = rann->rann_ttl;
+	flags = rann->rann_flags;
+	root_is_gate = !!(flags & RTW_RANN_FLAG_IS_GATE);
+	originator_addr = rann->rann_addr;
+	originator_sn = le32_to_cpu(rann->rann_seq);
+	interval = le32_to_cpu(rann->rann_interval);
+	hopcount = rann->rann_hopcount;
+	hopcount++;
+	metric = le32_to_cpu(rann->rann_metric);
+
+	/*  Ignore our own RANNs */
+	if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter)))
+		return;
+
+	RTW_HWMP_DBG("received RANN from "MAC_FMT" via neighbour "MAC_FMT" (is_gate=%d)\n",
+		  MAC_ARG(originator_addr), MAC_ARG(mgmt->addr2), root_is_gate);
+
+	rtw_rcu_read_lock();
+	sta = rtw_get_stainfo(pstapriv, mgmt->addr2);
+	if (!sta) {
+		rtw_rcu_read_unlock();
+		return;
+	}
+
+	metric_txsta = rtw_airtime_link_metric_get(adapter, sta);
+
+	path = rtw_mesh_path_lookup(adapter, originator_addr);
+	if (!path) {
+		path = rtw_mesh_path_add(adapter, originator_addr);
+		if (IS_ERR(path)) {
+			rtw_rcu_read_unlock();
+			mshstats->dropped_frames_no_route++;
+			return;
+		}
+	}
+
+	if (!(RTW_SN_LT(path->sn, originator_sn)) &&
+	    !(path->sn == originator_sn && metric < path->rann_metric)) {
+		rtw_rcu_read_unlock();
+		return;
+	}
+
+	if ((!(path->flags & (RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVING)) ||
+	     (rtw_time_after(rtw_get_current_time(), path->last_preq_to_root +
+				  rtw_root_path_confirmation_jiffies(adapter)) ||
+	     rtw_time_before(rtw_get_current_time(), path->last_preq_to_root))) &&
+	     !(path->flags & RTW_MESH_PATH_FIXED) && (ttl != 0)) {
+		u8 preq_node_flag = RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH;
+
+		RTW_HWMP_DBG("time to refresh root path "MAC_FMT"\n",
+			  MAC_ARG(originator_addr));
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+		if (RTW_SN_LT(path->sn, originator_sn) &&
+		    (path->rann_metric + mshcfg->sane_metric_delta < metric) &&
+		    _rtw_memcmp(bcast_addr, path->rann_snd_addr, ETH_ALEN) == _FALSE) {
+			RTW_HWMP_DBG("Trigger additional check for root "
+				     "confirm PREQ. rann_snd_addr = "MAC_FMT
+				     "add_chk_rann_snd_addr= "MAC_FMT"\n",
+					MAC_ARG(mgmt->addr2),
+					MAC_ARG(path->rann_snd_addr));
+			_rtw_memcpy(path->add_chk_rann_snd_addr,
+				    path->rann_snd_addr, ETH_ALEN);
+			preq_node_flag |= RTW_PREQ_Q_F_CHK;
+			
+		}
+#endif
+		rtw_mesh_queue_preq(path, preq_node_flag);
+		path->last_preq_to_root = rtw_get_current_time();
+	}
+
+	path->sn = originator_sn;
+	path->rann_metric = metric + metric_txsta;
+	path->is_root = _TRUE;
+	/* Recording RANNs sender address to send individually
+	 * addressed PREQs destined for root mesh STA */
+	_rtw_memcpy(path->rann_snd_addr, mgmt->addr2, ETH_ALEN);
+
+	if (root_is_gate) {
+		path->gate_ann_int = interval;
+		path->gate_asked = false;
+		rtw_mesh_path_add_gate(path);
+	} else if (path->is_gate) {
+		enter_critical_bh(&path->state_lock);
+		rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+		exit_critical_bh(&path->state_lock);
+	}
+
+	if (ttl <= 1) {
+		mshstats->dropped_frames_ttl++;
+		rtw_rcu_read_unlock();
+		return;
+	}
+	ttl--;
+
+	if (mshcfg->dot11MeshForwarding) {
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_RANN, flags, originator_addr,
+					   originator_sn, 0, NULL, 0, bcast_addr,
+					   hopcount, ttl, interval,
+					   metric + metric_txsta, 0, adapter);
+	}
+
+	rtw_rcu_read_unlock();
+}
+
+static u32 rtw_hwmp_route_info_get(_adapter *adapter,
+				   struct rtw_ieee80211_hdr_3addr *mgmt,
+				   const u8 *hwmp_ie, enum rtw_mpath_frame_type action)
+{
+	struct rtw_mesh_path *path;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	BOOLEAN fresh_info;
+	const u8 *originator_addr, *ta;
+	u32 originator_sn, originator_metric;
+	unsigned long originator_lifetime, exp_time;
+	u32 last_hop_metric, new_metric;
+	BOOLEAN process = _TRUE;
+
+	rtw_rcu_read_lock();
+	sta = rtw_get_stainfo(pstapriv, mgmt->addr2);
+	if (!sta) {
+		rtw_rcu_read_unlock();
+		return 0;
+	}
+
+	last_hop_metric = rtw_airtime_link_metric_get(adapter, sta);
+	/* Update and check originator routing info */
+	fresh_info = _TRUE;
+
+	switch (action) {
+	case RTW_MPATH_PREQ:
+		originator_addr = RTW_PREQ_IE_ORIG_ADDR(hwmp_ie);
+		originator_sn = RTW_PREQ_IE_ORIG_SN(hwmp_ie);
+		originator_lifetime = RTW_PREQ_IE_LIFETIME(hwmp_ie);
+		originator_metric = RTW_PREQ_IE_METRIC(hwmp_ie);
+		break;
+	case RTW_MPATH_PREP:
+		/* Note: For coding, the naming is not consist with spec */
+		originator_addr = RTW_PREP_IE_TARGET_ADDR(hwmp_ie);
+		originator_sn = RTW_PREP_IE_TARGET_SN(hwmp_ie);
+		originator_lifetime = RTW_PREP_IE_LIFETIME(hwmp_ie);
+		originator_metric = RTW_PREP_IE_METRIC(hwmp_ie);
+		break;
+	default:
+		rtw_rcu_read_unlock();
+		return 0;
+	}
+	new_metric = originator_metric + last_hop_metric;
+	if (new_metric < originator_metric)
+		new_metric = RTW_MAX_METRIC;
+	exp_time = RTW_TU_TO_EXP_TIME(originator_lifetime);
+
+	if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter))) {
+		process = _FALSE;
+		fresh_info = _FALSE;
+	} else {
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			enter_critical_bh(&path->state_lock);
+			if (path->flags & RTW_MESH_PATH_FIXED)
+				fresh_info = _FALSE;
+			else if ((path->flags & RTW_MESH_PATH_ACTIVE) &&
+			    (path->flags & RTW_MESH_PATH_SN_VALID)) {
+				if (RTW_SN_GT(path->sn, originator_sn) ||
+				    (path->sn == originator_sn &&
+				     new_metric >= path->metric)) {
+					process = _FALSE;
+					fresh_info = _FALSE;
+				}
+			} else if (!(path->flags & RTW_MESH_PATH_ACTIVE)) {
+				BOOLEAN have_sn, newer_sn, bounced;
+
+				have_sn = path->flags & RTW_MESH_PATH_SN_VALID;
+				newer_sn = have_sn && RTW_SN_GT(originator_sn, path->sn);
+				bounced = have_sn &&
+					  (RTW_SN_DELTA(originator_sn, path->sn) >
+							RTW_MAX_SANE_SN_DELTA);
+
+				if (!have_sn || newer_sn) {
+				} else if (bounced) {
+				} else {
+					process = _FALSE;
+					fresh_info = _FALSE;
+				}
+			}
+		} else {
+			path = rtw_mesh_path_add(adapter, originator_addr);
+			if (IS_ERR(path)) {
+				rtw_rcu_read_unlock();
+				return 0;
+			}
+			enter_critical_bh(&path->state_lock);
+		}
+
+		if (fresh_info) {
+			rtw_mesh_path_assign_nexthop(path, sta);
+			path->flags |= RTW_MESH_PATH_SN_VALID;
+			path->metric = new_metric;
+			path->sn = originator_sn;
+			path->exp_time = rtw_time_after(path->exp_time, exp_time)
+					  ?  path->exp_time : exp_time;
+			rtw_mesh_path_activate(path);
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+			if (path->is_root && (action == RTW_MPATH_PREP)) {
+				_rtw_memcpy(path->rann_snd_addr, 
+				mgmt->addr2, ETH_ALEN);
+				path->rann_metric = new_metric;
+			}
+#endif
+			exit_critical_bh(&path->state_lock);
+			rtw_mesh_path_tx_pending(path);
+		} else
+			exit_critical_bh(&path->state_lock);
+	}
+
+	/* Update and check transmitter routing info */
+	ta = mgmt->addr2;
+	if (rtw_ether_addr_equal(originator_addr, ta))
+		fresh_info = _FALSE;
+	else {
+		fresh_info = _TRUE;
+
+		path = rtw_mesh_path_lookup(adapter, ta);
+		if (path) {
+			enter_critical_bh(&path->state_lock);
+			if ((path->flags & RTW_MESH_PATH_FIXED) ||
+				((path->flags & RTW_MESH_PATH_ACTIVE) &&
+					(last_hop_metric > path->metric)))
+				fresh_info = _FALSE;
+		} else {
+			path = rtw_mesh_path_add(adapter, ta);
+			if (IS_ERR(path)) {
+				rtw_rcu_read_unlock();
+				return 0;
+			}
+			enter_critical_bh(&path->state_lock);
+		}
+
+		if (fresh_info) {
+			rtw_mesh_path_assign_nexthop(path, sta);
+			path->metric = last_hop_metric;
+			path->exp_time = rtw_time_after(path->exp_time, exp_time)
+					  ?  path->exp_time : exp_time;
+			rtw_mesh_path_activate(path);
+			exit_critical_bh(&path->state_lock);
+			rtw_mesh_path_tx_pending(path);
+		} else
+			exit_critical_bh(&path->state_lock);
+	}
+
+	rtw_rcu_read_unlock();
+
+	return process ? new_metric : 0;
+}
+
+static void rtw_mesh_rx_hwmp_frame_cnts(_adapter *adapter, u8 *addr)
+{
+	struct sta_info *sta;
+
+	sta = rtw_get_stainfo(&adapter->stapriv, addr);
+	if (sta)
+		sta->sta_stats.rx_hwmp_pkts++;
+}
+
+void rtw_mesh_rx_path_sel_frame(_adapter *adapter, union recv_frame *rframe)
+{
+	struct mesh_plink_ent *plink = NULL;
+	struct rtw_ieee802_11_elems elems;
+	u32 path_metric;
+	struct rx_pkt_attrib *attrib = &rframe->u.hdr.attrib;
+	u8 *pframe = rframe->u.hdr.rx_data, *start;
+	uint frame_len = rframe->u.hdr.len, left;
+	struct rtw_ieee80211_hdr_3addr *frame_hdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
+	u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+	ParseRes parse_res;
+
+	plink = rtw_mesh_plink_get(adapter, get_addr2_ptr(pframe));
+	if (!plink || plink->plink_state != RTW_MESH_PLINK_ESTAB)
+		return;
+
+	rtw_mesh_rx_hwmp_frame_cnts(adapter, get_addr2_ptr(pframe));
+
+	/* Mesh action frame IE offset = 2 */
+	attrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	left = frame_len - attrib->hdrlen - attrib->iv_len - attrib->icv_len - 2;
+	start = pframe + attrib->hdrlen + 2;
+
+	parse_res = rtw_ieee802_11_parse_elems(start, left, &elems, 1);
+	if (parse_res == ParseFailed)
+		RTW_HWMP_INFO(FUNC_ADPT_FMT" Path Select Frame ParseFailed\n"
+			, FUNC_ADPT_ARG(adapter));
+	else if (parse_res == ParseUnknown)
+		RTW_HWMP_INFO(FUNC_ADPT_FMT" Path Select Frame ParseUnknown\n"
+			, FUNC_ADPT_ARG(adapter));
+
+	if (elems.preq) {
+		if (elems.preq_len != 37)
+			/* Right now we support just 1 destination and no AE */
+			return;
+		path_metric = rtw_hwmp_route_info_get(adapter, frame_hdr, elems.preq,
+						  MPATH_PREQ);
+		if (path_metric)
+			rtw_hwmp_preq_frame_process(adapter, frame_hdr, elems.preq,
+						path_metric);
+	}
+	if (elems.prep) {
+		if (elems.prep_len != 31)
+			/* Right now we support no AE */
+			return;
+		path_metric = rtw_hwmp_route_info_get(adapter, frame_hdr, elems.prep,
+						  MPATH_PREP);
+		if (path_metric)
+			rtw_hwmp_prep_frame_process(adapter, frame_hdr, elems.prep,
+						path_metric);
+	}
+	if (elems.perr) {
+		if (elems.perr_len != 15)
+			/* Right now we support only one destination per PERR */
+			return;
+		rtw_hwmp_perr_frame_process(adapter, frame_hdr, elems.perr);
+	}
+	if (elems.rann)
+		rtw_hwmp_rann_frame_process(adapter, frame_hdr, (struct rtw_ieee80211_rann_ie *)elems.rann);
+}
+
+void rtw_mesh_queue_preq(struct rtw_mesh_path *path, u8 flags)
+{
+	_adapter *adapter = path->adapter;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_preq_queue *preq_node;
+
+	preq_node = rtw_malloc(sizeof(struct rtw_mesh_preq_queue));
+	if (!preq_node) {
+		RTW_HWMP_INFO("could not allocate PREQ node\n");
+		return;
+	}
+
+	enter_critical_bh(&minfo->mesh_preq_queue_lock);
+	if (minfo->preq_queue_len == RTW_MAX_PREQ_QUEUE_LEN) {
+		exit_critical_bh(&minfo->mesh_preq_queue_lock);
+		rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
+		if (rtw_print_ratelimit())
+			RTW_HWMP_INFO("PREQ node queue full\n");
+		return;
+	}
+
+	_rtw_spinlock(&path->state_lock);
+	if (path->flags & RTW_MESH_PATH_REQ_QUEUED) {
+		_rtw_spinunlock(&path->state_lock);
+		exit_critical_bh(&minfo->mesh_preq_queue_lock);
+		rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
+		return;
+	}
+
+	_rtw_memcpy(preq_node->dst, path->dst, ETH_ALEN);
+	preq_node->flags = flags;
+
+	path->flags |= RTW_MESH_PATH_REQ_QUEUED;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	if (flags & RTW_PREQ_Q_F_CHK)
+		path->flags |= RTW_MESH_PATH_ROOT_ADD_CHK;
+#endif
+	if (flags & RTW_PREQ_Q_F_PEER_AKA)
+		path->flags |= RTW_MESH_PATH_PEER_AKA;
+	_rtw_spinunlock(&path->state_lock);
+
+	rtw_list_insert_tail(&preq_node->list, &minfo->preq_queue.list);
+	++minfo->preq_queue_len;
+	exit_critical_bh(&minfo->mesh_preq_queue_lock);
+
+	if (rtw_time_after(rtw_get_current_time(), minfo->last_preq + rtw_min_preq_int_jiff(adapter)))
+		rtw_mesh_work(&adapter->mesh_work);
+
+	else if (rtw_time_before(rtw_get_current_time(), minfo->last_preq)) {
+		/* systime wrapped around issue */
+		minfo->last_preq = rtw_get_current_time() - rtw_min_preq_int_jiff(adapter) - 1;
+		rtw_mesh_work(&adapter->mesh_work);
+	} else
+		rtw_mod_timer(&adapter->mesh_path_timer, minfo->last_preq +
+						rtw_min_preq_int_jiff(adapter));
+}
+
+static const u8 *rtw_hwmp_preq_da(struct rtw_mesh_path *path,
+			    BOOLEAN is_root_add_chk, BOOLEAN da_is_peer)
+{
+	const u8 *da;
+
+	if (da_is_peer)
+		da = path->dst;
+	else if (path->is_root)
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+		da = is_root_add_chk ? path->add_chk_rann_snd_addr:
+				       path->rann_snd_addr;
+#else
+		da = path->rann_snd_addr;
+#endif
+	else
+		da = bcast_addr;
+
+	return da;
+}
+
+void rtw_mesh_path_start_discovery(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_preq_queue *preq_node;
+	struct rtw_mesh_path *path;
+	u8 ttl, target_flags = 0;
+	const u8 *da;
+	u32 lifetime;
+	u8 flags = 0;
+	BOOLEAN is_root_add_chk = _FALSE;
+	BOOLEAN da_is_peer;
+
+	enter_critical_bh(&minfo->mesh_preq_queue_lock);
+	if (!minfo->preq_queue_len ||
+		rtw_time_before(rtw_get_current_time(), minfo->last_preq +
+				rtw_min_preq_int_jiff(adapter))) {
+		exit_critical_bh(&minfo->mesh_preq_queue_lock);
+		return;
+	}
+
+	preq_node = rtw_list_first_entry(&minfo->preq_queue.list,
+			struct rtw_mesh_preq_queue, list);
+	rtw_list_delete(&preq_node->list); /* list_del_init(&preq_node->list); */
+	--minfo->preq_queue_len;
+	exit_critical_bh(&minfo->mesh_preq_queue_lock);
+
+	rtw_rcu_read_lock();
+	path = rtw_mesh_path_lookup(adapter, preq_node->dst);
+	if (!path)
+		goto enddiscovery;
+
+	enter_critical_bh(&path->state_lock);
+	if (path->flags & (RTW_MESH_PATH_DELETED | RTW_MESH_PATH_FIXED)) {
+		exit_critical_bh(&path->state_lock);
+		goto enddiscovery;
+	}
+	path->flags &= ~RTW_MESH_PATH_REQ_QUEUED;
+	if (preq_node->flags & RTW_PREQ_Q_F_START) {
+		if (path->flags & RTW_MESH_PATH_RESOLVING) {
+			exit_critical_bh(&path->state_lock);
+			goto enddiscovery;
+		} else {
+			path->flags &= ~RTW_MESH_PATH_RESOLVED;
+			path->flags |= RTW_MESH_PATH_RESOLVING;
+			path->discovery_retries = 0;
+			path->discovery_timeout = rtw_disc_timeout_jiff(adapter);
+		}
+	} else if (!(path->flags & RTW_MESH_PATH_RESOLVING) ||
+			path->flags & RTW_MESH_PATH_RESOLVED) {
+		path->flags &= ~RTW_MESH_PATH_RESOLVING;
+		exit_critical_bh(&path->state_lock);
+		goto enddiscovery;
+	}
+
+	minfo->last_preq = rtw_get_current_time();
+
+	if (rtw_time_after(rtw_get_current_time(), minfo->last_sn_update +
+				rtw_net_traversal_jiffies(adapter)) ||
+	    rtw_time_before(rtw_get_current_time(), minfo->last_sn_update)) {
+		++minfo->sn;
+		minfo->last_sn_update = rtw_get_current_time();
+	}
+	lifetime = rtw_default_lifetime(adapter);
+	ttl = mshcfg->element_ttl;
+	if (ttl == 0) {
+		minfo->mshstats.dropped_frames_ttl++;
+		exit_critical_bh(&path->state_lock);
+		goto enddiscovery;
+	}
+
+	if (preq_node->flags & RTW_PREQ_Q_F_REFRESH)
+		target_flags |= RTW_IEEE80211_PREQ_TO_FLAG;
+	else
+		target_flags &= ~RTW_IEEE80211_PREQ_TO_FLAG;
+
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	is_root_add_chk = !!(path->flags & RTW_MESH_PATH_ROOT_ADD_CHK);
+#endif
+	da_is_peer = !!(path->flags & RTW_MESH_PATH_PEER_AKA);
+	exit_critical_bh(&path->state_lock);
+
+	da = rtw_hwmp_preq_da(path, is_root_add_chk, da_is_peer);
+
+#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
+	flags = (mshcfg->dot11MeshGateAnnouncementProtocol)
+		? RTW_IEEE80211_PREQ_IS_GATE_FLAG : 0;
+#endif
+	rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, adapter_mac_addr(adapter), minfo->sn,
+				   target_flags, path->dst, path->sn, da, 0,
+				   ttl, lifetime, 0, minfo->preq_id++, adapter);
+	rtw_mod_timer(&path->timer, rtw_get_current_time() + path->discovery_timeout);
+
+enddiscovery:
+	rtw_rcu_read_unlock();
+	rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
+}
+
+void rtw_mesh_path_timer(void *ctx)
+{
+	struct rtw_mesh_path *path = (void *) ctx;
+	_adapter *adapter = path->adapter;
+	int ret;
+	u8 retry = 0;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+#endif
+	/* TBD: Proctect for suspend */
+#if 0
+	if (suspending)
+		return;
+#endif
+	enter_critical_bh(&path->state_lock);
+	if (path->flags & RTW_MESH_PATH_RESOLVED ||
+			(!(path->flags & RTW_MESH_PATH_RESOLVING))) {
+		path->flags &= ~(RTW_MESH_PATH_RESOLVING |
+				 RTW_MESH_PATH_RESOLVED |
+				 RTW_MESH_PATH_ROOT_ADD_CHK |
+				 RTW_MESH_PATH_PEER_AKA);
+		exit_critical_bh(&path->state_lock);
+	} else if (path->discovery_retries < rtw_max_preq_retries(adapter)) {
+		++path->discovery_retries;
+		path->discovery_timeout *= 2;
+		path->flags &= ~RTW_MESH_PATH_REQ_QUEUED;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+		if (path->discovery_retries > mshcfg->max_root_add_chk_cnt)
+			path->flags &= ~RTW_MESH_PATH_ROOT_ADD_CHK;
+#endif
+		if (path->gate_asked)
+			retry |= RTW_PREQ_Q_F_REFRESH;
+
+		exit_critical_bh(&path->state_lock);
+		rtw_mesh_queue_preq(path, retry);
+	} else {
+		path->flags &= ~(RTW_MESH_PATH_RESOLVING |
+				  RTW_MESH_PATH_RESOLVED |
+				  RTW_MESH_PATH_REQ_QUEUED |
+				  RTW_MESH_PATH_ROOT_ADD_CHK |
+				  RTW_MESH_PATH_PEER_AKA);
+		path->exp_time = rtw_get_current_time();
+		exit_critical_bh(&path->state_lock);
+		if (!path->is_gate && rtw_mesh_gate_num(adapter) > 0) {
+			ret = rtw_mesh_path_send_to_gates(path);
+			if (ret)
+				RTW_HWMP_DBG("no gate was reachable\n");
+		} else
+			rtw_mesh_path_flush_pending(path);
+	}
+}
+
+
+void rtw_mesh_path_tx_root_frame(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u32 interval = mshcfg->dot11MeshHWMPRannInterval;
+	u8 flags, target_flags = 0;
+
+	flags = (mshcfg->dot11MeshGateAnnouncementProtocol)
+			? RTW_RANN_FLAG_IS_GATE : 0;
+
+	switch (mshcfg->dot11MeshHWMPRootMode) {
+	case RTW_IEEE80211_PROACTIVE_RANN:
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_RANN, flags, adapter_mac_addr(adapter),
+					   ++minfo->sn, 0, NULL, 0, bcast_addr,
+					   0, mshcfg->element_ttl,
+					   interval, 0, 0, adapter);
+		break;
+	case RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP:
+		flags |= RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG;
+	case RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP:
+		interval = mshcfg->dot11MeshHWMPactivePathToRootTimeout;
+		target_flags |= RTW_IEEE80211_PREQ_TO_FLAG |
+				RTW_IEEE80211_PREQ_USN_FLAG;
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, adapter_mac_addr(adapter),
+					   ++minfo->sn, target_flags,
+					   (u8 *) bcast_addr, 0, bcast_addr,
+					   0, mshcfg->element_ttl, interval,
+					   0, minfo->preq_id++, adapter);
+		break;
+	default:
+		RTW_HWMP_INFO("Proactive mechanism not supported\n");
+		return;
+	}
+}
+
+void rtw_mesh_work(_workitem *work)
+{
+	/* use kernel global workqueue */
+	_set_workitem(work);
+}
+
+void rtw_ieee80211_mesh_path_timer(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
+	rtw_mesh_work(&adapter->mesh_work);
+}
+
+void rtw_ieee80211_mesh_path_root_timer(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
+
+	rtw_set_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
+
+	rtw_mesh_work(&adapter->mesh_work);
+}
+
+static void rtw_ieee80211_mesh_rootpath(_adapter *adapter)
+{
+	u32 interval;
+
+	rtw_mesh_path_tx_root_frame(adapter);
+
+	if (adapter->mesh_cfg.dot11MeshHWMPRootMode == RTW_IEEE80211_PROACTIVE_RANN)
+		interval = adapter->mesh_cfg.dot11MeshHWMPRannInterval;
+	else
+		interval = adapter->mesh_cfg.dot11MeshHWMProotInterval;
+
+	rtw_mod_timer(&adapter->mesh_path_root_timer,
+		  RTW_TU_TO_EXP_TIME(interval));
+}
+
+BOOLEAN rtw_ieee80211_mesh_root_setup(_adapter *adapter)
+{
+	BOOLEAN root_enabled = _FALSE;
+
+	if (adapter->mesh_cfg.dot11MeshHWMPRootMode > RTW_IEEE80211_ROOTMODE_ROOT) {
+		rtw_set_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
+		root_enabled = _TRUE;
+	}
+	else {
+		rtw_clear_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
+		/* stop running timer */
+		_cancel_timer_ex(&adapter->mesh_path_root_timer);
+		root_enabled = _FALSE;
+	}
+
+	return root_enabled;
+}
+
+void rtw_mesh_work_hdl(_workitem *work)
+{
+	_adapter *adapter = container_of(work, _adapter, mesh_work);
+
+	if (adapter->mesh_info.preq_queue_len &&
+		rtw_time_after(rtw_get_current_time(),
+		       adapter->mesh_info.last_preq + rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPpreqMinInterval)))
+		rtw_mesh_path_start_discovery(adapter);
+
+	if (rtw_test_and_clear_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags))
+		rtw_ieee80211_mesh_rootpath(adapter);
+}
+
+#ifndef RTW_PER_CMD_SUPPORT_FW
+static void rtw_update_metric_directly(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	u8 i;
+
+	for (i = 0; i < macid_ctl->num; i++) {
+		u8 role;
+		role = GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[i]);
+		if (role == H2C_MSR_ROLE_MESH) {
+			struct sta_info *sta = macid_ctl->sta[i];
+			u8 rate_idx, sgi, bw;
+			u32 rate;
+
+			if (!sta)
+				continue;
+			rate_idx = rtw_get_current_tx_rate(adapter, sta);
+			sgi = rtw_get_current_tx_sgi(adapter, sta);
+			bw = sta->cmn.bw_mode;
+			rate = rtw_desc_rate_to_bitrate(bw, rate_idx, sgi);
+			sta->metrics.data_rate = rate;
+		}
+	}
+}
+#endif
+
+void rtw_mesh_atlm_param_req_timer(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
+	u8 ret = _FAIL;
+
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	ret = rtw_req_per_cmd(adapter);
+	if (ret == _FAIL)
+		RTW_HWMP_INFO("rtw_req_per_cmd fail\n");
+#else
+	rtw_update_metric_directly(adapter);
+#endif
+	_set_timer(&adapter->mesh_atlm_param_req_timer, RTW_ATLM_REQ_CYCLE);
+}
+
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_hwmp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_hwmp.h
new file mode 100644
index 000000000000..1702bf22f4df
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_hwmp.h
@@ -0,0 +1,61 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_HWMP_H_
+#define __RTW_MESH_HWMP_H_
+
+#ifndef DBG_RTW_HWMP
+#define DBG_RTW_HWMP 0
+#endif
+#if DBG_RTW_HWMP
+#define RTW_HWMP_DBG(fmt, arg...) RTW_PRINT(fmt, ##arg)
+#else
+#define RTW_HWMP_DBG(fmt, arg...) RTW_DBG(fmt, ##arg)
+#endif
+
+#ifndef INFO_RTW_HWMP
+#define INFO_RTW_HWMP 0
+#endif
+#if INFO_RTW_HWMP
+#define RTW_HWMP_INFO(fmt, arg...) RTW_PRINT(fmt, ##arg)
+#else
+#define RTW_HWMP_INFO(fmt, arg...) RTW_INFO(fmt, ##arg)
+#endif
+
+
+void rtw_ewma_err_rate_init(struct rtw_ewma_err_rate *e);
+unsigned long rtw_ewma_err_rate_read(struct rtw_ewma_err_rate *e);
+void rtw_ewma_err_rate_add(struct rtw_ewma_err_rate *e, unsigned long val);
+int rtw_mesh_path_error_tx(_adapter *adapter,
+			   u8 ttl, const u8 *target, u32 target_sn,
+			   u16 target_rcode, const u8 *ra);
+void rtw_ieee80211s_update_metric(_adapter *adapter, u8 mac_id,
+				  u8 per, u8 rate,
+				  u8 bw, u8 total_pkt);
+void rtw_mesh_rx_path_sel_frame(_adapter *adapter, union recv_frame *rframe);
+void rtw_mesh_queue_preq(struct rtw_mesh_path *mpath, u8 flags);
+void rtw_mesh_path_start_discovery(_adapter *adapter);
+void rtw_mesh_path_timer(void *ctx);
+void rtw_mesh_path_tx_root_frame(_adapter *adapter);
+void rtw_mesh_work_hdl(_workitem *work);
+void rtw_ieee80211_mesh_path_timer(void *ctx);
+void rtw_ieee80211_mesh_path_root_timer(void *ctx);
+BOOLEAN rtw_ieee80211_mesh_root_setup(_adapter *adapter);
+void rtw_mesh_work(_workitem *work);
+void rtw_mesh_atlm_param_req_timer(void *ctx);
+
+#endif /* __RTW_MESH_HWMP_H_ */
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_pathtbl.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_pathtbl.c
new file mode 100644
index 000000000000..23df80919b39
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_pathtbl.c
@@ -0,0 +1,1148 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_PATHTBL_C_
+
+#ifdef CONFIG_RTW_MESH
+#include <drv_types.h>
+#include <linux/jhash.h>
+
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+static void rtw_mpath_free_rcu(struct rtw_mesh_path *mpath)
+{
+	kfree_rcu(mpath, rcu);
+	rtw_mstat_update(MSTAT_TYPE_PHY, MSTAT_FREE, sizeof(struct rtw_mesh_path));
+}
+#else
+static void rtw_mpath_free_rcu_callback(rtw_rcu_head *head)
+{
+	struct rtw_mesh_path *mpath;
+
+	mpath = container_of(head, struct rtw_mesh_path, rcu);
+	rtw_mfree(mpath, sizeof(struct rtw_mesh_path));
+}
+
+static void rtw_mpath_free_rcu(struct rtw_mesh_path *mpath)
+{
+	call_rcu(&mpath->rcu, rtw_mpath_free_rcu_callback);
+}
+#endif
+#endif /* PLATFORM_LINUX */
+
+static void rtw_mesh_path_free_rcu(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath);
+
+static u32 rtw_mesh_table_hash(const void *addr, u32 len, u32 seed)
+{
+	/* Use last four bytes of hw addr as hash index */
+	return jhash_1word(*(u32 *)(addr+2), seed);
+}
+
+static const rtw_rhashtable_params rtw_mesh_rht_params = {
+	.nelem_hint = 2,
+	.automatic_shrinking = true,
+	.key_len = ETH_ALEN,
+	.key_offset = offsetof(struct rtw_mesh_path, dst),
+	.head_offset = offsetof(struct rtw_mesh_path, rhash),
+	.hashfn = rtw_mesh_table_hash,
+};
+
+static inline bool rtw_mpath_expired(struct rtw_mesh_path *mpath)
+{
+	return (mpath->flags & RTW_MESH_PATH_ACTIVE) &&
+	       rtw_time_after(rtw_get_current_time(), mpath->exp_time) &&
+	       !(mpath->flags & RTW_MESH_PATH_FIXED);
+}
+
+static void rtw_mesh_path_rht_free(void *ptr, void *tblptr)
+{
+	struct rtw_mesh_path *mpath = ptr;
+	struct rtw_mesh_table *tbl = tblptr;
+
+	rtw_mesh_path_free_rcu(tbl, mpath);
+}
+
+static struct rtw_mesh_table *rtw_mesh_table_alloc(void)
+{
+	struct rtw_mesh_table *newtbl;
+
+	newtbl = rtw_malloc(sizeof(struct rtw_mesh_table));
+	if (!newtbl)
+		return NULL;
+
+	rtw_hlist_head_init(&newtbl->known_gates);
+	ATOMIC_SET(&newtbl->entries,  0);
+	_rtw_spinlock_init(&newtbl->gates_lock);
+
+	return newtbl;
+}
+
+static void rtw_mesh_table_free(struct rtw_mesh_table *tbl)
+{
+	rtw_rhashtable_free_and_destroy(&tbl->rhead,
+				    rtw_mesh_path_rht_free, tbl);
+	rtw_mfree(tbl, sizeof(struct rtw_mesh_table));
+}
+
+/**
+ *
+ * rtw_mesh_path_assign_nexthop - update mesh path next hop
+ *
+ * @mpath: mesh path to update
+ * @sta: next hop to assign
+ *
+ * Locking: mpath->state_lock must be held when calling this function
+ */
+void rtw_mesh_path_assign_nexthop(struct rtw_mesh_path *mpath, struct sta_info *sta)
+{
+	struct xmit_frame *xframe;
+	_list *list, *head;
+
+	rtw_rcu_assign_pointer(mpath->next_hop, sta);
+
+	enter_critical_bh(&mpath->frame_queue.lock);
+	head = &mpath->frame_queue.queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+		_rtw_memcpy(xframe->attrib.ra, sta->cmn.mac_addr, ETH_ALEN);
+	}
+
+	exit_critical_bh(&mpath->frame_queue.lock);
+}
+
+static void rtw_prepare_for_gate(struct xmit_frame *xframe, char *dst_addr,
+			     struct rtw_mesh_path *gate_mpath)
+{
+	struct pkt_attrib *attrib = &xframe->attrib;
+	char *next_hop;
+
+	if (attrib->mesh_frame_mode == MESH_UCAST_DATA)
+		attrib->mesh_frame_mode = MESH_UCAST_PX_DATA;
+
+	/* update next hop */
+	rtw_rcu_read_lock();
+	next_hop = rtw_rcu_dereference(gate_mpath->next_hop)->cmn.mac_addr;
+	_rtw_memcpy(attrib->ra, next_hop, ETH_ALEN);
+	rtw_rcu_read_unlock();
+	_rtw_memcpy(attrib->mda, dst_addr, ETH_ALEN);
+}
+
+/**
+ *
+ * rtw_mesh_path_move_to_queue - Move or copy frames from one mpath queue to another
+ *
+ * This function is used to transfer or copy frames from an unresolved mpath to
+ * a gate mpath.  The function also adds the Address Extension field and
+ * updates the next hop.
+ *
+ * If a frame already has an Address Extension field, only the next hop and
+ * destination addresses are updated.
+ *
+ * The gate mpath must be an active mpath with a valid mpath->next_hop.
+ *
+ * @mpath: An active mpath the frames will be sent to (i.e. the gate)
+ * @from_mpath: The failed mpath
+ * @copy: When true, copy all the frames to the new mpath queue.  When false,
+ * move them.
+ */
+static void rtw_mesh_path_move_to_queue(struct rtw_mesh_path *gate_mpath,
+				    struct rtw_mesh_path *from_mpath,
+				    bool copy)
+{
+	struct xmit_frame *fskb;
+	_list *list, *head;
+	_list failq;
+	u32 failq_len;
+	_irqL flags;
+
+	if (rtw_warn_on(gate_mpath == from_mpath))
+		return;
+	if (rtw_warn_on(!gate_mpath->next_hop))
+		return;
+
+	_rtw_init_listhead(&failq);
+
+	_enter_critical_bh(&from_mpath->frame_queue.lock, &flags);
+	rtw_list_splice_init(&from_mpath->frame_queue.queue, &failq);
+	failq_len = from_mpath->frame_queue_len;
+	from_mpath->frame_queue_len = 0;
+	_exit_critical_bh(&from_mpath->frame_queue.lock, &flags);
+
+	head = &failq;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		if (gate_mpath->frame_queue_len >= RTW_MESH_FRAME_QUEUE_LEN) {
+			RTW_MPATH_DBG(FUNC_ADPT_FMT" mpath queue for gate %pM is full!\n"
+				, FUNC_ADPT_ARG(gate_mpath->adapter), gate_mpath->dst);
+			break;
+		}
+
+		fskb = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+
+		rtw_list_delete(&fskb->list);
+		failq_len--;
+		rtw_prepare_for_gate(fskb, gate_mpath->dst, gate_mpath);
+		_enter_critical_bh(&gate_mpath->frame_queue.lock, &flags);
+		rtw_list_insert_tail(&fskb->list, get_list_head(&gate_mpath->frame_queue));
+		gate_mpath->frame_queue_len++;
+		_exit_critical_bh(&gate_mpath->frame_queue.lock, &flags);
+
+		#if 0 /* TODO: copy */
+		skb = rtw_skb_copy(fskb);
+		if (rtw_warn_on(!skb))
+			break;
+
+		rtw_prepare_for_gate(skb, gate_mpath->dst, gate_mpath);
+		skb_queue_tail(&gate_mpath->frame_queue, skb);
+
+		if (copy)
+			continue;
+
+		__skb_unlink(fskb, &failq);
+		rtw_skb_free(fskb);
+		#endif
+	}
+
+	RTW_MPATH_DBG(FUNC_ADPT_FMT" mpath queue for gate %pM has %d frames\n"
+		, FUNC_ADPT_ARG(gate_mpath->adapter), gate_mpath->dst, gate_mpath->frame_queue_len);
+
+	if (!copy)
+		return;
+
+	_enter_critical_bh(&from_mpath->frame_queue.lock, &flags);
+	rtw_list_splice(&failq, &from_mpath->frame_queue.queue);
+	from_mpath->frame_queue_len += failq_len;
+	_exit_critical_bh(&from_mpath->frame_queue.lock, &flags);
+}
+
+
+static struct rtw_mesh_path *rtw_mpath_lookup(struct rtw_mesh_table *tbl, const u8 *dst)
+{
+	struct rtw_mesh_path *mpath;
+
+	if (!tbl)
+		return NULL;
+
+	mpath = rtw_rhashtable_lookup_fast(&tbl->rhead, dst, rtw_mesh_rht_params);
+
+	if (mpath && rtw_mpath_expired(mpath)) {
+		enter_critical_bh(&mpath->state_lock);
+		mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
+		exit_critical_bh(&mpath->state_lock);
+	}
+	return mpath;
+}
+
+/**
+ * rtw_mesh_path_lookup - look up a path in the mesh path table
+ * @sdata: local subif
+ * @dst: hardware address (ETH_ALEN length) of destination
+ *
+ * Returns: pointer to the mesh path structure, or NULL if not found
+ *
+ * Locking: must be called within a read rcu section.
+ */
+struct rtw_mesh_path *
+rtw_mesh_path_lookup(_adapter *adapter, const u8 *dst)
+{
+	return rtw_mpath_lookup(adapter->mesh_info.mesh_paths, dst);
+}
+
+struct rtw_mesh_path *
+rtw_mpp_path_lookup(_adapter *adapter, const u8 *dst)
+{
+	return rtw_mpath_lookup(adapter->mesh_info.mpp_paths, dst);
+}
+
+static struct rtw_mesh_path *
+__rtw_mesh_path_lookup_by_idx(struct rtw_mesh_table *tbl, int idx)
+{
+	int i = 0, ret;
+	struct rtw_mesh_path *mpath = NULL;
+	rtw_rhashtable_iter iter;
+
+	if (!tbl)
+		return NULL;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return NULL;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto err;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		if (i++ == idx)
+			break;
+	}
+err:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+
+	if (IS_ERR(mpath) || !mpath)
+		return NULL;
+
+	if (rtw_mpath_expired(mpath)) {
+		enter_critical_bh(&mpath->state_lock);
+		mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
+		exit_critical_bh(&mpath->state_lock);
+	}
+	return mpath;
+}
+
+/**
+ * rtw_mesh_path_lookup_by_idx - look up a path in the mesh path table by its index
+ * @idx: index
+ * @sdata: local subif, or NULL for all entries
+ *
+ * Returns: pointer to the mesh path structure, or NULL if not found.
+ *
+ * Locking: must be called within a read rcu section.
+ */
+struct rtw_mesh_path *
+rtw_mesh_path_lookup_by_idx(_adapter *adapter, int idx)
+{
+	return __rtw_mesh_path_lookup_by_idx(adapter->mesh_info.mesh_paths, idx);
+}
+
+/**
+ * rtw_mpp_path_lookup_by_idx - look up a path in the proxy path table by its index
+ * @idx: index
+ * @sdata: local subif, or NULL for all entries
+ *
+ * Returns: pointer to the proxy path structure, or NULL if not found.
+ *
+ * Locking: must be called within a read rcu section.
+ */
+struct rtw_mesh_path *
+rtw_mpp_path_lookup_by_idx(_adapter *adapter, int idx)
+{
+	return __rtw_mesh_path_lookup_by_idx(adapter->mesh_info.mpp_paths, idx);
+}
+
+/**
+ * rtw_mesh_path_add_gate - add the given mpath to a mesh gate to our path table
+ * @mpath: gate path to add to table
+ */
+int rtw_mesh_path_add_gate(struct rtw_mesh_path *mpath)
+{
+	struct rtw_mesh_cfg *mcfg;
+	struct rtw_mesh_info *minfo;
+	struct rtw_mesh_table *tbl;
+	int err, ori_num_gates;
+
+	rtw_rcu_read_lock();
+	tbl = mpath->adapter->mesh_info.mesh_paths;
+	if (!tbl) {
+		err = -ENOENT;
+		goto err_rcu;
+	}
+
+	enter_critical_bh(&mpath->state_lock);
+	mcfg = &mpath->adapter->mesh_cfg;
+	mpath->gate_timeout = rtw_get_current_time() +
+			      rtw_ms_to_systime(mcfg->path_gate_timeout_factor *
+					        mpath->gate_ann_int);
+	if (mpath->is_gate) {
+		err = -EEXIST;
+		exit_critical_bh(&mpath->state_lock);
+		goto err_rcu;
+	}
+
+	minfo = &mpath->adapter->mesh_info;
+	mpath->is_gate = true;
+	_rtw_spinlock(&tbl->gates_lock);
+	ori_num_gates = minfo->num_gates;
+	minfo->num_gates++;
+	rtw_hlist_add_head_rcu(&mpath->gate_list, &tbl->known_gates);
+
+	if (ori_num_gates == 0
+		|| rtw_macaddr_is_larger(mpath->dst, minfo->max_addr_gate->dst)
+	) {
+		minfo->max_addr_gate = mpath;
+		minfo->max_addr_gate_is_larger_than_self =
+			rtw_macaddr_is_larger(mpath->dst, adapter_mac_addr(mpath->adapter));
+	}
+
+	_rtw_spinunlock(&tbl->gates_lock);
+
+	exit_critical_bh(&mpath->state_lock);
+
+	if (ori_num_gates == 0)
+		update_beacon(mpath->adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE);
+
+	RTW_MPATH_DBG(
+		  FUNC_ADPT_FMT" Mesh path: Recorded new gate: %pM. %d known gates\n",
+		  FUNC_ADPT_ARG(mpath->adapter),
+		  mpath->dst, mpath->adapter->mesh_info.num_gates);
+	err = 0;
+err_rcu:
+	rtw_rcu_read_unlock();
+	return err;
+}
+
+/**
+ * rtw_mesh_gate_del - remove a mesh gate from the list of known gates
+ * @tbl: table which holds our list of known gates
+ * @mpath: gate mpath
+ */
+void rtw_mesh_gate_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath)
+{
+	struct rtw_mesh_cfg *mcfg;
+	struct rtw_mesh_info *minfo;
+	int ori_num_gates;
+
+	rtw_lockdep_assert_held(&mpath->state_lock);
+	if (!mpath->is_gate)
+		return;
+
+	mcfg = &mpath->adapter->mesh_cfg;
+	minfo = &mpath->adapter->mesh_info;
+
+	mpath->is_gate = false;
+	enter_critical_bh(&tbl->gates_lock);
+	rtw_hlist_del_rcu(&mpath->gate_list);
+	ori_num_gates = minfo->num_gates;
+	minfo->num_gates--;
+
+	if (ori_num_gates == 1) {
+		minfo->max_addr_gate = NULL;
+		minfo->max_addr_gate_is_larger_than_self = 0;
+	} else if (minfo->max_addr_gate == mpath) {
+		struct rtw_mesh_path *gate, *max_addr_gate = NULL;
+		rtw_hlist_node *node;
+
+		rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+			if (!max_addr_gate || rtw_macaddr_is_larger(gate->dst, max_addr_gate->dst))
+				max_addr_gate = gate;
+		}
+		minfo->max_addr_gate = max_addr_gate;
+		minfo->max_addr_gate_is_larger_than_self =
+			rtw_macaddr_is_larger(max_addr_gate->dst, adapter_mac_addr(mpath->adapter));
+	}
+
+	exit_critical_bh(&tbl->gates_lock);
+
+	if (ori_num_gates == 1)
+		update_beacon(mpath->adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE);
+
+	RTW_MPATH_DBG(
+		  FUNC_ADPT_FMT" Mesh path: Deleted gate: %pM. %d known gates\n",
+		  FUNC_ADPT_ARG(mpath->adapter),
+		  mpath->dst, mpath->adapter->mesh_info.num_gates);
+}
+
+/**
+ * rtw_mesh_gate_search - search a mesh gate from the list of known gates
+ * @tbl: table which holds our list of known gates
+ * @addr: address of gate
+ */
+bool rtw_mesh_gate_search(struct rtw_mesh_table *tbl, const u8 *addr)
+{
+	struct rtw_mesh_path *gate;
+	rtw_hlist_node *node;
+	bool exist = 0;
+
+	rtw_rcu_read_lock();
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		if (_rtw_memcmp(gate->dst, addr, ETH_ALEN) == _TRUE) {
+			exist = 1;
+			break;
+		}
+	}
+
+	rtw_rcu_read_unlock();
+
+	return exist;
+}
+
+/**
+ * rtw_mesh_gate_num - number of gates known to this interface
+ * @sdata: subif data
+ */
+int rtw_mesh_gate_num(_adapter *adapter)
+{
+	return adapter->mesh_info.num_gates;
+}
+
+bool rtw_mesh_is_primary_gate(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+
+	return mcfg->dot11MeshGateAnnouncementProtocol
+		&& !minfo->max_addr_gate_is_larger_than_self;
+}
+
+void dump_known_gates(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_table *tbl;
+	struct rtw_mesh_path *gate;
+	rtw_hlist_node *node;
+
+	if (!rtw_mesh_gate_num(adapter))
+		goto exit;
+
+	rtw_rcu_read_lock();
+
+	tbl = minfo->mesh_paths;
+	if (!tbl)
+		goto unlock;
+
+	RTW_PRINT_SEL(sel, "num:%d\n", rtw_mesh_gate_num(adapter));
+
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		RTW_PRINT_SEL(sel, "%c"MAC_FMT"\n"
+			, gate == minfo->max_addr_gate ? '*' : ' '
+			, MAC_ARG(gate->dst));
+	}
+
+unlock:
+	rtw_rcu_read_unlock();
+exit:
+	return;
+}
+
+static
+struct rtw_mesh_path *rtw_mesh_path_new(_adapter *adapter,
+				const u8 *dst)
+{
+	struct rtw_mesh_path *new_mpath;
+
+	new_mpath = rtw_zmalloc(sizeof(struct rtw_mesh_path));
+	if (!new_mpath)
+		return NULL;
+
+	_rtw_memcpy(new_mpath->dst, dst, ETH_ALEN);
+	_rtw_memset(new_mpath->rann_snd_addr, 0xFF, ETH_ALEN);
+	new_mpath->is_root = false;
+	new_mpath->adapter = adapter;
+	new_mpath->flags = 0;
+	new_mpath->gate_asked = false;
+	_rtw_init_queue(&new_mpath->frame_queue);
+	new_mpath->frame_queue_len = 0;
+	new_mpath->exp_time = rtw_get_current_time();
+	_rtw_spinlock_init(&new_mpath->state_lock);
+	rtw_init_timer(&new_mpath->timer, adapter, rtw_mesh_path_timer, new_mpath);
+
+	return new_mpath;
+}
+
+/**
+ * rtw_mesh_path_add - allocate and add a new path to the mesh path table
+ * @dst: destination address of the path (ETH_ALEN length)
+ * @sdata: local subif
+ *
+ * Returns: 0 on success
+ *
+ * State: the initial state of the new path is set to 0
+ */
+struct rtw_mesh_path *rtw_mesh_path_add(_adapter *adapter,
+				const u8 *dst)
+{
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
+	struct rtw_mesh_path *mpath, *new_mpath;
+	int ret;
+
+	if (!tbl)
+		return ERR_PTR(-ENOTSUPP);
+
+	if (_rtw_memcmp(dst, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
+		/* never add ourselves as neighbours */
+		return ERR_PTR(-ENOTSUPP);
+
+	if (is_multicast_mac_addr(dst))
+		return ERR_PTR(-ENOTSUPP);
+
+	if (ATOMIC_INC_UNLESS(&adapter->mesh_info.mpaths, RTW_MESH_MAX_MPATHS) == 0)
+		return ERR_PTR(-ENOSPC);
+
+	new_mpath = rtw_mesh_path_new(adapter, dst);
+	if (!new_mpath)
+		return ERR_PTR(-ENOMEM);
+
+	do {
+		ret = rtw_rhashtable_lookup_insert_fast(&tbl->rhead,
+						    &new_mpath->rhash,
+						    rtw_mesh_rht_params);
+
+		if (ret == -EEXIST)
+			mpath = rtw_rhashtable_lookup_fast(&tbl->rhead,
+						       dst,
+						       rtw_mesh_rht_params);
+
+	} while (unlikely(ret == -EEXIST && !mpath));
+
+	if (ret && ret != -EEXIST)
+		return ERR_PTR(ret);
+
+	/* At this point either new_mpath was added, or we found a
+	 * matching entry already in the table; in the latter case
+	 * free the unnecessary new entry.
+	 */
+	if (ret == -EEXIST) {
+		rtw_mfree(new_mpath, sizeof(struct rtw_mesh_path));
+		new_mpath = mpath;
+	}
+	adapter->mesh_info.mesh_paths_generation++;
+	return new_mpath;
+}
+
+int rtw_mpp_path_add(_adapter *adapter,
+		 const u8 *dst, const u8 *mpp)
+{
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mpp_paths;
+	struct rtw_mesh_path *new_mpath;
+	int ret;
+
+	if (!tbl)
+		return -ENOTSUPP;
+
+	if (_rtw_memcmp(dst, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
+		/* never add ourselves as neighbours */
+		return -ENOTSUPP;
+
+	if (is_multicast_mac_addr(dst))
+		return -ENOTSUPP;
+
+	new_mpath = rtw_mesh_path_new(adapter, dst);
+
+	if (!new_mpath)
+		return -ENOMEM;
+
+	_rtw_memcpy(new_mpath->mpp, mpp, ETH_ALEN);
+	ret = rtw_rhashtable_lookup_insert_fast(&tbl->rhead,
+					    &new_mpath->rhash,
+					    rtw_mesh_rht_params);
+
+	adapter->mesh_info.mpp_paths_generation++;
+	return ret;
+}
+
+
+/**
+ * rtw_mesh_plink_broken - deactivates paths and sends perr when a link breaks
+ *
+ * @sta: broken peer link
+ *
+ * This function must be called from the rate control algorithm if enough
+ * delivery errors suggest that a peer link is no longer usable.
+ */
+void rtw_mesh_plink_broken(struct sta_info *sta)
+{
+	_adapter *adapter = sta->padapter;
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
+	static const u8 bcast[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		if (rtw_rcu_access_pointer(mpath->next_hop) == sta &&
+		    mpath->flags & RTW_MESH_PATH_ACTIVE &&
+		    !(mpath->flags & RTW_MESH_PATH_FIXED)) {
+			enter_critical_bh(&mpath->state_lock);
+			mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
+			++mpath->sn;
+			exit_critical_bh(&mpath->state_lock);
+			rtw_mesh_path_error_tx(adapter,
+				adapter->mesh_cfg.element_ttl,
+				mpath->dst, mpath->sn,
+				WLAN_REASON_MESH_PATH_DEST_UNREACHABLE, bcast);
+		}
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+static void rtw_mesh_path_free_rcu(struct rtw_mesh_table *tbl,
+			       struct rtw_mesh_path *mpath)
+{
+	_adapter *adapter = mpath->adapter;
+
+	enter_critical_bh(&mpath->state_lock);
+	mpath->flags |= RTW_MESH_PATH_RESOLVING | RTW_MESH_PATH_DELETED;
+	rtw_mesh_gate_del(tbl, mpath);
+	exit_critical_bh(&mpath->state_lock);
+	_cancel_timer_ex(&mpath->timer);
+	ATOMIC_DEC(&adapter->mesh_info.mpaths);
+	ATOMIC_DEC(&tbl->entries);
+	_rtw_spinlock_free(&mpath->state_lock);
+
+	rtw_mesh_path_flush_pending(mpath);
+
+	rtw_mpath_free_rcu(mpath);
+}
+
+static void __rtw_mesh_path_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath)
+{
+	rtw_rhashtable_remove_fast(&tbl->rhead, &mpath->rhash, rtw_mesh_rht_params);
+	rtw_mesh_path_free_rcu(tbl, mpath);
+}
+
+/**
+ * rtw_mesh_path_flush_by_nexthop - Deletes mesh paths if their next hop matches
+ *
+ * @sta: mesh peer to match
+ *
+ * RCU notes: this function is called when a mesh plink transitions from
+ * PLINK_ESTAB to any other state, since PLINK_ESTAB state is the only one that
+ * allows path creation. This will happen before the sta can be freed (because
+ * sta_info_destroy() calls this) so any reader in a rcu read block will be
+ * protected against the plink disappearing.
+ */
+void rtw_mesh_path_flush_by_nexthop(struct sta_info *sta)
+{
+	_adapter *adapter = sta->padapter;
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+
+		if (rtw_rcu_access_pointer(mpath->next_hop) == sta)
+			__rtw_mesh_path_del(tbl, mpath);
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+static void rtw_mpp_flush_by_proxy(_adapter *adapter,
+			       const u8 *proxy)
+{
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mpp_paths;
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+
+		if (_rtw_memcmp(mpath->mpp, proxy, ETH_ALEN) == _TRUE)
+			__rtw_mesh_path_del(tbl, mpath);
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+static void rtw_table_flush_by_iface(struct rtw_mesh_table *tbl)
+{
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+	
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		__rtw_mesh_path_del(tbl, mpath);
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+/**
+ * rtw_mesh_path_flush_by_iface - Deletes all mesh paths associated with a given iface
+ *
+ * This function deletes both mesh paths as well as mesh portal paths.
+ *
+ * @sdata: interface data to match
+ *
+ */
+void rtw_mesh_path_flush_by_iface(_adapter *adapter)
+{
+	rtw_table_flush_by_iface(adapter->mesh_info.mesh_paths);
+	rtw_table_flush_by_iface(adapter->mesh_info.mpp_paths);
+}
+
+/**
+ * rtw_table_path_del - delete a path from the mesh or mpp table
+ *
+ * @tbl: mesh or mpp path table
+ * @sdata: local subif
+ * @addr: dst address (ETH_ALEN length)
+ *
+ * Returns: 0 if successful
+ */
+static int rtw_table_path_del(struct rtw_mesh_table *tbl,
+			  const u8 *addr)
+{
+	struct rtw_mesh_path *mpath;
+
+	if (!tbl)
+		return -ENXIO;
+
+	rtw_rcu_read_lock();
+	mpath = rtw_rhashtable_lookup_fast(&tbl->rhead, addr, rtw_mesh_rht_params);
+	if (!mpath) {
+		rtw_rcu_read_unlock();
+		return -ENXIO;
+	}
+
+	__rtw_mesh_path_del(tbl, mpath);
+	rtw_rcu_read_unlock();
+	return 0;
+}
+
+
+/**
+ * rtw_mesh_path_del - delete a mesh path from the table
+ *
+ * @addr: dst address (ETH_ALEN length)
+ * @sdata: local subif
+ *
+ * Returns: 0 if successful
+ */
+int rtw_mesh_path_del(_adapter *adapter, const u8 *addr)
+{
+	int err;
+
+	/* flush relevant mpp entries first */
+	rtw_mpp_flush_by_proxy(adapter, addr);
+
+	err = rtw_table_path_del(adapter->mesh_info.mesh_paths, addr);
+	adapter->mesh_info.mesh_paths_generation++;
+	return err;
+}
+
+/**
+ * rtw_mesh_path_tx_pending - sends pending frames in a mesh path queue
+ *
+ * @mpath: mesh path to activate
+ *
+ * Locking: the state_lock of the mpath structure must NOT be held when calling
+ * this function.
+ */
+void rtw_mesh_path_tx_pending(struct rtw_mesh_path *mpath)
+{
+	if (mpath->flags & RTW_MESH_PATH_ACTIVE) {
+		struct rtw_mesh_info *minfo = &mpath->adapter->mesh_info;
+		_list q;
+		u32 q_len = 0;
+
+		_rtw_init_listhead(&q);
+
+		/* move to local queue */
+		enter_critical_bh(&mpath->frame_queue.lock);
+		if (mpath->frame_queue_len) {
+			rtw_list_splice_init(&mpath->frame_queue.queue, &q);
+			q_len = mpath->frame_queue_len;
+			mpath->frame_queue_len = 0;
+		}
+		exit_critical_bh(&mpath->frame_queue.lock);
+
+		if (q_len) {
+			/* move to mpath_tx_queue */
+			enter_critical_bh(&minfo->mpath_tx_queue.lock);
+			rtw_list_splice_tail(&q, &minfo->mpath_tx_queue.queue);
+			minfo->mpath_tx_queue_len += q_len;
+			exit_critical_bh(&minfo->mpath_tx_queue.lock);
+
+			/* schedule mpath_tx_tasklet */
+			tasklet_hi_schedule(&minfo->mpath_tx_tasklet);
+		}
+	}
+}
+
+/**
+ * rtw_mesh_path_send_to_gates - sends pending frames to all known mesh gates
+ *
+ * @mpath: mesh path whose queue will be emptied
+ *
+ * If there is only one gate, the frames are transferred from the failed mpath
+ * queue to that gate's queue.  If there are more than one gates, the frames
+ * are copied from each gate to the next.  After frames are copied, the
+ * mpath queues are emptied onto the transmission queue.
+ */
+int rtw_mesh_path_send_to_gates(struct rtw_mesh_path *mpath)
+{
+	_adapter *adapter = mpath->adapter;
+	struct rtw_mesh_table *tbl;
+	struct rtw_mesh_path *from_mpath = mpath;
+	struct rtw_mesh_path *gate;
+	bool copy = false;
+	rtw_hlist_node *node;
+
+	tbl = adapter->mesh_info.mesh_paths;
+	if (!tbl)
+		return 0;
+
+	rtw_rcu_read_lock();
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		if (gate->flags & RTW_MESH_PATH_ACTIVE) {
+			RTW_MPATH_DBG(FUNC_ADPT_FMT" Forwarding to %pM\n",
+				FUNC_ADPT_ARG(adapter), gate->dst);
+			rtw_mesh_path_move_to_queue(gate, from_mpath, copy);
+			from_mpath = gate;
+			copy = true;
+		} else {
+			RTW_MPATH_DBG(
+				  FUNC_ADPT_FMT" Not forwarding to %pM (flags %#x)\n",
+				  FUNC_ADPT_ARG(adapter), gate->dst, gate->flags);
+		}
+	}
+
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		RTW_MPATH_DBG(FUNC_ADPT_FMT" Sending to %pM\n",
+			FUNC_ADPT_ARG(adapter), gate->dst);
+		rtw_mesh_path_tx_pending(gate);
+	}
+	rtw_rcu_read_unlock();
+
+	return (from_mpath == mpath) ? -EHOSTUNREACH : 0;
+}
+
+/**
+ * rtw_mesh_path_discard_frame - discard a frame whose path could not be resolved
+ *
+ * @skb: frame to discard
+ * @sdata: network subif the frame was to be sent through
+ *
+ * Locking: the function must me called within a rcu_read_lock region
+ */
+void rtw_mesh_path_discard_frame(_adapter *adapter,
+			     struct xmit_frame *xframe)
+{
+	rtw_free_xmitframe(&adapter->xmitpriv, xframe);
+	adapter->mesh_info.mshstats.dropped_frames_no_route++;
+}
+
+/**
+ * rtw_mesh_path_flush_pending - free the pending queue of a mesh path
+ *
+ * @mpath: mesh path whose queue has to be freed
+ *
+ * Locking: the function must me called within a rcu_read_lock region
+ */
+void rtw_mesh_path_flush_pending(struct rtw_mesh_path *mpath)
+{
+	struct xmit_frame *xframe;
+	_list *list, *head;
+	_list tmp;
+
+	_rtw_init_listhead(&tmp);
+
+	enter_critical_bh(&mpath->frame_queue.lock);
+	rtw_list_splice_init(&mpath->frame_queue.queue, &tmp);
+	mpath->frame_queue_len = 0;
+	exit_critical_bh(&mpath->frame_queue.lock);
+
+	head = &tmp;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+		rtw_list_delete(&xframe->list);
+		rtw_mesh_path_discard_frame(mpath->adapter, xframe);
+	}
+}
+
+/**
+ * rtw_mesh_path_fix_nexthop - force a specific next hop for a mesh path
+ *
+ * @mpath: the mesh path to modify
+ * @next_hop: the next hop to force
+ *
+ * Locking: this function must be called holding mpath->state_lock
+ */
+void rtw_mesh_path_fix_nexthop(struct rtw_mesh_path *mpath, struct sta_info *next_hop)
+{
+	enter_critical_bh(&mpath->state_lock);
+	rtw_mesh_path_assign_nexthop(mpath, next_hop);
+	mpath->sn = 0xffff;
+	mpath->metric = 0;
+	mpath->hop_count = 0;
+	mpath->exp_time = 0;
+	mpath->flags = RTW_MESH_PATH_FIXED | RTW_MESH_PATH_SN_VALID;
+	rtw_mesh_path_activate(mpath);
+	exit_critical_bh(&mpath->state_lock);
+	rtw_ewma_err_rate_init(&next_hop->metrics.err_rate);
+	/* init it at a low value - 0 start is tricky */
+	rtw_ewma_err_rate_add(&next_hop->metrics.err_rate, 1);
+	rtw_mesh_path_tx_pending(mpath);
+}
+
+int rtw_mesh_pathtbl_init(_adapter *adapter)
+{
+	struct rtw_mesh_table *tbl_path, *tbl_mpp;
+	int ret;
+
+	tbl_path = rtw_mesh_table_alloc();
+	if (!tbl_path)
+		return -ENOMEM;
+
+	tbl_mpp = rtw_mesh_table_alloc();
+	if (!tbl_mpp) {
+		ret = -ENOMEM;
+		goto free_path;
+	}
+
+	rtw_rhashtable_init(&tbl_path->rhead, &rtw_mesh_rht_params);
+	rtw_rhashtable_init(&tbl_mpp->rhead, &rtw_mesh_rht_params);
+
+	adapter->mesh_info.mesh_paths = tbl_path;
+	adapter->mesh_info.mpp_paths = tbl_mpp;
+
+	return 0;
+
+free_path:
+	rtw_mesh_table_free(tbl_path);
+	return ret;
+}
+
+static
+void rtw_mesh_path_tbl_expire(_adapter *adapter,
+			  struct rtw_mesh_table *tbl)
+{
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		if ((!(mpath->flags & RTW_MESH_PATH_RESOLVING)) &&
+		    (!(mpath->flags & RTW_MESH_PATH_FIXED)) &&
+		     rtw_time_after(rtw_get_current_time(), mpath->exp_time + RTW_MESH_PATH_EXPIRE))
+			__rtw_mesh_path_del(tbl, mpath);
+
+		if (mpath->is_gate &&  /* need not to deal with non-gate case */
+		    rtw_time_after(rtw_get_current_time(), mpath->gate_timeout)) {
+			RTW_MPATH_DBG(FUNC_ADPT_FMT"mpath [%pM] expired systime is %lu systime is %lu\n",
+				      FUNC_ADPT_ARG(adapter), mpath->dst,
+				      mpath->gate_timeout, rtw_get_current_time());
+			enter_critical_bh(&mpath->state_lock);
+			if (mpath->gate_asked) { /* asked gate before */
+				rtw_mesh_gate_del(tbl, mpath);
+				exit_critical_bh(&mpath->state_lock);
+			} else {
+				mpath->gate_asked = true;
+				mpath->gate_timeout = rtw_get_current_time() + rtw_ms_to_systime(mpath->gate_ann_int);
+				exit_critical_bh(&mpath->state_lock);
+				rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH);
+				RTW_MPATH_DBG(FUNC_ADPT_FMT"mpath [%pM] ask mesh gate existence (is_root=%d)\n",
+				      FUNC_ADPT_ARG(adapter), mpath->dst, mpath->is_root);
+			}
+		}
+	}
+
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+void rtw_mesh_path_expire(_adapter *adapter)
+{
+	rtw_mesh_path_tbl_expire(adapter, adapter->mesh_info.mesh_paths);
+	rtw_mesh_path_tbl_expire(adapter, adapter->mesh_info.mpp_paths);
+}
+
+void rtw_mesh_pathtbl_unregister(_adapter *adapter)
+{
+	if (adapter->mesh_info.mesh_paths) {
+		rtw_mesh_table_free(adapter->mesh_info.mesh_paths);
+		adapter->mesh_info.mesh_paths = NULL;
+	}
+
+	if (adapter->mesh_info.mpp_paths) {
+		rtw_mesh_table_free(adapter->mesh_info.mpp_paths);
+		adapter->mesh_info.mpp_paths = NULL;
+	}
+}
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_pathtbl.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_pathtbl.h
new file mode 100644
index 000000000000..9fd4a0a3b994
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/mesh/rtw_mesh_pathtbl.h
@@ -0,0 +1,205 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_PATHTBL_H_
+#define __RTW_MESH_PATHTBL_H_
+
+#ifndef DBG_RTW_MPATH
+#define DBG_RTW_MPATH 1
+#endif
+#if DBG_RTW_MPATH
+#define RTW_MPATH_DBG(fmt, arg...) RTW_PRINT(fmt, ##arg)
+#else
+#define RTW_MPATH_DBG(fmt, arg...) do {} while (0)
+#endif
+
+/**
+ * enum rtw_mesh_path_flags - mesh path flags
+ *
+ * @RTW_MESH_PATH_ACTIVE: the mesh path can be used for forwarding
+ * @RTW_MESH_PATH_RESOLVING: the discovery process is running for this mesh path
+ * @RTW_MESH_PATH_SN_VALID: the mesh path contains a valid destination sequence
+ *	number
+ * @RTW_MESH_PATH_FIXED: the mesh path has been manually set and should not be
+ *	modified
+ * @RTW_MESH_PATH_RESOLVED: the mesh path can has been resolved
+ * @RTW_MESH_PATH_REQ_QUEUED: there is an unsent path request for this destination
+ *	already queued up, waiting for the discovery process to start.
+ * @RTW_MESH_PATH_DELETED: the mesh path has been deleted and should no longer
+ *	be used
+ * @RTW_MESH_PATH_ROOT_ADD_CHK: root additional check in root mode.
+ *	With this flag, It will try the last used rann_snd_addr
+ * @RTW_MESH_PATH_PEER_AKA: only used toward a peer, only used in active keep
+ *	alive mechanism. PREQ's da = path dst
+ * 
+ * RTW_MESH_PATH_RESOLVED is used by the mesh path timer to
+ * decide when to stop or cancel the mesh path discovery.
+ */
+enum rtw_mesh_path_flags {
+	RTW_MESH_PATH_ACTIVE =	BIT(0),
+	RTW_MESH_PATH_RESOLVING =	BIT(1),
+	RTW_MESH_PATH_SN_VALID =	BIT(2),
+	RTW_MESH_PATH_FIXED	=	BIT(3),
+	RTW_MESH_PATH_RESOLVED =	BIT(4),
+	RTW_MESH_PATH_REQ_QUEUED =	BIT(5),
+	RTW_MESH_PATH_DELETED =	BIT(6),
+	RTW_MESH_PATH_ROOT_ADD_CHK =	BIT(7),
+	RTW_MESH_PATH_PEER_AKA =	BIT(8),
+};
+
+/**
+ * struct rtw_mesh_path - mesh path structure
+ *
+ * @dst: mesh path destination mac address
+ * @mpp: mesh proxy mac address
+ * @rhash: rhashtable list pointer
+ * @gate_list: list pointer for known gates list
+ * @sdata: mesh subif
+ * @next_hop: mesh neighbor to which frames for this destination will be
+ *	forwarded
+ * @timer: mesh path discovery timer
+ * @frame_queue: pending queue for frames sent to this destination while the
+ *	path is unresolved
+ * @rcu: rcu head for freeing mesh path
+ * @sn: target sequence number
+ * @metric: current metric to this destination
+ * @hop_count: hops to destination
+ * @exp_time: in jiffies, when the path will expire or when it expired
+ * @discovery_timeout: timeout (lapse in jiffies) used for the last discovery
+ *	retry
+ * @discovery_retries: number of discovery retries
+ * @flags: mesh path flags, as specified on &enum rtw_mesh_path_flags
+ * @state_lock: mesh path state lock used to protect changes to the
+ * mpath itself.  No need to take this lock when adding or removing
+ * an mpath to a hash bucket on a path table.
+ * @rann_snd_addr: the RANN sender address
+ * @rann_metric: the aggregated path metric towards the root node
+ * @last_preq_to_root: Timestamp of last PREQ sent to root
+ * @is_root: the destination station of this path is a root node
+ * @is_gate: the destination station of this path is a mesh gate
+ *
+ *
+ * The dst address is unique in the mesh path table. Since the mesh_path is
+ * protected by RCU, deleting the next_hop STA must remove / substitute the
+ * mesh_path structure and wait until that is no longer reachable before
+ * destroying the STA completely.
+ */
+struct rtw_mesh_path {
+	u8 dst[ETH_ALEN];
+	u8 mpp[ETH_ALEN];	/* used for MPP or MAP */
+	rtw_rhash_head rhash;
+	rtw_hlist_node gate_list;
+	_adapter *adapter;
+	struct sta_info __rcu *next_hop;
+	_timer timer;
+	_queue frame_queue;
+	u32 frame_queue_len;
+	rtw_rcu_head rcu;
+	u32 sn;
+	u32 metric;
+	u8 hop_count;
+	systime exp_time;
+	systime discovery_timeout;
+	systime gate_timeout;
+	u32 gate_ann_int;    /* gate announce interval */
+	u8 discovery_retries;
+	enum rtw_mesh_path_flags flags;
+	_lock state_lock;
+	u8 rann_snd_addr[ETH_ALEN];
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	u8 add_chk_rann_snd_addr[ETH_ALEN];
+#endif
+	u32 rann_metric;
+	unsigned long last_preq_to_root;
+	bool is_root;
+	bool is_gate;
+	bool gate_asked;
+};
+
+/**
+ * struct rtw_mesh_table
+ *
+ * @known_gates: list of known mesh gates and their mpaths by the station. The
+ * gate's mpath may or may not be resolved and active.
+ * @gates_lock: protects updates to known_gates
+ * @rhead: the rhashtable containing struct mesh_paths, keyed by dest addr
+ * @entries: number of entries in the table
+ */
+struct rtw_mesh_table {
+	rtw_hlist_head known_gates;
+	_lock gates_lock;
+	rtw_rhashtable rhead;
+	ATOMIC_T entries;
+};
+
+#define RTW_MESH_PATH_EXPIRE (600 * HZ)
+
+/* Maximum number of paths per interface */
+#define RTW_MESH_MAX_MPATHS		1024
+
+/* Number of frames buffered per destination for unresolved destinations */
+#define RTW_MESH_FRAME_QUEUE_LEN	10
+
+int rtw_mesh_nexthop_lookup(_adapter *adapter,
+	const u8 *mda, const u8 *msa, u8 *ra);
+int rtw_mesh_nexthop_resolve(_adapter *adapter,
+			 struct xmit_frame *xframe);
+
+struct rtw_mesh_path *rtw_mesh_path_lookup(_adapter *adapter,
+				   const u8 *dst);
+struct rtw_mesh_path *rtw_mpp_path_lookup(_adapter *adapter,
+				  const u8 *dst);
+int rtw_mpp_path_add(_adapter *adapter,
+		 const u8 *dst, const u8 *mpp);
+struct rtw_mesh_path *
+rtw_mesh_path_lookup_by_idx(_adapter *adapter, int idx);
+struct rtw_mesh_path *
+rtw_mpp_path_lookup_by_idx(_adapter *adapter, int idx);
+void rtw_mesh_path_fix_nexthop(struct rtw_mesh_path *mpath, struct sta_info *next_hop);
+void rtw_mesh_path_expire(_adapter *adapter);
+
+struct rtw_mesh_path *
+rtw_mesh_path_add(_adapter *adapter, const u8 *dst);
+
+int rtw_mesh_path_add_gate(struct rtw_mesh_path *mpath);
+void rtw_mesh_gate_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath);
+bool rtw_mesh_gate_search(struct rtw_mesh_table *tbl, const u8 *addr);
+int rtw_mesh_path_send_to_gates(struct rtw_mesh_path *mpath);
+int rtw_mesh_gate_num(_adapter *adapter);
+bool rtw_mesh_is_primary_gate(_adapter *adapter);
+void dump_known_gates(void *sel, _adapter *adapter);
+
+void rtw_mesh_plink_broken(struct sta_info *sta);
+
+void rtw_mesh_path_assign_nexthop(struct rtw_mesh_path *mpath, struct sta_info *sta);
+void rtw_mesh_path_flush_pending(struct rtw_mesh_path *mpath);
+void rtw_mesh_path_tx_pending(struct rtw_mesh_path *mpath);
+int rtw_mesh_pathtbl_init(_adapter *adapter);
+void rtw_mesh_pathtbl_unregister(_adapter *adapter);
+int rtw_mesh_path_del(_adapter *adapter, const u8 *addr);
+
+void rtw_mesh_path_flush_by_nexthop(struct sta_info *sta);
+void rtw_mesh_path_discard_frame(_adapter *adapter,
+			     struct xmit_frame *xframe);
+
+static inline void rtw_mesh_path_activate(struct rtw_mesh_path *mpath)
+{
+	mpath->flags |= RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVED;
+}
+
+void rtw_mesh_path_flush_by_iface(_adapter *adapter);
+
+#endif /* __RTW_MESH_PATHTBL_H_ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ap.c
index 58505f98e9c8..247d94a55925 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ap.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ap.c
@@ -1,4224 +1,5040 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#define _RTW_AP_C_
-
-#include <drv_types.h>
-
-
-#ifdef CONFIG_AP_MODE
-
-extern unsigned char	RTW_WPA_OUI[];
-extern unsigned char 	WMM_OUI[];
-extern unsigned char	WPS_OUI[];
-extern unsigned char	P2P_OUI[];
-extern unsigned char	WFD_OUI[];
-
-void init_mlme_ap_info(_adapter *padapter)
-{
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct sta_priv *pstapriv = &padapter->stapriv;	
-	struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-	
-
-	_rtw_spinlock_init(&pmlmepriv->bcn_update_lock);	
-
-	//for ACL 
-	_rtw_init_queue(&pacl_list->acl_node_q);
-
-	//pmlmeext->bstart_bss = _FALSE;
-
-	start_ap_mode(padapter);
-}
-
-void free_mlme_ap_info(_adapter *padapter)
-{
-	_irqL irqL;
-	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);
-
-	//stop_ap_mode(padapter);
-
-	pmlmepriv->update_bcn = _FALSE;
-	pmlmeext->bstart_bss = _FALSE;	
-	
-	rtw_sta_flush(padapter, _TRUE);
-
-	pmlmeinfo->state = _HW_STATE_NOLINK_;
-
-	//free_assoc_sta_resources
-	rtw_free_all_stainfo(padapter);
-
-	//free bc/mc sta_info
-	psta = rtw_get_bcmc_stainfo(padapter);	
-	//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
-	rtw_free_stainfo(padapter, psta);
-	//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-	
-
-	_rtw_spinlock_free(&pmlmepriv->bcn_update_lock);
-	
-}
-
-static void update_BCNTIM(_adapter *padapter)
-{
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork_mlmeext = &(pmlmeinfo->network);
-	unsigned char *pie = pnetwork_mlmeext->IEs;
-
-/*
-	//DBG_871X("%s\n", __FUNCTION__);
-	
-	//update TIM IE
-	//if(pstapriv->tim_bitmap)
-*/
-	if (_TRUE) {
-		u8 *p, *dst_ie, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
-		u16 tim_bitmap_le;
-		uint offset, tmp_len, tim_ielen, tim_ie_offset, remainder_ielen;	
-	
-		tim_bitmap_le = cpu_to_le16(pstapriv->tim_bitmap);
-
-		p = rtw_get_ie(pie + _FIXED_IE_LENGTH_, _TIM_IE_, &tim_ielen, pnetwork_mlmeext->IELength - _FIXED_IE_LENGTH_);
-		if (p != NULL && tim_ielen > 0) {
-			tim_ielen += 2;
-			
-			premainder_ie = p + tim_ielen;
-
-			tim_ie_offset = (sint)(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 = _FIXED_IE_LENGTH_;
-
-			/* get ssid_ie len */
-			p = rtw_get_ie(pie + _BEACON_IE_OFFSET_, _SSID_IE_, &tmp_len, (pnetwork_mlmeext->IELength - _BEACON_IE_OFFSET_));
-			if (p != NULL)
-				offset += tmp_len+2;
-
-			/*get supported rates len*/
-			p = rtw_get_ie(pie + _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_, &tmp_len, (pnetwork_mlmeext->IELength - _BEACON_IE_OFFSET_));	
-			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 = rtw_malloc(remainder_ielen);
-			if(pbackup_remainder_ie && premainder_ie)
-				_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
-		}		
-		
-		*dst_ie++=_TIM_IE_;
-
-		if ((pstapriv->tim_bitmap&0xff00) && (pstapriv->tim_bitmap&0x00fe))			
-			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) {
-			u8 pvb = 0;
-			
-			if (pstapriv->tim_bitmap & 0x00fe)
-				pvb = (u8)tim_bitmap_le;
-			else if (pstapriv->tim_bitmap & 0xff00)			
-				pvb = (u8)(tim_bitmap_le >> 8);
-			else
-				pvb = (u8)tim_bitmap_le;
-
-			*dst_ie++ = pvb;
-			
-		} else if (tim_ielen == 5) {
-			_rtw_memcpy(dst_ie, &tim_bitmap_le, 2);
-			dst_ie += 2;				
-		}	
-		
-		/*copy remainder IE*/
-		if (pbackup_remainder_ie) {
-			_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
-
-			rtw_mfree(pbackup_remainder_ie, remainder_ielen);
-		}	
-
-		offset =  (uint)(dst_ie - pie);
-		pnetwork_mlmeext->IELength = offset + remainder_ielen;
-	
-	}
-}
-
-void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len)
-{
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8	bmatch = _FALSE;
-	u8	*pie = pnetwork->IEs;
-	u8	*p=NULL, *dst_ie=NULL, *premainder_ie=NULL, *pbackup_remainder_ie=NULL;
-	u32	i, offset, ielen, ie_offset, remainder_ielen = 0;
-
-	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pnetwork->IELength;)
-	{
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(pnetwork->IEs + i);
-
-		if (pIE->ElementID > index)
-		{
-			break;
-		}
-		else if(pIE->ElementID == index) // already exist the same IE
-		{
-			p = (u8 *)pIE;
-			ielen = pIE->Length;
-			bmatch = _TRUE;
-			break;
-		}
-
-		p = (u8 *)pIE;
-		ielen = pIE->Length;
-		i += (pIE->Length + 2);
-	}
-
-	if (p != NULL && ielen>0)
-	{
-		ielen += 2;
-		
-		premainder_ie = p+ielen;
-
-		ie_offset = (sint)(p -pie);
-		
-		remainder_ielen = pnetwork->IELength - ie_offset - ielen;
-
-		if(bmatch)
-			dst_ie = p;
-		else
-			dst_ie = (p+ielen);
-	}
-
-	if(dst_ie == NULL)
-		return;
-
-	if(remainder_ielen>0)
-	{
-		pbackup_remainder_ie = rtw_malloc(remainder_ielen);
-		if(pbackup_remainder_ie && premainder_ie)
-			_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
-	}
-
-	*dst_ie++=index;
-	*dst_ie++=len;
-
-	_rtw_memcpy(dst_ie, data, len);
-	dst_ie+=len;
-
-	//copy remainder IE
-	if(pbackup_remainder_ie)
-	{
-		_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
-
-		rtw_mfree(pbackup_remainder_ie, remainder_ielen);
-	}
-
-	offset =  (uint)(dst_ie - pie);
-	pnetwork->IELength = offset + remainder_ielen;
-}
-
-void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index)
-{
-	u8 *p, *dst_ie=NULL, *premainder_ie=NULL, *pbackup_remainder_ie=NULL;
-	uint offset, ielen, ie_offset, remainder_ielen = 0;
-	u8	*pie = pnetwork->IEs;
-
-	p = rtw_get_ie(pie + _FIXED_IE_LENGTH_, index, &ielen, pnetwork->IELength - _FIXED_IE_LENGTH_);
-	if (p != NULL && ielen>0)
-	{
-		ielen += 2;
-		
-		premainder_ie = p+ielen;
-
-		ie_offset = (sint)(p -pie);
-		
-		remainder_ielen = pnetwork->IELength - ie_offset - ielen;
-
-		dst_ie = p;
-	}
-	else {
-		return;
-	}
-
-	if(remainder_ielen>0)
-	{
-		pbackup_remainder_ie = rtw_malloc(remainder_ielen);
-		if(pbackup_remainder_ie && premainder_ie)
-			_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
-	}
-
-	//copy remainder IE
-	if(pbackup_remainder_ie)
-	{
-		_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
-
-		rtw_mfree(pbackup_remainder_ie, remainder_ielen);
-	}
-
-	offset =  (uint)(dst_ie - pie);
-	pnetwork->IELength = offset + remainder_ielen;
-}
-
-
-u8 chk_sta_is_alive(struct sta_info *psta);
-u8 chk_sta_is_alive(struct sta_info *psta)
-{
-	u8 ret = _FALSE;
-	#ifdef DBG_EXPIRATION_CHK
-	DBG_871X("sta:"MAC_FMT", rssi:%d, rx:"STA_PKTS_FMT", expire_to:%u, %s%ssq_len:%u\n"
-		, MAC_ARG(psta->hwaddr)
-		, psta->rssi_stat.UndecoratedSmoothedPWDB
-		//, STA_RX_PKTS_ARG(psta)
-		, STA_RX_PKTS_DIFF_ARG(psta)
-		, psta->expire_to
-		, psta->state&WIFI_SLEEP_STATE?"PS, ":""
-		, psta->state&WIFI_STA_ALIVE_CHK_STATE?"SAC, ":""
-		, psta->sleepq_len
-	);
-	#endif
-
-	//if(sta_last_rx_pkts(psta) == sta_rx_pkts(psta))
-	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))
-	{
-		#if 0
-		if(psta->state&WIFI_SLEEP_STATE)
-			ret = _TRUE;
-		#endif
-	}
-	else
-	{
-		ret = _TRUE;
-	}
-
-	sta_update_last_rx_pkts(psta);
-
-	return ret;
-}
-
-void	expire_timeout_chk(_adapter *padapter)
-{
-	_irqL irqL;
-	_list	*phead, *plist;
-	u8 updated = _FALSE;
-	struct sta_info *psta=NULL;	
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 chk_alive_num = 0;
-	char chk_alive_list[NUM_STA];
-	int i;
-
-
-	_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
-	
-	phead = &pstapriv->auth_list;
-	plist = get_next(phead);
-	
-	//check auth_queue
-	#ifdef DBG_EXPIRATION_CHK
-	if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
-		DBG_871X(FUNC_NDEV_FMT" auth_list, cnt:%u\n"
-			, FUNC_NDEV_ARG(padapter->pnetdev), pstapriv->auth_list_cnt);
-	}
-	#endif
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)	
-	{
-		psta = LIST_CONTAINOR(plist, struct sta_info, auth_list);
-
-		plist = get_next(plist);
-
-
-#ifdef CONFIG_ATMEL_RC_PATCH
-		if (_TRUE == _rtw_memcmp((void *)(pstapriv->atmel_rc_pattern), (void *)(psta->hwaddr), ETH_ALEN))
-			continue;
-		if (psta->flag_atmel_rc)
-			continue;
-#endif
-		if(psta->expire_to>0)
-		{
-			psta->expire_to--;
-			if (psta->expire_to == 0)
-			{
-				rtw_list_delete(&psta->auth_list);
-				pstapriv->auth_list_cnt--;
-				
-				DBG_871X("auth expire %02X%02X%02X%02X%02X%02X\n",
-					psta->hwaddr[0],psta->hwaddr[1],psta->hwaddr[2],psta->hwaddr[3],psta->hwaddr[4],psta->hwaddr[5]);
-				
-				_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
-				
-				//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);	
-				rtw_free_stainfo(padapter, psta);
-				//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);	
-				
-				_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
-			}	
-		}	
-		
-	}
-
-	_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
-	psta = NULL;
-	
-
-	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	
-	phead = &pstapriv->asoc_list;
-	plist = get_next(phead);
-
-	//check asoc_queue
-	#ifdef DBG_EXPIRATION_CHK
-	if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
-		DBG_871X(FUNC_NDEV_FMT" asoc_list, cnt:%u\n"
-			, FUNC_NDEV_ARG(padapter->pnetdev), pstapriv->asoc_list_cnt);
-	}
-	#endif
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-	{
-		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		plist = get_next(plist);
-#ifdef CONFIG_ATMEL_RC_PATCH
-		DBG_871X("%s:%d  psta=%p, %02x,%02x||%02x,%02x  \n\n", __func__,  __LINE__,
-			psta,pstapriv->atmel_rc_pattern[0], pstapriv->atmel_rc_pattern[5], psta->hwaddr[0], psta->hwaddr[5]);
-		if (_TRUE == _rtw_memcmp((void *)pstapriv->atmel_rc_pattern, (void *)(psta->hwaddr), ETH_ALEN))
-			continue;		
-		if (psta->flag_atmel_rc)
-			continue;
-		DBG_871X("%s: debug line:%d \n", __func__, __LINE__);
-#endif
-#ifdef CONFIG_AUTO_AP_MODE
-		if(psta->isrc)
-			continue;
-#endif
-		if (chk_sta_is_alive(psta) || !psta->expire_to) {
-			psta->expire_to = pstapriv->expire_to;
-			psta->keep_alive_trycnt = 0;
-			#ifdef CONFIG_TX_MCAST2UNI
-			psta->under_exist_checking = 0;
-			#endif	// CONFIG_TX_MCAST2UNI
-		} else {
-			psta->expire_to--;
-		}
-
-#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-#ifdef CONFIG_80211N_HT
-#ifdef CONFIG_TX_MCAST2UNI
-		if ( (psta->flags & WLAN_STA_HT) && (psta->htpriv.agg_enable_bitmap || psta->under_exist_checking) ) {
-			// check sta by delba(addba) for 11n STA 
-			// ToDo: use CCX report to check for all STAs
-			//DBG_871X("asoc check by DELBA/ADDBA! (pstapriv->expire_to=%d s)(psta->expire_to=%d s), [%02x, %d]\n", pstapriv->expire_to*2, psta->expire_to*2, psta->htpriv.agg_enable_bitmap, psta->under_exist_checking);
-			
-				if ( psta->expire_to <= (pstapriv->expire_to - 50 ) ) {
-				DBG_871X("asoc expire by DELBA/ADDBA! (%d s)\n", (pstapriv->expire_to-psta->expire_to)*2);
-				psta->under_exist_checking = 0;
-				psta->expire_to = 0;
-			} else if ( psta->expire_to <= (pstapriv->expire_to - 3) && (psta->under_exist_checking==0)) {
-				DBG_871X("asoc check by DELBA/ADDBA! (%d s)\n", (pstapriv->expire_to-psta->expire_to)*2);
-				psta->under_exist_checking = 1;
-				//tear down TX AMPDU
-				send_delba(padapter, 1, psta->hwaddr);// // originator
-				psta->htpriv.agg_enable_bitmap = 0x0;//reset
-				psta->htpriv.candidate_tid_bitmap = 0x0;//reset
-			}
-		}
-#endif //CONFIG_TX_MCAST2UNI
-#endif //CONFIG_80211N_HT
-#endif //CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-
-		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;
-			}
-
-#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-#ifdef CONFIG_80211N_HT
-
-#define KEEP_ALIVE_TRYCNT (3)
-
-			if(psta->keep_alive_trycnt > 0 && psta->keep_alive_trycnt <= KEEP_ALIVE_TRYCNT)
-			{				
-				if(psta->state & WIFI_STA_ALIVE_CHK_STATE)
-					psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
-				else
-					psta->keep_alive_trycnt = 0;
-				
-			}
-			else if((psta->keep_alive_trycnt > KEEP_ALIVE_TRYCNT) && !(psta->state & WIFI_STA_ALIVE_CHK_STATE))
-			{
-				psta->keep_alive_trycnt = 0;
-			}			
-			if((psta->htpriv.ht_option==_TRUE) && (psta->htpriv.ampdu_enable==_TRUE)) 
-			{
-				uint priority = 1; //test using BK
-				u8 issued=0;				
-		
-				//issued = (psta->htpriv.agg_enable_bitmap>>priority)&0x1;
-				issued |= (psta->htpriv.candidate_tid_bitmap>>priority)&0x1;
-
-				if(0==issued)
-				{
-					if (!(psta->state & WIFI_STA_ALIVE_CHK_STATE))
-					{
-						psta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
-
-						if (psta->state & WIFI_SLEEP_STATE) 
-							psta->expire_to = 2; // 2x2=4 sec
-						else
-							psta->expire_to = 1; // 2 sec
-					
-						psta->state |= WIFI_STA_ALIVE_CHK_STATE;
-					
-						//add_ba_hdl(padapter, (u8*)paddbareq_parm);
-
-						DBG_871X("issue addba_req to check if sta alive, keep_alive_trycnt=%d\n", psta->keep_alive_trycnt);
-
-						issue_addba_req(padapter, psta->hwaddr, (u8)priority);
-		
-						_set_timer(&psta->addba_retry_timer, ADDBA_TO);
-						
-						psta->keep_alive_trycnt++;						
-
-						continue;
-					}			
-				}					
-			}
-			if(psta->keep_alive_trycnt > 0 && psta->state & WIFI_STA_ALIVE_CHK_STATE)
-			{
-				psta->keep_alive_trycnt = 0;
-				psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
-				DBG_871X("change to another methods to check alive if staion is at ps mode\n");
-			}	
-			
-#endif //CONFIG_80211N_HT
-#endif //CONFIG_ACTIVE_KEEP_ALIVE_CHECK	
-			if (psta->state & WIFI_SLEEP_STATE) {
-				if (!(psta->state & WIFI_STA_ALIVE_CHK_STATE)) {
-					//to check if alive by another methods if staion is at ps mode.					
-					psta->expire_to = pstapriv->expire_to;
-					psta->state |= WIFI_STA_ALIVE_CHK_STATE;
-
-					//DBG_871X("alive chk, sta:" MAC_FMT " is at ps mode!\n", MAC_ARG(psta->hwaddr));
-
-					//to update bcn with tim_bitmap for this station
-					pstapriv->tim_bitmap |= BIT(psta->aid);
-					update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
-
-					if(!pmlmeext->active_keep_alive_check)
-						continue;
-				}
-			}
-			#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-			if (pmlmeext->active_keep_alive_check) {
-				int stainfo_offset;
-
-				stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
-				if (stainfo_offset_valid(stainfo_offset)) {
-					chk_alive_list[chk_alive_num++] = stainfo_offset;
-				}
-
-				continue;
-			}
-			#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
-			rtw_list_delete(&psta->asoc_list);
-			pstapriv->asoc_list_cnt--;
-			DBG_871X("asoc expire "MAC_FMT", state=0x%x\n", MAC_ARG(psta->hwaddr), psta->state);
-			updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
-		}	
-		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_871X("%s sta:"MAC_FMT", sleepq_len:%u, free_xmitframe_cnt:%u, asoc_list_cnt:%u, clear sleep_q\n", __func__
-					, MAC_ARG(psta->hwaddr)
-					, psta->sleepq_len, padapter->xmitpriv.free_xmitframe_cnt, pstapriv->asoc_list_cnt);
-				wakeup_sta_to_xmit(padapter, psta);
-			}
-		}
-	}
-
-	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-if (chk_alive_num) {
-
-	u8 backup_ch = 0, backup_bw, backup_offset;
-	u8 union_ch = 0, union_bw, union_offset;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-	if (!rtw_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
-		|| pmlmeext->cur_channel != union_ch)
-		goto bypass_active_keep_alive;
-
-	/* switch to correct channel of current network  before issue keep-alive frames */
-	if (rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
-		backup_ch = rtw_get_oper_ch(padapter);
-		backup_bw = rtw_get_oper_bw(padapter);
-		backup_offset = rtw_get_oper_choffset(padapter);
-		set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
-	}
-
-	/* issue null data to check sta alive*/
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+#include <hal_data.h>
+
+#ifdef CONFIG_AP_MODE
+
+extern unsigned char	RTW_WPA_OUI[];
+extern unsigned char	WMM_OUI[];
+extern unsigned char	WPS_OUI[];
+extern unsigned char	P2P_OUI[];
+extern unsigned char	WFD_OUI[];
+
+void init_mlme_ap_info(_adapter *padapter)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	_rtw_spinlock_init(&pmlmepriv->bcn_update_lock);
+
+	/* pmlmeext->bstart_bss = _FALSE; */
+
+}
+
+void free_mlme_ap_info(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	stop_ap_mode(padapter);
+	_rtw_spinlock_free(&pmlmepriv->bcn_update_lock);
+
+}
+
+/*
+* Set TIM IE
+* return length of total TIM IE
+*/
+u8 rtw_set_tim_ie(u8 dtim_cnt, u8 dtim_period
+	, const u8 *tim_bmp, u8 tim_bmp_len, u8 *tim_ie)
+{
+	u8 *p = tim_ie;
+	u8 i, n1, n2;
+	u8 bmp_len;
+
+	if (rtw_bmp_not_empty(tim_bmp, tim_bmp_len)) {
+		/* find the first nonzero octet in tim_bitmap */
+		for (i = 0; i < tim_bmp_len; i++)
+			if (tim_bmp[i])
+				break;
+		n1 = i & 0xFE;
+	
+		/* find the last nonzero octet in tim_bitmap, except octet 0 */
+		for (i = tim_bmp_len - 1; i > 0; i--)
+			if (tim_bmp[i])
+				break;
+		n2 = i;
+		bmp_len = n2 - n1 + 1;
+	} else {
+		n1 = n2 = 0;
+		bmp_len = 1;
+	}
+
+	*p++ = WLAN_EID_TIM;
+	*p++ = 2 + 1 + bmp_len;
+	*p++ = dtim_cnt;
+	*p++ = dtim_period;
+	*p++ = (rtw_bmp_is_set(tim_bmp, tim_bmp_len, 0) ? BIT0 : 0) | n1;
+	_rtw_memcpy(p, tim_bmp + n1, bmp_len);
+
+#if 0
+	RTW_INFO("n1:%u, n2:%u, bmp_offset:%u, bmp_len:%u\n", n1, n2, n1 / 2, bmp_len);
+	RTW_INFO_DUMP("tim_ie: ", tim_ie + 2, 2 + 1 + bmp_len);
+#endif
+	return 2 + 2 + 1 + bmp_len;
+}
+
+static void update_BCNTIM(_adapter *padapter)
+{
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork_mlmeext = &(pmlmeinfo->network);
+	unsigned char *pie = pnetwork_mlmeext->IEs;
+
+#if 0
+
+
+	/* update TIM IE */
+	/* if(rtw_tim_map_anyone_be_set(padapter, pstapriv->tim_bitmap)) */
+#endif
+	if (_TRUE) {
+		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_ie(pie + _FIXED_IE_LENGTH_, _TIM_IE_, &tim_ielen, pnetwork_mlmeext->IELength - _FIXED_IE_LENGTH_);
+		if (p != NULL && tim_ielen > 0) {
+			tim_ielen += 2;
+
+			premainder_ie = p + tim_ielen;
+
+			tim_ie_offset = (sint)(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 = _FIXED_IE_LENGTH_;
+
+			/* get ssid_ie len */
+			p = rtw_get_ie(pie + _BEACON_IE_OFFSET_, _SSID_IE_, &tmp_len, (pnetwork_mlmeext->IELength - _BEACON_IE_OFFSET_));
+			if (p != NULL)
+				offset += tmp_len + 2;
+
+			/*get supported rates len*/
+			p = rtw_get_ie(pie + _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_, &tmp_len, (pnetwork_mlmeext->IELength - _BEACON_IE_OFFSET_));
+			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 = rtw_malloc(remainder_ielen);
+			if (pbackup_remainder_ie && premainder_ie)
+				_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
+		}
+
+		/* append TIM IE */
+		dst_ie += rtw_set_tim_ie(0, 1, pstapriv->tim_bitmap, pstapriv->aid_bmp_len, dst_ie);
+
+		/*copy remainder IE*/
+		if (pbackup_remainder_ie) {
+			_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
+
+			rtw_mfree(pbackup_remainder_ie, remainder_ielen);
+		}
+
+		offset = (uint)(dst_ie - pie);
+		pnetwork_mlmeext->IELength = offset + remainder_ielen;
+
+	}
+}
+
+void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len)
+{
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	u8	bmatch = _FALSE;
+	u8	*pie = pnetwork->IEs;
+	u8	*p = NULL, *dst_ie = NULL, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
+	u32	i, offset, ielen, ie_offset, remainder_ielen = 0;
+
+	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pnetwork->IELength;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(pnetwork->IEs + i);
+
+		if (pIE->ElementID > index)
+			break;
+		else if (pIE->ElementID == index) { /* already exist the same IE */
+			p = (u8 *)pIE;
+			ielen = pIE->Length;
+			bmatch = _TRUE;
+			break;
+		}
+
+		p = (u8 *)pIE;
+		ielen = pIE->Length;
+		i += (pIE->Length + 2);
+	}
+
+	if (p != NULL && ielen > 0) {
+		ielen += 2;
+
+		premainder_ie = p + ielen;
+
+		ie_offset = (sint)(p - pie);
+
+		remainder_ielen = pnetwork->IELength - ie_offset - ielen;
+
+		if (bmatch)
+			dst_ie = p;
+		else
+			dst_ie = (p + ielen);
+	}
+
+	if (dst_ie == NULL)
+		return;
+
+	if (remainder_ielen > 0) {
+		pbackup_remainder_ie = rtw_malloc(remainder_ielen);
+		if (pbackup_remainder_ie && premainder_ie)
+			_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
+	}
+
+	*dst_ie++ = index;
+	*dst_ie++ = len;
+
+	_rtw_memcpy(dst_ie, data, len);
+	dst_ie += len;
+
+	/* copy remainder IE */
+	if (pbackup_remainder_ie) {
+		_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
+
+		rtw_mfree(pbackup_remainder_ie, remainder_ielen);
+	}
+
+	offset = (uint)(dst_ie - pie);
+	pnetwork->IELength = offset + remainder_ielen;
+}
+
+void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index)
+{
+	u8 *p, *dst_ie = NULL, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
+	uint offset, ielen, ie_offset, remainder_ielen = 0;
+	u8	*pie = pnetwork->IEs;
+
+	p = rtw_get_ie(pie + _FIXED_IE_LENGTH_, index, &ielen, pnetwork->IELength - _FIXED_IE_LENGTH_);
+	if (p != NULL && ielen > 0) {
+		ielen += 2;
+
+		premainder_ie = p + ielen;
+
+		ie_offset = (sint)(p - pie);
+
+		remainder_ielen = pnetwork->IELength - ie_offset - ielen;
+
+		dst_ie = p;
+	} else
+		return;
+
+	if (remainder_ielen > 0) {
+		pbackup_remainder_ie = rtw_malloc(remainder_ielen);
+		if (pbackup_remainder_ie && premainder_ie)
+			_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
+	}
+
+	/* copy remainder IE */
+	if (pbackup_remainder_ie) {
+		_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
+
+		rtw_mfree(pbackup_remainder_ie, remainder_ielen);
+	}
+
+	offset = (uint)(dst_ie - pie);
+	pnetwork->IELength = offset + remainder_ielen;
+}
+
+
+u8 chk_sta_is_alive(struct sta_info *psta);
+u8 chk_sta_is_alive(struct sta_info *psta)
+{
+	u8 ret = _FALSE;
+#ifdef DBG_EXPIRATION_CHK
+	RTW_INFO("sta:"MAC_FMT", rssi:%d, rx:"STA_PKTS_FMT", expire_to:%u, %s%ssq_len:%u\n"
+		 , MAC_ARG(psta->cmn.mac_addr)
+		 , psta->cmn.rssi_stat.rssi
+		 /* , STA_RX_PKTS_ARG(psta) */
+		 , STA_RX_PKTS_DIFF_ARG(psta)
+		 , psta->expire_to
+		 , psta->state & WIFI_SLEEP_STATE ? "PS, " : ""
+		 , psta->state & WIFI_STA_ALIVE_CHK_STATE ? "SAC, " : ""
+		 , psta->sleepq_len
+		);
+#endif
+
+	/* if(sta_last_rx_pkts(psta) == sta_rx_pkts(psta)) */
+	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)) {
+#if 0
+		if (psta->state & WIFI_SLEEP_STATE)
+			ret = _TRUE;
+#endif
+#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(psta->padapter) &&
+		    (psta->sta_stats.last_rx_hwmp_pkts !=
+		     psta->sta_stats.rx_hwmp_pkts))
+			ret = _TRUE;
+#endif
+	} else
+		ret = _TRUE;
+
+	sta_update_last_rx_pkts(psta);
+
+	return ret;
+}
+
+/**
+ * issue_aka_chk_frame - issue active keep alive check frame
+ *	aka = active keep alive
+ */
+static int issue_aka_chk_frame(_adapter *adapter, struct sta_info *psta)
+{
+	int ret = _FAIL;
+	u8 *target_addr = psta->cmn.mac_addr;
+
+	if (MLME_IS_AP(adapter)) {
+		/* issue null data to check sta alive */
+		if (psta->state & WIFI_SLEEP_STATE)
+			ret = issue_nulldata(adapter, target_addr, 0, 1, 50);
+		else
+			ret = issue_nulldata(adapter, target_addr, 0, 3, 50);
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		struct rtw_mesh_path *mpath;
+
+		rtw_rcu_read_lock();
+		mpath = rtw_mesh_path_lookup(adapter, target_addr);
+		if (!mpath) {
+			mpath = rtw_mesh_path_add(adapter, target_addr);
+			if (IS_ERR(mpath)) {
+				rtw_rcu_read_unlock();
+				RTW_ERR("[%s] rtw_mesh_path_add fail.\n",
+					__FUNCTION__);
+				return _FAIL;
+			}
+		}
+		if (mpath->flags & RTW_MESH_PATH_ACTIVE)
+			ret = _SUCCESS;
+		else {
+			u8 flags = RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_PEER_AKA;
+			/* issue PREQ to check peer alive */
+			rtw_mesh_queue_preq(mpath, flags);
+			ret = _FALSE;
+		}
+		rtw_rcu_read_unlock();
+	}
+#endif
+	return ret;
+}
+
+void	expire_timeout_chk(_adapter *padapter)
+{
+	_irqL irqL;
+	_list	*phead, *plist;
+	u8 updated = _FALSE;
+	struct sta_info *psta = NULL;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 chk_alive_num = 0;
+	char chk_alive_list[NUM_STA];
+	int i;
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)
+		&& check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE)
+	) {
+		struct rtw_mesh_cfg *mcfg = &padapter->mesh_cfg;
+
+		rtw_mesh_path_expire(padapter);
+
+		/* TBD: up layer timeout mechanism */
+		/* if (!mcfg->plink_timeout)
+			return; */
+#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+		return;
+#endif
+	}
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	/*	then driver may check fail due to not recv client's frame under sitesurvey,
+	 *	don't expire timeout chk under MCC under sitesurvey */
+
+	if (rtw_hal_mcc_link_status_chk(padapter, __func__) == _FALSE)
+		return;
+#endif
+
+	_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
+
+	phead = &pstapriv->auth_list;
+	plist = get_next(phead);
+
+	/* check auth_queue */
+#ifdef DBG_EXPIRATION_CHK
+	if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
+		RTW_INFO(FUNC_NDEV_FMT" auth_list, cnt:%u\n"
+			, FUNC_NDEV_ARG(padapter->pnetdev), pstapriv->auth_list_cnt);
+	}
+#endif
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info, auth_list);
+
+		plist = get_next(plist);
+
+
+#ifdef CONFIG_ATMEL_RC_PATCH
+		if (_rtw_memcmp((void *)(pstapriv->atmel_rc_pattern), (void *)(psta->cmn.mac_addr), ETH_ALEN) == _TRUE)
+			continue;
+		if (psta->flag_atmel_rc)
+			continue;
+#endif
+		if (psta->expire_to > 0) {
+			psta->expire_to--;
+			if (psta->expire_to == 0) {
+				rtw_list_delete(&psta->auth_list);
+				pstapriv->auth_list_cnt--;
+
+				RTW_INFO("auth expire %02X%02X%02X%02X%02X%02X\n",
+					psta->cmn.mac_addr[0], psta->cmn.mac_addr[1], psta->cmn.mac_addr[2],
+					psta->cmn.mac_addr[3], psta->cmn.mac_addr[4], psta->cmn.mac_addr[5]);
+
+				_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
+
+				/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);	 */
+				rtw_free_stainfo(padapter, psta);
+				/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);	 */
+
+				_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
+			}
+		}
+
+	}
+
+	_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
+	psta = NULL;
+
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	/* check asoc_queue */
+#ifdef DBG_EXPIRATION_CHK
+	if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
+		RTW_INFO(FUNC_NDEV_FMT" asoc_list, cnt:%u\n"
+			, FUNC_NDEV_ARG(padapter->pnetdev), pstapriv->asoc_list_cnt);
+	}
+#endif
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+#ifdef CONFIG_ATMEL_RC_PATCH
+		RTW_INFO("%s:%d  psta=%p, %02x,%02x||%02x,%02x  \n\n", __func__,  __LINE__,
+			psta, pstapriv->atmel_rc_pattern[0], pstapriv->atmel_rc_pattern[5], psta->cmn.mac_addr[0], psta->cmn.mac_addr[5]);
+		if (_rtw_memcmp((void *)pstapriv->atmel_rc_pattern, (void *)(psta->cmn.mac_addr), ETH_ALEN) == _TRUE)
+			continue;
+		if (psta->flag_atmel_rc)
+			continue;
+		RTW_INFO("%s: debug line:%d\n", __func__, __LINE__);
+#endif
+#ifdef CONFIG_AUTO_AP_MODE
+		if (psta->isrc)
+			continue;
+#endif
+		if (chk_sta_is_alive(psta) || !psta->expire_to) {
+			psta->expire_to = pstapriv->expire_to;
+			psta->keep_alive_trycnt = 0;
+#ifdef CONFIG_TX_MCAST2UNI
+			psta->under_exist_checking = 0;
+#endif	/* CONFIG_TX_MCAST2UNI */
+		} else
+			psta->expire_to--;
+
+#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+#ifdef CONFIG_80211N_HT
+#ifdef CONFIG_TX_MCAST2UNI
+		if ((psta->flags & WLAN_STA_HT) && (psta->htpriv.agg_enable_bitmap || psta->under_exist_checking)) {
+			/* check sta by delba(addba) for 11n STA */
+			/* ToDo: use CCX report to check for all STAs */
+			/* RTW_INFO("asoc check by DELBA/ADDBA! (pstapriv->expire_to=%d s)(psta->expire_to=%d s), [%02x, %d]\n", pstapriv->expire_to*2, psta->expire_to*2, psta->htpriv.agg_enable_bitmap, psta->under_exist_checking); */
+
+			if (psta->expire_to <= (pstapriv->expire_to - 50)) {
+				RTW_INFO("asoc expire by DELBA/ADDBA! (%d s)\n", (pstapriv->expire_to - psta->expire_to) * 2);
+				psta->under_exist_checking = 0;
+				psta->expire_to = 0;
+			} else if (psta->expire_to <= (pstapriv->expire_to - 3) && (psta->under_exist_checking == 0)) {
+				RTW_INFO("asoc check by DELBA/ADDBA! (%d s)\n", (pstapriv->expire_to - psta->expire_to) * 2);
+				psta->under_exist_checking = 1;
+				/* tear down TX AMPDU */
+				send_delba(padapter, 1, psta->cmn.mac_addr);/*  */ /* originator */
+				psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
+				psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
+			}
+		}
+#endif /* CONFIG_TX_MCAST2UNI */
+#endif /* CONFIG_80211N_HT */
+#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
+
+		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;
+			}
+
+#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+#ifdef CONFIG_80211N_HT
+
+#define KEEP_ALIVE_TRYCNT (3)
+
+			if (psta->keep_alive_trycnt > 0 && psta->keep_alive_trycnt <= KEEP_ALIVE_TRYCNT) {
+				if (psta->state & WIFI_STA_ALIVE_CHK_STATE)
+					psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
+				else
+					psta->keep_alive_trycnt = 0;
+
+			} else if ((psta->keep_alive_trycnt > KEEP_ALIVE_TRYCNT) && !(psta->state & WIFI_STA_ALIVE_CHK_STATE))
+				psta->keep_alive_trycnt = 0;
+			if ((psta->htpriv.ht_option == _TRUE) && (psta->htpriv.ampdu_enable == _TRUE)) {
+				uint priority = 1; /* test using BK */
+				u8 issued = 0;
+
+				/* issued = (psta->htpriv.agg_enable_bitmap>>priority)&0x1; */
+				issued |= (psta->htpriv.candidate_tid_bitmap >> priority) & 0x1;
+
+				if (0 == issued) {
+					if (!(psta->state & WIFI_STA_ALIVE_CHK_STATE)) {
+						psta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
+
+						if (psta->state & WIFI_SLEEP_STATE)
+							psta->expire_to = 2; /* 2x2=4 sec */
+						else
+							psta->expire_to = 1; /* 2 sec */
+
+						psta->state |= WIFI_STA_ALIVE_CHK_STATE;
+
+						/* add_ba_hdl(padapter, (u8*)paddbareq_parm); */
+
+						RTW_INFO("issue addba_req to check if sta alive, keep_alive_trycnt=%d\n", psta->keep_alive_trycnt);
+
+						issue_addba_req(padapter, psta->cmn.mac_addr, (u8)priority);
+
+						_set_timer(&psta->addba_retry_timer, ADDBA_TO);
+
+						psta->keep_alive_trycnt++;
+
+						continue;
+					}
+				}
+			}
+			if (psta->keep_alive_trycnt > 0 && psta->state & WIFI_STA_ALIVE_CHK_STATE) {
+				psta->keep_alive_trycnt = 0;
+				psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
+				RTW_INFO("change to another methods to check alive if staion is at ps mode\n");
+			}
+
+#endif /* CONFIG_80211N_HT */
+#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK	 */
+			if (psta->state & WIFI_SLEEP_STATE) {
+				if (!(psta->state & WIFI_STA_ALIVE_CHK_STATE)) {
+					/* to check if alive by another methods if staion is at ps mode.					 */
+					psta->expire_to = pstapriv->expire_to;
+					psta->state |= WIFI_STA_ALIVE_CHK_STATE;
+
+					/* RTW_INFO("alive chk, sta:" MAC_FMT " is at ps mode!\n", MAC_ARG(psta->cmn.mac_addr)); */
+
+					/* to update bcn with tim_bitmap for this station */
+					rtw_tim_map_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
+					update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
+
+					if (!pmlmeext->active_keep_alive_check)
+						continue;
+				}
+			}
+
+			{
+				int stainfo_offset;
+
+				stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
+				if (stainfo_offset_valid(stainfo_offset))
+					chk_alive_list[chk_alive_num++] = stainfo_offset;
+				continue;
+			}
+		} 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)
+			   ) {
+				RTW_INFO("%s sta:"MAC_FMT", sleepq_len:%u, free_xmitframe_cnt:%u, asoc_list_cnt:%u, clear sleep_q\n", __func__
+					 , MAC_ARG(psta->cmn.mac_addr)
+					, psta->sleepq_len, padapter->xmitpriv.free_xmitframe_cnt, pstapriv->asoc_list_cnt);
+				wakeup_sta_to_xmit(padapter, psta);
+			}
+		}
+	}
+
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	if (chk_alive_num) {
+		u8 backup_ch = 0, backup_bw = 0, backup_offset = 0;
+		u8 union_ch = 0, union_bw = 0, union_offset = 0;
+		u8 switch_channel_by_drv = _TRUE;
+		struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+		char del_asoc_list[NUM_STA];
+
+		_rtw_memset(del_asoc_list, NUM_STA, NUM_STA);
+
+		#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+		if (pmlmeext->active_keep_alive_check) {
+			#ifdef CONFIG_MCC_MODE
+			if (MCC_EN(padapter)) {
+				/* driver doesn't switch channel under MCC */
+				if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+					switch_channel_by_drv = _FALSE;
+			}
+			#endif
+
+			if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
+				|| pmlmeext->cur_channel != union_ch)
+				switch_channel_by_drv = _FALSE;
+
+			/* switch to correct channel of current network  before issue keep-alive frames */
+			if (switch_channel_by_drv == _TRUE && rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
+				backup_ch = rtw_get_oper_ch(padapter);
+				backup_bw = rtw_get_oper_bw(padapter);
+				backup_offset = rtw_get_oper_choffset(padapter);
+				set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			}
+		}
+		#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
+
+		/* check loop */
+		for (i = 0; i < chk_alive_num; i++) {
+			int ret = _FAIL;
+
+			psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
+
+			#ifdef CONFIG_ATMEL_RC_PATCH
+			if (_rtw_memcmp(pstapriv->atmel_rc_pattern, psta->cmn.mac_addr, ETH_ALEN) == _TRUE)
+				continue;
+			if (psta->flag_atmel_rc)
+				continue;
+			#endif
+
+			if (!(psta->state & _FW_LINKED))
+				continue;
+
+			#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+			if (pmlmeext->active_keep_alive_check) {
+				/* issue active keep alive frame to check */
+				ret = issue_aka_chk_frame(padapter, psta);
+
+				psta->keep_alive_trycnt++;
+				if (ret == _SUCCESS) {
+					RTW_INFO("asoc check, sta(" MAC_FMT ") is alive\n", MAC_ARG(psta->cmn.mac_addr));
+					psta->expire_to = pstapriv->expire_to;
+					psta->keep_alive_trycnt = 0;
+					continue;
+				} else if (psta->keep_alive_trycnt <= 3) {
+					RTW_INFO("ack check for asoc expire, keep_alive_trycnt=%d\n", psta->keep_alive_trycnt);
+					psta->expire_to = 1;
+					continue;
+				}
+			}
+			#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
+
+			psta->keep_alive_trycnt = 0;
+			del_asoc_list[i] = chk_alive_list[i];
+			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+			if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
+				rtw_list_delete(&psta->asoc_list);
+				pstapriv->asoc_list_cnt--;
+				STA_SET_MESH_PLINK(psta, NULL);
+			}
+			_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+		}
+
+		/* delete loop */
+		for (i = 0; i < chk_alive_num; i++) {
+			u8 sta_addr[ETH_ALEN];
+
+			if (del_asoc_list[i] >= NUM_STA)
+				continue;
+
+			psta = rtw_get_stainfo_by_offset(pstapriv, del_asoc_list[i]);
+			_rtw_memcpy(sta_addr, psta->cmn.mac_addr, ETH_ALEN);
+
+			RTW_INFO("asoc expire "MAC_FMT", state=0x%x\n", MAC_ARG(psta->cmn.mac_addr), psta->state);
+			updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_DEAUTH_LEAVING, _FALSE);
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter))
+				rtw_mesh_expire_peer(padapter, sta_addr);
+			#endif
+		}
+
+		#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+		if (pmlmeext->active_keep_alive_check) {
+			/* back to the original operation channel */
+			if (switch_channel_by_drv == _TRUE && backup_ch > 0)
+				set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
+		}
+		#endif
+	}
+
+	associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
+}
+
+void rtw_ap_update_sta_ra_info(_adapter *padapter, struct sta_info *psta)
+{
+	int i;
+	u8 rf_type;
+	unsigned char sta_band = 0;
+	u64 tx_ra_bitmap = 0;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX *pcur_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
+
+	if (!psta)
+		return;
+
+	if (!(psta->state & _FW_LINKED))
+		return;
+
+	rtw_hal_update_sta_ra_info(padapter, psta);
+	tx_ra_bitmap = psta->cmn.ra_info.ramask;
+
+	if (pcur_network->Configuration.DSConfig > 14) {
+
+		if (tx_ra_bitmap & 0xffff000)
+			sta_band |= WIRELESS_11_5N;
+
+		if (tx_ra_bitmap & 0xff0)
+			sta_band |= WIRELESS_11A;
+
+		/* 5G band */
+#ifdef CONFIG_80211AC_VHT
+		if (psta->vhtpriv.vht_option)
+			sta_band = WIRELESS_11_5AC;
+#endif
+	} else {
+		if (tx_ra_bitmap & 0xffff000)
+			sta_band |= WIRELESS_11_24N;
+
+		if (tx_ra_bitmap & 0xff0)
+			sta_band |= WIRELESS_11G;
+
+		if (tx_ra_bitmap & 0x0f)
+			sta_band |= WIRELESS_11B;
+	}
+
+	psta->wireless_mode = sta_band;
+	rtw_hal_update_sta_wset(padapter, psta);
+	RTW_INFO("%s=> mac_id:%d , tx_ra_bitmap:0x%016llx, networkType:0x%02x\n",
+			__FUNCTION__, psta->cmn.mac_id, tx_ra_bitmap, psta->wireless_mode);
+}
+
+#ifdef CONFIG_BMC_TX_RATE_SELECT
+u8 rtw_ap_find_mini_tx_rate(_adapter *adapter)
+{
+	_irqL irqL;
+	_list	*phead, *plist;
+	u8 miini_tx_rate = ODM_RATEVHTSS4MCS9, sta_tx_rate;
+	struct sta_info *psta = NULL;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+
+		sta_tx_rate = psta->cmn.ra_info.curr_tx_rate & 0x7F;
+		if (sta_tx_rate < miini_tx_rate)
+			miini_tx_rate = sta_tx_rate;
+	}
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	return miini_tx_rate;
+}
+
+u8 rtw_ap_find_bmc_rate(_adapter *adapter, u8 tx_rate)
+{
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(adapter);
+	u8 tx_ini_rate = ODM_RATE6M;
+
+	switch (tx_rate) {
+	case ODM_RATEVHTSS3MCS9:
+	case ODM_RATEVHTSS3MCS8:
+	case ODM_RATEVHTSS3MCS7:
+	case ODM_RATEVHTSS3MCS6:
+	case ODM_RATEVHTSS3MCS5:
+	case ODM_RATEVHTSS3MCS4:
+	case ODM_RATEVHTSS3MCS3:
+	case ODM_RATEVHTSS2MCS9:
+	case ODM_RATEVHTSS2MCS8:
+	case ODM_RATEVHTSS2MCS7:
+	case ODM_RATEVHTSS2MCS6:
+	case ODM_RATEVHTSS2MCS5:
+	case ODM_RATEVHTSS2MCS4:
+	case ODM_RATEVHTSS2MCS3:
+	case ODM_RATEVHTSS1MCS9:
+	case ODM_RATEVHTSS1MCS8:
+	case ODM_RATEVHTSS1MCS7:
+	case ODM_RATEVHTSS1MCS6:
+	case ODM_RATEVHTSS1MCS5:
+	case ODM_RATEVHTSS1MCS4:
+	case ODM_RATEVHTSS1MCS3:
+	case ODM_RATEMCS15:
+	case ODM_RATEMCS14:
+	case ODM_RATEMCS13:
+	case ODM_RATEMCS12:
+	case ODM_RATEMCS11:
+	case ODM_RATEMCS7:
+	case ODM_RATEMCS6:
+	case ODM_RATEMCS5:
+	case ODM_RATEMCS4:
+	case ODM_RATEMCS3:
+	case ODM_RATE54M:
+	case ODM_RATE48M:
+	case ODM_RATE36M:
+	case ODM_RATE24M:
+		tx_ini_rate = ODM_RATE24M;
+		break;
+	case ODM_RATEVHTSS3MCS2:
+	case ODM_RATEVHTSS3MCS1:
+	case ODM_RATEVHTSS2MCS2:
+	case ODM_RATEVHTSS2MCS1:
+	case ODM_RATEVHTSS1MCS2:
+	case ODM_RATEVHTSS1MCS1:
+	case ODM_RATEMCS10:
+	case ODM_RATEMCS9:
+	case ODM_RATEMCS2:
+	case ODM_RATEMCS1:
+	case ODM_RATE18M:
+	case ODM_RATE12M:
+		tx_ini_rate = ODM_RATE12M;
+		break;
+	case ODM_RATEVHTSS3MCS0:
+	case ODM_RATEVHTSS2MCS0:
+	case ODM_RATEVHTSS1MCS0:
+	case ODM_RATEMCS8:
+	case ODM_RATEMCS0:
+	case ODM_RATE9M:
+	case ODM_RATE6M:
+		tx_ini_rate = ODM_RATE6M;
+		break;
+	case ODM_RATE11M:
+	case ODM_RATE5_5M:
+	case ODM_RATE2M:
+	case ODM_RATE1M:
+		tx_ini_rate = ODM_RATE1M;
+		break;
+	default:
+		tx_ini_rate = ODM_RATE6M;
+		break;
+	}
+
+	if (hal_data->current_band_type == BAND_ON_5G)
+		if (tx_ini_rate < ODM_RATE6M)
+			tx_ini_rate = ODM_RATE6M;
+
+	return tx_ini_rate;
+}
+
+void rtw_update_bmc_sta_tx_rate(_adapter *adapter)
+{
+	struct sta_info *psta = NULL;
+	u8 tx_rate;
+
+	psta = rtw_get_bcmc_stainfo(adapter);
+	if (psta == NULL) {
+		RTW_ERR(ADPT_FMT "could not get bmc_sta !!\n", ADPT_ARG(adapter));
+		return;
+	}
+
+	if (adapter->bmc_tx_rate != MGN_UNKNOWN) {
+		psta->init_rate = adapter->bmc_tx_rate;
+		goto _exit;
+	}
+
+	if (adapter->stapriv.asoc_sta_count <= 2)
+		goto _exit;
+
+	tx_rate = rtw_ap_find_mini_tx_rate(adapter);
+	#ifdef CONFIG_BMC_TX_LOW_RATE
+	tx_rate = rtw_ap_find_bmc_rate(adapter, tx_rate);
+	#endif
+
+	psta->init_rate = hw_rate_to_m_rate(tx_rate);
+
+_exit:
+	RTW_INFO(ADPT_FMT" BMC Tx rate - %s\n", ADPT_ARG(adapter), MGN_RATE_STR(psta->init_rate));
+}
+#endif
+
+void rtw_init_bmc_sta_tx_rate(_adapter *padapter, struct sta_info *psta)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	u8 rate_idx = 0;
+	u8 brate_table[] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M,
+		MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M};
+
+	if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
+		return;
+
+	if (padapter->bmc_tx_rate != MGN_UNKNOWN)
+		psta->init_rate = padapter->bmc_tx_rate;
+	else {
+		#ifdef CONFIG_BMC_TX_LOW_RATE
+		if (IsEnableHWOFDM(pmlmeext->cur_wireless_mode) && (psta->cmn.ra_info.ramask && 0xFF0))
+			rate_idx = get_lowest_rate_idx_ex(psta->cmn.ra_info.ramask, 4); /*from basic rate*/
+		else
+			rate_idx = get_lowest_rate_idx(psta->cmn.ra_info.ramask); /*from basic rate*/
+		#else
+		rate_idx = get_highest_rate_idx(psta->cmn.ra_info.ramask); /*from basic rate*/
+		#endif
+		if (rate_idx < 12)
+			psta->init_rate = brate_table[rate_idx];
+		else
+			psta->init_rate = MGN_1M;
+	}
+
+	RTW_INFO(ADPT_FMT" BMC Init Tx rate - %s\n", ADPT_ARG(padapter), MGN_RATE_STR(psta->init_rate));
+}
+
+void update_bmc_sta(_adapter *padapter)
+{
+	_irqL	irqL;
+	unsigned char	network_type;
+	int supportRateNum = 0;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX *pcur_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
+	struct sta_info *psta = rtw_get_bcmc_stainfo(padapter);
+
+	if (psta) {
+		psta->cmn.aid = 0;/* default set to 0 */
+#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter))
+			psta->qos_option = 1;
+		else
+#endif
+			psta->qos_option = 0;
+#ifdef CONFIG_80211N_HT
+		psta->htpriv.ht_option = _FALSE;
+#endif /* CONFIG_80211N_HT */
+
+		psta->ieee8021x_blocked = 0;
+
+		_rtw_memset((void *)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
+
+		/* psta->dot118021XPrivacy = _NO_PRIVACY_; */ /* !!! remove it, because it has been set before this. */
+
+		supportRateNum = rtw_get_rateset_len((u8 *)&pcur_network->SupportedRates);
+		network_type = rtw_check_network_type((u8 *)&pcur_network->SupportedRates, supportRateNum, pcur_network->Configuration.DSConfig);
+		if (IsSupportedTxCCK(network_type))
+			network_type = WIRELESS_11B;
+		else if (network_type == WIRELESS_INVALID) { /* error handling */
+			if (pcur_network->Configuration.DSConfig > 14)
+				network_type = WIRELESS_11A;
+			else
+				network_type = WIRELESS_11B;
+		}
+		update_sta_basic_rate(psta, network_type);
+		psta->wireless_mode = network_type;
+
+		rtw_hal_update_sta_ra_info(padapter, psta);
+
+		_enter_critical_bh(&psta->lock, &irqL);
+		psta->state = _FW_LINKED;
+		_exit_critical_bh(&psta->lock, &irqL);
+
+		rtw_sta_media_status_rpt(padapter, psta, 1);
+		rtw_init_bmc_sta_tx_rate(padapter, psta);
+
+	} else
+		RTW_INFO("add_RATid_bmc_sta error!\n");
+
+}
+
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_BEAMFORMING)
+void update_sta_info_apmode_ht_bf_cap(_adapter *padapter, struct sta_info *psta)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ht_priv	*phtpriv_ap = &pmlmepriv->htpriv;
+	struct ht_priv	*phtpriv_sta = &psta->htpriv;
+
+	u8 cur_beamform_cap = 0;
+
+	/*Config Tx beamforming setting*/
+	if (TEST_FLAG(phtpriv_ap->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
+		GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP((u8 *)(&phtpriv_sta->ht_cap))) {
+		SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
+		/*Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
+		SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS((u8 *)(&phtpriv_sta->ht_cap)) << 6);
+	}
+
+	if (TEST_FLAG(phtpriv_ap->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
+		GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP((u8 *)(&phtpriv_sta->ht_cap))) {
+		SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
+		/*Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
+		SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS((u8 *)(&phtpriv_sta->ht_cap)) << 4);
+	}
+	if (cur_beamform_cap)
+		RTW_INFO("Client STA(%d) HT Beamforming Cap = 0x%02X\n", psta->cmn.aid, cur_beamform_cap);
+
+	phtpriv_sta->beamform_cap = cur_beamform_cap;
+	psta->cmn.bf_info.ht_beamform_cap = cur_beamform_cap;
+
+}
+#endif /*CONFIG_80211N_HT && CONFIG_BEAMFORMING*/
+
+/* notes:
+ * AID: 1~MAX for sta and 0 for bc/mc in ap/adhoc mode  */
+void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta)
+{
+	_irqL	irqL;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+#ifdef CONFIG_80211N_HT
+	struct ht_priv	*phtpriv_ap = &pmlmepriv->htpriv;
+	struct ht_priv	*phtpriv_sta = &psta->htpriv;
+#endif /* CONFIG_80211N_HT */
+	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0;
+	/* set intf_tag to if1 */
+	/* psta->intf_tag = 0; */
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	/*alloc macid when call rtw_alloc_stainfo(),release macid when call rtw_free_stainfo()*/
+
+	if (!MLME_IS_MESH(padapter) && psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
+		psta->ieee8021x_blocked = _TRUE;
+	else
+		psta->ieee8021x_blocked = _FALSE;
+
+
+	/* update sta's cap */
+
+	/* ERP */
+	VCS_update(padapter, psta);
+#ifdef CONFIG_80211N_HT
+	/* HT related cap */
+	if (phtpriv_sta->ht_option) {
+		/* check if sta supports rx ampdu */
+		phtpriv_sta->ampdu_enable = phtpriv_ap->ampdu_enable;
+
+		phtpriv_sta->rx_ampdu_min_spacing = (phtpriv_sta->ht_cap.ampdu_params_info & IEEE80211_HT_CAP_AMPDU_DENSITY) >> 2;
+
+		/* bwmode */
+		if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH))
+			psta->cmn.bw_mode = CHANNEL_WIDTH_40;
+		else
+			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
+
+		if (phtpriv_sta->op_present
+			&& !GET_HT_OP_ELE_STA_CHL_WIDTH(phtpriv_sta->ht_op))
+			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
+
+		if (psta->ht_40mhz_intolerant)
+			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
+
+		if (pmlmeext->cur_bwmode < psta->cmn.bw_mode)
+			psta->cmn.bw_mode = pmlmeext->cur_bwmode;
+
+		phtpriv_sta->ch_offset = pmlmeext->cur_ch_offset;
+
+
+		/* check if sta support s Short GI 20M */
+		if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_20))
+			phtpriv_sta->sgi_20m = _TRUE;
+
+		/* check if sta support s Short GI 40M */
+		if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_40)) {
+			if (psta->cmn.bw_mode == CHANNEL_WIDTH_40) /* according to psta->bw_mode */
+				phtpriv_sta->sgi_40m = _TRUE;
+			else
+				phtpriv_sta->sgi_40m = _FALSE;
+		}
+
+		psta->qos_option = _TRUE;
+
+		/* B0 Config LDPC Coding Capability */
+		if (TEST_FLAG(phtpriv_ap->ldpc_cap, LDPC_HT_ENABLE_TX) &&
+		    GET_HT_CAP_ELE_LDPC_CAP((u8 *)(&phtpriv_sta->ht_cap))) {
+			SET_FLAG(cur_ldpc_cap, (LDPC_HT_ENABLE_TX | LDPC_HT_CAP_TX));
+			RTW_INFO("Enable HT Tx LDPC for STA(%d)\n", psta->cmn.aid);
+		}
+
+		/* B7 B8 B9 Config STBC setting */
+		if (TEST_FLAG(phtpriv_ap->stbc_cap, STBC_HT_ENABLE_TX) &&
+		    GET_HT_CAP_ELE_RX_STBC((u8 *)(&phtpriv_sta->ht_cap))) {
+			SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX));
+			RTW_INFO("Enable HT Tx STBC for STA(%d)\n", psta->cmn.aid);
+		}
+
+		#ifdef CONFIG_BEAMFORMING
+		update_sta_info_apmode_ht_bf_cap(padapter, psta);
+		#endif
+	} else {
+		phtpriv_sta->ampdu_enable = _FALSE;
+
+		phtpriv_sta->sgi_20m = _FALSE;
+		phtpriv_sta->sgi_40m = _FALSE;
+		psta->cmn.bw_mode = CHANNEL_WIDTH_20;
+		phtpriv_sta->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	}
+
+	phtpriv_sta->ldpc_cap = cur_ldpc_cap;
+	phtpriv_sta->stbc_cap = cur_stbc_cap;
+
+	/* Rx AMPDU */
+	send_delba(padapter, 0, psta->cmn.mac_addr);/* recipient */
+
+	/* TX AMPDU */
+	send_delba(padapter, 1, psta->cmn.mac_addr);/*  */ /* originator */
+	phtpriv_sta->agg_enable_bitmap = 0x0;/* reset */
+	phtpriv_sta->candidate_tid_bitmap = 0x0;/* reset */
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_80211AC_VHT
+	update_sta_vht_info_apmode(padapter, psta);
+#endif
+	psta->cmn.ra_info.is_support_sgi = query_ra_short_GI(psta, rtw_get_tx_bw_mode(padapter, psta));
+	update_ldpc_stbc_cap(psta);
+
+	/* todo: init other variables */
+
+	_rtw_memset((void *)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
+
+
+	/* add ratid */
+	/* add_RATid(padapter, psta); */ /* move to ap_sta_info_defer_update() */
+
+	/* ap mode */
+	rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
+
+	_enter_critical_bh(&psta->lock, &irqL);
+	psta->state |= _FW_LINKED;
+	_exit_critical_bh(&psta->lock, &irqL);
+
+
+}
+
+static void update_ap_info(_adapter *padapter, struct sta_info *psta)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+#ifdef CONFIG_80211N_HT
+	struct ht_priv	*phtpriv_ap = &pmlmepriv->htpriv;
+#endif /* CONFIG_80211N_HT */
+
+	psta->wireless_mode = pmlmeext->cur_wireless_mode;
+
+	psta->bssratelen = rtw_get_rateset_len(pnetwork->SupportedRates);
+	_rtw_memcpy(psta->bssrateset, pnetwork->SupportedRates, psta->bssratelen);
+
+#ifdef CONFIG_80211N_HT
+	/* HT related cap */
+	if (phtpriv_ap->ht_option) {
+		/* check if sta supports rx ampdu */
+		/* phtpriv_ap->ampdu_enable = phtpriv_ap->ampdu_enable; */
+
+		/* check if sta support s Short GI 20M */
+		if ((phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_20))
+			phtpriv_ap->sgi_20m = _TRUE;
+		/* check if sta support s Short GI 40M */
+		if ((phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_40))
+			phtpriv_ap->sgi_40m = _TRUE;
+
+		psta->qos_option = _TRUE;
+	} else {
+		phtpriv_ap->ampdu_enable = _FALSE;
+
+		phtpriv_ap->sgi_20m = _FALSE;
+		phtpriv_ap->sgi_40m = _FALSE;
+	}
+
+	psta->cmn.bw_mode = pmlmeext->cur_bwmode;
+	phtpriv_ap->ch_offset = pmlmeext->cur_ch_offset;
+
+	phtpriv_ap->agg_enable_bitmap = 0x0;/* reset */
+	phtpriv_ap->candidate_tid_bitmap = 0x0;/* reset */
+
+	_rtw_memcpy(&psta->htpriv, &pmlmepriv->htpriv, sizeof(struct ht_priv));
+
+#ifdef CONFIG_80211AC_VHT
+	_rtw_memcpy(&psta->vhtpriv, &pmlmepriv->vhtpriv, sizeof(struct vht_priv));
+#endif /* CONFIG_80211AC_VHT */
+
+#endif /* CONFIG_80211N_HT */
+
+	psta->state |= WIFI_AP_STATE; /* Aries, add,fix bug of flush_cam_entry at STOP AP mode , 0724 */
+}
+
+static void rtw_set_hw_wmm_param(_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;
+
+	acm_mask = 0;
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) ||
+	    (pmlmeext->cur_wireless_mode & WIRELESS_11_24N))
+		aSifsTime = 16;
+	else
+		aSifsTime = 10;
+
+	if (pmlmeinfo->WMM_enable == 0) {
+		padapter->mlmepriv.acm_mask = 0;
+
+		AIFS = aSifsTime + (2 * pmlmeinfo->slotTime);
+
+		if (pmlmeext->cur_wireless_mode & (WIRELESS_11G | WIRELESS_11A)) {
+			ECWMin = 4;
+			ECWMax = 10;
+		} else if (pmlmeext->cur_wireless_mode & WIRELESS_11B) {
+			ECWMin = 5;
+			ECWMax = 10;
+		} else {
+			ECWMin = 4;
+			ECWMax = 10;
+		}
+
+		TXOP = 0;
+		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
+
+		ECWMin = 2;
+		ECWMax = 3;
+		TXOP = 0x2f;
+		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
+
+	} else {
+		edca[0] = edca[1] = edca[2] = edca[3] = 0;
+
+		/*TODO:*/
+		acm_mask = 0;
+		padapter->mlmepriv.acm_mask = acm_mask;
+
+#if 0
+		/* BK */
+		/* AIFS = AIFSN * slot time + SIFS - r2t phy delay */
+#endif
+		AIFS = (7 * pmlmeinfo->slotTime) + aSifsTime;
+		ECWMin = 4;
+		ECWMax = 10;
+		TXOP = 0;
+		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
+		edca[XMIT_BK_QUEUE] = acParm;
+		RTW_INFO("WMM(BK): %x\n", acParm);
+
+		/* BE */
+		AIFS = (3 * pmlmeinfo->slotTime) + aSifsTime;
+		ECWMin = 4;
+		ECWMax = 6;
+		TXOP = 0;
+		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
+		edca[XMIT_BE_QUEUE] = acParm;
+		RTW_INFO("WMM(BE): %x\n", acParm);
+
+		/* VI */
+		AIFS = (1 * pmlmeinfo->slotTime) + aSifsTime;
+		ECWMin = 3;
+		ECWMax = 4;
+		TXOP = 94;
+		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
+		edca[XMIT_VI_QUEUE] = acParm;
+		RTW_INFO("WMM(VI): %x\n", acParm);
+
+		/* VO */
+		AIFS = (1 * pmlmeinfo->slotTime) + aSifsTime;
+		ECWMin = 2;
+		ECWMax = 3;
+		TXOP = 47;
+		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
+		edca[XMIT_VO_QUEUE] = acParm;
+		RTW_INFO("WMM(VO): %x\n", acParm);
+
+
+		if (padapter->registrypriv.acm_method == 1)
+			rtw_hal_set_hwreg(padapter, HW_VAR_ACM_CTRL, (u8 *)(&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, tmp, 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) {
+						tmp = edca[i];
+						edca[i] = edca[j];
+						edca[j] = tmp;
+
+						tmp = inx[i];
+						inx[i] = inx[j];
+						inx[j] = tmp;
+
+						change_inx = _FALSE;
+					}
+				}
+			}
+		}
+
+		for (i = 0 ; i < 4 ; i++) {
+			pxmitpriv->wmm_para_seq[i] = inx[i];
+			RTW_INFO("wmm_para_seq(%d): %d\n", i, pxmitpriv->wmm_para_seq[i]);
+		}
+
+	}
+
+}
+
+static void update_hw_ht_param(_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);
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+
+	/* 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_caps.u.HT_cap_element.AMPDU_para & 0x03;
+
+	min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;
+
+	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MIN_SPACE, (u8 *)(&min_MPDU_spacing));
+
+	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&max_AMPDU_len));
+
+	/*  */
+	/* Config SM Power Save setting */
+	/*  */
+	pmlmeinfo->SM_PS = (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & 0x0C) >> 2;
+	if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC) {
+#if 0
+		u8 i;
+		/* update the MCS rates */
+		for (i = 0; i < 16; i++)
+			pmlmeinfo->HT_caps.HT_cap_element.MCS_rate[i] &= MCS_rate_1R[i];
+#endif
+		RTW_INFO("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __FUNCTION__);
+	}
+
+	/*  */
+	/* Config current HT Protection mode. */
+	/*  */
+	/* pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3; */
+
+}
+
+static void rtw_ap_check_scan(_adapter *padapter)
+{
+	_irqL	irqL;
+	_list		*plist, *phead;
+	u32	delta_time, lifetime;
+	struct	wlan_network	*pnetwork = NULL;
+	WLAN_BSSID_EX *pbss = NULL;
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	_queue	*queue	= &(pmlmepriv->scanned_queue);
+	u8 do_scan = _FALSE;
+	u8 reason = RTW_AUTO_SCAN_REASON_UNSPECIFIED;
+
+	lifetime = SCANQUEUE_LIFETIME; /* 20 sec */
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+	phead = get_list_head(queue);
+	if (rtw_end_of_queue_search(phead, get_next(phead)) == _TRUE)
+		if (padapter->registrypriv.wifi_spec) {
+			do_scan = _TRUE;
+			reason |= RTW_AUTO_SCAN_REASON_2040_BSS;
+		}
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+#ifdef CONFIG_RTW_ACS
+	if (padapter->registrypriv.acs_auto_scan) {
+		do_scan = _TRUE;
+		reason |= RTW_AUTO_SCAN_REASON_ACS;
+		rtw_acs_start(padapter);
+	}
+#endif/*CONFIG_RTW_ACS*/
+
+	if (_TRUE == do_scan) {
+		RTW_INFO("%s : drv scans by itself and wait_completed\n", __func__);
+		rtw_drv_scan_by_self(padapter, reason);
+		rtw_scan_wait_completed(padapter);
+	}
+
+#ifdef CONFIG_RTW_ACS
+	if (padapter->registrypriv.acs_auto_scan)
+		rtw_acs_stop(padapter);
+#endif
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
+		    && rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
+		    && _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))) {
+			delta_time = (u32) rtw_get_passing_time_ms(pnetwork->last_scanned);
+
+			if (delta_time < lifetime) {
+
+				uint ie_len = 0;
+				u8 *pbuf = NULL;
+				u8 *ie = NULL;
+
+				pbss = &pnetwork->network;
+				ie = pbss->IEs;
+
+				/*check if HT CAP INFO IE exists or not*/
+				pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss->IELength - _BEACON_IE_OFFSET_));
+				if (pbuf == NULL) {
+					/* HT CAP INFO IE don't exist, it is b/g mode bss.*/
+
+					if (_FALSE == ATOMIC_READ(&pmlmepriv->olbc))
+						ATOMIC_SET(&pmlmepriv->olbc, _TRUE);
+
+					if (_FALSE == ATOMIC_READ(&pmlmepriv->olbc_ht))
+						ATOMIC_SET(&pmlmepriv->olbc_ht, _TRUE);
+					
+					if (padapter->registrypriv.wifi_spec)
+						RTW_INFO("%s: %s is a/b/g ap\n", __func__, pnetwork->network.Ssid.Ssid);
+				}
+			}
+		}
+
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	pmlmepriv->num_sta_no_ht = 0; /* reset to 0 after ap do scanning*/
+
+}
+
+void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter)
+{
+	WLAN_BSSID_EX *pnetwork = &(adapter->mlmepriv.cur_network.network);
+	struct sta_info *sta = NULL;
+
+	/* update cur_wireless_mode */
+	update_wireless_mode(adapter);
+
+	/* update RRSR and RTS_INIT_RATE register after set channel and bandwidth */
+	UpdateBrateTbl(adapter, pnetwork->SupportedRates);
+	rtw_hal_set_hwreg(adapter, HW_VAR_BASIC_RATE, pnetwork->SupportedRates);
+
+	/* update capability after cur_wireless_mode updated */
+	update_capinfo(adapter, rtw_get_capability(pnetwork));
+
+	/* update bc/mc sta_info */
+	update_bmc_sta(adapter);
+
+	/* update AP's sta info */
+	sta = rtw_get_stainfo(&adapter->stapriv, pnetwork->MacAddress);
+	if (!sta) {
+		RTW_INFO(FUNC_ADPT_FMT" !sta for macaddr="MAC_FMT"\n", FUNC_ADPT_ARG(adapter), MAC_ARG(pnetwork->MacAddress));
+		rtw_warn_on(1);
+		return;
+	}
+
+	update_ap_info(adapter, sta);
+}
+
+void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
+{
+#define DUMP_ADAPTERS_STATUS 0
+	u8 self_action = MLME_ACTION_UNKNOWN;
+	u8 val8;
+	u16 bcn_interval;
+	u32	acparm;
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network; /* used as input */
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork_mlmeext = &(pmlmeinfo->network);
+	struct dvobj_priv *pdvobj = padapter->dvobj;
+	s16 req_ch = REQ_CH_NONE, req_bw = REQ_BW_NONE, req_offset = REQ_OFFSET_NONE;
+	bool ch_setting_changed = _FALSE;
+	u8 ch_to_set = 0, bw_to_set, offset_to_set;
+	u8 doiqk = _FALSE;
+	/* use for check ch bw offset can be allowed or not */
+	u8 chbw_allow = _TRUE;
+
+	if (MLME_IS_AP(padapter))
+		self_action = MLME_AP_STARTED;
+	else if (MLME_IS_MESH(padapter))
+		self_action = MLME_MESH_STARTED;
+	else
+		rtw_warn_on(1);
+
+	if (parm->req_ch != 0) {
+		/* bypass other setting, go checking ch, bw, offset */
+		req_ch = parm->req_ch;
+		req_bw = parm->req_bw;
+		req_offset = parm->req_offset;
+		goto chbw_decision;
+	} else {
+		/* inform this request comes from upper layer */
+		req_ch = 0;
+		_rtw_memcpy(pnetwork_mlmeext, pnetwork, pnetwork->Length);
+	}
+
+	bcn_interval = (u16)pnetwork->Configuration.BeaconPeriod;
+
+	/* 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 (NULL == rtw_get_wps_ie(pnetwork->IEs + _FIXED_IE_LENGTH_, pnetwork->IELength - _FIXED_IE_LENGTH_, NULL, NULL))
+		pmlmeext->bstart_bss = _TRUE;
+
+	/* todo: update wmm, ht cap */
+	/* pmlmeinfo->WMM_enable; */
+	/* pmlmeinfo->HT_enable; */
+	if (pmlmepriv->qospriv.qos_option)
+		pmlmeinfo->WMM_enable = _TRUE;
+#ifdef CONFIG_80211N_HT
+	if (pmlmepriv->htpriv.ht_option) {
+		pmlmeinfo->WMM_enable = _TRUE;
+		pmlmeinfo->HT_enable = _TRUE;
+		/* pmlmeinfo->HT_info_enable = _TRUE; */
+		/* pmlmeinfo->HT_caps_enable = _TRUE; */
+
+		update_hw_ht_param(padapter);
+	}
+#endif /* #CONFIG_80211N_HT */
+
+#ifdef CONFIG_80211AC_VHT
+	if (pmlmepriv->vhtpriv.vht_option) {
+		pmlmeinfo->VHT_enable = _TRUE;
+		update_hw_vht_param(padapter);
+	}
+#endif /* CONFIG_80211AC_VHT */
+
+	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 != _WEP40_) && (psecuritypriv->dot11PrivacyAlgrthm != _WEP104_)
+			&& !MLME_IS_MESH(padapter) /* mesh group key is set before this function */
+		)
+			flush_all_cam_entry(padapter);	/* clear CAM */
+	}
+
+	/* set MSR to AP_Mode		 */
+	Set_MSR(padapter, _HW_STATE_AP_);
+
+	/* Set BSSID REG */
+	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pnetwork->MacAddress);
+
+	/* Set EDCA param reg */
+#ifdef CONFIG_CONCURRENT_MODE
+	acparm = 0x005ea42b;
+#else
+	acparm = 0x002F3217; /* VO */
+#endif
+	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acparm));
+	acparm = 0x005E4317; /* VI */
+	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acparm));
+	/* acparm = 0x00105320; */ /* BE */
+	acparm = 0x005ea42b;
+	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
+	acparm = 0x0000A444; /* BK */
+	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acparm));
+
+	/* Set Security */
+	val8 = (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) ? 0xcc : 0xcf;
+	rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+
+	/* Beacon Control related register */
+	rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&bcn_interval));
+
+chbw_decision:
+	ch_setting_changed = rtw_ap_chbw_decision(padapter, req_ch, req_bw, req_offset
+		     , &ch_to_set, &bw_to_set, &offset_to_set, &chbw_allow);
+
+	/* let pnetwork_mlme == pnetwork_mlmeext */
+	_rtw_memcpy(pnetwork, pnetwork_mlmeext, pnetwork_mlmeext->Length);
+
+	rtw_start_bss_hdl_after_chbw_decided(padapter);
+
+#if defined(CONFIG_DFS_MASTER)
+	rtw_dfs_master_status_apply(padapter, self_action);
+#endif
+	rtw_hal_rcr_set_chk_bssid(padapter, self_action);
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter)) {
+		/* 
+		* due to check under rtw_ap_chbw_decision
+		* if under MCC mode, means req channel setting is the same as current channel setting
+		* if not under MCC mode, mean req channel setting is not the same as current channel setting
+		*/
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+				RTW_INFO(FUNC_ADPT_FMT": req channel setting is the same as current channel setting, go to update BCN\n"
+				, FUNC_ADPT_ARG(padapter));
+
+				goto update_beacon;
+
+		}
+	}
+
+	/* issue null data to AP for all interface connecting to AP before switch channel setting for softap */
+	rtw_hal_mcc_issue_null_data(padapter, chbw_allow, 1);
+#endif /* CONFIG_MCC_MODE */
+
+	if (!IS_CH_WAITING(adapter_to_rfctl(padapter))) {
+		doiqk = _TRUE;
+		rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+	}
+
+	if (ch_to_set != 0) {
+		set_channel_bwmode(padapter, ch_to_set, offset_to_set, bw_to_set);
+		rtw_mi_update_union_chan_inf(padapter, ch_to_set, offset_to_set, bw_to_set);
+	}
+
+	doiqk = _FALSE;
+	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+
+#ifdef CONFIG_MCC_MODE
+	/* after set_channel_bwmode for backup IQK */
+	rtw_hal_set_mcc_setting_start_bss_network(padapter, chbw_allow);
+#endif
+
+	if (ch_setting_changed == _TRUE
+		&& (MLME_IS_GO(padapter) || MLME_IS_MESH(padapter)) /* pure AP is not needed*/
+	) {
+		#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+		rtw_cfg80211_ch_switch_notify(padapter
+			, pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset
+			, pmlmepriv->htpriv.ht_option);
+		#endif
+	}
+
+	if (DUMP_ADAPTERS_STATUS) {
+		RTW_INFO(FUNC_ADPT_FMT" done\n", FUNC_ADPT_ARG(padapter));
+		dump_adapters_status(RTW_DBGDUMP , adapter_to_dvobj(padapter));
+	}
+
+update_beacon:
+	/* update beacon content only if bstart_bss is _TRUE */
+	if (_TRUE == pmlmeext->bstart_bss) {
+
+		_irqL irqL;
+
+		if ((ATOMIC_READ(&pmlmepriv->olbc) == _TRUE) || (ATOMIC_READ(&pmlmepriv->olbc_ht) == _TRUE)) {
+			/* AP is not starting a 40 MHz BSS in presence of an 802.11g BSS. */
+
+			pmlmepriv->ht_op_mode &= (~HT_INFO_OPERATION_MODE_OP_MODE_MASK);
+			pmlmepriv->ht_op_mode |= OP_MODE_MAY_BE_LEGACY_STAS;
+			update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
+		}
+
+		update_beacon(padapter, _TIM_IE_, NULL, _FALSE);
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+		_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+		if (rtw_is_list_empty(&padapter->list)) {
+			rtw_list_insert_tail(&padapter->list, get_list_head(&pdvobj->ap_if_q));
+			pdvobj->nr_ap_if++;
+			pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL / pdvobj->nr_ap_if;
+		}
+		_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+
+		rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pdvobj->inter_bcn_space));
+
+#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
+
+	}
+
+	rtw_scan_wait_completed(padapter);
+
+	/* send beacon */
+	if (!rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY)) {
+
+		/*update_beacon(padapter, _TIM_IE_, NULL, _TRUE);*/
+
+#if !defined(CONFIG_INTERRUPT_BASED_TXBCN)
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+		if (pdvobj->nr_ap_if == 1) {
+			RTW_INFO("start SW BCN TIMER!\n");
+			_set_timer(&pdvobj->txbcn_timer, bcn_interval);
+		}
+#else
+		/* other case will  tx beacon when bcn interrupt coming in. */
+		if (send_beacon(padapter) == _FAIL)
+			RTW_INFO("issue_beacon, fail!\n");
+#endif
+#endif
+#endif /* !defined(CONFIG_INTERRUPT_BASED_TXBCN) */
+	}
+
+	/*Set EDCA param reg after update cur_wireless_mode & update_capinfo*/
+	if (pregpriv->wifi_spec == 1)
+		rtw_set_hw_wmm_param(padapter);
+
+	/*pmlmeext->bstart_bss = _TRUE;*/
+}
+
+int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
+{
+	int ret = _SUCCESS;
+	u8 *p;
+	u8 *pHT_caps_ie = NULL;
+	u8 *pHT_info_ie = NULL;
+	u16 cap, ht_cap = _FALSE;
+	uint ie_len = 0;
+	int group_cipher, pairwise_cipher;
+	u8 mfp_opt = MFP_NO;
+	u8	channel, network_type, supportRate[NDIS_802_11_LENGTH_RATES_EX];
+	int supportRateNum = 0;
+	u8 OUI1[] = {0x00, 0x50, 0xf2, 0x01};
+	u8 wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
+	u8 WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
+	HT_CAP_AMPDU_DENSITY best_ampdu_density;
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	WLAN_BSSID_EX *pbss_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *ie = pbss_network->IEs;
+	u8 vht_cap = _FALSE;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	u8 rf_num = 0;
+
+	/* 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 */
+
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
+
+	if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
+		return _FAIL;
+
+
+	if (len > MAX_IE_SZ)
+		return _FAIL;
+
+	pbss_network->IELength = len;
+
+	_rtw_memset(ie, 0, MAX_IE_SZ);
+
+	_rtw_memcpy(ie, pbuf, pbss_network->IELength);
+
+
+	if (pbss_network->InfrastructureMode != Ndis802_11APMode
+		&& pbss_network->InfrastructureMode != Ndis802_11_mesh
+	) {
+		rtw_warn_on(1);
+		return _FAIL;
+	}
+
+
+	rtw_ap_check_scan(padapter);
+
+
+	pbss_network->Rssi = 0;
+
+	_rtw_memcpy(pbss_network->MacAddress, adapter_mac_addr(padapter), ETH_ALEN);
+
+	/* beacon interval */
+	p = rtw_get_beacon_interval_from_ie(ie);/* ie + 8;	 */ /* 8: TimeStamp, 2: Beacon Interval 2:Capability */
+	/* pbss_network->Configuration.BeaconPeriod = le16_to_cpu(*(unsigned short*)p); */
+	pbss_network->Configuration.BeaconPeriod = RTW_GET_LE16(p);
+
+	/* capability */
+	/* cap = *(unsigned short *)rtw_get_capability_from_ie(ie); */
+	/* cap = le16_to_cpu(cap); */
+	cap = RTW_GET_LE16(ie);
+
+	/* SSID */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _SSID_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0) {
+		_rtw_memset(&pbss_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
+		_rtw_memcpy(pbss_network->Ssid.Ssid, (p + 2), ie_len);
+		pbss_network->Ssid.SsidLength = ie_len;
+#ifdef CONFIG_P2P
+		_rtw_memcpy(padapter->wdinfo.p2p_group_ssid, pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength);
+		padapter->wdinfo.p2p_group_ssid_len = pbss_network->Ssid.SsidLength;
+#endif
+	}
+
+#ifdef CONFIG_RTW_MESH
+	/* Mesh ID */
+	if (MLME_IS_MESH(padapter)) {
+		p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, WLAN_EID_MESH_ID, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+		if (p && ie_len > 0) {
+			_rtw_memset(&pbss_network->mesh_id, 0, sizeof(NDIS_802_11_SSID));
+			_rtw_memcpy(pbss_network->mesh_id.Ssid, (p + 2), ie_len);
+			pbss_network->mesh_id.SsidLength = ie_len;
+		}
+	}
+#endif
+
+	/* chnnel */
+	channel = 0;
+	pbss_network->Configuration.Length = 0;
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _DSSET_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0)
+		channel = *(p + 2);
+
+	pbss_network->Configuration.DSConfig = channel;
+
+
+	_rtw_memset(supportRate, 0, NDIS_802_11_LENGTH_RATES_EX);
+	/* get supported rates */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p !=  NULL) {
+		_rtw_memcpy(supportRate, p + 2, ie_len);
+		supportRateNum = ie_len;
+	}
+
+	/* get ext_supported rates */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, &ie_len, pbss_network->IELength - _BEACON_IE_OFFSET_);
+	if (p !=  NULL) {
+		_rtw_memcpy(supportRate + supportRateNum, p + 2, ie_len);
+		supportRateNum += ie_len;
+
+	}
+
+	network_type = rtw_check_network_type(supportRate, supportRateNum, channel);
+
+	rtw_set_supported_rate(pbss_network->SupportedRates, network_type);
+
+
+	/* parsing ERP_IE */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _ERPINFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0)
+		ERP_IE_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)p);
+
+	/* update privacy/security */
+	if (cap & 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 = _NO_PRIVACY_;
+	psecuritypriv->wpa2_pairwise_cipher = _NO_PRIVACY_;
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0) {
+		if (rtw_parse_wpa2_ie(p, ie_len + 2, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _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;
+#if 0
+			switch (group_cipher) {
+			case WPA_CIPHER_NONE:
+				psecuritypriv->wpa2_group_cipher = _NO_PRIVACY_;
+				break;
+			case WPA_CIPHER_WEP40:
+				psecuritypriv->wpa2_group_cipher = _WEP40_;
+				break;
+			case WPA_CIPHER_TKIP:
+				psecuritypriv->wpa2_group_cipher = _TKIP_;
+				break;
+			case WPA_CIPHER_CCMP:
+				psecuritypriv->wpa2_group_cipher = _AES_;
+				break;
+			case WPA_CIPHER_WEP104:
+				psecuritypriv->wpa2_group_cipher = _WEP104_;
+				break;
+			}
+
+			switch (pairwise_cipher) {
+			case WPA_CIPHER_NONE:
+				psecuritypriv->wpa2_pairwise_cipher = _NO_PRIVACY_;
+				break;
+			case WPA_CIPHER_WEP40:
+				psecuritypriv->wpa2_pairwise_cipher = _WEP40_;
+				break;
+			case WPA_CIPHER_TKIP:
+				psecuritypriv->wpa2_pairwise_cipher = _TKIP_;
+				break;
+			case WPA_CIPHER_CCMP:
+				psecuritypriv->wpa2_pairwise_cipher = _AES_;
+				break;
+			case WPA_CIPHER_WEP104:
+				psecuritypriv->wpa2_pairwise_cipher = _WEP104_;
+				break;
+			}
+#endif
+		}
+
+	}
+
+	/* wpa */
+	ie_len = 0;
+	group_cipher = 0;
+	pairwise_cipher = 0;
+	psecuritypriv->wpa_group_cipher = _NO_PRIVACY_;
+	psecuritypriv->wpa_pairwise_cipher = _NO_PRIVACY_;
+	for (p = ie + _BEACON_IE_OFFSET_; ; p += (ie_len + 2)) {
+		p = rtw_get_ie(p, _SSN_IE_1_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));
+		if ((p) && (_rtw_memcmp(p + 2, OUI1, 4))) {
+			if (rtw_parse_wpa_ie(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(0);
+
+				psecuritypriv->wpa_group_cipher = group_cipher;
+				psecuritypriv->wpa_pairwise_cipher = pairwise_cipher;
+
+#if 0
+				switch (group_cipher) {
+				case WPA_CIPHER_NONE:
+					psecuritypriv->wpa_group_cipher = _NO_PRIVACY_;
+					break;
+				case WPA_CIPHER_WEP40:
+					psecuritypriv->wpa_group_cipher = _WEP40_;
+					break;
+				case WPA_CIPHER_TKIP:
+					psecuritypriv->wpa_group_cipher = _TKIP_;
+					break;
+				case WPA_CIPHER_CCMP:
+					psecuritypriv->wpa_group_cipher = _AES_;
+					break;
+				case WPA_CIPHER_WEP104:
+					psecuritypriv->wpa_group_cipher = _WEP104_;
+					break;
+				}
+
+				switch (pairwise_cipher) {
+				case WPA_CIPHER_NONE:
+					psecuritypriv->wpa_pairwise_cipher = _NO_PRIVACY_;
+					break;
+				case WPA_CIPHER_WEP40:
+					psecuritypriv->wpa_pairwise_cipher = _WEP40_;
+					break;
+				case WPA_CIPHER_TKIP:
+					psecuritypriv->wpa_pairwise_cipher = _TKIP_;
+					break;
+				case WPA_CIPHER_CCMP:
+					psecuritypriv->wpa_pairwise_cipher = _AES_;
+					break;
+				case WPA_CIPHER_WEP104:
+					psecuritypriv->wpa_pairwise_cipher = _WEP104_;
+					break;
+				}
+#endif
+			}
+
+			break;
+
+		}
+
+		if ((p == NULL) || (ie_len == 0))
+			break;
+
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		/* MFP is mandatory for secure mesh */
+		if (padapter->mesh_info.mesh_auth_id)
+			mfp_opt = MFP_REQUIRED;
+	} else
+#endif
+	if (mfp_opt == MFP_INVALID) {
+		RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+		return _FAIL;
+	}
+	psecuritypriv->mfp_opt = mfp_opt;
+
+	/* wmm */
+	ie_len = 0;
+	pmlmepriv->qospriv.qos_option = 0;
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		pmlmepriv->qospriv.qos_option = 1;
+#endif
+	if (pregistrypriv->wmm_enable) {
+		for (p = ie + _BEACON_IE_OFFSET_; ; p += (ie_len + 2)) {
+			p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));
+			if ((p) && _rtw_memcmp(p + 2, WMM_PARA_IE, 6)) {
+				pmlmepriv->qospriv.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;
+		}
+	}
+#ifdef CONFIG_80211N_HT
+	/* parsing HT_CAP_IE */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0) {
+		u8 rf_type = 0;
+		HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor = MAX_AMPDU_FACTOR_64K;
+		struct rtw_ieee80211_ht_cap *pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
+
+		if (0) {
+			RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE from upper layer:\n", FUNC_ADPT_ARG(padapter));
+			dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
+		}
+
+		pHT_caps_ie = p;
+
+		ht_cap = _TRUE;
+		network_type |= WIRELESS_11_24N;
+
+		rtw_ht_use_default_setting(padapter);
+
+		/* Update HT Capabilities Info field */
+		if (pmlmepriv->htpriv.sgi_20m == _FALSE)
+			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_20);
+
+		if (pmlmepriv->htpriv.sgi_40m == _FALSE)
+			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_40);
+
+		if (!TEST_FLAG(pmlmepriv->htpriv.ldpc_cap, LDPC_HT_ENABLE_RX))
+			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_LDPC_CODING);
+
+		if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
+			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_TX_STBC);
+
+		if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_RX))
+			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_RX_STBC_3R);
+
+		/* Update A-MPDU Parameters field */
+		pht_cap->ampdu_params_info &= ~(IEEE80211_HT_CAP_AMPDU_FACTOR | IEEE80211_HT_CAP_AMPDU_DENSITY);
+
+		if ((psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_CCMP) ||
+			(psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_CCMP)) {
+			rtw_hal_get_def_var(padapter, HW_VAR_BEST_AMPDU_DENSITY, &best_ampdu_density);
+			pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & (best_ampdu_density << 2));
+		} else
+			pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & 0x00);
+
+		rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
+		pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_FACTOR & max_rx_ampdu_factor); /* set  Max Rx AMPDU size  to 64K */
+
+		_rtw_memcpy(&(pmlmeinfo->HT_caps), pht_cap, sizeof(struct HT_caps_element));
+
+		/* Update Supported MCS Set field */
+		{
+			struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+			u8 rx_nss = 0;
+			int i;
+
+			rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+			rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
+
+			/* RX MCS Bitmask */
+			switch (rx_nss) {
+			case 1:
+				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_1R);
+				break;
+			case 2:
+				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_2R);
+				break;
+			case 3:
+				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_3R);
+				break;
+			case 4:
+				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_4R);
+				break;
+			default:
+				RTW_WARN("rf_type:%d or rx_nss:%u is not expected\n", rf_type, hal_spec->rx_nss_num);
+			}
+			for (i = 0; i < 10; i++)
+				*(HT_CAP_ELE_RX_MCS_MAP(pht_cap) + i) &= padapter->mlmeextpriv.default_supported_mcs_set[i];
+		}
+
+#ifdef CONFIG_BEAMFORMING
+		/* Use registry value to enable HT Beamforming. */
+		/* ToDo: use configure file to set these capability. */
+		pht_cap->tx_BF_cap_info = 0;
+
+		/* HT Beamformer */
+		if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
+			/* Transmit NDP Capable */
+			SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(pht_cap, 1);
+			/* Explicit Compressed Steering Capable */
+			SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pht_cap, 1);
+			/* Compressed Steering Number Antennas */
+			SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, 1);
+			rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
+			SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pht_cap, rf_num);
+		}
+
+		/* HT Beamformee */
+		if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) {
+			/* Receive NDP Capable */
+			SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(pht_cap, 1);
+			/* Explicit Compressed Beamforming Feedback Capable */
+			SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pht_cap, 2);
+			rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
+			SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, rf_num);
+		}
+#endif /* CONFIG_BEAMFORMING */
+
+		_rtw_memcpy(&pmlmepriv->htpriv.ht_cap, p + 2, ie_len);
+
+		if (0) {
+			RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE driver masked:\n", FUNC_ADPT_ARG(padapter));
+			dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
+		}
+	}
+
+	/* parsing HT_INFO_IE */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0) {
+		pHT_info_ie = p;
+		if (channel == 0)
+			pbss_network->Configuration.DSConfig = GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2);
+		else if (channel != GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2)) {
+			RTW_INFO(FUNC_ADPT_FMT" ch inconsistent, DSSS:%u, HT primary:%u\n"
+				, FUNC_ADPT_ARG(padapter), channel, GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2));
+		}
+	}
+#endif /* CONFIG_80211N_HT */
+
+	switch (network_type) {
+	case WIRELESS_11B:
+		pbss_network->NetworkTypeInUse = Ndis802_11DS;
+		break;
+	case WIRELESS_11G:
+	case WIRELESS_11BG:
+	case WIRELESS_11G_24N:
+	case WIRELESS_11BG_24N:
+		pbss_network->NetworkTypeInUse = Ndis802_11OFDM24;
+		break;
+	case WIRELESS_11A:
+		pbss_network->NetworkTypeInUse = Ndis802_11OFDM5;
+		break;
+	default:
+		pbss_network->NetworkTypeInUse = Ndis802_11OFDM24;
+		break;
+	}
+
+	pmlmepriv->cur_network.network_type = network_type;
+
+#ifdef CONFIG_80211N_HT
+	pmlmepriv->htpriv.ht_option = _FALSE;
+
+	if ((psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_TKIP) ||
+	    (psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_TKIP)) {
+		/* todo: */
+		/* ht_cap = _FALSE; */
+	}
+
+	/* ht_cap	 */
+	if (pregistrypriv->ht_enable && ht_cap == _TRUE) {
+		pmlmepriv->htpriv.ht_option = _TRUE;
+		pmlmepriv->qospriv.qos_option = 1;
+
+		pmlmepriv->htpriv.ampdu_enable = pregistrypriv->ampdu_enable ? _TRUE : _FALSE;
+
+		HT_caps_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)pHT_caps_ie);
+
+		HT_info_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)pHT_info_ie);
+	}
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+
+	/* Parsing VHT CAP IE */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0)
+		vht_cap = _TRUE;
+
+	/* Parsing VHT OPERATION IE */
+
+	pmlmepriv->ori_vht_en = 0;
+	pmlmepriv->vhtpriv.vht_option = _FALSE;
+	/* if channel in 5G band, then add vht ie . */
+	if ((pbss_network->Configuration.DSConfig > 14)
+		&& (pmlmepriv->htpriv.ht_option == _TRUE)
+		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
+		&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+		&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+	) {
+		if (vht_cap == _TRUE
+			&& MLME_IS_MESH(padapter) /* allow only mesh temporarily before VHT IE checking is ready */
+		) {
+			rtw_check_for_vht20(padapter, ie + _BEACON_IE_OFFSET_, pbss_network->IELength - _BEACON_IE_OFFSET_);
+			pmlmepriv->ori_vht_en = 1;
+			pmlmepriv->vhtpriv.vht_option = _TRUE;
+		} else if (REGSTY_IS_11AC_AUTO(pregistrypriv)) {
+			rtw_vht_ies_detach(padapter, pbss_network);
+			rtw_vht_ies_attach(padapter, pbss_network);
+		}
+	}
+
+	if (pmlmepriv->vhtpriv.vht_option == _FALSE)
+		rtw_vht_ies_detach(padapter, pbss_network);
+#endif /* CONFIG_80211AC_VHT */
+
+	if(pbss_network->Configuration.DSConfig <= 14 && padapter->registrypriv.wifi_spec == 1) {
+		uint len = 0;
+
+		SET_EXT_CAPABILITY_ELE_BSS_COEXIST(pmlmepriv->ext_capab_ie_data, 1);
+		pmlmepriv->ext_capab_ie_len = 10;
+		rtw_set_ie(pbss_network->IEs + pbss_network->IELength, EID_EXTCapability, 8, pmlmepriv->ext_capab_ie_data, &len);
+		pbss_network->IELength += pmlmepriv->ext_capab_ie_len;
+	}
+
+	pbss_network->Length = get_WLAN_BSSID_EX_sz((WLAN_BSSID_EX *)pbss_network);
+
+	rtw_ies_get_chbw(pbss_network->IEs + _BEACON_IE_OFFSET_, pbss_network->IELength - _BEACON_IE_OFFSET_
+		, &pmlmepriv->ori_ch, &pmlmepriv->ori_bw, &pmlmepriv->ori_offset, 1, 1);
+	rtw_warn_on(pmlmepriv->ori_ch == 0);
+
+	{
+		/* alloc sta_info for ap itself */
+
+		struct sta_info *sta;
+
+		sta = rtw_get_stainfo(&padapter->stapriv, pbss_network->MacAddress);
+		if (!sta) {
+			sta = rtw_alloc_stainfo(&padapter->stapriv, pbss_network->MacAddress);
+			if (sta == NULL)
+				return _FAIL;
+		}
+	}
+
+	rtw_startbss_cmd(padapter, RTW_CMDF_WAIT_ACK);
+	{
+		int sk_band = RTW_GET_SCAN_BAND_SKIP(padapter);
+
+		if (sk_band)
+			RTW_CLR_SCAN_BAND_SKIP(padapter, sk_band);
+	}
+
+	rtw_indicate_connect(padapter);
+
+	pmlmepriv->cur_network.join_res = _TRUE;/* for check if already set beacon */
+
+	/* update bc/mc sta_info */
+	/* update_bmc_sta(padapter); */
+
+	return ret;
+
+}
+
+#if CONFIG_RTW_MACADDR_ACL
+void rtw_macaddr_acl_init(_adapter *adapter, u8 period)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+	_queue *acl_node_q;
+	int i;
+	_irqL irqL;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
+	_rtw_spinlock_init(&(acl_node_q->lock));
+
+	_enter_critical_bh(&(acl_node_q->lock), &irqL);
+	_rtw_init_listhead(&(acl_node_q->queue));
+	acl->num = 0;
+	acl->mode = RTW_ACL_MODE_DISABLED;
+	for (i = 0; i < NUM_ACL; i++) {
+		_rtw_init_listhead(&acl->aclnode[i].list);
+		acl->aclnode[i].valid = _FALSE;
+	}
+	_exit_critical_bh(&(acl_node_q->lock), &irqL);
+}
+
+static void _rtw_macaddr_acl_deinit(_adapter *adapter, u8 period, bool clear_only)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+	_queue *acl_node_q;
+	_irqL irqL;
+	_list *head, *list;
+	struct rtw_wlan_acl_node *acl_node;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
+	_enter_critical_bh(&(acl_node_q->lock), &irqL);
+	head = get_list_head(acl_node_q);
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
+		list = get_next(list);
+
+		if (acl_node->valid == _TRUE) {
+			acl_node->valid = _FALSE;
+			rtw_list_delete(&acl_node->list);
+			acl->num--;
+		}
+	}
+	_exit_critical_bh(&(acl_node_q->lock), &irqL);
+
+	if (!clear_only)
+		_rtw_spinlock_free(&(acl_node_q->lock));
+
+	rtw_warn_on(acl->num);
+	acl->mode = RTW_ACL_MODE_DISABLED;
+}
+
+void rtw_macaddr_acl_deinit(_adapter *adapter, u8 period)
+{
+	_rtw_macaddr_acl_deinit(adapter, period, 0);
+}
+
+void rtw_macaddr_acl_clear(_adapter *adapter, u8 period)
+{
+	_rtw_macaddr_acl_deinit(adapter, period, 1);
+}
+
+void rtw_set_macaddr_acl(_adapter *adapter, u8 period, int mode)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	acl = &stapriv->acl_list[period];
+
+	RTW_INFO(FUNC_ADPT_FMT" p=%u, mode=%d\n"
+		, FUNC_ADPT_ARG(adapter), period, mode);
+
+	acl->mode = mode;
+}
+
+int rtw_acl_add_sta(_adapter *adapter, u8 period, const u8 *addr)
+{
+	_irqL irqL;
+	_list *list, *head;
+	u8 existed = 0;
+	int i = -1, ret = 0;
+	struct rtw_wlan_acl_node *acl_node;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+	_queue *acl_node_q;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		ret = -1;
+		goto exit;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
+	_enter_critical_bh(&(acl_node_q->lock), &irqL);
+
+	head = get_list_head(acl_node_q);
+	list = get_next(head);
+
+	/* search for existed entry */
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(acl_node->addr, addr, ETH_ALEN)) {
+			if (acl_node->valid == _TRUE) {
+				existed = 1;
+				break;
+			}
+		}
+	}
+	if (existed)
+		goto release_lock;
+
+	if (acl->num >= NUM_ACL)
+		goto release_lock;
+
+	/* find empty one and use */
+	for (i = 0; i < NUM_ACL; i++) {
+
+		acl_node = &acl->aclnode[i];
+		if (acl_node->valid == _FALSE) {
+
+			_rtw_init_listhead(&acl_node->list);
+			_rtw_memcpy(acl_node->addr, addr, ETH_ALEN);
+			acl_node->valid = _TRUE;
+
+			rtw_list_insert_tail(&acl_node->list, get_list_head(acl_node_q));
+			acl->num++;
+			break;
+		}
+	}
+
+release_lock:
+	_exit_critical_bh(&(acl_node_q->lock), &irqL);
+
+	if (!existed && (i < 0 || i >= NUM_ACL))
+		ret = -1;
+
+	RTW_INFO(FUNC_ADPT_FMT" p=%u "MAC_FMT" %s (acl_num=%d)\n"
+		 , FUNC_ADPT_ARG(adapter), period, MAC_ARG(addr)
+		, (existed ? "existed" : ((i < 0 || i >= NUM_ACL) ? "no room" : "added"))
+		 , acl->num);
+exit:
+	return ret;
+}
+
+int rtw_acl_remove_sta(_adapter *adapter, u8 period, const u8 *addr)
+{
+	_irqL irqL;
+	_list *list, *head;
+	int ret = 0;
+	struct rtw_wlan_acl_node *acl_node;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+	_queue	*acl_node_q;
+	u8 is_baddr = is_broadcast_mac_addr(addr);
+	u8 match = 0;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
+	_enter_critical_bh(&(acl_node_q->lock), &irqL);
+
+	head = get_list_head(acl_node_q);
+	list = get_next(head);
+
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
+		list = get_next(list);
+
+		if (is_baddr || _rtw_memcmp(acl_node->addr, addr, ETH_ALEN)) {
+			if (acl_node->valid == _TRUE) {
+				acl_node->valid = _FALSE;
+				rtw_list_delete(&acl_node->list);
+				acl->num--;
+				match = 1;
+			}
+		}
+	}
+
+	_exit_critical_bh(&(acl_node_q->lock), &irqL);
+
+	RTW_INFO(FUNC_ADPT_FMT" p=%u "MAC_FMT" %s (acl_num=%d)\n"
+		 , FUNC_ADPT_ARG(adapter), period, MAC_ARG(addr)
+		 , is_baddr ? "clear all" : (match ? "match" : "no found")
+		 , acl->num);
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_RTW_MACADDR_ACL */
+
+u8 rtw_ap_set_sta_key(_adapter *adapter, const u8 *addr, u8 alg, const u8 *key, u8 keyid, u8 gk)
+{
+	struct cmd_priv *cmdpriv = &adapter->cmdpriv;
+	struct cmd_obj *cmd;
+	struct set_stakey_parm *param;
+	u8	res = _SUCCESS;
+
+	cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (cmd == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	param = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
+	if (param == NULL) {
+		rtw_mfree((u8 *) cmd, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	init_h2fwcmd_w_parm_no_rsp(cmd, param, _SetStaKey_CMD_);
+
+	_rtw_memcpy(param->addr, addr, ETH_ALEN);
+	param->algorithm = alg;
+	param->keyid = keyid;
+	_rtw_memcpy(param->key, key, 16);
+	param->gk = gk;
+
+	res = rtw_enqueue_cmd(cmdpriv, cmd);
+
+exit:
+	return res;
+}
+
+u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta)
+{
+	return rtw_ap_set_sta_key(padapter
+		, psta->cmn.mac_addr
+		, psta->dot118021XPrivacy
+		, psta->dot118021x_UncstKey.skey
+		, 0
+		, 0
+	);
+}
+
+static int rtw_ap_set_key(_adapter *padapter, u8 *key, u8 alg, int keyid, u8 set_tx)
+{
+	u8 keylen;
+	struct cmd_obj *pcmd;
+	struct setkey_parm *psetkeyparm;
+	struct cmd_priv	*pcmdpriv = &(padapter->cmdpriv);
+	int res = _SUCCESS;
+
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+	pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+	psetkeyparm = (struct setkey_parm *)rtw_zmalloc(sizeof(struct setkey_parm));
+	if (psetkeyparm == NULL) {
+		rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	_rtw_memset(psetkeyparm, 0, sizeof(struct setkey_parm));
+
+	psetkeyparm->keyid = (u8)keyid;
+	if (is_wep_enc(alg))
+		padapter->securitypriv.key_mask |= BIT(psetkeyparm->keyid);
+
+	psetkeyparm->algorithm = alg;
+
+	psetkeyparm->set_tx = set_tx;
+
+	switch (alg) {
+	case _WEP40_:
+		keylen = 5;
+		break;
+	case _WEP104_:
+		keylen = 13;
+		break;
+	case _TKIP_:
+	case _TKIP_WTMIC_:
+	case _AES_:
+	default:
+		keylen = 16;
+	}
+
+	_rtw_memcpy(&(psetkeyparm->key[0]), key, keylen);
+
+	pcmd->cmdcode = _SetKey_CMD_;
+	pcmd->parmbuf = (u8 *)psetkeyparm;
+	pcmd->cmdsz = (sizeof(struct setkey_parm));
+	pcmd->rsp = NULL;
+	pcmd->rspsz = 0;
+
+
+	_rtw_init_listhead(&pcmd->list);
+
+	res = rtw_enqueue_cmd(pcmdpriv, pcmd);
+
+exit:
+
+	return res;
+}
+
+int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	return rtw_ap_set_key(padapter, key, alg, keyid, 1);
+}
+
+int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx)
+{
+	u8 alg;
+
+	switch (keylen) {
+	case 5:
+		alg = _WEP40_;
+		break;
+	case 13:
+		alg = _WEP104_;
+		break;
+	default:
+		alg = _NO_PRIVACY_;
+	}
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	return rtw_ap_set_key(padapter, key, alg, keyid, set_tx);
+}
+
+u8 rtw_ap_bmc_frames_hdl(_adapter *padapter)
+{
+#define HIQ_XMIT_COUNTS (6)
+	_irqL irqL;
+	struct sta_info *psta_bmc;
+	_list	*xmitframe_plist, *xmitframe_phead;
+	struct xmit_frame *pxmitframe = NULL;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct sta_priv  *pstapriv = &padapter->stapriv;
+	bool update_tim = _FALSE;
+
+
+	if (padapter->registrypriv.wifi_spec != 1)
+		return H2C_SUCCESS;
+
+
+	psta_bmc = rtw_get_bcmc_stainfo(padapter);
+	if (!psta_bmc)
+		return H2C_SUCCESS;
+
+
+	_enter_critical_bh(&pxmitpriv->lock, &irqL);
+
+	if ((rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) && (psta_bmc->sleepq_len > 0)) {
+		int tx_counts = 0;
+
+		_update_beacon(padapter, _TIM_IE_, NULL, _FALSE, "update TIM with TIB=1");
+
+		RTW_INFO("sleepq_len of bmc_sta = %d\n", psta_bmc->sleepq_len);
+
+		xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
+		xmitframe_plist = get_next(xmitframe_phead);
+
+		while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
+			pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
+
+			xmitframe_plist = get_next(xmitframe_plist);
+
+			rtw_list_delete(&pxmitframe->list);
+
+			psta_bmc->sleepq_len--;
+			tx_counts++;
+
+			if (psta_bmc->sleepq_len > 0)
+				pxmitframe->attrib.mdata = 1;
+			else
+				pxmitframe->attrib.mdata = 0;
+
+			if (tx_counts == HIQ_XMIT_COUNTS)
+				pxmitframe->attrib.mdata = 0;
+
+			pxmitframe->attrib.triggered = 1;
+
+			if (xmitframe_hiq_filter(pxmitframe) == _TRUE)
+				pxmitframe->attrib.qsel = QSLT_HIGH;/*HIQ*/
+
+			rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
+
+			if (tx_counts == HIQ_XMIT_COUNTS)
+				break;
+
+		}
+
+	} else {
+		if (psta_bmc->sleepq_len == 0) {
+
+			/*RTW_INFO("sleepq_len of bmc_sta = %d\n", psta_bmc->sleepq_len);*/
+
+			if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0))
+				update_tim = _TRUE;
+
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
+
+			if (update_tim == _TRUE) {
+				RTW_INFO("clear TIB\n");
+				_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "bmc sleepq and HIQ empty");
+			}
+		}
+	}
+
+	_exit_critical_bh(&pxmitpriv->lock, &irqL);
+
+#if 0
+	/* HIQ Check */
+	rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
+
+	while (_FALSE == empty && rtw_get_passing_time_ms(start) < 3000) {
+		rtw_msleep_os(100);
+		rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
+	}
+
+
+	printk("check if hiq empty=%d\n", empty);
+#endif
+
+	return H2C_SUCCESS;
+}
+
+#ifdef CONFIG_NATIVEAP_MLME
+
+static void associated_stainfo_update(_adapter *padapter, struct sta_info *psta, u32 sta_info_type)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	RTW_INFO("%s: "MAC_FMT", updated_type=0x%x\n", __func__, MAC_ARG(psta->cmn.mac_addr), sta_info_type);
+
+	if (sta_info_type & STA_INFO_UPDATE_BW) {
+
+		if ((psta->flags & WLAN_STA_HT) && !psta->ht_20mhz_set) {
+			if (pmlmepriv->sw_to_20mhz) {
+				psta->cmn.bw_mode = CHANNEL_WIDTH_20;
+				/*psta->htpriv.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;*/
+				psta->htpriv.sgi_40m = _FALSE;
+			} else {
+				/*TODO: Switch back to 40MHZ?80MHZ*/
+			}
+		}
+	}
+
+	/*
+		if (sta_info_type & STA_INFO_UPDATE_RATE) {
+
+		}
+	*/
+
+	if (sta_info_type & STA_INFO_UPDATE_PROTECTION_MODE)
+		VCS_update(padapter, psta);
+
+	/*
+		if (sta_info_type & STA_INFO_UPDATE_CAP) {
+
+		}
+
+		if (sta_info_type & STA_INFO_UPDATE_HT_CAP) {
+
+		}
+
+		if (sta_info_type & STA_INFO_UPDATE_VHT_CAP) {
+
+		}
+	*/
+
+}
+
+static void update_bcn_ext_capab_ie(_adapter *padapter)
+{
+	sint ie_len = 0;
+	unsigned char	*pbuf;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
+	u8 *ie = pnetwork->IEs;
+	u8 null_extcap_data[8] = {0};
+
+	pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_CAP_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+	if (pbuf && ie_len > 0)
+		rtw_remove_bcn_ie(padapter, pnetwork, _EXT_CAP_IE_);
+
+	if ((pmlmepriv->ext_capab_ie_len > 0) &&
+	    (_rtw_memcmp(pmlmepriv->ext_capab_ie_data, null_extcap_data, sizeof(null_extcap_data)) == _FALSE))
+		rtw_add_bcn_ie(padapter, pnetwork, _EXT_CAP_IE_, pmlmepriv->ext_capab_ie_data, pmlmepriv->ext_capab_ie_len);
+
+}
+
+static void update_bcn_erpinfo_ie(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
+	unsigned char *p, *ie = pnetwork->IEs;
+	u32 len = 0;
+
+	RTW_INFO("%s, ERP_enable=%d\n", __FUNCTION__, pmlmeinfo->ERP_enable);
+
+	if (!pmlmeinfo->ERP_enable)
+		return;
+
+	/* parsing ERP_IE */
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _ERPINFO_IE_, &len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+	if (p && len > 0) {
+		PNDIS_802_11_VARIABLE_IEs pIE = (PNDIS_802_11_VARIABLE_IEs)p;
+
+		if (pmlmepriv->num_sta_non_erp == 1)
+			pIE->data[0] |= RTW_ERP_INFO_NON_ERP_PRESENT | RTW_ERP_INFO_USE_PROTECTION;
+		else
+			pIE->data[0] &= ~(RTW_ERP_INFO_NON_ERP_PRESENT | RTW_ERP_INFO_USE_PROTECTION);
+
+		if (pmlmepriv->num_sta_no_short_preamble > 0)
+			pIE->data[0] |= RTW_ERP_INFO_BARKER_PREAMBLE_MODE;
+		else
+			pIE->data[0] &= ~(RTW_ERP_INFO_BARKER_PREAMBLE_MODE);
+
+		ERP_IE_handler(padapter, pIE);
+	}
+
+}
+
+static void update_bcn_htcap_ie(_adapter *padapter)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+
+}
+
+static void update_bcn_htinfo_ie(_adapter *padapter)
+{
+	/*
+	u8 beacon_updated = _FALSE;
+	u32 sta_info_update_type = STA_INFO_UPDATE_NONE;
+	*/
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
+	unsigned char *p, *ie = pnetwork->IEs;
+	u32 len = 0;
+
+	if (pmlmepriv->htpriv.ht_option == _FALSE)
+		return;
+
+	if (pmlmeinfo->HT_info_enable != 1)
+		return;
+
+
+	RTW_INFO("%s current operation mode=0x%X\n",
+		 __FUNCTION__, pmlmepriv->ht_op_mode);
+
+	RTW_INFO("num_sta_40mhz_intolerant(%d), 20mhz_width_req(%d), intolerant_ch_rpt(%d), olbc(%d)\n",
+		pmlmepriv->num_sta_40mhz_intolerant, pmlmepriv->ht_20mhz_width_req, pmlmepriv->ht_intolerant_ch_reported, ATOMIC_READ(&pmlmepriv->olbc));
+
+	/*parsing HT_INFO_IE, currently only update ht_op_mode - pht_info->infos[1] & pht_info->infos[2] for wifi logo test*/
+	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+	if (p && len > 0) {
+		struct HT_info_element *pht_info = NULL;
+
+		pht_info = (struct HT_info_element *)(p + 2);
+
+		/* for STA Channel Width/Secondary Channel Offset*/
+		if ((pmlmepriv->sw_to_20mhz == 0) && (pmlmeext->cur_channel <= 14)) {
+			if ((pmlmepriv->num_sta_40mhz_intolerant > 0) || (pmlmepriv->ht_20mhz_width_req == _TRUE)
+			    || (pmlmepriv->ht_intolerant_ch_reported == _TRUE) || (ATOMIC_READ(&pmlmepriv->olbc) == _TRUE)) {
+				SET_HT_OP_ELE_2ND_CHL_OFFSET(pht_info, 0);
+				SET_HT_OP_ELE_STA_CHL_WIDTH(pht_info, 0);
+
+				pmlmepriv->sw_to_20mhz = 1;
+				/*
+				sta_info_update_type |= STA_INFO_UPDATE_BW;
+				beacon_updated = _TRUE;
+				*/
+
+				RTW_INFO("%s:switching to 20Mhz\n", __FUNCTION__);
+
+				/*TODO : cur_bwmode/cur_ch_offset switches to 20Mhz*/
+			}
+		} else {
+
+			if ((pmlmepriv->num_sta_40mhz_intolerant == 0) && (pmlmepriv->ht_20mhz_width_req == _FALSE)
+			    && (pmlmepriv->ht_intolerant_ch_reported == _FALSE) && (ATOMIC_READ(&pmlmepriv->olbc) == _FALSE)) {
+
+				if (pmlmeext->cur_bwmode >= CHANNEL_WIDTH_40) {
+
+					SET_HT_OP_ELE_STA_CHL_WIDTH(pht_info, 1);
+
+					SET_HT_OP_ELE_2ND_CHL_OFFSET(pht_info,
+						(pmlmeext->cur_ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER) ?
+						HT_INFO_HT_PARAM_SECONDARY_CHNL_ABOVE : HT_INFO_HT_PARAM_SECONDARY_CHNL_BELOW);
+
+					pmlmepriv->sw_to_20mhz = 0;
+					/*
+					sta_info_update_type |= STA_INFO_UPDATE_BW;
+					beacon_updated = _TRUE;
+					*/
+
+					RTW_INFO("%s:switching back to 40Mhz\n", __FUNCTION__);
+				}
+			}
+		}
+
+		/* to update  ht_op_mode*/
+		*(u16 *)(pht_info->infos + 1) = cpu_to_le16(pmlmepriv->ht_op_mode);
+
+	}
+
+	/*associated_clients_update(padapter, beacon_updated, sta_info_update_type);*/
+
+}
+
+static void update_bcn_rsn_ie(_adapter *padapter)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+
+}
+
+static void update_bcn_wpa_ie(_adapter *padapter)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+
+}
+
+static void update_bcn_wmm_ie(_adapter *padapter)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+
+}
+
+static void update_bcn_wps_ie(_adapter *padapter)
+{
+	u8 *pwps_ie = NULL, *pwps_ie_src, *premainder_ie, *pbackup_remainder_ie = NULL;
+	uint wps_ielen = 0, wps_offset, remainder_ielen;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
+	unsigned char *ie = pnetwork->IEs;
+	u32 ielen = pnetwork->IELength;
+
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	pwps_ie = rtw_get_wps_ie(ie + _FIXED_IE_LENGTH_, ielen - _FIXED_IE_LENGTH_, NULL, &wps_ielen);
+
+	if (pwps_ie == NULL || wps_ielen == 0)
+		return;
+
+	pwps_ie_src = pmlmepriv->wps_beacon_ie;
+	if (pwps_ie_src == NULL)
+		return;
+
+	wps_offset = (uint)(pwps_ie - ie);
+
+	premainder_ie = pwps_ie + wps_ielen;
+
+	remainder_ielen = ielen - wps_offset - wps_ielen;
+
+	if (remainder_ielen > 0) {
+		pbackup_remainder_ie = rtw_malloc(remainder_ielen);
+		if (pbackup_remainder_ie)
+			_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
+	}
+
+	wps_ielen = (uint)pwps_ie_src[1];/* to get ie data len */
+	if ((wps_offset + wps_ielen + 2 + remainder_ielen) <= MAX_IE_SZ) {
+		_rtw_memcpy(pwps_ie, pwps_ie_src, wps_ielen + 2);
+		pwps_ie += (wps_ielen + 2);
+
+		if (pbackup_remainder_ie)
+			_rtw_memcpy(pwps_ie, pbackup_remainder_ie, remainder_ielen);
+
+		/* update IELength */
+		pnetwork->IELength = wps_offset + (wps_ielen + 2) + remainder_ielen;
+	}
+
+	if (pbackup_remainder_ie)
+		rtw_mfree(pbackup_remainder_ie, remainder_ielen);
+
+	/* deal with the case without set_tx_beacon_cmd() in update_beacon() */
+#if defined(CONFIG_INTERRUPT_BASED_TXBCN) || defined(CONFIG_PCI_HCI)
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+		u8 sr = 0;
+		rtw_get_wps_attr_content(pwps_ie_src,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
+
+		if (sr) {
+			set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
+			RTW_INFO("%s, set WIFI_UNDER_WPS\n", __func__);
+		} else {
+			clr_fwstate(pmlmepriv, WIFI_UNDER_WPS);
+			RTW_INFO("%s, clr WIFI_UNDER_WPS\n", __func__);
+		}
+	}
+#endif
+}
+
+static void update_bcn_p2p_ie(_adapter *padapter)
+{
+
+}
+
+static void update_bcn_vendor_spec_ie(_adapter *padapter, u8 *oui)
+{
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	if (_rtw_memcmp(RTW_WPA_OUI, oui, 4))
+		update_bcn_wpa_ie(padapter);
+	else if (_rtw_memcmp(WMM_OUI, oui, 4))
+		update_bcn_wmm_ie(padapter);
+	else if (_rtw_memcmp(WPS_OUI, oui, 4))
+		update_bcn_wps_ie(padapter);
+	else if (_rtw_memcmp(P2P_OUI, oui, 4))
+		update_bcn_p2p_ie(padapter);
+	else
+		RTW_INFO("unknown OUI type!\n");
+
+
+}
+
+void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *tag)
+{
+	_irqL irqL;
+	struct mlme_priv *pmlmepriv;
+	struct mlme_ext_priv *pmlmeext;
+	bool updated = 1; /* treat as upadated by default */
+
+	if (!padapter)
+		return;
+
+	pmlmepriv = &(padapter->mlmepriv);
+	pmlmeext = &(padapter->mlmeextpriv);
+
+	if (pmlmeext->bstart_bss == _FALSE)
+		return;
+
+	_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
+
+	switch (ie_id) {
+	case _TIM_IE_:
+		update_BCNTIM(padapter);
+		break;
+
+	case _ERPINFO_IE_:
+		update_bcn_erpinfo_ie(padapter);
+		break;
+
+	case _HT_CAPABILITY_IE_:
+		update_bcn_htcap_ie(padapter);
+		break;
+
+	case _RSN_IE_2_:
+		update_bcn_rsn_ie(padapter);
+		break;
+
+	case _HT_ADD_INFO_IE_:
+		update_bcn_htinfo_ie(padapter);
+		break;
+
+	case _EXT_CAP_IE_:
+		update_bcn_ext_capab_ie(padapter);
+		break;
+
+#ifdef CONFIG_RTW_MESH
+	case WLAN_EID_MESH_CONFIG:
+		updated = rtw_mesh_update_bss_peering_status(padapter, &(pmlmeext->mlmext_info.network));
+		updated |= rtw_mesh_update_bss_formation_info(padapter, &(pmlmeext->mlmext_info.network));
+		updated |= rtw_mesh_update_bss_forwarding_state(padapter, &(pmlmeext->mlmext_info.network));
+		break;
+#endif
+
+	case _VENDOR_SPECIFIC_IE_:
+		update_bcn_vendor_spec_ie(padapter, oui);
+		break;
+
+	case 0xFF:
+	default:
+		break;
+	}
+
+	if (updated)
+		pmlmepriv->update_bcn = _TRUE;
+
+	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
+
+#ifndef CONFIG_INTERRUPT_BASED_TXBCN
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	if (tx && updated) {
+		/* send_beacon(padapter); */ /* send_beacon must execute on TSR level */
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" ie_id:%u - %s\n", FUNC_ADPT_ARG(padapter), ie_id, tag);
+		set_tx_beacon_cmd(padapter);
+	}
+#else
+	{
+		/* PCI will issue beacon when BCN interrupt occurs.		 */
+	}
+#endif
+#endif /* !CONFIG_INTERRUPT_BASED_TXBCN */
+}
+
+#ifdef CONFIG_80211N_HT
+
+void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len)
+{
+	struct sta_info *psta;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 beacon_updated = _FALSE;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
+	uint frame_body_len = frame_len - sizeof(struct rtw_ieee80211_hdr_3addr);
+	u8 category, action;
+
+	psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+	if (psta == NULL)
+		return;
+
+
+	category = frame_body[0];
+	action = frame_body[1];
+
+	if (frame_body_len > 0) {
+		if ((frame_body[2] == EID_BSSCoexistence) && (frame_body[3] > 0)) {
+			u8 ie_data = frame_body[4];
+
+			if (ie_data & RTW_WLAN_20_40_BSS_COEX_40MHZ_INTOL) {
+				if (psta->ht_40mhz_intolerant == 0) {
+					psta->ht_40mhz_intolerant = 1;
+					pmlmepriv->num_sta_40mhz_intolerant++;
+					beacon_updated = _TRUE;
+				}
+			} else if (ie_data & RTW_WLAN_20_40_BSS_COEX_20MHZ_WIDTH_REQ)	{
+				if (pmlmepriv->ht_20mhz_width_req == _FALSE) {
+					pmlmepriv->ht_20mhz_width_req = _TRUE;
+					beacon_updated = _TRUE;
+				}
+			} else
+				beacon_updated = _FALSE;
+		}
+	}
+
+	if (frame_body_len > 8) {
+		/* if EID_BSSIntolerantChlReport ie exists */
+		if ((frame_body[5] == EID_BSSIntolerantChlReport) && (frame_body[6] > 0)) {
+			/*todo:*/
+			if (pmlmepriv->ht_intolerant_ch_reported == _FALSE) {
+				pmlmepriv->ht_intolerant_ch_reported = _TRUE;
+				beacon_updated = _TRUE;
+			}
+		}
+	}
+
+	if (beacon_updated) {
+
+		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE);
+
+		associated_stainfo_update(padapter, psta, STA_INFO_UPDATE_BW);
+	}
+
+
+
+}
+
+void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field)
+{
+	u8 e_field, m_field;
+	struct sta_info *psta;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	psta = rtw_get_stainfo(pstapriv, ta);
+	if (psta == NULL)
+		return;
+
+	e_field = (ctrl_field & BIT(0)) ? 1 : 0;
+	m_field = (ctrl_field & BIT(1)) ? 1 : 0;
+
+	if (e_field) {
+
+		/* enable */
+		/* 0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
+
+		if (m_field) /*mode*/
+			psta->htpriv.smps_cap = 1;
+		else
+			psta->htpriv.smps_cap = 0;
+	} else {
+		/*disable*/
+		psta->htpriv.smps_cap = 3;
+	}
+
+	rtw_dm_ra_mask_wk_cmd(padapter, (u8 *)psta);
+
+}
+
+/*
+op_mode
+Set to 0 (HT pure) under the followign 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)
+*/
+int rtw_ht_operation_update(_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 == _FALSE)
+		return 0;
+
+	/*if (!iface->conf->ieee80211n || iface->conf->ht_op_mode_fixed)
+		return 0;*/
+
+	RTW_INFO("%s current operation mode=0x%X\n",
+		 __FUNCTION__, pmlmepriv->ht_op_mode);
+
+	if (!(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)
+	    && pmlmepriv->num_sta_ht_no_gf) {
+		pmlmepriv->ht_op_mode |=
+			HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT;
+		op_mode_changes++;
+	} else if ((pmlmepriv->ht_op_mode &
+		    HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT) &&
+		   pmlmepriv->num_sta_ht_no_gf == 0) {
+		pmlmepriv->ht_op_mode &=
+			~HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT;
+		op_mode_changes++;
+	}
+
+	if (!(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT) &&
+	    (pmlmepriv->num_sta_no_ht || ATOMIC_READ(&pmlmepriv->olbc_ht))) {
+		pmlmepriv->ht_op_mode |= HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT;
+		op_mode_changes++;
+	} else if ((pmlmepriv->ht_op_mode &
+		    HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT) &&
+		   (pmlmepriv->num_sta_no_ht == 0 && !ATOMIC_READ(&pmlmepriv->olbc_ht))) {
+		pmlmepriv->ht_op_mode &=
+			~HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT;
+		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.
+	 */
+	new_op_mode = 0;
+	if (pmlmepriv->num_sta_no_ht /*||
+	    (pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)*/)
+		new_op_mode = OP_MODE_MIXED;
+	else if ((phtpriv_ap->ht_cap.cap_info & IEEE80211_HT_CAP_SUP_WIDTH)
+		 && pmlmepriv->num_sta_ht_20mhz)
+		new_op_mode = OP_MODE_20MHZ_HT_STA_ASSOCED;
+	else if (ATOMIC_READ(&pmlmepriv->olbc_ht))
+		new_op_mode = OP_MODE_MAY_BE_LEGACY_STAS;
+	else
+		new_op_mode = OP_MODE_PURE;
+
+	cur_op_mode = pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_OP_MODE_MASK;
+	if (cur_op_mode != new_op_mode) {
+		pmlmepriv->ht_op_mode &= ~HT_INFO_OPERATION_MODE_OP_MODE_MASK;
+		pmlmepriv->ht_op_mode |= new_op_mode;
+		op_mode_changes++;
+	}
+
+	RTW_INFO("%s new operation mode=0x%X changes=%d\n",
+		 __FUNCTION__, pmlmepriv->ht_op_mode, op_mode_changes);
+
+	return op_mode_changes;
+
+}
+
+#endif /* CONFIG_80211N_HT */
+
+void associated_clients_update(_adapter *padapter, u8 updated, u32 sta_info_type)
+{
+	/* update associcated stations cap. */
+	if (updated == _TRUE) {
+		_irqL irqL;
+		_list	*phead, *plist;
+		struct sta_info *psta = NULL;
+		struct sta_priv *pstapriv = &padapter->stapriv;
+
+		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+		phead = &pstapriv->asoc_list;
+		plist = get_next(phead);
+
+		/* check asoc_queue */
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+
+			plist = get_next(plist);
+
+			associated_stainfo_update(padapter, psta, sta_info_type);
+		}
+
+		_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	}
+
+}
+
+/* called > TSR LEVEL for USB or SDIO Interface*/
+void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta)
+{
+	u8 beacon_updated = _FALSE;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+
+
+#if 0
+	if (!(psta->capability & WLAN_CAPABILITY_SHORT_PREAMBLE) &&
+	    !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))
+			ieee802_11_set_beacons(hapd->iface);
+	}
+#endif
+
+
+	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;
+		}
+	} 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;
+		}
+	}
+
+#if 0
+	if (psta->flags & WLAN_STA_NONERP && !psta->nonerp_set) {
+		psta->nonerp_set = 1;
+		pmlmepriv->num_sta_non_erp++;
+		if (pmlmepriv->num_sta_non_erp == 1)
+			ieee802_11_set_beacons(hapd->iface);
+	}
+#endif
+
+	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_beacon(padapter, _ERPINFO_IE_, NULL, _FALSE);
+			}
+		}
+
+	} 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_beacon(padapter, _ERPINFO_IE_, NULL, _FALSE);
+			}
+		}
+
+	}
+
+
+#if 0
+	if (!(psta->capability & WLAN_CAPABILITY_SHORT_SLOT) &&
+	    !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))
+			ieee802_11_set_beacons(hapd->iface);
+	}
+#endif
+
+	if (!(psta->capability & WLAN_CAPABILITY_SHORT_SLOT)) {
+		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;
+		}
+	} 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;
+		}
+	}
+
+#ifdef CONFIG_80211N_HT
+	if (psta->flags & WLAN_STA_HT) {
+		u16 ht_capab = le16_to_cpu(psta->htpriv.ht_cap.cap_info);
+
+		RTW_INFO("HT: STA " MAC_FMT " HT Capabilities Info: 0x%04x\n",
+			MAC_ARG(psta->cmn.mac_addr), 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++;
+			}
+			RTW_INFO("%s STA " MAC_FMT " - no "
+				 "greenfield, num of non-gf stations %d\n",
+				 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
+				 pmlmepriv->num_sta_ht_no_gf);
+		}
+
+		if ((ht_capab & IEEE80211_HT_CAP_SUP_WIDTH) == 0) {
+			if (!psta->ht_20mhz_set) {
+				psta->ht_20mhz_set = 1;
+				pmlmepriv->num_sta_ht_20mhz++;
+			}
+			RTW_INFO("%s STA " MAC_FMT " - 20 MHz HT, "
+				 "num of 20MHz HT STAs %d\n",
+				 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
+				 pmlmepriv->num_sta_ht_20mhz);
+		}
+
+		if (((ht_capab & RTW_IEEE80211_HT_CAP_40MHZ_INTOLERANT) != 0) &&
+			(psta->ht_40mhz_intolerant == 0)) {
+			psta->ht_40mhz_intolerant = 1;
+			pmlmepriv->num_sta_40mhz_intolerant++;
+			RTW_INFO("%s STA " MAC_FMT " - 40MHZ_INTOLERANT, ",
+				   __FUNCTION__, MAC_ARG(psta->cmn.mac_addr));
+		}
+
+	} else {
+		if (!psta->no_ht_set) {
+			psta->no_ht_set = 1;
+			pmlmepriv->num_sta_no_ht++;
+		}
+		if (pmlmepriv->htpriv.ht_option == _TRUE) {
+			RTW_INFO("%s STA " MAC_FMT
+				 " - no HT, num of non-HT stations %d\n",
+				 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
+				 pmlmepriv->num_sta_no_ht);
+		}
+	}
+
+	if (rtw_ht_operation_update(padapter) > 0) {
+		update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
+		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
+		beacon_updated = _TRUE;
+	}
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		struct sta_priv *pstapriv = &padapter->stapriv;
+
+		update_beacon(padapter, WLAN_EID_MESH_CONFIG, NULL, _FALSE);
+		if (pstapriv->asoc_list_cnt == 1)
+			_set_timer(&padapter->mesh_atlm_param_req_timer, 0);
+		beacon_updated = _TRUE;
+	}
+#endif
+
+	if (beacon_updated)
+		update_beacon(padapter, 0xFF, NULL, _TRUE);
+
+	/* update associcated stations cap. */
+	associated_clients_update(padapter,  beacon_updated, STA_INFO_UPDATE_ALL);
+
+	RTW_INFO("%s, updated=%d\n", __func__, beacon_updated);
+
+}
+
+u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta)
+{
+	u8 beacon_updated = _FALSE;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+
+	if (!psta)
+		return beacon_updated;
+
+	if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
+		rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
+		beacon_updated = _TRUE;
+		update_beacon(padapter, _TIM_IE_, NULL, _FALSE);
+	}
+
+	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;
+	}
+
+	if (psta->nonerp_set) {
+		psta->nonerp_set = 0;
+		pmlmepriv->num_sta_non_erp--;
+		if (pmlmepriv->num_sta_non_erp == 0) {
+			beacon_updated = _TRUE;
+			update_beacon(padapter, _ERPINFO_IE_, NULL, _FALSE);
+		}
+	}
+
+	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;
+	}
+
+#ifdef CONFIG_80211N_HT
+	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 (psta->ht_40mhz_intolerant) {
+		psta->ht_40mhz_intolerant = 0;
+		if (pmlmepriv->num_sta_40mhz_intolerant > 0)
+			pmlmepriv->num_sta_40mhz_intolerant--;
+		else
+			rtw_warn_on(1);
+	}
+
+	if (rtw_ht_operation_update(padapter) > 0) {
+		update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
+		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
+	}
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		update_beacon(padapter, WLAN_EID_MESH_CONFIG, NULL, _FALSE);
+		if (pstapriv->asoc_list_cnt == 0)
+			_cancel_timer_ex(&padapter->mesh_atlm_param_req_timer);
+		beacon_updated = _TRUE;
+	}
+#endif
+
+	if (beacon_updated == _TRUE)
+		update_beacon(padapter, 0xFF, NULL, _TRUE);
+
+#if 0
+	/* update associated stations cap. */
+	associated_clients_update(padapter,  beacon_updated, STA_INFO_UPDATE_ALL); /* move it to avoid deadlock */
+#endif
+
+	RTW_INFO("%s, updated=%d\n", __func__, beacon_updated);
+
+	return beacon_updated;
+
+}
+
+u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reason, bool enqueue)
+{
+	_irqL irqL;
+	u8 beacon_updated = _FALSE;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	if (!psta)
+		return beacon_updated;
+
+	if (active == _TRUE) {
+#ifdef CONFIG_80211N_HT
+		/* tear down Rx AMPDU */
+		send_delba(padapter, 0, psta->cmn.mac_addr);/* recipient */
+
+		/* tear down TX AMPDU */
+		send_delba(padapter, 1, psta->cmn.mac_addr);/*  */ /* originator */
+
+#endif /* CONFIG_80211N_HT */
+
+		if (!MLME_IS_MESH(padapter))
+			issue_deauth(padapter, psta->cmn.mac_addr, reason);
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_mesh_path_flush_by_nexthop(psta);
+#endif
+
+#ifdef CONFIG_BEAMFORMING
+	beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_LEAVE, psta->cmn.mac_addr, ETH_ALEN, 1);
+#endif
+
+	psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
+	psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
+
+	/* clear cam entry / key */
+	rtw_clearstakey_cmd(padapter, psta, enqueue);
+
+
+	_enter_critical_bh(&psta->lock, &irqL);
+	psta->state &= ~_FW_LINKED;
+	_exit_critical_bh(&psta->lock, &irqL);
+
+	if (!MLME_IS_MESH(padapter)) {
+#ifdef CONFIG_IOCTL_CFG80211
+		#ifdef COMPAT_KERNEL_RELEASE
+		rtw_cfg80211_indicate_sta_disassoc(padapter, psta->cmn.mac_addr, reason);
+		#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
+		rtw_cfg80211_indicate_sta_disassoc(padapter, psta->cmn.mac_addr, reason);
+		#else /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER) */
+		/* will call rtw_cfg80211_indicate_sta_disassoc() in cmd_thread for old API context */
+		#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER) */
+#else
+		rtw_indicate_sta_disassoc_event(padapter, psta);
+#endif
+	}
+	beacon_updated = bss_cap_update_on_sta_leave(padapter, psta);
+
+	report_del_sta_event(padapter, psta->cmn.mac_addr, reason, enqueue, _FALSE);
+
+	return beacon_updated;
+
+}
+
+int rtw_ap_inform_ch_switch(_adapter *padapter, u8 new_ch, u8 ch_offset)
+{
+	_irqL irqL;
+	_list	*phead, *plist;
+	int ret = 0;
+	struct sta_info *psta = NULL;
+	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};
+
+	if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
+		return ret;
+
+	RTW_INFO(FUNC_NDEV_FMT" with ch:%u, offset:%u\n",
+		 FUNC_NDEV_ARG(padapter->pnetdev), new_ch, ch_offset);
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	/* for each sta in asoc_queue */
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+
+		issue_action_spct_ch_switch(padapter, psta->cmn.mac_addr, new_ch, ch_offset);
+		psta->expire_to = ((pstapriv->expire_to * 2) > 5) ? 5 : (pstapriv->expire_to * 2);
+	}
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	issue_action_spct_ch_switch(padapter, bc_addr, new_ch, ch_offset);
+
+	return ret;
+}
+
+int rtw_sta_flush(_adapter *padapter, bool enqueue)
+{
+	_irqL irqL;
+	_list	*phead, *plist;
+	int ret = 0;
+	struct sta_info *psta = NULL;
+	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 flush_num = 0;
+	char flush_list[NUM_STA];
+	int i;
+
+	if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
+		return ret;
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(padapter->pnetdev));
+
+	/* pick sta from sta asoc_queue */
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		int stainfo_offset;
+
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+
+		rtw_list_delete(&psta->asoc_list);
+		pstapriv->asoc_list_cnt--;
+		STA_SET_MESH_PLINK(psta, NULL);
+
+		stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
+		if (stainfo_offset_valid(stainfo_offset))
+			flush_list[flush_num++] = stainfo_offset;
+		else
+			rtw_warn_on(1);
+	}
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	/* call ap_free_sta() for each sta picked */
+	for (i = 0; i < flush_num; i++) {
+		u8 sta_addr[ETH_ALEN];
+
+		psta = rtw_get_stainfo_by_offset(pstapriv, flush_list[i]);
+		_rtw_memcpy(sta_addr, psta->cmn.mac_addr, ETH_ALEN);
+
+		ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, enqueue);
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter))
+			rtw_mesh_expire_peer(padapter, sta_addr);
+		#endif
+	}
+
+	if (!MLME_IS_MESH(padapter))
+		issue_deauth(padapter, bc_addr, WLAN_REASON_DEAUTH_LEAVING);
+
+	associated_clients_update(padapter, _TRUE, STA_INFO_UPDATE_ALL);
+
+	return ret;
+}
+
+/* called > TSR LEVEL for USB or SDIO Interface*/
+void sta_info_update(_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->qospriv.qos_option == 0)
+		psta->qos_option = 0;
+
+
+#ifdef CONFIG_80211N_HT
+	/* update 802.11n ht cap. */
+	if (WLAN_STA_HT & flags) {
+		psta->htpriv.ht_option = _TRUE;
+		psta->qos_option = 1;
+
+		psta->htpriv.smps_cap = (psta->htpriv.ht_cap.cap_info & IEEE80211_HT_CAP_SM_PS) >> 2;
+	} else
+		psta->htpriv.ht_option = _FALSE;
+
+	if (pmlmepriv->htpriv.ht_option == _FALSE)
+		psta->htpriv.ht_option = _FALSE;
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+	/* update 802.11AC vht cap. */
+	if (WLAN_STA_VHT & flags)
+		psta->vhtpriv.vht_option = _TRUE;
+	else
+		psta->vhtpriv.vht_option = _FALSE;
+
+	if (pmlmepriv->vhtpriv.vht_option == _FALSE)
+		psta->vhtpriv.vht_option = _FALSE;
+#endif
+
+	update_sta_info_apmode(padapter, psta);
+}
+
+/* called >= TSR LEVEL for USB or SDIO Interface*/
+void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta)
+{
+	if (psta->state & _FW_LINKED)
+		rtw_hal_update_ra_mask(psta); /* DM_RATR_STA_INIT */
+}
+/* restore hw setting from sw data structures */
+void rtw_ap_restore_network(_adapter *padapter)
+{
+	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	_irqL irqL;
+	_list	*phead, *plist;
+	u8 chk_alive_num = 0;
+	char chk_alive_list[NUM_STA];
+	int i;
+
+	rtw_setopmode_cmd(padapter
+		, MLME_IS_AP(padapter) ? Ndis802_11APMode : Ndis802_11_mesh
+		, RTW_CMDF_DIRECTLY
+	);
+
+	set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
+
+	rtw_startbss_cmd(padapter, RTW_CMDF_DIRECTLY);
+
+	if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
+	    (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
+		/* restore group key, WEP keys is restored in ips_leave() */
+		rtw_set_key(padapter, psecuritypriv, psecuritypriv->dot118021XGrpKeyid, 0, _FALSE);
+	}
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		int stainfo_offset;
+
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+
+		stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
+		if (stainfo_offset_valid(stainfo_offset))
+			chk_alive_list[chk_alive_num++] = stainfo_offset;
+	}
+
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
 	for (i = 0; i < chk_alive_num; i++) {
-		int ret = _FAIL;
-
-		psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
-#ifdef CONFIG_ATMEL_RC_PATCH
-		if (_TRUE == _rtw_memcmp(  pstapriv->atmel_rc_pattern, psta->hwaddr, ETH_ALEN))
-			continue;
-		if (psta->flag_atmel_rc)
-			continue;
-#endif
-		if(!(psta->state &_FW_LINKED))
-			continue;		
-	
-		if (psta->state & WIFI_SLEEP_STATE)
-			ret = issue_nulldata(padapter, psta->hwaddr, 0, 1, 50);
-		else
-			ret = issue_nulldata(padapter, psta->hwaddr, 0, 3, 50);
-
-		psta->keep_alive_trycnt++;
-		if (ret == _SUCCESS)
-		{
-			DBG_871X("asoc check, sta(" MAC_FMT ") is alive\n", MAC_ARG(psta->hwaddr));
-			psta->expire_to = pstapriv->expire_to;
-			psta->keep_alive_trycnt = 0;
-			continue;
-		}
-		else if (psta->keep_alive_trycnt <= 3)
-		{
-			DBG_871X("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_871X("asoc expire "MAC_FMT", state=0x%x\n", MAC_ARG(psta->hwaddr), psta->state);
-		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-		if (rtw_is_list_empty(&psta->asoc_list)==_FALSE) {
-			rtw_list_delete(&psta->asoc_list);
-			pstapriv->asoc_list_cnt--;
-			updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
-		}
-		_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-	}
-
-	/* back to the original operation channel */
-	if (backup_ch > 0)
-		set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
-
-bypass_active_keep_alive:
-	;
-}
-#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
-
-	associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
-}
-
-void add_RATid(_adapter *padapter, struct sta_info *psta, u8 rssi_level)
-{	
-	int i;
-	u8 rf_type;
-	unsigned char sta_band = 0, shortGIrate = _FALSE;
-	u64 tx_ra_bitmap = 0;
-	struct ht_priv	*psta_ht = NULL;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	WLAN_BSSID_EX *pcur_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
-	u8 bw;
-
-#ifdef CONFIG_80211N_HT
-	if(psta)
-		psta_ht = &psta->htpriv;
-	else
-		return;
-#endif //CONFIG_80211N_HT
-
-	if(!(psta->state & _FW_LINKED))
-		return;
-
-#if 0//gtest
-	if(get_rf_mimo_mode(padapter) == RTL8712_RF_2T2R)
-	{
-		//is this a 2r STA?
-		if((pstat->tx_ra_bitmap & 0x0ff00000) != 0 && !(priv->pshare->has_2r_sta & BIT(pstat->aid)))
-		{
-			priv->pshare->has_2r_sta |= BIT(pstat->aid);
-			if(rtw_read16(padapter, 0x102501f6) != 0xffff)
-			{
-				rtw_write16(padapter, 0x102501f6, 0xffff);
-				reset_1r_sta_RA(priv, 0xffff);
-				Switch_1SS_Antenna(priv, 3);
-			}
-		}
-		else// bg or 1R STA? 
-		{ 
-			if((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N) && pstat->ht_cap_len && priv->pshare->has_2r_sta == 0)
-			{
-				if(rtw_read16(padapter, 0x102501f6) != 0x7777)
-				{ // MCS7 SGI
-					rtw_write16(padapter, 0x102501f6,0x7777);
-					reset_1r_sta_RA(priv, 0x7777);
-					Switch_1SS_Antenna(priv, 2);
-				}
-			}
-		}
-		
-	}
-
-	if ((pstat->rssi_level < 1) || (pstat->rssi_level > 3)) 
-	{
-		if (pstat->rssi >= priv->pshare->rf_ft_var.raGoDownUpper)
-			pstat->rssi_level = 1;
-		else if ((pstat->rssi >= priv->pshare->rf_ft_var.raGoDown20MLower) ||
-			((priv->pshare->is_40m_bw) && (pstat->ht_cap_len) &&
-			(pstat->rssi >= priv->pshare->rf_ft_var.raGoDown40MLower) &&
-			(pstat->ht_cap_buf.ht_cap_info & cpu_to_le16(_HTCAP_SUPPORT_CH_WDTH_))))
-			pstat->rssi_level = 2;
-		else
-			pstat->rssi_level = 3;
-	}
-
-	// rate adaptive by rssi
-	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N) && pstat->ht_cap_len)
-	{
-		if ((get_rf_mimo_mode(priv) == MIMO_1T2R) || (get_rf_mimo_mode(priv) == MIMO_1T1R))
-		{
-			switch (pstat->rssi_level) {
-				case 1:
-					pstat->tx_ra_bitmap &= 0x100f0000;
-					break;
-				case 2:
-					pstat->tx_ra_bitmap &= 0x100ff000;
-					break;
-				case 3:
-					if (priv->pshare->is_40m_bw)
-						pstat->tx_ra_bitmap &= 0x100ff005;
-					else
-						pstat->tx_ra_bitmap &= 0x100ff001;
-
-					break;
-			}
-		}
-		else 
-		{
-			switch (pstat->rssi_level) {
-				case 1:
-					pstat->tx_ra_bitmap &= 0x1f0f0000;
-					break;
-				case 2:
-					pstat->tx_ra_bitmap &= 0x1f0ff000;
-					break;
-				case 3:
-					if (priv->pshare->is_40m_bw)
-						pstat->tx_ra_bitmap &= 0x000ff005;
-					else
-						pstat->tx_ra_bitmap &= 0x000ff001;
-
-					break;
-			}
-
-			// Don't need to mask high rates due to new rate adaptive parameters
-			//if (pstat->is_broadcom_sta)		// use MCS12 as the highest rate vs. Broadcom sta
-			//	pstat->tx_ra_bitmap &= 0x81ffffff;
-
-			// NIC driver will report not supporting MCS15 and MCS14 in asoc req
-			//if (pstat->is_rtl8190_sta && !pstat->is_2t_mimo_sta)
-			//	pstat->tx_ra_bitmap &= 0x83ffffff;		// if Realtek 1x2 sta, don't use MCS15 and MCS14
-		}
-	}
-	else if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) && isErpSta(pstat))
-	{
-		switch (pstat->rssi_level) {
-			case 1:
-				pstat->tx_ra_bitmap &= 0x00000f00;
-				break;
-			case 2:
-				pstat->tx_ra_bitmap &= 0x00000ff0;
-				break;
-			case 3:
-				pstat->tx_ra_bitmap &= 0x00000ff5;
-				break;
-		}
-	}
-	else 
-	{
-		pstat->tx_ra_bitmap &= 0x0000000d;
-	}
-
-	// disable tx short GI when station cannot rx MCS15(AP is 2T2R)
-	// disable tx short GI when station cannot rx MCS7 (AP is 1T2R or 1T1R)
-	// if there is only 1r STA and we are 2T2R, DO NOT mask SGI rate
-	if ((!(pstat->tx_ra_bitmap & 0x8000000) && (priv->pshare->has_2r_sta > 0) && (get_rf_mimo_mode(padapter) == RTL8712_RF_2T2R)) ||
-		 (!(pstat->tx_ra_bitmap & 0x80000) && (get_rf_mimo_mode(padapter) != RTL8712_RF_2T2R)))
-	{
-		pstat->tx_ra_bitmap &= ~BIT(28);	
-	}
-#endif
-
-	rtw_hal_update_sta_rate_mask(padapter, psta);
-	tx_ra_bitmap = psta->ra_mask;
-
-	bw = rtw_get_tx_bw_mode(padapter, psta);
-	shortGIrate = query_ra_short_GI(psta, bw);
-
-	if ( pcur_network->Configuration.DSConfig > 14 ) {
-		
-		if (tx_ra_bitmap & 0xffff000)
-			sta_band |= WIRELESS_11_5N ;
-
-		if (tx_ra_bitmap & 0xff0)
-			sta_band |= WIRELESS_11A;
-
-		// 5G band
-		#ifdef CONFIG_80211AC_VHT
-		if (psta->vhtpriv.vht_option)  {
-			sta_band = WIRELESS_11_5AC;
-		}		
-		#endif
-		
-	} else {
-		if (tx_ra_bitmap & 0xffff000)
-			sta_band |= WIRELESS_11_24N;
-
-		if (tx_ra_bitmap & 0xff0)
-			sta_band |= WIRELESS_11G;
-
-		if (tx_ra_bitmap & 0x0f)
-			sta_band |= WIRELESS_11B;
-	}
-
-	psta->wireless_mode = sta_band;
-	psta->raid = rtw_hal_networktype_to_raid(padapter, psta);
-	
-	if (psta->aid < NUM_STA)
-	{
-		u8	arg[4] = {0};
-
-		arg[0] = psta->mac_id;
-		arg[1] = psta->raid;
-		arg[2] = shortGIrate;
-		arg[3] = psta->init_rate;
-
-		DBG_871X("%s=> mac_id:%d , raid:%d , shortGIrate=%d, tx_ra_bitmap:0x%016llx, networkType:0x%02x\n", 
-			__FUNCTION__, psta->mac_id, psta->raid, shortGIrate, tx_ra_bitmap, psta->wireless_mode);
-			
-		rtw_hal_add_ra_tid(padapter, tx_ra_bitmap, arg, rssi_level);
-	}
-	else 
-	{
-		DBG_871X("station aid %d exceed the max number\n", psta->aid);
-	}
-
-}
-
-void update_bmc_sta(_adapter *padapter)
-{
-	_irqL	irqL;
-	unsigned char	network_type;
-	int supportRateNum = 0;
-	u64 tx_ra_bitmap = 0;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	WLAN_BSSID_EX *pcur_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;	
-	struct sta_info *psta = rtw_get_bcmc_stainfo(padapter);
-
-	if(psta)
-	{
-		psta->aid = 0;//default set to 0
-		psta->qos_option = 0;
-#ifdef CONFIG_80211N_HT	
-		psta->htpriv.ht_option = _FALSE;
-#endif //CONFIG_80211N_HT
-
-		psta->ieee8021x_blocked = 0;
-
-		_rtw_memset((void*)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
-
-		//psta->dot118021XPrivacy = _NO_PRIVACY_;//!!! remove it, because it has been set before this.
-
-		//prepare for add_RATid		
-		supportRateNum = rtw_get_rateset_len((u8*)&pcur_network->SupportedRates);
-		network_type = rtw_check_network_type((u8*)&pcur_network->SupportedRates, supportRateNum, pcur_network->Configuration.DSConfig);
-		if (IsSupportedTxCCK(network_type)) {
-			network_type = WIRELESS_11B;
-		}
-		else if (network_type == WIRELESS_INVALID) { // error handling
-			if ( pcur_network->Configuration.DSConfig > 14 )
-				network_type = WIRELESS_11A;
-			else
-				network_type = WIRELESS_11B;
-		}
-		update_sta_basic_rate(psta, network_type);
-		psta->wireless_mode = network_type;
-
-		rtw_hal_update_sta_rate_mask(padapter, psta);
-		tx_ra_bitmap = psta->ra_mask;
-
-		psta->raid = rtw_hal_networktype_to_raid(padapter,psta);
-
-		//ap mode
-		rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
-
-		//if(pHalData->fw_ractrl == _TRUE)
-		{
-			u8	arg[4] = {0};
-
-			arg[0] = psta->mac_id;
-			arg[1] = psta->raid;
-			arg[2] = 0;
-			arg[3] = psta->init_rate;
-
-			DBG_871X("%s=> mac_id:%d , raid:%d , bitmap=0x%016llx\n", 
-				__FUNCTION__ , psta->mac_id, psta->raid , tx_ra_bitmap);
-
-			rtw_hal_add_ra_tid(padapter, tx_ra_bitmap, arg, 0);
-		}
-
-		rtw_sta_media_status_rpt(padapter, psta, 1);
-
-		_enter_critical_bh(&psta->lock, &irqL);
-		psta->state = _FW_LINKED;
-		_exit_critical_bh(&psta->lock, &irqL);
-
-	}
-	else
-	{
-		DBG_871X("add_RATid_bmc_sta error!\n");
-	}
-		
-}
-
-//notes:
-//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_info_apmode(_adapter *padapter, struct sta_info *psta)
-{	
-	_irqL	irqL;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-#ifdef CONFIG_80211N_HT
-	struct ht_priv	*phtpriv_ap = &pmlmepriv->htpriv;
-	struct ht_priv	*phtpriv_sta = &psta->htpriv;
-#endif //CONFIG_80211N_HT
-	u8	cur_ldpc_cap=0, cur_stbc_cap=0, cur_beamform_cap=0;
-	//set intf_tag to if1
-	//psta->intf_tag = 0;
-
-        DBG_871X("%s\n",__FUNCTION__);
-
-	//psta->mac_id = psta->aid+4;
-	//psta->mac_id = psta->aid+1;//alloc macid when call rtw_alloc_stainfo(),
-		                                       //release macid when call rtw_free_stainfo()
-
-	//ap mode
-	rtw_hal_set_odm_var(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_update(padapter, psta);
-#ifdef CONFIG_80211N_HT	
-	//HT related cap
-	if(phtpriv_sta->ht_option)
-	{
-		//check if sta supports rx ampdu
-		phtpriv_sta->ampdu_enable = phtpriv_ap->ampdu_enable;
-
-		phtpriv_sta->rx_ampdu_min_spacing = (phtpriv_sta->ht_cap.ampdu_params_info&IEEE80211_HT_CAP_AMPDU_DENSITY)>>2;
-	
-		// bwmode
-		if((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH))
-		{			
-			psta->bw_mode = CHANNEL_WIDTH_40;
-		}
-		else
-		{			
-			psta->bw_mode = CHANNEL_WIDTH_20;
-		}
-
-		if (psta->ht_40mhz_intolerant)
-			psta->bw_mode = CHANNEL_WIDTH_20;
-		
-		if(pmlmeext->cur_bwmode < psta->bw_mode)
-		{
-			psta->bw_mode = pmlmeext->cur_bwmode;
-		}
-
-		phtpriv_sta->ch_offset = pmlmeext->cur_ch_offset;
-
-
-		//check if sta support s Short GI 20M 
-		if((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_20))
-		{
-			phtpriv_sta->sgi_20m = _TRUE;
-		}
-		
-		//check if sta support s Short GI 40M 
-		if((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_40))
-		{
-			if(psta->bw_mode == CHANNEL_WIDTH_40) //according to psta->bw_mode
-				phtpriv_sta->sgi_40m = _TRUE;
-			else
-				phtpriv_sta->sgi_40m = _FALSE;
-		}
-
-		psta->qos_option = _TRUE;
-
-		// B0 Config LDPC Coding Capability
-		if (TEST_FLAG(phtpriv_ap->ldpc_cap, LDPC_HT_ENABLE_TX) && 
-			GET_HT_CAP_ELE_LDPC_CAP((u8 *)(&phtpriv_sta->ht_cap)))
-		{
-			SET_FLAG(cur_ldpc_cap, (LDPC_HT_ENABLE_TX | LDPC_HT_CAP_TX));
-			DBG_871X("Enable HT Tx LDPC for STA(%d)\n",psta->aid);
-		}
-
-		// B7 B8 B9 Config STBC setting
-		if (TEST_FLAG(phtpriv_ap->stbc_cap, STBC_HT_ENABLE_TX) &&
-			GET_HT_CAP_ELE_RX_STBC((u8 *)(&phtpriv_sta->ht_cap)))
-		{
-			SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX) );
-			DBG_871X("Enable HT Tx STBC for STA(%d)\n",psta->aid);
-		}
-
-#ifdef CONFIG_BEAMFORMING
-		/*Config Tx beamforming setting*/
-		if (TEST_FLAG(phtpriv_ap->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) && 
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP((u8 *)(&phtpriv_sta->ht_cap)))
-		{
-			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
-			/*Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
-			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS((u8 *)(&phtpriv_sta->ht_cap)) << 6);
-		}
-
-		if (TEST_FLAG(phtpriv_ap->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP((u8 *)(&phtpriv_sta->ht_cap)))
-		{
-			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
-			/*Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
-			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS((u8 *)(&phtpriv_sta->ht_cap)) << 4);
-		}
-		if (cur_beamform_cap) {
-			DBG_871X("Client STA(%d) HT Beamforming Cap = 0x%02X\n", psta->aid, cur_beamform_cap);
-		}
-#endif /*CONFIG_BEAMFORMING*/
-	}
-	else
-	{
-		phtpriv_sta->ampdu_enable = _FALSE;
-		
-		phtpriv_sta->sgi_20m = _FALSE;
-		phtpriv_sta->sgi_40m = _FALSE;
-		psta->bw_mode = CHANNEL_WIDTH_20;
-		phtpriv_sta->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	}
-
-	phtpriv_sta->ldpc_cap = cur_ldpc_cap;
-	phtpriv_sta->stbc_cap = cur_stbc_cap;
-	phtpriv_sta->beamform_cap = cur_beamform_cap;
-
-	//Rx AMPDU
-	send_delba(padapter, 0, psta->hwaddr);// recipient
-	
-	//TX AMPDU
-	send_delba(padapter, 1, psta->hwaddr);// // originator
-	phtpriv_sta->agg_enable_bitmap = 0x0;//reset
-	phtpriv_sta->candidate_tid_bitmap = 0x0;//reset
-#endif //CONFIG_80211N_HT
-
-#ifdef CONFIG_80211AC_VHT
-	update_sta_vht_info_apmode(padapter, psta);
-#endif
-
-	update_ldpc_stbc_cap(psta);
-
-	//todo: init other variables
-	
-	_rtw_memset((void*)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
-
-
-	//add ratid
-	//add_RATid(padapter, psta);//move to ap_sta_info_defer_update()
-
-
-	_enter_critical_bh(&psta->lock, &irqL);
-	psta->state |= _FW_LINKED;
-	_exit_critical_bh(&psta->lock, &irqL);
-	
-
-}
-
-static void update_ap_info(_adapter *padapter, struct sta_info *psta)
-{
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-#ifdef CONFIG_80211N_HT
-	struct ht_priv	*phtpriv_ap = &pmlmepriv->htpriv;
-#endif //CONFIG_80211N_HT
-
-	psta->wireless_mode = pmlmeext->cur_wireless_mode;
-
-	psta->bssratelen = rtw_get_rateset_len(pnetwork->SupportedRates);
-	_rtw_memcpy(psta->bssrateset, pnetwork->SupportedRates, psta->bssratelen);
-
-#ifdef CONFIG_80211N_HT	
-	//HT related cap
-	if(phtpriv_ap->ht_option)
-	{
-		//check if sta supports rx ampdu
-		//phtpriv_ap->ampdu_enable = phtpriv_ap->ampdu_enable;
-
-		//check if sta support s Short GI 20M
-		if((phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_20))
-		{
-			phtpriv_ap->sgi_20m = _TRUE;
-		}
-		//check if sta support s Short GI 40M
-		if((phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_40))
-		{
-			phtpriv_ap->sgi_40m = _TRUE;
-		}
-
-		psta->qos_option = _TRUE;
-	}
-	else
-	{
-		phtpriv_ap->ampdu_enable = _FALSE;
-		
-		phtpriv_ap->sgi_20m = _FALSE;
-		phtpriv_ap->sgi_40m = _FALSE;
-	}
-
-	psta->bw_mode = pmlmeext->cur_bwmode;
-	phtpriv_ap->ch_offset = pmlmeext->cur_ch_offset;
-
-	phtpriv_ap->agg_enable_bitmap = 0x0;//reset
-	phtpriv_ap->candidate_tid_bitmap = 0x0;//reset
-
-	_rtw_memcpy(&psta->htpriv, &pmlmepriv->htpriv, sizeof(struct ht_priv));
-
-#ifdef CONFIG_80211AC_VHT
-	_rtw_memcpy(&psta->vhtpriv, &pmlmepriv->vhtpriv, sizeof(struct vht_priv));
-#endif //CONFIG_80211AC_VHT
-
-#endif //CONFIG_80211N_HT
-
-	psta->state |= WIFI_AP_STATE; /* Aries, add,fix bug of flush_cam_entry at STOP AP mode , 0724 */
-}
-
-static void rtw_set_hw_wmm_param(_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;
-
-	acm_mask = 0;
-
-	if (IsSupported5G(pmlmeext->cur_wireless_mode) || 
-		(pmlmeext->cur_wireless_mode & WIRELESS_11_24N))
-		aSifsTime = 16;
-	else
-		aSifsTime = 10;
-
-	if (pmlmeinfo->WMM_enable == 0) {
-		padapter->mlmepriv.acm_mask = 0;
-
-		AIFS = aSifsTime + (2 * pmlmeinfo->slotTime);
-
-		if (pmlmeext->cur_wireless_mode & (WIRELESS_11G | WIRELESS_11A)) {
-			ECWMin = 4;
-			ECWMax = 10;
-		} else if (pmlmeext->cur_wireless_mode & WIRELESS_11B) {
-			ECWMin = 5;
-			ECWMax = 10;
-		} else {
-			ECWMin = 4;
-			ECWMax = 10;
-		}
-
-		TXOP = 0;
-		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
-
-		ECWMin = 2;
-		ECWMax = 3;
-		TXOP = 0x2f;
-		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
-		
-	} else {
-		edca[0] = edca[1] = edca[2] = edca[3] = 0;
-
-		/*TODO:*/
-		acm_mask = 0;
-		padapter->mlmepriv.acm_mask = acm_mask;
-
-		/*
-		//BK
-		//AIFS = AIFSN * slot time + SIFS - r2t phy delay
-		*/
-		AIFS = (7 * pmlmeinfo->slotTime) + aSifsTime;
-		ECWMin = 4;
-		ECWMax = 10;
-		TXOP = 0;		
-		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
-		edca[XMIT_BK_QUEUE] = acParm;
-		DBG_871X("WMM(BK): %x\n", acParm);
-		
-		/* BE */
-		AIFS = (3 * pmlmeinfo->slotTime) + aSifsTime;
-		ECWMin = 4;
-		ECWMax = 6;
-		TXOP = 0;		
-		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
-		edca[XMIT_BE_QUEUE] = acParm;
-		DBG_871X("WMM(BE): %x\n", acParm);
-
-		/* VI */
-		AIFS = (1 * pmlmeinfo->slotTime) + aSifsTime;
-		ECWMin = 3;
-		ECWMax = 4;
-		TXOP = 94;		
-		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
-		edca[XMIT_VI_QUEUE] = acParm;
-		DBG_871X("WMM(VI): %x\n", acParm);
-
-		/* VO */
-		AIFS = (1 * pmlmeinfo->slotTime) + aSifsTime;
-		ECWMin = 2;
-		ECWMax = 3;
-		TXOP = 47;		
-		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
-		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
-		edca[XMIT_VO_QUEUE] = acParm;
-		DBG_871X("WMM(VO): %x\n", acParm);
-
-		
-		if (padapter->registrypriv.acm_method == 1)
-			rtw_hal_set_hwreg(padapter, HW_VAR_ACM_CTRL, (u8 *)(&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, tmp, 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) {
-						tmp = edca[i];
-						edca[i] = edca[j];
-						edca[j] = tmp;
-
-						tmp = inx[i];
-						inx[i] = inx[j];
-						inx[j] = tmp;
-
-						change_inx = _FALSE;
-					}
-				}
-			}
-		}
-
-		for (i = 0 ; i < 4 ; i++) {
-			pxmitpriv->wmm_para_seq[i] = inx[i];
-			DBG_871X("wmm_para_seq(%d): %d\n", i, pxmitpriv->wmm_para_seq[i]);
-		}
-		
-	}
-	
-}
-
-static void update_hw_ht_param(_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_871X("%s\n", __FUNCTION__);
-	
-
-	//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_caps.u.HT_cap_element.AMPDU_para & 0x03;	
-	
-	min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;	
-
-	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MIN_SPACE, (u8 *)(&min_MPDU_spacing));
-
-	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&max_AMPDU_len));
-
-	//
-	// Config SM Power Save setting
-	//
-	pmlmeinfo->SM_PS = (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & 0x0C) >> 2;
-	if(pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC)
-	{
-		/*u8 i;
-		//update the MCS rates
-		for (i = 0; i < 16; i++)
-		{
-			pmlmeinfo->HT_caps.HT_cap_element.MCS_rate[i] &= MCS_rate_1R[i];
-		}*/
-		DBG_871X("%s(): WLAN_HT_CAP_SM_PS_STATIC\n",__FUNCTION__);
-	}
-
-	//
-	// Config current HT Protection mode.
-	//
-	//pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3;
-
-}
-
-static void rtw_ap_check_scan(_adapter *padapter)
-{
-	_irqL	irqL;
-	_list		*plist, *phead;
-	u32	delta_time, lifetime;
-	struct	wlan_network	*pnetwork = NULL;
-	WLAN_BSSID_EX *pbss = NULL;	
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);	
-	_queue	*queue	= &(pmlmepriv->scanned_queue);
-	u8 do_scan = _FALSE;
-
-	lifetime = SCANQUEUE_LIFETIME; /* 20 sec */
-
-	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-	phead = get_list_head(queue);
-	if (rtw_end_of_queue_search(phead, get_next(phead)) == _TRUE)
-		if (padapter->registrypriv.wifi_spec)
-			do_scan = _TRUE;
-	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-	if (padapter->registrypriv.acs_auto_scan) {
-		do_scan = _TRUE;
-		rtw_acs_start(padapter, _TRUE);
-	}
-#endif
-		
-	if (_TRUE == do_scan) {
-		DBG_871X("%s : drv scans by itself and wait_completed\n", __func__);
-		rtw_drv_scan_by_self(padapter);
-		rtw_scan_wait_completed(padapter);
-	}
-	
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-	if (padapter->registrypriv.acs_auto_scan)
-		rtw_acs_start(padapter, _FALSE);
-#endif	
-	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-
-	phead = get_list_head(queue);
-	plist = get_next(phead);
-
-	while (1) {
-		
-		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
-			break;
-
-		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-		
-		if (rtw_ch_set_search_ch(padapter->mlmeextpriv.channel_set, pnetwork->network.Configuration.DSConfig) >= 0
-			&& rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
-			&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))) {		
-			delta_time = (u32) rtw_get_passing_time_ms(pnetwork->last_scanned);
-			
-			if (delta_time < lifetime) {
-
-				uint ie_len = 0;	
-				u8 *pbuf = NULL;
-				u8 *ie = NULL;
-		
-				pbss = &pnetwork->network;
-				ie = pbss->IEs;
-		
-				/*check if HT CAP INFO IE exists or not*/
-				pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss->IELength - _BEACON_IE_OFFSET_));
-				if (pbuf == NULL) {
-					/* HT CAP INFO IE don't exist, it is b/g mode bss.*/
-				
-					if (pmlmepriv->olbc == _FALSE)
-						pmlmepriv->olbc = _TRUE;
-
-					if (pmlmepriv->olbc_ht == _FALSE)
-						pmlmepriv->olbc_ht = _TRUE;
-				}						
-			}			
-		}
-
-		plist = get_next(plist);	
-		
-	}
-	
-	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-
-	pmlmepriv->num_sta_no_ht = 0; /* reset to 0 after ap do scanning*/
-	
-}
-
-void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter)
-{
-	WLAN_BSSID_EX *pnetwork = &(adapter->mlmepriv.cur_network.network);
-	struct sta_info *sta = NULL;
-
-	/* update cur_wireless_mode */
-	update_wireless_mode(adapter);
-
-	/* update RRSR and RTS_INIT_RATE register after set channel and bandwidth */
-	UpdateBrateTbl(adapter, pnetwork->SupportedRates);
-	rtw_hal_set_hwreg(adapter, HW_VAR_BASIC_RATE, pnetwork->SupportedRates);
-
-	/* update capability after cur_wireless_mode updated */
-	update_capinfo(adapter, rtw_get_capability(pnetwork));
-
-	/* update bc/mc sta_info */
-	update_bmc_sta(adapter);
-
-	/* update AP's sta info */
-	sta = rtw_get_stainfo(&adapter->stapriv, pnetwork->MacAddress);
-	if (!sta) {
-		DBG_871X(FUNC_ADPT_FMT" !sta for macaddr="MAC_FMT"\n", FUNC_ADPT_ARG(adapter), MAC_ARG(pnetwork->MacAddress));
-		rtw_warn_on(1);
-		return;
-	}
-
-	update_ap_info(adapter, sta);
-}
-
-void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
-{
-#define DUMP_ADAPTERS_STATUS 0
-
-	u8 val8;
-	u16 bcn_interval;
-	u32	acparm;
-	struct registry_priv	 *pregpriv = &padapter->registrypriv;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct security_priv* psecuritypriv=&(padapter->securitypriv);	
-	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network; /* used as input */
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork_mlmeext = &(pmlmeinfo->network);
-	u8 req_ch, req_bw, req_offset;
-	bool ch_setting_changed = _FALSE;
-	u8 ch_to_set = 0, bw_to_set, offset_to_set;
-	u8 doiqk = _FALSE;
-
-	if (parm->req_ch == 0) {
-		/* change to unspecificed ch, bw, offset, get from IE */
-		goto get_cbhw_from_ie;
-	} else if (parm->req_ch > 0) {
-		/* change ch, bw, offset */
-		req_ch = parm->req_ch;
-		req_bw = parm->req_bw;
-		req_offset = parm->req_offset;
-		goto change_chbw;
-	}
-
-	bcn_interval = (u16)pnetwork->Configuration.BeaconPeriod;	
-
-	//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(NULL == rtw_get_wps_ie(pnetwork->IEs+_FIXED_IE_LENGTH_, pnetwork->IELength-_FIXED_IE_LENGTH_, NULL, NULL))
-	{
-		pmlmeext->bstart_bss = _TRUE;
-	}
-
-	//todo: update wmm, ht cap
-	//pmlmeinfo->WMM_enable;
-	//pmlmeinfo->HT_enable;
-	if(pmlmepriv->qospriv.qos_option)
-		pmlmeinfo->WMM_enable = _TRUE;
-#ifdef CONFIG_80211N_HT
-	if(pmlmepriv->htpriv.ht_option)
-	{
-		pmlmeinfo->WMM_enable = _TRUE;
-		pmlmeinfo->HT_enable = _TRUE;
-		//pmlmeinfo->HT_info_enable = _TRUE;
-		//pmlmeinfo->HT_caps_enable = _TRUE;
-
-		update_hw_ht_param(padapter);
-	}
-#endif //#CONFIG_80211N_HT
-
-#ifdef CONFIG_80211AC_VHT
-	if(pmlmepriv->vhtpriv.vht_option) {
-		pmlmeinfo->VHT_enable = _TRUE;
-		update_hw_vht_param(padapter);
-	}
-#endif //CONFIG_80211AC_VHT
-
-	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 != _WEP40_) && (psecuritypriv->dot11PrivacyAlgrthm != _WEP104_))
-			flush_all_cam_entry(padapter);	//clear CAM
-	}	
-
-	//set MSR to AP_Mode		
-	Set_MSR(padapter, _HW_STATE_AP_);	
-		
-	//Set BSSID REG
-	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pnetwork->MacAddress);
-
-	//Set EDCA param reg
-#ifdef CONFIG_CONCURRENT_MODE
-	acparm = 0x005ea42b;
-#else
-	acparm = 0x002F3217; // VO
-#endif
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acparm));
-	acparm = 0x005E4317; // VI
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acparm));
-	//acparm = 0x00105320; // BE
-	acparm = 0x005ea42b;
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
-	acparm = 0x0000A444; // BK
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acparm));
-
-	//Set Security
-	val8 = (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)? 0xcc: 0xcf;
-	rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
-
-	//Beacon Control related register
-	rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&bcn_interval));
-
-#if 0
-	if(pmlmepriv->cur_network.join_res != _TRUE) //setting only at  first time
-	{
-		//u32 initialgain;
-
-		//initialgain = 0x1e;
-
-
-		//disable dynamic functions, such as high power, DIG
-		/*rtw_phydm_ability_backup(padapter);*/
-		/*rtw_phydm_func_disable_all(padapter);*/
-		
-		//turn on all dynamic functions	
-		/* Switch_DM_Func(padapter, DYNAMIC_ALL_FUNC_ENABLE, _TRUE);*/
-
-		/*rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);*/
-	
-	}
-#endif
-
-get_cbhw_from_ie:
-	rtw_ies_get_chbw(pnetwork->IEs + sizeof(NDIS_802_11_FIXED_IEs)
-		, pnetwork->IELength - sizeof(NDIS_802_11_FIXED_IEs)
-		, &req_ch, &req_bw, &req_offset);
-
-change_chbw:
-	rtw_warn_on(req_ch == 0);
-
-	ch_setting_changed = rtw_ap_chbw_decision(padapter, req_ch, req_bw, req_offset
-		, &ch_to_set, &bw_to_set, &offset_to_set);
-
-	//let pnetwork_mlmeext == pnetwork_mlme.
-	_rtw_memcpy(pnetwork_mlmeext, pnetwork, pnetwork->Length);
-
-	rtw_start_bss_hdl_after_chbw_decided(padapter);
-
-	#if defined(CONFIG_DFS_MASTER)
-	rtw_dfs_master_status_apply(padapter, MLME_AP_STARTED);
-	#endif
-
-	doiqk = _TRUE;
-	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
-	
-	if (ch_to_set != 0)
-		set_channel_bwmode(padapter, ch_to_set, offset_to_set, bw_to_set);
-
-	doiqk = _FALSE;
-	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
-	if (DUMP_ADAPTERS_STATUS) {
-		DBG_871X(FUNC_ADPT_FMT" done\n", FUNC_ADPT_ARG(padapter));
-		dump_adapters_status(RTW_DBGDUMP , adapter_to_dvobj(padapter));
-	}
-
-	if (_TRUE == pmlmeext->bstart_bss
-		&& !check_fwstate(pmlmepriv, WIFI_SITE_MONITOR)
-		&& !check_fwstate(pmlmepriv, WIFI_OP_CH_SWITCHING)
-		#ifdef CONFIG_CONCURRENT_MODE
-		&& !check_buddy_fwstate(padapter, WIFI_SITE_MONITOR)
-		#endif
-	) {
-
-	       if ((pmlmepriv->olbc == _TRUE) || (pmlmepriv->olbc_ht == _TRUE)) {
-
-			/* AP is not starting a 40 MHz BSS in presence of an 802.11g BSS. */
-
-			pmlmepriv->ht_op_mode &= (~HT_INFO_OPERATION_MODE_OP_MODE_MASK);
-			pmlmepriv->ht_op_mode |= OP_MODE_MAY_BE_LEGACY_STAS;
-			update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
-		}
-
-		update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
-
-		#if !defined(CONFIG_INTERRUPT_BASED_TXBCN)
-		#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-		/* other case will  tx beacon when bcn interrupt coming in. */
-		if (send_beacon(padapter) == _FAIL)
-			DBG_871X("issue_beacon, fail!\n");
-		#endif 
-		#endif /* !defined(CONFIG_INTERRUPT_BASED_TXBCN) */
-	}
-
-	/*Set EDCA param reg after update cur_wireless_mode & update_capinfo*/
-	if (pregpriv->wifi_spec == 1)
-		rtw_set_hw_wmm_param(padapter);
-	
-	/*pmlmeext->bstart_bss = _TRUE;*/
-}
-
-int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
-{
-	int ret=_SUCCESS;
-	u8 *p;
-	u8 *pHT_caps_ie=NULL;
-	u8 *pHT_info_ie=NULL;
-	u16 cap, 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 OUI1[] = {0x00, 0x50, 0xf2,0x01};
-	u8 wps_oui[4]={0x0,0x50,0xf2,0x04};
-	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);
-	WLAN_BSSID_EX *pbss_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;	
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 *ie = pbss_network->IEs;
-	u8 vht_cap=_FALSE;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8 rf_num = 0;
-	
-	/* 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_871X("%s, len=%d\n", __FUNCTION__, len);
-
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
-		return _FAIL;
-
-
-	if(len>MAX_IE_SZ)
-		return _FAIL;
-	
-	pbss_network->IELength = len;
-
-	_rtw_memset(ie, 0, MAX_IE_SZ);
-	
-	_rtw_memcpy(ie, pbuf, pbss_network->IELength);
-
-
-	if(pbss_network->InfrastructureMode!=Ndis802_11APMode)
-		return _FAIL;
-
-
-	rtw_ap_check_scan(padapter);
-	
-
-	pbss_network->Rssi = 0;
-
-	_rtw_memcpy(pbss_network->MacAddress, adapter_mac_addr(padapter), ETH_ALEN);
-	
-	//beacon interval
-	p = rtw_get_beacon_interval_from_ie(ie);//ie + 8;	// 8: TimeStamp, 2: Beacon Interval 2:Capability
-	//pbss_network->Configuration.BeaconPeriod = le16_to_cpu(*(unsigned short*)p);
-	pbss_network->Configuration.BeaconPeriod = RTW_GET_LE16(p);
-	
-	//capability
-	//cap = *(unsigned short *)rtw_get_capability_from_ie(ie);
-	//cap = le16_to_cpu(cap);
-	cap = RTW_GET_LE16(ie);
-
-	//SSID
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _SSID_IE_, &ie_len, (pbss_network->IELength -_BEACON_IE_OFFSET_));
-	if(p && ie_len>0)
-	{
-		_rtw_memset(&pbss_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
-		_rtw_memcpy(pbss_network->Ssid.Ssid, (p + 2), ie_len);
-		pbss_network->Ssid.SsidLength = ie_len;
-		#ifdef CONFIG_P2P
-		_rtw_memcpy(padapter->wdinfo.p2p_group_ssid, pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength);
-		padapter->wdinfo.p2p_group_ssid_len = pbss_network->Ssid.SsidLength;
-		#endif
-	}
-
-	//chnnel
-	channel = 0;
-	pbss_network->Configuration.Length = 0;
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _DSSET_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if(p && ie_len>0)
-		channel = *(p + 2);
-
-	pbss_network->Configuration.DSConfig = channel;
-
-	
-	_rtw_memset(supportRate, 0, NDIS_802_11_LENGTH_RATES_EX);
-	// get supported rates
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));	
-	if (p !=  NULL) 
-	{
-		_rtw_memcpy(supportRate, p+2, ie_len);	
-		supportRateNum = ie_len;
-	}
-	
-	//get ext_supported rates
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, &ie_len, pbss_network->IELength - _BEACON_IE_OFFSET_);	
-	if (p !=  NULL)
-	{
-		_rtw_memcpy(supportRate+supportRateNum, p+2, ie_len);
-		supportRateNum += ie_len;
-	
-	}
-
-	network_type = rtw_check_network_type(supportRate, supportRateNum, channel);
-
-	rtw_set_supported_rate(pbss_network->SupportedRates, network_type);
-
-
-	//parsing ERP_IE
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _ERPINFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if(p && ie_len>0)
-	{
-		ERP_IE_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)p);
-	}
-
-	//update privacy/security
-	if (cap & 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 = _NO_PRIVACY_;
-	psecuritypriv->wpa2_pairwise_cipher = _NO_PRIVACY_;	
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));		
-	if(p && ie_len>0)
-	{
-		if(rtw_parse_wpa2_ie(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;
-#if 0
-			switch(group_cipher)
-			{
-				case WPA_CIPHER_NONE:				
-				psecuritypriv->wpa2_group_cipher = _NO_PRIVACY_;
-				break;
-				case WPA_CIPHER_WEP40:				
-				psecuritypriv->wpa2_group_cipher = _WEP40_;
-				break;
-				case WPA_CIPHER_TKIP:				
-				psecuritypriv->wpa2_group_cipher = _TKIP_;
-				break;
-				case WPA_CIPHER_CCMP:				
-				psecuritypriv->wpa2_group_cipher = _AES_;				
-				break;
-				case WPA_CIPHER_WEP104:					
-				psecuritypriv->wpa2_group_cipher = _WEP104_;
-				break;
-			}
-
-			switch(pairwise_cipher)
-			{
-				case WPA_CIPHER_NONE:			
-				psecuritypriv->wpa2_pairwise_cipher = _NO_PRIVACY_;
-				break;
-				case WPA_CIPHER_WEP40:			
-				psecuritypriv->wpa2_pairwise_cipher = _WEP40_;
-				break;
-				case WPA_CIPHER_TKIP:				
-				psecuritypriv->wpa2_pairwise_cipher = _TKIP_;
-				break;
-				case WPA_CIPHER_CCMP:			
-				psecuritypriv->wpa2_pairwise_cipher = _AES_;
-				break;
-				case WPA_CIPHER_WEP104:					
-				psecuritypriv->wpa2_pairwise_cipher = _WEP104_;
-				break;
-			}
-#endif			
-		}
-		
-	}
-
-	//wpa
-	ie_len = 0;
-	group_cipher = 0; pairwise_cipher = 0;
-	psecuritypriv->wpa_group_cipher = _NO_PRIVACY_;
-	psecuritypriv->wpa_pairwise_cipher = _NO_PRIVACY_;	
-	for (p = ie + _BEACON_IE_OFFSET_; ;p += (ie_len + 2))
-	{
-		p = rtw_get_ie(p, _SSN_IE_1_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));		
-		if ((p) && (_rtw_memcmp(p+2, OUI1, 4)))
-		{
-			if(rtw_parse_wpa_ie(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(0);
-
-				psecuritypriv->wpa_group_cipher = group_cipher;
-				psecuritypriv->wpa_pairwise_cipher = pairwise_cipher;
-
-#if 0
-				switch(group_cipher)
-				{
-					case WPA_CIPHER_NONE:					
-					psecuritypriv->wpa_group_cipher = _NO_PRIVACY_;
-					break;
-					case WPA_CIPHER_WEP40:					
-					psecuritypriv->wpa_group_cipher = _WEP40_;
-					break;
-					case WPA_CIPHER_TKIP:					
-					psecuritypriv->wpa_group_cipher = _TKIP_;
-					break;
-					case WPA_CIPHER_CCMP:					
-					psecuritypriv->wpa_group_cipher = _AES_;				
-					break;
-					case WPA_CIPHER_WEP104:					
-					psecuritypriv->wpa_group_cipher = _WEP104_;
-					break;
-				}
-
-				switch(pairwise_cipher)
-				{
-					case WPA_CIPHER_NONE:					
-					psecuritypriv->wpa_pairwise_cipher = _NO_PRIVACY_;
-					break;
-					case WPA_CIPHER_WEP40:					
-					psecuritypriv->wpa_pairwise_cipher = _WEP40_;
-					break;
-					case WPA_CIPHER_TKIP:					
-					psecuritypriv->wpa_pairwise_cipher = _TKIP_;
-					break;
-					case WPA_CIPHER_CCMP:					
-					psecuritypriv->wpa_pairwise_cipher = _AES_;
-					break;
-					case WPA_CIPHER_WEP104:					
-					psecuritypriv->wpa_pairwise_cipher = _WEP104_;
-					break;
-				}
-#endif				
-			}
-
-			break;
-			
-		}
-			
-		if ((p == NULL) || (ie_len == 0))
-		{
-				break;
-		}
-		
-	}
-
-	//wmm
-	ie_len = 0;
-	pmlmepriv->qospriv.qos_option = 0;
-	if(pregistrypriv->wmm_enable)
-	{
-		for (p = ie + _BEACON_IE_OFFSET_; ;p += (ie_len + 2))
-		{			
-			p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));	
-			if((p) && _rtw_memcmp(p+2, WMM_PARA_IE, 6)) 
-			{
-				pmlmepriv->qospriv.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;
-			}			
-		}		
-	}
-#ifdef CONFIG_80211N_HT
-	//parsing HT_CAP_IE
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if(p && ie_len>0)
-	{
-		u8 rf_type=0;
-		HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor=MAX_AMPDU_FACTOR_64K;
-		struct rtw_ieee80211_ht_cap *pht_cap = (struct rtw_ieee80211_ht_cap *)(p+2);
-
-		if (0) {
-			DBG_871X(FUNC_ADPT_FMT" HT_CAP_IE from upper layer:\n", FUNC_ADPT_ARG(padapter));
-			dump_ht_cap_ie_content(RTW_DBGDUMP, p+2, ie_len);
-		}
-
-		pHT_caps_ie=p;
-
-		ht_cap = _TRUE;
-		network_type |= WIRELESS_11_24N;
-
-		rtw_ht_use_default_setting(padapter);
-
-		/* Update HT Capabilities Info field */
-		if (pmlmepriv->htpriv.sgi_20m == _FALSE)
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_20);
-
-		if (pmlmepriv->htpriv.sgi_40m == _FALSE)
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_40);
-
-		if (!TEST_FLAG(pmlmepriv->htpriv.ldpc_cap, LDPC_HT_ENABLE_RX))
-		{
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_LDPC_CODING);
-		}
-
-		if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
-		{
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_TX_STBC);
-		}		
-
-		if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_RX))
-		{
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_RX_STBC_3R);
-		}
-
-		/* Update A-MPDU Parameters field */
-		pht_cap->ampdu_params_info &= ~(IEEE80211_HT_CAP_AMPDU_FACTOR|IEEE80211_HT_CAP_AMPDU_DENSITY);
-
-		if((psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_CCMP) ||
-			(psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_CCMP))
-		{
-			pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY&(0x07<<2));
-		}	
-		else
-		{
-			pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY&0x00);	
-		}	
-
-		rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
-		pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_FACTOR & max_rx_ampdu_factor); //set  Max Rx AMPDU size  to 64K
-		
-		_rtw_memcpy(&(pmlmeinfo->HT_caps), pht_cap, sizeof(struct HT_caps_element));
-
-		/* Update Supported MCS Set field */
-		{
-			int i;
-
-			rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-
-			/* RX MCS Bitmask */
-			switch(rf_type)
-			{
-				case RF_1T1R:
-				case RF_1T2R: //?
-					set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_1R);
-					break;
-				case RF_2T2R:
-					set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_2R);
-					break;
-				case RF_3T3R:
-					set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_3R);
-					break;
-				default:
-					DBG_871X("[warning] rf_type %d is not expected\n", rf_type);
-			}
-			for (i = 0; i < 10; i++)
-				*(HT_CAP_ELE_RX_MCS_MAP(pht_cap)+i) &= padapter->mlmeextpriv.default_supported_mcs_set[i];
-		}
-
-#ifdef CONFIG_BEAMFORMING
-		// Use registry value to enable HT Beamforming.
-		// ToDo: use configure file to set these capability.
-		pht_cap->tx_BF_cap_info = 0;
-
-		// HT Beamformer
-		if(TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE))
-		{
-			// Transmit NDP Capable
-			SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(pht_cap, 1);
-			// Explicit Compressed Steering Capable
-			SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pht_cap, 1);
-			// Compressed Steering Number Antennas
-			SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, 1);
-			rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
-			SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pht_cap, rf_num);		
-		}
-
-		// HT Beamformee
-		if(TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
-		{
-			// Receive NDP Capable
-			SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(pht_cap, 1);
-			// Explicit Compressed Beamforming Feedback Capable
-			SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pht_cap, 2);
-			rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
-			SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, rf_num);
-		}
-#endif //CONFIG_BEAMFORMING
-
-		_rtw_memcpy(&pmlmepriv->htpriv.ht_cap, p+2, ie_len);
-
-		if (0) {
-			DBG_871X(FUNC_ADPT_FMT" HT_CAP_IE driver masked:\n", FUNC_ADPT_ARG(padapter));
-			dump_ht_cap_ie_content(RTW_DBGDUMP, p+2, ie_len);
-		}
-	}
-
-	//parsing HT_INFO_IE
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if(p && ie_len>0)
-	{
-		pHT_info_ie=p;
-	}
-#endif //CONFIG_80211N_HT
-	switch(network_type)
-	{
-		case WIRELESS_11B:
-			pbss_network->NetworkTypeInUse = Ndis802_11DS;
-			break;	
-		case WIRELESS_11G:
-		case WIRELESS_11BG:
-             case WIRELESS_11G_24N:
-		case WIRELESS_11BG_24N:
-			pbss_network->NetworkTypeInUse = Ndis802_11OFDM24;
-			break;
-		case WIRELESS_11A:
-			pbss_network->NetworkTypeInUse = Ndis802_11OFDM5;
-			break;
-		default :
-			pbss_network->NetworkTypeInUse = Ndis802_11OFDM24;
-			break;
-	}
-	
-	pmlmepriv->cur_network.network_type = network_type;
-
-#ifdef CONFIG_80211N_HT
-	pmlmepriv->htpriv.ht_option = _FALSE;
-
-	if( (psecuritypriv->wpa2_pairwise_cipher&WPA_CIPHER_TKIP) ||
-		      (psecuritypriv->wpa_pairwise_cipher&WPA_CIPHER_TKIP))
-	{	
-		//todo:
-		//ht_cap = _FALSE;
-	}
-		      
-	//ht_cap	
-	if(pregistrypriv->ht_enable && ht_cap==_TRUE)
-	{		
-		pmlmepriv->htpriv.ht_option = _TRUE;
-		pmlmepriv->qospriv.qos_option = 1;
-
-		pmlmepriv->htpriv.ampdu_enable = pregistrypriv->ampdu_enable ? _TRUE : _FALSE;
-
-		HT_caps_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)pHT_caps_ie);
-		
-		HT_info_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)pHT_info_ie);
-	}
-#endif
-
-#ifdef CONFIG_80211AC_VHT
-
-	//Parsing VHT CAP IE
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if(p && ie_len>0)
-	{	
-		vht_cap = _TRUE; 
-	}
-	//Parsing VHT OPERATION IE
-	
-
-	pmlmepriv->vhtpriv.vht_option = _FALSE;
-	// if channel in 5G band, then add vht ie .
-	if ((pbss_network->Configuration.DSConfig > 14)
-		&& (pmlmepriv->htpriv.ht_option == _TRUE)
-		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
-		&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-		&& (!pmlmepriv->country_ent || COUNTRY_CHPLAN_EN_11AC(pmlmepriv->country_ent))
-	) {
-		if (vht_cap == _TRUE)
-			pmlmepriv->vhtpriv.vht_option = _TRUE;
-		else if (REGSTY_IS_11AC_AUTO(pregistrypriv)) {
-			u8	cap_len, operation_len;
-
-			rtw_vht_use_default_setting(padapter);
-
-			{
-				/* VHT Operation mode notifiy bit in Extended IE (127) */
-				uint len = 0;
-				
-				SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(pmlmepriv->ext_capab_ie_data, 1);
-				pmlmepriv->ext_capab_ie_len = 10;
-				rtw_set_ie(pbss_network->IEs + pbss_network->IELength, EID_EXTCapability, 8, pmlmepriv->ext_capab_ie_data, &len);
-				pbss_network->IELength += pmlmepriv->ext_capab_ie_len;
-			}
-			
-			// VHT Capabilities element
-			cap_len = rtw_build_vht_cap_ie(padapter, pbss_network->IEs + pbss_network->IELength);
-			pbss_network->IELength += cap_len;
-
-			// VHT Operation element
-			operation_len = rtw_build_vht_operation_ie(padapter, pbss_network->IEs + pbss_network->IELength, pbss_network->Configuration.DSConfig);
-			pbss_network->IELength += operation_len;
-
-			pmlmepriv->vhtpriv.vht_option = _TRUE;
-		}		
-	}
-#endif //CONFIG_80211AC_VHT
-
-	pbss_network->Length = get_WLAN_BSSID_EX_sz((WLAN_BSSID_EX  *)pbss_network);
-
-	rtw_ies_get_chbw(pbss_network->IEs + _BEACON_IE_OFFSET_, pbss_network->IELength - _BEACON_IE_OFFSET_
-		, &pmlmepriv->ori_ch, &pmlmepriv->ori_bw, &pmlmepriv->ori_offset);
-	rtw_warn_on(pmlmepriv->ori_ch == 0);
-
-{
-	/* alloc sta_info for ap itself */
-
-	struct sta_info *sta;
-
-	sta = rtw_get_stainfo(&padapter->stapriv, pbss_network->MacAddress);
-	if (!sta) {
-		sta = rtw_alloc_stainfo(&padapter->stapriv, pbss_network->MacAddress);
-		if (sta == NULL) 
-			return _FAIL;
-	}
-}
-
-	rtw_startbss_cmd(padapter, RTW_CMDF_WAIT_ACK);
-
-	rtw_indicate_connect( padapter);
-
-	pmlmepriv->cur_network.join_res = _TRUE;//for check if already set beacon
-		
-	//update bc/mc sta_info
-	//update_bmc_sta(padapter);
-
-	return ret;
-
-}
-
-void rtw_set_macaddr_acl(_adapter *padapter, int mode)
-{
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-
-	DBG_871X("%s, mode=%d\n", __func__, mode);
-
-	pacl_list->mode = mode;
-}
-
-int rtw_acl_add_sta(_adapter *padapter, u8 *addr)
-{
-	_irqL irqL;
-	_list	*plist, *phead;
-	u8 added = _FALSE;
-	int i, ret=0;
-	struct rtw_wlan_acl_node *paclnode;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-	_queue	*pacl_node_q =&pacl_list->acl_node_q;	
-
-	DBG_871X("%s(acl_num=%d)=" MAC_FMT "\n", __func__, pacl_list->num, MAC_ARG(addr));	
-
-	if((NUM_ACL-1) < pacl_list->num)
-		return (-1);	
-
-
-	_enter_critical_bh(&(pacl_node_q->lock), &irqL);
-
-	phead = get_list_head(pacl_node_q);
-	plist = get_next(phead);
-		
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-	{
-		paclnode = LIST_CONTAINOR(plist, struct rtw_wlan_acl_node, list);
-		plist = get_next(plist);
-
-		if(_rtw_memcmp(paclnode->addr, addr, ETH_ALEN))
-		{
-			if(paclnode->valid == _TRUE)
-			{
-				added = _TRUE;
-				DBG_871X("%s, sta has been added\n", __func__);
-				break;
-			}
-		}		
-	}
-	
-	_exit_critical_bh(&(pacl_node_q->lock), &irqL);
-
-
-	if(added == _TRUE)
-		return ret;
-	
-
-	_enter_critical_bh(&(pacl_node_q->lock), &irqL);
-
-	for(i=0; i< NUM_ACL; i++)
-	{
-		paclnode = &pacl_list->aclnode[i];
-
-		if(paclnode->valid == _FALSE)
-		{
-			_rtw_init_listhead(&paclnode->list);
-	
-			_rtw_memcpy(paclnode->addr, addr, ETH_ALEN);
-		
-			paclnode->valid = _TRUE;
-
-			rtw_list_insert_tail(&paclnode->list, get_list_head(pacl_node_q));
-	
-			pacl_list->num++;
-
-			break;
-		}
-	}
-
-	DBG_871X("%s, acl_num=%d\n", __func__, pacl_list->num);
-	
-	_exit_critical_bh(&(pacl_node_q->lock), &irqL);
-
-	return ret;
-}
-
-int rtw_acl_remove_sta(_adapter *padapter, u8 *addr)
-{
-	_irqL irqL;
-	_list	*plist, *phead;
-	int i, ret=0;
-	struct rtw_wlan_acl_node *paclnode;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-	_queue	*pacl_node_q =&pacl_list->acl_node_q;
-	u8 baddr[ETH_ALEN] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };	//Baddr is used for clearing acl_list
-
-	DBG_871X("%s(acl_num=%d)=" MAC_FMT "\n", __func__, pacl_list->num, MAC_ARG(addr));	
-
-	_enter_critical_bh(&(pacl_node_q->lock), &irqL);
-
-	phead = get_list_head(pacl_node_q);
-	plist = get_next(phead);
-		
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-	{
-		paclnode = LIST_CONTAINOR(plist, struct rtw_wlan_acl_node, list);
-		plist = get_next(plist);
-
-		if(_rtw_memcmp(paclnode->addr, addr, ETH_ALEN) || _rtw_memcmp(baddr, addr, ETH_ALEN))
-		{
-			if(paclnode->valid == _TRUE)
-			{
-				paclnode->valid = _FALSE;
-
-				rtw_list_delete(&paclnode->list);
-				
-				pacl_list->num--;
-			}
-		}		
-	}
-	
-	_exit_critical_bh(&(pacl_node_q->lock), &irqL);
-
-	DBG_871X("%s, acl_num=%d\n", __func__, pacl_list->num);
-	
-	return ret;
-
-}
-
-u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta)
-{
-	struct cmd_obj*			ph2c;
-	struct set_stakey_parm	*psetstakey_para;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;	
-	u8	res=_SUCCESS;
-
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if ( ph2c == NULL){
-		res= _FAIL;
-		goto exit;
-	}
-
-	psetstakey_para = (struct set_stakey_parm*)rtw_zmalloc(sizeof(struct set_stakey_parm));
-	if(psetstakey_para==NULL){
-		rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
-		res=_FAIL;
-		goto exit;
-	}
-
-	init_h2fwcmd_w_parm_no_rsp(ph2c, psetstakey_para, _SetStaKey_CMD_);
-
-
-	psetstakey_para->algorithm = (u8)psta->dot118021XPrivacy;
-
-	_rtw_memcpy(psetstakey_para->addr, psta->hwaddr, ETH_ALEN);	
-	
-	_rtw_memcpy(psetstakey_para->key, &psta->dot118021x_UncstKey, 16);
-
-	
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
-
-exit:
-
-	return res;
-	
-}
-
-static int rtw_ap_set_key(_adapter *padapter, u8 *key, u8 alg, int keyid, u8 set_tx)
-{
-	u8 keylen;
-	struct cmd_obj* pcmd;
-	struct setkey_parm *psetkeyparm;
-	struct cmd_priv	*pcmdpriv=&(padapter->cmdpriv);	
-	int res=_SUCCESS;
-
-	//DBG_871X("%s\n", __FUNCTION__);
-	
-	pcmd = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(pcmd==NULL){
-		res= _FAIL;
-		goto exit;
-	}
-	psetkeyparm=(struct setkey_parm*)rtw_zmalloc(sizeof(struct setkey_parm));
-	if(psetkeyparm==NULL){
-		rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
-		res= _FAIL;
-		goto exit;
-	}
-
-	_rtw_memset(psetkeyparm, 0, sizeof(struct setkey_parm));
-		
-	psetkeyparm->keyid=(u8)keyid;
-	if (is_wep_enc(alg))
-		padapter->securitypriv.key_mask |= BIT(psetkeyparm->keyid);
-
-	psetkeyparm->algorithm = alg;
-
-	psetkeyparm->set_tx = set_tx;
-
-	switch(alg)
-	{
-		case _WEP40_:					
-			keylen = 5;
-			break;
-		case _WEP104_:
-			keylen = 13;			
-			break;
-		case _TKIP_:
-		case _TKIP_WTMIC_:
-		case _AES_:
-		default:
-			keylen = 16;
-	}
-
-	_rtw_memcpy(&(psetkeyparm->key[0]), key, keylen);
-	
-	pcmd->cmdcode = _SetKey_CMD_;
-	pcmd->parmbuf = (u8 *)psetkeyparm;   
-	pcmd->cmdsz =  (sizeof(struct setkey_parm));  
-	pcmd->rsp = NULL;
-	pcmd->rspsz = 0;
-
-
-	_rtw_init_listhead(&pcmd->list);
-
-	res = rtw_enqueue_cmd(pcmdpriv, pcmd);
-
-exit:
-
-	return res;
-}
-
-int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid)
-{
-	DBG_871X("%s\n", __FUNCTION__);
-
-	return rtw_ap_set_key(padapter, key, alg, keyid, 1);
-}
-
-int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx)
-{
-	u8 alg;
-
-	switch(keylen)
-	{
-		case 5:
-			alg =_WEP40_;			
-			break;
-		case 13:
-			alg =_WEP104_;			
-			break;
-		default:
-			alg =_NO_PRIVACY_;			
-	}
-
-	DBG_871X("%s\n", __FUNCTION__);
-
-	return rtw_ap_set_key(padapter, key, alg, keyid, set_tx);
-}
-
-u8 rtw_ap_bmc_frames_hdl(_adapter *padapter)
-{
-#define HIQ_XMIT_COUNTS (6)
-	_irqL irqL;
-	struct sta_info *psta_bmc;
-	_list	*xmitframe_plist, *xmitframe_phead;
-	struct xmit_frame *pxmitframe = NULL;
-	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-	struct sta_priv  *pstapriv = &padapter->stapriv;
-	bool update_tim = _FALSE;
-
-
-	if (padapter->registrypriv.wifi_spec != 1)
-		return H2C_SUCCESS;
-
-	
-	psta_bmc = rtw_get_bcmc_stainfo(padapter);
-	if (!psta_bmc)
-		return H2C_SUCCESS;
-
-
-	_enter_critical_bh(&pxmitpriv->lock, &irqL);
-
-	if ((pstapriv->tim_bitmap & BIT(0)) && (psta_bmc->sleepq_len > 0)) {
-		int tx_counts = 0;
-		
-		_update_beacon(padapter, _TIM_IE_, NULL, _FALSE, "update TIM with TIB=1");
-
-		DBG_871X("sleepq_len of bmc_sta = %d\n", psta_bmc->sleepq_len);
-
-		xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
-		xmitframe_plist = get_next(xmitframe_phead);
-
-		while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
-			pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
-
-			xmitframe_plist = get_next(xmitframe_plist);
-
-			rtw_list_delete(&pxmitframe->list);
-
-			psta_bmc->sleepq_len--;
-			tx_counts++;
-			
-			if (psta_bmc->sleepq_len > 0)
-				pxmitframe->attrib.mdata = 1;
-			else
-				pxmitframe->attrib.mdata = 0;
-
-			if (tx_counts == HIQ_XMIT_COUNTS)
-				pxmitframe->attrib.mdata = 0;
-			
-			pxmitframe->attrib.triggered = 1;
-
-			if (xmitframe_hiq_filter(pxmitframe) == _TRUE)
-				pxmitframe->attrib.qsel = QSLT_HIGH;/*HIQ*/
-
-			rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
-
-			if (tx_counts == HIQ_XMIT_COUNTS)
-				break;
-			
-		}
-
-	} else {
-		if (psta_bmc->sleepq_len == 0) {
-			
-			/*DBG_871X("sleepq_len of bmc_sta = %d\n", psta_bmc->sleepq_len);*/
-			
-			if (pstapriv->tim_bitmap & BIT(0))
-				update_tim = _TRUE;
-
-			pstapriv->tim_bitmap &= ~BIT(0);
-			pstapriv->sta_dz_bitmap &= ~BIT(0);
-
-			if (update_tim == _TRUE) {
-				DBG_871X("clear TIB\n");
-				_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "bmc sleepq and HIQ empty");
-			}			
-		}
-	}
-
-	_exit_critical_bh(&pxmitpriv->lock, &irqL);
-
-/*
-	//HIQ Check
-	rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
-
-	while (_FALSE == empty && rtw_get_passing_time_ms(start) < 3000)
-	{
-		rtw_msleep_os(100);
-		rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
-	}
-
-
-	printk("check if hiq empty=%d\n", empty);
-*/
-
-	return H2C_SUCCESS;
-}
-
-#ifdef CONFIG_NATIVEAP_MLME
-
-static void associated_stainfo_update(_adapter *padapter, struct sta_info *psta, u32 sta_info_type)
-{
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-
-	DBG_871X("%s: "MAC_FMT", updated_type=0x%x\n", __func__, MAC_ARG(psta->hwaddr), sta_info_type);
-	
-	if (sta_info_type & STA_INFO_UPDATE_BW) {
-
-		if ((psta->flags & WLAN_STA_HT) && !psta->ht_20mhz_set) {
-			if (pmlmepriv->sw_to_20mhz) {
-				psta->bw_mode = CHANNEL_WIDTH_20;
-				/*psta->htpriv.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;*/
-				psta->htpriv.sgi_40m = _FALSE;				
-			} else {
-				/*TODO: Switch back to 40MHZ?80MHZ*/
-			}
-		}		
-	}
-
-/*
-	if (sta_info_type & STA_INFO_UPDATE_RATE) {
-		
-	}
-*/	
-
-	if (sta_info_type & STA_INFO_UPDATE_PROTECTION_MODE)
-		VCS_update(padapter, psta);
-	
-/*
-	if (sta_info_type & STA_INFO_UPDATE_CAP) {
-		
-	}
-
-	if (sta_info_type & STA_INFO_UPDATE_HT_CAP) {
-		
-	}
-
-	if (sta_info_type & STA_INFO_UPDATE_VHT_CAP) {
-		
-	}	
-*/
-
-}
-
-static void update_bcn_ext_capab_ie(_adapter *padapter)
-{
-	sint ie_len = 0;
-	unsigned char	*pbuf;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
-	u8 *ie = pnetwork->IEs; 
-	u8 null_extcap_data[8] = {0};
-	
-	pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_CAP_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-	if (pbuf && ie_len > 0)
-		rtw_remove_bcn_ie(padapter, pnetwork, _EXT_CAP_IE_);
-
-	if ((pmlmepriv->ext_capab_ie_len > 0) && 
-		(_rtw_memcmp(pmlmepriv->ext_capab_ie_data, null_extcap_data, sizeof(null_extcap_data)) == _FALSE))
-		rtw_add_bcn_ie(padapter, pnetwork, _EXT_CAP_IE_, pmlmepriv->ext_capab_ie_data, pmlmepriv->ext_capab_ie_len);
-	
-}
-
-static void update_bcn_fixed_ie(_adapter *padapter)
-{
-	DBG_871X("%s\n", __FUNCTION__);
-
-}
-
-static void update_bcn_erpinfo_ie(_adapter *padapter)
-{
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
-	unsigned char *p, *ie = pnetwork->IEs;
-	u32 len = 0;
-
-	DBG_871X("%s, ERP_enable=%d\n", __FUNCTION__, pmlmeinfo->ERP_enable);
-
-	if(!pmlmeinfo->ERP_enable)
-		return;
-
-	//parsing ERP_IE
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _ERPINFO_IE_, &len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-	if(p && len>0)
-	{
-		PNDIS_802_11_VARIABLE_IEs pIE = (PNDIS_802_11_VARIABLE_IEs)p;
-
-		if (pmlmepriv->num_sta_non_erp == 1)
-			pIE->data[0] |= RTW_ERP_INFO_NON_ERP_PRESENT|RTW_ERP_INFO_USE_PROTECTION;
-		else
-			pIE->data[0] &= ~(RTW_ERP_INFO_NON_ERP_PRESENT|RTW_ERP_INFO_USE_PROTECTION);
-
-		if(pmlmepriv->num_sta_no_short_preamble > 0)
-			pIE->data[0] |= RTW_ERP_INFO_BARKER_PREAMBLE_MODE;
-		else
-			pIE->data[0] &= ~(RTW_ERP_INFO_BARKER_PREAMBLE_MODE);
-	
-		ERP_IE_handler(padapter, pIE);
-	}
-	
-}
-
-static void update_bcn_htcap_ie(_adapter *padapter)
-{
-	DBG_871X("%s\n", __FUNCTION__);
-
-}
-
-static void update_bcn_htinfo_ie(_adapter *padapter)
-{	
-	/*
-	u8 beacon_updated = _FALSE;
-	u32 sta_info_update_type = STA_INFO_UPDATE_NONE;	
-	*/
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
-	unsigned char *p, *ie = pnetwork->IEs;
-	u32 len = 0;	
-
-	if (pmlmepriv->htpriv.ht_option == _FALSE) 
-		return;
-
-	if (pmlmeinfo->HT_info_enable != 1)
-		return;
-
-
-	DBG_871X("%s current operation mode=0x%X\n",
-		   __FUNCTION__, pmlmepriv->ht_op_mode);
-
-	DBG_871X("num_sta_40mhz_intolerant(%d), 20mhz_width_req(%d), intolerant_ch_rpt(%d), olbc(%d)\n", 
-					pmlmepriv->num_sta_40mhz_intolerant, pmlmepriv->ht_20mhz_width_req, pmlmepriv->ht_intolerant_ch_reported, pmlmepriv->olbc);
-
-	/*parsing HT_INFO_IE, currently only update ht_op_mode - pht_info->infos[1] & pht_info->infos[2] for wifi logo test*/
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-	if (p && len > 0) {
-		struct HT_info_element *pht_info = NULL;
-		
-		pht_info = (struct HT_info_element *)(p + 2);		
-
-		/* for STA Channel Width/Secondary Channel Offset*/
-		if ((pmlmepriv->sw_to_20mhz == 0) && (pmlmeext->cur_channel <= 14)) {
-			if ((pmlmepriv->num_sta_40mhz_intolerant > 0) || (pmlmepriv->ht_20mhz_width_req == _TRUE) 
-				|| (pmlmepriv->ht_intolerant_ch_reported == _TRUE) || (pmlmepriv->olbc == _TRUE)) {
-				SET_HT_OP_ELE_2ND_CHL_OFFSET(pht_info, 0);
-				SET_HT_OP_ELE_STA_CHL_WIDTH(pht_info, 0);
-
-				pmlmepriv->sw_to_20mhz = 1;
-				/*
-				sta_info_update_type |= STA_INFO_UPDATE_BW;
-				beacon_updated = _TRUE;
-				*/
-	
-				DBG_871X("%s:switching to 20Mhz\n", __FUNCTION__);	
-
-				/*TODO : cur_bwmode/cur_ch_offset switches to 20Mhz*/
-			}
-		} else {
-
-			if ((pmlmepriv->num_sta_40mhz_intolerant == 0) && (pmlmepriv->ht_20mhz_width_req == _FALSE) 
-				&& (pmlmepriv->ht_intolerant_ch_reported == _FALSE) && (pmlmepriv->olbc == _FALSE)) {
-
-				if (pmlmeext->cur_bwmode >= CHANNEL_WIDTH_40) {
-					
-					SET_HT_OP_ELE_STA_CHL_WIDTH(pht_info, 1);
-
-					SET_HT_OP_ELE_2ND_CHL_OFFSET(pht_info, 
-					(pmlmeext->cur_ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER) ? 
-						HT_INFO_HT_PARAM_SECONDARY_CHNL_ABOVE : HT_INFO_HT_PARAM_SECONDARY_CHNL_BELOW);
-					
-					pmlmepriv->sw_to_20mhz = 0;
-					/*
-					sta_info_update_type |= STA_INFO_UPDATE_BW;
-					beacon_updated = _TRUE;
-					*/
-					
-					DBG_871X("%s:switching back to 40Mhz\n", __FUNCTION__);	
-				}
-			}
-		}
-
-		/* to update  ht_op_mode*/
-		*(u16 *)(pht_info->infos + 1) = cpu_to_le16(pmlmepriv->ht_op_mode);
-		
-	}	
-
-	/*associated_clients_update(padapter, beacon_updated, sta_info_update_type);*/
-
-}
-
-static void update_bcn_rsn_ie(_adapter *padapter)
-{
-	DBG_871X("%s\n", __FUNCTION__);
-
-}
-
-static void update_bcn_wpa_ie(_adapter *padapter)
-{
-	DBG_871X("%s\n", __FUNCTION__);
-
-}
-
-static void update_bcn_wmm_ie(_adapter *padapter)
-{
-	DBG_871X("%s\n", __FUNCTION__);
-	
-}
-
-static void update_bcn_wps_ie(_adapter *padapter)
-{
-	u8 *pwps_ie=NULL, *pwps_ie_src, *premainder_ie, *pbackup_remainder_ie=NULL;
-	uint wps_ielen=0, wps_offset, remainder_ielen;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
-	unsigned char *ie = pnetwork->IEs;
-	u32 ielen = pnetwork->IELength;
-
-
-	DBG_871X("%s\n", __FUNCTION__);
-
-	pwps_ie = rtw_get_wps_ie(ie+_FIXED_IE_LENGTH_, ielen-_FIXED_IE_LENGTH_, NULL, &wps_ielen);
-	
-	if(pwps_ie==NULL || wps_ielen==0)
-		return;
-
-	pwps_ie_src = pmlmepriv->wps_beacon_ie;
-	if(pwps_ie_src == NULL)
-		return;
-
-	wps_offset = (uint)(pwps_ie-ie);
-
-	premainder_ie = pwps_ie + wps_ielen;
-
-	remainder_ielen = ielen - wps_offset - wps_ielen;
-
-	if(remainder_ielen>0)
-	{
-		pbackup_remainder_ie = rtw_malloc(remainder_ielen);
-		if(pbackup_remainder_ie)
-			_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
-	}
-
-	wps_ielen = (uint)pwps_ie_src[1];//to get ie data len
-	if((wps_offset+wps_ielen+2+remainder_ielen)<=MAX_IE_SZ)
-	{
-		_rtw_memcpy(pwps_ie, pwps_ie_src, wps_ielen+2);
-		pwps_ie += (wps_ielen+2);
-
-		if(pbackup_remainder_ie)
-			_rtw_memcpy(pwps_ie, pbackup_remainder_ie, remainder_ielen);
-
-		//update IELength
-		pnetwork->IELength = wps_offset + (wps_ielen+2) + remainder_ielen;
-	}
-
-	if(pbackup_remainder_ie)
-		rtw_mfree(pbackup_remainder_ie, remainder_ielen);
-	
-	// deal with the case without set_tx_beacon_cmd() in update_beacon() 
-#if defined( CONFIG_INTERRUPT_BASED_TXBCN ) || defined( CONFIG_PCI_HCI )
-	if( (pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
-		u8 sr = 0;
-		rtw_get_wps_attr_content(pwps_ie_src,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8*)(&sr), NULL);
-	
-		if( sr ) {
-			set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
-			DBG_871X("%s, set WIFI_UNDER_WPS\n", __func__);
-		}
-	}
-#endif
-}
-
-static void update_bcn_p2p_ie(_adapter *padapter)
-{
-
-}
-
-static void update_bcn_vendor_spec_ie(_adapter *padapter, u8*oui)
-{
-	DBG_871X("%s\n", __FUNCTION__);
-
-	if(_rtw_memcmp(RTW_WPA_OUI, oui, 4))
-	{
-		update_bcn_wpa_ie(padapter);
-	}
-	else if(_rtw_memcmp(WMM_OUI, oui, 4))
-	{
-		update_bcn_wmm_ie(padapter);
-	}
-	else if(_rtw_memcmp(WPS_OUI, oui, 4))
-	{
-		update_bcn_wps_ie(padapter);
-	}
-	else if(_rtw_memcmp(P2P_OUI, oui, 4))
-	{
-		update_bcn_p2p_ie(padapter);
-	}
-	else
-	{
-		DBG_871X("unknown OUI type!\n");
- 	}
-	
-	
-}
-
-void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *tag)
-{
-	_irqL irqL;
-	struct mlme_priv *pmlmepriv;
-	struct mlme_ext_priv	*pmlmeext;
-	//struct mlme_ext_info	*pmlmeinfo;
-	
-	//DBG_871X("%s\n", __FUNCTION__);
-
-	if(!padapter)
-		return;
-
-	pmlmepriv = &(padapter->mlmepriv);
-	pmlmeext = &(padapter->mlmeextpriv);
-	//pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	if(_FALSE == pmlmeext->bstart_bss)
-		return;
-
-	_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
-
-	switch(ie_id)
-	{
-		case 0xFF:
-
-			update_bcn_fixed_ie(padapter);//8: TimeStamp, 2: Beacon Interval 2:Capability
-			
-			break;
-	
-		case _TIM_IE_:
-			
-			update_BCNTIM(padapter);
-			
-			break;
-
-		case _ERPINFO_IE_:
-
-			update_bcn_erpinfo_ie(padapter);
-
-			break;
-
-		case _HT_CAPABILITY_IE_:
-
-			update_bcn_htcap_ie(padapter);
-			
-			break;
-
-		case _RSN_IE_2_:
-
-			update_bcn_rsn_ie(padapter);
-
-			break;
-			
-		case _HT_ADD_INFO_IE_:
-
-			update_bcn_htinfo_ie(padapter);
-			
-			break;
-	
-		case _EXT_CAP_IE_:
-
-			update_bcn_ext_capab_ie(padapter);
-
-			break;
-	
-		case _VENDOR_SPECIFIC_IE_:
-
-			update_bcn_vendor_spec_ie(padapter, oui);
-			
-			break;
-			
-		default:
-			break;
-	}
-
-	pmlmepriv->update_bcn = _TRUE;
-	
-	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);		
-	
-#ifndef CONFIG_INTERRUPT_BASED_TXBCN 
-#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	if(tx)
-	{
-		//send_beacon(padapter);//send_beacon must execute on TSR level
-		if (0)
-			DBG_871X(FUNC_ADPT_FMT" ie_id:%u - %s\n", FUNC_ADPT_ARG(padapter), ie_id, tag);
-		set_tx_beacon_cmd(padapter);
-	}
-#else
-	{	
-		//PCI will issue beacon when BCN interrupt occurs.		
-	}
-#endif
-#endif //!CONFIG_INTERRUPT_BASED_TXBCN
-	
-}
-
-#ifdef CONFIG_80211N_HT
-
-void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len)
-{
-	struct sta_info *psta;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 beacon_updated = _FALSE;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);	
-	uint frame_body_len = frame_len - sizeof(struct rtw_ieee80211_hdr_3addr);
-	u8 category, action;
-
-	psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));
-	if (psta == NULL) 
-		return;
-
-
-	category = frame_body[0];
-	action = frame_body[1];
-
-	if (frame_body_len > 0) {
-		if ((frame_body[2] == EID_BSSCoexistence) && (frame_body[3] > 0)) {			
-			u8 ie_data = frame_body[4];
-
-			if (ie_data & RTW_WLAN_20_40_BSS_COEX_40MHZ_INTOL) {
-				if (psta->ht_40mhz_intolerant == 0) {				
-					psta->ht_40mhz_intolerant = 1;
-					pmlmepriv->num_sta_40mhz_intolerant++;
-					beacon_updated = _TRUE;
-				}	
-			} else if (ie_data & RTW_WLAN_20_40_BSS_COEX_20MHZ_WIDTH_REQ)	{				
-				if (pmlmepriv->ht_20mhz_width_req == _FALSE) {				
-					pmlmepriv->ht_20mhz_width_req = _TRUE;			
-					beacon_updated = _TRUE;
-				}	
-			} else
-				beacon_updated = _FALSE;
-		}		
-	}
-
-	if (frame_body_len > 8) {
-		/* if EID_BSSIntolerantChlReport ie exists */
-		if ((frame_body[5] == EID_BSSIntolerantChlReport) && (frame_body[6] > 0)) {
-			/*todo:*/
-			if (pmlmepriv->ht_intolerant_ch_reported == _FALSE) {				
-				pmlmepriv->ht_intolerant_ch_reported = _TRUE;			
-				beacon_updated = _TRUE;
-			}
-		}			
-	}
-
-	if (beacon_updated) {
-		
-		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE);
-	
-		associated_stainfo_update(padapter, psta, STA_INFO_UPDATE_BW);
-	}
-
-	
-	
-}
-
-void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field)
-{
-	u8 e_field, m_field;
-	struct sta_info *psta;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-
-	psta = rtw_get_stainfo(pstapriv, ta);
-	if (psta == NULL) 
-		return;
-
-	e_field = (ctrl_field & BIT(0)) ? 1 : 0;
-	m_field = (ctrl_field & BIT(1)) ? 1 : 0;	
-
-	if (e_field) {
-
-		/* enable */
-		/* 0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
-		 
-		if (m_field) /*mode*/
-			psta->htpriv.smps_cap = 1;
-		else
-			psta->htpriv.smps_cap = 0;
-	} else {
-		/*disable*/
-		psta->htpriv.smps_cap = 3;
-	}
-
-	rtw_dm_ra_mask_wk_cmd(padapter, (u8 *)psta);
-
-}
-
-/*
-op_mode
-Set to 0 (HT pure) under the followign 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(_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 == _FALSE) 
-		return 0;
-	
-	/*if (!iface->conf->ieee80211n || iface->conf->ht_op_mode_fixed)
-		return 0;*/
-
-	DBG_871X("%s current operation mode=0x%X\n",
-		   __FUNCTION__, pmlmepriv->ht_op_mode);
-
-	if (!(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)
-	    && pmlmepriv->num_sta_ht_no_gf) {
-		pmlmepriv->ht_op_mode |=
-			HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT;
-		op_mode_changes++;
-	} else if ((pmlmepriv->ht_op_mode &
-		    HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT) &&
-		   pmlmepriv->num_sta_ht_no_gf == 0) {
-		pmlmepriv->ht_op_mode &=
-			~HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT;
-		op_mode_changes++;
-	}
-
-	if (!(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT) &&
-	    (pmlmepriv->num_sta_no_ht || pmlmepriv->olbc_ht)) {
-		pmlmepriv->ht_op_mode |= HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT;
-		op_mode_changes++;
-	} else if ((pmlmepriv->ht_op_mode &
-		    HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT) &&
-		   (pmlmepriv->num_sta_no_ht == 0 && !pmlmepriv->olbc_ht)) {
-		pmlmepriv->ht_op_mode &=
-			~HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT;
-		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.
-	 */
-	new_op_mode = 0;
-	if (pmlmepriv->num_sta_no_ht /*||
-	    (pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)*/)
-		new_op_mode = OP_MODE_MIXED;
-	else if ((phtpriv_ap->ht_cap.cap_info & IEEE80211_HT_CAP_SUP_WIDTH)
-		 && pmlmepriv->num_sta_ht_20mhz)
-		new_op_mode = OP_MODE_20MHZ_HT_STA_ASSOCED;
-	else if (pmlmepriv->olbc_ht)
-		new_op_mode = OP_MODE_MAY_BE_LEGACY_STAS;
-	else
-		new_op_mode = OP_MODE_PURE;
-
-	cur_op_mode = pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_OP_MODE_MASK;
-	if (cur_op_mode != new_op_mode) {
-		pmlmepriv->ht_op_mode &= ~HT_INFO_OPERATION_MODE_OP_MODE_MASK;
-		pmlmepriv->ht_op_mode |= new_op_mode;
-		op_mode_changes++;
-	}
-
-	DBG_871X("%s new operation mode=0x%X changes=%d\n",
-		   __FUNCTION__, pmlmepriv->ht_op_mode, op_mode_changes);
-
-	return op_mode_changes;
-	
-}
-
-#endif /* CONFIG_80211N_HT */
-
-void associated_clients_update(_adapter *padapter, u8 updated, u32 sta_info_type)
-{
-	//update associcated stations cap.
-	if(updated == _TRUE)
-	{
-		_irqL irqL;
-		_list	*phead, *plist;
-		struct sta_info *psta=NULL;	
-		struct sta_priv *pstapriv = &padapter->stapriv;
-			
-		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-		
-		phead = &pstapriv->asoc_list;
-		plist = get_next(phead);
-		
-		//check asoc_queue
-		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)	
-		{
-			psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		
-			plist = get_next(plist);
-
-			associated_stainfo_update(padapter, psta, sta_info_type);			
-		}
-
-		_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-	}		
-
-}
-
-/* called > TSR LEVEL for USB or SDIO Interface*/
-void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta)
-{
-	u8 beacon_updated = _FALSE;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
-
-	
-#if 0
-	if (!(psta->capability & WLAN_CAPABILITY_SHORT_PREAMBLE) &&
-	    !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))
-			ieee802_11_set_beacons(hapd->iface);
-	}
-#endif
-
-
-	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_beacon(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_beacon(padapter, 0xFF, NULL, _TRUE);
-			}	
-			
-		}
-	}
-
-#if 0
-	if (psta->flags & WLAN_STA_NONERP && !psta->nonerp_set) {
-		psta->nonerp_set = 1;
-		pmlmepriv->num_sta_non_erp++;
-		if (pmlmepriv->num_sta_non_erp == 1)
-			ieee802_11_set_beacons(hapd->iface);
-	}
-#endif
-
-	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_beacon(padapter, _ERPINFO_IE_, 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_beacon(padapter, _ERPINFO_IE_, NULL, _TRUE);
-			}	
-		}
-		
-	}
-
-
-#if 0
-	if (!(psta->capability & WLAN_CAPABILITY_SHORT_SLOT) &&
-	    !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))
-			ieee802_11_set_beacons(hapd->iface);
-	}
-#endif
-
-	if(!(psta->capability & WLAN_CAPABILITY_SHORT_SLOT))
-	{
-		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_beacon(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_beacon(padapter, 0xFF, NULL, _TRUE);
-			}			
-		}
-	}	
-	
-#ifdef CONFIG_80211N_HT
-
-	if (psta->flags & WLAN_STA_HT) 
-	{
-		u16 ht_capab = le16_to_cpu(psta->htpriv.ht_cap.cap_info);
-			
-		DBG_871X("HT: STA " MAC_FMT " HT Capabilities "
-			   "Info: 0x%04x\n", MAC_ARG(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_871X("%s STA " MAC_FMT " - no "
-				   "greenfield, num of non-gf stations %d\n",
-				   __FUNCTION__, MAC_ARG(psta->hwaddr),
-				   pmlmepriv->num_sta_ht_no_gf);
-		}
-		
-		if ((ht_capab & IEEE80211_HT_CAP_SUP_WIDTH) == 0) {
-			if (!psta->ht_20mhz_set) {
-				psta->ht_20mhz_set = 1;
-				pmlmepriv->num_sta_ht_20mhz++;
-			}
-			DBG_871X("%s STA " MAC_FMT " - 20 MHz HT, "
-				   "num of 20MHz HT STAs %d\n",
-				   __FUNCTION__, MAC_ARG(psta->hwaddr),
-				   pmlmepriv->num_sta_ht_20mhz);
-		}
-		
-
-		if (ht_capab & RTW_IEEE80211_HT_CAP_40MHZ_INTOLERANT) {
-
-			if (!psta->ht_40mhz_intolerant) {
-				psta->ht_40mhz_intolerant = 1;
-				pmlmepriv->num_sta_40mhz_intolerant++;
-				DBG_871X("%s STA " MAC_FMT " - HT_CAP_40MHZ_INTOLERANT is set\n" ,
-				   __FUNCTION__, MAC_ARG(psta->hwaddr));
-				beacon_updated = _TRUE;
-			}
-				
-/*
-			if (pmlmepriv->ht_40mhz_intolerant == _FALSE) {
-				
-				pmlmepriv->ht_40mhz_intolerant = _TRUE;				
-			
-				DBG_871X("%s STA " MAC_FMT " - HT_CAP_40MHZ_INTOLERANT is set\n" ,
-				   __FUNCTION__, MAC_ARG(psta->hwaddr));
-
-				beacon_updated = _TRUE;
-			}
-*/			
-
-			/*update ext_capab_ie_len & ext_capab_ie_data for beacon, probersp, assocrsp.*/
-			if (pmlmepriv->ext_capab_ie_len == 0)
-				pmlmepriv->ext_capab_ie_len = 1;
-			SET_EXT_CAPABILITY_ELE_BSS_COEXIST(pmlmepriv->ext_capab_ie_data, 1);
-
-			update_beacon(padapter, _EXT_CAP_IE_, NULL, _FALSE);
-		}		
-		
-	} 
-	else 
-	{
-		if (!psta->no_ht_set) {
-			psta->no_ht_set = 1;
-			pmlmepriv->num_sta_no_ht++;
-		}
-		if(pmlmepriv->htpriv.ht_option == _TRUE) {		
-			DBG_871X("%s STA " MAC_FMT
-				   " - no HT, num of non-HT stations %d\n",
-				   __FUNCTION__, MAC_ARG(psta->hwaddr),
-				   pmlmepriv->num_sta_no_ht);
-		}
-	}
-
-	if (rtw_ht_operation_update(padapter) > 0) {
-		update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
-		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE);
-		/*beacon_updated = _TRUE;*/
-	}	
-	
-#endif /* CONFIG_80211N_HT */
-
-	//update associcated stations cap.
-	associated_clients_update(padapter,  beacon_updated, STA_INFO_UPDATE_ALL);
-
-	DBG_871X("%s, updated=%d\n", __func__, beacon_updated);
-
-}
-
-u8 bss_cap_update_on_sta_leave(_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_beacon(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_beacon(padapter, _ERPINFO_IE_, 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_beacon(padapter, 0xFF, NULL, _TRUE);
-		}	
-	}
-	
-#ifdef CONFIG_80211N_HT
-
-	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 (psta->ht_40mhz_intolerant) {
-		psta->ht_40mhz_intolerant = 0;
-		pmlmepriv->num_sta_40mhz_intolerant--;
-
-		/*update ext_capab_ie_len & ext_capab_ie_data for beacon, probersp, assocrsp.*/
-		if ((pmlmepriv->ext_capab_ie_len > 0) && (pmlmepriv->num_sta_40mhz_intolerant == 0)) {
-			SET_EXT_CAPABILITY_ELE_BSS_COEXIST(pmlmepriv->ext_capab_ie_data, 0);
-			update_beacon(padapter, _EXT_CAP_IE_, NULL, _FALSE);
-		}
-		
-		beacon_updated = _TRUE;
-
-		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
-	}
-
-	if (rtw_ht_operation_update(padapter) > 0) {
-		update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
-		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE);
-	}
-	
-#endif /* CONFIG_80211N_HT */
-
-	/* update associated stations cap.
-	associated_clients_update(padapter,  beacon_updated, STA_INFO_UPDATE_ALL); //move it to avoid deadlock
-	*/
-	
-	DBG_871X("%s, updated=%d\n", __func__, beacon_updated);
-
-	return beacon_updated;
-
-}
-
-u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reason, bool enqueue)
-{
-	_irqL irqL;
-	u8 beacon_updated = _FALSE;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-
-	if(!psta)
-		return beacon_updated;
-
-	if (active == _TRUE)
-	{
-#ifdef CONFIG_80211N_HT
-		//tear down Rx AMPDU
-		send_delba(padapter, 0, psta->hwaddr);// recipient
-	
-		//tear down TX AMPDU
-		send_delba(padapter, 1, psta->hwaddr);// // originator
-		
-#endif //CONFIG_80211N_HT
-
-		issue_deauth(padapter, psta->hwaddr, reason);
-	}
-
-#ifdef CONFIG_BEAMFORMING
-	beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_LEAVE, psta->hwaddr, ETH_ALEN, 1);
-#endif
-
-	psta->htpriv.agg_enable_bitmap = 0x0;//reset
-	psta->htpriv.candidate_tid_bitmap = 0x0;//reset
-
-	//clear cam entry / key
-	rtw_clearstakey_cmd(padapter, psta, enqueue);
-
-
-	_enter_critical_bh(&psta->lock, &irqL);
-	psta->state &= ~_FW_LINKED;
-	_exit_critical_bh(&psta->lock, &irqL);
-
-	#ifdef CONFIG_IOCTL_CFG80211
-	if (1) {
-		#ifdef COMPAT_KERNEL_RELEASE
-		rtw_cfg80211_indicate_sta_disassoc(padapter, psta->hwaddr, reason);
-		#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
-		rtw_cfg80211_indicate_sta_disassoc(padapter, psta->hwaddr, reason);
-		#else //(LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
-		/* will call rtw_cfg80211_indicate_sta_disassoc() in cmd_thread for old API context */
-		#endif //(LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
-	} else
-	#endif //CONFIG_IOCTL_CFG80211
-	{
-		rtw_indicate_sta_disassoc_event(padapter, psta);
-	}
-
-	report_del_sta_event(padapter, psta->hwaddr, reason, enqueue, _FALSE);
-
-	beacon_updated = bss_cap_update_on_sta_leave(padapter, psta);
-
-	//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);					
-	rtw_free_stainfo(padapter, psta);
-	//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-	
-
-	return beacon_updated;
-
-}
-
-int rtw_ap_inform_ch_switch(_adapter *padapter, u8 new_ch, u8 ch_offset)
-{
-	_irqL irqL;
-	_list	*phead, *plist;
-	int ret=0;	
-	struct sta_info *psta = NULL;	
-	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};
-
-	if((pmlmeinfo->state&0x03) != WIFI_FW_AP_STATE)
-		return ret;
-
-	DBG_871X(FUNC_NDEV_FMT" with ch:%u, offset:%u\n",
-		FUNC_NDEV_ARG(padapter->pnetdev), new_ch, ch_offset);
-
-	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	phead = &pstapriv->asoc_list;
-	plist = get_next(phead);
-	
-	/* for each sta in asoc_queue */
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)	
-	{		
-		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		plist = get_next(plist);
-
-		issue_action_spct_ch_switch(padapter, psta->hwaddr, new_ch, ch_offset);
-		psta->expire_to = ((pstapriv->expire_to * 2) > 5) ? 5 : (pstapriv->expire_to * 2);
-	}
-	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-	issue_action_spct_ch_switch(padapter, bc_addr, new_ch, ch_offset);
-
-	return ret;
-}
-
-int rtw_sta_flush(_adapter *padapter, bool enqueue)
-{
-	_irqL irqL;
-	_list	*phead, *plist;
-	int ret = 0;
-	struct sta_info *psta = NULL;	
-	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 flush_num = 0;
-	char flush_list[NUM_STA];
-	int i;
-
-	if ((pmlmeinfo->state&0x03) != WIFI_FW_AP_STATE)
-		return ret;
-
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(padapter->pnetdev));
-
-	/* pick sta from sta asoc_queue */
-	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	phead = &pstapriv->asoc_list;
-	plist = get_next(phead);
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
-		int stainfo_offset;
-
-		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		plist = get_next(plist);
-
-		rtw_list_delete(&psta->asoc_list);
-		pstapriv->asoc_list_cnt--;
-
-		stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
-		if (stainfo_offset_valid(stainfo_offset))
-			flush_list[flush_num++] = stainfo_offset;
-		else
-			rtw_warn_on(1);
-	}
-	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-	/* call ap_free_sta() for each sta picked */
-	for (i = 0; i < flush_num; i++) {
-		psta = rtw_get_stainfo_by_offset(pstapriv, flush_list[i]);
-		ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, enqueue);
-	}
-
-	issue_deauth(padapter, bc_addr, WLAN_REASON_DEAUTH_LEAVING);
-
-	associated_clients_update(padapter, _TRUE, STA_INFO_UPDATE_ALL);
-
-	return ret;
-}
-
-/* called > TSR LEVEL for USB or SDIO Interface*/
-void sta_info_update(_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->qospriv.qos_option == 0)	
-		psta->qos_option = 0;
-
-		
-#ifdef CONFIG_80211N_HT		
-	//update 802.11n ht cap.
-	if(WLAN_STA_HT&flags)
-	{
-		psta->htpriv.ht_option = _TRUE;
-		psta->qos_option = 1;	
-
-		psta->htpriv.smps_cap = (psta->htpriv.ht_cap.cap_info & IEEE80211_HT_CAP_SM_PS)>>2;
-	}
-	else		
-	{
-		psta->htpriv.ht_option = _FALSE;
-	}
-		
-	if(pmlmepriv->htpriv.ht_option == _FALSE)	
-		psta->htpriv.ht_option = _FALSE;
-#endif
-
-#ifdef CONFIG_80211AC_VHT
-	//update 802.11AC vht cap.
-	if(WLAN_STA_VHT&flags)
-	{
-		psta->vhtpriv.vht_option = _TRUE;
-	}
-	else		
-	{
-		psta->vhtpriv.vht_option = _FALSE;
-	}
-
-	if(pmlmepriv->vhtpriv.vht_option == _FALSE)
-		psta->vhtpriv.vht_option = _FALSE;
-#endif	
-
-
-	update_sta_info_apmode(padapter, psta);
-		
-
-}
-
-/* called >= TSR LEVEL for USB or SDIO Interface*/
-void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta)
-{
-	if (psta->state & _FW_LINKED) {
-		//add ratid
-		add_RATid(padapter, psta, 0);//DM_RATR_STA_INIT
-	}	
-}
-/* restore hw setting from sw data structures */
-void rtw_ap_restore_network(_adapter *padapter)
-{
-	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct sta_priv * pstapriv = &padapter->stapriv;
-	struct sta_info *psta;
-	struct security_priv* psecuritypriv=&(padapter->securitypriv);
-	_irqL irqL;
-	_list	*phead, *plist;
-	u8 chk_alive_num = 0;
-	char chk_alive_list[NUM_STA];
-	int i;
-
-	rtw_setopmode_cmd(padapter, Ndis802_11APMode,_FALSE);
-
-	set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-	rtw_startbss_cmd(padapter, RTW_CMDF_DIRECTLY);
-
-	if((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
-		(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_))
-	{
-		/* restore group key, WEP keys is restored in ips_leave() */
-		rtw_set_key(padapter, psecuritypriv, psecuritypriv->dot118021XGrpKeyid, 0,_FALSE);
-	}
-
-	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	
-	phead = &pstapriv->asoc_list;
-	plist = get_next(phead);
-
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
-		int stainfo_offset;
-
-		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		plist = get_next(plist);
-
-		stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
-		if (stainfo_offset_valid(stainfo_offset)) {
-			chk_alive_list[chk_alive_num++] = stainfo_offset;
-		}
-	}
-
-	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-	for (i = 0; i < chk_alive_num; i++) {
-		psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
-
-		if (psta == NULL) {
-			DBG_871X(FUNC_ADPT_FMT" sta_info is null\n", FUNC_ADPT_ARG(padapter));
-		} else if (psta->state &_FW_LINKED) {
-			rtw_sta_media_status_rpt(padapter, psta, 1);
-			Update_RA_Entry(padapter, psta);
-			//pairwise key
-			/* per sta pairwise key and settings */
-			if(	(padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
-				(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_))
-			{
-				rtw_setstakey_cmd(padapter, psta, UNICAST_KEY,_FALSE);
-			}			
-		}
-	}
-
-}
-
-void start_ap_mode(_adapter *padapter)
-{
-	int i;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-	
-	pmlmepriv->update_bcn = _FALSE;
-	
-	/*init_mlme_ap_info(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;
-#ifdef CONFIG_80211N_HT
-	pmlmepriv->num_sta_no_ht = 0;
-#endif //CONFIG_80211N_HT
-	pmlmeinfo->HT_info_enable = 0;
-	pmlmeinfo->HT_caps_enable = 0;
-	pmlmeinfo->HT_enable = 0;
-	
-	pmlmepriv->num_sta_ht_20mhz = 0;
-	pmlmepriv->num_sta_40mhz_intolerant = 0;
-	pmlmepriv->olbc = _FALSE;
-	pmlmepriv->olbc_ht = _FALSE;
-	
-#ifdef CONFIG_80211N_HT
-	pmlmepriv->ht_20mhz_width_req = _FALSE;
-	pmlmepriv->ht_intolerant_ch_reported = _FALSE;
-	pmlmepriv->ht_op_mode = 0;
-	pmlmepriv->sw_to_20mhz = 0;
-#endif
-
-	_rtw_memset(pmlmepriv->ext_capab_ie_data, 0, sizeof(pmlmepriv->ext_capab_ie_data));
-	pmlmepriv->ext_capab_ie_len = 0;
-
-	for (i = 0 ;  i < NUM_STA ; i++)
-		pstapriv->sta_aid[i] = NULL;
-	
-	//for ACL 
-	_rtw_init_listhead(&(pacl_list->acl_node_q.queue));
-	pacl_list->num = 0;
-	pacl_list->mode = 0;
-	for(i = 0; i < NUM_ACL; i++)
-	{		
-		_rtw_init_listhead(&pacl_list->aclnode[i].list);
-		pacl_list->aclnode[i].valid = _FALSE;
-	}
-
-}
-
-void stop_ap_mode(_adapter *padapter)
-{
-	_irqL irqL;
-	_list	*phead, *plist;
-	struct rtw_wlan_acl_node *paclnode;
-	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;
-	_queue	*pacl_node_q =&pacl_list->acl_node_q;	
-
-	pmlmepriv->update_bcn = _FALSE;
-	pmlmeext->bstart_bss = _FALSE;
-	padapter->netif_up = _FALSE;
-	//_rtw_spinlock_free(&pmlmepriv->bcn_update_lock);
-	
-	//reset and init security priv , this can refine with rtw_reset_securitypriv
-	_rtw_memset((unsigned char *)&padapter->securitypriv, 0, sizeof (struct security_priv));
-	padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
-	padapter->securitypriv.ndisencryptstatus = Ndis802_11WEPDisabled;
-
-	#ifdef CONFIG_DFS_MASTER
-	rtw_dfs_master_status_apply(padapter, MLME_AP_STOPPED);
-	#endif
-
-	/* free scan queue */
-	rtw_free_network_queue(padapter, _TRUE);
-
-	//for ACL
-	_enter_critical_bh(&(pacl_node_q->lock), &irqL);
-	phead = get_list_head(pacl_node_q);
-	plist = get_next(phead);		
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-	{
-		paclnode = LIST_CONTAINOR(plist, struct rtw_wlan_acl_node, list);
-		plist = get_next(plist);
-
-		if(paclnode->valid == _TRUE)
-		{
-			paclnode->valid = _FALSE;
-
-			rtw_list_delete(&paclnode->list);
-				
-			pacl_list->num--;		
-		}		
-	}	
-	_exit_critical_bh(&(pacl_node_q->lock), &irqL);
-	
-	DBG_871X("%s, free acl_node_queue, num=%d\n", __func__, pacl_list->num);
-	
-	rtw_sta_flush(padapter, _TRUE);
-
-	//free_assoc_sta_resources	
-	rtw_free_all_stainfo(padapter);
-	
-	psta = rtw_get_bcmc_stainfo(padapter);
-	//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
-	rtw_free_stainfo(padapter, psta);
-	//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-	
-	rtw_init_bcmc_stainfo(padapter);	
-
-	rtw_free_mlme_priv_ie_data(pmlmepriv);
-
-#ifdef CONFIG_BT_COEXIST
-	rtw_btcoex_MediaStatusNotify(padapter, 0); //disconnect 
-#endif	
-
-}
-
-#endif //CONFIG_NATIVEAP_MLME
-
-void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset)
-{
-#define UPDATE_VHT_CAP 1
-#define UPDATE_HT_CAP 1
-
-#ifdef CONFIG_80211AC_VHT
-	{
-		struct vht_priv	*vhtpriv = &adapter->mlmepriv.vhtpriv;
-		u8 *vht_cap_ie, *vht_op_ie;
-		int vht_cap_ielen, vht_op_ielen;
-		u8	center_freq;
-
-		vht_cap_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_VHTCapability, &vht_cap_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
-		vht_op_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_VHTOperation, &vht_op_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
-		center_freq = rtw_get_center_ch(ch, bw, offset);
-
-		/* update vht cap ie */
-		if (vht_cap_ie && vht_cap_ielen) {
-			#if UPDATE_VHT_CAP
-			/* if ((bw == CHANNEL_WIDTH_160 || bw == CHANNEL_WIDTH_80_80) && pvhtpriv->sgi_160m)
-				SET_VHT_CAPABILITY_ELE_SHORT_GI160M(pvht_cap_ie + 2, 1);
-			else */
-				SET_VHT_CAPABILITY_ELE_SHORT_GI160M(vht_cap_ie + 2, 0);
-
-			if (bw >= CHANNEL_WIDTH_80 && vhtpriv->sgi_80m)
-				SET_VHT_CAPABILITY_ELE_SHORT_GI80M(vht_cap_ie + 2, 1);
-			else
-				SET_VHT_CAPABILITY_ELE_SHORT_GI80M(vht_cap_ie + 2, 0);
-			#endif
-		}
-
-		/* update vht op ie */
-		if (vht_op_ie && vht_op_ielen) {
-			if (bw < CHANNEL_WIDTH_80) {
-				SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 0);
-				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, 0);
-				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
-			} else if (bw == CHANNEL_WIDTH_80) {
-				SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 1);
-				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, center_freq);
-				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
-			} else {
-				DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(adapter), bw);
-				rtw_warn_on(1);
-			}
-		}
-	}
-#endif /* CONFIG_80211AC_VHT */
-#ifdef CONFIG_80211N_HT
-	{
-		struct ht_priv	*htpriv = &adapter->mlmepriv.htpriv;
-		u8 *ht_cap_ie, *ht_op_ie;
-		int ht_cap_ielen, ht_op_ielen;
-
-		ht_cap_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_HTCapability, &ht_cap_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
-		ht_op_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_HTInfo, &ht_op_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
-
-		/* update ht cap ie */
-		if (ht_cap_ie && ht_cap_ielen) {
-			#if UPDATE_HT_CAP
-			if (bw >= CHANNEL_WIDTH_40)
-				SET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2, 1);
-			else
-				SET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2, 0);
-
-			if (bw >= CHANNEL_WIDTH_40 && htpriv->sgi_40m)
-				SET_HT_CAP_ELE_SHORT_GI40M(ht_cap_ie + 2, 1);
-			else
-				SET_HT_CAP_ELE_SHORT_GI40M(ht_cap_ie + 2, 0);
-
-			if (htpriv->sgi_20m)
-				SET_HT_CAP_ELE_SHORT_GI20M(ht_cap_ie + 2, 1);
-			else
-				SET_HT_CAP_ELE_SHORT_GI20M(ht_cap_ie + 2, 0);
-			#endif
-		}
-
-		/* update ht op ie */
-		if (ht_op_ie && ht_op_ielen) {
-			SET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2, ch);
-			switch (offset) {
-			case HAL_PRIME_CHNL_OFFSET_LOWER:
-				SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCA);
-				break;
-			case HAL_PRIME_CHNL_OFFSET_UPPER:
-				SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCB);
-				break;
-			case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
-			default:
-				SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCN);
-				break;
-			}
-
-			if (bw >= CHANNEL_WIDTH_40)
-				SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2, 1);
-			else
-				SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2, 0);
-		}
-	}
-#endif /* CONFIG_80211N_HT */
-
-{
-	u8 *p;
-	int ie_len;
-	u8 old_ch = bss->Configuration.DSConfig;
-	bool change_band = _FALSE;
-
-	if ((ch <= 14 && old_ch >= 36) || (ch >= 36 && old_ch <= 14))
-		change_band = _TRUE;
-
-	/* update channel in IE */
-	p = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), _DSSET_IE_, &ie_len, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
-	if (p && ie_len > 0)
-		*(p + 2) = ch;
-
-	bss->Configuration.DSConfig = ch;
-
-	/* band is changed, update ERP, support rate, ext support rate IE */
-	if (change_band == _TRUE)
-		change_band_update_ie(adapter, bss, ch);
-}
-
-}
-
-bool rtw_ap_chbw_decision(_adapter *adapter, u8 req_ch, u8 req_bw, u8 req_offset
-	, u8 *ch, u8 *bw, u8 *offset)
-{
-	u8 dec_ch, dec_bw, dec_offset;
-	u8 u_ch = 0, u_offset, u_bw;
-	bool changed = _FALSE;
-	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
-	u8 sta_num;
-	u8 ld_sta_num;
-	u8 lg_sta_num;
-	u8 ap_num;
-	u8 ld_ap_num;
-	bool set_u_ch = _FALSE, set_dec_ch = _FALSE;
-
-	dec_ch = req_ch;
-	dec_bw = req_bw;
-	dec_offset = req_offset;
-	
-	rtw_dev_iface_status_no_self(adapter, &sta_num, &ld_sta_num, &lg_sta_num, &ap_num, &ld_ap_num);
-	DBG_871X(FUNC_ADPT_FMT" ld_sta_num:%u, lg_sta_num%u, ap_num:%u\n"
-		, FUNC_ADPT_ARG(adapter), ld_sta_num, lg_sta_num, ap_num);
-
-	if (ld_sta_num || ap_num) {
-		/* has linked STA or AP mode, follow */
-
-		rtw_warn_on(!rtw_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset));
-
-		DBG_871X(FUNC_ADPT_FMT" union no self: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
-		DBG_871X(FUNC_ADPT_FMT" req: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
-
-		rtw_adjust_chbw(adapter, u_ch, &dec_bw, &dec_offset);
-
-		rtw_sync_chbw(&dec_ch, &dec_bw, &dec_offset
-			, &u_ch, &u_bw, &u_offset);
-
-		rtw_ap_update_bss_chbw(adapter, &(adapter->mlmepriv.cur_network.network)
-			, dec_ch, dec_bw, dec_offset);
-
-		set_u_ch = _TRUE;
-	} else if (lg_sta_num) {
-		/* has linking STA */
-
-		rtw_warn_on(!rtw_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset));
-
-		DBG_871X(FUNC_ADPT_FMT" union no self: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
-		DBG_871X(FUNC_ADPT_FMT" req: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
-
-		rtw_adjust_chbw(adapter, dec_ch, &dec_bw, &dec_offset);
-		
-		if (rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch, dec_bw, dec_offset)) {
-
-			rtw_sync_chbw(&dec_ch, &dec_bw, &dec_offset
-					, &u_ch, &u_bw, &u_offset);
-
-			rtw_ap_update_bss_chbw(adapter, &(adapter->mlmepriv.cur_network.network)
-				, dec_ch, dec_bw, dec_offset);
-
-			set_u_ch = _TRUE;
-		} else {
-			/* set this for possible ch change when join down*/
-			set_fwstate(&adapter->mlmepriv, WIFI_OP_CH_SWITCHING);
-		}
-	} else {
-		/* single AP mode */
-
-		DBG_871X(FUNC_ADPT_FMT" req: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
-		rtw_adjust_chbw(adapter, dec_ch, &dec_bw, &dec_offset);
-
-		#if defined(CONFIG_DFS_MASTER)
-		/* check NOL */
-		if (rtw_chset_is_ch_non_ocp(mlmeext->channel_set, dec_ch, dec_bw, dec_offset)) {
-			/* choose 5G DFS channel for debug */
-			if (adapter_to_rfctl(adapter)->dbg_dfs_master_choose_dfs_ch_first
-				&& rtw_choose_available_chbw(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, RTW_CHF_2G|RTW_CHF_NON_DFS) == _TRUE) {
-				DBG_871X(FUNC_ADPT_FMT" choose 5G DFS channel for debug\n", FUNC_ADPT_ARG(adapter));
-			} else 
-			/* choose from 5G no DFS */
-			if (rtw_choose_available_chbw(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, RTW_CHF_2G|RTW_CHF_DFS) == _FALSE) {
-				/* including 5G DFS, not long CAC */
-				if (rtw_choose_available_chbw(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, RTW_CHF_2G|RTW_CHF_LONG_CAC) == _FALSE) {
-					/* including 5G DFS, long CAC */
-					if (rtw_choose_available_chbw(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, RTW_CHF_2G) == _FALSE) {
-						/* including 2.4G channel */
-						if (rtw_choose_available_chbw(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, RTW_CHF_5G) == _FALSE) {
-							DBG_871X(FUNC_ADPT_FMT" no available ch\n", FUNC_ADPT_ARG(adapter));
-							rtw_warn_on(1);
-						}
-					}
-				}
-			}
-		}
-		#endif /* defined(CONFIG_DFS_MASTER) */
-
-		rtw_ap_update_bss_chbw(adapter, &(adapter->mlmepriv.cur_network.network)
-				, dec_ch, dec_bw, dec_offset);
-
-		set_dec_ch = _TRUE;
-	}
-
-	if (check_fwstate(&adapter->mlmepriv, _FW_UNDER_SURVEY)
-		#ifdef CONFIG_CONCURRENT_MODE
-		|| check_buddy_fwstate(adapter, _FW_UNDER_SURVEY)
-		#endif
-	) {
-		/* scanning, leave ch setting to scan state machine */
-		set_u_ch = set_dec_ch = _FALSE;
-	}
-
-	if (mlmeext->cur_channel != dec_ch
-		|| mlmeext->cur_bwmode != dec_bw
-		|| mlmeext->cur_ch_offset != dec_offset)
-		changed = _TRUE;
-
-	if (changed == _TRUE && rtw_linked_check(adapter) == _TRUE) {
-		#ifdef CONFIG_SPCT_CH_SWITCH
-		if (1)
-			rtw_ap_inform_ch_switch(adapter, dec_ch, dec_offset);
-		else
-		#endif
-			rtw_sta_flush(adapter, _FALSE);
-	}
-
-	mlmeext->cur_channel = dec_ch;
-	mlmeext->cur_bwmode = dec_bw;
-	mlmeext->cur_ch_offset = dec_offset;
-
-	if (u_ch != 0)
-		DBG_871X(FUNC_ADPT_FMT" union: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
-
-	DBG_871X(FUNC_ADPT_FMT" dec: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), dec_ch, dec_bw, dec_offset);
-
-	if (set_u_ch == _TRUE) {
-		*ch = u_ch;
-		*bw = u_bw;
-		*offset = u_offset;
-	} else if (set_dec_ch == _TRUE) {
-		*ch = dec_ch;
-		*bw = dec_bw;
-		*offset = dec_offset;
-	}	
-
-	return changed;
-}
-
-#endif //CONFIG_AP_MODE
-
+		psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
+
+		if (psta == NULL)
+			RTW_INFO(FUNC_ADPT_FMT" sta_info is null\n", FUNC_ADPT_ARG(padapter));
+		else if (psta->state & _FW_LINKED) {
+			rtw_sta_media_status_rpt(padapter, psta, 1);
+			Update_RA_Entry(padapter, psta);
+			/* pairwise key */
+			/* per sta pairwise key and settings */
+			if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
+			    (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_))
+				rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _FALSE);
+		}
+	}
+
+}
+
+void start_ap_mode(_adapter *padapter)
+{
+	int i;
+	struct sta_info *psta = NULL;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+
+	pmlmepriv->update_bcn = _FALSE;
+
+	/*init_mlme_ap_info(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;
+#ifdef CONFIG_80211N_HT
+	pmlmepriv->num_sta_no_ht = 0;
+#endif /* CONFIG_80211N_HT */
+	pmlmeinfo->HT_info_enable = 0;
+	pmlmeinfo->HT_caps_enable = 0;
+	pmlmeinfo->HT_enable = 0;
+
+	pmlmepriv->num_sta_ht_20mhz = 0;
+	pmlmepriv->num_sta_40mhz_intolerant = 0;
+	ATOMIC_SET(&pmlmepriv->olbc, _FALSE);
+	ATOMIC_SET(&pmlmepriv->olbc_ht, _FALSE);
+
+#ifdef CONFIG_80211N_HT
+	pmlmepriv->ht_20mhz_width_req = _FALSE;
+	pmlmepriv->ht_intolerant_ch_reported = _FALSE;
+	pmlmepriv->ht_op_mode = 0;
+	pmlmepriv->sw_to_20mhz = 0;
+#endif
+
+	_rtw_memset(pmlmepriv->ext_capab_ie_data, 0, sizeof(pmlmepriv->ext_capab_ie_data));
+	pmlmepriv->ext_capab_ie_len = 0;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	psecuritypriv->dot118021x_bmc_cam_id = INVALID_SEC_MAC_CAM_ID;
+#endif
+
+	for (i = 0 ;  i < pstapriv->max_aid; i++)
+		pstapriv->sta_aid[i] = NULL;
+
+	psta = rtw_get_bcmc_stainfo(padapter);
+	/*_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);*/
+	if (psta)
+		rtw_free_stainfo(padapter, psta);
+	/*_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);*/
+
+	rtw_init_bcmc_stainfo(padapter);
+
+	if (rtw_mi_get_ap_num(padapter))
+		RTW_SET_SCAN_BAND_SKIP(padapter, BAND_5G);
+
+}
+
+void rtw_ap_bcmc_sta_flush(_adapter *padapter)
+{
+#ifdef CONFIG_CONCURRENT_MODE
+	int cam_id = -1;
+	u8 *addr = adapter_mac_addr(padapter);
+
+	cam_id = rtw_iface_bcmc_id_get(padapter);
+	if (cam_id != INVALID_SEC_MAC_CAM_ID) {
+		RTW_PRINT("clear group key for "ADPT_FMT" addr:"MAC_FMT", camid:%d\n",
+			ADPT_ARG(padapter), MAC_ARG(addr), cam_id);
+		clear_cam_entry(padapter, cam_id);
+		rtw_camid_free(padapter, cam_id);
+		rtw_iface_bcmc_id_set(padapter, INVALID_SEC_MAC_CAM_ID);	/*init default value*/
+	}
+#else
+	invalidate_cam_all(padapter);
+#endif
+}
+
+void stop_ap_mode(_adapter *padapter)
+{
+	u8 self_action = MLME_ACTION_UNKNOWN;
+	_irqL irqL;
+	struct sta_info *psta = NULL;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct dvobj_priv *pdvobj = padapter->dvobj;
+
+	RTW_INFO("%s -"ADPT_FMT"\n", __func__, ADPT_ARG(padapter));
+
+	if (MLME_IS_AP(padapter))
+		self_action = MLME_AP_STOPPED;
+	else if (MLME_IS_MESH(padapter))
+		self_action = MLME_MESH_STOPPED;
+	else
+		rtw_warn_on(1);
+
+	pmlmepriv->update_bcn = _FALSE;
+	/*pmlmeext->bstart_bss = _FALSE;*/
+	padapter->netif_up = _FALSE;
+	/* _rtw_spinlock_free(&pmlmepriv->bcn_update_lock); */
+
+	/* reset and init security priv , this can refine with rtw_reset_securitypriv */
+	_rtw_memset((unsigned char *)&padapter->securitypriv, 0, sizeof(struct security_priv));
+	padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
+	padapter->securitypriv.ndisencryptstatus = Ndis802_11WEPDisabled;
+
+#ifdef CONFIG_DFS_MASTER
+	rtw_dfs_master_status_apply(padapter, self_action);
+#endif
+
+	/* free scan queue */
+	rtw_free_network_queue(padapter, _TRUE);
+
+#if CONFIG_RTW_MACADDR_ACL
+	rtw_macaddr_acl_clear(padapter, RTW_ACL_PERIOD_BSS);
+#endif
+
+	rtw_sta_flush(padapter, _TRUE);
+	rtw_ap_bcmc_sta_flush(padapter);
+
+	/* free_assoc_sta_resources	 */
+	rtw_free_all_stainfo(padapter);
+
+	psta = rtw_get_bcmc_stainfo(padapter);
+	if (psta) {
+		rtw_sta_mstatus_disc_rpt(padapter, psta->cmn.mac_id);
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
+		rtw_free_stainfo(padapter, psta);
+		/*_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);*/
+	}
+
+	rtw_free_mlme_priv_ie_data(pmlmepriv);
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	if (pmlmeext->bstart_bss == _TRUE) {
+		_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+		pdvobj->nr_ap_if--;
+		if (pdvobj->nr_ap_if > 0)
+			pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL / pdvobj->nr_ap_if;
+		else
+			pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL;
+
+		rtw_list_delete(&padapter->list);
+		_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+
+		rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pdvobj->inter_bcn_space));
+
+		if (pdvobj->nr_ap_if == 0)
+			_cancel_timer_ex(&pdvobj->txbcn_timer);
+	}
+#endif
+
+	pmlmeext->bstart_bss = _FALSE;
+
+	rtw_hal_rcr_set_chk_bssid(padapter, self_action);
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_MediaStatusNotify(padapter, 0); /* disconnect */
+#endif
+
+}
+
+#endif /* CONFIG_NATIVEAP_MLME */
+
+void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset)
+{
+#define UPDATE_VHT_CAP 1
+#define UPDATE_HT_CAP 1
+#ifdef CONFIG_80211AC_VHT
+	struct vht_priv *vhtpriv = &adapter->mlmepriv.vhtpriv;
+#endif
+	{
+		u8 *p;
+		int ie_len;
+		u8 old_ch = bss->Configuration.DSConfig;
+		bool change_band = _FALSE;
+
+		if ((ch <= 14 && old_ch >= 36) || (ch >= 36 && old_ch <= 14))
+			change_band = _TRUE;
+
+		/* update channel in IE */
+		p = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), _DSSET_IE_, &ie_len, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
+		if (p && ie_len > 0)
+			*(p + 2) = ch;
+
+		bss->Configuration.DSConfig = ch;
+
+		/* band is changed, update ERP, support rate, ext support rate IE */
+		if (change_band == _TRUE)
+			change_band_update_ie(adapter, bss, ch);
+	}
+
+#ifdef CONFIG_80211AC_VHT
+	if (vhtpriv->vht_option == _TRUE) {
+		u8 *vht_cap_ie, *vht_op_ie;
+		int vht_cap_ielen, vht_op_ielen;
+		u8	center_freq;
+
+		vht_cap_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_VHTCapability, &vht_cap_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
+		vht_op_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_VHTOperation, &vht_op_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
+		center_freq = rtw_get_center_ch(ch, bw, offset);
+
+		/* update vht cap ie */
+		if (vht_cap_ie && vht_cap_ielen) {
+			#if UPDATE_VHT_CAP
+			/* if ((bw == CHANNEL_WIDTH_160 || bw == CHANNEL_WIDTH_80_80) && pvhtpriv->sgi_160m)
+				SET_VHT_CAPABILITY_ELE_SHORT_GI160M(pvht_cap_ie + 2, 1);
+			else */
+				SET_VHT_CAPABILITY_ELE_SHORT_GI160M(vht_cap_ie + 2, 0);
+
+			if (bw >= CHANNEL_WIDTH_80 && vhtpriv->sgi_80m)
+				SET_VHT_CAPABILITY_ELE_SHORT_GI80M(vht_cap_ie + 2, 1);
+			else
+				SET_VHT_CAPABILITY_ELE_SHORT_GI80M(vht_cap_ie + 2, 0);
+			#endif
+		}
+
+		/* update vht op ie */
+		if (vht_op_ie && vht_op_ielen) {
+			if (bw < CHANNEL_WIDTH_80) {
+				SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 0);
+				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, 0);
+				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
+			} else if (bw == CHANNEL_WIDTH_80) {
+				SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 1);
+				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, center_freq);
+				SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
+			} else {
+				RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(adapter), bw);
+				rtw_warn_on(1);
+			}
+		}
+	}
+#endif /* CONFIG_80211AC_VHT */
+#ifdef CONFIG_80211N_HT
+	{
+		struct ht_priv	*htpriv = &adapter->mlmepriv.htpriv;
+		u8 *ht_cap_ie, *ht_op_ie;
+		int ht_cap_ielen, ht_op_ielen;
+
+		ht_cap_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_HTCapability, &ht_cap_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
+		ht_op_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_HTInfo, &ht_op_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
+
+		/* update ht cap ie */
+		if (ht_cap_ie && ht_cap_ielen) {
+			#if UPDATE_HT_CAP
+			if (bw >= CHANNEL_WIDTH_40)
+				SET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2, 1);
+			else
+				SET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2, 0);
+
+			if (bw >= CHANNEL_WIDTH_40 && htpriv->sgi_40m)
+				SET_HT_CAP_ELE_SHORT_GI40M(ht_cap_ie + 2, 1);
+			else
+				SET_HT_CAP_ELE_SHORT_GI40M(ht_cap_ie + 2, 0);
+
+			if (htpriv->sgi_20m)
+				SET_HT_CAP_ELE_SHORT_GI20M(ht_cap_ie + 2, 1);
+			else
+				SET_HT_CAP_ELE_SHORT_GI20M(ht_cap_ie + 2, 0);
+			#endif
+		}
+
+		/* update ht op ie */
+		if (ht_op_ie && ht_op_ielen) {
+			SET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2, ch);
+			switch (offset) {
+			case HAL_PRIME_CHNL_OFFSET_LOWER:
+				SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCA);
+				break;
+			case HAL_PRIME_CHNL_OFFSET_UPPER:
+				SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCB);
+				break;
+			case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
+			default:
+				SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCN);
+				break;
+			}
+
+			if (bw >= CHANNEL_WIDTH_40)
+				SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2, 1);
+			else
+				SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2, 0);
+		}
+	}
+#endif /* CONFIG_80211N_HT */
+}
+
+/*
+* return _TRUE if ch setting differs from mlmeext.network
+*/
+bool rtw_ap_chbw_decision(_adapter *adapter, s16 req_ch, s8 req_bw, s8 req_offset
+			  , u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow)
+{
+	RT_CHANNEL_INFO *chset = adapter_to_chset(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	bool ch_avail = _FALSE;
+	u8 cur_ie_ch, cur_ie_bw, cur_ie_offset;
+	u8 dec_ch, dec_bw, dec_offset;
+	u8 u_ch = 0, u_offset, u_bw;
+	bool changed = _FALSE;
+	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
+	WLAN_BSSID_EX *network = &(mlmeext->mlmext_info.network);
+	struct mi_state mstate;
+	bool set_u_ch = _FALSE, set_dec_ch = _FALSE;
+
+	rtw_ies_get_chbw(BSS_EX_TLV_IES(network), BSS_EX_TLV_IES_LEN(network)
+		, &cur_ie_ch, &cur_ie_bw, &cur_ie_offset, 1, 1);
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(adapter)) {
+		if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
+			/* check channel settings are the same */
+			if (cur_ie_ch == mlmeext->cur_channel
+				&& cur_ie_bw == mlmeext->cur_bwmode
+					&& cur_ie_offset == mlmeext->cur_ch_offset) {
+
+
+					RTW_INFO(FUNC_ADPT_FMT"req ch settings are the same as current ch setting, go to exit\n"
+						, FUNC_ADPT_ARG(adapter));
+
+					*chbw_allow = _FALSE;
+					goto exit;
+			} else {
+					RTW_INFO(FUNC_ADPT_FMT"request channel settings are not the same as current channel setting(%d,%d,%d,%d,%d,%d), restart MCC\n"
+						, FUNC_ADPT_ARG(adapter)
+						, cur_ie_ch, cur_ie_bw, cur_ie_bw
+						, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+
+				rtw_hal_set_mcc_setting_disconnect(adapter);
+			}
+		}	
+	}
+#endif /* CONFIG_MCC_MODE */
+
+	if (req_ch == 0) {
+		/* request comes from upper layer, use cur_ie values */
+		dec_ch = cur_ie_ch;
+		dec_bw = cur_ie_bw;
+		dec_offset = cur_ie_offset;
+	} else {
+		/* use chbw of cur_ie updated with specifying req as temporary decision */
+		dec_ch = (req_ch <= REQ_CH_NONE) ? cur_ie_ch : req_ch;
+		dec_bw = (req_bw <= REQ_BW_NONE) ? cur_ie_bw : req_bw;
+		dec_offset = (req_offset <= REQ_OFFSET_NONE) ? cur_ie_offset : req_offset;
+	}
+
+	rtw_mi_status_no_self(adapter, &mstate);
+	RTW_INFO(FUNC_ADPT_FMT" ld_sta_num:%u, lg_sta_num%u, ap_num:%u, mesh_num:%u\n"
+		, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate), MSTATE_STA_LG_NUM(&mstate)
+		, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate));
+
+	if (MSTATE_STA_LD_NUM(&mstate) || MSTATE_AP_NUM(&mstate) || MSTATE_MESH_NUM(&mstate)) {
+		/* has linked STA or AP/Mesh mode */
+
+		rtw_warn_on(!rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset));
+
+		RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
+		RTW_INFO(FUNC_ADPT_FMT" req: %d,%d,%d\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
+
+		rtw_adjust_chbw(adapter, u_ch, &dec_bw, &dec_offset);
+
+#ifdef CONFIG_MCC_MODE
+		if (MCC_EN(adapter)) {
+			if (!rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch, dec_bw, dec_offset)) {
+				mlmeext->cur_channel = *ch = dec_ch = cur_ie_ch;
+				mlmeext->cur_bwmode = *bw = dec_bw = cur_ie_bw;
+				mlmeext->cur_ch_offset = *offset = dec_offset = cur_ie_offset;
+				/* channel bw offset can not be allowed, need MCC */
+				*chbw_allow = _FALSE;
+				RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
+					 , *ch, *bw, *offset);
+				goto exit;
+			} else
+				/* channel bw offset can be allowed, not need MCC */
+				*chbw_allow = _TRUE;
+		}
+#endif /* CONFIG_MCC_MODE */
+
+		/* follow */
+		rtw_chset_sync_chbw(chset
+			, &dec_ch, &dec_bw, &dec_offset
+			, &u_ch, &u_bw, &u_offset);
+
+		set_u_ch = _TRUE;
+	} else if (MSTATE_STA_LG_NUM(&mstate)) {
+		/* has linking STA */
+
+		rtw_warn_on(!rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset));
+
+		RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
+		RTW_INFO(FUNC_ADPT_FMT" req: %d,%d,%d\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
+
+		rtw_adjust_chbw(adapter, dec_ch, &dec_bw, &dec_offset);
+
+		if (rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch, dec_bw, dec_offset)) {
+
+			rtw_chset_sync_chbw(chset
+				, &dec_ch, &dec_bw, &dec_offset
+				, &u_ch, &u_bw, &u_offset);
+
+			set_u_ch = _TRUE;
+
+			/* channel bw offset can be allowed, not need MCC */
+			*chbw_allow = _TRUE;
+		} else {
+#ifdef CONFIG_MCC_MODE
+			if (MCC_EN(adapter)) {
+				mlmeext->cur_channel = *ch = dec_ch;
+				mlmeext->cur_bwmode = *bw = dec_bw;
+				mlmeext->cur_ch_offset = *offset = dec_offset;
+
+				/* channel bw offset can not be allowed, need MCC */
+				*chbw_allow = _FALSE;
+				RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
+					 , *ch, *bw, *offset);
+				goto exit;
+			}
+#endif /* CONFIG_MCC_MODE */
+
+			/* set this for possible ch change when join down*/
+			set_fwstate(&adapter->mlmepriv, WIFI_OP_CH_SWITCHING);
+		}
+	} else {
+		/* single AP/Mesh mode */
+
+		RTW_INFO(FUNC_ADPT_FMT" req: %d,%d,%d\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
+
+		if (req_ch <= REQ_CH_NONE) /* channel is not specified */
+			goto choose_chbw;
+
+		if (rtw_chset_search_ch(chset, dec_ch) < 0) {
+			RTW_WARN(FUNC_ADPT_FMT" ch:%u doesn't fit in chplan\n", FUNC_ADPT_ARG(adapter), dec_ch);
+			if (req_ch > 0) {
+				/* specific channel and not from IE => don't change channel setting */
+				*chbw_allow = _FALSE;
+				goto exit;
+			}
+			goto choose_chbw;
+		}
+
+		/* check temporary decision first */
+		rtw_adjust_chbw(adapter, dec_ch, &dec_bw, &dec_offset);
+		if (!rtw_get_offset_by_chbw(dec_ch, dec_bw, &dec_offset)
+			&& req_bw > REQ_BW_NONE
+		) {
+			RTW_WARN(FUNC_ADPT_FMT" req: %u,%u has no valid offset\n", FUNC_ADPT_ARG(adapter), dec_ch, dec_bw);
+			*chbw_allow = _FALSE;
+			goto exit;
+		}
+
+		while (!rtw_chset_is_chbw_valid(chset, dec_ch, dec_bw, dec_offset)
+			|| (rtw_odm_dfs_domain_unknown(adapter) && rtw_is_dfs_chbw(dec_ch, dec_bw, dec_offset))
+			|| rtw_chset_is_ch_non_ocp(chset, dec_ch, dec_bw, dec_offset)
+		) {
+			if (dec_bw > CHANNEL_WIDTH_20)
+				dec_bw--;
+			if (dec_bw == CHANNEL_WIDTH_20) {
+				dec_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+				break;
+			}
+		}
+
+		if (rtw_odm_dfs_domain_unknown(adapter) && rtw_is_dfs_chbw(dec_ch, dec_bw, dec_offset)) {
+			RTW_WARN(FUNC_ADPT_FMT" DFS channel %u can't be used\n", FUNC_ADPT_ARG(adapter), dec_ch);
+			if (req_ch > 0) {
+				/* specific channel and not from IE => don't change channel setting */
+				*chbw_allow = _FALSE;
+				goto exit;
+			}
+			goto choose_chbw;
+		}
+
+		if (rtw_chset_is_ch_non_ocp(chset, dec_ch, dec_bw, dec_offset) == _FALSE)
+			goto update_bss_chbw;
+		RTW_WARN(FUNC_ADPT_FMT" DFS channel %u under non ocp\n", FUNC_ADPT_ARG(adapter), dec_ch);
+
+choose_chbw:
+		req_ch = req_ch > 0 ? dec_ch : 0;
+		if (req_bw <= REQ_BW_NONE)
+			req_bw = cur_ie_bw;
+
+#if defined(CONFIG_DFS_MASTER)
+		if (!rtw_odm_dfs_domain_unknown(adapter)) {
+			if (rfctl->dbg_dfs_master_choose_dfs_ch_first) {
+				ch_avail = rtw_choose_shortest_waiting_ch(adapter, req_ch, req_bw
+							, &dec_ch, &dec_bw, &dec_offset
+							, RTW_CHF_2G | RTW_CHF_NON_DFS
+							, MLME_IS_ASOC(adapter) ? mlmeext->cur_channel : cur_ie_ch
+							, rfctl->ch_sel_same_band_prefer);
+				if (ch_avail == _TRUE) {
+					RTW_INFO(FUNC_ADPT_FMT" choose 5G DFS channel for debug\n", FUNC_ADPT_ARG(adapter));
+					goto update_bss_chbw;
+				}
+			}
+
+			if (rfctl->dfs_ch_sel_d_flags) {
+				ch_avail = rtw_choose_shortest_waiting_ch(adapter, req_ch, req_bw
+							, &dec_ch, &dec_bw, &dec_offset
+							, rfctl->dfs_ch_sel_d_flags
+							, MLME_IS_ASOC(adapter) ? mlmeext->cur_channel : cur_ie_ch
+							, rfctl->ch_sel_same_band_prefer);
+				if (ch_avail == _TRUE) {
+					RTW_INFO(FUNC_ADPT_FMT" choose with dfs_ch_sel_d_flags:0x%02x for debug\n"
+						, FUNC_ADPT_ARG(adapter), rfctl->dfs_ch_sel_d_flags);
+					goto update_bss_chbw;
+				}
+			}
+
+			ch_avail = rtw_choose_shortest_waiting_ch(adapter, req_ch, req_bw
+						, &dec_ch, &dec_bw, &dec_offset
+						, 0
+						, MLME_IS_ASOC(adapter) ? mlmeext->cur_channel : cur_ie_ch
+						, rfctl->ch_sel_same_band_prefer);
+			if (ch_avail == _FALSE) {
+				RTW_WARN(FUNC_ADPT_FMT" no available channel\n", FUNC_ADPT_ARG(adapter));
+				*chbw_allow = _FALSE;
+				goto exit;
+			}
+
+		} else
+#endif /* defined(CONFIG_DFS_MASTER) */
+		{
+			ch_avail = rtw_choose_shortest_waiting_ch(adapter, req_ch, req_bw
+						, &dec_ch, &dec_bw, &dec_offset
+						, RTW_CHF_DFS
+						, MLME_IS_ASOC(adapter) ? mlmeext->cur_channel : cur_ie_ch
+						, rfctl->ch_sel_same_band_prefer);
+			if (ch_avail == _FALSE) {
+				RTW_WARN(FUNC_ADPT_FMT" no available channel\n", FUNC_ADPT_ARG(adapter));
+				*chbw_allow = _FALSE;
+				goto exit;
+			}
+		}
+
+update_bss_chbw:
+		/* channel bw offset can be allowed for single AP, not need MCC */
+		*chbw_allow = _TRUE;
+		set_dec_ch = _TRUE;
+	}
+
+	if (rtw_mi_check_fwstate(adapter, _FW_UNDER_SURVEY)) {
+		/* scanning, leave ch setting to scan state machine */
+		set_u_ch = set_dec_ch = _FALSE;
+	}
+
+	/* ch setting differs from mlmeext.network IE */
+	if (cur_ie_ch != dec_ch
+		|| cur_ie_bw != dec_bw
+		|| cur_ie_offset != dec_offset)
+		changed = _TRUE;
+
+	/* ch setting differs from existing one */
+	if (check_fwstate(&adapter->mlmepriv, WIFI_ASOC_STATE)
+		&& (mlmeext->cur_channel != dec_ch
+			|| mlmeext->cur_bwmode != dec_bw
+			|| mlmeext->cur_ch_offset != dec_offset)
+	) {
+		if (rtw_linked_check(adapter) == _TRUE) {
+			#ifdef CONFIG_SPCT_CH_SWITCH
+			if (1)
+				rtw_ap_inform_ch_switch(adapter, dec_ch, dec_offset);
+			else
+			#endif
+				rtw_sta_flush(adapter, _FALSE);
+		}
+	}
+
+	mlmeext->cur_channel = dec_ch;
+	mlmeext->cur_bwmode = dec_bw;
+	mlmeext->cur_ch_offset = dec_offset;
+
+	rtw_ap_update_bss_chbw(adapter, network, dec_ch, dec_bw, dec_offset);
+
+	if (u_ch != 0)
+		RTW_INFO(FUNC_ADPT_FMT" union: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
+
+	RTW_INFO(FUNC_ADPT_FMT" dec: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), dec_ch, dec_bw, dec_offset);
+
+	if (set_u_ch == _TRUE) {
+		*ch = u_ch;
+		*bw = u_bw;
+		*offset = u_offset;
+	} else if (set_dec_ch == _TRUE) {
+		*ch = dec_ch;
+		*bw = dec_bw;
+		*offset = dec_offset;
+	}
+exit:
+	return changed;
+}
+
+u8 rtw_ap_sta_linking_state_check(_adapter *adapter)
+{
+	struct sta_info *psta;
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	int i;
+	_list *plist, *phead;
+	_irqL irqL;
+	u8 rst = _FALSE;
+
+	if (!MLME_IS_AP(adapter) && !MLME_IS_MESH(adapter))
+		return _FALSE;
+
+	if (pstapriv->auth_list_cnt !=0)
+		return _TRUE;
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+		if (!(psta->state &_FW_LINKED)) {
+			rst = _TRUE;
+			break;
+		}
+	}
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	return rst;
+}
+
+/*#define DBG_SWTIMER_BASED_TXBCN*/
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+void tx_beacon_handlder(struct dvobj_priv *pdvobj)
+{
+#define BEACON_EARLY_TIME		20	/* unit:TU*/
+	_irqL irqL;
+	_list	*plist, *phead;
+	u32 timestamp[2];
+	u32 bcn_interval_us; /* unit : usec */
+	u64 time;
+	u32 cur_tick, time_offset; /* unit : usec */
+	u32 inter_bcn_space_us; /* unit : usec */
+	u32 txbcn_timer_ms; /* unit : ms */
+	int nr_vap, idx, bcn_idx;
+	int i;
+	u8 val8, late = 0;
+	_adapter *padapter = NULL;
+
+	i = 0;
+
+	/* get first ap mode interface */
+	_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+	if (rtw_is_list_empty(&pdvobj->ap_if_q.queue) || (pdvobj->nr_ap_if == 0)) {
+		RTW_INFO("[%s] ERROR: ap_if_q is empty!or nr_ap = %d\n", __func__, pdvobj->nr_ap_if);
+		_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+		return;
+	} else
+		padapter = LIST_CONTAINOR(get_next(&(pdvobj->ap_if_q.queue)), struct _ADAPTER, list);
+	_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+
+	if (NULL == padapter) {
+		RTW_INFO("[%s] ERROR: no any ap interface!\n", __func__);
+		return;
+	}
+
+
+	bcn_interval_us = DEFAULT_BCN_INTERVAL * NET80211_TU_TO_US;
+	if (0 == bcn_interval_us) {
+		RTW_INFO("[%s] ERROR: beacon interval = 0\n", __func__);
+		return;
+	}
+
+	/* read TSF */
+	timestamp[1] = rtw_read32(padapter, 0x560 + 4);
+	timestamp[0] = rtw_read32(padapter, 0x560);
+	while (timestamp[1]) {
+		time = (0xFFFFFFFF % bcn_interval_us + 1) * timestamp[1] + timestamp[0];
+		timestamp[0] = (u32)time;
+		timestamp[1] = (u32)(time >> 32);
+	}
+	cur_tick = timestamp[0] % bcn_interval_us;
+
+
+	_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+
+	nr_vap = (pdvobj->nr_ap_if - 1);
+	if (nr_vap > 0) {
+		inter_bcn_space_us = pdvobj->inter_bcn_space * NET80211_TU_TO_US; /* beacon_interval / (nr_vap+1); */
+		idx = cur_tick / inter_bcn_space_us;
+		if (idx < nr_vap)	/* if (idx < (nr_vap+1))*/
+			bcn_idx = idx + 1;	/* bcn_idx = (idx + 1) % (nr_vap+1);*/
+		else
+			bcn_idx = 0;
+
+		/* to get padapter based on bcn_idx */
+		padapter = NULL;
+		phead = get_list_head(&pdvobj->ap_if_q);
+		plist = get_next(phead);
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			padapter = LIST_CONTAINOR(plist, struct _ADAPTER, list);
+
+			plist = get_next(plist);
+
+			if (i == bcn_idx)
+				break;
+
+			i++;
+		}
+		if ((NULL == padapter) || (i > pdvobj->nr_ap_if)) {
+			RTW_INFO("[%s] ERROR: nr_ap_if = %d, padapter=%p, bcn_idx=%d, index=%d\n",
+				__func__, pdvobj->nr_ap_if, padapter, bcn_idx, i);
+			_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+			return;
+		}
+#ifdef DBG_SWTIMER_BASED_TXBCN
+		RTW_INFO("BCN_IDX=%d, cur_tick=%d, padapter=%p\n", bcn_idx, cur_tick, padapter);
+#endif
+		if (((idx + 2 == nr_vap + 1) && (idx < nr_vap + 1)) || (0 == bcn_idx)) {
+			time_offset = bcn_interval_us - cur_tick - BEACON_EARLY_TIME * NET80211_TU_TO_US;
+			if ((s32)time_offset < 0)
+				time_offset += inter_bcn_space_us;
+
+		} else {
+			time_offset = (idx + 2) * inter_bcn_space_us - cur_tick - BEACON_EARLY_TIME * NET80211_TU_TO_US;
+			if (time_offset > (inter_bcn_space_us + (inter_bcn_space_us >> 1))) {
+				time_offset -= inter_bcn_space_us;
+				late = 1;
+			}
+		}
+	} else
+		/*#endif*/ { /* MBSSID */
+		time_offset = 2 * bcn_interval_us - cur_tick - BEACON_EARLY_TIME * NET80211_TU_TO_US;
+		if (time_offset > (bcn_interval_us + (bcn_interval_us >> 1))) {
+			time_offset -= bcn_interval_us;
+			late = 1;
+		}
+	}
+	_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+
+#ifdef DBG_SWTIMER_BASED_TXBCN
+	RTW_INFO("set sw bcn timer %d us\n", time_offset);
+#endif
+	txbcn_timer_ms = time_offset / NET80211_TU_TO_US;
+	_set_timer(&pdvobj->txbcn_timer, txbcn_timer_ms);
+
+	if (padapter) {
+#ifdef CONFIG_BCN_RECOVERY
+		rtw_ap_bcn_recovery(padapter);
+#endif /*CONFIG_BCN_RECOVERY*/
+
+#ifdef CONFIG_BCN_XMIT_PROTECT
+		rtw_ap_bcn_queue_empty_check(padapter, txbcn_timer_ms);
+#endif /*CONFIG_BCN_XMIT_PROTECT*/
+
+#ifdef DBG_SWTIMER_BASED_TXBCN
+		RTW_INFO("padapter=%p, PORT=%d\n", padapter, padapter->hw_port);
+#endif
+		/* bypass TX BCN queue if op ch is switching/waiting */
+		if (!check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
+			&& !IS_CH_WAITING(adapter_to_rfctl(padapter))
+		) {
+			/*update_beacon(padapter, _TIM_IE_, NULL, _FALSE);*/
+			/*issue_beacon(padapter, 0);*/
+			send_beacon(padapter);
+		}
+	}
+
+#if 0
+	/* handle any buffered BC/MC frames*/
+	/* Don't dynamically change DIS_ATIM due to HW will auto send ACQ after HIQ empty.*/
+	val8 = *((unsigned char *)priv->beaconbuf + priv->timoffset + 4);
+	if (val8 & 0x01) {
+		process_mcast_dzqueue(priv);
+		priv->pkt_in_dtimQ = 0;
+	}
+#endif
+
+}
+
+void tx_beacon_timer_handlder(void *ctx)
+{
+	struct dvobj_priv *pdvobj = (struct dvobj_priv *)ctx;
+	_adapter *padapter = pdvobj->padapters[0];
+
+	if (padapter)
+		set_tx_beacon_cmd(padapter);
+}
+#endif
+
+void rtw_ap_parse_sta_capability(_adapter *adapter, struct sta_info *sta, u8 *cap)
+{
+	sta->capability = RTW_GET_LE16(cap);
+	if (sta->capability & WLAN_CAPABILITY_SHORT_PREAMBLE)
+		sta->flags |= WLAN_STA_SHORT_PREAMBLE;
+	else
+		sta->flags &= ~WLAN_STA_SHORT_PREAMBLE;
+}
+
+u16 rtw_ap_parse_sta_supported_rates(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len)
+{
+	u8 rate_set[16];
+	u8 rate_num;
+	int i;
+	u16 status = _STATS_SUCCESSFUL_;
+
+	rtw_ies_get_supported_rate(tlv_ies, tlv_ies_len, rate_set, &rate_num);
+	if (rate_num == 0) {
+		RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" with no supported rate\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		status = _STATS_FAILURE_;
+		goto exit;
+	}
+
+	_rtw_memcpy(sta->bssrateset, rate_set, rate_num);
+	sta->bssratelen = rate_num;
+
+	if (MLME_IS_AP(adapter)) {
+		/* this function force only CCK rates to be bassic rate... */
+		UpdateBrateTblForSoftAP(sta->bssrateset, sta->bssratelen);
+	}
+
+	/* if (hapd->iface->current_mode->mode == HOSTAPD_MODE_IEEE80211G) */ /* ? */
+	sta->flags |= WLAN_STA_NONERP;
+	for (i = 0; i < sta->bssratelen; i++) {
+		if ((sta->bssrateset[i] & 0x7f) > 22) {
+			sta->flags &= ~WLAN_STA_NONERP;
+			break;
+		}
+	}
+
+exit:
+	return status;
+}
+
+u16 rtw_ap_parse_sta_security_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems)
+{
+	struct security_priv *sec = &adapter->securitypriv;
+	u8 *wpa_ie;
+	int wpa_ie_len;
+	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
+	u16 status = _STATS_SUCCESSFUL_;
+
+	sta->dot8021xalg = 0;
+	sta->wpa_psk = 0;
+	sta->wpa_group_cipher = 0;
+	sta->wpa2_group_cipher = 0;
+	sta->wpa_pairwise_cipher = 0;
+	sta->wpa2_pairwise_cipher = 0;
+	_rtw_memset(sta->wpa_ie, 0, sizeof(sta->wpa_ie));
+
+	if ((sec->wpa_psk & BIT(1)) && elems->rsn_ie) {
+		wpa_ie = elems->rsn_ie;
+		wpa_ie_len = elems->rsn_ie_len;
+
+		if (rtw_parse_wpa2_ie(wpa_ie - 2, wpa_ie_len + 2, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
+			sta->dot8021xalg = 1;/* psk, todo:802.1x */
+			sta->wpa_psk |= BIT(1);
+
+			sta->wpa2_group_cipher = group_cipher & sec->wpa2_group_cipher;
+			sta->wpa2_pairwise_cipher = pairwise_cipher & sec->wpa2_pairwise_cipher;
+
+			if (!sta->wpa2_group_cipher)
+				status = WLAN_STATUS_GROUP_CIPHER_NOT_VALID;
+
+			if (!sta->wpa2_pairwise_cipher)
+				status = WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID;
+		} else
+			status = WLAN_STATUS_INVALID_IE;
+
+	}
+	else if ((sec->wpa_psk & BIT(0)) && elems->wpa_ie) {
+		wpa_ie = elems->wpa_ie;
+		wpa_ie_len = elems->wpa_ie_len;
+
+		if (rtw_parse_wpa_ie(wpa_ie - 2, wpa_ie_len + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+			sta->dot8021xalg = 1;/* psk, todo:802.1x */
+			sta->wpa_psk |= BIT(0);
+
+			sta->wpa_group_cipher = group_cipher & sec->wpa_group_cipher;
+			sta->wpa_pairwise_cipher = pairwise_cipher & sec->wpa_pairwise_cipher;
+
+			if (!sta->wpa_group_cipher)
+				status = WLAN_STATUS_GROUP_CIPHER_NOT_VALID;
+
+			if (!sta->wpa_pairwise_cipher)
+				status = WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID;
+		} else
+			status = WLAN_STATUS_INVALID_IE;
+
+	} else {
+		wpa_ie = NULL;
+		wpa_ie_len = 0;
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		/* MFP is mandatory for secure mesh */
+		if (adapter->mesh_info.mesh_auth_id)
+			sta->flags |= WLAN_STA_MFP;
+	} else
+#endif
+	if ((sec->mfp_opt == MFP_REQUIRED && mfp_opt == MFP_NO) || mfp_opt == MFP_INVALID) 
+		status = WLAN_STATUS_ROBUST_MGMT_FRAME_POLICY_VIOLATION;
+	else if (sec->mfp_opt >= MFP_OPTIONAL && mfp_opt >= MFP_OPTIONAL)
+		sta->flags |= WLAN_STA_MFP;
+
+	if (status != _STATS_SUCCESSFUL_)
+		goto exit;
+
+	if (!MLME_IS_AP(adapter))
+		goto exit;
+
+	sta->flags &= ~(WLAN_STA_WPS | WLAN_STA_MAYBE_WPS);
+	/* if (hapd->conf->wps_state && wpa_ie == NULL) { */ /* todo: to check ap if supporting WPS */
+	if (wpa_ie == NULL) {
+		if (elems->wps_ie) {
+			RTW_INFO("STA included WPS IE in "
+				 "(Re)Association Request - assume WPS is "
+				 "used\n");
+			sta->flags |= WLAN_STA_WPS;
+			/* wpabuf_free(sta->wps_ie); */
+			/* sta->wps_ie = wpabuf_alloc_copy(elems.wps_ie + 4, */
+			/*				elems.wps_ie_len - 4); */
+		} else {
+			RTW_INFO("STA did not include WPA/RSN IE "
+				 "in (Re)Association Request - possible WPS "
+				 "use\n");
+			sta->flags |= WLAN_STA_MAYBE_WPS;
+		}
+
+		/* AP support WPA/RSN, and sta is going to do WPS, but AP is not ready */
+		/* that the selected registrar of AP is _FLASE */
+		if ((sec->wpa_psk > 0)
+			&& (sta->flags & (WLAN_STA_WPS | WLAN_STA_MAYBE_WPS))
+		) {
+			struct mlme_priv *mlme = &adapter->mlmepriv;
+
+			if (mlme->wps_beacon_ie) {
+				u8 selected_registrar = 0;
+
+				rtw_get_wps_attr_content(mlme->wps_beacon_ie, mlme->wps_beacon_ie_len, WPS_ATTR_SELECTED_REGISTRAR, &selected_registrar, NULL);
+
+				if (!selected_registrar) {
+					RTW_INFO("selected_registrar is _FALSE , or AP is not ready to do WPS\n");
+					status = _STATS_UNABLE_HANDLE_STA_;
+					goto exit;
+				}
+			}
+		}
+
+	} else {
+		int copy_len;
+
+		if (sec->wpa_psk == 0) {
+			RTW_INFO("STA " MAC_FMT
+				": WPA/RSN IE in association request, but AP don't support WPA/RSN\n",
+				MAC_ARG(sta->cmn.mac_addr));
+			status = WLAN_STATUS_INVALID_IE;
+			goto exit;
+		}
+
+		if (elems->wps_ie) {
+			RTW_INFO("STA included WPS IE in "
+				 "(Re)Association Request - WPS is "
+				 "used\n");
+			sta->flags |= WLAN_STA_WPS;
+			copy_len = 0;
+		} else
+			copy_len = ((wpa_ie_len + 2) > sizeof(sta->wpa_ie)) ? (sizeof(sta->wpa_ie)) : (wpa_ie_len + 2);
+
+		if (copy_len > 0)
+			_rtw_memcpy(sta->wpa_ie, wpa_ie - 2, copy_len);
+	}
+
+exit:
+	return status;
+}
+
+void rtw_ap_parse_sta_wmm_ie(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len)
+{
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	unsigned char WMM_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01};
+	u8 *p;
+
+	sta->flags &= ~WLAN_STA_WME;
+	sta->qos_option = 0;
+	sta->qos_info = 0;
+	sta->has_legacy_ac = _TRUE;
+	sta->uapsd_vo = 0;
+	sta->uapsd_vi = 0;
+	sta->uapsd_be = 0;
+	sta->uapsd_bk = 0;
+
+	if (!mlme->qospriv.qos_option)
+		goto exit;
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		/* QoS is mandatory in mesh */
+		sta->flags |= WLAN_STA_WME;
+	}
+#endif
+
+	p = rtw_get_ie_ex(tlv_ies, tlv_ies_len, WLAN_EID_VENDOR_SPECIFIC, WMM_IE, 6, NULL, NULL);
+	if (!p)
+		goto exit;
+
+	sta->flags |= WLAN_STA_WME;
+	sta->qos_option = 1;
+	sta->qos_info = *(p + 8);
+	sta->max_sp_len = (sta->qos_info >> 5) & 0x3;
+
+	if ((sta->qos_info & 0xf) != 0xf)
+		sta->has_legacy_ac = _TRUE;
+	else
+		sta->has_legacy_ac = _FALSE;
+
+	if (sta->qos_info & 0xf) {
+		if (sta->qos_info & BIT(0))
+			sta->uapsd_vo = BIT(0) | BIT(1);
+		else
+			sta->uapsd_vo = 0;
+
+		if (sta->qos_info & BIT(1))
+			sta->uapsd_vi = BIT(0) | BIT(1);
+		else
+			sta->uapsd_vi = 0;
+
+		if (sta->qos_info & BIT(2))
+			sta->uapsd_bk = BIT(0) | BIT(1);
+		else
+			sta->uapsd_bk = 0;
+
+		if (sta->qos_info & BIT(3))
+			sta->uapsd_be = BIT(0) | BIT(1);
+		else
+			sta->uapsd_be = 0;
+	}
+
+exit:
+	return;
+}
+
+void rtw_ap_parse_sta_ht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems)
+{
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+
+	sta->flags &= ~WLAN_STA_HT;
+
+#ifdef CONFIG_80211N_HT
+	if (mlme->htpriv.ht_option == _FALSE)
+		goto exit;
+
+	/* save HT capabilities in the sta object */
+	_rtw_memset(&sta->htpriv.ht_cap, 0, sizeof(struct rtw_ieee80211_ht_cap));
+	if (elems->ht_capabilities && elems->ht_capabilities_len >= sizeof(struct rtw_ieee80211_ht_cap)) {
+		sta->flags |= WLAN_STA_HT;
+		sta->flags |= WLAN_STA_WME;
+		_rtw_memcpy(&sta->htpriv.ht_cap, elems->ht_capabilities, sizeof(struct rtw_ieee80211_ht_cap));
+
+		if (elems->ht_operation && elems->ht_operation_len == HT_OP_IE_LEN) {
+			_rtw_memcpy(sta->htpriv.ht_op, elems->ht_operation, HT_OP_IE_LEN);
+			sta->htpriv.op_present = 1;
+		}
+	}
+exit:
+#endif
+
+	return;
+}
+
+void rtw_ap_parse_sta_vht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems)
+{
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+
+	sta->flags &= ~WLAN_STA_VHT;
+
+#ifdef CONFIG_80211AC_VHT
+	if (mlme->vhtpriv.vht_option == _FALSE)
+		goto exit;
+
+	_rtw_memset(&sta->vhtpriv, 0, sizeof(struct vht_priv));
+	if (elems->vht_capabilities && elems->vht_capabilities_len == VHT_CAP_IE_LEN) {
+		sta->flags |= WLAN_STA_VHT;
+		_rtw_memcpy(sta->vhtpriv.vht_cap, elems->vht_capabilities, VHT_CAP_IE_LEN);
+
+		if (elems->vht_operation && elems->vht_operation_len== VHT_OP_IE_LEN) {
+			_rtw_memcpy(sta->vhtpriv.vht_op, elems->vht_operation, VHT_OP_IE_LEN);
+			sta->vhtpriv.op_present = 1;
+		}
+
+		if (elems->vht_op_mode_notify && elems->vht_op_mode_notify_len == 1) {
+			_rtw_memcpy(&sta->vhtpriv.vht_op_mode_notify, elems->vht_op_mode_notify, 1);
+			sta->vhtpriv.notify_present = 1;
+		}
+	}
+exit:
+#endif
+
+	return;
+}
+#endif /* CONFIG_AP_MODE */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_beamforming.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_beamforming.c
index 0b52972ff2e8..447be2c7db21 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_beamforming.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_beamforming.c
@@ -1,1244 +1,3156 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#define _RTW_BEAMFORMING_C_
-
-#include <drv_types.h>
-#include <hal_data.h>
-
-#ifdef CONFIG_BEAMFORMING
-
-#if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
-struct beamforming_entry	*beamforming_get_entry_by_addr(struct mlme_priv *pmlmepriv, u8* ra,u8* idx)
-{
-	u8	i = 0;
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-	
-	for(i = 0; i < BEAMFORMING_ENTRY_NUM; i++)
-	{
-		if(	pBeamInfo->beamforming_entry[i].bUsed && 
-			(_rtw_memcmp(ra,pBeamInfo->beamforming_entry[i].mac_addr, ETH_ALEN)))
-		{
-			*idx = i;
-			return &(pBeamInfo->beamforming_entry[i]);
-		}
-	}
-
-	return NULL;
-}
-
-BEAMFORMING_CAP beamforming_get_entry_beam_cap_by_mac_id(PVOID pmlmepriv ,u8 mac_id)
-{
-	u8	i = 0;
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO((struct mlme_priv *)pmlmepriv);
-	BEAMFORMING_CAP		BeamformEntryCap = BEAMFORMING_CAP_NONE;
-	
-	for(i = 0; i < BEAMFORMING_ENTRY_NUM; i++)
-	{
-		if(	pBeamInfo->beamforming_entry[i].bUsed && 
-			(mac_id == pBeamInfo->beamforming_entry[i].mac_id))
-		{
-			BeamformEntryCap =  pBeamInfo->beamforming_entry[i].beamforming_entry_cap;
-			i = BEAMFORMING_ENTRY_NUM;
-		}
-	}
-
-	return BeamformEntryCap;
-}
-
-struct beamforming_entry	*beamforming_get_free_entry(struct mlme_priv *pmlmepriv, u8* idx)
-{
-	u8	i = 0;
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-
-	for(i = 0; i < BEAMFORMING_ENTRY_NUM; i++)
-	{
-		if(pBeamInfo->beamforming_entry[i].bUsed == _FALSE)
-		{
-			*idx = i;
-			return &(pBeamInfo->beamforming_entry[i]);
-		}	
-	}
-	return NULL;
-}
-
-
-struct beamforming_entry	*beamforming_add_entry(PADAPTER adapter, u8* ra, u16 aid,
-	u16 mac_id, CHANNEL_WIDTH bw, BEAMFORMING_CAP beamfrom_cap, u8* idx)
-{
-	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
-	struct beamforming_entry	*pEntry = beamforming_get_free_entry(pmlmepriv, idx);
-
-	if(pEntry != NULL)
-	{	
-		pEntry->bUsed = _TRUE;
-		pEntry->aid = aid;
-		pEntry->mac_id = mac_id;
-		pEntry->sound_bw = bw;
-		if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-		{
-			u16	BSSID = ((*(adapter_mac_addr(adapter) + 5) & 0xf0) >> 4) ^ 
-				(*(adapter_mac_addr(adapter) + 5) & 0xf); /* BSSID[44:47] xor BSSID[40:43] */
-			pEntry->p_aid = (aid + BSSID * 32) & 0x1ff;		// (dec(A) + dec(B)*32) mod 512
-			pEntry->g_id = 63;
-		}		
-		else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))
-		{
-			pEntry->p_aid = 0;
-			pEntry->g_id = 63;
-		}
-		else
-		{
-			pEntry->p_aid =  ra[5];						// BSSID[39:47]
-			pEntry->p_aid = (pEntry->p_aid << 1) | (ra[4] >> 7 );
-			pEntry->g_id = 0;
-		}
-		_rtw_memcpy(pEntry->mac_addr, ra, ETH_ALEN);
-		pEntry->bSound = _FALSE;
-
-		//3 TODO SW/FW sound period
-		pEntry->sound_period = 200;
-		pEntry->beamforming_entry_cap = beamfrom_cap;
-		pEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-
-
-		pEntry->PreLogSeq = 0;	/*Modified by Jeffery @2015-04-13*/
-		pEntry->LogSeq = 0;		/*Modified by Jeffery @2014-10-29*/
-		pEntry->LogRetryCnt = 0;	/*Modified by Jeffery @2014-10-29*/
-		pEntry->LogSuccess = 0;	/*LogSuccess is NOT needed to be accumulated, so  LogSuccessCnt->LogSuccess, 2015-04-13, Jeffery*/
-		pEntry->ClockResetTimes = 0;	/*Modified by Jeffery @2015-04-13*/
-		pEntry->LogStatusFailCnt = 0;
-
-		return pEntry;
-	}
-	else
-		return NULL;
-}
-
-BOOLEAN	beamforming_remove_entry(struct mlme_priv *pmlmepriv, u8* ra, u8* idx)
-{
-	struct beamforming_entry	*pEntry = beamforming_get_entry_by_addr(pmlmepriv, ra, idx);
-
-	if(pEntry != NULL)
-	{	
-		pEntry->bUsed = _FALSE;
-		pEntry->beamforming_entry_cap = BEAMFORMING_CAP_NONE;
-		pEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-		return _TRUE;
-	}
-	else
-		return _FALSE;
-}
-
-/* Used for BeamformingStart_V1  */
-void	beamforming_dym_ndpa_rate(PADAPTER adapter)
-{
-	u16	NDPARate = MGN_6M;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
-	
-	if(pHalData->MinUndecoratedPWDBForDM > 30) // link RSSI > 30%
-		NDPARate = MGN_24M;
-	else
-		NDPARate = MGN_6M;
-
-	//BW = CHANNEL_WIDTH_20;
-	NDPARate = NDPARate << 8;
-	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_RATE, (u8 *)&NDPARate);
-}
-
-void beamforming_dym_period(PADAPTER Adapter)
-{
-	u8	Idx;
-	BOOLEAN	bChangePeriod = _FALSE;
-	u16	SoundPeriod_SW, SoundPeriod_FW;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(Adapter);
-	struct beamforming_entry	*pBeamformEntry;
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(( &Adapter->mlmepriv));
-	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
-	
-	//3 TODO  per-client throughput caculation.
-
-	if(pdvobjpriv->traffic_stat.cur_tx_tp + pdvobjpriv->traffic_stat.cur_rx_tp > 2)
-	{
-		SoundPeriod_SW = 32*20;
-		SoundPeriod_FW = 2;
-	}	
-	else
-	{
-		SoundPeriod_SW = 32*2000;
-		SoundPeriod_FW = 200;
-	}	
-
-	for(Idx = 0; Idx < BEAMFORMING_ENTRY_NUM; Idx++)
-	{
-		pBeamformEntry = pBeamInfo->beamforming_entry+Idx;
-		if(pBeamformEntry->bDefaultCSI)
-		{
-			SoundPeriod_SW = 32*2000;
-			SoundPeriod_FW = 200;
-		}
-
-		if(pBeamformEntry->beamforming_entry_cap & (BEAMFORMER_CAP_HT_EXPLICIT |BEAMFORMER_CAP_VHT_SU))
-		{
-			if(pSoundInfo->sound_mode == SOUNDING_FW_VHT_TIMER || pSoundInfo->sound_mode == SOUNDING_FW_HT_TIMER)
-			{				
-				if(pBeamformEntry->sound_period != SoundPeriod_FW)
-				{
-					pBeamformEntry->sound_period = SoundPeriod_FW;
-					bChangePeriod = _TRUE;	// Only FW sounding need to send H2C packet to change sound period. 
-				}
-			}
-			else if(pBeamformEntry->sound_period != SoundPeriod_SW)
-			{
-				pBeamformEntry->sound_period = SoundPeriod_SW;
-			}
-		}
-	}
-
-	if(bChangePeriod)
-		rtw_hal_set_hwreg(Adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&Idx);
-}
-
-BOOLEAN	issue_ht_sw_ndpa_packet(PADAPTER Adapter, u8 *ra, CHANNEL_WIDTH bw, u8 qidx)
-{
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8	ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	u8	aSifsTime = 0;
-	u8	NDPTxRate = 0;
-
-	DBG_871X("%s: issue_ht_sw_ndpa_packet!\n", __func__);
-
-	NDPTxRate = MGN_MCS8;
-	DBG_871X("%s: NDPTxRate =%d\n", __func__, NDPTxRate);
-	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-	
-	if (pmgntframe == NULL)
-		return _FALSE;
-
-	/*update attribute*/
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(Adapter, pattrib);
-	pattrib->qsel = QSLT_MGNT;
-	pattrib->rate = NDPTxRate;
-	pattrib->bwmode = bw;
-	pattrib->order = 1;
-	pattrib->subtype = WIFI_ACTION_NOACK;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetOrderBit(pframe);
-	SetFrameSubType(pframe, WIFI_ACTION_NOACK);
-
-	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
-		aSifsTime = 10;
-	else
-		aSifsTime = 16;
-
-	duration = 2*aSifsTime + 40;
-	
-	if (bw == CHANNEL_WIDTH_40)
-		duration += 87;
-	else	
-		duration += 180;
-
-	SetDuration(pframe, duration);
-
-	/*HT control field*/
-	SET_HT_CTRL_CSI_STEERING(pframe+24, 3);
-	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe+24, 1);
-
-	_rtw_memcpy(pframe+28, ActionHdr, 4);
-
-	pattrib->pktlen = 32;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-
-	return _TRUE;
-
-
-}
-BOOLEAN	issue_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, CHANNEL_WIDTH bw, u8 qidx)
-{
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8	ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	u8	aSifsTime = 0;
-
-	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-
-	if (pmgntframe == NULL)
-		return _FALSE;
-
-	/*update attribute*/
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(Adapter, pattrib);
-
-	if (qidx == BCN_QUEUE_INX)
-		pattrib->qsel = QSLT_BEACON;
-	pattrib->rate = MGN_MCS8;
-	pattrib->bwmode = bw;
-	pattrib->order = 1;
-	pattrib->subtype = WIFI_ACTION_NOACK;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr*)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetOrderBit(pframe);
-	SetFrameSubType(pframe, WIFI_ACTION_NOACK);
-
-	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	if( pmlmeext->cur_wireless_mode == WIRELESS_11B)
-		aSifsTime = 10;
-	else
-		aSifsTime = 16;
-
-	duration = 2*aSifsTime + 40;
-	
-	if(bw == CHANNEL_WIDTH_40)
-		duration+= 87;
-	else	
-		duration+= 180;
-
-	SetDuration(pframe, duration);
-
-	//HT control field
-	SET_HT_CTRL_CSI_STEERING(pframe+24, 3);
-	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe+24, 1);
-
-	_rtw_memcpy(pframe+28, ActionHdr, 4);
-
-	pattrib->pktlen = 32;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-
-	return _TRUE;
-}
-
-BOOLEAN	beamforming_send_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, CHANNEL_WIDTH bw, u8 qidx)
-{
-	return issue_ht_ndpa_packet(Adapter, ra, bw, qidx);
-}
-BOOLEAN	issue_vht_sw_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, CHANNEL_WIDTH bw, u8 qidx)
-{
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv		*pmlmepriv = &(Adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-	struct rtw_ndpa_sta_info	sta_info;
-	u8		 NDPTxRate = 0;
-	
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	u8	sequence = 0, aSifsTime = 0;
-
-	DBG_871X("%s: issue_vht_sw_ndpa_packet!\n", __func__);
-
-	
-	NDPTxRate = MGN_VHT2SS_MCS0;
-	DBG_871X("%s: NDPTxRate =%d\n", __func__, NDPTxRate);
-	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-
-	if (pmgntframe == NULL) {
-		DBG_871X("%s, alloc mgnt frame fail\n", __func__);
-		return _FALSE;
-	}
-
-	/*update attribute*/
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(Adapter, pattrib);
-	pattrib->qsel = QSLT_MGNT;
-	pattrib->rate = NDPTxRate;
-	pattrib->bwmode = bw;
-	pattrib->subtype = WIFI_NDPA;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetFrameSubType(pframe, WIFI_NDPA);
-
-	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
-
-	if (IsSupported5G(pmlmeext->cur_wireless_mode) || IsSupportedHT(pmlmeext->cur_wireless_mode))
-		aSifsTime = 16;
-	else
-		aSifsTime = 10;
-
-	duration = 2*aSifsTime + 44;
-	
-	if (bw == CHANNEL_WIDTH_80)
-		duration += 40;
-	else if (bw == CHANNEL_WIDTH_40)
-		duration += 87;
-	else	
-		duration += 180;
-
-	SetDuration(pframe, duration);
-	
-	sequence = pBeamInfo->sounding_sequence << 2;
-	if (pBeamInfo->sounding_sequence >= 0x3f)
-		pBeamInfo->sounding_sequence = 0;
-	else
-		pBeamInfo->sounding_sequence++;
-
-	_rtw_memcpy(pframe+16, &sequence, 1);
-	if (((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE))
-		aid = 0;		
-
-	sta_info.aid = aid;
-	sta_info.feedback_type = 0;
-	sta_info.nc_index = 0;
-	
-	_rtw_memcpy(pframe+17, (u8 *)&sta_info, 2);
-
-	pattrib->pktlen = 19;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-	
-
-	return _TRUE;
-
-}
-BOOLEAN	issue_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, CHANNEL_WIDTH bw, u8 qidx)
-{
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv		*pmlmepriv = &(Adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-	struct rtw_ndpa_sta_info	sta_info;
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	u8	sequence = 0, aSifsTime = 0;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		return _FALSE;
-
-	/*update attribute*/
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(Adapter, pattrib);
-
-	if (qidx == BCN_QUEUE_INX)
-		pattrib->qsel = QSLT_BEACON;
-	pattrib->rate = MGN_VHT2SS_MCS0;
-	pattrib->bwmode = bw;
-	pattrib->subtype = WIFI_NDPA;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr*)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetFrameSubType(pframe, WIFI_NDPA);
-
-	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
-
-	if (IsSupported5G(pmlmeext->cur_wireless_mode) || IsSupportedHT(pmlmeext->cur_wireless_mode))
-		aSifsTime = 16;
-	else
-		aSifsTime = 10;
-
-	duration = 2*aSifsTime + 44;
-	
-	if(bw == CHANNEL_WIDTH_80)
-		duration += 40;
-	else if(bw == CHANNEL_WIDTH_40)
-		duration+= 87;
-	else	
-		duration+= 180;
-
-	SetDuration(pframe, duration);
-
-	sequence = pBeamInfo->sounding_sequence<< 2;
-	if (pBeamInfo->sounding_sequence >= 0x3f)
-		pBeamInfo->sounding_sequence = 0;
-	else
-		pBeamInfo->sounding_sequence++;
-
-	_rtw_memcpy(pframe+16, &sequence,1);
-
-	if(((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE))
-		aid = 0;		
-
-	sta_info.aid = aid;
-	sta_info.feedback_type = 0;
-	sta_info.nc_index= 0;
-	
-	_rtw_memcpy(pframe+17, (u8 *)&sta_info, 2);
-
-	pattrib->pktlen = 19;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-
-	return _TRUE;
-}
-
-BOOLEAN	beamforming_send_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, CHANNEL_WIDTH bw, u8 qidx)
-{
-	return issue_vht_ndpa_packet(Adapter, ra, aid, bw, qidx);
-}
-
-BOOLEAN	beamfomring_bSounding(struct beamforming_info *pBeamInfo)
-{
-	BOOLEAN		bSounding = _FALSE;
-
-	if(( beamforming_get_beamform_cap(pBeamInfo) & BEAMFORMER_CAP) == 0)
-		bSounding = _FALSE;
-	else 
-		bSounding = _TRUE;
-
-	return bSounding;
-}
-
-u8	beamforming_sounding_idx(struct beamforming_info *pBeamInfo)
-{
-	u8	idx = 0;
-	u8	i;
-
-	for(i = 0; i < BEAMFORMING_ENTRY_NUM; i++)
-	{
-		if (pBeamInfo->beamforming_entry[i].bUsed &&
-			(_FALSE == pBeamInfo->beamforming_entry[i].bSound))
-		{
-			idx = i;
-			break;
-		}
-	}
-
-	return idx;
-}
-
-SOUNDING_MODE	beamforming_sounding_mode(struct beamforming_info *pBeamInfo, u8 idx)
-{
-	struct beamforming_entry	BeamEntry = pBeamInfo->beamforming_entry[idx];
-	SOUNDING_MODE	mode;
-
-	if(BeamEntry.beamforming_entry_cap & BEAMFORMER_CAP_VHT_SU)
-	{
-		mode = SOUNDING_FW_VHT_TIMER;
-	}
-	else if(BeamEntry.beamforming_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
-	{
-		mode = SOUNDING_FW_HT_TIMER;
-	}
-	else
-	{
-		mode = SOUNDING_STOP_All_TIMER;
-	}
-
-	return mode;
-}
-
-u16	beamforming_sounding_time(struct beamforming_info *pBeamInfo, SOUNDING_MODE mode, u8 idx)
-{
-	u16						sounding_time = 0xffff;
-	struct beamforming_entry	BeamEntry = pBeamInfo->beamforming_entry[idx];
-
-	sounding_time = BeamEntry.sound_period;
-
-	return sounding_time;
-}
-
-CHANNEL_WIDTH	beamforming_sounding_bw(struct beamforming_info *pBeamInfo, SOUNDING_MODE mode, u8 idx)
-{
-	CHANNEL_WIDTH				sounding_bw = CHANNEL_WIDTH_20;
-	struct beamforming_entry		BeamEntry = pBeamInfo->beamforming_entry[idx];
-
-	sounding_bw = BeamEntry.sound_bw;
-
-	return sounding_bw;
-}
-
-BOOLEAN	beamforming_select_beam_entry(struct beamforming_info *pBeamInfo)
-{
-	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
-
-	pSoundInfo->sound_idx = beamforming_sounding_idx(pBeamInfo);
-
-	if(pSoundInfo->sound_idx < BEAMFORMING_ENTRY_NUM)
-		pSoundInfo->sound_mode = beamforming_sounding_mode(pBeamInfo, pSoundInfo->sound_idx);
-	else
-		pSoundInfo->sound_mode = SOUNDING_STOP_All_TIMER;
-	
-	if(SOUNDING_STOP_All_TIMER == pSoundInfo->sound_mode)
-	{
-		return _FALSE;
-	}
-	else
-	{
-		pSoundInfo->sound_bw = beamforming_sounding_bw(pBeamInfo, pSoundInfo->sound_mode, pSoundInfo->sound_idx );
-		pSoundInfo->sound_period = beamforming_sounding_time(pBeamInfo, pSoundInfo->sound_mode, pSoundInfo->sound_idx );
-		return _TRUE;
-	}
-}
-
-BOOLEAN	beamforming_start_fw(PADAPTER adapter, u8 idx)
-{
-	u8						*RA = NULL;
-	struct beamforming_entry	*pEntry;
-	BOOLEAN					ret = _TRUE;
-	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-
-	pEntry = &(pBeamInfo->beamforming_entry[idx]);
-	if(pEntry->bUsed == _FALSE)
-	{
-		DBG_871X("Skip Beamforming, no entry for Idx =%d\n", idx);
-		return _FALSE;
-	}
-
-	pEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
-	pEntry->bSound = _TRUE;
-	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&idx);
-
-	return _TRUE;
-}
-
-void	beamforming_end_fw(PADAPTER adapter)
-{
-	u8	idx = 0;
-
-	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&idx);
-
-	DBG_871X("%s\n", __FUNCTION__);
-}
-
-BOOLEAN	beamforming_start_period(PADAPTER adapter)
-{
-	BOOLEAN	ret = _TRUE;
-	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
-
-	beamforming_dym_ndpa_rate(adapter);
-
-	beamforming_select_beam_entry(pBeamInfo);
-
-	if(pSoundInfo->sound_mode == SOUNDING_FW_VHT_TIMER || pSoundInfo->sound_mode == SOUNDING_FW_HT_TIMER)
-	{
-		ret = beamforming_start_fw(adapter, pSoundInfo->sound_idx);
-	}
-	else
-	{
-		ret = _FALSE;
-	}
-
-	DBG_871X("%s Idx %d Mode %d BW %d Period %d\n", __FUNCTION__, 
-			pSoundInfo->sound_idx, pSoundInfo->sound_mode, pSoundInfo->sound_bw, pSoundInfo->sound_period);
-
-	return ret;
-}
-
-void	beamforming_end_period(PADAPTER adapter)
-{
-	u8						idx = 0;
-	struct beamforming_entry	*pBeamformEntry;
-	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
-
-
-	if(pSoundInfo->sound_mode == SOUNDING_FW_VHT_TIMER || pSoundInfo->sound_mode == SOUNDING_FW_HT_TIMER)
-	{		
-		beamforming_end_fw(adapter);
-	}
-}
-
-void	beamforming_notify(PADAPTER adapter)
-{
-	BOOLEAN		bSounding = _FALSE;
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(&(adapter->mlmepriv));
-
-	bSounding = beamfomring_bSounding(pBeamInfo);
-	
-	if(pBeamInfo->beamforming_state == BEAMFORMING_STATE_IDLE)
-	{
-		if(bSounding)
-		{			
-			if(beamforming_start_period(adapter) == _TRUE)
-				pBeamInfo->beamforming_state = BEAMFORMING_STATE_START;
-		}
-	}
-	else if(pBeamInfo->beamforming_state == BEAMFORMING_STATE_START)
-	{
-		if(bSounding)
-		{
-			if(beamforming_start_period(adapter) == _FALSE)
-				pBeamInfo->beamforming_state = BEAMFORMING_STATE_END;
-		}
-		else
-		{
-			beamforming_end_period(adapter);
-			pBeamInfo->beamforming_state = BEAMFORMING_STATE_END;
-		}
-	}
-	else if(pBeamInfo->beamforming_state == BEAMFORMING_STATE_END)
-	{
-		if(bSounding)
-		{
-			if(beamforming_start_period(adapter) == _TRUE)
-				pBeamInfo->beamforming_state = BEAMFORMING_STATE_START;
-		}
-	}
-	else
-	{
-		DBG_871X("%s BeamformState %d\n", __FUNCTION__, pBeamInfo->beamforming_state);
-	}
-
-	DBG_871X("%s BeamformState %d bSounding %d\n", __FUNCTION__, pBeamInfo->beamforming_state, bSounding);
-}
-
-BOOLEAN	beamforming_init_entry(PADAPTER	adapter, struct sta_info *psta, u8* idx)
-{
-	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
-	struct ht_priv		*phtpriv = &(pmlmepriv->htpriv);
-#ifdef CONFIG_80211AC_VHT	
-	struct vht_priv		*pvhtpriv = &(pmlmepriv->vhtpriv);
-#endif
-	struct mlme_ext_priv	*pmlmeext = &(adapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct beamforming_entry	*pBeamformEntry = NULL;
-	u8	*ra; 
-	u16	aid, mac_id;
-	u8	wireless_mode;
-	CHANNEL_WIDTH	bw = CHANNEL_WIDTH_20;
-	BEAMFORMING_CAP	beamform_cap = BEAMFORMING_CAP_NONE;
-
-	// The current setting does not support Beaforming
-	if (0 == phtpriv->beamform_cap 
-#ifdef CONFIG_80211AC_VHT
-		&& 0 == pvhtpriv->beamform_cap
-#endif
-		) {
-		DBG_871X("The configuration disabled Beamforming! Skip...\n");
-		return _FALSE;
-	}
-
-	aid = psta->aid;
-	ra = psta->hwaddr;
-	mac_id = psta->mac_id;
-	wireless_mode = psta->wireless_mode;
-	bw = psta->bw_mode;
-
-	if (IsSupportedHT(wireless_mode) || IsSupportedVHT(wireless_mode)) {
-		//3 // HT
-		u8	cur_beamform;
-
-		cur_beamform = psta->htpriv.beamform_cap;
-
-		// We are Beamformee because the STA is Beamformer
-		if(TEST_FLAG(cur_beamform, BEAMFORMING_HT_BEAMFORMER_ENABLE))
-			beamform_cap =(BEAMFORMING_CAP)(beamform_cap |BEAMFORMEE_CAP_HT_EXPLICIT);
-
-		// We are Beamformer because the STA is Beamformee
-		if(TEST_FLAG(cur_beamform, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
-			beamform_cap =(BEAMFORMING_CAP)(beamform_cap | BEAMFORMER_CAP_HT_EXPLICIT);
-#ifdef CONFIG_80211AC_VHT
-		if (IsSupportedVHT(wireless_mode)) {
-			//3 // VHT
-			cur_beamform = psta->vhtpriv.beamform_cap;
-
-			// We are Beamformee because the STA is Beamformer
-			if(TEST_FLAG(cur_beamform, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
-				beamform_cap =(BEAMFORMING_CAP)(beamform_cap |BEAMFORMEE_CAP_VHT_SU);
-			// We are Beamformer because the STA is Beamformee
-			if(TEST_FLAG(cur_beamform, BEAMFORMING_VHT_BEAMFORMEE_ENABLE))
-				beamform_cap =(BEAMFORMING_CAP)(beamform_cap |BEAMFORMER_CAP_VHT_SU);
-		}
-#endif //CONFIG_80211AC_VHT
-
-		if(beamform_cap == BEAMFORMING_CAP_NONE)
-			return _FALSE;
-		
-		DBG_871X("Beamforming Config Capability = 0x%02X\n", beamform_cap);
-
-		pBeamformEntry = beamforming_get_entry_by_addr(pmlmepriv, ra, idx);
-		if (pBeamformEntry == NULL) {
-			pBeamformEntry = beamforming_add_entry(adapter, ra, aid, mac_id, bw, beamform_cap, idx);
-			if(pBeamformEntry == NULL)
-				return _FALSE;
-			else
-				pBeamformEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
-		} else {
-			// Entry has been created. If entry is initialing or progressing then errors occur.
-			if (pBeamformEntry->beamforming_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && 
-				pBeamformEntry->beamforming_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-				DBG_871X("Error State of Beamforming");
-				return _FALSE;
-			} else {
-				pBeamformEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
-			}
-		}
-
-		pBeamformEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-		psta->txbf_paid = pBeamformEntry->p_aid;
-		psta->txbf_gid = pBeamformEntry->g_id;
-
-		DBG_871X("%s Idx %d\n", __FUNCTION__, *idx);
-	} else {
-		return _FALSE;
-	}
-
-	return _SUCCESS;
-}
-
-void	beamforming_deinit_entry(PADAPTER adapter, u8* ra)
-{
-	u8	idx = 0;
-	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
-	
-	if(beamforming_remove_entry(pmlmepriv, ra, &idx) == _TRUE)
-	{
-		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_LEAVE, (u8 *)&idx);
-	}
-
-	DBG_871X("%s Idx %d\n", __FUNCTION__, idx);
-}
-
-void	beamforming_reset(PADAPTER adapter)
-{
-	u8	idx = 0;
-	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-
-	for(idx = 0; idx < BEAMFORMING_ENTRY_NUM; idx++)
-	{
-		if(pBeamInfo->beamforming_entry[idx].bUsed == _TRUE)
-		{
-			pBeamInfo->beamforming_entry[idx].bUsed = _FALSE;
-			pBeamInfo->beamforming_entry[idx].beamforming_entry_cap = BEAMFORMING_CAP_NONE;
-			pBeamInfo->beamforming_entry[idx].beamforming_entry_state= BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-			rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_LEAVE, (u8 *)&idx);
-		}
-	}
-
-	DBG_871X("%s\n", __FUNCTION__);
-}
-
-void beamforming_sounding_fail(PADAPTER Adapter)
-{
-	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-	struct beamforming_entry	*pEntry = &(pBeamInfo->beamforming_entry[pBeamInfo->beamforming_cur_idx]);
-
-	pEntry->bSound = _FALSE;
-	rtw_hal_set_hwreg(Adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&pBeamInfo->beamforming_cur_idx);
-	beamforming_deinit_entry(Adapter, pEntry->mac_addr);
-}
-
-void	beamforming_check_sounding_success(PADAPTER Adapter,BOOLEAN status)
-{
-	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
-	struct beamforming_entry	*pEntry = &(pBeamInfo->beamforming_entry[pBeamInfo->beamforming_cur_idx]);
-
-	if(status == 1)
-	{
-		pEntry->LogStatusFailCnt = 0;
-	}	
-	else
-	{
-		pEntry->LogStatusFailCnt++;
-		DBG_871X("%s LogStatusFailCnt %d\n", __FUNCTION__, pEntry->LogStatusFailCnt);
-	}
-	if(pEntry->LogStatusFailCnt > 20)
-	{
-		DBG_871X("%s LogStatusFailCnt > 20, Stop SOUNDING\n", __FUNCTION__);
-		//pEntry->bSound = _FALSE;
-		//rtw_hal_set_hwreg(Adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&pBeamInfo->beamforming_cur_idx);
-		//beamforming_deinit_entry(Adapter, pEntry->mac_addr);
-		beamforming_wk_cmd(Adapter, BEAMFORMING_CTRL_SOUNDING_FAIL, NULL, 0, 1);
-	}
-}
-
-void	beamforming_enter(PADAPTER adapter, PVOID psta)
-{
-	u8	idx = 0xff;
-
-	if(beamforming_init_entry(adapter, (struct sta_info *)psta, &idx))
-		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_ENTER, (u8 *)&idx);
-
-	//DBG_871X("%s Idx %d\n", __FUNCTION__, idx);
-}
-
-void	beamforming_leave(PADAPTER adapter,u8* ra)
-{
-	if(ra == NULL)
-		beamforming_reset(adapter);
-	else
-		beamforming_deinit_entry(adapter, ra);
-
-	beamforming_notify(adapter);
-}
-
-BEAMFORMING_CAP beamforming_get_beamform_cap(struct beamforming_info	*pBeamInfo)
-{
-	u8	i;
-	BOOLEAN 				bSelfBeamformer = _FALSE;
-	BOOLEAN 				bSelfBeamformee = _FALSE;
-	struct beamforming_entry	beamforming_entry;
-	BEAMFORMING_CAP 		beamform_cap = BEAMFORMING_CAP_NONE;
-
-	for(i = 0; i < BEAMFORMING_ENTRY_NUM; i++)
-	{
-		beamforming_entry = pBeamInfo->beamforming_entry[i];
-
-		if(beamforming_entry.bUsed)
-		{
-			if( (beamforming_entry.beamforming_entry_cap & BEAMFORMEE_CAP_VHT_SU) ||
-				(beamforming_entry.beamforming_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT))
-				bSelfBeamformee = _TRUE;
-			if( (beamforming_entry.beamforming_entry_cap & BEAMFORMER_CAP_VHT_SU) ||
-				(beamforming_entry.beamforming_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT))
-				bSelfBeamformer = _TRUE;
-		}
-
-		if(bSelfBeamformer && bSelfBeamformee)
-			i = BEAMFORMING_ENTRY_NUM;
-	}
-
-	if(bSelfBeamformer)
-		beamform_cap |= BEAMFORMER_CAP;
-	if(bSelfBeamformee)
-		beamform_cap |= BEAMFORMEE_CAP;
-
-	return beamform_cap;
-}
-
-void	beamforming_watchdog(PADAPTER Adapter)
-{
-	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(( &(Adapter->mlmepriv)));
-
-	if(pBeamInfo->beamforming_state != BEAMFORMING_STATE_START)
-		return;
-
-	beamforming_dym_period(Adapter);
-	beamforming_dym_ndpa_rate(Adapter);
-}
-#endif/* #if (BEAMFORMING_SUPPORT ==0) - for diver defined beamforming*/
-
-u32	beamforming_get_report_frame(PADAPTER	 Adapter, union recv_frame *precv_frame)
-{
-	u32	ret = _SUCCESS;
-#if (BEAMFORMING_SUPPORT == 1)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-
-	ret = Beamforming_GetReportFrame(pDM_Odm, precv_frame);
-	
-#else /*(BEAMFORMING_SUPPORT == 0)- for drv beamfoming*/
-	struct beamforming_entry	*pBeamformEntry = NULL;
-	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
-	u8	*pframe = precv_frame->u.hdr.rx_data;
-	u32	frame_len = precv_frame->u.hdr.len;
-	u8	*ta;
-	u8	idx, offset;
-	
-	/*DBG_871X("beamforming_get_report_frame\n");*/
-
-	/*Memory comparison to see if CSI report is the same with previous one*/
-	ta = GetAddr2Ptr(pframe);
-	pBeamformEntry = beamforming_get_entry_by_addr(pmlmepriv, ta, &idx);
-	if (pBeamformEntry->beamforming_entry_cap & BEAMFORMER_CAP_VHT_SU)
-		offset = 31;	/*24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)*/
-	else if (pBeamformEntry->beamforming_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
-		offset = 34;	/*24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)*/
-	else
-		return ret;
-
-	/*DBG_871X("%s MacId %d offset=%d\n", __FUNCTION__, pBeamformEntry->mac_id, offset);*/
-
-	if (_rtw_memcmp(pBeamformEntry->PreCsiReport + offset, pframe+offset, frame_len-offset) == _FALSE)
-		pBeamformEntry->DefaultCsiCnt = 0;
-	else 
-		pBeamformEntry->DefaultCsiCnt++;
-	
-	_rtw_memcpy(&pBeamformEntry->PreCsiReport, pframe, frame_len);
-
-	pBeamformEntry->bDefaultCSI = _FALSE;
-
-	if (pBeamformEntry->DefaultCsiCnt > 20)
-		pBeamformEntry->bDefaultCSI = _TRUE;
-	else
-		pBeamformEntry->bDefaultCSI = _FALSE;
-#endif
-	return ret;
-}
-
-void	beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_frame)
-{
-#if (BEAMFORMING_SUPPORT == 1)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-
-	Beamforming_GetNDPAFrame(pDM_Odm, precv_frame);
-
-#else /*(BEAMFORMING_SUPPORT == 0)- for drv beamfoming*/
-	u8	*ta;
-	u8	idx, Sequence;
-	u8	*pframe = precv_frame->u.hdr.rx_data;
-	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
-	struct beamforming_entry	*pBeamformEntry = NULL;
-
-	/*DBG_871X("beamforming_get_ndpa_frame\n");*/
-
-	if (IS_HARDWARE_TYPE_8812(Adapter) == _FALSE)
-		return;
-	else if (GetFrameSubType(pframe) != WIFI_NDPA)
-		return;
-
-	ta = GetAddr2Ptr(pframe);
-	/*Remove signaling TA. */
-	ta[0] = ta[0] & 0xFE; 
-	
-	pBeamformEntry = beamforming_get_entry_by_addr(pmlmepriv, ta, &idx);
-
-	if (pBeamformEntry == NULL)
-		return;
-	else if (!(pBeamformEntry->beamforming_entry_cap & BEAMFORMEE_CAP_VHT_SU))
-		return;
-	/*LogSuccess: As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is NO LONGER needed !2015-04-10, Jeffery*/
-	/*ClockResetTimes: While BFer entry always doesn't receive our CSI, clock will reset again and again.So ClockResetTimes is limited to 5 times.2015-04-13, Jeffery*/
-	else if ((pBeamformEntry->LogSuccess == 1) || (pBeamformEntry->ClockResetTimes == 5)) {
-		DBG_871X("[%s] LogSeq=%d, PreLogSeq=%d\n", __func__, pBeamformEntry->LogSeq, pBeamformEntry->PreLogSeq);
-		return;
-	}
-
-	Sequence = (pframe[16]) >> 2;
-	DBG_871X("[%s] Start, Sequence=%d, LogSeq=%d, PreLogSeq=%d, LogRetryCnt=%d, ClockResetTimes=%d, LogSuccess=%d\n", 
-		__func__, Sequence, pBeamformEntry->LogSeq, pBeamformEntry->PreLogSeq, pBeamformEntry->LogRetryCnt, pBeamformEntry->ClockResetTimes, pBeamformEntry->LogSuccess);
-
-	if ((pBeamformEntry->LogSeq != 0) && (pBeamformEntry->PreLogSeq != 0)) {
-		/*Success condition*/
-		if ((pBeamformEntry->LogSeq != Sequence) && (pBeamformEntry->PreLogSeq != pBeamformEntry->LogSeq)) {
-			/* break option for clcok reset, 2015-03-30, Jeffery */
-			pBeamformEntry->LogRetryCnt = 0;
-			/*As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is no longer needed.*/
-			/*That is, LogSuccess is NOT needed to be reset to zero, 2015-04-13, Jeffery*/
-			pBeamformEntry->LogSuccess = 1;
-		
-		} else {/*Fail condition*/
-
-			if (pBeamformEntry->LogRetryCnt == 5) {
-				pBeamformEntry->ClockResetTimes++;
-		pBeamformEntry->LogRetryCnt = 0;
-
-				DBG_871X("[%s] Clock Reset!!! ClockResetTimes=%d\n",  __func__, pBeamformEntry->ClockResetTimes);
-			beamforming_wk_cmd(Adapter, BEAMFORMING_CTRL_SOUNDING_CLK, NULL, 0, 1);
-
-			} else
-		pBeamformEntry->LogRetryCnt++;
-	}
-	}
-
-	/*Update LogSeq & PreLogSeq*/
-	pBeamformEntry->PreLogSeq = pBeamformEntry->LogSeq;
-	pBeamformEntry->LogSeq = Sequence;
-
-#endif
-	
-}
-
-
-
-
-void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf)
-{
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-_func_enter_;
-
-#if (BEAMFORMING_SUPPORT == 1) /*(BEAMFORMING_SUPPORT == 1)- for PHYDM beamfoming*/
-	switch (type) {
-	case BEAMFORMING_CTRL_ENTER:
-	{
-		struct sta_info	*psta = (PVOID)pbuf;
-		u16			staIdx = psta->mac_id;
-
-		Beamforming_Enter(pDM_Odm, staIdx);		
-		break;
-	}
-	case BEAMFORMING_CTRL_LEAVE:
-		Beamforming_Leave(pDM_Odm, pbuf);
-		break;
-	default:
-		break;
-
-	}
-#else /*(BEAMFORMING_SUPPORT == 0)- for drv beamfoming*/
-	switch (type) {	
-		case BEAMFORMING_CTRL_ENTER:
-			beamforming_enter(padapter, (PVOID)pbuf);
-			break;
-
-		case BEAMFORMING_CTRL_LEAVE:
-			beamforming_leave(padapter, pbuf);
-			break;
-
-		case BEAMFORMING_CTRL_SOUNDING_FAIL:
-			beamforming_sounding_fail(padapter);
-			break;
-
-		case BEAMFORMING_CTRL_SOUNDING_CLK:
-			rtw_hal_set_hwreg(padapter, HW_VAR_SOUNDING_CLK, NULL);
-			break;
-	
-		default:
-			break;
-	}
-#endif
-_func_exit_;
-}
-
-u8	beamforming_wk_cmd(_adapter*padapter, s32 type, u8 *pbuf, s32 size, u8 enqueue)
-{
-	struct cmd_obj	*ph2c;
-	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
-	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
-	u8	res = _SUCCESS;
-	
-_func_enter_;
-
-	if(enqueue)
-	{
-		u8	*wk_buf;
-	
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-		if(ph2c==NULL){
-			res= _FAIL;
-			goto exit;
-		}
-		
-		pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-		if(pdrvextra_cmd_parm==NULL){
-			rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-			res= _FAIL;
-			goto exit;
-		}
-
-		if (pbuf != NULL) {
-			wk_buf = rtw_zmalloc(size);
-			if(wk_buf==NULL){
-				rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
-				rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
-				res= _FAIL;
-				goto exit;
-			}
-
-			_rtw_memcpy(wk_buf, pbuf, size);
-		} else {
-			wk_buf = NULL;
-			size = 0;
-		}
-
-		pdrvextra_cmd_parm->ec_id = BEAMFORMING_WK_CID;
-		pdrvextra_cmd_parm->type = type;
-		pdrvextra_cmd_parm->size = size;
-		pdrvextra_cmd_parm->pbuf = wk_buf;
-
-		init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
-
-		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	}
-	else
-	{
-		beamforming_wk_hdl(padapter, type, pbuf);
-	}
-	
-exit:
-	
-_func_exit_;
-
-	return res;
-}
-
-void update_attrib_txbf_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)
-{
-	if (psta) {
-		pattrib->txbf_g_id = psta->txbf_gid;
-		pattrib->txbf_p_aid = psta->txbf_paid;
-	}
-}
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BEAMFORMING_C_
+
+#include <drv_types.h>
+#include <hal_data.h>
+
+#ifdef CONFIG_BEAMFORMING
+
+#ifdef RTW_BEAMFORMING_VERSION_2
+
+struct ndpa_sta_info {
+	u16 aid:12;
+	u16 feedback_type:1;
+	u16 nc_index:3;
+};
+
+static void _get_txvector_parameter(PADAPTER adapter, struct sta_info *sta, u8 *g_id, u16 *p_aid)
+{
+	struct mlme_priv *mlme;
+	u16 aid;
+	u8 *bssid;
+	u16 val16;
+	u8 i;
+
+
+	mlme = &adapter->mlmepriv;
+
+	if (check_fwstate(mlme, WIFI_AP_STATE)) {
+		/*
+		 * Sent by an AP and addressed to a STA associated with that AP
+		 * or sent by a DLS or TDLS STA in a direct path to
+		 * a DLS or TDLS peer STA
+		 */
+
+		aid = sta->cmn.aid;
+		bssid = adapter_mac_addr(adapter);
+		RTW_INFO("%s: AID=0x%x BSSID=" MAC_FMT "\n",
+			 __FUNCTION__, sta->cmn.aid, MAC_ARG(bssid));
+
+		/* AID[0:8] */
+		aid &= 0x1FF;
+		/* BSSID[44:47] xor BSSID[40:43] */
+		val16 = ((bssid[5] & 0xF0) >> 4) ^ (bssid[5] & 0xF);
+		/* (dec(AID[0:8]) + dec(BSSID)*2^5) mod 2^9 */
+		*p_aid = (aid + (val16 << 5)) & 0x1FF;
+		*g_id = 63;
+	} else if ((check_fwstate(mlme, WIFI_ADHOC_STATE) == _TRUE)
+		   || (check_fwstate(mlme, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
+		/*
+		 * Otherwise, includes
+		 * 1. Sent to an IBSS STA
+		 * 2. Sent by an AP to a non associated STA
+		 * 3. Sent to a STA for which it is not known
+		 *    which condition is applicable
+		 */
+		*p_aid = 0;
+		*g_id = 63;
+	} else {
+		/* Addressed to AP */
+		bssid = sta->cmn.mac_addr;
+		RTW_INFO("%s: BSSID=" MAC_FMT "\n", __FUNCTION__, MAC_ARG(bssid));
+
+		/* BSSID[39:47] */
+		*p_aid = (bssid[5] << 1) | (bssid[4] >> 7);
+		*g_id = 0;
+	}
+
+	RTW_INFO("%s: GROUP_ID=0x%02x PARTIAL_AID=0x%04x\n",
+		 __FUNCTION__, *g_id, *p_aid);
+}
+
+/*
+ * Parameters
+ *	adapter		struct _adapter*
+ *	sta		struct sta_info*
+ *	sta_bf_cap	beamforming capabe of sta
+ *	sounding_dim	Number of Sounding Dimensions
+ *	comp_steering	Compressed Steering Number of Beamformer Antennas Supported
+ */
+static void _get_sta_beamform_cap(PADAPTER adapter, struct sta_info *sta,
+	u8 *sta_bf_cap, u8 *sounding_dim, u8 *comp_steering)
+{
+	struct beamforming_info *info;
+	struct ht_priv *ht;
+#ifdef CONFIG_80211AC_VHT
+	struct vht_priv *vht;
+#endif /* CONFIG_80211AC_VHT */
+	u16 bf_cap;
+
+
+	*sta_bf_cap = 0;
+	*sounding_dim = 0;
+	*comp_steering = 0;
+
+	info = GET_BEAMFORM_INFO(adapter);
+	ht = &adapter->mlmepriv.htpriv;
+#ifdef CONFIG_80211AC_VHT
+	vht = &adapter->mlmepriv.vhtpriv;
+#endif /* CONFIG_80211AC_VHT */
+
+	if (is_supported_ht(sta->wireless_mode) == _TRUE) {
+		/* HT */
+		bf_cap = ht->beamform_cap;
+
+		if (TEST_FLAG(bf_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) {
+			info->beamforming_cap |= BEAMFORMEE_CAP_HT_EXPLICIT;
+			*sta_bf_cap |= BEAMFORMER_CAP_HT_EXPLICIT;
+			*sounding_dim = (bf_cap & BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP) >> 6;
+		}
+		if (TEST_FLAG(bf_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
+			info->beamforming_cap |= BEAMFORMER_CAP_HT_EXPLICIT;
+			*sta_bf_cap |= BEAMFORMEE_CAP_HT_EXPLICIT;
+			*comp_steering = (bf_cap & BEAMFORMING_HT_BEAMFORMER_STEER_NUM) >> 4;
+		}
+	}
+
+#ifdef CONFIG_80211AC_VHT
+	if (is_supported_vht(sta->wireless_mode) == _TRUE) {
+		/* VHT */
+		bf_cap = vht->beamform_cap;
+
+		/* We are SU Beamformee because the STA is SU Beamformer */
+		if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) {
+			info->beamforming_cap |= BEAMFORMEE_CAP_VHT_SU;
+			*sta_bf_cap |= BEAMFORMER_CAP_VHT_SU;
+
+			/* We are MU Beamformee because the STA is MU Beamformer */
+			if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)) {
+				info->beamforming_cap |= BEAMFORMEE_CAP_VHT_MU;
+				*sta_bf_cap |= BEAMFORMER_CAP_VHT_MU;
+			}
+
+			*sounding_dim = (bf_cap & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
+		}
+		/* We are SU Beamformer because the STA is SU Beamformee */
+		if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
+			info->beamforming_cap |= BEAMFORMER_CAP_VHT_SU;
+			*sta_bf_cap |= BEAMFORMEE_CAP_VHT_SU;
+
+			/* We are MU Beamformer because the STA is MU Beamformee */
+			if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
+				info->beamforming_cap |= BEAMFORMER_CAP_VHT_MU;
+				*sta_bf_cap |= BEAMFORMEE_CAP_VHT_MU;
+			}
+
+			*comp_steering = (bf_cap & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
+		}
+	}
+#endif /* CONFIG_80211AC_VHT */
+}
+
+static u8 _send_ht_ndpa_packet(PADAPTER adapter, u8 *ra, enum channel_width bw)
+{
+	/* General */
+	struct xmit_priv		*pxmitpriv;
+	struct mlme_ext_priv		*pmlmeext;
+	struct mlme_ext_info		*pmlmeinfo;
+	struct xmit_frame		*pmgntframe;
+	/* Beamforming */
+	struct beamforming_info		*info;
+	struct beamformee_entry		*bfee;
+	struct ndpa_sta_info		sta_info;
+	u8 ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xE0, 0x4C};
+	/* MISC */
+	struct pkt_attrib		*attrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	enum MGN_RATE txrate;
+	u8 *pframe;
+	u16 duration = 0;
+	u8 aSifsTime = 0;
+
+
+	RTW_INFO("+%s: Send to " MAC_FMT "\n", __FUNCTION__, MAC_ARG(ra));
+
+	pxmitpriv = &adapter->xmitpriv;
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+	bfee = rtw_bf_bfee_get_entry_by_addr(adapter, ra);
+	if (!bfee) {
+		RTW_ERR("%s: Cann't find beamformee entry!\n", __FUNCTION__);
+		return _FALSE;
+	}
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (!pmgntframe) {
+		RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
+		return _FALSE;
+	}
+
+	txrate = beamforming_get_htndp_tx_rate(GET_PDM_ODM(adapter), bfee->comp_steering_num_of_bfer);
+
+	/* update attribute */
+	attrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, attrib);
+	/*attrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
+	attrib->subtype = WIFI_ACTION_NOACK;
+	attrib->bwmode = bw;
+	/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
+	attrib->order = 1;
+	attrib->rate = (u8)txrate;
+	attrib->bf_pkt_type = 0;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	/* Frame control */
+	pwlanhdr->frame_ctl = 0;
+	set_frame_sub_type(pframe, attrib->subtype);
+	set_order_bit(pframe);
+
+	/* Duration */
+	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
+		aSifsTime = 10;
+	else
+		aSifsTime = 16;
+	duration = 2 * aSifsTime + 40;
+	if (bw == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+	set_duration(pframe, duration);
+
+	/* DA */
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+	/* SA */
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+	/* BSSID */
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
+
+	/* HT control field */
+	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
+
+	/*
+	 * Frame Body
+	 * Category field: vender-specific value, 0x7F
+	 * OUI: 0x00E04C
+	 */
+	_rtw_memcpy(pframe + 28, ActionHdr, 4);
+
+	attrib->pktlen = 32;
+	attrib->last_txcmdsz = attrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return _TRUE;
+}
+
+static u8 _send_vht_ndpa_packet(PADAPTER adapter, u8 *ra, u16 aid, enum channel_width bw)
+{
+	/* General */
+	struct xmit_priv		*pxmitpriv;
+	struct mlme_ext_priv		*pmlmeext;
+	struct xmit_frame		*pmgntframe;
+	/* Beamforming */
+	struct beamforming_info		*info;
+	struct beamformee_entry		*bfee;
+	struct ndpa_sta_info		sta_info;
+	/* MISC */
+	struct pkt_attrib		*attrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	u8 *pframe;
+	enum MGN_RATE txrate;
+	u16 duration = 0;
+	u8 sequence = 0, aSifsTime = 0;
+
+
+	RTW_INFO("+%s: Send to " MAC_FMT "\n", __FUNCTION__, MAC_ARG(ra));
+
+	pxmitpriv = &adapter->xmitpriv;
+	pmlmeext = &adapter->mlmeextpriv;
+	info = GET_BEAMFORM_INFO(adapter);
+	bfee = rtw_bf_bfee_get_entry_by_addr(adapter, ra);
+	if (!bfee) {
+		RTW_ERR("%s: Cann't find beamformee entry!\n", __FUNCTION__);
+		return _FALSE;
+	}
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (!pmgntframe) {
+		RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
+		return _FALSE;
+	}
+
+	txrate = beamforming_get_vht_ndp_tx_rate(GET_PDM_ODM(adapter), bfee->comp_steering_num_of_bfer);
+
+	/* update attribute */
+	attrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, attrib);
+	/*pattrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
+	attrib->subtype = WIFI_NDPA;
+	attrib->bwmode = bw;
+	/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
+	attrib->rate = (u8)txrate;
+	attrib->bf_pkt_type = 0;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, TXDESC_OFFSET + WLANHDR_OFFSET);
+	pframe = pmgntframe->buf_addr + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	/* Frame control */
+	pwlanhdr->frame_ctl = 0;
+	set_frame_sub_type(pframe, attrib->subtype);
+
+	/* Duration */
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		aSifsTime = 16;
+	else
+		aSifsTime = 10;
+	duration = 2 * aSifsTime + 44;
+	if (bw == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (bw == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+	set_duration(pframe, duration);
+
+	/* RA */
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+
+	/* TA */
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+
+	/* Sounding Sequence, bit0~1 is reserved */
+	sequence = info->sounding_sequence << 2;
+	if (info->sounding_sequence >= 0x3f)
+		info->sounding_sequence = 0;
+	else
+		info->sounding_sequence++;
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+
+	/* STA Info */
+	/*
+	 * "AID12" Equal to 0 if the STA is an AP, mesh STA or
+	 * STA that is a member of an IBSS
+	 */
+	if (check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _FALSE)
+		aid = 0;
+	sta_info.aid = aid;
+	/* "Feedback Type" set to 0 for SU */
+	sta_info.feedback_type = 0;
+	/* "Nc Index" reserved if the Feedback Type field indicates SU */
+	sta_info.nc_index = 0;
+	_rtw_memcpy(pframe + 17, (u8 *)&sta_info, 2);
+
+	attrib->pktlen = 19;
+	attrib->last_txcmdsz = attrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return _TRUE;
+}
+
+static u8 _send_vht_mu_ndpa_packet(PADAPTER adapter, enum channel_width bw)
+{
+	/* General */
+	struct xmit_priv		*pxmitpriv;
+	struct mlme_ext_priv		*pmlmeext;
+	struct xmit_frame		*pmgntframe;
+	/* Beamforming */
+	struct beamforming_info		*info;
+	struct sounding_info		*sounding;
+	struct beamformee_entry		*bfee;
+	struct ndpa_sta_info		sta_info;
+	/* MISC */
+	struct pkt_attrib		*attrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	enum MGN_RATE txrate;
+	u8 *pframe;
+	u8 *ra = NULL;
+	u16 duration = 0;
+	u8 sequence = 0, aSifsTime = 0;
+	u8 i;
+
+
+	RTW_INFO("+%s\n", __FUNCTION__);
+
+	pxmitpriv = &adapter->xmitpriv;
+	pmlmeext = &adapter->mlmeextpriv;
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	txrate = MGN_VHT2SS_MCS0;
+
+	/*
+	 * Fill the first MU BFee entry (STA1) MAC addr to destination address then
+	 * HW will change A1 to broadcast addr.
+	 * 2015.05.28. Suggested by SD1 Chunchu.
+	 */
+	bfee = &info->bfee_entry[sounding->mu_sounding_list[0]];
+	ra = bfee->mac_addr;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (!pmgntframe) {
+		RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
+		return _FALSE;
+	}
+
+	/* update attribute */
+	attrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, attrib);
+	/*attrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
+	attrib->subtype = WIFI_NDPA;
+	attrib->bwmode = bw;
+	/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
+	attrib->rate = (u8)txrate;
+	/* Set TxBFPktType of Tx desc to unicast type if there is only one MU STA for HW design */
+	if (info->sounding_info.candidate_mu_bfee_cnt > 1)
+		attrib->bf_pkt_type = 1;
+	else
+		attrib->bf_pkt_type = 0;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, TXDESC_OFFSET + WLANHDR_OFFSET);
+	pframe = pmgntframe->buf_addr + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	/* Frame control */
+	pwlanhdr->frame_ctl = 0;
+	set_frame_sub_type(pframe, attrib->subtype);
+
+	/* Duration */
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		aSifsTime = 16;
+	else
+		aSifsTime = 10;
+	duration = 2 * aSifsTime + 44;
+	if (bw == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (bw == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+	set_duration(pframe, duration);
+
+	/* RA */
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+
+	/* TA */
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+
+	/* Sounding Sequence, bit0~1 is reserved */
+	sequence = info->sounding_sequence << 2;
+	if (info->sounding_sequence >= 0x3f)
+		info->sounding_sequence = 0;
+	else
+		info->sounding_sequence++;
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+
+	attrib->pktlen = 17;
+
+	/*
+	 * Construct STA info. for multiple STAs
+	 * STA Info1, ..., STA Info n
+	 */
+	for (i = 0; i < sounding->candidate_mu_bfee_cnt; i++) {
+		bfee = &info->bfee_entry[sounding->mu_sounding_list[i]];
+		sta_info.aid = bfee->aid;
+		sta_info.feedback_type = 1; /* 1'b1: MU */
+		sta_info.nc_index = 0;
+		_rtw_memcpy(pframe + attrib->pktlen, (u8 *)&sta_info, 2);
+		attrib->pktlen += 2;
+	}
+
+	attrib->last_txcmdsz = attrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return _TRUE;
+}
+
+static u8 _send_bf_report_poll(PADAPTER adapter, u8 *ra, u8 bFinalPoll)
+{
+	/* General */
+	struct xmit_priv *pxmitpriv;
+	struct xmit_frame *pmgntframe;
+	/* MISC */
+	struct pkt_attrib *attrib;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	u8 *pframe;
+
+
+	RTW_INFO("+%s: Send to " MAC_FMT "\n", __FUNCTION__, MAC_ARG(ra));
+
+	pxmitpriv = &adapter->xmitpriv;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (!pmgntframe) {
+		RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
+		return _FALSE;
+	}
+
+	/* update attribute */
+	attrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, attrib);
+	/*attrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
+	attrib->subtype = WIFI_BF_REPORT_POLL;
+	attrib->bwmode = CHANNEL_WIDTH_20;
+	/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
+	attrib->rate = MGN_6M;
+	if (bFinalPoll)
+		attrib->bf_pkt_type = 3;
+	else
+		attrib->bf_pkt_type = 2;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, TXDESC_OFFSET + WLANHDR_OFFSET);
+	pframe = pmgntframe->buf_addr + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	/* Frame control */
+	pwlanhdr->frame_ctl = 0;
+	set_frame_sub_type(pframe, attrib->subtype);
+
+	/* Duration */
+	set_duration(pframe, 100);
+
+	/* RA */
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+
+	/* TA */
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+
+	/* Feedback Segment Retransmission Bitmap */
+	pframe[16] = 0xFF;
+
+	attrib->pktlen = 17;
+	attrib->last_txcmdsz = attrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return _TRUE;
+}
+
+static void _sounding_update_min_period(PADAPTER adapter, u16 period, u8 leave)
+{
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+	u8 i = 0;
+	u16 min_val = 0xFFFF;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	if (_TRUE == leave) {
+		/*
+		 * When a BFee left,
+		 * we need to find the latest min sounding period
+		 * from the remaining BFees
+		 */
+		for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+			bfee = &info->bfee_entry[i];
+			if ((bfee->used == _TRUE)
+			    && (bfee->sound_period < min_val))
+				min_val = bfee->sound_period;
+		}
+
+		if (min_val == 0xFFFF)
+			info->sounding_info.min_sounding_period = 0;
+		else
+			info->sounding_info.min_sounding_period = min_val;
+	} else {
+		if ((info->sounding_info.min_sounding_period == 0)
+		    || (period < info->sounding_info.min_sounding_period))
+			info->sounding_info.min_sounding_period = period;
+	}
+}
+
+static void _sounding_init(struct sounding_info *sounding)
+{
+	_rtw_memset(sounding->su_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_SU);
+	_rtw_memset(sounding->mu_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_MU);
+	sounding->state = SOUNDING_STATE_NONE;
+	sounding->su_bfee_curidx = 0xFF;
+	sounding->candidate_mu_bfee_cnt = 0;
+	sounding->min_sounding_period = 0;
+	sounding->sound_remain_cnt_per_period = 0;
+}
+
+static void _sounding_reset_vars(PADAPTER adapter)
+{
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	u8 idx;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	_rtw_memset(sounding->su_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_SU);
+	_rtw_memset(sounding->mu_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_MU);
+	sounding->su_bfee_curidx = 0xFF;
+	sounding->candidate_mu_bfee_cnt = 0;
+
+	/* Clear bSound flag for the new period */
+	for (idx = 0; idx < MAX_BEAMFORMEE_ENTRY_NUM; idx++) {
+		if ((info->bfee_entry[idx].used == _TRUE)
+		    && (info->bfee_entry[idx].sounding == _TRUE)) {
+			info->bfee_entry[idx].sounding = _FALSE;
+			info->bfee_entry[idx].bCandidateSoundingPeer = _FALSE;
+		}
+	}
+}
+
+/*
+ * Return
+ *	0	Prepare sounding list OK
+ *	-1	Fail to prepare sounding list, because no beamformee need to souding
+ *	-2	Fail to prepare sounding list, because beamformee state not ready
+ *
+ */
+static int _sounding_get_list(PADAPTER adapter)
+{
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	struct beamformee_entry *bfee;
+	u8 i, mu_idx = 0, su_idx = 0, not_ready = 0;
+	int ret = 0;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	/* Add MU BFee list first because MU priority is higher than SU */
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (bfee->used == _FALSE)
+			continue;
+
+		if (bfee->state != BEAMFORM_ENTRY_HW_STATE_ADDED) {
+			RTW_ERR("%s: Invalid BFee idx(%d) Hw state=%d\n", __FUNCTION__, i, bfee->state);
+			not_ready++;
+			continue;
+		}
+
+		/*
+		 * Decrease BFee's SoundCnt per period
+		 * If the remain count is 0,
+		 * then it can be sounded at this time
+		 */
+		if (bfee->SoundCnt) {
+			bfee->SoundCnt--;
+			if (bfee->SoundCnt)
+				continue;
+		}
+
+		/*
+		 * <tynli_Note>
+		 *	If the STA supports MU BFee capability then we add it to MUSoundingList directly
+		 *	because we can only sound one STA by unicast NDPA with MU cap enabled to get correct channel info.
+		 *	Suggested by BB team Luke Lee. 2015.11.25.
+		 */
+		if (bfee->cap & BEAMFORMEE_CAP_VHT_MU) {
+			/* MU BFee */
+			if (mu_idx >= MAX_NUM_BEAMFORMEE_MU) {
+				RTW_ERR("%s: Too much MU bfee entry(Limit:%d)\n", __FUNCTION__, MAX_NUM_BEAMFORMEE_MU);
+				continue;
+			}
+
+			if (bfee->bApplySounding == _TRUE) {
+				bfee->bCandidateSoundingPeer = _TRUE;
+				bfee->SoundCnt = GetInitSoundCnt(bfee->sound_period, sounding->min_sounding_period);
+				sounding->mu_sounding_list[mu_idx] = i;
+				mu_idx++;
+			}
+		} else if (bfee->cap & (BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT)) {
+			/* SU BFee (HT/VHT) */
+			if (su_idx >= MAX_NUM_BEAMFORMEE_SU) {
+				RTW_ERR("%s: Too much SU bfee entry(Limit:%d)\n", __FUNCTION__, MAX_NUM_BEAMFORMEE_SU);
+				continue;
+			}
+
+			if (bfee->bDeleteSounding == _TRUE) {
+				sounding->su_sounding_list[su_idx] = i;
+				su_idx++;
+			} else if ((bfee->bApplySounding == _TRUE)
+			    && (bfee->bSuspendSUCap == _FALSE)) {
+				bfee->bCandidateSoundingPeer = _TRUE;
+				bfee->SoundCnt = GetInitSoundCnt(bfee->sound_period, sounding->min_sounding_period);
+				sounding->su_sounding_list[su_idx] = i;
+				su_idx++;
+			}
+		}
+	}
+
+	sounding->candidate_mu_bfee_cnt = mu_idx;
+
+	if (su_idx + mu_idx == 0) {
+		ret = -1;
+		if (not_ready)
+			ret = -2;
+	}
+
+	RTW_INFO("-%s: There are %d SU and %d MU BFees in this sounding period\n", __FUNCTION__, su_idx, mu_idx);
+
+	return ret;
+}
+
+static void _sounding_handler(PADAPTER adapter)
+{
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	struct beamformee_entry *bfee;
+	u8 su_idx, i;
+	u32 timeout_period = 0;
+	u8 set_timer = _FALSE;
+	int ret = 0;
+	static u16 wait_cnt = 0;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	RTW_DBG("+%s: state=%d\n", __FUNCTION__, sounding->state);
+	if ((sounding->state != SOUNDING_STATE_INIT)
+	    && (sounding->state != SOUNDING_STATE_SU_SOUNDDOWN)
+	    && (sounding->state != SOUNDING_STATE_MU_SOUNDDOWN)
+	    && (sounding->state != SOUNDING_STATE_SOUNDING_TIMEOUT)) {
+		RTW_WARN("%s: Invalid State(%d) and return!\n", __FUNCTION__, sounding->state);
+		return;
+	}
+
+	if (sounding->state == SOUNDING_STATE_INIT) {
+		RTW_INFO("%s: Sounding start\n", __FUNCTION__);
+
+		/* Init Var */
+		_sounding_reset_vars(adapter);
+
+		/* Get the sounding list of this sounding period */
+		ret = _sounding_get_list(adapter);
+		if (ret == -1) {
+			wait_cnt = 0;
+			sounding->state = SOUNDING_STATE_NONE;
+			RTW_ERR("%s: No BFees found, set to SOUNDING_STATE_NONE\n", __FUNCTION__);
+			info->sounding_running--;
+			return;
+		}
+		if (ret == -2) {
+			RTW_WARN("%s: Temporarily cann't find BFee to sounding\n", __FUNCTION__);
+			if (wait_cnt < 5) {
+				wait_cnt++;
+			} else {
+				wait_cnt = 0;
+				sounding->state = SOUNDING_STATE_NONE;
+				RTW_ERR("%s: Wait changing state timeout!! Set to SOUNDING_STATE_NONE\n", __FUNCTION__);
+			}
+			info->sounding_running--;
+			return;
+		}
+		if (ret != 0) {
+			wait_cnt = 0;
+			RTW_ERR("%s: Unkown state(%d)!\n", __FUNCTION__, ret);
+			info->sounding_running--;
+			return;
+
+		}
+
+		wait_cnt = 0;
+
+		if (check_fwstate(&adapter->mlmepriv, WIFI_SITE_MONITOR) == _TRUE) {
+			RTW_INFO("%s: Sounding abort! scanning APs...\n", __FUNCTION__);
+			info->sounding_running--;
+			return;
+		}
+
+		rtw_ps_deny(adapter, PS_DENY_BEAMFORMING);
+		LeaveAllPowerSaveModeDirect(adapter);
+	}
+
+	/* Get non-sound SU BFee index */
+	for (i = 0; i < MAX_NUM_BEAMFORMEE_SU; i++) {
+		su_idx = sounding->su_sounding_list[i];
+		if (su_idx >= MAX_BEAMFORMEE_ENTRY_NUM)
+			continue;
+		bfee = &info->bfee_entry[su_idx];
+		if (_FALSE == bfee->sounding)
+			break;
+	}
+	if (i < MAX_NUM_BEAMFORMEE_SU) {
+		sounding->su_bfee_curidx = su_idx;
+		/* Set to sounding start state */
+		sounding->state = SOUNDING_STATE_SU_START;
+		RTW_DBG("%s: Set to SOUNDING_STATE_SU_START\n", __FUNCTION__);
+
+		bfee->sounding = _TRUE;
+		/* Reset sounding timeout flag for the new sounding */
+		bfee->bSoundingTimeout = _FALSE;
+
+		if (_TRUE == bfee->bDeleteSounding) {
+			u8 res = _FALSE;
+			rtw_bf_cmd(adapter, BEAMFORMING_CTRL_END_PERIOD, &res, 1, 0);
+			return;
+		}
+
+		/* Start SU sounding */
+		if (bfee->cap & BEAMFORMEE_CAP_VHT_SU)
+			_send_vht_ndpa_packet(adapter, bfee->mac_addr, bfee->aid, bfee->sound_bw);
+		else if (bfee->cap & BEAMFORMEE_CAP_HT_EXPLICIT)
+			_send_ht_ndpa_packet(adapter, bfee->mac_addr, bfee->sound_bw);
+
+		/* Set sounding timeout timer */
+		_set_timer(&info->sounding_timeout_timer, SU_SOUNDING_TIMEOUT);
+		return;
+	}
+
+	if (sounding->candidate_mu_bfee_cnt > 0) {
+		/*
+		 * If there is no SU BFee then find MU BFee and perform MU sounding
+		 *
+		 * <tynli_note> Need to check the MU starting condition. 2015.12.15.
+		 */
+		sounding->state = SOUNDING_STATE_MU_START;
+		RTW_DBG("%s: Set to SOUNDING_STATE_MU_START\n", __FUNCTION__);
+
+		/* Update MU BFee info */
+		for (i = 0; i < sounding->candidate_mu_bfee_cnt; i++) {
+			bfee = &info->bfee_entry[sounding->mu_sounding_list[i]];
+			bfee->sounding = _TRUE;
+		}
+
+		/* Send MU NDPA */
+		bfee = &info->bfee_entry[sounding->mu_sounding_list[0]];
+		_send_vht_mu_ndpa_packet(adapter, bfee->sound_bw);
+
+		/* Send BF report poll if more than 1 MU STA */
+		for (i = 1; i < sounding->candidate_mu_bfee_cnt; i++) {
+			bfee = &info->bfee_entry[sounding->mu_sounding_list[i]];
+
+			if (i == (sounding->candidate_mu_bfee_cnt - 1))/* The last STA*/
+				_send_bf_report_poll(adapter, bfee->mac_addr, _TRUE);
+			else
+				_send_bf_report_poll(adapter, bfee->mac_addr, _FALSE);
+		}
+
+		sounding->candidate_mu_bfee_cnt = 0;
+
+		/* Set sounding timeout timer */
+		_set_timer(&info->sounding_timeout_timer, MU_SOUNDING_TIMEOUT);
+		return;
+	}
+
+	info->sounding_running--;
+	sounding->state = SOUNDING_STATE_INIT;
+	RTW_INFO("%s: Sounding finished!\n", __FUNCTION__);
+	rtw_ps_deny_cancel(adapter, PS_DENY_BEAMFORMING);
+}
+
+static void _sounding_force_stop(PADAPTER adapter)
+{
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	if ((sounding->state == SOUNDING_STATE_SU_START)
+	    || (sounding->state == SOUNDING_STATE_MU_START)) {
+		u8 res = _FALSE;
+		_cancel_timer_ex(&info->sounding_timeout_timer);
+		rtw_bf_cmd(adapter, BEAMFORMING_CTRL_END_PERIOD, &res, 1, 1);
+		return;
+	}
+
+	info->sounding_running--;
+	sounding->state = SOUNDING_STATE_INIT;
+	RTW_INFO("%s: Sounding finished!\n", __FUNCTION__);
+	rtw_ps_deny_cancel(adapter, PS_DENY_BEAMFORMING);
+}
+
+static void _sounding_timer_handler(void *FunctionContext)
+{
+	PADAPTER adapter;
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	static u8 delay = 0;
+
+
+	RTW_DBG("+%s\n", __FUNCTION__);
+
+	adapter = (PADAPTER)FunctionContext;
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	if (SOUNDING_STATE_NONE == sounding->state) {
+		RTW_INFO("%s: Stop!\n", __FUNCTION__);
+		if (info->sounding_running)
+			RTW_WARN("%s: souding_running=%d when thread stop!\n",
+				 __FUNCTION__, info->sounding_running);
+		return;
+	}
+
+	_set_timer(&info->sounding_timer, sounding->min_sounding_period);
+
+	if (!info->sounding_running) {
+		if (SOUNDING_STATE_INIT != sounding->state) {
+			RTW_WARN("%s: state(%d) != SOUNDING_STATE_INIT!!\n", __FUNCTION__, sounding->state);
+			sounding->state = SOUNDING_STATE_INIT;
+		}
+		delay = 0;
+		info->sounding_running++;
+		rtw_bf_cmd(adapter, BEAMFORMING_CTRL_START_PERIOD, NULL, 0, 1);
+	} else {
+		if (delay != 0xFF)
+			delay++;
+		RTW_WARN("%s: souding is still processing...(state:%d, running:%d, delay:%d)\n",
+			 __FUNCTION__, sounding->state, info->sounding_running, delay);
+		if (delay > 3) {
+			RTW_WARN("%s: Stop sounding!!\n", __FUNCTION__);
+			_sounding_force_stop(adapter);
+		}
+	}
+}
+
+static void _sounding_timeout_timer_handler(void *FunctionContext)
+{
+	PADAPTER adapter;
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	struct beamformee_entry *bfee;
+
+
+	RTW_WARN("+%s\n", __FUNCTION__);
+
+	adapter = (PADAPTER)FunctionContext;
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	if (SOUNDING_STATE_SU_START == sounding->state) {
+		sounding->state = SOUNDING_STATE_SOUNDING_TIMEOUT;
+		RTW_ERR("%s: Set to SU SOUNDING_STATE_SOUNDING_TIMEOUT\n", __FUNCTION__);
+		/* SU BFee */
+		bfee = &info->bfee_entry[sounding->su_bfee_curidx];
+		bfee->bSoundingTimeout = _TRUE;
+		RTW_WARN("%s: The BFee entry[%d] is Sounding Timeout!\n", __FUNCTION__, sounding->su_bfee_curidx);
+	} else if (SOUNDING_STATE_MU_START == sounding->state) {
+		sounding->state = SOUNDING_STATE_SOUNDING_TIMEOUT;
+		RTW_ERR("%s: Set to MU SOUNDING_STATE_SOUNDING_TIMEOUT\n", __FUNCTION__);
+	} else {
+		RTW_WARN("%s: unexpected sounding state:0x%02x\n", __FUNCTION__, sounding->state);
+		return;
+	}
+
+	rtw_bf_cmd(adapter, BEAMFORMING_CTRL_START_PERIOD, NULL, 0, 1);
+}
+
+static struct beamformer_entry *_bfer_get_free_entry(PADAPTER adapter)
+{
+	u8 i = 0;
+	struct beamforming_info *info;
+	struct beamformer_entry *bfer;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	for (i = 0; i < MAX_BEAMFORMER_ENTRY_NUM; i++) {
+		bfer = &info->bfer_entry[i];
+		if (bfer->used == _FALSE)
+			return bfer;
+	}
+
+	return NULL;
+}
+
+static struct beamformer_entry *_bfer_get_entry_by_addr(PADAPTER adapter, u8 *ra)
+{
+	u8 i = 0;
+	struct beamforming_info *info;
+	struct beamformer_entry *bfer;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	for (i = 0; i < MAX_BEAMFORMER_ENTRY_NUM; i++) {
+		bfer = &info->bfer_entry[i];
+		if (bfer->used == _FALSE)
+			continue;
+		if (_rtw_memcmp(ra, bfer->mac_addr, ETH_ALEN) == _TRUE)
+			return bfer;
+	}
+
+	return NULL;
+}
+
+static struct beamformer_entry *_bfer_add_entry(PADAPTER adapter,
+	struct sta_info *sta, u8 bf_cap, u8 sounding_dim, u8 comp_steering)
+{
+	struct mlme_priv *mlme;
+	struct beamforming_info *info;
+	struct beamformer_entry *bfer;
+	u8 *bssid;
+	u16 val16;
+	u8 i;
+
+
+	mlme = &adapter->mlmepriv;
+	info = GET_BEAMFORM_INFO(adapter);
+
+	bfer = _bfer_get_entry_by_addr(adapter, sta->cmn.mac_addr);
+	if (!bfer) {
+		bfer = _bfer_get_free_entry(adapter);
+		if (!bfer)
+			return NULL;
+	}
+
+	bfer->used = _TRUE;
+	_get_txvector_parameter(adapter, sta, &bfer->g_id, &bfer->p_aid);
+	_rtw_memcpy(bfer->mac_addr, sta->cmn.mac_addr, ETH_ALEN);
+	bfer->cap = bf_cap;
+	bfer->state = BEAMFORM_ENTRY_HW_STATE_ADD_INIT;
+	bfer->NumofSoundingDim = sounding_dim;
+
+	if (TEST_FLAG(bf_cap, BEAMFORMER_CAP_VHT_MU)) {
+		info->beamformer_mu_cnt += 1;
+		bfer->aid = sta->cmn.aid;
+	} else if (TEST_FLAG(bf_cap, BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT)) {
+		info->beamformer_su_cnt += 1;
+
+		/* Record HW idx info */
+		for (i = 0; i < MAX_NUM_BEAMFORMER_SU; i++) {
+			if ((info->beamformer_su_reg_maping & BIT(i)) == 0) {
+				info->beamformer_su_reg_maping |= BIT(i);
+				bfer->su_reg_index = i;
+				break;
+			}
+		}
+		RTW_INFO("%s: Add BFer entry beamformer_su_reg_maping=%#x, su_reg_index=%d\n",
+			 __FUNCTION__, info->beamformer_su_reg_maping, bfer->su_reg_index);
+	}
+
+	return bfer;
+}
+
+static void _bfer_remove_entry(PADAPTER adapter, struct beamformer_entry *entry)
+{
+	struct beamforming_info *info;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	entry->state = BEAMFORM_ENTRY_HW_STATE_DELETE_INIT;
+
+	if (TEST_FLAG(entry->cap, BEAMFORMER_CAP_VHT_MU)) {
+		info->beamformer_mu_cnt -= 1;
+		_rtw_memset(entry->gid_valid, 0, 8);
+		_rtw_memset(entry->user_position, 0, 16);
+	} else if (TEST_FLAG(entry->cap, BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT)) {
+		info->beamformer_su_cnt -= 1;
+	}
+
+	if (info->beamformer_mu_cnt == 0)
+		info->beamforming_cap &= ~BEAMFORMEE_CAP_VHT_MU;
+	if (info->beamformer_su_cnt == 0)
+		info->beamforming_cap &= ~(BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT);
+}
+
+static u8 _bfer_set_entry_gid(PADAPTER adapter, u8 *addr, u8 *gid, u8 *position)
+{
+	struct beamformer_entry bfer;
+
+	memset(&bfer, 0, sizeof(bfer));
+	memcpy(bfer.mac_addr, addr, 6);
+
+	/* Parsing Membership Status Array */
+	memcpy(bfer.gid_valid, gid, 8);
+
+	/* Parsing User Position Array */
+	memcpy(bfer.user_position, position, 16);
+
+	/* Config HW GID table */
+	rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_GID_TABLE, (u8 *) &bfer,
+			sizeof(bfer), 1);
+
+	return _SUCCESS;
+}
+
+static struct beamformee_entry *_bfee_get_free_entry(PADAPTER adapter)
+{
+	u8 i = 0;
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (bfee->used == _FALSE)
+			return bfee;
+	}
+
+	return NULL;
+}
+
+static struct beamformee_entry *_bfee_get_entry_by_addr(PADAPTER adapter, u8 *ra)
+{
+	u8 i = 0;
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (bfee->used == _FALSE)
+			continue;
+		if (_rtw_memcmp(ra, bfee->mac_addr, ETH_ALEN) == _TRUE)
+			return bfee;
+	}
+
+	return NULL;
+}
+
+static u8 _bfee_get_first_su_entry_idx(PADAPTER adapter, struct beamformee_entry *ignore)
+{
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+	u8 i;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (ignore && (bfee == ignore))
+			continue;
+		if (bfee->used == _FALSE)
+			continue;
+		if ((!TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU))
+		    && TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT))
+			return i;
+	}
+
+	return 0xFF;
+}
+
+/*
+ * Description:
+ *	Get the first entry index of MU Beamformee.
+ *
+ * Return Value:
+ *	Index of the first MU sta, or 0xFF for invalid index.
+ *
+ * 2015.05.25. Created by tynli.
+ *
+ */
+static u8 _bfee_get_first_mu_entry_idx(PADAPTER adapter, struct beamformee_entry *ignore)
+{
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+	u8 i;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (ignore && (bfee == ignore))
+			continue;
+		if (bfee->used == _FALSE)
+			continue;
+		if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU))
+			return i;
+	}
+
+	return 0xFF;
+}
+
+static struct beamformee_entry *_bfee_add_entry(PADAPTER adapter,
+	struct sta_info *sta, u8 bf_cap, u8 sounding_dim, u8 comp_steering)
+{
+	struct mlme_priv *mlme;
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+	u8 *bssid;
+	u16 val16;
+	u8 i;
+
+
+	mlme = &adapter->mlmepriv;
+	info = GET_BEAMFORM_INFO(adapter);
+
+	bfee = _bfee_get_entry_by_addr(adapter, sta->cmn.mac_addr);
+	if (!bfee) {
+		bfee = _bfee_get_free_entry(adapter);
+		if (!bfee)
+			return NULL;
+	}
+
+	bfee->used = _TRUE;
+	bfee->aid = sta->cmn.aid;
+	bfee->mac_id = sta->cmn.mac_id;
+	bfee->sound_bw = sta->cmn.bw_mode;
+
+	_get_txvector_parameter(adapter, sta, &bfee->g_id, &bfee->p_aid);
+	sta->cmn.bf_info.g_id = bfee->g_id;
+	sta->cmn.bf_info.p_aid = bfee->p_aid;
+
+	_rtw_memcpy(bfee->mac_addr, sta->cmn.mac_addr, ETH_ALEN);
+	bfee->txbf = _FALSE;
+	bfee->sounding = _FALSE;
+	bfee->sound_period = 40;
+	_sounding_update_min_period(adapter, bfee->sound_period, _FALSE);
+	bfee->SoundCnt = GetInitSoundCnt(bfee->sound_period, info->sounding_info.min_sounding_period);
+	bfee->cap = bf_cap;
+	bfee->state = BEAMFORM_ENTRY_HW_STATE_ADD_INIT;
+
+	bfee->bCandidateSoundingPeer = _FALSE;
+	bfee->bSoundingTimeout = _FALSE;
+	bfee->bDeleteSounding = _FALSE;
+	bfee->bApplySounding = _TRUE;
+
+	bfee->tx_timestamp = 0;
+	bfee->tx_bytes = 0;
+
+	bfee->LogStatusFailCnt = 0;
+	bfee->NumofSoundingDim = sounding_dim;
+	bfee->comp_steering_num_of_bfer = comp_steering;
+	bfee->bSuspendSUCap = _FALSE;
+
+	if (TEST_FLAG(bf_cap, BEAMFORMEE_CAP_VHT_MU)) {
+		info->beamformee_mu_cnt += 1;
+		info->first_mu_bfee_index = _bfee_get_first_mu_entry_idx(adapter, NULL);
+
+		if (_TRUE == info->bEnableSUTxBFWorkAround) {
+			/* When the first MU BFee added, discard SU BFee bfee's capability */
+			if ((info->beamformee_mu_cnt == 1) && (info->beamformee_su_cnt > 0)) {
+				if (info->TargetSUBFee) {
+					info->TargetSUBFee->bSuspendSUCap = _TRUE;
+					info->TargetSUBFee->bDeleteSounding = _TRUE;
+				} else {
+					RTW_ERR("%s: UNEXPECTED!! info->TargetSUBFee is NULL!", __FUNCTION__);
+				}
+				info->TargetSUBFee = NULL;
+				_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
+				rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_CSI_REPORT, (u8*)&info->TargetCSIInfo, sizeof(struct _RT_CSI_INFO), 0);
+			}
+		}
+
+		/* Record HW idx info */
+		for (i = 0; i < MAX_NUM_BEAMFORMEE_MU; i++) {
+			if ((info->beamformee_mu_reg_maping & BIT(i)) == 0) {
+				info->beamformee_mu_reg_maping |= BIT(i);
+				bfee->mu_reg_index = i;
+				break;
+			}
+		}
+		RTW_INFO("%s: Add BFee entry beamformee_mu_reg_maping=%#x, mu_reg_index=%d\n",
+			 __FUNCTION__, info->beamformee_mu_reg_maping, bfee->mu_reg_index);
+
+	} else if (TEST_FLAG(bf_cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT)) {
+		info->beamformee_su_cnt += 1;
+
+		if (_TRUE == info->bEnableSUTxBFWorkAround) {
+			/* Record the first SU BFee index. We only allow the first SU BFee to be sound */
+			if ((info->beamformee_su_cnt == 1) && (info->beamformee_mu_cnt == 0)) {
+				info->TargetSUBFee = bfee;
+				_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
+				bfee->bSuspendSUCap = _FALSE;
+			} else {
+				bfee->bSuspendSUCap = _TRUE;
+			}
+		}
+
+		/* Record HW idx info */
+		for (i = 0; i < MAX_NUM_BEAMFORMEE_SU; i++) {
+			if ((info->beamformee_su_reg_maping & BIT(i)) == 0) {
+				info->beamformee_su_reg_maping |= BIT(i);
+				bfee->su_reg_index = i;
+				break;
+			}
+		}
+		RTW_INFO("%s: Add BFee entry beamformee_su_reg_maping=%#x, su_reg_index=%d\n",
+			 __FUNCTION__, info->beamformee_su_reg_maping, bfee->su_reg_index);
+	}
+
+	return bfee;
+}
+
+static void _bfee_remove_entry(PADAPTER adapter, struct beamformee_entry *entry)
+{
+	struct beamforming_info *info;
+	u8 idx;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	entry->state = BEAMFORM_ENTRY_HW_STATE_DELETE_INIT;
+
+	if (TEST_FLAG(entry->cap, BEAMFORMEE_CAP_VHT_MU)) {
+		info->beamformee_mu_cnt -= 1;
+		info->first_mu_bfee_index = _bfee_get_first_mu_entry_idx(adapter, entry);
+
+		if (_TRUE == info->bEnableSUTxBFWorkAround) {
+			if ((info->beamformee_mu_cnt == 0) && (info->beamformee_su_cnt > 0)) {
+				idx = _bfee_get_first_su_entry_idx(adapter, NULL);
+				info->TargetSUBFee = &info->bfee_entry[idx];
+				_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
+				info->TargetSUBFee->bSuspendSUCap = _FALSE;
+			}
+		}
+	} else if (TEST_FLAG(entry->cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT)) {
+		info->beamformee_su_cnt -= 1;
+
+		/* When the target SU BFee leaves, disable workaround */
+		if ((_TRUE == info->bEnableSUTxBFWorkAround)
+		    && (entry == info->TargetSUBFee)) {
+			entry->bSuspendSUCap = _TRUE;
+			info->TargetSUBFee = NULL;
+			_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
+			rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_CSI_REPORT, (u8*)&info->TargetCSIInfo, sizeof(struct _RT_CSI_INFO), 0);
+		}
+	}
+
+	if (info->beamformee_mu_cnt == 0)
+		info->beamforming_cap &= ~BEAMFORMER_CAP_VHT_MU;
+	if (info->beamformee_su_cnt == 0)
+		info->beamforming_cap &= ~(BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT);
+
+	_sounding_update_min_period(adapter, 0, _TRUE);
+}
+
+static enum beamforming_cap _bfee_get_entry_cap_by_macid(PADAPTER adapter, u8 macid)
+{
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee;
+	u8 i;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	for (i = 0; i < MAX_BEAMFORMER_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (bfee->used == _FALSE)
+			continue;
+		if (bfee->mac_id == macid)
+			return bfee->cap;
+	}
+
+	return BEAMFORMING_CAP_NONE;
+}
+
+static void _beamforming_enter(PADAPTER adapter, void *p)
+{
+	struct mlme_priv *mlme;
+	struct ht_priv *htpriv;
+#ifdef CONFIG_80211AC_VHT
+	struct vht_priv *vhtpriv;
+#endif
+	struct mlme_ext_priv *mlme_ext;
+	struct sta_info *sta, *sta_copy;
+	struct beamforming_info *info;
+	struct beamformer_entry *bfer = NULL;
+	struct beamformee_entry *bfee = NULL;
+	u8 wireless_mode;
+	u8 sta_bf_cap;
+	u8 sounding_dim = 0; /* number of sounding dimensions */
+	u8 comp_steering_num = 0; /* compressed steering number */
+
+
+	mlme = &adapter->mlmepriv;
+	htpriv = &mlme->htpriv;
+#ifdef CONFIG_80211AC_VHT
+	vhtpriv = &mlme->vhtpriv;
+#endif
+	mlme_ext = &adapter->mlmeextpriv;
+	info = GET_BEAMFORM_INFO(adapter);
+
+	sta_copy = (struct sta_info *)p;
+	sta = rtw_get_stainfo(&adapter->stapriv, sta_copy->cmn.mac_addr);
+	if (!sta) {
+		RTW_ERR("%s: Cann't find STA info for " MAC_FMT "\n",
+			__FUNCTION__, MAC_ARG(sta_copy->cmn.mac_addr));
+		return;
+	}
+	if (sta != sta_copy) {
+		RTW_WARN("%s: Origin sta(fake)=%p realsta=%p for " MAC_FMT "\n",
+		__FUNCTION__, sta_copy, sta, MAC_ARG(sta_copy->cmn.mac_addr));
+	}
+
+	/* The current setting does not support Beaforming */
+	wireless_mode = sta->wireless_mode;
+	if ((is_supported_ht(wireless_mode) == _FALSE)
+	    && (is_supported_vht(wireless_mode) == _FALSE)) {
+		RTW_WARN("%s: Not support HT or VHT mode\n", __FUNCTION__);
+		return;
+	}
+
+	if ((0 == htpriv->beamform_cap)
+#ifdef CONFIG_80211AC_VHT
+	    && (0 == vhtpriv->beamform_cap)
+#endif
+	   ) {
+		RTW_INFO("The configuration disabled Beamforming! Skip...\n");
+		return;
+	}
+
+	_get_sta_beamform_cap(adapter, sta,
+			      &sta_bf_cap, &sounding_dim, &comp_steering_num);
+	RTW_INFO("STA Beamforming Capability=0x%02X\n", sta_bf_cap);
+	if (sta_bf_cap == BEAMFORMING_CAP_NONE)
+		return;
+	if ((sta_bf_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
+	    || (sta_bf_cap & BEAMFORMEE_CAP_VHT_SU)
+	    || (sta_bf_cap & BEAMFORMEE_CAP_VHT_MU))
+		sta_bf_cap |= BEAMFORMEE_CAP;
+	if ((sta_bf_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+	    || (sta_bf_cap & BEAMFORMER_CAP_VHT_SU)
+	    || (sta_bf_cap & BEAMFORMER_CAP_VHT_MU))
+		sta_bf_cap |= BEAMFORMER_CAP;
+
+	if (sta_bf_cap & BEAMFORMER_CAP) {
+		/* The other side is beamformer */
+		bfer = _bfer_add_entry(adapter, sta, sta_bf_cap, sounding_dim, comp_steering_num);
+		if (!bfer)
+			RTW_ERR("%s: Fail to allocate bfer entry!\n", __FUNCTION__);
+	}
+	if (sta_bf_cap & BEAMFORMEE_CAP) {
+		/* The other side is beamformee */
+		bfee = _bfee_add_entry(adapter, sta, sta_bf_cap, sounding_dim, comp_steering_num);
+		if (!bfee)
+			RTW_ERR("%s: Fail to allocate bfee entry!\n", __FUNCTION__);
+	}
+	if (!bfer && !bfee)
+		return;
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_ENTER, (u8*)sta);
+
+	/* Perform sounding if there is BFee */
+	if ((info->beamformee_su_cnt != 0)
+	    || (info->beamformee_mu_cnt != 0)) {
+		if (SOUNDING_STATE_NONE == info->sounding_info.state) {
+			info->sounding_info.state = SOUNDING_STATE_INIT;
+			/* Start sounding after 2 sec */
+			_set_timer(&info->sounding_timer, 2000);
+		}
+	}
+}
+
+static void _beamforming_reset(PADAPTER adapter)
+{
+	RTW_ERR("%s: Not ready!!\n", __FUNCTION__);
+}
+
+static void _beamforming_leave(PADAPTER adapter, u8 *ra)
+{
+	struct beamforming_info *info;
+	struct beamformer_entry *bfer = NULL;
+	struct beamformee_entry *bfee = NULL;
+	u8 bHwStateAddInit = _FALSE;
+
+
+	RTW_INFO("+%s\n", __FUNCTION__);
+
+	info = GET_BEAMFORM_INFO(adapter);
+	bfer = _bfer_get_entry_by_addr(adapter, ra);
+	bfee = _bfee_get_entry_by_addr(adapter, ra);
+
+	if (!bfer && !bfee) {
+		RTW_WARN("%s: " MAC_FMT " is neither beamforming ee or er!!\n",
+			__FUNCTION__, MAC_ARG(ra));
+		return;
+	}
+
+	if (bfer)
+		_bfer_remove_entry(adapter, bfer);
+
+	if (bfee)
+		_bfee_remove_entry(adapter, bfee);
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_LEAVE, ra);
+
+	/* Stop sounding if there is no any BFee */
+	if ((info->beamformee_su_cnt == 0)
+	    && (info->beamformee_mu_cnt == 0)) {
+		_cancel_timer_ex(&info->sounding_timer);
+		_sounding_init(&info->sounding_info);
+	}
+
+	RTW_INFO("-%s\n", __FUNCTION__);
+}
+
+static void _beamforming_sounding_down(PADAPTER adapter, u8 status)
+{
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	struct beamformee_entry *bfee;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	RTW_INFO("+%s: sounding=%d, status=0x%02x\n", __FUNCTION__, sounding->state, status);
+
+	if (sounding->state == SOUNDING_STATE_MU_START) {
+		RTW_INFO("%s: MU sounding done\n", __FUNCTION__);
+		sounding->state = SOUNDING_STATE_MU_SOUNDDOWN;
+		RTW_INFO("%s: Set to SOUNDING_STATE_MU_SOUNDDOWN\n", __FUNCTION__);
+		info->SetHalSoundownOnDemandCnt++;
+		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_STATUS, &status);
+	} else if (sounding->state == SOUNDING_STATE_SU_START) {
+		RTW_INFO("%s: SU entry[%d] sounding down\n", __FUNCTION__, sounding->su_bfee_curidx);
+		bfee = &info->bfee_entry[sounding->su_bfee_curidx];
+		sounding->state = SOUNDING_STATE_SU_SOUNDDOWN;
+		RTW_INFO("%s: Set to SOUNDING_STATE_SU_SOUNDDOWN\n", __FUNCTION__);
+
+		/*
+		 * <tynli_note>
+		 *	bfee->bSoundingTimeout this flag still cannot avoid
+		 *	old sound down event happens in the new sounding period.
+		 *	2015.12.10
+		 */
+		if (_TRUE == bfee->bSoundingTimeout) {
+			RTW_WARN("%s: The entry[%d] is bSoundingTimeout!\n", __FUNCTION__, sounding->su_bfee_curidx);
+			bfee->bSoundingTimeout = _FALSE;
+			return;
+		}
+
+		if (_TRUE == status) {
+			/* success */
+			bfee->LogStatusFailCnt = 0;
+			info->SetHalSoundownOnDemandCnt++;
+			rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_STATUS, &status);
+		} else if (_TRUE == bfee->bDeleteSounding) {
+			RTW_WARN("%s: Delete entry[%d] sounding info!\n", __FUNCTION__, sounding->su_bfee_curidx);
+			rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_STATUS, &status);
+			bfee->bDeleteSounding = _FALSE;
+		} else {
+			bfee->LogStatusFailCnt++;
+			RTW_WARN("%s: LogStatusFailCnt=%d\n", __FUNCTION__, bfee->LogStatusFailCnt);
+			if (bfee->LogStatusFailCnt > 30) {
+				RTW_ERR("%s: LogStatusFailCnt > 30, Stop SOUNDING!!\n", __FUNCTION__);
+				rtw_bf_cmd(adapter, BEAMFORMING_CTRL_LEAVE, bfee->mac_addr, ETH_ALEN, 1);
+			}
+		}
+	} else {
+		RTW_WARN("%s: unexpected sounding state:0x%02x\n", __FUNCTION__, sounding->state);
+		return;
+	}
+
+	rtw_bf_cmd(adapter, BEAMFORMING_CTRL_START_PERIOD, NULL, 0, 0);
+}
+
+static void _c2h_snd_txbf(PADAPTER adapter, u8 *buf, u8 buf_len)
+{
+	struct beamforming_info	*info;
+	u8 res;
+
+	info = GET_BEAMFORM_INFO(adapter);
+
+	_cancel_timer_ex(&info->sounding_timeout_timer);
+
+	res = C2H_SND_TXBF_GET_SND_RESULT(buf) ? _TRUE : _FALSE;
+	RTW_INFO("+%s: %s\n", __FUNCTION__, res==_TRUE?"Success":"Fail!");
+
+	rtw_bf_cmd(adapter, BEAMFORMING_CTRL_END_PERIOD, &res, 1, 1);
+}
+
+/*
+ * Description:
+ *	This function is for phydm only
+ */
+enum beamforming_cap rtw_bf_bfee_get_entry_cap_by_macid(void *mlme, u8 macid)
+{
+	PADAPTER adapter;
+	enum beamforming_cap cap = BEAMFORMING_CAP_NONE;
+
+
+	adapter = mlme_to_adapter((struct mlme_priv *)mlme);
+	cap = _bfee_get_entry_cap_by_macid(adapter, macid);
+
+	return cap;
+}
+
+struct beamformer_entry *rtw_bf_bfer_get_entry_by_addr(PADAPTER adapter, u8 *ra)
+{
+	return _bfer_get_entry_by_addr(adapter, ra);
+}
+
+struct beamformee_entry *rtw_bf_bfee_get_entry_by_addr(PADAPTER adapter, u8 *ra)
+{
+	return _bfee_get_entry_by_addr(adapter, ra);
+}
+
+void rtw_bf_get_ndpa_packet(PADAPTER adapter, union recv_frame *precv_frame)
+{
+	RTW_DBG("+%s\n", __FUNCTION__);
+}
+
+u32 rtw_bf_get_report_packet(PADAPTER adapter, union recv_frame *precv_frame)
+{
+	u32 ret = _SUCCESS;
+	struct beamforming_info *info;
+	struct beamformee_entry *bfee = NULL;
+	u8 *pframe;
+	u32 frame_len;
+	u8 *ta;
+	u8 *frame_body;
+	u8 category, action;
+	u8 *pMIMOCtrlField, *pCSIMatrix;
+	u8 Nc = 0, Nr = 0, CH_W = 0, Ng = 0, CodeBook = 0;
+	u16 CSIMatrixLen = 0;
+
+
+	RTW_INFO("+%s\n", __FUNCTION__);
+
+	info = GET_BEAMFORM_INFO(adapter);
+	pframe = precv_frame->u.hdr.rx_data;
+	frame_len = precv_frame->u.hdr.len;
+
+	/* Memory comparison to see if CSI report is the same with previous one */
+	ta = get_addr2_ptr(pframe);
+	bfee = _bfee_get_entry_by_addr(adapter, ta);
+	if (!bfee)
+		return _FAIL;
+
+	frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
+	category = frame_body[0];
+	action = frame_body[1];
+
+	if ((category == RTW_WLAN_CATEGORY_VHT)
+	    && (action == RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING)) {
+		pMIMOCtrlField = pframe + 26;
+		Nc = (*pMIMOCtrlField) & 0x7;
+		Nr = ((*pMIMOCtrlField) & 0x38) >> 3;
+		CH_W =  (((*pMIMOCtrlField) & 0xC0) >> 6);
+		Ng = (*(pMIMOCtrlField+1)) & 0x3;
+		CodeBook = ((*(pMIMOCtrlField+1)) & 0x4) >> 2;
+		/*
+		 * 24+(1+1+3)+2
+		 * ==> MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)
+		 */
+		pCSIMatrix = pMIMOCtrlField + 3 + Nc;
+		CSIMatrixLen = frame_len - 26 - 3 - Nc;
+		info->TargetCSIInfo.bVHT = _TRUE;
+	} else if ((category == RTW_WLAN_CATEGORY_HT)
+		   && (action == RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING)) {
+		pMIMOCtrlField = pframe + 26;
+		Nc = (*pMIMOCtrlField) & 0x3;
+		Nr = ((*pMIMOCtrlField) & 0xC) >> 2;
+		CH_W = ((*pMIMOCtrlField) & 0x10) >> 4;
+		Ng = ((*pMIMOCtrlField) & 0x60) >> 5;
+		CodeBook = ((*(pMIMOCtrlField+1)) & 0x6) >> 1;
+		/*
+		 * 24+(1+1+6)+2
+		 * ==> MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)
+		 */
+		pCSIMatrix = pMIMOCtrlField + 6 + Nr;
+		CSIMatrixLen = frame_len  - 26 - 6 - Nr;
+		info->TargetCSIInfo.bVHT = _FALSE;
+	}
+
+	/* Update current CSI report info */
+	if ((_TRUE == info->bEnableSUTxBFWorkAround)
+	    && (info->TargetSUBFee == bfee)) {
+		if ((info->TargetCSIInfo.Nc != Nc) || (info->TargetCSIInfo.Nr != Nr) ||
+			(info->TargetCSIInfo.ChnlWidth != CH_W) || (info->TargetCSIInfo.Ng != Ng) ||
+			(info->TargetCSIInfo.CodeBook != CodeBook)) {
+			info->TargetCSIInfo.Nc = Nc;
+			info->TargetCSIInfo.Nr = Nr;
+			info->TargetCSIInfo.ChnlWidth = CH_W;
+			info->TargetCSIInfo.Ng = Ng;
+			info->TargetCSIInfo.CodeBook = CodeBook;
+
+			rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_CSI_REPORT, (u8*)&info->TargetCSIInfo, sizeof(struct _RT_CSI_INFO), 1);
+		}
+	}
+
+	RTW_INFO("%s: pkt type=%d-%d, Nc=%d, Nr=%d, CH_W=%d, Ng=%d, CodeBook=%d\n",
+		 __FUNCTION__, category, action, Nc, Nr, CH_W, Ng, CodeBook);
+
+	return ret;
+}
+
+u8 rtw_bf_send_vht_gid_mgnt_packet(PADAPTER adapter, u8 *ra, u8 *gid, u8 *position)
+{
+	/* General */
+	struct xmit_priv *xmitpriv;
+	struct mlme_priv *mlmepriv;
+	struct xmit_frame *pmgntframe;
+	/* MISC */
+	struct pkt_attrib *attrib;
+	struct rtw_ieee80211_hdr *wlanhdr;
+	u8 *pframe, *ptr;
+
+
+	xmitpriv = &adapter->xmitpriv;
+	mlmepriv = &adapter->mlmepriv;
+
+	pmgntframe = alloc_mgtxmitframe(xmitpriv);
+	if (!pmgntframe)
+		return _FALSE;
+
+	/* update attribute */
+	attrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, attrib);
+	attrib->rate = MGN_6M;
+	attrib->bwmode = CHANNEL_WIDTH_20;
+	attrib->subtype = WIFI_ACTION;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)pmgntframe->buf_addr + TXDESC_OFFSET;
+	wlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	wlanhdr->frame_ctl = 0;
+	set_frame_sub_type(pframe, attrib->subtype);
+	set_duration(pframe, 0);
+	SetFragNum(pframe, 0);
+	SetSeqNum(pframe, 0);
+
+	_rtw_memcpy(wlanhdr->addr1, ra, ETH_ALEN);
+	_rtw_memcpy(wlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memcpy(wlanhdr->addr3, get_bssid(mlmepriv), ETH_ALEN);
+
+	pframe[24] = RTW_WLAN_CATEGORY_VHT;
+	pframe[25] = RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT;
+	/* Set Membership Status Array */
+	ptr = pframe + 26;
+	_rtw_memcpy(ptr, gid, 8);
+	/* Set User Position Array */
+	ptr = pframe + 34;
+	_rtw_memcpy(ptr, position, 16);
+
+	attrib->pktlen = 54;
+	attrib->last_txcmdsz = attrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return _TRUE;
+}
+
+/*
+ * Description:
+ *	On VHT GID management frame by an MU beamformee.
+ */
+void rtw_bf_get_vht_gid_mgnt_packet(PADAPTER adapter, union recv_frame *precv_frame)
+{
+	u8 *pframe;
+	u8 *ta, *gid, *position;
+
+
+	RTW_DBG("+%s\n", __FUNCTION__);
+
+	pframe = precv_frame->u.hdr.rx_data;
+
+	/* Get address by Addr2 */
+	ta = get_addr2_ptr(pframe);
+	/* Remove signaling TA */
+	ta[0] &= 0xFE;
+
+	/* Membership Status Array */
+	gid = pframe + 26;
+	/* User Position Array */
+	position= pframe + 34;
+
+	_bfer_set_entry_gid(adapter, ta, gid, position);
+}
+
+void rtw_bf_init(PADAPTER adapter)
+{
+	struct beamforming_info	*info;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	info->beamforming_cap = BEAMFORMING_CAP_NONE;
+	info->beamforming_state = BEAMFORMING_STATE_IDLE;
+/*
+	info->bfee_entry[MAX_BEAMFORMEE_ENTRY_NUM];
+	info->bfer_entry[MAX_BEAMFORMER_ENTRY_NUM];
+*/
+	info->sounding_sequence = 0;
+	info->beamformee_su_cnt = 0;
+	info->beamformer_su_cnt = 0;
+	info->beamformee_su_reg_maping = 0;
+	info->beamformer_su_reg_maping = 0;
+	info->beamformee_mu_cnt = 0;
+	info->beamformer_mu_cnt = 0;
+	info->beamformee_mu_reg_maping = 0;
+	info->first_mu_bfee_index = 0xFF;
+	info->mu_bfer_curidx = 0xFF;
+	info->cur_csi_rpt_rate = HALMAC_OFDM24;
+
+	_sounding_init(&info->sounding_info);
+	rtw_init_timer(&info->sounding_timer, adapter, _sounding_timer_handler, adapter);
+	rtw_init_timer(&info->sounding_timeout_timer, adapter, _sounding_timeout_timer_handler, adapter);
+
+	info->SetHalBFEnterOnDemandCnt = 0;
+	info->SetHalBFLeaveOnDemandCnt = 0;
+	info->SetHalSoundownOnDemandCnt = 0;
+
+	info->bEnableSUTxBFWorkAround = _TRUE;
+	info->TargetSUBFee = NULL;
+
+	info->sounding_running = 0;
+}
+
+void rtw_bf_cmd_hdl(PADAPTER adapter, u8 type, u8 *pbuf)
+{
+	switch (type) {
+	case BEAMFORMING_CTRL_ENTER:
+		_beamforming_enter(adapter, pbuf);
+		break;
+
+	case BEAMFORMING_CTRL_LEAVE:
+		if (pbuf == NULL)
+			_beamforming_reset(adapter);
+		else
+			_beamforming_leave(adapter, pbuf);
+		break;
+
+	case BEAMFORMING_CTRL_START_PERIOD:
+		_sounding_handler(adapter);
+		break;
+
+	case BEAMFORMING_CTRL_END_PERIOD:
+		_beamforming_sounding_down(adapter, *pbuf);
+		break;
+
+	case BEAMFORMING_CTRL_SET_GID_TABLE:
+		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_SET_GID_TABLE, pbuf);
+		break;
+
+	case BEAMFORMING_CTRL_SET_CSI_REPORT:
+		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_CSI_REPORT, pbuf);
+		break;
+
+	default:
+		break;
+	}
+}
+
+u8 rtw_bf_cmd(PADAPTER adapter, s32 type, u8 *pbuf, s32 size, u8 enqueue)
+{
+	struct cmd_obj *ph2c;
+	struct drvextra_cmd_parm *pdrvextra_cmd_parm;
+	struct cmd_priv	*pcmdpriv = &adapter->cmdpriv;
+	u8 *wk_buf;
+	u8 res = _SUCCESS;
+
+
+	if (!enqueue) {
+		rtw_bf_cmd_hdl(adapter, type, pbuf);
+		goto exit;
+	}
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	if (pbuf != NULL) {
+		wk_buf = rtw_zmalloc(size);
+		if (wk_buf == NULL) {
+			rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
+			rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
+			res = _FAIL;
+			goto exit;
+		}
+
+		_rtw_memcpy(wk_buf, pbuf, size);
+	} else {
+		wk_buf = NULL;
+		size = 0;
+	}
+
+	pdrvextra_cmd_parm->ec_id = BEAMFORMING_WK_CID;
+	pdrvextra_cmd_parm->type = type;
+	pdrvextra_cmd_parm->size = size;
+	pdrvextra_cmd_parm->pbuf = wk_buf;
+
+	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+
+exit:
+	return res;
+}
+
+void rtw_bf_update_attrib(PADAPTER adapter, struct pkt_attrib *attrib, struct sta_info *sta)
+{
+	if (sta) {
+		attrib->txbf_g_id = sta->cmn.bf_info.g_id;
+		attrib->txbf_p_aid = sta->cmn.bf_info.p_aid;
+	}
+}
+
+void rtw_bf_c2h_handler(PADAPTER adapter, u8 id, u8 *buf, u8 buf_len)
+{
+	switch (id) {
+	case CMD_ID_C2H_SND_TXBF:
+		_c2h_snd_txbf(adapter, buf, buf_len);
+		break;
+	}
+}
+
+#define toMbps(bytes, secs)	(rtw_division64(bytes >> 17, secs))
+void rtw_bf_update_traffic(PADAPTER adapter)
+{
+	struct beamforming_info	*info;
+	struct sounding_info *sounding;
+	struct beamformee_entry *bfee;
+	struct sta_info *sta;
+	u8 bfee_cnt, sounding_idx, i;
+	u16 tp[MAX_BEAMFORMEE_ENTRY_NUM] = {0};
+	u8 tx_rate[MAX_BEAMFORMEE_ENTRY_NUM] = {0};
+	u64 tx_bytes, last_bytes;
+	u32 time;
+	systime last_timestamp;
+	u8 set_timer = _FALSE;
+
+
+	info = GET_BEAMFORM_INFO(adapter);
+	sounding = &info->sounding_info;
+
+	/* Check any bfee exist? */
+	bfee_cnt = info->beamformee_su_cnt + info->beamformee_mu_cnt;
+	if (bfee_cnt == 0)
+		return;
+
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (_FALSE == bfee->used)
+			continue;
+
+		sta = rtw_get_stainfo(&adapter->stapriv, bfee->mac_addr);
+		if (!sta) {
+			RTW_ERR("%s: Cann't find sta_info for " MAC_FMT "!\n", __FUNCTION__, MAC_ARG(bfee->mac_addr));
+			continue;
+		}
+
+		last_timestamp = bfee->tx_timestamp;
+		last_bytes = bfee->tx_bytes;
+		bfee->tx_timestamp = rtw_get_current_time();
+		bfee->tx_bytes = sta->sta_stats.tx_bytes;
+		if (last_timestamp) {
+			if (bfee->tx_bytes >= last_bytes)
+				tx_bytes = bfee->tx_bytes - last_bytes;
+			else
+				tx_bytes = bfee->tx_bytes + (~last_bytes);
+			time = rtw_get_time_interval_ms(last_timestamp, bfee->tx_timestamp);
+			time = (time > 1000) ? time/1000 : 1;
+			tp[i] = toMbps(tx_bytes, time);
+			tx_rate[i] = rtw_get_current_tx_rate(adapter, sta);
+			RTW_INFO("%s: BFee idx(%d), MadId(%d), TxTP=%lld bytes (%d Mbps), txrate=%d\n",
+				 __FUNCTION__, i, bfee->mac_id, tx_bytes, tp[i], tx_rate[i]);
+		}
+	}
+
+	sounding_idx = phydm_get_beamforming_sounding_info(GET_PDM_ODM(adapter), tp, MAX_BEAMFORMEE_ENTRY_NUM, tx_rate);
+
+	for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
+		bfee = &info->bfee_entry[i];
+		if (_FALSE == bfee->used) {
+			if (sounding_idx & BIT(i))
+				RTW_WARN("%s: bfee(%d) not in used but need sounding?!\n", __FUNCTION__, i);
+			continue;
+		}
+
+		if (sounding_idx & BIT(i)) {
+			if (_FALSE == bfee->bApplySounding) {
+				bfee->bApplySounding = _TRUE;
+				bfee->SoundCnt = 0;
+				set_timer = _TRUE;
+			}
+		} else {
+			if (_TRUE == bfee->bApplySounding) {
+				bfee->bApplySounding = _FALSE;
+				bfee->bDeleteSounding = _TRUE;
+				bfee->SoundCnt = 0;
+				set_timer = _TRUE;
+			}
+		}
+	}
+
+	if (_TRUE == set_timer) {
+		if (SOUNDING_STATE_NONE == info->sounding_info.state) {
+			info->sounding_info.state = SOUNDING_STATE_INIT;
+			_set_timer(&info->sounding_timer, 0);
+		}
+	}
+}
+
+#else /* !RTW_BEAMFORMING_VERSION_2 */
+
+#if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
+struct beamforming_entry	*beamforming_get_entry_by_addr(struct mlme_priv *pmlmepriv, u8 *ra, u8 *idx)
+{
+	u8	i = 0;
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+
+	for (i = 0; i < BEAMFORMING_ENTRY_NUM; i++) {
+		if (pBeamInfo->beamforming_entry[i].bUsed &&
+		    (_rtw_memcmp(ra, pBeamInfo->beamforming_entry[i].mac_addr, ETH_ALEN))) {
+			*idx = i;
+			return &(pBeamInfo->beamforming_entry[i]);
+		}
+	}
+
+	return NULL;
+}
+
+BEAMFORMING_CAP beamforming_get_entry_beam_cap_by_mac_id(PVOID pmlmepriv , u8 mac_id)
+{
+	u8	i = 0;
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO((struct mlme_priv *)pmlmepriv);
+	BEAMFORMING_CAP		BeamformEntryCap = BEAMFORMING_CAP_NONE;
+
+	for (i = 0; i < BEAMFORMING_ENTRY_NUM; i++) {
+		if (pBeamInfo->beamforming_entry[i].bUsed &&
+		    (mac_id == pBeamInfo->beamforming_entry[i].mac_id)) {
+			BeamformEntryCap =  pBeamInfo->beamforming_entry[i].beamforming_entry_cap;
+			i = BEAMFORMING_ENTRY_NUM;
+		}
+	}
+
+	return BeamformEntryCap;
+}
+
+struct beamforming_entry	*beamforming_get_free_entry(struct mlme_priv *pmlmepriv, u8 *idx)
+{
+	u8	i = 0;
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+
+	for (i = 0; i < BEAMFORMING_ENTRY_NUM; i++) {
+		if (pBeamInfo->beamforming_entry[i].bUsed == _FALSE) {
+			*idx = i;
+			return &(pBeamInfo->beamforming_entry[i]);
+		}
+	}
+	return NULL;
+}
+
+
+struct beamforming_entry	*beamforming_add_entry(PADAPTER adapter, u8 *ra, u16 aid,
+	u16 mac_id, enum channel_width bw, BEAMFORMING_CAP beamfrom_cap, u8 *idx)
+{
+	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
+	struct beamforming_entry	*pEntry = beamforming_get_free_entry(pmlmepriv, idx);
+
+	if (pEntry != NULL) {
+		pEntry->bUsed = _TRUE;
+		pEntry->aid = aid;
+		pEntry->mac_id = mac_id;
+		pEntry->sound_bw = bw;
+		if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
+			u16	BSSID = ((*(adapter_mac_addr(adapter) + 5) & 0xf0) >> 4) ^
+				(*(adapter_mac_addr(adapter) + 5) & 0xf); /* BSSID[44:47] xor BSSID[40:43] */
+			pEntry->p_aid = (aid + BSSID * 32) & 0x1ff;		/* (dec(A) + dec(B)*32) mod 512 */
+			pEntry->g_id = 63;
+		} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
+			pEntry->p_aid = 0;
+			pEntry->g_id = 63;
+		} else {
+			pEntry->p_aid =  ra[5];						/* BSSID[39:47] */
+			pEntry->p_aid = (pEntry->p_aid << 1) | (ra[4] >> 7);
+			pEntry->g_id = 0;
+		}
+		_rtw_memcpy(pEntry->mac_addr, ra, ETH_ALEN);
+		pEntry->bSound = _FALSE;
+
+		/* 3 TODO SW/FW sound period */
+		pEntry->sound_period = 200;
+		pEntry->beamforming_entry_cap = beamfrom_cap;
+		pEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+
+
+		pEntry->PreLogSeq = 0;	/*Modified by Jeffery @2015-04-13*/
+		pEntry->LogSeq = 0;		/*Modified by Jeffery @2014-10-29*/
+		pEntry->LogRetryCnt = 0;	/*Modified by Jeffery @2014-10-29*/
+		pEntry->LogSuccess = 0;	/*LogSuccess is NOT needed to be accumulated, so  LogSuccessCnt->LogSuccess, 2015-04-13, Jeffery*/
+		pEntry->ClockResetTimes = 0;	/*Modified by Jeffery @2015-04-13*/
+		pEntry->LogStatusFailCnt = 0;
+
+		return pEntry;
+	} else
+		return NULL;
+}
+
+BOOLEAN	beamforming_remove_entry(struct mlme_priv *pmlmepriv, u8 *ra, u8 *idx)
+{
+	struct beamforming_entry	*pEntry = beamforming_get_entry_by_addr(pmlmepriv, ra, idx);
+
+	if (pEntry != NULL) {
+		pEntry->bUsed = _FALSE;
+		pEntry->beamforming_entry_cap = BEAMFORMING_CAP_NONE;
+		pEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		return _TRUE;
+	} else
+		return _FALSE;
+}
+
+/* Used for BeamformingStart_V1 */
+void	beamforming_dym_ndpa_rate(PADAPTER adapter)
+{
+	u16	NDPARate = MGN_6M;
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
+	s8 min_rssi = 0;
+
+	min_rssi = rtw_phydm_get_min_rssi(adapter);
+	if (min_rssi > 30) /* link RSSI > 30% */
+		NDPARate = MGN_24M;
+	else
+		NDPARate = MGN_6M;
+
+	/* BW = CHANNEL_WIDTH_20; */
+	NDPARate = NDPARate << 8;
+	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_RATE, (u8 *)&NDPARate);
+}
+
+void beamforming_dym_period(PADAPTER Adapter)
+{
+	u8	Idx;
+	BOOLEAN	bChangePeriod = _FALSE;
+	u16	SoundPeriod_SW, SoundPeriod_FW;
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(Adapter);
+	struct beamforming_entry	*pBeamformEntry;
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO((&Adapter->mlmepriv));
+	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
+
+	/* 3 TODO  per-client throughput caculation. */
+
+	if (pdvobjpriv->traffic_stat.cur_tx_tp + pdvobjpriv->traffic_stat.cur_rx_tp > 2) {
+		SoundPeriod_SW = 32 * 20;
+		SoundPeriod_FW = 2;
+	} else {
+		SoundPeriod_SW = 32 * 2000;
+		SoundPeriod_FW = 200;
+	}
+
+	for (Idx = 0; Idx < BEAMFORMING_ENTRY_NUM; Idx++) {
+		pBeamformEntry = pBeamInfo->beamforming_entry + Idx;
+		if (pBeamformEntry->bDefaultCSI) {
+			SoundPeriod_SW = 32 * 2000;
+			SoundPeriod_FW = 200;
+		}
+
+		if (pBeamformEntry->beamforming_entry_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) {
+			if (pSoundInfo->sound_mode == SOUNDING_FW_VHT_TIMER || pSoundInfo->sound_mode == SOUNDING_FW_HT_TIMER) {
+				if (pBeamformEntry->sound_period != SoundPeriod_FW) {
+					pBeamformEntry->sound_period = SoundPeriod_FW;
+					bChangePeriod = _TRUE;	/* Only FW sounding need to send H2C packet to change sound period. */
+				}
+			} else if (pBeamformEntry->sound_period != SoundPeriod_SW)
+				pBeamformEntry->sound_period = SoundPeriod_SW;
+		}
+	}
+
+	if (bChangePeriod)
+		rtw_hal_set_hwreg(Adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&Idx);
+}
+
+BOOLEAN	issue_ht_sw_ndpa_packet(PADAPTER Adapter, u8 *ra, enum channel_width bw, u8 qidx)
+{
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	aSifsTime = 0;
+	u8	NDPTxRate = 0;
+
+	RTW_INFO("%s: issue_ht_sw_ndpa_packet!\n", __func__);
+
+	NDPTxRate = MGN_MCS8;
+	RTW_INFO("%s: NDPTxRate =%d\n", __func__, NDPTxRate);
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL)
+		return _FALSE;
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(Adapter, pattrib);
+	pattrib->qsel = QSLT_MGNT;
+	pattrib->rate = NDPTxRate;
+	pattrib->bwmode = bw;
+	pattrib->order = 1;
+	pattrib->subtype = WIFI_ACTION_NOACK;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_order_bit(pframe);
+	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
+
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
+		aSifsTime = 10;
+	else
+		aSifsTime = 16;
+
+	duration = 2 * aSifsTime + 40;
+
+	if (bw == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	/*HT control field*/
+	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
+
+	_rtw_memcpy(pframe + 28, ActionHdr, 4);
+
+	pattrib->pktlen = 32;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(Adapter, pmgntframe);
+
+	return _TRUE;
+
+
+}
+BOOLEAN	issue_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, enum channel_width bw, u8 qidx)
+{
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	aSifsTime = 0;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL)
+		return _FALSE;
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(Adapter, pattrib);
+
+	if (qidx == BCN_QUEUE_INX)
+		pattrib->qsel = QSLT_BEACON;
+	pattrib->rate = MGN_MCS8;
+	pattrib->bwmode = bw;
+	pattrib->order = 1;
+	pattrib->subtype = WIFI_ACTION_NOACK;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_order_bit(pframe);
+	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
+
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
+		aSifsTime = 10;
+	else
+		aSifsTime = 16;
+
+	duration = 2 * aSifsTime + 40;
+
+	if (bw == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	/* HT control field */
+	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
+
+	_rtw_memcpy(pframe + 28, ActionHdr, 4);
+
+	pattrib->pktlen = 32;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(Adapter, pmgntframe);
+
+	return _TRUE;
+}
+
+BOOLEAN	beamforming_send_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, enum channel_width bw, u8 qidx)
+{
+	return issue_ht_ndpa_packet(Adapter, ra, bw, qidx);
+}
+BOOLEAN	issue_vht_sw_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, enum channel_width bw, u8 qidx)
+{
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv		*pmlmepriv = &(Adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+	struct rtw_ndpa_sta_info	sta_info;
+	u8		 NDPTxRate = 0;
+
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	sequence = 0, aSifsTime = 0;
+
+	RTW_INFO("%s: issue_vht_sw_ndpa_packet!\n", __func__);
+
+
+	NDPTxRate = MGN_VHT2SS_MCS0;
+	RTW_INFO("%s: NDPTxRate =%d\n", __func__, NDPTxRate);
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		RTW_INFO("%s, alloc mgnt frame fail\n", __func__);
+		return _FALSE;
+	}
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(Adapter, pattrib);
+	pattrib->qsel = QSLT_MGNT;
+	pattrib->rate = NDPTxRate;
+	pattrib->bwmode = bw;
+	pattrib->subtype = WIFI_NDPA;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_frame_sub_type(pframe, WIFI_NDPA);
+
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		aSifsTime = 16;
+	else
+		aSifsTime = 10;
+
+	duration = 2 * aSifsTime + 44;
+
+	if (bw == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (bw == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	sequence = pBeamInfo->sounding_sequence << 2;
+	if (pBeamInfo->sounding_sequence >= 0x3f)
+		pBeamInfo->sounding_sequence = 0;
+	else
+		pBeamInfo->sounding_sequence++;
+
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		aid = 0;
+
+	sta_info.aid = aid;
+	sta_info.feedback_type = 0;
+	sta_info.nc_index = 0;
+
+	_rtw_memcpy(pframe + 17, (u8 *)&sta_info, 2);
+
+	pattrib->pktlen = 19;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(Adapter, pmgntframe);
+
+
+	return _TRUE;
+
+}
+BOOLEAN	issue_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, enum channel_width bw, u8 qidx)
+{
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv		*pmlmepriv = &(Adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+	struct rtw_ndpa_sta_info	sta_info;
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	sequence = 0, aSifsTime = 0;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return _FALSE;
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(Adapter, pattrib);
+
+	if (qidx == BCN_QUEUE_INX)
+		pattrib->qsel = QSLT_BEACON;
+	pattrib->rate = MGN_VHT2SS_MCS0;
+	pattrib->bwmode = bw;
+	pattrib->subtype = WIFI_NDPA;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_frame_sub_type(pframe, WIFI_NDPA);
+
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(Adapter), ETH_ALEN);
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		aSifsTime = 16;
+	else
+		aSifsTime = 10;
+
+	duration = 2 * aSifsTime + 44;
+
+	if (bw == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (bw == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	sequence = pBeamInfo->sounding_sequence << 2;
+	if (pBeamInfo->sounding_sequence >= 0x3f)
+		pBeamInfo->sounding_sequence = 0;
+	else
+		pBeamInfo->sounding_sequence++;
+
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		aid = 0;
+
+	sta_info.aid = aid;
+	sta_info.feedback_type = 0;
+	sta_info.nc_index = 0;
+
+	_rtw_memcpy(pframe + 17, (u8 *)&sta_info, 2);
+
+	pattrib->pktlen = 19;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(Adapter, pmgntframe);
+
+	return _TRUE;
+}
+
+BOOLEAN	beamforming_send_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, enum channel_width bw, u8 qidx)
+{
+	return issue_vht_ndpa_packet(Adapter, ra, aid, bw, qidx);
+}
+
+BOOLEAN	beamfomring_bSounding(struct beamforming_info *pBeamInfo)
+{
+	BOOLEAN		bSounding = _FALSE;
+
+	if ((beamforming_get_beamform_cap(pBeamInfo) & BEAMFORMER_CAP) == 0)
+		bSounding = _FALSE;
+	else
+		bSounding = _TRUE;
+
+	return bSounding;
+}
+
+u8	beamforming_sounding_idx(struct beamforming_info *pBeamInfo)
+{
+	u8	idx = 0;
+	u8	i;
+
+	for (i = 0; i < BEAMFORMING_ENTRY_NUM; i++) {
+		if (pBeamInfo->beamforming_entry[i].bUsed &&
+		    (_FALSE == pBeamInfo->beamforming_entry[i].bSound)) {
+			idx = i;
+			break;
+		}
+	}
+
+	return idx;
+}
+
+SOUNDING_MODE	beamforming_sounding_mode(struct beamforming_info *pBeamInfo, u8 idx)
+{
+	struct beamforming_entry	BeamEntry = pBeamInfo->beamforming_entry[idx];
+	SOUNDING_MODE	mode;
+
+	if (BeamEntry.beamforming_entry_cap & BEAMFORMER_CAP_VHT_SU)
+		mode = SOUNDING_FW_VHT_TIMER;
+	else if (BeamEntry.beamforming_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+		mode = SOUNDING_FW_HT_TIMER;
+	else
+		mode = SOUNDING_STOP_All_TIMER;
+
+	return mode;
+}
+
+u16	beamforming_sounding_time(struct beamforming_info *pBeamInfo, SOUNDING_MODE mode, u8 idx)
+{
+	u16						sounding_time = 0xffff;
+	struct beamforming_entry	BeamEntry = pBeamInfo->beamforming_entry[idx];
+
+	sounding_time = BeamEntry.sound_period;
+
+	return sounding_time;
+}
+
+enum channel_width	beamforming_sounding_bw(struct beamforming_info *pBeamInfo, SOUNDING_MODE mode, u8 idx)
+{
+	enum channel_width				sounding_bw = CHANNEL_WIDTH_20;
+	struct beamforming_entry		BeamEntry = pBeamInfo->beamforming_entry[idx];
+
+	sounding_bw = BeamEntry.sound_bw;
+
+	return sounding_bw;
+}
+
+BOOLEAN	beamforming_select_beam_entry(struct beamforming_info *pBeamInfo)
+{
+	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
+
+	pSoundInfo->sound_idx = beamforming_sounding_idx(pBeamInfo);
+
+	if (pSoundInfo->sound_idx < BEAMFORMING_ENTRY_NUM)
+		pSoundInfo->sound_mode = beamforming_sounding_mode(pBeamInfo, pSoundInfo->sound_idx);
+	else
+		pSoundInfo->sound_mode = SOUNDING_STOP_All_TIMER;
+
+	if (SOUNDING_STOP_All_TIMER == pSoundInfo->sound_mode)
+		return _FALSE;
+	else {
+		pSoundInfo->sound_bw = beamforming_sounding_bw(pBeamInfo, pSoundInfo->sound_mode, pSoundInfo->sound_idx);
+		pSoundInfo->sound_period = beamforming_sounding_time(pBeamInfo, pSoundInfo->sound_mode, pSoundInfo->sound_idx);
+		return _TRUE;
+	}
+}
+
+BOOLEAN	beamforming_start_fw(PADAPTER adapter, u8 idx)
+{
+	u8						*RA = NULL;
+	struct beamforming_entry	*pEntry;
+	BOOLEAN					ret = _TRUE;
+	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+
+	pEntry = &(pBeamInfo->beamforming_entry[idx]);
+	if (pEntry->bUsed == _FALSE) {
+		RTW_INFO("Skip Beamforming, no entry for Idx =%d\n", idx);
+		return _FALSE;
+	}
+
+	pEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+	pEntry->bSound = _TRUE;
+	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&idx);
+
+	return _TRUE;
+}
+
+void	beamforming_end_fw(PADAPTER adapter)
+{
+	u8	idx = 0;
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&idx);
+
+	RTW_INFO("%s\n", __FUNCTION__);
+}
+
+BOOLEAN	beamforming_start_period(PADAPTER adapter)
+{
+	BOOLEAN	ret = _TRUE;
+	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
+
+	beamforming_dym_ndpa_rate(adapter);
+
+	beamforming_select_beam_entry(pBeamInfo);
+
+	if (pSoundInfo->sound_mode == SOUNDING_FW_VHT_TIMER || pSoundInfo->sound_mode == SOUNDING_FW_HT_TIMER)
+		ret = beamforming_start_fw(adapter, pSoundInfo->sound_idx);
+	else
+		ret = _FALSE;
+
+	RTW_INFO("%s Idx %d Mode %d BW %d Period %d\n", __FUNCTION__,
+		pSoundInfo->sound_idx, pSoundInfo->sound_mode, pSoundInfo->sound_bw, pSoundInfo->sound_period);
+
+	return ret;
+}
+
+void	beamforming_end_period(PADAPTER adapter)
+{
+	u8						idx = 0;
+	struct beamforming_entry	*pBeamformEntry;
+	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+	struct sounding_info		*pSoundInfo = &(pBeamInfo->sounding_info);
+
+
+	if (pSoundInfo->sound_mode == SOUNDING_FW_VHT_TIMER || pSoundInfo->sound_mode == SOUNDING_FW_HT_TIMER)
+		beamforming_end_fw(adapter);
+}
+
+void	beamforming_notify(PADAPTER adapter)
+{
+	BOOLEAN		bSounding = _FALSE;
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(&(adapter->mlmepriv));
+
+	bSounding = beamfomring_bSounding(pBeamInfo);
+
+	if (pBeamInfo->beamforming_state == BEAMFORMING_STATE_IDLE) {
+		if (bSounding) {
+			if (beamforming_start_period(adapter) == _TRUE)
+				pBeamInfo->beamforming_state = BEAMFORMING_STATE_START;
+		}
+	} else if (pBeamInfo->beamforming_state == BEAMFORMING_STATE_START) {
+		if (bSounding) {
+			if (beamforming_start_period(adapter) == _FALSE)
+				pBeamInfo->beamforming_state = BEAMFORMING_STATE_END;
+		} else {
+			beamforming_end_period(adapter);
+			pBeamInfo->beamforming_state = BEAMFORMING_STATE_END;
+		}
+	} else if (pBeamInfo->beamforming_state == BEAMFORMING_STATE_END) {
+		if (bSounding) {
+			if (beamforming_start_period(adapter) == _TRUE)
+				pBeamInfo->beamforming_state = BEAMFORMING_STATE_START;
+		}
+	} else
+		RTW_INFO("%s BeamformState %d\n", __FUNCTION__, pBeamInfo->beamforming_state);
+
+	RTW_INFO("%s BeamformState %d bSounding %d\n", __FUNCTION__, pBeamInfo->beamforming_state, bSounding);
+}
+
+BOOLEAN	beamforming_init_entry(PADAPTER	adapter, struct sta_info *psta, u8 *idx)
+{
+	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
+	struct ht_priv		*phtpriv = &(pmlmepriv->htpriv);
+#ifdef CONFIG_80211AC_VHT
+	struct vht_priv		*pvhtpriv = &(pmlmepriv->vhtpriv);
+#endif
+	struct mlme_ext_priv	*pmlmeext = &(adapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct beamforming_entry	*pBeamformEntry = NULL;
+	u8	*ra;
+	u16	aid, mac_id;
+	u8	wireless_mode;
+	enum channel_width	bw = CHANNEL_WIDTH_20;
+	BEAMFORMING_CAP	beamform_cap = BEAMFORMING_CAP_NONE;
+
+	/* The current setting does not support Beaforming */
+	if (0 == phtpriv->beamform_cap
+#ifdef CONFIG_80211AC_VHT
+	    && 0 == pvhtpriv->beamform_cap
+#endif
+	   ) {
+		RTW_INFO("The configuration disabled Beamforming! Skip...\n");
+		return _FALSE;
+	}
+
+	aid = psta->cmn.aid;
+	ra = psta->cmn.mac_addr;
+	mac_id = psta->cmn.mac_id;
+	wireless_mode = psta->wireless_mode;
+	bw = psta->cmn.bw_mode;
+
+	if (is_supported_ht(wireless_mode) || is_supported_vht(wireless_mode)) {
+		/* 3 */ /* HT */
+		u8	cur_beamform;
+
+		cur_beamform = psta->htpriv.beamform_cap;
+
+		/* We are Beamformee because the STA is Beamformer */
+		if (TEST_FLAG(cur_beamform, BEAMFORMING_HT_BEAMFORMER_ENABLE))
+			beamform_cap = (BEAMFORMING_CAP)(beamform_cap | BEAMFORMEE_CAP_HT_EXPLICIT);
+
+		/* We are Beamformer because the STA is Beamformee */
+		if (TEST_FLAG(cur_beamform, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+			beamform_cap = (BEAMFORMING_CAP)(beamform_cap | BEAMFORMER_CAP_HT_EXPLICIT);
+#ifdef CONFIG_80211AC_VHT
+		if (is_supported_vht(wireless_mode)) {
+			/* 3 */ /* VHT */
+			cur_beamform = psta->vhtpriv.beamform_cap;
+
+			/* We are Beamformee because the STA is Beamformer */
+			if (TEST_FLAG(cur_beamform, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
+				beamform_cap = (BEAMFORMING_CAP)(beamform_cap | BEAMFORMEE_CAP_VHT_SU);
+			/* We are Beamformer because the STA is Beamformee */
+			if (TEST_FLAG(cur_beamform, BEAMFORMING_VHT_BEAMFORMEE_ENABLE))
+				beamform_cap = (BEAMFORMING_CAP)(beamform_cap | BEAMFORMER_CAP_VHT_SU);
+		}
+#endif /* CONFIG_80211AC_VHT */
+
+		if (beamform_cap == BEAMFORMING_CAP_NONE)
+			return _FALSE;
+
+		RTW_INFO("Beamforming Config Capability = 0x%02X\n", beamform_cap);
+
+		pBeamformEntry = beamforming_get_entry_by_addr(pmlmepriv, ra, idx);
+		if (pBeamformEntry == NULL) {
+			pBeamformEntry = beamforming_add_entry(adapter, ra, aid, mac_id, bw, beamform_cap, idx);
+			if (pBeamformEntry == NULL)
+				return _FALSE;
+			else
+				pBeamformEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+		} else {
+			/* Entry has been created. If entry is initialing or progressing then errors occur. */
+			if (pBeamformEntry->beamforming_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED &&
+			    pBeamformEntry->beamforming_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+				RTW_INFO("Error State of Beamforming");
+				return _FALSE;
+			} else
+				pBeamformEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+		}
+
+		pBeamformEntry->beamforming_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+		psta->cmn.bf_info.p_aid = pBeamformEntry->p_aid;
+		psta->cmn.bf_info.g_id = pBeamformEntry->g_id;
+
+		RTW_INFO("%s Idx %d\n", __FUNCTION__, *idx);
+	} else
+		return _FALSE;
+
+	return _SUCCESS;
+}
+
+void	beamforming_deinit_entry(PADAPTER adapter, u8 *ra)
+{
+	u8	idx = 0;
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+
+	if (beamforming_remove_entry(pmlmepriv, ra, &idx) == _TRUE)
+		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_LEAVE, (u8 *)&idx);
+
+	RTW_INFO("%s Idx %d\n", __FUNCTION__, idx);
+}
+
+void	beamforming_reset(PADAPTER adapter)
+{
+	u8	idx = 0;
+	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+
+	for (idx = 0; idx < BEAMFORMING_ENTRY_NUM; idx++) {
+		if (pBeamInfo->beamforming_entry[idx].bUsed == _TRUE) {
+			pBeamInfo->beamforming_entry[idx].bUsed = _FALSE;
+			pBeamInfo->beamforming_entry[idx].beamforming_entry_cap = BEAMFORMING_CAP_NONE;
+			pBeamInfo->beamforming_entry[idx].beamforming_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+			rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_LEAVE, (u8 *)&idx);
+		}
+	}
+
+	RTW_INFO("%s\n", __FUNCTION__);
+}
+
+void beamforming_sounding_fail(PADAPTER Adapter)
+{
+	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+	struct beamforming_entry	*pEntry = &(pBeamInfo->beamforming_entry[pBeamInfo->beamforming_cur_idx]);
+
+	pEntry->bSound = _FALSE;
+	rtw_hal_set_hwreg(Adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&pBeamInfo->beamforming_cur_idx);
+	beamforming_deinit_entry(Adapter, pEntry->mac_addr);
+}
+
+void	beamforming_check_sounding_success(PADAPTER Adapter, BOOLEAN status)
+{
+	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO(pmlmepriv);
+	struct beamforming_entry	*pEntry = &(pBeamInfo->beamforming_entry[pBeamInfo->beamforming_cur_idx]);
+
+	if (status == 1)
+		pEntry->LogStatusFailCnt = 0;
+	else {
+		pEntry->LogStatusFailCnt++;
+		RTW_INFO("%s LogStatusFailCnt %d\n", __FUNCTION__, pEntry->LogStatusFailCnt);
+	}
+	if (pEntry->LogStatusFailCnt > 20) {
+		RTW_INFO("%s LogStatusFailCnt > 20, Stop SOUNDING\n", __FUNCTION__);
+		/* pEntry->bSound = _FALSE; */
+		/* rtw_hal_set_hwreg(Adapter, HW_VAR_SOUNDING_FW_NDPA, (u8 *)&pBeamInfo->beamforming_cur_idx); */
+		/* beamforming_deinit_entry(Adapter, pEntry->mac_addr); */
+		beamforming_wk_cmd(Adapter, BEAMFORMING_CTRL_SOUNDING_FAIL, NULL, 0, 1);
+	}
+}
+
+void	beamforming_enter(PADAPTER adapter, PVOID psta)
+{
+	u8	idx = 0xff;
+
+	if (beamforming_init_entry(adapter, (struct sta_info *)psta, &idx))
+		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_ENTER, (u8 *)&idx);
+
+	/* RTW_INFO("%s Idx %d\n", __FUNCTION__, idx); */
+}
+
+void	beamforming_leave(PADAPTER adapter, u8 *ra)
+{
+	if (ra == NULL)
+		beamforming_reset(adapter);
+	else
+		beamforming_deinit_entry(adapter, ra);
+
+	beamforming_notify(adapter);
+}
+
+BEAMFORMING_CAP beamforming_get_beamform_cap(struct beamforming_info	*pBeamInfo)
+{
+	u8	i;
+	BOOLEAN				bSelfBeamformer = _FALSE;
+	BOOLEAN				bSelfBeamformee = _FALSE;
+	struct beamforming_entry	beamforming_entry;
+	BEAMFORMING_CAP		beamform_cap = BEAMFORMING_CAP_NONE;
+
+	for (i = 0; i < BEAMFORMING_ENTRY_NUM; i++) {
+		beamforming_entry = pBeamInfo->beamforming_entry[i];
+
+		if (beamforming_entry.bUsed) {
+			if ((beamforming_entry.beamforming_entry_cap & BEAMFORMEE_CAP_VHT_SU) ||
+			    (beamforming_entry.beamforming_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT))
+				bSelfBeamformee = _TRUE;
+			if ((beamforming_entry.beamforming_entry_cap & BEAMFORMER_CAP_VHT_SU) ||
+			    (beamforming_entry.beamforming_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT))
+				bSelfBeamformer = _TRUE;
+		}
+
+		if (bSelfBeamformer && bSelfBeamformee)
+			i = BEAMFORMING_ENTRY_NUM;
+	}
+
+	if (bSelfBeamformer)
+		beamform_cap |= BEAMFORMER_CAP;
+	if (bSelfBeamformee)
+		beamform_cap |= BEAMFORMEE_CAP;
+
+	return beamform_cap;
+}
+
+void	beamforming_watchdog(PADAPTER Adapter)
+{
+	struct beamforming_info	*pBeamInfo = GET_BEAMFORM_INFO((&(Adapter->mlmepriv)));
+
+	if (pBeamInfo->beamforming_state != BEAMFORMING_STATE_START)
+		return;
+
+	beamforming_dym_period(Adapter);
+	beamforming_dym_ndpa_rate(Adapter);
+}
+#endif/* #if (BEAMFORMING_SUPPORT ==0) - for diver defined beamforming*/
+
+u32	rtw_beamforming_get_report_frame(PADAPTER	 Adapter, union recv_frame *precv_frame)
+{
+	u32	ret = _SUCCESS;
+#if (BEAMFORMING_SUPPORT == 1)
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+
+	ret = beamforming_get_report_frame(pDM_Odm, precv_frame);
+
+#else /*(BEAMFORMING_SUPPORT == 0)- for drv beamfoming*/
+	struct beamforming_entry	*pBeamformEntry = NULL;
+	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
+	u8	*pframe = precv_frame->u.hdr.rx_data;
+	u32	frame_len = precv_frame->u.hdr.len;
+	u8	*ta;
+	u8	idx, offset;
+
+	/*RTW_INFO("rtw_beamforming_get_report_frame\n");*/
+
+	/*Memory comparison to see if CSI report is the same with previous one*/
+	ta = get_addr2_ptr(pframe);
+	pBeamformEntry = beamforming_get_entry_by_addr(pmlmepriv, ta, &idx);
+	if (pBeamformEntry->beamforming_entry_cap & BEAMFORMER_CAP_VHT_SU)
+		offset = 31;	/*24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)*/
+	else if (pBeamformEntry->beamforming_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+		offset = 34;	/*24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)*/
+	else
+		return ret;
+
+	/*RTW_INFO("%s MacId %d offset=%d\n", __FUNCTION__, pBeamformEntry->mac_id, offset);*/
+
+	if (_rtw_memcmp(pBeamformEntry->PreCsiReport + offset, pframe + offset, frame_len - offset) == _FALSE)
+		pBeamformEntry->DefaultCsiCnt = 0;
+	else
+		pBeamformEntry->DefaultCsiCnt++;
+
+	_rtw_memcpy(&pBeamformEntry->PreCsiReport, pframe, frame_len);
+
+	pBeamformEntry->bDefaultCSI = _FALSE;
+
+	if (pBeamformEntry->DefaultCsiCnt > 20)
+		pBeamformEntry->bDefaultCSI = _TRUE;
+	else
+		pBeamformEntry->bDefaultCSI = _FALSE;
+#endif
+	return ret;
+}
+
+void	rtw_beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_frame)
+{
+#if (BEAMFORMING_SUPPORT == 1)
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+
+	beamforming_get_ndpa_frame(pDM_Odm, precv_frame);
+
+#else /*(BEAMFORMING_SUPPORT == 0)- for drv beamfoming*/
+	u8	*ta;
+	u8	idx, Sequence;
+	u8	*pframe = precv_frame->u.hdr.rx_data;
+	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
+	struct beamforming_entry	*pBeamformEntry = NULL;
+
+	/*RTW_INFO("rtw_beamforming_get_ndpa_frame\n");*/
+
+	if (IS_HARDWARE_TYPE_8812(Adapter) == _FALSE)
+		return;
+	else if (get_frame_sub_type(pframe) != WIFI_NDPA)
+		return;
+
+	ta = get_addr2_ptr(pframe);
+	/*Remove signaling TA. */
+	ta[0] = ta[0] & 0xFE;
+
+	pBeamformEntry = beamforming_get_entry_by_addr(pmlmepriv, ta, &idx);
+
+	if (pBeamformEntry == NULL)
+		return;
+	else if (!(pBeamformEntry->beamforming_entry_cap & BEAMFORMEE_CAP_VHT_SU))
+		return;
+	/*LogSuccess: As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is NO LONGER needed !2015-04-10, Jeffery*/
+	/*ClockResetTimes: While BFer entry always doesn't receive our CSI, clock will reset again and again.So ClockResetTimes is limited to 5 times.2015-04-13, Jeffery*/
+	else if ((pBeamformEntry->LogSuccess == 1) || (pBeamformEntry->ClockResetTimes == 5)) {
+		RTW_INFO("[%s] LogSeq=%d, PreLogSeq=%d\n", __func__, pBeamformEntry->LogSeq, pBeamformEntry->PreLogSeq);
+		return;
+	}
+
+	Sequence = (pframe[16]) >> 2;
+	RTW_INFO("[%s] Start, Sequence=%d, LogSeq=%d, PreLogSeq=%d, LogRetryCnt=%d, ClockResetTimes=%d, LogSuccess=%d\n",
+		__func__, Sequence, pBeamformEntry->LogSeq, pBeamformEntry->PreLogSeq, pBeamformEntry->LogRetryCnt, pBeamformEntry->ClockResetTimes, pBeamformEntry->LogSuccess);
+
+	if ((pBeamformEntry->LogSeq != 0) && (pBeamformEntry->PreLogSeq != 0)) {
+		/*Success condition*/
+		if ((pBeamformEntry->LogSeq != Sequence) && (pBeamformEntry->PreLogSeq != pBeamformEntry->LogSeq)) {
+			/* break option for clcok reset, 2015-03-30, Jeffery */
+			pBeamformEntry->LogRetryCnt = 0;
+			/*As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is no longer needed.*/
+			/*That is, LogSuccess is NOT needed to be reset to zero, 2015-04-13, Jeffery*/
+			pBeamformEntry->LogSuccess = 1;
+
+		} else {/*Fail condition*/
+
+			if (pBeamformEntry->LogRetryCnt == 5) {
+				pBeamformEntry->ClockResetTimes++;
+				pBeamformEntry->LogRetryCnt = 0;
+
+				RTW_INFO("[%s] Clock Reset!!! ClockResetTimes=%d\n",  __func__, pBeamformEntry->ClockResetTimes);
+				beamforming_wk_cmd(Adapter, BEAMFORMING_CTRL_SOUNDING_CLK, NULL, 0, 1);
+
+			} else
+				pBeamformEntry->LogRetryCnt++;
+		}
+	}
+
+	/*Update LogSeq & PreLogSeq*/
+	pBeamformEntry->PreLogSeq = pBeamformEntry->LogSeq;
+	pBeamformEntry->LogSeq = Sequence;
+
+#endif
+
+}
+
+
+
+
+void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf)
+{
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+
+#if (BEAMFORMING_SUPPORT == 1) /*(BEAMFORMING_SUPPORT == 1)- for PHYDM beamfoming*/
+	switch (type) {
+	case BEAMFORMING_CTRL_ENTER: {
+		struct sta_info	*psta = (PVOID)pbuf;
+		u16			staIdx = psta->cmn.mac_id;
+
+		beamforming_enter(pDM_Odm, staIdx);
+		break;
+	}
+	case BEAMFORMING_CTRL_LEAVE:
+		beamforming_leave(pDM_Odm, pbuf);
+		break;
+	default:
+		break;
+
+	}
+#else /*(BEAMFORMING_SUPPORT == 0)- for drv beamfoming*/
+	switch (type) {
+	case BEAMFORMING_CTRL_ENTER:
+		beamforming_enter(padapter, (PVOID)pbuf);
+		break;
+
+	case BEAMFORMING_CTRL_LEAVE:
+		beamforming_leave(padapter, pbuf);
+		break;
+
+	case BEAMFORMING_CTRL_SOUNDING_FAIL:
+		beamforming_sounding_fail(padapter);
+		break;
+
+	case BEAMFORMING_CTRL_SOUNDING_CLK:
+		rtw_hal_set_hwreg(padapter, HW_VAR_SOUNDING_CLK, NULL);
+		break;
+
+	default:
+		break;
+	}
+#endif
+}
+
+u8	beamforming_wk_cmd(_adapter *padapter, s32 type, u8 *pbuf, s32 size, u8 enqueue)
+{
+	struct cmd_obj	*ph2c;
+	struct drvextra_cmd_parm	*pdrvextra_cmd_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;
+
+	/*20170214 ad_hoc mode and mp_mode not support BF*/
+	if ((padapter->registrypriv.mp_mode == 1)
+		|| (pmlmeinfo->state == WIFI_FW_ADHOC_STATE))
+		return res;
+
+	if (enqueue) {
+		u8	*wk_buf;
+
+		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (ph2c == NULL) {
+			res = _FAIL;
+			goto exit;
+		}
+
+		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (pdrvextra_cmd_parm == NULL) {
+			rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
+			res = _FAIL;
+			goto exit;
+		}
+
+		if (pbuf != NULL) {
+			wk_buf = rtw_zmalloc(size);
+			if (wk_buf == NULL) {
+				rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
+				rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
+				res = _FAIL;
+				goto exit;
+			}
+
+			_rtw_memcpy(wk_buf, pbuf, size);
+		} else {
+			wk_buf = NULL;
+			size = 0;
+		}
+
+		pdrvextra_cmd_parm->ec_id = BEAMFORMING_WK_CID;
+		pdrvextra_cmd_parm->type = type;
+		pdrvextra_cmd_parm->size = size;
+		pdrvextra_cmd_parm->pbuf = wk_buf;
+
+		init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+	} else
+		beamforming_wk_hdl(padapter, type, pbuf);
+
+exit:
+
+
+	return res;
+}
+
+void update_attrib_txbf_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)
+{
+	if (psta) {
+		pattrib->txbf_g_id = psta->cmn.bf_info.g_id;
+		pattrib->txbf_p_aid = psta->cmn.bf_info.p_aid;
+	}
+}
+#endif /* !RTW_BEAMFORMING_VERSION_2 */
+
+#endif /* CONFIG_BEAMFORMING */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_br_ext.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_br_ext.c
index 024049cfbdc7..8b0c7c3712e7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_br_ext.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_br_ext.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,54 +12,49 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_BR_EXT_C_
 
 #ifdef __KERNEL__
-#include <linux/if_arp.h>
-#include <net/ip.h>
-#include <net/ipx.h>
-#include <linux/atalk.h>
-#include <linux/udp.h>
-#include <linux/if_pppox.h>
+	#include <linux/if_arp.h>
+	#include <net/ip.h>
+	#include <net/ipx.h>
+	#include <linux/atalk.h>
+	#include <linux/udp.h>
+	#include <linux/if_pppox.h>
 #endif
 
-#if 1	// rtw_wifi_driver
-#include <drv_types.h>
-#else	// rtw_wifi_driver
-#include "./8192cd_cfg.h"
+#if 1	/* rtw_wifi_driver */
+	#include <drv_types.h>
+#else	/* rtw_wifi_driver */
+	#include "./8192cd_cfg.h"
 
-#ifndef __KERNEL__
-#include "./sys-support.h"
-#endif
+	#ifndef __KERNEL__
+		#include "./sys-support.h"
+	#endif
 
-#include "./8192cd.h"
-#include "./8192cd_headers.h"
-#include "./8192cd_br_ext.h"
-#include "./8192cd_debug.h"
-#endif	// rtw_wifi_driver
+	#include "./8192cd.h"
+	#include "./8192cd_headers.h"
+	#include "./8192cd_br_ext.h"
+	#include "./8192cd_debug.h"
+#endif /* rtw_wifi_driver */
 
 #ifdef CL_IPV6_PASS
-#ifdef __KERNEL__
-#include <linux/ipv6.h>
-#include <linux/icmpv6.h>
-#include <net/ndisc.h>
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
-#include <net/ip6_checksum.h>
-#else
-#include <net/checksum.h>
-#endif
-#endif
+	#ifdef __KERNEL__
+		#include <linux/ipv6.h>
+		#include <linux/icmpv6.h>
+		#include <net/ndisc.h>
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
+			#include <net/ip6_checksum.h>
+		#else
+			#include <net/checksum.h>
+		#endif
+	#endif
 #endif
 
 #ifdef CONFIG_BR_EXT
 
-//#define BR_EXT_DEBUG
+/* #define BR_EXT_DEBUG */
 
 #define NAT25_IPV4		01
 #define NAT25_IPV6		02
@@ -71,7 +67,7 @@
 
 #define MAGIC_CODE		0x8186
 #define MAGIC_CODE_LEN	2
-#define WAIT_TIME_PPPOE	5	// waiting time for pppoe server in sec
+#define WAIT_TIME_PPPOE	5	/* waiting time for pppoe server in sec */
 
 /*-----------------------------------------------------------------
   How database records network address:
@@ -85,18 +81,18 @@
 -----------------------------------------------------------------*/
 
 
-//Find a tag in pppoe frame and return the pointer
+/* Find a tag in pppoe frame and return the pointer */
 static __inline__ unsigned char *__nat25_find_pppoe_tag(struct pppoe_hdr *ph, unsigned short type)
 {
 	unsigned char *cur_ptr, *start_ptr;
 	unsigned short tagLen, tagType;
 
 	start_ptr = cur_ptr = (unsigned char *)ph->tag;
-	while((cur_ptr - start_ptr) < ntohs(ph->length)) {
-		// prevent un-alignment access
+	while ((cur_ptr - start_ptr) < ntohs(ph->length)) {
+		/* prevent un-alignment access */
 		tagType = (unsigned short)((cur_ptr[0] << 8) + cur_ptr[1]);
 		tagLen  = (unsigned short)((cur_ptr[2] << 8) + cur_ptr[3]);
-		if(tagType == type)
+		if (tagType == type)
 			return cur_ptr;
 		cur_ptr = cur_ptr + TAG_HDR_LEN + tagLen;
 	}
@@ -116,7 +112,7 @@ static __inline__ int __nat25_add_pppoe_tag(struct sk_buff *skb, struct pppoe_ta
 	}
 
 	skb_put(skb, data_len);
-	// have a room for new tag
+	/* have a room for new tag */
 	memmove(((unsigned char *)ph->tag + data_len), (unsigned char *)ph->tag, ntohs(ph->length));
 	ph->length = htons(ntohs(ph->length) + data_len);
 	memcpy((unsigned char *)ph->tag, tag, data_len);
@@ -128,19 +124,19 @@ static int skb_pull_and_merge(struct sk_buff *skb, unsigned char *src, int len)
 	int tail_len;
 	unsigned long end, tail;
 
-	if ((src+len) > skb_tail_pointer(skb) || skb->len < len)
+	if ((src + len) > skb_tail_pointer(skb) || skb->len < len)
 		return -1;
 
 	tail = (unsigned long)skb_tail_pointer(skb);
-	end = (unsigned long)src+len;
+	end = (unsigned long)src + len;
 	if (tail < end)
 		return -1;
 
-	tail_len = (int)(tail-end);
+	tail_len = (int)(tail - end);
 	if (tail_len > 0)
-		memmove(src, src+len, tail_len);
+		memmove(src, src + len, tail_len);
 
-	skb_trim(skb, skb->len-len);
+	skb_trim(skb, skb->len - len);
 	return 0;
 }
 
@@ -148,16 +144,16 @@ static __inline__ unsigned long __nat25_timeout(_adapter *priv)
 {
 	unsigned long timeout;
 
-	timeout = jiffies - NAT25_AGEING_TIME*HZ;
+	timeout = jiffies - NAT25_AGEING_TIME * HZ;
 
 	return timeout;
 }
 
 
 static __inline__ int  __nat25_has_expired(_adapter *priv,
-				struct nat25_network_db_entry *fdb)
+		struct nat25_network_db_entry *fdb)
 {
-	if(time_before_eq(fdb->ageing_timer, __nat25_timeout(priv)))
+	if (time_before_eq(fdb->ageing_timer, __nat25_timeout(priv)))
 		return 1;
 
 	return 0;
@@ -165,78 +161,78 @@ static __inline__ int  __nat25_has_expired(_adapter *priv,
 
 
 static __inline__ void __nat25_generate_ipv4_network_addr(unsigned char *networkAddr,
-				unsigned int *ipAddr)
+		unsigned int *ipAddr)
 {
 	memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
 
 	networkAddr[0] = NAT25_IPV4;
-	memcpy(networkAddr+7, (unsigned char *)ipAddr, 4);
+	memcpy(networkAddr + 7, (unsigned char *)ipAddr, 4);
 }
 
 
 static __inline__ void __nat25_generate_ipx_network_addr_with_node(unsigned char *networkAddr,
-				unsigned int *ipxNetAddr, unsigned char *ipxNodeAddr)
+		unsigned int *ipxNetAddr, unsigned char *ipxNodeAddr)
 {
 	memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
 
 	networkAddr[0] = NAT25_IPX;
-	memcpy(networkAddr+1, (unsigned char *)ipxNetAddr, 4);
-	memcpy(networkAddr+5, ipxNodeAddr, 6);
+	memcpy(networkAddr + 1, (unsigned char *)ipxNetAddr, 4);
+	memcpy(networkAddr + 5, ipxNodeAddr, 6);
 }
 
 
 static __inline__ void __nat25_generate_ipx_network_addr_with_socket(unsigned char *networkAddr,
-				unsigned int *ipxNetAddr, unsigned short *ipxSocketAddr)
+		unsigned int *ipxNetAddr, unsigned short *ipxSocketAddr)
 {
 	memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
 
 	networkAddr[0] = NAT25_IPX;
-	memcpy(networkAddr+1, (unsigned char *)ipxNetAddr, 4);
-	memcpy(networkAddr+5, (unsigned char *)ipxSocketAddr, 2);
+	memcpy(networkAddr + 1, (unsigned char *)ipxNetAddr, 4);
+	memcpy(networkAddr + 5, (unsigned char *)ipxSocketAddr, 2);
 }
 
 
 static __inline__ void __nat25_generate_apple_network_addr(unsigned char *networkAddr,
-				unsigned short *network, unsigned char *node)
+		unsigned short *network, unsigned char *node)
 {
 	memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
 
 	networkAddr[0] = NAT25_APPLE;
-	memcpy(networkAddr+1, (unsigned char *)network, 2);
+	memcpy(networkAddr + 1, (unsigned char *)network, 2);
 	networkAddr[3] = *node;
 }
 
 
 static __inline__ void __nat25_generate_pppoe_network_addr(unsigned char *networkAddr,
-				unsigned char *ac_mac, unsigned short *sid)
+		unsigned char *ac_mac, unsigned short *sid)
 {
 	memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
 
 	networkAddr[0] = NAT25_PPPOE;
-	memcpy(networkAddr+1, (unsigned char *)sid, 2);
-	memcpy(networkAddr+3, (unsigned char *)ac_mac, 6);
+	memcpy(networkAddr + 1, (unsigned char *)sid, 2);
+	memcpy(networkAddr + 3, (unsigned char *)ac_mac, 6);
 }
 
 
 #ifdef CL_IPV6_PASS
 static  void __nat25_generate_ipv6_network_addr(unsigned char *networkAddr,
-				unsigned int *ipAddr)
+		unsigned int *ipAddr)
 {
 	memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
 
 	networkAddr[0] = NAT25_IPV6;
-	memcpy(networkAddr+1, (unsigned char *)ipAddr, 16);
+	memcpy(networkAddr + 1, (unsigned char *)ipAddr, 16);
 }
 
 
 static unsigned char *scan_tlv(unsigned char *data, int len, unsigned char tag, unsigned char len8b)
 {
 	while (len > 0) {
-		if (*data == tag && *(data+1) == len8b && len >= len8b*8)
-			return data+2;	
-		
-		len -= (*(data+1))*8;		
-		data += (*(data+1))*8;		
+		if (*data == tag && *(data + 1) == len8b && len >= len8b * 8)
+			return data + 2;
+
+		len -= (*(data + 1)) * 8;
+		data += (*(data + 1)) * 8;
 	}
 	return NULL;
 }
@@ -246,119 +242,108 @@ static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char
 {
 	struct icmp6hdr *icmphdr = (struct icmp6hdr *)data;
 	unsigned char *mac;
-	
-	if (icmphdr->icmp6_type == NDISC_ROUTER_SOLICITATION) { 
+
+	if (icmphdr->icmp6_type == NDISC_ROUTER_SOLICITATION) {
 		if (len >= 8) {
-			mac = scan_tlv(&data[8], len-8, 1, 1);
+			mac = scan_tlv(&data[8], len - 8, 1, 1);
 			if (mac) {
-				DBG_871X("Router Solicitation, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
-					mac[0],mac[1],mac[2],mac[3],mac[4],mac[5],					
-					replace_mac[0],replace_mac[1],replace_mac[2],replace_mac[3],replace_mac[4],replace_mac[5]);
-				memcpy(mac, replace_mac, 6);	
-				return 1;				
+				RTW_INFO("Router Solicitation, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
+					mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
+					replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
+				memcpy(mac, replace_mac, 6);
+				return 1;
 			}
 		}
-	}
-	else if (icmphdr->icmp6_type == NDISC_ROUTER_ADVERTISEMENT) {
+	} else if (icmphdr->icmp6_type == NDISC_ROUTER_ADVERTISEMENT) {
 		if (len >= 16) {
-			mac = scan_tlv(&data[16], len-16, 1, 1);
+			mac = scan_tlv(&data[16], len - 16, 1, 1);
 			if (mac) {
-				DBG_871X("Router Advertisement, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
-					mac[0],mac[1],mac[2],mac[3],mac[4],mac[5],					
-					replace_mac[0],replace_mac[1],replace_mac[2],replace_mac[3],replace_mac[4],replace_mac[5]);
-				memcpy(mac, replace_mac, 6);			
-				return 1;				
+				RTW_INFO("Router Advertisement, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
+					mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
+					replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
+				memcpy(mac, replace_mac, 6);
+				return 1;
 			}
-		}		
-	}
-	else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_SOLICITATION) {
+		}
+	} else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_SOLICITATION) {
 		if (len >= 24) {
-			mac = scan_tlv(&data[24], len-24, 1, 1);
-			if (mac) {		
-				DBG_871X("Neighbor Solicitation, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
-					mac[0],mac[1],mac[2],mac[3],mac[4],mac[5],					
-					replace_mac[0],replace_mac[1],replace_mac[2],replace_mac[3],replace_mac[4],replace_mac[5]);
-				memcpy(mac, replace_mac, 6);	
-				return 1;								
+			mac = scan_tlv(&data[24], len - 24, 1, 1);
+			if (mac) {
+				RTW_INFO("Neighbor Solicitation, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
+					mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
+					replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
+				memcpy(mac, replace_mac, 6);
+				return 1;
 			}
-		}		
-	}
-	else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_ADVERTISEMENT) {
+		}
+	} else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_ADVERTISEMENT) {
 		if (len >= 24) {
-			mac = scan_tlv(&data[24], len-24, 2, 1);
+			mac = scan_tlv(&data[24], len - 24, 2, 1);
 			if (mac) {
-				DBG_871X("Neighbor Advertisement, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
-					mac[0],mac[1],mac[2],mac[3],mac[4],mac[5],					
-					replace_mac[0],replace_mac[1],replace_mac[2],replace_mac[3],replace_mac[4],replace_mac[5]);
-				memcpy(mac, replace_mac, 6);		
-				return 1;				
+				RTW_INFO("Neighbor Advertisement, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
+					mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
+					replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
+				memcpy(mac, replace_mac, 6);
+				return 1;
 			}
-		}		
-	}
-	else if (icmphdr->icmp6_type == NDISC_REDIRECT) {
+		}
+	} else if (icmphdr->icmp6_type == NDISC_REDIRECT) {
 		if (len >= 40) {
-			mac = scan_tlv(&data[40], len-40, 2, 1);
-			if (mac) {				
-				DBG_871X("Redirect,  replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
-					mac[0],mac[1],mac[2],mac[3],mac[4],mac[5],					
-					replace_mac[0],replace_mac[1],replace_mac[2],replace_mac[3],replace_mac[4],replace_mac[5]);
-				memcpy(mac, replace_mac, 6);	
-				return 1;				
+			mac = scan_tlv(&data[40], len - 40, 2, 1);
+			if (mac) {
+				RTW_INFO("Redirect,  replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
+					mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
+					replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
+				memcpy(mac, replace_mac, 6);
+				return 1;
 			}
-		}		
-	}	
+		}
+	}
 	return 0;
 }
 
 
 static void convert_ipv6_mac_to_mc(struct sk_buff *skb)
-{	
+{
 	struct ipv6hdr *iph = (struct ipv6hdr *)(skb->data + ETH_HLEN);
 	unsigned char *dst_mac = skb->data;
 
-	//dst_mac[0] = 0xff;
-	//dst_mac[1] = 0xff;
+	/* dst_mac[0] = 0xff; */
+	/* dst_mac[1] = 0xff; */
 	/*modified by qinjunjie,ipv6 multicast address ix 0x33-33-xx-xx-xx-xx*/
 	dst_mac[0] = 0x33;
 	dst_mac[1] = 0x33;
 	memcpy(&dst_mac[2], &iph->daddr.s6_addr32[3], 4);
-	#if defined(__LINUX_2_6__) 
+#if defined(__LINUX_2_6__)
 	/*modified by qinjunjie,warning:should not remove next line*/
 	skb->pkt_type = PACKET_MULTICAST;
-	#endif
+#endif
 }
 #endif /* CL_IPV6_PASS */
 
 
 static __inline__ int __nat25_network_hash(unsigned char *networkAddr)
 {
-	if(networkAddr[0] == NAT25_IPV4)
-	{
+	if (networkAddr[0] == NAT25_IPV4) {
 		unsigned long x;
 
 		x = networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10];
 
 		return x & (NAT25_HASH_SIZE - 1);
-	}
-	else if(networkAddr[0] == NAT25_IPX)
-	{
+	} else if (networkAddr[0] == NAT25_IPX) {
 		unsigned long x;
 
 		x = networkAddr[1] ^ networkAddr[2] ^ networkAddr[3] ^ networkAddr[4] ^ networkAddr[5] ^
-			networkAddr[6] ^ networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10];
+		    networkAddr[6] ^ networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10];
 
 		return x & (NAT25_HASH_SIZE - 1);
-	}
-	else if(networkAddr[0] == NAT25_APPLE)
-	{
+	} else if (networkAddr[0] == NAT25_APPLE) {
 		unsigned long x;
 
 		x = networkAddr[1] ^ networkAddr[2] ^ networkAddr[3];
 
 		return x & (NAT25_HASH_SIZE - 1);
-	}
-	else if(networkAddr[0] == NAT25_PPPOE)
-	{
+	} else if (networkAddr[0] == NAT25_PPPOE) {
 		unsigned long x;
 
 		x = networkAddr[0] ^ networkAddr[1] ^ networkAddr[2] ^ networkAddr[3] ^ networkAddr[4] ^ networkAddr[5] ^ networkAddr[6] ^ networkAddr[7] ^ networkAddr[8];
@@ -366,24 +351,22 @@ static __inline__ int __nat25_network_hash(unsigned char *networkAddr)
 		return x & (NAT25_HASH_SIZE - 1);
 	}
 #ifdef CL_IPV6_PASS
-	else if(networkAddr[0] == NAT25_IPV6)
-	{
+	else if (networkAddr[0] == NAT25_IPV6) {
 		unsigned long x;
 
 		x = networkAddr[1] ^ networkAddr[2] ^ networkAddr[3] ^ networkAddr[4] ^ networkAddr[5] ^
-			networkAddr[6] ^ networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10] ^
-			networkAddr[11] ^ networkAddr[12] ^ networkAddr[13] ^ networkAddr[14] ^ networkAddr[15] ^
-			networkAddr[16];
-	
+		    networkAddr[6] ^ networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10] ^
+		    networkAddr[11] ^ networkAddr[12] ^ networkAddr[13] ^ networkAddr[14] ^ networkAddr[15] ^
+		    networkAddr[16];
+
 		return x & (NAT25_HASH_SIZE - 1);
 	}
-#endif	
-	else
-	{
+#endif
+	else {
 		unsigned long x = 0;
 		int i;
 
-		for (i=0; i<MAX_NETWORK_ADDR_LEN; i++)
+		for (i = 0; i < MAX_NETWORK_ADDR_LEN; i++)
 			x ^= networkAddr[i];
 
 		return x & (NAT25_HASH_SIZE - 1);
@@ -392,101 +375,98 @@ static __inline__ int __nat25_network_hash(unsigned char *networkAddr)
 
 
 static __inline__ void __network_hash_link(_adapter *priv,
-				struct nat25_network_db_entry *ent, int hash)
+		struct nat25_network_db_entry *ent, int hash)
 {
-	// Caller must _enter_critical_bh already!
-	//_irqL irqL;
-	//_enter_critical_bh(&priv->br_ext_lock, &irqL);
+	/* Caller must _enter_critical_bh already! */
+	/* _irqL irqL; */
+	/* _enter_critical_bh(&priv->br_ext_lock, &irqL); */
 
 	ent->next_hash = priv->nethash[hash];
-	if(ent->next_hash != NULL)
+	if (ent->next_hash != NULL)
 		ent->next_hash->pprev_hash = &ent->next_hash;
 	priv->nethash[hash] = ent;
 	ent->pprev_hash = &priv->nethash[hash];
 
-	//_exit_critical_bh(&priv->br_ext_lock, &irqL);
+	/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
 }
 
 
 static __inline__ void __network_hash_unlink(struct nat25_network_db_entry *ent)
 {
-	// Caller must _enter_critical_bh already!
-	//_irqL irqL;
-	//_enter_critical_bh(&priv->br_ext_lock, &irqL);
+	/* Caller must _enter_critical_bh already! */
+	/* _irqL irqL; */
+	/* _enter_critical_bh(&priv->br_ext_lock, &irqL); */
 
 	*(ent->pprev_hash) = ent->next_hash;
-	if(ent->next_hash != NULL)
+	if (ent->next_hash != NULL)
 		ent->next_hash->pprev_hash = ent->pprev_hash;
 	ent->next_hash = NULL;
 	ent->pprev_hash = NULL;
 
-	//_exit_critical_bh(&priv->br_ext_lock, &irqL);
+	/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
 }
 
 
 static int __nat25_db_network_lookup_and_replace(_adapter *priv,
-				struct sk_buff *skb, unsigned char *networkAddr)
+		struct sk_buff *skb, unsigned char *networkAddr)
 {
 	struct nat25_network_db_entry *db;
 	_irqL irqL;
 	_enter_critical_bh(&priv->br_ext_lock, &irqL);
 
 	db = priv->nethash[__nat25_network_hash(networkAddr)];
-	while (db != NULL)
-	{
-		if(!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN))
-		{
-			if(!__nat25_has_expired(priv, db))
-			{
-				// replace the destination mac address
+	while (db != NULL) {
+		if (!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN)) {
+			if (!__nat25_has_expired(priv, db)) {
+				/* replace the destination mac address */
 				memcpy(skb->data, db->macAddr, ETH_ALEN);
 				atomic_inc(&db->use_count);
 
 #ifdef CL_IPV6_PASS
-				DBG_871X("NAT25: Lookup M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"	
-							"%02x%02x%02x%02x%02x%02x\n",				
-					db->macAddr[0],
-					db->macAddr[1],
-					db->macAddr[2],
-					db->macAddr[3],
-					db->macAddr[4],
-					db->macAddr[5],
-					db->networkAddr[0],
-					db->networkAddr[1],
-					db->networkAddr[2],
-					db->networkAddr[3],
-					db->networkAddr[4],
-					db->networkAddr[5],
-					db->networkAddr[6],
-					db->networkAddr[7],
-					db->networkAddr[8],
-					db->networkAddr[9],
-					db->networkAddr[10],
-					db->networkAddr[11],
-					db->networkAddr[12],
-					db->networkAddr[13],
-					db->networkAddr[14],
-					db->networkAddr[15],
-					db->networkAddr[16]);
-#else				
-				DBG_871X("NAT25: Lookup M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
-					db->macAddr[0],
-					db->macAddr[1],
-					db->macAddr[2],
-					db->macAddr[3],
-					db->macAddr[4],
-					db->macAddr[5],
-					db->networkAddr[0],
-					db->networkAddr[1],
-					db->networkAddr[2],
-					db->networkAddr[3],
-					db->networkAddr[4],
-					db->networkAddr[5],
-					db->networkAddr[6],
-					db->networkAddr[7],
-					db->networkAddr[8],
-					db->networkAddr[9],
-					db->networkAddr[10]);
+				RTW_INFO("NAT25: Lookup M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
+					 "%02x%02x%02x%02x%02x%02x\n",
+					 db->macAddr[0],
+					 db->macAddr[1],
+					 db->macAddr[2],
+					 db->macAddr[3],
+					 db->macAddr[4],
+					 db->macAddr[5],
+					 db->networkAddr[0],
+					 db->networkAddr[1],
+					 db->networkAddr[2],
+					 db->networkAddr[3],
+					 db->networkAddr[4],
+					 db->networkAddr[5],
+					 db->networkAddr[6],
+					 db->networkAddr[7],
+					 db->networkAddr[8],
+					 db->networkAddr[9],
+					 db->networkAddr[10],
+					 db->networkAddr[11],
+					 db->networkAddr[12],
+					 db->networkAddr[13],
+					 db->networkAddr[14],
+					 db->networkAddr[15],
+					 db->networkAddr[16]);
+#else
+				RTW_INFO("NAT25: Lookup M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
+					 db->macAddr[0],
+					 db->macAddr[1],
+					 db->macAddr[2],
+					 db->macAddr[3],
+					 db->macAddr[4],
+					 db->macAddr[5],
+					 db->networkAddr[0],
+					 db->networkAddr[1],
+					 db->networkAddr[2],
+					 db->networkAddr[3],
+					 db->networkAddr[4],
+					 db->networkAddr[5],
+					 db->networkAddr[6],
+					 db->networkAddr[7],
+					 db->networkAddr[8],
+					 db->networkAddr[9],
+					 db->networkAddr[10]);
 #endif
 			}
 			_exit_critical_bh(&priv->br_ext_lock, &irqL);
@@ -502,7 +482,7 @@ static int __nat25_db_network_lookup_and_replace(_adapter *priv,
 
 
 static void __nat25_db_network_insert(_adapter *priv,
-				unsigned char *macAddr, unsigned char *networkAddr)
+		      unsigned char *macAddr, unsigned char *networkAddr)
 {
 	struct nat25_network_db_entry *db;
 	int hash;
@@ -511,10 +491,8 @@ static void __nat25_db_network_insert(_adapter *priv,
 
 	hash = __nat25_network_hash(networkAddr);
 	db = priv->nethash[hash];
-	while (db != NULL)
-	{
-		if(!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN))
-		{
+	while (db != NULL) {
+		if (!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN)) {
 			memcpy(db->macAddr, macAddr, ETH_ALEN);
 			db->ageing_timer = jiffies;
 			_exit_critical_bh(&priv->br_ext_lock, &irqL);
@@ -525,7 +503,7 @@ static void __nat25_db_network_insert(_adapter *priv,
 	}
 
 	db = (struct nat25_network_db_entry *) rtw_malloc(sizeof(*db));
-	if(db == NULL) {
+	if (db == NULL) {
 		_exit_critical_bh(&priv->br_ext_lock, &irqL);
 		return;
 	}
@@ -552,66 +530,64 @@ static void __nat25_db_print(_adapter *priv)
 	struct nat25_network_db_entry *db;
 
 	counter++;
-	if((counter % 16) != 0)
+	if ((counter % 16) != 0)
 		return;
 
-	for(i=0, j=0; i<NAT25_HASH_SIZE; i++)
-	{
+	for (i = 0, j = 0; i < NAT25_HASH_SIZE; i++) {
 		db = priv->nethash[i];
 
-		while (db != NULL)
-		{
+		while (db != NULL) {
 #ifdef CL_IPV6_PASS
 			panic_printk("NAT25: DB(%d) H(%02d) C(%d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
-					"%02x%02x%02x%02x%02x%02x\n",
-				j,
-				i,
-				atomic_read(&db->use_count),
-				db->macAddr[0],
-				db->macAddr[1],
-				db->macAddr[2],
-				db->macAddr[3],
-				db->macAddr[4],
-				db->macAddr[5],
-				db->networkAddr[0],
-				db->networkAddr[1],
-				db->networkAddr[2],
-				db->networkAddr[3],
-				db->networkAddr[4],
-				db->networkAddr[5],
-				db->networkAddr[6],
-				db->networkAddr[7],
-				db->networkAddr[8],
-				db->networkAddr[9],
-				db->networkAddr[10],
-				db->networkAddr[11],
-				db->networkAddr[12],
-				db->networkAddr[13],
-				db->networkAddr[14],
-				db->networkAddr[15],
-				db->networkAddr[16]);
+				     "%02x%02x%02x%02x%02x%02x\n",
+				     j,
+				     i,
+				     atomic_read(&db->use_count),
+				     db->macAddr[0],
+				     db->macAddr[1],
+				     db->macAddr[2],
+				     db->macAddr[3],
+				     db->macAddr[4],
+				     db->macAddr[5],
+				     db->networkAddr[0],
+				     db->networkAddr[1],
+				     db->networkAddr[2],
+				     db->networkAddr[3],
+				     db->networkAddr[4],
+				     db->networkAddr[5],
+				     db->networkAddr[6],
+				     db->networkAddr[7],
+				     db->networkAddr[8],
+				     db->networkAddr[9],
+				     db->networkAddr[10],
+				     db->networkAddr[11],
+				     db->networkAddr[12],
+				     db->networkAddr[13],
+				     db->networkAddr[14],
+				     db->networkAddr[15],
+				     db->networkAddr[16]);
 #else
 			panic_printk("NAT25: DB(%d) H(%02d) C(%d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
-				j,
-				i,
-				atomic_read(&db->use_count),
-				db->macAddr[0],
-				db->macAddr[1],
-				db->macAddr[2],
-				db->macAddr[3],
-				db->macAddr[4],
-				db->macAddr[5],
-				db->networkAddr[0],
-				db->networkAddr[1],
-				db->networkAddr[2],
-				db->networkAddr[3],
-				db->networkAddr[4],
-				db->networkAddr[5],
-				db->networkAddr[6],
-				db->networkAddr[7],
-				db->networkAddr[8],
-				db->networkAddr[9],
-				db->networkAddr[10]);
+				     j,
+				     i,
+				     atomic_read(&db->use_count),
+				     db->macAddr[0],
+				     db->macAddr[1],
+				     db->macAddr[2],
+				     db->macAddr[3],
+				     db->macAddr[4],
+				     db->macAddr[5],
+				     db->networkAddr[0],
+				     db->networkAddr[1],
+				     db->networkAddr[2],
+				     db->networkAddr[3],
+				     db->networkAddr[4],
+				     db->networkAddr[5],
+				     db->networkAddr[6],
+				     db->networkAddr[7],
+				     db->networkAddr[8],
+				     db->networkAddr[9],
+				     db->networkAddr[10]);
 #endif
 			j++;
 
@@ -635,17 +611,15 @@ void nat25_db_cleanup(_adapter *priv)
 	int i;
 	_irqL irqL;
 	_enter_critical_bh(&priv->br_ext_lock, &irqL);
-	
-	for(i=0; i<NAT25_HASH_SIZE; i++)
-	{
+
+	for (i = 0; i < NAT25_HASH_SIZE; i++) {
 		struct nat25_network_db_entry *f;
 		f = priv->nethash[i];
 		while (f != NULL) {
 			struct nat25_network_db_entry *g;
 
 			g = f->next_hash;
-			if(priv->scdb_entry == f)
-			{
+			if (priv->scdb_entry == f) {
 				memset(priv->scdb_mac, 0, ETH_ALEN);
 				memset(priv->scdb_ip, 0, 4);
 				priv->scdb_entry = NULL;
@@ -666,76 +640,71 @@ void nat25_db_expire(_adapter *priv)
 	int i;
 	_irqL irqL;
 	_enter_critical_bh(&priv->br_ext_lock, &irqL);
-	
-	//if(!priv->ethBrExtInfo.nat25_disable)
+
+	/* if(!priv->ethBrExtInfo.nat25_disable) */
 	{
-		for (i=0; i<NAT25_HASH_SIZE; i++)
-		{
+		for (i = 0; i < NAT25_HASH_SIZE; i++) {
 			struct nat25_network_db_entry *f;
 			f = priv->nethash[i];
 
-			while (f != NULL)
-			{
+			while (f != NULL) {
 				struct nat25_network_db_entry *g;
 				g = f->next_hash;
 
-				if(__nat25_has_expired(priv, f))
-				{
-					if(atomic_dec_and_test(&f->use_count))
-					{
+				if (__nat25_has_expired(priv, f)) {
+					if (atomic_dec_and_test(&f->use_count)) {
 #ifdef BR_EXT_DEBUG
 #ifdef CL_IPV6_PASS
 						panic_printk("NAT25 Expire H(%02d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
-								"%02x%02x%02x%02x%02x%02x\n",
-							i,
-							f->macAddr[0],
-							f->macAddr[1],
-							f->macAddr[2],
-							f->macAddr[3],
-							f->macAddr[4],
-							f->macAddr[5],
-							f->networkAddr[0],
-							f->networkAddr[1],
-							f->networkAddr[2],
-							f->networkAddr[3],
-							f->networkAddr[4],
-							f->networkAddr[5],
-							f->networkAddr[6],
-							f->networkAddr[7],
-							f->networkAddr[8],
-							f->networkAddr[9],
-							f->networkAddr[10],
-							f->networkAddr[11],
-							f->networkAddr[12],
-							f->networkAddr[13],
-							f->networkAddr[14],
-							f->networkAddr[15],
+							"%02x%02x%02x%02x%02x%02x\n",
+							     i,
+							     f->macAddr[0],
+							     f->macAddr[1],
+							     f->macAddr[2],
+							     f->macAddr[3],
+							     f->macAddr[4],
+							     f->macAddr[5],
+							     f->networkAddr[0],
+							     f->networkAddr[1],
+							     f->networkAddr[2],
+							     f->networkAddr[3],
+							     f->networkAddr[4],
+							     f->networkAddr[5],
+							     f->networkAddr[6],
+							     f->networkAddr[7],
+							     f->networkAddr[8],
+							     f->networkAddr[9],
+							     f->networkAddr[10],
+							     f->networkAddr[11],
+							     f->networkAddr[12],
+							     f->networkAddr[13],
+							     f->networkAddr[14],
+							     f->networkAddr[15],
 							f->networkAddr[16]);
 #else
 
 						panic_printk("NAT25 Expire H(%02d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
-							i,
-							f->macAddr[0],
-							f->macAddr[1],
-							f->macAddr[2],
-							f->macAddr[3],
-							f->macAddr[4],
-							f->macAddr[5],
-							f->networkAddr[0],
-							f->networkAddr[1],
-							f->networkAddr[2],
-							f->networkAddr[3],
-							f->networkAddr[4],
-							f->networkAddr[5],
-							f->networkAddr[6],
-							f->networkAddr[7],
-							f->networkAddr[8],
-							f->networkAddr[9],
+							     i,
+							     f->macAddr[0],
+							     f->macAddr[1],
+							     f->macAddr[2],
+							     f->macAddr[3],
+							     f->macAddr[4],
+							     f->macAddr[5],
+							     f->networkAddr[0],
+							     f->networkAddr[1],
+							     f->networkAddr[2],
+							     f->networkAddr[3],
+							     f->networkAddr[4],
+							     f->networkAddr[5],
+							     f->networkAddr[6],
+							     f->networkAddr[7],
+							     f->networkAddr[8],
+							     f->networkAddr[9],
 							f->networkAddr[10]);
 #endif
 #endif
-						if(priv->scdb_entry == f)
-						{
+						if (priv->scdb_entry == f) {
 							memset(priv->scdb_mac, 0, ETH_ALEN);
 							memset(priv->scdb_ip, 0, 4);
 							priv->scdb_entry = NULL;
@@ -771,8 +740,8 @@ static int checkIPMcAndReplace(_adapter *priv, struct sk_buff *skb, unsigned int
 		if (pstat->ipmc_num == 0)
 			continue;
 
-		for (i=0; i<MAX_IP_MC_ENTRY; i++) {
-			if (pstat->ipmc[i].used && !memcmp(&pstat->ipmc[i].mcmac[3], ((unsigned char *)dst_ip)+1, 3)) {
+		for (i = 0; i < MAX_IP_MC_ENTRY; i++) {
+			if (pstat->ipmc[i].used && !memcmp(&pstat->ipmc[i].mcmac[3], ((unsigned char *)dst_ip) + 1, 3)) {
 				memcpy(skb->data, pstat->ipmc[i].mcmac, ETH_ALEN);
 				return 1;
 			}
@@ -787,405 +756,354 @@ int nat25_db_handle(_adapter *priv, struct sk_buff *skb, int method)
 	unsigned short protocol;
 	unsigned char networkAddr[MAX_NETWORK_ADDR_LEN];
 
-	if(skb == NULL)
+	if (skb == NULL)
 		return -1;
 
-	if((method <= NAT25_MIN) || (method >= NAT25_MAX))
+	if ((method <= NAT25_MIN) || (method >= NAT25_MAX))
 		return -1;
 
 	protocol = *((unsigned short *)(skb->data + 2 * ETH_ALEN));
 
 	/*---------------------------------------------------*/
-	/*                 Handle IP frame                   */
+	/*                 Handle IP frame                  */
 	/*---------------------------------------------------*/
-	if(protocol == __constant_htons(ETH_P_IP))
-	{
-		struct iphdr* iph = (struct iphdr *)(skb->data + ETH_HLEN);
+	if (protocol == __constant_htons(ETH_P_IP)) {
+		struct iphdr *iph = (struct iphdr *)(skb->data + ETH_HLEN);
 
-		if(((unsigned char*)(iph) + (iph->ihl<<2)) >= (skb->data + ETH_HLEN + skb->len))
-		{
+		if (((unsigned char *)(iph) + (iph->ihl << 2)) >= (skb->data + ETH_HLEN + skb->len)) {
 			DEBUG_WARN("NAT25: malformed IP packet !\n");
 			return -1;
 		}
 
-		switch(method)
-		{
-			case NAT25_CHECK:
-				return -1;
-
-			case NAT25_INSERT:
-				{
-					//some muticast with source IP is all zero, maybe other case is illegal
-					//in class A, B, C, host address is all zero or all one is illegal
-					if (iph->saddr == 0)
-						return 0;
-					DBG_871X("NAT25: Insert IP, SA=%08x, DA=%08x\n", iph->saddr, iph->daddr);
-					__nat25_generate_ipv4_network_addr(networkAddr, &iph->saddr);
-					//record source IP address and , source mac address into db
-					__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
+		switch (method) {
+		case NAT25_CHECK:
+			return -1;
 
-					__nat25_db_print(priv);
-				}
+		case NAT25_INSERT: {
+			/* some muticast with source IP is all zero, maybe other case is illegal */
+			/* in class A, B, C, host address is all zero or all one is illegal */
+			if (iph->saddr == 0)
 				return 0;
+			RTW_INFO("NAT25: Insert IP, SA=%08x, DA=%08x\n", iph->saddr, iph->daddr);
+			__nat25_generate_ipv4_network_addr(networkAddr, &iph->saddr);
+			/* record source IP address and , source mac address into db */
+			__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
+
+			__nat25_db_print(priv);
+		}
+		return 0;
 
-			case NAT25_LOOKUP:
-				{
-					DBG_871X("NAT25: Lookup IP, SA=%08x, DA=%08x\n", iph->saddr, iph->daddr);
+		case NAT25_LOOKUP: {
+			RTW_INFO("NAT25: Lookup IP, SA=%08x, DA=%08x\n", iph->saddr, iph->daddr);
 #ifdef SUPPORT_TX_MCAST2UNI
-					if (priv->pshare->rf_ft_var.mc2u_disable ||
-							((((OPMODE & (WIFI_STATION_STATE|WIFI_ASOC_STATE))
-							== (WIFI_STATION_STATE|WIFI_ASOC_STATE)) &&
-							!checkIPMcAndReplace(priv, skb, &iph->daddr)) ||
-							(OPMODE & WIFI_ADHOC_STATE)))
+			if (priv->pshare->rf_ft_var.mc2u_disable ||
+			    ((((OPMODE & (WIFI_STATION_STATE | WIFI_ASOC_STATE))
+			       == (WIFI_STATION_STATE | WIFI_ASOC_STATE)) &&
+			      !checkIPMcAndReplace(priv, skb, &iph->daddr)) ||
+			     (OPMODE & WIFI_ADHOC_STATE)))
 #endif
-					{
-						__nat25_generate_ipv4_network_addr(networkAddr, &iph->daddr);
-
-						if (!__nat25_db_network_lookup_and_replace(priv, skb, networkAddr)) {
-							if (*((unsigned char *)&iph->daddr + 3) == 0xff) {
-								// L2 is unicast but L3 is broadcast, make L2 bacome broadcast
-								DBG_871X("NAT25: Set DA as boardcast\n");
-								memset(skb->data, 0xff, ETH_ALEN);
-							}
-							else {
-								// forward unknow IP packet to upper TCP/IP
-								DBG_871X("NAT25: Replace DA with BR's MAC\n");
-								if ( (*(u32 *)priv->br_mac) == 0 && (*(u16 *)(priv->br_mac+4)) == 0 ) {
-									void netdev_br_init(struct net_device *netdev);
-									printk("Re-init netdev_br_init() due to br_mac==0!\n");
-									netdev_br_init(priv->pnetdev);
-								}
-								memcpy(skb->data, priv->br_mac, ETH_ALEN);
-							}
+			{
+				__nat25_generate_ipv4_network_addr(networkAddr, &iph->daddr);
+
+				if (!__nat25_db_network_lookup_and_replace(priv, skb, networkAddr)) {
+					if (*((unsigned char *)&iph->daddr + 3) == 0xff) {
+						/* L2 is unicast but L3 is broadcast, make L2 bacome broadcast */
+						RTW_INFO("NAT25: Set DA as boardcast\n");
+						memset(skb->data, 0xff, ETH_ALEN);
+					} else {
+						/* forward unknow IP packet to upper TCP/IP */
+						RTW_INFO("NAT25: Replace DA with BR's MAC\n");
+						if ((*(u32 *)priv->br_mac) == 0 && (*(u16 *)(priv->br_mac + 4)) == 0) {
+							void netdev_br_init(struct net_device *netdev);
+							printk("Re-init netdev_br_init() due to br_mac==0!\n");
+							netdev_br_init(priv->pnetdev);
 						}
+						memcpy(skb->data, priv->br_mac, ETH_ALEN);
 					}
 				}
-				return 0;
+			}
+		}
+		return 0;
 
-			default:
-				return -1;
+		default:
+			return -1;
 		}
 	}
 
 	/*---------------------------------------------------*/
-	/*                 Handle ARP frame                  */
+	/*                 Handle ARP frame                 */
 	/*---------------------------------------------------*/
-	else if(protocol == __constant_htons(ETH_P_ARP))
-	{
+	else if (protocol == __constant_htons(ETH_P_ARP)) {
 		struct arphdr *arp = (struct arphdr *)(skb->data + ETH_HLEN);
 		unsigned char *arp_ptr = (unsigned char *)(arp + 1);
 		unsigned int *sender, *target;
 
-		if(arp->ar_pro != __constant_htons(ETH_P_IP))
-		{
+		if (arp->ar_pro != __constant_htons(ETH_P_IP)) {
 			DEBUG_WARN("NAT25: arp protocol unknown (%4x)!\n", htons(arp->ar_pro));
 			return -1;
 		}
 
-		switch(method)
-		{
-			case NAT25_CHECK:
-				return 0;	// skb_copy for all ARP frame
+		switch (method) {
+		case NAT25_CHECK:
+			return 0;	/* skb_copy for all ARP frame */
 
-			case NAT25_INSERT:
-				{
-					DBG_871X("NAT25: Insert ARP, MAC=%02x%02x%02x%02x%02x%02x\n", arp_ptr[0],
-						arp_ptr[1], arp_ptr[2], arp_ptr[3], arp_ptr[4], arp_ptr[5]);
+		case NAT25_INSERT: {
+			RTW_INFO("NAT25: Insert ARP, MAC=%02x%02x%02x%02x%02x%02x\n", arp_ptr[0],
+				arp_ptr[1], arp_ptr[2], arp_ptr[3], arp_ptr[4], arp_ptr[5]);
 
-					// change to ARP sender mac address to wlan STA address
-                                        memcpy(arp_ptr, GET_MY_HWADDR(priv), ETH_ALEN);
+			/* change to ARP sender mac address to wlan STA address */
+			memcpy(arp_ptr, GET_MY_HWADDR(priv), ETH_ALEN);
 
-					arp_ptr += arp->ar_hln;
-					sender = (unsigned int *)arp_ptr;
+			arp_ptr += arp->ar_hln;
+			sender = (unsigned int *)arp_ptr;
 
-					__nat25_generate_ipv4_network_addr(networkAddr, sender);
+			__nat25_generate_ipv4_network_addr(networkAddr, sender);
 
-					__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
+			__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
 
-					__nat25_db_print(priv);
-				}
-				return 0;
+			__nat25_db_print(priv);
+		}
+		return 0;
 
-			case NAT25_LOOKUP:
-				{
-					DBG_871X("NAT25: Lookup ARP\n");
+		case NAT25_LOOKUP: {
+			RTW_INFO("NAT25: Lookup ARP\n");
 
-					arp_ptr += arp->ar_hln;
-					sender = (unsigned int *)arp_ptr;
-					arp_ptr += (arp->ar_hln + arp->ar_pln);
-					target = (unsigned int *)arp_ptr;
+			arp_ptr += arp->ar_hln;
+			sender = (unsigned int *)arp_ptr;
+			arp_ptr += (arp->ar_hln + arp->ar_pln);
+			target = (unsigned int *)arp_ptr;
 
-					__nat25_generate_ipv4_network_addr(networkAddr, target);
+			__nat25_generate_ipv4_network_addr(networkAddr, target);
 
-					__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
+			__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
 
-					// change to ARP target mac address to Lookup result
-					arp_ptr = (unsigned char *)(arp + 1);
-					arp_ptr += (arp->ar_hln + arp->ar_pln);
-					memcpy(arp_ptr, skb->data, ETH_ALEN);
-				}
-				return 0;
+			/* change to ARP target mac address to Lookup result */
+			arp_ptr = (unsigned char *)(arp + 1);
+			arp_ptr += (arp->ar_hln + arp->ar_pln);
+			memcpy(arp_ptr, skb->data, ETH_ALEN);
+		}
+		return 0;
 
-			default:
-				return -1;
+		default:
+			return -1;
 		}
 	}
 
 	/*---------------------------------------------------*/
-	/*         Handle IPX and Apple Talk frame           */
+	/*         Handle IPX and Apple Talk frame          */
 	/*---------------------------------------------------*/
-	else if((protocol == __constant_htons(ETH_P_IPX)) || 
-		(protocol == __constant_htons(ETH_P_ATALK)) ||
-		(protocol == __constant_htons(ETH_P_AARP)))
-	{
+	else if ((protocol == __constant_htons(ETH_P_IPX)) ||
+		 (protocol == __constant_htons(ETH_P_ATALK)) ||
+		 (protocol == __constant_htons(ETH_P_AARP))) {
 		unsigned char ipx_header[2] = {0xFF, 0xFF};
 		struct ipxhdr	*ipx = NULL;
 		struct elapaarp	*ea = NULL;
 		struct ddpehdr	*ddp = NULL;
 		unsigned char *framePtr = skb->data + ETH_HLEN;
 
-		if(protocol == __constant_htons(ETH_P_IPX))
-		{
-			DBG_871X("NAT25: Protocol=IPX (Ethernet II)\n");
+		if (protocol == __constant_htons(ETH_P_IPX)) {
+			RTW_INFO("NAT25: Protocol=IPX (Ethernet II)\n");
 			ipx = (struct ipxhdr *)framePtr;
-		}
-		else //if(protocol <= __constant_htons(ETH_FRAME_LEN))
-		{
-			if(!memcmp(ipx_header, framePtr, 2))
-			{
-				DBG_871X("NAT25: Protocol=IPX (Ethernet 802.3)\n");
+		} else { /* if(protocol <= __constant_htons(ETH_FRAME_LEN)) */
+			if (!memcmp(ipx_header, framePtr, 2)) {
+				RTW_INFO("NAT25: Protocol=IPX (Ethernet 802.3)\n");
 				ipx = (struct ipxhdr *)framePtr;
-			}
-			else
-			{
+			} else {
 				unsigned char ipx_8022_type =  0xE0;
 				unsigned char snap_8022_type = 0xAA;
 
-				if(*framePtr == snap_8022_type)
-				{
-					unsigned char ipx_snap_id[5] = {0x0, 0x0, 0x0, 0x81, 0x37};		// IPX SNAP ID
-					unsigned char aarp_snap_id[5] = {0x00, 0x00, 0x00, 0x80, 0xF3};	// Apple Talk AARP SNAP ID
-					unsigned char ddp_snap_id[5] = {0x08, 0x00, 0x07, 0x80, 0x9B};	// Apple Talk DDP SNAP ID
+				if (*framePtr == snap_8022_type) {
+					unsigned char ipx_snap_id[5] = {0x0, 0x0, 0x0, 0x81, 0x37};		/* IPX SNAP ID */
+					unsigned char aarp_snap_id[5] = {0x00, 0x00, 0x00, 0x80, 0xF3};	/* Apple Talk AARP SNAP ID */
+					unsigned char ddp_snap_id[5] = {0x08, 0x00, 0x07, 0x80, 0x9B};	/* Apple Talk DDP SNAP ID */
 
-					framePtr += 3;	// eliminate the 802.2 header
+					framePtr += 3;	/* eliminate the 802.2 header */
 
-					if(!memcmp(ipx_snap_id, framePtr, 5))
-					{
-						framePtr += 5;	// eliminate the SNAP header
+					if (!memcmp(ipx_snap_id, framePtr, 5)) {
+						framePtr += 5;	/* eliminate the SNAP header */
 
-						DBG_871X("NAT25: Protocol=IPX (Ethernet SNAP)\n");
+						RTW_INFO("NAT25: Protocol=IPX (Ethernet SNAP)\n");
 						ipx = (struct ipxhdr *)framePtr;
-					}
-					else if(!memcmp(aarp_snap_id, framePtr, 5))
-					{
-						framePtr += 5;	// eliminate the SNAP header
+					} else if (!memcmp(aarp_snap_id, framePtr, 5)) {
+						framePtr += 5;	/* eliminate the SNAP header */
 
 						ea = (struct elapaarp *)framePtr;
-					}
-					else if(!memcmp(ddp_snap_id, framePtr, 5))
-					{
-						framePtr += 5;	// eliminate the SNAP header
+					} else if (!memcmp(ddp_snap_id, framePtr, 5)) {
+						framePtr += 5;	/* eliminate the SNAP header */
 
 						ddp = (struct ddpehdr *)framePtr;
-					}
-					else
-					{
+					} else {
 						DEBUG_WARN("NAT25: Protocol=Ethernet SNAP %02x%02x%02x%02x%02x\n", framePtr[0],
 							framePtr[1], framePtr[2], framePtr[3], framePtr[4]);
 						return -1;
 					}
-				}
-				else if(*framePtr == ipx_8022_type)
-				{
-					framePtr += 3;	// eliminate the 802.2 header
+				} else if (*framePtr == ipx_8022_type) {
+					framePtr += 3;	/* eliminate the 802.2 header */
 
-					if(!memcmp(ipx_header, framePtr, 2))
-					{
-						DBG_871X("NAT25: Protocol=IPX (Ethernet 802.2)\n");
+					if (!memcmp(ipx_header, framePtr, 2)) {
+						RTW_INFO("NAT25: Protocol=IPX (Ethernet 802.2)\n");
 						ipx = (struct ipxhdr *)framePtr;
-					}
-					else
+					} else
 						return -1;
 				}
 			}
 		}
 
-		/*   IPX   */
-		if(ipx != NULL)
-		{
-			switch(method)
-			{
-				case NAT25_CHECK:
-					if(!memcmp(skb->data+ETH_ALEN, ipx->ipx_source.node, ETH_ALEN))
-					{
-						DBG_871X("NAT25: Check IPX skb_copy\n");
-						return 0;
-					}
-					return -1;
-
-				case NAT25_INSERT:
-					{
-						DBG_871X("NAT25: Insert IPX, Dest=%08x,%02x%02x%02x%02x%02x%02x,%04x Source=%08x,%02x%02x%02x%02x%02x%02x,%04x\n",
-							ipx->ipx_dest.net,
-							ipx->ipx_dest.node[0],
-							ipx->ipx_dest.node[1],
-							ipx->ipx_dest.node[2],
-							ipx->ipx_dest.node[3],
-							ipx->ipx_dest.node[4],
-							ipx->ipx_dest.node[5],
-							ipx->ipx_dest.sock,
-							ipx->ipx_source.net,
-							ipx->ipx_source.node[0],
-							ipx->ipx_source.node[1],
-							ipx->ipx_source.node[2],
-							ipx->ipx_source.node[3],
-							ipx->ipx_source.node[4],
-							ipx->ipx_source.node[5],
-							ipx->ipx_source.sock);
-
-						if(!memcmp(skb->data+ETH_ALEN, ipx->ipx_source.node, ETH_ALEN))
-						{
-							DBG_871X("NAT25: Use IPX Net, and Socket as network addr\n");
-
-							__nat25_generate_ipx_network_addr_with_socket(networkAddr, &ipx->ipx_source.net, &ipx->ipx_source.sock);
-
-							// change IPX source node addr to wlan STA address
-                                                        memcpy(ipx->ipx_source.node, GET_MY_HWADDR(priv), ETH_ALEN);
-						}
-						else
-						{
-							__nat25_generate_ipx_network_addr_with_node(networkAddr, &ipx->ipx_source.net, ipx->ipx_source.node);
-						}
-
-						__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
-
-						__nat25_db_print(priv);
-					}
+		/*   IPX  */
+		if (ipx != NULL) {
+			switch (method) {
+			case NAT25_CHECK:
+				if (!memcmp(skb->data + ETH_ALEN, ipx->ipx_source.node, ETH_ALEN)) {
+					RTW_INFO("NAT25: Check IPX skb_copy\n");
 					return 0;
+				}
+				return -1;
 
-				case NAT25_LOOKUP:
-					{
-                                                if(!memcmp(GET_MY_HWADDR(priv), ipx->ipx_dest.node, ETH_ALEN))
-						{
-							DBG_871X("NAT25: Lookup IPX, Modify Destination IPX Node addr\n");
+			case NAT25_INSERT: {
+				RTW_INFO("NAT25: Insert IPX, Dest=%08x,%02x%02x%02x%02x%02x%02x,%04x Source=%08x,%02x%02x%02x%02x%02x%02x,%04x\n",
+					 ipx->ipx_dest.net,
+					 ipx->ipx_dest.node[0],
+					 ipx->ipx_dest.node[1],
+					 ipx->ipx_dest.node[2],
+					 ipx->ipx_dest.node[3],
+					 ipx->ipx_dest.node[4],
+					 ipx->ipx_dest.node[5],
+					 ipx->ipx_dest.sock,
+					 ipx->ipx_source.net,
+					 ipx->ipx_source.node[0],
+					 ipx->ipx_source.node[1],
+					 ipx->ipx_source.node[2],
+					 ipx->ipx_source.node[3],
+					 ipx->ipx_source.node[4],
+					 ipx->ipx_source.node[5],
+					 ipx->ipx_source.sock);
+
+				if (!memcmp(skb->data + ETH_ALEN, ipx->ipx_source.node, ETH_ALEN)) {
+					RTW_INFO("NAT25: Use IPX Net, and Socket as network addr\n");
+
+					__nat25_generate_ipx_network_addr_with_socket(networkAddr, &ipx->ipx_source.net, &ipx->ipx_source.sock);
+
+					/* change IPX source node addr to wlan STA address */
+					memcpy(ipx->ipx_source.node, GET_MY_HWADDR(priv), ETH_ALEN);
+				} else
+					__nat25_generate_ipx_network_addr_with_node(networkAddr, &ipx->ipx_source.net, ipx->ipx_source.node);
+
+				__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
+
+				__nat25_db_print(priv);
+			}
+			return 0;
 
-							__nat25_generate_ipx_network_addr_with_socket(networkAddr, &ipx->ipx_dest.net, &ipx->ipx_dest.sock);
+			case NAT25_LOOKUP: {
+				if (!memcmp(GET_MY_HWADDR(priv), ipx->ipx_dest.node, ETH_ALEN)) {
+					RTW_INFO("NAT25: Lookup IPX, Modify Destination IPX Node addr\n");
 
-							__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
+					__nat25_generate_ipx_network_addr_with_socket(networkAddr, &ipx->ipx_dest.net, &ipx->ipx_dest.sock);
 
-							// replace IPX destination node addr with Lookup destination MAC addr
-							memcpy(ipx->ipx_dest.node, skb->data, ETH_ALEN);
-						}
-						else
-						{
-							__nat25_generate_ipx_network_addr_with_node(networkAddr, &ipx->ipx_dest.net, ipx->ipx_dest.node);
+					__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
 
-							__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
-						}
-					}
-					return 0;
+					/* replace IPX destination node addr with Lookup destination MAC addr */
+					memcpy(ipx->ipx_dest.node, skb->data, ETH_ALEN);
+				} else {
+					__nat25_generate_ipx_network_addr_with_node(networkAddr, &ipx->ipx_dest.net, ipx->ipx_dest.node);
 
-				default:
-					return -1;
+					__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
+				}
+			}
+			return 0;
+
+			default:
+				return -1;
 			}
 		}
 
-		/*   AARP   */
-		else if(ea != NULL)
-		{
+		/*   AARP  */
+		else if (ea != NULL) {
 			/* Sanity check fields. */
-			if(ea->hw_len != ETH_ALEN || ea->pa_len != AARP_PA_ALEN)
-			{
+			if (ea->hw_len != ETH_ALEN || ea->pa_len != AARP_PA_ALEN) {
 				DEBUG_WARN("NAT25: Appletalk AARP Sanity check fail!\n");
 				return -1;
 			}
 
-			switch(method)
-			{
-				case NAT25_CHECK:
-					return 0;
+			switch (method) {
+			case NAT25_CHECK:
+				return 0;
 
-				case NAT25_INSERT:
-					{
-						// change to AARP source mac address to wlan STA address
-                                                memcpy(ea->hw_src, GET_MY_HWADDR(priv), ETH_ALEN);
+			case NAT25_INSERT: {
+				/* change to AARP source mac address to wlan STA address */
+				memcpy(ea->hw_src, GET_MY_HWADDR(priv), ETH_ALEN);
 
-						DBG_871X("NAT25: Insert AARP, Source=%d,%d Destination=%d,%d\n",
-							ea->pa_src_net,
-							ea->pa_src_node,
-							ea->pa_dst_net,
-							ea->pa_dst_node);
+				RTW_INFO("NAT25: Insert AARP, Source=%d,%d Destination=%d,%d\n",
+					 ea->pa_src_net,
+					 ea->pa_src_node,
+					 ea->pa_dst_net,
+					 ea->pa_dst_node);
 
-						__nat25_generate_apple_network_addr(networkAddr, &ea->pa_src_net, &ea->pa_src_node);
+				__nat25_generate_apple_network_addr(networkAddr, &ea->pa_src_net, &ea->pa_src_node);
 
-						__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
+				__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
 
-						__nat25_db_print(priv);
-					}
-					return 0;
+				__nat25_db_print(priv);
+			}
+			return 0;
 
-				case NAT25_LOOKUP:
-					{
-						DBG_871X("NAT25: Lookup AARP, Source=%d,%d Destination=%d,%d\n",
-							ea->pa_src_net,
-							ea->pa_src_node,
-							ea->pa_dst_net,
-							ea->pa_dst_node);
+			case NAT25_LOOKUP: {
+				RTW_INFO("NAT25: Lookup AARP, Source=%d,%d Destination=%d,%d\n",
+					 ea->pa_src_net,
+					 ea->pa_src_node,
+					 ea->pa_dst_net,
+					 ea->pa_dst_node);
 
-						__nat25_generate_apple_network_addr(networkAddr, &ea->pa_dst_net, &ea->pa_dst_node);
+				__nat25_generate_apple_network_addr(networkAddr, &ea->pa_dst_net, &ea->pa_dst_node);
 
-						__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
+				__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
 
-						// change to AARP destination mac address to Lookup result
-						memcpy(ea->hw_dst, skb->data, ETH_ALEN);
-					}
-					return 0;
+				/* change to AARP destination mac address to Lookup result */
+				memcpy(ea->hw_dst, skb->data, ETH_ALEN);
+			}
+			return 0;
 
-				default:
-					return -1;
+			default:
+				return -1;
 			}
 		}
 
-		/*   DDP   */
-		else if(ddp != NULL)
-		{
-			switch(method)
-			{
-				case NAT25_CHECK:
-					return -1;
+		/*   DDP  */
+		else if (ddp != NULL) {
+			switch (method) {
+			case NAT25_CHECK:
+				return -1;
 
-				case NAT25_INSERT:
-					{
-						DBG_871X("NAT25: Insert DDP, Source=%d,%d Destination=%d,%d\n",
-							ddp->deh_snet,
-							ddp->deh_snode,
-							ddp->deh_dnet,
-							ddp->deh_dnode);
+			case NAT25_INSERT: {
+				RTW_INFO("NAT25: Insert DDP, Source=%d,%d Destination=%d,%d\n",
+					 ddp->deh_snet,
+					 ddp->deh_snode,
+					 ddp->deh_dnet,
+					 ddp->deh_dnode);
 
-						__nat25_generate_apple_network_addr(networkAddr, &ddp->deh_snet, &ddp->deh_snode);
+				__nat25_generate_apple_network_addr(networkAddr, &ddp->deh_snet, &ddp->deh_snode);
 
-						__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
+				__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
 
-						__nat25_db_print(priv);
-					}
-					return 0;
+				__nat25_db_print(priv);
+			}
+			return 0;
 
-				case NAT25_LOOKUP:
-					{
-						DBG_871X("NAT25: Lookup DDP, Source=%d,%d Destination=%d,%d\n",
-							ddp->deh_snet,
-							ddp->deh_snode,
-							ddp->deh_dnet,
-							ddp->deh_dnode);
+			case NAT25_LOOKUP: {
+				RTW_INFO("NAT25: Lookup DDP, Source=%d,%d Destination=%d,%d\n",
+					 ddp->deh_snet,
+					 ddp->deh_snode,
+					 ddp->deh_dnet,
+					 ddp->deh_dnode);
 
-						__nat25_generate_apple_network_addr(networkAddr, &ddp->deh_dnet, &ddp->deh_dnode);
+				__nat25_generate_apple_network_addr(networkAddr, &ddp->deh_dnet, &ddp->deh_dnode);
 
-						__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
-					}
-					return 0;
+				__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
+			}
+			return 0;
 
-				default:
-					return -1;
+			default:
+				return -1;
 			}
 		}
 
@@ -1193,291 +1111,271 @@ int nat25_db_handle(_adapter *priv, struct sk_buff *skb, int method)
 	}
 
 	/*---------------------------------------------------*/
-	/*                Handle PPPoE frame                 */
+	/*                Handle PPPoE frame                */
 	/*---------------------------------------------------*/
-	else if((protocol == __constant_htons(ETH_P_PPP_DISC)) ||
-		(protocol == __constant_htons(ETH_P_PPP_SES)))
-	{
+	else if ((protocol == __constant_htons(ETH_P_PPP_DISC)) ||
+		 (protocol == __constant_htons(ETH_P_PPP_SES))) {
 		struct pppoe_hdr *ph = (struct pppoe_hdr *)(skb->data + ETH_HLEN);
 		unsigned short *pMagic;
 
-		switch(method)
-		{
-			case NAT25_CHECK:
-				if (ph->sid == 0)
-					return 0;
-				return 1;
+		switch (method) {
+		case NAT25_CHECK:
+			if (ph->sid == 0)
+				return 0;
+			return 1;
 
-			case NAT25_INSERT:
-				if(ph->sid == 0)	// Discovery phase according to tag
-				{
-					if(ph->code == PADI_CODE || ph->code == PADR_CODE)
-					{
-						if (priv->ethBrExtInfo.addPPPoETag) {
-							struct pppoe_tag *tag, *pOldTag;
-							unsigned char tag_buf[40];
-							int old_tag_len=0;
-
-							tag = (struct pppoe_tag *)tag_buf;
-							pOldTag = (struct pppoe_tag *)__nat25_find_pppoe_tag(ph, ntohs(PTT_RELAY_SID));
-							if (pOldTag) { // if SID existed, copy old value and delete it
-								old_tag_len = ntohs(pOldTag->tag_len);
-								if (old_tag_len+TAG_HDR_LEN+MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN > sizeof(tag_buf)) {
-									DEBUG_ERR("SID tag length too long!\n");
-									return -1;
-								}
-
-								memcpy(tag->tag_data+MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN,
-									pOldTag->tag_data, old_tag_len);
-
-								if (skb_pull_and_merge(skb, (unsigned char *)pOldTag, TAG_HDR_LEN+old_tag_len) < 0) {
-									DEBUG_ERR("call skb_pull_and_merge() failed in PADI/R packet!\n");
-									return -1;
-								}
-								ph->length = htons(ntohs(ph->length)-TAG_HDR_LEN-old_tag_len);
+		case NAT25_INSERT:
+			if (ph->sid == 0) {	/* Discovery phase according to tag */
+				if (ph->code == PADI_CODE || ph->code == PADR_CODE) {
+					if (priv->ethBrExtInfo.addPPPoETag) {
+						struct pppoe_tag *tag, *pOldTag;
+						unsigned char tag_buf[40];
+						int old_tag_len = 0;
+
+						tag = (struct pppoe_tag *)tag_buf;
+						pOldTag = (struct pppoe_tag *)__nat25_find_pppoe_tag(ph, ntohs(PTT_RELAY_SID));
+						if (pOldTag) { /* if SID existed, copy old value and delete it */
+							old_tag_len = ntohs(pOldTag->tag_len);
+							if (old_tag_len + TAG_HDR_LEN + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN > sizeof(tag_buf)) {
+								DEBUG_ERR("SID tag length too long!\n");
+								return -1;
 							}
 
-							tag->tag_type = PTT_RELAY_SID;
-							tag->tag_len = htons(MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN+old_tag_len);
-
-							// insert the magic_code+client mac in relay tag
-							pMagic = (unsigned short *)tag->tag_data;
-							*pMagic = htons(MAGIC_CODE);
-							memcpy(tag->tag_data+MAGIC_CODE_LEN, skb->data+ETH_ALEN, ETH_ALEN);
+							memcpy(tag->tag_data + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN,
+							       pOldTag->tag_data, old_tag_len);
 
-							//Add relay tag
-							if(__nat25_add_pppoe_tag(skb, tag) < 0)
+							if (skb_pull_and_merge(skb, (unsigned char *)pOldTag, TAG_HDR_LEN + old_tag_len) < 0) {
+								DEBUG_ERR("call skb_pull_and_merge() failed in PADI/R packet!\n");
 								return -1;
-
-							DBG_871X("NAT25: Insert PPPoE, forward %s packet\n",
-											(ph->code == PADI_CODE ? "PADI" : "PADR"));
-						}
-						else { // not add relay tag
-							if (priv->pppoe_connection_in_progress &&
-									memcmp(skb->data+ETH_ALEN, priv->pppoe_addr, ETH_ALEN))	 {
-								DEBUG_ERR("Discard PPPoE packet due to another PPPoE connection is in progress!\n");
-								return -2;
 							}
+							ph->length = htons(ntohs(ph->length) - TAG_HDR_LEN - old_tag_len);
+						}
 
-							if (priv->pppoe_connection_in_progress == 0)
-								memcpy(priv->pppoe_addr, skb->data+ETH_ALEN, ETH_ALEN);
+						tag->tag_type = PTT_RELAY_SID;
+						tag->tag_len = htons(MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN + old_tag_len);
 
-							priv->pppoe_connection_in_progress = WAIT_TIME_PPPOE;
-						}
-					}
-					else
-						return -1;
-				}
-				else	// session phase
-				{
-						DBG_871X("NAT25: Insert PPPoE, insert session packet to %s\n", skb->dev->name);
+						/* insert the magic_code+client mac in relay tag */
+						pMagic = (unsigned short *)tag->tag_data;
+						*pMagic = htons(MAGIC_CODE);
+						memcpy(tag->tag_data + MAGIC_CODE_LEN, skb->data + ETH_ALEN, ETH_ALEN);
 
-						__nat25_generate_pppoe_network_addr(networkAddr, skb->data, &(ph->sid));
+						/* Add relay tag */
+						if (__nat25_add_pppoe_tag(skb, tag) < 0)
+							return -1;
 
-						__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
+						RTW_INFO("NAT25: Insert PPPoE, forward %s packet\n",
+							(ph->code == PADI_CODE ? "PADI" : "PADR"));
+					} else { /* not add relay tag */
+						if (priv->pppoe_connection_in_progress &&
+						    memcmp(skb->data + ETH_ALEN, priv->pppoe_addr, ETH_ALEN))	 {
+							DEBUG_ERR("Discard PPPoE packet due to another PPPoE connection is in progress!\n");
+							return -2;
+						}
 
-						__nat25_db_print(priv);
+						if (priv->pppoe_connection_in_progress == 0)
+							memcpy(priv->pppoe_addr, skb->data + ETH_ALEN, ETH_ALEN);
 
-						if (!priv->ethBrExtInfo.addPPPoETag &&
-								priv->pppoe_connection_in_progress &&
-									!memcmp(skb->data+ETH_ALEN, priv->pppoe_addr, ETH_ALEN))
-							priv->pppoe_connection_in_progress = 0;
-				}
-				return 0;
+						priv->pppoe_connection_in_progress = WAIT_TIME_PPPOE;
+					}
+				} else
+					return -1;
+			} else {	/* session phase */
+				RTW_INFO("NAT25: Insert PPPoE, insert session packet to %s\n", skb->dev->name);
 
-			case NAT25_LOOKUP:
-				if(ph->code == PADO_CODE || ph->code == PADS_CODE)
-				{
-					if (priv->ethBrExtInfo.addPPPoETag) {
-						struct pppoe_tag *tag;
-						unsigned char *ptr;
-						unsigned short tagType, tagLen;
-						int offset=0;
+				__nat25_generate_pppoe_network_addr(networkAddr, skb->data, &(ph->sid));
 
-						if((ptr = __nat25_find_pppoe_tag(ph, ntohs(PTT_RELAY_SID))) == 0) {
-							DEBUG_ERR("Fail to find PTT_RELAY_SID in FADO!\n");
-							return -1;
-						}
+				__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
 
-						tag = (struct pppoe_tag *)ptr;
-						tagType = (unsigned short)((ptr[0] << 8) + ptr[1]);
-						tagLen = (unsigned short)((ptr[2] << 8) + ptr[3]);
+				__nat25_db_print(priv);
 
-						if((tagType != ntohs(PTT_RELAY_SID)) || (tagLen < (MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN))) {
-							DEBUG_ERR("Invalid PTT_RELAY_SID tag length [%d]!\n", tagLen);
-							return -1;
-						}
+				if (!priv->ethBrExtInfo.addPPPoETag &&
+				    priv->pppoe_connection_in_progress &&
+				    !memcmp(skb->data + ETH_ALEN, priv->pppoe_addr, ETH_ALEN))
+					priv->pppoe_connection_in_progress = 0;
+			}
+			return 0;
+
+		case NAT25_LOOKUP:
+			if (ph->code == PADO_CODE || ph->code == PADS_CODE) {
+				if (priv->ethBrExtInfo.addPPPoETag) {
+					struct pppoe_tag *tag;
+					unsigned char *ptr;
+					unsigned short tagType, tagLen;
+					int offset = 0;
+
+					ptr = __nat25_find_pppoe_tag(ph, ntohs(PTT_RELAY_SID));
+					if (ptr == 0) {
+						DEBUG_ERR("Fail to find PTT_RELAY_SID in FADO!\n");
+						return -1;
+					}
 
-						pMagic = (unsigned short *)tag->tag_data;
-						if (ntohs(*pMagic) != MAGIC_CODE) {
-							DEBUG_ERR("Can't find MAGIC_CODE in %s packet!\n",
-								(ph->code == PADO_CODE ? "PADO" : "PADS"));
-							return -1;
-						}
+					tag = (struct pppoe_tag *)ptr;
+					tagType = (unsigned short)((ptr[0] << 8) + ptr[1]);
+					tagLen = (unsigned short)((ptr[2] << 8) + ptr[3]);
+
+					if ((tagType != ntohs(PTT_RELAY_SID)) || (tagLen < (MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN))) {
+						DEBUG_ERR("Invalid PTT_RELAY_SID tag length [%d]!\n", tagLen);
+						return -1;
+					}
 
-						memcpy(skb->data, tag->tag_data+MAGIC_CODE_LEN, ETH_ALEN);
+					pMagic = (unsigned short *)tag->tag_data;
+					if (ntohs(*pMagic) != MAGIC_CODE) {
+						DEBUG_ERR("Can't find MAGIC_CODE in %s packet!\n",
+							(ph->code == PADO_CODE ? "PADO" : "PADS"));
+						return -1;
+					}
 
-						if (tagLen > MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN)
-							offset = TAG_HDR_LEN;
+					memcpy(skb->data, tag->tag_data + MAGIC_CODE_LEN, ETH_ALEN);
 
-						if (skb_pull_and_merge(skb, ptr+offset, TAG_HDR_LEN+MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN-offset) < 0) {
-							DEBUG_ERR("call skb_pull_and_merge() failed in PADO packet!\n");
-							return -1;
-						}
-						ph->length = htons(ntohs(ph->length)-(TAG_HDR_LEN+MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN-offset));
-						if (offset > 0)
-							tag->tag_len = htons(tagLen-MAGIC_CODE_LEN-RTL_RELAY_TAG_LEN);
+					if (tagLen > MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN)
+						offset = TAG_HDR_LEN;
 
-						DBG_871X("NAT25: Lookup PPPoE, forward %s Packet from %s\n",
-							(ph->code == PADO_CODE ? "PADO" : "PADS"),	skb->dev->name);
+					if (skb_pull_and_merge(skb, ptr + offset, TAG_HDR_LEN + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN - offset) < 0) {
+						DEBUG_ERR("call skb_pull_and_merge() failed in PADO packet!\n");
+						return -1;
 					}
-					else { // not add relay tag
-						if (!priv->pppoe_connection_in_progress) {
-							DEBUG_ERR("Discard PPPoE packet due to no connection in progresss!\n");
-							return -1;
-						}
-						memcpy(skb->data, priv->pppoe_addr, ETH_ALEN);
-						priv->pppoe_connection_in_progress = WAIT_TIME_PPPOE;
+					ph->length = htons(ntohs(ph->length) - (TAG_HDR_LEN + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN - offset));
+					if (offset > 0)
+						tag->tag_len = htons(tagLen - MAGIC_CODE_LEN - RTL_RELAY_TAG_LEN);
+
+					RTW_INFO("NAT25: Lookup PPPoE, forward %s Packet from %s\n",
+						(ph->code == PADO_CODE ? "PADO" : "PADS"),	skb->dev->name);
+				} else { /* not add relay tag */
+					if (!priv->pppoe_connection_in_progress) {
+						DEBUG_ERR("Discard PPPoE packet due to no connection in progresss!\n");
+						return -1;
 					}
+					memcpy(skb->data, priv->pppoe_addr, ETH_ALEN);
+					priv->pppoe_connection_in_progress = WAIT_TIME_PPPOE;
 				}
-				else {
-					if(ph->sid != 0)
-					{
-						DBG_871X("NAT25: Lookup PPPoE, lookup session packet from %s\n", skb->dev->name);
-						__nat25_generate_pppoe_network_addr(networkAddr, skb->data+ETH_ALEN, &(ph->sid));
+			} else {
+				if (ph->sid != 0) {
+					RTW_INFO("NAT25: Lookup PPPoE, lookup session packet from %s\n", skb->dev->name);
+					__nat25_generate_pppoe_network_addr(networkAddr, skb->data + ETH_ALEN, &(ph->sid));
 
-						__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
+					__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
 
-						__nat25_db_print(priv);
-					}
-					else
-						return -1;
+					__nat25_db_print(priv);
+				} else
+					return -1;
 
-				}
-				return 0;
+			}
+			return 0;
 
-			default:
-				return -1;
+		default:
+			return -1;
 		}
 	}
 
 	/*---------------------------------------------------*/
-	/*                 Handle EAP frame                  */
+	/*                 Handle EAP frame                 */
 	/*---------------------------------------------------*/
-	else if(protocol == __constant_htons(0x888e))
-	{
-		switch(method)
-		{
-			case NAT25_CHECK:
-				return -1;
+	else if (protocol == __constant_htons(0x888e)) {
+		switch (method) {
+		case NAT25_CHECK:
+			return -1;
 
-			case NAT25_INSERT:
-				return 0;
+		case NAT25_INSERT:
+			return 0;
 
-			case NAT25_LOOKUP:
-				return 0;
+		case NAT25_LOOKUP:
+			return 0;
 
-			default:
-				return -1;
+		default:
+			return -1;
 		}
 	}
 
 	/*---------------------------------------------------*/
-	/*         Handle C-Media proprietary frame          */
+	/*         Handle C-Media proprietary frame         */
 	/*---------------------------------------------------*/
-	else if((protocol == __constant_htons(0xe2ae)) ||
-		(protocol == __constant_htons(0xe2af)))
-	{
-		switch(method)
-		{
-			case NAT25_CHECK:
-				return -1;
+	else if ((protocol == __constant_htons(0xe2ae)) ||
+		 (protocol == __constant_htons(0xe2af))) {
+		switch (method) {
+		case NAT25_CHECK:
+			return -1;
 
-			case NAT25_INSERT:
-				return 0;
+		case NAT25_INSERT:
+			return 0;
 
-			case NAT25_LOOKUP:
-				return 0;
+		case NAT25_LOOKUP:
+			return 0;
 
-			default:
-				return -1;
+		default:
+			return -1;
 		}
 	}
 
 	/*---------------------------------------------------*/
-	/*         Handle IPV6 frame      							  */
+	/*         Handle IPV6 frame      							 */
 	/*---------------------------------------------------*/
 #ifdef CL_IPV6_PASS
-	else if(protocol == __constant_htons(ETH_P_IPV6))
-	{
+	else if (protocol == __constant_htons(ETH_P_IPV6)) {
 		struct ipv6hdr *iph = (struct ipv6hdr *)(skb->data + ETH_HLEN);
 
-		if (sizeof(*iph) >= (skb->len - ETH_HLEN))
-		{
+		if (sizeof(*iph) >= (skb->len - ETH_HLEN)) {
 			DEBUG_WARN("NAT25: malformed IPv6 packet !\n");
 			return -1;
 		}
 
-		switch(method)
-		{
-			case NAT25_CHECK:
-				if (skb->data[0] & 1)
-					return 0;				
-				return -1;
-
-			case NAT25_INSERT:
-				{
-					DBG_871X("NAT25: Insert IP, SA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x,"
-									" DA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x\n", 
-						iph->saddr.s6_addr16[0],iph->saddr.s6_addr16[1],iph->saddr.s6_addr16[2],iph->saddr.s6_addr16[3],
-						iph->saddr.s6_addr16[4],iph->saddr.s6_addr16[5],iph->saddr.s6_addr16[6],iph->saddr.s6_addr16[7],
-						iph->daddr.s6_addr16[0],iph->daddr.s6_addr16[1],iph->daddr.s6_addr16[2],iph->daddr.s6_addr16[3],
-						iph->daddr.s6_addr16[4],iph->daddr.s6_addr16[5],iph->daddr.s6_addr16[6],iph->daddr.s6_addr16[7]);
-
-					if (memcmp(&iph->saddr, "\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0", 16)) {
-						__nat25_generate_ipv6_network_addr(networkAddr, (unsigned int *)&iph->saddr);
-						__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
-						__nat25_db_print(priv);
-
-						if (iph->nexthdr == IPPROTO_ICMPV6 && 
-								skb->len > (ETH_HLEN +  sizeof(*iph) + 4)) {
-							if (update_nd_link_layer_addr(skb->data + ETH_HLEN + sizeof(*iph), 
-                                                                skb->len - ETH_HLEN - sizeof(*iph), GET_MY_HWADDR(priv))) {                                                   
-								struct icmp6hdr  *hdr = (struct icmp6hdr *)(skb->data + ETH_HLEN + sizeof(*iph));
-								hdr->icmp6_cksum = 0;
-								hdr->icmp6_cksum = csum_ipv6_magic(&iph->saddr, &iph->daddr,
-												iph->payload_len,
-												IPPROTO_ICMPV6,
-												csum_partial((__u8 *)hdr, iph->payload_len, 0));
-							}
-						}						
-					}
-				}
+		switch (method) {
+		case NAT25_CHECK:
+			if (skb->data[0] & 1)
 				return 0;
+			return -1;
 
-			case NAT25_LOOKUP:
-				DBG_871X("NAT25: Lookup IP, SA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x,"
-								" DA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x\n", 
-						iph->saddr.s6_addr16[0],iph->saddr.s6_addr16[1],iph->saddr.s6_addr16[2],iph->saddr.s6_addr16[3],
-						iph->saddr.s6_addr16[4],iph->saddr.s6_addr16[5],iph->saddr.s6_addr16[6],iph->saddr.s6_addr16[7],
-						iph->daddr.s6_addr16[0],iph->daddr.s6_addr16[1],iph->daddr.s6_addr16[2],iph->daddr.s6_addr16[3],
-						iph->daddr.s6_addr16[4],iph->daddr.s6_addr16[5],iph->daddr.s6_addr16[6],iph->daddr.s6_addr16[7]);
-			
-
-				__nat25_generate_ipv6_network_addr(networkAddr, (unsigned int *)&iph->daddr);
-				if (!__nat25_db_network_lookup_and_replace(priv, skb, networkAddr)) {
-#ifdef SUPPORT_RX_UNI2MCAST							
-					if (iph->daddr.s6_addr[0] == 0xff)
-						convert_ipv6_mac_to_mc(skb);	
-#endif											
+		case NAT25_INSERT: {
+			RTW_INFO("NAT25: Insert IP, SA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x,"
+				" DA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x\n",
+				iph->saddr.s6_addr16[0], iph->saddr.s6_addr16[1], iph->saddr.s6_addr16[2], iph->saddr.s6_addr16[3],
+				iph->saddr.s6_addr16[4], iph->saddr.s6_addr16[5], iph->saddr.s6_addr16[6], iph->saddr.s6_addr16[7],
+				iph->daddr.s6_addr16[0], iph->daddr.s6_addr16[1], iph->daddr.s6_addr16[2], iph->daddr.s6_addr16[3],
+				iph->daddr.s6_addr16[4], iph->daddr.s6_addr16[5], iph->daddr.s6_addr16[6], iph->daddr.s6_addr16[7]);
+
+			if (memcmp(&iph->saddr, "\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0", 16)) {
+				__nat25_generate_ipv6_network_addr(networkAddr, (unsigned int *)&iph->saddr);
+				__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
+				__nat25_db_print(priv);
+
+				if (iph->nexthdr == IPPROTO_ICMPV6 &&
+				    skb->len > (ETH_HLEN +  sizeof(*iph) + 4)) {
+					if (update_nd_link_layer_addr(skb->data + ETH_HLEN + sizeof(*iph),
+						skb->len - ETH_HLEN - sizeof(*iph), GET_MY_HWADDR(priv))) {
+						struct icmp6hdr  *hdr = (struct icmp6hdr *)(skb->data + ETH_HLEN + sizeof(*iph));
+						hdr->icmp6_cksum = 0;
+						hdr->icmp6_cksum = csum_ipv6_magic(&iph->saddr, &iph->daddr,
+							iph->payload_len,
+							IPPROTO_ICMPV6,
+							csum_partial((__u8 *)hdr, iph->payload_len, 0));
+					}
 				}
-				return 0;
+			}
+		}
+		return 0;
+
+		case NAT25_LOOKUP:
+			RTW_INFO("NAT25: Lookup IP, SA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x,"
+				 " DA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x\n",
+				iph->saddr.s6_addr16[0], iph->saddr.s6_addr16[1], iph->saddr.s6_addr16[2], iph->saddr.s6_addr16[3],
+				iph->saddr.s6_addr16[4], iph->saddr.s6_addr16[5], iph->saddr.s6_addr16[6], iph->saddr.s6_addr16[7],
+				iph->daddr.s6_addr16[0], iph->daddr.s6_addr16[1], iph->daddr.s6_addr16[2], iph->daddr.s6_addr16[3],
+				iph->daddr.s6_addr16[4], iph->daddr.s6_addr16[5], iph->daddr.s6_addr16[6], iph->daddr.s6_addr16[7]);
+
+
+			__nat25_generate_ipv6_network_addr(networkAddr, (unsigned int *)&iph->daddr);
+			if (!__nat25_db_network_lookup_and_replace(priv, skb, networkAddr)) {
+#ifdef SUPPORT_RX_UNI2MCAST
+				if (iph->daddr.s6_addr[0] == 0xff)
+					convert_ipv6_mac_to_mc(skb);
+#endif
+			}
+			return 0;
 
-			default:
-				return -1;
+		default:
+			return -1;
 		}
 	}
-#endif	// CL_IPV6_PASS
+#endif /* CL_IPV6_PASS */
 
 	return -1;
 }
@@ -1486,39 +1384,36 @@ int nat25_db_handle(_adapter *priv, struct sk_buff *skb, int method)
 int nat25_handle_frame(_adapter *priv, struct sk_buff *skb)
 {
 #ifdef BR_EXT_DEBUG
-	if((!priv->ethBrExtInfo.nat25_disable) && (!(skb->data[0] & 1)))
-	{
+	if ((!priv->ethBrExtInfo.nat25_disable) && (!(skb->data[0] & 1))) {
 		panic_printk("NAT25: Input Frame: DA=%02x%02x%02x%02x%02x%02x SA=%02x%02x%02x%02x%02x%02x\n",
-			skb->data[0],
-			skb->data[1],
-			skb->data[2],
-			skb->data[3],
-			skb->data[4],
-			skb->data[5],
-			skb->data[6],
-			skb->data[7],
-			skb->data[8],
-			skb->data[9],
-			skb->data[10],
-			skb->data[11]);
+			     skb->data[0],
+			     skb->data[1],
+			     skb->data[2],
+			     skb->data[3],
+			     skb->data[4],
+			     skb->data[5],
+			     skb->data[6],
+			     skb->data[7],
+			     skb->data[8],
+			     skb->data[9],
+			     skb->data[10],
+			     skb->data[11]);
 	}
 #endif
 
-	if(!(skb->data[0] & 1))
-	{
-		int is_vlan_tag=0, i, retval=0;
-		unsigned short vlan_hdr=0;
+	if (!(skb->data[0] & 1)) {
+		int is_vlan_tag = 0, i, retval = 0;
+		unsigned short vlan_hdr = 0;
 
-		if (*((unsigned short *)(skb->data+ETH_ALEN*2)) == __constant_htons(ETH_P_8021Q)) {
+		if (*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_8021Q)) {
 			is_vlan_tag = 1;
-			vlan_hdr = *((unsigned short *)(skb->data+ETH_ALEN*2+2));
-			for (i=0; i<6; i++)
-				*((unsigned short *)(skb->data+ETH_ALEN*2+2-i*2)) = *((unsigned short *)(skb->data+ETH_ALEN*2-2-i*2));
+			vlan_hdr = *((unsigned short *)(skb->data + ETH_ALEN * 2 + 2));
+			for (i = 0; i < 6; i++)
+				*((unsigned short *)(skb->data + ETH_ALEN * 2 + 2 - i * 2)) = *((unsigned short *)(skb->data + ETH_ALEN * 2 - 2 - i * 2));
 			skb_pull(skb, 4);
 		}
 
-		if (!priv->ethBrExtInfo.nat25_disable)
-		{
+		if (!priv->ethBrExtInfo.nat25_disable) {
 			_irqL irqL;
 			_enter_critical_bh(&priv->br_ext_lock, &irqL);
 			/*
@@ -1527,38 +1422,36 @@ int nat25_handle_frame(_adapter *priv, struct sk_buff *skb)
 			 *	corresponding network protocol is NOT support.
 			 */
 			if (!priv->ethBrExtInfo.nat25sc_disable &&
-				(*((unsigned short *)(skb->data+ETH_ALEN*2)) == __constant_htons(ETH_P_IP)) &&
-				!memcmp(priv->scdb_ip, skb->data+ETH_HLEN+16, 4)) {
+			    (*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_IP)) &&
+			    !memcmp(priv->scdb_ip, skb->data + ETH_HLEN + 16, 4)) {
 				memcpy(skb->data, priv->scdb_mac, ETH_ALEN);
-				
+
 				_exit_critical_bh(&priv->br_ext_lock, &irqL);
-			}
-			else {
+			} else {
 				_exit_critical_bh(&priv->br_ext_lock, &irqL);
-				
+
 				retval = nat25_db_handle(priv, skb, NAT25_LOOKUP);
 			}
-		}
-		else {
-			if (((*((unsigned short *)(skb->data+ETH_ALEN*2)) == __constant_htons(ETH_P_IP)) &&
-					!memcmp(priv->br_ip, skb->data+ETH_HLEN+16, 4)) ||
-				((*((unsigned short *)(skb->data+ETH_ALEN*2)) == __constant_htons(ETH_P_ARP)) &&
-					!memcmp(priv->br_ip, skb->data+ETH_HLEN+24, 4))) {
-				// for traffic to upper TCP/IP
+		} else {
+			if (((*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_IP)) &&
+			     !memcmp(priv->br_ip, skb->data + ETH_HLEN + 16, 4)) ||
+			    ((*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_ARP)) &&
+			     !memcmp(priv->br_ip, skb->data + ETH_HLEN + 24, 4))) {
+				/* for traffic to upper TCP/IP */
 				retval = nat25_db_handle(priv, skb, NAT25_LOOKUP);
 			}
 		}
 
 		if (is_vlan_tag) {
 			skb_push(skb, 4);
-			for (i=0; i<6; i++)
-				*((unsigned short *)(skb->data+i*2)) = *((unsigned short *)(skb->data+4+i*2));
-			*((unsigned short *)(skb->data+ETH_ALEN*2)) = __constant_htons(ETH_P_8021Q);
-			*((unsigned short *)(skb->data+ETH_ALEN*2+2)) = vlan_hdr;
+			for (i = 0; i < 6; i++)
+				*((unsigned short *)(skb->data + i * 2)) = *((unsigned short *)(skb->data + 4 + i * 2));
+			*((unsigned short *)(skb->data + ETH_ALEN * 2)) = __constant_htons(ETH_P_8021Q);
+			*((unsigned short *)(skb->data + ETH_ALEN * 2 + 2)) = vlan_hdr;
 		}
 
-		if(retval == -1) {
-			//DEBUG_ERR("NAT25: Lookup fail!\n");
+		if (retval == -1) {
+			/* DEBUG_ERR("NAT25: Lookup fail!\n"); */
 			return -1;
 		}
 	}
@@ -1572,23 +1465,20 @@ void mac_clone(_adapter *priv, unsigned char *addr)
 	struct sockaddr sa;
 
 	memcpy(sa.sa_data, addr, ETH_ALEN);
-	DBG_871X("MAC Clone: Addr=%02x%02x%02x%02x%02x%02x\n",
-		addr[0], addr[1], addr[2], addr[3], addr[4], addr[5]);
+	RTW_INFO("MAC Clone: Addr=%02x%02x%02x%02x%02x%02x\n",
+		 addr[0], addr[1], addr[2], addr[3], addr[4], addr[5]);
 	rtl8192cd_set_hwaddr(priv->dev, &sa);
 }
 
 
 int mac_clone_handle_frame(_adapter *priv, struct sk_buff *skb)
 {
-	if(priv->ethBrExtInfo.macclone_enable && !priv->macclone_completed)
-	{
-		if(!(skb->data[ETH_ALEN] & 1))	//// check any other particular MAC add
-		{
-                        if(memcmp(skb->data+ETH_ALEN, GET_MY_HWADDR(priv), ETH_ALEN) &&
-				((priv->dev->br_port) &&
-				 memcmp(skb->data+ETH_ALEN, priv->br_mac, ETH_ALEN)))
-			{
-				mac_clone(priv, skb->data+ETH_ALEN);
+	if (priv->ethBrExtInfo.macclone_enable && !priv->macclone_completed) {
+		if (!(skb->data[ETH_ALEN] & 1)) {	/* check any other particular MAC add */
+			if (memcmp(skb->data + ETH_ALEN, GET_MY_HWADDR(priv), ETH_ALEN) &&
+			    ((priv->dev->br_port) &&
+			     memcmp(skb->data + ETH_ALEN, priv->br_mac, ETH_ALEN))) {
+				mac_clone(priv, skb->data + ETH_ALEN);
 				priv->macclone_completed = 1;
 			}
 		}
@@ -1596,7 +1486,7 @@ int mac_clone_handle_frame(_adapter *priv, struct sk_buff *skb)
 
 	return 0;
 }
-#endif // 0
+#endif /* 0 */
 
 #define SERVER_PORT			67
 #define CLIENT_PORT			68
@@ -1624,40 +1514,34 @@ struct dhcpMessage {
 
 void dhcp_flag_bcast(_adapter *priv, struct sk_buff *skb)
 {
-	if(skb == NULL)
+	if (skb == NULL)
 		return;
 
-	if(!priv->ethBrExtInfo.dhcp_bcst_disable)
-	{
+	if (!priv->ethBrExtInfo.dhcp_bcst_disable) {
 		unsigned short protocol = *((unsigned short *)(skb->data + 2 * ETH_ALEN));
 
-		if(protocol == __constant_htons(ETH_P_IP)) // IP
-		{
-			struct iphdr* iph = (struct iphdr *)(skb->data + ETH_HLEN);
+		if (protocol == __constant_htons(ETH_P_IP)) { /* IP */
+			struct iphdr *iph = (struct iphdr *)(skb->data + ETH_HLEN);
 
-			if(iph->protocol == IPPROTO_UDP) // UDP
-			{
+			if (iph->protocol == IPPROTO_UDP) { /* UDP */
 				struct udphdr *udph = (struct udphdr *)((SIZE_PTR)iph + (iph->ihl << 2));
 
-				if((udph->source == __constant_htons(CLIENT_PORT))
-					&& (udph->dest == __constant_htons(SERVER_PORT))) // DHCP request
-				{
+				if ((udph->source == __constant_htons(CLIENT_PORT))
+				    && (udph->dest == __constant_htons(SERVER_PORT))) { /* DHCP request */
 					struct dhcpMessage *dhcph =
 						(struct dhcpMessage *)((SIZE_PTR)udph + sizeof(struct udphdr));
 
-					if(dhcph->cookie == __constant_htonl(DHCP_MAGIC)) // match magic word
-					{
-						if(!(dhcph->flags & htons(BROADCAST_FLAG))) // if not broadcast
-						{
+					if (dhcph->cookie == __constant_htonl(DHCP_MAGIC)) { /* match magic word */
+						if (!(dhcph->flags & htons(BROADCAST_FLAG))) { /* if not broadcast */
 							register int sum = 0;
 
-							DBG_871X("DHCP: change flag of DHCP request to broadcast.\n");
-							// or BROADCAST flag
+							RTW_INFO("DHCP: change flag of DHCP request to broadcast.\n");
+							/* or BROADCAST flag */
 							dhcph->flags |= htons(BROADCAST_FLAG);
-							// recalculate checksum
+							/* recalculate checksum */
 							sum = ~(udph->check) & 0xffff;
 							sum += dhcph->flags;
-							while(sum >> 16)
+							while (sum >> 16)
 								sum = (sum & 0xffff) + (sum >> 16);
 							udph->check = ~sum;
 						}
@@ -1670,30 +1554,28 @@ void dhcp_flag_bcast(_adapter *priv, struct sk_buff *skb)
 
 
 void *scdb_findEntry(_adapter *priv, unsigned char *macAddr,
-				unsigned char *ipAddr)
+		     unsigned char *ipAddr)
 {
 	unsigned char networkAddr[MAX_NETWORK_ADDR_LEN];
 	struct nat25_network_db_entry *db;
 	int hash;
-	//_irqL irqL;
-	//_enter_critical_bh(&priv->br_ext_lock, &irqL);
+	/* _irqL irqL; */
+	/* _enter_critical_bh(&priv->br_ext_lock, &irqL); */
 
 	__nat25_generate_ipv4_network_addr(networkAddr, (unsigned int *)ipAddr);
 	hash = __nat25_network_hash(networkAddr);
 	db = priv->nethash[hash];
-	while (db != NULL)
-	{
-		if(!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN)) {
-			//_exit_critical_bh(&priv->br_ext_lock, &irqL);
+	while (db != NULL) {
+		if (!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN)) {
+			/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
 			return (void *)db;
 		}
 
 		db = db->next_hash;
 	}
 
-	//_exit_critical_bh(&priv->br_ext_lock, &irqL);
+	/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
 	return NULL;
 }
 
-#endif	// CONFIG_BR_EXT
-
+#endif /* CONFIG_BR_EXT */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_bt_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_bt_mp.c
index 30cf14e5ab88..f198cbb2ce88 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_bt_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_bt_mp.c
@@ -1,1753 +1,1576 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-
-#include <drv_types.h>
-#include <rtw_bt_mp.h>
-
-#if defined(CONFIG_RTL8723B)
-#include <rtl8723b_hal.h>
-#endif
-
-#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8821A)
-void MPh2c_timeout_handle(void *FunctionContext)
-{
-	PADAPTER pAdapter;
-	PMPT_CONTEXT pMptCtx;
-
-
-	DBG_8192C("[MPT], MPh2c_timeout_handle \n");
-
-	pAdapter = (PADAPTER)FunctionContext;
-	pMptCtx = &pAdapter->mppriv.MptCtx;
-
-	pMptCtx->bMPh2c_timeout = _TRUE;
-
-	if ((_FALSE == pMptCtx->MptH2cRspEvent)
-		|| ((_TRUE == pMptCtx->MptH2cRspEvent)
-			&& (_FALSE == pMptCtx->MptBtC2hEvent)))
-	{
-		_rtw_up_sema(&pMptCtx->MPh2c_Sema);
-	}
-}
-
-u32 WaitC2Hevent(PADAPTER pAdapter, u8 *C2H_event, u32 delay_time)
-{
-	PMPT_CONTEXT		pMptCtx=&(pAdapter->mppriv.MptCtx);
-	pMptCtx->bMPh2c_timeout=_FALSE;
-	
-	if( pAdapter->registrypriv.mp_mode == 0 )
-	{
-		DBG_8192C("[MPT], Error!! WaitC2Hevent mp_mode == 0!!\n");
-		return _FALSE;
-	}
-
-	_set_timer( &pMptCtx->MPh2c_timeout_timer, delay_time );
-	
-	_rtw_down_sema(&pMptCtx->MPh2c_Sema);
-
-	if (pMptCtx->bMPh2c_timeout == _TRUE)
-	{
-		*C2H_event = _FALSE;
-		
-		return _FALSE;
-	}
-
-	// for safty, cancel timer here again
-	_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
-	
-	return _TRUE;
-}
-
-BT_CTRL_STATUS
-mptbt_CheckC2hFrame(
-	PADAPTER		Adapter,
-	PBT_H2C			pH2c,
-	PBT_EXT_C2H		pExtC2h
-	)
-{
-	BT_CTRL_STATUS	c2hStatus = BT_STATUS_C2H_SUCCESS;
-		
-	//DBG_8192C("[MPT], MPT rsp C2H hex: %x %x %x  %x %x %x \n"), pExtC2h , pExtC2h+1 ,pExtC2h+2 ,pExtC2h+3 ,pExtC2h+4 ,pExtC2h+5);
-
-	DBG_8192C("[MPT], statusCode = 0x%x\n", pExtC2h->statusCode);
-	DBG_8192C("[MPT], retLen = %d\n", pExtC2h->retLen);
-	DBG_8192C("[MPT], opCodeVer : req/rsp=%d/%d\n", pH2c->opCodeVer, pExtC2h->opCodeVer);
-	DBG_8192C("[MPT], reqNum : req/rsp=%d/%d\n", pH2c->reqNum, pExtC2h->reqNum);
-	if(pExtC2h->reqNum != pH2c->reqNum)
-	{
-		c2hStatus = BT_STATUS_C2H_REQNUM_MISMATCH;
-		DBG_8192C("[MPT], Error!! C2H reqNum Mismatch!!\n");
-	}
-	else if(pExtC2h->opCodeVer != pH2c->opCodeVer)
-	{
-		c2hStatus = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
-		DBG_8192C("[MPT], Error!! OPCode version L mismatch!!\n");
-	}
-
-	return c2hStatus;
-}
-
-BT_CTRL_STATUS
-mptbt_SendH2c(
-	PADAPTER	Adapter,
-	PBT_H2C	pH2c,
-	u2Byte		h2cCmdLen
-	)
-{
-	//KIRQL				OldIrql = KeGetCurrentIrql();
-	BT_CTRL_STATUS	h2cStatus=BT_STATUS_H2C_SUCCESS;
-	PMPT_CONTEXT		pMptCtx=&(Adapter->mppriv.MptCtx);
-	u1Byte				i;
-
-	DBG_8192C("[MPT], mptbt_SendH2c()=========>\n");
-
-	//PlatformResetEvent(&pMptCtx->MptH2cRspEvent);
-	//PlatformResetEvent(&pMptCtx->MptBtC2hEvent);
-	
-//	if(OldIrql == PASSIVE_LEVEL)
-//	{
-		//RTPRINT_DATA(FMPBT, FMPBT_H2C_CONTENT, ("[MPT], MPT H2C hex: \n"), pH2c, h2cCmdLen);
-
-		for(i=0; i<BT_H2C_MAX_RETRY; i++)
-		{
-			DBG_8192C("[MPT], Send H2C command to wifi!!!\n");
-
-			pMptCtx->MptH2cRspEvent = _FALSE;
-			pMptCtx->MptBtC2hEvent = _FALSE;
-
-#if defined(CONFIG_RTL8723B)
-			rtl8723b_set_FwBtMpOper_cmd(Adapter, pH2c->opCode, pH2c->opCodeVer, pH2c->reqNum, pH2c->buf);
-#endif
-			pMptCtx->h2cReqNum++;
-			pMptCtx->h2cReqNum %= 16;
-
-			if(WaitC2Hevent(Adapter, &pMptCtx->MptH2cRspEvent, 100))
-			{
-				DBG_8192C("[MPT], Received WiFi MptH2cRspEvent!!!\n");
-				if(WaitC2Hevent(Adapter, &pMptCtx->MptBtC2hEvent, 400))
-				{
-					DBG_8192C("[MPT], Received MptBtC2hEvent!!!\n");
-					break;
-				}
-				else
-				{
-					DBG_8192C("[MPT], Error!!BT MptBtC2hEvent timeout!!\n");
-					h2cStatus = BT_STATUS_H2C_BT_NO_RSP;
-				}
-			}
-			else
-			{
-				DBG_8192C("[MPT], Error!!WiFi  MptH2cRspEvent timeout!!\n");
-				h2cStatus = BT_STATUS_H2C_TIMTOUT;
-			}
-		}
-//	}
-//	else
-//	{
-//		RT_ASSERT(FALSE, ("[MPT],  mptbt_SendH2c() can only run under PASSIVE_LEVEL!!\n"));
-//		h2cStatus = BT_STATUS_WRONG_LEVEL;
-//	}
-
-	DBG_8192C("[MPT], mptbt_SendH2c()<=========\n");
-	return h2cStatus;
-}
-
-
-
-BT_CTRL_STATUS
-mptbt_CheckBtRspStatus(
-	PADAPTER			Adapter,
-	PBT_EXT_C2H			pExtC2h
-	)
-{
-	BT_CTRL_STATUS	retStatus=BT_OP_STATUS_SUCCESS;
-
-	switch(pExtC2h->statusCode)
-	{
-		case BT_OP_STATUS_SUCCESS:
-			retStatus = BT_STATUS_BT_OP_SUCCESS;
-			DBG_8192C("[MPT], BT status : BT_STATUS_SUCCESS\n");
-			break;
-		case BT_OP_STATUS_VERSION_MISMATCH:
-			retStatus = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
-			DBG_8192C("[MPT], BT status : BT_STATUS_OPCODE_L_VERSION_MISMATCH\n");
-			break;
-		case BT_OP_STATUS_UNKNOWN_OPCODE:
-			retStatus = BT_STATUS_UNKNOWN_OPCODE_L;
-			DBG_8192C("[MPT], BT status : BT_STATUS_UNKNOWN_OPCODE_L\n");
-			break;
-		case BT_OP_STATUS_ERROR_PARAMETER:
-			retStatus = BT_STATUS_PARAMETER_FORMAT_ERROR_L;
-			DBG_8192C("[MPT], BT status : BT_STATUS_PARAMETER_FORMAT_ERROR_L\n");
-			break;
-		default:
-			retStatus = BT_STATUS_UNKNOWN_STATUS_L;
-			DBG_8192C("[MPT], BT status : BT_STATUS_UNKNOWN_STATUS_L\n");
-			break;
-	}
-	
-	return retStatus;
-}	
-
-
-
-BT_CTRL_STATUS
-mptbt_BtFwOpCodeProcess(
-	PADAPTER		Adapter,
-	u1Byte			btFwOpCode,
-	u1Byte			opCodeVer,
-	pu1Byte			pH2cPar,
-	u1Byte			h2cParaLen
-	)
-{
-	u1Byte				H2C_Parameter[6] ={0};
-	PBT_H2C				pH2c=(PBT_H2C)&H2C_Parameter[0];
-	PMPT_CONTEXT		pMptCtx=&(Adapter->mppriv.MptCtx);
-	PBT_EXT_C2H			pExtC2h=(PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
-	u2Byte				paraLen=0,i;
-	BT_CTRL_STATUS	h2cStatus=BT_STATUS_H2C_SUCCESS, c2hStatus=BT_STATUS_C2H_SUCCESS;
-	BT_CTRL_STATUS	retStatus=BT_STATUS_H2C_BT_NO_RSP;
-
-	if( Adapter->registrypriv.mp_mode == 0 )
-	{
-		DBG_8192C("[MPT], Error!! mptbt_BtFwOpCodeProces mp_mode == 0!!\n");
-		return _FALSE;
-	}
-
-	pH2c->opCode = btFwOpCode;
-	pH2c->opCodeVer = opCodeVer;
-	pH2c->reqNum = pMptCtx->h2cReqNum;
-	//PlatformMoveMemory(&pH2c->buf[0], pH2cPar, h2cParaLen);
-	//_rtw_memcpy(&pH2c->buf[0], pH2cPar, h2cParaLen);
-	_rtw_memcpy(pH2c->buf, pH2cPar, h2cParaLen);
-
-	DBG_8192C("[MPT], pH2c->opCode=%d\n", pH2c->opCode);
-	DBG_8192C("[MPT], pH2c->opCodeVer=%d\n", pH2c->opCodeVer);
-	DBG_8192C("[MPT], pH2c->reqNum=%d\n", pH2c->reqNum);
-	DBG_8192C("[MPT], h2c parameter length=%d\n", h2cParaLen);
-	for (i=0; i<h2cParaLen; i++)
-	{
-		DBG_8192C("[MPT], parameter[%d]=0x%02x\n", i, pH2c->buf[i]);
-	}
-
-	h2cStatus = mptbt_SendH2c(Adapter, pH2c, h2cParaLen+2);
-	if(BT_STATUS_H2C_SUCCESS == h2cStatus)
-	{
-		// if reach here, it means H2C get the correct c2h response, 
-		c2hStatus = mptbt_CheckC2hFrame(Adapter, pH2c, pExtC2h);
-		if(BT_STATUS_C2H_SUCCESS == c2hStatus)
-		{
-			retStatus = mptbt_CheckBtRspStatus(Adapter, pExtC2h);
-		}
-		else
-		{
-			DBG_8192C("[MPT], Error!! C2H failed for pH2c->opCode=%d\n", pH2c->opCode);
-			// check c2h status error, return error status code to upper layer.
-			retStatus = c2hStatus;
-		}
-	}
-	else
-	{
-		DBG_8192C("[MPT], Error!! H2C failed for pH2c->opCode=%d\n", pH2c->opCode);
-		// check h2c status error, return error status code to upper layer.
-		retStatus = h2cStatus;
-	}
-
-	return retStatus;
-}
-
-
-
-
-u2Byte
-mptbt_BtReady(
-	PADAPTER		Adapter,
-	PBT_REQ_CMD 	pBtReq,
-	PBT_RSP_CMD 	pBtRsp
-	)
-{
-	u1Byte				h2cParaBuf[6] ={0};
-	u1Byte				h2cParaLen=0;
-	u2Byte				paraLen=0;
-	u1Byte				retStatus=BT_STATUS_BT_OP_SUCCESS;
-	u1Byte				btOpcode;
-	u1Byte				btOpcodeVer=0;
-	PMPT_CONTEXT		pMptCtx=&(Adapter->mppriv.MptCtx);
-	PBT_EXT_C2H			pExtC2h=(PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
-	u1Byte				i;
-	u1Byte				btFwVer=0, bdAddr[6]={0};
-	u2Byte				btRealFwVer=0;
-	pu2Byte 			pu2Tmp=NULL;
-
-	//
-	// check upper layer parameters
-	//
-
-	// 1. check upper layer opcode version
-	if(pBtReq->opCodeVer != 1)
-	{
-		DBG_8192C("[MPT], Error!! Upper OP code version not match!!!\n");
-		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
-		return paraLen;
-	}
-
-	pBtRsp->pParamStart[0] = MP_BT_NOT_READY;
-	paraLen = 10;
-	//
-	// execute lower layer opcodes
-	//
-
-	// Get BT FW version
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_GET_BT_VERSION;
-	// execute h2c and check respond c2h from bt fw is correct or not
-	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-	else
-	{
-		pu2Tmp = (pu2Byte)&pExtC2h->buf[0];
-		btRealFwVer = *pu2Tmp;
-		btFwVer = pExtC2h->buf[1];
-		DBG_8192C("[MPT], btRealFwVer=0x%x, btFwVer=0x%x\n", btRealFwVer, btFwVer);
-	}
-
-	// Get BD Address
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_GET_BD_ADDR_L;
-	// execute h2c and check respond c2h from bt fw is correct or not
-	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-	else
-	{
-		bdAddr[5] = pExtC2h->buf[0];
-		bdAddr[4] = pExtC2h->buf[1];
-		bdAddr[3] = pExtC2h->buf[2];
-	}
-
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_GET_BD_ADDR_H;
-	// execute h2c and check respond c2h from bt fw is correct or not
-	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-	else
-	{
-		bdAddr[2] = pExtC2h->buf[0];
-		bdAddr[1] = pExtC2h->buf[1];
-		bdAddr[0] = pExtC2h->buf[2];
-	}
-	DBG_8192C("[MPT], Local BDAddr:");
-	for(i=0; i<6; i++)
-	{
-		DBG_8192C(" 0x%x ", bdAddr[i]);
-	}
-	pBtRsp->status = BT_STATUS_SUCCESS;
-	pBtRsp->pParamStart[0] = MP_BT_READY;
-	pu2Tmp = (pu2Byte)&pBtRsp->pParamStart[1];
-	*pu2Tmp = btRealFwVer;
-	pBtRsp->pParamStart[3] = btFwVer;
-	for(i=0; i<6; i++)
-	{
-		pBtRsp->pParamStart[4+i] = bdAddr[5-i];
-	}
-
-	return paraLen;
-}
-
-void mptbt_close_WiFiRF(PADAPTER Adapter)
-{
-	PHY_SetBBReg(Adapter, 0x824, 0xF, 0x0);
-	PHY_SetBBReg(Adapter, 0x824, 0x700000, 0x0);
-	PHY_SetRFReg(Adapter, RF_PATH_A, 0x0, 0xF0000, 0x0);
-}
-
-void mptbt_open_WiFiRF(PADAPTER	Adapter)
-{
-	PHY_SetBBReg(Adapter, 0x824, 0x700000, 0x3);
-	PHY_SetBBReg(Adapter, 0x824, 0xF, 0x2);
-	PHY_SetRFReg(Adapter, RF_PATH_A, 0x0, 0xF0000, 0x3);
-}
-
-u4Byte mptbt_switch_RF(PADAPTER	Adapter, u1Byte	Enter)
-{
-	u2Byte	tmp_2byte = 0;
-
-	//Enter test mode
-	if (Enter) {
-		////1>. close WiFi RF
-		mptbt_close_WiFiRF(Adapter);
-		
-		////2>. change ant switch to BT
-		tmp_2byte = rtw_read16(Adapter, 0x860);
-		tmp_2byte = tmp_2byte | BIT(9);
-		tmp_2byte = tmp_2byte & (~BIT(8));
-		rtw_write16(Adapter, 0x860, tmp_2byte);
-		rtw_write16(Adapter, 0x870, 0x300);
-	} else {
-		////1>. Open WiFi RF
-		mptbt_open_WiFiRF(Adapter);
-		
-		////2>. change ant switch back
-		tmp_2byte = rtw_read16(Adapter, 0x860);
-		tmp_2byte = tmp_2byte | BIT(8);
-		tmp_2byte = tmp_2byte & (~BIT(9));
-		rtw_write16(Adapter, 0x860, tmp_2byte);
-		rtw_write16(Adapter, 0x870, 0x300);
-	}
-
-	return 0;
-}
-
-u2Byte
-mptbt_BtSetMode(
-	PADAPTER		Adapter,
-	PBT_REQ_CMD 	pBtReq,
-	PBT_RSP_CMD 	pBtRsp
-	)
-{
-	u1Byte				h2cParaBuf[6] ={0};
-	u1Byte				h2cParaLen=0;
-	u2Byte				paraLen=0;
-	u1Byte				retStatus=BT_STATUS_BT_OP_SUCCESS;
-	u1Byte				btOpcode;
-	u1Byte				btOpcodeVer=0;
-	u1Byte				btModeToSet=0;
-
-	//
-	// check upper layer parameters
-	//
-	// 1. check upper layer opcode version
-	if(pBtReq->opCodeVer != 1)
-	{
-		DBG_8192C("[MPT], Error!! Upper OP code version not match!!!\n");
-		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
-		return paraLen;
-	}
-	// 2. check upper layer parameter length
-	if(1 == pBtReq->paraLength)
-	{
-		btModeToSet = pBtReq->pParamStart[0];
-		DBG_8192C("[MPT], BtTestMode=%d \n", btModeToSet);
-	}
-	else
-	{
-		DBG_8192C("[MPT], Error!! wrong parameter length=%d (should be 1)\n", pBtReq->paraLength);
-		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
-		return paraLen;
-	}
-	
-	//
-	// execute lower layer opcodes
-	//
-	
-	// 1. fill h2c parameters	
-	// check bt mode
-	btOpcode = BT_LO_OP_SET_BT_MODE;
-	if(btModeToSet >= MP_BT_MODE_MAX)
-	{
-		pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	else
-	{
-		mptbt_switch_RF(Adapter, 1);
-
-		h2cParaBuf[0] = btModeToSet;
-		h2cParaLen = 1;
-		// 2. execute h2c and check respond c2h from bt fw is correct or not
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	
-	// 3. construct respond status code and data.
-	if(BT_STATUS_BT_OP_SUCCESS == retStatus)
-	{
-		pBtRsp->status = BT_STATUS_SUCCESS;
-	}
-	else
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-	}
-	
-	return paraLen;
-}
-
-
-VOID
-MPTBT_FwC2hBtMpCtrl(
-	PADAPTER	Adapter,
-	pu1Byte 	tmpBuf,
-	u1Byte		length
-	)
-{
-	u32 i;
-	PMPT_CONTEXT	pMptCtx=&(Adapter->mppriv.MptCtx);
-	PBT_EXT_C2H pExtC2h=(PBT_EXT_C2H)tmpBuf;
-	
-	if(Adapter->bBTFWReady == _FALSE || Adapter->registrypriv.mp_mode == 0 )
-	{	
-		//DBG_8192C("Ignore C2H BT MP Info since not in MP mode \n");
-		return;
-	}
-	if( length > 32 || length < 3 )
-	{
-		DBG_8192C("\n [MPT], pExtC2h->buf hex: length=%d > 32 || < 3\n",length);
-		return;
-	}
-
-	//cancel_timeout for h2c handle
-	_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
-
-	for (i=0; i<length; i++)
-	{
-		DBG_8192C("[MPT], %s, buf[%d]=0x%02x ", __FUNCTION__, i, tmpBuf[i]);
-	}
-	DBG_8192C("[MPT], pExtC2h->extendId=0x%x\n", pExtC2h->extendId);
-	
-	switch(pExtC2h->extendId)
-	{
-		case EXT_C2H_WIFI_FW_ACTIVE_RSP:
-			DBG_8192C("[MPT], EXT_C2H_WIFI_FW_ACTIVE_RSP\n");
-#if 0
-			DBG_8192C("[MPT], pExtC2h->buf hex: \n");
-			for (i=0; i<(length-3); i++)
-			{
-				DBG_8192C(" 0x%x ", pExtC2h->buf[i]);
-			}
-#endif
-			if ((_FALSE == pMptCtx->bMPh2c_timeout)
-				&& (_FALSE == pMptCtx->MptH2cRspEvent))
-			{
-				pMptCtx->MptH2cRspEvent = _TRUE;
-				_rtw_up_sema(&pMptCtx->MPh2c_Sema);
-			}
-			break;
-
-		case EXT_C2H_TRIG_BY_BT_FW:
-			DBG_8192C("[MPT], EXT_C2H_TRIG_BY_BT_FW\n");
-			_rtw_memcpy(&pMptCtx->c2hBuf[0], tmpBuf, length);
-			DBG_8192C("[MPT], pExtC2h->statusCode=0x%x\n", pExtC2h->statusCode);
-			DBG_8192C("[MPT], pExtC2h->retLen=0x%x\n", pExtC2h->retLen);
-			DBG_8192C("[MPT], pExtC2h->opCodeVer=0x%x\n", pExtC2h->opCodeVer);
-			DBG_8192C("[MPT], pExtC2h->reqNum=0x%x\n", pExtC2h->reqNum);
-			for (i=0; i<(length-3); i++)
-			{
-				DBG_8192C("[MPT], pExtC2h->buf[%d]=0x%02x\n", i, pExtC2h->buf[i]);
-			}
-
-			if ((_FALSE == pMptCtx->bMPh2c_timeout)
-				&& (_TRUE == pMptCtx->MptH2cRspEvent)
-				&& (_FALSE == pMptCtx->MptBtC2hEvent))
-			{
-				pMptCtx->MptBtC2hEvent = _TRUE;
-				_rtw_up_sema(&pMptCtx->MPh2c_Sema);
-			}
-			break;
-
-		default:
-			DBG_8192C("[MPT], EXT_C2H Target not found,pExtC2h->extendId =%d ,pExtC2h->reqNum=%d\n",pExtC2h->extendId,pExtC2h->reqNum);
-			break;
-	}
-	
-
-	
-}
-
-
-u2Byte
-mptbt_BtGetGeneral(
-	IN	PADAPTER		Adapter,
-	IN	PBT_REQ_CMD 	pBtReq,
-	IN	PBT_RSP_CMD 	pBtRsp
-	)
-{
-	PMPT_CONTEXT		pMptCtx=&(Adapter->mppriv.MptCtx);
-	PBT_EXT_C2H 		pExtC2h=(PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
-	u1Byte				h2cParaBuf[6] ={0};
-	u1Byte				h2cParaLen=0;
-	u2Byte				paraLen=0;
-	u1Byte				retStatus=BT_STATUS_BT_OP_SUCCESS;
-	u1Byte				btOpcode, bdAddr[6]={0};
-	u1Byte				btOpcodeVer=0;
-	u1Byte				getType=0, i;
-	u2Byte				getParaLen=0, validParaLen=0;
-	u1Byte				regType=0, reportType=0;
-	u4Byte				regAddr=0, regValue=0;
-	pu4Byte 			pu4Tmp;
-	pu2Byte 			pu2Tmp;
-	pu1Byte 			pu1Tmp;
-
-	//
-	// check upper layer parameters
-	//
-	
-	// check upper layer opcode version
-	if(pBtReq->opCodeVer != 1)
-	{
-		DBG_8192C("[MPT], Error!! Upper OP code version not match!!!\n");
-		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
-		return paraLen;
-	}
-	// check upper layer parameter length
-	if(pBtReq->paraLength < 1)
-	{
-		DBG_8192C("[MPT], Error!! wrong parameter length=%d (should larger than 1)\n", pBtReq->paraLength);
-		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
-		return paraLen;
-	}
-	getParaLen = pBtReq->paraLength - 1;
-	getType = pBtReq->pParamStart[0];
-	
-	DBG_8192C("[MPT], getType=%d, getParaLen=%d\n", getType, getParaLen);
-
-	// check parameter first
-	switch(getType)
-	{
-		case BT_GGET_REG:
-			DBG_8192C("[MPT], [BT_GGET_REG]\n");
-			validParaLen = 5;
-			if(getParaLen == validParaLen)
-			{
-				btOpcode = BT_LO_OP_READ_REG;
-				regType = pBtReq->pParamStart[1];
-				pu4Tmp = (pu4Byte)&pBtReq->pParamStart[2];
-				regAddr = *pu4Tmp;
-				DBG_8192C("[MPT], BT_GGET_REG regType=0x%02x, regAddr=0x%08x!!\n",
-					regType, regAddr);
-				if(regType >= BT_REG_MAX)
-				{
-					pBtRsp->status = (btOpcode<<8)| BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-					return paraLen;
-				}
-				else
-				{
-					if( ((BT_REG_RF==regType)&&(regAddr>0x7f)) ||
-						((BT_REG_MODEM==regType)&&(regAddr>0x1ff)) ||
-						((BT_REG_BLUEWIZE==regType)&&(regAddr>0xfff)) ||
-						((BT_REG_VENDOR==regType)&&(regAddr>0xfff)) ||
-						((BT_REG_LE==regType)&&(regAddr>0xfff)) )
-					{				
-						pBtRsp->status = (btOpcode<<8)| BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-						return paraLen;
-					}
-				}
-			}
-			break;
-		case BT_GGET_STATUS:
-			DBG_8192C("[MPT], [BT_GGET_STATUS]\n");
-			validParaLen = 0;
-			break;
-		case BT_GGET_REPORT:
-			DBG_8192C("[MPT], [BT_GGET_REPORT]\n");
-			validParaLen = 1;
-			if(getParaLen == validParaLen)
-			{
-				reportType = pBtReq->pParamStart[1];
-				DBG_8192C("[MPT], BT_GGET_REPORT reportType=0x%x!!\n", reportType);
-				if(reportType >= BT_REPORT_MAX)
-				{
-					pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-					return paraLen;
-				}
-			}
-			break;
-		default:
-			{
-				DBG_8192C("[MPT], Error!! getType=%d, out of range\n", getType);
-				pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-				return paraLen;
-			}
-			break;
-	}
-	if(getParaLen != validParaLen)
-	{
-		DBG_8192C("[MPT], Error!! wrong parameter length=%d for BT_GET_GEN_CMD cmd id=0x%x, paraLen should=0x%x\n",
-			getParaLen, getType, validParaLen);
-		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
-		return paraLen;
-	}
-	
-	//
-	// execute lower layer opcodes
-	//
-	if(BT_GGET_REG == getType)
-	{
-		// fill h2c parameters
-		// here we should write reg value first then write the address, adviced by Austin
-		btOpcode = BT_LO_OP_READ_REG;
-		h2cParaBuf[0] = regType;
-		h2cParaBuf[1] = pBtReq->pParamStart[2];
-		h2cParaBuf[2] = pBtReq->pParamStart[3];
-		h2cParaLen = 3;
-		// execute h2c and check respond c2h from bt fw is correct or not
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-		// construct respond status code and data.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-
-		pu2Tmp = (pu2Byte)&pExtC2h->buf[0];
-		regValue = *pu2Tmp;
-		DBG_8192C("[MPT], read reg regType=0x%02x, regAddr=0x%08x, regValue=0x%04x\n", 
-			regType, regAddr, regValue);
-		
-		pu4Tmp = (pu4Byte)&pBtRsp->pParamStart[0];
-		*pu4Tmp = regValue;
-		paraLen = 4;
-	}
-	else if(BT_GGET_STATUS == getType)
-	{
-		btOpcode = BT_LO_OP_GET_BT_STATUS;
-		h2cParaLen = 0;
-		// execute h2c and check respond c2h from bt fw is correct or not
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-		// construct respond status code and data.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-
-		pBtRsp->pParamStart[0] = pExtC2h->buf[0];
-		pBtRsp->pParamStart[1] = pExtC2h->buf[1];
-		DBG_8192C("[MPT], read bt status, testMode=0x%x, testStatus=0x%x\n", 
-			pBtRsp->pParamStart[0], pBtRsp->pParamStart[1]);		
-		paraLen = 2;
-	}
-	else if(BT_GGET_REPORT == getType)
-	{
-		switch(reportType)
-		{
-			case BT_REPORT_RX_PACKET_CNT:
-				{
-					DBG_8192C("[MPT], [Rx Packet Counts]\n");
-					btOpcode = BT_LO_OP_GET_RX_PKT_CNT_L;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					pBtRsp->pParamStart[0] = pExtC2h->buf[0];
-					pBtRsp->pParamStart[1] = pExtC2h->buf[1];
-
-					btOpcode = BT_LO_OP_GET_RX_PKT_CNT_H;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					pBtRsp->pParamStart[2] = pExtC2h->buf[0];
-					pBtRsp->pParamStart[3] = pExtC2h->buf[1];
-					paraLen = 4;
-				}
-				break;
-			case BT_REPORT_RX_ERROR_BITS:
-				{
-					DBG_8192C("[MPT], [Rx Error Bits]\n");
-					btOpcode = BT_LO_OP_GET_RX_ERROR_BITS_L;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					pBtRsp->pParamStart[0] = pExtC2h->buf[0];
-					pBtRsp->pParamStart[1] = pExtC2h->buf[1];
-
-					btOpcode = BT_LO_OP_GET_RX_ERROR_BITS_H;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					pBtRsp->pParamStart[2] = pExtC2h->buf[0];
-					pBtRsp->pParamStart[3] = pExtC2h->buf[1];
-					paraLen = 4;
-				}
-				break;
-			case BT_REPORT_RSSI:
-				{
-					DBG_8192C("[MPT], [RSSI]\n");
-					btOpcode = BT_LO_OP_GET_RSSI;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					pBtRsp->pParamStart[0] = pExtC2h->buf[0];
-					pBtRsp->pParamStart[1] = pExtC2h->buf[1];
-					paraLen = 2;
-				}
-				break;
-			case BT_REPORT_CFO_HDR_QUALITY:
-				{
-					DBG_8192C("[MPT], [CFO & Header Quality]\n");
-					btOpcode = BT_LO_OP_GET_CFO_HDR_QUALITY_L;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					pBtRsp->pParamStart[0] = pExtC2h->buf[0];
-					pBtRsp->pParamStart[1] = pExtC2h->buf[1];
-
-					btOpcode = BT_LO_OP_GET_CFO_HDR_QUALITY_H;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					pBtRsp->pParamStart[2] = pExtC2h->buf[0];
-					pBtRsp->pParamStart[3] = pExtC2h->buf[1];
-					paraLen = 4;
-				}
-				break;
-			case BT_REPORT_CONNECT_TARGET_BD_ADDR:
-				{
-					DBG_8192C("[MPT], [Connected Target BD ADDR]\n");
-					btOpcode = BT_LO_OP_GET_TARGET_BD_ADDR_L;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					bdAddr[5] = pExtC2h->buf[0];
-					bdAddr[4] = pExtC2h->buf[1];
-					bdAddr[3] = pExtC2h->buf[2];
-
-					btOpcode = BT_LO_OP_GET_TARGET_BD_ADDR_H;
-					h2cParaLen = 0;
-					// execute h2c and check respond c2h from bt fw is correct or not
-					retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-					// construct respond status code and data.
-					if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-					{
-						pBtRsp->status = ((btOpcode<<8)|retStatus);
-						DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-						return paraLen;
-					}
-					bdAddr[2] = pExtC2h->buf[0];
-					bdAddr[1] = pExtC2h->buf[1];
-					bdAddr[0] = pExtC2h->buf[2];
-						
-					DBG_8192C("[MPT], Connected Target BDAddr:%s", bdAddr);
-					for(i=0; i<6; i++)
-					{
-						pBtRsp->pParamStart[i] = bdAddr[5-i];
-					}
-					paraLen = 6;
-				}
-				break;
-			default:
-				pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-				return paraLen;
-				break;
-		}
-	}
-
-	pBtRsp->status = BT_STATUS_SUCCESS;
-	return paraLen;
-}
-
-
-
-u2Byte
-mptbt_BtSetGeneral(
-	IN	PADAPTER		Adapter,
-	IN	PBT_REQ_CMD 	pBtReq,
-	IN	PBT_RSP_CMD 	pBtRsp
-	)
-{
-	u1Byte				h2cParaBuf[6] ={0};
-	u1Byte				h2cParaLen=0;
-	u2Byte				paraLen=0;
-	u1Byte				retStatus=BT_STATUS_BT_OP_SUCCESS;
-	u1Byte				btOpcode;
-	u1Byte				btOpcodeVer=0;
-	u1Byte				setType=0;
-	u2Byte				setParaLen=0, validParaLen=0;
-	u1Byte				regType=0, bdAddr[6]={0}, calVal=0;
-	u4Byte				regAddr=0, regValue=0;
-	pu4Byte 			pu4Tmp;
-	pu2Byte 			pu2Tmp;
-	pu1Byte 			pu1Tmp;
-
-	//
-	// check upper layer parameters
-	//
-	
-	// check upper layer opcode version
-	if(pBtReq->opCodeVer != 1)
-	{
-		DBG_8192C("[MPT], Error!! Upper OP code version not match!!!\n");
-		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
-		return paraLen;
-	}
-	// check upper layer parameter length
-	if(pBtReq->paraLength < 1)
-	{
-		DBG_8192C("[MPT], Error!! wrong parameter length=%d (should larger than 1)\n", pBtReq->paraLength);
-		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
-		return paraLen;
-	}
-	setParaLen = pBtReq->paraLength - 1;
-	setType = pBtReq->pParamStart[0];
-	
-	DBG_8192C("[MPT], setType=%d, setParaLen=%d\n", setType, setParaLen);
-
-	// check parameter first
-	switch(setType)
-	{
-		case BT_GSET_REG:
-			DBG_8192C ("[MPT], [BT_GSET_REG]\n");
-			validParaLen = 9;
-			if(setParaLen == validParaLen)
-			{
-				btOpcode = BT_LO_OP_WRITE_REG_VALUE;
-				regType = pBtReq->pParamStart[1];
-				pu4Tmp = (pu4Byte)&pBtReq->pParamStart[2];
-				regAddr = *pu4Tmp;
-				pu4Tmp = (pu4Byte)&pBtReq->pParamStart[6];
-				regValue = *pu4Tmp;
-				DBG_8192C("[MPT], BT_GSET_REG regType=0x%x, regAddr=0x%x, regValue=0x%x!!\n", 
-					regType, regAddr, regValue);
-				if(regType >= BT_REG_MAX)
-				{
-					pBtRsp->status = (btOpcode<<8)| BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-					return paraLen;
-				}
-				else
-				{
-					if( ((BT_REG_RF==regType)&&(regAddr>0x7f)) ||
-						((BT_REG_MODEM==regType)&&(regAddr>0x1ff)) ||
-						((BT_REG_BLUEWIZE==regType)&&(regAddr>0xfff)) ||
-						((BT_REG_VENDOR==regType)&&(regAddr>0xfff)) ||
-						((BT_REG_LE==regType)&&(regAddr>0xfff)) )
-					{				
-						pBtRsp->status = (btOpcode<<8)| BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-						return paraLen;
-					}
-				}
-			}
-			break;
-		case BT_GSET_RESET:
-			DBG_8192C("[MPT], [BT_GSET_RESET]\n");
-			validParaLen = 0;
-			break;
-		case BT_GSET_TARGET_BD_ADDR:
-			DBG_8192C("[MPT], [BT_GSET_TARGET_BD_ADDR]\n");
-			validParaLen = 6;
-			if(setParaLen == validParaLen)
-			{
-				btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_H;
-				if( (pBtReq->pParamStart[1]==0) &&
-					(pBtReq->pParamStart[2]==0) &&
-					(pBtReq->pParamStart[3]==0) &&
-					(pBtReq->pParamStart[4]==0) &&
-					(pBtReq->pParamStart[5]==0) &&
-					(pBtReq->pParamStart[6]==0) )
-				{
-					DBG_8192C("[MPT], Error!! targetBDAddr=all zero\n");
-					pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-					return paraLen;
-				}
-				if( (pBtReq->pParamStart[1]==0xff) &&
-					(pBtReq->pParamStart[2]==0xff) &&
-					(pBtReq->pParamStart[3]==0xff) &&
-					(pBtReq->pParamStart[4]==0xff) &&
-					(pBtReq->pParamStart[5]==0xff) &&
-					(pBtReq->pParamStart[6]==0xff) )
-				{
-					DBG_8192C("[MPT], Error!! targetBDAddr=all 0xf\n");
-					pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-					return paraLen;
-				}
-				bdAddr[0] = pBtReq->pParamStart[6];
-				bdAddr[1] = pBtReq->pParamStart[5];
-				bdAddr[2] = pBtReq->pParamStart[4];
-				bdAddr[3] = pBtReq->pParamStart[3];
-				bdAddr[4] = pBtReq->pParamStart[2];
-				bdAddr[5] = pBtReq->pParamStart[1];
-				DBG_8192C ("[MPT], target BDAddr:%x,%x,%x,%x,%x,%x\n", 
-							bdAddr[0],bdAddr[1],bdAddr[2],bdAddr[3],bdAddr[4],bdAddr[5]);
-			}
-			break;
-		case BT_GSET_TX_PWR_FINETUNE:
-			DBG_8192C("[MPT], [BT_GSET_TX_PWR_FINETUNE]\n");
-			validParaLen = 1;
-			if(setParaLen == validParaLen)
-			{
-				btOpcode = BT_LO_OP_SET_TX_POWER_CALIBRATION;
-				calVal = pBtReq->pParamStart[1];
-				if( (calVal<1) || (calVal>9) )
-				{
-					pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-					return paraLen;
-				}
-				DBG_8192C ("[MPT], calVal=%d\n", calVal);
-			}
-			break;
-		case BT_SET_TRACKING_INTERVAL:
-			DBG_871X("[MPT], [BT_SET_TRACKING_INTERVAL] setParaLen =%d \n",setParaLen);
-			
-			validParaLen = 1;	
-			if(setParaLen == validParaLen)	
-				calVal = pBtReq->pParamStart[1];
-			break;
-		case BT_SET_THERMAL_METER:
-			DBG_871X("[MPT], [BT_SET_THERMAL_METER] setParaLen =%d \n",setParaLen);
-			validParaLen = 1;	
-			if(setParaLen == validParaLen)	
-				calVal = pBtReq->pParamStart[1];
-			break;
-		case BT_ENABLE_CFO_TRACKING:
-			DBG_871X("[MPT], [BT_ENABLE_CFO_TRACKING] setParaLen =%d \n",setParaLen);
-			validParaLen = 1;	
-			if(setParaLen == validParaLen)	
-				calVal = pBtReq->pParamStart[1];
-			break;
-		case BT_GSET_UPDATE_BT_PATCH:
-			
-			break;
-		default:
-			{
-				DBG_8192C ("[MPT], Error!! setType=%d, out of range\n", setType);
-				pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-				return paraLen;
-			}
-			break;
-	}
-	if(setParaLen != validParaLen)
-	{
-		DBG_8192C("[MPT], Error!! wrong parameter length=%d for BT_SET_GEN_CMD cmd id=0x%x, paraLen should=0x%x\n",
-			setParaLen, setType, validParaLen);
-		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
-		return paraLen;
-	}
-	
-	//
-	// execute lower layer opcodes
-	//
-	if(BT_GSET_REG == setType)
-	{
-		// fill h2c parameters
-		// here we should write reg value first then write the address, adviced by Austin
-		btOpcode = BT_LO_OP_WRITE_REG_VALUE;
-		h2cParaBuf[0] = pBtReq->pParamStart[6];
-		h2cParaBuf[1] = pBtReq->pParamStart[7];
-		h2cParaBuf[2] = pBtReq->pParamStart[8];
-		h2cParaLen = 3;
-		// execute h2c and check respond c2h from bt fw is correct or not
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-		// construct respond status code and data.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-		
-		// write reg address
-		btOpcode = BT_LO_OP_WRITE_REG_ADDR;
-		h2cParaBuf[0] = regType;
-		h2cParaBuf[1] = pBtReq->pParamStart[2];
-		h2cParaBuf[2] = pBtReq->pParamStart[3];
-		h2cParaLen = 3;
-		// execute h2c and check respond c2h from bt fw is correct or not
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-		// construct respond status code and data.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}		
-	}
-	else if(BT_GSET_RESET == setType)
-	{
-		btOpcode = BT_LO_OP_RESET;
-		h2cParaLen = 0;
-		// execute h2c and check respond c2h from bt fw is correct or not
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-		// construct respond status code and data.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-	}
-	else if(BT_GSET_TARGET_BD_ADDR == setType)
-	{
-		// fill h2c parameters
-		btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_L;
-		h2cParaBuf[0] = pBtReq->pParamStart[1];
-		h2cParaBuf[1] = pBtReq->pParamStart[2];
-		h2cParaBuf[2] = pBtReq->pParamStart[3];
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);		
-		// ckeck bt return status.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-
-		btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_H;
-		h2cParaBuf[0] = pBtReq->pParamStart[4];
-		h2cParaBuf[1] = pBtReq->pParamStart[5];
-		h2cParaBuf[2] = pBtReq->pParamStart[6];
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);		
-		// ckeck bt return status.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-	}
-	else if(BT_GSET_TX_PWR_FINETUNE == setType)
-	{
-		// fill h2c parameters
-		btOpcode = BT_LO_OP_SET_TX_POWER_CALIBRATION;
-		h2cParaBuf[0] = calVal;
-		h2cParaLen = 1;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-		// ckeck bt return status.
-		if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-		{
-			pBtRsp->status = ((btOpcode<<8)|retStatus);
-			DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-	}
-	else if(BT_SET_TRACKING_INTERVAL == setType)
-	{
-		//	BT_LO_OP_SET_TRACKING_INTERVAL								= 0x22,
-		//	BT_LO_OP_SET_THERMAL_METER									= 0x23,
-		//	BT_LO_OP_ENABLE_CFO_TRACKING									= 0x24,
-				btOpcode = BT_LO_OP_SET_TRACKING_INTERVAL;
-				h2cParaBuf[0] = calVal;
-				h2cParaLen = 1;
-				retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);		
-				// ckeck bt return status.
-				if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-				{
-					pBtRsp->status = ((btOpcode<<8)|retStatus);
-					DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-					return paraLen;
-				}
-	}
-	else if(BT_SET_THERMAL_METER == setType)
-	{
-				btOpcode = BT_LO_OP_SET_THERMAL_METER;
-				h2cParaBuf[0] = calVal;
-				h2cParaLen = 1;
-				retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);		
-				// ckeck bt return status.
-				if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-				{
-					pBtRsp->status = ((btOpcode<<8)|retStatus);
-					DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-					return paraLen;
-				}
-	}
-	else if(BT_ENABLE_CFO_TRACKING == setType)
-	{
-				btOpcode = BT_LO_OP_ENABLE_CFO_TRACKING;
-				h2cParaBuf[0] = calVal;
-				h2cParaLen = 1;
-				retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);		
-				// ckeck bt return status.
-				if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-				{
-					pBtRsp->status = ((btOpcode<<8)|retStatus);
-					DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-			return paraLen;
-		}
-	}
-	
-	pBtRsp->status = BT_STATUS_SUCCESS;
-	return paraLen;
-}
-
-
-
-u2Byte
-mptbt_BtSetTxRxPars(
-	IN	PADAPTER		Adapter,
-	IN	PBT_REQ_CMD 	pBtReq,
-	IN	PBT_RSP_CMD 	pBtRsp
-	)
-{
-	u1Byte				h2cParaBuf[6] ={0};
-	u1Byte				h2cParaLen=0;
-	u2Byte				paraLen=0;
-	u1Byte				retStatus=BT_STATUS_BT_OP_SUCCESS;
-	u1Byte				btOpcode;
-	u1Byte				btOpcodeVer=0;
-	PBT_TXRX_PARAMETERS pTxRxPars=(PBT_TXRX_PARAMETERS)&pBtReq->pParamStart[0];
-	u2Byte				lenTxRx=sizeof(BT_TXRX_PARAMETERS);
-	u1Byte				i;
-	u1Byte				bdAddr[6]={0};
-
-	//
-	// check upper layer parameters
-	//
-	
-	// 1. check upper layer opcode version
-	if(pBtReq->opCodeVer != 1)
-	{
-		DBG_8192C("[MPT], Error!! Upper OP code version not match!!!\n");
-		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
-		return paraLen;
-	}
-	// 2. check upper layer parameter length
-	if(pBtReq->paraLength == sizeof(BT_TXRX_PARAMETERS))
-	{	
-		DBG_8192C ("[MPT], pTxRxPars->txrxChannel=0x%x \n", pTxRxPars->txrxChannel);
-		DBG_8192C ("[MPT], pTxRxPars->txrxTxPktCnt=0x%8x \n", pTxRxPars->txrxTxPktCnt);
-		DBG_8192C  ("[MPT], pTxRxPars->txrxTxPktInterval=0x%x \n", pTxRxPars->txrxTxPktInterval);
-		DBG_8192C  ("[MPT], pTxRxPars->txrxPayloadType=0x%x \n", pTxRxPars->txrxPayloadType);
-		DBG_8192C  ("[MPT], pTxRxPars->txrxPktType=0x%x \n", pTxRxPars->txrxPktType);
-		DBG_8192C  ("[MPT], pTxRxPars->txrxPayloadLen=0x%x \n", pTxRxPars->txrxPayloadLen);
-		DBG_8192C  ("[MPT], pTxRxPars->txrxPktHeader=0x%x \n", pTxRxPars->txrxPktHeader);
-		DBG_8192C  ("[MPT], pTxRxPars->txrxWhitenCoeff=0x%x \n", pTxRxPars->txrxWhitenCoeff); 	
-		bdAddr[0] = pTxRxPars->txrxBdaddr[5];
-		bdAddr[1] = pTxRxPars->txrxBdaddr[4];
-		bdAddr[2] = pTxRxPars->txrxBdaddr[3];
-		bdAddr[3] = pTxRxPars->txrxBdaddr[2];
-		bdAddr[4] = pTxRxPars->txrxBdaddr[1];
-		bdAddr[5] = pTxRxPars->txrxBdaddr[0];
-		DBG_8192C  ("[MPT], pTxRxPars->txrxBdaddr: %s", &bdAddr[0]);
-		DBG_8192C ("[MPT], pTxRxPars->txrxTxGainIndex=0x%x \n", pTxRxPars->txrxTxGainIndex);
-	}
-	else
-	{
-		DBG_8192C  ("[MPT], Error!! pBtReq->paraLength=%d, correct Len=%d\n", pBtReq->paraLength, lenTxRx);
-		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
-		return paraLen;
-	}
-
-	//
-	// execute lower layer opcodes
-	//
-	
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_SET_PKT_HEADER;
-	if(pTxRxPars->txrxPktHeader > 0x3ffff)
-	{
-		DBG_8192C  ("[MPT], Error!! pTxRxPars->txrxPktHeader=0x%x is out of range, (should be between 0x0~0x3ffff)\n", pTxRxPars->txrxPktHeader);
-		pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	else
-	{
-		h2cParaBuf[0] = (u1Byte)(pTxRxPars->txrxPktHeader&0xff);
-		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxPktHeader&0xff00)>>8);
-		h2cParaBuf[2] = (u1Byte)((pTxRxPars->txrxPktHeader&0xff0000)>>16);
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C  ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}	
-
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_SET_PKT_TYPE_LEN;
-	{
-		u2Byte	payloadLenLimit=0;
-		switch(pTxRxPars->txrxPktType)
-		{
-			case MP_BT_PKT_DH1:
-				payloadLenLimit = 27*8;
-				break;
-			case MP_BT_PKT_DH3:
-				payloadLenLimit = 183*8;
-				break;
-			case MP_BT_PKT_DH5:
-				payloadLenLimit = 339*8;
-				break;
-			case MP_BT_PKT_2DH1:
-				payloadLenLimit = 54*8;
-				break;
-			case MP_BT_PKT_2DH3:
-				payloadLenLimit = 367*8;
-				break;
-			case MP_BT_PKT_2DH5:
-				payloadLenLimit = 679*8;
-				break;
-			case MP_BT_PKT_3DH1:
-				payloadLenLimit = 83*8;
-				break;
-			case MP_BT_PKT_3DH3:
-				payloadLenLimit = 552*8;
-				break;
-			case MP_BT_PKT_3DH5:
-				payloadLenLimit = 1021*8;
-				break;
-			case MP_BT_PKT_LE:
-				payloadLenLimit = 39*8;
-				break;
-			default:
-				{
-					DBG_8192C  ("[MPT], Error!! Unknown pTxRxPars->txrxPktType=0x%x\n", pTxRxPars->txrxPktType);
-					pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-					return paraLen;
-				}
-				break;
-		}
-
-		if(pTxRxPars->txrxPayloadLen > payloadLenLimit)
-		{
-			DBG_8192C ("[MPT], Error!! pTxRxPars->txrxPayloadLen=0x%x, (should smaller than %d)\n", 
-				pTxRxPars->txrxPayloadLen, payloadLenLimit);
-			pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-			return paraLen;
-		}
-
-		h2cParaBuf[0] = pTxRxPars->txrxPktType;
-		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxPayloadLen&0xff));
-		h2cParaBuf[2] = (u1Byte)((pTxRxPars->txrxPayloadLen&0xff00)>>8);
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_SET_PKT_CNT_L_PL_TYPE;
-	if(pTxRxPars->txrxPayloadType > MP_BT_PAYLOAD_MAX)
-	{
-		DBG_8192C  ("[MPT], Error!! pTxRxPars->txrxPayloadType=0x%x, (should be between 0~4)\n", pTxRxPars->txrxPayloadType);
-		pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	else
-	{
-		h2cParaBuf[0] = (u1Byte)((pTxRxPars->txrxTxPktCnt&0xff));
-		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxTxPktCnt&0xff00)>>8);
-		h2cParaBuf[2] = pTxRxPars->txrxPayloadType;
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}	
-
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_SET_PKT_CNT_H_PKT_INTV;
-	if(pTxRxPars->txrxTxPktInterval > 15)
-	{
-	DBG_8192C  ("[MPT], Error!! pTxRxPars->txrxTxPktInterval=0x%x, (should be between 0~15)\n", pTxRxPars->txrxTxPktInterval);
-	pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	else
-	{
-		h2cParaBuf[0] = (u1Byte)((pTxRxPars->txrxTxPktCnt&0xff0000)>>16);
-		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxTxPktCnt&0xff000000)>>24);
-		h2cParaBuf[2] = pTxRxPars->txrxTxPktInterval;
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}	
-
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_SET_WHITENCOEFF;
-	{
-		h2cParaBuf[0] = pTxRxPars->txrxWhitenCoeff;
-		h2cParaLen = 1;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C  ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-
-
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_SET_CHNL_TX_GAIN;
-	if( (pTxRxPars->txrxChannel > 78) ||
-		(pTxRxPars->txrxTxGainIndex > 7) )
-	{
-		DBG_8192C ("[MPT], Error!! pTxRxPars->txrxChannel=0x%x, (should be between 0~78)\n", pTxRxPars->txrxChannel);
-		DBG_8192C ("[MPT], Error!! pTxRxPars->txrxTxGainIndex=0x%x, (should be between 0~7)\n", pTxRxPars->txrxTxGainIndex);
-		pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	else
-	{
-		h2cParaBuf[0] = pTxRxPars->txrxChannel;
-		h2cParaBuf[1] = pTxRxPars->txrxTxGainIndex;
-		h2cParaLen = 2;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-
-	// fill h2c parameters
-	btOpcode = BT_LO_OP_SET_BD_ADDR_L;
-	if( (pTxRxPars->txrxBdaddr[0]==0) &&
-		(pTxRxPars->txrxBdaddr[1]==0) &&
-		(pTxRxPars->txrxBdaddr[2]==0) &&
-		(pTxRxPars->txrxBdaddr[3]==0) &&
-		(pTxRxPars->txrxBdaddr[4]==0) &&
-		(pTxRxPars->txrxBdaddr[5]==0) )
-	{
-		DBG_8192C ("[MPT], Error!! pTxRxPars->txrxBdaddr=all zero\n");
-		pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	if( (pTxRxPars->txrxBdaddr[0]==0xff) &&
-		(pTxRxPars->txrxBdaddr[1]==0xff) &&
-		(pTxRxPars->txrxBdaddr[2]==0xff) &&
-		(pTxRxPars->txrxBdaddr[3]==0xff) &&
-		(pTxRxPars->txrxBdaddr[4]==0xff) &&
-		(pTxRxPars->txrxBdaddr[5]==0xff) )
-	{
-		DBG_8192C ("[MPT], Error!! pTxRxPars->txrxBdaddr=all 0xf\n");
-		pBtRsp->status = (btOpcode<<8)|BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	
-	{
-		h2cParaBuf[0] = pTxRxPars->txrxBdaddr[0];
-		h2cParaBuf[1] = pTxRxPars->txrxBdaddr[1];
-		h2cParaBuf[2] = pTxRxPars->txrxBdaddr[2];
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}	
-
-	btOpcode = BT_LO_OP_SET_BD_ADDR_H;
-	{
-		h2cParaBuf[0] = pTxRxPars->txrxBdaddr[3];
-		h2cParaBuf[1] = pTxRxPars->txrxBdaddr[4];
-		h2cParaBuf[2] = pTxRxPars->txrxBdaddr[5];
-		h2cParaLen = 3;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	// ckeck bt return status.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C  ("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-
-	pBtRsp->status = BT_STATUS_SUCCESS;
-	return paraLen;
-}
-
-
-
-u2Byte
-mptbt_BtTestCtrl(
-	IN	PADAPTER		Adapter,
-	IN	PBT_REQ_CMD 	pBtReq,
-	IN	PBT_RSP_CMD 	pBtRsp
-	)
-{
-	u1Byte				h2cParaBuf[6] ={0};
-	u1Byte				h2cParaLen=0;
-	u2Byte				paraLen=0;
-	u1Byte				retStatus=BT_STATUS_BT_OP_SUCCESS;
-	u1Byte				btOpcode;
-	u1Byte				btOpcodeVer=0;
-	u1Byte				testCtrl=0;
-
-	//
-	// check upper layer parameters
-	//
-	
-	// 1. check upper layer opcode version
-	if(pBtReq->opCodeVer != 1)
-	{
-		DBG_8192C("[MPT], Error!! Upper OP code version not match!!!\n");
-		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
-		return paraLen;
-	}
-	// 2. check upper layer parameter length
-	if(1 == pBtReq->paraLength)
-	{
-		testCtrl = pBtReq->pParamStart[0];
-		DBG_8192C("[MPT], testCtrl=%d \n", testCtrl);
-	}
-	else
-	{
-		DBG_8192C("[MPT], Error!! wrong parameter length=%d (should be 1)\n", pBtReq->paraLength);
-		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
-		return paraLen;
-	}
-	
-	//
-	// execute lower layer opcodes
-	//
-	
-	// 1. fill h2c parameters	
-	// check bt mode
-	btOpcode = BT_LO_OP_TEST_CTRL;
-	if(testCtrl >= MP_BT_TEST_MAX)
-	{
-		DBG_8192C("[MPT], Error!! testCtrl=0x%x, (should be between smaller or equal to 0x%x)\n", 
-			testCtrl, MP_BT_TEST_MAX-1);
-		pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
-		return paraLen;
-	}
-	else
-	{
-		h2cParaBuf[0] = testCtrl;
-		h2cParaLen = 1;
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-	}
-	
-	// 3. construct respond status code and data.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-
-	pBtRsp->status = BT_STATUS_SUCCESS;
-	return paraLen;
-}
-
-
-u2Byte
-mptbt_TestBT(
-	IN	PADAPTER		Adapter,
-	IN	PBT_REQ_CMD 	pBtReq,
-	IN	PBT_RSP_CMD 	pBtRsp
-	)
-{
-
-	u1Byte				h2cParaBuf[6] ={0};
-	u1Byte				h2cParaLen=0;
-	u2Byte				paraLen=0;
-	u1Byte				retStatus=BT_STATUS_BT_OP_SUCCESS;
-	u1Byte				btOpcode;
-	u1Byte				btOpcodeVer=0;
-	u1Byte				testCtrl=0;
-
-	// 1. fill h2c parameters	
-		btOpcode =  0x11;
-		h2cParaBuf[0] = 0x11;
-		h2cParaBuf[1] = 0x0;
-		h2cParaBuf[2] = 0x0;
-		h2cParaBuf[3] = 0x0;
-		h2cParaBuf[4] = 0x0;
-		h2cParaLen = 1;
-	//	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
-		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, h2cParaBuf, h2cParaLen);
-	
-	
-	// 3. construct respond status code and data.
-	if(BT_STATUS_BT_OP_SUCCESS != retStatus)
-	{
-		pBtRsp->status = ((btOpcode<<8)|retStatus);
-		DBG_8192C("[MPT], Error!! status code=0x%x \n", pBtRsp->status);
-		return paraLen;
-	}
-
-	pBtRsp->status = BT_STATUS_SUCCESS;
-	return paraLen;
-}
-
-VOID
-mptbt_BtControlProcess(
-	PADAPTER	Adapter,
-	PVOID		pInBuf
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	PBT_H2C 		pH2c=(PBT_H2C)&H2C_Parameter[0];
-	PMPT_CONTEXT	pMptCtx=&(Adapter->mppriv.MptCtx);
-	PBT_REQ_CMD 	pBtReq=(PBT_REQ_CMD)pInBuf;
-	PBT_RSP_CMD 	pBtRsp;
-	u1Byte			i;
-
-
-	DBG_8192C("[MPT], mptbt_BtControlProcess()=========>\n");
-
-	DBG_8192C("[MPT], input opCodeVer=%d\n", pBtReq->opCodeVer);
-	DBG_8192C("[MPT], input OpCode=%d\n", pBtReq->OpCode);
-	DBG_8192C("[MPT], paraLength=%d \n", pBtReq->paraLength);
-	if(pBtReq->paraLength)
-	{
-		//DBG_8192C("[MPT], parameters(hex):0x%x %d \n",&pBtReq->pParamStart[0], pBtReq->paraLength);
-	}
-
-	_rtw_memset((void*)pMptCtx->mptOutBuf, 0, 100);
-	pMptCtx->mptOutLen = 4; //length of (BT_RSP_CMD.status+BT_RSP_CMD.paraLength)
-
-	pBtRsp = (PBT_RSP_CMD)pMptCtx->mptOutBuf;
-	pBtRsp->status = BT_STATUS_SUCCESS;
-	pBtRsp->paraLength = 0x0;
-
-	// The following we should maintain the User OP codes sent by upper layer
-	switch(pBtReq->OpCode)
-	{
-		case BT_UP_OP_BT_READY:
-			DBG_8192C("[MPT], OPcode : [BT_READY]\n");
-			pBtRsp->paraLength = mptbt_BtReady(Adapter, pBtReq, pBtRsp);
-			break;
-		case BT_UP_OP_BT_SET_MODE:
-			DBG_8192C("[MPT], OPcode : [BT_SET_MODE]\n");
-			pBtRsp->paraLength = mptbt_BtSetMode(Adapter, pBtReq, pBtRsp);
-			break;
-		case BT_UP_OP_BT_SET_TX_RX_PARAMETER:
-			DBG_8192C("[MPT], OPcode : [BT_SET_TXRX_PARAMETER]\n");
-			pBtRsp->paraLength = mptbt_BtSetTxRxPars(Adapter, pBtReq, pBtRsp);
-			break;
-		case BT_UP_OP_BT_SET_GENERAL:
-			DBG_8192C("[MPT], OPcode : [BT_SET_GENERAL]\n");
-			pBtRsp->paraLength = mptbt_BtSetGeneral(Adapter, pBtReq, pBtRsp);
-			break;
-		case BT_UP_OP_BT_GET_GENERAL:
-			DBG_8192C("[MPT], OPcode : [BT_GET_GENERAL]\n");
-			pBtRsp->paraLength = mptbt_BtGetGeneral(Adapter, pBtReq, pBtRsp);
-			break;
-		case BT_UP_OP_BT_TEST_CTRL:
-			DBG_8192C("[MPT], OPcode : [BT_TEST_CTRL]\n");
-			pBtRsp->paraLength = mptbt_BtTestCtrl(Adapter, pBtReq, pBtRsp);
-			break;
-		case BT_UP_OP_TEST_BT:
-			DBG_8192C("[MPT], OPcode : [TEST_BT]\n");
-			pBtRsp->paraLength = mptbt_TestBT(Adapter, pBtReq, pBtRsp);
-			break;
-		default:
-			DBG_8192C("[MPT], Error!! OPcode : UNDEFINED!!!!\n");
-			pBtRsp->status = BT_STATUS_UNKNOWN_OPCODE_U;
-			pBtRsp->paraLength = 0x0;
-			break;
-	}
-
-	pMptCtx->mptOutLen += pBtRsp->paraLength;
-
-	DBG_8192C("[MPT], pMptCtx->mptOutLen=%d, pBtRsp->paraLength=%d\n", pMptCtx->mptOutLen, pBtRsp->paraLength);
-	DBG_8192C("[MPT], mptbt_BtControlProcess()<=========\n");
-}
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <rtw_bt_mp.h>
+
+#if defined(CONFIG_RTL8723B)
+	#include <rtl8723b_hal.h>
+#endif
+
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8821A)
+void MPh2c_timeout_handle(void *FunctionContext)
+{
+	PADAPTER pAdapter;
+	PMPT_CONTEXT pMptCtx;
+
+
+	RTW_INFO("[MPT], MPh2c_timeout_handle\n");
+
+	pAdapter = (PADAPTER)FunctionContext;
+	pMptCtx = &pAdapter->mppriv.mpt_ctx;
+
+	pMptCtx->bMPh2c_timeout = _TRUE;
+
+	if ((_FALSE == pMptCtx->MptH2cRspEvent)
+	    || ((_TRUE == pMptCtx->MptH2cRspEvent)
+		&& (_FALSE == pMptCtx->MptBtC2hEvent)))
+		_rtw_up_sema(&pMptCtx->MPh2c_Sema);
+}
+
+u32 WaitC2Hevent(PADAPTER pAdapter, u8 *C2H_event, u32 delay_time)
+{
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	pMptCtx->bMPh2c_timeout = _FALSE;
+
+	if (pAdapter->registrypriv.mp_mode == 0) {
+		RTW_INFO("[MPT], Error!! WaitC2Hevent mp_mode == 0!!\n");
+		return _FALSE;
+	}
+
+	_set_timer(&pMptCtx->MPh2c_timeout_timer, delay_time);
+
+	_rtw_down_sema(&pMptCtx->MPh2c_Sema);
+
+	if (pMptCtx->bMPh2c_timeout == _TRUE) {
+		*C2H_event = _FALSE;
+
+		return _FALSE;
+	}
+
+	/* for safty, cancel timer here again */
+	_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
+
+	return _TRUE;
+}
+
+BT_CTRL_STATUS
+mptbt_CheckC2hFrame(
+	PADAPTER		Adapter,
+	PBT_H2C			pH2c,
+	PBT_EXT_C2H		pExtC2h
+)
+{
+	BT_CTRL_STATUS	c2hStatus = BT_STATUS_C2H_SUCCESS;
+
+	/* RTW_INFO("[MPT], MPT rsp C2H hex: %x %x %x  %x %x %x\n"), pExtC2h , pExtC2h+1 ,pExtC2h+2 ,pExtC2h+3 ,pExtC2h+4 ,pExtC2h+5); */
+
+	RTW_INFO("[MPT], statusCode = 0x%x\n", pExtC2h->statusCode);
+	RTW_INFO("[MPT], retLen = %d\n", pExtC2h->retLen);
+	RTW_INFO("[MPT], opCodeVer : req/rsp=%d/%d\n", pH2c->opCodeVer, pExtC2h->opCodeVer);
+	RTW_INFO("[MPT], reqNum : req/rsp=%d/%d\n", pH2c->reqNum, pExtC2h->reqNum);
+	if (pExtC2h->reqNum != pH2c->reqNum) {
+		c2hStatus = BT_STATUS_C2H_REQNUM_MISMATCH;
+		RTW_INFO("[MPT], Error!! C2H reqNum Mismatch!!\n");
+	} else if (pExtC2h->opCodeVer != pH2c->opCodeVer) {
+		c2hStatus = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
+		RTW_INFO("[MPT], Error!! OPCode version L mismatch!!\n");
+	}
+
+	return c2hStatus;
+}
+
+BT_CTRL_STATUS
+mptbt_SendH2c(
+	PADAPTER	Adapter,
+	PBT_H2C	pH2c,
+	u2Byte		h2cCmdLen
+)
+{
+	/* KIRQL				OldIrql = KeGetCurrentIrql(); */
+	BT_CTRL_STATUS	h2cStatus = BT_STATUS_H2C_SUCCESS;
+	PMPT_CONTEXT		pMptCtx = &(Adapter->mppriv.mpt_ctx);
+	u1Byte				i;
+
+	RTW_INFO("[MPT], mptbt_SendH2c()=========>\n");
+
+	/* PlatformResetEvent(&pMptCtx->MptH2cRspEvent); */
+	/* PlatformResetEvent(&pMptCtx->MptBtC2hEvent); */
+
+	/*	if(OldIrql == PASSIVE_LEVEL)
+	 *	{ */
+	/* RTPRINT_DATA(FMPBT, FMPBT_H2C_CONTENT, ("[MPT], MPT H2C hex:\n"), pH2c, h2cCmdLen); */
+
+	for (i = 0; i < BT_H2C_MAX_RETRY; i++) {
+		RTW_INFO("[MPT], Send H2C command to wifi!!!\n");
+
+		pMptCtx->MptH2cRspEvent = _FALSE;
+		pMptCtx->MptBtC2hEvent = _FALSE;
+
+#if defined(CONFIG_RTL8723B)
+		rtl8723b_set_FwBtMpOper_cmd(Adapter, pH2c->opCode, pH2c->opCodeVer, pH2c->reqNum, pH2c->buf);
+#endif
+		pMptCtx->h2cReqNum++;
+		pMptCtx->h2cReqNum %= 16;
+
+		if (WaitC2Hevent(Adapter, &pMptCtx->MptH2cRspEvent, 100)) {
+			RTW_INFO("[MPT], Received WiFi MptH2cRspEvent!!!\n");
+			if (WaitC2Hevent(Adapter, &pMptCtx->MptBtC2hEvent, 400)) {
+				RTW_INFO("[MPT], Received MptBtC2hEvent!!!\n");
+				break;
+			} else {
+				RTW_INFO("[MPT], Error!!BT MptBtC2hEvent timeout!!\n");
+				h2cStatus = BT_STATUS_H2C_BT_NO_RSP;
+			}
+		} else {
+			RTW_INFO("[MPT], Error!!WiFi  MptH2cRspEvent timeout!!\n");
+			h2cStatus = BT_STATUS_H2C_TIMTOUT;
+		}
+	}
+	/*	}
+	 *	else
+	 *	{
+	 * 		RT_ASSERT(FALSE, ("[MPT],  mptbt_SendH2c() can only run under PASSIVE_LEVEL!!\n"));
+	 *		h2cStatus = BT_STATUS_WRONG_LEVEL;
+	 *	} */
+
+	RTW_INFO("[MPT], mptbt_SendH2c()<=========\n");
+	return h2cStatus;
+}
+
+
+
+BT_CTRL_STATUS
+mptbt_CheckBtRspStatus(
+	PADAPTER			Adapter,
+	PBT_EXT_C2H			pExtC2h
+)
+{
+	BT_CTRL_STATUS	retStatus = BT_OP_STATUS_SUCCESS;
+
+	switch (pExtC2h->statusCode) {
+	case BT_OP_STATUS_SUCCESS:
+		retStatus = BT_STATUS_BT_OP_SUCCESS;
+		RTW_INFO("[MPT], BT status : BT_STATUS_SUCCESS\n");
+		break;
+	case BT_OP_STATUS_VERSION_MISMATCH:
+		retStatus = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
+		RTW_INFO("[MPT], BT status : BT_STATUS_OPCODE_L_VERSION_MISMATCH\n");
+		break;
+	case BT_OP_STATUS_UNKNOWN_OPCODE:
+		retStatus = BT_STATUS_UNKNOWN_OPCODE_L;
+		RTW_INFO("[MPT], BT status : BT_STATUS_UNKNOWN_OPCODE_L\n");
+		break;
+	case BT_OP_STATUS_ERROR_PARAMETER:
+		retStatus = BT_STATUS_PARAMETER_FORMAT_ERROR_L;
+		RTW_INFO("[MPT], BT status : BT_STATUS_PARAMETER_FORMAT_ERROR_L\n");
+		break;
+	default:
+		retStatus = BT_STATUS_UNKNOWN_STATUS_L;
+		RTW_INFO("[MPT], BT status : BT_STATUS_UNKNOWN_STATUS_L\n");
+		break;
+	}
+
+	return retStatus;
+}
+
+
+
+BT_CTRL_STATUS
+mptbt_BtFwOpCodeProcess(
+	PADAPTER		Adapter,
+	u1Byte			btFwOpCode,
+	u1Byte			opCodeVer,
+	pu1Byte			pH2cPar,
+	u1Byte			h2cParaLen
+)
+{
+	u1Byte				H2C_Parameter[6] = {0};
+	PBT_H2C				pH2c = (PBT_H2C)&H2C_Parameter[0];
+	PMPT_CONTEXT		pMptCtx = &(Adapter->mppriv.mpt_ctx);
+	PBT_EXT_C2H			pExtC2h = (PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
+	u2Byte				paraLen = 0, i;
+	BT_CTRL_STATUS	h2cStatus = BT_STATUS_H2C_SUCCESS, c2hStatus = BT_STATUS_C2H_SUCCESS;
+	BT_CTRL_STATUS	retStatus = BT_STATUS_H2C_BT_NO_RSP;
+
+	if (Adapter->registrypriv.mp_mode == 0) {
+		RTW_INFO("[MPT], Error!! mptbt_BtFwOpCodeProces mp_mode == 0!!\n");
+		return _FALSE;
+	}
+
+	pH2c->opCode = btFwOpCode;
+	pH2c->opCodeVer = opCodeVer;
+	pH2c->reqNum = pMptCtx->h2cReqNum;
+	/* PlatformMoveMemory(&pH2c->buf[0], pH2cPar, h2cParaLen); */
+	/* _rtw_memcpy(&pH2c->buf[0], pH2cPar, h2cParaLen); */
+	_rtw_memcpy(pH2c->buf, pH2cPar, h2cParaLen);
+
+	RTW_INFO("[MPT], pH2c->opCode=%d\n", pH2c->opCode);
+	RTW_INFO("[MPT], pH2c->opCodeVer=%d\n", pH2c->opCodeVer);
+	RTW_INFO("[MPT], pH2c->reqNum=%d\n", pH2c->reqNum);
+	RTW_INFO("[MPT], h2c parameter length=%d\n", h2cParaLen);
+	for (i = 0; i < h2cParaLen; i++)
+		RTW_INFO("[MPT], parameter[%d]=0x%02x\n", i, pH2c->buf[i]);
+
+	h2cStatus = mptbt_SendH2c(Adapter, pH2c, h2cParaLen + 2);
+	if (BT_STATUS_H2C_SUCCESS == h2cStatus) {
+		/* if reach here, it means H2C get the correct c2h response, */
+		c2hStatus = mptbt_CheckC2hFrame(Adapter, pH2c, pExtC2h);
+		if (BT_STATUS_C2H_SUCCESS == c2hStatus)
+			retStatus = mptbt_CheckBtRspStatus(Adapter, pExtC2h);
+		else {
+			RTW_INFO("[MPT], Error!! C2H failed for pH2c->opCode=%d\n", pH2c->opCode);
+			/* check c2h status error, return error status code to upper layer. */
+			retStatus = c2hStatus;
+		}
+	} else {
+		RTW_INFO("[MPT], Error!! H2C failed for pH2c->opCode=%d\n", pH2c->opCode);
+		/* check h2c status error, return error status code to upper layer. */
+		retStatus = h2cStatus;
+	}
+
+	return retStatus;
+}
+
+
+
+
+u2Byte
+mptbt_BtReady(
+	PADAPTER		Adapter,
+	PBT_REQ_CMD	pBtReq,
+	PBT_RSP_CMD	pBtRsp
+)
+{
+	u1Byte				h2cParaBuf[6] = {0};
+	u1Byte				h2cParaLen = 0;
+	u2Byte				paraLen = 0;
+	u1Byte				retStatus = BT_STATUS_BT_OP_SUCCESS;
+	u1Byte				btOpcode;
+	u1Byte				btOpcodeVer = 0;
+	PMPT_CONTEXT		pMptCtx = &(Adapter->mppriv.mpt_ctx);
+	PBT_EXT_C2H			pExtC2h = (PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
+	u1Byte				i;
+	u1Byte				btFwVer = 0, bdAddr[6] = {0};
+	u2Byte				btRealFwVer = 0;
+	pu2Byte			pu2Tmp = NULL;
+
+	/*  */
+	/* check upper layer parameters */
+	/*  */
+
+	/* 1. check upper layer opcode version */
+	if (pBtReq->opCodeVer != 1) {
+		RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
+		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
+		return paraLen;
+	}
+
+	pBtRsp->pParamStart[0] = MP_BT_NOT_READY;
+	paraLen = 10;
+	/*  */
+	/* execute lower layer opcodes */
+	/*  */
+
+	/* Get BT FW version */
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_GET_BT_VERSION;
+	/* execute h2c and check respond c2h from bt fw is correct or not */
+	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	} else {
+		pu2Tmp = (pu2Byte)&pExtC2h->buf[0];
+		btRealFwVer = *pu2Tmp;
+		btFwVer = pExtC2h->buf[1];
+		RTW_INFO("[MPT], btRealFwVer=0x%x, btFwVer=0x%x\n", btRealFwVer, btFwVer);
+	}
+
+	/* Get BD Address */
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_GET_BD_ADDR_L;
+	/* execute h2c and check respond c2h from bt fw is correct or not */
+	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	} else {
+		bdAddr[5] = pExtC2h->buf[0];
+		bdAddr[4] = pExtC2h->buf[1];
+		bdAddr[3] = pExtC2h->buf[2];
+	}
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_GET_BD_ADDR_H;
+	/* execute h2c and check respond c2h from bt fw is correct or not */
+	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	} else {
+		bdAddr[2] = pExtC2h->buf[0];
+		bdAddr[1] = pExtC2h->buf[1];
+		bdAddr[0] = pExtC2h->buf[2];
+	}
+	RTW_INFO("[MPT], Local BDAddr:");
+	for (i = 0; i < 6; i++)
+		RTW_INFO(" 0x%x ", bdAddr[i]);
+	pBtRsp->status = BT_STATUS_SUCCESS;
+	pBtRsp->pParamStart[0] = MP_BT_READY;
+	pu2Tmp = (pu2Byte)&pBtRsp->pParamStart[1];
+	*pu2Tmp = btRealFwVer;
+	pBtRsp->pParamStart[3] = btFwVer;
+	for (i = 0; i < 6; i++)
+		pBtRsp->pParamStart[4 + i] = bdAddr[5 - i];
+
+	return paraLen;
+}
+
+void mptbt_close_WiFiRF(PADAPTER Adapter)
+{
+	phy_set_bb_reg(Adapter, 0x824, 0xF, 0x0);
+	phy_set_bb_reg(Adapter, 0x824, 0x700000, 0x0);
+	phy_set_rf_reg(Adapter, RF_PATH_A, 0x0, 0xF0000, 0x0);
+}
+
+void mptbt_open_WiFiRF(PADAPTER	Adapter)
+{
+	phy_set_bb_reg(Adapter, 0x824, 0x700000, 0x3);
+	phy_set_bb_reg(Adapter, 0x824, 0xF, 0x2);
+	phy_set_rf_reg(Adapter, RF_PATH_A, 0x0, 0xF0000, 0x3);
+}
+
+u4Byte mptbt_switch_RF(PADAPTER	Adapter, u1Byte	Enter)
+{
+	u2Byte	tmp_2byte = 0;
+
+	/* Enter test mode */
+	if (Enter) {
+		/* 1>. close WiFi RF */
+		mptbt_close_WiFiRF(Adapter);
+
+		/* 2>. change ant switch to BT */
+		tmp_2byte = rtw_read16(Adapter, 0x860);
+		tmp_2byte = tmp_2byte | BIT(9);
+		tmp_2byte = tmp_2byte & (~BIT(8));
+		rtw_write16(Adapter, 0x860, tmp_2byte);
+		rtw_write16(Adapter, 0x870, 0x300);
+	} else {
+		/* 1>. Open WiFi RF */
+		mptbt_open_WiFiRF(Adapter);
+
+		/* 2>. change ant switch back */
+		tmp_2byte = rtw_read16(Adapter, 0x860);
+		tmp_2byte = tmp_2byte | BIT(8);
+		tmp_2byte = tmp_2byte & (~BIT(9));
+		rtw_write16(Adapter, 0x860, tmp_2byte);
+		rtw_write16(Adapter, 0x870, 0x300);
+	}
+
+	return 0;
+}
+
+u2Byte
+mptbt_BtSetMode(
+	PADAPTER		Adapter,
+	PBT_REQ_CMD	pBtReq,
+	PBT_RSP_CMD	pBtRsp
+)
+{
+	u1Byte				h2cParaBuf[6] = {0};
+	u1Byte				h2cParaLen = 0;
+	u2Byte				paraLen = 0;
+	u1Byte				retStatus = BT_STATUS_BT_OP_SUCCESS;
+	u1Byte				btOpcode;
+	u1Byte				btOpcodeVer = 0;
+	u1Byte				btModeToSet = 0;
+
+	/*  */
+	/* check upper layer parameters */
+	/*  */
+	/* 1. check upper layer opcode version */
+	if (pBtReq->opCodeVer != 1) {
+		RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
+		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
+		return paraLen;
+	}
+	/* 2. check upper layer parameter length */
+	if (1 == pBtReq->paraLength) {
+		btModeToSet = pBtReq->pParamStart[0];
+		RTW_INFO("[MPT], BtTestMode=%d\n", btModeToSet);
+	} else {
+		RTW_INFO("[MPT], Error!! wrong parameter length=%d (should be 1)\n", pBtReq->paraLength);
+		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
+		return paraLen;
+	}
+
+	/*  */
+	/* execute lower layer opcodes */
+	/*  */
+
+	/* 1. fill h2c parameters	 */
+	/* check bt mode */
+	btOpcode = BT_LO_OP_SET_BT_MODE;
+	if (btModeToSet >= MP_BT_MODE_MAX) {
+		pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	} else {
+		mptbt_switch_RF(Adapter, 1);
+
+		h2cParaBuf[0] = btModeToSet;
+		h2cParaLen = 1;
+		/* 2. execute h2c and check respond c2h from bt fw is correct or not */
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* 3. construct respond status code and data. */
+	if (BT_STATUS_BT_OP_SUCCESS == retStatus)
+		pBtRsp->status = BT_STATUS_SUCCESS;
+	else {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+	}
+
+	return paraLen;
+}
+
+
+VOID
+MPTBT_FwC2hBtMpCtrl(
+	PADAPTER	Adapter,
+	pu1Byte	tmpBuf,
+	u1Byte		length
+)
+{
+	u32 i;
+	PMPT_CONTEXT	pMptCtx = &(Adapter->mppriv.mpt_ctx);
+	PBT_EXT_C2H pExtC2h = (PBT_EXT_C2H)tmpBuf;
+
+	if (GET_HAL_DATA(Adapter)->bBTFWReady == _FALSE || Adapter->registrypriv.mp_mode == 0) {
+		/* RTW_INFO("Ignore C2H BT MP Info since not in MP mode\n"); */
+		return;
+	}
+	if (length > 32 || length < 3) {
+		RTW_INFO("\n [MPT], pExtC2h->buf hex: length=%d > 32 || < 3\n", length);
+		return;
+	}
+
+	/* cancel_timeout for h2c handle */
+	_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
+
+	for (i = 0; i < length; i++)
+		RTW_INFO("[MPT], %s, buf[%d]=0x%02x ", __FUNCTION__, i, tmpBuf[i]);
+	RTW_INFO("[MPT], pExtC2h->extendId=0x%x\n", pExtC2h->extendId);
+
+	switch (pExtC2h->extendId) {
+	case EXT_C2H_WIFI_FW_ACTIVE_RSP:
+		RTW_INFO("[MPT], EXT_C2H_WIFI_FW_ACTIVE_RSP\n");
+#if 0
+		RTW_INFO("[MPT], pExtC2h->buf hex:\n");
+		for (i = 0; i < (length - 3); i++)
+			RTW_INFO(" 0x%x ", pExtC2h->buf[i]);
+#endif
+		if ((_FALSE == pMptCtx->bMPh2c_timeout)
+		    && (_FALSE == pMptCtx->MptH2cRspEvent)) {
+			pMptCtx->MptH2cRspEvent = _TRUE;
+			_rtw_up_sema(&pMptCtx->MPh2c_Sema);
+		}
+		break;
+
+	case EXT_C2H_TRIG_BY_BT_FW:
+		RTW_INFO("[MPT], EXT_C2H_TRIG_BY_BT_FW\n");
+		_rtw_memcpy(&pMptCtx->c2hBuf[0], tmpBuf, length);
+		RTW_INFO("[MPT], pExtC2h->statusCode=0x%x\n", pExtC2h->statusCode);
+		RTW_INFO("[MPT], pExtC2h->retLen=0x%x\n", pExtC2h->retLen);
+		RTW_INFO("[MPT], pExtC2h->opCodeVer=0x%x\n", pExtC2h->opCodeVer);
+		RTW_INFO("[MPT], pExtC2h->reqNum=0x%x\n", pExtC2h->reqNum);
+		for (i = 0; i < (length - 3); i++)
+			RTW_INFO("[MPT], pExtC2h->buf[%d]=0x%02x\n", i, pExtC2h->buf[i]);
+
+		if ((_FALSE == pMptCtx->bMPh2c_timeout)
+		    && (_TRUE == pMptCtx->MptH2cRspEvent)
+		    && (_FALSE == pMptCtx->MptBtC2hEvent)) {
+			pMptCtx->MptBtC2hEvent = _TRUE;
+			_rtw_up_sema(&pMptCtx->MPh2c_Sema);
+		}
+		break;
+
+	default:
+		RTW_INFO("[MPT], EXT_C2H Target not found,pExtC2h->extendId =%d ,pExtC2h->reqNum=%d\n", pExtC2h->extendId, pExtC2h->reqNum);
+		break;
+	}
+
+
+
+}
+
+
+u2Byte
+mptbt_BtGetGeneral(
+	IN	PADAPTER		Adapter,
+	IN	PBT_REQ_CMD	pBtReq,
+	IN	PBT_RSP_CMD	pBtRsp
+)
+{
+	PMPT_CONTEXT		pMptCtx = &(Adapter->mppriv.mpt_ctx);
+	PBT_EXT_C2H		pExtC2h = (PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
+	u1Byte				h2cParaBuf[6] = {0};
+	u1Byte				h2cParaLen = 0;
+	u2Byte				paraLen = 0;
+	u1Byte				retStatus = BT_STATUS_BT_OP_SUCCESS;
+	u1Byte				btOpcode, bdAddr[6] = {0};
+	u1Byte				btOpcodeVer = 0;
+	u1Byte				getType = 0, i;
+	u2Byte				getParaLen = 0, validParaLen = 0;
+	u1Byte				regType = 0, reportType = 0;
+	u4Byte				regAddr = 0, regValue = 0;
+	pu4Byte			pu4Tmp;
+	pu2Byte			pu2Tmp;
+	pu1Byte			pu1Tmp;
+
+	/*  */
+	/* check upper layer parameters */
+	/*  */
+
+	/* check upper layer opcode version */
+	if (pBtReq->opCodeVer != 1) {
+		RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
+		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
+		return paraLen;
+	}
+	/* check upper layer parameter length */
+	if (pBtReq->paraLength < 1) {
+		RTW_INFO("[MPT], Error!! wrong parameter length=%d (should larger than 1)\n", pBtReq->paraLength);
+		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
+		return paraLen;
+	}
+	getParaLen = pBtReq->paraLength - 1;
+	getType = pBtReq->pParamStart[0];
+
+	RTW_INFO("[MPT], getType=%d, getParaLen=%d\n", getType, getParaLen);
+
+	/* check parameter first */
+	switch (getType) {
+	case BT_GGET_REG:
+		RTW_INFO("[MPT], [BT_GGET_REG]\n");
+		validParaLen = 5;
+		if (getParaLen == validParaLen) {
+			btOpcode = BT_LO_OP_READ_REG;
+			regType = pBtReq->pParamStart[1];
+			pu4Tmp = (pu4Byte)&pBtReq->pParamStart[2];
+			regAddr = *pu4Tmp;
+			RTW_INFO("[MPT], BT_GGET_REG regType=0x%02x, regAddr=0x%08x!!\n",
+				 regType, regAddr);
+			if (regType >= BT_REG_MAX) {
+				pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+				return paraLen;
+			} else {
+				if (((BT_REG_RF == regType) && (regAddr > 0x7f)) ||
+				    ((BT_REG_MODEM == regType) && (regAddr > 0x1ff)) ||
+				    ((BT_REG_BLUEWIZE == regType) && (regAddr > 0xfff)) ||
+				    ((BT_REG_VENDOR == regType) && (regAddr > 0xfff)) ||
+				    ((BT_REG_LE == regType) && (regAddr > 0xfff))) {
+					pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+					return paraLen;
+				}
+			}
+		}
+		break;
+	case BT_GGET_STATUS:
+		RTW_INFO("[MPT], [BT_GGET_STATUS]\n");
+		validParaLen = 0;
+		break;
+	case BT_GGET_REPORT:
+		RTW_INFO("[MPT], [BT_GGET_REPORT]\n");
+		validParaLen = 1;
+		if (getParaLen == validParaLen) {
+			reportType = pBtReq->pParamStart[1];
+			RTW_INFO("[MPT], BT_GGET_REPORT reportType=0x%x!!\n", reportType);
+			if (reportType >= BT_REPORT_MAX) {
+				pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+				return paraLen;
+			}
+		}
+		break;
+	default: {
+		RTW_INFO("[MPT], Error!! getType=%d, out of range\n", getType);
+		pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	}
+	break;
+	}
+	if (getParaLen != validParaLen) {
+		RTW_INFO("[MPT], Error!! wrong parameter length=%d for BT_GET_GEN_CMD cmd id=0x%x, paraLen should=0x%x\n",
+			 getParaLen, getType, validParaLen);
+		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
+		return paraLen;
+	}
+
+	/*  */
+	/* execute lower layer opcodes */
+	/*  */
+	if (BT_GGET_REG == getType) {
+		/* fill h2c parameters */
+		/* here we should write reg value first then write the address, adviced by Austin */
+		btOpcode = BT_LO_OP_READ_REG;
+		h2cParaBuf[0] = regType;
+		h2cParaBuf[1] = pBtReq->pParamStart[2];
+		h2cParaBuf[2] = pBtReq->pParamStart[3];
+		h2cParaLen = 3;
+		/* execute h2c and check respond c2h from bt fw is correct or not */
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* construct respond status code and data. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+
+		pu2Tmp = (pu2Byte)&pExtC2h->buf[0];
+		regValue = *pu2Tmp;
+		RTW_INFO("[MPT], read reg regType=0x%02x, regAddr=0x%08x, regValue=0x%04x\n",
+			 regType, regAddr, regValue);
+
+		pu4Tmp = (pu4Byte)&pBtRsp->pParamStart[0];
+		*pu4Tmp = regValue;
+		paraLen = 4;
+	} else if (BT_GGET_STATUS == getType) {
+		btOpcode = BT_LO_OP_GET_BT_STATUS;
+		h2cParaLen = 0;
+		/* execute h2c and check respond c2h from bt fw is correct or not */
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* construct respond status code and data. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+
+		pBtRsp->pParamStart[0] = pExtC2h->buf[0];
+		pBtRsp->pParamStart[1] = pExtC2h->buf[1];
+		RTW_INFO("[MPT], read bt status, testMode=0x%x, testStatus=0x%x\n",
+			 pBtRsp->pParamStart[0], pBtRsp->pParamStart[1]);
+		paraLen = 2;
+	} else if (BT_GGET_REPORT == getType) {
+		switch (reportType) {
+		case BT_REPORT_RX_PACKET_CNT: {
+			RTW_INFO("[MPT], [Rx Packet Counts]\n");
+			btOpcode = BT_LO_OP_GET_RX_PKT_CNT_L;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			pBtRsp->pParamStart[0] = pExtC2h->buf[0];
+			pBtRsp->pParamStart[1] = pExtC2h->buf[1];
+
+			btOpcode = BT_LO_OP_GET_RX_PKT_CNT_H;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			pBtRsp->pParamStart[2] = pExtC2h->buf[0];
+			pBtRsp->pParamStart[3] = pExtC2h->buf[1];
+			paraLen = 4;
+		}
+		break;
+		case BT_REPORT_RX_ERROR_BITS: {
+			RTW_INFO("[MPT], [Rx Error Bits]\n");
+			btOpcode = BT_LO_OP_GET_RX_ERROR_BITS_L;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			pBtRsp->pParamStart[0] = pExtC2h->buf[0];
+			pBtRsp->pParamStart[1] = pExtC2h->buf[1];
+
+			btOpcode = BT_LO_OP_GET_RX_ERROR_BITS_H;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			pBtRsp->pParamStart[2] = pExtC2h->buf[0];
+			pBtRsp->pParamStart[3] = pExtC2h->buf[1];
+			paraLen = 4;
+		}
+		break;
+		case BT_REPORT_RSSI: {
+			RTW_INFO("[MPT], [RSSI]\n");
+			btOpcode = BT_LO_OP_GET_RSSI;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			pBtRsp->pParamStart[0] = pExtC2h->buf[0];
+			pBtRsp->pParamStart[1] = pExtC2h->buf[1];
+			paraLen = 2;
+		}
+		break;
+		case BT_REPORT_CFO_HDR_QUALITY: {
+			RTW_INFO("[MPT], [CFO & Header Quality]\n");
+			btOpcode = BT_LO_OP_GET_CFO_HDR_QUALITY_L;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			pBtRsp->pParamStart[0] = pExtC2h->buf[0];
+			pBtRsp->pParamStart[1] = pExtC2h->buf[1];
+
+			btOpcode = BT_LO_OP_GET_CFO_HDR_QUALITY_H;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			pBtRsp->pParamStart[2] = pExtC2h->buf[0];
+			pBtRsp->pParamStart[3] = pExtC2h->buf[1];
+			paraLen = 4;
+		}
+		break;
+		case BT_REPORT_CONNECT_TARGET_BD_ADDR: {
+			RTW_INFO("[MPT], [Connected Target BD ADDR]\n");
+			btOpcode = BT_LO_OP_GET_TARGET_BD_ADDR_L;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			bdAddr[5] = pExtC2h->buf[0];
+			bdAddr[4] = pExtC2h->buf[1];
+			bdAddr[3] = pExtC2h->buf[2];
+
+			btOpcode = BT_LO_OP_GET_TARGET_BD_ADDR_H;
+			h2cParaLen = 0;
+			/* execute h2c and check respond c2h from bt fw is correct or not */
+			retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+			/* construct respond status code and data. */
+			if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+				pBtRsp->status = ((btOpcode << 8) | retStatus);
+				RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+				return paraLen;
+			}
+			bdAddr[2] = pExtC2h->buf[0];
+			bdAddr[1] = pExtC2h->buf[1];
+			bdAddr[0] = pExtC2h->buf[2];
+
+			RTW_INFO("[MPT], Connected Target BDAddr:%s", bdAddr);
+			for (i = 0; i < 6; i++)
+				pBtRsp->pParamStart[i] = bdAddr[5 - i];
+			paraLen = 6;
+		}
+		break;
+		default:
+			pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+			return paraLen;
+			break;
+		}
+	}
+
+	pBtRsp->status = BT_STATUS_SUCCESS;
+	return paraLen;
+}
+
+
+
+u2Byte
+mptbt_BtSetGeneral(
+	IN	PADAPTER		Adapter,
+	IN	PBT_REQ_CMD	pBtReq,
+	IN	PBT_RSP_CMD	pBtRsp
+)
+{
+	u1Byte				h2cParaBuf[6] = {0};
+	u1Byte				h2cParaLen = 0;
+	u2Byte				paraLen = 0;
+	u1Byte				retStatus = BT_STATUS_BT_OP_SUCCESS;
+	u1Byte				btOpcode;
+	u1Byte				btOpcodeVer = 0;
+	u1Byte				setType = 0;
+	u2Byte				setParaLen = 0, validParaLen = 0;
+	u1Byte				regType = 0, bdAddr[6] = {0}, calVal = 0;
+	u4Byte				regAddr = 0, regValue = 0;
+	pu4Byte			pu4Tmp;
+	pu2Byte			pu2Tmp;
+	pu1Byte			pu1Tmp;
+
+	/*  */
+	/* check upper layer parameters */
+	/*  */
+
+	/* check upper layer opcode version */
+	if (pBtReq->opCodeVer != 1) {
+		RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
+		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
+		return paraLen;
+	}
+	/* check upper layer parameter length */
+	if (pBtReq->paraLength < 1) {
+		RTW_INFO("[MPT], Error!! wrong parameter length=%d (should larger than 1)\n", pBtReq->paraLength);
+		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
+		return paraLen;
+	}
+	setParaLen = pBtReq->paraLength - 1;
+	setType = pBtReq->pParamStart[0];
+
+	RTW_INFO("[MPT], setType=%d, setParaLen=%d\n", setType, setParaLen);
+
+	/* check parameter first */
+	switch (setType) {
+	case BT_GSET_REG:
+		RTW_INFO("[MPT], [BT_GSET_REG]\n");
+		validParaLen = 9;
+		if (setParaLen == validParaLen) {
+			btOpcode = BT_LO_OP_WRITE_REG_VALUE;
+			regType = pBtReq->pParamStart[1];
+			pu4Tmp = (pu4Byte)&pBtReq->pParamStart[2];
+			regAddr = *pu4Tmp;
+			pu4Tmp = (pu4Byte)&pBtReq->pParamStart[6];
+			regValue = *pu4Tmp;
+			RTW_INFO("[MPT], BT_GSET_REG regType=0x%x, regAddr=0x%x, regValue=0x%x!!\n",
+				 regType, regAddr, regValue);
+			if (regType >= BT_REG_MAX) {
+				pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+				return paraLen;
+			} else {
+				if (((BT_REG_RF == regType) && (regAddr > 0x7f)) ||
+				    ((BT_REG_MODEM == regType) && (regAddr > 0x1ff)) ||
+				    ((BT_REG_BLUEWIZE == regType) && (regAddr > 0xfff)) ||
+				    ((BT_REG_VENDOR == regType) && (regAddr > 0xfff)) ||
+				    ((BT_REG_LE == regType) && (regAddr > 0xfff))) {
+					pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+					return paraLen;
+				}
+			}
+		}
+		break;
+	case BT_GSET_RESET:
+		RTW_INFO("[MPT], [BT_GSET_RESET]\n");
+		validParaLen = 0;
+		break;
+	case BT_GSET_TARGET_BD_ADDR:
+		RTW_INFO("[MPT], [BT_GSET_TARGET_BD_ADDR]\n");
+		validParaLen = 6;
+		if (setParaLen == validParaLen) {
+			btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_H;
+			if ((pBtReq->pParamStart[1] == 0) &&
+			    (pBtReq->pParamStart[2] == 0) &&
+			    (pBtReq->pParamStart[3] == 0) &&
+			    (pBtReq->pParamStart[4] == 0) &&
+			    (pBtReq->pParamStart[5] == 0) &&
+			    (pBtReq->pParamStart[6] == 0)) {
+				RTW_INFO("[MPT], Error!! targetBDAddr=all zero\n");
+				pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+				return paraLen;
+			}
+			if ((pBtReq->pParamStart[1] == 0xff) &&
+			    (pBtReq->pParamStart[2] == 0xff) &&
+			    (pBtReq->pParamStart[3] == 0xff) &&
+			    (pBtReq->pParamStart[4] == 0xff) &&
+			    (pBtReq->pParamStart[5] == 0xff) &&
+			    (pBtReq->pParamStart[6] == 0xff)) {
+				RTW_INFO("[MPT], Error!! targetBDAddr=all 0xf\n");
+				pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+				return paraLen;
+			}
+			bdAddr[0] = pBtReq->pParamStart[6];
+			bdAddr[1] = pBtReq->pParamStart[5];
+			bdAddr[2] = pBtReq->pParamStart[4];
+			bdAddr[3] = pBtReq->pParamStart[3];
+			bdAddr[4] = pBtReq->pParamStart[2];
+			bdAddr[5] = pBtReq->pParamStart[1];
+			RTW_INFO("[MPT], target BDAddr:%x,%x,%x,%x,%x,%x\n",
+				bdAddr[0], bdAddr[1], bdAddr[2], bdAddr[3], bdAddr[4], bdAddr[5]);
+		}
+		break;
+	case BT_GSET_TX_PWR_FINETUNE:
+		RTW_INFO("[MPT], [BT_GSET_TX_PWR_FINETUNE]\n");
+		validParaLen = 1;
+		if (setParaLen == validParaLen) {
+			btOpcode = BT_LO_OP_SET_TX_POWER_CALIBRATION;
+			calVal = pBtReq->pParamStart[1];
+			if ((calVal < 1) || (calVal > 9)) {
+				pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+				return paraLen;
+			}
+			RTW_INFO("[MPT], calVal=%d\n", calVal);
+		}
+		break;
+	case BT_SET_TRACKING_INTERVAL:
+		RTW_INFO("[MPT], [BT_SET_TRACKING_INTERVAL] setParaLen =%d\n", setParaLen);
+
+		validParaLen = 1;
+		if (setParaLen == validParaLen)
+			calVal = pBtReq->pParamStart[1];
+		break;
+	case BT_SET_THERMAL_METER:
+		RTW_INFO("[MPT], [BT_SET_THERMAL_METER] setParaLen =%d\n", setParaLen);
+		validParaLen = 1;
+		if (setParaLen == validParaLen)
+			calVal = pBtReq->pParamStart[1];
+		break;
+	case BT_ENABLE_CFO_TRACKING:
+		RTW_INFO("[MPT], [BT_ENABLE_CFO_TRACKING] setParaLen =%d\n", setParaLen);
+		validParaLen = 1;
+		if (setParaLen == validParaLen)
+			calVal = pBtReq->pParamStart[1];
+		break;
+	case BT_GSET_UPDATE_BT_PATCH:
+
+		break;
+	default: {
+		RTW_INFO("[MPT], Error!! setType=%d, out of range\n", setType);
+		pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	}
+	break;
+	}
+	if (setParaLen != validParaLen) {
+		RTW_INFO("[MPT], Error!! wrong parameter length=%d for BT_SET_GEN_CMD cmd id=0x%x, paraLen should=0x%x\n",
+			 setParaLen, setType, validParaLen);
+		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
+		return paraLen;
+	}
+
+	/*  */
+	/* execute lower layer opcodes */
+	/*  */
+	if (BT_GSET_REG == setType) {
+		/* fill h2c parameters */
+		/* here we should write reg value first then write the address, adviced by Austin */
+		btOpcode = BT_LO_OP_WRITE_REG_VALUE;
+		h2cParaBuf[0] = pBtReq->pParamStart[6];
+		h2cParaBuf[1] = pBtReq->pParamStart[7];
+		h2cParaBuf[2] = pBtReq->pParamStart[8];
+		h2cParaLen = 3;
+		/* execute h2c and check respond c2h from bt fw is correct or not */
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* construct respond status code and data. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+
+		/* write reg address */
+		btOpcode = BT_LO_OP_WRITE_REG_ADDR;
+		h2cParaBuf[0] = regType;
+		h2cParaBuf[1] = pBtReq->pParamStart[2];
+		h2cParaBuf[2] = pBtReq->pParamStart[3];
+		h2cParaLen = 3;
+		/* execute h2c and check respond c2h from bt fw is correct or not */
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* construct respond status code and data. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+	} else if (BT_GSET_RESET == setType) {
+		btOpcode = BT_LO_OP_RESET;
+		h2cParaLen = 0;
+		/* execute h2c and check respond c2h from bt fw is correct or not */
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* construct respond status code and data. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+	} else if (BT_GSET_TARGET_BD_ADDR == setType) {
+		/* fill h2c parameters */
+		btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_L;
+		h2cParaBuf[0] = pBtReq->pParamStart[1];
+		h2cParaBuf[1] = pBtReq->pParamStart[2];
+		h2cParaBuf[2] = pBtReq->pParamStart[3];
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* ckeck bt return status. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+
+		btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_H;
+		h2cParaBuf[0] = pBtReq->pParamStart[4];
+		h2cParaBuf[1] = pBtReq->pParamStart[5];
+		h2cParaBuf[2] = pBtReq->pParamStart[6];
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* ckeck bt return status. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+	} else if (BT_GSET_TX_PWR_FINETUNE == setType) {
+		/* fill h2c parameters */
+		btOpcode = BT_LO_OP_SET_TX_POWER_CALIBRATION;
+		h2cParaBuf[0] = calVal;
+		h2cParaLen = 1;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* ckeck bt return status. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+	} else if (BT_SET_TRACKING_INTERVAL == setType) {
+		/*	BT_LO_OP_SET_TRACKING_INTERVAL								= 0x22, */
+		/*	BT_LO_OP_SET_THERMAL_METER									= 0x23, */
+		/*	BT_LO_OP_ENABLE_CFO_TRACKING									= 0x24, */
+		btOpcode = BT_LO_OP_SET_TRACKING_INTERVAL;
+		h2cParaBuf[0] = calVal;
+		h2cParaLen = 1;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* ckeck bt return status. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+	} else if (BT_SET_THERMAL_METER == setType) {
+		btOpcode = BT_LO_OP_SET_THERMAL_METER;
+		h2cParaBuf[0] = calVal;
+		h2cParaLen = 1;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* ckeck bt return status. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+	} else if (BT_ENABLE_CFO_TRACKING == setType) {
+		btOpcode = BT_LO_OP_ENABLE_CFO_TRACKING;
+		h2cParaBuf[0] = calVal;
+		h2cParaLen = 1;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+		/* ckeck bt return status. */
+		if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+			pBtRsp->status = ((btOpcode << 8) | retStatus);
+			RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+			return paraLen;
+		}
+	}
+
+	pBtRsp->status = BT_STATUS_SUCCESS;
+	return paraLen;
+}
+
+
+
+u2Byte
+mptbt_BtSetTxRxPars(
+	IN	PADAPTER		Adapter,
+	IN	PBT_REQ_CMD	pBtReq,
+	IN	PBT_RSP_CMD	pBtRsp
+)
+{
+	u1Byte				h2cParaBuf[6] = {0};
+	u1Byte				h2cParaLen = 0;
+	u2Byte				paraLen = 0;
+	u1Byte				retStatus = BT_STATUS_BT_OP_SUCCESS;
+	u1Byte				btOpcode;
+	u1Byte				btOpcodeVer = 0;
+	PBT_TXRX_PARAMETERS pTxRxPars = (PBT_TXRX_PARAMETERS)&pBtReq->pParamStart[0];
+	u2Byte				lenTxRx = sizeof(BT_TXRX_PARAMETERS);
+	u1Byte				i;
+	u1Byte				bdAddr[6] = {0};
+
+	/*  */
+	/* check upper layer parameters */
+	/*  */
+
+	/* 1. check upper layer opcode version */
+	if (pBtReq->opCodeVer != 1) {
+		RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
+		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
+		return paraLen;
+	}
+	/* 2. check upper layer parameter length */
+	if (pBtReq->paraLength == sizeof(BT_TXRX_PARAMETERS)) {
+		RTW_INFO("[MPT], pTxRxPars->txrxChannel=0x%x\n", pTxRxPars->txrxChannel);
+		RTW_INFO("[MPT], pTxRxPars->txrxTxPktCnt=0x%8x\n", pTxRxPars->txrxTxPktCnt);
+		RTW_INFO("[MPT], pTxRxPars->txrxTxPktInterval=0x%x\n", pTxRxPars->txrxTxPktInterval);
+		RTW_INFO("[MPT], pTxRxPars->txrxPayloadType=0x%x\n", pTxRxPars->txrxPayloadType);
+		RTW_INFO("[MPT], pTxRxPars->txrxPktType=0x%x\n", pTxRxPars->txrxPktType);
+		RTW_INFO("[MPT], pTxRxPars->txrxPayloadLen=0x%x\n", pTxRxPars->txrxPayloadLen);
+		RTW_INFO("[MPT], pTxRxPars->txrxPktHeader=0x%x\n", pTxRxPars->txrxPktHeader);
+		RTW_INFO("[MPT], pTxRxPars->txrxWhitenCoeff=0x%x\n", pTxRxPars->txrxWhitenCoeff);
+		bdAddr[0] = pTxRxPars->txrxBdaddr[5];
+		bdAddr[1] = pTxRxPars->txrxBdaddr[4];
+		bdAddr[2] = pTxRxPars->txrxBdaddr[3];
+		bdAddr[3] = pTxRxPars->txrxBdaddr[2];
+		bdAddr[4] = pTxRxPars->txrxBdaddr[1];
+		bdAddr[5] = pTxRxPars->txrxBdaddr[0];
+		RTW_INFO("[MPT], pTxRxPars->txrxBdaddr: %s", &bdAddr[0]);
+		RTW_INFO("[MPT], pTxRxPars->txrxTxGainIndex=0x%x\n", pTxRxPars->txrxTxGainIndex);
+	} else {
+		RTW_INFO("[MPT], Error!! pBtReq->paraLength=%d, correct Len=%d\n", pBtReq->paraLength, lenTxRx);
+		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
+		return paraLen;
+	}
+
+	/*  */
+	/* execute lower layer opcodes */
+	/*  */
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_SET_PKT_HEADER;
+	if (pTxRxPars->txrxPktHeader > 0x3ffff) {
+		RTW_INFO("[MPT], Error!! pTxRxPars->txrxPktHeader=0x%x is out of range, (should be between 0x0~0x3ffff)\n", pTxRxPars->txrxPktHeader);
+		pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	} else {
+		h2cParaBuf[0] = (u1Byte)(pTxRxPars->txrxPktHeader & 0xff);
+		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxPktHeader & 0xff00) >> 8);
+		h2cParaBuf[2] = (u1Byte)((pTxRxPars->txrxPktHeader & 0xff0000) >> 16);
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_SET_PKT_TYPE_LEN;
+	{
+		u2Byte	payloadLenLimit = 0;
+		switch (pTxRxPars->txrxPktType) {
+		case MP_BT_PKT_DH1:
+			payloadLenLimit = 27 * 8;
+			break;
+		case MP_BT_PKT_DH3:
+			payloadLenLimit = 183 * 8;
+			break;
+		case MP_BT_PKT_DH5:
+			payloadLenLimit = 339 * 8;
+			break;
+		case MP_BT_PKT_2DH1:
+			payloadLenLimit = 54 * 8;
+			break;
+		case MP_BT_PKT_2DH3:
+			payloadLenLimit = 367 * 8;
+			break;
+		case MP_BT_PKT_2DH5:
+			payloadLenLimit = 679 * 8;
+			break;
+		case MP_BT_PKT_3DH1:
+			payloadLenLimit = 83 * 8;
+			break;
+		case MP_BT_PKT_3DH3:
+			payloadLenLimit = 552 * 8;
+			break;
+		case MP_BT_PKT_3DH5:
+			payloadLenLimit = 1021 * 8;
+			break;
+		case MP_BT_PKT_LE:
+			payloadLenLimit = 39 * 8;
+			break;
+		default: {
+			RTW_INFO("[MPT], Error!! Unknown pTxRxPars->txrxPktType=0x%x\n", pTxRxPars->txrxPktType);
+			pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+			return paraLen;
+		}
+		break;
+		}
+
+		if (pTxRxPars->txrxPayloadLen > payloadLenLimit) {
+			RTW_INFO("[MPT], Error!! pTxRxPars->txrxPayloadLen=0x%x, (should smaller than %d)\n",
+				 pTxRxPars->txrxPayloadLen, payloadLenLimit);
+			pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+			return paraLen;
+		}
+
+		h2cParaBuf[0] = pTxRxPars->txrxPktType;
+		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxPayloadLen & 0xff));
+		h2cParaBuf[2] = (u1Byte)((pTxRxPars->txrxPayloadLen & 0xff00) >> 8);
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_SET_PKT_CNT_L_PL_TYPE;
+	if (pTxRxPars->txrxPayloadType > MP_BT_PAYLOAD_MAX) {
+		RTW_INFO("[MPT], Error!! pTxRxPars->txrxPayloadType=0x%x, (should be between 0~4)\n", pTxRxPars->txrxPayloadType);
+		pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	} else {
+		h2cParaBuf[0] = (u1Byte)((pTxRxPars->txrxTxPktCnt & 0xff));
+		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxTxPktCnt & 0xff00) >> 8);
+		h2cParaBuf[2] = pTxRxPars->txrxPayloadType;
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_SET_PKT_CNT_H_PKT_INTV;
+	if (pTxRxPars->txrxTxPktInterval > 15) {
+		RTW_INFO("[MPT], Error!! pTxRxPars->txrxTxPktInterval=0x%x, (should be between 0~15)\n", pTxRxPars->txrxTxPktInterval);
+		pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	} else {
+		h2cParaBuf[0] = (u1Byte)((pTxRxPars->txrxTxPktCnt & 0xff0000) >> 16);
+		h2cParaBuf[1] = (u1Byte)((pTxRxPars->txrxTxPktCnt & 0xff000000) >> 24);
+		h2cParaBuf[2] = pTxRxPars->txrxTxPktInterval;
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_SET_WHITENCOEFF;
+	{
+		h2cParaBuf[0] = pTxRxPars->txrxWhitenCoeff;
+		h2cParaLen = 1;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_SET_CHNL_TX_GAIN;
+	if ((pTxRxPars->txrxChannel > 78) ||
+	    (pTxRxPars->txrxTxGainIndex > 7)) {
+		RTW_INFO("[MPT], Error!! pTxRxPars->txrxChannel=0x%x, (should be between 0~78)\n", pTxRxPars->txrxChannel);
+		RTW_INFO("[MPT], Error!! pTxRxPars->txrxTxGainIndex=0x%x, (should be between 0~7)\n", pTxRxPars->txrxTxGainIndex);
+		pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	} else {
+		h2cParaBuf[0] = pTxRxPars->txrxChannel;
+		h2cParaBuf[1] = pTxRxPars->txrxTxGainIndex;
+		h2cParaLen = 2;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	/* fill h2c parameters */
+	btOpcode = BT_LO_OP_SET_BD_ADDR_L;
+	if ((pTxRxPars->txrxBdaddr[0] == 0) &&
+	    (pTxRxPars->txrxBdaddr[1] == 0) &&
+	    (pTxRxPars->txrxBdaddr[2] == 0) &&
+	    (pTxRxPars->txrxBdaddr[3] == 0) &&
+	    (pTxRxPars->txrxBdaddr[4] == 0) &&
+	    (pTxRxPars->txrxBdaddr[5] == 0)) {
+		RTW_INFO("[MPT], Error!! pTxRxPars->txrxBdaddr=all zero\n");
+		pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	}
+	if ((pTxRxPars->txrxBdaddr[0] == 0xff) &&
+	    (pTxRxPars->txrxBdaddr[1] == 0xff) &&
+	    (pTxRxPars->txrxBdaddr[2] == 0xff) &&
+	    (pTxRxPars->txrxBdaddr[3] == 0xff) &&
+	    (pTxRxPars->txrxBdaddr[4] == 0xff) &&
+	    (pTxRxPars->txrxBdaddr[5] == 0xff)) {
+		RTW_INFO("[MPT], Error!! pTxRxPars->txrxBdaddr=all 0xf\n");
+		pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	}
+
+	{
+		h2cParaBuf[0] = pTxRxPars->txrxBdaddr[0];
+		h2cParaBuf[1] = pTxRxPars->txrxBdaddr[1];
+		h2cParaBuf[2] = pTxRxPars->txrxBdaddr[2];
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	btOpcode = BT_LO_OP_SET_BD_ADDR_H;
+	{
+		h2cParaBuf[0] = pTxRxPars->txrxBdaddr[3];
+		h2cParaBuf[1] = pTxRxPars->txrxBdaddr[4];
+		h2cParaBuf[2] = pTxRxPars->txrxBdaddr[5];
+		h2cParaLen = 3;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+	/* ckeck bt return status. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	pBtRsp->status = BT_STATUS_SUCCESS;
+	return paraLen;
+}
+
+
+
+u2Byte
+mptbt_BtTestCtrl(
+	IN	PADAPTER		Adapter,
+	IN	PBT_REQ_CMD	pBtReq,
+	IN	PBT_RSP_CMD	pBtRsp
+)
+{
+	u1Byte				h2cParaBuf[6] = {0};
+	u1Byte				h2cParaLen = 0;
+	u2Byte				paraLen = 0;
+	u1Byte				retStatus = BT_STATUS_BT_OP_SUCCESS;
+	u1Byte				btOpcode;
+	u1Byte				btOpcodeVer = 0;
+	u1Byte				testCtrl = 0;
+
+	/*  */
+	/* check upper layer parameters */
+	/*  */
+
+	/* 1. check upper layer opcode version */
+	if (pBtReq->opCodeVer != 1) {
+		RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
+		pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
+		return paraLen;
+	}
+	/* 2. check upper layer parameter length */
+	if (1 == pBtReq->paraLength) {
+		testCtrl = pBtReq->pParamStart[0];
+		RTW_INFO("[MPT], testCtrl=%d\n", testCtrl);
+	} else {
+		RTW_INFO("[MPT], Error!! wrong parameter length=%d (should be 1)\n", pBtReq->paraLength);
+		pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
+		return paraLen;
+	}
+
+	/*  */
+	/* execute lower layer opcodes */
+	/*  */
+
+	/* 1. fill h2c parameters	 */
+	/* check bt mode */
+	btOpcode = BT_LO_OP_TEST_CTRL;
+	if (testCtrl >= MP_BT_TEST_MAX) {
+		RTW_INFO("[MPT], Error!! testCtrl=0x%x, (should be between smaller or equal to 0x%x)\n",
+			 testCtrl, MP_BT_TEST_MAX - 1);
+		pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
+		return paraLen;
+	} else {
+		h2cParaBuf[0] = testCtrl;
+		h2cParaLen = 1;
+		retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
+	}
+
+	/* 3. construct respond status code and data. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	pBtRsp->status = BT_STATUS_SUCCESS;
+	return paraLen;
+}
+
+
+u2Byte
+mptbt_TestBT(
+	IN	PADAPTER		Adapter,
+	IN	PBT_REQ_CMD	pBtReq,
+	IN	PBT_RSP_CMD	pBtRsp
+)
+{
+
+	u1Byte				h2cParaBuf[6] = {0};
+	u1Byte				h2cParaLen = 0;
+	u2Byte				paraLen = 0;
+	u1Byte				retStatus = BT_STATUS_BT_OP_SUCCESS;
+	u1Byte				btOpcode;
+	u1Byte				btOpcodeVer = 0;
+	u1Byte				testCtrl = 0;
+
+	/* 1. fill h2c parameters	 */
+	btOpcode =  0x11;
+	h2cParaBuf[0] = 0x11;
+	h2cParaBuf[1] = 0x0;
+	h2cParaBuf[2] = 0x0;
+	h2cParaBuf[3] = 0x0;
+	h2cParaBuf[4] = 0x0;
+	h2cParaLen = 1;
+	/*	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen); */
+	retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, h2cParaBuf, h2cParaLen);
+
+
+	/* 3. construct respond status code and data. */
+	if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
+		pBtRsp->status = ((btOpcode << 8) | retStatus);
+		RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
+		return paraLen;
+	}
+
+	pBtRsp->status = BT_STATUS_SUCCESS;
+	return paraLen;
+}
+
+VOID
+mptbt_BtControlProcess(
+	PADAPTER	Adapter,
+	PVOID		pInBuf
+)
+{
+	u1Byte			H2C_Parameter[6] = {0};
+	PBT_H2C		pH2c = (PBT_H2C)&H2C_Parameter[0];
+	PMPT_CONTEXT	pMptCtx = &(Adapter->mppriv.mpt_ctx);
+	PBT_REQ_CMD	pBtReq = (PBT_REQ_CMD)pInBuf;
+	PBT_RSP_CMD	pBtRsp;
+	u1Byte			i;
+
+
+	RTW_INFO("[MPT], mptbt_BtControlProcess()=========>\n");
+
+	RTW_INFO("[MPT], input opCodeVer=%d\n", pBtReq->opCodeVer);
+	RTW_INFO("[MPT], input OpCode=%d\n", pBtReq->OpCode);
+	RTW_INFO("[MPT], paraLength=%d\n", pBtReq->paraLength);
+	if (pBtReq->paraLength) {
+		/* RTW_INFO("[MPT], parameters(hex):0x%x %d\n",&pBtReq->pParamStart[0], pBtReq->paraLength); */
+	}
+
+	_rtw_memset((void *)pMptCtx->mptOutBuf, 0, 100);
+	pMptCtx->mptOutLen = 4; /* length of (BT_RSP_CMD.status+BT_RSP_CMD.paraLength) */
+
+	pBtRsp = (PBT_RSP_CMD)pMptCtx->mptOutBuf;
+	pBtRsp->status = BT_STATUS_SUCCESS;
+	pBtRsp->paraLength = 0x0;
+
+	/* The following we should maintain the User OP codes sent by upper layer */
+	switch (pBtReq->OpCode) {
+	case BT_UP_OP_BT_READY:
+		RTW_INFO("[MPT], OPcode : [BT_READY]\n");
+		pBtRsp->paraLength = mptbt_BtReady(Adapter, pBtReq, pBtRsp);
+		break;
+	case BT_UP_OP_BT_SET_MODE:
+		RTW_INFO("[MPT], OPcode : [BT_SET_MODE]\n");
+		pBtRsp->paraLength = mptbt_BtSetMode(Adapter, pBtReq, pBtRsp);
+		break;
+	case BT_UP_OP_BT_SET_TX_RX_PARAMETER:
+		RTW_INFO("[MPT], OPcode : [BT_SET_TXRX_PARAMETER]\n");
+		pBtRsp->paraLength = mptbt_BtSetTxRxPars(Adapter, pBtReq, pBtRsp);
+		break;
+	case BT_UP_OP_BT_SET_GENERAL:
+		RTW_INFO("[MPT], OPcode : [BT_SET_GENERAL]\n");
+		pBtRsp->paraLength = mptbt_BtSetGeneral(Adapter, pBtReq, pBtRsp);
+		break;
+	case BT_UP_OP_BT_GET_GENERAL:
+		RTW_INFO("[MPT], OPcode : [BT_GET_GENERAL]\n");
+		pBtRsp->paraLength = mptbt_BtGetGeneral(Adapter, pBtReq, pBtRsp);
+		break;
+	case BT_UP_OP_BT_TEST_CTRL:
+		RTW_INFO("[MPT], OPcode : [BT_TEST_CTRL]\n");
+		pBtRsp->paraLength = mptbt_BtTestCtrl(Adapter, pBtReq, pBtRsp);
+		break;
+	case BT_UP_OP_TEST_BT:
+		RTW_INFO("[MPT], OPcode : [TEST_BT]\n");
+		pBtRsp->paraLength = mptbt_TestBT(Adapter, pBtReq, pBtRsp);
+		break;
+	default:
+		RTW_INFO("[MPT], Error!! OPcode : UNDEFINED!!!!\n");
+		pBtRsp->status = BT_STATUS_UNKNOWN_OPCODE_U;
+		pBtRsp->paraLength = 0x0;
+		break;
+	}
+
+	pMptCtx->mptOutLen += pBtRsp->paraLength;
+
+	RTW_INFO("[MPT], pMptCtx->mptOutLen=%d, pBtRsp->paraLength=%d\n", pMptCtx->mptOutLen, pBtRsp->paraLength);
+	RTW_INFO("[MPT], mptbt_BtControlProcess()<=========\n");
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_btcoex.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_btcoex.c
index aafdd72c7d33..4cb440592d6c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_btcoex.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_btcoex.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,18 +12,11 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifdef CONFIG_BT_COEXIST
-
+ *****************************************************************************/
 #include <drv_types.h>
-#include <hal_btcoex.h>
 #include <hal_data.h>
-
+#ifdef CONFIG_BT_COEXIST
+#include <hal_btcoex.h>
 
 void rtw_btcoex_Initialize(PADAPTER padapter)
 {
@@ -34,6 +28,16 @@ void rtw_btcoex_PowerOnSetting(PADAPTER padapter)
 	hal_btcoex_PowerOnSetting(padapter);
 }
 
+void rtw_btcoex_AntInfoSetting(PADAPTER padapter)
+{
+	hal_btcoex_AntInfoSetting(padapter);
+}
+
+void rtw_btcoex_PowerOffSetting(PADAPTER padapter)
+{
+	hal_btcoex_PowerOffSetting(padapter);
+}
+
 void rtw_btcoex_PreLoadFirmware(PADAPTER padapter)
 {
 	hal_btcoex_PreLoadFirmware(padapter);
@@ -71,26 +75,28 @@ void rtw_btcoex_ScanNotify(PADAPTER padapter, u8 type)
 	PHAL_DATA_TYPE	pHalData;
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
-	PBT_MGNT	pBtMgnt=&pcoex_info->BtMgnt;
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
+	PBT_MGNT	pBtMgnt = &pcoex_info->BtMgnt;
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 
 	pHalData = GET_HAL_DATA(padapter);
 	if (_FALSE == pHalData->EEPROMBluetoothCoexist)
 		return;
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if ((_FALSE == type) && (padapter->pbuddy_adapter))
-	{
-		PADAPTER pbuddy = padapter->pbuddy_adapter;
-		if (check_fwstate(&pbuddy->mlmepriv, WIFI_SITE_MONITOR) == _TRUE)
+	if (_FALSE == type) {
+		#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_buddy_check_fwstate(padapter, WIFI_SITE_MONITOR))
+			return;
+		#endif
+
+		if (DEV_MGMT_TX_NUM(adapter_to_dvobj(padapter))
+			|| DEV_ROCH_NUM(adapter_to_dvobj(padapter)))
 			return;
 	}
-#endif
 
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-	if(pBtMgnt->ExtConfig.bEnableWifiScanNotify)
+	if (pBtMgnt->ExtConfig.bEnableWifiScanNotify)
 		rtw_btcoex_SendScanNotify(padapter, type);
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX	
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX	 */
 
 	hal_btcoex_ScanNotify(padapter, type);
 }
@@ -104,19 +110,16 @@ void rtw_btcoex_ConnectNotify(PADAPTER padapter, u8 action)
 		return;
 
 #ifdef DBG_CONFIG_ERROR_RESET
-	if (_TRUE == rtw_hal_sreset_inprogress(padapter))
-	{
-		DBG_8192C(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
-			FUNC_ADPT_ARG(padapter));
+	if (_TRUE == rtw_hal_sreset_inprogress(padapter)) {
+		RTW_INFO(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
+			 FUNC_ADPT_ARG(padapter));
 		return;
 	}
-#endif // DBG_CONFIG_ERROR_RESET
-		
+#endif /* DBG_CONFIG_ERROR_RESET */
+
 #ifdef CONFIG_CONCURRENT_MODE
-	if ((_FALSE == action) && (padapter->pbuddy_adapter))
-	{
-		PADAPTER pbuddy = padapter->pbuddy_adapter;
-		if (check_fwstate(&pbuddy->mlmepriv, WIFI_UNDER_LINKING) == _TRUE)
+	if (_FALSE == action) {
+		if (rtw_mi_buddy_check_fwstate(padapter, WIFI_UNDER_LINKING))
 			return;
 	}
 #endif
@@ -133,28 +136,23 @@ void rtw_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus)
 		return;
 
 #ifdef DBG_CONFIG_ERROR_RESET
-	if (_TRUE == rtw_hal_sreset_inprogress(padapter))
-	{
-		DBG_8192C(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
-			FUNC_ADPT_ARG(padapter));
+	if (_TRUE == rtw_hal_sreset_inprogress(padapter)) {
+		RTW_INFO(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
+			 FUNC_ADPT_ARG(padapter));
 		return;
 	}
-#endif // DBG_CONFIG_ERROR_RESET
+#endif /* DBG_CONFIG_ERROR_RESET */
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if ((RT_MEDIA_DISCONNECT == mediaStatus) && (padapter->pbuddy_adapter))
-	{
-		PADAPTER pbuddy = padapter->pbuddy_adapter;
-		if (check_fwstate(&pbuddy->mlmepriv, WIFI_ASOC_STATE) == _TRUE)
+	if (RT_MEDIA_DISCONNECT == mediaStatus) {
+		if (rtw_mi_buddy_check_fwstate(padapter, WIFI_ASOC_STATE))
 			return;
 	}
-#endif // CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_CONCURRENT_MODE */
 
 	if ((RT_MEDIA_CONNECT == mediaStatus)
-		&& (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE))
-	{
+	    && (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE))
 		rtw_hal_set_hwreg(padapter, HW_VAR_DL_RSVD_PAGE, NULL);
-	}
 
 	hal_btcoex_MediaStatusNotify(padapter, mediaStatus);
 }
@@ -220,43 +218,45 @@ void rtw_btcoex_SuspendNotify(PADAPTER padapter, u8 state)
 void rtw_btcoex_HaltNotify(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE	pHalData;
+	u8 do_halt = 1;
 
 	pHalData = GET_HAL_DATA(padapter);
 	if (_FALSE == pHalData->EEPROMBluetoothCoexist)
-		return;
-
-	if (_FALSE == padapter->bup)
-	{
-		DBG_871X(FUNC_ADPT_FMT ": bup=%d Skip!\n",
-			FUNC_ADPT_ARG(padapter), padapter->bup);
+		do_halt = 0;
 
-		return;
+	if (_FALSE == padapter->bup) {
+		RTW_INFO(FUNC_ADPT_FMT ": bup=%d Skip!\n",
+			 FUNC_ADPT_ARG(padapter), padapter->bup);
+		do_halt = 0;
 	}
 
 	if (rtw_is_surprise_removed(padapter)) {
-		DBG_871X(FUNC_ADPT_FMT ": bSurpriseRemoved=%s Skip!\n",
-			FUNC_ADPT_ARG(padapter), rtw_is_surprise_removed(padapter)?"True":"False");
-
-		return;
+		RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=%s Skip!\n",
+			FUNC_ADPT_ARG(padapter), rtw_is_surprise_removed(padapter) ? "True" : "False");
+		do_halt = 0;
 	}
 
-	hal_btcoex_HaltNotify(padapter);
+	hal_btcoex_HaltNotify(padapter, do_halt);
 }
 
-void rtw_btcoex_ScoreBoardStatusNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
+void rtw_btcoex_switchband_notify(u8 under_scan, u8 band_type)
 {
-	PHAL_DATA_TYPE	pHalData;
+	hal_btcoex_switchband_notify(under_scan, band_type);
+}
 
-	pHalData = GET_HAL_DATA(padapter);
-	if (_FALSE == pHalData->EEPROMBluetoothCoexist)
-		return;
+void rtw_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length)
+{
+	hal_btcoex_WlFwDbgInfoNotify(padapter, tmpBuf, length);
+}
 
-	hal_btcoex_ScoreBoardStatusNotify(padapter, length, tmpBuf);
+void rtw_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id)
+{
+	hal_btcoex_rx_rate_change_notify(padapter, is_data_frame, rate_id);
 }
 
 void rtw_btcoex_SwitchBtTRxMask(PADAPTER padapter)
 {
-	hal_btcoex_SwitchBtTRxMask(padapter);	
+	hal_btcoex_SwitchBtTRxMask(padapter);
 }
 
 void rtw_btcoex_Switch(PADAPTER padapter, u8 enable)
@@ -278,13 +278,6 @@ void rtw_btcoex_Handler(PADAPTER padapter)
 	if (_FALSE == pHalData->EEPROMBluetoothCoexist)
 		return;
 
-#if defined(CONFIG_CONCURRENT_MODE)
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
-		return;
-#endif
-
-
-
 	hal_btcoex_Hanlder(padapter);
 }
 
@@ -318,13 +311,9 @@ u32 rtw_btcoex_GetAMPDUSize(PADAPTER padapter)
 void rtw_btcoex_SetManualControl(PADAPTER padapter, u8 manual)
 {
 	if (_TRUE == manual)
-	{
 		hal_btcoex_SetManualControl(padapter, _TRUE);
-	}
 	else
-	{
 		hal_btcoex_SetManualControl(padapter, _FALSE);
-	}
 }
 
 u8 rtw_btcoex_1Ant(PADAPTER padapter)
@@ -352,31 +341,6 @@ u8 rtw_btcoex_LpsVal(PADAPTER padapter)
 	return hal_btcoex_LpsVal(padapter);
 }
 
-void rtw_btcoex_SetBTCoexist(PADAPTER padapter, u8 bBtExist)
-{
-	hal_btcoex_SetBTCoexist(padapter, bBtExist);
-}
-
-void rtw_btcoex_SetChipType(PADAPTER padapter, u8 chipType)
-{
-	hal_btcoex_SetChipType(padapter, chipType);
-}
-
-void rtw_btcoex_SetPGAntNum(PADAPTER padapter, u8 antNum)
-{
-	hal_btcoex_SetPgAntNum(padapter, antNum);
-}
-
-u8 rtw_btcoex_GetPGAntNum(PADAPTER padapter)
-{
-	return hal_btcoex_GetPgAntNum(padapter);
-}
-
-void rtw_btcoex_SetSingleAntPath(PADAPTER padapter, u8 singleAntPath)
-{
-	hal_btcoex_SetSingleAntPath(padapter, singleAntPath);
-}
-
 u32 rtw_btcoex_GetRaMask(PADAPTER padapter)
 {
 	return hal_btcoex_GetRaMask(padapter);
@@ -412,9 +376,9 @@ u8 rtw_btcoex_IsBtLinkExist(PADAPTER padapter)
 	return hal_btcoex_IsBtLinkExist(padapter);
 }
 
-void rtw_btcoex_SetBtPatchVersion(PADAPTER padapter,u16 btHciVer, u16 btPatchVer)
+void rtw_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer)
 {
-	hal_btcoex_SetBtPatchVersion(padapter,btHciVer,btPatchVer);
+	hal_btcoex_SetBtPatchVersion(padapter, btHciVer, btPatchVer);
 }
 
 void rtw_btcoex_SetHciVersion(PADAPTER  padapter, u16 hciVersion)
@@ -422,19 +386,31 @@ void rtw_btcoex_SetHciVersion(PADAPTER  padapter, u16 hciVersion)
 	hal_btcoex_SetHciVersion(padapter, hciVersion);
 }
 
-void rtw_btcoex_StackUpdateProfileInfo(void) 
+void rtw_btcoex_StackUpdateProfileInfo(void)
 {
 	hal_btcoex_StackUpdateProfileInfo();
 }
 
-void rtw_btcoex_BTOffOnNotify(PADAPTER padapter, u8 bBTON)
+void rtw_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON)
+{
+	hal_btcoex_pta_off_on_notify(padapter, bBTON);
+}
+
+#ifdef CONFIG_RF4CE_COEXIST
+void rtw_btcoex_SetRf4ceLinkState(PADAPTER padapter, u8 state)
 {
-	hal_btcoex_BTOffOnNotify(padapter, bBTON);
+	hal_btcoex_set_rf4ce_link_state(state);
 }
 
-// ==================================================
-// Below Functions are called by BT-Coex
-// ==================================================
+u8 rtw_btcoex_GetRf4ceLinkState(PADAPTER padapter)
+{
+	return hal_btcoex_get_rf4ce_link_state();
+}
+#endif
+
+/* ==================================================
+ * Below Functions are called by BT-Coex
+ * ================================================== */
 void rtw_btcoex_rx_ampdu_apply(PADAPTER padapter)
 {
 	rtw_rx_ampdu_apply(padapter);
@@ -453,19 +429,20 @@ void rtw_btcoex_LPS_Enter(PADAPTER padapter)
 	rtw_set_ps_mode(padapter, PS_MODE_MIN, 0, lpsVal, "BTCOEX");
 }
 
-void rtw_btcoex_LPS_Leave(PADAPTER padapter)
+u8 rtw_btcoex_LPS_Leave(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrpriv;
 
 
 	pwrpriv = adapter_to_pwrctl(padapter);
 
-	if (pwrpriv->pwr_mode != PS_MODE_ACTIVE)
-	{
+	if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
 		rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "BTCOEX");
 		LPS_RF_ON_check(padapter, 100);
 		pwrpriv->bpower_saving = _FALSE;
 	}
+
+	return _TRUE;
 }
 
 u16 rtw_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data)
@@ -478,13 +455,69 @@ u16 rtw_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val)
 	return hal_btcoex_btreg_write(padapter, type, addr, val);
 }
 
+u8 rtw_btcoex_get_bt_coexist(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
-// ==================================================
-// Below Functions are BT-Coex socket related function
-// ==================================================
+	return pHalData->EEPROMBluetoothCoexist;
+}
+
+u8 rtw_btcoex_get_chip_type(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	return pHalData->EEPROMBluetoothType;
+}
+
+u8 rtw_btcoex_get_pg_ant_num(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	return pHalData->EEPROMBluetoothAntNum == Ant_x2 ? 2 : 1;
+}
+
+u8 rtw_btcoex_get_pg_single_ant_path(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	return pHalData->ant_path;
+}
+
+u8 rtw_btcoex_get_pg_rfe_type(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	return pHalData->rfe_type;
+}
+
+u8 rtw_btcoex_is_tfbga_package_type(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+#ifdef CONFIG_RTL8723B
+	if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA80)
+	    || (pHalData->PackageType == PACKAGE_TFBGA90))
+		return _TRUE;
+#endif
+
+	return _FALSE;
+}
+
+u8 rtw_btcoex_get_ant_div_cfg(PADAPTER padapter)
+{
+	PHAL_DATA_TYPE pHalData;
+
+	pHalData = GET_HAL_DATA(padapter);
+	
+	return (pHalData->AntDivCfg == 0) ? _FALSE : _TRUE;
+}
+
+/* ==================================================
+ * Below Functions are BT-Coex socket related function
+ * ================================================== */
 
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-_adapter *pbtcoexadapter = NULL;
+_adapter *pbtcoexadapter; /* = NULL; */ /* do not initialise globals to 0 or NULL */
 u8 rtw_btcoex_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)
 {
 	struct cmd_obj *ph2c;
@@ -493,23 +526,23 @@ u8 rtw_btcoex_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)
 	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
 	u8	res = _SUCCESS;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
 	if (pdrvextra_cmd_parm == NULL) {
-		rtw_mfree((u8*)ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
 		res = _FAIL;
 		goto exit;
 	}
 
 	btinfo = rtw_zmalloc(len);
 	if (btinfo == NULL) {
-		rtw_mfree((u8*)ph2c, sizeof(struct cmd_obj));
-		rtw_mfree((u8*)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
 		res = _FAIL;
 		goto exit;
 	}
@@ -529,40 +562,40 @@ exit:
 	return res;
 }
 
-u8 rtw_btcoex_send_event_to_BT(_adapter *padapter, u8 status,  u8 event_code, u8 opcode_low, u8 opcode_high,u8 *dbg_msg)
+u8 rtw_btcoex_send_event_to_BT(_adapter *padapter, u8 status,  u8 event_code, u8 opcode_low, u8 opcode_high, u8 *dbg_msg)
 {
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0,tx_event_length = 0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	
-	pEvent = (rtw_HCI_event*)(&localBuf[0]);
+
+	pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 	pEvent->EventCode = event_code;
-	pEvent->Data[0] = 0x1;	//packet #
+	pEvent->Data[0] = 0x1;	/* packet # */
 	pEvent->Data[1] = opcode_low;
 	pEvent->Data[2] = opcode_high;
 	len = len + 3;
 
-		// Return parameters starts from here
-	pRetPar = &pEvent->Data[len];		
-	pRetPar[0] = status;		//status
+	/* Return parameters starts from here */
+	pRetPar = &pEvent->Data[len];
+	pRetPar[0] = status;		/* status */
 
 	len++;
 	pEvent->Length = len;
 
-	//total tx event length + EventCode length + sizeof(length)
+	/* total tx event length + EventCode length + sizeof(length) */
 	tx_event_length = pEvent->Length + 2;
 #if 0
 	rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, dbg_msg);
-#endif		
+#endif
 	status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
-		
+
 	return status;
 }
 
-/* 
-Ref: 
+/*
+Ref:
 Realtek Wi-Fi Driver
 Host Controller Interface for
 Bluetooth 3.0 + HS V1.4 2013/02/07
@@ -573,8 +606,8 @@ Window team code & BT team code
 
 u8 rtw_btcoex_parse_BT_info_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 {
-	#define BT_INFO_LENGTH 8
-	
+#define BT_INFO_LENGTH 8
+
 	u8 curPollEnable = pcmd[0];
 	u8 curPollTime = pcmd[1];
 	u8 btInfoReason = pcmd[2];
@@ -583,358 +616,338 @@ u8 rtw_btcoex_parse_BT_info_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0,tx_event_length = 0;
+	u8	len = 0, tx_event_length = 0;
 	RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
 	rtw_HCI_event *pEvent;
 
-	/* DBG_871X("%s\n",__func__);
-	DBG_871X("current Poll Enable: %d, currrent Poll Time: %d\n",curPollEnable,curPollTime);
-	DBG_871X("BT Info reason: %d, BT Info length: %d\n",btInfoReason,btInfoLen);
-	DBG_871X("%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x\n"
+	/* RTW_INFO("%s\n",__func__);
+	RTW_INFO("current Poll Enable: %d, currrent Poll Time: %d\n",curPollEnable,curPollTime);
+	RTW_INFO("BT Info reason: %d, BT Info length: %d\n",btInfoReason,btInfoLen);
+	RTW_INFO("%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x\n"
 		,pcmd[4],pcmd[5],pcmd[6],pcmd[7],pcmd[8],pcmd[9],pcmd[10],pcmd[11]);*/
 
 	_rtw_memset(btinfo, 0, BT_INFO_LENGTH);
-	
+
 #if 1
-	if(BT_INFO_LENGTH != btInfoLen)
-	{
+	if (BT_INFO_LENGTH != btInfoLen) {
 		status = HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE;
-		DBG_871X("Error BT Info Length: %d\n",btInfoLen);
-		//return _FAIL;
-	}
-	else
+		RTW_INFO("Error BT Info Length: %d\n", btInfoLen);
+		/* return _FAIL; */
+	} else
 #endif
 	{
-		if(0x1 == btInfoReason || 0x2 == btInfoReason)
-		{
+		if (0x1 == btInfoReason || 0x2 == btInfoReason) {
 			_rtw_memcpy(btinfo, &pcmd[4], btInfoLen);
 			btinfo[0] = btInfoReason;
-			rtw_btcoex_btinfo_cmd(padapter,btinfo,btInfoLen);
-		}
-		else
-		{
-			DBG_871X("Other BT info reason\n");
-		}
+			rtw_btcoex_btinfo_cmd(padapter, btinfo, btInfoLen);
+		} else
+			RTW_INFO("Other BT info reason\n");
 	}
 
-	//send complete event to BT
+	/* send complete event to BT */
 	{
 
-		pEvent = (rtw_HCI_event*)(&localBuf[0]);
+		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_BT_INFO_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_INFO_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-			// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-			//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 #if 0
-		rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length,"BT_info_event");
-#endif		
+		rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT_info_event");
+#endif
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
-		
+
 		return status;
-			//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
 u8 rtw_btcoex_parse_BT_patch_ver_info_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 {
-	RTW_HCI_STATUS status=HCI_STATUS_SUCCESS;
-	u16		btPatchVer=0x0, btHciVer=0x0;
-	//u16		*pU2tmp;
-	
+	RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
+	u16		btPatchVer = 0x0, btHciVer = 0x0;
+	/* u16		*pU2tmp; */
+
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
 
-	btHciVer = pcmd[0] | pcmd[1]<<8;
-	btPatchVer = pcmd[2] | pcmd[3]<<8;
+	btHciVer = pcmd[0] | pcmd[1] << 8;
+	btPatchVer = pcmd[2] | pcmd[3] << 8;
 
 
-	DBG_871X("%s, cmd:%02x %02x %02x %02x\n",__func__, pcmd[0] ,pcmd[1] ,pcmd[2] ,pcmd[3]);
-	DBG_871X("%s, HCI Ver:%d, Patch Ver:%d\n",__func__, btHciVer,btPatchVer);
-	
-	rtw_btcoex_SetBtPatchVersion(padapter,btHciVer,btPatchVer);
+	RTW_INFO("%s, cmd:%02x %02x %02x %02x\n", __func__, pcmd[0] , pcmd[1] , pcmd[2] , pcmd[3]);
+	RTW_INFO("%s, HCI Ver:%d, Patch Ver:%d\n", __func__, btHciVer, btPatchVer);
 
+	rtw_btcoex_SetBtPatchVersion(padapter, btHciVer, btPatchVer);
 
-	//send complete event to BT
+
+	/* send complete event to BT */
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_BT_PATCH_VERSION_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_PATCH_VERSION_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 #if 0
-		rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length,"BT_patch_event");
+		rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT_patch_event");
 #endif
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
 u8 rtw_btcoex_parse_HCI_Ver_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 {
-	RTW_HCI_STATUS status=HCI_STATUS_SUCCESS;
-	u16 hciver = pcmd[0] | pcmd[1] <<8;
-	
+	RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
+	u16 hciver = pcmd[0] | pcmd[1] << 8;
+
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	
+
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
-	PBT_MGNT	pBtMgnt=&pcoex_info->BtMgnt;
+	PBT_MGNT	pBtMgnt = &pcoex_info->BtMgnt;
 	pBtMgnt->ExtConfig.HCIExtensionVer = hciver;
-	DBG_871X("%s, HCI Version: %d\n",__func__,pBtMgnt->ExtConfig.HCIExtensionVer);
-	if(pBtMgnt->ExtConfig.HCIExtensionVer  < 4)
-	{
+	RTW_INFO("%s, HCI Version: %d\n", __func__, pBtMgnt->ExtConfig.HCIExtensionVer);
+	if (pBtMgnt->ExtConfig.HCIExtensionVer  < 4) {
 		status = HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE;
-		DBG_871X("%s, Version = %d, HCI Version < 4\n",__func__,pBtMgnt->ExtConfig.HCIExtensionVer );
-	}
-	else
-	{
-		rtw_btcoex_SetHciVersion(padapter,hciver);
-	}
-	//send complete event to BT
+		RTW_INFO("%s, Version = %d, HCI Version < 4\n", __func__, pBtMgnt->ExtConfig.HCIExtensionVer);
+	} else
+		rtw_btcoex_SetHciVersion(padapter, hciver);
+	/* send complete event to BT */
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_EXTENSION_VERSION_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_EXTENSION_VERSION_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
-	
+
 }
 
 u8 rtw_btcoex_parse_WIFI_scan_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 {
-	RTW_HCI_STATUS status=HCI_STATUS_SUCCESS;
+	RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
 
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	
+
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
-	PBT_MGNT	pBtMgnt=&pcoex_info->BtMgnt;
-	pBtMgnt->ExtConfig.bEnableWifiScanNotify= pcmd[0];
-	DBG_871X("%s, bEnableWifiScanNotify: %d\n",__func__,pBtMgnt->ExtConfig.bEnableWifiScanNotify);
-	
-	//send complete event to BT
+	PBT_MGNT	pBtMgnt = &pcoex_info->BtMgnt;
+	pBtMgnt->ExtConfig.bEnableWifiScanNotify = pcmd[0];
+	RTW_INFO("%s, bEnableWifiScanNotify: %d\n", __func__, pBtMgnt->ExtConfig.bEnableWifiScanNotify);
+
+	/* send complete event to BT */
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_ENABLE_WIFI_SCAN_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_ENABLE_WIFI_SCAN_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
 u8 rtw_btcoex_parse_HCI_link_status_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 {
-	RTW_HCI_STATUS	status=HCI_STATUS_SUCCESS;
-	struct bt_coex_info	*pcoex_info=&padapter->coex_info;
-	PBT_MGNT	pBtMgnt=&pcoex_info->BtMgnt;
-	//PBT_DBG		pBtDbg=&padapter->MgntInfo.BtInfo.BtDbg;
-	u8		i, numOfHandle=0, numOfAcl=0;
+	RTW_HCI_STATUS	status = HCI_STATUS_SUCCESS;
+	struct bt_coex_info	*pcoex_info = &padapter->coex_info;
+	PBT_MGNT	pBtMgnt = &pcoex_info->BtMgnt;
+	/* PBT_DBG		pBtDbg=&padapter->MgntInfo.BtInfo.BtDbg; */
+	u8		i, numOfHandle = 0, numOfAcl = 0;
 	u16		conHandle;
 	u8		btProfile, btCoreSpec, linkRole;
 	u8		*pTriple;
 
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	
-	//pBtDbg->dbgHciInfo.hciCmdCntLinkStatusNotify++;
-	//RT_DISP_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "LinkStatusNotify, Hex Data :\n", 
-	//		&pHciCmd->Data[0], pHciCmd->Length);
 
-	DBG_871X("BTLinkStatusNotify\n");
+	/* pBtDbg->dbgHciInfo.hciCmdCntLinkStatusNotify++; */
+	/* RT_DISP_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "LinkStatusNotify, Hex Data :\n",  */
+	/*		&pHciCmd->Data[0], pHciCmd->Length); */
+
+	RTW_INFO("BTLinkStatusNotify\n");
 
-	// Current only RTL8723 support this command.
-	//pBtMgnt->bSupportProfile = TRUE;
+	/* Current only RTL8723 support this command. */
+	/* pBtMgnt->bSupportProfile = TRUE; */
 	pBtMgnt->bSupportProfile = _FALSE;
 
 	pBtMgnt->ExtConfig.NumberOfACL = 0;
 	pBtMgnt->ExtConfig.NumberOfSCO = 0;
-	
+
 	numOfHandle = pcmd[0];
-	//RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, ("numOfHandle = 0x%x\n", numOfHandle));
-	//RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCIExtensionVer = %d\n", pBtMgnt->ExtConfig.HCIExtensionVer));
-	DBG_871X("numOfHandle = 0x%x\n", numOfHandle);
-	DBG_871X("HCIExtensionVer = %d\n", pBtMgnt->ExtConfig.HCIExtensionVer);
-	
+	/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, ("numOfHandle = 0x%x\n", numOfHandle)); */
+	/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCIExtensionVer = %d\n", pBtMgnt->ExtConfig.HCIExtensionVer)); */
+	RTW_INFO("numOfHandle = 0x%x\n", numOfHandle);
+	RTW_INFO("HCIExtensionVer = %d\n", pBtMgnt->ExtConfig.HCIExtensionVer);
+
 	pTriple = &pcmd[1];
-	for(i=0; i<numOfHandle; i++)
-	{	
-		if(pBtMgnt->ExtConfig.HCIExtensionVer < 1)
-		{
+	for (i = 0; i < numOfHandle; i++) {
+		if (pBtMgnt->ExtConfig.HCIExtensionVer < 1) {
 			conHandle = *((u8 *)&pTriple[0]);
 			btProfile = pTriple[2];
 			btCoreSpec = pTriple[3];
-			if(BT_PROFILE_SCO == btProfile)
-			{
+			if (BT_PROFILE_SCO == btProfile)
 				pBtMgnt->ExtConfig.NumberOfSCO++;
-			}
-			else
-			{
-				pBtMgnt->ExtConfig.NumberOfACL++;			
+			else {
+				pBtMgnt->ExtConfig.NumberOfACL++;
 				pBtMgnt->ExtConfig.aclLink[i].ConnectHandle = conHandle;
 				pBtMgnt->ExtConfig.aclLink[i].BTProfile = btProfile;
 				pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec = btCoreSpec;
 			}
-			//RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, 
-			//	("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d\n",
-			//		conHandle, btProfile, btCoreSpec));
-			DBG_871X("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d\n", conHandle, btProfile, btCoreSpec);
+			/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, */
+			/*	("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d\n", */
+			/*		conHandle, btProfile, btCoreSpec)); */
+			RTW_INFO("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d\n", conHandle, btProfile, btCoreSpec);
 			pTriple += 4;
-		}
-		else if(pBtMgnt->ExtConfig.HCIExtensionVer >= 1)
-		{
+		} else if (pBtMgnt->ExtConfig.HCIExtensionVer >= 1) {
 			conHandle = *((pu2Byte)&pTriple[0]);
 			btProfile = pTriple[2];
 			btCoreSpec = pTriple[3];
 			linkRole = pTriple[4];
-			if(BT_PROFILE_SCO == btProfile)
-			{
+			if (BT_PROFILE_SCO == btProfile)
 				pBtMgnt->ExtConfig.NumberOfSCO++;
-			}
-			else
-			{
-				pBtMgnt->ExtConfig.NumberOfACL++;			
+			else {
+				pBtMgnt->ExtConfig.NumberOfACL++;
 				pBtMgnt->ExtConfig.aclLink[i].ConnectHandle = conHandle;
 				pBtMgnt->ExtConfig.aclLink[i].BTProfile = btProfile;
 				pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec = btCoreSpec;
 				pBtMgnt->ExtConfig.aclLink[i].linkRole = linkRole;
 			}
-			//RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, 
-			DBG_871X("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d, LinkRole=%d\n",
-				conHandle, btProfile, btCoreSpec, linkRole);
+			/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, */
+			RTW_INFO("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d, LinkRole=%d\n",
+				 conHandle, btProfile, btCoreSpec, linkRole);
 			pTriple += 5;
-		}	
+		}
 	}
 	rtw_btcoex_StackUpdateProfileInfo();
 
-		//send complete event to BT
+	/* send complete event to BT */
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_LINK_STATUS_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_LINK_STATUS_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
-	
-	
+
+
 }
 
 u8 rtw_btcoex_parse_HCI_BT_coex_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 {
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	RTW_HCI_STATUS	status=HCI_STATUS_SUCCESS;
+	RTW_HCI_STATUS	status = HCI_STATUS_SUCCESS;
 
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_BT_COEX_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_COEX_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
@@ -942,73 +955,72 @@ u8 rtw_btcoex_parse_HCI_BT_operation_notify_cmd(_adapter *padapter, u8 *pcmd, u1
 {
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	RTW_HCI_STATUS	status=HCI_STATUS_SUCCESS;
-
-	DBG_871X("%s, OP code: %d\n",__func__,pcmd[0]);
-
-	switch(pcmd[0])
-	{
-		case HCI_BT_OP_NONE:
-			DBG_871X("[bt operation] : Operation None!!\n");
-			break;
-		case HCI_BT_OP_INQUIRY_START:
-			DBG_871X("[bt operation] : Inquiry start!!\n");
-			break;
-		case HCI_BT_OP_INQUIRY_FINISH:
-			DBG_871X("[bt operation] : Inquiry finished!!\n");
-			break;
-		case HCI_BT_OP_PAGING_START:
-			DBG_871X("[bt operation] : Paging is started!!\n");
-			break;
-		case HCI_BT_OP_PAGING_SUCCESS:
-			DBG_871X("[bt operation] : Paging complete successfully!!\n");
-			break;
-		case HCI_BT_OP_PAGING_UNSUCCESS:
-			DBG_871X("[bt operation] : Paging complete unsuccessfully!!\n");
-			break;
-		case HCI_BT_OP_PAIRING_START:
-			DBG_871X("[bt operation] : Pairing start!!\n");
-			break;
-		case HCI_BT_OP_PAIRING_FINISH:
-			DBG_871X("[bt operation] : Pairing finished!!\n");
-			break;
-		case HCI_BT_OP_BT_DEV_ENABLE:
-			DBG_871X("[bt operation] : BT Device is enabled!!\n");
-			break;
-		case HCI_BT_OP_BT_DEV_DISABLE:
-			DBG_871X("[bt operation] : BT Device is disabled!!\n");
-			break;
-		default:
-			DBG_871X("[bt operation] : Unknown, error!!\n");
-			break;
+	RTW_HCI_STATUS	status = HCI_STATUS_SUCCESS;
+
+	RTW_INFO("%s, OP code: %d\n", __func__, pcmd[0]);
+
+	switch (pcmd[0]) {
+	case HCI_BT_OP_NONE:
+		RTW_INFO("[bt operation] : Operation None!!\n");
+		break;
+	case HCI_BT_OP_INQUIRY_START:
+		RTW_INFO("[bt operation] : Inquiry start!!\n");
+		break;
+	case HCI_BT_OP_INQUIRY_FINISH:
+		RTW_INFO("[bt operation] : Inquiry finished!!\n");
+		break;
+	case HCI_BT_OP_PAGING_START:
+		RTW_INFO("[bt operation] : Paging is started!!\n");
+		break;
+	case HCI_BT_OP_PAGING_SUCCESS:
+		RTW_INFO("[bt operation] : Paging complete successfully!!\n");
+		break;
+	case HCI_BT_OP_PAGING_UNSUCCESS:
+		RTW_INFO("[bt operation] : Paging complete unsuccessfully!!\n");
+		break;
+	case HCI_BT_OP_PAIRING_START:
+		RTW_INFO("[bt operation] : Pairing start!!\n");
+		break;
+	case HCI_BT_OP_PAIRING_FINISH:
+		RTW_INFO("[bt operation] : Pairing finished!!\n");
+		break;
+	case HCI_BT_OP_BT_DEV_ENABLE:
+		RTW_INFO("[bt operation] : BT Device is enabled!!\n");
+		break;
+	case HCI_BT_OP_BT_DEV_DISABLE:
+		RTW_INFO("[bt operation] : BT Device is disabled!!\n");
+		break;
+	default:
+		RTW_INFO("[bt operation] : Unknown, error!!\n");
+		break;
 	}
 
-			//send complete event to BT
+	/* send complete event to BT */
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_BT_OPERATION_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_OPERATION_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
@@ -1016,68 +1028,68 @@ u8 rtw_btcoex_parse_BT_AFH_MAP_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdl
 {
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	RTW_HCI_STATUS	status=HCI_STATUS_SUCCESS;
+	RTW_HCI_STATUS	status = HCI_STATUS_SUCCESS;
 
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_BT_AFH_MAP_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_AFH_MAP_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
 u8 rtw_btcoex_parse_BT_register_val_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
 {
-	
+
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	RTW_HCI_STATUS	status=HCI_STATUS_SUCCESS;
+	RTW_HCI_STATUS	status = HCI_STATUS_SUCCESS;
 
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_BT_REGISTER_VALUE_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_REGISTER_VALUE_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
@@ -1085,33 +1097,33 @@ u8 rtw_btcoex_parse_HCI_BT_abnormal_notify_cmd(_adapter *padapter, u8 *pcmd, u16
 {
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	RTW_HCI_STATUS	status=HCI_STATUS_SUCCESS;
+	RTW_HCI_STATUS	status = HCI_STATUS_SUCCESS;
 
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_BT_ABNORMAL_NOTIFY, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_ABNORMAL_NOTIFY, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
@@ -1119,125 +1131,123 @@ u8 rtw_btcoex_parse_HCI_query_RF_status_cmd(_adapter *padapter, u8 *pcmd, u16 cm
 {
 	u8 localBuf[6] = "";
 	u8 *pRetPar;
-	u8	len=0, tx_event_length =0;
+	u8	len = 0, tx_event_length = 0;
 	rtw_HCI_event *pEvent;
-	RTW_HCI_STATUS	status=HCI_STATUS_SUCCESS;
+	RTW_HCI_STATUS	status = HCI_STATUS_SUCCESS;
 
 	{
 		pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
 
 		pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-		pEvent->Data[0] = 0x1;	//packet #
+		pEvent->Data[0] = 0x1;	/* packet # */
 		pEvent->Data[1] = HCIOPCODELOW(HCI_QUERY_RF_STATUS, OGF_EXTENSION);
 		pEvent->Data[2] = HCIOPCODEHIGHT(HCI_QUERY_RF_STATUS, OGF_EXTENSION);
 		len = len + 3;
 
-		// Return parameters starts from here
-		pRetPar = &pEvent->Data[len];		
-		pRetPar[0] = status;		//status
+		/* Return parameters starts from here */
+		pRetPar = &pEvent->Data[len];
+		pRetPar[0] = status;		/* status */
 
 		len++;
 		pEvent->Length = len;
 
-		//total tx event length + EventCode length + sizeof(length)
+		/* total tx event length + EventCode length + sizeof(length) */
 		tx_event_length = pEvent->Length + 2;
 
 		status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 		return status;
-		//bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2);
+		/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
 	}
 }
 
 /*****************************************
 * HCI cmd format :
-*| 15 - 0						|	
+*| 15 - 0						|
 *| OPcode (OCF|OGF<<10)		|
 *| 15 - 8		|7 - 0			|
-*|Cmd para 	|Cmd para Length	|
+*|Cmd para	|Cmd para Length	|
 *|Cmd para......				|
 ******************************************/
 
-//bit 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15
-//	 |	OCF			             |	   OGF       |
-void rtw_btcoex_parse_hci_extend_cmd(_adapter *padapter, u8 *pcmd, u16 len,const u16 hci_OCF)
-{
+/* bit 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15
+ *	 |	OCF			             |	   OGF       | */
+void rtw_btcoex_parse_hci_extend_cmd(_adapter *padapter, u8 *pcmd, u16 len, const u16 hci_OCF)
+{
+
+	RTW_INFO("%s: OCF: %x\n", __func__, hci_OCF);
+	switch (hci_OCF) {
+	case HCI_EXTENSION_VERSION_NOTIFY:
+		RTW_INFO("HCI_EXTENSION_VERSION_NOTIFY\n");
+		rtw_btcoex_parse_HCI_Ver_notify_cmd(padapter, pcmd, len);
+		break;
+	case HCI_LINK_STATUS_NOTIFY:
+		RTW_INFO("HCI_LINK_STATUS_NOTIFY\n");
+		rtw_btcoex_parse_HCI_link_status_notify_cmd(padapter, pcmd, len);
+		break;
+	case HCI_BT_OPERATION_NOTIFY:
+		/* only for 8723a 2ant */
+		RTW_INFO("HCI_BT_OPERATION_NOTIFY\n");
+		rtw_btcoex_parse_HCI_BT_operation_notify_cmd(padapter, pcmd, len);
+		/*  */
+		break;
+	case HCI_ENABLE_WIFI_SCAN_NOTIFY:
+		RTW_INFO("HCI_ENABLE_WIFI_SCAN_NOTIFY\n");
+		rtw_btcoex_parse_WIFI_scan_notify_cmd(padapter, pcmd, len);
+		break;
+	case HCI_QUERY_RF_STATUS:
+		/* only for 8723b 2ant */
+		RTW_INFO("HCI_QUERY_RF_STATUS\n");
+		rtw_btcoex_parse_HCI_query_RF_status_cmd(padapter, pcmd, len);
+		break;
+	case HCI_BT_ABNORMAL_NOTIFY:
+		RTW_INFO("HCI_BT_ABNORMAL_NOTIFY\n");
+		rtw_btcoex_parse_HCI_BT_abnormal_notify_cmd(padapter, pcmd, len);
+		break;
+	case HCI_BT_INFO_NOTIFY:
+		RTW_INFO("HCI_BT_INFO_NOTIFY\n");
+		rtw_btcoex_parse_BT_info_notify_cmd(padapter, pcmd, len);
+		break;
+	case HCI_BT_COEX_NOTIFY:
+		RTW_INFO("HCI_BT_COEX_NOTIFY\n");
+		rtw_btcoex_parse_HCI_BT_coex_notify_cmd(padapter, pcmd, len);
+		break;
+	case HCI_BT_PATCH_VERSION_NOTIFY:
+		RTW_INFO("HCI_BT_PATCH_VERSION_NOTIFY\n");
+		rtw_btcoex_parse_BT_patch_ver_info_cmd(padapter, pcmd, len);
+		break;
+	case HCI_BT_AFH_MAP_NOTIFY:
+		RTW_INFO("HCI_BT_AFH_MAP_NOTIFY\n");
+		rtw_btcoex_parse_BT_AFH_MAP_notify_cmd(padapter, pcmd, len);
+		break;
+	case HCI_BT_REGISTER_VALUE_NOTIFY:
+		RTW_INFO("HCI_BT_REGISTER_VALUE_NOTIFY\n");
+		rtw_btcoex_parse_BT_register_val_notify_cmd(padapter, pcmd, len);
+		break;
+	default:
+		RTW_INFO("ERROR!!! Unknown OCF: %x\n", hci_OCF);
+		break;
 
-	DBG_871X("%s: OCF: %x\n",__func__,hci_OCF);
-	switch(hci_OCF)
-	{
-		case HCI_EXTENSION_VERSION_NOTIFY:
-			DBG_871X("HCI_EXTENSION_VERSION_NOTIFY\n");
-			rtw_btcoex_parse_HCI_Ver_notify_cmd(padapter,pcmd, len);
-			break;
-		case HCI_LINK_STATUS_NOTIFY:
-			DBG_871X("HCI_LINK_STATUS_NOTIFY\n");
-			rtw_btcoex_parse_HCI_link_status_notify_cmd(padapter,pcmd, len);
-			break;
-		case HCI_BT_OPERATION_NOTIFY:
-			// only for 8723a 2ant
-			DBG_871X("HCI_BT_OPERATION_NOTIFY\n");
-			rtw_btcoex_parse_HCI_BT_operation_notify_cmd(padapter,pcmd, len);
-			//
-			break;
-		case HCI_ENABLE_WIFI_SCAN_NOTIFY:
-			DBG_871X("HCI_ENABLE_WIFI_SCAN_NOTIFY\n");
-			rtw_btcoex_parse_WIFI_scan_notify_cmd(padapter,pcmd, len);
-			break;
-		case HCI_QUERY_RF_STATUS:
-			// only for 8723b 2ant
-			DBG_871X("HCI_QUERY_RF_STATUS\n");
-			rtw_btcoex_parse_HCI_query_RF_status_cmd(padapter,pcmd, len);
-			break;
-		case HCI_BT_ABNORMAL_NOTIFY:
-			DBG_871X("HCI_BT_ABNORMAL_NOTIFY\n");
-			rtw_btcoex_parse_HCI_BT_abnormal_notify_cmd(padapter,pcmd, len);
-			break;
-		case HCI_BT_INFO_NOTIFY:
-			DBG_871X("HCI_BT_INFO_NOTIFY\n");
-			rtw_btcoex_parse_BT_info_notify_cmd(padapter,pcmd, len);
-			break;
-		case HCI_BT_COEX_NOTIFY:
-			DBG_871X("HCI_BT_COEX_NOTIFY\n");
-			rtw_btcoex_parse_HCI_BT_coex_notify_cmd(padapter,pcmd, len);
-			break;
-		case HCI_BT_PATCH_VERSION_NOTIFY:
-			DBG_871X("HCI_BT_PATCH_VERSION_NOTIFY\n");
-			rtw_btcoex_parse_BT_patch_ver_info_cmd(padapter,pcmd, len);
-			break;
-		case HCI_BT_AFH_MAP_NOTIFY:
-			DBG_871X("HCI_BT_AFH_MAP_NOTIFY\n");
-			rtw_btcoex_parse_BT_AFH_MAP_notify_cmd(padapter,pcmd, len);
-			break;
-		case HCI_BT_REGISTER_VALUE_NOTIFY:
-			DBG_871X("HCI_BT_REGISTER_VALUE_NOTIFY\n");
-			rtw_btcoex_parse_BT_register_val_notify_cmd(padapter,pcmd, len);
-			break;
-		default:
-			DBG_871X("ERROR!!! Unknown OCF: %x\n",hci_OCF);
-			break;
-			
 	}
 }
 
 void rtw_btcoex_parse_hci_cmd(_adapter *padapter, u8 *pcmd, u16 len)
 {
-	u16 opcode = pcmd[0] | pcmd[1]<<8;
+	u16 opcode = pcmd[0] | pcmd[1] << 8;
 	u16 hci_OGF = HCI_OGF(opcode);
 	u16 hci_OCF = HCI_OCF(opcode);
-	u8 cmdlen = len -3;
+	u8 cmdlen = len - 3;
 	u8 pare_len = pcmd[2];
 
-	DBG_871X("%s OGF: %x,OCF: %x\n", __func__, hci_OGF, hci_OCF);
-	switch(hci_OGF)
-	{
-		case OGF_EXTENSION:
-			DBG_871X("HCI_EXTENSION_CMD_OGF\n");
-			rtw_btcoex_parse_hci_extend_cmd(padapter, &pcmd[3], cmdlen, hci_OCF);
-			break;
-		default:
-			DBG_871X("Other OGF: %x\n",hci_OGF);
-			break;
+	RTW_INFO("%s OGF: %x,OCF: %x\n", __func__, hci_OGF, hci_OCF);
+	switch (hci_OGF) {
+	case OGF_EXTENSION:
+		RTW_INFO("HCI_EXTENSION_CMD_OGF\n");
+		rtw_btcoex_parse_hci_extend_cmd(padapter, &pcmd[3], cmdlen, hci_OCF);
+		break;
+	default:
+		RTW_INFO("Other OGF: %x\n", hci_OGF);
+		break;
 	}
 }
 
@@ -1250,30 +1260,30 @@ u16 rtw_btcoex_parse_recv_data(u8 *msg, u8 msg_size)
 	u8 cmp_msg5[32] = attend_req;
 	u8 cmp_msg6[32] = invite_rsp;
 	u8 res = OTHER;
-	
+
 	if (_rtw_memcmp(cmp_msg1, msg, msg_size) == _TRUE) {
-		/*DBG_871X("%s, msg:%s\n",__func__,msg);*/
+		/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
 		res = RX_ATTEND_ACK;
 	} else if (_rtw_memcmp(cmp_msg2, msg, msg_size) == _TRUE) {
-		/*DBG_871X("%s, msg:%s\n",__func__,msg);*/
+		/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
 		res = RX_LEAVE_ACK;
 	} else if (_rtw_memcmp(cmp_msg3, msg, msg_size) == _TRUE) {
-		/*DBG_871X("%s, msg:%s\n",__func__,msg);*/
+		/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
 		res = RX_BT_LEAVE;
 	} else if (_rtw_memcmp(cmp_msg4, msg, msg_size) == _TRUE) {
-		/*DBG_871X("%s, msg:%s\n",__func__,msg);*/
+		/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
 		res = RX_INVITE_REQ;
-	} else if (_rtw_memcmp(cmp_msg5, msg, msg_size) == _TRUE) {
+	} else if (_rtw_memcmp(cmp_msg5, msg, msg_size) == _TRUE)
 		res = RX_ATTEND_REQ;
-	} else if (_rtw_memcmp(cmp_msg6, msg, msg_size) == _TRUE) {
+	else if (_rtw_memcmp(cmp_msg6, msg, msg_size) == _TRUE)
 		res = RX_INVITE_RSP;
-	} else {
-		/*DBG_871X("%s, %s\n", __func__, msg);*/
+	else {
+		/*RTW_INFO("%s, %s\n", __func__, msg);*/
 		res = OTHER;
 	}
-	
-	/*DBG_871X("%s, res:%d\n", __func__, res);*/
-	
+
+	/*RTW_INFO("%s, res:%d\n", __func__, res);*/
+
 	return res;
 }
 
@@ -1292,11 +1302,11 @@ void rtw_btcoex_recvmsgbysocket(void *data)
 	struct bt_coex_info *pcoex_info = NULL;
 	struct sock *sk = NULL;
 	struct sk_buff *skb = NULL;
-	
-	/*DBG_871X("%s\n",__func__);*/
+
+	/*RTW_INFO("%s\n",__func__);*/
 
 	if (pbtcoexadapter == NULL) {
-		DBG_871X("%s: btcoexadapter NULL!\n", __func__);
+		RTW_INFO("%s: btcoexadapter NULL!\n", __func__);
 		return;
 	}
 
@@ -1304,123 +1314,123 @@ void rtw_btcoex_recvmsgbysocket(void *data)
 	sk = pcoex_info->sk_store;
 
 	if (sk == NULL) {
-		DBG_871X("%s: critical error when receive socket data!\n", __func__);
+		RTW_INFO("%s: critical error when receive socket data!\n", __func__);
 		return;
 	}
-	
+
 	len = skb_queue_len(&sk->sk_receive_queue);
 	while (len > 0) {
 		skb = skb_dequeue(&sk->sk_receive_queue);
 
 		/*important: cut the udp header from skb->data! header length is 8 byte*/
-		recv_length = skb->len-8;
+		recv_length = skb->len - 8;
 		_rtw_memset(recv_data, 0, sizeof(recv_data));
-		_rtw_memcpy(recv_data, skb->data+8, recv_length);
-		
+		_rtw_memcpy(recv_data, skb->data + 8, recv_length);
+
 		parse_res = rtw_btcoex_parse_recv_data(recv_data, recv_length);
-/*
+#if 0
 		if (RX_ATTEND_ACK == parse_res) {
-			//attend ack 
+			/* attend ack */
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_ATTEND_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			RTW_INFO("RX_ATTEND_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 		} else if (RX_ATTEND_REQ == parse_res) {
-			//attend req from BT 
+			/* attend req from BT */
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_BT_ATTEND_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			RTW_INFO("RX_BT_ATTEND_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 			rtw_btcoex_sendmsgbysocket(pbtcoexadapter, attend_ack, sizeof(attend_ack), _FALSE);
 		} else if (RX_INVITE_REQ == parse_res) {
-			//invite req from BT
+			/* invite req from BT */
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_INVITE_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			RTW_INFO("RX_INVITE_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 			rtw_btcoex_sendmsgbysocket(pbtcoexadapter, invite_rsp, sizeof(invite_rsp), _FALSE);
 		} else if (RX_INVITE_RSP == parse_res) {
-			//invite rsp
+			/* invite rsp */
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_INVITE_RSP!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			RTW_INFO("RX_INVITE_RSP!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 		} else if (RX_LEAVE_ACK == parse_res) {
-			//mean BT know wifi  will leave
+			/* mean BT know wifi  will leave */
 			pcoex_info->BT_attend = _FALSE;
-			DBG_871X("RX_LEAVE_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);			
+			RTW_INFO("RX_LEAVE_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 		} else if (RX_BT_LEAVE == parse_res) {
-			//BT leave
-			rtw_btcoex_sendmsgbysocket(pbtcoexadapter, leave_ack, sizeof(leave_ack), _FALSE); // no ack
+			/* BT leave */
+			rtw_btcoex_sendmsgbysocket(pbtcoexadapter, leave_ack, sizeof(leave_ack), _FALSE); /*  no ack */
 			pcoex_info->BT_attend = _FALSE;
-			DBG_871X("RX_BT_LEAVE!sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);			
+			RTW_INFO("RX_BT_LEAVE!sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 		} else {
-			//todo: check if recv data are really hci cmds
+			/* todo: check if recv data are really hci cmds */
 			if (_TRUE == pcoex_info->BT_attend)
 				rtw_btcoex_parse_hci_cmd(pbtcoexadapter, recv_data, recv_length);
 		}
-*/
+#endif
 		switch (parse_res) {
 		case RX_ATTEND_ACK:
 			/* attend ack */
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_ATTEND_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
-			rtw_btcoex_BTOffOnNotify(pbtcoexadapter, pcoex_info->BT_attend);
+			RTW_INFO("RX_ATTEND_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
 			break;
 
 		case RX_ATTEND_REQ:
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_BT_ATTEND_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			RTW_INFO("RX_BT_ATTEND_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 			rtw_btcoex_sendmsgbysocket(pbtcoexadapter, attend_ack, sizeof(attend_ack), _FALSE);
-			rtw_btcoex_BTOffOnNotify(pbtcoexadapter, pcoex_info->BT_attend);
+			rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
 			break;
 
 		case RX_INVITE_REQ:
 			/* invite req from BT */
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_INVITE_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			RTW_INFO("RX_INVITE_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 			rtw_btcoex_sendmsgbysocket(pbtcoexadapter, invite_rsp, sizeof(invite_rsp), _FALSE);
-			rtw_btcoex_BTOffOnNotify(pbtcoexadapter, pcoex_info->BT_attend);
+			rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
 			break;
 
 		case RX_INVITE_RSP:
-			 /*invite rsp*/
+			/*invite rsp*/
 			pcoex_info->BT_attend = _TRUE;
-			DBG_871X("RX_INVITE_RSP!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
-			rtw_btcoex_BTOffOnNotify(pbtcoexadapter, pcoex_info->BT_attend);
+			RTW_INFO("RX_INVITE_RSP!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
 			break;
 
 		case RX_LEAVE_ACK:
 			/* mean BT know wifi  will leave */
 			pcoex_info->BT_attend = _FALSE;
-			DBG_871X("RX_LEAVE_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
-			rtw_btcoex_BTOffOnNotify(pbtcoexadapter, pcoex_info->BT_attend);
+			RTW_INFO("RX_LEAVE_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
 			break;
 
 		case RX_BT_LEAVE:
 			/* BT leave */
 			rtw_btcoex_sendmsgbysocket(pbtcoexadapter, leave_ack, sizeof(leave_ack), _FALSE); /* no ack */
 			pcoex_info->BT_attend = _FALSE;
-			DBG_871X("RX_BT_LEAVE!sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);	
-			rtw_btcoex_BTOffOnNotify(pbtcoexadapter, pcoex_info->BT_attend);
+			RTW_INFO("RX_BT_LEAVE!sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+			rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
 			break;
 
 		default:
 			if (_TRUE == pcoex_info->BT_attend)
 				rtw_btcoex_parse_hci_cmd(pbtcoexadapter, recv_data, recv_length);
 			else
-				DBG_871X("ERROR!! BT is UP\n");
+				RTW_INFO("ERROR!! BT is UP\n");
 			break;
 
 		}
-		
+
 		len--;
 		kfree_skb(skb);
 	}
 }
 
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0))
-void rtw_btcoex_recvmsg_init(struct sock *sk_in, s32 bytes)
+	void rtw_btcoex_recvmsg_init(struct sock *sk_in, s32 bytes)
 #else
-void rtw_btcoex_recvmsg_init(struct sock *sk_in)
+	void rtw_btcoex_recvmsg_init(struct sock *sk_in)
 #endif
 {
 	struct bt_coex_info *pcoex_info = NULL;
-	
+
 	if (pbtcoexadapter == NULL) {
-		DBG_871X("%s: btcoexadapter NULL\n", __func__);
+		RTW_INFO("%s: btcoexadapter NULL\n", __func__);
 		return;
 	}
 	pcoex_info = &pbtcoexadapter->coex_info;
@@ -1428,31 +1438,31 @@ void rtw_btcoex_recvmsg_init(struct sock *sk_in)
 	if (pcoex_info->btcoex_wq != NULL)
 		queue_delayed_work(pcoex_info->btcoex_wq, &pcoex_info->recvmsg_work, 0);
 	else
-		DBG_871X("%s: BTCOEX workqueue NULL\n", __func__);
+		RTW_INFO("%s: BTCOEX workqueue NULL\n", __func__);
 }
 
 u8 rtw_btcoex_sendmsgbysocket(_adapter *padapter, u8 *msg, u8 msg_size, bool force)
 {
-	u8 error; 
-	struct msghdr	udpmsg; 
-	mm_segment_t	oldfs; 
-	struct iovec	iov; 
+	u8 error;
+	struct msghdr	udpmsg;
+	mm_segment_t	oldfs;
+	struct iovec	iov;
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
 
-	/* DBG_871X("%s: msg:%s, force:%s\n", __func__, msg, force == _TRUE?"TRUE":"FALSE"); */
+	/* RTW_INFO("%s: msg:%s, force:%s\n", __func__, msg, force == _TRUE?"TRUE":"FALSE"); */
 	if (_FALSE == force) {
 		if (_FALSE == pcoex_info->BT_attend) {
-			DBG_871X("TX Blocked: WiFi-BT disconnected\n");			
+			RTW_INFO("TX Blocked: WiFi-BT disconnected\n");
 			return _FAIL;
 		}
 	}
-		
-	iov.iov_base	 = (void *)msg; 
-	iov.iov_len	 = msg_size; 
-	udpmsg.msg_name	 = &pcoex_info->bt_sockaddr; 
-	udpmsg.msg_namelen	= sizeof(struct sockaddr_in); 
+
+	iov.iov_base	 = (void *)msg;
+	iov.iov_len	 = msg_size;
+	udpmsg.msg_name	 = &pcoex_info->bt_sockaddr;
+	udpmsg.msg_namelen	= sizeof(struct sockaddr_in);
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
-    /* referece:sock_xmit in kernel code
+	/* referece:sock_xmit in kernel code
 	 * WRITE for sock_sendmsg, READ for sock_recvmsg
 	 * third parameter for msg_iovlen
 	 * last parameter for iov_len
@@ -1462,10 +1472,10 @@ u8 rtw_btcoex_sendmsgbysocket(_adapter *padapter, u8 *msg, u8 msg_size, bool for
 	udpmsg.msg_iov	 = &iov;
 	udpmsg.msg_iovlen	= 1;
 #endif
-	udpmsg.msg_control	= NULL; 
-	udpmsg.msg_controllen = 0; 
-	udpmsg.msg_flags	= MSG_DONTWAIT | MSG_NOSIGNAL; 
-	oldfs = get_fs(); 
+	udpmsg.msg_control	= NULL;
+	udpmsg.msg_controllen = 0;
+	udpmsg.msg_flags	= MSG_DONTWAIT | MSG_NOSIGNAL;
+	oldfs = get_fs();
 	set_fs(KERNEL_DS);
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
@@ -1473,9 +1483,9 @@ u8 rtw_btcoex_sendmsgbysocket(_adapter *padapter, u8 *msg, u8 msg_size, bool for
 #else
 	error = sock_sendmsg(pcoex_info->udpsock, &udpmsg, msg_size);
 #endif
-	set_fs(oldfs); 
+	set_fs(oldfs);
 	if (error < 0) {
-		DBG_871X("Error when sendimg msg, error:%d\n", error); 
+		RTW_INFO("Error when sendimg msg, error:%d\n", error);
 		return _FAIL;
 	} else
 		return _SUCCESS;
@@ -1483,53 +1493,53 @@ u8 rtw_btcoex_sendmsgbysocket(_adapter *padapter, u8 *msg, u8 msg_size, bool for
 
 u8 rtw_btcoex_create_kernel_socket(_adapter *padapter)
 {
-	s8 kernel_socket_err; 
+	s8 kernel_socket_err;
 	u8 tx_msg[255] = attend_req;
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
 	s32 sock_reuse = 1;
 	u8 status = _FAIL;
-	
-	DBG_871X("%s CONNECT_PORT %d\n", __func__, CONNECT_PORT);
+
+	RTW_INFO("%s CONNECT_PORT %d\n", __func__, CONNECT_PORT);
 
 	if (NULL == pcoex_info) {
-		DBG_871X("coex_info: NULL\n"); 
+		RTW_INFO("coex_info: NULL\n");
 		status =  _FAIL;
 	}
-	
-	kernel_socket_err = sock_create(PF_INET, SOCK_DGRAM, 0, &pcoex_info->udpsock); 
-    
-	if (kernel_socket_err < 0) { 
-		DBG_871X("Error during creation of socket error:%d\n", kernel_socket_err); 
-		status = _FAIL;	
+
+	kernel_socket_err = sock_create(PF_INET, SOCK_DGRAM, 0, &pcoex_info->udpsock);
+
+	if (kernel_socket_err < 0) {
+		RTW_INFO("Error during creation of socket error:%d\n", kernel_socket_err);
+		status = _FAIL;
 	} else {
-		_rtw_memset(&(pcoex_info->wifi_sockaddr), 0, sizeof(pcoex_info->wifi_sockaddr)); 
-		pcoex_info->wifi_sockaddr.sin_family = AF_INET; 
-		pcoex_info->wifi_sockaddr.sin_port = htons(CONNECT_PORT); 
+		_rtw_memset(&(pcoex_info->wifi_sockaddr), 0, sizeof(pcoex_info->wifi_sockaddr));
+		pcoex_info->wifi_sockaddr.sin_family = AF_INET;
+		pcoex_info->wifi_sockaddr.sin_port = htons(CONNECT_PORT);
 		pcoex_info->wifi_sockaddr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
 
-		_rtw_memset(&(pcoex_info->bt_sockaddr), 0, sizeof(pcoex_info->bt_sockaddr)); 
-		pcoex_info->bt_sockaddr.sin_family = AF_INET; 
-		pcoex_info->bt_sockaddr.sin_port = htons(CONNECT_PORT_BT); 
+		_rtw_memset(&(pcoex_info->bt_sockaddr), 0, sizeof(pcoex_info->bt_sockaddr));
+		pcoex_info->bt_sockaddr.sin_family = AF_INET;
+		pcoex_info->bt_sockaddr.sin_port = htons(CONNECT_PORT_BT);
 		pcoex_info->bt_sockaddr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
 
 		pcoex_info->sk_store = NULL;
-		kernel_socket_err = pcoex_info->udpsock->ops->bind(pcoex_info->udpsock, (struct sockaddr *)&pcoex_info->wifi_sockaddr, 
-			sizeof(pcoex_info->wifi_sockaddr)); 
-		if (kernel_socket_err == 0) {	
-			DBG_871X("binding socket success\n"); 
+		kernel_socket_err = pcoex_info->udpsock->ops->bind(pcoex_info->udpsock, (struct sockaddr *)&pcoex_info->wifi_sockaddr,
+				    sizeof(pcoex_info->wifi_sockaddr));
+		if (kernel_socket_err == 0) {
+			RTW_INFO("binding socket success\n");
 			pcoex_info->udpsock->sk->sk_data_ready = rtw_btcoex_recvmsg_init;
 			pcoex_info->sock_open |=  KERNEL_SOCKET_OK;
 			pcoex_info->BT_attend = _FALSE;
-			DBG_871X("WIFI sending attend_req\n"); 
+			RTW_INFO("WIFI sending attend_req\n");
 			rtw_btcoex_sendmsgbysocket(padapter, attend_req, sizeof(attend_req), _TRUE);
 			status = _SUCCESS;
-		} else { 
+		} else {
 			pcoex_info->BT_attend = _FALSE;
 			sock_release(pcoex_info->udpsock); /* bind fail release socket */
-			DBG_871X("Error binding socket: %d\n", kernel_socket_err); 
+			RTW_INFO("Error binding socket: %d\n", kernel_socket_err);
 			status = _FAIL;
-		} 
-			
+		}
+
 	}
 
 	return status;
@@ -1539,40 +1549,40 @@ void rtw_btcoex_close_kernel_socket(_adapter *padapter)
 {
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
 	if (pcoex_info->sock_open & KERNEL_SOCKET_OK) {
-		DBG_871X("release kernel socket\n");
+		RTW_INFO("release kernel socket\n");
 		sock_release(pcoex_info->udpsock);
-		pcoex_info->sock_open &= ~(KERNEL_SOCKET_OK);	
+		pcoex_info->sock_open &= ~(KERNEL_SOCKET_OK);
 		if (_TRUE == pcoex_info->BT_attend)
 			pcoex_info->BT_attend = _FALSE;
-		
-		DBG_871X("sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
+
+		RTW_INFO("sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
 	}
 }
 
 void rtw_btcoex_init_socket(_adapter *padapter)
 {
-		
+
 	u8 is_invite = _FALSE;
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
-	DBG_871X("%s\n", __func__);
+	RTW_INFO("%s\n", __func__);
 	if (_FALSE == pcoex_info->is_exist) {
-		_rtw_memset(pcoex_info,0,sizeof(struct bt_coex_info));
+		_rtw_memset(pcoex_info, 0, sizeof(struct bt_coex_info));
 		pcoex_info->btcoex_wq = create_workqueue("BTCOEX");
 		INIT_DELAYED_WORK(&pcoex_info->recvmsg_work,
-			  (void *)rtw_btcoex_recvmsgbysocket);
+				  (void *)rtw_btcoex_recvmsgbysocket);
 		pbtcoexadapter = padapter;
 		/* We expect BT is off if BT don't send ack to wifi */
-		DBG_871X("We expect BT is off if BT send ack to wifi\n");
-		rtw_btcoex_BTOffOnNotify(pbtcoexadapter, _FALSE);
-		if (rtw_btcoex_create_kernel_socket(padapter) == _SUCCESS) {
+		RTW_INFO("We expect BT is off if BT send ack to wifi\n");
+		rtw_btcoex_pta_off_on_notify(pbtcoexadapter, _FALSE);
+		if (rtw_btcoex_create_kernel_socket(padapter) == _SUCCESS)
 			pcoex_info->is_exist = _TRUE;
-		} else {
+		else {
 			pcoex_info->is_exist = _FALSE;
 			pbtcoexadapter = NULL;
 		}
-		
-		DBG_871X("%s: pbtcoexadapter:%p, coex_info->is_exist: %s\n"
-			, __func__, pbtcoexadapter, pcoex_info->is_exist == _TRUE?"TRUE":"FALSE");
+
+		RTW_INFO("%s: pbtcoexadapter:%p, coex_info->is_exist: %s\n"
+			, __func__, pbtcoexadapter, pcoex_info->is_exist == _TRUE ? "TRUE" : "FALSE");
 	}
 }
 
@@ -1580,9 +1590,9 @@ void rtw_btcoex_close_socket(_adapter *padapter)
 {
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
 
-	DBG_871X("%s--coex_info->is_exist: %s, pcoex_info->BT_attend:%s\n"
-		, __func__, pcoex_info->is_exist == _TRUE?"TRUE":"FALSE", pcoex_info->BT_attend == _TRUE?"TRUE":"FALSE");
-	
+	RTW_INFO("%s--coex_info->is_exist: %s, pcoex_info->BT_attend:%s\n"
+		, __func__, pcoex_info->is_exist == _TRUE ? "TRUE" : "FALSE", pcoex_info->BT_attend == _TRUE ? "TRUE" : "FALSE");
+
 	if (_TRUE == pcoex_info->is_exist) {
 		if (_TRUE == pcoex_info->BT_attend) {
 			/*inform BT wifi leave*/
@@ -1603,40 +1613,38 @@ void rtw_btcoex_close_socket(_adapter *padapter)
 
 void rtw_btcoex_dump_tx_msg(u8 *tx_msg, u8 len, u8 *msg_name)
 {
-	u8 	i = 0;
-	DBG_871X("======> Msg name: %s\n", msg_name);
-	for(i=0;i<len;i++)
-	{
+	u8	i = 0;
+	RTW_INFO("======> Msg name: %s\n", msg_name);
+	for (i = 0; i < len; i++)
 		printk("%02x ", tx_msg[i]);
-	}
 	printk("\n");
-	DBG_871X("Msg name: %s <======\n", msg_name);
+	RTW_INFO("Msg name: %s <======\n", msg_name);
 }
 
 /* Porting from Windows team */
 void rtw_btcoex_SendEventExtBtCoexControl(PADAPTER padapter, u8 bNeedDbgRsp, u8 dataLen, void *pData)
 {
-	u8			len=0, tx_event_length = 0;
+	u8			len = 0, tx_event_length = 0;
 	u8 			localBuf[32] = "";
 	u8			*pRetPar;
-	u8			opCode=0;
-	u8			*pInBuf=(pu1Byte)pData;
+	u8			opCode = 0;
+	u8			*pInBuf = (pu1Byte)pData;
 	u8			*pOpCodeContent;
 	rtw_HCI_event *pEvent;
 
-	opCode = pInBuf[0];	
+	opCode = pInBuf[0];
 
-	DBG_871X("%s, OPCode:%02x\n",__func__,opCode);
+	RTW_INFO("%s, OPCode:%02x\n", __func__, opCode);
 
-	pEvent = (rtw_HCI_event*)(&localBuf[0]);
+	pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
-	//len += bthci_ExtensionEventHeaderRtk(&localBuf[0], 
-	//	HCI_EVENT_EXT_BT_COEX_CONTROL);
+	/* len += bthci_ExtensionEventHeaderRtk(&localBuf[0], */
+	/*	HCI_EVENT_EXT_BT_COEX_CONTROL); */
 	pEvent->EventCode = HCI_EVENT_EXTENSION_RTK;
-	pEvent->Data[0] = HCI_EVENT_EXT_BT_COEX_CONTROL;	//extension event code
-	len ++;
-	
-	// Return parameters starts from here
+	pEvent->Data[0] = HCI_EVENT_EXT_BT_COEX_CONTROL;	/* extension event code */
+	len++;
+
+	/* Return parameters starts from here */
 	pRetPar = &pEvent->Data[len];
 	_rtw_memcpy(&pRetPar[0], pData, dataLen);
 
@@ -1644,7 +1652,7 @@ void rtw_btcoex_SendEventExtBtCoexControl(PADAPTER padapter, u8 bNeedDbgRsp, u8
 
 	pEvent->Length = len;
 
-	//total tx event length + EventCode length + sizeof(length)
+	/* total tx event length + EventCode length + sizeof(length) */
 	tx_event_length = pEvent->Length + 2;
 #if 0
 	rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT COEX CONTROL", _FALSE);
@@ -1658,28 +1666,27 @@ void rtw_btcoex_SendEventExtBtInfoControl(PADAPTER padapter, u8 dataLen, void *p
 {
 	rtw_HCI_event *pEvent;
 	u8			*pRetPar;
-	u8			len=0, tx_event_length = 0;
+	u8			len = 0, tx_event_length = 0;
 	u8 			localBuf[32] = "";
 
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
 	PBT_MGNT		pBtMgnt = &pcoex_info->BtMgnt;
-	
-	/* DBG_871X("%s\n",__func__);*/
-	if(pBtMgnt->ExtConfig.HCIExtensionVer < 4) //not support
-	{
-		DBG_871X("ERROR: HCIExtensionVer = %d, HCIExtensionVer<4 !!!!\n",pBtMgnt->ExtConfig.HCIExtensionVer);
+
+	/* RTW_INFO("%s\n",__func__);*/
+	if (pBtMgnt->ExtConfig.HCIExtensionVer < 4) { /* not support */
+		RTW_INFO("ERROR: HCIExtensionVer = %d, HCIExtensionVer<4 !!!!\n", pBtMgnt->ExtConfig.HCIExtensionVer);
 		return;
 	}
 
 	pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
-	//len += bthci_ExtensionEventHeaderRtk(&localBuf[0], 
-	//		HCI_EVENT_EXT_BT_INFO_CONTROL);
+	/* len += bthci_ExtensionEventHeaderRtk(&localBuf[0], */
+	/*		HCI_EVENT_EXT_BT_INFO_CONTROL); */
 	pEvent->EventCode = HCI_EVENT_EXTENSION_RTK;
-	pEvent->Data[0] = HCI_EVENT_EXT_BT_INFO_CONTROL;		//extension event code
-	len ++;
+	pEvent->Data[0] = HCI_EVENT_EXT_BT_INFO_CONTROL;		/* extension event code */
+	len++;
 
-	// Return parameters starts from here
+	/* Return parameters starts from here */
 	pRetPar = &pEvent->Data[len];
 	_rtw_memcpy(&pRetPar[0], pData, dataLen);
 
@@ -1687,18 +1694,18 @@ void rtw_btcoex_SendEventExtBtInfoControl(PADAPTER padapter, u8 dataLen, void *p
 
 	pEvent->Length = len;
 
-	//total tx event length + EventCode length + sizeof(length)
+	/* total tx event length + EventCode length + sizeof(length) */
 	tx_event_length = pEvent->Length + 2;
 #if 0
 	rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT INFO CONTROL");
 #endif
 	rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
-	
+
 }
 
 void rtw_btcoex_SendScanNotify(PADAPTER padapter, u8 scanType)
 {
-	u8	len=0, tx_event_length=0;
+	u8	len = 0, tx_event_length = 0;
 	u8 	localBuf[7] = "";
 	u8	*pRetPar;
 	u8	*pu1Temp;
@@ -1706,34 +1713,52 @@ void rtw_btcoex_SendScanNotify(PADAPTER padapter, u8 scanType)
 	struct bt_coex_info *pcoex_info = &padapter->coex_info;
 	PBT_MGNT		pBtMgnt = &pcoex_info->BtMgnt;
 
-//	if(!pBtMgnt->BtOperationOn)
-//		return;
-		
+	/*	if(!pBtMgnt->BtOperationOn)
+	 *		return; */
+
 	pEvent = (rtw_HCI_event *)(&localBuf[0]);
 
-//	len += bthci_ExtensionEventHeaderRtk(&localBuf[0], 
-//			HCI_EVENT_EXT_WIFI_SCAN_NOTIFY);
+	/*	len += bthci_ExtensionEventHeaderRtk(&localBuf[0],
+	 *			HCI_EVENT_EXT_WIFI_SCAN_NOTIFY); */
 
 	pEvent->EventCode = HCI_EVENT_EXTENSION_RTK;
-	pEvent->Data[0] = HCI_EVENT_EXT_WIFI_SCAN_NOTIFY;		//extension event code
-	len ++;
+	pEvent->Data[0] = HCI_EVENT_EXT_WIFI_SCAN_NOTIFY;		/* extension event code */
+	len++;
 
-	// Return parameters starts from here
-	//pRetPar = &PPacketIrpEvent->Data[len];
-	//pu1Temp = (u8 *)&pRetPar[0];
-	//*pu1Temp = scanType;
+	/* Return parameters starts from here */
+	/* pRetPar = &PPacketIrpEvent->Data[len]; */
+	/* pu1Temp = (u8 *)&pRetPar[0]; */
+	/* *pu1Temp = scanType; */
 	pEvent->Data[len] = scanType;
 	len += 1;
 
 	pEvent->Length = len;
 
-	//total tx event length + EventCode length + sizeof(length)
+	/* total tx event length + EventCode length + sizeof(length) */
 	tx_event_length = pEvent->Length + 2;
 #if 0
 	rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "WIFI SCAN OPERATION");
-#endif	
+#endif
 	rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
 }
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+#endif /* CONFIG_BT_COEXIST */
+
+void rtw_btcoex_set_ant_info(PADAPTER padapter)
+{
+#ifdef CONFIG_BT_COEXIST
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+
+	if (hal->EEPROMBluetoothCoexist == _TRUE) {
+		u8 bMacPwrCtrlOn = _FALSE;
+
+		rtw_btcoex_AntInfoSetting(padapter);
+		rtw_hal_get_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
+		if (bMacPwrCtrlOn == _TRUE)
+			rtw_btcoex_PowerOnSetting(padapter);
+	}
+	else
+#endif
+		rtw_btcoex_wifionly_AntInfoSetting(padapter);
+}
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_btcoex_wifionly.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_btcoex_wifionly.c
new file mode 100644
index 000000000000..104df9de5962
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_btcoex_wifionly.c
@@ -0,0 +1,43 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_btcoex_wifionly.h>
+#include <hal_data.h>
+
+void rtw_btcoex_wifionly_switchband_notify(PADAPTER padapter)
+{
+	hal_btcoex_wifionly_switchband_notify(padapter);
+}
+
+void rtw_btcoex_wifionly_scan_notify(PADAPTER padapter)
+{
+	hal_btcoex_wifionly_scan_notify(padapter);
+}
+
+void rtw_btcoex_wifionly_hw_config(PADAPTER padapter)
+{
+	hal_btcoex_wifionly_hw_config(padapter);
+}
+
+void rtw_btcoex_wifionly_initialize(PADAPTER padapter)
+{
+	hal_btcoex_wifionly_initlizevariables(padapter);
+}
+
+void rtw_btcoex_wifionly_AntInfoSetting(PADAPTER padapter)
+{
+	hal_btcoex_wifionly_AntInfoSetting(padapter);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_cmd.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_cmd.c
index b91e13708669..bd6f9f0546bd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_cmd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_cmd.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_CMD_C_
 
 #include <drv_types.h>
@@ -31,133 +27,177 @@ Caller and the rtw_cmd_thread can protect cmd_q by spin_lock.
 No irqsave is necessary.
 */
 
-sint	_rtw_init_cmd_priv (struct	cmd_priv *pcmdpriv)
+sint	_rtw_init_cmd_priv(struct	cmd_priv *pcmdpriv)
 {
-	sint res=_SUCCESS;
-	
-_func_enter_;	
+	sint res = _SUCCESS;
+
 
 	_rtw_init_sema(&(pcmdpriv->cmd_queue_sema), 0);
-	//_rtw_init_sema(&(pcmdpriv->cmd_done_sema), 0);
-	_rtw_init_sema(&(pcmdpriv->terminate_cmdthread_sema), 0);
-	
-	
+	/* _rtw_init_sema(&(pcmdpriv->cmd_done_sema), 0); */
+	_rtw_init_sema(&(pcmdpriv->start_cmdthread_sema), 0);
+
 	_rtw_init_queue(&(pcmdpriv->cmd_queue));
-	
-	//allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf
-	
+
+	/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
+
 	pcmdpriv->cmd_seq = 1;
-	
+
 	pcmdpriv->cmd_allocated_buf = rtw_zmalloc(MAX_CMDSZ + CMDBUFF_ALIGN_SZ);
-	
-	if (pcmdpriv->cmd_allocated_buf == NULL){
-		res= _FAIL;
+
+	if (pcmdpriv->cmd_allocated_buf == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	
-	pcmdpriv->cmd_buf = pcmdpriv->cmd_allocated_buf  +  CMDBUFF_ALIGN_SZ - ( (SIZE_PTR)(pcmdpriv->cmd_allocated_buf) & (CMDBUFF_ALIGN_SZ-1));
-		
+
+	pcmdpriv->cmd_buf = pcmdpriv->cmd_allocated_buf  +  CMDBUFF_ALIGN_SZ - ((SIZE_PTR)(pcmdpriv->cmd_allocated_buf) & (CMDBUFF_ALIGN_SZ - 1));
+
 	pcmdpriv->rsp_allocated_buf = rtw_zmalloc(MAX_RSPSZ + 4);
-	
-	if (pcmdpriv->rsp_allocated_buf == NULL){
-		res= _FAIL;
+
+	if (pcmdpriv->rsp_allocated_buf == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	
-	pcmdpriv->rsp_buf = pcmdpriv->rsp_allocated_buf  +  4 - ( (SIZE_PTR)(pcmdpriv->rsp_allocated_buf) & 3);
+
+	pcmdpriv->rsp_buf = pcmdpriv->rsp_allocated_buf  +  4 - ((SIZE_PTR)(pcmdpriv->rsp_allocated_buf) & 3);
 
 	pcmdpriv->cmd_issued_cnt = pcmdpriv->cmd_done_cnt = pcmdpriv->rsp_cnt = 0;
 
 	_rtw_mutex_init(&pcmdpriv->sctx_mutex);
 exit:
-	
-_func_exit_;	  
+
 
 	return res;
-	
-}	
+
+}
 
 #ifdef CONFIG_C2H_WK
-static void c2h_wk_callback(_workitem *work);
-#endif
+static void c2h_wk_callback(_workitem *work)
+{
+	struct evt_priv *evtpriv = container_of(work, struct evt_priv, c2h_wk);
+	_adapter *adapter = container_of(evtpriv, _adapter, evtpriv);
+	u8 *c2h_evt;
+	c2h_id_filter direct_hdl_filter = rtw_hal_c2h_id_handle_directly;
+	u8 id, seq, plen;
+	u8 *payload;
+
+	evtpriv->c2h_wk_alive = _TRUE;
+
+	while (!rtw_cbuf_empty(evtpriv->c2h_queue)) {
+		c2h_evt = (u8 *)rtw_cbuf_pop(evtpriv->c2h_queue);
+		if (c2h_evt != NULL) {
+			/* This C2H event is read, clear it */
+			c2h_evt_clear(adapter);
+		} else {
+			c2h_evt = (u8 *)rtw_malloc(C2H_REG_LEN);
+			if (c2h_evt == NULL) {
+				rtw_warn_on(1);
+				continue;
+			}
+
+			/* This C2H event is not read, read & clear now */
+			if (rtw_hal_c2h_evt_read(adapter, c2h_evt) != _SUCCESS) {
+				rtw_mfree(c2h_evt, C2H_REG_LEN);
+				continue;
+			}
+		}
+
+		/* Special pointer to trigger c2h_evt_clear only */
+		if ((void *)c2h_evt == (void *)evtpriv)
+			continue;
+
+		if (!rtw_hal_c2h_valid(adapter, c2h_evt)
+			|| rtw_hal_c2h_reg_hdr_parse(adapter, c2h_evt, &id, &seq, &plen, &payload) != _SUCCESS
+		) {
+			rtw_mfree(c2h_evt, C2H_REG_LEN);
+			continue;
+		}
+
+		if (direct_hdl_filter(adapter, id, seq, plen, payload) == _TRUE) {
+			/* Handle directly */
+			rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
+			rtw_mfree(c2h_evt, C2H_REG_LEN);
+		} else {
+			/* Enqueue into cmd_thread for others */
+			rtw_c2h_reg_wk_cmd(adapter, c2h_evt);
+			rtw_mfree(c2h_evt, C2H_REG_LEN);
+		}
+	}
+
+	evtpriv->c2h_wk_alive = _FALSE;
+}
+#endif /* CONFIG_C2H_WK */
+
 sint _rtw_init_evt_priv(struct evt_priv *pevtpriv)
 {
-	sint res=_SUCCESS;
+	sint res = _SUCCESS;
 
-_func_enter_;	
 
 #ifdef CONFIG_H2CLBK
 	_rtw_init_sema(&(pevtpriv->lbkevt_done), 0);
 	pevtpriv->lbkevt_limit = 0;
 	pevtpriv->lbkevt_num = 0;
-	pevtpriv->cmdevt_parm = NULL;		
-#endif		
-	
-	//allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf
+	pevtpriv->cmdevt_parm = NULL;
+#endif
+
+	/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
 	ATOMIC_SET(&pevtpriv->event_seq, 0);
 	pevtpriv->evt_done_cnt = 0;
 
 #ifdef CONFIG_EVENT_THREAD_MODE
 
 	_rtw_init_sema(&(pevtpriv->evt_notify), 0);
-	_rtw_init_sema(&(pevtpriv->terminate_evtthread_sema), 0);
 
-	pevtpriv->evt_allocated_buf = rtw_zmalloc(MAX_EVTSZ + 4);	
-	if (pevtpriv->evt_allocated_buf == NULL){
-		res= _FAIL;
+	pevtpriv->evt_allocated_buf = rtw_zmalloc(MAX_EVTSZ + 4);
+	if (pevtpriv->evt_allocated_buf == NULL) {
+		res = _FAIL;
 		goto exit;
-		}
+	}
 	pevtpriv->evt_buf = pevtpriv->evt_allocated_buf  +  4 - ((unsigned int)(pevtpriv->evt_allocated_buf) & 3);
-	
-		
+
+
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	pevtpriv->allocated_c2h_mem = rtw_zmalloc(C2H_MEM_SZ +4); 
-	
-	if (pevtpriv->allocated_c2h_mem == NULL){
-		res= _FAIL;
+	pevtpriv->allocated_c2h_mem = rtw_zmalloc(C2H_MEM_SZ + 4);
+
+	if (pevtpriv->allocated_c2h_mem == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
 	pevtpriv->c2h_mem = pevtpriv->allocated_c2h_mem +  4\
-	- ( (u32)(pevtpriv->allocated_c2h_mem) & 3);
+			    - ((u32)(pevtpriv->allocated_c2h_mem) & 3);
 #ifdef PLATFORM_OS_XP
-	pevtpriv->pc2h_mdl= IoAllocateMdl((u8 *)pevtpriv->c2h_mem, C2H_MEM_SZ , FALSE, FALSE, NULL);
-	
-	if(pevtpriv->pc2h_mdl == NULL){
-		res= _FAIL;
+	pevtpriv->pc2h_mdl = IoAllocateMdl((u8 *)pevtpriv->c2h_mem, C2H_MEM_SZ , FALSE, FALSE, NULL);
+
+	if (pevtpriv->pc2h_mdl == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 	MmBuildMdlForNonPagedPool(pevtpriv->pc2h_mdl);
 #endif
-#endif //end of CONFIG_SDIO_HCI
+#endif /* end of CONFIG_SDIO_HCI */
 
 	_rtw_init_queue(&(pevtpriv->evt_queue));
 
-exit:	
+exit:
 
-#endif //end of CONFIG_EVENT_THREAD_MODE
+#endif /* end of CONFIG_EVENT_THREAD_MODE */
 
 #ifdef CONFIG_C2H_WK
 	_init_workitem(&pevtpriv->c2h_wk, c2h_wk_callback, NULL);
 	pevtpriv->c2h_wk_alive = _FALSE;
-	pevtpriv->c2h_queue = rtw_cbuf_alloc(C2H_QUEUE_MAX_LEN+1);
+	pevtpriv->c2h_queue = rtw_cbuf_alloc(C2H_QUEUE_MAX_LEN + 1);
 #endif
 
-_func_exit_;		 
 
 	return res;
 }
 
-void _rtw_free_evt_priv (struct	evt_priv *pevtpriv)
+void _rtw_free_evt_priv(struct	evt_priv *pevtpriv)
 {
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("+_rtw_free_evt_priv \n"));
 
 #ifdef CONFIG_EVENT_THREAD_MODE
 	_rtw_free_sema(&(pevtpriv->evt_notify));
-	_rtw_free_sema(&(pevtpriv->terminate_evtthread_sema));
-
 
 	if (pevtpriv->evt_allocated_buf)
 		rtw_mfree(pevtpriv->evt_allocated_buf, MAX_EVTSZ + 4);
@@ -165,50 +205,45 @@ _func_enter_;
 
 #ifdef CONFIG_C2H_WK
 	_cancel_workitem_sync(&pevtpriv->c2h_wk);
-	while(pevtpriv->c2h_wk_alive)
+	while (pevtpriv->c2h_wk_alive)
 		rtw_msleep_os(10);
 
 	while (!rtw_cbuf_empty(pevtpriv->c2h_queue)) {
 		void *c2h;
-		if ((c2h = rtw_cbuf_pop(pevtpriv->c2h_queue)) != NULL
-			&& c2h != (void *)pevtpriv) {
+		c2h = rtw_cbuf_pop(pevtpriv->c2h_queue);
+		if (c2h != NULL && c2h != (void *)pevtpriv)
 			rtw_mfree(c2h, 16);
-		}
 	}
 	rtw_cbuf_free(pevtpriv->c2h_queue);
 #endif
 
-	RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("-_rtw_free_evt_priv \n"));
 
-_func_exit_;	  	
 
 }
 
-void _rtw_free_cmd_priv (struct	cmd_priv *pcmdpriv)
+void _rtw_free_cmd_priv(struct	cmd_priv *pcmdpriv)
 {
-_func_enter_;
 
-	if(pcmdpriv){
+	if (pcmdpriv) {
 		_rtw_spinlock_free(&(pcmdpriv->cmd_queue.lock));
 		_rtw_free_sema(&(pcmdpriv->cmd_queue_sema));
-		//_rtw_free_sema(&(pcmdpriv->cmd_done_sema));
-		_rtw_free_sema(&(pcmdpriv->terminate_cmdthread_sema));
+		/* _rtw_free_sema(&(pcmdpriv->cmd_done_sema)); */
+		_rtw_free_sema(&(pcmdpriv->start_cmdthread_sema));
 
 		if (pcmdpriv->cmd_allocated_buf)
 			rtw_mfree(pcmdpriv->cmd_allocated_buf, MAX_CMDSZ + CMDBUFF_ALIGN_SZ);
-		
+
 		if (pcmdpriv->rsp_allocated_buf)
 			rtw_mfree(pcmdpriv->rsp_allocated_buf, MAX_RSPSZ + 4);
 
 		_rtw_mutex_free(&pcmdpriv->sctx_mutex);
 	}
-_func_exit_;		
 }
 
 /*
 Calling Context:
 
-rtw_enqueue_cmd can only be called between kernel thread, 
+rtw_enqueue_cmd can only be called between kernel thread,
 since only spin_lock is used.
 
 ISR/Call-Back functions can't call this sub-function.
@@ -222,62 +257,59 @@ sint _rtw_enqueue_cmd(_queue *queue, struct cmd_obj *obj, bool to_head)
 {
 	_irqL irqL;
 
-_func_enter_;
 
 	if (obj == NULL)
 		goto exit;
 
-	//_enter_critical_bh(&queue->lock, &irqL);
-	_enter_critical(&queue->lock, &irqL);	
+	/* _enter_critical_bh(&queue->lock, &irqL); */
+	_enter_critical(&queue->lock, &irqL);
 
 	if (to_head)
 		rtw_list_insert_head(&obj->list, &queue->queue);
 	else
 		rtw_list_insert_tail(&obj->list, &queue->queue);
 
-	#ifdef DBG_CMD_QUEUE
-	if(dump_cmd_id){
-		printk("%s===> cmdcode:0x%02x\n",__FUNCTION__,obj->cmdcode);
-		if(obj->cmdcode == GEN_CMD_CODE(_Set_MLME_EVT)){
-			if(obj->parmbuf){
+#ifdef DBG_CMD_QUEUE
+	if (dump_cmd_id) {
+		printk("%s===> cmdcode:0x%02x\n", __FUNCTION__, obj->cmdcode);
+		if (obj->cmdcode == GEN_CMD_CODE(_Set_MLME_EVT)) {
+			if (obj->parmbuf) {
 				struct C2HEvent_Header *pc2h_evt_hdr = (struct C2HEvent_Header *)(obj->parmbuf);
-				printk("pc2h_evt_hdr->ID:0x%02x(%d)\n",pc2h_evt_hdr->ID,pc2h_evt_hdr->ID);
+				printk("pc2h_evt_hdr->ID:0x%02x(%d)\n", pc2h_evt_hdr->ID, pc2h_evt_hdr->ID);
 			}
 		}
-		if(obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)){
-			if(obj->parmbuf){
-				struct drvextra_cmd_parm *pdrvextra_cmd_parm =(struct drvextra_cmd_parm*)(obj->parmbuf);
-				printk("pdrvextra_cmd_parm->ec_id:0x%02x\n",pdrvextra_cmd_parm->ec_id);
+		if (obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
+			if (obj->parmbuf) {
+				struct drvextra_cmd_parm *pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)(obj->parmbuf);
+				printk("pdrvextra_cmd_parm->ec_id:0x%02x\n", pdrvextra_cmd_parm->ec_id);
 			}
 		}
-	}	
-	
-	if (queue->queue.prev->next != &queue->queue)
-	{
-		DBG_871X("[%d] head %p, tail %p, tail->prev->next %p[tail], tail->next %p[head]\n", __LINE__,
-            &queue->queue, queue->queue.prev, queue->queue.prev->prev->next, queue->queue.prev->next);
-		
-		DBG_871X("==========%s============\n",__FUNCTION__);
-		DBG_871X("head:%p,obj_addr:%p\n",&queue->queue,obj);
-		DBG_871X("padapter: %p\n",obj->padapter);
-		DBG_871X("cmdcode: 0x%02x\n",obj->cmdcode);
-		DBG_871X("res: %d\n",obj->res);
-		DBG_871X("parmbuf: %p\n",obj->parmbuf);
-		DBG_871X("cmdsz: %d\n",obj->cmdsz);
-		DBG_871X("rsp: %p\n",obj->rsp);
-		DBG_871X("rspsz: %d\n",obj->rspsz);
-		DBG_871X("sctx: %p\n",obj->sctx);
-		DBG_871X("list->next: %p\n",obj->list.next);
-		DBG_871X("list->prev: %p\n",obj->list.prev);
-	}
-	#endif //DBG_CMD_QUEUE
-	
-	//_exit_critical_bh(&queue->lock, &irqL);	
+	}
+
+	if (queue->queue.prev->next != &queue->queue) {
+		RTW_INFO("[%d] head %p, tail %p, tail->prev->next %p[tail], tail->next %p[head]\n", __LINE__,
+			&queue->queue, queue->queue.prev, queue->queue.prev->prev->next, queue->queue.prev->next);
+
+		RTW_INFO("==========%s============\n", __FUNCTION__);
+		RTW_INFO("head:%p,obj_addr:%p\n", &queue->queue, obj);
+		RTW_INFO("padapter: %p\n", obj->padapter);
+		RTW_INFO("cmdcode: 0x%02x\n", obj->cmdcode);
+		RTW_INFO("res: %d\n", obj->res);
+		RTW_INFO("parmbuf: %p\n", obj->parmbuf);
+		RTW_INFO("cmdsz: %d\n", obj->cmdsz);
+		RTW_INFO("rsp: %p\n", obj->rsp);
+		RTW_INFO("rspsz: %d\n", obj->rspsz);
+		RTW_INFO("sctx: %p\n", obj->sctx);
+		RTW_INFO("list->next: %p\n", obj->list.next);
+		RTW_INFO("list->prev: %p\n", obj->list.prev);
+	}
+#endif /* DBG_CMD_QUEUE */
+
+	/* _exit_critical_bh(&queue->lock, &irqL);	 */
 	_exit_critical(&queue->lock, &irqL);
 
-exit:	
+exit:
 
-_func_exit_;
 
 	return _SUCCESS;
 }
@@ -287,62 +319,57 @@ struct	cmd_obj	*_rtw_dequeue_cmd(_queue *queue)
 	_irqL irqL;
 	struct cmd_obj *obj;
 
-_func_enter_;
 
-	//_enter_critical_bh(&(queue->lock), &irqL);
+	/* _enter_critical_bh(&(queue->lock), &irqL); */
 	_enter_critical(&queue->lock, &irqL);
-	
-	#ifdef DBG_CMD_QUEUE
-	if (queue->queue.prev->next != &queue->queue)
-	{
-   		 DBG_871X("[%d] head %p, tail %p, tail->prev->next %p[tail], tail->next %p[head]\n", __LINE__,
-            &queue->queue, queue->queue.prev, queue->queue.prev->prev->next, queue->queue.prev->next);
+
+#ifdef DBG_CMD_QUEUE
+	if (queue->queue.prev->next != &queue->queue) {
+		RTW_INFO("[%d] head %p, tail %p, tail->prev->next %p[tail], tail->next %p[head]\n", __LINE__,
+			&queue->queue, queue->queue.prev, queue->queue.prev->prev->next, queue->queue.prev->next);
 	}
-	#endif //DBG_CMD_QUEUE
+#endif /* DBG_CMD_QUEUE */
 
 
-	if (rtw_is_list_empty(&(queue->queue))){
+	if (rtw_is_list_empty(&(queue->queue)))
 		obj = NULL;
-	}
-	else
-	{
+	else {
 		obj = LIST_CONTAINOR(get_next(&(queue->queue)), struct cmd_obj, list);
 
-		#ifdef DBG_CMD_QUEUE
-		if (queue->queue.prev->next != &queue->queue){
-				DBG_871X("==========%s============\n",__FUNCTION__);
-                          DBG_871X("head:%p,obj_addr:%p\n",&queue->queue,obj);
-				DBG_871X("padapter: %p\n",obj->padapter);
-				DBG_871X("cmdcode: 0x%02x\n",obj->cmdcode);
-				DBG_871X("res: %d\n",obj->res);
-				DBG_871X("parmbuf: %p\n",obj->parmbuf);
-				DBG_871X("cmdsz: %d\n",obj->cmdsz);
-				DBG_871X("rsp: %p\n",obj->rsp);
-				DBG_871X("rspsz: %d\n",obj->rspsz);
-				DBG_871X("sctx: %p\n",obj->sctx);                        	
-				DBG_871X("list->next: %p\n",obj->list.next);
-				DBG_871X("list->prev: %p\n",obj->list.prev);
+#ifdef DBG_CMD_QUEUE
+		if (queue->queue.prev->next != &queue->queue) {
+			RTW_INFO("==========%s============\n", __FUNCTION__);
+			RTW_INFO("head:%p,obj_addr:%p\n", &queue->queue, obj);
+			RTW_INFO("padapter: %p\n", obj->padapter);
+			RTW_INFO("cmdcode: 0x%02x\n", obj->cmdcode);
+			RTW_INFO("res: %d\n", obj->res);
+			RTW_INFO("parmbuf: %p\n", obj->parmbuf);
+			RTW_INFO("cmdsz: %d\n", obj->cmdsz);
+			RTW_INFO("rsp: %p\n", obj->rsp);
+			RTW_INFO("rspsz: %d\n", obj->rspsz);
+			RTW_INFO("sctx: %p\n", obj->sctx);
+			RTW_INFO("list->next: %p\n", obj->list.next);
+			RTW_INFO("list->prev: %p\n", obj->list.prev);
+		}
+
+		if (dump_cmd_id) {
+			RTW_INFO("%s===> cmdcode:0x%02x\n", __FUNCTION__, obj->cmdcode);
+			if (obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
+				if (obj->parmbuf) {
+					struct drvextra_cmd_parm *pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)(obj->parmbuf);
+					printk("pdrvextra_cmd_parm->ec_id:0x%02x\n", pdrvextra_cmd_parm->ec_id);
+				}
+			}
+
 		}
-		
-		if(dump_cmd_id){
-			DBG_871X("%s===> cmdcode:0x%02x\n",__FUNCTION__,obj->cmdcode);
-		 	if(obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)){
-				if(obj->parmbuf){
-                                struct drvextra_cmd_parm *pdrvextra_cmd_parm =(struct drvextra_cmd_parm*)(obj->parmbuf);
-                                printk("pdrvextra_cmd_parm->ec_id:0x%02x\n",pdrvextra_cmd_parm->ec_id);
-                        }
-                	}
-
-		}	
-		#endif //DBG_CMD_QUEUE
-		
+#endif /* DBG_CMD_QUEUE */
+
 		rtw_list_delete(&obj->list);
 	}
 
-	//_exit_critical_bh(&(queue->lock), &irqL);
+	/* _exit_critical_bh(&(queue->lock), &irqL); */
 	_exit_critical(&queue->lock, &irqL);
 
-_func_exit_;	
 
 	return obj;
 }
@@ -350,81 +377,58 @@ _func_exit_;
 u32	rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
 {
 	u32	res;
-_func_enter_;	
-	res = _rtw_init_cmd_priv (pcmdpriv);
-_func_exit_;	
-	return res;	
+	res = _rtw_init_cmd_priv(pcmdpriv);
+	return res;
 }
 
-u32	rtw_init_evt_priv (struct	evt_priv *pevtpriv)
+u32	rtw_init_evt_priv(struct	evt_priv *pevtpriv)
 {
 	int	res;
-_func_enter_;		
 	res = _rtw_init_evt_priv(pevtpriv);
-_func_exit_;		
 	return res;
 }
 
-void rtw_free_evt_priv (struct	evt_priv *pevtpriv)
+void rtw_free_evt_priv(struct	evt_priv *pevtpriv)
 {
-_func_enter_;
-	RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("rtw_free_evt_priv\n"));
 	_rtw_free_evt_priv(pevtpriv);
-_func_exit_;		
-}	
+}
 
-void rtw_free_cmd_priv (struct	cmd_priv *pcmdpriv)
+void rtw_free_cmd_priv(struct	cmd_priv *pcmdpriv)
 {
-_func_enter_;
-	RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("rtw_free_cmd_priv\n"));
 	_rtw_free_cmd_priv(pcmdpriv);
-_func_exit_;	
-}	
+}
 
 int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj);
 int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
 {
-	u8 bAllow = _FALSE; //set to _TRUE to allow enqueuing cmd when hw_init_completed is _FALSE
-	
-	#ifdef SUPPORT_HW_RFOFF_DETECTED
-	//To decide allow or not
-	if( (adapter_to_pwrctl(pcmdpriv->padapter)->bHWPwrPindetect)
-		&&(!pcmdpriv->padapter->registrypriv.usbss_enable)
-	)		
-	{
-		if(cmd_obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra) ) 
-		{
-			struct drvextra_cmd_parm	*pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)cmd_obj->parmbuf; 
-			if(pdrvextra_cmd_parm->ec_id == POWER_SAVING_CTRL_WK_CID)
-			{	
-				//DBG_871X("==>enqueue POWER_SAVING_CTRL_WK_CID\n");
-				bAllow = _TRUE; 
-			}
-		}
-	}
-	#endif
+	u8 bAllow = _FALSE; /* set to _TRUE to allow enqueuing cmd when hw_init_completed is _FALSE */
 
-#ifndef CONFIG_C2H_PACKET_EN
-	/* C2H should be always allowed */
-	if(cmd_obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
-		struct drvextra_cmd_parm *pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)cmd_obj->parmbuf;
-		if(pdrvextra_cmd_parm->ec_id == C2H_WK_CID) {
-			bAllow = _TRUE;
+#ifdef SUPPORT_HW_RFOFF_DETECTED
+	/* To decide allow or not */
+	if ((adapter_to_pwrctl(pcmdpriv->padapter)->bHWPwrPindetect)
+	    && (!pcmdpriv->padapter->registrypriv.usbss_enable)
+	   ) {
+		if (cmd_obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
+			struct drvextra_cmd_parm	*pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)cmd_obj->parmbuf;
+			if (pdrvextra_cmd_parm->ec_id == POWER_SAVING_CTRL_WK_CID) {
+				/* RTW_INFO("==>enqueue POWER_SAVING_CTRL_WK_CID\n"); */
+				bAllow = _TRUE;
+			}
 		}
 	}
 #endif
 
-	if(cmd_obj->cmdcode == GEN_CMD_CODE(_SetChannelPlan))
+	if (cmd_obj->cmdcode == GEN_CMD_CODE(_SetChannelPlan))
 		bAllow = _TRUE;
 
 	if (cmd_obj->no_io)
 		bAllow = _TRUE;
 
 	if ((!rtw_is_hw_init_completed(pcmdpriv->padapter) && (bAllow == _FALSE))
-		|| ATOMIC_READ(&(pcmdpriv->cmdthd_running)) == _FALSE	//com_thread not running
-	) {
+	    || ATOMIC_READ(&(pcmdpriv->cmdthd_running)) == _FALSE	/* com_thread not running */
+	   ) {
 		if (DBG_CMD_EXECUTE)
-			DBG_871X(ADPT_FMT" drop "CMD_FMT" hw_init_completed:%u, cmdthd_running:%u\n", ADPT_ARG(cmd_obj->padapter)
+			RTW_INFO(ADPT_FMT" drop "CMD_FMT" hw_init_completed:%u, cmdthd_running:%u\n", ADPT_ARG(cmd_obj->padapter)
 				, CMD_ARG(cmd_obj), rtw_get_hw_init_completed(cmd_obj->padapter), ATOMIC_READ(&pcmdpriv->cmdthd_running));
 		if (0)
 			rtw_warn_on(1);
@@ -440,25 +444,23 @@ u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
 {
 	int res = _FAIL;
 	PADAPTER padapter = pcmdpriv->padapter;
-	
-_func_enter_;	
-	
-	if (cmd_obj == NULL) {
+
+
+	if (cmd_obj == NULL)
 		goto exit;
-	}
 
 	cmd_obj->padapter = padapter;
 
 #ifdef CONFIG_CONCURRENT_MODE
-	//change pcmdpriv to primary's pcmdpriv
-	if (padapter->adapter_type != PRIMARY_ADAPTER && padapter->pbuddy_adapter)
-		pcmdpriv = &(padapter->pbuddy_adapter->cmdpriv);
-#endif	
+	/* change pcmdpriv to primary's pcmdpriv */
+	if (!is_primary_adapter(padapter))
+		pcmdpriv = &(GET_PRIMARY_ADAPTER(padapter)->cmdpriv);
+#endif
 
 	res = rtw_cmd_filter(pcmdpriv, cmd_obj);
 	if ((_FAIL == res) || (cmd_obj->cmdsz > MAX_CMDSZ)) {
 		if (cmd_obj->cmdsz > MAX_CMDSZ) {
-			DBG_871X("%s failed due to obj->cmdsz(%d) > MAX_CMDSZ(%d)\n", __func__, cmd_obj->cmdsz, MAX_CMDSZ);
+			RTW_INFO("%s failed due to obj->cmdsz(%d) > MAX_CMDSZ(%d)\n", __func__, cmd_obj->cmdsz, MAX_CMDSZ);
 			rtw_warn_on(1);
 		}
 
@@ -474,12 +476,11 @@ _func_enter_;
 
 	res = _rtw_enqueue_cmd(&pcmdpriv->cmd_queue, cmd_obj, 0);
 
-	if(res == _SUCCESS)
+	if (res == _SUCCESS)
 		_rtw_up_sema(&pcmdpriv->cmd_queue_sema);
-	
-exit:	
-	
-_func_exit_;
+
+exit:
+
 
 	return res;
 }
@@ -487,57 +488,46 @@ _func_exit_;
 struct	cmd_obj	*rtw_dequeue_cmd(struct cmd_priv *pcmdpriv)
 {
 	struct cmd_obj *cmd_obj;
-	
-_func_enter_;		
+
 
 	cmd_obj = _rtw_dequeue_cmd(&pcmdpriv->cmd_queue);
-		
-_func_exit_;			
+
 	return cmd_obj;
 }
 
 void rtw_cmd_clr_isr(struct	cmd_priv *pcmdpriv)
 {
-_func_enter_;
 	pcmdpriv->cmd_done_cnt++;
-	//_rtw_up_sema(&(pcmdpriv->cmd_done_sema));
-_func_exit_;		
+	/* _rtw_up_sema(&(pcmdpriv->cmd_done_sema)); */
 }
 
 void rtw_free_cmd_obj(struct cmd_obj *pcmd)
 {
 	struct drvextra_cmd_parm *extra_parm = NULL;
-_func_enter_;
 
 	if (pcmd->parmbuf != NULL) {
 		/* free parmbuf in cmd_obj */
 		rtw_mfree((unsigned char *)pcmd->parmbuf, pcmd->cmdsz);
 	}
-	if(pcmd->rsp!=NULL)
-	{
-		if(pcmd->rspsz!= 0)
-		{
-			//free rsp in cmd_obj
-			rtw_mfree((unsigned char*)pcmd->rsp, pcmd->rspsz);
-		}	
-	}	
+	if (pcmd->rsp != NULL) {
+		if (pcmd->rspsz != 0) {
+			/* free rsp in cmd_obj */
+			rtw_mfree((unsigned char *)pcmd->rsp, pcmd->rspsz);
+		}
+	}
+
+	/* free cmd_obj */
+	rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
 
-	//free cmd_obj
-	rtw_mfree((unsigned char*)pcmd, sizeof(struct cmd_obj));
-	
-_func_exit_;		
 }
 
 
 void rtw_stop_cmd_thread(_adapter *adapter)
 {
-	if(adapter->cmdThread &&
-		ATOMIC_READ(&(adapter->cmdpriv.cmdthd_running)) == _TRUE &&
-		adapter->cmdpriv.stop_req == 0)
-	{
-		adapter->cmdpriv.stop_req = 1;
+	if (adapter->cmdThread) {
 		_rtw_up_sema(&adapter->cmdpriv.cmd_queue_sema);
-		_rtw_down_sema(&adapter->cmdpriv.terminate_cmdthread_sema);
+		rtw_thread_stop(adapter->cmdThread);
+		adapter->cmdThread = NULL;
 	}
 }
 
@@ -546,50 +536,40 @@ thread_return rtw_cmd_thread(thread_context context)
 	u8 ret;
 	struct cmd_obj *pcmd;
 	u8 *pcmdbuf, *prspbuf;
-	u32 cmd_start_time;
+	systime cmd_start_time;
 	u32 cmd_process_time;
-	u8 (*cmd_hdl)(_adapter *padapter, u8* pbuf);
+	u8(*cmd_hdl)(_adapter *padapter, u8 *pbuf);
 	void (*pcmd_callback)(_adapter *dev, struct cmd_obj *pcmd);
 	PADAPTER padapter = (PADAPTER)context;
 	struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
 	struct drvextra_cmd_parm *extra_parm = NULL;
 	_irqL irqL;
-_func_enter_;
 
 	thread_enter("RTW_CMD_THREAD");
 
 	pcmdbuf = pcmdpriv->cmd_buf;
 	prspbuf = pcmdpriv->rsp_buf;
-
-	pcmdpriv->stop_req = 0;
 	ATOMIC_SET(&(pcmdpriv->cmdthd_running), _TRUE);
-	_rtw_up_sema(&pcmdpriv->terminate_cmdthread_sema);
+	_rtw_up_sema(&pcmdpriv->start_cmdthread_sema);
 
-	RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("start r871x rtw_cmd_thread !!!!\n"));
 
 	while (1) {
 		if (_rtw_down_sema(&pcmdpriv->cmd_queue_sema) == _FAIL) {
-			DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" _rtw_down_sema(&pcmdpriv->cmd_queue_sema) return _FAIL, break\n", FUNC_ADPT_ARG(padapter));
+			RTW_PRINT(FUNC_ADPT_FMT" _rtw_down_sema(&pcmdpriv->cmd_queue_sema) return _FAIL, break\n", FUNC_ADPT_ARG(padapter));
 			break;
 		}
 
 		if (RTW_CANNOT_RUN(padapter)) {
-			DBG_871X_LEVEL(_drv_always_, "%s: DriverStopped(%s) SurpriseRemoved(%s) break at line %d\n",
-				__func__
-				, rtw_is_drv_stopped(padapter)?"True":"False"
-				, rtw_is_surprise_removed(padapter)?"True":"False"
-				, __LINE__);
+			RTW_DBG(FUNC_ADPT_FMT "- bDriverStopped(%s) bSurpriseRemoved(%s)\n",
+				FUNC_ADPT_ARG(padapter),
+				rtw_is_drv_stopped(padapter) ? "True" : "False",
+				rtw_is_surprise_removed(padapter) ? "True" : "False");
 			break;
 		}
 
-		if (pcmdpriv->stop_req) {
-			DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" stop_req:%u, break\n", FUNC_ADPT_ARG(padapter), pcmdpriv->stop_req);
-			break;
-		}
-		
 		_enter_critical(&pcmdpriv->cmd_queue.lock, &irqL);
 		if (rtw_is_list_empty(&(pcmdpriv->cmd_queue.queue))) {
-			//DBG_871X("%s: cmd queue is empty!\n", __func__);
+			/* RTW_INFO("%s: cmd queue is empty!\n", __func__); */
 			_exit_critical(&pcmdpriv->cmd_queue.lock, &irqL);
 			continue;
 		}
@@ -597,19 +577,19 @@ _func_enter_;
 
 _next:
 		if (RTW_CANNOT_RUN(padapter)) {
-			DBG_871X_LEVEL(_drv_always_, "%s: DriverStopped(%s) SurpriseRemoved(%s) break at line %d\n",
-				__func__
-				, rtw_is_drv_stopped(padapter)?"True":"False"
-				, rtw_is_surprise_removed(padapter)?"True":"False"
-				, __LINE__);
+			RTW_PRINT("%s: DriverStopped(%s) SurpriseRemoved(%s) break at line %d\n",
+				  __func__
+				, rtw_is_drv_stopped(padapter) ? "True" : "False"
+				, rtw_is_surprise_removed(padapter) ? "True" : "False"
+				  , __LINE__);
 			break;
 		}
 
 		pcmd = rtw_dequeue_cmd(pcmdpriv);
 		if (!pcmd) {
-			#ifdef CONFIG_LPS_LCLK
+#ifdef CONFIG_LPS_LCLK
 			rtw_unregister_cmd_alive(padapter);
-			#endif
+#endif
 			continue;
 		}
 
@@ -617,20 +597,20 @@ _next:
 		pcmdpriv->cmd_issued_cnt++;
 
 		if (pcmd->cmdsz > MAX_CMDSZ) {
-			DBG_871X_LEVEL(_drv_err_, "%s cmdsz:%d > MAX_CMDSZ:%d\n", __func__, pcmd->cmdsz, MAX_CMDSZ);
+			RTW_ERR("%s cmdsz:%d > MAX_CMDSZ:%d\n", __func__, pcmd->cmdsz, MAX_CMDSZ);
 			pcmd->res = H2C_PARAMETERS_ERROR;
 			goto post_process;
 		}
 
 		if (pcmd->cmdcode >= (sizeof(wlancmds) / sizeof(struct cmd_hdl))) {
-			DBG_871X_LEVEL(_drv_err_, "%s undefined cmdcode:%d\n", __func__, pcmd->cmdcode);
+			RTW_ERR("%s undefined cmdcode:%d\n", __func__, pcmd->cmdcode);
 			pcmd->res = H2C_PARAMETERS_ERROR;
 			goto post_process;
 		}
 
 		cmd_hdl = wlancmds[pcmd->cmdcode].h2cfuns;
 		if (!cmd_hdl) {
-			DBG_871X_LEVEL(_drv_err_, "%s no cmd_hdl for cmdcode:%d\n", __func__, pcmd->cmdcode);
+			RTW_ERR("%s no cmd_hdl for cmdcode:%d\n", __func__, pcmd->cmdcode);
 			pcmd->res = H2C_PARAMETERS_ERROR;
 			goto post_process;
 		}
@@ -645,31 +625,31 @@ _next:
 			goto post_process;
 		}
 
-		#ifdef CONFIG_LPS_LCLK
-		if (pcmd->no_io) {
+#ifdef CONFIG_LPS_LCLK
+		if (pcmd->no_io)
 			rtw_unregister_cmd_alive(padapter);
-		} else {
+		else {
 			if (rtw_register_cmd_alive(padapter) != _SUCCESS) {
 				if (DBG_CMD_EXECUTE)
-					DBG_871X_LEVEL(_drv_always_, "%s: wait to leave LPS_LCLK\n", __func__);
+					RTW_PRINT("%s: wait to leave LPS_LCLK\n", __func__);
 
 				pcmd->res = H2C_ENQ_HEAD;
 				ret = _rtw_enqueue_cmd(&pcmdpriv->cmd_queue, pcmd, 1);
 				if (ret == _SUCCESS) {
 					if (DBG_CMD_EXECUTE)
-						DBG_871X(ADPT_FMT" "CMD_FMT" ENQ_HEAD\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd));
+						RTW_INFO(ADPT_FMT" "CMD_FMT" ENQ_HEAD\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd));
 					continue;
 				}
 
-				DBG_871X(ADPT_FMT" "CMD_FMT" ENQ_HEAD_FAIL\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd));
+				RTW_INFO(ADPT_FMT" "CMD_FMT" ENQ_HEAD_FAIL\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd));
 				pcmd->res = H2C_ENQ_HEAD_FAIL;
 				rtw_warn_on(1);
 			}
 		}
-		#endif /* CONFIG_LPS_LCLK */
+#endif /* CONFIG_LPS_LCLK */
 
 		if (DBG_CMD_EXECUTE)
-			DBG_871X(ADPT_FMT" "CMD_FMT" %sexecute\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd)
+			RTW_INFO(ADPT_FMT" "CMD_FMT" %sexecute\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd)
 				, pcmd->res == H2C_ENQ_HEAD ? "ENQ_HEAD " : (pcmd->res == H2C_ENQ_HEAD_FAIL ? "ENQ_HEAD_FAIL " : ""));
 
 		_rtw_memcpy(pcmdbuf, pcmd->parmbuf, pcmd->cmdsz);
@@ -683,7 +663,7 @@ post_process:
 		_enter_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
 		if (pcmd->sctx) {
 			if (0)
-				DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" pcmd->sctx\n", FUNC_ADPT_ARG(pcmd->padapter));
+				RTW_PRINT(FUNC_ADPT_FMT" pcmd->sctx\n", FUNC_ADPT_ARG(pcmd->padapter));
 			if (pcmd->res == H2C_SUCCESS)
 				rtw_sctx_done(&pcmd->sctx);
 			else
@@ -693,29 +673,21 @@ post_process:
 
 		cmd_process_time = rtw_get_passing_time_ms(cmd_start_time);
 		if (cmd_process_time > 1000) {
-			DBG_871X(ADPT_FMT" "CMD_FMT" process_time=%d\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd), cmd_process_time);
+			RTW_INFO(ADPT_FMT" "CMD_FMT" process_time=%d\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd), cmd_process_time);
 			if (0)
 				rtw_warn_on(1);
 		}
 
-		//call callback function for post-processed
-		if(pcmd->cmdcode < (sizeof(rtw_cmd_callback) /sizeof(struct _cmd_callback)))
-		{
+		/* call callback function for post-processed */
+		if (pcmd->cmdcode < (sizeof(rtw_cmd_callback) / sizeof(struct _cmd_callback))) {
 			pcmd_callback = rtw_cmd_callback[pcmd->cmdcode].callback;
-			if(pcmd_callback == NULL)
-			{
-				RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("mlme_cmd_hdl(): pcmd_callback=0x%p, cmdcode=0x%x\n", pcmd_callback, pcmd->cmdcode));
+			if (pcmd_callback == NULL) {
 				rtw_free_cmd_obj(pcmd);
+			} else {
+				/* todo: !!! fill rsp_buf to pcmd->rsp if (pcmd->rsp!=NULL) */
+				pcmd_callback(pcmd->padapter, pcmd);/* need conider that free cmd_obj in rtw_cmd_callback */
 			}
-			else
-			{
-				//todo: !!! fill rsp_buf to pcmd->rsp if (pcmd->rsp!=NULL)
-				pcmd_callback(pcmd->padapter, pcmd);//need conider that free cmd_obj in rtw_cmd_callback
-			}
-		}
-		else
-		{
-			RT_TRACE(_module_rtl871x_cmd_c_,_drv_err_,("%s: cmdcode=0x%x callback not defined!\n", __FUNCTION__, pcmd->cmdcode));
+		} else {
 			rtw_free_cmd_obj(pcmd);
 		}
 
@@ -729,6 +701,9 @@ post_process:
 	rtw_unregister_cmd_alive(padapter);
 #endif
 
+	/* to avoid enqueue cmd after free all cmd_obj */
+	ATOMIC_SET(&(pcmdpriv->cmdthd_running), _FALSE);
+
 	/* free all cmd_obj resources */
 	do {
 		pcmd = rtw_dequeue_cmd(pcmdpriv);
@@ -736,19 +711,18 @@ post_process:
 			break;
 
 		if (0)
-			DBG_871X("%s: leaving... drop "CMD_FMT"\n", __func__, CMD_ARG(pcmd));
+			RTW_INFO("%s: leaving... drop "CMD_FMT"\n", __func__, CMD_ARG(pcmd));
 
 		if (pcmd->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
 			extra_parm = (struct drvextra_cmd_parm *)pcmd->parmbuf;
-			if(extra_parm->pbuf && extra_parm->size > 0) {
+			if (extra_parm->pbuf && extra_parm->size > 0)
 				rtw_mfree(extra_parm->pbuf, extra_parm->size);
-			}
 		}
 
 		_enter_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
 		if (pcmd->sctx) {
 			if (0)
-				DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" pcmd->sctx\n", FUNC_ADPT_ARG(pcmd->padapter));
+				RTW_PRINT(FUNC_ADPT_FMT" pcmd->sctx\n", FUNC_ADPT_ARG(pcmd->padapter));
 			rtw_sctx_done_err(&pcmd->sctx, RTW_SCTX_DONE_CMD_DROP);
 		}
 		_exit_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
@@ -756,13 +730,11 @@ post_process:
 		rtw_free_cmd_obj(pcmd);
 	} while (1);
 
-	_rtw_up_sema(&pcmdpriv->terminate_cmdthread_sema);
-	ATOMIC_SET(&(pcmdpriv->cmdthd_running), _FALSE);
-
-_func_exit_;
+	RTW_INFO(FUNC_ADPT_FMT " Exit\n", FUNC_ADPT_ARG(padapter));
 
-	thread_exit();
+	rtw_thread_wait_stop();
 
+	return 0;
 }
 
 
@@ -772,97 +744,87 @@ u32 rtw_enqueue_evt(struct evt_priv *pevtpriv, struct evt_obj *obj)
 	_irqL irqL;
 	int	res;
 	_queue *queue = &pevtpriv->evt_queue;
-	
-_func_enter_;	
 
-	res = _SUCCESS; 		
+
+	res = _SUCCESS;
 
 	if (obj == NULL) {
 		res = _FAIL;
 		goto exit;
-	}	
+	}
 
 	_enter_critical_bh(&queue->lock, &irqL);
 
 	rtw_list_insert_tail(&obj->list, &queue->queue);
-	
+
 	_exit_critical_bh(&queue->lock, &irqL);
 
-	//rtw_evt_notify_isr(pevtpriv);
+	/* rtw_evt_notify_isr(pevtpriv); */
 
 exit:
-	
-_func_exit_;		
 
-	return res;	
+
+	return res;
 }
 
 struct evt_obj *rtw_dequeue_evt(_queue *queue)
 {
 	_irqL irqL;
 	struct	evt_obj	*pevtobj;
-	
-_func_enter_;		
+
 
 	_enter_critical_bh(&queue->lock, &irqL);
 
 	if (rtw_is_list_empty(&(queue->queue)))
 		pevtobj = NULL;
-	else
-	{
+	else {
 		pevtobj = LIST_CONTAINOR(get_next(&(queue->queue)), struct evt_obj, list);
 		rtw_list_delete(&pevtobj->list);
 	}
 
 	_exit_critical_bh(&queue->lock, &irqL);
-	
-_func_exit_;			
 
-	return pevtobj;	
+
+	return pevtobj;
 }
 
 void rtw_free_evt_obj(struct evt_obj *pevtobj)
 {
-_func_enter_;
 
-	if(pevtobj->parmbuf)
-		rtw_mfree((unsigned char*)pevtobj->parmbuf, pevtobj->evtsz);
-	
-	rtw_mfree((unsigned char*)pevtobj, sizeof(struct evt_obj));
-	
-_func_exit_;		
+	if (pevtobj->parmbuf)
+		rtw_mfree((unsigned char *)pevtobj->parmbuf, pevtobj->evtsz);
+
+	rtw_mfree((unsigned char *)pevtobj, sizeof(struct evt_obj));
+
 }
 
 void rtw_evt_notify_isr(struct evt_priv *pevtpriv)
 {
-_func_enter_;
 	pevtpriv->evt_done_cnt++;
 	_rtw_up_sema(&(pevtpriv->evt_notify));
-_func_exit_;	
 }
 #endif
 
 
 /*
-u8 rtw_setstandby_cmd(unsigned char  *adapter) 
+u8 rtw_setstandby_cmd(unsigned char  *adapter)
 */
 u8 rtw_setstandby_cmd(_adapter *padapter, uint action)
 {
-	struct cmd_obj*			ph2c;
-	struct usb_suspend_parm*	psetusbsuspend;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;
+	struct cmd_obj			*ph2c;
+	struct usb_suspend_parm	*psetusbsuspend;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
 
 	u8 ret = _SUCCESS;
-	
-_func_enter_;	
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL) {
 		ret = _FAIL;
 		goto exit;
 	}
-	
-	psetusbsuspend = (struct usb_suspend_parm*)rtw_zmalloc(sizeof(struct usb_suspend_parm)); 
+
+	psetusbsuspend = (struct usb_suspend_parm *)rtw_zmalloc(sizeof(struct usb_suspend_parm));
 	if (psetusbsuspend == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
 		ret = _FAIL;
@@ -873,140 +835,102 @@ _func_enter_;
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, psetusbsuspend, GEN_CMD_CODE(_SetUsbSuspend));
 
-	ret = rtw_enqueue_cmd(pcmdpriv, ph2c);	
-	
-exit:	
-	
-_func_exit_;		
+	ret = rtw_enqueue_cmd(pcmdpriv, ph2c);
+
+exit:
+
 
 	return ret;
 }
 
+void rtw_init_sitesurvey_parm(_adapter *padapter, struct sitesurvey_parm *pparm)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+
+	_rtw_memset(pparm, 0, sizeof(struct sitesurvey_parm));
+	pparm->scan_mode = pmlmepriv->scan_mode;
+}
+
 /*
 rtw_sitesurvey_cmd(~)
 	### NOTE:#### (!!!!)
 	MUST TAKE CARE THAT BEFORE CALLING THIS FUNC, YOU SHOULD HAVE LOCKED pmlmepriv->lock
 */
-u8 rtw_sitesurvey_cmd(_adapter  *padapter, NDIS_802_11_SSID *ssid, int ssid_num,
-	struct rtw_ieee80211_channel *ch, int ch_num)
+u8 rtw_sitesurvey_cmd(_adapter *padapter, struct sitesurvey_parm *pparm)
 {
 	u8 res = _FAIL;
 	struct cmd_obj		*ph2c;
 	struct sitesurvey_parm	*psurveyPara;
-	struct cmd_priv 	*pcmdpriv = &padapter->cmdpriv;
+	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 #ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif //CONFIG_P2P
-
-_func_enter_;
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 
 #ifdef CONFIG_LPS
-	if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE){
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_SCAN, 1);
-	}
 #endif
 
 #ifdef CONFIG_P2P_PS
-	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 		p2p_ps_wk_cmd(padapter, P2P_PS_SCAN, 1);
-	}
-#endif //CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL)
 		return _FAIL;
 
-	psurveyPara = (struct sitesurvey_parm*)rtw_zmalloc(sizeof(struct sitesurvey_parm)); 
+	psurveyPara = (struct sitesurvey_parm *)rtw_zmalloc(sizeof(struct sitesurvey_parm));
 	if (psurveyPara == NULL) {
-		rtw_mfree((unsigned char*) ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((unsigned char *) ph2c, sizeof(struct cmd_obj));
 		return _FAIL;
 	}
 
-	rtw_free_network_queue(padapter, _FALSE);
+	if (pparm)
+		_rtw_memcpy(psurveyPara, pparm, sizeof(struct sitesurvey_parm));
+	else
+		psurveyPara->scan_mode = pmlmepriv->scan_mode;
 
-	RT_TRACE(_module_rtl871x_cmd_c_, _drv_info_, ("%s: flush network queue\n", __FUNCTION__));
+	rtw_free_network_queue(padapter, _FALSE);
 
 	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].SsidLength) {
-				_rtw_memcpy(&psurveyPara->ssid[i], &ssid[i], sizeof(NDIS_802_11_SSID));
-				psurveyPara->ssid_num++;
-				if (0)
-					DBG_871X(FUNC_ADPT_FMT" ssid:(%s, %d)\n", FUNC_ADPT_ARG(padapter),
-						psurveyPara->ssid[i].Ssid, psurveyPara->ssid[i].SsidLength);
-			}
-		}
-	}
-
-	/* 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 & RTW_IEEE80211_CHAN_DISABLED)) {
-				_rtw_memcpy(&psurveyPara->ch[i], &ch[i], sizeof(struct rtw_ieee80211_channel));
-				psurveyPara->ch_num++;
-				if (0)
-					DBG_871X(FUNC_ADPT_FMT" ch:%u\n", FUNC_ADPT_ARG(padapter),
-						psurveyPara->ch[i].hw_value);
-			}
-		}
-	}
-
 	set_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
 
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 
-	if(res == _SUCCESS) {
+	if (res == _SUCCESS) {
+		u32 scan_timeout_ms;
 
 		pmlmepriv->scan_start_time = rtw_get_current_time();
-
-#ifdef CONFIG_SCAN_BACKOP
-		if((padapter->pbuddy_adapter->mlmeextpriv.mlmext_info.state&0x03) == WIFI_FW_AP_STATE)
-		{
-			if(IsSupported5G(padapter->registrypriv.wireless_mode) 
-				&& IsSupported24G(padapter->registrypriv.wireless_mode)) //dual band
-				mlme_set_scan_to_timer(pmlmepriv, CONC_SCANNING_TIMEOUT_DUAL_BAND);
-			else //single band
-				mlme_set_scan_to_timer(pmlmepriv, CONC_SCANNING_TIMEOUT_SINGLE_BAND);
-		}		
-		else
-#endif /* CONFIG_SCAN_BACKOP */
-			mlme_set_scan_to_timer(pmlmepriv, SCANNING_TIMEOUT);
+		scan_timeout_ms = rtw_scan_timeout_decision(padapter);
+		mlme_set_scan_to_timer(pmlmepriv,scan_timeout_ms);
 
 		rtw_led_control(padapter, LED_CTL_SITE_SURVEY);
-	} else {
+	} else
 		_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
-	}
 
-_func_exit_;		
 
 	return res;
 }
 
 u8 rtw_setdatarate_cmd(_adapter *padapter, u8 *rateset)
 {
-	struct cmd_obj*			ph2c;
-	struct setdatarate_parm*	pbsetdataratepara;
-	struct cmd_priv*		pcmdpriv = &padapter->cmdpriv;
+	struct cmd_obj			*ph2c;
+	struct setdatarate_parm	*pbsetdataratepara;
+	struct cmd_priv		*pcmdpriv = &padapter->cmdpriv;
 	u8	res = _SUCCESS;
 
-_func_enter_;	
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	pbsetdataratepara = (struct setdatarate_parm*)rtw_zmalloc(sizeof(struct setdatarate_parm)); 
+	pbsetdataratepara = (struct setdatarate_parm *)rtw_zmalloc(sizeof(struct setdatarate_parm));
 	if (pbsetdataratepara == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
 		res = _FAIL;
@@ -1015,8 +939,8 @@ _func_enter_;
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pbsetdataratepara, GEN_CMD_CODE(_SetDataRate));
 #ifdef MP_FIRMWARE_OFFLOAD
-	pbsetdataratepara->curr_rateidx = *(u32*)rateset;
-//	_rtw_memcpy(pbsetdataratepara, rateset, sizeof(u32));
+	pbsetdataratepara->curr_rateidx = *(u32 *)rateset;
+	/*	_rtw_memcpy(pbsetdataratepara, rateset, sizeof(u32)); */
 #else
 	pbsetdataratepara->mac_id = 5;
 	_rtw_memcpy(pbsetdataratepara->datarates, rateset, NumRates);
@@ -1024,48 +948,45 @@ _func_enter_;
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 exit:
 
-_func_exit_;
 
 	return res;
 }
 
 u8 rtw_setbasicrate_cmd(_adapter *padapter, u8 *rateset)
 {
-	struct cmd_obj*			ph2c;
-	struct setbasicrate_parm*	pssetbasicratepara;
-	struct cmd_priv*		pcmdpriv=&padapter->cmdpriv;
+	struct cmd_obj			*ph2c;
+	struct setbasicrate_parm	*pssetbasicratepara;
+	struct cmd_priv		*pcmdpriv = &padapter->cmdpriv;
 	u8	res = _SUCCESS;
 
-_func_enter_;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL) {
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
-	pssetbasicratepara = (struct setbasicrate_parm*)rtw_zmalloc(sizeof(struct setbasicrate_parm)); 
+	pssetbasicratepara = (struct setbasicrate_parm *)rtw_zmalloc(sizeof(struct setbasicrate_parm));
 
 	if (pssetbasicratepara == NULL) {
-		rtw_mfree((u8*) ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
 		res = _FAIL;
 		goto exit;
 	}
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pssetbasicratepara, _SetBasicRate_CMD_);
 
-	_rtw_memcpy(pssetbasicratepara->basicrates, rateset, NumRates);	   
+	_rtw_memcpy(pssetbasicratepara->basicrates, rateset, NumRates);
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
-exit:	
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+exit:
 
-_func_exit_;		
 
 	return res;
 }
 
 
 /*
-unsigned char rtw_setphy_cmd(unsigned char  *adapter) 
+unsigned char rtw_setphy_cmd(unsigned char  *adapter)
 
 1.  be called only after rtw_update_registrypriv_dev_network( ~) or mp testing program
 2.  for AdHoc/Ap mode or mp mode?
@@ -1073,38 +994,35 @@ unsigned char rtw_setphy_cmd(unsigned char  *adapter)
 */
 u8 rtw_setphy_cmd(_adapter *padapter, u8 modem, u8 ch)
 {
-	struct cmd_obj*			ph2c;
-	struct setphy_parm*		psetphypara;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;
-//	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
-//	struct registry_priv*		pregistry_priv = &padapter->registrypriv;
-	u8	res=_SUCCESS;
+	struct cmd_obj			*ph2c;
+	struct setphy_parm		*psetphypara;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	/*	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
+	 *	struct registry_priv*		pregistry_priv = &padapter->registrypriv; */
+	u8	res = _SUCCESS;
 
-_func_enter_;	
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
-		}
-	psetphypara = (struct setphy_parm*)rtw_zmalloc(sizeof(struct setphy_parm)); 
+	}
+	psetphypara = (struct setphy_parm *)rtw_zmalloc(sizeof(struct setphy_parm));
 
-	if(psetphypara==NULL){
+	if (psetphypara == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, psetphypara, _SetPhy_CMD_);
 
-	RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("CH=%d, modem=%d", ch, modem));
 
 	psetphypara->modem = modem;
 	psetphypara->rfchannel = ch;
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
-exit:	
-_func_exit_;		
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+exit:
 	return res;
 }
 
@@ -1115,7 +1033,6 @@ u8 rtw_getmacreg_cmd(_adapter *padapter, u8 len, u32 addr)
 	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
 	u8	res = _SUCCESS;
 
-_func_enter_;
 	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL) {
 		res = _FAIL;
@@ -1137,185 +1054,172 @@ _func_enter_;
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 
 exit:
-_func_exit_;
 	return res;
 }
 
 void rtw_usb_catc_trigger_cmd(_adapter *padapter, const char *caller)
 {
-	DBG_871X("%s caller:%s\n", __func__, caller);
+	RTW_INFO("%s caller:%s\n", __func__, caller);
 	rtw_getmacreg_cmd(padapter, 1, 0x1c4);
 }
 
-u8 rtw_setbbreg_cmd(_adapter*padapter, u8 offset, u8 val)
-{	
-	struct cmd_obj*			ph2c;
-	struct writeBB_parm*		pwritebbparm;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;	
-	u8	res=_SUCCESS;
-_func_enter_;
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res= _FAIL;
+u8 rtw_setbbreg_cmd(_adapter *padapter, u8 offset, u8 val)
+{
+	struct cmd_obj			*ph2c;
+	struct writeBB_parm		*pwritebbparm;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
-		}
-	pwritebbparm = (struct writeBB_parm*)rtw_zmalloc(sizeof(struct writeBB_parm)); 
+	}
+	pwritebbparm = (struct writeBB_parm *)rtw_zmalloc(sizeof(struct writeBB_parm));
 
-	if(pwritebbparm==NULL){
+	if (pwritebbparm == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, pwritebbparm, GEN_CMD_CODE(_SetBBReg));	
+	init_h2fwcmd_w_parm_no_rsp(ph2c, pwritebbparm, GEN_CMD_CODE(_SetBBReg));
 
 	pwritebbparm->offset = offset;
 	pwritebbparm->value = val;
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
-exit:	
-_func_exit_;	
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+exit:
 	return res;
 }
 
 u8 rtw_getbbreg_cmd(_adapter  *padapter, u8 offset, u8 *pval)
-{	
-	struct cmd_obj*			ph2c;
-	struct readBB_parm*		prdbbparm;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;
-	u8	res=_SUCCESS;
-	
-_func_enter_;
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res=_FAIL;
+{
+	struct cmd_obj			*ph2c;
+	struct readBB_parm		*prdbbparm;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
-		}
-	prdbbparm = (struct readBB_parm*)rtw_zmalloc(sizeof(struct readBB_parm)); 
+	}
+	prdbbparm = (struct readBB_parm *)rtw_zmalloc(sizeof(struct readBB_parm));
 
-	if(prdbbparm ==NULL){
+	if (prdbbparm == NULL) {
 		rtw_mfree((unsigned char *) ph2c, sizeof(struct	cmd_obj));
 		return _FAIL;
 	}
 
 	_rtw_init_listhead(&ph2c->list);
-	ph2c->cmdcode =GEN_CMD_CODE(_GetBBReg);
+	ph2c->cmdcode = GEN_CMD_CODE(_GetBBReg);
 	ph2c->parmbuf = (unsigned char *)prdbbparm;
 	ph2c->cmdsz =  sizeof(struct readBB_parm);
 	ph2c->rsp = pval;
 	ph2c->rspsz = sizeof(struct readBB_rsp);
-	
-	prdbbparm ->offset = offset;
-	
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
+
+	prdbbparm->offset = offset;
+
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 exit:
-_func_exit_;	
 	return res;
 }
 
 u8 rtw_setrfreg_cmd(_adapter  *padapter, u8 offset, u32 val)
-{	
-	struct cmd_obj*			ph2c;
-	struct writeRF_parm*		pwriterfparm;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;	
-	u8	res=_SUCCESS;
-_func_enter_;
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res= _FAIL;	
+{
+	struct cmd_obj			*ph2c;
+	struct writeRF_parm		*pwriterfparm;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	pwriterfparm = (struct writeRF_parm*)rtw_zmalloc(sizeof(struct writeRF_parm)); 
+	pwriterfparm = (struct writeRF_parm *)rtw_zmalloc(sizeof(struct writeRF_parm));
 
-	if(pwriterfparm==NULL){
+	if (pwriterfparm == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, pwriterfparm, GEN_CMD_CODE(_SetRFReg));	
+	init_h2fwcmd_w_parm_no_rsp(ph2c, pwriterfparm, GEN_CMD_CODE(_SetRFReg));
 
 	pwriterfparm->offset = offset;
 	pwriterfparm->value = val;
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 exit:
-_func_exit_;	
 	return res;
 }
 
 u8 rtw_getrfreg_cmd(_adapter  *padapter, u8 offset, u8 *pval)
-{	
-	struct cmd_obj*			ph2c;
-	struct readRF_parm*		prdrfparm;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;	
-	u8	res=_SUCCESS;
+{
+	struct cmd_obj			*ph2c;
+	struct readRF_parm		*prdrfparm;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
 
-_func_enter_;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
-	prdrfparm = (struct readRF_parm*)rtw_zmalloc(sizeof(struct readRF_parm)); 
-	if(prdrfparm ==NULL){
+	prdrfparm = (struct readRF_parm *)rtw_zmalloc(sizeof(struct readRF_parm));
+	if (prdrfparm == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
 	_rtw_init_listhead(&ph2c->list);
-	ph2c->cmdcode =GEN_CMD_CODE(_GetRFReg);
+	ph2c->cmdcode = GEN_CMD_CODE(_GetRFReg);
 	ph2c->parmbuf = (unsigned char *)prdrfparm;
 	ph2c->cmdsz =  sizeof(struct readRF_parm);
 	ph2c->rsp = pval;
 	ph2c->rspsz = sizeof(struct readRF_rsp);
-	
-	prdrfparm ->offset = offset;
-	
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
+
+	prdrfparm->offset = offset;
+
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 
 exit:
 
-_func_exit_;	
 
 	return res;
 }
 
-void rtw_getbbrfreg_cmdrsp_callback(_adapter*	padapter,  struct cmd_obj *pcmd)
-{       
- _func_enter_;  
-		
-	//rtw_free_cmd_obj(pcmd);
-	rtw_mfree((unsigned char*) pcmd->parmbuf, pcmd->cmdsz);
-	rtw_mfree((unsigned char*) pcmd, sizeof(struct cmd_obj));
-	
+void rtw_getbbrfreg_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
+{
+
+	/* rtw_free_cmd_obj(pcmd); */
+	rtw_mfree((unsigned char *) pcmd->parmbuf, pcmd->cmdsz);
+	rtw_mfree((unsigned char *) pcmd, sizeof(struct cmd_obj));
+
 #ifdef CONFIG_MP_INCLUDED
 	if (padapter->registrypriv.mp_mode == 1)
-		padapter->mppriv.workparam.bcompleted= _TRUE;
-#endif	
-_func_exit_;		
+		padapter->mppriv.workparam.bcompleted = _TRUE;
+#endif
 }
 
-void rtw_readtssi_cmdrsp_callback(_adapter*	padapter,  struct cmd_obj *pcmd)
+void rtw_readtssi_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
 {
- _func_enter_;  
 
-	rtw_mfree((unsigned char*) pcmd->parmbuf, pcmd->cmdsz);
-	rtw_mfree((unsigned char*) pcmd, sizeof(struct cmd_obj));
-	
+	rtw_mfree((unsigned char *) pcmd->parmbuf, pcmd->cmdsz);
+	rtw_mfree((unsigned char *) pcmd, sizeof(struct cmd_obj));
+
 #ifdef CONFIG_MP_INCLUDED
 	if (padapter->registrypriv.mp_mode == 1)
-		padapter->mppriv.workparam.bcompleted= _TRUE;
+		padapter->mppriv.workparam.bcompleted = _TRUE;
 #endif
 
-_func_exit_;
 }
 
 static u8 rtw_createbss_cmd(_adapter  *adapter, int flags, bool adhoc
-	, s16 req_ch, u8 req_bw, u8 req_offset)
+			    , s16 req_ch, s8 req_bw, s8 req_offset)
 {
 	struct cmd_obj *cmdobj;
 	struct createbss_parm *parm;
@@ -1324,6 +1228,13 @@ static u8 rtw_createbss_cmd(_adapter  *adapter, int flags, bool adhoc
 	struct submit_ctx sctx;
 	u8 res = _SUCCESS;
 
+	if (req_ch > 0 && req_bw >= 0 && req_offset >= 0) {
+		if (!rtw_chset_is_chbw_valid(adapter_to_chset(adapter), req_ch, req_bw, req_offset)) {
+			res = _FAIL;
+			goto exit;
+		}
+	}
+
 	/* prepare cmd parameter */
 	parm = (struct createbss_parm *)rtw_zmalloc(sizeof(*parm));
 	if (parm == NULL) {
@@ -1381,7 +1292,7 @@ inline u8 rtw_create_ibss_cmd(_adapter *adapter, int flags)
 {
 	return rtw_createbss_cmd(adapter, flags
 		, 1
-		, -1, 0, 0 /* for now, adhoc doesn't support ch,bw,offset request */
+		, 0, REQ_BW_NONE, REQ_OFFSET_NONE /* for now, adhoc doesn't support ch,bw,offset request */
 	);
 }
 
@@ -1389,11 +1300,11 @@ inline u8 rtw_startbss_cmd(_adapter *adapter, int flags)
 {
 	return rtw_createbss_cmd(adapter, flags
 		, 0
-		, -1, 0, 0 /* doesn't request ch, bw, offset */
+		, 0, REQ_BW_NONE, REQ_OFFSET_NONE /* excute entire AP setup cmd */
 	);
 }
 
-inline u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, u8 req_ch, u8 req_bw, u8 req_offset)
+inline u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, s16 req_ch, s8 req_bw, s8 req_offset)
 {
 	return rtw_createbss_cmd(adapter, flags
 		, 0
@@ -1401,216 +1312,242 @@ inline u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, u8 req_ch, u8 re
 	);
 }
 
-u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network* pnetwork)
+#ifdef CONFIG_RTW_80211R
+static void rtw_ft_validate_akm_type(_adapter  *padapter,
+	struct wlan_network *pnetwork)
 {
-	u8	*auth, res = _SUCCESS;
-	uint	t_len = 0;
-	WLAN_BSSID_EX		*psecnetwork;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u32 tmp_len;
+	u8 *ptmp;
+
+	/*IEEE802.11-2012 Std. Table 8-101—AKM suite selectors*/
+	if (rtw_ft_valid_akm(padapter, psecuritypriv->rsn_akm_suite_type)) {
+		ptmp = rtw_get_ie(&pnetwork->network.IEs[12], 
+				_MDIE_, &tmp_len, (pnetwork->network.IELength-12));
+		if (ptmp) {
+			pft_roam->mdid = *(u16 *)(ptmp+2);
+			pft_roam->ft_cap = *(ptmp+4);
+
+			RTW_INFO("FT: target " MAC_FMT " mdid=(0x%2x), capacity=(0x%2x)\n", 
+				MAC_ARG(pnetwork->network.MacAddress), pft_roam->mdid, pft_roam->ft_cap);
+			rtw_ft_set_flags(padapter, RTW_FT_PEER_EN);
+
+			if (rtw_ft_otd_roam_en(padapter))
+				rtw_ft_set_flags(padapter, RTW_FT_PEER_OTD_EN);
+		} else {
+			/* Don't use FT roaming if target AP cannot support FT */
+			rtw_ft_clr_flags(padapter, (RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN));
+			rtw_ft_reset_status(padapter);
+		}
+	} else {
+		/* It could be a non-FT connection */
+		rtw_ft_clr_flags(padapter, (RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN));
+		rtw_ft_reset_status(padapter);
+	}	
+}
+#endif
+
+u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork)
+{
+	u8	*auth, res = _SUCCESS;
+	uint	t_len = 0;
+	WLAN_BSSID_EX		*psecnetwork;
 	struct cmd_obj		*pcmd;
-	struct cmd_priv		*pcmdpriv=&padapter->cmdpriv;
+	struct cmd_priv		*pcmdpriv = &padapter->cmdpriv;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct qos_priv		*pqospriv= &pmlmepriv->qospriv;
-	struct security_priv	*psecuritypriv=&padapter->securitypriv;
+	struct qos_priv		*pqospriv = &pmlmepriv->qospriv;
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
 #ifdef CONFIG_80211N_HT
 	struct ht_priv			*phtpriv = &pmlmepriv->htpriv;
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 #ifdef CONFIG_80211AC_VHT
 	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
-#endif //CONFIG_80211AC_VHT
+#endif /* CONFIG_80211AC_VHT */
 	NDIS_802_11_NETWORK_INFRASTRUCTURE ndis_network_mode = pnetwork->network.InfrastructureMode;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	u32 tmp_len;
-	u8 *ptmp=NULL;
-_func_enter_;
+	u8 *ptmp = NULL;
 
 	rtw_led_control(padapter, LED_CTL_START_TO_LINK);
 
-	if (pmlmepriv->assoc_ssid.SsidLength == 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 = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(pcmd==NULL){
-		res=_FAIL;
-		RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_, ("rtw_joinbss_cmd: memory allocate for cmd_obj fail!!!\n"));
+	pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	/* // for IEs is pointer 
-	t_len = sizeof (ULONG) + sizeof (NDIS_802_11_MAC_ADDRESS) + 2 + 
-			sizeof (NDIS_802_11_SSID) + sizeof (ULONG) + 
-			sizeof (NDIS_802_11_RSSI) + sizeof (NDIS_802_11_NETWORK_TYPE) + 
-			sizeof (NDIS_802_11_CONFIGURATION) +	
-			sizeof (NDIS_802_11_NETWORK_INFRASTRUCTURE) +   
-			sizeof (NDIS_802_11_RATES_EX)+ sizeof(WLAN_PHY_INFO)+ sizeof (ULONG) + MAX_IE_SZ;
-	*/
-	//for IEs is fix buf size
+#if 0
+	/*  for IEs is pointer */
+	t_len = sizeof(ULONG) + sizeof(NDIS_802_11_MAC_ADDRESS) + 2 +
+		sizeof(NDIS_802_11_SSID) + sizeof(ULONG) +
+		sizeof(NDIS_802_11_RSSI) + sizeof(NDIS_802_11_NETWORK_TYPE) +
+		sizeof(NDIS_802_11_CONFIGURATION) +
+		sizeof(NDIS_802_11_NETWORK_INFRASTRUCTURE) +
+		sizeof(NDIS_802_11_RATES_EX) + sizeof(WLAN_PHY_INFO) + sizeof(ULONG) + MAX_IE_SZ;
+#endif
+	/* for IEs is fix buf size */
 	t_len = sizeof(WLAN_BSSID_EX);
 
 
-	//for hidden ap to set fw_state here
-	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) != _TRUE)
-	{
-		switch(ndis_network_mode)
-		{
-			case Ndis802_11IBSS:
-				set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
-				break;
-
-			case Ndis802_11Infrastructure:
-				set_fwstate(pmlmepriv, WIFI_STATION_STATE);
-				break;
+	/* for hidden ap to set fw_state here */
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) != _TRUE) {
+		switch (ndis_network_mode) {
+		case Ndis802_11IBSS:
+			set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
+			break;
 
-			case Ndis802_11APMode:
-			case Ndis802_11AutoUnknown:
-			case Ndis802_11InfrastructureMax:
-			case Ndis802_11Monitor:
-				break;
+		case Ndis802_11Infrastructure:
+			set_fwstate(pmlmepriv, WIFI_STATION_STATE);
+			break;
 
+		default:
+			rtw_warn_on(1);
+			break;
 		}
 	}
 
 	pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pnetwork->network.IEs, pnetwork->network.IELength);
 
-	/* 
+#ifdef CONFIG_80211AC_VHT
+	/* save AP beamform_cap info for BCM IOT issue */
+	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM)
+		pvhtpriv->ap_is_mu_bfer =
+			get_vht_mu_bfer_cap(pnetwork->network.IEs,
+				pnetwork->network.IELength);
+#endif
+	/*
 		Modified by Arvin 2015/05/13
-		Solution for allocating a new WLAN_BSSID_EX to avoid race condition issue between disconnect and joinbss 
+		Solution for allocating a new WLAN_BSSID_EX to avoid race condition issue between disconnect and joinbss
 	*/
 	psecnetwork = (WLAN_BSSID_EX *)rtw_zmalloc(sizeof(WLAN_BSSID_EX));
-	if(psecnetwork==NULL)
-	{
-		if(pcmd !=NULL)
+	if (psecnetwork == NULL) {
+		if (pcmd != NULL)
 			rtw_mfree((unsigned char *)pcmd, sizeof(struct	cmd_obj));
-		
-		res=_FAIL;
-		
-		RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_, ("rtw_joinbss_cmd :psecnetwork==NULL!!!\n"));
-		
+
+		res = _FAIL;
+
+
 		goto exit;
 	}
 
 	_rtw_memset(psecnetwork, 0, t_len);
 
 	_rtw_memcpy(psecnetwork, &pnetwork->network, get_WLAN_BSSID_EX_sz(&pnetwork->network));
-	
-	auth=&psecuritypriv->authenticator_ie[0];
-	psecuritypriv->authenticator_ie[0]=(unsigned char)psecnetwork->IELength;
 
-	if((psecnetwork->IELength-12) < (256-1)) {
-		_rtw_memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], psecnetwork->IELength-12);
-	} else {
-		_rtw_memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], (256-1));
-	}
-	  
+	auth = &psecuritypriv->authenticator_ie[0];
+	psecuritypriv->authenticator_ie[0] = (unsigned char)psecnetwork->IELength;
+
+	if ((psecnetwork->IELength - 12) < (256 - 1))
+		_rtw_memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], psecnetwork->IELength - 12);
+	else
+		_rtw_memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], (256 - 1));
+
 	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 )
-	{
-		_rtw_memcpy( &pmlmepriv->assoc_bssid[ 0 ], &pnetwork->network.MacAddress[ 0 ], ETH_ALEN );
-	}
+	/* 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)
+		_rtw_memcpy(&pmlmepriv->assoc_bssid[0], &pnetwork->network.MacAddress[0], ETH_ALEN);
 
-	psecnetwork->IELength = rtw_restruct_sec_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0], pnetwork->network.IELength);
+	/* copy fixed ie */
+	_rtw_memcpy(psecnetwork->IEs, pnetwork->network.IEs, 12);
+	psecnetwork->IELength = 12;
+
+	psecnetwork->IELength += rtw_restruct_sec_ie(padapter, psecnetwork->IEs + psecnetwork->IELength);
 
 
 	pqospriv->qos_option = 0;
-	
-	if(pregistrypriv->wmm_enable)	
-	{
-		tmp_len = rtw_restruct_wmm_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0], pnetwork->network.IELength, psecnetwork->IELength);	
 
-		if (psecnetwork->IELength != tmp_len)		
-		{
+	if (pregistrypriv->wmm_enable) {
+#ifdef CONFIG_WMMPS_STA	
+		rtw_uapsd_use_default_setting(padapter);
+#endif /* CONFIG_WMMPS_STA */		
+		tmp_len = rtw_restruct_wmm_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0], pnetwork->network.IELength, psecnetwork->IELength);
+
+		if (psecnetwork->IELength != tmp_len) {
 			psecnetwork->IELength = tmp_len;
-			pqospriv->qos_option = 1; //There is WMM IE in this corresp. beacon
+			pqospriv->qos_option = 1; /* There is WMM IE in this corresp. beacon */
+		} else {
+			pqospriv->qos_option = 0;/* There is no WMM IE in this corresp. beacon */
 		}
-		else 
-		{
-			pqospriv->qos_option = 0;//There is no WMM IE in this corresp. beacon
-		}		
-	}	
+	}
 
 #ifdef CONFIG_80211N_HT
 	phtpriv->ht_option = _FALSE;
-	ptmp = rtw_get_ie(&pnetwork->network.IEs[12], _HT_CAPABILITY_IE_, &tmp_len, pnetwork->network.IELength-12);
-	if(pregistrypriv->ht_enable && ptmp && tmp_len>0)
-	{
-		//	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 (	( padapter->securitypriv.dot11PrivacyAlgrthm != _WEP40_ ) &&
-			( padapter->securitypriv.dot11PrivacyAlgrthm != _WEP104_ ) &&
-			( padapter->securitypriv.dot11PrivacyAlgrthm != _TKIP_ ))
-		{
+	ptmp = rtw_get_ie(&pnetwork->network.IEs[12], _HT_CAPABILITY_IE_, &tmp_len, pnetwork->network.IELength - 12);
+	if (pregistrypriv->ht_enable && ptmp && tmp_len > 0) {
+		/*	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 ((padapter->securitypriv.dot11PrivacyAlgrthm != _WEP40_) &&
+		    (padapter->securitypriv.dot11PrivacyAlgrthm != _WEP104_) &&
+		    (padapter->securitypriv.dot11PrivacyAlgrthm != _TKIP_)) {
 			rtw_ht_use_default_setting(padapter);
 
-			rtw_build_wmm_ie_ht(padapter, &psecnetwork->IEs[0], &psecnetwork->IELength);
-
-			//rtw_restructure_ht_ie
-			rtw_restructure_ht_ie(padapter, &pnetwork->network.IEs[12], &psecnetwork->IEs[0], 
-									pnetwork->network.IELength-12, &psecnetwork->IELength,
-									pnetwork->network.Configuration.DSConfig);
+			/* rtw_restructure_ht_ie */
+			rtw_restructure_ht_ie(padapter, &pnetwork->network.IEs[12], &psecnetwork->IEs[0],
+				pnetwork->network.IELength - 12, &psecnetwork->IELength,
+				pnetwork->network.Configuration.DSConfig);
 		}
 	}
 
 #ifdef CONFIG_80211AC_VHT
 	pvhtpriv->vht_option = _FALSE;
 	if (phtpriv->ht_option
-		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
-		&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-		&& (!pmlmepriv->country_ent || COUNTRY_CHPLAN_EN_11AC(pmlmepriv->country_ent))
-	) {
-		rtw_restructure_vht_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0], 
-								pnetwork->network.IELength, &psecnetwork->IELength);
+	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
+	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+	   ) {
+		rtw_restructure_vht_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0],
+			pnetwork->network.IELength, &psecnetwork->IELength);
 	}
 #endif
 
 	rtw_append_exented_cap(padapter, &psecnetwork->IEs[0], &psecnetwork->IELength);
 
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_RTW_80211R
+	rtw_ft_validate_akm_type(padapter, pnetwork);
+#endif
 
-	#if 0
-	psecuritypriv->supplicant_ie[0]=(u8)psecnetwork->IELength;
+#if 0
+	psecuritypriv->supplicant_ie[0] = (u8)psecnetwork->IELength;
 
-	if(psecnetwork->IELength < (256-1))
-	{
+	if (psecnetwork->IELength < (256 - 1))
 		_rtw_memcpy(&psecuritypriv->supplicant_ie[1], &psecnetwork->IEs[0], psecnetwork->IELength);
-	}
 	else
-	{
-		_rtw_memcpy(&psecuritypriv->supplicant_ie[1], &psecnetwork->IEs[0], (256-1));
-	}
-	#endif
-	
+		_rtw_memcpy(&psecuritypriv->supplicant_ie[1], &psecnetwork->IEs[0], (256 - 1));
+#endif
+
 	pcmd->cmdsz = sizeof(WLAN_BSSID_EX);
 
 #ifdef CONFIG_RTL8712
-	//wlan_network endian conversion	
+	/* wlan_network endian conversion	 */
 	psecnetwork->Length = cpu_to_le32(psecnetwork->Length);
-	psecnetwork->Ssid.SsidLength= cpu_to_le32(psecnetwork->Ssid.SsidLength);
+	psecnetwork->Ssid.SsidLength = cpu_to_le32(psecnetwork->Ssid.SsidLength);
 	psecnetwork->Privacy = cpu_to_le32(psecnetwork->Privacy);
 	psecnetwork->Rssi = cpu_to_le32(psecnetwork->Rssi);
 	psecnetwork->NetworkTypeInUse = cpu_to_le32(psecnetwork->NetworkTypeInUse);
 	psecnetwork->Configuration.ATIMWindow = cpu_to_le32(psecnetwork->Configuration.ATIMWindow);
 	psecnetwork->Configuration.BeaconPeriod = cpu_to_le32(psecnetwork->Configuration.BeaconPeriod);
 	psecnetwork->Configuration.DSConfig = cpu_to_le32(psecnetwork->Configuration.DSConfig);
-	psecnetwork->Configuration.FHConfig.DwellTime=cpu_to_le32(psecnetwork->Configuration.FHConfig.DwellTime);
-	psecnetwork->Configuration.FHConfig.HopPattern=cpu_to_le32(psecnetwork->Configuration.FHConfig.HopPattern);
-	psecnetwork->Configuration.FHConfig.HopSet=cpu_to_le32(psecnetwork->Configuration.FHConfig.HopSet);
-	psecnetwork->Configuration.FHConfig.Length=cpu_to_le32(psecnetwork->Configuration.FHConfig.Length);	
+	psecnetwork->Configuration.FHConfig.DwellTime = cpu_to_le32(psecnetwork->Configuration.FHConfig.DwellTime);
+	psecnetwork->Configuration.FHConfig.HopPattern = cpu_to_le32(psecnetwork->Configuration.FHConfig.HopPattern);
+	psecnetwork->Configuration.FHConfig.HopSet = cpu_to_le32(psecnetwork->Configuration.FHConfig.HopSet);
+	psecnetwork->Configuration.FHConfig.Length = cpu_to_le32(psecnetwork->Configuration.FHConfig.Length);
 	psecnetwork->Configuration.Length = cpu_to_le32(psecnetwork->Configuration.Length);
 	psecnetwork->InfrastructureMode = cpu_to_le32(psecnetwork->InfrastructureMode);
-	psecnetwork->IELength = cpu_to_le32(psecnetwork->IELength);      
+	psecnetwork->IELength = cpu_to_le32(psecnetwork->IELength);
 #endif
 
 	_rtw_init_listhead(&pcmd->list);
-	pcmd->cmdcode = _JoinBss_CMD_;//GEN_CMD_CODE(_JoinBss)
+	pcmd->cmdcode = _JoinBss_CMD_;/* GEN_CMD_CODE(_JoinBss) */
 	pcmd->parmbuf = (unsigned char *)psecnetwork;
 	pcmd->rsp = NULL;
 	pcmd->rspsz = 0;
@@ -1618,22 +1555,21 @@ _func_enter_;
 	res = rtw_enqueue_cmd(pcmdpriv, pcmd);
 
 exit:
-	
-_func_exit_;
+
 
 	return res;
 }
 
-u8 rtw_disassoc_cmd(_adapter*padapter, u32 deauth_timeout_ms, bool enqueue) /* for sta_mode */
+u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, int flags) /* for sta_mode */
 {
 	struct cmd_obj *cmdobj = NULL;
 	struct disconnect_parm *param = NULL;
 	struct cmd_priv *cmdpriv = &padapter->cmdpriv;
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	struct submit_ctx sctx;
 	u8 res = _SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_cmd_c_, _drv_notice_, ("+rtw_disassoc_cmd\n"));
 
 	/* prepare cmd parameter */
 	param = (struct disconnect_parm *)rtw_zmalloc(sizeof(*param));
@@ -1643,8 +1579,13 @@ _func_enter_;
 	}
 	param->deauth_timeout_ms = deauth_timeout_ms;
 
-	if (enqueue) {
-		/* need enqueue, prepare cmd_obj and enqueue */
+	if (flags & RTW_CMDF_DIRECTLY) {
+		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
+		if (disconnect_hdl(padapter, (u8 *)param) != H2C_SUCCESS)
+			res = _FAIL;
+		rtw_mfree((u8 *)param, sizeof(*param));
+
+	} else {
 		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
 		if (cmdobj == NULL) {
 			res = _FAIL;
@@ -1652,177 +1593,189 @@ _func_enter_;
 			goto exit;
 		}
 		init_h2fwcmd_w_parm_no_rsp(cmdobj, param, _DisConnect_CMD_);
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			cmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 2000);
+		}
 		res = rtw_enqueue_cmd(cmdpriv, cmdobj);
-	} else {
-		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
-		if (H2C_SUCCESS != disconnect_hdl(padapter, (u8 *)param))
-			res = _FAIL;
-		rtw_mfree((u8 *)param, sizeof(*param));
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+		}
 	}
 
 exit:
 
-_func_exit_;	
 
 	return res;
 }
 
-u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, bool enqueue)
+u8 rtw_setopmode_cmd(_adapter  *adapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, u8 flags)
 {
-	struct	cmd_obj*	ph2c;
-	struct	setopmode_parm* psetop;
-
-	struct	cmd_priv   *pcmdpriv= &padapter->cmdpriv;
-	u8	res=_SUCCESS;
-
-_func_enter_;
-	psetop = (struct setopmode_parm*)rtw_zmalloc(sizeof(struct setopmode_parm)); 
+	struct cmd_obj *cmdobj;
+	struct setopmode_parm *parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
+	u8 res = _SUCCESS;
 
-	if(psetop==NULL){		
-		res=_FAIL;
+	/* prepare cmd parameter */
+	parm = (struct setopmode_parm *)rtw_zmalloc(sizeof(*parm));
+	if (parm == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	psetop->mode = (u8)networktype;
-	
-	if(enqueue){
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));			
-		if(ph2c==NULL){		
-			rtw_mfree((u8 *)psetop, sizeof(*psetop));
-			res= _FAIL;
+	parm->mode = (u8)networktype;
+
+	if (flags & RTW_CMDF_DIRECTLY) {
+		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
+		if (H2C_SUCCESS != setopmode_hdl(adapter, (u8 *)parm))
+			res = _FAIL;
+		rtw_mfree((u8 *)parm, sizeof(*parm));
+	} else {
+		/* need enqueue, prepare cmd_obj and enqueue */
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
+		if (cmdobj == NULL) {
+			res = _FAIL;
+			rtw_mfree((u8 *)parm, sizeof(*parm));
 			goto exit;
-		}	
+		}
 
-		init_h2fwcmd_w_parm_no_rsp(ph2c, psetop, _SetOpMode_CMD_);
-		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	}
-	else{
-		setopmode_hdl(padapter, (u8 *)psetop);
-		rtw_mfree((u8 *)psetop, sizeof(*psetop));
-	}
-exit:
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, _SetOpMode_CMD_);
+
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			cmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 2000);
+		}
+
+		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
 
-_func_exit_;	
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+		}
+	}
 
+exit:
 	return res;
 }
 
 u8 rtw_setstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 key_type, bool enqueue)
 {
-	struct cmd_obj*			ph2c;
+	struct cmd_obj			*ph2c;
 	struct set_stakey_parm	*psetstakey_para;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;
+	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;
-	u8	res=_SUCCESS;
+	struct security_priv		*psecuritypriv = &padapter->securitypriv;
+	u8	res = _SUCCESS;
 
-_func_enter_;
 
-	psetstakey_para = (struct set_stakey_parm*)rtw_zmalloc(sizeof(struct set_stakey_parm));
-	if(psetstakey_para==NULL){	
-		res=_FAIL;
+	psetstakey_para = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
+	if (psetstakey_para == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-		
-	_rtw_memcpy(psetstakey_para->addr, sta->hwaddr,ETH_ALEN);
-		
-	if(check_fwstate(pmlmepriv, WIFI_STATION_STATE)){
-			psetstakey_para->algorithm =(unsigned char) psecuritypriv->dot11PrivacyAlgrthm;
-	}else{
+
+	_rtw_memcpy(psetstakey_para->addr, sta->cmn.mac_addr, ETH_ALEN);
+
+	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 (key_type == GROUP_KEY) {
 		_rtw_memcpy(&psetstakey_para->key, &psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey, 16);
-	}
-	else if (key_type == UNICAST_KEY) {
+		psetstakey_para->gk = 1;
+	} else if (key_type == UNICAST_KEY)
 		_rtw_memcpy(&psetstakey_para->key, &sta->dot118021x_UncstKey, 16);
-	}
 #ifdef CONFIG_TDLS
-	else if(key_type == TDLS_KEY){
-			_rtw_memcpy(&psetstakey_para->key, sta->tpk.tk, 16);
-		psetstakey_para->algorithm=(u8)sta->dot118021XPrivacy;
-       }
+	else if (key_type == TDLS_KEY) {
+		_rtw_memcpy(&psetstakey_para->key, sta->tpk.tk, 16);
+		psetstakey_para->algorithm = (u8)sta->dot118021XPrivacy;
+	}
 #endif /* CONFIG_TDLS */
 
-	//jeff: set this becasue at least sw key is ready
-	padapter->securitypriv.busetkipkey=_TRUE;
+	/* jeff: set this becasue at least sw key is ready */
+	padapter->securitypriv.busetkipkey = _TRUE;
 
-	if(enqueue)
-	{
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-		if ( ph2c == NULL){
+	if (enqueue) {
+		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (ph2c == NULL) {
 			rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
-			res= _FAIL;
+			res = _FAIL;
 			goto exit;
-		}	
+		}
 
-		psetstakey_rsp = (struct set_stakey_rsp*)rtw_zmalloc(sizeof(struct set_stakey_rsp)); 
-		if(psetstakey_rsp == NULL){
+		psetstakey_rsp = (struct set_stakey_rsp *)rtw_zmalloc(sizeof(struct set_stakey_rsp));
+		if (psetstakey_rsp == NULL) {
 			rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
 			rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
-			res=_FAIL;
+			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);
-		res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
-	}
-	else{
+		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+	} else {
 		set_stakey_hdl(padapter, (u8 *)psetstakey_para);
 		rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
 	}
 exit:
 
-_func_exit_;	
 
 	return res;
 }
 
 u8 rtw_clearstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 enqueue)
 {
-	struct cmd_obj*			ph2c;
+	struct cmd_obj			*ph2c;
 	struct set_stakey_parm	*psetstakey_para;
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;
-	struct set_stakey_rsp		*psetstakey_rsp = NULL;	
+	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 security_priv		*psecuritypriv = &padapter->securitypriv;
 	s16 cam_id = 0;
-	u8	res=_SUCCESS;
+	u8	res = _SUCCESS;
 
-_func_enter_;
+	if (!sta) {
+		RTW_ERR("%s sta == NULL\n", __func__);
+		goto exit;
+	}
 
-	if(!enqueue)
-	{
-		while ((cam_id = rtw_camid_search(padapter, sta->hwaddr, -1, -1)) >= 0) {
-			DBG_871X_LEVEL(_drv_always_, "clear key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(sta->hwaddr), cam_id);
+	if (!enqueue) {
+		while ((cam_id = rtw_camid_search(padapter, sta->cmn.mac_addr, -1, -1)) >= 0) {
+			RTW_PRINT("clear key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(sta->cmn.mac_addr), cam_id);
 			clear_cam_entry(padapter, cam_id);
 			rtw_camid_free(padapter, cam_id);
 		}
-	}
-	else
-	{
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-		if ( ph2c == NULL){
-			res= _FAIL;
+	} else {
+		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (ph2c == NULL) {
+			res = _FAIL;
 			goto exit;
 		}
 
-		psetstakey_para = (struct set_stakey_parm*)rtw_zmalloc(sizeof(struct set_stakey_parm));
-		if(psetstakey_para==NULL){
+		psetstakey_para = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
+		if (psetstakey_para == NULL) {
 			rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
-			res=_FAIL;
+			res = _FAIL;
 			goto exit;
 		}
 
-		psetstakey_rsp = (struct set_stakey_rsp*)rtw_zmalloc(sizeof(struct set_stakey_rsp)); 
-		if(psetstakey_rsp == NULL){
+		psetstakey_rsp = (struct set_stakey_rsp *)rtw_zmalloc(sizeof(struct set_stakey_rsp));
+		if (psetstakey_rsp == NULL) {
 			rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
 			rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
-			res=_FAIL;
+			res = _FAIL;
 			goto exit;
 		}
 
@@ -1830,118 +1783,112 @@ _func_enter_;
 		ph2c->rsp = (u8 *) psetstakey_rsp;
 		ph2c->rspsz = sizeof(struct set_stakey_rsp);
 
-		_rtw_memcpy(psetstakey_para->addr, sta->hwaddr, ETH_ALEN);
+		_rtw_memcpy(psetstakey_para->addr, sta->cmn.mac_addr, ETH_ALEN);
 
 		psetstakey_para->algorithm = _NO_PRIVACY_;
-	
-		res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
-		
+
+		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+
 	}
-	
+
 exit:
 
-_func_exit_;	
 
 	return res;
 }
 
 u8 rtw_setrttbl_cmd(_adapter  *padapter, struct setratable_parm *prate_table)
 {
-	struct cmd_obj*			ph2c;
-	struct setratable_parm *	psetrttblparm;	
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;
-	u8	res=_SUCCESS;
-_func_enter_;	
+	struct cmd_obj			*ph2c;
+	struct setratable_parm	*psetrttblparm;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
-		}
-	psetrttblparm = (struct setratable_parm*)rtw_zmalloc(sizeof(struct setratable_parm)); 
+	}
+	psetrttblparm = (struct setratable_parm *)rtw_zmalloc(sizeof(struct setratable_parm));
 
-	if(psetrttblparm==NULL){
+	if (psetrttblparm == NULL) {
 		rtw_mfree((unsigned char *) ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, psetrttblparm, GEN_CMD_CODE(_SetRaTable));
 
-	_rtw_memcpy(psetrttblparm,prate_table,sizeof(struct setratable_parm));
+	_rtw_memcpy(psetrttblparm, prate_table, sizeof(struct setratable_parm));
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 exit:
-_func_exit_;	
 	return res;
 
 }
 
 u8 rtw_getrttbl_cmd(_adapter  *padapter, struct getratable_rsp *pval)
 {
-	struct cmd_obj*			ph2c;
-	struct getratable_parm *	pgetrttblparm;	
-	struct cmd_priv 			*pcmdpriv=&padapter->cmdpriv;
-	u8	res=_SUCCESS;
-_func_enter_;	
+	struct cmd_obj			*ph2c;
+	struct getratable_parm	*pgetrttblparm;
+	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	pgetrttblparm = (struct getratable_parm*)rtw_zmalloc(sizeof(struct getratable_parm)); 
+	pgetrttblparm = (struct getratable_parm *)rtw_zmalloc(sizeof(struct getratable_parm));
 
-	if(pgetrttblparm==NULL){
+	if (pgetrttblparm == NULL) {
 		rtw_mfree((unsigned char *) ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-//	init_h2fwcmd_w_parm_no_rsp(ph2c, psetrttblparm, GEN_CMD_CODE(_SetRaTable));
+	/*	init_h2fwcmd_w_parm_no_rsp(ph2c, psetrttblparm, GEN_CMD_CODE(_SetRaTable)); */
 
 	_rtw_init_listhead(&ph2c->list);
-	ph2c->cmdcode =GEN_CMD_CODE(_GetRaTable);
+	ph2c->cmdcode = GEN_CMD_CODE(_GetRaTable);
 	ph2c->parmbuf = (unsigned char *)pgetrttblparm;
 	ph2c->cmdsz =  sizeof(struct getratable_parm);
-	ph2c->rsp = (u8*)pval;
+	ph2c->rsp = (u8 *)pval;
 	ph2c->rspsz = sizeof(struct getratable_rsp);
-	
-	pgetrttblparm ->rsvd = 0x0;
-	
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
+
+	pgetrttblparm->rsvd = 0x0;
+
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 exit:
-_func_exit_;	
 	return res;
 
 }
 
 u8 rtw_setassocsta_cmd(_adapter  *padapter, u8 *mac_addr)
 {
-	struct cmd_priv 		*pcmdpriv = &padapter->cmdpriv;
-	struct cmd_obj*			ph2c;
-	struct set_assocsta_parm	*psetassocsta_para;	
+	struct cmd_priv		*pcmdpriv = &padapter->cmdpriv;
+	struct cmd_obj			*ph2c;
+	struct set_assocsta_parm	*psetassocsta_para;
 	struct set_stakey_rsp		*psetassocsta_rsp = NULL;
 
-	u8	res=_SUCCESS;
+	u8	res = _SUCCESS;
 
-_func_enter_;	
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
-	psetassocsta_para = (struct set_assocsta_parm*)rtw_zmalloc(sizeof(struct set_assocsta_parm));
-	if(psetassocsta_para==NULL){
+	psetassocsta_para = (struct set_assocsta_parm *)rtw_zmalloc(sizeof(struct set_assocsta_parm));
+	if (psetassocsta_para == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
-		res=_FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	psetassocsta_rsp = (struct set_stakey_rsp*)rtw_zmalloc(sizeof(struct set_assocsta_rsp)); 
-	if(psetassocsta_rsp==NULL){
+	psetassocsta_rsp = (struct set_stakey_rsp *)rtw_zmalloc(sizeof(struct set_assocsta_rsp));
+	if (psetassocsta_rsp == NULL) {
 		rtw_mfree((u8 *) ph2c, sizeof(struct	cmd_obj));
 		rtw_mfree((u8 *) psetassocsta_para, sizeof(struct set_assocsta_parm));
 		return _FAIL;
@@ -1951,37 +1898,35 @@ _func_enter_;
 	ph2c->rsp = (u8 *) psetassocsta_rsp;
 	ph2c->rspsz = sizeof(struct set_assocsta_rsp);
 
-	_rtw_memcpy(psetassocsta_para->addr, mac_addr,ETH_ALEN);
-	
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);	
+	_rtw_memcpy(psetassocsta_para->addr, mac_addr, ETH_ALEN);
+
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 
 exit:
 
-_func_exit_;	
 
 	return res;
- }
+}
 
-u8 rtw_addbareq_cmd(_adapter*padapter, u8 tid, u8 *addr)
+u8 rtw_addbareq_cmd(_adapter *padapter, u8 tid, u8 *addr)
 {
 	struct cmd_priv		*pcmdpriv = &padapter->cmdpriv;
-	struct cmd_obj*		ph2c;
+	struct cmd_obj		*ph2c;
 	struct addBaReq_parm	*paddbareq_parm;
 
-	u8	res=_SUCCESS;
-	
-_func_enter_;	
+	u8	res = _SUCCESS;
+
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	
-	paddbareq_parm = (struct addBaReq_parm*)rtw_zmalloc(sizeof(struct addBaReq_parm)); 
-	if(paddbareq_parm==NULL){
+
+	paddbareq_parm = (struct addBaReq_parm *)rtw_zmalloc(sizeof(struct addBaReq_parm));
+	if (paddbareq_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -1990,199 +1935,236 @@ _func_enter_;
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, paddbareq_parm, GEN_CMD_CODE(_AddBAReq));
 
-	//DBG_871X("rtw_addbareq_cmd, tid=%d\n", tid);
+	/* RTW_INFO("rtw_addbareq_cmd, tid=%d\n", tid); */
 
-	//rtw_enqueue_cmd(pcmdpriv, ph2c);	
+	/* rtw_enqueue_cmd(pcmdpriv, ph2c);	 */
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
+
 exit:
-	
-_func_exit_;
+
 
 	return res;
 }
-//add for CONFIG_IEEE80211W, none 11w can use it
-u8 rtw_reset_securitypriv_cmd(_adapter*padapter)
+
+u8 rtw_addbarsp_cmd(_adapter *padapter, u8 *addr, u16 tid, u8 status, u8 size, u16 start_seq)
 {
-	struct cmd_obj*		ph2c;
-	struct drvextra_cmd_parm  *pdrvextra_cmd_parm;	
-	struct cmd_priv	*pcmdpriv=&padapter->cmdpriv;
-	u8	res=_SUCCESS;
-	
-_func_enter_;	
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	struct cmd_obj *ph2c;
+	struct addBaRsp_parm *paddBaRsp_parm;
+	u8 res = _SUCCESS;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
+
+	paddBaRsp_parm = (struct addBaRsp_parm *)rtw_zmalloc(sizeof(struct addBaRsp_parm));
+
+	if (paddBaRsp_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm->ec_id = RESET_SECURITYPRIV;
-	pdrvextra_cmd_parm->type = 0;
-	pdrvextra_cmd_parm->size = 0;
-	pdrvextra_cmd_parm->pbuf = NULL;
+	_rtw_memcpy(paddBaRsp_parm->addr, addr, ETH_ALEN);
+	paddBaRsp_parm->tid = tid;
+	paddBaRsp_parm->status = status;
+	paddBaRsp_parm->size = size;
+	paddBaRsp_parm->start_seq = start_seq;
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+	init_h2fwcmd_w_parm_no_rsp(ph2c, paddBaRsp_parm, GEN_CMD_CODE(_AddBARsp));
 
-	
-	//rtw_enqueue_cmd(pcmdpriv, ph2c);	
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
+
 exit:
-	
-_func_exit_;
 
-	return res;
 
+	return res;
 }
-
-u8 rtw_free_assoc_resources_cmd(_adapter*padapter)
+/* add for CONFIG_IEEE80211W, none 11w can use it */
+u8 rtw_reset_securitypriv_cmd(_adapter *padapter)
 {
-	struct cmd_obj*		ph2c;
-	struct drvextra_cmd_parm  *pdrvextra_cmd_parm;	
-	struct cmd_priv	*pcmdpriv=&padapter->cmdpriv;
-	u8	res=_SUCCESS;
-	
-_func_enter_;	
+	struct cmd_obj		*ph2c;
+	struct drvextra_cmd_parm  *pdrvextra_cmd_parm;
+	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
+
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm->ec_id = FREE_ASSOC_RESOURCES;
+	pdrvextra_cmd_parm->ec_id = RESET_SECURITYPRIV;
 	pdrvextra_cmd_parm->type = 0;
 	pdrvextra_cmd_parm->size = 0;
 	pdrvextra_cmd_parm->pbuf = NULL;
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
-	
-	//rtw_enqueue_cmd(pcmdpriv, ph2c);	
+
+	/* rtw_enqueue_cmd(pcmdpriv, ph2c);	 */
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
+
 exit:
-	
-_func_exit_;
+
 
 	return res;
 
 }
 
-u8 rtw_dynamic_chk_wk_cmd(_adapter*padapter)
+u8 rtw_free_assoc_resources_cmd(_adapter *padapter, u8 lock_scanned_queue)
 {
-	struct cmd_obj*		ph2c;
-	struct drvextra_cmd_parm  *pdrvextra_cmd_parm;	
-	struct cmd_priv	*pcmdpriv=&padapter->cmdpriv;
-	u8	res=_SUCCESS;
-	
-_func_enter_;	
+	struct cmd_obj		*ph2c;
+	struct drvextra_cmd_parm  *pdrvextra_cmd_parm;
+	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
 
-	//only  primary padapter does this cmd
-/*
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->adapter_type != PRIMARY_ADAPTER && padapter->pbuddy_adapter)
-		pcmdpriv = &(padapter->pbuddy_adapter->cmdpriv);
-#endif
-*/
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm->ec_id = DYNAMIC_CHK_WK_CID;
-	pdrvextra_cmd_parm->type = 0;
+	pdrvextra_cmd_parm->ec_id = FREE_ASSOC_RESOURCES;
+	pdrvextra_cmd_parm->type = lock_scanned_queue;
 	pdrvextra_cmd_parm->size = 0;
 	pdrvextra_cmd_parm->pbuf = NULL;
+
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
-	
-	//rtw_enqueue_cmd(pcmdpriv, ph2c);	
+
+	/* rtw_enqueue_cmd(pcmdpriv, ph2c);	 */
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
+
 exit:
-	
-_func_exit_;
+
 
 	return res;
 
 }
 
-u8 rtw_set_ch_cmd(_adapter*padapter, u8 ch, u8 bw, u8 ch_offset, u8 enqueue)
+u8 rtw_dynamic_chk_wk_cmd(_adapter *padapter)
 {
-	struct cmd_obj *pcmdobj;
+	struct cmd_obj		*ph2c;
+	struct drvextra_cmd_parm  *pdrvextra_cmd_parm;
+	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
+
+
+	/* only  primary padapter does this cmd */
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm->ec_id = DYNAMIC_CHK_WK_CID;
+	pdrvextra_cmd_parm->type = 0;
+	pdrvextra_cmd_parm->size = 0;
+	pdrvextra_cmd_parm->pbuf = NULL;
+	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+
+	/* rtw_enqueue_cmd(pcmdpriv, ph2c);	 */
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+
+exit:
+
+
+	return res;
+
+}
+
+u8 rtw_set_chbw_cmd(_adapter *padapter, u8 ch, u8 bw, u8 ch_offset, u8 flags)
+{
+	struct cmd_obj *pcmdobj;
 	struct set_ch_parm *set_ch_parm;
 	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	struct submit_ctx sctx;
+	u8 res = _SUCCESS;
 
-	u8 res=_SUCCESS;
-
-_func_enter_;
 
-	DBG_871X(FUNC_NDEV_FMT" ch:%u, bw:%u, ch_offset:%u\n",
-		FUNC_NDEV_ARG(padapter->pnetdev), ch, bw, ch_offset);
+	RTW_INFO(FUNC_NDEV_FMT" ch:%u, bw:%u, ch_offset:%u\n",
+		 FUNC_NDEV_ARG(padapter->pnetdev), ch, bw, ch_offset);
 
 	/* check input parameter */
 
 	/* prepare cmd parameter */
 	set_ch_parm = (struct set_ch_parm *)rtw_zmalloc(sizeof(*set_ch_parm));
 	if (set_ch_parm == NULL) {
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 	set_ch_parm->ch = ch;
 	set_ch_parm->bw = bw;
 	set_ch_parm->ch_offset = ch_offset;
 
-	if (enqueue) {
+	if (flags & RTW_CMDF_DIRECTLY) {
+		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
+		if (H2C_SUCCESS != rtw_set_chbw_hdl(padapter, (u8 *)set_ch_parm))
+			res = _FAIL;
+
+		rtw_mfree((u8 *)set_ch_parm, sizeof(*set_ch_parm));
+	} else {
 		/* need enqueue, prepare cmd_obj and enqueue */
-		pcmdobj = (struct cmd_obj*)rtw_zmalloc(sizeof(struct	cmd_obj));
-		if(pcmdobj == NULL){
+		pcmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
+		if (pcmdobj == NULL) {
 			rtw_mfree((u8 *)set_ch_parm, sizeof(*set_ch_parm));
-			res=_FAIL;
+			res = _FAIL;
 			goto exit;
 		}
 
 		init_h2fwcmd_w_parm_no_rsp(pcmdobj, set_ch_parm, GEN_CMD_CODE(_SetChannel));
+
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			pcmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 10 * 1000);
+		}
+
 		res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
-	} else {
-		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
-		if( H2C_SUCCESS !=set_ch_hdl(padapter, (u8 *)set_ch_parm) )
-			res = _FAIL;
-		
-		rtw_mfree((u8 *)set_ch_parm, sizeof(*set_ch_parm));
+
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				pcmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+		}
 	}
 
 	/* do something based on res... */
 
 exit:
 
-	DBG_871X(FUNC_NDEV_FMT" res:%u\n", FUNC_NDEV_ARG(padapter->pnetdev), res);
+	RTW_INFO(FUNC_NDEV_FMT" res:%u\n", FUNC_NDEV_ARG(padapter->pnetdev), res);
 
-_func_exit_;	
 
 	return res;
 }
@@ -2196,7 +2178,6 @@ u8 _rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, const struct cou
 	struct submit_ctx sctx;
 	u8 res = _SUCCESS;
 
-_func_enter_;
 
 	/* check if allow software config */
 	if (swconfig && rtw_hal_is_disable_sw_channel_plan(adapter) == _TRUE) {
@@ -2252,13 +2233,29 @@ _func_enter_;
 			if (sctx.status == RTW_SCTX_SUBMITTED)
 				cmdobj->sctx = NULL;
 			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status != RTW_SCTX_DONE_SUCCESS)
+				res = _FAIL;
 		}
-	}
-	
-exit:
 
-_func_exit_;	
+		/* allow set channel plan when cmd_thread is not running */
+		if (res != _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			parm = (struct SetChannelPlan_param *)rtw_zmalloc(sizeof(*parm));
+			if (parm == NULL) {
+				res = _FAIL;
+				goto exit;
+			}
+			parm->country_ent = country_ent;
+			parm->channel_plan = chplan;
+
+			if (H2C_SUCCESS != set_chplan_hdl(adapter, (u8 *)parm))
+				res = _FAIL;
+			else
+				res = _SUCCESS;
+			rtw_mfree((u8 *)parm, sizeof(*parm));
+		}
+	}
 
+exit:
 	return res;
 }
 
@@ -2272,124 +2269,116 @@ inline u8 rtw_set_country_cmd(_adapter *adapter, int flags, const char *country_
 	const struct country_chplan *ent;
 
 	if (is_alpha(country_code[0]) == _FALSE
-		|| is_alpha(country_code[1]) == _FALSE
-	) {
-		DBG_871X_LEVEL(_drv_always_, "%s input country_code is not alpha2\n", __func__);
+	    || is_alpha(country_code[1]) == _FALSE
+	   ) {
+		RTW_PRINT("%s input country_code is not alpha2\n", __func__);
 		return _FAIL;
 	}
 
 	ent = rtw_get_chplan_from_country(country_code);
 
 	if (ent == NULL) {
-		DBG_871X_LEVEL(_drv_always_, "%s unsupported country_code:\"%c%c\"\n", __func__, country_code[0], country_code[1]);
+		RTW_PRINT("%s unsupported country_code:\"%c%c\"\n", __func__, country_code[0], country_code[1]);
 		return _FAIL;
 	}
 
-	DBG_871X_LEVEL(_drv_always_, "%s country_code:\"%c%c\" mapping to chplan:0x%02x\n", __func__, country_code[0], country_code[1], ent->chplan);
+	RTW_PRINT("%s country_code:\"%c%c\" mapping to chplan:0x%02x\n", __func__, country_code[0], country_code[1], ent->chplan);
 
-	return _rtw_set_chplan_cmd(adapter, flags, RTW_CHPLAN_MAX, ent, swconfig);
+	return _rtw_set_chplan_cmd(adapter, flags, RTW_CHPLAN_UNSPECIFIED, ent, swconfig);
 }
 
-u8 rtw_led_blink_cmd(_adapter*padapter, PVOID pLed)
+u8 rtw_led_blink_cmd(_adapter *padapter, PVOID pLed)
 {
-	struct	cmd_obj*	pcmdobj;
+	struct	cmd_obj	*pcmdobj;
 	struct	LedBlink_param *ledBlink_param;
 	struct	cmd_priv   *pcmdpriv = &padapter->cmdpriv;
 
-	u8	res=_SUCCESS;
+	u8	res = _SUCCESS;
+
 
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_cmd_c_, _drv_notice_, ("+rtw_led_blink_cmd\n"));
-	
-	pcmdobj = (struct	cmd_obj*)rtw_zmalloc(sizeof(struct	cmd_obj));
-	if(pcmdobj == NULL){
-		res=_FAIL;
+	pcmdobj = (struct	cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
+	if (pcmdobj == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
 	ledBlink_param = (struct	LedBlink_param *)rtw_zmalloc(sizeof(struct	LedBlink_param));
-	if(ledBlink_param == NULL) {
+	if (ledBlink_param == NULL) {
 		rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	ledBlink_param->pLed=pLed;
-	
+	ledBlink_param->pLed = pLed;
+
 	init_h2fwcmd_w_parm_no_rsp(pcmdobj, ledBlink_param, GEN_CMD_CODE(_LedBlink));
 	res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
-	
+
 exit:
 
-_func_exit_;	
 
 	return res;
 }
 
-u8 rtw_set_csa_cmd(_adapter*padapter, u8 new_ch_no)
+u8 rtw_set_csa_cmd(_adapter *padapter, u8 new_ch_no)
 {
-	struct	cmd_obj*	pcmdobj;
-	struct	SetChannelSwitch_param*setChannelSwitch_param;
-	struct 	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct	cmd_obj	*pcmdobj;
+	struct	SetChannelSwitch_param *setChannelSwitch_param;
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct	cmd_priv   *pcmdpriv = &padapter->cmdpriv;
 
-	u8	res=_SUCCESS;
+	u8	res = _SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_cmd_c_, _drv_notice_, ("+rtw_set_csa_cmd\n"));
-	
-	pcmdobj = (struct	cmd_obj*)rtw_zmalloc(sizeof(struct	cmd_obj));
-	if(pcmdobj == NULL){
-		res=_FAIL;
+
+	pcmdobj = (struct	cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
+	if (pcmdobj == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
 	setChannelSwitch_param = (struct SetChannelSwitch_param *)rtw_zmalloc(sizeof(struct	SetChannelSwitch_param));
-	if(setChannelSwitch_param == NULL) {
+	if (setChannelSwitch_param == NULL) {
 		rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
-	setChannelSwitch_param->new_ch_no=new_ch_no;
-	
+	setChannelSwitch_param->new_ch_no = new_ch_no;
+
 	init_h2fwcmd_w_parm_no_rsp(pcmdobj, setChannelSwitch_param, GEN_CMD_CODE(_SetChannelSwitch));
 	res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
-	
+
 exit:
 
-_func_exit_;	
 
 	return res;
 }
 
 u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option)
 {
-	struct	cmd_obj*	pcmdobj;
+	struct	cmd_obj	*pcmdobj;
 	struct	TDLSoption_param	*TDLSoption;
-	struct 	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct	cmd_priv   *pcmdpriv = &padapter->cmdpriv;
 
-	u8	res=_SUCCESS;
+	u8	res = _SUCCESS;
 
-_func_enter_;
 
 #ifdef CONFIG_TDLS
 
-	RT_TRACE(_module_rtl871x_cmd_c_, _drv_notice_, ("+rtw_set_tdls_cmd\n"));
 
-	pcmdobj = (struct	cmd_obj*)rtw_zmalloc(sizeof(struct	cmd_obj));
-	if(pcmdobj == NULL){
-		res=_FAIL;
+	pcmdobj = (struct	cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
+	if (pcmdobj == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
-	TDLSoption= (struct TDLSoption_param *)rtw_zmalloc(sizeof(struct TDLSoption_param));
-	if(TDLSoption == NULL) {
+	TDLSoption = (struct TDLSoption_param *)rtw_zmalloc(sizeof(struct TDLSoption_param));
+	if (TDLSoption == NULL) {
 		rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -2401,12 +2390,11 @@ _func_enter_;
 	init_h2fwcmd_w_parm_no_rsp(pcmdobj, TDLSoption, GEN_CMD_CODE(_TDLS));
 	res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
 
-#endif	//CONFIG_TDLS
-	
+#endif /* CONFIG_TDLS */
+
 exit:
 
 
-_func_exit_;	
 
 	return res;
 }
@@ -2445,53 +2433,7 @@ exit:
 	return res;
 }
 
-
-static void collect_traffic_statistics(_adapter *padapter)
-{
-	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
-		return;
-#endif
-
-	// Tx
-	pdvobjpriv->traffic_stat.tx_bytes = padapter->xmitpriv.tx_bytes;
-	pdvobjpriv->traffic_stat.tx_pkts = padapter->xmitpriv.tx_pkts;
-	pdvobjpriv->traffic_stat.tx_drop = padapter->xmitpriv.tx_drop;
-
-	// Rx
-	pdvobjpriv->traffic_stat.rx_bytes = padapter->recvpriv.rx_bytes;
-	pdvobjpriv->traffic_stat.rx_pkts = padapter->recvpriv.rx_pkts;
-	pdvobjpriv->traffic_stat.rx_drop = padapter->recvpriv.rx_drop;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	// Add secondary adapter statistics
-	if(rtw_buddy_adapter_up(padapter))
-	{
-		// Tx
-		pdvobjpriv->traffic_stat.tx_bytes += padapter->pbuddy_adapter->xmitpriv.tx_bytes;
-		pdvobjpriv->traffic_stat.tx_pkts += padapter->pbuddy_adapter->xmitpriv.tx_pkts;
-		pdvobjpriv->traffic_stat.tx_drop += padapter->pbuddy_adapter->xmitpriv.tx_drop;
-
-		// Rx
-		pdvobjpriv->traffic_stat.rx_bytes += padapter->pbuddy_adapter->recvpriv.rx_bytes;
-		pdvobjpriv->traffic_stat.rx_pkts += padapter->pbuddy_adapter->recvpriv.rx_pkts;
-		pdvobjpriv->traffic_stat.rx_drop += padapter->pbuddy_adapter->recvpriv.rx_drop;
-	}
-#endif
-
-	// Calculate throughput in last interval
-	pdvobjpriv->traffic_stat.cur_tx_bytes = pdvobjpriv->traffic_stat.tx_bytes - pdvobjpriv->traffic_stat.last_tx_bytes;
-	pdvobjpriv->traffic_stat.cur_rx_bytes = pdvobjpriv->traffic_stat.rx_bytes - pdvobjpriv->traffic_stat.last_rx_bytes;
-	pdvobjpriv->traffic_stat.last_tx_bytes = pdvobjpriv->traffic_stat.tx_bytes;
-	pdvobjpriv->traffic_stat.last_rx_bytes = pdvobjpriv->traffic_stat.rx_bytes;
-
-	pdvobjpriv->traffic_stat.cur_tx_tp = (u32)(pdvobjpriv->traffic_stat.cur_tx_bytes *8/2/1024/1024);
-	pdvobjpriv->traffic_stat.cur_rx_tp = (u32)(pdvobjpriv->traffic_stat.cur_rx_bytes *8/2/1024/1024);
-}
-
-//from_timer == 1 means driver is in LPS
+/* from_timer == 1 means driver is in LPS */
 u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 {
 	u8	bEnterPS = _FALSE;
@@ -2506,9 +2448,9 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 	struct tdls_info *ptdlsinfo = &(padapter->tdlsinfo);
 	struct tdls_txmgmt txmgmt;
 	u8 baddr[ETH_ALEN] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-	RT_LINK_DETECT_T * link_detect = &pmlmepriv->LinkDetectInfo;
+	RT_LINK_DETECT_T *link_detect = &pmlmepriv->LinkDetectInfo;
 
 #ifdef CONFIG_BT_COEXIST
 	if (padapter->registrypriv.wifi_spec != 1) {
@@ -2522,21 +2464,18 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 	}
 	BusyThreshold = BusyThresholdHigh;
 
-	collect_traffic_statistics(padapter);
 
-	//
-	// Determine if our traffic is busy now
-	//
-	if((check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE) 
-		/*&& !MgntInitAdapterInProgress(pMgntInfo)*/)
-	{
-		// if we raise bBusyTraffic in last watchdog, using lower threshold.
+	/*  */
+	/* Determine if our traffic is busy now */
+	/*  */
+	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+	    /*&& !MgntInitAdapterInProgress(pMgntInfo)*/) {
+		/* if we raise bBusyTraffic in last watchdog, using lower threshold. */
 		if (pmlmepriv->LinkDetectInfo.bBusyTraffic)
-				BusyThreshold = BusyThresholdLow;
+			BusyThreshold = BusyThresholdLow;
 
-		if( pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > BusyThreshold ||
-			pmlmepriv->LinkDetectInfo.NumTxOkInPeriod > BusyThreshold )
-		{
+		if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > BusyThreshold ||
+		    pmlmepriv->LinkDetectInfo.NumTxOkInPeriod > BusyThreshold) {
 			bBusyTraffic = _TRUE;
 
 			if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > pmlmepriv->LinkDetectInfo.NumTxOkInPeriod)
@@ -2545,10 +2484,9 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 				bTxBusyTraffic = _TRUE;
 		}
 
-		// Higher Tx/Rx data.
-		if( pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > 4000 ||
-			pmlmepriv->LinkDetectInfo.NumTxOkInPeriod > 4000 )
-		{
+		/* Higher Tx/Rx data. */
+		if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > 4000 ||
+		    pmlmepriv->LinkDetectInfo.NumTxOkInPeriod > 4000) {
 			bHigherBusyTraffic = _TRUE;
 
 			if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > pmlmepriv->LinkDetectInfo.NumTxOkInPeriod)
@@ -2562,19 +2500,19 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 #define RX_ACTIVE_TH 20
 #define TRAFFIC_PROTECT_PERIOD_MS 4500
 
-	if (link_detect->NumTxOkInPeriod > TX_ACTIVE_TH
-		|| link_detect->NumRxUnicastOkInPeriod > RX_ACTIVE_TH) {
-		
-		DBG_871X_LEVEL(_drv_info_, FUNC_ADPT_FMT" acqiure wake_lock for %u ms(tx:%d,rx_unicast:%d)\n",
-			FUNC_ADPT_ARG(padapter),
-			TRAFFIC_PROTECT_PERIOD_MS,
-			link_detect->NumTxOkInPeriod,
-			link_detect->NumRxUnicastOkInPeriod);
+		if (link_detect->NumTxOkInPeriod > TX_ACTIVE_TH
+		    || link_detect->NumRxUnicastOkInPeriod > RX_ACTIVE_TH) {
 
-		rtw_lock_traffic_suspend_timeout(TRAFFIC_PROTECT_PERIOD_MS);
-	}
+			RTW_INFO(FUNC_ADPT_FMT" acqiure wake_lock for %u ms(tx:%d,rx_unicast:%d)\n",
+				 FUNC_ADPT_ARG(padapter),
+				 TRAFFIC_PROTECT_PERIOD_MS,
+				 link_detect->NumTxOkInPeriod,
+				 link_detect->NumRxUnicastOkInPeriod);
+
+			rtw_lock_traffic_suspend_timeout(TRAFFIC_PROTECT_PERIOD_MS);
+		}
 #endif
-		
+
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_TDLS_AUTOSETUP
 		/* TDLS_WATCHDOG_PERIOD * 2sec, periodically send */
@@ -2585,121 +2523,102 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 			}
 			ptdlsinfo->watchdog_count++;
 		}
-#endif //CONFIG_TDLS_AUTOSETUP
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS_AUTOSETUP */
+#endif /* CONFIG_TDLS */
 
 #ifdef CONFIG_LPS
-		// check traffic for  powersaving.
-		if( ((pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod + pmlmepriv->LinkDetectInfo.NumTxOkInPeriod) > 8 ) ||
-#ifdef CONFIG_LPS_SLOW_TRANSITION			
-			(pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 2) 
-#else //CONFIG_LPS_SLOW_TRANSITION
-			(pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4) 
-#endif //CONFIG_LPS_SLOW_TRANSITION
-			)
-		{
+		/* check traffic for  powersaving. */
+		if (((pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod + pmlmepriv->LinkDetectInfo.NumTxOkInPeriod) > 8) ||
+#ifdef CONFIG_LPS_SLOW_TRANSITION
+		    (pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 2)
+#else /* CONFIG_LPS_SLOW_TRANSITION */
+		    (pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4)
+#endif /* CONFIG_LPS_SLOW_TRANSITION */
+		   ) {
 #ifdef DBG_RX_COUNTER_DUMP
-			if( padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
-				DBG_871X("(-)Tx = %d, Rx = %d \n",pmlmepriv->LinkDetectInfo.NumTxOkInPeriod,pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
-#endif	
-			bEnterPS= _FALSE;
+			if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
+				RTW_INFO("(-)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
+#endif
+			bEnterPS = _FALSE;
 #ifdef CONFIG_LPS_SLOW_TRANSITION
-			if(bBusyTraffic == _TRUE)
-			{
-				if(pmlmepriv->LinkDetectInfo.TrafficTransitionCount <= 4)
+			if (bBusyTraffic == _TRUE) {
+				if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount <= 4)
 					pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 4;
 
 				pmlmepriv->LinkDetectInfo.TrafficTransitionCount++;
 
-				//DBG_871X("Set TrafficTransitionCount to %d\n", pmlmepriv->LinkDetectInfo.TrafficTransitionCount);
-			
-				if(pmlmepriv->LinkDetectInfo.TrafficTransitionCount > 30/*TrafficTransitionLevel*/)
-				{
+				/* RTW_INFO("Set TrafficTransitionCount to %d\n", pmlmepriv->LinkDetectInfo.TrafficTransitionCount); */
+
+				if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount > 30/*TrafficTransitionLevel*/)
 					pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 30;
-				}	
 			}
-#endif //CONFIG_LPS_SLOW_TRANSITION
-	
-		}
-		else
-		{
-#ifdef DBG_RX_COUNTER_DUMP		
-			if( padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
-				DBG_871X("(+)Tx = %d, Rx = %d \n",pmlmepriv->LinkDetectInfo.NumTxOkInPeriod,pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
-#endif			
+#endif /* CONFIG_LPS_SLOW_TRANSITION */
+
+		} else {
+#ifdef DBG_RX_COUNTER_DUMP
+			if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
+				RTW_INFO("(+)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
+#endif
 #ifdef CONFIG_LPS_SLOW_TRANSITION
-			if(pmlmepriv->LinkDetectInfo.TrafficTransitionCount>=2)
-				pmlmepriv->LinkDetectInfo.TrafficTransitionCount -=2;
+			if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount >= 2)
+				pmlmepriv->LinkDetectInfo.TrafficTransitionCount -= 2;
 			else
 				pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
 
-			if(pmlmepriv->LinkDetectInfo.TrafficTransitionCount == 0)
-				bEnterPS= _TRUE;
-#else //CONFIG_LPS_SLOW_TRANSITION
-				bEnterPS= _TRUE;
-#endif //CONFIG_LPS_SLOW_TRANSITION
+			if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount == 0)
+				bEnterPS = _TRUE;
+#else /* CONFIG_LPS_SLOW_TRANSITION */
+			bEnterPS = _TRUE;
+#endif /* CONFIG_LPS_SLOW_TRANSITION */
 		}
 
 #ifdef CONFIG_DYNAMIC_DTIM
-		if(pmlmepriv->LinkDetectInfo.LowPowerTransitionCount == 8)
-			bEnterPS= _FALSE;
+		if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount == 8)
+			bEnterPS = _FALSE;
 
-		DBG_871X("LowPowerTransitionCount=%d\n", pmlmepriv->LinkDetectInfo.LowPowerTransitionCount);
-#endif //CONFIG_DYNAMIC_DTIM
+		RTW_INFO("LowPowerTransitionCount=%d\n", pmlmepriv->LinkDetectInfo.LowPowerTransitionCount);
+#endif /* CONFIG_DYNAMIC_DTIM */
 
-		// LeisurePS only work in infra mode.
-		if(bEnterPS)
-		{
-			if(!from_timer)
-			{
+		/* LeisurePS only work in infra mode. */
+		if (bEnterPS) {
+			if (!from_timer) {
 #ifdef CONFIG_DYNAMIC_DTIM
-				if(pmlmepriv->LinkDetectInfo.LowPowerTransitionCount < 8)
-				{					
+				if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount < 8)
 					adapter_to_pwrctl(padapter)->dtim = 1;
-				}	
 				else
-				{					
 					adapter_to_pwrctl(padapter)->dtim = 3;
-				}
-#endif //CONFIG_DYNAMIC_DTIM
+#endif /* CONFIG_DYNAMIC_DTIM */
 				LPS_Enter(padapter, "TRAFFIC_IDLE");
-			}	
-			else
-			{
-				//do this at caller
-				//rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 1);
-				//rtw_hal_dm_watchdog_in_lps(padapter);
-			}				
+			} else {
+				/* do this at caller */
+				/* rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 1); */
+				/* rtw_hal_dm_watchdog_in_lps(padapter); */
+			}
 #ifdef CONFIG_DYNAMIC_DTIM
-			if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode ==_TRUE )
+			if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
 				pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
-#endif //CONFIG_DYNAMIC_DTIM
-		}
-		else
-		{
+#endif /* CONFIG_DYNAMIC_DTIM */
+		} else {
 #ifdef CONFIG_DYNAMIC_DTIM
-			if(pmlmepriv->LinkDetectInfo.LowPowerTransitionCount != 8)
+			if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount != 8)
 				pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
 			else
 				pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
-#endif //CONFIG_DYNAMIC_DTIM			
-			if(!from_timer)
-			{
+#endif /* CONFIG_DYNAMIC_DTIM			 */
+			if (!from_timer)
 				LPS_Leave(padapter, "TRAFFIC_BUSY");
-			}
-			else
-			{
+			else {
 #ifdef CONFIG_CONCURRENT_MODE
-			 	if(padapter->iface_type == IFACE_PORT0) 
+				#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
+				if (padapter->hw_port == HW_PORT0)
+				#endif
 #endif
 					rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_TRAFFIC_BUSY, 1);
 			}
 		}
-	
-#endif // CONFIG_LPS
-	}
-	else
-	{
+
+#endif /* CONFIG_LPS */
+	} else {
 #ifdef CONFIG_LPS
 		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 		int n_assoc_iface = 0;
@@ -2710,13 +2629,19 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 				n_assoc_iface++;
 		}
 
-		if(!from_timer && n_assoc_iface == 0)
+		if (!from_timer && n_assoc_iface == 0)
 			LPS_Leave(padapter, "NON_LINKED");
 #endif
 	}
 
 	session_tracker_chk_cmd(padapter, NULL);
 
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+	rtw_bf_update_traffic(padapter);
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+
 	pmlmepriv->LinkDetectInfo.NumRxOkInPeriod = 0;
 	pmlmepriv->LinkDetectInfo.NumTxOkInPeriod = 0;
 	pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod = 0;
@@ -2728,65 +2653,123 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 	pmlmepriv->LinkDetectInfo.bHigherBusyTxTraffic = bHigherBusyTxTraffic;
 
 	return bEnterPS;
-	
+
 }
 
-void dynamic_chk_wk_hdl(_adapter *padapter)
+
+/* for 11n Logo 4.2.31/4.2.32 */
+static void dynamic_update_bcn_check(_adapter *padapter)
 {
-	struct mlme_priv *pmlmepriv;
-	pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-#ifdef CONFIG_AP_MODE
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{			
+	if (!padapter->registrypriv.wifi_spec)
+		return;
+
+	if (!MLME_IS_AP(padapter))
+		return;
+
+	if (pmlmeext->bstart_bss) {
+		/* In 10 * 2 = 20s, there are no legacy AP, update HT info  */
+		static u8 count = 1;
+
+		if (count % 10 == 0) {
+			count = 1;
+
+			if (_FALSE == ATOMIC_READ(&pmlmepriv->olbc)
+				&& _FALSE == ATOMIC_READ(&pmlmepriv->olbc_ht)) {
+
+				if (rtw_ht_operation_update(padapter) > 0) {
+					update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
+					update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE);
+				}
+			}
+		}
+
+		/* In 2s, there are any legacy AP, update HT info, and then reset count  */
+
+		if (_FALSE != ATOMIC_READ(&pmlmepriv->olbc)
+			&& _FALSE != ATOMIC_READ(&pmlmepriv->olbc_ht)) {
+					
+			if (rtw_ht_operation_update(padapter) > 0) {
+				update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
+				update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE);
+
+			}
+			ATOMIC_SET(&pmlmepriv->olbc, _FALSE);
+			ATOMIC_SET(&pmlmepriv->olbc_ht, _FALSE);
+			count = 0;
+		}
+
+		count ++;
+	}
+}
+void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+	#ifdef CONFIG_AP_MODE
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
 		expire_timeout_chk(padapter);
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter) && MLME_IS_ASOC(padapter))
+			rtw_mesh_peer_status_chk(padapter);
+		#endif
 	}
-#endif
-#endif //CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+	#endif
+	#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
+	dynamic_update_bcn_check(padapter);
 
-#ifdef DBG_CONFIG_ERROR_DETECT	
-	rtw_hal_sreset_xmit_status_check(padapter);		
-	rtw_hal_sreset_linked_status_check(padapter);
-#endif	
+	linked_status_chk(padapter, 0);
+	traffic_status_watchdog(padapter, 0);
 
-	//for debug purpose
+	/* for debug purpose */
 	_linked_info_dump(padapter);
 
+	#ifdef CONFIG_BEAMFORMING
+	#ifndef RTW_BEAMFORMING_VERSION_2
+	#if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
+	beamforming_watchdog(padapter);
+	#endif
+	#endif /* !RTW_BEAMFORMING_VERSION_2 */
+	#endif
+
+}
+void rtw_dynamic_chk_wk_hdl(_adapter *padapter)
+{
+	rtw_mi_dynamic_chk_wk_hdl(padapter);
 
-	//if(check_fwstate(pmlmepriv, _FW_UNDER_LINKING|_FW_UNDER_SURVEY)==_FALSE)
+#ifdef DBG_CONFIG_ERROR_DETECT
+	rtw_hal_sreset_xmit_status_check(padapter);
+	rtw_hal_sreset_linked_status_check(padapter);
+#endif
+
+	/* if(check_fwstate(pmlmepriv, _FW_UNDER_LINKING|_FW_UNDER_SURVEY)==_FALSE) */
 	{
-		linked_status_chk(padapter, 0);
-		traffic_status_watchdog(padapter, 0);
-		#ifdef DBG_RX_COUNTER_DUMP
+#ifdef DBG_RX_COUNTER_DUMP
 		rtw_dump_rx_counters(padapter);
-		#endif
+#endif
 		dm_DynamicUsbTxAgg(padapter, 0);
 	}
-
-#ifdef CONFIG_BEAMFORMING
-#if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
-	beamforming_watchdog(padapter);
-#endif
-#endif
-
 	rtw_hal_dm_watchdog(padapter);
 
-	//check_hw_pbc(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->type);
+	/* check_hw_pbc(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->type); */
 
 #ifdef CONFIG_BT_COEXIST
-	//
-	// BT-Coexist
-	//
+	/* BT-Coexist */
 	rtw_btcoex_Handler(padapter);
 #endif
 
-	
 #ifdef CONFIG_IPS_CHECK_IN_WD
-	//always call rtw_ps_processor() at last one.
-	if (is_primary_adapter(padapter))
-		rtw_ps_processor(padapter);
+	/* always call rtw_ps_processor() at last one. */
+	rtw_ps_processor(padapter);
 #endif
+
+#ifdef CONFIG_MCC_MODE
+	rtw_hal_mcc_sw_status_check(padapter);
+#endif /* CONFIG_MCC_MODE */
+
 }
 
 #ifdef CONFIG_LPS
@@ -2797,109 +2780,101 @@ void lps_ctrl_wk_hdl(_adapter *padapter, u8 lps_ctrl_type)
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	u8	mstatus;
-	
-_func_enter_;
 
-	if((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)
-		|| (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
-	{
+
+	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)
+	    || (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
 		return;
-	}
 
-	switch(lps_ctrl_type)
-	{
-		case LPS_CTRL_SCAN:
-			//DBG_871X("LPS_CTRL_SCAN \n");
+	switch (lps_ctrl_type) {
+	case LPS_CTRL_SCAN:
+		/* RTW_INFO("LPS_CTRL_SCAN\n"); */
 #ifdef CONFIG_BT_COEXIST
-			rtw_btcoex_ScanNotify(padapter, _TRUE);
-#endif // CONFIG_BT_COEXIST
-			if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
-			{
-				// connect
-				LPS_Leave(padapter, "LPS_CTRL_SCAN");
-			}
-			break;
-		case LPS_CTRL_JOINBSS:
-			//DBG_871X("LPS_CTRL_JOINBSS \n");
-			LPS_Leave(padapter, "LPS_CTRL_JOINBSS");
-			break;
-		case LPS_CTRL_CONNECT:
-			//DBG_871X("LPS_CTRL_CONNECT \n");
-			mstatus = 1;//connect
-			// Reset LPS Setting
-			pwrpriv->LpsIdleCount = 0;
-			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
+		rtw_btcoex_ScanNotify(padapter, _TRUE);
+#endif /* CONFIG_BT_COEXIST */
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+			/* connect */
+			LPS_Leave(padapter, "LPS_CTRL_SCAN");
+		}
+		break;
+	case LPS_CTRL_JOINBSS:
+		/* RTW_INFO("LPS_CTRL_JOINBSS\n"); */
+		LPS_Leave(padapter, "LPS_CTRL_JOINBSS");
+		break;
+	case LPS_CTRL_CONNECT:
+		/* RTW_INFO("LPS_CTRL_CONNECT\n"); */
+		mstatus = 1;/* connect */
+		/* Reset LPS Setting */
+		pwrpriv->LpsIdleCount = 0;
+		rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
 #ifdef CONFIG_BT_COEXIST
-			rtw_btcoex_MediaStatusNotify(padapter, mstatus);
-#endif // CONFIG_BT_COEXIST
-			break;
-		case LPS_CTRL_DISCONNECT:
-			//DBG_871X("LPS_CTRL_DISCONNECT \n");
-			mstatus = 0;//disconnect
+		rtw_btcoex_MediaStatusNotify(padapter, mstatus);
+#endif /* CONFIG_BT_COEXIST */
+		break;
+	case LPS_CTRL_DISCONNECT:
+		/* RTW_INFO("LPS_CTRL_DISCONNECT\n"); */
+		mstatus = 0;/* disconnect */
 #ifdef CONFIG_BT_COEXIST
-			rtw_btcoex_MediaStatusNotify(padapter, mstatus);
-#endif // CONFIG_BT_COEXIST
-			LPS_Leave(padapter, "LPS_CTRL_DISCONNECT");
-			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
-			break;
-		case LPS_CTRL_SPECIAL_PACKET:
-			//DBG_871X("LPS_CTRL_SPECIAL_PACKET \n");
-			pwrpriv->DelayLPSLastTimeStamp = rtw_get_current_time();
+		rtw_btcoex_MediaStatusNotify(padapter, mstatus);
+#endif /* CONFIG_BT_COEXIST */
+		LPS_Leave(padapter, "LPS_CTRL_DISCONNECT");
+		rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
+		break;
+	case LPS_CTRL_SPECIAL_PACKET:
+		/* RTW_INFO("LPS_CTRL_SPECIAL_PACKET\n"); */
+		pwrpriv->DelayLPSLastTimeStamp = rtw_get_current_time();
 #ifdef CONFIG_BT_COEXIST
-			rtw_btcoex_SpecialPacketNotify(padapter, PACKET_DHCP);
-#endif // CONFIG_BT_COEXIST
-			LPS_Leave(padapter, "LPS_CTRL_SPECIAL_PACKET");
-			break;
-		case LPS_CTRL_LEAVE:
-			LPS_Leave(padapter, "LPS_CTRL_LEAVE");
-			break;
-		case LPS_CTRL_LEAVE_CFG80211_PWRMGMT:
-			LPS_Leave(padapter, "CFG80211_PWRMGMT");
-			break;
-		case LPS_CTRL_TRAFFIC_BUSY:
-			LPS_Leave(padapter, "LPS_CTRL_TRAFFIC_BUSY");
-			break;
-		case LPS_CTRL_TX_TRAFFIC_LEAVE:
-			LPS_Leave(padapter, "LPS_CTRL_TX_TRAFFIC_LEAVE");
-			break;
-		case LPS_CTRL_RX_TRAFFIC_LEAVE:
-			LPS_Leave(padapter, "LPS_CTRL_RX_TRAFFIC_LEAVE");
-			break;
-		case LPS_CTRL_ENTER:
-			LPS_Enter(padapter, "TRAFFIC_IDLE_1");
-			break;
-		default:
-			break;
+		rtw_btcoex_SpecialPacketNotify(padapter, PACKET_DHCP);
+#endif /* CONFIG_BT_COEXIST */
+		LPS_Leave(padapter, "LPS_CTRL_SPECIAL_PACKET");
+		break;
+	case LPS_CTRL_LEAVE:
+		LPS_Leave(padapter, "LPS_CTRL_LEAVE");
+		break;
+	case LPS_CTRL_LEAVE_CFG80211_PWRMGMT:
+		LPS_Leave(padapter, "CFG80211_PWRMGMT");
+		break;
+	case LPS_CTRL_TRAFFIC_BUSY:
+		LPS_Leave(padapter, "LPS_CTRL_TRAFFIC_BUSY");
+		break;
+	case LPS_CTRL_TX_TRAFFIC_LEAVE:
+		LPS_Leave(padapter, "LPS_CTRL_TX_TRAFFIC_LEAVE");
+		break;
+	case LPS_CTRL_RX_TRAFFIC_LEAVE:
+		LPS_Leave(padapter, "LPS_CTRL_RX_TRAFFIC_LEAVE");
+		break;
+	case LPS_CTRL_ENTER:
+		LPS_Enter(padapter, "TRAFFIC_IDLE_1");
+		break;
+	default:
+		break;
 	}
 
-_func_exit_;
 }
 
-u8 rtw_lps_ctrl_wk_cmd(_adapter*padapter, u8 lps_ctrl_type, u8 enqueue)
+u8 rtw_lps_ctrl_wk_cmd(_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;
-	//struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+	/* struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter); */
 	u8	res = _SUCCESS;
-	
-_func_enter_;
 
-	//if(!pwrctrlpriv->bLeisurePs)
-	//	return res;
 
-	if(enqueue)
-	{
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-		if(ph2c==NULL){
-			res= _FAIL;
+	/* if(!pwrctrlpriv->bLeisurePs) */
+	/*	return res; */
+
+	if (enqueue) {
+		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (ph2c == NULL) {
+			res = _FAIL;
 			goto exit;
 		}
-		
-		pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-		if(pdrvextra_cmd_parm==NULL){
+
+		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (pdrvextra_cmd_parm == NULL) {
 			rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-			res= _FAIL;
+			res = _FAIL;
 			goto exit;
 		}
 
@@ -2911,43 +2886,39 @@ _func_enter_;
 		init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
 		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	}
-	else
-	{
+	} else
 		lps_ctrl_wk_hdl(padapter, lps_ctrl_type);
-	}
-	
+
 exit:
-	
-_func_exit_;
+
 
 	return res;
 
 }
 
-void rtw_dm_in_lps_hdl(_adapter*padapter)
+void rtw_dm_in_lps_hdl(_adapter *padapter)
 {
-	rtw_hal_set_hwreg(padapter, HW_VAR_DM_IN_LPS, NULL);
+	rtw_hal_set_hwreg(padapter, HW_VAR_DM_IN_LPS_LCLK, NULL);
 }
 
-u8 rtw_dm_in_lps_wk_cmd(_adapter*padapter)
+u8 rtw_dm_in_lps_wk_cmd(_adapter *padapter)
 {
 	struct cmd_obj	*ph2c;
 	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
 	u8	res = _SUCCESS;
-	
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-		
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -2959,9 +2930,9 @@ u8 rtw_dm_in_lps_wk_cmd(_adapter*padapter)
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
+
 exit:
-	
+
 	return res;
 
 }
@@ -2970,7 +2941,7 @@ void rtw_lps_change_dtim_hdl(_adapter *padapter, u8 dtim)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 
-	if(dtim <=0 || dtim > 16)
+	if (dtim <= 0 || dtim > 16)
 		return;
 
 #ifdef CONFIG_BT_COEXIST
@@ -2982,23 +2953,21 @@ void rtw_lps_change_dtim_hdl(_adapter *padapter, u8 dtim)
 	_enter_pwrlock(&pwrpriv->lock);
 #endif
 
-	if(pwrpriv->dtim!=dtim)
-	{
-		DBG_871X("change DTIM from %d to %d, bFwCurrentInPSMode=%d, ps_mode=%d\n", pwrpriv->dtim, dtim, 
-			pwrpriv->bFwCurrentInPSMode, pwrpriv->pwr_mode);
-		
+	if (pwrpriv->dtim != dtim) {
+		RTW_INFO("change DTIM from %d to %d, bFwCurrentInPSMode=%d, ps_mode=%d\n", pwrpriv->dtim, dtim,
+			 pwrpriv->bFwCurrentInPSMode, pwrpriv->pwr_mode);
+
 		pwrpriv->dtim = dtim;
-	}	
+	}
 
-	if((pwrpriv->bFwCurrentInPSMode ==_TRUE) && (pwrpriv->pwr_mode > PS_MODE_ACTIVE))		 
-	{
+	if ((pwrpriv->bFwCurrentInPSMode == _TRUE) && (pwrpriv->pwr_mode > PS_MODE_ACTIVE)) {
 		u8 ps_mode = pwrpriv->pwr_mode;
 
-		//DBG_871X("change DTIM from %d to %d, ps_mode=%d\n", pwrpriv->dtim, dtim, ps_mode);
-	
+		/* RTW_INFO("change DTIM from %d to %d, ps_mode=%d\n", pwrpriv->dtim, dtim, ps_mode); */
+
 		rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
 	}
-	
+
 #ifdef CONFIG_LPS_LCLK
 	_exit_pwrlock(&pwrpriv->lock);
 #endif
@@ -3007,29 +2976,29 @@ void rtw_lps_change_dtim_hdl(_adapter *padapter, u8 dtim)
 
 #endif
 
-u8 rtw_lps_change_dtim_cmd(_adapter*padapter, u8 dtim)
+u8 rtw_lps_change_dtim_cmd(_adapter *padapter, u8 dtim)
 {
 	struct cmd_obj	*ph2c;
 	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
 	u8	res = _SUCCESS;
-/*
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type != IFACE_PORT0)
-		return res;
-#endif
-*/
+	/*
+	#ifdef CONFIG_CONCURRENT_MODE
+		if (padapter->hw_port != HW_PORT0)
+			return res;
+	#endif
+	*/
 	{
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-		if(ph2c==NULL){
-			res= _FAIL;
+		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (ph2c == NULL) {
+			res = _FAIL;
 			goto exit;
 		}
-		
-		pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-		if(pdrvextra_cmd_parm==NULL){
+
+		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (pdrvextra_cmd_parm == NULL) {
 			rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-			res= _FAIL;
+			res = _FAIL;
 			goto exit;
 		}
 
@@ -3042,38 +3011,37 @@ u8 rtw_lps_change_dtim_cmd(_adapter*padapter, u8 dtim)
 
 		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 	}
-	
+
 exit:
-	
+
 	return res;
 
 }
 
-#if (RATE_ADAPTIVE_SUPPORT==1)
+#if (RATE_ADAPTIVE_SUPPORT == 1)
 void rpt_timer_setting_wk_hdl(_adapter *padapter, u16 minRptTime)
 {
 	rtw_hal_set_hwreg(padapter, HW_VAR_RPT_TIMER_SETTING, (u8 *)(&minRptTime));
 }
 
-u8 rtw_rpt_timer_cfg_cmd(_adapter*padapter, u16 minRptTime)
+u8 rtw_rpt_timer_cfg_cmd(_adapter *padapter, u16 minRptTime)
 {
 	struct cmd_obj		*ph2c;
-	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;	
+	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
 
 	u8	res = _SUCCESS;
 
-_func_enter_;
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
-	if(pdrvextra_cmd_parm==NULL){
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -3085,7 +3053,6 @@ _func_enter_;
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 exit:
 
-_func_exit_;
 
 	return res;
 
@@ -3096,33 +3063,39 @@ _func_exit_;
 #ifdef CONFIG_ANTENNA_DIVERSITY
 void antenna_select_wk_hdl(_adapter *padapter, u8 antenna)
 {
-	rtw_hal_set_hwreg(padapter, HW_VAR_ANTENNA_DIVERSITY_SELECT, (u8 *)(&antenna));
+	rtw_hal_set_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &antenna, _TRUE);
 }
 
-u8 rtw_antenna_select_cmd(_adapter*padapter, u8 antenna,u8 enqueue)
+u8 rtw_antenna_select_cmd(_adapter *padapter, u8 antenna, u8 enqueue)
 {
 	struct cmd_obj		*ph2c;
-	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;	
+	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
-	u8 	bSupportAntDiv = _FALSE;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	u8	bSupportAntDiv = _FALSE;
 	u8	res = _SUCCESS;
+	int	i;
 
-_func_enter_;
 	rtw_hal_get_def_var(padapter, HAL_DEF_IS_SUPPORT_ANT_DIV, &(bSupportAntDiv));
-	if(_FALSE == bSupportAntDiv )	return res;
+	if (_FALSE == bSupportAntDiv)
+		return _FAIL;
 
-	if(_TRUE == enqueue)
-	{
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-		if(ph2c==NULL){
-			res= _FAIL;
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (rtw_linked_check(dvobj->padapters[i]))
+			return _FAIL;
+	}
+
+	if (_TRUE == enqueue) {
+		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (ph2c == NULL) {
+			res = _FAIL;
 			goto exit;
 		}
 
-		pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
-		if(pdrvextra_cmd_parm==NULL){
+		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (pdrvextra_cmd_parm == NULL) {
 			rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-			res= _FAIL;
+			res = _FAIL;
 			goto exit;
 		}
 
@@ -3133,13 +3106,10 @@ _func_enter_;
 		init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
 		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	}
-	else{
-		antenna_select_wk_hdl(padapter,antenna );
-	}
+	} else
+		antenna_select_wk_hdl(padapter, antenna);
 exit:
 
-_func_exit_;
 
 	return res;
 
@@ -3148,134 +3118,300 @@ _func_exit_;
 
 void rtw_dm_ra_mask_hdl(_adapter *padapter, struct sta_info *psta)
 {
-	if (psta) {
+	if (psta)
 		set_sta_rate(padapter, psta);
+}
+
+u8 rtw_dm_ra_mask_wk_cmd(_adapter *padapter, u8 *psta)
+{
+	struct cmd_obj	*ph2c;
+	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
+	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
+
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
+		goto exit;
 	}
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm->ec_id = DM_RA_MSK_WK_CID;
+	pdrvextra_cmd_parm->type = 0;
+	pdrvextra_cmd_parm->size = 0;
+	pdrvextra_cmd_parm->pbuf = psta;
+
+	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+
+exit:
+
+	return res;
+
+}
+
+void power_saving_wk_hdl(_adapter *padapter)
+{
+	rtw_ps_processor(padapter);
+}
+
+/* add for CONFIG_IEEE80211W, none 11w can use it */
+void reset_securitypriv_hdl(_adapter *padapter)
+{
+	rtw_reset_securitypriv(padapter);
 }
 
-u8 rtw_dm_ra_mask_wk_cmd(_adapter*padapter, u8 *psta)
-{
-	struct cmd_obj	*ph2c;
-	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
-	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
-	u8	res = _SUCCESS;
-	
+void free_assoc_resources_hdl(_adapter *padapter, u8 lock_scanned_queue)
+{
+	rtw_free_assoc_resources(padapter, lock_scanned_queue);
+}
+
+#ifdef CONFIG_P2P
+u8 p2p_protocol_wk_cmd(_adapter *padapter, int intCmdType)
+{
+	struct cmd_obj	*ph2c;
+	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
+	u8	res = _SUCCESS;
+
+
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+		return res;
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm->ec_id = P2P_PROTO_WK_CID;
+	pdrvextra_cmd_parm->type = intCmdType;	/*	As the command tppe. */
+	pdrvextra_cmd_parm->size = 0;
+	pdrvextra_cmd_parm->pbuf = NULL;		/*	Must be NULL here */
+
+	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+
+exit:
+
+
+	return res;
+
+}
+
+#ifdef CONFIG_IOCTL_CFG80211
+static u8 _p2p_roch_cmd(_adapter *adapter
+	, u64 cookie, struct wireless_dev *wdev
+	, struct ieee80211_channel *ch, enum nl80211_channel_type ch_type
+	, unsigned int duration
+	, u8 flags
+)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *parm;
+	struct p2p_roch_parm *roch_parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
+	u8 cancel = duration ? 0 : 1;
+	u8	res = _SUCCESS;
+
+	roch_parm = (struct p2p_roch_parm *)rtw_zmalloc(sizeof(struct p2p_roch_parm));
+	if (roch_parm == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	roch_parm->cookie = cookie;
+	roch_parm->wdev = wdev;
+	if (!cancel) {
+		_rtw_memcpy(&roch_parm->ch, ch, sizeof(struct ieee80211_channel));
+		roch_parm->ch_type = ch_type;
+		roch_parm->duration = duration;
+	}
+
+	if (flags & RTW_CMDF_DIRECTLY) {
+		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
+		if (H2C_SUCCESS != p2p_protocol_wk_hdl(adapter, cancel ? P2P_CANCEL_RO_CH_WK : P2P_RO_CH_WK, (u8 *)roch_parm))
+			res = _FAIL;
+		rtw_mfree((u8 *)roch_parm, sizeof(*roch_parm));
+	} else {
+		/* need enqueue, prepare cmd_obj and enqueue */
+		parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (parm == NULL) {
+			rtw_mfree((u8 *)roch_parm, sizeof(*roch_parm));
+			res = _FAIL;
+			goto exit;
+		}
+
+		parm->ec_id = P2P_PROTO_WK_CID;
+		parm->type = cancel ? P2P_CANCEL_RO_CH_WK : P2P_RO_CH_WK;
+		parm->size = sizeof(*roch_parm);
+		parm->pbuf = (u8 *)roch_parm;
+
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
+		if (cmdobj == NULL) {
+			res = _FAIL;
+			rtw_mfree((u8 *)roch_parm, sizeof(*roch_parm));
+			rtw_mfree((u8 *)parm, sizeof(*parm));
+			goto exit;
+		}
+
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
-		goto exit;
-	}
-		
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
-		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
-		goto exit;
-	}
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			cmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 10 * 1000);
+		}
 
-	pdrvextra_cmd_parm->ec_id = DM_RA_MSK_WK_CID;
-	pdrvextra_cmd_parm->type = 0;
-	pdrvextra_cmd_parm->size = 0;
-	pdrvextra_cmd_parm->pbuf = psta;
+		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status != RTW_SCTX_DONE_SUCCESS)
+				res = _FAIL;
+		}
+	}
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
 exit:
-	
 	return res;
-
 }
 
-void power_saving_wk_hdl(_adapter *padapter)
+inline u8 p2p_roch_cmd(_adapter *adapter
+	, u64 cookie, struct wireless_dev *wdev
+	, struct ieee80211_channel *ch, enum nl80211_channel_type ch_type
+	, unsigned int duration
+	, u8 flags
+)
 {
-	 rtw_ps_processor(padapter);
+	return _p2p_roch_cmd(adapter, cookie, wdev, ch, ch_type, duration, flags);
 }
 
-//add for CONFIG_IEEE80211W, none 11w can use it
-void reset_securitypriv_hdl(_adapter *padapter)
+inline u8 p2p_cancel_roch_cmd(_adapter *adapter, u64 cookie, struct wireless_dev *wdev, u8 flags)
 {
-	 rtw_reset_securitypriv(padapter);
+	return _p2p_roch_cmd(adapter, cookie, wdev, NULL, 0, 0, flags);
 }
 
-void free_assoc_resources_hdl(_adapter *padapter)
-{
-	 rtw_free_assoc_resources(padapter, 1);
-}
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_P2P */
 
-#ifdef CONFIG_P2P
-u8 p2p_protocol_wk_cmd(_adapter*padapter, int intCmdType )
+#ifdef CONFIG_IOCTL_CFG80211 
+inline u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack, u8 flags)
 {
-	struct cmd_obj	*ph2c;
-	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
-	struct wifidirect_info	*pwdinfo= &(padapter->wdinfo);
-	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *parm;
+	struct mgnt_tx_parm *mgnt_parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
 	u8	res = _SUCCESS;
-	
-_func_enter_;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
-		return res;
+	mgnt_parm = (struct mgnt_tx_parm *)rtw_zmalloc(sizeof(struct mgnt_tx_parm));
+	if (mgnt_parm == NULL) {
+		res = _FAIL;
+			goto exit;
 	}
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
-		goto exit;
-	}
-			
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
-		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
-		goto exit;
-	}
+	mgnt_parm->tx_ch = tx_ch;
+	mgnt_parm->no_cck = no_cck;
+	mgnt_parm->buf = buf;
+	mgnt_parm->len = len;
+	mgnt_parm->wait_ack = wait_ack;
 
-	pdrvextra_cmd_parm->ec_id = P2P_PROTO_WK_CID;
-	pdrvextra_cmd_parm->type = intCmdType;	//	As the command tppe.
-	pdrvextra_cmd_parm->size = 0;
-	pdrvextra_cmd_parm->pbuf = NULL;		//	Must be NULL here
+	if (flags & RTW_CMDF_DIRECTLY) {
+		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
+		if (H2C_SUCCESS != rtw_mgnt_tx_handler(adapter, (u8 *)mgnt_parm))
+			res = _FAIL;
+		rtw_mfree((u8 *)mgnt_parm, sizeof(*mgnt_parm));
+	} else {
+		/* need enqueue, prepare cmd_obj and enqueue */
+		parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (parm == NULL) {
+			rtw_mfree((u8 *)mgnt_parm, sizeof(*mgnt_parm));
+			res = _FAIL;
+			goto exit;
+		}
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+		parm->ec_id = MGNT_TX_WK_CID;
+		parm->type = 0;
+		parm->size = sizeof(*mgnt_parm);
+		parm->pbuf = (u8 *)mgnt_parm;
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
-exit:
-	
-_func_exit_;
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
+		if (cmdobj == NULL) {
+			res = _FAIL;
+			rtw_mfree((u8 *)mgnt_parm, sizeof(*mgnt_parm));
+			rtw_mfree((u8 *)parm, sizeof(*parm));
+			goto exit;
+		}
 
-	return res;
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			cmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 10 * 1000);
+		}
+
+		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status != RTW_SCTX_DONE_SUCCESS)
+				res = _FAIL;
+		}
+	}
 
+exit:
+	return res;
 }
-#endif //CONFIG_P2P
+#endif
 
-u8 rtw_ps_cmd(_adapter*padapter)
+u8 rtw_ps_cmd(_adapter *padapter)
 {
 	struct cmd_obj		*ppscmd;
-	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;	
+	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
-	
+
 	u8	res = _SUCCESS;
-_func_enter_;
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
+	if (!is_primary_adapter(padapter))
 		goto exit;
 #endif
-	
-	ppscmd = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ppscmd==NULL){
-		res= _FAIL;
+
+	ppscmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ppscmd == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-		
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
 		rtw_mfree((unsigned char *)ppscmd, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -3286,10 +3422,9 @@ _func_enter_;
 	init_h2fwcmd_w_parm_no_rsp(ppscmd, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
 	res = rtw_enqueue_cmd(pcmdpriv, ppscmd);
-	
+
 exit:
-	
-_func_exit_;
+
 
 	return res;
 
@@ -3301,62 +3436,56 @@ static void rtw_chk_hi_queue_hdl(_adapter *padapter)
 {
 	struct sta_info *psta_bmc;
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 	u8 empty = _FALSE;
 
 	psta_bmc = rtw_get_bcmc_stainfo(padapter);
-	if(!psta_bmc)
+	if (!psta_bmc)
 		return;
 
 	rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
 
-	while(_FALSE == empty && rtw_get_passing_time_ms(start) < rtw_get_wait_hiq_empty_ms())
-	{
+	while (_FALSE == empty && rtw_get_passing_time_ms(start) < rtw_get_wait_hiq_empty_ms()) {
 		rtw_msleep_os(100);
 		rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
 	}
 
-	if(psta_bmc->sleepq_len==0)
-	{
-		if(empty == _SUCCESS)
-		{
+	if (psta_bmc->sleepq_len == 0) {
+		if (empty == _SUCCESS) {
 			bool update_tim = _FALSE;
 
-			if (pstapriv->tim_bitmap & BIT(0))
+			if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0))
 				update_tim = _TRUE;
 
-			pstapriv->tim_bitmap &= ~BIT(0);
-			pstapriv->sta_dz_bitmap &= ~BIT(0);
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
 
 			if (update_tim == _TRUE)
 				_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "bmc sleepq and HIQ empty");
-		}
-		else //re check again
-		{
+		} else /* re check again */
 			rtw_chk_hi_queue_cmd(padapter);
-		}
-		
-	}	
-	
+
+	}
+
 }
 
-u8 rtw_chk_hi_queue_cmd(_adapter*padapter)
+u8 rtw_chk_hi_queue_cmd(_adapter *padapter)
 {
 	struct cmd_obj	*ph2c;
-	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;	
+	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
 	u8	res = _SUCCESS;
-	
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-	if(ph2c==NULL){
-		res= _FAIL;
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-			
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-	if(pdrvextra_cmd_parm==NULL){
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -3368,9 +3497,9 @@ u8 rtw_chk_hi_queue_cmd(_adapter*padapter)
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
+
 exit:
-	
+
 	return res;
 
 }
@@ -3378,71 +3507,103 @@ exit:
 #ifdef CONFIG_DFS_MASTER
 u8 rtw_dfs_master_hdl(_adapter *adapter)
 {
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	struct mlme_priv *mlme = &adapter->mlmepriv;
+	int i;
 
 	if (!rfctl->dfs_master_enabled)
 		goto exit;
 
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (!dvobj->padapters[i])
+			continue;
+		if (check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE)
+			&& check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_ASOC_STATE))
+			break;
+	}
+
+	if (i >= dvobj->iface_nums)
+		goto cac_status_chk;
+	else
+		adapter = dvobj->padapters[i];
+
 	if (rtw_get_on_cur_ch_time(adapter) == 0
 		|| rtw_get_passing_time_ms(rtw_get_on_cur_ch_time(adapter)) < 300
 	) {
-		/* offchannel , by pass radar detect */
+		/* offchannel , bypass radar detect */
 		goto cac_status_chk;
 	}
 
-	if (rfctl->dbg_dfs_master_fake_radar_detect_cnt
-		|| rtw_odm_radar_detect(adapter) == _TRUE
+	if (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl)) {
+		/* non_ocp, bypass radar detect */
+		goto cac_status_chk;
+	}
+
+	if (!rfctl->dbg_dfs_master_fake_radar_detect_cnt
+		&& rtw_odm_radar_detect(adapter) != _TRUE)
+		goto cac_status_chk;
+
+	if (!rfctl->dbg_dfs_master_fake_radar_detect_cnt
+		&& rfctl->dbg_dfs_master_radar_detect_trigger_non
 	) {
-		if (rfctl->dbg_dfs_master_fake_radar_detect_cnt != 0) {
-			DBG_871X(FUNC_ADPT_FMT" fake radar detect, cnt:%d\n", FUNC_ADPT_ARG(adapter)
-				, rfctl->dbg_dfs_master_fake_radar_detect_cnt);
-			rfctl->dbg_dfs_master_fake_radar_detect_cnt--;
-		}
-	
-		if (rfctl->dbg_dfs_master_radar_detect_trigger_non) {
-			/* radar detect debug mode, trigger no mlme flow */
-			DBG_871X(FUNC_ADPT_FMT" radar detected, trigger no mlme flow for debug\n", FUNC_ADPT_ARG(adapter));
-		} else {
-			/* TODO: move timer to rfctl */
-			struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-			int i;
+		/* radar detect debug mode, trigger no mlme flow */
+		RTW_INFO(FUNC_ADPT_FMT" radar detected on test mode, trigger no mlme flow\n", FUNC_ADPT_ARG(adapter));
+		goto cac_status_chk;
+	}
 
-			for (i = 0; i < dvobj->iface_nums; i++) {
-				if (!dvobj->padapters[i])
-					continue;
-				if (check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_AP_STATE)
-					&& check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_AP_STATE))
-					break;
-			}
 
-			if (i >= dvobj->iface_nums) {
-				/* what? */
-				rtw_warn_on(1);
-			} else {
-				rtw_chset_update_non_ocp(dvobj->padapters[i]->mlmeextpriv.channel_set
-					, rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
+	if (rfctl->dbg_dfs_master_fake_radar_detect_cnt != 0) {
+		RTW_INFO(FUNC_ADPT_FMT" fake radar detected, cnt:%d\n", FUNC_ADPT_ARG(adapter)
+			, rfctl->dbg_dfs_master_fake_radar_detect_cnt);
+		rfctl->dbg_dfs_master_fake_radar_detect_cnt--;
+	} else
+		RTW_INFO(FUNC_ADPT_FMT" radar detected\n", FUNC_ADPT_ARG(adapter));
 
-				/* change op ch, inform ch switch */
-				rtw_change_bss_chbw_cmd(dvobj->padapters[i], RTW_CMDF_DIRECTLY, 0, 0, 0);
-			}
+	rtw_chset_update_non_ocp(rfctl->channel_set
+		, rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
+	rfctl->radar_detected = 1;
 
-			if (rfctl->dfs_master_enabled)
-				goto set_timer;
-			goto exit;
-		}
-	}
+	/* trigger channel selection */
+	rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_DIRECTLY, -1, adapter->mlmepriv.ori_bw, -1);
+
+	if (rfctl->dfs_master_enabled)
+		goto set_timer;
+	goto exit;
 
 cac_status_chk:
 
-	if (!IS_UNDER_CAC(rfctl) && !IS_CAC_STOPPED(rfctl)) {
+	if (!IS_CAC_STOPPED(rfctl)
+		&& ((IS_UNDER_CAC(rfctl) && rfctl->cac_force_stop)
+			|| !IS_CH_WAITING(rfctl)
+			)
+	) {
 		u8 pause = 0x00;
 
 		rtw_hal_set_hwreg(adapter, HW_VAR_TXPAUSE, &pause);
-		rfctl->cac_end_time = RTW_CAC_STOPPED;
+		rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
+
+		if (rtw_mi_check_fwstate(adapter, WIFI_UNDER_LINKING|WIFI_SITE_MONITOR) == _FALSE) {
+			u8 doiqk = _TRUE;
+			u8 u_ch, u_bw, u_offset;
+
+			rtw_hal_set_hwreg(adapter , HW_VAR_DO_IQK , &doiqk);
+
+			if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset))
+				set_channel_bwmode(adapter, u_ch, u_offset, u_bw);
+			else
+				rtw_warn_on(1);
+
+			doiqk = _FALSE;
+			rtw_hal_set_hwreg(adapter , HW_VAR_DO_IQK , &doiqk);
+
+			ResumeTxBeacon(adapter);
+			rtw_mi_tx_beacon_hdl(adapter);
+		}
 	}
 
 set_timer:
+	/* TODO: move timer to rfctl */
 	_set_timer(&mlme->dfs_master_timer, DFS_MASTER_TIMER_MS);
 
 exit:
@@ -3457,11 +3618,11 @@ u8 rtw_dfs_master_cmd(_adapter *adapter, bool enqueue)
 	u8 res = _FAIL;
 
 	if (enqueue) {
-		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));	
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 		if (cmdobj == NULL)
 			goto exit;
 
-		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
+		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
 		if (pdrvextra_cmd_parm == NULL) {
 			rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
 			goto exit;
@@ -3483,9 +3644,9 @@ exit:
 	return res;
 }
 
-void rtw_dfs_master_timer_hdl(RTW_TIMER_HDL_ARGS)
+void rtw_dfs_master_timer_hdl(void *ctx)
 {
-	_adapter *adapter = (_adapter *)FunctionContext;
+	_adapter *adapter = (_adapter *)ctx;
 
 	rtw_dfs_master_cmd(adapter, _TRUE);
 }
@@ -3497,28 +3658,28 @@ void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset)
 	/* TODO: move timer to rfctl */
 	adapter = GET_PRIMARY_ADAPTER(adapter);
 
-	DBG_871X(FUNC_ADPT_FMT" on %u,%u,%u\n", FUNC_ADPT_ARG(adapter), ch, bw, offset);
+	RTW_INFO(FUNC_ADPT_FMT" on %u,%u,%u\n", FUNC_ADPT_ARG(adapter), ch, bw, offset);
 
-	rfctl->pre_radar_detect_by_sta_link = rfctl->radar_detect_by_sta_link;
-	rfctl->radar_detect_by_sta_link = _FALSE;
+	if (rtw_is_cac_reset_needed(adapter, ch, bw, offset) == _TRUE)
+		rtw_reset_cac(adapter, ch, bw, offset);
 
-	rfctl->pre_radar_detect_ch = rfctl->radar_detect_ch;
-	rfctl->pre_radar_detect_bw = rfctl->radar_detect_bw;
-	rfctl->pre_radar_detect_offset = rfctl->radar_detect_offset;
+	rfctl->radar_detect_by_others = _FALSE;
 	rfctl->radar_detect_ch = ch;
 	rfctl->radar_detect_bw = bw;
 	rfctl->radar_detect_offset = offset;
 
-	if (rtw_is_cac_reset_needed(adapter) == _TRUE)
-		rtw_rfctl_reset_cac(adapter_to_rfctl(adapter));
+	rfctl->radar_detected = 0;
+
+	if (IS_CH_WAITING(rfctl))
+		StopTxBeacon(adapter);
 
 	if (!rfctl->dfs_master_enabled) {
-		DBG_871X(FUNC_ADPT_FMT" set dfs_master_enabled\n", FUNC_ADPT_ARG(adapter));
+		RTW_INFO(FUNC_ADPT_FMT" set dfs_master_enabled\n", FUNC_ADPT_ARG(adapter));
 		rfctl->dfs_master_enabled = 1;
 		_set_timer(&adapter->mlmepriv.dfs_master_timer, DFS_MASTER_TIMER_MS);
 
 		if (rtw_rfctl_overlap_radar_detect_ch(rfctl)) {
-			if (IS_UNDER_CAC(rfctl)) {
+			if (IS_CH_WAITING(rfctl)) {
 				u8 pause = 0xFF;
 
 				rtw_hal_set_hwreg(adapter, HW_VAR_TXPAUSE, &pause);
@@ -3528,28 +3689,33 @@ void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset)
 	}
 }
 
-void rtw_dfs_master_disable(_adapter *adapter, bool ld_sta_in_dfs)
+void rtw_dfs_master_disable(_adapter *adapter, u8 ch, u8 bw, u8 offset, bool by_others)
 {
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-	
+
 	/* TODO: move timer to rfctl */
 	adapter = GET_PRIMARY_ADAPTER(adapter);
 
-	rfctl->pre_radar_detect_by_sta_link = rfctl->radar_detect_by_sta_link;
-	rfctl->radar_detect_by_sta_link = ld_sta_in_dfs;
+	rfctl->radar_detect_by_others = by_others;
 
 	if (rfctl->dfs_master_enabled) {
 		bool overlap_radar_detect_ch = rtw_rfctl_overlap_radar_detect_ch(rfctl);
 
-		DBG_871X(FUNC_ADPT_FMT" clear dfs_master_enabled\n", FUNC_ADPT_ARG(adapter));
+		RTW_INFO(FUNC_ADPT_FMT" clear dfs_master_enabled\n", FUNC_ADPT_ARG(adapter));
 
 		rfctl->dfs_master_enabled = 0;
-		rfctl->radar_detect_ch = rfctl->pre_radar_detect_ch = 0;
-		rfctl->radar_detect_bw = rfctl->pre_radar_detect_bw = 0;
-		rfctl->radar_detect_offset = rfctl->pre_radar_detect_offset = 0;
-		rfctl->cac_end_time = RTW_CAC_STOPPED;
+		rfctl->radar_detected = 0;
+		rfctl->radar_detect_ch = 0;
+		rfctl->radar_detect_bw = 0;
+		rfctl->radar_detect_offset = 0;
+		rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
 		_cancel_timer_ex(&adapter->mlmepriv.dfs_master_timer);
 
+		if (rtw_mi_check_fwstate(adapter, WIFI_UNDER_LINKING|WIFI_SITE_MONITOR) == _FALSE) {
+			ResumeTxBeacon(adapter);
+			rtw_mi_tx_beacon_hdl(adapter);
+		}
+
 		if (overlap_radar_detect_ch) {
 			u8 pause = 0x00;
 
@@ -3557,41 +3723,62 @@ void rtw_dfs_master_disable(_adapter *adapter, bool ld_sta_in_dfs)
 			rtw_odm_radar_detect_disable(adapter);
 		}
 	}
+
+	if (by_others) {
+		rfctl->radar_detect_ch = ch;
+		rfctl->radar_detect_bw = bw;
+		rfctl->radar_detect_offset = offset;
+	}
 }
 
 void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action)
 {
 	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-	u8 ld_sta_num, lg_sta_num, ap_num;
+	struct mi_state mstate;
 	u8 u_ch, u_bw, u_offset;
 	bool ld_sta_in_dfs = _FALSE;
 	bool sync_ch = _FALSE; /* _FALSE: asign channel directly */
 	bool needed = _FALSE;
 
-	rtw_dev_iface_status_no_self(adapter, NULL, &ld_sta_num, &lg_sta_num, &ap_num, NULL);
-	rtw_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset);
+	rtw_mi_status_no_self(adapter, &mstate);
+	rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset);
 	if (u_ch != 0)
 		sync_ch = _TRUE;
 
 	switch (self_action) {
 	case MLME_STA_CONNECTING:
-		lg_sta_num++;
+		MSTATE_STA_LG_NUM(&mstate)++;
 		break;
 	case MLME_STA_CONNECTED:
-		ld_sta_num++;
+		MSTATE_STA_LD_NUM(&mstate)++;
 		break;
+	case MLME_STA_DISCONNECTED:
+		break;
+#ifdef CONFIG_AP_MODE
 	case MLME_AP_STARTED:
-		ap_num++;
+		MSTATE_AP_NUM(&mstate)++;
 		break;
 	case MLME_AP_STOPPED:
-	case MLME_STA_DISCONNECTED:
+		break;
+#endif
+#ifdef CONFIG_RTW_MESH
+	case MLME_MESH_STARTED:
+		MSTATE_MESH_NUM(&mstate)++;
+		break;
+	case MLME_MESH_STOPPED:
+		break;
+#endif
+	case MLME_ACTION_NONE:
+		/* caller without effect of decision */
+		break;
 	default:
+		rtw_warn_on(1);
 		break;
 	}
 
 	if (sync_ch == _TRUE) {
 		if (!rtw_is_chbw_grouped(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset)) {
-			DBG_871X(FUNC_ADPT_FMT" can't sync %u,%u,%u with %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
+			RTW_INFO(FUNC_ADPT_FMT" can't sync %u,%u,%u with %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
 				, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset);
 			goto apply;
 		}
@@ -3604,37 +3791,39 @@ void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action)
 		u_offset = mlmeext->cur_ch_offset;
 	}
 
-	if (ld_sta_num > 0) {
+	if (MSTATE_STA_LD_NUM(&mstate) > 0) {
 		/* rely on AP on which STA mode connects */
-		if (rtw_is_dfs_ch(u_ch, u_bw, u_offset))
+		if (rtw_is_dfs_chbw(u_ch, u_bw, u_offset))
 			ld_sta_in_dfs = _TRUE;
 		goto apply;
 	}
 
-	if (lg_sta_num > 0) {
+	if (MSTATE_STA_LG_NUM(&mstate) > 0) {
 		/* STA mode is linking */
 		goto apply;
 	}
 
-	if (ap_num == 0) {
-		/* No working AP mode */
+	if (!MSTATE_AP_NUM(&mstate) && !MSTATE_MESH_NUM(&mstate)) {
+		/* No working AP/Mesh mode */
 		goto apply;
 	}
 
-	if (rtw_is_dfs_ch(u_ch, u_bw, u_offset))
+	if (rtw_is_dfs_chbw(u_ch, u_bw, u_offset))
 		needed = _TRUE;
 
 apply:
 
-	DBG_871X(FUNC_ADPT_FMT" needed:%d, self_action:%u\n"
+	RTW_INFO(FUNC_ADPT_FMT" needed:%d, self_action:%u\n"
 		, FUNC_ADPT_ARG(adapter), needed, self_action);
-	DBG_871X(FUNC_ADPT_FMT" ld_sta_num:%u, lg_sta_num:%u, ap_num:%u, %u,%u,%u\n"
-		, FUNC_ADPT_ARG(adapter), ld_sta_num, lg_sta_num, ap_num, u_ch, u_bw, u_offset);
+	RTW_INFO(FUNC_ADPT_FMT" ld_sta_num:%u, lg_sta_num:%u, ap_num:%u, mesh_num:%u, %u,%u,%u\n"
+		, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate), MSTATE_STA_LG_NUM(&mstate)
+		, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate)
+		, u_ch, u_bw, u_offset);
 
 	if (needed == _TRUE)
 		rtw_dfs_master_enable(adapter, u_ch, u_bw, u_offset);
 	else
-		rtw_dfs_master_disable(adapter, ld_sta_in_dfs);
+		rtw_dfs_master_disable(adapter, u_ch, u_bw, u_offset, ld_sta_in_dfs);
 }
 #endif /* CONFIG_DFS_MASTER */
 
@@ -3678,64 +3867,63 @@ struct btinfo {
 void btinfo_evt_dump(void *sel, void *buf)
 {
 	struct btinfo *info = (struct btinfo *)buf;
-	
-	DBG_871X_SEL_NL(sel, "cid:0x%02x, len:%u\n", info->cid, info->len);
+
+	RTW_PRINT_SEL(sel, "cid:0x%02x, len:%u\n", info->cid, info->len);
 
 	if (info->len > 2)
-		DBG_871X_SEL_NL(sel, "byte2:%s%s%s%s%s%s%s%s\n"
-			, info->bConnection?"bConnection ":""
-			, info->bSCOeSCO?"bSCOeSCO ":""
-			, info->bInQPage?"bInQPage ":""
-			, info->bACLBusy?"bACLBusy ":""
-			, info->bSCOBusy?"bSCOBusy ":""
-			, info->bHID?"bHID ":""
-			, info->bA2DP?"bA2DP ":""
-			, info->bFTP?"bFTP":""
-		);
+		RTW_PRINT_SEL(sel, "byte2:%s%s%s%s%s%s%s%s\n"
+			      , info->bConnection ? "bConnection " : ""
+			      , info->bSCOeSCO ? "bSCOeSCO " : ""
+			      , info->bInQPage ? "bInQPage " : ""
+			      , info->bACLBusy ? "bACLBusy " : ""
+			      , info->bSCOBusy ? "bSCOBusy " : ""
+			      , info->bHID ? "bHID " : ""
+			      , info->bA2DP ? "bA2DP " : ""
+			      , info->bFTP ? "bFTP" : ""
+			     );
 
 	if (info->len > 3)
-		DBG_871X_SEL_NL(sel, "retry_cnt:%u\n", info->retry_cnt);
+		RTW_PRINT_SEL(sel, "retry_cnt:%u\n", info->retry_cnt);
 
 	if (info->len > 4)
-		DBG_871X_SEL_NL(sel, "rssi:%u\n", info->rssi);
+		RTW_PRINT_SEL(sel, "rssi:%u\n", info->rssi);
 
 	if (info->len > 5)
-		DBG_871X_SEL_NL(sel, "byte5:%s%s\n"
-			, info->eSCO_SCO?"eSCO_SCO ":""
-			, info->Master_Slave?"Master_Slave ":""
-		);
+		RTW_PRINT_SEL(sel, "byte5:%s%s\n"
+			      , info->eSCO_SCO ? "eSCO_SCO " : ""
+			      , info->Master_Slave ? "Master_Slave " : ""
+			     );
 }
 
 static void rtw_btinfo_hdl(_adapter *adapter, u8 *buf, u16 buf_len)
 {
-	#define BTINFO_WIFI_FETCH 0x23
-	#define BTINFO_BT_AUTO_RPT 0x27
+#define BTINFO_WIFI_FETCH 0x23
+#define BTINFO_BT_AUTO_RPT 0x27
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	struct btinfo_8761ATV *info = (struct btinfo_8761ATV *)buf;
-#else //!CONFIG_BT_COEXIST_SOCKET_TRX
+#else /* !CONFIG_BT_COEXIST_SOCKET_TRX */
 	struct btinfo *info = (struct btinfo *)buf;
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 	u8 cmd_idx;
 	u8 len;
 
 	cmd_idx = info->cid;
 
-	if (info->len > buf_len-2) {
+	if (info->len > buf_len - 2) {
 		rtw_warn_on(1);
-		len = buf_len-2;
-	} else {
+		len = buf_len - 2;
+	} else
 		len = info->len;
-	}
 
-//#define DBG_PROC_SET_BTINFO_EVT
+	/* #define DBG_PROC_SET_BTINFO_EVT */
 #ifdef DBG_PROC_SET_BTINFO_EVT
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-	DBG_871X("%s: btinfo[0]=%x,btinfo[1]=%x,btinfo[2]=%x,btinfo[3]=%x btinfo[4]=%x,btinfo[5]=%x,btinfo[6]=%x,btinfo[7]=%x\n"
-				, __func__, buf[0], buf[1], buf[2], buf[3], buf[4], buf[5], buf[6], buf[7]);
-#else//!CONFIG_BT_COEXIST_SOCKET_TRX
+	RTW_INFO("%s: btinfo[0]=%x,btinfo[1]=%x,btinfo[2]=%x,btinfo[3]=%x btinfo[4]=%x,btinfo[5]=%x,btinfo[6]=%x,btinfo[7]=%x\n"
+		, __func__, buf[0], buf[1], buf[2], buf[3], buf[4], buf[5], buf[6], buf[7]);
+#else/* !CONFIG_BT_COEXIST_SOCKET_TRX */
 	btinfo_evt_dump(RTW_DBGDUMP, info);
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-#endif // DBG_PROC_SET_BTINFO_EVT
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+#endif /* DBG_PROC_SET_BTINFO_EVT */
 
 	/* transform BT-FW btinfo to WiFI-FW C2H format and notify */
 	if (cmd_idx == BTINFO_WIFI_FETCH)
@@ -3743,10 +3931,10 @@ static void rtw_btinfo_hdl(_adapter *adapter, u8 *buf, u16 buf_len)
 	else if (cmd_idx == BTINFO_BT_AUTO_RPT)
 		buf[1] = 2;
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-	else if(0x01 == cmd_idx || 0x02 == cmd_idx)
+	else if (0x01 == cmd_idx || 0x02 == cmd_idx)
 		buf[1] = buf[0];
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-	rtw_btcoex_BtInfoNotify(adapter ,len+1, &buf[1]);
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+	rtw_btcoex_BtInfoNotify(adapter , len + 1, &buf[1]);
 }
 
 u8 rtw_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)
@@ -3757,23 +3945,23 @@ u8 rtw_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)
 	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
 	u8	res = _SUCCESS;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
 	if (pdrvextra_cmd_parm == NULL) {
-		rtw_mfree((u8*)ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
 		res = _FAIL;
 		goto exit;
 	}
 
 	btinfo = rtw_zmalloc(len);
 	if (btinfo == NULL) {
-		rtw_mfree((u8*)ph2c, sizeof(struct cmd_obj));
-		rtw_mfree((u8*)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
 		res = _FAIL;
 		goto exit;
 	}
@@ -3792,55 +3980,205 @@ u8 rtw_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)
 exit:
 	return res;
 }
-#endif //CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
-//#ifdef CONFIG_C2H_PACKET_EN
-u8 rtw_c2h_packet_wk_cmd(PADAPTER padapter, u8 *pbuf, u16 length)
+u8 rtw_test_h2c_cmd(_adapter *adapter, u8 *buf, u8 len)
 {
-	struct cmd_obj *ph2c;
+	struct cmd_obj *pcmdobj;
 	struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-	u8	*extra_cmd_buf;
+	u8 *ph2c_content;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	u8	res = _SUCCESS;
+
+	pcmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmdobj == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	ph2c_content = rtw_zmalloc(len);
+	if (ph2c_content == NULL) {
+		rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm->ec_id = TEST_H2C_CID;
+	pdrvextra_cmd_parm->type = 0;
+	pdrvextra_cmd_parm->size = len;
+	pdrvextra_cmd_parm->pbuf = ph2c_content;
+
+	_rtw_memcpy(ph2c_content, buf, len);
+
+	init_h2fwcmd_w_parm_no_rsp(pcmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+	res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
+
+exit:
+	return res;
+}
+
+#ifdef CONFIG_MP_INCLUDED
+static s32 rtw_mp_cmd_hdl(_adapter *padapter, u8 mp_cmd_id)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	int ret = H2C_SUCCESS;
+	uint status = _SUCCESS;
+	u8 rfreg0;
+
+	if (mp_cmd_id == MP_START) {
+		if (padapter->registrypriv.mp_mode == 0) {
+			rtw_intf_stop(padapter);
+			rtw_hal_deinit(padapter);
+			padapter->registrypriv.mp_mode = 1;
+#ifdef CONFIG_RF_POWER_TRIM
+			if (!IS_HARDWARE_TYPE_8814A(padapter) && !IS_HARDWARE_TYPE_8822B(padapter)) {
+				padapter->registrypriv.RegPwrTrimEnable = 1;
+				rtw_hal_read_chip_info(padapter);
+			}
+#endif /*CONFIG_RF_POWER_TRIM*/
+			rtw_reset_drv_sw(padapter);
+			status = rtw_hal_init(padapter);
+			if (status == _FAIL) {
+				ret = H2C_REJECTED;
+				goto exit;
+			}
+#ifndef RTW_HALMAC
+			rtw_intf_start(padapter);
+#endif /* !RTW_HALMAC */
+#ifdef RTW_HALMAC /*for New IC*/
+			MPT_InitializeAdapter(padapter, 1);
+#endif /* CONFIG_MP_INCLUDED */
+		}
+
+		if (padapter->registrypriv.mp_mode == 0) {
+			ret = H2C_REJECTED;
+			goto exit;
+		}
+
+		if (padapter->mppriv.mode == MP_OFF) {
+			if (mp_start_test(padapter) == _FAIL) {
+				ret = H2C_REJECTED;
+				goto exit;
+			}
+			padapter->mppriv.mode = MP_ON;
+			MPT_PwrCtlDM(padapter, 0);
+		}
+		padapter->mppriv.bmac_filter = _FALSE;
+#ifdef CONFIG_RTL8723B
+#ifdef CONFIG_USB_HCI
+		rtw_write32(padapter, 0x765, 0x0000);
+		rtw_write32(padapter, 0x948, 0x0280);
+#else
+		rtw_write32(padapter, 0x765, 0x0000);
+		rtw_write32(padapter, 0x948, 0x0000);
+#endif
+#ifdef CONFIG_FOR_RTL8723BS_VQ0
+		rtw_write32(padapter, 0x765, 0x0000);
+		rtw_write32(padapter, 0x948, 0x0280);
+#endif
+		rtw_write8(padapter, 0x66, 0x27); /*Open BT uart Log*/
+		rtw_write8(padapter, 0xc50, 0x20); /*for RX init Gain*/
+#endif
+		odm_write_dig(&pHalData->odmpriv, 0x20);
+
+	} else if (mp_cmd_id == MP_STOP) {
+		if (padapter->registrypriv.mp_mode == 1) {
+			MPT_DeInitAdapter(padapter);
+			rtw_intf_stop(padapter);
+			rtw_hal_deinit(padapter);
+			padapter->registrypriv.mp_mode = 0;
+			rtw_reset_drv_sw(padapter);
+			status = rtw_hal_init(padapter);
+			if (status == _FAIL) {
+				ret = H2C_REJECTED;
+				goto exit;
+			}
+#ifndef RTW_HALMAC
+			rtw_intf_start(padapter);
+#endif /* !RTW_HALMAC */
+		}
+
+		if (padapter->mppriv.mode != MP_OFF) {
+			mp_stop_test(padapter);
+			padapter->mppriv.mode = MP_OFF;
+		}
+
+	} else {
+		RTW_INFO(FUNC_ADPT_FMT"invalid id:%d\n", FUNC_ADPT_ARG(padapter), mp_cmd_id);
+		ret = H2C_PARAMETERS_ERROR;
+		rtw_warn_on(1);
+	}
+
+exit:
+	return ret;
+}
+
+u8 rtw_mp_cmd(_adapter *adapter, u8 mp_cmd_id, u8 flags)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
 	u8	res = _SUCCESS;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
-	if (ph2c == NULL) {
+	parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (parm == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
-	if (pdrvextra_cmd_parm == NULL) {
-		rtw_mfree((u8*)ph2c, sizeof(struct cmd_obj));
-		res = _FAIL;
-		goto exit;
-	}
+	parm->ec_id = MP_CMD_WK_CID;
+	parm->type = mp_cmd_id;
+	parm->size = 0;
+	parm->pbuf = NULL;
 
-	extra_cmd_buf = rtw_zmalloc(length);
-	if (extra_cmd_buf == NULL) {
-		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
-		rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
-		res = _FAIL;
-		goto exit;
-	}
+	if (flags & RTW_CMDF_DIRECTLY) {
+		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
+		if (H2C_SUCCESS != rtw_mp_cmd_hdl(adapter, mp_cmd_id))
+			res = _FAIL;
+		rtw_mfree((u8 *)parm, sizeof(*parm));
+	} else {
+		/* need enqueue, prepare cmd_obj and enqueue */
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
+		if (cmdobj == NULL) {
+			res = _FAIL;
+			rtw_mfree((u8 *)parm, sizeof(*parm));
+			goto exit;
+		}
 
-	_rtw_memcpy(extra_cmd_buf, pbuf, length);
-	pdrvextra_cmd_parm->ec_id = C2H_WK_CID;
-	pdrvextra_cmd_parm->type = 0;
-	pdrvextra_cmd_parm->size = length;
-	pdrvextra_cmd_parm->pbuf = extra_cmd_buf;
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			cmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 10 * 1000);
+		}
 
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status != RTW_SCTX_DONE_SUCCESS)
+				res = _FAIL;
+		}
+	}
 
 exit:
 	return res;
 }
-
-//#else //CONFIG_C2H_PACKET_EN
-/* dont call R/W in this function, beucase SDIO interrupt have claim host */
-/* or deadlock will happen and cause special-systemserver-died in android */
+#endif	/*CONFIG_MP_INCLUDED*/
 
 #ifdef CONFIG_RTW_CUSTOMER_STR
 static s32 rtw_customer_str_cmd_hdl(_adapter *adapter, u8 write, const u8 *cstr)
@@ -3929,61 +4267,82 @@ inline u8 rtw_customer_str_write_cmd(_adapter *adapter, const u8 *cstr)
 }
 #endif /* CONFIG_RTW_CUSTOMER_STR */
 
-u8 rtw_c2h_wk_cmd(PADAPTER padapter, u8 *c2h_evt)
+u8 rtw_c2h_wk_cmd(PADAPTER padapter, u8 *pbuf, u16 length, u8 type)
 {
 	struct cmd_obj *ph2c;
 	struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
-	u8	res = _SUCCESS;
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	u8 *extra_cmd_buf;
+	u8 res = _SUCCESS;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (ph2c == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
 	if (pdrvextra_cmd_parm == NULL) {
-		rtw_mfree((u8*)ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	extra_cmd_buf = rtw_zmalloc(length);
+	if (extra_cmd_buf == NULL) {
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
 		res = _FAIL;
 		goto exit;
 	}
 
+	_rtw_memcpy(extra_cmd_buf, pbuf, length);
 	pdrvextra_cmd_parm->ec_id = C2H_WK_CID;
-	pdrvextra_cmd_parm->type = 0;
-	pdrvextra_cmd_parm->size =  c2h_evt?16:0;
-	pdrvextra_cmd_parm->pbuf = c2h_evt;
+	pdrvextra_cmd_parm->type = type;
+	pdrvextra_cmd_parm->size = length;
+	pdrvextra_cmd_parm->pbuf = extra_cmd_buf;
 
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	
+
 exit:
-	
 	return res;
 }
-//#endif //CONFIG_C2H_PACKET_EN
 
-u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void*), void* context)
+#ifdef CONFIG_FW_C2H_REG
+inline u8 rtw_c2h_reg_wk_cmd(_adapter *adapter, u8 *c2h_evt)
+{
+	return rtw_c2h_wk_cmd(adapter, c2h_evt, c2h_evt ? C2H_REG_LEN : 0, C2H_TYPE_REG);
+}
+#endif
+
+#ifdef CONFIG_FW_C2H_PKT
+inline u8 rtw_c2h_packet_wk_cmd(_adapter *adapter, u8 *c2h_evt, u16 length)
+{
+	return rtw_c2h_wk_cmd(adapter, c2h_evt, length, C2H_TYPE_PKT);
+}
+#endif
+
+u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void *), void *context)
 {
 	struct cmd_priv *pcmdpriv;
 	struct cmd_obj *ph2c;
 	struct RunInThread_param *parm;
 	s32 res = _SUCCESS;
 
-_func_enter_;
 
 	pcmdpriv = &padapter->cmdpriv;
 
-	ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (NULL == ph2c) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	parm = (struct RunInThread_param*)rtw_zmalloc(sizeof(struct RunInThread_param));
+	parm = (struct RunInThread_param *)rtw_zmalloc(sizeof(struct RunInThread_param));
 	if (NULL == parm) {
-		rtw_mfree((u8*)ph2c, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
 		res = _FAIL;
 		goto exit;
 	}
@@ -3995,84 +4354,36 @@ _func_enter_;
 	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
 exit:
 
-_func_exit_;
 
 	return res;
 }
 
+#ifdef CONFIG_FW_C2H_REG
 s32 c2h_evt_hdl(_adapter *adapter, u8 *c2h_evt, c2h_id_filter filter)
 {
 	s32 ret = _FAIL;
-	u8 buf[16];
+	u8 buf[C2H_REG_LEN] = {0};
+	u8 id, seq, plen;
+	u8 *payload;
 
 	if (!c2h_evt) {
 		/* No c2h event in cmd_obj, read c2h event before handling*/
-		if (rtw_hal_c2h_evt_read(adapter, buf) == _SUCCESS) {
-			c2h_evt = buf;
-			
-			if (filter && filter(c2h_evt) == _FALSE)
-				goto exit;
-
-			ret = rtw_hal_c2h_handler(adapter, c2h_evt);
-		}
-	} else {
-
-		if (filter && filter(c2h_evt) == _FALSE)
+		if (rtw_hal_c2h_evt_read(adapter, buf) != _SUCCESS)
 			goto exit;
-
-		ret = rtw_hal_c2h_handler(adapter, c2h_evt);
+		c2h_evt = buf;
 	}
-exit:
-	return ret;
-}
-
-#ifdef CONFIG_C2H_WK
-static void c2h_wk_callback(_workitem *work)
-{
-	struct evt_priv *evtpriv = container_of(work, struct evt_priv, c2h_wk);
-	_adapter *adapter = container_of(evtpriv, _adapter, evtpriv);
-	u8 *c2h_evt;
-	c2h_id_filter ccx_id_filter = rtw_hal_c2h_id_filter_ccx(adapter);
-
-	evtpriv->c2h_wk_alive = _TRUE;
 
-	while (!rtw_cbuf_empty(evtpriv->c2h_queue)) {
-		if ((c2h_evt = (u8 *)rtw_cbuf_pop(evtpriv->c2h_queue)) != NULL) {
-			/* This C2H event is read, clear it */
-			c2h_evt_clear(adapter);
-		} else if ((c2h_evt = (u8 *)rtw_malloc(16)) != NULL) {
-			/* This C2H event is not read, read & clear now */
-			if (rtw_hal_c2h_evt_read(adapter, c2h_evt) != _SUCCESS) {
-				rtw_mfree(c2h_evt, 16);
-				continue;
-			}
-		} else {
-			rtw_warn_on(1);
-			continue;
-		}
+	rtw_hal_c2h_reg_hdr_parse(adapter, c2h_evt, &id, &seq, &plen, &payload);
 
-		/* Special pointer to trigger c2h_evt_clear only */
-		if ((void *)c2h_evt == (void *)evtpriv)
-			continue;
+	if (filter && filter(adapter, id, seq, plen, payload) == _FALSE)
+		goto exit;
 
-		if (!rtw_hal_c2h_valid(adapter, c2h_evt)) {
-			rtw_mfree(c2h_evt, 16);
-			continue;
-		}
-		
-		if (ccx_id_filter(c2h_evt) == _TRUE) {
-			/* Handle CCX report here */
-			rtw_hal_c2h_handler(adapter, c2h_evt);
-			rtw_mfree(c2h_evt, 16);
-		} else {
-			/* Enqueue into cmd_thread for others */
-			rtw_c2h_wk_cmd(adapter, c2h_evt);
-		}
-	}
+	ret = rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
 
-	evtpriv->c2h_wk_alive = _FALSE;
+exit:
+	return ret;
 }
-#endif
+#endif /* CONFIG_FW_C2H_REG */
 
 u8 session_tracker_cmd(_adapter *adapter, u8 cmd, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)
 {
@@ -4151,7 +4462,7 @@ void session_tracker_chk_for_sta(_adapter *adapter, struct sta_info *sta)
 	u8 op_wfd_mode = MIRACAST_DISABLED;
 
 	if (DBG_SESSION_TRACKER)
-		DBG_871X(FUNC_ADPT_FMT" sta:%p\n", FUNC_ADPT_ARG(adapter), sta);
+		RTW_INFO(FUNC_ADPT_FMT" sta:%p\n", FUNC_ADPT_ARG(adapter), sta);
 
 	if (!(sta->state & _FW_LINKED))
 		goto exit;
@@ -4191,7 +4502,7 @@ void session_tracker_chk_for_sta(_adapter *adapter, struct sta_info *sta)
 
 		#ifdef CONFIG_WFD
 		if (0)
-			DBG_871X(FUNC_ADPT_FMT" local:%u, remote:%u, rtsp:%u, %u, %u\n", FUNC_ADPT_ARG(adapter)
+			RTW_INFO(FUNC_ADPT_FMT" local:%u, remote:%u, rtsp:%u, %u, %u\n", FUNC_ADPT_ARG(adapter)
 				, ntohs(st->local_port), ntohs(st->remote_port), adapter->wfd_info.rtsp_ctrlport, adapter->wfd_info.tdls_rtsp_ctrlport
 				, adapter->wfd_info.peer_rtsp_ctrlport);
 		if (ntohs(st->local_port) == adapter->wfd_info.rtsp_ctrlport)
@@ -4280,7 +4591,7 @@ void session_tracker_cmd_hdl(_adapter *adapter, struct st_cmd_parm *parm)
 		u8 alloc_st = 0;
 
 		if (DBG_SESSION_TRACKER)
-			DBG_871X(FUNC_ADPT_FMT" cmd:%u, sta:%p, local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT"\n"
+			RTW_INFO(FUNC_ADPT_FMT" cmd:%u, sta:%p, local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT"\n"
 				, FUNC_ADPT_ARG(adapter), cmd, sta
 				, IP_ARG(&local_naddr), PORT_ARG(&local_port)
 				, IP_ARG(&remote_naddr), PORT_ARG(&remote_port)
@@ -4352,235 +4663,312 @@ exit:
 	return;
 }
 
+#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
+static s32 rtw_req_per_cmd_hdl(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct macid_bmp req_macid_bmp, *macid_bmp;
+	u8 i, ret = _FAIL;
+
+	macid_bmp = &macid_ctl->if_g[adapter->iface_id];
+	_rtw_memcpy(&req_macid_bmp, macid_bmp, sizeof(struct macid_bmp));
+
+	/* Clear none mesh's macid */
+	for (i = 0; i < macid_ctl->num; i++) {
+		u8 role;
+		role = GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[i]);
+		if (role != H2C_MSR_ROLE_MESH)
+			rtw_macid_map_clr(&req_macid_bmp, i);
+	}
+
+	/* group_macid: always be 0 in NIC, so only pass macid_bitmap.m0
+	 * rpt_type: 0 includes all info in 1, use 0 for now 
+	 * macid_bitmap: pass m0 only for NIC
+	 */
+	ret = rtw_hal_set_req_per_rpt_cmd(adapter, 0, 0, req_macid_bmp.m0);
+
+	return ret;
+}
+
+u8 rtw_req_per_cmd(_adapter *adapter)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
+	u8 res = _SUCCESS;
+
+	parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (parm == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	parm->ec_id = REQ_PER_CMD_WK_CID;
+	parm->type = 0;
+	parm->size = 0;
+	parm->pbuf = NULL;
+
+	cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
+	if (cmdobj == NULL) {
+		res = _FAIL;
+		rtw_mfree((u8 *)parm, sizeof(*parm));
+		goto exit;
+	}
+
+	init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+	res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+
+exit:
+	return res;
+}
+#endif
+
 u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 	int ret = H2C_SUCCESS;
 	struct drvextra_cmd_parm *pdrvextra_cmd;
 
-	if(!pbuf)
+	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
 
-	pdrvextra_cmd = (struct drvextra_cmd_parm*)pbuf;
-	
+	pdrvextra_cmd = (struct drvextra_cmd_parm *)pbuf;
+
 	switch (pdrvextra_cmd->ec_id) {
 	case STA_MSTATUS_RPT_WK_CID:
 		rtw_sta_media_status_rpt_cmd_hdl(padapter, (struct sta_media_status_rpt_cmd_parm *)pdrvextra_cmd->pbuf);
 		break;
 
 	case DYNAMIC_CHK_WK_CID:/*only  primary padapter go to this cmd, but execute dynamic_chk_wk_hdl() for two interfaces */
-#ifdef CONFIG_CONCURRENT_MODE
-			if (padapter->pbuddy_adapter)
-				dynamic_chk_wk_hdl(padapter->pbuddy_adapter);
-#endif
-			dynamic_chk_wk_hdl(padapter);
-			break;
-		case POWER_SAVING_CTRL_WK_CID:
-			power_saving_wk_hdl(padapter);
-			break;
+		rtw_dynamic_chk_wk_hdl(padapter);
+		break;
+	case POWER_SAVING_CTRL_WK_CID:
+		power_saving_wk_hdl(padapter);
+		break;
 #ifdef CONFIG_LPS
-		case LPS_CTRL_WK_CID:
-			lps_ctrl_wk_hdl(padapter, (u8)pdrvextra_cmd->type);
-			break;
-		case DM_IN_LPS_WK_CID:
-			rtw_dm_in_lps_hdl(padapter);
-			break;
-		case LPS_CHANGE_DTIM_CID:
-			rtw_lps_change_dtim_hdl(padapter, (u8)pdrvextra_cmd->type);
-			break;
+	case LPS_CTRL_WK_CID:
+		lps_ctrl_wk_hdl(padapter, (u8)pdrvextra_cmd->type);
+		break;
+	case DM_IN_LPS_WK_CID:
+		rtw_dm_in_lps_hdl(padapter);
+		break;
+	case LPS_CHANGE_DTIM_CID:
+		rtw_lps_change_dtim_hdl(padapter, (u8)pdrvextra_cmd->type);
+		break;
 #endif
-#if (RATE_ADAPTIVE_SUPPORT==1)
-		case RTP_TIMER_CFG_WK_CID:
-			rpt_timer_setting_wk_hdl(padapter, pdrvextra_cmd->type);
-			break;
+#if (RATE_ADAPTIVE_SUPPORT == 1)
+	case RTP_TIMER_CFG_WK_CID:
+		rpt_timer_setting_wk_hdl(padapter, pdrvextra_cmd->type);
+		break;
 #endif
 #ifdef CONFIG_ANTENNA_DIVERSITY
-		case ANT_SELECT_WK_CID:
-			antenna_select_wk_hdl(padapter, pdrvextra_cmd->type);
-			break;
+	case ANT_SELECT_WK_CID:
+		antenna_select_wk_hdl(padapter, pdrvextra_cmd->type);
+		break;
 #endif
 #ifdef CONFIG_P2P_PS
-		case P2P_PS_WK_CID:
-			p2p_ps_wk_hdl(padapter, pdrvextra_cmd->type);
-			break;
+	case P2P_PS_WK_CID:
+		p2p_ps_wk_hdl(padapter, pdrvextra_cmd->type);
+		break;
 #endif
 #ifdef CONFIG_P2P
-		case P2P_PROTO_WK_CID:
+	case P2P_PROTO_WK_CID:
 		/*
 		* Commented by Albert 2011/07/01
 		* I used the type_size as the type command
 		*/
-			p2p_protocol_wk_hdl(padapter, pdrvextra_cmd->type);
-			break;
+		ret = p2p_protocol_wk_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
+		break;
 #endif
 #ifdef CONFIG_AP_MODE
-		case CHECK_HIQ_WK_CID:
-			rtw_chk_hi_queue_hdl(padapter);
-			break;
+	case CHECK_HIQ_WK_CID:
+		rtw_chk_hi_queue_hdl(padapter);
+		break;
 #endif
 #ifdef CONFIG_INTEL_WIDI
-		case INTEl_WIDI_WK_CID:
-			intel_widi_wk_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
-			break;
+	case INTEl_WIDI_WK_CID:
+		intel_widi_wk_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
+		break;
 #endif
 	/* add for CONFIG_IEEE80211W, none 11w can use it */
-		case RESET_SECURITYPRIV:
-			reset_securitypriv_hdl(padapter);
+	case RESET_SECURITYPRIV:
+		reset_securitypriv_hdl(padapter);
+		break;
+	case FREE_ASSOC_RESOURCES:
+		free_assoc_resources_hdl(padapter, (u8)pdrvextra_cmd->type);
+		break;
+	case C2H_WK_CID:
+		switch (pdrvextra_cmd->type) {
+		#ifdef CONFIG_FW_C2H_REG
+		case C2H_TYPE_REG:
+			c2h_evt_hdl(padapter, pdrvextra_cmd->pbuf, NULL);
 			break;
-		case FREE_ASSOC_RESOURCES:
-			free_assoc_resources_hdl(padapter);
+		#endif
+		#ifdef CONFIG_FW_C2H_PKT
+		case C2H_TYPE_PKT:
+			rtw_hal_c2h_pkt_hdl(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
 			break;
-		case C2H_WK_CID:
-#ifdef CONFIG_C2H_PACKET_EN
-			rtw_hal_set_hwreg_with_buf(padapter, HW_VAR_C2H_HANDLE, pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
-#else		
-			c2h_evt_hdl(padapter, pdrvextra_cmd->pbuf, NULL);
-#endif
+		#endif
+		default:
+			RTW_ERR("unknown C2H type:%d\n", pdrvextra_cmd->type);
+			rtw_warn_on(1);
 			break;
+		}
+		break;
 #ifdef CONFIG_BEAMFORMING
-		case BEAMFORMING_WK_CID:
-			beamforming_wk_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
-			break;
+	case BEAMFORMING_WK_CID:
+		beamforming_wk_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
+		break;
 #endif
-		case DM_RA_MSK_WK_CID:
-			rtw_dm_ra_mask_hdl(padapter, (struct sta_info *)pdrvextra_cmd->pbuf);
-			break;
+	case DM_RA_MSK_WK_CID:
+		rtw_dm_ra_mask_hdl(padapter, (struct sta_info *)pdrvextra_cmd->pbuf);
+		break;
 #ifdef CONFIG_BT_COEXIST
-		case BTINFO_WK_CID:
-			rtw_btinfo_hdl(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
-			break;
+	case BTINFO_WK_CID:
+		rtw_btinfo_hdl(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
+		break;
 #endif
 #ifdef CONFIG_DFS_MASTER
-		case DFS_MASTER_WK_CID:
-			rtw_dfs_master_hdl(padapter);
-			break;
+	case DFS_MASTER_WK_CID:
+		rtw_dfs_master_hdl(padapter);
+		break;
 #endif
 	case SESSION_TRACKER_WK_CID:
 		session_tracker_cmd_hdl(padapter, (struct st_cmd_parm *)pdrvextra_cmd->pbuf);
 		break;
-
 	case EN_HW_UPDATE_TSF_WK_CID:
 		rtw_hal_set_hwreg(padapter, HW_VAR_EN_HW_UPDATE_TSF, NULL);
 		break;
+	case TEST_H2C_CID:
+		rtw_hal_fill_h2c_cmd(padapter, pdrvextra_cmd->pbuf[0], pdrvextra_cmd->size - 1, &pdrvextra_cmd->pbuf[1]);
+		break;
+	case MP_CMD_WK_CID:
+#ifdef CONFIG_MP_INCLUDED
+		ret = rtw_mp_cmd_hdl(padapter, pdrvextra_cmd->type);
+#endif
+		break;
 #ifdef CONFIG_RTW_CUSTOMER_STR
 	case CUSTOMER_STR_WK_CID:
 		ret = rtw_customer_str_cmd_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
 		break;
 #endif
-		default:
-			break;
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	case RSON_SCAN_WK_CID:
+		rtw_rson_scan_cmd_hdl(padapter, pdrvextra_cmd->type);
+		break;
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+	case MGNT_TX_WK_CID:
+		ret = rtw_mgnt_tx_handler(padapter, pdrvextra_cmd->pbuf);
+		break;
+#endif /* CONFIG_IOCTL_CFG80211 */
+#ifdef CONFIG_MCC_MODE
+	case MCC_SET_DURATION_WK_CID:
+		ret = rtw_set_mcc_duration_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
+		break;
+#endif /* CONFIG_MCC_MODE */
+#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
+	case REQ_PER_CMD_WK_CID:
+		ret = rtw_req_per_cmd_hdl(padapter);
+		break;
+#endif
+	default:
+		break;
 	}
 
-	if (pdrvextra_cmd->pbuf && pdrvextra_cmd->size>0)
-	{
+	if (pdrvextra_cmd->pbuf && pdrvextra_cmd->size > 0)
 		rtw_mfree(pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
-	}
 
 	return ret;
 }
 
-void rtw_survey_cmd_callback(_adapter*	padapter ,  struct cmd_obj *pcmd)
+void rtw_survey_cmd_callback(_adapter	*padapter ,  struct cmd_obj *pcmd)
 {
-	struct 	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-_func_enter_;
 
-	if(pcmd->res == H2C_DROPPED)
-	{
-		//TODO: cancel timer and do timeout handler directly...
-		//need to make timeout handlerOS independent
+	if (pcmd->res == H2C_DROPPED) {
+		/* TODO: cancel timer and do timeout handler directly... */
+		/* need to make timeout handlerOS independent */
 		mlme_set_scan_to_timer(pmlmepriv, 1);
-	}
-	else if (pcmd->res != H2C_SUCCESS) {
+	} else if (pcmd->res != H2C_SUCCESS) {
 		mlme_set_scan_to_timer(pmlmepriv, 1);
-		RT_TRACE(_module_rtl871x_cmd_c_,_drv_err_,("\n ********Error: MgntActrtw_set_802_11_bssid_LIST_SCAN Fail ************\n\n."));
-	} 
+	}
 
-	// free cmd
+	/* free cmd */
 	rtw_free_cmd_obj(pcmd);
 
-_func_exit_;	
 }
-void rtw_disassoc_cmd_callback(_adapter*	padapter,  struct cmd_obj *pcmd)
+void rtw_disassoc_cmd_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
 {
 	_irqL	irqL;
-	struct 	mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	
-_func_enter_;	
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-	if (pcmd->res != H2C_SUCCESS)
-	{
+
+	if (pcmd->res != H2C_SUCCESS) {
 		_enter_critical_bh(&pmlmepriv->lock, &irqL);
 		set_fwstate(pmlmepriv, _FW_LINKED);
 		_exit_critical_bh(&pmlmepriv->lock, &irqL);
-				
-		RT_TRACE(_module_rtl871x_cmd_c_,_drv_err_,("\n ***Error: disconnect_cmd_callback Fail ***\n."));
-
 		goto exit;
 	}
 #ifdef CONFIG_BR_EXT
-	else //clear bridge database
+	else /* clear bridge database */
 		nat25_db_cleanup(padapter);
-#endif //CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
 
-	// free cmd
+	/* free cmd */
 	rtw_free_cmd_obj(pcmd);
-	
+
 exit:
-	
-_func_exit_;	
+	return;
 }
 
 
 void rtw_getmacreg_cmdrsp_callback(_adapter *padapter,  struct cmd_obj *pcmd)
 {
 
-_func_enter_;
 
 	rtw_free_cmd_obj(pcmd);
 
-_func_exit_;
 }
 
-void rtw_joinbss_cmd_callback(_adapter*	padapter,  struct cmd_obj *pcmd)
+void rtw_joinbss_cmd_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
 {
-	struct 	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-_func_enter_;	
 
-	if(pcmd->res == H2C_DROPPED)
-	{
-		//TODO: cancel timer and do timeout handler directly...
-		//need to make timeout handlerOS independent
+	if (pcmd->res == H2C_DROPPED) {
+		/* TODO: cancel timer and do timeout handler directly... */
+		/* need to make timeout handlerOS independent */
 		_set_timer(&pmlmepriv->assoc_timer, 1);
-	}
-	else if(pcmd->res != H2C_SUCCESS)
-	{
+	} else if (pcmd->res != H2C_SUCCESS)
 		_set_timer(&pmlmepriv->assoc_timer, 1);
-	}
 
 	rtw_free_cmd_obj(pcmd);
-	
-_func_exit_;	
+
 }
 
 void rtw_create_ibss_post_hdl(_adapter *padapter, int status)
-{	
+{
 	_irqL irqL;
-	u8 timer_cancelled;
 	struct sta_info *psta = NULL;
-	struct wlan_network *pwlan = NULL;		
-	struct 	mlme_priv *pmlmepriv = &padapter->mlmepriv;	
+	struct wlan_network *pwlan = NULL;
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	WLAN_BSSID_EX *pdev_network = &padapter->registrypriv.dev_network;
 	struct wlan_network *mlme_cur_network = &(pmlmepriv->cur_network);
 
 	if (status != H2C_SUCCESS)
 		_set_timer(&pmlmepriv->assoc_timer, 1);
 
-	_cancel_timer(&pmlmepriv->assoc_timer, &timer_cancelled);
+	_cancel_timer_ex(&pmlmepriv->assoc_timer);
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	{	
+	{
 		_irqL irqL;
 
 		pwlan = _rtw_alloc_network(pmlmepriv);
@@ -4588,29 +4976,26 @@ void rtw_create_ibss_post_hdl(_adapter *padapter, int status)
 		if (pwlan == NULL) {
 			pwlan = rtw_get_oldest_wlan_network(&pmlmepriv->scanned_queue);
 			if (pwlan == NULL) {
-				RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_, ("Error:  can't get pwlan in rtw_joinbss_event_callback\n"));
 				_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 				goto createbss_cmd_fail;
 			}
 			pwlan->last_scanned = rtw_get_current_time();
-		} else {
+		} else
 			rtw_list_insert_tail(&(pwlan->list), &pmlmepriv->scanned_queue.queue);
-		}
 
 		pdev_network->Length = get_WLAN_BSSID_EX_sz(pdev_network);
 		_rtw_memcpy(&(pwlan->network), pdev_network, pdev_network->Length);
-		//pwlan->fixed = _TRUE;
+		/* pwlan->fixed = _TRUE; */
 
 		/* copy pdev_network information to pmlmepriv->cur_network */
 		_rtw_memcpy(&mlme_cur_network->network, pdev_network, (get_WLAN_BSSID_EX_sz(pdev_network)));
 
-		#if 0
+#if 0
 		/* reset DSConfig */
 		mlme_cur_network->network.Configuration.DSConfig = (u32)rtw_ch2freq(pdev_network->Configuration.DSConfig);
-		#endif
+#endif
 
 		_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-
 		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 		/* we will set _FW_LINKED when there is one more sat to join us (rtw_stassoc_event_callback) */
 	}
@@ -4623,52 +5008,45 @@ exit:
 
 
 
-void rtw_setstaKey_cmdrsp_callback(_adapter*	padapter ,  struct cmd_obj *pcmd)
+void rtw_setstaKey_cmdrsp_callback(_adapter	*padapter ,  struct cmd_obj *pcmd)
 {
-	
-	struct sta_priv * pstapriv = &padapter->stapriv;
-	struct set_stakey_rsp* psetstakey_rsp = (struct set_stakey_rsp*) (pcmd->rsp);
-	struct sta_info*	psta = rtw_get_stainfo(pstapriv, psetstakey_rsp->addr);
 
-_func_enter_;	
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct set_stakey_rsp *psetstakey_rsp = (struct set_stakey_rsp *)(pcmd->rsp);
+	struct sta_info	*psta = rtw_get_stainfo(pstapriv, psetstakey_rsp->addr);
 
-	if(psta==NULL)
-	{
-		RT_TRACE(_module_rtl871x_cmd_c_,_drv_err_,("\nERROR: rtw_setstaKey_cmdrsp_callback => can't get sta_info \n\n"));
+
+	if (psta == NULL) {
 		goto exit;
 	}
-	
-	//psta->aid = psta->mac_id = psetstakey_rsp->keyid; //CAM_ID(CAM_ENTRY)
-	
-exit:	
+
+	/* psta->cmn.aid = psta->cmn.mac_id = psetstakey_rsp->keyid; */ /* CAM_ID(CAM_ENTRY) */
+
+exit:
 
 	rtw_free_cmd_obj(pcmd);
-	
-_func_exit_;	
+
 
 }
-void rtw_setassocsta_cmdrsp_callback(_adapter*	padapter,  struct cmd_obj *pcmd)
+void rtw_setassocsta_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
 {
 	_irqL	irqL;
-	struct sta_priv * pstapriv = &padapter->stapriv;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;	
-	struct set_assocsta_parm* passocsta_parm = (struct set_assocsta_parm*)(pcmd->parmbuf);
-	struct set_assocsta_rsp* passocsta_rsp = (struct set_assocsta_rsp*) (pcmd->rsp);		
-	struct sta_info*	psta = rtw_get_stainfo(pstapriv, passocsta_parm->addr);
-
-_func_enter_;	
-	
-	if(psta==NULL)
-	{
-		RT_TRACE(_module_rtl871x_cmd_c_,_drv_err_,("\nERROR: setassocsta_cmdrsp_callbac => can't get sta_info \n\n"));
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct set_assocsta_parm *passocsta_parm = (struct set_assocsta_parm *)(pcmd->parmbuf);
+	struct set_assocsta_rsp *passocsta_rsp = (struct set_assocsta_rsp *)(pcmd->rsp);
+	struct sta_info	*psta = rtw_get_stainfo(pstapriv, passocsta_parm->addr);
+
+
+	if (psta == NULL) {
 		goto exit;
 	}
-	
-	psta->aid = psta->mac_id = passocsta_rsp->cam_id;
+
+	psta->cmn.aid = psta->cmn.mac_id = passocsta_rsp->cam_id;
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) && (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE))           	
+	if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) && (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE))
 		_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
 
 	set_fwstate(pmlmepriv, _FW_LINKED);
@@ -4677,21 +5055,17 @@ _func_enter_;
 exit:
 	rtw_free_cmd_obj(pcmd);
 
-_func_exit_;
 }
 
-void rtw_getrttbl_cmd_cmdrsp_callback(_adapter*	padapter,  struct cmd_obj *pcmd);
-void rtw_getrttbl_cmd_cmdrsp_callback(_adapter*	padapter,  struct cmd_obj *pcmd)
+void rtw_getrttbl_cmd_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd);
+void rtw_getrttbl_cmd_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
 {
-_func_enter_;
 
 	rtw_free_cmd_obj(pcmd);
 #ifdef CONFIG_MP_INCLUDED
 	if (padapter->registrypriv.mp_mode == 1)
-		padapter->mppriv.workparam.bcompleted=_TRUE;
+		padapter->mppriv.workparam.bcompleted = _TRUE;
 #endif
 
-_func_exit_;
 
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_debug.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_debug.c
index 69bbf396bfee..2e6705d479d4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_debug.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_debug.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,112 +12,88 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_DEBUG_C_
 
 #include <drv_types.h>
 #include <hal_data.h>
 
-u32 GlobalDebugLevel = _drv_err_;
+#ifdef CONFIG_RTW_DEBUG
+const char *rtw_log_level_str[] = {
+	"_DRV_NONE_ = 0",
+	"_DRV_ALWAYS_ = 1",
+	"_DRV_ERR_ = 2",
+	"_DRV_WARNING_ = 3",
+	"_DRV_INFO_ = 4",
+	"_DRV_DEBUG_ = 5",
+	"_DRV_MAX_ = 6",
+};
+#endif
 
 #ifdef CONFIG_DEBUG_RTL871X
-
-	u64 GlobalDebugComponents = \
-			_module_rtl871x_xmit_c_ |
-			_module_xmit_osdep_c_ |
-			_module_rtl871x_recv_c_ |
-			_module_recv_osdep_c_ |
-			_module_rtl871x_mlme_c_ |
-			_module_mlme_osdep_c_ |
-			_module_rtl871x_sta_mgt_c_ |
-			_module_rtl871x_cmd_c_ |
-			_module_cmd_osdep_c_ |
-			_module_rtl871x_io_c_ |
-			_module_io_osdep_c_ |
-			_module_os_intfs_c_|
-			_module_rtl871x_security_c_|
-			_module_rtl871x_eeprom_c_|
-			_module_hal_init_c_|
-			_module_hci_hal_init_c_|
-			_module_rtl871x_ioctl_c_|
-			_module_rtl871x_ioctl_set_c_|
-			_module_rtl871x_ioctl_query_c_|
-			_module_rtl871x_pwrctrl_c_|
-			_module_hci_intfs_c_|
-			_module_hci_ops_c_|
-			_module_hci_ops_os_c_|
-			_module_rtl871x_ioctl_os_c|
-			_module_rtl8712_cmd_c_|
-			_module_hal_xmit_c_|
-			_module_rtl8712_recv_c_ |
-			_module_mp_ |
-			_module_efuse_;
-
+	u64 GlobalDebugComponents = 0;
 #endif /* CONFIG_DEBUG_RTL871X */
 
 #include <rtw_version.h>
 
 #ifdef CONFIG_TDLS
-#define TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE	41
+	#define TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE	41
 #endif
 
 void dump_drv_version(void *sel)
 {
-	DBG_871X_SEL_NL(sel, "%s %s\n", DRV_NAME, DRIVERVERSION);
-	DBG_871X_SEL_NL(sel, "build time: %s %s\n", __DATE__, __TIME__);
+	RTW_PRINT_SEL(sel, "%s %s\n", DRV_NAME, DRIVERVERSION);
+	RTW_PRINT_SEL(sel, "build time: %s %s\n", __DATE__, __TIME__);
 }
 
 void dump_drv_cfg(void *sel)
 {
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
 	char *kernel_version = utsname()->release;
-	
-	DBG_871X_SEL_NL(sel, "\nKernel Version: %s\n", kernel_version);
+
+	RTW_PRINT_SEL(sel, "\nKernel Version: %s\n", kernel_version);
 #endif
 
-	DBG_871X_SEL_NL(sel, "Driver Version: %s\n", DRIVERVERSION);
-	DBG_871X_SEL_NL(sel, "------------------------------------------------\n");
+	RTW_PRINT_SEL(sel, "Driver Version: %s\n", DRIVERVERSION);
+	RTW_PRINT_SEL(sel, "------------------------------------------------\n");
 #ifdef CONFIG_IOCTL_CFG80211
-	DBG_871X_SEL_NL(sel, "CFG80211\n");
-	#ifdef RTW_USE_CFG80211_STA_EVENT
-	DBG_871X_SEL_NL(sel, "RTW_USE_CFG80211_STA_EVENT\n");
-	#endif
+	RTW_PRINT_SEL(sel, "CFG80211\n");
+#ifdef RTW_USE_CFG80211_STA_EVENT
+	RTW_PRINT_SEL(sel, "RTW_USE_CFG80211_STA_EVENT\n");
+#endif
 	#ifdef CONFIG_RADIO_WORK
-	DBG_871X_SEL_NL(sel, "CONFIG_RADIO_WORK\n");
+	RTW_PRINT_SEL(sel, "CONFIG_RADIO_WORK\n");
 	#endif
 #else
-	DBG_871X_SEL_NL(sel, "WEXT\n");
+	RTW_PRINT_SEL(sel, "WEXT\n");
 #endif
 
-	DBG_871X_SEL_NL(sel, "DBG:%d\n", DBG);
-#ifdef CONFIG_DEBUG
-	DBG_871X_SEL_NL(sel, "CONFIG_DEBUG\n");
+	RTW_PRINT_SEL(sel, "DBG:%d\n", DBG);
+#ifdef CONFIG_RTW_DEBUG
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_DEBUG\n");
 #endif
 
 #ifdef CONFIG_CONCURRENT_MODE
-	DBG_871X_SEL_NL(sel, "CONFIG_CONCURRENT_MODE\n");
+	RTW_PRINT_SEL(sel, "CONFIG_CONCURRENT_MODE\n");
 #endif
 
 #ifdef CONFIG_POWER_SAVING
-	DBG_871X_SEL_NL(sel, "CONFIG_POWER_SAVING\n");
+	RTW_PRINT_SEL(sel, "CONFIG_POWER_SAVING\n");
 #endif
 
 #ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
-	DBG_871X_SEL_NL(sel, "LOAD_PHY_PARA_FROM_FILE - REALTEK_CONFIG_PATH=%s\n", REALTEK_CONFIG_PATH);
+	RTW_PRINT_SEL(sel, "LOAD_PHY_PARA_FROM_FILE - REALTEK_CONFIG_PATH=%s\n", REALTEK_CONFIG_PATH);
 	#if defined(CONFIG_MULTIDRV) || defined(REALTEK_CONFIG_PATH_WITH_IC_NAME_FOLDER)
 	RTW_PRINT_SEL(sel, "LOAD_PHY_PARA_FROM_FILE - REALTEK_CONFIG_PATH_WITH_IC_NAME_FOLDER\n");
 	#endif
-	#ifdef CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY
-	DBG_871X_SEL_NL(sel, "CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY\n");
-	#endif
-	#ifdef CONFIG_CALIBRATE_TX_POWER_TO_MAX
-	DBG_871X_SEL_NL(sel, "CONFIG_CALIBRATE_TX_POWER_TO_MAX\n");
-	#endif
+
+/* configurations about TX power */
+#ifdef CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY
+	RTW_PRINT_SEL(sel, "CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY\n");
+#endif
+#ifdef CONFIG_CALIBRATE_TX_POWER_TO_MAX
+	RTW_PRINT_SEL(sel, "CONFIG_CALIBRATE_TX_POWER_TO_MAX\n");
+#endif
 #endif
 	RTW_PRINT_SEL(sel, "RTW_DEF_MODULE_REGULATORY_CERT=0x%02x\n", RTW_DEF_MODULE_REGULATORY_CERT);
 
@@ -125,73 +102,110 @@ void dump_drv_cfg(void *sel)
 
 
 #ifdef CONFIG_DISABLE_ODM
-	DBG_871X_SEL_NL(sel, "CONFIG_DISABLE_ODM\n");
+	RTW_PRINT_SEL(sel, "CONFIG_DISABLE_ODM\n");
 #endif
 
 #ifdef CONFIG_MINIMAL_MEMORY_USAGE
-	DBG_871X_SEL_NL(sel, "CONFIG_MINIMAL_MEMORY_USAGE\n");
+	RTW_PRINT_SEL(sel, "CONFIG_MINIMAL_MEMORY_USAGE\n");
 #endif
 
-	DBG_871X_SEL_NL(sel, "CONFIG_RTW_ADAPTIVITY_EN = %d\n", CONFIG_RTW_ADAPTIVITY_EN);
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_ADAPTIVITY_EN = %d\n", CONFIG_RTW_ADAPTIVITY_EN);
 #if (CONFIG_RTW_ADAPTIVITY_EN)
-	DBG_871X_SEL_NL(sel, "ADAPTIVITY_MODE = %s\n", (CONFIG_RTW_ADAPTIVITY_MODE) ? "carrier_sense" : "normal");
+	RTW_PRINT_SEL(sel, "ADAPTIVITY_MODE = %s\n", (CONFIG_RTW_ADAPTIVITY_MODE) ? "carrier_sense" : "normal");
 #endif
 
 #ifdef CONFIG_WOWLAN
-	DBG_871X_SEL_NL(sel, "CONFIG_WOWLAN - ");
+	RTW_PRINT_SEL(sel, "CONFIG_WOWLAN - ");
 
-	#ifdef CONFIG_GPIO_WAKEUP
-	DBG_871X_SEL_NL(sel, "CONFIG_GPIO_WAKEUP - WAKEUP_GPIO_IDX:%d\n", WAKEUP_GPIO_IDX);
-	#endif
-#endif	
+#ifdef CONFIG_GPIO_WAKEUP
+	RTW_PRINT_SEL(sel, "CONFIG_GPIO_WAKEUP - WAKEUP_GPIO_IDX:%d\n", WAKEUP_GPIO_IDX);
+#endif
+#endif
+
+#ifdef CONFIG_TDLS
+	RTW_PRINT_SEL(sel, "CONFIG_TDLS\n");
+#endif
+
+#ifdef CONFIG_RTW_80211R
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_80211R\n");
+#endif
+
+#ifdef CONFIG_RTW_NETIF_SG
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_NETIF_SG\n");
+#endif
+
+#ifdef CONFIG_RTW_WIFI_HAL
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_WIFI_HAL\n");
+#endif
 
 #ifdef CONFIG_USB_HCI
-	#ifdef CONFIG_SUPPORT_USB_INT	
-	DBG_871X_SEL_NL(sel, "CONFIG_SUPPORT_USB_INT\n");
-	#endif
-	#ifdef CONFIG_USB_INTERRUPT_IN_PIPE		
-	DBG_871X_SEL_NL(sel, "CONFIG_USB_INTERRUPT_IN_PIPE\n");
-	#endif
-	#ifdef CONFIG_USB_TX_AGGREGATION
-	DBG_871X_SEL_NL(sel, "CONFIG_USB_TX_AGGREGATION\n");
-	#endif
-	#ifdef CONFIG_USB_RX_AGGREGATION
-	DBG_871X_SEL_NL(sel, "CONFIG_USB_RX_AGGREGATION\n");
-	#endif
-	#ifdef CONFIG_USE_USB_BUFFER_ALLOC_TX
-	DBG_871X_SEL_NL(sel, "CONFIG_USE_USB_BUFFER_ALLOC_TX\n");
-	#endif
-	#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
-	DBG_871X_SEL_NL(sel, "CONFIG_USE_USB_BUFFER_ALLOC_RX\n");
-	#endif	
-	#ifdef CONFIG_PREALLOC_RECV_SKB
-	DBG_871X_SEL_NL(sel, "CONFIG_PREALLOC_RECV_SKB\n");
-	#endif
-	#ifdef CONFIG_FIX_NR_BULKIN_BUFFER
-	DBG_871X_SEL_NL(sel, "CONFIG_FIX_NR_BULKIN_BUFFER\n");
-	#endif
+#ifdef CONFIG_SUPPORT_USB_INT
+	RTW_PRINT_SEL(sel, "CONFIG_SUPPORT_USB_INT\n");
+#endif
+#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
+	RTW_PRINT_SEL(sel, "CONFIG_USB_INTERRUPT_IN_PIPE\n");
+#endif
+#ifdef CONFIG_USB_TX_AGGREGATION
+	RTW_PRINT_SEL(sel, "CONFIG_USB_TX_AGGREGATION\n");
+#endif
+#ifdef CONFIG_USB_RX_AGGREGATION
+	RTW_PRINT_SEL(sel, "CONFIG_USB_RX_AGGREGATION\n");
+#endif
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_TX
+	RTW_PRINT_SEL(sel, "CONFIG_USE_USB_BUFFER_ALLOC_TX\n");
+#endif
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+	RTW_PRINT_SEL(sel, "CONFIG_USE_USB_BUFFER_ALLOC_RX\n");
+#endif
+#ifdef CONFIG_PREALLOC_RECV_SKB
+	RTW_PRINT_SEL(sel, "CONFIG_PREALLOC_RECV_SKB\n");
+#endif
+#ifdef CONFIG_FIX_NR_BULKIN_BUFFER
+	RTW_PRINT_SEL(sel, "CONFIG_FIX_NR_BULKIN_BUFFER\n");
+#endif
 #endif /*CONFIG_USB_HCI*/
-	
+
 #ifdef CONFIG_SDIO_HCI
-	#ifdef CONFIG_TX_AGGREGATION
-	DBG_871X_SEL_NL(sel, "CONFIG_TX_AGGREGATION\n");
-	#endif
-	#ifdef CONFIG_RX_AGGREGATION
-	DBG_871X_SEL_NL(sel, "CONFIG_RX_AGGREGATION\n");
-	#endif
+#ifdef CONFIG_TX_AGGREGATION
+	RTW_PRINT_SEL(sel, "CONFIG_TX_AGGREGATION\n");
+#endif
+#ifdef CONFIG_RX_AGGREGATION
+	RTW_PRINT_SEL(sel, "CONFIG_RX_AGGREGATION\n");
+#endif
 #endif /*CONFIG_SDIO_HCI*/
 
 #ifdef CONFIG_PCI_HCI
 #endif
-	
-	DBG_871X_SEL_NL(sel, "MAX_XMITBUF_SZ = %d\n", MAX_XMITBUF_SZ);
-	DBG_871X_SEL_NL(sel, "MAX_RECVBUF_SZ = %d\n", MAX_RECVBUF_SZ);
-	
+
+	RTW_PRINT_SEL(sel, "\n=== XMIT-INFO ===\n");
+	RTW_PRINT_SEL(sel, "NR_XMITFRAME = %d\n", NR_XMITFRAME);
+	RTW_PRINT_SEL(sel, "NR_XMITBUFF = %d\n", NR_XMITBUFF);
+	RTW_PRINT_SEL(sel, "MAX_XMITBUF_SZ = %d\n", MAX_XMITBUF_SZ);
+	RTW_PRINT_SEL(sel, "NR_XMIT_EXTBUFF = %d\n", NR_XMIT_EXTBUFF);
+	RTW_PRINT_SEL(sel, "MAX_XMIT_EXTBUF_SZ = %d\n", MAX_XMIT_EXTBUF_SZ);
+	RTW_PRINT_SEL(sel, "MAX_CMDBUF_SZ = %d\n", MAX_CMDBUF_SZ);
+
+	RTW_PRINT_SEL(sel, "\n=== RECV-INFO ===\n");
+	RTW_PRINT_SEL(sel, "NR_RECVFRAME = %d\n", NR_RECVFRAME);
+	RTW_PRINT_SEL(sel, "NR_RECVBUFF = %d\n", NR_RECVBUFF);
+	RTW_PRINT_SEL(sel, "MAX_RECVBUF_SZ = %d\n", MAX_RECVBUF_SZ);
+
 }
 
 void dump_log_level(void *sel)
 {
-	DBG_871X_SEL_NL(sel, "log_level:%d\n", GlobalDebugLevel);
+#ifdef CONFIG_RTW_DEBUG
+	int i;
+
+	RTW_PRINT_SEL(sel, "drv_log_level:%d\n", rtw_drv_log_level);
+	for (i = 0; i <= _DRV_MAX_; i++) {
+		if (rtw_log_level_str[i])
+			RTW_PRINT_SEL(sel, "%c %s = %d\n",
+				(rtw_drv_log_level == i) ? '+' : ' ', rtw_log_level_str[i], i);
+	}
+#else
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_DEBUG is disabled\n");
+#endif
 }
 
 #ifdef CONFIG_SDIO_HCI
@@ -199,17 +213,16 @@ void sd_f0_reg_dump(void *sel, _adapter *adapter)
 {
 	int i;
 
-	for(i=0x0;i<=0xff;i++)
-	{	
-		if(i%16==0)
-			DBG_871X_SEL_NL(sel, "0x%02x ",i);
+	for (i = 0x0; i <= 0xff; i++) {
+		if (i % 16 == 0)
+			RTW_PRINT_SEL(sel, "0x%02x ", i);
 
-		DBG_871X_SEL(sel, "%02x ", rtw_sd_f0_read8(adapter, i));
+		_RTW_PRINT_SEL(sel, "%02x ", rtw_sd_f0_read8(adapter, i));
 
-		if(i%16==15)
-			DBG_871X_SEL(sel, "\n");
-		else if(i%8==7)
-			DBG_871X_SEL(sel, "\t");
+		if (i % 16 == 15)
+			_RTW_PRINT_SEL(sel, "\n");
+		else if (i % 8 == 7)
+			_RTW_PRINT_SEL(sel, "\t");
 	}
 }
 
@@ -219,10 +232,10 @@ void sdio_local_reg_dump(void *sel, _adapter *adapter)
 
 	for (i = 0x0; i < 0x100; i += 4) {
 		if (j % 4 == 1)
-			DBG_871X_SEL_NL(sel, "0x%02x", i);
-		DBG_871X_SEL(sel, " 0x%08x ", rtw_read32(adapter, (0x1025 << 16) | i));
+			RTW_PRINT_SEL(sel, "0x%02x", i);
+		_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, (0x1025 << 16) | i));
 		if ((j++) % 4 == 0)
-			DBG_871X_SEL(sel, "\n");
+			_RTW_PRINT_SEL(sel, "\n");
 	}
 }
 #endif /* CONFIG_SDIO_HCI */
@@ -231,44 +244,82 @@ void mac_reg_dump(void *sel, _adapter *adapter)
 {
 	int i, j = 1;
 
-	DBG_871X_SEL_NL(sel, "======= MAC REG =======\n");
+	RTW_PRINT_SEL(sel, "======= MAC REG =======\n");
 
-	for(i=0x0;i<0x800;i+=4)
-	{
-		if(j%4==1)
-			DBG_871X_SEL_NL(sel, "0x%03x",i);
-		DBG_871X_SEL(sel, " 0x%08x ", rtw_read32(adapter,i));
-		if((j++)%4 == 0)
-			DBG_871X_SEL(sel, "\n");
+	for (i = 0x0; i < 0x800; i += 4) {
+		if (j % 4 == 1)
+			RTW_PRINT_SEL(sel, "0x%04x", i);
+		_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
+		if ((j++) % 4 == 0)
+			_RTW_PRINT_SEL(sel, "\n");
 	}
-	
+
 #ifdef CONFIG_RTL8814A
 	{
-		for(i=0x1000;i<0x1650;i+=4)
-		{
-			if(j%4==1)
-				DBG_871X_SEL_NL(sel, "0x%03x",i);
-			DBG_871X_SEL(sel, " 0x%08x ", rtw_read32(adapter,i));
-			if((j++)%4 == 0)
-				DBG_871X_SEL(sel, "\n");
+		for (i = 0x1000; i < 0x1650; i += 4) {
+			if (j % 4 == 1)
+				RTW_PRINT_SEL(sel, "0x%04x", i);
+			_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
+			if ((j++) % 4 == 0)
+				_RTW_PRINT_SEL(sel, "\n");
 		}
 	}
 #endif /* CONFIG_RTL8814A */
+
+
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	for (i = 0x1000; i < 0x1800; i += 4) {
+		if (j % 4 == 1)
+			RTW_PRINT_SEL(sel, "0x%04x", i);
+		_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
+		if ((j++) % 4 == 0)
+			_RTW_PRINT_SEL(sel, "\n");
+	}
+#endif /* CONFIG_RTL8822B */
 }
 
 void bb_reg_dump(void *sel, _adapter *adapter)
 {
 	int i, j = 1;
 
-	DBG_871X_SEL_NL(sel, "======= BB REG =======\n");
-	for(i=0x800;i<0x1000;i+=4)
-	{
-		if(j%4==1)
-			DBG_871X_SEL_NL(sel, "0x%03x",i);
-		DBG_871X_SEL(sel, " 0x%08x ", rtw_read32(adapter,i));
-		if((j++)%4 == 0)
-			DBG_871X_SEL(sel, "\n");
+	RTW_PRINT_SEL(sel, "======= BB REG =======\n");
+	for (i = 0x800; i < 0x1000; i += 4) {
+		if (j % 4 == 1)
+			RTW_PRINT_SEL(sel, "0x%04x", i);
+		_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
+		if ((j++) % 4 == 0)
+			_RTW_PRINT_SEL(sel, "\n");
+	}
+
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	for (i = 0x1800; i < 0x2000; i += 4) {
+		if (j % 4 == 1)
+			RTW_PRINT_SEL(sel, "0x%04x", i);
+		_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
+		if ((j++) % 4 == 0)
+			_RTW_PRINT_SEL(sel, "\n");
+	}
+#endif /* CONFIG_RTL8822B */
+}
+
+void bb_reg_dump_ex(void *sel, _adapter *adapter)
+{
+	int i, j = 1;
+
+	RTW_PRINT_SEL(sel, "======= BB REG =======\n");
+	for (i = 0x800; i < 0x1000; i += 4) {
+		RTW_PRINT_SEL(sel, "0x%04x", i);
+		_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
+		_RTW_PRINT_SEL(sel, "\n");
+	}
+
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	for (i = 0x1800; i < 0x2000; i += 4) {
+		RTW_PRINT_SEL(sel, "0x%04x", i);
+		_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
+		_RTW_PRINT_SEL(sel, "\n");
 	}
+#endif /* CONFIG_RTL8822B */
 }
 
 void rf_reg_dump(void *sel, _adapter *adapter)
@@ -279,79 +330,35 @@ void rf_reg_dump(void *sel, _adapter *adapter)
 	u8 path_nums = 0;
 
 	rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-	if((RF_1T2R == rf_type) ||(RF_1T1R ==rf_type ))
+	if ((RF_1T2R == rf_type) || (RF_1T1R == rf_type))
 		path_nums = 1;
 	else
 		path_nums = 2;
 
-	DBG_871X_SEL_NL(sel, "======= RF REG =======\n");
+	RTW_PRINT_SEL(sel, "======= RF REG =======\n");
 
-	for (path=0;path<path_nums;path++) {
-		DBG_871X_SEL_NL(sel, "RF_Path(%x)\n",path);
-		for (i=0;i<0x100;i++) {
+	for (path = 0; path < path_nums; path++) {
+		RTW_PRINT_SEL(sel, "RF_Path(%x)\n", path);
+		for (i = 0; i < 0x100; i++) {
 			value = rtw_hal_read_rfreg(adapter, path, i, 0xffffffff);
-			if(j%4==1)
-				DBG_871X_SEL_NL(sel, "0x%02x ",i);
-			DBG_871X_SEL(sel, " 0x%08x ",value);
-			if((j++)%4==0)
-				DBG_871X_SEL(sel, "\n");
+			if (j % 4 == 1)
+				RTW_PRINT_SEL(sel, "0x%02x ", i);
+			_RTW_PRINT_SEL(sel, " 0x%08x ", value);
+			if ((j++) % 4 == 0)
+				_RTW_PRINT_SEL(sel, "\n");
 		}
 	}
 }
 
-static u8 fwdl_test_chksum_fail = 0;
-static u8 fwdl_test_wintint_rdy_fail = 0;
-
-bool rtw_fwdl_test_trigger_chksum_fail(void)
-{
-	if (fwdl_test_chksum_fail) {
-		DBG_871X_LEVEL(_drv_always_, "fwdl test case: trigger chksum_fail\n");
-		fwdl_test_chksum_fail--;
-		return _TRUE;
-	}
-	return _FALSE;
-}
-
-bool rtw_fwdl_test_trigger_wintint_rdy_fail(void)
-{
-	if (fwdl_test_wintint_rdy_fail) {
-		DBG_871X_LEVEL(_drv_always_, "fwdl test case: trigger wintint_rdy_fail\n");
-		fwdl_test_wintint_rdy_fail--;
-		return _TRUE;
-	}
-	return _FALSE;
-}
-
-static u32 g_wait_hiq_empty_ms = 0;
-
-u32 rtw_get_wait_hiq_empty_ms(void)
-{
-	return g_wait_hiq_empty_ms;
-}
-
-static u8 del_rx_ampdu_test_no_tx_fail = 0;
-
-bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void)
-{
-	if (del_rx_ampdu_test_no_tx_fail) {
-		DBG_871X_LEVEL(_drv_always_, "del_rx_ampdu test case: trigger no_tx_fail\n");
-		del_rx_ampdu_test_no_tx_fail--;
-		return _TRUE;
-	}
-	return _FALSE;
-}
-
-void rtw_sink_rtp_seq_dbg( _adapter *adapter,_pkt *pkt)
+void rtw_sink_rtp_seq_dbg(_adapter *adapter, u8 *ehdr_pos)
 {
 	struct recv_priv *precvpriv = &(adapter->recvpriv);
-	if( precvpriv->sink_udpport > 0)
-	{
-		if(*((u16*)((pkt->data)+0x24)) == cpu_to_be16(precvpriv->sink_udpport))
-		{
-			precvpriv->pre_rtp_rxseq= precvpriv->cur_rtp_rxseq;
-			precvpriv->cur_rtp_rxseq = be16_to_cpu(*((u16*)((pkt->data)+0x2C)));
-			if( precvpriv->pre_rtp_rxseq+1 != precvpriv->cur_rtp_rxseq)
-				DBG_871X("%s : RTP Seq num from %d to %d\n",__FUNCTION__,precvpriv->pre_rtp_rxseq,precvpriv->cur_rtp_rxseq);
+	if (precvpriv->sink_udpport > 0) {
+		if (*((u16 *)(ehdr_pos + 0x24)) == cpu_to_be16(precvpriv->sink_udpport)) {
+			precvpriv->pre_rtp_rxseq = precvpriv->cur_rtp_rxseq;
+			precvpriv->cur_rtp_rxseq = be16_to_cpu(*((u16 *)(ehdr_pos + 0x2C)));
+			if (precvpriv->pre_rtp_rxseq + 1 != precvpriv->cur_rtp_rxseq)
+				RTW_INFO("%s : RTP Seq num from %d to %d\n", __FUNCTION__, precvpriv->pre_rtp_rxseq, precvpriv->cur_rtp_rxseq);
 		}
 	}
 }
@@ -364,9 +371,9 @@ void sta_rx_reorder_ctl_dump(void *sel, struct sta_info *sta)
 	for (i = 0; i < 16; i++) {
 		reorder_ctl = &sta->recvreorder_ctrl[i];
 		if (reorder_ctl->ampdu_size != RX_AMPDU_SIZE_INVALID || reorder_ctl->indicate_seq != 0xFFFF) {
-			DBG_871X_SEL_NL(sel, "tid=%d, enable=%d, ampdu_size=%u, indicate_seq=%u\n"
+			RTW_PRINT_SEL(sel, "tid=%d, enable=%d, ampdu_size=%u, indicate_seq=%u\n"
 				, i, reorder_ctl->enable, reorder_ctl->ampdu_size, reorder_ctl->indicate_seq
-			);
+				     );
 		}
 	}
 }
@@ -417,58 +424,136 @@ void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
 	_adapter *iface;
 	u8 u_ch, u_bw, u_offset;
 
-	DBG_871X_SEL_NL(sel, "%-2s %-8s %-17s %-4s %-7s %s\n"
-		, "id", "ifname", "macaddr", "port", "ch", "status");
+	dump_mi_status(sel, dvobj);
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	RTW_PRINT_SEL(sel, "default port id:%d\n\n", dvobj->default_port_id);
+#endif /* CONFIG_FW_MULTI_PORT_SUPPORT */
+
+	RTW_PRINT_SEL(sel, "dev status:%s%s\n\n"
+		, dev_is_surprise_removed(dvobj) ? " SR" : ""
+		, dev_is_drv_stopped(dvobj) ? " DS" : ""
+	);
+
+#ifdef CONFIG_P2P
+#define P2P_INFO_TITLE_FMT	" %-3s %-4s"
+#define P2P_INFO_TITLE_ARG	, "lch", "p2ps"
+#ifdef CONFIG_IOCTL_CFG80211
+#define P2P_INFO_VALUE_FMT	" %3u %c%3u"
+#define P2P_INFO_VALUE_ARG	, iface->wdinfo.listen_channel, iface->wdev_data.p2p_enabled ? 'e' : ' ', rtw_p2p_state(&iface->wdinfo)
+#else
+#define P2P_INFO_VALUE_FMT	" %3u %4u"
+#define P2P_INFO_VALUE_ARG	, iface->wdinfo.listen_channel, rtw_p2p_state(&iface->wdinfo)
+#endif
+#define P2P_INFO_DASH		"---------"
+#else
+#define P2P_INFO_TITLE_FMT	""
+#define P2P_INFO_TITLE_ARG
+#define P2P_INFO_VALUE_FMT	""
+#define P2P_INFO_VALUE_ARG
+#define P2P_INFO_DASH
+#endif
+
+	RTW_PRINT_SEL(sel, "%-2s %-15s %c %-3s %-3s %-3s %-17s %-4s %-7s"
+		P2P_INFO_TITLE_FMT
+		" %s\n"
+		, "id", "ifname", ' ', "bup", "nup", "ncd", "macaddr", "port", "ch"
+		P2P_INFO_TITLE_ARG
+		, "status");
 
-	DBG_871X_SEL_NL(sel, "------------------------------------------\n");
+	RTW_PRINT_SEL(sel, "---------------------------------------------------------------"
+		P2P_INFO_DASH
+		"-------\n");
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
 		if (iface) {
-			DBG_871X_SEL_NL(sel, "%2d %-8s "MAC_FMT" %4hhu %3u,%u,%u "MLME_STATE_FMT" %s%s\n"
-				, i, ADPT_ARG(iface)
+			RTW_PRINT_SEL(sel, "%2d %-15s %c %3u %3u %3u "MAC_FMT" %4hhu %3u,%u,%u"
+				P2P_INFO_VALUE_FMT
+				" "MLME_STATE_FMT"\n"
+				, i, iface->registered ? ADPT_ARG(iface) : NULL
+				, iface->registered ? 'R' : ' '
+				, iface->bup
+				, iface->netif_up
+				, iface->net_closed
 				, MAC_ARG(adapter_mac_addr(iface))
-				, get_iface_type(iface)
+				, get_hw_port(iface)
 				, iface->mlmeextpriv.cur_channel
 				, iface->mlmeextpriv.cur_bwmode
 				, iface->mlmeextpriv.cur_ch_offset
+				P2P_INFO_VALUE_ARG
 				, MLME_STATE_ARG(iface)
-				, rtw_is_surprise_removed(iface)?" SR":""
-				, rtw_is_drv_stopped(iface)?" DS":""
 			);
 		}
 	}
 
-	DBG_871X_SEL_NL(sel, "------------------------------------------\n");
+	RTW_PRINT_SEL(sel, "---------------------------------------------------------------"
+		P2P_INFO_DASH
+		"-------\n");
 
-	rtw_get_ch_setting_union(dvobj->padapters[IFACE_ID0], &u_ch, &u_bw, &u_offset);
-	DBG_871X_SEL_NL(sel, "%34s %3u,%u,%u\n"
+	rtw_mi_get_ch_setting_union(dvobj_get_primary_adapter(dvobj), &u_ch, &u_bw, &u_offset);
+	RTW_PRINT_SEL(sel, "%55s %3u,%u,%u\n"
 		, "union:"
 		, u_ch, u_bw, u_offset
 	);
 
-	DBG_871X_SEL_NL(sel, "%34s %3u,%u,%u\n"
+	RTW_PRINT_SEL(sel, "%55s %3u,%u,%u offch_state:%d\n"
 		, "oper:"
 		, dvobj->oper_channel
 		, dvobj->oper_bwmode
 		, dvobj->oper_ch_offset
+		, rfctl->offch_state
 	);
 
-	#ifdef CONFIG_DFS_MASTER
+#ifdef CONFIG_DFS_MASTER
 	if (rfctl->radar_detect_ch != 0) {
-		DBG_871X_SEL_NL(sel, "%34s %3u,%u,%u"
+		RTW_PRINT_SEL(sel, "%55s %3u,%u,%u"
 			, "radar_detect:"
 			, rfctl->radar_detect_ch
 			, rfctl->radar_detect_bw
 			, rfctl->radar_detect_offset
 		);
 
-		if (IS_UNDER_CAC(rfctl))
-			DBG_871X_SEL(sel, ", cac:%d\n", rtw_systime_to_ms(rfctl->cac_end_time - rtw_get_current_time()));
-		else
-			DBG_871X_SEL(sel, "\n");
+		if (rfctl->radar_detect_by_others)
+			_RTW_PRINT_SEL(sel, ", by AP of STA link");
+		else {
+			u32 non_ocp_ms;
+			u32 cac_ms;
+			u8 dfs_domain = rtw_odm_get_dfs_domain(dvobj_get_primary_adapter(dvobj));
+
+			_RTW_PRINT_SEL(sel, ", domain:%u", dfs_domain);
+
+			for (i = 0; i < dvobj->iface_nums; i++) {
+				if (!dvobj->padapters[i])
+					continue;
+				if (check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE)
+					&& check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_ASOC_STATE))
+					break;
+			}
+
+			if (i >= dvobj->iface_nums) {
+				RTW_PRINT_SEL(sel, "DFS master enable without AP/Mesh mode???");
+				goto end_dfs_master;
+			}
+
+			rtw_get_ch_waiting_ms(dvobj->padapters[i]
+				, rfctl->radar_detect_ch
+				, rfctl->radar_detect_bw
+				, rfctl->radar_detect_offset
+				, &non_ocp_ms
+				, &cac_ms
+			);
+
+			if (non_ocp_ms)
+				_RTW_PRINT_SEL(sel, ", non_ocp:%d", non_ocp_ms);
+			if (cac_ms)
+				_RTW_PRINT_SEL(sel, ", cac:%d", cac_ms);
+		}
+
+end_dfs_master:
+		_RTW_PRINT_SEL(sel, "\n");
 	}
-	#endif
+#endif /* CONFIG_DFS_MASTER */
 }
 
 #define SEC_CAM_ENT_ID_TITLE_FMT "%-2s"
@@ -492,21 +577,19 @@ void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
 void dump_sec_cam_ent(void *sel, struct sec_cam_ent *ent, int id)
 {
 	if (id >= 0) {
-		DBG_871X_SEL_NL(sel, SEC_CAM_ENT_ID_VALUE_FMT " " SEC_CAM_ENT_VALUE_FMT"\n"
+		RTW_PRINT_SEL(sel, SEC_CAM_ENT_ID_VALUE_FMT " " SEC_CAM_ENT_VALUE_FMT"\n"
 			, SEC_CAM_ENT_ID_VALUE_ARG(id), SEC_CAM_ENT_VALUE_ARG(ent));
-	} else {
-		DBG_871X_SEL_NL(sel, SEC_CAM_ENT_VALUE_FMT"\n", SEC_CAM_ENT_VALUE_ARG(ent));
-	}
+	} else
+		RTW_PRINT_SEL(sel, SEC_CAM_ENT_VALUE_FMT"\n", SEC_CAM_ENT_VALUE_ARG(ent));
 }
 
 void dump_sec_cam_ent_title(void *sel, u8 has_id)
 {
 	if (has_id) {
-		DBG_871X_SEL_NL(sel, SEC_CAM_ENT_ID_TITLE_FMT " " SEC_CAM_ENT_TITLE_FMT"\n"
+		RTW_PRINT_SEL(sel, SEC_CAM_ENT_ID_TITLE_FMT " " SEC_CAM_ENT_TITLE_FMT"\n"
 			, SEC_CAM_ENT_ID_TITLE_ARG, SEC_CAM_ENT_TITLE_ARG);
-	} else {
-		DBG_871X_SEL_NL(sel, SEC_CAM_ENT_TITLE_FMT"\n", SEC_CAM_ENT_TITLE_ARG);
-	}
+	} else
+		RTW_PRINT_SEL(sel, SEC_CAM_ENT_TITLE_FMT"\n", SEC_CAM_ENT_TITLE_ARG);
 }
 
 void dump_sec_cam(void *sel, _adapter *adapter)
@@ -516,7 +599,7 @@ void dump_sec_cam(void *sel, _adapter *adapter)
 	struct sec_cam_ent ent;
 	int i;
 
-	DBG_871X_SEL_NL(sel, "HW sec cam:\n");
+	RTW_PRINT_SEL(sel, "HW sec cam:\n");
 	dump_sec_cam_ent_title(sel, 1);
 	for (i = 0; i < cam_ctl->num; i++) {
 		rtw_sec_read_cam_ent(adapter, i, (u8 *)(&ent.ctrl), ent.mac, ent.key);
@@ -524,6 +607,21 @@ void dump_sec_cam(void *sel, _adapter *adapter)
 	}
 }
 
+void dump_sec_cam_cache(void *sel, _adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	int i;
+
+	RTW_PRINT_SEL(sel, "SW sec cam cache:\n");
+	dump_sec_cam_ent_title(sel, 1);
+	for (i = 0; i < cam_ctl->num; i++) {
+		if (dvobj->cam_cache[i].ctrl != 0)
+			dump_sec_cam_ent(sel, &dvobj->cam_cache[i], i);
+	}
+
+}
+
 #ifdef CONFIG_PROC_DEBUG
 ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
@@ -532,11 +630,10 @@ ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t
 	char tmp[32];
 	u32 addr, val, len;
 
-	if (count < 3)
-	{
-		DBG_871X("argument size is less than 3\n");
+	if (count < 3) {
+		RTW_INFO("argument size is less than 3\n");
 		return -EFAULT;
-	}	
+	}
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
@@ -548,59 +645,57 @@ ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t
 		int num = sscanf(tmp, "%x %x %x", &addr, &val, &len);
 
 		if (num !=  3) {
-			DBG_871X("invalid write_reg parameter!\n");
+			RTW_INFO("invalid write_reg parameter!\n");
 			return count;
 		}
 
-		switch(len)
-		{
-			case 1:
-				rtw_write8(padapter, addr, (u8)val);				
-				break;
-			case 2:
-				rtw_write16(padapter, addr, (u16)val);				
-				break;
-			case 4:
-				rtw_write32(padapter, addr, val);				
-				break;
-			default:
-				DBG_871X("error write length=%d", len);
-				break;
-		}			
-		
+		switch (len) {
+		case 1:
+			rtw_write8(padapter, addr, (u8)val);
+			break;
+		case 2:
+			rtw_write16(padapter, addr, (u16)val);
+			break;
+		case 4:
+			rtw_write32(padapter, addr, val);
+			break;
+		default:
+			RTW_INFO("error write length=%d", len);
+			break;
+		}
+
 	}
-	
+
 	return count;
-	
+
 }
 
-static u32 proc_get_read_addr=0xeeeeeeee;
-static u32 proc_get_read_len=0x4;
+static u32 proc_get_read_addr = 0xeeeeeeee;
+static u32 proc_get_read_len = 0x4;
 
 int proc_get_read_reg(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	if (proc_get_read_addr==0xeeeeeeee) {
-		DBG_871X_SEL_NL(m, "address not initialized\n");
+	if (proc_get_read_addr == 0xeeeeeeee) {
+		RTW_PRINT_SEL(m, "address not initialized\n");
 		return 0;
-	}	
+	}
 
-	switch(proc_get_read_len)
-	{
-		case 1:			
-			DBG_871X_SEL_NL(m, "rtw_read8(0x%x)=0x%x\n", proc_get_read_addr, rtw_read8(padapter, proc_get_read_addr));
-			break;
-		case 2:
-			DBG_871X_SEL_NL(m, "rtw_read16(0x%x)=0x%x\n", proc_get_read_addr, rtw_read16(padapter, proc_get_read_addr));
-			break;
-		case 4:
-			DBG_871X_SEL_NL(m, "rtw_read32(0x%x)=0x%x\n", proc_get_read_addr, rtw_read32(padapter, proc_get_read_addr));
-			break;
-		default:
-			DBG_871X_SEL_NL(m, "error read length=%d\n", proc_get_read_len);
-			break;
+	switch (proc_get_read_len) {
+	case 1:
+		RTW_PRINT_SEL(m, "rtw_read8(0x%x)=0x%x\n", proc_get_read_addr, rtw_read8(padapter, proc_get_read_addr));
+		break;
+	case 2:
+		RTW_PRINT_SEL(m, "rtw_read16(0x%x)=0x%x\n", proc_get_read_addr, rtw_read16(padapter, proc_get_read_addr));
+		break;
+	case 4:
+		RTW_PRINT_SEL(m, "rtw_read32(0x%x)=0x%x\n", proc_get_read_addr, rtw_read32(padapter, proc_get_read_addr));
+		break;
+	default:
+		RTW_PRINT_SEL(m, "error read length=%d\n", proc_get_read_len);
+		break;
 	}
 
 	return 0;
@@ -612,11 +707,10 @@ ssize_t proc_set_read_reg(struct file *file, const char __user *buffer, size_t c
 	char tmp[16];
 	u32 addr, len;
 
-	if (count < 2)
-	{
-		DBG_871X("argument size is less than 2\n");
+	if (count < 2) {
+		RTW_INFO("argument size is less than 2\n");
 		return -EFAULT;
-	}	
+	}
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
@@ -628,26 +722,145 @@ ssize_t proc_set_read_reg(struct file *file, const char __user *buffer, size_t c
 		int num = sscanf(tmp, "%x %x", &addr, &len);
 
 		if (num !=  2) {
-			DBG_871X("invalid read_reg parameter!\n");
+			RTW_INFO("invalid read_reg parameter!\n");
 			return count;
 		}
 
 		proc_get_read_addr = addr;
-		
+
 		proc_get_read_len = len;
 	}
-	
+
 	return count;
 
 }
 
+int proc_get_rx_stat(struct seq_file *m, void *v)
+{
+	_irqL	 irqL;
+	_list	*plist, *phead;
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_info *psta = NULL;
+	struct stainfo_stats	*pstats = NULL;
+	struct sta_priv		*pstapriv = &(adapter->stapriv);
+	u32 i, j;
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+			plist = get_next(plist);
+			pstats = &psta->sta_stats;
+
+			if (pstats == NULL)
+				continue;
+			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6) !=  _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) != _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), 6) != _TRUE)) {
+				RTW_PRINT_SEL(m, "MAC :\t\t"MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+				RTW_PRINT_SEL(m, "data_rx_cnt :\t%llu\n", sta_rx_data_uc_pkts(psta) - pstats->last_rx_data_uc_pkts);
+				pstats->last_rx_data_uc_pkts = sta_rx_data_uc_pkts(psta);
+				RTW_PRINT_SEL(m, "duplicate_cnt :\t%u\n", pstats->duplicate_cnt);
+				pstats->duplicate_cnt = 0;
+				RTW_PRINT_SEL(m, "rx_per_rate_cnt :\n");
+
+				for (j = 0; j < 0x60; j++) {
+					RTW_PRINT_SEL(m, "%08u  ", pstats->rxratecnt[j]);
+					pstats->rxratecnt[j] = 0;
+					if ((j%8) == 7)
+						RTW_PRINT_SEL(m, "\n");
+				}
+				RTW_PRINT_SEL(m, "\n");
+			}
+		}
+	}
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	return 0;
+}
+
+int proc_get_tx_stat(struct seq_file *m, void *v)
+{
+	_irqL	irqL;
+	_list	*plist, *phead;
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_info *psta = NULL;
+	u8 sta_mac[NUM_STA][ETH_ALEN] = {{0}};
+	uint mac_id[NUM_STA];
+	struct stainfo_stats	*pstats = NULL;
+	struct sta_priv	*pstapriv = &(adapter->stapriv);
+	struct sta_priv	*pstapriv_primary = &(GET_PRIMARY_ADAPTER(adapter))->stapriv;
+	u32 i, macid_rec_idx = 0;
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	struct submit_ctx gotc2h;
+
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+			plist = get_next(plist);
+			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6) !=  _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) != _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), 6) != _TRUE)) {
+				_rtw_memcpy(&sta_mac[macid_rec_idx][0], psta->cmn.mac_addr, ETH_ALEN);
+				mac_id[macid_rec_idx] = psta->cmn.mac_id;
+				macid_rec_idx++;
+			}
+		}
+	}
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	for (i = 0; i < macid_rec_idx; i++) {
+		_rtw_memcpy(pstapriv_primary->c2h_sta_mac, &sta_mac[i][0], ETH_ALEN);
+		pstapriv_primary->c2h_adapter_id = adapter->iface_id;
+		rtw_sctx_init(&gotc2h, 60);
+		pstapriv_primary->gotc2h = &gotc2h;
+		rtw_hal_reqtxrpt(adapter, mac_id[i]);
+		if (rtw_sctx_wait(&gotc2h, __func__)) {
+			psta = rtw_get_stainfo(pstapriv, &sta_mac[i][0]);
+			if(psta) {
+				pstats = &psta->sta_stats;
+#ifndef ROKU_PRIVATE
+				RTW_PRINT_SEL(m, "data_sent_cnt :\t%u\n", pstats->tx_ok_cnt + pstats->tx_fail_cnt);
+				RTW_PRINT_SEL(m, "success_cnt :\t%u\n", pstats->tx_ok_cnt);
+				RTW_PRINT_SEL(m, "failure_cnt :\t%u\n", pstats->tx_fail_cnt);
+				RTW_PRINT_SEL(m, "retry_cnt :\t%u\n\n", pstats->tx_retry_cnt);
+#else
+				RTW_PRINT_SEL(m, "MAC: " MAC_FMT " sent: %u fail: %u retry: %u\n",
+				MAC_ARG(&sta_mac[i][0]), pstats->tx_ok_cnt, pstats->tx_fail_cnt, pstats->tx_retry_cnt);
+#endif /* ROKU_PRIVATE */
+
+			} else
+				RTW_PRINT_SEL(m, "STA is gone\n");
+		} else {
+			//to avoid c2h modify counters
+			pstapriv_primary->gotc2h = NULL;
+			_rtw_memset(pstapriv_primary->c2h_sta_mac, 0, ETH_ALEN);
+			pstapriv_primary->c2h_adapter_id = CONFIG_IFACE_NUMBER;
+			RTW_PRINT_SEL(m, "Warming : Query timeout, operation abort!!\n");
+			break;
+		}
+		pstapriv_primary->gotc2h = NULL;
+		_rtw_memset(pstapriv_primary->c2h_sta_mac, 0, ETH_ALEN);
+		pstapriv_primary->c2h_adapter_id = CONFIG_IFACE_NUMBER;
+	}
+	return 0;
+}
+
 int proc_get_fwstate(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
-	DBG_871X_SEL_NL(m, "fwstate=0x%x\n", get_fwstate(pmlmepriv));
+	RTW_PRINT_SEL(m, "fwstate=0x%x\n", get_fwstate(pmlmepriv));
 
 	return 0;
 }
@@ -655,29 +868,29 @@ int proc_get_fwstate(struct seq_file *m, void *v)
 int proc_get_sec_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct security_priv *sec = &padapter->securitypriv;
 
-	DBG_871X_SEL_NL(m, "auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n", 
-						sec->dot11AuthAlgrthm, sec->dot11PrivacyAlgrthm,
-						sec->ndisauthtype, sec->ndisencryptstatus);
+	RTW_PRINT_SEL(m, "auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n",
+		sec->dot11AuthAlgrthm, sec->dot11PrivacyAlgrthm,
+		sec->ndisauthtype, sec->ndisencryptstatus);
 
-	DBG_871X_SEL_NL(m, "hw_decrypted=%d\n", sec->hw_decrypted);
+	RTW_PRINT_SEL(m, "hw_decrypted=%d\n", sec->hw_decrypted);
 
 #ifdef DBG_SW_SEC_CNT
-	DBG_871X_SEL_NL(m, "wep_sw_enc_cnt=%llu, %llu, %llu\n"
+	RTW_PRINT_SEL(m, "wep_sw_enc_cnt=%llu, %llu, %llu\n"
 		, sec->wep_sw_enc_cnt_bc , sec->wep_sw_enc_cnt_mc, sec->wep_sw_enc_cnt_uc);
-	DBG_871X_SEL_NL(m, "wep_sw_dec_cnt=%llu, %llu, %llu\n"
+	RTW_PRINT_SEL(m, "wep_sw_dec_cnt=%llu, %llu, %llu\n"
 		, sec->wep_sw_dec_cnt_bc , sec->wep_sw_dec_cnt_mc, sec->wep_sw_dec_cnt_uc);
 
-	DBG_871X_SEL_NL(m, "tkip_sw_enc_cnt=%llu, %llu, %llu\n"
-		, sec->tkip_sw_enc_cnt_bc , sec->tkip_sw_enc_cnt_mc, sec->tkip_sw_enc_cnt_uc);	
-	DBG_871X_SEL_NL(m, "tkip_sw_dec_cnt=%llu, %llu, %llu\n"
+	RTW_PRINT_SEL(m, "tkip_sw_enc_cnt=%llu, %llu, %llu\n"
+		, sec->tkip_sw_enc_cnt_bc , sec->tkip_sw_enc_cnt_mc, sec->tkip_sw_enc_cnt_uc);
+	RTW_PRINT_SEL(m, "tkip_sw_dec_cnt=%llu, %llu, %llu\n"
 		, sec->tkip_sw_dec_cnt_bc , sec->tkip_sw_dec_cnt_mc, sec->tkip_sw_dec_cnt_uc);
 
-	DBG_871X_SEL_NL(m, "aes_sw_enc_cnt=%llu, %llu, %llu\n"
+	RTW_PRINT_SEL(m, "aes_sw_enc_cnt=%llu, %llu, %llu\n"
 		, sec->aes_sw_enc_cnt_bc , sec->aes_sw_enc_cnt_mc, sec->aes_sw_enc_cnt_uc);
-	DBG_871X_SEL_NL(m, "aes_sw_dec_cnt=%llu, %llu, %llu\n"
+	RTW_PRINT_SEL(m, "aes_sw_dec_cnt=%llu, %llu, %llu\n"
 		, sec->aes_sw_dec_cnt_bc , sec->aes_sw_dec_cnt_mc, sec->aes_sw_dec_cnt_uc);
 #endif /* DBG_SW_SEC_CNT */
 
@@ -687,11 +900,11 @@ int proc_get_sec_info(struct seq_file *m, void *v)
 int proc_get_mlmext_state(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	DBG_871X_SEL_NL(m, "pmlmeinfo->state=0x%x\n", pmlmeinfo->state);
+	RTW_PRINT_SEL(m, "pmlmeinfo->state=0x%x\n", pmlmeinfo->state);
 
 	return 0;
 }
@@ -702,7 +915,7 @@ int proc_get_roam_flags(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X_SEL_NL(m, "0x%02x\n", rtw_roam_flags(adapter));
+	RTW_PRINT_SEL(m, "0x%02x\n", rtw_roam_flags(adapter));
 
 	return 0;
 }
@@ -730,9 +943,9 @@ ssize_t proc_set_roam_flags(struct file *file, const char __user *buffer, size_t
 		if (num == 1)
 			rtw_assign_roam_flags(adapter, flags);
 	}
-	
+
 	return count;
-	
+
 }
 
 int proc_get_roam_param(struct seq_file *m, void *v)
@@ -741,11 +954,12 @@ int proc_get_roam_param(struct seq_file *m, void *v)
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *mlme = &adapter->mlmepriv;
 
-	DBG_871X_SEL_NL(m, "%12s %12s %11s\n", "rssi_diff_th", "scanr_exp_ms", "scan_int_ms");
-	DBG_871X_SEL_NL(m, "%-12u %-12u %-11u\n"
+	RTW_PRINT_SEL(m, "%12s %12s %11s %14s\n", "rssi_diff_th", "scanr_exp_ms", "scan_int_ms", "rssi_threshold");
+	RTW_PRINT_SEL(m, "%-12u %-12u %-11u %-14u\n"
 		, mlme->roam_rssi_diff_th
 		, mlme->roam_scanr_exp_ms
 		, mlme->roam_scan_int_ms
+		, mlme->roam_rssi_threshold
 	);
 
 	return 0;
@@ -761,6 +975,7 @@ ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t
 	u8 rssi_diff_th;
 	u32 scanr_exp_ms;
 	u32 scan_int_ms;
+	u8 rssi_threshold;
 
 	if (count < 1)
 		return -EFAULT;
@@ -772,7 +987,7 @@ ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%hhu %u %u", &rssi_diff_th, &scanr_exp_ms, &scan_int_ms);
+		int num = sscanf(tmp, "%hhu %u %u %hhu", &rssi_diff_th, &scanr_exp_ms, &scan_int_ms, &rssi_threshold);
 
 		if (num >= 1)
 			mlme->roam_rssi_diff_th = rssi_diff_th;
@@ -780,10 +995,12 @@ ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t
 			mlme->roam_scanr_exp_ms = scanr_exp_ms;
 		if (num >= 3)
 			mlme->roam_scan_int_ms = scan_int_ms;
+		if (num >= 4)
+			mlme->roam_rssi_threshold = rssi_threshold;
 	}
-	
+
 	return count;
-	
+
 }
 
 ssize_t proc_set_roam_tgt_addr(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
@@ -804,37 +1021,76 @@ ssize_t proc_set_roam_tgt_addr(struct file *file, const char __user *buffer, siz
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%hhx:%hhx:%hhx:%hhx:%hhx:%hhx", addr, addr+1, addr+2, addr+3, addr+4, addr+5);
+		int num = sscanf(tmp, "%hhx:%hhx:%hhx:%hhx:%hhx:%hhx", addr, addr + 1, addr + 2, addr + 3, addr + 4, addr + 5);
 		if (num == 6)
 			_rtw_memcpy(adapter->mlmepriv.roam_tgt_addr, addr, ETH_ALEN);
 
-		DBG_871X("set roam_tgt_addr to "MAC_FMT"\n", MAC_ARG(adapter->mlmepriv.roam_tgt_addr));
+		RTW_INFO("set roam_tgt_addr to "MAC_FMT"\n", MAC_ARG(adapter->mlmepriv.roam_tgt_addr));
 	}
 
 	return count;
 }
 #endif /* CONFIG_LAYER2_ROAMING */
 
-int proc_get_qos_option(struct seq_file *m, void *v)
+#ifdef CONFIG_RTW_80211R
+ssize_t proc_set_ft_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X_SEL_NL(m, "qos_option=%d\n", pmlmepriv->qospriv.qos_option);
+	char tmp[32];
+	u8 flags;
 
-	return 0;
-}
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%hhx", &flags);
+
+		if (num == 1)
+			adapter->mlmepriv.ft_roam.ft_flags = flags;
+	}
+
+	return count;
+
+}
+
+int proc_get_ft_flags(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "0x%02x\n", adapter->mlmepriv.ft_roam.ft_flags);
+
+	return 0;
+}
+#endif
+
+int proc_get_qos_option(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	RTW_PRINT_SEL(m, "qos_option=%d\n", pmlmepriv->qospriv.qos_option);
+
+	return 0;
+}
 
 int proc_get_ht_option(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	
+
 #ifdef CONFIG_80211N_HT
-	DBG_871X_SEL_NL(m, "ht_option=%d\n", pmlmepriv->htpriv.ht_option);
-#endif //CONFIG_80211N_HT
+	RTW_PRINT_SEL(m, "ht_option=%d\n", pmlmepriv->htpriv.ht_option);
+#endif /* CONFIG_80211N_HT */
 
 	return 0;
 }
@@ -842,14 +1098,14 @@ int proc_get_ht_option(struct seq_file *m, void *v)
 int proc_get_rf_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;	
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+
+	RTW_PRINT_SEL(m, "cur_ch=%d, cur_bw=%d, cur_ch_offet=%d\n",
+		pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
 
-	DBG_871X_SEL_NL(m, "cur_ch=%d, cur_bw=%d, cur_ch_offet=%d\n", 
-					pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
-	
-	DBG_871X_SEL_NL(m, "oper_ch=%d, oper_bw=%d, oper_ch_offet=%d\n", 
-					rtw_get_oper_ch(padapter), rtw_get_oper_bw(padapter),  rtw_get_oper_choffset(padapter));
+	RTW_PRINT_SEL(m, "oper_ch=%d, oper_bw=%d, oper_ch_offet=%d\n",
+		rtw_get_oper_ch(padapter), rtw_get_oper_bw(padapter),  rtw_get_oper_choffset(padapter));
 
 	return 0;
 }
@@ -866,29 +1122,29 @@ int proc_get_scan_param(struct seq_file *m, void *v)
 #define SCAN_PARAM_TITLE_ARG , "scan_ch_ms"
 #define SCAN_PARAM_VALUE_ARG , ss->scan_ch_ms
 #ifdef CONFIG_80211N_HT
-	#define SCAN_PARAM_TITLE_FMT_HT " %15s %13s"
-	#define SCAN_PARAM_VALUE_FMT_HT " %-15u %-13u"
-	#define SCAN_PARAM_TITLE_ARG_HT , "rx_ampdu_accept", "rx_ampdu_size"
-	#define SCAN_PARAM_VALUE_ARG_HT , ss->rx_ampdu_accept, ss->rx_ampdu_size
+#define SCAN_PARAM_TITLE_FMT_HT " %15s %13s"
+#define SCAN_PARAM_VALUE_FMT_HT " %-15u %-13u"
+#define SCAN_PARAM_TITLE_ARG_HT , "rx_ampdu_accept", "rx_ampdu_size"
+#define SCAN_PARAM_VALUE_ARG_HT , ss->rx_ampdu_accept, ss->rx_ampdu_size
 #else
-	#define SCAN_PARAM_TITLE_FMT_HT ""
-	#define SCAN_PARAM_VALUE_FMT_HT ""
-	#define SCAN_PARAM_TITLE_ARG_HT
-	#define SCAN_PARAM_VALUE_ARG_HT
+#define SCAN_PARAM_TITLE_FMT_HT ""
+#define SCAN_PARAM_VALUE_FMT_HT ""
+#define SCAN_PARAM_TITLE_ARG_HT
+#define SCAN_PARAM_VALUE_ARG_HT
 #endif
 #ifdef CONFIG_SCAN_BACKOP
-	#define SCAN_PARAM_TITLE_FMT_BACKOP " %9s %12s"
-	#define SCAN_PARAM_VALUE_FMT_BACKOP " %-9u %-12u"
-	#define SCAN_PARAM_TITLE_ARG_BACKOP , "backop_ms", "scan_cnt_max"
-	#define SCAN_PARAM_VALUE_ARG_BACKOP , ss->backop_ms, ss->scan_cnt_max
+#define SCAN_PARAM_TITLE_FMT_BACKOP " %9s %12s"
+#define SCAN_PARAM_VALUE_FMT_BACKOP " %-9u %-12u"
+#define SCAN_PARAM_TITLE_ARG_BACKOP , "backop_ms", "scan_cnt_max"
+#define SCAN_PARAM_VALUE_ARG_BACKOP , ss->backop_ms, ss->scan_cnt_max
 #else
-	#define SCAN_PARAM_TITLE_FMT_BACKOP ""
-	#define SCAN_PARAM_VALUE_FMT_BACKOP ""
-	#define SCAN_PARAM_TITLE_ARG_BACKOP
-	#define SCAN_PARAM_VALUE_ARG_BACKOP
+#define SCAN_PARAM_TITLE_FMT_BACKOP ""
+#define SCAN_PARAM_VALUE_FMT_BACKOP ""
+#define SCAN_PARAM_TITLE_ARG_BACKOP
+#define SCAN_PARAM_VALUE_ARG_BACKOP
 #endif
 
-	DBG_871X_SEL_NL(m,
+	RTW_PRINT_SEL(m,
 		SCAN_PARAM_TITLE_FMT
 		SCAN_PARAM_TITLE_FMT_HT
 		SCAN_PARAM_TITLE_FMT_BACKOP
@@ -898,7 +1154,7 @@ int proc_get_scan_param(struct seq_file *m, void *v)
 		SCAN_PARAM_TITLE_ARG_BACKOP
 	);
 
-	DBG_871X_SEL_NL(m,
+	RTW_PRINT_SEL(m,
 		SCAN_PARAM_VALUE_FMT
 		SCAN_PARAM_VALUE_FMT_HT
 		SCAN_PARAM_VALUE_FMT_BACKOP
@@ -920,26 +1176,26 @@ ssize_t proc_set_scan_param(struct file *file, const char __user *buffer, size_t
 
 	char tmp[32] = {0};
 
-u16 scan_ch_ms;
+	u16 scan_ch_ms;
 #define SCAN_PARAM_INPUT_FMT "%hu"
 #define SCAN_PARAM_INPUT_ARG , &scan_ch_ms
 #ifdef CONFIG_80211N_HT
 	u8 rx_ampdu_accept;
 	u8 rx_ampdu_size;
-	#define SCAN_PARAM_INPUT_FMT_HT " %hhu %hhu"
-	#define SCAN_PARAM_INPUT_ARG_HT , &rx_ampdu_accept, &rx_ampdu_size
+#define SCAN_PARAM_INPUT_FMT_HT " %hhu %hhu"
+#define SCAN_PARAM_INPUT_ARG_HT , &rx_ampdu_accept, &rx_ampdu_size
 #else
-	#define SCAN_PARAM_INPUT_FMT_HT ""
-	#define SCAN_PARAM_INPUT_ARG_HT
+#define SCAN_PARAM_INPUT_FMT_HT ""
+#define SCAN_PARAM_INPUT_ARG_HT
 #endif
 #ifdef CONFIG_SCAN_BACKOP
 	u16 backop_ms;
 	u8 scan_cnt_max;
-	#define SCAN_PARAM_INPUT_FMT_BACKOP " %hu %hhu"
-	#define SCAN_PARAM_INPUT_ARG_BACKOP , &backop_ms, &scan_cnt_max
+#define SCAN_PARAM_INPUT_FMT_BACKOP " %hu %hhu"
+#define SCAN_PARAM_INPUT_ARG_BACKOP , &backop_ms, &scan_cnt_max
 #else
-	#define SCAN_PARAM_INPUT_FMT_BACKOP ""
-	#define SCAN_PARAM_INPUT_ARG_BACKOP
+#define SCAN_PARAM_INPUT_FMT_BACKOP ""
+#define SCAN_PARAM_INPUT_ARG_BACKOP
 #endif
 
 	if (count < 1)
@@ -963,21 +1219,21 @@ u16 scan_ch_ms;
 
 		if (num-- > 0)
 			ss->scan_ch_ms = scan_ch_ms;
-		#ifdef CONFIG_80211N_HT
+#ifdef CONFIG_80211N_HT
 		if (num-- > 0)
 			ss->rx_ampdu_accept = rx_ampdu_accept;
 		if (num-- > 0)
 			ss->rx_ampdu_size = rx_ampdu_size;
-		#endif
-		#ifdef CONFIG_SCAN_BACKOP
+#endif
+#ifdef CONFIG_SCAN_BACKOP
 		if (num-- > 0)
 			ss->backop_ms = backop_ms;
 		if (num-- > 0)
 			ss->scan_cnt_max = scan_cnt_max;
-		#endif
+#endif
 	}
-	
-	return count;	
+
+	return count;
 }
 
 int proc_get_scan_abort(struct seq_file *m, void *v)
@@ -988,70 +1244,31 @@ int proc_get_scan_abort(struct seq_file *m, void *v)
 
 	pass_ms = rtw_scan_abort_timeout(adapter, 10000);
 
-	DBG_871X_SEL_NL(m, "%u\n", pass_ms);
+	RTW_PRINT_SEL(m, "%u\n", pass_ms);
 
 	return 0;
 }
 
-#ifdef CONFIG_SCAN_BACKOP
-int proc_get_backop_flags_sta(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	DBG_871X_SEL_NL(m, "0x%02x\n", mlmeext_scan_backop_flags_sta(mlmeext));
-
-	return 0;
-}
-
-ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	char tmp[32];
-	u8 flags;
-
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhx", &flags);
-
-		if (num == 1)
-			mlmeext_assign_scan_backop_flags_sta(mlmeext, flags);
-	}
-	
-	return count;
-}
-
-int proc_get_backop_flags_ap(struct seq_file *m, void *v)
+#ifdef CONFIG_RTW_REPEATER_SON
+int proc_get_rson_data(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	DBG_871X_SEL_NL(m, "0x%02x\n", mlmeext_scan_backop_flags_ap(mlmeext));
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char rson_data_str[256];
 
+	rtw_rson_get_property_str(padapter, rson_data_str);
+	RTW_PRINT_SEL(m, "%s\n", rson_data_str);
 	return 0;
 }
 
-ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_rson_data(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	char tmp[32];
-	u8 flags;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+	char tmp[64] = {0};
+	int num;
+	u8 field[10], value[64];
 
 	if (count < 1)
 		return -EFAULT;
@@ -1062,17 +1279,21 @@ ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, s
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhx", &flags);
-
-		if (num == 1)
-			mlmeext_assign_scan_backop_flags_ap(mlmeext, flags);
+		num = sscanf(tmp, "%s %s", field, value);
+		if (num != 2) {
+			RTW_INFO("Invalid format : echo <field> <value> > son_data\n");
+			return count;
+		}
+		RTW_INFO("field=%s  value=%s\n", field, value);
+		num = rtw_rson_set_property(padapter, field, value);
+		if (num != 1) {
+			RTW_INFO("Invalid field(%s) or value(%s)\n", field, value);
+			return count;
+		}
 	}
-	
 	return count;
 }
-
-#endif /* CONFIG_SCAN_BACKOP */
+#endif /*CONFIG_RTW_REPEATER_SON*/
 
 int proc_get_survey_info(struct seq_file *m, void *v)
 {
@@ -1091,62 +1312,75 @@ int proc_get_survey_info(struct seq_file *m, void *v)
 	char flag_str[64];
 	int ielen = 0;
 	u32 wpsielen = 0;
+#ifdef CONFIG_RTW_MESH
+	const char *ssid_title_str = "ssid/mesh_id";
+#else
+	const char *ssid_title_str = "ssid";
+#endif
 
-	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);	
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 	phead = get_list_head(queue);
-	if(!phead)
-		return 0;
+	if (!phead)
+		goto _exit;
 	plist = get_next(phead);
 	if (!plist)
-		return 0;
+		goto _exit;
 
-	DBG_871X_SEL_NL(m, "%5s  %-17s  %3s  %-3s  %-4s  %-4s  %5s  %32s  %32s\n", "index", "bssid", "ch", "RSSI", "SdBm", "Noise", "age", "flag", "ssid");
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_show_survey_info(m, plist, phead);
+#else
+
+	RTW_PRINT_SEL(m, "%5s  %-17s  %3s  %-3s  %-4s  %-4s  %5s  %32s  %32s\n", "index", "bssid", "ch", "RSSI", "SdBm", "Noise", "age", "flag", ssid_title_str);
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-                if (!pnetwork)
+		if (!pnetwork)
 			break;
-	
-		if ( check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE &&
-			is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
-			notify_signal = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);//dbm
+
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
+		    is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
+			notify_signal = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);/* dbm */
 		} else {
-			notify_signal = translate_percentage_to_dbm(pnetwork->network.PhyInfo.SignalStrength);//dbm
+			notify_signal = translate_percentage_to_dbm(pnetwork->network.PhyInfo.SignalStrength);/* dbm */
 		}
 
-		#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-		rtw_hal_get_odm_var(padapter, HAL_ODM_NOISE_MONITOR,&(pnetwork->network.Configuration.DSConfig), &(notify_noise));
-		#endif
-	
-		ie_wpa = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &ielen, pnetwork->network.IELength-12);	
-		ie_wpa2 = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &ielen, pnetwork->network.IELength-12);
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+		if (IS_NM_ENABLE(padapter))
+			notify_noise = rtw_noise_query_by_chan_num(padapter, pnetwork->network.Configuration.DSConfig);
+#endif
+
+		ie_wpa = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &ielen, pnetwork->network.IELength - 12);
+		ie_wpa2 = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &ielen, pnetwork->network.IELength - 12);
 		ie_cap = rtw_get_capability(&pnetwork->network);
-		ie_wps = rtw_get_wps_ie(&pnetwork->network.IEs[12], pnetwork->network.IELength-12, NULL, &wpsielen);
-		ie_p2p = rtw_get_p2p_ie(&pnetwork->network.IEs[12], pnetwork->network.IELength-12, NULL, &ielen);
+		ie_wps = rtw_get_wps_ie(&pnetwork->network.IEs[12], pnetwork->network.IELength - 12, NULL, &wpsielen);
+		ie_p2p = rtw_get_p2p_ie(&pnetwork->network.IEs[12], pnetwork->network.IELength - 12, NULL, &ielen);
 		ssid = pnetwork->network.Ssid.Ssid;
 		sprintf(flag_str, "%s%s%s%s%s%s%s",
-					(ie_wpa) ? "[WPA]":"",
-					(ie_wpa2) ? "[WPA2]":"",
-					(!ie_wpa && !ie_wpa && ie_cap & BIT(4)) ? "[WEP]":"",
-					(ie_wps) ? "[WPS]":"",
-					(pnetwork->network.InfrastructureMode == Ndis802_11IBSS) ? "[IBSS]":"",
-					(ie_cap & BIT(0)) ? "[ESS]":"",
-					(ie_p2p) ? "[P2P]":"");
-		DBG_871X_SEL_NL(m, "%5d  "MAC_FMT"  %3d  %3d  %4d  %4d    %5d  %32s  %32s\n", 
+			(ie_wpa) ? "[WPA]" : "",
+			(ie_wpa2) ? "[WPA2]" : "",
+			(!ie_wpa && !ie_wpa && ie_cap & BIT(4)) ? "[WEP]" : "",
+			(ie_wps) ? "[WPS]" : "",
+			(pnetwork->network.InfrastructureMode == Ndis802_11IBSS) ? "[IBSS]" : 
+				(pnetwork->network.InfrastructureMode == Ndis802_11_mesh) ? "[MESH]" : "",
+			(ie_cap & BIT(0)) ? "[ESS]" : "",
+			(ie_p2p) ? "[P2P]" : "");
+		RTW_PRINT_SEL(m, "%5d  "MAC_FMT"  %3d  %3d  %4d  %4d    %5d  %32s  %32s\n",
 			++index,
-			MAC_ARG(pnetwork->network.MacAddress), 
+			MAC_ARG(pnetwork->network.MacAddress),
 			pnetwork->network.Configuration.DSConfig,
 			(int)pnetwork->network.Rssi,
 			notify_signal,
 			notify_noise,
-			rtw_get_passing_time_ms((u32)pnetwork->last_scanned),
+			rtw_get_passing_time_ms(pnetwork->last_scanned),
 			flag_str,
-			pnetwork->network.Ssid.Ssid);
+			pnetwork->network.InfrastructureMode == Ndis802_11_mesh ? pnetwork->network.mesh_id.Ssid : pnetwork->network.Ssid.Ssid
+		);
 		plist = get_next(plist);
 	}
+#endif
+_exit:
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	return 0;
@@ -1166,65 +1400,51 @@ ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_
 		return -EFAULT;
 
 #ifdef CONFIG_MP_INCLUDED
-		if ((padapter->registrypriv.mp_mode == 1)
-#ifdef CONFIG_CONCURRENT_MODE
-		|| ((padapter->pbuddy_adapter) && (padapter->pbuddy_adapter->registrypriv.mp_mode == 1))
-#endif			
-		){
-			DBG_871X(FUNC_ADPT_FMT ": MP mode block Scan request\n", FUNC_ADPT_ARG(padapter));	
-			goto exit;
-		}
-#endif
-	rtw_ps_deny(padapter, PS_DENY_SCAN);
-	if (_FAIL == rtw_pwr_wakeup(padapter))
-		goto exit;
-
-	if (rtw_is_drv_stopped(padapter)) {
-		DBG_871X("scan abort!! bDriverStopped=_TRUE\n");
-		goto exit;
-	}
-	
-	if (!padapter->bup) {
-		DBG_871X("scan abort!! bup=%d\n", padapter->bup);
-		goto exit;
-	}
-	
-	if (!rtw_is_hw_init_completed(padapter)) {
-		DBG_871X("scan abort!! hw_init_completed=FALSE\n");
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block Scan request\n");
 		goto exit;
 	}
-	
+#endif
 	if (rtw_is_scan_deny(padapter)) {
-		DBG_871X(FUNC_ADPT_FMT  ": scan deny\n", FUNC_ADPT_ARG(padapter));
+		RTW_INFO(FUNC_ADPT_FMT  ": scan deny\n", FUNC_ADPT_ARG(padapter));
 		goto exit;
 	}
-	
-	if ((pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE)
-#ifdef CONFIG_CONCURRENT_MODE
-	|| (rtw_get_buddy_bBusyTraffic(padapter) == _TRUE)
-#endif
-	) {
-		DBG_871X("scan abort!! BusyTraffic == _TRUE\n");
-		goto exit;
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	if (_FAIL == rtw_pwr_wakeup(padapter))
+		goto cancel_ps_deny;
+
+	if (!rtw_is_adapter_up(padapter)) {
+		RTW_INFO("scan abort!! adapter cannot use\n");
+		goto cancel_ps_deny;
 	}
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY|_FW_UNDER_LINKING) == _TRUE) {
-		DBG_8192C("scan abort!! fwstate=0x%x\n", pmlmepriv->fw_state);
-		goto exit;
+	if (rtw_mi_busy_traffic_check(padapter, _FALSE)) {
+		RTW_INFO("scan abort!! BusyTraffic == _TRUE\n");
+		goto cancel_ps_deny;
+	}
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) && check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+		RTW_INFO("scan abort!! AP mode process WPS\n");
+		goto cancel_ps_deny;
+	}
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("scan abort!! fwstate=0x%x\n", pmlmepriv->fw_state);
+		goto cancel_ps_deny;
 	}
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter,
-		_FW_UNDER_SURVEY|_FW_UNDER_LINKING|WIFI_UNDER_WPS) == _TRUE) {
-		DBG_871X("scan abort!! buddy_fwstate=0x%x\n",
-				get_fwstate(&(padapter->pbuddy_adapter->mlmepriv)));
-		goto exit;
+	if (rtw_mi_buddy_check_fwstate(padapter,
+		       _FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
+		RTW_INFO("scan abort!! buddy_fwstate check failed\n");
+		goto cancel_ps_deny;
 	}
 #endif
-	_status = rtw_set_802_11_bssid_list_scan(padapter, NULL, 0);
+	_status = rtw_set_802_11_bssid_list_scan(padapter, NULL);
 
-exit:
+cancel_ps_deny:
 	rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
+exit:
 	return count;
 }
 
@@ -1239,35 +1459,29 @@ int proc_get_ap_info(struct seq_file *m, void *v)
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
 	psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
-	if(psta)
-	{
-		int i;
-		struct recv_reorder_ctrl *preorder_ctrl;
-					
-		DBG_871X_SEL_NL(m, "SSID=%s\n", cur_network->network.Ssid.Ssid);		
-		DBG_871X_SEL_NL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->hwaddr));
-		DBG_871X_SEL_NL(m, "cur_channel=%d, cur_bwmode=%d, cur_ch_offset=%d\n", pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);		
-		DBG_871X_SEL_NL(m, "wireless_mode=0x%x, rtsen=%d, cts2slef=%d\n", psta->wireless_mode, psta->rtsen, psta->cts2self);
-		DBG_871X_SEL_NL(m, "state=0x%x, aid=%d, macid=%d, raid=%d\n", psta->state, psta->aid, psta->mac_id, psta->raid);
+	if (psta) {
+		RTW_PRINT_SEL(m, "SSID=%s\n", cur_network->network.Ssid.Ssid);
+		RTW_PRINT_SEL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+		RTW_PRINT_SEL(m, "cur_channel=%d, cur_bwmode=%d, cur_ch_offset=%d\n", pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
+		RTW_PRINT_SEL(m, "wireless_mode=0x%x, rtsen=%d, cts2slef=%d\n", psta->wireless_mode, psta->rtsen, psta->cts2self);
+		RTW_PRINT_SEL(m, "state=0x%x, aid=%d, macid=%d, raid=%d\n",
+			psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
 #ifdef CONFIG_80211N_HT
-		DBG_871X_SEL_NL(m, "qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);		
-		DBG_871X_SEL_NL(m, "bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n", psta->bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
-		DBG_871X_SEL_NL(m, "ampdu_enable = %d\n", psta->htpriv.ampdu_enable);	
-		DBG_871X_SEL_NL(m, "agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
-		DBG_871X_SEL_NL(m, "ldpc_cap=0x%x, stbc_cap=0x%x, beamform_cap=0x%x\n", psta->htpriv.ldpc_cap, psta->htpriv.stbc_cap, psta->htpriv.beamform_cap);
-#endif //CONFIG_80211N_HT
+		RTW_PRINT_SEL(m, "qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
+		RTW_PRINT_SEL(m, "bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n"
+			, psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
+		RTW_PRINT_SEL(m, "ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
+		RTW_PRINT_SEL(m, "agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
+		RTW_PRINT_SEL(m, "ldpc_cap=0x%x, stbc_cap=0x%x, beamform_cap=0x%x\n", psta->htpriv.ldpc_cap, psta->htpriv.stbc_cap, psta->htpriv.beamform_cap);
+#endif /* CONFIG_80211N_HT */
 #ifdef CONFIG_80211AC_VHT
-		DBG_871X_SEL_NL(m, "vht_en=%d, vht_sgi_80m=%d\n", psta->vhtpriv.vht_option, psta->vhtpriv.sgi_80m);
-		DBG_871X_SEL_NL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", psta->vhtpriv.ldpc_cap, psta->vhtpriv.stbc_cap, psta->vhtpriv.beamform_cap);
-		DBG_871X_SEL_NL(m, "vht_mcs_map=0x%x, vht_highest_rate=0x%x, vht_ampdu_len=%d\n", *(u16*)psta->vhtpriv.vht_mcs_map, psta->vhtpriv.vht_highest_rate, psta->vhtpriv.ampdu_len);
+		RTW_PRINT_SEL(m, "vht_en=%d, vht_sgi_80m=%d\n", psta->vhtpriv.vht_option, psta->vhtpriv.sgi_80m);
+		RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", psta->vhtpriv.ldpc_cap, psta->vhtpriv.stbc_cap, psta->vhtpriv.beamform_cap);
+		RTW_PRINT_SEL(m, "vht_mcs_map=0x%x, vht_highest_rate=0x%x, vht_ampdu_len=%d\n", *(u16 *)psta->vhtpriv.vht_mcs_map, psta->vhtpriv.vht_highest_rate, psta->vhtpriv.ampdu_len);
 #endif
-
 		sta_rx_reorder_ctl_dump(m, psta);
-	}
-	else
-	{							
-		DBG_871X_SEL_NL(m, "can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
-	}
+	} else
+		RTW_PRINT_SEL(m, "can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
 
 	return 0;
 }
@@ -1276,8 +1490,7 @@ ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	struct recv_priv  *precvpriv = &padapter->recvpriv;
 	char cmd[32] = {0};
 	u8 cnt = 0;
 
@@ -1290,18 +1503,19 @@ ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t
 		int num = sscanf(cmd, "%hhx", &cnt);
 
 		if (0 == cnt) {
-			pdbgpriv->dbg_rx_ampdu_drop_count = 0;
-			pdbgpriv->dbg_rx_ampdu_forced_indicate_count = 0;
-			pdbgpriv->dbg_rx_ampdu_loss_count = 0;
-			pdbgpriv->dbg_rx_dup_mgt_frame_drop_count = 0;
-			pdbgpriv->dbg_rx_ampdu_window_shift_cnt = 0;
-			pdbgpriv->dbg_rx_conflic_mac_addr_cnt = 0;
+			precvpriv->dbg_rx_ampdu_drop_count = 0;
+			precvpriv->dbg_rx_ampdu_forced_indicate_count = 0;
+			precvpriv->dbg_rx_ampdu_loss_count = 0;
+			precvpriv->dbg_rx_dup_mgt_frame_drop_count = 0;
+			precvpriv->dbg_rx_ampdu_window_shift_cnt = 0;
+			precvpriv->dbg_rx_conflic_mac_addr_cnt = 0;
+			precvpriv->dbg_rx_drop_count = 0;
 		}
 	}
 
 	return count;
 }
-	
+
 int proc_get_trx_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
@@ -1309,111 +1523,90 @@ int proc_get_trx_info(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	struct recv_priv  *precvpriv = &padapter->recvpriv;
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	struct hw_xmit *phwxmit;
+	u16 vo_params[4], vi_params[4], be_params[4], bk_params[4];
+
+	padapter->hal_func.read_wmmedca_reg(padapter, vo_params, vi_params, be_params, bk_params);
+
+	RTW_PRINT_SEL(m, "wmm_edca_vo, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", vo_params[0], vo_params[1], vo_params[2], vo_params[3]);
+	RTW_PRINT_SEL(m, "wmm_edca_vi, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", vi_params[0], vi_params[1], vi_params[2], vi_params[3]);
+	RTW_PRINT_SEL(m, "wmm_edca_be, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", be_params[0], be_params[1], be_params[2], be_params[3]);
+	RTW_PRINT_SEL(m, "wmm_edca_bk, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", bk_params[0], bk_params[1], bk_params[2], bk_params[3]);
 
 	dump_os_queue(m, padapter);
 
-	DBG_871X_SEL_NL(m, "free_xmitbuf_cnt=%d, free_xmitframe_cnt=%d\n"
+	RTW_PRINT_SEL(m, "free_xmitbuf_cnt=%d, free_xmitframe_cnt=%d\n"
 		, pxmitpriv->free_xmitbuf_cnt, pxmitpriv->free_xmitframe_cnt);
-	DBG_871X_SEL_NL(m, "free_ext_xmitbuf_cnt=%d, free_xframe_ext_cnt=%d\n"
+	RTW_PRINT_SEL(m, "free_ext_xmitbuf_cnt=%d, free_xframe_ext_cnt=%d\n"
 		, pxmitpriv->free_xmit_extbuf_cnt, pxmitpriv->free_xframe_ext_cnt);
-	DBG_871X_SEL_NL(m, "free_recvframe_cnt=%d\n"
-		, precvpriv->free_recvframe_cnt);
+	RTW_PRINT_SEL(m, "free_recvframe_cnt=%d\n"
+		      , precvpriv->free_recvframe_cnt);
 
-	for(i = 0; i < 4; i++) 
-	{
+	for (i = 0; i < 4; i++) {
 		phwxmit = pxmitpriv->hwxmits + i;
-		DBG_871X_SEL_NL(m, "%d, hwq.accnt=%d\n", i, phwxmit->accnt);
+		RTW_PRINT_SEL(m, "%d, hwq.accnt=%d\n", i, phwxmit->accnt);
 	}
 
+	rtw_hal_get_hwreg(padapter, HW_VAR_DUMP_MAC_TXFIFO, (u8 *)m);
+
 #ifdef CONFIG_USB_HCI
-	DBG_871X_SEL_NL(m, "rx_urb_pending_cn=%d\n", ATOMIC_READ(&(precvpriv->rx_pending_cnt)));
-#endif
-
-	//Folowing are RX info
-	//Counts of packets whose seq_num is less than preorder_ctrl->indicate_seq, Ex delay, retransmission, redundant packets and so on
-	DBG_871X_SEL_NL(m,"Rx: Counts of Packets Whose Seq_Num Less Than Reorder Control Seq_Num: %llu\n",(unsigned long long)pdbgpriv->dbg_rx_ampdu_drop_count);
-	//How many times the Rx Reorder Timer is triggered.
-	DBG_871X_SEL_NL(m,"Rx: Reorder Time-out Trigger Counts: %llu\n",(unsigned long long)pdbgpriv->dbg_rx_ampdu_forced_indicate_count);
-	//Total counts of packets loss
-	DBG_871X_SEL_NL(m,"Rx: Packet Loss Counts: %llu\n",(unsigned long long)pdbgpriv->dbg_rx_ampdu_loss_count);
-	DBG_871X_SEL_NL(m,"Rx: Duplicate Management Frame Drop Count: %llu\n",(unsigned long long)pdbgpriv->dbg_rx_dup_mgt_frame_drop_count);
-	DBG_871X_SEL_NL(m,"Rx: AMPDU BA window shift Count: %llu\n",(unsigned long long)pdbgpriv->dbg_rx_ampdu_window_shift_cnt);
-	/*The same mac addr counts*/
-	DBG_871X_SEL_NL(m, "Rx: Conflict MAC Address Frames Count: %llu\n", (unsigned long long)pdbgpriv->dbg_rx_conflic_mac_addr_cnt);
-	return 0;
-}
+	RTW_PRINT_SEL(m, "rx_urb_pending_cn=%d\n", ATOMIC_READ(&(precvpriv->rx_pending_cnt)));
+#endif
 
-int proc_get_dis_pwt(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 dis_pwt = 0;
-	rtw_hal_get_def_var(padapter, HAL_DEF_DBG_DIS_PWT, &(dis_pwt));
-	DBG_871X_SEL_NL(m, " Tx Power training mode:%s \n",(dis_pwt==_TRUE)?"Disable":"Enable");
+	dump_rx_bh_tk(m, &GET_PRIMARY_ADAPTER(padapter)->recvpriv);
+
+	/* Folowing are RX info */
+	RTW_PRINT_SEL(m, "RX: Count of Packets dropped by Driver: %llu\n", (unsigned long long)precvpriv->dbg_rx_drop_count);
+	/* Counts of packets whose seq_num is less than preorder_ctrl->indicate_seq, Ex delay, retransmission, redundant packets and so on */
+	RTW_PRINT_SEL(m, "Rx: Counts of Packets Whose Seq_Num Less Than Reorder Control Seq_Num: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_drop_count);
+	/* How many times the Rx Reorder Timer is triggered. */
+	RTW_PRINT_SEL(m, "Rx: Reorder Time-out Trigger Counts: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_forced_indicate_count);
+	/* Total counts of packets loss */
+	RTW_PRINT_SEL(m, "Rx: Packet Loss Counts: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_loss_count);
+	RTW_PRINT_SEL(m, "Rx: Duplicate Management Frame Drop Count: %llu\n", (unsigned long long)precvpriv->dbg_rx_dup_mgt_frame_drop_count);
+	RTW_PRINT_SEL(m, "Rx: AMPDU BA window shift Count: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_window_shift_cnt);
+	/*The same mac addr counts*/
+	RTW_PRINT_SEL(m, "Rx: Conflict MAC Address Frames Count: %llu\n", (unsigned long long)precvpriv->dbg_rx_conflic_mac_addr_cnt);
 	return 0;
 }
-ssize_t proc_set_dis_pwt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[4]={0};
-	u8 dis_pwt = 0;
-	
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhx", &dis_pwt);
-		DBG_871X("Set Tx Power training mode:%s\n", (dis_pwt == _TRUE)?"Disable":"Enable");
-		
-		if (num >= 1)
-			rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DIS_PWT, &(dis_pwt));
-	}
-
-	return count;
-	
-}
 
 int proc_get_rate_ctl(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	int i;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 data_rate = 0, sgi=0, data_fb = 0;
-		
+	u8 data_rate = 0, sgi = 0, data_fb = 0;
+
 	if (adapter->fix_rate != 0xff) {
 		data_rate = adapter->fix_rate & 0x7F;
-		sgi = adapter->fix_rate >>7;
-		data_fb = adapter->data_fb?1:0;
-		DBG_871X_SEL_NL(m, "FIXED %s%s%s\n"
+		sgi = adapter->fix_rate >> 7;
+		data_fb = adapter->data_fb ? 1 : 0;
+		RTW_PRINT_SEL(m, "FIXED %s%s%s\n"
 			, HDATA_RATE(data_rate)
-			, data_rate>DESC_RATE54M?(sgi?" SGI":" LGI"):""
-			, data_fb?" FB":""
+			, data_rate > DESC_RATE54M ? (sgi ? " SGI" : " LGI") : ""
+			, data_fb ? " FB" : ""
 		);
-		DBG_871X_SEL_NL(m, "0x%02x %u\n", adapter->fix_rate, adapter->data_fb);
-	} else {
-		DBG_871X_SEL_NL(m, "RA\n");
-	}
+		RTW_PRINT_SEL(m, "0x%02x %u\n", adapter->fix_rate, adapter->data_fb);
+	} else
+		RTW_PRINT_SEL(m, "RA\n");
 
 	return 0;
 }
 
+#ifdef 	CONFIG_PHDYM_FW_FIXRATE
+void phydm_fw_fix_rate(void *dm_void, u8 en, u8	macid, u8 bw, u8 rate);
+#endif
 ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	char tmp[32];
-	u8 fix_rate;
-	u8 data_fb;
+	u8 fix_rate = 0xFF;
+#ifdef 	CONFIG_PHDYM_FW_FIXRATE
+	u8 bw = 0;
+#else
+	u8 data_fb = 0;
+#endif
 
 	if (count < 1)
 		return -EFAULT;
@@ -1424,43 +1617,102 @@ ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t c
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+#ifdef 	CONFIG_PHDYM_FW_FIXRATE
+		struct dm_struct *dm = adapter_to_phydm(adapter);
+		u8 en = 1, macid = 255;
+		_irqL	irqL;
+		_list	*plist, *phead;
+		struct sta_info *psta = NULL;
+		struct sta_priv	*pstapriv = &(adapter->stapriv);
+		u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+		u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+		uint mac_id[NUM_STA];
+		int i, macid_rec_idx = 0;
+		int num = sscanf(tmp, "%hhx %hhu %hhu", &fix_rate, &bw, &macid);
+
+		if (num < 1) {
+			RTW_INFO("Invalid input!! \"ex: echo <rate> <bw> <macid> > /proc/.../rate_ctl\"\n");
+			return count;
+		}
+
+		if ((fix_rate == 0) || (fix_rate == 0xFF))
+			en = 0;
+			
+		if (macid != 255) {
+			RTW_INFO("Call phydm_fw_fix_rate()--en[%d] mac_id[%d] bw[%d] fix_rate[%d]\n", en, macid, bw, fix_rate);
+			phydm_fw_fix_rate(dm, en, macid, bw, fix_rate);
+			return count;
+		}
+
+		/*	no specific macid, apply to all macids except bc/mc macid */
+		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+		for (i = 0; i < NUM_STA; i++) {
+			phead = &(pstapriv->sta_hash[i]);
+			plist = get_next(phead);
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+				plist = get_next(plist);
+				if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) !=  _TRUE)
+					&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
+					&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), ETH_ALEN) != _TRUE)) {
+						mac_id[macid_rec_idx] = psta->cmn.mac_id;
+						macid_rec_idx++;
+				}
+			}
+		}
+		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
+		for (i = 0; i < macid_rec_idx; i++) {
+			RTW_INFO("Call phydm_fw_fix_rate()--en[%d] mac_id[%d] bw[%d] fix_rate[%d]\n", en, mac_id[i], bw, fix_rate);
+			phydm_fw_fix_rate(dm, en, mac_id[i], bw, fix_rate);
+		}
+#else
 		int num = sscanf(tmp, "%hhx %hhu", &fix_rate, &data_fb);
 
 		if (num >= 1) {
 			u8 fix_rate_ori = adapter->fix_rate;
 
 			adapter->fix_rate = fix_rate;
-			if (fix_rate_ori != fix_rate)
+			if (fix_rate == 0xFF)
+				hal_data->ForcedDataRate = 0;
+			else
+				hal_data->ForcedDataRate = hw_rate_to_m_rate(fix_rate & 0x7F);
+
+			if (adapter->fix_bw != 0xFF && fix_rate_ori != fix_rate)
 				rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
 		}
 		if (num >= 2)
-			adapter->data_fb = data_fb?1:0;
+			adapter->data_fb = data_fb ? 1 : 0;
+#endif
 	}
 
 	return count;
 }
-#ifdef DBG_RX_COUNTER_DUMP
-int proc_get_rx_cnt_dump(struct seq_file *m, void *v)
+
+#ifdef CONFIG_AP_MODE
+int proc_get_bmc_tx_rate(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	int i;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	struct sta_info *psta = NULL;
 
-	DBG_871X_SEL_NL(m, "BIT0- Dump RX counters of DRV \n");
-	DBG_871X_SEL_NL(m, "BIT1- Dump RX counters of MAC \n");
-	DBG_871X_SEL_NL(m, "BIT2- Dump RX counters of PHY \n");
-	DBG_871X_SEL_NL(m, "BIT3- Dump TRX data frame of DRV \n");
-	DBG_871X_SEL_NL(m, "dump_rx_cnt_mode = 0x%02x \n", adapter->dump_rx_cnt_mode);
+	if (!MLME_IS_AP(adapter) && !MLME_IS_MESH(adapter)) {
+		RTW_PRINT_SEL(m, "[ERROR] Not in SoftAP/Mesh mode !!\n");
+		return 0;
+	}
 
+	RTW_PRINT_SEL(m, " BMC Tx rate - %s\n", MGN_RATE_STR(adapter->bmc_tx_rate));
 	return 0;
 }
-ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+
+ssize_t proc_set_bmc_tx_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	char tmp[32];
-	u8 dump_rx_cnt_mode;
+	u8 bmc_tx_rate;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1472,43 +1724,34 @@ ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%hhx", &dump_rx_cnt_mode);
+		int num = sscanf(tmp, "%hhx", &bmc_tx_rate);
 
-		rtw_dump_phy_rxcnts_preprocess(adapter,dump_rx_cnt_mode);
-		adapter->dump_rx_cnt_mode = dump_rx_cnt_mode;
-		
+		if (num >= 1)
+			/*adapter->bmc_tx_rate = hw_rate_to_m_rate(bmc_tx_rate);*/
+			adapter->bmc_tx_rate = bmc_tx_rate;
 	}
 
 	return count;
 }
-#endif
-ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[32];
-	int num;
-
-	if (count < 1)
-		return -EFAULT;
+#endif /*CONFIG_AP_MODE*/
 
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
 
-	if (buffer && !copy_from_user(tmp, buffer, count))
-		num = sscanf(tmp, "%hhu %hhu", &fwdl_test_chksum_fail, &fwdl_test_wintint_rdy_fail);
+int proc_get_tx_power_offset(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	int i;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	return count;
+	RTW_PRINT_SEL(m, "Tx power offset - %u\n", adapter->power_offset);
+	return 0;
 }
 
-ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_tx_power_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	int num;
+	u8 power_offset = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1518,36 +1761,42 @@ ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *bu
 		return -EFAULT;
 	}
 
-	if (buffer && !copy_from_user(tmp, buffer, count))
-		num = sscanf(tmp, "%hhu", &del_rx_ampdu_test_no_tx_fail);
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu", &power_offset);
+
+		if (num >= 1) {
+			if (power_offset > 5)
+				power_offset = 0;
+
+			adapter->power_offset = power_offset;
+		}
+	}
 
 	return count;
 }
 
-#ifdef CONFIG_DFS_MASTER
-int proc_get_dfs_master_test_case(struct seq_file *m, void *v)
+int proc_get_bw_ctl(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u8 data_bw = 0;
 
-	DBG_871X_SEL_NL(m, "%-24s %-19s\n", "radar_detect_trigger_non", "choose_dfs_ch_first");
-	DBG_871X_SEL_NL(m, "%24hhu %19hhu\n"
-		, rfctl->dbg_dfs_master_radar_detect_trigger_non
-		, rfctl->dbg_dfs_master_choose_dfs_ch_first
-	);
+	if (adapter->fix_bw != 0xff) {
+		data_bw = adapter->fix_bw;
+		RTW_PRINT_SEL(m, "FIXED %s\n", ch_width_str(data_bw));
+	} else
+		RTW_PRINT_SEL(m, "Auto\n");
 
 	return 0;
 }
 
-ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_bw_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	char tmp[32];
-	u8 radar_detect_trigger_non;
-	u8 choose_dfs_ch_first;
+	u8 fix_bw;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1558,17 +1807,147 @@ ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buff
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		int num = sscanf(tmp, "%hhu %hhu", &radar_detect_trigger_non, &choose_dfs_ch_first);
+		int num = sscanf(tmp, "%hhu", &fix_bw);
 
-		if (num >= 1)
-			rfctl->dbg_dfs_master_radar_detect_trigger_non = radar_detect_trigger_non;
-		if (num >= 2)
-			rfctl->dbg_dfs_master_choose_dfs_ch_first = choose_dfs_ch_first;
+		if (num >= 1) {
+			u8 fix_bw_ori = adapter->fix_bw;
+
+			adapter->fix_bw = fix_bw;
+
+			if (adapter->fix_rate != 0xFF && fix_bw_ori != fix_bw)
+				rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
+		}
 	}
 
 	return count;
 }
-#endif /* CONFIG_DFS_MASTER */
+
+#ifdef DBG_RX_COUNTER_DUMP
+int proc_get_rx_cnt_dump(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	int i;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "BIT0- Dump RX counters of DRV\n");
+	RTW_PRINT_SEL(m, "BIT1- Dump RX counters of MAC\n");
+	RTW_PRINT_SEL(m, "BIT2- Dump RX counters of PHY\n");
+	RTW_PRINT_SEL(m, "BIT3- Dump TRX data frame of DRV\n");
+	RTW_PRINT_SEL(m, "dump_rx_cnt_mode = 0x%02x\n", adapter->dump_rx_cnt_mode);
+
+	return 0;
+}
+ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 dump_rx_cnt_mode;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &dump_rx_cnt_mode);
+
+		rtw_dump_phy_rxcnts_preprocess(adapter, dump_rx_cnt_mode);
+		adapter->dump_rx_cnt_mode = dump_rx_cnt_mode;
+
+	}
+
+	return count;
+}
+#endif
+
+static u8 fwdl_test_chksum_fail = 0;
+static u8 fwdl_test_wintint_rdy_fail = 0;
+
+bool rtw_fwdl_test_trigger_chksum_fail(void)
+{
+	if (fwdl_test_chksum_fail) {
+		RTW_PRINT("fwdl test case: trigger chksum_fail\n");
+		fwdl_test_chksum_fail--;
+		return _TRUE;
+	}
+	return _FALSE;
+}
+
+bool rtw_fwdl_test_trigger_wintint_rdy_fail(void)
+{
+	if (fwdl_test_wintint_rdy_fail) {
+		RTW_PRINT("fwdl test case: trigger wintint_rdy_fail\n");
+		fwdl_test_wintint_rdy_fail--;
+		return _TRUE;
+	}
+	return _FALSE;
+}
+
+ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count))
+		num = sscanf(tmp, "%hhu %hhu", &fwdl_test_chksum_fail, &fwdl_test_wintint_rdy_fail);
+
+	return count;
+}
+
+static u8 del_rx_ampdu_test_no_tx_fail = 0;
+
+bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void)
+{
+	if (del_rx_ampdu_test_no_tx_fail) {
+		RTW_PRINT("del_rx_ampdu test case: trigger no_tx_fail\n");
+		del_rx_ampdu_test_no_tx_fail--;
+		return _TRUE;
+	}
+	return _FALSE;
+}
+
+ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count))
+		num = sscanf(tmp, "%hhu", &del_rx_ampdu_test_no_tx_fail);
+
+	return count;
+}
+
+static u32 g_wait_hiq_empty_ms = 0;
+
+u32 rtw_get_wait_hiq_empty_ms(void)
+{
+	return g_wait_hiq_empty_ms;
+}
 
 ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
@@ -1591,44 +1970,121 @@ ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, si
 	return count;
 }
 
-int proc_get_suspend_resume_info(struct seq_file *m, void *v)
+static systime sta_linking_test_start_time = 0;
+static u32 sta_linking_test_wait_ms = 0;
+static u8 sta_linking_test_force_fail = 0;
+
+void rtw_sta_linking_test_set_start(void)
+{
+	sta_linking_test_start_time = rtw_get_current_time();
+}
+
+bool rtw_sta_linking_test_wait_done(void)
+{
+	return rtw_get_passing_time_ms(sta_linking_test_start_time) >= sta_linking_test_wait_ms;
+}
+
+bool rtw_sta_linking_test_force_fail(void)
+{
+	return sta_linking_test_force_fail;
+}
+
+ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		u32 wait_ms = 0;
+		u8 force_fail = 0;
+		int num = sscanf(tmp, "%u %hhu", &wait_ms, &force_fail);
+
+		if (num >= 1)
+			sta_linking_test_wait_ms = wait_ms;
+		if (num >= 2)
+			sta_linking_test_force_fail = force_fail;
+	}
+
+	return count;
+}
+
+int proc_get_ps_dbg_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct dvobj_priv *dvobj = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
 
-	DBG_871X_SEL_NL(m, "dbg_sdio_alloc_irq_cnt=%d\n", pdbgpriv->dbg_sdio_alloc_irq_cnt);
-	DBG_871X_SEL_NL(m, "dbg_sdio_free_irq_cnt=%d\n", pdbgpriv->dbg_sdio_free_irq_cnt);
-	DBG_871X_SEL_NL(m, "dbg_sdio_alloc_irq_error_cnt=%d\n",pdbgpriv->dbg_sdio_alloc_irq_error_cnt);
-	DBG_871X_SEL_NL(m, "dbg_sdio_free_irq_error_cnt=%d\n", pdbgpriv->dbg_sdio_free_irq_error_cnt);
-	DBG_871X_SEL_NL(m, "dbg_sdio_init_error_cnt=%d\n",pdbgpriv->dbg_sdio_init_error_cnt);
-	DBG_871X_SEL_NL(m, "dbg_sdio_deinit_error_cnt=%d\n", pdbgpriv->dbg_sdio_deinit_error_cnt);
-	DBG_871X_SEL_NL(m, "dbg_suspend_error_cnt=%d\n", pdbgpriv->dbg_suspend_error_cnt);
-	DBG_871X_SEL_NL(m, "dbg_suspend_cnt=%d\n",pdbgpriv->dbg_suspend_cnt);
-	DBG_871X_SEL_NL(m, "dbg_resume_cnt=%d\n", pdbgpriv->dbg_resume_cnt);
-	DBG_871X_SEL_NL(m, "dbg_resume_error_cnt=%d\n", pdbgpriv->dbg_resume_error_cnt);
-	DBG_871X_SEL_NL(m, "dbg_deinit_fail_cnt=%d\n",pdbgpriv->dbg_deinit_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_carddisable_cnt=%d\n", pdbgpriv->dbg_carddisable_cnt);
-	DBG_871X_SEL_NL(m, "dbg_ps_insuspend_cnt=%d\n",pdbgpriv->dbg_ps_insuspend_cnt);
-	DBG_871X_SEL_NL(m, "dbg_dev_unload_inIPS_cnt=%d\n", pdbgpriv->dbg_dev_unload_inIPS_cnt);
-	DBG_871X_SEL_NL(m, "dbg_scan_pwr_state_cnt=%d\n", pdbgpriv->dbg_scan_pwr_state_cnt);
-	DBG_871X_SEL_NL(m, "dbg_downloadfw_pwr_state_cnt=%d\n", pdbgpriv->dbg_downloadfw_pwr_state_cnt);
-	DBG_871X_SEL_NL(m, "dbg_carddisable_error_cnt=%d\n", pdbgpriv->dbg_carddisable_error_cnt);
-	DBG_871X_SEL_NL(m, "dbg_fw_read_ps_state_fail_cnt=%d\n", pdbgpriv->dbg_fw_read_ps_state_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_leave_ips_fail_cnt=%d\n", pdbgpriv->dbg_leave_ips_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_leave_lps_fail_cnt=%d\n", pdbgpriv->dbg_leave_lps_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_h2c_leave32k_fail_cnt=%d\n", pdbgpriv->dbg_h2c_leave32k_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_diswow_dload_fw_fail_cnt=%d\n", pdbgpriv->dbg_diswow_dload_fw_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_enwow_dload_fw_fail_cnt=%d\n", pdbgpriv->dbg_enwow_dload_fw_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_ips_drvopen_fail_cnt=%d\n", pdbgpriv->dbg_ips_drvopen_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_poll_fail_cnt=%d\n", pdbgpriv->dbg_poll_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_rpwm_toogle_cnt=%d\n", pdbgpriv->dbg_rpwm_toogle_cnt);
-	DBG_871X_SEL_NL(m, "dbg_rpwm_timeout_fail_cnt=%d\n", pdbgpriv->dbg_rpwm_timeout_fail_cnt);
-	DBG_871X_SEL_NL(m, "dbg_sreset_cnt=%d\n", pdbgpriv->dbg_sreset_cnt);
+	RTW_PRINT_SEL(m, "dbg_sdio_alloc_irq_cnt=%d\n", pdbgpriv->dbg_sdio_alloc_irq_cnt);
+	RTW_PRINT_SEL(m, "dbg_sdio_free_irq_cnt=%d\n", pdbgpriv->dbg_sdio_free_irq_cnt);
+	RTW_PRINT_SEL(m, "dbg_sdio_alloc_irq_error_cnt=%d\n", pdbgpriv->dbg_sdio_alloc_irq_error_cnt);
+	RTW_PRINT_SEL(m, "dbg_sdio_free_irq_error_cnt=%d\n", pdbgpriv->dbg_sdio_free_irq_error_cnt);
+	RTW_PRINT_SEL(m, "dbg_sdio_init_error_cnt=%d\n", pdbgpriv->dbg_sdio_init_error_cnt);
+	RTW_PRINT_SEL(m, "dbg_sdio_deinit_error_cnt=%d\n", pdbgpriv->dbg_sdio_deinit_error_cnt);
+	RTW_PRINT_SEL(m, "dbg_suspend_error_cnt=%d\n", pdbgpriv->dbg_suspend_error_cnt);
+	RTW_PRINT_SEL(m, "dbg_suspend_cnt=%d\n", pdbgpriv->dbg_suspend_cnt);
+	RTW_PRINT_SEL(m, "dbg_resume_cnt=%d\n", pdbgpriv->dbg_resume_cnt);
+	RTW_PRINT_SEL(m, "dbg_resume_error_cnt=%d\n", pdbgpriv->dbg_resume_error_cnt);
+	RTW_PRINT_SEL(m, "dbg_deinit_fail_cnt=%d\n", pdbgpriv->dbg_deinit_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_carddisable_cnt=%d\n", pdbgpriv->dbg_carddisable_cnt);
+	RTW_PRINT_SEL(m, "dbg_ps_insuspend_cnt=%d\n", pdbgpriv->dbg_ps_insuspend_cnt);
+	RTW_PRINT_SEL(m, "dbg_dev_unload_inIPS_cnt=%d\n", pdbgpriv->dbg_dev_unload_inIPS_cnt);
+	RTW_PRINT_SEL(m, "dbg_scan_pwr_state_cnt=%d\n", pdbgpriv->dbg_scan_pwr_state_cnt);
+	RTW_PRINT_SEL(m, "dbg_downloadfw_pwr_state_cnt=%d\n", pdbgpriv->dbg_downloadfw_pwr_state_cnt);
+	RTW_PRINT_SEL(m, "dbg_carddisable_error_cnt=%d\n", pdbgpriv->dbg_carddisable_error_cnt);
+	RTW_PRINT_SEL(m, "dbg_fw_read_ps_state_fail_cnt=%d\n", pdbgpriv->dbg_fw_read_ps_state_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_leave_ips_fail_cnt=%d\n", pdbgpriv->dbg_leave_ips_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_leave_lps_fail_cnt=%d\n", pdbgpriv->dbg_leave_lps_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_h2c_leave32k_fail_cnt=%d\n", pdbgpriv->dbg_h2c_leave32k_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_diswow_dload_fw_fail_cnt=%d\n", pdbgpriv->dbg_diswow_dload_fw_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_enwow_dload_fw_fail_cnt=%d\n", pdbgpriv->dbg_enwow_dload_fw_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_ips_drvopen_fail_cnt=%d\n", pdbgpriv->dbg_ips_drvopen_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_poll_fail_cnt=%d\n", pdbgpriv->dbg_poll_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_rpwm_toogle_cnt=%d\n", pdbgpriv->dbg_rpwm_toogle_cnt);
+	RTW_PRINT_SEL(m, "dbg_rpwm_timeout_fail_cnt=%d\n", pdbgpriv->dbg_rpwm_timeout_fail_cnt);
+	RTW_PRINT_SEL(m, "dbg_sreset_cnt=%d\n", pdbgpriv->dbg_sreset_cnt);
+	RTW_PRINT_SEL(m, "dbg_fw_mem_dl_error_cnt=%d\n", pdbgpriv->dbg_fw_mem_dl_error_cnt);
 
 	return 0;
 }
+ssize_t proc_set_ps_dbg_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter->dvobj;
+	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
+	char tmp[32];
+	u8 ps_dbg_cmd_id;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &ps_dbg_cmd_id);
+
+		if (ps_dbg_cmd_id == 1) /*Clean all*/
+			_rtw_memset(pdbgpriv, 0, sizeof(struct debug_priv));
+
+	}
+
+	return count;
+}
+
 
 #ifdef CONFIG_DBG_COUNTER
 
@@ -1638,94 +2094,94 @@ int proc_get_rx_logs(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct rx_logs *rx_logs = &padapter->rx_logs;
 
-	DBG_871X_SEL_NL(m, 
-		"intf_rx=%d\n"
-		"intf_rx_err_recvframe=%d\n"
-		"intf_rx_err_skb=%d\n"
-		"intf_rx_report=%d\n"
-		"core_rx=%d\n"
-		"core_rx_pre=%d\n"
-		"core_rx_pre_ver_err=%d\n"
-		"core_rx_pre_mgmt=%d\n"
-		"core_rx_pre_mgmt_err_80211w=%d\n"
-		"core_rx_pre_mgmt_err=%d\n"
-		"core_rx_pre_ctrl=%d\n"
-		"core_rx_pre_ctrl_err=%d\n"
-		"core_rx_pre_data=%d\n"
-		"core_rx_pre_data_wapi_seq_err=%d\n"
-		"core_rx_pre_data_wapi_key_err=%d\n"
-		"core_rx_pre_data_handled=%d\n"
-		"core_rx_pre_data_err=%d\n"
-		"core_rx_pre_data_unknown=%d\n"
-		"core_rx_pre_unknown=%d\n"
-		"core_rx_enqueue=%d\n"
-		"core_rx_dequeue=%d\n"
-		"core_rx_post=%d\n"
-		"core_rx_post_decrypt=%d\n"
-		"core_rx_post_decrypt_wep=%d\n"
-		"core_rx_post_decrypt_tkip=%d\n"
-		"core_rx_post_decrypt_aes=%d\n"
-		"core_rx_post_decrypt_wapi=%d\n"
-		"core_rx_post_decrypt_hw=%d\n"
-		"core_rx_post_decrypt_unknown=%d\n"
-		"core_rx_post_decrypt_err=%d\n"
-		"core_rx_post_defrag_err=%d\n"
-		"core_rx_post_portctrl_err=%d\n"
-		"core_rx_post_indicate=%d\n"
-		"core_rx_post_indicate_in_oder=%d\n"
-		"core_rx_post_indicate_reoder=%d\n"
-		"core_rx_post_indicate_err=%d\n"
-		"os_indicate=%d\n"
-		"os_indicate_ap_mcast=%d\n"
-		"os_indicate_ap_forward=%d\n"
-		"os_indicate_ap_self=%d\n"
-		"os_indicate_err=%d\n"
-		"os_netif_ok=%d\n"
-		"os_netif_err=%d\n",
-		rx_logs->intf_rx,
-		rx_logs->intf_rx_err_recvframe,
-		rx_logs->intf_rx_err_skb,
-		rx_logs->intf_rx_report,
-		rx_logs->core_rx,
-		rx_logs->core_rx_pre,
-		rx_logs->core_rx_pre_ver_err,
-		rx_logs->core_rx_pre_mgmt,
-		rx_logs->core_rx_pre_mgmt_err_80211w,
-		rx_logs->core_rx_pre_mgmt_err,
-		rx_logs->core_rx_pre_ctrl,
-		rx_logs->core_rx_pre_ctrl_err,
-		rx_logs->core_rx_pre_data,
-		rx_logs->core_rx_pre_data_wapi_seq_err,
-		rx_logs->core_rx_pre_data_wapi_key_err,
-		rx_logs->core_rx_pre_data_handled,
-		rx_logs->core_rx_pre_data_err,
-		rx_logs->core_rx_pre_data_unknown,
-		rx_logs->core_rx_pre_unknown,
-		rx_logs->core_rx_enqueue,
-		rx_logs->core_rx_dequeue,
-		rx_logs->core_rx_post,
-		rx_logs->core_rx_post_decrypt,
-		rx_logs->core_rx_post_decrypt_wep,
-		rx_logs->core_rx_post_decrypt_tkip,
-		rx_logs->core_rx_post_decrypt_aes,
-		rx_logs->core_rx_post_decrypt_wapi,
-		rx_logs->core_rx_post_decrypt_hw,
-		rx_logs->core_rx_post_decrypt_unknown,
-		rx_logs->core_rx_post_decrypt_err,
-		rx_logs->core_rx_post_defrag_err,
-		rx_logs->core_rx_post_portctrl_err,
-		rx_logs->core_rx_post_indicate,
-		rx_logs->core_rx_post_indicate_in_oder,
-		rx_logs->core_rx_post_indicate_reoder,
-		rx_logs->core_rx_post_indicate_err,
-		rx_logs->os_indicate,
-		rx_logs->os_indicate_ap_mcast,
-		rx_logs->os_indicate_ap_forward,
-		rx_logs->os_indicate_ap_self,
-		rx_logs->os_indicate_err,
-		rx_logs->os_netif_ok,
-		rx_logs->os_netif_err
-	);
+	RTW_PRINT_SEL(m,
+		      "intf_rx=%d\n"
+		      "intf_rx_err_recvframe=%d\n"
+		      "intf_rx_err_skb=%d\n"
+		      "intf_rx_report=%d\n"
+		      "core_rx=%d\n"
+		      "core_rx_pre=%d\n"
+		      "core_rx_pre_ver_err=%d\n"
+		      "core_rx_pre_mgmt=%d\n"
+		      "core_rx_pre_mgmt_err_80211w=%d\n"
+		      "core_rx_pre_mgmt_err=%d\n"
+		      "core_rx_pre_ctrl=%d\n"
+		      "core_rx_pre_ctrl_err=%d\n"
+		      "core_rx_pre_data=%d\n"
+		      "core_rx_pre_data_wapi_seq_err=%d\n"
+		      "core_rx_pre_data_wapi_key_err=%d\n"
+		      "core_rx_pre_data_handled=%d\n"
+		      "core_rx_pre_data_err=%d\n"
+		      "core_rx_pre_data_unknown=%d\n"
+		      "core_rx_pre_unknown=%d\n"
+		      "core_rx_enqueue=%d\n"
+		      "core_rx_dequeue=%d\n"
+		      "core_rx_post=%d\n"
+		      "core_rx_post_decrypt=%d\n"
+		      "core_rx_post_decrypt_wep=%d\n"
+		      "core_rx_post_decrypt_tkip=%d\n"
+		      "core_rx_post_decrypt_aes=%d\n"
+		      "core_rx_post_decrypt_wapi=%d\n"
+		      "core_rx_post_decrypt_hw=%d\n"
+		      "core_rx_post_decrypt_unknown=%d\n"
+		      "core_rx_post_decrypt_err=%d\n"
+		      "core_rx_post_defrag_err=%d\n"
+		      "core_rx_post_portctrl_err=%d\n"
+		      "core_rx_post_indicate=%d\n"
+		      "core_rx_post_indicate_in_oder=%d\n"
+		      "core_rx_post_indicate_reoder=%d\n"
+		      "core_rx_post_indicate_err=%d\n"
+		      "os_indicate=%d\n"
+		      "os_indicate_ap_mcast=%d\n"
+		      "os_indicate_ap_forward=%d\n"
+		      "os_indicate_ap_self=%d\n"
+		      "os_indicate_err=%d\n"
+		      "os_netif_ok=%d\n"
+		      "os_netif_err=%d\n",
+		      rx_logs->intf_rx,
+		      rx_logs->intf_rx_err_recvframe,
+		      rx_logs->intf_rx_err_skb,
+		      rx_logs->intf_rx_report,
+		      rx_logs->core_rx,
+		      rx_logs->core_rx_pre,
+		      rx_logs->core_rx_pre_ver_err,
+		      rx_logs->core_rx_pre_mgmt,
+		      rx_logs->core_rx_pre_mgmt_err_80211w,
+		      rx_logs->core_rx_pre_mgmt_err,
+		      rx_logs->core_rx_pre_ctrl,
+		      rx_logs->core_rx_pre_ctrl_err,
+		      rx_logs->core_rx_pre_data,
+		      rx_logs->core_rx_pre_data_wapi_seq_err,
+		      rx_logs->core_rx_pre_data_wapi_key_err,
+		      rx_logs->core_rx_pre_data_handled,
+		      rx_logs->core_rx_pre_data_err,
+		      rx_logs->core_rx_pre_data_unknown,
+		      rx_logs->core_rx_pre_unknown,
+		      rx_logs->core_rx_enqueue,
+		      rx_logs->core_rx_dequeue,
+		      rx_logs->core_rx_post,
+		      rx_logs->core_rx_post_decrypt,
+		      rx_logs->core_rx_post_decrypt_wep,
+		      rx_logs->core_rx_post_decrypt_tkip,
+		      rx_logs->core_rx_post_decrypt_aes,
+		      rx_logs->core_rx_post_decrypt_wapi,
+		      rx_logs->core_rx_post_decrypt_hw,
+		      rx_logs->core_rx_post_decrypt_unknown,
+		      rx_logs->core_rx_post_decrypt_err,
+		      rx_logs->core_rx_post_defrag_err,
+		      rx_logs->core_rx_post_portctrl_err,
+		      rx_logs->core_rx_post_indicate,
+		      rx_logs->core_rx_post_indicate_in_oder,
+		      rx_logs->core_rx_post_indicate_reoder,
+		      rx_logs->core_rx_post_indicate_err,
+		      rx_logs->os_indicate,
+		      rx_logs->os_indicate_ap_mcast,
+		      rx_logs->os_indicate_ap_forward,
+		      rx_logs->os_indicate_ap_self,
+		      rx_logs->os_indicate_err,
+		      rx_logs->os_netif_ok,
+		      rx_logs->os_netif_err
+		     );
 
 	return 0;
 }
@@ -1735,113 +2191,113 @@ int proc_get_tx_logs(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tx_logs *tx_logs = &padapter->tx_logs;
-	
-	DBG_871X_SEL_NL(m,
-		"os_tx=%d\n"
-		"os_tx_err_up=%d\n"
-		"os_tx_err_xmit=%d\n"
-		"os_tx_m2u=%d\n"
-		"os_tx_m2u_ignore_fw_linked=%d\n"
-		"os_tx_m2u_ignore_self=%d\n"
-		"os_tx_m2u_entry=%d\n"
-		"os_tx_m2u_entry_err_xmit=%d\n"
-		"os_tx_m2u_entry_err_skb=%d\n"
-		"os_tx_m2u_stop=%d\n"
-		"core_tx=%d\n"
-		"core_tx_err_pxmitframe=%d\n"
-		"core_tx_err_brtx=%d\n"
-		"core_tx_upd_attrib=%d\n"
-		"core_tx_upd_attrib_adhoc=%d\n"
-		"core_tx_upd_attrib_sta=%d\n"
-		"core_tx_upd_attrib_ap=%d\n"
-		"core_tx_upd_attrib_unknown=%d\n"
-		"core_tx_upd_attrib_dhcp=%d\n"
-		"core_tx_upd_attrib_icmp=%d\n"
-		"core_tx_upd_attrib_active=%d\n"
-		"core_tx_upd_attrib_err_ucast_sta=%d\n"
-		"core_tx_upd_attrib_err_ucast_ap_link=%d\n"
-		"core_tx_upd_attrib_err_sta=%d\n"
-		"core_tx_upd_attrib_err_link=%d\n"
-		"core_tx_upd_attrib_err_sec=%d\n"
-		"core_tx_ap_enqueue_warn_fwstate=%d\n"
-		"core_tx_ap_enqueue_warn_sta=%d\n"
-		"core_tx_ap_enqueue_warn_nosta=%d\n"
-		"core_tx_ap_enqueue_warn_link=%d\n"
-		"core_tx_ap_enqueue_warn_trigger=%d\n"
-		"core_tx_ap_enqueue_mcast=%d\n"
-		"core_tx_ap_enqueue_ucast=%d\n"
-		"core_tx_ap_enqueue=%d\n"
-		"intf_tx=%d\n"
-		"intf_tx_pending_ac=%d\n"
-		"intf_tx_pending_fw_under_survey=%d\n"
-		"intf_tx_pending_fw_under_linking=%d\n"
-		"intf_tx_pending_xmitbuf=%d\n"
-		"intf_tx_enqueue=%d\n"
-		"core_tx_enqueue=%d\n"
-		"core_tx_enqueue_class=%d\n"
-		"core_tx_enqueue_class_err_sta=%d\n"
-		"core_tx_enqueue_class_err_nosta=%d\n"
-		"core_tx_enqueue_class_err_fwlink=%d\n"
-		"intf_tx_direct=%d\n"
-		"intf_tx_direct_err_coalesce=%d\n"
-		"intf_tx_dequeue=%d\n"
-		"intf_tx_dequeue_err_coalesce=%d\n"
-		"intf_tx_dump_xframe=%d\n"
-		"intf_tx_dump_xframe_err_txdesc=%d\n"
-		"intf_tx_dump_xframe_err_port=%d\n",
-		tx_logs->os_tx,
-		tx_logs->os_tx_err_up,
-		tx_logs->os_tx_err_xmit,
-		tx_logs->os_tx_m2u,
-		tx_logs->os_tx_m2u_ignore_fw_linked,
-		tx_logs->os_tx_m2u_ignore_self,
-		tx_logs->os_tx_m2u_entry,
-		tx_logs->os_tx_m2u_entry_err_xmit,
-		tx_logs->os_tx_m2u_entry_err_skb,
-		tx_logs->os_tx_m2u_stop,
-		tx_logs->core_tx,
-		tx_logs->core_tx_err_pxmitframe,
-		tx_logs->core_tx_err_brtx,
-		tx_logs->core_tx_upd_attrib,
-		tx_logs->core_tx_upd_attrib_adhoc,
-		tx_logs->core_tx_upd_attrib_sta,
-		tx_logs->core_tx_upd_attrib_ap,
-		tx_logs->core_tx_upd_attrib_unknown,
-		tx_logs->core_tx_upd_attrib_dhcp,
-		tx_logs->core_tx_upd_attrib_icmp,
-		tx_logs->core_tx_upd_attrib_active,
-		tx_logs->core_tx_upd_attrib_err_ucast_sta,
-		tx_logs->core_tx_upd_attrib_err_ucast_ap_link,
-		tx_logs->core_tx_upd_attrib_err_sta,
-		tx_logs->core_tx_upd_attrib_err_link,
-		tx_logs->core_tx_upd_attrib_err_sec,
-		tx_logs->core_tx_ap_enqueue_warn_fwstate,
-		tx_logs->core_tx_ap_enqueue_warn_sta,
-		tx_logs->core_tx_ap_enqueue_warn_nosta,
-		tx_logs->core_tx_ap_enqueue_warn_link,
-		tx_logs->core_tx_ap_enqueue_warn_trigger,
-		tx_logs->core_tx_ap_enqueue_mcast,
-		tx_logs->core_tx_ap_enqueue_ucast,
-		tx_logs->core_tx_ap_enqueue,
-		tx_logs->intf_tx,
-		tx_logs->intf_tx_pending_ac,
-		tx_logs->intf_tx_pending_fw_under_survey,
-		tx_logs->intf_tx_pending_fw_under_linking,
-		tx_logs->intf_tx_pending_xmitbuf,
-		tx_logs->intf_tx_enqueue,
-		tx_logs->core_tx_enqueue,
-		tx_logs->core_tx_enqueue_class,
-		tx_logs->core_tx_enqueue_class_err_sta,
-		tx_logs->core_tx_enqueue_class_err_nosta,
-		tx_logs->core_tx_enqueue_class_err_fwlink,
-		tx_logs->intf_tx_direct,
-		tx_logs->intf_tx_direct_err_coalesce,
-		tx_logs->intf_tx_dequeue,
-		tx_logs->intf_tx_dequeue_err_coalesce,
-		tx_logs->intf_tx_dump_xframe,
-		tx_logs->intf_tx_dump_xframe_err_txdesc,
-		tx_logs->intf_tx_dump_xframe_err_port
-	);
+
+	RTW_PRINT_SEL(m,
+		      "os_tx=%d\n"
+		      "os_tx_err_up=%d\n"
+		      "os_tx_err_xmit=%d\n"
+		      "os_tx_m2u=%d\n"
+		      "os_tx_m2u_ignore_fw_linked=%d\n"
+		      "os_tx_m2u_ignore_self=%d\n"
+		      "os_tx_m2u_entry=%d\n"
+		      "os_tx_m2u_entry_err_xmit=%d\n"
+		      "os_tx_m2u_entry_err_skb=%d\n"
+		      "os_tx_m2u_stop=%d\n"
+		      "core_tx=%d\n"
+		      "core_tx_err_pxmitframe=%d\n"
+		      "core_tx_err_brtx=%d\n"
+		      "core_tx_upd_attrib=%d\n"
+		      "core_tx_upd_attrib_adhoc=%d\n"
+		      "core_tx_upd_attrib_sta=%d\n"
+		      "core_tx_upd_attrib_ap=%d\n"
+		      "core_tx_upd_attrib_unknown=%d\n"
+		      "core_tx_upd_attrib_dhcp=%d\n"
+		      "core_tx_upd_attrib_icmp=%d\n"
+		      "core_tx_upd_attrib_active=%d\n"
+		      "core_tx_upd_attrib_err_ucast_sta=%d\n"
+		      "core_tx_upd_attrib_err_ucast_ap_link=%d\n"
+		      "core_tx_upd_attrib_err_sta=%d\n"
+		      "core_tx_upd_attrib_err_link=%d\n"
+		      "core_tx_upd_attrib_err_sec=%d\n"
+		      "core_tx_ap_enqueue_warn_fwstate=%d\n"
+		      "core_tx_ap_enqueue_warn_sta=%d\n"
+		      "core_tx_ap_enqueue_warn_nosta=%d\n"
+		      "core_tx_ap_enqueue_warn_link=%d\n"
+		      "core_tx_ap_enqueue_warn_trigger=%d\n"
+		      "core_tx_ap_enqueue_mcast=%d\n"
+		      "core_tx_ap_enqueue_ucast=%d\n"
+		      "core_tx_ap_enqueue=%d\n"
+		      "intf_tx=%d\n"
+		      "intf_tx_pending_ac=%d\n"
+		      "intf_tx_pending_fw_under_survey=%d\n"
+		      "intf_tx_pending_fw_under_linking=%d\n"
+		      "intf_tx_pending_xmitbuf=%d\n"
+		      "intf_tx_enqueue=%d\n"
+		      "core_tx_enqueue=%d\n"
+		      "core_tx_enqueue_class=%d\n"
+		      "core_tx_enqueue_class_err_sta=%d\n"
+		      "core_tx_enqueue_class_err_nosta=%d\n"
+		      "core_tx_enqueue_class_err_fwlink=%d\n"
+		      "intf_tx_direct=%d\n"
+		      "intf_tx_direct_err_coalesce=%d\n"
+		      "intf_tx_dequeue=%d\n"
+		      "intf_tx_dequeue_err_coalesce=%d\n"
+		      "intf_tx_dump_xframe=%d\n"
+		      "intf_tx_dump_xframe_err_txdesc=%d\n"
+		      "intf_tx_dump_xframe_err_port=%d\n",
+		      tx_logs->os_tx,
+		      tx_logs->os_tx_err_up,
+		      tx_logs->os_tx_err_xmit,
+		      tx_logs->os_tx_m2u,
+		      tx_logs->os_tx_m2u_ignore_fw_linked,
+		      tx_logs->os_tx_m2u_ignore_self,
+		      tx_logs->os_tx_m2u_entry,
+		      tx_logs->os_tx_m2u_entry_err_xmit,
+		      tx_logs->os_tx_m2u_entry_err_skb,
+		      tx_logs->os_tx_m2u_stop,
+		      tx_logs->core_tx,
+		      tx_logs->core_tx_err_pxmitframe,
+		      tx_logs->core_tx_err_brtx,
+		      tx_logs->core_tx_upd_attrib,
+		      tx_logs->core_tx_upd_attrib_adhoc,
+		      tx_logs->core_tx_upd_attrib_sta,
+		      tx_logs->core_tx_upd_attrib_ap,
+		      tx_logs->core_tx_upd_attrib_unknown,
+		      tx_logs->core_tx_upd_attrib_dhcp,
+		      tx_logs->core_tx_upd_attrib_icmp,
+		      tx_logs->core_tx_upd_attrib_active,
+		      tx_logs->core_tx_upd_attrib_err_ucast_sta,
+		      tx_logs->core_tx_upd_attrib_err_ucast_ap_link,
+		      tx_logs->core_tx_upd_attrib_err_sta,
+		      tx_logs->core_tx_upd_attrib_err_link,
+		      tx_logs->core_tx_upd_attrib_err_sec,
+		      tx_logs->core_tx_ap_enqueue_warn_fwstate,
+		      tx_logs->core_tx_ap_enqueue_warn_sta,
+		      tx_logs->core_tx_ap_enqueue_warn_nosta,
+		      tx_logs->core_tx_ap_enqueue_warn_link,
+		      tx_logs->core_tx_ap_enqueue_warn_trigger,
+		      tx_logs->core_tx_ap_enqueue_mcast,
+		      tx_logs->core_tx_ap_enqueue_ucast,
+		      tx_logs->core_tx_ap_enqueue,
+		      tx_logs->intf_tx,
+		      tx_logs->intf_tx_pending_ac,
+		      tx_logs->intf_tx_pending_fw_under_survey,
+		      tx_logs->intf_tx_pending_fw_under_linking,
+		      tx_logs->intf_tx_pending_xmitbuf,
+		      tx_logs->intf_tx_enqueue,
+		      tx_logs->core_tx_enqueue,
+		      tx_logs->core_tx_enqueue_class,
+		      tx_logs->core_tx_enqueue_class_err_sta,
+		      tx_logs->core_tx_enqueue_class_err_nosta,
+		      tx_logs->core_tx_enqueue_class_err_fwlink,
+		      tx_logs->intf_tx_direct,
+		      tx_logs->intf_tx_direct_err_coalesce,
+		      tx_logs->intf_tx_dequeue,
+		      tx_logs->intf_tx_dequeue_err_coalesce,
+		      tx_logs->intf_tx_dump_xframe,
+		      tx_logs->intf_tx_dump_xframe_err_txdesc,
+		      tx_logs->intf_tx_dump_xframe_err_port
+		     );
 
 	return 0;
 }
@@ -1851,47 +2307,47 @@ int proc_get_int_logs(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X_SEL_NL(m,
-		"all=%d\n"
-		"err=%d\n"
-		"tbdok=%d\n"
-		"tbder=%d\n"
-		"bcnderr=%d\n"
-		"bcndma=%d\n"
-		"bcndma_e=%d\n"
-		"rx=%d\n"
-		"rx_rdu=%d\n"
-		"rx_fovw=%d\n"
-		"txfovw=%d\n"
-		"mgntok=%d\n"
-		"highdok=%d\n"
-		"bkdok=%d\n"
-		"bedok=%d\n"
-		"vidok=%d\n"
-		"vodok=%d\n",
-		padapter->int_logs.all,
-		padapter->int_logs.err,
-		padapter->int_logs.tbdok,
-		padapter->int_logs.tbder,
-		padapter->int_logs.bcnderr,
-		padapter->int_logs.bcndma,
-		padapter->int_logs.bcndma_e,
-		padapter->int_logs.rx,
-		padapter->int_logs.rx_rdu,
-		padapter->int_logs.rx_fovw,
-		padapter->int_logs.txfovw,
-		padapter->int_logs.mgntok,
-		padapter->int_logs.highdok,
-		padapter->int_logs.bkdok,
-		padapter->int_logs.bedok,
-		padapter->int_logs.vidok,
-		padapter->int_logs.vodok
-	);
+	RTW_PRINT_SEL(m,
+		      "all=%d\n"
+		      "err=%d\n"
+		      "tbdok=%d\n"
+		      "tbder=%d\n"
+		      "bcnderr=%d\n"
+		      "bcndma=%d\n"
+		      "bcndma_e=%d\n"
+		      "rx=%d\n"
+		      "rx_rdu=%d\n"
+		      "rx_fovw=%d\n"
+		      "txfovw=%d\n"
+		      "mgntok=%d\n"
+		      "highdok=%d\n"
+		      "bkdok=%d\n"
+		      "bedok=%d\n"
+		      "vidok=%d\n"
+		      "vodok=%d\n",
+		      padapter->int_logs.all,
+		      padapter->int_logs.err,
+		      padapter->int_logs.tbdok,
+		      padapter->int_logs.tbder,
+		      padapter->int_logs.bcnderr,
+		      padapter->int_logs.bcndma,
+		      padapter->int_logs.bcndma_e,
+		      padapter->int_logs.rx,
+		      padapter->int_logs.rx_rdu,
+		      padapter->int_logs.rx_fovw,
+		      padapter->int_logs.txfovw,
+		      padapter->int_logs.mgntok,
+		      padapter->int_logs.highdok,
+		      padapter->int_logs.bkdok,
+		      padapter->int_logs.bedok,
+		      padapter->int_logs.vidok,
+		      padapter->int_logs.vodok
+		     );
 
 	return 0;
 }
 
-#endif // CONFIG_DBG_COUNTER
+#endif /* CONFIG_DBG_COUNTER */
 
 int proc_get_hw_status(struct seq_file *m, void *v)
 {
@@ -1899,37 +2355,107 @@ int proc_get_hw_status(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct dvobj_priv *dvobj = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
-
-	if (pdbgpriv->dbg_rx_fifo_last_overflow == 1
-		&& pdbgpriv->dbg_rx_fifo_curr_overflow == 1
-		&& pdbgpriv->dbg_rx_fifo_diff_overflow == 1
-	) {
-		DBG_871X_SEL_NL(m, "RX FIFO full count: no implementation\n");
-	} else {
-		DBG_871X_SEL_NL(m, "RX FIFO full count: last_time=%llu, current_time=%llu, differential=%llu\n"
+	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
+
+	if (regsty->check_hw_status == 0)
+		RTW_PRINT_SEL(m, "RX FIFO full count: not check in watch dog\n");
+	else if (pdbgpriv->dbg_rx_fifo_last_overflow == 1
+	    && pdbgpriv->dbg_rx_fifo_curr_overflow == 1
+	    && pdbgpriv->dbg_rx_fifo_diff_overflow == 1
+	   )
+		RTW_PRINT_SEL(m, "RX FIFO full count: no implementation\n");
+	else {
+		RTW_PRINT_SEL(m, "RX FIFO full count: last_time=%llu, current_time=%llu, differential=%llu\n"
 			, pdbgpriv->dbg_rx_fifo_last_overflow, pdbgpriv->dbg_rx_fifo_curr_overflow, pdbgpriv->dbg_rx_fifo_diff_overflow);
 	}
 
 	return 0;
 }
 
+ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = padapter->dvobj;
+	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
+	char tmp[32];
+	u32 enable;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &enable);
+
+		if (regsty && enable <= 1) {
+			regsty->check_hw_status = enable;
+			RTW_INFO("check_hw_status=%d\n", regsty->check_hw_status);
+		}
+	}
+
+	return count;
+}
+
+int proc_get_trx_info_debug(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	int i;
+
+
+	/*============  tx info ============	*/
+	rtw_hal_get_def_var(padapter, HW_DEF_RA_INFO_DUMP, m);
+
+	/*============  rx info ============	*/
+	rtw_hal_set_odm_var(padapter, HAL_ODM_RX_INFO_DUMP, m, _FALSE);
+
+
+	return 0;
+}
+
 int proc_get_rx_signal(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
-	DBG_871X_SEL_NL(m, "rssi:%d\n", padapter->recvpriv.rssi);
-	//DBG_871X_SEL_NL(m, "rxpwdb:%d\n", padapter->recvpriv.rxpwdb);
-	DBG_871X_SEL_NL(m, "signal_strength:%u\n", padapter->recvpriv.signal_strength);
-	DBG_871X_SEL_NL(m, "signal_qual:%u\n", padapter->recvpriv.signal_qual);
-
-	rtw_get_noise(padapter);
-	DBG_871X_SEL_NL(m, "noise:%d\n", padapter->recvpriv.noise);
-	#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
-	rtw_odm_get_perpkt_rssi(m,padapter);
-	rtw_get_raw_rssi_info(m,padapter);
-	#endif
+	RTW_PRINT_SEL(m, "rssi:%d\n", padapter->recvpriv.rssi);
+	/* RTW_PRINT_SEL(m, "rxpwdb:%d\n", padapter->recvpriv.rxpwdb); */
+	RTW_PRINT_SEL(m, "signal_strength:%u\n", padapter->recvpriv.signal_strength);
+	RTW_PRINT_SEL(m, "signal_qual:%u\n", padapter->recvpriv.signal_qual);
+#ifdef CONFIG_MP_INCLUDED
+	if (padapter->registrypriv.mp_mode == 1) {
+		if (padapter->mppriv.antenna_rx == ANTENNA_A)
+			RTW_PRINT_SEL(m, "Antenna: A\n");
+		else if (padapter->mppriv.antenna_rx == ANTENNA_B)
+			RTW_PRINT_SEL(m, "Antenna: B\n");
+		else if (padapter->mppriv.antenna_rx == ANTENNA_C)
+			RTW_PRINT_SEL(m, "Antenna: C\n");
+		else if (padapter->mppriv.antenna_rx == ANTENNA_D)
+			RTW_PRINT_SEL(m, "Antenna: D\n");
+		else if (padapter->mppriv.antenna_rx == ANTENNA_AB)
+			RTW_PRINT_SEL(m, "Antenna: AB\n");
+		else if (padapter->mppriv.antenna_rx == ANTENNA_BC)
+			RTW_PRINT_SEL(m, "Antenna: BC\n");
+		else if (padapter->mppriv.antenna_rx == ANTENNA_CD)
+			RTW_PRINT_SEL(m, "Antenna: CD\n");
+		else
+			RTW_PRINT_SEL(m, "Antenna: __\n");
+		return 0;
+	}
+#endif
+#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
+	rtw_odm_get_perpkt_rssi(m, padapter);
+	rtw_get_raw_rssi_info(m, padapter);
+#endif
 	return 0;
 }
 
@@ -1952,25 +2478,25 @@ ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t
 
 		int num = sscanf(tmp, "%u %u", &is_signal_dbg, &signal_strength);
 
-		is_signal_dbg = is_signal_dbg==0?0:1;
-		
-		if(is_signal_dbg && num!=2)
+		is_signal_dbg = is_signal_dbg == 0 ? 0 : 1;
+
+		if (is_signal_dbg && num != 2)
 			return count;
-			
-		signal_strength = signal_strength>100?100:signal_strength;
+
+		signal_strength = signal_strength > 100 ? 100 : signal_strength;
 
 		padapter->recvpriv.is_signal_dbg = is_signal_dbg;
-		padapter->recvpriv.signal_strength_dbg=signal_strength;
+		padapter->recvpriv.signal_strength_dbg = signal_strength;
 
-		if(is_signal_dbg)
-			DBG_871X("set %s %u\n", "DBG_SIGNAL_STRENGTH", signal_strength);
+		if (is_signal_dbg)
+			RTW_INFO("set %s %u\n", "DBG_SIGNAL_STRENGTH", signal_strength);
 		else
-			DBG_871X("set %s\n", "HW_SIGNAL_STRENGTH");
-		
+			RTW_INFO("set %s\n", "HW_SIGNAL_STRENGTH");
+
 	}
-	
+
 	return count;
-	
+
 }
 #ifdef CONFIG_80211N_HT
 
@@ -1980,8 +2506,8 @@ int proc_get_ht_enable(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 
-	if(pregpriv)
-		DBG_871X_SEL_NL(m, "%d\n", pregpriv->ht_enable);
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "%d\n", pregpriv->ht_enable);
 
 	return 0;
 }
@@ -2006,15 +2532,14 @@ ssize_t proc_set_ht_enable(struct file *file, const char __user *buffer, size_t
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if( pregpriv && mode < 2 )
-		{
-			pregpriv->ht_enable= mode;
-			DBG_871X("ht_enable=%d\n", pregpriv->ht_enable);
+		if (pregpriv && mode < 2) {
+			pregpriv->ht_enable = mode;
+			RTW_INFO("ht_enable=%d\n", pregpriv->ht_enable);
 		}
 	}
-	
+
 	return count;
-	
+
 }
 
 int proc_get_bw_mode(struct seq_file *m, void *v)
@@ -2023,8 +2548,8 @@ int proc_get_bw_mode(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 
-	if(pregpriv)
-		DBG_871X_SEL_NL(m, "0x%02x\n", pregpriv->bw_mode);
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->bw_mode);
 
 	return 0;
 }
@@ -2036,6 +2561,8 @@ ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t co
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 	char tmp[32];
 	u32 mode;
+	u8 bw_2g;
+	u8 bw_5g;
 
 	if (count < 1)
 		return -EFAULT;
@@ -2047,19 +2574,20 @@ ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t co
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%d ", &mode);
+		int num = sscanf(tmp, "%x ", &mode);
+		bw_5g = mode >> 4;
+		bw_2g = mode & 0x0f;
 
-		if( pregpriv &&  mode < 2 )
-		{
+		if (pregpriv && bw_2g <= 4 && bw_5g <= 4) {
 
 			pregpriv->bw_mode = mode;
-			printk("bw_mode=%d\n", mode);
+			printk("bw_mode=0x%x\n", mode);
 
 		}
 	}
-	
+
 	return count;
-	
+
 }
 
 int proc_get_ampdu_enable(struct seq_file *m, void *v)
@@ -2068,8 +2596,8 @@ int proc_get_ampdu_enable(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 
-	if(pregpriv)
-		DBG_871X_SEL_NL(m, "%d\n", pregpriv->ampdu_enable);
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "%d\n", pregpriv->ampdu_enable);
 
 	return 0;
 }
@@ -2094,16 +2622,15 @@ ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if( pregpriv && mode < 3 )
-		{
-			pregpriv->ampdu_enable= mode;
+		if (pregpriv && mode < 2) {
+			pregpriv->ampdu_enable = mode;
 			printk("ampdu_enable=%d\n", mode);
 		}
 
 	}
-	
+
 	return count;
-	
+
 }
 
 int proc_get_mac_rptbuf(struct seq_file *m, void *v)
@@ -2115,47 +2642,63 @@ int proc_get_mac_rptbuf(struct seq_file *m, void *v)
 	u32 shcut_addr = 0;
 	u32 read_addr = 0;
 #ifdef CONFIG_RTL8814A
-	DBG_871X_SEL_NL(m, "TX ShortCut:\n");
+	RTW_PRINT_SEL(m, "TX ShortCut:\n");
 	for (mac_id = 0; mac_id < 64; mac_id++) {
-		rtw_write16(padapter, 0x140, 0x662 | ((mac_id & BIT5)>>5));
+		rtw_write16(padapter, 0x140, 0x662 | ((mac_id & BIT5) >> 5));
 		shcut_addr = 0x8000;
-		shcut_addr = shcut_addr | ((mac_id&0x1f) << 7);
-		DBG_871X_SEL_NL(m, "mac_id=%d, 0x140=%x =>\n", mac_id, 0x662 | ((mac_id & BIT5)>>5));
+		shcut_addr = shcut_addr | ((mac_id & 0x1f) << 7);
+		RTW_PRINT_SEL(m, "mac_id=%d, 0x140=%x =>\n", mac_id, 0x662 | ((mac_id & BIT5) >> 5));
 		for (i = 0; i < 30; i++) {
 			read_addr = 0;
-			read_addr = shcut_addr | (i<<2);
-			DBG_871X_SEL_NL(m, "i=%02d: MAC_%04x= %08x ", i, read_addr, rtw_read32(padapter, read_addr));
-			if (!((i+1) % 4))
-				DBG_871X_SEL_NL(m, "\n");
+			read_addr = shcut_addr | (i << 2);
+			RTW_PRINT_SEL(m, "i=%02d: MAC_%04x= %08x ", i, read_addr, rtw_read32(padapter, read_addr));
+			if (!((i + 1) % 4))
+				RTW_PRINT_SEL(m, "\n");
 			if (i == 29)
-				DBG_871X_SEL_NL(m, "\n");
+				RTW_PRINT_SEL(m, "\n");
 		}
 	}
 #endif /* CONFIG_RTL8814A */
 	return 0;
 }
 
+void dump_regsty_rx_ampdu_size_limit(void *sel, _adapter *adapter)
+{
+	struct registry_priv *regsty = adapter_to_regsty(adapter);
+	int i;
+
+	RTW_PRINT_SEL(sel, "%-3s %-3s %-3s %-3s %-4s\n"
+		, "", "20M", "40M", "80M", "160M");
+	for (i = 0; i < 4; i++)
+		RTW_PRINT_SEL(sel, "%dSS %3u %3u %3u %4u\n", i + 1
+			, regsty->rx_ampdu_sz_limit_by_nss_bw[i][0]
+			, regsty->rx_ampdu_sz_limit_by_nss_bw[i][1]
+			, regsty->rx_ampdu_sz_limit_by_nss_bw[i][2]
+			, regsty->rx_ampdu_sz_limit_by_nss_bw[i][3]);
+}
 
 int proc_get_rx_ampdu(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X_SEL(m, "accept: ");
+	_RTW_PRINT_SEL(m, "accept: ");
 	if (padapter->fix_rx_ampdu_accept == RX_AMPDU_ACCEPT_INVALID)
-		DBG_871X_SEL_NL(m, "%u%s\n", rtw_rx_ampdu_is_accept(padapter), "(auto)");
+		RTW_PRINT_SEL(m, "%u%s\n", rtw_rx_ampdu_is_accept(padapter), "(auto)");
 	else
-		DBG_871X_SEL_NL(m, "%u%s\n", padapter->fix_rx_ampdu_accept, "(fixed)");
+		RTW_PRINT_SEL(m, "%u%s\n", padapter->fix_rx_ampdu_accept, "(fixed)");
 
-	DBG_871X_SEL(m, "size: ");
-	if (padapter->fix_rx_ampdu_size == RX_AMPDU_SIZE_INVALID)
-		DBG_871X_SEL_NL(m, "%u%s\n", rtw_rx_ampdu_size(padapter), "(auto)");
-	else
-		DBG_871X_SEL_NL(m, "%u%s\n", padapter->fix_rx_ampdu_size, "(fixed)");
+	_RTW_PRINT_SEL(m, "size: ");
+	if (padapter->fix_rx_ampdu_size == RX_AMPDU_SIZE_INVALID) {
+		RTW_PRINT_SEL(m, "%u%s\n", rtw_rx_ampdu_size(padapter), "(auto) with conditional limit:");
+		dump_regsty_rx_ampdu_size_limit(m, padapter);
+	} else
+		RTW_PRINT_SEL(m, "%u%s\n", padapter->fix_rx_ampdu_size, "(fixed)");
+	RTW_PRINT_SEL(m, "\n");
 
-	DBG_871X_SEL_NL(m, "%19s %17s\n", "fix_rx_ampdu_accept", "fix_rx_ampdu_size");
+	RTW_PRINT_SEL(m, "%19s %17s\n", "fix_rx_ampdu_accept", "fix_rx_ampdu_size");
 
-	DBG_871X_SEL(m, "%-19d %-17u\n"
+	_RTW_PRINT_SEL(m, "%-19d %-17u\n"
 		, padapter->fix_rx_ampdu_accept
 		, padapter->fix_rx_ampdu_size);
 
@@ -2202,16 +2745,14 @@ int proc_get_rx_ampdu_factor(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
 
-	if(padapter)
-	{
-		DBG_871X_SEL_NL(m,"rx ampdu factor = %x\n",padapter->driver_rx_ampdu_factor);
-	}
-	
+	if (padapter)
+		RTW_PRINT_SEL(m, "rx ampdu factor = %x\n", padapter->driver_rx_ampdu_factor);
+
 	return 0;
 }
 
 ssize_t proc_set_rx_ampdu_factor(struct file *file, const char __user *buffer
-                                 , size_t count, loff_t *pos, void *data)
+				 , size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
@@ -2230,31 +2771,70 @@ ssize_t proc_set_rx_ampdu_factor(struct file *file, const char __user *buffer
 
 		int num = sscanf(tmp, "%d ", &factor);
 
-		if( padapter && (num == 1) )
-		{
-			DBG_871X("padapter->driver_rx_ampdu_factor = %x\n", factor);
+		if (padapter && (num == 1)) {
+			RTW_INFO("padapter->driver_rx_ampdu_factor = %x\n", factor);
 
-			if(factor  > 0x03)
+			if (factor  > 0x03)
 				padapter->driver_rx_ampdu_factor = 0xFF;
 			else
-				padapter->driver_rx_ampdu_factor = factor;			
+				padapter->driver_rx_ampdu_factor = factor;
 		}
 	}
 
 	return count;
 }
 
-int proc_get_rx_ampdu_density(struct seq_file *m, void *v)
+int proc_get_tx_max_agg_num(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
 
-	if(padapter)
-	{
-		DBG_871X_SEL_NL(m,"rx ampdu densityg = %x\n",padapter->driver_rx_ampdu_spacing);
+	if (padapter)
+		RTW_PRINT_SEL(m, "tx max AMPDU num = 0x%02x\n", padapter->driver_tx_max_agg_num);
+
+	return 0;
+}
+
+ssize_t proc_set_tx_max_agg_num(struct file *file, const char __user *buffer
+				 , size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 agg_num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx ", &agg_num);
+
+		if (padapter && (num == 1)) {
+			RTW_INFO("padapter->driver_tx_max_agg_num = 0x%02x\n", agg_num);
+
+			padapter->driver_tx_max_agg_num = agg_num;
+		}
 	}
 
+	return count;
+}
+
+int proc_get_rx_ampdu_density(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+
+	if (padapter)
+		RTW_PRINT_SEL(m, "rx ampdu densityg = %x\n", padapter->driver_rx_ampdu_spacing);
+
 	return 0;
 }
 
@@ -2277,11 +2857,10 @@ ssize_t proc_set_rx_ampdu_density(struct file *file, const char __user *buffer,
 
 		int num = sscanf(tmp, "%d ", &density);
 
-		if( padapter && (num == 1) )
-		{
-			DBG_871X("padapter->driver_rx_ampdu_spacing = %x\n", density);
+		if (padapter && (num == 1)) {
+			RTW_INFO("padapter->driver_rx_ampdu_spacing = %x\n", density);
 
-			if(density > 0x07)
+			if (density > 0x07)
 				padapter->driver_rx_ampdu_spacing = 0xFF;
 			else
 				padapter->driver_rx_ampdu_spacing = density;
@@ -2297,10 +2876,8 @@ int proc_get_tx_ampdu_density(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
 
-	if(padapter)
-	{
-		DBG_871X_SEL_NL(m,"tx ampdu density = %x\n",padapter->driver_ampdu_spacing);
-	}
+	if (padapter)
+		RTW_PRINT_SEL(m, "tx ampdu density = %x\n", padapter->driver_ampdu_spacing);
 
 	return 0;
 }
@@ -2324,11 +2901,10 @@ ssize_t proc_set_tx_ampdu_density(struct file *file, const char __user *buffer,
 
 		int num = sscanf(tmp, "%d ", &density);
 
-		if( padapter && (num == 1) )
-		{
-			DBG_871X("padapter->driver_ampdu_spacing = %x\n", density);
+		if (padapter && (num == 1)) {
+			RTW_INFO("padapter->driver_ampdu_spacing = %x\n", density);
 
-			if(density > 0x07)
+			if (density > 0x07)
 				padapter->driver_ampdu_spacing = 0xFF;
 			else
 				padapter->driver_ampdu_spacing = density;
@@ -2337,7 +2913,106 @@ ssize_t proc_set_tx_ampdu_density(struct file *file, const char __user *buffer,
 
 	return count;
 }
-#endif //CONFIG_80211N_HT
+
+#ifdef CONFIG_TX_AMSDU
+int proc_get_tx_amsdu(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+
+	if (padapter)
+	{
+		RTW_PRINT_SEL(m, "tx amsdu = %d\n", padapter->tx_amsdu);
+		RTW_PRINT_SEL(m, "amsdu set timer conut = %u\n", pxmitpriv->amsdu_debug_set_timer);
+		RTW_PRINT_SEL(m, "amsdu  time out count = %u\n", pxmitpriv->amsdu_debug_timeout);
+		RTW_PRINT_SEL(m, "amsdu coalesce one count = %u\n", pxmitpriv->amsdu_debug_coalesce_one);
+		RTW_PRINT_SEL(m, "amsdu coalesce two count = %u\n", pxmitpriv->amsdu_debug_coalesce_two);
+	}
+
+	return 0;
+}
+
+ssize_t proc_set_tx_amsdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	char tmp[32];
+	u32 amsdu;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &amsdu);
+
+		if (padapter && (num == 1)) {
+			RTW_INFO("padapter->tx_amsdu = %x\n", amsdu);
+
+			if (amsdu > 3)
+				padapter->tx_amsdu = 0;
+			else if(amsdu == 3)
+			{
+				pxmitpriv->amsdu_debug_set_timer = 0;
+				pxmitpriv->amsdu_debug_timeout = 0;
+				pxmitpriv->amsdu_debug_coalesce_one = 0;
+				pxmitpriv->amsdu_debug_coalesce_two = 0;
+			}
+			else
+				padapter->tx_amsdu = amsdu;
+		}
+	}
+
+	return count;
+}
+
+int proc_get_tx_amsdu_rate(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (padapter)
+		RTW_PRINT_SEL(m, "tx amsdu rate = %d Mbps\n", padapter->tx_amsdu_rate);
+
+	return 0;
+}
+
+ssize_t proc_set_tx_amsdu_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u32 amsdu_rate;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &amsdu_rate);
+
+		if (padapter && (num == 1)) {
+			RTW_INFO("padapter->tx_amsdu_rate = %x\n", amsdu_rate);
+			padapter->tx_amsdu_rate = amsdu_rate;
+		}
+	}
+
+	return count;
+}
+#endif /* CONFIG_TX_AMSDU */
+#endif /* CONFIG_80211N_HT */
 
 int proc_get_en_fwps(struct seq_file *m, void *v)
 {
@@ -2347,9 +3022,9 @@ int proc_get_en_fwps(struct seq_file *m, void *v)
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	if(pregpriv)
-		DBG_871X_SEL_NL(m, "check_fw_ps = %d , 1:enable get FW PS state , 0: disable get FW PS state\n"
-			, pregpriv->check_fw_ps);
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "check_fw_ps = %d , 1:enable get FW PS state , 0: disable get FW PS state\n"
+			      , pregpriv->check_fw_ps);
 
 	return 0;
 }
@@ -2376,10 +3051,9 @@ ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t co
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if( pregpriv &&  mode < 2 )
-		{
+		if (pregpriv &&  mode < 2) {
 			pregpriv->check_fw_ps = mode;
-			DBG_871X("pregpriv->check_fw_ps=%d \n",pregpriv->check_fw_ps);
+			RTW_INFO("pregpriv->check_fw_ps=%d\n", pregpriv->check_fw_ps);
 		}
 
 	}
@@ -2394,21 +3068,159 @@ int proc_get_two_path_rssi(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
 	if(padapter)
-		DBG_871X_SEL_NL(m, "%d %d\n",
+		RTW_PRINT_SEL(m, "%d %d\n",
 			padapter->recvpriv.RxRssi[0], padapter->recvpriv.RxRssi[1]);
 
 	return 0;
 }
 */
 #ifdef CONFIG_80211N_HT
+void rtw_dump_dft_phy_cap(void *sel, _adapter *adapter)
+{
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct ht_priv	*phtpriv = &pmlmepriv->htpriv;
+	#ifdef CONFIG_80211AC_VHT
+	struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
+	#endif
+
+	#ifdef CONFIG_80211AC_VHT
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT STBC Tx : %s\n", (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT STBC Rx : %s\n", (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_RX)) ? "V" : "X");
+	#endif
+	RTW_PRINT_SEL(sel, "[DFT CAP] HT STBC Tx : %s\n", (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] HT STBC Rx : %s\n\n", (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX)) ? "V" : "X");
+
+	#ifdef CONFIG_80211AC_VHT
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT LDPC Tx : %s\n", (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT LDPC Rx : %s\n", (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_RX)) ? "V" : "X");
+	#endif
+	RTW_PRINT_SEL(sel, "[DFT CAP] HT LDPC Tx : %s\n", (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] HT LDPC Rx : %s\n\n", (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX)) ? "V" : "X");
+
+	#ifdef CONFIG_BEAMFORMING
+	#ifdef CONFIG_80211AC_VHT
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT MU Bfer : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT MU Bfee : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT SU Bfer : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] VHT SU Bfee : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) ? "V" : "X");
+	#endif
+	RTW_PRINT_SEL(sel, "[DFT CAP] HT Bfer : %s\n", (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE))  ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DFT CAP] HT Bfee : %s\n", (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) ? "V" : "X");
+	#endif
+}
+
+void rtw_get_dft_phy_cap(void *sel, _adapter *adapter)
+{
+	RTW_PRINT_SEL(sel, "\n ======== PHY CAP protocol ========\n");
+	rtw_ht_use_default_setting(adapter);
+	#ifdef CONFIG_80211AC_VHT
+	rtw_vht_use_default_setting(adapter);
+	#endif
+	rtw_dump_dft_phy_cap(sel, adapter);
+}
+
+void rtw_dump_drv_phy_cap(void *sel, _adapter *adapter)
+{
+	struct registry_priv	*pregistry_priv = &adapter->registrypriv;
+
+	RTW_PRINT_SEL(sel, "\n ======== DRV's configuration ========\n");
+	#if 0
+	RTW_PRINT_SEL(sel, "[DRV CAP] TRx Capability : 0x%08x\n", phy_spec->trx_cap);
+	RTW_PRINT_SEL(sel, "[DRV CAP] Tx Stream Num Index : %d\n", (phy_spec->trx_cap >> 24) & 0xFF); /*Tx Stream Num Index [31:24]*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] Rx Stream Num Index : %d\n", (phy_spec->trx_cap >> 16) & 0xFF); /*Rx Stream Num Index [23:16]*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] Tx Path Num Index : %d\n", (phy_spec->trx_cap >> 8) & 0xFF);/*Tx Path Num Index	[15:8]*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] Rx Path Num Index : %d\n", (phy_spec->trx_cap & 0xFF));/*Rx Path Num Index	[7:0]*/
+	#endif
+
+	RTW_PRINT_SEL(sel, "[DRV CAP] STBC Capability : 0x%02x\n", pregistry_priv->stbc_cap);
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT STBC Tx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT1)) ? "V" : "X"); /*BIT1: Enable VHT STBC Tx*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT STBC Rx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT0)) ? "V" : "X"); /*BIT0: Enable VHT STBC Rx*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT STBC Tx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT5)) ? "V" : "X"); /*BIT5: Enable HT STBC Tx*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT STBC Rx : %s\n\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT4)) ? "V" : "X"); /*BIT4: Enable HT STBC Rx*/
+
+	RTW_PRINT_SEL(sel, "[DRV CAP] LDPC Capability : 0x%02x\n", pregistry_priv->ldpc_cap);
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT LDPC Tx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT1)) ? "V" : "X"); /*BIT1: Enable VHT LDPC Tx*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT LDPC Rx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT0)) ? "V" : "X"); /*BIT0: Enable VHT LDPC Rx*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT LDPC Tx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT5)) ? "V" : "X"); /*BIT5: Enable HT LDPC Tx*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT LDPC Rx : %s\n\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT4)) ? "V" : "X"); /*BIT4: Enable HT LDPC Rx*/
+	#ifdef CONFIG_BEAMFORMING
+	#if 0
+	RTW_PRINT_SEL(sel, "[DRV CAP] TxBF parameter : 0x%08x\n", phy_spec->txbf_param);
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT Sounding Dim : %d\n", (phy_spec->txbf_param >> 24) & 0xFF); /*VHT Sounding Dim [31:24]*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT Steering Ant : %d\n", (phy_spec->txbf_param >> 16) & 0xFF); /*VHT Steering Ant [23:16]*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT Sounding Dim : %d\n", (phy_spec->txbf_param >> 8) & 0xFF); /*HT Sounding Dim [15:8]*/
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT Steering Ant : %d\n", phy_spec->txbf_param & 0xFF); /*HT Steering Ant [7:0]*/
+	#endif
+
+	/*
+	 * BIT0: Enable VHT SU Beamformer
+	 * BIT1: Enable VHT SU Beamformee
+	 * BIT2: Enable VHT MU Beamformer, depend on VHT SU Beamformer
+	 * BIT3: Enable VHT MU Beamformee, depend on VHT SU Beamformee
+	 * BIT4: Enable HT Beamformer
+	 * BIT5: Enable HT Beamformee
+	 */
+	RTW_PRINT_SEL(sel, "[DRV CAP] TxBF Capability : 0x%02x\n", pregistry_priv->beamform_cap);
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT MU Bfer : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT2)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT MU Bfee : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT3)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT SU Bfer : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT0)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DRV CAP] VHT SU Bfee : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT1)) ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT Bfer : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT4))  ? "V" : "X");
+	RTW_PRINT_SEL(sel, "[DRV CAP] HT Bfee : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT5)) ? "V" : "X");
+
+	RTW_PRINT_SEL(sel, "[DRV CAP] Tx Bfer rf_num : %d\n", pregistry_priv->beamformer_rf_num);
+	RTW_PRINT_SEL(sel, "[DRV CAP] Tx Bfee rf_num : %d\n", pregistry_priv->beamformee_rf_num);
+	#endif
+}
+
+int proc_get_stbc_cap(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->stbc_cap);
+
+	return 0;
+}
+
+ssize_t proc_set_stbc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	char tmp[32];
+	u32 mode;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &mode);
+
+		if (pregpriv) {
+			pregpriv->stbc_cap = mode;
+			RTW_INFO("stbc_cap = 0x%02x\n", mode);
+		}
+	}
+
+	return count;
+}
 int proc_get_rx_stbc(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 
-	if(pregpriv)
-		DBG_871X_SEL_NL(m, "%d\n", pregpriv->rx_stbc);
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "%d\n", pregpriv->rx_stbc);
 
 	return 0;
 }
@@ -2433,17 +3245,98 @@ ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t co
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if( pregpriv && (mode == 0 || mode == 1|| mode == 2|| mode == 3))
-		{
-			pregpriv->rx_stbc= mode;
+		if (pregpriv && (mode == 0 || mode == 1 || mode == 2 || mode == 3)) {
+			pregpriv->rx_stbc = mode;
 			printk("rx_stbc=%d\n", mode);
 		}
 	}
-	
+
+	return count;
+
+}
+int proc_get_ldpc_cap(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->ldpc_cap);
+
+	return 0;
+}
+
+ssize_t proc_set_ldpc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	char tmp[32];
+	u32 mode;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &mode);
+
+		if (pregpriv) {
+			pregpriv->ldpc_cap = mode;
+			RTW_INFO("ldpc_cap = 0x%02x\n", mode);
+		}
+	}
+
+	return count;
+}
+#ifdef CONFIG_BEAMFORMING
+int proc_get_txbf_cap(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->beamform_cap);
+
+	return 0;
+}
+
+ssize_t proc_set_txbf_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	char tmp[32];
+	u32 mode;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &mode);
+
+		if (pregpriv) {
+			pregpriv->beamform_cap = mode;
+			RTW_INFO("beamform_cap = 0x%02x\n", mode);
+		}
+	}
+
 	return count;
-	
 }
-#endif //CONFIG_80211N_HT
+#endif
+#endif /* CONFIG_80211N_HT */
 
 /*int proc_get_rssi_disp(struct seq_file *m, void *v)
 {
@@ -2461,9 +3354,9 @@ ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t co
 
 	if (count < 1)
 	{
-		DBG_8192C("argument size is less than 1\n");
+		RTW_INFO("argument size is less than 1\n");
 		return -EFAULT;
-	}	
+	}
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
@@ -2475,28 +3368,28 @@ ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t co
 		int num = sscanf(tmp, "%x", &enable);
 
 		if (num !=  1) {
-			DBG_8192C("invalid set_rssi_disp parameter!\n");
+			RTW_INFO("invalid set_rssi_disp parameter!\n");
 			return count;
 		}
-		
+
 		if(enable)
-		{			
-			DBG_8192C("Linked info Function Enable\n");
-			padapter->bLinkInfoDump = enable ;			
+		{
+			RTW_INFO("Linked info Function Enable\n");
+			padapter->bLinkInfoDump = enable ;
 		}
 		else
 		{
-			DBG_8192C("Linked info Function Disable\n");
+			RTW_INFO("Linked info Function Disable\n");
 			padapter->bLinkInfoDump = 0 ;
 		}
-	
+
 	}
-	
+
 	return count;
-	
-}	
 
-*/		
+}
+
+*/
 #ifdef CONFIG_AP_MODE
 
 int proc_get_all_sta_info(struct seq_file *m, void *v)
@@ -2509,64 +3402,80 @@ int proc_get_all_sta_info(struct seq_file *m, void *v)
 	int i;
 	_list	*plist, *phead;
 
-	DBG_871X_SEL_NL(m, "sta_dz_bitmap=0x%x, tim_bitmap=0x%x\n", pstapriv->sta_dz_bitmap, pstapriv->tim_bitmap);
+	RTW_MAP_DUMP_SEL(m, "sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+	RTW_MAP_DUMP_SEL(m, "tim_bitmap=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
 
 	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-	for(i=0; i< NUM_STA; i++)
-	{
+	for (i = 0; i < NUM_STA; i++) {
 		phead = &(pstapriv->sta_hash[i]);
 		plist = get_next(phead);
-		
-		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-		{
+
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
 
 			plist = get_next(plist);
 
-			//if(extra_arg == psta->aid)
+			/* if(extra_arg == psta->cmn.aid) */
 			{
-				DBG_871X_SEL_NL(m, "==============================\n");
-				DBG_871X_SEL_NL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->hwaddr));
-				DBG_871X_SEL_NL(m, "rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
-				DBG_871X_SEL_NL(m, "state=0x%x, aid=%d, macid=%d, raid=%d\n", psta->state, psta->aid, psta->mac_id, psta->raid);
+				RTW_PRINT_SEL(m, "==============================\n");
+				RTW_PRINT_SEL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+				RTW_PRINT_SEL(m, "rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
+				RTW_PRINT_SEL(m, "state=0x%x, aid=%d, macid=%d, raid=%d\n",
+					psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
 #ifdef CONFIG_80211N_HT
-				DBG_871X_SEL_NL(m, "qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);	
-				DBG_871X_SEL_NL(m, "bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n", psta->bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
-				DBG_871X_SEL_NL(m, "ampdu_enable = %d\n", psta->htpriv.ampdu_enable);									
-				DBG_871X_SEL_NL(m, "agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
-#endif //CONFIG_80211N_HT
-				DBG_871X_SEL_NL(m, "sleepq_len=%d\n", psta->sleepq_len);
-				DBG_871X_SEL_NL(m, "sta_xmitpriv.vo_q_qcnt=%d\n", psta->sta_xmitpriv.vo_q.qcnt);
-				DBG_871X_SEL_NL(m, "sta_xmitpriv.vi_q_qcnt=%d\n", psta->sta_xmitpriv.vi_q.qcnt);
-				DBG_871X_SEL_NL(m, "sta_xmitpriv.be_q_qcnt=%d\n", psta->sta_xmitpriv.be_q.qcnt);
-				DBG_871X_SEL_NL(m, "sta_xmitpriv.bk_q_qcnt=%d\n", psta->sta_xmitpriv.bk_q.qcnt);
-
-				DBG_871X_SEL_NL(m, "capability=0x%x\n", psta->capability);
-				DBG_871X_SEL_NL(m, "flags=0x%x\n", psta->flags);
-				DBG_871X_SEL_NL(m, "wpa_psk=0x%x\n", psta->wpa_psk);
-				DBG_871X_SEL_NL(m, "wpa2_group_cipher=0x%x\n", psta->wpa2_group_cipher);
-				DBG_871X_SEL_NL(m, "wpa2_pairwise_cipher=0x%x\n", psta->wpa2_pairwise_cipher);
-				DBG_871X_SEL_NL(m, "qos_info=0x%x\n", psta->qos_info);
-				DBG_871X_SEL_NL(m, "dot118021XPrivacy=0x%x\n", psta->dot118021XPrivacy);
+				RTW_PRINT_SEL(m, "qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
+				RTW_PRINT_SEL(m, "bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n"
+					, psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
+				RTW_PRINT_SEL(m, "ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
+				RTW_PRINT_SEL(m, "tx_amsdu_enable = %d\n", psta->htpriv.tx_amsdu_enable);
+				RTW_PRINT_SEL(m, "agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
+#endif /* CONFIG_80211N_HT */
+#ifdef CONFIG_80211AC_VHT
+				RTW_PRINT_SEL(m, "vht_en=%d, vht_sgi_80m=%d\n", psta->vhtpriv.vht_option, psta->vhtpriv.sgi_80m);
+				RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", psta->vhtpriv.ldpc_cap, psta->vhtpriv.stbc_cap, psta->vhtpriv.beamform_cap);
+				RTW_PRINT_SEL(m, "vht_mcs_map=0x%x, vht_highest_rate=0x%x, vht_ampdu_len=%d\n", *(u16 *)psta->vhtpriv.vht_mcs_map, psta->vhtpriv.vht_highest_rate, psta->vhtpriv.ampdu_len);
+#endif
+				RTW_PRINT_SEL(m, "sleepq_len=%d\n", psta->sleepq_len);
+				RTW_PRINT_SEL(m, "sta_xmitpriv.vo_q_qcnt=%d\n", psta->sta_xmitpriv.vo_q.qcnt);
+				RTW_PRINT_SEL(m, "sta_xmitpriv.vi_q_qcnt=%d\n", psta->sta_xmitpriv.vi_q.qcnt);
+				RTW_PRINT_SEL(m, "sta_xmitpriv.be_q_qcnt=%d\n", psta->sta_xmitpriv.be_q.qcnt);
+				RTW_PRINT_SEL(m, "sta_xmitpriv.bk_q_qcnt=%d\n", psta->sta_xmitpriv.bk_q.qcnt);
+
+				RTW_PRINT_SEL(m, "capability=0x%x\n", psta->capability);
+				RTW_PRINT_SEL(m, "flags=0x%x\n", psta->flags);
+				RTW_PRINT_SEL(m, "wpa_psk=0x%x\n", psta->wpa_psk);
+				RTW_PRINT_SEL(m, "wpa2_group_cipher=0x%x\n", psta->wpa2_group_cipher);
+				RTW_PRINT_SEL(m, "wpa2_pairwise_cipher=0x%x\n", psta->wpa2_pairwise_cipher);
+				RTW_PRINT_SEL(m, "qos_info=0x%x\n", psta->qos_info);
+				RTW_PRINT_SEL(m, "dot118021XPrivacy=0x%x\n", psta->dot118021XPrivacy);
 
 				sta_rx_reorder_ctl_dump(m, psta);
 
 #ifdef CONFIG_TDLS
-				DBG_871X_SEL_NL(m, "tdls_sta_state=0x%08x\n", psta->tdls_sta_state);
-				DBG_871X_SEL_NL(m, "PeerKey_Lifetime=%d\n", psta->TDLS_PeerKey_Lifetime);
-				DBG_871X_SEL_NL(m, "rx_data_pkts=%llu\n", psta->sta_stats.rx_data_pkts);
-				DBG_871X_SEL_NL(m, "rx_bytes=%llu\n", psta->sta_stats.rx_bytes);
-				DBG_871X_SEL_NL(m, "tx_data_pkts=%llu\n", psta->sta_stats.tx_pkts);
-				DBG_871X_SEL_NL(m, "tx_bytes=%llu\n", psta->sta_stats.tx_bytes);
-#endif //CONFIG_TDLS
-
+				RTW_PRINT_SEL(m, "tdls_sta_state=0x%08x\n", psta->tdls_sta_state);
+				RTW_PRINT_SEL(m, "PeerKey_Lifetime=%d\n", psta->TDLS_PeerKey_Lifetime);
+#endif /* CONFIG_TDLS */
+				RTW_PRINT_SEL(m, "rx_data_uc_pkts=%llu\n", sta_rx_data_uc_pkts(psta));
+				RTW_PRINT_SEL(m, "rx_data_mc_pkts=%llu\n", psta->sta_stats.rx_data_mc_pkts);
+				RTW_PRINT_SEL(m, "rx_data_bc_pkts=%llu\n", psta->sta_stats.rx_data_bc_pkts);
+				RTW_PRINT_SEL(m, "rx_uc_bytes=%llu\n", sta_rx_uc_bytes(psta));
+				RTW_PRINT_SEL(m, "rx_mc_bytes=%llu\n", psta->sta_stats.rx_mc_bytes);
+				RTW_PRINT_SEL(m, "rx_bc_bytes=%llu\n", psta->sta_stats.rx_bc_bytes);
+				RTW_PRINT_SEL(m, "rx_avg_tp =%d (Bps)\n", psta->cmn.rx_moving_average_tp);
+
+				RTW_PRINT_SEL(m, "tx_data_pkts=%llu\n", psta->sta_stats.tx_pkts);
+				RTW_PRINT_SEL(m, "tx_bytes=%llu\n", psta->sta_stats.tx_bytes);
+				RTW_PRINT_SEL(m, "tx_avg_tp =%d (MBps)\n", psta->cmn.tx_moving_average_tp);
+#ifdef CONFIG_RTW_80211K
+				RTW_PRINT_SEL(m, "rm_en_cap="RM_CAP_FMT"\n", RM_CAP_ARG(psta->rm_en_cap));
+#endif
 				dump_st_ctl(m, &psta->st_ctl);
 
 				if (STA_OP_WFD_MODE(psta))
-					DBG_871X_SEL_NL(m, "op_wfd_mode:0x%02x\n", STA_OP_WFD_MODE(psta));
+					RTW_PRINT_SEL(m, "op_wfd_mode:0x%02x\n", STA_OP_WFD_MODE(psta));
 
-				DBG_871X_SEL_NL(m, "==============================\n");
+				RTW_PRINT_SEL(m, "==============================\n");
 			}
 
 		}
@@ -2578,7 +3487,7 @@ int proc_get_all_sta_info(struct seq_file *m, void *v)
 	return 0;
 }
 
-#endif		
+#endif
 
 #ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
 int proc_get_rtkm_info(struct seq_file *m, void *v)
@@ -2587,16 +3496,16 @@ int proc_get_rtkm_info(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct recv_priv	*precvpriv = &padapter->recvpriv;
 	struct recv_buf *precvbuf;
-	
+
 	precvbuf = (struct recv_buf *)precvpriv->precv_buf;
 
-	DBG_871X_SEL_NL(m, "============[RTKM Info]============\n");
-	DBG_871X_SEL_NL(m, "MAX_RTKM_NR_PREALLOC_RECV_SKB: %d\n", rtw_rtkm_get_nr_recv_skb());
-	DBG_871X_SEL_NL(m, "MAX_RTKM_RECVBUF_SZ: %d\n", rtw_rtkm_get_buff_size());
+	RTW_PRINT_SEL(m, "============[RTKM Info]============\n");
+	RTW_PRINT_SEL(m, "MAX_RTKM_NR_PREALLOC_RECV_SKB: %d\n", rtw_rtkm_get_nr_recv_skb());
+	RTW_PRINT_SEL(m, "MAX_RTKM_RECVBUF_SZ: %d\n", rtw_rtkm_get_buff_size());
 
-	DBG_871X_SEL_NL(m, "============[Driver Info]============\n");
-	DBG_871X_SEL_NL(m, "NR_PREALLOC_RECV_SKB: %d\n", NR_PREALLOC_RECV_SKB);
-	DBG_871X_SEL_NL(m, "MAX_RECVBUF_SZ: %d\n", precvbuf->alloc_sz);
+	RTW_PRINT_SEL(m, "============[Driver Info]============\n");
+	RTW_PRINT_SEL(m, "NR_PREALLOC_RECV_SKB: %d\n", NR_PREALLOC_RECV_SKB);
+	RTW_PRINT_SEL(m, "MAX_RECVBUF_SZ: %d\n", precvbuf->alloc_sz);
 
 	return 0;
 }
@@ -2609,8 +3518,8 @@ extern atomic_t _malloc_size;;
 
 int proc_get_malloc_cnt(struct seq_file *m, void *v)
 {
-	DBG_871X_SEL_NL(m, "_malloc_cnt=%d\n", atomic_read(&_malloc_cnt));
-	DBG_871X_SEL_NL(m, "_malloc_size=%d\n", atomic_read(&_malloc_size));
+	RTW_PRINT_SEL(m, "_malloc_cnt=%d\n", atomic_read(&_malloc_cnt));
+	RTW_PRINT_SEL(m, "_malloc_size=%d\n", atomic_read(&_malloc_size));
 
 	return 0;
 }
@@ -2621,53 +3530,54 @@ int proc_get_best_channel(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	u32 i, best_channel_24G = 1, best_channel_5G = 36, index_24G = 0, index_5G = 0;
 
-	for (i=0; pmlmeext->channel_set[i].ChannelNum !=0; i++) {
-		if ( pmlmeext->channel_set[i].ChannelNum == 1)
+	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
+		if (rfctl->channel_set[i].ChannelNum == 1)
 			index_24G = i;
-		if ( pmlmeext->channel_set[i].ChannelNum == 36)
+		if (rfctl->channel_set[i].ChannelNum == 36)
 			index_5G = i;
-	}	
-	
-	for (i=0; (i < MAX_CHANNEL_NUM) && (pmlmeext->channel_set[i].ChannelNum !=0) ; i++) {
-		// 2.4G
-		if ( pmlmeext->channel_set[i].ChannelNum == 6 ) {
-			if ( pmlmeext->channel_set[i].rx_count < pmlmeext->channel_set[index_24G].rx_count ) {
+	}
+
+	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
+		/* 2.4G */
+		if (rfctl->channel_set[i].ChannelNum == 6) {
+			if (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_24G].rx_count) {
 				index_24G = i;
-				best_channel_24G = pmlmeext->channel_set[i].ChannelNum;
+				best_channel_24G = rfctl->channel_set[i].ChannelNum;
 			}
 		}
 
-		// 5G
-		if ( pmlmeext->channel_set[i].ChannelNum >= 36
-			&& pmlmeext->channel_set[i].ChannelNum < 140 ) {
-			 // Find primary channel
-			if ( (( pmlmeext->channel_set[i].ChannelNum - 36) % 8 == 0)
-				&& (pmlmeext->channel_set[i].rx_count < pmlmeext->channel_set[index_5G].rx_count) ) {
+		/* 5G */
+		if (rfctl->channel_set[i].ChannelNum >= 36
+		    && rfctl->channel_set[i].ChannelNum < 140) {
+			/* Find primary channel */
+			if (((rfctl->channel_set[i].ChannelNum - 36) % 8 == 0)
+			    && (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
 				index_5G = i;
-				best_channel_5G = pmlmeext->channel_set[i].ChannelNum;
+				best_channel_5G = rfctl->channel_set[i].ChannelNum;
 			}
 		}
 
-		if ( pmlmeext->channel_set[i].ChannelNum >= 149
-			&& pmlmeext->channel_set[i].ChannelNum < 165) {
-			 // find primary channel
-			if ( (( pmlmeext->channel_set[i].ChannelNum - 149) % 8 == 0)
-				&& (pmlmeext->channel_set[i].rx_count < pmlmeext->channel_set[index_5G].rx_count) ) {
+		if (rfctl->channel_set[i].ChannelNum >= 149
+		    && rfctl->channel_set[i].ChannelNum < 165) {
+			/* find primary channel */
+			if (((rfctl->channel_set[i].ChannelNum - 149) % 8 == 0)
+			    && (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
 				index_5G = i;
-				best_channel_5G = pmlmeext->channel_set[i].ChannelNum;
+				best_channel_5G = rfctl->channel_set[i].ChannelNum;
 			}
 		}
-#if 1 // debug
-		DBG_871X_SEL_NL(m, "The rx cnt of channel %3d = %d\n", 
-					pmlmeext->channel_set[i].ChannelNum, pmlmeext->channel_set[i].rx_count);
+#if 1 /* debug */
+		RTW_PRINT_SEL(m, "The rx cnt of channel %3d = %d\n",
+			rfctl->channel_set[i].ChannelNum, rfctl->channel_set[i].rx_count);
 #endif
 	}
-	
-	DBG_871X_SEL_NL(m, "best_channel_5G = %d\n", best_channel_5G);
-	DBG_871X_SEL_NL(m, "best_channel_24G = %d\n", best_channel_24G);
+
+	RTW_PRINT_SEL(m, "best_channel_5G = %d\n", best_channel_5G);
+	RTW_PRINT_SEL(m, "best_channel_24G = %d\n", best_channel_24G);
 
 	return 0;
 }
@@ -2676,10 +3586,11 @@ ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	char tmp[32];
 
-	if(count < 1)
+	if (count < 1)
 		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
@@ -2689,12 +3600,10 @@ ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 		int i;
-		for(i = 0; pmlmeext->channel_set[i].ChannelNum != 0; i++)
-		{
-			pmlmeext->channel_set[i].rx_count = 0;
-		}
+		for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++)
+			rfctl->channel_set[i].rx_count = 0;
 
-		DBG_871X("set %s\n", "Clean Best Channel Count");
+		RTW_INFO("set %s\n", "Clean Best Channel Count");
 	}
 
 	return count;
@@ -2711,7 +3620,7 @@ int proc_get_btcoex_dbg(struct seq_file *m, void *v)
 
 	rtw_btcoex_GetDBG(padapter, buf, 512);
 
-	DBG_871X_SEL(m, "%s", buf);
+	_RTW_PRINT_SEL(m, "%s", buf);
 
 	return 0;
 }
@@ -2726,20 +3635,18 @@ ssize_t proc_set_btcoex_dbg(struct file *file, const char __user *buffer, size_t
 
 	padapter = (PADAPTER)rtw_netdev_priv(dev);
 
-//	DBG_871X("+" FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(padapter));
+	/*	RTW_INFO("+" FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(padapter)); */
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n",
+			 FUNC_ADPT_ARG(padapter));
 
-	if (NULL == buffer)
-	{
-		DBG_871X(FUNC_ADPT_FMT ": input buffer is NULL!\n",
-			FUNC_ADPT_ARG(padapter));
-		
 		return -EFAULT;
 	}
 
-	if (count < 1)
-	{
-		DBG_871X(FUNC_ADPT_FMT ": input length is 0!\n",
-			FUNC_ADPT_ARG(padapter));
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n",
+			 FUNC_ADPT_ARG(padapter));
 
 		return -EFAULT;
 	}
@@ -2748,33 +3655,29 @@ ssize_t proc_set_btcoex_dbg(struct file *file, const char __user *buffer, size_t
 	if (num > (sizeof(tmp) - 1))
 		num = (sizeof(tmp) - 1);
 
-	if (copy_from_user(tmp, buffer, num))
-	{
-		DBG_871X(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
-			FUNC_ADPT_ARG(padapter));
+	if (copy_from_user(tmp, buffer, num)) {
+		RTW_INFO(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
+			 FUNC_ADPT_ARG(padapter));
 
 		return -EFAULT;
 	}
 
-	num = sscanf(tmp, "%x %x", module, module+1);
-	if (1 == num)
-	{
+	num = sscanf(tmp, "%x %x", module, module + 1);
+	if (1 == num) {
 		if (0 == module[0])
 			_rtw_memset(module, 0, sizeof(module));
 		else
 			_rtw_memset(module, 0xFF, sizeof(module));
-	}
-	else if (2 != num)
-	{
-		DBG_871X(FUNC_ADPT_FMT ": input(\"%s\") format incorrect!\n",
-			FUNC_ADPT_ARG(padapter), tmp);
+	} else if (2 != num) {
+		RTW_INFO(FUNC_ADPT_FMT ": input(\"%s\") format incorrect!\n",
+			 FUNC_ADPT_ARG(padapter), tmp);
 
 		if (0 == num)
 			return -EFAULT;
 	}
 
-	DBG_871X(FUNC_ADPT_FMT ": input 0x%08X 0x%08X\n",
-		FUNC_ADPT_ARG(padapter), module[0], module[1]);
+	RTW_INFO(FUNC_ADPT_FMT ": input 0x%08X 0x%08X\n",
+		 FUNC_ADPT_ARG(padapter), module[0], module[1]);
 	rtw_btcoex_SetDBG(padapter, module);
 
 	return count;
@@ -2784,24 +3687,72 @@ int proc_get_btcoex_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	PADAPTER padapter;
-	const u32 bufsize = 30*100;
+	const u32 bufsize = 30 * 100;
 	u8 *pbuf = NULL;
 
 	padapter = (PADAPTER)rtw_netdev_priv(dev);
 
 	pbuf = rtw_zmalloc(bufsize);
-	if (NULL == pbuf) {
+	if (NULL == pbuf)
 		return -ENOMEM;
-	}
 
 	rtw_btcoex_DisplayBtCoexInfo(padapter, pbuf, bufsize);
 
-	DBG_871X_SEL(m, "%s\n", pbuf);
-	
+	_RTW_PRINT_SEL(m, "%s\n", pbuf);
+
 	rtw_mfree(pbuf, bufsize);
 
 	return 0;
 }
+
+#ifdef CONFIG_RF4CE_COEXIST
+int proc_get_rf4ce_state(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 state = 0, voice = 0;
+
+	state = rtw_btcoex_GetRf4ceLinkState(adapter);
+
+	RTW_PRINT_SEL(m, "RF4CE %s\n", state?"Connected":"Disconnect");
+
+	return 0;
+}
+
+/* This interface is designed for user space application to inform RF4CE state
+ * Initial define for DHC 1295 E387 project
+ *
+ * echo state voice > rf4ce_state
+ * state
+ *	0: RF4CE disconnected
+ *	1: RF4CE connected
+ */
+ssize_t proc_set_rf4ce_state(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 state;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &state);
+
+		if (num >= 1)
+			rtw_btcoex_SetRf4ceLinkState(adapter, state);
+	}
+
+	return count;
+}
+#endif /* CONFIG_RF4CE_COEXIST */
 #endif /* CONFIG_BT_COEXIST */
 
 #if defined(DBG_CONFIG_ERROR_DETECT)
@@ -2809,8 +3760,21 @@ int proc_get_sreset(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *psdpriv = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
+	if (psrtpriv->dbg_sreset_ctrl == _TRUE) {
+		RTW_PRINT_SEL(m, "self_dect_tx_cnt:%llu\n", psrtpriv->self_dect_tx_cnt);
+		RTW_PRINT_SEL(m, "self_dect_rx_cnt:%llu\n", psrtpriv->self_dect_rx_cnt);
+		RTW_PRINT_SEL(m, "self_dect_fw_cnt:%llu\n", psrtpriv->self_dect_fw_cnt);
+		RTW_PRINT_SEL(m, "tx_dma_status_cnt:%llu\n", psrtpriv->tx_dma_status_cnt);
+		RTW_PRINT_SEL(m, "rx_dma_status_cnt:%llu\n", psrtpriv->rx_dma_status_cnt);
+		RTW_PRINT_SEL(m, "self_dect_case:%d\n", psrtpriv->self_dect_case);
+		RTW_PRINT_SEL(m, "dbg_sreset_cnt:%d\n", pdbgpriv->dbg_sreset_cnt);
+	}
 	return 0;
 }
 
@@ -2818,6 +3782,8 @@ ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t cou
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
 	char tmp[32];
 	s32 trigger_point;
 
@@ -2835,17 +3801,76 @@ ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t cou
 
 		if (trigger_point == SRESET_TGP_NULL)
 			rtw_hal_sreset_reset(padapter);
+		else if (trigger_point == SRESET_TGP_INFO)
+			psrtpriv->dbg_sreset_ctrl = _TRUE;
 		else
 			sreset_set_trigger_point(padapter, trigger_point);
 	}
-	
+
 	return count;
-	
+
 }
 #endif /* DBG_CONFIG_ERROR_DETECT */
 
 #ifdef CONFIG_PCI_HCI
 
+int proc_get_pci_aspm(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct pci_priv	*pcipriv = &(pdvobjpriv->pcipriv);
+	u8 tmp8 = 0;
+	u16 tmp16 = 0;
+	u32 tmp32 = 0;
+	u8 l1_idle = 0;
+
+
+	RTW_PRINT_SEL(m, "***** ASPM Capability *****\n");
+
+	pci_read_config_dword(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCAP, &tmp32);
+
+	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp32&PCI_EXP_LNKCAP_CLKPM) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp32&BIT10) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp32&BIT11) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_l1off_capability(padapter);
+	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", tmp8 ? "Enable" : "Disable");
+
+	RTW_PRINT_SEL(m, "***** ASPM CTRL Reg *****\n");
+
+	pci_read_config_word(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCTL, &tmp16);
+
+	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp16&PCI_EXP_LNKCTL_CLKREQ_EN) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp16&BIT0) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp16&BIT1) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_l1off_nic_support(padapter);
+	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", tmp8 ? "Enable" : "Disable");
+
+	RTW_PRINT_SEL(m, "***** ASPM Backdoor *****\n");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
+	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp8 & BIT4) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x70f);
+	l1_idle = tmp8 & 0x38;
+	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp8&BIT7) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
+	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp8 & BIT3) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x718);
+	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", (tmp8 & BIT5) ? "Enable" : "Disable");
+
+	RTW_PRINT_SEL(m, "********* MISC **********\n");
+	RTW_PRINT_SEL(m, "ASPM L1 Idel Time: 0x%x\n", l1_idle>>3);
+	RTW_PRINT_SEL(m, "*************************\n");
+
+	return 0;
+}
+
 int proc_get_rx_ring(struct seq_file *m, void *v)
 {
 	_irqL irqL;
@@ -2856,28 +3881,30 @@ int proc_get_rx_ring(struct seq_file *m, void *v)
 	struct rtw_rx_ring *rx_ring = &precvpriv->rx_ring[RX_MPDU_QUEUE];
 	int i, j;
 
-	DBG_871X_SEL_NL(m, "rx ring (%p)\n", rx_ring);
-	DBG_871X_SEL_NL(m, "  dma: 0x%08x\n", (int) rx_ring->dma);
-	DBG_871X_SEL_NL(m, "  idx: %d\n", rx_ring->idx);
+	RTW_PRINT_SEL(m, "rx ring (%p)\n", rx_ring);
+	RTW_PRINT_SEL(m, "  dma: 0x%08x\n", (int) rx_ring->dma);
+	RTW_PRINT_SEL(m, "  idx: %d\n", rx_ring->idx);
 
 	_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
-	for (i=0; i<precvpriv->rxringcount; i++)
-	{
+	for (i = 0; i < precvpriv->rxringcount; i++) {
+#ifdef CONFIG_TRX_BD_ARCH
+		struct rx_buf_desc *entry = &rx_ring->buf_desc[i];
+#else
 		struct recv_stat *entry = &rx_ring->desc[i];
+#endif
 		struct sk_buff *skb = rx_ring->rx_buf[i];
 
-		DBG_871X_SEL_NL(m, "  desc[%03d]: %p, rx_buf[%03d]: 0x%08x\n",
+		RTW_PRINT_SEL(m, "  desc[%03d]: %p, rx_buf[%03d]: 0x%08x\n",
 			i, entry, i, cpu_to_le32(*((dma_addr_t *)skb->cb)));
 
-		for (j=0; j<sizeof(*entry)/4; j++)
-		{
+		for (j = 0; j < sizeof(*entry) / 4; j++) {
 			if ((j % 4) == 0)
-				DBG_871X_SEL_NL(m, "  0x%03x", j);
+				RTW_PRINT_SEL(m, "  0x%03x", j);
 
-			DBG_871X_SEL_NL(m, " 0x%08x ", ((int *) entry)[j]);
+			RTW_PRINT_SEL(m, " 0x%08x ", ((int *) entry)[j]);
 
 			if ((j % 4) == 3)
-				DBG_871X_SEL_NL(m, "\n");
+				RTW_PRINT_SEL(m, "\n");
 		}
 	}
 	_exit_critical(&pdvobjpriv->irq_th_lock, &irqL);
@@ -2895,31 +3922,33 @@ int proc_get_tx_ring(struct seq_file *m, void *v)
 	int i, j, k;
 
 	_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
-	for (i = 0; i < PCI_MAX_TX_QUEUE_COUNT; i++)
-	{
+	for (i = 0; i < PCI_MAX_TX_QUEUE_COUNT; i++) {
 		struct rtw_tx_ring *tx_ring = &pxmitpriv->tx_ring[i];
 
-		DBG_871X_SEL_NL(m, "tx ring[%d] (%p)\n", i, tx_ring);
-		DBG_871X_SEL_NL(m, "  dma: 0x%08x\n", (int) tx_ring->dma);
-		DBG_871X_SEL_NL(m, "  idx: %d\n", tx_ring->idx);
-		DBG_871X_SEL_NL(m, "  entries: %d\n", tx_ring->entries);
-//		DBG_871X_SEL_NL(m, "  queue: %d\n", tx_ring->queue);
-		DBG_871X_SEL_NL(m, "  qlen: %d\n", tx_ring->qlen);
-
-		for (j=0; j < pxmitpriv->txringcount[i]; j++)
-		{
+		RTW_PRINT_SEL(m, "tx ring[%d] (%p)\n", i, tx_ring);
+		RTW_PRINT_SEL(m, "  dma: 0x%08x\n", (int) tx_ring->dma);
+		RTW_PRINT_SEL(m, "  idx: %d\n", tx_ring->idx);
+		RTW_PRINT_SEL(m, "  entries: %d\n", tx_ring->entries);
+		/*		RTW_PRINT_SEL(m, "  queue: %d\n", tx_ring->queue); */
+		RTW_PRINT_SEL(m, "  qlen: %d\n", tx_ring->qlen);
+
+		for (j = 0; j < pxmitpriv->txringcount[i]; j++) {
+#ifdef CONFIG_TRX_BD_ARCH
+			struct tx_buf_desc *entry = &tx_ring->buf_desc[j];
+			RTW_PRINT_SEL(m, "  buf_desc[%03d]: %p\n", j, entry);
+#else
 			struct tx_desc *entry = &tx_ring->desc[j];
+			RTW_PRINT_SEL(m, "  desc[%03d]: %p\n", j, entry);
+#endif
 
-			DBG_871X_SEL_NL(m, "  desc[%03d]: %p\n", j, entry);
-			for (k=0; k < sizeof(*entry)/4; k++)
-			{
+			for (k = 0; k < sizeof(*entry) / 4; k++) {
 				if ((k % 4) == 0)
-					DBG_871X_SEL_NL(m, "  0x%03x", k);
+					RTW_PRINT_SEL(m, "  0x%03x", k);
 
-				DBG_871X_SEL_NL(m, " 0x%08x ", ((int *) entry)[k]);
+				RTW_PRINT_SEL(m, " 0x%08x ", ((int *) entry)[k]);
 
 				if ((k % 4) == 3)
-					DBG_871X_SEL_NL(m, "\n");
+					RTW_PRINT_SEL(m, "\n");
 			}
 		}
 	}
@@ -2927,32 +3956,119 @@ int proc_get_tx_ring(struct seq_file *m, void *v)
 
 	return 0;
 }
-#endif
 
-#ifdef CONFIG_GPIO_WAKEUP
-int proc_get_wowlan_gpio_info(struct seq_file *m, void *v)
+#ifdef DBG_TXBD_DESC_DUMP
+int proc_get_tx_ring_ext(struct seq_file *m, void *v)
 {
+	_irqL irqL;
 	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	u8 val = pwrpriv->is_high_active;
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct rtw_tx_desc_backup *pbuf;
+	int i, j, k, idx;
+
+	RTW_PRINT_SEL(m, "<<<< tx ring ext dump settings >>>>\n");
+	RTW_PRINT_SEL(m, " - backup frame num: %d\n", TX_BAK_FRMAE_CNT);
+	RTW_PRINT_SEL(m, " - backup max. desc size: %d bytes\n", TX_BAK_DESC_LEN);
+	RTW_PRINT_SEL(m, " - backup data size: %d bytes\n\n", TX_BAK_DATA_LEN);
+
+	if (!pxmitpriv->dump_txbd_desc) {
+		RTW_PRINT_SEL(m, "Dump function is disabled.\n");
+		return 0;
+	}
+
+	_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
+	for (i = 0; i < HW_QUEUE_ENTRY; i++) {
+		struct rtw_tx_ring *tx_ring = &pxmitpriv->tx_ring[i];
+
+		idx = rtw_get_tx_desc_backup(padapter, i, &pbuf);
+
+		RTW_PRINT_SEL(m, "Tx ring[%d]", i);
+		switch (i) {
+		case 0:
+			RTW_PRINT_SEL(m, " (VO)\n");
+			break;
+		case 1:
+			RTW_PRINT_SEL(m, " (VI)\n");
+			break;
+		case 2:
+			RTW_PRINT_SEL(m, " (BE)\n");
+			break;
+		case 3:
+			RTW_PRINT_SEL(m, " (BK)\n");
+			break;
+		case 4:
+			RTW_PRINT_SEL(m, " (BCN)\n");
+			break;
+		case 5:
+			RTW_PRINT_SEL(m, " (MGT)\n");
+			break;
+		case 6:
+			RTW_PRINT_SEL(m, " (HIGH)\n");
+			break;
+		case 7:
+			RTW_PRINT_SEL(m, " (TXCMD)\n");
+			break;
+		default:
+			RTW_PRINT_SEL(m, " (?)\n");
+			break;
+		}
+
+		RTW_PRINT_SEL(m, "  Entries: %d\n", TX_BAK_FRMAE_CNT);
+		RTW_PRINT_SEL(m, "  Last idx: %d\n", idx);
 
-	DBG_871X_SEL_NL(m, "wakeup_gpio_idx: %d\n", WAKEUP_GPIO_IDX);
-	DBG_871X_SEL_NL(m, "high_active: %d\n", val);
+		for (j = 0; j < TX_BAK_FRMAE_CNT; j++) {
+			RTW_PRINT_SEL(m, "  desc[%03d]:\n", j);
+
+			for (k = 0; k < (pbuf->tx_desc_size) / 4; k++) {
+				if ((k % 4) == 0)
+					RTW_PRINT_SEL(m, "  0x%03x", k);
+
+				RTW_PRINT_SEL(m, " 0x%08x ", ((int *)pbuf->tx_bak_desc)[k]);
+
+				if ((k % 4) == 3)
+					RTW_PRINT_SEL(m, "\n");
+			}
+
+#if 1 /* data dump */
+			if (pbuf->tx_desc_size) {
+				RTW_PRINT_SEL(m, "  data[%03d]:\n", j);
+
+				for (k = 0; k < (TX_BAK_DATA_LEN) / 4; k++) {
+					if ((k % 4) == 0)
+						RTW_PRINT_SEL(m, "  0x%03x", k);
+
+					RTW_PRINT_SEL(m, " 0x%08x ", ((int *)pbuf->tx_bak_data_hdr)[k]);
+
+					if ((k % 4) == 3)
+						RTW_PRINT_SEL(m, "\n");
+				}
+				RTW_PRINT_SEL(m, "\n");
+			}
+#endif
+
+			RTW_PRINT_SEL(m, "  R/W pointer: %d/%d\n", pbuf->tx_bak_rp, pbuf->tx_bak_wp);
+
+			pbuf = pbuf + 1;
+		}
+		RTW_PRINT_SEL(m, "\n");
+	}
+	_exit_critical(&pdvobjpriv->irq_th_lock, &irqL);
 
 	return 0;
 }
 
-ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,
-		size_t count, loff_t *pos, void *data)
+ssize_t proc_set_tx_ring_ext(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
+	_irqL irqL;
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	char tmp[32] = {0};
-	int num = 0;
-	u32 is_high_active = 0;
-	u8 val8 = 0;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+	char tmp[32];
+	u32 reset = 0;
+	u32 dump = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -2964,79 +4080,163 @@ ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		num = sscanf(tmp, "%u", &is_high_active);
+		int num = sscanf(tmp, "%u %u", &dump, &reset);
 
-		is_high_active = is_high_active == 0 ? 0 : 1;
+		if (num != 2) {
+			RTW_INFO("invalid parameter!\n");
+			return count;
+		}
 
-		pwrpriv->is_high_active = is_high_active;
+		_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
+		pxmitpriv->dump_txbd_desc = (BOOLEAN) dump;
 
-		rtw_ps_deny(padapter, PS_DENY_IOCTL);
-		LeaveAllPowerSaveModeDirect(padapter);
-		val8 = (pwrpriv->is_high_active == 0) ? 1 : 0;
-		rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
-		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+		if (reset == 1)
+			rtw_tx_desc_backup_reset();
+
+		_exit_critical(&pdvobjpriv->irq_th_lock, &irqL);
 
-		DBG_871X("set %s %d\n", "gpio_high_active",
-				pwrpriv->is_high_active);
-		DBG_871X("%s: set GPIO_%d %d as default.\n",
-			 __func__, WAKEUP_GPIO_IDX, val8);
 	}
-	
+
 	return count;
 }
-#endif /* CONFIG_GPIO_WAKEUP */
 
-#ifdef CONFIG_P2P_WOWLAN
-int proc_get_p2p_wowlan_info(struct seq_file *m, void *v)
+#endif
+
+#endif
+
+#ifdef CONFIG_WOWLAN
+int proc_get_pattern_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-	struct p2p_wowlan_info	 peerinfo = pwdinfo->p2p_wow_info;
-	if(_TRUE == peerinfo.is_trigger)
-	{
-		DBG_871X_SEL_NL(m,"is_trigger: TRUE\n");
-		switch(peerinfo.wowlan_recv_frame_type)
-		{
-			case P2P_WOWLAN_RECV_NEGO_REQ:
-				DBG_871X_SEL_NL(m,"Frame Type: Nego Request\n");
-				break;
-			case P2P_WOWLAN_RECV_INVITE_REQ:
-				DBG_871X_SEL_NL(m,"Frame Type: Invitation Request\n");
-				break;
-			case P2P_WOWLAN_RECV_PROVISION_REQ:
-				DBG_871X_SEL_NL(m,"Frame Type: Provision Request\n");
-				break;
-			default:
-				break;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
+	u8 pattern_num = 0, val8;
+	char str_1[128];
+	char *p_str;
+	int i = 0 , j = 0, k = 0;
+	int len = 0, max_len = 0, total = 0;
+
+	p_str = str_1;
+	max_len = sizeof(str_1);
+
+	total = pwrpriv->wowlan_pattern_idx;
+
+	rtw_set_default_pattern(padapter);
+
+	/*show pattern*/
+	RTW_PRINT_SEL(m, "\n======[Pattern Info.]======\n");
+	RTW_PRINT_SEL(m, "pattern number: %d\n", total);
+	RTW_PRINT_SEL(m, "support default patterns: %c\n",
+		      (pwrpriv->default_patterns_en) ? 'Y' : 'N');
+
+	for (k = 0; k < total ; k++) {
+		RTW_PRINT_SEL(m, "\npattern idx: %d\n", k);
+		RTW_PRINT_SEL(m, "pattern content:\n");
+
+		p_str = str_1;
+		max_len = sizeof(str_1);
+		for (i = 0 ; i < MAX_WKFM_PATTERN_SIZE / 8 ; i++) {
+			_rtw_memset(p_str, 0, max_len);
+			len = 0;
+			for (j = 0 ; j < 8 ; j++) {
+				val8 = pwrpriv->patterns[k].content[i * 8 + j];
+				len += snprintf(p_str + len, max_len - len,
+						"%02x ", val8);
+			}
+			RTW_PRINT_SEL(m, "%s\n", p_str);
 		}
-		DBG_871X_SEL_NL(m,"Peer Addr: "MAC_FMT"\n", MAC_ARG(peerinfo.wowlan_peer_addr));
-		DBG_871X_SEL_NL(m,"Peer WPS Config: %x\n", peerinfo.wowlan_peer_wpsconfig);
-		DBG_871X_SEL_NL(m,"Persistent Group: %d\n", peerinfo.wowlan_peer_is_persistent);
-		DBG_871X_SEL_NL(m,"Intivation Type: %d\n", peerinfo.wowlan_peer_invitation_type);
-	}
-	else
-	{
-		DBG_871X_SEL_NL(m,"is_trigger: False\n");
+		RTW_PRINT_SEL(m, "\npattern mask:\n");
+		for (i = 0 ; i < MAX_WKFM_SIZE / 8 ; i++) {
+			_rtw_memset(p_str, 0, max_len);
+			len = 0;
+			for (j = 0 ; j < 8 ; j++) {
+				val8 = pwrpriv->patterns[k].mask[i * 8 + j];
+				len += snprintf(p_str + len, max_len - len,
+						"%02x ", val8);
+			}
+			RTW_PRINT_SEL(m, "%s\n", p_str);
+		}
+
+		RTW_PRINT_SEL(m, "\npriv_pattern_len:\n");
+		RTW_PRINT_SEL(m, "pattern_len: %d\n", pwrpriv->patterns[k].len);
+		RTW_PRINT_SEL(m, "*****************\n");
 	}
+
 	return 0;
 }
-#endif /* CONFIG_P2P_WOWLAN */
 
-int proc_get_new_bcn_max(struct seq_file *m, void *v)
+ssize_t proc_set_pattern_info(struct file *file, const char __user *buffer,
+			      size_t count, loff_t *pos, void *data)
 {
-	extern int new_bcn_max;
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct wowlan_ioctl_param poidparam;
+	u8 tmp[MAX_WKFM_PATTERN_SIZE] = {0};
+	int ret = 0, num = 0;
+	u8 index = 0;
+
+	poidparam.subcode = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (pwrpriv->wowlan_pattern_idx >= MAX_WKFM_CAM_NUM) {
+		RTW_INFO("WARNING: priv-pattern is full(idx: %d)\n",
+			 pwrpriv->wowlan_pattern_idx);
+		RTW_INFO("WARNING: please clean priv-pattern first\n");
+		return -ENOMEM;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		if (strncmp(tmp, "clean", 5) == 0) {
+			poidparam.subcode = WOWLAN_PATTERN_CLEAN;
+			rtw_hal_set_hwreg(padapter,
+					  HW_VAR_WOWLAN, (u8 *)&poidparam);
+		} else {
+			index = pwrpriv->wowlan_pattern_idx;
+			ret = rtw_wowlan_parser_pattern_cmd(tmp,
+					    pwrpriv->patterns[index].content,
+					    &pwrpriv->patterns[index].len,
+					    pwrpriv->patterns[index].mask);
+			if (ret == _TRUE)
+				pwrpriv->wowlan_pattern_idx++;
+		}
+	}
+
+	return count;
+}
+
+int proc_get_wakeup_event(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv  *registry_par = &padapter->registrypriv;
 
-	DBG_871X_SEL_NL(m, "%d", new_bcn_max);
+	RTW_PRINT_SEL(m, "wakeup event: %#02x\n", registry_par->wakeup_event);
 	return 0;
 }
 
-ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_wakeup_event(struct file *file, const char __user *buffer,
+			      size_t count, loff_t *pos, void *data)
 {
-	char tmp[32];
-	extern int new_bcn_max;
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+	struct registry_priv  *registry_par = &padapter->registrypriv;
+	u32 wakeup_event = 0;
+
+	u8 tmp[8] = {0};
+	int ret = 0, num = 0;
+	u8 index = 0;
 
-	if(count < 1)
+	if (count < 1)
 		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
@@ -3045,874 +4245,1923 @@ ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count))
-		sscanf(tmp, "%d ", &new_bcn_max);
+		num = sscanf(tmp, "%u", &wakeup_event);
+	else
+		return -EFAULT;
+
+	if (wakeup_event <= 0x07) {
+		registry_par->wakeup_event = wakeup_event;
+
+		if (wakeup_event & BIT(1))
+			pwrctrlpriv->default_patterns_en = _TRUE;
+		else
+			pwrctrlpriv->default_patterns_en = _FALSE;
+
+		rtw_wow_pattern_sw_reset(padapter);
+
+		RTW_INFO("%s: wakeup_event: %#2x, default pattern: %d\n",
+			 __func__, registry_par->wakeup_event,
+			 pwrctrlpriv->default_patterns_en);
+	} else {
+		return -EINVAL;
+	}
 
 	return count;
 }
 
-#ifdef CONFIG_POWER_SAVING
-int proc_get_ps_info(struct seq_file *m, void *v)
-{	
+int proc_get_wakeup_reason(struct seq_file *m, void *v)
+{
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	u8 ips_mode = pwrpriv->ips_mode;
-	u8 lps_mode = pwrpriv->power_mgnt;
-	char *str = "";
+	u8 val = pwrpriv->wowlan_last_wake_reason;
 
-	DBG_871X_SEL_NL(m, "======Power Saving Info:======\n");
-	DBG_871X_SEL_NL(m, "*IPS:\n");
+	RTW_PRINT_SEL(m, "last wake reason: %#02x\n", val);
+	return 0;
+}
+#endif /*CONFIG_WOWLAN*/
 
-	if (ips_mode == IPS_NORMAL) {
-#ifdef CONFIG_FWLPS_IN_IPS
-		str = "FW_LPS_IN_IPS";
-#else
-		str = "Card Disable";
-#endif
-	} else if (ips_mode == IPS_NONE) {
-		str = "NO IPS";
-	} else if (ips_mode == IPS_LEVEL_2) {
+#ifdef CONFIG_GPIO_WAKEUP
+int proc_get_wowlan_gpio_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	u8 val = pwrpriv->is_high_active;
+
+	RTW_PRINT_SEL(m, "wakeup_gpio_idx: %d\n", WAKEUP_GPIO_IDX);
+	RTW_PRINT_SEL(m, "high_active: %d\n", val);
+
+	return 0;
+}
+
+ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,
+				  size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	char tmp[32] = {0};
+	int num = 0;
+	u32 is_high_active = 0;
+	u8 val8 = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		num = sscanf(tmp, "%u", &is_high_active);
+
+		is_high_active = is_high_active == 0 ? 0 : 1;
+
+		pwrpriv->is_high_active = is_high_active;
+
+		rtw_ps_deny(padapter, PS_DENY_IOCTL);
+		LeaveAllPowerSaveModeDirect(padapter);
+
+		#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
+		if (pwrpriv->is_high_active == 0)
+			rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
+		else
+			rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
+		#else
+		val8 = (pwrpriv->is_high_active == 0) ? 1 : 0;
+		rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
+		rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
+		#endif
+		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+
+		RTW_INFO("set %s %d\n", "gpio_high_active",
+			 pwrpriv->is_high_active);
+		RTW_INFO("%s: set GPIO_%d %d as default.\n",
+			 __func__, WAKEUP_GPIO_IDX, val8);
+	}
+
+	return count;
+}
+#endif /* CONFIG_GPIO_WAKEUP */
+
+#ifdef CONFIG_P2P_WOWLAN
+int proc_get_p2p_wowlan_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	struct p2p_wowlan_info	 peerinfo = pwdinfo->p2p_wow_info;
+	if (_TRUE == peerinfo.is_trigger) {
+		RTW_PRINT_SEL(m, "is_trigger: TRUE\n");
+		switch (peerinfo.wowlan_recv_frame_type) {
+		case P2P_WOWLAN_RECV_NEGO_REQ:
+			RTW_PRINT_SEL(m, "Frame Type: Nego Request\n");
+			break;
+		case P2P_WOWLAN_RECV_INVITE_REQ:
+			RTW_PRINT_SEL(m, "Frame Type: Invitation Request\n");
+			break;
+		case P2P_WOWLAN_RECV_PROVISION_REQ:
+			RTW_PRINT_SEL(m, "Frame Type: Provision Request\n");
+			break;
+		default:
+			break;
+		}
+		RTW_PRINT_SEL(m, "Peer Addr: "MAC_FMT"\n", MAC_ARG(peerinfo.wowlan_peer_addr));
+		RTW_PRINT_SEL(m, "Peer WPS Config: %x\n", peerinfo.wowlan_peer_wpsconfig);
+		RTW_PRINT_SEL(m, "Persistent Group: %d\n", peerinfo.wowlan_peer_is_persistent);
+		RTW_PRINT_SEL(m, "Intivation Type: %d\n", peerinfo.wowlan_peer_invitation_type);
+	} else
+		RTW_PRINT_SEL(m, "is_trigger: False\n");
+	return 0;
+}
+#endif /* CONFIG_P2P_WOWLAN */
+
+int proc_get_new_bcn_max(struct seq_file *m, void *v)
+{
+	extern int new_bcn_max;
+
+	RTW_PRINT_SEL(m, "%d", new_bcn_max);
+	return 0;
+}
+
+ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	char tmp[32];
+	extern int new_bcn_max;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count))
+		sscanf(tmp, "%d ", &new_bcn_max);
+
+	return count;
+}
+
+#ifdef CONFIG_POWER_SAVING
+int proc_get_ps_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	u8 ips_mode = pwrpriv->ips_mode;
+	u8 lps_mode = pwrpriv->power_mgnt;
+	u8 lps_level = pwrpriv->lps_level;
+	char *str = "";
+
+	RTW_PRINT_SEL(m, "======Power Saving Info:======\n");
+	RTW_PRINT_SEL(m, "*IPS:\n");
+
+	if (ips_mode == IPS_NORMAL) {
+#ifdef CONFIG_FWLPS_IN_IPS
+		str = "FW_LPS_IN_IPS";
+#else
+		str = "Card Disable";
+#endif
+	} else if (ips_mode == IPS_NONE)
+		str = "NO IPS";
+	else if (ips_mode == IPS_LEVEL_2)
 		str = "IPS_LEVEL_2";
-	} else {
+	else
 		str = "invalid ips_mode";
+
+	RTW_PRINT_SEL(m, " IPS mode: %s\n", str);
+	RTW_PRINT_SEL(m, " IPS enter count:%d, IPS leave count:%d\n",
+		      pwrpriv->ips_enter_cnts, pwrpriv->ips_leave_cnts);
+	RTW_PRINT_SEL(m, "------------------------------\n");
+	RTW_PRINT_SEL(m, "*LPS:\n");
+
+	if (lps_mode == PS_MODE_ACTIVE)
+		str = "NO LPS";
+	else if (lps_mode == PS_MODE_MIN)
+		str = "MIN";
+	else if (lps_mode == PS_MODE_MAX)
+		str = "MAX";
+	else if (lps_mode == PS_MODE_DTIM)
+		str = "DTIM";
+	else
+		sprintf(str, "%d", lps_mode);
+
+	RTW_PRINT_SEL(m, " LPS mode: %s\n", str);
+
+	if (pwrpriv->dtim != 0)
+		RTW_PRINT_SEL(m, " DTIM: %d\n", pwrpriv->dtim);
+	RTW_PRINT_SEL(m, " LPS enter count:%d, LPS leave count:%d\n",
+		      pwrpriv->lps_enter_cnts, pwrpriv->lps_leave_cnts);
+
+	if (lps_level == LPS_LCLK)
+		str = "LPS_LCLK";
+	else if  (lps_level == LPS_PG)
+		str = "LPS_PG";
+	else
+		str = "LPS_NORMAL";
+	RTW_PRINT_SEL(m, " LPS level: %s\n", str);
+
+	RTW_PRINT_SEL(m, "=============================\n");
+	return 0;
+}
+
+#ifdef CONFIG_WMMPS_STA	
+int proc_get_wmmps_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	char *uapsd_max_sp_str="";
+
+	if (pregpriv){
+		switch(pregpriv->uapsd_max_sp_len) {
+			case 0:
+				uapsd_max_sp_str = "NO_LIMIT";
+				break;
+			case 1:
+				uapsd_max_sp_str = "TWO_MSDU";
+				break;
+			case 2:
+				uapsd_max_sp_str = "FOUR_MSDU";
+				break;
+			case 3:
+				uapsd_max_sp_str = "SIX_MSDU";
+				break;
+			default:
+				uapsd_max_sp_str = "UNSPECIFIED";
+				break;
+		}
+
+		RTW_PRINT_SEL(m, "====== WMMPS_STA Info:======\n");
+		RTW_PRINT_SEL(m, "uapsd_max_sp_len=0x%02x (%s)\n", pregpriv->uapsd_max_sp_len, uapsd_max_sp_str);
+		RTW_PRINT_SEL(m, "uapsd_ac_enable=0x%02x\n", pregpriv->uapsd_ac_enable);
+		RTW_PRINT_SEL(m, "BIT0 - AC_VO UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_VO) ? "Enabled" : "Disabled");
+		RTW_PRINT_SEL(m, "BIT1 - AC_VI UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_VI) ? "Enabled" : "Disabled");
+		RTW_PRINT_SEL(m, "BIT2 - AC_BK UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_BK) ? "Enabled" : "Disabled");
+		RTW_PRINT_SEL(m, "BIT3 - AC_BE UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_BE) ? "Enabled" : "Disabled");
+		RTW_PRINT_SEL(m, "============================\n");
+	}
+
+	return 0;
+}
+
+ssize_t proc_set_wmmps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	char tmp[32];
+	u8 uapsd_ac_setting;
+	u8 uapsd_max_sp_len_setting;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhx", &uapsd_max_sp_len_setting, &uapsd_ac_setting);
+		
+		if (pregpriv) {
+			if (num >= 1){	
+				pregpriv->uapsd_max_sp_len = uapsd_max_sp_len_setting;
+				RTW_INFO("uapsd_max_sp_len = %d\n", pregpriv->uapsd_max_sp_len);
+			}
+
+			if (num >= 2){
+				pregpriv->uapsd_ac_enable = uapsd_ac_setting;
+				RTW_INFO("uapsd_ac_enable = 0x%02x\n", pregpriv->uapsd_ac_enable);
+			}
+		}	
+	}
+
+	return count;
+}
+#endif /* CONFIG_WMMPS_STA */
+#endif /* CONFIG_POWER_SAVING */
+
+#ifdef CONFIG_TDLS
+int proc_get_tdls_enable(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv *pregpriv = &padapter->registrypriv;
+
+	if (pregpriv)
+		RTW_PRINT_SEL(m, "TDLS is %s !\n", (rtw_is_tdls_enabled(padapter) == _TRUE) ? "enabled" : "disabled");
+
+	return 0;
+}
+
+ssize_t proc_set_tdls_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	char tmp[32];
+	u32 en_tdls = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d ", &en_tdls);
+
+		if (pregpriv) {
+			if (en_tdls > 0)
+				rtw_enable_tdls_func(padapter);
+			else
+				rtw_disable_tdls_func(padapter, _TRUE);
+		}
+	}
+
+	return count;
+}
+
+static int proc_tdls_display_tdls_function_info(struct seq_file *m)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
+	u8 SpaceBtwnItemAndValueTmp = 0;
+	BOOLEAN FirstMatchFound = _FALSE;
+	int j = 0;
+
+	RTW_PRINT_SEL(m, "============[TDLS Function Info]============\n");
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Enable", (rtw_is_tdls_enabled(padapter) == _TRUE) ? "_TRUE" : "_FALSE");
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Driver Setup", (ptdlsinfo->driver_setup == _TRUE) ? "_TRUE" : "_FALSE");
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Prohibited", (ptdlsinfo->ap_prohibited == _TRUE) ? "_TRUE" : "_FALSE");
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Channel Switch Prohibited", (ptdlsinfo->ch_switch_prohibited == _TRUE) ? "_TRUE" : "_FALSE");
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Link Established", (ptdlsinfo->link_established == _TRUE) ? "_TRUE" : "_FALSE");
+	RTW_PRINT_SEL(m, "%-*s = %d/%d\n", SpaceBtwnItemAndValue, "TDLS STA Num (Linked/Allowed)", ptdlsinfo->sta_cnt, MAX_ALLOWED_TDLS_STA_NUM);
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Allowed STA Num Reached", (ptdlsinfo->sta_maximum == _TRUE) ? "_TRUE" : "_FALSE");
+
+#ifdef CONFIG_TDLS_CH_SW
+	RTW_PRINT_SEL(m, "%-*s =", SpaceBtwnItemAndValue, "TDLS CH SW State");
+	if (ptdlsinfo->chsw_info.ch_sw_state == TDLS_STATE_NONE)
+		RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_STATE_NONE");
+	else {
+		for (j = 0; j < 32; j++) {
+			if (ptdlsinfo->chsw_info.ch_sw_state & BIT(j)) {
+				if (FirstMatchFound ==  _FALSE) {
+					SpaceBtwnItemAndValueTmp = 1;
+					FirstMatchFound = _TRUE;
+				} else
+					SpaceBtwnItemAndValueTmp = SpaceBtwnItemAndValue + 3;
+				switch (BIT(j)) {
+				case TDLS_INITIATOR_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_INITIATOR_STATE");
+					break;
+				case TDLS_RESPONDER_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_RESPONDER_STATE");
+					break;
+				case TDLS_LINKED_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_LINKED_STATE");
+					break;
+				case TDLS_WAIT_PTR_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_WAIT_PTR_STATE");
+					break;
+				case TDLS_ALIVE_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_ALIVE_STATE");
+					break;
+				case TDLS_CH_SWITCH_ON_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SWITCH_ON_STATE");
+					break;
+				case TDLS_PEER_AT_OFF_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_PEER_AT_OFF_STATE");
+					break;
+				case TDLS_CH_SW_INITIATOR_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SW_INITIATOR_STATE");
+					break;
+				case TDLS_WAIT_CH_RSP_STATE:
+					RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValue, " ", "TDLS_WAIT_CH_RSP_STATE");
+					break;
+				default:
+					RTW_PRINT_SEL(m, "%-*sBIT(%d)\n", SpaceBtwnItemAndValueTmp, " ", j);
+					break;
+				}
+			}
+		}
+	}
+
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS CH SW On", (ATOMIC_READ(&ptdlsinfo->chsw_info.chsw_on) == _TRUE) ? "_TRUE" : "_FALSE");
+	RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Off-Channel Num", ptdlsinfo->chsw_info.off_ch_num);
+	RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Channel Offset", ptdlsinfo->chsw_info.ch_offset);
+	RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Current Time", ptdlsinfo->chsw_info.cur_time);
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS CH SW Delay Switch Back", (ptdlsinfo->chsw_info.delay_switch_back == _TRUE) ? "_TRUE" : "_FALSE");
+	RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Dump Back", ptdlsinfo->chsw_info.dump_stack);
+#endif
+
+	RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Device Discovered", (ptdlsinfo->dev_discovered == _TRUE) ? "_TRUE" : "_FALSE");
+
+	return 0;
+}
+
+static int proc_tdls_display_network_info(struct seq_file *m)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+	int i = 0;
+	u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
+
+	/* Display the linked AP/GO info */
+	RTW_PRINT_SEL(m, "============[Associated AP/GO Info]============\n");
+
+	if ((pmlmepriv->fw_state & WIFI_STATION_STATE) && (pmlmepriv->fw_state & _FW_LINKED)) {
+		RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "BSSID", cur_network->network.Ssid.Ssid);
+		RTW_PRINT_SEL(m, "%-*s = "MAC_FMT"\n", SpaceBtwnItemAndValue, "Mac Address", MAC_ARG(cur_network->network.MacAddress));
+
+		RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Wireless Mode");
+		for (i = 0; i < 8; i++) {
+			if (pmlmeext->cur_wireless_mode & BIT(i)) {
+				switch (BIT(i)) {
+				case WIRELESS_11B:
+					RTW_PRINT_SEL(m, "%4s", "11B ");
+					break;
+				case WIRELESS_11G:
+					RTW_PRINT_SEL(m, "%4s", "11G ");
+					break;
+				case WIRELESS_11A:
+					RTW_PRINT_SEL(m, "%4s", "11A ");
+					break;
+				case WIRELESS_11_24N:
+					RTW_PRINT_SEL(m, "%7s", "11_24N ");
+					break;
+				case WIRELESS_11_5N:
+					RTW_PRINT_SEL(m, "%6s", "11_5N ");
+					break;
+				case WIRELESS_AUTO:
+					RTW_PRINT_SEL(m, "%5s", "AUTO ");
+					break;
+				case WIRELESS_11AC:
+					RTW_PRINT_SEL(m, "%5s", "11AC ");
+					break;
+				}
+			}
+		}
+		RTW_PRINT_SEL(m, "\n");
+
+		RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Privacy");
+		switch (padapter->securitypriv.dot11PrivacyAlgrthm) {
+		case _NO_PRIVACY_:
+			RTW_PRINT_SEL(m, "%s\n", "NO PRIVACY");
+			break;
+		case _WEP40_:
+			RTW_PRINT_SEL(m, "%s\n", "WEP 40");
+			break;
+		case _TKIP_:
+			RTW_PRINT_SEL(m, "%s\n", "TKIP");
+			break;
+		case _TKIP_WTMIC_:
+			RTW_PRINT_SEL(m, "%s\n", "TKIP WTMIC");
+			break;
+		case _AES_:
+			RTW_PRINT_SEL(m, "%s\n", "AES");
+			break;
+		case _WEP104_:
+			RTW_PRINT_SEL(m, "%s\n", "WEP 104");
+			break;
+		case _WEP_WPA_MIXED_:
+			RTW_PRINT_SEL(m, "%s\n", "WEP/WPA Mixed");
+			break;
+		case _SMS4_:
+			RTW_PRINT_SEL(m, "%s\n", "SMS4");
+			break;
+#ifdef CONFIG_IEEE80211W
+		case _BIP_:
+			RTW_PRINT_SEL(m, "%s\n", "BIP");
+			break;
+#endif /* CONFIG_IEEE80211W */
+		}
+
+		RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "Channel", pmlmeext->cur_channel);
+		RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Channel Offset");
+		switch (pmlmeext->cur_ch_offset) {
+		case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
+			RTW_PRINT_SEL(m, "%s\n", "N/A");
+			break;
+		case HAL_PRIME_CHNL_OFFSET_LOWER:
+			RTW_PRINT_SEL(m, "%s\n", "Lower");
+			break;
+		case HAL_PRIME_CHNL_OFFSET_UPPER:
+			RTW_PRINT_SEL(m, "%s\n", "Upper");
+			break;
+		}
+
+		RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Bandwidth Mode");
+		switch (pmlmeext->cur_bwmode) {
+		case CHANNEL_WIDTH_20:
+			RTW_PRINT_SEL(m, "%s\n", "20MHz");
+			break;
+		case CHANNEL_WIDTH_40:
+			RTW_PRINT_SEL(m, "%s\n", "40MHz");
+			break;
+		case CHANNEL_WIDTH_80:
+			RTW_PRINT_SEL(m, "%s\n", "80MHz");
+			break;
+		case CHANNEL_WIDTH_160:
+			RTW_PRINT_SEL(m, "%s\n", "160MHz");
+			break;
+		case CHANNEL_WIDTH_80_80:
+			RTW_PRINT_SEL(m, "%s\n", "80MHz + 80MHz");
+			break;
+		}
+	} else
+		RTW_PRINT_SEL(m, "No association with AP/GO exists!\n");
+
+	return 0;
+}
+
+static int proc_tdls_display_tdls_sta_info(struct seq_file *m)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct sta_info *psta;
+	int i = 0, j = 0;
+	_irqL irqL;
+	_list	*plist, *phead;
+	u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
+	u8 SpaceBtwnItemAndValueTmp = 0;
+	u8 NumOfTdlsStaToShow = 0;
+	BOOLEAN FirstMatchFound = _FALSE;
+
+	/* Search for TDLS sta info to display */
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+			plist = get_next(plist);
+			if (psta->tdls_sta_state != TDLS_STATE_NONE) {
+				/* We got one TDLS sta info to show */
+				RTW_PRINT_SEL(m, "============[TDLS Peer STA Info: STA %d]============\n", ++NumOfTdlsStaToShow);
+				RTW_PRINT_SEL(m, "%-*s = "MAC_FMT"\n", SpaceBtwnItemAndValue, "Mac Address", MAC_ARG(psta->cmn.mac_addr));
+				RTW_PRINT_SEL(m, "%-*s =", SpaceBtwnItemAndValue, "TDLS STA State");
+				SpaceBtwnItemAndValueTmp = 0;
+				FirstMatchFound = _FALSE;
+				for (j = 0; j < 32; j++) {
+					if (psta->tdls_sta_state & BIT(j)) {
+						if (FirstMatchFound ==  _FALSE) {
+							SpaceBtwnItemAndValueTmp = 1;
+							FirstMatchFound = _TRUE;
+						} else
+							SpaceBtwnItemAndValueTmp = SpaceBtwnItemAndValue + 3;
+						switch (BIT(j)) {
+						case TDLS_INITIATOR_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_INITIATOR_STATE");
+							break;
+						case TDLS_RESPONDER_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_RESPONDER_STATE");
+							break;
+						case TDLS_LINKED_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_LINKED_STATE");
+							break;
+						case TDLS_WAIT_PTR_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_WAIT_PTR_STATE");
+							break;
+						case TDLS_ALIVE_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_ALIVE_STATE");
+							break;
+						case TDLS_CH_SWITCH_ON_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SWITCH_ON_STATE");
+							break;
+						case TDLS_PEER_AT_OFF_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_PEER_AT_OFF_STATE");
+							break;
+						case TDLS_CH_SW_INITIATOR_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SW_INITIATOR_STATE");
+							break;
+						case TDLS_WAIT_CH_RSP_STATE:
+							RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValue, " ", "TDLS_WAIT_CH_RSP_STATE");
+							break;
+						default:
+							RTW_PRINT_SEL(m, "%-*sBIT(%d)\n", SpaceBtwnItemAndValueTmp, " ", j);
+							break;
+						}
+					}
+				}
+
+				RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Wireless Mode");
+				for (j = 0; j < 8; j++) {
+					if (psta->wireless_mode & BIT(j)) {
+						switch (BIT(j)) {
+						case WIRELESS_11B:
+							RTW_PRINT_SEL(m, "%4s", "11B ");
+							break;
+						case WIRELESS_11G:
+							RTW_PRINT_SEL(m, "%4s", "11G ");
+							break;
+						case WIRELESS_11A:
+							RTW_PRINT_SEL(m, "%4s", "11A ");
+							break;
+						case WIRELESS_11_24N:
+							RTW_PRINT_SEL(m, "%7s", "11_24N ");
+							break;
+						case WIRELESS_11_5N:
+							RTW_PRINT_SEL(m, "%6s", "11_5N ");
+							break;
+						case WIRELESS_AUTO:
+							RTW_PRINT_SEL(m, "%5s", "AUTO ");
+							break;
+						case WIRELESS_11AC:
+							RTW_PRINT_SEL(m, "%5s", "11AC ");
+							break;
+						}
+					}
+				}
+				RTW_PRINT_SEL(m, "\n");
+
+				RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Bandwidth Mode");
+				switch (psta->cmn.bw_mode) {
+				case CHANNEL_WIDTH_20:
+					RTW_PRINT_SEL(m, "%s\n", "20MHz");
+					break;
+				case CHANNEL_WIDTH_40:
+					RTW_PRINT_SEL(m, "%s\n", "40MHz");
+					break;
+				case CHANNEL_WIDTH_80:
+					RTW_PRINT_SEL(m, "%s\n", "80MHz");
+					break;
+				case CHANNEL_WIDTH_160:
+					RTW_PRINT_SEL(m, "%s\n", "160MHz");
+					break;
+				case CHANNEL_WIDTH_80_80:
+					RTW_PRINT_SEL(m, "%s\n", "80MHz + 80MHz");
+					break;
+				case CHANNEL_WIDTH_5:
+					RTW_PRINT_SEL(m, "%s\n", "5MHz");
+					break;
+				case CHANNEL_WIDTH_10:
+					RTW_PRINT_SEL(m, "%s\n", "10MHz");
+					break;
+				default:
+					RTW_PRINT_SEL(m, "(%d)%s\n", psta->cmn.bw_mode, "invalid");
+					break;
+				}
+
+				RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Privacy");
+				switch (psta->dot118021XPrivacy) {
+				case _NO_PRIVACY_:
+					RTW_PRINT_SEL(m, "%s\n", "NO PRIVACY");
+					break;
+				case _WEP40_:
+					RTW_PRINT_SEL(m, "%s\n", "WEP 40");
+					break;
+				case _TKIP_:
+					RTW_PRINT_SEL(m, "%s\n", "TKIP");
+					break;
+				case _TKIP_WTMIC_:
+					RTW_PRINT_SEL(m, "%s\n", "TKIP WTMIC");
+					break;
+				case _AES_:
+					RTW_PRINT_SEL(m, "%s\n", "AES");
+					break;
+				case _WEP104_:
+					RTW_PRINT_SEL(m, "%s\n", "WEP 104");
+					break;
+				case _WEP_WPA_MIXED_:
+					RTW_PRINT_SEL(m, "%s\n", "WEP/WPA Mixed");
+					break;
+				case _SMS4_:
+					RTW_PRINT_SEL(m, "%s\n", "SMS4");
+					break;
+#ifdef CONFIG_IEEE80211W
+				case _BIP_:
+					RTW_PRINT_SEL(m, "%s\n", "BIP");
+					break;
+#endif /* CONFIG_IEEE80211W */
+				}
+
+				RTW_PRINT_SEL(m, "%-*s = %d sec/%d sec\n", SpaceBtwnItemAndValue, "TPK Lifetime (Current/Expire)", psta->TPK_count, psta->TDLS_PeerKey_Lifetime);
+				RTW_PRINT_SEL(m, "%-*s = %llu\n", SpaceBtwnItemAndValue, "Tx Packets Over Direct Link", psta->sta_stats.tx_pkts);
+				RTW_PRINT_SEL(m, "%-*s = %llu\n", SpaceBtwnItemAndValue, "Rx Packets Over Direct Link", psta->sta_stats.rx_data_pkts);
+			}
+		}
+	}
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	if (NumOfTdlsStaToShow == 0) {
+		RTW_PRINT_SEL(m, "============[TDLS Peer STA Info]============\n");
+		RTW_PRINT_SEL(m, "No TDLS direct link exists!\n");
+	}
+
+	return 0;
+}
+
+int proc_get_tdls_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct sta_info *psta;
+	int i = 0, j = 0;
+	_irqL irqL;
+	_list	*plist, *phead;
+	u8 SpaceBtwnItemAndValue = 41;
+	u8 SpaceBtwnItemAndValueTmp = 0;
+	u8 NumOfTdlsStaToShow = 0;
+	BOOLEAN FirstMatchFound = _FALSE;
+
+	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
+		RTW_PRINT_SEL(m, "No tdls info can be shown since hal doesn't support tdls\n");
+		return 0;
+	}
+
+	proc_tdls_display_tdls_function_info(m);
+	proc_tdls_display_network_info(m);
+	proc_tdls_display_tdls_sta_info(m);
+
+	return 0;
+}
+#endif
+
+int proc_get_monitor(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+
+	if (WIFI_MONITOR_STATE == get_fwstate(pmlmepriv)) {
+		RTW_PRINT_SEL(m, "Monitor mode : Enable\n");
+
+		RTW_PRINT_SEL(m, "ch=%d, ch_offset=%d, bw=%d\n",
+			rtw_get_oper_ch(padapter), rtw_get_oper_choffset(padapter), rtw_get_oper_bw(padapter));
+	} else
+		RTW_PRINT_SEL(m, "Monitor mode : Disable\n");
+
+	return 0;
+}
+
+ssize_t proc_set_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	char tmp[32];
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 target_chan, target_offset, target_bw;
+
+	if (count < 3) {
+		RTW_INFO("argument size is less than 3\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%hhu %hhu %hhu", &target_chan, &target_offset, &target_bw);
+
+		if (num != 3) {
+			RTW_INFO("invalid write_reg parameter!\n");
+			return count;
+		}
+
+		padapter->mlmeextpriv.cur_channel  = target_chan;
+		set_channel_bwmode(padapter, target_chan, target_offset, target_bw);
+	}
+
+	return count;
+}
+#ifdef DBG_XMIT_BLOCK
+int proc_get_xmit_block(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_xmit_block(m, padapter);
+
+	return 0;
+}
+
+ssize_t proc_set_xmit_block(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 xb_mode, xb_reason;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx %hhx", &xb_mode, &xb_reason);
+
+		if (num != 2) {
+			RTW_INFO("invalid parameter!\n");
+			return count;
+		}
+
+		if (xb_mode == 0)/*set*/
+			rtw_set_xmit_block(padapter, xb_reason);
+		else if (xb_mode == 1)/*clear*/
+			rtw_clr_xmit_block(padapter, xb_reason);
+		else
+			RTW_INFO("invalid parameter!\n");
+	}
+
+	return count;
+}
+#endif
+
+#include <hal_data.h>
+int proc_get_efuse_map(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+	struct pwrctrl_priv *pwrctrlpriv  = adapter_to_pwrctl(padapter);
+	PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
+	int i, j;
+	u8 ips_mode = IPS_NUM;
+	u16 mapLen;
+
+	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
+	if (mapLen > EFUSE_MAX_MAP_LEN)
+		mapLen = EFUSE_MAX_MAP_LEN;
+
+	ips_mode = pwrctrlpriv->ips_mode;
+	rtw_pm_set_ips(padapter, IPS_NONE);
+
+	if (pHalData->efuse_file_status == EFUSE_FILE_LOADED) {
+		RTW_PRINT_SEL(m, "File eFuse Map loaded! file path:%s\nDriver eFuse Map From File\n", EFUSE_MAP_PATH);
+		if (pHalData->bautoload_fail_flag)
+			RTW_PRINT_SEL(m, "File Autoload fail!!!\n");
+	} else if (pHalData->efuse_file_status ==  EFUSE_FILE_FAILED) {
+		RTW_PRINT_SEL(m, "Open File eFuse Map Fail ! file path:%s\nDriver eFuse Map From Default\n", EFUSE_MAP_PATH);
+		if (pHalData->bautoload_fail_flag)
+			RTW_PRINT_SEL(m, "HW Autoload fail!!!\n");
+	} else {
+		RTW_PRINT_SEL(m, "Driver eFuse Map From HW\n");
+		if (pHalData->bautoload_fail_flag)
+			RTW_PRINT_SEL(m, "HW Autoload fail!!!\n");
+	}
+	for (i = 0; i < mapLen; i += 16) {
+		RTW_PRINT_SEL(m, "0x%02x\t", i);
+		for (j = 0; j < 8; j++)
+			RTW_PRINT_SEL(m, "%02X ", pHalData->efuse_eeprom_data[i + j]);
+		RTW_PRINT_SEL(m, "\t");
+		for (; j < 16; j++)
+			RTW_PRINT_SEL(m, "%02X ", pHalData->efuse_eeprom_data[i + j]);
+		RTW_PRINT_SEL(m, "\n");
+	}
+
+	if (rtw_efuse_map_read(padapter, 0, mapLen, pEfuseHal->fakeEfuseInitMap) == _FAIL) {
+		RTW_PRINT_SEL(m, "WARN - Read Realmap Failed\n");
+		return 0;
+	}
+
+	RTW_PRINT_SEL(m, "\n");
+	RTW_PRINT_SEL(m, "HW eFuse Map\n");
+	for (i = 0; i < mapLen; i += 16) {
+		RTW_PRINT_SEL(m, "0x%02x\t", i);
+		for (j = 0; j < 8; j++)
+			RTW_PRINT_SEL(m, "%02X ", pEfuseHal->fakeEfuseInitMap[i + j]);
+		RTW_PRINT_SEL(m, "\t");
+		for (; j < 16; j++)
+			RTW_PRINT_SEL(m, "%02X ", pEfuseHal->fakeEfuseInitMap[i + j]);
+		RTW_PRINT_SEL(m, "\n");
+	}
+
+	rtw_pm_set_ips(padapter, ips_mode);
+
+	return 0;
+}
+
+ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+#if 0
+	char tmp[256] = {0};
+	u32 addr, cnts;
+	u8 efuse_data;
+
+	int jj, kk;
+
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrctrlpriv  = adapter_to_pwrctl(padapter);
+	u8 ips_mode = IPS_NUM;
+
+	if (count < 3) {
+		RTW_INFO("argument size is less than 3\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%x %d %x", &addr, &cnts, &efuse_data);
+
+		if (num != 3) {
+			RTW_INFO("invalid write_reg parameter!\n");
+			return count;
+		}
+	}
+	ips_mode = pwrctrlpriv->ips_mode;
+	rtw_pm_set_ips(padapter, IPS_NONE);
+	if (rtw_efuse_map_write(padapter, addr, cnts, &efuse_data) == _FAIL)
+		RTW_INFO("WARN - rtw_efuse_map_write error!!\n");
+	rtw_pm_set_ips(padapter, ips_mode);
+#endif
+	return count;
+}
+
+#ifdef CONFIG_IEEE80211W
+ssize_t proc_set_tx_sa_query(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	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 dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *psta;
+	_list	*plist, *phead;
+	_irqL	 irqL;
+	char tmp[16];
+	u8	mac_addr[NUM_STA][ETH_ALEN];
+	u32 key_type;
+	u8 index;
+
+	if (count > 2) {
+		RTW_INFO("argument size is more than 2\n");
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {
+
+		int num = sscanf(tmp, "%x", &key_type);
+
+		if (num !=  1) {
+			RTW_INFO("invalid read_reg parameter!\n");
+			return count;
+		}
+		RTW_INFO("0: set sa query request , key_type=%d\n", key_type);
+	}
+
+	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+	    && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
+		RTW_INFO("STA:"MAC_FMT"\n", MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
+		/* TX unicast sa_query to AP */
+		issue_action_SA_Query(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, 0, (u8)key_type);
+	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
+		/* TX unicast sa_query to every client STA */
+		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+		for (index = 0; index < NUM_STA; index++) {
+			psta = NULL;
+
+			phead = &(pstapriv->sta_hash[index]);
+			plist = get_next(phead);
+
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+				plist = get_next(plist);
+				_rtw_memcpy(&mac_addr[psta->cmn.mac_id][0], psta->cmn.mac_addr, ETH_ALEN);
+			}
+		}
+		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+		for (index = 0; index < macid_ctl->num && index < NUM_STA; index++) {
+			if (rtw_macid_is_used(macid_ctl, index) && !rtw_macid_is_bmc(macid_ctl, index)) {
+				if (!_rtw_memcmp(get_my_bssid(&(pmlmeinfo->network)), &mac_addr[index][0], ETH_ALEN)
+				    && !IS_MCAST(&mac_addr[index][0])) {
+					issue_action_SA_Query(padapter, &mac_addr[index][0], 0, 0, (u8)key_type);
+					RTW_INFO("STA[%u]:"MAC_FMT"\n", index , MAC_ARG(&mac_addr[index][0]));
+				}
+			}
+		}
+	}
+
+	return count;
+}
+
+int proc_get_tx_sa_query(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "%s\n", __func__);
+	return 0;
+}
+
+ssize_t proc_set_tx_deauth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	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 dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *psta;
+	_list	*plist, *phead;
+	_irqL	 irqL;
+	char tmp[16];
+	u8	mac_addr[NUM_STA][ETH_ALEN];
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u32 key_type;
+	u8 index;
+
+
+	if (count > 2) {
+		RTW_INFO("argument size is more than 2\n");
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {
+
+		int num = sscanf(tmp, "%x", &key_type);
+
+		if (num !=  1) {
+			RTW_INFO("invalid read_reg parameter!\n");
+			return count;
+		}
+		RTW_INFO("key_type=%d\n", key_type);
+	}
+	if (key_type < 0 || key_type > 4)
+		return count;
+
+	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+	    && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+		if (key_type == 3) /* key_type 3 only for AP mode */
+			return count;
+		/* TX unicast deauth to AP */
+		issue_deauth_11w(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, (u8)key_type);
+	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+
+		if (key_type == 3)
+			issue_deauth_11w(padapter, bc_addr, 0, IEEE80211W_RIGHT_KEY);
+
+		/* TX unicast deauth to every client STA */
+		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+		for (index = 0; index < NUM_STA; index++) {
+			psta = NULL;
+
+			phead = &(pstapriv->sta_hash[index]);
+			plist = get_next(phead);
+
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+				plist = get_next(plist);
+				_rtw_memcpy(&mac_addr[psta->cmn.mac_id][0], psta->cmn.mac_addr, ETH_ALEN);
+			}
+		}
+		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+		for (index = 0; index < macid_ctl->num && index < NUM_STA; index++) {
+			if (rtw_macid_is_used(macid_ctl, index) && !rtw_macid_is_bmc(macid_ctl, index)) {
+				if (!_rtw_memcmp(get_my_bssid(&(pmlmeinfo->network)), &mac_addr[index][0], ETH_ALEN)) {
+					if (key_type != 3)
+						issue_deauth_11w(padapter, &mac_addr[index][0], 0, (u8)key_type);
+
+					psta = rtw_get_stainfo(pstapriv, &mac_addr[index][0]);
+					if (psta && key_type != IEEE80211W_WRONG_KEY && key_type != IEEE80211W_NO_KEY) {
+						u8 updated = _FALSE;
+
+						_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+						if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
+							rtw_list_delete(&psta->asoc_list);
+							pstapriv->asoc_list_cnt--;
+							updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
+
+						}
+						_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+						associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
+					}
+
+					RTW_INFO("STA[%u]:"MAC_FMT"\n", index , MAC_ARG(&mac_addr[index][0]));
+				}
+			}
+		}
+	}
+
+	return count;
+}
+
+int proc_get_tx_deauth(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "%s\n", __func__);
+	return 0;
+}
+
+ssize_t proc_set_tx_auth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	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 dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *psta;
+	_list	*plist, *phead;
+	_irqL	 irqL;
+	char tmp[16];
+	u8	mac_addr[NUM_STA][ETH_ALEN];
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u32 tx_auth;
+	u8 index;
+
+
+	if (count > 2) {
+		RTW_INFO("argument size is more than 2\n");
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {
+
+		int num = sscanf(tmp, "%x", &tx_auth);
+
+		if (num !=  1) {
+			RTW_INFO("invalid read_reg parameter!\n");
+			return count;
+		}
+		RTW_INFO("1: setnd auth, 2: send assoc request. tx_auth=%d\n", tx_auth);
+	}
+
+	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+	    && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+		if (tx_auth == 1) {
+			/* TX unicast auth to AP */
+			issue_auth(padapter, NULL, 0);
+		} else if (tx_auth == 2) {
+			/* TX unicast auth to AP */
+			issue_assocreq(padapter);
+		}
+	}
+
+	return count;
+}
+
+int proc_get_tx_auth(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "%s\n", __func__);
+	return 0;
+}
+#endif /* CONFIG_IEEE80211W */
+
+#ifdef CONFIG_MCC_MODE
+int proc_get_mcc_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_adapters_status(m, adapter_to_dvobj(adapter));
+	rtw_hal_dump_mcc_info(m, adapter_to_dvobj(adapter));
+	return 0;
+}
+
+int proc_get_mcc_policy_table(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_hal_dump_mcc_policy_table(m);
+	return 0;
+}
+
+ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[255];
+	u32 en_mcc = 0;
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+		_adapter *iface = NULL;
+		u8 i = 0;
+		int num = sscanf(tmp, "%u", &en_mcc);
+
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
+
+		RTW_INFO("%s: en_mcc = %d\n", __func__, en_mcc);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface)
+				continue;
+			iface->registrypriv.en_mcc = en_mcc;
+		}
+	}
+
+	return count;
+}
+
+ssize_t proc_set_mcc_duration(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[255];
+	u32 enable_runtime_duration = 0, mcc_duration = 0;
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u %u", &enable_runtime_duration, &mcc_duration);
+
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
+
+		if (num > 2) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters > 2\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
+
+		if (num >= 1) {
+			SET_MCC_RUNTIME_DURATION(padapter, enable_runtime_duration);
+			RTW_INFO("runtime duration:%s\n", enable_runtime_duration ? "enable":"disable");
+		}
+
+		if (num == 2) {
+			RTW_INFO("mcc duration:%d\n", mcc_duration);
+			rtw_set_mcc_duration_cmd(padapter, MCC_DURATION_DIRECET, mcc_duration);
+		}
+	}
+
+	return count;
+}
+
+ssize_t proc_set_mcc_single_tx_criteria(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[255];
+	u32 mcc_single_tx_criteria = 0;
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+		_adapter *iface = NULL;
+		u8 i = 0;
+		int num = sscanf(tmp, "%u", &mcc_single_tx_criteria);
+
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
+
+		RTW_INFO("%s: mcc_single_tx_criteria = %d\n", __func__, mcc_single_tx_criteria);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface)
+				continue;
+			iface->registrypriv.rtw_mcc_single_tx_cri = mcc_single_tx_criteria;
+		}
+
+
+	}
+
+	return count;
+}
+
+
+ssize_t proc_set_mcc_ap_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[255];
+	u32 mcc_ap_bw20_target_tp = 0;
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
 	}
 
-	DBG_871X_SEL_NL(m, " IPS mode: %s\n", str);
-	DBG_871X_SEL_NL(m, " IPS enter count:%d, IPS leave count:%d\n",
-			pwrpriv->ips_enter_cnts, pwrpriv->ips_leave_cnts);
-	DBG_871X_SEL_NL(m, "------------------------------\n");
-	DBG_871X_SEL_NL(m, "*LPS:\n");
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u", &mcc_ap_bw20_target_tp);
 
-	if (lps_mode == PS_MODE_ACTIVE) {
-		str = "NO LPS";
-	} else if (lps_mode == PS_MODE_MIN) {
-		str = "MIN";
-	} else if (lps_mode == PS_MODE_MAX) {
-		str = "MAX";
-	} else if (lps_mode == PS_MODE_DTIM) {
-		str = "DTIM";
-	} else {
-		sprintf(str, "%d", lps_mode);
-	}
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
 
-	DBG_871X_SEL_NL(m, " LPS mode: %s\n", str);
+		RTW_INFO("%s: mcc_ap_bw20_target_tp = %d\n", __func__, mcc_ap_bw20_target_tp);
 
-	if (pwrpriv->dtim != 0)
-		DBG_871X_SEL_NL(m, " DTIM: %d\n", pwrpriv->dtim);
-	DBG_871X_SEL_NL(m, " LPS enter count:%d, LPS leave count:%d\n",
-			pwrpriv->lps_enter_cnts, pwrpriv->lps_leave_cnts);
-	DBG_871X_SEL_NL(m, "=============================\n");
-	return 0;
+		padapter->registrypriv.rtw_mcc_ap_bw20_target_tx_tp = mcc_ap_bw20_target_tp;
+
+
+	}
+
+	return count;
 }
-#endif //CONFIG_POWER_SAVING
 
-#ifdef CONFIG_TDLS
-static int proc_tdls_display_tdls_function_info(struct seq_file *m)
+ssize_t proc_set_mcc_ap_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
+	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
-	u8 SpaceBtwnItemAndValueTmp = 0;
-	BOOLEAN FirstMatchFound = _FALSE;
-	int j= 0;
-	
-	DBG_871X_SEL_NL(m, "============[TDLS Function Info]============\n");
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Prohibited", (ptdlsinfo->ap_prohibited == _TRUE) ? "_TRUE" : "_FALSE");
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Channel Switch Prohibited", (ptdlsinfo->ch_switch_prohibited == _TRUE) ? "_TRUE" : "_FALSE");
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Link Established", (ptdlsinfo->link_established == _TRUE) ? "_TRUE" : "_FALSE");
-	DBG_871X_SEL_NL(m, "%-*s = %d/%d\n", SpaceBtwnItemAndValue, "TDLS STA Num (Linked/Allowed)", ptdlsinfo->sta_cnt, MAX_ALLOWED_TDLS_STA_NUM);
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Allowed STA Num Reached", (ptdlsinfo->sta_maximum == _TRUE) ? "_TRUE" : "_FALSE");
+	char tmp[255];
+	u32 mcc_ap_bw40_target_tp = 0;
 
-#ifdef CONFIG_TDLS_CH_SW
-	DBG_871X_SEL_NL(m, "%-*s =", SpaceBtwnItemAndValue, "TDLS CH SW State");
-	if (ptdlsinfo->chsw_info.ch_sw_state == TDLS_STATE_NONE)
-	{
-		DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_STATE_NONE");
-	}
-	else
-	{
-		for (j = 0; j < 32; j++)
-		{
-			if (ptdlsinfo->chsw_info.ch_sw_state & BIT(j))
-			{
-				if (FirstMatchFound ==  _FALSE)
-				{
-					SpaceBtwnItemAndValueTmp = 1;
-					FirstMatchFound = _TRUE;
-				}
-				else
-				{
-					SpaceBtwnItemAndValueTmp = SpaceBtwnItemAndValue + 3;
-				}
-				switch (BIT(j))
-				{
-					case TDLS_INITIATOR_STATE:
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_INITIATOR_STATE");
-						break;
-					case TDLS_RESPONDER_STATE:
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_RESPONDER_STATE");
-						break;
-					case TDLS_LINKED_STATE:
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_LINKED_STATE");
-						break;
-					case TDLS_WAIT_PTR_STATE:		
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_WAIT_PTR_STATE");
-						break;
-					case TDLS_ALIVE_STATE:		
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_ALIVE_STATE");
-						break;
-					case TDLS_CH_SWITCH_ON_STATE:	
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SWITCH_ON_STATE");
-						break;
-					case TDLS_PEER_AT_OFF_STATE:		
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_PEER_AT_OFF_STATE");
-						break;
-					case TDLS_CH_SW_INITIATOR_STATE:		
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SW_INITIATOR_STATE");
-						break;
-					case TDLS_WAIT_CH_RSP_STATE:		
-						DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValue, " ", "TDLS_WAIT_CH_RSP_STATE");
-						break;
-					default:
-						DBG_871X_SEL_NL(m, "%-*sBIT(%d)\n", SpaceBtwnItemAndValueTmp, " ", j);
-						break;
-				}
-			}
-		}
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
 	}
 
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS CH SW On", (ATOMIC_READ(&ptdlsinfo->chsw_info.chsw_on) == _TRUE) ? "_TRUE" : "_FALSE");
-	DBG_871X_SEL_NL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Off-Channel Num", ptdlsinfo->chsw_info.off_ch_num);
-	DBG_871X_SEL_NL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Channel Offset", ptdlsinfo->chsw_info.ch_offset);
-	DBG_871X_SEL_NL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Current Time", ptdlsinfo->chsw_info.cur_time);
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS CH SW Delay Switch Back", (ptdlsinfo->chsw_info.delay_switch_back == _TRUE) ? "_TRUE" : "_FALSE");
-	DBG_871X_SEL_NL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Dump Back", ptdlsinfo->chsw_info.dump_stack);
-#endif
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
 
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Device Discovered", (ptdlsinfo->dev_discovered == _TRUE) ? "_TRUE" : "_FALSE");
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Enable", (ptdlsinfo->tdls_enable == _TRUE) ? "_TRUE" : "_FALSE");
-	DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Driver Setup", (ptdlsinfo->driver_setup == _TRUE) ? "_TRUE" : "_FALSE");
-	
-	return 0;
-}
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
 
-static int proc_tdls_display_network_info(struct seq_file *m)
-{
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
-	int i = 0;
-	u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u", &mcc_ap_bw40_target_tp);
 
-	/* Display the linked AP/GO info */
-	DBG_871X_SEL_NL(m, "============[Associated AP/GO Info]============\n");
-	
-	if ((pmlmepriv->fw_state & WIFI_STATION_STATE) && (pmlmepriv->fw_state & _FW_LINKED))
-	{
-		DBG_871X_SEL_NL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "BSSID", cur_network->network.Ssid.Ssid);
-		DBG_871X_SEL_NL(m, "%-*s = "MAC_FMT"\n", SpaceBtwnItemAndValue, "Mac Address", MAC_ARG(cur_network->network.MacAddress));
-		
-		DBG_871X_SEL_NL(m, "%-*s = ", SpaceBtwnItemAndValue, "Wireless Mode");
-		for (i = 0; i < 8; i++)
-		{
-			if (pmlmeext->cur_wireless_mode & BIT(i))
-			{
-				switch (BIT(i))
-				{
-					case WIRELESS_11B: 
-						DBG_871X_SEL_NL(m, "%4s", "11B ");
-						break;
-					case WIRELESS_11G:
-						DBG_871X_SEL_NL(m, "%4s", "11G ");
-						break;
-					case WIRELESS_11A:
-						DBG_871X_SEL_NL(m, "%4s", "11A ");
-						break;
-					case WIRELESS_11_24N:
-						DBG_871X_SEL_NL(m, "%7s", "11_24N ");
-						break;
-					case WIRELESS_11_5N:
-						DBG_871X_SEL_NL(m, "%6s", "11_5N ");
-						break;
-					case WIRELESS_AUTO:
-						DBG_871X_SEL_NL(m, "%5s", "AUTO ");
-						break;
-					case WIRELESS_11AC:
-						DBG_871X_SEL_NL(m, "%5s", "11AC ");
-						break;
-				}
-			}
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
 		}
-		DBG_871X_SEL_NL(m, "\n");
 
-		DBG_871X_SEL_NL(m, "%-*s = ", SpaceBtwnItemAndValue, "Privacy");
-		switch (padapter->securitypriv.dot11PrivacyAlgrthm)
-		{
-			case _NO_PRIVACY_:
-				DBG_871X_SEL_NL(m, "%s\n", "NO PRIVACY");
-				break;
-			case _WEP40_:	
-				DBG_871X_SEL_NL(m, "%s\n", "WEP 40");
-				break;
-			case _TKIP_:
-				DBG_871X_SEL_NL(m, "%s\n", "TKIP");
-				break;
-			case _TKIP_WTMIC_:
-				DBG_871X_SEL_NL(m, "%s\n", "TKIP WTMIC");
-				break;
-			case _AES_:				
-				DBG_871X_SEL_NL(m, "%s\n", "AES");
-				break;
-			case _WEP104_:
-				DBG_871X_SEL_NL(m, "%s\n", "WEP 104");
-				break;
-			case _WEP_WPA_MIXED_:
-				DBG_871X_SEL_NL(m, "%s\n", "WEP/WPA Mixed");
-				break;
-			case _SMS4_:
-				DBG_871X_SEL_NL(m, "%s\n", "SMS4");
-				break;
-#ifdef CONFIG_IEEE80211W
-			case _BIP_:
-				DBG_871X_SEL_NL(m, "%s\n", "BIP");
-				break;	
-#endif //CONFIG_IEEE80211W
-		}
-		
-		DBG_871X_SEL_NL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "Channel", pmlmeext->cur_channel);
-		DBG_871X_SEL_NL(m, "%-*s = ", SpaceBtwnItemAndValue, "Channel Offset");
-		switch (pmlmeext->cur_ch_offset)
-		{
-			case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
-				DBG_871X_SEL_NL(m, "%s\n", "N/A");
-				break;
-			case HAL_PRIME_CHNL_OFFSET_LOWER:
-				DBG_871X_SEL_NL(m, "%s\n", "Lower");
-				break;
-			case HAL_PRIME_CHNL_OFFSET_UPPER:
-				DBG_871X_SEL_NL(m, "%s\n", "Upper");
-				break;
-		}
-		
-		DBG_871X_SEL_NL(m, "%-*s = ", SpaceBtwnItemAndValue, "Bandwidth Mode");
-		switch (pmlmeext->cur_bwmode)
-		{
-			case CHANNEL_WIDTH_20:
-				DBG_871X_SEL_NL(m, "%s\n", "20MHz");
-				break;
-			case CHANNEL_WIDTH_40:
-				DBG_871X_SEL_NL(m, "%s\n", "40MHz");
-				break;
-			case CHANNEL_WIDTH_80:
-				DBG_871X_SEL_NL(m, "%s\n", "80MHz");
-				break;
-			case CHANNEL_WIDTH_160:
-				DBG_871X_SEL_NL(m, "%s\n", "160MHz");
-				break;
-			case CHANNEL_WIDTH_80_80:
-				DBG_871X_SEL_NL(m, "%s\n", "80MHz + 80MHz");
-				break;
-		}
-	}
-	else
-	{
-		DBG_871X_SEL_NL(m, "No association with AP/GO exists!\n");
+		RTW_INFO("%s: mcc_ap_bw40_target_tp = %d\n", __func__, mcc_ap_bw40_target_tp);
+
+		padapter->registrypriv.rtw_mcc_ap_bw40_target_tx_tp = mcc_ap_bw40_target_tp;
+
+
 	}
 
-	return 0;
+	return count;
 }
 
-static int proc_tdls_display_tdls_sta_info(struct seq_file *m)
+ssize_t proc_set_mcc_ap_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
+	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct sta_info *psta;
-	int i = 0, j = 0;
-	_irqL irqL;
-	_list	*plist, *phead;
-	u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
-	u8 SpaceBtwnItemAndValueTmp = 0;
-	u8 NumOfTdlsStaToShow = 0;
-	BOOLEAN FirstMatchFound = _FALSE;
-	
-	/* Search for TDLS sta info to display */
-	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-	for (i=0; i< NUM_STA; i++)
-	{
-		phead = &(pstapriv->sta_hash[i]);
-		plist = get_next(phead);	
-		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-		{
-				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
-				plist = get_next(plist);
-				if (psta->tdls_sta_state != TDLS_STATE_NONE)
-				{
-					/* We got one TDLS sta info to show */
-					DBG_871X_SEL_NL(m, "============[TDLS Peer STA Info: STA %d]============\n", ++NumOfTdlsStaToShow);
-					DBG_871X_SEL_NL(m, "%-*s = "MAC_FMT"\n", SpaceBtwnItemAndValue, "Mac Address", MAC_ARG(psta->hwaddr));
-					DBG_871X_SEL_NL(m, "%-*s =", SpaceBtwnItemAndValue, "TDLS STA State");
-					SpaceBtwnItemAndValueTmp = 0;
-					FirstMatchFound = _FALSE;
-					for (j = 0; j < 32; j++)
-					{
-						if (psta->tdls_sta_state & BIT(j))
-						{
-							if (FirstMatchFound ==  _FALSE)
-							{
-								SpaceBtwnItemAndValueTmp = 1;
-								FirstMatchFound = _TRUE;
-							}
-							else
-							{
-								SpaceBtwnItemAndValueTmp = SpaceBtwnItemAndValue + 3;
-							}
-							switch (BIT(j))
-							{
-								case TDLS_INITIATOR_STATE:
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_INITIATOR_STATE");
-									break;
-								case TDLS_RESPONDER_STATE:
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_RESPONDER_STATE");
-									break;
-								case TDLS_LINKED_STATE:
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_LINKED_STATE");
-									break;
-								case TDLS_WAIT_PTR_STATE:		
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_WAIT_PTR_STATE");
-									break;
-								case TDLS_ALIVE_STATE:		
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_ALIVE_STATE");
-									break;
-								case TDLS_CH_SWITCH_ON_STATE:	
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SWITCH_ON_STATE");
-									break;
-								case TDLS_PEER_AT_OFF_STATE:		
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_PEER_AT_OFF_STATE");
-									break;
-								case TDLS_CH_SW_INITIATOR_STATE:		
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SW_INITIATOR_STATE");
-									break;
-								case TDLS_WAIT_CH_RSP_STATE:		
-									DBG_871X_SEL_NL(m, "%-*s%s\n", SpaceBtwnItemAndValue, " ", "TDLS_WAIT_CH_RSP_STATE");
-									break;
-								default:
-									DBG_871X_SEL_NL(m, "%-*sBIT(%d)\n", SpaceBtwnItemAndValueTmp, " ", j);
-									break;
-							}
-						}
-					}
+	char tmp[255];
+	u32 mcc_ap_bw80_target_tp = 0;
 
-					DBG_871X_SEL_NL(m, "%-*s = ", SpaceBtwnItemAndValue, "Wireless Mode");
-					for (j = 0; j < 8; j++)
-					{
-						if (psta->wireless_mode & BIT(j))
-						{
-							switch (BIT(j))
-							{
-								case WIRELESS_11B: 
-									DBG_871X_SEL_NL(m, "%4s", "11B ");
-									break;
-								case WIRELESS_11G:
-									DBG_871X_SEL_NL(m, "%4s", "11G ");
-									break;
-								case WIRELESS_11A:
-									DBG_871X_SEL_NL(m, "%4s", "11A ");
-									break;
-								case WIRELESS_11_24N:
-									DBG_871X_SEL_NL(m, "%7s", "11_24N ");
-									break;
-								case WIRELESS_11_5N:
-									DBG_871X_SEL_NL(m, "%6s", "11_5N ");
-									break;
-								case WIRELESS_AUTO:
-									DBG_871X_SEL_NL(m, "%5s", "AUTO ");
-									break;
-								case WIRELESS_11AC:
-									DBG_871X_SEL_NL(m, "%5s", "11AC ");
-									break;
-							}
-						}
-					}
-					DBG_871X_SEL_NL(m, "\n");
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
 
-					DBG_871X_SEL_NL(m, "%-*s = ", SpaceBtwnItemAndValue, "Bandwidth Mode");
-					switch (psta->bw_mode)
-					{
-						case CHANNEL_WIDTH_20:
-							DBG_871X_SEL_NL(m, "%s\n", "20MHz");
-							break;
-						case CHANNEL_WIDTH_40:
-							DBG_871X_SEL_NL(m, "%s\n", "40MHz");
-							break;
-						case CHANNEL_WIDTH_80:
-							DBG_871X_SEL_NL(m, "%s\n", "80MHz");
-							break;
-						case CHANNEL_WIDTH_160:
-							DBG_871X_SEL_NL(m, "%s\n", "160MHz");
-							break;
-						case CHANNEL_WIDTH_80_80:
-							DBG_871X_SEL_NL(m, "%s\n", "80MHz + 80MHz");
-							break;
-					}
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
 
-					DBG_871X_SEL_NL(m, "%-*s = ", SpaceBtwnItemAndValue, "Privacy");
-					switch (psta->dot118021XPrivacy)
-					{
-						case _NO_PRIVACY_:
-							DBG_871X_SEL_NL(m, "%s\n", "NO PRIVACY");
-							break;
-						case _WEP40_:	
-							DBG_871X_SEL_NL(m, "%s\n", "WEP 40");
-							break;
-						case _TKIP_:
-							DBG_871X_SEL_NL(m, "%s\n", "TKIP");
-							break;
-						case _TKIP_WTMIC_:
-							DBG_871X_SEL_NL(m, "%s\n", "TKIP WTMIC");
-							break;
-						case _AES_:				
-							DBG_871X_SEL_NL(m, "%s\n", "AES");
-							break;
-						case _WEP104_:
-							DBG_871X_SEL_NL(m, "%s\n", "WEP 104");
-							break;
-						case _WEP_WPA_MIXED_:
-							DBG_871X_SEL_NL(m, "%s\n", "WEP/WPA Mixed");
-							break;
-						case _SMS4_:
-							DBG_871X_SEL_NL(m, "%s\n", "SMS4");
-							break;
-#ifdef CONFIG_IEEE80211W
-						case _BIP_:
-							DBG_871X_SEL_NL(m, "%s\n", "BIP");
-							break;
-#endif //CONFIG_IEEE80211W
-					}
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
 
-					DBG_871X_SEL_NL(m, "%-*s = %d sec/%d sec\n", SpaceBtwnItemAndValue, "TPK Lifetime (Current/Expire)", psta->TPK_count, psta->TDLS_PeerKey_Lifetime);
-					DBG_871X_SEL_NL(m, "%-*s = %llu\n", SpaceBtwnItemAndValue, "Tx Packets Over Direct Link", psta->sta_stats.tx_pkts);
-					DBG_871X_SEL_NL(m, "%-*s = %llu\n", SpaceBtwnItemAndValue, "Rx Packets Over Direct Link", psta->sta_stats.rx_data_pkts);
-				}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u", &mcc_ap_bw80_target_tp);
+
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
 		}
-	}
-	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-	if (NumOfTdlsStaToShow == 0)
-	{
-		DBG_871X_SEL_NL(m, "============[TDLS Peer STA Info]============\n");
-		DBG_871X_SEL_NL(m, "No TDLS direct link exists!\n");
+
+		RTW_INFO("%s: mcc_ap_bw80_target_tp = %d\n", __func__, mcc_ap_bw80_target_tp);
+
+		padapter->registrypriv.rtw_mcc_ap_bw80_target_tx_tp = mcc_ap_bw80_target_tp;
+
+
 	}
 
-	return 0;
+	return count;
 }
 
-int proc_get_tdls_info(struct seq_file *m, void *v)
+ssize_t proc_set_mcc_sta_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
+	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct sta_info *psta;
-	int i = 0, j = 0;
-	_irqL irqL;
-	_list	*plist, *phead;
-	u8 SpaceBtwnItemAndValue = 41;
-	u8 SpaceBtwnItemAndValueTmp = 0;
-	u8 NumOfTdlsStaToShow = 0;
-	BOOLEAN FirstMatchFound = _FALSE;
+	char tmp[255];
+	u32 mcc_sta_bw20_target_tp = 0;
 
-	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
-		DBG_871X_SEL_NL(m, "No tdls info can be shown since hal doesn't support tdls\n");
-		return 0;
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
 	}
 
-	proc_tdls_display_tdls_function_info(m);
-	proc_tdls_display_network_info(m);
-	proc_tdls_display_tdls_sta_info(m);	
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
 
-	return 0;
-}
-#endif
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
 
-int proc_get_monitor(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u", &mcc_sta_bw20_target_tp);
+
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
+
+		RTW_INFO("%s: mcc_sta_bw20_target_tp = %d\n", __func__, mcc_sta_bw20_target_tp);
+
+		padapter->registrypriv.rtw_mcc_sta_bw20_target_tx_tp = mcc_sta_bw20_target_tp;
 
-	if (WIFI_MONITOR_STATE == get_fwstate(pmlmepriv)) {
-		DBG_871X_SEL_NL(m, "Monitor mode : Enable\n");
 
-		DBG_871X_SEL_NL(m, "ch=%d, ch_offset=%d, bw=%d\n",
-						rtw_get_oper_ch(padapter), rtw_get_oper_choffset(padapter), rtw_get_oper_bw(padapter));
-	} else {
-		DBG_871X_SEL_NL(m, "Monitor mode : Disable\n");
 	}
 
-	return 0;
+	return count;
 }
 
-ssize_t proc_set_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_mcc_sta_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	char tmp[32];
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 target_chan, target_offset, target_bw;
+	char tmp[255];
+	u32 mcc_sta_bw40_target_tp = 0;
 
-	if (count < 3) {
-		DBG_871X("argument size is less than 3\n");
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
 		return -EFAULT;
 	}
 
 	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
 		rtw_warn_on(1);
 		return -EFAULT;
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		int num = sscanf(tmp, "%hhu %hhu %hhu", &target_chan, &target_offset, &target_bw);
+		int num = sscanf(tmp, "%u", &mcc_sta_bw40_target_tp);
 
-		if (num != 3) {
-			DBG_871X("invalid write_reg parameter!\n");
-			return count;
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
 		}
 
-		padapter->mlmeextpriv.cur_channel  = target_chan;
-		set_channel_bwmode(padapter, target_chan, target_offset, target_bw);
+		RTW_INFO("%s: mcc_sta_bw40_target_tp = %d\n", __func__, mcc_sta_bw40_target_tp);
+
+		padapter->registrypriv.rtw_mcc_sta_bw40_target_tx_tp = mcc_sta_bw40_target_tp;
+
+
 	}
 
 	return count;
 }
 
-#include <hal_data.h>
-int proc_get_efuse_map(struct seq_file *m, void *v)
+ssize_t proc_set_mcc_sta_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
+	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
-	struct pwrctrl_priv *pwrctrlpriv  = adapter_to_pwrctl(padapter);
-	PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
-	int i, j;
-	u8 ips_mode = IPS_NUM; 
-	int mapLen = EFUSE_MAP_SIZE;
+	char tmp[255];
+	u32 mcc_sta_bw80_target_tp = 0;
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u", &mcc_sta_bw80_target_tp);
+
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
+
+		RTW_INFO("%s: mcc_sta_bw80_target_tp = %d\n", __func__, mcc_sta_bw80_target_tp);
+
+		padapter->registrypriv.rtw_mcc_sta_bw80_target_tx_tp = mcc_sta_bw80_target_tp;
+
 
-	ips_mode = pwrctrlpriv->ips_mode;
-	rtw_pm_set_ips(padapter, IPS_NONE);
-	if (rtw_efuse_map_read(padapter, EFUSE_WIFI, mapLen, pEfuseHal->fakeEfuseInitMap) == _FAIL)
-		DBG_871X_SEL_NL(m, "WARN - Read Realmap Failed\n");	
-	
-	DBG_871X_SEL_NL(m, "\n");
-	for (i = 0; i < EFUSE_MAP_SIZE; i += 16) {
-		DBG_871X_SEL_NL(m, "0x%02x\t", i);
-		for (j = 0; j < 8; j++) 
-			DBG_871X_SEL_NL(m, "%02X ", pEfuseHal->fakeEfuseInitMap[i+j]);
-		
-		DBG_871X_SEL_NL(m, "\t");
-				
-		for (; j < 16; j++)
-			DBG_871X_SEL_NL(m, "%02X ", pEfuseHal->fakeEfuseInitMap[i+j]);
-		
-		DBG_871X_SEL_NL(m, "\n");
-				
 	}
-	rtw_pm_set_ips(padapter, ips_mode);
-	return 0;
+
+	return count;
 }
+#endif /* CONFIG_MCC_MODE */
 
-ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+int proc_get_ack_timeout(struct seq_file *m, void *v)
 {
-#if 0
-	char tmp[256] = {0};
-	u32 addr, cnts;
-	u8 efuse_data;
-	
-	int jj, kk;
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 ack_timeout_val, ack_timeout_val_cck;
+
+	ack_timeout_val = rtw_read8(padapter, REG_ACKTO);
+
+#ifdef CONFIG_RTL8821C
+	ack_timeout_val_cck = rtw_read8(padapter, REG_ACKTO_CCK_8821C);
+	RTW_PRINT_SEL(m, "Current CCK packet ACK Timeout = %d us (0x%x).\n", ack_timeout_val_cck, ack_timeout_val_cck);
+	RTW_PRINT_SEL(m, "Current non-CCK packet ACK Timeout = %d us (0x%x).\n", ack_timeout_val, ack_timeout_val);
+#else
+	RTW_PRINT_SEL(m, "Current ACK Timeout = %d us (0x%x).\n", ack_timeout_val, ack_timeout_val);
+#endif
 
+	return 0;
+}
+
+ssize_t proc_set_ack_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct pwrctrl_priv *pwrctrlpriv  = adapter_to_pwrctl(padapter);
-	u8 ips_mode = IPS_NUM;
-	
-	if (count < 3) {
-		DBG_871X("argument size is less than 3\n");
-		return -EFAULT;
-	}
-	
+	char tmp[32];
+	u32 ack_timeout_ms, ack_timeout_ms_cck;
+
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
 		return -EFAULT;
 	}
-	
+
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u %u", &ack_timeout_ms, &ack_timeout_ms_cck);
 
-		int num = sscanf(tmp, "%x %d %x", &addr, &cnts, &efuse_data);
-	
-		if (num != 3) {
-			DBG_871X("invalid write_reg parameter!\n");
-			return count;
+#ifdef CONFIG_RTL8821C
+		if (num < 2) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 2\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
+#else
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
 		}
+#endif
+		/* This register sets the Ack time out value after Tx unicast packet. It is in units of us. */
+		rtw_write8(padapter, REG_ACKTO, (u8)ack_timeout_ms);
+
+#ifdef CONFIG_RTL8821C
+		/* This register sets the Ack time out value after Tx unicast CCK packet. It is in units of us. */
+		rtw_write8(padapter, REG_ACKTO_CCK_8821C, (u8)ack_timeout_ms_cck);
+		RTW_INFO("Set CCK packet ACK Timeout to %d us.\n", ack_timeout_ms_cck);
+		RTW_INFO("Set non-CCK packet ACK Timeout to %d us.\n", ack_timeout_ms);
+#else
+		RTW_INFO("Set ACK Timeout to %d us.\n", ack_timeout_ms);
+#endif
 	}
-	ips_mode = pwrctrlpriv->ips_mode;
-	rtw_pm_set_ips(padapter, IPS_NONE);
-	if (rtw_efuse_map_write(padapter, addr, cnts, &efuse_data) == _FAIL) 
-		DBG_871X("WARN - rtw_efuse_map_write error!!\n");		
-	rtw_pm_set_ips(padapter, ips_mode);
-#endif	
+
 	return count;
 }
 
-#ifdef CONFIG_IEEE80211W
-ssize_t proc_set_tx_sa_query(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	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 dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	struct sta_info *psta;
-	_list	*plist, *phead;
-	_irqL	 irqL;
-	char tmp[16];
-	u8	mac_addr[NUM_STA][ETH_ALEN];
-	u32 key_type;
-	u8 index;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
+	char tmp[32];
+	u32 iqk_offload_enable = 0, ch_switch_offload_enable = 0;
 
-	if (count > 2) {
-		DBG_871X("argument size is more than 2\n");
+	if (buffer == NULL) {
+		RTW_INFO("input buffer is NULL!\n");
 		return -EFAULT;
-	}	
-
-	if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {		
+	}
 
-		int num = sscanf(tmp, "%x", &key_type);
+	if (count < 1) {
+		RTW_INFO("input length is 0!\n");
+		return -EFAULT;
+	}
 
-		if (num !=  1) {
-			DBG_871X("invalid read_reg parameter!\n");
-			return count;
-		}
-		DBG_871X("0: set sa query request , key_type=%d\n", key_type);
+	if (count > sizeof(tmp)) {
+		RTW_INFO("input length is too large\n");
+		rtw_warn_on(1);
+		return -EFAULT;
 	}
-	
-	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-		&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && padapter->securitypriv.binstallBIPkey == _TRUE) {
-		DBG_871X("STA:"MAC_FMT"\n", MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
-		/* TX unicast sa_query to AP */
-		issue_action_SA_Query(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, 0, (u8)key_type);
-	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE && padapter->securitypriv.binstallBIPkey == _TRUE) {
-		/* TX unicast sa_query to every client STA */
-		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-		for (index = 0; index < NUM_STA; index++) {
-			psta = NULL;
-			
-			phead = &(pstapriv->sta_hash[index]);
-			plist = get_next(phead);
-			
-			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
-				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
-				plist = get_next(plist);
-				_rtw_memcpy(&mac_addr[psta->mac_id][0], psta->hwaddr, ETH_ALEN);
-			}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%d %d", &iqk_offload_enable, &ch_switch_offload_enable);
+
+		if (num < 2) {
+			RTW_INFO("input parameters < 1\n");
+			return -EINVAL;
 		}
-		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-		
-		for (index = 0; index < macid_ctl->num && index < NUM_STA; index++) {
-			if (rtw_macid_is_used(macid_ctl, index) && !rtw_macid_is_bmc(macid_ctl, index)) {
-				if (!_rtw_memcmp(get_my_bssid(&(pmlmeinfo->network)), &mac_addr[index][0], ETH_ALEN) 
-					&& !IS_MCAST(&mac_addr[index][0])) {
-					issue_action_SA_Query(padapter, &mac_addr[index][0], 0, 0, (u8)key_type);
-					DBG_871X("STA[%u]:"MAC_FMT"\n", index , MAC_ARG(&mac_addr[index][0]));
-				}
-			}
+
+		if (hal->RegIQKFWOffload != iqk_offload_enable) {
+			hal->RegIQKFWOffload = iqk_offload_enable;
+			rtw_hal_update_iqk_fw_offload_cap(pri_adapter);
 		}
+
+		if (hal->ch_switch_offload != ch_switch_offload_enable)
+			hal->ch_switch_offload = ch_switch_offload_enable;
 	}
-	
+
 	return count;
 }
 
-int proc_get_tx_sa_query(struct seq_file *m, void *v)
+int proc_get_fw_offload(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
+
+
+	RTW_PRINT_SEL(m, "IQK FW offload:%s\n", hal->RegIQKFWOffload?"enable":"disable");
+	RTW_PRINT_SEL(m, "Channel switch FW offload:%s\n", hal->ch_switch_offload?"enable":"disable");
+	return 0;
+}
+
+#ifdef CONFIG_DBG_RF_CAL
+int proc_get_iqk_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
-	DBG_871X_SEL_NL(m, "%s\n", __func__);
+
 	return 0;
 }
 
-ssize_t proc_set_tx_deauth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_iqk(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	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 dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	struct sta_info *psta;
-	_list	*plist, *phead;
-	_irqL	 irqL;
-	char tmp[16];
-	u8	mac_addr[NUM_STA][ETH_ALEN];
-	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-	u32 key_type;
-	u8 index;
-	
+	char tmp[32];
+	u32 recovery, clear, segment;
 
-	if (count > 2) {
-		DBG_871X("argument size is more than 2\n");
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
 		return -EFAULT;
-	}	
+	}
 
-	if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {		
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%x", &key_type);
+		int num = sscanf(tmp, "%d %d %d", &recovery, &clear, &segment);
 
-		if (num !=  1) {
-			DBG_871X("invalid read_reg parameter!\n");
-			return count;
-		}
-		DBG_871X("key_type=%d\n", key_type);
-	}
-	if (key_type < 0 || key_type > 4)
-		return count;
-	
-	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-		&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
-		if (key_type == 3) /* key_type 3 only for AP mode */
-			return count;
-		/* TX unicast deauth to AP */
-		issue_deauth_11w(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, (u8)key_type);
-	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
-		
-		if (key_type == 3)
-			issue_deauth_11w(padapter, bc_addr, 0, IEEE80211W_RIGHT_KEY);
-		
-		/* TX unicast deauth to every client STA */
-		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-		for (index = 0; index < NUM_STA; index++) {
-			psta = NULL;
-			
-			phead = &(pstapriv->sta_hash[index]);
-			plist = get_next(phead);
-			
-			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
-				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
-				plist = get_next(plist);
-				_rtw_memcpy(&mac_addr[psta->mac_id][0], psta->hwaddr, ETH_ALEN);
-			}
-		}
-		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-		
-		for (index = 0; index < macid_ctl->num && index < NUM_STA; index++) {
-			if (rtw_macid_is_used(macid_ctl, index) && !rtw_macid_is_bmc(macid_ctl, index)) {
-				if (!_rtw_memcmp(get_my_bssid(&(pmlmeinfo->network)), &mac_addr[index][0], ETH_ALEN)) {
-					if (key_type != 3)
-						issue_deauth_11w(padapter, &mac_addr[index][0], 0, (u8)key_type);
-					
-					psta = rtw_get_stainfo(pstapriv, &mac_addr[index][0]);	
-					if (psta && key_type != IEEE80211W_WRONG_KEY && key_type != IEEE80211W_NO_KEY) {
-						u8 updated = _FALSE;
-					
-						_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-						if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {			
-							rtw_list_delete(&psta->asoc_list);
-							pstapriv->asoc_list_cnt--;
-							updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
-			
-						}
-						_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-			
-						associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
-					}
-					
-					DBG_871X("STA[%u]:"MAC_FMT"\n", index , MAC_ARG(&mac_addr[index][0]));
-				}
-			}
-		}
+		rtw_hal_iqk_test(padapter, recovery, clear, segment);
 	}
-	
+
 	return count;
+
 }
 
-int proc_get_tx_deauth(struct seq_file *m, void *v)
+int proc_get_lck_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
-	DBG_871X_SEL_NL(m, "%s\n", __func__);
+
 	return 0;
 }
 
-ssize_t proc_set_tx_auth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_lck(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	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 dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	struct sta_info *psta;
-	_list	*plist, *phead;
-	_irqL	 irqL;
-	char tmp[16];
-	u8	mac_addr[NUM_STA][ETH_ALEN];
-	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-	u32 tx_auth;
-	u8 index;
-	
+	char tmp[32];
+	u32 trigger;
 
-	if (count > 2) {
-		DBG_871X("argument size is more than 2\n");
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
 		return -EFAULT;
-	}	
+	}
 
-	if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {		
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%x", &tx_auth);
+		int num = sscanf(tmp, "%d", &trigger);
 
-		if (num !=  1) {
-			DBG_871X("invalid read_reg parameter!\n");
-			return count;
-		}
-		DBG_871X("1: setnd auth, 2: send assoc request. tx_auth=%d\n", tx_auth);
+		rtw_hal_lck_test(padapter);
 	}
-	
-	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-		&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
-		if (tx_auth == 1) {
-			/* TX unicast auth to AP */
-			issue_auth(padapter, NULL, 0);
-		} else if (tx_auth == 2) {
-			/* TX unicast auth to AP */
-			issue_assocreq(padapter);
-		}
-	} 
-	
+
 	return count;
 }
+#endif /* CONFIG_DBG_RF_CAL */
 
-int proc_get_tx_auth(struct seq_file *m, void *v)
+#endif /* CONFIG_PROC_DEBUG */
+#define RTW_BUFDUMP_BSIZE		16
+#if 1
+inline void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
+					bool _idx_show, const u8 *_hexdata, int _hexdatalen)
 {
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
-	DBG_871X_SEL_NL(m, "%s\n", __func__);
-	return 0;
+	int __i;
+	u8 *ptr = (u8 *)_hexdata;
+
+	if (_loglevel <= rtw_drv_log_level) {
+		if (_titlestring) {
+			if (sel == RTW_DBGDUMP)
+				RTW_PRINT("");
+			_RTW_PRINT_SEL(sel, "%s", _titlestring);
+			if (_hexdatalen >= RTW_BUFDUMP_BSIZE)
+				_RTW_PRINT_SEL(sel, "\n");
+		}
+
+		for (__i = 0; __i < _hexdatalen; __i++) {
+			if (((__i % RTW_BUFDUMP_BSIZE) == 0) && (_hexdatalen >= RTW_BUFDUMP_BSIZE)) {
+				if (sel == RTW_DBGDUMP)
+					RTW_PRINT("");
+				if (_idx_show)
+					_RTW_PRINT_SEL(sel, "0x%03X: ", __i);
+			}
+			_RTW_PRINT_SEL(sel, "%02X%s", ptr[__i], (((__i + 1) % 4) == 0) ? "  " : " ");
+			if ((__i + 1 < _hexdatalen) && ((__i + 1) % RTW_BUFDUMP_BSIZE) == 0)
+				_RTW_PRINT_SEL(sel, "\n");
+		}
+		_RTW_PRINT_SEL(sel, "\n");
+	}
 }
-#endif /* CONFIG_IEEE80211W */
+#else
+inline void _RTW_STR_DUMP_SEL(void *sel, char *str_out)
+{
+	if (sel == RTW_DBGDUMP)
+		_dbgdump("%s\n", str_out);
+	#if defined(_seqdump)
+	else
+		_seqdump(sel, "%s\n", str_out);
+	#endif /*_seqdump*/
+}
+inline void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
+					bool _idx_show, u8 *_hexdata, int _hexdatalen)
+{
+	int __i, len;
+	int __j, idx;
+	int block_num, remain_byte;
+	char str_out[128] = {'\0'};
+	char str_val[32] = {'\0'};
+	char *p = NULL;
+	u8 *ptr = (u8 *)_hexdata;
+
+	if (_loglevel <= rtw_drv_log_level) {
+		/*dump title*/
+		p = &str_out[0];
+		if (_titlestring) {
+			if (sel == RTW_DBGDUMP) {
+				len = snprintf(str_val, sizeof(str_val), "%s", DRIVER_PREFIX);
+				strncpy(p, str_val, len);
+				p += len;
+			}
+			len = snprintf(str_val, sizeof(str_val), "%s", _titlestring);
+			strncpy(p, str_val, len);
+			p += len;
+		}
+		if (p != &str_out[0]) {
+			_RTW_STR_DUMP_SEL(sel, str_out);
+			_rtw_memset(&str_out, '\0', sizeof(str_out));
+		}
 
-#endif /* CONFIG_PROC_DEBUG */
+		/*dump buffer*/
+		block_num = _hexdatalen / RTW_BUFDUMP_BSIZE;
+		remain_byte = _hexdatalen % RTW_BUFDUMP_BSIZE;
+		for (__i = 0; __i < block_num; __i++) {
+			p = &str_out[0];
+			if (sel == RTW_DBGDUMP) {
+				len = snprintf(str_val, sizeof(str_val), "%s", DRIVER_PREFIX);
+				strncpy(p, str_val, len);
+				p += len;
+			}
+			if (_idx_show) {
+				len = snprintf(str_val, sizeof(str_val), "0x%03X: ", __i * RTW_BUFDUMP_BSIZE);
+				strncpy(p, str_val, len);
+				p += len;
+			}
+			for (__j =0; __j < RTW_BUFDUMP_BSIZE; __j++) {
+				idx = __i * RTW_BUFDUMP_BSIZE + __j;
+				len = snprintf(str_val, sizeof(str_val), "%02X%s", ptr[idx], (((__j + 1) % 4) == 0) ? "  " : " ");
+				strncpy(p, str_val, len);
+				p += len;
+			}
+			_RTW_STR_DUMP_SEL(sel, str_out);
+			_rtw_memset(&str_out, '\0', sizeof(str_out));
+		}
+
+		p = &str_out[0];
+		if ((sel == RTW_DBGDUMP) && remain_byte) {
+			len = snprintf(str_val, sizeof(str_val), "%s", DRIVER_PREFIX);
+			strncpy(p, str_val, len);
+			p += len;
+		}
+		if (_idx_show && remain_byte) {
+			len = snprintf(str_val, sizeof(str_val), "0x%03X: ", block_num * RTW_BUFDUMP_BSIZE);
+			strncpy(p, str_val, len);
+			p += len;
+		}
+		for (__i = 0; __i < remain_byte; __i++) {
+			idx = block_num * RTW_BUFDUMP_BSIZE + __i;
+			len = snprintf(str_val, sizeof(str_val), "%02X%s", ptr[idx], (((__i + 1) % 4) == 0) ? "  " : " ");
+			strncpy(p, str_val, len);
+			p += len;
+		}
+		_RTW_STR_DUMP_SEL(sel, str_out);
+	}
+}
 
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_eeprom.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_eeprom.c
index e83c090ac746..dde4b639d74a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_eeprom.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_eeprom.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,45 +12,34 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_EEPROM_C_
 
 #include <drv_conf.h>
 #include <osdep_service.h>
 #include <drv_types.h>
 
-void up_clk(_adapter*	padapter,	 u16 *x)
+void up_clk(_adapter	*padapter,	 u16 *x)
 {
-_func_enter_;
 	*x = *x | _EESK;
 	rtw_write8(padapter, EE_9346CR, (u8)*x);
 	rtw_udelay_os(CLOCK_RATE);
 
-_func_exit_;
-	
+
 }
 
-void down_clk(_adapter *	padapter, u16 *x	)
+void down_clk(_adapter	*padapter, u16 *x)
 {
-_func_enter_;
 	*x = *x & ~_EESK;
 	rtw_write8(padapter, EE_9346CR, (u8)*x);
 	rtw_udelay_os(CLOCK_RATE);
-_func_exit_;	
 }
 
-void shift_out_bits(_adapter * padapter, u16 data, u16 count)
+void shift_out_bits(_adapter *padapter, u16 data, u16 count)
 {
-	u16 x,mask;
-_func_enter_;
+	u16 x, mask;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 	mask = 0x01 << (count - 1);
@@ -57,13 +47,11 @@ _func_enter_;
 
 	x &= ~(_EEDO | _EEDI);
 
-	do
-	{
+	do {
 		x &= ~_EEDI;
-		if(data & mask)
+		if (data & mask)
 			x |= _EEDI;
 		if (rtw_is_surprise_removed(padapter)) {
-			RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 			goto out;
 		}
 		rtw_write8(padapter, EE_9346CR, (u8)x);
@@ -71,137 +59,118 @@ _func_enter_;
 		up_clk(padapter, &x);
 		down_clk(padapter, &x);
 		mask = mask >> 1;
-	} while(mask);
+	} while (mask);
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 	x &= ~_EEDI;
 	rtw_write8(padapter, EE_9346CR, (u8)x);
-out:	
-_func_exit_;		
+out:
+	return;
 }
 
-u16 shift_in_bits (_adapter * padapter)
+u16 shift_in_bits(_adapter *padapter)
 {
-	u16 x,d=0,i;
-_func_enter_;	
+	u16 x, d = 0, i;
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 	x = rtw_read8(padapter, EE_9346CR);
 
-	x &= ~( _EEDO | _EEDI);
+	x &= ~(_EEDO | _EEDI);
 	d = 0;
 
-	for(i=0; i<16; i++)
-	{
+	for (i = 0; i < 16; i++) {
 		d = d << 1;
 		up_clk(padapter, &x);
-	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
-		goto out;
-	}
+		if (rtw_is_surprise_removed(padapter)) {
+			goto out;
+		}
 		x = rtw_read8(padapter, EE_9346CR);
 
 		x &= ~(_EEDI);
-		if(x & _EEDO)
-		d |= 1;
+		if (x & _EEDO)
+			d |= 1;
 
 		down_clk(padapter, &x);
 	}
-out:	
-_func_exit_;		
+out:
 
 	return d;
 }
 
-void standby(_adapter *	padapter	)
+void standby(_adapter	*padapter)
 {
 	u8   x;
-_func_enter_;	
 	x = rtw_read8(padapter, EE_9346CR);
 
 	x &= ~(_EECS | _EESK);
-	rtw_write8(padapter, EE_9346CR,x);
+	rtw_write8(padapter, EE_9346CR, x);
 
 	rtw_udelay_os(CLOCK_RATE);
 	x |= _EECS;
 	rtw_write8(padapter, EE_9346CR, x);
 	rtw_udelay_os(CLOCK_RATE);
-_func_exit_;		
 }
 
-u16 wait_eeprom_cmd_done(_adapter* padapter)
+u16 wait_eeprom_cmd_done(_adapter *padapter)
 {
-	u8 	x;
-	u16	i,res=_FALSE;
-_func_enter_;	
-	standby(padapter );
-	for (i=0; i<200; i++) 
-	{
+	u8	x;
+	u16	i, res = _FALSE;
+	standby(padapter);
+	for (i = 0; i < 200; i++) {
 		x = rtw_read8(padapter, EE_9346CR);
-		if (x & _EEDO){
-			res=_TRUE;
+		if (x & _EEDO) {
+			res = _TRUE;
 			goto exit;
-			}
+		}
 		rtw_udelay_os(CLOCK_RATE);
 	}
-exit:	
-_func_exit_;			
+exit:
 	return res;
 }
 
-void eeprom_clean(_adapter * padapter)
+void eeprom_clean(_adapter *padapter)
 {
 	u16 x;
-_func_enter_;		
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 	x = rtw_read8(padapter, EE_9346CR);
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 	x &= ~(_EECS | _EEDI);
 	rtw_write8(padapter, EE_9346CR, (u8)x);
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 	up_clk(padapter, &x);
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 	down_clk(padapter, &x);
-out:	
-_func_exit_;			
+out:
+	return;
 }
 
-void eeprom_write16(_adapter * padapter, u16 reg, u16 data)
+void eeprom_write16(_adapter *padapter, u16 reg, u16 data)
 {
 	u8 x;
 #ifdef CONFIG_RTL8712
-	u8	tmp8_ori,tmp8_new,tmp8_clk_ori,tmp8_clk_new;
-	tmp8_ori=rtw_read8(padapter, 0x102502f1);
-	tmp8_new=tmp8_ori & 0xf7;
-	if(tmp8_ori != tmp8_new){	
+	u8	tmp8_ori, tmp8_new, tmp8_clk_ori, tmp8_clk_new;
+	tmp8_ori = rtw_read8(padapter, 0x102502f1);
+	tmp8_new = tmp8_ori & 0xf7;
+	if (tmp8_ori != tmp8_new) {
 		rtw_write8(padapter, 0x102502f1, tmp8_new);
-		RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x102502f1=====\n"));
 	}
-	tmp8_clk_ori=rtw_read8(padapter,0x10250003);
-	tmp8_clk_new=tmp8_clk_ori|0x20;
-	if(tmp8_clk_new!=tmp8_clk_ori){
-		RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x10250003=====\n"));
+	tmp8_clk_ori = rtw_read8(padapter, 0x10250003);
+	tmp8_clk_new = tmp8_clk_ori | 0x20;
+	if (tmp8_clk_new != tmp8_clk_ori) {
 		rtw_write8(padapter, 0x10250003, tmp8_clk_new);
-	}	
+	}
 #endif
-_func_enter_;		
-	
+
 	x = rtw_read8(padapter, EE_9346CR);
 
 	x &= ~(_EEDI | _EEDO | _EESK | _EEM0);
@@ -209,94 +178,86 @@ _func_enter_;
 	rtw_write8(padapter, EE_9346CR, x);
 
 	shift_out_bits(padapter, EEPROM_EWEN_OPCODE, 5);
-	
-	if(padapter->EepromAddressSize==8)	//CF+ and SDIO
+
+	if (padapter->EepromAddressSize == 8)	/* CF+ and SDIO */
 		shift_out_bits(padapter, 0, 6);
-	else									//USB
+	else									/* USB */
 		shift_out_bits(padapter, 0, 4);
-	
-	standby( padapter);
 
-// Commented out by rcnjko, 2004.0
-//	// Erase this particular word.  Write the erase opcode and register
-//	// number in that order. The opcode is 3bits in length; reg is 6 bits long.
-//	shift_out_bits(Adapter, EEPROM_ERASE_OPCODE, 3);
-//	shift_out_bits(Adapter, reg, Adapter->EepromAddressSize);
-//
-//	if (wait_eeprom_cmd_done(Adapter ) == FALSE) 
-//	{
-//		return;
-//	}
+	standby(padapter);
+
+	/* Commented out by rcnjko, 2004.0
+	 * 	  Erase this particular word.  Write the erase opcode and register
+	 *    number in that order. The opcode is 3bits in length; reg is 6 bits long. */
+/*	shift_out_bits(Adapter, EEPROM_ERASE_OPCODE, 3);
+ *	shift_out_bits(Adapter, reg, Adapter->EepromAddressSize);
+ *
+ *	if (wait_eeprom_cmd_done(Adapter ) == FALSE)
+ *	{
+ *		return;
+ *	} */
 
 
-	standby(padapter );
+	standby(padapter);
 
-	// write the new word to the EEPROM
+	/* write the new word to the EEPROM */
 
-	// send the write opcode the EEPORM
+	/* send the write opcode the EEPORM */
 	shift_out_bits(padapter, EEPROM_WRITE_OPCODE, 3);
 
-	// select which word in the EEPROM that we are writing to.
+	/* select which word in the EEPROM that we are writing to. */
 	shift_out_bits(padapter, reg, padapter->EepromAddressSize);
 
-	// write the data to the selected EEPROM word.
+	/* write the data to the selected EEPROM word. */
 	shift_out_bits(padapter, data, 16);
 
-	if (wait_eeprom_cmd_done(padapter ) == _FALSE) 
-	{
+	if (wait_eeprom_cmd_done(padapter) == _FALSE)
 
 		goto exit;
-	}
 
-	standby(padapter );
+	standby(padapter);
 
 	shift_out_bits(padapter, EEPROM_EWDS_OPCODE, 5);
 	shift_out_bits(padapter, reg, 4);
 
-	eeprom_clean(padapter );
-exit:	
+	eeprom_clean(padapter);
+exit:
 #ifdef CONFIG_RTL8712
-	if(tmp8_clk_new!=tmp8_clk_ori)
+	if (tmp8_clk_new != tmp8_clk_ori)
 		rtw_write8(padapter, 0x10250003, tmp8_clk_ori);
-	if(tmp8_new!=tmp8_ori)
+	if (tmp8_new != tmp8_ori)
 		rtw_write8(padapter, 0x102502f1, tmp8_ori);
 
 #endif
-_func_exit_;	
 	return;
 }
 
-u16 eeprom_read16(_adapter * padapter, u16 reg) //ReadEEprom
+u16 eeprom_read16(_adapter *padapter, u16 reg)  /* ReadEEprom */
 {
 
 	u16 x;
-	u16 data=0;
+	u16 data = 0;
 #ifdef CONFIG_RTL8712
-	u8	tmp8_ori,tmp8_new,tmp8_clk_ori,tmp8_clk_new;
-	tmp8_ori= rtw_read8(padapter, 0x102502f1);
+	u8	tmp8_ori, tmp8_new, tmp8_clk_ori, tmp8_clk_new;
+	tmp8_ori = rtw_read8(padapter, 0x102502f1);
 	tmp8_new = tmp8_ori & 0xf7;
-	if(tmp8_ori != tmp8_new){	
+	if (tmp8_ori != tmp8_new) {
 		rtw_write8(padapter, 0x102502f1, tmp8_new);
-		RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x102502f1=====\n"));
 	}
-	tmp8_clk_ori=rtw_read8(padapter,0x10250003);
-	tmp8_clk_new=tmp8_clk_ori|0x20;
-	if(tmp8_clk_new!=tmp8_clk_ori){
-		RT_TRACE(_module_rtl871x_mp_ioctl_c_,_drv_err_,("====write 0x10250003=====\n"));
+	tmp8_clk_ori = rtw_read8(padapter, 0x10250003);
+	tmp8_clk_new = tmp8_clk_ori | 0x20;
+	if (tmp8_clk_new != tmp8_clk_ori) {
 		rtw_write8(padapter, 0x10250003, tmp8_clk_new);
-	}	
+	}
 #endif
-_func_enter_;		
 
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
-	// select EEPROM, reset bits, set _EECS
+	/* select EEPROM, reset bits, set _EECS */
 	x = rtw_read8(padapter, EE_9346CR);
 
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 
@@ -304,24 +265,23 @@ _func_enter_;
 	x |= _EEM1 | _EECS;
 	rtw_write8(padapter, EE_9346CR, (unsigned char)x);
 
-	// write the read opcode and register number in that order
-	// The opcode is 3bits in length, reg is 6 bits long
+	/* write the read opcode and register number in that order */
+	/* The opcode is 3bits in length, reg is 6 bits long */
 	shift_out_bits(padapter, EEPROM_READ_OPCODE, 3);
 	shift_out_bits(padapter, reg, padapter->EepromAddressSize);
 
-	// Now read the data (16 bits) in from the selected EEPROM word
+	/* Now read the data (16 bits) in from the selected EEPROM word */
 	data = shift_in_bits(padapter);
 
 	eeprom_clean(padapter);
-out:	
+out:
 #ifdef CONFIG_RTL8712
-	if(tmp8_clk_new!=tmp8_clk_ori)
+	if (tmp8_clk_new != tmp8_clk_ori)
 		rtw_write8(padapter, 0x10250003, tmp8_clk_ori);
-	if(tmp8_new!=tmp8_ori)
+	if (tmp8_new != tmp8_ori)
 		rtw_write8(padapter, 0x102502f1, tmp8_ori);
 
 #endif
-_func_exit_;		
 	return data;
 
 
@@ -330,22 +290,19 @@ _func_exit_;
 
 
 
-//From even offset
-void eeprom_read_sz(_adapter * padapter, u16 reg, u8* data, u32 sz) 
+/* From even offset */
+void eeprom_read_sz(_adapter *padapter, u16 reg, u8 *data, u32 sz)
 {
 
 	u16 x, data16;
 	u32 i;
-_func_enter_;		
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
-	// select EEPROM, reset bits, set _EECS
+	/* select EEPROM, reset bits, set _EECS */
 	x = rtw_read8(padapter, EE_9346CR);
 
 	if (rtw_is_surprise_removed(padapter)) {
-		RT_TRACE(_module_rtl871x_eeprom_c_, _drv_err_, ("padapter->bSurpriseRemoved==_TRUE"));
 		goto out;
 	}
 
@@ -353,71 +310,61 @@ _func_enter_;
 	x |= _EEM1 | _EECS;
 	rtw_write8(padapter, EE_9346CR, (unsigned char)x);
 
-	// write the read opcode and register number in that order
-	// The opcode is 3bits in length, reg is 6 bits long
+	/* write the read opcode and register number in that order */
+	/* The opcode is 3bits in length, reg is 6 bits long */
 	shift_out_bits(padapter, EEPROM_READ_OPCODE, 3);
 	shift_out_bits(padapter, reg, padapter->EepromAddressSize);
 
 
-	for(i=0; i<sz; i+=2)
-	{
+	for (i = 0; i < sz; i += 2) {
 		data16 = shift_in_bits(padapter);
 		data[i] = data16 & 0xff;
-		data[i+1] = data16 >>8;		
+		data[i + 1] = data16 >> 8;
 	}
 
 	eeprom_clean(padapter);
-out:	
-_func_exit_;		
-
-
-
+out:
+	return;
 }
 
 
-//addr_off : address offset of the entry in eeprom (not the tuple number of eeprom (reg); that is addr_off !=reg)
-u8 eeprom_read(_adapter * padapter, u32 addr_off, u8 sz, u8* rbuf)
+/* addr_off : address offset of the entry in eeprom (not the tuple number of eeprom (reg); that is addr_off !=reg) */
+u8 eeprom_read(_adapter *padapter, u32 addr_off, u8 sz, u8 *rbuf)
 {
 	u8 quotient, remainder, addr_2align_odd;
-	u16 reg, stmp , i=0, idx = 0;
-_func_enter_;		
+	u16 reg, stmp , i = 0, idx = 0;
 	reg = (u16)(addr_off >> 1);
 	addr_2align_odd = (u8)(addr_off & 0x1);
 
-	if(addr_2align_odd) //read that start at high part: e.g  1,3,5,7,9,...
-	{
+	if (addr_2align_odd) { /* read that start at high part: e.g  1,3,5,7,9,... */
 		stmp = eeprom_read16(padapter, reg);
-		rbuf[idx++] = (u8) ((stmp>>8)&0xff); //return hogh-part of the short
-		reg++; sz--;
+		rbuf[idx++] = (u8)((stmp >> 8) & 0xff); /* return hogh-part of the short */
+		reg++;
+		sz--;
 	}
-	
+
 	quotient = sz >> 1;
 	remainder = sz & 0x1;
 
-	for( i=0 ; i < quotient; i++)
-	{
-		stmp = eeprom_read16(padapter, reg+i);
-		rbuf[idx++] = (u8) (stmp&0xff);
-		rbuf[idx++] = (u8) ((stmp>>8)&0xff);
+	for (i = 0 ; i < quotient; i++) {
+		stmp = eeprom_read16(padapter, reg + i);
+		rbuf[idx++] = (u8)(stmp & 0xff);
+		rbuf[idx++] = (u8)((stmp >> 8) & 0xff);
 	}
-	
-	reg = reg+i;
-	if(remainder){ //end of read at lower part of short : 0,2,4,6,...
+
+	reg = reg + i;
+	if (remainder) { /* end of read at lower part of short : 0,2,4,6,... */
 		stmp = eeprom_read16(padapter, reg);
-		rbuf[idx] = (u8)(stmp & 0xff); 
+		rbuf[idx] = (u8)(stmp & 0xff);
 	}
-_func_exit_;		
 	return _TRUE;
 }
 
 
 
-VOID read_eeprom_content(_adapter *	padapter)
+VOID read_eeprom_content(_adapter	*padapter)
 {
 
-_func_enter_;		
 
 
-_func_exit_;		
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ieee80211.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ieee80211.c
index 663bb595e864..addd7fbece37 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ieee80211.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ieee80211.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,17 +12,12 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _IEEE80211_C
 
 #ifdef CONFIG_PLATFORM_INTEL_BYT
-#include <linux/fs.h>
-#endif 
+	#include <linux/fs.h>
+#endif
 #include <drv_types.h>
 
 
@@ -46,25 +42,27 @@ u8 RSN_CIPHER_SUITE_TKIP[] = { 0x00, 0x0f, 0xac, 2 };
 u8 RSN_CIPHER_SUITE_WRAP[] = { 0x00, 0x0f, 0xac, 3 };
 u8 RSN_CIPHER_SUITE_CCMP[] = { 0x00, 0x0f, 0xac, 4 };
 u8 RSN_CIPHER_SUITE_WEP104[] = { 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};
+/* -----------------------------------------------------------
+ * 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
+};
 
 u8 mgn_rates_cck[4] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M};
 u8 mgn_rates_ofdm[8] = {MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M};
@@ -73,15 +71,19 @@ u8 mgn_rates_mcs8_15[8] = {MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11, MGN_MCS12,
 u8 mgn_rates_mcs16_23[8] = {MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19, MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23};
 u8 mgn_rates_mcs24_31[8] = {MGN_MCS24, MGN_MCS25, MGN_MCS26, MGN_MCS27, MGN_MCS28, MGN_MCS29, MGN_MCS30, MGN_MCS31};
 u8 mgn_rates_vht1ss[10] = {MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4
-	, MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9};
+	, MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9
+			  };
 u8 mgn_rates_vht2ss[10] = {MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4
-	, MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9};
+	, MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9
+			  };
 u8 mgn_rates_vht3ss[10] = {MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4
-	, MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9};
+	, MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9
+			  };
 u8 mgn_rates_vht4ss[10] = {MGN_VHT4SS_MCS0, MGN_VHT4SS_MCS1, MGN_VHT4SS_MCS2, MGN_VHT4SS_MCS3, MGN_VHT4SS_MCS4
-	, MGN_VHT4SS_MCS5, MGN_VHT4SS_MCS6, MGN_VHT4SS_MCS7, MGN_VHT4SS_MCS8, MGN_VHT4SS_MCS9};
+	, MGN_VHT4SS_MCS5, MGN_VHT4SS_MCS6, MGN_VHT4SS_MCS7, MGN_VHT4SS_MCS8, MGN_VHT4SS_MCS9
+			  };
 
-static const char * const _rate_section_str[] = {
+static const char *const _rate_section_str[] = {
 	"CCK",
 	"OFDM",
 	"HT_1SS",
@@ -116,10 +118,10 @@ struct rate_section_ent rates_by_sections[RATE_SECTION_NUM] = {
 
 int rtw_get_bit_value_from_ieee_value(u8 val)
 {
-	unsigned char dot11_rate_table[]={2,4,11,22,12,18,24,36,48,72,96,108,0}; // last element must be zero!!
+	unsigned char dot11_rate_table[] = {2, 4, 11, 22, 12, 18, 24, 36, 48, 72, 96, 108, 0}; /* last element must be zero!! */
 
-	int i=0;
-	while(dot11_rate_table[i] != 0) {
+	int i = 0;
+	while (dot11_rate_table[i] != 0) {
 		if (dot11_rate_table[i] == val)
 			return BIT(i);
 		i++;
@@ -128,18 +130,17 @@ int rtw_get_bit_value_from_ieee_value(u8 val)
 }
 
 uint	rtw_is_cckrates_included(u8 *rate)
-{	
-		u32	i = 0;			
-
-		while(rate[i]!=0)
-		{		
-			if  (  (((rate[i]) & 0x7f) == 2)	|| (((rate[i]) & 0x7f) == 4) ||		
-			(((rate[i]) & 0x7f) == 11)  || (((rate[i]) & 0x7f) == 22) )		
-				return _TRUE;
-			i++;
-		}
-		
-		return _FALSE;
+{
+	u32	i = 0;
+
+	while (rate[i] != 0) {
+		if ((((rate[i]) & 0x7f) == 2)	|| (((rate[i]) & 0x7f) == 4) ||
+		    (((rate[i]) & 0x7f) == 11)  || (((rate[i]) & 0x7f) == 22))
+			return _TRUE;
+		i++;
+	}
+
+	return _FALSE;
 }
 
 uint	rtw_is_cckratesonly_included(u8 *rate)
@@ -147,56 +148,52 @@ uint	rtw_is_cckratesonly_included(u8 *rate)
 	u32 i = 0;
 
 
-	while(rate[i]!=0)
-	{
-			if  (  (((rate[i]) & 0x7f) != 2) && (((rate[i]) & 0x7f) != 4) &&
-				(((rate[i]) & 0x7f) != 11)  && (((rate[i]) & 0x7f) != 22) )
-				return _FALSE;
+	while (rate[i] != 0) {
+		if ((((rate[i]) & 0x7f) != 2) && (((rate[i]) & 0x7f) != 4) &&
+		    (((rate[i]) & 0x7f) != 11)  && (((rate[i]) & 0x7f) != 22))
+			return _FALSE;
 
-			i++;
+		i++;
 	}
-	
+
 	return _TRUE;
 
 }
 
 int rtw_check_network_type(unsigned char *rate, int ratelen, int channel)
 {
-	if (channel > 14)
-	{
+	if (channel > 14) {
 		if ((rtw_is_cckrates_included(rate)) == _TRUE)
 			return WIRELESS_INVALID;
 		else
 			return WIRELESS_11A;
-	}	
-	else  // could be pure B, pure G, or B/G
-	{
-		if ((rtw_is_cckratesonly_included(rate)) == _TRUE)	
+	} else { /* could be pure B, pure G, or B/G */
+		if ((rtw_is_cckratesonly_included(rate)) == _TRUE)
 			return WIRELESS_11B;
-		else if((rtw_is_cckrates_included(rate)) == _TRUE)
-			return 	WIRELESS_11BG;
+		else if ((rtw_is_cckrates_included(rate)) == _TRUE)
+			return	WIRELESS_11BG;
 		else
 			return WIRELESS_11G;
 	}
-	
+
 }
 
 u8 *rtw_set_fixed_ie(unsigned char *pbuf, unsigned int len, unsigned char *source,
-				unsigned int *frlen)
+		     unsigned int *frlen)
 {
 	_rtw_memcpy((void *)pbuf, (void *)source, len);
 	*frlen = *frlen + len;
-	return (pbuf + len);
+	return pbuf + len;
 }
 
-// rtw_set_ie will update frame length
+/* rtw_set_ie will update frame length */
 u8 *rtw_set_ie
 (
-	u8 *pbuf, 
-	sint index, 
+	u8 *pbuf,
+	sint index,
 	uint len,
-	u8 *source, 
-	uint *frlen //frame length
+	const u8 *source,
+	uint *frlen /* frame length */
 )
 {
 	*pbuf = (u8)index;
@@ -205,14 +202,15 @@ u8 *rtw_set_ie
 
 	if (len > 0)
 		_rtw_memcpy((void *)(pbuf + 2), (void *)source, len);
-	
-	*frlen = *frlen + (len + 2);
-	
-	return (pbuf + len + 2);
+
+	if (frlen)
+		*frlen = *frlen + (len + 2);
+
+	return pbuf + len + 2;
 }
 
 inline u8 *rtw_set_ie_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode,
-	u8 new_ch, u8 ch_switch_cnt)
+				u8 new_ch, u8 ch_switch_cnt)
 {
 	u8 ie_data[3];
 
@@ -226,10 +224,10 @@ inline u8 secondary_ch_offset_to_hal_ch_offset(u8 ch_offset)
 {
 	if (ch_offset == SCN)
 		return HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	else if(ch_offset == SCA)
-		return HAL_PRIME_CHNL_OFFSET_UPPER;
-	else if(ch_offset == SCB)
+	else if (ch_offset == SCA)
 		return HAL_PRIME_CHNL_OFFSET_LOWER;
+	else if (ch_offset == SCB)
+		return HAL_PRIME_CHNL_OFFSET_UPPER;
 
 	return HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 }
@@ -238,10 +236,10 @@ inline u8 hal_ch_offset_to_secondary_ch_offset(u8 ch_offset)
 {
 	if (ch_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE)
 		return SCN;
-	else if(ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
-		return SCB;
-	else if(ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
+	else if (ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
 		return SCA;
+	else if (ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
+		return SCB;
 
 	return SCN;
 }
@@ -252,14 +250,14 @@ inline u8 *rtw_set_ie_secondary_ch_offset(u8 *buf, u32 *buf_len, u8 secondary_ch
 }
 
 inline u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl,
-	u8 flags, u16 reason, u16 precedence)
+		u8 flags, u16 reason, u16 precedence)
 {
 	u8 ie_data[6];
 
 	ie_data[0] = ttl;
 	ie_data[1] = flags;
-	RTW_PUT_LE16((u8*)&ie_data[2], reason);
-	RTW_PUT_LE16((u8*)&ie_data[4], precedence);
+	RTW_PUT_LE16((u8 *)&ie_data[2], reason);
+	RTW_PUT_LE16((u8 *)&ie_data[4], precedence);
 
 	return rtw_set_ie(buf, 0x118,  6, ie_data, buf_len);
 }
@@ -267,28 +265,22 @@ inline u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl,
 /*----------------------------------------------------------------------------
 index: the information element id index, limit is the limit for search
 -----------------------------------------------------------------------------*/
-u8 *rtw_get_ie(u8 *pbuf, sint index, sint *len, sint limit)
+u8 *rtw_get_ie(const u8 *pbuf, sint index, sint *len, sint limit)
 {
-	sint tmp,i;
-	u8 *p;
-_func_enter_;
-	if (limit < 1){
-		_func_exit_;	
+	sint tmp, i;
+	const u8 *p;
+	if (limit < 1) {
 		return NULL;
 	}
 
 	p = pbuf;
 	i = 0;
 	*len = 0;
-	while(1)
-	{
-		if (*p == index)
-		{
+	while (1) {
+		if (*p == index) {
 			*len = *(p + 1);
-			return (p);
-		}
-		else
-		{
+			return (u8 *)p;
+		} else {
 			tmp = *(p + 1);
 			p += (tmp + 2);
 			i += (tmp + 2);
@@ -296,7 +288,6 @@ _func_enter_;
 		if (i >= limit)
 			break;
 	}
-_func_exit_;		
 	return NULL;
 }
 
@@ -312,43 +303,39 @@ _func_exit_;
  *
  * Returns: The address of the specific IE found, or NULL
  */
-u8 *rtw_get_ie_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len, u8 *ie, uint *ielen)
+u8 *rtw_get_ie_ex(const u8 *in_ie, uint in_len, u8 eid, const u8 *oui, u8 oui_len, u8 *ie, uint *ielen)
 {
 	uint cnt;
-	u8 *target_ie = NULL;
+	const u8 *target_ie = NULL;
 
 
-	if(ielen)
+	if (ielen)
 		*ielen = 0;
 
-	if(!in_ie || in_len<=0)
-		return target_ie;
+	if (!in_ie || in_len <= 0)
+		return (u8 *)target_ie;
 
 	cnt = 0;
 
-	while(cnt<in_len)
-	{
-		if(eid == in_ie[cnt]
-			&& ( !oui || _rtw_memcmp(&in_ie[cnt+2], oui, oui_len) == _TRUE))
-		{
+	while (cnt < in_len) {
+		if (eid == in_ie[cnt]
+		    && (!oui || _rtw_memcmp(&in_ie[cnt + 2], oui, oui_len) == _TRUE)) {
 			target_ie = &in_ie[cnt];
 
-			if(ie)
-				_rtw_memcpy(ie, &in_ie[cnt], in_ie[cnt+1]+2);
-			
-			if(ielen)
-				*ielen = in_ie[cnt+1]+2;
+			if (ie)
+				_rtw_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	 */
 		}
-		else
-		{
-			cnt+=in_ie[cnt+1]+2; //goto next	
-		}		
 
-	}	
+	}
 
-	return target_ie;
+	return (u8 *)target_ie;
 }
 
 /**
@@ -369,8 +356,8 @@ int rtw_ies_remove_ie(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 o
 	u32 target_ielen;
 	u8 *start;
 	uint search_len;
-	
-	if(!ies || !ies_len || *ies_len <= offset)
+
+	if (!ies || !ies_len || *ies_len <= offset)
 		goto exit;
 
 	start = ies + offset;
@@ -388,102 +375,94 @@ int rtw_ies_remove_ie(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 o
 
 			start = target_ie;
 			search_len = remain_len;
-		} else {
+		} else
 			break;
-		}
 	}
 exit:
 	return ret;
 }
 
-void rtw_set_supported_rate(u8* SupportedRates, uint mode) 
+void rtw_set_supported_rate(u8 *SupportedRates, uint mode)
 {
-_func_enter_;
 
 	_rtw_memset(SupportedRates, 0, NDIS_802_11_LENGTH_RATES_EX);
-	
-	switch (mode)
-	{
-		case WIRELESS_11B:
-			_rtw_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 ?
-		case WIRELESS_11_5AC:
-			_rtw_memcpy(SupportedRates, WIFI_OFDMRATES, IEEE80211_NUM_OFDM_RATESLEN);
-			break;
-		
-		case WIRELESS_11BG:
-		case WIRELESS_11G_24N:
-		case WIRELESS_11_24N:
-		case WIRELESS_11BG_24N:
-			_rtw_memcpy(SupportedRates, WIFI_CCKRATES, IEEE80211_CCK_RATE_LEN);
-			_rtw_memcpy(SupportedRates + IEEE80211_CCK_RATE_LEN, WIFI_OFDMRATES, IEEE80211_NUM_OFDM_RATESLEN);
-			break;
-	
+
+	switch (mode) {
+	case WIRELESS_11B:
+		_rtw_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 ? */
+	case WIRELESS_11_5AC:
+		_rtw_memcpy(SupportedRates, WIFI_OFDMRATES, IEEE80211_NUM_OFDM_RATESLEN);
+		break;
+
+	case WIRELESS_11BG:
+	case WIRELESS_11G_24N:
+	case WIRELESS_11_24N:
+	case WIRELESS_11BG_24N:
+		_rtw_memcpy(SupportedRates, WIFI_CCKRATES, IEEE80211_CCK_RATE_LEN);
+		_rtw_memcpy(SupportedRates + IEEE80211_CCK_RATE_LEN, WIFI_OFDMRATES, IEEE80211_NUM_OFDM_RATESLEN);
+		break;
+
 	}
-_func_exit_;	
 }
 
 uint	rtw_get_rateset_len(u8	*rateset)
 {
 	uint i = 0;
-_func_enter_;	
-	while(1)
-	{
+	while (1) {
 		if ((rateset[i]) == 0)
 			break;
-			
+
 		if (i > 12)
 			break;
-			
-		i++;			
+
+		i++;
 	}
-_func_exit_;		
 	return i;
 }
 
 int rtw_generate_ie(struct registry_priv *pregistrypriv)
 {
 	u8	wireless_mode;
-	int 	sz = 0, rateLen;
-	WLAN_BSSID_EX*	pdev_network = &pregistrypriv->dev_network;
-	u8*	ie = pdev_network->IEs;
-	
-_func_enter_;		
-
-	//timestamp will be inserted by hardware
-	sz += 8;	
+	int	sz = 0, rateLen;
+	WLAN_BSSID_EX	*pdev_network = &pregistrypriv->dev_network;
+	u8	*ie = pdev_network->IEs;
+
+
+	/* timestamp will be inserted by hardware */
+	sz += 8;
 	ie += sz;
-	
-	//beacon interval : 2bytes
-	*(u16*)ie = cpu_to_le16((u16)pdev_network->Configuration.BeaconPeriod);//BCN_INTERVAL;
-	sz += 2; 
+
+	/* beacon interval : 2bytes */
+	*(u16 *)ie = cpu_to_le16((u16)pdev_network->Configuration.BeaconPeriod); /* BCN_INTERVAL; */
+	sz += 2;
 	ie += 2;
-	
-	//capability info
-	*(u16*)ie = 0;
-	
-	*(u16*)ie |= cpu_to_le16(cap_IBSS);
-
-	if(pregistrypriv->preamble == PREAMBLE_SHORT)
-		*(u16*)ie |= cpu_to_le16(cap_ShortPremble);
-	
+
+	/* capability info */
+	*(u16 *)ie = 0;
+
+	*(u16 *)ie |= cpu_to_le16(cap_IBSS);
+
+	if (pregistrypriv->preamble == PREAMBLE_SHORT)
+		*(u16 *)ie |= cpu_to_le16(cap_ShortPremble);
+
 	if (pdev_network->Privacy)
-		*(u16*)ie |= cpu_to_le16(cap_Privacy);
-	
+		*(u16 *)ie |= cpu_to_le16(cap_Privacy);
+
 	sz += 2;
 	ie += 2;
-	
-	//SSID
+
+	/* SSID */
 	ie = rtw_set_ie(ie, _SSID_IE_, pdev_network->Ssid.SsidLength, pdev_network->Ssid.Ssid, &sz);
-	
-	//supported rates
+
+	/* supported rates */
 	if (pregistrypriv->wireless_mode == WIRELESS_11ABGN) {
-		if(pdev_network->Configuration.DSConfig > 14)
+		if (pdev_network->Configuration.DSConfig > 14)
 			wireless_mode = WIRELESS_11A_5N;
 		else
 			wireless_mode = WIRELESS_11BG_24N;
@@ -496,46 +475,38 @@ _func_enter_;
 		wireless_mode = pregistrypriv->wireless_mode;
 
 	rtw_set_supported_rate(pdev_network->SupportedRates, wireless_mode) ;
-	
+
 	rateLen = rtw_get_rateset_len(pdev_network->SupportedRates);
 
-	if (rateLen > 8)
-	{
+	if (rateLen > 8) {
 		ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, 8, pdev_network->SupportedRates, &sz);
-		//ie = rtw_set_ie(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (pdev_network->SupportedRates + 8), &sz);
-	}
-	else
-	{
+		/* ie = rtw_set_ie(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (pdev_network->SupportedRates + 8), &sz); */
+	} else
 		ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, rateLen, pdev_network->SupportedRates, &sz);
-	}
 
-	//DS parameter set
+	/* DS parameter set */
 	ie = rtw_set_ie(ie, _DSSET_IE_, 1, (u8 *)&(pdev_network->Configuration.DSConfig), &sz);
 
 
-	//IBSS Parameter Set
-	
+	/* IBSS Parameter Set */
+
 	ie = rtw_set_ie(ie, _IBSS_PARA_IE_, 2, (u8 *)&(pdev_network->Configuration.ATIMWindow), &sz);
 
 	if (rateLen > 8)
-	{		
 		ie = rtw_set_ie(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (pdev_network->SupportedRates + 8), &sz);
-	}
-	
+
 #ifdef CONFIG_80211N_HT
-	//HT Cap.
-	if(((pregistrypriv->wireless_mode&WIRELESS_11_5N)||(pregistrypriv->wireless_mode&WIRELESS_11_24N)) 
-		&& (pregistrypriv->ht_enable==_TRUE))
-	{
-		//todo:
+	/* HT Cap. */
+	if (((pregistrypriv->wireless_mode & WIRELESS_11_5N) || (pregistrypriv->wireless_mode & WIRELESS_11_24N))
+	    && (pregistrypriv->ht_enable == _TRUE)) {
+		/* todo: */
 	}
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 
-	//pdev_network->IELength =  sz; //update IELength
+	/* pdev_network->IELength =  sz; */ /* update IELength */
 
-_func_exit_;
 
-	//return _SUCCESS;
+	/* return _SUCCESS; */
 
 	return sz;
 
@@ -549,19 +520,17 @@ unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit)
 	u8 *pbuf = pie;
 	int limit_new = limit;
 
-	while(1) 
-	{
+	while (1) {
 		pbuf = rtw_get_ie(pbuf, _WPA_IE_ID_, &len, limit_new);
 
 		if (pbuf) {
 
-			//check if oui matches...
-			if (_rtw_memcmp((pbuf + 2), wpa_oui_type, sizeof (wpa_oui_type)) == _FALSE) {
+			/* check if oui matches... */
+			if (_rtw_memcmp((pbuf + 2), wpa_oui_type, sizeof(wpa_oui_type)) == _FALSE)
 
 				goto check_next_ie;
-			}
 
-			//check version...
+			/* check version... */
 			_rtw_memcpy((u8 *)&val16, (pbuf + 6), sizeof(val16));
 
 			val16 = le16_to_cpu(val16);
@@ -572,8 +541,7 @@ unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit)
 
 			return pbuf;
 
-		}
-		else {
+		} else {
 
 			*wpa_ie_len = 0;
 			return NULL;
@@ -597,9 +565,9 @@ check_next_ie:
 }
 
 unsigned char *rtw_get_wpa2_ie(unsigned char *pie, int *rsn_ie_len, int limit)
-{	
+{
 
-	return rtw_get_ie(pie, _WPA2_IE_ID_,rsn_ie_len, limit);
+	return rtw_get_ie(pie, _WPA2_IE_ID_, rsn_ie_len, limit);
 
 }
 
@@ -636,9 +604,9 @@ int rtw_get_wpa2_cipher_suite(u8 *s)
 }
 
 
-int rtw_parse_wpa_ie(u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x)
+int rtw_parse_wpa_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x)
 {
-	int i, ret=_SUCCESS;
+	int i, ret = _SUCCESS;
 	int left, count;
 	u8 *pos;
 	u8 SUITE_1X[4] = {0x00, 0x50, 0xf2, 1};
@@ -648,62 +616,50 @@ int rtw_parse_wpa_ie(u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwis
 		return _FAIL;
 	}
 
-	
-	if ((*wpa_ie != _WPA_IE_ID_) || (*(wpa_ie+1) != (u8)(wpa_ie_len - 2)) ||
-	   (_rtw_memcmp(wpa_ie+2, RTW_WPA_OUI_TYPE, WPA_SELECTOR_LEN) != _TRUE) )
-	{		
+
+	if ((*wpa_ie != _WPA_IE_ID_) || (*(wpa_ie + 1) != (u8)(wpa_ie_len - 2)) ||
+	    (_rtw_memcmp(wpa_ie + 2, RTW_WPA_OUI_TYPE, WPA_SELECTOR_LEN) != _TRUE))
 		return _FAIL;
-	}
 
 	pos = wpa_ie;
 
 	pos += 8;
-	left = wpa_ie_len - 8;	
+	left = wpa_ie_len - 8;
 
 
-	//group_cipher
+	/* 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", __FUNCTION__, left));
-		
+
+	} else if (left > 0) {
+
 		return _FAIL;
 	}
 
 
-	//pairwise_cipher
-	if (left >= 2)
-	{		
-                //count = le16_to_cpu(*(u16*)pos);	
+	/* pairwise_cipher */
+	if (left >= 2) {
+		/* count = le16_to_cpu(*(u16*)pos);	 */
 		count = RTW_GET_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", __FUNCTION__, count, left));
 			return _FAIL;
 		}
-		
-		for (i = 0; i < count; i++)
-		{
+
+		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)",   __FUNCTION__));
+
+	} else if (left == 1) {
 		return _FAIL;
 	}
 
@@ -711,257 +667,281 @@ int rtw_parse_wpa_ie(u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwis
 		if (left >= 6) {
 			pos += 2;
 			if (_rtw_memcmp(pos, SUITE_1X, 4) == 1) {
-				RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("%s : there has 802.1x auth\n", __FUNCTION__));
 				*is_8021x = 1;
 			}
 		}
 	}
-	
+
 	return ret;
-	
+
 }
 
-int rtw_parse_wpa2_ie(u8* rsn_ie, int rsn_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x)
+int rtw_rsne_info_parse(const u8 *ie, uint ie_len, struct rsne_info *info)
 {
-	int i, ret=_SUCCESS;
-	int left, count;
-	u8 *pos;
-	u8 SUITE_1X[4] = {0x00,0x0f, 0xac, 0x01};
+	int i;
+	const u8 *pos = ie;
+	u16 cnt;
 
-	if (rsn_ie_len <= 0) {
-		/* No RSN IE - fail silently */
-		return _FAIL;
-	}
+	_rtw_memset(info, 0, sizeof(struct rsne_info));
 
+	if (ie + ie_len < pos + 4)
+		goto err;
 
-	if ((*rsn_ie!= _WPA2_IE_ID_) || (*(rsn_ie+1) != (u8)(rsn_ie_len - 2)))
-	{		
-		return _FAIL;
+	if (*ie != WLAN_EID_RSN || *(ie + 1) != ie_len - 2)
+		goto err;
+	pos += 2 + 2;
+
+	/* Group CS */
+	if (ie + ie_len < pos + 4) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
 	}
-	
-	pos = rsn_ie;
+	info->gcs = (u8 *)pos;
 	pos += 4;
-	left = rsn_ie_len - 4;	
 
-	//group_cipher
-	if (left >= RSN_SELECTOR_LEN) {
+	/* Pairwise CS */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	cnt = RTW_GET_LE16(pos);
+	pos += 2;
+	if (ie + ie_len < pos + 4 * cnt) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->pcs_cnt = cnt;
+	info->pcs_list = (u8 *)pos;
+	pos += 4 * cnt;
 
-		*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", __FUNCTION__, left));
-		return _FAIL;
+	/* AKM */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	cnt = RTW_GET_LE16(pos);
+	pos += 2;
+	if (ie + ie_len < pos + 4 * cnt) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
 	}
+	info->akm_cnt = cnt;
+	info->akm_list = (u8 *)pos;
+	pos += 4 * cnt;
 
-	//pairwise_cipher
-	if (left >= 2)
-	{		
-	        //count = le16_to_cpu(*(u16*)pos);
-		count = RTW_GET_LE16(pos);
-		pos += 2;
-		left -= 2;
+	/* RSN cap */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->cap = (u8 *)pos;
+	pos += 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", __FUNCTION__, 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;
-		}
+	/* PMKID */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	cnt = RTW_GET_LE16(pos);
+	pos += 2;
+	if (ie + ie_len < pos + 16 * cnt) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->pmkid_cnt = cnt;
+	info->pmkid_list = (u8 *)pos;
+	pos += 16 * cnt;
 
-	} 
-	else if (left == 1)
-	{
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("%s: ie too short (for key mgmt)",  __FUNCTION__));
-		
-		return _FAIL;
+	/* Group Mgmt CS */
+	if (ie + ie_len < pos + 4) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->gmcs = (u8 *)pos;
+
+exit:
+	return _SUCCESS;
+
+err:
+	info->err = 1;
+	return _FAIL;
+}
+
+int rtw_parse_wpa2_ie(u8 *rsn_ie, int rsn_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x, u8 *mfp_opt)
+{
+	struct rsne_info info;
+	int i, ret = _SUCCESS;
+	u8 SUITE_1X[4] = {0x00, 0x0f, 0xac, 0x01};
+
+	ret = rtw_rsne_info_parse(rsn_ie, rsn_ie_len, &info);
+	if (ret != _SUCCESS)
+		goto exit;
+
+	if (group_cipher) {
+		if (info.gcs)
+			*group_cipher = rtw_get_wpa2_cipher_suite(info.gcs);
+		else
+			*group_cipher = 0;
+	}
+
+	if (pairwise_cipher) {
+		*pairwise_cipher = 0;
+		for (i = 0; i < info.pcs_cnt; i++)
+			*pairwise_cipher |= rtw_get_wpa2_cipher_suite(info.pcs_list + 4 * i);
 	}
 
 	if (is_8021x) {
-		if (left >= 6) {
-			pos += 2;
-			if (_rtw_memcmp(pos, SUITE_1X, 4) == 1) {
-				RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("%s (): there has 802.1x auth\n", __FUNCTION__));
-				*is_8021x = 1;
-			}
-		}
+		*is_8021x = 0;
+		/* here only check the first AKM suite */
+		if (info.akm_cnt && _rtw_memcmp(SUITE_1X, info.akm_list, 4) == _TRUE)
+			*is_8021x = 1;
+	}
+
+	if (mfp_opt) {
+		*mfp_opt = MFP_NO;
+		if (info.cap)
+			*mfp_opt = GET_RSN_CAP_MFP_OPTION(info.cap);
 	}
 
+exit:
 	return ret;
-	
 }
 
-//#ifdef CONFIG_WAPI_SUPPORT
-int rtw_get_wapi_ie(u8 *in_ie,uint in_len,u8 *wapi_ie,u16 *wapi_len)
+/* #ifdef CONFIG_WAPI_SUPPORT */
+int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len)
 {
 	int len = 0;
 	u8 authmode, i;
-	uint 	cnt;
-	u8 wapi_oui1[4]={0x0,0x14,0x72,0x01};
-	u8 wapi_oui2[4]={0x0,0x14,0x72,0x02};
+	uint	cnt;
+	u8 wapi_oui1[4] = {0x0, 0x14, 0x72, 0x01};
+	u8 wapi_oui2[4] = {0x0, 0x14, 0x72, 0x02};
 
-_func_enter_;
 
-	if(wapi_len)
+	if (wapi_len)
 		*wapi_len = 0;
 
-	if(!in_ie || in_len<=0)
+	if (!in_ie || in_len <= 0)
 		return len;
 
 	cnt = (_TIMESTAMP_ + _BEACON_ITERVAL_ + _CAPABILITY_);
-	
-	while(cnt<in_len)
-	{
-		authmode=in_ie[cnt];
-
-		//if(authmode==_WAPI_IE_)
-		if(authmode==_WAPI_IE_ && (_rtw_memcmp(&in_ie[cnt+6], wapi_oui1,4)==_TRUE ||
-				       	_rtw_memcmp(&in_ie[cnt+6], wapi_oui2,4)==_TRUE))
-		{
-			if (wapi_ie) {
-				_rtw_memcpy(wapi_ie, &in_ie[cnt],in_ie[cnt+1]+2);
-
-				for(i=0;i<(in_ie[cnt+1]+2);i=i+8){
-					RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("\n %2x,%2x,%2x,%2x,%2x,%2x,%2x,%2x\n",
-								wapi_ie[i],wapi_ie[i+1],wapi_ie[i+2],wapi_ie[i+3],wapi_ie[i+4],
-								wapi_ie[i+5],wapi_ie[i+6],wapi_ie[i+7]));
-				}
-			}
 
-			if(wapi_len)
-				*wapi_len=in_ie[cnt+1]+2;
-			
-			cnt+=in_ie[cnt+1]+2;  //get next
-		}
-		else
-		{
-			cnt+=in_ie[cnt+1]+2;   //get next
+	while (cnt < in_len) {
+		authmode = in_ie[cnt];
+
+		/* if(authmode==_WAPI_IE_) */
+		if (authmode == _WAPI_IE_ && (_rtw_memcmp(&in_ie[cnt + 6], wapi_oui1, 4) == _TRUE ||
+			_rtw_memcmp(&in_ie[cnt + 6], wapi_oui2, 4) == _TRUE)) {
+			if (wapi_ie)
+				_rtw_memcpy(wapi_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
+
+			if (wapi_len)
+				*wapi_len = in_ie[cnt + 1] + 2;
+
+			cnt += in_ie[cnt + 1] + 2; /* get next */
+		} else {
+			cnt += in_ie[cnt + 1] + 2; /* get next */
 		}
 	}
 
-	if(wapi_len)
+	if (wapi_len)
 		len = *wapi_len;
 
-_func_exit_;
 
 	return len;
 
 }
-//#endif
+/* #endif */
 
-int rtw_get_sec_ie(u8 *in_ie,uint in_len,u8 *rsn_ie,u16 *rsn_len,u8 *wpa_ie,u16 *wpa_len)
+int rtw_get_sec_ie(u8 *in_ie, uint in_len, u8 *rsn_ie, u16 *rsn_len, u8 *wpa_ie, u16 *wpa_len)
 {
 	u8 authmode, sec_idx, i;
-	u8 wpa_oui[4]={0x0,0x50,0xf2,0x01};
-	uint 	cnt;
-	
-_func_enter_;
+	u8 wpa_oui[4] = {0x0, 0x50, 0xf2, 0x01};
+	uint	cnt;
+
+
+	/* Search required WPA or WPA2 IE and copy to sec_ie[ ] */
 
-	//Search required WPA or WPA2 IE and copy to sec_ie[ ]
-	
 	cnt = (_TIMESTAMP_ + _BEACON_ITERVAL_ + _CAPABILITY_);
-	
-	sec_idx=0;
-		
-	while(cnt<in_len)
-	{
-		authmode=in_ie[cnt];
-		
-		if((authmode==_WPA_IE_ID_)&&(_rtw_memcmp(&in_ie[cnt+2], &wpa_oui[0],4)==_TRUE))
-		{	
-				RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("\n rtw_get_wpa_ie: sec_idx=%d in_ie[cnt+1]+2=%d\n",sec_idx,in_ie[cnt+1]+2));		
-
-				if (wpa_ie) {
-				_rtw_memcpy(wpa_ie, &in_ie[cnt],in_ie[cnt+1]+2);
-
-				for(i=0;i<(in_ie[cnt+1]+2);i=i+8){
-						RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("\n %2x,%2x,%2x,%2x,%2x,%2x,%2x,%2x\n",
-									wpa_ie[i],wpa_ie[i+1],wpa_ie[i+2],wpa_ie[i+3],wpa_ie[i+4],
-									wpa_ie[i+5],wpa_ie[i+6],wpa_ie[i+7]));
-					}
-				}
 
-				*wpa_len=in_ie[cnt+1]+2;
-				cnt+=in_ie[cnt+1]+2;  //get next
-		}
-		else
-		{
-			if(authmode==_WPA2_IE_ID_)
-			{
-				RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("\n get_rsn_ie: sec_idx=%d in_ie[cnt+1]+2=%d\n",sec_idx,in_ie[cnt+1]+2));		
-
-				if (rsn_ie) {
-				_rtw_memcpy(rsn_ie, &in_ie[cnt],in_ie[cnt+1]+2);
-
-				for(i=0;i<(in_ie[cnt+1]+2);i=i+8){
-						RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("\n %2x,%2x,%2x,%2x,%2x,%2x,%2x,%2x\n",
-									rsn_ie[i],rsn_ie[i+1],rsn_ie[i+2],rsn_ie[i+3],rsn_ie[i+4],
-									rsn_ie[i+5],rsn_ie[i+6],rsn_ie[i+7]));
-					}
-				}
+	sec_idx = 0;
+
+	while (cnt < in_len) {
+		authmode = in_ie[cnt];
+
+		if ((authmode == _WPA_IE_ID_) && (_rtw_memcmp(&in_ie[cnt + 2], &wpa_oui[0], 4) == _TRUE)) {
+
+			if (wpa_ie)
+				_rtw_memcpy(wpa_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
+
+			*wpa_len = in_ie[cnt + 1] + 2;
+			cnt += in_ie[cnt + 1] + 2; /* get next */
+		} else {
+			if (authmode == _WPA2_IE_ID_) {
+
+				if (rsn_ie)
+					_rtw_memcpy(rsn_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
 
-				*rsn_len=in_ie[cnt+1]+2;
-				cnt+=in_ie[cnt+1]+2;  //get next
+				*rsn_len = in_ie[cnt + 1] + 2;
+				cnt += in_ie[cnt + 1] + 2; /* get next */
+			} else {
+				cnt += in_ie[cnt + 1] + 2; /* get next */
 			}
-			else
-			{
-				cnt+=in_ie[cnt+1]+2;   //get next
-			}	
 		}
-		
+
 	}
-	
-_func_exit_;
 
-	return (*rsn_len+*wpa_len);
-	
+
+	return *rsn_len + *wpa_len;
+
 }
 
 u8 rtw_is_wps_ie(u8 *ie_ptr, uint *wps_ielen)
-{	
+{
 	u8 match = _FALSE;
-	u8 eid, wps_oui[4]={0x0,0x50,0xf2,0x04};
-	
-	if(ie_ptr == NULL) return match;
-	
+	u8 eid, wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
+
+	if (ie_ptr == NULL)
+		return match;
+
 	eid = ie_ptr[0];
-	
-	if((eid==_WPA_IE_ID_)&&(_rtw_memcmp(&ie_ptr[2], wps_oui, 4)==_TRUE))
-	{			
-		//DBG_8192C("==> found WPS_IE.....\n");
-		*wps_ielen = ie_ptr[1]+2;			
-		match=_TRUE;
-	}	
+
+	if ((eid == _WPA_IE_ID_) && (_rtw_memcmp(&ie_ptr[2], wps_oui, 4) == _TRUE)) {
+		/* RTW_INFO("==> found WPS_IE.....\n"); */
+		*wps_ielen = ie_ptr[1] + 2;
+		match = _TRUE;
+	}
 	return match;
 }
 
-u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, u8 frame_type)
+u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, enum bss_type frame_type)
 {
-	u8*	wps = NULL;
+	u8	*wps = NULL;
 
-	DBG_871X( "[%s] frame_type = %d\n", __FUNCTION__, frame_type );
-	switch( frame_type )
-	{
-		case 1:
-		case 3:
-		{	//	Beacon or Probe Response
-			wps = rtw_get_wps_ie(in_ie + _PROBERSP_IE_OFFSET_, in_len - _PROBERSP_IE_OFFSET_, wps_ie, wps_ielen);
-			break;
-		}
-		case 2:
-		{	//	Probe Request
-			wps = rtw_get_wps_ie(in_ie + _PROBEREQ_IE_OFFSET_ , in_len - _PROBEREQ_IE_OFFSET_ , wps_ie, wps_ielen);
-			break;
-		}
+	RTW_INFO("[%s] frame_type = %d\n", __FUNCTION__, frame_type);
+	switch (frame_type) {
+	case BSS_TYPE_BCN:
+	case BSS_TYPE_PROB_RSP: {
+		/*	Beacon or Probe Response */
+		wps = rtw_get_wps_ie(in_ie + _PROBERSP_IE_OFFSET_, in_len - _PROBERSP_IE_OFFSET_, wps_ie, wps_ielen);
+		break;
+	}
+	case BSS_TYPE_PROB_REQ: {
+		/*	Probe Request */
+		wps = rtw_get_wps_ie(in_ie + _PROBEREQ_IE_OFFSET_ , in_len - _PROBEREQ_IE_OFFSET_ , wps_ie, wps_ielen);
+		break;
+	}
+	default:
+	case BSS_TYPE_UNDEF:
+		break;
 	}
 	return wps;
 }
@@ -975,10 +955,10 @@ u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps
  *
  * Returns: The address of the WPS IE found, or NULL
  */
-u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
+u8 *rtw_get_wps_ie(const u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
 {
 	uint cnt;
-	u8 *wpsie_ptr = NULL;
+	const u8 *wpsie_ptr = NULL;
 	u8 eid, wps_oui[4] = {0x00, 0x50, 0xf2, 0x04};
 
 	if (wps_ielen)
@@ -986,11 +966,11 @@ u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
 
 	if (!in_ie) {
 		rtw_warn_on(1);
-		return wpsie_ptr;
+		return (u8 *)wpsie_ptr;
 	}
 
 	if (in_len <= 0)
-		return wpsie_ptr;
+		return (u8 *)wpsie_ptr;
 
 	cnt = 0;
 
@@ -1012,13 +992,12 @@ u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
 				*wps_ielen = in_ie[cnt + 1] + 2;
 
 			break;
-		} else {
+		} else
 			cnt += in_ie[cnt + 1] + 2;
-		}
 
 	}
 
-	return wpsie_ptr;
+	return (u8 *)wpsie_ptr;
 }
 
 /**
@@ -1031,50 +1010,44 @@ u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
  *
  * Returns: the address of the specific WPS attribute found, or NULL
  */
-u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8 *buf_attr, u32 *len_attr)
+u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_attr, u32 *len_attr)
 {
 	u8 *attr_ptr = NULL;
-	u8 * target_attr_ptr = NULL;
-	u8 wps_oui[4]={0x00,0x50,0xF2,0x04};
+	u8 *target_attr_ptr = NULL;
+	u8 wps_oui[4] = {0x00, 0x50, 0xF2, 0x04};
 
-	if(len_attr)
+	if (len_attr)
 		*len_attr = 0;
 
-	if ( ( wps_ie[0] != _VENDOR_SPECIFIC_IE_ ) ||
-		( _rtw_memcmp( wps_ie + 2, wps_oui , 4 ) != _TRUE ) )
-	{
+	if ((wps_ie[0] != _VENDOR_SPECIFIC_IE_) ||
+	    (_rtw_memcmp(wps_ie + 2, wps_oui , 4) != _TRUE))
 		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)
+	/* 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 = RTW_GET_BE16(attr_ptr);
 		u16 attr_data_len = RTW_GET_BE16(attr_ptr + 2);
 		u16 attr_len = attr_data_len + 4;
-		
-		//DBG_871X("%s attr_ptr:%p, id:%u, length:%u\n", __FUNCTION__, attr_ptr, attr_id, attr_data_len);
-		if( attr_id == target_attr_id )
-		{
+
+		/* RTW_INFO("%s attr_ptr:%p, id:%u, length:%u\n", __FUNCTION__, attr_ptr, attr_id, attr_data_len); */
+		if (attr_id == target_attr_id) {
 			target_attr_ptr = attr_ptr;
-		
-			if(buf_attr)
+
+			if (buf_attr)
 				_rtw_memcpy(buf_attr, attr_ptr, attr_len);
-			
-			if(len_attr)
+
+			if (len_attr)
 				*len_attr = attr_len;
-			
+
 			break;
+		} else {
+			attr_ptr += attr_len; /* goto next */
 		}
-		else
-		{
-			attr_ptr += attr_len; //goto next
-		}		
-		
-	}	
+
+	}
 
 	return target_attr_ptr;
 }
@@ -1089,33 +1062,32 @@ u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8 *buf_att
  *
  * Returns: the address of the specific WPS attribute content found, or NULL
  */
-u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8 *buf_content, uint *len_content)
+u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_content, uint *len_content)
 {
 	u8 *attr_ptr;
 	u32 attr_len;
 
-	if(len_content)
+	if (len_content)
 		*len_content = 0;
-	
+
 	attr_ptr = rtw_get_wps_attr(wps_ie, wps_ielen, target_attr_id, NULL, &attr_len);
 
-	if(attr_ptr && attr_len)
-	{
-		if(buf_content)
-			_rtw_memcpy(buf_content, attr_ptr+4, attr_len-4);
+	if (attr_ptr && attr_len) {
+		if (buf_content)
+			_rtw_memcpy(buf_content, attr_ptr + 4, attr_len - 4);
 
-		if(len_content)
-			*len_content = attr_len-4;
+		if (len_content)
+			*len_content = attr_len - 4;
 
-		return attr_ptr+4;
+		return attr_ptr + 4;
 	}
 
 	return NULL;
 }
 
 static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
-					    struct rtw_ieee802_11_elems *elems,
-					    int show_errors)
+		struct rtw_ieee802_11_elems *elems,
+		int show_errors)
 {
 	unsigned int oui;
 
@@ -1124,9 +1096,9 @@ static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
 	 * sub-type. */
 	if (elen < 4) {
 		if (show_errors) {
-			DBG_871X("short vendor specific "
-				   "information element ignored (len=%lu)\n",
-				   (unsigned long) elen);
+			RTW_INFO("short vendor specific "
+				 "information element ignored (len=%lu)\n",
+				 (unsigned long) elen);
 		}
 		return -1;
 	}
@@ -1145,10 +1117,10 @@ static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
 			break;
 		case WME_OUI_TYPE: /* this is a Wi-Fi WME info. element */
 			if (elen < 5) {
-				DBG_871X("short WME "
-					   "information element ignored "
-					   "(len=%lu)\n",
-					   (unsigned long) elen);
+				RTW_DBG("short WME "
+					"information element ignored "
+					"(len=%lu)\n",
+					(unsigned long) elen);
 				return -1;
 			}
 			switch (pos[4]) {
@@ -1162,10 +1134,10 @@ static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
 				elems->wme_tspec_len = elen;
 				break;
 			default:
-				DBG_871X_LEVEL(_drv_warning_, "unknown WME "
-					   "information element ignored "
-					   "(subtype=%d len=%lu)\n",
-					   pos[4], (unsigned long) elen);
+				RTW_DBG("unknown WME "
+					"information element ignored "
+					"(subtype=%d len=%lu)\n",
+					pos[4], (unsigned long) elen);
 				return -1;
 			}
 			break;
@@ -1175,10 +1147,10 @@ static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
 			elems->wps_ie_len = elen;
 			break;
 		default:
-			DBG_871X_LEVEL(_drv_warning_, "Unknown Microsoft "
-				   "information element ignored "
-				   "(type=%d len=%lu)\n",
-				   pos[3], (unsigned long) elen);
+			RTW_DBG("Unknown Microsoft "
+				"information element ignored "
+				"(type=%d len=%lu)\n",
+				pos[3], (unsigned long) elen);
 			return -1;
 		}
 		break;
@@ -1190,24 +1162,24 @@ static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
 			elems->vendor_ht_cap_len = elen;
 			break;
 		default:
-			DBG_871X_LEVEL(_drv_warning_, "Unknown Broadcom "
-				   "information element ignored "
-				   "(type=%d len=%lu)\n",
-				   pos[3], (unsigned long) elen);
+			RTW_DBG("Unknown Broadcom "
+				"information element ignored "
+				"(type=%d len=%lu)\n",
+				pos[3], (unsigned long) elen);
 			return -1;
 		}
 		break;
 
 	default:
-		DBG_871X_LEVEL(_drv_warning_, "unknown vendor specific information "
-			   "element ignored (vendor OUI %02x:%02x:%02x "
-			   "len=%lu)\n",
-			   pos[0], pos[1], pos[2], (unsigned long) elen);
+		RTW_DBG("unknown vendor specific information "
+			"element ignored (vendor OUI %02x:%02x:%02x "
+			"len=%lu)\n",
+			pos[0], pos[1], pos[2], (unsigned long) elen);
 		return -1;
 	}
 
 	return 0;
-	
+
 }
 
 /**
@@ -1219,8 +1191,8 @@ static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
  * Returns: Parsing result
  */
 ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
-				struct rtw_ieee802_11_elems *elems,
-				int show_errors)
+				    struct rtw_ieee802_11_elems *elems,
+				    int show_errors)
 {
 	uint left = len;
 	u8 *pos = start;
@@ -1237,10 +1209,10 @@ ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
 
 		if (elen > left) {
 			if (show_errors) {
-				DBG_871X("IEEE 802.11 element "
-					   "parse failed (id=%d elen=%d "
-					   "left=%lu)\n",
-					   id, elen, (unsigned long) left);				
+				RTW_INFO("IEEE 802.11 element "
+					 "parse failed (id=%d elen=%d "
+					 "left=%lu)\n",
+					 id, elen, (unsigned long) left);
 			}
 			return ParseFailed;
 		}
@@ -1288,8 +1260,8 @@ ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
 			break;
 		case WLAN_EID_VENDOR_SPECIFIC:
 			if (rtw_ieee802_11_parse_vendor_specific(pos, elen,
-							     elems,
-							     show_errors))
+					elems,
+					show_errors))
 				unknown++;
 			break;
 		case WLAN_EID_RSN:
@@ -1336,12 +1308,33 @@ ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
 			elems->vht_op_mode_notify = pos;
 			elems->vht_op_mode_notify_len = elen;
 			break;
+		case _EID_RRM_EN_CAP_IE_:
+			elems->rm_en_cap = pos;
+			elems->rm_en_cap_len = elen;
+			break;
+#ifdef CONFIG_RTW_MESH
+		case WLAN_EID_PREQ:
+			elems->preq = pos;
+			elems->preq_len = elen;
+			break;
+		case WLAN_EID_PREP:
+			elems->prep = pos;
+			elems->prep_len = elen;
+			break;
+		case WLAN_EID_PERR:
+			elems->perr = pos;
+			elems->perr_len = elen;
+			break;
+		case WLAN_EID_RANN:
+			elems->rann = pos;
+			elems->rann_len = elen;
+			break;
+#endif
 		default:
 			unknown++;
 			if (!show_errors)
 				break;
-			DBG_871X_LEVEL(_drv_warning_,
-				"IEEE 802.11 element parse "
+			RTW_DBG("IEEE 802.11 element parse "
 				"ignored unknown element (id=%d elen=%d)\n",
 				id, elen);
 			break;
@@ -1355,32 +1348,32 @@ ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
 		return ParseFailed;
 
 	return unknown ? ParseUnknown : ParseOK;
-	
+
 }
 
 static u8 key_char2num(u8 ch);
 static u8 key_char2num(u8 ch)
 {
-    if((ch>='0')&&(ch<='9'))
-        return ch - '0';
-    else if ((ch>='a')&&(ch<='f'))
-        return ch - 'a' + 10;
-    else if ((ch>='A')&&(ch<='F'))
-        return ch - 'A' + 10;
-    else
-	 return 0xff;
+	if ((ch >= '0') && (ch <= '9'))
+		return ch - '0';
+	else if ((ch >= 'a') && (ch <= 'f'))
+		return ch - 'a' + 10;
+	else if ((ch >= 'A') && (ch <= 'F'))
+		return ch - 'A' + 10;
+	else
+		return 0xff;
 }
 
 u8 str_2char2num(u8 hch, u8 lch);
 u8 str_2char2num(u8 hch, u8 lch)
 {
-    return ((key_char2num(hch) * 10 ) + key_char2num(lch));
+	return (key_char2num(hch) * 10) + key_char2num(lch);
 }
 
 u8 key_2char2num(u8 hch, u8 lch);
 u8 key_2char2num(u8 hch, u8 lch)
 {
-    return ((key_char2num(hch) << 4) | key_char2num(lch));
+	return (key_char2num(hch) << 4) | key_char2num(lch);
 }
 
 void macstr2num(u8 *dst, u8 *src);
@@ -1388,14 +1381,12 @@ void macstr2num(u8 *dst, u8 *src)
 {
 	int	jj, kk;
 	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
-	{
 		dst[jj] = key_2char2num(src[kk], src[kk + 1]);
-	}
 }
 
 u8 convert_ip_addr(u8 hch, u8 mch, u8 lch)
 {
-    return ((key_char2num(hch) * 100) + (key_char2num(mch) * 10 ) + key_char2num(lch));
+	return (key_char2num(hch) * 100) + (key_char2num(mch) * 10) + key_char2num(lch);
 }
 
 #ifdef CONFIG_PLATFORM_INTEL_BYT
@@ -1408,32 +1399,28 @@ int rtw_get_mac_addr_intel(unsigned char *buf)
 	struct file *fp = NULL;
 	mm_segment_t oldfs;
 	unsigned char c_mac[MAC_ADDRESS_LEN];
-	char fname[]="/config/wifi/mac.txt";
-	int jj,kk;
+	char fname[] = "/config/wifi/mac.txt";
+	int jj, kk;
 
-	DBG_871X("%s Enter\n", __FUNCTION__);
+	RTW_INFO("%s Enter\n", __FUNCTION__);
 
 	ret = rtw_retrieve_from_file(fname, c_mac, MAC_ADDRESS_LEN);
-	if(ret < MAC_ADDRESS_LEN)
-	{
+	if (ret < MAC_ADDRESS_LEN)
 		return -1;
-	}
 
-	for( jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 2 )
-	{
-		buf[jj] = key_2char2num(c_mac[kk], c_mac[kk+ 1]);
-	}
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 2)
+		buf[jj] = key_2char2num(c_mac[kk], c_mac[kk + 1]);
 
-	DBG_871X("%s: read from file mac address: "MAC_FMT"\n",
+	RTW_INFO("%s: read from file mac address: "MAC_FMT"\n",
 		 __FUNCTION__, MAC_ARG(buf));
 
 	return 0;
 }
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 
 /*
  * Description:
- * rtw_check_invalid_mac_address: 
+ * rtw_check_invalid_mac_address:
  * This is only used for checking mac address valid or not.
  *
  * Input:
@@ -1479,11 +1466,6 @@ func_exit:
 }
 
 extern char *rtw_initmac;
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
-#include <linux/rfkill-wlan.h>
-#else
-extern int rk29sdk_wifi_mac_addr(unsigned char *buf);
-#endif
 /**
  * rtw_macaddr_cfg - Decide the mac address used
  * @out: buf to store mac address decided
@@ -1501,7 +1483,7 @@ void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr)
 
 	/* Users specify the mac address */
 	if (rtw_initmac) {
-		int jj,kk;
+		int jj, kk;
 
 		for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
 			mac[jj] = key_2char2num(rtw_initmac[kk], rtw_initmac[kk + 1]);
@@ -1509,28 +1491,6 @@ void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr)
 		goto err_chk;
 	}
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))	
-	if (!rockchip_wifi_mac_addr(mac)) {
-		printk("=========> get mac address from flash=[%02x:%02x:%02x:%02x:%02x:%02x]\n", mac[0], mac[1],
-                mac[2], mac[3], mac[4], mac[5]);
-		//_rtw_memcpy(mac_addr, mac, ETH_ALEN);
-		goto err_chk;
-	}
-#else
-#ifndef CONFIG_ANDROID_4_2
-{
-	u8 macbuf[30] = {0};
-	if (!rk29sdk_wifi_mac_addr(macbuf)) {
-		int jj,kk;
-		printk("=========> get mac address from flash %s\n", macbuf);
-		for( jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3 )
-		    mac[jj] = key_2char2num(macbuf[kk], macbuf[kk+ 1]);
-		goto err_chk;
-	}
-}
-#endif
-#endif	
-
 	/* platform specified */
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 	if (rtw_get_mac_addr_intel(mac) == 0)
@@ -1545,91 +1505,134 @@ void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr)
 
 err_chk:
 	if (rtw_check_invalid_mac_address(mac, _TRUE) == _TRUE) {
-		#if DEFAULT_RANDOM_MACADDR
-		DBG_871X_LEVEL(_drv_err_, "invalid mac addr:"MAC_FMT", assign random MAC\n", MAC_ARG(mac));
+#if DEFAULT_RANDOM_MACADDR
+		RTW_ERR("invalid mac addr:"MAC_FMT", assign random MAC\n", MAC_ARG(mac));
 		*((u32 *)(&mac[2])) = rtw_random32();
 		mac[0] = 0x00;
 		mac[1] = 0xe0;
 		mac[2] = 0x4c;
-		#else
-		DBG_871X_LEVEL(_drv_err_, "invalid mac addr:"MAC_FMT", assign default one\n", MAC_ARG(mac));
+#else
+		RTW_ERR("invalid mac addr:"MAC_FMT", assign default one\n", MAC_ARG(mac));
 		mac[0] = 0x00;
 		mac[1] = 0xe0;
 		mac[2] = 0x4c;
 		mac[3] = 0x87;
 		mac[4] = 0x00;
 		mac[5] = 0x00;
-		#endif
+#endif
 	}
 
 	_rtw_memcpy(out, mac, ETH_ALEN);
-	DBG_871X("%s mac addr:"MAC_FMT"\n", __func__, MAC_ARG(out));
+	RTW_INFO("%s mac addr:"MAC_FMT"\n", __func__, MAC_ARG(out));
 }
 
 #ifdef CONFIG_80211N_HT
-void dump_ht_cap_ie_content(void *sel, u8 *buf, u32 buf_len)
+void dump_ht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len)
 {
-	if (buf_len != 26) {
-		DBG_871X_SEL_NL(sel, "Invalid HT capability IE len:%d != %d\n", buf_len, 26);
+	if (buf_len != HT_CAP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid HT capability IE len:%d != %d\n", buf_len, HT_CAP_IE_LEN);
 		return;
 	}
 
-	DBG_871X_SEL_NL(sel, "HT Capabilities Info:%02x%02x\n", *(buf), *(buf+1));
-	DBG_871X_SEL_NL(sel, "A-MPDU Parameters:"HT_AMPDU_PARA_FMT"\n"
-		, HT_AMPDU_PARA_ARG(HT_CAP_ELE_AMPDU_PARA(buf)));
-	DBG_871X_SEL_NL(sel, "Supported MCS Set:"HT_SUP_MCS_SET_FMT"\n"
-		, HT_SUP_MCS_SET_ARG(HT_CAP_ELE_SUP_MCS_SET(buf)));
+	RTW_PRINT_SEL(sel, "cap_info:%02x%02x:%s\n", *(buf), *(buf + 1)
+		, GET_HT_CAP_ELE_CHL_WIDTH(buf) ? " 40MHz" : " 20MHz");
+	RTW_PRINT_SEL(sel, "A-MPDU Parameters:"HT_AMPDU_PARA_FMT"\n"
+		      , HT_AMPDU_PARA_ARG(HT_CAP_ELE_AMPDU_PARA(buf)));
+	RTW_PRINT_SEL(sel, "Supported MCS Set:"HT_SUP_MCS_SET_FMT"\n"
+		      , HT_SUP_MCS_SET_ARG(HT_CAP_ELE_SUP_MCS_SET(buf)));
 }
 
-void dump_ht_cap_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_ht_cap_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8* pos = (u8*)ie;
+	const u8 *pos = ie;
 	u16 id;
 	u16 len;
 
-	u8 *ht_cap_ie;
+	const u8 *ht_cap_ie;
 	sint ht_cap_ielen;
 
-	ht_cap_ie = rtw_get_ie(ie, _HT_CAPABILITY_IE_, &ht_cap_ielen, ie_len);
-	if(!ie || ht_cap_ie != ie)
+	ht_cap_ie = rtw_get_ie(ie, WLAN_EID_HT_CAP, &ht_cap_ielen, ie_len);
+	if (!ie || ht_cap_ie != ie)
+		return;
+
+	dump_ht_cap_ie_content(sel, ht_cap_ie + 2, ht_cap_ielen);
+}
+
+const char *const _ht_sc_offset_str[] = {
+	"SCN",
+	"SCA",
+	"SC-RSVD",
+	"SCB",
+};
+
+void dump_ht_op_ie_content(void *sel, const u8 *buf, u32 buf_len)
+{
+	if (buf_len != HT_OP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid HT operation IE len:%d != %d\n", buf_len, HT_OP_IE_LEN);
 		return;
+	}
 
-	dump_ht_cap_ie_content(sel, ht_cap_ie+2, ht_cap_ielen);
+	RTW_PRINT_SEL(sel, "ch:%u%s %s\n"
+		, GET_HT_OP_ELE_PRI_CHL(buf)
+		, GET_HT_OP_ELE_STA_CHL_WIDTH(buf) ? "" : " 20MHz only"
+		, ht_sc_offset_str(GET_HT_OP_ELE_2ND_CHL_OFFSET(buf))
+	);
+}
+
+void dump_ht_op_ie(void *sel, const u8 *ie, u32 ie_len)
+{
+	const u8 *pos = ie;
+	u16 id;
+	u16 len;
+
+	const u8 *ht_op_ie;
+	sint ht_op_ielen;
+
+	ht_op_ie = rtw_get_ie(ie, WLAN_EID_HT_OPERATION, &ht_op_ielen, ie_len);
+	if (!ie || ht_op_ie != ie)
+		return;
+
+	dump_ht_op_ie_content(sel, ht_op_ie + 2, ht_op_ielen);
 }
 #endif /* CONFIG_80211N_HT */
 
-void dump_ies(void *sel, u8 *buf, u32 buf_len)
+void dump_ies(void *sel, const u8 *buf, u32 buf_len)
 {
-	u8* pos = (u8*)buf;
+	const u8 *pos = buf;
 	u8 id, len;
 
-	while(pos-buf+1<buf_len){
+	while (pos - buf + 1 < buf_len) {
 		id = *pos;
-		len = *(pos+1);
+		len = *(pos + 1);
 
-		DBG_871X_SEL_NL(sel, "%s ID:%u, LEN:%u\n", __FUNCTION__, id, len);
-		#ifdef CONFIG_80211N_HT
+		RTW_PRINT_SEL(sel, "%s ID:%u, LEN:%u\n", __FUNCTION__, id, len);
+#ifdef CONFIG_80211N_HT
 		dump_ht_cap_ie(sel, pos, len + 2);
-		#endif
+		dump_ht_op_ie(sel, pos, len + 2);
+#endif
+#ifdef CONFIG_80211AC_VHT
+		dump_vht_cap_ie(sel, pos, len + 2);
+		dump_vht_op_ie(sel, pos, len + 2);
+#endif
 		dump_wps_ie(sel, pos, len + 2);
-		#ifdef CONFIG_P2P
+#ifdef CONFIG_P2P
 		dump_p2p_ie(sel, pos, len + 2);
-		#ifdef CONFIG_WFD
+#ifdef CONFIG_WFD
 		dump_wfd_ie(sel, pos, len + 2);
-		#endif
-		#endif
+#endif
+#endif
 
-		pos+=(2+len);
+		pos += (2 + len);
 	}
 }
 
-void dump_wps_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_wps_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8* pos = (u8*)ie;
+	const u8 *pos = ie;
 	u16 id;
 	u16 len;
 
-	u8 *wps_ie;
+	const u8 *wps_ie;
 	uint wps_ielen;
 
 	wps_ie = rtw_get_wps_ie(ie, ie_len, NULL, &wps_ielen);
@@ -1641,7 +1644,7 @@ void dump_wps_ie(void *sel, u8 *ie, u32 ie_len)
 		id = RTW_GET_BE16(pos);
 		len = RTW_GET_BE16(pos + 2);
 
-		DBG_871X_SEL_NL(sel, "%s ID:0x%04x, LEN:%u%s\n", __func__, id, len
+		RTW_PRINT_SEL(sel, "%s ID:0x%04x, LEN:%u%s\n", __func__, id, len
 			, ((pos - ie + 4 + len) <= ie_len) ? "" : "(exceed ie_len)");
 
 		pos += (4 + len);
@@ -1655,8 +1658,10 @@ void dump_wps_ie(void *sel, u8 *ie, u32 ie_len)
  * @ch: pointer of ch, used as output
  * @bw: pointer of bw, used as output
  * @offset: pointer of offset, used as output
+ * @ht: check HT IEs
+ * @vht: check VHT IEs, if true imply ht is true
  */
-void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset)
+void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht)
 {
 	u8 *p;
 	int	ie_len;
@@ -1670,66 +1675,68 @@ void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset)
 		*ch = *(p + 2);
 
 #ifdef CONFIG_80211N_HT
-{
-	u8 *ht_cap_ie, *ht_op_ie;
-	int ht_cap_ielen, ht_op_ielen;
-
-	ht_cap_ie = rtw_get_ie(ies, EID_HTCapability, &ht_cap_ielen, ies_len);
-	if (ht_cap_ie && ht_cap_ielen) {
-		if (GET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2))
-			*bw = CHANNEL_WIDTH_40;
-	}
-
-	ht_op_ie = rtw_get_ie(ies, EID_HTInfo, &ht_op_ielen, ies_len);
-	if (ht_op_ie && ht_op_ielen) {
-		if (*ch == 0) {
-			*ch = GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2);
-		} else if (*ch != 0 && *ch != GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2)) {
-			DBG_871X("%s ch inconsistent, DSSS:%u, HT primary:%u\n"
-				, __func__, *ch, GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2));
+	if (ht || vht) {
+		u8 *ht_cap_ie, *ht_op_ie;
+		int ht_cap_ielen, ht_op_ielen;
+
+		ht_cap_ie = rtw_get_ie(ies, EID_HTCapability, &ht_cap_ielen, ies_len);
+		if (ht_cap_ie && ht_cap_ielen) {
+			if (GET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2))
+				*bw = CHANNEL_WIDTH_40;
 		}
 
-		if (!GET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2))
-			*bw = CHANNEL_WIDTH_20;
+		ht_op_ie = rtw_get_ie(ies, EID_HTInfo, &ht_op_ielen, ies_len);
+		if (ht_op_ie && ht_op_ielen) {
+			if (*ch == 0)
+				*ch = GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2);
+			else if (*ch != 0 && *ch != GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2)) {
+				RTW_INFO("%s ch inconsistent, DSSS:%u, HT primary:%u\n"
+					, __func__, *ch, GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2));
+			}
 
-		if (*bw == CHANNEL_WIDTH_40) {
-			switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2)) {
-			case SCA:
-				*offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-				break;
-			case SCB:
-				*offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-				break;
+			if (!GET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2))
+				*bw = CHANNEL_WIDTH_20;
+
+			if (*bw == CHANNEL_WIDTH_40) {
+				switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2)) {
+				case SCA:
+					*offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+					break;
+				case SCB:
+					*offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+					break;
+				}
 			}
 		}
-	}
-}
-#endif /* CONFIG_80211N_HT */
+
 #ifdef CONFIG_80211AC_VHT
-{
-	u8 *vht_op_ie;
-	int vht_op_ielen;
+		if (vht) {
+			u8 *vht_op_ie;
+			int vht_op_ielen;
+
+			vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
+			if (vht_op_ie && vht_op_ielen) {
+				if (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2) >= 1)
+					*bw = CHANNEL_WIDTH_80;
+			}
+		}
+#endif /* CONFIG_80211AC_VHT */
 
-	vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
-	if (vht_op_ie && vht_op_ielen) {
-		if (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2) >= 1)
-			*bw = CHANNEL_WIDTH_80;
 	}
-}
-#endif
+#endif /* CONFIG_80211N_HT */
 }
 
-void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset)
+void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht)
 {
 	rtw_ies_get_chbw(bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)
 		, bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)
-		, ch, bw, offset);
+		, ch, bw, offset, ht, vht);
 
-	if (*ch == 0) {
+	if (*ch == 0)
 		*ch = bss->Configuration.DSConfig;
-	} else if (*ch != bss->Configuration.DSConfig) {
-		DBG_871X("inconsistent ch - ies:%u bss->Configuration.DSConfig:%u\n"
-			, *ch, bss->Configuration.DSConfig);
+	else if (*ch != bss->Configuration.DSConfig) {
+		RTW_INFO("inconsistent ch - ies:%u bss->Configuration.DSConfig:%u\n"
+			 , *ch, bss->Configuration.DSConfig);
 		*ch = bss->Configuration.DSConfig;
 		rtw_warn_on(1);
 	}
@@ -1745,7 +1752,7 @@ void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset)
  * @offset_b: offset of set b
  */
 bool rtw_is_chbw_grouped(u8 ch_a, u8 bw_a, u8 offset_a
-	, u8 ch_b, u8 bw_b, u8 offset_b)
+			 , u8 ch_b, u8 bw_b, u8 offset_b)
 {
 	bool is_grouped = _FALSE;
 
@@ -1753,8 +1760,8 @@ bool rtw_is_chbw_grouped(u8 ch_a, u8 bw_a, u8 offset_a
 		/* ch is different */
 		goto exit;
 	} else if ((bw_a == CHANNEL_WIDTH_40 || bw_a == CHANNEL_WIDTH_80)
-			&& (bw_b == CHANNEL_WIDTH_40 || bw_b == CHANNEL_WIDTH_80)
-	) {
+		   && (bw_b == CHANNEL_WIDTH_40 || bw_b == CHANNEL_WIDTH_80)
+		  ) {
 		if (offset_a != offset_b)
 			goto exit;
 	}
@@ -1775,7 +1782,7 @@ exit:
  * @g_offset: pointer of the ongoing group offset, may be modified further
  */
 void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
-	, u8 *g_ch, u8 *g_bw, u8 *g_offset)
+		   , u8 *g_ch, u8 *g_bw, u8 *g_offset)
 {
 
 	*req_ch = *g_ch;
@@ -1790,10 +1797,10 @@ void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
 		if (*g_bw == CHANNEL_WIDTH_40 || *g_bw == CHANNEL_WIDTH_80)
 			*req_offset = *g_offset;
 		else if (*g_bw == CHANNEL_WIDTH_20)
-			*req_offset = rtw_get_offset_by_ch(*req_ch);
+			rtw_get_offset_by_chbw(*req_ch, *req_bw, req_offset);
 
 		if (*req_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
-			DBG_871X_LEVEL(_drv_err_, "%s req 80MHz BW without offset, down to 20MHz\n", __func__);
+			RTW_ERR("%s req 80MHz BW without offset, down to 20MHz\n", __func__);
 			rtw_warn_on(1);
 			*req_bw = CHANNEL_WIDTH_20;
 		}
@@ -1802,10 +1809,10 @@ void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
 		if (*g_bw == CHANNEL_WIDTH_40 || *g_bw == CHANNEL_WIDTH_80)
 			*req_offset = *g_offset;
 		else if (*g_bw == CHANNEL_WIDTH_20)
-			*req_offset = rtw_get_offset_by_ch(*req_ch);
+			rtw_get_offset_by_chbw(*req_ch, *req_bw, req_offset);
 
 		if (*req_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
-			DBG_871X_LEVEL(_drv_err_, "%s req 40MHz BW without offset, down to 20MHz\n", __func__);
+			RTW_ERR("%s req 40MHz BW without offset, down to 20MHz\n", __func__);
 			rtw_warn_on(1);
 			*req_bw = CHANNEL_WIDTH_20;
 		}
@@ -1814,7 +1821,7 @@ void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
 		*req_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 		break;
 	default:
-		DBG_871X_LEVEL(_drv_err_, "%s req unsupported BW:%u\n", __func__, *req_bw);
+		RTW_ERR("%s req unsupported BW:%u\n", __func__, *req_bw);
 		rtw_warn_on(1);
 	}
 
@@ -1834,22 +1841,20 @@ u32 rtw_get_p2p_merged_ies_len(u8 *in_ie, u32 in_len)
 {
 	PNDIS_802_11_VARIABLE_IEs	pIE;
 	u8 OUI[4] = { 0x50, 0x6f, 0x9a, 0x09 };
-	int i=0;
-	int j=0, len=0;
+	int i = 0;
+	int j = 0, len = 0;
 
-	while( i < in_len)
-	{
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(in_ie+ i);
+	while (i < in_len) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(in_ie + i);
 
-		if( pIE->ElementID == _VENDOR_SPECIFIC_IE_ && _rtw_memcmp(pIE->data, OUI, 4) )
-		{
-			len += pIE->Length-4; // 4 is P2P OUI length, don't count it in this loop
+		if (pIE->ElementID == _VENDOR_SPECIFIC_IE_ && _rtw_memcmp(pIE->data, OUI, 4)) {
+			len += pIE->Length - 4; /* 4 is P2P OUI length, don't count it in this loop */
 		}
 
 		i += (pIE->Length + 2);
 	}
 
-	return len + 4;	// Append P2P OUI length at last.
+	return len + 4;	/* Append P2P OUI length at last. */
 }
 
 /**
@@ -1864,44 +1869,41 @@ int rtw_p2p_merge_ies(u8 *in_ie, u32 in_len, u8 *merge_ie)
 	PNDIS_802_11_VARIABLE_IEs	pIE;
 	u8 len = 0;
 	u8 OUI[4] = { 0x50, 0x6f, 0x9a, 0x09 };
-	u8 ELOUI[6] = { 0xDD, 0x00, 0x50, 0x6f, 0x9a, 0x09 };	//EID;Len;OUI, Len would copy at the end of function
-	int i=0;
+	u8 ELOUI[6] = { 0xDD, 0x00, 0x50, 0x6f, 0x9a, 0x09 };	/* EID;Len;OUI, Len would copy at the end of function */
+	int i = 0;
 
-	if( merge_ie != NULL)
-	{
-		//Set first P2P OUI
+	if (merge_ie != NULL) {
+		/* Set first P2P OUI */
 		_rtw_memcpy(merge_ie, ELOUI, 6);
 		merge_ie += 6;
 
-		while( i < in_len)
-		{
-			pIE = (PNDIS_802_11_VARIABLE_IEs)(in_ie+ i);
+		while (i < in_len) {
+			pIE = (PNDIS_802_11_VARIABLE_IEs)(in_ie + i);
 
-			// Take out the rest of P2P OUIs
-			if( pIE->ElementID == _VENDOR_SPECIFIC_IE_ && _rtw_memcmp(pIE->data, OUI, 4) )
-			{
-				_rtw_memcpy( merge_ie, pIE->data +4, pIE->Length -4);
-				len += pIE->Length-4;
-				merge_ie += pIE->Length-4;
+			/* Take out the rest of P2P OUIs */
+			if (pIE->ElementID == _VENDOR_SPECIFIC_IE_ && _rtw_memcmp(pIE->data, OUI, 4)) {
+				_rtw_memcpy(merge_ie, pIE->data + 4, pIE->Length - 4);
+				len += pIE->Length - 4;
+				merge_ie += pIE->Length - 4;
 			}
 
 			i += (pIE->Length + 2);
 		}
 
-		return len + 4;	// 4 is for P2P OUI
+		return len + 4;	/* 4 is for P2P OUI */
 
 	}
 
 	return 0;
 }
 
-void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_p2p_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8* pos = (u8*)ie;
+	const u8 *pos = ie;
 	u8 id;
 	u16 len;
 
-	u8 *p2p_ie;
+	const u8 *p2p_ie;
 	uint p2p_ielen;
 
 	p2p_ie = rtw_get_p2p_ie(ie, ie_len, NULL, &p2p_ielen);
@@ -1913,7 +1915,7 @@ void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len)
 		id = *pos;
 		len = RTW_GET_LE16(pos + 1);
 
-		DBG_871X_SEL_NL(sel, "%s ID:%u, LEN:%u%s\n", __func__, id, len
+		RTW_PRINT_SEL(sel, "%s ID:%u, LEN:%u%s\n", __func__, id, len
 			, ((pos - ie + 3 + len) <= ie_len) ? "" : "(exceed ie_len)");
 
 		pos += (3 + len);
@@ -1929,10 +1931,10 @@ void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len)
  *
  * Returns: The address of the P2P IE found, or NULL
  */
-u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
+u8 *rtw_get_p2p_ie(const u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
 {
 	uint cnt;
-	u8 *p2p_ie_ptr = NULL;
+	const u8 *p2p_ie_ptr = NULL;
 	u8 eid, p2p_oui[4] = {0x50, 0x6F, 0x9A, 0x09};
 
 	if (p2p_ielen)
@@ -1940,11 +1942,11 @@ u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
 
 	if (!in_ie || in_len < 0) {
 		rtw_warn_on(1);
-		return p2p_ie_ptr;
+		return (u8 *)p2p_ie_ptr;
 	}
 
 	if (in_len <= 0)
-		return p2p_ie_ptr;
+		return (u8 *)p2p_ie_ptr;
 
 	cnt = 0;
 
@@ -1966,13 +1968,12 @@ u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
 				*p2p_ielen = in_ie[cnt + 1] + 2;
 
 			break;
-		} else {
+		} else
 			cnt += in_ie[cnt + 1] + 2;
-		}
 
 	}
 
-	return p2p_ie_ptr;
+	return (u8 *)p2p_ie_ptr;
 }
 
 /**
@@ -1985,7 +1986,7 @@ u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
  *
  * Returns: the address of the specific WPS attribute found, or NULL
  */
-u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_attr, u32 *len_attr)
+u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id , u8 *buf_attr, u32 *len_attr)
 {
 	u8 *attr_ptr = NULL;
 	u8 *target_attr_ptr = NULL;
@@ -1995,9 +1996,9 @@ u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_attr
 		*len_attr = 0;
 
 	if (!p2p_ie
-		|| p2p_ielen <= 6
-		|| (p2p_ie[0] != WLAN_EID_VENDOR_SPECIFIC)
-		|| (_rtw_memcmp(p2p_ie + 2, p2p_oui, 4) != _TRUE))
+	    || p2p_ielen <= 6
+	    || (p2p_ie[0] != WLAN_EID_VENDOR_SPECIFIC)
+	    || (_rtw_memcmp(p2p_ie + 2, p2p_oui, 4) != _TRUE))
 		return attr_ptr;
 
 	/* 6 = 1(Element ID) + 1(Length) + 3 (OUI) + 1(OUI Type) */
@@ -2010,7 +2011,7 @@ u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_attr
 		u16 attr_len = attr_data_len + 3;
 
 		if (0)
-			DBG_871X("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len);
+			RTW_INFO("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len);
 
 		if ((attr_ptr - p2p_ie + attr_len) > p2p_ielen)
 			break;
@@ -2025,10 +2026,9 @@ u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_attr
 				*len_attr = attr_len;
 
 			break;
-		} else {
+		} else
 			attr_ptr += attr_len;
-		}
-	}	
+	}
 
 	return target_attr_ptr;
 }
@@ -2043,7 +2043,7 @@ u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_attr
  *
  * Returns: the address of the specific P2P attribute content found, or NULL
  */
-u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_content, uint *len_content)
+u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id , u8 *buf_content, uint *len_content)
 {
 	u8 *attr_ptr;
 	u32 attr_len;
@@ -2067,19 +2067,19 @@ u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *
 }
 
 u32 rtw_set_p2p_attr_content(u8 *pbuf, u8 attr_id, u16 attr_len, u8 *pdata_attr)
-{	
+{
 	u32 a_len;
 
 	*pbuf = attr_id;
-		
-	//*(u16*)(pbuf + 1) = cpu_to_le16(attr_len);
+
+	/* *(u16*)(pbuf + 1) = cpu_to_le16(attr_len); */
 	RTW_PUT_LE16(pbuf + 1, attr_len);
 
-	if(pdata_attr)
-		_rtw_memcpy(pbuf + 3, pdata_attr, attr_len);		
-		
+	if (pdata_attr)
+		_rtw_memcpy(pbuf + 3, pdata_attr, attr_len);
+
 	a_len = attr_len + 3;
-		
+
 	return a_len;
 }
 
@@ -2099,12 +2099,12 @@ uint rtw_del_p2p_ie(u8 *ies, uint ies_len_ori, const char *msg)
 			uint remain_len = ies_len - (next_ie - ies);
 
 			if (DBG_DEL_P2P_IE && msg) {
-				DBG_871X("%s %d before\n", __func__, index);
+				RTW_INFO("%s %d before\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ies, ies_len);
 
-				DBG_871X("ies:%p, ies_len:%u\n", ies, ies_len);
-				DBG_871X("target_ie:%p, target_ie_len:%u\n", target_ie, target_ie_len);
-				DBG_871X("next_ie:%p, remain_len:%u\n", next_ie, remain_len);
+				RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
+				RTW_INFO("target_ie:%p, target_ie_len:%u\n", target_ie, target_ie_len);
+				RTW_INFO("next_ie:%p, remain_len:%u\n", next_ie, remain_len);
 			}
 
 			_rtw_memmove(target_ie, next_ie, remain_len);
@@ -2112,14 +2112,13 @@ uint rtw_del_p2p_ie(u8 *ies, uint ies_len_ori, const char *msg)
 			ies_len -= target_ie_len;
 
 			if (DBG_DEL_P2P_IE && msg) {
-				DBG_871X("%s %d after\n", __func__, index);
+				RTW_INFO("%s %d after\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ies, ies_len);
 			}
 
 			index++;
-		} else {
+		} else
 			break;
-		}
 	}
 
 	return ies_len;
@@ -2134,19 +2133,19 @@ uint rtw_del_p2p_attr(u8 *ie, uint ielen_ori, u8 attr_id)
 	uint ielen = ielen_ori;
 	int index = 0;
 
-	while(1) {
+	while (1) {
 		target_attr = rtw_get_p2p_attr(ie, ielen, attr_id, NULL, &target_attr_len);
 		if (target_attr && target_attr_len) {
 			u8 *next_attr = target_attr + target_attr_len;
 			uint remain_len = ielen - (next_attr - ie);
 
 			if (DBG_DEL_P2P_ATTR) {
-				DBG_871X("%s %d before\n", __func__, index);
+				RTW_INFO("%s %d before\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ie, ielen);
 
-				DBG_871X("ie:%p, ielen:%u\n", ie, ielen);
-				DBG_871X("target_attr:%p, target_attr_len:%u\n", target_attr, target_attr_len);
-				DBG_871X("next_attr:%p, remain_len:%u\n", next_attr, remain_len);
+				RTW_INFO("ie:%p, ielen:%u\n", ie, ielen);
+				RTW_INFO("target_attr:%p, target_attr_len:%u\n", target_attr, target_attr_len);
+				RTW_INFO("next_attr:%p, remain_len:%u\n", next_attr, remain_len);
 			}
 
 			_rtw_memmove(target_attr, next_attr, remain_len);
@@ -2155,14 +2154,13 @@ uint rtw_del_p2p_attr(u8 *ie, uint ielen_ori, u8 attr_id)
 			ielen -= target_attr_len;
 
 			if (DBG_DEL_P2P_ATTR) {
-				DBG_871X("%s %d after\n", __func__, index);
+				RTW_INFO("%s %d after\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ie, ielen);
 			}
 
 			index++;
-		} else {
+		} else
 			break;
-		}
 	}
 
 	return ielen;
@@ -2206,12 +2204,12 @@ void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
 
 			if (DBG_BSS_EX_DEL_P2P_ATTR) {
 				if (rtw_get_p2p_attr(ie, ie_len_ori, attr_id, NULL, NULL)) {
-					DBG_871X("%s %d before\n", __func__, index);
+					RTW_INFO("%s %d before\n", __func__, index);
 					dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
 
-					DBG_871X("ies:%p, ies_len:%u\n", ies, ies_len);
-					DBG_871X("ie:%p, ie_len_ori:%u\n", ie, ie_len_ori);
-					DBG_871X("next_ie_ori:%p, remain_len:%u\n", next_ie_ori, remain_len);
+					RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
+					RTW_INFO("ie:%p, ie_len_ori:%u\n", ie, ie_len_ori);
+					RTW_INFO("next_ie_ori:%p, remain_len:%u\n", next_ie_ori, remain_len);
 					has_target_attr = 1;
 				}
 			}
@@ -2225,13 +2223,12 @@ void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
 				bss_ex->IELength -= ie_len_ori - ie_len;
 
 				ies = next_ie;
-			} else {
+			} else
 				ies = next_ie_ori;
-			}
 
 			if (DBG_BSS_EX_DEL_P2P_ATTR) {
 				if (has_target_attr) {
-					DBG_871X("%s %d after\n", __func__, index);
+					RTW_INFO("%s %d after\n", __func__, index);
 					dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
 				}
 			}
@@ -2239,19 +2236,18 @@ void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
 			ies_len = remain_len;
 
 			index++;
-		} else {
+		} else
 			break;
-		}
 	}
 }
 
-void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_wfd_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8* pos = (u8*)ie;
+	const u8 *pos = ie;
 	u8 id;
 	u16 len;
 
-	u8 *wfd_ie;
+	const u8 *wfd_ie;
 	uint wfd_ielen;
 
 	wfd_ie = rtw_get_wfd_ie(ie, ie_len, NULL, &wfd_ielen);
@@ -2263,7 +2259,7 @@ void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len)
 		id = *pos;
 		len = RTW_GET_BE16(pos + 1);
 
-		DBG_871X_SEL_NL(sel, "%s ID:%u, LEN:%u%s\n", __func__, id, len
+		RTW_PRINT_SEL(sel, "%s ID:%u, LEN:%u%s\n", __func__, id, len
 			, ((pos - ie + 3 + len) <= ie_len) ? "" : "(exceed ie_len)");
 
 		pos += (3 + len);
@@ -2279,10 +2275,10 @@ void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len)
  *
  * Returns: The address of the P2P IE found, or NULL
  */
-u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
+u8 *rtw_get_wfd_ie(const u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
 {
 	uint cnt;
-	u8 *wfd_ie_ptr = NULL;
+	const u8 *wfd_ie_ptr = NULL;
 	u8 eid, wfd_oui[4] = {0x50, 0x6F, 0x9A, 0x0A};
 
 	if (wfd_ielen)
@@ -2290,11 +2286,11 @@ u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
 
 	if (!in_ie || in_len < 0) {
 		rtw_warn_on(1);
-		return wfd_ie_ptr;
+		return (u8 *)wfd_ie_ptr;
 	}
 
 	if (in_len <= 0)
-		return wfd_ie_ptr;
+		return (u8 *)wfd_ie_ptr;
 
 	cnt = 0;
 
@@ -2316,13 +2312,12 @@ u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
 				*wfd_ielen = in_ie[cnt + 1] + 2;
 
 			break;
-		} else {
+		} else
 			cnt += in_ie[cnt + 1] + 2;
-		}
 
 	}
 
-	return wfd_ie_ptr;
+	return (u8 *)wfd_ie_ptr;
 }
 
 /**
@@ -2345,9 +2340,9 @@ u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr
 		*len_attr = 0;
 
 	if (!wfd_ie
-		|| wfd_ielen <= 6
-		|| (wfd_ie[0] != WLAN_EID_VENDOR_SPECIFIC)
-		|| (_rtw_memcmp(wfd_ie + 2, wfd_oui, 4) != _TRUE))
+	    || wfd_ielen <= 6
+	    || (wfd_ie[0] != WLAN_EID_VENDOR_SPECIFIC)
+	    || (_rtw_memcmp(wfd_ie + 2, wfd_oui, 4) != _TRUE))
 		return attr_ptr;
 
 	/* 6 = 1(Element ID) + 1(Length) + 3 (OUI) + 1(OUI Type) */
@@ -2360,7 +2355,7 @@ u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr
 		u16 attr_len = attr_data_len + 3;
 
 		if (0)
-			DBG_871X("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len);
+			RTW_INFO("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len);
 
 		if ((attr_ptr - wfd_ie + attr_len) > wfd_ielen)
 			break;
@@ -2375,9 +2370,8 @@ u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr
 				*len_attr = attr_len;
 
 			break;
-		} else {
+		} else
 			attr_ptr += attr_len;
-		}
 	}
 
 	return target_attr_ptr;
@@ -2432,12 +2426,12 @@ uint rtw_del_wfd_ie(u8 *ies, uint ies_len_ori, const char *msg)
 			uint remain_len = ies_len - (next_ie - ies);
 
 			if (DBG_DEL_WFD_IE && msg) {
-				DBG_871X("%s %d before\n", __func__, index);
+				RTW_INFO("%s %d before\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ies, ies_len);
 
-				DBG_871X("ies:%p, ies_len:%u\n", ies, ies_len);
-				DBG_871X("target_ie:%p, target_ie_len:%u\n", target_ie, target_ie_len);
-				DBG_871X("next_ie:%p, remain_len:%u\n", next_ie, remain_len);
+				RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
+				RTW_INFO("target_ie:%p, target_ie_len:%u\n", target_ie, target_ie_len);
+				RTW_INFO("next_ie:%p, remain_len:%u\n", next_ie, remain_len);
 			}
 
 			_rtw_memmove(target_ie, next_ie, remain_len);
@@ -2445,14 +2439,13 @@ uint rtw_del_wfd_ie(u8 *ies, uint ies_len_ori, const char *msg)
 			ies_len -= target_ie_len;
 
 			if (DBG_DEL_WFD_IE && msg) {
-				DBG_871X("%s %d after\n", __func__, index);
+				RTW_INFO("%s %d after\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ies, ies_len);
 			}
 
 			index++;
-		} else {
+		} else
 			break;
-		}
 	}
 
 	return ies_len;
@@ -2474,12 +2467,12 @@ uint rtw_del_wfd_attr(u8 *ie, uint ielen_ori, u8 attr_id)
 			uint remain_len = ielen - (next_attr - ie);
 
 			if (DBG_DEL_WFD_ATTR) {
-				DBG_871X("%s %d before\n", __func__, index);
+				RTW_INFO("%s %d before\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ie, ielen);
 
-				DBG_871X("ie:%p, ielen:%u\n", ie, ielen);
-				DBG_871X("target_attr:%p, target_attr_len:%u\n", target_attr, target_attr_len);
-				DBG_871X("next_attr:%p, remain_len:%u\n", next_attr, remain_len);
+				RTW_INFO("ie:%p, ielen:%u\n", ie, ielen);
+				RTW_INFO("target_attr:%p, target_attr_len:%u\n", target_attr, target_attr_len);
+				RTW_INFO("next_attr:%p, remain_len:%u\n", next_attr, remain_len);
 			}
 
 			_rtw_memmove(target_attr, next_attr, remain_len);
@@ -2488,14 +2481,13 @@ uint rtw_del_wfd_attr(u8 *ie, uint ielen_ori, u8 attr_id)
 			ielen -= target_attr_len;
 
 			if (DBG_DEL_WFD_ATTR) {
-				DBG_871X("%s %d after\n", __func__, index);
+				RTW_INFO("%s %d after\n", __func__, index);
 				dump_ies(RTW_DBGDUMP, ie, ielen);
 			}
 
 			index++;
-		} else {
+		} else
 			break;
-		}
 	}
 
 	return ielen;
@@ -2538,12 +2530,12 @@ void rtw_bss_ex_del_wfd_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
 
 			if (DBG_BSS_EX_DEL_WFD_ATTR) {
 				if (rtw_get_wfd_attr(ie, ie_len_ori, attr_id, NULL, NULL)) {
-					DBG_871X("%s %d before\n", __func__, index);
+					RTW_INFO("%s %d before\n", __func__, index);
 					dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
 
-					DBG_871X("ies:%p, ies_len:%u\n", ies, ies_len);
-					DBG_871X("ie:%p, ie_len_ori:%u\n", ie, ie_len_ori);
-					DBG_871X("next_ie_ori:%p, remain_len:%u\n", next_ie_ori, remain_len);
+					RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
+					RTW_INFO("ie:%p, ie_len_ori:%u\n", ie, ie_len_ori);
+					RTW_INFO("next_ie_ori:%p, remain_len:%u\n", next_ie_ori, remain_len);
 					has_target_attr = 1;
 				}
 			}
@@ -2557,13 +2549,12 @@ void rtw_bss_ex_del_wfd_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
 				bss_ex->IELength -= ie_len_ori - ie_len;
 
 				ies = next_ie;
-			} else {
+			} else
 				ies = next_ie_ori;
-			}
 
 			if (DBG_BSS_EX_DEL_WFD_ATTR) {
 				if (has_target_attr) {
-					DBG_871X("%s %d after\n", __func__, index);
+					RTW_INFO("%s %d after\n", __func__, index);
 					dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
 				}
 			}
@@ -2571,13 +2562,12 @@ void rtw_bss_ex_del_wfd_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
 			ies_len = remain_len;
 
 			index++;
-		} else {
+		} else
 			break;
-		}
 	}
 }
 
-//Baron adds to avoid FreeBSD warning
+/* Baron adds to avoid FreeBSD warning */
 int ieee80211_is_empty_essid(const char *essid, int essid_len)
 {
 	/* Single white space is for Linksys APs */
@@ -2627,33 +2617,25 @@ int rtw_get_cipher_info(struct wlan_network *pnetwork)
 	unsigned char *pbuf;
 	int group_cipher = 0, pairwise_cipher = 0, is8021x = 0;
 	int ret = _FAIL;
-	pbuf = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength-12);
+	pbuf = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
 
-	if(pbuf && (wpa_ielen>0)) {
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_get_cipher_info: wpa_ielen: %d", wpa_ielen));
-		if (_SUCCESS == rtw_parse_wpa_ie(pbuf, wpa_ielen+2, &group_cipher, &pairwise_cipher, &is8021x)) {
+	if (pbuf && (wpa_ielen > 0)) {
+		if (_SUCCESS == rtw_parse_wpa_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x)) {
 
 			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",
-						__func__, pnetwork->BcnInfo.pairwise_cipher, pnetwork->BcnInfo.is_8021x));
 			ret = _SUCCESS;
 		}
 	} else {
 
-		pbuf = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength-12);
+		pbuf = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
 
-		if(pbuf && (wpa_ielen>0)) {
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("get RSN IE\n"));
-			if (_SUCCESS == rtw_parse_wpa2_ie(pbuf, wpa_ielen+2, &group_cipher, &pairwise_cipher, &is8021x)) {
-				RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("get RSN IE  OK!!!\n"));
+		if (pbuf && (wpa_ielen > 0)) {
+			if (_SUCCESS == rtw_parse_wpa2_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x, NULL)) {
 				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",	__func__, pnetwork->BcnInfo.pairwise_cipher,
-							pnetwork->BcnInfo.group_cipher,pnetwork->BcnInfo.is_8021x));
 				ret = _SUCCESS;
 			}
 		}
@@ -2666,8 +2648,8 @@ void rtw_get_bcn_info(struct wlan_network *pnetwork)
 {
 	unsigned short cap = 0;
 	u8 bencrypt = 0;
-	//u8 wpa_ie[255],rsn_ie[255];
-	u16 wpa_len=0,rsn_len=0;
+	/* u8 wpa_ie[255],rsn_ie[255]; */
+	u16 wpa_len = 0, rsn_len = 0;
 	struct HT_info_element *pht_info = NULL;
 	struct rtw_ieee80211_ht_cap *pht_cap = NULL;
 	unsigned int		len;
@@ -2678,52 +2660,41 @@ void rtw_get_bcn_info(struct wlan_network *pnetwork)
 	if (cap & WLAN_CAPABILITY_PRIVACY) {
 		bencrypt = 1;
 		pnetwork->network.Privacy = 1;
-	} else {
+	} else
 		pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_OPENSYS;
-	}
-	rtw_get_sec_ie(pnetwork->network.IEs ,pnetwork->network.IELength,NULL,&rsn_len,NULL,&wpa_len);
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_get_bcn_info: ssid=%s\n",pnetwork->network.Ssid.Ssid));
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_get_bcn_info: wpa_len=%d rsn_len=%d\n",wpa_len,rsn_len));
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_get_bcn_info: ssid=%s\n",pnetwork->network.Ssid.Ssid));
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_get_bcn_info: wpa_len=%d rsn_len=%d\n",wpa_len,rsn_len));
+	rtw_get_sec_ie(pnetwork->network.IEs , pnetwork->network.IELength, NULL, &rsn_len, NULL, &wpa_len);
 
-	if (rsn_len > 0) {
+	if (rsn_len > 0)
 		pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_WPA2;
-	} else if (wpa_len > 0) {
+	else if (wpa_len > 0)
 		pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_WPA;
-	} else {
+	else {
 		if (bencrypt)
 			pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_WEP;
 	}
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_get_bcn_info: pnetwork->encryp_protocol is %x\n",
-				pnetwork->BcnInfo.encryp_protocol));
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_get_bcn_info: pnetwork->encryp_protocol is %x\n",
-				pnetwork->BcnInfo.encryp_protocol));
 	rtw_get_cipher_info(pnetwork);
 
 	/* get bwmode and ch_offset */
 	/* parsing HT_CAP_IE */
 	p = rtw_get_ie(pnetwork->network.IEs + _FIXED_IE_LENGTH_, _HT_CAPABILITY_IE_, &len, pnetwork->network.IELength - _FIXED_IE_LENGTH_);
-	if(p && len>0) {
-			pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
-			pnetwork->BcnInfo.ht_cap_info = pht_cap->cap_info;
-	} else {
-			pnetwork->BcnInfo.ht_cap_info = 0;
-	}
+	if (p && len > 0) {
+		pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
+		pnetwork->BcnInfo.ht_cap_info = pht_cap->cap_info;
+	} else
+		pnetwork->BcnInfo.ht_cap_info = 0;
 	/* parsing HT_INFO_IE */
 	p = rtw_get_ie(pnetwork->network.IEs + _FIXED_IE_LENGTH_, _HT_ADD_INFO_IE_, &len, pnetwork->network.IELength - _FIXED_IE_LENGTH_);
-	if(p && len>0) {
-			pht_info = (struct HT_info_element *)(p + 2);
-			pnetwork->BcnInfo.ht_info_infos_0 = pht_info->infos[0];
-	} else {
-			pnetwork->BcnInfo.ht_info_infos_0 = 0;
-	}
+	if (p && len > 0) {
+		pht_info = (struct HT_info_element *)(p + 2);
+		pnetwork->BcnInfo.ht_info_infos_0 = pht_info->infos[0];
+	} else
+		pnetwork->BcnInfo.ht_info_infos_0 = 0;
 }
 
 u8	rtw_ht_mcsset_to_nss(u8 *supp_mcs_set)
 {
 	u8 nss = 1;
-	
+
 	if (supp_mcs_set[3])
 		nss = 4;
 	else if (supp_mcs_set[2])
@@ -2733,74 +2704,104 @@ u8	rtw_ht_mcsset_to_nss(u8 *supp_mcs_set)
 	else if (supp_mcs_set[0])
 		nss = 1;
 	else
-		DBG_871X("%s,%d, warning! supp_mcs_set is zero\n", __func__, __LINE__);
-	/* DBG_871X("%s HT: %dSS\n", __FUNCTION__, nss); */
+		RTW_INFO("%s,%d, warning! supp_mcs_set is zero\n", __func__, __LINE__);
+	/* RTW_INFO("%s HT: %dSS\n", __FUNCTION__, nss); */
 	return nss;
 }
 
-//show MCS rate, unit: 100Kbps
-u16 rtw_mcs_rate(u8 rf_type, u8 bw_40MHz, u8 short_GI, unsigned char * MCS_rate)
+u32	rtw_ht_mcs_set_to_bitmap(u8 *mcs_set, u8 nss)
+{
+	u8 i;
+	u32 bitmap = 0;
+
+	for (i = 0; i < nss; i++)
+		bitmap |= mcs_set[i] << (i * 8);
+
+	RTW_INFO("ht_mcs_set=%02x %02x %02x %02x, nss=%u, bitmap=%08x\n"
+		, mcs_set[0], mcs_set[1], mcs_set[2], mcs_set[3], nss, bitmap);
+
+	return bitmap;
+}
+
+/* show MCS rate, unit: 100Kbps */
+u16 rtw_mcs_rate(u8 rf_type, u8 bw_40MHz, u8 short_GI, unsigned char *MCS_rate)
 {
 	u16 max_rate = 0;
 
-	/*MCS_rate[2] = 3T3R , MCS_rate[1] = 2T2R , MCS_rate[0] = 1T1R*/
-	if (MCS_rate[2]) {
+	if (MCS_rate[3]) {
+		if (MCS_rate[3] & BIT(7))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 6000 : 5400) : ((short_GI) ? 2889 : 2600);
+		else if (MCS_rate[3] & BIT(6))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 5400 : 4860) : ((short_GI) ? 2600 : 2340);
+		else if (MCS_rate[3] & BIT(5))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 4800 : 4320) : ((short_GI) ? 2311 : 2080);
+		else if (MCS_rate[3] & BIT(4))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 3600 : 3240) : ((short_GI) ? 1733 : 1560);
+		else if (MCS_rate[3] & BIT(3))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 2400 : 2160) : ((short_GI) ? 1156 : 1040);
+		else if (MCS_rate[3] & BIT(2))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1800 : 1620) : ((short_GI) ? 867 : 780);
+		else if (MCS_rate[3] & BIT(1))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1200 : 1080) : ((short_GI) ? 578 : 520);
+		else if (MCS_rate[3] & BIT(0))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 600 : 540) : ((short_GI) ? 289 : 260);
+	} else if (MCS_rate[2]) {
 		if (MCS_rate[2] & BIT(7))
-			max_rate = (bw_40MHz) ? ((short_GI)?4500:4050):((short_GI)?2167:1950);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 4500 : 4050) : ((short_GI) ? 2167 : 1950);
 		else if (MCS_rate[2] & BIT(6))
-			max_rate = (bw_40MHz) ? ((short_GI)?4050:3645):((short_GI)?1950:1750);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 4050 : 3645) : ((short_GI) ? 1950 : 1750);
 		else if (MCS_rate[2] & BIT(5))
-			max_rate = (bw_40MHz) ? ((short_GI)?3600:3240):((short_GI)?1733:1560);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 3600 : 3240) : ((short_GI) ? 1733 : 1560);
 		else if (MCS_rate[2] & BIT(4))
-			max_rate = (bw_40MHz) ? ((short_GI)?2700:2430):((short_GI)?1300:1170);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 2700 : 2430) : ((short_GI) ? 1300 : 1170);
 		else if (MCS_rate[2] & BIT(3))
-			max_rate = (bw_40MHz) ? ((short_GI)?1800:1620):((short_GI)?867:780);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1800 : 1620) : ((short_GI) ? 867 : 780);
 		else if (MCS_rate[2] & BIT(2))
-			max_rate = (bw_40MHz) ? ((short_GI)?1350:1215):((short_GI)?650:585);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1350 : 1215) : ((short_GI) ? 650 : 585);
 		else if (MCS_rate[2] & BIT(1))
-			max_rate = (bw_40MHz) ? ((short_GI)?900:810):((short_GI)?433:390);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 900 : 810) : ((short_GI) ? 433 : 390);
 		else if (MCS_rate[2] & BIT(0))
-			max_rate = (bw_40MHz) ? ((short_GI)?450:405):((short_GI)?217:195);
+			max_rate = (bw_40MHz) ? ((short_GI) ? 450 : 405) : ((short_GI) ? 217 : 195);
 	} else if (MCS_rate[1]) {
-			if(MCS_rate[1] & BIT(7))
-				max_rate = (bw_40MHz) ? ((short_GI)?3000:2700):((short_GI)?1444:1300);
-			else if(MCS_rate[1] & BIT(6))
-				max_rate = (bw_40MHz) ? ((short_GI)?2700:2430):((short_GI)?1300:1170);
-			else if(MCS_rate[1] & BIT(5))
-				max_rate = (bw_40MHz) ? ((short_GI)?2400:2160):((short_GI)?1156:1040);
-			else if(MCS_rate[1] & BIT(4))
-				max_rate = (bw_40MHz) ? ((short_GI)?1800:1620):((short_GI)?867:780);
-			else if(MCS_rate[1] & BIT(3))
-				max_rate = (bw_40MHz) ? ((short_GI)?1200:1080):((short_GI)?578:520);
-			else if(MCS_rate[1] & BIT(2))
-				max_rate = (bw_40MHz) ? ((short_GI)?900:810):((short_GI)?433:390);
-			else if(MCS_rate[1] & BIT(1))
-				max_rate = (bw_40MHz) ? ((short_GI)?600:540):((short_GI)?289:260);
-			else if(MCS_rate[1] & BIT(0))
-				max_rate = (bw_40MHz) ? ((short_GI)?300:270):((short_GI)?144:130);
+		if (MCS_rate[1] & BIT(7))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 3000 : 2700) : ((short_GI) ? 1444 : 1300);
+		else if (MCS_rate[1] & BIT(6))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 2700 : 2430) : ((short_GI) ? 1300 : 1170);
+		else if (MCS_rate[1] & BIT(5))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 2400 : 2160) : ((short_GI) ? 1156 : 1040);
+		else if (MCS_rate[1] & BIT(4))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1800 : 1620) : ((short_GI) ? 867 : 780);
+		else if (MCS_rate[1] & BIT(3))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1200 : 1080) : ((short_GI) ? 578 : 520);
+		else if (MCS_rate[1] & BIT(2))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 900 : 810) : ((short_GI) ? 433 : 390);
+		else if (MCS_rate[1] & BIT(1))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 600 : 540) : ((short_GI) ? 289 : 260);
+		else if (MCS_rate[1] & BIT(0))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 300 : 270) : ((short_GI) ? 144 : 130);
 	} else {
-			if(MCS_rate[0] & BIT(7))
-				max_rate = (bw_40MHz) ? ((short_GI)?1500:1350):((short_GI)?722:650);
-			else if(MCS_rate[0] & BIT(6))
-				max_rate = (bw_40MHz) ? ((short_GI)?1350:1215):((short_GI)?650:585);
-			else if(MCS_rate[0] & BIT(5))
-				max_rate = (bw_40MHz) ? ((short_GI)?1200:1080):((short_GI)?578:520);
-			else if(MCS_rate[0] & BIT(4))
-				max_rate = (bw_40MHz) ? ((short_GI)?900:810):((short_GI)?433:390);
-			else if(MCS_rate[0] & BIT(3))
-				max_rate = (bw_40MHz) ? ((short_GI)?600:540):((short_GI)?289:260);
-			else if(MCS_rate[0] & BIT(2))
-				max_rate = (bw_40MHz) ? ((short_GI)?450:405):((short_GI)?217:195);
-			else if(MCS_rate[0] & BIT(1))
-				max_rate = (bw_40MHz) ? ((short_GI)?300:270):((short_GI)?144:130);
-			else if(MCS_rate[0] & BIT(0))
-				max_rate = (bw_40MHz) ? ((short_GI)?150:135):((short_GI)?72:65);
-		}
+		if (MCS_rate[0] & BIT(7))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1500 : 1350) : ((short_GI) ? 722 : 650);
+		else if (MCS_rate[0] & BIT(6))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1350 : 1215) : ((short_GI) ? 650 : 585);
+		else if (MCS_rate[0] & BIT(5))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 1200 : 1080) : ((short_GI) ? 578 : 520);
+		else if (MCS_rate[0] & BIT(4))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 900 : 810) : ((short_GI) ? 433 : 390);
+		else if (MCS_rate[0] & BIT(3))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 600 : 540) : ((short_GI) ? 289 : 260);
+		else if (MCS_rate[0] & BIT(2))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 450 : 405) : ((short_GI) ? 217 : 195);
+		else if (MCS_rate[0] & BIT(1))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 300 : 270) : ((short_GI) ? 144 : 130);
+		else if (MCS_rate[0] & BIT(0))
+			max_rate = (bw_40MHz) ? ((short_GI) ? 150 : 135) : ((short_GI) ? 72 : 65);
+	}
 
 	return max_rate;
 }
 
-int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8* category, u8 *action)
+int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8 *category, u8 *action)
 {
 	const u8 *frame_body = frame + sizeof(struct rtw_ieee80211_hdr_3addr);
 	u16 fc;
@@ -2809,16 +2810,14 @@ int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8* category, u8 *act
 
 	fc = le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)frame)->frame_ctl);
 
-	if ((fc & (RTW_IEEE80211_FCTL_FTYPE|RTW_IEEE80211_FCTL_STYPE))
-		!= (RTW_IEEE80211_FTYPE_MGMT|RTW_IEEE80211_STYPE_ACTION)
-	)
-	{
+	if ((fc & (RTW_IEEE80211_FCTL_FTYPE | RTW_IEEE80211_FCTL_STYPE))
+	    != (RTW_IEEE80211_FTYPE_MGMT | RTW_IEEE80211_STYPE_ACTION)
+	   )
 		return _FALSE;
-	}
 
 	c = frame_body[0];
 
-	switch(c) {
+	switch (c) {
 	case RTW_WLAN_CATEGORY_P2P: /* vendor-specific */
 		break;
 	default:
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_io.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_io.c
index d08c16dac4c7..1fcc7610bffe 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_io.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_io.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 /*
 
 The purpose of rtw_io.c
@@ -52,129 +48,115 @@ jackson@realtek.com.tw
 #include <drv_types.h>
 #include <hal_data.h>
 
-#if defined (PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
-#error "Shall be Linux or Windows, but not both!\n"
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+	#error "Shall be Linux or Windows, but not both!\n"
 #endif
 
-#ifdef CONFIG_SDIO_HCI
-#define rtw_le16_to_cpu(val) 		val
-#define rtw_le32_to_cpu(val)		val
-#define rtw_cpu_to_le16(val)		val
-#define rtw_cpu_to_le32(val)		val
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_PLATFORM_RTL8197D)
+	#define rtw_le16_to_cpu(val)		val
+	#define rtw_le32_to_cpu(val)		val
+	#define rtw_cpu_to_le16(val)		val
+	#define rtw_cpu_to_le32(val)		val
 #else
-#define rtw_le16_to_cpu(val) 		le16_to_cpu(val)
-#define rtw_le32_to_cpu(val)		le32_to_cpu(val)
-#define rtw_cpu_to_le16(val)		cpu_to_le16(val)
-#define rtw_cpu_to_le32(val)		cpu_to_le32(val)
+	#define rtw_le16_to_cpu(val)		le16_to_cpu(val)
+	#define rtw_le32_to_cpu(val)		le32_to_cpu(val)
+	#define rtw_cpu_to_le16(val)		cpu_to_le16(val)
+	#define rtw_cpu_to_le32(val)		cpu_to_le32(val)
 #endif
 
 
 u8 _rtw_read8(_adapter *adapter, u32 addr)
 {
 	u8 r_val;
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
-	u8 (*_read8)(struct intf_hdl *pintfhdl, u32 addr);
-	_func_enter_;
+	u8(*_read8)(struct intf_hdl *pintfhdl, u32 addr);
 	_read8 = pintfhdl->io_ops._read8;
 
 	r_val = _read8(pintfhdl, addr);
-	_func_exit_;
 	return r_val;
 }
 
 u16 _rtw_read16(_adapter *adapter, u32 addr)
 {
 	u16 r_val;
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
-	u16 	(*_read16)(struct intf_hdl *pintfhdl, u32 addr);
-	_func_enter_;
+	u16(*_read16)(struct intf_hdl *pintfhdl, u32 addr);
 	_read16 = pintfhdl->io_ops._read16;
 
 	r_val = _read16(pintfhdl, addr);
-	_func_exit_;
 	return rtw_le16_to_cpu(r_val);
 }
 
 u32 _rtw_read32(_adapter *adapter, u32 addr)
 {
 	u32 r_val;
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
-	u32 	(*_read32)(struct intf_hdl *pintfhdl, u32 addr);
-	_func_enter_;
+	u32(*_read32)(struct intf_hdl *pintfhdl, u32 addr);
 	_read32 = pintfhdl->io_ops._read32;
 
 	r_val = _read32(pintfhdl, addr);
-	_func_exit_;
 	return rtw_le32_to_cpu(r_val);
 
 }
 
 int _rtw_write8(_adapter *adapter, u32 addr, u8 val)
 {
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 	int (*_write8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
 	int ret;
-	_func_enter_;
 	_write8 = pintfhdl->io_ops._write8;
 
 	ret = _write8(pintfhdl, addr, val);
-	_func_exit_;
-	
+
 	return RTW_STATUS_CODE(ret);
 }
 int _rtw_write16(_adapter *adapter, u32 addr, u16 val)
 {
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 	int (*_write16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
 	int ret;
-	_func_enter_;
 	_write16 = pintfhdl->io_ops._write16;
 
 	val = rtw_cpu_to_le16(val);
 	ret = _write16(pintfhdl, addr, val);
-	_func_exit_;
 
 	return RTW_STATUS_CODE(ret);
 }
 int _rtw_write32(_adapter *adapter, u32 addr, u32 val)
 {
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 	int (*_write32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
 	int ret;
-	_func_enter_;
 	_write32 = pintfhdl->io_ops._write32;
-	
+
 	val = rtw_cpu_to_le32(val);
 	ret = _write32(pintfhdl, addr, val);
-	_func_exit_;
 
 	return RTW_STATUS_CODE(ret);
 }
 
-int _rtw_writeN(_adapter *adapter, u32 addr ,u32 length , u8 *pdata)
+int _rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *pdata)
 {
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
-        struct	intf_hdl	*pintfhdl = (struct intf_hdl*)(&(pio_priv->intf));
-	int (*_writeN)(struct intf_hdl *pintfhdl, u32 addr,u32 length, u8 *pdata);
+	struct	intf_hdl	*pintfhdl = (struct intf_hdl *)(&(pio_priv->intf));
+	int (*_writeN)(struct intf_hdl *pintfhdl, u32 addr, u32 length, u8 *pdata);
 	int ret;
-	_func_enter_;
 	_writeN = pintfhdl->io_ops._writeN;
 
-	ret = _writeN(pintfhdl, addr,length,pdata);
-	_func_exit_;
+	ret = _writeN(pintfhdl, addr, length, pdata);
 
 	return RTW_STATUS_CODE(ret);
 }
@@ -185,17 +167,15 @@ u8 _rtw_sd_f0_read8(_adapter *adapter, u32 addr)
 	u8 r_val = 0x00;
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct intf_hdl *pintfhdl = &(pio_priv->intf);
-	u8 (*_sd_f0_read8)(struct intf_hdl *pintfhdl, u32 addr);
+	u8(*_sd_f0_read8)(struct intf_hdl *pintfhdl, u32 addr);
 
-	_func_enter_;
 	_sd_f0_read8 = pintfhdl->io_ops._sd_f0_read8;
 
 	if (_sd_f0_read8)
 		r_val = _sd_f0_read8(pintfhdl, addr);
 	else
-		DBG_871X_LEVEL(_drv_warning_, FUNC_ADPT_FMT" _sd_f0_read8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
+		RTW_WARN(FUNC_ADPT_FMT" _sd_f0_read8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
 
-	_func_exit_;
 	return r_val;
 }
 
@@ -205,14 +185,14 @@ u8 _rtw_sd_iread8(_adapter *adapter, u32 addr)
 	u8 r_val = 0x00;
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct intf_hdl *pintfhdl = &(pio_priv->intf);
-	u8 (*_sd_iread8)(struct intf_hdl *pintfhdl, u32 addr);
+	u8(*_sd_iread8)(struct intf_hdl *pintfhdl, u32 addr);
 
 	_sd_iread8 = pintfhdl->io_ops._sd_iread8;
 
 	if (_sd_iread8)
 		r_val = _sd_iread8(pintfhdl, addr);
 	else
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" _sd_iread8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
+		RTW_ERR(FUNC_ADPT_FMT" _sd_iread8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
 
 	return r_val;
 }
@@ -222,14 +202,14 @@ u16 _rtw_sd_iread16(_adapter *adapter, u32 addr)
 	u16 r_val = 0x00;
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct intf_hdl *pintfhdl = &(pio_priv->intf);
-	u16 (*_sd_iread16)(struct intf_hdl *pintfhdl, u32 addr);
+	u16(*_sd_iread16)(struct intf_hdl *pintfhdl, u32 addr);
 
 	_sd_iread16 = pintfhdl->io_ops._sd_iread16;
 
 	if (_sd_iread16)
 		r_val = _sd_iread16(pintfhdl, addr);
 	else
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" _sd_iread16 callback is NULL\n", FUNC_ADPT_ARG(adapter));
+		RTW_ERR(FUNC_ADPT_FMT" _sd_iread16 callback is NULL\n", FUNC_ADPT_ARG(adapter));
 
 	return r_val;
 }
@@ -239,14 +219,14 @@ u32 _rtw_sd_iread32(_adapter *adapter, u32 addr)
 	u32 r_val = 0x00;
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct intf_hdl *pintfhdl = &(pio_priv->intf);
-	u32 (*_sd_iread32)(struct intf_hdl *pintfhdl, u32 addr);
+	u32(*_sd_iread32)(struct intf_hdl *pintfhdl, u32 addr);
 
 	_sd_iread32 = pintfhdl->io_ops._sd_iread32;
 
 	if (_sd_iread32)
 		r_val = _sd_iread32(pintfhdl, addr);
 	else
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" _sd_iread32 callback is NULL\n", FUNC_ADPT_ARG(adapter));
+		RTW_ERR(FUNC_ADPT_FMT" _sd_iread32 callback is NULL\n", FUNC_ADPT_ARG(adapter));
 
 	return r_val;
 }
@@ -263,7 +243,7 @@ int _rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val)
 	if (_sd_iwrite8)
 		ret = _sd_iwrite8(pintfhdl, addr, val);
 	else
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" _sd_iwrite8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
+		RTW_ERR(FUNC_ADPT_FMT" _sd_iwrite8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
 
 	return RTW_STATUS_CODE(ret);
 }
@@ -280,7 +260,7 @@ int _rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val)
 	if (_sd_iwrite16)
 		ret = _sd_iwrite16(pintfhdl, addr, val);
 	else
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" _sd_iwrite16 callback is NULL\n", FUNC_ADPT_ARG(adapter));
+		RTW_ERR(FUNC_ADPT_FMT" _sd_iwrite16 callback is NULL\n", FUNC_ADPT_ARG(adapter));
 
 	return RTW_STATUS_CODE(ret);
 }
@@ -296,7 +276,7 @@ int _rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val)
 	if (_sd_iwrite32)
 		ret = _sd_iwrite32(pintfhdl, addr, val);
 	else
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" _sd_iwrite32 callback is NULL\n", FUNC_ADPT_ARG(adapter));
+		RTW_ERR(FUNC_ADPT_FMT" _sd_iwrite32 callback is NULL\n", FUNC_ADPT_ARG(adapter));
 
 	return RTW_STATUS_CODE(ret);
 }
@@ -307,46 +287,40 @@ int _rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val)
 
 int _rtw_write8_async(_adapter *adapter, u32 addr, u8 val)
 {
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 	int (*_write8_async)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
 	int ret;
-	_func_enter_;
 	_write8_async = pintfhdl->io_ops._write8_async;
 
 	ret = _write8_async(pintfhdl, addr, val);
-	_func_exit_;
 
 	return RTW_STATUS_CODE(ret);
 }
 int _rtw_write16_async(_adapter *adapter, u32 addr, u16 val)
 {
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 	int (*_write16_async)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
 	int ret;
-	_func_enter_;
 	_write16_async = pintfhdl->io_ops._write16_async;
 	val = rtw_cpu_to_le16(val);
 	ret = _write16_async(pintfhdl, addr, val);
-	_func_exit_;
 
 	return RTW_STATUS_CODE(ret);
 }
 int _rtw_write32_async(_adapter *adapter, u32 addr, u32 val)
 {
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 	int (*_write32_async)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
 	int ret;
-	_func_enter_;
 	_write32_async = pintfhdl->io_ops._write32_async;
 	val = rtw_cpu_to_le32(val);
 	ret = _write32_async(pintfhdl, addr, val);
-	_func_exit_;
 
 	return RTW_STATUS_CODE(ret);
 }
@@ -354,16 +328,12 @@ int _rtw_write32_async(_adapter *adapter, u32 addr, u32 val)
 void _rtw_read_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
 {
 	void (*_read_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 
-	_func_enter_;
 
 	if (RTW_CANNOT_RUN(adapter)) {
-		RT_TRACE(_module_rtl871x_io_c_, _drv_info_, ("rtw_read_mem:bDriverStopped(%s) OR bSurpriseRemoved(%s)"
-			, rtw_is_drv_stopped(adapter)?"True":"False"
-			, rtw_is_surprise_removed(adapter)?"True":"False"));
 		return;
 	}
 
@@ -371,48 +341,40 @@ void _rtw_read_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
 
 	_read_mem(pintfhdl, addr, cnt, pmem);
 
-	_func_exit_;
 
 }
 
 void _rtw_write_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
 {
 	void (*_write_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 
-	_func_enter_;
 
 	_write_mem = pintfhdl->io_ops._write_mem;
 
 	_write_mem(pintfhdl, addr, cnt, pmem);
 
-	_func_exit_;
 
 }
 
 void _rtw_read_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
 {
-	u32 (*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	u32(*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 
-	_func_enter_;
 
 	if (RTW_CANNOT_RUN(adapter)) {
-		RT_TRACE(_module_rtl871x_io_c_, _drv_info_, ("rtw_read_port:bDriverStopped(%s) OR bSurpriseRemoved(%s)"
-			, rtw_is_drv_stopped(adapter)?"True":"False"
-			, rtw_is_surprise_removed(adapter)?"True":"False"));	    
-	     return;
+		return;
 	}
 
 	_read_port = pintfhdl->io_ops._read_port;
 
 	_read_port(pintfhdl, addr, cnt, pmem);
 
-	_func_exit_;
 
 }
 
@@ -426,25 +388,23 @@ void _rtw_read_port_cancel(_adapter *adapter)
 
 	RTW_DISABLE_FUNC(adapter, DF_RX_BIT);
 
-	if(_read_port_cancel)
+	if (_read_port_cancel)
 		_read_port_cancel(pintfhdl);
 }
 
 u32 _rtw_write_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
 {
-	u32 (*_write_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
-	//struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue;
+	u32(*_write_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	/* struct	io_queue  	*pio_queue = (struct io_queue *)adapter->pio_queue; */
 	struct io_priv *pio_priv = &adapter->iopriv;
 	struct	intf_hdl		*pintfhdl = &(pio_priv->intf);
 	u32 ret = _SUCCESS;
 
-	_func_enter_;
 
 	_write_port = pintfhdl->io_ops._write_port;
-	
+
 	ret = _write_port(pintfhdl, addr, cnt, pmem);
 
-	 _func_exit_;
 
 	return ret;
 }
@@ -463,7 +423,7 @@ u32 _rtw_write_port_and_wait(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem, int
 	if (ret == _SUCCESS)
 		ret = rtw_sctx_wait(&sctx, __func__);
 
-	 return ret;
+	return ret;
 }
 
 void _rtw_write_port_cancel(_adapter *adapter)
@@ -476,10 +436,10 @@ void _rtw_write_port_cancel(_adapter *adapter)
 
 	RTW_DISABLE_FUNC(adapter, DF_TX_BIT);
 
-	if(_write_port_cancel)
+	if (_write_port_cancel)
 		_write_port_cancel(pintfhdl);
 }
-int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter,struct _io_ops *pops))
+int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter, struct _io_ops *pops))
 {
 	struct io_priv	*piopriv = &padapter->iopriv;
 	struct intf_hdl *pintf = &piopriv->intf;
@@ -490,8 +450,8 @@ int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter
 	piopriv->padapter = padapter;
 	pintf->padapter = padapter;
 	pintf->pintf_dev = adapter_to_dvobj(padapter);
-		
-	set_intf_ops(padapter,&pintf->io_ops);	
+
+	set_intf_ops(padapter, &pintf->io_ops);
 
 	return _SUCCESS;
 }
@@ -505,11 +465,13 @@ int rtw_inc_and_chk_continual_io_error(struct dvobj_priv *dvobj)
 {
 	int ret = _FALSE;
 	int value;
-	if( (value=ATOMIC_INC_RETURN(&dvobj->continual_io_error)) > MAX_CONTINUAL_IO_ERR) {
-		DBG_871X("[dvobj:%p][ERROR] continual_io_error:%d > %d\n", dvobj, value, MAX_CONTINUAL_IO_ERR);
+
+	value = ATOMIC_INC_RETURN(&dvobj->continual_io_error);
+	if (value > MAX_CONTINUAL_IO_ERR) {
+		RTW_INFO("[dvobj:%p][ERROR] continual_io_error:%d > %d\n", dvobj, value, MAX_CONTINUAL_IO_ERR);
 		ret = _TRUE;
 	} else {
-		//DBG_871X("[dvobj:%p] continual_io_error:%d\n", dvobj, value);
+		/* RTW_INFO("[dvobj:%p] continual_io_error:%d\n", dvobj, value); */
 	}
 	return ret;
 }
@@ -519,42 +481,42 @@ int rtw_inc_and_chk_continual_io_error(struct dvobj_priv *dvobj)
 */
 void rtw_reset_continual_io_error(struct dvobj_priv *dvobj)
 {
-	ATOMIC_SET(&dvobj->continual_io_error, 0);	
+	ATOMIC_SET(&dvobj->continual_io_error, 0);
 }
 
 #ifdef DBG_IO
 
 u32 read_sniff_ranges[][2] = {
-	//{0x520, 0x523},
-}; 
+	/* {0x520, 0x523}, */
+};
 
 u32 write_sniff_ranges[][2] = {
-	//{0x520, 0x523},
-	//{0x4c, 0x4c},
-}; 
+	/* {0x520, 0x523}, */
+	/* {0x4c, 0x4c}, */
+};
 
-int read_sniff_num = sizeof(read_sniff_ranges)/sizeof(u32)/2;
-int write_sniff_num = sizeof(write_sniff_ranges)/sizeof(u32)/2;
+int read_sniff_num = sizeof(read_sniff_ranges) / sizeof(u32) / 2;
+int write_sniff_num = sizeof(write_sniff_ranges) / sizeof(u32) / 2;
 
 bool match_read_sniff_ranges(u32 addr, u16 len)
 {
 	int i;
-	for (i = 0; i<read_sniff_num; i++) {
+	for (i = 0; i < read_sniff_num; i++) {
 		if (addr + len > read_sniff_ranges[i][0] && addr <= read_sniff_ranges[i][1])
 			return _TRUE;
 	}
-	
+
 	return _FALSE;
 }
 
 bool match_write_sniff_ranges(u32 addr, u16 len)
 {
 	int i;
-	for (i = 0; i<write_sniff_num; i++) {
+	for (i = 0; i < write_sniff_num; i++) {
 		if (addr + len > write_sniff_ranges[i][0] && addr <= write_sniff_ranges[i][1])
 			return _TRUE;
 	}
-	
+
 	return _FALSE;
 }
 
@@ -574,8 +536,8 @@ struct rf_sniff_ent rf_write_sniff_ranges[] = {
 	/* {MAX_RF_PATH, 0x55, bRFRegOffsetMask}, */
 };
 
-int rf_read_sniff_num = sizeof(rf_read_sniff_ranges)/sizeof(struct rf_sniff_ent);
-int rf_write_sniff_num = sizeof(rf_write_sniff_ranges)/sizeof(struct rf_sniff_ent);
+int rf_read_sniff_num = sizeof(rf_read_sniff_ranges) / sizeof(struct rf_sniff_ent);
+int rf_write_sniff_num = sizeof(rf_write_sniff_ranges) / sizeof(struct rf_sniff_ent);
 
 bool match_rf_read_sniff_ranges(u8 path, u32 addr, u32 mask)
 {
@@ -608,7 +570,7 @@ u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line
 	u8 val = _rtw_read8(adapter, addr);
 
 	if (match_read_sniff_ranges(addr, 1))
-		DBG_871X("DBG_IO %s:%d rtw_read8(0x%04x) return 0x%02x\n", caller, line, addr, val);
+		RTW_INFO("DBG_IO %s:%d rtw_read8(0x%04x) return 0x%02x\n", caller, line, addr, val);
 
 	return val;
 }
@@ -616,9 +578,9 @@ u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line
 u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u16 val = _rtw_read16(adapter, addr);
-	
+
 	if (match_read_sniff_ranges(addr, 2))
-		DBG_871X("DBG_IO %s:%d rtw_read16(0x%04x) return 0x%04x\n", caller, line, addr, val);
+		RTW_INFO("DBG_IO %s:%d rtw_read16(0x%04x) return 0x%04x\n", caller, line, addr, val);
 
 	return val;
 }
@@ -626,9 +588,9 @@ u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int li
 u32 dbg_rtw_read32(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u32 val = _rtw_read32(adapter, addr);
-	
+
 	if (match_read_sniff_ranges(addr, 4))
-		DBG_871X("DBG_IO %s:%d rtw_read32(0x%04x) return 0x%08x\n", caller, line, addr, val);
+		RTW_INFO("DBG_IO %s:%d rtw_read32(0x%04x) return 0x%08x\n", caller, line, addr, val);
 
 	return val;
 }
@@ -636,28 +598,28 @@ u32 dbg_rtw_read32(_adapter *adapter, u32 addr, const char *caller, const int li
 int dbg_rtw_write8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 1))
-		DBG_871X("DBG_IO %s:%d rtw_write8(0x%04x, 0x%02x)\n", caller, line, addr, val);
-	
+		RTW_INFO("DBG_IO %s:%d rtw_write8(0x%04x, 0x%02x)\n", caller, line, addr, val);
+
 	return _rtw_write8(adapter, addr, val);
 }
 int dbg_rtw_write16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 2))
-		DBG_871X("DBG_IO %s:%d rtw_write16(0x%04x, 0x%04x)\n", caller, line, addr, val);
-	
+		RTW_INFO("DBG_IO %s:%d rtw_write16(0x%04x, 0x%04x)\n", caller, line, addr, val);
+
 	return _rtw_write16(adapter, addr, val);
 }
 int dbg_rtw_write32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 4))
-		DBG_871X("DBG_IO %s:%d rtw_write32(0x%04x, 0x%08x)\n", caller, line, addr, val);
-	
+		RTW_INFO("DBG_IO %s:%d rtw_write32(0x%04x, 0x%08x)\n", caller, line, addr, val);
+
 	return _rtw_write32(adapter, addr, val);
 }
-int dbg_rtw_writeN(_adapter *adapter, u32 addr ,u32 length , u8 *data, const char *caller, const int line)
+int dbg_rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *data, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, length))
-		DBG_871X("DBG_IO %s:%d rtw_writeN(0x%04x, %u)\n", caller, line, addr, length);
+		RTW_INFO("DBG_IO %s:%d rtw_writeN(0x%04x, %u)\n", caller, line, addr, length);
 
 	return _rtw_writeN(adapter, addr, length, data);
 }
@@ -667,10 +629,10 @@ u8 dbg_rtw_sd_f0_read8(_adapter *adapter, u32 addr, const char *caller, const in
 {
 	u8 val = _rtw_sd_f0_read8(adapter, addr);
 
-	#if 0
+#if 0
 	if (match_read_sniff_ranges(addr, 1))
-		DBG_871X("DBG_IO %s:%d rtw_sd_f0_read8(0x%04x) return 0x%02x\n", caller, line, addr, val);
-	#endif
+		RTW_INFO("DBG_IO %s:%d rtw_sd_f0_read8(0x%04x) return 0x%02x\n", caller, line, addr, val);
+#endif
 
 	return val;
 }
@@ -681,7 +643,7 @@ u8 dbg_rtw_sd_iread8(_adapter *adapter, u32 addr, const char *caller, const int
 	u8 val = rtw_sd_iread8(adapter, addr);
 
 	if (match_read_sniff_ranges(addr, 1))
-		DBG_871X("DBG_IO %s:%d rtw_sd_iread8(0x%04x) return 0x%02x\n", caller, line, addr, val);
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iread8(0x%04x) return 0x%02x\n", caller, line, addr, val);
 
 	return val;
 }
@@ -689,9 +651,9 @@ u8 dbg_rtw_sd_iread8(_adapter *adapter, u32 addr, const char *caller, const int
 u16 dbg_rtw_sd_iread16(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u16 val = _rtw_sd_iread16(adapter, addr);
-	
+
 	if (match_read_sniff_ranges(addr, 2))
-		DBG_871X("DBG_IO %s:%d rtw_sd_iread16(0x%04x) return 0x%04x\n", caller, line, addr, val);
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iread16(0x%04x) return 0x%04x\n", caller, line, addr, val);
 
 	return val;
 }
@@ -699,9 +661,9 @@ u16 dbg_rtw_sd_iread16(_adapter *adapter, u32 addr, const char *caller, const in
 u32 dbg_rtw_sd_iread32(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u32 val = _rtw_sd_iread32(adapter, addr);
-	
+
 	if (match_read_sniff_ranges(addr, 4))
-		DBG_871X("DBG_IO %s:%d rtw_sd_iread32(0x%04x) return 0x%08x\n", caller, line, addr, val);
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iread32(0x%04x) return 0x%08x\n", caller, line, addr, val);
 
 	return val;
 }
@@ -709,22 +671,22 @@ u32 dbg_rtw_sd_iread32(_adapter *adapter, u32 addr, const char *caller, const in
 int dbg_rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 1))
-		DBG_871X("DBG_IO %s:%d rtw_sd_iwrite8(0x%04x, 0x%02x)\n", caller, line, addr, val);
-	
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite8(0x%04x, 0x%02x)\n", caller, line, addr, val);
+
 	return _rtw_sd_iwrite8(adapter, addr, val);
 }
 int dbg_rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 2))
-		DBG_871X("DBG_IO %s:%d rtw_sd_iwrite16(0x%04x, 0x%04x)\n", caller, line, addr, val);
-	
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite16(0x%04x, 0x%04x)\n", caller, line, addr, val);
+
 	return _rtw_sd_iwrite16(adapter, addr, val);
 }
 int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 4))
-		DBG_871X("DBG_IO %s:%d rtw_sd_iwrite32(0x%04x, 0x%08x)\n", caller, line, addr, val);
-	
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite32(0x%04x, 0x%08x)\n", caller, line, addr, val);
+
 	return _rtw_sd_iwrite32(adapter, addr, val);
 }
 
@@ -733,5 +695,3 @@ int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller
 #endif /* CONFIG_SDIO_HCI */
 
 #endif
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_query.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_query.c
index d7cd885903eb..d878b4cb4315 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_query.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_query.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,182 +12,156 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_IOCTL_QUERY_C_
 
 #include <drv_types.h>
 
 
 #ifdef PLATFORM_WINDOWS
-//
-// Added for WPA2-PSK, by Annie, 2005-09-20.
-//
+/*
+ * Added for WPA2-PSK, by Annie, 2005-09-20.
+ *   */
 u8
 query_802_11_capability(
-	_adapter*		Adapter,
-	u8*			pucBuf,
-	u32 *		pulOutLen
+	_adapter		*Adapter,
+	u8			*pucBuf,
+	u32		*pulOutLen
 )
 {
-	static NDIS_802_11_AUTHENTICATION_ENCRYPTION szAuthEnc[] = 
-	{
-		{Ndis802_11AuthModeOpen, Ndis802_11EncryptionDisabled}, 
+	static NDIS_802_11_AUTHENTICATION_ENCRYPTION szAuthEnc[] = {
+		{Ndis802_11AuthModeOpen, Ndis802_11EncryptionDisabled},
 		{Ndis802_11AuthModeOpen, Ndis802_11Encryption1Enabled},
-		{Ndis802_11AuthModeShared, Ndis802_11EncryptionDisabled}, 
+		{Ndis802_11AuthModeShared, Ndis802_11EncryptionDisabled},
 		{Ndis802_11AuthModeShared, Ndis802_11Encryption1Enabled},
-		{Ndis802_11AuthModeWPA, Ndis802_11Encryption2Enabled}, 
+		{Ndis802_11AuthModeWPA, Ndis802_11Encryption2Enabled},
 		{Ndis802_11AuthModeWPA, Ndis802_11Encryption3Enabled},
-		{Ndis802_11AuthModeWPAPSK, Ndis802_11Encryption2Enabled}, 
+		{Ndis802_11AuthModeWPAPSK, Ndis802_11Encryption2Enabled},
 		{Ndis802_11AuthModeWPAPSK, Ndis802_11Encryption3Enabled},
-		{Ndis802_11AuthModeWPANone, Ndis802_11Encryption2Enabled}, 
+		{Ndis802_11AuthModeWPANone, Ndis802_11Encryption2Enabled},
 		{Ndis802_11AuthModeWPANone, Ndis802_11Encryption3Enabled},
-		{Ndis802_11AuthModeWPA2, Ndis802_11Encryption2Enabled}, 
+		{Ndis802_11AuthModeWPA2, Ndis802_11Encryption2Enabled},
 		{Ndis802_11AuthModeWPA2, Ndis802_11Encryption3Enabled},
-		{Ndis802_11AuthModeWPA2PSK, Ndis802_11Encryption2Enabled}, 
+		{Ndis802_11AuthModeWPA2PSK, Ndis802_11Encryption2Enabled},
 		{Ndis802_11AuthModeWPA2PSK, Ndis802_11Encryption3Enabled}
-	};	
-	static ULONG	ulNumOfPairSupported = sizeof(szAuthEnc)/sizeof(NDIS_802_11_AUTHENTICATION_ENCRYPTION);
-	NDIS_802_11_CAPABILITY * pCap = (NDIS_802_11_CAPABILITY *)pucBuf;
-	u8*	pucAuthEncryptionSupported = (u8*) pCap->AuthenticationEncryptionSupported;
+	};
+	static ULONG	ulNumOfPairSupported = sizeof(szAuthEnc) / sizeof(NDIS_802_11_AUTHENTICATION_ENCRYPTION);
+	NDIS_802_11_CAPABILITY *pCap = (NDIS_802_11_CAPABILITY *)pucBuf;
+	u8	*pucAuthEncryptionSupported = (u8 *) pCap->AuthenticationEncryptionSupported;
 
 
 	pCap->Length = sizeof(NDIS_802_11_CAPABILITY);
-	if(ulNumOfPairSupported > 1 )
-		pCap->Length += 	(ulNumOfPairSupported-1) * sizeof(NDIS_802_11_AUTHENTICATION_ENCRYPTION);
-	
-	pCap->Version = 2;	
-	pCap->NoOfPMKIDs = NUM_PMKID_CACHE;	
+	if (ulNumOfPairSupported > 1)
+		pCap->Length +=	(ulNumOfPairSupported - 1) * sizeof(NDIS_802_11_AUTHENTICATION_ENCRYPTION);
+
+	pCap->Version = 2;
+	pCap->NoOfPMKIDs = NUM_PMKID_CACHE;
 	pCap->NoOfAuthEncryptPairsSupported = ulNumOfPairSupported;
 
-	if( sizeof (szAuthEnc) <= 240 )		// 240 = 256 - 4*4	// SecurityInfo.szCapability: only 256 bytes in size.
-	{
-		_rtw_memcpy( pucAuthEncryptionSupported, (u8*)szAuthEnc,  sizeof (szAuthEnc) );
+	if (sizeof(szAuthEnc) <= 240)		/* 240 = 256 - 4*4	 */ { /* SecurityInfo.szCapability: only 256 bytes in size. */
+		_rtw_memcpy(pucAuthEncryptionSupported, (u8 *)szAuthEnc,  sizeof(szAuthEnc));
 		*pulOutLen = pCap->Length;
 		return _TRUE;
-	}
-	else
-	{
+	} else {
 		*pulOutLen = 0;
-		RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("_query_802_11_capability(): szAuthEnc size is too large.\n"));
 		return _FALSE;
 	}
 }
 
-u8 query_802_11_association_information(	_adapter *padapter,PNDIS_802_11_ASSOCIATION_INFORMATION	pAssocInfo)
+u8 query_802_11_association_information(_adapter *padapter, PNDIS_802_11_ASSOCIATION_INFORMATION	pAssocInfo)
 {
 	struct wlan_network *tgt_network;
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	struct	security_priv  *psecuritypriv=&(padapter->securitypriv);
-	WLAN_BSSID_EX	*psecnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;					
-	u8 *	pDest = (u8 *)pAssocInfo + sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
-	unsigned char i,*auth_ie,*supp_ie;
+	struct	security_priv  *psecuritypriv = &(padapter->securitypriv);
+	WLAN_BSSID_EX	*psecnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
+	u8	*pDest = (u8 *)pAssocInfo + sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
+	unsigned char i, *auth_ie, *supp_ie;
 
-	//NdisZeroMemory(pAssocInfo, sizeof(NDIS_802_11_ASSOCIATION_INFORMATION));
+	/* NdisZeroMemory(pAssocInfo, sizeof(NDIS_802_11_ASSOCIATION_INFORMATION)); */
 	_rtw_memset(pAssocInfo, 0, sizeof(NDIS_802_11_ASSOCIATION_INFORMATION));
-	//pAssocInfo->Length = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
-
-	//------------------------------------------------------
-	// Association Request related information
-	//------------------------------------------------------
-	// Req_1. AvailableRequestFixedIEs
-	if(psecnetwork!=NULL){
-		
-	pAssocInfo->AvailableRequestFixedIEs |= NDIS_802_11_AI_REQFI_CAPABILITIES|NDIS_802_11_AI_REQFI_CURRENTAPADDRESS;
-	pAssocInfo->RequestFixedIEs.Capabilities = (unsigned short)* & psecnetwork->IEs[10];
-	_rtw_memcpy(pAssocInfo->RequestFixedIEs.CurrentAPAddress,
-		& psecnetwork->MacAddress, 6);
-
-	pAssocInfo->OffsetRequestIEs = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
-
-	if(check_fwstate( pmlmepriv, _FW_UNDER_LINKING|_FW_LINKED)==_TRUE)
-	{
-		
-		if(psecuritypriv->ndisauthtype>=Ndis802_11AuthModeWPA2)
-			pDest[0] =48;		//RSN Information Element
-		else 
-			pDest[0] =221;	//WPA(SSN) Information Element
-		
-		RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n Adapter->ndisauthtype==Ndis802_11AuthModeWPA)?0xdd:0x30 [%d]",pDest[0]));
-		supp_ie=&psecuritypriv->supplicant_ie[0];
-		for(i=0;i<supp_ie[0];i++)
-		{
-			RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("IEs [%d] = 0x%x \n\n", i,supp_ie[i]));
-		}
+	/* pAssocInfo->Length = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION); */
+
+	/* ------------------------------------------------------ */
+	/* Association Request related information */
+	/* ------------------------------------------------------ */
+	/* Req_1. AvailableRequestFixedIEs */
+	if (psecnetwork != NULL) {
+
+		pAssocInfo->AvailableRequestFixedIEs |= NDIS_802_11_AI_REQFI_CAPABILITIES | NDIS_802_11_AI_REQFI_CURRENTAPADDRESS;
+		pAssocInfo->RequestFixedIEs.Capabilities = (unsigned short) *&psecnetwork->IEs[10];
+		_rtw_memcpy(pAssocInfo->RequestFixedIEs.CurrentAPAddress,
+			    &psecnetwork->MacAddress, 6);
+
+		pAssocInfo->OffsetRequestIEs = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION);
+
+		if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING | _FW_LINKED) == _TRUE) {
+
+			if (psecuritypriv->ndisauthtype >= Ndis802_11AuthModeWPA2)
+				pDest[0] = 48;		/* RSN Information Element */
+			else
+				pDest[0] = 221;	/* WPA(SSN) Information Element */
+
+			supp_ie = &psecuritypriv->supplicant_ie[0];
+
+			i = 13;	/* 0~11 is fixed information element		 */
+			while ((i < supp_ie[0]) && (i < 256)) {
+				if ((unsigned char)supp_ie[i] == pDest[0]) {
+					_rtw_memcpy((u8 *)(pDest),
+						    &supp_ie[i],
+						    supp_ie[1 + i] + 2);
+
+					break;
+				}
+
+				i = i + supp_ie[i + 1] + 2;
+				if (supp_ie[1 + i] == 0)
+					i = i + 1;
 
-		i=13;	//0~11 is fixed information element		
-		RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("i= %d tgt_network->network.IELength=%d\n\n", i,(int)psecnetwork->IELength));
-		while((i<supp_ie[0]) && (i<256)){
-			if((unsigned char)supp_ie[i]==pDest[0]){
-						_rtw_memcpy((u8 *)(pDest),
-							&supp_ie[i], 
-							supp_ie[1+i]+2);
-			
-				break;
 			}
-			
-			i=i+supp_ie[i+1]+2;
-			if(supp_ie[1+i]==0)
-				i=i+1;
-			RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("iteration i=%d IEs [%d] = 0x%x \n\n", i,i,supp_ie[i+1]));
-			
-		}
-		
 
-		pAssocInfo->RequestIELength += (2 + supp_ie[1+i]);// (2 + psecnetwork->IEs[1+i]+4);
 
-	}
-	
+			pAssocInfo->RequestIELength += (2 + supp_ie[1 + i]); /* (2 + psecnetwork->IEs[1+i]+4); */
+
+		}
+
 
-		RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n psecnetwork != NULL,fwstate==_FW_UNDER_LINKING \n"));
 
 	}
-	
 
-	//------------------------------------------------------
-	// Association Response related information
-	//------------------------------------------------------
 
-	if(check_fwstate( pmlmepriv, _FW_LINKED)==_TRUE)
-	{
-		tgt_network =&(pmlmepriv->cur_network);
-		if(tgt_network!=NULL){
-		pAssocInfo->AvailableResponseFixedIEs =
+	/* ------------------------------------------------------ */
+	/* Association Response related information */
+	/* ------------------------------------------------------ */
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		tgt_network = &(pmlmepriv->cur_network);
+		if (tgt_network != NULL) {
+			pAssocInfo->AvailableResponseFixedIEs =
 				NDIS_802_11_AI_RESFI_CAPABILITIES
-				|NDIS_802_11_AI_RESFI_ASSOCIATIONID
+				| NDIS_802_11_AI_RESFI_ASSOCIATIONID
 				;
 
-		pAssocInfo->ResponseFixedIEs.Capabilities =(unsigned short)* & tgt_network->network.IEs[10];
-		pAssocInfo->ResponseFixedIEs.StatusCode = 0;
-		pAssocInfo->ResponseFixedIEs.AssociationId =(unsigned short) tgt_network->aid;
+			pAssocInfo->ResponseFixedIEs.Capabilities = (unsigned short) *&tgt_network->network.IEs[10];
+			pAssocInfo->ResponseFixedIEs.StatusCode = 0;
+			pAssocInfo->ResponseFixedIEs.AssociationId = (unsigned short) tgt_network->aid;
 
-		pDest = (u8 *)pAssocInfo + sizeof(NDIS_802_11_ASSOCIATION_INFORMATION)+pAssocInfo->RequestIELength;
-		auth_ie=&psecuritypriv->authenticator_ie[0];
+			pDest = (u8 *)pAssocInfo + sizeof(NDIS_802_11_ASSOCIATION_INFORMATION) + pAssocInfo->RequestIELength;
+			auth_ie = &psecuritypriv->authenticator_ie[0];
 
-		for(i=0;i<auth_ie[0];i++)
-			RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("IEs [%d] = 0x%x \n\n", i,auth_ie[i]));
 
-		i=auth_ie[0]-12;
-		if(i>0){
-			_rtw_memcpy((u8 *)&pDest[0],&auth_ie[1],i);
-			pAssocInfo->ResponseIELength =i; 
-		}
+			i = auth_ie[0] - 12;
+			if (i > 0) {
+				_rtw_memcpy((u8 *)&pDest[0], &auth_ie[1], i);
+				pAssocInfo->ResponseIELength = i;
+			}
 
 
-		pAssocInfo->OffsetResponseIEs = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION) + pAssocInfo->RequestIELength;  
+			pAssocInfo->OffsetResponseIEs = sizeof(NDIS_802_11_ASSOCIATION_INFORMATION) + pAssocInfo->RequestIELength;
 
 
-		RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n tgt_network != NULL,fwstate==_FW_LINKED \n"));
 		}
-	}												  	
-	RT_TRACE(_module_rtl871x_ioctl_query_c_,_drv_info_,("\n exit query_802_11_association_information \n"));
-_func_exit_;
+	}
 
 	return _TRUE;
 }
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_rtl.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_rtl.c
index 998965975491..8126ddc5c193 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_rtl.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_rtl.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,950 +12,835 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define  _RTW_IOCTL_RTL_C_
 
 #include <drv_types.h>
 
 #ifdef CONFIG_MP_INCLUDED
-#include <rtw_mp_ioctl.h>
+	#include <rtw_mp_ioctl.h>
 #endif
 
-struct oid_obj_priv oid_rtl_seg_01_01[] =
-{
-	{1, &oid_null_function},										//0x80
-	{1, &oid_null_function},										//0x81
-	{1, &oid_null_function},										//0x82
-	{1, &oid_null_function},										//0x83//OID_RT_SET_SNIFFER_MODE
-	{1, &oid_rt_get_signal_quality_hdl},							//0x84
-	{1, &oid_rt_get_small_packet_crc_hdl},						//0x85
-	{1, &oid_rt_get_middle_packet_crc_hdl},						//0x86
-	{1, &oid_rt_get_large_packet_crc_hdl},						//0x87
-	{1, &oid_rt_get_tx_retry_hdl},								//0x88
-	{1, &oid_rt_get_rx_retry_hdl},								//0x89
-	{1, &oid_rt_pro_set_fw_dig_state_hdl},						//0x8A
-	{1, &oid_rt_pro_set_fw_ra_state_hdl}	,						//0x8B
-	{1, &oid_null_function},										//0x8C
-	{1, &oid_null_function},										//0x8D
-	{1, &oid_null_function},										//0x8E
-	{1, &oid_null_function},										//0x8F
-	{1, &oid_rt_get_rx_total_packet_hdl},							//0x90
-	{1, &oid_rt_get_tx_beacon_ok_hdl},							//0x91
-	{1, &oid_rt_get_tx_beacon_err_hdl},							//0x92
-	{1, &oid_rt_get_rx_icv_err_hdl},								//0x93
-	{1, &oid_rt_set_encryption_algorithm_hdl},					//0x94
-	{1, &oid_null_function},										//0x95
-	{1, &oid_rt_get_preamble_mode_hdl},							//0x96
-	{1, &oid_null_function},										//0x97
-	{1, &oid_rt_get_ap_ip_hdl},									//0x98
-	{1, &oid_rt_get_channelplan_hdl},							//0x99	
-	{1, &oid_rt_set_preamble_mode_hdl},	 						//0x9A
-	{1, &oid_rt_set_bcn_intvl_hdl},								//0x9B
-	{1, &oid_null_function},										//0x9C
-	{1, &oid_rt_dedicate_probe_hdl},								//0x9D
-	{1, &oid_null_function},										//0x9E
-	{1, &oid_null_function},										//0x9F
-	{1, &oid_null_function},										//0xA0
-	{1, &oid_null_function},										//0xA1
-	{1, &oid_null_function},										//0xA2
-	{1, &oid_null_function},										//0xA3
-	{1, &oid_null_function},										//0xA4
-	{1, &oid_null_function},										//0xA5
-	{1, &oid_null_function},										//0xA6
-	{1, &oid_rt_get_total_tx_bytes_hdl},							//0xA7
-	{1, &oid_rt_get_total_rx_bytes_hdl},							//0xA8
-	{1, &oid_rt_current_tx_power_level_hdl},						//0xA9	
-	{1, &oid_rt_get_enc_key_mismatch_count_hdl},	 			//0xAA
-	{1, &oid_rt_get_enc_key_match_count_hdl},					//0xAB
-	{1, &oid_rt_get_channel_hdl},								//0xAC
-	{1, &oid_rt_set_channelplan_hdl},								//0xAD
-	{1, &oid_rt_get_hardware_radio_off_hdl},						//0xAE
-	{1, &oid_null_function},										//0xAF
-	{1, &oid_null_function},										//0xB0
-	{1, &oid_null_function},										//0xB1
-	{1, &oid_null_function},										//0xB2
-	{1, &oid_null_function},										//0xB3
-	{1, &oid_rt_get_key_mismatch_hdl},							//0xB4
-	{1, &oid_null_function},										//0xB5
-	{1, &oid_null_function},										//0xB6
-	{1, &oid_null_function},										//0xB7
-	{1, &oid_null_function},										//0xB8
-	{1, &oid_null_function},										//0xB9	
-	{1, &oid_null_function},	 									//0xBA
-	{1, &oid_rt_supported_wireless_mode_hdl},					//0xBB
-	{1, &oid_rt_get_channel_list_hdl},							//0xBC
-	{1, &oid_rt_get_scan_in_progress_hdl},						//0xBD
-	{1, &oid_null_function},										//0xBE
-	{1, &oid_null_function},										//0xBF
-	{1, &oid_null_function},										//0xC0
-	{1, &oid_rt_forced_data_rate_hdl},							//0xC1
-	{1, &oid_rt_wireless_mode_for_scan_list_hdl},					//0xC2
-	{1, &oid_rt_get_bss_wireless_mode_hdl},						//0xC3
-	{1, &oid_rt_scan_with_magic_packet_hdl},					//0xC4
-	{1, &oid_null_function},										//0xC5
-	{1, &oid_null_function},										//0xC6
-	{1, &oid_null_function},										//0xC7
-	{1, &oid_null_function},										//0xC8
-	{1, &oid_null_function},										//0xC9	
-	{1, &oid_null_function},	 									//0xCA
-	{1, &oid_null_function},										//0xCB
-	{1, &oid_null_function},										//0xCC
-	{1, &oid_null_function},										//0xCD
-	{1, &oid_null_function},										//0xCE
-	{1, &oid_null_function},										//0xCF
-	
+struct oid_obj_priv oid_rtl_seg_01_01[] = {
+	{1, &oid_null_function},										/* 0x80 */
+	{1, &oid_null_function},										/* 0x81 */
+	{1, &oid_null_function},										/* 0x82 */
+	{1, &oid_null_function},										/* 0x83 */ /* OID_RT_SET_SNIFFER_MODE */
+	{1, &oid_rt_get_signal_quality_hdl},							/* 0x84 */
+	{1, &oid_rt_get_small_packet_crc_hdl},						/* 0x85 */
+	{1, &oid_rt_get_middle_packet_crc_hdl},						/* 0x86 */
+	{1, &oid_rt_get_large_packet_crc_hdl},						/* 0x87 */
+	{1, &oid_rt_get_tx_retry_hdl},								/* 0x88 */
+	{1, &oid_rt_get_rx_retry_hdl},								/* 0x89 */
+	{1, &oid_rt_pro_set_fw_dig_state_hdl},						/* 0x8A */
+	{1, &oid_rt_pro_set_fw_ra_state_hdl}	,						/* 0x8B */
+	{1, &oid_null_function},										/* 0x8C */
+	{1, &oid_null_function},										/* 0x8D */
+	{1, &oid_null_function},										/* 0x8E */
+	{1, &oid_null_function},										/* 0x8F */
+	{1, &oid_rt_get_rx_total_packet_hdl},							/* 0x90 */
+	{1, &oid_rt_get_tx_beacon_ok_hdl},							/* 0x91 */
+	{1, &oid_rt_get_tx_beacon_err_hdl},							/* 0x92 */
+	{1, &oid_rt_get_rx_icv_err_hdl},								/* 0x93 */
+	{1, &oid_rt_set_encryption_algorithm_hdl},					/* 0x94 */
+	{1, &oid_null_function},										/* 0x95 */
+	{1, &oid_rt_get_preamble_mode_hdl},							/* 0x96 */
+	{1, &oid_null_function},										/* 0x97 */
+	{1, &oid_rt_get_ap_ip_hdl},									/* 0x98 */
+	{1, &oid_rt_get_channelplan_hdl},							/* 0x99	 */
+	{1, &oid_rt_set_preamble_mode_hdl},	 						/* 0x9A */
+	{1, &oid_rt_set_bcn_intvl_hdl},								/* 0x9B */
+	{1, &oid_null_function},										/* 0x9C */
+	{1, &oid_rt_dedicate_probe_hdl},								/* 0x9D */
+	{1, &oid_null_function},										/* 0x9E */
+	{1, &oid_null_function},										/* 0x9F */
+	{1, &oid_null_function},										/* 0xA0 */
+	{1, &oid_null_function},										/* 0xA1 */
+	{1, &oid_null_function},										/* 0xA2 */
+	{1, &oid_null_function},										/* 0xA3 */
+	{1, &oid_null_function},										/* 0xA4 */
+	{1, &oid_null_function},										/* 0xA5 */
+	{1, &oid_null_function},										/* 0xA6 */
+	{1, &oid_rt_get_total_tx_bytes_hdl},							/* 0xA7 */
+	{1, &oid_rt_get_total_rx_bytes_hdl},							/* 0xA8 */
+	{1, &oid_rt_current_tx_power_level_hdl},						/* 0xA9	 */
+	{1, &oid_rt_get_enc_key_mismatch_count_hdl},	 			/* 0xAA */
+	{1, &oid_rt_get_enc_key_match_count_hdl},					/* 0xAB */
+	{1, &oid_rt_get_channel_hdl},								/* 0xAC */
+	{1, &oid_rt_set_channelplan_hdl},								/* 0xAD */
+	{1, &oid_rt_get_hardware_radio_off_hdl},						/* 0xAE */
+	{1, &oid_null_function},										/* 0xAF */
+	{1, &oid_null_function},										/* 0xB0 */
+	{1, &oid_null_function},										/* 0xB1 */
+	{1, &oid_null_function},										/* 0xB2 */
+	{1, &oid_null_function},										/* 0xB3 */
+	{1, &oid_rt_get_key_mismatch_hdl},							/* 0xB4 */
+	{1, &oid_null_function},										/* 0xB5 */
+	{1, &oid_null_function},										/* 0xB6 */
+	{1, &oid_null_function},										/* 0xB7 */
+	{1, &oid_null_function},										/* 0xB8 */
+	{1, &oid_null_function},										/* 0xB9	 */
+	{1, &oid_null_function},	 									/* 0xBA */
+	{1, &oid_rt_supported_wireless_mode_hdl},					/* 0xBB */
+	{1, &oid_rt_get_channel_list_hdl},							/* 0xBC */
+	{1, &oid_rt_get_scan_in_progress_hdl},						/* 0xBD */
+	{1, &oid_null_function},										/* 0xBE */
+	{1, &oid_null_function},										/* 0xBF */
+	{1, &oid_null_function},										/* 0xC0 */
+	{1, &oid_rt_forced_data_rate_hdl},							/* 0xC1 */
+	{1, &oid_rt_wireless_mode_for_scan_list_hdl},					/* 0xC2 */
+	{1, &oid_rt_get_bss_wireless_mode_hdl},						/* 0xC3 */
+	{1, &oid_rt_scan_with_magic_packet_hdl},					/* 0xC4 */
+	{1, &oid_null_function},										/* 0xC5 */
+	{1, &oid_null_function},										/* 0xC6 */
+	{1, &oid_null_function},										/* 0xC7 */
+	{1, &oid_null_function},										/* 0xC8 */
+	{1, &oid_null_function},										/* 0xC9	 */
+	{1, &oid_null_function},	 									/* 0xCA */
+	{1, &oid_null_function},										/* 0xCB */
+	{1, &oid_null_function},										/* 0xCC */
+	{1, &oid_null_function},										/* 0xCD */
+	{1, &oid_null_function},										/* 0xCE */
+	{1, &oid_null_function},										/* 0xCF */
+
 };
 
-struct oid_obj_priv oid_rtl_seg_01_03[] =
-{
-	{1, &oid_rt_ap_get_associated_station_list_hdl},				//0x00
-	{1, &oid_null_function},										//0x01
-	{1, &oid_rt_ap_switch_into_ap_mode_hdl},					//0x02
-	{1, &oid_null_function},										//0x03
-	{1, &oid_rt_ap_supported_hdl},								//0x04
-	{1, &oid_rt_ap_set_passphrase_hdl},							//0x05
+struct oid_obj_priv oid_rtl_seg_01_03[] = {
+	{1, &oid_rt_ap_get_associated_station_list_hdl},				/* 0x00 */
+	{1, &oid_null_function},										/* 0x01 */
+	{1, &oid_rt_ap_switch_into_ap_mode_hdl},					/* 0x02 */
+	{1, &oid_null_function},										/* 0x03 */
+	{1, &oid_rt_ap_supported_hdl},								/* 0x04 */
+	{1, &oid_rt_ap_set_passphrase_hdl},							/* 0x05 */
 
 };
 
-struct oid_obj_priv oid_rtl_seg_01_11[] =
-{
-	{1, &oid_null_function},					//0xC0	OID_RT_PRO_RX_FILTER	
-	{1, &oid_null_function},					//0xC1	OID_CE_USB_WRITE_REGISTRY
-	{1, &oid_null_function},					//0xC2	OID_CE_USB_READ_REGISTRY
-	{1, &oid_null_function},					//0xC3	OID_RT_PRO_SET_INITIAL_GAIN
-	{1, &oid_null_function},					//0xC4	OID_RT_PRO_SET_BB_RF_STANDBY_MODE
-	{1, &oid_null_function},					//0xC5	OID_RT_PRO_SET_BB_RF_SHUTDOWN_MODE
-	{1, &oid_null_function},					//0xC6	OID_RT_PRO_SET_TX_CHARGE_PUMP
-	{1, &oid_null_function},					//0xC7	OID_RT_PRO_SET_RX_CHARGE_PUMP
-	{1, &oid_rt_pro_rf_write_registry_hdl},	//0xC8	
-	{1, &oid_rt_pro_rf_read_registry_hdl},	//0xC9	
-	{1, &oid_null_function}					//0xCA	OID_RT_PRO_QUERY_RF_TYPE
-	
+struct oid_obj_priv oid_rtl_seg_01_11[] = {
+	{1, &oid_null_function},					/* 0xC0	OID_RT_PRO_RX_FILTER	 */
+	{1, &oid_null_function},					/* 0xC1	OID_CE_USB_WRITE_REGISTRY */
+	{1, &oid_null_function},					/* 0xC2	OID_CE_USB_READ_REGISTRY */
+	{1, &oid_null_function},					/* 0xC3	OID_RT_PRO_SET_INITIAL_GAIN */
+	{1, &oid_null_function},					/* 0xC4	OID_RT_PRO_SET_BB_RF_STANDBY_MODE */
+	{1, &oid_null_function},					/* 0xC5	OID_RT_PRO_SET_BB_RF_SHUTDOWN_MODE */
+	{1, &oid_null_function},					/* 0xC6	OID_RT_PRO_SET_TX_CHARGE_PUMP */
+	{1, &oid_null_function},					/* 0xC7	OID_RT_PRO_SET_RX_CHARGE_PUMP */
+	{1, &oid_rt_pro_rf_write_registry_hdl},	/* 0xC8	 */
+	{1, &oid_rt_pro_rf_read_registry_hdl},	/* 0xC9	 */
+	{1, &oid_null_function}					/* 0xCA	OID_RT_PRO_QUERY_RF_TYPE */
+
 };
 
-struct oid_obj_priv oid_rtl_seg_03_00[] =
-{
-	{1, &oid_null_function},										//0x00
-	{1, &oid_rt_get_connect_state_hdl},							//0x01
-	{1, &oid_null_function},										//0x02
-	{1, &oid_null_function},										//0x03
-	{1, &oid_rt_set_default_key_id_hdl},							//0x04
+struct oid_obj_priv oid_rtl_seg_03_00[] = {
+	{1, &oid_null_function},										/* 0x00 */
+	{1, &oid_rt_get_connect_state_hdl},							/* 0x01 */
+	{1, &oid_null_function},										/* 0x02 */
+	{1, &oid_null_function},										/* 0x03 */
+	{1, &oid_rt_set_default_key_id_hdl},							/* 0x04 */
+
 
-	
 };
 
 
-//**************  oid_rtl_seg_01_01 section start ************** 
+/* **************  oid_rtl_seg_01_01 section start ************** */
 
-NDIS_STATUS oid_rt_pro_set_fw_dig_state_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_pro_set_fw_dig_state_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 #if 0
 	PADAPTER		Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 	_irqL			oldirql;
-	
-	_func_enter_;
-	
-	if(poid_par_priv->type_of_oid != SET_OID) 
-	{
+
+
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
-			
-	_irqlevel_changed_(&oldirql,LOWER);
-	if(poid_par_priv->information_buf_len >= sizeof(struct setdig_parm))
-	{
-		//DEBUG_ERR(("===> oid_rt_pro_set_fw_dig_state_hdl. type:0x%02x.\n",*((unsigned char*)poid_par_priv->information_buf )));	
-		if(!rtw_setfwdig_cmd(Adapter,*((unsigned char*)poid_par_priv->information_buf )))			
-		{
+
+	_irqlevel_changed_(&oldirql, LOWER);
+	if (poid_par_priv->information_buf_len >= sizeof(struct setdig_parm)) {
+		/* DEBUG_ERR(("===> oid_rt_pro_set_fw_dig_state_hdl. type:0x%02x.\n",*((unsigned char*)poid_par_priv->information_buf )));	 */
+		if (!rtw_setfwdig_cmd(Adapter, *((unsigned char *)poid_par_priv->information_buf)))
 			status = NDIS_STATUS_NOT_ACCEPTED;
-		}
-		                   
-	}
-	else{
+
+	} else
 		status = NDIS_STATUS_NOT_ACCEPTED;
-	}  
-	_irqlevel_changed_(&oldirql,RAISE);
-	_func_exit_;
+	_irqlevel_changed_(&oldirql, RAISE);
 #endif
 	return status;
 }
-//-----------------------------------------------------------------------------
-NDIS_STATUS oid_rt_pro_set_fw_ra_state_hdl(struct oid_par_priv* poid_par_priv)
+/* ----------------------------------------------------------------------------- */
+NDIS_STATUS oid_rt_pro_set_fw_ra_state_hdl(struct oid_par_priv *poid_par_priv)
 {
 
 	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 #if 0
 	PADAPTER		Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 	_irqL			oldirql;
-	
-	_func_enter_;	
-	if(poid_par_priv->type_of_oid != SET_OID) 
-	{
+
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
 
-					
-	_irqlevel_changed_(&oldirql,LOWER);
-	
-	if(poid_par_priv->information_buf_len >= sizeof(struct setra_parm))
-	{
-		//DEBUG_ERR(("===> oid_rt_pro_set_fw_ra_state_hdl. type:0x%02x.\n",*((unsigned char*)poid_par_priv->information_buf )));	
-		if(!rtw_setfwra_cmd(Adapter,*((unsigned char*)poid_par_priv->information_buf )))			
-		{
+
+	_irqlevel_changed_(&oldirql, LOWER);
+
+	if (poid_par_priv->information_buf_len >= sizeof(struct setra_parm)) {
+		/* DEBUG_ERR(("===> oid_rt_pro_set_fw_ra_state_hdl. type:0x%02x.\n",*((unsigned char*)poid_par_priv->information_buf )));	 */
+		if (!rtw_setfwra_cmd(Adapter, *((unsigned char *)poid_par_priv->information_buf)))
 			status = NDIS_STATUS_NOT_ACCEPTED;
-		}
-		                   
-	}
-	else{
+
+	} else
 		status = NDIS_STATUS_NOT_ACCEPTED;
-	}  
-	_irqlevel_changed_(&oldirql,RAISE);
-	_func_exit_;
+	_irqlevel_changed_(&oldirql, RAISE);
 #endif
 	return status;
 }
-//-----------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_signal_quality_hdl(struct oid_par_priv* poid_par_priv)
+/* ----------------------------------------------------------------------------- */
+NDIS_STATUS oid_rt_get_signal_quality_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	//DEBUG_ERR(("<**********************oid_rt_get_signal_quality_hdl \n"));
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	/* DEBUG_ERR(("<**********************oid_rt_get_signal_quality_hdl\n")); */
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 #if 0
-		if(pMgntInfo->mAssoc || pMgntInfo->mIbss)
-		{
-			ulInfo = pAdapter->RxStats.SignalQuality;
-			*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-		}
-		else
-		{
-			ulInfo = 0xffffffff; // It stands for -1 in 4-byte integer.
-		}
-		break;
+	if (pMgntInfo->mAssoc || pMgntInfo->mIbss) {
+		ulInfo = pAdapter->RxStats.SignalQuality;
+		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
+	} else {
+		ulInfo = 0xffffffff; /* It stands for -1 in 4-byte integer. */
+	}
+	break;
 #endif
 
 	return status;
 }
 
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 
-NDIS_STATUS oid_rt_get_small_packet_crc_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_small_packet_crc_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
-		
-	if(poid_par_priv->information_buf_len >=  sizeof(ULONG) )
-	{		
-		*(ULONG *)poid_par_priv->information_buf = padapter->recvpriv.rx_smallpacket_crcerr;
-		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;		
 	}
-	else
-	{
+
+	if (poid_par_priv->information_buf_len >=  sizeof(ULONG)) {
+		*(ULONG *)poid_par_priv->information_buf = padapter->recvpriv.rx_smallpacket_crcerr;
+		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_middle_packet_crc_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_middle_packet_crc_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
-	if(poid_par_priv->information_buf_len >=  sizeof(ULONG) )
-	{		
+	if (poid_par_priv->information_buf_len >=  sizeof(ULONG)) {
 		*(ULONG *)poid_par_priv->information_buf = padapter->recvpriv.rx_middlepacket_crcerr;
-		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;		
-	}
-	else
-	{
+		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_large_packet_crc_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_large_packet_crc_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}	
+	}
 
-	if(poid_par_priv->information_buf_len >=  sizeof(ULONG) )
-	{		
+	if (poid_par_priv->information_buf_len >=  sizeof(ULONG)) {
 		*(ULONG *)poid_par_priv->information_buf = padapter->recvpriv.rx_largepacket_crcerr;
-		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;		
-	}
-	else
-	{
+		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
 
 	return status;
 }
 
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_tx_retry_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_tx_retry_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_rx_retry_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_rx_retry_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_rx_total_packet_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_rx_total_packet_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}	
-	if(poid_par_priv->information_buf_len >=  sizeof(ULONG) )
-	{		
-		*(u64 *)poid_par_priv->information_buf = padapter->recvpriv.rx_pkts + padapter->recvpriv.rx_drop;
-		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;		
 	}
-	else
-	{
+	if (poid_par_priv->information_buf_len >=  sizeof(ULONG)) {
+		*(u64 *)poid_par_priv->information_buf = padapter->recvpriv.rx_pkts + padapter->recvpriv.rx_drop;
+		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_tx_beacon_ok_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_tx_beacon_ok_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_tx_beacon_err_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_tx_beacon_err_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_rx_icv_err_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_rx_icv_err_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
-	if(poid_par_priv->information_buf_len>= sizeof(u32))
-	{
-		//_rtw_memcpy(*(uint *)poid_par_priv->information_buf,padapter->recvpriv.rx_icv_err,sizeof(u32));
+	if (poid_par_priv->information_buf_len >= sizeof(u32)) {
+		/* _rtw_memcpy(*(uint *)poid_par_priv->information_buf,padapter->recvpriv.rx_icv_err,sizeof(u32)); */
 		*(uint *)poid_par_priv->information_buf = padapter->recvpriv.rx_icv_err;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	}
-	else
-	{
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH ;
-	}
-	
+
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_set_encryption_algorithm_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_set_encryption_algorithm_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != SET_OID)
-	{
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}	
+	}
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_preamble_mode_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_preamble_mode_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
-	ULONG			preamblemode = 0 ;			
-		
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	ULONG			preamblemode = 0 ;
+
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
-	if(poid_par_priv->information_buf_len>= sizeof(ULONG))
-	{		
-		if(padapter->registrypriv.preamble == PREAMBLE_LONG)
+	}
+	if (poid_par_priv->information_buf_len >= sizeof(ULONG)) {
+		if (padapter->registrypriv.preamble == PREAMBLE_LONG)
 			preamblemode = 0;
 		else if (padapter->registrypriv.preamble == PREAMBLE_AUTO)
 			preamblemode = 1;
 		else if (padapter->registrypriv.preamble == PREAMBLE_SHORT)
 			preamblemode = 2;
-		
-			
+
+
 		*(ULONG *)poid_par_priv->information_buf = preamblemode ;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	}
-	else
-	{
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH ;
-	}
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_ap_ip_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_ap_ip_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
 
-NDIS_STATUS oid_rt_get_channelplan_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_channelplan_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	*(u16 *)poid_par_priv->information_buf = padapter->mlmepriv.ChannelPlan ;
+	*(u16 *)poid_par_priv->information_buf = rfctl->ChannelPlan;
 
 	return status;
 }
-NDIS_STATUS oid_rt_set_channelplan_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_set_channelplan_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
-	
-	if(poid_par_priv->type_of_oid != SET_OID)
-	{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
-	
-	padapter->mlmepriv.ChannelPlan  = *(u16 *)poid_par_priv->information_buf ;
+	}
+
+	rfctl->ChannelPlan  = *(u16 *)poid_par_priv->information_buf;
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_set_preamble_mode_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_set_preamble_mode_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 	ULONG			preamblemode = 0;
-	if(poid_par_priv->type_of_oid != SET_OID)
-	{
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
-	 
-	if(poid_par_priv->information_buf_len>= sizeof(ULONG))
-	{		
+
+	if (poid_par_priv->information_buf_len >= sizeof(ULONG)) {
 		preamblemode = *(ULONG *)poid_par_priv->information_buf ;
-		if( preamblemode == 0)
+		if (preamblemode == 0)
 			padapter->registrypriv.preamble = PREAMBLE_LONG;
-		else if (preamblemode==1 )
+		else if (preamblemode == 1)
 			padapter->registrypriv.preamble = PREAMBLE_AUTO;
-		else if ( preamblemode==2 )
-			padapter->registrypriv.preamble = PREAMBLE_SHORT;		
-			
+		else if (preamblemode == 2)
+			padapter->registrypriv.preamble = PREAMBLE_SHORT;
+
 		*(ULONG *)poid_par_priv->information_buf = preamblemode ;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	}
-	else
-	{
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH ;
-	}	
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_set_bcn_intvl_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_set_bcn_intvl_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != SET_OID)
-	{
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_dedicate_probe_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_dedicate_probe_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_total_tx_bytes_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_total_tx_bytes_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}	
-	if(poid_par_priv->information_buf_len>= sizeof(ULONG))
-	{		
+	}
+	if (poid_par_priv->information_buf_len >= sizeof(ULONG)) {
 		*(u64 *)poid_par_priv->information_buf = padapter->xmitpriv.tx_bytes;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	}
-	else
-	{
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH ;
-	}
-	
+
 
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_get_total_rx_bytes_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_get_total_rx_bytes_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
-	if(poid_par_priv->information_buf_len>= sizeof(ULONG))
-	{
-		//_rtw_memcpy(*(uint *)poid_par_priv->information_buf,padapter->recvpriv.rx_icv_err,sizeof(u32));
+	if (poid_par_priv->information_buf_len >= sizeof(ULONG)) {
+		/* _rtw_memcpy(*(uint *)poid_par_priv->information_buf,padapter->recvpriv.rx_icv_err,sizeof(u32)); */
 		*(u64 *)poid_par_priv->information_buf = padapter->recvpriv.rx_bytes;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	}
-	else
-	{
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH ;
-	}
 	return status;
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_current_tx_power_level_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_current_tx_power_level_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_enc_key_mismatch_count_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_enc_key_mismatch_count_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_enc_key_match_count_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_enc_key_match_count_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_channel_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_channel_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 	struct	mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	NDIS_802_11_CONFIGURATION		*pnic_Config;
 
 	ULONG   channelnum;
 
-	_func_enter_;
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
-	if ( (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
-		(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE))
+	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE))
 		pnic_Config = &pmlmepriv->cur_network.network.Configuration;
 	else
 		pnic_Config = &padapter->registrypriv.dev_network.Configuration;
 
 	channelnum = pnic_Config->DSConfig;
 	*(ULONG *)poid_par_priv->information_buf = channelnum;
-	
+
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	_func_exit_;
 
 
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_hardware_radio_off_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_hardware_radio_off_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_key_mismatch_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_key_mismatch_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_supported_wireless_mode_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_supported_wireless_mode_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
-	ULONG 			ulInfo = 0 ;
-	//DEBUG_ERR(("<**********************oid_rt_supported_wireless_mode_hdl \n"));	
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	ULONG			ulInfo = 0 ;
+	/* DEBUG_ERR(("<**********************oid_rt_supported_wireless_mode_hdl\n"));	 */
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
-	if(poid_par_priv->information_buf_len >= sizeof(ULONG)){
-		ulInfo |= 0x0100; //WIRELESS_MODE_B
-		ulInfo |= 0x0200; //WIRELESS_MODE_G
-		ulInfo |= 0x0400; //WIRELESS_MODE_A
+	}
+	if (poid_par_priv->information_buf_len >= sizeof(ULONG)) {
+		ulInfo |= 0x0100; /* WIRELESS_MODE_B */
+		ulInfo |= 0x0200; /* WIRELESS_MODE_G */
+		ulInfo |= 0x0400; /* WIRELESS_MODE_A */
 
-		*(ULONG *) poid_par_priv->information_buf = ulInfo;		
-		//DEBUG_ERR(("<===oid_rt_supported_wireless_mode %x\n",ulInfo));	
+		*(ULONG *) poid_par_priv->information_buf = ulInfo;
+		/* DEBUG_ERR(("<===oid_rt_supported_wireless_mode %x\n",ulInfo));	 */
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	}
-	else{
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}		
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_channel_list_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_channel_list_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_scan_in_progress_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_scan_in_progress_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
 
 
-NDIS_STATUS oid_rt_forced_data_rate_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_forced_data_rate_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	return status;
 }
-NDIS_STATUS oid_rt_wireless_mode_for_scan_list_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_wireless_mode_for_scan_list_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	return status;
 }
-NDIS_STATUS oid_rt_get_bss_wireless_mode_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_bss_wireless_mode_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
 
-NDIS_STATUS oid_rt_scan_with_magic_packet_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_scan_with_magic_packet_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	return status;
 }
-//**************  oid_rtl_seg_01_01 section end ************** 
+/* **************  oid_rtl_seg_01_01 section end ************** */
 
-//**************  oid_rtl_seg_01_03 section start ************** 
-NDIS_STATUS oid_rt_ap_get_associated_station_list_hdl(struct oid_par_priv* poid_par_priv)
+/* **************  oid_rtl_seg_01_03 section start ************** */
+NDIS_STATUS oid_rt_ap_get_associated_station_list_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
-NDIS_STATUS oid_rt_ap_switch_into_ap_mode_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_ap_switch_into_ap_mode_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	return status;
 }
-NDIS_STATUS oid_rt_ap_supported_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_ap_supported_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	return status;
 }
-NDIS_STATUS oid_rt_ap_set_passphrase_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_ap_set_passphrase_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != SET_OID)
-	{
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
 	return status;
 }
 
-//**************  oid_rtl_seg_01_03 section end ************** 
+/* **************  oid_rtl_seg_01_03 section end ************** */
 
-//****************  oid_rtl_seg_01_11   section start ****************
-NDIS_STATUS oid_rt_pro_rf_write_registry_hdl(struct oid_par_priv* poid_par_priv)
+/* ****************  oid_rtl_seg_01_11   section start **************** */
+NDIS_STATUS oid_rt_pro_rf_write_registry_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 	_irqL			oldirql;
-	_func_enter_;
-	//DEBUG_ERR(("<**********************oid_rt_pro_rf_write_registry_hdl \n"));
-	if(poid_par_priv->type_of_oid != SET_OID) //QUERY_OID
-	{
-		status = NDIS_STATUS_NOT_ACCEPTED;
-		return status;
-	}
-	
-	_irqlevel_changed_(&oldirql,LOWER);
-	if(poid_par_priv->information_buf_len== (sizeof(unsigned long)*3))
-	{      
-		//RegOffsetValue	- The offset of RF register to write.
-		//RegDataWidth	- The data width of RF register to write.
-		//RegDataValue	- The value to write. 
-		//RegOffsetValue = *((unsigned long*)InformationBuffer);
-		//RegDataWidth = *((unsigned long*)InformationBuffer+1);	   
-		//RegDataValue =  *((unsigned long*)InformationBuffer+2);	
-		if(!rtw_setrfreg_cmd(Adapter, 
-						*(unsigned char*)poid_par_priv->information_buf, 
-						(unsigned long)(*((unsigned long*)poid_par_priv->information_buf+2))))
-		{
-			status = NDIS_STATUS_NOT_ACCEPTED;
-		}
-	                   
+	/* DEBUG_ERR(("<**********************oid_rt_pro_rf_write_registry_hdl\n")); */
+	if (poid_par_priv->type_of_oid != SET_OID) { /* QUERY_OID */
+		status = NDIS_STATUS_NOT_ACCEPTED;
+		return status;
 	}
-	else{
+
+	_irqlevel_changed_(&oldirql, LOWER);
+	if (poid_par_priv->information_buf_len == (sizeof(unsigned long) * 3)) {
+		/* RegOffsetValue	- The offset of RF register to write. */
+		/* RegDataWidth	- The data width of RF register to write. */
+		/* RegDataValue	- The value to write. */
+		/* RegOffsetValue = *((unsigned long*)InformationBuffer); */
+		/* RegDataWidth = *((unsigned long*)InformationBuffer+1);	   */
+		/* RegDataValue =  *((unsigned long*)InformationBuffer+2);	 */
+		if (!rtw_setrfreg_cmd(Adapter,
+			      *(unsigned char *)poid_par_priv->information_buf,
+			(unsigned long)(*((unsigned long *)poid_par_priv->information_buf + 2))))
+			status = NDIS_STATUS_NOT_ACCEPTED;
+
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}   
-	_irqlevel_changed_(&oldirql,RAISE);
-	_func_exit_;
+	_irqlevel_changed_(&oldirql, RAISE);
 
 	return status;
 }
 
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_pro_rf_read_registry_hdl(struct oid_par_priv* poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_pro_rf_read_registry_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 #if 0
 	PADAPTER		Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 	_irqL	oldirql;
-	_func_enter_;
 
-	//DEBUG_ERR(("<**********************oid_rt_pro_rf_read_registry_hdl \n"));
-	if(poid_par_priv->type_of_oid != SET_OID) //QUERY_OID
-	{
+	/* DEBUG_ERR(("<**********************oid_rt_pro_rf_read_registry_hdl\n")); */
+	if (poid_par_priv->type_of_oid != SET_OID) { /* QUERY_OID */
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}	
-	
-	_irqlevel_changed_(&oldirql,LOWER);
-	if(poid_par_priv->information_buf_len== (sizeof(unsigned long)*3))
-	{
-		if(Adapter->mppriv.act_in_progress == _TRUE)
-		{
+	}
+
+	_irqlevel_changed_(&oldirql, LOWER);
+	if (poid_par_priv->information_buf_len == (sizeof(unsigned long) * 3)) {
+		if (Adapter->mppriv.act_in_progress == _TRUE)
 			status = NDIS_STATUS_NOT_ACCEPTED;
-		}
-		else
-		{
-			//init workparam
+		else {
+			/* init workparam */
 			Adapter->mppriv.act_in_progress = _TRUE;
-			Adapter->mppriv.workparam.bcompleted= _FALSE;
+			Adapter->mppriv.workparam.bcompleted = _FALSE;
 			Adapter->mppriv.workparam.act_type = MPT_READ_RF;
-			Adapter->mppriv.workparam.io_offset = *(unsigned long*)poid_par_priv->information_buf;		
+			Adapter->mppriv.workparam.io_offset = *(unsigned long *)poid_par_priv->information_buf;
 			Adapter->mppriv.workparam.io_value = 0xcccccccc;
-				       
-			//RegOffsetValue	- The offset of RF register to read.
-			//RegDataWidth	- The data width of RF register to read.
-			//RegDataValue	- The value to read. 
-			//RegOffsetValue = *((unsigned long*)InformationBuffer);
-			//RegDataWidth = *((unsigned long*)InformationBuffer+1);	   
-			//RegDataValue =  *((unsigned long*)InformationBuffer+2);	   	 	                   
-			if(!rtw_getrfreg_cmd(Adapter, 
-							*(unsigned char*)poid_par_priv->information_buf, 
-							(unsigned char*)&Adapter->mppriv.workparam.io_value))
-			{
+
+			/* RegOffsetValue	- The offset of RF register to read. */
+			/* RegDataWidth	- The data width of RF register to read. */
+			/* RegDataValue	- The value to read. */
+			/* RegOffsetValue = *((unsigned long*)InformationBuffer); */
+			/* RegDataWidth = *((unsigned long*)InformationBuffer+1);	   */
+			/* RegDataValue =  *((unsigned long*)InformationBuffer+2);	   	 	                   */
+			if (!rtw_getrfreg_cmd(Adapter,
+				*(unsigned char *)poid_par_priv->information_buf,
+				(unsigned char *)&Adapter->mppriv.workparam.io_value))
 				status = NDIS_STATUS_NOT_ACCEPTED;
-			}
 		}
-				      		   
-		                   
-	}
-	else	{
+
+
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
-	_irqlevel_changed_(&oldirql,RAISE);
-	_func_exit_;
+	_irqlevel_changed_(&oldirql, RAISE);
 #endif
 	return status;
 }
 
-//****************  oid_rtl_seg_01_11   section end****************	
+/* ****************  oid_rtl_seg_01_11   section end****************	 */
 
 
-//**************  oid_rtl_seg_03_00 section start **************  
-enum _CONNECT_STATE_{
+/* **************  oid_rtl_seg_03_00 section start **************  */
+enum _CONNECT_STATE_ {
 	CHECKINGSTATUS,
 	ASSOCIATED,
 	ADHOCMODE,
 	NOTASSOCIATED
 };
 
-NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
@@ -962,23 +848,22 @@ NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv* poid_par_priv)
 	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 
 	ULONG ulInfo;
-		
-	if(poid_par_priv->type_of_oid != QUERY_OID)
-	{
+
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
-	}		
+	}
 
-	// nStatus==0	CheckingStatus
-	// nStatus==1	Associated
-	// nStatus==2	AdHocMode
-	// nStatus==3	NotAssociated
-	
-	if(check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
+	/* nStatus==0	CheckingStatus */
+	/* nStatus==1	Associated */
+	/* nStatus==2	AdHocMode */
+	/* nStatus==3	NotAssociated */
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
 		ulInfo = CHECKINGSTATUS;
-	else if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)	
+	else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 		ulInfo = ASSOCIATED;
-	else if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)== _TRUE)
+	else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)
 		ulInfo = ADHOCMODE;
 	else
 		ulInfo = NOTASSOCIATED ;
@@ -987,35 +872,31 @@ NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv* poid_par_priv)
 	*poid_par_priv->bytes_rw =  poid_par_priv->information_buf_len;
 
 #if 0
-	// Rearrange the order to let the UI still shows connection when scan is in progress
-	RT_TRACE(COMP_OID_QUERY, DBG_LOUD, ("===> Query OID_RT_GET_CONNECT_STATE.\n"));
-	if(pMgntInfo->mAssoc)
+	/* Rearrange the order to let the UI still shows connection when scan is in progress */
+	if (pMgntInfo->mAssoc)
 		ulInfo = 1;
-	else if(pMgntInfo->mIbss)
+	else if (pMgntInfo->mIbss)
 		ulInfo = 2;
-	else if(pMgntInfo->bScanInProgress)
+	else if (pMgntInfo->bScanInProgress)
 		ulInfo = 0;
 	else
 		ulInfo = 3;
 	ulInfoLen = sizeof(ULONG);
-	RT_TRACE(COMP_OID_QUERY, DBG_LOUD, ("<=== Query OID_RT_GET_CONNECT_STATE: %d\n", ulInfo));
 #endif
 
 	return status;
 }
 
-NDIS_STATUS oid_rt_set_default_key_id_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_set_default_key_id_hdl(struct oid_par_priv *poid_par_priv)
 {
-	NDIS_STATUS	 	status = NDIS_STATUS_SUCCESS;
+	NDIS_STATUS		status = NDIS_STATUS_SUCCESS;
 	PADAPTER		padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-	if(poid_par_priv->type_of_oid != SET_OID)
-	{
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
-	
+
 	return status;
 }
-//**************  oid_rtl_seg_03_00 section end **************  
-
+/* **************  oid_rtl_seg_03_00 section end **************  */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_set.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_set.c
index caf69ee5973a..fae77549882d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_set.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_ioctl_set.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_IOCTL_SET_C_
 
 #include <drv_types.h>
@@ -26,22 +22,21 @@
 extern void indicate_wx_scan_complete_event(_adapter *padapter);
 
 #define IS_MAC_ADDRESS_BROADCAST(addr) \
-( \
-	( (addr[0] == 0xff) && (addr[1] == 0xff) && \
-		(addr[2] == 0xff) && (addr[3] == 0xff) && \
-		(addr[4] == 0xff) && (addr[5] == 0xff) )  ? _TRUE : _FALSE \
-)
+	(\
+	 ((addr[0] == 0xff) && (addr[1] == 0xff) && \
+	  (addr[2] == 0xff) && (addr[3] == 0xff) && \
+	  (addr[4] == 0xff) && (addr[5] == 0xff)) ? _TRUE : _FALSE \
+	)
 
 u8 rtw_validate_bssid(u8 *bssid)
 {
 	u8 ret = _TRUE;
 
 	if (is_zero_mac_addr(bssid)
-		|| is_broadcast_mac_addr(bssid)
-		|| is_multicast_mac_addr(bssid)
-	) { 
+	    || is_broadcast_mac_addr(bssid)
+	    || is_multicast_mac_addr(bssid)
+	   )
 		ret = _FALSE;
-	}
 
 	return ret;
 }
@@ -49,162 +44,141 @@ u8 rtw_validate_bssid(u8 *bssid)
 u8 rtw_validate_ssid(NDIS_802_11_SSID *ssid)
 {
 	u8	 i;
-	u8	ret=_TRUE;
+	u8	ret = _TRUE;
 
-_func_enter_;	
 
 	if (ssid->SsidLength > 32) {
-		RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_, ("ssid length >32\n"));
-		ret= _FALSE;
+		ret = _FALSE;
 		goto exit;
 	}
 
 #ifdef CONFIG_VALIDATE_SSID
-	for(i = 0; i < ssid->SsidLength; i++)
-	{
-		//wifi, printable ascii code must be supported
-		if(!( (ssid->Ssid[i] >= 0x20) && (ssid->Ssid[i] <= 0x7e) )){
-			RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_, ("ssid has nonprintabl ascii\n"));
-			ret= _FALSE;
+	for (i = 0; i < ssid->SsidLength; i++) {
+		/* wifi, printable ascii code must be supported */
+		if (!((ssid->Ssid[i] >= 0x20) && (ssid->Ssid[i] <= 0x7e))) {
+			ret = _FALSE;
 			break;
 		}
 	}
 #endif /* CONFIG_VALIDATE_SSID */
 
-exit:	
+exit:
 
-_func_exit_;
 
 	return ret;
 }
 
-u8 rtw_do_join(_adapter * padapter);
-u8 rtw_do_join(_adapter * padapter)
+u8 rtw_do_join(_adapter *padapter);
+u8 rtw_do_join(_adapter *padapter)
 {
 	_irqL	irqL;
 	_list	*plist, *phead;
-	u8* pibss = NULL;
+	u8 *pibss = NULL;
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct sitesurvey_parm parm;
 	_queue	*queue	= &(pmlmepriv->scanned_queue);
-	u8 ret=_SUCCESS;
+	u8 ret = _SUCCESS;
 
-_func_enter_;
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 	phead = get_list_head(queue);
 	plist = get_next(phead);
 
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("\n rtw_do_join: phead = %p; plist = %p \n\n\n", phead, plist));
 
 	pmlmepriv->cur_network.join_res = -2;
-		
+
 	set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
 
 	pmlmepriv->pscanned = plist;
 
 	pmlmepriv->to_join = _TRUE;
 
-	if(_rtw_queue_empty(queue)== _TRUE)
-	{	
+	rtw_init_sitesurvey_parm(padapter, &parm);
+	_rtw_memcpy(&parm.ssid[0], &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
+	parm.ssid_num = 1;
+
+	if (_rtw_queue_empty(queue) == _TRUE) {
 		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 		_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-            		
-		//when set_ssid/set_bssid for rtw_do_join(), but scanning queue is empty
-		//we try to issue sitesurvey firstly	
-            		
-		if (pmlmepriv->LinkDetectInfo.bBusyTraffic ==_FALSE
-			|| rtw_to_roam(padapter) > 0
-		)
-		{
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("rtw_do_join(): site survey if scanned_queue is empty\n."));
-			// submit site_survey_cmd
-			if(_SUCCESS!=(ret=rtw_sitesurvey_cmd(padapter, &pmlmepriv->assoc_ssid, 1, NULL, 0)) ) {
+
+		/* when set_ssid/set_bssid for rtw_do_join(), but scanning queue is empty */
+		/* we try to issue sitesurvey firstly	 */
+
+		if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _FALSE
+		    || rtw_to_roam(padapter) > 0
+		   ) {
+			/* submit site_survey_cmd */
+			ret = rtw_sitesurvey_cmd(padapter, &parm);
+			if (_SUCCESS != ret) {
 				pmlmepriv->to_join = _FALSE;
-				RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("rtw_do_join(): site survey return error\n."));
 			}
-		}
-		else
-		{
+		} else {
 			pmlmepriv->to_join = _FALSE;
 			ret = _FAIL;
 		}
-		
+
 		goto exit;
-	}	
-	else 	
-	{
+	} else {
 		int select_ret;
 		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-		if((select_ret=rtw_select_and_join_from_scanned_queue(pmlmepriv))==_SUCCESS)
-		{
+		select_ret = rtw_select_and_join_from_scanned_queue(pmlmepriv);
+		if (select_ret == _SUCCESS) {
 			pmlmepriv->to_join = _FALSE;
 			_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
-		}
-		else	
-		{
-			if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)==_TRUE)
-			{
-				// submit createbss_cmd to change to a ADHOC_MASTER
+		} else {
+			if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+				/* submit createbss_cmd to change to a ADHOC_MASTER */
 
- 				//pmlmepriv->lock has been acquired by caller...
+				/* pmlmepriv->lock has been acquired by caller... */
 				WLAN_BSSID_EX    *pdev_network = &(padapter->registrypriv.dev_network);
 
-				pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;
-				
+				/*pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;*/
+				init_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
+
 				pibss = padapter->registrypriv.dev_network.MacAddress;
 
 				_rtw_memset(&pdev_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
 				_rtw_memcpy(&pdev_network->Ssid, &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
-	
+
 				rtw_update_registrypriv_dev_network(padapter);
 
 				rtw_generate_random_ibss(pibss);
-					
+
 				if (rtw_create_ibss_cmd(padapter, 0) != _SUCCESS) {
-					RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_, ("***Error=>do_goin: rtw_create_ibss_cmd status FAIL***\n"));						
 					ret =  _FALSE;
 					goto exit;
 				}
 
-			     	pmlmepriv->to_join = _FALSE;
+				pmlmepriv->to_join = _FALSE;
 
-				RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("***Error=> rtw_select_and_join_from_scanned_queue FAIL under STA_Mode*** \n "));						
 
-			}			
-			else
-			{ 
-				// can't associate ; reset under-linking			
+			} else {
+				/* can't associate ; reset under-linking			 */
 				_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
 
-#if 0	
-				if((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE))
-				{
-					if(_rtw_memcmp(pmlmepriv->cur_network.network.Ssid.Ssid, pmlmepriv->assoc_ssid.Ssid, pmlmepriv->assoc_ssid.SsidLength))
-					{ 
-						// for funk to do roaming
-						// funk will reconnect, but funk will not sitesurvey before reconnect
-						RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("for funk to do roaming"));
-						if(pmlmepriv->sitesurveyctrl.traffic_busy==_FALSE)
-							rtw_sitesurvey_cmd(padapter, &pmlmepriv->assoc_ssid, 1, NULL, 0);
+#if 0
+				if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)) {
+					if (_rtw_memcmp(pmlmepriv->cur_network.network.Ssid.Ssid, pmlmepriv->assoc_ssid.Ssid, pmlmepriv->assoc_ssid.SsidLength)) {
+						/* for funk to do roaming */
+						/* funk will reconnect, but funk will not sitesurvey before reconnect */
+						if (pmlmepriv->sitesurveyctrl.traffic_busy == _FALSE)
+							rtw_sitesurvey_cmd(padapter, &parm);
 					}
-				
-				}				
+
+				}
 #endif
 
-				//when set_ssid/set_bssid for rtw_do_join(), but there are no desired bss in scanning queue
-				//we try to issue sitesurvey firstly			
-				if(pmlmepriv->LinkDetectInfo.bBusyTraffic==_FALSE
-					|| rtw_to_roam(padapter) > 0
-				)
-				{
-					//DBG_871X("rtw_do_join() when   no desired bss in scanning queue \n");
-					if( _SUCCESS!=(ret=rtw_sitesurvey_cmd(padapter, &pmlmepriv->assoc_ssid, 1, NULL, 0)) ){
+				/* when set_ssid/set_bssid for rtw_do_join(), but there are no desired bss in scanning queue */
+				/* we try to issue sitesurvey firstly			 */
+				if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _FALSE
+				    || rtw_to_roam(padapter) > 0
+				   ) {
+					/* RTW_INFO("rtw_do_join() when   no desired bss in scanning queue\n"); */
+					ret = rtw_sitesurvey_cmd(padapter, &parm);
+					if (_SUCCESS != ret) {
 						pmlmepriv->to_join = _FALSE;
-						RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("do_join(): site survey return error\n."));
 					}
-				}				
-				else
-				{
+				} else {
 					ret = _FAIL;
 					pmlmepriv->to_join = _FALSE;
 				}
@@ -213,162 +187,133 @@ _func_enter_;
 		}
 
 	}
-	
+
 exit:
-	
-_func_exit_;	
 
-	return ret;	
+	return ret;
 }
 
 #ifdef PLATFORM_WINDOWS
-u8 rtw_pnp_set_power_wakeup(_adapter* padapter)
+u8 rtw_pnp_set_power_wakeup(_adapter *padapter)
 {
-	u8 res=_SUCCESS;
+	u8 res = _SUCCESS;
+
 
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("==>rtw_pnp_set_power_wakeup!!!\n"));
-	
 	res = rtw_setstandby_cmd(padapter, 0);
 
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("<==rtw_pnp_set_power_wakeup!!!\n"));
 
-_func_exit_;
-	
+
 	return res;
 }
 
-u8 rtw_pnp_set_power_sleep(_adapter* padapter)
+u8 rtw_pnp_set_power_sleep(_adapter *padapter)
 {
-	u8 res=_SUCCESS;	
-	
-_func_enter_;
+	u8 res = _SUCCESS;
 
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("==>rtw_pnp_set_power_sleep!!!\n"));
-	//DbgPrint("+rtw_pnp_set_power_sleep\n");
+
+	/* DbgPrint("+rtw_pnp_set_power_sleep\n"); */
 
 	res = rtw_setstandby_cmd(padapter, 1);
 
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("<==rtw_pnp_set_power_sleep!!!\n"));
 
-_func_exit_;
 
 	return res;
 }
 
-u8 rtw_set_802_11_reload_defaults(_adapter * padapter, NDIS_802_11_RELOAD_DEFAULTS reloadDefaults)
+u8 rtw_set_802_11_reload_defaults(_adapter *padapter, NDIS_802_11_RELOAD_DEFAULTS reloadDefaults)
 {
-_func_enter_;
 
-	switch( reloadDefaults)
-	{
-		case Ndis802_11ReloadWEPKeys:
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("SetInfo OID_802_11_RELOAD_DEFAULTS : Ndis802_11ReloadWEPKeys\n"));
-			break;
-	}
 
-	// SecClearAllKeys(Adapter);
-	// 8711 CAM was not for En/Decrypt only
-	// so, we can't clear all keys.
-	// should we disable WPAcfg (ox0088) bit 1-2, instead of clear all CAM
-	
-	//TO DO...
 
-_func_exit_;
-	
+	/* SecClearAllKeys(Adapter); */
+	/* 8711 CAM was not for En/Decrypt only */
+	/* so, we can't clear all keys. */
+	/* should we disable WPAcfg (ox0088) bit 1-2, instead of clear all CAM */
+
+	/* TO DO... */
+
+
 	return _TRUE;
 }
 
-u8 set_802_11_test(_adapter* padapter, NDIS_802_11_TEST *test)
+u8 set_802_11_test(_adapter *padapter, NDIS_802_11_TEST *test)
 {
-	u8 ret=_TRUE;
-	
-_func_enter_;
+	u8 ret = _TRUE;
 
-	switch(test->Type)
-	{
-		case 1:
-			NdisMIndicateStatus(padapter->hndis_adapter, NDIS_STATUS_MEDIA_SPECIFIC_INDICATION, (PVOID)&test->AuthenticationEvent, test->Length - 8);
-			NdisMIndicateStatusComplete(padapter->hndis_adapter);
-			break;
 
-		case 2:
-			NdisMIndicateStatus(padapter->hndis_adapter, NDIS_STATUS_MEDIA_SPECIFIC_INDICATION, (PVOID)&test->RssiTrigger, sizeof(NDIS_802_11_RSSI));
-			NdisMIndicateStatusComplete(padapter->hndis_adapter);
-			break;
+	switch (test->Type) {
+	case 1:
+		NdisMIndicateStatus(padapter->hndis_adapter, NDIS_STATUS_MEDIA_SPECIFIC_INDICATION, (PVOID)&test->AuthenticationEvent, test->Length - 8);
+		NdisMIndicateStatusComplete(padapter->hndis_adapter);
+		break;
 
-		default:
-			ret=_FALSE;
-			break;
+	case 2:
+		NdisMIndicateStatus(padapter->hndis_adapter, NDIS_STATUS_MEDIA_SPECIFIC_INDICATION, (PVOID)&test->RssiTrigger, sizeof(NDIS_802_11_RSSI));
+		NdisMIndicateStatusComplete(padapter->hndis_adapter);
+		break;
+
+	default:
+		ret = _FALSE;
+		break;
 	}
 
-_func_exit_;
 
-	return ret;	
+	return ret;
 }
 
-u8	rtw_set_802_11_pmkid(_adapter*	padapter, NDIS_802_11_PMKID *pmkid)
+u8	rtw_set_802_11_pmkid(_adapter	*padapter, NDIS_802_11_PMKID *pmkid)
 {
-	u8	ret=_SUCCESS;
+	u8	ret = _SUCCESS;
 
 	return ret;
 }
 
 #endif
 
-u8 rtw_set_802_11_bssid(_adapter* padapter, u8 *bssid)
-{	
-	_irqL irqL;	
-	u8 status=_SUCCESS;
+u8 rtw_set_802_11_bssid(_adapter *padapter, u8 *bssid)
+{
+	_irqL irqL;
+	u8 status = _SUCCESS;
 
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	
-_func_enter_;
-	
-	DBG_871X_LEVEL(_drv_always_, "set bssid:%pM\n", bssid);
 
-	if ((bssid[0]==0x00 && bssid[1]==0x00 && bssid[2]==0x00 && bssid[3]==0x00 && bssid[4]==0x00 &&bssid[5]==0x00) ||
-	    (bssid[0]==0xFF && bssid[1]==0xFF && bssid[2]==0xFF && bssid[3]==0xFF && bssid[4]==0xFF &&bssid[5]==0xFF))
-	{
+
+	RTW_PRINT("set bssid:%pM\n", bssid);
+
+	if ((bssid[0] == 0x00 && bssid[1] == 0x00 && bssid[2] == 0x00 && bssid[3] == 0x00 && bssid[4] == 0x00 && bssid[5] == 0x00) ||
+	    (bssid[0] == 0xFF && bssid[1] == 0xFF && bssid[2] == 0xFF && bssid[3] == 0xFF && bssid[4] == 0xFF && bssid[5] == 0xFF)) {
 		status = _FAIL;
 		goto exit;
 	}
-		
+
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
 
-	DBG_871X("Set BSSID under fw_state=0x%08x\n", get_fwstate(pmlmepriv));
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+	RTW_INFO("Set BSSID under fw_state=0x%08x\n", get_fwstate(pmlmepriv));
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
 		goto handle_tkip_countermeasure;
-	} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+	else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
 		goto release_mlme_lock;
-	}
 
-	if (check_fwstate(pmlmepriv, _FW_LINKED|WIFI_ADHOC_MASTER_STATE) == _TRUE)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_, ("set_bssid: _FW_LINKED||WIFI_ADHOC_MASTER_STATE\n"));
+	if (check_fwstate(pmlmepriv, _FW_LINKED | WIFI_ADHOC_MASTER_STATE) == _TRUE) {
 
-		if (_rtw_memcmp(&pmlmepriv->cur_network.network.MacAddress, bssid, ETH_ALEN) == _TRUE)
-		{		
+		if (_rtw_memcmp(&pmlmepriv->cur_network.network.MacAddress, bssid, ETH_ALEN) == _TRUE) {
 			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE)
-				goto release_mlme_lock;//it means driver is in WIFI_ADHOC_MASTER_STATE, we needn't create bss again.
+				goto release_mlme_lock;/* it means driver is in WIFI_ADHOC_MASTER_STATE, we needn't create bss again. */
 		} else {
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("Set BSSID not the same bssid\n"));
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("set_bssid="MAC_FMT"\n", MAC_ARG(bssid) ));
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("cur_bssid="MAC_FMT"\n", MAC_ARG(pmlmepriv->cur_network.network.MacAddress) ));
 
-			rtw_disassoc_cmd(padapter, 0, _TRUE);
+			rtw_disassoc_cmd(padapter, 0, 0);
 
 			if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 				rtw_indicate_disconnect(padapter, 0, _FALSE);
 
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources_cmd(padapter, _TRUE);
 
 			if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
 				_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
 				set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
-			}		
+			}
 		}
 	}
 
@@ -380,115 +325,89 @@ handle_tkip_countermeasure:
 
 	_rtw_memset(&pmlmepriv->assoc_ssid, 0, sizeof(NDIS_802_11_SSID));
 	_rtw_memcpy(&pmlmepriv->assoc_bssid, bssid, ETH_ALEN);
-	pmlmepriv->assoc_by_bssid=_TRUE;
+	pmlmepriv->assoc_by_bssid = _TRUE;
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
-		pmlmepriv->to_join = _TRUE;	
-	}
-	else {
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
+		pmlmepriv->to_join = _TRUE;
+	else
 		status = rtw_do_join(padapter);
-	}
 
 release_mlme_lock:
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
-		
+
 exit:
-	RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-		("rtw_set_802_11_bssid: status=%d\n", status));
-	
-_func_exit_;
+
 
 	return status;
 }
 
-u8 rtw_set_802_11_ssid(_adapter* padapter, NDIS_802_11_SSID *ssid)
-{	
+u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid)
+{
 	_irqL irqL;
 	u8 status = _SUCCESS;
 	u32 cur_time = 0;
 
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct wlan_network *pnetwork = &pmlmepriv->cur_network;
-	
-_func_enter_;
-	
-	DBG_871X_LEVEL(_drv_always_, "set ssid [%s] fw_state=0x%08x\n",
-		       	ssid->Ssid, get_fwstate(pmlmepriv));
+
+
+	RTW_PRINT("set ssid [%s] fw_state=0x%08x\n",
+		  ssid->Ssid, get_fwstate(pmlmepriv));
 
 	if (!rtw_is_hw_init_completed(padapter)) {
-		RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-			 ("set_ssid: hw_init_completed==_FALSE=>exit!!!\n"));
 		status = _FAIL;
 		goto exit;
 	}
-		
+
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	DBG_871X("Set SSID under fw_state=0x%08x\n", get_fwstate(pmlmepriv));
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {	
+	RTW_INFO("Set SSID under fw_state=0x%08x\n", get_fwstate(pmlmepriv));
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
 		goto handle_tkip_countermeasure;
-	} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+	else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
 		goto release_mlme_lock;
-	}
 
-	if (check_fwstate(pmlmepriv, _FW_LINKED|WIFI_ADHOC_MASTER_STATE) == _TRUE)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-			 ("set_ssid: _FW_LINKED||WIFI_ADHOC_MASTER_STATE\n"));
+	if (check_fwstate(pmlmepriv, _FW_LINKED | WIFI_ADHOC_MASTER_STATE) == _TRUE) {
 
 		if ((pmlmepriv->assoc_ssid.SsidLength == ssid->SsidLength) &&
-		    (_rtw_memcmp(&pmlmepriv->assoc_ssid.Ssid, ssid->Ssid, ssid->SsidLength) == _TRUE))
-		{			
-			if((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE))
-			{
-				RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-					 ("Set SSID is the same ssid, fw_state=0x%08x\n",
-					  get_fwstate(pmlmepriv)));
-
-				if(rtw_is_same_ibss(padapter, pnetwork) == _FALSE)
-				{				
-					//if in WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE, create bss or rejoin again
-					rtw_disassoc_cmd(padapter, 0, _TRUE);
+		    (_rtw_memcmp(&pmlmepriv->assoc_ssid.Ssid, ssid->Ssid, ssid->SsidLength) == _TRUE)) {
+			if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE)) {
+
+				if (rtw_is_same_ibss(padapter, pnetwork) == _FALSE) {
+					/* if in WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE, create bss or rejoin again */
+					rtw_disassoc_cmd(padapter, 0, 0);
 
 					if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 						rtw_indicate_disconnect(padapter, 0, _FALSE);
-						
-					rtw_free_assoc_resources(padapter, 1);
+
+					rtw_free_assoc_resources_cmd(padapter, _TRUE);
 
 					if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
 						_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
 						set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
 					}
-				}
-				else
-				{
-					goto release_mlme_lock;//it means driver is in WIFI_ADHOC_MASTER_STATE, we needn't create bss again.
+				} else {
+					goto release_mlme_lock;/* it means driver is in WIFI_ADHOC_MASTER_STATE, we needn't create bss again. */
 				}
 			}
 #ifdef CONFIG_LPS
-			else {
+			else
 				rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_JOINBSS, 1);
-			}
 #endif
-		}
-		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", ssid->Ssid, (unsigned int)ssid->SsidLength));
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("assoc_ssid=[%s] len=0x%x\n", pmlmepriv->assoc_ssid.Ssid, (unsigned int)pmlmepriv->assoc_ssid.SsidLength));
+		} else {
 
-			rtw_disassoc_cmd(padapter, 0, _TRUE);
+			rtw_disassoc_cmd(padapter, 0, 0);
 
 			if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 				rtw_indicate_disconnect(padapter, 0, _FALSE);
-			
-			rtw_free_assoc_resources(padapter, 1);
+
+			rtw_free_assoc_resources_cmd(padapter, _TRUE);
 
 			if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
 				_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
 				set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
 			}
-		}		
+		}
 	}
 
 handle_tkip_countermeasure:
@@ -503,29 +422,24 @@ handle_tkip_countermeasure:
 	}
 
 	_rtw_memcpy(&pmlmepriv->assoc_ssid, ssid, sizeof(NDIS_802_11_SSID));
-	pmlmepriv->assoc_by_bssid=_FALSE;
+	pmlmepriv->assoc_by_bssid = _FALSE;
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
-		pmlmepriv->to_join = _TRUE;	
-	}
-	else {
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
+		pmlmepriv->to_join = _TRUE;
+	else
 		status = rtw_do_join(padapter);
-	}
 
 release_mlme_lock:
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
 exit:
-	RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-		("-rtw_set_802_11_ssid: status=%d\n", status));
-	
-_func_exit_;
+
 
 	return status;
-	
+
 }
 
-u8 rtw_set_802_11_connect(_adapter* padapter, u8 *bssid, NDIS_802_11_SSID *ssid)
+u8 rtw_set_802_11_connect(_adapter *padapter, u8 *bssid, NDIS_802_11_SSID *ssid)
 {
 	_irqL irqL;
 	u8 status = _SUCCESS;
@@ -534,7 +448,6 @@ u8 rtw_set_802_11_connect(_adapter* padapter, u8 *bssid, NDIS_802_11_SSID *ssid)
 	bool ssid_valid = _TRUE;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-_func_enter_;
 
 	if (!ssid || rtw_validate_ssid(ssid) == _FALSE)
 		ssid_valid = _FALSE;
@@ -543,29 +456,26 @@ _func_enter_;
 		bssid_valid = _FALSE;
 
 	if (ssid_valid == _FALSE && bssid_valid == _FALSE) {
-		DBG_871X(FUNC_ADPT_FMT" ssid:%p, ssid_valid:%d, bssid:%p, bssid_valid:%d\n",
+		RTW_INFO(FUNC_ADPT_FMT" ssid:%p, ssid_valid:%d, bssid:%p, bssid_valid:%d\n",
 			FUNC_ADPT_ARG(padapter), ssid, ssid_valid, bssid, bssid_valid);
 		status = _FAIL;
 		goto exit;
 	}
 
 	if (!rtw_is_hw_init_completed(padapter)) {
-		RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-			 ("set_ssid: hw_init_completed==_FALSE=>exit!!!\n"));
 		status = _FAIL;
 		goto exit;
 	}
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT"  fw_state=0x%08x\n",
-		FUNC_ADPT_ARG(padapter), get_fwstate(pmlmepriv));
+	RTW_PRINT(FUNC_ADPT_FMT"  fw_state=0x%08x\n",
+		  FUNC_ADPT_ARG(padapter), get_fwstate(pmlmepriv));
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
 		goto handle_tkip_countermeasure;
-	} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+	else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
 		goto release_mlme_lock;
-	}
 
 handle_tkip_countermeasure:
 	if (rtw_handle_tkip_countermeasure(padapter, __func__) == _FAIL) {
@@ -581,767 +491,280 @@ handle_tkip_countermeasure:
 	if (bssid && bssid_valid) {
 		_rtw_memcpy(&pmlmepriv->assoc_bssid, bssid, ETH_ALEN);
 		pmlmepriv->assoc_by_bssid = _TRUE;
-	} else {
+	} else
 		pmlmepriv->assoc_by_bssid = _FALSE;
-	}
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
-		pmlmepriv->to_join = _TRUE;	
-	}
-	else {
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
+		pmlmepriv->to_join = _TRUE;
+	else
 		status = rtw_do_join(padapter);
-	}
 
 release_mlme_lock:
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
 exit:
-	
-_func_exit_;
+
 
 	return status;
 }
 
-u8 rtw_set_802_11_infrastructure_mode(_adapter* padapter, 
-	NDIS_802_11_NETWORK_INFRASTRUCTURE networktype)
+u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter,
+			      NDIS_802_11_NETWORK_INFRASTRUCTURE networktype)
 {
 	_irqL irqL;
 	struct	mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct	wlan_network	*cur_network = &pmlmepriv->cur_network;
-	NDIS_802_11_NETWORK_INFRASTRUCTURE* pold_state = &(cur_network->network.InfrastructureMode);
-	
-_func_enter_;
-
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_notice_,
-		 ("+rtw_set_802_11_infrastructure_mode: old=%d new=%d fw_state=0x%08x\n",
-		  *pold_state, networktype, get_fwstate(pmlmepriv)));
-	
-	if(*pold_state != networktype)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,(" change mode!"));
-		//DBG_871X("change mode, old_mode=%d, new_mode=%d, fw_state=0x%x\n", *pold_state, networktype, get_fwstate(pmlmepriv));
+	NDIS_802_11_NETWORK_INFRASTRUCTURE *pold_state = &(cur_network->network.InfrastructureMode);
+	u8 ap2sta_mode = _FALSE;
+	u8 ret = _TRUE;
+
+	if (*pold_state != networktype) {
+		/* RTW_INFO("change mode, old_mode=%d, new_mode=%d, fw_state=0x%x\n", *pold_state, networktype, get_fwstate(pmlmepriv)); */
 
-		if(*pold_state==Ndis802_11APMode)
-		{		
-			//change to other mode from Ndis802_11APMode			
+		if (*pold_state == Ndis802_11APMode
+			|| *pold_state == Ndis802_11_mesh
+		) {
+			/* change to other mode from Ndis802_11APMode/Ndis802_11_mesh */
 			cur_network->join_res = -1;
-			
+			ap2sta_mode = _TRUE;
 #ifdef CONFIG_NATIVEAP_MLME
 			stop_ap_mode(padapter);
 #endif
 		}
 
 		_enter_critical_bh(&pmlmepriv->lock, &irqL);
-		
-		if((check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE) ||(*pold_state==Ndis802_11IBSS))
-			rtw_disassoc_cmd(padapter, 0, _TRUE);
-
-		if((check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE) ||
-			(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)== _TRUE) )
-			rtw_free_assoc_resources(padapter, 1);
-
-		if((*pold_state == Ndis802_11Infrastructure) ||(*pold_state == Ndis802_11IBSS))
-	       {
-			if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
-			{		
+
+		if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) || (*pold_state == Ndis802_11IBSS))
+			rtw_disassoc_cmd(padapter, 0, 0);
+
+		if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
+		    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE))
+			rtw_free_assoc_resources_cmd(padapter, _TRUE);
+
+		if ((*pold_state == Ndis802_11Infrastructure) || (*pold_state == Ndis802_11IBSS)) {
+			if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
 				rtw_indicate_disconnect(padapter, 0, _FALSE); /*will clr Linked_state; before this function, we must have checked whether issue dis-assoc_cmd or not*/
 			}
-	       }
-		
+		}
+
 		*pold_state = networktype;
 
 		_clr_fwstate_(pmlmepriv, ~WIFI_NULL_STATE);
-				
-		switch(networktype)
-		{
-			case Ndis802_11IBSS:
-				set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
-				break;
-				
-			case Ndis802_11Infrastructure:
-				set_fwstate(pmlmepriv, WIFI_STATION_STATE);
-				break;
-				
-			case Ndis802_11APMode:
-				set_fwstate(pmlmepriv, WIFI_AP_STATE);
+
+		switch (networktype) {
+		case Ndis802_11IBSS:
+			set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
+			break;
+
+		case Ndis802_11Infrastructure:
+			set_fwstate(pmlmepriv, WIFI_STATION_STATE);
+
+			if (ap2sta_mode)
+				rtw_init_bcmc_stainfo(padapter);
+			break;
+
+		case Ndis802_11APMode:
+			set_fwstate(pmlmepriv, WIFI_AP_STATE);
 #ifdef CONFIG_NATIVEAP_MLME
-				start_ap_mode(padapter);
-				//rtw_indicate_connect(padapter);
-#endif				
-				
-				break;
-
-			case Ndis802_11AutoUnknown:
-			case Ndis802_11InfrastructureMax:
-				break;
-			case Ndis802_11Monitor:
-				set_fwstate(pmlmepriv, WIFI_MONITOR_STATE);
-				break;
+			start_ap_mode(padapter);
+			/* rtw_indicate_connect(padapter); */
+#endif
+
+			break;
+
+#ifdef CONFIG_RTW_MESH
+		case Ndis802_11_mesh:
+			set_fwstate(pmlmepriv, WIFI_MESH_STATE);
+			start_ap_mode(padapter);
+			break;
+#endif
+
+		case Ndis802_11AutoUnknown:
+		case Ndis802_11InfrastructureMax:
+			break;
+		case Ndis802_11Monitor:
+			set_fwstate(pmlmepriv, WIFI_MONITOR_STATE);
+			break;
+		default:
+			ret = _FALSE;
+			rtw_warn_on(1);
 		}
 
-		//SecClearAllKeys(adapter);
-		
-		//RT_TRACE(COMP_OID_SET, DBG_LOUD, ("set_infrastructure: fw_state:%x after changing mode\n",
-		//									get_fwstate(pmlmepriv) ));
+		/* SecClearAllKeys(adapter); */
+
 
 		_exit_critical_bh(&pmlmepriv->lock, &irqL);
 	}
 
-_func_exit_;
-
-	return _TRUE;
+	return ret;
 }
 
 
 u8 rtw_set_802_11_disassociate(_adapter *padapter)
 {
 	_irqL irqL;
-	struct mlme_priv * pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-_func_enter_;
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("MgntActrtw_set_802_11_disassociate: rtw_indicate_disconnect\n"));
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
 
-		rtw_disassoc_cmd(padapter, 0, _TRUE);
+		rtw_disassoc_cmd(padapter, 0, 0);
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
-		//modify for CONFIG_IEEE80211W, none 11w can use it
-		rtw_free_assoc_resources_cmd(padapter);
+		/* modify for CONFIG_IEEE80211W, none 11w can use it */
+		rtw_free_assoc_resources_cmd(padapter, _TRUE);
 		if (_FAIL == rtw_pwr_wakeup(padapter))
-			DBG_871X("%s(): rtw_pwr_wakeup fail !!!\n",__FUNCTION__);
+			RTW_INFO("%s(): rtw_pwr_wakeup fail !!!\n", __FUNCTION__);
 	}
 
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
-	
-_func_exit_;
 
-	return _TRUE;	
+
+	return _TRUE;
 }
 
-u8 rtw_set_802_11_bssid_list_scan(_adapter* padapter, NDIS_802_11_SSID *pssid, int ssid_max_num)
-{	
+#if 1
+u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, struct sitesurvey_parm *pparm)
+{
 	_irqL	irqL;
-	struct	mlme_priv		*pmlmepriv= &padapter->mlmepriv;
-	u8	res=_TRUE;
-	
-_func_enter_;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8	res = _TRUE;
+
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	res = rtw_sitesurvey_cmd(padapter, pparm);
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+
+	return res;
+}
+
+#else
+u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, struct sitesurvey_parm *pparm)
+{
+	_irqL	irqL;
+	struct	mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	u8	res = _TRUE;
+
 
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("+rtw_set_802_11_bssid_list_scan(), fw_state=%x\n", get_fwstate(pmlmepriv)));
 
 	if (padapter == NULL) {
-		res=_FALSE;
+		res = _FALSE;
 		goto exit;
 	}
 	if (!rtw_is_hw_init_completed(padapter)) {
 		res = _FALSE;
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n===rtw_set_802_11_bssid_list_scan:hw_init_completed==_FALSE===\n"));
 		goto exit;
 	}
-	
-	if ((check_fwstate(pmlmepriv, _FW_UNDER_SURVEY|_FW_UNDER_LINKING) == _TRUE) ||
-		(pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE))
-	{
-		// Scan or linking is in progress, do nothing.
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("rtw_set_802_11_bssid_list_scan fail since fw_state = %x\n", get_fwstate(pmlmepriv)));
+
+	if ((check_fwstate(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) ||
+	    (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE)) {
+		/* Scan or linking is in progress, do nothing. */
 		res = _TRUE;
 
-		if(check_fwstate(pmlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING))== _TRUE){
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n###_FW_UNDER_SURVEY|_FW_UNDER_LINKING\n\n"));
-		} else {
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n###pmlmepriv->sitesurveyctrl.traffic_busy==_TRUE\n\n"));
-		}
-	} else {		
+
+	} else {
 		if (rtw_is_scan_deny(padapter)) {
-			DBG_871X(FUNC_ADPT_FMT": scan deny\n", FUNC_ADPT_ARG(padapter));
+			RTW_INFO(FUNC_ADPT_FMT": scan deny\n", FUNC_ADPT_ARG(padapter));
 			indicate_wx_scan_complete_event(padapter);
 			return _SUCCESS;
 		}
-		
-		_enter_critical_bh(&pmlmepriv->lock, &irqL);		
-		
-		res = rtw_sitesurvey_cmd(padapter, pssid, ssid_max_num, NULL, 0);
-		
+
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+
+		res = rtw_sitesurvey_cmd(padapter, pparm);
+
 		_exit_critical_bh(&pmlmepriv->lock, &irqL);
 	}
 exit:
-	
-_func_exit_;
 
-	return res;	
-}
 
-u8 rtw_set_802_11_authentication_mode(_adapter* padapter, NDIS_802_11_AUTHENTICATION_MODE authmode) 
+	return res;
+}
+#endif
+u8 rtw_set_802_11_authentication_mode(_adapter *padapter, NDIS_802_11_AUTHENTICATION_MODE authmode)
 {
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	int res;
 	u8 ret;
-	
-_func_enter_;
-
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("set_802_11_auth.mode(): mode=%x\n", authmode));
-
-	psecuritypriv->ndisauthtype=authmode;
-	
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("rtw_set_802_11_authentication_mode:psecuritypriv->ndisauthtype=%d", psecuritypriv->ndisauthtype));
-	
-	if(psecuritypriv->ndisauthtype>3)
-		psecuritypriv->dot11AuthAlgrthm=dot11AuthAlgrthm_8021X;
-	
-#ifdef CONFIG_WAPI_SUPPORT
-	if(psecuritypriv->ndisauthtype == 6)
-		psecuritypriv->dot11AuthAlgrthm=dot11AuthAlgrthm_WAPI;
-#endif
 
-	res=rtw_set_auth(padapter,psecuritypriv);
-	
-	if(res==_SUCCESS)
-		ret=_TRUE;
-	else
-		ret=_FALSE;
-	
-_func_exit_;
 
-	return ret;
-}
-
-u8 rtw_set_802_11_add_wep(_adapter* padapter, NDIS_802_11_WEP *wep){
-
-	u8		bdefaultkey;
-	u8		btransmitkey;
-	sint		keyid,res;
-	struct security_priv* psecuritypriv=&(padapter->securitypriv);
-	u8		ret=_SUCCESS;
-
-_func_enter_;
-
-	bdefaultkey=(wep->KeyIndex & 0x40000000) > 0 ? _FALSE : _TRUE;   //for ???
-	btransmitkey= (wep->KeyIndex & 0x80000000) > 0 ? _TRUE  : _FALSE;	//for ???
-	keyid=wep->KeyIndex & 0x3fffffff;
-
-	if(keyid>=4)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("MgntActrtw_set_802_11_add_wep:keyid>4=>fail\n"));
-		ret=_FALSE;
-		goto exit;
-	}
-	
-	switch(wep->KeyLength)
-	{
-		case 5:
-			psecuritypriv->dot11PrivacyAlgrthm=_WEP40_;
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("MgntActrtw_set_802_11_add_wep:wep->KeyLength=5\n"));
-			break;
-		case 13:
-			psecuritypriv->dot11PrivacyAlgrthm=_WEP104_;
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("MgntActrtw_set_802_11_add_wep:wep->KeyLength=13\n"));
-			break;
-		default:
-			psecuritypriv->dot11PrivacyAlgrthm=_NO_PRIVACY_;
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("MgntActrtw_set_802_11_add_wep:wep->KeyLength!=5 or 13\n"));
-			break;
-	}
-	
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("rtw_set_802_11_add_wep:befor memcpy, wep->KeyLength=0x%x wep->KeyIndex=0x%x  keyid =%x\n",wep->KeyLength,wep->KeyIndex,keyid));
 
-	_rtw_memcpy(&(psecuritypriv->dot11DefKey[keyid].skey[0]),&(wep->KeyMaterial),wep->KeyLength);
+	psecuritypriv->ndisauthtype = authmode;
 
-	psecuritypriv->dot11DefKeylen[keyid]=wep->KeyLength;
 
-	psecuritypriv->dot11PrivacyKeyIndex=keyid;
+	if (psecuritypriv->ndisauthtype > 3)
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
 
-	RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("rtw_set_802_11_add_wep:security key material : %x %x %x %x %x %x %x %x %x %x %x %x %x \n",
-		psecuritypriv->dot11DefKey[keyid].skey[0],psecuritypriv->dot11DefKey[keyid].skey[1],psecuritypriv->dot11DefKey[keyid].skey[2],
-		psecuritypriv->dot11DefKey[keyid].skey[3],psecuritypriv->dot11DefKey[keyid].skey[4],psecuritypriv->dot11DefKey[keyid].skey[5],
-		psecuritypriv->dot11DefKey[keyid].skey[6],psecuritypriv->dot11DefKey[keyid].skey[7],psecuritypriv->dot11DefKey[keyid].skey[8],
-		psecuritypriv->dot11DefKey[keyid].skey[9],psecuritypriv->dot11DefKey[keyid].skey[10],psecuritypriv->dot11DefKey[keyid].skey[11],
-		psecuritypriv->dot11DefKey[keyid].skey[12]));
-
-	res=rtw_set_key(padapter,psecuritypriv, keyid, 1, _TRUE);
-	
-	if(res==_FAIL)
-		ret= _FALSE;
-exit:
-	
-_func_exit_;
-
-	return ret;
-	
-}
+#ifdef CONFIG_WAPI_SUPPORT
+	if (psecuritypriv->ndisauthtype == 6)
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+#endif
 
-u8 rtw_set_802_11_remove_wep(_adapter* padapter, u32 keyindex){
-	
-	u8 ret=_SUCCESS;
-	
-_func_enter_;
+	res = rtw_set_auth(padapter, psecuritypriv);
 
-	if (keyindex >= 0x80000000 || padapter == NULL){
-		
-		ret=_FALSE;
-		goto exit;
+	if (res == _SUCCESS)
+		ret = _TRUE;
+	else
+		ret = _FALSE;
 
-	}
-	else 
-	{
-		int res;
-		struct security_priv* psecuritypriv=&(padapter->securitypriv);
-		if( keyindex < 4 ){
-			
-			_rtw_memset(&psecuritypriv->dot11DefKey[keyindex], 0, 16);
-			
-			res=rtw_set_key(padapter,psecuritypriv,keyindex, 0, _TRUE);
-			
-			psecuritypriv->dot11DefKeylen[keyindex]=0;
-			
-			if(res==_FAIL)
-				ret=_FAIL;
-			
-		}
-		else
-		{			
-			ret=_FAIL;
-		}
-		
-	}
-	
-exit:	
-	
-_func_exit_;
 
 	return ret;
-	
 }
 
-u8 rtw_set_802_11_add_key(_adapter* padapter, NDIS_802_11_KEY *key){
-
-	uint	encryptionalgo;
-	u8 * pbssid;
-	struct sta_info *stainfo;
-	u8	bgroup = _FALSE;
-	u8	bgrouptkey = _FALSE;//can be remove later
-	u8	ret=_SUCCESS;
-	
-_func_enter_;
-
-	if (((key->KeyIndex & 0x80000000) == 0) && ((key->KeyIndex & 0x40000000) > 0)){
-
-		// It is invalid to clear bit 31 and set bit 30. If the miniport driver encounters this combination, 
-		// it must fail the request and return NDIS_STATUS_INVALID_DATA.
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("rtw_set_802_11_add_key: ((key->KeyIndex & 0x80000000) == 0)[=%d] ",(int)(key->KeyIndex & 0x80000000) == 0));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("rtw_set_802_11_add_key:((key->KeyIndex & 0x40000000) > 0)[=%d]" , (int)(key->KeyIndex & 0x40000000) > 0));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_info_,("rtw_set_802_11_add_key: key->KeyIndex=%d \n" ,(int)key->KeyIndex));
-		ret= _FAIL;
-		goto exit;
-	}
-
-	if(key->KeyIndex & 0x40000000)
-	{ 
-		// Pairwise key
-
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("OID_802_11_ADD_KEY: +++++ Pairwise key +++++\n"));
-	
-		pbssid=get_bssid(&padapter->mlmepriv);
-		stainfo=rtw_get_stainfo(&padapter->stapriv, pbssid);
-
-		if((stainfo!=NULL)&&(padapter->securitypriv.dot11AuthAlgrthm==dot11AuthAlgrthm_8021X)){
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("OID_802_11_ADD_KEY:( stainfo!=NULL)&&(Adapter->securitypriv.dot11AuthAlgrthm==dot11AuthAlgrthm_8021X)\n"));
-			encryptionalgo=stainfo->dot118021XPrivacy;
-		}
-		else{
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("OID_802_11_ADD_KEY: stainfo==NULL)||(Adapter->securitypriv.dot11AuthAlgrthm!=dot11AuthAlgrthm_8021X)\n"));
-			encryptionalgo=padapter->securitypriv.dot11PrivacyAlgrthm;
-		}
-
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("rtw_set_802_11_add_key: (encryptionalgo ==%d)!\n",encryptionalgo ));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("rtw_set_802_11_add_key: (Adapter->securitypriv.dot11PrivacyAlgrthm ==%d)!\n",padapter->securitypriv.dot11PrivacyAlgrthm));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("rtw_set_802_11_add_key: (Adapter->securitypriv.dot11AuthAlgrthm ==%d)!\n",padapter->securitypriv.dot11AuthAlgrthm));
-
-		if((stainfo!=NULL)){
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("rtw_set_802_11_add_key: (stainfo->dot118021XPrivacy ==%d)!\n", stainfo->dot118021XPrivacy));
-		}
-		
-		if(key->KeyIndex & 0x000000FF){
-			// The key index is specified in the lower 8 bits by values of zero to 255.
-			// The key index should be set to zero for a Pairwise key, and the driver should fail with
-			// NDIS_STATUS_INVALID_DATA if the lower 8 bits is not zero
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,(" key->KeyIndex & 0x000000FF.\n"));
-			ret= _FAIL;
-			goto exit;
-		}
-
-		// check BSSID
-		if (IS_MAC_ADDRESS_BROADCAST(key->BSSID) == _TRUE){
-
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("MacAddr_isBcst(key->BSSID)\n"));
-			ret= _FALSE;
-			goto exit;
-		}
-
-		// Check key length for TKIP.
-		//if(encryptionAlgorithm == RT_ENC_TKIP_ENCRYPTION && key->KeyLength != 32)
-		if((encryptionalgo== _TKIP_)&& (key->KeyLength != 32)){
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("TKIP KeyLength:0x%x != 32\n", key->KeyLength));
-			ret=_FAIL;
-			goto exit;
-
-		}
-
-		// Check key length for AES.
-		if((encryptionalgo== _AES_)&& (key->KeyLength != 16)) {
-			// For our supplicant, EAPPkt9x.vxd, cannot differentiate TKIP and AES case.
-			if(key->KeyLength == 32) {
-				key->KeyLength = 16; 
-			} else {
-				ret= _FAIL;
-				goto exit;
-			}
-		}
-
-		/* Check key length for WEP. For NDTEST, 2005.01.27, by rcnjko. -> modify checking condition*/
-		if (((encryptionalgo == _WEP40_) && (key->KeyLength != 5)) || ((encryptionalgo == _WEP104_) && (key->KeyLength != 13))) {
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("WEP KeyLength:0x%x != 5 or 13\n", key->KeyLength));
-			ret=_FAIL;
-			goto exit;
-		}
-
-		bgroup = _FALSE;
-
-		// Check the pairwise key. Added by Annie, 2005-07-06.
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("------------------------------------------\n"));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("[Pairwise Key set]\n"));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("------------------------------------------\n"));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("key index: 0x%8x(0x%8x)\n", key->KeyIndex,(key->KeyIndex&0x3)));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("key Length: %d\n", key->KeyLength));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("------------------------------------------\n"));
-	
-	}
-	else 
-	{	
-		// Group key - KeyIndex(BIT30==0)
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("OID_802_11_ADD_KEY: +++++ Group key +++++\n"));
-
-
-		// when add wep key through add key and didn't assigned encryption type before
-		if((padapter->securitypriv.ndisauthtype<=3)&&(padapter->securitypriv.dot118021XGrpPrivacy==0))
-		{
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("keylen=%d( Adapter->securitypriv.dot11PrivacyAlgrthm=%x  )padapter->securitypriv.dot118021XGrpPrivacy(%x)\n", key->KeyLength,padapter->securitypriv.dot11PrivacyAlgrthm,padapter->securitypriv.dot118021XGrpPrivacy));
-
-			switch(key->KeyLength)
-			{
-				case 5:
-					padapter->securitypriv.dot11PrivacyAlgrthm=_WEP40_;
-					RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("Adapter->securitypriv.dot11PrivacyAlgrthm= %x key->KeyLength=%u\n", padapter->securitypriv.dot11PrivacyAlgrthm,key->KeyLength));
-					break;
-				case 13:
-					padapter->securitypriv.dot11PrivacyAlgrthm=_WEP104_;
-					RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("Adapter->securitypriv.dot11PrivacyAlgrthm= %x key->KeyLength=%u\n", padapter->securitypriv.dot11PrivacyAlgrthm,key->KeyLength));
-					break;
-				default:
-					padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;
-					RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("Adapter->securitypriv.dot11PrivacyAlgrthm= %x key->KeyLength=%u \n", padapter->securitypriv.dot11PrivacyAlgrthm,key->KeyLength));
-					break;
-			}
-			
-			encryptionalgo=padapter->securitypriv.dot11PrivacyAlgrthm;
-			
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,(" Adapter->securitypriv.dot11PrivacyAlgrthm=%x\n", padapter->securitypriv.dot11PrivacyAlgrthm));
-			
-		}
-		else 
-		{
-			encryptionalgo=padapter->securitypriv.dot118021XGrpPrivacy;
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("( Adapter->securitypriv.dot11PrivacyAlgrthm=%x  )encryptionalgo(%x)=padapter->securitypriv.dot118021XGrpPrivacy(%x)keylen=%d\n", padapter->securitypriv.dot11PrivacyAlgrthm,encryptionalgo,padapter->securitypriv.dot118021XGrpPrivacy,key->KeyLength));
-
-		}
-		
-		if((check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE)==_TRUE) && (IS_MAC_ADDRESS_BROADCAST(key->BSSID) == _FALSE)) {
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,(" IBSS but BSSID is not Broadcast Address.\n"));
-			ret= _FAIL;
-			goto exit;
-		}
-
-		// Check key length for TKIP
-		if((encryptionalgo== _TKIP_) && (key->KeyLength != 32)) {
-
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,(" TKIP GTK KeyLength:%u != 32\n", key->KeyLength));
-			ret= _FAIL;
-			goto exit;
-
-		} else if(encryptionalgo== _AES_ && (key->KeyLength != 16 && key->KeyLength != 32) ) {
-			
-			// Check key length for AES
-			// For NDTEST, we allow keylen=32 in this case. 2005.01.27, by rcnjko.
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("<=== SetInfo, OID_802_11_ADD_KEY: AES GTK KeyLength:%u != 16 or 32\n", key->KeyLength));
-			ret= _FAIL;
-			goto exit;
-		}
-
-		// Change the key length for EAPPkt9x.vxd. Added by Annie, 2005-11-03.
-		if((encryptionalgo==  _AES_) && (key->KeyLength == 32) ) {
-			key->KeyLength = 16; 
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("AES key length changed: %u\n", key->KeyLength) );
-		}
-
-		if(key->KeyIndex & 0x8000000) {//error ??? 0x8000_0000
-			bgrouptkey = _TRUE;
-		}
+u8 rtw_set_802_11_add_wep(_adapter *padapter, NDIS_802_11_WEP *wep)
+{
 
-		if((check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE)==_TRUE)&&(check_fwstate(&padapter->mlmepriv, _FW_LINKED)==_TRUE))
-		{
-			bgrouptkey = _TRUE;
-		}
+	u8		bdefaultkey;
+	u8		btransmitkey;
+	sint		keyid, res;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	u8		ret = _SUCCESS;
 
-		bgroup = _TRUE;
 
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("------------------------------------------\n") );
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("[Group Key set]\n") );
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("------------------------------------------\n")) ;
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("key index: 0x%8x(0x%8x)\n", key->KeyIndex,(key->KeyIndex&0x3)));
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("key Length: %d\n", key->KeyLength)) ;
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("------------------------------------------\n"));
-		
-	}	
+	bdefaultkey = (wep->KeyIndex & 0x40000000) > 0 ? _FALSE : _TRUE; /* for ??? */
+	btransmitkey = (wep->KeyIndex & 0x80000000) > 0 ? _TRUE  : _FALSE;	/* for ??? */
+	keyid = wep->KeyIndex & 0x3fffffff;
 
-	// If WEP encryption algorithm, just call rtw_set_802_11_add_wep().
-	if((padapter->securitypriv.dot11AuthAlgrthm !=dot11AuthAlgrthm_8021X)&&(encryptionalgo== _WEP40_  || encryptionalgo== _WEP104_))
-	{
-		u8 ret;		
-		u32 keyindex;		
-		u32 len = FIELD_OFFSET(NDIS_802_11_KEY, KeyMaterial) + key->KeyLength;
-		NDIS_802_11_WEP *wep = &padapter->securitypriv.ndiswep;
-				
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("OID_802_11_ADD_KEY: +++++ WEP key +++++\n"));
-
-		wep->Length = len;
-		keyindex = key->KeyIndex&0x7fffffff;
-		wep->KeyIndex = keyindex ;
-		wep->KeyLength = key->KeyLength;
-		
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("OID_802_11_ADD_KEY:Before memcpy \n"));
-
-		_rtw_memcpy(wep->KeyMaterial, key->KeyMaterial, key->KeyLength);	
-		_rtw_memcpy(&(padapter->securitypriv.dot11DefKey[keyindex].skey[0]), key->KeyMaterial, key->KeyLength);
-
-		padapter->securitypriv.dot11DefKeylen[keyindex]=key->KeyLength;		
-		padapter->securitypriv.dot11PrivacyKeyIndex=keyindex;
-		
-		ret = rtw_set_802_11_add_wep(padapter, wep);
-	
+	if (keyid >= 4) {
+		ret = _FALSE;
 		goto exit;
-		
 	}
 
-	if(key->KeyIndex & 0x20000000){
-		// SetRSC
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("OID_802_11_ADD_KEY: +++++ SetRSC+++++\n"));
-		if(bgroup == _TRUE)
-		{
-			NDIS_802_11_KEY_RSC keysrc=key->KeyRSC & 0x00FFFFFFFFFFFFULL;
-			_rtw_memcpy(&padapter->securitypriv.dot11Grprxpn, &keysrc, 8);			
-		} 
-		else 
-		{		
-			NDIS_802_11_KEY_RSC keysrc=key->KeyRSC & 0x00FFFFFFFFFFFFULL;	
-			_rtw_memcpy(&padapter->securitypriv.dot11Grptxpn, &keysrc, 8);			
-		}
-			
+	switch (wep->KeyLength) {
+	case 5:
+		psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+		break;
+	case 13:
+		psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+		break;
+	default:
+		psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		break;
 	}
 
-	// Indicate this key idx is used for TX
-	// Save the key in KeyMaterial
-	if(bgroup == _TRUE) // Group transmit key
-	{
-		int res;
-		
-		if(bgrouptkey == _TRUE)
-		{		
-			padapter->securitypriv.dot118021XGrpKeyid=(u8)key->KeyIndex;
-		}
-		
-		if((key->KeyIndex&0x3) == 0){
-			ret = _FAIL;
-			goto exit;
-		}		
-		
-		_rtw_memset(&padapter->securitypriv.dot118021XGrpKey[(u8)((key->KeyIndex) & 0x03)], 0, 16);
-		_rtw_memset(&padapter->securitypriv.dot118021XGrptxmickey[(u8)((key->KeyIndex) & 0x03)], 0, 16);
-		_rtw_memset(&padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)], 0, 16);
-		
-		if((key->KeyIndex & 0x10000000))
-		{
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrptxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 16, 8);
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 24, 8);
-			
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n rtw_set_802_11_add_key:rx mic :0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x\n",
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[0],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[1],
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[2],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[3],
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[4],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[5],
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[6],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[7]));
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n rtw_set_802_11_add_key:set Group mic key!!!!!!!!\n"));
-
-		}
-		else
-		{
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrptxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 24, 8);
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 16, 8);
-			
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n rtw_set_802_11_add_key:rx mic :0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x\n",
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[0],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[1],
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[2],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[3],
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[4],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[5],
-				padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)].skey[6],padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex-1) & 0x03)].skey[7]));
-			RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n rtw_set_802_11_add_key:set Group mic key!!!!!!!!\n"));
-		
-		}
-
-		//set group key by index
-		_rtw_memcpy(&padapter->securitypriv.dot118021XGrpKey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial, key->KeyLength);
-		
-		key->KeyIndex=key->KeyIndex & 0x03;
-		
-		padapter->securitypriv.binstallGrpkey=_TRUE;
-		
-		padapter->securitypriv.bcheck_grpkey=_FALSE;
-		
-		RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("reset group key"));
-		
-		res=rtw_set_key(padapter,&padapter->securitypriv, key->KeyIndex, 1, _TRUE);
-
-		if(res==_FAIL)
-			ret= _FAIL;
 
-		goto exit;
-			
-	}
-	else // Pairwise Key
-	{
-		u8 res;
-		
-		pbssid=get_bssid(&padapter->mlmepriv);
-		stainfo=rtw_get_stainfo(&padapter->stapriv , pbssid );
-		
-		if(stainfo!=NULL)
-		{			
-			_rtw_memset( &stainfo->dot118021x_UncstKey, 0, 16);// clear keybuffer
-			
-			_rtw_memcpy(&stainfo->dot118021x_UncstKey, key->KeyMaterial, 16);
-			
-			if(encryptionalgo== _TKIP_)
-			{
-				padapter->securitypriv.busetkipkey=_FALSE;
-				
-				//_set_timer(&padapter->securitypriv.tkip_timer, 50);
-				
-				RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n ==========_set_timer\n"));
-				
-				// if TKIP, save the Receive/Transmit MIC key in KeyMaterial[128-255]
-				if((key->KeyIndex & 0x10000000)){
-					_rtw_memcpy(&stainfo->dot11tkiptxmickey, key->KeyMaterial + 16, 8);
-					_rtw_memcpy(&stainfo->dot11tkiprxmickey, key->KeyMaterial + 24, 8);
+	_rtw_memcpy(&(psecuritypriv->dot11DefKey[keyid].skey[0]), &(wep->KeyMaterial), wep->KeyLength);
 
-				} else {
-					_rtw_memcpy(&stainfo->dot11tkiptxmickey, key->KeyMaterial + 24, 8);
-					_rtw_memcpy(&stainfo->dot11tkiprxmickey, key->KeyMaterial + 16, 8);
+	psecuritypriv->dot11DefKeylen[keyid] = wep->KeyLength;
 
-				}
-		
-			}
-			else if(encryptionalgo == _AES_)
-			{		
-	
-			}
+	psecuritypriv->dot11PrivacyKeyIndex = keyid;
 
-		
-			//Set key to CAM through H2C command
-			#if 0
-			if(bgrouptkey)//never go to here
-			{
-				res=rtw_setstakey_cmd(padapter, stainfo, GROUP_KEY, _TRUE);
-				RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n rtw_set_802_11_add_key:rtw_setstakey_cmd(group)\n"));
-			}
-			else{
-				res=rtw_setstakey_cmd(padapter, stainfo, UNICAST_KEY, _TRUE);
-				RT_TRACE(_module_rtl871x_ioctl_set_c_,_drv_err_,("\n rtw_set_802_11_add_key:rtw_setstakey_cmd(unicast)\n"));
-			}
-			#else
-			
-			res = rtw_setstakey_cmd(padapter, stainfo, UNICAST_KEY, _TRUE);
-			RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_, ("\n rtw_set_802_11_add_key:rtw_setstakey_cmd(unicast)\n"));
-			#endif
-
-			if(res ==_FALSE)
-				ret= _FAIL;
-			
-		}
 
-	}
+	res = rtw_set_key(padapter, psecuritypriv, keyid, 1, _TRUE);
 
+	if (res == _FAIL)
+		ret = _FALSE;
 exit:
-	
-_func_exit_;
-
-	return ret;	
-}
-
-u8 rtw_set_802_11_remove_key(_adapter*	padapter, NDIS_802_11_REMOVE_KEY *key){
-	
-	uint				encryptionalgo;
-	u8 * pbssid;
-	struct sta_info *stainfo;
-	u8	bgroup = (key->KeyIndex & 0x4000000) > 0 ? _FALSE: _TRUE;
-	u8	keyIndex = (u8)key->KeyIndex & 0x03;
-	u8	ret=_SUCCESS;
-	
-_func_enter_;
-
-	if ((key->KeyIndex & 0xbffffffc) > 0) {
-		ret=_FAIL;
-		goto exit;
-	}
 
-	if (bgroup == _TRUE) {
-		encryptionalgo= padapter->securitypriv.dot118021XGrpPrivacy;
-		// clear group key by index
-		//NdisZeroMemory(Adapter->MgntInfo.SecurityInfo.KeyBuf[keyIndex], MAX_WEP_KEY_LEN);
-		//Adapter->MgntInfo.SecurityInfo.KeyLen[keyIndex] = 0;
-		
-		_rtw_memset(&padapter->securitypriv.dot118021XGrpKey[keyIndex], 0, 16);
-		
-		//! \todo Send a H2C Command to Firmware for removing this Key in CAM Entry.
-	
-	} else {
-	
-		pbssid=get_bssid(&padapter->mlmepriv);
-		stainfo=rtw_get_stainfo(&padapter->stapriv , pbssid );
-		if(stainfo !=NULL){
-			encryptionalgo=stainfo->dot118021XPrivacy;
-
-		// clear key by BSSID
-		_rtw_memset(&stainfo->dot118021x_UncstKey, 0, 16);
-		
-		//! \todo Send a H2C Command to Firmware for disable this Key in CAM Entry.
 
-		}
-		else{
-			ret= _FAIL;
-			goto exit;
-		}
-	}
-
-exit:
-	
-_func_exit_;
+	return ret;
 
-	return _TRUE;
-	
 }
 
 /*
-* rtw_get_cur_max_rate - 
+* rtw_get_cur_max_rate -
 * @adapter: pointer to _adapter structure
-* 
+*
 * Return 0 or 100Kbps
 */
 u16 rtw_get_cur_max_rate(_adapter *adapter)
@@ -1351,84 +774,79 @@ u16 rtw_get_cur_max_rate(_adapter *adapter)
 	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 	WLAN_BSSID_EX	*pcur_bss = &pmlmepriv->cur_network.network;
 	struct sta_info *psta = NULL;
-	u8	short_GI=0;
+	u8	short_GI = 0;
 #ifdef CONFIG_80211N_HT
 	u8	rf_type = 0;
 #endif
 
 #ifdef CONFIG_MP_INCLUDED
-	if (adapter->registrypriv.mp_mode == 1)
-	{	
+	if (adapter->registrypriv.mp_mode == 1) {
 		if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
 			return 0;
 	}
 #endif
 
-	if((check_fwstate(pmlmepriv, _FW_LINKED) != _TRUE) 
-		&& (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) != _TRUE))
+	if ((check_fwstate(pmlmepriv, _FW_LINKED) != _TRUE)
+	    && (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) != _TRUE))
 		return 0;
 
 	psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
 	if (psta == NULL)
 		return 0;
 
-	short_GI = query_ra_short_GI(psta, psta->bw_mode);
+	short_GI = query_ra_short_GI(psta, rtw_get_tx_bw_mode(adapter, psta));
 
 #ifdef CONFIG_80211N_HT
-	if (IsSupportedHT(psta->wireless_mode)) {
+	if (is_supported_ht(psta->wireless_mode)) {
 		rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-
-		max_rate = rtw_mcs_rate(
-			rf_type,
-			((psta->bw_mode == CHANNEL_WIDTH_40)?1:0),
-			short_GI,
-			psta->htpriv.ht_cap.supp_mcs_set
+		max_rate = rtw_mcs_rate(rf_type
+			, (psta->cmn.bw_mode == CHANNEL_WIDTH_40) ? 1 : 0
+			, short_GI
+			, psta->htpriv.ht_cap.supp_mcs_set
 		);
 	}
 #ifdef CONFIG_80211AC_VHT
-	else if (IsSupportedVHT(psta->wireless_mode)) {
-		max_rate = ((rtw_vht_mcs_to_data_rate(psta->bw_mode, short_GI, pmlmepriv->vhtpriv.vht_highest_rate) + 1) >> 1) * 10;
-	}
-#endif //CONFIG_80211AC_VHT
-	else 
-#endif //CONFIG_80211N_HT
+	else if (is_supported_vht(psta->wireless_mode))
+		max_rate = ((rtw_vht_mcs_to_data_rate(psta->cmn.bw_mode, short_GI, pmlmepriv->vhtpriv.vht_highest_rate) + 1) >> 1) * 10;
+#endif /* CONFIG_80211AC_VHT */
+	else
+#endif /* CONFIG_80211N_HT */
 	{
-		while( (pcur_bss->SupportedRates[i]!=0) && (pcur_bss->SupportedRates[i]!=0xFF))
-		{
-			rate = pcur_bss->SupportedRates[i]&0x7F;
-			if(rate>max_rate)
+		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;
+
+		max_rate = max_rate * 10 / 2;
 	}
 
 	return max_rate;
 }
 
 /*
-* rtw_set_scan_mode - 
+* rtw_set_scan_mode -
 * @adapter: pointer to _adapter structure
-* @scan_mode: 
-* 
+* @scan_mode:
+*
 * Return _SUCCESS or _FAIL
 */
 int rtw_set_scan_mode(_adapter *adapter, RT_SCAN_TYPE scan_mode)
 {
-	if(scan_mode != SCAN_ACTIVE && scan_mode != SCAN_PASSIVE)
+	if (scan_mode != SCAN_ACTIVE && scan_mode != SCAN_PASSIVE)
 		return _FAIL;
-	
+
 	adapter->mlmepriv.scan_mode = scan_mode;
 
 	return _SUCCESS;
 }
 
 /*
-* rtw_set_channel_plan - 
+* rtw_set_channel_plan -
 * @adapter: pointer to _adapter structure
-* @channel_plan: 
-* 
+* @channel_plan:
+*
 * Return _SUCCESS or _FAIL
 */
 int rtw_set_channel_plan(_adapter *adapter, u8 channel_plan)
@@ -1436,15 +854,15 @@ int rtw_set_channel_plan(_adapter *adapter, u8 channel_plan)
 	struct registry_priv *pregistrypriv = &adapter->registrypriv;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 
-	//handle by cmd_thread to sync with scan operation
+	/* handle by cmd_thread to sync with scan operation */
 	return rtw_set_chplan_cmd(adapter, RTW_CMDF_WAIT_ACK, channel_plan, 1);
 }
 
 /*
-* rtw_set_country - 
+* rtw_set_country -
 * @adapter: pointer to _adapter structure
 * @country_code: string of country code
-* 
+*
 * Return _SUCCESS or _FAIL
 */
 int rtw_set_country(_adapter *adapter, const char *country_code)
@@ -1452,26 +870,26 @@ int rtw_set_country(_adapter *adapter, const char *country_code)
 #ifdef CONFIG_RTW_IOCTL_SET_COUNTRY
 	return rtw_set_country_cmd(adapter, RTW_CMDF_WAIT_ACK, country_code, 1);
 #else
-	return _FAIL;
+	RTW_INFO("%s(): not applied\n", __func__);
+	return _SUCCESS;
 #endif
 }
 
 /*
-* rtw_set_band - 
+* rtw_set_band -
 * @adapter: pointer to _adapter structure
 * @band: band to set
-* 
+*
 * Return _SUCCESS or _FAIL
 */
 int rtw_set_band(_adapter *adapter, u8 band)
 {
 	if (rtw_band_valid(band)) {
-		DBG_871X(FUNC_ADPT_FMT" band:%d\n", FUNC_ADPT_ARG(adapter), band);
+		RTW_INFO(FUNC_ADPT_FMT" band:%d\n", FUNC_ADPT_ARG(adapter), band);
 		adapter->setband = band;
 		return _SUCCESS;
 	}
 
-	DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" band:%d fail\n", FUNC_ADPT_ARG(adapter), band);
+	RTW_PRINT(FUNC_ADPT_FMT" band:%d fail\n", FUNC_ADPT_ARG(adapter), band);
 	return _FAIL;
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_iol.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_iol.c
index 3524e1c5a5ed..26180b71f5fb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_iol.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_iol.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #include <drv_types.h>
 
@@ -29,20 +25,20 @@ struct xmit_frame	*rtw_IOL_accquire_xmit_frame(ADAPTER *adapter)
 	struct xmit_priv	*pxmitpriv = &(adapter->xmitpriv);
 
 #if 1
-	if ((xmit_frame = rtw_alloc_xmitframe(pxmitpriv)) == NULL)
-	{
-		DBG_871X("%s rtw_alloc_xmitframe return null\n", __FUNCTION__);
+	xmit_frame = rtw_alloc_xmitframe(pxmitpriv);
+	if (xmit_frame == NULL) {
+		RTW_INFO("%s rtw_alloc_xmitframe return null\n", __FUNCTION__);
 		goto exit;
 	}
-	
-	if ((xmitbuf = rtw_alloc_xmitbuf(pxmitpriv)) == NULL)
-	{
-		DBG_871X("%s rtw_alloc_xmitbuf return null\n", __FUNCTION__);
+
+	xmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
+	if (xmitbuf == NULL) {
+		RTW_INFO("%s rtw_alloc_xmitbuf return null\n", __FUNCTION__);
 		rtw_free_xmitframe(pxmitpriv, xmit_frame);
-		xmit_frame=NULL;
+		xmit_frame = NULL;
 		goto exit;
 	}
-	
+
 	xmit_frame->frame_tag = MGNT_FRAMETAG;
 	xmit_frame->pxmitbuf = xmitbuf;
 	xmit_frame->buf_addr = xmitbuf->pbuf;
@@ -50,15 +46,14 @@ struct xmit_frame	*rtw_IOL_accquire_xmit_frame(ADAPTER *adapter)
 
 	pattrib = &xmit_frame->attrib;
 	update_mgntframe_attrib(adapter, pattrib);
-	pattrib->qsel = QSLT_BEACON;//Beacon	
-	pattrib->subtype = WIFI_BEACON;	
+	pattrib->qsel = QSLT_BEACON;/* Beacon	 */
+	pattrib->subtype = WIFI_BEACON;
 	pattrib->pktlen = pattrib->last_txcmdsz = 0;
 
 #else
-	if ((xmit_frame = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		DBG_871X("%s alloc_mgtxmitframe return null\n", __FUNCTION__);
-	}
+	xmit_frame = alloc_mgtxmitframe(pxmitpriv);
+	if (xmit_frame == NULL)
+		RTW_INFO("%s alloc_mgtxmitframe return null\n", __FUNCTION__);
 	else {
 		pattrib = &xmit_frame->attrib;
 		update_mgntframe_attrib(adapter, pattrib);
@@ -79,12 +74,12 @@ int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len
 	u32 ori_len;
 
 	buf_offset = TXDESC_OFFSET;
-	ori_len = buf_offset+pattrib->pktlen;
+	ori_len = buf_offset + pattrib->pktlen;
 
-	//check if the io_buf can accommodate new cmds
-	if(ori_len + cmd_len + 8 > MAX_XMITBUF_SZ) {
-		DBG_871X("%s %u is large than MAX_XMITBUF_SZ:%u, can't accommodate new cmds\n", __FUNCTION__
-			, ori_len + cmd_len + 8, MAX_XMITBUF_SZ);
+	/* check if the io_buf can accommodate new cmds */
+	if (ori_len + cmd_len + 8 > MAX_XMITBUF_SZ) {
+		RTW_INFO("%s %u is large than MAX_XMITBUF_SZ:%u, can't accommodate new cmds\n", __FUNCTION__
+			 , ori_len + cmd_len + 8, MAX_XMITBUF_SZ);
 		return _FAIL;
 	}
 
@@ -92,18 +87,18 @@ int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len
 	pattrib->pktlen += cmd_len;
 	pattrib->last_txcmdsz += cmd_len;
 
-	//DBG_871X("%s ori:%u + cmd_len:%u = %u\n", __FUNCTION__, ori_len, cmd_len, buf_offset+pattrib->pktlen);
-	
+	/* RTW_INFO("%s ori:%u + cmd_len:%u = %u\n", __FUNCTION__, ori_len, cmd_len, buf_offset+pattrib->pktlen); */
+
 	return _SUCCESS;
 }
 
 bool rtw_IOL_applied(ADAPTER *adapter)
-{	
-	if(1 == adapter->registrypriv.fw_iol)
+{
+	if (1 == adapter->registrypriv.fw_iol)
 		return _TRUE;
 
 #ifdef CONFIG_USB_HCI
-	if((2 == adapter->registrypriv.fw_iol) && (IS_FULL_SPEED_USB(adapter)))
+	if ((2 == adapter->registrypriv.fw_iol) && (IS_FULL_SPEED_USB(adapter)))
 		return _TRUE;
 #endif
 
@@ -112,7 +107,7 @@ bool rtw_IOL_applied(ADAPTER *adapter)
 
 int rtw_IOL_exec_cmds_sync(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt)
 {
-	return rtw_hal_iol_cmd(adapter, xmit_frame, max_wating_ms,bndy_cnt);
+	return rtw_hal_iol_cmd(adapter, xmit_frame, max_wating_ms, bndy_cnt);
 }
 
 #ifdef CONFIG_IOL_NEW_GENERATION
@@ -122,195 +117,193 @@ int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary)
 }
 int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, u8 mask)
 {
-	struct ioreg_cfg cmd = {8,IOREG_CMD_WB_REG,0x0, 0x0,0x0};
+	struct ioreg_cfg cmd = {8, IOREG_CMD_WB_REG, 0x0, 0x0, 0x0};
 
-	//RTW_PUT_LE16((u8*)&cmd.address, addr);	
-	//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	
-	cmd.address = cpu_to_le16(addr);	
+	/* RTW_PUT_LE16((u8*)&cmd.address, addr);	 */
+	/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	 */
+	cmd.address = cpu_to_le16(addr);
 	cmd.data = cpu_to_le32(value);
-	
-	if(mask!=0xFF)
-	{
+
+	if (mask != 0xFF) {
 		cmd.length = 12;
-		//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	
+		/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	 */
 		cmd.mask = cpu_to_le32(mask);
-	}	
-		
-	//DBG_871X("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask);
+	}
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
+	/* RTW_INFO("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask); */
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
 
 }
 int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, u16 mask)
 {
-	struct ioreg_cfg cmd = {8,IOREG_CMD_WW_REG,0x0, 0x0,0x0};
+	struct ioreg_cfg cmd = {8, IOREG_CMD_WW_REG, 0x0, 0x0, 0x0};
 
-	//RTW_PUT_LE16((u8*)&cmd.address, addr);	
-	//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	
-	cmd.address = cpu_to_le16(addr);	
+	/* RTW_PUT_LE16((u8*)&cmd.address, addr);	 */
+	/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	 */
+	cmd.address = cpu_to_le16(addr);
 	cmd.data = cpu_to_le32(value);
-	
-	if(mask!=0xFFFF)
-	{
+
+	if (mask != 0xFFFF) {
 		cmd.length = 12;
-		//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	
+		/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	 */
 		cmd.mask =  cpu_to_le32(mask);
-	}	
-		
-	//DBG_871X("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask);
+	}
+
+	/* RTW_INFO("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask); */
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
-	
 }
 int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, u32 mask)
 {
-	struct ioreg_cfg cmd = {8,IOREG_CMD_WD_REG,0x0, 0x0,0x0};
+	struct ioreg_cfg cmd = {8, IOREG_CMD_WD_REG, 0x0, 0x0, 0x0};
 
-	//RTW_PUT_LE16((u8*)&cmd.address, addr);	
-	//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	
-	cmd.address = cpu_to_le16(addr);	
+	/* RTW_PUT_LE16((u8*)&cmd.address, addr);	 */
+	/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	 */
+	cmd.address = cpu_to_le16(addr);
 	cmd.data = cpu_to_le32(value);
-	
-	if(mask!=0xFFFFFFFF)
-	{
+
+	if (mask != 0xFFFFFFFF) {
 		cmd.length = 12;
-		//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	
+		/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	 */
 		cmd.mask =  cpu_to_le32(mask);
-	}	
-		
-	//DBG_871X("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__, addr,value,mask);
+	}
+
+	/* RTW_INFO("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__, addr,value,mask); */
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
-	
 }
 
 int _rtw_IOL_append_WRF_cmd(struct xmit_frame *xmit_frame, u8 rf_path, u16 addr, u32 value, u32 mask)
 {
-	struct ioreg_cfg cmd = {8,IOREG_CMD_W_RF,0x0, 0x0,0x0};
+	struct ioreg_cfg cmd = {8, IOREG_CMD_W_RF, 0x0, 0x0, 0x0};
 
-	//RTW_PUT_LE16((u8*)&cmd.address, addr);	
-	//RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	
-	cmd.address = (rf_path<<8) |((addr) &0xFF);	
+	/* RTW_PUT_LE16((u8*)&cmd.address, addr);	 */
+	/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value);	 */
+	cmd.address = (rf_path << 8) | ((addr) & 0xFF);
 	cmd.data = cpu_to_le32(value);
-	
-	if(mask!=0x000FFFFF)
-	{
+
+	if (mask != 0x000FFFFF) {
 		cmd.length = 12;
-		//RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	
+		/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask);	 */
 		cmd.mask =  cpu_to_le32(mask);
-	}	
-		
-	//DBG_871X("%s rf_path:0x%02x addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__,rf_path, addr,value,mask);
+	}
+
+	/* RTW_INFO("%s rf_path:0x%02x addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__,rf_path, addr,value,mask); */
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, cmd.length);
-	
 }
 
 
 
 int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us)
 {
-	struct ioreg_cfg cmd = {4,IOREG_CMD_DELAY_US,0x0, 0x0,0x0};
-	//RTW_PUT_LE16((u8*)&cmd.address, us);	
-	cmd.address = cpu_to_le16(us);	
+	struct ioreg_cfg cmd = {4, IOREG_CMD_DELAY_US, 0x0, 0x0, 0x0};
+	/* RTW_PUT_LE16((u8*)&cmd.address, us);	 */
+	cmd.address = cpu_to_le16(us);
 
-	//DBG_871X("%s %u\n", __FUNCTION__, us);
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 4);
+	/* RTW_INFO("%s %u\n", __FUNCTION__, us); */
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 4);
 }
 
 int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms)
 {
-	struct ioreg_cfg cmd = {4,IOREG_CMD_DELAY_US,0x0, 0x0,0x0};
+	struct ioreg_cfg cmd = {4, IOREG_CMD_DELAY_US, 0x0, 0x0, 0x0};
 
-	//RTW_PUT_LE16((u8*)&cmd.address, ms);	
-	cmd.address = cpu_to_le16(ms);	
+	/* RTW_PUT_LE16((u8*)&cmd.address, ms);	 */
+	cmd.address = cpu_to_le16(ms);
 
-	//DBG_871X("%s %u\n", __FUNCTION__, ms);
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 4);
+	/* RTW_INFO("%s %u\n", __FUNCTION__, ms); */
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 4);
 }
 int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame)
-{	
-	struct ioreg_cfg cmd = {4,IOREG_CMD_END,0xFFFF, 0xFF,0x0};
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 4);
+{
+	struct ioreg_cfg cmd = {4, IOREG_CMD_END, 0xFFFF, 0xFF, 0x0};
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 4);
 
 }
 
 u8 rtw_IOL_cmd_boundary_handle(struct xmit_frame *pxmit_frame)
-{	
+{
 	u8 is_cmd_bndy = _FALSE;
-	if(((pxmit_frame->attrib.pktlen+32)%256) + 8 >= 256){
+	if (((pxmit_frame->attrib.pktlen + 32) % 256) + 8 >= 256) {
 		rtw_IOL_append_END_cmd(pxmit_frame);
-		pxmit_frame->attrib.pktlen = ((((pxmit_frame->attrib.pktlen+32)/256)+1)*256 );
-		
-		//printk("==> %s, pktlen(%d)\n",__FUNCTION__,pxmit_frame->attrib.pktlen);
+		pxmit_frame->attrib.pktlen = ((((pxmit_frame->attrib.pktlen + 32) / 256) + 1) * 256);
+
+		/* printk("==> %s, pktlen(%d)\n",__FUNCTION__,pxmit_frame->attrib.pktlen); */
 		pxmit_frame->attrib.last_txcmdsz = pxmit_frame->attrib.pktlen;
-		is_cmd_bndy = _TRUE;	
+		is_cmd_bndy = _TRUE;
 	}
 	return is_cmd_bndy;
 }
 
-void rtw_IOL_cmd_buf_dump(ADAPTER *Adapter,int buf_len,u8 *pbuf)
+void rtw_IOL_cmd_buf_dump(ADAPTER *Adapter, int buf_len, u8 *pbuf)
 {
 	int i;
-	int j=1;
-	
-	printk("###### %s ######\n",__FUNCTION__);
-	for(i=0;i< buf_len;i++){
-		printk("%02x-",*(pbuf+i));
-			
-		if(j%32 ==0) printk("\n");j++;				
+	int j = 1;
+
+	printk("###### %s ######\n", __FUNCTION__);
+	for (i = 0; i < buf_len; i++) {
+		printk("%02x-", *(pbuf + i));
+
+		if (j % 32 == 0)
+			printk("\n");
+		j++;
 	}
 	printk("\n");
-	printk("============= ioreg_cmd len = %d =============== \n",buf_len);	
+	printk("============= ioreg_cmd len = %d ===============\n", buf_len);
 }
 
 
-#else //CONFIG_IOL_NEW_GENERATION
+#else /* CONFIG_IOL_NEW_GENERATION */
 int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary)
-{	
+{
 	IOL_CMD cmd = {0x0, IOL_CMD_LLT, 0x0, 0x0};
-	
-	RTW_PUT_BE32((u8*)&cmd.value, (u32)page_boundary);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
+	RTW_PUT_BE32((u8 *)&cmd.value, (u32)page_boundary);
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
 }
 
 int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value)
 {
 	IOL_CMD cmd = {0x0, IOL_CMD_WB_REG, 0x0, 0x0};
-	
-	RTW_PUT_BE16((u8*)&cmd.address, (u16)addr);
-	RTW_PUT_BE32((u8*)&cmd.value, (u32)value);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
+	RTW_PUT_BE16((u8 *)&cmd.address, (u16)addr);
+	RTW_PUT_BE32((u8 *)&cmd.value, (u32)value);
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
 }
 
 int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value)
 {
 	IOL_CMD cmd = {0x0, IOL_CMD_WW_REG, 0x0, 0x0};
-	
-	RTW_PUT_BE16((u8*)&cmd.address, (u16)addr);
-	RTW_PUT_BE32((u8*)&cmd.value, (u32)value);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
+	RTW_PUT_BE16((u8 *)&cmd.address, (u16)addr);
+	RTW_PUT_BE32((u8 *)&cmd.value, (u32)value);
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
 }
 
 int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value)
 {
 	IOL_CMD cmd = {0x0, IOL_CMD_WD_REG, 0x0, 0x0};
-	u8* pos = (u8 *)&cmd;
-	
-	RTW_PUT_BE16((u8*)&cmd.address, (u16)addr);
-	RTW_PUT_BE32((u8*)&cmd.value, (u32)value);
+	u8 *pos = (u8 *)&cmd;
+
+	RTW_PUT_BE16((u8 *)&cmd.address, (u16)addr);
+	RTW_PUT_BE32((u8 *)&cmd.value, (u32)value);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
 }
 
 #ifdef DBG_IO
 int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 1))
-		DBG_871X("DBG_IO %s:%d IOL_WB(0x%04x, 0x%02x)\n", caller, line, addr, value);
+		RTW_INFO("DBG_IO %s:%d IOL_WB(0x%04x, 0x%02x)\n", caller, line, addr, value);
 
 	return _rtw_IOL_append_WB_cmd(xmit_frame, addr, value);
 }
@@ -318,7 +311,7 @@ int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value,
 int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 2))
-		DBG_871X("DBG_IO %s:%d IOL_WW(0x%04x, 0x%04x)\n", caller, line, addr, value);
+		RTW_INFO("DBG_IO %s:%d IOL_WW(0x%04x, 0x%04x)\n", caller, line, addr, value);
 
 	return _rtw_IOL_append_WW_cmd(xmit_frame, addr, value);
 }
@@ -326,7 +319,7 @@ int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value
 int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line)
 {
 	if (match_write_sniff_ranges(addr, 4))
-		DBG_871X("DBG_IO %s:%d IOL_WD(0x%04x, 0x%08x)\n", caller, line, addr, value);
+		RTW_INFO("DBG_IO %s:%d IOL_WD(0x%04x, 0x%08x)\n", caller, line, addr, value);
 
 	return _rtw_IOL_append_WD_cmd(xmit_frame, addr, value);
 }
@@ -335,31 +328,31 @@ int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value
 int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us)
 {
 	IOL_CMD cmd = {0x0, IOL_CMD_DELAY_US, 0x0, 0x0};
-	
-	RTW_PUT_BE32((u8*)&cmd.value, (u32)us);
 
-	//DBG_871X("%s %u\n", __FUNCTION__, us);
+	RTW_PUT_BE32((u8 *)&cmd.value, (u32)us);
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
+	/* RTW_INFO("%s %u\n", __FUNCTION__, us); */
+
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
 }
 
 int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms)
 {
 	IOL_CMD cmd = {0x0, IOL_CMD_DELAY_MS, 0x0, 0x0};
-	
-	RTW_PUT_BE32((u8*)&cmd.value, (u32)ms);
 
-	//DBG_871X("%s %u\n", __FUNCTION__, ms);
+	RTW_PUT_BE32((u8 *)&cmd.value, (u32)ms);
+
+	/* RTW_INFO("%s %u\n", __FUNCTION__, ms); */
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&cmd, 8);
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
 }
 
 int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame)
-{	
+{
 	IOL_CMD end_cmd = {0x0, IOL_CMD_END, 0x0, 0x0};
 
 
-	return rtw_IOL_append_cmds(xmit_frame, (u8*)&end_cmd, 8);
+	return rtw_IOL_append_cmds(xmit_frame, (u8 *)&end_cmd, 8);
 
 }
 
@@ -367,24 +360,24 @@ int rtw_IOL_exec_cmd_array_sync(PADAPTER adapter, u8 *IOL_cmds, u32 cmd_num, u32
 {
 	struct xmit_frame	*xmit_frame;
 
-	if((xmit_frame=rtw_IOL_accquire_xmit_frame(adapter)) == NULL)
+	xmit_frame = rtw_IOL_accquire_xmit_frame(adapter);
+	if (xmit_frame == NULL)
 		return _FAIL;
 
-	if(rtw_IOL_append_cmds(xmit_frame, IOL_cmds, cmd_num<<3) == _FAIL)
+	if (rtw_IOL_append_cmds(xmit_frame, IOL_cmds, cmd_num << 3) == _FAIL)
 		return _FAIL;
 
-	return rtw_IOL_exec_cmds_sync(adapter, xmit_frame, max_wating_ms,0);
+	return rtw_IOL_exec_cmds_sync(adapter, xmit_frame, max_wating_ms, 0);
 }
 
 int rtw_IOL_exec_empty_cmds_sync(ADAPTER *adapter, u32 max_wating_ms)
 {
 	IOL_CMD end_cmd = {0x0, IOL_CMD_END, 0x0, 0x0};
-	return rtw_IOL_exec_cmd_array_sync(adapter, (u8*)&end_cmd, 1, max_wating_ms);
+	return rtw_IOL_exec_cmd_array_sync(adapter, (u8 *)&end_cmd, 1, max_wating_ms);
 }
-#endif //CONFIG_IOL_NEW_GENERATION
-
+#endif /* CONFIG_IOL_NEW_GENERATION */
 
 
 
-#endif //CONFIG_IOL
 
+#endif /* CONFIG_IOL */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mem.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mem.c
index d05e3af6993e..4f241751050e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mem.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mem.c
@@ -1,122 +1,129 @@
-
-#include <drv_types.h>
-#include <rtw_mem.h>
-
-MODULE_LICENSE("GPL");
-MODULE_DESCRIPTION("Realtek Wireless Lan Driver");
-MODULE_AUTHOR("Realtek Semiconductor Corp.");
-MODULE_VERSION("DRIVERVERSION");
-
-struct sk_buff_head rtk_skb_mem_q;
-struct u8* rtk_buf_mem[NR_RECVBUFF];
-
-struct u8	* rtw_get_buf_premem(int index)
-{
-	printk("%s, rtk_buf_mem index : %d\n", __func__, index);
-	return rtk_buf_mem[index];
-}
-
-u16 rtw_rtkm_get_buff_size(void)
-{
-	return MAX_RTKM_RECVBUF_SZ;
-}
-EXPORT_SYMBOL(rtw_rtkm_get_buff_size);
-
-u8 rtw_rtkm_get_nr_recv_skb(void)
-{
-	return MAX_RTKM_NR_PREALLOC_RECV_SKB;
-}
-EXPORT_SYMBOL(rtw_rtkm_get_nr_recv_skb);
-
-struct sk_buff *rtw_alloc_skb_premem(u16 in_size)
-{
-	struct sk_buff *skb = NULL;
-
-	if (in_size > MAX_RTKM_RECVBUF_SZ) {
-		pr_info("warning %s: driver buffer size(%d) > rtkm buffer size(%d)\n", __func__, in_size, MAX_RTKM_RECVBUF_SZ);
-		WARN_ON(1);
-		return skb;
-	}
-
-	skb = skb_dequeue(&rtk_skb_mem_q);
-
-	printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
-
-	return skb;	
-}
-EXPORT_SYMBOL(rtw_alloc_skb_premem);
-
-int rtw_free_skb_premem(struct sk_buff *pskb)
-{
-	if(!pskb)
-		return -1;
-
-	if (skb_queue_len(&rtk_skb_mem_q) >= MAX_RTKM_NR_PREALLOC_RECV_SKB)	
-		return -1;
-	
-	skb_queue_tail(&rtk_skb_mem_q, pskb);
-	
-	printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
-
-	return 0;
-}
-EXPORT_SYMBOL(rtw_free_skb_premem);
-
-static int __init rtw_mem_init(void)
-{
-	int i;
-	SIZE_PTR tmpaddr=0;
-	SIZE_PTR alignment=0;
-	struct sk_buff *pskb=NULL;
-
-	printk("%s\n", __func__);
-	pr_info("MAX_RTKM_NR_PREALLOC_RECV_SKB: %d\n", MAX_RTKM_NR_PREALLOC_RECV_SKB);
-	pr_info("MAX_RTKM_RECVBUF_SZ: %d\n", MAX_RTKM_RECVBUF_SZ);
-
-#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
-	for(i=0; i<NR_RECVBUFF; i++)

-	{

-		rtk_buf_mem[i] = usb_buffer_alloc(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);
-	}
-#endif //CONFIG_USE_USB_BUFFER_ALLOC_RX
-
-	skb_queue_head_init(&rtk_skb_mem_q);
-
-	for(i=0; i<MAX_RTKM_NR_PREALLOC_RECV_SKB; i++)
-	{
-		pskb = __dev_alloc_skb(MAX_RTKM_RECVBUF_SZ + RECVBUFF_ALIGN_SZ, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
-		if(pskb)
-		{		
-			tmpaddr = (SIZE_PTR)pskb->data;
-			alignment = tmpaddr & (RECVBUFF_ALIGN_SZ-1);
-			skb_reserve(pskb, (RECVBUFF_ALIGN_SZ - alignment));
-
-			skb_queue_tail(&rtk_skb_mem_q, pskb);
-		}
-		else
-		{
-			printk("%s, alloc skb memory fail!\n", __func__);
-		}
-
-		pskb=NULL;
-	}
-
-	printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
-
-	return 0;
-	
-}
-
-static void __exit rtw_mem_exit(void)
-{
-	if (skb_queue_len(&rtk_skb_mem_q)) {
-		printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
-	}
-
-	skb_queue_purge(&rtk_skb_mem_q);
-
-	printk("%s\n", __func__);
-}
-
-module_init(rtw_mem_init);
-module_exit(rtw_mem_exit);
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 <rtw_mem.h>
+
+MODULE_LICENSE("GPL");
+MODULE_DESCRIPTION("Realtek Wireless Lan Driver");
+MODULE_AUTHOR("Realtek Semiconductor Corp.");
+MODULE_VERSION("DRIVERVERSION");
+
+struct sk_buff_head rtk_skb_mem_q;
+struct u8 *rtk_buf_mem[NR_RECVBUFF];
+
+struct u8	*rtw_get_buf_premem(int index)
+{
+	printk("%s, rtk_buf_mem index : %d\n", __func__, index);
+	return rtk_buf_mem[index];
+}
+
+u16 rtw_rtkm_get_buff_size(void)
+{
+	return MAX_RTKM_RECVBUF_SZ;
+}
+EXPORT_SYMBOL(rtw_rtkm_get_buff_size);
+
+u8 rtw_rtkm_get_nr_recv_skb(void)
+{
+	return MAX_RTKM_NR_PREALLOC_RECV_SKB;
+}
+EXPORT_SYMBOL(rtw_rtkm_get_nr_recv_skb);
+
+struct sk_buff *rtw_alloc_skb_premem(u16 in_size)
+{
+	struct sk_buff *skb = NULL;
+
+	if (in_size > MAX_RTKM_RECVBUF_SZ) {
+		pr_info("warning %s: driver buffer size(%d) > rtkm buffer size(%d)\n", __func__, in_size, MAX_RTKM_RECVBUF_SZ);
+		WARN_ON(1);
+		return skb;
+	}
+
+	skb = skb_dequeue(&rtk_skb_mem_q);
+
+	printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
+
+	return skb;
+}
+EXPORT_SYMBOL(rtw_alloc_skb_premem);
+
+int rtw_free_skb_premem(struct sk_buff *pskb)
+{
+	if (!pskb)
+		return -1;
+
+	if (skb_queue_len(&rtk_skb_mem_q) >= MAX_RTKM_NR_PREALLOC_RECV_SKB)
+		return -1;
+
+	skb_queue_tail(&rtk_skb_mem_q, pskb);
+
+	printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
+
+	return 0;
+}
+EXPORT_SYMBOL(rtw_free_skb_premem);
+
+static int __init rtw_mem_init(void)
+{
+	int i;
+	SIZE_PTR tmpaddr = 0;
+	SIZE_PTR alignment = 0;
+	struct sk_buff *pskb = NULL;
+
+	printk("%s\n", __func__);
+	pr_info("MAX_RTKM_NR_PREALLOC_RECV_SKB: %d\n", MAX_RTKM_NR_PREALLOC_RECV_SKB);
+	pr_info("MAX_RTKM_RECVBUF_SZ: %d\n", MAX_RTKM_RECVBUF_SZ);
+
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+	for (i = 0; i < NR_RECVBUFF; i++)
+		rtk_buf_mem[i] = usb_buffer_alloc(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
+
+	skb_queue_head_init(&rtk_skb_mem_q);
+
+	for (i = 0; i < MAX_RTKM_NR_PREALLOC_RECV_SKB; i++) {
+		pskb = __dev_alloc_skb(MAX_RTKM_RECVBUF_SZ + RECVBUFF_ALIGN_SZ, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+		if (pskb) {
+			tmpaddr = (SIZE_PTR)pskb->data;
+			alignment = tmpaddr & (RECVBUFF_ALIGN_SZ - 1);
+			skb_reserve(pskb, (RECVBUFF_ALIGN_SZ - alignment));
+
+			skb_queue_tail(&rtk_skb_mem_q, pskb);
+		} else
+			printk("%s, alloc skb memory fail!\n", __func__);
+
+		pskb = NULL;
+	}
+
+	printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
+
+	return 0;
+
+}
+
+static void __exit rtw_mem_exit(void)
+{
+	if (skb_queue_len(&rtk_skb_mem_q))
+		printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
+
+	skb_queue_purge(&rtk_skb_mem_q);
+
+	printk("%s\n", __func__);
+}
+
+module_init(rtw_mem_init);
+module_exit(rtw_mem_exit);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mi.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mi.c
new file mode 100644
index 000000000000..347c818ffc3e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mi.c
@@ -0,0 +1,1479 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MI_C_
+
+#include <drv_types.h>
+#include <hal_data.h>
+
+void rtw_mi_update_union_chan_inf(_adapter *adapter, u8 ch, u8 offset , u8 bw)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mi_state *iface_state = &dvobj->iface_state;
+
+	iface_state->union_ch = ch;
+	iface_state->union_bw = bw;
+	iface_state->union_offset = offset;
+}
+
+#ifdef CONFIG_P2P
+static u8 _rtw_mi_p2p_listen_scan_chk(_adapter *adapter)
+{
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 p2p_listen_scan_state = _FALSE;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_LISTEN) ||
+			rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_SCAN)) {
+			p2p_listen_scan_state = _TRUE;
+			break;
+		}
+	}
+	return p2p_listen_scan_state;
+}
+#endif
+u8 rtw_mi_stayin_union_ch_chk(_adapter *adapter)
+{
+	u8 rst = _TRUE;
+	u8 u_ch, u_bw, u_offset;
+	u8 o_ch, o_bw, o_offset;
+
+	u_ch = rtw_mi_get_union_chan(adapter);
+	u_bw = rtw_mi_get_union_bw(adapter);
+	u_offset = rtw_mi_get_union_offset(adapter);
+
+	o_ch = rtw_get_oper_ch(adapter);
+	o_bw = rtw_get_oper_bw(adapter);
+	o_offset = rtw_get_oper_choffset(adapter);
+
+	if ((u_ch != o_ch) || (u_bw != o_bw) || (u_offset != o_offset))
+		rst = _FALSE;
+
+	#ifdef DBG_IFACE_STATUS
+	if (rst == _FALSE) {
+		RTW_ERR("%s Not stay in union channel\n", __func__);
+		if (GET_HAL_DATA(adapter)->bScanInProcess == _TRUE)
+			RTW_ERR("ScanInProcess\n");
+		#ifdef CONFIG_P2P
+		if (_rtw_mi_p2p_listen_scan_chk(adapter))
+			RTW_ERR("P2P in listen or scan state\n");
+		#endif
+		RTW_ERR("union ch, bw, offset: %u,%u,%u\n", u_ch, u_bw, u_offset);
+		RTW_ERR("oper ch, bw, offset: %u,%u,%u\n", o_ch, o_bw, o_offset);
+		RTW_ERR("=========================\n");
+	}
+	#endif
+	return rst;
+}
+
+u8 rtw_mi_stayin_union_band_chk(_adapter *adapter)
+{
+	u8 rst = _TRUE;
+	u8 u_ch, o_ch;
+	u8 u_band, o_band;
+
+	u_ch = rtw_mi_get_union_chan(adapter);
+	o_ch = rtw_get_oper_ch(adapter);
+	u_band = (u_ch > 14) ? BAND_ON_5G : BAND_ON_2_4G;
+	o_band = (o_ch > 14) ? BAND_ON_5G : BAND_ON_2_4G;
+
+	if (u_ch != o_ch)
+		if(u_band != o_band)
+			rst = _FALSE;
+
+	#ifdef DBG_IFACE_STATUS
+	if (rst == _FALSE)
+		RTW_ERR("%s Not stay in union band\n", __func__);
+	#endif
+
+	return rst;
+}
+
+/* Find union about ch, bw, ch_offset of all linked/linking interfaces */
+int _rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset, bool include_self)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
+	struct mlme_ext_priv *mlmeext;
+	int i;
+	u8 ch_ret = 0;
+	u8 bw_ret = CHANNEL_WIDTH_20;
+	u8 offset_ret = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int num = 0;
+
+	if (ch)
+		*ch = 0;
+	if (bw)
+		*bw = CHANNEL_WIDTH_20;
+	if (offset)
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		mlmeext = &iface->mlmeextpriv;
+
+		if (!check_fwstate(&iface->mlmepriv, _FW_LINKED | _FW_UNDER_LINKING))
+			continue;
+
+		if (check_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING))
+			continue;
+
+		if (include_self == _FALSE && adapter == iface)
+			continue;
+
+		if (num == 0) {
+			ch_ret = mlmeext->cur_channel;
+			bw_ret = mlmeext->cur_bwmode;
+			offset_ret = mlmeext->cur_ch_offset;
+			num++;
+			continue;
+		}
+
+		if (ch_ret != mlmeext->cur_channel) {
+			num = 0;
+			break;
+		}
+
+		if (bw_ret < mlmeext->cur_bwmode) {
+			bw_ret = mlmeext->cur_bwmode;
+			offset_ret = mlmeext->cur_ch_offset;
+		} else if (bw_ret == mlmeext->cur_bwmode && offset_ret != mlmeext->cur_ch_offset) {
+			num = 0;
+			break;
+		}
+
+		num++;
+	}
+
+	if (num) {
+		if (ch)
+			*ch = ch_ret;
+		if (bw)
+			*bw = bw_ret;
+		if (offset)
+			*offset = offset_ret;
+	}
+
+	return num;
+}
+
+inline int rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
+{
+	return _rtw_mi_get_ch_setting_union(adapter, ch, bw, offset, 1);
+}
+
+inline int rtw_mi_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
+{
+	return _rtw_mi_get_ch_setting_union(adapter, ch, bw, offset, 0);
+}
+
+#define MI_STATUS_SELF_ONLY		0
+#define MI_STATUS_OTHERS_ONLY	1
+#define MI_STATUS_ALL			2
+
+/* For now, not return union_ch/bw/offset */
+void _rtw_mi_status(_adapter *adapter, struct mi_state *mstate, u8 target_sel)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
+	int i;
+
+	_rtw_memset(mstate, 0, sizeof(struct mi_state));
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+
+		if (target_sel == MI_STATUS_SELF_ONLY && iface != adapter)
+			continue;
+		if (target_sel == MI_STATUS_OTHERS_ONLY && iface == adapter)
+			continue;
+
+		if (check_fwstate(&iface->mlmepriv, WIFI_STATION_STATE) == _TRUE) {
+			MSTATE_STA_NUM(mstate)++;
+			if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
+				MSTATE_STA_LD_NUM(mstate)++;
+
+				#ifdef CONFIG_TDLS
+				if (iface->tdlsinfo.link_established == _TRUE)
+					MSTATE_TDLS_LD_NUM(mstate)++;
+				#endif
+			}
+			if (check_fwstate(&iface->mlmepriv, _FW_UNDER_LINKING) == _TRUE)
+				MSTATE_STA_LG_NUM(mstate)++;
+
+#ifdef CONFIG_AP_MODE
+		} else if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE ) {
+			if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
+				MSTATE_AP_NUM(mstate)++;
+				if (iface->stapriv.asoc_sta_count > 2)
+					MSTATE_AP_LD_NUM(mstate)++;
+			} else
+				MSTATE_AP_STARTING_NUM(mstate)++;
+#endif
+
+		} else if (check_fwstate(&iface->mlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) == _TRUE
+			&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
+		) {
+			MSTATE_ADHOC_NUM(mstate)++;
+			if (iface->stapriv.asoc_sta_count > 2)
+				MSTATE_ADHOC_LD_NUM(mstate)++;
+
+#ifdef CONFIG_RTW_MESH
+		} else if (check_fwstate(&iface->mlmepriv, WIFI_MESH_STATE) == _TRUE
+			&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
+		) {
+			MSTATE_MESH_NUM(mstate)++;
+			if (iface->stapriv.asoc_sta_count > 2)
+				MSTATE_MESH_LD_NUM(mstate)++;
+#endif
+
+		}
+
+		if (check_fwstate(&iface->mlmepriv, WIFI_UNDER_WPS) == _TRUE)
+			MSTATE_WPS_NUM(mstate)++;
+
+		if (check_fwstate(&iface->mlmepriv, WIFI_SITE_MONITOR) == _TRUE) {
+			MSTATE_SCAN_NUM(mstate)++;
+
+			if (mlmeext_scan_state(&iface->mlmeextpriv) != SCAN_DISABLE
+				&& mlmeext_scan_state(&iface->mlmeextpriv) != SCAN_BACK_OP)
+				MSTATE_SCAN_ENTER_NUM(mstate)++;
+		}
+
+#ifdef CONFIG_IOCTL_CFG80211
+		if (rtw_cfg80211_get_is_mgmt_tx(iface))
+			MSTATE_MGMT_TX_NUM(mstate)++;
+		#ifdef CONFIG_P2P
+		if (rtw_cfg80211_get_is_roch(iface) == _TRUE)
+			MSTATE_ROCH_NUM(mstate)++;
+		#endif
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+	}
+}
+
+inline void rtw_mi_status(_adapter *adapter, struct mi_state *mstate)
+{
+	return _rtw_mi_status(adapter, mstate, MI_STATUS_ALL);
+}
+
+inline void rtw_mi_status_no_self(_adapter *adapter, struct mi_state *mstate)
+{
+	return _rtw_mi_status(adapter, mstate, MI_STATUS_OTHERS_ONLY);
+}
+
+inline void rtw_mi_status_no_others(_adapter *adapter, struct mi_state *mstate)
+{
+	return _rtw_mi_status(adapter, mstate, MI_STATUS_SELF_ONLY);
+}
+
+/* For now, not handle union_ch/bw/offset */
+inline void rtw_mi_status_merge(struct mi_state *d, struct mi_state *a)
+{
+	d->sta_num += a->sta_num;
+	d->ld_sta_num += a->ld_sta_num;
+	d->lg_sta_num += a->lg_sta_num;
+#ifdef CONFIG_TDLS
+	d->ld_tdls_num += a->ld_tdls_num;
+#endif
+#ifdef CONFIG_AP_MODE
+	d->ap_num += a->ap_num;
+	d->ld_ap_num += a->ld_ap_num;
+#endif
+	d->adhoc_num += a->adhoc_num;
+	d->ld_adhoc_num += a->ld_adhoc_num;
+#ifdef CONFIG_RTW_MESH
+	d->mesh_num += a->mesh_num;
+	d->ld_mesh_num += a->ld_mesh_num;
+#endif
+	d->scan_num += a->scan_num;
+	d->scan_enter_num += a->scan_enter_num;
+	d->uwps_num += a->uwps_num;
+#ifdef CONFIG_IOCTL_CFG80211
+	#ifdef CONFIG_P2P
+	d->roch_num += a->roch_num;
+	#endif
+	d->mgmt_tx_num += a->mgmt_tx_num;
+#endif
+}
+
+void dump_mi_status(void *sel, struct dvobj_priv *dvobj)
+{
+	RTW_PRINT_SEL(sel, "== dvobj-iface_state ==\n");
+	RTW_PRINT_SEL(sel, "sta_num:%d\n", DEV_STA_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "linking_sta_num:%d\n", DEV_STA_LG_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "linked_sta_num:%d\n", DEV_STA_LD_NUM(dvobj));
+#ifdef CONFIG_TDLS
+	RTW_PRINT_SEL(sel, "linked_tdls_num:%d\n", DEV_TDLS_LD_NUM(dvobj));
+#endif
+#ifdef CONFIG_AP_MODE
+	RTW_PRINT_SEL(sel, "ap_num:%d\n", DEV_AP_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "starting_ap_num:%d\n", DEV_AP_STARTING_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "linked_ap_num:%d\n", DEV_AP_LD_NUM(dvobj));
+#endif
+	RTW_PRINT_SEL(sel, "adhoc_num:%d\n", DEV_ADHOC_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "linked_adhoc_num:%d\n", DEV_ADHOC_LD_NUM(dvobj));
+#ifdef CONFIG_RTW_MESH
+	RTW_PRINT_SEL(sel, "mesh_num:%d\n", DEV_MESH_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "linked_mesh_num:%d\n", DEV_MESH_LD_NUM(dvobj));
+#endif
+#ifdef CONFIG_P2P
+	RTW_PRINT_SEL(sel, "p2p_device_num:%d\n", rtw_mi_stay_in_p2p_mode(dvobj_get_primary_adapter(dvobj)));
+#endif
+	RTW_PRINT_SEL(sel, "scan_num:%d\n", DEV_SCAN_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "under_wps_num:%d\n", DEV_WPS_NUM(dvobj));
+#if defined(CONFIG_IOCTL_CFG80211)
+	#if defined(CONFIG_P2P)
+	RTW_PRINT_SEL(sel, "roch_num:%d\n", DEV_ROCH_NUM(dvobj));
+	#endif
+	RTW_PRINT_SEL(sel, "mgmt_tx_num:%d\n", DEV_MGMT_TX_NUM(dvobj));
+#endif
+	RTW_PRINT_SEL(sel, "union_ch:%d\n", DEV_U_CH(dvobj));
+	RTW_PRINT_SEL(sel, "union_bw:%d\n", DEV_U_BW(dvobj));
+	RTW_PRINT_SEL(sel, "union_offset:%d\n", DEV_U_OFFSET(dvobj));
+	RTW_PRINT_SEL(sel, "================\n\n");
+}
+
+void dump_dvobj_mi_status(void *sel, const char *fun_name, _adapter *adapter)
+{
+	RTW_INFO("\n[ %s ] call %s\n", fun_name, __func__);
+	dump_mi_status(sel, adapter_to_dvobj(adapter));
+}
+
+inline void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state)
+{
+	_adapter *adapter = container_of(pmlmepriv, _adapter, mlmepriv);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mi_state *iface_state = &dvobj->iface_state;
+	struct mi_state tmp_mstate;
+	u8 i;
+	u8 u_ch, u_offset, u_bw;
+	_adapter *iface;
+
+	if (state == WIFI_MONITOR_STATE
+		|| state == 0xFFFFFFFF
+	)
+		return;
+
+	if (0)
+		RTW_INFO("%s => will change or clean state to 0x%08x\n", __func__, state);
+
+	rtw_mi_status(adapter, &tmp_mstate);
+	_rtw_memcpy(iface_state, &tmp_mstate, sizeof(struct mi_state));
+
+	if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset))
+		rtw_mi_update_union_chan_inf(adapter , u_ch, u_offset , u_bw);
+	else {
+		if (0) {
+			dump_adapters_status(RTW_DBGDUMP , dvobj);
+			RTW_INFO("%s-[ERROR] cannot get union channel\n", __func__);
+			rtw_warn_on(1);
+		}
+	}
+
+#ifdef DBG_IFACE_STATUS
+	DBG_IFACE_STATUS_DUMP(adapter);
+#endif
+}
+u8 rtw_mi_check_status(_adapter *adapter, u8 type)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mi_state *iface_state = &dvobj->iface_state;
+	u8 ret = _FALSE;
+
+#ifdef DBG_IFACE_STATUS
+	DBG_IFACE_STATUS_DUMP(adapter);
+	RTW_INFO("%s-"ADPT_FMT" check type:%d\n", __func__, ADPT_ARG(adapter), type);
+#endif
+
+	switch (type) {
+	case MI_LINKED:
+		if (MSTATE_STA_LD_NUM(iface_state) || MSTATE_AP_NUM(iface_state) || MSTATE_ADHOC_NUM(iface_state) || MSTATE_MESH_NUM(iface_state)) /*check_fwstate(&iface->mlmepriv, _FW_LINKED)*/
+			ret = _TRUE;
+		break;
+	case MI_ASSOC:
+		if (MSTATE_STA_LD_NUM(iface_state) || MSTATE_AP_LD_NUM(iface_state) || MSTATE_ADHOC_LD_NUM(iface_state) || MSTATE_MESH_LD_NUM(iface_state))
+			ret = _TRUE;
+		break;
+	case MI_UNDER_WPS:
+		if (MSTATE_WPS_NUM(iface_state))
+			ret = _TRUE;
+		break;
+
+	case MI_AP_MODE:
+		if (MSTATE_AP_NUM(iface_state))
+			ret = _TRUE;
+		break;
+	case MI_AP_ASSOC:
+		if (MSTATE_AP_LD_NUM(iface_state))
+			ret = _TRUE;
+		break;
+
+	case MI_ADHOC:
+		if (MSTATE_ADHOC_NUM(iface_state))
+			ret = _TRUE;
+		break;
+	case MI_ADHOC_ASSOC:
+		if (MSTATE_ADHOC_LD_NUM(iface_state))
+			ret = _TRUE;
+		break;
+
+#ifdef CONFIG_RTW_MESH
+	case MI_MESH:
+		if (MSTATE_MESH_NUM(iface_state))
+			ret = _TRUE;
+		break;
+	case MI_MESH_ASSOC:
+		if (MSTATE_MESH_LD_NUM(iface_state))
+			ret = _TRUE;
+		break;
+#endif
+
+	case MI_STA_NOLINK: /* this is misleading, but not used now */
+		if (MSTATE_STA_NUM(iface_state) && (!(MSTATE_STA_LD_NUM(iface_state) || MSTATE_STA_LG_NUM(iface_state))))
+			ret = _TRUE;
+		break;
+	case MI_STA_LINKED:
+		if (MSTATE_STA_LD_NUM(iface_state))
+			ret = _TRUE;
+		break;
+	case MI_STA_LINKING:
+		if (MSTATE_STA_LG_NUM(iface_state))
+			ret = _TRUE;
+		break;
+
+	default:
+		break;
+	}
+	return ret;
+}
+
+/*
+* return value : 0 is failed or have not interface meet condition
+* return value : !0 is success or interface numbers which meet condition
+* return value of ops_func must be _TRUE or _FALSE
+*/
+static u8 _rtw_mi_process(_adapter *padapter, bool exclude_self,
+		  void *data, u8(*ops_func)(_adapter *padapter, void *data))
+{
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	u8 ret = 0;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+
+			if ((exclude_self) && (iface == padapter))
+				continue;
+
+			if (ops_func)
+				if (_TRUE == ops_func(iface, data))
+					ret++;
+		}
+	}
+	return ret;
+}
+static u8 _rtw_mi_process_without_schk(_adapter *padapter, bool exclude_self,
+		  void *data, u8(*ops_func)(_adapter *padapter, void *data))
+{
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	u8 ret = 0;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {
+			if ((exclude_self) && (iface == padapter))
+				continue;
+
+			if (ops_func)
+				if (ops_func(iface, data) == _TRUE)
+					ret++;
+		}
+	}
+	return ret;
+}
+
+static u8 _rtw_mi_netif_caroff_qstop(_adapter *padapter, void *data)
+{
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	rtw_netif_carrier_off(pnetdev);
+	rtw_netif_stop_queue(pnetdev);
+	return _TRUE;
+}
+u8 rtw_mi_netif_caroff_qstop(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_caroff_qstop);
+}
+u8 rtw_mi_buddy_netif_caroff_qstop(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_caroff_qstop);
+}
+
+static u8 _rtw_mi_netif_caron_qstart(_adapter *padapter, void *data)
+{
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	rtw_netif_carrier_on(pnetdev);
+	rtw_netif_start_queue(pnetdev);
+	return _TRUE;
+}
+u8 rtw_mi_netif_caron_qstart(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_caron_qstart);
+}
+u8 rtw_mi_buddy_netif_caron_qstart(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_caron_qstart);
+}
+
+static u8 _rtw_mi_netif_stop_queue(_adapter *padapter, void *data)
+{
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	rtw_netif_stop_queue(pnetdev);
+	return _TRUE;
+}
+u8 rtw_mi_netif_stop_queue(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_stop_queue);
+}
+u8 rtw_mi_buddy_netif_stop_queue(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_stop_queue);
+}
+
+static u8 _rtw_mi_netif_wake_queue(_adapter *padapter, void *data)
+{
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	if (pnetdev)
+		rtw_netif_wake_queue(pnetdev);
+	return _TRUE;
+}
+u8 rtw_mi_netif_wake_queue(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_wake_queue);
+}
+u8 rtw_mi_buddy_netif_wake_queue(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_wake_queue);
+}
+
+static u8 _rtw_mi_netif_carrier_on(_adapter *padapter, void *data)
+{
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	if (pnetdev)
+		rtw_netif_carrier_on(pnetdev);
+	return _TRUE;
+}
+u8 rtw_mi_netif_carrier_on(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_carrier_on);
+}
+u8 rtw_mi_buddy_netif_carrier_on(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_carrier_on);
+}
+
+static u8 _rtw_mi_netif_carrier_off(_adapter *padapter, void *data)
+{
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	if (pnetdev)
+		rtw_netif_carrier_off(pnetdev);
+	return _TRUE;
+}
+u8 rtw_mi_netif_carrier_off(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_carrier_off);
+}
+u8 rtw_mi_buddy_netif_carrier_off(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_carrier_off);
+}
+
+static u8 _rtw_mi_scan_abort(_adapter *adapter, void *data)
+{
+	bool bwait = *(bool *)data;
+
+	if (bwait)
+		rtw_scan_abort(adapter);
+	else
+		rtw_scan_abort_no_wait(adapter);
+
+	return _TRUE;
+}
+void rtw_mi_scan_abort(_adapter *adapter, bool bwait)
+{
+	bool in_data = bwait;
+
+	_rtw_mi_process(adapter, _FALSE, &in_data, _rtw_mi_scan_abort);
+
+}
+void rtw_mi_buddy_scan_abort(_adapter *adapter, bool bwait)
+{
+	bool in_data = bwait;
+
+	_rtw_mi_process(adapter, _TRUE, &in_data, _rtw_mi_scan_abort);
+}
+
+static u32 _rtw_mi_start_drv_threads(_adapter *adapter, bool exclude_self)
+{
+	int i;
+	_adapter *iface = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u32 _status = _SUCCESS;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {
+			if ((exclude_self) && (iface == adapter))
+				continue;
+			if (rtw_start_drv_threads(iface) == _FAIL) {
+				_status = _FAIL;
+				break;
+			}
+		}
+	}
+	return _status;
+}
+u32 rtw_mi_start_drv_threads(_adapter *adapter)
+{
+	return _rtw_mi_start_drv_threads(adapter, _FALSE);
+}
+u32 rtw_mi_buddy_start_drv_threads(_adapter *adapter)
+{
+	return _rtw_mi_start_drv_threads(adapter, _TRUE);
+}
+
+static void _rtw_mi_stop_drv_threads(_adapter *adapter, bool exclude_self)
+{
+	int i;
+	_adapter *iface = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {
+			if ((exclude_self) && (iface == adapter))
+				continue;
+			rtw_stop_drv_threads(iface);
+		}
+	}
+}
+void rtw_mi_stop_drv_threads(_adapter *adapter)
+{
+	_rtw_mi_stop_drv_threads(adapter, _FALSE);
+}
+void rtw_mi_buddy_stop_drv_threads(_adapter *adapter)
+{
+	_rtw_mi_stop_drv_threads(adapter, _TRUE);
+}
+
+static u8 _rtw_mi_cancel_all_timer(_adapter *adapter, void *data)
+{
+	rtw_cancel_all_timer(adapter);
+	return _TRUE;
+}
+void rtw_mi_cancel_all_timer(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_cancel_all_timer);
+}
+void rtw_mi_buddy_cancel_all_timer(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_cancel_all_timer);
+}
+
+static u8 _rtw_mi_reset_drv_sw(_adapter *adapter, void *data)
+{
+	rtw_reset_drv_sw(adapter);
+	return _TRUE;
+}
+void rtw_mi_reset_drv_sw(_adapter *adapter)
+{
+	_rtw_mi_process_without_schk(adapter, _FALSE, NULL, _rtw_mi_reset_drv_sw);
+}
+void rtw_mi_buddy_reset_drv_sw(_adapter *adapter)
+{
+	_rtw_mi_process_without_schk(adapter, _TRUE, NULL, _rtw_mi_reset_drv_sw);
+}
+
+static u8 _rtw_mi_intf_start(_adapter *adapter, void *data)
+{
+	rtw_intf_start(adapter);
+	return _TRUE;
+}
+void rtw_mi_intf_start(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_intf_start);
+}
+void rtw_mi_buddy_intf_start(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_intf_start);
+}
+
+static u8 _rtw_mi_intf_stop(_adapter *adapter, void *data)
+{
+	rtw_intf_stop(adapter);
+	return _TRUE;
+}
+void rtw_mi_intf_stop(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_intf_stop);
+}
+void rtw_mi_buddy_intf_stop(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_intf_stop);
+}
+
+static u8 _rtw_mi_suspend_free_assoc_resource(_adapter *padapter, void *data)
+{
+	return rtw_suspend_free_assoc_resource(padapter);
+}
+void rtw_mi_suspend_free_assoc_resource(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_suspend_free_assoc_resource);
+}
+void rtw_mi_buddy_suspend_free_assoc_resource(_adapter *adapter)
+{
+	_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_suspend_free_assoc_resource);
+}
+
+static u8 _rtw_mi_is_scan_deny(_adapter *adapter, void *data)
+{
+	return rtw_is_scan_deny(adapter);
+}
+
+u8 rtw_mi_is_scan_deny(_adapter *adapter)
+{
+	return _rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_is_scan_deny);
+
+}
+u8 rtw_mi_buddy_is_scan_deny(_adapter *adapter)
+{
+	return _rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_is_scan_deny);
+}
+
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
+static u8 _rtw_mi_set_scan_deny(_adapter *adapter, void *data)
+{
+	u32 ms = *(u32 *)data;
+
+	rtw_set_scan_deny(adapter, ms);
+	return _TRUE;
+}
+void rtw_mi_set_scan_deny(_adapter *adapter, u32 ms)
+{
+	u32 in_data = ms;
+
+	_rtw_mi_process(adapter, _FALSE, &in_data, _rtw_mi_set_scan_deny);
+}
+void rtw_mi_buddy_set_scan_deny(_adapter *adapter, u32 ms)
+{
+	u32 in_data = ms;
+
+	_rtw_mi_process(adapter, _TRUE, &in_data, _rtw_mi_set_scan_deny);
+}
+#endif /*CONFIG_SET_SCAN_DENY_TIMER*/
+
+static u8 _rtw_mi_beacon_update(_adapter *padapter, void *data)
+{
+	if (!MLME_IS_STA(padapter)
+	    && check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE) {
+		RTW_INFO(ADPT_FMT" - update_beacon\n", ADPT_ARG(padapter));
+		update_beacon(padapter, 0xFF, NULL, _TRUE);
+	}
+	return _TRUE;
+}
+
+void rtw_mi_beacon_update(_adapter *padapter)
+{
+	_rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_beacon_update);
+}
+
+void rtw_mi_buddy_beacon_update(_adapter *padapter)
+{
+	_rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_beacon_update);
+}
+
+static u8 _rtw_mi_hal_dump_macaddr(_adapter *padapter, void *data)
+{
+	u8 mac_addr[ETH_ALEN] = {0};
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_MAC_ADDR, mac_addr);
+	RTW_INFO(ADPT_FMT"MAC Address ="MAC_FMT"\n", ADPT_ARG(padapter), MAC_ARG(mac_addr));
+	return _TRUE;
+}
+void rtw_mi_hal_dump_macaddr(_adapter *padapter)
+{
+	_rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_hal_dump_macaddr);
+}
+void rtw_mi_buddy_hal_dump_macaddr(_adapter *padapter)
+{
+	_rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_hal_dump_macaddr);
+}
+
+#ifdef CONFIG_PCI_HCI
+static u8 _rtw_mi_xmit_tasklet_schedule(_adapter *padapter, void *data)
+{
+	if (rtw_txframes_pending(padapter)) {
+		/* try to deal with the pending packets */
+		tasklet_hi_schedule(&(padapter->xmitpriv.xmit_tasklet));
+	}
+	return _TRUE;
+}
+void rtw_mi_xmit_tasklet_schedule(_adapter *padapter)
+{
+	_rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_xmit_tasklet_schedule);
+}
+void rtw_mi_buddy_xmit_tasklet_schedule(_adapter *padapter)
+{
+	_rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_xmit_tasklet_schedule);
+}
+#endif
+
+u8 _rtw_mi_busy_traffic_check(_adapter *padapter, void *data)
+{
+	u32 passtime;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	bool check_sc_interval = *(bool *)data;
+
+	if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE) {
+		if (check_sc_interval) {
+			/* Miracast can't do AP scan*/
+			passtime = rtw_get_passing_time_ms(pmlmepriv->lastscantime);
+			pmlmepriv->lastscantime = rtw_get_current_time();
+			if (passtime > BUSY_TRAFFIC_SCAN_DENY_PERIOD) {
+				RTW_INFO(ADPT_FMT" bBusyTraffic == _TRUE\n", ADPT_ARG(padapter));
+				return _TRUE;
+			}
+		} else
+			return _TRUE;
+	}
+
+	return _FALSE;
+}
+
+u8 rtw_mi_busy_traffic_check(_adapter *padapter, bool check_sc_interval)
+{
+	bool in_data = check_sc_interval;
+
+	return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_busy_traffic_check);
+}
+u8 rtw_mi_buddy_busy_traffic_check(_adapter *padapter, bool check_sc_interval)
+{
+	bool in_data = check_sc_interval;
+
+	return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_busy_traffic_check);
+}
+static u8 _rtw_mi_check_mlmeinfo_state(_adapter *padapter, void *data)
+{
+	u32 state = *(u32 *)data;
+	struct mlme_ext_priv *mlmeext = &padapter->mlmeextpriv;
+
+	/*if (mlmeext_msr(mlmeext) == state)*/
+	if (check_mlmeinfo_state(mlmeext, state))
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+u8 rtw_mi_check_mlmeinfo_state(_adapter *padapter, u32 state)
+{
+	u32 in_data = state;
+
+	return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_check_mlmeinfo_state);
+}
+
+u8 rtw_mi_buddy_check_mlmeinfo_state(_adapter *padapter, u32 state)
+{
+	u32 in_data = state;
+
+	return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_check_mlmeinfo_state);
+}
+
+/*#define DBG_DUMP_FW_STATE*/
+#ifdef DBG_DUMP_FW_STATE
+static void rtw_dbg_dump_fwstate(_adapter *padapter, sint state)
+{
+	u8 buf[32] = {0};
+
+	if (state & WIFI_FW_NULL_STATE) {
+		_rtw_memset(buf, 0, 32);
+		sprintf(buf, "WIFI_FW_NULL_STATE");
+		RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
+	}
+
+	if (state & _FW_LINKED) {
+		_rtw_memset(buf, 0, 32);
+		sprintf(buf, "_FW_LINKED");
+		RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
+	}
+
+	if (state & _FW_UNDER_LINKING) {
+		_rtw_memset(buf, 0, 32);
+		sprintf(buf, "_FW_UNDER_LINKING");
+		RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
+	}
+
+	if (state & _FW_UNDER_SURVEY) {
+		_rtw_memset(buf, 0, 32);
+		sprintf(buf, "_FW_UNDER_SURVEY");
+		RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
+	}
+}
+#endif
+
+static u8 _rtw_mi_check_fwstate(_adapter *padapter, void *data)
+{
+	u8 ret = _FALSE;
+
+	sint state = *(sint *)data;
+
+	if ((state == WIFI_FW_NULL_STATE) &&
+	    (padapter->mlmepriv.fw_state == WIFI_FW_NULL_STATE))
+		ret = _TRUE;
+	else if (_TRUE == check_fwstate(&padapter->mlmepriv, state))
+		ret = _TRUE;
+#ifdef DBG_DUMP_FW_STATE
+	if (ret)
+		rtw_dbg_dump_fwstate(padapter, state);
+#endif
+	return ret;
+}
+u8 rtw_mi_check_fwstate(_adapter *padapter, sint state)
+{
+	sint in_data = state;
+
+	return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_check_fwstate);
+}
+u8 rtw_mi_buddy_check_fwstate(_adapter *padapter, sint state)
+{
+	sint in_data = state;
+
+	return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_check_fwstate);
+}
+
+static u8 _rtw_mi_traffic_statistics(_adapter *padapter , void *data)
+{
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+
+	/* Tx */
+	pdvobjpriv->traffic_stat.tx_bytes += padapter->xmitpriv.tx_bytes;
+	pdvobjpriv->traffic_stat.tx_pkts += padapter->xmitpriv.tx_pkts;
+	pdvobjpriv->traffic_stat.tx_drop += padapter->xmitpriv.tx_drop;
+
+	/* Rx */
+	pdvobjpriv->traffic_stat.rx_bytes += padapter->recvpriv.rx_bytes;
+	pdvobjpriv->traffic_stat.rx_pkts += padapter->recvpriv.rx_pkts;
+	pdvobjpriv->traffic_stat.rx_drop += padapter->recvpriv.rx_drop;
+	return _TRUE;
+}
+u8 rtw_mi_traffic_statistics(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_traffic_statistics);
+}
+
+static u8 _rtw_mi_check_miracast_enabled(_adapter *padapter , void *data)
+{
+	return is_miracast_enabled(padapter);
+}
+u8 rtw_mi_check_miracast_enabled(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_check_miracast_enabled);
+}
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+static u8 _rtw_mi_check_pending_xmitbuf(_adapter *padapter , void *data)
+{
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+
+	return check_pending_xmitbuf(pxmitpriv);
+}
+u8 rtw_mi_check_pending_xmitbuf(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_check_pending_xmitbuf);
+}
+u8 rtw_mi_buddy_check_pending_xmitbuf(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_check_pending_xmitbuf);
+}
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+static u8 _rtw_mi_dequeue_writeport(_adapter *padapter , bool exclude_self)
+{
+	int i;
+	u8	queue_empty = _TRUE;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+
+			if ((exclude_self) && (iface == padapter))
+				continue;
+
+			queue_empty &= _dequeue_writeport(iface);
+		}
+	}
+	return queue_empty;
+}
+u8 rtw_mi_dequeue_writeport(_adapter *padapter)
+{
+	return _rtw_mi_dequeue_writeport(padapter, _FALSE);
+}
+u8 rtw_mi_buddy_dequeue_writeport(_adapter *padapter)
+{
+	return _rtw_mi_dequeue_writeport(padapter, _TRUE);
+}
+#endif
+static void _rtw_mi_adapter_reset(_adapter *padapter , u8 exclude_self)
+{
+	int i;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (dvobj->padapters[i]) {
+			if ((exclude_self) && (dvobj->padapters[i] == padapter))
+				continue;
+			dvobj->padapters[i] = NULL;
+		}
+	}
+}
+
+void rtw_mi_adapter_reset(_adapter *padapter)
+{
+	_rtw_mi_adapter_reset(padapter, _FALSE);
+}
+
+void rtw_mi_buddy_adapter_reset(_adapter *padapter)
+{
+	_rtw_mi_adapter_reset(padapter, _TRUE);
+}
+
+static u8 _rtw_mi_dynamic_check_timer_handlder(_adapter *adapter, void *data)
+{
+	rtw_iface_dynamic_check_timer_handlder(adapter);
+	return _TRUE;
+}
+u8 rtw_mi_dynamic_check_timer_handlder(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_dynamic_check_timer_handlder);
+}
+u8 rtw_mi_buddy_dynamic_check_timer_handlder(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_dynamic_check_timer_handlder);
+}
+
+static u8 _rtw_mi_dev_unload(_adapter *adapter, void *data)
+{
+	rtw_dev_unload(adapter);
+	return _TRUE;
+}
+u8 rtw_mi_dev_unload(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_dev_unload);
+}
+u8 rtw_mi_buddy_dev_unload(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_dev_unload);
+}
+
+static u8 _rtw_mi_dynamic_chk_wk_hdl(_adapter *adapter, void *data)
+{
+	rtw_iface_dynamic_chk_wk_hdl(adapter);
+	return _TRUE;
+}
+u8 rtw_mi_dynamic_chk_wk_hdl(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_dynamic_chk_wk_hdl);
+}
+u8 rtw_mi_buddy_dynamic_chk_wk_hdl(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_dynamic_chk_wk_hdl);
+}
+
+static u8 _rtw_mi_os_xmit_schedule(_adapter *adapter, void *data)
+{
+	rtw_os_xmit_schedule(adapter);
+	return _TRUE;
+}
+u8 rtw_mi_os_xmit_schedule(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_os_xmit_schedule);
+}
+u8 rtw_mi_buddy_os_xmit_schedule(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_os_xmit_schedule);
+}
+
+static u8 _rtw_mi_report_survey_event(_adapter *adapter, void *data)
+{
+	union recv_frame *precv_frame = (union recv_frame *)data;
+
+	report_survey_event(adapter, precv_frame);
+	return _TRUE;
+}
+u8 rtw_mi_report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
+{
+	return _rtw_mi_process(padapter, _FALSE, precv_frame, _rtw_mi_report_survey_event);
+}
+u8 rtw_mi_buddy_report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
+{
+	return _rtw_mi_process(padapter, _TRUE, precv_frame, _rtw_mi_report_survey_event);
+}
+
+static u8 _rtw_mi_sreset_adapter_hdl(_adapter *adapter, void *data)
+{
+	u8 bstart = *(u8 *)data;
+
+	if (bstart)
+		sreset_start_adapter(adapter);
+	else
+		sreset_stop_adapter(adapter);
+	return _TRUE;
+}
+u8 rtw_mi_sreset_adapter_hdl(_adapter *padapter, u8 bstart)
+{
+	u8 in_data = bstart;
+
+	return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_sreset_adapter_hdl);
+}
+u8 rtw_mi_buddy_sreset_adapter_hdl(_adapter *padapter, u8 bstart)
+{
+	u8 in_data = bstart;
+
+	return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_sreset_adapter_hdl);
+}
+static u8 _rtw_mi_tx_beacon_hdl(_adapter *adapter, void *data)
+{
+	if ((MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))
+		&& check_fwstate(&adapter->mlmepriv, WIFI_ASOC_STATE) == _TRUE
+	) {
+		adapter->mlmepriv.update_bcn = _TRUE;
+#ifndef CONFIG_INTERRUPT_BASED_TXBCN
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+		tx_beacon_hdl(adapter, NULL);
+#endif
+#endif
+	}
+	return _TRUE;
+}
+u8 rtw_mi_tx_beacon_hdl(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_tx_beacon_hdl);
+}
+u8 rtw_mi_buddy_tx_beacon_hdl(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_sreset_adapter_hdl);
+}
+
+static u8 _rtw_mi_set_tx_beacon_cmd(_adapter *adapter, void *data)
+{
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+
+	if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
+		if (pmlmepriv->update_bcn == _TRUE)
+			set_tx_beacon_cmd(adapter);
+	}
+	return _TRUE;
+}
+u8 rtw_mi_set_tx_beacon_cmd(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_set_tx_beacon_cmd);
+}
+u8 rtw_mi_buddy_set_tx_beacon_cmd(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_set_tx_beacon_cmd);
+}
+
+#ifdef CONFIG_P2P
+static u8 _rtw_mi_p2p_chk_state(_adapter *adapter, void *data)
+{
+	struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
+	enum P2P_STATE state = *(enum P2P_STATE *)data;
+
+	return rtw_p2p_chk_state(pwdinfo, state);
+}
+u8 rtw_mi_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state)
+{
+	u8 in_data = p2p_state;
+
+	return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_p2p_chk_state);
+}
+u8 rtw_mi_buddy_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state)
+{
+	u8 in_data  = p2p_state;
+
+	return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_p2p_chk_state);
+}
+static u8 _rtw_mi_stay_in_p2p_mode(_adapter *adapter, void *data)
+{
+	struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
+
+	if (rtw_p2p_role(pwdinfo) != P2P_ROLE_DISABLE)
+		return _TRUE;
+	return _FALSE;
+}
+u8 rtw_mi_stay_in_p2p_mode(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_stay_in_p2p_mode);
+}
+u8 rtw_mi_buddy_stay_in_p2p_mode(_adapter *padapter)
+{
+	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_stay_in_p2p_mode);
+}
+#endif /*CONFIG_P2P*/
+
+_adapter *rtw_get_iface_by_id(_adapter *padapter, u8 iface_id)
+{
+	_adapter *iface = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	if ((padapter == NULL) || (iface_id >= CONFIG_IFACE_NUMBER)) {
+		rtw_warn_on(1);
+		return iface;
+	}
+
+	return  dvobj->padapters[iface_id];
+}
+
+_adapter *rtw_get_iface_by_macddr(_adapter *padapter, const u8 *mac_addr)
+{
+	int i;
+	_adapter *iface = NULL;
+	u8 bmatch = _FALSE;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && (_rtw_memcmp(mac_addr, adapter_mac_addr(iface), ETH_ALEN))) {
+			bmatch = _TRUE;
+			break;
+		}
+	}
+	if (bmatch)
+		return iface;
+	else
+		return NULL;
+}
+
+_adapter *rtw_get_iface_by_hwport(_adapter *padapter, u8 hw_port)
+{
+	int i;
+	_adapter *iface = NULL;
+	u8 bmatch = _FALSE;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && (hw_port == iface->hw_port)) {
+			bmatch = _TRUE;
+			break;
+		}
+	}
+	if (bmatch)
+		return iface;
+	else
+		return NULL;
+}
+
+/*#define CONFIG_SKB_ALLOCATED*/
+#define DBG_SKB_PROCESS
+#ifdef DBG_SKB_PROCESS
+void rtw_dbg_skb_process(_adapter *padapter, union recv_frame *precvframe, union recv_frame *pcloneframe)
+{
+	_pkt *pkt_copy, *pkt_org;
+
+	pkt_org = precvframe->u.hdr.pkt;
+	pkt_copy = pcloneframe->u.hdr.pkt;
+	/*
+		RTW_INFO("%s ===== ORG SKB =====\n", __func__);
+		RTW_INFO(" SKB head(%p)\n", pkt_org->head);
+		RTW_INFO(" SKB data(%p)\n", pkt_org->data);
+		RTW_INFO(" SKB tail(%p)\n", pkt_org->tail);
+		RTW_INFO(" SKB end(%p)\n", pkt_org->end);
+
+		RTW_INFO(" recv frame head(%p)\n", precvframe->u.hdr.rx_head);
+		RTW_INFO(" recv frame data(%p)\n", precvframe->u.hdr.rx_data);
+		RTW_INFO(" recv frame tail(%p)\n", precvframe->u.hdr.rx_tail);
+		RTW_INFO(" recv frame end(%p)\n", precvframe->u.hdr.rx_end);
+
+		RTW_INFO("%s ===== COPY SKB =====\n", __func__);
+		RTW_INFO(" SKB head(%p)\n", pkt_copy->head);
+		RTW_INFO(" SKB data(%p)\n", pkt_copy->data);
+		RTW_INFO(" SKB tail(%p)\n", pkt_copy->tail);
+		RTW_INFO(" SKB end(%p)\n", pkt_copy->end);
+
+		RTW_INFO(" recv frame head(%p)\n", pcloneframe->u.hdr.rx_head);
+		RTW_INFO(" recv frame data(%p)\n", pcloneframe->u.hdr.rx_data);
+		RTW_INFO(" recv frame tail(%p)\n", pcloneframe->u.hdr.rx_tail);
+		RTW_INFO(" recv frame end(%p)\n", pcloneframe->u.hdr.rx_end);
+	*/
+	/*
+		RTW_INFO("%s => recv_frame adapter(%p,%p)\n", __func__, precvframe->u.hdr.adapter, pcloneframe->u.hdr.adapter);
+		RTW_INFO("%s => recv_frame dev(%p,%p)\n", __func__, pkt_org->dev , pkt_copy->dev);
+		RTW_INFO("%s => recv_frame len(%d,%d)\n", __func__, precvframe->u.hdr.len, pcloneframe->u.hdr.len);
+	*/
+	if (precvframe->u.hdr.len != pcloneframe->u.hdr.len)
+		RTW_INFO("%s [WARN]  recv_frame length(%d:%d) compare failed\n", __func__, precvframe->u.hdr.len, pcloneframe->u.hdr.len);
+
+	if (_rtw_memcmp(&precvframe->u.hdr.attrib, &pcloneframe->u.hdr.attrib, sizeof(struct rx_pkt_attrib)) == _FALSE)
+		RTW_INFO("%s [WARN]  recv_frame attrib compare failed\n", __func__);
+
+	if (_rtw_memcmp(precvframe->u.hdr.rx_data, pcloneframe->u.hdr.rx_data, precvframe->u.hdr.len) == _FALSE)
+		RTW_INFO("%s [WARN]  recv_frame rx_data compare failed\n", __func__);
+
+}
+#endif
+
+static s32 _rtw_mi_buddy_clone_bcmc_packet(_adapter *adapter, union recv_frame *precvframe, u8 *pphy_status, union recv_frame *pcloneframe)
+{
+	s32 ret = _SUCCESS;
+	u8 *pbuf = precvframe->u.hdr.rx_data;
+	struct rx_pkt_attrib *pattrib = NULL;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(adapter);
+
+	if (pcloneframe) {
+		pcloneframe->u.hdr.adapter = adapter;
+
+		_rtw_init_listhead(&pcloneframe->u.hdr.list);
+		pcloneframe->u.hdr.precvbuf = NULL;	/*can't access the precvbuf for new arch.*/
+		pcloneframe->u.hdr.len = 0;
+
+		_rtw_memcpy(&pcloneframe->u.hdr.attrib, &precvframe->u.hdr.attrib, sizeof(struct rx_pkt_attrib));
+
+		pattrib = &pcloneframe->u.hdr.attrib;
+#ifdef CONFIG_SKB_ALLOCATED
+		if (rtw_os_alloc_recvframe(adapter, pcloneframe, pbuf, NULL) == _SUCCESS)
+#else
+		if (rtw_os_recvframe_duplicate_skb(adapter, pcloneframe, precvframe->u.hdr.pkt) == _SUCCESS)
+#endif
+		{
+#ifdef CONFIG_SKB_ALLOCATED
+			recvframe_put(pcloneframe, pattrib->pkt_len);
+#endif
+
+#ifdef DBG_SKB_PROCESS
+			rtw_dbg_skb_process(adapter, precvframe, pcloneframe);
+#endif
+
+			if (pphy_status)
+				rx_query_phy_status(pcloneframe, pphy_status);
+
+			ret = rtw_recv_entry(pcloneframe);
+		} else {
+			ret = -1;
+			RTW_INFO("%s()-%d: rtw_os_alloc_recvframe() failed!\n", __func__, __LINE__);
+		}
+
+	}
+	return ret;
+}
+
+void rtw_mi_buddy_clone_bcmc_packet(_adapter *padapter, union recv_frame *precvframe, u8 *pphy_status)
+{
+	int i;
+	s32 ret = _SUCCESS;
+	_adapter *iface = NULL;
+	union recv_frame *pcloneframe = NULL;
+	struct recv_priv *precvpriv = &padapter->recvpriv;/*primary_padapter*/
+	_queue *pfree_recv_queue = &precvpriv->free_recv_queue;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	u8 *fhead = get_recvframe_data(precvframe);
+	u8 type = GetFrameType(fhead);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface || iface == padapter)
+			continue;
+		if (rtw_is_adapter_up(iface) == _FALSE || iface->registered == 0)
+			continue;
+		if (type == WIFI_DATA_TYPE && !adapter_allow_bmc_data_rx(iface))
+			continue;
+
+		pcloneframe = rtw_alloc_recvframe(pfree_recv_queue);
+		if (pcloneframe) {
+			ret = _rtw_mi_buddy_clone_bcmc_packet(iface, precvframe, pphy_status, pcloneframe);
+			if (_SUCCESS != ret) {
+				if (ret == -1)
+					rtw_free_recvframe(pcloneframe, pfree_recv_queue);
+				/*RTW_INFO(ADPT_FMT"-clone BC/MC frame failed\n", ADPT_ARG(iface));*/
+			}
+		}
+	}
+
+}
+
+#ifdef CONFIG_PCI_HCI
+/*API be created temporary for MI, caller is interrupt-handler, PCIE's interrupt handler cannot apply to multi-AP*/
+_adapter *rtw_mi_get_ap_adapter(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	int i;
+	_adapter *iface = NULL;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE
+		    && check_fwstate(&iface->mlmepriv, WIFI_ASOC_STATE) == _TRUE)
+			break;
+
+	}
+	return iface;
+}
+#endif
+
+void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b)
+{
+#ifdef CONFIG_CONCURRENT_MODE
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+
+	int i;
+	_adapter *iface = NULL;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		if (macid_ctl->iface_bmc[iface->iface_id] != INVALID_SEC_MAC_CAM_ID) {
+			if (macid_ctl->iface_bmc[iface->iface_id] == camid_a)
+				macid_ctl->iface_bmc[iface->iface_id] = camid_b;
+			else if (macid_ctl->iface_bmc[iface->iface_id] == camid_b)
+				macid_ctl->iface_bmc[iface->iface_id] = camid_a;
+			iface->securitypriv.dot118021x_bmc_cam_id  = macid_ctl->iface_bmc[iface->iface_id];
+		}
+	}
+#endif
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme.c
index bd5ac1106328..9b9e5982cca8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,61 +12,96 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_MLME_C_
 
 #include <hal_data.h>
 
 extern void indicate_wx_scan_complete_event(_adapter *padapter);
-extern u8 rtw_do_join(_adapter * padapter);
+extern u8 rtw_do_join(_adapter *padapter);
+
+
+void rtw_init_mlme_timer(_adapter *padapter)
+{
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	rtw_init_timer(&(pmlmepriv->assoc_timer), padapter, rtw_join_timeout_handler, padapter);
+	rtw_init_timer(&(pmlmepriv->scan_to_timer), padapter, rtw_scan_timeout_handler, padapter);
+
+#ifdef CONFIG_DFS_MASTER
+	rtw_init_timer(&(pmlmepriv->dfs_master_timer), padapter, rtw_dfs_master_timer_hdl, padapter);
+#endif
+
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
+	rtw_init_timer(&(pmlmepriv->set_scan_deny_timer), padapter, rtw_set_scan_deny_timer_hdl, padapter);
+#endif
 
+#ifdef RTK_DMP_PLATFORM
+	_init_workitem(&(pmlmepriv->Linkup_workitem), Linkup_workitem_callback, padapter);
+	_init_workitem(&(pmlmepriv->Linkdown_workitem), Linkdown_workitem_callback, padapter);
+#endif
+}
 
-sint	_rtw_init_mlme_priv (_adapter* padapter)
+sint	_rtw_init_mlme_priv(_adapter *padapter)
 {
 	sint	i;
 	u8	*pbuf;
 	struct wlan_network	*pnetwork;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	sint	res = _SUCCESS;
 
-_func_enter_;
 
-	// We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc().
-	//_rtw_memset((u8 *)pmlmepriv, 0, sizeof(struct mlme_priv));
+	/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
+	/* _rtw_memset((u8 *)pmlmepriv, 0, sizeof(struct mlme_priv)); */
+
+
+	/*qos_priv*/
+	/*pmlmepriv->qospriv.qos_option = pregistrypriv->wmm_enable;*/
+
+	/*ht_priv*/
+#ifdef CONFIG_80211N_HT
+	pmlmepriv->htpriv.ampdu_enable = _FALSE;/*set to disabled*/
+#endif
 
 	pmlmepriv->nic_hdl = (u8 *)padapter;
 
 	pmlmepriv->pscanned = NULL;
-	pmlmepriv->fw_state = WIFI_STATION_STATE; // Must sync with rtw_wdev_alloc() 
-	                                          // wdev->iftype = NL80211_IFTYPE_STATION
+	/*pmlmepriv->fw_state = WIFI_STATION_STATE; */ /*Must sync with rtw_wdev_alloc()*/
+	/*init_fwstate(pmlmepriv, WIFI_STATION_STATE);*/
+	init_fwstate(pmlmepriv, WIFI_NULL_STATE);/*assigned interface role(STA/AP) must after execute set_opmode*/
+
+	/* wdev->iftype = NL80211_IFTYPE_STATION*/
 	pmlmepriv->cur_network.network.InfrastructureMode = Ndis802_11AutoUnknown;
-	pmlmepriv->scan_mode=SCAN_ACTIVE;// 1: active, 0: pasive. Maybe someday we should rename this varable to "active_mode" (Jeff)
+	pmlmepriv->scan_mode = SCAN_ACTIVE; /* 1: active, 0: pasive. Maybe someday we should rename this varable to "active_mode" (Jeff) */
 
-	_rtw_spinlock_init(&(pmlmepriv->lock));	
+	_rtw_spinlock_init(&(pmlmepriv->lock));
 	_rtw_init_queue(&(pmlmepriv->free_bss_pool));
 	_rtw_init_queue(&(pmlmepriv->scanned_queue));
 
 	set_scanned_network_val(pmlmepriv, 0);
-	
-	_rtw_memset(&pmlmepriv->assoc_ssid,0,sizeof(NDIS_802_11_SSID));
 
-	pbuf = rtw_zvmalloc(MAX_BSS_CNT * (sizeof(struct wlan_network)));
-	
-	if (pbuf == NULL){
-		res=_FAIL;
+	_rtw_memset(&pmlmepriv->assoc_ssid, 0, sizeof(NDIS_802_11_SSID));
+
+	if (padapter->registrypriv.max_bss_cnt != 0)
+		pmlmepriv->max_bss_cnt = padapter->registrypriv.max_bss_cnt;
+	else if (rfctl->max_chan_nums <= MAX_CHANNEL_NUM_2G)
+		pmlmepriv->max_bss_cnt = MAX_BSS_CNT;
+	else
+		pmlmepriv->max_bss_cnt = MAX_BSS_CNT + MAX_BSS_CNT;
+
+
+	pbuf = rtw_zvmalloc(pmlmepriv->max_bss_cnt * (sizeof(struct wlan_network)));
+
+	if (pbuf == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 	pmlmepriv->free_bss_buf = pbuf;
-		
+
 	pnetwork = (struct wlan_network *)pbuf;
-	
-	for(i = 0; i < MAX_BSS_CNT; i++)
-	{		
+
+	for (i = 0; i < pmlmepriv->max_bss_cnt; i++) {
 		_rtw_init_listhead(&(pnetwork->list));
 
 		rtw_list_insert_tail(&(pnetwork->list), &(pmlmepriv->free_bss_pool.queue));
@@ -73,44 +109,56 @@ _func_enter_;
 		pnetwork++;
 	}
 
-	//allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf
+	/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
 
 	rtw_clear_scan_deny(padapter);
 #ifdef CONFIG_ARP_KEEP_ALIVE
 	pmlmepriv->bGetGateway = 0;
+	pmlmepriv->GetGatewayTryCnt = 0;
 #endif
 
 #ifdef CONFIG_LAYER2_ROAMING
-	#define RTW_ROAM_SCAN_RESULT_EXP_MS 5*1000
-	#define RTW_ROAM_RSSI_DIFF_TH 10
-	#define RTW_ROAM_SCAN_INTERVAL_MS 10*1000
+#define RTW_ROAM_SCAN_RESULT_EXP_MS (5*1000)
+#define RTW_ROAM_RSSI_DIFF_TH 10
+#define RTW_ROAM_SCAN_INTERVAL_MS (10*1000)
+#define RTW_ROAM_RSSI_THRESHOLD 70
 
 	pmlmepriv->roam_flags = 0
-		| RTW_ROAM_ON_EXPIRED
-		#ifdef CONFIG_LAYER2_ROAMING_RESUME
-		| RTW_ROAM_ON_RESUME
-		#endif
-		#ifdef CONFIG_LAYER2_ROAMING_ACTIVE
-		| RTW_ROAM_ACTIVE
-		#endif
-		;
+				| RTW_ROAM_ON_EXPIRED
+#ifdef CONFIG_LAYER2_ROAMING_RESUME
+				| RTW_ROAM_ON_RESUME
+#endif
+#ifdef CONFIG_LAYER2_ROAMING_ACTIVE
+				| RTW_ROAM_ACTIVE
+#endif
+				;
 
 	pmlmepriv->roam_scanr_exp_ms = RTW_ROAM_SCAN_RESULT_EXP_MS;
 	pmlmepriv->roam_rssi_diff_th = RTW_ROAM_RSSI_DIFF_TH;
 	pmlmepriv->roam_scan_int_ms = RTW_ROAM_SCAN_INTERVAL_MS;
+	pmlmepriv->roam_rssi_threshold = RTW_ROAM_RSSI_THRESHOLD;
+	pmlmepriv->need_to_roam = _FALSE;
 #endif /* CONFIG_LAYER2_ROAMING */
 
+#ifdef CONFIG_RTW_80211R
+	rtw_ft_info_init(&pmlmepriv->ft_roam);
+#endif
+#ifdef CONFIG_LAYER2_ROAMING
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+	rtw_roam_nb_info_init(padapter);
+	pmlmepriv->ch_cnt = 0;
+#endif	
+#endif
 	rtw_init_mlme_timer(padapter);
 
 exit:
 
-_func_exit_;
 
 	return res;
-}	
+}
 
-void rtw_mfree_mlme_priv_lock (struct mlme_priv *pmlmepriv);
-void rtw_mfree_mlme_priv_lock (struct mlme_priv *pmlmepriv)
+void rtw_mfree_mlme_priv_lock(struct mlme_priv *pmlmepriv);
+void rtw_mfree_mlme_priv_lock(struct mlme_priv *pmlmepriv)
 {
 	_rtw_spinlock_free(&pmlmepriv->lock);
 	_rtw_spinlock_free(&(pmlmepriv->free_bss_pool.lock));
@@ -119,24 +167,23 @@ void rtw_mfree_mlme_priv_lock (struct mlme_priv *pmlmepriv)
 
 static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
 {
-	if(*ppie)
-	{		
+	if (*ppie) {
 		rtw_mfree(*ppie, *plen);
 		*plen = 0;
-		*ppie=NULL;
-	}	
+		*ppie = NULL;
+	}
 }
 
 void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
 {
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
 	rtw_buf_free(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len);
 	rtw_buf_free(&pmlmepriv->assoc_rsp, &pmlmepriv->assoc_rsp_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->wps_beacon_ie, &pmlmepriv->wps_beacon_ie_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->wps_probe_req_ie, &pmlmepriv->wps_probe_req_ie_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->wps_probe_resp_ie, &pmlmepriv->wps_probe_resp_ie_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->wps_assoc_resp_ie, &pmlmepriv->wps_assoc_resp_ie_len);
-	
+
 	rtw_free_mlme_ie_data(&pmlmepriv->p2p_beacon_ie, &pmlmepriv->p2p_beacon_ie_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->p2p_probe_req_ie, &pmlmepriv->p2p_probe_req_ie_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->p2p_probe_resp_ie, &pmlmepriv->p2p_probe_resp_ie_len);
@@ -145,7 +192,7 @@ void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
 	rtw_free_mlme_ie_data(&pmlmepriv->p2p_assoc_resp_ie, &pmlmepriv->p2p_assoc_resp_ie_len);
 #endif
 
-#if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)	
+#if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
 	rtw_free_mlme_ie_data(&pmlmepriv->wfd_beacon_ie, &pmlmepriv->wfd_beacon_ie_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_req_ie, &pmlmepriv->wfd_probe_req_ie_len);
 	rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_resp_ie, &pmlmepriv->wfd_probe_resp_ie_len);
@@ -154,6 +201,9 @@ void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
 	rtw_free_mlme_ie_data(&pmlmepriv->wfd_assoc_resp_ie, &pmlmepriv->wfd_assoc_resp_ie_len);
 #endif
 
+#ifdef CONFIG_RTW_80211R
+	rtw_free_mlme_ie_data(&pmlmepriv->auth_rsp, &pmlmepriv->auth_rsp_len);
+#endif
 }
 
 #if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
@@ -172,11 +222,11 @@ int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_
 	if (wfd_info->wfd_enable == _TRUE)
 		goto success; /* WFD IE is build by self */
 
-	if (!ie && !ie_len) {
+	if (!ie && !ie_len)
 		clear = 1;
-	} else if (!ie || !ie_len) {
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" type:%u, ie:%p, ie_len:%u"
-			, FUNC_ADPT_ARG(adapter), type, ie, ie_len);
+	else if (!ie || !ie_len) {
+		RTW_PRINT(FUNC_ADPT_FMT" type:%u, ie:%p, ie_len:%u"
+			  , FUNC_ADPT_ARG(adapter), type, ie, ie_len);
 		rtw_warn_on(1);
 		goto exit;
 	}
@@ -207,8 +257,8 @@ int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_
 		t_ie_len = &mlme->wfd_assoc_resp_ie_len;
 		break;
 	default:
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" unsupported type:%u"
-			, FUNC_ADPT_ARG(adapter), type);
+		RTW_PRINT(FUNC_ADPT_FMT" unsupported type:%u"
+			  , FUNC_ADPT_ARG(adapter), type);
 		rtw_warn_on(1);
 		goto exit;
 	}
@@ -223,7 +273,7 @@ int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_
 	if (!clear) {
 		*t_ie = rtw_malloc(ie_len);
 		if (*t_ie == NULL) {
-			DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" type:%u, rtw_malloc() fail\n"
+			RTW_ERR(FUNC_ADPT_FMT" type:%u, rtw_malloc() fail\n"
 				, FUNC_ADPT_ARG(adapter), type);
 			goto exit;
 		}
@@ -239,7 +289,7 @@ int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_
 		if (attr_content && attr_contentlen) {
 			if (RTW_GET_BE16(attr_content + 2) != wfd_info->rtsp_ctrlport) {
 				wfd_info->rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
-				DBG_871X(FUNC_ADPT_FMT" type:%u, RTSP CTRL port = %u\n"
+				RTW_INFO(FUNC_ADPT_FMT" type:%u, RTSP CTRL port = %u\n"
 					, FUNC_ADPT_ARG(adapter), type, wfd_info->rtsp_ctrlport);
 			}
 		}
@@ -253,44 +303,41 @@ exit:
 }
 #endif /* defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211) */
 
-void _rtw_free_mlme_priv (struct mlme_priv *pmlmepriv)
+void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
 {
-_func_enter_;
-	if (NULL == pmlmepriv){
+	_adapter *adapter = mlme_to_adapter(pmlmepriv);
+	if (NULL == pmlmepriv) {
 		rtw_warn_on(1);
 		goto exit;
 	}
 	rtw_free_mlme_priv_ie_data(pmlmepriv);
 
-	if(pmlmepriv){
-		rtw_mfree_mlme_priv_lock (pmlmepriv);
+	if (pmlmepriv) {
+		rtw_mfree_mlme_priv_lock(pmlmepriv);
 
-		if (pmlmepriv->free_bss_buf) {
-			rtw_vmfree(pmlmepriv->free_bss_buf, MAX_BSS_CNT * sizeof(struct wlan_network));
-		}
+		if (pmlmepriv->free_bss_buf)
+			rtw_vmfree(pmlmepriv->free_bss_buf, pmlmepriv->max_bss_cnt * sizeof(struct wlan_network));
 	}
 exit:
-_func_exit_;	
+	return;
 }
 
 sint	_rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork)
 {
 	_irqL irqL;
 
-_func_enter_;	
 
 	if (pnetwork == NULL)
 		goto exit;
-	
+
 	_enter_critical_bh(&queue->lock, &irqL);
 
 	rtw_list_insert_tail(&pnetwork->list, &queue->queue);
 
 	_exit_critical_bh(&queue->lock, &irqL);
 
-exit:	
+exit:
 
-_func_exit_;		
 
 	return _SUCCESS;
 }
@@ -302,75 +349,69 @@ struct	wlan_network *_rtw_dequeue_network(_queue *queue)
 
 	struct wlan_network *pnetwork;
 
-_func_enter_;	
 
 	_enter_critical_bh(&queue->lock, &irqL);
 
 	if (_rtw_queue_empty(queue) == _TRUE)
 
 		pnetwork = NULL;
-	
+
 	else
 	{
 		pnetwork = LIST_CONTAINOR(get_next(&queue->queue), struct wlan_network, list);
-		
+
 		rtw_list_delete(&(pnetwork->list));
 	}
-	
+
 	_exit_critical_bh(&queue->lock, &irqL);
 
-_func_exit_;		
 
 	return pnetwork;
 }
 */
 
-struct	wlan_network *_rtw_alloc_network(struct	mlme_priv *pmlmepriv )//(_queue *free_queue)
+struct	wlan_network *_rtw_alloc_network(struct	mlme_priv *pmlmepriv) /* (_queue *free_queue) */
 {
 	_irqL	irqL;
-	struct	wlan_network	*pnetwork;	
+	struct	wlan_network	*pnetwork;
 	_queue *free_queue = &pmlmepriv->free_bss_pool;
-	_list* plist = NULL;
-	
-_func_enter_;	
+	_list *plist = NULL;
+
 
 	_enter_critical_bh(&free_queue->lock, &irqL);
-	
+
 	if (_rtw_queue_empty(free_queue) == _TRUE) {
-		pnetwork=NULL;
+		pnetwork = NULL;
 		goto exit;
 	}
 	plist = get_next(&(free_queue->queue));
-	
+
 	pnetwork = LIST_CONTAINOR(plist , struct wlan_network, list);
-	
+
 	rtw_list_delete(&pnetwork->list);
-	
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_, ("_rtw_alloc_network: ptr=%p\n", plist));
+
 	pnetwork->network_type = 0;
 	pnetwork->fixed = _FALSE;
 	pnetwork->last_scanned = rtw_get_current_time();
-	pnetwork->aid=0;	
-	pnetwork->join_res=0;
+	pnetwork->aid = 0;
+	pnetwork->join_res = 0;
+
+	pmlmepriv->num_of_scanned++;
 
-	pmlmepriv->num_of_scanned ++;
-	
 exit:
 	_exit_critical_bh(&free_queue->lock, &irqL);
 
-_func_exit_;		
 
-	return pnetwork;	
+	return pnetwork;
 }
 
-void _rtw_free_network(struct	mlme_priv *pmlmepriv ,struct wlan_network *pnetwork, u8 isfreeall)
+void _rtw_free_network(struct	mlme_priv *pmlmepriv , struct wlan_network *pnetwork, u8 isfreeall)
 {
 	u32 delta_time;
 	u32 lifetime = SCANQUEUE_LIFETIME;
-	_irqL irqL;	
+	_irqL irqL;
 	_queue *free_queue = &(pmlmepriv->free_bss_pool);
-	
-_func_enter_;		
+
 
 	if (pnetwork == NULL)
 		goto exit;
@@ -378,34 +419,31 @@ _func_enter_;
 	if (pnetwork->fixed == _TRUE)
 		goto exit;
 
-	if ( (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)==_TRUE ) || 
-		(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)==_TRUE ) )
+	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
 		lifetime = 1;
 
-	if(!isfreeall)
-	{
+	if (!isfreeall) {
 		delta_time = (u32) rtw_get_passing_time_ms(pnetwork->last_scanned);
-		if(delta_time < lifetime)// unit:msec
+		if (delta_time < lifetime) /* unit:msec */
 			goto exit;
 	}
 
 	_enter_critical_bh(&free_queue->lock, &irqL);
-	
+
 	rtw_list_delete(&(pnetwork->list));
 
-	rtw_list_insert_tail(&(pnetwork->list),&(free_queue->queue));
-		
-	pmlmepriv->num_of_scanned --;
-	
+	rtw_list_insert_tail(&(pnetwork->list), &(free_queue->queue));
+
+	pmlmepriv->num_of_scanned--;
+
+
+	/* RTW_INFO("_rtw_free_network:SSID=%s\n", pnetwork->network.Ssid.Ssid); */
 
-	//DBG_871X("_rtw_free_network:SSID=%s\n", pnetwork->network.Ssid.Ssid);
-	
 	_exit_critical_bh(&free_queue->lock, &irqL);
-	
-exit:		
-	
-_func_exit_;			
 
+exit:
+	return;
 }
 
 void _rtw_free_network_nolock(struct	mlme_priv *pmlmepriv, struct wlan_network *pnetwork)
@@ -413,7 +451,6 @@ void _rtw_free_network_nolock(struct	mlme_priv *pmlmepriv, struct wlan_network *
 
 	_queue *free_queue = &(pmlmepriv->free_bss_pool);
 
-_func_enter_;		
 
 	if (pnetwork == NULL)
 		goto exit;
@@ -421,129 +458,69 @@ _func_enter_;
 	if (pnetwork->fixed == _TRUE)
 		goto exit;
 
-	//_enter_critical(&free_queue->lock, &irqL);
-	
+	/* _enter_critical(&free_queue->lock, &irqL); */
+
 	rtw_list_delete(&(pnetwork->list));
 
 	rtw_list_insert_tail(&(pnetwork->list), get_list_head(free_queue));
-		
-	pmlmepriv->num_of_scanned --;
-	
-	//_exit_critical(&free_queue->lock, &irqL);
-	
-exit:		
-
-_func_exit_;			
 
-}
-
-
-/*
-	return the wlan_network with the matching addr
-
-	Shall be calle under atomic context... to avoid possible racing condition...
-*/
-struct wlan_network *_rtw_find_network(_queue *scanned_queue, u8 *addr)
-{
-
-	//_irqL irqL;
-	_list	*phead, *plist;
-	struct	wlan_network *pnetwork = NULL;
-	u8 zero_addr[ETH_ALEN] = {0,0,0,0,0,0};
-	
-_func_enter_;	
-
-	if(_rtw_memcmp(zero_addr, addr, ETH_ALEN)){
-		pnetwork=NULL;
-		goto exit;
-	}
-	
-	//_enter_critical_bh(&scanned_queue->lock, &irqL);
-	
-	phead = get_list_head(scanned_queue);
-	plist = get_next(phead);
-	 
-	while (plist != phead)
-       {
-                pnetwork = LIST_CONTAINOR(plist, struct wlan_network ,list);
-
-		if (_rtw_memcmp(addr, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE)
-                        break;
-		
-		plist = get_next(plist);
-        }
-
-	if(plist == phead)
-		pnetwork = NULL;
+	pmlmepriv->num_of_scanned--;
 
-	//_exit_critical_bh(&scanned_queue->lock, &irqL);
-	
-exit:		
-	
-_func_exit_;		
+	/* _exit_critical(&free_queue->lock, &irqL); */
 
-	return pnetwork;
-	
+exit:
+	return;
 }
 
-
 void _rtw_free_network_queue(_adapter *padapter, u8 isfreeall)
 {
 	_irqL irqL;
 	_list *phead, *plist;
 	struct wlan_network *pnetwork;
-	struct mlme_priv* pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	_queue *scanned_queue = &pmlmepriv->scanned_queue;
 
-_func_enter_;	
-	
+
 
 	_enter_critical_bh(&scanned_queue->lock, &irqL);
 
 	phead = get_list_head(scanned_queue);
 	plist = get_next(phead);
 
-	while (rtw_end_of_queue_search(phead, plist) == _FALSE)
-	{
+	while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
 
 		plist = get_next(plist);
 
-		_rtw_free_network(pmlmepriv,pnetwork, isfreeall);
-		
+		_rtw_free_network(pmlmepriv, pnetwork, isfreeall);
+
 	}
 
 	_exit_critical_bh(&scanned_queue->lock, &irqL);
-	
-_func_exit_;		
+
 
 }
 
 
 
 
-sint rtw_if_up(_adapter *padapter)	{
+sint rtw_if_up(_adapter *padapter)
+{
 
 	sint res;
-_func_enter_;		
 
 	if (RTW_CANNOT_RUN(padapter) ||
-		(check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE)) {
-		RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_, ("rtw_if_up:bDriverStopped(%s) OR bSurpriseRemoved(%s)"
-			, rtw_is_drv_stopped(padapter)?"True":"False"
-			, rtw_is_surprise_removed(padapter)?"True":"False"));
-		res=_FALSE;
-	}
-	else
-		res=  _TRUE;
-	
-_func_exit_;
+	    (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE)) {
+		res = _FALSE;
+	} else
+		res =  _TRUE;
+
 	return res;
 }
 
 
-void rtw_generate_random_ibss(u8* pibss)
+void rtw_generate_random_ibss(u8 *pibss)
 {
 	*((u32 *)(&pibss[2])) = rtw_random32();
 	pibss[0] = 0x02; /* in ad-hoc mode local bit must set to 1 */
@@ -553,56 +530,47 @@ void rtw_generate_random_ibss(u8* pibss)
 
 u8 *rtw_get_capability_from_ie(u8 *ie)
 {
-	return (ie + 8 + 2);
+	return ie + 8 + 2;
 }
 
 
 u16 rtw_get_capability(WLAN_BSSID_EX *bss)
 {
 	u16	val;
-_func_enter_;	
 
-	_rtw_memcpy((u8 *)&val, rtw_get_capability_from_ie(bss->IEs), 2); 
+	_rtw_memcpy((u8 *)&val, rtw_get_capability_from_ie(bss->IEs), 2);
 
-_func_exit_;		
 	return le16_to_cpu(val);
 }
 
 u8 *rtw_get_timestampe_from_ie(u8 *ie)
 {
-	return (ie + 0);	
+	return ie + 0;
 }
 
 u8 *rtw_get_beacon_interval_from_ie(u8 *ie)
 {
-	return (ie + 8);	
+	return ie + 8;
 }
 
 
-int	rtw_init_mlme_priv (_adapter *padapter)//(struct	mlme_priv *pmlmepriv)
+int	rtw_init_mlme_priv(_adapter *padapter) /* (struct	mlme_priv *pmlmepriv) */
 {
 	int	res;
-_func_enter_;	
-	res = _rtw_init_mlme_priv(padapter);// (pmlmepriv);
-_func_exit_;	
+	res = _rtw_init_mlme_priv(padapter);/* (pmlmepriv); */
 	return res;
 }
 
-void rtw_free_mlme_priv (struct mlme_priv *pmlmepriv)
+void rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
 {
-_func_enter_;
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("rtw_free_mlme_priv\n"));
-	_rtw_free_mlme_priv (pmlmepriv);
-_func_exit_;	
+	_rtw_free_mlme_priv(pmlmepriv);
 }
 
 int	rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork);
 int	rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork)
 {
 	int	res;
-_func_enter_;		
 	res = _rtw_enqueue_network(queue, pnetwork);
-_func_exit_;		
 	return res;
 }
 
@@ -610,131 +578,158 @@ _func_exit_;
 static struct	wlan_network *rtw_dequeue_network(_queue *queue)
 {
 	struct wlan_network *pnetwork;
-_func_enter_;		
 	pnetwork = _rtw_dequeue_network(queue);
-_func_exit_;		
 	return pnetwork;
 }
 */
 
-struct	wlan_network *rtw_alloc_network(struct	mlme_priv *pmlmepriv );
-struct	wlan_network *rtw_alloc_network(struct	mlme_priv *pmlmepriv )//(_queue	*free_queue)
+struct	wlan_network *rtw_alloc_network(struct	mlme_priv *pmlmepriv);
+struct	wlan_network *rtw_alloc_network(struct	mlme_priv *pmlmepriv) /* (_queue	*free_queue) */
 {
 	struct	wlan_network	*pnetwork;
-_func_enter_;			
 	pnetwork = _rtw_alloc_network(pmlmepriv);
-_func_exit_;			
 	return pnetwork;
 }
 
 void rtw_free_network(struct mlme_priv *pmlmepriv, struct	wlan_network *pnetwork, u8 is_freeall);
-void rtw_free_network(struct mlme_priv *pmlmepriv, struct	wlan_network *pnetwork, u8 is_freeall)//(struct	wlan_network *pnetwork, _queue	*free_queue)
+void rtw_free_network(struct mlme_priv *pmlmepriv, struct	wlan_network *pnetwork, u8 is_freeall)/* (struct	wlan_network *pnetwork, _queue	*free_queue) */
 {
-_func_enter_;		
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("rtw_free_network==> ssid = %s \n\n" , pnetwork->network.Ssid.Ssid));
 	_rtw_free_network(pmlmepriv, pnetwork, is_freeall);
-_func_exit_;
 }
 
-void rtw_free_network_nolock(_adapter * padapter, struct wlan_network *pnetwork );
-void rtw_free_network_nolock(_adapter * padapter, struct wlan_network *pnetwork )
+void rtw_free_network_nolock(_adapter *padapter, struct wlan_network *pnetwork);
+void rtw_free_network_nolock(_adapter *padapter, struct wlan_network *pnetwork)
 {
-_func_enter_;		
-	//RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("rtw_free_network==> ssid = %s \n\n" , pnetwork->network.Ssid.Ssid));
 	_rtw_free_network_nolock(&(padapter->mlmepriv), pnetwork);
 #ifdef CONFIG_IOCTL_CFG80211
 	rtw_cfg80211_unlink_bss(padapter, pnetwork);
-#endif //CONFIG_IOCTL_CFG80211
-_func_exit_;		
+#endif /* CONFIG_IOCTL_CFG80211 */
 }
 
 
-void rtw_free_network_queue(_adapter* dev, u8 isfreeall)
+void rtw_free_network_queue(_adapter *dev, u8 isfreeall)
 {
-_func_enter_;		
 	_rtw_free_network_queue(dev, isfreeall);
-_func_exit_;			
 }
 
-/*
-	return the wlan_network with the matching addr
+struct wlan_network *_rtw_find_network(_queue *scanned_queue, const u8 *addr)
+{
+	_list	*phead, *plist;
+	struct	wlan_network *pnetwork = NULL;
+	u8 zero_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
 
-	Shall be calle under atomic context... to avoid possible racing condition...
-*/
-struct	wlan_network *rtw_find_network(_queue *scanned_queue, u8 *addr)
+	if (_rtw_memcmp(zero_addr, addr, ETH_ALEN)) {
+		pnetwork = NULL;
+		goto exit;
+	}
+
+	phead = get_list_head(scanned_queue);
+	plist = get_next(phead);
+
+	while (plist != phead) {
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network , list);
+
+		if (_rtw_memcmp(addr, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE)
+			break;
+
+		plist = get_next(plist);
+	}
+
+	if (plist == phead)
+		pnetwork = NULL;
+
+exit:
+	return pnetwork;
+}
+
+struct wlan_network *rtw_find_network(_queue *scanned_queue, const u8 *addr)
 {
-	struct	wlan_network *pnetwork = _rtw_find_network(scanned_queue, addr);
+	struct	wlan_network *pnetwork;
+	_irqL irqL;
+
+	 _enter_critical_bh(&scanned_queue->lock, &irqL);
+	pnetwork = _rtw_find_network(scanned_queue, addr);
+	_exit_critical_bh(&scanned_queue->lock, &irqL);
 
 	return pnetwork;
 }
 
 int rtw_is_same_ibss(_adapter *adapter, struct wlan_network *pnetwork)
 {
-	int ret=_TRUE;
+	int ret = _TRUE;
 	struct security_priv *psecuritypriv = &adapter->securitypriv;
 
-	if ( (psecuritypriv->dot11PrivacyAlgrthm != _NO_PRIVACY_ ) &&
-		    ( pnetwork->network.Privacy == 0 ) )
-	{
-		ret=_FALSE;
-	}
-	else if((psecuritypriv->dot11PrivacyAlgrthm == _NO_PRIVACY_ ) &&
-		 ( pnetwork->network.Privacy == 1 ) )
-	{
-		ret=_FALSE;
-	}
+	if ((psecuritypriv->dot11PrivacyAlgrthm != _NO_PRIVACY_) &&
+	    (pnetwork->network.Privacy == 0))
+		ret = _FALSE;
+	else if ((psecuritypriv->dot11PrivacyAlgrthm == _NO_PRIVACY_) &&
+		 (pnetwork->network.Privacy == 1))
+		ret = _FALSE;
 	else
-	{
-		ret=_TRUE;
-	}
-	
+		ret = _TRUE;
+
 	return ret;
-	
+
 }
 
 inline int is_same_ess(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b)
 {
-	//RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("(%s,%d)(%s,%d)\n",
-	//		a->Ssid.Ssid,a->Ssid.SsidLength,b->Ssid.Ssid,b->Ssid.SsidLength));
-	return (a->Ssid.SsidLength == b->Ssid.SsidLength) 
-		&&  _rtw_memcmp(a->Ssid.Ssid, b->Ssid.Ssid, a->Ssid.SsidLength)==_TRUE;
+	return (a->Ssid.SsidLength == b->Ssid.SsidLength)
+	       &&  _rtw_memcmp(a->Ssid.Ssid, b->Ssid.Ssid, a->Ssid.SsidLength) == _TRUE;
 }
 
 int is_same_network(WLAN_BSSID_EX *src, WLAN_BSSID_EX *dst, u8 feature)
 {
-	 u16 s_cap, d_cap;
-	 
-_func_enter_;	
+	u16 s_cap, d_cap;
 
-	if(rtw_bug_check(dst, src, &s_cap, &d_cap)==_FALSE)
-			return _FALSE;
+
+	if (rtw_bug_check(dst, src, &s_cap, &d_cap) == _FALSE)
+		return _FALSE;
 
 	_rtw_memcpy((u8 *)&s_cap, rtw_get_capability_from_ie(src->IEs), 2);
 	_rtw_memcpy((u8 *)&d_cap, rtw_get_capability_from_ie(dst->IEs), 2);
 
-	
+
 	s_cap = le16_to_cpu(s_cap);
 	d_cap = le16_to_cpu(d_cap);
-	
-_func_exit_;			
+
 
 #ifdef CONFIG_P2P
-	if ((feature == 1) && // 1: P2P supported
-		(_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN) == _TRUE)
-		) {
+	if ((feature == 1) && /* 1: P2P supported */
+	    (_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN) == _TRUE)
+	   )
 		return _TRUE;
-	}
 #endif
 
-	return ((src->Ssid.SsidLength == dst->Ssid.SsidLength) &&
-		//	(src->Configuration.DSConfig == dst->Configuration.DSConfig) &&
-			( (_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN)) == _TRUE) &&
-			( (_rtw_memcmp(src->Ssid.Ssid, dst->Ssid.Ssid, src->Ssid.SsidLength)) == _TRUE) &&
-			((s_cap & WLAN_CAPABILITY_IBSS) == 
-			(d_cap & WLAN_CAPABILITY_IBSS)) &&
-			((s_cap & WLAN_CAPABILITY_BSS) == 
-			(d_cap & WLAN_CAPABILITY_BSS)));
-	
+	/* Wi-Fi driver doesn't consider the situation of BCN and ProbRsp sent from the same hidden AP, 
+	  * it considers these two packets are sent from different AP. 
+	  * Therefore, the scan queue may store two scan results of the same hidden AP, likes below.
+	  *
+	  *  index            bssid              ch    RSSI   SdBm  Noise   age          flag             ssid
+	  *    1    00:e0:4c:55:50:01    153   -73     -73        0     7044   [WPS][ESS]     RTK5G
+	  *    3    00:e0:4c:55:50:01    153   -73     -73        0     7044   [WPS][ESS]
+	  *
+	  * Original rules will compare Ssid, SsidLength, MacAddress, s_cap, d_cap at the same time.
+	  * Wi-Fi driver will assume that the BCN and ProbRsp sent from the same hidden AP are the same network
+	  * after we add an additional rule to compare SsidLength and Ssid.
+	  * It means the scan queue will not store two scan results of the same hidden AP, it only store ProbRsp.
+	  * For customer request.
+	  */
+	  
+	if (((_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN)) == _TRUE) &&
+		((s_cap & WLAN_CAPABILITY_IBSS) == (d_cap & WLAN_CAPABILITY_IBSS)) &&
+		((s_cap & WLAN_CAPABILITY_BSS) == (d_cap & WLAN_CAPABILITY_BSS))) {
+		if ((src->Ssid.SsidLength == dst->Ssid.SsidLength) && 
+			(((_rtw_memcmp(src->Ssid.Ssid, dst->Ssid.Ssid, src->Ssid.SsidLength)) == _TRUE) || //Case of normal AP
+			(is_all_null(src->Ssid.Ssid, src->Ssid.SsidLength) == _TRUE || is_all_null(dst->Ssid.Ssid, dst->Ssid.SsidLength) == _TRUE))) //Case of hidden AP
+			return _TRUE;
+		else if ((src->Ssid.SsidLength == 0 || dst->Ssid.SsidLength == 0)) //Case of hidden AP
+			return _TRUE;
+		else
+			return _FALSE;
+	} else {
+		return _FALSE;
+	}
 }
 
 struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network)
@@ -746,17 +741,17 @@ struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_n
 	plist = get_next(phead);
 
 	while (plist != phead) {
-		found = LIST_CONTAINOR(plist, struct wlan_network ,list);
+		found = LIST_CONTAINOR(plist, struct wlan_network , list);
 
-		if (is_same_network(&network->network, &found->network,0))
+		if (is_same_network(&network->network, &found->network, 0))
 			break;
 
 		plist = get_next(plist);
 	}
 
-	if(plist == phead)
+	if (plist == phead)
 		found = NULL;
-exit:		
+exit:
 	return found;
 }
 
@@ -766,7 +761,7 @@ struct wlan_network *rtw_find_same_network(_queue *scanned_queue, struct wlan_ne
 	struct wlan_network *found = NULL;
 
 	if (scanned_queue == NULL || network == NULL)
-		goto exit;	
+		goto exit;
 
 	_enter_critical_bh(&scanned_queue->lock, &irqL);
 	found = _rtw_find_same_network(scanned_queue, network);
@@ -776,41 +771,37 @@ exit:
 	return found;
 }
 
-struct	wlan_network	* rtw_get_oldest_wlan_network(_queue *scanned_queue)
+struct	wlan_network	*rtw_get_oldest_wlan_network(_queue *scanned_queue)
 {
 	_list	*plist, *phead;
 
-	
+
 	struct	wlan_network	*pwlan = NULL;
 	struct	wlan_network	*oldest = NULL;
-_func_enter_;		
 	phead = get_list_head(scanned_queue);
-	
+
 	plist = get_next(phead);
 
-	while(1)
-	{
-		
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+	while (1) {
+
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
-		
-		pwlan= LIST_CONTAINOR(plist, struct wlan_network, list);
 
-		if(pwlan->fixed!=_TRUE)
-		{		
-			if (oldest == NULL ||time_after(oldest->last_scanned, pwlan->last_scanned))
+		pwlan = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		if (pwlan->fixed != _TRUE) {
+			if (oldest == NULL || rtw_time_after(oldest->last_scanned, pwlan->last_scanned))
 				oldest = pwlan;
 		}
-		
+
 		plist = get_next(plist);
 	}
-_func_exit_;		
 	return oldest;
-	
+
 }
 
 void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src,
-	_adapter * padapter, bool update_ie)
+		    _adapter *padapter, bool update_ie)
 {
 	u8 ss_ori = dst->PhyInfo.SignalStrength;
 	u8 sq_ori = dst->PhyInfo.SignalQuality;
@@ -824,22 +815,21 @@ void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src,
 	u8 sq_final;
 	long rssi_final;
 
-_func_enter_;		
 
 #ifdef CONFIG_ANTENNA_DIVERSITY
-	rtw_hal_antdiv_rssi_compared(padapter, dst, src); //this will update src.Rssi, need consider again
+	rtw_hal_antdiv_rssi_compared(padapter, dst, src); /* this will update src.Rssi, need consider again */
 #endif
 
-	#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
-	if(strcmp(dst->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
-		DBG_871X(FUNC_ADPT_FMT" %s("MAC_FMT", ch%u) ss_ori:%3u, sq_ori:%3u, rssi_ori:%3ld, ss_smp:%3u, sq_smp:%3u, rssi_smp:%3ld\n"
-			, FUNC_ADPT_ARG(padapter)
+#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
+	if (strcmp(dst->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
+		RTW_INFO(FUNC_ADPT_FMT" %s("MAC_FMT", ch%u) ss_ori:%3u, sq_ori:%3u, rssi_ori:%3ld, ss_smp:%3u, sq_smp:%3u, rssi_smp:%3ld\n"
+			 , FUNC_ADPT_ARG(padapter)
 			, src->Ssid.Ssid, MAC_ARG(src->MacAddress), src->Configuration.DSConfig
-			,ss_ori, sq_ori, rssi_ori
-			,ss_smp, sq_smp, rssi_smp
-		);
+			 , ss_ori, sq_ori, rssi_ori
+			 , ss_smp, sq_smp, rssi_smp
+			);
 	}
-	#endif
+#endif
 
 	/* The rule below is 1/5 for sample value, 4/5 for history value */
 	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) && is_same_network(&(padapter->mlmepriv.cur_network.network), src, 0)) {
@@ -847,23 +837,22 @@ _func_enter_;
 		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;
+		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->PhyInfo.SignalStrength)+(u32)(dst->PhyInfo.SignalStrength)*4)/5;
-			sq_final = ((u32)(src->PhyInfo.SignalQuality)+(u32)(dst->PhyInfo.SignalQuality)*4)/5;
-			rssi_final = (src->Rssi+dst->Rssi*4)/5;
+	} else {
+		if (sq_smp != 101) { /* from the right channel */
+			ss_final = ((u32)(src->PhyInfo.SignalStrength) + (u32)(dst->PhyInfo.SignalStrength) * 4) / 5;
+			sq_final = ((u32)(src->PhyInfo.SignalQuality) + (u32)(dst->PhyInfo.SignalQuality) * 4) / 5;
+			rssi_final = (src->Rssi + dst->Rssi * 4) / 5;
 		} else {
 			/* bss info not receving from the right channel, use the original RX signal infos */
 			ss_final = dst->PhyInfo.SignalStrength;
 			sq_final = dst->PhyInfo.SignalQuality;
 			rssi_final = dst->Rssi;
 		}
-		
+
 	}
 
 	if (update_ie) {
@@ -876,76 +865,68 @@ _func_enter_;
 	dst->PhyInfo.SignalQuality = sq_final;
 	dst->Rssi = rssi_final;
 
-	#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
-	if(strcmp(dst->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
-		DBG_871X(FUNC_ADPT_FMT" %s("MAC_FMT"), SignalStrength:%u, SignalQuality:%u, RawRSSI:%ld\n"
-			, FUNC_ADPT_ARG(padapter)
+#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
+	if (strcmp(dst->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
+		RTW_INFO(FUNC_ADPT_FMT" %s("MAC_FMT"), SignalStrength:%u, SignalQuality:%u, RawRSSI:%ld\n"
+			 , FUNC_ADPT_ARG(padapter)
 			, dst->Ssid.Ssid, MAC_ARG(dst->MacAddress), dst->PhyInfo.SignalStrength, dst->PhyInfo.SignalQuality, dst->Rssi);
 	}
-	#endif
+#endif
 
-#if 0 // old codes, may be useful one day...
-//	DBG_871X("update_network: rssi=0x%lx dst->Rssi=%d ,dst->Rssi=0x%lx , src->Rssi=0x%lx",(dst->Rssi+src->Rssi)/2,dst->Rssi,dst->Rssi,src->Rssi);
-	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) && is_same_network(&(padapter->mlmepriv.cur_network.network), src))
-	{
-	
-		//DBG_871X("b:ssid=%s update_network: src->rssi=0x%d padapter->recvpriv.ui_rssi=%d\n",src->Ssid.Ssid,src->Rssi,padapter->recvpriv.signal);
-		if(padapter->recvpriv.signal_qual_data.total_num++ >= PHY_LINKQUALITY_SLID_WIN_MAX)
-	        {
-	              padapter->recvpriv.signal_qual_data.total_num = PHY_LINKQUALITY_SLID_WIN_MAX;
-	              last_evm = padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index];
-	              padapter->recvpriv.signal_qual_data.total_val -= last_evm;
-	        }
-               	padapter->recvpriv.signal_qual_data.total_val += query_rx_pwr_percentage(src->Rssi);
-
-              	padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index++] = query_rx_pwr_percentage(src->Rssi);
-                if(padapter->recvpriv.signal_qual_data.index >= PHY_LINKQUALITY_SLID_WIN_MAX)
-                       padapter->recvpriv.signal_qual_data.index = 0;
-
-		//DBG_871X("Total SQ=%d  pattrib->signal_qual= %d\n", padapter->recvpriv.signal_qual_data.total_val, src->Rssi);
-
-		// <1> Showed on UI for user,in percentage.
-		tmpVal = padapter->recvpriv.signal_qual_data.total_val/padapter->recvpriv.signal_qual_data.total_num;
-                padapter->recvpriv.signal=(u8)tmpVal;//Link quality
-
-		src->Rssi= translate_percentage_to_dbm(padapter->recvpriv.signal) ;
-	}
-	else{
-//	DBG_871X("ELSE:ssid=%s update_network: src->rssi=0x%d dst->rssi=%d\n",src->Ssid.Ssid,src->Rssi,dst->Rssi);
-		src->Rssi=(src->Rssi +dst->Rssi)/2;//dBM
-	}	
+#if 0 /* old codes, may be useful one day...
+ * 	RTW_INFO("update_network: rssi=0x%lx dst->Rssi=%d ,dst->Rssi=0x%lx , src->Rssi=0x%lx",(dst->Rssi+src->Rssi)/2,dst->Rssi,dst->Rssi,src->Rssi); */
+	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) && is_same_network(&(padapter->mlmepriv.cur_network.network), src)) {
+
+		/* RTW_INFO("b:ssid=%s update_network: src->rssi=0x%d padapter->recvpriv.ui_rssi=%d\n",src->Ssid.Ssid,src->Rssi,padapter->recvpriv.signal); */
+		if (padapter->recvpriv.signal_qual_data.total_num++ >= PHY_LINKQUALITY_SLID_WIN_MAX) {
+			padapter->recvpriv.signal_qual_data.total_num = PHY_LINKQUALITY_SLID_WIN_MAX;
+			last_evm = padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index];
+			padapter->recvpriv.signal_qual_data.total_val -= last_evm;
+		}
+		padapter->recvpriv.signal_qual_data.total_val += query_rx_pwr_percentage(src->Rssi);
+
+		padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index++] = query_rx_pwr_percentage(src->Rssi);
+		if (padapter->recvpriv.signal_qual_data.index >= PHY_LINKQUALITY_SLID_WIN_MAX)
+			padapter->recvpriv.signal_qual_data.index = 0;
+
+		/* RTW_INFO("Total SQ=%d  pattrib->signal_qual= %d\n", padapter->recvpriv.signal_qual_data.total_val, src->Rssi); */
 
-//	DBG_871X("a:update_network: src->rssi=0x%d padapter->recvpriv.ui_rssi=%d\n",src->Rssi,padapter->recvpriv.signal);
+		/* <1> Showed on UI for user,in percentage. */
+		tmpVal = padapter->recvpriv.signal_qual_data.total_val / padapter->recvpriv.signal_qual_data.total_num;
+		padapter->recvpriv.signal = (u8)tmpVal; /* Link quality */
+
+		src->Rssi = translate_percentage_to_dbm(padapter->recvpriv.signal) ;
+	} else {
+		/*	RTW_INFO("ELSE:ssid=%s update_network: src->rssi=0x%d dst->rssi=%d\n",src->Ssid.Ssid,src->Rssi,dst->Rssi); */
+		src->Rssi = (src->Rssi + dst->Rssi) / 2; /* dBM */
+	}
+
+	/*	RTW_INFO("a:update_network: src->rssi=0x%d padapter->recvpriv.ui_rssi=%d\n",src->Rssi,padapter->recvpriv.signal); */
 
 #endif
 
-_func_exit_;		
 }
 
 static void update_current_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)
 {
 	struct	mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
-	
-_func_enter_;		
 
-	rtw_bug_check(&(pmlmepriv->cur_network.network), 
-		&(pmlmepriv->cur_network.network), 
-		&(pmlmepriv->cur_network.network), 
-		&(pmlmepriv->cur_network.network));
 
-	if ( (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE) && (is_same_network(&(pmlmepriv->cur_network.network), pnetwork, 0)))
-	{
-		//RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,"Same Network\n");
+	rtw_bug_check(&(pmlmepriv->cur_network.network),
+		      &(pmlmepriv->cur_network.network),
+		      &(pmlmepriv->cur_network.network),
+		      &(pmlmepriv->cur_network.network));
 
-		//if(pmlmepriv->cur_network.network.IELength<= pnetwork->IELength)
+	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && (is_same_network(&(pmlmepriv->cur_network.network), pnetwork, 0))) {
+
+		/* if(pmlmepriv->cur_network.network.IELength<= pnetwork->IELength) */
 		{
-			update_network(&(pmlmepriv->cur_network.network), pnetwork,adapter, _TRUE);
-			rtw_update_protection(adapter, (pmlmepriv->cur_network.network.IEs) + sizeof (NDIS_802_11_FIXED_IEs), 
-									pmlmepriv->cur_network.network.IELength);
+			update_network(&(pmlmepriv->cur_network.network), pnetwork, adapter, _TRUE);
+			rtw_update_protection(adapter, (pmlmepriv->cur_network.network.IEs) + sizeof(NDIS_802_11_FIXED_IEs),
+				      pmlmepriv->cur_network.network.IELength);
 		}
 	}
 
-_func_exit_;			
 
 }
 
@@ -956,7 +937,7 @@ Caller must hold pmlmepriv->lock first.
 
 
 */
-void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
+bool rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 {
 	_irqL irqL;
 	_list	*plist, *phead;
@@ -964,28 +945,31 @@ void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
 	struct mlme_ext_priv	*pmlmeext = &(adapter->mlmeextpriv);
 #ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(adapter->wdinfo);
-#endif // CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
+#endif /* CONFIG_P2P */
 	_queue	*queue	= &(pmlmepriv->scanned_queue);
 	struct wlan_network	*pnetwork = NULL;
-	struct wlan_network	*oldest = NULL;
+	struct wlan_network	*choice = NULL;
 	int target_find = 0;
-	u8 feature = 0;    
-
-_func_enter_;
+	u8 feature = 0;
+	bool update_ie = _FALSE;
 
 	_enter_critical_bh(&queue->lock, &irqL);
 	phead = get_list_head(queue);
 	plist = get_next(phead);
 
+#if 0
+	RTW_INFO("%s => ssid:%s , rssi:%ld , ss:%d\n",
+		__func__, target->Ssid.Ssid, target->Rssi, target->PhyInfo.SignalStrength);
+#endif
+
 #ifdef CONFIG_P2P
 	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		feature = 1; // p2p enable
+		feature = 1; /* p2p enable */
 #endif
 
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
@@ -994,78 +978,88 @@ _func_enter_;
 
 #ifdef CONFIG_P2P
 		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) &&
-			(_rtw_memcmp(pnetwork->network.MacAddress, target->MacAddress, ETH_ALEN) == _TRUE))
-		{
+		    (_rtw_memcmp(pnetwork->network.MacAddress, target->MacAddress, ETH_ALEN) == _TRUE)) {
 			target_find = 1;
 			break;
 		}
 #endif
 
-		if (is_same_network(&(pnetwork->network), target, feature))
-		{
+		if (is_same_network(&(pnetwork->network), target, feature)) {
 			target_find = 1;
 			break;
 		}
 
 		if (rtw_roam_flags(adapter)) {
-			/* TODO: don't  select netowrk in the same ess as oldest if it's new enough*/
+			/* TODO: don't  select netowrk in the same ess as choice if it's new enough*/
 		}
-
-		if (oldest == NULL || time_after(oldest->last_scanned, pnetwork->last_scanned))
-			oldest = pnetwork;
-
+#ifdef CONFIG_RSSI_PRIORITY
+		if ((choice == NULL) || (pnetwork->network.PhyInfo.SignalStrength < choice->network.PhyInfo.SignalStrength))
+			#ifdef CONFIG_RTW_MESH
+			if (!MLME_IS_MESH(adapter) || check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _FALSE
+				|| !rtw_bss_is_same_mbss(&pmlmepriv->cur_network.network, &pnetwork->network))
+			#endif
+				choice = pnetwork;
+#else
+		if (choice == NULL || rtw_time_after(choice->last_scanned, pnetwork->last_scanned))
+			#ifdef CONFIG_RTW_MESH
+			if (!MLME_IS_MESH(adapter) || check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _FALSE
+				|| !rtw_bss_is_same_mbss(&pmlmepriv->cur_network.network, &pnetwork->network))
+			#endif
+				choice = pnetwork;
+#endif
 		plist = get_next(plist);
 
 	}
-	
-	
+
+
 	/* If we didn't find a match, then get a new network slot to initialize
 	 * with this beacon's information */
-	//if (rtw_end_of_queue_search(phead,plist)== _TRUE) {
-	if (!target_find) {		
+	/* if (rtw_end_of_queue_search(phead,plist)== _TRUE) { */
+	if (!target_find) {
 		if (_rtw_queue_empty(&(pmlmepriv->free_bss_pool)) == _TRUE) {
-			/* If there are no more slots, expire the oldest */
-			//list_del_init(&oldest->list);
-			pnetwork = oldest;
-			if(pnetwork==NULL){ 
-				RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n\n\nsomething wrong here\n\n\n"));
-				goto exit;
-			}
+			/* If there are no more slots, expire the choice */
+			/* list_del_init(&choice->list); */
+			pnetwork = choice;
+			if (pnetwork == NULL)
+				goto unlock_scan_queue;
+
+#ifdef CONFIG_RSSI_PRIORITY
+		RTW_DBG("%s => ssid:%s ,bssid:"MAC_FMT"  will be deleted from scanned_queue (rssi:%ld , ss:%d)\n",
+			__func__, pnetwork->network.Ssid.Ssid, MAC_ARG(pnetwork->network.MacAddress), pnetwork->network.Rssi, pnetwork->network.PhyInfo.SignalStrength);
+#else
+		RTW_DBG("%s => ssid:%s ,bssid:"MAC_FMT" will be deleted from scanned_queue\n",
+			__func__, pnetwork->network.Ssid.Ssid, MAC_ARG(pnetwork->network.MacAddress));
+#endif
+
 #ifdef CONFIG_ANTENNA_DIVERSITY
-			//target->PhyInfo.Optimum_antenna = pHalData->CurAntenna;//optimum_antenna=>For antenna diversity
-			rtw_hal_get_def_var(adapter, HAL_DEF_CURRENT_ANTENNA, &(target->PhyInfo.Optimum_antenna));
+			rtw_hal_get_odm_var(adapter, HAL_ODM_ANTDIV_SELECT, &(target->PhyInfo.Optimum_antenna), NULL);
 #endif
 			_rtw_memcpy(&(pnetwork->network), target,  get_WLAN_BSSID_EX_sz(target));
-			//pnetwork->last_scanned = rtw_get_current_time();
-			// variable initialize
+			/* pnetwork->last_scanned = rtw_get_current_time(); */
+			/* variable initialize */
 			pnetwork->fixed = _FALSE;
 			pnetwork->last_scanned = rtw_get_current_time();
 
-			pnetwork->network_type = 0;	
-			pnetwork->aid=0;		
-			pnetwork->join_res=0;
+			pnetwork->network_type = 0;
+			pnetwork->aid = 0;
+			pnetwork->join_res = 0;
 
 			/* bss info not receving from the right channel */
 			if (pnetwork->network.PhyInfo.SignalQuality == 101)
 				pnetwork->network.PhyInfo.SignalQuality = 0;
-		}
-		else {
+		} else {
 			/* Otherwise just pull from the free list */
 
-			pnetwork = rtw_alloc_network(pmlmepriv); // will update scan_time
-
-			if(pnetwork==NULL){ 
-				RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n\n\nsomething wrong here\n\n\n"));
-				goto exit;
-			}
+			pnetwork = rtw_alloc_network(pmlmepriv); /* will update scan_time */
+			if (pnetwork == NULL)
+				goto unlock_scan_queue;
 
 			bssid_ex_sz = get_WLAN_BSSID_EX_sz(target);
 			target->Length = bssid_ex_sz;
 #ifdef CONFIG_ANTENNA_DIVERSITY
-			//target->PhyInfo.Optimum_antenna = pHalData->CurAntenna;
-			rtw_hal_get_def_var(adapter, HAL_DEF_CURRENT_ANTENNA, &(target->PhyInfo.Optimum_antenna));
+			rtw_hal_get_odm_var(adapter, HAL_ODM_ANTDIV_SELECT, &(target->PhyInfo.Optimum_antenna), NULL);
 #endif
-			_rtw_memcpy(&(pnetwork->network), target, bssid_ex_sz );
+			_rtw_memcpy(&(pnetwork->network), target, bssid_ex_sz);
 
 			pnetwork->last_scanned = rtw_get_current_time();
 
@@ -1073,40 +1067,45 @@ _func_enter_;
 			if (pnetwork->network.PhyInfo.SignalQuality == 101)
 				pnetwork->network.PhyInfo.SignalQuality = 0;
 
-			rtw_list_insert_tail(&(pnetwork->list),&(queue->queue)); 
+			rtw_list_insert_tail(&(pnetwork->list), &(queue->queue));
 
 		}
-	}
-	else {
+	} 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 
+		 * 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 = rtw_get_current_time();
 
-		//target.Reserved[0]==1, means that scaned network is a bcn frame.
-		if((pnetwork->network.IELength>target->IELength) && (target->Reserved[0]==1))
+		/* target.Reserved[0]==BSS_TYPE_BCN, means that scanned network is a bcn frame. */
+		if ((pnetwork->network.IELength > target->IELength) && (target->Reserved[0] == BSS_TYPE_BCN))
 			update_ie = _FALSE;
 
-		// probe resp(3) > beacon(1) > probe req(2)
-		if ((target->Reserved[0] != 2) &&
-			(target->Reserved[0] >= pnetwork->network.Reserved[0])
-			) {
+		if (MLME_IS_MESH(adapter)
+			/* probe resp(3) > beacon(1) > probe req(2) */
+			|| (target->Reserved[0] != BSS_TYPE_PROB_REQ
+				&& target->Reserved[0] >= pnetwork->network.Reserved[0])
+		)
 			update_ie = _TRUE;
-		}
-		else {
+		else
 			update_ie = _FALSE;
-		}
 
-		update_network(&(pnetwork->network), target,adapter, update_ie);
+		update_network(&(pnetwork->network), target, adapter, update_ie);
 	}
 
-exit:
+unlock_scan_queue:
 	_exit_critical_bh(&queue->lock, &irqL);
 
-_func_exit_;
+#ifdef CONFIG_RTW_MESH
+	if (pnetwork && MLME_IS_MESH(adapter)
+		&& check_fwstate(pmlmepriv, WIFI_ASOC_STATE)
+		&& !check_fwstate(pmlmepriv, WIFI_SITE_MONITOR)
+	)
+		rtw_chk_candidate_peer_notify(adapter, pnetwork);
+#endif
+
+	return update_ie;
 }
 
 void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork);
@@ -1114,35 +1113,36 @@ void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)
 {
 	_irqL irqL;
 	struct	mlme_priv	*pmlmepriv = &(((_adapter *)adapter)->mlmepriv);
-	//_queue	*queue	= &(pmlmepriv->scanned_queue);
+	bool update_ie;
+	/* _queue	*queue	= &(pmlmepriv->scanned_queue); */
 
-_func_enter_;		
 
-	//_enter_critical_bh(&queue->lock, &irqL);
+	/* _enter_critical_bh(&queue->lock, &irqL); */
 
-	#if defined(CONFIG_P2P) && defined(CONFIG_P2P_REMOVE_GROUP_INFO)
+#if defined(CONFIG_P2P) && defined(CONFIG_P2P_REMOVE_GROUP_INFO)
 	if (adapter->registrypriv.wifi_spec == 0)
 		rtw_bss_ex_del_p2p_attr(pnetwork, P2P_ATTR_GROUP_INFO);
-	#endif
-	
+#endif
+
 	if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
 		rtw_bss_ex_del_wfd_ie(pnetwork);
 
-	update_current_network(adapter, pnetwork);
-	
-	rtw_update_scanned_network(adapter, pnetwork);
+	/* Wi-Fi driver will update the current network if the scan result of the connected AP be updated by scan. */
+	update_ie = rtw_update_scanned_network(adapter, pnetwork);
+
+	if (update_ie)
+		update_current_network(adapter, pnetwork);
+
+	/* _exit_critical_bh(&queue->lock, &irqL); */
 
-	//_exit_critical_bh(&queue->lock, &irqL);
-	
-_func_exit_;		
 }
 
-//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
+/* 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 */
 int rtw_is_desired_network(_adapter *adapter, struct wlan_network *pnetwork);
 int rtw_is_desired_network(_adapter *adapter, struct wlan_network *pnetwork)
 {
@@ -1151,55 +1151,47 @@ int rtw_is_desired_network(_adapter *adapter, struct wlan_network *pnetwork)
 	u32 desired_encmode;
 	u32 privacy;
 
-	//u8 wps_ie[512];
+	/* u8 wps_ie[512]; */
 	uint wps_ielen;
 
 	int bselected = _TRUE;
-	
+
 	desired_encmode = psecuritypriv->ndisencryptstatus;
 	privacy = pnetwork->network.Privacy;
 
-	if(check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
-	{
-		if(rtw_get_wps_ie(pnetwork->network.IEs+_FIXED_IE_LENGTH_, pnetwork->network.IELength-_FIXED_IE_LENGTH_, NULL, &wps_ielen)!=NULL)
-		{
+	if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+		if (rtw_get_wps_ie(pnetwork->network.IEs + _FIXED_IE_LENGTH_, pnetwork->network.IELength - _FIXED_IE_LENGTH_, NULL, &wps_ielen) != NULL)
 			return _TRUE;
-		}
 		else
-		{	
 			return _FALSE;
-		}	
 	}
-	if (adapter->registrypriv.wifi_spec == 1) //for  correct flow of 8021X  to do....
-	{
-		u8 *p=NULL;
-		uint ie_len=0;
+	if (adapter->registrypriv.wifi_spec == 1) { /* for  correct flow of 8021X  to do.... */
+		u8 *p = NULL;
+		uint ie_len = 0;
 
 		if ((desired_encmode == Ndis802_11EncryptionDisabled) && (privacy != 0))
-	            bselected = _FALSE;
+			bselected = _FALSE;
 
-		if ( psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
+		if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
 			p = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
-			if (p && ie_len>0) {
+			if (p && ie_len > 0)
 				bselected = _TRUE;
-			} else {
+			else
 				bselected = _FALSE;
-			}
 		}
 	}
-	
 
- 	if ((desired_encmode != Ndis802_11EncryptionDisabled) && (privacy == 0)) {
-		DBG_871X("desired_encmode: %d, privacy: %d\n", desired_encmode, privacy);
+
+	if ((desired_encmode != Ndis802_11EncryptionDisabled) && (privacy == 0)) {
+		RTW_INFO("desired_encmode: %d, privacy: %d\n", desired_encmode, privacy);
 		bselected = _FALSE;
- 	}
+	}
 
-	if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)
-	{
-		if(pnetwork->network.InfrastructureMode != pmlmepriv->cur_network.network.InfrastructureMode)
+	if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+		if (pnetwork->network.InfrastructureMode != pmlmepriv->cur_network.network.InfrastructureMode)
 			bselected = _FALSE;
-	}	
-		
+	}
+
 
 	return bselected;
 }
@@ -1208,10 +1200,7 @@ int rtw_is_desired_network(_adapter *adapter, struct wlan_network *pnetwork)
 void rtw_atimdone_event_callback(_adapter	*adapter , u8 *pbuf)
 {
 
-_func_enter_;		
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("receive atimdone_evet\n"));	
-_func_exit_;			
-	return;	
+	return;
 }
 
 
@@ -1222,93 +1211,83 @@ void rtw_survey_event_callback(_adapter	*adapter, u8 *pbuf)
 	WLAN_BSSID_EX *pnetwork;
 	struct	mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
 
-_func_enter_;		
 
 	pnetwork = (WLAN_BSSID_EX *)pbuf;
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_survey_event_callback, ssid=%s\n",  pnetwork->Ssid.Ssid));
 
 #ifdef CONFIG_RTL8712
-        //endian_convert
- 	pnetwork->Length = le32_to_cpu(pnetwork->Length);
-  	pnetwork->Ssid.SsidLength = le32_to_cpu(pnetwork->Ssid.SsidLength);	
-	pnetwork->Privacy =le32_to_cpu( pnetwork->Privacy);
+	/* endian_convert */
+	pnetwork->Length = le32_to_cpu(pnetwork->Length);
+	pnetwork->Ssid.SsidLength = le32_to_cpu(pnetwork->Ssid.SsidLength);
+	pnetwork->Privacy = le32_to_cpu(pnetwork->Privacy);
 	pnetwork->Rssi = le32_to_cpu(pnetwork->Rssi);
-	pnetwork->NetworkTypeInUse =le32_to_cpu(pnetwork->NetworkTypeInUse);	
+	pnetwork->NetworkTypeInUse = le32_to_cpu(pnetwork->NetworkTypeInUse);
 	pnetwork->Configuration.ATIMWindow = le32_to_cpu(pnetwork->Configuration.ATIMWindow);
 	pnetwork->Configuration.BeaconPeriod = le32_to_cpu(pnetwork->Configuration.BeaconPeriod);
-	pnetwork->Configuration.DSConfig =le32_to_cpu(pnetwork->Configuration.DSConfig);
-	pnetwork->Configuration.FHConfig.DwellTime=le32_to_cpu(pnetwork->Configuration.FHConfig.DwellTime);
-	pnetwork->Configuration.FHConfig.HopPattern=le32_to_cpu(pnetwork->Configuration.FHConfig.HopPattern);
-	pnetwork->Configuration.FHConfig.HopSet=le32_to_cpu(pnetwork->Configuration.FHConfig.HopSet);
-	pnetwork->Configuration.FHConfig.Length=le32_to_cpu(pnetwork->Configuration.FHConfig.Length);	
+	pnetwork->Configuration.DSConfig = le32_to_cpu(pnetwork->Configuration.DSConfig);
+	pnetwork->Configuration.FHConfig.DwellTime = le32_to_cpu(pnetwork->Configuration.FHConfig.DwellTime);
+	pnetwork->Configuration.FHConfig.HopPattern = le32_to_cpu(pnetwork->Configuration.FHConfig.HopPattern);
+	pnetwork->Configuration.FHConfig.HopSet = le32_to_cpu(pnetwork->Configuration.FHConfig.HopSet);
+	pnetwork->Configuration.FHConfig.Length = le32_to_cpu(pnetwork->Configuration.FHConfig.Length);
 	pnetwork->Configuration.Length = le32_to_cpu(pnetwork->Configuration.Length);
 	pnetwork->InfrastructureMode = le32_to_cpu(pnetwork->InfrastructureMode);
 	pnetwork->IELength = le32_to_cpu(pnetwork->IELength);
-#endif	
+#endif
 
 	len = get_WLAN_BSSID_EX_sz(pnetwork);
-	if(len > (sizeof(WLAN_BSSID_EX)))
-	{
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n ****rtw_survey_event_callback: return a wrong bss ***\n"));
+	if (len > (sizeof(WLAN_BSSID_EX))) {
 		return;
 	}
 
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	// update IBSS_network 's timestamp
-	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) == _TRUE)
-	{
-		//RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,"rtw_survey_event_callback : WIFI_ADHOC_MASTER_STATE \n\n");
-		if(_rtw_memcmp(&(pmlmepriv->cur_network.network.MacAddress), pnetwork->MacAddress, ETH_ALEN))
-		{
-			struct wlan_network* ibss_wlan = NULL;
+	/* update IBSS_network 's timestamp */
+	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) == _TRUE) {
+		if (_rtw_memcmp(&(pmlmepriv->cur_network.network.MacAddress), pnetwork->MacAddress, ETH_ALEN)) {
+			struct wlan_network *ibss_wlan = NULL;
 			_irqL	irqL;
-			
+
 			_rtw_memcpy(pmlmepriv->cur_network.network.IEs, pnetwork->IEs, 8);
 			_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-			ibss_wlan = rtw_find_network(&pmlmepriv->scanned_queue,  pnetwork->MacAddress);
-			if(ibss_wlan)
-			{
-				_rtw_memcpy(ibss_wlan->network.IEs , pnetwork->IEs, 8);			
-				_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);		
+			ibss_wlan = _rtw_find_network(&pmlmepriv->scanned_queue,  pnetwork->MacAddress);
+			if (ibss_wlan) {
+				_rtw_memcpy(ibss_wlan->network.IEs , pnetwork->IEs, 8);
+				_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 				goto exit;
 			}
 			_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 		}
 	}
 
-	// lock pmlmepriv->lock when you accessing network_q
-	if ((check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) == _FALSE)
-	{		
-   	        if( pnetwork->Ssid.Ssid[0] == 0 )
-		{
+	/* lock pmlmepriv->lock when you accessing network_q */
+	if ((check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) == _FALSE) {
+		if (pnetwork->Ssid.Ssid[0] == 0)
 			pnetwork->Ssid.SsidLength = 0;
-		}	
 		rtw_add_network(adapter, pnetwork);
-	}	
+	}
+
+exit:
 
-exit:	
-		
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
-_func_exit_;		
 
-	return;	
+	return;
 }
 
 void rtw_surveydone_event_callback(_adapter	*adapter, u8 *pbuf)
 {
 	_irqL  irqL;
-	u8 timer_cancelled;
+	struct sitesurvey_parm parm;
 	struct	mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
+#ifdef CONFIG_RTW_80211R
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+#endif
 
 #ifdef CONFIG_MLME_EXT
 	mlmeext_surveydone_event_callback(adapter);
 #endif
 
-_func_enter_;
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 	if (pmlmepriv->wps_probe_req_ie) {
@@ -1318,133 +1297,119 @@ _func_enter_;
 		pmlmepriv->wps_probe_req_ie = NULL;
 	}
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_surveydone_event_callback: fw_state:%x\n\n", get_fwstate(pmlmepriv)));
 
-	if (check_fwstate(pmlmepriv,_FW_UNDER_SURVEY) == _FALSE) {
-		DBG_871X(FUNC_ADPT_FMT" fw_state:0x%x\n", FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
-		//rtw_warn_on(1);
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _FALSE) {
+		RTW_INFO(FUNC_ADPT_FMT" fw_state:0x%x\n", FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
+		/* rtw_warn_on(1); */
 	}
 
 	_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
-	_cancel_timer(&pmlmepriv->scan_to_timer, &timer_cancelled);
+	_cancel_timer_ex(&pmlmepriv->scan_to_timer);
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
+#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	rtw_set_signal_stat_timer(&adapter->recvpriv);
-	#endif
+#endif
 
-	if(pmlmepriv->to_join == _TRUE)
-	{
-		if((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)==_TRUE) )
-		{
-			if(check_fwstate(pmlmepriv, _FW_LINKED)==_FALSE)
-			{
-				set_fwstate(pmlmepriv, _FW_UNDER_LINKING);	
-				
-				if(rtw_select_and_join_from_scanned_queue(pmlmepriv)==_SUCCESS)
-				{
+	if (pmlmepriv->to_join == _TRUE) {
+		if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)) {
+			if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
+
+				if (rtw_select_and_join_from_scanned_queue(pmlmepriv) == _SUCCESS)
 					_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
-				}
-				else
-				{
-					WLAN_BSSID_EX    *pdev_network = &(adapter->registrypriv.dev_network); 			
+				else {
+					WLAN_BSSID_EX    *pdev_network = &(adapter->registrypriv.dev_network);
 					u8 *pibss = adapter->registrypriv.dev_network.MacAddress;
 
-					//pmlmepriv->fw_state ^= _FW_UNDER_SURVEY;//because don't set assoc_timer
+					/* pmlmepriv->fw_state ^= _FW_UNDER_SURVEY; */ /* because don't set assoc_timer */
 					_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
 
-					RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("switching to adhoc master\n"));
-				
+
 					_rtw_memset(&pdev_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
 					_rtw_memcpy(&pdev_network->Ssid, &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
-	
+
 					rtw_update_registrypriv_dev_network(adapter);
 					rtw_generate_random_ibss(pibss);
 
-	
-					pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;
-			
+					/*pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;*/
+					init_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
+
 					if (rtw_create_ibss_cmd(adapter, 0) != _SUCCESS)
-						RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_, ("Error=>rtw_create_ibss_cmd status FAIL\n"));
+						RTW_ERR("rtw_create_ibss_cmd FAIL\n");
 
-			     		pmlmepriv->to_join = _FALSE;
-		   		}
-		 	}
-		}
-		else
-		{
+					pmlmepriv->to_join = _FALSE;
+				}
+			}
+		} else {
 			int s_ret;
 			set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
 			pmlmepriv->to_join = _FALSE;
-			if(_SUCCESS == (s_ret=rtw_select_and_join_from_scanned_queue(pmlmepriv)))
-			{
-	     		     _set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);	 
-			}
-			else if(s_ret == 2)//there is no need to wait for join
-			{
+			s_ret = rtw_select_and_join_from_scanned_queue(pmlmepriv);
+			if (_SUCCESS == s_ret)
+				_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
+			else if (s_ret == 2) { /* there is no need to wait for join */
 				_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
 				rtw_indicate_connect(adapter);
-			}
-			else
-			{
-				DBG_871X("try_to_join, but select scanning queue fail, to_roam:%d\n", rtw_to_roam(adapter));
+			} else {
+				RTW_INFO("try_to_join, but select scanning queue fail, to_roam:%d\n", rtw_to_roam(adapter));
 
 				if (rtw_to_roam(adapter) != 0) {
-					if(rtw_dec_to_roam(adapter) == 0
-						|| _SUCCESS != rtw_sitesurvey_cmd(adapter, &pmlmepriv->assoc_ssid, 1, NULL, 0)
-					) {
+
+					rtw_init_sitesurvey_parm(adapter, &parm);
+					_rtw_memcpy(&parm.ssid[0], &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
+					parm.ssid_num = 1;
+
+					if (rtw_dec_to_roam(adapter) == 0
+					    || _SUCCESS != rtw_sitesurvey_cmd(adapter, &parm)
+					   ) {
 						rtw_set_to_roam(adapter, 0);
 #ifdef CONFIG_INTEL_WIDI
-						if(adapter->mlmepriv.widi_state == INTEL_WIDI_STATE_ROAMING)
-						{
+						if (adapter->mlmepriv.widi_state == INTEL_WIDI_STATE_ROAMING) {
 							_rtw_memset(pmlmepriv->sa_ext, 0x00, L2SDTA_SERVICE_VE_LEN);
 							intel_widi_wk_cmd(adapter, INTEL_WIDI_LISTEN_WK, NULL, 0);
-							DBG_871X("change to widi listen\n");
+							RTW_INFO("change to widi listen\n");
 						}
-#endif // CONFIG_INTEL_WIDI
-						rtw_free_assoc_resources(adapter, 1);
+#endif /* CONFIG_INTEL_WIDI */
+						rtw_free_assoc_resources(adapter, _TRUE);
 						rtw_indicate_disconnect(adapter, 0, _FALSE);
-					} else {
+					} else
 						pmlmepriv->to_join = _TRUE;
-					}
-				}
-				else
-				{
+				} else
 					rtw_indicate_disconnect(adapter, 0, _FALSE);
-				}
 				_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
 			}
 		}
 	} else {
 		if (rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
 			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
-				&& check_fwstate(pmlmepriv, _FW_LINKED))
-			{
+			    && check_fwstate(pmlmepriv, _FW_LINKED)) {
 				if (rtw_select_roaming_candidate(pmlmepriv) == _SUCCESS) {
+#ifdef CONFIG_RTW_80211R
+					rtw_ft_start_roam(adapter,
+						(u8 *)pmlmepriv->roam_network->network.MacAddress);
+#else
 					receive_disconnect(adapter, pmlmepriv->cur_network.network.MacAddress
 						, WLAN_REASON_ACTIVE_ROAM, _FALSE);
+#endif
 				}
 			}
 		}
 	}
-	
-	//DBG_871X("scan complete in %dms\n",rtw_get_passing_time_ms(pmlmepriv->scan_start_time));
+
+	/* RTW_INFO("scan complete in %dms\n",rtw_get_passing_time_ms(pmlmepriv->scan_start_time)); */
 
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
 #ifdef CONFIG_P2P_PS
-	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 		p2p_ps_wk_cmd(adapter, P2P_PS_SCAN_DONE, 0);
-	}
-#endif // CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
-	rtw_os_xmit_schedule(adapter);
-#ifdef CONFIG_CONCURRENT_MODE	
-	rtw_os_xmit_schedule(adapter->pbuddy_adapter);
-#endif
+	rtw_mi_os_xmit_schedule(adapter);
 
 #ifdef CONFIG_DRVEXT_MODULE_WSC
 	drvext_surveydone_callback(&adapter->drvextpriv);
@@ -1452,45 +1417,37 @@ _func_enter_;
 
 #ifdef DBG_CONFIG_ERROR_DETECT
 	{
-		struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;		
-		if(pmlmeext->sitesurvey_res.bss_cnt == 0){
-			//rtw_hal_sreset_reset(adapter);
+		struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+		if (pmlmeext->sitesurvey_res.bss_cnt == 0) {
+			/* rtw_hal_sreset_reset(adapter); */
 		}
 	}
 #endif
 
 #ifdef CONFIG_IOCTL_CFG80211
 	rtw_cfg80211_surveydone_event_callback(adapter);
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 	rtw_indicate_scan_done(adapter, _FALSE);
 
 #if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_IOCTL_CFG80211)
-	if (adapter->pbuddy_adapter) {
-		_adapter *buddy_adapter = adapter->pbuddy_adapter;
-		struct mlme_priv *buddy_mlme = &(buddy_adapter->mlmepriv);
-		struct rtw_wdev_priv *buddy_wdev_priv = adapter_wdev_data(buddy_adapter);
-		bool indicate_buddy_scan = _FALSE;
-
-		_enter_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
-		if (buddy_wdev_priv->scan_request && buddy_mlme->scanning_via_buddy_intf == _TRUE) {
-			buddy_mlme->scanning_via_buddy_intf = _FALSE;
-			clr_fwstate(buddy_mlme, _FW_UNDER_SURVEY);
-			indicate_buddy_scan = _TRUE;
-		}
-		_exit_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
+	rtw_cfg80211_indicate_scan_done_for_buddy(adapter, _FALSE);
+#endif
 
-		if (indicate_buddy_scan == _TRUE) {
-			#ifdef CONFIG_IOCTL_CFG80211
-			rtw_cfg80211_surveydone_event_callback(buddy_adapter);
-			#endif
-			rtw_indicate_scan_done(buddy_adapter, _FALSE);
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_OFFCH_CAND
+	if (rtw_mesh_offch_candidate_accepted(adapter)) {
+		u8 ch;
+
+		ch = rtw_mesh_select_operating_ch(adapter);
+		if (ch && pmlmepriv->cur_network.network.Configuration.DSConfig != ch) {
+			/* trigger channel switch with bw specified by upper layer */
+			rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_DIRECTLY, ch, adapter->mlmepriv.ori_bw, -1);
+			issue_probereq_ex(adapter, &pmlmepriv->cur_network.network.mesh_id, NULL, 0, 0, 0, 0);
 		}
 	}
-#endif /* CONFIG_CONCURRENT_MODE */
-
-_func_exit_;	
-
+	#endif
+#endif /* CONFIG_RTW_MESH */
 }
 
 void rtw_dummy_event_callback(_adapter *adapter , u8 *pbuf)
@@ -1509,138 +1466,129 @@ static void free_scanqueue(struct	mlme_priv *pmlmepriv)
 	_queue *free_queue = &pmlmepriv->free_bss_pool;
 	_queue *scan_queue = &pmlmepriv->scanned_queue;
 	_list	*plist, *phead, *ptemp;
-	
-_func_enter_;		
-	
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_, ("+free_scanqueue\n"));
+
+
 	_enter_critical_bh(&scan_queue->lock, &irqL0);
 	_enter_critical_bh(&free_queue->lock, &irqL);
 
 	phead = get_list_head(scan_queue);
 	plist = get_next(phead);
 
-	while (plist != phead)
-       {
+	while (plist != phead) {
 		ptemp = get_next(plist);
 		rtw_list_delete(plist);
 		rtw_list_insert_tail(plist, &free_queue->queue);
-		plist =ptemp;
-		pmlmepriv->num_of_scanned --;
-        }
-	
+		plist = ptemp;
+		pmlmepriv->num_of_scanned--;
+	}
+
 	_exit_critical_bh(&free_queue->lock, &irqL);
 	_exit_critical_bh(&scan_queue->lock, &irqL0);
-	
-_func_exit_;
+
 }
 
-void rtw_reset_rx_info(struct debug_priv *pdbgpriv){
-	pdbgpriv->dbg_rx_ampdu_drop_count = 0;
-	pdbgpriv->dbg_rx_ampdu_forced_indicate_count = 0;
-	pdbgpriv->dbg_rx_ampdu_loss_count = 0;
-	pdbgpriv->dbg_rx_dup_mgt_frame_drop_count = 0;
-	pdbgpriv->dbg_rx_ampdu_window_shift_cnt = 0;
+void rtw_reset_rx_info(_adapter *adapter)
+{
+	struct recv_priv  *precvpriv = &adapter->recvpriv;
+
+	precvpriv->dbg_rx_ampdu_drop_count = 0;
+	precvpriv->dbg_rx_ampdu_forced_indicate_count = 0;
+	precvpriv->dbg_rx_ampdu_loss_count = 0;
+	precvpriv->dbg_rx_dup_mgt_frame_drop_count = 0;
+	precvpriv->dbg_rx_ampdu_window_shift_cnt = 0;
+	precvpriv->dbg_rx_drop_count = 0;
+	precvpriv->dbg_rx_conflic_mac_addr_cnt = 0;
 }
-	
+
 /*
 *rtw_free_assoc_resources: the caller has to lock pmlmepriv->lock
 */
-void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue)
+void rtw_free_assoc_resources(_adapter *adapter, u8 lock_scanned_queue)
 {
 	_irqL irqL;
-	struct wlan_network* pwlan = NULL;
+	struct wlan_network *pwlan = NULL;
 	struct	mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct	sta_priv *pstapriv = &adapter->stapriv;
 	struct wlan_network *tgt_network = &pmlmepriv->cur_network;
-	struct dvobj_priv *psdpriv = adapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;	
 
-	
+
 #ifdef CONFIG_TDLS
 	struct tdls_info *ptdlsinfo = &adapter->tdlsinfo;
-#endif //CONFIG_TDLS
-_func_enter_;			
+#endif /* CONFIG_TDLS */
+
 
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_, ("+rtw_free_assoc_resources\n"));
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_, ("tgt_network->network.MacAddress="MAC_FMT" ssid=%s\n",
-		MAC_ARG(tgt_network->network.MacAddress), tgt_network->network.Ssid.Ssid));
+	RTW_INFO("%s-"ADPT_FMT" tgt_network MacAddress=" MAC_FMT" ssid=%s\n",
+		__func__, ADPT_ARG(adapter), MAC_ARG(tgt_network->network.MacAddress), tgt_network->network.Ssid.Ssid);
 
 	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-		struct sta_info* psta;
-		
+		struct sta_info *psta;
+
 		psta = rtw_get_stainfo(&adapter->stapriv, tgt_network->network.MacAddress);
 
 #ifdef CONFIG_TDLS
-		if (ptdlsinfo->link_established == _TRUE) {
+		rtw_free_all_tdls_sta(adapter, _TRUE);
+		rtw_reset_tdls_info(adapter);
+
+		if (ptdlsinfo->link_established == _TRUE)
 			rtw_tdls_cmd(adapter, NULL, TDLS_RS_RCR);
-			rtw_reset_tdls_info(adapter);
-			rtw_free_all_stainfo(adapter);
-			//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-		}
-		else
-#endif //CONFIG_TDLS
-		{
-			//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-			rtw_free_stainfo(adapter,  psta);
-		}
+#endif /* CONFIG_TDLS */
+
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
+		rtw_free_stainfo(adapter, psta);
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
 
-		//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-		
 	}
 
-	if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE|WIFI_ADHOC_MASTER_STATE)) {
-		struct sta_info* psta;
-	
+	if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
+		struct sta_info *psta;
+
 		rtw_free_all_stainfo(adapter);
 
 		psta = rtw_get_bcmc_stainfo(adapter);
-		//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
 		rtw_free_stainfo(adapter, psta);
-		//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
 
-		rtw_init_bcmc_stainfo(adapter);	
+		rtw_init_bcmc_stainfo(adapter);
 	}
 
-	if(lock_scanned_queue)
+	if (lock_scanned_queue)
 		_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-	
+
 	pwlan = _rtw_find_same_network(&pmlmepriv->scanned_queue, tgt_network);
-	if(pwlan)		
-	{
+	if ((pwlan)  && (!check_fwstate(pmlmepriv, WIFI_UNDER_WPS))) {
 		pwlan->fixed = _FALSE;
 
-                DBG_871X("free disconnecting network\n");
+		RTW_INFO("free disconnecting network of scanned_queue\n");
 		rtw_free_network_nolock(adapter, pwlan);
 #ifdef CONFIG_P2P
-		if(!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE))
-		{
-			rtw_set_scan_deny(adapter, 2000);
-			//rtw_clear_scan_deny(adapter);			
+		if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
+			rtw_mi_set_scan_deny(adapter, 2000);
+			/* rtw_clear_scan_deny(adapter);			 */
 		}
-#endif //CONFIG_P2P
-	}	
-	else
-	{
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("rtw_free_assoc_resources : pwlan== NULL \n\n"));
+#endif /* CONFIG_P2P */
+	} else {
+		if (pwlan == NULL)
+			RTW_INFO("free disconnecting network of scanned_queue failed due to pwlan== NULL\n\n");
+		if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
+			RTW_INFO("donot free disconnecting network of scanned_queue when WIFI_UNDER_WPS\n\n");
 	}
 
 
-	if((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) && (adapter->stapriv.asoc_sta_count== 1))
-		/*||check_fwstate(pmlmepriv, WIFI_STATION_STATE)*/)
-	{
+	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) && (adapter->stapriv.asoc_sta_count == 1))
+	    /*||check_fwstate(pmlmepriv, WIFI_STATION_STATE)*/) {
 		if (pwlan)
 			rtw_free_network_nolock(adapter, pwlan);
 	}
 
-	if(lock_scanned_queue)
+	if (lock_scanned_queue)
 		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-	
+
 	adapter->securitypriv.key_mask = 0;
 
-	rtw_reset_rx_info(pdbgpriv);
+	rtw_reset_rx_info(adapter);
+
 
-_func_exit_;	
-	
 }
 
 /*
@@ -1650,49 +1598,31 @@ void rtw_indicate_connect(_adapter *padapter)
 {
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
-	
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_, ("+rtw_indicate_connect\n"));
- 
+
+
 	pmlmepriv->to_join = _FALSE;
 
-	if(!check_fwstate(&padapter->mlmepriv, _FW_LINKED)) 
-	{
+	if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
 
 		set_fwstate(pmlmepriv, _FW_LINKED);
 
 		rtw_led_control(padapter, LED_CTL_LINK);
 
-	
-#ifdef CONFIG_DRVEXT_MODULE
-		if(padapter->drvextpriv.enable_wpa)
-		{
-			indicate_l2_connect(padapter);
-		}
-		else
-#endif
-		{
-			rtw_os_indicate_connect(padapter);
-		}
-
+		rtw_os_indicate_connect(padapter);
 	}
 
 	rtw_set_to_roam(padapter, 0);
 #ifdef CONFIG_INTEL_WIDI
-	if(padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_ROAMING)
-	{
+	if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_ROAMING) {
 		_rtw_memset(pmlmepriv->sa_ext, 0x00, L2SDTA_SERVICE_VE_LEN);
 		intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_WK, NULL, 0);
-		DBG_871X("change to widi listen\n");
+		RTW_INFO("change to widi listen\n");
 	}
-#endif // CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
+	if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
+		rtw_mi_set_scan_deny(padapter, 3000);
 
-	rtw_set_scan_deny(padapter, 3000);
-
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_, ("-rtw_indicate_connect: fw_state=0x%08x\n", get_fwstate(pmlmepriv)));
- 
-_func_exit_;
 
 }
 
@@ -1702,66 +1632,59 @@ _func_exit_;
 */
 void rtw_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)
 {
-	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;	
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX	*cur_network = &(pmlmeinfo->network);
 	struct sta_info *psta;
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 *wps_ie=NULL;
-	uint wpsie_len=0;
+	u8 *wps_ie = NULL;
+	uint wpsie_len = 0;
 
-_func_enter_;	
-	
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_, ("+rtw_indicate_disconnect\n"));
 
-	_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING|WIFI_UNDER_WPS);
 
-	// force to clear cur_network_scanned's SELECTED REGISTRAR
+	_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS);
+
+	/* force to clear cur_network_scanned's SELECTED REGISTRAR */
 	if (pmlmepriv->cur_network_scanned) {
 		WLAN_BSSID_EX	*current_joined_bss = &(pmlmepriv->cur_network_scanned->network);
 		if (current_joined_bss) {
-			wps_ie=rtw_get_wps_ie(current_joined_bss->IEs +_FIXED_IE_LENGTH_,
-				current_joined_bss->IELength-_FIXED_IE_LENGTH_, NULL, &wpsie_len);
-			if (wps_ie && wpsie_len>0) {
+			wps_ie = rtw_get_wps_ie(current_joined_bss->IEs + _FIXED_IE_LENGTH_,
+				current_joined_bss->IELength - _FIXED_IE_LENGTH_, NULL, &wpsie_len);
+			if (wps_ie && wpsie_len > 0) {
 				u8 *attr = NULL;
 				u32 attr_len;
-				attr=rtw_get_wps_attr(wps_ie, wpsie_len, WPS_ATTR_SELECTED_REGISTRAR,
-						       NULL, &attr_len);
+				attr = rtw_get_wps_attr(wps_ie, wpsie_len, WPS_ATTR_SELECTED_REGISTRAR,
+							NULL, &attr_len);
 				if (attr)
 					*(attr + 4) = 0;
 			}
 		}
 	}
-        //DBG_871X("clear wps when %s\n", __func__);
+	/* RTW_INFO("clear wps when %s\n", __func__); */
 
-	if(rtw_to_roam(padapter) > 0)
+	if (rtw_to_roam(padapter) > 0)
 		_clr_fwstate_(pmlmepriv, _FW_LINKED);
 
 #ifdef CONFIG_WAPI_SUPPORT
-	psta = rtw_get_stainfo(pstapriv,cur_network->MacAddress);
+	psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
 	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
-	{
-		rtw_wapi_return_one_sta_info(padapter, psta->hwaddr);
-	}
+		rtw_wapi_return_one_sta_info(padapter, psta->cmn.mac_addr);
 	else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
-		check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))
-	{
+		 check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))
 		rtw_wapi_return_all_sta_info(padapter);
-	}
 #endif
 
-	if(check_fwstate(&padapter->mlmepriv, _FW_LINKED) 
-		|| (rtw_to_roam(padapter) <= 0)
-	)
-	{
+	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)
+	    || (rtw_to_roam(padapter) <= 0)
+	   ) {
 
 		rtw_os_indicate_disconnect(padapter, reason, locally_generated);
 
-		//set ips_deny_time to avoid enter IPS before LPS leave
+		/* set ips_deny_time to avoid enter IPS before LPS leave */
 		rtw_set_ips_deny(padapter, 3000);
 
-	      _clr_fwstate_(pmlmepriv, _FW_LINKED);
+		_clr_fwstate_(pmlmepriv, _FW_LINKED);
 
 		rtw_led_control(padapter, LED_CTL_NO_LINK);
 
@@ -1770,7 +1693,7 @@ _func_enter_;
 
 #ifdef CONFIG_P2P_PS
 	p2p_ps_wk_cmd(padapter, P2P_PS_DISABLE, 1);
-#endif // CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
 #ifdef CONFIG_LPS
 	rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_DISCONNECT, 1);
@@ -1780,67 +1703,65 @@ _func_enter_;
 	beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_LEAVE, cur_network->MacAddress, ETH_ALEN, 1);
 #endif /*CONFIG_BEAMFORMING*/
 
-_func_exit_;	
 }
 
-inline void rtw_indicate_scan_done( _adapter *padapter, bool aborted)
+inline void rtw_indicate_scan_done(_adapter *padapter, bool aborted)
 {
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
 
 	rtw_os_indicate_scan_done(padapter, aborted);
 
 #ifdef CONFIG_IPS
 	if (is_primary_adapter(padapter)
-		&& (_FALSE == adapter_to_pwrctl(padapter)->bInSuspend)
-		&& (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE|WIFI_UNDER_LINKING) == _FALSE))
-	{
+	    && (_FALSE == adapter_to_pwrctl(padapter)->bInSuspend)
+	    && (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE | WIFI_UNDER_LINKING) == _FALSE)) {
 		struct pwrctrl_priv *pwrpriv;
 
 		pwrpriv = adapter_to_pwrctl(padapter);
 		rtw_set_ips_deny(padapter, 0);
 #ifdef CONFIG_IPS_CHECK_IN_WD
-		_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 1);
-#else // !CONFIG_IPS_CHECK_IN_WD
+		_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 1);
+#else /* !CONFIG_IPS_CHECK_IN_WD */
 		_rtw_set_pwr_state_check_timer(pwrpriv, 1);
-#endif // !CONFIG_IPS_CHECK_IN_WD
+#endif /* !CONFIG_IPS_CHECK_IN_WD */
 	}
-#endif // CONFIG_IPS
+#endif /* CONFIG_IPS */
 }
 
 static u32 _rtw_wait_scan_done(_adapter *adapter, u8 abort, u32 timeout_ms)
 {
-	u32 start;
+	systime start;
 	u32 pass_ms;
 	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
 	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
 
 	start = rtw_get_current_time();
-	
+
 	pmlmeext->scan_abort = abort;
-	
+
 	while (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)
-		&& rtw_get_passing_time_ms(start) <= timeout_ms) {
+	       && rtw_get_passing_time_ms(start) <= timeout_ms) {
 
 		if (RTW_CANNOT_RUN(adapter))
 			break;
 
-		DBG_871X(FUNC_NDEV_FMT"fw_state=_FW_UNDER_SURVEY!\n", FUNC_NDEV_ARG(adapter->pnetdev));
+		RTW_INFO(FUNC_NDEV_FMT"fw_state=_FW_UNDER_SURVEY!\n", FUNC_NDEV_ARG(adapter->pnetdev));
 		rtw_msleep_os(20);
 	}
 
 	if (_TRUE == abort) {
 		if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
 			if (!RTW_CANNOT_RUN(adapter))
-				DBG_871X(FUNC_NDEV_FMT"waiting for scan_abort time out!\n", FUNC_NDEV_ARG(adapter->pnetdev));
-			#ifdef CONFIG_PLATFORM_MSTAR
+				RTW_INFO(FUNC_NDEV_FMT"waiting for scan_abort time out!\n", FUNC_NDEV_ARG(adapter->pnetdev));
+#ifdef CONFIG_PLATFORM_MSTAR
 			/*_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);*/
 			set_survey_timer(pmlmeext, 0);
 			mlme_set_scan_to_timer(pmlmepriv, 50);
-			#endif
+#endif
 			rtw_indicate_scan_done(adapter, _TRUE);
 		}
 	}
-	
+
 	pmlmeext->scan_abort = _FALSE;
 	pass_ms = rtw_get_passing_time_ms(start);
 
@@ -1850,17 +1771,11 @@ static u32 _rtw_wait_scan_done(_adapter *adapter, u8 abort, u32 timeout_ms)
 
 void rtw_scan_wait_completed(_adapter *adapter)
 {
-	u32 scan_to = SCANNING_TIMEOUT;
-
-#ifdef CONFIG_SCAN_BACKOP
-	if (IsSupported5G(adapter->registrypriv.wireless_mode) 
-		&& IsSupported24G(adapter->registrypriv.wireless_mode)) /*dual band*/
-		scan_to = CONC_SCANNING_TIMEOUT_DUAL_BAND;
-	else /*single band*/
-		scan_to = CONC_SCANNING_TIMEOUT_SINGLE_BAND;
-#endif /* CONFIG_SCAN_BACKOP */
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct ss_res *ss = &pmlmeext->sitesurvey_res;
 
-	_rtw_wait_scan_done(adapter, _FALSE, scan_to);
+	_rtw_wait_scan_done(adapter, _FALSE, ss->scan_timeout_ms);
 }
 
 u32 rtw_scan_abort_timeout(_adapter *adapter, u32 timeout_ms)
@@ -1882,427 +1797,406 @@ void rtw_scan_abort(_adapter *adapter)
 	rtw_scan_abort_timeout(adapter, 200);
 }
 
+static u32 _rtw_wait_join_done(_adapter *adapter, u8 abort, u32 timeout_ms)
+{
+	systime start;
+	u32 pass_ms;
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	start = rtw_get_current_time();
+
+	pmlmeext->join_abort = abort;
+	if (abort)
+		set_link_timer(pmlmeext, 1);
+
+	while (rtw_get_passing_time_ms(start) <= timeout_ms
+		&& (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)
+			#ifdef CONFIG_IOCTL_CFG80211
+			|| rtw_cfg80211_is_connect_requested(adapter)
+			#endif
+			)
+	) {
+		if (RTW_CANNOT_RUN(adapter))
+			break;
+
+		RTW_INFO(FUNC_ADPT_FMT" linking...\n", FUNC_ADPT_ARG(adapter));
+		rtw_msleep_os(20);
+	}
+
+	if (abort) {
+		if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)
+			#ifdef CONFIG_IOCTL_CFG80211
+			|| rtw_cfg80211_is_connect_requested(adapter)
+			#endif
+		) {
+			if (!RTW_CANNOT_RUN(adapter))
+				RTW_INFO(FUNC_ADPT_FMT" waiting for join_abort time out!\n", FUNC_ADPT_ARG(adapter));
+		}
+	}
+
+	pmlmeext->join_abort = 0;
+	pass_ms = rtw_get_passing_time_ms(start);
+
+	return pass_ms;
+}
+
+u32 rtw_join_abort_timeout(_adapter *adapter, u32 timeout_ms)
+{
+	return _rtw_wait_join_done(adapter, _TRUE, timeout_ms);
+}
+
 static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wlan_network *pnetwork)
 {
 	int i;
-	struct sta_info *bmc_sta, *psta=NULL;
+	struct sta_info *psta = NULL;
 	struct recv_reorder_ctrl *preorder_ctrl;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 
 	psta = rtw_get_stainfo(pstapriv, pnetwork->network.MacAddress);
-	if(psta==NULL) {
+	if (psta == NULL)
 		psta = rtw_alloc_stainfo(pstapriv, pnetwork->network.MacAddress);
-	}
-
-	if(psta) //update ptarget_sta
-	{
-		DBG_871X("%s\n", __FUNCTION__);
-	
-		psta->aid  = pnetwork->join_res;
 
-#if 0 //alloc macid when call rtw_alloc_stainfo(), and release macid when call rtw_free_stainfo()
-#ifdef CONFIG_CONCURRENT_MODE	
+	if (psta) { /* update ptarget_sta */
+		RTW_INFO("%s\n", __FUNCTION__);
 
-		if(PRIMARY_ADAPTER == padapter->adapter_type)
-			psta->mac_id=0;
-		else
-			psta->mac_id=2;
-#else
-		psta->mac_id=0;
-#endif
-#endif //removed
+		psta->cmn.aid  = pnetwork->join_res;
 
 		update_sta_info(padapter, psta);
 
-		//update station supportRate
+		/* update station supportRate */
 		psta->bssratelen = rtw_get_rateset_len(pnetwork->network.SupportedRates);
 		_rtw_memcpy(psta->bssrateset, pnetwork->network.SupportedRates, psta->bssratelen);
-		rtw_hal_update_sta_rate_mask(padapter, psta);
+		rtw_hal_update_sta_ra_info(padapter, psta);
 
 		psta->wireless_mode = pmlmeext->cur_wireless_mode;
-		psta->raid = rtw_hal_networktype_to_raid(padapter,psta);
-
-
-		//sta mode
-		rtw_hal_set_odm_var(padapter,HAL_ODM_STA_INFO,psta,_TRUE);
-
-		//security related
-		if(padapter->securitypriv.dot11AuthAlgrthm== dot11AuthAlgrthm_8021X)
-		{						
-			padapter->securitypriv.binstallGrpkey=_FALSE;
-			padapter->securitypriv.busetkipkey=_FALSE;						
-			padapter->securitypriv.bgrpkey_handshake=_FALSE;
-
-			psta->ieee8021x_blocked=_TRUE;
-			psta->dot118021XPrivacy=padapter->securitypriv.dot11PrivacyAlgrthm;
-						
-			_rtw_memset((u8 *)&psta->dot118021x_UncstKey, 0, sizeof (union Keytype));
-						
-			_rtw_memset((u8 *)&psta->dot11tkiprxmickey, 0, sizeof (union Keytype));
-			_rtw_memset((u8 *)&psta->dot11tkiptxmickey, 0, sizeof (union Keytype));
-						
-			_rtw_memset((u8 *)&psta->dot11txpn, 0, sizeof (union pn48));
-			psta->dot11txpn.val = psta->dot11txpn.val + 1;
-#ifdef CONFIG_IEEE80211W
-			_rtw_memset((u8 *)&psta->dot11wtxpn, 0, sizeof (union pn48));
-#endif //CONFIG_IEEE80211W
-			_rtw_memset((u8 *)&psta->dot11rxpn, 0, sizeof (union pn48));	
+		rtw_hal_update_sta_wset(padapter, psta);
+
+		/* sta mode */
+		rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
+
+		/* security related */
+#ifdef CONFIG_RTW_80211R
+		if ((padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
+			&& (psta->ft_pairwise_key_installed == _FALSE)) {
+#else
+		if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
+#endif
+			u8 *ie;
+			sint ie_len;
+			u8 mfp_opt = MFP_NO;
+
+			padapter->securitypriv.binstallGrpkey = _FALSE;
+			padapter->securitypriv.busetkipkey = _FALSE;
+			padapter->securitypriv.bgrpkey_handshake = _FALSE;
+
+			ie = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, WLAN_EID_RSN
+				, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
+			if (ie && ie_len > 0
+				&& rtw_parse_wpa2_ie(ie, ie_len + 2, NULL, NULL, NULL, &mfp_opt) == _SUCCESS
+			) {
+				if (padapter->securitypriv.mfp_opt >= MFP_OPTIONAL && mfp_opt >= MFP_OPTIONAL)
+					psta->flags |= WLAN_STA_MFP;
+			}
+
+			psta->ieee8021x_blocked = _TRUE;
+			psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+
+			_rtw_memset((u8 *)&psta->dot118021x_UncstKey, 0, sizeof(union Keytype));
+			_rtw_memset((u8 *)&psta->dot11tkiprxmickey, 0, sizeof(union Keytype));
+			_rtw_memset((u8 *)&psta->dot11tkiptxmickey, 0, sizeof(union Keytype));
 		}
 
-		//	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 tramsmitted.
-		if ( padapter->securitypriv.wps_ie_len != 0 )
-		{
-			psta->ieee8021x_blocked=_TRUE;
+		/*	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 tramsmitted. */
+		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, reseting  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];
+		/* for A-MPDU Rx reordering buffer control for sta_info */
+		/* if A-MPDU Rx is enabled, reseting  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;
 			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d indicate_seq:%u \n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq);
+			RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_CLEAR indicate_seq:%u\n"
+				, FUNC_ADPT_ARG(padapter), i, preorder_ctrl->indicate_seq);
 			#endif
-			preorder_ctrl->wend_b= 0xffff;
-			preorder_ctrl->wsize_b = 64;//max_ampdu_sz;//ex. 32(kbytes) -> wsize_b=32
+			preorder_ctrl->wend_b = 0xffff;
+			preorder_ctrl->wsize_b = 64;/* max_ampdu_sz; */ /* ex. 32(kbytes) -> wsize_b=32 */
 			preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
 		}
-
-		
-		bmc_sta = rtw_get_bcmc_stainfo(padapter);
-		if(bmc_sta)
-		{
-			for(i=0; i < 16 ; i++)
-			{
-				//preorder_ctrl = &precvpriv->recvreorder_ctrl[i];
-				preorder_ctrl = &bmc_sta->recvreorder_ctrl[i];
-				preorder_ctrl->enable = _FALSE;
-				preorder_ctrl->indicate_seq = 0xffff;
-				#ifdef DBG_RX_SEQ
-				DBG_871X("DBG_RX_SEQ %s:%d indicate_seq:%u \n", __FUNCTION__, __LINE__,
-					preorder_ctrl->indicate_seq);
-				#endif
-				preorder_ctrl->wend_b= 0xffff;
-				preorder_ctrl->wsize_b = 64;//max_ampdu_sz;//ex. 32(kbytes) -> wsize_b=32
-				preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
-			}
-		}
 	}
-					
+
+#ifdef	CONFIG_RTW_80211K
+	_rtw_memcpy(&psta->rm_en_cap, pnetwork->network.PhyInfo.rm_en_cap, 5);
+#endif
+
 	return psta;
-	
+
 }
 
-//pnetwork : returns from rtw_joinbss_event_callback
-//ptarget_wlan: found from scanned_queue
+/* pnetwork : returns from rtw_joinbss_event_callback
+ * ptarget_wlan: found from scanned_queue */
 static void rtw_joinbss_update_network(_adapter *padapter, struct wlan_network *ptarget_wlan, struct wlan_network  *pnetwork)
 {
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);	
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
 
-	DBG_871X("%s\n", __FUNCTION__);
-	
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("\nfw_state:%x, BSSID:"MAC_FMT"\n"
-		,get_fwstate(pmlmepriv), MAC_ARG(pnetwork->network.MacAddress)));
+	RTW_INFO("%s\n", __FUNCTION__);
+
+
 
-				
-	// why not use ptarget_wlan??
+	/* why not use ptarget_wlan?? */
 	_rtw_memcpy(&cur_network->network, &pnetwork->network, pnetwork->network.Length);
-	// some IEs in pnetwork is wrong, so we should use ptarget_wlan IEs
+	/* some IEs in pnetwork is wrong, so we should use ptarget_wlan IEs */
 	cur_network->network.IELength = ptarget_wlan->network.IELength;
 	_rtw_memcpy(&cur_network->network.IEs[0], &ptarget_wlan->network.IEs[0], MAX_IE_SZ);
 
 	cur_network->aid = pnetwork->join_res;
 
-				
+
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	rtw_set_signal_stat_timer(&padapter->recvpriv);
 #endif
 	padapter->recvpriv.signal_strength = ptarget_wlan->network.PhyInfo.SignalStrength;
 	padapter->recvpriv.signal_qual = ptarget_wlan->network.PhyInfo.SignalQuality;
-	//the ptarget_wlan->network.Rssi is raw data, we use ptarget_wlan->network.PhyInfo.SignalStrength instead (has scaled)
+	/* the ptarget_wlan->network.Rssi is raw data, we use ptarget_wlan->network.PhyInfo.SignalStrength instead (has scaled) */
 	padapter->recvpriv.rssi = translate_percentage_to_dbm(ptarget_wlan->network.PhyInfo.SignalStrength);
-	#if defined(DBG_RX_SIGNAL_DISPLAY_PROCESSING) && 1
-		DBG_871X(FUNC_ADPT_FMT" signal_strength:%3u, rssi:%3d, signal_qual:%3u"
-			"\n"
-			, FUNC_ADPT_ARG(padapter)
-			, padapter->recvpriv.signal_strength
-			, padapter->recvpriv.rssi
-			, padapter->recvpriv.signal_qual
-	);
-	#endif
+#if defined(DBG_RX_SIGNAL_DISPLAY_PROCESSING) && 1
+	RTW_INFO(FUNC_ADPT_FMT" signal_strength:%3u, rssi:%3d, signal_qual:%3u"
+		 "\n"
+		 , FUNC_ADPT_ARG(padapter)
+		 , padapter->recvpriv.signal_strength
+		 , padapter->recvpriv.rssi
+		 , padapter->recvpriv.signal_qual
+		);
+#endif
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	rtw_set_signal_stat_timer(&padapter->recvpriv);
 #endif
-				
-	//update fw_state //will clr _FW_UNDER_LINKING here indirectly
-	switch(pnetwork->network.InfrastructureMode)
-	{	
-		case Ndis802_11Infrastructure:						
-			
-				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 Ndis802_11IBSS:		
-				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;
+
+	/* update fw_state */ /* will clr _FW_UNDER_LINKING here indirectly */
+
+	switch (pnetwork->network.InfrastructureMode) {
+	case Ndis802_11Infrastructure:
+
+		if (pmlmepriv->fw_state & WIFI_UNDER_WPS)
+			/*pmlmepriv->fw_state = WIFI_STATION_STATE|WIFI_UNDER_WPS;*/
+			init_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_UNDER_WPS);
+		else
+			/*pmlmepriv->fw_state = WIFI_STATION_STATE;*/
+			init_fwstate(pmlmepriv, WIFI_STATION_STATE);
+		break;
+	case Ndis802_11IBSS:
+		/*pmlmepriv->fw_state = WIFI_ADHOC_STATE;*/
+		init_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
+		break;
+	default:
+		/*pmlmepriv->fw_state = WIFI_NULL_STATE;*/
+		init_fwstate(pmlmepriv, WIFI_NULL_STATE);
+		break;
 	}
 
-	rtw_update_protection(padapter, (cur_network->network.IEs) + sizeof (NDIS_802_11_FIXED_IEs), 
-									(cur_network->network.IELength));
+	rtw_update_protection(padapter, (cur_network->network.IEs) + sizeof(NDIS_802_11_FIXED_IEs),
+			      (cur_network->network.IELength));
 
-#ifdef CONFIG_80211N_HT			
+#ifdef CONFIG_80211N_HT
 	rtw_update_ht_cap(padapter, cur_network->network.IEs, cur_network->network.IELength, (u8) cur_network->network.Configuration.DSConfig);
 #endif
 }
 
-//Notes: the fucntion could be > passive_level (the same context as Rx tasklet)
-//pnetwork : returns from rtw_joinbss_event_callback
-//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).
-//
-//#define REJOIN
-void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
-{
-	_irqL irqL,irqL2;
-	static u8 retry=0;
-	u8 timer_cancelled;
-	struct sta_info *ptarget_sta= NULL, *pcur_sta = NULL;
-   	struct	sta_priv *pstapriv = &adapter->stapriv;
+/* Notes: the fucntion could be > passive_level (the same context as Rx tasklet)
+ * pnetwork : returns from rtw_joinbss_event_callback
+ * 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).
+ */
+/* #define REJOIN */
+void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf, u16 status)
+{
+	_irqL irqL, irqL2;
+	static u8 retry = 0;
+	struct sta_info *ptarget_sta = NULL, *pcur_sta = NULL;
+	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	*pnetwork	= (struct wlan_network *)pbuf;
+	struct wlan_network	*cur_network = &(pmlmepriv->cur_network);
 	struct wlan_network	*pcur_wlan = NULL, *ptarget_wlan = NULL;
-	unsigned int 		the_same_macaddr = _FALSE;	
+	unsigned int		the_same_macaddr = _FALSE;
 
-_func_enter_;	
 
 #ifdef CONFIG_RTL8712
-       //endian_convert
+	/* endian_convert */
 	pnetwork->join_res = le32_to_cpu(pnetwork->join_res);
 	pnetwork->network_type = le32_to_cpu(pnetwork->network_type);
 	pnetwork->network.Length = le32_to_cpu(pnetwork->network.Length);
 	pnetwork->network.Ssid.SsidLength = le32_to_cpu(pnetwork->network.Ssid.SsidLength);
-	pnetwork->network.Privacy =le32_to_cpu( pnetwork->network.Privacy);
+	pnetwork->network.Privacy = le32_to_cpu(pnetwork->network.Privacy);
 	pnetwork->network.Rssi = le32_to_cpu(pnetwork->network.Rssi);
-	pnetwork->network.NetworkTypeInUse =le32_to_cpu(pnetwork->network.NetworkTypeInUse) ;	
+	pnetwork->network.NetworkTypeInUse = le32_to_cpu(pnetwork->network.NetworkTypeInUse) ;
 	pnetwork->network.Configuration.ATIMWindow = le32_to_cpu(pnetwork->network.Configuration.ATIMWindow);
 	pnetwork->network.Configuration.BeaconPeriod = le32_to_cpu(pnetwork->network.Configuration.BeaconPeriod);
 	pnetwork->network.Configuration.DSConfig = le32_to_cpu(pnetwork->network.Configuration.DSConfig);
-	pnetwork->network.Configuration.FHConfig.DwellTime=le32_to_cpu(pnetwork->network.Configuration.FHConfig.DwellTime);
-	pnetwork->network.Configuration.FHConfig.HopPattern=le32_to_cpu(pnetwork->network.Configuration.FHConfig.HopPattern);
-	pnetwork->network.Configuration.FHConfig.HopSet=le32_to_cpu(pnetwork->network.Configuration.FHConfig.HopSet);
-	pnetwork->network.Configuration.FHConfig.Length=le32_to_cpu(pnetwork->network.Configuration.FHConfig.Length);	
+	pnetwork->network.Configuration.FHConfig.DwellTime = le32_to_cpu(pnetwork->network.Configuration.FHConfig.DwellTime);
+	pnetwork->network.Configuration.FHConfig.HopPattern = le32_to_cpu(pnetwork->network.Configuration.FHConfig.HopPattern);
+	pnetwork->network.Configuration.FHConfig.HopSet = le32_to_cpu(pnetwork->network.Configuration.FHConfig.HopSet);
+	pnetwork->network.Configuration.FHConfig.Length = le32_to_cpu(pnetwork->network.Configuration.FHConfig.Length);
 	pnetwork->network.Configuration.Length = le32_to_cpu(pnetwork->network.Configuration.Length);
 	pnetwork->network.InfrastructureMode = le32_to_cpu(pnetwork->network.InfrastructureMode);
-	pnetwork->network.IELength = le32_to_cpu(pnetwork->network.IELength );
+	pnetwork->network.IELength = le32_to_cpu(pnetwork->network.IELength);
 #endif
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("joinbss event call back received with res=%d\n", pnetwork->join_res));
 
 	rtw_get_encrypt_decrypt_from_registrypriv(adapter);
-	
 
-	if (pmlmepriv->assoc_ssid.SsidLength == 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_,("@@@@@   rtw_joinbss_event_callback for SSid:%s\n", pmlmepriv->assoc_ssid.Ssid));
-	}
-	
+
+
 	the_same_macaddr = _rtw_memcmp(pnetwork->network.MacAddress, cur_network->network.MacAddress, ETH_ALEN);
 
 	pnetwork->network.Length = get_WLAN_BSSID_EX_sz(&pnetwork->network);
-	if(pnetwork->network.Length > sizeof(WLAN_BSSID_EX))
-	{
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n\n ***joinbss_evt_callback return a wrong bss ***\n\n"));
+	if (pnetwork->network.Length > sizeof(WLAN_BSSID_EX)) {
 		goto ignore_joinbss_callback;
 	}
-		
+
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
-	
+
 	pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
 	pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
-	
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("\n rtw_joinbss_event_callback !! _enter_critical \n"));
 
-	if(pnetwork->join_res > 0)
-	{
+
+	if (pnetwork->join_res > 0) {
 		_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 		retry = 0;
-		if (check_fwstate(pmlmepriv,_FW_UNDER_LINKING) )
-		{
-			//s1. find ptarget_wlan
-			if(check_fwstate(pmlmepriv, _FW_LINKED) )
-			{
-				if(the_same_macaddr == _TRUE)
-				{
-					ptarget_wlan = rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);					
-				}
-				else
-				{
-					pcur_wlan = rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
-					if(pcur_wlan)	pcur_wlan->fixed = _FALSE;
+		if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
+			/* s1. find ptarget_wlan */
+			if (check_fwstate(pmlmepriv, _FW_LINKED)) {
+				if (the_same_macaddr == _TRUE)
+					ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
+				else {
+					pcur_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
+					if (pcur_wlan)
+						pcur_wlan->fixed = _FALSE;
 
 					pcur_sta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
-					if(pcur_sta){
-						//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
+					if (pcur_sta) {
+						/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
 						rtw_free_stainfo(adapter,  pcur_sta);
-						//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
+						/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
 					}
 
-					ptarget_wlan = rtw_find_network(&pmlmepriv->scanned_queue, pnetwork->network.MacAddress);
-					if(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE){
-						if(ptarget_wlan)	ptarget_wlan->fixed = _TRUE;			
+					ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, pnetwork->network.MacAddress);
+					if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+						if (ptarget_wlan)
+							ptarget_wlan->fixed = _TRUE;
 					}
 				}
 
-			}
-			else
-			{
+			} else {
 				ptarget_wlan = _rtw_find_same_network(&pmlmepriv->scanned_queue, pnetwork);
-				if(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE){
-					if(ptarget_wlan)	ptarget_wlan->fixed = _TRUE;			
+				if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+					if (ptarget_wlan)
+						ptarget_wlan->fixed = _TRUE;
 				}
 			}
-		
-			//s2. update cur_network 
-			if(ptarget_wlan)
-			{			
+
+			/* s2. update cur_network */
+			if (ptarget_wlan)
 				rtw_joinbss_update_network(adapter, ptarget_wlan, pnetwork);
-			}
-			else
-			{			
-				DBG_871X_LEVEL(_drv_always_, "Can't find ptarget_wlan when joinbss_event callback\n");
+			else {
+				RTW_PRINT("Can't find ptarget_wlan when joinbss_event callback\n");
 				_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 				goto ignore_joinbss_callback;
 			}
-					
-			
-			//s3. find ptarget_sta & update ptarget_sta after update cur_network only for station mode 
+
+
+			/* s3. find ptarget_sta & update ptarget_sta after update cur_network only for station mode */
 			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
 				ptarget_sta = rtw_joinbss_update_stainfo(adapter, pnetwork);
 				if (ptarget_sta == NULL) {
-					DBG_871X_LEVEL(_drv_err_, "Can't update stainfo when joinbss_event callback\n");
+					RTW_ERR("Can't update stainfo when joinbss_event callback\n");
 					_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 					goto ignore_joinbss_callback;
 				}
 			}
 
-			//s4. indicate connect			
+			/* s4. indicate connect			 */
 			if (MLME_IS_STA(adapter) || MLME_IS_ADHOC(adapter)) {
 				pmlmepriv->cur_network_scanned = ptarget_wlan;
 				rtw_indicate_connect(adapter);
 			}
-				
-			//s5. Cancle assoc_timer					
-			_cancel_timer(&pmlmepriv->assoc_timer, &timer_cancelled);
-		
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("Cancle assoc_timer \n"));		
-		
-		}
-		else
-		{
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("rtw_joinbss_event_callback err: fw_state:%x", get_fwstate(pmlmepriv)));	
+
+			/* s5. Cancle assoc_timer					 */
+			_cancel_timer_ex(&pmlmepriv->assoc_timer);
+
+
+		} else {
 			_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 			goto ignore_joinbss_callback;
 		}
-		
-		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);	
-				
-	}
-	else if(pnetwork->join_res == -4) 
-	{
+
+		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	} else if (pnetwork->join_res == -4) {
 		rtw_reset_securitypriv(adapter);
-		_set_timer(&pmlmepriv->assoc_timer, 1);					
+		pmlmepriv->join_status = status;
+		_set_timer(&pmlmepriv->assoc_timer, 1);
 
-		//rtw_free_assoc_resources(adapter, 1);
+		/* rtw_free_assoc_resources(adapter, _TRUE); */
 
-		if((check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) == _TRUE)
-		{		
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("fail! clear _FW_UNDER_LINKING ^^^fw_state=%x\n", get_fwstate(pmlmepriv)));
+		if ((check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) == _TRUE) {
 			_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-		}	
-		
-	}
-	else //if join_res < 0 (join fails), then try again
-	{
-	
-		#ifdef REJOIN
+		}
+
+	} else { /* if join_res < 0 (join fails), then try again */
+
+#ifdef REJOIN
 		res = _FAIL;
-		if(retry < 2) {
+		if (retry < 2) {
 			res = rtw_select_and_join_from_scanned_queue(pmlmepriv);
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("rtw_select_and_join_from_scanned_queue again! res:%d\n",res));
 		}
 
-		 if(res == _SUCCESS)
-		{
-			//extend time of assoc_timer
+		if (res == _SUCCESS) {
+			/* extend time of assoc_timer */
 			_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
 			retry++;
-		}
-		else if(res == 2)//there is no need to wait for join
-		{
+		} else if (res == 2) { /* there is no need to wait for join */
 			_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
 			rtw_indicate_connect(adapter);
-		}	
-		else
-		{
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("Set Assoc_Timer = 1; can't find match ssid in scanned_q \n"));
-		#endif
-			
+		} else {
+#endif
+			pmlmepriv->join_status = status;
 			_set_timer(&pmlmepriv->assoc_timer, 1);
-			//rtw_free_assoc_resources(adapter, 1);
+			/* rtw_free_assoc_resources(adapter, _TRUE); */
 			_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-			
-		#ifdef REJOIN
-			retry = 0;	
+
+#ifdef REJOIN
+			retry = 0;
 		}
-		#endif
+#endif
 	}
 
 ignore_joinbss_callback:
-
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
-	_func_exit_;	
 }
 
 void rtw_joinbss_event_callback(_adapter *adapter, u8 *pbuf)
 {
-	struct wlan_network 	*pnetwork	= (struct wlan_network *)pbuf;
+	struct wlan_network	*pnetwork	= (struct wlan_network *)pbuf;
 
-_func_enter_;
 
 	mlmeext_joinbss_event_callback(adapter, pnetwork->join_res);
 
-	rtw_os_xmit_schedule(adapter);
-
-#ifdef CONFIG_CONCURRENT_MODE	
-	rtw_os_xmit_schedule(adapter->pbuddy_adapter);
-#endif	
+	rtw_mi_os_xmit_schedule(adapter);
 
-_func_exit_;
 }
 
 void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool connected)
@@ -2313,35 +2207,35 @@ void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool conn
 	u8 role = H2C_MSR_ROLE_RSVD;
 
 	if (sta == NULL) {
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" sta is NULL\n"
-			, FUNC_ADPT_ARG(adapter));
+		RTW_PRINT(FUNC_ADPT_FMT" sta is NULL\n"
+			  , FUNC_ADPT_ARG(adapter));
 		rtw_warn_on(1);
 		return;
 	}
 
-	if (sta->mac_id >= macid_ctl->num) {
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" invalid macid:%u\n"
-			, FUNC_ADPT_ARG(adapter), sta->mac_id);
+	if (sta->cmn.mac_id >= macid_ctl->num) {
+		RTW_PRINT(FUNC_ADPT_FMT" invalid macid:%u\n"
+			  , FUNC_ADPT_ARG(adapter), sta->cmn.mac_id);
 		rtw_warn_on(1);
 		return;
 	}
 
-	if (!rtw_macid_is_used(macid_ctl, sta->mac_id)) {
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" macid:%u not is used, set connected to 0\n"
-			, FUNC_ADPT_ARG(adapter), sta->mac_id);
+	if (!rtw_macid_is_used(macid_ctl, sta->cmn.mac_id)) {
+		RTW_PRINT(FUNC_ADPT_FMT" macid:%u not is used, set connected to 0\n"
+			  , FUNC_ADPT_ARG(adapter), sta->cmn.mac_id);
 		connected = 0;
 		rtw_warn_on(1);
 	}
 
-	if (connected && !rtw_macid_is_bmc(macid_ctl, sta->mac_id)) {
+	if (connected && !rtw_macid_is_bmc(macid_ctl, sta->cmn.mac_id)) {
 		miracast_enabled = STA_OP_WFD_MODE(sta) != 0 && is_miracast_enabled(adapter);
 		miracast_sink = miracast_enabled && (STA_OP_WFD_MODE(sta) & MIRACAST_SINK);
 
-		#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS
 		if (sta->tdls_sta_state & TDLS_LINKED_STATE)
 			role = H2C_MSR_ROLE_TDLS;
 		else
-		#endif
+#endif
 		if (MLME_IS_STA(adapter)) {
 			if (MLME_IS_GC(adapter))
 				role = H2C_MSR_ROLE_GO;
@@ -2354,8 +2248,10 @@ void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool conn
 				role = H2C_MSR_ROLE_STA;
 		} else if (MLME_IS_ADHOC(adapter) || MLME_IS_ADHOC_MASTER(adapter))
 			role = H2C_MSR_ROLE_ADHOC;
+		else if (MLME_IS_MESH(adapter))
+			role = H2C_MSR_ROLE_MESH;
 
-		#ifdef CONFIG_WFD
+#ifdef CONFIG_WFD
 		if (role == H2C_MSR_ROLE_GC
 			|| role == H2C_MSR_ROLE_GO
 			|| role == H2C_MSR_ROLE_TDLS
@@ -2365,7 +2261,7 @@ void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool conn
 				|| adapter->wfd_info.peer_rtsp_ctrlport)
 				rtw_wfd_st_switch(sta, 1);
 		}
-		#endif
+#endif
 	}
 
 	rtw_hal_set_FwMediaStatusRpt_single_cmd(adapter
@@ -2373,7 +2269,7 @@ void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool conn
 		, miracast_enabled
 		, miracast_sink
 		, role
-		, sta->mac_id
+		, sta->cmn.mac_id
 	);
 }
 
@@ -2428,103 +2324,102 @@ inline void rtw_sta_media_status_rpt_cmd_hdl(_adapter *adapter, struct sta_media
 
 void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf)
 {
-	_irqL irqL;	
+	_irqL irqL;
 	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 stassoc_event	*pstassoc	= (struct stassoc_event *)pbuf;
+	struct wlan_network	*cur_network = &(pmlmepriv->cur_network);
 	struct wlan_network	*ptarget_wlan = NULL;
-	
-_func_enter_;	
-	
-	if(rtw_access_ctrl(adapter, pstassoc->macaddr) == _FALSE)
+
+
+#if CONFIG_RTW_MACADDR_ACL
+	if (rtw_access_ctrl(adapter, pstassoc->macaddr) == _FALSE)
 		return;
+#endif
 
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE))
-	{
-		psta = rtw_get_stainfo(&adapter->stapriv, pstassoc->macaddr);	
-		if(psta)
-		{		
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
+		psta = rtw_get_stainfo(&adapter->stapriv, pstassoc->macaddr);
+		if (psta) {
 			u8 *passoc_req = NULL;
 			u32 assoc_req_len = 0;
-		
+
 			rtw_sta_media_status_rpt(adapter, psta, 1);
-		
-#ifndef CONFIG_AUTO_AP_MODE
 
+#ifdef CONFIG_MCC_MODE
+			rtw_hal_mcc_update_macid_bitmap(adapter, psta->cmn.mac_id, _TRUE);
+#endif /* CONFIG_MCC_MODE */
+
+#ifndef CONFIG_AUTO_AP_MODE
 			ap_sta_info_defer_update(adapter, psta);
 
-			//report to upper layer 
-			DBG_871X("indicate_sta_assoc_event to upper layer - hostapd\n");
-#ifdef CONFIG_IOCTL_CFG80211
-			_enter_critical_bh(&psta->lock, &irqL);
-			if(psta->passoc_req && psta->assoc_req_len>0)
-			{				
-				passoc_req = rtw_zmalloc(psta->assoc_req_len);
-				if(passoc_req)
-				{
-					assoc_req_len = psta->assoc_req_len;
-					_rtw_memcpy(passoc_req, psta->passoc_req, assoc_req_len);
-					
-					rtw_mfree(psta->passoc_req , psta->assoc_req_len);
-					psta->passoc_req = NULL;
-					psta->assoc_req_len = 0;
+			if (!MLME_IS_MESH(adapter)) {
+				/* report to upper layer */
+				RTW_INFO("indicate_sta_assoc_event to upper layer - hostapd\n");
+				#ifdef CONFIG_IOCTL_CFG80211
+				_enter_critical_bh(&psta->lock, &irqL);
+				if (psta->passoc_req && psta->assoc_req_len > 0) {
+					passoc_req = rtw_zmalloc(psta->assoc_req_len);
+					if (passoc_req) {
+						assoc_req_len = psta->assoc_req_len;
+						_rtw_memcpy(passoc_req, psta->passoc_req, assoc_req_len);
+
+						rtw_mfree(psta->passoc_req , psta->assoc_req_len);
+						psta->passoc_req = NULL;
+						psta->assoc_req_len = 0;
+					}
 				}
-			}			
-			_exit_critical_bh(&psta->lock, &irqL);
-
-			if(passoc_req && assoc_req_len>0)
-			{
-				rtw_cfg80211_indicate_sta_assoc(adapter, passoc_req, assoc_req_len);
+				_exit_critical_bh(&psta->lock, &irqL);
 
-				rtw_mfree(passoc_req, assoc_req_len);
-			}			
-#else //!CONFIG_IOCTL_CFG80211	
-			rtw_indicate_sta_assoc_event(adapter, psta);
-#endif //!CONFIG_IOCTL_CFG80211
-#endif //!CONFIG_AUTO_AP_MODE
+				if (passoc_req && assoc_req_len > 0) {
+					rtw_cfg80211_indicate_sta_assoc(adapter, passoc_req, assoc_req_len);
+					rtw_mfree(passoc_req, assoc_req_len);
+				}
+				#else /* !CONFIG_IOCTL_CFG80211	 */
+				rtw_indicate_sta_assoc_event(adapter, psta);
+				#endif /* !CONFIG_IOCTL_CFG80211 */
+			}
+#endif /* !CONFIG_AUTO_AP_MODE */
 
 #ifdef CONFIG_BEAMFORMING
 			beamforming_wk_cmd(adapter, BEAMFORMING_CTRL_ENTER, (u8 *)psta, sizeof(struct sta_info), 0);
 #endif/*CONFIG_BEAMFORMING*/
-		}		
+			if (is_wep_enc(adapter->securitypriv.dot11PrivacyAlgrthm))
+				rtw_ap_wep_pk_setting(adapter, psta);
+		}
 		goto exit;
-	}	
-#endif //defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	}
+#endif /* defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 
 	/* for AD-HOC mode */
 	psta = rtw_get_stainfo(&adapter->stapriv, pstassoc->macaddr);
 	if (psta == NULL) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" get no sta_info with "MAC_FMT"\n"
+		RTW_ERR(FUNC_ADPT_FMT" get no sta_info with "MAC_FMT"\n"
 			, FUNC_ADPT_ARG(adapter), MAC_ARG(pstassoc->macaddr));
 		rtw_warn_on(1);
 		goto exit;
 	}
 
-	rtw_hal_set_odm_var(adapter,HAL_ODM_STA_INFO,psta,_TRUE);
-
 	rtw_sta_media_status_rpt(adapter, psta, 1);
-	
-	if(adapter->securitypriv.dot11AuthAlgrthm==dot11AuthAlgrthm_8021X)
+
+	if (adapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
 		psta->dot118021XPrivacy = adapter->securitypriv.dot11PrivacyAlgrthm;
-	
 
-	psta->ieee8021x_blocked = _FALSE;		
-	
+
+	psta->ieee8021x_blocked = _FALSE;
+
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	if ( (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)==_TRUE ) || 
-		(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)==_TRUE ) )
-	{
-		if(adapter->stapriv.asoc_sta_count== 2)
-		{
+	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)) {
+		if (adapter->stapriv.asoc_sta_count == 2) {
 			_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-			ptarget_wlan = rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
+			ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
 			pmlmepriv->cur_network_scanned = ptarget_wlan;
-			if(ptarget_wlan)	ptarget_wlan->fixed = _TRUE;
+			if (ptarget_wlan)
+				ptarget_wlan->fixed = _TRUE;
 			_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-			// a sta + bc/mc_stainfo (not Ibss_stainfo)
+			/* a sta + bc/mc_stainfo (not Ibss_stainfo) */
 			rtw_indicate_connect(adapter);
 		}
 	}
@@ -2533,16 +2428,14 @@ _func_enter_;
 
 
 	mlmeext_sta_add_event_callback(adapter, psta);
-	
+
 #ifdef CONFIG_RTL8711
-	//submit SetStaKey_cmd to tell fw, fw will allocate an CAM entry for this sta	
+	/* submit SetStaKey_cmd to tell fw, fw will allocate an CAM entry for this sta	 */
 	rtw_setstakey_cmd(adapter, psta, GROUP_KEY, _TRUE);
 #endif
-		
-exit:
-	
-_func_exit_;	
 
+exit:
+	return;
 }
 
 #ifdef CONFIG_IEEE80211W
@@ -2552,14 +2445,13 @@ void rtw_sta_timeout_event_callback(_adapter *adapter, u8 *pbuf)
 	struct sta_info *psta;
 	struct stadel_event *pstadel = (struct stadel_event *)pbuf;
 	struct sta_priv *pstapriv = &adapter->stapriv;
-	
-_func_enter_;
-	
+
+
 	psta = rtw_get_stainfo(&adapter->stapriv, pstadel->macaddr);
 
 	if (psta) {
 		u8 updated = _FALSE;
-		
+
 		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 		if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
 			rtw_list_delete(&psta->asoc_list);
@@ -2571,181 +2463,389 @@ _func_enter_;
 		associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
 	}
 
-	
-_func_exit_;	
+
 
 }
 #endif /* CONFIG_IEEE80211W */
 
+#ifdef CONFIG_RTW_80211R
+void rtw_ft_info_init(struct ft_roam_info *pft)
+{
+	_rtw_memset(pft, 0, sizeof(struct ft_roam_info));
+	pft->ft_flags = 0
+		| RTW_FT_EN
+		| RTW_FT_OTD_EN
+#ifdef CONFIG_RTW_BTM_ROAM
+		| RTW_FT_BTM_ROAM
+#endif
+		;
+	pft->ft_updated_bcn = _FALSE;
+}
+
+u8 rtw_ft_chk_roaming_candidate(
+	_adapter *padapter, struct wlan_network *competitor)
+{
+	u8 *pmdie;
+	u32 mdie_len = 0;
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+
+	if (!(pmdie = rtw_get_ie(&competitor->network.IEs[12],
+			_MDIE_, &mdie_len, competitor->network.IELength-12)))
+		return _FALSE;
+
+	if (!_rtw_memcmp(&pft_roam->mdid, (pmdie+2), 2))
+		return _FALSE;
+
+	/*The candidate don't support over-the-DS*/
+	if (rtw_ft_valid_otd_candidate(padapter, pmdie)) {
+		RTW_INFO("FT: ignore the candidate("
+			MAC_FMT ") for over-the-DS\n", 
+			MAC_ARG(competitor->network.MacAddress));
+			rtw_ft_clr_flags(padapter, RTW_FT_PEER_OTD_EN);
+		return _FALSE;	
+	}
+
+	return _TRUE;
+}
+
+void rtw_ft_update_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
+{
+	struct sta_priv		*pstapriv = &padapter->stapriv;
+	struct sta_info		*psta = NULL;
+
+	psta = rtw_get_stainfo(pstapriv, pnetwork->MacAddress);
+	if (psta == NULL)
+		psta = rtw_alloc_stainfo(pstapriv, pnetwork->MacAddress);
+
+	if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
+
+		padapter->securitypriv.binstallGrpkey = _FALSE;
+		padapter->securitypriv.busetkipkey = _FALSE;
+		padapter->securitypriv.bgrpkey_handshake = _FALSE;
+
+		psta->ieee8021x_blocked = _TRUE;
+		psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+
+		_rtw_memset((u8 *)&psta->dot118021x_UncstKey, 0, sizeof(union Keytype));
+		_rtw_memset((u8 *)&psta->dot11tkiprxmickey, 0, sizeof(union Keytype));
+		_rtw_memset((u8 *)&psta->dot11tkiptxmickey, 0, sizeof(union Keytype));
+	}
+
+}
+
+void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct stassoc_event *pstassoc = (struct stassoc_event *)pbuf;
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&(pmlmeinfo->network);
+	struct cfg80211_ft_event_params ft_evt_parms;
+	_irqL irqL;
+
+	_rtw_memset(&ft_evt_parms, 0, sizeof(ft_evt_parms));
+	rtw_ft_update_stainfo(padapter, pnetwork);
+	ft_evt_parms.ies_len = pft_roam->ft_event.ies_len;
+	ft_evt_parms.ies =  rtw_zmalloc(ft_evt_parms.ies_len);
+	if (ft_evt_parms.ies)
+		_rtw_memcpy((void *)ft_evt_parms.ies, pft_roam->ft_event.ies, ft_evt_parms.ies_len);
+	 else
+		goto err_2;
+
+	ft_evt_parms.target_ap = rtw_zmalloc(ETH_ALEN);
+	if (ft_evt_parms.target_ap)
+		_rtw_memcpy((void *)ft_evt_parms.target_ap, pstassoc->macaddr, ETH_ALEN);
+	else
+		goto err_1;
+
+	ft_evt_parms.ric_ies = pft_roam->ft_event.ric_ies;
+	ft_evt_parms.ric_ies_len = pft_roam->ft_event.ric_ies_len;
+
+	rtw_ft_lock_set_status(padapter, RTW_FT_AUTHENTICATED_STA, &irqL);
+	rtw_cfg80211_ft_event(padapter, &ft_evt_parms);
+	RTW_INFO("%s: to "MAC_FMT"\n", __func__, MAC_ARG(ft_evt_parms.target_ap));
+
+	rtw_mfree((u8 *)pft_roam->ft_event.target_ap, ETH_ALEN);
+err_1:
+	rtw_mfree((u8 *)ft_evt_parms.ies, ft_evt_parms.ies_len);
+err_2:
+	return;
+}
+#endif
+
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+void rtw_roam_nb_info_init(_adapter *padapter)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	
+	_rtw_memset(&pnb->nb_rpt, 0, sizeof(pnb->nb_rpt));
+	_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
+	_rtw_memset(&pnb->roam_target_addr, 0, ETH_ALEN);
+	pnb->nb_rpt_valid = _FALSE;
+	pnb->nb_rpt_ch_list_num = 0;
+	pnb->preference_en = _FALSE;
+	pnb->nb_rpt_is_same = _TRUE;
+	pnb->last_nb_rpt_entries = 0;
+#ifdef CONFIG_RTW_WNM
+	rtw_init_timer(&pnb->roam_scan_timer, 
+		padapter, rtw_wnm_roam_scan_hdl, 
+		padapter);
+#endif
+}
+
+u8 rtw_roam_nb_scan_list_set(
+	_adapter *padapter, struct sitesurvey_parm *pparm)
+{
+	u8 ret = _FALSE;
+	u32 i;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct roam_nb_info *pnb = &(pmlmepriv->nb_info);
+
+	if (!rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE))
+		return ret;
+
+	if (!pmlmepriv->need_to_roam)
+		return ret;
+
+	if ((!pmlmepriv->nb_info.nb_rpt_valid) || (!pnb->nb_rpt_ch_list_num))
+		return ret;
+
+	if (!pparm)
+		return ret;
+
+	rtw_init_sitesurvey_parm(padapter, pparm);
+	if (rtw_roam_busy_scan(padapter, pnb)) {
+		pparm->ch_num = 1;
+		pparm->ch[pmlmepriv->ch_cnt].hw_value = 
+			pnb->nb_rpt_ch_list[pmlmepriv->ch_cnt].hw_value;
+		pmlmepriv->ch_cnt++;
+		ret = _TRUE;
+		if (pmlmepriv->ch_cnt == pnb->nb_rpt_ch_list_num) {
+			pmlmepriv->nb_info.nb_rpt_valid = _FALSE;
+			pmlmepriv->ch_cnt = 0;
+		}
+		goto set_bssid_list;
+	}
+
+	pparm->ch_num = (pnb->nb_rpt_ch_list_num > RTW_CHANNEL_SCAN_AMOUNT)?
+		(RTW_CHANNEL_SCAN_AMOUNT):(pnb->nb_rpt_ch_list_num);
+	for (i=0; i<pparm->ch_num; i++) {
+		pparm->ch[i].hw_value = pnb->nb_rpt_ch_list[i].hw_value;
+		pparm->ch[i].flags = RTW_IEEE80211_CHAN_PASSIVE_SCAN;
+	}
+
+	pmlmepriv->nb_info.nb_rpt_valid = _FALSE;
+	pmlmepriv->ch_cnt = 0;		
+	ret = _TRUE;
+
+set_bssid_list:
+	rtw_set_802_11_bssid_list_scan(padapter, pparm);
+	return ret;
+}
+#endif
+
+void rtw_sta_mstatus_disc_rpt(_adapter *adapter, u8 mac_id)
+{
+	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
+
+	if (mac_id >= 0 && mac_id < macid_ctl->num) {
+		u8 id_is_shared = mac_id == RTW_DEFAULT_MGMT_MACID; /* TODO: real shared macid judgment */
+
+		RTW_INFO(FUNC_ADPT_FMT" - mac_id=%d%s\n", FUNC_ADPT_ARG(adapter)
+			, mac_id, id_is_shared ? " shared" : "");
+
+		if (!id_is_shared) {
+			rtw_hal_set_FwMediaStatusRpt_single_cmd(adapter, 0, 0, 0, 0, mac_id);
+			/*
+			 * For safety, prevent from keeping macid sleep.
+			 * If we can sure all power mode enter/leave are paired,
+			 * this check can be removed.
+			 * Lucas@20131113
+			 */
+			/* wakeup macid after disconnect. */
+			/*if (MLME_IS_STA(adapter))*/
+			rtw_hal_macid_wakeup(adapter, mac_id);
+		}
+	} else {
+		RTW_PRINT(FUNC_ADPT_FMT" invalid macid:%u\n"
+			  , FUNC_ADPT_ARG(adapter), mac_id);
+		rtw_warn_on(1);
+	}
+}
+void rtw_sta_mstatus_report(_adapter *adapter)
+{
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct wlan_network *tgt_network = &pmlmepriv->cur_network;
+	struct sta_info *psta = NULL;
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) && check_fwstate(pmlmepriv, WIFI_ASOC_STATE)) {
+		psta = rtw_get_stainfo(&adapter->stapriv, tgt_network->network.MacAddress);
+		if (psta)
+			rtw_sta_mstatus_disc_rpt(adapter, psta->cmn.mac_id);
+		else {
+			RTW_INFO("%s "ADPT_FMT" - mac_addr: "MAC_FMT" psta == NULL\n", __func__, ADPT_ARG(adapter), MAC_ARG(tgt_network->network.MacAddress));
+			rtw_warn_on(1);
+		}
+	}
+}
+
 void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 {
-	_irqL irqL,irqL2;
-	int mac_id = (-1);
+	_irqL irqL, irqL2;
+
 	struct sta_info *psta;
-	struct wlan_network* pwlan = NULL;
-	WLAN_BSSID_EX    *pdev_network=NULL;
-	u8* pibss = NULL;
+	struct wlan_network *pwlan = NULL;
+	WLAN_BSSID_EX    *pdev_network = NULL;
+	u8 *pibss = NULL;
 	struct	mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
-	struct 	stadel_event *pstadel	= (struct stadel_event*)pbuf;
-   	struct	sta_priv *pstapriv = &adapter->stapriv;
+	struct	stadel_event *pstadel	= (struct stadel_event *)pbuf;
+	struct	sta_priv *pstapriv = &adapter->stapriv;
 	struct wlan_network *tgt_network = &(pmlmepriv->cur_network);
 	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
 
-_func_enter_;	
-	
+
+	RTW_INFO("%s(mac_id=%d)=" MAC_FMT "\n", __func__, pstadel->mac_id, MAC_ARG(pstadel->macaddr));
+	rtw_sta_mstatus_disc_rpt(adapter, pstadel->mac_id);
+
+#ifdef CONFIG_MCC_MODE
+	rtw_hal_mcc_update_macid_bitmap(adapter, pstadel->mac_id, _FALSE);
+#endif /* CONFIG_MCC_MODE */
+
 	psta = rtw_get_stainfo(&adapter->stapriv, pstadel->macaddr);
-	if(psta)
-		mac_id = psta->mac_id;
-	else
-		mac_id = pstadel->mac_id;
 
-	DBG_871X("%s(mac_id=%d)=" MAC_FMT "\n", __func__, mac_id, MAC_ARG(pstadel->macaddr));
+	if (psta == NULL) {
+		RTW_INFO("%s(mac_id=%d)=" MAC_FMT " psta == NULL\n", __func__, pstadel->mac_id, MAC_ARG(pstadel->macaddr));
+		/*rtw_warn_on(1);*/
+	}
 
-	if (mac_id >= 0 && mac_id < macid_ctl->num) {
-		rtw_hal_set_FwMediaStatusRpt_single_cmd(adapter, 0, 0, 0, 0, mac_id);
-		/*
-		 * For safety, prevent from keeping macid sleep.
-		 * If we can sure all power mode enter/leave are paired,
-		 * this check can be removed.
-		 * Lucas@20131113
-		 */
-		/* wakeup macid after disconnect. */
-		if (MLME_IS_STA(adapter))
-			rtw_hal_macid_wakeup(adapter, mac_id);
+	if (psta)
+		rtw_wfd_st_switch(psta, 0);
 
-		if (psta)
-			rtw_wfd_st_switch(psta, 0);
-	} else {
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" invalid macid:%u\n"
-			, FUNC_ADPT_ARG(adapter), mac_id);
-		rtw_warn_on(1);
+	if (MLME_IS_MESH(adapter)) {
+		rtw_free_stainfo(adapter, psta);
+		return;
 	}
 
-	//if(check_fwstate(pmlmepriv, WIFI_AP_STATE))
-	if((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
+	if (MLME_IS_AP(adapter)) {
 #ifdef CONFIG_IOCTL_CFG80211
-		#ifdef COMPAT_KERNEL_RELEASE
-
-		#elif (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,37)) || defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
-		rtw_cfg80211_indicate_sta_disassoc(adapter, pstadel->macaddr, *(u16*)pstadel->rsvd);
-		#endif //(LINUX_VERSION_CODE < KERNEL_VERSION(2,6,37)) || defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
-#endif //CONFIG_IOCTL_CFG80211
+#ifdef COMPAT_KERNEL_RELEASE
 
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 37)) || defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
+		rtw_cfg80211_indicate_sta_disassoc(adapter, pstadel->macaddr, *(u16 *)pstadel->rsvd);
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 37)) || defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER) */
+#endif /* CONFIG_IOCTL_CFG80211 */
+		rtw_free_stainfo(adapter, psta);
 		return;
 	}
 
-
 	mlmeext_sta_del_event_callback(adapter);
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL2);
 
-	if(check_fwstate(pmlmepriv, WIFI_STATION_STATE) )
-	{
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
 		u16 reason = *((unsigned short *)(pstadel->rsvd));
 		bool roam = _FALSE;
 		struct wlan_network *roam_target = NULL;
 
-		#ifdef CONFIG_LAYER2_ROAMING
-		if(adapter->registrypriv.wifi_spec==1) {
+#ifdef CONFIG_LAYER2_ROAMING
+#ifdef CONFIG_RTW_80211R
+		if (rtw_ft_roam_expired(adapter, reason))
+			pmlmepriv->ft_roam.ft_roam_on_expired = _TRUE;
+		else
+			pmlmepriv->ft_roam.ft_roam_on_expired = _FALSE;
+#endif
+		if (adapter->registrypriv.wifi_spec == 1)
 			roam = _FALSE;
-		} else if (reason == WLAN_REASON_EXPIRATION_CHK && rtw_chk_roam_flags(adapter, RTW_ROAM_ON_EXPIRED)) {
+		else if (reason == WLAN_REASON_EXPIRATION_CHK && rtw_chk_roam_flags(adapter, RTW_ROAM_ON_EXPIRED))
 			roam = _TRUE;
-		} else if (reason == WLAN_REASON_ACTIVE_ROAM && rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
+		else if (reason == WLAN_REASON_ACTIVE_ROAM && rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
 			roam = _TRUE;
 			roam_target = pmlmepriv->roam_network;
 		}
 #ifdef CONFIG_INTEL_WIDI
-		else if (adapter->mlmepriv.widi_state == INTEL_WIDI_STATE_CONNECTED) {
+		else if (adapter->mlmepriv.widi_state == INTEL_WIDI_STATE_CONNECTED)
 			roam = _TRUE;
-		}
-#endif // CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
 		if (roam == _TRUE) {
 			if (rtw_to_roam(adapter) > 0)
 				rtw_dec_to_roam(adapter); /* this stadel_event is caused by roaming, decrease to_roam */
 			else if (rtw_to_roam(adapter) == 0)
 				rtw_set_to_roam(adapter, adapter->registrypriv.max_roaming_times);
-		} else {
+		} else
 			rtw_set_to_roam(adapter, 0);
-		}
-		#endif /* CONFIG_LAYER2_ROAMING */
+#endif /* CONFIG_LAYER2_ROAMING */
 
 		rtw_free_uc_swdec_pending_queue(adapter);
 
-		rtw_free_assoc_resources(adapter, 1);
-		rtw_indicate_disconnect(adapter, *(u16 *)pstadel->rsvd, pstadel->locally_generated);
+		rtw_free_assoc_resources(adapter, _TRUE);
 		rtw_free_mlme_priv_ie_data(pmlmepriv);
 
 		_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-		// remove the network entry in scanned_queue
-		pwlan = rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);	
-		if (pwlan) {			
+		/* remove the network entry in scanned_queue */
+		pwlan = _rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);
+		if ((pwlan)  && (!check_fwstate(pmlmepriv, WIFI_UNDER_WPS))) {
 			pwlan->fixed = _FALSE;
 			rtw_free_network_nolock(adapter, pwlan);
 		}
 		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
+		rtw_indicate_disconnect(adapter, *(u16 *)pstadel->rsvd, pstadel->locally_generated);
 #ifdef CONFIG_INTEL_WIDI
 		if (!rtw_to_roam(adapter))
 			process_intel_widi_disconnect(adapter, 1);
-#endif // CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
 		_rtw_roaming(adapter, roam_target);
 	}
 
-	if ( check_fwstate(pmlmepriv,WIFI_ADHOC_MASTER_STATE) || 
-	      check_fwstate(pmlmepriv,WIFI_ADHOC_STATE))
-	{
-		
-		//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
+	if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) ||
+	    check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
+
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
 		rtw_free_stainfo(adapter,  psta);
-		//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-		
-		if(adapter->stapriv.asoc_sta_count== 1) //a sta + bc/mc_stainfo (not Ibss_stainfo)
-		{ 
-			//rtw_indicate_disconnect(adapter);//removed@20091105
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
+
+		if (adapter->stapriv.asoc_sta_count == 1) { /* a sta + bc/mc_stainfo (not Ibss_stainfo) */
+			/* rtw_indicate_disconnect(adapter); */ /* removed@20091105 */
 			_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-			//free old ibss network
-			//pwlan = rtw_find_network(&pmlmepriv->scanned_queue, pstadel->macaddr);
-			pwlan = rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);
-			if(pwlan)	
-			{
+			/* free old ibss network */
+			/* pwlan = _rtw_find_network(&pmlmepriv->scanned_queue, pstadel->macaddr); */
+			pwlan = _rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);
+			if (pwlan) {
 				pwlan->fixed = _FALSE;
-				rtw_free_network_nolock(adapter, pwlan); 
+				rtw_free_network_nolock(adapter, pwlan);
 			}
 			_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-			//re-create ibss
-			pdev_network = &(adapter->registrypriv.dev_network);			
+			/* re-create ibss */
+			pdev_network = &(adapter->registrypriv.dev_network);
 			pibss = adapter->registrypriv.dev_network.MacAddress;
 
 			_rtw_memcpy(pdev_network, &tgt_network->network, get_WLAN_BSSID_EX_sz(&tgt_network->network));
-			
+
 			_rtw_memset(&pdev_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
 			_rtw_memcpy(&pdev_network->Ssid, &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
-	
-			rtw_update_registrypriv_dev_network(adapter);			
+
+			rtw_update_registrypriv_dev_network(adapter);
 
 			rtw_generate_random_ibss(pibss);
-			
-			if(check_fwstate(pmlmepriv,WIFI_ADHOC_STATE))
-			{
+
+			if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
 				set_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
 				_clr_fwstate_(pmlmepriv, WIFI_ADHOC_STATE);
 			}
 
 			if (rtw_create_ibss_cmd(adapter, 0) != _SUCCESS)
-				RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_, ("***Error=>stadel_event_callback: rtw_create_ibss_cmd status FAIL***\n"));
+				RTW_ERR("rtw_create_ibss_cmd FAIL\n");
 
 		}
-		
+
 	}
-	
+
 	_exit_critical_bh(&pmlmepriv->lock, &irqL2);
-	
-_func_exit_;	
+
 
 }
 
@@ -2756,36 +2856,31 @@ void rtw_cpwm_event_callback(PADAPTER padapter, u8 *pbuf)
 	struct reportpwrstate_parm *preportpwrstate;
 #endif
 
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("+rtw_cpwm_event_callback !!!\n"));
 #ifdef CONFIG_LPS_LCLK
-	preportpwrstate = (struct reportpwrstate_parm*)pbuf;
+	preportpwrstate = (struct reportpwrstate_parm *)pbuf;
 	preportpwrstate->state |= (u8)(adapter_to_pwrctl(padapter)->cpwm_tog + 0x80);
 	cpwm_int_hdl(padapter, preportpwrstate);
 #endif
 
-_func_exit_;
 
 }
 
 
 void rtw_wmm_event_callback(PADAPTER padapter, u8 *pbuf)
 {
-_func_enter_;
 
 	WMMOnAssocRsp(padapter);
 
-_func_exit_;
 
 }
 
 /*
-* _rtw_join_timeout_handler - Timeout/faliure handler for CMD JoinBss
-* @adapter: pointer to _adapter structure
+* rtw_join_timeout_handler - Timeout/failure handler for CMD JoinBss
 */
-void _rtw_join_timeout_handler (_adapter *adapter)
+void rtw_join_timeout_handler(void *ctx)
 {
+	_adapter *adapter = (_adapter *)ctx;
 	_irqL irqL;
 	struct	mlme_priv *pmlmepriv = &adapter->mlmepriv;
 
@@ -2794,68 +2889,72 @@ void _rtw_join_timeout_handler (_adapter *adapter)
 		_rtw_up_sema(&pmlmepriv->assoc_terminate);
 		return;
 	}
-#endif	
+#endif
 
-_func_enter_;		
 
 
-	DBG_871X("%s, fw_state=%x\n", __FUNCTION__, get_fwstate(pmlmepriv));
-	
+	RTW_INFO("%s, fw_state=%x\n", __FUNCTION__, get_fwstate(pmlmepriv));
+
 	if (RTW_CANNOT_RUN(adapter))
 		return;
 
-	
+
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
-	#ifdef CONFIG_LAYER2_ROAMING
+#ifdef CONFIG_LAYER2_ROAMING
 	if (rtw_to_roam(adapter) > 0) { /* join timeout caused by roaming */
-		while(1) {
+		while (1) {
 			rtw_dec_to_roam(adapter);
 			if (rtw_to_roam(adapter) != 0) { /* try another */
 				int do_join_r;
-				DBG_871X("%s try another roaming\n", __FUNCTION__);
-				if( _SUCCESS!=(do_join_r=rtw_do_join(adapter)) ) {
-					DBG_871X("%s roaming do_join return %d\n", __FUNCTION__ ,do_join_r);
+				RTW_INFO("%s try another roaming\n", __FUNCTION__);
+				do_join_r = rtw_do_join(adapter);
+				if (_SUCCESS != do_join_r) {
+					RTW_INFO("%s roaming do_join return %d\n", __FUNCTION__ , do_join_r);
 					continue;
 				}
 				break;
 			} else {
 #ifdef CONFIG_INTEL_WIDI
-				if(adapter->mlmepriv.widi_state == INTEL_WIDI_STATE_ROAMING)
-				{
+				if (adapter->mlmepriv.widi_state == INTEL_WIDI_STATE_ROAMING) {
 					_rtw_memset(pmlmepriv->sa_ext, 0x00, L2SDTA_SERVICE_VE_LEN);
 					intel_widi_wk_cmd(adapter, INTEL_WIDI_LISTEN_WK, NULL, 0);
-					DBG_871X("change to widi listen\n");
+					RTW_INFO("change to widi listen\n");
 				}
-#endif // CONFIG_INTEL_WIDI
-				DBG_871X("%s We've try roaming but fail\n", __FUNCTION__);
-				rtw_indicate_disconnect(adapter, 0, _FALSE);
+#endif /* CONFIG_INTEL_WIDI */
+				RTW_INFO("%s We've try roaming but fail\n", __FUNCTION__);
+#ifdef CONFIG_RTW_80211R
+				rtw_ft_clr_flags(adapter, RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN);
+				rtw_ft_reset_status(adapter);
+#endif
+				rtw_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
 				break;
 			}
 		}
-		
-	} else 
-	#endif
+
+	} else
+#endif
 	{
-		rtw_indicate_disconnect(adapter, 0, _FALSE);
-		free_scanqueue(pmlmepriv);//???
+		rtw_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
+		free_scanqueue(pmlmepriv);/* ??? */
 
 #ifdef CONFIG_IOCTL_CFG80211
-		//indicate disconnect for the case that join_timeout and check_fwstate != FW_LINKED
-		rtw_cfg80211_indicate_disconnect(adapter, 0, _FALSE);
-#endif //CONFIG_IOCTL_CFG80211
+		/* indicate disconnect for the case that join_timeout and check_fwstate != FW_LINKED */
+		rtw_cfg80211_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+	}
 
- 	}
+	pmlmepriv->join_status = 0; /* reset */
 
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
-	
 
-#ifdef CONFIG_DRVEXT_MODULE_WSC	
-	drvext_assoc_fail_indicate(&adapter->drvextpriv);	
-#endif	
 
-	
-_func_exit_;
+#ifdef CONFIG_DRVEXT_MODULE_WSC
+	drvext_assoc_fail_indicate(&adapter->drvextpriv);
+#endif
+
+
 
 }
 
@@ -2863,241 +2962,383 @@ _func_exit_;
 * rtw_scan_timeout_handler - Timeout/Faliure handler for CMD SiteSurvey
 * @adapter: pointer to _adapter structure
 */
-void rtw_scan_timeout_handler (_adapter *adapter)
-{	
+void rtw_scan_timeout_handler(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
 	_irqL irqL;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	DBG_871X(FUNC_ADPT_FMT" fw_state=%x\n", FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
+	RTW_INFO(FUNC_ADPT_FMT" fw_state=%x\n", FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
-	
+
 	_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
-	
+
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
-	
+
 #ifdef CONFIG_IOCTL_CFG80211
 	rtw_cfg80211_surveydone_event_callback(adapter);
-#endif //CONFIG_IOCTL_CFG80211
-	
+#endif /* CONFIG_IOCTL_CFG80211 */
+
 	rtw_indicate_scan_done(adapter, _TRUE);
 
 #if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_IOCTL_CFG80211)
-	if (adapter->pbuddy_adapter) {
-		_adapter *buddy_adapter = adapter->pbuddy_adapter;
-		struct mlme_priv *buddy_mlme = &(buddy_adapter->mlmepriv);
-		struct rtw_wdev_priv *buddy_wdev_priv = adapter_wdev_data(buddy_adapter);
-		bool indicate_buddy_scan = _FALSE;
-
-		_enter_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
-		if (buddy_wdev_priv->scan_request && buddy_mlme->scanning_via_buddy_intf == _TRUE) {
-			buddy_mlme->scanning_via_buddy_intf = _FALSE;
-			clr_fwstate(buddy_mlme, _FW_UNDER_SURVEY);
-			indicate_buddy_scan = _TRUE;
-		}
-		_exit_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
-
-		if (indicate_buddy_scan == _TRUE) {
-			rtw_indicate_scan_done(buddy_adapter, _TRUE);
-		}
-	}
-#endif /* CONFIG_CONCURRENT_MODE */
+	rtw_cfg80211_indicate_scan_done_for_buddy(adapter, _TRUE);
+#endif
 }
 
-void rtw_mlme_reset_auto_scan_int(_adapter *adapter)
+void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason)
 {
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	struct mlme_priv *mlme = &adapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-#ifdef CONFIG_P2P
-	if(!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
-		mlme->auto_scan_int_ms = 0; /* disabled */
-		goto exit;
-	}
-#endif	
-	if(pmlmeinfo->VHT_enable) //disable auto scan when connect to 11AC AP
-	{
-		mlme->auto_scan_int_ms = 0;
-	}
-	else if(adapter->registrypriv.wifi_spec && is_client_associated_to_ap(adapter) == _TRUE) {
-		mlme->auto_scan_int_ms = 60*1000;
-#ifdef CONFIG_LAYER2_ROAMING
-	} else if(rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
-		if (check_fwstate(mlme, WIFI_STATION_STATE) && check_fwstate(mlme, _FW_LINKED))
-			mlme->auto_scan_int_ms = mlme->roam_scan_int_ms;
-#endif
-	} else {
-		mlme->auto_scan_int_ms = 0; /* disabled */
+	u8 u_ch;
+	u32 interval_ms = 0xffffffff; /* 0xffffffff: special value to make min() works well, also means no auto scan */
+
+	*reason = RTW_AUTO_SCAN_REASON_UNSPECIFIED;
+	rtw_mi_get_ch_setting_union(adapter, &u_ch, NULL, NULL);
+
+	if (hal_chk_bw_cap(adapter, BW_CAP_40M)
+		&& is_client_associated_to_ap(adapter) == _TRUE
+		&& u_ch >= 1 && u_ch <= 14
+		&& adapter->registrypriv.wifi_spec
+		/* TODO: AP Connected is 40MHz capability? */
+	) {
+		interval_ms = rtw_min(interval_ms, 60 * 1000);
+		*reason |= RTW_AUTO_SCAN_REASON_2040_BSS;
+	}
+
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_OFFCH_CAND
+	if (adapter->mesh_cfg.peer_sel_policy.offch_find_int_ms
+		&& rtw_mesh_offch_candidate_accepted(adapter)
+		#ifdef CONFIG_DFS_MASTER
+		&& (!rfctl->radar_detect_ch || (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl)))
+		#endif
+	) {
+		interval_ms = rtw_min(interval_ms, adapter->mesh_cfg.peer_sel_policy.offch_find_int_ms);
+		*reason |= RTW_AUTO_SCAN_REASON_MESH_OFFCH_CAND;
 	}
+	#endif
+#endif /* CONFIG_RTW_MESH */
+
 exit:
+	if (interval_ms == 0xffffffff)
+		interval_ms = 0;
+
+	rtw_mlme_set_auto_scan_int(adapter, interval_ms);
 	return;
 }
 
-void rtw_drv_scan_by_self(_adapter *padapter)
+void rtw_drv_scan_by_self(_adapter *padapter, u8 reason)
 {
+	struct sitesurvey_parm parm;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	int i;
 
-	if (!padapter->registrypriv.wifi_spec) {
-		if (check_fwstate(pmlmepriv, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING)) == _TRUE) {
-			DBG_871X(FUNC_ADPT_FMT" _FW_UNDER_SURVEY|_FW_UNDER_LINKING\n", FUNC_ADPT_ARG(padapter));
-			goto exit;
-		}
-			
-		if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE) {
-			DBG_871X(FUNC_ADPT_FMT" exit BusyTraffic\n", FUNC_ADPT_ARG(padapter));
+
+	if (rtw_is_scan_deny(padapter))
+		goto exit;
+
+	if (!rtw_is_adapter_up(padapter))
+		goto exit;
+
+	if (rtw_mi_busy_traffic_check(padapter, _FALSE)) {
+#ifdef CONFIG_LAYER2_ROAMING
+		if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE) && pmlmepriv->need_to_roam == _TRUE) {
+			RTW_INFO("need to roam, don't care BusyTraffic\n");
+		} else
+#endif
+		{
+			RTW_INFO(FUNC_ADPT_FMT" exit BusyTraffic\n", FUNC_ADPT_ARG(padapter));
 			goto exit;
 		}
 	}
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) && check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+		RTW_INFO(FUNC_ADPT_FMT" WIFI_AP_STATE && WIFI_UNDER_WPS\n", FUNC_ADPT_ARG(padapter));
+		goto exit;
+	}
+	if (check_fwstate(pmlmepriv, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING)) == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT" _FW_UNDER_SURVEY|_FW_UNDER_LINKING\n", FUNC_ADPT_ARG(padapter));
+		goto exit;
+	}
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter)) {
-		if ((check_buddy_fwstate(padapter, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING)) == _TRUE) ||
-			(padapter->pbuddy_adapter->mlmepriv.LinkDetectInfo.bBusyTraffic == _TRUE)) {		
-				DBG_871X(FUNC_ADPT_FMT", but buddy_intf is under scanning or linking or BusyTraffic\n", FUNC_ADPT_ARG(padapter));
-				goto exit;
-		}
+	if (rtw_mi_buddy_check_fwstate(padapter, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS))) {
+		RTW_INFO(FUNC_ADPT_FMT", but buddy_intf is under scanning or linking or wps_phase\n", FUNC_ADPT_ARG(padapter));
+		goto exit;
 	}
 #endif
 
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO(FUNC_ADPT_FMT" reason:0x%02x\n", FUNC_ADPT_ARG(padapter), reason);
 
-	rtw_set_802_11_bssid_list_scan(padapter, NULL, 0);
+	/* only for 20/40 BSS */
+	if (reason == RTW_AUTO_SCAN_REASON_2040_BSS) {
+		rtw_init_sitesurvey_parm(padapter, &parm);
+		for (i=0;i<14;i++) {
+			parm.ch[i].hw_value = i + 1;
+			parm.ch[i].flags = RTW_IEEE80211_CHAN_PASSIVE_SCAN;
+		}
+		parm.ch_num = 14;
+		rtw_set_802_11_bssid_list_scan(padapter, &parm);
+		goto exit;
+	}
 
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+	if ((reason == RTW_AUTO_SCAN_REASON_ROAM) 
+		&& (rtw_roam_nb_scan_list_set(padapter, &parm)))
+		goto exit;
+#endif
+
+	rtw_set_802_11_bssid_list_scan(padapter, NULL);
 exit:
-	return;	
+	return;
 }
 
 static void rtw_auto_scan_handler(_adapter *padapter)
 {
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 reason = RTW_AUTO_SCAN_REASON_UNSPECIFIED;
 
-	rtw_mlme_reset_auto_scan_int(padapter);
+	rtw_mlme_reset_auto_scan_int(padapter, &reason);
 
-	if (pmlmepriv->auto_scan_int_ms != 0
-		&& rtw_get_passing_time_ms(pmlmepriv->scan_start_time) > pmlmepriv->auto_scan_int_ms) 
-		rtw_drv_scan_by_self(padapter);
-	
-}
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE))
+		goto exit;
+#endif
 
-void rtw_dynamic_check_timer_handlder(_adapter *adapter)
-{
-#ifdef CONFIG_AP_MODE
-	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-#endif //CONFIG_AP_MODE
-	struct registry_priv *pregistrypriv = &adapter->registrypriv;
-#ifdef CONFIG_CONCURRENT_MODE	
-	PADAPTER pbuddy_adapter = adapter->pbuddy_adapter;
+#ifdef CONFIG_TDLS
+	if (padapter->tdlsinfo.link_established == _TRUE)
+		goto exit;
 #endif
 
-	if(!adapter)
-		return;	
+	if (pmlmepriv->auto_scan_int_ms == 0
+	    || rtw_get_passing_time_ms(pmlmepriv->scan_start_time) < pmlmepriv->auto_scan_int_ms)
+		goto exit;
 
-	if (!rtw_is_hw_init_completed(adapter))
-		return;
+	rtw_drv_scan_by_self(padapter, reason);
 
-	if (RTW_CANNOT_RUN(adapter))
-		return;
+exit:
+	return;
+}
+static u8 is_drv_in_lps(_adapter *adapter)
+{
+	u8 is_in_lps = _FALSE;
 
-	
-#ifdef CONFIG_CONCURRENT_MODE
-	if(pbuddy_adapter)
-	{
-		if(adapter->net_closed == _TRUE && pbuddy_adapter->net_closed == _TRUE)
-		{
-			return;
-		}		
-	}
-	else
-#endif //CONFIG_CONCURRENT_MODE
-	if(adapter->net_closed == _TRUE)
-	{
+	#ifdef CONFIG_LPS_LCLK_WD_TIMER /* to avoid leaving lps 32k frequently*/
+	if ((adapter_to_pwrctl(adapter)->bFwCurrentInPSMode == _TRUE)
+	#ifdef CONFIG_BT_COEXIST
+		&& (rtw_btcoex_IsBtControlLps(adapter) == _FALSE)
+	#endif
+		)
+		is_in_lps = _TRUE;
+	#endif /* CONFIG_LPS_LCLK_WD_TIMER*/
+	return is_in_lps;
+}
+void rtw_iface_dynamic_check_timer_handlder(_adapter *adapter)
+{
+#ifdef CONFIG_AP_MODE
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+#endif /* CONFIG_AP_MODE */
+
+	if (adapter->net_closed == _TRUE)
 		return;
-	}	
+	#ifdef CONFIG_LPS_LCLK_WD_TIMER /* to avoid leaving lps 32k frequently*/
+	if (is_drv_in_lps(adapter)) {
+		u8 bEnterPS;
 
-#ifdef CONFIG_BT_COEXIST
-	if (is_primary_adapter(adapter)) {
-		if (GET_HAL_DATA(adapter)->EEPROMBluetoothCoexist == 1)
-			DBG_871X("IsBtDisabled=%d, IsBtControlLps=%d\n" , rtw_btcoex_IsBtDisabled(adapter) , rtw_btcoex_IsBtControlLps(adapter));
-	}
-#endif
+		linked_status_chk(adapter, 1);
 
-#ifdef CONFIG_LPS_LCLK_WD_TIMER /* to avoid leaving lps 32k frequently*/
-	if ((adapter_to_pwrctl(adapter)->bFwCurrentInPSMode ==_TRUE )
-#ifdef CONFIG_BT_COEXIST
-		&& (rtw_btcoex_IsBtControlLps(adapter) == _FALSE)
-#endif		
-		) 
-	{
-		u8 bEnterPS;	
-		
-		linked_status_chk(adapter, 1);	
-			
 		bEnterPS = traffic_status_watchdog(adapter, 1);
-		if(bEnterPS)
-		{
-			//rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 1);
+		if (bEnterPS) {
+			/* rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 1); */
 			rtw_hal_dm_watchdog_in_lps(adapter);
+		} else {
+			/* call rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1) in traffic_status_watchdog() */
 		}
-		else
-		{
-			//call rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1) in traffic_status_watchdog()
-		}
-			
 	}
-	else
-#endif //CONFIG_LPS_LCLK_WD_TIMER	
-	{
-		if(is_primary_adapter(adapter))
-		{	
-			rtw_dynamic_chk_wk_cmd(adapter);		
-		}	
-	}	
+	#endif /* CONFIG_LPS_LCLK_WD_TIMER	*/
 
 	/* auto site survey */
 	rtw_auto_scan_handler(adapter);
 
-#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 #ifdef CONFIG_AP_MODE
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
+	if (MLME_IS_AP(adapter)|| MLME_IS_MESH(adapter)) {
+		#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 		expire_timeout_chk(adapter);
-	}	
+		#endif /* !CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
+
+		#ifdef CONFIG_BMC_TX_RATE_SELECT
+		rtw_update_bmc_sta_tx_rate(adapter);
+		#endif /*CONFIG_BMC_TX_RATE_SELECT*/
+	}
+#endif /*CONFIG_AP_MODE*/
+
+
+#ifdef CONFIG_BR_EXT
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
+	rcu_read_lock();
+#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
+
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+	if (adapter->pnetdev->br_port
+#else	/* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
+	if (rcu_dereference(adapter->pnetdev->rx_handler_data)
+#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
+		&& (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE)) {
+		/* expire NAT2.5 entry */
+		void nat25_db_expire(_adapter *priv);
+		nat25_db_expire(adapter);
+
+		if (adapter->pppoe_connection_in_progress > 0)
+			adapter->pppoe_connection_in_progress--;
+		/* due to rtw_dynamic_check_timer_handlder() is called every 2 seconds */
+		if (adapter->pppoe_connection_in_progress > 0)
+			adapter->pppoe_connection_in_progress--;
+	}
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
+	rcu_read_unlock();
+#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
+
+#endif /* CONFIG_BR_EXT */
+
+}
+
+/*TP_avg(t) = (1/10) * TP_avg(t-1) + (9/10) * TP(t) MBps*/
+static void collect_sta_traffic_statistics(_adapter *adapter)
+{
+	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
+	struct sta_info *sta;
+	u16 curr_tx_mbytes = 0, curr_rx_mbytes = 0;
+	int i;
+
+	for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
+		sta = macid_ctl->sta[i];
+		if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr)) {
+			if (sta->sta_stats.last_tx_bytes > sta->sta_stats.tx_bytes)
+				sta->sta_stats.last_tx_bytes =  sta->sta_stats.tx_bytes;
+			if (sta->sta_stats.last_rx_bytes > sta->sta_stats.rx_bytes)
+				sta->sta_stats.last_rx_bytes = sta->sta_stats.rx_bytes;
+			if (sta->sta_stats.last_rx_bc_bytes > sta->sta_stats.rx_bc_bytes)
+				sta->sta_stats.last_rx_bc_bytes = sta->sta_stats.rx_bc_bytes;
+			if (sta->sta_stats.last_rx_mc_bytes > sta->sta_stats.rx_mc_bytes)
+				sta->sta_stats.last_rx_mc_bytes = sta->sta_stats.rx_mc_bytes;
+
+			curr_tx_mbytes = ((sta->sta_stats.tx_bytes - sta->sta_stats.last_tx_bytes) >> 20) / 2; /*MBps*/
+			curr_rx_mbytes = ((sta->sta_stats.rx_bytes - sta->sta_stats.last_rx_bytes) >> 20) / 2; /*MBps*/
+			sta->sta_stats.tx_tp_mbytes = curr_tx_mbytes;
+			sta->sta_stats.rx_tp_mbytes = curr_rx_mbytes;
+
+			sta->cmn.tx_moving_average_tp =
+				(sta->cmn.tx_moving_average_tp / 10) + (curr_tx_mbytes * 9 / 10);
+
+			sta->cmn.rx_moving_average_tp =
+				(sta->cmn.rx_moving_average_tp / 10) + (curr_rx_mbytes * 9 /10);
+
+			if (adapter->bsta_tp_dump)
+				dump_sta_traffic(RTW_DBGDUMP, adapter, sta);
+
+			sta->sta_stats.last_tx_bytes = sta->sta_stats.tx_bytes;
+			sta->sta_stats.last_rx_bytes = sta->sta_stats.rx_bytes;
+			sta->sta_stats.last_rx_bc_bytes = sta->sta_stats.rx_bc_bytes;
+			sta->sta_stats.last_rx_mc_bytes = sta->sta_stats.rx_mc_bytes;
+		}
+	}
+}
+
+void rtw_sta_traffic_info(void *sel, _adapter *adapter)
+{
+	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
+	struct sta_info *sta;
+	int i;
+
+	for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
+		sta = macid_ctl->sta[i];
+		if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr))
+			dump_sta_traffic(sel, adapter, sta);
+	}
+}
+
+/*#define DBG_TRAFFIC_STATISTIC*/
+static void collect_traffic_statistics(_adapter *padapter)
+{
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+
+	/*_rtw_memset(&pdvobjpriv->traffic_stat, 0, sizeof(struct rtw_traffic_statistics));*/
+
+	/* Tx bytes reset*/
+	pdvobjpriv->traffic_stat.tx_bytes = 0;
+	pdvobjpriv->traffic_stat.tx_pkts = 0;
+	pdvobjpriv->traffic_stat.tx_drop = 0;
+
+	/* Rx bytes reset*/
+	pdvobjpriv->traffic_stat.rx_bytes = 0;
+	pdvobjpriv->traffic_stat.rx_pkts = 0;
+	pdvobjpriv->traffic_stat.rx_drop = 0;
+
+	rtw_mi_traffic_statistics(padapter);
+
+	/* Calculate throughput in last interval */
+	pdvobjpriv->traffic_stat.cur_tx_bytes = pdvobjpriv->traffic_stat.tx_bytes - pdvobjpriv->traffic_stat.last_tx_bytes;
+	pdvobjpriv->traffic_stat.cur_rx_bytes = pdvobjpriv->traffic_stat.rx_bytes - pdvobjpriv->traffic_stat.last_rx_bytes;
+	pdvobjpriv->traffic_stat.last_tx_bytes = pdvobjpriv->traffic_stat.tx_bytes;
+	pdvobjpriv->traffic_stat.last_rx_bytes = pdvobjpriv->traffic_stat.rx_bytes;
+
+	pdvobjpriv->traffic_stat.cur_tx_tp = (u32)(pdvobjpriv->traffic_stat.cur_tx_bytes * 8 / 2 / 1024 / 1024);
+	pdvobjpriv->traffic_stat.cur_rx_tp = (u32)(pdvobjpriv->traffic_stat.cur_rx_bytes * 8 / 2 / 1024 / 1024);
+
+	#ifdef DBG_TRAFFIC_STATISTIC
+	RTW_INFO("\n========================\n");
+	RTW_INFO("cur_tx_bytes:%lld\n", pdvobjpriv->traffic_stat.cur_tx_bytes);
+	RTW_INFO("cur_rx_bytes:%lld\n", pdvobjpriv->traffic_stat.cur_rx_bytes);
+
+	RTW_INFO("last_tx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_tx_bytes);
+	RTW_INFO("last_rx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_rx_bytes);
+
+	RTW_INFO("cur_tx_tp:%d\n", pdvobjpriv->traffic_stat.cur_tx_tp);
+	RTW_INFO("cur_rx_tp:%d\n", pdvobjpriv->traffic_stat.cur_rx_tp);
+	#endif
+
+#ifdef CONFIG_RTW_NAPI
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	dynamic_napi_th_chk (padapter);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#endif
+	
+}
+
+void rtw_dynamic_check_timer_handlder(void *ctx)
+{
+	struct dvobj_priv *pdvobj = (struct dvobj_priv *)ctx;
+	_adapter *adapter = dvobj_get_primary_adapter(pdvobj);
+
+#if (MP_DRIVER == 1)
+	if (adapter->registrypriv.mp_mode == 1 && adapter->mppriv.mp_dm == 0) { /* for MP ODM dynamic Tx power tracking */
+		/* RTW_INFO("%s mp_dm =0 return\n", __func__); */
+		goto exit;
+	}
 #endif
-#endif //!CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 
-#ifdef CONFIG_BR_EXT
+	if (!adapter)
+		goto exit;
 
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
-	rcu_read_lock();
-#endif	// (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
-
-#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) 
-	if( adapter->pnetdev->br_port 
-#else	// (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-	if( rcu_dereference(adapter->pnetdev->rx_handler_data)
-#endif	// (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-		&& (check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE) )
-	{
-		// expire NAT2.5 entry
-		void nat25_db_expire(_adapter *priv);
-		nat25_db_expire(adapter);
+	if (!rtw_is_hw_init_completed(adapter))
+		goto exit;
 
-		if (adapter->pppoe_connection_in_progress > 0) {
-			adapter->pppoe_connection_in_progress--;
-		}
-		
-		// due to rtw_dynamic_check_timer_handlder() is called every 2 seconds
-		if (adapter->pppoe_connection_in_progress > 0) {
-			adapter->pppoe_connection_in_progress--;
-		}
-	}
+	if (RTW_CANNOT_RUN(adapter))
+		goto exit;
 
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
-	rcu_read_unlock();
-#endif	// (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
+	collect_traffic_statistics(adapter);
+	collect_sta_traffic_statistics(adapter);
+	rtw_mi_dynamic_check_timer_handlder(adapter);
 
-#endif	// CONFIG_BR_EXT
-	
+	if (!is_drv_in_lps(adapter))
+		rtw_dynamic_chk_wk_cmd(adapter);
+
+exit:
+	_set_timer(&pdvobj->dynamic_chk_timer, 2000);
 }
 
 
@@ -3113,37 +3354,22 @@ inline void rtw_clear_scan_deny(_adapter *adapter)
 	struct mlme_priv *mlmepriv = &adapter->mlmepriv;
 	ATOMIC_SET(&mlmepriv->set_scan_deny, 0);
 	if (0)
-		DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+		RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
 }
 
-void rtw_set_scan_deny_timer_hdl(_adapter *adapter)
+void rtw_set_scan_deny_timer_hdl(void *ctx)
 {
+	_adapter *adapter = (_adapter *)ctx;
+
 	rtw_clear_scan_deny(adapter);
 }
-
 void rtw_set_scan_deny(_adapter *adapter, u32 ms)
 {
 	struct mlme_priv *mlmepriv = &adapter->mlmepriv;
-#ifdef CONFIG_CONCURRENT_MODE
-	struct mlme_priv *b_mlmepriv;
-#endif
-
 	if (0)
-		DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+		RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
 	ATOMIC_SET(&mlmepriv->set_scan_deny, 1);
 	_set_timer(&mlmepriv->set_scan_deny_timer, ms);
-	
-#ifdef CONFIG_CONCURRENT_MODE
-	if (!adapter->pbuddy_adapter)
-		return;
-
-	if (0)
-		DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter->pbuddy_adapter));
- 	b_mlmepriv = &adapter->pbuddy_adapter->mlmepriv;
-	ATOMIC_SET(&b_mlmepriv->set_scan_deny, 1);
-	_set_timer(&b_mlmepriv->set_scan_deny_timer, ms);	
-#endif
-	
 }
 #endif
 
@@ -3159,40 +3385,68 @@ static int rtw_check_roaming_candidate(struct mlme_priv *mlme
 	int updated = _FALSE;
 	_adapter *adapter = container_of(mlme, _adapter, mlmepriv);
 
-	if(is_same_ess(&competitor->network, &mlme->cur_network.network) == _FALSE)
+	if (rtw_chset_search_ch(adapter_to_chset(adapter), competitor->network.Configuration.DSConfig) < 0)
+		goto exit;
+
+#if defined(CONFIG_RTW_REPEATER_SON) &&  (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
+	if (rtw_rson_isupdate_roamcan(mlme, candidate, competitor))
+		goto  update;
+	goto exit;
+#endif
+
+	if (is_same_ess(&competitor->network, &mlme->cur_network.network) == _FALSE)
 		goto exit;
 
-	if(rtw_is_desired_network(adapter, competitor) == _FALSE)
+	if (rtw_is_desired_network(adapter, competitor) == _FALSE)
 		goto exit;
 
-	DBG_871X("roam candidate:%s %s("MAC_FMT", ch%3u) rssi:%d, age:%5d\n",
-		(competitor == mlme->cur_network_scanned)?"*":" " ,
-		competitor->network.Ssid.Ssid,
-		MAC_ARG(competitor->network.MacAddress),
-		competitor->network.Configuration.DSConfig,
-		(int)competitor->network.Rssi,
-		rtw_get_passing_time_ms(competitor->last_scanned)
-	);
+#ifdef CONFIG_LAYER2_ROAMING
+	if (mlme->need_to_roam == _FALSE)
+		goto exit;
+#endif
+
+#ifdef CONFIG_RTW_80211R
+	if (rtw_ft_chk_flags(adapter, RTW_FT_PEER_EN)) {
+		if (rtw_ft_chk_roaming_candidate(adapter, competitor) == _FALSE)
+		goto exit;
+	}
+#endif
+
+	RTW_INFO("roam candidate:%s %s("MAC_FMT", ch%3u) rssi:%d, age:%5d\n",
+		 (competitor == mlme->cur_network_scanned) ? "*" : " " ,
+		 competitor->network.Ssid.Ssid,
+		 MAC_ARG(competitor->network.MacAddress),
+		 competitor->network.Configuration.DSConfig,
+		 (int)competitor->network.Rssi,
+		 rtw_get_passing_time_ms(competitor->last_scanned)
+		);
 
 	/* got specific addr to roam */
 	if (!is_zero_mac_addr(mlme->roam_tgt_addr)) {
-		if(_rtw_memcmp(mlme->roam_tgt_addr, competitor->network.MacAddress, ETH_ALEN) == _TRUE)
+		if (_rtw_memcmp(mlme->roam_tgt_addr, competitor->network.MacAddress, ETH_ALEN) == _TRUE)
 			goto update;
 		else
 			goto exit;
 	}
-	#if 1
-	if(rtw_get_passing_time_ms((u32)competitor->last_scanned) >= mlme->roam_scanr_exp_ms)
+#if 1
+	if (rtw_get_passing_time_ms(competitor->last_scanned) >= mlme->roam_scanr_exp_ms)
 		goto exit;
 
+#if defined(CONFIG_RTW_80211R) && defined(CONFIG_RTW_WNM)
+	if (rtw_wnm_btm_diff_bss(adapter) && 
+		rtw_wnm_btm_roam_candidate(adapter, competitor)) {
+		goto update;
+	}	
+#endif
+
 	if (competitor->network.Rssi - mlme->cur_network_scanned->network.Rssi < mlme->roam_rssi_diff_th)
 		goto exit;
 
-	if(*candidate != NULL && (*candidate)->network.Rssi>=competitor->network.Rssi)
+	if (*candidate != NULL && (*candidate)->network.Rssi >= competitor->network.Rssi)
 		goto exit;
-	#else
+#else
 	goto exit;
-	#endif
+#endif
 
 update:
 	*candidate = competitor;
@@ -3207,13 +3461,12 @@ int rtw_select_roaming_candidate(struct mlme_priv *mlme)
 	_irqL	irqL;
 	int ret = _FAIL;
 	_list	*phead;
-	_adapter *adapter;	
+	_adapter *adapter;
 	_queue	*queue	= &(mlme->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
 	struct	wlan_network	*candidate = NULL;
-	u8 		bSupportAntDiv = _FALSE;
+	u8		bSupportAntDiv = _FALSE;
 
-_func_enter_;
 
 	if (mlme->cur_network_scanned == NULL) {
 		rtw_warn_on(1);
@@ -3221,7 +3474,7 @@ _func_enter_;
 	}
 
 	_enter_critical_bh(&(mlme->scanned_queue.lock), &irqL);
-	phead = get_list_head(queue);		
+	phead = get_list_head(queue);
 	adapter = (_adapter *)mlme->nic_hdl;
 
 	mlme->pscanned = get_next(phead);
@@ -3229,38 +3482,60 @@ _func_enter_;
 	while (!rtw_end_of_queue_search(phead, mlme->pscanned)) {
 
 		pnetwork = LIST_CONTAINOR(mlme->pscanned, struct wlan_network, list);
-		if(pnetwork==NULL){
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("%s return _FAIL:(pnetwork==NULL)\n", __FUNCTION__));
+		if (pnetwork == NULL) {
 			ret = _FAIL;
 			goto exit;
 		}
-		
+
 		mlme->pscanned = get_next(mlme->pscanned);
 
 		if (0)
-			DBG_871X("%s("MAC_FMT", ch%u) rssi:%d\n"
-				, pnetwork->network.Ssid.Ssid
-				, MAC_ARG(pnetwork->network.MacAddress)
-				, pnetwork->network.Configuration.DSConfig
-				, (int)pnetwork->network.Rssi);
+			RTW_INFO("%s("MAC_FMT", ch%u) rssi:%d\n"
+				 , pnetwork->network.Ssid.Ssid
+				 , MAC_ARG(pnetwork->network.MacAddress)
+				 , pnetwork->network.Configuration.DSConfig
+				 , (int)pnetwork->network.Rssi);
 
 		rtw_check_roaming_candidate(mlme, &candidate, pnetwork);
- 
- 	}
 
-	if(candidate == NULL) {
-		DBG_871X("%s: return _FAIL(candidate == NULL)\n", __FUNCTION__);
+	}
+
+	if (candidate == NULL) {
+	/*	if parent note lost the path to root and there is no other cadidate, report disconnection	*/
+#if defined(CONFIG_RTW_REPEATER_SON) &&  (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
+		struct rtw_rson_struct  rson_curr;
+		u8 rson_score;
+
+		rtw_get_rson_struct(&(mlme->cur_network_scanned->network), &rson_curr);
+		rson_score = rtw_cal_rson_score(&rson_curr, mlme->cur_network_scanned->network.Rssi);
+		if (check_fwstate(mlme, _FW_LINKED)
+			&& ((rson_score == RTW_RSON_SCORE_NOTCNNT)
+			|| (rson_score == RTW_RSON_SCORE_NOTSUP)))
+			receive_disconnect(adapter, mlme->cur_network_scanned->network.MacAddress
+								, WLAN_REASON_EXPIRATION_CHK, _FALSE);
+#endif
+		RTW_INFO("%s: return _FAIL(candidate == NULL)\n", __FUNCTION__);
 		ret = _FAIL;
 		goto exit;
 	} else {
-		DBG_871X("%s: candidate: %s("MAC_FMT", ch:%u)\n", __FUNCTION__,
-			candidate->network.Ssid.Ssid, MAC_ARG(candidate->network.MacAddress),
-			candidate->network.Configuration.DSConfig);
+#if defined(CONFIG_RTW_REPEATER_SON) &&  (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
+		struct rtw_rson_struct  rson_curr;
+		u8 rson_score;
 
+		rtw_get_rson_struct(&(candidate->network), &rson_curr);
+		rson_score = rtw_cal_rson_score(&rson_curr, candidate->network.Rssi);
+		RTW_INFO("%s: candidate: %s("MAC_FMT", ch:%u) rson_score:%d\n", __FUNCTION__,
+			candidate->network.Ssid.Ssid, MAC_ARG(candidate->network.MacAddress),
+			 candidate->network.Configuration.DSConfig, rson_score);
+#else
+		RTW_INFO("%s: candidate: %s("MAC_FMT", ch:%u)\n", __FUNCTION__,
+			candidate->network.Ssid.Ssid, MAC_ARG(candidate->network.MacAddress),
+			 candidate->network.Configuration.DSConfig);
+#endif
 		mlme->roam_network = candidate;
 
 		if (_rtw_memcmp(candidate->network.MacAddress, mlme->roam_tgt_addr, ETH_ALEN) == _TRUE)
-			_rtw_memset(mlme->roam_tgt_addr,0, ETH_ALEN);
+			_rtw_memset(mlme->roam_tgt_addr, 0, ETH_ALEN);
 	}
 
 	ret = _SUCCESS;
@@ -3277,55 +3552,75 @@ exit:
 * @return _FALSE: candidate is not updated
 */
 static int rtw_check_join_candidate(struct mlme_priv *mlme
-	, struct wlan_network **candidate, struct wlan_network *competitor)
+	    , struct wlan_network **candidate, struct wlan_network *competitor)
 {
 	int updated = _FALSE;
 	_adapter *adapter = container_of(mlme, _adapter, mlmepriv);
 
+	if (rtw_chset_search_ch(adapter_to_chset(adapter), competitor->network.Configuration.DSConfig) < 0)
+		goto exit;
+
+#if defined(CONFIG_RTW_REPEATER_SON) &&  (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
+	s16 rson_score;
+	struct rtw_rson_struct  rson_data;
+
+	if (rtw_rson_choose(candidate, competitor)) {
+		*candidate = competitor;
+		rtw_get_rson_struct(&((*candidate)->network), &rson_data);
+		rson_score = rtw_cal_rson_score(&rson_data, (*candidate)->network.Rssi);
+		RTW_INFO("[assoc_ssid:%s] new candidate: %s("MAC_FMT", ch%u) rson_score:%d\n",
+			 mlme->assoc_ssid.Ssid,
+			 (*candidate)->network.Ssid.Ssid,
+			 MAC_ARG((*candidate)->network.MacAddress),
+			 (*candidate)->network.Configuration.DSConfig,
+			 rson_score);
+		return _TRUE;
+	}
+	return _FALSE;
+#endif
 
-	//check bssid, if needed
-	if(mlme->assoc_by_bssid==_TRUE) {
-		if(_rtw_memcmp(competitor->network.MacAddress, mlme->assoc_bssid, ETH_ALEN) ==_FALSE)
+	/* check bssid, if needed */
+	if (mlme->assoc_by_bssid == _TRUE) {
+		if (_rtw_memcmp(competitor->network.MacAddress, mlme->assoc_bssid, ETH_ALEN) == _FALSE)
 			goto exit;
 	}
 
-	//check ssid, if needed
-	if(mlme->assoc_ssid.Ssid[0] && mlme->assoc_ssid.SsidLength) {
-		if(	competitor->network.Ssid.SsidLength != mlme->assoc_ssid.SsidLength
-			|| _rtw_memcmp(competitor->network.Ssid.Ssid, mlme->assoc_ssid.Ssid, mlme->assoc_ssid.SsidLength) == _FALSE
-		)
+	/* check ssid, if needed */
+	if (mlme->assoc_ssid.Ssid[0] && mlme->assoc_ssid.SsidLength) {
+		if (competitor->network.Ssid.SsidLength != mlme->assoc_ssid.SsidLength
+		    || _rtw_memcmp(competitor->network.Ssid.Ssid, mlme->assoc_ssid.Ssid, mlme->assoc_ssid.SsidLength) == _FALSE
+		   )
 			goto exit;
 	}
 
-	if(rtw_is_desired_network(adapter, competitor)  == _FALSE)
+	if (rtw_is_desired_network(adapter, competitor)  == _FALSE)
 		goto exit;
 
-#ifdef  CONFIG_LAYER2_ROAMING
-	if(rtw_to_roam(adapter) > 0) {
-		if(	rtw_get_passing_time_ms((u32)competitor->last_scanned) >= mlme->roam_scanr_exp_ms
-			|| is_same_ess(&competitor->network, &mlme->cur_network.network) == _FALSE
-		)
+#ifdef CONFIG_LAYER2_ROAMING
+	if (rtw_to_roam(adapter) > 0) {
+		if (rtw_get_passing_time_ms(competitor->last_scanned) >= mlme->roam_scanr_exp_ms
+		    || is_same_ess(&competitor->network, &mlme->cur_network.network) == _FALSE
+		   )
 			goto exit;
 	}
 #endif
-	
-	if(*candidate == NULL ||(*candidate)->network.Rssi<competitor->network.Rssi )
-	{
+
+	if (*candidate == NULL || (*candidate)->network.Rssi < competitor->network.Rssi) {
 		*candidate = competitor;
 		updated = _TRUE;
 	}
 
-	if(updated){
-		DBG_871X("[by_bssid:%u][assoc_ssid:%s][to_roam:%u] "
-			"new candidate: %s("MAC_FMT", ch%u) rssi:%d\n",
-			mlme->assoc_by_bssid,
-			mlme->assoc_ssid.Ssid,
-			rtw_to_roam(adapter),
-			(*candidate)->network.Ssid.Ssid,
-			MAC_ARG((*candidate)->network.MacAddress),
-			(*candidate)->network.Configuration.DSConfig,
-			(int)(*candidate)->network.Rssi
-		);
+	if (updated) {
+		RTW_INFO("[by_bssid:%u][assoc_ssid:%s][to_roam:%u] "
+			 "new candidate: %s("MAC_FMT", ch%u) rssi:%d\n",
+			 mlme->assoc_by_bssid,
+			 mlme->assoc_ssid.Ssid,
+			 rtw_to_roam(adapter),
+			 (*candidate)->network.Ssid.Ssid,
+			 MAC_ARG((*candidate)->network.MacAddress),
+			 (*candidate)->network.Configuration.DSConfig,
+			 (int)(*candidate)->network.Rssi
+			);
 	}
 
 exit:
@@ -3343,30 +3638,29 @@ pmlmepriv->lock
 
 */
 
-int rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv )
+int rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv)
 {
 	_irqL	irqL;
 	int ret;
 	_list	*phead;
-	_adapter *adapter;	
+	_adapter *adapter;
 	_queue	*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
 	struct	wlan_network	*candidate = NULL;
-	u8 		bSupportAntDiv = _FALSE;
+	u8		bSupportAntDiv = _FALSE;
 
-_func_enter_;
 
 	adapter = (_adapter *)pmlmepriv->nic_hdl;
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-	#ifdef CONFIG_LAYER2_ROAMING
+#ifdef CONFIG_LAYER2_ROAMING
 	if (pmlmepriv->roam_network) {
 		candidate = pmlmepriv->roam_network;
 		pmlmepriv->roam_network = NULL;
 		goto candidate_exist;
 	}
-	#endif
+#endif
 
 	phead = get_list_head(queue);
 	pmlmepriv->pscanned = get_next(phead);
@@ -3374,426 +3668,508 @@ _func_enter_;
 	while (!rtw_end_of_queue_search(phead, pmlmepriv->pscanned)) {
 
 		pnetwork = LIST_CONTAINOR(pmlmepriv->pscanned, struct wlan_network, list);
-		if(pnetwork==NULL){
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("%s return _FAIL:(pnetwork==NULL)\n", __FUNCTION__));
+		if (pnetwork == NULL) {
 			ret = _FAIL;
 			goto exit;
 		}
-		
+
 		pmlmepriv->pscanned = get_next(pmlmepriv->pscanned);
 
 		if (0)
-			DBG_871X("%s("MAC_FMT", ch%u) rssi:%d\n"
-				, pnetwork->network.Ssid.Ssid
-				, MAC_ARG(pnetwork->network.MacAddress)
-				, pnetwork->network.Configuration.DSConfig
-				, (int)pnetwork->network.Rssi);
+			RTW_INFO("%s("MAC_FMT", ch%u) rssi:%d\n"
+				 , pnetwork->network.Ssid.Ssid
+				 , MAC_ARG(pnetwork->network.MacAddress)
+				 , pnetwork->network.Configuration.DSConfig
+				 , (int)pnetwork->network.Rssi);
 
 		rtw_check_join_candidate(pmlmepriv, &candidate, pnetwork);
- 
- 	}
 
-	if(candidate == NULL) {
-		DBG_871X("%s: return _FAIL(candidate == NULL)\n", __FUNCTION__);
+	}
+
+	if (candidate == NULL) {
+		RTW_INFO("%s: return _FAIL(candidate == NULL)\n", __FUNCTION__);
 #ifdef CONFIG_WOWLAN
-		_clr_fwstate_(pmlmepriv, _FW_LINKED|_FW_UNDER_LINKING);
+		_clr_fwstate_(pmlmepriv, _FW_LINKED | _FW_UNDER_LINKING);
 #endif
 		ret = _FAIL;
 		goto exit;
 	} else {
-		DBG_871X("%s: candidate: %s("MAC_FMT", ch:%u)\n", __FUNCTION__,
+		RTW_INFO("%s: candidate: %s("MAC_FMT", ch:%u)\n", __FUNCTION__,
 			candidate->network.Ssid.Ssid, MAC_ARG(candidate->network.MacAddress),
-			candidate->network.Configuration.DSConfig);
+			 candidate->network.Configuration.DSConfig);
 		goto candidate_exist;
 	}
-	
+
 candidate_exist:
 
-	// check for situation of  _FW_LINKED 
-	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
-	{
-		DBG_871X("%s: _FW_LINKED while ask_for_joinbss!!!\n", __FUNCTION__);
+	/* check for situation of  _FW_LINKED */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		RTW_INFO("%s: _FW_LINKED while ask_for_joinbss!!!\n", __FUNCTION__);
 
-		#if 0 // for WPA/WPA2 authentication, wpa_supplicant will expect authentication from AP, it is needed to reconnect AP...
-		if(is_same_network(&pmlmepriv->cur_network.network, &candidate->network))
-		{
-			DBG_871X("%s: _FW_LINKED and is same network, it needn't join again\n", __FUNCTION__);
+#if 0 /* for WPA/WPA2 authentication, wpa_supplicant will expect authentication from AP, it is needed to reconnect AP... */
+		if (is_same_network(&pmlmepriv->cur_network.network, &candidate->network)) {
+			RTW_INFO("%s: _FW_LINKED and is same network, it needn't join again\n", __FUNCTION__);
+
+			rtw_indicate_connect(adapter);/* rtw_indicate_connect again */
 
-			rtw_indicate_connect(adapter);//rtw_indicate_connect again
-				
 			ret = 2;
 			goto exit;
-		}
-		else
-		#endif
+		} else
+#endif
 		{
-			rtw_disassoc_cmd(adapter, 0, _TRUE);
+			rtw_disassoc_cmd(adapter, 0, 0);
 			rtw_indicate_disconnect(adapter, 0, _FALSE);
-			rtw_free_assoc_resources(adapter, 0);
+			rtw_free_assoc_resources_cmd(adapter, _TRUE);
 		}
 	}
-	
-	#ifdef CONFIG_ANTENNA_DIVERSITY
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
 	rtw_hal_get_def_var(adapter, HAL_DEF_IS_SUPPORT_ANT_DIV, &(bSupportAntDiv));
-	if(_TRUE == bSupportAntDiv)	
-	{
+	if (_TRUE == bSupportAntDiv) {
 		u8 CurrentAntenna;
-		rtw_hal_get_def_var(adapter, HAL_DEF_CURRENT_ANTENNA, &(CurrentAntenna));			
-		DBG_871X("#### Opt_Ant_(%s) , cur_Ant(%s)\n",
-			(2==candidate->network.PhyInfo.Optimum_antenna)?"A":"B",
-			(2==CurrentAntenna)?"A":"B"
-		);
+		rtw_hal_get_odm_var(adapter, HAL_ODM_ANTDIV_SELECT, &(CurrentAntenna), NULL);
+		RTW_INFO("#### Opt_Ant_(%s) , cur_Ant(%s)\n",
+			(MAIN_ANT == candidate->network.PhyInfo.Optimum_antenna) ? "MAIN_ANT" : "AUX_ANT",
+			 (MAIN_ANT == CurrentAntenna) ? "MAIN_ANT" : "AUX_ANT"
+			);
 	}
-	#endif
+#endif
 	set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
 	ret = rtw_joinbss_cmd(adapter, candidate);
-	
+
 exit:
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-_func_exit_;
 
 	return ret;
 }
 
-sint rtw_set_auth(_adapter * adapter,struct security_priv *psecuritypriv)
+sint rtw_set_auth(_adapter *adapter, struct security_priv *psecuritypriv)
 {
-	struct	cmd_obj* pcmd;
-	struct 	setauth_parm *psetauthparm;
-	struct	cmd_priv	*pcmdpriv=&(adapter->cmdpriv);
-	sint		res=_SUCCESS;
-	
-_func_enter_;	
+	struct	cmd_obj *pcmd;
+	struct	setauth_parm *psetauthparm;
+	struct	cmd_priv	*pcmdpriv = &(adapter->cmdpriv);
+	sint		res = _SUCCESS;
 
-	pcmd = (struct	cmd_obj*)rtw_zmalloc(sizeof(struct	cmd_obj));
-	if(pcmd==NULL){
-		res= _FAIL;  //try again
+
+	pcmd = (struct	cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
+	if (pcmd == NULL) {
+		res = _FAIL; /* try again */
 		goto exit;
 	}
-	
-	psetauthparm=(struct setauth_parm*)rtw_zmalloc(sizeof(struct setauth_parm));
-	if(psetauthparm==NULL){
+
+	psetauthparm = (struct setauth_parm *)rtw_zmalloc(sizeof(struct setauth_parm));
+	if (psetauthparm == NULL) {
 		rtw_mfree((unsigned char *)pcmd, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
 	_rtw_memset(psetauthparm, 0, sizeof(struct setauth_parm));
-	psetauthparm->mode=(unsigned char)psecuritypriv->dot11AuthAlgrthm;
-	
+	psetauthparm->mode = (unsigned char)psecuritypriv->dot11AuthAlgrthm;
+
 	pcmd->cmdcode = _SetAuth_CMD_;
-	pcmd->parmbuf = (unsigned char *)psetauthparm;   
-	pcmd->cmdsz =  (sizeof(struct setauth_parm));  
+	pcmd->parmbuf = (unsigned char *)psetauthparm;
+	pcmd->cmdsz = (sizeof(struct setauth_parm));
 	pcmd->rsp = NULL;
 	pcmd->rspsz = 0;
 
 
 	_rtw_init_listhead(&pcmd->list);
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("after enqueue set_auth_cmd, auth_mode=%x\n", psecuritypriv->dot11AuthAlgrthm));
 
 	res = rtw_enqueue_cmd(pcmdpriv, pcmd);
 
 exit:
 
-_func_exit_;
 
 	return res;
 
 }
 
 
-sint rtw_set_key(_adapter * adapter,struct security_priv *psecuritypriv,sint keyid, u8 set_tx, bool enqueue)
+sint rtw_set_key(_adapter *adapter, struct security_priv *psecuritypriv, sint keyid, u8 set_tx, bool enqueue)
 {
 	u8	keylen;
 	struct cmd_obj		*pcmd;
 	struct setkey_parm	*psetkeyparm;
 	struct cmd_priv		*pcmdpriv = &(adapter->cmdpriv);
 	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
-	sint	res=_SUCCESS;
-	
-_func_enter_;
+	sint	res = _SUCCESS;
 
-	psetkeyparm=(struct setkey_parm*)rtw_zmalloc(sizeof(struct setkey_parm));
-	if(psetkeyparm==NULL){		
-		res= _FAIL;
+
+	psetkeyparm = (struct setkey_parm *)rtw_zmalloc(sizeof(struct setkey_parm));
+	if (psetkeyparm == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 	_rtw_memset(psetkeyparm, 0, sizeof(struct setkey_parm));
 
-	if(psecuritypriv->dot11AuthAlgrthm ==dot11AuthAlgrthm_8021X){		
-		psetkeyparm->algorithm=(unsigned char)psecuritypriv->dot118021XGrpPrivacy;	
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n rtw_set_key: psetkeyparm->algorithm=(unsigned char)psecuritypriv->dot118021XGrpPrivacy=%d \n", psetkeyparm->algorithm));
-	}	
-	else{
-		psetkeyparm->algorithm=(u8)psecuritypriv->dot11PrivacyAlgrthm;
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n rtw_set_key: psetkeyparm->algorithm=(u8)psecuritypriv->dot11PrivacyAlgrthm=%d \n", psetkeyparm->algorithm));
+	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
+		psetkeyparm->algorithm = (unsigned char)psecuritypriv->dot118021XGrpPrivacy;
+	} else {
+		psetkeyparm->algorithm = (u8)psecuritypriv->dot11PrivacyAlgrthm;
 
 	}
-	psetkeyparm->keyid = (u8)keyid;//0~3
+	psetkeyparm->keyid = (u8)keyid;/* 0~3 */
 	psetkeyparm->set_tx = set_tx;
 	if (is_wep_enc(psetkeyparm->algorithm))
 		adapter->securitypriv.key_mask |= BIT(psetkeyparm->keyid);
 
-	DBG_871X("==> rtw_set_key algorithm(%x),keyid(%x),key_mask(%x)\n",psetkeyparm->algorithm,psetkeyparm->keyid, adapter->securitypriv.key_mask);
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n rtw_set_key: psetkeyparm->algorithm=%d psetkeyparm->keyid=(u8)keyid=%d \n",psetkeyparm->algorithm, keyid));
+	RTW_INFO("==> rtw_set_key algorithm(%x),keyid(%x),key_mask(%x)\n", psetkeyparm->algorithm, psetkeyparm->keyid, adapter->securitypriv.key_mask);
 
-	switch(psetkeyparm->algorithm){
-			
-		case _WEP40_:
-			keylen=5;
-			_rtw_memcpy(&(psetkeyparm->key[0]), &(psecuritypriv->dot11DefKey[keyid].skey[0]), keylen);
-			break;
-		case _WEP104_:
-			keylen=13;
-			_rtw_memcpy(&(psetkeyparm->key[0]), &(psecuritypriv->dot11DefKey[keyid].skey[0]), keylen);
-			break;
-		case _TKIP_:
-			keylen=16;			
-			_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
-			psetkeyparm->grpkey=1;
-			break;
-		case _AES_:
-			keylen=16;			
-			_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
-			psetkeyparm->grpkey=1;
-			break;
-		default:
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("\n rtw_set_key:psecuritypriv->dot11PrivacyAlgrthm = %x (must be 1 or 2 or 4 or 5)\n",psecuritypriv->dot11PrivacyAlgrthm));
-			res= _FAIL;
-			rtw_mfree((unsigned char *)psetkeyparm, sizeof(struct setkey_parm));
-			goto exit;
+	switch (psetkeyparm->algorithm) {
+
+	case _WEP40_:
+		keylen = 5;
+		_rtw_memcpy(&(psetkeyparm->key[0]), &(psecuritypriv->dot11DefKey[keyid].skey[0]), keylen);
+		break;
+	case _WEP104_:
+		keylen = 13;
+		_rtw_memcpy(&(psetkeyparm->key[0]), &(psecuritypriv->dot11DefKey[keyid].skey[0]), keylen);
+		break;
+	case _TKIP_:
+		keylen = 16;
+		_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
+		break;
+	case _AES_:
+		keylen = 16;
+		_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
+		break;
+	default:
+		res = _FAIL;
+		rtw_mfree((unsigned char *)psetkeyparm, sizeof(struct setkey_parm));
+		goto exit;
 	}
-		
-		
-	if(enqueue){
-		pcmd = (struct	cmd_obj*)rtw_zmalloc(sizeof(struct	cmd_obj));
-		if(pcmd==NULL){
+
+
+	if (enqueue) {
+		pcmd = (struct	cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
+		if (pcmd == NULL) {
 			rtw_mfree((unsigned char *)psetkeyparm, sizeof(struct setkey_parm));
-			res= _FAIL;  //try again
+			res = _FAIL; /* try again */
 			goto exit;
 		}
-		
+
 		pcmd->cmdcode = _SetKey_CMD_;
-		pcmd->parmbuf = (u8 *)psetkeyparm;   
-		pcmd->cmdsz =  (sizeof(struct setkey_parm));  
+		pcmd->parmbuf = (u8 *)psetkeyparm;
+		pcmd->cmdsz = (sizeof(struct setkey_parm));
 		pcmd->rsp = NULL;
 		pcmd->rspsz = 0;
 
 		_rtw_init_listhead(&pcmd->list);
 
-		//_rtw_init_sema(&(pcmd->cmd_sem), 0);
+		/* _rtw_init_sema(&(pcmd->cmd_sem), 0); */
 
 		res = rtw_enqueue_cmd(pcmdpriv, pcmd);
-	}
-	else{
+	} else {
 		setkey_hdl(adapter, (u8 *)psetkeyparm);
 		rtw_mfree((u8 *) psetkeyparm, sizeof(struct setkey_parm));
 	}
 exit:
-_func_exit_;
 	return res;
 
 }
 
-
-//adjust IEs for rtw_joinbss_cmd in WMM
-int rtw_restruct_wmm_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len, uint initial_out_len)
+#ifdef CONFIG_WMMPS_STA
+/*
+ * rtw_uapsd_use_default_setting
+ * This function is used for setting default uapsd max sp length to uapsd_max_sp_len
+ * in qos_priv data structure from registry. In additional, it will also map default uapsd 
+ * ac to each uapsd TID, delivery-enabled and trigger-enabled of corresponding TID. 
+ * 
+ * Arguments:
+ * @padapter: _adapter pointer.
+ *
+ * Auther: Arvin Liu
+ * Date: 2017/05/03
+ */
+void	rtw_uapsd_use_default_setting(_adapter *padapter)
 {
-	unsigned	int ielength=0;
-	unsigned int i, j;
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct qos_priv		*pqospriv = &pmlmepriv->qospriv;
+	struct registry_priv		*pregistrypriv = &padapter->registrypriv;
 
-	i = 12; //after the fixed IE
-	while(i<in_len)
-	{
-		ielength = initial_out_len;		
+	if (pregistrypriv->uapsd_ac_enable != 0) {
+		pqospriv->uapsd_max_sp_len = pregistrypriv->uapsd_max_sp_len;
 		
-		if(in_ie[i] == 0xDD && in_ie[i+2] == 0x00 && in_ie[i+3] == 0x50  && in_ie[i+4] == 0xF2 && in_ie[i+5] == 0x02 && i+5 < in_len) //WMM element ID and OUI
-		{
+		CLEAR_FLAGS(pqospriv->uapsd_tid);
+		CLEAR_FLAGS(pqospriv->uapsd_tid_delivery_enabled);
+		CLEAR_FLAGS(pqospriv->uapsd_tid_trigger_enabled);
+
+		/* check the uapsd setting of AC_VO from registry then map these setting to each TID if necessary  */
+		if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_VO)) {
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID7);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID7);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID7);
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID6);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID6);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID6);
+		}
 
-			//Append WMM IE to the last index of out_ie
-			/*
-			for(j=i; j< i+(in_ie[i+1]+2); j++)
-			{
-				out_ie[ielength] = in_ie[j];				
-				ielength++;
-			}
-			out_ie[initial_out_len+8] = 0x00; //force the QoS Info Field to be zero
-	                */
-                       
-                        for ( j = i; j < i + 9; j++ )
-                        {
-                            out_ie[ ielength] = in_ie[ j ];
-                            ielength++;
-                        } 
-                        out_ie[ initial_out_len + 1 ] = 0x07;
-                        out_ie[ initial_out_len + 6 ] = 0x00;
-                        out_ie[ initial_out_len + 8 ] = 0x00;
-	
-			break;
+		/* check the uapsd setting of AC_VI from registry then map these setting to each TID if necessary  */
+		if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_VI)) {	
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID5);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID5);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID5);
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID4);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID4);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID4);
 		}
 
-		i+=(in_ie[i+1]+2); // to the next IE element
+		/* check the uapsd setting of AC_BK from registry then map these setting to each TID if necessary  */
+		if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_BK)) {
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID2);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID2);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID2);
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID1);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID1);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID1);
+		}
+
+		/* check the uapsd setting of AC_BE from registry then map these setting to each TID if necessary  */
+		if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_BE)) {
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID3);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID3);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID3);
+			SET_FLAG(pqospriv->uapsd_tid, WMM_TID0);
+			SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID0);
+			SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID0);
+		}
+
+		RTW_INFO("[WMMPS] UAPSD MAX SP Len = 0x%02x, UAPSD TID enabled = 0x%02x\n", 
+			pqospriv->uapsd_max_sp_len, (u8)pqospriv->uapsd_tid);
 	}
-	
-	return ielength;
-	
+
 }
 
+/*
+ * rtw_is_wmmps_mode
+ * This function is used for checking whether Driver and an AP support uapsd function or not.
+ * If both of them support uapsd function, it will return true. Otherwise returns false.
+ * 
+ * Arguments:
+ * @padapter: _adapter pointer.
+ *
+ * Auther: Arvin Liu
+ * Date: 2017/06/12
+ */
+bool rtw_is_wmmps_mode(_adapter *padapter) 
+{
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct qos_priv	*pqospriv = &pmlmepriv->qospriv;
+		
+	if ((pqospriv->uapsd_ap_supported) && ((pqospriv->uapsd_tid & BIT_MASK_TID_TC)  != 0))
+		return _TRUE;
 
-//
-// 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
-//
-//
+	return _FALSE;
+}
+#endif /* CONFIG_WMMPS_STA */
 
-static int SecIsInPMKIDList(_adapter *Adapter, u8 *bssid)
+/* adjust IEs for rtw_joinbss_cmd in WMM */
+int rtw_restruct_wmm_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len, uint initial_out_len)
 {
-	struct security_priv *psecuritypriv=&Adapter->securitypriv;
-	int i=0;
+#ifdef CONFIG_WMMPS_STA
+	struct mlme_priv		*pmlmepriv = &adapter->mlmepriv;
+	struct qos_priv		*pqospriv = &pmlmepriv->qospriv;
+#endif /* CONFIG_WMMPS_STA */
+	unsigned	int ielength = 0;
+	unsigned int i, j;
+	u8 qos_info = 0;
+
+	i = 12; /* after the fixed IE */
+	while (i < in_len) {
+		ielength = initial_out_len;
+
+		if (in_ie[i] == 0xDD && in_ie[i + 2] == 0x00 && in_ie[i + 3] == 0x50  && in_ie[i + 4] == 0xF2 && in_ie[i + 5] == 0x02 && i + 5 < in_len) { /* WMM element ID and OUI */
+
+			/* Append WMM IE to the last index of out_ie */
+#if 0
+			for (j = i; j < i + (in_ie[i + 1] + 2); j++) {
+				out_ie[ielength] = in_ie[j];
+				ielength++;
+			}
+			out_ie[initial_out_len + 8] = 0x00; /* force the QoS Info Field to be zero */
+#endif
+
+			for (j = i; j < i + 9; j++) {
+				out_ie[ielength] = in_ie[j];
+				ielength++;
+			}
+			out_ie[initial_out_len + 1] = 0x07;
+			out_ie[initial_out_len + 6] = 0x00;
+
+#ifdef CONFIG_WMMPS_STA
+			switch(pqospriv->uapsd_max_sp_len) {
+				case NO_LIMIT: 
+					/* do nothing */
+					break;
+				case TWO_MSDU: 
+					SET_FLAG(qos_info, BIT5);
+					break;
+				case FOUR_MSDU: 
+					SET_FLAG(qos_info, BIT6);
+					break;	
+				case SIX_MSDU: 
+					SET_FLAG(qos_info, BIT5);
+					SET_FLAG(qos_info, BIT6);
+					break;
+				default:
+					/* do nothing */
+					break;
+			};
+
+			/* check TID7 and TID6 for AC_VO to set corresponding Qos_info bit in WMM IE  */
+			if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID7)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID6)))
+				SET_FLAG(qos_info, WMM_IE_UAPSD_VO);
+			/* check TID5 and TID4 for AC_VI to set corresponding Qos_info bit in WMM IE  */
+			if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID5)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID4)))
+				SET_FLAG(qos_info, WMM_IE_UAPSD_VI);
+			/* check TID2 and TID1 for AC_BK to set corresponding Qos_info bit in WMM IE  */
+			if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID2)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID1)))
+				SET_FLAG(qos_info, WMM_IE_UAPSD_BK);
+			/* check TID3 and TID0 for AC_BE to set corresponding Qos_info bit in WMM IE  */
+			if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID3)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID0)))
+				SET_FLAG(qos_info, WMM_IE_UAPSD_BE);
+#endif /* CONFIG_WMMPS_STA */
+			
+			out_ie[initial_out_len + 8] = qos_info;
 
-	do
-	{
-		if( ( psecuritypriv->PMKIDList[i].bUsed ) && 
-                    (  _rtw_memcmp( psecuritypriv->PMKIDList[i].Bssid, bssid, ETH_ALEN ) == _TRUE ) )
-		{
 			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.
+		i += (in_ie[i + 1] + 2); /* to the next IE element */
 	}
 
-	return (i);
-	
+	return ielength;
+
 }
 
-//
-// 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(_adapter *adapter,int iEntry, u8 *ie, uint ie_len)
+/*
+ * 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(_adapter *Adapter, u8 *bssid)
 {
-	struct security_priv *sec=&adapter->securitypriv;
+	struct security_priv *psecuritypriv = &Adapter->securitypriv;
+	int i = 0;
 
-	if (ie[13] > 20) {
-		int i;
-		u16 pmkid_cnt = RTW_GET_LE16(ie+14+20);
-		if (pmkid_cnt == 1 && _rtw_memcmp(ie+14+20+2, &sec->PMKIDList[iEntry].PMKID, 16)) {
-			DBG_871X(FUNC_ADPT_FMT" has carried the same PMKID:"KEY_FMT"\n"
-				, FUNC_ADPT_ARG(adapter), KEY_ARG(&sec->PMKIDList[iEntry].PMKID));
-			goto exit;
+	do {
+		if ((psecuritypriv->PMKIDList[i].bUsed) &&
+		    (_rtw_memcmp(psecuritypriv->PMKIDList[i].Bssid, bssid, ETH_ALEN) == _TRUE))
+			break;
+		else {
+			i++;
+			/* continue; */
 		}
 
-		DBG_871X(FUNC_ADPT_FMT" remove original PMKID, count:%u\n"
-			, FUNC_ADPT_ARG(adapter), pmkid_cnt);
+	} while (i < NUM_PMKID_CACHE);
 
-		for (i=0;i<pmkid_cnt;i++)
-			DBG_871X("    "KEY_FMT"\n", KEY_ARG(ie+14+20+2+i*16));
-
-		ie_len -= 2+pmkid_cnt*16;
-		ie[13] = 20;
+	if (i == NUM_PMKID_CACHE) {
+		i = -1;/* Could not find. */
+	} else {
+		/* There is one Pre-Authentication Key for the specific BSSID. */
 	}
 
-	if (ie[13] <= 20) {	
-		/* The RSN IE didn't include the PMK ID, append the PMK information */
+	return i;
 
-		DBG_871X(FUNC_ADPT_FMT" append PMKID:"KEY_FMT"\n"
-				, FUNC_ADPT_ARG(adapter), KEY_ARG(&sec->PMKIDList[iEntry].PMKID));
+}
 
-		RTW_PUT_LE16(&ie[ie_len], 1);
-		ie_len += 2;
+static int rtw_rsn_sync_pmkid(_adapter *adapter, u8 *ie, uint ie_len, int i_ent)
+{
+	struct security_priv *sec = &adapter->securitypriv;
+	struct rsne_info info;
+	u8 gm_cs[4];
+	int i;
 
-		_rtw_memcpy(&ie[ie_len], &sec->PMKIDList[iEntry].PMKID, 16);
-		ie_len += 16;
+	rtw_rsne_info_parse(ie, ie_len, &info);
 
-		ie[13] += 18;//PMKID length = 2+16
+	if (info.err) {
+		RTW_WARN(FUNC_ADPT_FMT" rtw_rsne_info_parse error\n"
+			, FUNC_ADPT_ARG(adapter));
+		return 0;
 	}
 
-exit:
-	return (ie_len);
-}
-
-static int rtw_remove_pmkid(_adapter *adapter, u8 *ie, uint ie_len)
-{
-	struct security_priv *sec=&adapter->securitypriv;
-	int i;
-	u16 pmkid_cnt = RTW_GET_LE16(ie+14+20);
+	if (i_ent < 0 && info.pmkid_cnt == 0)
+		goto exit;
 
-	if (ie[13] <= 20)
+	if (i_ent >= 0 && info.pmkid_cnt == 1 && _rtw_memcmp(info.pmkid_list, sec->PMKIDList[i_ent].PMKID, 16)) {
+		RTW_INFO(FUNC_ADPT_FMT" has carried the same PMKID:"KEY_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), KEY_ARG(&sec->PMKIDList[i_ent].PMKID));
 		goto exit;
+	}
+
+	/* bakcup group mgmt cs */
+	if (info.gmcs)
+		_rtw_memcpy(gm_cs, info.gmcs, 4);
 
-	DBG_871X(FUNC_ADPT_FMT" remove original PMKID, count:%u\n"
-		, FUNC_ADPT_ARG(adapter), pmkid_cnt);
+	if (info.pmkid_cnt) {
+		RTW_INFO(FUNC_ADPT_FMT" remove original PMKID, count:%u\n"
+			 , FUNC_ADPT_ARG(adapter), info.pmkid_cnt);
+		for (i = 0; i < info.pmkid_cnt; i++)
+			RTW_INFO("    "KEY_FMT"\n", KEY_ARG(info.pmkid_list + i * 16));
+	}
 
-	for (i=0;i<pmkid_cnt;i++)
-		DBG_871X("    "KEY_FMT"\n", KEY_ARG(ie+14+20+2+i*16));
+	if (i_ent >= 0) {
+		RTW_INFO(FUNC_ADPT_FMT" append PMKID:"KEY_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), KEY_ARG(sec->PMKIDList[i_ent].PMKID));
 
-	ie_len -= 2+pmkid_cnt*16;
-	ie[13] = 20;
+		info.pmkid_cnt = 1; /* update new pmkid_cnt */
+		_rtw_memcpy(info.pmkid_list, sec->PMKIDList[i_ent].PMKID, 16);
+	} else
+		info.pmkid_cnt = 0; /* update new pmkid_cnt */
+
+	RTW_PUT_LE16(info.pmkid_list - 2, info.pmkid_cnt);
+	if (info.gmcs)
+		_rtw_memcpy(info.pmkid_list + 16 * info.pmkid_cnt, gm_cs, 4);
+
+	ie_len = 1 + 1 + 2 + 4
+		+ 2 + 4 * info.pcs_cnt
+		+ 2 + 4 * info.akm_cnt
+		+ 2
+		+ 2 + 16 * info.pmkid_cnt
+		+ (info.gmcs ? 4 : 0)
+		;
+	
+	ie[1] = (u8)(ie_len - 2);
 
 exit:
-	return (ie_len);
+	return ie_len;
 }
 
-sint rtw_restruct_sec_ie(_adapter *adapter,u8 *in_ie, u8 *out_ie, uint in_len)
+sint rtw_restruct_sec_ie(_adapter *adapter, u8 *out_ie)
 {
-	u8 authmode=0x0, securitytype, match;
+	u8 authmode = 0x0, securitytype, match;
 	u8 sec_ie[255], uncst_oui[4], bkup_ie[255];
-	u8 wpa_oui[4]={0x0, 0x50, 0xf2, 0x01};
-	uint 	ielength, cnt, remove_cnt;
+	u8 wpa_oui[4] = {0x0, 0x50, 0xf2, 0x01};
+	uint	ielength = 0, cnt, remove_cnt;
 	int iEntry;
 
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct security_priv *psecuritypriv=&adapter->securitypriv;
-	uint 	ndisauthmode=psecuritypriv->ndisauthtype;
+	struct security_priv *psecuritypriv = &adapter->securitypriv;
+	uint	ndisauthmode = psecuritypriv->ndisauthtype;
 	uint ndissecuritytype = psecuritypriv->ndisencryptstatus;
-	
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-		 ("+rtw_restruct_sec_ie: ndisauthmode=%d ndissecuritytype=%d\n",
-		  ndisauthmode, ndissecuritytype));
-	
-	//copy fixed ie only
-	_rtw_memcpy(out_ie, in_ie,12);
-	ielength=12;
-	if((ndisauthmode==Ndis802_11AuthModeWPA)||(ndisauthmode==Ndis802_11AuthModeWPAPSK))
-			authmode=_WPA_IE_ID_;
-	if((ndisauthmode==Ndis802_11AuthModeWPA2)||(ndisauthmode==Ndis802_11AuthModeWPA2PSK))
-			authmode=_WPA2_IE_ID_;
-
-	if(check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
-	{
-		_rtw_memcpy(out_ie+ielength, psecuritypriv->wps_ie, psecuritypriv->wps_ie_len);
-		
-		ielength += psecuritypriv->wps_ie_len;
-	}
-	else if((authmode==_WPA_IE_ID_)||(authmode==_WPA2_IE_ID_))
-	{		
-		//copy RSN or SSN		
-		_rtw_memcpy(&out_ie[ielength], &psecuritypriv->supplicant_ie[0], psecuritypriv->supplicant_ie[1]+2);
+	if ((ndisauthmode == Ndis802_11AuthModeWPA) || (ndisauthmode == Ndis802_11AuthModeWPAPSK))
+		authmode = _WPA_IE_ID_;
+	if ((ndisauthmode == Ndis802_11AuthModeWPA2) || (ndisauthmode == Ndis802_11AuthModeWPA2PSK))
+		authmode = _WPA2_IE_ID_;
+
+	if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+		_rtw_memcpy(out_ie, psecuritypriv->wps_ie, psecuritypriv->wps_ie_len);
+		ielength = psecuritypriv->wps_ie_len;
+
+	} else if ((authmode == _WPA_IE_ID_) || (authmode == _WPA2_IE_ID_)) {
+		/* copy RSN or SSN		 */
+		_rtw_memcpy(out_ie, psecuritypriv->supplicant_ie, psecuritypriv->supplicant_ie[1] + 2);
 		/* debug for CONFIG_IEEE80211W
 		{
 			int jj;
@@ -3802,183 +4178,159 @@ _func_enter_;
 				printk(" %02x ", psecuritypriv->supplicant_ie[jj]);
 			printk("\n");
 		}*/
-		ielength+=psecuritypriv->supplicant_ie[1]+2;
+		ielength = psecuritypriv->supplicant_ie[1] + 2;
 		rtw_report_sec_ie(adapter, authmode, psecuritypriv->supplicant_ie);
-	
-#ifdef CONFIG_DRVEXT_MODULE
-		drvext_report_sec_ie(&adapter->drvextpriv, authmode, sec_ie);	
-#endif
 	}
 
-	iEntry = SecIsInPMKIDList(adapter, pmlmepriv->assoc_bssid);
-	if(iEntry<0)
-	{
-		if(authmode == _WPA2_IE_ID_)
-			ielength = rtw_remove_pmkid(adapter, out_ie, ielength);
-	}
-	else
-	{
-		if(authmode == _WPA2_IE_ID_)
-			ielength=rtw_append_pmkid(adapter, iEntry, out_ie, ielength);
+	if (authmode == WLAN_EID_RSN) {
+		iEntry = SecIsInPMKIDList(adapter, pmlmepriv->assoc_bssid);
+		ielength = rtw_rsn_sync_pmkid(adapter, out_ie, ielength, iEntry);
 	}
 
-_func_exit_;
-	
-	return ielength;	
+	return ielength;
 }
 
-void rtw_init_registrypriv_dev_network(	_adapter* adapter)
+void rtw_init_registrypriv_dev_network(_adapter *adapter)
 {
-	struct registry_priv* pregistrypriv = &adapter->registrypriv;
+	struct registry_priv *pregistrypriv = &adapter->registrypriv;
 	WLAN_BSSID_EX    *pdev_network = &pregistrypriv->dev_network;
 	u8 *myhwaddr = adapter_mac_addr(adapter);
-	
-_func_enter_;
+
 
 	_rtw_memcpy(pdev_network->MacAddress, myhwaddr, ETH_ALEN);
 
 	_rtw_memcpy(&pdev_network->Ssid, &pregistrypriv->ssid, sizeof(NDIS_802_11_SSID));
-	
-	pdev_network->Configuration.Length=sizeof(NDIS_802_11_CONFIGURATION);
-	pdev_network->Configuration.BeaconPeriod = 100;	
+
+	pdev_network->Configuration.Length = sizeof(NDIS_802_11_CONFIGURATION);
+	pdev_network->Configuration.BeaconPeriod = 100;
 	pdev_network->Configuration.FHConfig.Length = 0;
 	pdev_network->Configuration.FHConfig.HopPattern = 0;
 	pdev_network->Configuration.FHConfig.HopSet = 0;
 	pdev_network->Configuration.FHConfig.DwellTime = 0;
-	
-	
-_func_exit_;	
-	
+
+
+
 }
 
-void rtw_update_registrypriv_dev_network(_adapter* adapter) 
+void rtw_update_registrypriv_dev_network(_adapter *adapter)
 {
-	int sz=0;
-	struct registry_priv* pregistrypriv = &adapter->registrypriv;	
+	int sz = 0;
+	struct registry_priv *pregistrypriv = &adapter->registrypriv;
 	WLAN_BSSID_EX    *pdev_network = &pregistrypriv->dev_network;
-	struct	security_priv*	psecuritypriv = &adapter->securitypriv;
+	struct	security_priv	*psecuritypriv = &adapter->securitypriv;
 	struct	wlan_network	*cur_network = &adapter->mlmepriv.cur_network;
-	//struct	xmit_priv	*pxmitpriv = &adapter->xmitpriv;
+	/* struct	xmit_priv	*pxmitpriv = &adapter->xmitpriv; */
 	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
 
-_func_enter_;
 
 #if 0
 	pxmitpriv->vcs_setting = pregistrypriv->vrtl_carrier_sense;
 	pxmitpriv->vcs = pregistrypriv->vcs_type;
 	pxmitpriv->vcs_type = pregistrypriv->vcs_type;
-	//pxmitpriv->rts_thresh = pregistrypriv->rts_thresh;
+	/* pxmitpriv->rts_thresh = pregistrypriv->rts_thresh; */
 	pxmitpriv->frag_len = pregistrypriv->frag_thresh;
-	
+
 	adapter->qospriv.qos_option = pregistrypriv->wmm_enable;
-#endif	
+#endif
 
-	pdev_network->Privacy = (psecuritypriv->dot11PrivacyAlgrthm > 0 ? 1 : 0) ; // adhoc no 802.1x
+	pdev_network->Privacy = (psecuritypriv->dot11PrivacyAlgrthm > 0 ? 1 : 0) ; /* adhoc no 802.1x */
 
 	pdev_network->Rssi = 0;
 
-	switch(pregistrypriv->wireless_mode)
-	{
-		case WIRELESS_11B:
-			pdev_network->NetworkTypeInUse = (Ndis802_11DS);
-			break;	
-		case WIRELESS_11G:
-		case WIRELESS_11BG:
-		case WIRELESS_11_24N:
-		case WIRELESS_11G_24N:
-		case WIRELESS_11BG_24N:
-			pdev_network->NetworkTypeInUse = (Ndis802_11OFDM24);
-			break;
-		case WIRELESS_11A:
-		case WIRELESS_11A_5N:
+	switch (pregistrypriv->wireless_mode) {
+	case WIRELESS_11B:
+		pdev_network->NetworkTypeInUse = (Ndis802_11DS);
+		break;
+	case WIRELESS_11G:
+	case WIRELESS_11BG:
+	case WIRELESS_11_24N:
+	case WIRELESS_11G_24N:
+	case WIRELESS_11BG_24N:
+		pdev_network->NetworkTypeInUse = (Ndis802_11OFDM24);
+		break;
+	case WIRELESS_11A:
+	case WIRELESS_11A_5N:
+		pdev_network->NetworkTypeInUse = (Ndis802_11OFDM5);
+		break;
+	case WIRELESS_11ABGN:
+		if (pregistrypriv->channel > 14)
 			pdev_network->NetworkTypeInUse = (Ndis802_11OFDM5);
-			break;
-		case WIRELESS_11ABGN:
-			if(pregistrypriv->channel > 14)
-				pdev_network->NetworkTypeInUse = (Ndis802_11OFDM5);
-			else
-				pdev_network->NetworkTypeInUse = (Ndis802_11OFDM24);
-			break;
-		default :
-			// TODO
-			break;
+		else
+			pdev_network->NetworkTypeInUse = (Ndis802_11OFDM24);
+		break;
+	default:
+		/* TODO */
+		break;
 	}
-	
+
 	pdev_network->Configuration.DSConfig = (pregistrypriv->channel);
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("pregistrypriv->channel=%d, pdev_network->Configuration.DSConfig=0x%x\n", pregistrypriv->channel, pdev_network->Configuration.DSConfig));	
 
 	if (cur_network->network.InfrastructureMode == Ndis802_11IBSS) {
 		pdev_network->Configuration.ATIMWindow = (0);
 
 		if (pmlmeext->cur_channel != 0)
 			pdev_network->Configuration.DSConfig = pmlmeext->cur_channel;
-		else 
+		else
 			pdev_network->Configuration.DSConfig = 1;
 	}
 
 	pdev_network->InfrastructureMode = (cur_network->network.InfrastructureMode);
 
-	// 1. Supported rates
-	// 2. IE
+	/* 1. Supported rates */
+	/* 2. IE */
 
-	//rtw_set_supported_rate(pdev_network->SupportedRates, pregistrypriv->wireless_mode) ; // will be called in rtw_generate_ie
+	/* rtw_set_supported_rate(pdev_network->SupportedRates, pregistrypriv->wireless_mode) ; */ /* will be called in rtw_generate_ie */
 	sz = rtw_generate_ie(pregistrypriv);
 
 	pdev_network->IELength = sz;
 
-	pdev_network->Length = get_WLAN_BSSID_EX_sz((WLAN_BSSID_EX  *)pdev_network);
+	pdev_network->Length = get_WLAN_BSSID_EX_sz((WLAN_BSSID_EX *)pdev_network);
+
+	/* notes: translate IELength & Length after assign the Length to cmdsz in createbss_cmd(); */
+	/* pdev_network->IELength = cpu_to_le32(sz); */
 
-	//notes: translate IELength & Length after assign the Length to cmdsz in createbss_cmd();
-	//pdev_network->IELength = cpu_to_le32(sz);
-		
-_func_exit_;	
 
 }
 
-void rtw_get_encrypt_decrypt_from_registrypriv(_adapter* adapter)
+void rtw_get_encrypt_decrypt_from_registrypriv(_adapter *adapter)
 {
-_func_enter_;
 
 
-_func_exit_;	
-	
+
 }
 
-//the fucntion is at passive_level 
+/* the fucntion is at passive_level */
 void rtw_joinbss_reset(_adapter *padapter)
 {
 	u8	threshold;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	//todo: if you want to do something io/reg/hw setting before join_bss, please add code here
-	
-#ifdef CONFIG_80211N_HT	
-	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;	
+	/* todo: if you want to do something io/reg/hw setting before join_bss, please add code here */
+
+#ifdef CONFIG_80211N_HT
+	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
 
 	pmlmepriv->num_FortyMHzIntolerant = 0;
 
 	pmlmepriv->num_sta_no_ht = 0;
 
-	phtpriv->ampdu_enable = _FALSE;//reset to disabled
+	phtpriv->ampdu_enable = _FALSE;/* reset to disabled */
 
-#if defined( CONFIG_USB_HCI) || defined (CONFIG_SDIO_HCI)
-	// 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)		
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI)
+	/* 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;		
+			threshold = 0;
 		rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
-	}
-	else
-	{
+	} else {
 		threshold = 1;
 		rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
 	}
-#endif//#if defined( CONFIG_USB_HCI) || defined (CONFIG_SDIO_HCI)
+#endif/* #if defined( CONFIG_USB_HCI) || defined (CONFIG_SDIO_HCI) */
 
-#endif//#ifdef CONFIG_80211N_HT
+#endif/* #ifdef CONFIG_80211N_HT */
 
 }
 
@@ -3986,11 +4338,13 @@ void rtw_joinbss_reset(_adapter *padapter)
 #ifdef CONFIG_80211N_HT
 void	rtw_ht_use_default_setting(_adapter *padapter)
 {
-	struct mlme_priv 		*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
 	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
 	BOOLEAN		bHwLDPCSupport = _FALSE, bHwSTBCSupport = _FALSE;
+#ifdef CONFIG_BEAMFORMING
 	BOOLEAN		bHwSupportBeamformer = _FALSE, bHwSupportBeamformee = _FALSE;
+#endif /* CONFIG_BEAMFORMING */
 
 	if (pregistrypriv->wifi_spec)
 		phtpriv->bss_coexist = 1;
@@ -4000,54 +4354,58 @@ void	rtw_ht_use_default_setting(_adapter *padapter)
 	phtpriv->sgi_40m = TEST_FLAG(pregistrypriv->short_gi, BIT1) ? _TRUE : _FALSE;
 	phtpriv->sgi_20m = TEST_FLAG(pregistrypriv->short_gi, BIT0) ? _TRUE : _FALSE;
 
-	// LDPC support
+	/* LDPC support */
 	rtw_hal_get_def_var(padapter, HAL_DEF_RX_LDPC, (u8 *)&bHwLDPCSupport);
 	CLEAR_FLAGS(phtpriv->ldpc_cap);
-	if(bHwLDPCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->ldpc_cap, BIT4))
+	if (bHwLDPCSupport) {
+		if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT4))
 			SET_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX);
 	}
 	rtw_hal_get_def_var(padapter, HAL_DEF_TX_LDPC, (u8 *)&bHwLDPCSupport);
-	if(bHwLDPCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->ldpc_cap, BIT5))
+	if (bHwLDPCSupport) {
+		if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT5))
 			SET_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX);
 	}
 	if (phtpriv->ldpc_cap)
-		DBG_871X("[HT] HAL Support LDPC = 0x%02X\n", phtpriv->ldpc_cap);
+		RTW_INFO("[HT] HAL Support LDPC = 0x%02X\n", phtpriv->ldpc_cap);
 
-	// STBC
+	/* STBC */
 	rtw_hal_get_def_var(padapter, HAL_DEF_TX_STBC, (u8 *)&bHwSTBCSupport);
 	CLEAR_FLAGS(phtpriv->stbc_cap);
-	if(bHwSTBCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->stbc_cap, BIT5))
+	if (bHwSTBCSupport) {
+		if (TEST_FLAG(pregistrypriv->stbc_cap, BIT5))
 			SET_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX);
 	}
 	rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)&bHwSTBCSupport);
-	if(bHwSTBCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->stbc_cap, BIT4))
+	if (bHwSTBCSupport) {
+		if (TEST_FLAG(pregistrypriv->stbc_cap, BIT4))
 			SET_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX);
 	}
 	if (phtpriv->stbc_cap)
-		DBG_871X("[HT] HAL Support STBC = 0x%02X\n", phtpriv->stbc_cap);
+		RTW_INFO("[HT] HAL Support STBC = 0x%02X\n", phtpriv->stbc_cap);
 
-	// Beamforming setting
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&bHwSupportBeamformer);
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&bHwSupportBeamformee);
+	/* Beamforming setting */
 	CLEAR_FLAGS(phtpriv->beamform_cap);
-	if(TEST_FLAG(pregistrypriv->beamform_cap, BIT4) && bHwSupportBeamformer)
-	{
-		SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
-		DBG_871X("[HT] HAL Support Beamformer\n");
-	}
-	if(TEST_FLAG(pregistrypriv->beamform_cap, BIT5) && bHwSupportBeamformee)
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+	/* only enable beamforming in STA client mode */
+	if (MLME_IS_STA(padapter) && !MLME_IS_GC(padapter)
+				  && !MLME_IS_ADHOC(padapter)
+				  && !MLME_IS_MESH(padapter))
+#endif
 	{
-		SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
-		DBG_871X("[HT] HAL Support Beamformee\n");
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&bHwSupportBeamformer);
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&bHwSupportBeamformee);
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT4) && bHwSupportBeamformer) {
+			SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
+			RTW_INFO("[HT] HAL Support Beamformer\n");
+		}
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT5) && bHwSupportBeamformee) {
+			SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
+			RTW_INFO("[HT] HAL Support Beamformee\n");
+		}
 	}
+#endif /* CONFIG_BEAMFORMING */
 }
 void rtw_build_wmm_ie_ht(_adapter *padapter, u8 *out_ie, uint *pout_len)
 {
@@ -4055,11 +4413,10 @@ void rtw_build_wmm_ie_ht(_adapter *padapter, u8 *out_ie, uint *pout_len)
 	int out_len;
 	u8 *pframe;
 
-	if(padapter->mlmepriv.qospriv.qos_option == 0)
-	{
+	if (padapter->mlmepriv.qospriv.qos_option == 0) {
 		out_len = *pout_len;
-		pframe = rtw_set_ie(out_ie+out_len, _VENDOR_SPECIFIC_IE_, 
-							_WMM_IE_Length_, WMM_IE, pout_len);
+		pframe = rtw_set_ie(out_ie + out_len, _VENDOR_SPECIFIC_IE_,
+				    _WMM_IE_Length_, WMM_IE, pout_len);
 
 		padapter->mlmepriv.qospriv.qos_option = 1;
 	}
@@ -4069,15 +4426,21 @@ void rtw_build_wmm_ie_ht(_adapter *padapter, u8 *out_ie, uint *pout_len)
 unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len, u8 channel)
 {
 	u32 ielen, out_len;
+	u32 rx_packet_offset, max_recvbuf_sz;
 	HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor;
 	HT_CAP_AMPDU_DENSITY best_ampdu_density;
 	unsigned char *p, *pframe;
 	struct rtw_ieee80211_ht_cap ht_capie;
-	u8	cbw40_enable = 0, rf_type = 0, operation_bw = 0, rf_num = 0, rx_stbc_nss = 0;
+	u8	cbw40_enable = 0, rf_type = 0, rf_num = 0, rx_stbc_nss = 0, rx_nss = 0;
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+#ifdef CONFIG_80211AC_VHT
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct vht_priv	*pvhtpriv = &pmlmepriv->vhtpriv;
+#endif /* CONFIG_80211AC_VHT */
 
 	phtpriv->ht_option = _FALSE;
 
@@ -4090,37 +4453,7 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 	if (phtpriv->sgi_20m)
 		ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_20;
 
-	/* Get HT BW */
-	if (in_ie == NULL) {
-		/* TDLS: TODO 20/40 issue */
-		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-			operation_bw = padapter->mlmeextpriv.cur_bwmode;
-			if (operation_bw > CHANNEL_WIDTH_40)
-				operation_bw = CHANNEL_WIDTH_40;
-		} else
-			/* TDLS: TODO 40? */
-			operation_bw = CHANNEL_WIDTH_40;
-	} else {
-		p = rtw_get_ie(in_ie, _HT_ADD_INFO_IE_, &ielen, in_len);
-		if (p && (ielen == sizeof(struct ieee80211_ht_addt_info))) {
-			struct HT_info_element *pht_info = (struct HT_info_element *)(p+2);
-			if (pht_info->infos[0] & BIT(2)) {
-				switch (pht_info->infos[0] & 0x3) {
-				case 1:
-				case 3:
-					operation_bw = CHANNEL_WIDTH_40;
-					break;
-				default:
-					operation_bw = CHANNEL_WIDTH_20;
-					break;
-				}
-			} else {
-				operation_bw = CHANNEL_WIDTH_20;
-			}
-		}
-	}
-
-	/* to disable 40M Hz support while gd_bw_40MHz_en = 0 */
+	/* check if 40MHz is allowed according to hal cap and registry */
 	if (hal_chk_bw_cap(padapter, BW_CAP_40M)) {
 		if (channel > 14) {
 			if (REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
@@ -4131,10 +4464,53 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 		}
 	}
 
-	if ((cbw40_enable == 1) && (operation_bw == CHANNEL_WIDTH_40)) {
-		ht_capie.cap_info |= IEEE80211_HT_CAP_SUP_WIDTH;
-		if (phtpriv->sgi_40m)
-			ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_40;
+	if (cbw40_enable) {
+		u8 oper_bw = CHANNEL_WIDTH_20, oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+
+		if (in_ie == NULL) {
+			/* TDLS: TODO 20/40 issue */
+			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+				oper_bw = padapter->mlmeextpriv.cur_bwmode;
+				if (oper_bw > CHANNEL_WIDTH_40)
+					oper_bw = CHANNEL_WIDTH_40;
+			} else
+				/* TDLS: TODO 40? */
+				oper_bw = CHANNEL_WIDTH_40;
+		} else {
+			p = rtw_get_ie(in_ie, WLAN_EID_HT_OPERATION, &ielen, in_len);
+			if (p && ielen == HT_OP_IE_LEN) {
+				if (GET_HT_OP_ELE_STA_CHL_WIDTH(p + 2)) {
+					switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(p + 2)) {
+					case SCA:
+						oper_bw = CHANNEL_WIDTH_40;
+						oper_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+						break;
+					case SCB:
+						oper_bw = CHANNEL_WIDTH_40;
+						oper_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+						break;
+					}
+				}
+			}
+		}
+
+		/* adjust bw to fit in channel plan setting */
+		if (oper_bw == CHANNEL_WIDTH_40
+			&& oper_offset != HAL_PRIME_CHNL_OFFSET_DONT_CARE /* check this because TDLS has no info to set offset */
+			&& !rtw_chset_is_chbw_valid(adapter_to_chset(padapter), channel, oper_bw, oper_offset)
+		) {
+			oper_bw = CHANNEL_WIDTH_20;
+			oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			rtw_warn_on(!rtw_chset_is_chbw_valid(adapter_to_chset(padapter), channel, oper_bw, oper_offset));
+		}
+
+		if (oper_bw == CHANNEL_WIDTH_40) {
+			ht_capie.cap_info |= IEEE80211_HT_CAP_SUP_WIDTH;
+			if (phtpriv->sgi_40m)
+				ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_40;
+		}
+
+		cbw40_enable = oper_bw == CHANNEL_WIDTH_40 ? 1 : 0;
 	}
 
 	/* todo: disable SM power save mode */
@@ -4143,94 +4519,89 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 	/* RX LDPC */
 	if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX)) {
 		ht_capie.cap_info |= IEEE80211_HT_CAP_LDPC_CODING;
-		DBG_871X("[HT] Declare supporting RX LDPC\n");
+		RTW_INFO("[HT] Declare supporting RX LDPC\n");
 	}
 
 	/* TX STBC */
 	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX)) {
 		ht_capie.cap_info |= IEEE80211_HT_CAP_TX_STBC;
-		DBG_871X("[HT] Declare supporting TX STBC\n");
+		RTW_INFO("[HT] Declare supporting TX STBC\n");
 	}
 
 	/* RX STBC */
 	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX)) {
-		if((pregistrypriv->rx_stbc == 0x3) ||							/* enable for 2.4/5 GHz */
-			((channel <= 14) && (pregistrypriv->rx_stbc == 0x1)) ||		/* enable for 2.4GHz */
-			((channel > 14) && (pregistrypriv->rx_stbc == 0x2)) ||		/* enable for 5GHz */
-			(pregistrypriv->wifi_spec == 1)) {
+		if ((pregistrypriv->rx_stbc == 0x3) ||							/* enable for 2.4/5 GHz */
+		    ((channel <= 14) && (pregistrypriv->rx_stbc == 0x1)) ||		/* enable for 2.4GHz */
+		    ((channel > 14) && (pregistrypriv->rx_stbc == 0x2)) ||		/* enable for 5GHz */
+		    (pregistrypriv->wifi_spec == 1)) {
 			/* HAL_DEF_RX_STBC means STBC RX spatial stream, todo: VHT 4 streams */
 			rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)(&rx_stbc_nss));
 			SET_HT_CAP_ELE_RX_STBC(&ht_capie, rx_stbc_nss);
-			DBG_871X("[HT] Declare supporting RX STBC = %d\n", rx_stbc_nss);
+			RTW_INFO("[HT] Declare supporting RX STBC = %d\n", rx_stbc_nss);
 		}
 	}
 
-	//fill default supported_mcs_set
+	/* fill default supported_mcs_set */
 	_rtw_memcpy(ht_capie.supp_mcs_set, pmlmeext->default_supported_mcs_set, 16);
 
-	//update default supported_mcs_set
+	/* update default supported_mcs_set */
 	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+	rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
 
-	switch(rf_type)
-	{
-	case RF_1T1R:
+	switch (rx_nss) {
+	case 1:
 		set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_1R);
-			break;
-
-	case RF_2T2R:
-	case RF_1T2R:
+		break;
+	case 2:
 		#ifdef CONFIG_DISABLE_MCS13TO15
-		if(((cbw40_enable == 1) && (operation_bw == CHANNEL_WIDTH_40)) && (pregistrypriv->wifi_spec!=1))
-				set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_2R_13TO15_OFF);	
+		if (cbw40_enable && pregistrypriv->wifi_spec != 1)
+			set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_2R_13TO15_OFF);
 		else
-				set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_2R);	
-		#else //CONFIG_DISABLE_MCS13TO15
+		#endif
 			set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_2R);
-		#endif //CONFIG_DISABLE_MCS13TO15
 		break;
-	case RF_3T3R:
+	case 3:
 		set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_3R);
 		break;
+	case 4:
+		set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_4R);
+		break;
 	default:
-		DBG_871X("[warning] rf_type %d is not expected\n", rf_type);
+		RTW_WARN("rf_type:%d or rx_nss:%u is not expected\n", rf_type, hal_spec->rx_nss_num);
 	}
 
 	{
-		u32 rx_packet_offset, max_recvbuf_sz;
 		rtw_hal_get_def_var(padapter, HAL_DEF_RX_PACKET_OFFSET, &rx_packet_offset);
 		rtw_hal_get_def_var(padapter, HAL_DEF_MAX_RECVBUF_SZ, &max_recvbuf_sz);
-		//if(max_recvbuf_sz-rx_packet_offset>(8191-256)) {
-		//	DBG_871X("%s IEEE80211_HT_CAP_MAX_AMSDU is set\n", __FUNCTION__);
-		//	ht_capie.cap_info = ht_capie.cap_info |IEEE80211_HT_CAP_MAX_AMSDU;
-		//}
+		if (max_recvbuf_sz - rx_packet_offset >= (8191 - 256)) {
+			RTW_INFO("%s IEEE80211_HT_CAP_MAX_AMSDU is set\n", __FUNCTION__);
+			ht_capie.cap_info = ht_capie.cap_info | IEEE80211_HT_CAP_MAX_AMSDU;
+		}
 	}
-	/* 	
+	/*
 	AMPDU_para [1:0]:Max AMPDU Len => 0:8k , 1:16k, 2:32k, 3:64k
-	AMPDU_para [4:2]:Min MPDU Start Spacing	
+	AMPDU_para [4:2]:Min MPDU Start Spacing
 	*/
 
 	/*
-	#if defined(CONFIG_RTL8188E )&& defined (CONFIG_SDIO_HCI)
+	#if defined(CONFIG_RTL8188E) && defined(CONFIG_SDIO_HCI)
 	ht_capie.ampdu_params_info = 2;
 	#else
 	ht_capie.ampdu_params_info = (IEEE80211_HT_CAP_AMPDU_FACTOR&0x03);
 	#endif
 	*/
 
-	if(padapter->driver_rx_ampdu_factor != 0xFF)
+	if (padapter->driver_rx_ampdu_factor != 0xFF)
 		max_rx_ampdu_factor = (HT_CAP_AMPDU_FACTOR)padapter->driver_rx_ampdu_factor;
 	else
 		rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
-				
-	//rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
-	ht_capie.ampdu_params_info = (max_rx_ampdu_factor&0x03);
 
-	if(padapter->driver_rx_ampdu_spacing != 0xFF) 
-	{
-		ht_capie.ampdu_params_info |= (( padapter->driver_rx_ampdu_spacing&0x07) <<2);	
-	}
-	else
-	{
+	/* rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor); */
+	ht_capie.ampdu_params_info = (max_rx_ampdu_factor & 0x03);
+
+	if (padapter->driver_rx_ampdu_spacing != 0xFF)
+		ht_capie.ampdu_params_info |= ((padapter->driver_rx_ampdu_spacing & 0x07) << 2);
+	else {
 		if (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_) {
 			/*
 			*	Todo : Each chip must to ask DD , this chip best ampdu_density setting
@@ -4240,8 +4611,8 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 
 			ht_capie.ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & (best_ampdu_density << 2));
 
-		 } else
-			ht_capie.ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY&0x00);
+		} else
+			ht_capie.ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & 0x00);
 	}
 #ifdef CONFIG_BEAMFORMING
 	ht_capie.tx_BF_cap_info = 0;
@@ -4264,99 +4635,92 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 		SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(&ht_capie, 1);
 		/* Explicit Compressed Beamforming Feedback Capable */
 		SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(&ht_capie, 2);
+
 		rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
+#ifdef CONFIG_80211AC_VHT
+		/* IOT action suggested by Yu Chen 2017/3/3 */
+		if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) &&
+			!pvhtpriv->ap_is_mu_bfer)
+			rf_num = (rf_num >= 2 ? 2 : rf_num);
+#endif
 		SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(&ht_capie, rf_num);
 	}
 #endif/*CONFIG_BEAMFORMING*/
 
-	pframe = rtw_set_ie(out_ie+out_len, _HT_CAPABILITY_IE_, 
-						sizeof(struct rtw_ieee80211_ht_cap), (unsigned char*)&ht_capie, pout_len);
+	pframe = rtw_set_ie(out_ie + out_len, _HT_CAPABILITY_IE_,
+		sizeof(struct rtw_ieee80211_ht_cap), (unsigned char *)&ht_capie, pout_len);
 
 	phtpriv->ht_option = _TRUE;
 
-	if(in_ie!=NULL)
-	{
+	if (in_ie != NULL) {
 		p = rtw_get_ie(in_ie, _HT_ADD_INFO_IE_, &ielen, in_len);
-		if(p && (ielen==sizeof(struct ieee80211_ht_addt_info)))
-		{
-			out_len = *pout_len;		
-			pframe = rtw_set_ie(out_ie+out_len, _HT_ADD_INFO_IE_, ielen, p+2 , pout_len);
+		if (p && (ielen == sizeof(struct ieee80211_ht_addt_info))) {
+			out_len = *pout_len;
+			pframe = rtw_set_ie(out_ie + out_len, _HT_ADD_INFO_IE_, ielen, p + 2 , pout_len);
 		}
 	}
 
-	return (phtpriv->ht_option);
-	
+	return phtpriv->ht_option;
+
 }
 
-//the fucntion is > passive_level (in critical_section)
+/* the fucntion is > passive_level (in critical_section) */
 void rtw_update_ht_cap(_adapter *padapter, u8 *pie, uint ie_len, u8 channel)
-{	
+{
 	u8 *p, max_ampdu_sz;
-	int len;		
-	//struct sta_info *bmc_sta, *psta;
+	int len;
+	/* struct sta_info *bmc_sta, *psta; */
 	struct rtw_ieee80211_ht_cap *pht_capie;
 	struct ieee80211_ht_addt_info *pht_addtinfo;
-	//struct recv_reorder_ctrl *preorder_ctrl;
+	/* struct recv_reorder_ctrl *preorder_ctrl; */
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
-	//struct recv_priv *precvpriv = &padapter->recvpriv;
+	/* struct recv_priv *precvpriv = &padapter->recvpriv; */
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
-	//struct wlan_network *pcur_network = &(pmlmepriv->cur_network);;
+	/* struct wlan_network *pcur_network = &(pmlmepriv->cur_network);; */
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8 cbw40_enable=0;
-	
+	u8 cbw40_enable = 0;
+
 
-	if(!phtpriv->ht_option)
+	if (!phtpriv->ht_option)
 		return;
 
 	if ((!pmlmeinfo->HT_info_enable) || (!pmlmeinfo->HT_caps_enable))
 		return;
 
-	DBG_871X("+rtw_update_ht_cap()\n");
+	RTW_INFO("+rtw_update_ht_cap()\n");
 
-	//maybe needs check if ap supports rx ampdu.
-	if((phtpriv->ampdu_enable==_FALSE) &&(pregistrypriv->ampdu_enable==1))
-	{
-		if(pregistrypriv->wifi_spec==1)
-		{
-			//remove this part because testbed AP should disable RX AMPDU
-			//phtpriv->ampdu_enable = _FALSE;
+	/* maybe needs check if ap supports rx ampdu. */
+	if ((phtpriv->ampdu_enable == _FALSE) && (pregistrypriv->ampdu_enable == 1)) {
+		if (pregistrypriv->wifi_spec == 1) {
+			/* remove this part because testbed AP should disable RX AMPDU */
+			/* phtpriv->ampdu_enable = _FALSE; */
 			phtpriv->ampdu_enable = _TRUE;
-		}
-		else
-		{
+		} else
 			phtpriv->ampdu_enable = _TRUE;
-		}
-	}
-	else if(pregistrypriv->ampdu_enable==2)
-	{
-		//remove this part because testbed AP should disable RX AMPDU
-		//phtpriv->ampdu_enable = _TRUE;
-	}
+	} 
 
-	
-	//check Max Rx A-MPDU Size 
+
+	/* check Max Rx A-MPDU Size */
 	len = 0;
-	p = rtw_get_ie(pie+sizeof (NDIS_802_11_FIXED_IEs), _HT_CAPABILITY_IE_, &len, ie_len-sizeof (NDIS_802_11_FIXED_IEs));
-	if(p && len>0)	
-	{
-		pht_capie = (struct rtw_ieee80211_ht_cap *)(p+2);
+	p = rtw_get_ie(pie + sizeof(NDIS_802_11_FIXED_IEs), _HT_CAPABILITY_IE_, &len, ie_len - sizeof(NDIS_802_11_FIXED_IEs));
+	if (p && len > 0) {
+		pht_capie = (struct rtw_ieee80211_ht_cap *)(p + 2);
 		max_ampdu_sz = (pht_capie->ampdu_params_info & IEEE80211_HT_CAP_AMPDU_FACTOR);
-		max_ampdu_sz = 1 << (max_ampdu_sz+3); // max_ampdu_sz (kbytes);
-		
-		//DBG_871X("rtw_update_ht_cap(): max_ampdu_sz=%d\n", max_ampdu_sz);
+		max_ampdu_sz = 1 << (max_ampdu_sz + 3); /* max_ampdu_sz (kbytes); */
+
+		/* RTW_INFO("rtw_update_ht_cap(): max_ampdu_sz=%d\n", max_ampdu_sz); */
 		phtpriv->rx_ampdu_maxlen = max_ampdu_sz;
-		
+
 	}
 
 
-	len=0;
-	p = rtw_get_ie(pie+sizeof (NDIS_802_11_FIXED_IEs), _HT_ADD_INFO_IE_, &len, ie_len-sizeof (NDIS_802_11_FIXED_IEs));
-	if(p && len>0)	
-	{
-		pht_addtinfo = (struct ieee80211_ht_addt_info *)(p+2);
-		//todo:
+	len = 0;
+	p = rtw_get_ie(pie + sizeof(NDIS_802_11_FIXED_IEs), _HT_ADD_INFO_IE_, &len, ie_len - sizeof(NDIS_802_11_FIXED_IEs));
+	if (p && len > 0) {
+		pht_addtinfo = (struct ieee80211_ht_addt_info *)(p + 2);
+		/* todo: */
 	}
 
 	if (hal_chk_bw_cap(padapter, BW_CAP_40M)) {
@@ -4369,131 +4733,86 @@ void rtw_update_ht_cap(_adapter *padapter, u8 *pie, uint ie_len, u8 channel)
 		}
 	}
 
-	//update cur_bwmode & cur_ch_offset
+	/* update cur_bwmode & cur_ch_offset */
 	if ((cbw40_enable) &&
-		(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & BIT(1)) && 
-		(pmlmeinfo->HT_info.infos[0] & BIT(2)))
-	{
+	    (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & BIT(1)) &&
+	    (pmlmeinfo->HT_info.infos[0] & BIT(2))) {
+		struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
 		int i;
 		u8	rf_type = RF_1T1R;
+		u8 tx_nss = 0;
 
 		rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+		tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
 
-		//update the MCS set
+		/* update the MCS set */
 		for (i = 0; i < 16; i++)
 			pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate[i] &= pmlmeext->default_supported_mcs_set[i];
 
-		//update the MCS rates
-		switch(rf_type)
-		{
-			case RF_1T1R:
-			case RF_1T2R:
-				set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_1R);							
-				break;
-			case RF_2T2R:
-				#ifdef CONFIG_DISABLE_MCS13TO15
-				if(pmlmeext->cur_bwmode == CHANNEL_WIDTH_40 && pregistrypriv->wifi_spec != 1 )				
-					set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R_13TO15_OFF);				
-				else
-					set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R);
-#else //CONFIG_DISABLE_MCS13TO15
+		/* update the MCS rates */
+		switch (tx_nss) {
+		case 1:
+			set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_1R);
+			break;
+		case 2:
+			#ifdef CONFIG_DISABLE_MCS13TO15
+			if (pmlmeext->cur_bwmode == CHANNEL_WIDTH_40 && pregistrypriv->wifi_spec != 1)
+				set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R_13TO15_OFF);
+			else
+			#endif
 				set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R);
-#endif //CONFIG_DISABLE_MCS13TO15
-				break;
-			case RF_3T3R:
-				set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_3R);
-				break;
-			default:
-				DBG_871X("[warning] rf_type %d is not expected\n", rf_type);
+			break;
+		case 3:
+			set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_3R);
+			break;
+		case 4:
+			set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_4R);
+			break;
+		default:
+			RTW_WARN("rf_type:%d or tx_nss_num:%u is not expected\n", rf_type, hal_spec->tx_nss_num);
 		}
 
-		//switch to the 40M Hz mode accoring to the AP
-		//pmlmeext->cur_bwmode = CHANNEL_WIDTH_40;
-		switch ((pmlmeinfo->HT_info.infos[0] & 0x3))
-		{
-			case EXTCHNL_OFFSET_UPPER:
-				pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-				break;
-			
-			case EXTCHNL_OFFSET_LOWER:
-				pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-				break;
-				
-			default:
-				pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-				break;
-		}		
+		/* switch to the 40M Hz mode accoring to the AP */
+		/* pmlmeext->cur_bwmode = CHANNEL_WIDTH_40; */
+		switch ((pmlmeinfo->HT_info.infos[0] & 0x3)) {
+		case EXTCHNL_OFFSET_UPPER:
+			pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+			break;
+
+		case EXTCHNL_OFFSET_LOWER:
+			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
-	//
+	/*  */
+	/* Config SM Power Save setting */
+	/*  */
 	pmlmeinfo->SM_PS = (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & 0x0C) >> 2;
-	if(pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC)
-	{
-		/*u8 i;
-		//update the MCS rates
+	if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC) {
+#if 0
+		u8 i;
+		/* update the MCS rates */
 		for (i = 0; i < 16; i++)
-		{
 			pmlmeinfo->HT_caps.HT_cap_element.MCS_rate[i] &= MCS_rate_1R[i];
-		}*/
-		DBG_871X("%s(): WLAN_HT_CAP_SM_PS_STATIC\n",__FUNCTION__);
+#endif
+		RTW_INFO("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __FUNCTION__);
 	}
 
-	//
-	// Config current HT Protection mode.
-	//
+	/*  */
+	/* Config current HT Protection mode. */
+	/*  */
 	pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3;
-
-	
-	
-#if 0 //move to rtw_update_sta_info_client()
-	//for A-MPDU Rx reordering buffer control for bmc_sta & sta_info
-	//if A-MPDU Rx is enabled, reseting  rx_ordering_ctrl wstart_b(indicate_seq) to default value=0xffff
-	//todo: check if AP can send A-MPDU packets
-	bmc_sta = rtw_get_bcmc_stainfo(padapter);
-	if(bmc_sta)
-	{
-		for(i=0; i < 16 ; i++)
-		{
-			//preorder_ctrl = &precvpriv->recvreorder_ctrl[i];
-			preorder_ctrl = &bmc_sta->recvreorder_ctrl[i];
-			preorder_ctrl->enable = _FALSE;
-			preorder_ctrl->indicate_seq = 0xffff;
-			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d indicate_seq:%u \n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq);
-			#endif
-			preorder_ctrl->wend_b= 0xffff;
-			preorder_ctrl->wsize_b = 64;//max_ampdu_sz;//ex. 32(kbytes) -> wsize_b=32
-		}
-	}
-
-	psta = rtw_get_stainfo(&padapter->stapriv, pcur_network->network.MacAddress);
-	if(psta)
-	{
-		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;
-			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d indicate_seq:%u \n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq);
-			#endif
-			preorder_ctrl->wend_b= 0xffff;
-			preorder_ctrl->wsize_b = 64;//max_ampdu_sz;//ex. 32(kbytes) -> wsize_b=32
-		}
-	}
-#endif	
-
 }
 
 #ifdef CONFIG_TDLS
 void rtw_issue_addbareq_cmd_tdls(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
-	struct pkt_attrib *pattrib =&pxmitframe->attrib;
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
 	struct sta_info *ptdls_sta = NULL;
 	u8 issued;
 	int priority;
@@ -4507,71 +4826,66 @@ void rtw_issue_addbareq_cmd_tdls(_adapter *padapter, struct xmit_frame *pxmitfra
 			phtpriv = &ptdls_sta->htpriv;
 
 			if ((phtpriv->ht_option == _TRUE) && (phtpriv->ampdu_enable == _TRUE)) {
-				issued = (phtpriv->agg_enable_bitmap>>priority)&0x1;
-				issued |= (phtpriv->candidate_tid_bitmap>>priority)&0x1;
+				issued = (phtpriv->agg_enable_bitmap >> priority) & 0x1;
+				issued |= (phtpriv->candidate_tid_bitmap >> priority) & 0x1;
 
 				if (0 == issued) {
-					DBG_871X("[%s], p=%d\n", __FUNCTION__, priority);
+					RTW_INFO("[%s], p=%d\n", __FUNCTION__, priority);
 					ptdls_sta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
-					rtw_addbareq_cmd(padapter,(u8)priority, pattrib->dst);
+					rtw_addbareq_cmd(padapter, (u8)priority, pattrib->dst);
 				}
 			}
 		}
 	}
 }
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 void rtw_issue_addbareq_cmd(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
 	u8 issued;
 	int priority;
-	struct sta_info *psta=NULL;
+	struct sta_info *psta = NULL;
 	struct ht_priv	*phtpriv;
-	struct pkt_attrib *pattrib =&pxmitframe->attrib;
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
 	s32 bmcst = IS_MCAST(pattrib->ra);
 
-	//if(bmcst || (padapter->mlmepriv.LinkDetectInfo.bTxBusyTraffic == _FALSE))
-	if(bmcst || (padapter->mlmepriv.LinkDetectInfo.NumTxOkInPeriod<100))	
+	/* if(bmcst || (padapter->mlmepriv.LinkDetectInfo.bTxBusyTraffic == _FALSE)) */
+	if (bmcst || (padapter->mlmepriv.LinkDetectInfo.NumTxOkInPeriod < 100))
 		return;
-	
+
 	priority = pattrib->priority;
 
 #ifdef CONFIG_TDLS
 	rtw_issue_addbareq_cmd_tdls(padapter, pxmitframe);
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 	psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-	if(pattrib->psta != psta)
-	{
-		DBG_871X("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
+	if (pattrib->psta != psta) {
+		RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
 		return;
 	}
-	
-	if(psta==NULL)
-	{
-		DBG_871X("%s, psta==NUL\n", __func__);
+
+	if (psta == NULL) {
+		RTW_INFO("%s, psta==NUL\n", __func__);
 		return;
 	}
 
-	if(!(psta->state &_FW_LINKED))
-	{
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
+	if (!(psta->state & _FW_LINKED)) {
+		RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
 		return;
-	}	
+	}
 
 
 	phtpriv = &psta->htpriv;
 
-	if((phtpriv->ht_option==_TRUE) && (phtpriv->ampdu_enable==_TRUE)) 
-	{
-		issued = (phtpriv->agg_enable_bitmap>>priority)&0x1;
-		issued |= (phtpriv->candidate_tid_bitmap>>priority)&0x1;
+	if ((phtpriv->ht_option == _TRUE) && (phtpriv->ampdu_enable == _TRUE)) {
+		issued = (phtpriv->agg_enable_bitmap >> priority) & 0x1;
+		issued |= (phtpriv->candidate_tid_bitmap >> priority) & 0x1;
 
-		if(0==issued)
-		{
-			DBG_871X("rtw_issue_addbareq_cmd, p=%d\n", priority);
+		if (0 == issued) {
+			RTW_INFO("rtw_issue_addbareq_cmd, p=%d\n", priority);
 			psta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
-			rtw_addbareq_cmd(padapter,(u8) priority, pattrib->ra);
+			rtw_addbareq_cmd(padapter, (u8) priority, pattrib->ra);
 		}
 	}
 
@@ -4579,28 +4893,29 @@ void rtw_issue_addbareq_cmd(_adapter *padapter, struct xmit_frame *pxmitframe)
 
 void rtw_append_exented_cap(_adapter *padapter, u8 *out_ie, uint *pout_len)
 {
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
 #ifdef CONFIG_80211AC_VHT
 	struct vht_priv	*pvhtpriv = &pmlmepriv->vhtpriv;
-#endif //CONFIG_80211AC_VHT
+#endif /* CONFIG_80211AC_VHT */
 	u8	cap_content[8] = { 0 };
 	u8	*pframe;
 	u8   null_content[8] = {0};
 
-	if (phtpriv->bss_coexist) {
+	if (phtpriv->bss_coexist)
 		SET_EXT_CAPABILITY_ELE_BSS_COEXIST(cap_content, 1);
-	}
 
 #ifdef CONFIG_80211AC_VHT
-	if (pvhtpriv->vht_option) {
+	if (pvhtpriv->vht_option)
 		SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(cap_content, 1);
-	}
-#endif //CONFIG_80211AC_VHT
+#endif /* CONFIG_80211AC_VHT */
+#ifdef CONFIG_RTW_WNM
+	rtw_wnm_set_ext_cap_btm(cap_content, 1);
+#endif
 	/*
 		From 802.11 specification,if a STA does not support any of capabilities defined
-		in the Extended Capabilities element, then the STA is not required to 
-		transmit the Extended Capabilities element. 
+		in the Extended Capabilities element, then the STA is not required to
+		transmit the Extended Capabilities element.
 	*/
 	if (_FALSE == _rtw_memcmp(cap_content, null_content, 8))
 		pframe = rtw_set_ie(out_ie + *pout_len, EID_EXTCapability, 8, cap_content , pout_len);
@@ -4640,11 +4955,11 @@ void _rtw_roaming(_adapter *padapter, struct wlan_network *tgt_network)
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct wlan_network *cur_network = &pmlmepriv->cur_network;
 	int do_join_r;
-	
-	if(0 < rtw_to_roam(padapter)) {
-		DBG_871X("roaming from %s("MAC_FMT"), length:%d\n",
-				cur_network->network.Ssid.Ssid, MAC_ARG(cur_network->network.MacAddress),
-				cur_network->network.Ssid.SsidLength);
+
+	if (0 < rtw_to_roam(padapter)) {
+		RTW_INFO("roaming from %s("MAC_FMT"), length:%d\n",
+			cur_network->network.Ssid.Ssid, MAC_ARG(cur_network->network.MacAddress),
+			 cur_network->network.Ssid.SsidLength);
 		_rtw_memcpy(&pmlmepriv->assoc_ssid, &cur_network->network.Ssid, sizeof(NDIS_802_11_SSID));
 
 		pmlmepriv->assoc_by_bssid = _FALSE;
@@ -4653,24 +4968,29 @@ void _rtw_roaming(_adapter *padapter, struct wlan_network *tgt_network)
 		rtw_wapi_return_all_sta_info(padapter);
 #endif
 
-		while(1) {
-			if( _SUCCESS==(do_join_r=rtw_do_join(padapter)) ) {
+		while (1) {
+			do_join_r = rtw_do_join(padapter);
+			if (_SUCCESS == do_join_r)
 				break;
-			} else {
-				DBG_871X("roaming do_join return %d\n", do_join_r);
+			else {
+				RTW_INFO("roaming do_join return %d\n", do_join_r);
 				rtw_dec_to_roam(padapter);
-				
-				if(rtw_to_roam(padapter) > 0) {
+
+				if (rtw_to_roam(padapter) > 0)
 					continue;
-				} else {
-					DBG_871X("%s(%d) -to roaming fail, indicate_disconnect\n", __FUNCTION__,__LINE__);
+				else {
+					RTW_INFO("%s(%d) -to roaming fail, indicate_disconnect\n", __FUNCTION__, __LINE__);
+#ifdef CONFIG_RTW_80211R
+					rtw_ft_clr_flags(padapter, RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN);
+					rtw_ft_reset_status(padapter);
+#endif
 					rtw_indicate_disconnect(padapter, 0, _FALSE);
 					break;
 				}
 			}
 		}
 	}
-	
+
 }
 #endif /* CONFIG_LAYER2_ROAMING */
 
@@ -4679,9 +4999,14 @@ bool rtw_adjust_chbw(_adapter *adapter, u8 req_ch, u8 *req_bw, u8 *req_offset)
 	struct registry_priv *regsty = adapter_to_regsty(adapter);
 	u8 allowed_bw;
 
-	if (req_ch <= 14)
+	if (req_ch <= 14) {
 		allowed_bw = REGSTY_BW_2G(regsty);
-	else
+		if (MLME_IS_MESH(adapter)) {
+			/* prevent secondary channel offset mismatch */
+			if (req_ch >= 5 && req_ch <= 9)
+				allowed_bw = CHANNEL_WIDTH_20;
+		}
+	} else
 		allowed_bw = REGSTY_BW_5G(regsty);
 
 	allowed_bw = hal_largest_bw(adapter, allowed_bw);
@@ -4701,72 +5026,51 @@ bool rtw_adjust_chbw(_adapter *adapter, u8 req_ch, u8 *req_bw, u8 *req_offset)
 
 sint rtw_linked_check(_adapter *padapter)
 {
-	if(	(check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE) ||
-			(check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE|WIFI_ADHOC_MASTER_STATE) == _TRUE))
-	{
-		if(padapter->stapriv.asoc_sta_count > 2)
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)
+		|| MLME_IS_ADHOC(padapter) || MLME_IS_ADHOC_MASTER(padapter)
+	) {
+		if (padapter->stapriv.asoc_sta_count > 2)
 			return _TRUE;
-	}
-	else
-	{	//Station mode
-		if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)== _TRUE)
+	} else {
+		/* Station mode */
+		if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE)
 			return _TRUE;
 	}
 	return _FALSE;
 }
+/*#define DBG_ADAPTER_STATE_CHK*/
+u8 rtw_is_adapter_up(_adapter *padapter)
+{
+	if (padapter == NULL)
+		return _FALSE;
 
-#ifdef CONFIG_CONCURRENT_MODE
-sint rtw_buddy_adapter_up(_adapter *padapter)
-{	
-	sint res = _FALSE;
-	
-	if(padapter == NULL)
-		return res;
-
-
-	if(padapter->pbuddy_adapter == NULL)
-		res = _FALSE;
-	else if (RTW_CANNOT_RUN(padapter) ||
-		(padapter->pbuddy_adapter->bup == _FALSE) || (!rtw_is_hw_init_completed(padapter)))
-		res = _FALSE;
-	else
-		res = _TRUE;
-
-	return res;	
-
-}
+	if (RTW_CANNOT_RUN(padapter)) {
+		#ifdef DBG_ADAPTER_STATE_CHK
+		RTW_INFO(FUNC_ADPT_FMT " FALSE -bDriverStopped(%s) bSurpriseRemoved(%s)\n"
+			, FUNC_ADPT_ARG(padapter)
+			, rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+		#endif
+		return _FALSE;
+	}
 
-sint check_buddy_fwstate(_adapter *padapter, sint state)
-{
-	if(padapter == NULL)
-		return _FALSE;	
-	
-	if(padapter->pbuddy_adapter == NULL)
-		return _FALSE;	
-		
-	if ((state == WIFI_FW_NULL_STATE) && 
-		(padapter->pbuddy_adapter->mlmepriv.fw_state == WIFI_FW_NULL_STATE))
-		return _TRUE;		
-	
-	if (padapter->pbuddy_adapter->mlmepriv.fw_state & state)
-		return _TRUE;
+	if (!rtw_is_hw_init_completed(padapter)) {
+		#ifdef DBG_ADAPTER_STATE_CHK
+		RTW_INFO(FUNC_ADPT_FMT " FALSE -(hw_init_completed == _FALSE)\n", FUNC_ADPT_ARG(padapter));
+		#endif
+		return _FALSE;
+	}
 
-	return _FALSE;
-}
+	if (padapter->bup == _FALSE) {
+		#ifdef DBG_ADAPTER_STATE_CHK
+		RTW_INFO(FUNC_ADPT_FMT " FALSE -(bup == _FALSE)\n", FUNC_ADPT_ARG(padapter));
+		#endif
+		return _FALSE;
+	}
 
-u8 rtw_get_buddy_bBusyTraffic(_adapter *padapter)
-{
-	if(padapter == NULL)
-		return _FALSE;	
-	
-	if(padapter->pbuddy_adapter == NULL)
-		return _FALSE;	
-	
-	return padapter->pbuddy_adapter->mlmepriv.LinkDetectInfo.bBusyTraffic;
+	return _TRUE;
 }
 
-#endif //CONFIG_CONCURRENT_MODE
-
 bool is_miracast_enabled(_adapter *adapter)
 {
 	bool enabled = 0;
@@ -4774,7 +5078,7 @@ bool is_miracast_enabled(_adapter *adapter)
 	struct wifi_display_info *wfdinfo = &adapter->wfd_info;
 
 	enabled = (wfdinfo->stack_wfd_mode & (MIRACAST_SOURCE | MIRACAST_SINK))
-		|| (wfdinfo->op_wfd_mode & (MIRACAST_SOURCE | MIRACAST_SINK));
+		  || (wfdinfo->op_wfd_mode & (MIRACAST_SOURCE | MIRACAST_SINK));
 #endif
 
 	return enabled;
@@ -4812,8 +5116,8 @@ static bool wfd_st_match_rule(_adapter *adapter, u8 *local_naddr, u8 *local_port
 	struct wifi_display_info *wfdinfo = &adapter->wfd_info;
 
 	if (ntohs(*((u16 *)local_port)) == wfdinfo->rtsp_ctrlport
-		|| ntohs(*((u16 *)local_port)) == wfdinfo->tdls_rtsp_ctrlport
-		|| ntohs(*((u16 *)remote_port)) == wfdinfo->peer_rtsp_ctrlport)
+	    || ntohs(*((u16 *)local_port)) == wfdinfo->tdls_rtsp_ctrlport
+	    || ntohs(*((u16 *)remote_port)) == wfdinfo->peer_rtsp_ctrlport)
 		return _TRUE;
 	return _FALSE;
 }
@@ -4833,4 +5137,3 @@ inline void rtw_wfd_st_switch(struct sta_info *sta, bool on)
 		rtw_st_ctl_unregister(&sta->st_ctl, SESSION_TRACKER_REG_ID_WFD);
 #endif
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme_ext.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme_ext.c
index 3c13f6d8b20f..604a3c850b71 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme_ext.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mlme_ext.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,22 +12,17 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_MLME_EXT_C_
 
 #include <drv_types.h>
 #ifdef CONFIG_IOCTL_CFG80211
-#include <rtw_wifi_regd.h>
-#endif //CONFIG_IOCTL_CFG80211
+	#include <rtw_wifi_regd.h>
+#endif /* CONFIG_IOCTL_CFG80211 */
 #include <hal_data.h>
 
 
-struct mlme_handler mlme_sta_tbl[]={
+struct mlme_handler mlme_sta_tbl[] = {
 	{WIFI_ASSOCREQ,		"OnAssocReq",	&OnAssocReq},
 	{WIFI_ASSOCRSP,		"OnAssocRsp",	&OnAssocRsp},
 	{WIFI_REASSOCREQ,	"OnReAssocReq",	&OnAssocReq},
@@ -45,11 +41,11 @@ struct mlme_handler mlme_sta_tbl[]={
 	{WIFI_AUTH,			"OnAuth",		&OnAuthClient},
 	{WIFI_DEAUTH,		"OnDeAuth",		&OnDeAuth},
 	{WIFI_ACTION,		"OnAction",		&OnAction},
-	{WIFI_ACTION_NOACK,"OnActionNoAck",	&OnAction},
+	{WIFI_ACTION_NOACK, "OnActionNoAck",	&OnAction},
 };
 
 #ifdef _CONFIG_NATIVEAP_MLME_
-struct mlme_handler mlme_ap_tbl[]={
+struct mlme_handler mlme_ap_tbl[] = {
 	{WIFI_ASSOCREQ,		"OnAssocReq",	&OnAssocReq},
 	{WIFI_ASSOCRSP,		"OnAssocRsp",	&OnAssocRsp},
 	{WIFI_REASSOCREQ,	"OnReAssocReq",	&OnAssocReq},
@@ -68,34 +64,39 @@ struct mlme_handler mlme_ap_tbl[]={
 	{WIFI_AUTH,			"OnAuth",		&OnAuth},
 	{WIFI_DEAUTH,		"OnDeAuth",		&OnDeAuth},
 	{WIFI_ACTION,		"OnAction",		&OnAction},
-	{WIFI_ACTION_NOACK,"OnActionNoAck",	&OnAction},
+	{WIFI_ACTION_NOACK, "OnActionNoAck",	&OnAction},
 };
 #endif
 
-struct action_handler OnAction_tbl[]={
+struct action_handler OnAction_tbl[] = {
 	{RTW_WLAN_CATEGORY_SPECTRUM_MGMT,	 "ACTION_SPECTRUM_MGMT", on_action_spct},
 	{RTW_WLAN_CATEGORY_QOS, "ACTION_QOS", &OnAction_qos},
 	{RTW_WLAN_CATEGORY_DLS, "ACTION_DLS", &OnAction_dls},
 	{RTW_WLAN_CATEGORY_BACK, "ACTION_BACK", &OnAction_back},
 	{RTW_WLAN_CATEGORY_PUBLIC, "ACTION_PUBLIC", on_action_public},
-	{RTW_WLAN_CATEGORY_RADIO_MEASUREMENT, "ACTION_RADIO_MEASUREMENT", &DoReserved},
-	{RTW_WLAN_CATEGORY_FT, "ACTION_FT",	&DoReserved},
+	{RTW_WLAN_CATEGORY_RADIO_MEAS, "ACTION_RADIO_MEAS", &on_action_rm},
+	{RTW_WLAN_CATEGORY_FT, "ACTION_FT",	&OnAction_ft},
 	{RTW_WLAN_CATEGORY_HT,	"ACTION_HT",	&OnAction_ht},
 #ifdef CONFIG_IEEE80211W
 	{RTW_WLAN_CATEGORY_SA_QUERY, "ACTION_SA_QUERY", &OnAction_sa_query},
 #else
 	{RTW_WLAN_CATEGORY_SA_QUERY, "ACTION_SA_QUERY", &DoReserved},
-#endif //CONFIG_IEEE80211W
-	//add for CONFIG_IEEE80211W
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_RTW_WNM
+	{RTW_WLAN_CATEGORY_WNM, "ACTION_WNM", &on_action_wnm},
+#endif
 	{RTW_WLAN_CATEGORY_UNPROTECTED_WNM, "ACTION_UNPROTECTED_WNM", &DoReserved},
-	{RTW_WLAN_CATEGORY_SELF_PROTECTED, "ACTION_SELF_PROTECTED", &DoReserved},
+#ifdef CONFIG_RTW_MESH
+	{RTW_WLAN_CATEGORY_MESH, "ACTION_MESH", &on_action_mesh},
+	{RTW_WLAN_CATEGORY_SELF_PROTECTED, "ACTION_SELF_PROTECTED", &on_action_self_protected},
+#endif
 	{RTW_WLAN_CATEGORY_WMM, "ACTION_WMM", &OnAction_wmm},
 	{RTW_WLAN_CATEGORY_VHT, "ACTION_VHT", &OnAction_vht},
-	{RTW_WLAN_CATEGORY_P2P, "ACTION_P2P", &OnAction_p2p},	
+	{RTW_WLAN_CATEGORY_P2P, "ACTION_P2P", &OnAction_p2p},
 };
 
 
-u8	null_addr[ETH_ALEN]= {0,0,0,0,0,0};
+u8	null_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
 
 /**************************************************
 OUI definitions for the vendor specific IE
@@ -103,8 +104,8 @@ OUI definitions for the vendor specific IE
 unsigned char	RTW_WPA_OUI[] = {0x00, 0x50, 0xf2, 0x01};
 unsigned char WMM_OUI[] = {0x00, 0x50, 0xf2, 0x02};
 unsigned char	WPS_OUI[] = {0x00, 0x50, 0xf2, 0x04};
-unsigned char	P2P_OUI[] = {0x50,0x6F,0x9A,0x09};
-unsigned char	WFD_OUI[] = {0x50,0x6F,0x9A,0x0A};
+unsigned char	P2P_OUI[] = {0x50, 0x6F, 0x9A, 0x09};
+unsigned char	WFD_OUI[] = {0x50, 0x6F, 0x9A, 0x0A};
 
 unsigned char	WMM_INFO_OUI[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01};
 unsigned char	WMM_PARA_OUI[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
@@ -143,166 +144,300 @@ static RT_CHANNEL_PLAN legacy_channel_plan[] = {
 };
 #endif
 
-static RT_CHANNEL_PLAN_2G RTW_ChannelPlan2G[] = {
-	/* 0, RTW_RD_2G_NULL */		{{}, 0},
-	/* 1, RTW_RD_2G_WORLD */	{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 2, RTW_RD_2G_ETSI1 */		{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 3, RTW_RD_2G_FCC1 */		{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11}, 11},
-	/* 4, RTW_RD_2G_MKK1 */		{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14}, 14},
-	/* 5, RTW_RD_2G_ETSI2 */		{{10, 11, 12, 13}, 4},
-	/* 6, RTW_RD_2G_GLOBAL */	{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14}, 14},
-	/* 7, RTW_RD_2G_MKK2 */		{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 8, RTW_RD_2G_FCC2 */		{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
+enum rtw_rd_2g {
+	RTW_RD_2G_NULL = 0,
+	RTW_RD_2G_WORLD = 1,	/* Worldwird 13 */
+	RTW_RD_2G_ETSI1 = 2,	/* Europe */
+	RTW_RD_2G_FCC1 = 3,		/* US */
+	RTW_RD_2G_MKK1 = 4,		/* Japan */
+	RTW_RD_2G_ETSI2 = 5,	/* France */
+	RTW_RD_2G_GLOBAL = 6,	/* Global domain */
+	RTW_RD_2G_MKK2 = 7,		/* Japan */
+	RTW_RD_2G_FCC2 = 8,		/* US */
+	RTW_RD_2G_IC1 = 9,		/* Canada */
+	RTW_RD_2G_WORLD1 = 10,	/* Worldwide 11 */
+
+	RTW_RD_2G_MAX,
+};
+
+enum rtw_rd_5g {
+	RTW_RD_5G_NULL = 0,		/*	*/
+	RTW_RD_5G_ETSI1 = 1,	/* Europe */
+	RTW_RD_5G_ETSI2 = 2,	/* Australia, New Zealand */
+	RTW_RD_5G_ETSI3 = 3,	/* Russia */
+	RTW_RD_5G_FCC1 = 4,		/* US */
+	RTW_RD_5G_FCC2 = 5,		/* FCC w/o DFS Channels */
+	RTW_RD_5G_FCC3 = 6,		/* Bolivia, Chile, El Salvador, Venezuela */
+	RTW_RD_5G_FCC4 = 7,		/* Venezuela */
+	RTW_RD_5G_FCC5 = 8,		/* China */
+	RTW_RD_5G_FCC6 = 9,		/*	*/
+	RTW_RD_5G_FCC7 = 10,	/* US(w/o Weather radar) */
+	RTW_RD_5G_IC1 = 11,		/* Canada(w/o Weather radar) */
+	RTW_RD_5G_KCC1 = 12,	/* Korea */
+	RTW_RD_5G_MKK1 = 13,	/* Japan */
+	RTW_RD_5G_MKK2 = 14,	/* Japan (W52, W53) */
+	RTW_RD_5G_MKK3 = 15,	/* Japan (W56) */
+	RTW_RD_5G_NCC1 = 16,	/* Taiwan, (w/o Weather radar) */
+	RTW_RD_5G_NCC2 = 17,	/* Taiwan, Band2, Band4 */
+	RTW_RD_5G_NCC3 = 18,	/* Taiwan w/o DFS, Band4 only */
+	RTW_RD_5G_ETSI4 = 19,	/* Europe w/o DFS, Band1 only */
+	RTW_RD_5G_ETSI5 = 20,	/* Australia, New Zealand(w/o Weather radar) */
+	RTW_RD_5G_FCC8 = 21,	/* Latin America */
+	RTW_RD_5G_ETSI6 = 22,	/* Israel, Bahrain, Egypt, India, China, Malaysia */
+	RTW_RD_5G_ETSI7 = 23,	/* China */
+	RTW_RD_5G_ETSI8 = 24,	/* Jordan */
+	RTW_RD_5G_ETSI9 = 25,	/* Lebanon */
+	RTW_RD_5G_ETSI10 = 26,	/* Qatar */
+	RTW_RD_5G_ETSI11 = 27,	/* Russia */
+	RTW_RD_5G_NCC4 = 28,	/* Taiwan, (w/o Weather radar) */
+	RTW_RD_5G_ETSI12 = 29,	/* Indonesia */
+	RTW_RD_5G_FCC9 = 30,	/* (w/o Weather radar) */
+	RTW_RD_5G_ETSI13 = 31,	/* (w/o Weather radar) */
+	RTW_RD_5G_FCC10 = 32,	/* Argentina(w/o Weather radar) */
+	RTW_RD_5G_MKK4 = 33,	/* Japan (W52) */
+	RTW_RD_5G_ETSI14 = 34,	/* Russia */
+	RTW_RD_5G_FCC11 = 35,	/* US(include CH144) */
+	RTW_RD_5G_ETSI15 = 36,	/* Malaysia */
+	RTW_RD_5G_MKK5 = 37,	/* Japan */
+	RTW_RD_5G_ETSI16 = 38,	/* Europe */
+	RTW_RD_5G_ETSI17 = 39,	/* Europe */
+	RTW_RD_5G_FCC12 = 40,	/* FCC */
+	RTW_RD_5G_FCC13 = 41,	/* FCC */
+	RTW_RD_5G_FCC14 = 42,	/* FCC w/o Weather radar(w/o 5600~5650MHz) */
+	RTW_RD_5G_FCC15 = 43,	/* FCC w/o Band3 */
+	RTW_RD_5G_FCC16 = 44,	/* FCC w/o Band3 */
+	RTW_RD_5G_ETSI18 = 45,	/* ETSI w/o DFS Band2&3 */
+	RTW_RD_5G_ETSI19 = 46,	/* Europe */
+	RTW_RD_5G_FCC17 = 47,	/* FCC w/o Weather radar(w/o 5600~5650MHz) */
+	RTW_RD_5G_ETSI20 = 48,	/* Europe */
+	RTW_RD_5G_IC2 = 49,		/* Canada(w/o Weather radar), include ch144 */
+	RTW_RD_5G_ETSI21 = 50,	/* Australia, New Zealand(w/o Weather radar) */
+	RTW_RD_5G_FCC18 = 51,	/*  */
+	RTW_RD_5G_WORLD = 52,	/* Worldwide */
+	RTW_RD_5G_CHILE1 = 53,	/* Chile */
+	RTW_RD_5G_ACMA1 = 54,	/* Australia, New Zealand (w/o Weather radar) (w/o Ch120~Ch128) */
+	RTW_RD_5G_WORLD1 = 55,	/* 5G Worldwide Band1&2 */
+	RTW_RD_5G_CHILE2 = 56,	/* Chile (Band2,Band3) */
+
+	/* === Below are driver defined for legacy channel plan compatible, DON'T assign index ==== */
+	RTW_RD_5G_OLD_FCC1,
+	RTW_RD_5G_OLD_NCC1,
+	RTW_RD_5G_OLD_KCC1,
+
+	RTW_RD_5G_MAX,
+};
+
+static struct ch_list_t RTW_ChannelPlan2G[] = {
+	/* 0, RTW_RD_2G_NULL */		CH_LIST_ENT(0),
+	/* 1, RTW_RD_2G_WORLD */	CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 2, RTW_RD_2G_ETSI1 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 3, RTW_RD_2G_FCC1 */		CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
+	/* 4, RTW_RD_2G_MKK1 */		CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
+	/* 5, RTW_RD_2G_ETSI2 */		CH_LIST_ENT(4, 10, 11, 12, 13),
+	/* 6, RTW_RD_2G_GLOBAL */	CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
+	/* 7, RTW_RD_2G_MKK2 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 8, RTW_RD_2G_FCC2 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 9, RTW_RD_2G_IC1 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 10, RTW_RD_2G_WORLD1 */	CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
 };
 
-static RT_CHANNEL_PLAN_5G RTW_ChannelPlan5G[] = {
-	/* 0, RTW_RD_5G_NULL */		{{}, 0},
-	/* 1, RTW_RD_5G_ETSI1 */		{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 19},
-	/* 2, RTW_RD_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},
-	/* 3, RTW_RD_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},
-	/* 4, RTW_RD_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},
-	/* 5, RTW_RD_5G_FCC2 */		{{36, 40, 44, 48, 149, 153, 157, 161, 165}, 9},
-	/* 6, RTW_RD_5G_FCC3 */		{{36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165}, 13},
-	/* 7, RTW_RD_5G_FCC4 */		{{36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161}, 12},
-	/* 8, RTW_RD_5G_FCC5 */		{{149, 153, 157, 161, 165}, 5},
-	/* 9, RTW_RD_5G_FCC6 */		{{36, 40, 44, 48, 52, 56, 60, 64}, 8},
-	/* 10, RTW_RD_5G_FCC7 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 21},
-	/* 11, RTW_RD_5G_KCC1 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161}, 19},
-	/* 12, RTW_RD_5G_MKK1 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 19},
-	/* 13, RTW_RD_5G_MKK2 */	{{36, 40, 44, 48, 52, 56, 60, 64}, 8},
-	/* 14, RTW_RD_5G_MKK3 */	{{100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 11},
-	/* 15, RTW_RD_5G_NCC1 */	{{56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 16},
-	/* 16, RTW_RD_5G_NCC2 */	{{56, 60, 64, 149, 153, 157, 161, 165}, 8},
-	/* 17, RTW_RD_5G_NCC3 */	{{149, 153, 157, 161, 165}, 5},
-	/* 18, RTW_RD_5G_ETSI4 */	{{36, 40, 44, 48}, 4},
-	/* 19, RTW_RD_5G_ETSI5 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 21},
-	/* 20, RTW_RD_5G_FCC8 */	{{149, 153, 157, 161}, 4},
-	/* 21, RTW_RD_5G_ETSI6 */	{{36, 40, 44, 48, 52, 56, 60, 64}, 8},
-	/* 22, RTW_RD_5G_ETSI7 */	{{36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165}, 13},
-	/* 23, RTW_RD_5G_ETSI8 */	{{36, 40, 44, 48, 149, 153, 157, 161, 165}, 9},
-	/* 24, RTW_RD_5G_ETSI9 */	{{100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 11},
-	/* 25, RTW_RD_5G_ETSI10 */	{{149, 153, 157, 161, 165}, 5},
-	/* 26, RTW_RD_5G_ETSI11 */	{{36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140, 149, 153, 157, 161, 165}, 16},
-	/* 27, RTW_RD_5G_NCC4 */	{{52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 17},
-	/* 28, RTW_RD_5G_ETSI12 */	{{149, 153, 157, 161}, 4},
-	/* 29, RTW_RD_5G_FCC9 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 21},
-	/* 30, RTW_RD_5G_ETSI13 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140}, 16},
-	/* 31, RTW_RD_5G_FCC10 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161}, 20},
-	/* 32, RTW_RD_5G_MKK4 */	{{36, 40, 44, 48}, 4},
-	/* 33, RTW_RD_5G_ETSI14 */	{{36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140}, 11},
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+static struct ch_list_t RTW_ChannelPlan5G[] = {
+	/* 0, RTW_RD_5G_NULL */		CH_LIST_ENT(0),
+	/* 1, RTW_RD_5G_ETSI1 */		CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 2, RTW_RD_5G_ETSI2 */		CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 3, RTW_RD_5G_ETSI3 */		CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 149, 153, 157, 161, 165),
+	/* 4, RTW_RD_5G_FCC1 */		CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 5, RTW_RD_5G_FCC2 */		CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
+	/* 6, RTW_RD_5G_FCC3 */		CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 7, RTW_RD_5G_FCC4 */		CH_LIST_ENT(12, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161),
+	/* 8, RTW_RD_5G_FCC5 */		CH_LIST_ENT(5, 149, 153, 157, 161, 165),
+	/* 9, RTW_RD_5G_FCC6 */		CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 10, RTW_RD_5G_FCC7 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 11, RTW_RD_5G_IC1 */		CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 12, RTW_RD_5G_KCC1 */	CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161),
+	/* 13, RTW_RD_5G_MKK1 */	CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 14, RTW_RD_5G_MKK2 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 15, RTW_RD_5G_MKK3 */	CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 16, RTW_RD_5G_NCC1 */	CH_LIST_ENT(16, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 17, RTW_RD_5G_NCC2 */	CH_LIST_ENT(8, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 18, RTW_RD_5G_NCC3 */	CH_LIST_ENT(5, 149, 153, 157, 161, 165),
+	/* 19, RTW_RD_5G_ETSI4 */	CH_LIST_ENT(4, 36, 40, 44, 48),
+	/* 20, RTW_RD_5G_ETSI5 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 21, RTW_RD_5G_FCC8 */	CH_LIST_ENT(4, 149, 153, 157, 161),
+	/* 22, RTW_RD_5G_ETSI6 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 23, RTW_RD_5G_ETSI7 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 24, RTW_RD_5G_ETSI8 */	CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
+	/* 25, RTW_RD_5G_ETSI9 */	CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 26, RTW_RD_5G_ETSI10 */	CH_LIST_ENT(5, 149, 153, 157, 161, 165),
+	/* 27, RTW_RD_5G_ETSI11 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 28, RTW_RD_5G_NCC4 */	CH_LIST_ENT(17, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 29, RTW_RD_5G_ETSI12 */	CH_LIST_ENT(4, 149, 153, 157, 161),
+	/* 30, RTW_RD_5G_FCC9 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 31, RTW_RD_5G_ETSI13 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
+	/* 32, RTW_RD_5G_FCC10 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161),
+	/* 33, RTW_RD_5G_MKK4 */	CH_LIST_ENT(4, 36, 40, 44, 48),
+	/* 34, RTW_RD_5G_ETSI14 */	CH_LIST_ENT(11, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140),
+	/* 35, RTW_RD_5G_FCC11 */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 36, RTW_RD_5G_ETSI15 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 149, 153, 157, 161, 165),
+	/* 37, RTW_RD_5G_MKK5 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 38, RTW_RD_5G_ETSI16 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 39, RTW_RD_5G_ETSI17 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 40, RTW_RD_5G_FCC12*/	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 41, RTW_RD_5G_FCC13 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 42, RTW_RD_5G_FCC14 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 43, RTW_RD_5G_FCC15 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 44, RTW_RD_5G_FCC16 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 45, RTW_RD_5G_ETSI18 */	CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
+	/* 46, RTW_RD_5G_ETSI19 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 47, RTW_RD_5G_FCC17 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
+	/* 48, RTW_RD_5G_ETSI20 */	CH_LIST_ENT(9, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 49, RTW_RD_5G_IC2 */		CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 50, RTW_RD_5G_ETSI21 */	CH_LIST_ENT(13, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 51, RTW_RD_5G_FCC18 */	CH_LIST_ENT(8, 100, 104, 108, 112, 116, 132, 136, 140),
+	/* 52, RTW_RD_5G_WORLD */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 53, RTW_RD_5G_CHILE1 */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 54, RTW_RD_5G_ACMA1 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 55, RTW_RD_5G_WORLD1 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 56, RTW_RD_5G_CHILE2 */	CH_LIST_ENT(16, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144),
 
 	/* === Below are driver defined for legacy channel plan compatible, NO static index assigned ==== */
-	/* RTW_RD_5G_OLD_FCC1 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 20},
-	/* RTW_RD_5G_OLD_NCC1 */	{{56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 15},
-	/* RTW_RD_5G_OLD_KCC1 */	{{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165}, 20},
+	/* RTW_RD_5G_OLD_FCC1 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
+	/* RTW_RD_5G_OLD_NCC1 */	CH_LIST_ENT(15, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
+	/* RTW_RD_5G_OLD_KCC1 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165),
 };
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
 
-static RT_CHANNEL_PLAN_MAP	RTW_ChannelPlanMap[] = {
+static RT_CHANNEL_PLAN_MAP	RTW_ChannelPlanMap[RTW_CHPLAN_MAX] = {
 	/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_KCC1,		TXPWR_LMT_FCC},		/* 0x00, RTW_CHPLAN_FCC */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_OLD_FCC1,	TXPWR_LMT_FCC},		/* 0x01, RTW_CHPLAN_IC */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI},	/* 0x02, RTW_CHPLAN_ETSI */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_NULL,		TXPWR_LMT_ETSI},	/* 0x03, RTW_CHPLAN_SPAIN */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_NULL,		TXPWR_LMT_ETSI},	/* 0x04, RTW_CHPLAN_FRANCE */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_NULL,		TXPWR_LMT_MKK},		/* 0x05, RTW_CHPLAN_MKK */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_NULL,		TXPWR_LMT_MKK},		/* 0x06, RTW_CHPLAN_MKK1 */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI},	/* 0x07, RTW_CHPLAN_ISRAEL */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_FCC6,		TXPWR_LMT_MKK},		/* 0x08, RTW_CHPLAN_TELEC */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_OLD_NCC1,	TXPWR_LMT_FCC},		/* 0x0B, RTW_CHPLAN_TAIWAN */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI},	/* 0x0C, RTW_CHPLAN_CHINA */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC3,		TXPWR_LMT_WW},		/* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */ /* ETSI:Singapore, India. FCC:Mexico => WW */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_OLD_KCC1,	TXPWR_LMT_ETSI},	/* 0x0E, RTW_CHPLAN_KOREA */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI},	/* 0x0F, RTW_CHPLAN_TURKEY */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_ETSI1,	TXPWR_LMT_MKK},		/* 0x10, RTW_CHPLAN_JAPAN */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC2,		TXPWR_LMT_FCC},		/* 0x11, RTW_CHPLAN_FCC_NO_DFS */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_FCC7,		TXPWR_LMT_MKK},		/* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_FCC1,		TXPWR_LMT_WW},		/* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_NCC2,		TXPWR_LMT_FCC},		/* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_FCC7,		TXPWR_LMT_ETSI},	/* 0x15, RTW_CHPLAN_ETSI_NO_DFS */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_NCC1,		TXPWR_LMT_ETSI},	/* 0x16, RTW_CHPLAN_KOREA_NO_DFS */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_FCC7,		TXPWR_LMT_MKK},		/* 0x17, RTW_CHPLAN_JAPAN_NO_DFS */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI},	/* 0x18, RTW_CHPLAN_PAKISTAN_NO_DFS */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC5,		TXPWR_LMT_FCC},		/* 0x19, RTW_CHPLAN_TAIWAN2_NO_DFS */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x1A, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x1B, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x1C, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x1D, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x1E, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_FCC1,		TXPWR_LMT_WW},		/* 0x1F, RTW_CHPLAN_WORLD_WIDE_ONLY_5G */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_KCC1,		TXPWR_LMT_FCC),		/* 0x00, RTW_CHPLAN_FCC */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_FCC1,	TXPWR_LMT_FCC),		/* 0x01, RTW_CHPLAN_IC */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x02, RTW_CHPLAN_ETSI */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x03, RTW_CHPLAN_SPAIN */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x04, RTW_CHPLAN_FRANCE */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x05, RTW_CHPLAN_MKK */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x06, RTW_CHPLAN_MKK1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI),	/* 0x07, RTW_CHPLAN_ISRAEL */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_FCC6,		TXPWR_LMT_MKK),		/* 0x08, RTW_CHPLAN_TELEC */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_NCC1,	TXPWR_LMT_FCC),		/* 0x0B, RTW_CHPLAN_TAIWAN */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI),	/* 0x0C, RTW_CHPLAN_CHINA */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC3,		TXPWR_LMT_WW),		/* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */ /* ETSI:Singapore, India. FCC:Mexico => WW */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_KCC1,	TXPWR_LMT_ETSI),	/* 0x0E, RTW_CHPLAN_KOREA */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI),	/* 0x0F, RTW_CHPLAN_TURKEY */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_MKK),		/* 0x10, RTW_CHPLAN_JAPAN */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x11, RTW_CHPLAN_FCC_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC7,		TXPWR_LMT_MKK),		/* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC1,		TXPWR_LMT_WW),		/* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC2,		TXPWR_LMT_FCC),		/* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC7,		TXPWR_LMT_ETSI),	/* 0x15, RTW_CHPLAN_ETSI_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NCC1,		TXPWR_LMT_ETSI),	/* 0x16, RTW_CHPLAN_KOREA_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_FCC7,		TXPWR_LMT_MKK),		/* 0x17, RTW_CHPLAN_JAPAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI),	/* 0x18, RTW_CHPLAN_PAKISTAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x19, RTW_CHPLAN_TAIWAN2_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1A, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1B, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1C, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1D, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1E, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_FCC1,		TXPWR_LMT_WW),		/* 0x1F, RTW_CHPLAN_WORLD_WIDE_ONLY_5G */
 
 	/* ===== 0x20 ~ 0x7F, new channel plan ===== */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x20, RTW_CHPLAN_WORLD_NULL */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_NULL,		TXPWR_LMT_ETSI},	/* 0x21, RTW_CHPLAN_ETSI1_NULL */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_NULL,		TXPWR_LMT_FCC},		/* 0x22, RTW_CHPLAN_FCC1_NULL */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_NULL,		TXPWR_LMT_MKK},		/* 0x23, RTW_CHPLAN_MKK1_NULL */
-	{RTW_RD_2G_ETSI2,	RTW_RD_5G_NULL,		TXPWR_LMT_ETSI},	/* 0x24, RTW_CHPLAN_ETSI2_NULL */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC1,		TXPWR_LMT_FCC},		/* 0x25, RTW_CHPLAN_FCC1_FCC1 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI},	/* 0x26, RTW_CHPLAN_WORLD_ETSI1 */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_MKK1,		TXPWR_LMT_MKK},		/* 0x27, RTW_CHPLAN_MKK1_MKK1 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_KCC1,		TXPWR_LMT_ETSI},	/* 0x28, RTW_CHPLAN_WORLD_KCC1 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_FCC2,		TXPWR_LMT_FCC},		/* 0x29, RTW_CHPLAN_WORLD_FCC2 */
-	{RTW_RD_2G_FCC2,	RTW_RD_5G_NULL,		TXPWR_LMT_FCC},		/* 0x2A, RTW_CHPLAN_FCC2_NULL */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x2B, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x2C, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x2D, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x2E, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x2F, */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_FCC3,		TXPWR_LMT_FCC},		/* 0x30, RTW_CHPLAN_WORLD_FCC3 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_FCC4,		TXPWR_LMT_FCC},		/* 0x31, RTW_CHPLAN_WORLD_FCC4 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_FCC5,		TXPWR_LMT_FCC},		/* 0x32, RTW_CHPLAN_WORLD_FCC5 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_FCC6,		TXPWR_LMT_FCC},		/* 0x33, RTW_CHPLAN_WORLD_FCC6 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC7,		TXPWR_LMT_FCC},		/* 0x34, RTW_CHPLAN_FCC1_FCC7 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI2,	TXPWR_LMT_ETSI},	/* 0x35, RTW_CHPLAN_WORLD_ETSI2 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI3,	TXPWR_LMT_ETSI},	/* 0x36, RTW_CHPLAN_WORLD_ETSI3 */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_MKK2,		TXPWR_LMT_MKK},		/* 0x37, RTW_CHPLAN_MKK1_MKK2 */
-	{RTW_RD_2G_MKK1,	RTW_RD_5G_MKK3,		TXPWR_LMT_MKK},		/* 0x38, RTW_CHPLAN_MKK1_MKK3 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_NCC1,		TXPWR_LMT_FCC},		/* 0x39, RTW_CHPLAN_FCC1_NCC1 */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x3A, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x3B, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x3C, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x3D, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x3E, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x3F, */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_NCC2,		TXPWR_LMT_FCC},		/* 0x40, RTW_CHPLAN_FCC1_NCC2 */
-	{RTW_RD_2G_GLOBAL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x41, RTW_CHPLAN_GLOBAL_NULL */
-	{RTW_RD_2G_ETSI1,	RTW_RD_5G_ETSI4,	TXPWR_LMT_ETSI},	/* 0x42, RTW_CHPLAN_ETSI1_ETSI4 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC2,		TXPWR_LMT_FCC},		/* 0x43, RTW_CHPLAN_FCC1_FCC2 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_NCC3,		TXPWR_LMT_FCC},		/* 0x44, RTW_CHPLAN_FCC1_NCC3 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI5,	TXPWR_LMT_ETSI},	/* 0x45, RTW_CHPLAN_WORLD_ETSI5 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC8,		TXPWR_LMT_FCC},		/* 0x46, RTW_CHPLAN_FCC1_FCC8 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI6,	TXPWR_LMT_ETSI},	/* 0x47, RTW_CHPLAN_WORLD_ETSI6 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI7,	TXPWR_LMT_ETSI},	/* 0x48, RTW_CHPLAN_WORLD_ETSI7 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI8,	TXPWR_LMT_ETSI},	/* 0x49, RTW_CHPLAN_WORLD_ETSI8 */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x4A, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x4B, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x4C, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x4D, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x4E, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x4F, */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI9,	TXPWR_LMT_ETSI},	/* 0x50, RTW_CHPLAN_WORLD_ETSI9 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI10,	TXPWR_LMT_ETSI},	/* 0x51, RTW_CHPLAN_WORLD_ETSI10 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI11,	TXPWR_LMT_ETSI},	/* 0x52, RTW_CHPLAN_WORLD_ETSI11 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_NCC4,		TXPWR_LMT_FCC},		/* 0x53, RTW_CHPLAN_FCC1_NCC4 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI12,	TXPWR_LMT_ETSI},	/* 0x54, RTW_CHPLAN_WORLD_ETSI12 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC9,		TXPWR_LMT_FCC},		/* 0x55, RTW_CHPLAN_FCC1_FCC9 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI13,	TXPWR_LMT_ETSI},	/* 0x56, RTW_CHPLAN_WORLD_ETSI13 */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC10,	TXPWR_LMT_FCC},		/* 0x57, RTW_CHPLAN_FCC1_FCC10 */
-	{RTW_RD_2G_MKK2,	RTW_RD_5G_MKK4,		TXPWR_LMT_MKK},		/* 0x58, RTW_CHPLAN_MKK2_MKK4 */
-	{RTW_RD_2G_WORLD,	RTW_RD_5G_ETSI14,	TXPWR_LMT_ETSI},	/* 0x59, RTW_CHPLAN_WORLD_ETSI14 */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x5A, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x5B, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x5C, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x5D, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x5E, */
-	{RTW_RD_2G_NULL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW},		/* 0x5F, */
-	{RTW_RD_2G_FCC1,	RTW_RD_5G_FCC5,		TXPWR_LMT_FCC},		/* 0x60, RTW_CHPLAN_FCC1_FCC5 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x20, RTW_CHPLAN_WORLD_NULL */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x21, RTW_CHPLAN_ETSI1_NULL */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NULL,		TXPWR_LMT_FCC),		/* 0x22, RTW_CHPLAN_FCC1_NULL */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x23, RTW_CHPLAN_MKK1_NULL */
+	CHPLAN_ENT(RTW_RD_2G_ETSI2,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x24, RTW_CHPLAN_ETSI2_NULL */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC),		/* 0x25, RTW_CHPLAN_FCC1_FCC1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x26, RTW_CHPLAN_WORLD_ETSI1 */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK1,		TXPWR_LMT_MKK),		/* 0x27, RTW_CHPLAN_MKK1_MKK1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_KCC1,		TXPWR_LMT_KCC),		/* 0x28, RTW_CHPLAN_WORLD_KCC1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x29, RTW_CHPLAN_WORLD_FCC2 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_NULL,		TXPWR_LMT_FCC),		/* 0x2A, RTW_CHPLAN_FCC2_NULL */
+	CHPLAN_ENT(RTW_RD_2G_IC1,		RTW_RD_5G_IC2,		TXPWR_LMT_IC),		/* 0x2B, RTW_CHPLAN_IC1_IC2 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x2C, RTW_CHPLAN_MKK2_NULL */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_CHILE1,	TXPWR_LMT_CHILE),	/* 0x2D, RTW_CHPLAN_WORLD_CHILE1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD1,	RTW_RD_5G_WORLD1,	TXPWR_LMT_WW),		/* 0x2E, RTW_CHPLAN_WORLD1_WORLD1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_CHILE2,	TXPWR_LMT_CHILE),	/* 0x2F, RTW_CHPLAN_WORLD_CHILE2 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC3,		TXPWR_LMT_FCC),		/* 0x30, RTW_CHPLAN_WORLD_FCC3 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC4,		TXPWR_LMT_FCC),		/* 0x31, RTW_CHPLAN_WORLD_FCC4 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x32, RTW_CHPLAN_WORLD_FCC5 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC6,		TXPWR_LMT_FCC),		/* 0x33, RTW_CHPLAN_WORLD_FCC6 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x34, RTW_CHPLAN_FCC1_FCC7 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI2,	TXPWR_LMT_ETSI),	/* 0x35, RTW_CHPLAN_WORLD_ETSI2 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI3,	TXPWR_LMT_ETSI),	/* 0x36, RTW_CHPLAN_WORLD_ETSI3 */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK2,		TXPWR_LMT_MKK),		/* 0x37, RTW_CHPLAN_MKK1_MKK2 */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK3,		TXPWR_LMT_MKK),		/* 0x38, RTW_CHPLAN_MKK1_MKK3 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC1,		TXPWR_LMT_FCC),		/* 0x39, RTW_CHPLAN_FCC1_NCC1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x3A, RTW_CHPLAN_ETSI1_ETSI1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ACMA1,	TXPWR_LMT_ACMA),	/* 0x3B, RTW_CHPLAN_ETSI1_ACMA1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI6,	TXPWR_LMT_ETSI),	/* 0x3C, RTW_CHPLAN_ETSI1_ETSI6 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI12,	TXPWR_LMT_ETSI),	/* 0x3D, RTW_CHPLAN_ETSI1_ETSI12 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3E, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3F, */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC2,		TXPWR_LMT_FCC),		/* 0x40, RTW_CHPLAN_FCC1_NCC2 */
+	CHPLAN_ENT(RTW_RD_2G_GLOBAL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x41, RTW_CHPLAN_GLOBAL_NULL */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI4,	TXPWR_LMT_ETSI),	/* 0x42, RTW_CHPLAN_ETSI1_ETSI4 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x43, RTW_CHPLAN_FCC1_FCC2 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC3,		TXPWR_LMT_FCC),		/* 0x44, RTW_CHPLAN_FCC1_NCC3 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ACMA1,	TXPWR_LMT_ACMA),	/* 0x45, RTW_CHPLAN_WORLD_ACMA1 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC8,		TXPWR_LMT_FCC),		/* 0x46, RTW_CHPLAN_FCC1_FCC8 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI6,	TXPWR_LMT_ETSI),	/* 0x47, RTW_CHPLAN_WORLD_ETSI6 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI7,	TXPWR_LMT_ETSI),	/* 0x48, RTW_CHPLAN_WORLD_ETSI7 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI8,	TXPWR_LMT_ETSI),	/* 0x49, RTW_CHPLAN_WORLD_ETSI8 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4A, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4B, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4C, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4D, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4E, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4F, */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI9,	TXPWR_LMT_ETSI),	/* 0x50, RTW_CHPLAN_WORLD_ETSI9 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI10,	TXPWR_LMT_ETSI),	/* 0x51, RTW_CHPLAN_WORLD_ETSI10 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI11,	TXPWR_LMT_ETSI),	/* 0x52, RTW_CHPLAN_WORLD_ETSI11 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC4,		TXPWR_LMT_FCC),		/* 0x53, RTW_CHPLAN_FCC1_NCC4 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI12,	TXPWR_LMT_ETSI),	/* 0x54, RTW_CHPLAN_WORLD_ETSI12 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC9,		TXPWR_LMT_FCC),		/* 0x55, RTW_CHPLAN_FCC1_FCC9 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI13,	TXPWR_LMT_ETSI),	/* 0x56, RTW_CHPLAN_WORLD_ETSI13 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC10,	TXPWR_LMT_FCC),		/* 0x57, RTW_CHPLAN_FCC1_FCC10 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK4,		TXPWR_LMT_MKK),		/* 0x58, RTW_CHPLAN_MKK2_MKK4 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI14,	TXPWR_LMT_ETSI),	/* 0x59, RTW_CHPLAN_WORLD_ETSI14 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5A, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5B, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5C, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5D, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5E, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5F, */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x60, RTW_CHPLAN_FCC1_FCC5 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x61, RTW_CHPLAN_FCC2_FCC7 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC),		/* 0x62, RTW_CHPLAN_FCC2_FCC1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI15,	TXPWR_LMT_ETSI),	/* 0x63, RTW_CHPLAN_WORLD_ETSI15 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK5,		TXPWR_LMT_MKK),		/* 0x64, RTW_CHPLAN_MKK2_MKK5 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI16,	TXPWR_LMT_ETSI),	/* 0x65, RTW_CHPLAN_ETSI1_ETSI16 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC14,	TXPWR_LMT_FCC),		/* 0x66, RTW_CHPLAN_FCC1_FCC14 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x67, RTW_CHPLAN_FCC1_FCC12 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC14,	TXPWR_LMT_FCC),		/* 0x68, RTW_CHPLAN_FCC2_FCC14 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x69, RTW_CHPLAN_FCC2_FCC12 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI17,	TXPWR_LMT_ETSI),	/* 0x6A, RTW_CHPLAN_ETSI1_ETSI17 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC16,	TXPWR_LMT_FCC),		/* 0x6B, RTW_CHPLAN_WORLD_FCC16 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC13,	TXPWR_LMT_FCC),		/* 0x6C, RTW_CHPLAN_WORLD_FCC13 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC15,	TXPWR_LMT_FCC),		/* 0x6D, RTW_CHPLAN_FCC2_FCC15 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x6E, RTW_CHPLAN_WORLD_FCC12 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI8,	TXPWR_LMT_ETSI),	/* 0x6F, RTW_CHPLAN_NULL_ETSI8 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI18,	TXPWR_LMT_ETSI),	/* 0x70, RTW_CHPLAN_NULL_ETSI18 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI17,	TXPWR_LMT_ETSI),	/* 0x71, RTW_CHPLAN_NULL_ETSI17 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI19,	TXPWR_LMT_ETSI),	/* 0x72, RTW_CHPLAN_NULL_ETSI19 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x73, RTW_CHPLAN_WORLD_FCC7 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC17,	TXPWR_LMT_FCC),		/* 0x74, RTW_CHPLAN_FCC2_FCC17 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI20,	TXPWR_LMT_ETSI),	/* 0x75, RTW_CHPLAN_WORLD_ETSI20 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC11,	TXPWR_LMT_FCC),		/* 0x76, RTW_CHPLAN_FCC2_FCC11 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI21,	TXPWR_LMT_ETSI),	/* 0x77, RTW_CHPLAN_WORLD_ETSI21 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC18,	TXPWR_LMT_FCC),		/* 0x78, RTW_CHPLAN_FCC1_FCC18 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK1,		TXPWR_LMT_MKK),		/* 0x79, RTW_CHPLAN_MKK2_MKK1 */
 };
 
-static RT_CHANNEL_PLAN_MAP RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE = {
-	RTW_RD_2G_WORLD,	RTW_RD_5G_FCC1,		TXPWR_LMT_FCC		/* 0x7F, Realtek Define */
-};
+static RT_CHANNEL_PLAN_MAP RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE =
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC);		/* 0x7F, Realtek Define */
 
 bool rtw_chplan_is_empty(u8 id)
 {
@@ -314,90 +449,437 @@ bool rtw_chplan_is_empty(u8 id)
 		chplan_map = &RTW_ChannelPlanMap[id];
 
 	if (chplan_map->Index2G == RTW_RD_2G_NULL
-		&& chplan_map->Index5G == RTW_RD_5G_NULL)
+		#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		&& chplan_map->Index5G == RTW_RD_5G_NULL
+		#endif
+	)
 		return _TRUE;
 
 	return _FALSE;
 }
 
-#ifdef CONFIG_DFS_MASTER
-void rtw_rfctl_reset_cac(struct rf_ctl_t *rfctl)
+bool rtw_regsty_is_excl_chs(struct registry_priv *regsty, u8 ch)
+{
+	int i;
+
+	for (i = 0; i < MAX_CHANNEL_NUM; i++) {
+		if (regsty->excl_chs[i] == 0)
+			break;
+		if (regsty->excl_chs[i] == ch)
+			return _TRUE;
+	}
+	return _FALSE;
+}
+
+inline u8 rtw_rd_5g_band1_passive(u8 rtw_rd_5g)
+{
+	u8 passive = 0;
+
+	switch (rtw_rd_5g) {
+	case RTW_RD_5G_FCC13:
+	case RTW_RD_5G_FCC16:
+	case RTW_RD_5G_ETSI18:
+	case RTW_RD_5G_ETSI19:
+	case RTW_RD_5G_WORLD:
+	case RTW_RD_5G_WORLD1:
+		passive = 1;
+	};
+
+	return passive;
+}
+
+inline u8 rtw_rd_5g_band4_passive(u8 rtw_rd_5g)
+{
+	u8 passive = 0;
+
+	switch (rtw_rd_5g) {
+	case RTW_RD_5G_MKK5:
+	case RTW_RD_5G_ETSI16:
+	case RTW_RD_5G_ETSI18:
+	case RTW_RD_5G_ETSI19:
+	case RTW_RD_5G_WORLD:
+		passive = 1;
+	};
+
+	return passive;
+}
+
+static void init_channel_list(_adapter *padapter, RT_CHANNEL_INFO *channel_set
+	, struct p2p_channels *channel_list)
+{
+	struct registry_priv *regsty = adapter_to_regsty(padapter);
+
+	struct p2p_oper_class_map op_class[] = {
+		{ IEEE80211G,  81,   1,  13,  1, BW20 },
+		{ IEEE80211G,  82,  14,  14,  1, BW20 },
+#if 0 /* Do not enable HT40 on 2 GHz */
+		{ IEEE80211G,  83,   1,   9,  1, BW40PLUS },
+		{ IEEE80211G,  84,   5,  13,  1, BW40MINUS },
+#endif
+		{ 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 (rtw_chset_search_ch(channel_set, ch) == -1)
+				continue;
+
+			if ((padapter->registrypriv.ht_enable == 0) && (o->inc == 8))
+				continue;
+
+			if ((REGSTY_IS_BW_5G_SUPPORT(regsty, CHANNEL_WIDTH_40)) &&
+			    ((o->bw == BW40MINUS) || (o->bw == BW40PLUS)))
+				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(_adapter *padapter, u8 ChannelPlan, RT_CHANNEL_INFO *channel_set)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct registry_priv *regsty = adapter_to_regsty(padapter);
+	u8	index, chanset_size = 0;
+	u8	b5GBand = _FALSE, b2_4GBand = _FALSE;
+	u8	Index2G = 0, Index5G = 0;
+	int i;
+
+	if (!rtw_is_channel_plan_valid(ChannelPlan)) {
+		RTW_ERR("ChannelPlan ID 0x%02X error !!!!!\n", ChannelPlan);
+		return chanset_size;
+	}
+
+	_rtw_memset(channel_set, 0, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
+
+	if (IsSupported24G(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_2G))
+		b2_4GBand = _TRUE;
+
+	if (is_supported_5g(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_5G))
+		b5GBand = _TRUE;
+
+	if (b2_4GBand == _FALSE && b5GBand == _FALSE) {
+		RTW_WARN("HW band_cap has no intersection with SW wireless_mode setting\n");
+		return chanset_size;
+	}
+
+	if (b2_4GBand) {
+		if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
+			Index2G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index2G;
+		else
+			Index2G = RTW_ChannelPlanMap[ChannelPlan].Index2G;
+
+		for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan2G[Index2G]); index++) {
+			if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan2G[Index2G], index)) == _TRUE)
+				continue;
+
+			if (chanset_size >= MAX_CHANNEL_NUM) {
+				RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
+				break;
+			}
+
+			channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan2G[Index2G], index);
+
+			if (ChannelPlan == RTW_CHPLAN_GLOBAL_DOAMIN
+				|| Index2G == RTW_RD_2G_GLOBAL
+			) {
+				/* Channel 1~11 is active, and 12~14 is passive */
+				if (channel_set[chanset_size].ChannelNum >= 1 && channel_set[chanset_size].ChannelNum <= 11)
+					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+				else if ((channel_set[chanset_size].ChannelNum  >= 12 && channel_set[chanset_size].ChannelNum  <= 14))
+					channel_set[chanset_size].ScanType  = SCAN_PASSIVE;
+			} else if (ChannelPlan == RTW_CHPLAN_WORLD_WIDE_13
+				|| ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G
+				|| Index2G == RTW_RD_2G_WORLD
+			) {
+				/* channel 12~13, passive scan */
+				if (channel_set[chanset_size].ChannelNum <= 11)
+					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+				else
+					channel_set[chanset_size].ScanType = SCAN_PASSIVE;
+			} else
+				channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+
+			chanset_size++;
+		}
+	}
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (b5GBand) {
+		if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
+			Index5G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index5G;
+		else
+			Index5G = RTW_ChannelPlanMap[ChannelPlan].Index5G;
+
+		for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan5G[Index5G]); index++) {
+			if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan5G[Index5G], index)) == _TRUE)
+				continue;
+			#ifndef CONFIG_DFS
+			if (rtw_is_dfs_ch(CH_LIST_CH(RTW_ChannelPlan5G[Index5G], index)))
+				continue;
+			#endif
+
+			if (chanset_size >= MAX_CHANNEL_NUM) {
+				RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
+				break;
+			}
+
+			channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan5G[Index5G], index);
+
+			if ((ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G) /* all channels passive */
+				|| (rtw_is_5g_band1(channel_set[chanset_size].ChannelNum)
+					&& rtw_rd_5g_band1_passive(Index5G)) /* band1 passive */
+				|| (rtw_is_5g_band4(channel_set[chanset_size].ChannelNum)
+					&& rtw_rd_5g_band4_passive(Index5G)) /* band4 passive */
+				|| (rtw_is_dfs_ch(channel_set[chanset_size].ChannelNum)) /* DFS channel(band2, 3) passive */
+			)
+				channel_set[chanset_size].ScanType = SCAN_PASSIVE;
+			else
+				channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+
+			chanset_size++;
+		}
+	}
+
+	#ifdef CONFIG_DFS_MASTER
+	for (i = 0; i < chanset_size; i++)
+		channel_set[i].non_ocp_end_time = rtw_get_current_time();
+	#endif
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
+
+	if (chanset_size)
+		RTW_INFO(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, ch num:%d\n"
+			, FUNC_ADPT_ARG(padapter), ChannelPlan, chanset_size);
+	else
+		RTW_WARN(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, final chset has no channel\n"
+			, FUNC_ADPT_ARG(padapter), ChannelPlan);
+
+	return chanset_size;
+}
+
+#ifdef CONFIG_TXPWR_LIMIT
+void rtw_txpwr_init_regd(struct rf_ctl_t *rfctl)
 {
-	if (rtw_is_long_cac_ch(rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset))
-		rfctl->cac_end_time = rtw_get_current_time() + rtw_ms_to_systime(CAC_TIME_CE_MS);
+	u8 regd;
+	u8 regd_name;
+	struct regd_exc_ent *exc;
+	struct txpwr_lmt_ent *ent;
+	_irqL irqL;
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	rfctl->regd_name = NULL;
+
+	if (rfctl->txpwr_regd_num == 0) {
+		RTW_PRINT("there is no any txpwr_regd\n");
+		goto release_lock;
+	}
+
+	/* search from exception mapping */
+	exc = _rtw_regd_exc_search(rfctl
+		, rfctl->country_ent ? rfctl->country_ent->alpha2 : NULL
+		, rfctl->ChannelPlan);
+	if (exc) {
+		u8 has_country = (exc->country[0] == '\0' && exc->country[1] == '\0') ? 0 : 1;
+
+		if (strcmp(exc->regd_name, regd_str(TXPWR_LMT_NONE)) == 0)
+			rfctl->regd_name = regd_str(TXPWR_LMT_NONE);
+		else if (strcmp(exc->regd_name, regd_str(TXPWR_LMT_WW)) == 0)
+			rfctl->regd_name = regd_str(TXPWR_LMT_WW);
+		else {
+			ent = _rtw_txpwr_lmt_get_by_name(rfctl, exc->regd_name);
+			if (ent)
+				rfctl->regd_name = ent->regd_name;
+		}
+
+		RTW_PRINT("exception mapping country:%c%c domain:0x%02x to%s regd_name:%s\n"
+			, has_country ? exc->country[0] : '0'
+			, has_country ? exc->country[1] : '0'
+			, exc->domain
+			, rfctl->regd_name ? "" : " unknown"
+			, exc->regd_name
+		);
+		if (rfctl->regd_name)
+			goto release_lock;
+	}
+
+	/* follow default channel plan mapping */
+	if (rfctl->ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
+		regd = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.regd;
 	else
-		rfctl->cac_end_time = rtw_get_current_time() + rtw_ms_to_systime(CAC_TIME_MS);
+		regd = RTW_ChannelPlanMap[rfctl->ChannelPlan].regd;
+
+	if (regd == TXPWR_LMT_NONE)
+		rfctl->regd_name = regd_str(TXPWR_LMT_NONE);
+	else if (regd == TXPWR_LMT_WW)
+		rfctl->regd_name = regd_str(TXPWR_LMT_WW);
+	else {
+		ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_str(regd));
+		if (ent)
+			rfctl->regd_name = ent->regd_name;
+	}
+
+	RTW_PRINT("default mapping domain:0x%02x to%s regd_name:%s\n"
+		, rfctl->ChannelPlan
+		, rfctl->regd_name ? "" : " unknown"
+		, regd_str(regd)
+	);
+	if (rfctl->regd_name)
+		goto release_lock;
+
+	switch (regd) {
+	/*
+	* To support older chips without new predefined regd:
+	* - use FCC if IC or CHILE not found
+	* - use ETSI if KCC or ACMA not found
+	*/
+	case TXPWR_LMT_IC:
+	case TXPWR_LMT_KCC:
+	case TXPWR_LMT_ACMA:
+	case TXPWR_LMT_CHILE:
+		if (regd == TXPWR_LMT_IC || regd == TXPWR_LMT_CHILE)
+			regd = TXPWR_LMT_FCC;
+		else if (regd == TXPWR_LMT_KCC || regd == TXPWR_LMT_ACMA)
+			regd = TXPWR_LMT_ETSI;
+		ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_str(regd));
+		if (ent)
+			rfctl->regd_name = ent->regd_name;
+		RTW_PRINT("alternate regd_name:%s %s\n"
+			, regd_str(regd)
+			, rfctl->regd_name ? "is used" : "not found"
+		);
+		if (rfctl->regd_name)
+			break;
+	default:
+		rfctl->regd_name = regd_str(TXPWR_LMT_WW);
+		RTW_PRINT("assign %s for default case\n", regd_str(TXPWR_LMT_WW));
+		break;
+	};
+
+release_lock:
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+}
+#endif /* CONFIG_TXPWR_LIMIT */
+
+void rtw_rfctl_init(_adapter *adapter)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	rfctl->max_chan_nums = init_channel_set(adapter, rfctl->ChannelPlan, rfctl->channel_set);
+	init_channel_list(adapter, rfctl->channel_set, &rfctl->channel_list);
+
+	_rtw_mutex_init(&rfctl->offch_mutex);
+
+#ifdef CONFIG_TXPWR_LIMIT
+	_rtw_mutex_init(&rfctl->txpwr_lmt_mutex);
+	_rtw_init_listhead(&rfctl->reg_exc_list);
+	_rtw_init_listhead(&rfctl->txpwr_lmt_list);
+#endif
+
+	rfctl->ch_sel_same_band_prefer = 1;
+
+#ifdef CONFIG_DFS_MASTER
+	rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
+
+	/* TODO: dfs_master_timer */
+#endif
+}
+
+void rtw_rfctl_deinit(_adapter *adapter)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	_rtw_mutex_free(&rfctl->offch_mutex);
+
+#ifdef CONFIG_TXPWR_LIMIT
+	rtw_regd_exc_list_free(rfctl);
+	rtw_txpwr_lmt_list_free(rfctl);
+	_rtw_mutex_free(&rfctl->txpwr_lmt_mutex);
+#endif
+
+#ifdef CONFIG_DFS_MASTER
+	/* TODO: dfs_master_timer */
+#endif
 }
 
+#ifdef CONFIG_DFS_MASTER
 /*
-* check if channel coverage includes new range and the new range is in DFS range
-* called after radar_detect_ch,bw,offset is updated
+* called in rtw_dfs_master_enable()
+* assume the request channel coverage is DFS range
+* base on the current status and the request channel coverage to check if need to reset complete CAC time
 */
-bool rtw_is_cac_reset_needed(_adapter *adapter)
+bool rtw_is_cac_reset_needed(_adapter *adapter, u8 ch, u8 bw, u8 offset)
 {
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	bool needed = _FALSE;
-	u32 pre_hi, pre_lo, hi, lo;
+	u32 cur_hi, cur_lo, hi, lo;
 
-	if (0)
-		DBG_871X("pre_radar_detect_ch:%d, pre_radar_detect_by_sta_link:%d\n"
-			, rfctl->pre_radar_detect_ch, rfctl->pre_radar_detect_by_sta_link);
-
-	if (rfctl->pre_radar_detect_by_sta_link == _TRUE)
+	if (rfctl->radar_detected == 1) {
+		needed = _TRUE;
 		goto exit;
+	}
 
-	if (rfctl->pre_radar_detect_ch == 0) {
+	if (rfctl->radar_detect_ch == 0) {
 		needed = _TRUE;
 		goto exit;
 	}
 
-	if (rtw_chbw_to_freq_range(rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset, &hi, &lo) == _FALSE)
+	if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE) {
+		RTW_ERR("request detection range ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
 		rtw_warn_on(1);
-	if (rtw_chbw_to_freq_range(rfctl->pre_radar_detect_ch, rfctl->pre_radar_detect_bw, rfctl->pre_radar_detect_offset, &pre_hi, &pre_lo) == _FALSE)
+	}
+
+	if (rtw_chbw_to_freq_range(rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset, &cur_hi, &cur_lo) == _FALSE) {
+		RTW_ERR("cur detection range ch:%u, bw:%u, offset:%u\n", rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
 		rtw_warn_on(1);
+	}
 
-	if (!rtw_is_range_a_in_b(hi, lo, pre_hi, pre_lo)) {
-		if (rtw_is_range_a_in_b(pre_hi, pre_lo, hi, lo)) {
-			/* currrent is supper set of previous */
-			if (rtw_is_dfs_range(hi, lo))
-				needed = _TRUE;
-		} else if (rtw_is_range_overlap(hi, lo, pre_hi, pre_lo)) {
-			/* currrent is not supper set of previous, but has overlap */
-			u32 new_hi, new_lo;
-
-			if (lo < pre_lo) {
-				new_hi = pre_lo;
-				new_lo = lo;
-				if (hi <= pre_lo || hi >= pre_hi) {
-					DBG_871X_LEVEL(_drv_err_, "hi:%u, lo:%u, pre_hi:%u, pre_lo:%u\n"
-						, hi, lo, pre_hi, pre_lo);
-					rtw_warn_on(1);
-					goto exit;
-				}
-			} else if (hi > pre_hi) {
-				new_hi = hi;
-				new_lo = pre_hi;
-				if (lo >= pre_hi && lo <= pre_lo) {
-					DBG_871X_LEVEL(_drv_err_, "hi:%u, lo:%u, pre_hi:%u, pre_lo:%u\n"
-						, hi, lo, pre_hi, pre_lo);
-					rtw_warn_on(1);
-					goto exit;
-				}
-			} else {
-				DBG_871X_LEVEL(_drv_err_, "hi:%u, lo:%u, pre_hi:%u, pre_lo:%u\n"
-					, hi, lo, pre_hi, pre_lo);
-				rtw_warn_on(1);
-				goto exit;
-			}
+	if (hi <= lo || cur_hi <= cur_lo) {
+		RTW_ERR("hi:%u, lo:%u, cur_hi:%u, cur_lo:%u\n", hi, lo, cur_hi, cur_lo);
+		rtw_warn_on(1);
+	}
 
-			if (rtw_is_dfs_range(new_hi, new_lo))
-				needed = _TRUE;
-			
-		} else {
-			/* no overlap */
-			if (rtw_is_dfs_range(hi, lo))
-				needed = _TRUE;
-		}
+	if (rtw_is_range_a_in_b(hi, lo, cur_hi, cur_lo)) {
+		/* request is in current detect range */
+		goto exit;
+	}
+
+	/* check if request channel coverage has new range and the new range is in DFS range */
+	if (!rtw_is_range_overlap(hi, lo, cur_hi, cur_lo)) {
+		/* request has no overlap with current */
+		needed = _TRUE;
+	} else if (rtw_is_range_a_in_b(cur_hi, cur_lo, hi, lo)) {
+		/* request is supper set of current */
+		if ((hi != cur_hi && rtw_is_dfs_range(hi, cur_hi)) || (lo != cur_lo && rtw_is_dfs_range(cur_lo, lo)))
+			needed = _TRUE;
+	} else {
+		/* request is not supper set of current, but has overlap */
+		if ((lo < cur_lo && rtw_is_dfs_range(cur_lo, lo)) || (hi > cur_hi && rtw_is_dfs_range(hi, cur_hi)))
+			needed = _TRUE;
 	}
 
 exit:
@@ -411,6 +893,9 @@ bool _rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8
 	u32 r_hi = 0, r_lo = 0;
 	int i;
 
+	if (rfctl->radar_detect_by_others)
+		goto exit;
+
 	if (rfctl->radar_detect_ch == 0)
 		goto exit;
 
@@ -441,9 +926,9 @@ bool rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl)
 				, rfctl_to_dvobj(rfctl)->oper_ch_offset);
 }
 
-bool rtw_rfctl_is_tx_blocked_by_cac(struct rf_ctl_t *rfctl)
+bool rtw_rfctl_is_tx_blocked_by_ch_waiting(struct rf_ctl_t *rfctl)
 {
-	return (rtw_rfctl_overlap_radar_detect_ch(rfctl) && IS_UNDER_CAC(rfctl));
+	return rtw_rfctl_overlap_radar_detect_ch(rfctl) && IS_CH_WAITING(rfctl);
 }
 
 bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
@@ -455,7 +940,7 @@ bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
 	if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
 		goto exit;
 
-	for (i = 0; ch_set[i].ChannelNum != 0; i++) {
+	for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
 		if (!rtw_ch2freq(ch_set[i].ChannelNum)) {
 			rtw_warn_on(1);
 			continue;
@@ -476,43 +961,76 @@ exit:
 	return ret;
 }
 
-/**
- * rtw_chset_update_non_ocp - update non_ocp_end_time according to the given @ch, @bw, @offset into @ch_set
- * @ch_set: the given channel set
- * @ch: channel number on which radar is detected
- * @bw: bandwidth on which radar is detected
- * @offset: bandwidth offset on which radar is detected
- * @ms: ms to add from now to update non_ocp_end_time, ms < 0 means use NON_OCP_TIME_MS
- */
-static void _rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms)
+u32 rtw_chset_get_ch_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
 {
+	int ms = 0;
+	systime current_time;
 	u32 hi = 0, lo = 0;
 	int i;
 
 	if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
 		goto exit;
 
-	for (i = 0; ch_set[i].ChannelNum != 0; i++) {
+	current_time = rtw_get_current_time();
+
+	for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
 		if (!rtw_ch2freq(ch_set[i].ChannelNum)) {
 			rtw_warn_on(1);
 			continue;
 		}
 
+		if (!CH_IS_NON_OCP(&ch_set[i]))
+			continue;
+
 		if (lo <= rtw_ch2freq(ch_set[i].ChannelNum)
 			&& rtw_ch2freq(ch_set[i].ChannelNum) <= hi
 		) {
-			if (ms >= 0)
-				ch_set[i].non_ocp_end_time = rtw_get_current_time() + rtw_ms_to_systime(ms);
-			else
-				ch_set[i].non_ocp_end_time = rtw_get_current_time() + rtw_ms_to_systime(NON_OCP_TIME_MS);
+			if (rtw_systime_to_ms(ch_set[i].non_ocp_end_time - current_time) > ms)
+				ms = rtw_systime_to_ms(ch_set[i].non_ocp_end_time - current_time);
 		}
-	}	
+	}
 
 exit:
-	return;
+	return ms;
 }
 
-inline void rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
+/**
+ * rtw_chset_update_non_ocp - update non_ocp_end_time according to the given @ch, @bw, @offset into @ch_set
+ * @ch_set: the given channel set
+ * @ch: channel number on which radar is detected
+ * @bw: bandwidth on which radar is detected
+ * @offset: bandwidth offset on which radar is detected
+ * @ms: ms to add from now to update non_ocp_end_time, ms < 0 means use NON_OCP_TIME_MS
+ */
+static void _rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms)
+{
+	u32 hi = 0, lo = 0;
+	int i;
+
+	if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
+		goto exit;
+
+	for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
+		if (!rtw_ch2freq(ch_set[i].ChannelNum)) {
+			rtw_warn_on(1);
+			continue;
+		}
+
+		if (lo <= rtw_ch2freq(ch_set[i].ChannelNum)
+			&& rtw_ch2freq(ch_set[i].ChannelNum) <= hi
+		) {
+			if (ms >= 0)
+				ch_set[i].non_ocp_end_time = rtw_get_current_time() + rtw_ms_to_systime(ms);
+			else
+				ch_set[i].non_ocp_end_time = rtw_get_current_time() + rtw_ms_to_systime(NON_OCP_TIME_MS);
+		}
+	}
+
+exit:
+	return;
+}
+
+inline void rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
 {
 	_rtw_chset_update_non_ocp(ch_set, ch, bw, offset, -1);
 }
@@ -521,57 +1039,228 @@ inline void rtw_chset_update_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u
 {
 	_rtw_chset_update_non_ocp(ch_set, ch, bw, offset, ms);
 }
+
+u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u32 non_ocp_ms;
+	u32 cac_ms;
+	u8 in_rd_range = 0; /* if in current radar detection range*/
+
+	if (rtw_chset_is_ch_non_ocp(rfctl->channel_set, ch, bw, offset))
+		non_ocp_ms = rtw_chset_get_ch_non_ocp_ms(rfctl->channel_set, ch, bw, offset);
+	else
+		non_ocp_ms = 0;
+
+	if (rfctl->dfs_master_enabled) {
+		u32 cur_hi, cur_lo, hi, lo;
+
+		if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE) {
+			RTW_ERR("input range ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
+			rtw_warn_on(1);
+		}
+
+		if (rtw_chbw_to_freq_range(rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset, &cur_hi, &cur_lo) == _FALSE) {
+			RTW_ERR("cur detection range ch:%u, bw:%u, offset:%u\n", rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
+			rtw_warn_on(1);
+		}
+
+		if (rtw_is_range_a_in_b(hi, lo, cur_hi, cur_lo))
+			in_rd_range = 1;
+	}
+
+	if (!rtw_is_dfs_chbw(ch, bw, offset))
+		cac_ms = 0;
+	else if (in_rd_range && !non_ocp_ms) {
+		if (IS_CH_WAITING(rfctl))
+			cac_ms = rtw_systime_to_ms(rfctl->cac_end_time - rtw_get_current_time());
+		else
+			cac_ms = 0;
+	} else if (rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(adapter)))
+		cac_ms = CAC_TIME_CE_MS;
+	else
+		cac_ms = CAC_TIME_MS;
+
+	if (r_non_ocp_ms)
+		*r_non_ocp_ms = non_ocp_ms;
+	if (r_cac_ms)
+		*r_cac_ms = cac_ms;
+
+	return non_ocp_ms + cac_ms;
+}
+
+void rtw_reset_cac(_adapter *adapter, u8 ch, u8 bw, u8 offset)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u32 non_ocp_ms;
+	u32 cac_ms;
+
+	rtw_get_ch_waiting_ms(adapter
+		, ch
+		, bw
+		, offset
+		, &non_ocp_ms
+		, &cac_ms
+	);
+
+	rfctl->cac_start_time = rtw_get_current_time() + rtw_ms_to_systime(non_ocp_ms);
+	rfctl->cac_end_time = rfctl->cac_start_time + rtw_ms_to_systime(cac_ms);
+
+	/* skip special value */
+	if (rfctl->cac_start_time == RTW_CAC_STOPPED) {
+		rfctl->cac_start_time++;
+		rfctl->cac_end_time++;
+	}
+	if (rfctl->cac_end_time == RTW_CAC_STOPPED)
+		rfctl->cac_end_time++;
+}
+
+u32 rtw_force_stop_cac(_adapter *adapter, u32 timeout_ms)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	systime start;
+	u32 pass_ms;
+
+	start = rtw_get_current_time();
+
+	rfctl->cac_force_stop = 1;
+
+	while (rtw_get_passing_time_ms(start) <= timeout_ms
+		&& IS_UNDER_CAC(rfctl)
+	) {
+		if (RTW_CANNOT_RUN(adapter))
+			break;
+		rtw_msleep_os(20);
+	}
+
+	if (IS_UNDER_CAC(rfctl)) {
+		if (!RTW_CANNOT_RUN(adapter))
+			RTW_INFO(FUNC_ADPT_FMT" waiting for cac stop timeout!\n", FUNC_ADPT_ARG(adapter));
+	}
+
+	rfctl->cac_force_stop = 0;
+
+	pass_ms = rtw_get_passing_time_ms(start);
+
+	return pass_ms;
+}
 #endif /* CONFIG_DFS_MASTER */
 
-bool rtw_choose_available_chbw(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset, u8 d_flags)
+/* choose channel with shortest waiting (non ocp + cac) time */
+bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 sel_ch, u8 max_bw
+	, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset
+	, u8 d_flags, u8 cur_ch, u8 same_band_prefer)
 {
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+#ifndef DBG_CHOOSE_SHORTEST_WAITING_CH
+#define DBG_CHOOSE_SHORTEST_WAITING_CH 0
+#endif
+
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct registry_priv *regsty = adapter_to_regsty(adapter);
+	u8 ch, bw, offset;
+	u8 ch_c = 0, bw_c = 0, offset_c = 0;
 	int i;
+	u32 min_waiting_ms = 0;
 
 	if (!dec_ch || !dec_bw || !dec_offset) {
 		rtw_warn_on(1);
-		return _FAIL;
+		return _FALSE;
 	}
 
-	for (i = 0; i < mlmeext->max_chan_nums; i++) {
+	/* full search and narrow bw judegement first to avoid potetial judegement timing issue */
+	for (bw = CHANNEL_WIDTH_20; bw <= max_bw; bw++) {
+		if (!hal_is_bw_support(adapter, bw))
+			continue;
 
-		*dec_ch = mlmeext->channel_set[i].ChannelNum;
-		*dec_bw = req_bw;
-		if (*dec_bw == CHANNEL_WIDTH_20)
-			*dec_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		else
-			*dec_offset = rtw_get_offset_by_ch(*dec_ch);
+		for (i = 0; i < rfctl->max_chan_nums; i++) {
+			u32 non_ocp_ms = 0;
+			u32 cac_ms = 0;
+			u32 waiting_ms = 0;
 
-		if ((d_flags & RTW_CHF_2G) && *dec_ch <= 14)
-			continue;
+			ch = rfctl->channel_set[i].ChannelNum;
+			if (sel_ch > 0 && ch != sel_ch)
+				continue;
 
-		if ((d_flags & RTW_CHF_5G)  && *dec_ch > 14)
-			continue;
+			if ((d_flags & RTW_CHF_2G) && ch <= 14)
+				continue;
 
-		rtw_adjust_chbw(adapter, *dec_ch, dec_bw, dec_offset);
+			if ((d_flags & RTW_CHF_5G) && ch > 14)
+				continue;
 
-		if ((d_flags & RTW_CHF_DFS) && rtw_is_dfs_ch(*dec_ch, *dec_bw, *dec_offset))
-			continue;
+			if (ch > 14) {
+				if (bw > REGSTY_BW_5G(regsty))
+					continue;
+			} else {
+				if (bw > REGSTY_BW_2G(regsty))
+					continue;
+			}
 
-		if ((d_flags & RTW_CHF_LONG_CAC) && rtw_is_long_cac_ch(*dec_ch, *dec_bw, *dec_offset))
-			continue;
+			if (!rtw_get_offset_by_chbw(ch, bw, &offset))
+				continue;
 
-		if ((d_flags & RTW_CHF_NON_DFS) && !rtw_is_dfs_ch(*dec_ch, *dec_bw, *dec_offset))
-			continue;
+			if (!rtw_chset_is_chbw_valid(rfctl->channel_set, ch, bw, offset))
+				continue;
 
-		if ((d_flags & RTW_CHF_NON_LONG_CAC) && !rtw_is_long_cac_ch(*dec_ch, *dec_bw, *dec_offset))
-			continue;
+			if ((d_flags & RTW_CHF_NON_OCP) && rtw_chset_is_ch_non_ocp(rfctl->channel_set, ch, bw, offset))
+				continue;
 
-		if (!rtw_chset_is_ch_non_ocp(mlmeext->channel_set, *dec_ch, *dec_bw, *dec_offset))
-			break;
+			if ((d_flags & RTW_CHF_DFS) && rtw_is_dfs_chbw(ch, bw, offset))
+				continue;
+
+			if ((d_flags & RTW_CHF_LONG_CAC) && rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(adapter)))
+				continue;
+
+			if ((d_flags & RTW_CHF_NON_DFS) && !rtw_is_dfs_chbw(ch, bw, offset))
+				continue;
+
+			if ((d_flags & RTW_CHF_NON_LONG_CAC) && !rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(adapter)))
+				continue;
+
+			#ifdef CONFIG_DFS_MASTER
+			waiting_ms = rtw_get_ch_waiting_ms(adapter, ch, bw, offset, &non_ocp_ms, &cac_ms);
+			#endif
+
+			if (DBG_CHOOSE_SHORTEST_WAITING_CH)
+				RTW_INFO(FUNC_ADPT_FMT":%u,%u,%u %u(non_ocp:%u, cac:%u)\n"
+					, FUNC_ADPT_ARG(adapter), ch, bw, offset, waiting_ms, non_ocp_ms, cac_ms);
+
+			if (ch_c == 0
+				/* first: smaller wating time */
+				|| min_waiting_ms > waiting_ms
+				/* then: wider bw */
+				|| (min_waiting_ms == waiting_ms && bw > bw_c)
+				/* then: same band if requested */
+				|| (same_band_prefer && min_waiting_ms == waiting_ms && bw == bw_c
+					&& !rtw_is_same_band(cur_ch, ch_c) && rtw_is_same_band(cur_ch, ch))
+			) {
+				ch_c = ch;
+				bw_c = bw;
+				offset_c = offset;
+				min_waiting_ms = waiting_ms;
+			}
+		}
+	}
+
+	if (ch_c != 0) {
+		RTW_INFO(FUNC_ADPT_FMT": d_flags:0x%02x cur_ch:%u sb_prefer:%u %u,%u,%u waiting_ms:%u\n"
+			, FUNC_ADPT_ARG(adapter), d_flags, cur_ch, same_band_prefer
+			, ch_c, bw_c, offset_c, min_waiting_ms);
+
+		*dec_ch = ch_c;
+		*dec_bw = bw_c;
+		*dec_offset = offset_c;
+		return _TRUE;
 	}
 
-	return (i < mlmeext->max_chan_nums)?_TRUE:_FALSE;
+	if (d_flags == 0)
+		rtw_warn_on(1);
+
+	return _FALSE;
 }
 
 void dump_country_chplan(void *sel, const struct country_chplan *ent)
 {
-	DBG_871X_SEL(sel, "\"%c%c\", 0x%02X%s\n"
+	RTW_PRINT_SEL(sel, "\"%c%c\", 0x%02X%s\n"
 		, ent->alpha2[0], ent->alpha2[1], ent->chplan
 		, COUNTRY_CHPLAN_EN_11AC(ent) ? " ac" : ""
 	);
@@ -583,10 +1272,10 @@ void dump_country_chplan_map(void *sel)
 	u8 code[2];
 
 #if RTW_DEF_MODULE_REGULATORY_CERT
-	DBG_871X_SEL(sel, "RTW_DEF_MODULE_REGULATORY_CERT:0x%x\n", RTW_DEF_MODULE_REGULATORY_CERT);
+	RTW_PRINT_SEL(sel, "RTW_DEF_MODULE_REGULATORY_CERT:0x%x\n", RTW_DEF_MODULE_REGULATORY_CERT);
 #endif
 #ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
-	DBG_871X_SEL(sel, "CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP\n");
+	RTW_PRINT_SEL(sel, "CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP\n");
 #endif
 
 	for (code[0] = 'A'; code[0] <= 'Z'; code[0]++) {
@@ -602,16 +1291,21 @@ void dump_country_chplan_map(void *sel)
 
 void dump_chplan_id_list(void *sel)
 {
+	u8 first = 1;
 	int i;
 
 	for (i = 0; i < RTW_CHPLAN_MAX; i++) {
 		if (!rtw_is_channel_plan_valid(i))
 			continue;
 
-		DBG_871X_SEL(sel, "0x%02X ", i);
+		if (first) {
+			RTW_PRINT_SEL(sel, "0x%02X ", i);
+			first = 0;
+		} else
+			_RTW_PRINT_SEL(sel, "0x%02X ", i);
 	}
 
-	DBG_871X_SEL_NL(sel, "0x7F\n");
+	_RTW_PRINT_SEL(sel, "0x7F\n");
 }
 
 void dump_chplan_test(void *sel)
@@ -620,89 +1314,194 @@ void dump_chplan_test(void *sel)
 
 	/* check invalid channel */
 	for (i = 0; i < RTW_RD_2G_MAX; i++) {
-		for (j = 0; j < RTW_ChannelPlan2G[i].Len; j++) {
-			if (rtw_ch2freq(RTW_ChannelPlan2G[i].Channel[j]) == 0)
-				DBG_871X_SEL_NL(sel, "invalid ch:%u at (%d,%d)\n", RTW_ChannelPlan2G[i].Channel[j], i, j);
+		for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan2G[i]); j++) {
+			if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan2G[i], j)) == 0)
+				RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan2G[i], j), i, j);
 		}
 	}
 
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
 	for (i = 0; i < RTW_RD_5G_MAX; i++) {
-		for (j = 0; j < RTW_ChannelPlan5G[i].Len; j++) {
-			if (rtw_ch2freq(RTW_ChannelPlan5G[i].Channel[j]) == 0)
-				DBG_871X_SEL_NL(sel, "invalid ch:%u at (%d,%d)\n", RTW_ChannelPlan5G[i].Channel[j], i, j);
+		for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan5G[i]); j++) {
+			if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan5G[i], j)) == 0)
+				RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan5G[i], j), i, j);
 		}
 	}
+#endif
 }
 
 void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set)
 {
 	u8	i;
 
-	for (i = 0; ch_set[i].ChannelNum != 0; i++) {
-		DBG_871X_SEL_NL(sel, "ch:%3u, freq:%u, scan_type:%d"
+	for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
+		RTW_PRINT_SEL(sel, "ch:%3u, freq:%u, scan_type:%d"
 			, ch_set[i].ChannelNum, rtw_ch2freq(ch_set[i].ChannelNum), ch_set[i].ScanType);
-	
-		#ifdef CONFIG_FIND_BEST_CHANNEL
-		DBG_871X_SEL(sel, ", rx_count:%u", ch_set[i].rx_count);
-		#endif
-		
-		#ifdef CONFIG_DFS_MASTER
-		if (rtw_is_dfs_ch(ch_set[i].ChannelNum, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE)) {
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+		_RTW_PRINT_SEL(sel, ", rx_count:%u", ch_set[i].rx_count);
+#endif
+
+#ifdef CONFIG_DFS_MASTER
+		if (rtw_is_dfs_ch(ch_set[i].ChannelNum)) {
 			if (CH_IS_NON_OCP(&ch_set[i]))
-				DBG_871X_SEL(sel, ", non_ocp:%d"
+				_RTW_PRINT_SEL(sel, ", non_ocp:%d"
 					, rtw_systime_to_ms(ch_set[i].non_ocp_end_time - rtw_get_current_time()));
 			else
-				DBG_871X_SEL(sel, ", non_ocp:N/A");
+				_RTW_PRINT_SEL(sel, ", non_ocp:N/A");
 		}
-		#endif
+#endif
 
-		DBG_871X_SEL(sel, "\n");
+		_RTW_PRINT_SEL(sel, "\n");
 	}
 
-	DBG_871X_SEL_NL(sel, "total ch number:%d\n", i);
+	RTW_PRINT_SEL(sel, "total ch number:%d\n", i);
 }
 
 void dump_cur_chset(void *sel, _adapter *adapter)
 {
-	struct mlme_priv *mlme = &adapter->mlmepriv;
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct registry_priv *regsty = adapter_to_regsty(adapter);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	int i;
 
-	if (mlme->country_ent)
-		dump_country_chplan(sel, mlme->country_ent);
+	if (rfctl->country_ent)
+		dump_country_chplan(sel, rfctl->country_ent);
 	else
-		DBG_871X_SEL_NL(sel, "chplan:0x%02X\n", mlme->ChannelPlan);
+		RTW_PRINT_SEL(sel, "chplan:0x%02X\n", rfctl->ChannelPlan);
+
+#ifdef CONFIG_TXPWR_LIMIT
+	RTW_PRINT_SEL(sel, "PLS regd:%s\n", rfctl->regd_name);
+#endif
+
+#ifdef CONFIG_DFS_MASTER
+	RTW_PRINT_SEL(sel, "dfs_domain:%u\n", rtw_odm_get_dfs_domain(adapter));
+#endif
+
+	for (i = 0; i < MAX_CHANNEL_NUM; i++)
+		if (regsty->excl_chs[i] != 0)
+			break;
+
+	if (i < MAX_CHANNEL_NUM) {
+		RTW_PRINT_SEL(sel, "excl_chs:");
+		for (i = 0; i < MAX_CHANNEL_NUM; i++) {
+			if (regsty->excl_chs[i] == 0)
+				break;
+			_RTW_PRINT_SEL(sel, "%u ", regsty->excl_chs[i]);
+		}
+		_RTW_PRINT_SEL(sel, "\n");
+	}
 
-	DBG_871X_SEL_NL(sel, "2G_PLS:%u, 5G_PLS:%u\n"
-		, hal_data->Regulation2_4G, hal_data->Regulation5G);
-	dump_chset(sel, mlmeext->channel_set);
+	dump_chset(sel, rfctl->channel_set);
 }
 
 /*
  * Search the @param ch in given @param ch_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_ch(RT_CHANNEL_INFO *ch_set, const u32 ch)
+int rtw_chset_search_ch(RT_CHANNEL_INFO *ch_set, const u32 ch)
+{
+	int i;
+
+	if (ch == 0)
+		return -1;
+
+	for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
+		if (ch == ch_set[i].ChannelNum)
+			return i;
+	}
+
+	return -1;
+}
+
+/*
+ * Check if the @param ch, bw, offset is valid for the given @param ch_set
+ * @ch_set: the given channel set
+ * @ch: the given channel number
+ * @bw: the given bandwidth
+ * @offset: the given channel offset
+ *
+ * return valid (1) or not (0)
+ */
+u8 rtw_chset_is_chbw_valid(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
 {
+	u8 cch;
+	u8 *op_chs;
+	u8 op_ch_num;
+	u8 valid = 0;
 	int i;
-	for(i=0;ch_set[i].ChannelNum!=0;i++){
-		if(ch == ch_set[i].ChannelNum)
+
+	cch = rtw_get_center_ch(ch, bw, offset);
+
+	if (!rtw_get_op_chs_by_cch_bw(cch, bw, &op_chs, &op_ch_num))
+		goto exit;
+
+	for (i = 0; i < op_ch_num; i++) {
+		if (0)
+			RTW_INFO("%u,%u,%u - cch:%u, bw:%u, op_ch:%u\n", ch, bw, offset, cch, bw, *(op_chs + i));
+		if (rtw_chset_search_ch(ch_set, *(op_chs + i)) == -1)
 			break;
 	}
-	
-	if(i >= ch_set[i].ChannelNum)
-		return -1;
-	return i;
+
+	if (op_ch_num != 0 && i == op_ch_num)
+		valid = 1;
+
+exit:
+	return valid;
+}
+
+/**
+ * rtw_chset_sync_chbw - obey g_ch, adjust g_bw, g_offset, bw, offset to fit in channel plan
+ * @ch_set: channel plan to check
+ * @req_ch: pointer of the request ch, may be modified further
+ * @req_bw: pointer of the request bw, may be modified further
+ * @req_offset: pointer of the request offset, may be modified further
+ * @g_ch: pointer of the ongoing group ch
+ * @g_bw: pointer of the ongoing group bw, may be modified further
+ * @g_offset: pointer of the ongoing group offset, may be modified further
+ */
+void rtw_chset_sync_chbw(RT_CHANNEL_INFO *ch_set, u8 *req_ch, u8 *req_bw, u8 *req_offset
+	, u8 *g_ch, u8 *g_bw, u8 *g_offset)
+{
+	u8 r_ch, r_bw, r_offset;
+	u8 u_ch, u_bw, u_offset;
+	u8 cur_bw = *req_bw;
+
+	while (1) {
+		r_ch = *req_ch;
+		r_bw = cur_bw;
+		r_offset = *req_offset;
+		u_ch = *g_ch;
+		u_bw = *g_bw;
+		u_offset = *g_offset;
+
+		rtw_sync_chbw(&r_ch, &r_bw, &r_offset, &u_ch, &u_bw, &u_offset);
+
+		if (rtw_chset_is_chbw_valid(ch_set, r_ch, r_bw, r_offset))
+			break;
+		if (cur_bw == CHANNEL_WIDTH_20) {
+			rtw_warn_on(1);
+			break;
+		}
+		cur_bw--;
+	};
+
+	*req_ch = r_ch;
+	*req_bw = r_bw;
+	*req_offset = r_offset;
+	*g_ch = u_ch;
+	*g_bw = u_bw;
+	*g_offset = u_offset;
 }
 
 /*
  * Check the @param ch is fit with setband setting of @param adapter
  * @adapter: the given adapter
  * @ch: the given channel number
- * 
+ *
  * return _TRUE when check valid, _FALSE not valid
  */
 bool rtw_mlme_band_check(_adapter *adapter, const u32 ch)
@@ -710,12 +1509,43 @@ bool rtw_mlme_band_check(_adapter *adapter, const u32 ch)
 	if (adapter->setband == WIFI_FREQUENCY_BAND_AUTO /* 2.4G and 5G */
 		|| (adapter->setband == WIFI_FREQUENCY_BAND_2GHZ && ch < 35) /* 2.4G only */
 		|| (adapter->setband == WIFI_FREQUENCY_BAND_5GHZ && ch > 35) /* 5G only */
-	) {
+	)
 		return _TRUE;
-	}
+	return _FALSE;
+}
+inline void RTW_SET_SCAN_BAND_SKIP(_adapter *padapter, int skip_band)
+{
+	int bs = ATOMIC_READ(&padapter->bandskip);
+
+	bs |= skip_band;
+	ATOMIC_SET(&padapter->bandskip, bs);
+}
+
+inline void RTW_CLR_SCAN_BAND_SKIP(_adapter *padapter, int skip_band)
+{
+	int bs = ATOMIC_READ(&padapter->bandskip);
+
+	bs &= ~(skip_band);
+	ATOMIC_SET(&padapter->bandskip, bs);
+}
+inline int RTW_GET_SCAN_BAND_SKIP(_adapter *padapter)
+{
+	return ATOMIC_READ(&padapter->bandskip);
+}
+
+#define RTW_IS_SCAN_BAND_SKIP(padapter, skip_band) (ATOMIC_READ(&padapter->bandskip) & (skip_band))
+
+bool rtw_mlme_ignore_chan(_adapter *adapter, const u32 ch)
+{
+	if (RTW_IS_SCAN_BAND_SKIP(adapter, BAND_24G) && ch < 35) /* SKIP 2.4G Band channel */
+		return _TRUE;
+	if (RTW_IS_SCAN_BAND_SKIP(adapter, BAND_5G)  && ch > 35) /* SKIP 5G Band channel */
+		return _TRUE;
+
 	return _FALSE;
 }
 
+
 /****************************************************************************
 
 Following are the initialization functions for WiFi MLME
@@ -725,20 +1555,21 @@ Following are the initialization functions for WiFi MLME
 int init_hw_mlme_ext(_adapter *padapter)
 {
 	struct	mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	u8 rx_bar_enble = _TRUE;
 
-	//set_opmode_cmd(padapter, infra_client_with_mlme);//removed
-
+	/* set_opmode_cmd(padapter, infra_client_with_mlme); */ /* removed */
+	rtw_hal_set_hwreg(padapter, HW_VAR_ENABLE_RX_BAR, &rx_bar_enble);
 	set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
 
 	return _SUCCESS;
 }
 
-void init_mlme_default_rate_set(_adapter* padapter)
+void init_mlme_default_rate_set(_adapter *padapter)
 {
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-	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,};
+	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,};
 	unsigned char	supported_mcs_set[16] = {0xff, 0xff, 0xff, 0x00, 0x00, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
 
 	_rtw_memcpy(pmlmeext->datarate, mixed_datarate, NumRates);
@@ -747,29 +1578,27 @@ void init_mlme_default_rate_set(_adapter* padapter)
 	_rtw_memcpy(pmlmeext->default_supported_mcs_set, supported_mcs_set, sizeof(pmlmeext->default_supported_mcs_set));
 }
 
-static void init_mlme_ext_priv_value(_adapter* padapter)
+static void init_mlme_ext_priv_value(_adapter *padapter)
 {
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 	ATOMIC_SET(&pmlmeext->event_seq, 0);
-	pmlmeext->mgnt_seq = 0;//reset to zero when disconnect at client mode
+	pmlmeext->mgnt_seq = 0;/* reset to zero when disconnect at client mode */
 #ifdef CONFIG_IEEE80211W
 	pmlmeext->sa_query_seq = 0;
-	pmlmeext->mgnt_80211w_IPN=0;
-	pmlmeext->mgnt_80211w_IPN_rx=0;
-#endif //CONFIG_IEEE80211W
+#endif
 	pmlmeext->cur_channel = padapter->registrypriv.channel;
 	pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
 	pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	
+
 	pmlmeext->retry = 0;
 
 	pmlmeext->cur_wireless_mode = padapter->registrypriv.wireless_mode;
 
 	init_mlme_default_rate_set(padapter);
 
-	if(pmlmeext->cur_channel > 14)
+	if (pmlmeext->cur_channel > 14)
 		pmlmeext->tx_rate = IEEE80211_OFDM_RATE_6MB;
 	else
 		pmlmeext->tx_rate = IEEE80211_CCK_RATE_1MB;
@@ -780,16 +1609,21 @@ static void init_mlme_ext_priv_value(_adapter* padapter)
 	pmlmeext->sitesurvey_res.scan_ch_ms = SURVEY_TO;
 	pmlmeext->sitesurvey_res.rx_ampdu_accept = RX_AMPDU_ACCEPT_INVALID;
 	pmlmeext->sitesurvey_res.rx_ampdu_size = RX_AMPDU_SIZE_INVALID;
-	#ifdef CONFIG_SCAN_BACKOP
-	mlmeext_assign_scan_backop_flags_sta(pmlmeext, /*SS_BACKOP_EN|*/SS_BACKOP_PS_ANNC|SS_BACKOP_TX_RESUME);
-	mlmeext_assign_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN|SS_BACKOP_PS_ANNC|SS_BACKOP_TX_RESUME);
+#ifdef CONFIG_SCAN_BACKOP
+	mlmeext_assign_scan_backop_flags_sta(pmlmeext, /*SS_BACKOP_EN|*/SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
+	#ifdef CONFIG_AP_MODE
+	mlmeext_assign_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN | SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
+	#endif
+	#ifdef CONFIG_RTW_MESH
+	mlmeext_assign_scan_backop_flags_mesh(pmlmeext, /*SS_BACKOP_EN | */SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
+	#endif
 	pmlmeext->sitesurvey_res.scan_cnt = 0;
 	pmlmeext->sitesurvey_res.scan_cnt_max = RTW_SCAN_NUM_OF_CH;
 	pmlmeext->sitesurvey_res.backop_ms = RTW_BACK_OP_CH_MS;
-	#endif
-	#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
+#endif
+#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
 	pmlmeext->sitesurvey_res.is_sw_antdiv_bl_scan = 0;
-	#endif
+#endif
 	pmlmeext->scan_abort = _FALSE;
 
 	pmlmeinfo->state = WIFI_FW_NULL_STATE;
@@ -815,228 +1649,65 @@ static void init_mlme_ext_priv_value(_adapter* padapter)
 	pmlmeext->action_public_dialog_token = 0xff;
 }
 
-static int has_channel(RT_CHANNEL_INFO *channel_set,
-					   u8 chanset_size,
-					   u8 chan) {
-	int i;
+void init_mlme_ext_timer(_adapter *padapter)
+{
+	struct	mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-	for (i = 0; i < chanset_size; i++) {
-		if (channel_set[i].ChannelNum == chan) {
-			return 1;
-		}
-	}
+	rtw_init_timer(&pmlmeext->survey_timer, padapter, survey_timer_hdl, padapter);
+	rtw_init_timer(&pmlmeext->link_timer, padapter, link_timer_hdl, padapter);
+#ifdef CONFIG_RTW_80211R
+	rtw_init_timer(&pmlmeext->ft_link_timer, padapter, rtw_ft_link_timer_hdl, padapter);
+	rtw_init_timer(&pmlmeext->ft_roam_timer, padapter, rtw_ft_roam_timer_hdl, padapter);
+#endif
 
-	return 0;
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_init_timer(&pmlmeext->rson_scan_timer, padapter, rson_timer_hdl, padapter);
+#endif
 }
 
-static void init_channel_list(_adapter *padapter, RT_CHANNEL_INFO *channel_set,
-							  u8 chanset_size,
-							  struct p2p_channels *channel_list) {
-	struct registry_priv *regsty = adapter_to_regsty(padapter);
+int	init_mlme_ext_priv(_adapter *padapter)
+{
+	int	res = _SUCCESS;
+	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);
 
-	struct p2p_oper_class_map op_class[] = {
-		{ IEEE80211G,  81,   1,  13,  1, BW20 },
-		{ IEEE80211G,  82,  14,  14,  1, BW20 },
-#if 0 /* Do not enable HT40 on 2 GHz */
-		{ IEEE80211G,  83,   1,   9,  1, BW40PLUS },
-		{ IEEE80211G,  84,   5,  13,  1, BW40MINUS },
-#endif
-		{ 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) && (8 == o->inc))
-				continue;
-
-			if ((REGSTY_IS_BW_5G_SUPPORT(regsty, CHANNEL_WIDTH_40)) &&
-				((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(_adapter* padapter, u8 ChannelPlan, RT_CHANNEL_INFO *channel_set)
-{
-	u8	index,chanset_size = 0;
-	u8	b5GBand = _FALSE, b2_4GBand = _FALSE;
-	u8	Index2G = 0, Index5G=0;
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
-
-	if (!rtw_is_channel_plan_valid(ChannelPlan)) {
-		DBG_871X_LEVEL(_drv_err_, "ChannelPlan ID 0x%02X error !!!!!\n", ChannelPlan);
-		return chanset_size;
-	}
-
-	_rtw_memset(channel_set, 0, sizeof(RT_CHANNEL_INFO)*MAX_CHANNEL_NUM);
-
-	if (IsSupported24G(padapter->registrypriv.wireless_mode))
-		b2_4GBand = _TRUE;
-
-	if (IsSupported5G(padapter->registrypriv.wireless_mode))
-		b5GBand = _TRUE;
-
-	if (b2_4GBand) {
-		if (RTW_CHPLAN_REALTEK_DEFINE == ChannelPlan)
-			Index2G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index2G;
-		else
-			Index2G = RTW_ChannelPlanMap[ChannelPlan].Index2G;
-
-		for (index = 0; index < RTW_ChannelPlan2G[Index2G].Len; index++) {
-			channel_set[chanset_size].ChannelNum = RTW_ChannelPlan2G[Index2G].Channel[index];
-
-			if (RTW_CHPLAN_GLOBAL_DOAMIN == ChannelPlan
-				|| RTW_CHPLAN_GLOBAL_NULL == ChannelPlan
-			) {
-				/* Channel 1~11 is active, and 12~14 is passive */
-				if(channel_set[chanset_size].ChannelNum >= 1 && channel_set[chanset_size].ChannelNum <= 11)
-					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-				else if((channel_set[chanset_size].ChannelNum  >= 12 && channel_set[chanset_size].ChannelNum  <= 14))
-					channel_set[chanset_size].ScanType  = SCAN_PASSIVE;			
-			} else if (RTW_CHPLAN_WORLD_WIDE_13 == ChannelPlan
-				|| RTW_CHPLAN_WORLD_WIDE_5G == ChannelPlan
-				|| RTW_RD_2G_WORLD == Index2G
-			) {
-				/* channel 12~13, passive scan */
-				if(channel_set[chanset_size].ChannelNum <= 11)
-					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-				else
-					channel_set[chanset_size].ScanType = SCAN_PASSIVE;
-			} else {
-				channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-			}
-
-			chanset_size++;
-		}
-	}
-
-	if (b5GBand) {
-		if (RTW_CHPLAN_REALTEK_DEFINE == ChannelPlan)
-			Index5G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index5G;
-		else
-			Index5G = RTW_ChannelPlanMap[ChannelPlan].Index5G;
-
-		for (index = 0; index < RTW_ChannelPlan5G[Index5G].Len; index++) {
-#ifdef CONFIG_DFS
-			channel_set[chanset_size].ChannelNum = RTW_ChannelPlan5G[Index5G].Channel[index];
-			if ( channel_set[chanset_size].ChannelNum <= 48 
-				|| channel_set[chanset_size].ChannelNum >= 149 )
-			{
-				if (RTW_CHPLAN_WORLD_WIDE_5G == ChannelPlan) /* passive scan for all 5G channels */
-					channel_set[chanset_size].ScanType = SCAN_PASSIVE;
-				else
-					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-			}
-			else
-			{
-				channel_set[chanset_size].ScanType = SCAN_PASSIVE;
-			}
-			chanset_size++;
-#else /* CONFIG_DFS */
-			if (RTW_ChannelPlan5G[Index5G].Channel[index] <= 48
-				|| RTW_ChannelPlan5G[Index5G].Channel[index] >= 149
-			) {
-				channel_set[chanset_size].ChannelNum = RTW_ChannelPlan5G[Index5G].Channel[index];
-				if (RTW_CHPLAN_WORLD_WIDE_5G == ChannelPlan) /* passive scan for all 5G channels */
-					channel_set[chanset_size].ScanType = SCAN_PASSIVE;
-				else
-					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-				DBG_871X("%s(): channel_set[%d].ChannelNum = %d\n", __FUNCTION__, chanset_size, channel_set[chanset_size].ChannelNum);
-				chanset_size++;
-			}
-#endif /* CONFIG_DFS */
-		}
-	}
-
-	if (RTW_CHPLAN_REALTEK_DEFINE == ChannelPlan) {
-		hal_data->Regulation2_4G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.regd;
-		hal_data->Regulation5G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.regd;
-	} else {
-		hal_data->Regulation2_4G = RTW_ChannelPlanMap[ChannelPlan].regd;
-		hal_data->Regulation5G = RTW_ChannelPlanMap[ChannelPlan].regd;
-	}
-
-	DBG_871X(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, ch num:%d\n"
-		, FUNC_ADPT_ARG(padapter), ChannelPlan, chanset_size);
-
-	return chanset_size;
-}
-
-int	init_mlme_ext_priv(_adapter* padapter)
-{
-	int	res = _SUCCESS;
-	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);
-
-	// We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc().
-	//_rtw_memset((u8 *)pmlmeext, 0, sizeof(struct mlme_ext_priv));
+	/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
+	/* _rtw_memset((u8 *)pmlmeext, 0, sizeof(struct mlme_ext_priv)); */
 
 	pmlmeext->padapter = padapter;
 
-	//fill_fwpriv(padapter, &(pmlmeext->fwpriv));
+	/* fill_fwpriv(padapter, &(pmlmeext->fwpriv)); */
 
 	init_mlme_ext_priv_value(padapter);
 	pmlmeinfo->bAcceptAddbaReq = pregistrypriv->bAcceptAddbaReq;
-	
+
 	init_mlme_ext_timer(padapter);
 
 #ifdef CONFIG_AP_MODE
-	init_mlme_ap_info(padapter);	
+	init_mlme_ap_info(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->last_scan_time = 0;
 	pmlmeext->mlmeext_init = _TRUE;
 
 
-#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK	
+#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 	pmlmeext->active_keep_alive_check = _TRUE;
 #else
 	pmlmeext->active_keep_alive_check = _FALSE;
 #endif
 
-#ifdef DBG_FIXED_CHAN		
-	pmlmeext->fixed_chan = 0xFF;	
+#ifdef DBG_FIXED_CHAN
+	pmlmeext->fixed_chan = 0xFF;
 #endif
 
 	return res;
 
 }
 
-void free_mlme_ext_priv (struct mlme_ext_priv *pmlmeext)
+void free_mlme_ext_priv(struct mlme_ext_priv *pmlmeext)
 {
 	_adapter *padapter = pmlmeext->padapter;
 
@@ -1046,51 +1717,40 @@ void free_mlme_ext_priv (struct mlme_ext_priv *pmlmeext)
 	if (rtw_is_drv_stopped(padapter)) {
 		_cancel_timer_ex(&pmlmeext->survey_timer);
 		_cancel_timer_ex(&pmlmeext->link_timer);
-		//_cancel_timer_ex(&pmlmeext->ADDBA_timer);
 	}
 }
 
-static u8 cmp_pkt_chnl_diff(_adapter *padapter,u8* pframe,uint packet_len)
-{	// if the channel is same, return 0. else return channel differential	
+static u8 cmp_pkt_chnl_diff(_adapter *padapter, u8 *pframe, uint packet_len)
+{
+	/* if the channel is same, return 0. else return channel differential	 */
 	uint len;
-	u8 channel;	
-	u8 *p;		
-	p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_, _DSSET_IE_, &len, packet_len - _BEACON_IE_OFFSET_);	
-	if (p)	
-	{	
-		channel = *(p + 2);		
-		if(padapter->mlmeextpriv.cur_channel >= channel)		
-		{			
-			return (padapter->mlmeextpriv.cur_channel - channel);		
-		}		
-		else		
-		{			
-			return (channel-padapter->mlmeextpriv.cur_channel);		
-		}	
-	}	
-	else
-	{		
-		return 0;	
-	}
+	u8 channel;
+	u8 *p;
+	p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_, _DSSET_IE_, &len, packet_len - _BEACON_IE_OFFSET_);
+	if (p) {
+		channel = *(p + 2);
+		if (padapter->mlmeextpriv.cur_channel >= channel)
+			return padapter->mlmeextpriv.cur_channel - channel;
+		else
+			return channel - padapter->mlmeextpriv.cur_channel;
+	} else
+		return 0;
 }
 
 static void _mgt_dispatcher(_adapter *padapter, struct mlme_handler *ptable, union recv_frame *precv_frame)
 {
-	u8 bc_addr[ETH_ALEN] = {0xff,0xff,0xff,0xff,0xff,0xff};
-	u8 *pframe = precv_frame->u.hdr.rx_data; 
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 *pframe = precv_frame->u.hdr.rx_data;
 
-	  if(ptable->func)
-        {
-       	 //receive the frames that ra(a1) is my address or ra(a1) is bc address.
+	if (ptable->func) {
+		/* receive the frames that ra(a1) is my address or ra(a1) is bc address. */
 		if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN) &&
-			!_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN)) 
-		{
+		    !_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN))
 			return;
-		}
-		
+
 		ptable->func(padapter, precv_frame);
-        }
-	
+	}
+
 }
 
 void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)
@@ -1099,73 +1759,60 @@ void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)
 	struct mlme_handler *ptable;
 #ifdef CONFIG_AP_MODE
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-#endif //CONFIG_AP_MODE
-	u8 bc_addr[ETH_ALEN] = {0xff,0xff,0xff,0xff,0xff,0xff};
+#endif /* CONFIG_AP_MODE */
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 	u8 *pframe = precv_frame->u.hdr.rx_data;
-	struct sta_info *psta = rtw_get_stainfo(&padapter->stapriv, GetAddr2Ptr(pframe));
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	struct sta_info *psta = rtw_get_stainfo(&padapter->stapriv, get_addr2_ptr(pframe));
+	struct recv_priv  *precvpriv = &padapter->recvpriv;
 
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-		 ("+mgt_dispatcher: type(0x%x) subtype(0x%x)\n",
-		  GetFrameType(pframe), GetFrameSubType(pframe)));
 
 #if 0
 	{
 		u8 *pbuf;
 		pbuf = GetAddr1Ptr(pframe);
-		DBG_871X("A1-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf+1), *(pbuf+2), *(pbuf+3), *(pbuf+4), *(pbuf+5));
-		pbuf = GetAddr2Ptr(pframe);
-		DBG_871X("A2-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf+1), *(pbuf+2), *(pbuf+3), *(pbuf+4), *(pbuf+5));
+		RTW_INFO("A1-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf + 1), *(pbuf + 2), *(pbuf + 3), *(pbuf + 4), *(pbuf + 5));
+		pbuf = get_addr2_ptr(pframe);
+		RTW_INFO("A2-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf + 1), *(pbuf + 2), *(pbuf + 3), *(pbuf + 4), *(pbuf + 5));
 		pbuf = GetAddr3Ptr(pframe);
-		DBG_871X("A3-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf+1), *(pbuf+2), *(pbuf+3), *(pbuf+4), *(pbuf+5));
+		RTW_INFO("A3-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf + 1), *(pbuf + 2), *(pbuf + 3), *(pbuf + 4), *(pbuf + 5));
 	}
 #endif
 
-	if (GetFrameType(pframe) != WIFI_MGT_TYPE)
-	{
-		RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_, ("mgt_dispatcher: type(0x%x) error!\n", GetFrameType(pframe)));
+	if (GetFrameType(pframe) != WIFI_MGT_TYPE) {
 		return;
 	}
 
-	//receive the frames that ra(a1) is my address or ra(a1) is bc address.
+	/* receive the frames that ra(a1) is my address or ra(a1) is bc address. */
 	if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN) &&
-		!_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN))
-	{
+	    !_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN))
 		return;
-	}
 
 	ptable = mlme_sta_tbl;
 
-	index = GetFrameSubType(pframe) >> 4;
+	index = get_frame_sub_type(pframe) >> 4;
 
 #ifdef CONFIG_TDLS
-	if((index << 4)==WIFI_ACTION){
+	if ((index << 4) == WIFI_ACTION) {
 		/* category==public (4), action==TDLS_DISCOVERY_RESPONSE */
-		if (*(pframe+24) == RTW_WLAN_CATEGORY_PUBLIC && *(pframe+25) == TDLS_DISCOVERY_RESPONSE) {
-			DBG_871X("[TDLS] Recv %s from "MAC_FMT"\n", rtw_tdls_action_txt(TDLS_DISCOVERY_RESPONSE), MAC_ARG(GetAddr2Ptr(pframe)));
+		if (*(pframe + 24) == RTW_WLAN_CATEGORY_PUBLIC && *(pframe + 25) == TDLS_DISCOVERY_RESPONSE) {
+			RTW_INFO("[TDLS] Recv %s from "MAC_FMT"\n", rtw_tdls_action_txt(TDLS_DISCOVERY_RESPONSE), MAC_ARG(get_addr2_ptr(pframe)));
 			On_TDLS_Dis_Rsp(padapter, precv_frame);
 		}
 	}
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-	if (index >= (sizeof(mlme_sta_tbl) /sizeof(struct mlme_handler)))
-	{
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("Currently we do not support reserved sub-fr-type=%d\n", index));
+	if (index >= (sizeof(mlme_sta_tbl) / sizeof(struct mlme_handler))) {
 		return;
 	}
 	ptable += index;
 
 #if 1
-	if (psta != NULL)
-	{
-		if (GetRetry(pframe))
-		{
-			if (precv_frame->u.hdr.attrib.seq_num == psta->RxMgmtFrameSeqNum)
-			{
+	if (psta != NULL) {
+		if (GetRetry(pframe)) {
+			if (precv_frame->u.hdr.attrib.seq_num == psta->RxMgmtFrameSeqNum) {
 				/* drop the duplicate management frame */
-				pdbgpriv->dbg_rx_dup_mgt_frame_drop_count++;
-				DBG_871X("Drop duplicate management frame with seq_num = %d.\n", precv_frame->u.hdr.attrib.seq_num);
+				precvpriv->dbg_rx_dup_mgt_frame_drop_count++;
+				RTW_INFO("Drop duplicate management frame with seq_num = %d.\n", precv_frame->u.hdr.attrib.seq_num);
 				return;
 			}
 		}
@@ -1173,59 +1820,52 @@ void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)
 	}
 #else
 
-	if(GetRetry(pframe))
-	{
-		//RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("drop due to decache!\n"));
-		//return;
+	if (GetRetry(pframe)) {
+		/* return; */
 	}
 #endif
 
 #ifdef CONFIG_AP_MODE
-	switch (GetFrameSubType(pframe)) 
-	{
-		case WIFI_AUTH:
-			if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-				ptable->func = &OnAuth;
-			else
-				ptable->func = &OnAuthClient;
-			//pass through
-		case WIFI_ASSOCREQ:
-		case WIFI_REASSOCREQ:
-			_mgt_dispatcher(padapter, ptable, precv_frame);	
-#ifdef CONFIG_HOSTAPD_MLME				
-			if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-				rtw_hostapd_mlme_rx(padapter, precv_frame);
-#endif			
-			break;
-		case WIFI_PROBEREQ:
-			if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-			{
-#ifdef CONFIG_HOSTAPD_MLME		
-				rtw_hostapd_mlme_rx(padapter, precv_frame);		
-#else
-				_mgt_dispatcher(padapter, ptable, precv_frame);
-#endif
-			}
-			else
-				_mgt_dispatcher(padapter, ptable, precv_frame);
-			break;
-		case WIFI_BEACON:			
-			_mgt_dispatcher(padapter, ptable, precv_frame);
-			break;
-		case WIFI_ACTION:
-			//if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-			_mgt_dispatcher(padapter, ptable, precv_frame);		
-			break;
-		default:
-			_mgt_dispatcher(padapter, ptable, precv_frame);	
-			if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-				rtw_hostapd_mlme_rx(padapter, precv_frame);			
-			break;
+	switch (get_frame_sub_type(pframe)) {
+	case WIFI_AUTH:
+		if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter))
+			ptable->func = &OnAuth;
+		else
+			ptable->func = &OnAuthClient;
+	/* pass through */
+	case WIFI_ASSOCREQ:
+	case WIFI_REASSOCREQ:
+		_mgt_dispatcher(padapter, ptable, precv_frame);
+		#ifdef CONFIG_HOSTAPD_MLME
+		if (MLME_IS_AP(padapter))
+			rtw_hostapd_mlme_rx(padapter, precv_frame);
+		#endif
+		break;
+	case WIFI_PROBEREQ:
+		_mgt_dispatcher(padapter, ptable, precv_frame);
+		#ifdef CONFIG_HOSTAPD_MLME
+		if (MLME_IS_AP(padapter))
+			rtw_hostapd_mlme_rx(padapter, precv_frame);
+		#endif
+		break;
+	case WIFI_BEACON:
+		_mgt_dispatcher(padapter, ptable, precv_frame);
+		break;
+	case WIFI_ACTION:
+		_mgt_dispatcher(padapter, ptable, precv_frame);
+		break;
+	default:
+		_mgt_dispatcher(padapter, ptable, precv_frame);
+		#ifdef CONFIG_HOSTAPD_MLME
+		if (MLME_IS_AP(padapter))
+			rtw_hostapd_mlme_rx(padapter, precv_frame);
+		#endif
+		break;
 	}
 #else
 
-	_mgt_dispatcher(padapter, ptable, precv_frame);	
-	
+	_mgt_dispatcher(padapter, ptable, precv_frame);
+
 #endif
 
 }
@@ -1236,45 +1876,41 @@ u32 p2p_listen_state_process(_adapter *padapter, unsigned char *da)
 	bool response = _TRUE;
 
 #ifdef CONFIG_IOCTL_CFG80211
-	if( padapter->wdinfo.driver_interface == DRIVER_CFG80211 )
-	{
-		if(padapter->cfg80211_wdinfo.is_ro_ch == _FALSE
+	if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
+		if (rtw_cfg80211_get_is_roch(padapter) == _FALSE
 			|| rtw_get_oper_ch(padapter) != padapter->wdinfo.listen_channel
 			|| adapter_wdev_data(padapter)->p2p_enabled == _FALSE
 			|| padapter->mlmepriv.wps_probe_resp_ie == NULL
 			|| padapter->mlmepriv.p2p_probe_resp_ie == NULL
-		)
-		{
+		) {
 #ifdef CONFIG_DEBUG_CFG80211
-			DBG_871X("DON'T issue_probersp_p2p: p2p_enabled:%d, wps_probe_resp_ie:%p, p2p_probe_resp_ie:%p, ",
-				adapter_wdev_data(padapter)->p2p_enabled,
-				padapter->mlmepriv.wps_probe_resp_ie,
-				padapter->mlmepriv.p2p_probe_resp_ie);
-			DBG_871X("is_ro_ch:%d, op_ch:%d, p2p_listen_channel:%d\n", 
-				padapter->cfg80211_wdinfo.is_ro_ch,
-				rtw_get_oper_ch(padapter),
-				padapter->wdinfo.listen_channel);
+			RTW_INFO(ADPT_FMT" DON'T issue_probersp_p2p: p2p_enabled:%d, wps_probe_resp_ie:%p, p2p_probe_resp_ie:%p\n"
+				, ADPT_ARG(padapter)
+				, adapter_wdev_data(padapter)->p2p_enabled
+				, padapter->mlmepriv.wps_probe_resp_ie
+				, padapter->mlmepriv.p2p_probe_resp_ie);
+			RTW_INFO(ADPT_FMT" DON'T issue_probersp_p2p: is_ro_ch:%d, op_ch:%d, p2p_listen_channel:%d\n"
+				, ADPT_ARG(padapter)
+				, rtw_cfg80211_get_is_roch(padapter)
+				, rtw_get_oper_ch(padapter)
+				, padapter->wdinfo.listen_channel);
 #endif
 			response = _FALSE;
 		}
-	}
-	else
-#endif //CONFIG_IOCTL_CFG80211
-	if( padapter->wdinfo.driver_interface == DRIVER_WEXT )
-	{
-		//	do nothing if the device name is empty
-		if ( !padapter->wdinfo.device_name_len )
-		{
-			response	= _FALSE;
+	} else
+#endif /* CONFIG_IOCTL_CFG80211 */
+		if (padapter->wdinfo.driver_interface == DRIVER_WEXT) {
+			/*	do nothing if the device name is empty */
+			if (!padapter->wdinfo.device_name_len)
+				response	= _FALSE;
 		}
-	}
 
 	if (response == _TRUE)
-		issue_probersp_p2p( padapter, da);
-	
+		issue_probersp_p2p(padapter, da);
+
 	return _SUCCESS;
 }
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 
 /****************************************************************************
@@ -1290,13 +1926,13 @@ unsigned int OnProbeReq(_adapter *padapter, union 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);
-	WLAN_BSSID_EX 	*cur = &(pmlmeinfo->network);
+	WLAN_BSSID_EX	*cur = &(pmlmeinfo->network);
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	uint len = precv_frame->u.hdr.len;
 	u8 is_valid_p2p_probereq = _FALSE;
 
 #ifdef CONFIG_ATMEL_RC_PATCH
-	u8 *target_ie=NULL, *wps_ie=NULL;
+	u8 *target_ie = NULL, *wps_ie = NULL;
 	u8 *start;
 	uint search_len = 0, wps_ielen = 0, target_ielen = 0;
 	struct sta_info	*psta;
@@ -1311,180 +1947,153 @@ unsigned int OnProbeReq(_adapter *padapter, union recv_frame *precv_frame)
 
 #ifdef CONFIG_IOCTL_CFG80211
 	if ((pwdinfo->driver_interface == DRIVER_CFG80211)
-		&& !rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
-		&& (GET_CFG80211_REPORT_MGMT(adapter_wdev_data(padapter), IEEE80211_STYPE_PROBE_REQ) == _TRUE)
-		 ) {
-		rtw_cfg80211_rx_probe_request(padapter, pframe, len);
+	    && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
+	    && (GET_CFG80211_REPORT_MGMT(adapter_wdev_data(padapter), IEEE80211_STYPE_PROBE_REQ) == _TRUE)
+	) {
+		rtw_cfg80211_rx_probe_request(padapter, precv_frame);
 		return _SUCCESS;
 	}
 #endif /* CONFIG_IOCTL_CFG80211 */
 
-	if (	!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && 
-		!rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE) && 
-		!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) &&
-		!rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH) &&
-		!rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
-	   )
-	{
-		//	Commented by Albert 2011/03/17
-		//	mcs_rate = 0 -> CCK 1M rate
-		//	mcs_rate = 1 -> CCK 2M rate
-		//	mcs_rate = 2 -> CCK 5.5M rate
-		//	mcs_rate = 3 -> CCK 11M rate
-		//	In the P2P mode, the driver should not support the CCK rate
-
-		//	Commented by Kurt 2012/10/16
-		//	IOT issue: Google Nexus7 use 1M rate to send p2p_probe_req after GO nego completed and Nexus7 is client
-        if (padapter->registrypriv.wifi_spec == 1)
-        {
-            if ( pattrib->data_rate <= 3 )
-            {
-                wifi_test_chk_rate = 0;
-            }
-        }
-
-		if( wifi_test_chk_rate == 1 )
-		{
-			if((is_valid_p2p_probereq = process_probe_req_p2p_ie(pwdinfo, pframe, len)) == _TRUE)
-			{
-				if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE))
-				{
-					// FIXME
-					if( padapter->wdinfo.driver_interface == DRIVER_WEXT )
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) &&
+	    !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE) &&
+	    !rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) &&
+	    !rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH) &&
+	    !rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
+	   ) {
+		/*	Commented by Albert 2011/03/17 */
+		/*	mcs_rate = 0->CCK 1M rate */
+		/*	mcs_rate = 1->CCK 2M rate */
+		/*	mcs_rate = 2->CCK 5.5M rate */
+		/*	mcs_rate = 3->CCK 11M rate */
+		/*	In the P2P mode, the driver should not support the CCK rate */
+
+		/*	Commented by Kurt 2012/10/16 */
+		/*	IOT issue: Google Nexus7 use 1M rate to send p2p_probe_req after GO nego completed and Nexus7 is client */
+		if (padapter->registrypriv.wifi_spec == 1) {
+			if (pattrib->data_rate <= 3)
+				wifi_test_chk_rate = 0;
+		}
+
+		if (wifi_test_chk_rate == 1) {
+			is_valid_p2p_probereq = process_probe_req_p2p_ie(pwdinfo, pframe, len);
+			if (is_valid_p2p_probereq == _TRUE) {
+				if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)) {
+					/* FIXME */
+					if (padapter->wdinfo.driver_interface == DRIVER_WEXT)
 						report_survey_event(padapter, precv_frame);
 
-					p2p_listen_state_process( padapter,  get_sa(pframe));
+					p2p_listen_state_process(padapter,  get_sa(pframe));
 
-					return _SUCCESS;	
+					return _SUCCESS;
 				}
 
-				if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-				{
+				if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
 					goto _continue;
-				}
 			}
 		}
 	}
 
 _continue:
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
-	if(check_fwstate(pmlmepriv, WIFI_STATION_STATE))
-	{
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
 		return _SUCCESS;
-	}
 
-	if(check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE && 
-		check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE|WIFI_AP_STATE)==_FALSE)
-	{
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE &&
+	    check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE | WIFI_AP_STATE | WIFI_MESH_STATE) == _FALSE)
 		return _SUCCESS;
-	}
 
 
-	//DBG_871X("+OnProbeReq\n");
+	/* RTW_INFO("+OnProbeReq\n"); */
 
 
 #ifdef CONFIG_ATMEL_RC_PATCH
-		if ((wps_ie = rtw_get_wps_ie(
-			pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_,
-			len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_,
-			 NULL, &wps_ielen))) {
-		
-			target_ie = rtw_get_wps_attr_content( wps_ie, wps_ielen, WPS_ATTR_MANUFACTURER, NULL, &target_ielen);
-		}
-		if ((target_ie && (target_ielen == 4)) && (_TRUE ==_rtw_memcmp((void *)target_ie, "Ozmo",4 ))) {
-			//psta->flag_atmel_rc = 1;
-			unsigned char *sa_addr = get_sa(pframe);
-			printk("%s: Find Ozmo RC -- %02x:%02x:%02x:%02x:%02x:%02x  \n\n",
-				__func__, *sa_addr, *(sa_addr+1), *(sa_addr+2), *(sa_addr+3), *(sa_addr+4), *(sa_addr+5));
-			_rtw_memcpy(  pstapriv->atmel_rc_pattern, get_sa(pframe), ETH_ALEN);
-		}
+	wps_ie = rtw_get_wps_ie(
+			      pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_,
+			      len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_,
+			      NULL, &wps_ielen);
+	if (wps_ie)
+		target_ie = rtw_get_wps_attr_content(wps_ie, wps_ielen, WPS_ATTR_MANUFACTURER, NULL, &target_ielen);
+	if ((target_ie && (target_ielen == 4)) && (_TRUE == _rtw_memcmp((void *)target_ie, "Ozmo", 4))) {
+		/* psta->flag_atmel_rc = 1; */
+		unsigned char *sa_addr = get_sa(pframe);
+		printk("%s: Find Ozmo RC -- %02x:%02x:%02x:%02x:%02x:%02x  \n\n",
+		       __func__, *sa_addr, *(sa_addr + 1), *(sa_addr + 2), *(sa_addr + 3), *(sa_addr + 4), *(sa_addr + 5));
+		_rtw_memcpy(pstapriv->atmel_rc_pattern, get_sa(pframe), ETH_ALEN);
+	}
 #endif
 
 
 #ifdef CONFIG_AUTO_AP_MODE
-	if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
-			pmlmepriv->cur_network.join_res == _TRUE)
-	{
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
+	    pmlmepriv->cur_network.join_res == _TRUE) {
 		_irqL	irqL;
 		struct sta_info	*psta;
 		u8 *mac_addr, *peer_addr;
 		struct sta_priv *pstapriv = &padapter->stapriv;
-		u8 RC_OUI[4]={0x00,0xE0,0x4C,0x0A};
-		//EID[1] + EID_LEN[1] + RC_OUI[4] + MAC[6] + PairingID[2] + ChannelNum[2]
+		u8 RC_OUI[4] = {0x00, 0xE0, 0x4C, 0x0A};
+		/* EID[1] + EID_LEN[1] + RC_OUI[4] + MAC[6] + PairingID[2] + ChannelNum[2] */
 
 		p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, (int *)&ielen,
-			len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
+			       len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
 
-		if(!p || ielen !=14)
+		if (!p || ielen != 14)
 			goto _non_rc_device;
 
-		if(!_rtw_memcmp(p+2, RC_OUI, sizeof(RC_OUI)))
+		if (!_rtw_memcmp(p + 2, RC_OUI, sizeof(RC_OUI)))
 			goto _non_rc_device;
 
-		if(!_rtw_memcmp(p+6, get_sa(pframe), ETH_ALEN))
-		{
-			DBG_871X("%s, do rc pairing ("MAC_FMT"), but mac addr mismatch!("MAC_FMT")\n", __FUNCTION__,
-				MAC_ARG(get_sa(pframe)), MAC_ARG(p+6));
+		if (!_rtw_memcmp(p + 6, get_sa(pframe), ETH_ALEN)) {
+			RTW_INFO("%s, do rc pairing ("MAC_FMT"), but mac addr mismatch!("MAC_FMT")\n", __FUNCTION__,
+				 MAC_ARG(get_sa(pframe)), MAC_ARG(p + 6));
 
 			goto _non_rc_device;
 		}
 
-		DBG_871X("%s, got the pairing device("MAC_FMT")\n", __FUNCTION__,  MAC_ARG(get_sa(pframe)));
+		RTW_INFO("%s, got the pairing device("MAC_FMT")\n", __FUNCTION__,  MAC_ARG(get_sa(pframe)));
 
-		//new a station
+		/* new a station */
 		psta = rtw_get_stainfo(pstapriv, get_sa(pframe));
-		if (psta == NULL)
-		{
-			// allocate a new one
-			DBG_871X("going to alloc stainfo for rc="MAC_FMT"\n",  MAC_ARG(get_sa(pframe)));
+		if (psta == NULL) {
+			/* allocate a new one */
+			RTW_INFO("going to alloc stainfo for rc="MAC_FMT"\n",  MAC_ARG(get_sa(pframe)));
 			psta = rtw_alloc_stainfo(pstapriv, get_sa(pframe));
-			if (psta == NULL)
-			{
-				//TODO:
-				DBG_871X(" Exceed the upper limit of supported clients...\n");
+			if (psta == NULL) {
+				/* TODO: */
+				RTW_INFO(" Exceed the upper limit of supported clients...\n");
 				return _SUCCESS;
 			}
 
 			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-			if (rtw_is_list_empty(&psta->asoc_list))
-			{
+			if (rtw_is_list_empty(&psta->asoc_list)) {
 				psta->expire_to = pstapriv->expire_to;
 				rtw_list_insert_tail(&psta->asoc_list, &pstapriv->asoc_list);
 				pstapriv->asoc_list_cnt++;
 			}
 			_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 
-			//generate pairing ID
+			/* generate pairing ID */
 			mac_addr = adapter_mac_addr(padapter);
-			peer_addr = psta->hwaddr;
-			psta->pid = (u16)(((mac_addr[4]<<8) + mac_addr[5]) + ((peer_addr[4]<<8) + peer_addr[5]));
+			peer_addr = psta->cmn.mac_addr;
+			psta->pid = (u16)(((mac_addr[4] << 8) + mac_addr[5]) + ((peer_addr[4] << 8) + peer_addr[5]));
 
-			//update peer stainfo
+			/* update peer stainfo */
 			psta->isrc = _TRUE;
-			//psta->aid = 0;
-			//psta->mac_id = 2;
-
-			/* get a unique AID */
-			if (psta->aid > 0) {
-				DBG_871X("old AID %d\n", psta->aid);
-			} else {
-				for (psta->aid = 1; psta->aid <= NUM_STA; psta->aid++)
-					if (pstapriv->sta_aid[psta->aid - 1] == NULL)
-						break;
 
-				if (psta->aid > pstapriv->max_num_sta) {
-					psta->aid = 0;
-					DBG_871X("no room for more AIDs\n");
+			/* AID assignment */
+			if (psta->cmn.aid > 0)
+				RTW_INFO(FUNC_ADPT_FMT" old AID=%d\n", FUNC_ADPT_ARG(padapter), psta->cmn.aid);
+			else {
+				if (!rtw_aid_alloc(padapter, psta)) {
+					RTW_INFO(FUNC_ADPT_FMT" no room for more AIDs\n", FUNC_ADPT_ARG(padapter));
 					return _SUCCESS;
-				} else {
-					pstapriv->sta_aid[psta->aid - 1] = psta;
-					DBG_871X("allocate new AID = (%d)\n", psta->aid);
 				}
+				RTW_INFO(FUNC_ADPT_FMT" allocate new AID=%d\n", FUNC_ADPT_ARG(padapter), psta->cmn.aid);
 			}
-			
+
 			psta->qos_option = 1;
-			psta->bw_mode = CHANNEL_WIDTH_20;
+			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
 			psta->ieee8021x_blocked = _FALSE;
 #ifdef CONFIG_80211N_HT
 			psta->htpriv.ht_option = _TRUE;
@@ -1492,19 +2101,19 @@ _continue:
 			psta->htpriv.sgi_20m = _FALSE;
 			psta->htpriv.sgi_40m = _FALSE;
 			psta->htpriv.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-			psta->htpriv.agg_enable_bitmap = 0x0;//reset
-			psta->htpriv.candidate_tid_bitmap = 0x0;//reset
+			psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
+			psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
 #endif
 
 			rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
 
-			_rtw_memset((void*)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
+			_rtw_memset((void *)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
 
 			_enter_critical_bh(&psta->lock, &irqL);
 			psta->state |= _FW_LINKED;
 			_exit_critical_bh(&psta->lock, &irqL);
 
-			report_add_sta_event(padapter, psta->hwaddr);
+			report_add_sta_event(padapter, psta->cmn.mac_addr);
 
 		}
 
@@ -1518,47 +2127,52 @@ _non_rc_device:
 
 	return _SUCCESS;
 
-#endif //CONFIG_AUTO_AP_MODE
-	
+#endif /* CONFIG_AUTO_AP_MODE */
+
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if(((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE) &&
-		check_buddy_fwstate(padapter, _FW_UNDER_LINKING|_FW_UNDER_SURVEY))
-	{
-		//don't process probe req
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) &&
+	    rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | _FW_UNDER_SURVEY)) {
+		/* don't process probe req */
 		return _SUCCESS;
 	}
-#endif	
+#endif
 
 	p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _SSID_IE_, (int *)&ielen,
-			len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
+		       len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
 
 
-	//check (wildcard) SSID 
-	if (p != NULL)
-	{
-		if(is_valid_p2p_probereq == _TRUE)
-		{
+	/* check (wildcard) SSID */
+	if (p != NULL) {
+		if (is_valid_p2p_probereq == _TRUE)
 			goto _issue_probersp;
-		}
 
-		if ( (ielen != 0 && _FALSE ==_rtw_memcmp((void *)(p+2), (void *)cur->Ssid.Ssid, cur->Ssid.SsidLength))
-			|| (ielen == 0 && pmlmeinfo->hidden_ssid_mode)
-		)
-		{
-			return _SUCCESS;
+		if ((ielen != 0 && _FALSE == _rtw_memcmp((void *)(p + 2), (void *)cur->Ssid.Ssid, cur->Ssid.SsidLength))
+			|| (ielen == 0 && pmlmeinfo->hidden_ssid_mode))
+			goto exit;
+
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter)) {
+			p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, WLAN_EID_MESH_ID, (int *)&ielen,
+					len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
+
+			if (!p)
+				goto exit;
+			if (ielen != 0 && _rtw_memcmp((void *)(p + 2), (void *)cur->mesh_id.Ssid, cur->mesh_id.SsidLength) == _FALSE)
+				goto exit;
 		}
+		#endif
 
 _issue_probersp:
-		if(((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE && 
-			pmlmepriv->cur_network.join_res == _TRUE)) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))
-		{
-			//DBG_871X("+issue_probersp during ap mode\n");
-			issue_probersp(padapter, get_sa(pframe), is_valid_p2p_probereq);		
+		if (((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
+		      pmlmepriv->cur_network.join_res == _TRUE)) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
+			/* RTW_INFO("+issue_probersp during ap mode\n"); */
+			issue_probersp(padapter, get_sa(pframe), is_valid_p2p_probereq);
 		}
 
 	}
 
+exit:
 	return _SUCCESS;
 
 }
@@ -1576,93 +2190,123 @@ unsigned int OnProbeRsp(_adapter *padapter, union recv_frame *precv_frame)
 
 
 #ifdef CONFIG_P2P
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ))
-	{
-		if ( _TRUE == pwdinfo->tx_prov_disc_info.benable )
-		{
-			if( _rtw_memcmp( pwdinfo->tx_prov_disc_info.peerIFAddr, GetAddr2Ptr(pframe), ETH_ALEN ) )
-			{
-				if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT))
-				{
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ)) {
+		if (_TRUE == pwdinfo->tx_prov_disc_info.benable) {
+			if (_rtw_memcmp(pwdinfo->tx_prov_disc_info.peerIFAddr, get_addr2_ptr(pframe), ETH_ALEN)) {
+				if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
 					pwdinfo->tx_prov_disc_info.benable = _FALSE;
-					issue_p2p_provision_request( padapter,
-												pwdinfo->tx_prov_disc_info.ssid.Ssid, 
-												pwdinfo->tx_prov_disc_info.ssid.SsidLength,
-												pwdinfo->tx_prov_disc_info.peerDevAddr );
-				}
-				else if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) )
-				{
+					issue_p2p_provision_request(padapter,
+						pwdinfo->tx_prov_disc_info.ssid.Ssid,
+						pwdinfo->tx_prov_disc_info.ssid.SsidLength,
+						pwdinfo->tx_prov_disc_info.peerDevAddr);
+				} else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
 					pwdinfo->tx_prov_disc_info.benable = _FALSE;
-					issue_p2p_provision_request( padapter,
-												NULL, 
-												0,
-												pwdinfo->tx_prov_disc_info.peerDevAddr );
+					issue_p2p_provision_request(padapter,
+								    NULL,
+								    0,
+						pwdinfo->tx_prov_disc_info.peerDevAddr);
 				}
-			}		
+			}
 		}
 		return _SUCCESS;
-	}
-	else if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING))
-	{
-		if ( _TRUE == pwdinfo->nego_req_info.benable )
-		{
-			DBG_871X( "[%s] P2P State is GONEGO ING!\n", __FUNCTION__ );
-			if( _rtw_memcmp( pwdinfo->nego_req_info.peerDevAddr, GetAddr2Ptr(pframe), ETH_ALEN ) )
-			{
+	} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING)) {
+		if (_TRUE == pwdinfo->nego_req_info.benable) {
+			RTW_INFO("[%s] P2P State is GONEGO ING!\n", __FUNCTION__);
+			if (_rtw_memcmp(pwdinfo->nego_req_info.peerDevAddr, get_addr2_ptr(pframe), ETH_ALEN)) {
 				pwdinfo->nego_req_info.benable = _FALSE;
-				issue_p2p_GO_request( padapter, pwdinfo->nego_req_info.peerDevAddr);
+				issue_p2p_GO_request(padapter, pwdinfo->nego_req_info.peerDevAddr);
 			}
 		}
-	}
-	else if( rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ ) )
-	{
-		if ( _TRUE == pwdinfo->invitereq_info.benable )
-		{
-			DBG_871X( "[%s] P2P_STATE_TX_INVITE_REQ!\n", __FUNCTION__ );
-			if( _rtw_memcmp( pwdinfo->invitereq_info.peer_macaddr, GetAddr2Ptr(pframe), ETH_ALEN ) )
-			{
+	} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ)) {
+		if (_TRUE == pwdinfo->invitereq_info.benable) {
+			RTW_INFO("[%s] P2P_STATE_TX_INVITE_REQ!\n", __FUNCTION__);
+			if (_rtw_memcmp(pwdinfo->invitereq_info.peer_macaddr, get_addr2_ptr(pframe), ETH_ALEN)) {
 				pwdinfo->invitereq_info.benable = _FALSE;
-				issue_p2p_invitation_request( padapter, pwdinfo->invitereq_info.peer_macaddr );
+				issue_p2p_invitation_request(padapter, pwdinfo->invitereq_info.peer_macaddr);
 			}
 		}
 	}
 #endif
 
 
-	if (mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS)) {
-		report_survey_event(padapter, precv_frame);	
-#ifdef CONFIG_CONCURRENT_MODE
-		report_survey_event(padapter->pbuddy_adapter, precv_frame);	
-#endif
+	if ((mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS))
+		|| (MLME_IS_MESH(padapter) && check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE))
+		#ifdef CONFIG_RTW_REPEATER_SON
+		|| (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS)
+		#endif
+	) {
+		rtw_mi_report_survey_event(padapter, precv_frame);
 		return _SUCCESS;
 	}
 
-	#if 0 //move to validate_recv_mgnt_frame
-	if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN))
-	{
-		if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-		{
-			if ((psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe))) != NULL)
-			{
+#if 0 /* move to validate_recv_mgnt_frame */
+	if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)) {
+		if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
+			psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+			if (psta != NULL)
 				psta->sta_stats.rx_mgnt_pkts++;
-			}
 		}
 	}
-	#endif
-	
+#endif
+
 	return _SUCCESS;
-	
+
 }
 
-unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
+/* for 11n Logo 4.2.31/4.2.32 */
+static void rtw_check_legacy_ap(_adapter *padapter, u8 *pframe, u32 len)
 {
-	struct sta_info	*psta;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct sta_priv	*pstapriv = &padapter->stapriv;
-	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint len = precv_frame->u.hdr.len;
+
+	if (!padapter->registrypriv.wifi_spec)
+		return;
+	
+	if(!MLME_IS_AP(padapter))
+		return;
+	
+
+	if (pmlmeext->bstart_bss == _TRUE) {
+		int left;
+		u16 capability;
+		unsigned char *pos;
+		struct rtw_ieee802_11_elems elems;
+		struct HT_info_element *pht_info = NULL;
+		u16 cur_op_mode; 
+
+		/* checking IEs */
+		left = len - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_;
+		pos = pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_;
+		if (rtw_ieee802_11_parse_elems(pos, left, &elems, 1) == ParseFailed) {
+			RTW_INFO("%s: parse fail for "MAC_FMT"\n", __func__, MAC_ARG(GetAddr3Ptr(pframe)));
+			return;
+		}
+
+		cur_op_mode = pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_OP_MODE_MASK;
+
+		/* for legacy ap */
+		if (elems.ht_capabilities == NULL && elems.ht_capabilities_len == 0) {
+
+			if (0)
+				RTW_INFO("%s: "MAC_FMT" is legacy ap\n", __func__, MAC_ARG(GetAddr3Ptr(pframe)));
+
+			ATOMIC_SET(&pmlmepriv->olbc, _TRUE);
+			ATOMIC_SET(&pmlmepriv->olbc_ht, _TRUE);
+		}
+			
+	}
+}
+
+unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
+{
+	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;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	uint len = precv_frame->u.hdr.len;
 	WLAN_BSSID_EX *pbss;
 	int ret = _SUCCESS;
 	u8 *p = NULL;
@@ -1670,35 +2314,49 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 #ifdef CONFIG_TDLS
 	struct sta_info *ptdls_sta;
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+#ifdef CONFIG_TDLS_CH_SW
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+#endif
 #endif /* CONFIG_TDLS */
 
+	if (validate_beacon_len(pframe, len) == _FALSE)
+		return _SUCCESS;
 #ifdef CONFIG_ATTEMPT_TO_FIX_AP_BEACON_ERROR
-	p = rtw_get_ie(pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, &ielen, precv_frame->u.hdr.len -sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_);
-	if ((p != NULL) && (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_871X("[WIFIDBG] Error in ESR IE is detected in Beacon of BSSID:"MAC_FMT". Fix the length of ESR IE to avoid failed Beacon parsing.\n", MAC_ARG(GetAddr3Ptr(pframe)));
-		       	*(p + 1) = ielen - 1;
+	p = rtw_get_ie(pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, &ielen,
+		precv_frame->u.hdr.len - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_);
+	if ((p != NULL) && (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. */
+			RTW_INFO("[WIFIDBG] Error in ESR IE is detected in Beacon of BSSID:"MAC_FMT". Fix the length of ESR IE to avoid failed Beacon parsing.\n", MAC_ARG(GetAddr3Ptr(pframe)));
+			*(p + 1) = ielen - 1;
 		}
 	}
 #endif
 
-	if (mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS)) {
-		report_survey_event(padapter, precv_frame);
-#ifdef CONFIG_CONCURRENT_MODE
-		report_survey_event(padapter->pbuddy_adapter, precv_frame);	
-#endif
+	if (mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS)
+		|| (MLME_IS_MESH(padapter) && check_fwstate(pmlmepriv, WIFI_ASOC_STATE))
+	) {
+		rtw_mi_report_survey_event(padapter, precv_frame);
 		return _SUCCESS;
 	}
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS)
+		rtw_mi_report_survey_event(padapter, precv_frame);
+#endif
 
-	if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN))
-	{
-		if (pmlmeinfo->state & WIFI_FW_AUTH_NULL)
-		{
-			//we should update current network before auth, or some IE is wrong
-			pbss = (WLAN_BSSID_EX*)rtw_malloc(sizeof(WLAN_BSSID_EX));
+	rtw_check_legacy_ap(padapter, pframe, len);
+
+	if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)) {
+		if ((pmlmeinfo->state & WIFI_FW_AUTH_NULL)
+			&& (rtw_sta_linking_test_wait_done() || pmlmeext->join_abort)
+		) {
+			if (rtw_sta_linking_test_force_fail() || pmlmeext->join_abort) {
+				set_link_timer(pmlmeext, 1);
+				return _SUCCESS;
+			}
+
+			/* we should update current network before auth, or some IE is wrong */
+			pbss = (WLAN_BSSID_EX *)rtw_malloc(sizeof(WLAN_BSSID_EX));
 			if (pbss) {
 				if (collect_bss_info(padapter, precv_frame, pbss) == _SUCCESS) {
 					struct beacon_keys recv_beacon;
@@ -1706,29 +2364,28 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 					update_network(&(pmlmepriv->cur_network.network), pbss, padapter, _TRUE);
 					rtw_get_bcn_info(&(pmlmepriv->cur_network));
 
-					// update bcn keys
+					/* update bcn keys */
 					if (rtw_get_bcn_keys(padapter, pframe, len, &recv_beacon) == _TRUE) {
-						DBG_871X("%s: beacon keys ready\n", __func__);
+						RTW_INFO("%s: beacon keys ready\n", __func__);
 						_rtw_memcpy(&pmlmepriv->cur_beacon_keys,
 							&recv_beacon, sizeof(recv_beacon));
 						pmlmepriv->new_beacon_cnts = 0;
-					}
-					else {
-						DBG_871X_LEVEL(_drv_err_, "%s: get beacon keys failed\n", __func__);
+					} else {
+						RTW_ERR("%s: get beacon keys failed\n", __func__);
 						_rtw_memset(&pmlmepriv->cur_beacon_keys, 0, sizeof(recv_beacon));
 						pmlmepriv->new_beacon_cnts = 0;
 					}
 				}
-				rtw_mfree((u8*)pbss, sizeof(WLAN_BSSID_EX));
+				rtw_mfree((u8 *)pbss, sizeof(WLAN_BSSID_EX));
 			}
 
-			//check the vendor of the assoc AP
-			pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pframe+sizeof(struct rtw_ieee80211_hdr_3addr), len-sizeof(struct rtw_ieee80211_hdr_3addr));				
+			/* check the vendor of the assoc AP */
+			pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pframe + sizeof(struct rtw_ieee80211_hdr_3addr), len - sizeof(struct rtw_ieee80211_hdr_3addr));
 
-			//update TSF Value
+			/* update TSF Value */
 			update_TSF(pmlmeext, pframe, len);
 
-			//reset for adaptive_early_32k
+			/* reset for adaptive_early_32k */
 			pmlmeext->adaptive_tsf_done = _FALSE;
 			pmlmeext->DrvBcnEarly = 0xff;
 			pmlmeext->DrvBcnTimeOut = 0xff;
@@ -1737,98 +2394,101 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 			_rtw_memset(pmlmeext->bcn_delay_ratio, 0, sizeof(pmlmeext->bcn_delay_ratio));
 
 #ifdef CONFIG_P2P_PS
-			process_p2p_ps_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN));
-#endif //CONFIG_P2P_PS
+			/* Comment by YiWei , in wifi p2p spec the "3.3 P2P Power Management" , "These mechanisms are available in a P2P Group in which only P2P Devices are associated." */
+			/* process_p2p_ps_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN)); */
+#endif /* CONFIG_P2P_PS */
 
-#if defined(CONFIG_P2P)&&defined(CONFIG_CONCURRENT_MODE)
+#if defined(CONFIG_P2P) && defined(CONFIG_CONCURRENT_MODE)
 			if (padapter->registrypriv.wifi_spec) {
 				if (process_p2p_cross_connect_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN)) == _FALSE) {
-					if((padapter->pbuddy_adapter->mlmeextpriv.mlmext_info.state&0x03) == WIFI_FW_AP_STATE) {
-						DBG_871X_LEVEL(_drv_always_, "no issue auth, P2P cross-connect does not permit\n ");
+					if (rtw_mi_buddy_check_mlmeinfo_state(padapter, WIFI_FW_AP_STATE)) {
+						RTW_PRINT("no issue auth, P2P cross-connect does not permit\n ");
 						return _SUCCESS;
 					}
 				}
 			}
-#endif // CONFIG_P2P CONFIG_P2P and CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_P2P CONFIG_P2P and CONFIG_CONCURRENT_MODE */
 
-			//start auth
+			/* start auth */
 			start_clnt_auth(padapter);
 
 			return _SUCCESS;
 		}
 
-		if(((pmlmeinfo->state&0x03) == WIFI_FW_STATION_STATE) && (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
-		{
-			if ((psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe))) != NULL)
-			{
-				#ifdef CONFIG_PATCH_JOIN_WRONG_CHANNEL        
-				//Merge from 8712 FW code
-				if (cmp_pkt_chnl_diff(padapter,pframe,len) != 0)        
-				{            // join wrong channel, deauth and reconnect           
+		if (((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) && (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
+			psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+			if (psta != NULL) {
+#ifdef CONFIG_PATCH_JOIN_WRONG_CHANNEL
+				/* Merge from 8712 FW code */
+				if (cmp_pkt_chnl_diff(padapter, pframe, len) != 0) {
+					/* join wrong channel, deauth and reconnect           */
 					issue_deauth(padapter, (&(pmlmeinfo->network))->MacAddress, WLAN_REASON_DEAUTH_LEAVING);
 
 					report_del_sta_event(padapter, (&(pmlmeinfo->network))->MacAddress, WLAN_REASON_JOIN_WRONG_CHANNEL, _TRUE, _FALSE);
-					pmlmeinfo->state &= (~WIFI_FW_ASSOC_SUCCESS);    		
+					pmlmeinfo->state &= (~WIFI_FW_ASSOC_SUCCESS);
 					return _SUCCESS;
-				}        
-				#endif //CONFIG_PATCH_JOIN_WRONG_CHANNEL
-
+				}
+#endif /* CONFIG_PATCH_JOIN_WRONG_CHANNEL */
+#ifdef CONFIG_RTW_80211R
+				rtw_ft_update_bcn(padapter, precv_frame);
+#endif
 				ret = rtw_check_bcn_info(padapter, pframe, len);
 				if (!ret) {
-						DBG_871X_LEVEL(_drv_always_, "ap has changed, disconnect now\n ");
-						receive_disconnect(padapter, pmlmeinfo->network.MacAddress , 0, _FALSE);
-						return _SUCCESS;
+					RTW_PRINT("ap has changed, disconnect now\n ");
+					receive_disconnect(padapter, pmlmeinfo->network.MacAddress , 0, _FALSE);
+					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_871X("update_bcn_info\n");
+				/* 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) {
+					/* RTW_INFO("update_bcn_info\n"); */
 					update_beacon_info(padapter, pframe, len, psta);
 				}
 
-				adaptive_early_32k(pmlmeext, pframe, len);			 	
-				
+				pmlmepriv->cur_network_scanned->network.Rssi = precv_frame->u.hdr.attrib.phy_info.recv_signal_power;
+
+				adaptive_early_32k(pmlmeext, pframe, len);
+
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_TDLS_CH_SW
-				if (padapter->tdlsinfo.ch_switch_prohibited == _FALSE)
-				{
+				if (rtw_tdls_is_chsw_allowed(padapter) == _TRUE) {
 					/* Send TDLS Channel Switch Request when receiving Beacon */
-					if ((padapter->tdlsinfo.chsw_info.ch_sw_state & TDLS_CH_SW_INITIATOR_STATE) && (pmlmeext->cur_channel == rtw_get_oper_ch(padapter))) {
-						ptdlsinfo->chsw_info.ch_sw_state |= TDLS_WAIT_CH_RSP_STATE;
-						/* DBG_871X("[%s] issue_tdls_ch_switch_req to "MAC_FMT"\n", __FUNCTION__, MAC_ARG(padapter->tdlsinfo.chsw_info.addr)); */
+					if ((padapter->tdlsinfo.chsw_info.ch_sw_state & TDLS_CH_SW_INITIATOR_STATE) && (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE)
+					    && (pmlmeext->cur_channel == rtw_get_oper_ch(padapter))) {
 						ptdls_sta = rtw_get_stainfo(&padapter->stapriv, padapter->tdlsinfo.chsw_info.addr);
 						if (ptdls_sta != NULL) {
 							if (ptdls_sta->tdls_sta_state | TDLS_LINKED_STATE)
-								issue_tdls_ch_switch_req(padapter, ptdls_sta);
+								_set_timer(&ptdls_sta->stay_on_base_chnl_timer, TDLS_CH_SW_STAY_ON_BASE_CHNL_TIMEOUT);
 						}
 					}
 				}
-#endif				
+#endif
 #endif /* CONFIG_TDLS */
 
-#ifdef CONFIG_DFS
-				process_csa_ie(padapter, pframe, len);	//channel switch announcement
-#endif //CONFIG_DFS
+				#ifdef CONFIG_DFS
+				process_csa_ie(padapter
+					, pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_
+					, len - (WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_));
+				#endif
 
 #ifdef CONFIG_P2P_PS
 				process_p2p_ps_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN));
-#endif //CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
 				if (pmlmeext->en_hw_update_tsf)
 					rtw_enable_hw_update_tsf_cmd(padapter);
 
-				#if 0 //move to validate_recv_mgnt_frame
+#if 0 /* move to validate_recv_mgnt_frame */
 				psta->sta_stats.rx_mgnt_pkts++;
-				#endif
+#endif
 			}
 
-		} else if ((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) {
+		} else if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
 			_irqL irqL;
 			u8 rate_set[16];
 			u8 rate_num = 0;
 
-			psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));
+			psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
 			if (psta != NULL) {
 				/*
 				* update WMM, ERP in the beacon
@@ -1839,17 +2499,16 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 
 				if (pmlmeext->en_hw_update_tsf)
 					rtw_enable_hw_update_tsf_cmd(padapter);
-
 			} else {
 				rtw_ies_get_supported_rate(pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_, len - WLAN_HDR_A3_LEN - _BEACON_IE_OFFSET_, rate_set, &rate_num);
 				if (rate_num == 0) {
-					DBG_871X(FUNC_ADPT_FMT" RX beacon with no supported rate\n", FUNC_ADPT_ARG(padapter));
+					RTW_INFO(FUNC_ADPT_FMT" RX beacon with no supported rate\n", FUNC_ADPT_ARG(padapter));
 					goto _END_ONBEACON_;
 				}
 
-				psta = rtw_alloc_stainfo(pstapriv, GetAddr2Ptr(pframe));
+				psta = rtw_alloc_stainfo(pstapriv, get_addr2_ptr(pframe));
 				if (psta == NULL) {
-					DBG_871X(FUNC_ADPT_FMT" Exceed the upper limit of supported clients\n", FUNC_ADPT_ARG(padapter));
+					RTW_INFO(FUNC_ADPT_FMT" Exceed the upper limit of supported clients\n", FUNC_ADPT_ARG(padapter));
 					goto _END_ONBEACON_;
 				}
 
@@ -1858,11 +2517,11 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 				_rtw_memcpy(psta->bssrateset, rate_set, rate_num);
 				psta->bssratelen = rate_num;
 
-				//update TSF Value
-				update_TSF(pmlmeext, pframe, len);			
+				/* update TSF Value */
+				update_TSF(pmlmeext, pframe, len);
 
-				//report sta add event
-				report_add_sta_event(padapter, GetAddr2Ptr(pframe));
+				/* report sta add event */
+				report_add_sta_event(padapter, get_addr2_ptr(pframe));
 			}
 		}
 	}
@@ -1878,48 +2537,69 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 #ifdef CONFIG_AP_MODE
 	_irqL irqL;
 	unsigned int	auth_mode, seq, ie_len;
-	unsigned char	*sa, *p;	
+	unsigned char	*sa, *p;
 	u16	algorithm;
 	int	status;
-	static struct sta_info stat;	
-	struct	sta_info	*pstat=NULL;	
+	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);
-	u8 *pframe = precv_frame->u.hdr.rx_data; 
+	u8 *pframe = precv_frame->u.hdr.rx_data;
 	uint len = precv_frame->u.hdr.len;
 	u8	offset = 0;
 
-	
-#ifdef CONFIG_CONCURRENT_MODE	
-	if(((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE) &&
-		check_buddy_fwstate(padapter, _FW_UNDER_LINKING|_FW_UNDER_SURVEY))
-	{
-		//don't process auth request;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) &&
+	    rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | _FW_UNDER_SURVEY)) {
+		/* don't process auth request; */
 		return _SUCCESS;
 	}
-#endif //CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_CONCURRENT_MODE */
 
-	if((pmlmeinfo->state&0x03) != WIFI_FW_AP_STATE)
+	if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
 		return _FAIL;
 
-	DBG_871X("+OnAuth\n");
+#if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_RTW_MESH)
+	if (MLME_IS_MESH(padapter)) {
+		if (!MLME_IS_ASOC(padapter))
+			return _SUCCESS;
+		
+		#if CONFIG_RTW_MACADDR_ACL
+		if (rtw_access_ctrl(padapter, get_addr2_ptr(pframe)) == _FALSE)
+			return _SUCCESS;
+		#endif
+
+		if (!rtw_mesh_plink_get(padapter, get_addr2_ptr(pframe))) {
+			if (adapter_to_rfctl(padapter)->offch_state == OFFCHS_NONE)
+				issue_probereq(padapter, &padapter->mlmepriv.cur_network.network.mesh_id, get_addr2_ptr(pframe));
+
+			/* only peer being added (checked by notify conditions) is allowed */
+			return _SUCCESS;
+		}
+
+		rtw_cfg80211_rx_mframe(padapter, precv_frame, NULL);
+		return _SUCCESS;
+	}
+#endif
+
+	RTW_INFO("+OnAuth\n");
 
-	sa = GetAddr2Ptr(pframe);
+	sa = get_addr2_ptr(pframe);
 
 	auth_mode = psecuritypriv->dot11AuthAlgrthm;
 
-	if (GetPrivacy(pframe))
-	{
+	if (GetPrivacy(pframe)) {
 		u8	*iv;
-		struct rx_pkt_attrib	 *prxattrib = &(precv_frame->u.hdr.attrib);
+		struct rx_pkt_attrib	*prxattrib = &(precv_frame->u.hdr.attrib);
 
 		prxattrib->hdrlen = WLAN_HDR_A3_LEN;
 		prxattrib->encrypt = _WEP40_;
 
-		iv = pframe+prxattrib->hdrlen;
-		prxattrib->key_index = ((iv[3]>>6)&0x3);
+		iv = pframe + prxattrib->hdrlen;
+		prxattrib->key_index = ((iv[3] >> 6) & 0x3);
 
 		prxattrib->iv_len = 4;
 		prxattrib->icv_len = 4;
@@ -1929,83 +2609,50 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 		offset = 4;
 	}
 
-	algorithm = le16_to_cpu(*(u16*)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset));
-	seq 	= le16_to_cpu(*(u16*)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 2));
+	algorithm = le16_to_cpu(*(u16 *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset));
+	seq	= le16_to_cpu(*(u16 *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 2));
 
-	DBG_871X("auth alg=%x, seq=%X\n", algorithm, seq);
+	RTW_INFO("auth alg=%x, seq=%X\n", algorithm, seq);
 
 	if (auth_mode == 2 &&
-			psecuritypriv->dot11PrivacyAlgrthm != _WEP40_ &&
-			psecuritypriv->dot11PrivacyAlgrthm != _WEP104_)
+	    psecuritypriv->dot11PrivacyAlgrthm != _WEP40_ &&
+	    psecuritypriv->dot11PrivacyAlgrthm != _WEP104_)
 		auth_mode = 0;
 
-	if ((algorithm > 0 && auth_mode == 0) ||	// rx a shared-key auth but shared not enabled
-		(algorithm == 0 && auth_mode == 1) )	// rx a open-system auth but shared-key is enabled
-	{		
-		DBG_871X("auth rejected due to bad alg [alg=%d, auth_mib=%d] %02X%02X%02X%02X%02X%02X\n",
+	if ((algorithm > 0 && auth_mode == 0) ||	/* rx a shared-key auth but shared not enabled */
+	    (algorithm == 0 && auth_mode == 1)) {	/* rx a open-system auth but shared-key is enabled */
+		RTW_INFO("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 = _STATS_NO_SUPP_ALG_;
-		
-		goto auth_fail;
-	}
-	
-#if 0 //ACL control	
-	phead = &priv->wlan_acl_list;
-	plist = phead->next;
-	//check sa
-	if (acl_mode == 1)		// 1: positive check, only those on acl_list can be connected.
-		res = FAIL;
-	else
-		res = SUCCESS;
 
-	while(plist != phead)
-	{
-		paclnode = list_entry(plist, struct rtw_wlan_acl_node, list);
-		plist = plist->next;
-		if (!memcmp((void *)sa, paclnode->addr, 6)) {
-			if (paclnode->mode & 2) { // deny
-				res = FAIL;
-				break;
-			}
-			else {
-				res = SUCCESS;
-				break;
-			}
-		}
+		goto auth_fail;
 	}
 
-	if (res != SUCCESS) {
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,"auth abort because ACL!\n");
-		return FAIL;
-	}
-#else
-	if(rtw_access_ctrl(padapter, sa) == _FALSE)
-	{
+#if CONFIG_RTW_MACADDR_ACL
+	if (rtw_access_ctrl(padapter, sa) == _FALSE) {
 		status = _STATS_UNABLE_HANDLE_STA_;
 		goto auth_fail;
-	}	
+	}
 #endif
 
 	pstat = rtw_get_stainfo(pstapriv, sa);
-	if (pstat == NULL)
-	{
+	if (pstat == NULL) {
 
-		// allocate a new one
-		DBG_871X("going to alloc stainfo for sa="MAC_FMT"\n",  MAC_ARG(sa));
+		/* allocate a new one */
+		RTW_INFO("going to alloc stainfo for sa="MAC_FMT"\n",  MAC_ARG(sa));
 		pstat = rtw_alloc_stainfo(pstapriv, sa);
-		if (pstat == NULL)
-		{
-			DBG_871X(" Exceed the upper limit of supported clients...\n");
+		if (pstat == NULL) {
+			RTW_INFO(" Exceed the upper limit of supported clients...\n");
 			status = _STATS_UNABLE_HANDLE_STA_;
 			goto auth_fail;
 		}
-		
+
 		pstat->state = WIFI_FW_AUTH_NULL;
 		pstat->auth_seq = 0;
-		
-		//pstat->flags = 0;
-		//pstat->capability = 0;
+
+		/* pstat->flags = 0; */
+		/* pstat->capability = 0; */
 	} else {
 #ifdef CONFIG_IEEE80211W
 		if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
@@ -2013,7 +2660,7 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 		{
 
 			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-			if (rtw_is_list_empty(&pstat->asoc_list) == _FALSE) {			
+			if (rtw_is_list_empty(&pstat->asoc_list) == _FALSE) {
 				rtw_list_delete(&pstat->asoc_list);
 				pstapriv->asoc_list_cnt--;
 				if (pstat->expire_to > 0)
@@ -2028,15 +2675,15 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 	}
 
 #ifdef CONFIG_IEEE80211W
-	if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS)) 
+	if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
 #endif /* CONFIG_IEEE80211W */
 	{
 		_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
-		if (rtw_is_list_empty(&pstat->auth_list)) {		
-	
+		if (rtw_is_list_empty(&pstat->auth_list)) {
+
 			rtw_list_insert_tail(&pstat->auth_list, &pstapriv->auth_list);
 			pstapriv->auth_list_cnt++;
-		}	
+		}
 		_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
 	}
 
@@ -2044,20 +2691,17 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 		pstat->expire_to = pstapriv->auth_to;
 
 
-	if ((pstat->auth_seq + 1) != seq)
-	{
-		DBG_871X("(1)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
-			seq, pstat->auth_seq+1);
+	if ((pstat->auth_seq + 1) != seq) {
+		RTW_INFO("(1)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
+			 seq, pstat->auth_seq + 1);
 		status = _STATS_OUT_OF_AUTH_SEQ_;
 		goto auth_fail;
 	}
 
-	if (algorithm==0 && (auth_mode == 0 || auth_mode == 2 || auth_mode == 3))
-	{
-		if (seq == 1)
-		{
+	if (algorithm == 0 && (auth_mode == 0 || auth_mode == 2 || auth_mode == 3)) {
+		if (seq == 1) {
 #ifdef CONFIG_IEEE80211W
-			if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS)) 
+			if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
 #endif /* CONFIG_IEEE80211W */
 			{
 				pstat->state &= ~WIFI_FW_AUTH_NULL;
@@ -2065,25 +2709,20 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 				pstat->expire_to = pstapriv->assoc_to;
 			}
 			pstat->authalg = algorithm;
-		}
-		else
-		{
-			DBG_871X("(2)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
-				seq, pstat->auth_seq+1);
+		} else {
+			RTW_INFO("(2)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
+				 seq, pstat->auth_seq + 1);
 			status = _STATS_OUT_OF_AUTH_SEQ_;
 			goto auth_fail;
 		}
-	}
-	else // shared system or auto authentication
-	{
-		if (seq == 1)
-		{
-			//prepare for the challenging txt...
+	} else { /* shared system or auto authentication */
+		if (seq == 1) {
+			/* prepare for the challenging txt... */
 
-			//get_random_bytes((void *)pstat->chg_txt, 128);//TODO:
+			/* get_random_bytes((void *)pstat->chg_txt, 128); */ /* TODO: */
 			_rtw_memset((void *)pstat->chg_txt, 78, 128);
 #ifdef CONFIG_IEEE80211W
-			if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS)) 
+			if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
 #endif /* CONFIG_IEEE80211W */
 			{
 				pstat->state &= ~WIFI_FW_AUTH_NULL;
@@ -2091,26 +2730,22 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 			}
 			pstat->authalg = algorithm;
 			pstat->auth_seq = 2;
-		}
-		else if (seq == 3)
-		{
-			//checking for challenging txt...
-			DBG_871X("checking for challenging txt...\n");
-			
+		} else if (seq == 3) {
+			/* checking for challenging txt... */
+			RTW_INFO("checking for challenging txt...\n");
+
 			p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + 4 + _AUTH_IE_OFFSET_ , _CHLGETXT_IE_, (int *)&ie_len,
-					len - WLAN_HDR_A3_LEN - _AUTH_IE_OFFSET_ - 4);
+				len - WLAN_HDR_A3_LEN - _AUTH_IE_OFFSET_ - 4);
 
-			if((p==NULL) || (ie_len<=0))
-			{
-				DBG_871X("auth rejected because challenge failure!(1)\n");
+			if ((p == NULL) || (ie_len <= 0)) {
+				RTW_INFO("auth rejected because challenge failure!(1)\n");
 				status = _STATS_CHALLENGE_FAIL_;
 				goto auth_fail;
 			}
-			
-			if (_rtw_memcmp((void *)(p + 2), pstat->chg_txt, 128))
-			{
+
+			if (_rtw_memcmp((void *)(p + 2), pstat->chg_txt, 128)) {
 #ifdef CONFIG_IEEE80211W
-				if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS)) 
+				if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
 #endif /* CONFIG_IEEE80211W */
 				{
 					pstat->state &= (~WIFI_FW_AUTH_STATE);
@@ -2118,27 +2753,23 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 					/* challenging txt is correct... */
 					pstat->expire_to =  pstapriv->assoc_to;
 				}
-			}
-			else
-			{
-				DBG_871X("auth rejected because challenge failure!\n");
+			} else {
+				RTW_INFO("auth rejected because challenge failure!\n");
 				status = _STATS_CHALLENGE_FAIL_;
 				goto auth_fail;
 			}
-		}
-		else
-		{
-			DBG_871X("(3)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
-				seq, pstat->auth_seq+1);
+		} else {
+			RTW_INFO("(3)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
+				 seq, pstat->auth_seq + 1);
 			status = _STATS_OUT_OF_AUTH_SEQ_;
 			goto auth_fail;
 		}
 	}
 
 
-	// Now, we are going to issue_auth...
-	pstat->auth_seq = seq + 1;	
-	
+	/* Now, we are going to issue_auth... */
+	pstat->auth_seq = seq + 1;
+
 #ifdef CONFIG_NATIVEAP_MLME
 	issue_auth(padapter, pstat, (unsigned short)(_STATS_SUCCESSFUL_));
 #endif
@@ -2146,21 +2777,21 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 	if ((pstat->state & WIFI_FW_AUTH_SUCCESS) || (pstat->state & WIFI_FW_ASSOC_SUCCESS))
 		pstat->auth_seq = 0;
 
-		
+
 	return _SUCCESS;
 
 auth_fail:
 
-	if(pstat)
+	if (pstat)
 		rtw_free_stainfo(padapter , pstat);
-	
+
 	pstat = &stat;
 	_rtw_memset((char *)pstat, '\0', sizeof(stat));
 	pstat->auth_seq = 2;
-	_rtw_memcpy(pstat->hwaddr, sa, 6);	
-	
+	_rtw_memcpy(pstat->cmn.mac_addr, sa, 6);
+
 #ifdef CONFIG_NATIVEAP_MLME
-	issue_auth(padapter, pstat, (unsigned short)status);	
+	issue_auth(padapter, pstat, (unsigned short)status);
 #endif
 
 #endif
@@ -2178,48 +2809,44 @@ unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	uint pkt_len = precv_frame->u.hdr.len;
 
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	//check A1 matches or not
+	/* check A1 matches or not */
 	if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
 		return _SUCCESS;
 
-	if (!(pmlmeinfo->state & WIFI_FW_AUTH_STATE))
+	if (!(pmlmeinfo->state & WIFI_FW_AUTH_STATE) || pmlmeext->join_abort)
 		return _SUCCESS;
 
-	offset = (GetPrivacy(pframe))? 4: 0;
+	offset = (GetPrivacy(pframe)) ? 4 : 0;
 
-	algthm 	= le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset));
-	seq 	= le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 2));
-	status 	= le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 4));
+	algthm	= le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset));
+	seq	= le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 2));
+	status	= le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 4));
 
-	if (status != 0)
-	{
-		DBG_871X("clnt auth fail, status: %d\n", status);
-		if(status == 13)//&& pmlmeinfo->auth_algo == dot11AuthAlgrthm_Auto)
-		{
-			if(pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
+	if (status != 0) {
+		RTW_INFO("clnt auth fail, status: %d\n", status);
+		if (status == 13) { /* && pmlmeinfo->auth_algo == dot11AuthAlgrthm_Auto) */
+			if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
 				pmlmeinfo->auth_algo = dot11AuthAlgrthm_Open;
 			else
 				pmlmeinfo->auth_algo = dot11AuthAlgrthm_Shared;
-			//pmlmeinfo->reauth_count = 0;
+			/* pmlmeinfo->reauth_count = 0; */
 		}
-		
+
+		pmlmeinfo->auth_status = status;
 		set_link_timer(pmlmeext, 1);
 		goto authclnt_fail;
 	}
 
-	if (seq == 2)
-	{
-		if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
-		{
-			 // legendary shared system
+	if (seq == 2) {
+		if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared) {
+			/* legendary shared system */
 			p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _AUTH_IE_OFFSET_, _CHLGETXT_IE_, (int *)&len,
 				pkt_len - WLAN_HDR_A3_LEN - _AUTH_IE_OFFSET_);
 
-			if (p == NULL)
-			{
-				//DBG_871X("marc: no challenge text?\n");
+			if (p == NULL) {
+				/* RTW_INFO("marc: no challenge text?\n"); */
 				goto authclnt_fail;
 			}
 
@@ -2229,41 +2856,34 @@ unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)
 			set_link_timer(pmlmeext, REAUTH_TO);
 
 			return _SUCCESS;
-		}
-		else
-		{
-			// open system
+		} else {
+			/* open, or 802.11r FTAA system */
 			go2asoc = 1;
 		}
-	}
-	else if (seq == 4)
-	{
+	} else if (seq == 4) {
 		if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
-		{
 			go2asoc = 1;
-		}
 		else
-		{
 			goto authclnt_fail;
-		}
-	}
-	else
-	{
-		// this is also illegal
-		//DBG_871X("marc: clnt auth failed due to illegal seq=%x\n", seq);
+	} else {
+		/* this is also illegal */
+		/* RTW_INFO("marc: clnt auth failed due to illegal seq=%x\n", seq); */
 		goto authclnt_fail;
 	}
 
-	if (go2asoc)
-	{
-		DBG_871X_LEVEL(_drv_always_, "auth success, start assoc\n");
+	if (go2asoc) {
+#ifdef CONFIG_RTW_80211R
+		if (rtw_ft_update_auth_rsp_ies(padapter, pframe, pkt_len))
+			return _SUCCESS;
+#endif
+		RTW_PRINT("auth success, start assoc\n");
 		start_clnt_assoc(padapter);
 		return _SUCCESS;
 	}
 
 authclnt_fail:
 
-	//pmlmeinfo->state &= ~(WIFI_FW_AUTH_STATE);
+	/* pmlmeinfo->state &= ~(WIFI_FW_AUTH_STATE); */
 
 	return _FAIL;
 
@@ -2274,20 +2894,16 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 #ifdef CONFIG_AP_MODE
 	_irqL irqL;
 	u16 capab_info, listen_interval;
-	struct rtw_ieee802_11_elems elems;	
+	struct rtw_ieee802_11_elems elems;
 	struct sta_info	*pstat;
-	unsigned char		reassoc, *p, *pos, *wpa_ie;
-	unsigned char WMM_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01};
-	int		i, ie_len, wpa_ie_len, left;
-	u8 rate_set[16];
-	u8 rate_num;
+	unsigned char		reassoc, *p, *pos;
+	int		i, ie_len, left;
 	unsigned short		status = _STATS_SUCCESSFUL_;
-	unsigned short		frame_type, ie_offset=0;	
+	unsigned short		frame_type, ie_offset = 0;
 	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);	
-	WLAN_BSSID_EX 	*cur = &(pmlmeinfo->network);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX	*cur = &(pmlmeinfo->network);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	uint pkt_len = precv_frame->u.hdr.len;
@@ -2296,89 +2912,79 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 	u8 p2p_status_code = P2P_STATUS_SUCCESS;
 	u8 *p2pie;
 	u32 p2pielen = 0;
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if(((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE) &&
-		check_buddy_fwstate(padapter, _FW_UNDER_LINKING|_FW_UNDER_SURVEY))
-	{
-		//don't process assoc request;
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) &&
+	    rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | _FW_UNDER_SURVEY)) {
+		/* don't process assoc request; */
 		return _SUCCESS;
 	}
-#endif //CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_CONCURRENT_MODE */
 
-	if((pmlmeinfo->state&0x03) != WIFI_FW_AP_STATE)
+	if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
 		return _FAIL;
-	
-	frame_type = GetFrameSubType(pframe);
-	if (frame_type == WIFI_ASSOCREQ)
-	{
+
+	frame_type = get_frame_sub_type(pframe);
+	if (frame_type == WIFI_ASSOCREQ) {
 		reassoc = 0;
 		ie_offset = _ASOCREQ_IE_OFFSET_;
-	}	
-	else // WIFI_REASSOCREQ
-	{
+	} else { /* WIFI_REASSOCREQ */
 		reassoc = 1;
 		ie_offset = _REASOCREQ_IE_OFFSET_;
 	}
-	
+
 
 	if (pkt_len < IEEE80211_3ADDR_LEN + ie_offset) {
-		DBG_871X("handle_assoc(reassoc=%d) - too short payload (len=%lu)"
-		       "\n", reassoc, (unsigned long)pkt_len);
+		RTW_INFO("handle_assoc(reassoc=%d) - too short payload (len=%lu)"
+			 "\n", reassoc, (unsigned long)pkt_len);
 		return _FAIL;
 	}
-	
-	pstat = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));
-	if (pstat == (struct sta_info *)NULL)
-	{
+
+	pstat = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+	if (pstat == (struct sta_info *)NULL) {
 		status = _RSON_CLS2_;
 		goto asoc_class2_error;
 	}
 
-	capab_info = RTW_GET_LE16(pframe + WLAN_HDR_A3_LEN);
-	//capab_info = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));	
-	//listen_interval = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN+2));
-	listen_interval = RTW_GET_LE16(pframe + WLAN_HDR_A3_LEN+2);
-
-	left = pkt_len - (IEEE80211_3ADDR_LEN + ie_offset);
-	pos = pframe + (IEEE80211_3ADDR_LEN + ie_offset);
-	
-
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	// check if this stat has been successfully authenticated/assocated
-	if (!((pstat->state) & WIFI_FW_AUTH_SUCCESS))
-	{
-		if (!((pstat->state) & WIFI_FW_ASSOC_SUCCESS))
-		{
+	/* check if this stat has been successfully authenticated/assocated */
+	if (!((pstat->state) & WIFI_FW_AUTH_SUCCESS)) {
+		if (!((pstat->state) & WIFI_FW_ASSOC_SUCCESS)) {
 			status = _RSON_CLS2_;
 			goto asoc_class2_error;
-		}
-		else
-		{
+		} else {
 			pstat->state &= (~WIFI_FW_ASSOC_SUCCESS);
-			pstat->state |= WIFI_FW_ASSOC_STATE;				
+			pstat->state |= WIFI_FW_ASSOC_STATE;
 		}
-	}
-	else
-	{
+	} else {
 		pstat->state &= (~WIFI_FW_AUTH_SUCCESS);
 		pstat->state |= WIFI_FW_ASSOC_STATE;
 	}
 
-
-#if 0// todo:tkip_countermeasures
+#if 0/* todo:tkip_countermeasures */
 	if (hapd->tkip_countermeasures) {
 		resp = WLAN_REASON_MICHAEL_MIC_FAILURE;
 		goto fail;
 	}
 #endif
 
-	pstat->capability = capab_info;
+	/* now parse all ieee802_11 ie to point to elems */
+	left = pkt_len - (IEEE80211_3ADDR_LEN + ie_offset);
+	pos = pframe + (IEEE80211_3ADDR_LEN + ie_offset);
+	if (rtw_ieee802_11_parse_elems(pos, left, &elems, 1) == ParseFailed) {
+		RTW_INFO("STA " MAC_FMT " sent invalid association request\n",
+			 MAC_ARG(pstat->cmn.mac_addr));
+		status = _STATS_FAILURE_;
+		goto OnAssocReqFail;
+	}
+
+	rtw_ap_parse_sta_capability(padapter, pstat, pframe + WLAN_HDR_A3_LEN);
 
-#if 0//todo:
-	//check listen_interval
+	listen_interval = RTW_GET_LE16(pframe + WLAN_HDR_A3_LEN + 2);
+#if 0/* todo: */
+	/* check listen_interval */
 	if (listen_interval > hapd->conf->max_listen_interval) {
 		hostapd_logger(hapd, mgmt->sa, HOSTAPD_MODULE_IEEE80211,
 			       HOSTAPD_LEVEL_DEBUG,
@@ -2387,406 +2993,106 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 		resp = WLAN_STATUS_ASSOC_DENIED_LISTEN_INT_TOO_LARGE;
 		goto fail;
 	}
-	
+
 	pstat->listen_interval = listen_interval;
 #endif
 
-	//now parse all ieee802_11 ie to point to elems
-	if (rtw_ieee802_11_parse_elems(pos, left, &elems, 1) == ParseFailed ||
-	    !elems.ssid) {
-		DBG_871X("STA " MAC_FMT " sent invalid association request\n",
-		       MAC_ARG(pstat->hwaddr));
-		status = _STATS_FAILURE_;		
-		goto OnAssocReqFail;
-	}
-
-
-	// now we should check all the fields...
-	// checking SSID
-	p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + ie_offset, _SSID_IE_, &ie_len,
-		pkt_len - WLAN_HDR_A3_LEN - ie_offset);
-	if (p == NULL)
-	{
-		status = _STATS_FAILURE_;		
-	}
-
-	if (ie_len == 0) // broadcast ssid, however it is not allowed in assocreq
+	/* now we should check all the fields... */
+	/* checking SSID */
+	if (elems.ssid == NULL
+		|| elems.ssid_len == 0
+		|| elems.ssid_len != cur->Ssid.SsidLength
+		|| _rtw_memcmp(elems.ssid, cur->Ssid.Ssid, cur->Ssid.SsidLength) == _FALSE
+	) {
 		status = _STATS_FAILURE_;
-	else
-	{
-		// check if ssid match
-		if (!_rtw_memcmp((void *)(p+2), cur->Ssid.Ssid, cur->Ssid.SsidLength))
-			status = _STATS_FAILURE_;
-
-		if (ie_len != cur->Ssid.SsidLength)
-			status = _STATS_FAILURE_;
+		goto OnAssocReqFail;
 	}
 
-	if(_STATS_SUCCESSFUL_ != status)
+	/* (Extended) Supported rates */
+	status = rtw_ap_parse_sta_supported_rates(padapter, pstat
+		, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
+	if (status != _STATS_SUCCESSFUL_)
 		goto OnAssocReqFail;
 
-	rtw_ies_get_supported_rate(pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset, rate_set, &rate_num);
-	if (rate_num == 0) {
-		DBG_871X(FUNC_ADPT_FMT" RX assoc-req with no supported rate\n", FUNC_ADPT_ARG(padapter));
-		status = _STATS_FAILURE_;
+	/* check RSN/WPA/WPS */
+	status = rtw_ap_parse_sta_security_ie(padapter, pstat, &elems);
+	if (status != _STATS_SUCCESSFUL_)
 		goto OnAssocReqFail;
-	}
-	_rtw_memcpy(pstat->bssrateset, rate_set, rate_num);
-	pstat->bssratelen = rate_num;
-	UpdateBrateTblForSoftAP(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;
-	_rtw_memset(pstat->wpa_ie, 0, sizeof(pstat->wpa_ie));
-	if((psecuritypriv->wpa_psk & BIT(1)) && elems.rsn_ie) {
-
-		int group_cipher=0, pairwise_cipher=0;	
-		
-		wpa_ie = elems.rsn_ie;
-		wpa_ie_len = elems.rsn_ie_len;
-
-		if(rtw_parse_wpa2_ie(wpa_ie-2, wpa_ie_len+2, &group_cipher, &pairwise_cipher, NULL) == _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;
-			
-			if(!pstat->wpa2_group_cipher)
-				status = WLAN_STATUS_GROUP_CIPHER_NOT_VALID;
 
-			if(!pstat->wpa2_pairwise_cipher)
-				status = WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID;
-		}
-		else
-		{
-			status = WLAN_STATUS_INVALID_IE;
-		}	
-			
-	} else if ((psecuritypriv->wpa_psk & BIT(0)) && elems.wpa_ie) {
+	/* check if there is WMM IE & support WWM-PS */
+	rtw_ap_parse_sta_wmm_ie(padapter, pstat
+		, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
 
-		int group_cipher=0, pairwise_cipher=0;	
-		
-		wpa_ie = elems.wpa_ie;
-		wpa_ie_len = elems.wpa_ie_len;
+	rtw_ap_parse_sta_ht_ie(padapter, pstat, &elems);
+	rtw_ap_parse_sta_vht_ie(padapter, pstat, &elems);
 
-		if(rtw_parse_wpa_ie(wpa_ie-2, wpa_ie_len+2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS)
-		{
-			pstat->dot8021xalg = 1;//psk,  todo:802.1x						
-			pstat->wpa_psk |= BIT(0);
+	if (((pstat->flags & WLAN_STA_HT) || (pstat->flags & WLAN_STA_VHT)) &&
+	    ((pstat->wpa2_pairwise_cipher & WPA_CIPHER_TKIP) ||
+	     (pstat->wpa_pairwise_cipher & WPA_CIPHER_TKIP))) {
 
-			pstat->wpa_group_cipher = group_cipher&psecuritypriv->wpa_group_cipher;				
-			pstat->wpa_pairwise_cipher = pairwise_cipher&psecuritypriv->wpa_pairwise_cipher;
-			
-			if(!pstat->wpa_group_cipher)
-				status = WLAN_STATUS_GROUP_CIPHER_NOT_VALID;
+		RTW_INFO("(V)HT: " MAC_FMT " tried to use TKIP with (V)HT association\n", MAC_ARG(pstat->cmn.mac_addr));
 
-			if(!pstat->wpa_pairwise_cipher)
-				status = WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID;
-		
-		}
-		else
-		{
-			status = WLAN_STATUS_INVALID_IE;
-		}
-		
-	} else {
-		wpa_ie = NULL;
-		wpa_ie_len = 0;
+		pstat->flags &= ~WLAN_STA_HT;
+		pstat->flags &= ~WLAN_STA_VHT;
+		/*status = WLAN_STATUS_CIPHER_REJECTED_PER_POLICY;
+		  * goto OnAssocReqFail;
+		*/
 	}
 
-	if(_STATS_SUCCESSFUL_ != status)
-		goto OnAssocReqFail;
-
-	pstat->flags &= ~(WLAN_STA_WPS | WLAN_STA_MAYBE_WPS);
-	//if (hapd->conf->wps_state && wpa_ie == NULL) { //todo: to check ap if supporting WPS
-	if(wpa_ie == NULL) {
-		if (elems.wps_ie) {
-			DBG_871X("STA included WPS IE in "
-				   "(Re)Association Request - assume WPS is "
-				   "used\n");
-			pstat->flags |= WLAN_STA_WPS;
-			//wpabuf_free(sta->wps_ie);
-			//sta->wps_ie = wpabuf_alloc_copy(elems.wps_ie + 4,
-			//				elems.wps_ie_len - 4);
-		} else {
-			DBG_871X("STA did not include WPA/RSN IE "
-				   "in (Re)Association Request - possible WPS "
-				   "use\n");
-			pstat->flags |= WLAN_STA_MAYBE_WPS;
-		}
-
-
-		// AP support WPA/RSN, and sta is going to do WPS, but AP is not ready
-		// that the selected registrar of AP is _FLASE
-		if((psecuritypriv->wpa_psk >0)  
-			&& (pstat->flags & (WLAN_STA_WPS|WLAN_STA_MAYBE_WPS)))
-		{
-			if(pmlmepriv->wps_beacon_ie)
-			{	
-				u8 selected_registrar = 0;
-				
-				rtw_get_wps_attr_content(pmlmepriv->wps_beacon_ie, pmlmepriv->wps_beacon_ie_len, WPS_ATTR_SELECTED_REGISTRAR , &selected_registrar, NULL);
-
-				if(!selected_registrar)
-				{						
-					DBG_871X("selected_registrar is _FALSE , or AP is not ready to do WPS\n");
-						
-					status = _STATS_UNABLE_HANDLE_STA_;
-			
-					goto OnAssocReqFail;
-				}						
-			}			
-		}
-			
-	}
-	else
-	{
-		int copy_len;
-
-		if(psecuritypriv->wpa_psk == 0)
-		{
-			DBG_871X("STA " MAC_FMT ": WPA/RSN IE in association "
-		       	"request, but AP don't support WPA/RSN\n", MAC_ARG(pstat->hwaddr));
-			
-			status = WLAN_STATUS_INVALID_IE;
-			
-			goto OnAssocReqFail;
-
-		}
-
-		if (elems.wps_ie) {
-			DBG_871X("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)
-			_rtw_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->qospriv.qos_option) 
-	{
-		p = pframe + WLAN_HDR_A3_LEN + ie_offset; ie_len = 0;
-		for (;;) 
-		{
-			p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &ie_len, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
-			if (p != NULL) {
-				if (_rtw_memcmp(p+2, WMM_IE, 6)) {
-
-					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 + ie_len + 2;
-		}
-	}
-
-
-#ifdef CONFIG_80211N_HT
-	/* save HT capabilities in the sta object */
-	_rtw_memset(&pstat->htpriv.ht_cap, 0, sizeof(struct rtw_ieee80211_ht_cap));
-	if (elems.ht_capabilities && elems.ht_capabilities_len >= sizeof(struct rtw_ieee80211_ht_cap)) 
-	{
-		pstat->flags |= WLAN_STA_HT;
-		
-		pstat->flags |= WLAN_STA_WME;
-		
-		_rtw_memcpy(&pstat->htpriv.ht_cap, elems.ht_capabilities, sizeof(struct rtw_ieee80211_ht_cap));			
-		
-	} else
-		pstat->flags &= ~WLAN_STA_HT;
-
-	
-	if((pmlmepriv->htpriv.ht_option == _FALSE) && (pstat->flags&WLAN_STA_HT))
-	{
-		status = _STATS_FAILURE_;
-		goto OnAssocReqFail;
-	}
-		
-#endif /* CONFIG_80211N_HT */
-
-#ifdef CONFIG_80211AC_VHT
-	_rtw_memset(&pstat->vhtpriv, 0, sizeof(struct vht_priv));
-	if (elems.vht_capabilities && elems.vht_capabilities_len == 12) {
-		pstat->flags |= WLAN_STA_VHT;
-
-		_rtw_memcpy(pstat->vhtpriv.vht_cap, elems.vht_capabilities, 12);
-
-		if (elems.vht_op_mode_notify && elems.vht_op_mode_notify_len == 1) {
-			_rtw_memcpy(&pstat->vhtpriv.vht_op_mode_notify, elems.vht_op_mode_notify, 1);
-		}
-		else // for Frame without Operating Mode notify ie; default: 80M
-		{
-			pstat->vhtpriv.vht_op_mode_notify = CHANNEL_WIDTH_80;
-		}
-	}
-	else {
-		pstat->flags &= ~WLAN_STA_VHT;
-	}
-
-	if((pmlmepriv->vhtpriv.vht_option == _FALSE) && (pstat->flags&WLAN_STA_VHT))
-	{
-		status = _STATS_FAILURE_;
-		goto OnAssocReqFail;
-	}
-#endif /* CONFIG_80211AC_VHT */
-
-	if (((pstat->flags & WLAN_STA_HT) || (pstat->flags & WLAN_STA_VHT)) && 
-		((pstat->wpa2_pairwise_cipher & WPA_CIPHER_TKIP) || 
-		(pstat->wpa_pairwise_cipher & WPA_CIPHER_TKIP))) {
-
-		DBG_871X("(V)HT: " MAC_FMT " tried to use TKIP with (V)HT association\n", MAC_ARG(pstat->hwaddr));
-
-		pstat->flags &= ~WLAN_STA_HT;
-		pstat->flags &= ~WLAN_STA_VHT;
-		/*status = WLAN_STATUS_CIPHER_REJECTED_PER_POLICY;
-		  * goto OnAssocReqFail;
-		*/
-	}
-
-
-       //
-       //if (hapd->iface->current_mode->mode == HOSTAPD_MODE_IEEE80211G)//?
-	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 != _STATS_SUCCESSFUL_)
+	if (status != _STATS_SUCCESSFUL_)
 		goto OnAssocReqFail;
 
 #ifdef CONFIG_P2P
 	pstat->is_p2p_device = _FALSE;
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	{		
-		if( (p2pie=rtw_get_p2p_ie(pframe + WLAN_HDR_A3_LEN + ie_offset , pkt_len - WLAN_HDR_A3_LEN - ie_offset , NULL, &p2pielen)))
-		{
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		p2pie = rtw_get_p2p_ie(pframe + WLAN_HDR_A3_LEN + ie_offset , pkt_len - WLAN_HDR_A3_LEN - ie_offset , NULL, &p2pielen);
+		if (p2pie) {
 			pstat->is_p2p_device = _TRUE;
-			if((p2p_status_code=(u8)process_assoc_req_p2p_ie(pwdinfo, pframe, pkt_len, pstat))>0)
-			{
+			p2p_status_code = (u8)process_assoc_req_p2p_ie(pwdinfo, pframe, pkt_len, pstat);
+			if (p2p_status_code > 0) {
 				pstat->p2p_status_code = p2p_status_code;
 				status = _STATS_CAP_FAIL_;
 				goto OnAssocReqFail;
 			}
 		}
-		#ifdef CONFIG_WFD
+#ifdef CONFIG_WFD
 		rtw_process_wfd_ies(padapter, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset, __func__);
-		#endif
+#endif
 	}
 	pstat->p2p_status_code = p2p_status_code;
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
-	//TODO: identify_proprietary_vendor_ie();
-	// Realtek proprietary IE
-	// identify if this is Broadcom sta
-	// identify if this is ralink sta
-	// Customer proprietary IE
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (rtw_rson_ap_check_sta(padapter, pframe, pkt_len, ie_offset))
+		goto OnAssocReqFail;
+#endif
 
-	
+	/* 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_871X("  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) {
-				if (pstat->aid > pstapriv->max_num_sta) {
-					pstat->aid = 0;
-				
-					DBG_871X("  no room for more AIDs\n");
+#ifdef CONFIG_RTW_80211K
+	rtw_ap_parse_sta_rm_en_cap(padapter, pstat, &elems);
+#endif
 
-					status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
-				
-					goto OnAssocReqFail;
-				
-			
-				} else {
-					pstapriv->sta_aid[pstat->aid - 1] = pstat;
-					DBG_871X("allocate new AID = (%d)\n", pstat->aid);
-					break;
-				}				
-			}
-		}	
+	/* AID assignment */
+	if (pstat->cmn.aid > 0)
+		RTW_INFO(FUNC_ADPT_FMT" old AID=%d\n", FUNC_ADPT_ARG(padapter), pstat->cmn.aid);
+	else {
+		if (!rtw_aid_alloc(padapter, pstat)) {
+			RTW_INFO(FUNC_ADPT_FMT" no room for more AIDs\n", FUNC_ADPT_ARG(padapter));
+			status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
+			goto OnAssocReqFail;
+		}
+		RTW_INFO(FUNC_ADPT_FMT" allocate new AID=%d\n", FUNC_ADPT_ARG(padapter), pstat->cmn.aid);
 	}
 
-
-	pstat->state &= (~WIFI_FW_ASSOC_STATE);	
+	pstat->state &= (~WIFI_FW_ASSOC_STATE);
 	pstat->state |= WIFI_FW_ASSOC_SUCCESS;
-	/* DBG_871X("==================%s, %d,  (%x), bpairwise_key_installed=%d, MAC:"MAC_FMT"\n"
-	, __func__, __LINE__, pstat->state, pstat->bpairwise_key_installed, MAC_ARG(pstat->hwaddr)); */
+	/* RTW_INFO("==================%s, %d,  (%x), bpairwise_key_installed=%d, MAC:"MAC_FMT"\n"
+	, __func__, __LINE__, pstat->state, pstat->bpairwise_key_installed, MAC_ARG(pstat->cmn.mac_addr)); */
 #ifdef CONFIG_IEEE80211W
 	if (pstat->bpairwise_key_installed != _TRUE)
 #endif /* CONFIG_IEEE80211W */
@@ -2797,8 +3103,8 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 			pstapriv->auth_list_cnt--;
 		}
 		_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
-	
-		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);	
+
+		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 		if (rtw_is_list_empty(&pstat->asoc_list)) {
 			pstat->expire_to = pstapriv->expire_to;
 			rtw_list_insert_tail(&pstat->asoc_list, &pstapriv->asoc_list);
@@ -2807,9 +3113,8 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 		_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 	}
 
-	// now the station is qualified to join our BSS...	
-	if(pstat && (pstat->state & WIFI_FW_ASSOC_SUCCESS) && (_STATS_SUCCESSFUL_==status))
-	{
+	/* now the station is qualified to join our BSS...	 */
+	if (pstat && (pstat->state & WIFI_FW_ASSOC_SUCCESS) && (_STATS_SUCCESSFUL_ == status)) {
 #ifdef CONFIG_NATIVEAP_MLME
 #ifdef CONFIG_IEEE80211W
 		if (pstat->bpairwise_key_installed != _TRUE)
@@ -2823,7 +3128,7 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 		if (pstat->bpairwise_key_installed == _TRUE)
 			status = _STATS_REFUSED_TEMPORARILY_;
 #endif /* CONFIG_IEEE80211W */
-		//.2 issue assoc rsp before notify station join event.
+		/* .2 issue assoc rsp before notify station join event. */
 		if (frame_type == WIFI_ASSOCREQ)
 			issue_asocrsp(padapter, status, pstat, WIFI_ASSOCRSP);
 		else
@@ -2831,35 +3136,33 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 
 #ifdef CONFIG_IOCTL_CFG80211
 		_enter_critical_bh(&pstat->lock, &irqL);
-		if(pstat->passoc_req)
-		{
+		if (pstat->passoc_req) {
 			rtw_mfree(pstat->passoc_req, pstat->assoc_req_len);
 			pstat->passoc_req = NULL;
 			pstat->assoc_req_len = 0;
 		}
 
 		pstat->passoc_req =  rtw_zmalloc(pkt_len);
-		if(pstat->passoc_req)
-		{
+		if (pstat->passoc_req) {
 			_rtw_memcpy(pstat->passoc_req, pframe, pkt_len);
 			pstat->assoc_req_len = pkt_len;
 		}
 		_exit_critical_bh(&pstat->lock, &irqL);
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 #ifdef CONFIG_IEEE80211W
 		if (pstat->bpairwise_key_installed != _TRUE)
 #endif /* CONFIG_IEEE80211W */
 		{
 			/* .3-(1) report sta add event */
-			report_add_sta_event(padapter, pstat->hwaddr);
+			report_add_sta_event(padapter, pstat->cmn.mac_addr);
 		}
 #ifdef CONFIG_IEEE80211W
-		if (pstat->bpairwise_key_installed == _TRUE && padapter->securitypriv.binstallBIPkey == _TRUE) {
-			DBG_871X(MAC_FMT"\n", MAC_ARG(pstat->hwaddr));
-			issue_action_SA_Query(padapter, pstat->hwaddr, 0, 0, IEEE80211W_RIGHT_KEY);
+		if (pstat->bpairwise_key_installed == _TRUE && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
+			RTW_INFO(MAC_FMT"\n", MAC_ARG(pstat->cmn.mac_addr));
+			issue_action_SA_Query(padapter, pstat->cmn.mac_addr, 0, 0, IEEE80211W_RIGHT_KEY);
 		}
 #endif /* CONFIG_IEEE80211W */
-#endif //CONFIG_NATIVEAP_MLME
+#endif /* CONFIG_NATIVEAP_MLME */
 	}
 
 	return _SUCCESS;
@@ -2867,16 +3170,16 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 asoc_class2_error:
 
 #ifdef CONFIG_NATIVEAP_MLME
-	issue_deauth(padapter, (void *)GetAddr2Ptr(pframe), status);
+	issue_deauth(padapter, (void *)get_addr2_ptr(pframe), status);
 #endif
 
-	return _FAIL;		
+	return _FAIL;
 
 OnAssocReqFail:
 
 
 #ifdef CONFIG_NATIVEAP_MLME
-	pstat->aid = 0;
+	pstat->cmn.aid = 0;
 	if (frame_type == WIFI_ASSOCREQ)
 		issue_asocrsp(padapter, status, pstat, WIFI_ASSOCRSP);
 	else
@@ -2886,9 +3189,37 @@ OnAssocReqFail:
 
 #endif /* CONFIG_AP_MODE */
 
-	return _FAIL;		
+	return _FAIL;
+
+}
+
+#if defined(CONFIG_LAYER2_ROAMING) && defined(CONFIG_RTW_80211K)
+void rtw_roam_nb_discover(_adapter *padapter, u8 bfroce)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);	
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta;
+	u8 nb_req_issue = _FALSE;
+
+	if (!check_fwstate(pmlmepriv, _FW_LINKED))
+		return;
+
+	if (!rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE))
+		return;
 
+	psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
+	if (!psta)
+		return;
+	
+	if (bfroce || (!pmlmepriv->nb_info.nb_rpt_is_same))
+		nb_req_issue = _TRUE;
+	
+	if (nb_req_issue && (psta->rm_en_cap[0] & RTW_RRM_NB_RPT_EN)) 
+		rm_add_nb_req(padapter, psta);
 }
+#endif
 
 unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 {
@@ -2899,18 +3230,18 @@ unsigned int OnAssocRsp(_adapter *padapter, union 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);
-	//WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	/* WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network); */
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	uint pkt_len = precv_frame->u.hdr.len;
 	PNDIS_802_11_VARIABLE_IEs	pWapiIE = NULL;
 
-	DBG_871X("%s\n", __FUNCTION__);
-	
-	//check A1 matches or not
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	/* check A1 matches or not */
 	if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
 		return _SUCCESS;
 
-	if (!(pmlmeinfo->state & (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE)))
+	if (!(pmlmeinfo->state & (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE)) || pmlmeext->join_abort)
 		return _SUCCESS;
 
 	if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
@@ -2918,83 +3249,83 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 
 	_cancel_timer_ex(&pmlmeext->link_timer);
 
-	//status
-	if ((status = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 2))) > 0)
-	{
-		DBG_871X("assoc reject, status code: %d\n", status);
+	/* status */
+	status = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 2));
+	if (status > 0) {
+		RTW_INFO("assoc reject, status code: %d\n", status);
 		pmlmeinfo->state = WIFI_FW_NULL_STATE;
 		res = -4;
 		goto report_assoc_result;
 	}
 
-	//get capabilities
+	/* get capabilities */
 	pmlmeinfo->capability = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
 
-	//set slot time
-	pmlmeinfo->slotTime = (pmlmeinfo->capability & BIT(10))? 9: 20;
+	/* set slot time */
+	pmlmeinfo->slotTime = (pmlmeinfo->capability & BIT(10)) ? 9 : 20;
 
-	//AID
-	res = pmlmeinfo->aid = (int)(le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 4))&0x3fff);
+	/* AID */
+	res = pmlmeinfo->aid = (int)(le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 4)) & 0x3fff);
 
-	//following are moved to join event callback function
-	//to handle HT, WMM, rate adaptive, update MAC reg
-	//for not to handle the synchronous IO in the tasklet
-	for (i = (6 + WLAN_HDR_A3_LEN); i < pkt_len;)
-	{
+	/* following are moved to join event callback function */
+	/* to handle HT, WMM, rate adaptive, update MAC reg */
+	/* for not to handle the synchronous IO in the tasklet */
+	for (i = (6 + WLAN_HDR_A3_LEN); i < pkt_len;) {
 		pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + i);
 
-		switch (pIE->ElementID)
-		{
-			case _VENDOR_SPECIFIC_IE_:
-				if (_rtw_memcmp(pIE->data, WMM_PARA_OUI, 6))	//WMM
-				{
-					WMM_param_handler(padapter, pIE);
-				}
+		switch (pIE->ElementID) {
+		case _VENDOR_SPECIFIC_IE_:
+			if (_rtw_memcmp(pIE->data, WMM_PARA_OUI, 6))	/* WMM */
+				WMM_param_handler(padapter, pIE);
 #if defined(CONFIG_P2P) && defined(CONFIG_WFD)
-				else if ( _rtw_memcmp(pIE->data, WFD_OUI, 4))		//WFD
-				{
-					rtw_process_wfd_ie(padapter, (u8 *)pIE, pIE->Length, __func__);
-				}
-#endif				
-				break;
+			else if (_rtw_memcmp(pIE->data, WFD_OUI, 4))		/* WFD */
+				rtw_process_wfd_ie(padapter, (u8 *)pIE, pIE->Length, __func__);
+#endif
+			break;
 
 #ifdef CONFIG_WAPI_SUPPORT
-			case _WAPI_IE_:
-				pWapiIE = pIE;
-				break;
+		case _WAPI_IE_:
+			pWapiIE = pIE;
+			break;
 #endif
 
-			case _HT_CAPABILITY_IE_:	//HT caps
-				HT_caps_handler(padapter, pIE);
-				break;
+		case _HT_CAPABILITY_IE_:	/* HT caps */
+			HT_caps_handler(padapter, pIE);
+			break;
 
-			case _HT_EXTRA_INFO_IE_:	//HT info
-				HT_info_handler(padapter, pIE);
-				break;
+		case _HT_EXTRA_INFO_IE_:	/* HT info */
+			HT_info_handler(padapter, pIE);
+			break;
 
 #ifdef CONFIG_80211AC_VHT
-			case EID_VHTCapability:
-				VHT_caps_handler(padapter, pIE);
-				break;
+		case EID_VHTCapability:
+			VHT_caps_handler(padapter, pIE);
+			break;
 
-			case EID_VHTOperation:
-				VHT_operation_handler(padapter, pIE);
-				break;
+		case EID_VHTOperation:
+			VHT_operation_handler(padapter, pIE);
+			break;
 #endif
 
-			case _ERPINFO_IE_:
-				ERP_IE_handler(padapter, pIE);
-				break;
+		case _ERPINFO_IE_:
+			ERP_IE_handler(padapter, pIE);
+			break;
 #ifdef CONFIG_TDLS
-			case _EXT_CAP_IE_:
-				if (check_ap_tdls_prohibited(pIE->data, pIE->Length) == _TRUE)
-					padapter->tdlsinfo.ap_prohibited = _TRUE;
-				if (check_ap_tdls_ch_switching_prohibited(pIE->data, pIE->Length) == _TRUE)
-					padapter->tdlsinfo.ch_switch_prohibited = _TRUE;
-				break;
+		case _EXT_CAP_IE_:
+			if (check_ap_tdls_prohibited(pIE->data, pIE->Length) == _TRUE)
+				padapter->tdlsinfo.ap_prohibited = _TRUE;
+			if (check_ap_tdls_ch_switching_prohibited(pIE->data, pIE->Length) == _TRUE)
+				padapter->tdlsinfo.ch_switch_prohibited = _TRUE;
+			break;
 #endif /* CONFIG_TDLS */
-			default:
-				break;
+
+#ifdef CONFIG_RTW_80211K
+		case _EID_RRM_EN_CAP_IE_:
+			RM_IE_handler(padapter, pIE);
+			break;
+#endif
+		default:
+			break;
 		}
 
 		i += (pIE->Length + 2);
@@ -3007,18 +3338,20 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 	pmlmeinfo->state &= (~WIFI_FW_ASSOC_STATE);
 	pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
 
-	//Update Basic Rate Table for spec, 2010-12-28 , by thomas
+	/* Update Basic Rate Table for spec, 2010-12-28 , by thomas */
 	UpdateBrateTbl(padapter, pmlmeinfo->network.SupportedRates);
 
 report_assoc_result:
-	if (res > 0) {
+	if (res > 0)
 		rtw_buf_update(&pmlmepriv->assoc_rsp, &pmlmepriv->assoc_rsp_len, pframe, pkt_len);
-	} else {
+	else
 		rtw_buf_free(&pmlmepriv->assoc_rsp, &pmlmepriv->assoc_rsp_len);
-	}
 
-	report_join_res(padapter, res);
+	report_join_res(padapter, res, status);
 
+#if defined(CONFIG_LAYER2_ROAMING) && defined(CONFIG_RTW_80211K)
+	rtw_roam_nb_discover(padapter, _TRUE);
+#endif
 	return _SUCCESS;
 }
 
@@ -3030,49 +3363,43 @@ unsigned int OnDeAuth(_adapter *padapter, union recv_frame *precv_frame)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 #ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif //CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 
-	//check A3
+	/* check A3 */
 	if (!(_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)))
 		return _SUCCESS;
 
-	DBG_871X(FUNC_ADPT_FMT" - Start to Disconnect\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO(FUNC_ADPT_FMT" - Start to Disconnect\n", FUNC_ADPT_ARG(padapter));
 
 #ifdef CONFIG_P2P
-	if ( pwdinfo->rx_invitereq_info.scan_op_ch_only )
-	{
-		_cancel_timer_ex( &pwdinfo->reset_ch_sitesurvey );
-		_set_timer( &pwdinfo->reset_ch_sitesurvey, 10 );
+	if (pwdinfo->rx_invitereq_info.scan_op_ch_only) {
+		_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
+		_set_timer(&pwdinfo->reset_ch_sitesurvey, 10);
 	}
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 	reason = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
 
-	rtw_lock_rx_suspend_timeout(8000);
-
 #ifdef CONFIG_AP_MODE
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{		
+	if (MLME_IS_AP(padapter)) {
 		_irqL irqL;
 		struct sta_info *psta;
 		struct sta_priv *pstapriv = &padapter->stapriv;
-		
-		//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
-		//rtw_free_stainfo(padapter, psta);
-		//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
 
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
-			, FUNC_ADPT_ARG(padapter), reason, GetAddr2Ptr(pframe));
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
+		/* rtw_free_stainfo(padapter, psta); */
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
 
-		psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));	
-		if(psta)
-		{
+		RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
+			, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe));
+
+		psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+		if (psta) {
 			u8 updated = _FALSE;
-		
+
 			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-			if(rtw_is_list_empty(&psta->asoc_list)==_FALSE)
-			{			
+			if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
 				rtw_list_delete(&psta->asoc_list);
 				pstapriv->asoc_list_cnt--;
 				updated = ap_free_sta(padapter, psta, _FALSE, reason, _TRUE);
@@ -3082,40 +3409,35 @@ unsigned int OnDeAuth(_adapter *padapter, union recv_frame *precv_frame)
 
 			associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
 		}
-		
+
 
 		return _SUCCESS;
-	}
-	else
+	} else
 #endif
-	{
+	if (!MLME_IS_MESH(padapter)) {
 		int	ignore_received_deauth = 0;
 
-		//	Commented by Albert 20130604
-		//	Before sending the auth frame to start the STA/GC mode connection with AP/GO, 
-		//	we will send the deauth first.
-		//	However, the Win8.1 with BRCM Wi-Fi will send the deauth with reason code 6 to us after receieving our deauth.
-		//	Added the following code to avoid this case.
-		if ( ( pmlmeinfo->state & WIFI_FW_AUTH_STATE ) ||
-			( pmlmeinfo->state & WIFI_FW_ASSOC_STATE ) )
-		{
-			if ( reason == WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA )
-			{
+		/*	Commented by Albert 20130604 */
+		/*	Before sending the auth frame to start the STA/GC mode connection with AP/GO,  */
+		/*	we will send the deauth first. */
+		/*	However, the Win8.1 with BRCM Wi-Fi will send the deauth with reason code 6 to us after receieving our deauth. */
+		/*	Added the following code to avoid this case. */
+		if ((pmlmeinfo->state & WIFI_FW_AUTH_STATE) ||
+		    (pmlmeinfo->state & WIFI_FW_ASSOC_STATE)) {
+			if (reason == WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA)
 				ignore_received_deauth = 1;
-			} else if (WLAN_REASON_PREV_AUTH_NOT_VALID == reason) {
-				// TODO: 802.11r
+			else if (WLAN_REASON_PREV_AUTH_NOT_VALID == reason) {
+				/* TODO: 802.11r */
 				ignore_received_deauth = 1;
 			}
 		}
 
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" reason=%u, ta=%pM, ignore=%d\n"
-			, FUNC_ADPT_ARG(padapter), reason, GetAddr2Ptr(pframe), ignore_received_deauth);
+		RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM, ignore=%d\n"
+			, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe), ignore_received_deauth);
 
-		if ( 0 == ignore_received_deauth )
-		{
-			receive_disconnect(padapter, GetAddr2Ptr(pframe), reason, _FALSE);
-		}
-	}	
+		if (0 == ignore_received_deauth)
+			receive_disconnect(padapter, get_addr2_ptr(pframe), reason, _FALSE);
+	}
 	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
 	return _SUCCESS;
 
@@ -3129,53 +3451,47 @@ unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 #ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif //CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 
-	//check A3
+	/* check A3 */
 	if (!(_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)))
 		return _SUCCESS;
 
-	DBG_871X(FUNC_ADPT_FMT" - Start to Disconnect\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO(FUNC_ADPT_FMT" - Start to Disconnect\n", FUNC_ADPT_ARG(padapter));
 
 #ifdef CONFIG_P2P
-	if ( pwdinfo->rx_invitereq_info.scan_op_ch_only )
-	{
-		_cancel_timer_ex( &pwdinfo->reset_ch_sitesurvey );
-		_set_timer( &pwdinfo->reset_ch_sitesurvey, 10 );
+	if (pwdinfo->rx_invitereq_info.scan_op_ch_only) {
+		_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
+		_set_timer(&pwdinfo->reset_ch_sitesurvey, 10);
 	}
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 	reason = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
 
-	rtw_lock_rx_suspend_timeout(8000);
-	
 #ifdef CONFIG_AP_MODE
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{	
+	if (MLME_IS_AP(padapter)) {
 		_irqL irqL;
 		struct sta_info *psta;
 		struct sta_priv *pstapriv = &padapter->stapriv;
-		
-		//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);	
-		//rtw_free_stainfo(padapter, psta);
-		//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
 
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
-			, FUNC_ADPT_ARG(padapter), reason, GetAddr2Ptr(pframe));
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);	 */
+		/* rtw_free_stainfo(padapter, psta); */
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
 
-		psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));	
-		if(psta)
-		{
+		RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
+			, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe));
+
+		psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+		if (psta) {
 			u8 updated = _FALSE;
-			
+
 			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-			if(rtw_is_list_empty(&psta->asoc_list)==_FALSE)
-			{
+			if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
 				rtw_list_delete(&psta->asoc_list);
 				pstapriv->asoc_list_cnt--;
 				updated = ap_free_sta(padapter, psta, _FALSE, reason, _TRUE);
-			
+
 			}
 			_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 
@@ -3183,15 +3499,14 @@ unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame)
 		}
 
 		return _SUCCESS;
-	}
-	else
+	} else
 #endif
-	{
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
-			, FUNC_ADPT_ARG(padapter), reason, GetAddr2Ptr(pframe));
+	if (!MLME_IS_MESH(padapter)) {
+		RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
+			, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe));
 
-		receive_disconnect(padapter, GetAddr2Ptr(pframe), reason, _FALSE);
-	}	
+		receive_disconnect(padapter, get_addr2_ptr(pframe), reason, _FALSE);
+	}
 	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
 	return _SUCCESS;
 
@@ -3199,7 +3514,7 @@ unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame)
 
 unsigned int OnAtim(_adapter *padapter, union recv_frame *precv_frame)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 	return _SUCCESS;
 }
 
@@ -3210,31 +3525,30 @@ unsigned int on_action_spct_ch_switch(_adapter *padapter, struct sta_info *psta,
 	struct mlme_ext_info	*pmlmeinfo = &(mlmeext->mlmext_info);
 
 	if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
-		ret = _SUCCESS;	
+		ret = _SUCCESS;
 		goto exit;
 	}
 
 	if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) {
-		
+
 		int ch_switch_mode = -1, ch = -1, ch_switch_cnt = -1;
 		int ch_offset = -1;
 		u8 bwmode;
 		struct ieee80211_info_element *ie;
 
-		DBG_871X(FUNC_NDEV_FMT" from "MAC_FMT"\n",
-			FUNC_NDEV_ARG(padapter->pnetdev), MAC_ARG(psta->hwaddr));
+		RTW_INFO(FUNC_NDEV_FMT" from "MAC_FMT"\n",
+			FUNC_NDEV_ARG(padapter->pnetdev), MAC_ARG(psta->cmn.mac_addr));
 
 		for_each_ie(ie, ies, ies_len) {
 			if (ie->id == WLAN_EID_CHANNEL_SWITCH) {
 				ch_switch_mode = ie->data[0];
 				ch = ie->data[1];
 				ch_switch_cnt = ie->data[2];
-				DBG_871X("ch_switch_mode:%d, ch:%d, ch_switch_cnt:%d\n",
-					ch_switch_mode, ch, ch_switch_cnt);
-			}
-			else if (ie->id == WLAN_EID_SECONDARY_CHANNEL_OFFSET) {
+				RTW_INFO("ch_switch_mode:%d, ch:%d, ch_switch_cnt:%d\n",
+					 ch_switch_mode, ch, ch_switch_cnt);
+			} else if (ie->id == WLAN_EID_SECONDARY_CHANNEL_OFFSET) {
 				ch_offset = secondary_ch_offset_to_hal_ch_offset(ie->data[0]);
-				DBG_871X("ch_offset:%d\n", ch_offset);
+				RTW_INFO("ch_offset:%d\n", ch_offset);
 			}
 		}
 
@@ -3245,7 +3559,7 @@ unsigned int on_action_spct_ch_switch(_adapter *padapter, struct sta_info *psta,
 			bwmode = mlmeext->cur_bwmode;
 		else
 			bwmode = (ch_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) ?
-				CHANNEL_WIDTH_20 : CHANNEL_WIDTH_40;
+				 CHANNEL_WIDTH_20 : CHANNEL_WIDTH_40;
 
 		ch_offset = (ch_offset == -1) ? mlmeext->cur_ch_offset : ch_offset;
 
@@ -3254,7 +3568,7 @@ unsigned int on_action_spct_ch_switch(_adapter *padapter, struct sta_info *psta,
 		 * 2. things after channel switching
 		 */
 
-		ret = rtw_set_ch_cmd(padapter, ch, bwmode, ch_offset, _TRUE);
+		ret = rtw_set_chbw_cmd(padapter, ch, bwmode, ch_offset, 0);
 	}
 
 exit:
@@ -3272,18 +3586,19 @@ unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame)
 	u8 category;
 	u8 action;
 
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(padapter->pnetdev));
-
-	psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));
+	psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
 
 	if (!psta)
 		goto exit;
 
 	category = frame_body[0];
-	if(category != RTW_WLAN_CATEGORY_SPECTRUM_MGMT)
+	if (category != RTW_WLAN_CATEGORY_SPECTRUM_MGMT)
 		goto exit;
 
 	action = frame_body[1];
+
+	RTW_INFO(FUNC_ADPT_FMT" action:%u\n", FUNC_ADPT_ARG(padapter), action);
+
 	switch (action) {
 	case RTW_WLAN_ACTION_SPCT_MSR_REQ:
 	case RTW_WLAN_ACTION_SPCT_MSR_RPRT:
@@ -3291,10 +3606,15 @@ unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame)
 	case RTW_WLAN_ACTION_SPCT_TPC_RPRT:
 		break;
 	case RTW_WLAN_ACTION_SPCT_CHL_SWITCH:
-		#ifdef CONFIG_SPCT_CH_SWITCH
-		ret = on_action_spct_ch_switch(padapter, psta, &frame_body[2],
-			frame_len-(frame_body-pframe)-2);
-		#endif
+#ifdef CONFIG_SPCT_CH_SWITCH
+		ret = on_action_spct_ch_switch(padapter, psta
+				, frame_body + 2, frame_len - (frame_body - pframe) - 2);
+#elif defined(CONFIG_DFS)
+		if (MLME_IS_STA(padapter) && MLME_IS_ASOC(padapter)) {
+			process_csa_ie(padapter
+				, frame_body + 2, frame_len - (frame_body - pframe) - 2);
+		}
+#endif
 		break;
 	default:
 		break;
@@ -3314,22 +3634,66 @@ unsigned int OnAction_dls(_adapter *padapter, union recv_frame *precv_frame)
 	return _SUCCESS;
 }
 
-/**
- * rtw_rx_ampdu_size - Get the target RX AMPDU buffer size for the specific @adapter
- * @adapter: the adapter to get target RX AMPDU buffer size
- *
- * Returns: the target RX AMPDU buffer size
- */
-u8 rtw_rx_ampdu_size(_adapter *adapter)
+#ifdef CONFIG_RTW_WNM
+unsigned int on_action_wnm(_adapter *adapter, union recv_frame *rframe)
 {
-	u8 size;
-	HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor;
+	unsigned int ret = _FAIL;
+	struct sta_info *sta = NULL;
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	struct sta_priv *stapriv = &(adapter->stapriv);
+	u8 *frame = rframe->u.hdr.rx_data;
+	u32 frame_len = rframe->u.hdr.len;
+	u8 *frame_body = (u8 *)(frame + sizeof(struct rtw_ieee80211_hdr_3addr));
+	u32 frame_body_len = frame_len - sizeof(struct rtw_ieee80211_hdr_3addr);	
+	u8 category, action;
+	int cnt = 0;
+	char msg[16];
 
-	if (adapter->fix_rx_ampdu_size != RX_AMPDU_SIZE_INVALID) {
-		size = adapter->fix_rx_ampdu_size;
+	sta = rtw_get_stainfo(stapriv, get_addr2_ptr(frame));
+	if (!sta)
 		goto exit;
+
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_WNM)
+		goto exit;
+
+	action = frame_body[1];
+
+	switch (action) {
+#ifdef CONFIG_RTW_80211R
+	case RTW_WLAN_ACTION_WNM_BTM_REQ:
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+			RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_REQ recv.\n");
+			rtw_wnm_process_btm_req(adapter, frame_body, frame_body_len);
+		}
+		ret = _SUCCESS;
+		break;
+#endif		
+	default:
+		#ifdef CONFIG_IOCTL_CFG80211
+		cnt += sprintf((msg + cnt), "ACT_WNM %u", action);
+		rtw_cfg80211_rx_action(adapter, rframe, msg);
+		#endif
+		ret = _SUCCESS;
+		break;
 	}
 
+exit:
+	return ret;
+}
+#endif /* CONFIG_RTW_WNM */
+
+/**
+ * rtw_rx_ampdu_size - Get the target RX AMPDU buffer size for the specific @adapter
+ * @adapter: the adapter to get target RX AMPDU buffer size
+ *
+ * Returns: the target RX AMPDU buffer size
+ */
+u8 rtw_rx_ampdu_size(_adapter *adapter)
+{
+	u8 size;
+	HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor;
+
 #ifdef CONFIG_BT_COEXIST
 	if (rtw_btcoex_IsBTCoexCtrlAMPDUSize(adapter) == _TRUE) {
 		size = rtw_btcoex_GetAMPDUSize(adapter);
@@ -3339,9 +3703,9 @@ u8 rtw_rx_ampdu_size(_adapter *adapter)
 
 	/* for scan */
 	if (!mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_DISABLE)
-		&& !mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_COMPLETE)
-		&& adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_size != RX_AMPDU_SIZE_INVALID
-	) {
+	    && !mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_COMPLETE)
+	    && adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_size != RX_AMPDU_SIZE_INVALID
+	   ) {
 		size = adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_size;
 		goto exit;
 	}
@@ -3351,7 +3715,14 @@ u8 rtw_rx_ampdu_size(_adapter *adapter)
 		max_rx_ampdu_factor = (HT_CAP_AMPDU_FACTOR)adapter->driver_rx_ampdu_factor;
 	else
 		rtw_hal_get_def_var(adapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
-
+	
+	/* In Maximum A-MPDU Length Exponent subfield of A-MPDU Parameters field of HT Capabilities element,
+		the unit of max_rx_ampdu_factor are octets. 8K, 16K, 32K, 64K is right.
+		But the buffer size subfield of Block Ack Parameter Set field in ADDBA action frame indicates
+		the number of buffers available for this particular TID. Each buffer is equal to max. size of 
+		MSDU or AMSDU. 
+		The size variable means how many MSDUs or AMSDUs, it's not Kbytes.
+	*/
 	if (MAX_AMPDU_FACTOR_64K == max_rx_ampdu_factor)
 		size = 64;
 	else if (MAX_AMPDU_FACTOR_32K == max_rx_ampdu_factor)
@@ -3395,9 +3766,9 @@ bool rtw_rx_ampdu_is_accept(_adapter *adapter)
 
 	/* for scan */
 	if (!mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_DISABLE)
-		&& !mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_COMPLETE)
-		&& adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept != RX_AMPDU_ACCEPT_INVALID
-	) {
+	    && !mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_COMPLETE)
+	    && adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept != RX_AMPDU_ACCEPT_INVALID
+	   ) {
 		accept = adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept;
 		goto exit;
 	}
@@ -3430,7 +3801,7 @@ bool rtw_rx_ampdu_set_size(_adapter *adapter, u8 size, u8 reason)
 		if (adapter->fix_rx_ampdu_size != size) {
 			adapter->fix_rx_ampdu_size = size;
 			is_adj = _TRUE;
-			DBG_871X(FUNC_ADPT_FMT" fix_rx_ampdu_size:%u\n", FUNC_ADPT_ARG(adapter), size);
+			RTW_INFO(FUNC_ADPT_FMT" fix_rx_ampdu_size:%u\n", FUNC_ADPT_ARG(adapter), size);
 		}
 	} else if (reason == RX_AMPDU_DRV_SCAN) {
 		struct ss_res *ss = &adapter->mlmeextpriv.sitesurvey_res;
@@ -3438,7 +3809,7 @@ bool rtw_rx_ampdu_set_size(_adapter *adapter, u8 size, u8 reason)
 		if (ss->rx_ampdu_size != size) {
 			ss->rx_ampdu_size = size;
 			is_adj = _TRUE;
-			DBG_871X(FUNC_ADPT_FMT" ss.rx_ampdu_size:%u\n", FUNC_ADPT_ARG(adapter), size);
+			RTW_INFO(FUNC_ADPT_FMT" ss.rx_ampdu_size:%u\n", FUNC_ADPT_ARG(adapter), size);
 		}
 	}
 
@@ -3466,13 +3837,13 @@ bool rtw_rx_ampdu_set_accept(_adapter *adapter, u8 accept, u8 reason)
 		if (adapter->fix_rx_ampdu_accept != accept) {
 			adapter->fix_rx_ampdu_accept = accept;
 			is_adj = _TRUE;
-			DBG_871X(FUNC_ADPT_FMT" fix_rx_ampdu_accept:%u\n", FUNC_ADPT_ARG(adapter), accept);
+			RTW_INFO(FUNC_ADPT_FMT" fix_rx_ampdu_accept:%u\n", FUNC_ADPT_ARG(adapter), accept);
 		}
 	} else if (reason == RX_AMPDU_DRV_SCAN) {
 		if (adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept != accept) {
 			adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept = accept;
 			is_adj = _TRUE;
-			DBG_871X(FUNC_ADPT_FMT" ss.rx_ampdu_accept:%u\n", FUNC_ADPT_ARG(adapter), accept);
+			RTW_INFO(FUNC_ADPT_FMT" ss.rx_ampdu_accept:%u\n", FUNC_ADPT_ARG(adapter), accept);
 		}
 	}
 
@@ -3520,6 +3891,35 @@ exit:
 	return ret;
 }
 
+u8 rx_ampdu_size_sta_limit(_adapter *adapter, struct sta_info *sta)
+{
+	u8 sz_limit = 0xFF;
+
+#ifdef CONFIG_80211N_HT
+	struct registry_priv *regsty = adapter_to_regsty(adapter);
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct mlme_ext_info *mlmeinfo = &adapter->mlmeextpriv.mlmext_info;
+	s8 nss = -1;
+	u8 bw = rtw_min(sta->cmn.bw_mode, adapter->mlmeextpriv.cur_bwmode);
+
+	#ifdef CONFIG_80211AC_VHT
+	if (is_supported_vht(sta->wireless_mode)) {
+		nss = rtw_min(rtw_vht_mcsmap_to_nss(mlme->vhtpriv.vht_mcs_map)
+				, rtw_vht_mcsmap_to_nss(sta->vhtpriv.vht_mcs_map));
+	} else
+	#endif
+	if (is_supported_ht(sta->wireless_mode)) {
+		nss = rtw_min(rtw_ht_mcsset_to_nss(mlmeinfo->HT_caps.u.HT_cap_element.MCS_rate)
+				, rtw_ht_mcsset_to_nss(sta->htpriv.ht_cap.supp_mcs_set));
+	}
+
+	if (nss >= 1)
+		sz_limit = regsty->rx_ampdu_sz_limit_by_nss_bw[nss - 1][bw];
+#endif /* CONFIG_80211N_HT */
+
+	return sz_limit;
+}
+
 /**
  * rx_ampdu_apply_sta - Apply RX AMPDU setting to the specific @sta
  * @adapter: the adapter to which @sta belongs
@@ -3553,19 +3953,28 @@ u8 rx_ampdu_apply_sta(_adapter *adapter, struct sta_info *sta, u8 accept, u8 siz
 u16 rtw_rx_ampdu_apply(_adapter *adapter)
 {
 	u16 adj_cnt = 0;
-	struct mlme_ext_priv *mlmeext;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 	struct sta_info *sta;
 	u8 accept = rtw_rx_ampdu_is_accept(adapter);
-	u8 size = rtw_rx_ampdu_size(adapter);
+	u8 size;
 
-	mlmeext = &adapter->mlmeextpriv;
+	if (adapter->fix_rx_ampdu_size != RX_AMPDU_SIZE_INVALID)
+		size = adapter->fix_rx_ampdu_size;
+	else
+		size = rtw_rx_ampdu_size(adapter);
 
-	if (mlmeext_msr(mlmeext) == WIFI_FW_STATION_STATE) {
+	if (MLME_IS_STA(adapter)) {
 		sta = rtw_get_stainfo(&adapter->stapriv, get_bssid(&adapter->mlmepriv));
-		if (sta)
-			adj_cnt += rx_ampdu_apply_sta(adapter, sta, accept, size);
+		if (sta) {
+			u8 sta_size = size;
 
-	} else if (mlmeext_msr(mlmeext) == WIFI_FW_AP_STATE) {
+			if (adapter->fix_rx_ampdu_size == RX_AMPDU_SIZE_INVALID)
+				sta_size = rtw_min(size, rx_ampdu_size_sta_limit(adapter, sta));
+			adj_cnt += rx_ampdu_apply_sta(adapter, sta, accept, sta_size);
+		}
+		/* TODO: TDLS peer */
+
+	} else if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
 		_irqL irqL;
 		_list *phead, *plist;
 		u8 peer_num = 0;
@@ -3593,18 +4002,25 @@ u16 rtw_rx_ampdu_apply(_adapter *adapter)
 
 		for (i = 0; i < peer_num; i++) {
 			sta = rtw_get_stainfo_by_offset(pstapriv, peers[i]);
-			if (sta)
-				adj_cnt += rx_ampdu_apply_sta(adapter, sta, accept, size);
+			if (sta) {
+				u8 sta_size = size;
+
+				if (adapter->fix_rx_ampdu_size == RX_AMPDU_SIZE_INVALID)
+					sta_size = rtw_min(size, rx_ampdu_size_sta_limit(adapter, sta));
+				adj_cnt += rx_ampdu_apply_sta(adapter, sta, accept, sta_size);
+			}
 		}
 	}
 
+	/* TODO: ADHOC */
+
 	return adj_cnt;
 }
 
 unsigned int OnAction_back(_adapter *padapter, union recv_frame *precv_frame)
 {
 	u8 *addr;
-	struct sta_info *psta=NULL;
+	struct sta_info *psta = NULL;
 	struct recv_reorder_ctrl *preorder_ctrl;
 	unsigned char		*frame_body;
 	unsigned char		category, action;
@@ -3613,174 +4029,143 @@ unsigned int OnAction_back(_adapter *padapter, union recv_frame *precv_frame)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct registry_priv *pregpriv = &padapter->registrypriv;
+
 #ifdef CONFIG_80211N_HT
 
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	//check RA matches or not	
+	/* check RA matches or not	 */
 	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
 		return _SUCCESS;
 
-/*
-	//check A1 matches or not
+#if 0
+	/* check A1 matches or not */
 	if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
 		return _SUCCESS;
-*/
+#endif
 
-	if((pmlmeinfo->state&0x03) != WIFI_FW_AP_STATE)	
+	if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
 		if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
 			return _SUCCESS;
 
-	addr = GetAddr2Ptr(pframe);
+	addr = get_addr2_ptr(pframe);
 	psta = rtw_get_stainfo(pstapriv, addr);
 
-	if(psta==NULL)
+	if (psta == NULL)
 		return _SUCCESS;
 
 	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
 
 	category = frame_body[0];
-	if (category == RTW_WLAN_CATEGORY_BACK)// representing Block Ack
-	{
+	if (category == RTW_WLAN_CATEGORY_BACK) { /* representing Block Ack */
 #ifdef CONFIG_TDLS
-		if((psta->tdls_sta_state & TDLS_LINKED_STATE) && 
-			(psta->htpriv.ht_option==_TRUE) &&
-			(psta->htpriv.ampdu_enable==_TRUE))
-		{
-			DBG_871X("Recv [%s] from direc link\n", __FUNCTION__);
-		}
+		if ((psta->tdls_sta_state & TDLS_LINKED_STATE) &&
+		    (psta->htpriv.ht_option == _TRUE) &&
+		    (psta->htpriv.ampdu_enable == _TRUE))
+			RTW_INFO("Recv [%s] from direc link\n", __FUNCTION__);
 		else
-#endif //CONFIG_TDLS
-		if (!pmlmeinfo->HT_enable)
-		{
-			return _SUCCESS;
-		}
+#endif /* CONFIG_TDLS */
+			if (!pmlmeinfo->HT_enable)
+				return _SUCCESS;
 
 		action = frame_body[1];
-		DBG_871X("%s, action=%d\n", __FUNCTION__, action);
-		switch (action)
-		{
-			case RTW_WLAN_ACTION_ADDBA_REQ: //ADDBA request
+		RTW_INFO("%s, action=%d\n", __FUNCTION__, action);
+		switch (action) {
+		case RTW_WLAN_ACTION_ADDBA_REQ: /* ADDBA request */
 
-				_rtw_memcpy(&(pmlmeinfo->ADDBA_req), &(frame_body[2]), sizeof(struct ADDBA_request));
-				//process_addba_req(padapter, (u8*)&(pmlmeinfo->ADDBA_req), GetAddr3Ptr(pframe));
-				process_addba_req(padapter, (u8*)&(pmlmeinfo->ADDBA_req), addr);
-								
-				break;
-
-			case RTW_WLAN_ACTION_ADDBA_RESP: //ADDBA response
+			_rtw_memcpy(&(pmlmeinfo->ADDBA_req), &(frame_body[2]), sizeof(struct ADDBA_request));
+			/* process_addba_req(padapter, (u8*)&(pmlmeinfo->ADDBA_req), GetAddr3Ptr(pframe)); */
+			process_addba_req(padapter, (u8 *)&(pmlmeinfo->ADDBA_req), addr);
 
-				//status = frame_body[3] | (frame_body[4] << 8); //endian issue
-				status = RTW_GET_LE16(&frame_body[3]);
-				tid = ((frame_body[5] >> 2) & 0x7);
+			break;
 
-				if (status == 0)
-				{	//successful					
-					DBG_871X("agg_enable for TID=%d\n", tid);
-					psta->htpriv.agg_enable_bitmap |= 1 << tid;					
-					psta->htpriv.candidate_tid_bitmap &= ~BIT(tid);				
-				}
-				else
-				{					
-					psta->htpriv.agg_enable_bitmap &= ~BIT(tid);					
+		case RTW_WLAN_ACTION_ADDBA_RESP: /* ADDBA response */
+
+			/* status = frame_body[3] | (frame_body[4] << 8); */ /* endian issue */
+			status = RTW_GET_LE16(&frame_body[3]);
+			tid = ((frame_body[5] >> 2) & 0x7);
+			if (status == 0) {
+				/* successful					 */
+				RTW_INFO("agg_enable for TID=%d\n", tid);
+				psta->htpriv.agg_enable_bitmap |= 1 << tid;
+				psta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
+				/* amsdu in ampdu */
+				if (pregpriv->tx_ampdu_amsdu == 0)
+					psta->htpriv.tx_amsdu_enable = _FALSE;
+				else if (pregpriv->tx_ampdu_amsdu == 1)
+					psta->htpriv.tx_amsdu_enable = _TRUE;
+				else {
+					if (frame_body[5] & 1)
+						psta->htpriv.tx_amsdu_enable = _TRUE;
 				}
+			} else
+				psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
 
-				if(psta->state & WIFI_STA_ALIVE_CHK_STATE)
-				{
-					DBG_871X("%s alive check - rx ADDBA response\n", __func__);
-					psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
-					psta->expire_to = pstapriv->expire_to;
-					psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
-				}
+			if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
+				RTW_INFO("%s alive check - rx ADDBA response\n", __func__);
+				psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
+				psta->expire_to = pstapriv->expire_to;
+				psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
+			}
 
-				//DBG_871X("marc: ADDBA RSP: %x\n", pmlmeinfo->agg_enable_bitmap);
-				break;
+			/* RTW_INFO("marc: ADDBA RSP: %x\n", pmlmeinfo->agg_enable_bitmap); */
+			break;
 
-			case RTW_WLAN_ACTION_DELBA: //DELBA
-				if ((frame_body[3] & BIT(3)) == 0)
-				{
-					psta->htpriv.agg_enable_bitmap &= ~(1 << ((frame_body[3] >> 4) & 0xf));
-					psta->htpriv.candidate_tid_bitmap &= ~(1 << ((frame_body[3] >> 4) & 0xf));
-					
-					//reason_code = frame_body[4] | (frame_body[5] << 8);
-					reason_code = RTW_GET_LE16(&frame_body[4]);
-				}
-				else if((frame_body[3] & BIT(3)) == BIT(3))
-				{						
-					tid = (frame_body[3] >> 4) & 0x0F;
-				
-					preorder_ctrl = &psta->recvreorder_ctrl[tid];
-					preorder_ctrl->enable = _FALSE;
-					preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
-				}
-				
-				DBG_871X("%s(): DELBA: %x(%x)\n", __FUNCTION__,pmlmeinfo->agg_enable_bitmap, reason_code);
-				//todo: how to notify the host while receiving DELETE BA
-				break;
+		case RTW_WLAN_ACTION_DELBA: /* DELBA */
+			if ((frame_body[3] & BIT(3)) == 0) {
+				psta->htpriv.agg_enable_bitmap &= ~(1 << ((frame_body[3] >> 4) & 0xf));
+				psta->htpriv.candidate_tid_bitmap &= ~(1 << ((frame_body[3] >> 4) & 0xf));
 
-			default:
-				break;
+				/* reason_code = frame_body[4] | (frame_body[5] << 8); */
+				reason_code = RTW_GET_LE16(&frame_body[4]);
+			} else if ((frame_body[3] & BIT(3)) == BIT(3)) {
+				tid = (frame_body[3] >> 4) & 0x0F;
+
+				preorder_ctrl = &psta->recvreorder_ctrl[tid];
+				preorder_ctrl->enable = _FALSE;
+				preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
+			}
+
+			RTW_INFO("%s(): DELBA: %x(%x)\n", __FUNCTION__, pmlmeinfo->agg_enable_bitmap, reason_code);
+			/* todo: how to notify the host while receiving DELETE BA */
+			break;
+
+		default:
+			break;
 		}
 	}
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 	return _SUCCESS;
 }
 
 #ifdef CONFIG_P2P
-
-static int get_reg_classes_full_count(struct p2p_channels channel_list) {
+int get_reg_classes_full_count(struct p2p_channels *channel_list)
+{
 	int cnt = 0;
 	int i;
 
-	for (i = 0; i < channel_list.reg_classes; i++) {
-		cnt += channel_list.reg_class[i].channels;
-	}
+	for (i = 0; i < channel_list->reg_classes; i++)
+		cnt += channel_list->reg_class[i].channels;
 
 	return cnt;
 }
 
-static void get_channel_cnt_24g_5gl_5gh(  struct mlme_ext_priv *pmlmeext, u8* p24g_cnt, u8* p5gl_cnt, u8* p5gh_cnt )
-{
-	int	i = 0;
-
-	*p24g_cnt = 0;
-	*p5gl_cnt = 0;
-	*p5gh_cnt = 0;	
-	
-	for( i = 0; i < pmlmeext->max_chan_nums; i++ )
-	{
-		if ( pmlmeext->channel_set[ i ].ChannelNum <= 14 )
-		{
-			(*p24g_cnt)++;
-		}
-		else if ( ( pmlmeext->channel_set[ i ].ChannelNum > 14 ) && ( pmlmeext->channel_set[ i ].ChannelNum <= 48 ) )
-		{
-			//	Just include the channel 36, 40, 44, 48 channels for 5G low
-			(*p5gl_cnt)++;
-		}
-		else if ( ( pmlmeext->channel_set[ i ].ChannelNum >= 149 ) && ( pmlmeext->channel_set[ i ].ChannelNum <= 161 ) )
-		{
-			//	Just include the channel 149, 153, 157, 161 channels for 5G high
-			(*p5gh_cnt)++;
-		}
-	}
-}
-
-void issue_p2p_GO_request(_adapter *padapter, u8* raddr)
+void issue_p2p_GO_request(_adapter *padapter, u8 *raddr)
 {
-
+	struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_GO_NEGO_REQ;
-	u8			wpsie[ 255 ] = { 0x00 }, p2pie[ 255 ] = { 0x00 };
+	u8			wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
 	u8			wpsielen = 0, p2pielen = 0, i;
 	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
 	u16			len_channellist_attr = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
-	
+
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
@@ -3789,16 +4174,15 @@ void issue_p2p_GO_request(_adapter *padapter, u8* raddr)
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	DBG_871X( "[%s] In\n", __FUNCTION__ );
-	//update attribute
+	RTW_INFO("[%s] In\n", __FUNCTION__);
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -3816,7 +4200,7 @@ void issue_p2p_GO_request(_adapter *padapter, u8* raddr)
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -3824,379 +4208,331 @@ void issue_p2p_GO_request(_adapter *padapter, u8* raddr)
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pwdinfo->negotiation_dialog_token = 1;	//	Initialize the dialog value
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pwdinfo->negotiation_dialog_token = 1;	/*	Initialize the dialog value */
 	pframe = rtw_set_fixed_ie(pframe, 1, &pwdinfo->negotiation_dialog_token, &(pattrib->pktlen));
 
-	
 
-	//	WPS Section
+
+	/*	WPS Section */
 	wpsielen = 0;
-	//	WPS OUI
-	*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+	/*	WPS OUI */
+	*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
 	wpsielen += 4;
 
-	//	WPS version
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 	wpsielen += 2;
 
-	//	Value:
-	wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 
-	//	Device Password ID
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_DEVICE_PWID );
+	/*	Device Password ID */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 	wpsielen += 2;
 
-	//	Value:
+	/*	Value: */
 
-	if ( pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PEER_DISPLAY_PIN )
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_USER_SPEC );
-	}
-	else if ( pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_SELF_DISPLAY_PIN )
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_REGISTRAR_SPEC );
-	}
-	else if ( pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC )
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_PBC );
-	}
+	if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PEER_DISPLAY_PIN)
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_USER_SPEC);
+	else if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_SELF_DISPLAY_PIN)
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC);
+	else if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC)
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_PBC);
 
 	wpsielen += 2;
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen );
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
 
 
-	//	P2P IE Section.
+	/*	P2P IE Section. */
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20110306
-	//	According to the P2P Specification, the group negoitation request frame should contain 9 P2P attributes
-	//	1. P2P Capability
-	//	2. Group Owner Intent
-	//	3. Configuration Timeout
-	//	4. Listen Channel
-	//	5. Extended Listen Timing
-	//	6. Intended P2P Interface Address
-	//	7. Channel List
-	//	8. P2P Device Info
-	//	9. Operating Channel
-
-
-	//	P2P Capability
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20110306 */
+	/*	According to the P2P Specification, the group negoitation request frame should contain 9 P2P attributes */
+	/*	1. P2P Capability */
+	/*	2. Group Owner Intent */
+	/*	3. Configuration Timeout */
+	/*	4. Listen Channel */
+	/*	5. Extended Listen Timing */
+	/*	6. Intended P2P Interface Address */
+	/*	7. Channel List */
+	/*	8. P2P Device Info */
+	/*	9. Operating Channel */
+
+
+	/*	P2P Capability */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
-	p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
+	p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
 
-	//	Group Capability Bitmap, 1 byte
-	if ( pwdinfo->persistent_supported )
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
-	}
+	/*	Group Capability Bitmap, 1 byte */
+	if (pwdinfo->persistent_supported)
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
 	else
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN;
-	}
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
 
 
-	//	Group Owner Intent
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_GO_INTENT;
+	/*	Group Owner Intent */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_GO_INTENT;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value:
-	//	Todo the tie breaker bit.
-	p2pie[ p2pielen++ ] = ( ( pwdinfo->intent << 1 ) &  0xFE );
+	/*	Value: */
+	/*	Todo the tie breaker bit. */
+	p2pie[p2pielen++] = ((pwdinfo->intent << 1) &  0xFE);
 
-	//	Configuration Timeout
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CONF_TIMEOUT;
+	/*	Configuration Timeout */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P GO
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P Client
+	/*	Value: */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P GO */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P Client */
 
 
-	//	Listen Channel
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_LISTEN_CH;
+	/*	Listen Channel */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_LISTEN_CH;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
 
-	//	Operating Class
-	p2pie[ p2pielen++ ] = 0x51;	//	Copy from SD7
-	
-	//	Channel Number
-	p2pie[ p2pielen++ ] = pwdinfo->listen_channel;	//	listening channel number
-	
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Operating Class */
+	p2pie[p2pielen++] = 0x51;	/*	Copy from SD7 */
+
+	/*	Channel Number */
+	p2pie[p2pielen++] = pwdinfo->listen_channel;	/*	listening channel number */
 
-	//	Extended Listen Timing ATTR
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_EX_LISTEN_TIMING;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0004 );
+	/*	Extended Listen Timing ATTR */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0004);
 	p2pielen += 2;
 
-	//	Value:
-	//	Availability Period
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
+	/*	Value: */
+	/*	Availability Period */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
 	p2pielen += 2;
 
-	//	Availability Interval
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
+	/*	Availability Interval */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
 	p2pielen += 2;
 
 
-	//	Intended P2P Interface Address
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_INTENTED_IF_ADDR;
+	/*	Intended P2P Interface Address */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_INTENDED_IF_ADDR;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
 	p2pielen += 2;
 
-	//	Value:
+	/*	Value: */
 	_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
 
-	//	Channel List
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CH_LIST;
+	/*	Channel List */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
 
-	// Length:
-	// Country String(3)
-	// + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?)
-	// + number of channels in all classes
+	/* Length: */
+	/* Country String(3) */
+	/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
+	/* + number of channels in all classes */
 	len_channellist_attr = 3
-	   + (1 + 1) * (u16)(pmlmeext->channel_list.reg_classes)
-	   + get_reg_classes_full_count(pmlmeext->channel_list);
+		       + (1 + 1) * (u16)(ch_list->reg_classes)
+		       + get_reg_classes_full_count(ch_list);
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter , _FW_LINKED)
-		&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 5 + 1 );
-	}
+	if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
 	else
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-	}
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 #else
 
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 
 #endif
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
 
-	//	Channel Entry List
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Channel Entry List */
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter , _FW_LINKED)
-		&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-	{
-		_adapter *pbuddy_adapter = padapter->pbuddy_adapter;	
-		struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+	if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+		u8 union_ch = rtw_mi_get_union_chan(padapter);
 
-		//	Operating Class
-		if ( pbuddy_mlmeext->cur_channel > 14 )
-		{
-			if ( pbuddy_mlmeext->cur_channel >= 149 )
-			{
-				p2pie[ p2pielen++ ] = 0x7c;
-			}
+		/*	Operating Class */
+		if (union_ch > 14) {
+			if (union_ch >= 149)
+				p2pie[p2pielen++] = 0x7c;
 			else
-			{
-				p2pie[ p2pielen++ ] = 0x73;
-			}
-		}
-		else
-		{
-			p2pie[ p2pielen++ ] = 0x51;
-		}
-
-		//	Number of Channels
-		//	Just support 1 channel and this channel is AP's channel
-		p2pie[ p2pielen++ ] = 1;
+				p2pie[p2pielen++] = 0x73;
+		} else
+			p2pie[p2pielen++] = 0x51;
 
-		//	Channel List
-		p2pie[ p2pielen++ ] = pbuddy_mlmeext->cur_channel;
-	}
-	else
-	{
-		int i,j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+		/*	Number of Channels */
+		/*	Just support 1 channel and this channel is AP's channel */
+		p2pie[p2pielen++] = 1;
 
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
-		}
-	}
-#else // CONFIG_CONCURRENT_MODE
+		/*	Channel List */
+		p2pie[p2pielen++] = union_ch;
+	} else
+#endif /* CONFIG_CONCURRENT_MODE */
 	{
-		int i,j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
+		int i, j;
+		for (j = 0; j < ch_list->reg_classes; j++) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+			/*	Number of Channels */
+			p2pie[p2pielen++] = ch_list->reg_class[j].channels;
 
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
+			/*	Channel List */
+			for (i = 0; i < ch_list->reg_class[j].channels; i++)
+				p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
 		}
 	}
-#endif // CONFIG_CONCURRENT_MODE
 
-	//	Device Info
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
+	/*	Device Info */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-	//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	//	P2P Device Address
+	/*	Value: */
+	/*	P2P Device Address */
 	_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Config Method
-	//	This field should be big endian. Noted by P2P specification.
+	/*	Config Method */
+	/*	This field should be big endian. Noted by P2P specification. */
 
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->supported_wps_cm );
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
 
 	p2pielen += 2;
 
-	//	Primary Device Type
-	//	Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+	/*	Primary Device Type */
+	/*	Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
 	p2pielen += 2;
 
-	//	OUI
-	*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
+	/*	OUI */
+	*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
 	p2pielen += 4;
 
-	//	Sub Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+	/*	Sub Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
 	p2pielen += 2;
 
-	//	Number of Secondary Device Types
-	p2pie[ p2pielen++ ] = 0x00;	//	No Secondary Device Type List
+	/*	Number of Secondary Device Types */
+	p2pie[p2pielen++] = 0x00;	/*	No Secondary Device Type List */
 
-	//	Device Name
-	//	Type:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+	/*	Device Name */
+	/*	Type: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 	p2pielen += 2;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len );
-	p2pielen += pwdinfo->device_name_len;	
-	
+	/*	Value: */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len);
+	p2pielen += pwdinfo->device_name_len;
 
-	//	Operating Channel
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
-	p2pielen += 2;
+	/*	Operating Channel */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
+	p2pielen += 2;
 
-	//	Operating Class
-	if ( pwdinfo->operating_channel <= 14 )
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x51;
-	}
-	else if ( ( pwdinfo->operating_channel >= 36 ) && ( pwdinfo->operating_channel <= 48 ) )
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x73;
-	}
-	else
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x7c;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
+
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Operating Class */
+	if (pwdinfo->operating_channel <= 14) {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x51;
+	} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x73;
+	} else {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x7c;
 	}
 
-	//	Channel Number
-	p2pie[ p2pielen++ ] = pwdinfo->operating_channel;	//	operating channel number
+	/*	Channel Number */
+	p2pie[p2pielen++] = pwdinfo->operating_channel;	/*	operating channel number */
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen );		
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
 
 #ifdef CONFIG_WFD
 	wfdielen = build_nego_req_wfd_ie(pwdinfo, pframe);
@@ -4213,21 +4549,21 @@ void issue_p2p_GO_request(_adapter *padapter, u8* raddr)
 }
 
 
-void issue_p2p_GO_response(_adapter *padapter, u8* raddr, u8* frame_body,uint len, u8 result)
+void issue_p2p_GO_response(_adapter *padapter, u8 *raddr, u8 *frame_body, uint len, u8 result)
 {
-
+	struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_GO_NEGO_RESP;
-	u8			wpsie[ 255 ] = { 0x00 }, p2pie[ 255 ] = { 0x00 };
+	u8			wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
 	u8			p2pielen = 0, i;
 	uint			wpsielen = 0;
 	u16			wps_devicepassword_id = 0x0000;
 	uint			wps_devicepassword_id_len = 0;
 	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh;
 	u16			len_channellist_attr = 0;
-	
+
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
@@ -4236,19 +4572,18 @@ void issue_p2p_GO_response(_adapter *padapter, u8* raddr, u8* frame_body,uint le
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	DBG_871X( "[%s] In, result = %d\n", __FUNCTION__,  result );
-	//update attribute
+	RTW_INFO("[%s] In, result = %d\n", __FUNCTION__,  result);
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -4266,7 +4601,7 @@ void issue_p2p_GO_response(_adapter *padapter, u8* raddr, u8* frame_body,uint le
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -4274,414 +4609,351 @@ void issue_p2p_GO_response(_adapter *padapter, u8* raddr, u8* frame_body,uint le
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pwdinfo->negotiation_dialog_token = frame_body[7];	//	The Dialog Token of provisioning discovery request frame.
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pwdinfo->negotiation_dialog_token = frame_body[7];	/*	The Dialog Token of provisioning discovery request frame. */
 	pframe = rtw_set_fixed_ie(pframe, 1, &(pwdinfo->negotiation_dialog_token), &(pattrib->pktlen));
 
-	//	Commented by Albert 20110328
-	//	Try to get the device password ID from the WPS IE of group negotiation request frame
-	//	WiFi Direct test plan 5.1.15
-	rtw_get_wps_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, wpsie, &wpsielen);
-	rtw_get_wps_attr_content( wpsie, wpsielen, WPS_ATTR_DEVICE_PWID, (u8*) &wps_devicepassword_id, &wps_devicepassword_id_len);
-	wps_devicepassword_id = be16_to_cpu( wps_devicepassword_id );
+	/*	Commented by Albert 20110328 */
+	/*	Try to get the device password ID from the WPS IE of group negotiation request frame */
+	/*	WiFi Direct test plan 5.1.15 */
+	rtw_get_wps_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, wpsie, &wpsielen);
+	rtw_get_wps_attr_content(wpsie, wpsielen, WPS_ATTR_DEVICE_PWID, (u8 *) &wps_devicepassword_id, &wps_devicepassword_id_len);
+	wps_devicepassword_id = be16_to_cpu(wps_devicepassword_id);
 
-	_rtw_memset( wpsie, 0x00, 255 );
+	_rtw_memset(wpsie, 0x00, 255);
 	wpsielen = 0;
 
-	//	WPS Section
+	/*	WPS Section */
 	wpsielen = 0;
-	//	WPS OUI
-	*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+	/*	WPS OUI */
+	*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
 	wpsielen += 4;
 
-	//	WPS version
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 	wpsielen += 2;
 
-	//	Value:
-	wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 
-	//	Device Password ID
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_DEVICE_PWID );
+	/*	Device Password ID */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 	wpsielen += 2;
 
-	//	Value:
-	if ( wps_devicepassword_id == WPS_DPID_USER_SPEC )
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_REGISTRAR_SPEC );
-	}
-	else if ( wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC )
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_USER_SPEC );
-	}
+	/*	Value: */
+	if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC);
+	else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_USER_SPEC);
 	else
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_PBC );
-	}
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_PBC);
 	wpsielen += 2;
 
-	//	Commented by Kurt 20120113
-	//	If some device wants to do p2p handshake without sending prov_disc_req
-	//	We have to get peer_req_cm from here.
-	if(_rtw_memcmp( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "000", 3) )
-	{
-		if ( wps_devicepassword_id == WPS_DPID_USER_SPEC )
-		{
-			_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3 );
-		}
-		else if ( wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC )
-		{
-			_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3 );	
-		}
+	/*	Commented by Kurt 20120113 */
+	/*	If some device wants to do p2p handshake without sending prov_disc_req */
+	/*	We have to get peer_req_cm from here. */
+	if (_rtw_memcmp(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "000", 3)) {
+		if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
+			_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3);
+		else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
+			_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3);
 		else
-		{
-			_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3 );	
-		}
+			_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3);
 	}
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen );
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
 
 
-	//	P2P IE Section.
+	/*	P2P IE Section. */
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20100908
-	//	According to the P2P Specification, the group negoitation response frame should contain 9 P2P attributes
-	//	1. Status
-	//	2. P2P Capability
-	//	3. Group Owner Intent
-	//	4. Configuration Timeout
-	//	5. Operating Channel
-	//	6. Intended P2P Interface Address
-	//	7. Channel List
-	//	8. Device Info
-	//	9. Group ID	( Only GO )
-
-
-	//	ToDo:
-
-	//	P2P Status
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_STATUS;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20100908 */
+	/*	According to the P2P Specification, the group negoitation response frame should contain 9 P2P attributes */
+	/*	1. Status */
+	/*	2. P2P Capability */
+	/*	3. Group Owner Intent */
+	/*	4. Configuration Timeout */
+	/*	5. Operating Channel */
+	/*	6. Intended P2P Interface Address */
+	/*	7. Channel List */
+	/*	8. Device Info */
+	/*	9. Group ID	( Only GO ) */
+
+
+	/*	ToDo: */
+
+	/*	P2P Status */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_STATUS;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = result;
-	
-	//	P2P Capability
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
+	/*	Value: */
+	p2pie[p2pielen++] = result;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	P2P Capability */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
 
-	if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) )
-	{
-		//	Commented by Albert 2011/03/08
-		//	According to the P2P specification
-		//	if the sending device will be client, the P2P Capability should be reserved of group negotation response frame
-		p2pie[ p2pielen++ ] = 0;
-	}
-	else
-	{
-		//	Be group owner or meet the error case
-		p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
-	}
-	
-	//	Group Capability Bitmap, 1 byte
-	if ( pwdinfo->persistent_supported )
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
+		/*	Commented by Albert 2011/03/08 */
+		/*	According to the P2P specification */
+		/*	if the sending device will be client, the P2P Capability should be reserved of group negotation response frame */
+		p2pie[p2pielen++] = 0;
+	} else {
+		/*	Be group owner or meet the error case */
+		p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
 	}
+
+	/*	Group Capability Bitmap, 1 byte */
+	if (pwdinfo->persistent_supported)
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
 	else
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN;
-	}
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
 
-	//	Group Owner Intent
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_GO_INTENT;
+	/*	Group Owner Intent */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_GO_INTENT;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value:
-	if ( pwdinfo->peer_intent & 0x01 )
-	{
-		//	Peer's tie breaker bit is 1, our tie breaker bit should be 0
-		p2pie[ p2pielen++ ] = ( pwdinfo->intent << 1 );
-	}
-	else
-	{
-		//	Peer's tie breaker bit is 0, our tie breaker bit should be 1
-		p2pie[ p2pielen++ ] = ( ( pwdinfo->intent << 1 ) | BIT(0) );
+	/*	Value: */
+	if (pwdinfo->peer_intent & 0x01) {
+		/*	Peer's tie breaker bit is 1, our tie breaker bit should be 0 */
+		p2pie[p2pielen++] = (pwdinfo->intent << 1);
+	} else {
+		/*	Peer's tie breaker bit is 0, our tie breaker bit should be 1 */
+		p2pie[p2pielen++] = ((pwdinfo->intent << 1) | BIT(0));
 	}
 
 
-	//	Configuration Timeout
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CONF_TIMEOUT;
+	/*	Configuration Timeout */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P GO
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P Client
+	/*	Value: */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P GO */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P Client */
 
-	//	Operating Channel
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
+	/*	Operating Channel */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
-
-	//	Operating Class
-	if ( pwdinfo->operating_channel <= 14 )
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x51;
-	}
-	else if ( ( pwdinfo->operating_channel >= 36 ) && ( pwdinfo->operating_channel <= 48 ) )
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x73;
-	}
-	else
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x7c;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
+
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Operating Class */
+	if (pwdinfo->operating_channel <= 14) {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x51;
+	} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x73;
+	} else {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x7c;
 	}
-	
-	//	Channel Number
-	p2pie[ p2pielen++ ] = pwdinfo->operating_channel;	//	operating channel number
 
-	//	Intended P2P Interface Address	
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_INTENTED_IF_ADDR;
+	/*	Channel Number */
+	p2pie[p2pielen++] = pwdinfo->operating_channel;	/*	operating channel number */
+
+	/*	Intended P2P Interface Address	 */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_INTENDED_IF_ADDR;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
 	p2pielen += 2;
 
-	//	Value:
+	/*	Value: */
 	_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Channel List
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CH_LIST;
+	/*	Channel List */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
 
-	// Country String(3)
-	// + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?)
-	// + number of channels in all classes
+	/* Country String(3) */
+	/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
+	/* + number of channels in all classes */
 	len_channellist_attr = 3
-	   + (1 + 1) * (u16)pmlmeext->channel_list.reg_classes
-	   + get_reg_classes_full_count(pmlmeext->channel_list);
+		       + (1 + 1) * (u16)ch_list->reg_classes
+		       + get_reg_classes_full_count(ch_list);
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter , _FW_LINKED)
-		&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 5 + 1 );
-	}
+	if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
 	else
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-	}
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 #else
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-
- #endif
+#endif
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
+
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
 
-	//	Channel Entry List
+	/*	Channel Entry List */
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter , _FW_LINKED)
-		&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-	{
-		_adapter *pbuddy_adapter = padapter->pbuddy_adapter;	
-		struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+	if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
 
-		//	Operating Class
-		if ( pbuddy_mlmeext->cur_channel > 14 )
-		{
-			if ( pbuddy_mlmeext->cur_channel >= 149 )
-			{
-				p2pie[ p2pielen++ ] = 0x7c;
-			}
+		u8 union_chan = rtw_mi_get_union_chan(padapter);
+
+		/*Operating Class*/
+		if (union_chan > 14) {
+			if (union_chan >= 149)
+				p2pie[p2pielen++] = 0x7c;
 			else
-			{
-				p2pie[ p2pielen++ ] = 0x73;
-			}
-		}
-		else
-		{
-			p2pie[ p2pielen++ ] = 0x51;
-		}
+				p2pie[p2pielen++] = 0x73;
 
-		//	Number of Channels
-		//	Just support 1 channel and this channel is AP's channel
-		p2pie[ p2pielen++ ] = 1;
+		} else
+			p2pie[p2pielen++] = 0x51;
 
-		//	Channel List
-		p2pie[ p2pielen++ ] = pbuddy_mlmeext->cur_channel;
-	}
-	else
-	{
-		int i, j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
+		/*	Number of Channels
+			Just support 1 channel and this channel is AP's channel*/
+		p2pie[p2pielen++] = 1;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
-
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
-		}
-	}
-#else // CONFIG_CONCURRENT_MODE
+		/*Channel List*/
+		p2pie[p2pielen++] = union_chan;
+	} else
+#endif /* CONFIG_CONCURRENT_MODE */
 	{
 		int i, j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
+		for (j = 0; j < ch_list->reg_classes; j++) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+			/*	Number of Channels */
+			p2pie[p2pielen++] = ch_list->reg_class[j].channels;
 
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
+			/*	Channel List */
+			for (i = 0; i < ch_list->reg_class[j].channels; i++)
+				p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
 		}
 	}
-#endif // CONFIG_CONCURRENT_MODE
 
-	
-	//	Device Info
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
-
-	//	Length:
-	//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-	//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
+	/*	Device Info */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
+
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	//	P2P Device Address
+	/*	Value: */
+	/*	P2P Device Address */
 	_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Config Method
-	//	This field should be big endian. Noted by P2P specification.
+	/*	Config Method */
+	/*	This field should be big endian. Noted by P2P specification. */
 
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->supported_wps_cm );
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
 
 	p2pielen += 2;
 
-	//	Primary Device Type
-	//	Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+	/*	Primary Device Type */
+	/*	Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
 	p2pielen += 2;
 
-	//	OUI
-	*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
+	/*	OUI */
+	*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
 	p2pielen += 4;
 
-	//	Sub Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+	/*	Sub Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
 	p2pielen += 2;
 
-	//	Number of Secondary Device Types
-	p2pie[ p2pielen++ ] = 0x00;	//	No Secondary Device Type List
+	/*	Number of Secondary Device Types */
+	p2pie[p2pielen++] = 0x00;	/*	No Secondary Device Type List */
 
-	//	Device Name
-	//	Type:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+	/*	Device Name */
+	/*	Type: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 	p2pielen += 2;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len );
-	p2pielen += pwdinfo->device_name_len;	
-	
-	if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) )
-	{
-		//	Group ID Attribute
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_ID;
+	/*	Value: */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len);
+	p2pielen += pwdinfo->device_name_len;
+
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		/*	Group ID Attribute */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
 
-		//	Length:
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN + pwdinfo->nego_ssidlen );
+		/*	Length: */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + pwdinfo->nego_ssidlen);
 		p2pielen += 2;
 
-		//	Value:
-		//	p2P Device Address
-		_rtw_memcpy( p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN );
+		/*	Value: */
+		/*	p2P Device Address */
+		_rtw_memcpy(p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN);
 		p2pielen += ETH_ALEN;
 
-		//	SSID
-		_rtw_memcpy( p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen );
+		/*	SSID */
+		_rtw_memcpy(p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
 		p2pielen += pwdinfo->nego_ssidlen;
-		
+
 	}
-	
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen );	
-	
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
+
 #ifdef CONFIG_WFD
 	wfdielen = build_nego_resp_wfd_ie(pwdinfo, pframe);
 	pframe += wfdielen;
@@ -4696,16 +4968,16 @@ void issue_p2p_GO_response(_adapter *padapter, u8* raddr, u8* frame_body,uint le
 
 }
 
-void issue_p2p_GO_confirm(_adapter *padapter, u8* raddr, u8 result)
+void issue_p2p_GO_confirm(_adapter *padapter, u8 *raddr, u8 result)
 {
 
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_GO_NEGO_CONF;
-	u8			wpsie[ 255 ] = { 0x00 }, p2pie[ 255 ] = { 0x00 };
+	u8			wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
 	u8			wpsielen = 0, p2pielen = 0;
-	
+
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
@@ -4714,18 +4986,17 @@ void issue_p2p_GO_confirm(_adapter *padapter, u8* raddr, u8 result)
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	DBG_871X( "[%s] In\n", __FUNCTION__ );
-	//update attribute
+	RTW_INFO("[%s] In\n", __FUNCTION__);
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -4743,7 +5014,7 @@ void issue_p2p_GO_confirm(_adapter *padapter, u8* raddr, u8 result)
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -4751,204 +5022,173 @@ void issue_p2p_GO_confirm(_adapter *padapter, u8* raddr, u8 result)
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(pwdinfo->negotiation_dialog_token), &(pattrib->pktlen));
 
-	
 
-	//	P2P IE Section.
 
-	//	P2P OUI
+	/*	P2P IE Section. */
+
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20110306
-	//	According to the P2P Specification, the group negoitation request frame should contain 5 P2P attributes
-	//	1. Status
-	//	2. P2P Capability
-	//	3. Operating Channel
-	//	4. Channel List
-	//	5. Group ID	( if this WiFi is GO )
-
-	//	P2P Status
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_STATUS;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20110306 */
+	/*	According to the P2P Specification, the group negoitation request frame should contain 5 P2P attributes */
+	/*	1. Status */
+	/*	2. P2P Capability */
+	/*	3. Operating Channel */
+	/*	4. Channel List */
+	/*	5. Group ID	( if this WiFi is GO ) */
+
+	/*	P2P Status */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_STATUS;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = result;
+	/*	Value: */
+	p2pie[p2pielen++] = result;
 
-	//	P2P Capability
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
+	/*	P2P Capability */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
-	p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
-	
-	//	Group Capability Bitmap, 1 byte
-	if ( pwdinfo->persistent_supported )
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
-	}
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
+	p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
+
+	/*	Group Capability Bitmap, 1 byte */
+	if (pwdinfo->persistent_supported)
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
 	else
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN;
-	}
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
 
 
-	//	Operating Channel
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
+	/*	Operating Channel */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
 
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
 
-	if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) )
-	{
-		if ( pwdinfo->peer_operating_ch <= 14 )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x51;
-		}
-		else if ( ( pwdinfo->peer_operating_ch >= 36 ) && ( pwdinfo->peer_operating_ch <= 48 ) )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x73;
-		}
-		else
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x7c;
-		}
-		
-		p2pie[ p2pielen++ ] = pwdinfo->peer_operating_ch;
-	}
-	else
-	{
-		if ( pwdinfo->operating_channel <= 14 )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x51;
-		}
-		else if ( ( pwdinfo->operating_channel >= 36 ) && ( pwdinfo->operating_channel <= 48 ) )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x73;
+
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
+		if (pwdinfo->peer_operating_ch <= 14) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x51;
+		} else if ((pwdinfo->peer_operating_ch >= 36) && (pwdinfo->peer_operating_ch <= 48)) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x73;
+		} else {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x7c;
 		}
-		else
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x7c;
+
+		p2pie[p2pielen++] = pwdinfo->peer_operating_ch;
+	} else {
+		if (pwdinfo->operating_channel <= 14) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x51;
+		} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x73;
+		} else {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x7c;
 		}
-		
-		//	Channel Number
-		p2pie[ p2pielen++ ] = pwdinfo->operating_channel;		//	Use the listen channel as the operating channel
+
+		/*	Channel Number */
+		p2pie[p2pielen++] = pwdinfo->operating_channel;		/*	Use the listen channel as the operating channel */
 	}
 
 
-	//	Channel List
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CH_LIST;
+	/*	Channel List */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
 
-	*(u16*) ( p2pie + p2pielen ) = 6;
+	*(u16 *)(p2pie + p2pielen) = 6;
 	p2pielen += 2;
 
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
-
-	//	Value:
-	if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) )
-	{
-		if ( pwdinfo->peer_operating_ch <= 14 )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x51;
-		}
-		else if ( ( pwdinfo->peer_operating_ch >= 36 ) && ( pwdinfo->peer_operating_ch <= 48 ) )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x73;
-		}
-		else
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x7c;
-		}
-		p2pie[ p2pielen++ ] = 1;
-		p2pie[ p2pielen++ ] = pwdinfo->peer_operating_ch;
-	}
-	else
-	{
-		if ( pwdinfo->operating_channel <= 14 )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x51;
-		}
-		else if ( ( pwdinfo->operating_channel >= 36 ) && ( pwdinfo->operating_channel <= 48 ) )
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x73;
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
+
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Value: */
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
+		if (pwdinfo->peer_operating_ch <= 14) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x51;
+		} else if ((pwdinfo->peer_operating_ch >= 36) && (pwdinfo->peer_operating_ch <= 48)) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x73;
+		} else {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x7c;
 		}
-		else
-		{
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x7c;
+		p2pie[p2pielen++] = 1;
+		p2pie[p2pielen++] = pwdinfo->peer_operating_ch;
+	} else {
+		if (pwdinfo->operating_channel <= 14) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x51;
+		} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x73;
+		} else {
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x7c;
 		}
-		
-		//	Channel Number
-		p2pie[ p2pielen++ ] = 1;
-		p2pie[ p2pielen++ ] = pwdinfo->operating_channel;		//	Use the listen channel as the operating channel
+
+		/*	Channel Number */
+		p2pie[p2pielen++] = 1;
+		p2pie[p2pielen++] = pwdinfo->operating_channel;		/*	Use the listen channel as the operating channel */
 	}
 
-	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) )
-	{
-		//	Group ID Attribute
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_ID;
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		/*	Group ID Attribute */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
 
-		//	Length:
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN + pwdinfo->nego_ssidlen );
+		/*	Length: */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + pwdinfo->nego_ssidlen);
 		p2pielen += 2;
 
-		//	Value:
-		//	p2P Device Address
-		_rtw_memcpy( p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN );
+		/*	Value: */
+		/*	p2P Device Address */
+		_rtw_memcpy(p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN);
 		p2pielen += ETH_ALEN;
 
-		//	SSID
-		_rtw_memcpy( p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen );
+		/*	SSID */
+		_rtw_memcpy(p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
 		p2pielen += pwdinfo->nego_ssidlen;
 	}
-	
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen );
-	
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
+
 #ifdef CONFIG_WFD
 	wfdielen = build_nego_confirm_wfd_ie(pwdinfo, pframe);
 	pframe += wfdielen;
@@ -4963,27 +5203,21 @@ void issue_p2p_GO_confirm(_adapter *padapter, u8* raddr, u8 result)
 
 }
 
-void issue_p2p_invitation_request(_adapter *padapter, u8* raddr )
+void issue_p2p_invitation_request(_adapter *padapter, u8 *raddr)
 {
-
+	struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_INVIT_REQ;
-	u8			p2pie[ 255 ] = { 0x00 };
+	u8			p2pie[255] = { 0x00 };
 	u8			p2pielen = 0, i;
 	u8			dialogToken = 3;
 	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
-	u16			len_channellist_attr = 0;	
+	u16			len_channellist_attr = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-	struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif
 
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
@@ -4993,15 +5227,14 @@ void issue_p2p_invitation_request(_adapter *padapter, u8* raddr )
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -5019,7 +5252,7 @@ void issue_p2p_invitation_request(_adapter *padapter, u8* raddr )
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -5027,270 +5260,234 @@ void issue_p2p_invitation_request(_adapter *padapter, u8* raddr )
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
 
-	//	P2P IE Section.
+	/*	P2P IE Section. */
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20101011
-	//	According to the P2P Specification, the P2P Invitation request frame should contain 7 P2P attributes
-	//	1. Configuration Timeout
-	//	2. Invitation Flags
-	//	3. Operating Channel	( Only GO )
-	//	4. P2P Group BSSID	( Should be included if I am the GO )
-	//	5. Channel List
-	//	6. P2P Group ID
-	//	7. P2P Device Info
-
-	//	Configuration Timeout
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CONF_TIMEOUT;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20101011 */
+	/*	According to the P2P Specification, the P2P Invitation request frame should contain 7 P2P attributes */
+	/*	1. Configuration Timeout */
+	/*	2. Invitation Flags */
+	/*	3. Operating Channel	( Only GO ) */
+	/*	4. P2P Group BSSID	( Should be included if I am the GO ) */
+	/*	5. Channel List */
+	/*	6. P2P Group ID */
+	/*	7. P2P Device Info */
+
+	/*	Configuration Timeout */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P GO
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P Client
+	/*	Value: */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P GO */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P Client */
 
-	//	Invitation Flags
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_INVITATION_FLAGS;
+	/*	Invitation Flags */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_INVITATION_FLAGS;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = P2P_INVITATION_FLAGS_PERSISTENT;
+	/*	Value: */
+	p2pie[p2pielen++] = P2P_INVITATION_FLAGS_PERSISTENT;
 
 
-	//	Operating Channel
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
+	/*	Operating Channel */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
-
-	//	Operating Class
-	if ( pwdinfo->invitereq_info.operating_ch <= 14 )
-		p2pie[ p2pielen++ ] = 0x51;
-	else if ( ( pwdinfo->invitereq_info.operating_ch >= 36 ) && ( pwdinfo->invitereq_info.operating_ch <= 48 ) )
-		p2pie[ p2pielen++ ] = 0x73;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
+
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Operating Class */
+	if (pwdinfo->invitereq_info.operating_ch <= 14)
+		p2pie[p2pielen++] = 0x51;
+	else if ((pwdinfo->invitereq_info.operating_ch >= 36) && (pwdinfo->invitereq_info.operating_ch <= 48))
+		p2pie[p2pielen++] = 0x73;
 	else
-		p2pie[ p2pielen++ ] = 0x7c;
-	
-	//	Channel Number
-	p2pie[ p2pielen++ ] = pwdinfo->invitereq_info.operating_ch;	//	operating channel number
+		p2pie[p2pielen++] = 0x7c;
 
-	if (_rtw_memcmp(adapter_mac_addr(padapter), pwdinfo->invitereq_info.go_bssid, ETH_ALEN))
-	{
-		//	P2P Group BSSID
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_BSSID;
+	/*	Channel Number */
+	p2pie[p2pielen++] = pwdinfo->invitereq_info.operating_ch;	/*	operating channel number */
+
+	if (_rtw_memcmp(adapter_mac_addr(padapter), pwdinfo->invitereq_info.go_bssid, ETH_ALEN)) {
+		/*	P2P Group BSSID */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_GROUP_BSSID;
 
-		//	Length:
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN );
+		/*	Length: */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
 		p2pielen += 2;
 
-		//	Value:
-		//	P2P Device Address for GO
-		_rtw_memcpy( p2pie + p2pielen, pwdinfo->invitereq_info.go_bssid, ETH_ALEN );
+		/*	Value: */
+		/*	P2P Device Address for GO */
+		_rtw_memcpy(p2pie + p2pielen, pwdinfo->invitereq_info.go_bssid, ETH_ALEN);
 		p2pielen += ETH_ALEN;
 	}
 
-	//	Channel List
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CH_LIST;
+	/*	Channel List */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
 
-	
-	//	Length:
-	// Country String(3)
-	// + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?)
-	// + number of channels in all classes
+
+	/*	Length: */
+	/* Country String(3) */
+	/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
+	/* + number of channels in all classes */
 	len_channellist_attr = 3
-	   + (1 + 1) * (u16)pmlmeext->channel_list.reg_classes
-	   + get_reg_classes_full_count(pmlmeext->channel_list);
+		       + (1 + 1) * (u16)ch_list->reg_classes
+		       + get_reg_classes_full_count(ch_list);
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter , _FW_LINKED)
-		&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 5 + 1 );
-	}
+	if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
 	else
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-	}
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 #else
-
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-
- #endif
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
+#endif
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
 
-	//	Channel Entry List
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Channel Entry List */
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_LINKED)
-		&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-	{
-		_adapter *pbuddy_adapter = padapter->pbuddy_adapter;	
-		struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+	if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+		u8 union_ch =  rtw_mi_get_union_chan(padapter);
 
-		//	Operating Class
-		if ( pbuddy_mlmeext->cur_channel > 14 )
-		{
-			if ( pbuddy_mlmeext->cur_channel >= 149 )
-			{
-				p2pie[ p2pielen++ ] = 0x7c;
-			}
+		/*	Operating Class */
+		if (union_ch > 14) {
+			if (union_ch >= 149)
+				p2pie[p2pielen++] = 0x7c;
 			else
-			{
-				p2pie[ p2pielen++ ] = 0x73;
-			}
-		}
-		else
-		{
-			p2pie[ p2pielen++ ] = 0x51;
-		}
-
-		//	Number of Channels
-		//	Just support 1 channel and this channel is AP's channel
-		p2pie[ p2pielen++ ] = 1;
+				p2pie[p2pielen++] = 0x73;
+		} else
+			p2pie[p2pielen++] = 0x51;
 
-		//	Channel List
-		p2pie[ p2pielen++ ] = pbuddy_mlmeext->cur_channel;
-	}
-	else
-	{
-		int i, j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+		/*	Number of Channels */
+		/*	Just support 1 channel and this channel is AP's channel */
+		p2pie[p2pielen++] = 1;
 
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
-		}
-	}
-#else // CONFIG_CONCURRENT_MODE
+		/*	Channel List */
+		p2pie[p2pielen++] = union_ch;
+	} else
+#endif /* CONFIG_CONCURRENT_MODE */
 	{
 		int i, j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
+		for (j = 0; j < ch_list->reg_classes; j++) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+			/*	Number of Channels */
+			p2pie[p2pielen++] = ch_list->reg_class[j].channels;
 
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
+			/*	Channel List */
+			for (i = 0; i < ch_list->reg_class[j].channels; i++)
+				p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
 		}
 	}
-#endif // CONFIG_CONCURRENT_MODE
 
 
-	//	P2P Group ID
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_ID;
+	/*	P2P Group ID */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 6 + pwdinfo->invitereq_info.ssidlen );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(6 + pwdinfo->invitereq_info.ssidlen);
 	p2pielen += 2;
 
-	//	Value:
-	//	P2P Device Address for GO
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->invitereq_info.go_bssid, ETH_ALEN );
+	/*	Value: */
+	/*	P2P Device Address for GO */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->invitereq_info.go_bssid, ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	SSID
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->invitereq_info.go_ssid, pwdinfo->invitereq_info.ssidlen );
+	/*	SSID */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->invitereq_info.go_ssid, pwdinfo->invitereq_info.ssidlen);
 	p2pielen += pwdinfo->invitereq_info.ssidlen;
-	
 
-	//	Device Info
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-	//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
+	/*	Device Info */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
+
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
 	p2pielen += 2;
-	
-	//	Value:
-	//	P2P Device Address
+
+	/*	Value: */
+	/*	P2P Device Address */
 	_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Config Method
-	//	This field should be big endian. Noted by P2P specification.
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_DISPLAY );
+	/*	Config Method */
+	/*	This field should be big endian. Noted by P2P specification. */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_DISPLAY);
 	p2pielen += 2;
 
-	//	Primary Device Type
-	//	Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+	/*	Primary Device Type */
+	/*	Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
 	p2pielen += 2;
 
-	//	OUI
-	*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
+	/*	OUI */
+	*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
 	p2pielen += 4;
 
-	//	Sub Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+	/*	Sub Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
 	p2pielen += 2;
 
-	//	Number of Secondary Device Types
-	p2pie[ p2pielen++ ] = 0x00;	//	No Secondary Device Type List
+	/*	Number of Secondary Device Types */
+	p2pie[p2pielen++] = 0x00;	/*	No Secondary Device Type List */
 
-	//	Device Name
-	//	Type:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+	/*	Device Name */
+	/*	Type: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 	p2pielen += 2;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len );
+	/*	Value: */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
 	p2pielen += pwdinfo->device_name_len;
-		
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen );	
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
 
 #ifdef CONFIG_WFD
 	wfdielen = build_invitation_req_wfd_ie(pwdinfo, pframe);
@@ -5306,27 +5503,21 @@ void issue_p2p_invitation_request(_adapter *padapter, u8* raddr )
 
 }
 
-void issue_p2p_invitation_response(_adapter *padapter, u8* raddr, u8 dialogToken, u8 status_code)
+void issue_p2p_invitation_response(_adapter *padapter, u8 *raddr, u8 dialogToken, u8 status_code)
 {
-
+	struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_INVIT_RESP;
-	u8			p2pie[ 255 ] = { 0x00 };
+	u8			p2pie[255] = { 0x00 };
 	u8			p2pielen = 0, i;
 	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
 	u16			len_channellist_attr = 0;
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-	struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif	
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
-	
+
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
@@ -5335,15 +5526,14 @@ void issue_p2p_invitation_response(_adapter *padapter, u8* raddr, u8 dialogToken
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -5361,7 +5551,7 @@ void issue_p2p_invitation_response(_adapter *padapter, u8* raddr, u8 dialogToken
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -5369,210 +5559,173 @@ void issue_p2p_invitation_response(_adapter *padapter, u8* raddr, u8 dialogToken
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
 
-	//	P2P IE Section.
+	/*	P2P IE Section. */
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20101005
-	//	According to the P2P Specification, the P2P Invitation response frame should contain 5 P2P attributes
-	//	1. Status
-	//	2. Configuration Timeout
-	//	3. Operating Channel	( Only GO )
-	//	4. P2P Group BSSID	( Only GO )
-	//	5. Channel List
-
-	//	P2P Status
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_STATUS;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20101005 */
+	/*	According to the P2P Specification, the P2P Invitation response frame should contain 5 P2P attributes */
+	/*	1. Status */
+	/*	2. Configuration Timeout */
+	/*	3. Operating Channel	( Only GO ) */
+	/*	4. P2P Group BSSID	( Only GO ) */
+	/*	5. Channel List */
+
+	/*	P2P Status */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_STATUS;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value:
-	//	When status code is P2P_STATUS_FAIL_INFO_UNAVAILABLE.
-	//	Sent the event receiving the P2P Invitation Req frame to DMP UI.
-	//	DMP had to compare the MAC address to find out the profile.
-	//	So, the WiFi driver will send the P2P_STATUS_FAIL_INFO_UNAVAILABLE to NB.
-	//	If the UI found the corresponding profile, the WiFi driver sends the P2P Invitation Req
-	//	to NB to rebuild the persistent group.
-	p2pie[ p2pielen++ ] = status_code;
-	
-	//	Configuration Timeout
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CONF_TIMEOUT;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	Value: */
+	/*	When status code is P2P_STATUS_FAIL_INFO_UNAVAILABLE. */
+	/*	Sent the event receiving the P2P Invitation Req frame to DMP UI. */
+	/*	DMP had to compare the MAC address to find out the profile. */
+	/*	So, the WiFi driver will send the P2P_STATUS_FAIL_INFO_UNAVAILABLE to NB. */
+	/*	If the UI found the corresponding profile, the WiFi driver sends the P2P Invitation Req */
+	/*	to NB to rebuild the persistent group. */
+	p2pie[p2pielen++] = status_code;
+
+	/*	Configuration Timeout */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P GO
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P Client
+	/*	Value: */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P GO */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P Client */
 
-	if( status_code == P2P_STATUS_SUCCESS )
-	{
-		if( rtw_p2p_chk_role( pwdinfo, P2P_ROLE_GO ) )
-		{
-			//	The P2P Invitation request frame asks this Wi-Fi device to be the P2P GO
-			//	In this case, the P2P Invitation response frame should carry the two more P2P attributes.
-			//	First one is operating channel attribute.
-			//	Second one is P2P Group BSSID attribute.
+	if (status_code == P2P_STATUS_SUCCESS) {
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+			/*	The P2P Invitation request frame asks this Wi-Fi device to be the P2P GO */
+			/*	In this case, the P2P Invitation response frame should carry the two more P2P attributes. */
+			/*	First one is operating channel attribute. */
+			/*	Second one is P2P Group BSSID attribute. */
 
-			//	Operating Channel
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
+			/*	Operating Channel */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 			p2pielen += 2;
 
-			//	Value:
-			//	Country String
-			p2pie[ p2pielen++ ] = 'X';
-			p2pie[ p2pielen++ ] = 'X';
-		
-			//	The third byte should be set to 0x04.
-			//	Described in the "Operating Channel Attribute" section.
-			p2pie[ p2pielen++ ] = 0x04;
+			/*	Value: */
+			/*	Country String */
+			p2pie[p2pielen++] = 'X';
+			p2pie[p2pielen++] = 'X';
 
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x51;	//	Copy from SD7
-		
-			//	Channel Number
-			p2pie[ p2pielen++ ] = pwdinfo->operating_channel;	//	operating channel number
-			
+			/*	The third byte should be set to 0x04. */
+			/*	Described in the "Operating Channel Attribute" section. */
+			p2pie[p2pielen++] = 0x04;
+
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x51;	/*	Copy from SD7 */
+
+			/*	Channel Number */
+			p2pie[p2pielen++] = pwdinfo->operating_channel;	/*	operating channel number */
 
-			//	P2P Group BSSID
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_BSSID;
 
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN );
+			/*	P2P Group BSSID */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_GROUP_BSSID;
+
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
 			p2pielen += 2;
 
-			//	Value:
-			//	P2P Device Address for GO
+			/*	Value: */
+			/*	P2P Device Address for GO */
 			_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 			p2pielen += ETH_ALEN;
 
 		}
 
-		//	Channel List
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_CH_LIST;
+		/*	Channel List */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
 
-		//	Length:
-		// Country String(3)
-		// + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?)
-		// + number of channels in all classes
+		/*	Length: */
+		/* Country String(3) */
+		/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
+		/* + number of channels in all classes */
 		len_channellist_attr = 3
-			+ (1 + 1) * (u16)pmlmeext->channel_list.reg_classes
-			+ get_reg_classes_full_count(pmlmeext->channel_list);
+			+ (1 + 1) * (u16)ch_list->reg_classes
+			+ get_reg_classes_full_count(ch_list);
 
 #ifdef CONFIG_CONCURRENT_MODE
-		if (check_buddy_fwstate(padapter, _FW_LINKED)
-			&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-		{
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 5 + 1 );
-		}
+		if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
 		else
-		{
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-		}
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 #else
-
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 #endif
 		p2pielen += 2;
 
-		//	Value:
-		//	Country String
-		p2pie[ p2pielen++ ] = 'X';
-		p2pie[ p2pielen++ ] = 'X';
+		/*	Value: */
+		/*	Country String */
+		p2pie[p2pielen++] = 'X';
+		p2pie[p2pielen++] = 'X';
 
-		//	The third byte should be set to 0x04.
-		//	Described in the "Operating Channel Attribute" section.
-		p2pie[ p2pielen++ ] = 0x04;
+		/*	The third byte should be set to 0x04. */
+		/*	Described in the "Operating Channel Attribute" section. */
+		p2pie[p2pielen++] = 0x04;
 
-		//	Channel Entry List
+		/*	Channel Entry List */
 #ifdef CONFIG_CONCURRENT_MODE
-		if (check_buddy_fwstate(padapter , _FW_LINKED)
-			&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-		{
-			_adapter *pbuddy_adapter = padapter->pbuddy_adapter;	
-			struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+		if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
 
-			//	Operating Class
-			if ( pbuddy_mlmeext->cur_channel > 14 )
-			{
-				if ( pbuddy_mlmeext->cur_channel >= 149 )
-				{
-					p2pie[ p2pielen++ ] = 0x7c;
-				}
+			/*	Operating Class */
+			if (union_ch > 14) {
+				if (union_ch >= 149)
+					p2pie[p2pielen++]  = 0x7c;
 				else
-				{
-					p2pie[ p2pielen++ ] = 0x73;
-				}
-			}
-			else
-			{
-				p2pie[ p2pielen++ ] = 0x51;
-			}
-
-			//	Number of Channels
-			//	Just support 1 channel and this channel is AP's channel
-			p2pie[ p2pielen++ ] = 1;
+					p2pie[p2pielen++] = 0x73;
+			} else
+				p2pie[p2pielen++] = 0x51;
 
-			//	Channel List
-			p2pie[ p2pielen++ ] = pbuddy_mlmeext->cur_channel;
-		}
-		else
-		{
-			int i, j;
-			for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-				//	Operating Class
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
 
-				//	Number of Channels
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+			/*	Number of Channels */
+			/*	Just support 1 channel and this channel is AP's channel */
+			p2pie[p2pielen++] = 1;
 
-				//	Channel List
-				for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-					p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-				}
-			}
-		}
-#else // CONFIG_CONCURRENT_MODE
+			/*	Channel List */
+			p2pie[p2pielen++] = union_ch;
+		} else
+#endif /* CONFIG_CONCURRENT_MODE */
 		{
 			int i, j;
-			for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-				//	Operating Class
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
+			for (j = 0; j < ch_list->reg_classes; j++) {
+				/*	Operating Class */
+				p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
 
-				//	Number of Channels
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+				/*	Number of Channels */
+				p2pie[p2pielen++] = ch_list->reg_class[j].channels;
 
-				//	Channel List
-				for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-					p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-				}
+				/*	Channel List */
+				for (i = 0; i < ch_list->reg_class[j].channels; i++)
+					p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
 			}
 		}
-#endif // CONFIG_CONCURRENT_MODE
 	}
-		
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen );	
-	
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
+
 #ifdef CONFIG_WFD
 	wfdielen = build_invitation_resp_wfd_ie(pwdinfo, pframe);
 	pframe += wfdielen;
@@ -5587,20 +5740,20 @@ void issue_p2p_invitation_response(_adapter *padapter, u8* raddr, u8 dialogToken
 
 }
 
-void issue_p2p_provision_request(_adapter *padapter, u8* pssid, u8 ussidlen, u8* pdev_raddr )
+void issue_p2p_provision_request(_adapter *padapter, u8 *pssid, u8 ussidlen, u8 *pdev_raddr)
 {
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u8			dialogToken = 1;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_PROVISION_DISC_REQ;
-	u8			wpsie[ 100 ] = { 0x00 };
+	u8			wpsie[100] = { 0x00 };
 	u8			wpsielen = 0;
 	u32			p2pielen = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
-	
+
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
@@ -5612,13 +5765,12 @@ void issue_p2p_provision_request(_adapter *padapter, u8* pssid, u8 ussidlen, u8*
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	DBG_871X( "[%s] In\n", __FUNCTION__ );
-	//update attribute
+	RTW_INFO("[%s] In\n", __FUNCTION__);
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -5636,7 +5788,7 @@ void issue_p2p_provision_request(_adapter *padapter, u8* pssid, u8 ussidlen, u8*
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -5644,45 +5796,45 @@ void issue_p2p_provision_request(_adapter *padapter, u8* pssid, u8 ussidlen, u8*
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));		
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
 
-	p2pielen = build_prov_disc_request_p2p_ie( pwdinfo, pframe, pssid, ussidlen, pdev_raddr );
+	p2pielen = build_prov_disc_request_p2p_ie(pwdinfo, pframe, pssid, ussidlen, pdev_raddr);
 
 	pframe += p2pielen;
 	pattrib->pktlen += p2pielen;
 
 	wpsielen = 0;
-	//	WPS OUI
-	*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+	/*	WPS OUI */
+	*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
 	wpsielen += 4;
 
-	//	WPS version
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 	wpsielen += 2;
 
-	//	Value:
-	wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 
-	//	Config Method
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD );
+	/*	Config Method */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 	wpsielen += 2;
 
-	//	Value:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->tx_prov_disc_info.wps_config_method_request );
+	/*	Value: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->tx_prov_disc_info.wps_config_method_request);
 	wpsielen += 2;
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen );
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
 
 
 #ifdef CONFIG_WFD
@@ -5700,26 +5852,24 @@ void issue_p2p_provision_request(_adapter *padapter, u8* pssid, u8 ussidlen, u8*
 }
 
 
-u8 is_matched_in_profilelist( u8* peermacaddr, struct profile_info* profileinfo )
+u8 is_matched_in_profilelist(u8 *peermacaddr, struct profile_info *profileinfo)
 {
 	u8 i, match_result = 0;
 
-	DBG_871X( "[%s] peermac = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
-	  	    peermacaddr[0], peermacaddr[1],peermacaddr[2],peermacaddr[3],peermacaddr[4],peermacaddr[5]);
-	
-	for( i = 0; i < P2P_MAX_PERSISTENT_GROUP_NUM; i++, profileinfo++ )
-	{
-	       DBG_871X( "[%s] profileinfo_mac = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
-		   	    profileinfo->peermac[0], profileinfo->peermac[1],profileinfo->peermac[2],profileinfo->peermac[3],profileinfo->peermac[4],profileinfo->peermac[5]);		   
-		if ( _rtw_memcmp( peermacaddr, profileinfo->peermac, ETH_ALEN ) )
-		{
+	RTW_INFO("[%s] peermac = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
+		peermacaddr[0], peermacaddr[1], peermacaddr[2], peermacaddr[3], peermacaddr[4], peermacaddr[5]);
+
+	for (i = 0; i < P2P_MAX_PERSISTENT_GROUP_NUM; i++, profileinfo++) {
+		RTW_INFO("[%s] profileinfo_mac = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
+			profileinfo->peermac[0], profileinfo->peermac[1], profileinfo->peermac[2], profileinfo->peermac[3], profileinfo->peermac[4], profileinfo->peermac[5]);
+		if (_rtw_memcmp(peermacaddr, profileinfo->peermac, ETH_ALEN)) {
 			match_result = 1;
-			DBG_871X( "[%s] Match!\n", __FUNCTION__ );
+			RTW_INFO("[%s] Match!\n", __FUNCTION__);
 			break;
 		}
 	}
-	
-	return (match_result );
+
+	return match_result ;
 }
 
 void issue_probersp_p2p(_adapter *padapter, unsigned char *da)
@@ -5728,13 +5878,13 @@ void issue_probersp_p2p(_adapter *padapter, unsigned char *da)
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short				*fctrl;	
+	unsigned short				*fctrl;
 	unsigned char					*mac;
 	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	//WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	/* WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network); */
 	u16					beacon_interval = 100;
 	u16					capInfo = 0;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
@@ -5745,291 +5895,290 @@ void issue_probersp_p2p(_adapter *padapter, unsigned char *da)
 #endif
 #ifdef CONFIG_INTEL_WIDI
 	u8 zero_array_check[L2SDTA_SERVICE_VE_LEN] = { 0x00 };
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-	//DBG_871X("%s\n", __FUNCTION__);
-	
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
-	
-	//update attribute
+
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);	
-	
+	update_mgntframe_attrib(padapter, pattrib);
+
+	if (IS_CCK_RATE(pattrib->rate)) {
+		/* force OFDM 6M rate */
+		pattrib->rate = MGN_6M;
+		pattrib->raid = rtw_get_mgntframe_raid(padapter, WIRELESS_11G);
+	}
+
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-		
+
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;	
-	
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
 	mac = adapter_mac_addr(padapter);
-	
+
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
-	
-	//	Use the device address for BSSID field.	
+
+	/*	Use the device address for BSSID field.	 */
 	_rtw_memcpy(pwlanhdr->addr3, mac, ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(fctrl, WIFI_PROBERSP);
-	
+	set_frame_sub_type(fctrl, WIFI_PROBERSP);
+
 	pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = pattrib->hdrlen;
 	pframe += pattrib->hdrlen;
 
-	//timestamp will be inserted by hardware
+	/* timestamp will be inserted by hardware */
 	pframe += 8;
 	pattrib->pktlen += 8;
 
-	// beacon interval: 2 bytes
-	_rtw_memcpy(pframe, (unsigned char *) &beacon_interval, 2); 
+	/* beacon interval: 2 bytes */
+	_rtw_memcpy(pframe, (unsigned char *) &beacon_interval, 2);
 	pframe += 2;
 	pattrib->pktlen += 2;
 
-	//	capability info: 2 bytes
-	//	ESS and IBSS bits must be 0 (defined in the 3.1.2.1.1 of WiFi Direct Spec)
+	/*	capability info: 2 bytes */
+	/*	ESS and IBSS bits must be 0 (defined in the 3.1.2.1.1 of WiFi Direct Spec) */
 	capInfo |= cap_ShortPremble;
 	capInfo |= cap_ShortSlot;
-	
+
 	_rtw_memcpy(pframe, (unsigned char *) &capInfo, 2);
 	pframe += 2;
 	pattrib->pktlen += 2;
 
 
-	// SSID
+	/* SSID */
 	pframe = rtw_set_ie(pframe, _SSID_IE_, 7, pwdinfo->p2p_wildcard_ssid, &pattrib->pktlen);
 
-	// supported rates...
-	//	Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 )
+	/* supported rates... */
+	/*	Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 ) */
 	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pwdinfo->support_rate, &pattrib->pktlen);
 
-	// DS parameter set
+	/* DS parameter set */
 	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&pwdinfo->listen_channel, &pattrib->pktlen);
 
 #ifdef CONFIG_IOCTL_CFG80211
-	if(adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211 )
-	{
-		if( pmlmepriv->wps_probe_resp_ie != NULL && pmlmepriv->p2p_probe_resp_ie != NULL )
-		{
-			//WPS IE
+	if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (pmlmepriv->wps_probe_resp_ie != NULL && pmlmepriv->p2p_probe_resp_ie != NULL) {
+			/* WPS IE */
 			_rtw_memcpy(pframe, pmlmepriv->wps_probe_resp_ie, pmlmepriv->wps_probe_resp_ie_len);
 			pattrib->pktlen += pmlmepriv->wps_probe_resp_ie_len;
 			pframe += pmlmepriv->wps_probe_resp_ie_len;
 
-			//P2P IE
+			/* P2P IE */
 			_rtw_memcpy(pframe, pmlmepriv->p2p_probe_resp_ie, pmlmepriv->p2p_probe_resp_ie_len);
 			pattrib->pktlen += pmlmepriv->p2p_probe_resp_ie_len;
 			pframe += pmlmepriv->p2p_probe_resp_ie_len;
 		}
-	}
-	else
-#endif //CONFIG_IOCTL_CFG80211		
+	} else
+#endif /* CONFIG_IOCTL_CFG80211		 */
 	{
 
-		//	Todo: WPS IE
-		//	Noted by Albert 20100907
-		//	According to the WPS specification, all the WPS attribute is presented by Big Endian.
+		/*	Todo: WPS IE */
+		/*	Noted by Albert 20100907 */
+		/*	According to the WPS specification, all the WPS attribute is presented by Big Endian. */
 
 		wpsielen = 0;
-		//	WPS OUI
-		*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+		/*	WPS OUI */
+		*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
 		wpsielen += 4;
 
-		//	WPS version
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+		/*	WPS version */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
-		wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+		/*	Value: */
+		wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 
 #ifdef CONFIG_INTEL_WIDI
-		//	Commented by Kurt
-		//	Appended WiDi info. only if we did issued_probereq_widi(), and then we saved ven. ext. in pmlmepriv->sa_ext.
-		if(  _rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE 
-			|| pmlmepriv->num_p2p_sdt != 0 )
-		{
-			//Sec dev type
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_SEC_DEV_TYPE_LIST );
+		/*	Commented by Kurt */
+		/*	Appended WiDi info. only if we did issued_probereq_widi(), and then we saved ven. ext. in pmlmepriv->sa_ext. */
+		if (_rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE
+		    || pmlmepriv->num_p2p_sdt != 0) {
+			/* Sec dev type */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SEC_DEV_TYPE_LIST);
 			wpsielen += 2;
 
-			//	Length:
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0008 );
+			/*	Length: */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
 			wpsielen += 2;
 
-			//	Value:
-			//	Category ID
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_CID_DISPLAYS );
+			/*	Value: */
+			/*	Category ID */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_DISPLAYS);
 			wpsielen += 2;
 
-			//	OUI
-			*(u32*) ( wpsie + wpsielen ) = cpu_to_be32( INTEL_DEV_TYPE_OUI );
+			/*	OUI */
+			*(u32 *)(wpsie + wpsielen) = cpu_to_be32(INTEL_DEV_TYPE_OUI);
 			wpsielen += 4;
 
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_SCID_WIDI_CONSUMER_SINK );
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_WIDI_CONSUMER_SINK);
 			wpsielen += 2;
 
-			if(  _rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE )
-			{
-				//	Vendor Extension
-				_rtw_memcpy( wpsie + wpsielen, pmlmepriv->sa_ext, L2SDTA_SERVICE_VE_LEN );
+			if (_rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE) {
+				/*	Vendor Extension */
+				_rtw_memcpy(wpsie + wpsielen, pmlmepriv->sa_ext, L2SDTA_SERVICE_VE_LEN);
 				wpsielen += L2SDTA_SERVICE_VE_LEN;
 			}
 		}
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-		//	WiFi Simple Config State
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_SIMPLE_CONF_STATE );
+		/*	WiFi Simple Config State */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SIMPLE_CONF_STATE);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
-		wpsie[wpsielen++] = WPS_WSC_STATE_NOT_CONFIG;	//	Not Configured.
+		/*	Value: */
+		wpsie[wpsielen++] = WPS_WSC_STATE_NOT_CONFIG;	/*	Not Configured. */
 
-		//	Response Type
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_RESP_TYPE );
+		/*	Response Type */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_RESP_TYPE);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
+		/*	Value: */
 		wpsie[wpsielen++] = WPS_RESPONSE_TYPE_8021X;
 
-		//	UUID-E
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_UUID_E );
+		/*	UUID-E */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_UUID_E);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0010 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0010);
 		wpsielen += 2;
 
-		//	Value:
+		/*	Value: */
 		if (pwdinfo->external_uuid == 0) {
-			_rtw_memset( wpsie + wpsielen, 0x0, 16 );
+			_rtw_memset(wpsie + wpsielen, 0x0, 16);
 			_rtw_memcpy(wpsie + wpsielen, mac, ETH_ALEN);
-		} else {
-			_rtw_memcpy( wpsie + wpsielen, pwdinfo->uuid, 0x10 );
-		}
+		} else
+			_rtw_memcpy(wpsie + wpsielen, pwdinfo->uuid, 0x10);
 		wpsielen += 0x10;
 
-		//	Manufacturer
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_MANUFACTURER );
+		/*	Manufacturer */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MANUFACTURER);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0007 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0007);
 		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, "Realtek", 7 );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, "Realtek", 7);
 		wpsielen += 7;
 
-		//	Model Name
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_MODEL_NAME );
+		/*	Model Name */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NAME);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0006 );
-		wpsielen += 2;	
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0006);
+		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, "8192CU", 6 );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, "8192CU", 6);
 		wpsielen += 6;
 
-		//	Model Number
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_MODEL_NUMBER );
+		/*	Model Number */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NUMBER);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
-		wpsie[ wpsielen++ ] = 0x31;		//	character 1
+		/*	Value: */
+		wpsie[wpsielen++] = 0x31;		/*	character 1 */
 
-		//	Serial Number
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_SERIAL_NUMBER );
+		/*	Serial Number */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SERIAL_NUMBER);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( ETH_ALEN );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(ETH_ALEN);
 		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, "123456" , ETH_ALEN );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, "123456" , ETH_ALEN);
 		wpsielen += ETH_ALEN;
 
-		//	Primary Device Type
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_PRIMARY_DEV_TYPE );
+		/*	Primary Device Type */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0008 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
 		wpsielen += 2;
 
-		//	Value:
-		//	Category ID
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+		/*	Value: */
+		/*	Category ID */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
 		wpsielen += 2;
 
-		//	OUI
-		*(u32*) ( wpsie + wpsielen ) = cpu_to_be32( WPSOUI );
+		/*	OUI */
+		*(u32 *)(wpsie + wpsielen) = cpu_to_be32(WPSOUI);
 		wpsielen += 4;
 
-		//	Sub Category ID
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+		/*	Sub Category ID */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
 		wpsielen += 2;
 
-		//	Device Name
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+		/*	Device Name */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->device_name_len );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->device_name_len);
 		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len);
 		wpsielen += pwdinfo->device_name_len;
 
-		//	Config Method
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD );
+		/*	Config Method */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 		wpsielen += 2;
 
-		//	Value:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->supported_wps_cm );
+		/*	Value: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
 		wpsielen += 2;
-		
 
-		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen );
-		
+
+		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
+
 
 		p2pielen = build_probe_resp_p2p_ie(pwdinfo, pframe);
 		pframe += p2pielen;
@@ -6043,10 +6192,10 @@ void issue_probersp_p2p(_adapter *padapter, unsigned char *da)
 #endif
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
-	
+
 
 	dump_mgntframe(padapter, pmgntframe);
-	
+
 	return;
 
 }
@@ -6066,8 +6215,8 @@ int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	int	bssrate_len = 0;
 	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);	
-	u8					wpsie[255] = { 0x00 }, p2pie[ 255 ] = { 0x00 };
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
 	u16					wpsielen = 0, p2pielen = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
@@ -6076,15 +6225,19 @@ int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		goto exit;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
+	if (IS_CCK_RATE(pattrib->rate)) {
+		/* force OFDM 6M rate */
+		pattrib->rate = MGN_6M;
+		pattrib->raid = rtw_get_mgntframe_raid(padapter, WIRELESS_11G);
+	}
 
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
@@ -6100,15 +6253,12 @@ int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
 		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
 		_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
 	} else {
-		if ( ( pwdinfo->p2p_info.scan_op_ch_only ) || ( pwdinfo->rx_invitereq_info.scan_op_ch_only ) )
-		{
-			//	This two flags will be set when this is only the P2P client mode.
+		if ((pwdinfo->p2p_info.scan_op_ch_only) || (pwdinfo->rx_invitereq_info.scan_op_ch_only)) {
+			/*	This two flags will be set when this is only the P2P client mode. */
 			_rtw_memcpy(pwlanhdr->addr1, pwdinfo->p2p_peer_interface_addr, ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr3, pwdinfo->p2p_peer_interface_addr, ETH_ALEN);
-		}
-		else
-		{
-			//	broadcast probe request frame
+		} else {
+			/*	broadcast probe request frame */
 			_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr3, bc_addr, ETH_ALEN);
 		}
@@ -6117,249 +6267,239 @@ int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_PROBEREQ);
+	set_frame_sub_type(pframe, WIFI_PROBEREQ);
 
-	pframe += sizeof (struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof (struct rtw_ieee80211_hdr_3addr);
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ))
-	{
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ))
 		pframe = rtw_set_ie(pframe, _SSID_IE_, pwdinfo->tx_prov_disc_info.ssid.SsidLength, pwdinfo->tx_prov_disc_info.ssid.Ssid, &(pattrib->pktlen));
-	}
 	else
-	{
 		pframe = rtw_set_ie(pframe, _SSID_IE_, P2P_WILDCARD_SSID_LEN, pwdinfo->p2p_wildcard_ssid, &(pattrib->pktlen));
-	}
-	//	Use the OFDM rate in the P2P probe request frame. ( 6(B), 9(B), 12(B), 24(B), 36, 48, 54 )
+	/*	Use the OFDM rate in the P2P probe request frame. ( 6(B), 9(B), 12(B), 24(B), 36, 48, 54 ) */
 	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pwdinfo->support_rate, &pattrib->pktlen);
 
 #ifdef CONFIG_IOCTL_CFG80211
-	if(adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211 )
-	{
-		if( pmlmepriv->wps_probe_req_ie != NULL && pmlmepriv->p2p_probe_req_ie != NULL )
-		{
-			//WPS IE
+	if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (pmlmepriv->wps_probe_req_ie != NULL && pmlmepriv->p2p_probe_req_ie != NULL) {
+			/* WPS IE */
 			_rtw_memcpy(pframe, pmlmepriv->wps_probe_req_ie, pmlmepriv->wps_probe_req_ie_len);
 			pattrib->pktlen += pmlmepriv->wps_probe_req_ie_len;
 			pframe += pmlmepriv->wps_probe_req_ie_len;
 
-			//P2P IE
+			/* P2P IE */
 			_rtw_memcpy(pframe, pmlmepriv->p2p_probe_req_ie, pmlmepriv->p2p_probe_req_ie_len);
 			pattrib->pktlen += pmlmepriv->p2p_probe_req_ie_len;
 			pframe += pmlmepriv->p2p_probe_req_ie_len;
 		}
-	}
-	else
-#endif //CONFIG_IOCTL_CFG80211
+	} else
+#endif /* CONFIG_IOCTL_CFG80211 */
 	{
 
-		//	WPS IE
-		//	Noted by Albert 20110221
-		//	According to the WPS specification, all the WPS attribute is presented by Big Endian.
+		/*	WPS IE */
+		/*	Noted by Albert 20110221 */
+		/*	According to the WPS specification, all the WPS attribute is presented by Big Endian. */
 
 		wpsielen = 0;
-		//	WPS OUI
-		*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+		/*	WPS OUI */
+		*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
 		wpsielen += 4;
 
-		//	WPS version
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+		/*	WPS version */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
-		wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+		/*	Value: */
+		wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 
-		if( pmlmepriv->wps_probe_req_ie == NULL )
-		{
-			//	UUID-E
-			//	Type:
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_UUID_E );
+		if (pmlmepriv->wps_probe_req_ie == NULL) {
+			/*	UUID-E */
+			/*	Type: */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_UUID_E);
 			wpsielen += 2;
 
-			//	Length:
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0010 );
+			/*	Length: */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0010);
 			wpsielen += 2;
 
-			//	Value:
+			/*	Value: */
 			if (pwdinfo->external_uuid == 0) {
-				_rtw_memset( wpsie + wpsielen, 0x0, 16 );
+				_rtw_memset(wpsie + wpsielen, 0x0, 16);
 				_rtw_memcpy(wpsie + wpsielen, mac, ETH_ALEN);
-			} else {
-				_rtw_memcpy( wpsie + wpsielen, pwdinfo->uuid, 0x10 );
-			}
+			} else
+				_rtw_memcpy(wpsie + wpsielen, pwdinfo->uuid, 0x10);
 			wpsielen += 0x10;
 
-			//	Config Method
-			//	Type:
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD );
+			/*	Config Method */
+			/*	Type: */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
 			wpsielen += 2;
 
-			//	Length:
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+			/*	Length: */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 			wpsielen += 2;
 
-			//	Value:
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->supported_wps_cm );
+			/*	Value: */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
 			wpsielen += 2;
 		}
 
-		//	Device Name
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+		/*	Device Name */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->device_name_len );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->device_name_len);
 		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len);
 		wpsielen += pwdinfo->device_name_len;
 
-		//	Primary Device Type
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_PRIMARY_DEV_TYPE );
+		/*	Primary Device Type */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0008 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
 		wpsielen += 2;
 
-		//	Value:
-		//	Category ID
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_CID_RTK_WIDI );
+		/*	Value: */
+		/*	Category ID */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_RTK_WIDI);
 		wpsielen += 2;
 
-		//	OUI
-		*(u32*) ( wpsie + wpsielen ) = cpu_to_be32( WPSOUI );
+		/*	OUI */
+		*(u32 *)(wpsie + wpsielen) = cpu_to_be32(WPSOUI);
 		wpsielen += 4;
 
-		//	Sub Category ID
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_SCID_RTK_DMP );
+		/*	Sub Category ID */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_RTK_DMP);
 		wpsielen += 2;
 
-		//	Device Password ID
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_DEVICE_PWID );
+		/*	Device Password ID */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 		wpsielen += 2;
 
-		//	Value:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_REGISTRAR_SPEC );	//	Registrar-specified
-		wpsielen += 2;	
+		/*	Value: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC);	/*	Registrar-specified */
+		wpsielen += 2;
 
-		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen );
-		
-		//	P2P OUI
+		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
+
+		/*	P2P OUI */
 		p2pielen = 0;
-		p2pie[ p2pielen++ ] = 0x50;
-		p2pie[ p2pielen++ ] = 0x6F;
-		p2pie[ p2pielen++ ] = 0x9A;
-		p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-		//	Commented by Albert 20110221
-		//	According to the P2P Specification, the probe request frame should contain 5 P2P attributes
-		//	1. P2P Capability
-		//	2. P2P Device ID if this probe request wants to find the specific P2P device
-		//	3. Listen Channel
-		//	4. Extended Listen Timing
-		//	5. Operating Channel if this WiFi is working as the group owner now
-
-		//	P2P Capability
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
-
-		//	Length:
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+		p2pie[p2pielen++] = 0x50;
+		p2pie[p2pielen++] = 0x6F;
+		p2pie[p2pielen++] = 0x9A;
+		p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+		/*	Commented by Albert 20110221 */
+		/*	According to the P2P Specification, the probe request frame should contain 5 P2P attributes */
+		/*	1. P2P Capability */
+		/*	2. P2P Device ID if this probe request wants to find the specific P2P device */
+		/*	3. Listen Channel */
+		/*	4. Extended Listen Timing */
+		/*	5. Operating Channel if this WiFi is working as the group owner now */
+
+		/*	P2P Capability */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+		/*	Length: */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 		p2pielen += 2;
 
-		//	Value:
-		//	Device Capability Bitmap, 1 byte
-		p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
-		
-		//	Group Capability Bitmap, 1 byte
-		if ( pwdinfo->persistent_supported )
-			p2pie[ p2pielen++ ] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
+		/*	Value: */
+		/*	Device Capability Bitmap, 1 byte */
+		p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
+
+		/*	Group Capability Bitmap, 1 byte */
+		if (pwdinfo->persistent_supported)
+			p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
 		else
-			p2pie[ p2pielen++ ] = DMP_P2P_GRPCAP_SUPPORT;
+			p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
 
-		//	Listen Channel
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_LISTEN_CH;
+		/*	Listen Channel */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_LISTEN_CH;
 
-		//	Length:
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+		/*	Length: */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 		p2pielen += 2;
 
-		//	Value:
-		//	Country String
-		p2pie[ p2pielen++ ] = 'X';
-		p2pie[ p2pielen++ ] = 'X';
-		
-		//	The third byte should be set to 0x04.
-		//	Described in the "Operating Channel Attribute" section.
-		p2pie[ p2pielen++ ] = 0x04;
+		/*	Value: */
+		/*	Country String */
+		p2pie[p2pielen++] = 'X';
+		p2pie[p2pielen++] = 'X';
 
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x51;	//	Copy from SD7
-		
-		//	Channel Number
-		p2pie[ p2pielen++ ] = pwdinfo->listen_channel;	//	listen channel
-		
+		/*	The third byte should be set to 0x04. */
+		/*	Described in the "Operating Channel Attribute" section. */
+		p2pie[p2pielen++] = 0x04;
 
-		//	Extended Listen Timing
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_EX_LISTEN_TIMING;
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x51;	/*	Copy from SD7 */
 
-		//	Length:
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0004 );
+		/*	Channel Number */
+		p2pie[p2pielen++] = pwdinfo->listen_channel;	/*	listen channel */
+
+
+		/*	Extended Listen Timing */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
+
+		/*	Length: */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0004);
 		p2pielen += 2;
 
-		//	Value:
-		//	Availability Period
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
+		/*	Value: */
+		/*	Availability Period */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
 		p2pielen += 2;
 
-		//	Availability Interval
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
+		/*	Availability Interval */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
 		p2pielen += 2;
 
-		if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) )
-		{
-			//	Operating Channel (if this WiFi is working as the group owner now)
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+			/*	Operating Channel (if this WiFi is working as the group owner now) */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 			p2pielen += 2;
 
-			//	Value:
-			//	Country String
-			p2pie[ p2pielen++ ] = 'X';
-			p2pie[ p2pielen++ ] = 'X';
-		
-			//	The third byte should be set to 0x04.
-			//	Described in the "Operating Channel Attribute" section.
-			p2pie[ p2pielen++ ] = 0x04;
+			/*	Value: */
+			/*	Country String */
+			p2pie[p2pielen++] = 'X';
+			p2pie[p2pielen++] = 'X';
+
+			/*	The third byte should be set to 0x04. */
+			/*	Described in the "Operating Channel Attribute" section. */
+			p2pie[p2pielen++] = 0x04;
+
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x51;	/*	Copy from SD7 */
+
+			/*	Channel Number */
+			p2pie[p2pielen++] = pwdinfo->operating_channel;	/*	operating channel number */
 
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x51;	//	Copy from SD7
-		
-			//	Channel Number
-			p2pie[ p2pielen++ ] = pwdinfo->operating_channel;	//	operating channel number
-			
 		}
-		
-		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen );	
+
+		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
 
 	}
 
@@ -6371,11 +6511,10 @@ int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("issuing probe_req, tx_len=%d\n", pattrib->last_txcmdsz));
 
-	if (wait_ack) {
+	if (wait_ack)
 		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	} else {
+	else {
 		dump_mgntframe(padapter, pmgntframe);
 		ret = _SUCCESS;
 	}
@@ -6398,58 +6537,57 @@ int issue_probereq_p2p_ex(_adapter *adapter, u8 *da, int try_cnt, int wait_ms)
 {
 	int ret;
 	int i = 0;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 
-	do
-	{
-		ret = _issue_probereq_p2p(adapter, da, wait_ms>0?_TRUE:_FALSE);
+	do {
+		ret = _issue_probereq_p2p(adapter, da, wait_ms > 0 ? _TRUE : _FALSE);
 
 		i++;
 
 		if (RTW_CANNOT_RUN(adapter))
 			break;
 
-		if(i < try_cnt && wait_ms > 0 && ret==_FAIL)
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
 			rtw_msleep_os(wait_ms);
 
-	}while((i<try_cnt) && ((ret==_FAIL)||(wait_ms==0)));
+	} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
 
 	if (ret != _FAIL) {
 		ret = _SUCCESS;
-		#ifndef DBG_XMIT_ACK
+#ifndef DBG_XMIT_ACK
 		goto exit;
-		#endif
+#endif
 	}
 
 	if (try_cnt && wait_ms) {
 		if (da)
-			DBG_871X(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
+			RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
 				FUNC_ADPT_ARG(adapter), MAC_ARG(da), rtw_get_oper_ch(adapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
 		else
-			DBG_871X(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
+			RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
 				FUNC_ADPT_ARG(adapter), rtw_get_oper_ch(adapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
 	}
 exit:
 	return ret;
 }
 
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 s32 rtw_action_public_decache(union recv_frame *rframe, u8 token_offset)
 {
 	_adapter *adapter = rframe->u.hdr.adapter;
 	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
 	u8 *frame = rframe->u.hdr.rx_data;
-	u16 seq_ctrl = ((rframe->u.hdr.attrib.seq_num&0xffff) << 4) | (rframe->u.hdr.attrib.frag_num & 0xf);
+	u16 seq_ctrl = ((rframe->u.hdr.attrib.seq_num & 0xffff) << 4) | (rframe->u.hdr.attrib.frag_num & 0xf);
 	u8 token = *(rframe->u.hdr.rx_data + sizeof(struct rtw_ieee80211_hdr_3addr) + token_offset);
 
 	if (GetRetry(frame)) {
 		if ((seq_ctrl == mlmeext->action_public_rxseq)
-			&& (token == mlmeext->action_public_dialog_token)
-		) {
-			DBG_871X(FUNC_ADPT_FMT" seq_ctrl=0x%x, rxseq=0x%x, token:%d\n",
+		    && (token == mlmeext->action_public_dialog_token)
+		   ) {
+			RTW_INFO(FUNC_ADPT_FMT" seq_ctrl=0x%x, rxseq=0x%x, token:%d\n",
 				FUNC_ADPT_ARG(adapter), seq_ctrl, mlmeext->action_public_rxseq, token);
 			return _FAIL;
 		}
@@ -6471,422 +6609,361 @@ unsigned int on_action_public_p2p(union recv_frame *precv_frame)
 #ifdef CONFIG_P2P
 	u8 *p2p_ie;
 	u32	p2p_ielen, wps_ielen;
-	struct	wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct	wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	u8	result = P2P_STATUS_SUCCESS;
 	u8	empty_addr[ETH_ALEN] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
 	u8 *merged_p2pie = NULL;
-	u32 merged_p2p_ielen= 0;
-#endif //CONFIG_P2P
+	u32 merged_p2p_ielen = 0;
+#endif /* CONFIG_P2P */
 
 	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
 
 #ifdef CONFIG_P2P
-	_cancel_timer_ex( &pwdinfo->reset_ch_sitesurvey );
+	_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
 #ifdef CONFIG_IOCTL_CFG80211
-	if(adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211)
-	{
-		rtw_cfg80211_rx_p2p_action_public(padapter, pframe, len);
-	}
+	if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211)
+		rtw_cfg80211_rx_p2p_action_public(padapter, precv_frame);
 	else
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 	{
-		//	Do nothing if the driver doesn't enable the P2P function.
-		if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
+		/*	Do nothing if the driver doesn't enable the P2P function. */
+		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
 			return _SUCCESS;
 
 		len -= sizeof(struct rtw_ieee80211_hdr_3addr);
 
-		switch( frame_body[ 6 ] )//OUI Subtype
-		{
-			case P2P_GO_NEGO_REQ:
-			{
-				DBG_871X( "[%s] Got GO Nego Req Frame\n", __FUNCTION__);
-				_rtw_memset( &pwdinfo->groupid_info, 0x00, sizeof( struct group_id_info ) );
-
-				if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ))
-				{
-					rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-				}
-
-				if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
-				{
-					//	Commented by Albert 20110526
-					//	In this case, this means the previous nego fail doesn't be reset yet.
-					_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
-					//	Restore the previous p2p state
-					rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-					DBG_871X( "[%s] Restore the previous p2p state to %d\n", __FUNCTION__, rtw_p2p_state(pwdinfo) );						
-				}					
+		switch (frame_body[6]) { /* OUI Subtype */
+		case P2P_GO_NEGO_REQ: {
+			RTW_INFO("[%s] Got GO Nego Req Frame\n", __FUNCTION__);
+			_rtw_memset(&pwdinfo->groupid_info, 0x00, sizeof(struct group_id_info));
+
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ))
+				rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
+
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL)) {
+				/*	Commented by Albert 20110526 */
+				/*	In this case, this means the previous nego fail doesn't be reset yet. */
+				_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+				/*	Restore the previous p2p state */
+				rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
+				RTW_INFO("[%s] Restore the previous p2p state to %d\n", __FUNCTION__, rtw_p2p_state(pwdinfo));
+			}
 #ifdef CONFIG_CONCURRENT_MODE
-				if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-				{
-					_cancel_timer_ex( &pwdinfo->ap_p2p_switch_timer );
-				}
-#endif // CONFIG_CONCURRENT_MODE
+			if (rtw_mi_buddy_check_fwstate(padapter, _FW_LINKED))
+				_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif /* CONFIG_CONCURRENT_MODE */
 
-				//	Commented by Kurt 20110902
-				//Add if statement to avoid receiving duplicate prov disc req. such that pre_p2p_state would be covered.
-				if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING))
-					rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+			/*	Commented by Kurt 20110902 */
+			/* Add if statement to avoid receiving duplicate prov disc req. such that pre_p2p_state would be covered. */
+			if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING))
+				rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
 
-				//	Commented by Kurt 20120113
-				//	Get peer_dev_addr here if peer doesn't issue prov_disc frame.
-				if( _rtw_memcmp(pwdinfo->rx_prov_disc_info.peerDevAddr, empty_addr, ETH_ALEN) )
-					_rtw_memcpy(pwdinfo->rx_prov_disc_info.peerDevAddr, GetAddr2Ptr(pframe), ETH_ALEN);
+			/*	Commented by Kurt 20120113 */
+			/*	Get peer_dev_addr here if peer doesn't issue prov_disc frame. */
+			if (_rtw_memcmp(pwdinfo->rx_prov_disc_info.peerDevAddr, empty_addr, ETH_ALEN))
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.peerDevAddr, get_addr2_ptr(pframe), ETH_ALEN);
 
-				result = process_p2p_group_negotation_req( pwdinfo, frame_body, len );
-				issue_p2p_GO_response( padapter, GetAddr2Ptr(pframe), frame_body, len, result );
+			result = process_p2p_group_negotation_req(pwdinfo, frame_body, len);
+			issue_p2p_GO_response(padapter, get_addr2_ptr(pframe), frame_body, len, result);
 #ifdef CONFIG_INTEL_WIDI
-				if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_LISTEN) {
-					padapter->mlmepriv.widi_state = INTEL_WIDI_STATE_WFD_CONNECTION;
-					_cancel_timer_ex(&(padapter->mlmepriv.listen_timer));
-					intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_STOP_WK, NULL, 0);
-				}
-#endif //CONFIG_INTEL_WIDI
+			if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_LISTEN) {
+				padapter->mlmepriv.widi_state = INTEL_WIDI_STATE_WFD_CONNECTION;
+				_cancel_timer_ex(&(padapter->mlmepriv.listen_timer));
+				intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_STOP_WK, NULL, 0);
+			}
+#endif /* CONFIG_INTEL_WIDI */
 
-				//	Commented by Albert 20110718
-				//	No matter negotiating or negotiation failure, the driver should set up the restore P2P state timer.
+			/*	Commented by Albert 20110718 */
+			/*	No matter negotiating or negotiation failure, the driver should set up the restore P2P state timer. */
 #ifdef CONFIG_CONCURRENT_MODE
-				//	Commented by Albert 20120107
-				_set_timer( &pwdinfo->restore_p2p_state_timer, 3000 );
-#else // CONFIG_CONCURRENT_MODE
-				_set_timer( &pwdinfo->restore_p2p_state_timer, 5000 );
-#endif // CONFIG_CONCURRENT_MODE
-				break;					
-			}
-			case P2P_GO_NEGO_RESP:
-			{
-				DBG_871X( "[%s] Got GO Nego Resp Frame\n", __FUNCTION__);
+			/*	Commented by Albert 20120107 */
+			_set_timer(&pwdinfo->restore_p2p_state_timer, 3000);
+#else /* CONFIG_CONCURRENT_MODE */
+			_set_timer(&pwdinfo->restore_p2p_state_timer, 5000);
+#endif /* CONFIG_CONCURRENT_MODE */
+			break;
+		}
+		case P2P_GO_NEGO_RESP: {
+			RTW_INFO("[%s] Got GO Nego Resp Frame\n", __FUNCTION__);
 
-				if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING))
-				{
-					//	Commented by Albert 20110425
-					//	The restore timer is enabled when issuing the nego request frame of rtw_p2p_connect function.
-					_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
-					pwdinfo->nego_req_info.benable = _FALSE;
-					result = process_p2p_group_negotation_resp( pwdinfo, frame_body, len);
-					issue_p2p_GO_confirm( pwdinfo->padapter, GetAddr2Ptr(pframe), result);
-					if ( P2P_STATUS_SUCCESS == result )
-					{
-						if ( rtw_p2p_role(pwdinfo) == P2P_ROLE_CLIENT )
-						{
-							pwdinfo->p2p_info.operation_ch[ 0 ] = pwdinfo->peer_operating_ch;
-							#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
-							pwdinfo->p2p_info.operation_ch[ 1 ] = 1;	//Check whether GO is operating in channel 1;
-							pwdinfo->p2p_info.operation_ch[ 2 ] = 6;	//Check whether GO is operating in channel 6;
-							pwdinfo->p2p_info.operation_ch[ 3 ] = 11;	//Check whether GO is operating in channel 11;
-							#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH
-							pwdinfo->p2p_info.scan_op_ch_only = 1;
-							_set_timer( &pwdinfo->reset_ch_sitesurvey2, P2P_RESET_SCAN_CH );
-						}
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING)) {
+				/*	Commented by Albert 20110425 */
+				/*	The restore timer is enabled when issuing the nego request frame of rtw_p2p_connect function. */
+				_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+				pwdinfo->nego_req_info.benable = _FALSE;
+				result = process_p2p_group_negotation_resp(pwdinfo, frame_body, len);
+				issue_p2p_GO_confirm(pwdinfo->padapter, get_addr2_ptr(pframe), result);
+				if (P2P_STATUS_SUCCESS == result) {
+					if (rtw_p2p_role(pwdinfo) == P2P_ROLE_CLIENT) {
+						pwdinfo->p2p_info.operation_ch[0] = pwdinfo->peer_operating_ch;
+#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
+						pwdinfo->p2p_info.operation_ch[1] = 1;	/* Check whether GO is operating in channel 1; */
+						pwdinfo->p2p_info.operation_ch[2] = 6;	/* Check whether GO is operating in channel 6; */
+						pwdinfo->p2p_info.operation_ch[3] = 11;	/* Check whether GO is operating in channel 11; */
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
+						pwdinfo->p2p_info.scan_op_ch_only = 1;
+						_set_timer(&pwdinfo->reset_ch_sitesurvey2, P2P_RESET_SCAN_CH);
 					}
+				}
 
-					//	Reset the dialog token for group negotiation frames.
-					pwdinfo->negotiation_dialog_token = 1;
+				/*	Reset the dialog token for group negotiation frames. */
+				pwdinfo->negotiation_dialog_token = 1;
 
-					if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
-					{
-						_set_timer( &pwdinfo->restore_p2p_state_timer, 5000 );
-					}
-				}
-				else
-				{
-					DBG_871X( "[%s] Skipped GO Nego Resp Frame (p2p_state != P2P_STATE_GONEGO_ING)\n", __FUNCTION__);
+				if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
+					_set_timer(&pwdinfo->restore_p2p_state_timer, 5000);
+			} else
+				RTW_INFO("[%s] Skipped GO Nego Resp Frame (p2p_state != P2P_STATE_GONEGO_ING)\n", __FUNCTION__);
+
+			break;
+		}
+		case P2P_GO_NEGO_CONF: {
+			RTW_INFO("[%s] Got GO Nego Confirm Frame\n", __FUNCTION__);
+			result = process_p2p_group_negotation_confirm(pwdinfo, frame_body, len);
+			if (P2P_STATUS_SUCCESS == result) {
+				if (rtw_p2p_role(pwdinfo) == P2P_ROLE_CLIENT) {
+					pwdinfo->p2p_info.operation_ch[0] = pwdinfo->peer_operating_ch;
+#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
+					pwdinfo->p2p_info.operation_ch[1] = 1;	/* Check whether GO is operating in channel 1; */
+					pwdinfo->p2p_info.operation_ch[2] = 6;	/* Check whether GO is operating in channel 6; */
+					pwdinfo->p2p_info.operation_ch[3] = 11;	/* Check whether GO is operating in channel 11; */
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
+					pwdinfo->p2p_info.scan_op_ch_only = 1;
+					_set_timer(&pwdinfo->reset_ch_sitesurvey2, P2P_RESET_SCAN_CH);
 				}
-				
-				break;
 			}
-			case P2P_GO_NEGO_CONF:
-			{
-				DBG_871X( "[%s] Got GO Nego Confirm Frame\n", __FUNCTION__);
-				result = process_p2p_group_negotation_confirm( pwdinfo, frame_body, len);
-				if ( P2P_STATUS_SUCCESS == result )
-				{
-					if ( rtw_p2p_role(pwdinfo) == P2P_ROLE_CLIENT )
-					{
-						pwdinfo->p2p_info.operation_ch[ 0 ] = pwdinfo->peer_operating_ch;
-						#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
-						pwdinfo->p2p_info.operation_ch[ 1 ] = 1;	//Check whether GO is operating in channel 1;
-						pwdinfo->p2p_info.operation_ch[ 2 ] = 6;	//Check whether GO is operating in channel 6;
-						pwdinfo->p2p_info.operation_ch[ 3 ] = 11;	//Check whether GO is operating in channel 11;
-						#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH
-						pwdinfo->p2p_info.scan_op_ch_only = 1;
-						_set_timer( &pwdinfo->reset_ch_sitesurvey2, P2P_RESET_SCAN_CH );
-					}
+			break;
+		}
+		case P2P_INVIT_REQ: {
+			/*	Added by Albert 2010/10/05 */
+			/*	Received the P2P Invite Request frame. */
+
+			RTW_INFO("[%s] Got invite request frame!\n", __FUNCTION__);
+			p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
+			if (p2p_ie) {
+				/*	Parse the necessary information from the P2P Invitation Request frame. */
+				/*	For example: The MAC address of sending this P2P Invitation Request frame. */
+				u32	attr_contentlen = 0;
+				u8	status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
+				struct group_id_info group_id;
+				u8	invitation_flag = 0;
+				int j = 0;
+
+				merged_p2p_ielen = rtw_get_p2p_merged_ies_len(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_);
+
+				merged_p2pie = rtw_zmalloc(merged_p2p_ielen + 2);	/* 2 is for EID and Length */
+				if (merged_p2pie == NULL) {
+					RTW_INFO("[%s] Malloc p2p ie fail\n", __FUNCTION__);
+					goto exit;
 				}
-				break;
-			}
-			case P2P_INVIT_REQ:
-			{
-				//	Added by Albert 2010/10/05
-				//	Received the P2P Invite Request frame.
-				
-				DBG_871X( "[%s] Got invite request frame!\n", __FUNCTION__ );
-				if ( (p2p_ie=rtw_get_p2p_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen)) )
-				{
-					//	Parse the necessary information from the P2P Invitation Request frame.
-					//	For example: The MAC address of sending this P2P Invitation Request frame.
-					u32	attr_contentlen = 0;
-					u8	status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
-					struct group_id_info group_id;
-					u8	invitation_flag = 0;
-					int j=0;
-
-					merged_p2p_ielen = rtw_get_p2p_merged_ies_len(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_);
-
-					merged_p2pie = rtw_zmalloc(merged_p2p_ielen + 2);	// 2 is for EID and Length
-					if (merged_p2pie == NULL)
-					{
-						DBG_871X( "[%s] Malloc p2p ie fail\n", __FUNCTION__);
-						goto exit;
+				_rtw_memset(merged_p2pie, 0x00, merged_p2p_ielen);
+
+				merged_p2p_ielen = rtw_p2p_merge_ies(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, merged_p2pie);
+
+				rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_INVITATION_FLAGS, &invitation_flag, &attr_contentlen);
+				if (attr_contentlen) {
+
+					rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_BSSID, pwdinfo->p2p_peer_interface_addr, &attr_contentlen);
+					/*	Commented by Albert 20120510 */
+					/*	Copy to the pwdinfo->p2p_peer_interface_addr. */
+					/*	So that the WFD UI ( or Sigma ) can get the peer interface address by using the following command. */
+					/*	#> iwpriv wlan0 p2p_get peer_ifa */
+					/*	After having the peer interface address, the sigma can find the correct conf file for wpa_supplicant. */
+
+					if (attr_contentlen) {
+						RTW_INFO("[%s] GO's BSSID = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
+							pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1],
+							pwdinfo->p2p_peer_interface_addr[2], pwdinfo->p2p_peer_interface_addr[3],
+							pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
 					}
-					_rtw_memset(merged_p2pie, 0x00, merged_p2p_ielen);					
-
-					merged_p2p_ielen = rtw_p2p_merge_ies(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, merged_p2pie);
-
-					rtw_get_p2p_attr_content( merged_p2pie, merged_p2p_ielen, P2P_ATTR_INVITATION_FLAGS, &invitation_flag, &attr_contentlen);
-					if ( attr_contentlen )
-					{
-
-						rtw_get_p2p_attr_content( merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_BSSID, pwdinfo->p2p_peer_interface_addr, &attr_contentlen);
-						//	Commented by Albert 20120510
-						//	Copy to the pwdinfo->p2p_peer_interface_addr.
-						//	So that the WFD UI ( or Sigma ) can get the peer interface address by using the following command.
-						//	#> iwpriv wlan0 p2p_get peer_ifa
-						//	After having the peer interface address, the sigma can find the correct conf file for wpa_supplicant.
-
-						if ( attr_contentlen )
-						{
-							DBG_871X( "[%s] GO's BSSID = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
-									pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1],
-									pwdinfo->p2p_peer_interface_addr[2], pwdinfo->p2p_peer_interface_addr[3],
-									pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5] );
-						}								
-
-						if ( invitation_flag & P2P_INVITATION_FLAGS_PERSISTENT )
-						{
-							//	Re-invoke the persistent group.
-							
-							_rtw_memset( &group_id, 0x00, sizeof( struct group_id_info ) );
-							rtw_get_p2p_attr_content( merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_ID, ( u8* ) &group_id, &attr_contentlen);
-							if ( attr_contentlen )
-							{
-								if (_rtw_memcmp(group_id.go_device_addr, adapter_mac_addr(padapter), ETH_ALEN))
-								{
-									//	The p2p device sending this p2p invitation request wants this Wi-Fi device to be the persistent GO.
-									rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_GO );
-									rtw_p2p_set_role( pwdinfo, P2P_ROLE_GO );
-									status_code = P2P_STATUS_SUCCESS;
-								}
-								else
-								{
-									//	The p2p device sending this p2p invitation request wants to be the persistent GO.
-									if ( is_matched_in_profilelist( pwdinfo->p2p_peer_interface_addr, &pwdinfo->profileinfo[ 0 ] ) )
-									{
-										u8 operatingch_info[5] = { 0x00 };
-										if ( rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen) )
-										{
-											if( rtw_ch_set_search_ch(padapter->mlmeextpriv.channel_set, (u32)operatingch_info[4] ) >= 0 )
-											{
-												//	The operating channel is acceptable for this device.
-												pwdinfo->rx_invitereq_info.operation_ch[0]= operatingch_info[4];
-												#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
-												pwdinfo->rx_invitereq_info.operation_ch[1]= 1;		//Check whether GO is operating in channel 1;
-												pwdinfo->rx_invitereq_info.operation_ch[2]= 6;		//Check whether GO is operating in channel 6;
-												pwdinfo->rx_invitereq_info.operation_ch[3]= 11;		//Check whether GO is operating in channel 11;
-												#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH
-												pwdinfo->rx_invitereq_info.scan_op_ch_only = 1;
-												_set_timer( &pwdinfo->reset_ch_sitesurvey, P2P_RESET_SCAN_CH );
-												rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_MATCH );
-												rtw_p2p_set_role( pwdinfo, P2P_ROLE_CLIENT );
-												status_code = P2P_STATUS_SUCCESS;
-											}
-											else
-											{
-												//	The operating channel isn't supported by this device.
-												rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH );
-												rtw_p2p_set_role( pwdinfo, P2P_ROLE_DEVICE );
-												status_code = P2P_STATUS_FAIL_NO_COMMON_CH;
-												_set_timer( &pwdinfo->restore_p2p_state_timer, 3000 );
-											}
-										}
-										else
-										{
-											//	Commented by Albert 20121130
-											//	Intel will use the different P2P IE to store the operating channel information
-											//	Workaround for Intel WiDi 3.5
-											rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_MATCH );
-											rtw_p2p_set_role( pwdinfo, P2P_ROLE_CLIENT );
+
+					if (invitation_flag & P2P_INVITATION_FLAGS_PERSISTENT) {
+						/*	Re-invoke the persistent group. */
+
+						_rtw_memset(&group_id, 0x00, sizeof(struct group_id_info));
+						rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_ID, (u8 *) &group_id, &attr_contentlen);
+						if (attr_contentlen) {
+							if (_rtw_memcmp(group_id.go_device_addr, adapter_mac_addr(padapter), ETH_ALEN)) {
+								/*	The p2p device sending this p2p invitation request wants this Wi-Fi device to be the persistent GO. */
+								rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_GO);
+								rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
+								status_code = P2P_STATUS_SUCCESS;
+							} else {
+								/*	The p2p device sending this p2p invitation request wants to be the persistent GO. */
+								if (is_matched_in_profilelist(pwdinfo->p2p_peer_interface_addr, &pwdinfo->profileinfo[0])) {
+									u8 operatingch_info[5] = { 0x00 };
+									if (rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info,
+										&attr_contentlen)) {
+										if (rtw_chset_search_ch(adapter_to_chset(padapter), (u32)operatingch_info[4]) >= 0) {
+											/*	The operating channel is acceptable for this device. */
+											pwdinfo->rx_invitereq_info.operation_ch[0] = operatingch_info[4];
+#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
+											pwdinfo->rx_invitereq_info.operation_ch[1] = 1;		/* Check whether GO is operating in channel 1; */
+											pwdinfo->rx_invitereq_info.operation_ch[2] = 6;		/* Check whether GO is operating in channel 6; */
+											pwdinfo->rx_invitereq_info.operation_ch[3] = 11;		/* Check whether GO is operating in channel 11; */
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
+											pwdinfo->rx_invitereq_info.scan_op_ch_only = 1;
+											_set_timer(&pwdinfo->reset_ch_sitesurvey, P2P_RESET_SCAN_CH);
+											rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_MATCH);
+											rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
 											status_code = P2P_STATUS_SUCCESS;
-										}								
-									}
-									else
-									{
-										rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH );
-										#ifdef CONFIG_INTEL_WIDI
-										_rtw_memcpy( pwdinfo->p2p_peer_device_addr, group_id.go_device_addr , ETH_ALEN );
-										rtw_p2p_set_role( pwdinfo, P2P_ROLE_CLIENT );
-										#endif //CONFIG_INTEL_WIDI
-
-										status_code = P2P_STATUS_FAIL_UNKNOWN_P2PGROUP;
+										} else {
+											/*	The operating channel isn't supported by this device. */
+											rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH);
+											rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
+											status_code = P2P_STATUS_FAIL_NO_COMMON_CH;
+											_set_timer(&pwdinfo->restore_p2p_state_timer, 3000);
+										}
+									} else {
+										/*	Commented by Albert 20121130 */
+										/*	Intel will use the different P2P IE to store the operating channel information */
+										/*	Workaround for Intel WiDi 3.5 */
+										rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_MATCH);
+										rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
+										status_code = P2P_STATUS_SUCCESS;
 									}
+								} else {
+									rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH);
+#ifdef CONFIG_INTEL_WIDI
+									_rtw_memcpy(pwdinfo->p2p_peer_device_addr, group_id.go_device_addr , ETH_ALEN);
+									rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
+#endif /* CONFIG_INTEL_WIDI */
+
+									status_code = P2P_STATUS_FAIL_UNKNOWN_P2PGROUP;
 								}
 							}
-							else
-							{
-								DBG_871X( "[%s] P2P Group ID Attribute NOT FOUND!\n", __FUNCTION__ );
-								status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
-							}									
+						} else {
+							RTW_INFO("[%s] P2P Group ID Attribute NOT FOUND!\n", __FUNCTION__);
+							status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
 						}
-						else
-						{
-							//	Received the invitation to join a P2P group.
-
-							_rtw_memset( &group_id, 0x00, sizeof( struct group_id_info ) );
-							rtw_get_p2p_attr_content( merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_ID, ( u8* ) &group_id, &attr_contentlen);
-							if ( attr_contentlen )
-							{
-								if (_rtw_memcmp(group_id.go_device_addr, adapter_mac_addr(padapter), ETH_ALEN))
-								{
-									//	In this case, the GO can't be myself.
-									rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH );
-									status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
-								}
-								else
-								{
-									//	The p2p device sending this p2p invitation request wants to join an existing P2P group
-									//	Commented by Albert 2012/06/28
-									//	In this case, this Wi-Fi device should use the iwpriv command to get the peer device address.
-									//	The peer device address should be the destination address for the provisioning discovery request.
-									//	Then, this Wi-Fi device should use the iwpriv command to get the peer interface address.
-									//	The peer interface address should be the address for WPS mac address
-									_rtw_memcpy( pwdinfo->p2p_peer_device_addr, group_id.go_device_addr , ETH_ALEN );											
-									rtw_p2p_set_role( pwdinfo, P2P_ROLE_CLIENT );
-									rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_JOIN );
-									status_code = P2P_STATUS_SUCCESS;
-								}
-							}
-							else
-							{
-								DBG_871X( "[%s] P2P Group ID Attribute NOT FOUND!\n", __FUNCTION__ );
+					} else {
+						/*	Received the invitation to join a P2P group. */
+
+						_rtw_memset(&group_id, 0x00, sizeof(struct group_id_info));
+						rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_ID, (u8 *) &group_id, &attr_contentlen);
+						if (attr_contentlen) {
+							if (_rtw_memcmp(group_id.go_device_addr, adapter_mac_addr(padapter), ETH_ALEN)) {
+								/*	In this case, the GO can't be myself. */
+								rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH);
 								status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
+							} else {
+								/*	The p2p device sending this p2p invitation request wants to join an existing P2P group */
+								/*	Commented by Albert 2012/06/28 */
+								/*	In this case, this Wi-Fi device should use the iwpriv command to get the peer device address. */
+								/*	The peer device address should be the destination address for the provisioning discovery request. */
+								/*	Then, this Wi-Fi device should use the iwpriv command to get the peer interface address. */
+								/*	The peer interface address should be the address for WPS mac address */
+								_rtw_memcpy(pwdinfo->p2p_peer_device_addr, group_id.go_device_addr , ETH_ALEN);
+								rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
+								rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_JOIN);
+								status_code = P2P_STATUS_SUCCESS;
 							}
+						} else {
+							RTW_INFO("[%s] P2P Group ID Attribute NOT FOUND!\n", __FUNCTION__);
+							status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
 						}
 					}
-					else
-					{
-						DBG_871X( "[%s] P2P Invitation Flags Attribute NOT FOUND!\n", __FUNCTION__ );
-						status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
-					}							
+				} else {
+					RTW_INFO("[%s] P2P Invitation Flags Attribute NOT FOUND!\n", __FUNCTION__);
+					status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
+				}
 
-					DBG_871X( "[%s] status_code = %d\n", __FUNCTION__, status_code );
+				RTW_INFO("[%s] status_code = %d\n", __FUNCTION__, status_code);
 
-					pwdinfo->inviteresp_info.token = frame_body[ 7 ];
-					issue_p2p_invitation_response( padapter, GetAddr2Ptr(pframe), pwdinfo->inviteresp_info.token, status_code );
-					_set_timer( &pwdinfo->restore_p2p_state_timer, 3000 );
-				}
+				pwdinfo->inviteresp_info.token = frame_body[7];
+				issue_p2p_invitation_response(padapter, get_addr2_ptr(pframe), pwdinfo->inviteresp_info.token, status_code);
+				_set_timer(&pwdinfo->restore_p2p_state_timer, 3000);
+			}
 #ifdef CONFIG_INTEL_WIDI
-				if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_LISTEN) {
-					padapter->mlmepriv.widi_state = INTEL_WIDI_STATE_WFD_CONNECTION;
-					_cancel_timer_ex(&(padapter->mlmepriv.listen_timer));
-					intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_STOP_WK, NULL, 0);
-				}
-#endif //CONFIG_INTEL_WIDI
-				break;
+			if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_LISTEN) {
+				padapter->mlmepriv.widi_state = INTEL_WIDI_STATE_WFD_CONNECTION;
+				_cancel_timer_ex(&(padapter->mlmepriv.listen_timer));
+				intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_STOP_WK, NULL, 0);
 			}
-			case P2P_INVIT_RESP:
-			{
-				u8	attr_content = 0x00;
-				u32	attr_contentlen = 0;
-				
-				DBG_871X( "[%s] Got invite response frame!\n", __FUNCTION__ );
-				_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
-				if ( (p2p_ie=rtw_get_p2p_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen)) )
-				{
-					rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, &attr_content, &attr_contentlen);
-									
-					if ( attr_contentlen == 1 )
-					{
-						DBG_871X( "[%s] Status = %d\n", __FUNCTION__, attr_content );
-						pwdinfo->invitereq_info.benable = _FALSE;
-
-						if ( attr_content == P2P_STATUS_SUCCESS )
-						{
-							if (_rtw_memcmp(pwdinfo->invitereq_info.go_bssid, adapter_mac_addr(padapter), ETH_ALEN))
-								rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO );
-							else
-								rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
+#endif /* CONFIG_INTEL_WIDI */
+			break;
+		}
+		case P2P_INVIT_RESP: {
+			u8	attr_content = 0x00;
+			u32	attr_contentlen = 0;
 
-							rtw_p2p_set_state( pwdinfo, P2P_STATE_RX_INVITE_RESP_OK );
-						}
+			RTW_INFO("[%s] Got invite response frame!\n", __FUNCTION__);
+			_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+			p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
+			if (p2p_ie) {
+				rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, &attr_content, &attr_contentlen);
+
+				if (attr_contentlen == 1) {
+					RTW_INFO("[%s] Status = %d\n", __FUNCTION__, attr_content);
+					pwdinfo->invitereq_info.benable = _FALSE;
+
+					if (attr_content == P2P_STATUS_SUCCESS) {
+						if (_rtw_memcmp(pwdinfo->invitereq_info.go_bssid, adapter_mac_addr(padapter), ETH_ALEN))
+							rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
 						else
-						{
-							rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-							rtw_p2p_set_state( pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL );
-						}
-					}
-					else
-					{
+							rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
+
+						rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_OK);
+					} else {
 						rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-						rtw_p2p_set_state( pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL );
+						rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL);
 					}
-				}
-				else
-				{
+				} else {
 					rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-					rtw_p2p_set_state( pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL );
-				}
-
-				if ( rtw_p2p_chk_state( pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL ) )
-				{
-					_set_timer( &pwdinfo->restore_p2p_state_timer, 5000 );
+					rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL);
 				}
-				break;
+			} else {
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
+				rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL);
 			}
-			case P2P_DEVDISC_REQ:
 
-				process_p2p_devdisc_req(pwdinfo, pframe, len);
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL))
+				_set_timer(&pwdinfo->restore_p2p_state_timer, 5000);
+			break;
+		}
+		case P2P_DEVDISC_REQ:
 
-				break;
+			process_p2p_devdisc_req(pwdinfo, pframe, len);
+
+			break;
 
-			case P2P_DEVDISC_RESP:
+		case P2P_DEVDISC_RESP:
 
-				process_p2p_devdisc_resp(pwdinfo, pframe, len);
+			process_p2p_devdisc_resp(pwdinfo, pframe, len);
 
-				break;
+			break;
 
-			case P2P_PROVISION_DISC_REQ:
-				DBG_871X( "[%s] Got Provisioning Discovery Request Frame\n", __FUNCTION__ );
-				process_p2p_provdisc_req(pwdinfo, pframe, len);
-				_rtw_memcpy(pwdinfo->rx_prov_disc_info.peerDevAddr, GetAddr2Ptr(pframe), ETH_ALEN);
+		case P2P_PROVISION_DISC_REQ:
+			RTW_INFO("[%s] Got Provisioning Discovery Request Frame\n", __FUNCTION__);
+			process_p2p_provdisc_req(pwdinfo, pframe, len);
+			_rtw_memcpy(pwdinfo->rx_prov_disc_info.peerDevAddr, get_addr2_ptr(pframe), ETH_ALEN);
 
-				//20110902 Kurt
-				//Add the following statement to avoid receiving duplicate prov disc req. such that pre_p2p_state would be covered.
-				if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ))
-					rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
-				
-				rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ);
-				_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT );
+			/* 20110902 Kurt */
+			/* Add the following statement to avoid receiving duplicate prov disc req. such that pre_p2p_state would be covered. */
+			if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ))
+				rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ);
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
 #ifdef CONFIG_INTEL_WIDI
-				if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_LISTEN) {
-					padapter->mlmepriv.widi_state = INTEL_WIDI_STATE_WFD_CONNECTION;
-					_cancel_timer_ex(&(padapter->mlmepriv.listen_timer));
-					intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_STOP_WK, NULL, 0);
-				}
-#endif //CONFIG_INTEL_WIDI
-				break;
+			if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_LISTEN) {
+				padapter->mlmepriv.widi_state = INTEL_WIDI_STATE_WFD_CONNECTION;
+				_cancel_timer_ex(&(padapter->mlmepriv.listen_timer));
+				intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_STOP_WK, NULL, 0);
+			}
+#endif /* CONFIG_INTEL_WIDI */
+			break;
 
-			case P2P_PROVISION_DISC_RESP:
-				//	Commented by Albert 20110707
-				//	Should we check the pwdinfo->tx_prov_disc_info.bsent flag here??
-				DBG_871X( "[%s] Got Provisioning Discovery Response Frame\n", __FUNCTION__ );
-				//	Commented by Albert 20110426
-				//	The restore timer is enabled when issuing the provisioing request frame in rtw_p2p_prov_disc function.
-				_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
-				rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_RSP);
-				process_p2p_provdisc_resp(pwdinfo, pframe);
-				_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT );
-				break;
+		case P2P_PROVISION_DISC_RESP:
+			/*	Commented by Albert 20110707 */
+			/*	Should we check the pwdinfo->tx_prov_disc_info.bsent flag here?? */
+			RTW_INFO("[%s] Got Provisioning Discovery Response Frame\n", __FUNCTION__);
+			/*	Commented by Albert 20110426 */
+			/*	The restore timer is enabled when issuing the provisioing request frame in rtw_p2p_prov_disc function. */
+			_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_RSP);
+			process_p2p_provdisc_resp(pwdinfo, pframe);
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
+			break;
 
 		}
 	}
@@ -6894,11 +6971,9 @@ unsigned int on_action_public_p2p(union recv_frame *precv_frame)
 
 exit:
 
-	if(merged_p2pie)
-	{
+	if (merged_p2pie)
 		rtw_mfree(merged_p2pie, merged_p2p_ielen + 2);
-	}
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 	return _SUCCESS;
 }
 
@@ -6939,13 +7014,13 @@ unsigned int on_action_public_default(union recv_frame *precv_frame, u8 action)
 	if (rtw_action_public_decache(precv_frame, 2) == _FAIL)
 		goto exit;
 
-	#ifdef CONFIG_IOCTL_CFG80211
-	cnt += sprintf((msg+cnt), "%s(token:%u)", action_public_str(action), token);
-	rtw_cfg80211_rx_action(adapter, pframe, frame_len, msg);
-	#endif
+#ifdef CONFIG_IOCTL_CFG80211
+	cnt += sprintf((msg + cnt), "%s(token:%u)", action_public_str(action), token);
+	rtw_cfg80211_rx_action(adapter, precv_frame, msg);
+#endif
 
 	ret = _SUCCESS;
-	
+
 exit:
 	return ret;
 }
@@ -6989,1329 +7064,1486 @@ exit:
 	return ret;
 }
 
-unsigned int OnAction_ht(_adapter *padapter, union recv_frame *precv_frame)
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+static u8 rtw_wnm_nb_elem_parsing(
+	u8* pdata, u32 data_len, u8 from_btm, 
+	u32 *nb_rpt_num, u8 *nb_rpt_is_same,
+	struct roam_nb_info *pnb, struct wnm_btm_cant *pcandidates)
 {
-	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint frame_len = precv_frame->u.hdr.len;
-	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
-	u8 category, action;
+	u8 bfound = _FALSE, ret = _SUCCESS;
+	u8 *ptr, *pend, *op;
+	u32 elem_len, subelem_len, op_len;
+	u32 i, nb_rpt_entries = 0;
+	struct nb_rpt_hdr *pie;
+	struct wnm_btm_cant *pcandidate;
+
+	if ((!pdata) || (!pnb))
+		return _FAIL;
 
-	/* check RA matches or not */
-	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
-		goto exit;
+	if ((from_btm) && (!pcandidates))
+		return _FAIL;
 
-	category = frame_body[0];
-	if (category != RTW_WLAN_CATEGORY_HT)
-		goto exit;
+	ptr = pdata;
+	pend = ptr + data_len;
+	elem_len = data_len;
+	subelem_len = (u32)*(pdata+1);
 
-	action = frame_body[1];
-	switch (action) {
-	case RTW_WLAN_ACTION_HT_SM_PS:
-#ifdef CONFIG_80211N_HT
-#ifdef CONFIG_AP_MODE
-		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
-			rtw_process_ht_action_smps(padapter, GetAddr2Ptr(pframe), frame_body[2]);
-#endif /*CONFIG_AP_MODE*/
-#endif /*CONFIG_80211N_HT*/		
+	for (i=0; i < RTW_MAX_NB_RPT_NUM; i++) {
+		if (((ptr + 7) > pend) || (elem_len < subelem_len)) 
 			break;
-	case RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING:
-#ifdef CONFIG_BEAMFORMING
-		/*DBG_871X("RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING\n");*/
-		beamforming_get_report_frame(padapter, precv_frame);
-#endif /*CONFIG_BEAMFORMING*/
-		break;
-	default:
-		break;
-	}
 
-exit:
+		if (*ptr != 0x34) {
+			RTW_ERR("WNM: invalid data(0x%2x)!\n", *ptr);
+			ret = _FAIL;
+			break;
+		}
 
-	return _SUCCESS;
-}
+		pie = (struct nb_rpt_hdr *)ptr;		
+		if (from_btm) {
+			op = rtw_get_ie((u8 *)(ptr+15), 
+				WNM_BTM_CAND_PREF_SUBEID, 
+				&op_len, (subelem_len - 15));
+		}
 
-#ifdef CONFIG_IEEE80211W
-unsigned int OnAction_sa_query(_adapter *padapter, union recv_frame *precv_frame)
+		ptr = (u8 *)(ptr + subelem_len + 2);
+		elem_len -= (subelem_len +2);
+		subelem_len = *(ptr+1);
+		if (from_btm) {
+			pcandidate = (pcandidates + i);
+			_rtw_memcpy(&pcandidate->nb_rpt, pie, sizeof(struct nb_rpt_hdr));
+			if (op && (op_len !=0)) {
+				pcandidate->preference = *(op + 2);
+				bfound = _TRUE;
+			} else
+				pcandidate->preference = 0;
+
+			RTW_DBG("WNM: preference check bssid("MAC_FMT
+				") ,bss_info(0x%04X), reg_class(0x%02X), ch(%d),"
+				" phy_type(0x%02X), preference(0x%02X)\n",
+				MAC_ARG(pcandidate->nb_rpt.bssid), pcandidate->nb_rpt.bss_info, 
+				pcandidate->nb_rpt.reg_class, pcandidate->nb_rpt.ch_num, 
+				pcandidate->nb_rpt.phy_type, pcandidate->preference);
+		} else {
+			if (_rtw_memcmp(&pnb->nb_rpt[i], pie, sizeof(struct nb_rpt_hdr)) == _FALSE)
+				*nb_rpt_is_same = _FALSE;
+			_rtw_memcpy(&pnb->nb_rpt[i], pie, sizeof(struct nb_rpt_hdr));
+		}
+		nb_rpt_entries++;			
+	} 
+
+	if (from_btm) 
+		pnb->preference_en = (bfound)?_TRUE:_FALSE; 
+
+	*nb_rpt_num = nb_rpt_entries;
+	return ret;
+}	
+
+/* selection sorting based on preference value
+ * IN : 		nb_rpt_entries - candidate num
+ * IN/OUT :	pcandidates	- candidate list
+ * return : TRUE - means pcandidates is updated.  
+ */
+static u8 rtw_wnm_candidates_sorting(
+	u32 nb_rpt_entries, struct wnm_btm_cant *pcandidates)
 {
-	u8 *pframe = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct sta_info		*psta;
-	struct sta_priv		*pstapriv = &padapter->stapriv;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	u16 tid;
-	//Baron
-	
-	DBG_871X("OnAction_sa_query\n");
-	
-	switch (pframe[WLAN_HDR_A3_LEN+1])
-	{
-		case 0: //SA Query req
-			_rtw_memcpy(&tid, &pframe[WLAN_HDR_A3_LEN+2], sizeof(u16));
-			DBG_871X("OnAction_sa_query request,action=%d, tid=%04x, pframe=%02x-%02x\n"
-			, pframe[WLAN_HDR_A3_LEN+1], tid, pframe[WLAN_HDR_A3_LEN+2], pframe[WLAN_HDR_A3_LEN+3]);
-			issue_action_SA_Query(padapter, GetAddr2Ptr(pframe), 1, tid, IEEE80211W_RIGHT_KEY);
-			break;
+	u8 updated = _FALSE;
+	u32 i, j, pos;
+	struct wnm_btm_cant swap;
+	struct wnm_btm_cant *pcant_1, *pcant_2;
 
-		case 1: //SA Query rsp
-			psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));
-			if (psta != NULL)
-				_cancel_timer_ex(&psta->dot11w_expire_timer);
-			
-			_rtw_memcpy(&tid, &pframe[WLAN_HDR_A3_LEN+2], sizeof(u16));
-			DBG_871X("OnAction_sa_query response,action=%d, tid=%04x, cancel timer\n", pframe[WLAN_HDR_A3_LEN+1], tid);
-			break;
-		default:
-			break;
-	}
-	if(0)
-	{
-		int pp;
-		printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
-		for(pp=0;pp< pattrib->pkt_len; pp++)
-			printk(" %02x ", pframe[pp]);
-		printk("\n");
+	if ((!nb_rpt_entries) || (!pcandidates))
+		return updated;
+
+	for (i=0; i < (nb_rpt_entries - 1); i++) {
+		pos = i;
+		for (j=(i + 1); j < nb_rpt_entries; j++) {
+			pcant_1 = pcandidates+pos;
+			pcant_2 = pcandidates+j;
+			if ((pcant_1->preference) < (pcant_2->preference))
+				pos = j;
+		}
+
+		if (pos != i) {
+			updated = _TRUE;
+			_rtw_memcpy(&swap, (pcandidates+i), sizeof(struct wnm_btm_cant));
+			_rtw_memcpy((pcandidates+i), (pcandidates+pos), sizeof(struct wnm_btm_cant));
+			_rtw_memcpy((pcandidates+pos), &swap, sizeof(struct wnm_btm_cant));
+		}
 	}	
-	
-	return _SUCCESS;
-}
-#endif //CONFIG_IEEE80211W
+	return updated;
+}	
 
-unsigned int OnAction_wmm(_adapter *padapter, union recv_frame *precv_frame)
+static void rtw_wnm_nb_info_update(
+	u32 nb_rpt_entries, u8 from_btm, 
+	struct roam_nb_info *pnb, struct wnm_btm_cant *pcandidates, 
+	u8 *nb_rpt_is_same)
 {
-	return _SUCCESS;
-}
+	u8 is_found;
+	u32 i, j;
+	struct wnm_btm_cant *pcand;
 
-unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame)
-{
-#ifdef CONFIG_80211AC_VHT
-	struct rx_pkt_attrib *prxattrib = &precv_frame->u.hdr.attrib;
-	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint frame_len = precv_frame->u.hdr.len;
-	struct rtw_ieee80211_hdr_3addr *whdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
-	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
-	u8 category, action;
-	struct sta_info *psta = NULL;
-
-	/* check RA matches or not */
-	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
-		goto exit;
+	if (!pnb)
+		return;
 
-	category = frame_body[0];
-	if(category != RTW_WLAN_CATEGORY_VHT)
-		goto exit;
+	pnb->nb_rpt_ch_list_num = 0;
+	for (i=0; i<nb_rpt_entries; i++) {
+		is_found = _FALSE;
+		if (from_btm) {
+			pcand = (pcandidates+i);
+			if (_rtw_memcmp(&pnb->nb_rpt[i], &pcand->nb_rpt,
+					sizeof(struct nb_rpt_hdr)) == _FALSE)
+				*nb_rpt_is_same = _FALSE;
+			_rtw_memcpy(&pnb->nb_rpt[i], &pcand->nb_rpt, sizeof(struct nb_rpt_hdr));
+		}
 
-	action = frame_body[1];
-	switch (action) {
-	case RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING:
-#ifdef CONFIG_BEAMFORMING
-		/*DBG_871X("RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING\n");*/
-		beamforming_get_report_frame(padapter, precv_frame);
-#endif /*CONFIG_BEAMFORMING*/
-		break;
-	case RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION:
-		// CategoryCode(1) + ActionCode(1) + OpModeNotification(1)
-		//DBG_871X("RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION\n");
-		psta = rtw_get_stainfo(&padapter->stapriv, whdr->addr2);
-		if (psta)
-			rtw_process_vht_op_mode_notify(padapter, &frame_body[2], psta);
-		break;
-	default:
-		break;
-	}
+		RTW_DBG("WNM: bssid(" MAC_FMT 
+			") , bss_info(0x%04X), reg_class(0x%02X), ch_num(%d), phy_type(0x%02X)\n",
+			MAC_ARG(pnb->nb_rpt[i].bssid), pnb->nb_rpt[i].bss_info, 
+			pnb->nb_rpt[i].reg_class, pnb->nb_rpt[i].ch_num, 
+			pnb->nb_rpt[i].phy_type);
 
-exit:
-#endif //CONFIG_80211AC_VHT
+		if (pnb->nb_rpt[i].ch_num == 0)
+			continue;
 
-	return _SUCCESS;
+		for (j=0; j<nb_rpt_entries; j++) {
+			if (pnb->nb_rpt[i].ch_num == pnb->nb_rpt_ch_list[j].hw_value) {
+				is_found = _TRUE;
+				break;
+			}
+		}
+							
+		if (!is_found) {
+			pnb->nb_rpt_ch_list[pnb->nb_rpt_ch_list_num].hw_value = pnb->nb_rpt[i].ch_num;
+				pnb->nb_rpt_ch_list_num++;
+		}
+	}
 }
 
-unsigned int OnAction_p2p(_adapter *padapter, union recv_frame *precv_frame)
+static void rtw_wnm_btm_candidate_select(_adapter *padapter)
 {
-#ifdef CONFIG_P2P
-	u8 *frame_body;
-	u8 category, OUI_Subtype, dialogToken=0;
-	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint len = precv_frame->u.hdr.len;
-	struct	wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	struct wlan_network *pnetwork;
+	u8 bfound = _FALSE;
+	u32 i;
 
-	//check RA matches or not
-	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
-		return _SUCCESS;
+	for (i = 0; i < pnb->last_nb_rpt_entries; i++) {
+		pnetwork = rtw_find_network(
+				&(pmlmepriv->scanned_queue), 
+				pnb->nb_rpt[i].bssid);
 
-	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+		if (pnetwork) {
+			bfound = _TRUE;
+			break;
+		}
+	}
 
-	category = frame_body[0];
-	if(category != RTW_WLAN_CATEGORY_P2P)
-		return _SUCCESS;
+	if (bfound) {
+		_rtw_memcpy(pnb->roam_target_addr, pnb->nb_rpt[i].bssid, ETH_ALEN);
+		RTW_INFO("WNM : select btm entry(%d) - %s("MAC_FMT", ch%u) rssi:%d\n"
+			, i
+			, pnetwork->network.Ssid.Ssid
+			, MAC_ARG(pnetwork->network.MacAddress)
+			, pnetwork->network.Configuration.DSConfig
+			, (int)pnetwork->network.Rssi);
+	} else 
+		_rtw_memset(pnb->roam_target_addr,0, ETH_ALEN);
+}
 
-	if ( cpu_to_be32( *( ( u32* ) ( frame_body + 1 ) ) ) != P2POUI )
-		return _SUCCESS;
+u32 rtw_wnm_btm_candidates_survey(
+	_adapter *padapter, u8* pframe, u32 elem_len, u8 from_btm)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	struct wnm_btm_cant *pcandidate_list = NULL;
+	u8 nb_rpt_is_same = _TRUE;
+	u32	ret = _FAIL;
+	u32 nb_rpt_entries = 0;	
+
+	if (from_btm) {
+		u32 mlen = sizeof(struct wnm_btm_cant) * RTW_MAX_NB_RPT_NUM;
+		pcandidate_list = (struct wnm_btm_cant *)rtw_malloc(mlen);
+		if (pcandidate_list == NULL) 
+			goto exit;				
+	}
+
+	/*clean the status set last time*/
+	_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
+	pnb->nb_rpt_valid = _FALSE;
+	if (!rtw_wnm_nb_elem_parsing(
+			pframe, elem_len, from_btm, 
+			&nb_rpt_entries, &nb_rpt_is_same,
+			pnb, pcandidate_list))
+		goto exit;
 
-#ifdef CONFIG_IOCTL_CFG80211
-	if (adapter_wdev_data(padapter)->p2p_enabled
-		&& pwdinfo->driver_interface == DRIVER_CFG80211
-		) {
-		rtw_cfg80211_rx_action_p2p(padapter, pframe, len);
-		return _SUCCESS;
-	}
-	else
-#endif //CONFIG_IOCTL_CFG80211
-	{
-		len -= sizeof(struct rtw_ieee80211_hdr_3addr);
-		OUI_Subtype = frame_body[5];
-		dialogToken = frame_body[6];
+	if (nb_rpt_entries != 0) {
+		if ((from_btm) && (rtw_wnm_btm_preference_cap(padapter)))
+			rtw_wnm_candidates_sorting(nb_rpt_entries, pcandidate_list);
 
-		switch(OUI_Subtype)
-		{
-			case P2P_NOTICE_OF_ABSENCE:
-				
-				break;
-				
-			case P2P_PRESENCE_REQUEST:
+		rtw_wnm_nb_info_update(
+			nb_rpt_entries, from_btm, 
+			pnb, pcandidate_list, &nb_rpt_is_same);
+	}
 
-				process_p2p_presence_req(pwdinfo, pframe, len);			
-				
-				break;
-				
-			case P2P_PRESENCE_RESPONSE:
-				
-				break;
-				
-			case P2P_GO_DISC_REQUEST:
-				
-				break;
-				
-			default:
-				break;
-				
-		}
+	RTW_INFO("nb_rpt_is_same = %d, nb_rpt_entries = %d, last_nb_rpt_entries = %d\n", 
+		nb_rpt_is_same, nb_rpt_entries, pnb->last_nb_rpt_entries);
+	if ((nb_rpt_is_same == _TRUE) && (nb_rpt_entries == pnb->last_nb_rpt_entries))
+		pnb->nb_rpt_is_same = _TRUE;
+	else {
+		pnb->nb_rpt_is_same = _FALSE;
+		pnb->last_nb_rpt_entries = nb_rpt_entries;
 	}
-#endif //CONFIG_P2P
 
-	return _SUCCESS;
+	if ((from_btm) && (nb_rpt_entries != 0))
+		rtw_wnm_btm_candidate_select(padapter);
+	
+	pnb->nb_rpt_valid = _TRUE;
+	ret = _SUCCESS;
 
+exit:
+	if (from_btm && pcandidate_list)
+		rtw_mfree((u8 *)pcandidate_list, sizeof(struct wnm_btm_cant) * RTW_MAX_NB_RPT_NUM);
+	
+	return ret;
 }
+#endif
 
-unsigned int OnAction(_adapter *padapter, union recv_frame *precv_frame)
+unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame)
 {
-	int i;
-	unsigned char	category;
-	struct action_handler *ptable;
-	unsigned char	*frame_body;
-	u8 *pframe = precv_frame->u.hdr.rx_data; 
-
-	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
-	
-	category = frame_body[0];
-	
-	for(i = 0; i < sizeof(OnAction_tbl)/sizeof(struct action_handler); i++)	
-	{
-		ptable = &OnAction_tbl[i];
-		
-		if(category == ptable->num)
-			ptable->func(padapter, precv_frame);
-	
-	}
+#ifdef CONFIG_RTW_80211R
+	u32	ret = _FAIL;
+	u32	frame_len = 0;
+	u8	action_code = 0;
+	u8	category = 0;
+	u8	*pframe = NULL;
+	u8	*pframe_body = NULL;
+	u8	sta_addr[ETH_ALEN] = {0};
+	u8	*pie = NULL;
+	u32	ft_ie_len = 0;
+	u32 status_code = 0;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	struct mlme_priv *pmlmepriv = NULL;
+	struct wlan_network *proam_target = NULL;
+	struct ft_roam_info *pft_roam = NULL;
+	_irqL  irqL;
 
-	return _SUCCESS;
+	pmlmeext = &(padapter->mlmeextpriv);
+	pmlmeinfo = &(pmlmeext->mlmext_info);
+	pmlmepriv = &(padapter->mlmepriv);
+	pft_roam = &(pmlmepriv->ft_roam);
+	pframe = precv_frame->u.hdr.rx_data;
+	frame_len = precv_frame->u.hdr.len;
+	pframe_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
+	category = pframe_body[0];
+
+	if (category != RTW_WLAN_CATEGORY_FT)
+		goto exit;
 
-}
+	action_code = pframe_body[1];
+	switch (action_code) {
+	case RTW_WLAN_ACTION_FT_RSP:
+		RTW_INFO("FT: RTW_WLAN_ACTION_FT_RSP recv.\n");
+		if (!_rtw_memcmp(adapter_mac_addr(padapter), &pframe_body[2], ETH_ALEN)) {
+			RTW_ERR("FT: Unmatched STA MAC Address "MAC_FMT"\n", MAC_ARG(&pframe_body[2]));
+			goto exit;
+		}
 
-unsigned int DoReserved(_adapter *padapter, union recv_frame *precv_frame)
-{
+		status_code = le16_to_cpu(*(u16 *)((SIZE_PTR)pframe +  sizeof(struct rtw_ieee80211_hdr_3addr) + 14));
+		if (status_code != 0) {
+			RTW_ERR("FT: WLAN ACTION FT RESPONSE fail, status: %d\n", status_code);
+			goto exit;
+		}
 
-	//DBG_871X("rcvd mgt frame(%x, %x)\n", (GetFrameSubType(pframe) >> 4), *(unsigned int *)GetAddr1Ptr(pframe));
-	return _SUCCESS;
-}
+		if (is_zero_mac_addr(&pframe_body[8]) || is_broadcast_mac_addr(&pframe_body[8])) {
+			RTW_ERR("FT: Invalid Target MAC Address "MAC_FMT"\n", MAC_ARG(padapter->mlmepriv.roam_tgt_addr));
+			goto exit;
+		}
 
-struct xmit_frame *_alloc_mgtxmitframe(struct xmit_priv *pxmitpriv, bool once)
-{
-	struct xmit_frame *pmgntframe;
-	struct xmit_buf *pxmitbuf;
+		pie = rtw_get_ie(pframe_body, _MDIE_, &ft_ie_len, frame_len);
+		if (pie) {
+			if (!_rtw_memcmp(&pft_roam->mdid, pie+2, 2)) {
+				RTW_ERR("FT: Invalid MDID\n");
+				goto exit;
+			}
+		}
 
-	if (once)
-		pmgntframe = rtw_alloc_xmitframe_once(pxmitpriv);
-	else
-		pmgntframe = rtw_alloc_xmitframe_ext(pxmitpriv);
+		rtw_ft_set_status(padapter, RTW_FT_REQUESTED_STA);
+		_cancel_timer_ex(&pmlmeext->ft_link_timer);
 
-	if (pmgntframe == NULL) {
-		DBG_871X(FUNC_ADPT_FMT" alloc xmitframe fail, once:%d\n", FUNC_ADPT_ARG(pxmitpriv->adapter), once);
-		goto exit;
-	}
+		/*Disconnect current AP*/
+		receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress, WLAN_REASON_ACTIVE_ROAM, _FALSE);
 
-	if ((pxmitbuf = rtw_alloc_xmitbuf_ext(pxmitpriv)) == NULL) {
-		DBG_871X(FUNC_ADPT_FMT" alloc xmitbuf fail\n", FUNC_ADPT_ARG(pxmitpriv->adapter));
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		pmgntframe = NULL;
-		goto exit;
+		pft_roam->ft_action_len = frame_len;
+		_rtw_memcpy(pft_roam->ft_action, pframe, rtw_min(frame_len, RTW_FT_MAX_IE_SZ));
+		ret = _SUCCESS;
+		break;
+	case RTW_WLAN_ACTION_FT_REQ:
+	case RTW_WLAN_ACTION_FT_CONF:
+	case RTW_WLAN_ACTION_FT_ACK:
+	default:
+		RTW_ERR("FT: Unsupported FT Action!\n");
+		break;
 	}
 
-	pmgntframe->frame_tag = MGNT_FRAMETAG;
-	pmgntframe->pxmitbuf = pxmitbuf;
-	pmgntframe->buf_addr = pxmitbuf->pbuf;
-	pxmitbuf->priv_data = pmgntframe;
-
 exit:
-	return pmgntframe;
-
+	return ret;
+#else
+	return _SUCCESS;
+#endif
 }
 
-inline struct xmit_frame *alloc_mgtxmitframe(struct xmit_priv *pxmitpriv)
+#ifdef CONFIG_RTW_WNM
+u8 rtw_wmn_btm_rsp_reason_decision(_adapter *padapter, u8* req_mode)
 {
-	return _alloc_mgtxmitframe(pxmitpriv, _FALSE);
-}
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 reason = 0;
 
-inline struct xmit_frame *alloc_mgtxmitframe_once(struct xmit_priv *pxmitpriv)
-{
-	return _alloc_mgtxmitframe(pxmitpriv, _TRUE);
-}
+	if (!rtw_wnm_btm_diff_bss(padapter)) {
+		/* Reject - No suitable BSS transition candidates */
+		reason = 7;
+		goto candidate_remove;
+	}
 
+#ifdef CONFIG_RTW_80211R
+	if (rtw_ft_chk_flags(padapter, RTW_FT_BTM_ROAM)) {
+		/* Accept */
+		reason = 0;
+		goto under_survey;
+	}	
+#endif
 
-/****************************************************************************
+	if (((*req_mode) & DISASSOC_IMMINENT) == 0) {
+		/* Reject - Unspecified reject reason */
+		reason = 1;
+		goto candidate_remove;
+	}	
 
-Following are some TX fuctions for WiFi MLME
+	if (precvpriv->signal_strength_data.avg_val >= pmlmepriv->roam_rssi_threshold) {
+		reason = 1;
+		goto candidate_remove;
+	}
 
-*****************************************************************************/
+under_survey:	
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
+		RTW_INFO("%s reject due to _FW_UNDER_SURVEY\n", __func__);
+		reason = 1;
+	}
 
-void update_mgnt_tx_rate(_adapter *padapter, u8 rate)
-{
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+candidate_remove:
+	if (reason !=0)
+		rtw_wnm_reset_btm_candidate(&padapter->mlmepriv.nb_info);
 
-	pmlmeext->tx_rate = rate;
-	//DBG_871X("%s(): rate = %x\n",__FUNCTION__, rate);
+	return reason;
 }
 
-
-void update_monitor_frame_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
+static u32 rtw_wnm_btm_candidates_offset_get(u8* pframe)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	u8	wireless_mode;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct xmit_priv		*pxmitpriv = &padapter->xmitpriv;
-	struct sta_info		*psta = NULL;
-	struct sta_priv		*pstapriv = &padapter->stapriv;
-	struct sta_info *pbcmc_sta = NULL;
+	u8 *pos = pframe;
+	u32 offset = 0;
 
-	psta = rtw_get_stainfo(pstapriv, pattrib->ra);
-	pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+	if (!pframe)
+		return 0;
 
-	pattrib->hdrlen = 24;
-	pattrib->nr_frags = 1;
-	pattrib->priority = 7;
+	offset += 7;
+	pos += offset;
 
-	if (pbcmc_sta)
-		pattrib->mac_id = pbcmc_sta->mac_id;
-	else {
-		pattrib->mac_id = 0;
-		DBG_871X("mgmt use mac_id 0 will affect RA\n");
+	/* BSS Termination Duration check */
+	if (wnm_btm_bss_term_inc(pframe)) {
+		offset += 12;
+		pos += offset;	
+	}	
+
+	/* Session Information URL check*/
+	if (wnm_btm_ess_disassoc_im(pframe)) {
+		/*URL length field + URL variable length*/
+		offset = 1 + *(pframe + offset);
+		pos += offset;	
 	}
-	pattrib->qsel = QSLT_MGNT;
 
-	pattrib->pktlen = 0;
+	offset = (pos - pframe);
+	return offset;
+}
 
-	if (pmlmeext->tx_rate == IEEE80211_CCK_RATE_1MB)
-		wireless_mode = WIRELESS_11B;
-	else
-		wireless_mode = WIRELESS_11G;
+static void rtw_wnm_btm_req_hdr_parsing(u8* pframe, struct btm_req_hdr *phdr)
+{
+	u8 *pos = pframe;
+	u32 offset = 0;
 
-	pattrib->raid = rtw_get_mgntframe_raid(padapter, wireless_mode);
-	#ifdef CONFIG_80211AC_VHT
-		if (pHalData->rf_type == RF_1T1R)
-			pattrib->raid = RATEID_IDX_VHT_1SS;
-		else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
-			pattrib->raid = RATEID_IDX_VHT_2SS;
-		else if (pHalData->rf_type == RF_3T3R)
-			pattrib->raid = RATEID_IDX_VHT_3SS;
-		else
-			pattrib->raid = RATEID_IDX_BGN_40M_1SS;
-	#endif
+	if (!pframe || !phdr)
+		return;
 
-	#ifdef CONFIG_80211AC_VHT
-		pattrib->rate = MGN_VHT1SS_MCS9;
-	#else
-		pattrib->rate = MGN_MCS7;
-	#endif
+	_rtw_memset(phdr, 0, sizeof(struct btm_req_hdr));
+	phdr->req_mode  = wnm_btm_req_mode(pframe);
+	phdr->disassoc_timer = wnm_btm_disassoc_timer(pframe);
+	phdr->validity_interval = wnm_btm_valid_interval(pframe);
+	if (wnm_btm_bss_term_inc(pframe)) {
+		_rtw_memcpy(&phdr->term_duration, 
+			wnm_btm_term_duration_offset(pframe), 
+			sizeof(struct btm_term_duration));
+	}
+
+	RTW_DBG("WNM: req_mode(%1x), disassoc_timer(%02x), interval(%x)\n",
+		phdr->req_mode, phdr->disassoc_timer, phdr->validity_interval);
+	if (wnm_btm_bss_term_inc(pframe))
+		RTW_INFO("WNM: tsf(%llx), duration(%2x)\n",
+			phdr->term_duration.tsf, phdr->term_duration.duration);
+}
 
-	pattrib->encrypt = _NO_PRIVACY_;
-	pattrib->bswenc = _FALSE;
+void rtw_wnm_roam_scan_hdl(void *ctx)
+{
+	_adapter *padapter = (_adapter *)ctx;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
-	pattrib->qos_en = _FALSE;
-	pattrib->ht_en = 1;
-	pattrib->bwmode = CHANNEL_WIDTH_20;
-	pattrib->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	pattrib->sgi = _FALSE;
+	if (rtw_is_scan_deny(padapter)) 
+		RTW_INFO("WNM: roam scan would abort by scan_deny!\n");
+		
+	pmlmepriv->need_to_roam = _TRUE;
+	rtw_drv_scan_by_self(padapter, RTW_AUTO_SCAN_REASON_ROAM);
+}
 
-	pattrib->seqnum = pmlmeext->mgnt_seq;
+static void rtw_wnm_roam_scan(_adapter *padapter)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
 
-	pattrib->retry_ctrl = _TRUE;
+	if (rtw_is_scan_deny(padapter)) {
+		_cancel_timer_ex(&pnb->roam_scan_timer);
+		_set_timer(&pnb->roam_scan_timer, 1000);
+	} else
+		rtw_wnm_roam_scan_hdl((void *)padapter);
+}
 
-	pattrib->mbssid = 0;
-	pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
+void rtw_wnm_process_btm_req(_adapter *padapter, u8* pframe, u32 frame_len)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	struct btm_req_hdr req_hdr;
+	u8 *ptr, reason;
+	u32 elem_len, offset;
+
+	rtw_wnm_btm_req_hdr_parsing(pframe, &req_hdr);
+	offset = rtw_wnm_btm_candidates_offset_get(pframe);
+	if ((offset == 0) || ((frame_len - offset) <= 15))
+		return;
+
+	ptr = (pframe + offset);
+	elem_len = (frame_len - offset);
+	rtw_wnm_btm_candidates_survey(padapter, ptr, elem_len, _TRUE);
+	reason = rtw_wmn_btm_rsp_reason_decision(padapter, &pframe[3]);
+	rtw_wnm_issue_action(padapter, 
+		RTW_WLAN_ACTION_WNM_BTM_RSP, reason);
 
+	if (reason == 0) 
+		rtw_wnm_roam_scan(padapter);
 }
 
+void rtw_wnm_reset_btm_candidate(struct roam_nb_info *pnb)
+{
+	pnb->preference_en = _FALSE;
+	_rtw_memset(pnb->roam_target_addr, 0, ETH_ALEN);
+}
 
-void update_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
+void rtw_wnm_reset_btm_state(_adapter *padapter)
 {
-	u8	wireless_mode;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct xmit_priv 		*pxmitpriv = &padapter->xmitpriv;
-	struct sta_info		*psta = NULL;
-	struct sta_priv		*pstapriv = &padapter->stapriv;
-	struct sta_info *pbcmc_sta = NULL;
-	//_rtw_memset((u8 *)(pattrib), 0, sizeof(struct pkt_attrib));
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+
+	pnb->last_nb_rpt_entries = 0;
+	pnb->nb_rpt_is_same = _TRUE;
+	pnb->nb_rpt_valid = _FALSE;
+	pnb->nb_rpt_ch_list_num = 0;
+	rtw_wnm_reset_btm_candidate(pnb);
+	_rtw_memset(&pnb->nb_rpt, 0, sizeof(pnb->nb_rpt));
+	_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
+}
 
-	pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+void rtw_wnm_issue_action(_adapter *padapter, u8 action, u8 reason)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct xmit_frame *pmgntframe;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct pkt_attrib *pattrib;
+	u8 category, dialog_token, termination_delay, *pframe;
+	u16 *fctrl;
 
-	pattrib->hdrlen = 24;
-	pattrib->nr_frags = 1;
-	pattrib->priority = 7;
+	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
+		return ;
+	
+	pattrib = &(pmgntframe->attrib);
+	update_mgntframe_attrib(padapter, pattrib);
+	_rtw_memset(pmgntframe->buf_addr, 0, (WLANHDR_OFFSET + TXDESC_OFFSET));
 
-	if (pbcmc_sta)
-		pattrib->mac_id = pbcmc_sta->mac_id;
-	else {
-		pattrib->mac_id = 0;
-		DBG_871X("mgmt use mac_id 0 will affect RA\n");
-	}
-	pattrib->qsel = QSLT_MGNT;
+	pframe = (u8 *)(pmgntframe->buf_addr + TXDESC_OFFSET);
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
-	pattrib->pktlen = 0;
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
 
-	if (pmlmeext->tx_rate == IEEE80211_CCK_RATE_1MB)
-		wireless_mode = WIRELESS_11B;
-	else
-		wireless_mode = WIRELESS_11G;
-	pattrib->raid =  rtw_get_mgntframe_raid(padapter, wireless_mode);
-	pattrib->rate = pmlmeext->tx_rate;
-
-	pattrib->encrypt = _NO_PRIVACY_;
-	pattrib->bswenc = _FALSE;	
-
-	pattrib->qos_en = _FALSE;
-	pattrib->ht_en = _FALSE;
-	pattrib->bwmode = CHANNEL_WIDTH_20;
-	pattrib->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	pattrib->sgi = _FALSE;
+	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
 
-	pattrib->seqnum = pmlmeext->mgnt_seq;
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
-	pattrib->retry_ctrl = _TRUE;
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	pattrib->mbssid = 0;
-	pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
+	category = RTW_WLAN_CATEGORY_WNM;
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 
-	#ifdef CONFIG_BEAMFORMING
-	psta = rtw_get_stainfo(pstapriv, pattrib->ra);
-	if (psta)
-		update_attrib_txbf_info(padapter, pattrib, psta);
-	#endif
+	switch (action) {
+		case RTW_WLAN_ACTION_WNM_BTM_QUERY:
+			pframe = rtw_set_fixed_ie(pframe, 1, &(dialog_token), &(pattrib->pktlen));
+			pframe = rtw_set_fixed_ie(pframe, 1, &(reason), &(pattrib->pktlen));
+			RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_QUERY sent.\n");
+			break;
+		case RTW_WLAN_ACTION_WNM_BTM_RSP:
+			termination_delay = 0;
+			pframe = rtw_set_fixed_ie(pframe, 1, &(dialog_token), &(pattrib->pktlen));
+			pframe = rtw_set_fixed_ie(pframe, 1, &(reason), &(pattrib->pktlen));
+			pframe = rtw_set_fixed_ie(pframe, 1, &(termination_delay), &(pattrib->pktlen));
+			if (!is_zero_mac_addr(pmlmepriv->nb_info.roam_target_addr)) {
+				pframe = rtw_set_fixed_ie(pframe, 6, 
+					pmlmepriv->nb_info.roam_target_addr, &(pattrib->pktlen));
+			}
+			RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_RSP sent. reason = %d\n", reason);			
+			break;		
+		default:
+			goto exit;
+	}	
+	
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
 
+exit:	
+	return;
 }
+#endif
 
-void update_mgntframe_attrib_addr(_adapter *padapter, struct xmit_frame *pmgntframe)
+unsigned int OnAction_ht(_adapter *padapter, union recv_frame *precv_frame)
 {
-	u8	*pframe;
-	struct pkt_attrib	*pattrib = &pmgntframe->attrib;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	uint frame_len = precv_frame->u.hdr.len;
+	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
+	u8 category, action;
 
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	/* check RA matches or not */
+	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
+		goto exit;
 
-	_rtw_memcpy(pattrib->ra, GetAddr1Ptr(pframe), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, GetAddr2Ptr(pframe), ETH_ALEN);
-}
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_HT)
+		goto exit;
 
-void dump_mgntframe(_adapter *padapter, struct xmit_frame *pmgntframe)
-{
-	if (RTW_CANNOT_RUN(padapter)) {
-		rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
-		return;
+	action = frame_body[1];
+	switch (action) {
+	case RTW_WLAN_ACTION_HT_SM_PS:
+#ifdef CONFIG_80211N_HT
+#ifdef CONFIG_AP_MODE
+		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
+			rtw_process_ht_action_smps(padapter, get_addr2_ptr(pframe), frame_body[2]);
+#endif /*CONFIG_AP_MODE*/
+#endif /*CONFIG_80211N_HT*/
+		break;
+	case RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING:
+#ifdef CONFIG_BEAMFORMING
+		/*RTW_INFO("RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING\n");*/
+		rtw_beamforming_get_report_frame(padapter, precv_frame);
+#endif /*CONFIG_BEAMFORMING*/
+		break;
+	default:
+		break;
 	}
 
-	rtw_hal_mgnt_xmit(padapter, pmgntframe);
+exit:
+
+	return _SUCCESS;
 }
 
-s32 dump_mgntframe_and_wait(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms)
+#ifdef CONFIG_IEEE80211W
+unsigned int OnAction_sa_query(_adapter *padapter, union recv_frame *precv_frame)
 {
-	s32 ret = _FAIL;
-	_irqL irqL;
-	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;	
-	struct xmit_buf *pxmitbuf = pmgntframe->pxmitbuf;
-	struct submit_ctx sctx;
-
-	if (RTW_CANNOT_RUN(padapter)) {
-		rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
-		return ret;
-	}
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct sta_info		*psta;
+	struct sta_priv		*pstapriv = &padapter->stapriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u16 tid;
+	/* Baron */
 
-	rtw_sctx_init(&sctx, timeout_ms);
-	pxmitbuf->sctx = &sctx;
+	RTW_INFO("OnAction_sa_query\n");
 
-	ret = rtw_hal_mgnt_xmit(padapter, pmgntframe);
+	switch (pframe[WLAN_HDR_A3_LEN + 1]) {
+	case 0: /* SA Query req */
+		_rtw_memcpy(&tid, &pframe[WLAN_HDR_A3_LEN + 2], sizeof(u16));
+		RTW_INFO("OnAction_sa_query request,action=%d, tid=%04x, pframe=%02x-%02x\n"
+			, pframe[WLAN_HDR_A3_LEN + 1], tid, pframe[WLAN_HDR_A3_LEN + 2], pframe[WLAN_HDR_A3_LEN + 3]);
+		issue_action_SA_Query(padapter, get_addr2_ptr(pframe), 1, tid, IEEE80211W_RIGHT_KEY);
+		break;
 
-	if (ret == _SUCCESS)
-		ret = rtw_sctx_wait(&sctx, __func__);
+	case 1: /* SA Query rsp */
+		psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+		if (psta != NULL)
+			_cancel_timer_ex(&psta->dot11w_expire_timer);
 
-	_enter_critical(&pxmitpriv->lock_sctx, &irqL);
-	pxmitbuf->sctx = NULL;
-	_exit_critical(&pxmitpriv->lock_sctx, &irqL);
+		_rtw_memcpy(&tid, &pframe[WLAN_HDR_A3_LEN + 2], sizeof(u16));
+		RTW_INFO("OnAction_sa_query response,action=%d, tid=%04x, cancel timer\n", pframe[WLAN_HDR_A3_LEN + 1], tid);
+		break;
+	default:
+		break;
+	}
+	if (0) {
+		int pp;
+		printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
+		for (pp = 0; pp < pattrib->pkt_len; pp++)
+			printk(" %02x ", pframe[pp]);
+		printk("\n");
+	}
 
-	 return ret;
+	return _SUCCESS;
 }
+#endif /* CONFIG_IEEE80211W */
 
-s32 dump_mgntframe_and_wait_ack(_adapter *padapter, struct xmit_frame *pmgntframe)
+unsigned int on_action_rm(_adapter *padapter, union recv_frame *precv_frame)
 {
-#ifdef CONFIG_XMIT_ACK
-	static u8 seq_no = 0;
-	s32 ret = _FAIL;
-	u32 timeout_ms = 500;//  500ms
-	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
-	#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->pbuddy_adapter && !padapter->isprimary)
-		pxmitpriv = &(padapter->pbuddy_adapter->xmitpriv);
-	#endif
-
-	if (RTW_CANNOT_RUN(padapter)) {
-		rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
-		return -1;
-	}
-
-	_enter_critical_mutex(&pxmitpriv->ack_tx_mutex, NULL);
-	pxmitpriv->ack_tx = _TRUE;
-	pxmitpriv->seq_no = seq_no++;
-	pmgntframe->ack_report = 1;
-	rtw_sctx_init(&(pxmitpriv->ack_tx_ops), timeout_ms);
-	if (rtw_hal_mgnt_xmit(padapter, pmgntframe) == _SUCCESS) {
-#ifdef CONFIG_XMIT_ACK_POLLING
-		ret = rtw_ack_tx_polling(pxmitpriv, timeout_ms);
+#ifdef CONFIG_RTW_80211K
+	return rm_on_action(padapter, precv_frame);
 #else
-		ret = rtw_sctx_wait(&(pxmitpriv->ack_tx_ops), __func__);
-#endif
-	}
-
-	pxmitpriv->ack_tx = _FALSE;
-	_exit_critical_mutex(&pxmitpriv->ack_tx_mutex, NULL);
+	return _SUCCESS;
+#endif  /* CONFIG_RTW_80211K */
+}
 
-	 return ret;
-#else //!CONFIG_XMIT_ACK
-	dump_mgntframe(padapter, pmgntframe);
-	rtw_msleep_os(50);
+unsigned int OnAction_wmm(_adapter *padapter, union recv_frame *precv_frame)
+{
 	return _SUCCESS;
-#endif //!CONFIG_XMIT_ACK	 
 }
 
-int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
+unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame)
 {
-	u8 *ssid_ie;
-	sint ssid_len_ori;
-	int len_diff = 0;
-	
-	ssid_ie = rtw_get_ie(ies,  WLAN_EID_SSID, &ssid_len_ori, ies_len);
+#ifdef CONFIG_80211AC_VHT
+	struct rx_pkt_attrib *prxattrib = &precv_frame->u.hdr.attrib;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	uint frame_len = precv_frame->u.hdr.len;
+	struct rtw_ieee80211_hdr_3addr *whdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
+	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
+	u8 category, action;
+	struct sta_info *psta = NULL;
 
-	//DBG_871X("%s hidden_ssid_mode:%u, ssid_ie:%p, ssid_len_ori:%d\n", __FUNCTION__, hidden_ssid_mode, ssid_ie, ssid_len_ori);
-	
-	if(ssid_ie && ssid_len_ori>0)
-	{
-		switch(hidden_ssid_mode)
-		{
-			case 1:
-			{
-				u8 *next_ie = ssid_ie + 2 + ssid_len_ori;
-				u32 remain_len = 0;
-				
-				remain_len = ies_len -(next_ie-ies);
-				
-				ssid_ie[1] = 0;				
-				_rtw_memcpy(ssid_ie+2, next_ie, remain_len);
-				len_diff -= ssid_len_ori;
-				
-				break;
-			}		
-			case 2:
-				_rtw_memset(&ssid_ie[2], 0, ssid_len_ori);
-				break;
-			default:
-				break;
-		}
+	/* check RA matches or not */
+	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
+		goto exit;
+
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_VHT)
+		goto exit;
+
+	action = frame_body[1];
+	switch (action) {
+	case RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING:
+#ifdef CONFIG_BEAMFORMING
+		/*RTW_INFO("RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING\n");*/
+		rtw_beamforming_get_report_frame(padapter, precv_frame);
+#endif /*CONFIG_BEAMFORMING*/
+		break;
+	case RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION:
+		/* CategoryCode(1) + ActionCode(1) + OpModeNotification(1) */
+		/* RTW_INFO("RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION\n"); */
+		psta = rtw_get_stainfo(&padapter->stapriv, whdr->addr2);
+		if (psta)
+			rtw_process_vht_op_mode_notify(padapter, &frame_body[2], psta);
+		break;
+	case RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT:
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+		rtw_beamforming_get_vht_gid_mgnt_frame(padapter, precv_frame);
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+		break;
+	default:
+		break;
 	}
 
-	return len_diff;
+exit:
+#endif /* CONFIG_80211AC_VHT */
+
+	return _SUCCESS;
 }
 
-void issue_beacon(_adapter *padapter, int timeout_ms)
+unsigned int OnAction_p2p(_adapter *padapter, union recv_frame *precv_frame)
 {
-	struct xmit_frame	*pmgntframe;
-	struct pkt_attrib	*pattrib;
-	unsigned char	*pframe;
-	struct rtw_ieee80211_hdr *pwlanhdr;
-	unsigned short *fctrl;
-	unsigned int	rate_len;
-	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	_irqL irqL;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
-	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 #ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-#endif //CONFIG_P2P
+	u8 *frame_body;
+	u8 category, OUI_Subtype, dialogToken = 0;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	uint len = precv_frame->u.hdr.len;
+	struct	wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
+	/* check RA matches or not */
+	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
+		return _SUCCESS;
 
-	//DBG_871X("%s\n", __FUNCTION__);
+	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
 
-#ifdef CONFIG_BCN_ICF
-	if ((pmgntframe = rtw_alloc_bcnxmitframe(pxmitpriv)) == NULL)
-#else
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-#endif
-	{
-		DBG_871X("%s, alloc mgnt frame fail\n", __FUNCTION__);
-		return;
-	}
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
-#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_P2P)
+		return _SUCCESS;
 
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
-	pattrib->qsel = QSLT_BEACON;
-	#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->iface_type == IFACE_PORT1)	
-		pattrib->mbssid = 1;
-	#endif	
-	
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-		
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;	
-	
-	
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-	
-	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
+	if (cpu_to_be32(*((u32 *)(frame_body + 1))) != P2POUI)
+		return _SUCCESS;
 
-	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
-	//pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_BEACON);
-	
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);	
-	pattrib->pktlen = sizeof (struct rtw_ieee80211_hdr_3addr);
-	
-	if( (pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
-		//DBG_871X("ie len=%d\n", cur_network->IELength);
-#ifdef CONFIG_P2P
-		// for P2P : Primary Device Type & Device Name
-		u32 wpsielen=0, insert_len=0;
-		u8 *wpsie=NULL;		
-		wpsie = rtw_get_wps_ie(cur_network->IEs+_FIXED_IE_LENGTH_, cur_network->IELength-_FIXED_IE_LENGTH_, NULL, &wpsielen);
-		
-		if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && wpsie && wpsielen>0)
-		{
-			uint wps_offset, remainder_ielen;
-			u8 *premainder_ie, *pframe_wscie;
-	
-			wps_offset = (uint)(wpsie - cur_network->IEs);
+#ifdef CONFIG_IOCTL_CFG80211
+	if (adapter_wdev_data(padapter)->p2p_enabled
+		&& pwdinfo->driver_interface == DRIVER_CFG80211
+	) {
+		rtw_cfg80211_rx_action_p2p(padapter, precv_frame);
+		return _SUCCESS;
+	} else
+#endif /* CONFIG_IOCTL_CFG80211 */
+	{
+		len -= sizeof(struct rtw_ieee80211_hdr_3addr);
+		OUI_Subtype = frame_body[5];
+		dialogToken = frame_body[6];
 
-			premainder_ie = wpsie + wpsielen;
+		switch (OUI_Subtype) {
+		case P2P_NOTICE_OF_ABSENCE:
 
-			remainder_ielen = cur_network->IELength - wps_offset - wpsielen;
+			break;
 
-#ifdef CONFIG_IOCTL_CFG80211
-			if(adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211 )
-			{
-				if(pmlmepriv->wps_beacon_ie && pmlmepriv->wps_beacon_ie_len>0)
-				{
-					_rtw_memcpy(pframe, cur_network->IEs, wps_offset);
-					pframe += wps_offset;
-					pattrib->pktlen += wps_offset;
+		case P2P_PRESENCE_REQUEST:
 
-					_rtw_memcpy(pframe, pmlmepriv->wps_beacon_ie, pmlmepriv->wps_beacon_ie_len);
-					pframe += pmlmepriv->wps_beacon_ie_len;
-					pattrib->pktlen += pmlmepriv->wps_beacon_ie_len;
+			process_p2p_presence_req(pwdinfo, pframe, len);
 
-					//copy remainder_ie to pframe
-					_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
-					pframe += remainder_ielen;		
-					pattrib->pktlen += remainder_ielen;
-				}
-				else
-				{
-					_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
-					pframe += cur_network->IELength;
-					pattrib->pktlen += cur_network->IELength;
-				}
-			}
-			else
-#endif //CONFIG_IOCTL_CFG80211
-			{
-				pframe_wscie = pframe + wps_offset;
-				_rtw_memcpy(pframe, cur_network->IEs, wps_offset+wpsielen);			
-				pframe += (wps_offset + wpsielen);		
-				pattrib->pktlen += (wps_offset + wpsielen);
+			break;
 
-				//now pframe is end of wsc ie, insert Primary Device Type & Device Name
-				//	Primary Device Type
-				//	Type:
-				*(u16*) ( pframe + insert_len) = cpu_to_be16( WPS_ATTR_PRIMARY_DEV_TYPE );
-				insert_len += 2;
-				
-				//	Length:
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( 0x0008 );
-				insert_len += 2;
-				
-				//	Value:
-				//	Category ID
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
-				insert_len += 2;
+		case P2P_PRESENCE_RESPONSE:
 
-				//	OUI
-				*(u32*) ( pframe + insert_len ) = cpu_to_be32( WPSOUI );
-				insert_len += 4;
+			break;
 
-				//	Sub Category ID
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
-				insert_len += 2;
+		case P2P_GO_DISC_REQUEST:
 
+			break;
 
-				//	Device Name
-				//	Type:
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
-				insert_len += 2;
+		default:
+			break;
 
-				//	Length:
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( pwdinfo->device_name_len );
-				insert_len += 2;
+		}
+	}
+#endif /* CONFIG_P2P */
 
-				//	Value:
-				_rtw_memcpy( pframe + insert_len, pwdinfo->device_name, pwdinfo->device_name_len );
-				insert_len += pwdinfo->device_name_len;
+	return _SUCCESS;
 
+}
 
-				//update wsc ie length
-				*(pframe_wscie+1) = (wpsielen -2) + insert_len;
+unsigned int OnAction(_adapter *padapter, union recv_frame *precv_frame)
+{
+	int i;
+	unsigned char	category;
+	struct action_handler *ptable;
+	unsigned char	*frame_body;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
 
-				//pframe move to end
-				pframe+=insert_len;
-				pattrib->pktlen += insert_len;
+	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
 
-				//copy remainder_ie to pframe
-				_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
-				pframe += remainder_ielen;		
-				pattrib->pktlen += remainder_ielen;
-			}
-		}
-		else
-#endif //CONFIG_P2P
-		{
-			int len_diff;
-			_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
-			len_diff = update_hidden_ssid(
-				pframe+_BEACON_IE_OFFSET_
-				, cur_network->IELength-_BEACON_IE_OFFSET_
-				, pmlmeinfo->hidden_ssid_mode
-			);
-			pframe += (cur_network->IELength+len_diff);
-			pattrib->pktlen += (cur_network->IELength+len_diff);
-		}
+	category = frame_body[0];
 
-		{
-			u8 *wps_ie;
-			uint wps_ielen;
-			u8 sr = 0;
-			wps_ie = rtw_get_wps_ie(pmgntframe->buf_addr+TXDESC_OFFSET+sizeof (struct rtw_ieee80211_hdr_3addr)+_BEACON_IE_OFFSET_,
-				pattrib->pktlen-sizeof (struct rtw_ieee80211_hdr_3addr)-_BEACON_IE_OFFSET_, NULL, &wps_ielen);
-			if (wps_ie && wps_ielen>0) {
-				rtw_get_wps_attr_content(wps_ie,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8*)(&sr), NULL);
-			}
-			if (sr != 0)
-				set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
-			else
-				_clr_fwstate_(pmlmepriv, WIFI_UNDER_WPS);
-		}
+	for (i = 0; i < sizeof(OnAction_tbl) / sizeof(struct action_handler); i++) {
+		ptable = &OnAction_tbl[i];
 
-#ifdef CONFIG_P2P
-		if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-		{
-			u32 len;
-#ifdef CONFIG_IOCTL_CFG80211
-			if(adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211 )
-			{
-				len = pmlmepriv->p2p_beacon_ie_len;
-				if(pmlmepriv->p2p_beacon_ie && len>0)				
-					_rtw_memcpy(pframe, pmlmepriv->p2p_beacon_ie, len);
-			}
-			else
-#endif //CONFIG_IOCTL_CFG80211
-			{
-				len = build_beacon_p2p_ie(pwdinfo, pframe);
-			}
+		if (category == ptable->num)
+			ptable->func(padapter, precv_frame);
 
-			pframe += len;
-			pattrib->pktlen += len;
+	}
 
-			#ifdef CONFIG_WFD
-			len = rtw_append_beacon_wfd_ie(padapter, pframe);
-			pframe += len;
-			pattrib->pktlen += len;
-			#endif
-		}
-#endif //CONFIG_P2P
+	return _SUCCESS;
 
-		goto _issue_bcn;
+}
 
-	}
+unsigned int DoReserved(_adapter *padapter, union recv_frame *precv_frame)
+{
 
-	//below for ad-hoc mode
+	/* RTW_INFO("rcvd mgt frame(%x, %x)\n", (get_frame_sub_type(pframe) >> 4), *(unsigned int *)GetAddr1Ptr(pframe)); */
+	return _SUCCESS;
+}
 
-	//timestamp will be inserted by hardware
-	pframe += 8;
-	pattrib->pktlen += 8;
+struct xmit_frame *_alloc_mgtxmitframe(struct xmit_priv *pxmitpriv, bool once)
+{
+	struct xmit_frame *pmgntframe;
+	struct xmit_buf *pxmitbuf;
 
-	// beacon interval: 2 bytes
+	if (once)
+		pmgntframe = rtw_alloc_xmitframe_once(pxmitpriv);
+	else
+		pmgntframe = rtw_alloc_xmitframe_ext(pxmitpriv);
 
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2); 
+	if (pmgntframe == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT" alloc xmitframe fail, once:%d\n", FUNC_ADPT_ARG(pxmitpriv->adapter), once);
+		goto exit;
+	}
 
-	pframe += 2;
-	pattrib->pktlen += 2;
+	pxmitbuf = rtw_alloc_xmitbuf_ext(pxmitpriv);
+	if (pxmitbuf == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT" alloc xmitbuf fail\n", FUNC_ADPT_ARG(pxmitpriv->adapter));
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		pmgntframe = NULL;
+		goto exit;
+	}
 
-	// capability info: 2 bytes
+	pmgntframe->frame_tag = MGNT_FRAMETAG;
+	pmgntframe->pxmitbuf = pxmitbuf;
+	pmgntframe->buf_addr = pxmitbuf->pbuf;
+	pxmitbuf->priv_data = pmgntframe;
 
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
+exit:
+	return pmgntframe;
 
-	pframe += 2;
-	pattrib->pktlen += 2;
+}
 
-	// SSID
-	pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pattrib->pktlen);
+inline struct xmit_frame *alloc_mgtxmitframe(struct xmit_priv *pxmitpriv)
+{
+	return _alloc_mgtxmitframe(pxmitpriv, _FALSE);
+}
 
-	// supported rates...
-	rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
-	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8)? 8: rate_len), cur_network->SupportedRates, &pattrib->pktlen);
+inline struct xmit_frame *alloc_mgtxmitframe_once(struct xmit_priv *pxmitpriv)
+{
+	return _alloc_mgtxmitframe(pxmitpriv, _TRUE);
+}
 
-	// DS parameter set
-	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pattrib->pktlen);
 
-	//if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)
-	{
-		u8 erpinfo=0;
-		u32 ATIMWindow;
-		// IBSS Parameter Set...
-		//ATIMWindow = cur->Configuration.ATIMWindow;
-		ATIMWindow = 0;
-		pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pattrib->pktlen);
+/****************************************************************************
 
-		//ERP IE
-		pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pattrib->pktlen);
-	}	
+Following are some TX fuctions for WiFi MLME
 
+*****************************************************************************/
 
-	// EXTERNDED SUPPORTED RATE
-	if (rate_len > 8)
-	{
-		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pattrib->pktlen);
-	}
+void update_mgnt_tx_rate(_adapter *padapter, u8 rate)
+{
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 
+	pmlmeext->tx_rate = rate;
+	/* RTW_INFO("%s(): rate = %x\n",__FUNCTION__, rate); */
+}
 
-	//todo:HT for adhoc
 
-_issue_bcn:
+void update_monitor_frame_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	u8	wireless_mode;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct xmit_priv		*pxmitpriv = &padapter->xmitpriv;
+	struct sta_info		*psta = NULL;
+	struct sta_priv		*pstapriv = &padapter->stapriv;
 
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	pmlmepriv->update_bcn = _FALSE;
-	
-	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);	
-#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	psta = rtw_get_stainfo(pstapriv, pattrib->ra);
 
-	if ((pattrib->pktlen + TXDESC_SIZE) > 512)
-	{
-		DBG_871X("beacon frame too large\n");
-		return;
-	}
-	
-	pattrib->last_txcmdsz = pattrib->pktlen;
+	pattrib->hdrlen = 24;
+	pattrib->nr_frags = 1;
+	pattrib->priority = 7;
+	pattrib->mac_id = RTW_DEFAULT_MGMT_MACID;
+	pattrib->qsel = QSLT_MGNT;
 
-	//DBG_871X("issue bcn_sz=%d\n", pattrib->last_txcmdsz);
-	if(timeout_ms > 0)
-		dump_mgntframe_and_wait(padapter, pmgntframe, timeout_ms);
+	pattrib->pktlen = 0;
+
+	if (pmlmeext->tx_rate == IEEE80211_CCK_RATE_1MB)
+		wireless_mode = WIRELESS_11B;
 	else
-		dump_mgntframe(padapter, pmgntframe);
+		wireless_mode = WIRELESS_11G;
 
-}
+	pattrib->raid = rtw_get_mgntframe_raid(padapter, wireless_mode);
+#ifdef CONFIG_80211AC_VHT
+	if (pHalData->rf_type == RF_1T1R)
+		pattrib->raid = RATEID_IDX_VHT_1SS;
+	else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
+		pattrib->raid = RATEID_IDX_VHT_2SS;
+	else if (pHalData->rf_type == RF_3T3R)
+		pattrib->raid = RATEID_IDX_VHT_3SS;
+	else
+		pattrib->raid = RATEID_IDX_BGN_40M_1SS;
+#endif
 
-void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probereq)
-{
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	unsigned char					*pframe;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short				*fctrl;	
-	unsigned char					*mac, *bssid;
-	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	u8 *pwps_ie;
-	uint wps_ielen;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
-	unsigned int	rate_len;
-#ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-#ifdef CONFIG_WFD
-	u32					wfdielen = 0;
+#ifdef CONFIG_80211AC_VHT
+	pattrib->rate = MGN_VHT1SS_MCS9;
+#else
+	pattrib->rate = MGN_MCS7;
 #endif
-#endif //CONFIG_P2P
 
-	//DBG_871X("%s\n", __FUNCTION__);
+	pattrib->encrypt = _NO_PRIVACY_;
+	pattrib->bswenc = _FALSE;
 
-	if(da == NULL)
-		return;
+	pattrib->qos_en = _FALSE;
+	pattrib->ht_en = 1;
+	pattrib->bwmode = CHANNEL_WIDTH_20;
+	pattrib->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	pattrib->sgi = _FALSE;
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		return;
+	pattrib->seqnum = pmlmeext->mgnt_seq;
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		DBG_871X("%s, alloc mgnt frame fail\n", __FUNCTION__);
-		return;
-	}
+	pattrib->retry_ctrl = _TRUE;
 
+	pattrib->mbssid = 0;
+	pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
 
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);	
-	
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-		
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;	
-	
-	mac = adapter_mac_addr(padapter);
-	bssid = cur_network->MacAddress;
-	
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, bssid, ETH_ALEN);
-
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(fctrl, WIFI_PROBERSP);
-	
-	pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = pattrib->hdrlen;
-	pframe += pattrib->hdrlen;
-
-
-	if(cur_network->IELength>MAX_IE_SZ)
-		return;
-	
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-	if( (pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
-		pwps_ie = rtw_get_wps_ie(cur_network->IEs+_FIXED_IE_LENGTH_, cur_network->IELength-_FIXED_IE_LENGTH_, NULL, &wps_ielen);
-	
-		//inerset & update wps_probe_resp_ie
-		if((pmlmepriv->wps_probe_resp_ie!=NULL) && pwps_ie && (wps_ielen>0))
-		{
-			uint wps_offset, remainder_ielen;
-			u8 *premainder_ie;		
-	
-			wps_offset = (uint)(pwps_ie - cur_network->IEs);
+}
 
-			premainder_ie = pwps_ie + wps_ielen;
 
-			remainder_ielen = cur_network->IELength - wps_offset - wps_ielen;
+void update_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
+{
+	u8	wireless_mode;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct xmit_priv		*pxmitpriv = &padapter->xmitpriv;
+	/* _rtw_memset((u8 *)(pattrib), 0, sizeof(struct pkt_attrib)); */
 
-			_rtw_memcpy(pframe, cur_network->IEs, wps_offset);		
-			pframe += wps_offset;		
-			pattrib->pktlen += wps_offset;		
+	pattrib->hdrlen = 24;
+	pattrib->nr_frags = 1;
+	pattrib->priority = 7;
+	pattrib->mac_id = RTW_DEFAULT_MGMT_MACID;
+	pattrib->qsel = QSLT_MGNT;
 
-			wps_ielen = (uint)pmlmepriv->wps_probe_resp_ie[1];//to get ie data len
-			if((wps_offset+wps_ielen+2)<=MAX_IE_SZ)
-			{
-				_rtw_memcpy(pframe, pmlmepriv->wps_probe_resp_ie, wps_ielen+2);
-				pframe += wps_ielen+2;		
-				pattrib->pktlen += wps_ielen+2;	
-			}
+#ifdef CONFIG_MCC_MODE
+	update_mcc_mgntframe_attrib(padapter, pattrib);
+#endif
 
-			if((wps_offset+wps_ielen+2+remainder_ielen)<=MAX_IE_SZ)
-			{
-				_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
-				pframe += remainder_ielen;		
-				pattrib->pktlen += remainder_ielen;	
-			}
-		}
-		else
-		{
-			_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
-			pframe += cur_network->IELength;
-			pattrib->pktlen += cur_network->IELength;
-		}
+	pattrib->pktlen = 0;
 
-		/* retrieve SSID IE from cur_network->Ssid */
-		{
-			u8 *ssid_ie;
-			sint ssid_ielen;
-			sint ssid_ielen_diff;
-			u8 buf[MAX_IE_SZ];
-			u8 *ies = pmgntframe->buf_addr+TXDESC_OFFSET+sizeof(struct rtw_ieee80211_hdr_3addr);
+	if (IS_CCK_RATE(pmlmeext->tx_rate))
+		wireless_mode = WIRELESS_11B;
+	else
+		wireless_mode = WIRELESS_11G;
+	pattrib->raid =  rtw_get_mgntframe_raid(padapter, wireless_mode);
+	pattrib->rate = pmlmeext->tx_rate;
 
-			ssid_ie = rtw_get_ie(ies+_FIXED_IE_LENGTH_, _SSID_IE_, &ssid_ielen,
-				(pframe-ies)-_FIXED_IE_LENGTH_);
+	pattrib->encrypt = _NO_PRIVACY_;
+	pattrib->bswenc = _FALSE;
 
-			ssid_ielen_diff = cur_network->Ssid.SsidLength - ssid_ielen;
+	pattrib->qos_en = _FALSE;
+	pattrib->ht_en = _FALSE;
+	pattrib->bwmode = CHANNEL_WIDTH_20;
+	pattrib->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	pattrib->sgi = _FALSE;
 
-			if (ssid_ie &&  cur_network->Ssid.SsidLength) {
-				uint remainder_ielen;
-				u8 *remainder_ie;
-				remainder_ie = ssid_ie+2;
-				remainder_ielen = (pframe-remainder_ie);
+	pattrib->seqnum = pmlmeext->mgnt_seq;
 
-				if (remainder_ielen > MAX_IE_SZ) {
-					DBG_871X_LEVEL(_drv_warning_, FUNC_ADPT_FMT" remainder_ielen > MAX_IE_SZ\n", FUNC_ADPT_ARG(padapter));
-					remainder_ielen = MAX_IE_SZ;
-				}
+	pattrib->retry_ctrl = _TRUE;
 
-				_rtw_memcpy(buf, remainder_ie, remainder_ielen);
-				_rtw_memcpy(remainder_ie+ssid_ielen_diff, buf, remainder_ielen);
-				*(ssid_ie+1) = cur_network->Ssid.SsidLength;
-				_rtw_memcpy(ssid_ie+2, cur_network->Ssid.Ssid, cur_network->Ssid.SsidLength);
+	pattrib->mbssid = 0;
+	pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
+}
 
-				pframe += ssid_ielen_diff;
-				pattrib->pktlen += ssid_ielen_diff;
-			}
-		}
-	}	
-	else		
-#endif		
-	{
-	
-		//timestamp will be inserted by hardware
-		pframe += 8;
-		pattrib->pktlen += 8;
+void update_mgntframe_attrib_addr(_adapter *padapter, struct xmit_frame *pmgntframe)
+{
+	u8	*pframe;
+	struct pkt_attrib	*pattrib = &pmgntframe->attrib;
+#if defined(CONFIG_BEAMFORMING) || defined(CONFIG_ANTENNA_DIVERSITY)
+	struct sta_info		*sta = NULL;
+#endif
 
-		// beacon interval: 2 bytes
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
 
-		_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2); 
+	_rtw_memcpy(pattrib->ra, GetAddr1Ptr(pframe), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, get_addr2_ptr(pframe), ETH_ALEN);
 
-		pframe += 2;
-		pattrib->pktlen += 2;
+#if defined(CONFIG_BEAMFORMING) || defined(CONFIG_ANTENNA_DIVERSITY)
+	sta = pattrib->psta;
+	if (!sta) {
+		sta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
+		pattrib->psta = sta;
+	}
+	#ifdef CONFIG_BEAMFORMING
+	if (sta)
+		update_attrib_txbf_info(padapter, pattrib, sta);
+	#endif
+#endif /* defined(CONFIG_BEAMFORMING) || defined(CONFIG_ANTENNA_DIVERSITY) */
+}
 
-		// capability info: 2 bytes
+void dump_mgntframe(_adapter *padapter, struct xmit_frame *pmgntframe)
+{
+	if (RTW_CANNOT_RUN(padapter)) {
+		rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
+		return;
+	}
 
-		_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
+	rtw_hal_mgnt_xmit(padapter, pmgntframe);
+}
 
-		pframe += 2;
-		pattrib->pktlen += 2;
+s32 dump_mgntframe_and_wait(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms)
+{
+	s32 ret = _FAIL;
+	_irqL irqL;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct xmit_buf *pxmitbuf = pmgntframe->pxmitbuf;
+	struct submit_ctx sctx;
 
-		//below for ad-hoc mode
+	if (RTW_CANNOT_RUN(padapter)) {
+		rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
+		return ret;
+	}
 
-		// SSID
-		pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pattrib->pktlen);
+	rtw_sctx_init(&sctx, timeout_ms);
+	pxmitbuf->sctx = &sctx;
 
-		// supported rates...
-		rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8)? 8: rate_len), cur_network->SupportedRates, &pattrib->pktlen);
+	ret = rtw_hal_mgnt_xmit(padapter, pmgntframe);
 
-		// DS parameter set
-		pframe =rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pattrib->pktlen);
+	if (ret == _SUCCESS)
+		ret = rtw_sctx_wait(&sctx, __func__);
 
-		if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)
-		{
-			u8 erpinfo=0;
-			u32 ATIMWindow;
-			// IBSS Parameter Set...
-			//ATIMWindow = cur->Configuration.ATIMWindow;
-			ATIMWindow = 0;
-			pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pattrib->pktlen);
+	_enter_critical(&pxmitpriv->lock_sctx, &irqL);
+	pxmitbuf->sctx = NULL;
+	_exit_critical(&pxmitpriv->lock_sctx, &irqL);
 
-			//ERP IE
-			pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pattrib->pktlen);
-		}
+	return ret;
+}
 
-		
-		// EXTERNDED SUPPORTED RATE
-		if (rate_len > 8)
-		{
-			pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pattrib->pktlen);
-		}
+s32 dump_mgntframe_and_wait_ack_timeout(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms)
+{
+#ifdef CONFIG_XMIT_ACK
+	static u8 seq_no = 0;
+	s32 ret = _FAIL;
+	struct xmit_priv	*pxmitpriv = &(GET_PRIMARY_ADAPTER(padapter))->xmitpriv;
 
+	if (RTW_CANNOT_RUN(padapter)) {
+		rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
+		return -1;
+	}
 
-		//todo:HT for adhoc
+	_enter_critical_mutex(&pxmitpriv->ack_tx_mutex, NULL);
+	pxmitpriv->ack_tx = _TRUE;
+	pxmitpriv->seq_no = seq_no++;
+	pmgntframe->ack_report = 1;
+	rtw_sctx_init(&(pxmitpriv->ack_tx_ops), timeout_ms);
+	if (rtw_hal_mgnt_xmit(padapter, pmgntframe) == _SUCCESS)
+		ret = rtw_sctx_wait(&(pxmitpriv->ack_tx_ops), __func__);
 
-	}	
+	pxmitpriv->ack_tx = _FALSE;
+	_exit_critical_mutex(&pxmitpriv->ack_tx_mutex, NULL);
 
-#ifdef CONFIG_P2P
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)
-		/* IOT issue, When wifi_spec is not set, send probe_resp with P2P IE even if probe_req has no P2P IE */
-		&& (is_valid_p2p_probereq || !padapter->registrypriv.wifi_spec))
-	{
-		u32 len;
-#ifdef CONFIG_IOCTL_CFG80211
-		if(adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211 )
-		{
-			//if pwdinfo->role == P2P_ROLE_DEVICE will call issue_probersp_p2p()
-			len = pmlmepriv->p2p_go_probe_resp_ie_len;
-			if(pmlmepriv->p2p_go_probe_resp_ie && len>0)
-				_rtw_memcpy(pframe, pmlmepriv->p2p_go_probe_resp_ie, len);
-		}
-		else
-#endif //CONFIG_IOCTL_CFG80211
-		{
-			len = build_probe_resp_p2p_ie(pwdinfo, pframe);
-		}
+	return ret;
+#else /* !CONFIG_XMIT_ACK */
+	dump_mgntframe(padapter, pmgntframe);
+	rtw_msleep_os(50);
+	return _SUCCESS;
+#endif /* !CONFIG_XMIT_ACK */
+}
 
-		pframe += len;
-		pattrib->pktlen += len;
-		
-		#ifdef CONFIG_WFD
-		len = rtw_append_probe_resp_wfd_ie(padapter, pframe);
-		pframe += len;
-		pattrib->pktlen += len;
-		#endif
-	}
-#endif //CONFIG_P2P
+s32 dump_mgntframe_and_wait_ack(_adapter *padapter, struct xmit_frame *pmgntframe)
+{
+	/* In this case, use 500 ms as the default wait_ack timeout */
+	return dump_mgntframe_and_wait_ack_timeout(padapter, pmgntframe, 500);
+}
 
 
-#ifdef CONFIG_AUTO_AP_MODE
+int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
 {
-	struct sta_info	*psta;
-	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *ssid_ie;
+	sint ssid_len_ori;
+	int len_diff = 0;
 
-	DBG_871X("(%s)\n", __FUNCTION__);
+	ssid_ie = rtw_get_ie(ies,  WLAN_EID_SSID, &ssid_len_ori, ies_len);
 
-	//check rc station
-	psta = rtw_get_stainfo(pstapriv, da);
-	if (psta && psta->isrc && psta->pid>0)
-	{
-		u8 RC_OUI[4]={0x00,0xE0,0x4C,0x0A};
-		u8 RC_INFO[14] = {0};
-		//EID[1] + EID_LEN[1] + RC_OUI[4] + MAC[6] + PairingID[2] + ChannelNum[2]
-		u16 cu_ch = (u16)cur_network->Configuration.DSConfig;
+	/* RTW_INFO("%s hidden_ssid_mode:%u, ssid_ie:%p, ssid_len_ori:%d\n", __FUNCTION__, hidden_ssid_mode, ssid_ie, ssid_len_ori); */
 
-		DBG_871X("%s, reply rc(pid=0x%x) device "MAC_FMT" in ch=%d\n", __FUNCTION__,
-			psta->pid, MAC_ARG(psta->hwaddr), cu_ch);
+	if (ssid_ie && ssid_len_ori > 0) {
+		switch (hidden_ssid_mode) {
+		case 1: {
+			u8 *next_ie = ssid_ie + 2 + ssid_len_ori;
+			u32 remain_len = 0;
 
-		//append vendor specific ie
-		_rtw_memcpy(RC_INFO, RC_OUI, sizeof(RC_OUI));
-		_rtw_memcpy(&RC_INFO[4], mac, ETH_ALEN);
-		_rtw_memcpy(&RC_INFO[10], (u8*)&psta->pid, 2);
-		_rtw_memcpy(&RC_INFO[12], (u8*)&cu_ch, 2);
+			remain_len = ies_len - (next_ie - ies);
 
-		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, sizeof(RC_INFO), RC_INFO, &pattrib->pktlen);
+			ssid_ie[1] = 0;
+			_rtw_memcpy(ssid_ie + 2, next_ie, remain_len);
+			len_diff -= ssid_len_ori;
+
+			break;
+		}
+		case 2:
+			_rtw_memset(&ssid_ie[2], 0, ssid_len_ori);
+			break;
+		default:
+			break;
+		}
 	}
-}
-#endif //CONFIG_AUTO_AP_MODE
 
+	return len_diff;
+}
 
-	pattrib->last_txcmdsz = pattrib->pktlen;
-	
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+u32 rtw_build_vendor_ie(_adapter *padapter , unsigned char *pframe , u8 mgmt_frame_tyte)
+{
+	int vendor_ie_num = 0;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 len = 0;
 
-	dump_mgntframe(padapter, pmgntframe);
-	
-	return;
+	for (vendor_ie_num = 0 ; vendor_ie_num < WLAN_MAX_VENDOR_IE_NUM ; vendor_ie_num++) {
+		if (pmlmepriv->vendor_ielen[vendor_ie_num] > 0 && pmlmepriv->vendor_ie_mask[vendor_ie_num] & mgmt_frame_tyte) {
+			_rtw_memcpy(pframe , pmlmepriv->vendor_ie[vendor_ie_num] , pmlmepriv->vendor_ielen[vendor_ie_num]);
+			pframe +=  pmlmepriv->vendor_ielen[vendor_ie_num];
+			len += pmlmepriv->vendor_ielen[vendor_ie_num];
+		}
+	}
 
+	return len;
 }
+#endif
 
-int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch, bool append_wps, int wait_ack)
+void issue_beacon(_adapter *padapter, int timeout_ms)
 {
-	int ret = _FAIL;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	unsigned char			*pframe;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short		*fctrl;
-	unsigned char			*mac;
-	unsigned char			bssrate[NumRates];
-	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
+	struct xmit_frame	*pmgntframe;
+	struct pkt_attrib	*pattrib;
+	unsigned char	*pframe;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	unsigned short *fctrl;
+	unsigned int	rate_len;
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	_irqL irqL;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	int	bssrate_len = 0;
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
 	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+#ifdef CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		goto exit;
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		goto exit;
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+#ifdef CONFIG_BCN_ICF
+	pmgntframe = rtw_alloc_bcnxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+#else
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+#endif
+	{
+		RTW_INFO("%s, alloc mgnt frame fail\n", __FUNCTION__);
+		return;
 	}
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
+#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
+	pattrib->qsel = QSLT_BEACON;
 
+#if defined(CONFIG_CONCURRENT_MODE) && (!defined(CONFIG_SWTIMER_BASED_TXBCN))
+	if (padapter->hw_port == HW_PORT1)
+		pattrib->mbssid = 1;
+#endif
 
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
-	mac = adapter_mac_addr(padapter);
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	if (da)
-	{
-		//	unicast probe request frame
-		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
-	}
-	else
-	{
-		//	broadcast probe request frame
-		_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, bc_addr, ETH_ALEN);
-	}
+	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
 
-	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
+	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
+	/* pmlmeext->mgnt_seq++; */
+	set_frame_sub_type(pframe, WIFI_BEACON);
 
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_PROBEREQ);
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	pframe += sizeof (struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof (struct rtw_ieee80211_hdr_3addr);
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+		/* RTW_INFO("ie len=%d\n", cur_network->IELength); */
+#ifdef CONFIG_P2P
+		/* for P2P : Primary Device Type & Device Name */
+		u32 wpsielen = 0, insert_len = 0;
+		u8 *wpsie = NULL;
+		wpsie = rtw_get_wps_ie(cur_network->IEs + _FIXED_IE_LENGTH_, cur_network->IELength - _FIXED_IE_LENGTH_, NULL, &wpsielen);
 
-	if(pssid)
-		pframe = rtw_set_ie(pframe, _SSID_IE_, pssid->SsidLength, pssid->Ssid, &(pattrib->pktlen));
-	else
-		pframe = rtw_set_ie(pframe, _SSID_IE_, 0, NULL, &(pattrib->pktlen));
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && wpsie && wpsielen > 0) {
+			uint wps_offset, remainder_ielen;
+			u8 *premainder_ie, *pframe_wscie;
 
-	get_rate_set(padapter, bssrate, &bssrate_len);
+			wps_offset = (uint)(wpsie - cur_network->IEs);
 
-	if (bssrate_len > 8)
-	{
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
-		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
-	}
-	else
-	{
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
-	}
+			premainder_ie = wpsie + wpsielen;
 
-	if (ch)
-		pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, &ch, &pattrib->pktlen);
+			remainder_ielen = cur_network->IELength - wps_offset - wpsielen;
 
-	if (append_wps) {
-		//add wps_ie for wps2.0
-		if(pmlmepriv->wps_probe_req_ie_len>0 && pmlmepriv->wps_probe_req_ie)
+#ifdef CONFIG_IOCTL_CFG80211
+			if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
+				if (pmlmepriv->wps_beacon_ie && pmlmepriv->wps_beacon_ie_len > 0) {
+					_rtw_memcpy(pframe, cur_network->IEs, wps_offset);
+					pframe += wps_offset;
+					pattrib->pktlen += wps_offset;
+
+					_rtw_memcpy(pframe, pmlmepriv->wps_beacon_ie, pmlmepriv->wps_beacon_ie_len);
+					pframe += pmlmepriv->wps_beacon_ie_len;
+					pattrib->pktlen += pmlmepriv->wps_beacon_ie_len;
+
+					/* copy remainder_ie to pframe */
+					_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
+					pframe += remainder_ielen;
+					pattrib->pktlen += remainder_ielen;
+				} else {
+					_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
+					pframe += cur_network->IELength;
+					pattrib->pktlen += cur_network->IELength;
+				}
+			} else
+#endif /* CONFIG_IOCTL_CFG80211 */
+			{
+				pframe_wscie = pframe + wps_offset;
+				_rtw_memcpy(pframe, cur_network->IEs, wps_offset + wpsielen);
+				pframe += (wps_offset + wpsielen);
+				pattrib->pktlen += (wps_offset + wpsielen);
+
+				/* now pframe is end of wsc ie, insert Primary Device Type & Device Name */
+				/*	Primary Device Type */
+				/*	Type: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
+				insert_len += 2;
+
+				/*	Length: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(0x0008);
+				insert_len += 2;
+
+				/*	Value: */
+				/*	Category ID */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
+				insert_len += 2;
+
+				/*	OUI */
+				*(u32 *)(pframe + insert_len) = cpu_to_be32(WPSOUI);
+				insert_len += 4;
+
+				/*	Sub Category ID */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
+				insert_len += 2;
+
+
+				/*	Device Name */
+				/*	Type: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
+				insert_len += 2;
+
+				/*	Length: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(pwdinfo->device_name_len);
+				insert_len += 2;
+
+				/*	Value: */
+				_rtw_memcpy(pframe + insert_len, pwdinfo->device_name, pwdinfo->device_name_len);
+				insert_len += pwdinfo->device_name_len;
+
+
+				/* update wsc ie length */
+				*(pframe_wscie + 1) = (wpsielen - 2) + insert_len;
+
+				/* pframe move to end */
+				pframe += insert_len;
+				pattrib->pktlen += insert_len;
+
+				/* copy remainder_ie to pframe */
+				_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
+				pframe += remainder_ielen;
+				pattrib->pktlen += remainder_ielen;
+			}
+		} else
+#endif /* CONFIG_P2P */
 		{
-			_rtw_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;
-			//pmlmepriv->wps_probe_req_ie_len = 0 ;//reset to zero
+			int len_diff;
+			_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
+			len_diff = update_hidden_ssid(
+					   pframe + _BEACON_IE_OFFSET_
+				   , cur_network->IELength - _BEACON_IE_OFFSET_
+					   , pmlmeinfo->hidden_ssid_mode
+				   );
+			pframe += (cur_network->IELength + len_diff);
+			pattrib->pktlen += (cur_network->IELength + len_diff);
 		}
-	}
 
-	pattrib->last_txcmdsz = pattrib->pktlen;
+		{
+			u8 *wps_ie;
+			uint wps_ielen;
+			u8 sr = 0;
+			wps_ie = rtw_get_wps_ie(pmgntframe->buf_addr + TXDESC_OFFSET + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_,
+				pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_, NULL, &wps_ielen);
+			if (wps_ie && wps_ielen > 0)
+				rtw_get_wps_attr_content(wps_ie,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
+			if (sr != 0)
+				set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
+			else
+				_clr_fwstate_(pmlmepriv, WIFI_UNDER_WPS);
+		}
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_notice_,("issuing probe_req, tx_len=%d\n", pattrib->last_txcmdsz));
+#ifdef CONFIG_RTW_80211K
+		pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_,
+			sizeof(padapter->rmpriv.rm_en_cap_def),
+			padapter->rmpriv.rm_en_cap_def, &pattrib->pktlen);
+#endif
+
+#ifdef CONFIG_P2P
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+			u32 len;
+#ifdef CONFIG_IOCTL_CFG80211
+			if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
+				len = pmlmepriv->p2p_beacon_ie_len;
+				if (pmlmepriv->p2p_beacon_ie && len > 0)
+					_rtw_memcpy(pframe, pmlmepriv->p2p_beacon_ie, len);
+			} else
+#endif /* CONFIG_IOCTL_CFG80211 */
+			{
+				len = build_beacon_p2p_ie(pwdinfo, pframe);
+			}
+
+			pframe += len;
+			pattrib->pktlen += len;
+
+#ifdef CONFIG_MCC_MODE
+			pframe = rtw_hal_mcc_append_go_p2p_ie(padapter, pframe, &pattrib->pktlen);
+#endif /* CONFIG_MCC_MODE*/
+
+#ifdef CONFIG_WFD
+			len = rtw_append_beacon_wfd_ie(padapter, pframe);
+			pframe += len;
+			pattrib->pktlen += len;
+#endif
+		}
+#endif /* CONFIG_P2P */
+#ifdef CONFIG_RTW_REPEATER_SON
+		rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
+#endif
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+		pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_BEACON_VENDOR_IE_BIT);
+#endif
+		goto _issue_bcn;
 
-	if (wait_ack) {
-		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	} else {
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
 	}
 
-exit:
-	return ret;
-}
+	/* below for ad-hoc mode */
 
-inline void issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da)
-{
-	_issue_probereq(padapter, pssid, da, 0, 1, _FALSE);
-}
+	/* timestamp will be inserted by hardware */
+	pframe += 8;
+	pattrib->pktlen += 8;
 
-/*
- * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
- * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
- * try_cnt means the maximal TX count to try
- */
-int issue_probereq_ex(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch, bool append_wps,
-	int try_cnt, int wait_ms)
-{
-	int ret = _FAIL;
-	int i = 0;
-	u32 start = rtw_get_current_time();
+	/* beacon interval: 2 bytes */
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		goto exit;
+	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
 
-	do
-	{
-		ret = _issue_probereq(padapter, pssid, da, ch, append_wps, wait_ms>0?_TRUE:_FALSE);
+	pframe += 2;
+	pattrib->pktlen += 2;
 
-		i++;
+	/* capability info: 2 bytes */
 
-		if (RTW_CANNOT_RUN(padapter))
-			break;
+	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
 
-		if(i < try_cnt && wait_ms > 0 && ret==_FAIL)
-			rtw_msleep_os(wait_ms);
+	pframe += 2;
+	pattrib->pktlen += 2;
 
-	}while((i<try_cnt) && ((ret==_FAIL)||(wait_ms==0)));
+	/* SSID */
+	pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pattrib->pktlen);
 
-	if (ret != _FAIL) {
-		ret = _SUCCESS;
-		#ifndef DBG_XMIT_ACK
-		goto exit;
-		#endif
+	/* supported rates... */
+	rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
+	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pattrib->pktlen);
+
+	/* DS parameter set */
+	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pattrib->pktlen);
+
+	/* if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) */
+	{
+		u8 erpinfo = 0;
+		u32 ATIMWindow;
+		/* IBSS Parameter Set... */
+		/* ATIMWindow = cur->Configuration.ATIMWindow; */
+		ATIMWindow = 0;
+		pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pattrib->pktlen);
+
+		/* ERP IE */
+		pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pattrib->pktlen);
 	}
 
-	if (try_cnt && wait_ms) {
-		if (da)
-			DBG_871X(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
-		else
-			DBG_871X(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+
+	/* EXTERNDED SUPPORTED RATE */
+	if (rate_len > 8)
+		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pattrib->pktlen);
+
+
+	/* todo:HT for adhoc */
+
+_issue_bcn:
+
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	pmlmepriv->update_bcn = _FALSE;
+
+	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
+#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
+
+	if ((pattrib->pktlen + TXDESC_SIZE) > 512) {
+		RTW_INFO("beacon frame too large\n");
+		return;
 	}
-exit:
-	return ret;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	/* RTW_INFO("issue bcn_sz=%d\n", pattrib->last_txcmdsz); */
+	if (timeout_ms > 0)
+		dump_mgntframe_and_wait(padapter, pmgntframe, timeout_ms);
+	else
+		dump_mgntframe(padapter, pmgntframe);
+
 }
 
-// if psta == NULL, indiate we are station(client) now...
-void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status)
+void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probereq)
 {
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short				*fctrl;
-	unsigned int					val32;
-	unsigned short				val16;
-	int use_shared_key = 0;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	unsigned char					*mac, *bssid;
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	u8 *pwps_ie;
+	uint wps_ielen;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
+	unsigned int	rate_len;
+#ifdef CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+#ifdef CONFIG_WFD
+	u32					wfdielen = 0;
+#endif
+#endif /* CONFIG_P2P */
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+	if (da == NULL)
 		return;
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		return;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		RTW_INFO("%s, alloc mgnt frame fail\n", __FUNCTION__);
 		return;
 	}
 
-	//update attribute
+
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -8320,157 +8552,262 @@ void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
+	mac = adapter_mac_addr(padapter);
+	bssid = cur_network->MacAddress;
+
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
+	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, bssid, ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_AUTH);
+	set_frame_sub_type(fctrl, WIFI_PROBERSP);
 
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = pattrib->hdrlen;
+	pframe += pattrib->hdrlen;
 
 
-	if(psta)// for AP mode
-	{
-#ifdef CONFIG_NATIVEAP_MLME
+	if (cur_network->IELength > MAX_IE_SZ)
+		return;
 
-		_rtw_memcpy(pwlanhdr->addr1, psta->hwaddr, ETH_ALEN);		
-		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+		pwps_ie = rtw_get_wps_ie(cur_network->IEs + _FIXED_IE_LENGTH_, cur_network->IELength - _FIXED_IE_LENGTH_, NULL, &wps_ielen);
 
-	
-		// setting auth algo number
-		val16 = (u16)psta->authalg;
+		/* inerset & update wps_probe_resp_ie */
+		if ((pmlmepriv->wps_probe_resp_ie != NULL) && pwps_ie && (wps_ielen > 0)) {
+			uint wps_offset, remainder_ielen;
+			u8 *premainder_ie;
 
-		if(status != _STATS_SUCCESSFUL_)
-			val16 = 0;
+			wps_offset = (uint)(pwps_ie - cur_network->IEs);
 
-		if (val16)	{
-			val16 = cpu_to_le16(val16);	
-			use_shared_key = 1;
-		}
+			premainder_ie = pwps_ie + wps_ielen;
 
-		pframe = rtw_set_fixed_ie(pframe, _AUTH_ALGM_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
+			remainder_ielen = cur_network->IELength - wps_offset - wps_ielen;
 
-		// setting auth seq number
-		val16 =(u16)psta->auth_seq;
-		val16 = cpu_to_le16(val16);	
-		pframe = rtw_set_fixed_ie(pframe, _AUTH_SEQ_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
+			_rtw_memcpy(pframe, cur_network->IEs, wps_offset);
+			pframe += wps_offset;
+			pattrib->pktlen += wps_offset;
 
-		// setting status code...
-		val16 = status;
-		val16 = cpu_to_le16(val16);	
-		pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
+			wps_ielen = (uint)pmlmepriv->wps_probe_resp_ie[1];/* to get ie data len */
+			if ((wps_offset + wps_ielen + 2) <= MAX_IE_SZ) {
+				_rtw_memcpy(pframe, pmlmepriv->wps_probe_resp_ie, wps_ielen + 2);
+				pframe += wps_ielen + 2;
+				pattrib->pktlen += wps_ielen + 2;
+			}
+
+			if ((wps_offset + wps_ielen + 2 + remainder_ielen) <= MAX_IE_SZ) {
+				_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
+				pframe += remainder_ielen;
+				pattrib->pktlen += remainder_ielen;
+			}
+		} else {
+			_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
+			pframe += cur_network->IELength;
+			pattrib->pktlen += cur_network->IELength;
+		}
 
-		// added challenging text...
-		if ((psta->auth_seq == 2) && (psta->state & WIFI_FW_AUTH_STATE) && (use_shared_key==1))
+		/* retrieve SSID IE from cur_network->Ssid */
 		{
-			pframe = rtw_set_ie(pframe, _CHLGETXT_IE_, 128, psta->chg_txt, &(pattrib->pktlen));
+			u8 *ssid_ie;
+			sint ssid_ielen;
+			sint ssid_ielen_diff;
+			u8 buf[MAX_IE_SZ];
+			u8 *ies = pmgntframe->buf_addr + TXDESC_OFFSET + sizeof(struct rtw_ieee80211_hdr_3addr);
+
+			ssid_ie = rtw_get_ie(ies + _FIXED_IE_LENGTH_, _SSID_IE_, &ssid_ielen,
+				     (pframe - ies) - _FIXED_IE_LENGTH_);
+
+			ssid_ielen_diff = cur_network->Ssid.SsidLength - ssid_ielen;
+
+			if (ssid_ie &&  cur_network->Ssid.SsidLength) {
+				uint remainder_ielen;
+				u8 *remainder_ie;
+				remainder_ie = ssid_ie + 2;
+				remainder_ielen = (pframe - remainder_ie);
+
+				if (remainder_ielen > MAX_IE_SZ) {
+					RTW_WARN(FUNC_ADPT_FMT" remainder_ielen > MAX_IE_SZ\n", FUNC_ADPT_ARG(padapter));
+					remainder_ielen = MAX_IE_SZ;
+				}
+
+				_rtw_memcpy(buf, remainder_ie, remainder_ielen);
+				_rtw_memcpy(remainder_ie + ssid_ielen_diff, buf, remainder_ielen);
+				*(ssid_ie + 1) = cur_network->Ssid.SsidLength;
+				_rtw_memcpy(ssid_ie + 2, cur_network->Ssid.Ssid, cur_network->Ssid.SsidLength);
+
+				pframe += ssid_ielen_diff;
+				pattrib->pktlen += ssid_ielen_diff;
+			}
 		}
+#ifdef CONFIG_RTW_REPEATER_SON
+		rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
 #endif
-	}
-	else
-	{		
-		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
-	
-		// setting auth algo number		
-		val16 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)? 1: 0;// 0:OPEN System, 1:Shared key
-		if (val16)	{
-			val16 = cpu_to_le16(val16);	
-			use_shared_key = 1;
-		}	
-		//DBG_871X("%s auth_algo= %s auth_seq=%d\n",__FUNCTION__,(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))
-		{
-			//DBG_871X("==> iv(%d),key_index(%d)\n",pmlmeinfo->iv,pmlmeinfo->key_index);
-			val32 = ((pmlmeinfo->iv++) | (pmlmeinfo->key_index << 30));
-			val32 = cpu_to_le32(val32);
-			pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *)&val32, &(pattrib->pktlen));
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+		pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_PROBERESP_VENDOR_IE_BIT);
+#endif
+	} else
+#endif
+	{
 
-			pattrib->iv_len = 4;
+		/* timestamp will be inserted by hardware */
+		pframe += 8;
+		pattrib->pktlen += 8;
+
+		/* beacon interval: 2 bytes */
+
+		_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
+
+		pframe += 2;
+		pattrib->pktlen += 2;
+
+		/* capability info: 2 bytes */
+
+		_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
+
+		pframe += 2;
+		pattrib->pktlen += 2;
+
+		/* below for ad-hoc mode */
+
+		/* SSID */
+		pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pattrib->pktlen);
+
+		/* supported rates... */
+		rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pattrib->pktlen);
+
+		/* DS parameter set */
+		pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pattrib->pktlen);
+
+		if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
+			u8 erpinfo = 0;
+			u32 ATIMWindow;
+			/* IBSS Parameter Set... */
+			/* ATIMWindow = cur->Configuration.ATIMWindow; */
+			ATIMWindow = 0;
+			pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pattrib->pktlen);
+
+			/* ERP IE */
+			pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pattrib->pktlen);
 		}
 
-		pframe = rtw_set_fixed_ie(pframe, _AUTH_ALGM_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
-		
-		// setting auth seq number
-		val16 = pmlmeinfo->auth_seq;
-		val16 = cpu_to_le16(val16);	
-		pframe = rtw_set_fixed_ie(pframe, _AUTH_SEQ_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
 
-		
-		// setting status code...
-		val16 = status;
-		val16 = cpu_to_le16(val16);	
-		pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
+		/* EXTERNDED SUPPORTED RATE */
+		if (rate_len > 8)
+			pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pattrib->pktlen);
+
+
+		/* todo:HT for adhoc */
+
+	}
+
+#ifdef CONFIG_RTW_80211K
+	pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_,
+		sizeof(padapter->rmpriv.rm_en_cap_def),
+		padapter->rmpriv.rm_en_cap_def, &pattrib->pktlen);
+#endif
 
-		// then checking to see if sending challenging text...
-		if ((pmlmeinfo->auth_seq == 3) && (pmlmeinfo->state & WIFI_FW_AUTH_STATE) && (use_shared_key==1))
+#ifdef CONFIG_P2P
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)
+	    /* IOT issue, When wifi_spec is not set, send probe_resp with P2P IE even if probe_req has no P2P IE */
+	    && (is_valid_p2p_probereq || !padapter->registrypriv.wifi_spec)) {
+		u32 len;
+#ifdef CONFIG_IOCTL_CFG80211
+		if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
+			/* if pwdinfo->role == P2P_ROLE_DEVICE will call issue_probersp_p2p() */
+			len = pmlmepriv->p2p_go_probe_resp_ie_len;
+			if (pmlmepriv->p2p_go_probe_resp_ie && len > 0)
+				_rtw_memcpy(pframe, pmlmepriv->p2p_go_probe_resp_ie, len);
+		} else
+#endif /* CONFIG_IOCTL_CFG80211 */
 		{
-			pframe = rtw_set_ie(pframe, _CHLGETXT_IE_, 128, pmlmeinfo->chg_txt, &(pattrib->pktlen));
+			len = build_probe_resp_p2p_ie(pwdinfo, pframe);
+		}
 
-			SetPrivacy(fctrl);
-			
-			pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);			
-			
-			pattrib->encrypt = _WEP40_;
+		pframe += len;
+		pattrib->pktlen += len;
 
-			pattrib->icv_len = 4;
-			
-			pattrib->pktlen += pattrib->icv_len;			
-			
+#ifdef CONFIG_MCC_MODE
+		pframe = rtw_hal_mcc_append_go_p2p_ie(padapter, pframe, &pattrib->pktlen);
+#endif /* CONFIG_MCC_MODE*/
+
+#ifdef CONFIG_WFD
+		len = rtw_append_probe_resp_wfd_ie(padapter, pframe);
+		pframe += len;
+		pattrib->pktlen += len;
+#endif
+	}
+#endif /* CONFIG_P2P */
+
+
+#ifdef CONFIG_AUTO_AP_MODE
+	{
+		struct sta_info	*psta;
+		struct sta_priv *pstapriv = &padapter->stapriv;
+
+		RTW_INFO("(%s)\n", __FUNCTION__);
+
+		/* check rc station */
+		psta = rtw_get_stainfo(pstapriv, da);
+		if (psta && psta->isrc && psta->pid > 0) {
+			u8 RC_OUI[4] = {0x00, 0xE0, 0x4C, 0x0A};
+			u8 RC_INFO[14] = {0};
+			/* EID[1] + EID_LEN[1] + RC_OUI[4] + MAC[6] + PairingID[2] + ChannelNum[2] */
+			u16 cu_ch = (u16)cur_network->Configuration.DSConfig;
+
+			RTW_INFO("%s, reply rc(pid=0x%x) device "MAC_FMT" in ch=%d\n", __FUNCTION__,
+				 psta->pid, MAC_ARG(psta->cmn.mac_addr), cu_ch);
+
+			/* append vendor specific ie */
+			_rtw_memcpy(RC_INFO, RC_OUI, sizeof(RC_OUI));
+			_rtw_memcpy(&RC_INFO[4], mac, ETH_ALEN);
+			_rtw_memcpy(&RC_INFO[10], (u8 *)&psta->pid, 2);
+			_rtw_memcpy(&RC_INFO[12], (u8 *)&cu_ch, 2);
+
+			pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, sizeof(RC_INFO), RC_INFO, &pattrib->pktlen);
 		}
-		
 	}
+#endif /* CONFIG_AUTO_AP_MODE */
+
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
-	rtw_wep_encrypt(padapter, (u8 *)pmgntframe);
-	DBG_871X("%s\n", __FUNCTION__);
+
 	dump_mgntframe(padapter, pmgntframe);
 
 	return;
-}
 
+}
 
-void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *pstat, int pkt_type)
+int _issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps, int wait_ack)
 {
-#ifdef CONFIG_AP_MODE
-	struct xmit_frame	*pmgntframe;
+	int ret = _FAIL;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	unsigned char			*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct pkt_attrib *pattrib;
-	unsigned char	*pbuf, *pframe;
-	unsigned short val, ie_status;		
-	unsigned short *fctrl;
-	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+	unsigned short		*fctrl;
+	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;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);	
-	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
-	u8 *ie = pnetwork->IEs; 
-#ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-#ifdef CONFIG_WFD
-	u32					wfdielen = 0;
-#endif
-
-#endif //CONFIG_P2P
-
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		return;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	int	bssrate_len = 0;
+	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 
-	DBG_871X("%s\n", __FUNCTION__);
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		goto exit;
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		return;
-	}
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -8480,247 +8817,162 @@ void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *p
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
+	mac = adapter_mac_addr(padapter);
+
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	_rtw_memcpy((void *)GetAddr1Ptr(pwlanhdr), pstat->hwaddr, ETH_ALEN);
-	_rtw_memcpy((void *)GetAddr2Ptr(pwlanhdr), adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy((void *)GetAddr3Ptr(pwlanhdr), get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	if (da) {
+		/*	unicast probe request frame */
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
+	} else {
+		/*	broadcast probe request frame */
+		_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, bc_addr, ETH_ALEN);
+	}
 
+	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	if ((pkt_type == WIFI_ASSOCRSP) || (pkt_type == WIFI_REASSOCRSP))
-		SetFrameSubType(pwlanhdr, pkt_type);		
-	else
-		return;
+	set_frame_sub_type(pframe, WIFI_PROBEREQ);
 
-	pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen += pattrib->hdrlen;
-	pframe += pattrib->hdrlen;
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//capability
-	val = *(unsigned short *)rtw_get_capability_from_ie(ie);
+	if (pssid && !MLME_IS_MESH(padapter))
+		pframe = rtw_set_ie(pframe, _SSID_IE_, pssid->SsidLength, pssid->Ssid, &(pattrib->pktlen));
+	else
+		pframe = rtw_set_ie(pframe, _SSID_IE_, 0, NULL, &(pattrib->pktlen));
 
-	pframe = rtw_set_fixed_ie(pframe, _CAPABILITY_ , (unsigned char *)&val, &(pattrib->pktlen));
+	get_rate_set(padapter, bssrate, &bssrate_len);
 
-	ie_status = cpu_to_le16(status);
-	pframe = rtw_set_fixed_ie(pframe , _STATUS_CODE_ , (unsigned char *)&ie_status, &(pattrib->pktlen));
-	
-	val = cpu_to_le16(pstat->aid | BIT(14) | BIT(15));
-	pframe = rtw_set_fixed_ie(pframe, _ASOC_ID_ , (unsigned char *)&val, &(pattrib->pktlen));
+	if (bssrate_len > 8) {
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
+		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
+	} else
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
 
-	if (pstat->bssratelen <= 8)
-	{
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, pstat->bssratelen, pstat->bssrateset, &(pattrib->pktlen));
-	}	
-	else 
-	{
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pstat->bssrateset, &(pattrib->pktlen));
-		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (pstat->bssratelen-8), pstat->bssrateset+8, &(pattrib->pktlen));
-	}
+	if (ch)
+		pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, &ch, &pattrib->pktlen);
 
-#ifdef CONFIG_IEEE80211W	
-	if (status == _STATS_REFUSED_TEMPORARILY_) {
-		u8 timeout_itvl[5];
-		u32 timeout_interval = 3000;
-		/* Association Comeback time */
-		timeout_itvl[0] = 0x03;
-		timeout_interval = cpu_to_le32(timeout_interval);
-		_rtw_memcpy(timeout_itvl+1, &timeout_interval, 4);
-		pframe = rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, 5, timeout_itvl, &(pattrib->pktlen));
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (pssid)
+			pframe = rtw_set_ie_mesh_id(pframe, &pattrib->pktlen, pssid->Ssid, pssid->SsidLength);
+		else
+			pframe = rtw_set_ie_mesh_id(pframe, &pattrib->pktlen, NULL, 0);
 	}
-#endif /* CONFIG_IEEE80211W */
-
-#ifdef CONFIG_80211N_HT
-	if ((pstat->flags & WLAN_STA_HT) && (pmlmepriv->htpriv.ht_option))
-	{
-		uint ie_len=0;
-		
-		//FILL HT CAP INFO IE
-		//p = hostapd_eid_ht_capabilities_info(hapd, p);
-		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-		if(pbuf && ie_len>0)
-		{
-			_rtw_memcpy(pframe, pbuf, ie_len+2);
-			pframe += (ie_len+2);
-			pattrib->pktlen +=(ie_len+2);
-		}
+#endif
 
-		//FILL HT ADD INFO IE
-		//p = hostapd_eid_ht_operation(hapd, p);
-		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-		if(pbuf && ie_len>0)
-		{
-			_rtw_memcpy(pframe, pbuf, ie_len+2);
-			pframe += (ie_len+2);
-			pattrib->pktlen +=(ie_len+2);
+	if (append_wps) {
+		/* add wps_ie for wps2.0 */
+		if (pmlmepriv->wps_probe_req_ie_len > 0 && pmlmepriv->wps_probe_req_ie) {
+			_rtw_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;
+			/* pmlmepriv->wps_probe_req_ie_len = 0 ; */ /* reset to zero */
 		}
-		
-	}	
+	}
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_PROBEREQ_VENDOR_IE_BIT);
 #endif
 
-	/*adding EXT_CAPAB_IE */
-	if (pmlmepriv->ext_capab_ie_len > 0) {
-		uint ie_len = 0;
-		
-		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_CAP_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-		if (pbuf && ie_len > 0) {
-			_rtw_memcpy(pframe, pbuf, ie_len+2);
-			pframe += (ie_len+2);
-			pattrib->pktlen += (ie_len+2);
-		}
-	}	
-	
-#ifdef CONFIG_80211AC_VHT
-	if ((pstat->flags & WLAN_STA_VHT) && (pmlmepriv->vhtpriv.vht_option)
-		&& (pstat->wpa_pairwise_cipher != WPA_CIPHER_TKIP)
-		&& (pstat->wpa2_pairwise_cipher != WPA_CIPHER_TKIP))
-	{
-		u32 ie_len=0;
+	pattrib->last_txcmdsz = pattrib->pktlen;
 
-		//FILL VHT CAP IE
-		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-		if(pbuf && ie_len>0)
-		{
-			_rtw_memcpy(pframe, pbuf, ie_len+2);
-			pframe += (ie_len+2);
-			pattrib->pktlen +=(ie_len+2);
-		}
 
-		//FILL VHT OPERATION IE
-		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTOperation, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
-		if(pbuf && ie_len>0)
-		{
-			_rtw_memcpy(pframe, pbuf, ie_len+2);
-			pframe += (ie_len+2);
-			pattrib->pktlen +=(ie_len+2);
-		}
+	if (wait_ack)
+		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
+	else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
 	}
-#endif //CONFIG_80211AC_VHT
 
-	//FILL WMM IE
-	if ((pstat->flags & WLAN_STA_WME) && (pmlmepriv->qospriv.qos_option))
-	{
-		uint ie_len=0;
-		unsigned char WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};	
-		
-		for (pbuf = ie + _BEACON_IE_OFFSET_; ;pbuf+= (ie_len + 2))
-		{			
-			pbuf = rtw_get_ie(pbuf, _VENDOR_SPECIFIC_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));	
-			if(pbuf && _rtw_memcmp(pbuf+2, WMM_PARA_IE, 6)) 
-			{				
-				_rtw_memcpy(pframe, pbuf, ie_len+2);
-				pframe += (ie_len+2);
-				pattrib->pktlen +=(ie_len+2);
-				
-				break;				
-			}
-			
-			if ((pbuf == NULL) || (ie_len == 0))
-			{
-				break;
-			}			
-		}
-		
-	}
+exit:
+	return ret;
+}
 
+inline void issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da)
+{
+	_issue_probereq(padapter, pssid, da, 0, 1, _FALSE);
+}
 
-	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK)
-	{
-		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, 6 , REALTEK_96B_IE, &(pattrib->pktlen));
-	}
+/*
+ * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
+ * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
+ * try_cnt means the maximal TX count to try
+ */
+int issue_probereq_ex(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps,
+		      int try_cnt, int wait_ms)
+{
+	int ret = _FAIL;
+	int i = 0;
+	systime start = rtw_get_current_time();
 
-	//add WPS IE ie for wps 2.0
-	if(pmlmepriv->wps_assoc_resp_ie && pmlmepriv->wps_assoc_resp_ie_len>0)
-	{
-		_rtw_memcpy(pframe, pmlmepriv->wps_assoc_resp_ie, pmlmepriv->wps_assoc_resp_ie_len);
-		
-		pframe += pmlmepriv->wps_assoc_resp_ie_len;
-		pattrib->pktlen += pmlmepriv->wps_assoc_resp_ie_len;
-	}
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		goto exit;
 
-#ifdef CONFIG_P2P
-	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && (pstat->is_p2p_device == _TRUE)) {
-		u32 len;
+	do {
+		ret = _issue_probereq(padapter, pssid, da, ch, append_wps, wait_ms > 0 ? _TRUE : _FALSE);
 
-		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
-			len = 0;
-			if (pmlmepriv->p2p_assoc_resp_ie && pmlmepriv->p2p_assoc_resp_ie_len > 0) {
-				len = pmlmepriv->p2p_assoc_resp_ie_len;
-				_rtw_memcpy(pframe, pmlmepriv->p2p_assoc_resp_ie, len);
-			}
-		} else {
-			len = build_assoc_resp_p2p_ie(pwdinfo, pframe, pstat->p2p_status_code);
-		}
-		pframe += len;
-		pattrib->pktlen += len;
-	}
+		i++;
 
-	#ifdef CONFIG_WFD
-	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
-		wfdielen = rtw_append_assoc_resp_wfd_ie(padapter, pframe);
-		pframe += wfdielen;
-		pattrib->pktlen += wfdielen;
-	}
-	#endif
+		if (RTW_CANNOT_RUN(padapter))
+			break;
 
-#endif /* CONFIG_P2P */
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
+			rtw_msleep_os(wait_ms);
 
-	pattrib->last_txcmdsz = pattrib->pktlen;
-	
-	dump_mgntframe(padapter, pmgntframe);
-	
+	} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
+
+	if (ret != _FAIL) {
+		ret = _SUCCESS;
+#ifndef DBG_XMIT_ACK
+		goto exit;
 #endif
+	}
+
+	if (try_cnt && wait_ms) {
+		if (da)
+			RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+		else
+			RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+	}
+exit:
+	return ret;
 }
 
-void issue_assocreq(_adapter *padapter)
+/* if psta == NULL, indiate we are station(client) now... */
+void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status)
 {
-	int ret = _FAIL;
-	struct xmit_frame				*pmgntframe;
-	struct pkt_attrib				*pattrib;
-	unsigned char					*pframe, *p;
-	struct rtw_ieee80211_hdr			*pwlanhdr;
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	unsigned char					*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short				*fctrl;
+	unsigned int					val32;
 	unsigned short				val16;
-	unsigned int					i, j, ie_len, index=0;
-	unsigned char					rf_type, bssrate[NumRates], sta_bssrate[NumRates];
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	struct registry_priv	*pregpriv = &padapter->registrypriv;
-	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	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);
-	int	bssrate_len = 0, sta_bssrate_len = 0;
-	u8	vs_ie_length = 0;
-#ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-	u8					p2pie[ 255 ] = { 0x00 };
-	u16					p2pielen = 0;	
-#ifdef CONFIG_WFD
-	u32					wfdielen = 0;
-#endif
-#endif //CONFIG_P2P
 
-#ifdef CONFIG_DFS
-	u16	cap;
-
-	/* Dot H */
-	u8 pow_cap_ele[2] = { 0x00 };
-	u8 sup_ch[ 30 * 2 ] = {0x00 }, sup_ch_idx = 0, idx_5g = 2;	//For supported channel
-#endif //CONFIG_DFS
-
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		goto exit;
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		return;
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return;
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
-
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
@@ -8728,435 +8980,395 @@ void issue_assocreq(_adapter *padapter)
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
-	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ASSOCREQ);
+	set_frame_sub_type(pframe, WIFI_AUTH);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//caps
 
-#ifdef CONFIG_DFS
-	_rtw_memcpy(&cap, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
-	cap |= cap_SpecMgmt;
-	_rtw_memcpy(pframe, &cap, 2);
-#else
-	_rtw_memcpy(pframe, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
-#endif //CONFIG_DFS
+	if (psta) { /* for AP mode */
+#ifdef CONFIG_NATIVEAP_MLME
 
-	pframe += 2;
-	pattrib->pktlen += 2;
+		_rtw_memcpy(pwlanhdr->addr1, psta->cmn.mac_addr, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
 
-	//listen interval
-	//todo: listen interval for power saving
-	val16 = cpu_to_le16(3);
-	_rtw_memcpy(pframe ,(unsigned char *)&val16, 2);
-	pframe += 2;
-	pattrib->pktlen += 2;
 
-	//SSID
-	pframe = rtw_set_ie(pframe, _SSID_IE_,  pmlmeinfo->network.Ssid.SsidLength, pmlmeinfo->network.Ssid.Ssid, &(pattrib->pktlen));
+		/* setting auth algo number */
+		val16 = (u16)psta->authalg;
 
-#ifdef CONFIG_DFS
-	/* Dot H */
-	if(pmlmeext->cur_channel > 14)
-	{
-		pow_cap_ele[0] = 13;	// Minimum transmit power capability
-		pow_cap_ele[1] = 21;	// Maximum transmit power capability
-		pframe = rtw_set_ie(pframe, EID_PowerCap, 2, pow_cap_ele, &(pattrib->pktlen));
+		if (status != _STATS_SUCCESSFUL_)
+			val16 = 0;
 
-		//supported channels
-		do{
-			if( pmlmeext->channel_set[sup_ch_idx].ChannelNum <= 14 )
-			{
-				sup_ch[0] = 1;	//First channel number
-				sup_ch[1] = pmlmeext->channel_set[sup_ch_idx].ChannelNum;	//Number of channel
-			}
-			else
-			{
-				sup_ch[idx_5g++] = pmlmeext->channel_set[sup_ch_idx].ChannelNum;
-				sup_ch[idx_5g++] = 1;
-			}
-			sup_ch_idx++;
+		if (val16)	{
+			val16 = cpu_to_le16(val16);
+			use_shared_key = 1;
 		}
-		while( pmlmeext->channel_set[sup_ch_idx].ChannelNum != 0 );
-		pframe = rtw_set_ie(pframe, EID_SupportedChannels, idx_5g, sup_ch, &(pattrib->pktlen));
-	}
-#endif //CONFIG_DFS
-
-	//supported rate & extended supported rate
 
-#if 1	// Check if the AP's supported rates are also supported by STA.
-	get_rate_set(padapter, sta_bssrate, &sta_bssrate_len);
-	//DBG_871X("sta_bssrate_len=%d\n", sta_bssrate_len);
-	
-	if(pmlmeext->cur_channel == 14)// for JAPAN, channel 14 can only uses B Mode(CCK) 
-	{
-		sta_bssrate_len = 4;
-	}
+		pframe = rtw_set_fixed_ie(pframe, _AUTH_ALGM_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
 
-	
-	//for (i = 0; i < sta_bssrate_len; i++) {
-	//	DBG_871X("sta_bssrate[%d]=%02X\n", i, sta_bssrate[i]);
-	//}
+		/* setting auth seq number */
+		val16 = (u16)psta->auth_seq;
+		val16 = cpu_to_le16(val16);
+		pframe = rtw_set_fixed_ie(pframe, _AUTH_SEQ_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
 
-	for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
-		if (pmlmeinfo->network.SupportedRates[i] == 0) break;
-		DBG_871X("network.SupportedRates[%d]=%02X\n", i, pmlmeinfo->network.SupportedRates[i]);
-	}
-	
+		/* setting status code... */
+		val16 = status;
+		val16 = cpu_to_le16(val16);
+		pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
 
-	for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
-		if (pmlmeinfo->network.SupportedRates[i] == 0) break;
+		/* added challenging text... */
+		if ((psta->auth_seq == 2) && (psta->state & WIFI_FW_AUTH_STATE) && (use_shared_key == 1))
+			pframe = rtw_set_ie(pframe, _CHLGETXT_IE_, 128, psta->chg_txt, &(pattrib->pktlen));
+#endif
+	} else {
+		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
 
-		
-		// 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_871X("match i = %d, j=%d\n", i, j);
-				break;
-			} else {
-				//DBG_871X("not match: %02X != %02X\n", (pmlmeinfo->network.SupportedRates[i]|IEEE80211_BASIC_RATE_MASK), (sta_bssrate[j]|IEEE80211_BASIC_RATE_MASK));
+#ifdef CONFIG_RTW_80211R
+		if (rtw_ft_roam(padapter)) {
+			/* 2: 802.11R FTAA */
+			val16 = cpu_to_le16(2);
+		} else
+#endif
+		{
+			/* setting auth algo number */
+			val16 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared) ? 1 : 0;	/* 0:OPEN System, 1:Shared key */
+			if (val16) {
+				val16 = cpu_to_le16(val16);
+				use_shared_key = 1;
 			}
 		}
-		
-		if (j == sta_bssrate_len) {
-			// the rate is not supported by STA
-			DBG_871X("%s(): the rate[%d]=%02X is not supported by STA!\n",__FUNCTION__, i, pmlmeinfo->network.SupportedRates[i]);
-		} else {
-			// the rate is supported by STA
-			bssrate[index++] = pmlmeinfo->network.SupportedRates[i];
+
+		/* RTW_INFO("%s auth_algo= %s auth_seq=%d\n",__FUNCTION__,(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)) {
+			/* RTW_INFO("==> iv(%d),key_index(%d)\n",pmlmeinfo->iv,pmlmeinfo->key_index); */
+			val32 = ((pmlmeinfo->iv++) | (pmlmeinfo->key_index << 30));
+			val32 = cpu_to_le32(val32);
+			pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *)&val32, &(pattrib->pktlen));
+
+			pattrib->iv_len = 4;
 		}
-	}
-	
-	bssrate_len = index;
-	DBG_871X("bssrate_len = %d\n", bssrate_len);
 
-#else	// Check if the AP's supported rates are also supported by STA.
-#if 0
-	get_rate_set(padapter, bssrate, &bssrate_len);
-#else
-	for (bssrate_len = 0; bssrate_len < NumRates; bssrate_len++) {
-		if (pmlmeinfo->network.SupportedRates[bssrate_len] == 0) break;
+		pframe = rtw_set_fixed_ie(pframe, _AUTH_ALGM_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
 
-		if (pmlmeinfo->network.SupportedRates[bssrate_len] == 0x2C) // Avoid the proprietary data rate (22Mbps) of Handlink WSG-4000 AP
-			break;
+		/* setting auth seq number */
+		val16 = pmlmeinfo->auth_seq;
+		val16 = cpu_to_le16(val16);
+		pframe = rtw_set_fixed_ie(pframe, _AUTH_SEQ_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
 
-		bssrate[bssrate_len] = pmlmeinfo->network.SupportedRates[bssrate_len];
-	}
+
+		/* setting status code... */
+		val16 = status;
+		val16 = cpu_to_le16(val16);
+		pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
+
+#ifdef CONFIG_RTW_80211R
+		rtw_ft_build_auth_req_ies(padapter, pattrib, &pframe);
 #endif
-#endif	// Check if the AP's supported rates are also supported by STA.
 
-	if ((bssrate_len == 0) && (pmlmeinfo->network.SupportedRates[0] != 0)) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit; //don't connect to AP if no joint supported rate
-	}
+		/* 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_ie(pframe, _CHLGETXT_IE_, 128, pmlmeinfo->chg_txt, &(pattrib->pktlen));
 
+			SetPrivacy(fctrl);
 
-	if (bssrate_len > 8)
-	{
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
-		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
-	}
-	else if (bssrate_len > 0)
-	{
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
-	} else {
-		DBG_871X("%s: Connect to AP without 11b and 11g data rate!\n",__FUNCTION__);
-	}
+			pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//vendor specific IE, such as WPA, WMM, WPS
-	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;)
-	{
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(pmlmeinfo->network.IEs + i);
+			pattrib->encrypt = _WEP40_;
 
-		switch (pIE->ElementID)
-		{
-			case _VENDOR_SPECIFIC_IE_:
-				if ((_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4)) ||
-						(_rtw_memcmp(pIE->data, WMM_OUI, 4)) ||
-						(_rtw_memcmp(pIE->data, WPS_OUI, 4)))
-				{	
-					vs_ie_length = pIE->Length;
-					if((!padapter->registrypriv.wifi_spec) && (_rtw_memcmp(pIE->data, WPS_OUI, 4)))
-					{
-						//Commented by Kurt 20110629
-						//In some older APs, WPS handshake
-						//would be fail if we append vender extensions informations to AP
-
-						vs_ie_length = 14;
-					}
-					
-					pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, vs_ie_length, pIE->data, &(pattrib->pktlen));
-				}
-				break;
+			pattrib->icv_len = 4;
 
-			case EID_WPA2:
-				pframe = rtw_set_ie(pframe, EID_WPA2, pIE->Length, pIE->data, &(pattrib->pktlen));
-				break;
-#ifdef CONFIG_80211N_HT
-			case EID_HTCapability:
-				if(padapter->mlmepriv.htpriv.ht_option==_TRUE) {
-					if (!(is_ap_in_tkip(padapter)))
-					{
-						_rtw_memcpy(&(pmlmeinfo->HT_caps), pIE->data, sizeof(struct HT_caps_element));
+			pattrib->pktlen += pattrib->icv_len;
 
-						pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info = cpu_to_le16(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info);
+		}
 
-						pframe = rtw_set_ie(pframe, EID_HTCapability, pIE->Length , (u8 *)(&(pmlmeinfo->HT_caps)), &(pattrib->pktlen));
-					}
-				}
-				break;
-
-			case EID_EXTCapability:
-				if(padapter->mlmepriv.htpriv.ht_option==_TRUE) {
-					pframe = rtw_set_ie(pframe, EID_EXTCapability, pIE->Length, pIE->data, &(pattrib->pktlen));
-				}
-				break;
-#endif //CONFIG_80211N_HT
-#ifdef CONFIG_80211AC_VHT
-			case EID_VHTCapability:
-				if (padapter->mlmepriv.vhtpriv.vht_option ==_TRUE) {
-					pframe = rtw_set_ie(pframe, EID_VHTCapability, pIE->Length, pIE->data, &(pattrib->pktlen));
-				}
-				break;
+	}
 
-			case EID_OpModeNotification:
-				if (padapter->mlmepriv.vhtpriv.vht_option ==_TRUE) {
-					pframe = rtw_set_ie(pframe, EID_OpModeNotification, pIE->Length, pIE->data, &(pattrib->pktlen));
-				}
-				break;
-#endif // CONFIG_80211AC_VHT
-			default:
-				break;
-		}
+	pattrib->last_txcmdsz = pattrib->pktlen;
 
-		i += (pIE->Length + 2);
-	}
+	rtw_wep_encrypt(padapter, (u8 *)pmgntframe);
+	RTW_INFO("%s\n", __FUNCTION__);
+	dump_mgntframe(padapter, pmgntframe);
 
-	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK)
-	{
-		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, 6 , REALTEK_96B_IE, &(pattrib->pktlen));
-	}
+	return;
+}
 
 
-#ifdef CONFIG_WAPI_SUPPORT
-	rtw_build_assoc_req_wapi_ie(padapter, pframe, pattrib);
+void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *pstat, int pkt_type)
+{
+#ifdef CONFIG_AP_MODE
+	struct xmit_frame	*pmgntframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct pkt_attrib *pattrib;
+	unsigned char	*pbuf, *pframe;
+	unsigned short val, ie_status;
+	unsigned short *fctrl;
+	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);
+	WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
+	u8 *ie = pnetwork->IEs;
+#ifdef CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+#ifdef CONFIG_WFD
+	u32					wfdielen = 0;
 #endif
 
+#endif /* CONFIG_P2P */
 
-#ifdef CONFIG_P2P
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		return;
 
-#ifdef CONFIG_IOCTL_CFG80211
-	if(adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211 )
-	{
-		if(pmlmepriv->p2p_assoc_req_ie && pmlmepriv->p2p_assoc_req_ie_len>0)
-		{
-			_rtw_memcpy(pframe, pmlmepriv->p2p_assoc_req_ie, pmlmepriv->p2p_assoc_req_ie_len);
-			pframe += pmlmepriv->p2p_assoc_req_ie_len;
-			pattrib->pktlen += pmlmepriv->p2p_assoc_req_ie_len;
-		}
-	}
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return;
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy((void *)GetAddr1Ptr(pwlanhdr), pstat->cmn.mac_addr, ETH_ALEN);
+	_rtw_memcpy((void *)get_addr2_ptr(pwlanhdr), adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy((void *)GetAddr3Ptr(pwlanhdr), get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	if ((pkt_type == WIFI_ASSOCRSP) || (pkt_type == WIFI_REASSOCRSP))
+		set_frame_sub_type(pwlanhdr, pkt_type);
 	else
-#endif //CONFIG_IOCTL_CFG80211
-	{
-		if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
-		{
-			//	Should add the P2P IE in the association request frame.	
-			//	P2P OUI
-			
-			p2pielen = 0;
-			p2pie[ p2pielen++ ] = 0x50;
-			p2pie[ p2pielen++ ] = 0x6F;
-			p2pie[ p2pielen++ ] = 0x9A;
-			p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-			//	Commented by Albert 20101109
-			//	According to the P2P Specification, the association request frame should contain 3 P2P attributes
-			//	1. P2P Capability
-			//	2. Extended Listen Timing
-			//	3. Device Info
-			//	Commented by Albert 20110516
-			//	4. P2P Interface
-
-			//	P2P Capability
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
-
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
-			p2pielen += 2;
+		return;
 
-			//	Value:
-			//	Device Capability Bitmap, 1 byte
-			p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
+	pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen += pattrib->hdrlen;
+	pframe += pattrib->hdrlen;
 
-			//	Group Capability Bitmap, 1 byte
-			if ( pwdinfo->persistent_supported )
-				p2pie[ p2pielen++ ] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
-			else
-				p2pie[ p2pielen++ ] = DMP_P2P_GRPCAP_SUPPORT;
+	/* capability */
+	val = *(unsigned short *)rtw_get_capability_from_ie(ie);
 
-			//	Extended Listen Timing
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_EX_LISTEN_TIMING;
+	pframe = rtw_set_fixed_ie(pframe, _CAPABILITY_ , (unsigned char *)&val, &(pattrib->pktlen));
 
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0004 );
-			p2pielen += 2;
+	ie_status = cpu_to_le16(status);
+	pframe = rtw_set_fixed_ie(pframe , _STATUS_CODE_ , (unsigned char *)&ie_status, &(pattrib->pktlen));
 
-			//	Value:
-			//	Availability Period
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
-			p2pielen += 2;
+	val = cpu_to_le16(pstat->cmn.aid | BIT(14) | BIT(15));
+	pframe = rtw_set_fixed_ie(pframe, _ASOC_ID_ , (unsigned char *)&val, &(pattrib->pktlen));
 
-			//	Availability Interval
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
-			p2pielen += 2;
+	if (pstat->bssratelen <= 8)
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, pstat->bssratelen, pstat->bssrateset, &(pattrib->pktlen));
+	else {
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pstat->bssrateset, &(pattrib->pktlen));
+		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (pstat->bssratelen - 8), pstat->bssrateset + 8, &(pattrib->pktlen));
+	}
 
-			//	Device Info
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
+#ifdef CONFIG_IEEE80211W
+	if (status == _STATS_REFUSED_TEMPORARILY_) {
+		u8 timeout_itvl[5];
+		u32 timeout_interval = 3000;
+		/* Association Comeback time */
+		timeout_itvl[0] = 0x03;
+		timeout_interval = cpu_to_le32(timeout_interval);
+		_rtw_memcpy(timeout_itvl + 1, &timeout_interval, 4);
+		pframe = rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, 5, timeout_itvl, &(pattrib->pktlen));
+	}
+#endif /* CONFIG_IEEE80211W */
 
-			//	Length:
-			//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-			//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
-			p2pielen += 2;
+#ifdef CONFIG_80211N_HT
+	if ((pstat->flags & WLAN_STA_HT) && (pmlmepriv->htpriv.ht_option)) {
+		uint ie_len = 0;
 
-			//	Value:
-			//	P2P Device Address
-			_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
-			p2pielen += ETH_ALEN;
+		/* FILL HT CAP INFO IE */
+		/* p = hostapd_eid_ht_capabilities_info(hapd, p); */
+		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+		if (pbuf && ie_len > 0) {
+			_rtw_memcpy(pframe, pbuf, ie_len + 2);
+			pframe += (ie_len + 2);
+			pattrib->pktlen += (ie_len + 2);
+		}
 
-			//	Config Method
-			//	This field should be big endian. Noted by P2P specification.
-			if ( ( pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PEER_DISPLAY_PIN ) ||
-				( pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_SELF_DISPLAY_PIN ) )
-			{
-				*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_DISPLAY );
-			}
-			else
-			{
-				*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_PBC );
-			}
+		/* FILL HT ADD INFO IE */
+		/* p = hostapd_eid_ht_operation(hapd, p); */
+		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+		if (pbuf && ie_len > 0) {
+			_rtw_memcpy(pframe, pbuf, ie_len + 2);
+			pframe += (ie_len + 2);
+			pattrib->pktlen += (ie_len + 2);
+		}
 
-			p2pielen += 2;
+	}
+#endif
 
-			//	Primary Device Type
-			//	Category ID
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
-			p2pielen += 2;
+	/*adding EXT_CAPAB_IE */
+	if (pmlmepriv->ext_capab_ie_len > 0) {
+		uint ie_len = 0;
 
-			//	OUI
-			*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
-			p2pielen += 4;
+		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_CAP_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+		if (pbuf && ie_len > 0) {
+			_rtw_memcpy(pframe, pbuf, ie_len + 2);
+			pframe += (ie_len + 2);
+			pattrib->pktlen += (ie_len + 2);
+		}
+	}
 
-			//	Sub Category ID
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
-			p2pielen += 2;
+#ifdef CONFIG_80211AC_VHT
+	if ((pstat->flags & WLAN_STA_VHT) && (pmlmepriv->vhtpriv.vht_option)
+	    && (pstat->wpa_pairwise_cipher != WPA_CIPHER_TKIP)
+	    && (pstat->wpa2_pairwise_cipher != WPA_CIPHER_TKIP)) {
+		u32 ie_len = 0;
 
-			//	Number of Secondary Device Types
-			p2pie[ p2pielen++ ] = 0x00;	//	No Secondary Device Type List
+		/* FILL VHT CAP IE */
+		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+		if (pbuf && ie_len > 0) {
+			_rtw_memcpy(pframe, pbuf, ie_len + 2);
+			pframe += (ie_len + 2);
+			pattrib->pktlen += (ie_len + 2);
+		}
 
-			//	Device Name
-			//	Type:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
-			p2pielen += 2;
+		/* FILL VHT OPERATION IE */
+		pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTOperation, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
+		if (pbuf && ie_len > 0) {
+			_rtw_memcpy(pframe, pbuf, ie_len + 2);
+			pframe += (ie_len + 2);
+			pattrib->pktlen += (ie_len + 2);
+		}
+	}
+#endif /* CONFIG_80211AC_VHT */
 
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len );
-			p2pielen += 2;
+	/* FILL WMM IE */
+	if ((pstat->flags & WLAN_STA_WME) && (pmlmepriv->qospriv.qos_option)) {
+		uint ie_len = 0;
+		unsigned char WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
 
-			//	Value:
-			_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len );
-			p2pielen += pwdinfo->device_name_len;
-		
-			//	P2P Interface
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_INTERFACE;
-			
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x000D );
-			p2pielen += 2;
-			
-			//	Value:
-			_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN );	//	P2P Device Address
-			p2pielen += ETH_ALEN;
+		for (pbuf = ie + _BEACON_IE_OFFSET_; ; pbuf += (ie_len + 2)) {
+			pbuf = rtw_get_ie(pbuf, _VENDOR_SPECIFIC_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));
+			if (pbuf && _rtw_memcmp(pbuf + 2, WMM_PARA_IE, 6)) {
+				_rtw_memcpy(pframe, pbuf, ie_len + 2);
+				pframe += (ie_len + 2);
+				pattrib->pktlen += (ie_len + 2);
 
-			p2pie[ p2pielen++ ] = 1;	//	P2P Interface Address Count
-			
-			_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN );	//	P2P Interface Address List
-			p2pielen += ETH_ALEN;
-		
-			pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen );
+				break;
+			}
+
+			if ((pbuf == NULL) || (ie_len == 0))
+				break;
 		}
+
+	}
+
+
+	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK)
+		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, 6 , REALTEK_96B_IE, &(pattrib->pktlen));
+
+	/* add WPS IE ie for wps 2.0 */
+	if (pmlmepriv->wps_assoc_resp_ie && pmlmepriv->wps_assoc_resp_ie_len > 0) {
+		_rtw_memcpy(pframe, pmlmepriv->wps_assoc_resp_ie, pmlmepriv->wps_assoc_resp_ie_len);
+
+		pframe += pmlmepriv->wps_assoc_resp_ie_len;
+		pattrib->pktlen += pmlmepriv->wps_assoc_resp_ie_len;
 	}
 
-#endif //CONFIG_P2P
+#ifdef CONFIG_P2P
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && (pstat->is_p2p_device == _TRUE)) {
+		u32 len;
+
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
+			len = 0;
+			if (pmlmepriv->p2p_assoc_resp_ie && pmlmepriv->p2p_assoc_resp_ie_len > 0) {
+				len = pmlmepriv->p2p_assoc_resp_ie_len;
+				_rtw_memcpy(pframe, pmlmepriv->p2p_assoc_resp_ie, len);
+			}
+		} else
+			len = build_assoc_resp_p2p_ie(pwdinfo, pframe, pstat->p2p_status_code);
+		pframe += len;
+		pattrib->pktlen += len;
+	}
 
 #ifdef CONFIG_WFD
-	wfdielen = rtw_append_assoc_req_wfd_ie(padapter, pframe);
-	pframe += wfdielen;
-	pattrib->pktlen += wfdielen;
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		wfdielen = rtw_append_assoc_resp_wfd_ie(padapter, pframe);
+		pframe += wfdielen;
+		pattrib->pktlen += wfdielen;
+	}
 #endif
 
+#endif /* CONFIG_P2P */
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_ASSOCRESP_VENDOR_IE_BIT);
+#endif
 	pattrib->last_txcmdsz = pattrib->pktlen;
-	dump_mgntframe(padapter, pmgntframe);
-
-	ret = _SUCCESS;
 
-exit:
-	if (ret == _SUCCESS)
-		rtw_buf_update(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len, (u8 *)pwlanhdr, pattrib->pktlen);
-	else
-		rtw_buf_free(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len);
+	dump_mgntframe(padapter, pmgntframe);
 
-	return;
+#endif
 }
 
-//when wait_ack is ture, this function shoule be called at process context
-static int _issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int wait_ack)
+void _issue_assocreq(_adapter *padapter, u8 is_reassoc)
 {
 	int ret = _FAIL;
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	unsigned char					*pframe;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_frame				*pmgntframe;
+	struct pkt_attrib				*pattrib;
+	unsigned char					*pframe, *p;
+	struct rtw_ieee80211_hdr			*pwlanhdr;
 	unsigned short				*fctrl;
-	struct xmit_priv	*pxmitpriv;
-	struct mlme_ext_priv	*pmlmeext;
-	struct mlme_ext_info	*pmlmeinfo;
+	unsigned short				val16;
+	unsigned int					i, j, ie_len, index = 0;
+	unsigned char					rf_type, bssrate[NumRates], sta_bssrate[NumRates];
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	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;
+	u8	vs_ie_length = 0;
+#ifdef CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					p2pie[255] = { 0x00 };
+	u16					p2pielen = 0;
+#ifdef CONFIG_WFD
+	u32					wfdielen = 0;
+#endif
+#endif /* CONFIG_P2P */
 
-	//DBG_871X("%s:%d\n", __FUNCTION__, power_mode);
+#ifdef CONFIG_DFS
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	u16	cap;
 
-	if(!padapter)
-		goto exit;
+	/* Dot H */
+	u8 pow_cap_ele[2] = { 0x00 };
+	u8 sup_ch[30 * 2] = {0x00 }, sup_ch_idx = 0, idx_5g = 2;	/* For supported channel */
+#endif /* CONFIG_DFS */
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
 
-	pxmitpriv = &(padapter->xmitpriv);
-	pmlmeext = &(padapter->mlmeextpriv);
-	pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		goto exit;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
-	pattrib->retry_ctrl = _FALSE;
+
 
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
@@ -9165,327 +9377,455 @@ static int _issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int p
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
-
-	if((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
-		SetFrDs(fctrl);
-	}
-	else if((pmlmeinfo->state&0x03) == WIFI_FW_STATION_STATE)
-	{
-		SetToDs(fctrl);
-	}
-	
-	if (power_mode)
-	{
-		SetPwrMgt(fctrl);
-	}
-
-	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_DATA_NULL);
+	if (is_reassoc == _TRUE)
+		set_frame_sub_type(pframe, WIFI_REASSOCREQ);
+	else
+		set_frame_sub_type(pframe, WIFI_ASSOCREQ);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	pattrib->last_txcmdsz = pattrib->pktlen;
+	/* caps */
 
-	if(wait_ack)
-	{
-		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	}
-	else
-	{
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
-	}
+#ifdef CONFIG_DFS
+	_rtw_memcpy(&cap, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
+	cap |= cap_SpecMgmt;
+	_rtw_memcpy(pframe, &cap, 2);
+#else
+	_rtw_memcpy(pframe, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
+#endif /* CONFIG_DFS */
 
-exit:
-	return ret;
-}
+	pframe += 2;
+	pattrib->pktlen += 2;
 
-/*
- * [IMPORTANT] Don't call this function in interrupt context
- *
- * When wait_ms > 0, this function should be called at process context
- * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
- * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
- * try_cnt means the maximal TX count to try
- * da == NULL for station mode
- */
-int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)
-{
-	int ret = _FAIL;
-	int i = 0;
-	u32 start = rtw_get_current_time();
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct sta_info *psta;
+	/* listen interval */
+	/* todo: listen interval for power saving */
+	val16 = cpu_to_le16(3);
+	_rtw_memcpy(pframe , (unsigned char *)&val16, 2);
+	pframe += 2;
+	pattrib->pktlen += 2;
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		goto exit;
+	/*Construct Current AP Field for Reassoc-Req only*/
+	if (is_reassoc == _TRUE) {
+		_rtw_memcpy(pframe, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		pframe += ETH_ALEN;
+		pattrib->pktlen += ETH_ALEN;
+	}
 
-	/* da == NULL, assum it's null data for sta to ap*/
-	if (da == NULL)
-		da = get_my_bssid(&(pmlmeinfo->network));
+	/* SSID */
+	pframe = rtw_set_ie(pframe, _SSID_IE_,  pmlmeinfo->network.Ssid.SsidLength, pmlmeinfo->network.Ssid.Ssid, &(pattrib->pktlen));
 
-	psta = rtw_get_stainfo(&padapter->stapriv, da);
-	if (psta) {
-		if (power_mode)
-			rtw_hal_macid_sleep(padapter, psta->mac_id);
-		else
-			rtw_hal_macid_wakeup(padapter, psta->mac_id);
-	} else {
-		DBG_871X(FUNC_ADPT_FMT ": Can't find sta info for " MAC_FMT ", skip macid %s!!\n",
-			FUNC_ADPT_ARG(padapter), MAC_ARG(da), power_mode?"sleep":"wakeup");
-		rtw_warn_on(1);
-	}
+#ifdef CONFIG_DFS
+	/* Dot H */
+	if (pmlmeext->cur_channel > 14) {
+		pow_cap_ele[0] = 13;	/* Minimum transmit power capability */
+		pow_cap_ele[1] = 21;	/* Maximum transmit power capability */
+		pframe = rtw_set_ie(pframe, EID_PowerCap, 2, pow_cap_ele, &(pattrib->pktlen));
 
-	do {
-		ret = _issue_nulldata(padapter, da, power_mode, wait_ms>0?_TRUE:_FALSE);
+		/* supported channels */
+		while (sup_ch_idx < rfctl->max_chan_nums && rfctl->channel_set[sup_ch_idx].ChannelNum != 0) {
+			if (rfctl->channel_set[sup_ch_idx].ChannelNum <= 14) {
+				/* TODO: fix 2.4G supported channel when channel doesn't start from 1 and continuous */
+				sup_ch[0] = 1;	/* First channel number */
+				sup_ch[1] = rfctl->channel_set[sup_ch_idx].ChannelNum;	/* Number of channel */
+			} else {
+				sup_ch[idx_5g++] = rfctl->channel_set[sup_ch_idx].ChannelNum;
+				sup_ch[idx_5g++] = 1;
+			}
+			sup_ch_idx++;
+		}
+		pframe = rtw_set_ie(pframe, EID_SupportedChannels, idx_5g, sup_ch, &(pattrib->pktlen));
+	}
+#endif /* CONFIG_DFS */
 
-		i++;
+	/* supported rate & extended supported rate */
 
-		if (RTW_CANNOT_RUN(padapter))
-			break;
+#if 1	/* Check if the AP's supported rates are also supported by STA. */
+	get_rate_set(padapter, sta_bssrate, &sta_bssrate_len);
+	/* RTW_INFO("sta_bssrate_len=%d\n", sta_bssrate_len); */
 
-		if(i < try_cnt && wait_ms > 0 && ret==_FAIL)
-			rtw_msleep_os(wait_ms);
+	if (pmlmeext->cur_channel == 14) /* for JAPAN, channel 14 can only uses B Mode(CCK) */
+		sta_bssrate_len = 4;
 
-	}while((i<try_cnt) && ((ret==_FAIL)||(wait_ms==0)));
 
-	if (ret != _FAIL) {
-		ret = _SUCCESS;
-		#ifndef DBG_XMIT_ACK
-		goto exit;
-		#endif
-	}
+	/* for (i = 0; i < sta_bssrate_len; i++) { */
+	/*	RTW_INFO("sta_bssrate[%d]=%02X\n", i, sta_bssrate[i]); */
+	/* } */
 
-	if (try_cnt && wait_ms) {
-		if (da)
-			DBG_871X(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
-		else
-			DBG_871X(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+	for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
+		if (pmlmeinfo->network.SupportedRates[i] == 0)
+			break;
+		RTW_INFO("network.SupportedRates[%d]=%02X\n", i, pmlmeinfo->network.SupportedRates[i]);
 	}
-exit:
-	return ret;
-}
 
-/*
- * [IMPORTANT] This function run in interrupt context
- *
- * The null data packet would be sent without power bit,
- * and not guarantee success.
- */
-s32 issue_nulldata_in_interrupt(PADAPTER padapter, u8 *da, unsigned int power_mode)
-{
-	int ret;
-	struct mlme_ext_priv *pmlmeext;
-	struct mlme_ext_info *pmlmeinfo;
 
+	for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
+		if (pmlmeinfo->network.SupportedRates[i] == 0)
+			break;
 
-	pmlmeext = &padapter->mlmeextpriv;
-	pmlmeinfo = &pmlmeext->mlmext_info;
 
-	/* da == NULL, assum it's null data for sta to ap*/
-	if (da == NULL)
-		da = get_my_bssid(&(pmlmeinfo->network));
+		/* 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)) {
+				/* RTW_INFO("match i = %d, j=%d\n", i, j); */
+				break;
+			} else {
+				/* RTW_INFO("not match: %02X != %02X\n", (pmlmeinfo->network.SupportedRates[i]|IEEE80211_BASIC_RATE_MASK), (sta_bssrate[j]|IEEE80211_BASIC_RATE_MASK)); */
+			}
+		}
 
-	ret = _issue_nulldata(padapter, da, power_mode, _FALSE);
+		if (j == sta_bssrate_len) {
+			/* the rate is not supported by STA */
+			RTW_INFO("%s(): the rate[%d]=%02X is not supported by STA!\n", __FUNCTION__, i, pmlmeinfo->network.SupportedRates[i]);
+		} else {
+			/* the rate is supported by STA */
+			bssrate[index++] = pmlmeinfo->network.SupportedRates[i];
+		}
+	}
 
-	return ret;
-}
+	bssrate_len = index;
+	RTW_INFO("bssrate_len = %d\n", bssrate_len);
 
-//when wait_ack is ture, this function shoule be called at process context
-static int _issue_qos_nulldata(_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 rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short				*fctrl, *qc;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+#else	/* Check if the AP's supported rates are also supported by STA. */
+#if 0
+	get_rate_set(padapter, bssrate, &bssrate_len);
+#else
+	for (bssrate_len = 0; bssrate_len < NumRates; bssrate_len++) {
+		if (pmlmeinfo->network.SupportedRates[bssrate_len] == 0)
+			break;
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		goto exit;
+		if (pmlmeinfo->network.SupportedRates[bssrate_len] == 0x2C) /* Avoid the proprietary data rate (22Mbps) of Handlink WSG-4000 AP */
+			break;
 
-	DBG_871X("%s\n", __FUNCTION__);
+		bssrate[bssrate_len] = pmlmeinfo->network.SupportedRates[bssrate_len];
+	}
+#endif
+#endif /* Check if the AP's supported rates are also supported by STA. */
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		goto exit;
+	if ((bssrate_len == 0) && (pmlmeinfo->network.SupportedRates[0] != 0)) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit; /* don't connect to AP if no joint supported rate */
 	}
 
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
 
-	pattrib->hdrlen +=2;
-	pattrib->qos_en = _TRUE;
-	pattrib->eosp = 1;
-	pattrib->ack_policy = 0;
-	pattrib->mdata = 0;
+	if (bssrate_len > 8) {
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
+		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
+	} else if (bssrate_len > 0)
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
+	else
+		RTW_INFO("%s: Connect to AP without 11b and 11g data rate!\n", __FUNCTION__);
+
+#ifdef CONFIG_RTW_80211K
+	if (pmlmeinfo->network.PhyInfo.rm_en_cap[0] /* RM Enabled Capabilities */
+		| pmlmeinfo->network.PhyInfo.rm_en_cap[1]
+		| pmlmeinfo->network.PhyInfo.rm_en_cap[2]
+		| pmlmeinfo->network.PhyInfo.rm_en_cap[3]
+		| pmlmeinfo->network.PhyInfo.rm_en_cap[4])
+		pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_, 5,
+				(u8 *)padapter->rmpriv.rm_en_cap_def, &(pattrib->pktlen));
+#endif /* CONFIG_RTW_80211K */
+
+	/* vendor specific IE, such as WPA, WMM, WPS */
+	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(pmlmeinfo->network.IEs + i);
 
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+		switch (pIE->ElementID) {
+		case _VENDOR_SPECIFIC_IE_:
+			if ((_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4)) ||
+			    (_rtw_memcmp(pIE->data, WMM_OUI, 4)) ||
+			    (_rtw_memcmp(pIE->data, WPS_OUI, 4))) {
+				vs_ie_length = pIE->Length;
+				if ((!padapter->registrypriv.wifi_spec) && (_rtw_memcmp(pIE->data, WPS_OUI, 4))) {
+					/* Commented by Kurt 20110629 */
+					/* In some older APs, WPS handshake */
+					/* would be fail if we append vender extensions informations to AP */
+
+					vs_ie_length = 14;
+				}
 
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+				pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, vs_ie_length, pIE->data, &(pattrib->pktlen));
+			}
+			break;
 
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
+		case EID_WPA2:
+#ifdef CONFIG_RTW_80211R
+			if ((is_reassoc) && (rtw_ft_roam(padapter))) {
+				rtw_ft_update_rsnie(padapter, _TRUE, pattrib, &pframe);
+			} else
+#endif
+				pframe = rtw_set_ie(pframe, EID_WPA2, pIE->Length, pIE->data, &(pattrib->pktlen));
+			break;
+#ifdef CONFIG_80211N_HT
+		case EID_HTCapability:
+			if (padapter->mlmepriv.htpriv.ht_option == _TRUE) {
+				if (!(is_ap_in_tkip(padapter))) {
+					_rtw_memcpy(&(pmlmeinfo->HT_caps), pIE->data, sizeof(struct HT_caps_element));
 
-	if((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
-		SetFrDs(fctrl);
-	}
-	else if((pmlmeinfo->state&0x03) == WIFI_FW_STATION_STATE)
-	{
-		SetToDs(fctrl);
-	}
+					pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info = cpu_to_le16(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info);
 
-	if(pattrib->mdata)
-		SetMData(fctrl);
+					pframe = rtw_set_ie(pframe, EID_HTCapability, pIE->Length , (u8 *)(&(pmlmeinfo->HT_caps)), &(pattrib->pktlen));
+				}
+			}
+			break;
 
-	qc = (unsigned short *)(pframe + pattrib->hdrlen - 2);
-	
-	SetPriority(qc, tid);
+		case EID_EXTCapability:
+			if (padapter->mlmepriv.htpriv.ht_option == _TRUE)
+				pframe = rtw_set_ie(pframe, EID_EXTCapability, pIE->Length, pIE->data, &(pattrib->pktlen));
+			break;
+#endif /* CONFIG_80211N_HT */
+#ifdef CONFIG_80211AC_VHT
+		case EID_VHTCapability:
+			if (padapter->mlmepriv.vhtpriv.vht_option == _TRUE)
+				pframe = rtw_set_ie(pframe, EID_VHTCapability, pIE->Length, pIE->data, &(pattrib->pktlen));
+			break;
 
-	SetEOSP(qc, pattrib->eosp);
+		case EID_OpModeNotification:
+			if (padapter->mlmepriv.vhtpriv.vht_option == _TRUE)
+				pframe = rtw_set_ie(pframe, EID_OpModeNotification, pIE->Length, pIE->data, &(pattrib->pktlen));
+			break;
+#endif /* CONFIG_80211AC_VHT */
+		default:
+			break;
+		}
 
-	SetAckpolicy(qc, pattrib->ack_policy);
+		i += (pIE->Length + 2);
+	}
 
-	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK)
+		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, 6 , REALTEK_96B_IE, &(pattrib->pktlen));
 
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_QOS_DATA_NULL);
 
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
+#ifdef CONFIG_WAPI_SUPPORT
+	rtw_build_assoc_req_wapi_ie(padapter, pframe, pattrib);
+#endif
 
-	pattrib->last_txcmdsz = pattrib->pktlen;
-	
-	if(wait_ack)
-	{
-		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	}
-	else
-	{
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
-	}
 
-exit:
-	return ret;
-}
+#ifdef CONFIG_P2P
 
-/*
- * when wait_ms >0 , this function should be called at process context
- * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
- * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
- * try_cnt means the maximal TX count to try
- * da == NULL for station mode
- */
-int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int try_cnt, int wait_ms)
-{
-	int ret = _FAIL;
-	int i = 0;
-	u32 start = rtw_get_current_time();
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+#ifdef CONFIG_IOCTL_CFG80211
+	if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (pmlmepriv->p2p_assoc_req_ie && pmlmepriv->p2p_assoc_req_ie_len > 0) {
+			_rtw_memcpy(pframe, pmlmepriv->p2p_assoc_req_ie, pmlmepriv->p2p_assoc_req_ie_len);
+			pframe += pmlmepriv->p2p_assoc_req_ie_len;
+			pattrib->pktlen += pmlmepriv->p2p_assoc_req_ie_len;
+		}
+	} else
+#endif /* CONFIG_IOCTL_CFG80211 */
+	{
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
+			/*	Should add the P2P IE in the association request frame.	 */
+			/*	P2P OUI */
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		goto exit;
+			p2pielen = 0;
+			p2pie[p2pielen++] = 0x50;
+			p2pie[p2pielen++] = 0x6F;
+			p2pie[p2pielen++] = 0x9A;
+			p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+			/*	Commented by Albert 20101109 */
+			/*	According to the P2P Specification, the association request frame should contain 3 P2P attributes */
+			/*	1. P2P Capability */
+			/*	2. Extended Listen Timing */
+			/*	3. Device Info */
+			/*	Commented by Albert 20110516 */
+			/*	4. P2P Interface */
+
+			/*	P2P Capability */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
+			p2pielen += 2;
 
-	/* da == NULL, assum it's null data for sta to ap*/
-	if (da == NULL)
-		da = get_my_bssid(&(pmlmeinfo->network));
-	
-	do
-	{
-		ret = _issue_qos_nulldata(padapter, da, tid, wait_ms>0?_TRUE:_FALSE);
+			/*	Value: */
+			/*	Device Capability Bitmap, 1 byte */
+			p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
 
-		i++;
+			/*	Group Capability Bitmap, 1 byte */
+			if (pwdinfo->persistent_supported)
+				p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
+			else
+				p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
 
-		if (RTW_CANNOT_RUN(padapter))
-			break;
+			/*	Extended Listen Timing */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
 
-		if(i < try_cnt && wait_ms > 0 && ret==_FAIL)
-			rtw_msleep_os(wait_ms);
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0004);
+			p2pielen += 2;
 
-	}while((i<try_cnt) && ((ret==_FAIL)||(wait_ms==0)));
+			/*	Value: */
+			/*	Availability Period */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
+			p2pielen += 2;
 
-	if (ret != _FAIL) {
-		ret = _SUCCESS;
-		#ifndef DBG_XMIT_ACK
-		goto exit;
-		#endif
-	}
+			/*	Availability Interval */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
+			p2pielen += 2;
 
-	if (try_cnt && wait_ms) {
-		if (da)
-			DBG_871X(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
-		else
-			DBG_871X(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+			/*	Device Info */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
+
+			/*	Length: */
+			/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+			/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
+			p2pielen += 2;
+
+			/*	Value: */
+			/*	P2P Device Address */
+			_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
+			p2pielen += ETH_ALEN;
+
+			/*	Config Method */
+			/*	This field should be big endian. Noted by P2P specification. */
+			if ((pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PEER_DISPLAY_PIN) ||
+			    (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_SELF_DISPLAY_PIN))
+				*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_DISPLAY);
+			else
+				*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_PBC);
+
+			p2pielen += 2;
+
+			/*	Primary Device Type */
+			/*	Category ID */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
+			p2pielen += 2;
+
+			/*	OUI */
+			*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
+			p2pielen += 4;
+
+			/*	Sub Category ID */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
+			p2pielen += 2;
+
+			/*	Number of Secondary Device Types */
+			p2pie[p2pielen++] = 0x00;	/*	No Secondary Device Type List */
+
+			/*	Device Name */
+			/*	Type: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
+			p2pielen += 2;
+
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
+			p2pielen += 2;
+
+			/*	Value: */
+			_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
+			p2pielen += pwdinfo->device_name_len;
+
+			/*	P2P Interface */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_INTERFACE;
+
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x000D);
+			p2pielen += 2;
+
+			/*	Value: */
+			_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN);	/*	P2P Device Address */
+			p2pielen += ETH_ALEN;
+
+			p2pie[p2pielen++] = 1;	/*	P2P Interface Address Count */
+
+			_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN);	/*	P2P Interface Address List */
+			p2pielen += ETH_ALEN;
+
+			pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
+		}
 	}
+
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_WFD
+	wfdielen = rtw_append_assoc_req_wfd_ie(padapter, pframe);
+	pframe += wfdielen;
+	pattrib->pktlen += wfdielen;
+#endif
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
+#endif
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_ASSOCREQ_VENDOR_IE_BIT);
+#endif
+#ifdef CONFIG_RTW_80211R
+	rtw_ft_build_assoc_req_ies(padapter, is_reassoc, pattrib, &pframe);
+#endif
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
+
+	ret = _SUCCESS;
+
 exit:
-	return ret;
+	if (ret == _SUCCESS)
+		rtw_buf_update(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len, (u8 *)pwlanhdr, pattrib->pktlen);
+	else
+		rtw_buf_free(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len);
+
+	return;
 }
 
-static int _issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason, u8 wait_ack, u8 key_type)
+void issue_assocreq(_adapter *padapter)
+{
+	_issue_assocreq(padapter, _FALSE);
+}
+
+void issue_reassocreq(_adapter *padapter)
 {
+	_issue_assocreq(padapter, _TRUE);
+}
+
+/* when wait_ack is ture, this function shoule be called at process context */
+static int _issue_nulldata(_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 rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short				*fctrl;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	int ret = _FAIL;
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif //CONFIG_P2P	
+	struct xmit_priv	*pxmitpriv;
+	struct mlme_ext_priv	*pmlmeext;
+	struct mlme_ext_info	*pmlmeinfo;
+	u8 a4_shift;
 
-	//DBG_871X("%s to "MAC_FMT"\n", __func__, MAC_ARG(da));
+	/* RTW_INFO("%s:%d\n", __FUNCTION__, power_mode); */
 
-#ifdef CONFIG_P2P
-	if ( !( rtw_p2p_chk_state( pwdinfo, P2P_STATE_NONE ) ) && ( pwdinfo->rx_invitereq_info.scan_op_ch_only ) )
-	{
-		_cancel_timer_ex( &pwdinfo->reset_ch_sitesurvey );
-		_set_timer( &pwdinfo->reset_ch_sitesurvey, 10 );
-	}
-#endif //CONFIG_P2P
+	if (!padapter)
+		goto exit;
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pxmitpriv = &(padapter->xmitpriv);
+	pmlmeext = &(padapter->mlmeextpriv);
+	pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		goto exit;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 	pattrib->retry_ctrl = _FALSE;
-	pattrib->key_type = key_type;
+
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
@@ -9494,29 +9834,44 @@ static int _issue_deauth(_adapter *padapter, unsigned char *da, unsigned short r
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	if (MLME_IS_AP(padapter))
+		SetFrDs(fctrl);
+	else if (MLME_IS_STA(padapter))
+		SetToDs(fctrl);
+	else if (MLME_IS_MESH(padapter)) {
+		SetToDs(fctrl);
+		SetFrDs(fctrl);
+	}
+
+	if (power_mode)
+		SetPwrMgt(fctrl);
+
+	if (get_tofr_ds(fctrl) == 3) {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr4, adapter_mac_addr(padapter), ETH_ALEN);
+		a4_shift = ETH_ALEN;
+		pattrib->hdrlen += ETH_ALEN;
+	} else {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		a4_shift = 0;
+	}
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_DEAUTH);
-
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	set_frame_sub_type(pframe, WIFI_DATA_NULL);
 
-	reason = cpu_to_le16(reason);
-	pframe = rtw_set_fixed_ie(pframe, _RSON_CODE_ , (unsigned char *)&reason, &(pattrib->pktlen));
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr) + a4_shift;
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr) + a4_shift;
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
-
-	if(wait_ack)
-	{
+	if (wait_ack)
 		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	}
-	else
-	{
+	else {
 		dump_mgntframe(padapter, pmgntframe);
 		ret = _SUCCESS;
 	}
@@ -9525,97 +9880,95 @@ exit:
 	return ret;
 }
 
-int issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason)
-{
-	DBG_871X("%s to "MAC_FMT"\n", __func__, MAC_ARG(da));
-	return _issue_deauth(padapter, da, reason, _FALSE, IEEE80211W_RIGHT_KEY);
-}
-
-#ifdef CONFIG_IEEE80211W
-int issue_deauth_11w(_adapter *padapter, unsigned char *da, unsigned short reason, u8 key_type)
-{
-	DBG_871X("%s to "MAC_FMT"\n", __func__, MAC_ARG(da));
-	return _issue_deauth(padapter, da, reason, _FALSE, key_type);
-}
-#endif /* CONFIG_IEEE80211W */
-
 /*
+ * When wait_ms > 0, this function should be called at process context
  * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
  * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
  * try_cnt means the maximal TX count to try
+ * da == NULL for station mode
  */
-int issue_deauth_ex(_adapter *padapter, u8 *da, unsigned short reason, int try_cnt,
-	int wait_ms)
+int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)
 {
 	int ret = _FAIL;
 	int i = 0;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
 
-	do
-	{
-		ret = _issue_deauth(padapter, da, reason, wait_ms > 0 ? _TRUE:_FALSE, IEEE80211W_RIGHT_KEY);
+	/* da == NULL, assum it's null data for sta to ap */
+	if (da == NULL)
+		da = get_my_bssid(&(pmlmeinfo->network));
+
+	do {
+		ret = _issue_nulldata(padapter, da, power_mode, wait_ms > 0 ? _TRUE : _FALSE);
 
 		i++;
 
 		if (RTW_CANNOT_RUN(padapter))
 			break;
 
-		if(i < try_cnt && wait_ms > 0 && ret==_FAIL)
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
 			rtw_msleep_os(wait_ms);
 
-	}while((i<try_cnt) && ((ret==_FAIL)||(wait_ms==0)));
+	} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
 
 	if (ret != _FAIL) {
 		ret = _SUCCESS;
-		#ifndef DBG_XMIT_ACK
+#ifndef DBG_XMIT_ACK
 		goto exit;
-		#endif
+#endif
 	}
 
 	if (try_cnt && wait_ms) {
 		if (da)
-			DBG_871X(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
+			RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
 				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
 		else
-			DBG_871X(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
+			RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
 				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
 	}
 exit:
 	return ret;
 }
 
-void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset)
-{	
-	_irqL	irqL;
-	_list		*plist, *phead;
+/* when wait_ack is ture, this function shoule be called at process context */
+static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int wait_ack)
+{
+	int ret = _FAIL;
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
-	unsigned char				*pframe;
+	unsigned char					*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short			*fctrl;
+	unsigned short				*fctrl, *qc;
 	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);
+	u8 a4_shift;
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		return;
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		goto exit;
 
-	DBG_871X(FUNC_NDEV_FMT" ra="MAC_FMT", ch:%u, offset:%u\n",
-		FUNC_NDEV_ARG(padapter->pnetdev), MAC_ARG(ra), new_ch, ch_offset);
+	/* RTW_INFO("%s\n", __FUNCTION__); */
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		return;
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
+	pattrib->hdrlen += 2;
+	pattrib->qos_en = _TRUE;
+	pattrib->eosp = 1;
+	pattrib->ack_policy = 0;
+	pattrib->mdata = 0;
+
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
@@ -9624,173 +9977,155 @@ void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_of
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN); /* RA */
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN); /* TA */
-	_rtw_memcpy(pwlanhdr->addr3, ra, ETH_ALEN); /* DA = RA */
-
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	if (MLME_IS_AP(padapter))
+		SetFrDs(fctrl);
+	else if (MLME_IS_STA(padapter))
+		SetToDs(fctrl);
+	else if (MLME_IS_MESH(padapter)) {
+		SetToDs(fctrl);
+		SetFrDs(fctrl);
+	}
 
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	if (ps)
+		SetPwrMgt(fctrl);
 
-	/* category, action */
-	{
-		u8 category, action;
-		category = RTW_WLAN_CATEGORY_SPECTRUM_MGMT;
-		action = RTW_WLAN_ACTION_SPCT_CHL_SWITCH;
+	if (pattrib->mdata)
+		SetMData(fctrl);
 
-		pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
-		pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
+	if (get_tofr_ds(fctrl) == 3) {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr4, adapter_mac_addr(padapter), ETH_ALEN);
+		a4_shift = ETH_ALEN;
+		pattrib->hdrlen += ETH_ALEN;
+	} else {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		a4_shift = 0;
 	}
 
-	pframe = rtw_set_ie_ch_switch(pframe, &(pattrib->pktlen), 0, new_ch, 0);
-	pframe = rtw_set_ie_secondary_ch_offset(pframe, &(pattrib->pktlen),
-		hal_ch_offset_to_secondary_ch_offset(ch_offset));
+	qc = (unsigned short *)(pframe + pattrib->hdrlen - 2);
+
+	SetPriority(qc, tid);
+
+	SetEOSP(qc, pattrib->eosp);
+
+	SetAckpolicy(qc, pattrib->ack_policy);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos) + a4_shift;
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos) + a4_shift;
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
-	dump_mgntframe(padapter, pmgntframe);
+	if (wait_ack)
+		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
+	else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
 
+exit:
+	return ret;
 }
 
-#ifdef CONFIG_IEEE80211W
-void issue_action_SA_Query(_adapter *padapter, unsigned char *raddr, unsigned char action, unsigned short tid, u8 key_type)
+/*
+ * when wait_ms >0 , this function should be called at process context
+ * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
+ * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
+ * try_cnt means the maximal TX count to try
+ * da == NULL for station mode
+ */
+int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int try_cnt, int wait_ms)
 {
-	u8	category = RTW_WLAN_CATEGORY_SA_QUERY;
-	u16	reason_code;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	u8					*pframe;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16					*fctrl;
-	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
+	int ret = _FAIL;
+	int i = 0;
+	systime start = rtw_get_current_time();
 	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;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		return;
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		goto exit;
 
-	DBG_871X("%s, %04x\n", __FUNCTION__, tid);
+	/* da == NULL, assum it's null data for sta to ap*/
+	if (da == NULL)
+		da = get_my_bssid(&(pmlmeinfo->network));
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		DBG_871X("%s: alloc_mgtxmitframe fail\n", __FUNCTION__);
-		return;
-	}
-
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
-	pattrib->key_type = key_type;
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-
-	if(raddr)
-		_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
-	else
-		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	do {
+		ret = _issue_qos_nulldata(padapter, da, tid, ps, wait_ms > 0 ? _TRUE : _FALSE);
 
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+		i++;
 
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+		if (RTW_CANNOT_RUN(padapter))
+			break;
 
-	pframe = rtw_set_fixed_ie(pframe, 1, &category, &pattrib->pktlen);
-	pframe = rtw_set_fixed_ie(pframe, 1, &action, &pattrib->pktlen);
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
+			rtw_msleep_os(wait_ms);
 
-	switch (action)
-	{
-		case 0: //SA Query req
-			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)&pmlmeext->sa_query_seq, &pattrib->pktlen);
-			pmlmeext->sa_query_seq++;
-			/* send sa query request to AP, AP should reply sa query response in 1 second */
-			if (pattrib->key_type == IEEE80211W_RIGHT_KEY) {
-				psta = rtw_get_stainfo(pstapriv, raddr);
-				if (psta != NULL) {
-					/* DBG_871X("%s, %d, set dot11w_expire_timer\n", __func__, __LINE__); */
-					_set_timer(&psta->dot11w_expire_timer, 1000);
-				}
-			}
-			break;
+	} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
 
-		case 1: //SA Query rsp
-			tid = cpu_to_le16(tid);
-			/* DBG_871X("rtw_set_fixed_ie, %04x\n", tid); */
-			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)&tid, &pattrib->pktlen);
-			break;
-		default:
-			break;
+	if (ret != _FAIL) {
+		ret = _SUCCESS;
+#ifndef DBG_XMIT_ACK
+		goto exit;
+#endif
 	}
 
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(padapter, pmgntframe);
+	if (try_cnt && wait_ms) {
+		if (da)
+			RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+		else
+			RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+	}
+exit:
+	return ret;
 }
-#endif //CONFIG_IEEE80211W
 
-/**
- * issue_action_ba - internal function to TX Block Ack action frame
- * @padapter: the adapter to TX
- * @raddr: receiver address
- * @action: Block Ack Action
- * @tid: tid
- * @size: the announced AMPDU buffer size. used by ADDBA_RESP
- * @status: status/reason code. used by ADDBA_RESP, DELBA
- * @initiator: if we are the initiator of AMPDU association. used by DELBA
- * @wait_ack: used xmit ack
- *
- * Returns:
- * _SUCCESS: No xmit ack is used or acked
- * _FAIL: not acked when using xmit ack
- */
-static int issue_action_ba(_adapter *padapter, unsigned char *raddr, unsigned char action
-	, u8 tid, u8 size, u16 status, u8 initiator, int wait_ack)
+static int _issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason, u8 wait_ack, u8 key_type)
 {
-	int ret = _FAIL;
-	u8	category = RTW_WLAN_CATEGORY_BACK;
-	u16	start_seq;
-	u16	BA_para_set;
-	u16	BA_timeout_value;
-	u16	BA_starting_seqctrl;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	u8					*pframe;
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	unsigned char					*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16					*fctrl;
-	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
+	unsigned short				*fctrl;
+	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;
+	int ret = _FAIL;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P	 */
 
-#ifdef CONFIG_80211N_HT
+	/* RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(da)); */
+
+#ifdef CONFIG_P2P
+	if (!(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) && (pwdinfo->rx_invitereq_info.scan_op_ch_only)) {
+		_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
+		_set_timer(&pwdinfo->reset_ch_sitesurvey, 10);
+	}
+#endif /* CONFIG_P2P */
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		goto exit;
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
-
+	pattrib->retry_ctrl = _FALSE;
+	pattrib->key_type = key_type;
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
@@ -9799,211 +10134,69 @@ static int issue_action_ba(_adapter *padapter, unsigned char *raddr, unsigned ch
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	//_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_DEAUTH);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
-
-	if (category == 3)
-	{
-		switch (action)
-		{
-			case RTW_WLAN_ACTION_ADDBA_REQ:
-				do {
-					pmlmeinfo->dialogToken++;
-				} while (pmlmeinfo->dialogToken == 0);
-				pframe = rtw_set_fixed_ie(pframe, 1, &(pmlmeinfo->dialogToken), &(pattrib->pktlen));
-
-				#if defined(CONFIG_RTL8188E) && defined(CONFIG_SDIO_HCI)
-				BA_para_set = (0x0802 | ((tid & 0xf) << 2)); /* immediate ack & 16 buffer size */
-				#else
-				BA_para_set = (0x1002 | ((tid & 0xf) << 2)); /* immediate ack & 64 buffer size */
-				#endif
-
-				BA_para_set = cpu_to_le16(BA_para_set);
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
-
-				//BA_timeout_value = 0xffff;//max: 65535 TUs(~ 65 ms)
-				BA_timeout_value = 5000;//~ 5ms
-				BA_timeout_value = cpu_to_le16(BA_timeout_value);
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_timeout_value)), &(pattrib->pktlen));
-
-				//if ((psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress)) != NULL)
-				if ((psta = rtw_get_stainfo(pstapriv, raddr)) != NULL)
-				{
-					start_seq = (psta->sta_xmitpriv.txseq_tid[tid & 0x07]&0xfff) + 1;
-
-					DBG_871X("BA_starting_seqctrl = %d for TID=%d\n", start_seq, tid & 0x07);
-					
-					psta->BA_starting_seqctrl[tid & 0x07] = start_seq;
-					
-					BA_starting_seqctrl = start_seq << 4;
-				}
-				
-				BA_starting_seqctrl = cpu_to_le16(BA_starting_seqctrl);
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_starting_seqctrl)), &(pattrib->pktlen));
-				break;
-
-			case RTW_WLAN_ACTION_ADDBA_RESP:
-				pframe = rtw_set_fixed_ie(pframe, 1, &(pmlmeinfo->ADDBA_req.dialog_token), &(pattrib->pktlen));
-				status = cpu_to_le16(status);
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&status), &(pattrib->pktlen));
-
-				BA_para_set = le16_to_cpu(pmlmeinfo->ADDBA_req.BA_para_set);
-
-				BA_para_set &= ~IEEE80211_ADDBA_PARAM_TID_MASK;
-				BA_para_set |= (tid << 2) & IEEE80211_ADDBA_PARAM_TID_MASK;
-
-				BA_para_set &= ~RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
-				BA_para_set |= (size << 6) & RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
-
-				if (!padapter->registrypriv.wifi_spec) {
-					if(pregpriv->ampdu_amsdu==0)//disabled
-						BA_para_set &= ~BIT(0);
-					else if(pregpriv->ampdu_amsdu==1)//enabled
-						BA_para_set |= BIT(0);
-				}
-
-				BA_para_set = cpu_to_le16(BA_para_set);
-
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(pmlmeinfo->ADDBA_req.BA_timeout_value)), &(pattrib->pktlen));
-				break;
-
-			case RTW_WLAN_ACTION_DELBA:
-				BA_para_set = 0;
-				BA_para_set |= (tid << 12) & IEEE80211_DELBA_PARAM_TID_MASK;
-				BA_para_set |= (initiator << 11) & IEEE80211_DELBA_PARAM_INITIATOR_MASK;
-
-				BA_para_set = cpu_to_le16(BA_para_set);				
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
-				status = cpu_to_le16(status);
-				pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(status)), &(pattrib->pktlen));
-				break;
-			default:
-				break;
-		}
-	}
+	reason = cpu_to_le16(reason);
+	pframe = rtw_set_fixed_ie(pframe, _RSON_CODE_ , (unsigned char *)&reason, &(pattrib->pktlen));
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
-	if (wait_ack) {
+
+	if (wait_ack)
 		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	} else {
+	else {
 		dump_mgntframe(padapter, pmgntframe);
 		ret = _SUCCESS;
 	}
 
 exit:
-#endif //CONFIG_80211N_HT
 	return ret;
 }
 
-/**
- * issue_addba_req - TX ADDBA_REQ
- * @adapter: the adapter to TX
- * @ra: receiver address
- * @tid: tid
- */
-inline void issue_addba_req(_adapter *adapter, unsigned char *ra, u8 tid)
-{
-	issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_REQ
-		, tid
-		, 0 /* unused */
-		, 0 /* unused */
-		, 0 /* unused */
-		, _FALSE
-	);
-	DBG_871X(FUNC_ADPT_FMT" ra="MAC_FMT" tid=%u\n"
-		, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), tid);
-
-}
-
-/**
- * issue_addba_rsp - TX ADDBA_RESP
- * @adapter: the adapter to TX
- * @ra: receiver address
- * @tid: tid
- * @status: status code
- * @size: the announced AMPDU buffer size
- */
-inline void issue_addba_rsp(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size)
+int issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason)
 {
-	issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_RESP
-		, tid
-		, size
-		, status
-		, 0 /* unused */
-		, _FALSE
-	);
-	DBG_871X(FUNC_ADPT_FMT" ra="MAC_FMT" status=%u, tid=%u, size=%u\n"
-		, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), status, tid, size);
+	RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(da));
+	return _issue_deauth(padapter, da, reason, _FALSE, IEEE80211W_RIGHT_KEY);
 }
 
-/**
- * issue_del_ba - TX DELBA
- * @adapter: the adapter to TX
- * @ra: receiver address
- * @tid: tid
- * @reason: reason code
- * @initiator: if we are the initiator of AMPDU association. used by DELBA
- */
-inline void issue_del_ba(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator)
+#ifdef CONFIG_IEEE80211W
+int issue_deauth_11w(_adapter *padapter, unsigned char *da, unsigned short reason, u8 key_type)
 {
-	issue_action_ba(adapter, ra, RTW_WLAN_ACTION_DELBA
-		, tid
-		, 0 /* unused */
-		, reason
-		, initiator
-		, _FALSE
-	);
-	DBG_871X(FUNC_ADPT_FMT" ra="MAC_FMT" reason=%u, tid=%u, initiator=%u\n"
-		, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), reason, tid, initiator);
+	RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(da));
+	return _issue_deauth(padapter, da, reason, _FALSE, key_type);
 }
+#endif /* CONFIG_IEEE80211W */
 
-/**
- * issue_del_ba_ex - TX DELBA with xmit ack options
- * @adapter: the adapter to TX
- * @ra: receiver address
- * @tid: tid
- * @reason: reason code
- * @initiator: if we are the initiator of AMPDU association. used by DELBA
- * @try_cnt: the maximal TX count to try
- * @wait_ms: == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
- *           > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
+/*
+ * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
+ * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
+ * try_cnt means the maximal TX count to try
  */
-int issue_del_ba_ex(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator
-	, int try_cnt, int wait_ms)
+int issue_deauth_ex(_adapter *padapter, u8 *da, unsigned short reason, int try_cnt,
+		    int wait_ms)
 {
 	int ret = _FAIL;
 	int i = 0;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(adapter)))
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
 
 	do {
-		ret = issue_action_ba(adapter, ra, RTW_WLAN_ACTION_DELBA
-			, tid
-			, 0 /* unused */
-			, reason
-			, initiator
-			, wait_ms > 0?_TRUE:_FALSE
-		);
+		ret = _issue_deauth(padapter, da, reason, wait_ms > 0 ? _TRUE : _FALSE, IEEE80211W_RIGHT_KEY);
 
 		i++;
 
-		if (RTW_CANNOT_RUN(adapter))
+		if (RTW_CANNOT_RUN(padapter))
 			break;
 
 		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
@@ -10013,60 +10206,50 @@ int issue_del_ba_ex(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8
 
 	if (ret != _FAIL) {
 		ret = _SUCCESS;
-	#ifndef DBG_XMIT_ACK
-		/* goto exit; */
-	#endif
+#ifndef DBG_XMIT_ACK
+		goto exit;
+#endif
 	}
 
 	if (try_cnt && wait_ms) {
-		DBG_871X(FUNC_ADPT_FMT" ra="MAC_FMT" reason=%u, tid=%u, initiator=%u%s, %d/%d in %u ms\n"
-			, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), reason, tid, initiator
-			, ret == _SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+		if (da)
+			RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+		else
+			RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
 	}
 exit:
 	return ret;
 }
 
-static void issue_action_BSSCoexistPacket(_adapter *padapter)
-{	
+void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset)
+{
 	_irqL	irqL;
 	_list		*plist, *phead;
-	unsigned char category, action;
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char				*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short			*fctrl;
-	struct	wlan_network	*pnetwork = NULL;
 	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);
-	_queue		*queue	= &(pmlmepriv->scanned_queue);
-	u8 InfoContent[16] = {0};
-	u8 ICS[8][15];
-#ifdef CONFIG_80211N_HT	
-	if((pmlmepriv->num_FortyMHzIntolerant==0) || (pmlmepriv->num_sta_no_ht==0))
-		return;
 
-	if(_TRUE == pmlmeinfo->bwmode_updated)
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		return;
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		return;	
-
-	DBG_871X("%s\n", __FUNCTION__);
-
-
-	category = RTW_WLAN_CATEGORY_PUBLIC;
-	action = ACT_PUBLIC_BSSCOEXIST;
+	RTW_INFO(FUNC_NDEV_FMT" ra="MAC_FMT", ch:%u, offset:%u\n",
+		FUNC_NDEV_ARG(padapter->pnetdev), MAC_ARG(ra), new_ch, ch_offset);
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -10078,159 +10261,170 @@ static void issue_action_BSSCoexistPacket(_adapter *padapter)
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN); /* RA */
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN); /* TA */
+	_rtw_memcpy(pwlanhdr->addr3, ra, ETH_ALEN); /* DA = RA */
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
-
-
-	//
-	if(pmlmepriv->num_FortyMHzIntolerant>0)
+	/* category, action */
 	{
-		u8 iedata=0;
-		
-		iedata |= BIT(2);//20 MHz BSS Width Request
+		u8 category, action;
+		category = RTW_WLAN_CATEGORY_SPECTRUM_MGMT;
+		action = RTW_WLAN_ACTION_SPCT_CHL_SWITCH;
 
-		pframe = rtw_set_ie(pframe, EID_BSSCoexistence,  1, &iedata, &(pattrib->pktlen));
-		
+		pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+		pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	}
-	
 
-	//
-	_rtw_memset(ICS, 0, sizeof(ICS));
-	if(pmlmepriv->num_sta_no_ht>0)
-	{	
-		int i;
-	
-		_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+	pframe = rtw_set_ie_ch_switch(pframe, &(pattrib->pktlen), 0, new_ch, 0);
+	pframe = rtw_set_ie_secondary_ch_offset(pframe, &(pattrib->pktlen),
+			hal_ch_offset_to_secondary_ch_offset(ch_offset));
 
-		phead = get_list_head(queue);
-		plist = get_next(phead);
-       
-		while(1)
-		{
-			int len;
-			u8 *p;
-			WLAN_BSSID_EX *pbss_network;
-	
-			if (rtw_end_of_queue_search(phead,plist)== _TRUE)
-				break;		
+	pattrib->last_txcmdsz = pattrib->pktlen;
 
-			pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);      
-		
-			plist = get_next(plist);
+	dump_mgntframe(padapter, pmgntframe);
 
-			pbss_network = (WLAN_BSSID_EX *)&pnetwork->network;
+}
 
-			p = rtw_get_ie(pbss_network->IEs + _FIXED_IE_LENGTH_, _HT_CAPABILITY_IE_, &len, pbss_network->IELength - _FIXED_IE_LENGTH_);
-			if((p==NULL) || (len==0))//non-HT
-			{
-				if((pbss_network->Configuration.DSConfig<=0) || (pbss_network->Configuration.DSConfig>14))
-					continue;
-				
-				ICS[0][pbss_network->Configuration.DSConfig]=1;
-				
-				if(ICS[0][0] == 0)
-					ICS[0][0] = 1;		
-			}		
-	
-		}        
+#ifdef CONFIG_IEEE80211W
+void issue_action_SA_Query(_adapter *padapter, unsigned char *raddr, unsigned char action, unsigned short tid, u8 key_type)
+{
+	u8	category = RTW_WLAN_CATEGORY_SA_QUERY;
+	u16	reason_code;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	u8					*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	u16					*fctrl;
+	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;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		return;
 
+	RTW_INFO("%s, %04x\n", __FUNCTION__, tid);
 
-		for(i= 0;i<8;i++)
-		{
-			if(ICS[i][0] == 1)
-			{
-				int j, k = 0;
-				
-				InfoContent[k] = i;				
-				//SET_BSS_INTOLERANT_ELE_REG_CLASS(InfoContent,i);
-				k++;
-				
-				for(j=1;j<=14;j++)
-				{
-					if(ICS[i][j]==1)
-					{
-						if(k<16)
-						{
-							InfoContent[k] = j; //channel number
-							//SET_BSS_INTOLERANT_ELE_CHANNEL(InfoContent+k, j);
-							k++;
-						}	
-					}	
-				}	
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		RTW_INFO("%s: alloc_mgtxmitframe fail\n", __FUNCTION__);
+		return;
+	}
 
-				pframe = rtw_set_ie(pframe, EID_BSSIntolerantChlReport, k, InfoContent, &(pattrib->pktlen));
-				
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+	pattrib->key_type = key_type;
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	if (raddr)
+		_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
+	else
+		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	pframe = rtw_set_fixed_ie(pframe, 1, &category, &pattrib->pktlen);
+	pframe = rtw_set_fixed_ie(pframe, 1, &action, &pattrib->pktlen);
+
+	switch (action) {
+	case 0: /* SA Query req */
+		pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)&pmlmeext->sa_query_seq, &pattrib->pktlen);
+		pmlmeext->sa_query_seq++;
+		/* send sa query request to AP, AP should reply sa query response in 1 second */
+		if (pattrib->key_type == IEEE80211W_RIGHT_KEY) {
+			psta = rtw_get_stainfo(pstapriv, pwlanhdr->addr1);
+			if (psta != NULL) {
+				/* RTW_INFO("%s, %d, set dot11w_expire_timer\n", __func__, __LINE__); */
+				_set_timer(&psta->dot11w_expire_timer, 1000);
 			}
-			
 		}
-		
+		break;
 
+	case 1: /* SA Query rsp */
+		tid = cpu_to_le16(tid);
+		/* RTW_INFO("rtw_set_fixed_ie, %04x\n", tid); */
+		pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)&tid, &pattrib->pktlen);
+		break;
+	default:
+		break;
 	}
-		
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
 	dump_mgntframe(padapter, pmgntframe);
-#endif //CONFIG_80211N_HT
 }
+#endif /* CONFIG_IEEE80211W */
 
-// Spatial Multiplexing Powersave (SMPS) action frame
-int _issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode ,  u8 wait_ack)
+/**
+ * issue_action_ba - internal function to TX Block Ack action frame
+ * @padapter: the adapter to TX
+ * @raddr: receiver address
+ * @action: Block Ack Action
+ * @tid: tid
+ * @size: the announced AMPDU buffer size. used by ADDBA_RESP
+ * @status: status/reason code. used by ADDBA_RESP, DELBA
+ * @initiator: if we are the initiator of AMPDU association. used by DELBA
+ * @wait_ack: used xmit ack
+ *
+ * Returns:
+ * _SUCCESS: No xmit ack is used or acked
+ * _FAIL: not acked when using xmit ack
+ */
+static int issue_action_ba(_adapter *padapter, unsigned char *raddr, unsigned char action
+		   , u8 tid, u8 size, u16 status, u8 initiator, int wait_ack)
 {
-
 	int ret = _FAIL;
-	unsigned char category = RTW_WLAN_CATEGORY_HT;
-	u8 action = RTW_WLAN_ACTION_HT_SM_PS; 	
-	u8 sm_power_control=0;
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	unsigned char					*pframe;
+	u8	category = RTW_WLAN_CATEGORY_BACK;
+	u16	start_seq;
+	u16	BA_para_set;
+	u16	BA_timeout_value;
+	u16	BA_starting_seqctrl;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	u8					*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short				*fctrl;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	u16					*fctrl;
+	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;
 
+#ifdef CONFIG_80211N_HT
 
-	if(NewMimoPsMode==WLAN_HT_CAP_SM_PS_DISABLED)
-	{
-		sm_power_control = sm_power_control  & ~(BIT(0)); // SM Power Save Enable = 0 SM Power Save Disable 
-	}
-        else if(NewMimoPsMode==WLAN_HT_CAP_SM_PS_STATIC)
-        {
-                sm_power_control = sm_power_control | BIT(0);    // SM Power Save Enable = 1 SM Power Save Enable  
-                sm_power_control = sm_power_control & ~(BIT(1)); // SM Mode = 0 Static Mode
-        }
-        else if(NewMimoPsMode==WLAN_HT_CAP_SM_PS_DYNAMIC)
-        {
-                sm_power_control = sm_power_control | BIT(0); // SM Power Save Enable = 1 SM Power Save Enable  
-                sm_power_control = sm_power_control | BIT(1); // SM Mode = 1 Dynamic Mode
-        }
-        else 
-		return ret;
-
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
-		return ret;
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		goto exit;
 
-        DBG_871X("%s, sm_power_control=%u, NewMimoPsMode=%u\n", __FUNCTION__ , sm_power_control , NewMimoPsMode );
-    
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		return ret;
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -10242,904 +10436,1510 @@ int _issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoP
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN); /* RA */
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN); /* TA */
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN); /* DA = RA */
+	/* _rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN); */
+	_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	/* category, action */
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 
-	pframe = rtw_set_fixed_ie(pframe, 1, &(sm_power_control), &(pattrib->pktlen));
+	if (category == 3) {
+		switch (action) {
+		case RTW_WLAN_ACTION_ADDBA_REQ:
+			do {
+				pmlmeinfo->dialogToken++;
+			} while (pmlmeinfo->dialogToken == 0);
+			pframe = rtw_set_fixed_ie(pframe, 1, &(pmlmeinfo->dialogToken), &(pattrib->pktlen));
+
+#if defined(CONFIG_RTL8188E) && defined(CONFIG_SDIO_HCI)
+			BA_para_set = (0x0802 | ((tid & 0xf) << 2)); /* immediate ack & 16 buffer size */
+#else
+			BA_para_set = (0x1002 | ((tid & 0xf) << 2)); /* immediate ack & 64 buffer size */
+#endif
+
+#ifdef CONFIG_TX_AMSDU
+			if (padapter->tx_amsdu >= 1) /* TX AMSDU  enabled */
+				BA_para_set |= BIT(0);
+			else /* TX AMSDU disabled */
+				BA_para_set &= ~BIT(0);
+#endif
+			BA_para_set = cpu_to_le16(BA_para_set);
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
+
+			/* BA_timeout_value = 0xffff; */ /* max: 65535 TUs(~ 65 ms) */
+			BA_timeout_value = 5000;/* ~ 5ms */
+			BA_timeout_value = cpu_to_le16(BA_timeout_value);
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_timeout_value)), &(pattrib->pktlen));
+
+			/* if ((psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress)) != NULL) */
+			psta = rtw_get_stainfo(pstapriv, raddr);
+			if (psta != NULL) {
+				start_seq = (psta->sta_xmitpriv.txseq_tid[tid & 0x07] & 0xfff) + 1;
+
+				RTW_INFO("BA_starting_seqctrl = %d for TID=%d\n", start_seq, tid & 0x07);
+
+				psta->BA_starting_seqctrl[tid & 0x07] = start_seq;
+
+				BA_starting_seqctrl = start_seq << 4;
+			}
+
+			BA_starting_seqctrl = cpu_to_le16(BA_starting_seqctrl);
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_starting_seqctrl)), &(pattrib->pktlen));
+			break;
+
+		case RTW_WLAN_ACTION_ADDBA_RESP:
+			pframe = rtw_set_fixed_ie(pframe, 1, &(pmlmeinfo->ADDBA_req.dialog_token), &(pattrib->pktlen));
+			status = cpu_to_le16(status);
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&status), &(pattrib->pktlen));
+
+			BA_para_set = le16_to_cpu(pmlmeinfo->ADDBA_req.BA_para_set);
+
+			BA_para_set &= ~IEEE80211_ADDBA_PARAM_TID_MASK;
+			BA_para_set |= (tid << 2) & IEEE80211_ADDBA_PARAM_TID_MASK;
+
+			BA_para_set &= ~RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
+			BA_para_set |= (size << 6) & RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
+
+			if (!padapter->registrypriv.wifi_spec) {
+				if (pregpriv->rx_ampdu_amsdu == 0) /* disabled */
+					BA_para_set &= ~BIT(0);
+				else if (pregpriv->rx_ampdu_amsdu == 1) /* enabled */
+					BA_para_set |= BIT(0);
+			}
+
+			BA_para_set = cpu_to_le16(BA_para_set);
+
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(pmlmeinfo->ADDBA_req.BA_timeout_value)), &(pattrib->pktlen));
+			break;
+
+		case RTW_WLAN_ACTION_DELBA:
+			BA_para_set = 0;
+			BA_para_set |= (tid << 12) & IEEE80211_DELBA_PARAM_TID_MASK;
+			BA_para_set |= (initiator << 11) & IEEE80211_DELBA_PARAM_INITIATOR_MASK;
+
+			BA_para_set = cpu_to_le16(BA_para_set);
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
+			status = cpu_to_le16(status);
+			pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(status)), &(pattrib->pktlen));
+			break;
+		default:
+			break;
+		}
+	}
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
-	if(wait_ack)
-	{
+	if (wait_ack)
 		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	}
-	else
-	{
+	else {
 		dump_mgntframe(padapter, pmgntframe);
 		ret = _SUCCESS;
 	}
 
-        if (ret != _SUCCESS)
-            DBG_8192C("%s, ack to\n", __func__);
-
+exit:
+#endif /* CONFIG_80211N_HT */
 	return ret;
 }
 
-/*
- * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
- * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
- * try_cnt means the maximal TX count to try
+/**
+ * issue_addba_req - TX ADDBA_REQ
+ * @adapter: the adapter to TX
+ * @ra: receiver address
+ * @tid: tid
  */
-int issue_action_SM_PS_wait_ack(_adapter *padapter, unsigned char *raddr, u8 NewMimoPsMode, int try_cnt, int wait_ms)
+inline void issue_addba_req(_adapter *adapter, unsigned char *ra, u8 tid)
+{
+	issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_REQ
+			, tid
+			, 0 /* unused */
+			, 0 /* unused */
+			, 0 /* unused */
+			, _FALSE
+		       );
+	RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" tid=%u\n"
+		 , FUNC_ADPT_ARG(adapter), MAC_ARG(ra), tid);
+
+}
+
+/**
+ * issue_addba_rsp - TX ADDBA_RESP
+ * @adapter: the adapter to TX
+ * @ra: receiver address
+ * @tid: tid
+ * @status: status code
+ * @size: the announced AMPDU buffer size
+ */
+inline void issue_addba_rsp(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size)
+{
+	issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_RESP
+			, tid
+			, size
+			, status
+			, 0 /* unused */
+			, _FALSE
+		       );
+	RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" status=%u, tid=%u, size=%u\n"
+		 , FUNC_ADPT_ARG(adapter), MAC_ARG(ra), status, tid, size);
+}
+
+/**
+ * issue_addba_rsp_wait_ack - TX ADDBA_RESP and wait ack
+ * @adapter: the adapter to TX
+ * @ra: receiver address
+ * @tid: tid
+ * @status: status code
+ * @size: the announced AMPDU buffer size
+ * @try_cnt: the maximal TX count to try
+ * @wait_ms: == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
+ *           > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
+ */
+inline u8 issue_addba_rsp_wait_ack(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size, int try_cnt, int wait_ms)
 {
 	int ret = _FAIL;
 	int i = 0;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 
-	if (rtw_rfctl_is_tx_blocked_by_cac(adapter_to_rfctl(padapter)))
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(adapter)))
 		goto exit;
 
 	do {
-		ret = _issue_action_SM_PS(padapter, raddr, NewMimoPsMode , wait_ms>0?_TRUE:_FALSE );
+		ret = issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_RESP
+				      , tid
+				      , size
+				      , status
+				      , 0 /* unused */
+				      , _TRUE
+				     );
 
 		i++;
 
-		if (RTW_CANNOT_RUN(padapter))
+		if (RTW_CANNOT_RUN(adapter))
 			break;
 
-		if(i < try_cnt && wait_ms > 0 && ret==_FAIL)
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
 			rtw_msleep_os(wait_ms);
 
-	}while((i<try_cnt) && ((ret==_FAIL)||(wait_ms==0)));
+	} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
 
 	if (ret != _FAIL) {
 		ret = _SUCCESS;
-		#ifndef DBG_XMIT_ACK
-		goto exit;
-		#endif
+#ifndef DBG_XMIT_ACK
+		/* goto exit; */
+#endif
 	}
 
 	if (try_cnt && wait_ms) {
-		if (raddr)
-			DBG_871X(FUNC_ADPT_FMT" to "MAC_FMT", %s , %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), MAC_ARG(raddr),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
-		else
-			DBG_871X(FUNC_ADPT_FMT", %s , %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
+		RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" status:=%u tid=%u size:%u%s, %d/%d in %u ms\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), status, tid, size
+			, ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
 	}
-exit:
 
+exit:
 	return ret;
 }
 
-int issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode )
+/**
+ * issue_del_ba - TX DELBA
+ * @adapter: the adapter to TX
+ * @ra: receiver address
+ * @tid: tid
+ * @reason: reason code
+ * @initiator: if we are the initiator of AMPDU association. used by DELBA
+ */
+inline void issue_del_ba(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator)
 {
-	DBG_871X("%s to "MAC_FMT"\n", __func__, MAC_ARG(raddr));
-	return _issue_action_SM_PS(padapter, raddr, NewMimoPsMode , _FALSE );
+	issue_action_ba(adapter, ra, RTW_WLAN_ACTION_DELBA
+			, tid
+			, 0 /* unused */
+			, reason
+			, initiator
+			, _FALSE
+		       );
+	RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" reason=%u, tid=%u, initiator=%u\n"
+		 , FUNC_ADPT_ARG(adapter), MAC_ARG(ra), reason, tid, initiator);
 }
 
 /**
- * _send_delba_sta_tid - Cancel the AMPDU association for the specific @sta, @tid
- * @adapter: the adapter to which @sta belongs
- * @initiator: if we are the initiator of AMPDU association
- * @sta: the sta to be checked
- * @tid: the tid to be checked
- * @force: cancel and send DELBA even when no AMPDU association is setup
- * @wait_ack: send delba with xmit ack (valid when initiator == 0)
- *
- * Returns:
- * _FAIL if sta is NULL
- * when initiator is 1, always _SUCCESS
- * when initiator is 0, _SUCCESS if DELBA is acked
+ * issue_del_ba_ex - TX DELBA with xmit ack options
+ * @adapter: the adapter to TX
+ * @ra: receiver address
+ * @tid: tid
+ * @reason: reason code
+ * @initiator: if we are the initiator of AMPDU association. used by DELBA
+ * @try_cnt: the maximal TX count to try
+ * @wait_ms: == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
+ *           > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
  */
-static unsigned int _send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
-	, u8 force, int wait_ack)
+int issue_del_ba_ex(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator
+		    , int try_cnt, int wait_ms)
 {
-	int ret = _SUCCESS;
+	int ret = _FAIL;
+	int i = 0;
+	systime start = rtw_get_current_time();
 
-	if (sta == NULL) {
-		ret = _FAIL;
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(adapter)))
 		goto exit;
-	}
 
-	if (initiator == 0) {
-		/* recipient */
-		if (force || sta->recvreorder_ctrl[tid].enable == _TRUE) {
-			u8 ampdu_size_bak = sta->recvreorder_ctrl[tid].ampdu_size;
+	do {
+		ret = issue_action_ba(adapter, ra, RTW_WLAN_ACTION_DELBA
+				      , tid
+				      , 0 /* unused */
+				      , reason
+				      , initiator
+				      , wait_ms > 0 ? _TRUE : _FALSE
+				     );
 
-			sta->recvreorder_ctrl[tid].enable = _FALSE;
-			sta->recvreorder_ctrl[tid].ampdu_size = RX_AMPDU_SIZE_INVALID;
+		i++;
 
-			if (rtw_del_rx_ampdu_test_trigger_no_tx_fail())
-				ret = _FAIL;
-			else if (wait_ack)
-				ret = issue_del_ba_ex(adapter, sta->hwaddr, tid, 37, initiator, 3, 1);
-			else
-				issue_del_ba(adapter, sta->hwaddr, tid, 37, initiator);
+		if (RTW_CANNOT_RUN(adapter))
+			break;
 
-			if (ret == _FAIL && sta->recvreorder_ctrl[tid].enable == _FALSE)
-				sta->recvreorder_ctrl[tid].ampdu_size = ampdu_size_bak;
-		}
-	} else if (initiator == 1) {
-		/* originator */
-#ifdef CONFIG_80211N_HT
-		if (force || sta->htpriv.agg_enable_bitmap & BIT(tid)) {
-			sta->htpriv.agg_enable_bitmap &= ~BIT(tid);
-			sta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
-			issue_del_ba(adapter, sta->hwaddr, tid, 37, initiator);
-		}
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
+			rtw_msleep_os(wait_ms);
+
+	} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
+
+	if (ret != _FAIL) {
+		ret = _SUCCESS;
+#ifndef DBG_XMIT_ACK
+		/* goto exit; */
 #endif
 	}
 
+	if (try_cnt && wait_ms) {
+		RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" reason=%u, tid=%u, initiator=%u%s, %d/%d in %u ms\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), reason, tid, initiator
+			, ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+	}
 exit:
 	return ret;
 }
 
-inline unsigned int send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
-	, u8 force)
-{
-	return _send_delba_sta_tid(adapter, initiator, sta, tid, force, 0);
-}
-
-inline unsigned int send_delba_sta_tid_wait_ack(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
-	, u8 force)
-{
-	return _send_delba_sta_tid(adapter, initiator, sta, tid, force, 1);
-}
-
-unsigned int send_delba(_adapter *padapter, u8 initiator, u8 *addr)
+void issue_action_BSSCoexistPacket(_adapter *padapter)
 {
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta = NULL;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	_irqL	irqL;
+	_list		*plist, *phead;
+	unsigned char category, action;
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	unsigned char				*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	unsigned short			*fctrl;
+	struct	wlan_network	*pnetwork = NULL;
+	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);
-	u16 tid;
+	_queue		*queue	= &(pmlmepriv->scanned_queue);
+	u8 InfoContent[16] = {0};
+	u8 ICS[8][15];
+#ifdef CONFIG_80211N_HT
+	if ((pmlmepriv->num_FortyMHzIntolerant == 0) || (pmlmepriv->num_sta_no_ht == 0))
+		return;
 
-	if ((pmlmeinfo->state&0x03) != WIFI_FW_AP_STATE)
-		if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
-			return _SUCCESS;
+	if (_TRUE == pmlmeinfo->bwmode_updated)
+		return;
 
-	psta = rtw_get_stainfo(pstapriv, addr);
-	if(psta==NULL)
-		return _SUCCESS;
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		return;
 
-	#if 0
-	DBG_871X("%s:%s\n", __func__, (initiator == 0)?"RX_DIR":"TX_DIR");
-	if (initiator == 1) /* originator */
-		DBG_871X("tx agg_enable_bitmap(0x%08x)\n", psta->htpriv.agg_enable_bitmap);
-	#endif
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	for (tid = 0; tid < TID_NUM; tid++)
-		send_delba_sta_tid(padapter, initiator, psta, tid, 0);
 
-	return _SUCCESS;
-}
+	category = RTW_WLAN_CATEGORY_PUBLIC;
+	action = ACT_PUBLIC_BSSCOEXIST;
 
-unsigned int send_beacon(_adapter *padapter)
-{
-	u8	bxmitok = _FALSE;
-	int	issue=0;
-	int poll = 0;
-#if defined(CONFIG_PCI_HCI) && defined(RTL8814AE_SW_BCN)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-#endif
-//#ifdef CONFIG_CONCURRENT_MODE
-	//struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	//struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	//_adapter *pbuddy_adapter = padapter->pbuddy_adapter;
-	//struct mlme_priv *pbuddy_mlmepriv = &(pbuddy_adapter->mlmepriv);
-//#endif		
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return;
 
-#ifdef CONFIG_PCI_HCI
-	//DBG_871X("%s\n", __FUNCTION__);
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
 
-	rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
-	/* 8192EE Port select for Beacon DL */
-	rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
-	issue_beacon(padapter, 0);
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
 
-#ifdef RTL8814AE_SW_BCN
-	if (pHalData->bCorrectBCN != 0)
-		DBG_871X("%s, line%d, Warnning, pHalData->bCorrectBCN != 0\n", __func__, __LINE__);
-	pHalData->bCorrectBCN = 1;
-#endif
+	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
-	return _SUCCESS;
-#endif
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
-#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	u32 start = rtw_get_current_time();
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
-	rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
-	do{
-		issue_beacon(padapter, 100);
-		issue++;
-		do {
-			rtw_yield_os();
-			rtw_hal_get_hwreg(padapter, HW_VAR_BCN_VALID, (u8 *)(&bxmitok));
-			poll++;
-		} while ((poll%10) != 0 && _FALSE == bxmitok && !RTW_CANNOT_RUN(padapter));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 
-	} while (_FALSE == bxmitok && issue < 100 && !RTW_CANNOT_RUN(padapter));
 
-	if (RTW_CANNOT_RUN(padapter))
-		return _FAIL;
+	/*  */
+	if (pmlmepriv->num_FortyMHzIntolerant > 0) {
+		u8 iedata = 0;
 
-	
-	if(_FALSE == bxmitok)
-	{
-		DBG_871X("%s fail! %u ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
-		return _FAIL;
-	}
-	else
-	{
-		u32 passing_time = rtw_get_passing_time_ms(start);
+		iedata |= BIT(2);/* 20 MHz BSS Width Request */
 
-		if(passing_time > 100 || issue > 3)
-			DBG_871X("%s success, issue:%d, poll:%d, %u ms\n", __FUNCTION__, issue, poll, rtw_get_passing_time_ms(start));
-		//else
-		//	DBG_871X("%s success, issue:%d, poll:%d, %u ms\n", __FUNCTION__, issue, poll, rtw_get_passing_time_ms(start));
-		
-		rtw_hal_fw_correct_bcn(padapter);
+		pframe = rtw_set_ie(pframe, EID_BSSCoexistence,  1, &iedata, &(pattrib->pktlen));
 
-		return _SUCCESS;
 	}
 
-#endif
 
-}
+	/*  */
+	_rtw_memset(ICS, 0, sizeof(ICS));
+	if (pmlmepriv->num_sta_no_ht > 0) {
+		int i;
 
-/****************************************************************************
+		_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-Following are some utitity fuctions for WiFi MLME
+		phead = get_list_head(queue);
+		plist = get_next(phead);
 
-*****************************************************************************/
+		while (1) {
+			int len;
+			u8 *p;
+			WLAN_BSSID_EX *pbss_network;
 
-BOOLEAN IsLegal5GChannel(
-	IN PADAPTER			Adapter,
-	IN 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;
-}
+			if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+				break;
 
-//collect bss info from Beacon and Probe request/response frames.
-u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid)
-{
-	int	i;
-	u32	len;
-	u8	*p;
-	u16	val16, subtype;
-	u8	*pframe = precv_frame->u.hdr.rx_data;
-	u32	packet_len = precv_frame->u.hdr.len;
-	u8 ie_offset;
-	struct registry_priv 	*pregistrypriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+			pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
 
-	len = packet_len - sizeof(struct rtw_ieee80211_hdr_3addr);
+			plist = get_next(plist);
 
-	if (len > MAX_IE_SZ)
-	{
-		//DBG_871X("IE too long for survey event\n");
-		return _FAIL;
-	}
+			pbss_network = (WLAN_BSSID_EX *)&pnetwork->network;
 
-	_rtw_memset(bssid, 0, sizeof(WLAN_BSSID_EX));
+			p = rtw_get_ie(pbss_network->IEs + _FIXED_IE_LENGTH_, _HT_CAPABILITY_IE_, &len, pbss_network->IELength - _FIXED_IE_LENGTH_);
+			if ((p == NULL) || (len == 0)) { /* non-HT */
+				if ((pbss_network->Configuration.DSConfig <= 0) || (pbss_network->Configuration.DSConfig > 14))
+					continue;
 
-	subtype = GetFrameSubType(pframe);
+				ICS[0][pbss_network->Configuration.DSConfig] = 1;
+
+				if (ICS[0][0] == 0)
+					ICS[0][0] = 1;
+			}
 
-	if(subtype==WIFI_BEACON) {
-		bssid->Reserved[0] = 1;
-		ie_offset = _BEACON_IE_OFFSET_;
-	} else {
-		// FIXME : more type
-		if (subtype == WIFI_PROBERSP) {
-			ie_offset = _PROBERSP_IE_OFFSET_;
-			bssid->Reserved[0] = 3;
-		}
-		else if (subtype == WIFI_PROBEREQ) {
-			ie_offset = _PROBEREQ_IE_OFFSET_;
-			bssid->Reserved[0] = 2;
-		}
-		else {
-			bssid->Reserved[0] = 0;
-			ie_offset = _FIXED_IE_LENGTH_;
 		}
-	}
-		
-	bssid->Length = sizeof(WLAN_BSSID_EX) - MAX_IE_SZ + len;
 
-	//below is to copy the information element
-	bssid->IELength = len;
-	_rtw_memcpy(bssid->IEs, (pframe + sizeof(struct rtw_ieee80211_hdr_3addr)), bssid->IELength);
+		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-	//get the signal strength
-	//bssid->Rssi = precv_frame->u.hdr.attrib.SignalStrength; // 0-100 index.
-	bssid->Rssi = precv_frame->u.hdr.attrib.phy_info.RecvSignalPower; // in dBM.raw data	
-	bssid->PhyInfo.SignalQuality = precv_frame->u.hdr.attrib.phy_info.SignalQuality;//in percentage 
-	bssid->PhyInfo.SignalStrength = precv_frame->u.hdr.attrib.phy_info.SignalStrength;//in percentage
-#ifdef CONFIG_ANTENNA_DIVERSITY
-	//rtw_hal_get_hwreg(padapter, HW_VAR_CURRENT_ANTENNA, (u8 *)(&bssid->PhyInfo.Optimum_antenna));
-	rtw_hal_get_def_var(padapter, HAL_DEF_CURRENT_ANTENNA,  &bssid->PhyInfo.Optimum_antenna);
-#endif
 
-	// checking SSID
-	if ((p = rtw_get_ie(bssid->IEs + ie_offset, _SSID_IE_, &len, bssid->IELength - ie_offset)) == NULL)
-	{
-		DBG_871X("marc: cannot find SSID for survey event\n");
-		return _FAIL;
-	}
+		for (i = 0; i < 8; i++) {
+			if (ICS[i][0] == 1) {
+				int j, k = 0;
 
-	if (*(p + 1))
-	{
-		if (len > NDIS_802_11_LENGTH_SSID)
-		{
-			DBG_871X("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
-			return _FAIL;
-		}
-		_rtw_memcpy(bssid->Ssid.Ssid, (p + 2), *(p + 1));
-		bssid->Ssid.SsidLength = *(p + 1);
-	}
-	else
-	{
-		bssid->Ssid.SsidLength = 0;
-	}
+				InfoContent[k] = i;
+				/* SET_BSS_INTOLERANT_ELE_REG_CLASS(InfoContent,i); */
+				k++;
 
-	_rtw_memset(bssid->SupportedRates, 0, NDIS_802_11_LENGTH_RATES_EX);
+				for (j = 1; j <= 14; j++) {
+					if (ICS[i][j] == 1) {
+						if (k < 16) {
+							InfoContent[k] = j; /* channel number */
+							/* SET_BSS_INTOLERANT_ELE_CHANNEL(InfoContent+k, j); */
+							k++;
+						}
+					}
+				}
 
-	//checking rate info...
-	i = 0;
-	p = rtw_get_ie(bssid->IEs + ie_offset, _SUPPORTEDRATES_IE_, &len, bssid->IELength - ie_offset);
-	if (p != NULL)
-	{
-		if (len > NDIS_802_11_LENGTH_RATES_EX)
-		{
-			DBG_871X("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
-			return _FAIL;
-		}
-		_rtw_memcpy(bssid->SupportedRates, (p + 2), len);
-		i = len;
-	}
+				pframe = rtw_set_ie(pframe, EID_BSSIntolerantChlReport, k, InfoContent, &(pattrib->pktlen));
+
+			}
 
-	p = rtw_get_ie(bssid->IEs + ie_offset, _EXT_SUPPORTEDRATES_IE_, &len, bssid->IELength - ie_offset);
-	if (p != NULL)
-	{
-		if (len > (NDIS_802_11_LENGTH_RATES_EX-i))
-		{
-			DBG_871X("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
-			return _FAIL;
 		}
-		_rtw_memcpy(bssid->SupportedRates + i, (p + 2), len);
+
+
 	}
 
-	//todo:
-#if 0
-	if (judge_network_type(bssid->SupportedRates, (len + i)) == WIRELESS_11B)
-	{
-		bssid->NetworkTypeInUse = Ndis802_11DS;
-	}
-	else
-#endif
-	{
-		bssid->NetworkTypeInUse = Ndis802_11OFDM24;
-	}
 
-#ifdef CONFIG_P2P
-	if (subtype == WIFI_PROBEREQ)
-	{
-		u8 *p2p_ie;
-		u32	p2p_ielen;
-		// Set Listion Channel
-		if ((p2p_ie = rtw_get_p2p_ie(bssid->IEs, bssid->IELength, NULL, &p2p_ielen)))
-		{
-			u32	attr_contentlen = 0;
-			u8 listen_ch[5] = { 0x00 };
+	pattrib->last_txcmdsz = pattrib->pktlen;
 
-			rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, listen_ch, &attr_contentlen);
-			bssid->Configuration.DSConfig = listen_ch[4];
-		} else
-		{ // use current channel
-			bssid->Configuration.DSConfig = padapter->mlmeextpriv.cur_channel;
-			DBG_871X("%s()-%d: Cannot get p2p_ie. set DSconfig to op_ch(%d)\n", __FUNCTION__, __LINE__, bssid->Configuration.DSConfig);
-		}
+	dump_mgntframe(padapter, pmgntframe);
+#endif /* CONFIG_80211N_HT */
+}
 
-		// FIXME
-		bssid->InfrastructureMode = Ndis802_11Infrastructure;
-		_rtw_memcpy(bssid->MacAddress, GetAddr2Ptr(pframe), ETH_ALEN);
-		bssid->Privacy = 1;
-		return _SUCCESS;
-	}
-#endif //CONFIG_P2P
+/* Spatial Multiplexing Powersave (SMPS) action frame */
+int _issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode ,  u8 wait_ack)
+{
 
-	if (bssid->IELength < 12)
-		return _FAIL;
+	int ret = _FAIL;
+	unsigned char category = RTW_WLAN_CATEGORY_HT;
+	u8 action = RTW_WLAN_ACTION_HT_SM_PS;
+	u8 sm_power_control = 0;
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	unsigned char					*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	unsigned short				*fctrl;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	// Checking for DSConfig
-	p = rtw_get_ie(bssid->IEs + ie_offset, _DSSET_IE_, &len, bssid->IELength - ie_offset);
 
-	bssid->Configuration.DSConfig = 0;
-	bssid->Configuration.Length = 0;
+	if (NewMimoPsMode == WLAN_HT_CAP_SM_PS_DISABLED) {
+		sm_power_control = sm_power_control  & ~(BIT(0)); /* SM Power Save Enable = 0 SM Power Save Disable */
+	} else if (NewMimoPsMode == WLAN_HT_CAP_SM_PS_STATIC) {
+		sm_power_control = sm_power_control | BIT(0);    /* SM Power Save Enable = 1 SM Power Save Enable  */
+		sm_power_control = sm_power_control & ~(BIT(1)); /* SM Mode = 0 Static Mode */
+	} else if (NewMimoPsMode == WLAN_HT_CAP_SM_PS_DYNAMIC) {
+		sm_power_control = sm_power_control | BIT(0); /* SM Power Save Enable = 1 SM Power Save Enable  */
+		sm_power_control = sm_power_control | BIT(1); /* SM Mode = 1 Dynamic Mode */
+	} else
+		return ret;
 
-	if (p)
-	{
-		bssid->Configuration.DSConfig = *(p + 2);
-	}
-	else
-	{// In 5G, some ap do not have DSSET IE
-		// checking HT info for channel
-		p = rtw_get_ie(bssid->IEs + ie_offset, _HT_ADD_INFO_IE_, &len, bssid->IELength - ie_offset);
-		if(p)
-		{
-			struct HT_info_element *HT_info = (struct HT_info_element *)(p + 2);
-			bssid->Configuration.DSConfig = HT_info->primary_channel;
-		}
-		else
-		{ // use current channel
-			bssid->Configuration.DSConfig = rtw_get_oper_ch(padapter);
-		}
-	}
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		return ret;
 
-	_rtw_memcpy(&bssid->Configuration.BeaconPeriod, rtw_get_beacon_interval_from_ie(bssid->IEs), 2);
-	bssid->Configuration.BeaconPeriod = le32_to_cpu(bssid->Configuration.BeaconPeriod);
+	RTW_INFO("%s, sm_power_control=%u, NewMimoPsMode=%u\n", __FUNCTION__ , sm_power_control , NewMimoPsMode);
 
-	val16 = rtw_get_capability((WLAN_BSSID_EX *)bssid);
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return ret;
 
-	if (val16 & BIT(0))
-	{
-		bssid->InfrastructureMode = Ndis802_11Infrastructure;
-		_rtw_memcpy(bssid->MacAddress, GetAddr2Ptr(pframe), ETH_ALEN);
-	}
-	else
-	{
-		bssid->InfrastructureMode = Ndis802_11IBSS;
-		_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
-	}
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
 
-	if (val16 & BIT(4))
-		bssid->Privacy = 1;
-	else
-		bssid->Privacy = 0;
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
-	bssid->Configuration.ATIMWindow = 0;
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
-	//20/40 BSS Coexistence check
-	if((pregistrypriv->wifi_spec==1) && (_FALSE == pmlmeinfo->bwmode_updated))
-	{	
-		struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-#ifdef CONFIG_80211N_HT
-		p = rtw_get_ie(bssid->IEs + ie_offset, _HT_CAPABILITY_IE_, &len, bssid->IELength - ie_offset);
-		if(p && len>0)
-		{
-			struct HT_caps_element	*pHT_caps;
-			pHT_caps = (struct HT_caps_element	*)(p + 2);
-			
-			if(pHT_caps->u.HT_cap_element.HT_caps_info&BIT(14))
-			{				
-				pmlmepriv->num_FortyMHzIntolerant++;
-			}
-		}
-		else
-		{
-			pmlmepriv->num_sta_no_ht++;
-		}
-#endif //CONFIG_80211N_HT
-		
-	}
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
 
-#ifdef CONFIG_INTEL_WIDI
-	//process_intel_widi_query_or_tigger(padapter, bssid);
-	if(process_intel_widi_query_or_tigger(padapter, bssid))
-	{
-		return _FAIL;
-	}
-#endif // CONFIG_INTEL_WIDI
+	_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN); /* RA */
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN); /* TA */
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN); /* DA = RA */
 
-	#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) & 1
-	if(strcmp(bssid->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
-		DBG_871X("Receiving %s("MAC_FMT", DSConfig:%u) from ch%u with ss:%3u, sq:%3u, RawRSSI:%3ld\n"
-			, bssid->Ssid.Ssid, MAC_ARG(bssid->MacAddress), bssid->Configuration.DSConfig
-			, rtw_get_oper_ch(padapter)
-			, bssid->PhyInfo.SignalStrength, bssid->PhyInfo.SignalQuality, bssid->Rssi
-		);
-	}
-	#endif
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
-	// mark bss info receving from nearby channel as SignalQuality 101
-	if(bssid->Configuration.DSConfig != rtw_get_oper_ch(padapter))
-	{
-		bssid->PhyInfo.SignalQuality= 101;
-	}
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	return _SUCCESS;
-}
+	/* category, action */
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 
-void start_create_ibss(_adapter* padapter)
-{
-	unsigned short	caps;
-	u8	val8;
-	u8	join_type;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
-	u8 doiqk = _FALSE;
-	pmlmeext->cur_channel = (u8)pnetwork->Configuration.DSConfig;
-	pmlmeinfo->bcn_interval = get_beacon_interval(pnetwork);
+	pframe = rtw_set_fixed_ie(pframe, 1, &(sm_power_control), &(pattrib->pktlen));
 
-	//update wireless mode
-	update_wireless_mode(padapter);
+	pattrib->last_txcmdsz = pattrib->pktlen;
 
-	//udpate capability
-	caps = rtw_get_capability((WLAN_BSSID_EX *)pnetwork);
-	update_capinfo(padapter, caps);
-	if(caps&cap_IBSS)//adhoc master
-	{
-		//set_opmode_cmd(padapter, adhoc);//removed
+	if (wait_ack)
+		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
+	else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
 
-		val8 = 0xcf;
-		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+	if (ret != _SUCCESS)
+		RTW_INFO("%s, ack to\n", __func__);
 
-		doiqk = _TRUE;
-		rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+	return ret;
+}
 
-		//switch channel
-		set_channel_bwmode(padapter, pmlmeext->cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+/*
+ * wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
+ * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
+ * try_cnt means the maximal TX count to try
+ */
+int issue_action_SM_PS_wait_ack(_adapter *padapter, unsigned char *raddr, u8 NewMimoPsMode, int try_cnt, int wait_ms)
+{
+	int ret = _FAIL;
+	int i = 0;
+	systime start = rtw_get_current_time();
 
-		doiqk = _FALSE;
-		rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+		goto exit;
 
-		beacon_timing_control(padapter);
+	do {
+		ret = _issue_action_SM_PS(padapter, raddr, NewMimoPsMode , wait_ms > 0 ? _TRUE : _FALSE);
 
-		//set msr to WIFI_FW_ADHOC_STATE
-		pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
-		Set_MSR(padapter, (pmlmeinfo->state & 0x3));
+		i++;
 
-		//issue beacon
-		if(send_beacon(padapter)==_FAIL)
-		{
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_err_,("issuing beacon frame fail....\n"));
+		if (RTW_CANNOT_RUN(padapter))
+			break;
 
-			report_join_res(padapter, -1);
-			pmlmeinfo->state = WIFI_FW_NULL_STATE;
-		}
-		else
-		{
-			rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, padapter->registrypriv.dev_network.MacAddress);
-			join_type = 0;
-			rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
+			rtw_msleep_os(wait_ms);
 
-			report_join_res(padapter, 1);
-			pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
-			rtw_indicate_connect(padapter);
-		}
+	} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
+
+	if (ret != _FAIL) {
+		ret = _SUCCESS;
+#ifndef DBG_XMIT_ACK
+		goto exit;
+#endif
 	}
-	else
-	{
-		DBG_871X("start_create_ibss, invalid cap:%x\n", caps);
-		return;
+
+	if (try_cnt && wait_ms) {
+		if (raddr)
+			RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", %s , %d/%d in %u ms\n",
+				 FUNC_ADPT_ARG(padapter), MAC_ARG(raddr),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+		else
+			RTW_INFO(FUNC_ADPT_FMT", %s , %d/%d in %u ms\n",
+				 FUNC_ADPT_ARG(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
 	}
-	//update bc/mc sta_info
-	update_bmc_sta(padapter);
+exit:
 
+	return ret;
 }
 
-void start_clnt_join(_adapter* padapter)
+int issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode)
 {
-	unsigned short	caps;
-	u8	val8;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
-	int beacon_timeout;
-	u8 ASIX_ID[]= {0x00, 0x0E, 0xC6};
+	RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(raddr));
+	return _issue_action_SM_PS(padapter, raddr, NewMimoPsMode , _FALSE);
+}
 
-	//update wireless mode
-	update_wireless_mode(padapter);
+/**
+ * _send_delba_sta_tid - Cancel the AMPDU association for the specific @sta, @tid
+ * @adapter: the adapter to which @sta belongs
+ * @initiator: if we are the initiator of AMPDU association
+ * @sta: the sta to be checked
+ * @tid: the tid to be checked
+ * @force: cancel and send DELBA even when no AMPDU association is setup
+ * @wait_ack: send delba with xmit ack (valid when initiator == 0)
+ *
+ * Returns:
+ * _FAIL if sta is NULL
+ * when initiator is 1, always _SUCCESS
+ * when initiator is 0, _SUCCESS if DELBA is acked
+ */
+static unsigned int _send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
+					, u8 force, int wait_ack)
+{
+	int ret = _SUCCESS;
 
-	//udpate capability
-	caps = rtw_get_capability((WLAN_BSSID_EX *)pnetwork);
-	update_capinfo(padapter, caps);
-	
-	//check if sta is ASIX peer and fix IOT issue if it is.
-	if (_rtw_memcmp(get_my_bssid(&pmlmeinfo->network) ,ASIX_ID ,3)) {
-		u8 iot_flag = _TRUE;
-		rtw_hal_set_hwreg(padapter, HW_VAR_ASIX_IOT, (u8 *)(&iot_flag));
+	if (sta == NULL) {
+		ret = _FAIL;
+		goto exit;
 	}
-	
-	if (caps&cap_ESS)
-	{
-		Set_MSR(padapter, WIFI_FW_STATION_STATE);
 
-		val8 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X)? 0xcc: 0xcf;
+	if (initiator == 0) {
+		/* recipient */
+		if (force || sta->recvreorder_ctrl[tid].enable == _TRUE) {
+			u8 ampdu_size_bak = sta->recvreorder_ctrl[tid].ampdu_size;
 
-#ifdef CONFIG_WAPI_SUPPORT
-		if (padapter->wapiInfo.bWapiEnable && pmlmeinfo->auth_algo == dot11AuthAlgrthm_WAPI)
-		{
-			//Disable TxUseDefaultKey, RxUseDefaultKey, RxBroadcastUseDefaultKey.
-			val8 = 0x4c;
-		}
-#endif
-		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+			sta->recvreorder_ctrl[tid].enable = _FALSE;
+			sta->recvreorder_ctrl[tid].ampdu_size = RX_AMPDU_SIZE_INVALID;
 
-		#ifdef CONFIG_DEAUTH_BEFORE_CONNECT
-		// 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
+			if (rtw_del_rx_ampdu_test_trigger_no_tx_fail())
+				ret = _FAIL;
+			else if (wait_ack)
+				ret = issue_del_ba_ex(adapter, sta->cmn.mac_addr, tid, 37, initiator, 3, 1);
+			else
+				issue_del_ba(adapter, sta->cmn.mac_addr, tid, 37, initiator);
 
-		//	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.
-		{
-			#ifdef CONFIG_P2P
-			_queue *queue = &(padapter->mlmepriv.scanned_queue);
-			_list	*head = get_list_head(queue);
-			_list *pos = get_next(head);
-			struct wlan_network *scanned = NULL;
-			u8 ie_offset = 0;
-			_irqL irqL;
-			bool has_p2p_ie = _FALSE;
-
-			_enter_critical_bh(&(padapter->mlmepriv.scanned_queue.lock), &irqL);
+			if (ret == _FAIL && sta->recvreorder_ctrl[tid].enable == _FALSE)
+				sta->recvreorder_ctrl[tid].ampdu_size = ampdu_size_bak;
+		}
+	} else if (initiator == 1) {
+		/* originator */
+#ifdef CONFIG_80211N_HT
+		if (force || sta->htpriv.agg_enable_bitmap & BIT(tid)) {
+			sta->htpriv.agg_enable_bitmap &= ~BIT(tid);
+			sta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
+			issue_del_ba(adapter, sta->cmn.mac_addr, tid, 37, initiator);
+		}
+#endif
+	}
 
-			for (pos = get_next(head);!rtw_end_of_queue_search(head, pos); pos = get_next(pos)) {
-				
-				scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
+exit:
+	return ret;
+}
 
-				if (_rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
-					&& _rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
-				) {
-					ie_offset = (scanned->network.Reserved[0] == 2? 0:12);
-					if (rtw_get_p2p_ie(scanned->network.IEs+ie_offset, scanned->network.IELength-ie_offset, NULL, NULL))
-						has_p2p_ie = _TRUE;
-					break;
-				}
-			}
-	
-			_exit_critical_bh(&(padapter->mlmepriv.scanned_queue.lock), &irqL);
+inline unsigned int send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
+				       , u8 force)
+{
+	return _send_delba_sta_tid(adapter, initiator, sta, tid, force, 0);
+}
 
-			if (scanned == NULL || rtw_end_of_queue_search(head, pos) || has_p2p_ie == _FALSE)
-			#endif /* CONFIG_P2P */
-				//To avoid connecting to AP fail during resume process, change retry count from 5 to 1
-				issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
-		}
-		#endif /* CONFIG_DEAUTH_BEFORE_CONNECT */
+inline unsigned int send_delba_sta_tid_wait_ack(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
+		, u8 force)
+{
+	return _send_delba_sta_tid(adapter, initiator, sta, tid, force, 1);
+}
 
-		//here wait for receiving the beacon to start auth
-		//and enable a timer
-		beacon_timeout = decide_wait_for_beacon_timeout(pmlmeinfo->bcn_interval);
-		set_link_timer(pmlmeext, beacon_timeout);	
-		_set_timer( &padapter->mlmepriv.assoc_timer, 
-			(REAUTH_TO * REAUTH_LIMIT) + (REASSOC_TO*REASSOC_LIMIT) +beacon_timeout);
-		
-		pmlmeinfo->state = WIFI_FW_AUTH_NULL | WIFI_FW_STATION_STATE;
-	}
-	else if (caps&cap_IBSS) //adhoc client
-	{
-		Set_MSR(padapter, WIFI_FW_ADHOC_STATE);
+unsigned int send_delba(_adapter *padapter, u8 initiator, u8 *addr)
+{
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta = NULL;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u16 tid;
 
-		val8 = 0xcf;
-		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+	if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
+		if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
+			return _SUCCESS;
 
-		beacon_timing_control(padapter);
+	psta = rtw_get_stainfo(pstapriv, addr);
+	if (psta == NULL)
+		return _SUCCESS;
 
-		pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
+#if 0
+	RTW_INFO("%s:%s\n", __func__, (initiator == 0) ? "RX_DIR" : "TX_DIR");
+	if (initiator == 1) /* originator */
+		RTW_INFO("tx agg_enable_bitmap(0x%08x)\n", psta->htpriv.agg_enable_bitmap);
+#endif
 
-		report_join_res(padapter, 1);
-	}
-	else
-	{
-		//DBG_871X("marc: invalid cap:%x\n", caps);
-		return;
-	}
+	for (tid = 0; tid < TID_NUM; tid++)
+		send_delba_sta_tid(padapter, initiator, psta, tid, 0);
 
+	return _SUCCESS;
 }
 
-void start_clnt_auth(_adapter* padapter)
+unsigned int send_beacon(_adapter *padapter)
 {
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	bxmitok = _FALSE;
+	int	issue = 0;
+	int poll = 0;
+#if defined(CONFIG_PCI_HCI) && defined(RTL8814AE_SW_BCN)
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+#endif
 
-	_cancel_timer_ex(&pmlmeext->link_timer);
+#ifdef CONFIG_PCI_HCI
+	/* bypass TX BCN queue because op ch is switching/waiting */
+	if (check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
+		|| IS_CH_WAITING(adapter_to_rfctl(padapter))
+	)
+		return _SUCCESS;
 
-	pmlmeinfo->state &= (~WIFI_FW_AUTH_NULL);
-	pmlmeinfo->state |= WIFI_FW_AUTH_STATE;
+	/* RTW_INFO("%s\n", __FUNCTION__); */
 
-	pmlmeinfo->auth_seq = 1;
-	pmlmeinfo->reauth_count = 0;
-	pmlmeinfo->reassoc_count = 0;
-	pmlmeinfo->link_count = 0;
-	pmlmeext->retry = 0;
+	rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
 
+	/* 8192EE Port select for Beacon DL */
+	rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
 
-	DBG_871X_LEVEL(_drv_always_, "start auth\n");
-	issue_auth(padapter, NULL, 0);
+	issue_beacon(padapter, 0);
 
-	set_link_timer(pmlmeext, REAUTH_TO);
+#ifdef RTL8814AE_SW_BCN
+	if (pHalData->bCorrectBCN != 0)
+		RTW_INFO("%s, line%d, Warnning, pHalData->bCorrectBCN != 0\n", __func__, __LINE__);
+	pHalData->bCorrectBCN = 1;
+#endif
 
-}
+	return _SUCCESS;
+#endif
 
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	systime start = rtw_get_current_time();
 
-void start_clnt_assoc(_adapter* padapter)
-{
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	/* bypass TX BCN queue because op ch is switching/waiting */
+	if (check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
+		|| IS_CH_WAITING(adapter_to_rfctl(padapter))
+	)
+		return _SUCCESS;
 
-	_cancel_timer_ex(&pmlmeext->link_timer);
+#if defined(CONFIG_USB_HCI)
+#if defined(CONFIG_RTL8812A)
+	if (IS_FULL_SPEED_USB(padapter)) {
+		issue_beacon(padapter, 300);
+		bxmitok = _TRUE;
+	} else
+#endif
+#endif
+	{
+		rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
+		rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
+		do {
+			issue_beacon(padapter, 100);
+			issue++;
+			do {
+				rtw_yield_os();
+				rtw_hal_get_hwreg(padapter, HW_VAR_BCN_VALID, (u8 *)(&bxmitok));
+				poll++;
+			} while ((poll % 10) != 0 && _FALSE == bxmitok && !RTW_CANNOT_RUN(padapter));
 
-	pmlmeinfo->state &= (~(WIFI_FW_AUTH_NULL | WIFI_FW_AUTH_STATE));
-	pmlmeinfo->state |= (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE);
+		} while (bxmitok == _FALSE && (issue < 100) && !RTW_CANNOT_RUN(padapter));
+	}
+	if (RTW_CANNOT_RUN(padapter))
+		return _FAIL;
 
-	issue_assocreq(padapter);
 
-	set_link_timer(pmlmeext, REASSOC_TO);
-}
+	if (_FALSE == bxmitok) {
+		RTW_INFO("%s fail! %u ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
+		#ifdef CONFIG_BCN_RECOVERY
+		GET_HAL_DATA(padapter)->issue_bcn_fail++;
+		#endif  /*CONFIG_BCN_RECOVERY*/
+		return _FAIL;
+	} else {
+		u32 passing_time = rtw_get_passing_time_ms(start);
 
-unsigned int receive_disconnect(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, u8 locally_generated)
-{
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+		if (passing_time > 100 || issue > 3)
+			RTW_INFO("%s success, issue:%d, poll:%d, %u ms\n", __FUNCTION__, issue, poll, rtw_get_passing_time_ms(start));
+		else if (0)
+			RTW_INFO("%s success, issue:%d, poll:%d, %u ms\n", __FUNCTION__, issue, poll, rtw_get_passing_time_ms(start));
+
+		rtw_hal_fw_correct_bcn(padapter);
 
-	if (!(_rtw_memcmp(MacAddr, get_my_bssid(&pmlmeinfo->network), ETH_ALEN)))
 		return _SUCCESS;
+	}
 
-	DBG_871X("%s\n", __FUNCTION__);
+#endif
 
-	if((pmlmeinfo->state&0x03) == WIFI_FW_STATION_STATE)
-	{
-		if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-		{
-			pmlmeinfo->state = WIFI_FW_NULL_STATE;
-			report_del_sta_event(padapter, MacAddr, reason, _TRUE, locally_generated);
+}
 
-		}
-		else if (pmlmeinfo->state & WIFI_FW_LINKING_STATE)
-		{
-			pmlmeinfo->state = WIFI_FW_NULL_STATE;
-			report_join_res(padapter, -2);
-		} else
-			DBG_871X(FUNC_ADPT_FMT" - End to Disconnect\n", FUNC_ADPT_ARG(padapter));
-	}
+/****************************************************************************
 
-	return _SUCCESS;
+Following are some utitity fuctions for WiFi MLME
+
+*****************************************************************************/
+
+BOOLEAN IsLegal5GChannel(
+	IN PADAPTER			Adapter,
+	IN 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;
 }
 
-#ifdef CONFIG_80211D
-static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)
+/* collect bss info from Beacon and Probe request/response frames. */
+u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid)
 {
-	struct registry_priv *pregistrypriv;
-	struct mlme_ext_priv *pmlmeext;
-	RT_CHANNEL_INFO *chplan_new;
-	u8 channel;
-	u8 i;
+	int	i;
+	sint len;
+	u8	*p;
+	u8	rf_path;
+	u16	val16, subtype;
+	u8	*pframe = precv_frame->u.hdr.rx_data;
+	u32	packet_len = precv_frame->u.hdr.len;
+	u8 ie_offset;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 
-	pregistrypriv = &padapter->registrypriv;
-	pmlmeext = &padapter->mlmeextpriv;
+	len = packet_len - sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	// Adjust channel plan by AP Country IE
-	if (pregistrypriv->enable80211d &&
-		(!pmlmeext->update_channel_plan_by_ap_done))
-	{
-		u8 *ie, *p;
-		u32 len;
-		RT_CHANNEL_PLAN chplan_ap;
-		RT_CHANNEL_INFO chplan_sta[MAX_CHANNEL_NUM];
-		u8 country[4];
-		u8 fcn; // first channel number
-		u8 noc; // number of channel
-		u8 j, k;
+	if (len > MAX_IE_SZ) {
+		/* RTW_INFO("IE too long for survey event\n"); */
+		return _FAIL;
+	}
 
-		ie = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _COUNTRY_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-		if (!ie) return;
-		if (len < 6) return;
+	_rtw_memset(bssid, 0, sizeof(WLAN_BSSID_EX));
 
-		ie += 2;
-		p = ie;
-		ie += len;
+	subtype = get_frame_sub_type(pframe);
 
-		_rtw_memset(country, 0, 4);
-		_rtw_memcpy(country, p, 3);
-		p += 3;
-		RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-				("%s: 802.11d country=%s\n", __FUNCTION__, country));
+	if (subtype == WIFI_BEACON) {
+		bssid->Reserved[0] = BSS_TYPE_BCN;
+		ie_offset = _BEACON_IE_OFFSET_;
+	} else {
+		/* FIXME : more type */
+		if (subtype == WIFI_PROBERSP) {
+			ie_offset = _PROBERSP_IE_OFFSET_;
+			bssid->Reserved[0] = BSS_TYPE_PROB_RSP;
+		} else if (subtype == WIFI_PROBEREQ) {
+			ie_offset = _PROBEREQ_IE_OFFSET_;
+			bssid->Reserved[0] = BSS_TYPE_PROB_REQ;
+		} else {
+			bssid->Reserved[0] = BSS_TYPE_UNDEF;
+			ie_offset = _FIXED_IE_LENGTH_;
+		}
+	}
 
-		i = 0;
-		while ((ie - p) >= 3)
-		{
-			fcn = *(p++);
-			noc = *(p++);
-			p++;
+	bssid->Length = sizeof(WLAN_BSSID_EX) - MAX_IE_SZ + len;
 
-			for (j = 0; j < noc; j++)
-			{
-				if (fcn <= 14) channel = fcn + j; // 2.4 GHz
-				else channel = fcn + j*4; // 5 GHz
+	/* below is to copy the information element */
+	bssid->IELength = len;
+	_rtw_memcpy(bssid->IEs, (pframe + sizeof(struct rtw_ieee80211_hdr_3addr)), bssid->IELength);
 
-				chplan_ap.Channel[i++] = channel;
-			}
-		}
-		chplan_ap.Len = i;
+	/* get the signal strength */
+	/* bssid->Rssi = precv_frame->u.hdr.attrib.SignalStrength; */ /* 0-100 index. */
+	bssid->Rssi = precv_frame->u.hdr.attrib.phy_info.recv_signal_power; /* in dBM.raw data */
+	bssid->PhyInfo.SignalQuality = precv_frame->u.hdr.attrib.phy_info.signal_quality;/* in percentage */
+	bssid->PhyInfo.SignalStrength = precv_frame->u.hdr.attrib.phy_info.signal_strength;/* in percentage */
+
+	/* get rx_snr */
+	if (precv_frame->u.hdr.attrib.data_rate >= DESC_RATE11M) {
+		bssid->PhyInfo.is_cck_rate = 0;
+		for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++)
+			bssid->PhyInfo.rx_snr[rf_path] =
+				precv_frame->u.hdr.attrib.phy_info.rx_snr[rf_path];
+	} else
+		bssid->PhyInfo.is_cck_rate = 1;
 
-#ifdef CONFIG_DEBUG_RTL871X
-		i = 0;
-		DBG_871X("%s: AP[%s] channel plan {", __FUNCTION__, bssid->Ssid.Ssid);
-		while ((i < chplan_ap.Len) && (chplan_ap.Channel[i] != 0))
-		{
-			DBG_8192C("%02d,", chplan_ap.Channel[i]);
-			i++;
-		}
-		DBG_871X("}\n");
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	rtw_hal_get_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &(bssid->PhyInfo.Optimum_antenna), NULL);
 #endif
 
-		_rtw_memcpy(chplan_sta, pmlmeext->channel_set, sizeof(chplan_sta));
-#ifdef CONFIG_DEBUG_RTL871X
-		i = 0;
-		DBG_871X("%s: STA channel plan {", __FUNCTION__);
-		while ((i < MAX_CHANNEL_NUM) && (chplan_sta[i].ChannelNum != 0))
-		{
-			DBG_871X("%02d(%c),", chplan_sta[i].ChannelNum, chplan_sta[i].ScanType==SCAN_PASSIVE?'p':'a');
-			i++;
+	/* checking SSID */
+	p = rtw_get_ie(bssid->IEs + ie_offset, _SSID_IE_, &len, bssid->IELength - ie_offset);
+	if (p == NULL) {
+		RTW_INFO("marc: cannot find SSID for survey event\n");
+		return _FAIL;
+	}
+
+	if (*(p + 1)) {
+		if (len > NDIS_802_11_LENGTH_SSID) {
+			RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
+			return _FAIL;
 		}
-		DBG_871X("}\n");
-#endif
+		_rtw_memcpy(bssid->Ssid.Ssid, (p + 2), *(p + 1));
+		bssid->Ssid.SsidLength = *(p + 1);
+	} else
+		bssid->Ssid.SsidLength = 0;
 
-		_rtw_memset(pmlmeext->channel_set, 0, sizeof(pmlmeext->channel_set));
-		chplan_new = pmlmeext->channel_set;
+	_rtw_memset(bssid->SupportedRates, 0, NDIS_802_11_LENGTH_RATES_EX);
 
-		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;
+	/* checking rate info... */
+	i = 0;
+	p = rtw_get_ie(bssid->IEs + ie_offset, _SUPPORTEDRATES_IE_, &len, bssid->IELength - ie_offset);
+	if (p != NULL) {
+		if (len > NDIS_802_11_LENGTH_RATES_EX) {
+			RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
+			return _FAIL;
+		}
+		_rtw_memcpy(bssid->SupportedRates, (p + 2), len);
+		i = len;
+	}
 
-				if ((j == chplan_ap.Len) || (chplan_ap.Channel[j] > 14))
-					break;
+	p = rtw_get_ie(bssid->IEs + ie_offset, _EXT_SUPPORTEDRATES_IE_, &len, bssid->IELength - ie_offset);
+	if (p != NULL) {
+		if (len > (NDIS_802_11_LENGTH_RATES_EX - i)) {
+			RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
+			return _FAIL;
+		}
+		_rtw_memcpy(bssid->SupportedRates + i, (p + 2), len);
+	}
 
-				if (chplan_sta[i].ChannelNum == chplan_ap.Channel[j])
-				{
-					chplan_new[k].ChannelNum = chplan_ap.Channel[j];
+	/* todo: */
+#if 0
+	if (judge_network_type(bssid->SupportedRates, (len + i)) == WIRELESS_11B)
+		bssid->NetworkTypeInUse = Ndis802_11DS;
+	else
+#endif
+	{
+		bssid->NetworkTypeInUse = Ndis802_11OFDM24;
+	}
+
+#ifdef CONFIG_P2P
+	if (subtype == WIFI_PROBEREQ) {
+		u8 *p2p_ie;
+		u32	p2p_ielen;
+		/* Set Listion Channel */
+		p2p_ie = rtw_get_p2p_ie(bssid->IEs, bssid->IELength, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			u32	attr_contentlen = 0;
+			u8 listen_ch[5] = { 0x00 };
+
+			rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, listen_ch, &attr_contentlen);
+			bssid->Configuration.DSConfig = listen_ch[4];
+		} else {
+			/* use current channel */
+			bssid->Configuration.DSConfig = padapter->mlmeextpriv.cur_channel;
+			RTW_INFO("%s()-%d: Cannot get p2p_ie. set DSconfig to op_ch(%d)\n", __FUNCTION__, __LINE__, bssid->Configuration.DSConfig);
+		}
+
+		/* FIXME */
+		bssid->InfrastructureMode = Ndis802_11Infrastructure;
+		_rtw_memcpy(bssid->MacAddress, get_addr2_ptr(pframe), ETH_ALEN);
+		bssid->Privacy = 1;
+		return _SUCCESS;
+	}
+#endif /* CONFIG_P2P */
+
+	if (bssid->IELength < 12)
+		return _FAIL;
+
+	/* Checking for DSConfig */
+	p = rtw_get_ie(bssid->IEs + ie_offset, _DSSET_IE_, &len, bssid->IELength - ie_offset);
+
+	bssid->Configuration.DSConfig = 0;
+	bssid->Configuration.Length = 0;
+
+	if (p)
+		bssid->Configuration.DSConfig = *(p + 2);
+	else {
+		/* In 5G, some ap do not have DSSET IE */
+		/* checking HT info for channel */
+		p = rtw_get_ie(bssid->IEs + ie_offset, _HT_ADD_INFO_IE_, &len, bssid->IELength - ie_offset);
+		if (p) {
+			struct HT_info_element *HT_info = (struct HT_info_element *)(p + 2);
+			bssid->Configuration.DSConfig = HT_info->primary_channel;
+		} else {
+			/* use current channel */
+			bssid->Configuration.DSConfig = rtw_get_oper_ch(padapter);
+		}
+	}
+
+	_rtw_memcpy(&bssid->Configuration.BeaconPeriod, rtw_get_beacon_interval_from_ie(bssid->IEs), 2);
+	bssid->Configuration.BeaconPeriod = le32_to_cpu(bssid->Configuration.BeaconPeriod);
+
+	val16 = rtw_get_capability((WLAN_BSSID_EX *)bssid);
+
+	if ((val16 & 0x03) == cap_ESS) {
+		bssid->InfrastructureMode = Ndis802_11Infrastructure;
+		_rtw_memcpy(bssid->MacAddress, get_addr2_ptr(pframe), ETH_ALEN);
+	} else if ((val16 & 0x03) == cap_IBSS){
+		bssid->InfrastructureMode = Ndis802_11IBSS;
+		_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
+	} else if ((val16 & 0x03) == 0x00){
+		u8 *mesh_id_ie, *mesh_conf_ie;
+		sint mesh_id_ie_len, mesh_conf_ie_len;
+
+		mesh_id_ie = rtw_get_ie(bssid->IEs + ie_offset, WLAN_EID_MESH_ID, &mesh_id_ie_len, bssid->IELength - ie_offset);
+		mesh_conf_ie = rtw_get_ie(bssid->IEs + ie_offset, WLAN_EID_MESH_CONFIG, &mesh_conf_ie_len, bssid->IELength - ie_offset);
+		if (mesh_id_ie || mesh_conf_ie) {
+			if (!mesh_id_ie) {
+				RTW_INFO("cannot find Mesh ID for survey event\n");
+				return _FAIL;
+			}
+			if (mesh_id_ie_len) {
+				if (mesh_id_ie_len > NDIS_802_11_LENGTH_SSID) {
+					RTW_INFO("Mesh ID too long (%d) for survey event\n", mesh_id_ie_len);
+					return _FAIL;
+				}
+				_rtw_memcpy(bssid->mesh_id.Ssid, (mesh_id_ie + 2), mesh_id_ie_len);
+				bssid->mesh_id.SsidLength = mesh_id_ie_len;
+			} else
+				bssid->mesh_id.SsidLength = 0;
+
+			if (!mesh_conf_ie) {
+				RTW_INFO("cannot find Mesh config for survey event\n");
+				return _FAIL;
+			}
+			if (mesh_conf_ie_len != 7) {
+				RTW_INFO("invalid Mesh conf IE len (%d) for survey event\n", mesh_conf_ie_len);
+				return _FAIL;
+			}
+
+			bssid->InfrastructureMode = Ndis802_11_mesh;
+			_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
+		} else {
+			/* default cases */
+			bssid->InfrastructureMode = Ndis802_11IBSS;
+			_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
+		}
+	}
+
+	if (val16 & BIT(4))
+		bssid->Privacy = 1;
+	else
+		bssid->Privacy = 0;
+
+	bssid->Configuration.ATIMWindow = 0;
+
+	/* 20/40 BSS Coexistence check */
+	if ((pregistrypriv->wifi_spec == 1) && (_FALSE == pmlmeinfo->bwmode_updated)) {
+		struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+#ifdef CONFIG_80211N_HT
+		p = rtw_get_ie(bssid->IEs + ie_offset, _HT_CAPABILITY_IE_, &len, bssid->IELength - ie_offset);
+		if (p && len > 0) {
+			struct HT_caps_element	*pHT_caps;
+			pHT_caps = (struct HT_caps_element *)(p + 2);
+
+			if (pHT_caps->u.HT_cap_element.HT_caps_info & BIT(14))
+				pmlmepriv->num_FortyMHzIntolerant++;
+		} else
+			pmlmepriv->num_sta_no_ht++;
+#endif /* CONFIG_80211N_HT */
+
+	}
+
+#ifdef CONFIG_INTEL_WIDI
+	/* process_intel_widi_query_or_tigger(padapter, bssid); */
+	if (process_intel_widi_query_or_tigger(padapter, bssid))
+		return _FAIL;
+#endif /* CONFIG_INTEL_WIDI */
+
+#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) & 1
+	if (strcmp(bssid->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
+		RTW_INFO("Receiving %s("MAC_FMT", DSConfig:%u) from ch%u with ss:%3u, sq:%3u, RawRSSI:%3ld\n"
+			, bssid->Ssid.Ssid, MAC_ARG(bssid->MacAddress), bssid->Configuration.DSConfig
+			 , rtw_get_oper_ch(padapter)
+			, bssid->PhyInfo.SignalStrength, bssid->PhyInfo.SignalQuality, bssid->Rssi
+			);
+	}
+#endif
+
+	/* mark bss info receving from nearby channel as SignalQuality 101 */
+	if (bssid->Configuration.DSConfig != rtw_get_oper_ch(padapter))
+		bssid->PhyInfo.SignalQuality = 101;
+
+#ifdef CONFIG_RTW_80211K
+	p = rtw_get_ie(bssid->IEs + ie_offset, _EID_RRM_EN_CAP_IE_, &len, bssid->IELength - ie_offset);
+	if (p)
+		_rtw_memcpy(bssid->PhyInfo.rm_en_cap, (p + 2), *(p + 1));
+
+	/* save freerun counter */
+	bssid->PhyInfo.free_cnt = precv_frame->u.hdr.attrib.free_cnt;
+#endif
+	return _SUCCESS;
+}
+
+void start_create_ibss(_adapter *padapter)
+{
+	unsigned short	caps;
+	u8	val8;
+	u8	join_type;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+	u8 doiqk = _FALSE;
+	pmlmeext->cur_channel = (u8)pnetwork->Configuration.DSConfig;
+	pmlmeinfo->bcn_interval = get_beacon_interval(pnetwork);
+
+	/* update wireless mode */
+	update_wireless_mode(padapter);
+
+	/* udpate capability */
+	caps = rtw_get_capability((WLAN_BSSID_EX *)pnetwork);
+	update_capinfo(padapter, caps);
+	if (caps & cap_IBSS) { /* adhoc master */
+		/* set_opmode_cmd(padapter, adhoc); */ /* removed */
+
+		val8 = 0xcf;
+		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+
+		doiqk = _TRUE;
+		rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+
+		/* switch channel */
+		set_channel_bwmode(padapter, pmlmeext->cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+
+		doiqk = _FALSE;
+		rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+
+		beacon_timing_control(padapter);
+
+		/* set msr to WIFI_FW_ADHOC_STATE */
+		pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
+		Set_MSR(padapter, (pmlmeinfo->state & 0x3));
+
+		/* issue beacon */
+		if (send_beacon(padapter) == _FAIL) {
+
+			report_join_res(padapter, -1, WLAN_STATUS_UNSPECIFIED_FAILURE);
+			pmlmeinfo->state = WIFI_FW_NULL_STATE;
+		} else {
+			rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, padapter->registrypriv.dev_network.MacAddress);
+			join_type = 0;
+			rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+			rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
+
+			report_join_res(padapter, 1, WLAN_STATUS_SUCCESS);
+			pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
+			rtw_indicate_connect(padapter);
+		}
+	} else {
+		RTW_INFO("start_create_ibss, invalid cap:%x\n", caps);
+		return;
+	}
+	/* update bc/mc sta_info */
+	update_bmc_sta(padapter);
+
+}
+
+void start_clnt_join(_adapter *padapter)
+{
+	unsigned short	caps;
+	u8	val8;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+	int beacon_timeout;
+	u8 ASIX_ID[] = {0x00, 0x0E, 0xC6};
+
+	/* update wireless mode */
+	update_wireless_mode(padapter);
+
+	/* udpate capability */
+	caps = rtw_get_capability((WLAN_BSSID_EX *)pnetwork);
+	update_capinfo(padapter, caps);
+
+	/* check if sta is ASIX peer and fix IOT issue if it is. */
+	if (_rtw_memcmp(get_my_bssid(&pmlmeinfo->network) , ASIX_ID , 3)) {
+		u8 iot_flag = _TRUE;
+		rtw_hal_set_hwreg(padapter, HW_VAR_ASIX_IOT, (u8 *)(&iot_flag));
+	}
+
+	if (caps & cap_ESS) {
+		Set_MSR(padapter, WIFI_FW_STATION_STATE);
+
+		val8 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X) ? 0xcc : 0xcf;
+
+#ifdef CONFIG_WAPI_SUPPORT
+		if (padapter->wapiInfo.bWapiEnable && pmlmeinfo->auth_algo == dot11AuthAlgrthm_WAPI) {
+			/* Disable TxUseDefaultKey, RxUseDefaultKey, RxBroadcastUseDefaultKey. */
+			val8 = 0x4c;
+		}
+#endif
+		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+
+#ifdef CONFIG_DEAUTH_BEFORE_CONNECT
+		/* 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. */
+		{
+#ifdef CONFIG_P2P
+			_queue *queue = &(padapter->mlmepriv.scanned_queue);
+			_list	*head = get_list_head(queue);
+			_list *pos = get_next(head);
+			struct wlan_network *scanned = NULL;
+			u8 ie_offset = 0;
+			_irqL irqL;
+			bool has_p2p_ie = _FALSE;
+
+			_enter_critical_bh(&(padapter->mlmepriv.scanned_queue.lock), &irqL);
+
+			for (pos = get_next(head); !rtw_end_of_queue_search(head, pos); pos = get_next(pos)) {
+
+				scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
+
+				if (_rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
+				    && _rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
+				   ) {
+					ie_offset = (scanned->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12);
+					if (rtw_get_p2p_ie(scanned->network.IEs + ie_offset, scanned->network.IELength - ie_offset, NULL, NULL))
+						has_p2p_ie = _TRUE;
+					break;
+				}
+			}
+
+			_exit_critical_bh(&(padapter->mlmepriv.scanned_queue.lock), &irqL);
+
+			if (scanned == NULL || rtw_end_of_queue_search(head, pos) || has_p2p_ie == _FALSE)
+#endif /* CONFIG_P2P */
+				/* To avoid connecting to AP fail during resume process, change retry count from 5 to 1 */
+				issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
+		}
+#endif /* CONFIG_DEAUTH_BEFORE_CONNECT */
+
+		/* here wait for receiving the beacon to start auth */
+		/* and enable a timer */
+		beacon_timeout = decide_wait_for_beacon_timeout(pmlmeinfo->bcn_interval);
+		set_link_timer(pmlmeext, beacon_timeout);
+		_set_timer(&padapter->mlmepriv.assoc_timer,
+			(REAUTH_TO * REAUTH_LIMIT) + (REASSOC_TO * REASSOC_LIMIT) + beacon_timeout);
+
+#ifdef CONFIG_RTW_80211R
+		if (rtw_ft_roam(padapter)) {
+			rtw_ft_start_clnt_join(padapter);
+		} else
+#endif
+		{
+			rtw_sta_linking_test_set_start();
+			pmlmeinfo->state = WIFI_FW_AUTH_NULL | WIFI_FW_STATION_STATE;
+		}
+	} else if (caps & cap_IBSS) { /* adhoc client */
+		Set_MSR(padapter, WIFI_FW_ADHOC_STATE);
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
+
+		val8 = 0xcf;
+		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+
+		beacon_timing_control(padapter);
+
+		pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
+
+		report_join_res(padapter, 1, WLAN_STATUS_SUCCESS);
+	} else {
+		/* RTW_INFO("marc: invalid cap:%x\n", caps); */
+		return;
+	}
+
+}
+
+void start_clnt_auth(_adapter *padapter)
+{
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	_cancel_timer_ex(&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;
+
+#ifdef CONFIG_RTW_80211R
+	if (rtw_ft_roam(padapter)) {
+		rtw_ft_set_status(padapter, RTW_FT_AUTHENTICATING_STA);
+		RTW_PRINT("start ft auth\n");
+	} else
+#endif
+		RTW_PRINT("start auth\n");
+	issue_auth(padapter, NULL, 0);
+
+	set_link_timer(pmlmeext, REAUTH_TO);
+
+}
+
+
+void start_clnt_assoc(_adapter *padapter)
+{
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	_cancel_timer_ex(&pmlmeext->link_timer);
+
+	pmlmeinfo->state &= (~(WIFI_FW_AUTH_NULL | WIFI_FW_AUTH_STATE));
+	pmlmeinfo->state |= (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE);
+
+#ifdef CONFIG_RTW_80211R
+	if (rtw_ft_roam(padapter))
+		issue_reassocreq(padapter);
+	else
+#endif
+		issue_assocreq(padapter);
+
+	set_link_timer(pmlmeext, REASSOC_TO);
+}
+
+unsigned int receive_disconnect(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, u8 locally_generated)
+{
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (!(_rtw_memcmp(MacAddr, get_my_bssid(&pmlmeinfo->network), ETH_ALEN)))
+		return _SUCCESS;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_do_disconnect(padapter);
+#endif
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) {
+		if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
+			if (report_del_sta_event(padapter, MacAddr, reason, _TRUE, locally_generated) != _FAIL)
+				pmlmeinfo->state = WIFI_FW_NULL_STATE;
+		} else if (pmlmeinfo->state & WIFI_FW_LINKING_STATE) {
+			if (report_join_res(padapter, -2, reason) != _FAIL)
+				pmlmeinfo->state = WIFI_FW_NULL_STATE;
+		} else
+			RTW_INFO(FUNC_ADPT_FMT" - End to Disconnect\n", FUNC_ADPT_ARG(padapter));
+#ifdef CONFIG_RTW_80211R
+		rtw_ft_roam_status_reset(padapter);
+#endif
+#ifdef CONFIG_RTW_WNM
+		rtw_wnm_reset_btm_state(padapter);
+#endif
+	}
+
+	return _SUCCESS;
+}
+
+#ifdef CONFIG_80211D
+static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct registry_priv *pregistrypriv;
+	struct mlme_ext_priv *pmlmeext;
+	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)) {
+		u8 *ie, *p;
+		u32 len;
+		RT_CHANNEL_PLAN chplan_ap;
+		RT_CHANNEL_INFO *chplan_sta = NULL;
+		u8 country[4];
+		u8 fcn; /* first channel number */
+		u8 noc; /* number of channel */
+		u8 j, k;
+
+		ie = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _COUNTRY_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
+		if (!ie)
+			return;
+		if (len < 6)
+			return;
+
+		ie += 2;
+		p = ie;
+		ie += len;
+
+		_rtw_memset(country, 0, 4);
+		_rtw_memcpy(country, p, 3);
+		p += 3;
+		RTW_INFO("%s: 802.11d country=%s\n", __FUNCTION__, 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;
+
+#ifdef CONFIG_RTW_DEBUG
+		i = 0;
+		RTW_INFO("%s: AP[%s] channel plan {", __FUNCTION__, bssid->Ssid.Ssid);
+		while ((i < chplan_ap.Len) && (chplan_ap.Channel[i] != 0)) {
+			_RTW_INFO("%02d,", chplan_ap.Channel[i]);
+			i++;
+		}
+		_RTW_INFO("}\n");
+#endif
+
+		chplan_sta = rtw_malloc(sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
+		if (!chplan_sta)
+			goto done_update_chplan_from_ap;
+
+		_rtw_memcpy(chplan_sta, rfctl->channel_set, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
+#ifdef CONFIG_RTW_DEBUG
+		i = 0;
+		RTW_INFO("%s: STA channel plan {", __FUNCTION__);
+		while ((i < MAX_CHANNEL_NUM) && (chplan_sta[i].ChannelNum != 0)) {
+			_RTW_INFO("%02d(%c),", chplan_sta[i].ChannelNum, chplan_sta[i].ScanType == SCAN_PASSIVE ? 'p' : 'a');
+			i++;
+		}
+		_RTW_INFO("}\n");
+#endif
+
+		_rtw_memset(rfctl->channel_set, 0, sizeof(rfctl->channel_set));
+		chplan_new = rfctl->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;
+#if 0
+					chplan_new[k].ScanType = chplan_sta[i].ScanType;
+#else
+					chplan_new[k].ScanType = SCAN_PASSIVE;
+#endif
+					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;
+#if 0
+				chplan_new[k].ScanType = chplan_sta[i].ScanType;
+#else
+				chplan_new[k].ScanType = SCAN_PASSIVE;
+#endif
+				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])
-				{
+				} else if (chplan_sta[i].ChannelNum < chplan_ap.Channel[j]) {
 					chplan_new[k].ChannelNum = chplan_sta[i].ChannelNum;
-//					chplan_new[k].ScanType = chplan_sta[i].ScanType;
+#if 0
+					chplan_new[k].ScanType = chplan_sta[i].ScanType;
+#else
 					chplan_new[k].ScanType = SCAN_PASSIVE;
+#endif
 					i++;
 					k++;
-				}
-				else if (chplan_sta[i].ChannelNum > chplan_ap.Channel[j])
-				{
+				} 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++;
@@ -11147,203 +11947,387 @@ static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)
 				}
 			} 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))
-			{
+			/* 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 = chplan_sta[i].ScanType;
+#if 0
+				chplan_new[k].ScanType = chplan_sta[i].ScanType;
+#else
 				chplan_new[k].ScanType = SCAN_PASSIVE;
+#endif
 				i++;
 				k++;
 			}
 
-			// add channel AP supported
-			while ((j < chplan_ap.Len) && (chplan_ap.Channel[j] <= 14))
-			{
+			/* 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 2.4G channel plan
-			while ((i < MAX_CHANNEL_NUM) &&
-				(chplan_sta[i].ChannelNum != 0) &&
-				(chplan_sta[i].ChannelNum <= 14))
-			{
+		} 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;
+
+#ifdef CONFIG_RTW_DEBUG
+		k = 0;
+		RTW_INFO("%s: new STA channel plan {", __FUNCTION__);
+		while ((k < MAX_CHANNEL_NUM) && (chplan_new[k].ChannelNum != 0)) {
+			_RTW_INFO("%02d(%c),", chplan_new[k].ChannelNum, chplan_new[k].ScanType == SCAN_PASSIVE ? 'p' : 'c');
+			k++;
+		}
+		_RTW_INFO("}\n");
+#endif
+
+#if 0
+		/* recover the right channel index */
+		channel = chplan_sta[pmlmeext->sitesurvey_res.channel_idx].ChannelNum;
+		k = 0;
+		while ((k < MAX_CHANNEL_NUM) && (chplan_new[k].ChannelNum != 0)) {
+			if (chplan_new[k].ChannelNum == channel) {
+				RTW_INFO("%s: change mlme_ext sitesurvey channel index from %d to %d\n",
+					__FUNCTION__, pmlmeext->sitesurvey_res.channel_idx, k);
+				pmlmeext->sitesurvey_res.channel_idx = k;
+				break;
+			}
+			k++;
+		}
+#endif
+
+done_update_chplan_from_ap:
+		if (chplan_sta)
+			rtw_mfree(chplan_sta, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
+	}
+}
+#endif
+
+/****************************************************************************
+
+Following are the functions to report events
+
+*****************************************************************************/
+
+void report_survey_event(_adapter *padapter, union 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;
+	/* u8 *pframe = precv_frame->u.hdr.rx_data; */
+	/* uint len = precv_frame->u.hdr.len; */
+	RT_CHANNEL_INFO *chset = adapter_to_chset(padapter);
+	int ch_set_idx = -1;
+
+	if (!padapter)
+		return;
+
+	pmlmeext = &padapter->mlmeextpriv;
+	pcmdpriv = &padapter->cmdpriv;
+
+
+	pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd_obj == NULL)
+		return;
+
+	cmdsz = (sizeof(struct survey_event) + sizeof(struct C2HEvent_Header));
+	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
+	if (pevtcmd == NULL) {
+		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
+		return;
+	}
+
+	_rtw_init_listhead(&pcmd_obj->list);
+
+	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));
+
+	if (collect_bss_info(padapter, precv_frame, (WLAN_BSSID_EX *)&psurvey_evt->bss) == _FAIL) {
+		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)pevtcmd, cmdsz);
+		return;
+	}
+
+#ifdef CONFIG_80211D
+	process_80211d(padapter, &psurvey_evt->bss);
+#endif
+
+	ch_set_idx = rtw_chset_search_ch(chset, psurvey_evt->bss.Configuration.DSConfig);
+	if (ch_set_idx >= 0) {
+		if (psurvey_evt->bss.InfrastructureMode == Ndis802_11Infrastructure) {
+			if (chset[ch_set_idx].ScanType == SCAN_PASSIVE
+				&& !rtw_is_dfs_ch(psurvey_evt->bss.Configuration.DSConfig)
+			) {
+				RTW_INFO("%s: change ch:%d to active\n", __func__, psurvey_evt->bss.Configuration.DSConfig);
+				chset[ch_set_idx].ScanType = SCAN_ACTIVE;
+			}
+			#ifdef CONFIG_DFS
+			if (psurvey_evt->bss.Ssid.SsidLength == 0
+				|| is_all_null(psurvey_evt->bss.Ssid.Ssid, psurvey_evt->bss.Ssid.SsidLength) == _TRUE)
+				chset[ch_set_idx].hidden_bss_cnt++;
+			#endif
+		}
+	}
+
+	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+
+	pmlmeext->sitesurvey_res.bss_cnt++;
+
+	return;
+
+}
+
+void report_surveydone_event(_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 = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd_obj == NULL)
+		return;
+
+	cmdsz = (sizeof(struct surveydone_event) + sizeof(struct C2HEvent_Header));
+	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
+	if (pevtcmd == NULL) {
+		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
+		return;
+	}
+
+	_rtw_init_listhead(&pcmd_obj->list);
+
+	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;
+
+	RTW_INFO("survey done event(%x) band:%d for "ADPT_FMT"\n", psurveydone_evt->bss_cnt, padapter->setband, ADPT_ARG(padapter));
+
+	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+
+	return;
+
+}
+
+u32 report_join_res(_adapter *padapter, int aid_res, u16 status)
+{
+	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;
+	u32 ret = _FAIL;
+
+	pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd_obj == NULL)
+		goto exit;
+
+	cmdsz = (sizeof(struct joinbss_event) + sizeof(struct C2HEvent_Header));
+	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
+	if (pevtcmd == NULL) {
+		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
+		goto exit;
+	}
+
+	_rtw_init_listhead(&pcmd_obj->list);
+
+	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));
+	_rtw_memcpy((unsigned char *)(&(pjoinbss_evt->network.network)), &(pmlmeinfo->network), sizeof(WLAN_BSSID_EX));
+	pjoinbss_evt->network.join_res	= pjoinbss_evt->network.aid = aid_res;
+
+	RTW_INFO("report_join_res(%d, %u)\n", aid_res, status);
+
+
+	rtw_joinbss_event_prehandle(padapter, (u8 *)&pjoinbss_evt->network, status);
+
+
+	ret = rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+
+exit:
+	return ret;
+}
+
+void report_wmm_edca_update(_adapter *padapter)
+{
+	struct cmd_obj *pcmd_obj;
+	u8	*pevtcmd;
+	u32 cmdsz;
+	struct wmm_event		*pwmm_event;
+	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 = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd_obj == NULL)
+		return;
+
+	cmdsz = (sizeof(struct wmm_event) + sizeof(struct C2HEvent_Header));
+	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
+	if (pevtcmd == NULL) {
+		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
+		return;
+	}
+
+	_rtw_init_listhead(&pcmd_obj->list);
+
+	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 wmm_event);
+	pc2h_evt_hdr->ID = GEN_EVT_CODE(_WMM);
+	pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
 
-			// skip AP 2.4G channel plan
-			while ((j < chplan_ap.Len) && (chplan_ap.Channel[j] <= 14))
-			{
-				j++;
-			}
-		}
+	pwmm_event = (struct wmm_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
+	pwmm_event->wmm = 0;
 
-		if (pregistrypriv->wireless_mode & WIRELESS_11A)
-		{
-			do {
-				if ((i >= MAX_CHANNEL_NUM) ||
-					(chplan_sta[i].ChannelNum == 0))
-					break;
+	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
 
-				if ((j == chplan_ap.Len) || (chplan_ap.Channel[j] == 0))
-					break;
+	return;
 
-				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 = chplan_sta[i].ScanType;
-					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 = chplan_sta[i].ScanType;
-				chplan_new[k].ScanType = SCAN_PASSIVE;
-				i++;
-				k++;
-			}
+u32 report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated)
+{
+	struct cmd_obj *pcmd_obj;
+	u8	*pevtcmd;
+	u32 cmdsz;
+	struct sta_info *psta;
+	int	mac_id = -1;
+	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;
+	u8 res = _SUCCESS;
 
-			// 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++;
-			}
-		}
+	/* prepare cmd parameter */
+	cmdsz = (sizeof(struct stadel_event) + sizeof(struct C2HEvent_Header));
+	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
+	if (pevtcmd == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
 
-		pmlmeext->update_channel_plan_by_ap_done = 1;
+	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);
 
-#ifdef CONFIG_DEBUG_RTL871X
-		k = 0;
-		DBG_871X("%s: new STA channel plan {", __FUNCTION__);
-		while ((k < MAX_CHANNEL_NUM) && (chplan_new[k].ChannelNum != 0))
-		{
-			DBG_871X("%02d(%c),", chplan_new[k].ChannelNum, chplan_new[k].ScanType==SCAN_PASSIVE?'p':'c');
-			k++;
-		}
-		DBG_871X("}\n");
-#endif
+	pdel_sta_evt = (struct stadel_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
+	_rtw_memcpy((unsigned char *)(&(pdel_sta_evt->macaddr)), MacAddr, ETH_ALEN);
+	_rtw_memcpy((unsigned char *)(pdel_sta_evt->rsvd), (unsigned char *)(&reason), 2);
+	psta = rtw_get_stainfo(&padapter->stapriv, MacAddr);
+	if (psta)
+		mac_id = (int)psta->cmn.mac_id;
+	else
+		mac_id = (-1);
+	pdel_sta_evt->mac_id = mac_id;
+	pdel_sta_evt->locally_generated = locally_generated;
 
-#if 0
-		// recover the right channel index
-		channel = chplan_sta[pmlmeext->sitesurvey_res.channel_idx].ChannelNum;
-		k = 0;
-		while ((k < MAX_CHANNEL_NUM) && (chplan_new[k].ChannelNum != 0))
-		{
-			if (chplan_new[k].ChannelNum == channel) {
-				RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-						 ("%s: change mlme_ext sitesurvey channel index from %d to %d\n",
-						  __FUNCTION__, pmlmeext->sitesurvey_res.channel_idx, k));
-				pmlmeext->sitesurvey_res.channel_idx = k;
-				break;
-			}
-			k++;
+	if (!enqueue) {
+		/* do directly */
+		rtw_stadel_event_callback(padapter, (u8 *)pdel_sta_evt);
+		rtw_mfree(pevtcmd, cmdsz);
+	} else {
+		pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (pcmd_obj == NULL) {
+			rtw_mfree(pevtcmd, cmdsz);
+			res = _FAIL;
+			goto exit;
 		}
-#endif
-	}
 
-	// If channel is used by AP, set channel scan type to active
-	channel = bssid->Configuration.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",
-						  __FUNCTION__, channel));
-			}
-			break;
-		}
-		i++;
+		_rtw_init_listhead(&pcmd_obj->list);
+		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;
+
+		res = rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
 	}
-}
-#endif
 
-/****************************************************************************
+exit:
 
-Following are the functions to report events
+	RTW_INFO(FUNC_ADPT_FMT" "MAC_FMT" mac_id=%d, enqueue:%d, res:%u\n"
+		, FUNC_ADPT_ARG(padapter), MAC_ARG(MacAddr), mac_id, enqueue, res);
 
-*****************************************************************************/
+	return res;
+}
 
-void report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
+void report_add_sta_event(_adapter *padapter, unsigned char *MacAddr)
 {
 	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;
-	//u8 *pframe = precv_frame->u.hdr.rx_data;
-	//uint len = precv_frame->u.hdr.len;
-
-	if(!padapter)
-		return;
-
-	pmlmeext = &padapter->mlmeextpriv;
-	pcmdpriv = &padapter->cmdpriv;
-	
+	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;
 
-	if ((pcmd_obj = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
-	{
+	pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd_obj == NULL)
 		return;
-	}
 
-	cmdsz = (sizeof(struct survey_event) + sizeof(struct C2HEvent_Header));
-	if ((pevtcmd = (u8*)rtw_zmalloc(cmdsz)) == NULL)
-	{
+	cmdsz = (sizeof(struct stassoc_event) + sizeof(struct C2HEvent_Header));
+	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
+	if (pevtcmd == NULL) {
 		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
 		return;
 	}
@@ -11357,1331 +12341,1534 @@ void report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
 	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 = (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);
 
-	psurvey_evt = (struct survey_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
+	padd_sta_evt = (struct stassoc_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
+	_rtw_memcpy((unsigned char *)(&(padd_sta_evt->macaddr)), MacAddr, ETH_ALEN);
+
+	RTW_INFO("report_add_sta_event: add STA\n");
+
+	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+
+	return;
+}
+
+
+bool rtw_port_switch_chk(_adapter *adapter)
+{
+	bool switch_needed = _FALSE;
+#ifdef CONFIG_CONCURRENT_MODE
+#ifdef CONFIG_RUNTIME_PORT_SWITCH
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(dvobj);
+	_adapter *if_port0 = NULL;
+	_adapter *if_port1 = NULL;
+	struct mlme_ext_info *if_port0_mlmeinfo = NULL;
+	struct mlme_ext_info *if_port1_mlmeinfo = NULL;
+	int i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (get_hw_port(dvobj->padapters[i]) == HW_PORT0) {
+			if_port0 = dvobj->padapters[i];
+			if_port0_mlmeinfo = &(if_port0->mlmeextpriv.mlmext_info);
+		} else if (get_hw_port(dvobj->padapters[i]) == HW_PORT1) {
+			if_port1 = dvobj->padapters[i];
+			if_port1_mlmeinfo = &(if_port1->mlmeextpriv.mlmext_info);
+		}
+	}
+
+	if (if_port0 == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (if_port1 == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+#ifdef DBG_RUNTIME_PORT_SWITCH
+	RTW_INFO(FUNC_ADPT_FMT" wowlan_mode:%u\n"
+		 ADPT_FMT", port0, mlmeinfo->state:0x%08x, p2p_state:%d, %d\n"
+		 ADPT_FMT", port1, mlmeinfo->state:0x%08x, p2p_state:%d, %d\n",
+		 FUNC_ADPT_ARG(adapter), pwrctl->wowlan_mode,
+		ADPT_ARG(if_port0), if_port0_mlmeinfo->state, rtw_p2p_state(&if_port0->wdinfo), rtw_p2p_chk_state(&if_port0->wdinfo, P2P_STATE_NONE),
+		ADPT_ARG(if_port1), if_port1_mlmeinfo->state, rtw_p2p_state(&if_port1->wdinfo), rtw_p2p_chk_state(&if_port1->wdinfo, P2P_STATE_NONE));
+#endif /* DBG_RUNTIME_PORT_SWITCH */
+
+#ifdef CONFIG_WOWLAN
+	/* WOWLAN interface(primary, for now) should be port0 */
+	if (pwrctl->wowlan_mode == _TRUE) {
+		if (!is_primary_adapter(if_port0)) {
+			RTW_INFO("%s "ADPT_FMT" enable WOWLAN\n", __func__, ADPT_ARG(if_port1));
+			switch_needed = _TRUE;
+		}
+		goto exit;
+	}
+#endif /* CONFIG_WOWLAN */
+
+	/* AP/Mesh should use port0 for ctl frame's ack */
+	if ((if_port1_mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+		RTW_INFO("%s "ADPT_FMT" is AP/GO/Mesh\n", __func__, ADPT_ARG(if_port1));
+		switch_needed = _TRUE;
+		goto exit;
+	}
+
+	/* GC should use port0 for p2p ps */
+	if (((if_port1_mlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE)
+	    && (if_port1_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
+#ifdef CONFIG_P2P
+	    && !rtw_p2p_chk_state(&if_port1->wdinfo, P2P_STATE_NONE)
+#endif
+	    && !check_fwstate(&if_port1->mlmepriv, WIFI_UNDER_WPS)
+	   ) {
+		RTW_INFO("%s "ADPT_FMT" is GC\n", __func__, ADPT_ARG(if_port1));
+		switch_needed = _TRUE;
+		goto exit;
+	}
+
+	/* port1 linked, but port0 not linked */
+	if ((if_port1_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
+	    && !(if_port0_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
+	    && ((if_port0_mlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
+	   ) {
+		RTW_INFO("%s "ADPT_FMT" is SINGLE_LINK\n", __func__, ADPT_ARG(if_port1));
+		switch_needed = _TRUE;
+		goto exit;
+	}
+
+exit:
+#ifdef DBG_RUNTIME_PORT_SWITCH
+	RTW_INFO(FUNC_ADPT_FMT" ret:%d\n", FUNC_ADPT_ARG(adapter), switch_needed);
+#endif /* DBG_RUNTIME_PORT_SWITCH */
+#endif /* CONFIG_RUNTIME_PORT_SWITCH */
+#endif /* CONFIG_CONCURRENT_MODE */
+	return switch_needed;
+}
+
+/****************************************************************************
+
+Following are the event callback functions
+
+*****************************************************************************/
+
+/* for sta/adhoc mode */
+void update_sta_info(_adapter *padapter, struct sta_info *psta)
+{
+	_irqL	irqL;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	if (collect_bss_info(padapter, precv_frame, (WLAN_BSSID_EX *)&psurvey_evt->bss) == _FAIL)
-	{
-		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
-		rtw_mfree((u8 *)pevtcmd, cmdsz);
-		return;
-	}
+	/* ERP */
+	VCS_update(padapter, psta);
 
-#ifdef CONFIG_80211D
-	process_80211d(padapter, &psurvey_evt->bss);
-#endif
+#ifdef CONFIG_80211N_HT
+	/* HT */
+	if (pmlmepriv->htpriv.ht_option) {
+		psta->htpriv.ht_option = _TRUE;
 
-	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+		psta->htpriv.ampdu_enable = pmlmepriv->htpriv.ampdu_enable;
 
-	pmlmeext->sitesurvey_res.bss_cnt++;
+		psta->htpriv.rx_ampdu_min_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & IEEE80211_HT_CAP_AMPDU_DENSITY) >> 2;
 
-	return;
+		if (support_short_GI(padapter, &(pmlmeinfo->HT_caps), CHANNEL_WIDTH_20))
+			psta->htpriv.sgi_20m = _TRUE;
 
-}
+		if (support_short_GI(padapter, &(pmlmeinfo->HT_caps), CHANNEL_WIDTH_40))
+			psta->htpriv.sgi_40m = _TRUE;
 
-void report_surveydone_event(_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;
+		psta->qos_option = _TRUE;
 
-	if ((pcmd_obj = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
-	{
-		return;
-	}
+		psta->htpriv.ldpc_cap = pmlmepriv->htpriv.ldpc_cap;
+		psta->htpriv.stbc_cap = pmlmepriv->htpriv.stbc_cap;
+		psta->htpriv.beamform_cap = pmlmepriv->htpriv.beamform_cap;
 
-	cmdsz = (sizeof(struct surveydone_event) + sizeof(struct C2HEvent_Header));
-	if ((pevtcmd = (u8*)rtw_zmalloc(cmdsz)) == NULL)
+		_rtw_memcpy(&psta->htpriv.ht_cap, &pmlmeinfo->HT_caps, sizeof(struct rtw_ieee80211_ht_cap));
+		#ifdef CONFIG_BEAMFORMING
+		psta->htpriv.beamform_cap = pmlmepriv->htpriv.beamform_cap;
+		psta->cmn.bf_info.ht_beamform_cap = pmlmepriv->htpriv.beamform_cap;
+		#endif
+	} else
+#endif /* CONFIG_80211N_HT */
 	{
-		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
-		return;
-	}
-
-	_rtw_init_listhead(&pcmd_obj->list);
+#ifdef CONFIG_80211N_HT
+		psta->htpriv.ht_option = _FALSE;
+		psta->htpriv.ampdu_enable = _FALSE;
+		psta->htpriv.tx_amsdu_enable = _FALSE;
+		psta->htpriv.sgi_20m = _FALSE;
+		psta->htpriv.sgi_40m = _FALSE;
+#endif /* CONFIG_80211N_HT */
+		psta->qos_option = _FALSE;
 
-	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;
+#ifdef CONFIG_80211N_HT
+	psta->htpriv.ch_offset = pmlmeext->cur_ch_offset;
 
-	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);
+	psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
+	psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
+#endif /* CONFIG_80211N_HT */
 
-	psurveydone_evt = (struct surveydone_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-	psurveydone_evt->bss_cnt = pmlmeext->sitesurvey_res.bss_cnt;
+	psta->cmn.bw_mode = pmlmeext->cur_bwmode;
 
-	DBG_871X("survey done event(%x) band:%d for "ADPT_FMT"\n", psurveydone_evt->bss_cnt, padapter->setband, ADPT_ARG(padapter));
+	/* QoS */
+	if (pmlmepriv->qospriv.qos_option)
+		psta->qos_option = _TRUE;
 
-	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+#ifdef CONFIG_80211AC_VHT
+	_rtw_memcpy(&psta->vhtpriv, &pmlmepriv->vhtpriv, sizeof(struct vht_priv));
+	if (psta->vhtpriv.vht_option) {
+		psta->cmn.ra_info.is_vht_enable = _TRUE;
+		#ifdef CONFIG_BEAMFORMING
+		psta->vhtpriv.beamform_cap = pmlmepriv->vhtpriv.beamform_cap;
+		psta->cmn.bf_info.vht_beamform_cap = pmlmepriv->vhtpriv.beamform_cap;
+		#endif /*CONFIG_BEAMFORMING*/
+	}
+#endif /* CONFIG_80211AC_VHT */
+	psta->cmn.ra_info.is_support_sgi = query_ra_short_GI(psta, rtw_get_tx_bw_mode(padapter, psta));
+	update_ldpc_stbc_cap(psta);
 
-	return;
+	_enter_critical_bh(&psta->lock, &irqL);
+	psta->state = _FW_LINKED;
+	_exit_critical_bh(&psta->lock, &irqL);
 
 }
 
-void report_join_res(_adapter *padapter, int res)
+static void rtw_mlmeext_disconnect(_adapter *padapter)
 {
-	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_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-
-	if ((pcmd_obj = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
-	{
-		return;
-	}
-
-	cmdsz = (sizeof(struct joinbss_event) + sizeof(struct C2HEvent_Header));
-	if ((pevtcmd = (u8*)rtw_zmalloc(cmdsz)) == NULL)
-	{
-		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
-		return;
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+	u8 self_action = MLME_ACTION_UNKNOWN;
+	u8 state_backup = (pmlmeinfo->state & 0x03);
+	u8 ASIX_ID[] = {0x00, 0x0E, 0xC6};
+
+	if (MLME_IS_AP(padapter))
+		self_action = MLME_AP_STOPPED;
+	else if (MLME_IS_MESH(padapter))
+		self_action = MLME_MESH_STOPPED;
+	else if (MLME_IS_STA(padapter))
+		self_action = MLME_STA_DISCONNECTED;
+	else if (MLME_IS_ADHOC(padapter) || MLME_IS_ADHOC_MASTER(padapter))
+		self_action = MLME_ADHOC_STOPPED;
+	else if (MLME_IS_NULL(padapter))
+		self_action = MLME_ACTION_NONE;
+	else {
+		RTW_INFO("state:0x%x\n", MLME_STATE(padapter));
+		rtw_warn_on(1);
 	}
 
-	_rtw_init_listhead(&pcmd_obj->list);
+	/* set_opmode_cmd(padapter, infra_client_with_mlme); */
 
-	pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-	pcmd_obj->cmdsz = cmdsz;
-	pcmd_obj->parmbuf = pevtcmd;
+	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_DISCONNECT, 0);
+	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
 
-	pcmd_obj->rsp = NULL;
-	pcmd_obj->rspsz  = 0;
+	/* set MSR to no link state->infra. mode */
+	Set_MSR(padapter, _HW_STATE_STATION_);
 
-	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);
+	/* check if sta is ASIX peer and fix IOT issue if it is. */
+	if (_rtw_memcmp(get_my_bssid(&pmlmeinfo->network) , ASIX_ID , 3)) {
+		u8 iot_flag = _FALSE;
+		rtw_hal_set_hwreg(padapter, HW_VAR_ASIX_IOT, (u8 *)(&iot_flag));
+	}
+	pmlmeinfo->state = WIFI_FW_NULL_STATE;
 
-	pjoinbss_evt = (struct joinbss_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-	_rtw_memcpy((unsigned char *)(&(pjoinbss_evt->network.network)), &(pmlmeinfo->network), sizeof(WLAN_BSSID_EX));
-	pjoinbss_evt->network.join_res 	= pjoinbss_evt->network.aid = res;
+#ifdef CONFIG_MCC_MODE
+	/* mcc disconnect setting before download LPS rsvd page */
+	rtw_hal_set_mcc_setting_disconnect(padapter);
+#endif /* CONFIG_MCC_MODE */
 
-	DBG_871X("report_join_res(%d)\n", res);
-	
-	
-	rtw_joinbss_event_prehandle(padapter, (u8 *)&pjoinbss_evt->network);
-	
-	
-	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+	if (state_backup == WIFI_FW_STATION_STATE) {
+		if (rtw_port_switch_chk(padapter) == _TRUE) {
+			rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
+#ifdef CONFIG_LPS
+			{
+				_adapter *port0_iface = dvobj_get_port0_adapter(adapter_to_dvobj(padapter));
+				if (port0_iface)
+					rtw_lps_ctrl_wk_cmd(port0_iface, LPS_CTRL_CONNECT, 0);
+			}
+#endif
+		}
+	}
 
-	return;
+	/* switch to the 20M Hz mode after disconnect */
+	pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
+	pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 
-}
+#ifdef CONFIG_FCS_MODE
+	if (EN_FCS(padapter))
+		rtw_hal_set_hwreg(padapter, HW_VAR_STOP_FCS_MODE, NULL);
+#endif
 
-void report_wmm_edca_update(_adapter *padapter)
-{
-	struct cmd_obj *pcmd_obj;
-	u8	*pevtcmd;
-	u32 cmdsz;
-	struct wmm_event		*pwmm_event;
-	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;
+#ifdef CONFIG_DFS_MASTER
+	rtw_dfs_master_status_apply(padapter, self_action);
+#endif
 
-	if ((pcmd_obj = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
 	{
-		return;
-	}
+		u8 ch, bw, offset;
 
-	cmdsz = (sizeof(struct wmm_event) + sizeof(struct C2HEvent_Header));
-	if ((pevtcmd = (u8*)rtw_zmalloc(cmdsz)) == NULL)
-	{
-		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
-		return;
+		if (rtw_mi_get_ch_setting_union_no_self(padapter, &ch, &bw, &offset) != 0) {
+			set_channel_bwmode(padapter, ch, offset, bw);
+			rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
+		}
 	}
 
-	_rtw_init_listhead(&pcmd_obj->list);
+	flush_all_cam_entry(padapter);
 
-	pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-	pcmd_obj->cmdsz = cmdsz;
-	pcmd_obj->parmbuf = pevtcmd;
+	_cancel_timer_ex(&pmlmeext->link_timer);
 
-	pcmd_obj->rsp = NULL;
-	pcmd_obj->rspsz  = 0;
+	/* pmlmepriv->LinkDetectInfo.TrafficBusyState = _FALSE; */
+	pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
+	pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
 
-	pc2h_evt_hdr = (struct C2HEvent_Header*)(pevtcmd);
-	pc2h_evt_hdr->len = sizeof(struct wmm_event);
-	pc2h_evt_hdr->ID = GEN_EVT_CODE(_WMM);
-	pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
+#ifdef CONFIG_TDLS
+	padapter->tdlsinfo.ap_prohibited = _FALSE;
 
-	pwmm_event = (struct wmm_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-	pwmm_event->wmm =0;
-	
-	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+	/* For TDLS channel switch, currently we only allow it to work in wifi logo test mode */
+	if (padapter->registrypriv.wifi_spec == 1)
+		padapter->tdlsinfo.ch_switch_prohibited = _FALSE;
+#endif /* CONFIG_TDLS */
 
-	return;
+#ifdef CONFIG_WMMPS_STA
+	 if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+		/* reset currently related uapsd setting when the connection has broken */
+		pmlmepriv->qospriv.uapsd_max_sp_len = 0;
+		pmlmepriv->qospriv.uapsd_tid = 0;
+		pmlmepriv->qospriv.uapsd_tid_delivery_enabled = 0;
+		pmlmepriv->qospriv.uapsd_tid_trigger_enabled = 0;
+		pmlmepriv->qospriv.uapsd_ap_supported = 0;
+	}
+#endif /* CONFIG_WMMPS_STA */
 
 }
 
-void report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated)
+void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
 {
-	struct cmd_obj *pcmd_obj;
-	u8	*pevtcmd;
-	u32 cmdsz;
-	struct sta_info *psta;
-	int	mac_id = -1;
-	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;
-	u8 res = _SUCCESS;
+	struct sta_info		*psta, *psta_bmc;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
+	struct sta_priv		*pstapriv = &padapter->stapriv;
+	u8	join_type;
+#ifdef CONFIG_ARP_KEEP_ALIVE
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+#endif
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
 
-	/* prepare cmd parameter */
-	cmdsz = (sizeof(struct stadel_event) + sizeof(struct C2HEvent_Header));
-	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
-	if (pevtcmd == NULL) {
-		res = _FAIL;
-		goto exit;
+	if (join_res < 0) {
+		join_type = 1;
+		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+		rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
+
+		goto exit_mlmeext_joinbss_event_callback;
+	}
+#ifdef CONFIG_ARP_KEEP_ALIVE
+	pmlmepriv->bGetGateway = 1;
+	pmlmepriv->GetGatewayTryCnt = 0;
+#endif
+
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
+		/* update bc/mc sta_info */
+		update_bmc_sta(padapter);
 	}
 
-	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));
-	_rtw_memcpy((unsigned char *)(&(pdel_sta_evt->macaddr)), MacAddr, ETH_ALEN);
-	_rtw_memcpy((unsigned char *)(pdel_sta_evt->rsvd),(unsigned char *)(&reason),2);
-	psta = rtw_get_stainfo(&padapter->stapriv, MacAddr);
-	if(psta)
-		mac_id = (int)psta->mac_id;	
-	else
-		mac_id = (-1);
-	pdel_sta_evt->mac_id = mac_id;
-	 pdel_sta_evt->locally_generated = locally_generated;
+	/* turn on dynamic functions */
+	/* Switch_DM_Func(padapter, DYNAMIC_ALL_FUNC_ENABLE, _TRUE); */
 
-	if (!enqueue) {
-		/* do directly */
-		rtw_stadel_event_callback(padapter, (u8 *)pdel_sta_evt);
-		rtw_mfree(pevtcmd, cmdsz);
-	} else {
-		pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
-		if (pcmd_obj == NULL) {
-			rtw_mfree(pevtcmd, cmdsz);
-			res = _FAIL;
-			goto exit;
-		}
+	/* update IOT-releated issue */
+	update_IOT_info(padapter);
+
+	rtw_hal_set_hwreg(padapter, HW_VAR_BASIC_RATE, cur_network->SupportedRates);
+
+	/* BCN interval */
+	rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pmlmeinfo->bcn_interval));
+
+	/* udpate capability */
+	update_capinfo(padapter, pmlmeinfo->capability);
 
-		_rtw_init_listhead(&pcmd_obj->list);
-		pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-		pcmd_obj->cmdsz = cmdsz;
-		pcmd_obj->parmbuf = pevtcmd;
+	/* WMM, Update EDCA param */
+	WMMOnAssocRsp(padapter);
 
-		pcmd_obj->rsp = NULL;
-		pcmd_obj->rspsz  = 0;
+	/* HT */
+	HTOnAssocRsp(padapter);
 
-		res = rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
-	}
+#ifdef CONFIG_80211AC_VHT
+	/* VHT */
+	VHTOnAssocRsp(padapter);
+#endif
 
-exit:
+	psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
+	if (psta) { /* only for infra. mode */
+		psta->wireless_mode = pmlmeext->cur_wireless_mode;
 
-	DBG_871X(FUNC_ADPT_FMT" "MAC_FMT" mac_id=%d, enqueue:%d, res:%u\n"
-		, FUNC_ADPT_ARG(padapter), MAC_ARG(MacAddr), mac_id, enqueue, res);
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+		rtw_hal_set_default_port_id_cmd(padapter, psta->cmn.mac_id);
+#endif
 
-	return;
-}
+		/* set per sta rate after updating HT cap. */
+		set_sta_rate(padapter, psta);
 
-void report_add_sta_event(_adapter *padapter, unsigned char *MacAddr)
-{
-	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;
+		rtw_sta_media_status_rpt(padapter, psta, 1);
 
-	if ((pcmd_obj = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
-	{
-		return;
+		/* wakeup macid after join bss successfully to ensure
+			the subsequent data frames can be sent out normally */
+		rtw_hal_macid_wakeup(padapter, psta->cmn.mac_id);
 	}
 
-	cmdsz = (sizeof(struct stassoc_event) + sizeof(struct C2HEvent_Header));
-	if ((pevtcmd = (u8*)rtw_zmalloc(cmdsz)) == NULL)
-	{
-		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
-		return;
-	}
+#ifndef CONFIG_IOCTL_CFG80211
+	if (is_wep_enc(psecuritypriv->dot11PrivacyAlgrthm))
+		rtw_sec_restore_wep_key(padapter);
+#endif /* CONFIG_IOCTL_CFG80211 */
 
-	_rtw_init_listhead(&pcmd_obj->list);
+	if (rtw_port_switch_chk(padapter) == _TRUE)
+		rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
 
-	pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-	pcmd_obj->cmdsz = cmdsz;
-	pcmd_obj->parmbuf = pevtcmd;
+	join_type = 2;
+	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 
-	pcmd_obj->rsp = NULL;
-	pcmd_obj->rspsz  = 0;
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) {
+		/* correcting TSF */
+		correct_TSF(padapter, pmlmeext);
 
-	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);
+		/* set_link_timer(pmlmeext, DISCONNECT_TO); */
+	}
 
-	padd_sta_evt = (struct stassoc_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-	_rtw_memcpy((unsigned char *)(&(padd_sta_evt->macaddr)), MacAddr, ETH_ALEN);
+#ifdef CONFIG_LPS
+	#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
+	if (get_hw_port(padapter) == HW_PORT0)
+	#endif
+		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_CONNECT, 0);
+#endif
 
-	DBG_871X("report_add_sta_event: add STA\n");
+#ifdef CONFIG_BEAMFORMING
+	if (psta)
+		beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_ENTER, (u8 *)psta, sizeof(struct sta_info), 0);
+#endif/*CONFIG_BEAMFORMING*/
 
-	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
+exit_mlmeext_joinbss_event_callback:
 
-	return;
+	rtw_join_done_chk_ch(padapter, join_res);
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_join_done(padapter);
+#endif
+	RTW_INFO("=>%s - End to Connection without 4-way\n", __FUNCTION__);
 }
 
-
-bool rtw_port_switch_chk(_adapter *adapter)
+/* currently only adhoc mode will go here */
+void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta)
 {
-	bool switch_needed = _FALSE;
-#ifdef CONFIG_CONCURRENT_MODE
-#ifdef CONFIG_RUNTIME_PORT_SWITCH
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(dvobj);
-	_adapter *if_port0 = NULL;
-	_adapter *if_port1 = NULL;
-	struct mlme_ext_info *if_port0_mlmeinfo = NULL;
-	struct mlme_ext_info *if_port1_mlmeinfo = NULL;
-	int i;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	join_type;
 
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		if (get_iface_type(dvobj->padapters[i]) == IFACE_PORT0) {
-			if_port0 = dvobj->padapters[i];
-			if_port0_mlmeinfo = &(if_port0->mlmeextpriv.mlmext_info);
-		}
-		else if (get_iface_type(dvobj->padapters[i]) == IFACE_PORT1) {
-			if_port1 = dvobj->padapters[i];
-			if_port1_mlmeinfo = &(if_port1->mlmeextpriv.mlmext_info);
-		}
-	}
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	if (if_port0 == NULL) {
-		rtw_warn_on(1);
-		goto exit;
-	}
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
+		if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) { /* adhoc master or sta_count>1 */
+			/* nothing to do */
+		} else { /* adhoc client */
+			/* update TSF Value */
+			/* update_TSF(pmlmeext, pframe, len);			 */
 
-	if (if_port1 == NULL) {
-		rtw_warn_on(1);
-		goto exit;
-	}
+			/* correcting TSF */
+			correct_TSF(padapter, pmlmeext);
 
-#ifdef DBG_RUNTIME_PORT_SWITCH
-	DBG_871X(FUNC_ADPT_FMT" wowlan_mode:%u\n"
-		ADPT_FMT", port0, mlmeinfo->state:0x%08x, p2p_state:%d, %d\n"
-		ADPT_FMT", port1, mlmeinfo->state:0x%08x, p2p_state:%d, %d\n",
-		FUNC_ADPT_ARG(adapter), pwrctl->wowlan_mode,
-		ADPT_ARG(if_port0), if_port0_mlmeinfo->state, rtw_p2p_state(&if_port0->wdinfo), rtw_p2p_chk_state(&if_port0->wdinfo, P2P_STATE_NONE),
-		ADPT_ARG(if_port1), if_port1_mlmeinfo->state, rtw_p2p_state(&if_port1->wdinfo), rtw_p2p_chk_state(&if_port1->wdinfo, P2P_STATE_NONE));
-#endif /* DBG_RUNTIME_PORT_SWITCH */
+			/* start beacon */
+			if (send_beacon(padapter) == _FAIL)
+				rtw_warn_on(1);
 
-#ifdef CONFIG_WOWLAN
-	/* WOWLAN interface(primary, for now) should be port0 */
-	if (pwrctl->wowlan_mode == _TRUE) {
-		if(!is_primary_adapter(if_port0)) {
-			DBG_871X("%s "ADPT_FMT" enable WOWLAN\n", __func__, ADPT_ARG(if_port1));
-			switch_needed = _TRUE;
+			pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
 		}
-		goto exit;
-	}
-#endif /* CONFIG_WOWLAN */
-
-	/* AP should use port0 for ctl frame's ack */
-	if ((if_port1_mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
-		DBG_871X("%s "ADPT_FMT" is AP/GO\n", __func__, ADPT_ARG(if_port1));
-		switch_needed = _TRUE;
-		goto exit;
-	}
-
-	/* GC should use port0 for p2p ps */	
-	if (((if_port1_mlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE)
-		&& (if_port1_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-		&& !rtw_p2p_chk_state(&if_port1->wdinfo, P2P_STATE_NONE)
-		&& !check_fwstate(&if_port1->mlmepriv, WIFI_UNDER_WPS)
-	) {
-		DBG_871X("%s "ADPT_FMT" is GC\n", __func__, ADPT_ARG(if_port1));
-		switch_needed = _TRUE;
-		goto exit;
-	}
 
-	/* port1 linked, but port0 not linked */
-	if ((if_port1_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-		&& !(if_port0_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-		&& ((if_port0_mlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
-	) {
-		DBG_871X("%s "ADPT_FMT" is SINGLE_LINK\n", __func__, ADPT_ARG(if_port1));
-		switch_needed = _TRUE;
-		goto exit;
+		join_type = 2;
+		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 	}
 
-exit:
-#ifdef DBG_RUNTIME_PORT_SWITCH
-	DBG_871X(FUNC_ADPT_FMT" ret:%d\n", FUNC_ADPT_ARG(adapter), switch_needed);
-#endif /* DBG_RUNTIME_PORT_SWITCH */
-#endif /* CONFIG_RUNTIME_PORT_SWITCH */
-#endif /* CONFIG_CONCURRENT_MODE */
-	return switch_needed;
-}
+	/* update adhoc sta_info */
+	update_sta_info(padapter, psta);
 
-/****************************************************************************
+	rtw_hal_update_sta_ra_info(padapter, psta);
 
-Following are the event callback functions
+	/* ToDo: HT for Ad-hoc */
+	psta->wireless_mode = rtw_check_network_type(psta->bssrateset, psta->bssratelen, pmlmeext->cur_channel);
+	rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
 
-*****************************************************************************/
+	/* rate radaptive */
+	Update_RA_Entry(padapter, psta);
+}
 
-//for sta/adhoc mode
-void update_sta_info(_adapter *padapter, struct sta_info *psta)
+void mlmeext_sta_del_event_callback(_adapter *padapter)
 {
-	_irqL	irqL;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	//ERP
-	VCS_update(padapter, psta);
+	if (is_client_associated_to_ap(padapter) || is_IBSS_empty(padapter))
+		rtw_mlmeext_disconnect(padapter);
 
-#ifdef CONFIG_80211N_HT
-	//HT
-	if(pmlmepriv->htpriv.ht_option)
-	{
-		psta->htpriv.ht_option = _TRUE;
+}
 
-		psta->htpriv.ampdu_enable = pmlmepriv->htpriv.ampdu_enable;
+/****************************************************************************
 
-		psta->htpriv.rx_ampdu_min_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para&IEEE80211_HT_CAP_AMPDU_DENSITY)>>2;
+Following are the functions for the timer handlers
 
-		if (support_short_GI(padapter, &(pmlmeinfo->HT_caps), CHANNEL_WIDTH_20))
-			psta->htpriv.sgi_20m = _TRUE;
+*****************************************************************************/
+void _linked_info_dump(_adapter *padapter)
+{
+	if (padapter->bLinkInfoDump) {
+		rtw_hal_get_def_var(padapter, HW_DEF_RA_INFO_DUMP, RTW_DBGDUMP);
+		rtw_hal_set_odm_var(padapter, HAL_ODM_RX_INFO_DUMP, RTW_DBGDUMP, _FALSE);
+	}
+}
+/********************************************************************
 
-		if (support_short_GI(padapter, &(pmlmeinfo->HT_caps), CHANNEL_WIDTH_40))
-			psta->htpriv.sgi_40m = _TRUE;
+When station does not receive any packet in MAX_CONTINUAL_NORXPACKET_COUNT*2 seconds,
+recipient station will teardown the block ack by issuing DELBA frame.
 
-		psta->qos_option = _TRUE;
+*********************************************************************/
+void rtw_delba_check(_adapter *padapter, struct sta_info *psta, u8 from_timer)
+{
+	int	i = 0;
+	int ret = _SUCCESS;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-		psta->htpriv.ldpc_cap = pmlmepriv->htpriv.ldpc_cap;
-		psta->htpriv.stbc_cap = pmlmepriv->htpriv.stbc_cap;
-		psta->htpriv.beamform_cap = pmlmepriv->htpriv.beamform_cap;
+	/*
+		IOT issue,occur Broadcom ap(Buffalo WZR-D1800H,Netgear R6300).
+		AP is originator.AP does not transmit unicast packets when STA response its BAR.
+		This case probably occur ap issue BAR after AP builds BA.
 
-		_rtw_memcpy(&psta->htpriv.ht_cap, &pmlmeinfo->HT_caps, sizeof(struct rtw_ieee80211_ht_cap));
+		Follow 802.11 spec, STA shall maintain an inactivity timer for every negotiated Block Ack setup.
+		The inactivity timer is not reset when MPDUs corresponding to other TIDs are received.
+	*/
+	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) {
+		for (i = 0; i < TID_NUM ; i++) {
+			if ((psta->recvreorder_ctrl[i].enable) && 
+                        (sta_rx_data_qos_pkts(psta, i) == sta_last_rx_data_qos_pkts(psta, i)) ) {			
+					if (_TRUE == rtw_inc_and_chk_continual_no_rx_packet(psta, i)) {					
+						/* send a DELBA frame to the peer STA with the Reason Code field set to TIMEOUT */
+						if (!from_timer)
+							ret = issue_del_ba_ex(padapter, psta->cmn.mac_addr, i, 39, 0, 3, 1);
+						else
+							issue_del_ba(padapter,  psta->cmn.mac_addr, i, 39, 0);
+						psta->recvreorder_ctrl[i].enable = _FALSE;
+						if (ret != _FAIL)
+							psta->recvreorder_ctrl[i].ampdu_size = RX_AMPDU_SIZE_INVALID;
+						rtw_reset_continual_no_rx_packet(psta, i);
+					}				
+			} else {
+				/* The inactivity timer is reset when MPDUs to the TID is received. */
+				rtw_reset_continual_no_rx_packet(psta, i);
+			}
+		}
 	}
-	else
-#endif //CONFIG_80211N_HT
-	{
-#ifdef CONFIG_80211N_HT
-		psta->htpriv.ht_option = _FALSE;
+}
 
-		psta->htpriv.ampdu_enable = _FALSE;
-		
-		psta->htpriv.sgi_20m = _FALSE;
-		psta->htpriv.sgi_40m = _FALSE;
-#endif //CONFIG_80211N_HT
-		psta->qos_option = _FALSE;
+u8 chk_ap_is_alive(_adapter *padapter, struct sta_info *psta)
+{
+	u8 ret = _FALSE;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	}
+#ifdef DBG_EXPIRATION_CHK
+	RTW_INFO(FUNC_ADPT_FMT" rx:"STA_PKTS_FMT", beacon:%llu, probersp_to_self:%llu"
+		/*", probersp_bm:%llu, probersp_uo:%llu, probereq:%llu, BI:%u"*/
+		 ", retry:%u\n"
+		 , FUNC_ADPT_ARG(padapter)
+		 , STA_RX_PKTS_DIFF_ARG(psta)
+		, psta->sta_stats.rx_beacon_pkts - psta->sta_stats.last_rx_beacon_pkts
+		, psta->sta_stats.rx_probersp_pkts - psta->sta_stats.last_rx_probersp_pkts
+		/*, psta->sta_stats.rx_probersp_bm_pkts - psta->sta_stats.last_rx_probersp_bm_pkts
+		, psta->sta_stats.rx_probersp_uo_pkts - psta->sta_stats.last_rx_probersp_uo_pkts
+		, psta->sta_stats.rx_probereq_pkts - psta->sta_stats.last_rx_probereq_pkts
+		 , pmlmeinfo->bcn_interval*/
+		 , pmlmeext->retry
+		);
 
-#ifdef CONFIG_80211N_HT
-	psta->htpriv.ch_offset = pmlmeext->cur_ch_offset;
-	
-	psta->htpriv.agg_enable_bitmap = 0x0;//reset
-	psta->htpriv.candidate_tid_bitmap = 0x0;//reset
-#endif //CONFIG_80211N_HT
+	RTW_INFO(FUNC_ADPT_FMT" tx_pkts:%llu, link_count:%u\n", FUNC_ADPT_ARG(padapter)
+		 , sta_tx_pkts(psta)
+		 , pmlmeinfo->link_count
+		);
+#endif
 
-	psta->bw_mode = pmlmeext->cur_bwmode;
+	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;
 
-	//QoS
-	if(pmlmepriv->qospriv.qos_option)
-		psta->qos_option = _TRUE;
+	sta_update_last_rx_pkts(psta);
 
-#ifdef CONFIG_80211AC_VHT
-	_rtw_memcpy(&psta->vhtpriv, &pmlmepriv->vhtpriv, sizeof(struct vht_priv));
-#endif //CONFIG_80211AC_VHT
+	return ret;
+}
 
-	update_ldpc_stbc_cap(psta);
+u8 chk_adhoc_peer_is_alive(struct sta_info *psta)
+{
+	u8 ret = _TRUE;
+
+#ifdef DBG_EXPIRATION_CHK
+	RTW_INFO("sta:"MAC_FMT", rssi:%d, rx:"STA_PKTS_FMT", beacon:%llu, probersp_to_self:%llu"
+		/*", probersp_bm:%llu, probersp_uo:%llu, probereq:%llu, BI:%u"*/
+		 ", expire_to:%u\n"
+		 , MAC_ARG(psta->cmn.mac_addr)
+		 , psta->cmn.rssi_stat.rssi
+		 , STA_RX_PKTS_DIFF_ARG(psta)
+		, psta->sta_stats.rx_beacon_pkts - psta->sta_stats.last_rx_beacon_pkts
+		, psta->sta_stats.rx_probersp_pkts - psta->sta_stats.last_rx_probersp_pkts
+		/*, psta->sta_stats.rx_probersp_bm_pkts - psta->sta_stats.last_rx_probersp_bm_pkts
+		, psta->sta_stats.rx_probersp_uo_pkts - psta->sta_stats.last_rx_probersp_uo_pkts
+		, psta->sta_stats.rx_probereq_pkts - psta->sta_stats.last_rx_probereq_pkts
+		 , pmlmeinfo->bcn_interval*/
+		 , psta->expire_to
+		);
+#endif
+
+	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;
 
-	_enter_critical_bh(&psta->lock, &irqL);
-	psta->state = _FW_LINKED;
-	_exit_critical_bh(&psta->lock, &irqL);
+	sta_update_last_rx_pkts(psta);
 
+	return ret;
 }
 
-static void rtw_mlmeext_disconnect(_adapter *padapter)
+#ifdef CONFIG_TDLS
+u8 chk_tdls_peer_sta_is_alive(_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);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
-	u8 state_backup = (pmlmeinfo->state&0x03);
-	u8 ASIX_ID[]= {0x00, 0x0E, 0xC6};
-
-	//set_opmode_cmd(padapter, infra_client_with_mlme);
-
-	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_DISCONNECT, 0);
-	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
-
-	//set MSR to no link state -> infra. mode
-	Set_MSR(padapter, _HW_STATE_STATION_);
-
-	//check if sta is ASIX peer and fix IOT issue if it is.
-	if (_rtw_memcmp(get_my_bssid(&pmlmeinfo->network) ,ASIX_ID ,3)) {
-		u8 iot_flag = _FALSE;
-		rtw_hal_set_hwreg(padapter, HW_VAR_ASIX_IOT, (u8 *)(&iot_flag));
-	}
-	pmlmeinfo->state = WIFI_FW_NULL_STATE;
+	if ((psta->sta_stats.rx_data_pkts == psta->sta_stats.last_rx_data_pkts)
+	    && (psta->sta_stats.rx_tdls_disc_rsp_pkts == psta->sta_stats.last_rx_tdls_disc_rsp_pkts))
+		return _FALSE;
 
-	if(state_backup == WIFI_FW_STATION_STATE)
-	{
-		if (rtw_port_switch_chk(padapter) == _TRUE) {
-			rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
-			#ifdef CONFIG_LPS
-			{
-				_adapter *port0_iface = dvobj_get_port0_adapter(adapter_to_dvobj(padapter));
-				if (port0_iface)
-					rtw_lps_ctrl_wk_cmd(port0_iface, LPS_CTRL_CONNECT, 0);
-			}
-			#endif
-		}
-	}
+	return _TRUE;
+}
 
-	/* switch to the 20M Hz mode after disconnect */
-	pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
-	pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+void linked_status_chk_tdls(_adapter *padapter)
+{
+	struct candidate_pool {
+		struct sta_info *psta;
+		u8 addr[ETH_ALEN];
+	};
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	_irqL irqL;
+	u8 ack_chk;
+	struct sta_info *psta;
+	int i, num_teardown = 0, num_checkalive = 0;
+	_list	*plist, *phead;
+	struct tdls_txmgmt txmgmt;
+	struct candidate_pool checkalive[MAX_ALLOWED_TDLS_STA_NUM];
+	struct candidate_pool teardown[MAX_ALLOWED_TDLS_STA_NUM];
+	u8 tdls_sta_max = _FALSE;
 
-#ifdef CONFIG_FCS_MODE
-	if (EN_FCS(padapter))
-		rtw_hal_set_hwreg(padapter, HW_VAR_STOP_FCS_MODE, NULL);
-#endif
+#define ALIVE_MIN 2
+#define ALIVE_MAX 5
 
-#ifdef CONFIG_DFS_MASTER
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-		rtw_dfs_master_status_apply(padapter, MLME_AP_STOPPED);
-	else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
-		rtw_dfs_master_status_apply(padapter, MLME_STA_DISCONNECTED);
-#endif
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	_rtw_memset(checkalive, 0x00, sizeof(checkalive));
+	_rtw_memset(teardown, 0x00, sizeof(teardown));
 
-	{
-		u8 ch, bw, offset;
+	if ((padapter->tdlsinfo.link_established == _TRUE)) {
+		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+		for (i = 0; i < NUM_STA; i++) {
+			phead = &(pstapriv->sta_hash[i]);
+			plist = get_next(phead);
 
-		if (rtw_get_ch_setting_union_no_self(padapter, &ch, &bw, &offset) != 0)
-			set_channel_bwmode(padapter, ch, offset, bw);
-	}
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+				plist = get_next(plist);
 
-	flush_all_cam_entry(padapter);
+				if (psta->tdls_sta_state & TDLS_LINKED_STATE) {
+					psta->alive_count++;
+					if (psta->alive_count >= ALIVE_MIN) {
+						if (chk_tdls_peer_sta_is_alive(padapter, psta) == _FALSE) {
+							if (psta->alive_count < ALIVE_MAX) {
+								_rtw_memcpy(checkalive[num_checkalive].addr, psta->cmn.mac_addr, ETH_ALEN);
+								checkalive[num_checkalive].psta = psta;
+								num_checkalive++;
+							} else {
+								_rtw_memcpy(teardown[num_teardown].addr, psta->cmn.mac_addr, ETH_ALEN);
+								teardown[num_teardown].psta = psta;
+								num_teardown++;
+							}
+						} else
+							psta->alive_count = 0;
+					}
+					psta->sta_stats.last_rx_data_pkts = psta->sta_stats.rx_data_pkts;
+					psta->sta_stats.last_rx_tdls_disc_rsp_pkts = psta->sta_stats.rx_tdls_disc_rsp_pkts;
 
-	_cancel_timer_ex(&pmlmeext->link_timer);
+					if ((num_checkalive >= MAX_ALLOWED_TDLS_STA_NUM) || (num_teardown >= MAX_ALLOWED_TDLS_STA_NUM)) {
+						tdls_sta_max = _TRUE;
+						break;
+					}
+				}
+			}
 
-	//pmlmepriv->LinkDetectInfo.TrafficBusyState = _FALSE;
-	pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
-	pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
+			if (tdls_sta_max == _TRUE)
+				break;
+		}
+		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-#ifdef CONFIG_TDLS
-	padapter->tdlsinfo.ap_prohibited = _FALSE;
+		if (num_checkalive > 0) {
+			for (i = 0; i < num_checkalive; i++) {
+				_rtw_memcpy(txmgmt.peer, checkalive[i].addr, ETH_ALEN);
+				issue_tdls_dis_req(padapter, &txmgmt);
+				issue_tdls_dis_req(padapter, &txmgmt);
+				issue_tdls_dis_req(padapter, &txmgmt);
+			}
+		}
 
-	/* For TDLS channel switch, currently we only allow it to work in wifi logo test mode */
-	if (padapter->registrypriv.wifi_spec == 1)
-	{
-		padapter->tdlsinfo.ch_switch_prohibited = _FALSE;
+		if (num_teardown > 0) {
+			for (i = 0; i < num_teardown; i++) {
+				RTW_INFO("[%s %d] Send teardown to "MAC_FMT"\n", __FUNCTION__, __LINE__, MAC_ARG(teardown[i].addr));
+				txmgmt.status_code = _RSON_TDLS_TEAR_TOOFAR_;
+				_rtw_memcpy(txmgmt.peer, teardown[i].addr, ETH_ALEN);
+				issue_tdls_teardown(padapter, &txmgmt, _FALSE);
+			}
+		}
 	}
-#endif /* CONFIG_TDLS */
 
 }
+#endif /* CONFIG_TDLS */
 
-void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
+/* from_timer == 1 means driver is in LPS */
+void linked_status_chk(_adapter *padapter, u8 from_timer)
 {
-	struct sta_info		*psta, *psta_bmc;
+	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);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
 	struct sta_priv		*pstapriv = &padapter->stapriv;
-	u8	join_type;
-#ifdef CONFIG_ARP_KEEP_ALIVE
+#if defined(CONFIG_ARP_KEEP_ALIVE) || defined(CONFIG_LAYER2_ROAMING)
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 #endif
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#ifdef CONFIG_LAYER2_ROAMING
+	struct recv_priv	*precvpriv = &padapter->recvpriv;
+#endif
 
-	if(join_res < 0)
-	{
-		join_type = 1;
-		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
-		rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
+	if (padapter->registrypriv.mp_mode == _TRUE)
+		return;
 
-		goto exit_mlmeext_joinbss_event_callback;
-	}
-#ifdef CONFIG_ARP_KEEP_ALIVE
-	pmlmepriv->bGetGateway = 1;
-#endif
+	if (is_client_associated_to_ap(padapter)) {
+		/* linked infrastructure client mode */
 
-	if((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)
-	{
-		//update bc/mc sta_info
-		update_bmc_sta(padapter);
-	}
+		int tx_chk = _SUCCESS, rx_chk = _SUCCESS;
+		int rx_chk_limit;
+		int link_count_limit;
 
+#if defined(CONFIG_RTW_REPEATER_SON)
+	rtw_rson_scan_wk_cmd(padapter, RSON_SCAN_PROCESS);
+#elif defined(CONFIG_LAYER2_ROAMING)
+		if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE)) {
+			RTW_INFO("signal_strength_data.avg_val = %d\n", precvpriv->signal_strength_data.avg_val);
+			if (precvpriv->signal_strength_data.avg_val < pmlmepriv->roam_rssi_threshold) {
+#ifdef CONFIG_RTW_80211K
+				rtw_roam_nb_discover(padapter, _FALSE);
+#endif
+				pmlmepriv->need_to_roam = _TRUE;
+				rtw_drv_scan_by_self(padapter, RTW_AUTO_SCAN_REASON_ROAM);
+			} else
+				pmlmepriv->need_to_roam = _FALSE;
+		}
+#endif
+#ifdef CONFIG_MCC_MODE
+		/*
+		 * due to tx ps null date to ao, so ap doest not tx pkt to driver
+		 * we may check chk_ap_is_alive fail, and may issue_probereq to wrong channel under sitesurvey
+		 * don't keep alive check under MCC
+		 */
+		if (rtw_hal_mcc_link_status_chk(padapter, __func__) == _FALSE)
+			return;
+#endif
 
-	//turn on dynamic functions
-	/* Switch_DM_Func(padapter, DYNAMIC_ALL_FUNC_ENABLE, _TRUE); */
+#if defined(DBG_ROAMING_TEST) || defined(CONFIG_RTW_REPEATER_SON)
+		rx_chk_limit = 1;
+#elif defined(CONFIG_ACTIVE_KEEP_ALIVE_CHECK) && !defined(CONFIG_LPS_LCLK_WD_TIMER)
+		rx_chk_limit = 4;
+#else
+		rx_chk_limit = 8;
+#endif
+#ifdef CONFIG_ARP_KEEP_ALIVE
+		if (!from_timer && pmlmepriv->bGetGateway == 1 && pmlmepriv->GetGatewayTryCnt < 3) {
+			RTW_INFO("do rtw_gw_addr_query() : %d\n", pmlmepriv->GetGatewayTryCnt);
+			pmlmepriv->GetGatewayTryCnt++;
+			if (rtw_gw_addr_query(padapter) == 0)
+				pmlmepriv->bGetGateway = 0;
+			else {
+				_rtw_memset(pmlmepriv->gw_ip, 0, 4);
+				_rtw_memset(pmlmepriv->gw_mac_addr, 0, 6);
+			}
+		}
+#endif
+#ifdef CONFIG_P2P
+		if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE)) {
+			if (!from_timer)
+				link_count_limit = 3; /* 8 sec */
+			else
+				link_count_limit = 15; /* 32 sec */
+		} else
+#endif /* CONFIG_P2P */
+		{
+			if (!from_timer)
+				link_count_limit = 7; /* 16 sec */
+			else
+				link_count_limit = 29; /* 60 sec */
+		}
 
-	// update IOT-releated issue
-	update_IOT_info(padapter);
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+		if (ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on) == _TRUE)
+			return;
+#endif /* CONFIG_TDLS_CH_SW */
 
-	rtw_hal_set_hwreg(padapter, HW_VAR_BASIC_RATE, cur_network->SupportedRates);
+#ifdef CONFIG_TDLS_AUTOCHECKALIVE
+		linked_status_chk_tdls(padapter);
+#endif /* CONFIG_TDLS_AUTOCHECKALIVE */
+#endif /* CONFIG_TDLS */
 
-	//BCN interval
-	rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pmlmeinfo->bcn_interval));
+		psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
+		if (psta != NULL) {
+			bool is_p2p_enable = _FALSE;
+#ifdef CONFIG_P2P
+			is_p2p_enable = !rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE);
+#endif
 
-	//udpate capability
-	update_capinfo(padapter, pmlmeinfo->capability);
+#ifdef CONFIG_ISSUE_DELBA_WHEN_NO_TRAFFIC 
+			/*issue delba when ap does not tx data packet that is Broadcom ap */
+			rtw_delba_check(padapter, psta, from_timer);
+#endif
+			if (chk_ap_is_alive(padapter, psta) == _FALSE)
+				rx_chk = _FAIL;
 
-	//WMM, Update EDCA param
-	WMMOnAssocRsp(padapter);
+			if (sta_last_tx_pkts(psta) == sta_tx_pkts(psta))
+				tx_chk = _FAIL;
 
-	//HT
-	HTOnAssocRsp(padapter);
+#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+			if (!from_timer && pmlmeext->active_keep_alive_check && (rx_chk == _FAIL || tx_chk == _FAIL)
+			) {
+				u8 backup_ch = 0, backup_bw = 0, backup_offset = 0;
+				u8 union_ch = 0, union_bw = 0, union_offset = 0;
+				u8 switch_channel_by_drv = _TRUE;
 
-#ifdef CONFIG_80211AC_VHT
-	//VHT
-	VHTOnAssocRsp(padapter);
+				
+#ifdef CONFIG_MCC_MODE
+				if (MCC_EN(padapter)) {
+					/* driver doesn't switch channel under MCC */
+					if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+						switch_channel_by_drv = _FALSE;
+				}
 #endif
+				if (switch_channel_by_drv) {
+					if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
+						|| pmlmeext->cur_channel != union_ch)
+							goto bypass_active_keep_alive;
+
+					/* switch to correct channel of current network  before issue keep-alive frames */
+					if (rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
+						backup_ch = rtw_get_oper_ch(padapter);
+						backup_bw = rtw_get_oper_bw(padapter);
+						backup_offset = rtw_get_oper_choffset(padapter);
+						set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+					}
+				}
 
-	psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
-	if (psta) //only for infra. mode
-	{
-		//DBG_871X("set_sta_rate\n");
+				if (rx_chk != _SUCCESS)
+					issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, psta->cmn.mac_addr, 0, 0, 3, 1);
 
-		psta->wireless_mode = pmlmeext->cur_wireless_mode;
-	
-		//set per sta rate after updating HT cap.
-		set_sta_rate(padapter, psta);
-		
-		rtw_sta_media_status_rpt(padapter, psta, 1);
+				if ((tx_chk != _SUCCESS && pmlmeinfo->link_count++ == link_count_limit) || rx_chk != _SUCCESS) {
+					tx_chk = issue_nulldata(padapter, psta->cmn.mac_addr, 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;
+				}
 
-		/* wakeup macid after join bss successfully to ensure 
-			the subsequent data frames can be sent out normally */
-		rtw_hal_macid_wakeup(padapter, psta->mac_id);
-	}
+				/* back to the original operation channel */
+				if (backup_ch > 0 && switch_channel_by_drv)
+					set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
 
-#ifndef CONFIG_IOCTL_CFG80211
-	if (is_wep_enc(psecuritypriv->dot11PrivacyAlgrthm))
-		rtw_sec_restore_wep_key(padapter);
-#endif /* CONFIG_IOCTL_CFG80211 */
+bypass_active_keep_alive:
+				;
+			} else
+#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
+			{
+				if (rx_chk != _SUCCESS) {
+					if (pmlmeext->retry == 0) {
+#ifdef DBG_EXPIRATION_CHK
+						RTW_INFO("issue_probereq to trigger probersp, retry=%d\n", pmlmeext->retry);
+#endif
+						issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, (from_timer ? 0 : 1));
+						issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, (from_timer ? 0 : 1));
+						issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, (from_timer ? 0 : 1));
+					}
+				}
 
-	if (rtw_port_switch_chk(padapter) == _TRUE)
-		rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
+				if (tx_chk != _SUCCESS && pmlmeinfo->link_count++ == link_count_limit
+#ifdef CONFIG_MCC_MODE
+				    /* FW tx nulldata under MCC mode, we just check  ap is alive */
+				    && (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC))
+#endif /* CONFIG_MCC_MODE */
+				) {
+					#ifdef DBG_EXPIRATION_CHK
+					RTW_INFO("%s issue_nulldata(%d)\n", __FUNCTION__, from_timer ? 1 : 0);
+					#endif
+					if (from_timer)
+						tx_chk = issue_nulldata(padapter, NULL, 1, 0, 0);
+					else
+						tx_chk = issue_nulldata(padapter, NULL, 0, 1, 1);
+				}
+			}
 
-	join_type = 2;
-	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+			if (rx_chk == _FAIL) {
+				pmlmeext->retry++;
+				if (pmlmeext->retry > rx_chk_limit) {
+					RTW_PRINT(FUNC_ADPT_FMT" disconnect or roaming\n",
+						  FUNC_ADPT_ARG(padapter));
+					receive_disconnect(padapter, pmlmeinfo->network.MacAddress
+						, WLAN_REASON_EXPIRATION_CHK, _FALSE);
+					return;
+				}
+			} else
+				pmlmeext->retry = 0;
+
+			if (tx_chk == _FAIL)
+				pmlmeinfo->link_count %= (link_count_limit + 1);
+			else {
+				psta->sta_stats.last_tx_pkts = psta->sta_stats.tx_pkts;
+				pmlmeinfo->link_count = 0;
+			}
 
-	if((pmlmeinfo->state&0x03) == WIFI_FW_STATION_STATE)
-	{
-		// correcting TSF
-		correct_TSF(padapter, pmlmeext);
-	
-		//set_link_timer(pmlmeext, DISCONNECT_TO);
-	}
+		} /* end of if ((psta = rtw_get_stainfo(pstapriv, passoc_res->network.MacAddress)) != NULL) */
 
-#ifdef CONFIG_LPS
-	if(get_iface_type(padapter) == IFACE_PORT0)
-		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_CONNECT, 0);
-#endif
+	} else if (is_client_associated_to_ibss(padapter)) {
+		_irqL irqL;
+		_list *phead, *plist, dlist;
 
-#ifdef CONFIG_BEAMFORMING
-	if (psta)
-		beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_ENTER, (u8 *)psta, sizeof(struct sta_info), 0);
-#endif/*CONFIG_BEAMFORMING*/
+		_rtw_init_listhead(&dlist);
 
-exit_mlmeext_joinbss_event_callback:
+		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-	rtw_join_done_chk_ch(padapter, join_res);
+		for (i = 0; i < NUM_STA; i++) {
 
-	DBG_871X("=>%s - End to Connection without 4-way\n", __FUNCTION__);
-}
+			phead = &(pstapriv->sta_hash[i]);
+			plist = get_next(phead);
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+				plist = get_next(plist);
 
-//currently only adhoc mode will go here
-void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta)
-{
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8	join_type;
+				if (is_broadcast_mac_addr(psta->cmn.mac_addr))
+					continue;
 
-	DBG_871X("%s\n", __FUNCTION__);
+				if (chk_adhoc_peer_is_alive(psta) || !psta->expire_to)
+					psta->expire_to = pstapriv->adhoc_expire_to;
+				else
+					psta->expire_to--;
 
-	if((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)
-	{
-		if(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)//adhoc master or sta_count>1
-		{
-			//nothing to do
+				if (psta->expire_to <= 0) {
+					rtw_list_delete(&psta->list);
+					rtw_list_insert_tail(&psta->list, &dlist);
+				}
+			}
 		}
-		else//adhoc client
-		{
-			//update TSF Value
-			//update_TSF(pmlmeext, pframe, len);			
 
-			// correcting TSF
-			correct_TSF(padapter, pmlmeext);
-
-			//start beacon
-			if (send_beacon(padapter) == _FAIL)
-				rtw_warn_on(1);
+		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-			pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
+		plist = get_next(&dlist);
+		while (rtw_end_of_queue_search(&dlist, plist) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info, list);
+			plist = get_next(plist);
+			rtw_list_delete(&psta->list);
+			RTW_INFO(FUNC_ADPT_FMT" ibss expire "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+			report_del_sta_event(padapter, psta->cmn.mac_addr, WLAN_REASON_EXPIRATION_CHK, from_timer ? _TRUE : _FALSE, _FALSE);
 		}
-
-		join_type = 2;
-		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 	}
 
-	//update adhoc sta_info
-	update_sta_info(padapter, psta);
-
-	rtw_hal_update_sta_rate_mask(padapter, psta);
-
-	// ToDo: HT for Ad-hoc 
-	psta->wireless_mode = rtw_check_network_type(psta->bssrateset, psta->bssratelen, pmlmeext->cur_channel);
-	psta->raid = rtw_hal_networktype_to_raid(padapter, psta);
-
-	//rate radaptive
-	Update_RA_Entry(padapter, psta);
 }
 
-void mlmeext_sta_del_event_callback(_adapter *padapter)
+void survey_timer_hdl(void *ctx)
 {
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	_adapter *padapter = (_adapter *)ctx;
+	struct cmd_obj *cmd;
+	struct sitesurvey_parm *psurveyPara;
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif
 
-	if (is_client_associated_to_ap(padapter) || is_IBSS_empty(padapter))
-	{
-		rtw_mlmeext_disconnect(padapter);
+	if (mlmeext_scan_state(pmlmeext) > SCAN_DISABLE) {
+		cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (cmd == NULL) {
+			rtw_warn_on(1);
+			goto exit;
+		}
+
+		psurveyPara = (struct sitesurvey_parm *)rtw_zmalloc(sizeof(struct sitesurvey_parm));
+		if (psurveyPara == NULL) {
+			rtw_warn_on(1);
+			rtw_mfree((unsigned char *)cmd, sizeof(struct cmd_obj));
+			goto exit;
+		}
+
+		init_h2fwcmd_w_parm_no_rsp(cmd, psurveyPara, GEN_CMD_CODE(_SiteSurvey));
+		rtw_enqueue_cmd(pcmdpriv, cmd);
 	}
 
+exit:
+	return;
 }
 
-/****************************************************************************
+#ifdef CONFIG_RTW_REPEATER_SON
+/*	 100ms pass, stop rson_scan	*/
+void rson_timer_hdl(void *ctx)
+{
+	_adapter *padapter = (_adapter *)ctx;
 
-Following are the functions for the timer handlers
+	rtw_rson_scan_wk_cmd(padapter, RSON_SCAN_DISABLE);
+}
 
-*****************************************************************************/
-void _linked_info_dump(_adapter *padapter)
+#endif
+
+void link_timer_hdl(void *ctx)
 {
-	int i;
-	struct mlme_ext_priv    *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info    *pmlmeinfo = &(pmlmeext->mlmext_info);
-	int UndecoratedSmoothedPWDB = 0;
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	
-	if(padapter->bLinkInfoDump){
+	_adapter *padapter = (_adapter *)ctx;
+	/* 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; */
+#ifdef CONFIG_RTW_80211R
+	struct	sta_priv		*pstapriv = &padapter->stapriv;
+	struct	sta_info		*psta = NULL;
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+#endif
 
-		DBG_871X("\n============["ADPT_FMT"] linked status check ===================\n",ADPT_ARG(padapter));	
+	if (rtw_sta_linking_test_force_fail())
+		RTW_INFO("rtw_sta_linking_test_force_fail\n");
 
-		if((pmlmeinfo->state&0x03) == WIFI_FW_STATION_STATE)
-		{
-			rtw_hal_get_def_var(padapter, HAL_DEF_UNDERCORATEDSMOOTHEDPWDB, &UndecoratedSmoothedPWDB);	
-		
-			DBG_871X("AP[" MAC_FMT "] - UndecoratedSmoothedPWDB:%d\n",
-				MAC_ARG(padapter->mlmepriv.cur_network.network.MacAddress),UndecoratedSmoothedPWDB);
+	if (pmlmeext->join_abort && pmlmeinfo->state != WIFI_FW_NULL_STATE) {
+		RTW_INFO(FUNC_ADPT_FMT" join abort\n", FUNC_ADPT_ARG(padapter));
+		pmlmeinfo->state = WIFI_FW_NULL_STATE;
+		report_join_res(padapter, -4, WLAN_STATUS_UNSPECIFIED_FAILURE);
+		goto exit;
+	}
+
+	if (pmlmeinfo->state & WIFI_FW_AUTH_NULL) {
+		RTW_INFO("link_timer_hdl:no beacon while connecting\n");
+		pmlmeinfo->state = WIFI_FW_NULL_STATE;
+		report_join_res(padapter, -3, WLAN_STATUS_UNSPECIFIED_FAILURE);
+	} 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;
+			if (pmlmeinfo->auth_status) {
+				report_join_res(padapter, -1, pmlmeinfo->auth_status);
+				pmlmeinfo->auth_status = 0; /* reset */
+			} else
+				report_join_res(padapter, -1, WLAN_STATUS_UNSPECIFIED_FAILURE);
+			return;
+			/* } */
+			/* else */
+			/* { */
+			/*	pmlmeinfo->auth_algo = dot11AuthAlgrthm_Shared; */
+			/*	pmlmeinfo->reauth_count = 0; */
+			/* } */
 		}
-		else if((pmlmeinfo->state&0x03) == _HW_STATE_AP_)
-		{
-			_irqL irqL;
-			_list	*phead, *plist;
-	
-			struct sta_info *psta=NULL;	
-			struct sta_priv *pstapriv = &padapter->stapriv;
-			
-			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);	
-			phead = &pstapriv->asoc_list;
-			plist = get_next(phead);
-			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-			{
-				psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-				plist = get_next(plist);			
-				
-				DBG_871X("STA[" MAC_FMT "]:UndecoratedSmoothedPWDB:%d\n", 
-					MAC_ARG(psta->hwaddr),psta->rssi_stat.UndecoratedSmoothedPWDB);
+
+		RTW_INFO("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 = WIFI_FW_NULL_STATE;
+#ifdef CONFIG_RTW_80211R
+			if (rtw_ft_roam(padapter)) {
+				psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
+				if (psta)
+					rtw_free_stainfo(padapter,  psta);
 			}
-			_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);		
-			
+#endif
+			report_join_res(padapter, -2, WLAN_STATUS_UNSPECIFIED_FAILURE);
+			return;
 		}
-		for(i=0; i<macid_ctl->num; i++)
+
+#ifdef CONFIG_RTW_80211R
+		if (rtw_ft_roam(padapter)) {
+			RTW_INFO("link_timer_hdl: reassoc timeout and try again\n");
+			issue_reassocreq(padapter);
+		} else
+#endif
 		{
-			if(rtw_macid_is_used(macid_ctl, i) 
-				&& !rtw_macid_is_bmc(macid_ctl, i) /* skip bc/mc sta */
-			) {
-				//============  tx info ============	
-				rtw_hal_get_def_var(padapter, HW_DEF_RA_INFO_DUMP, &i);			
-			}
+			RTW_INFO("link_timer_hdl: assoc timeout and try again\n");
+			issue_assocreq(padapter);
 		}
-		rtw_hal_set_odm_var(padapter, HAL_ODM_RX_INFO_DUMP, NULL, _FALSE);
-		
+
+		set_link_timer(pmlmeext, REASSOC_TO);
 	}
-	      
 
+exit:
+	return;
 }
-void rtw_delba_check(_adapter *padapter, struct sta_info *psta, u8 from_timer)
+
+void addba_timer_hdl(void *ctx)
 {
-	int	i = 0;
-	int ret = _SUCCESS;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct sta_info *psta = (struct sta_info *)ctx;
+
+#ifdef CONFIG_80211N_HT
+	struct ht_priv	*phtpriv;
+
+	if (!psta)
+		return;
+
+	phtpriv = &psta->htpriv;
+
+	if ((phtpriv->ht_option == _TRUE) && (phtpriv->ampdu_enable == _TRUE)) {
+		if (phtpriv->candidate_tid_bitmap)
+			phtpriv->candidate_tid_bitmap = 0x0;
 
-	/*
-		IOT issue,occur Broadcom ap(Buffalo WZR-D1800H,Netgear R6300).
-		AP is originator.AP does not transmit unicast packets when STA response its BAR.
-		This case probably occur ap issue BAR after AP builds BA. 
-				
-		Follow 802.11 spec, STA shall maintain an inactivity timer for every negotiated Block Ack setup.
-		The inactivity timer is not reset when MPDUs corresponding to other TIDs are received.
-	*/
-	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) {
-		for (i = 0; i < TID_NUM ; i++) {				
-			if (sta_rx_data_qos_pkts(psta, i) == sta_last_rx_data_qos_pkts(psta, i)) {			
-				if (_TRUE == rtw_inc_and_chk_continual_no_rx_packet(psta, i)) {
-					if (psta->recvreorder_ctrl[i].enable) {						
-						/* send a DELBA frame to the peer STA with the Reason Code field set to TIMEOUT */		
-						if (!from_timer)
-							ret = issue_del_ba_ex(padapter, psta->hwaddr, i, 39, 0, 3, 1);
-						else
-							issue_del_ba(padapter,  psta->hwaddr, i, 39, 0);							
-						psta->recvreorder_ctrl[i].enable = _FALSE;
-						if (ret != _FAIL)
-							psta->recvreorder_ctrl[i].ampdu_size = RX_AMPDU_SIZE_INVALID;
-						rtw_reset_continual_no_rx_packet(psta, i);
-						}				
-					}
-				}
-			else{   
-				/* The inactivity timer is reset when MPDUs to the TID is received. */
-				rtw_reset_continual_no_rx_packet(psta, i);	
-			}
-		}
 	}
+#endif /* CONFIG_80211N_HT */
 }
 
-u8 chk_ap_is_alive(_adapter *padapter, struct sta_info *psta)
+#ifdef CONFIG_IEEE80211W
+void report_sta_timeout_event(_adapter *padapter, u8 *MacAddr, unsigned short reason)
 {
-	u8 ret = _FALSE;
-	int i = 0;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	#ifdef DBG_EXPIRATION_CHK
-	DBG_871X(FUNC_ADPT_FMT" rx:"STA_PKTS_FMT", beacon:%llu, probersp_to_self:%llu"
-				/*", probersp_bm:%llu, probersp_uo:%llu, probereq:%llu, BI:%u"*/
-				", retry:%u\n"
-		, FUNC_ADPT_ARG(padapter)
-		, STA_RX_PKTS_DIFF_ARG(psta)
-		, psta->sta_stats.rx_beacon_pkts - psta->sta_stats.last_rx_beacon_pkts
-		, psta->sta_stats.rx_probersp_pkts - psta->sta_stats.last_rx_probersp_pkts
-		/*, psta->sta_stats.rx_probersp_bm_pkts - psta->sta_stats.last_rx_probersp_bm_pkts
-		, psta->sta_stats.rx_probersp_uo_pkts - psta->sta_stats.last_rx_probersp_uo_pkts
-		, psta->sta_stats.rx_probereq_pkts - psta->sta_stats.last_rx_probereq_pkts
-		, pmlmeinfo->bcn_interval*/
-		, pmlmeext->retry
-	);
+	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;
 
-	DBG_871X(FUNC_ADPT_FMT" tx_pkts:%llu, link_count:%u\n", FUNC_ADPT_ARG(padapter)
-		, padapter->xmitpriv.tx_pkts
-		, pmlmeinfo->link_count
-	);
-	#endif
+	pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd_obj == NULL)
+		return;
 
-	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;
+	cmdsz = (sizeof(struct stadel_event) + sizeof(struct C2HEvent_Header));
+	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
+	if (pevtcmd == NULL) {
+		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
+		return;
 	}
 
-	sta_update_last_rx_pkts(psta);
+	_rtw_init_listhead(&pcmd_obj->list);
 
-	/*
-		record last rx data packets for every tid.
-	*/
-	for (i = 0; i < TID_NUM; i++)	
-		psta->sta_stats.last_rx_data_qos_pkts[i] = psta->sta_stats.rx_data_qos_pkts[i];
+	pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
+	pcmd_obj->cmdsz = cmdsz;
+	pcmd_obj->parmbuf = pevtcmd;
 
-	return ret;
-}
+	pcmd_obj->rsp = NULL;
+	pcmd_obj->rspsz  = 0;
 
-u8 chk_adhoc_peer_is_alive(struct sta_info *psta)
-{
-	u8 ret = _TRUE;
+	pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
+	pc2h_evt_hdr->len = sizeof(struct stadel_event);
+	pc2h_evt_hdr->ID = GEN_EVT_CODE(_TimeoutSTA);
+	pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
 
-	#ifdef DBG_EXPIRATION_CHK
-	DBG_871X("sta:"MAC_FMT", rssi:%d, rx:"STA_PKTS_FMT", beacon:%llu, probersp_to_self:%llu"
-		/*", probersp_bm:%llu, probersp_uo:%llu, probereq:%llu, BI:%u"*/
-		", expire_to:%u\n"
-		, MAC_ARG(psta->hwaddr)
-		, psta->rssi_stat.UndecoratedSmoothedPWDB
-		, STA_RX_PKTS_DIFF_ARG(psta)
-		, psta->sta_stats.rx_beacon_pkts - psta->sta_stats.last_rx_beacon_pkts
-		, psta->sta_stats.rx_probersp_pkts - psta->sta_stats.last_rx_probersp_pkts
-		/*, psta->sta_stats.rx_probersp_bm_pkts - psta->sta_stats.last_rx_probersp_bm_pkts
-		, psta->sta_stats.rx_probersp_uo_pkts - psta->sta_stats.last_rx_probersp_uo_pkts
-		, psta->sta_stats.rx_probereq_pkts - psta->sta_stats.last_rx_probereq_pkts
-		, pmlmeinfo->bcn_interval*/
-		, psta->expire_to
-	);
-	#endif
+	pdel_sta_evt = (struct stadel_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
+	_rtw_memcpy((unsigned char *)(&(pdel_sta_evt->macaddr)), MacAddr, ETH_ALEN);
+	_rtw_memcpy((unsigned char *)(pdel_sta_evt->rsvd), (unsigned char *)(&reason), 2);
 
-	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;
 
-	sta_update_last_rx_pkts(psta);
+	psta = rtw_get_stainfo(&padapter->stapriv, MacAddr);
+	if (psta)
+		mac_id = (int)psta->cmn.mac_id;
+	else
+		mac_id = (-1);
+
+	pdel_sta_evt->mac_id = mac_id;
+
+	RTW_INFO("report_del_sta_event: delete STA, mac_id=%d\n", mac_id);
+
+	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
 
-	return ret;
+	return;
 }
 
-#ifdef CONFIG_TDLS
-u8 chk_tdls_peer_sta_is_alive(_adapter *padapter, struct sta_info *psta)
+void clnt_sa_query_timeout(_adapter *padapter)
 {
-	if ((psta->sta_stats.rx_data_pkts == psta->sta_stats.last_rx_data_pkts)
-		&& (psta->sta_stats.rx_tdls_disc_rsp_pkts == psta->sta_stats.last_rx_tdls_disc_rsp_pkts))
-		return _FALSE;
+	struct mlme_ext_priv *mlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
 
-	return _TRUE;
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	receive_disconnect(padapter, get_my_bssid(&(mlmeinfo->network)), WLAN_REASON_SA_QUERY_TIMEOUT, _FALSE);
 }
 
-void linked_status_chk_tdls(_adapter *padapter)
+void sa_query_timer_hdl(void *ctx)
 {
-struct candidate_pool{
-	struct sta_info *psta;
-	u8 addr[ETH_ALEN];
-};
-	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta = (struct sta_info *)ctx;
+	_adapter *padapter = psta->padapter;
 	_irqL irqL;
-	u8 ack_chk;
-	struct sta_info *psta;
-	int i, num_teardown=0, num_checkalive=0;
-	_list	*plist, *phead;
-	struct tdls_txmgmt txmgmt;
-	struct candidate_pool checkalive[NUM_STA];
-	struct candidate_pool teardown[NUM_STA];
-#define ALIVE_MIN 2
-#define ALIVE_MAX 5
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	_rtw_memset(checkalive, 0x00, sizeof(checkalive));
-	_rtw_memset(teardown, 0x00, sizeof(teardown));
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE &&
+	    check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		clnt_sa_query_timeout(padapter);
+	else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
+		report_sta_timeout_event(padapter, psta->cmn.mac_addr, WLAN_REASON_PREV_AUTH_NOT_VALID);
+}
 
-	if((padapter->tdlsinfo.link_established == _TRUE)){
-		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-		for(i=0; i< NUM_STA; i++)
-		{
-			phead = &(pstapriv->sta_hash[i]);
-			plist = get_next(phead);
-			
-			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-			{
-				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
-				plist = get_next(plist);
+#endif /* CONFIG_IEEE80211W */
 
-				if(psta->tdls_sta_state & TDLS_LINKED_STATE)
-				{
-					psta->alive_count++;
-					if(psta->alive_count >= ALIVE_MIN)
-					{
-						if (chk_tdls_peer_sta_is_alive(padapter, psta) == _FALSE) {
-							if (psta->alive_count < ALIVE_MAX) {
-								_rtw_memcpy(checkalive[num_checkalive].addr, psta->hwaddr, ETH_ALEN);
-								checkalive[num_checkalive].psta = psta;
-								num_checkalive++;
-							}
-							else
-							{
-								_rtw_memcpy(teardown[num_teardown].addr, psta->hwaddr, ETH_ALEN);
-								teardown[num_teardown].psta = psta;
-								num_teardown++;
-							}
-						}
-						else
-						{
-							psta->alive_count = 0;
-						}
-					}
-					psta->sta_stats.last_rx_data_pkts = psta->sta_stats.rx_data_pkts;
-					psta->sta_stats.last_rx_tdls_disc_rsp_pkts = psta->sta_stats.rx_tdls_disc_rsp_pkts;
+#ifdef CONFIG_RTW_80211R
+void rtw_ft_update_bcn(_adapter *padapter, union recv_frame *precv_frame)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	uint len = precv_frame->u.hdr.len;
+	WLAN_BSSID_EX *pbss;
+
+	if (rtw_ft_chk_status(padapter,RTW_FT_ASSOCIATED_STA) 
+		&& (pmlmepriv->ft_roam.ft_updated_bcn == _FALSE)) {
+		pbss = (WLAN_BSSID_EX*)rtw_malloc(sizeof(WLAN_BSSID_EX));
+		if (pbss) {
+			if (collect_bss_info(padapter, precv_frame, pbss) == _SUCCESS) {
+				struct beacon_keys recv_beacon;
+
+				update_network(&(pmlmepriv->cur_network.network), pbss, padapter, _TRUE);
+				rtw_get_bcn_info(&(pmlmepriv->cur_network));
+				
+				/* update bcn keys */
+				if (rtw_get_bcn_keys(padapter, pframe, len, &recv_beacon) == _TRUE) {
+					RTW_INFO("%s: beacon keys ready\n", __func__);
+					_rtw_memcpy(&pmlmepriv->cur_beacon_keys,
+						&recv_beacon, sizeof(recv_beacon));
+					pmlmepriv->new_beacon_cnts = 0;
+				} else {
+					RTW_ERR("%s: get beacon keys failed\n", __func__);
+					_rtw_memset(&pmlmepriv->cur_beacon_keys, 0, sizeof(recv_beacon));
+					pmlmepriv->new_beacon_cnts = 0;
 				}
 			}
+			rtw_mfree((u8*)pbss, sizeof(WLAN_BSSID_EX));
 		}
-		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-		if (num_checkalive > 0) {
-			for (i = 0; i < num_checkalive; i++) {
-				_rtw_memcpy(txmgmt.peer, checkalive[i].addr, ETH_ALEN);
-				issue_tdls_dis_req(padapter, &txmgmt);
-				issue_tdls_dis_req(padapter, &txmgmt);
-				issue_tdls_dis_req(padapter, &txmgmt);
-			}
-		}
+		/* check the vendor of the assoc AP */
+		pmlmeinfo->assoc_AP_vendor = 	
+			check_assoc_AP(pframe+sizeof(struct rtw_ieee80211_hdr_3addr),
+				(len - sizeof(struct rtw_ieee80211_hdr_3addr)));
 
-		if(num_teardown > 0)
-		{
-			for(i=0; i< num_teardown; i++)
-			{
-				DBG_871X("[%s %d] Send teardown to "MAC_FMT" \n", __FUNCTION__, __LINE__, MAC_ARG(teardown[i].addr));
-				txmgmt.status_code = _RSON_TDLS_TEAR_TOOFAR_;
-				_rtw_memcpy(txmgmt.peer, teardown[i].addr, ETH_ALEN);
-				issue_tdls_teardown(padapter, &txmgmt, _FALSE);
-			}
-		}
+		/* update TSF Value */
+		update_TSF(pmlmeext, pframe, len);
+
+		/* reset for adaptive_early_32k */
+		pmlmeext->adaptive_tsf_done = _FALSE;
+		pmlmeext->DrvBcnEarly = 0xff;
+		pmlmeext->DrvBcnTimeOut = 0xff;
+		pmlmeext->bcn_cnt = 0;
+		_rtw_memset(pmlmeext->bcn_delay_cnt, 0, sizeof(pmlmeext->bcn_delay_cnt));
+		_rtw_memset(pmlmeext->bcn_delay_ratio, 0, sizeof(pmlmeext->bcn_delay_ratio));
+
+		pmlmepriv->ft_roam.ft_updated_bcn = _TRUE;
+	}
+}
+
+void rtw_ft_start_clnt_join(_adapter *padapter)
+{
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct	mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+
+	if (rtw_ft_otd_roam(padapter)) {
+		pmlmeinfo->state = WIFI_FW_AUTH_SUCCESS | WIFI_FW_STATION_STATE;
+		pft_roam->ft_event.ies =
+			(pft_roam->ft_action + sizeof(struct rtw_ieee80211_hdr_3addr) + 16);
+		pft_roam->ft_event.ies_len =
+			(pft_roam->ft_action_len - sizeof(struct rtw_ieee80211_hdr_3addr));
+
+		/*Not support RIC*/
+		pft_roam->ft_event.ric_ies =  NULL;
+		pft_roam->ft_event.ric_ies_len = 0;
+		rtw_ft_report_evt(padapter);
+		return;
 	}
 
+	pmlmeinfo->state = WIFI_FW_AUTH_NULL | WIFI_FW_STATION_STATE;
+	start_clnt_auth(padapter);
 }
-#endif //CONFIG_TDLS
 
-//from_timer == 1 means driver is in LPS
-void linked_status_chk(_adapter *padapter, u8 from_timer)
+u8 rtw_ft_update_rsnie(
+	_adapter *padapter, u8 bwrite, 
+	struct pkt_attrib *pattrib, u8 **pframe)
 {
-	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;
-#ifdef CONFIG_ARP_KEEP_ALIVE
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-#endif
-	
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u8 *pie;
+	u32 len;
 
-	if (is_client_associated_to_ap(padapter))
-	{
-		//linked infrastructure client mode
+	pie = rtw_get_ie(pft_roam->updated_ft_ies, EID_WPA2, &len, 
+			pft_roam->updated_ft_ies_len);
 
-		int tx_chk = _SUCCESS, rx_chk = _SUCCESS;
-		int rx_chk_limit;
-		int link_count_limit;
+	if (!bwrite)
+		return (pie)?_SUCCESS:_FAIL;
+	
+	if (pie) {
+		*pframe = rtw_set_ie(((u8 *)*pframe), EID_WPA2, len, 
+						pie+2, &(pattrib->pktlen));
+	} else
+		return _FAIL;
 
-		#if defined(DBG_ROAMING_TEST)
-		rx_chk_limit = 1;
-		#elif defined(CONFIG_ACTIVE_KEEP_ALIVE_CHECK) && !defined(CONFIG_LPS_LCLK_WD_TIMER)
-		rx_chk_limit = 4;
-		#else
-		rx_chk_limit = 8;
-		#endif
-#ifdef CONFIG_ARP_KEEP_ALIVE
-		if (!from_timer && pmlmepriv->bGetGateway == 1) {
-			DBG_871X("do rtw_gw_addr_query()");
-			if (rtw_gw_addr_query(padapter) == 0) {
-				pmlmepriv->bGetGateway = 0;
-			} else {
-				_rtw_memset(pmlmepriv->gw_ip, 0, 4);
-				_rtw_memset(pmlmepriv->gw_mac_addr, 0, 6);
-			}
-		}
-#endif
-#ifdef CONFIG_P2P
-		if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE))
-		{
-			if(!from_timer)
-				link_count_limit = 3; // 8 sec
-			else
-				link_count_limit = 15; // 32 sec
-		}
-		else
-#endif // CONFIG_P2P
-		{
-			if(!from_timer)
-				link_count_limit = 7; // 16 sec
-			else
-				link_count_limit = 29; // 60 sec
-		}		
+	return _SUCCESS;	
+}
 
-#ifdef CONFIG_TDLS
-#ifdef CONFIG_TDLS_CH_SW
-		if (ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on) == _TRUE)
-			return;
-#endif /* CONFIG_TDLS_CH_SW */
+static u8 rtw_ft_update_mdie(
+	_adapter *padapter, struct pkt_attrib *pattrib, u8 **pframe)
+{
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u8 *pie, mdie[3];
+	u32 len = 3;
+
+	if (rtw_ft_roam(padapter)) {
+		if ((pie = rtw_get_ie(pft_roam->updated_ft_ies, _MDIE_, 
+				&len, pft_roam->updated_ft_ies_len))) {
+			pie = (pie + 2); /* ignore md-id & length */
+		} else 
+			return _FAIL;
+	} else {
+		*((u16 *)&mdie[0]) = pft_roam->mdid;
+		mdie[2] = pft_roam->ft_cap;
+		pie = &mdie[0];
+	}
 
-#ifdef CONFIG_TDLS_AUTOCHECKALIVE
-		linked_status_chk_tdls(padapter);
-#endif /* CONFIG_TDLS_AUTOCHECKALIVE */
-#endif /* CONFIG_TDLS */
+	*pframe = rtw_set_ie(((u8 *)*pframe), _MDIE_, len , pie, &(pattrib->pktlen));
+	return _SUCCESS;	
+}
 
-		if ((psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress)) != NULL)
-		{
-			bool is_p2p_enable = _FALSE;
-			#ifdef CONFIG_P2P
-			is_p2p_enable = !rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE);
-			#endif
+static u8 rtw_ft_update_ftie(
+	_adapter *padapter, struct pkt_attrib *pattrib, u8 **pframe)
+{
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u8 *pie;
+	u32 len;
+
+	if ((pie = rtw_get_ie(pft_roam->updated_ft_ies, _FTIE_, &len, 
+				pft_roam->updated_ft_ies_len)) != NULL) {
+		*pframe = rtw_set_ie(*pframe, _FTIE_, len , 
+					(pie+2), &(pattrib->pktlen));
+	} else
+		return _FAIL;
 
-			/*issue delba when ap does not tx data packet that is Broadcom ap */
-			rtw_delba_check(padapter, psta, from_timer);
+	return _SUCCESS;	
+}
 
-			if (chk_ap_is_alive(padapter, psta) == _FALSE)
-				rx_chk = _FAIL;
+void rtw_ft_build_auth_req_ies(_adapter *padapter, 
+	struct pkt_attrib *pattrib, u8 **pframe)
+{
+	u8 ftie_append = _TRUE;
 
-			if (pxmitpriv->last_tx_pkts == pxmitpriv->tx_pkts)
-				tx_chk = _FAIL;
+	if (!pattrib || !(*pframe))
+		return;
 
-			#if defined(CONFIG_ACTIVE_KEEP_ALIVE_CHECK) && !defined(CONFIG_LPS_LCLK_WD_TIMER)
-			if (pmlmeext->active_keep_alive_check && (rx_chk == _FAIL || tx_chk == _FAIL)) {
-				u8 backup_ch = 0, backup_bw, backup_offset;
-				u8 union_ch = 0, union_bw, union_offset;
-
-				if (!rtw_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
-					|| pmlmeext->cur_channel != union_ch)
-						goto bypass_active_keep_alive;
-
-				/* switch to correct channel of current network  before issue keep-alive frames */
-				if (rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
-					backup_ch = rtw_get_oper_ch(padapter);
-					backup_bw = rtw_get_oper_bw(padapter);
-					backup_offset = rtw_get_oper_choffset(padapter);
-					set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
-				}
+	if (!rtw_ft_roam(padapter))
+		return;
 
-				if (rx_chk != _SUCCESS)
-					issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, psta->hwaddr, 0, 0, 3, 1);
+	ftie_append = rtw_ft_update_rsnie(padapter, _TRUE, pattrib, pframe);
+	rtw_ft_update_mdie(padapter, pattrib, pframe);
+	if (ftie_append)
+		rtw_ft_update_ftie(padapter, pattrib, pframe);
+}
 
-				if ((tx_chk != _SUCCESS && pmlmeinfo->link_count++ == link_count_limit) || rx_chk != _SUCCESS) {
-					tx_chk = issue_nulldata(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;
-				}
+void rtw_ft_build_assoc_req_ies(_adapter *padapter, 
+	u8 is_reassoc, struct pkt_attrib *pattrib, u8 **pframe)
+{
+	if (!pattrib || !(*pframe))
+		return;
 
-				/* back to the original operation channel */
-				if (backup_ch > 0)
-					set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
+	if (rtw_ft_chk_flags(padapter, RTW_FT_PEER_EN))
+		rtw_ft_update_mdie(padapter, pattrib, pframe);
 
-bypass_active_keep_alive:
-				;
-			}
-			else
-			#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
-			{
-				if (rx_chk != _SUCCESS) {
-					if (pmlmeext->retry == 0) {
-						#ifdef DBG_EXPIRATION_CHK
-						DBG_871X("issue_probereq to trigger probersp, retry=%d\n", pmlmeext->retry);
-						#endif
-						issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, 0);
-						issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, 0);
-						issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, 0);
-					}
-				}
+	if ((!is_reassoc) || (!rtw_ft_roam(padapter)))
+		return;
 
-				if (tx_chk != _SUCCESS && pmlmeinfo->link_count++ == link_count_limit) {
-					#ifdef DBG_EXPIRATION_CHK
-					DBG_871X("%s issue_nulldata(%d)\n", __FUNCTION__, from_timer?1:0);
-					#endif
-					tx_chk = issue_nulldata_in_interrupt(padapter, NULL, from_timer?1:0);
-				}
-			}
+	if (rtw_ft_update_rsnie(padapter, _FALSE, pattrib, pframe))
+		rtw_ft_update_ftie(padapter, pattrib, pframe);	
+}
 
-			if (rx_chk == _FAIL) {
-				pmlmeext->retry++;
-				if (pmlmeext->retry > rx_chk_limit) {
-					DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" disconnect or roaming\n",
-						FUNC_ADPT_ARG(padapter));
-					receive_disconnect(padapter, pmlmeinfo->network.MacAddress
-						, WLAN_REASON_EXPIRATION_CHK, _FALSE);
-					return;
-				}
-			} else {
-				pmlmeext->retry = 0;
-			}
+u8 rtw_ft_update_auth_rsp_ies(_adapter *padapter, u8 *pframe, u32 len)
+{
+	u8 ret = _SUCCESS;
+	u8 target_ap_addr[ETH_ALEN] = {0};
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
 
-			if (tx_chk == _FAIL) {
-				pmlmeinfo->link_count %= (link_count_limit+1);
-			} else {
-				pxmitpriv->last_tx_pkts = pxmitpriv->tx_pkts;
-				pmlmeinfo->link_count = 0;
-			}
+	if (!rtw_ft_roam(padapter))
+		return _FAIL;
 
-		} //end of if ((psta = rtw_get_stainfo(pstapriv, passoc_res->network.MacAddress)) != NULL)
+	/*rtw_ft_report_reassoc_evt already,
+	 * and waiting for cfg80211_rtw_update_ft_ies */
+	if (rtw_ft_authed_sta(padapter))
+		return ret;
 
-	} else if (is_client_associated_to_ibss(padapter)) {
-		_irqL irqL;
-		_list *phead, *plist, dlist;
+	if (!pframe || !len)
+		return _FAIL;
+	
+	rtw_buf_update(&pmlmepriv->auth_rsp, 
+		&pmlmepriv->auth_rsp_len, pframe, len);
+	pft_roam->ft_event.ies =
+		(pmlmepriv->auth_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6);
+	pft_roam->ft_event.ies_len =
+		(pmlmepriv->auth_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6);
+
+	/*Not support RIC*/
+	pft_roam->ft_event.ric_ies =  NULL;
+	pft_roam->ft_event.ric_ies_len =  0;
+	_rtw_memcpy(target_ap_addr, pmlmepriv->assoc_bssid, ETH_ALEN);
+	rtw_ft_report_reassoc_evt(padapter, target_ap_addr);
+
+	return ret;	
+}
 
-		_rtw_init_listhead(&dlist);
+static void rtw_ft_start_clnt_action(_adapter *padapter, u8 *pTargetAddr)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	rtw_ft_set_status(padapter, RTW_FT_REQUESTING_STA);
+	rtw_ft_issue_action_req(padapter, pTargetAddr);
+	_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
+}
 
-		for (i = 0; i < NUM_STA; i++) {
+void rtw_ft_start_roam(_adapter *padapter, u8 *pTargetAddr)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-			phead = &(pstapriv->sta_hash[i]);
-			plist = get_next(phead);
-			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
-				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
-				plist = get_next(plist);
+	if (rtw_ft_otd_roam(padapter)) {
+		rtw_ft_start_clnt_action(padapter, pTargetAddr);
+	} else {
+		/*wait a little time to retrieve packets buffered in the current ap while scan*/
+		_set_timer(&pmlmeext->ft_roam_timer, 30);
+	}
+}
 
-				if (is_broadcast_mac_addr(psta->hwaddr))
-					continue;
+void rtw_ft_issue_action_req(_adapter *padapter, u8 *pTargetAddr)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct xmit_frame *pmgntframe;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct pkt_attrib *pattrib;
+	u8 *pframe;
+	u8 category = RTW_WLAN_CATEGORY_FT;
+	u8 action = RTW_WLAN_ACTION_FT_REQ;
 
-				if (chk_adhoc_peer_is_alive(psta) || !psta->expire_to)
-					psta->expire_to = pstapriv->adhoc_expire_to;
-				else
-					psta->expire_to--;
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return;
 
-				if (psta->expire_to <= 0) {
-					rtw_list_delete(&psta->list);
-					rtw_list_insert_tail(&psta->list, &dlist);
-				}
-			}
-		}
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
-		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	pwlanhdr->frame_ctl = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
 
-		plist = get_next(&dlist);
-		while (rtw_end_of_queue_search(&dlist, plist) == _FALSE) {
-			psta = LIST_CONTAINOR(plist, struct sta_info, list);
-			plist = get_next(plist);
-			rtw_list_delete(&psta->list);
-			DBG_871X(FUNC_ADPT_FMT" ibss expire "MAC_FMT"\n"
-				, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->hwaddr));
-			report_del_sta_event(padapter, psta->hwaddr, WLAN_REASON_EXPIRATION_CHK, from_timer ? _TRUE : _FALSE, _FALSE);
-		}
-	}
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
-}
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-void survey_timer_hdl(_adapter *padapter)
-{
-	struct cmd_obj *cmd;
-	struct sitesurvey_parm *psurveyPara;
-	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 
-	if (mlmeext_scan_state(pmlmeext) > SCAN_DISABLE) {
-		cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
-		if (cmd == NULL) {
-			rtw_warn_on(1);
-			goto exit;
-		}
+	_rtw_memcpy(pframe, adapter_mac_addr(padapter), ETH_ALEN);
+	pframe += ETH_ALEN;
+	pattrib->pktlen += ETH_ALEN;
 
-		psurveyPara = (struct sitesurvey_parm *)rtw_zmalloc(sizeof(struct sitesurvey_parm));
-		if (psurveyPara == NULL) {
-			rtw_warn_on(1);
-			rtw_mfree((unsigned char *)cmd, sizeof(struct cmd_obj));
-			goto exit;
-		}
+	_rtw_memcpy(pframe, pTargetAddr, ETH_ALEN);
+	pframe += ETH_ALEN;
+	pattrib->pktlen += ETH_ALEN;
 
-		init_h2fwcmd_w_parm_no_rsp(cmd, psurveyPara, GEN_CMD_CODE(_SiteSurvey));
-		rtw_enqueue_cmd(pcmdpriv, cmd);
-	}
+	rtw_ft_update_mdie(padapter, pattrib, &pframe);
+	if (rtw_ft_update_rsnie(padapter, _TRUE, pattrib, &pframe))
+		rtw_ft_update_ftie(padapter, pattrib, &pframe);
 
-exit:
-	return;
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
 }
 
-void link_timer_hdl(_adapter *padapter)
+void rtw_ft_report_evt(_adapter *padapter)
 {
-	//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;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&(pmlmeinfo->network);
+	struct cfg80211_ft_event_params ft_evt_parms;
+	_irqL irqL;
 
+	_rtw_memset(&ft_evt_parms, 0, sizeof(ft_evt_parms));
+	rtw_ft_update_stainfo(padapter, pnetwork);
 
-	if (pmlmeinfo->state & WIFI_FW_AUTH_NULL)
-	{
-		DBG_871X("link_timer_hdl:no beacon while connecting\n");
-		pmlmeinfo->state = WIFI_FW_NULL_STATE;
-		report_join_res(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_res(padapter, -1);
-				return;
-			//}
-			//else
-			//{
-			//	pmlmeinfo->auth_algo = dot11AuthAlgrthm_Shared;
-			//	pmlmeinfo->reauth_count = 0;
-			//}
-		}
-		
-		DBG_871X("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 = WIFI_FW_NULL_STATE;
-			report_join_res(padapter, -2);
-			return;
-		}
+	if (!pnetwork)
+		goto err_2;
 
-		DBG_871X("link_timer_hdl: assoc timeout and try again\n");
-		issue_assocreq(padapter);
-		set_link_timer(pmlmeext, REASSOC_TO);
-	}
+	ft_evt_parms.ies_len = pft_roam->ft_event.ies_len;
+	ft_evt_parms.ies =  rtw_zmalloc(ft_evt_parms.ies_len);
+	if (ft_evt_parms.ies)
+		_rtw_memcpy((void *)ft_evt_parms.ies, pft_roam->ft_event.ies, ft_evt_parms.ies_len);
+	 else
+		goto err_2;
 
+	ft_evt_parms.target_ap = rtw_zmalloc(ETH_ALEN);
+	if (ft_evt_parms.target_ap)
+		_rtw_memcpy((void *)ft_evt_parms.target_ap, pnetwork->MacAddress, ETH_ALEN);
+	else
+		goto err_1;
+
+	ft_evt_parms.ric_ies = pft_roam->ft_event.ric_ies;
+	ft_evt_parms.ric_ies_len = pft_roam->ft_event.ric_ies_len;
+
+	rtw_ft_lock_set_status(padapter, RTW_FT_AUTHENTICATED_STA, &irqL);
+	rtw_cfg80211_ft_event(padapter, &ft_evt_parms);
+	RTW_INFO("FT: rtw_ft_report_evt\n");
+	rtw_mfree((u8 *)pft_roam->ft_event.target_ap, ETH_ALEN);
+err_1:
+	rtw_mfree((u8 *)ft_evt_parms.ies, ft_evt_parms.ies_len);
+err_2:
 	return;
 }
 
-void addba_timer_hdl(struct sta_info *psta)
+void rtw_ft_report_reassoc_evt(_adapter *padapter, u8 *pMacAddr)
 {
-#ifdef CONFIG_80211N_HT
-	struct ht_priv	*phtpriv;
-
-	if(!psta)
-		return;
-	
-	phtpriv = &psta->htpriv;
-
-	if((phtpriv->ht_option==_TRUE) && (phtpriv->ampdu_enable==_TRUE)) 
-	{
-		if(phtpriv->candidate_tid_bitmap)
-			phtpriv->candidate_tid_bitmap=0x0;
-		
-	}
-#endif //CONFIG_80211N_HT
-}
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
+	struct cmd_obj *pcmd_obj = NULL;
+	struct stassoc_event *passoc_sta_evt = NULL;
+	struct C2HEvent_Header *pc2h_evt_hdr = NULL;
+	u8 *pevtcmd = NULL;
+	u32 cmdsz = 0;
 
-#ifdef CONFIG_IEEE80211W
-void report_sta_timeout_event(_adapter *padapter, u8 *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 = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (pcmd_obj == NULL)
 		return;
 
-	cmdsz = (sizeof(struct stadel_event) + sizeof(struct C2HEvent_Header));
+	cmdsz = (sizeof(struct stassoc_event) + sizeof(struct C2HEvent_Header));
 	pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
 	if (pevtcmd == NULL) {
 		rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
@@ -12689,64 +13876,66 @@ void report_sta_timeout_event(_adapter *padapter, u8 *MacAddr, unsigned short re
 	}
 
 	_rtw_init_listhead(&pcmd_obj->list);
-
 	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(_TimeoutSTA);
+	pc2h_evt_hdr->len = sizeof(struct stassoc_event);
+	pc2h_evt_hdr->ID = GEN_EVT_CODE(_FT_REASSOC);
 	pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
 
-	pdel_sta_evt = (struct stadel_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
-	_rtw_memcpy((unsigned char *)(&(pdel_sta_evt->macaddr)), MacAddr, ETH_ALEN);
-	_rtw_memcpy((unsigned char *)(pdel_sta_evt->rsvd), (unsigned char *)(&reason), 2);
-
-
-	psta = rtw_get_stainfo(&padapter->stapriv, MacAddr);
-	if (psta)
-		mac_id = (int)psta->mac_id;	
-	else
-		mac_id = (-1);
-
-	pdel_sta_evt->mac_id = mac_id;
-
-	DBG_871X("report_del_sta_event: delete STA, mac_id=%d\n", mac_id);
-
+	passoc_sta_evt = (struct stassoc_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
+	_rtw_memcpy((unsigned char *)(&(passoc_sta_evt->macaddr)), pMacAddr, ETH_ALEN);
 	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
-
-	return;
 }
 
-void clnt_sa_query_timeout(_adapter *padapter)
+void rtw_ft_link_timer_hdl(void *ctx)
 {
+	_adapter *padapter = (_adapter *)ctx;
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
 
-	rtw_disassoc_cmd(padapter, 0, _TRUE);
-	rtw_indicate_disconnect(padapter, 0,  _FALSE);
-	rtw_free_assoc_resources(padapter, 1);	
-
-	DBG_871X("SA query timeout client disconnect\n");
+	if (rtw_ft_chk_status(padapter, RTW_FT_REQUESTING_STA)) {
+		if (pft_roam->ft_req_retry_cnt < RTW_FT_ACTION_REQ_LMT) {
+			pft_roam->ft_req_retry_cnt++;
+			rtw_ft_issue_action_req(padapter, (u8 *)pmlmepriv->roam_network->network.MacAddress);
+			_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
+		} else {
+			pft_roam->ft_req_retry_cnt = 0;	
+			if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
+				rtw_ft_set_status(padapter, RTW_FT_ASSOCIATED_STA);
+			else
+				rtw_ft_reset_status(padapter);
+		}
+	}
 }
 
-void sa_query_timer_hdl(struct sta_info *psta)
+void rtw_ft_roam_timer_hdl(void *ctx)
 {
-	_adapter *padapter = psta->padapter;
-	_irqL irqL;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	_adapter *padapter = (_adapter *)ctx;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
-	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE &&
-					check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
-		clnt_sa_query_timeout(padapter);
-	else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-		report_sta_timeout_event(padapter, psta->hwaddr, WLAN_REASON_PREV_AUTH_NOT_VALID);
+	receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress
+				, WLAN_REASON_ACTIVE_ROAM, _FALSE);
 }
 
-#endif //CONFIG_IEEE80211W
+void rtw_ft_roam_status_reset(_adapter *padapter)
+{
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+
+	if ((rtw_to_roam(padapter) > 0) && 
+		(!rtw_ft_chk_status(padapter, RTW_FT_REQUESTED_STA))) {
+		rtw_ft_reset_status(padapter);
+	}	
+	
+	padapter->mlmepriv.ft_roam.ft_updated_bcn = _FALSE;
+}
+#endif
 
 u8 NULL_hdl(_adapter *padapter, u8 *pbuf)
 {
@@ -12754,108 +13943,125 @@ u8 NULL_hdl(_adapter *padapter, u8 *pbuf)
 }
 
 #ifdef CONFIG_AUTO_AP_MODE
+void rtw_auto_ap_rx_msg_dump(_adapter *padapter, union recv_frame *precv_frame, u8 *ehdr_pos)
+{
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct sta_info *psta = precv_frame->u.hdr.psta;
+	struct ethhdr *ehdr = (struct ethhdr *)ehdr_pos;
+
+	RTW_INFO("eth rx: got eth_type=0x%x\n", ntohs(ehdr->h_proto));
+
+	if (psta && psta->isrc && psta->pid > 0) {
+		u16 rx_pid;
+
+		rx_pid = *(u16 *)(ehdr_pos + ETH_HLEN);
+
+		RTW_INFO("eth rx(pid=0x%x): sta("MAC_FMT") pid=0x%x\n",
+			 rx_pid, MAC_ARG(psta->cmn.mac_addr), psta->pid);
+
+		if (rx_pid == psta->pid) {
+			int i;
+			u16 len = *(u16 *)(ehdr_pos + ETH_HLEN + 2);
+			/* u16 ctrl_type = *(u16 *)(ehdr_pos + ETH_HLEN + 4); */
+
+			/* RTW_INFO("eth, RC: len=0x%x, ctrl_type=0x%x\n", len, ctrl_type);  */
+			RTW_INFO("eth, RC: len=0x%x\n", len);
+
+			for (i = 0; i < len; i++)
+				RTW_INFO("0x%x\n", *(ehdr_pos + ETH_HLEN + 4 + i));
+			/* RTW_INFO("0x%x\n", *(ehdr_pos + ETH_HLEN + 6 + i)); */
+
+			RTW_INFO("eth, RC-end\n");
+		}
+	}
+
+}
+
 void rtw_start_auto_ap(_adapter *adapter)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11APMode);
 
-	rtw_setopmode_cmd(adapter, Ndis802_11APMode,_TRUE);
+	rtw_setopmode_cmd(adapter, Ndis802_11APMode, RTW_CMDF_WAIT_ACK);
 }
 
 static int rtw_auto_ap_start_beacon(_adapter *adapter)
 {
-	int ret=0;
+	int ret = 0;
 	u8 *pbuf = NULL;
 	uint len;
 	u8	supportRate[16];
-	int 	sz = 0, rateLen;
-	u8 *	ie;
+	int	sz = 0, rateLen;
+	u8	*ie;
 	u8	wireless_mode, oper_channel;
-	u8 ssid[3] = {0}; //hidden ssid
+	u8 ssid[3] = {0}; /* hidden ssid */
 	u32 ssid_len = sizeof(ssid);
 	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
 
 
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
 
 	len = 128;
 	pbuf = rtw_zmalloc(len);
-	if(!pbuf)
+	if (!pbuf)
 		return -ENOMEM;
 
 
-	//generate beacon
+	/* generate beacon */
 	ie = pbuf;
 
-	//timestamp will be inserted by hardware
+	/* timestamp will be inserted by hardware */
 	sz += 8;
 	ie += sz;
 
-	//beacon interval : 2bytes
-	*(u16*)ie = cpu_to_le16((u16)100);//BCN_INTERVAL=100;
+	/* beacon interval : 2bytes */
+	*(u16 *)ie = cpu_to_le16((u16)100); /* BCN_INTERVAL=100; */
 	sz += 2;
 	ie += 2;
 
-	//capability info
-	*(u16*)ie = 0;
-	*(u16*)ie |= cpu_to_le16(cap_ESS);
-	*(u16*)ie |= cpu_to_le16(cap_ShortPremble);
-	//*(u16*)ie |= cpu_to_le16(cap_Privacy);
+	/* capability info */
+	*(u16 *)ie = 0;
+	*(u16 *)ie |= cpu_to_le16(cap_ESS);
+	*(u16 *)ie |= cpu_to_le16(cap_ShortPremble);
+	/* *(u16*)ie |= cpu_to_le16(cap_Privacy); */
 	sz += 2;
 	ie += 2;
 
-	//SSID
+	/* SSID */
 	ie = rtw_set_ie(ie, _SSID_IE_, ssid_len, ssid, &sz);
 
-	//supported rates
+	/* supported rates */
 	wireless_mode = WIRELESS_11BG_24N;
 	rtw_set_supported_rate(supportRate, wireless_mode) ;
 	rateLen = rtw_get_rateset_len(supportRate);
 	if (rateLen > 8)
-	{
 		ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, 8, supportRate, &sz);
-	}
 	else
-	{
 		ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, rateLen, supportRate, &sz);
-	}
-
 
-	//DS parameter set
-	if(check_buddy_fwstate(adapter, _FW_LINKED) &&
-		check_buddy_fwstate(adapter, WIFI_STATION_STATE))
-	{
-		PADAPTER pbuddy_adapter = adapter->pbuddy_adapter;
-		struct mlme_ext_priv *pbuddy_mlmeext  = &pbuddy_adapter->mlmeextpriv;
 
-		oper_channel = pbuddy_mlmeext->cur_channel;
-	}
+	/* DS parameter set */
+	if (rtw_mi_check_status(adapter, MI_LINKED))
+		oper_channel = rtw_mi_get_union_chan(adapter);
 	else
-	{
 		oper_channel = adapter_to_dvobj(adapter)->oper_channel;
-	}
+
 	ie = rtw_set_ie(ie, _DSSET_IE_, 1, &oper_channel, &sz);
 
-	//ext supported rates
+	/* ext supported rates */
 	if (rateLen > 8)
-	{
 		ie = rtw_set_ie(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (supportRate + 8), &sz);
-	}
 
-	DBG_871X("%s, start auto ap beacon sz=%d\n", __FUNCTION__, sz);
+	RTW_INFO("%s, start auto ap beacon sz=%d\n", __FUNCTION__, sz);
 
-	//lunch ap mode & start to issue beacon
-	if(rtw_check_beacon_data(adapter, pbuf,  sz) == _SUCCESS)
-	{
+	/* lunch ap mode & start to issue beacon */
+	if (rtw_check_beacon_data(adapter, pbuf,  sz) == _SUCCESS) {
 
-	}
-	else
-	{
+	} else
 		ret = -EINVAL;
-	}
 
 
 	rtw_mfree(pbuf, len);
@@ -12863,7 +14069,7 @@ static int rtw_auto_ap_start_beacon(_adapter *adapter)
 	return ret;
 
 }
-#endif//CONFIG_AUTO_AP_MODE
+#endif/* CONFIG_AUTO_AP_MODE */
 
 u8 setopmode_hdl(_adapter *padapter, u8 *pbuf)
 {
@@ -12872,78 +14078,72 @@ u8 setopmode_hdl(_adapter *padapter, u8 *pbuf)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct setopmode_parm *psetop = (struct setopmode_parm *)pbuf;
 
-	if(psetop->mode == Ndis802_11APMode)
-	{
+	if (psetop->mode == Ndis802_11APMode
+		|| psetop->mode == Ndis802_11_mesh
+	) {
 		pmlmeinfo->state = WIFI_FW_AP_STATE;
 		type = _HW_STATE_AP_;
-#ifdef CONFIG_NATIVEAP_MLME
-		//start_ap_mode(padapter);
-#endif
-	}
-	else if(psetop->mode == Ndis802_11Infrastructure)
-	{
-		pmlmeinfo->state &= ~(BIT(0)|BIT(1));// clear state
-		pmlmeinfo->state |= WIFI_FW_STATION_STATE;//set to 	STATION_STATE
+	} else if (psetop->mode == Ndis802_11Infrastructure) {
+		pmlmeinfo->state &= ~(BIT(0) | BIT(1)); /* clear state */
+		pmlmeinfo->state |= WIFI_FW_STATION_STATE;/* set to 	STATION_STATE */
 		type = _HW_STATE_STATION_;
-	}
-	else if(psetop->mode == Ndis802_11IBSS)
-	{
+	} else if (psetop->mode == Ndis802_11IBSS)
 		type = _HW_STATE_ADHOC_;
-	} else if (psetop->mode == Ndis802_11Monitor) {
+	else if (psetop->mode == Ndis802_11Monitor)
 		type = _HW_STATE_MONITOR_;
-	}
 	else
-	{
 		type = _HW_STATE_NOLINK_;
-	}
 
-	rtw_hal_set_hwreg(padapter, HW_VAR_SET_OPMODE, (u8 *)(&type));
-	//Set_NETYPE0_MSR(padapter, type);
+#ifdef CONFIG_AP_PORT_SWAP
+	rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, (u8 *)(&type));
+#endif
 
+	rtw_hal_set_hwreg(padapter, HW_VAR_SET_OPMODE, (u8 *)(&type));
 
 #ifdef CONFIG_AUTO_AP_MODE
-	if(psetop->mode == Ndis802_11APMode)
+	if (psetop->mode == Ndis802_11APMode)
 		rtw_auto_ap_start_beacon(padapter);
 #endif
 
-	if (rtw_port_switch_chk(padapter) == _TRUE)
-	{
+	if (rtw_port_switch_chk(padapter) == _TRUE) {
 		rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
 
-		if(psetop->mode == Ndis802_11APMode)
-			adapter_to_pwrctl(padapter)->fw_psmode_iface_id = 0xff; //ap mode won't dowload rsvd pages
+		if (psetop->mode == Ndis802_11APMode)
+			adapter_to_pwrctl(padapter)->fw_psmode_iface_id = 0xff; /* ap mode won't dowload rsvd pages */
 		else if (psetop->mode == Ndis802_11Infrastructure) {
-			#ifdef CONFIG_LPS
+#ifdef CONFIG_LPS
 			_adapter *port0_iface = dvobj_get_port0_adapter(adapter_to_dvobj(padapter));
 			if (port0_iface)
 				rtw_lps_ctrl_wk_cmd(port0_iface, LPS_CTRL_CONNECT, 0);
-			#endif	
+#endif
 		}
-	}	
+	}
 
 #ifdef CONFIG_BT_COEXIST
-	if (psetop->mode == Ndis802_11APMode)
-	{
-		// Do this after port switch to
-		// prevent from downloading rsvd page to wrong port
-		rtw_btcoex_MediaStatusNotify(padapter, 1); //connect 
+	if (psetop->mode == Ndis802_11APMode
+		|| psetop->mode == Ndis802_11_mesh
+		|| psetop->mode == Ndis802_11Monitor
+	) {
+		/* Do this after port switch to */
+		/* prevent from downloading rsvd page to wrong port */
+		rtw_btcoex_MediaStatusNotify(padapter, 1); /* connect */
 	}
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 	return H2C_SUCCESS;
-	
+
 }
 
 u8 createbss_hdl(_adapter *padapter, u8 *pbuf)
 {
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX	*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
+	WLAN_BSSID_EX	*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 	WLAN_BSSID_EX	*pdev_network = &padapter->registrypriv.dev_network;
 	struct createbss_parm *parm = (struct createbss_parm *)pbuf;
 	u8 ret = H2C_SUCCESS;
-	//u8	initialgain;
-	
+	/* u8	initialgain; */
+
 #ifdef CONFIG_AP_MODE
 	if (pmlmeinfo->state == WIFI_FW_AP_STATE) {
 		start_bss_network(padapter, parm);
@@ -12955,9 +14155,9 @@ u8 createbss_hdl(_adapter *padapter, u8 *pbuf)
 	if (parm->adhoc) {
 		rtw_warn_on(pdev_network->InfrastructureMode != Ndis802_11IBSS);
 		rtw_joinbss_reset(padapter);
-	
+
 		pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
-		pmlmeext->cur_ch_offset= HAL_PRIME_CHNL_OFFSET_DONT_CARE;	
+		pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 		pmlmeinfo->ERP_enable = 0;
 		pmlmeinfo->WMM_enable = 0;
 		pmlmeinfo->HT_enable = 0;
@@ -12966,19 +14166,11 @@ u8 createbss_hdl(_adapter *padapter, u8 *pbuf)
 		pmlmeinfo->agg_enable_bitmap = 0;
 		pmlmeinfo->candidate_tid_bitmap = 0;
 
-		//config the initial gain under linking, need to write the BB registers
-		//initialgain = 0x1E;
-		/*rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);*/
-
-		//disable dynamic functions, such as high power, DIG
-		rtw_phydm_ability_backup(padapter);
-		rtw_phydm_func_disable_all(padapter);
-		
-		//cancel link timer 
+		/* cancel link timer */
 		_cancel_timer_ex(&pmlmeext->link_timer);
 
-		//clear CAM
-		flush_all_cam_entry(padapter);	
+		/* clear CAM */
+		flush_all_cam_entry(padapter);
 
 		pdev_network->Length = get_WLAN_BSSID_EX_sz(pdev_network);
 		_rtw_memcpy(pnetwork, pdev_network, FIELD_OFFSET(WLAN_BSSID_EX, IELength));
@@ -13010,34 +14202,31 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 #ifdef CONFIG_ANTENNA_DIVERSITY
 	struct joinbss_parm	*pparm = (struct joinbss_parm *)pbuf;
-#endif //CONFIG_ANTENNA_DIVERSITY
+#endif /* CONFIG_ANTENNA_DIVERSITY */
 	u32 i;
-	//u8	initialgain;
-	//u32	acparm;
+	/* u8	initialgain; */
+	/* u32	acparm; */
 	u8 u_ch, u_bw, u_offset;
 	u8 doiqk = _FALSE;
 
-	//check already connecting to AP or not
-	if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-	{
+	/* check already connecting to AP or not */
+	if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
 		if (pmlmeinfo->state & WIFI_FW_STATION_STATE)
-		{
 			issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
-		}
 		pmlmeinfo->state = WIFI_FW_NULL_STATE;
-		
-		//clear CAM
-		flush_all_cam_entry(padapter);		
-		
+
+		/* clear CAM */
+		flush_all_cam_entry(padapter);
+
 		_cancel_timer_ex(&pmlmeext->link_timer);
-		
-		//set MSR to nolink -> infra. mode		
-		//Set_MSR(padapter, _HW_STATE_NOLINK_);
-		Set_MSR(padapter, _HW_STATE_STATION_);	
-		
+
+		/* set MSR to nolink->infra. mode		 */
+		/* Set_MSR(padapter, _HW_STATE_NOLINK_); */
+		Set_MSR(padapter, _HW_STATE_STATION_);
+
 
 		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_DISCONNECT, 0);
 	}
@@ -13060,130 +14249,129 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 	pmlmeinfo->agg_enable_bitmap = 0;
 	pmlmeinfo->candidate_tid_bitmap = 0;
 	pmlmeinfo->bwmode_updated = _FALSE;
-	//pmlmeinfo->assoc_AP_vendor = HT_IOT_PEER_MAX;
+	/* pmlmeinfo->assoc_AP_vendor = HT_IOT_PEER_MAX; */
 	pmlmeinfo->VHT_enable = 0;
 
-	_rtw_memcpy(pnetwork, pbuf, FIELD_OFFSET(WLAN_BSSID_EX, IELength)); 
+	_rtw_memcpy(pnetwork, pbuf, FIELD_OFFSET(WLAN_BSSID_EX, IELength));
 	pnetwork->IELength = ((WLAN_BSSID_EX *)pbuf)->IELength;
-	
-	if(pnetwork->IELength>MAX_IE_SZ)//Check pbuf->IELength
-		return H2C_PARAMETERS_ERROR;	
-	
+
+	if (pnetwork->IELength > MAX_IE_SZ) /* Check pbuf->IELength */
+		return H2C_PARAMETERS_ERROR;
+
 	if (pnetwork->IELength < 2) {
-		report_join_res(padapter, (-4));
+		report_join_res(padapter, (-4), WLAN_STATUS_UNSPECIFIED_FAILURE);
 		return H2C_SUCCESS;
 	}
-	_rtw_memcpy(pnetwork->IEs, ((WLAN_BSSID_EX *)pbuf)->IEs, pnetwork->IELength); 
+	_rtw_memcpy(pnetwork->IEs, ((WLAN_BSSID_EX *)pbuf)->IEs, pnetwork->IELength);
 
 	pmlmeinfo->bcn_interval = get_beacon_interval(pnetwork);
 
-	//Check AP vendor to move rtw_joinbss_cmd()
-	//pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pnetwork->IEs, pnetwork->IELength);
+	/* Check AP vendor to move rtw_joinbss_cmd() */
+	/* pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pnetwork->IEs, pnetwork->IELength); */
 
-	//sizeof(NDIS_802_11_FIXED_IEs)	
+	/* sizeof(NDIS_802_11_FIXED_IEs)	 */
 	for (i = _FIXED_IE_LENGTH_ ; i < pnetwork->IELength - 2 ;) {
 		pIE = (PNDIS_802_11_VARIABLE_IEs)(pnetwork->IEs + i);
 
-		switch (pIE->ElementID)
-		{
-			case _VENDOR_SPECIFIC_IE_://Get WMM IE.
-				if ( _rtw_memcmp(pIE->data, WMM_OUI, 4) )
-				{
-					WMM_param_handler(padapter, pIE);
-				}
-				break;
+		switch (pIE->ElementID) {
+		case _VENDOR_SPECIFIC_IE_: /* Get WMM IE. */
+			if (_rtw_memcmp(pIE->data, WMM_OUI, 4))
+				WMM_param_handler(padapter, pIE);
+			break;
 
 #ifdef CONFIG_80211N_HT
-			case _HT_CAPABILITY_IE_:	//Get HT Cap IE.
-				pmlmeinfo->HT_caps_enable = 1;
-				break;
+		case _HT_CAPABILITY_IE_:	/* Get HT Cap IE. */
+			pmlmeinfo->HT_caps_enable = 1;
+			break;
 
-			case _HT_EXTRA_INFO_IE_:	//Get HT Info IE.
-				pmlmeinfo->HT_info_enable = 1;
-				break;
+		case _HT_EXTRA_INFO_IE_:	/* Get HT Info IE. */
+			pmlmeinfo->HT_info_enable = 1;
+			break;
 #endif /* CONFIG_80211N_HT */
 
 #ifdef CONFIG_80211AC_VHT
-			case EID_VHTCapability://Get VHT Cap IE.
-				pmlmeinfo->VHT_enable = 1;
-				break;
+		case EID_VHTCapability: /* Get VHT Cap IE. */
+			pmlmeinfo->VHT_enable = 1;
+			break;
 
-			case EID_VHTOperation://Get VHT Operation IE.
-				break;
+		case EID_VHTOperation: /* Get VHT Operation IE. */
+			break;
 #endif /* CONFIG_80211AC_VHT */
-			default:
-				break;
+		default:
+			break;
 		}
 
 		i += (pIE->Length + 2);
 	}
 
 	rtw_bss_get_chbw(pnetwork
-		, &pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset);
+		, &pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset, 1, 1);
 
 	rtw_adjust_chbw(padapter, pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset);
 
 #if 0
 	if (padapter->registrypriv.wifi_spec) {
-		// for WiFi test, follow WMM test plan spec
-		acparm = 0x002F431C; // VO
+		/* for WiFi test, follow WMM test plan spec */
+		acparm = 0x002F431C; /* VO */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acparm));
-		acparm = 0x005E541C; // VI
+		acparm = 0x005E541C; /* VI */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acparm));
-		acparm = 0x0000A525; // BE
+		acparm = 0x0000A525; /* BE */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
-		acparm = 0x0000A549; // BK
+		acparm = 0x0000A549; /* BK */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acparm));
-	
-		// for WiFi test, mixed mode with intel STA under bg mode throughput issue
-		if (padapter->mlmepriv.htpriv.ht_option == _FALSE){
+
+		/* for WiFi test, mixed mode with intel STA under bg mode throughput issue */
+		if (padapter->mlmepriv.htpriv.ht_option == _FALSE) {
 			acparm = 0x00004320;
 			rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
 		}
-	}
-	else {
-		acparm = 0x002F3217; // VO
+	} else {
+		acparm = 0x002F3217; /* VO */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acparm));
-		acparm = 0x005E4317; // VI
+		acparm = 0x005E4317; /* VI */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acparm));
-		acparm = 0x00105320; // BE
+		acparm = 0x00105320; /* BE */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
-		acparm = 0x0000A444; // BK
+		acparm = 0x0000A444; /* BK */
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acparm));
 	}
 #endif
 
 	/* check channel, bandwidth, offset and switch */
 	if (rtw_chk_start_clnt_join(padapter, &u_ch, &u_bw, &u_offset) == _FAIL) {
-		report_join_res(padapter, (-4));
+		report_join_res(padapter, (-4), WLAN_STATUS_UNSPECIFIED_FAILURE);
 		return H2C_SUCCESS;
 	}
 
-	//disable dynamic functions, such as high power, DIG
+	/* disable dynamic functions, such as high power, DIG */
 	/*rtw_phydm_func_disable_all(padapter);*/
 
-	//config the initial gain under linking, need to write the BB registers
-	//initialgain = 0x1E;
+	/* config the initial gain under linking, need to write the BB registers */
+	/* initialgain = 0x1E; */
 	/*rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);*/
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmlmeinfo->network.MacAddress);
 	join_type = 0;
 	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+	if (MLME_IS_STA(padapter))
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTING);
 	doiqk = _TRUE;
 	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
 
 	set_channel_bwmode(padapter, u_ch, u_offset, u_bw);
+	rtw_mi_update_union_chan_inf(padapter, u_ch, u_offset, u_bw);
 
 	doiqk = _FALSE;
 	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
 
-	//cancel link timer 
+	/* cancel link timer */
 	_cancel_timer_ex(&pmlmeext->link_timer);
-	
+
 	start_clnt_join(padapter);
-	
+
 	return H2C_SUCCESS;
-	
+
 }
 
 u8 disconnect_hdl(_adapter *padapter, unsigned char *pbuf)
@@ -13191,30 +14379,28 @@ u8 disconnect_hdl(_adapter *padapter, unsigned char *pbuf)
 	struct disconnect_parm *param = (struct disconnect_parm *)pbuf;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 	u8 val8;
 
-	if (is_client_associated_to_ap(padapter))
-	{
+	if (is_client_associated_to_ap(padapter)) {
 #ifdef CONFIG_DFS
-		if(padapter->mlmepriv.handle_dfs == _FALSE)
-#endif //CONFIG_DFS
+		if (padapter->mlmepriv.handle_dfs == _FALSE)
+#endif /* CONFIG_DFS */
 #ifdef CONFIG_PLATFORM_ROCKCHIPS
-			//To avoid connecting to AP fail during resume process, change retry count from 5 to 1
+			/* To avoid connecting to AP fail during resume process, change retry count from 5 to 1 */
 			issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
 #else
-			issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, param->deauth_timeout_ms/100, 100);
-#endif //CONFIG_PLATFORM_ROCKCHIPS
+			issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, param->deauth_timeout_ms / 100, 100);
+#endif /* CONFIG_PLATFORM_ROCKCHIPS */
 	}
 
 #ifdef CONFIG_DFS
-	if( padapter->mlmepriv.handle_dfs == _TRUE )
+	if (padapter->mlmepriv.handle_dfs == _TRUE)
 		padapter->mlmepriv.handle_dfs = _FALSE;
-#endif //CONFIG_DFS
+#endif /* CONFIG_DFS */
 
-	if(((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE))
-	{
-		//Stop BCN
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
+		/* Stop BCN */
 		val8 = 0;
 		rtw_hal_set_hwreg(padapter, HW_VAR_BCN_FUNC, (u8 *)(&val8));
 	}
@@ -13223,10 +14409,12 @@ u8 disconnect_hdl(_adapter *padapter, unsigned char *pbuf)
 
 	rtw_free_uc_swdec_pending_queue(padapter);
 
-	return 	H2C_SUCCESS;
+	rtw_sta_mstatus_report(padapter);
+
+	return	H2C_SUCCESS;
 }
 
-static const char * const _scan_state_str[] = {
+static const char *const _scan_state_str[] = {
 	"SCAN_DISABLE",
 	"SCAN_START",
 	"SCAN_PS_ANNC_WAIT",
@@ -13260,21 +14448,21 @@ static bool scan_abort_hdl(_adapter *adapter)
 	bool ret = _FALSE;
 
 	if (pmlmeext->scan_abort == _TRUE) {
-		#ifdef CONFIG_P2P
+#ifdef CONFIG_P2P
 		if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
 			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_MAX);
 			ss->channel_idx = 3;
-			DBG_871X("%s idx:%d, cnt:%u\n", __FUNCTION__
-				, ss->channel_idx
-				, pwdinfo->find_phase_state_exchange_cnt
-			);
+			RTW_INFO("%s idx:%d, cnt:%u\n", __FUNCTION__
+				 , ss->channel_idx
+				 , pwdinfo->find_phase_state_exchange_cnt
+				);
 		} else
-		#endif
+#endif
 		{
 			ss->channel_idx = ss->ch_num;
-			DBG_871X("%s idx:%d\n", __FUNCTION__
-				, ss->channel_idx
-			);
+			RTW_INFO("%s idx:%d\n", __FUNCTION__
+				 , ss->channel_idx
+				);
 		}
 		pmlmeext->scan_abort = _FALSE;
 		ret = _TRUE;
@@ -13285,7 +14473,7 @@ static bool scan_abort_hdl(_adapter *adapter)
 
 u8 rtw_scan_sparse(_adapter *adapter, struct rtw_ieee80211_channel *ch, u8 ch_num)
 {
-/* interval larger than this is treated as backgroud scan */
+	/* interval larger than this is treated as backgroud scan */
 #ifndef RTW_SCAN_SPARSE_BG_INTERVAL_MS
 #define RTW_SCAN_SPARSE_BG_INTERVAL_MS 12000
 #endif
@@ -13296,6 +14484,11 @@ u8 rtw_scan_sparse(_adapter *adapter, struct rtw_ieee80211_channel *ch, u8 ch_nu
 #ifndef RTW_SCAN_SPARSE_CH_NUM_BG
 #define RTW_SCAN_SPARSE_CH_NUM_BG 4
 #endif
+#ifdef CONFIG_LAYER2_ROAMING
+#ifndef RTW_SCAN_SPARSE_CH_NUM_ROAMING_ACTIVE
+#define RTW_SCAN_SPARSE_CH_NUM_ROAMING_ACTIVE 1
+#endif
+#endif
 
 #define SCAN_SPARSE_CH_NUM_INVALID 255
 
@@ -13322,18 +14515,11 @@ u8 rtw_scan_sparse(_adapter *adapter, struct rtw_ieee80211_channel *ch, u8 ch_nu
 
 	interval = rtw_get_passing_time_ms(mlmeext->last_scan_time);
 
-	if (adapter->mlmepriv.LinkDetectInfo.bBusyTraffic == _TRUE
-		#ifdef CONFIG_CONCURRENT_MODE
-		|| (adapter->pbuddy_adapter && adapter->pbuddy_adapter->mlmepriv.LinkDetectInfo.bBusyTraffic == _TRUE)
-		#endif
-	)
-			busy_traffic = _TRUE;
 
-	if (is_miracast_enabled(adapter)
-		#ifdef CONFIG_CONCURRENT_MODE
-		|| (adapter->pbuddy_adapter && is_miracast_enabled(adapter->pbuddy_adapter))
-		#endif
-	)
+	if (rtw_mi_busy_traffic_check(adapter, _FALSE))
+		busy_traffic = _TRUE;
+
+	if (rtw_mi_check_miracast_enabled(adapter))
 		miracast_enabled = _TRUE;
 
 	if (interval > RTW_SCAN_SPARSE_BG_INTERVAL_MS)
@@ -13341,30 +14527,37 @@ u8 rtw_scan_sparse(_adapter *adapter, struct rtw_ieee80211_channel *ch, u8 ch_nu
 
 	/* max_allow_ch by conditions*/
 
-	#if RTW_SCAN_SPARSE_MIRACAST
+#if RTW_SCAN_SPARSE_MIRACAST
 	if (miracast_enabled == _TRUE && busy_traffic == _TRUE)
 		max_allow_ch = rtw_min(max_allow_ch, RTW_SCAN_SPARSE_CH_NUM_MIRACAST);
-	#endif
+#endif
 
-	#if RTW_SCAN_SPARSE_BG
+#if RTW_SCAN_SPARSE_BG
 	if (bg_scan == _TRUE)
 		max_allow_ch = rtw_min(max_allow_ch, RTW_SCAN_SPARSE_CH_NUM_BG);
-	#endif
+#endif
+
+#if  defined(CONFIG_LAYER2_ROAMING) && defined(RTW_SCAN_SPARSE_ROAMING_ACTIVE)
+	if (rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
+		if (busy_traffic == _TRUE && adapter->mlmepriv.need_to_roam == _TRUE)
+			max_allow_ch = rtw_min(max_allow_ch, RTW_SCAN_SPARSE_CH_NUM_ROAMING_ACTIVE);
+	}
+#endif
 
 
 	if (max_allow_ch != SCAN_SPARSE_CH_NUM_INVALID) {
 		int i;
 		int k = 0;
 
-		scan_division_num = (ch_num / max_allow_ch) + ((ch_num % max_allow_ch)?1:0);
+		scan_division_num = (ch_num / max_allow_ch) + ((ch_num % max_allow_ch) ? 1 : 0);
 		token = (token + 1) % scan_division_num;
-		
+
 		if (0)
-			DBG_871X("scan_division_num:%u, token:%u\n", scan_division_num, token);
-		
+			RTW_INFO("scan_division_num:%u, token:%u\n", scan_division_num, token);
+
 		for (i = 0; i < ch_num; i++) {
 			if (ch[i].hw_value && (i % scan_division_num) == token
-			) {
+			   ) {
 				if (i != k)
 					_rtw_memcpy(&ch[k], &ch[i], sizeof(struct rtw_ieee80211_channel));
 				k++;
@@ -13381,64 +14574,136 @@ exit:
 	return ret_num;
 }
 
+#ifdef CONFIG_SCAN_BACKOP
+u8 rtw_scan_backop_decision(_adapter *adapter)
+{
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	struct mi_state mstate;
+	u8 backop_flags = 0;
+
+	rtw_mi_status(adapter, &mstate);
+
+	if ((MSTATE_STA_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(mlmeext, SS_BACKOP_EN))
+		|| (MSTATE_STA_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(mlmeext, SS_BACKOP_EN_NL)))
+		backop_flags |= mlmeext_scan_backop_flags_sta(mlmeext);
+
+#ifdef CONFIG_AP_MODE
+	if ((MSTATE_AP_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(mlmeext, SS_BACKOP_EN))
+		|| (MSTATE_AP_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(mlmeext, SS_BACKOP_EN_NL)))
+		backop_flags |= mlmeext_scan_backop_flags_ap(mlmeext);
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	if ((MSTATE_MESH_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_mesh(mlmeext, SS_BACKOP_EN))
+		|| (MSTATE_MESH_NUM(&mstate) && mlmeext_chk_scan_backop_flags_mesh(mlmeext, SS_BACKOP_EN_NL)))
+		backop_flags |= mlmeext_scan_backop_flags_mesh(mlmeext);
+#endif
+
+	return backop_flags;
+}
+#endif
+
+#define SCANNING_TIMEOUT_EX	2000
+u32 rtw_scan_timeout_decision(_adapter *padapter)
+{
+	u32 back_op_times= 0;
+	u8 max_chan_num;
+	u16 scan_ms;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct ss_res *ss = &pmlmeext->sitesurvey_res;
+
+	if (is_supported_5g(padapter->registrypriv.wireless_mode)
+		&& IsSupported24G(padapter->registrypriv.wireless_mode)) 
+		max_chan_num = MAX_CHANNEL_NUM;/* dual band */
+	else
+		max_chan_num = MAX_CHANNEL_NUM_2G;/*single band*/
+
+	#ifdef CONFIG_SCAN_BACKOP
+	if (rtw_scan_backop_decision(padapter))
+		back_op_times = (max_chan_num / ss->scan_cnt_max) * ss->backop_ms;
+	#endif
+
+	if (ss->duration)
+		scan_ms = ss->duration;
+	else
+	#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
+	if (IS_ACS_ENABLE(padapter) && rtw_is_acs_st_valid(padapter))
+		scan_ms = rtw_acs_get_adv_st(padapter);
+	else
+	#endif /*CONFIG_RTW_ACS*/
+		scan_ms = ss->scan_ch_ms;
+
+	ss->scan_timeout_ms = (scan_ms * max_chan_num) + back_op_times + SCANNING_TIMEOUT_EX;
+	#ifdef DBG_SITESURVEY
+	RTW_INFO("%s , scan_timeout_ms = %d (ms)\n", __func__, ss->scan_timeout_ms);
+	#endif /*DBG_SITESURVEY*/
+	return ss->scan_timeout_ms;
+}
+
 static int rtw_scan_ch_decision(_adapter *padapter, struct rtw_ieee80211_channel *out,
-	u32 out_num, struct rtw_ieee80211_channel *in, u32 in_num)
+		u32 out_num, 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;
+	u8 chan;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 
 	/* clear first */
-	_rtw_memset(out, 0, sizeof(struct rtw_ieee80211_channel)*out_num);
+	_rtw_memset(out, 0, sizeof(struct rtw_ieee80211_channel) * out_num);
 
 	/* acquire channels from in */
 	j = 0;
-	for (i=0;i<in_num;i++) {
+	for (i = 0; i < in_num; i++) {
 
 		if (0)
-			DBG_871X(FUNC_ADPT_FMT" "CHAN_FMT"\n", FUNC_ADPT_ARG(padapter), CHAN_ARG(&in[i]));
+			RTW_INFO(FUNC_ADPT_FMT" "CHAN_FMT"\n", FUNC_ADPT_ARG(padapter), CHAN_ARG(&in[i]));
 
-		if(in[i].hw_value && !(in[i].flags & RTW_IEEE80211_CHAN_DISABLED)
-			&& (set_idx=rtw_ch_set_search_ch(pmlmeext->channel_set, in[i].hw_value)) >=0
-			&& rtw_mlme_band_check(padapter, in[i].hw_value) == _TRUE
-		)
-		{
+		if (!in[i].hw_value || (in[i].flags & RTW_IEEE80211_CHAN_DISABLED))
+			continue;
+		if (rtw_mlme_band_check(padapter, in[i].hw_value) == _FALSE)
+			continue;
+
+		set_idx = rtw_chset_search_ch(rfctl->channel_set, in[i].hw_value);
+		if (set_idx >= 0) {
 			if (j >= out_num) {
-				DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" out_num:%u not enough\n",
-					FUNC_ADPT_ARG(padapter), out_num);
+				RTW_PRINT(FUNC_ADPT_FMT" out_num:%u not enough\n",
+					  FUNC_ADPT_ARG(padapter), out_num);
 				break;
 			}
 
 			_rtw_memcpy(&out[j], &in[i], sizeof(struct rtw_ieee80211_channel));
-			
-			if(pmlmeext->channel_set[set_idx].ScanType == SCAN_PASSIVE)
+
+			if (rfctl->channel_set[set_idx].ScanType == SCAN_PASSIVE)
 				out[j].flags |= RTW_IEEE80211_CHAN_PASSIVE_SCAN;
-				
+
 			j++;
 		}
-		if(j>=out_num)
+		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++) {
 
-			if (0)
-				DBG_871X(FUNC_ADPT_FMT" ch:%u\n", FUNC_ADPT_ARG(padapter), pmlmeext->channel_set[i].ChannelNum);
+	/* if out is empty, use channel_set as default */
+	if (j == 0) {
+		for (i = 0; i < rfctl->max_chan_nums; i++) {
+			chan = rfctl->channel_set[i].ChannelNum;
+			if (rtw_mlme_band_check(padapter, chan) == _TRUE) {
+				if (rtw_mlme_ignore_chan(padapter, chan) == _TRUE)
+					continue;
 
-			if (rtw_mlme_band_check(padapter, pmlmeext->channel_set[i].ChannelNum) == _TRUE) {
+				if (0)
+					RTW_INFO(FUNC_ADPT_FMT" ch:%u\n", FUNC_ADPT_ARG(padapter), chan);
 
 				if (j >= out_num) {
-					DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" out_num:%u not enough\n",
+					RTW_PRINT(FUNC_ADPT_FMT" out_num:%u not enough\n",
 						FUNC_ADPT_ARG(padapter), out_num);
 					break;
 				}
 
-				out[j].hw_value = pmlmeext->channel_set[i].ChannelNum;
-			
-				if(pmlmeext->channel_set[i].ScanType == SCAN_PASSIVE)
+				out[j].hw_value = chan;
+
+				if (rfctl->channel_set[i].ScanType == SCAN_PASSIVE)
 					out[j].flags |= RTW_IEEE80211_CHAN_PASSIVE_SCAN;
 
 				j++;
@@ -13455,10 +14720,14 @@ static int rtw_scan_ch_decision(_adapter *padapter, struct rtw_ieee80211_channel
 static void sitesurvey_res_reset(_adapter *adapter, struct sitesurvey_parm *parm)
 {
 	struct ss_res *ss = &adapter->mlmeextpriv.sitesurvey_res;
+	RT_CHANNEL_INFO *chset = adapter_to_chset(adapter);
 	int i;
 
 	ss->bss_cnt = 0;
 	ss->channel_idx = 0;
+#ifdef CONFIG_DFS
+	ss->dfs_ch_ssid_scan = 0;
+#endif
 	ss->igi_scan = 0;
 	ss->igi_before_scan = 0;
 #ifdef CONFIG_SCAN_BACKOP
@@ -13467,22 +14736,32 @@ static void sitesurvey_res_reset(_adapter *adapter, struct sitesurvey_parm *parm
 #if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
 	ss->is_sw_antdiv_bl_scan = 0;
 #endif
-	
+	ss->ssid_num = 0;
 	for (i = 0; i < RTW_SSID_SCAN_AMOUNT; i++) {
 		if (parm->ssid[i].SsidLength) {
 			_rtw_memcpy(ss->ssid[i].Ssid, parm->ssid[i].Ssid, IW_ESSID_MAX_SIZE);
 			ss->ssid[i].SsidLength = parm->ssid[i].SsidLength;
-		} else {
+			ss->ssid_num++;
+		} else
 			ss->ssid[i].SsidLength = 0;
-		}
 	}
 
 	ss->ch_num = rtw_scan_ch_decision(adapter
-		, ss->ch, RTW_CHANNEL_SCAN_AMOUNT
-		, parm->ch, parm->ch_num
-	);
+					  , ss->ch, RTW_CHANNEL_SCAN_AMOUNT
+					  , parm->ch, parm->ch_num
+					 );
 
+#ifdef CONFIG_DFS
+	for (i = 0; i < MAX_CHANNEL_NUM; i++)
+		chset[i].hidden_bss_cnt = 0;
+#endif
+
+	ss->bw = parm->bw;
+	ss->igi = parm->igi;
+	ss->token = parm->token;
+	ss->duration = parm->duration;
 	ss->scan_mode = parm->scan_mode;
+	ss->token = parm->token;
 }
 
 static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *type)
@@ -13493,10 +14772,14 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
 	struct ss_res *ss = &pmlmeext->sitesurvey_res;
-
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	int ch_set_idx;
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
 #endif
+#ifdef CONFIG_SCAN_BACKOP
+	u8 backop_flags = 0;
+#endif
 
 	/* handle scan abort request */
 	scan_abort_hdl(padapter);
@@ -13513,12 +14796,10 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 		* Commented by Albert 2011/06/03
 		* The driver is in the find phase, it should go through the social channel.
 		*/
-		int ch_set_idx;
-
 		scan_ch = pwdinfo->social_chan[ss->channel_idx];
-		ch_set_idx = rtw_ch_set_search_ch(pmlmeext->channel_set, scan_ch);
+		ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, scan_ch);
 		if (ch_set_idx >= 0)
-			scan_type = pmlmeext->channel_set[ch_set_idx].ScanType;
+			scan_type = rfctl->channel_set[ch_set_idx].ScanType;
 		else
 			scan_type = SCAN_ACTIVE;
 	} else
@@ -13526,60 +14807,69 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 	{
 		struct rtw_ieee80211_channel *ch;
 
+		#ifdef CONFIG_SCAN_BACKOP
+		backop_flags = rtw_scan_backop_decision(padapter);
+		#endif
+
+#ifdef CONFIG_DFS
+		#ifdef CONFIG_SCAN_BACKOP
+		if (!(backop_flags && ss->scan_cnt >= ss->scan_cnt_max))
+		#endif
+		{
+			if (ss->channel_idx != 0 && ss->dfs_ch_ssid_scan == 0
+				&& pmlmeext->sitesurvey_res.ssid_num
+				&& rtw_is_dfs_ch(ss->ch[ss->channel_idx - 1].hw_value)
+			) {
+				ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, ss->ch[ss->channel_idx - 1].hw_value);
+				if (ch_set_idx != -1 && rfctl->channel_set[ch_set_idx].hidden_bss_cnt) {
+					ss->channel_idx--;
+					ss->dfs_ch_ssid_scan = 1;
+				}
+			} else
+				ss->dfs_ch_ssid_scan = 0;
+		}
+#endif /* CONFIG_DFS */
+
 		if (ss->channel_idx < ss->ch_num) {
 			ch = &ss->ch[ss->channel_idx];
 			scan_ch = ch->hw_value;
-			scan_type = (ch->flags & RTW_IEEE80211_CHAN_PASSIVE_SCAN) ? SCAN_PASSIVE : SCAN_ACTIVE;
+
+			#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
+			if (IS_ACS_ENABLE(padapter) && rtw_is_acs_passiv_scan(padapter))
+				scan_type = SCAN_PASSIVE;
+			else
+			#endif /*CONFIG_RTW_ACS*/
+				scan_type = (ch->flags & RTW_IEEE80211_CHAN_PASSIVE_SCAN) ? SCAN_PASSIVE : SCAN_ACTIVE;
 		}
 	}
 
 	if (scan_ch != 0) {
 		next_state = SCAN_PROCESS;
-		#ifdef CONFIG_SCAN_BACKOP
-		{
-			u8 sta_num;
-			u8 ld_sta_num;
-			u8 ap_num;
-			u8 ld_ap_num;
-			u8 backop_flags = 0;
 
-			rtw_dev_iface_status(padapter, &sta_num, &ld_sta_num, NULL, &ap_num, &ld_ap_num);
-
-			if ((ld_sta_num > 0 && mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN))
-					|| (sta_num > 0 && mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN_NL))
-			) {
-				backop_flags |= mlmeext_scan_backop_flags_sta(pmlmeext);
-			}
-
-			if ((ld_ap_num > 0 && mlmeext_chk_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN))
-					|| (ap_num > 0 && mlmeext_chk_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN_NL))
-			) {
-				backop_flags |= mlmeext_scan_backop_flags_ap(pmlmeext);
-			}
-
-			if (backop_flags) {
-				if (ss->scan_cnt < ss->scan_cnt_max) {
-					ss->scan_cnt++;
-				} else {
-					mlmeext_assign_scan_backop_flags(pmlmeext, backop_flags);
-					next_state = SCAN_BACKING_OP;
-				}
+		#ifdef CONFIG_SCAN_BACKOP
+		if (backop_flags) {
+			if (ss->scan_cnt < ss->scan_cnt_max)
+				ss->scan_cnt++;
+			else {
+				mlmeext_assign_scan_backop_flags(pmlmeext, backop_flags);
+				next_state = SCAN_BACKING_OP;
 			}
 		}
-		#endif /* CONFIG_SCAN_BACKOP */
+		#endif
+
 	} else if (rtw_p2p_findphase_ex_is_needed(pwdinfo)) {
 		/* go p2p listen */
 		next_state = SCAN_TO_P2P_LISTEN;
 
-	#ifdef CONFIG_ANTENNA_DIVERSITY
+#ifdef CONFIG_ANTENNA_DIVERSITY
 	} else if (rtw_hal_antdiv_before_linked(padapter)) {
 		/* go sw antdiv before link */
 		next_state = SCAN_SW_ANTDIV_BL;
-	#endif
+#endif
 	} else {
 		next_state = SCAN_COMPLETE;
 
-		#if defined(DBG_SCAN_SW_ANTDIV_BL)
+#if defined(DBG_SCAN_SW_ANTDIV_BL)
 		{
 			/* for SCAN_SW_ANTDIV_BL state testing */
 			struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
@@ -13597,18 +14887,17 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 				if (fake_sw_antdiv_bl_state == 0) {
 					next_state = SCAN_SW_ANTDIV_BL;
 					fake_sw_antdiv_bl_state = 1;
-				} else {
+				} else
 					fake_sw_antdiv_bl_state = 0;
-				}
 			}
 		}
-		#endif /* defined(DBG_SCAN_SW_ANTDIV_BL) */
+#endif /* defined(DBG_SCAN_SW_ANTDIV_BL) */
 	}
 
-	#ifdef CONFIG_SCAN_BACKOP
+#ifdef CONFIG_SCAN_BACKOP
 	if (next_state != SCAN_PROCESS)
 		ss->scan_cnt = 0;
-	#endif
+#endif
 
 
 #ifdef DBG_FIXED_CHAN
@@ -13628,6 +14917,8 @@ void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType)
 {
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct ss_res *ss = &pmlmeext->sitesurvey_res;
+	u8 ssid_scan = 0;
 
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
@@ -13636,43 +14927,26 @@ void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType)
 	if (survey_channel != 0) {
 		set_channel_bwmode(padapter, survey_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 
-		#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-		if (ACS_ENABLE == GET_ACS_STATE(padapter)) {
-			ACS_OP acs_op = ACS_RESET;
-
-			rtw_hal_set_odm_var(padapter, HAL_ODM_AUTO_CHNL_SEL, &acs_op, _TRUE);
-			rtw_set_acs_channel(padapter, survey_channel);
-			#ifdef DBG_AUTO_CHNL_SEL_NHM
-			DBG_871X("[ACS-"ADPT_FMT"]-set ch:%u\n",
-				ADPT_ARG(padapter), rtw_get_acs_channel(padapter));
-			#endif
-		}
-		#endif
-
+#ifdef CONFIG_DFS
+		if (ScanType == SCAN_PASSIVE && ss->dfs_ch_ssid_scan)
+			ssid_scan = 1;
+		else
+#endif
 		if (ScanType == SCAN_ACTIVE) {
-			#ifdef CONFIG_P2P
-			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN) || 
-				rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH)
-			) {
+#ifdef CONFIG_P2P
+			#ifdef CONFIG_IOCTL_CFG80211
+			if (rtw_cfg80211_is_p2p_scan(padapter))
+			#else
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
+				|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH))
+			#endif
+			{
 				issue_probereq_p2p(padapter, NULL);
 				issue_probereq_p2p(padapter, NULL);
 				issue_probereq_p2p(padapter, NULL);
 			} else
-			#endif /* CONFIG_P2P */
+#endif /* CONFIG_P2P */
 			{
-				int i;
-
-				for (i = 0; i < RTW_SSID_SCAN_AMOUNT; i++) {
-					if (pmlmeext->sitesurvey_res.ssid[i].SsidLength) {
-						/* IOT issue, When wifi_spec is not set, send one probe req without WPS IE. */
-						if (padapter->registrypriv.wifi_spec)
-							issue_probereq(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL);
-						else
-							issue_probereq_ex(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL, 0, 0, 0, 0);
-						issue_probereq(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL);
-					}
-				}
-
 				if (pmlmeext->sitesurvey_res.scan_mode == SCAN_ACTIVE) {
 					/* IOT issue, When wifi_spec is not set, send one probe req without WPS IE. */
 					if (padapter->registrypriv.wifi_spec)
@@ -13681,6 +14955,23 @@ void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType)
 						issue_probereq_ex(padapter, NULL, NULL, 0, 0, 0, 0);
 					issue_probereq(padapter, NULL, NULL);
 				}
+
+				ssid_scan = 1;
+			}
+		}
+
+		if (ssid_scan) {
+			int i;
+
+			for (i = 0; i < RTW_SSID_SCAN_AMOUNT; i++) {
+				if (pmlmeext->sitesurvey_res.ssid[i].SsidLength) {
+					/* IOT issue, When wifi_spec is not set, send one probe req without WPS IE. */
+					if (padapter->registrypriv.wifi_spec)
+						issue_probereq(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL);
+					else
+						issue_probereq_ex(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL, 0, 0, 0, 0);
+					issue_probereq(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL);
+				}
 			}
 		}
 	} else {
@@ -13697,13 +14988,22 @@ void survey_done_set_ch_bw(_adapter *padapter)
 	u8 cur_channel = 0;
 	u8 cur_bwmode;
 	u8 cur_ch_offset;
-	
-	if (rtw_get_ch_setting_union(padapter, &cur_channel, &cur_bwmode, &cur_ch_offset) != 0) {
+
+#ifdef CONFIG_MCC_MODE
+	if (!rtw_hal_mcc_change_scan_flag(padapter, &cur_channel, &cur_bwmode, &cur_ch_offset)) {
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" back to AP channel - ch:%u, bw:%u, offset:%u\n",
+				FUNC_ADPT_ARG(padapter), cur_channel, cur_bwmode, cur_ch_offset);
+		goto exit;
+	}
+#endif
+
+	if (rtw_mi_get_ch_setting_union(padapter, &cur_channel, &cur_bwmode, &cur_ch_offset) != 0) {
 		if (0)
-			DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
+			RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
 				FUNC_ADPT_ARG(padapter), cur_channel, cur_bwmode, cur_ch_offset);
 	} else {
-		#ifdef CONFIG_P2P
+#ifdef CONFIG_P2P
 		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 		_adapter *iface;
 		int i;
@@ -13713,72 +15013,132 @@ void survey_done_set_ch_bw(_adapter *padapter)
 			if (!iface)
 				continue;
 
-			#ifdef CONFIG_IOCTL_CFG80211
+#ifdef CONFIG_IOCTL_CFG80211
 			if (iface->wdinfo.driver_interface == DRIVER_CFG80211 && !adapter_wdev_data(iface)->p2p_enabled)
 				continue;
-			#endif
+#endif
 
 			if (rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_LISTEN)) {
 				cur_channel = iface->wdinfo.listen_channel;
 				cur_bwmode = CHANNEL_WIDTH_20;
 				cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 				if (0)
-					DBG_871X(FUNC_ADPT_FMT" back to "ADPT_FMT"'s listen ch - ch:%u, bw:%u, offset:%u\n",
+					RTW_INFO(FUNC_ADPT_FMT" back to "ADPT_FMT"'s listen ch - ch:%u, bw:%u, offset:%u\n",
 						FUNC_ADPT_ARG(padapter), ADPT_ARG(iface), cur_channel, cur_bwmode, cur_ch_offset);
 				break;
 			}
 		}
-		#endif /* CONFIG_P2P */
+#endif /* CONFIG_P2P */
 
 		if (cur_channel == 0) {
 			cur_channel = pmlmeext->cur_channel;
 			cur_bwmode = pmlmeext->cur_bwmode;
 			cur_ch_offset = pmlmeext->cur_ch_offset;
 			if (0)
-				DBG_871X(FUNC_ADPT_FMT" back to ch:%u, bw:%u, offset:%u\n",
+				RTW_INFO(FUNC_ADPT_FMT" back to ch:%u, bw:%u, offset:%u\n",
 					FUNC_ADPT_ARG(padapter), cur_channel, cur_bwmode, cur_ch_offset);
 		}
 	}
-
+exit:
 	set_channel_bwmode(padapter, cur_channel, cur_ch_offset, cur_bwmode);
 }
 
 /**
- * sitesurvey_ps_annc - check and doing ps announcement for all the adapters of given @dvobj
- * @dvobj: the dvobj to check
+ * rtw_ps_annc - check and doing ps announcement for all the adapters
+ * @adapter: the requesting adapter
  * @ps: power saving or not
  *
  * Returns: 0: no ps announcement is doing. 1: ps announcement is doing
  */
-u8 sitesurvey_ps_annc(struct dvobj_priv *dvobj, bool ps)
+u8 rtw_ps_annc(_adapter *adapter, bool ps)
 {
-	_adapter *adapter;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
 	int i;
 	u8 ps_anc = 0;
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
-		adapter = dvobj->padapters[i];
-		if (!adapter)
+		iface = dvobj->padapters[i];
+		if (!iface)
 			continue;
 
-		if (ps) {
-			if (is_client_associated_to_ap(adapter) == _TRUE) {
+		if (MLME_IS_STA(iface)) {
+			if (is_client_associated_to_ap(iface) == _TRUE) {
 				/* TODO: TDLS peers */
-				issue_nulldata(adapter, NULL, 1, 3, 500);
+				#ifdef CONFIG_MCC_MODE
+				/* for two station case */
+				if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_NEED_MCC)) {
+					u8 ch = iface->mlmeextpriv.cur_channel;
+					u8 offset = iface->mlmeextpriv.cur_ch_offset;
+					u8 bw = iface->mlmeextpriv.cur_bwmode;
+
+					set_channel_bwmode(iface, ch, offset, bw);
+				}
+				#endif /* CONFIG_MCC_MODE */
+				issue_nulldata(iface, NULL, ps, 3, 500);
 				ps_anc = 1;
 			}
-		} else {
-			if (is_client_associated_to_ap(adapter) == _TRUE) {
-				/* TODO: TDLS peers */
-				issue_nulldata(adapter, NULL, 0, 3, 500);
+		#ifdef CONFIG_RTW_MESH
+		} else if (MLME_IS_MESH(iface)) {
+			if (rtw_mesh_ps_annc(iface, ps))
 				ps_anc = 1;
-			}
+		#endif
 		}
 	}
-
 	return ps_anc;
 }
 
+void rtw_leave_opch(_adapter *adapter)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
+		return;
+#endif
+
+	_enter_critical_mutex(&rfctl->offch_mutex, NULL);
+
+	if (rfctl->offch_state == OFFCHS_NONE) {
+		/* prepare to leave operating channel */
+		rfctl->offch_state = OFFCHS_LEAVING_OP;
+
+		/* clear HW TX queue */
+		rtw_hal_set_hwreg(adapter, HW_VAR_CHECK_TXBUF, 0);
+
+		rtw_hal_macid_sleep_all_used(adapter);
+
+		rtw_ps_annc(adapter, 1);
+
+		rfctl->offch_state = OFFCHS_LEAVE_OP;
+	}
+
+	_exit_critical_mutex(&rfctl->offch_mutex, NULL);
+}
+
+void rtw_back_opch(_adapter *adapter)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
+		return;
+#endif
+
+	_enter_critical_mutex(&rfctl->offch_mutex, NULL);
+
+	if (rfctl->offch_state != OFFCHS_NONE) {
+		rfctl->offch_state = OFFCHS_BACKING_OP;
+		rtw_hal_macid_wakeup_all_used(adapter);
+		rtw_ps_annc(adapter, 0);
+
+		rfctl->offch_state = OFFCHS_NONE;
+		rtw_mi_os_xmit_schedule(adapter);
+	}
+
+	_exit_critical_mutex(&rfctl->offch_mutex, NULL);
+}
+
 void sitesurvey_set_igi(_adapter *adapter)
 {
 	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
@@ -13792,7 +15152,7 @@ void sitesurvey_set_igi(_adapter *adapter)
 	case SCAN_ENTER:
 		#ifdef CONFIG_P2P
 		#ifdef CONFIG_IOCTL_CFG80211
-		if (adapter_wdev_data(adapter)->p2p_enabled == _TRUE && pwdinfo->driver_interface == DRIVER_CFG80211)
+		if (pwdinfo->driver_interface == DRIVER_CFG80211 && rtw_cfg80211_is_p2p_scan(adapter))
 			igi = 0x30;
 		else
 		#endif /* CONFIG_IOCTL_CFG80211 */
@@ -13800,35 +15160,95 @@ void sitesurvey_set_igi(_adapter *adapter)
 			igi = 0x28;
 		else
 		#endif /* CONFIG_P2P */
+
+		if (ss->igi)
+			igi = ss->igi;
+		else
+		#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
+		if (IS_ACS_ENABLE(adapter) && rtw_is_acs_igi_valid(adapter))
+			igi = rtw_acs_get_adv_igi(adapter);
+		else
+		#endif /*CONFIG_RTW_ACS*/
 			igi = 0x1e;
 
-		/* record IGI status */
-		ss->igi_scan = igi;
-		rtw_hal_get_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &ss->igi_before_scan, NULL);
+		/* record IGI status */
+		ss->igi_scan = igi;
+		rtw_hal_get_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &ss->igi_before_scan, NULL);
+
+		/* disable DIG and set IGI for scan */
+		rtw_hal_set_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &igi, _FALSE);
+		break;
+	case SCAN_COMPLETE:
+	case SCAN_TO_P2P_LISTEN:
+		/* enable DIG and restore IGI */
+		igi = 0xff;
+		rtw_hal_set_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &igi, _FALSE);
+		break;
+#ifdef CONFIG_SCAN_BACKOP
+	case SCAN_BACKING_OP:
+		/* write IGI for op channel when DIG is not enabled */
+		odm_write_dig(adapter_to_phydm(adapter), ss->igi_before_scan);
+		break;
+	case SCAN_LEAVE_OP:
+		/* write IGI for scan when DIG is not enabled */
+		odm_write_dig(adapter_to_phydm(adapter), ss->igi_scan);
+		break;
+#endif /* CONFIG_SCAN_BACKOP */
+	default:
+		rtw_warn_on(1);
+		break;
+	}
+}
+void sitesurvey_set_msr(_adapter *adapter, bool enter)
+{
+	u8 network_type;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (enter) {
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_hal_get_hwreg(adapter, HW_VAR_MEDIA_STATUS, (u8 *)(&pmlmeinfo->hw_media_state));
+#endif
+		/* set MSR to no link state */
+		network_type = _HW_STATE_NOLINK_;
+	} else {
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		network_type = pmlmeinfo->hw_media_state;
+#else
+		network_type = pmlmeinfo->state & 0x3;
+#endif
+	}
+	Set_MSR(adapter, network_type);
+}
+
+void sitesurvey_set_offch_state(_adapter *adapter, u8 scan_state)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 
-		/* disable DIG and set IGI for scan */
-		rtw_hal_set_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &igi, _FALSE);
-		break;
-	case SCAN_COMPLETE:
-	case SCAN_TO_P2P_LISTEN:
-		/* enable DIG and restore IGI */
-		igi = 0xff;
-		rtw_hal_set_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &igi, _FALSE);
+	_enter_critical_mutex(&rfctl->offch_mutex, NULL);
+
+	switch (scan_state) {
+	case SCAN_DISABLE:
+	case SCAN_BACK_OP:
+		rfctl->offch_state = OFFCHS_NONE;
 		break;
-#ifdef CONFIG_SCAN_BACKOP
-	case SCAN_BACKING_OP:
-		/* write IGI for op channel when DIG is not enabled */
-		ODM_Write_DIG(GET_ODM(adapter), ss->igi_before_scan);
+	case SCAN_START:
+	case SCAN_LEAVING_OP:
+		rfctl->offch_state = OFFCHS_LEAVING_OP;
 		break;
+	case SCAN_ENTER:
 	case SCAN_LEAVE_OP:
-		/* write IGI for scan when DIG is not enabled */
-		ODM_Write_DIG(GET_ODM(adapter), ss->igi_scan);
+		rfctl->offch_state = OFFCHS_LEAVE_OP;
+		break;
+	case SCAN_COMPLETE:
+	case SCAN_BACKING_OP:
+		rfctl->offch_state = OFFCHS_BACKING_OP;
 		break;
-#endif /* CONFIG_SCAN_BACKOP */
 	default:
-		rtw_warn_on(1);
 		break;
 	}
+
+	_exit_critical_mutex(&rfctl->offch_mutex, NULL);
 }
 
 u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf)
@@ -13847,7 +15267,7 @@ u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf)
 
 #ifdef DBG_CHECK_FW_PS_STATE
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
-		DBG_871X("scan without leave 32k\n");
+		RTW_INFO("scan without leave 32k\n");
 		pdbgpriv->dbg_scan_pwr_state_cnt++;
 	}
 #endif /* DBG_CHECK_FW_PS_STATE */
@@ -13864,7 +15284,7 @@ operation_by_state:
 	switch (mlmeext_scan_state(pmlmeext)) {
 
 	case SCAN_DISABLE:
-		/* 
+		/*
 		* SW parameter initialization
 		*/
 
@@ -13877,18 +15297,22 @@ operation_by_state:
 		* prepare to leave operating channel
 		*/
 
+#ifdef CONFIG_MCC_MODE
+		rtw_hal_set_mcc_setting_scan_start(padapter);
+#endif /* CONFIG_MCC_MODE */
+
 		/* apply rx ampdu setting */
 		if (ss->rx_ampdu_accept != RX_AMPDU_ACCEPT_INVALID
-			|| ss->rx_ampdu_size != RX_AMPDU_SIZE_INVALID
-		) {
+			|| ss->rx_ampdu_size != RX_AMPDU_SIZE_INVALID)
 			rtw_rx_ampdu_apply(padapter);
-		}
 
 		/* clear HW TX queue before scan */
 		rtw_hal_set_hwreg(padapter, HW_VAR_CHECK_TXBUF, 0);
 
+		rtw_hal_macid_sleep_all_used(padapter);
+
 		/* power save state announcement */
-		if (sitesurvey_ps_annc(adapter_to_dvobj(padapter), 1)) {
+		if (rtw_ps_annc(padapter, 1)) {
 			mlmeext_set_scan_state(pmlmeext, SCAN_PS_ANNC_WAIT);
 			mlmeext_set_scan_next_state(pmlmeext, SCAN_ENTER);
 			set_survey_timer(pmlmeext, 50); /* delay 50ms to protect nulldata(1) */
@@ -13910,155 +15334,152 @@ operation_by_state:
 
 		/* config dynamic functions for off channel */
 		rtw_phydm_func_for_offchannel(padapter);
-		
 		/* set MSR to no link state */
-		Set_MSR(padapter, _HW_STATE_NOLINK_);
+		sitesurvey_set_msr(padapter, _TRUE);
+
 		val8 = 1; /* under site survey */
 		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 
 		mlmeext_set_scan_state(pmlmeext, SCAN_PROCESS);
 		goto operation_by_state;
 
-	case SCAN_PROCESS:
-	{
+	case SCAN_PROCESS: {
 		u8 scan_ch;
 		RT_SCAN_TYPE scan_type;
 		u8 next_state;
 		u32 scan_ms;
 
-		#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-		if ((ACS_ENABLE == GET_ACS_STATE(padapter)) && (0 != rtw_get_acs_channel(padapter))) {
-			ACS_OP acs_op = ACS_SELECT;
-
-			rtw_hal_set_odm_var(padapter, HAL_ODM_AUTO_CHNL_SEL, &acs_op, _TRUE);
-		}
-		#endif
+#ifdef CONFIG_RTW_ACS
+		if (IS_ACS_ENABLE(padapter))
+			rtw_acs_get_rst(padapter);
+#endif
 
 		next_state = sitesurvey_pick_ch_behavior(padapter, &scan_ch, &scan_type);
-		if (next_state != SCAN_PROCESS) {
-			#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-			if (ACS_ENABLE == GET_ACS_STATE(padapter)) {
-				rtw_set_acs_channel(padapter, 0);
-				#ifdef DBG_AUTO_CHNL_SEL_NHM
-				DBG_871X("[ACS-"ADPT_FMT"]-set ch:%u\n", ADPT_ARG(padapter), rtw_get_acs_channel(padapter));
-				#endif
-			}
-			#endif
 
+		if (next_state != SCAN_PROCESS) {
 			mlmeext_set_scan_state(pmlmeext, next_state);
 			goto operation_by_state;
 		}
 
 		/* still SCAN_PROCESS state */
-		if (0)
+		#ifdef DBG_SITESURVEY
 			#ifdef CONFIG_P2P
-			DBG_871X(FUNC_ADPT_FMT" %s ch:%u (cnt:%u,idx:%d) at %dms, %c%c%c\n"
+			RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (cnt:%u,idx:%d) at %dms, %c%c%c%c\n"
 				, FUNC_ADPT_ARG(padapter)
 				, mlmeext_scan_state_str(pmlmeext)
 				, scan_ch
 				, pwdinfo->find_phase_state_exchange_cnt, ss->channel_idx
 				, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
-				, scan_type?'A':'P', ss->scan_mode?'A':'P'
-				, ss->ssid[0].SsidLength?'S':' ' 
+				, scan_type ? 'A' : 'P', ss->scan_mode ? 'A' : 'P'
+				, ss->ssid[0].SsidLength ? 'S' : ' '
+				, ss->dfs_ch_ssid_scan ? 'D' : ' '
 			);
 			#else
-			DBG_871X(FUNC_ADPT_FMT" %s ch:%u (idx:%d) at %dms, %c%c%c\n"
+			RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (idx:%d) at %dms, %c%c%c%c\n"
 				, FUNC_ADPT_ARG(padapter)
 				, mlmeext_scan_state_str(pmlmeext)
 				, scan_ch
 				, ss->channel_idx
 				, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
-				, scan_type?'A':'P', ss->scan_mode?'A':'P'
-				, ss->ssid[0].SsidLength?'S':' '
+				, scan_type ? 'A' : 'P', ss->scan_mode ? 'A' : 'P'
+				, ss->ssid[0].SsidLength ? 'S' : ' '
+				, ss->dfs_ch_ssid_scan ? 'D' : ' '
 			);
 			#endif /* CONFIG_P2P */
-
-		#ifdef DBG_FIXED_CHAN
+		#endif /*DBG_SITESURVEY*/
+#ifdef DBG_FIXED_CHAN
 		if (pmlmeext->fixed_chan != 0xff)
-			DBG_871X(FUNC_ADPT_FMT" fixed_chan:%u\n", pmlmeext->fixed_chan);
-		#endif
+			RTW_INFO(FUNC_ADPT_FMT" fixed_chan:%u\n", pmlmeext->fixed_chan);
+#endif
 
 		site_survey(padapter, scan_ch, scan_type);
 
-		#if defined(CONFIG_ATMEL_RC_PATCH)
+#if defined(CONFIG_ATMEL_RC_PATCH)
 		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 			scan_ms = 20;
 		else
 			scan_ms = 40;
-		#else
-		scan_ms = ss->scan_ch_ms;
-		#endif
+#else
+		#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
+		if (IS_ACS_ENABLE(padapter) && rtw_is_acs_st_valid(padapter))
+			scan_ms = rtw_acs_get_adv_st(padapter);
+		else
+		#endif /*CONFIG_RTW_ACS*/
+			scan_ms = ss->scan_ch_ms;
+#endif
 
-		#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
+#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
 		if (ss->is_sw_antdiv_bl_scan)
-			scan_ms = scan_ms/2;
-		#endif
-
-		#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-		{
-			struct noise_info info;
+			scan_ms = scan_ms / 2;
+#endif
 
-			info.bPauseDIG = _FALSE;
-			info.IGIValue = 0;
-			info.max_time = scan_ms/2;
-			info.chan = scan_ch;
-			rtw_hal_set_odm_var(padapter, HAL_ODM_NOISE_MONITOR, &info, _FALSE); 
+#ifdef CONFIG_RTW_ACS
+		if (IS_ACS_ENABLE(padapter)) {
+			if (pparm->token)
+				rtw_acs_trigger(padapter, scan_ms, scan_ch, NHM_PID_IEEE_11K_HIGH);
+			else
+				rtw_acs_trigger(padapter, scan_ms, scan_ch, NHM_PID_ACS);
 		}
-		#endif
+#endif
 
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+		if (IS_NM_ENABLE(padapter))
+			rtw_noise_measure(padapter, scan_ch, _FALSE, 0, scan_ms / 2);
+#endif
 		set_survey_timer(pmlmeext, scan_ms);
 		break;
 	}
 
-	#ifdef CONFIG_SCAN_BACKOP
-	case SCAN_BACKING_OP:
-	{
+#ifdef CONFIG_SCAN_BACKOP
+	case SCAN_BACKING_OP: {
 		u8 back_ch, back_bw, back_ch_offset;
+		u8 need_ch_setting_union = _TRUE;
 
-		if (rtw_get_ch_setting_union(padapter, &back_ch, &back_bw, &back_ch_offset) == 0)
-			rtw_warn_on(1);
+#ifdef CONFIG_MCC_MODE
+		need_ch_setting_union = rtw_hal_mcc_change_scan_flag(padapter,
+				&back_ch, &back_bw, &back_ch_offset);
+#endif /* CONFIG_MCC_MODE */
 
-		if (0)
-			DBG_871X(FUNC_ADPT_FMT" %s ch:%u, bw:%u, offset:%u at %dms\n"
-				, FUNC_ADPT_ARG(padapter)
-				, mlmeext_scan_state_str(pmlmeext)
-				, back_ch, back_bw, back_ch_offset
-				, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
-			);
+		if (need_ch_setting_union) {
+			if (rtw_mi_get_ch_setting_union(padapter, &back_ch, &back_bw, &back_ch_offset) == 0)
+				rtw_warn_on(1);
+		}
 
+		#ifdef DBG_SITESURVEY
+			RTW_INFO(FUNC_ADPT_FMT" %s ch:%u, bw:%u, offset:%u at %dms\n"
+				 , FUNC_ADPT_ARG(padapter)
+				 , mlmeext_scan_state_str(pmlmeext)
+				 , back_ch, back_bw, back_ch_offset
+				, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
+				);
+		#endif /*DBG_SITESURVEY*/
 		set_channel_bwmode(padapter, back_ch, back_ch_offset, back_bw);
 
-		Set_MSR(padapter, (pmlmeinfo->state & 0x3));		
+		sitesurvey_set_msr(padapter, _FALSE);
+
 		val8 = 0; /* survey done */
 		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 
 		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC)) {
 			sitesurvey_set_igi(padapter);
-			sitesurvey_ps_annc(adapter_to_dvobj(padapter), 0);
+			rtw_hal_macid_wakeup_all_used(padapter);
+			rtw_ps_annc(padapter, 0);
 		}
 
 		mlmeext_set_scan_state(pmlmeext, SCAN_BACK_OP);
 		ss->backop_time = rtw_get_current_time();
 
-		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_TX_RESUME)) {
-			int	i;
-
-			/* resume TX */
-			for (i = 0; i < dvobj->iface_nums; i++) {
-				if (!dvobj->padapters[i])
-					continue;
+		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_TX_RESUME))
+			rtw_mi_os_xmit_schedule(padapter);
 
-				rtw_os_xmit_schedule(dvobj->padapters[i]);
-			}
-		}
 
 		goto operation_by_state;
 	}
-	
+
 	case SCAN_BACK_OP:
 		if (rtw_get_passing_time_ms(ss->backop_time) >= ss->backop_ms
-			|| pmlmeext->scan_abort
-		) {
+		    || pmlmeext->scan_abort
+		   ) {
 			mlmeext_set_scan_state(pmlmeext, SCAN_LEAVING_OP);
 			goto operation_by_state;
 		}
@@ -14067,14 +15488,15 @@ operation_by_state:
 
 	case SCAN_LEAVING_OP:
 		/*
-		* prepare to leave operating channel
-		*/
+		 * prepare to leave operating channel
+		 */
 
 		/* clear HW TX queue before scan */
 		rtw_hal_set_hwreg(padapter, HW_VAR_CHECK_TXBUF, 0);
 
+		rtw_hal_macid_sleep_all_used(padapter);
 		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC)
-			&& sitesurvey_ps_annc(adapter_to_dvobj(padapter), 1)
+			&& rtw_ps_annc(padapter, 1)
 		) {
 			mlmeext_set_scan_state(pmlmeext, SCAN_PS_ANNC_WAIT);
 			mlmeext_set_scan_next_state(pmlmeext, SCAN_LEAVE_OP);
@@ -14094,17 +15516,17 @@ operation_by_state:
 		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC))
 			sitesurvey_set_igi(padapter);
 
-		/* set MSR to no link state */
-		Set_MSR(padapter, _HW_STATE_NOLINK_);
-		val8 = 1; //under site survey
+		sitesurvey_set_msr(padapter, _TRUE);
+
+		val8 = 1; /* under site survey */
 		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 
 		mlmeext_set_scan_state(pmlmeext, SCAN_PROCESS);
 		goto operation_by_state;
 
-	#endif /* CONFIG_SCAN_BACKOP */
+#endif /* CONFIG_SCAN_BACKOP */
 
-	#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
+#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
 	case SCAN_SW_ANTDIV_BL:
 		/*
 		* 20100721
@@ -14118,9 +15540,9 @@ operation_by_state:
 		mlmeext_set_scan_next_state(pmlmeext, SCAN_PROCESS);
 		set_survey_timer(pmlmeext, ss->scan_ch_ms);
 		break;
-	#endif
+#endif
 
-	#ifdef CONFIG_P2P
+#ifdef CONFIG_P2P
 	case SCAN_TO_P2P_LISTEN:
 		/*
 		* Set the P2P State to the listen state of find phase
@@ -14128,7 +15550,7 @@ operation_by_state:
 		*/
 		set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_LISTEN);
-	
+
 		/* turn on phy-dynamic functions */
 		rtw_phydm_ability_restore(padapter);
 
@@ -14142,31 +15564,30 @@ operation_by_state:
 		mlmeext_set_scan_state(pmlmeext, SCAN_PROCESS);
 		ss->channel_idx = 0;
 		goto operation_by_state;
-	#endif /* CONFIG_P2P */
+#endif /* CONFIG_P2P */
 
-	case SCAN_COMPLETE:		
-		#ifdef CONFIG_P2P
+	case SCAN_COMPLETE:
+#ifdef CONFIG_P2P
 		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
-			|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH)
-		) {
-			#ifdef CONFIG_CONCURRENT_MODE
+		    || rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH)
+		   ) {
+#ifdef CONFIG_CONCURRENT_MODE
 			if (pwdinfo->driver_interface == DRIVER_WEXT) {
-				if (check_buddy_fwstate(padapter, _FW_LINKED))
+				if (rtw_mi_check_status(padapter, MI_LINKED))
 					_set_timer(&pwdinfo->ap_p2p_switch_timer, 500);
 			}
+#endif
+
 			rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-			#else
-			rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-			#endif
 		}
 		rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
-		#endif /* CONFIG_P2P */
+#endif /* CONFIG_P2P */
 
 		/* switch channel */
 		survey_done_set_ch_bw(padapter);
 
-		/* config MSR */
-		Set_MSR(padapter, (pmlmeinfo->state & 0x3));
+		sitesurvey_set_msr(padapter, _FALSE);
+
 		val8 = 0; /* survey done */
 		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 
@@ -14175,7 +15596,14 @@ operation_by_state:
 
 		sitesurvey_set_igi(padapter);
 
-		sitesurvey_ps_annc(adapter_to_dvobj(padapter), 0);
+#ifdef CONFIG_MCC_MODE
+		/* start MCC fail, then tx null data */
+		if (!rtw_hal_set_mcc_setting_scan_complete(padapter))
+#endif
+		{
+			rtw_hal_macid_wakeup_all_used(padapter);
+			rtw_ps_annc(padapter, 0);
+		}
 
 		/* apply rx ampdu setting */
 		rtw_rx_ampdu_apply(padapter);
@@ -14183,10 +15611,25 @@ operation_by_state:
 		mlmeext_set_scan_state(pmlmeext, SCAN_DISABLE);
 
 		report_surveydone_event(padapter);
+#ifdef CONFIG_RTW_ACS
+		if (IS_ACS_ENABLE(padapter))
+			rtw_acs_select_best_chan(padapter);
+#endif
 
+#if defined(CONFIG_BACKGROUND_NOISE_MONITOR) && defined(DBG_NOISE_MONITOR)
+		if (IS_NM_ENABLE(padapter))
+			rtw_noise_info_dump(RTW_DBGDUMP, padapter);
+#endif
 		issue_action_BSSCoexistPacket(padapter);
 		issue_action_BSSCoexistPacket(padapter);
 		issue_action_BSSCoexistPacket(padapter);
+
+#ifdef CONFIG_RTW_80211K
+		if (ss->token)
+			rm_post_event(padapter, ss->token, RM_EV_survey_done);
+#endif /* CONFIG_RTW_80211K */
+
+		break;
 	}
 
 	return H2C_SUCCESS;
@@ -14197,15 +15640,27 @@ u8 setauth_hdl(_adapter *padapter, unsigned char *pbuf)
 	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;
+	return	H2C_SUCCESS;
 }
 
+/*
+SEC CAM Entry format (32 bytes)
+DW0 - MAC_ADDR[15:0] | Valid[15] | MFB[14:8] | RSVD[7]  | GK[6] | MIC_KEY[5] | SEC_TYPE[4:2] | KID[1:0]
+DW0 - MAC_ADDR[15:0] | Valid[15] |RSVD[14:9] | RPT_MODE[8] | SPP_MODE[7]  | GK[6] | MIC_KEY[5] | SEC_TYPE[4:2] | KID[1:0] (92E/8812A/8814A)
+DW1 - MAC_ADDR[47:16]
+DW2 - KEY[31:0]
+DW3 - KEY[63:32]
+DW4 - KEY[95:64]
+DW5 - KEY[127:96]
+DW6 - RSVD
+DW7 - RSVD
+*/
+
+/*Set WEP key or Group Key*/
 u8 setkey_hdl(_adapter *padapter, u8 *pbuf)
 {
 	u16	ctrl = 0;
@@ -14214,31 +15669,45 @@ u8 setkey_hdl(_adapter *padapter, u8 *pbuf)
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	unsigned char null_addr[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
-	struct set_stakey_parm	sta_pparm;
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	u8 *addr;
-	bool used;
+	bool used = _FALSE;
 
-	//main tx key for wep.
-	if(pparm->set_tx)
+	/* main tx key for wep. */
+	if (pparm->set_tx)
 		pmlmeinfo->key_index = pparm->keyid;
 
-	cam_id = rtw_camid_alloc(padapter, NULL, pparm->keyid, &used);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
+		cam_id = rtw_iface_bcmc_id_get(padapter);
+	else
+#endif
+		cam_id = rtw_camid_alloc(padapter, NULL, pparm->keyid, 1, &used);
 
 	if (cam_id < 0)
 		goto enable_mc;
 
-	if (cam_id > 3) /* not default key, searched by A2 */
-		addr = get_bssid(&padapter->mlmepriv);
-	else
+#ifndef CONFIG_CONCURRENT_MODE
+	if (cam_id >= 0 && cam_id <= 3) {
+		/* default key camid */
 		addr = null_addr;
+	} else
+#endif
+	{
+		/* not default key camid */
+		if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)) {
+			/* group TX, force sec cam entry_id */
+			addr = adapter_mac_addr(padapter);
+		} else {
+			/* group RX, searched by A2 (TA) */
+			addr = get_bssid(&padapter->mlmepriv);
+		}
+	}
 
-	#ifdef DYNAMIC_CAMID_ALLOC
 	/* cam entry searched is pairwise key */
 	if (used == _TRUE && rtw_camid_is_gk(padapter, cam_id) == _FALSE) {
 		s16 camid_clr;
 
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" group key with "MAC_FMT" id:%u the same key id as pairwise key\n"
+		RTW_PRINT(FUNC_ADPT_FMT" group key with "MAC_FMT" id:%u the same key id as pairwise key\n"
 			, FUNC_ADPT_ARG(padapter), MAC_ARG(addr), pparm->keyid);
 
 		/* HW has problem to distinguish this group key with existing pairwise key, stop HW enc and dec for BMC */
@@ -14247,42 +15716,97 @@ u8 setkey_hdl(_adapter *padapter, u8 *pbuf)
 
 		/* clear group key */
 		while ((camid_clr = rtw_camid_search(padapter, addr, -1, 1)) >= 0) {
-			DBG_871X_LEVEL(_drv_always_, "clear group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(addr), camid_clr);
+			RTW_PRINT("clear group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(addr), camid_clr);
 			clear_cam_entry(padapter, camid_clr);
 			rtw_camid_free(padapter, camid_clr);
 		}
 
 		goto enable_mc;
 	}
-	#endif
 
-	ctrl = BIT(15) | BIT6 | ((pparm->algorithm) << 2) | pparm->keyid;
-	DBG_871X_LEVEL(_drv_always_, "set group key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n"
+	ctrl = BIT(15) | BIT(6) | ((pparm->algorithm) << 2) | pparm->keyid;
+
+	RTW_PRINT("set group key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n"
 		, cam_id, MAC_ARG(addr), pparm->keyid, security_type_str(pparm->algorithm));
+
 	write_cam(padapter, cam_id, ctrl, addr, pparm->key);
 
-	#ifdef DYNAMIC_CAMID_ALLOC
-	if (cam_id >=0 && cam_id <=3)
-		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8*)_TRUE);
-	#endif
+	/* if ((cam_id > 3) && (((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)))*/
+#ifdef CONFIG_CONCURRENT_MODE
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)) {
+		if (is_wep_enc(pparm->algorithm)) {
+			padapter->securitypriv.dot11Def_camid[pparm->keyid] = cam_id;
+			padapter->securitypriv.dot118021x_bmc_cam_id =
+				padapter->securitypriv.dot11Def_camid[padapter->securitypriv.dot11PrivacyKeyIndex];
+			RTW_PRINT("wep group key - force camid:%d\n", padapter->securitypriv.dot118021x_bmc_cam_id);
+		} else {
+			/*u8 org_cam_id = padapter->securitypriv.dot118021x_bmc_cam_id;*/
+
+			/*force GK's cam id*/
+			padapter->securitypriv.dot118021x_bmc_cam_id = cam_id;
+
+			/* for GTK rekey
+			if ((org_cam_id != INVALID_SEC_MAC_CAM_ID) &&
+				(org_cam_id != cam_id)) {
+				RTW_PRINT("clear group key for addr:"MAC_FMT", org_camid:%d new_camid:%d\n", MAC_ARG(addr), org_cam_id, cam_id);
+				clear_cam_entry(padapter, org_cam_id);
+				rtw_camid_free(padapter, org_cam_id);
+			}*/
+		}
+	}
+#endif
+
+
+#ifndef CONFIG_CONCURRENT_MODE
+	if (cam_id >= 0 && cam_id <= 3)
+		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8 *)_TRUE);
+#endif
+
 	/* 8814au should set both broadcast and unicast CAM entry for WEP key in STA mode */
-	if (_rtw_camctl_chk_cap(padapter, SEC_CAP_CHK_BMC) && is_wep_enc(psecuritypriv->dot11PrivacyAlgrthm)) {
-		struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	if (is_wep_enc(pparm->algorithm) && check_mlmeinfo_state(pmlmeext, WIFI_FW_STATION_STATE) &&
+	    _rtw_camctl_chk_cap(padapter, SEC_CAP_CHK_BMC)) {
+		struct set_stakey_parm	sta_pparm;
 
+		_rtw_memset(&sta_pparm, 0, sizeof(struct set_stakey_parm));
 		sta_pparm.algorithm = pparm->algorithm;
 		sta_pparm.keyid = pparm->keyid;
 		_rtw_memcpy(sta_pparm.key, pparm->key, 16);
-		_rtw_memcpy(sta_pparm.addr, get_bssid(pmlmepriv), ETH_ALEN);
-		set_stakey_hdl(padapter, (u8 *) &sta_pparm);
+		_rtw_memcpy(sta_pparm.addr, get_bssid(&padapter->mlmepriv), ETH_ALEN);
+		set_stakey_hdl(padapter, (u8 *)&sta_pparm);
 	}
 
 enable_mc:
-	//allow multicast packets to driver
+	/* allow multicast packets to driver */
 	rtw_hal_set_hwreg(padapter, HW_VAR_ON_RCR_AM, null_addr);
 
 	return H2C_SUCCESS;
 }
 
+void rtw_ap_wep_pk_setting(_adapter *adapter, struct sta_info *psta)
+{
+	struct security_priv *psecuritypriv = &(adapter->securitypriv);
+	struct set_stakey_parm	sta_pparm;
+	sint keyid;
+
+	if (!is_wep_enc(psecuritypriv->dot11PrivacyAlgrthm))
+		return;
+
+	for (keyid = 0; keyid < 4; keyid++) {
+		if ((psecuritypriv->key_mask & BIT(keyid)) && (keyid == psecuritypriv->dot11PrivacyKeyIndex)) {
+			sta_pparm.algorithm = psecuritypriv->dot11PrivacyAlgrthm;
+			sta_pparm.keyid = keyid;
+			sta_pparm.gk = 0;
+			_rtw_memcpy(sta_pparm.key, &(psecuritypriv->dot11DefKey[keyid].skey[0]), 16);
+			_rtw_memcpy(sta_pparm.addr, psta->cmn.mac_addr, ETH_ALEN);
+
+			RTW_PRINT(FUNC_ADPT_FMT"set WEP - PK with "MAC_FMT" keyid:%u\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr), keyid);
+
+			set_stakey_hdl(adapter, (u8 *)&sta_pparm);
+		}
+	}
+}
+
 u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf)
 {
 	u16 ctrl = 0;
@@ -14295,27 +15819,27 @@ u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf)
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct sta_info *psta;
 
-	if(pparm->algorithm == _NO_PRIVACY_)
+	if (pparm->algorithm == _NO_PRIVACY_)
 		goto write_to_cam;
 
 	psta = rtw_get_stainfo(pstapriv, pparm->addr);
 	if (!psta) {
-		DBG_871X_LEVEL(_drv_always_, "%s sta:"MAC_FMT" not found\n", __func__, MAC_ARG(pparm->addr));
+		RTW_PRINT("%s sta:"MAC_FMT" not found\n", __func__, MAC_ARG(pparm->addr));
 		ret = H2C_REJECTED;
 		goto exit;
 	}
 
 	pmlmeinfo->enc_algo = pparm->algorithm;
-	cam_id = rtw_camid_alloc(padapter, psta, 0, &used);
+
+	cam_id = rtw_camid_alloc(padapter, psta, pparm->keyid, pparm->gk, &used);
 	if (cam_id < 0)
 		goto exit;
 
-	#ifdef DYNAMIC_CAMID_ALLOC
-	/* cam entry searched is group key */
-	if (used == _TRUE && rtw_camid_is_gk(padapter, cam_id) == _TRUE) {
+	/* cam entry searched is group key when setting pariwise key */
+	if (!pparm->gk && used == _TRUE && rtw_camid_is_gk(padapter, cam_id) == _TRUE) {
 		s16 camid_clr;
 
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" pairwise key with "MAC_FMT" id:%u the same key id as group key\n"
+		RTW_PRINT(FUNC_ADPT_FMT" pairwise key with "MAC_FMT" id:%u the same key id as group key\n"
 			, FUNC_ADPT_ARG(padapter), MAC_ARG(pparm->addr), pparm->keyid);
 
 		/* HW has problem to distinguish this pairwise key with existing group key, stop HW enc and dec for BMC */
@@ -14324,24 +15848,26 @@ u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf)
 
 		/* clear group key */
 		while ((camid_clr = rtw_camid_search(padapter, pparm->addr, -1, 1)) >= 0) {
-			DBG_871X_LEVEL(_drv_always_, "clear group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(pparm->addr), camid_clr);
+			RTW_PRINT("clear group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(pparm->addr), camid_clr);
 			clear_cam_entry(padapter, camid_clr);
 			rtw_camid_free(padapter, camid_clr);
 		}
 	}
-	#endif
 
 write_to_cam:
-	if(pparm->algorithm == _NO_PRIVACY_) {
+	if (pparm->algorithm == _NO_PRIVACY_) {
 		while ((cam_id = rtw_camid_search(padapter, pparm->addr, -1, -1)) >= 0) {
-			DBG_871X_LEVEL(_drv_always_, "clear key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(pparm->addr), cam_id);
+			RTW_PRINT("clear key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(pparm->addr), cam_id);
 			clear_cam_entry(padapter, cam_id);
-			rtw_camid_free(padapter,cam_id);
+			rtw_camid_free(padapter, cam_id);
 		}
 	} else {
-		DBG_871X_LEVEL(_drv_always_, "set pairwise key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n",
-			cam_id, MAC_ARG(pparm->addr), pparm->keyid, security_type_str(pparm->algorithm));
+		RTW_PRINT("set %s key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n"
+			, pparm->gk ? "group" : "pairwise"
+			, cam_id, MAC_ARG(pparm->addr), pparm->keyid, security_type_str(pparm->algorithm));
 		ctrl = BIT(15) | ((pparm->algorithm) << 2) | pparm->keyid;
+		if (pparm->gk)
+			ctrl |= BIT(6);
 		write_cam(padapter, cam_id, ctrl, pparm->addr, pparm->key);
 	}
 	ret = H2C_SUCCESS_RSP;
@@ -14352,55 +15878,95 @@ exit:
 
 u8 add_ba_hdl(_adapter *padapter, unsigned char *pbuf)
 {
-	struct addBaReq_parm 	*pparm = (struct addBaReq_parm *)pbuf;
+	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 = rtw_get_stainfo(&padapter->stapriv, pparm->addr);
-	
-	if(!psta)
-		return 	H2C_SUCCESS;
-		
+
+	if (!psta)
+		return	H2C_SUCCESS;
+
 #ifdef CONFIG_80211N_HT
 	if (((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) && (pmlmeinfo->HT_enable)) ||
-		((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE))
-	{
-		//pmlmeinfo->ADDBA_retry_count = 0;
-		//pmlmeinfo->candidate_tid_bitmap |= (0x1 << pparm->tid);		
-		//psta->htpriv.candidate_tid_bitmap |= BIT(pparm->tid);
+	    ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
+		/* pmlmeinfo->ADDBA_retry_count = 0; */
+		/* pmlmeinfo->candidate_tid_bitmap |= (0x1 << pparm->tid);		 */
+		/* psta->htpriv.candidate_tid_bitmap |= BIT(pparm->tid); */
 		issue_addba_req(padapter, pparm->addr, (u8)pparm->tid);
-		//_set_timer(&pmlmeext->ADDBA_timer, ADDBA_TO);
 		_set_timer(&psta->addba_retry_timer, ADDBA_TO);
 	}
 #ifdef CONFIG_TDLS
-	else if((psta->tdls_sta_state & TDLS_LINKED_STATE)&& 
-		(psta->htpriv.ht_option==_TRUE) && 
-		(psta->htpriv.ampdu_enable==_TRUE) )
-	{
+	else if ((psta->tdls_sta_state & TDLS_LINKED_STATE) &&
+		 (psta->htpriv.ht_option == _TRUE) &&
+		 (psta->htpriv.ampdu_enable == _TRUE)) {
 		issue_addba_req(padapter, pparm->addr, (u8)pparm->tid);
 		_set_timer(&psta->addba_retry_timer, ADDBA_TO);
 	}
-#endif //CONFIG
+#endif /* CONFIG */
 	else
-	{		
-		psta->htpriv.candidate_tid_bitmap &= ~BIT(pparm->tid);		
-	}
-#endif //CONFIG_80211N_HT
-	return 	H2C_SUCCESS;
+		psta->htpriv.candidate_tid_bitmap &= ~BIT(pparm->tid);
+#endif /* CONFIG_80211N_HT */
+	return	H2C_SUCCESS;
 }
 
 
-u8 chk_bmc_sleepq_cmd(_adapter* padapter)
+u8 add_ba_rsp_hdl(_adapter *padapter, unsigned char *pbuf)
+{
+	struct addBaRsp_parm *pparm = (struct addBaRsp_parm *)pbuf;
+	u8 ret = _TRUE, i = 0, try_cnt = 3, wait_ms = 50;
+	struct recv_reorder_ctrl *preorder_ctrl;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta;
+
+	psta = rtw_get_stainfo(pstapriv, pparm->addr);
+	if (!psta)
+		goto exit;
+
+	preorder_ctrl = &psta->recvreorder_ctrl[pparm->tid];
+	ret = issue_addba_rsp_wait_ack(padapter, pparm->addr, pparm->tid, pparm->status, pparm->size, 3, 50);
+
+#ifdef CONFIG_UPDATE_INDICATE_SEQ_WHILE_PROCESS_ADDBA_REQ
+	/* status = 0 means accept this addba req, so update indicate seq = start_seq under this compile flag */
+	if (pparm->status == 0) {
+		preorder_ctrl->indicate_seq = pparm->start_seq;
+		#ifdef DBG_RX_SEQ
+		RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_UPDATE indicate_seq:%d, start_seq:%d\n"
+			, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, pparm->start_seq);
+		#endif
+	}
+#else
+	preorder_ctrl->indicate_seq = 0xffff;
+	#ifdef DBG_RX_SEQ
+	RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_CLEAR indicate_seq:%d, start_seq:%d\n"
+		, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, pparm->start_seq);
+	#endif
+#endif
+
+	/*
+	  * status = 0 means accept this addba req
+	  * status = 37 means reject this addba req
+	  */
+	if (pparm->status == 0) {
+		preorder_ctrl->enable = _TRUE;
+		preorder_ctrl->ampdu_size = pparm->size;
+	} else if (pparm->status == 37)
+		preorder_ctrl->enable = _FALSE;
+
+exit:
+	return H2C_SUCCESS;
+}
+
+u8 chk_bmc_sleepq_cmd(_adapter *padapter)
 {
 	struct cmd_obj *ph2c;
 	struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
 	u8 res = _SUCCESS;
 
-_func_enter_;
 
-	if ((ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
-	{
-		res= _FAIL;
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -14410,53 +15976,50 @@ _func_enter_;
 
 exit:
 
-_func_exit_;
 
 	return res;
 }
 
-u8 set_tx_beacon_cmd(_adapter* padapter)
+u8 set_tx_beacon_cmd(_adapter *padapter)
 {
 	struct cmd_obj	*ph2c;
-	struct Tx_Beacon_param 	*ptxBeacon_parm;	
+	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;
-	
-_func_enter_;	
 
-	if ((ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
-	{
-		res= _FAIL;
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
-	if ((ptxBeacon_parm = (struct Tx_Beacon_param *)rtw_zmalloc(sizeof(struct Tx_Beacon_param))) == NULL)
-	{
+	ptxBeacon_parm = (struct Tx_Beacon_param *)rtw_zmalloc(sizeof(struct Tx_Beacon_param));
+	if (ptxBeacon_parm == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct	cmd_obj));
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 
 	_rtw_memcpy(&(ptxBeacon_parm->network), &(pmlmeinfo->network), sizeof(WLAN_BSSID_EX));
 
 	len_diff = update_hidden_ssid(
-		ptxBeacon_parm->network.IEs+_BEACON_IE_OFFSET_
-		, ptxBeacon_parm->network.IELength-_BEACON_IE_OFFSET_
-		, pmlmeinfo->hidden_ssid_mode
-	);
+			   ptxBeacon_parm->network.IEs + _BEACON_IE_OFFSET_
+		   , ptxBeacon_parm->network.IELength - _BEACON_IE_OFFSET_
+			   , 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_cmd(pcmdpriv, ph2c);
 
-	
+
 exit:
-	
-_func_exit_;
+
 
 	return res;
 }
@@ -14466,57 +16029,49 @@ u8 mlme_evt_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 	u8 evt_code, evt_seq;
 	u16 evt_sz;
-	uint 	*peventbuf;
+	uint	*peventbuf;
 	void (*event_callback)(_adapter *dev, u8 *pbuf);
 	struct evt_priv *pevt_priv = &(padapter->evtpriv);
 
 	if (pbuf == NULL)
 		goto _abort_event_;
 
-	peventbuf = (uint*)pbuf;
-	evt_sz = (u16)(*peventbuf&0xffff);
-	evt_seq = (u8)((*peventbuf>>24)&0x7f);
-	evt_code = (u8)((*peventbuf>>16)&0xff);
-	
-		
-	#ifdef CHECK_EVENT_SEQ
-	// checking event sequence...		
-	if (evt_seq != (ATOMIC_READ(&pevt_priv->event_seq) & 0x7f) )
-	{
-		RT_TRACE(_module_rtl871x_cmd_c_,_drv_info_,("Evetn Seq Error! %d vs %d\n", (evt_seq & 0x7f), (ATOMIC_READ(&pevt_priv->event_seq) & 0x7f)));
-	
-		pevt_priv->event_seq = (evt_seq+1)&0x7f;
+	peventbuf = (uint *)pbuf;
+	evt_sz = (u16)(*peventbuf & 0xffff);
+	evt_seq = (u8)((*peventbuf >> 24) & 0x7f);
+	evt_code = (u8)((*peventbuf >> 16) & 0xff);
+
+
+#ifdef CHECK_EVENT_SEQ
+	/* checking event sequence...		 */
+	if (evt_seq != (ATOMIC_READ(&pevt_priv->event_seq) & 0x7f)) {
+
+		pevt_priv->event_seq = (evt_seq + 1) & 0x7f;
 
 		goto _abort_event_;
 	}
-	#endif
+#endif
 
-	// checking if event code is valid
-	if (evt_code >= MAX_C2HEVT)
-	{
-		RT_TRACE(_module_rtl871x_cmd_c_,_drv_err_,("\nEvent Code(%d) mismatch!\n", evt_code));
+	/* checking if event code is valid */
+	if (evt_code >= MAX_C2HEVT) {
 		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_,("\nEvent(%d) Parm Size mismatch (%d vs %d)!\n", 
-			evt_code, wlanevents[evt_code].parmsize, evt_sz));
-		goto _abort_event_;	
-			
+	/* checking if event size match the event parm size	 */
+	if ((wlanevents[evt_code].parmsize != 0) &&
+	    (wlanevents[evt_code].parmsize != evt_sz)) {
+
+		goto _abort_event_;
+
 	}
 
 	ATOMIC_INC(&pevt_priv->event_seq);
 
 	peventbuf += 2;
-				
-	if(peventbuf)
-	{
+
+	if (peventbuf) {
 		event_callback = wlanevents[evt_code].event_callback;
-		event_callback(padapter, (u8*)peventbuf);
+		event_callback(padapter, (u8 *)peventbuf);
 
 		pevt_priv->evt_done_cnt++;
 	}
@@ -14526,12 +16081,12 @@ _abort_event_:
 
 
 	return H2C_SUCCESS;
-		
+
 }
 
 u8 h2c_msg_hdl(_adapter *padapter, unsigned char *pbuf)
 {
-	if(!pbuf)
+	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
 
 	return H2C_SUCCESS;
@@ -14543,28 +16098,26 @@ u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf)
 	_irqL irqL;
 	struct sta_info *psta_bmc;
 	_list	*xmitframe_plist, *xmitframe_phead;
-	struct xmit_frame *pxmitframe=NULL;
+	struct xmit_frame *pxmitframe = NULL;
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	struct sta_priv  *pstapriv = &padapter->stapriv;
 
-	//for BC/MC Frames
+	/* for BC/MC Frames */
 	psta_bmc = rtw_get_bcmc_stainfo(padapter);
-	if(!psta_bmc)
+	if (!psta_bmc)
 		return H2C_SUCCESS;
 
-	if((pstapriv->tim_bitmap&BIT(0)) && (psta_bmc->sleepq_len>0))
-	{
+	if ((rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) && (psta_bmc->sleepq_len > 0)) {
 #ifndef CONFIG_PCI_HCI
-		rtw_msleep_os(10);// 10ms, ATIM(HIQ) Windows
+		rtw_msleep_os(10);/* 10ms, ATIM(HIQ) Windows */
 #endif
-		//_enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
+		/* _enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL); */
 		_enter_critical_bh(&pxmitpriv->lock, &irqL);
 
 		xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
 		xmitframe_plist = get_next(xmitframe_phead);
 
-		while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE)
-		{
+		while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
 			pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
 
 			xmitframe_plist = get_next(xmitframe_plist);
@@ -14572,28 +16125,26 @@ u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf)
 			rtw_list_delete(&pxmitframe->list);
 
 			psta_bmc->sleepq_len--;
-			if(psta_bmc->sleepq_len>0)
+			if (psta_bmc->sleepq_len > 0)
 				pxmitframe->attrib.mdata = 1;
 			else
 				pxmitframe->attrib.mdata = 0;
 
-			pxmitframe->attrib.triggered=1;
+			pxmitframe->attrib.triggered = 1;
 
 			if (xmitframe_hiq_filter(pxmitframe) == _TRUE)
-				pxmitframe->attrib.qsel = QSLT_HIGH;//HIQ
+				pxmitframe->attrib.qsel = QSLT_HIGH;/* HIQ */
 
-			#if 0
+#if 0
 			_exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
-			if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
-			{
+			if (rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
 				rtw_os_xmit_complete(padapter, pxmitframe);
-			}
 			_enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
-			#endif
+#endif
 			rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
 		}
 
-		//_exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
+		/* _exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL); */
 		_exit_critical_bh(&pxmitpriv->lock, &irqL);
 
 		if (rtw_get_intf_type(padapter) != RTW_PCIE) {
@@ -14608,18 +16159,21 @@ u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf)
 
 u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf)
 {
-	if(send_beacon(padapter)==_FAIL)
-	{
-		DBG_871X("issue_beacon, fail!\n");
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+
+	tx_beacon_handlder(padapter->dvobj);
+
+#else
+
+	if (send_beacon(padapter) == _FAIL) {
+		RTW_INFO("issue_beacon, fail!\n");
 		return H2C_PARAMETERS_ERROR;
 	}
 
-
-	if (padapter->registrypriv.wifi_spec == 1)
-		return H2C_SUCCESS;
-	
 	/* tx bc/mc frames after update TIM */
 	chk_bmc_sleepq_hdl(padapter, NULL);
+#endif
 
 	return H2C_SUCCESS;
 }
@@ -14632,77 +16186,60 @@ u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf)
 */
 void change_band_update_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 ch)
 {
-	u8	network_type,rate_len, total_rate_len,remainder_rate_len;
+	u8	network_type, rate_len, total_rate_len, remainder_rate_len;
 	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8	erpinfo=0x4;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	u8	erpinfo = 0x4;
 
 	if (ch >= 36) {
 		network_type = WIRELESS_11A;
 		total_rate_len = IEEE80211_NUM_OFDM_RATESLEN;
 		rtw_remove_bcn_ie(padapter, pnetwork, _ERPINFO_IE_);
+		#ifdef CONFIG_80211AC_VHT
+		/* if channel in 5G band, then add vht ie . */
+		if ((pmlmepriv->htpriv.ht_option == _TRUE)
+			&& REGSTY_IS_11AC_ENABLE(&padapter->registrypriv)
+			&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+			&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+		) {
+			if (REGSTY_IS_11AC_AUTO(&padapter->registrypriv)
+				|| pmlmepriv->ori_vht_en)
+				rtw_vht_ies_attach(padapter, pnetwork);
+		}
+		#endif
 	} else {
 		network_type = WIRELESS_11BG;
-		total_rate_len = IEEE80211_CCK_RATE_LEN+IEEE80211_NUM_OFDM_RATESLEN;
+		total_rate_len = IEEE80211_CCK_RATE_LEN + IEEE80211_NUM_OFDM_RATESLEN;
 		rtw_add_bcn_ie(padapter, pnetwork, _ERPINFO_IE_, &erpinfo, 1);
+		#ifdef CONFIG_80211AC_VHT
+		rtw_vht_ies_detach(padapter, pnetwork);
+		#endif
 	}
 
 	rtw_set_supported_rate(pnetwork->SupportedRates, network_type);
 
 	UpdateBrateTbl(padapter, pnetwork->SupportedRates);
 
-	if(total_rate_len > 8)
-	{
+	if (total_rate_len > 8) {
 		rate_len = 8;
 		remainder_rate_len = total_rate_len - 8;
-	}
-	else
-	{
+	} else {
 		rate_len = total_rate_len;
 		remainder_rate_len = 0;
 	}
 
 	rtw_add_bcn_ie(padapter, pnetwork, _SUPPORTEDRATES_IE_, pnetwork->SupportedRates, rate_len);
 
-	if(remainder_rate_len)
-	{
-		rtw_add_bcn_ie(padapter, pnetwork, _EXT_SUPPORTEDRATES_IE_, (pnetwork->SupportedRates+8), remainder_rate_len);
-	}
+	if (remainder_rate_len)
+		rtw_add_bcn_ie(padapter, pnetwork, _EXT_SUPPORTEDRATES_IE_, (pnetwork->SupportedRates + 8), remainder_rate_len);
 	else
-	{
 		rtw_remove_bcn_ie(padapter, pnetwork, _EXT_SUPPORTEDRATES_IE_);
-	}
 
 	pnetwork->Length = get_WLAN_BSSID_EX_sz(pnetwork);
 }
 
-#ifdef CONFIG_CONCURRENT_MODE
-sint check_buddy_mlmeinfo_state(_adapter *padapter, u32 state)
-{
-	PADAPTER pbuddy_adapter;
-	struct mlme_ext_priv *pbuddy_mlmeext;
-	struct mlme_ext_info *pbuddy_mlmeinfo;
-
-	if(padapter == NULL)
-		return _FALSE;	
-	
-	pbuddy_adapter = padapter->pbuddy_adapter;
-
-	if(pbuddy_adapter == NULL)
-		return _FALSE;	
-
-
-	pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-	pbuddy_mlmeinfo = &(pbuddy_mlmeext->mlmext_info);
-		
-	if((pbuddy_mlmeinfo->state&0x03) == state)
-		return _TRUE;		
-
-	return _FALSE;
-	
-}
-#endif /* CONFIG_CONCURRENT_MODE */
-
 void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 {
 #define DUMP_ADAPTERS_STATUS 0
@@ -14717,12 +16254,19 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 	dvobj = adapter_to_dvobj(adapter);
 
 	if (DUMP_ADAPTERS_STATUS) {
-		DBG_871X(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(adapter));
+		RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(adapter));
 		dump_adapters_status(RTW_DBGDUMP , dvobj);
 	}
 
 	if (join_res >= 0) {
-		if (rtw_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset) <= 0) {
+
+#ifdef CONFIG_MCC_MODE
+		/* MCC setting success, don't go to ch union process */
+		if (rtw_hal_set_mcc_setting_join_done_chk_ch(adapter))
+			return;
+#endif /* CONFIG_MCC_MODE */
+
+		if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset) <= 0) {
 			dump_adapters_status(RTW_DBGDUMP , dvobj);
 			rtw_warn_on(1);
 		}
@@ -14735,7 +16279,7 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 			if (!iface || iface == adapter)
 				continue;
 
-			if (check_fwstate(mlme, WIFI_AP_STATE)
+			if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
 				&& check_fwstate(mlme, WIFI_ASOC_STATE)
 			) {
 				bool is_grouped = rtw_is_chbw_grouped(u_ch, u_bw, u_offset
@@ -14749,8 +16293,9 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 					mlmeext->cur_channel = u_ch;
 					rtw_adjust_chbw(iface
 						, mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset);
-					
-					rtw_sync_chbw(&mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
+
+					rtw_chset_sync_chbw(adapter_to_chset(adapter)
+						, &mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
 						, &u_ch, &u_bw, &u_offset);
 
 					rtw_ap_update_bss_chbw(iface, &(mlmeext->mlmext_info.network)
@@ -14759,17 +16304,24 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 					_rtw_memcpy(&(mlme->cur_network.network), &(mlmeext->mlmext_info.network), sizeof(WLAN_BSSID_EX));
 
 					rtw_start_bss_hdl_after_chbw_decided(iface);
+
+					if (MLME_IS_GO(iface) || MLME_IS_MESH(iface)) { /* pure AP is not needed*/
+						#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+						rtw_cfg80211_ch_switch_notify(iface
+							, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset
+							, mlme->htpriv.ht_option);
+						#endif
+					}
 				}
 
-				update_beacon(iface, 0, NULL, _TRUE);
+				clr_fwstate(mlme, WIFI_OP_CH_SWITCHING);
+				update_beacon(iface, 0xFF, NULL, _TRUE);
 			}
-
-			clr_fwstate(mlme, WIFI_OP_CH_SWITCHING);
 		}
 
-		#ifdef CONFIG_DFS_MASTER
+#ifdef CONFIG_DFS_MASTER
 		rtw_dfs_master_status_apply(adapter, MLME_STA_CONNECTED);
-		#endif
+#endif
 	} else {
 		for (i = 0; i < dvobj->iface_nums; i++) {
 			iface = dvobj->padapters[i];
@@ -14779,22 +16331,25 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 			if (!iface || iface == adapter)
 				continue;
 
-			if (check_fwstate(mlme, WIFI_AP_STATE)
-				&& check_fwstate(mlme, WIFI_ASOC_STATE))
-				update_beacon(iface, 0, NULL, _TRUE);
-
-			clr_fwstate(mlme, WIFI_OP_CH_SWITCHING);
+			if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
+				&& check_fwstate(mlme, WIFI_ASOC_STATE)
+			) {
+				clr_fwstate(mlme, WIFI_OP_CH_SWITCHING);
+				update_beacon(iface, 0xFF, NULL, _TRUE);
+			}
 		}
-		#ifdef CONFIG_DFS_MASTER
+#ifdef CONFIG_DFS_MASTER
 		rtw_dfs_master_status_apply(adapter, MLME_STA_DISCONNECTED);
-		#endif
+#endif
 	}
 
-	if (rtw_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset))
+	if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset)) {
 		set_channel_bwmode(adapter, u_ch, u_offset, u_bw);
+		rtw_mi_update_union_chan_inf(adapter, u_ch, u_offset, u_bw);
+	}
 
 	if (DUMP_ADAPTERS_STATUS) {
-		DBG_871X(FUNC_ADPT_FMT" exit\n", FUNC_ADPT_ARG(adapter));
+		RTW_INFO(FUNC_ADPT_FMT" exit\n", FUNC_ADPT_ARG(adapter));
 		dump_adapters_status(RTW_DBGDUMP , dvobj);
 	}
 }
@@ -14819,321 +16374,162 @@ int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 
 	if (cur_ch == 0) {
 		connect_allow = _FALSE;
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" cur_ch:%u\n"
+		RTW_ERR(FUNC_ADPT_FMT" cur_ch:%u\n"
 			, FUNC_ADPT_ARG(adapter), cur_ch);
 		rtw_warn_on(1);
 		goto exit;
 	}
-	DBG_871X(FUNC_ADPT_FMT" req: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
+	RTW_INFO(FUNC_ADPT_FMT" req: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
 
 #ifdef CONFIG_CONCURRENT_MODE
-{
-	struct dvobj_priv *dvobj;
-	_adapter *iface;
-	struct mlme_priv *mlme;
-	struct mlme_ext_priv *mlmeext;
-	u8 sta_num;
-	u8 ld_sta_num;
-	u8 lg_sta_num;
-	u8 ap_num;
-	u8 ld_ap_num;
-	int i;
-
-	dvobj = adapter_to_dvobj(adapter);
-
-	rtw_dev_iface_status_no_self(adapter, &sta_num, &ld_sta_num, &lg_sta_num, &ap_num, &ld_ap_num);
-	DBG_871X(FUNC_ADPT_FMT" ld_sta_num:%u, ap_num:%u\n"
-		, FUNC_ADPT_ARG(adapter), ld_sta_num, ap_num);
-
-	if (!ld_sta_num && !ap_num) {
-		/* consider linking STA? */
-		goto connect_allow_hdl;
-	}
-
-	if (rtw_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset) <= 0) {
-		dump_adapters_status(RTW_DBGDUMP , dvobj);
-		rtw_warn_on(1);
-	}
-	DBG_871X(FUNC_ADPT_FMT" union no self: %u,%u,%u\n"
-		, FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
+	{
+		struct dvobj_priv *dvobj;
+		_adapter *iface;
+		struct mlme_priv *mlme;
+		struct mlme_ext_priv *mlmeext;
+		struct mi_state mstate;
+		int i;
 
-	/* chbw_allow? */
-	chbw_allow = rtw_is_chbw_grouped(pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset
-		, u_ch, u_bw, u_offset);
+		dvobj = adapter_to_dvobj(adapter);
 
-	DBG_871X(FUNC_ADPT_FMT" chbw_allow:%d\n"
-		, FUNC_ADPT_ARG(adapter), chbw_allow);
+		rtw_mi_status_no_self(adapter, &mstate);
+		RTW_INFO(FUNC_ADPT_FMT" ld_sta_num:%u, ap_num:%u, mesh_num:%u\n"
+			, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate)
+			, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate));
 
-	if (chbw_allow == _TRUE) {
-		rtw_sync_chbw(&cur_ch, &cur_bw, &cur_ch_offset, &u_ch, &u_bw, &u_offset);
-		rtw_warn_on(cur_ch != pmlmeext->cur_channel);
-		rtw_warn_on(cur_bw != pmlmeext->cur_bwmode);
-		rtw_warn_on(cur_ch_offset != pmlmeext->cur_ch_offset);
-		goto connect_allow_hdl;
-	}
+		if (!MSTATE_STA_LD_NUM(&mstate) && !MSTATE_AP_NUM(&mstate) && !MSTATE_MESH_NUM(&mstate)) {
+			/* consider linking STA? */
+			goto connect_allow_hdl;
+		}
 
-	/* chbw_allow is _FALSE, connect allow? */
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		iface = dvobj->padapters[i];
-		mlme = &iface->mlmepriv;
-		mlmeext = &iface->mlmeextpriv;
-
-		#ifdef CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT
-		if (check_fwstate(mlme, WIFI_STATION_STATE)
-			&& check_fwstate(mlme, WIFI_ASOC_STATE)
-			#if defined(CONFIG_P2P)
-			&& rtw_p2p_chk_state(&(iface->wdinfo), P2P_STATE_NONE)
-			#endif
-		) {
-			connect_allow = _FALSE;
-			break;
+		if (rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset) <= 0) {
+			dump_adapters_status(RTW_DBGDUMP , dvobj);
+			rtw_warn_on(1);
 		}
-		#endif /* CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT */
-	}
-	DBG_871X(FUNC_ADPT_FMT" connect_allow:%d\n"
-		, FUNC_ADPT_ARG(adapter), connect_allow);
+		RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n"
+			 , FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
 
-	if (connect_allow == _FALSE)
-		goto exit;
+		/* chbw_allow? */
+		chbw_allow = rtw_is_chbw_grouped(pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset
+						 , u_ch, u_bw, u_offset);
 
-connect_allow_hdl:
-	/* connect_allow == _TRUE */
+		RTW_INFO(FUNC_ADPT_FMT" chbw_allow:%d\n"
+			 , FUNC_ADPT_ARG(adapter), chbw_allow);
 
-	#ifdef CONFIG_DFS_MASTER
-	rtw_dfs_master_status_apply(adapter, MLME_STA_CONNECTING);
-	#endif
+#ifdef CONFIG_MCC_MODE
+		/* check setting success, don't go to ch union process */
+		if (rtw_hal_set_mcc_setting_chk_start_clnt_join(adapter, &u_ch, &u_bw, &u_offset, chbw_allow))
+			goto exit;
+#endif
 
-	if (chbw_allow == _FALSE) {
-		u_ch = cur_ch;
-		u_bw = cur_bw;
-		u_offset = cur_ch_offset;
+		if (chbw_allow == _TRUE) {
+			rtw_sync_chbw(&cur_ch, &cur_bw, &cur_ch_offset, &u_ch, &u_bw, &u_offset);
+			rtw_warn_on(cur_ch != pmlmeext->cur_channel);
+			rtw_warn_on(cur_bw != pmlmeext->cur_bwmode);
+			rtw_warn_on(cur_ch_offset != pmlmeext->cur_ch_offset);
+			goto connect_allow_hdl;
+		}
 
+#ifdef CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT
+		/* chbw_allow is _FALSE, connect allow? */
 		for (i = 0; i < dvobj->iface_nums; i++) {
 			iface = dvobj->padapters[i];
 			mlme = &iface->mlmepriv;
 			mlmeext = &iface->mlmeextpriv;
 
-			if (!iface || iface == adapter)
-				continue;
-
-			if (check_fwstate(mlme, WIFI_AP_STATE)
-				&& check_fwstate(mlme, WIFI_ASOC_STATE)
-			) {
-				#ifdef CONFIG_SPCT_CH_SWITCH
-				if (1)
-					rtw_ap_inform_ch_switch(iface, pmlmeext->cur_channel , pmlmeext->cur_ch_offset);
-				else
-				#endif
-					rtw_sta_flush(iface, _FALSE);
-
-				rtw_hal_set_hwreg(iface, HW_VAR_CHECK_TXBUF, 0);
-				set_fwstate(mlme, WIFI_OP_CH_SWITCHING);
-			} else if (check_fwstate(mlme, WIFI_STATION_STATE)
-				&& check_fwstate(mlme, WIFI_ASOC_STATE)
-			) {
-				rtw_disassoc_cmd(iface, 500, _FALSE);
-				rtw_indicate_disconnect(iface, 0, _FALSE);
-				rtw_free_assoc_resources(iface, 1);
+			if (check_fwstate(mlme, WIFI_STATION_STATE)
+			    && check_fwstate(mlme, WIFI_ASOC_STATE)
+#if defined(CONFIG_P2P)
+			    && rtw_p2p_chk_state(&(iface->wdinfo), P2P_STATE_NONE)
+#endif
+			   ) {
+				connect_allow = _FALSE;
+				break;
 			}
 		}
-	}
-}
-#endif /* CONFIG_CONCURRENT_MODE */
-
-exit:
+#endif /* CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT */
 
-	if (connect_allow == _TRUE) {
-		DBG_871X(FUNC_ADPT_FMT" union: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
-		*ch = u_ch;
-		*bw = u_bw;
-		*offset = u_offset;
-	}
+		if (MSTATE_STA_LD_NUM(&mstate) + MSTATE_AP_LD_NUM(&mstate) + MSTATE_MESH_LD_NUM(&mstate) >= 2)
+			connect_allow = _FALSE;
 
-	return connect_allow == _TRUE ? _SUCCESS : _FAIL;
-}
+		RTW_INFO(FUNC_ADPT_FMT" connect_allow:%d\n"
+			 , FUNC_ADPT_ARG(adapter), connect_allow);
 
-/* Find union about ch, bw, ch_offset of all linked/linking interfaces */
-int _rtw_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset, bool include_self)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	_adapter *iface;
-	struct mlme_ext_priv *mlmeext;
-	int i;
-	u8 ch_ret = 0;
-	u8 bw_ret = CHANNEL_WIDTH_20;
-	u8 offset_ret = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	int num = 0;
+		if (connect_allow == _FALSE)
+			goto exit;
 
-	if (ch) *ch = 0;
-	if (bw) *bw = CHANNEL_WIDTH_20;
-	if (offset) *offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+connect_allow_hdl:
+		/* connect_allow == _TRUE */
 
-	for (i = 0; i<dvobj->iface_nums; i++) {
-		iface = dvobj->padapters[i];
-		mlmeext = &iface->mlmeextpriv;
+#ifdef CONFIG_DFS_MASTER
+		rtw_dfs_master_status_apply(adapter, MLME_STA_CONNECTING);
+#endif
 
-		if (!check_fwstate(&iface->mlmepriv, _FW_LINKED|_FW_UNDER_LINKING))
-			continue;
+		if (chbw_allow == _FALSE) {
+			u_ch = cur_ch;
+			u_bw = cur_bw;
+			u_offset = cur_ch_offset;
 
-		if (check_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING))
-			continue;
+			for (i = 0; i < dvobj->iface_nums; i++) {
+				iface = dvobj->padapters[i];
+				mlme = &iface->mlmepriv;
+				mlmeext = &iface->mlmeextpriv;
 
-		if (include_self == _FALSE && adapter == iface)
-			continue;
+				if (!iface || iface == adapter)
+					continue;
 
-		if (num == 0) {
-			ch_ret = mlmeext->cur_channel;
-			bw_ret = mlmeext->cur_bwmode;
-			offset_ret = mlmeext->cur_ch_offset;
-			num++;
-			continue;
-		}
+				if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
+					&& check_fwstate(mlme, WIFI_ASOC_STATE)
+				) {
+					#ifdef CONFIG_SPCT_CH_SWITCH
+					if (1)
+						rtw_ap_inform_ch_switch(iface, pmlmeext->cur_channel , pmlmeext->cur_ch_offset);
+					else
+					#endif
+						rtw_sta_flush(iface, _FALSE);
 
-		if (ch_ret != mlmeext->cur_channel) {
-			num = 0;
-			break;
-		}
+					rtw_hal_set_hwreg(iface, HW_VAR_CHECK_TXBUF, 0);
+					set_fwstate(mlme, WIFI_OP_CH_SWITCHING);
 
-		if (bw_ret < mlmeext->cur_bwmode) {
-			bw_ret = mlmeext->cur_bwmode;
-			offset_ret = mlmeext->cur_ch_offset;
-		} else if (bw_ret == mlmeext->cur_bwmode && offset_ret != mlmeext->cur_ch_offset) {
-			num = 0;
-			break;
+				} else if (check_fwstate(mlme, WIFI_STATION_STATE)
+					&& check_fwstate(mlme, WIFI_ASOC_STATE)
+				) {
+					rtw_disassoc_cmd(iface, 500, RTW_CMDF_DIRECTLY);
+					rtw_indicate_disconnect(iface, 0, _FALSE);
+					rtw_free_assoc_resources(iface, _TRUE);
+				}
+			}
 		}
-
-		num++;
-	}
-
-	if (num) {
-		if (ch) *ch = ch_ret;
-		if (bw) *bw = bw_ret;
-		if (offset) *offset = offset_ret;
 	}
+#endif /* CONFIG_CONCURRENT_MODE */
 
-	return num;
-}
-
-inline int rtw_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
-{
-	return _rtw_get_ch_setting_union(adapter, ch, bw, offset, 1);
-}
-
-inline int rtw_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
-{
-	return _rtw_get_ch_setting_union(adapter, ch, bw, offset, 0);
-}
-
-void _rtw_dev_iface_status(_adapter *adapter, u8 *sta_num, u8 *ld_sta_num, u8 *lg_sta_num
-	, u8 *ap_num, u8 *ld_ap_num, bool include_self)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	_adapter *iface;
-	struct mlme_ext_priv *mlmeext;
-	struct mlme_ext_info *mlmeextinfo;
-	int i;
-	u8 sta_num_ret = 0;
-	u8 ld_sta_num_ret = 0;
-	u8 lg_sta_num_ret = 0;
-	u8 ap_num_ret = 0;
-	u8 ld_ap_num_ret = 0;
-
-	if (sta_num)
-		*sta_num = 0;
-	if (ld_sta_num)
-		*ld_sta_num = 0;
-	if (lg_sta_num)
-		*lg_sta_num = 0;
-	if (ap_num)
-		*ap_num = 0;
-	if (ld_ap_num)
-		*ld_ap_num = 0;
-
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		iface = dvobj->padapters[i];
-
-		if (include_self == _FALSE && iface == adapter)
-			continue;
-
-		mlmeext = &iface->mlmeextpriv;
-
-		if (mlmeext_msr(mlmeext) == WIFI_FW_STATION_STATE) {
-			sta_num_ret++;
-			if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE)
-				ld_sta_num_ret++;
-			if (check_fwstate(&iface->mlmepriv, _FW_UNDER_LINKING) == _TRUE)
-				lg_sta_num_ret++;
-		}
+exit:
 
-		if (mlmeext_msr(mlmeext) == WIFI_FW_AP_STATE
-			&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
-		) {
-			ap_num_ret++;
-			if (iface->stapriv.asoc_sta_count > 2)
-				ld_ap_num_ret++;
-		}
+	if (connect_allow == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT" union: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
+		*ch = u_ch;
+		*bw = u_bw;
+		*offset = u_offset;
 	}
 
-	if (sta_num)
-		*sta_num = sta_num_ret;
-	if (ld_sta_num)
-		*ld_sta_num = ld_sta_num_ret;
-	if (lg_sta_num)
-		*lg_sta_num = lg_sta_num_ret;
-	if (ap_num)
-		*ap_num = ap_num_ret;
-	if (ld_ap_num)
-		*ld_ap_num = ld_ap_num_ret;
-}
-
-inline void rtw_dev_iface_status(_adapter *adapter, u8 *sta_num, u8 *ld_sta_num, u8 *lg_sta_num
-	, u8 *ap_num, u8 *ld_ap_num)
-{
-	return _rtw_dev_iface_status(adapter, sta_num, ld_sta_num, lg_sta_num, ap_num, ld_ap_num, 1);
-}
-
-inline void rtw_dev_iface_status_no_self(_adapter *adapter, u8 *sta_num, u8 *ld_sta_num, u8 *lg_sta_num
-	, u8 *ap_num, u8 *ld_ap_num)
-{
-	return _rtw_dev_iface_status(adapter, sta_num, ld_sta_num, lg_sta_num, ap_num, ld_ap_num, 0);
+	return connect_allow == _TRUE ? _SUCCESS : _FAIL;
 }
 
-u8 rtw_mp_mode_check(_adapter *padapter)
-{
-#ifdef CONFIG_MP_INCLUDED
-#ifdef CONFIG_CONCURRENT_MODE
-	int i;
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	_adapter *iface = NULL;
-
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		iface = dvobj->padapters[i];
-
-		if ((iface) && (iface->registrypriv.mp_mode == 1))
-			return _TRUE;
-	}
-#else
-	if (padapter->registrypriv.mp_mode == 1)
-		return _TRUE;
-#endif
-#endif /* CONFIG_MP_INCLUDED */
-	return _FALSE;
-}
 
-u8 set_ch_hdl(_adapter *padapter, u8 *pbuf)
+u8 rtw_set_chbw_hdl(_adapter *padapter, u8 *pbuf)
 {
 	struct set_ch_parm *set_ch_parm;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 
-	if(!pbuf)
+	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
 
 	set_ch_parm = (struct set_ch_parm *)pbuf;
 
-	DBG_871X(FUNC_NDEV_FMT" ch:%u, bw:%u, ch_offset:%u\n",
-		FUNC_NDEV_ARG(padapter->pnetdev),
-		set_ch_parm->ch, set_ch_parm->bw, set_ch_parm->ch_offset);
+	RTW_INFO(FUNC_NDEV_FMT" ch:%u, bw:%u, ch_offset:%u\n",
+		 FUNC_NDEV_ARG(padapter->pnetdev),
+		 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;
@@ -15141,53 +16537,55 @@ u8 set_ch_hdl(_adapter *padapter, u8 *pbuf)
 
 	set_channel_bwmode(padapter, set_ch_parm->ch, set_ch_parm->ch_offset, set_ch_parm->bw);
 
-	return 	H2C_SUCCESS;
+	return	H2C_SUCCESS;
 }
 
 u8 set_chplan_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 	struct SetChannelPlan_param *setChannelPlan_param;
-	struct mlme_priv *mlme = &padapter->mlmepriv;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-	if(!pbuf)
+	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
 
 	setChannelPlan_param = (struct SetChannelPlan_param *)pbuf;
 
-	if(!rtw_is_channel_plan_valid(setChannelPlan_param->channel_plan)) {
+	if (!rtw_is_channel_plan_valid(setChannelPlan_param->channel_plan))
 		return H2C_PARAMETERS_ERROR;
-	}
 
-	mlme->country_ent = setChannelPlan_param->country_ent;
-	mlme->ChannelPlan = setChannelPlan_param->channel_plan;
+	rfctl->country_ent = setChannelPlan_param->country_ent;
+	rfctl->ChannelPlan = setChannelPlan_param->channel_plan;
+
+	rfctl->max_chan_nums = init_channel_set(padapter, rfctl->ChannelPlan, rfctl->channel_set);
+	init_channel_list(padapter, rfctl->channel_set, &rfctl->channel_list);
+#ifdef CONFIG_TXPWR_LIMIT
+	rtw_txpwr_init_regd(rfctl);
+#endif
 
-	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);	
+	rtw_hal_set_odm_var(padapter, HAL_ODM_REGULATION, NULL, _TRUE);
 
-	rtw_hal_set_odm_var(padapter,HAL_ODM_REGULATION,NULL,_TRUE);
-	
 #ifdef CONFIG_IOCTL_CFG80211
-	rtw_reg_notify_by_driver(padapter);
-#endif //CONFIG_IOCTL_CFG80211
+	rtw_regd_apply_flags(adapter_to_wiphy(padapter));
+#endif
 
-	return 	H2C_SUCCESS;
+	return	H2C_SUCCESS;
 }
 
 u8 led_blink_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 	struct LedBlink_param *ledBlink_param;
 
-	if(!pbuf)
+	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
 
 	ledBlink_param = (struct LedBlink_param *)pbuf;
 
-	#ifdef CONFIG_LED_HANDLED_BY_CMD_THREAD
+#ifdef CONFIG_RTW_LED_HANDLED_BY_CMD_THREAD
 	BlinkHandler((PLED_DATA)ledBlink_param->pLed);
-	#endif
+#endif
 
-	return 	H2C_SUCCESS;
+	return	H2C_SUCCESS;
 }
 
 u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf)
@@ -15197,7 +16595,7 @@ u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf)
 	u8 new_ch_no;
 	u8 gval8 = 0x00, sval8 = 0xff;
 
-	if(!pbuf)
+	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
 
 	setChannelSwitch_param = (struct SetChannelSwitch_param *)pbuf;
@@ -15207,24 +16605,23 @@ u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf)
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &sval8);
 
-	DBG_871X("DFS detected! Swiching channel to %d!\n", new_ch_no);
+	RTW_INFO("DFS detected! Swiching channel to %d!\n", new_ch_no);
 	set_channel_bwmode(padapter, new_ch_no, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &gval8);
 
-	rtw_disassoc_cmd(padapter, 0, _FALSE);
+	rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
 	rtw_indicate_disconnect(padapter, 0, _FALSE);
-	rtw_free_assoc_resources(padapter, 1);
+	rtw_free_assoc_resources(padapter, _TRUE);
 	rtw_free_network_queue(padapter, _TRUE);
 
-	if ( ((new_ch_no >= 52) && (new_ch_no <= 64)) ||((new_ch_no >= 100) && (new_ch_no <= 140)) ) {
-		DBG_871X("Switched to DFS band (ch %02x) again!!\n", new_ch_no);
-	}
+	if (rtw_is_dfs_ch(new_ch_no))
+		RTW_INFO("Switched to DFS band (ch %u) again!!\n", new_ch_no);
 
-	return 	H2C_SUCCESS;
+	return	H2C_SUCCESS;
 #else
 	return	H2C_REJECTED;
-#endif //CONFIG_DFS
+#endif /* CONFIG_DFS */
 
 }
 
@@ -15232,18 +16629,23 @@ u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 #ifdef CONFIG_TDLS
 	_irqL irqL;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-#ifdef CONFIG_TDLS_CH_SW	
+#ifdef CONFIG_TDLS_CH_SW
 	struct tdls_ch_switch *pchsw_info = &ptdlsinfo->chsw_info;
 #endif
 	struct TDLSoption_param *TDLSoption;
 	struct sta_info *ptdls_sta = NULL;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct sta_info *ap_sta = rtw_get_stainfo(&padapter->stapriv, get_my_bssid(&(pmlmeinfo->network)));
 	u8 survey_channel, i, min, option;
 	struct tdls_txmgmt txmgmt;
 	u32 setchtime, resp_sleep = 0, wait_time;
 	u8 zaddr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	u8 ret;
+	u8 doiqk;
+	u64 tx_ra_bitmap = 0;
 
 	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
@@ -15252,63 +16654,64 @@ u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)
 	option = TDLSoption->option;
 
 	if (!_rtw_memcmp(TDLSoption->addr, zaddr, ETH_ALEN)) {
-		ptdls_sta = rtw_get_stainfo( &(padapter->stapriv), TDLSoption->addr );
-		if (ptdls_sta == NULL) {
+		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), TDLSoption->addr);
+		if (ptdls_sta == NULL)
 			return H2C_REJECTED;
-		}
 	} else {
-		if (!(option == TDLS_RS_RCR || option == TDLS_CH_SW_BACK))
+		if (!(option == TDLS_RS_RCR))
 			return H2C_REJECTED;
 	}
 
-	//_enter_critical_bh(&(ptdlsinfo->hdl_lock), &irqL);
-	//DBG_871X("[%s] option:%d\n", __FUNCTION__, option);
-		
+	/* _enter_critical_bh(&(ptdlsinfo->hdl_lock), &irqL); */
+	/* RTW_INFO("[%s] option:%d\n", __FUNCTION__, option); */
+
 	switch (option) {
-	case TDLS_ESTABLISHED:
-	{
+	case TDLS_ESTABLISHED: {
 		/* As long as TDLS handshake success, we should set RCR_CBSSID_DATA bit to 0 */
 		/* So we can receive all kinds of data frames. */
 		u8 sta_band = 0;
 
-		//leave ALL PS when TDLS is established
-			rtw_pwr_wakeup(padapter);
+		/* leave ALL PS when TDLS is established */
+		rtw_pwr_wakeup(padapter);
 
-		rtw_hal_set_hwreg(padapter, HW_VAR_TDLS_WRCR, 0);
-		DBG_871X("Created Direct Link with "MAC_FMT"\n", MAC_ARG(ptdls_sta->hwaddr));
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_LINKED);
+		RTW_INFO("Created Direct Link with "MAC_FMT"\n", MAC_ARG(ptdls_sta->cmn.mac_addr));
 
 		/* Set TDLS sta rate. */
 		/* Update station supportRate */
-		rtw_hal_update_sta_rate_mask(padapter, ptdls_sta);
+		rtw_hal_update_sta_ra_info(padapter, ptdls_sta);
+		tx_ra_bitmap = ptdls_sta->cmn.ra_info.ramask;
+
 		if (pmlmeext->cur_channel > 14) {
-			if (ptdls_sta->ra_mask & 0xffff000)
+			if (tx_ra_bitmap & 0xffff000)
 				sta_band |= WIRELESS_11_5N ;
 
-			if (ptdls_sta->ra_mask & 0xff0)
+			if (tx_ra_bitmap & 0xff0)
 				sta_band |= WIRELESS_11A;
 
 			/* 5G band */
-			#ifdef CONFIG_80211AC_VHT
+#ifdef CONFIG_80211AC_VHT
 			if (ptdls_sta->vhtpriv.vht_option)
 				sta_band = WIRELESS_11_5AC;
-			#endif
-			
+#endif
+
 		} else {
-			if (ptdls_sta->ra_mask & 0xffff000)
+			if (tx_ra_bitmap & 0xffff000)
 				sta_band |= WIRELESS_11_24N;
 
-			if (ptdls_sta->ra_mask & 0xff0)
+			if (tx_ra_bitmap & 0xff0)
 				sta_band |= WIRELESS_11G;
 
-			if (ptdls_sta->ra_mask & 0x0f)
+			if (tx_ra_bitmap & 0x0f)
 				sta_band |= WIRELESS_11B;
 		}
 		ptdls_sta->wireless_mode = sta_band;
-		ptdls_sta->raid = rtw_hal_networktype_to_raid(padapter,ptdls_sta);
+		rtw_hal_update_sta_wset(padapter, ptdls_sta);
+		/* Sta mode */
+		rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, ptdls_sta, _TRUE);
+
 		set_sta_rate(padapter, ptdls_sta);
 		rtw_sta_media_status_rpt(padapter, ptdls_sta, 1);
-		/* Sta mode */
-		rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, ptdls_sta,_TRUE);
 		break;
 	}
 	case TDLS_ISSUE_PTI:
@@ -15316,85 +16719,155 @@ u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)
 		issue_tdls_peer_traffic_indication(padapter, ptdls_sta);
 		_set_timer(&ptdls_sta->pti_timer, TDLS_PTI_TIME);
 		break;
-#ifdef CONFIG_TDLS_CH_SW		
+#ifdef CONFIG_TDLS_CH_SW
 	case TDLS_CH_SW_RESP:
 		_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
 		txmgmt.status_code = 0;
-		_rtw_memcpy(txmgmt.peer, ptdls_sta->hwaddr, ETH_ALEN);
+		_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
 
-		issue_nulldata(padapter, NULL, 1, 0, 0);
+		if (ap_sta)
+			rtw_hal_macid_sleep(padapter, ap_sta->cmn.mac_id);
+		issue_nulldata(padapter, NULL, 1, 3, 3);
 
-		DBG_871X("issue tdls channel switch response\n");
-		issue_tdls_ch_switch_rsp(padapter, &txmgmt, _FALSE);
-		resp_sleep = 5;
-		rtw_msleep_os(resp_sleep);
+		RTW_INFO("[TDLS ] issue tdls channel switch response\n");
+		ret = issue_tdls_ch_switch_rsp(padapter, &txmgmt, _TRUE);
 
 		/* If we receive TDLS_CH_SW_REQ at off channel which it's target is AP's channel */
 		/* then we just switch to AP's channel*/
 		if (padapter->mlmeextpriv.cur_channel == pchsw_info->off_ch_num) {
-			SelectChannel(padapter, padapter->mlmeextpriv.cur_channel);
-			issue_nulldata(padapter, NULL, 0, 0, 0);
-			pchsw_info->ch_sw_state &= ~(TDLS_PEER_AT_OFF_STATE);
-			ATOMIC_SET(&pchsw_info->chsw_on, _FALSE);
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END_TO_BASE_CHNL);
 			break;
 		}
 
-		_set_timer(&ptdls_sta->delay_timer, pmlmeinfo->bcn_interval - 40);
+		if (ret == _SUCCESS)
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_OFF_CHNL);
+		else
+			RTW_INFO("[TDLS] issue_tdls_ch_switch_rsp wait ack fail !!!!!!!!!!\n");
+
+		break;
+	case TDLS_CH_SW_PREPARE:
+		pchsw_info->ch_sw_state |= TDLS_CH_SWITCH_PREPARE_STATE;
 
-		/* Continue following actions */
+		/* to collect IQK info of off-chnl */
+		doiqk = _TRUE;
+		rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK, &doiqk);
+		set_channel_bwmode(padapter, pchsw_info->off_ch_num, pchsw_info->ch_offset, (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20);
+		doiqk = _FALSE;
+		rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK, &doiqk);
 
-	case TDLS_CH_SW:
-		issue_nulldata(padapter, NULL, 1, 0, 0);
-		_set_timer(&ptdls_sta->ch_sw_timer, (u32)(ptdls_sta->ch_switch_timeout)/1000);
+		/* switch back to base-chnl */
+		set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
 
-		setchtime = rtw_systime_to_ms(rtw_get_current_time());
-		SelectChannel(padapter, pchsw_info->off_ch_num);
-		setchtime = rtw_systime_to_ms(rtw_get_current_time()) - setchtime;
-		setchtime += resp_sleep;
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
 
-		if (pmlmeext->cur_channel != rtw_get_oper_ch(padapter))
-			issue_nulldata(padapter, NULL, 0, 0, 0);
-		pchsw_info->ch_sw_state &= ~(TDLS_PEER_AT_OFF_STATE);
+		pchsw_info->ch_sw_state &= ~(TDLS_CH_SWITCH_PREPARE_STATE);
 
-		if ((u32)ptdls_sta->ch_switch_time/1000 > setchtime)
-			wait_time = (u32)ptdls_sta->ch_switch_time/1000 - setchtime;
-		else
-			wait_time = 0;
+		break;
+	case TDLS_CH_SW_START:
+		rtw_tdls_set_ch_sw_oper_control(padapter, _TRUE);
+		break;
+	case TDLS_CH_SW_TO_OFF_CHNL:
+		if (ap_sta)
+			rtw_hal_macid_sleep(padapter, ap_sta->cmn.mac_id);
+		issue_nulldata(padapter, NULL, 1, 3, 3);
 
-		if (wait_time > 0)
-			rtw_msleep_os(wait_time);
+		if (padapter->registrypriv.wifi_spec == 0) {
+		if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
+			_set_timer(&ptdls_sta->ch_sw_timer, (u32)(ptdls_sta->ch_switch_timeout) / 1000);
+		}
+
+		if (rtw_tdls_do_ch_sw(padapter, ptdls_sta, TDLS_CH_SW_OFF_CHNL, pchsw_info->off_ch_num,
+			pchsw_info->ch_offset, (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20, ptdls_sta->ch_switch_time) == _SUCCESS) {
+			pchsw_info->ch_sw_state &= ~(TDLS_PEER_AT_OFF_STATE);
+			if (pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE) {
+				if (issue_nulldata_to_TDLS_peer_STA(ptdls_sta->padapter, ptdls_sta->cmn.mac_addr, 0, 1, 
+					(padapter->registrypriv.wifi_spec == 0) ? 3 : 0) == _FAIL)
+					rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_BASE_CHNL);
+			}
+		} else {
+			if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
+				_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
+		}
+
+
+		break;
+	case TDLS_CH_SW_END:
+	case TDLS_CH_SW_END_TO_BASE_CHNL:
+		rtw_tdls_set_ch_sw_oper_control(padapter, _FALSE);
+		_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
+		_cancel_timer_ex(&ptdls_sta->stay_on_base_chnl_timer);
+		_cancel_timer_ex(&ptdls_sta->ch_sw_monitor_timer);
+#if 0
+		_rtw_memset(pHalData->tdls_ch_sw_iqk_info_base_chnl, 0x00, sizeof(pHalData->tdls_ch_sw_iqk_info_base_chnl));
+		_rtw_memset(pHalData->tdls_ch_sw_iqk_info_off_chnl, 0x00, sizeof(pHalData->tdls_ch_sw_iqk_info_off_chnl));
+#endif
 
-		issue_nulldata_to_TDLS_peer_STA(ptdls_sta->padapter, ptdls_sta->hwaddr, 0, 0, 0);
-		issue_nulldata_to_TDLS_peer_STA(ptdls_sta->padapter, ptdls_sta->hwaddr, 0, 0, 0);
+		if (option == TDLS_CH_SW_END_TO_BASE_CHNL)
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_BASE_CHNL);
 
 		break;
-	case TDLS_CH_SW_BACK:
+	case TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED:
+	case TDLS_CH_SW_TO_BASE_CHNL:
 		pchsw_info->ch_sw_state &= ~(TDLS_PEER_AT_OFF_STATE | TDLS_WAIT_CH_RSP_STATE);
-		ATOMIC_SET(&pchsw_info->chsw_on, _FALSE);
-		SelectChannel(padapter, padapter->mlmeextpriv.cur_channel);
-		issue_nulldata(padapter, NULL, 0, 0, 0);
+
+		if (option == TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED) {
+			if (ptdls_sta != NULL) {
+				/* Send unsolicited channel switch rsp. to peer */
+				_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+				txmgmt.status_code = 0;
+				_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+				issue_tdls_ch_switch_rsp(padapter, &txmgmt, _FALSE);
+			}
+		}
+
+		if (rtw_tdls_do_ch_sw(padapter, ptdls_sta, TDLS_CH_SW_BASE_CHNL, pmlmeext->cur_channel,
+			pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode, ptdls_sta->ch_switch_time) == _SUCCESS) {
+			if (ap_sta)
+				rtw_hal_macid_wakeup(padapter, ap_sta->cmn.mac_id);
+			issue_nulldata(padapter, NULL, 0, 3, 3);
+			/* set ch sw monitor timer for responder */
+			if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
+				_set_timer(&ptdls_sta->ch_sw_monitor_timer, TDLS_CH_SW_MONITOR_TIMEOUT);
+		}
+
 		break;
-#endif		
+#endif
 	case TDLS_RS_RCR:
-		rtw_hal_set_hwreg(padapter, HW_VAR_TDLS_RS_RCR, 0);
-		DBG_871X("wirte REG_RCR, set bit6 on\n");
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_NOLINK);
+		break;
+	case TDLS_TEARDOWN_STA:
+	case TDLS_TEARDOWN_STA_NO_WAIT:
+		_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+		txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
+		_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+
+		issue_tdls_teardown(padapter, &txmgmt, (option == TDLS_TEARDOWN_STA) ? _TRUE : _FALSE);
+
 		break;
-	case TDLS_TEAR_STA:
-#ifdef CONFIG_TDLS_CH_SW	
+	case TDLS_TEARDOWN_STA_LOCALLY:
+	case TDLS_TEARDOWN_STA_LOCALLY_POST:
+#ifdef CONFIG_TDLS_CH_SW
 		if (_rtw_memcmp(TDLSoption->addr, pchsw_info->addr, ETH_ALEN) == _TRUE) {
 			pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE |
-										TDLS_CH_SWITCH_ON_STATE |
-										TDLS_PEER_AT_OFF_STATE);
-			ATOMIC_SET(&pchsw_info->chsw_on, _FALSE);
+						     TDLS_CH_SWITCH_ON_STATE |
+						     TDLS_PEER_AT_OFF_STATE);
+			rtw_tdls_set_ch_sw_oper_control(padapter, _FALSE);
 			_rtw_memset(pchsw_info->addr, 0x00, ETH_ALEN);
 		}
-#endif		
-		rtw_sta_media_status_rpt(padapter, ptdls_sta, 0);
-		free_tdls_sta(padapter, ptdls_sta);
-		break;			
+#endif
+
+		if (option == TDLS_TEARDOWN_STA_LOCALLY)
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+
+		rtw_tdls_teardown_post_hdl(padapter, ptdls_sta, _FALSE);
+
+		if (ptdlsinfo->tdls_sctx != NULL)
+			rtw_sctx_done(&(ptdlsinfo->tdls_sctx));
+
+		break;
 	}
 
-	//_exit_critical_bh(&(ptdlsinfo->hdl_lock), &irqL);
+	/* _exit_critical_bh(&(ptdlsinfo->hdl_lock), &irqL); */
 
 	return H2C_SUCCESS;
 #else
@@ -15410,7 +16883,7 @@ u8 run_in_thread_hdl(_adapter *padapter, u8 *pbuf)
 
 	if (NULL == pbuf)
 		return H2C_PARAMETERS_ERROR;
-	p = (struct RunInThread_param*)pbuf;
+	p = (struct RunInThread_param *)pbuf;
 
 	if (p->func)
 		p->func(p->context);
@@ -15445,11 +16918,10 @@ u8 rtw_getmacreg_hdl(_adapter *padapter, u8 *pbuf)
 		value = rtw_read32(padapter, addr);
 		break;
 	default:
-		DBG_871X("%s: Unknown size\n", __func__);
+		RTW_INFO("%s: Unknown size\n", __func__);
 		break;
 	}
-	DBG_871X("%s: addr:0x%02x valeu:0x%02x\n", __func__, addr, value);
+	RTW_INFO("%s: addr:0x%02x valeu:0x%02x\n", __func__, addr, value);
 
 	return H2C_SUCCESS;
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp.c
index da5b4089b726..ed3b7338f3bf 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,21 +12,16 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_MP_C_
 #include <drv_types.h>
 #ifdef PLATFORM_FREEBSD
-#include <sys/unistd.h>		/* for RFHIGHPID */
+	#include <sys/unistd.h>		/* for RFHIGHPID */
 #endif
 
-#include "../hal/phydm/phydm_precomp.h"		
+#include "../hal/phydm/phydm_precomp.h"
 #if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8821A)
-#include <rtw_bt_mp.h>
+	#include <rtw_bt_mp.h>
 #endif
 
 #ifdef CONFIG_MP_VHT_HW_TX_MODE
@@ -35,54 +31,52 @@
 
 int rtfloor(float x)
 {
-int i = x - 2;
-while
-(++i <= x - 1);
-return i;
+	int i = x - 2;
+	while
+	(++i <= x - 1)
+		;
+	return i;
 }
 #endif
 
 #ifdef CONFIG_MP_INCLUDED
-
 u32 read_macreg(_adapter *padapter, u32 addr, u32 sz)
 {
 	u32 val = 0;
 
-	switch(sz)
-	{
-		case 1:
-			val = rtw_read8(padapter, addr);
-			break;
-		case 2:
-			val = rtw_read16(padapter, addr);
-			break;
-		case 4:
-			val = rtw_read32(padapter, addr);
-			break;
-		default:
-			val = 0xffffffff;
-			break;
+	switch (sz) {
+	case 1:
+		val = rtw_read8(padapter, addr);
+		break;
+	case 2:
+		val = rtw_read16(padapter, addr);
+		break;
+	case 4:
+		val = rtw_read32(padapter, addr);
+		break;
+	default:
+		val = 0xffffffff;
+		break;
 	}
 
 	return val;
-	
+
 }
 
 void write_macreg(_adapter *padapter, u32 addr, u32 val, u32 sz)
 {
-	switch(sz)
-	{
-		case 1:
-			rtw_write8(padapter, addr, (u8)val);
-			break;
-		case 2:
-			rtw_write16(padapter, addr, (u16)val);
-			break;
-		case 4:
-			rtw_write32(padapter, addr, val);
-			break;
-		default:
-			break;
+	switch (sz) {
+	case 1:
+		rtw_write8(padapter, addr, (u8)val);
+		break;
+	case 2:
+		rtw_write16(padapter, addr, (u16)val);
+		break;
+	case 4:
+		rtw_write32(padapter, addr, val);
+		break;
+	default:
+		break;
 	}
 
 }
@@ -138,7 +132,7 @@ static void _init_mp_priv_(struct mp_priv *pmp_priv)
 
 	pmp_priv->tx_pktcount = 0;
 
-	pmp_priv->rx_bssidpktcount=0;
+	pmp_priv->rx_bssidpktcount = 0;
 	pmp_priv->rx_pktcount = 0;
 	pmp_priv->rx_crcerrpktcount = 0;
 
@@ -151,6 +145,9 @@ static void _init_mp_priv_(struct mp_priv *pmp_priv)
 
 	pmp_priv->bSetRxBssid = _FALSE;
 	pmp_priv->bRTWSmbCfg = _FALSE;
+	pmp_priv->bloopback = _FALSE;
+
+	pmp_priv->bloadefusemap = _FALSE;
 
 	pnetwork = &pmp_priv->mp_network.network;
 	_rtw_memcpy(pnetwork->MacAddress, pmp_priv->network_macaddr, ETH_ALEN);
@@ -163,54 +160,51 @@ static void _init_mp_priv_(struct mp_priv *pmp_priv)
 	pmp_priv->tx.attrib.ht_en = 1;
 #endif
 
+	pmp_priv->mpt_ctx.mpt_rate_index = 1;
+
 }
 
 #ifdef PLATFORM_WINDOWS
-/*
+#if 0
 void mp_wi_callback(
-	IN NDIS_WORK_ITEM*	pwk_item,
+	IN NDIS_WORK_ITEM	*pwk_item,
 	IN PVOID			cntx
-	)
+)
 {
-	_adapter* padapter =(_adapter *)cntx;
-	struct mp_priv *pmppriv=&padapter->mppriv;
-	struct mp_wi_cntx	*pmp_wi_cntx=&pmppriv->wi_cntx;
+	_adapter *padapter = (_adapter *)cntx;
+	struct mp_priv *pmppriv = &padapter->mppriv;
+	struct mp_wi_cntx	*pmp_wi_cntx = &pmppriv->wi_cntx;
 
-	// Execute specified action.
-	if(pmp_wi_cntx->curractfunc != NULL)
-	{
+	/*  Execute specified action. */
+	if (pmp_wi_cntx->curractfunc != NULL) {
 		LARGE_INTEGER	cur_time;
 		ULONGLONG start_time, end_time;
-		NdisGetCurrentSystemTime(&cur_time);	// driver version
-		start_time = cur_time.QuadPart/10; // The return value is in microsecond
+		NdisGetCurrentSystemTime(&cur_time);	/*  driver version */
+		start_time = cur_time.QuadPart / 10; /*  The return value is in microsecond */
 
 		pmp_wi_cntx->curractfunc(padapter);
 
-		NdisGetCurrentSystemTime(&cur_time);	// driver version
-		end_time = cur_time.QuadPart/10; // The return value is in microsecond
+		NdisGetCurrentSystemTime(&cur_time);	/*  driver version */
+		end_time = cur_time.QuadPart / 10; /*  The return value is in microsecond */
 
-		RT_TRACE(_module_mp_, _drv_info_,
-			 ("WorkItemActType: %d, time spent: %I64d us\n",
-			  pmp_wi_cntx->param.act_type, (end_time-start_time)));
 	}
 
 	NdisAcquireSpinLock(&(pmp_wi_cntx->mp_wi_lock));
-	pmp_wi_cntx->bmp_wi_progress= _FALSE;
+	pmp_wi_cntx->bmp_wi_progress = _FALSE;
 	NdisReleaseSpinLock(&(pmp_wi_cntx->mp_wi_lock));
 
 	if (pmp_wi_cntx->bmpdrv_unload)
-	{
 		NdisSetEvent(&(pmp_wi_cntx->mp_wi_evt));
-	}
 
 }
-*/
+#endif
 
 static int init_mp_priv_by_os(struct mp_priv *pmp_priv)
 {
 	struct mp_wi_cntx *pmp_wi_cntx;
 
-	if (pmp_priv == NULL) return _FAIL;
+	if (pmp_priv == NULL)
+		return _FAIL;
 
 	pmp_priv->rx_testcnt = 0;
 	pmp_priv->rx_testcnt1 = 0;
@@ -220,7 +214,7 @@ static int init_mp_priv_by_os(struct mp_priv *pmp_priv)
 	pmp_priv->tx_testcnt1 = 0;
 
 	pmp_wi_cntx = &pmp_priv->wi_cntx
-	pmp_wi_cntx->bmpdrv_unload = _FALSE;
+		      pmp_wi_cntx->bmpdrv_unload = _FALSE;
 	pmp_wi_cntx->bmp_wi_progress = _FALSE;
 	pmp_wi_cntx->curractfunc = NULL;
 
@@ -234,7 +228,8 @@ static int init_mp_priv_by_os(struct mp_priv *pmp_priv)
 	int i, res;
 	struct mp_xmit_frame *pmp_xmitframe;
 
-	if (pmp_priv == NULL) return _FAIL;
+	if (pmp_priv == NULL)
+		return _FAIL;
 
 	_rtw_init_queue(&pmp_priv->free_mp_xmitqueue);
 
@@ -245,12 +240,11 @@ static int init_mp_priv_by_os(struct mp_priv *pmp_priv)
 		goto _exit_init_mp_priv;
 	}
 
-	pmp_priv->pmp_xmtframe_buf = pmp_priv->pallocated_mp_xmitframe_buf + 4 - ((SIZE_PTR) (pmp_priv->pallocated_mp_xmitframe_buf) & 3);
+	pmp_priv->pmp_xmtframe_buf = pmp_priv->pallocated_mp_xmitframe_buf + 4 - ((SIZE_PTR)(pmp_priv->pallocated_mp_xmitframe_buf) & 3);
 
-	pmp_xmitframe = (struct mp_xmit_frame*)pmp_priv->pmp_xmtframe_buf;
+	pmp_xmitframe = (struct mp_xmit_frame *)pmp_priv->pmp_xmtframe_buf;
 
-	for (i = 0; i < NR_MP_XMITFRAME; i++)
-	{
+	for (i = 0; i < NR_MP_XMITFRAME; i++) {
 		_rtw_init_listhead(&pmp_xmitframe->list);
 		rtw_list_insert_tail(&pmp_xmitframe->list, &pmp_priv->free_mp_xmitqueue.queue);
 
@@ -277,44 +271,44 @@ static void mp_init_xmit_attrib(struct mp_tx *pmptx, PADAPTER padapter)
 
 	struct pkt_attrib *pattrib;
 
-	// init xmitframe attribute
+	/* init xmitframe attribute */
 	pattrib = &pmptx->attrib;
 	_rtw_memset(pattrib, 0, sizeof(struct pkt_attrib));
 	_rtw_memset(pmptx->desc, 0, TXDESC_SIZE);
 
 	pattrib->ether_type = 0x8712;
-	#if 0
+#if 0
 	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-	#endif
+#endif
 	_rtw_memset(pattrib->dst, 0xFF, ETH_ALEN);
 
-//	pattrib->dhcp_pkt = 0;
-//	pattrib->pktlen = 0;
+	/*	pattrib->dhcp_pkt = 0;
+	 *	pattrib->pktlen = 0; */
 	pattrib->ack_policy = 0;
-//	pattrib->pkt_hdrlen = ETH_HLEN;
+	/*	pattrib->pkt_hdrlen = ETH_HLEN; */
 	pattrib->hdrlen = WLAN_HDR_A3_LEN;
 	pattrib->subtype = WIFI_DATA;
 	pattrib->priority = 0;
 	pattrib->qsel = pattrib->priority;
-//	do_queue_select(padapter, pattrib);
+	/*	do_queue_select(padapter, pattrib); */
 	pattrib->nr_frags = 1;
 	pattrib->encrypt = 0;
 	pattrib->bswenc = _FALSE;
 	pattrib->qos_en = _FALSE;
 
 	pattrib->pktlen = 1500;
-	
+
 #ifdef CONFIG_80211AC_VHT
-		if (pHalData->rf_type == RF_1T1R)
-			pattrib->raid = RATEID_IDX_VHT_1SS;
-		else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
-			pattrib->raid = RATEID_IDX_VHT_2SS;
-		else if (pHalData->rf_type == RF_3T3R)
-			pattrib->raid = RATEID_IDX_VHT_3SS;
-		else
-			pattrib->raid = RATEID_IDX_BGN_40M_1SS;
-#endif		
+	if (pHalData->rf_type == RF_1T1R)
+		pattrib->raid = RATEID_IDX_VHT_1SS;
+	else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
+		pattrib->raid = RATEID_IDX_VHT_2SS;
+	else if (pHalData->rf_type == RF_3T3R)
+		pattrib->raid = RATEID_IDX_VHT_3SS;
+	else
+		pattrib->raid = RATEID_IDX_BGN_40M_1SS;
+#endif
 }
 
 s32 init_mp_priv(PADAPTER padapter)
@@ -323,10 +317,10 @@ s32 init_mp_priv(PADAPTER padapter)
 	PHAL_DATA_TYPE pHalData;
 
 	pHalData = GET_HAL_DATA(padapter);
-	
+
 	_init_mp_priv_(pmppriv);
 	pmppriv->papdater = padapter;
-	pmppriv->mp_dm =0;
+	pmppriv->mp_dm = 0;
 	pmppriv->tx.stop = 1;
 	pmppriv->bSetTxPower = 0;		/*for  manually set tx power*/
 	pmppriv->bTxBufCkFail = _FALSE;
@@ -336,29 +330,28 @@ s32 init_mp_priv(PADAPTER padapter)
 	mp_init_xmit_attrib(&pmppriv->tx, padapter);
 
 	switch (padapter->registrypriv.rf_config) {
-		case RF_1T1R:
-			pmppriv->antenna_tx = ANTENNA_A;
-			pmppriv->antenna_rx = ANTENNA_A;
-			break;
-		case RF_1T2R:
-		default:
-			pmppriv->antenna_tx = ANTENNA_A;
-			pmppriv->antenna_rx = ANTENNA_AB;
-			break;
-		case RF_2T2R:
-		case RF_2T2R_GREEN:
-			pmppriv->antenna_tx = ANTENNA_AB;
-			pmppriv->antenna_rx = ANTENNA_AB;
-			break;
-		case RF_2T4R:
-			pmppriv->antenna_tx = ANTENNA_BC;
-			pmppriv->antenna_rx = ANTENNA_ABCD;
-			break;
+	case RF_1T1R:
+		pmppriv->antenna_tx = ANTENNA_A;
+		pmppriv->antenna_rx = ANTENNA_A;
+		break;
+	case RF_1T2R:
+	default:
+		pmppriv->antenna_tx = ANTENNA_A;
+		pmppriv->antenna_rx = ANTENNA_AB;
+		break;
+	case RF_2T2R:
+		pmppriv->antenna_tx = ANTENNA_AB;
+		pmppriv->antenna_rx = ANTENNA_AB;
+		break;
+	case RF_2T4R:
+		pmppriv->antenna_tx = ANTENNA_BC;
+		pmppriv->antenna_rx = ANTENNA_ABCD;
+		break;
 	}
-	
+
 	pHalData->AntennaRxPath = pmppriv->antenna_rx;
-	pHalData->AntennaTxPath = pmppriv->antenna_tx;
-	
+	pHalData->antenna_tx_path = pmppriv->antenna_tx;
+
 	return _SUCCESS;
 }
 
@@ -374,25 +367,25 @@ void free_mp_priv(struct mp_priv *pmp_priv)
 
 static VOID PHY_IQCalibrate_default(
 	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN 	bReCovery
-	)
-{	
-	DBG_871X("%s\n", __func__);
+	IN	BOOLEAN	bReCovery
+)
+{
+	RTW_INFO("%s\n", __func__);
 }
 
 static VOID PHY_LCCalibrate_default(
 	IN	PADAPTER	pAdapter
-	)
+)
 {
-	DBG_871X("%s\n", __func__);
+	RTW_INFO("%s\n", __func__);
 }
 
 static VOID PHY_SetRFPathSwitch_default(
 	IN	PADAPTER	pAdapter,
 	IN	BOOLEAN		bMain
-	)
+)
 {
-	DBG_871X("%s\n", __func__);
+	RTW_INFO("%s\n", __func__);
 }
 
 
@@ -403,163 +396,265 @@ void mpt_InitHWConfig(PADAPTER Adapter)
 	hal = GET_HAL_DATA(Adapter);
 
 	if (IS_HARDWARE_TYPE_8723B(Adapter)) {
-		// TODO: <20130114, Kordan> The following setting is only for DPDT and Fixed board type.
-		// TODO:  A better solution is configure it according EFUSE during the run-time. 
-
-		PHY_SetMacReg(Adapter, 0x64, BIT20, 0x0);		   //0x66[4]=0		
-		PHY_SetMacReg(Adapter, 0x64, BIT24, 0x0);		   //0x66[8]=0
-		PHY_SetMacReg(Adapter, 0x40, BIT4, 0x0);		   //0x40[4]=0		
-		PHY_SetMacReg(Adapter, 0x40, BIT3, 0x1);		   //0x40[3]=1		
-		PHY_SetMacReg(Adapter, 0x4C, BIT24, 0x1);		   //0x4C[24:23]=10
-		PHY_SetMacReg(Adapter, 0x4C, BIT23, 0x0);		   //0x4C[24:23]=10
-		PHY_SetBBReg(Adapter, 0x944, BIT1|BIT0, 0x3);	  //0x944[1:0]=11	
-		PHY_SetBBReg(Adapter, 0x930, bMaskByte0, 0x77);   //0x930[7:0]=77	  
-		PHY_SetMacReg(Adapter, 0x38, BIT11, 0x1);		   //0x38[11]=1
-
-		// TODO: <20130206, Kordan> The default setting is wrong, hard-coded here. 
-		PHY_SetMacReg(Adapter, 0x778, 0x3, 0x3);					// Turn off hardware PTA control (Asked by Scott)
-		PHY_SetMacReg(Adapter, 0x64, bMaskDWord, 0x36000000);	 //Fix BT S0/S1
-		PHY_SetMacReg(Adapter, 0x948, bMaskDWord, 0x0); 		   //Fix BT can't Tx
+		/* TODO: <20130114, Kordan> The following setting is only for DPDT and Fixed board type. */
+		/* TODO:  A better solution is configure it according EFUSE during the run-time. */
+
+		phy_set_mac_reg(Adapter, 0x64, BIT20, 0x0);		/* 0x66[4]=0		 */
+		phy_set_mac_reg(Adapter, 0x64, BIT24, 0x0);		/* 0x66[8]=0 */
+		phy_set_mac_reg(Adapter, 0x40, BIT4, 0x0);		/* 0x40[4]=0		 */
+		phy_set_mac_reg(Adapter, 0x40, BIT3, 0x1);		/* 0x40[3]=1		 */
+		phy_set_mac_reg(Adapter, 0x4C, BIT24, 0x1);		/* 0x4C[24:23]=10 */
+		phy_set_mac_reg(Adapter, 0x4C, BIT23, 0x0);		/* 0x4C[24:23]=10 */
+		phy_set_bb_reg(Adapter, 0x944, BIT1 | BIT0, 0x3);	/* 0x944[1:0]=11	 */
+		phy_set_bb_reg(Adapter, 0x930, bMaskByte0, 0x77);/* 0x930[7:0]=77	  */
+		phy_set_mac_reg(Adapter, 0x38, BIT11, 0x1);/* 0x38[11]=1 */
+
+		/* TODO: <20130206, Kordan> The default setting is wrong, hard-coded here. */
+		phy_set_mac_reg(Adapter, 0x778, 0x3, 0x3);					/* Turn off hardware PTA control (Asked by Scott) */
+		phy_set_mac_reg(Adapter, 0x64, bMaskDWord, 0x36000000);/* Fix BT S0/S1 */
+		phy_set_mac_reg(Adapter, 0x948, bMaskDWord, 0x0);		/* Fix BT can't Tx */
 
 		/* <20130522, Kordan> Turn off equalizer to improve Rx sensitivity. (Asked by EEChou) */
-		PHY_SetBBReg(Adapter, 0xA00, BIT8, 0x0);			/*0xA01[0] = 0*/
-	 } else if (IS_HARDWARE_TYPE_8821(Adapter)) {
+		phy_set_bb_reg(Adapter, 0xA00, BIT8, 0x0);			/*0xA01[0] = 0*/
+	} else if (IS_HARDWARE_TYPE_8821(Adapter)) {
 		/* <20131121, VincentL> Add for 8821AU DPDT setting and fix switching antenna issue (Asked by Rock)
 		<20131122, VincentL> Enable for all 8821A/8811AU  (Asked by Alex)*/
-		PHY_SetMacReg(Adapter, 0x4C, BIT23, 0x0);		   /*0x4C[23:22]=01*/
-		PHY_SetMacReg(Adapter, 0x4C, BIT22, 0x1);		   /*0x4C[23:22]=01*/
+		phy_set_mac_reg(Adapter, 0x4C, BIT23, 0x0);		/*0x4C[23:22]=01*/
+		phy_set_mac_reg(Adapter, 0x4C, BIT22, 0x1);		/*0x4C[23:22]=01*/
 	} else if (IS_HARDWARE_TYPE_8188ES(Adapter))
-		PHY_SetMacReg(Adapter, 0x4C , BIT23, 0);		/*select DPDT_P and DPDT_N as output pin*/
-#ifdef CONFIG_RTL8814A	
-	  else if (IS_HARDWARE_TYPE_8814A(Adapter))
+		phy_set_mac_reg(Adapter, 0x4C , BIT23, 0);		/*select DPDT_P and DPDT_N as output pin*/
+#ifdef CONFIG_RTL8814A
+	else if (IS_HARDWARE_TYPE_8814A(Adapter))
 		PlatformEFIOWrite2Byte(Adapter, REG_RXFLTMAP1_8814A, 0x2000);
-#endif		
-	/*
-	else if(IS_HARDWARE_TYPE_8822B(Adapter))
-	{
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(Adapter)) {
+		rtw_write32(Adapter, 0x520, rtw_read32(Adapter, 0x520) | 0x8000);
+		rtw_write32(Adapter, 0x524, rtw_read32(Adapter, 0x524) & (~0x800));
+	}
+#endif
+
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(Adapter)) {
+		u32 tmp_reg = 0;
+
 		PlatformEFIOWrite2Byte(Adapter, REG_RXFLTMAP1_8822B, 0x2000);
-	}*/
-#ifdef CONFIG_RTL8188F
-	else if (IS_HARDWARE_TYPE_8188F(Adapter)) {
-		if (IS_A_CUT(hal->VersionID) || (IS_B_CUT(hal->VersionID) && hal->VersionID.irv == 0xF)) {
+		/* fixed wifi can't 2.4g tx suggest by Szuyitasi 20160504 */
+		phy_set_bb_reg(Adapter, 0x70, bMaskByte3, 0x0e);
+		RTW_INFO(" 0x73 = 0x%x\n", phy_query_bb_reg(Adapter, 0x70, bMaskByte3));
+		phy_set_bb_reg(Adapter, 0x1704, bMaskDWord, 0x0000ff00);
+		RTW_INFO(" 0x1704 = 0x%x\n", phy_query_bb_reg(Adapter, 0x1704, bMaskDWord));
+		phy_set_bb_reg(Adapter, 0x1700, bMaskDWord, 0xc00f0038);
+		RTW_INFO(" 0x1700 = 0x%x\n", phy_query_bb_reg(Adapter, 0x1700, bMaskDWord));
+	}
+#endif /* CONFIG_RTL8822B */
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(Adapter))
+		PlatformEFIOWrite2Byte(Adapter, REG_RXFLTMAP1_8821C, 0x2000);
+#endif /* CONFIG_RTL8821C */
+#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
+	else if (IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8188GTV(Adapter)) {
+		if (IS_A_CUT(hal->version_id) || IS_B_CUT(hal->version_id)) {
 			RTW_INFO("%s() Active large power detection\n", __func__);
-			phy_active_large_power_detection_8188f(&hal->odmpriv);
+			phy_active_large_power_detection_8188f(&(GET_HAL_DATA(Adapter)->odmpriv));
 		}
 	}
 #endif
 }
 
+static void PHY_IQCalibrate(PADAPTER padapter, u8 bReCovery)
+{
+	halrf_iqk_trigger(&(GET_HAL_DATA(padapter)->odmpriv), bReCovery);
+}
+
+static void PHY_LCCalibrate(PADAPTER padapter)
+{
+	halrf_lck_trigger(&(GET_HAL_DATA(padapter)->odmpriv));
+}
+
+static u8 PHY_QueryRFPathSwitch(PADAPTER padapter)
+{
+	u8 bmain = 0;
+/*
+	if (IS_HARDWARE_TYPE_8723B(padapter)) {
+#ifdef CONFIG_RTL8723B
+		bmain = PHY_QueryRFPathSwitch_8723B(padapter);
+#endif
+	} else if (IS_HARDWARE_TYPE_8188E(padapter)) {
 #ifdef CONFIG_RTL8188E
-#define PHY_IQCalibrate(a,b)	PHY_IQCalibrate_8188E(a,b)
-#define PHY_LCCalibrate(a)	PHY_LCCalibrate_8188E(&(GET_HAL_DATA(a)->odmpriv))
-#define PHY_SetRFPathSwitch(a,b) PHY_SetRFPathSwitch_8188E(a,b)
+		bmain = PHY_QueryRFPathSwitch_8188E(padapter);
 #endif
-
+	} else if (IS_HARDWARE_TYPE_8814A(padapter)) {
 #ifdef CONFIG_RTL8814A
-#define PHY_IQCalibrate(a,b)	PHY_IQCalibrate_8814A(&(GET_HAL_DATA(a)->odmpriv), b)
-#define PHY_LCCalibrate(a)	PHY_LCCalibrate_8814A(&(GET_HAL_DATA(a)->odmpriv))
-#define PHY_SetRFPathSwitch(a,b) PHY_SetRFPathSwitch_8814A(a,b)
-#endif /* CONFIG_RTL8814A */
-
-#ifdef CONFIG_RTL8812A
-#define PHY_IQCalibrate(_Adapter, b)	PHY_IQCalibrate_8812A(_Adapter, b)
-#define PHY_LCCalibrate(_Adapter)	PHY_LCCalibrate_8812A(&(GET_HAL_DATA(_Adapter)->odmpriv))
-#define PHY_SetRFPathSwitch(_Adapter, b) PHY_SetRFPathSwitch_8812A(_Adapter, b)
+		bmain = PHY_QueryRFPathSwitch_8814A(padapter);
 #endif
-
-#ifdef CONFIG_RTL8821A
-#define PHY_IQCalibrate(_Adapter, b)	PHY_IQCalibrate_8821A(&(GET_HAL_DATA(_Adapter)->odmpriv), b)
-#define PHY_LCCalibrate(_Adapter)	PHY_LCCalibrate_8821A(&(GET_HAL_DATA(_Adapter)->odmpriv))
-#define PHY_SetRFPathSwitch(_Adapter, b) PHY_SetRFPathSwitch_8812A(_Adapter, b)
+	} else if (IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter)) {
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+		bmain = PHY_QueryRFPathSwitch_8812A(padapter);
 #endif
-
+	} else if (IS_HARDWARE_TYPE_8192E(padapter)) {
 #ifdef CONFIG_RTL8192E
-#define PHY_IQCalibrate(a,b)	PHY_IQCalibrate_8192E(a,b)
-#define PHY_LCCalibrate(a)	PHY_LCCalibrate_8192E(&(GET_HAL_DATA(a)->odmpriv))
-#define PHY_SetRFPathSwitch(a,b) PHY_SetRFPathSwitch_8192E(a,b)
-#endif //CONFIG_RTL8812A_8821A
-
-#ifdef CONFIG_RTL8723B
-static void PHY_IQCalibrate(PADAPTER padapter, u8 bReCovery)
-{
-	PHAL_DATA_TYPE pHalData;
-	u8 b2ant;	//false:1ant, true:2-ant
-	u8 RF_Path;	//0:S1, 1:S0
+		bmain = PHY_QueryRFPathSwitch_8192E(padapter);
+#endif
+	} else if (IS_HARDWARE_TYPE_8703B(padapter)) {
+#ifdef CONFIG_RTL8703B
+		bmain = PHY_QueryRFPathSwitch_8703B(padapter);
+#endif
+	} else if (IS_HARDWARE_TYPE_8188F(padapter)) {
+#ifdef CONFIG_RTL8188F
+		bmain = PHY_QueryRFPathSwitch_8188F(padapter);
+#endif
+	} else if (IS_HARDWARE_TYPE_8188GTV(padapter)) {
+#ifdef CONFIG_RTL8188GTV
+		bmain = PHY_QueryRFPathSwitch_8188GTV(padapter);
+#endif
+	} else if (IS_HARDWARE_TYPE_8822B(padapter)) {
+#ifdef CONFIG_RTL8822B
+		bmain = PHY_QueryRFPathSwitch_8822B(padapter);
+#endif
+	} else if (IS_HARDWARE_TYPE_8723D(padapter)) {
+#ifdef CONFIG_RTL8723D
+		bmain = PHY_QueryRFPathSwitch_8723D(padapter);
+#endif
+	} else
+*/
 
-	pHalData = GET_HAL_DATA(padapter);
-	b2ant = pHalData->EEPROMBluetoothAntNum==Ant_x2?_TRUE:_FALSE;
+	if (IS_HARDWARE_TYPE_8821C(padapter)) {
+#ifdef CONFIG_RTL8821C
+		bmain = phy_query_rf_path_switch_8821c(padapter);
+#endif
+	}
 
-	PHY_IQCalibrate_8723B(padapter, bReCovery, _FALSE, b2ant, pHalData->ant_path);
+	return bmain;
 }
 
+static void  PHY_SetRFPathSwitch(PADAPTER padapter , BOOLEAN bMain) {
 
-#define PHY_LCCalibrate(a)	PHY_LCCalibrate_8723B(&(GET_HAL_DATA(a)->odmpriv))
-#define PHY_SetRFPathSwitch(a,b)	PHY_SetRFPathSwitch_8723B(a,b)
-#endif
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+	struct dm_struct *phydm = &hal->odmpriv;
 
+	if (IS_HARDWARE_TYPE_8723B(padapter)) {
+#ifdef CONFIG_RTL8723B
+		phy_set_rf_path_switch_8723b(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8188E(padapter)) {
+#ifdef CONFIG_RTL8188E
+		phy_set_rf_path_switch_8188e(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8814A(padapter)) {	
+#ifdef CONFIG_RTL8814A
+		phy_set_rf_path_switch_8814a(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter)) {
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+		phy_set_rf_path_switch_8812a(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8192E(padapter)) {
+#ifdef CONFIG_RTL8192E
+		phy_set_rf_path_switch_8192e(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8703B(padapter)) {
 #ifdef CONFIG_RTL8703B
-static void PHY_IQCalibrate(PADAPTER padapter, u8 bReCovery) 
-{
-	PHY_IQCalibrate_8703B(padapter, bReCovery);
+		phy_set_rf_path_switch_8703b(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8188F(padapter) || IS_HARDWARE_TYPE_8188GTV(padapter)) {
+#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
+		phy_set_rf_path_switch_8188f(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8822B(padapter)) {
+#ifdef CONFIG_RTL8822B
+		phy_set_rf_path_switch_8822b(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8723D(padapter)) {
+#ifdef CONFIG_RTL8723D
+		phy_set_rf_path_switch_8723d(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8821C(padapter)) {
+#ifdef CONFIG_RTL8821C
+		phy_set_rf_path_switch_8821c(phydm, bMain);
+#endif
+	}
 }
 
 
-#define PHY_LCCalibrate(a)	PHY_LCCalibrate_8703B(&(GET_HAL_DATA(a)->odmpriv))
-#define PHY_SetRFPathSwitch(a, b)	
+static void phy_switch_rf_path_set(PADAPTER padapter , u8 *prf_set_State) {
+
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct dm_struct *p_dm = &pHalData->odmpriv;
+
+#ifdef CONFIG_RTL8821C
+	if (IS_HARDWARE_TYPE_8821C(padapter)) {
+		config_phydm_set_ant_path(p_dm, *prf_set_State, p_dm->current_ant_num_8821c);
+		/* Do IQK when switching to BTG/WLG, requested by RF Binson */
+		if (*prf_set_State == SWITCH_TO_BTG || *prf_set_State == SWITCH_TO_WLG)
+			PHY_IQCalibrate(padapter, FALSE);
+	}		
 #endif
 
-#ifdef CONFIG_RTL8188F
-static void PHY_IQCalibrate(PADAPTER padapter, u8 bReCovery)
-{
-	PHY_IQCalibrate_8188F(padapter, bReCovery, _FALSE);
 }
 
 
-#define PHY_LCCalibrate(a)	PHY_LCCalibrate_8188F(&(GET_HAL_DATA(a)->odmpriv))
-#define PHY_SetRFPathSwitch(a, b)	PHY_SetRFPathSwitch_8188F(a, b)
+#ifdef CONFIG_ANTENNA_DIVERSITY
+u8 rtw_mp_set_antdiv(PADAPTER padapter, BOOLEAN bMain)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 cur_ant, change_ant;
+
+	if (!pHalData->AntDivCfg)
+		return _FALSE;
+	/*rtw_hal_get_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &cur_ant, NULL);*/
+	change_ant = (bMain == MAIN_ANT) ? MAIN_ANT : AUX_ANT;
+
+	RTW_INFO("%s: config %s\n", __func__, (bMain == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+	rtw_antenna_select_cmd(padapter, change_ant, _FALSE);
+
+	return _TRUE;
+}
 #endif
 
 s32
 MPT_InitializeAdapter(
 	IN	PADAPTER			pAdapter,
 	IN	u8				Channel
-	)
+)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 	s32		rtStatus = _SUCCESS;
-	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.MptCtx;
+	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.mpt_ctx;
 	u32		ledsetting;
 	struct mlme_priv *pmlmepriv = &pAdapter->mlmepriv;
 
 	pMptCtx->bMptDrvUnload = _FALSE;
 	pMptCtx->bMassProdTest = _FALSE;
-	pMptCtx->bMptIndexEven = _TRUE;	//default gain index is -6.0db
+	pMptCtx->bMptIndexEven = _TRUE;	/* default gain index is -6.0db */
 	pMptCtx->h2cReqNum = 0x0;
-	//init for BT MP
+	/* init for BT MP */
 #if defined(CONFIG_RTL8723B)
 	pMptCtx->bMPh2c_timeout = _FALSE;
 	pMptCtx->MptH2cRspEvent = _FALSE;
 	pMptCtx->MptBtC2hEvent = _FALSE;
 	_rtw_init_sema(&pMptCtx->MPh2c_Sema, 0);
-	_init_timer( &pMptCtx->MPh2c_timeout_timer, pAdapter->pnetdev, MPh2c_timeout_handle, pAdapter );
+	rtw_init_timer(&pMptCtx->MPh2c_timeout_timer, pAdapter, MPh2c_timeout_handle, pAdapter);
 #endif
 
 	mpt_InitHWConfig(pAdapter);
 
 #ifdef CONFIG_RTL8723B
 	rtl8723b_InitAntenna_Selection(pAdapter);
-	if (IS_HARDWARE_TYPE_8723B(pAdapter))
-	{
+	if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
 
 		/* <20130522, Kordan> Turn off equalizer to improve Rx sensitivity. (Asked by EEChou)*/
-		PHY_SetBBReg(pAdapter, 0xA00, BIT8, 0x0);
+		phy_set_bb_reg(pAdapter, 0xA00, BIT8, 0x0);
 		PHY_SetRFPathSwitch(pAdapter, 1/*pHalData->bDefaultAntenna*/); /*default use Main*/
-		/*<20130522, Kordan> 0x51 and 0x71 should be set immediately after path switched, or they might be overwritten. */
-		if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90))
-					PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B10E);
-		else
-					PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
-	}	
+
+		if (pHalData->PackageType == PACKAGE_DEFAULT) 
+			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
+		else 
+			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6F10E);
+
+	}
 	/*set ant to wifi side in mp mode*/
 	rtw_write16(pAdapter, 0x870, 0x300);
 	rtw_write16(pAdapter, 0x860, 0x110);
@@ -567,39 +662,39 @@ MPT_InitializeAdapter(
 
 	pMptCtx->bMptWorkItemInProgress = _FALSE;
 	pMptCtx->CurrMptAct = NULL;
-	pMptCtx->MptRfPath = ODM_RF_PATH_A;
-	//-------------------------------------------------------------------------
-	// Don't accept any packets
+	pMptCtx->mpt_rf_path = RF_PATH_A;
+	/* ------------------------------------------------------------------------- */
+	/* Don't accept any packets */
 	rtw_write32(pAdapter, REG_RCR, 0);
 
-	//ledsetting = rtw_read32(pAdapter, REG_LEDCFG0);
-	//rtw_write32(pAdapter, REG_LEDCFG0, ledsetting & ~LED0DIS);
-	
-	//rtw_write32(pAdapter, REG_LEDCFG0, 0x08080);
+	/* ledsetting = rtw_read32(pAdapter, REG_LEDCFG0); */
+	/* rtw_write32(pAdapter, REG_LEDCFG0, ledsetting & ~LED0DIS); */
+
+	/* rtw_write32(pAdapter, REG_LEDCFG0, 0x08080); */
 	ledsetting = rtw_read32(pAdapter, REG_LEDCFG0);
-	
-	
+
+
 	PHY_LCCalibrate(pAdapter);
 	PHY_IQCalibrate(pAdapter, _FALSE);
-	//dm_CheckTXPowerTracking(&pHalData->odmpriv);	//trigger thermal meter
-	
-	PHY_SetRFPathSwitch(pAdapter, 1/*pHalData->bDefaultAntenna*/); //default use Main
-	
-	pMptCtx->backup0xc50 = (u1Byte)PHY_QueryBBReg(pAdapter, rOFDM0_XAAGCCore1, bMaskByte0);
-	pMptCtx->backup0xc58 = (u1Byte)PHY_QueryBBReg(pAdapter, rOFDM0_XBAGCCore1, bMaskByte0);
-	pMptCtx->backup0xc30 = (u1Byte)PHY_QueryBBReg(pAdapter, rOFDM0_RxDetector1, bMaskByte0);
-	pMptCtx->backup0x52_RF_A = (u1Byte)PHY_QueryRFReg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0);
-	pMptCtx->backup0x52_RF_B = (u1Byte)PHY_QueryRFReg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0);
+	/* dm_check_txpowertracking(&pHalData->odmpriv);	*/ /* trigger thermal meter */
+
+	PHY_SetRFPathSwitch(pAdapter, 1/*pHalData->bDefaultAntenna*/); /* default use Main */
+
+	pMptCtx->backup0xc50 = (u1Byte)phy_query_bb_reg(pAdapter, rOFDM0_XAAGCCore1, bMaskByte0);
+	pMptCtx->backup0xc58 = (u1Byte)phy_query_bb_reg(pAdapter, rOFDM0_XBAGCCore1, bMaskByte0);
+	pMptCtx->backup0xc30 = (u1Byte)phy_query_bb_reg(pAdapter, rOFDM0_RxDetector1, bMaskByte0);
+	pMptCtx->backup0x52_RF_A = (u1Byte)phy_query_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0);
+	pMptCtx->backup0x52_RF_B = (u1Byte)phy_query_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0);
 #ifdef CONFIG_RTL8188E
 	rtw_write32(pAdapter, REG_MACID_NO_LINK_0, 0x0);
 	rtw_write32(pAdapter, REG_MACID_NO_LINK_1, 0x0);
 #endif
 #ifdef CONFIG_RTL8814A
 	if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
-		pHalData->BackUp_IG_REG_4_Chnl_Section[0] = (u1Byte)PHY_QueryBBReg(pAdapter, rA_IGI_Jaguar, bMaskByte0);
-		pHalData->BackUp_IG_REG_4_Chnl_Section[1] = (u1Byte)PHY_QueryBBReg(pAdapter, rB_IGI_Jaguar, bMaskByte0);
-		pHalData->BackUp_IG_REG_4_Chnl_Section[2] = (u1Byte)PHY_QueryBBReg(pAdapter, rC_IGI_Jaguar2, bMaskByte0);
-		pHalData->BackUp_IG_REG_4_Chnl_Section[3] = (u1Byte)PHY_QueryBBReg(pAdapter, rD_IGI_Jaguar2, bMaskByte0);
+		pHalData->BackUp_IG_REG_4_Chnl_Section[0] = (u1Byte)phy_query_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0);
+		pHalData->BackUp_IG_REG_4_Chnl_Section[1] = (u1Byte)phy_query_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0);
+		pHalData->BackUp_IG_REG_4_Chnl_Section[2] = (u1Byte)phy_query_bb_reg(pAdapter, rC_IGI_Jaguar2, bMaskByte0);
+		pHalData->BackUp_IG_REG_4_Chnl_Section[3] = (u1Byte)phy_query_bb_reg(pAdapter, rD_IGI_Jaguar2, bMaskByte0);
 	}
 #endif
 	return	rtStatus;
@@ -625,43 +720,40 @@ MPT_InitializeAdapter(
 VOID
 MPT_DeInitAdapter(
 	IN	PADAPTER	pAdapter
-	)
+)
 {
-	PMPT_CONTEXT		pMptCtx = &pAdapter->mppriv.MptCtx;
+	PMPT_CONTEXT		pMptCtx = &pAdapter->mppriv.mpt_ctx;
 
 	pMptCtx->bMptDrvUnload = _TRUE;
-	#if defined(CONFIG_RTL8723B)
+#if defined(CONFIG_RTL8723B)
 	_rtw_free_sema(&(pMptCtx->MPh2c_Sema));
-	_cancel_timer_ex( &pMptCtx->MPh2c_timeout_timer);
-	#endif
-	#if	defined(CONFIG_RTL8723B)
-	PHY_SetBBReg(pAdapter,0xA01, BIT0, 1); ///suggestion  by jerry for MP Rx.
-	#endif
-#if 0 // for Windows
-	PlatformFreeWorkItem( &(pMptCtx->MptWorkItem) );
-
-	while(pMptCtx->bMptWorkItemInProgress)
-	{
-		if(NdisWaitEvent(&(pMptCtx->MptWorkItemEvent), 50))
-		{
+	_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
+#endif
+#if	defined(CONFIG_RTL8723B)
+	phy_set_bb_reg(pAdapter, 0xA01, BIT0, 1); /* /suggestion  by jerry for MP Rx. */
+#endif
+#if 0 /* for Windows */
+	PlatformFreeWorkItem(&(pMptCtx->MptWorkItem));
+
+	while (pMptCtx->bMptWorkItemInProgress) {
+		if (NdisWaitEvent(&(pMptCtx->MptWorkItemEvent), 50))
 			break;
-		}
 	}
-	NdisFreeSpinLock( &(pMptCtx->MptWorkItemSpinLock) );
+	NdisFreeSpinLock(&(pMptCtx->MptWorkItemSpinLock));
 #endif
 }
 
 static u8 mpt_ProStartTest(PADAPTER padapter)
 {
-	PMPT_CONTEXT pMptCtx = &padapter->mppriv.MptCtx;
+	PMPT_CONTEXT pMptCtx = &padapter->mppriv.mpt_ctx;
 
 	pMptCtx->bMassProdTest = _TRUE;
-	pMptCtx->bStartContTx = _FALSE;
+	pMptCtx->is_start_cont_tx = _FALSE;
 	pMptCtx->bCckContTx = _FALSE;
 	pMptCtx->bOfdmContTx = _FALSE;
 	pMptCtx->bSingleCarrier = _FALSE;
-	pMptCtx->bCarrierSuppression = _FALSE;
-	pMptCtx->bSingleTone = _FALSE;
+	pMptCtx->is_carrier_suppression = _FALSE;
+	pMptCtx->is_single_tone = _FALSE;
 	pMptCtx->HWTxmode = PACKETS_TX;
 
 	return _SUCCESS;
@@ -692,74 +784,70 @@ void rtw_mp_trigger_lck(PADAPTER padapter)
 	PHY_LCCalibrate(padapter);
 }
 
-static void disable_dm(PADAPTER padapter)
+static void init_mp_data(PADAPTER padapter)
 {
 	u8 v8;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 
-	//3 1. disable firmware dynamic mechanism
-	// disable Power Training, Rate Adaptive
+	/*disable BCN*/
 	v8 = rtw_read8(padapter, REG_BCN_CTRL);
 	v8 &= ~EN_BCN_FUNCTION;
 	rtw_write8(padapter, REG_BCN_CTRL, v8);
 
-	//3 2. disable driver dynamic mechanism
-	rtw_phydm_func_disable_all(padapter);
-
-	// enable APK, LCK and IQK but disable power tracking
-	pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = _FALSE;
-	rtw_phydm_func_set(padapter, ODM_RF_CALIBRATION);
-
-//#ifdef CONFIG_BT_COEXIST
-//	rtw_btcoex_Switch(padapter, 0); //remove for BT MP Down.
-//#endif
+	pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
 }
 
-
 void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-
-	if (bstart==1){
-		DBG_871X("in MPT_PwrCtlDM start\n");
-		rtw_phydm_func_set(padapter, ODM_RF_TX_PWR_TRACK | ODM_RF_CALIBRATION);
-
-		pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = _TRUE;
-		padapter->mppriv.mp_dm =1;
-		
-	}else{
-		DBG_871X("in MPT_PwrCtlDM stop \n");
-		disable_dm(padapter);
-		pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = _FALSE;
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+	u32	rf_ability;
+
+	if (bstart == 1) {
+		RTW_INFO("in MPT_PwrCtlDM start\n");
+
+		rf_ability = ((u32)halrf_cmn_info_get(pDM_Odm, HALRF_CMNINFO_ABILITY)) | HAL_RF_TX_PWR_TRACK;
+		halrf_cmn_info_set(pDM_Odm, HALRF_CMNINFO_ABILITY, rf_ability);
+
+		pDM_Odm->rf_calibrate_info.txpowertrack_control = _TRUE;
+		padapter->mppriv.mp_dm = 1;
+
+	} else {
+		RTW_INFO("in MPT_PwrCtlDM stop\n");
+		rf_ability = ((u32)halrf_cmn_info_get(pDM_Odm, HALRF_CMNINFO_ABILITY)) & ~HAL_RF_TX_PWR_TRACK;
+		halrf_cmn_info_set(pDM_Odm, HALRF_CMNINFO_ABILITY, rf_ability);
+		pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
 		padapter->mppriv.mp_dm = 0;
 		{
-			TXPWRTRACK_CFG	c;
-			u1Byte	chnl =0 ;
-			_rtw_memset(&c, 0, sizeof(TXPWRTRACK_CFG));
-			ConfigureTxpowerTrack(pDM_Odm, &c);
-			ODM_ClearTxPowerTrackingState(pDM_Odm);
-			if (*c.ODM_TxPwrTrackSetPwr) {
-				if (pDM_Odm->SupportICType == ODM_RTL8188F)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, MIX_MODE, ODM_RF_PATH_A, chnl);
-				else {
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, ODM_RF_PATH_A, chnl);
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, ODM_RF_PATH_B, chnl);
+			struct txpwrtrack_cfg c;
+			u1Byte	chnl = 0 ;
+			_rtw_memset(&c, 0, sizeof(struct txpwrtrack_cfg));
+			configure_txpower_track(pDM_Odm, &c);
+			odm_clear_txpowertracking_state(pDM_Odm);
+			if (*c.odm_tx_pwr_track_set_pwr) {
+				if (pDM_Odm->support_ic_type == ODM_RTL8188F)
+					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, MIX_MODE, RF_PATH_A, chnl);
+				else if (pDM_Odm->support_ic_type == ODM_RTL8723D) {
+					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_A, chnl);
+					SetTxPower(padapter);
+				} else {
+					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_A, chnl);
+					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_B, chnl);
 				}
 			}
 		}
 	}
-		
+
 }
 
 
-u32 mp_join(PADAPTER padapter,u8 mode)
+u32 mp_join(PADAPTER padapter, u8 mode)
 {
 	WLAN_BSSID_EX bssid;
 	struct sta_info *psta;
 	u32 length;
-	u8 val8;
+	u8 val8, join_type;
 	_irqL irqL;
 	s32 res = _SUCCESS;
 
@@ -768,36 +856,37 @@ u32 mp_join(PADAPTER padapter,u8 mode)
 	struct wlan_network *tgt_network = &pmlmepriv->cur_network;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
-	
-#ifdef CONFIG_IOCTL_CFG80211		
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+
+#ifdef CONFIG_IOCTL_CFG80211
 	struct wireless_dev *pwdev = padapter->rtw_wdev;
-#endif //#ifdef CONFIG_IOCTL_CFG80211
-	// 1. initialize a new WLAN_BSSID_EX
+#endif /* #ifdef CONFIG_IOCTL_CFG80211 */
+	/* 1. initialize a new WLAN_BSSID_EX */
 	_rtw_memset(&bssid, 0, sizeof(WLAN_BSSID_EX));
-	DBG_8192C("%s ,pmppriv->network_macaddr=%x %x %x %x %x %x \n",__func__,
-				pmppriv->network_macaddr[0],pmppriv->network_macaddr[1],pmppriv->network_macaddr[2],pmppriv->network_macaddr[3],pmppriv->network_macaddr[4],pmppriv->network_macaddr[5]);
+	RTW_INFO("%s ,pmppriv->network_macaddr=%x %x %x %x %x %x\n", __func__,
+		pmppriv->network_macaddr[0], pmppriv->network_macaddr[1], pmppriv->network_macaddr[2], pmppriv->network_macaddr[3], pmppriv->network_macaddr[4],
+		 pmppriv->network_macaddr[5]);
 	_rtw_memcpy(bssid.MacAddress, pmppriv->network_macaddr, ETH_ALEN);
-	
-	if( mode==WIFI_FW_ADHOC_STATE ){
+
+	if (mode == WIFI_FW_ADHOC_STATE) {
 		bssid.Ssid.SsidLength = strlen("mp_pseudo_adhoc");
-		_rtw_memcpy(bssid.Ssid.Ssid, (u8*)"mp_pseudo_adhoc", bssid.Ssid.SsidLength);
+		_rtw_memcpy(bssid.Ssid.Ssid, (u8 *)"mp_pseudo_adhoc", bssid.Ssid.SsidLength);
 		bssid.InfrastructureMode = Ndis802_11IBSS;
 		bssid.NetworkTypeInUse = Ndis802_11DS;
 		bssid.IELength = 0;
-		bssid.Configuration.DSConfig=pmppriv->channel;
+		bssid.Configuration.DSConfig = pmppriv->channel;
 
-	}else if(mode==WIFI_FW_STATION_STATE){
+	} else if (mode == WIFI_FW_STATION_STATE) {
 		bssid.Ssid.SsidLength = strlen("mp_pseudo_STATION");
-		_rtw_memcpy(bssid.Ssid.Ssid, (u8*)"mp_pseudo_STATION", bssid.Ssid.SsidLength);
+		_rtw_memcpy(bssid.Ssid.Ssid, (u8 *)"mp_pseudo_STATION", bssid.Ssid.SsidLength);
 		bssid.InfrastructureMode = Ndis802_11Infrastructure;
 		bssid.NetworkTypeInUse = Ndis802_11DS;
 		bssid.IELength = 0;
 	}
-	
+
 	length = get_WLAN_BSSID_EX_sz(&bssid);
 	if (length % 4)
-		bssid.Length = ((length >> 2) + 1) << 2; //round up to multiple of 4 bytes.
+		bssid.Length = ((length >> 2) + 1) << 2; /* round up to multiple of 4 bytes. */
 	else
 		bssid.Length = length;
 
@@ -806,61 +895,67 @@ u32 mp_join(PADAPTER padapter,u8 mode)
 	if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
 		goto end_of_mp_start_test;
 
-	//init mp_start_test status
+	/* init mp_start_test status */
 	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
-		rtw_disassoc_cmd(padapter, 500, _TRUE);
+		rtw_disassoc_cmd(padapter, 500, 0);
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
-		rtw_free_assoc_resources(padapter, 1);
+		rtw_free_assoc_resources_cmd(padapter, _TRUE);
 	}
 	pmppriv->prev_fw_state = get_fwstate(pmlmepriv);
-	pmlmepriv->fw_state = WIFI_MP_STATE;
+	/*pmlmepriv->fw_state = WIFI_MP_STATE;*/
+	init_fwstate(pmlmepriv, WIFI_MP_STATE);
 
 	set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
 
-	//3 2. create a new psta for mp driver
-	//clear psta in the cur_network, if any
+	/* 3 2. create a new psta for mp driver */
+	/* clear psta in the cur_network, if any */
 	psta = rtw_get_stainfo(&padapter->stapriv, tgt_network->network.MacAddress);
-	if (psta) rtw_free_stainfo(padapter, psta);
+	if (psta)
+		rtw_free_stainfo(padapter, psta);
 
 	psta = rtw_alloc_stainfo(&padapter->stapriv, bssid.MacAddress);
 	if (psta == NULL) {
-		RT_TRACE(_module_mp_, _drv_err_, ("mp_start_test: Can't alloc sta_info!\n"));
-		pmlmepriv->fw_state = pmppriv->prev_fw_state;
+		/*pmlmepriv->fw_state = pmppriv->prev_fw_state;*/
+		init_fwstate(pmlmepriv, pmppriv->prev_fw_state);
 		res = _FAIL;
 		goto end_of_mp_start_test;
 	}
-	set_fwstate(pmlmepriv,WIFI_ADHOC_MASTER_STATE);
-	//3 3. join psudo AdHoc
+	if (mode == WIFI_FW_ADHOC_STATE)
+	set_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
+	else
+		set_fwstate(pmlmepriv, WIFI_STATION_STATE);
+	/* 3 3. join psudo AdHoc */
 	tgt_network->join_res = 1;
-	tgt_network->aid = psta->aid = 1;
+	tgt_network->aid = psta->cmn.aid = 1;
 
 	_rtw_memcpy(&padapter->registrypriv.dev_network, &bssid, length);
 	rtw_update_registrypriv_dev_network(padapter);
-	_rtw_memcpy(&tgt_network->network,&padapter->registrypriv.dev_network, padapter->registrypriv.dev_network.Length);
-	_rtw_memcpy(pnetwork,&padapter->registrypriv.dev_network, padapter->registrypriv.dev_network.Length);
+	_rtw_memcpy(&tgt_network->network, &padapter->registrypriv.dev_network, padapter->registrypriv.dev_network.Length);
+	_rtw_memcpy(pnetwork, &padapter->registrypriv.dev_network, padapter->registrypriv.dev_network.Length);
 
 	rtw_indicate_connect(padapter);
 	_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-	set_fwstate(pmlmepriv,_FW_LINKED);
+	set_fwstate(pmlmepriv, _FW_LINKED);
 
 end_of_mp_start_test:
 
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
-	if(1) //(res == _SUCCESS)
-	{
-		// set MSR to WIFI_FW_ADHOC_STATE
-		if( mode==WIFI_FW_ADHOC_STATE ){
-
-			val8 = rtw_read8(padapter, MSR) & 0xFC; // 0x0102
-			val8 |= WIFI_FW_ADHOC_STATE;
-			rtw_write8(padapter, MSR, val8); // Link in ad hoc network
-		} 
-		else {
+	if (1) { /* (res == _SUCCESS) */
+		/* set MSR to WIFI_FW_ADHOC_STATE */
+		if (mode == WIFI_FW_ADHOC_STATE) {
+			/* set msr to WIFI_FW_ADHOC_STATE */
+			pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
+			Set_MSR(padapter, (pmlmeinfo->state & 0x3));
+			rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, padapter->registrypriv.dev_network.MacAddress);
+			rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
+			pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
+		} else {
 			Set_MSR(padapter, WIFI_FW_STATION_STATE);
 
-			DBG_8192C("%s , pmppriv->network_macaddr =%x %x %x %x %x %x\n",__func__,
-						pmppriv->network_macaddr[0],pmppriv->network_macaddr[1],pmppriv->network_macaddr[2],pmppriv->network_macaddr[3],pmppriv->network_macaddr[4],pmppriv->network_macaddr[5]);
+			RTW_INFO("%s , pmppriv->network_macaddr =%x %x %x %x %x %x\n", __func__,
+				pmppriv->network_macaddr[0], pmppriv->network_macaddr[1], pmppriv->network_macaddr[2], pmppriv->network_macaddr[3], pmppriv->network_macaddr[4],
+				 pmppriv->network_macaddr[5]);
 
 			rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmppriv->network_macaddr);
 		}
@@ -868,7 +963,7 @@ end_of_mp_start_test:
 
 	return res;
 }
-//This function initializes the DUT to the MP test mode
+/* This function initializes the DUT to the MP test mode */
 s32 mp_start_test(PADAPTER padapter)
 {
 	struct mp_priv *pmppriv = &padapter->mppriv;
@@ -876,61 +971,68 @@ s32 mp_start_test(PADAPTER padapter)
 
 	padapter->registrypriv.mp_mode = 1;
 
-	//3 disable dynamic mechanism
-	disable_dm(padapter);
-	#ifdef CONFIG_RTL8814A
+	init_mp_data(padapter);
+#ifdef CONFIG_RTL8814A
 	rtl8814_InitHalDm(padapter);
-	#endif /* CONFIG_RTL8814A */
-	#ifdef CONFIG_RTL8812A
+#endif /* CONFIG_RTL8814A */
+#ifdef CONFIG_RTL8812A
 	rtl8812_InitHalDm(padapter);
-	#endif /* CONFIG_RTL8812A */
-	#ifdef CONFIG_RTL8723B
+#endif /* CONFIG_RTL8812A */
+#ifdef CONFIG_RTL8723B
 	rtl8723b_InitHalDm(padapter);
-	#endif /* CONFIG_RTL8723B */
-	#ifdef CONFIG_RTL8703B
+#endif /* CONFIG_RTL8723B */
+#ifdef CONFIG_RTL8703B
 	rtl8703b_InitHalDm(padapter);
-	#endif /* CONFIG_RTL8703B */
-	#ifdef CONFIG_RTL8192E
+#endif /* CONFIG_RTL8703B */
+#ifdef CONFIG_RTL8192E
 	rtl8192e_InitHalDm(padapter);
-	#endif
-	#ifdef CONFIG_RTL8188F
+#endif
+#ifdef CONFIG_RTL8188F
 	rtl8188f_InitHalDm(padapter);
-	#endif
+#endif
+#ifdef CONFIG_RTL8188GTV
+	rtl8188gtv_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8188E
+	rtl8188e_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8723D
+	rtl8723d_InitHalDm(padapter);
+#endif /* CONFIG_RTL8723D */
 
-	//3 0. update mp_priv
+	/* 3 0. update mp_priv */
 
-	if (padapter->registrypriv.rf_config == RF_MAX_TYPE) {
-//		switch (phal->rf_type) {
+	if (!RF_TYPE_VALID(padapter->registrypriv.rf_config)) {
+		/*		switch (phal->rf_type) { */
 		switch (GET_RF_TYPE(padapter)) {
-			case RF_1T1R:
-				pmppriv->antenna_tx = ANTENNA_A;
-				pmppriv->antenna_rx = ANTENNA_A;
-				break;
-			case RF_1T2R:
-			default:
-				pmppriv->antenna_tx = ANTENNA_A;
-				pmppriv->antenna_rx = ANTENNA_AB;
-				break;
-			case RF_2T2R:
-			case RF_2T2R_GREEN:
-				pmppriv->antenna_tx = ANTENNA_AB;
-				pmppriv->antenna_rx = ANTENNA_AB;
-				break;
-			case RF_2T4R:
-				pmppriv->antenna_tx = ANTENNA_AB;
-				pmppriv->antenna_rx = ANTENNA_ABCD;
-				break;
-	}
+		case RF_1T1R:
+			pmppriv->antenna_tx = ANTENNA_A;
+			pmppriv->antenna_rx = ANTENNA_A;
+			break;
+		case RF_1T2R:
+		default:
+			pmppriv->antenna_tx = ANTENNA_A;
+			pmppriv->antenna_rx = ANTENNA_AB;
+			break;
+		case RF_2T2R:
+			pmppriv->antenna_tx = ANTENNA_AB;
+			pmppriv->antenna_rx = ANTENNA_AB;
+			break;
+		case RF_2T4R:
+			pmppriv->antenna_tx = ANTENNA_AB;
+			pmppriv->antenna_rx = ANTENNA_ABCD;
+			break;
+		}
 	}
 
 	mpt_ProStartTest(padapter);
 
-	mp_join(padapter,WIFI_FW_ADHOC_STATE);
+	mp_join(padapter, WIFI_FW_ADHOC_STATE);
 
 	return res;
 }
-//------------------------------------------------------------------------------
-//This function change the DUT from the MP test mode into normal mode
+/* ------------------------------------------------------------------------------
+ * This function change the DUT from the MP test mode into normal mode */
 void mp_stop_test(PADAPTER padapter)
 {
 	struct mp_priv *pmppriv = &padapter->mppriv;
@@ -939,54 +1041,61 @@ void mp_stop_test(PADAPTER padapter)
 	struct sta_info *psta;
 
 	_irqL irqL;
-	
-	if(pmppriv->mode==MP_ON)
-	{
-	pmppriv->bSetTxPower=0;
-	_enter_critical_bh(&pmlmepriv->lock, &irqL);	
-	if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _FALSE)
-		goto end_of_mp_stop_test;
 
-	//3 1. disconnect psudo AdHoc
-	rtw_indicate_disconnect(padapter, 0, _FALSE);
+	if (pmppriv->mode == MP_ON) {
+		pmppriv->bSetTxPower = 0;
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _FALSE)
+			goto end_of_mp_stop_test;
 
-	//3 2. clear psta used in mp test mode.
-//	rtw_free_assoc_resources(padapter, 1);
-	psta = rtw_get_stainfo(&padapter->stapriv, tgt_network->network.MacAddress);
-	if (psta) rtw_free_stainfo(padapter, psta);
+		/* 3 1. disconnect psudo AdHoc */
+		rtw_indicate_disconnect(padapter, 0, _FALSE);
+
+		/* 3 2. clear psta used in mp test mode.
+		*	rtw_free_assoc_resources(padapter, _TRUE); */
+		psta = rtw_get_stainfo(&padapter->stapriv, tgt_network->network.MacAddress);
+		if (psta)
+			rtw_free_stainfo(padapter, psta);
+
+		/* 3 3. return to normal state (default:station mode) */
+		/*pmlmepriv->fw_state = pmppriv->prev_fw_state; */ /* WIFI_STATION_STATE;*/
+		init_fwstate(pmlmepriv, pmppriv->prev_fw_state);
 
-	//3 3. return to normal state (default:station mode)
-	pmlmepriv->fw_state = pmppriv->prev_fw_state; // WIFI_STATION_STATE;
+		/* flush the cur_network */
+		_rtw_memset(tgt_network, 0, sizeof(struct wlan_network));
 
-	//flush the cur_network
-	_rtw_memset(tgt_network, 0, sizeof(struct wlan_network));
-	
-	_clr_fwstate_(pmlmepriv, WIFI_MP_STATE);
+		_clr_fwstate_(pmlmepriv, WIFI_MP_STATE);
 
 end_of_mp_stop_test:
 
-	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
-	#ifdef CONFIG_RTL8812A
-	rtl8812_InitHalDm(padapter);
-	#endif
-	#ifdef CONFIG_RTL8723B
-	rtl8723b_InitHalDm(padapter);
-	#endif
-	#ifdef CONFIG_RTL8703B
-	rtl8703b_InitHalDm(padapter);
-	#endif
-	#ifdef CONFIG_RTL8192E
-	rtl8192e_InitHalDm(padapter);
-	#endif
-	#ifdef CONFIG_RTL8188F
-	rtl8188f_InitHalDm(padapter);
-	#endif
+#ifdef CONFIG_RTL8812A
+		rtl8812_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8723B
+		rtl8723b_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8703B
+		rtl8703b_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8192E
+		rtl8192e_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8188F
+		rtl8188f_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8188GTV
+		rtl8188gtv_InitHalDm(padapter);
+#endif
+#ifdef CONFIG_RTL8723D
+		rtl8723d_InitHalDm(padapter);
+#endif
 	}
 }
 /*---------------------------hal\rtl8192c\MPT_Phy.c---------------------------*/
 #if 0
-//#ifdef CONFIG_USB_HCI
+/* #ifdef CONFIG_USB_HCI */
 static VOID mpt_AdjustRFRegByRateByChan92CU(PADAPTER pAdapter, u8 RateIdx, u8 Channel, u8 BandWidthID)
 {
 	u8		eRFPath;
@@ -994,18 +1103,17 @@ static VOID mpt_AdjustRFRegByRateByChan92CU(PADAPTER pAdapter, u8 RateIdx, u8 Ch
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 
 
-	if (RateIdx < MPT_RATE_6M) {	// CCK rate,for 88cu
+	if (RateIdx < MPT_RATE_6M) 	/* CCK rate,for 88cu */
 		rfReg0x26 = 0xf400;
-	}
-	else if ((RateIdx >= MPT_RATE_6M) && (RateIdx <= MPT_RATE_54M)) {// OFDM rate,for 88cu
+	else if ((RateIdx >= MPT_RATE_6M) && (RateIdx <= MPT_RATE_54M)) {/* OFDM rate,for 88cu */
 		if ((4 == Channel) || (8 == Channel) || (12 == Channel))
 			rfReg0x26 = 0xf000;
 		else if ((5 == Channel) || (7 == Channel) || (13 == Channel) || (14 == Channel))
 			rfReg0x26 = 0xf400;
 		else
 			rfReg0x26 = 0x4f200;
-	}
-	else if ((RateIdx >= MPT_RATE_MCS0) && (RateIdx <= MPT_RATE_MCS15)) {// MCS 20M ,for 88cu // MCS40M rate,for 88cu
+	} else if ((RateIdx >= MPT_RATE_MCS0) && (RateIdx <= MPT_RATE_MCS15)) {
+		/* MCS 20M ,for 88cu */ /* MCS40M rate,for 88cu */
 
 		if (CHANNEL_WIDTH_20 == BandWidthID) {
 			if ((4 == Channel) || (8 == Channel))
@@ -1014,8 +1122,7 @@ static VOID mpt_AdjustRFRegByRateByChan92CU(PADAPTER pAdapter, u8 RateIdx, u8 Ch
 				rfReg0x26 = 0xf400;
 			else
 				rfReg0x26 = 0x4f200;
-		}
-		else{
+		} else {
 			if ((4 == Channel) || (8 == Channel))
 				rfReg0x26 = 0xf000;
 			else if ((5 == Channel) || (7 == Channel))
@@ -1025,10 +1132,8 @@ static VOID mpt_AdjustRFRegByRateByChan92CU(PADAPTER pAdapter, u8 RateIdx, u8 Ch
 		}
 	}
 
-//	RT_TRACE(COMP_CMD, DBG_LOUD, ("\n mpt_AdjustRFRegByRateByChan92CU():Chan:%d Rate=%d rfReg0x26:0x%08x\n",Channel, RateIdx,rfReg0x26));
-	for (eRFPath = 0; eRFPath < pHalData->NumTotalRFPath; eRFPath++) {
+	for (eRFPath = 0; eRFPath < pHalData->NumTotalRFPath; eRFPath++)
 		write_rfreg(pAdapter, eRFPath, RF_SYN_G2, rfReg0x26);
-	}
 }
 #endif
 /*-----------------------------------------------------------------------------
@@ -1051,7 +1156,7 @@ static VOID mpt_AdjustRFRegByRateByChan92CU(PADAPTER pAdapter, u8 RateIdx, u8 Ch
 static void mpt_SwitchRfSetting(PADAPTER pAdapter)
 {
 	hal_mpt_SwitchRfSetting(pAdapter);
-    }
+}
 
 /*---------------------------hal\rtl8192c\MPT_Phy.c---------------------------*/
 /*---------------------------hal\rtl8192c\MPT_HelperFunc.c---------------------------*/
@@ -1097,15 +1202,15 @@ int SetTxPower(PADAPTER pAdapter)
 
 void SetTxAGCOffset(PADAPTER pAdapter, u32 ulTxAGCOffset)
 {
-	u32 TxAGCOffset_B, TxAGCOffset_C, TxAGCOffset_D,tmpAGC;
+	u32 TxAGCOffset_B, TxAGCOffset_C, TxAGCOffset_D, tmpAGC;
 
-	TxAGCOffset_B = (ulTxAGCOffset&0x000000ff);
-	TxAGCOffset_C = ((ulTxAGCOffset&0x0000ff00)>>8);
-	TxAGCOffset_D = ((ulTxAGCOffset&0x00ff0000)>>16);
+	TxAGCOffset_B = (ulTxAGCOffset & 0x000000ff);
+	TxAGCOffset_C = ((ulTxAGCOffset & 0x0000ff00) >> 8);
+	TxAGCOffset_D = ((ulTxAGCOffset & 0x00ff0000) >> 16);
 
-	tmpAGC = (TxAGCOffset_D<<8 | TxAGCOffset_C<<4 | TxAGCOffset_B);
+	tmpAGC = (TxAGCOffset_D << 8 | TxAGCOffset_C << 4 | TxAGCOffset_B);
 	write_bbreg(pAdapter, rFPGA0_TxGainStage,
-			(bXBTxAGC|bXCTxAGC|bXDTxAGC), tmpAGC);
+		    (bXBTxAGC | bXCTxAGC | bXDTxAGC), tmpAGC);
 }
 
 void SetDataRate(PADAPTER pAdapter)
@@ -1113,13 +1218,24 @@ void SetDataRate(PADAPTER pAdapter)
 	hal_mpt_SetDataRate(pAdapter);
 }
 
-void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter ,BOOLEAN bMain)
+void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter , BOOLEAN bMain)
 {
 
 	PHY_SetRFPathSwitch(pAdapter, bMain);
 
 }
 
+void mp_phy_switch_rf_path_set(PADAPTER pAdapter , u8 *pstate)
+{
+
+	phy_switch_rf_path_set(pAdapter, pstate);
+
+}
+
+u8 MP_PHY_QueryRFPathSwitch(PADAPTER pAdapter)
+{
+	return PHY_QueryRFPathSwitch(pAdapter);
+}
 
 s32 SetThermalMeter(PADAPTER pAdapter, u8 target_ther)
 {
@@ -1159,18 +1275,6 @@ void SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)
 	hal_mpt_SetCarrierSuppressionTx(pAdapter, bStart);
 }
 
-void SetCCKContinuousTx(PADAPTER pAdapter, u8 bStart)
-{
-	PhySetTxPowerLevel(pAdapter);
-	hal_mpt_SetCCKContinuousTx(pAdapter, bStart);
-}
-
-void SetOFDMContinuousTx(PADAPTER pAdapter, u8 bStart)
-{
-	PhySetTxPowerLevel(pAdapter);
-	hal_mpt_SetOFDMContinuousTx(pAdapter, bStart);
-}/* mpt_StartOfdmContTx */
-
 void SetContinuousTx(PADAPTER pAdapter, u8 bStart)
 {
 	PhySetTxPowerLevel(pAdapter);
@@ -1181,30 +1285,13 @@ void SetContinuousTx(PADAPTER pAdapter, u8 bStart)
 void PhySetTxPowerLevel(PADAPTER pAdapter)
 {
 	struct mp_priv *pmp_priv = &pAdapter->mppriv;
-		
-	if (pmp_priv->bSetTxPower==0) // for NO manually set power index
-	{
-#ifdef CONFIG_RTL8188E	
-		PHY_SetTxPowerLevel8188E(pAdapter,pmp_priv->channel);
-#endif
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-		PHY_SetTxPowerLevel8812(pAdapter,pmp_priv->channel);
-#endif
-#if defined(CONFIG_RTL8192E)
-		PHY_SetTxPowerLevel8192E(pAdapter,pmp_priv->channel);
-#endif
-#if defined(CONFIG_RTL8723B)
-		PHY_SetTxPowerLevel8723B(pAdapter,pmp_priv->channel);
-#endif
-#if defined(CONFIG_RTL8188F)
-		PHY_SetTxPowerLevel8188F(pAdapter, pmp_priv->channel);
-#endif
-	mpt_ProQueryCalTxPower(pAdapter,pmp_priv->antenna_tx);
 
-	}
+
+	if (pmp_priv->bSetTxPower == 0) /* for NO manually set power index */
+		rtw_hal_set_tx_power_level(pAdapter, pmp_priv->channel);
 }
 
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 static void dump_mpframe(PADAPTER padapter, struct xmit_frame *pmpframe)
 {
 	rtw_hal_mgnt_xmit(padapter, pmpframe);
@@ -1215,13 +1302,12 @@ static struct xmit_frame *alloc_mp_xmitframe(struct xmit_priv *pxmitpriv)
 	struct xmit_frame	*pmpframe;
 	struct xmit_buf	*pxmitbuf;
 
-	if ((pmpframe = rtw_alloc_xmitframe(pxmitpriv)) == NULL)
-	{
+	pmpframe = rtw_alloc_xmitframe(pxmitpriv);
+	if (pmpframe == NULL)
 		return NULL;
-	}
 
-	if ((pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv)) == NULL)
-	{
+	pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
+	if (pxmitbuf == NULL) {
 		rtw_free_xmitframe(pxmitpriv, pmpframe);
 		return NULL;
 	}
@@ -1238,6 +1324,48 @@ static struct xmit_frame *alloc_mp_xmitframe(struct xmit_priv *pxmitpriv)
 
 }
 
+#ifdef CONFIG_PCIE_HCI
+static u8 check_nic_enough_desc(_adapter *padapter, struct pkt_attrib *pattrib)
+{
+	u32 prio;
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+	struct rtw_tx_ring	*ring;
+
+	switch (pattrib->qsel) {
+	case 0:
+	case 3:
+		prio = BE_QUEUE_INX;
+		break;
+	case 1:
+	case 2:
+		prio = BK_QUEUE_INX;
+		break;
+	case 4:
+	case 5:
+		prio = VI_QUEUE_INX;
+		break;
+	case 6:
+	case 7:
+		prio = VO_QUEUE_INX;
+		break;
+	default:
+		prio = BE_QUEUE_INX;
+		break;
+	}
+
+	ring = &pxmitpriv->tx_ring[prio];
+
+	/*
+	 * for now we reserve two free descriptor as a safety boundary
+	 * between the tail and the head
+	 */
+	if ((ring->entries - ring->qlen) >= 2)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+#endif
+
 static thread_return mp_xmit_packet_thread(thread_context context)
 {
 	struct xmit_frame	*pxmitframe;
@@ -1250,34 +1378,39 @@ static thread_return mp_xmit_packet_thread(thread_context context)
 	pmptx = &pmp_priv->tx;
 	padapter = pmp_priv->papdater;
 	pxmitpriv = &(padapter->xmitpriv);
-	
+
 	thread_enter("RTW_MP_THREAD");
 
-	DBG_871X("%s:pkTx Start\n", __func__);
+	RTW_INFO("%s:pkTx Start\n", __func__);
 	while (1) {
 		pxmitframe = alloc_mp_xmitframe(pxmitpriv);
+#ifdef CONFIG_PCIE_HCI
+		if(check_nic_enough_desc(padapter, &pmptx->attrib) == _FALSE) {
+			rtw_usleep_os(1000);
+			continue;
+		}
+#endif
 		if (pxmitframe == NULL) {
 			if (pmptx->stop ||
-				RTW_CANNOT_RUN(padapter)) {
+			    RTW_CANNOT_RUN(padapter))
 				goto exit;
-			}
 			else {
 				rtw_usleep_os(10);
 				continue;
 			}
 		}
-		_rtw_memcpy((u8 *)(pxmitframe->buf_addr+TXDESC_OFFSET), pmptx->buf, pmptx->write_size);
+		_rtw_memcpy((u8 *)(pxmitframe->buf_addr + TXDESC_OFFSET), pmptx->buf, pmptx->write_size);
 		_rtw_memcpy(&(pxmitframe->attrib), &(pmptx->attrib), sizeof(struct pkt_attrib));
 
-		
+
 		rtw_usleep_os(padapter->mppriv.pktInterval);
 		dump_mpframe(padapter, pxmitframe);
-		
+
 		pmptx->sended++;
 		pmp_priv->tx_pktcount++;
 
 		if (pmptx->stop ||
-			RTW_CANNOT_RUN(padapter))
+		    RTW_CANNOT_RUN(padapter))
 			goto exit;
 		if ((pmptx->count != 0) &&
 		    (pmptx->count == pmptx->sended))
@@ -1287,21 +1420,22 @@ static thread_return mp_xmit_packet_thread(thread_context context)
 	}
 
 exit:
-	//DBG_871X("%s:pkTx Exit\n", __func__);
+	/* RTW_INFO("%s:pkTx Exit\n", __func__); */
 	rtw_mfree(pmptx->pallocated_buf, pmptx->buf_size);
 	pmptx->pallocated_buf = NULL;
 	pmptx->stop = 1;
 
-	thread_exit();
+	thread_exit(NULL);
+	return 0;
 }
 
 void fill_txdesc_for_mp(PADAPTER padapter, u8 *ptxdesc)
-{		
+{
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	_rtw_memcpy(ptxdesc, pmp_priv->tx.desc, TXDESC_SIZE);
 }
 
-#if defined(CONFIG_RTL8188E) 
+#if defined(CONFIG_RTL8188E)
 void fill_tx_desc_8188e(PADAPTER padapter)
 {
 	struct mp_priv *pmp_priv = &padapter->mppriv;
@@ -1309,48 +1443,49 @@ void fill_tx_desc_8188e(PADAPTER padapter)
 	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
 	u32	pkt_size = pattrib->last_txcmdsz;
 	s32 bmcast = IS_MCAST(pattrib->ra);
-// offset 0
+	/* offset 0 */
 #if !defined(CONFIG_RTL8188E_SDIO) && !defined(CONFIG_PCI_HCI)
 	desc->txdw0 |= cpu_to_le32(OWN | FSG | LSG);
-	desc->txdw0 |= cpu_to_le32(pkt_size & 0x0000FFFF); // packet size
-	desc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) << OFFSET_SHT) & 0x00FF0000); //32 bytes for TX Desc
-	if (bmcast) desc->txdw0 |= cpu_to_le32(BMC); // broadcast packet
+	desc->txdw0 |= cpu_to_le32(pkt_size & 0x0000FFFF); /* packet size */
+	desc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) << OFFSET_SHT) & 0x00FF0000); /* 32 bytes for TX Desc */
+	if (bmcast)
+		desc->txdw0 |= cpu_to_le32(BMC); /* broadcast packet */
 
 	desc->txdw1 |= cpu_to_le32((0x01 << 26) & 0xff000000);
 #endif
 
-	desc->txdw1 |= cpu_to_le32((pattrib->mac_id) & 0x3F); //CAM_ID(MAC_ID)
-	desc->txdw1 |= cpu_to_le32((pattrib->qsel << QSEL_SHT) & 0x00001F00); // Queue Select, TID
-	desc->txdw1 |= cpu_to_le32((pattrib->raid << RATE_ID_SHT) & 0x000F0000); // Rate Adaptive ID
-	// offset 8
-	//	desc->txdw2 |= cpu_to_le32(AGG_BK);//AGG BK
+	desc->txdw1 |= cpu_to_le32((pattrib->mac_id) & 0x3F); /* CAM_ID(MAC_ID) */
+	desc->txdw1 |= cpu_to_le32((pattrib->qsel << QSEL_SHT) & 0x00001F00); /* Queue Select, TID */
+	desc->txdw1 |= cpu_to_le32((pattrib->raid << RATE_ID_SHT) & 0x000F0000); /* Rate Adaptive ID */
+	/* offset 8 */
+	/* desc->txdw2 |= cpu_to_le32(AGG_BK); */ /* AGG BK */
 
-	desc->txdw3 |= cpu_to_le32((pattrib->seqnum<<16)&0x0fff0000);
+	desc->txdw3 |= cpu_to_le32((pattrib->seqnum << 16) & 0x0fff0000);
 	desc->txdw4 |= cpu_to_le32(HW_SSN);
-		
+
 	desc->txdw4 |= cpu_to_le32(USERATE);
 	desc->txdw4 |= cpu_to_le32(DISDATAFB);
 
-	if( pmp_priv->preamble ){
+	if (pmp_priv->preamble) {
 		if (HwRateToMPTRate(pmp_priv->rateidx) <=  MPT_RATE_54M)
-			desc->txdw4 |= cpu_to_le32(DATA_SHORT); // CCK Short Preamble
+			desc->txdw4 |= cpu_to_le32(DATA_SHORT); /* CCK Short Preamble */
 	}
 
 	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
 		desc->txdw4 |= cpu_to_le32(DATA_BW);
 
-	// offset 20
+	/* offset 20 */
 	desc->txdw5 |= cpu_to_le32(pmp_priv->rateidx & 0x0000001F);
 
-	if( pmp_priv->preamble ){
+	if (pmp_priv->preamble) {
 		if (HwRateToMPTRate(pmp_priv->rateidx) > MPT_RATE_54M)
-			desc->txdw5 |= cpu_to_le32(SGI); // MCS Short Guard Interval
+			desc->txdw5 |= cpu_to_le32(SGI); /* MCS Short Guard Interval */
 	}
 
-	desc->txdw5 |= cpu_to_le32(RTY_LMT_EN); // retry limit enable
-	desc->txdw5 |= cpu_to_le32(0x00180000); // DATA/RTS Rate Fallback Limit	
-		
-	
+	desc->txdw5 |= cpu_to_le32(RTY_LMT_EN); /* retry limit enable */
+	desc->txdw5 |= cpu_to_le32(0x00180000); /* DATA/RTS Rate Fallback Limit	 */
+
+
 }
 #endif
 
@@ -1360,18 +1495,18 @@ void fill_tx_desc_8814a(PADAPTER padapter)
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	u8 *pDesc   = (u8 *)&(pmp_priv->tx.desc);
 	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
-	
+
 	u32	pkt_size = pattrib->last_txcmdsz;
 	s32 bmcast = IS_MCAST(pattrib->ra);
-	u8 data_rate,pwr_status,offset;
+	u8 data_rate, pwr_status, offset;
 
-	//SET_TX_DESC_FIRST_SEG_8814A(pDesc, 1);
+	/* SET_TX_DESC_FIRST_SEG_8814A(pDesc, 1); */
 	SET_TX_DESC_LAST_SEG_8814A(pDesc, 1);
-	//SET_TX_DESC_OWN_(pDesc, 1);
-	
+	/* SET_TX_DESC_OWN_(pDesc, 1); */
+
 	SET_TX_DESC_PKT_SIZE_8814A(pDesc, pkt_size);
-	
-	offset = TXDESC_SIZE + OFFSET_SZ;		
+
+	offset = TXDESC_SIZE + OFFSET_SZ;
 
 	SET_TX_DESC_OFFSET_8814A(pDesc, offset);
 #if defined(CONFIG_PCI_HCI)
@@ -1379,32 +1514,29 @@ void fill_tx_desc_8814a(PADAPTER padapter)
 #else
 	SET_TX_DESC_PKT_OFFSET_8814A(pDesc, 1);
 #endif
-	
-	if (bmcast) {
+
+	if (bmcast)
 		SET_TX_DESC_BMC_8814A(pDesc, 1);
-	}
 
 	SET_TX_DESC_MACID_8814A(pDesc, pattrib->mac_id);
 	SET_TX_DESC_RATE_ID_8814A(pDesc, pattrib->raid);
-	
-	//SET_TX_DESC_RATE_ID_8812(pDesc, RATEID_IDX_G);
+
+	/* SET_TX_DESC_RATE_ID_8812(pDesc, RATEID_IDX_G); */
 	SET_TX_DESC_QUEUE_SEL_8814A(pDesc,  pattrib->qsel);
-	//SET_TX_DESC_QUEUE_SEL_8812(pDesc,  QSLT_MGNT);
+	/* SET_TX_DESC_QUEUE_SEL_8812(pDesc,  QSLT_MGNT); */
 
-	if ( pmp_priv->preamble ){
+	if (pmp_priv->preamble)
 		SET_TX_DESC_DATA_SHORT_8814A(pDesc, 1);
-	}
-	
+
 	if (!pattrib->qos_en) {
-		SET_TX_DESC_HWSEQ_EN_8814A(pDesc, 1); // Hw set sequence number
-	} else {
+		SET_TX_DESC_HWSEQ_EN_8814A(pDesc, 1); /* Hw set sequence number */
+	} else
 		SET_TX_DESC_SEQ_8814A(pDesc, pattrib->seqnum);
-	}
-	
-	if (pmp_priv->bandwidth <= CHANNEL_WIDTH_160) {
+
+	if (pmp_priv->bandwidth <= CHANNEL_WIDTH_160)
 		SET_TX_DESC_DATA_BW_8814A(pDesc, pmp_priv->bandwidth);
-	} else {
-		DBG_871X("%s:Err: unknown bandwidth %d, use 20M\n", __func__,pmp_priv->bandwidth);
+	else {
+		RTW_INFO("%s:Err: unknown bandwidth %d, use 20M\n", __func__, pmp_priv->bandwidth);
 		SET_TX_DESC_DATA_BW_8814A(pDesc, CHANNEL_WIDTH_20);
 	}
 
@@ -1421,18 +1553,18 @@ void fill_tx_desc_8812a(PADAPTER padapter)
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	u8 *pDesc   = (u8 *)&(pmp_priv->tx.desc);
 	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
-	
+
 	u32	pkt_size = pattrib->last_txcmdsz;
 	s32 bmcast = IS_MCAST(pattrib->ra);
-	u8 data_rate,pwr_status,offset;
+	u8 data_rate, pwr_status, offset;
 
 	SET_TX_DESC_FIRST_SEG_8812(pDesc, 1);
 	SET_TX_DESC_LAST_SEG_8812(pDesc, 1);
 	SET_TX_DESC_OWN_8812(pDesc, 1);
-	
+
 	SET_TX_DESC_PKT_SIZE_8812(pDesc, pkt_size);
-	
-	offset = TXDESC_SIZE + OFFSET_SZ;		
+
+	offset = TXDESC_SIZE + OFFSET_SZ;
 
 	SET_TX_DESC_OFFSET_8812(pDesc, offset);
 
@@ -1441,27 +1573,25 @@ void fill_tx_desc_8812a(PADAPTER padapter)
 #else
 	SET_TX_DESC_PKT_OFFSET_8812(pDesc, 1);
 #endif
-	if (bmcast) {
+	if (bmcast)
 		SET_TX_DESC_BMC_8812(pDesc, 1);
-	}
 
 	SET_TX_DESC_MACID_8812(pDesc, pattrib->mac_id);
 	SET_TX_DESC_RATE_ID_8812(pDesc, pattrib->raid);
 
-	//SET_TX_DESC_RATE_ID_8812(pDesc, RATEID_IDX_G);
+	/* SET_TX_DESC_RATE_ID_8812(pDesc, RATEID_IDX_G); */
 	SET_TX_DESC_QUEUE_SEL_8812(pDesc,  pattrib->qsel);
-	//SET_TX_DESC_QUEUE_SEL_8812(pDesc,  QSLT_MGNT);
-	
+	/* SET_TX_DESC_QUEUE_SEL_8812(pDesc,  QSLT_MGNT); */
+
 	if (!pattrib->qos_en) {
-		SET_TX_DESC_HWSEQ_EN_8812(pDesc, 1); // Hw set sequence number
-	} else {
+		SET_TX_DESC_HWSEQ_EN_8812(pDesc, 1); /* Hw set sequence number */
+	} else
 		SET_TX_DESC_SEQ_8812(pDesc, pattrib->seqnum);
-	}
-	
-	if (pmp_priv->bandwidth <= CHANNEL_WIDTH_160) {
+
+	if (pmp_priv->bandwidth <= CHANNEL_WIDTH_160)
 		SET_TX_DESC_DATA_BW_8812(pDesc, pmp_priv->bandwidth);
-	} else {
-		DBG_871X("%s:Err: unknown bandwidth %d, use 20M\n", __func__,pmp_priv->bandwidth);
+	else {
+		RTW_INFO("%s:Err: unknown bandwidth %d, use 20M\n", __func__, pmp_priv->bandwidth);
 		SET_TX_DESC_DATA_BW_8812(pDesc, CHANNEL_WIDTH_20);
 	}
 
@@ -1477,51 +1607,49 @@ void fill_tx_desc_8192e(PADAPTER padapter)
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	u8 *pDesc	= (u8 *)&(pmp_priv->tx.desc);
 	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
-		
+
 	u32 pkt_size = pattrib->last_txcmdsz;
 	s32 bmcast = IS_MCAST(pattrib->ra);
-	u8 data_rate,pwr_status,offset;
-	
+	u8 data_rate, pwr_status, offset;
+
 
 	SET_TX_DESC_PKT_SIZE_92E(pDesc, pkt_size);
-		
-	offset = TXDESC_SIZE + OFFSET_SZ;		
-	
+
+	offset = TXDESC_SIZE + OFFSET_SZ;
+
 	SET_TX_DESC_OFFSET_92E(pDesc, offset);
-	#if defined(CONFIG_PCI_HCI) /* 8192EE */
+#if defined(CONFIG_PCI_HCI) /* 8192EE */
 
 	SET_TX_DESC_PKT_OFFSET_92E(pDesc, 0); /* 8192EE pkt_offset is 0 */
-	#else /* 8192EU 8192ES */
+#else /* 8192EU 8192ES */
 	SET_TX_DESC_PKT_OFFSET_92E(pDesc, 1);
-	#endif
-		
-	if (bmcast) {
+#endif
+
+	if (bmcast)
 		SET_TX_DESC_BMC_92E(pDesc, 1);
-	}
-	
+
 	SET_TX_DESC_MACID_92E(pDesc, pattrib->mac_id);
 	SET_TX_DESC_RATE_ID_92E(pDesc, pattrib->raid);
-	
-	
+
+
 	SET_TX_DESC_QUEUE_SEL_92E(pDesc,  pattrib->qsel);
-	//SET_TX_DESC_QUEUE_SEL_8812(pDesc,  QSLT_MGNT);
-		
+	/* SET_TX_DESC_QUEUE_SEL_8812(pDesc,  QSLT_MGNT); */
+
 	if (!pattrib->qos_en) {
-		SET_TX_DESC_EN_HWSEQ_92E(pDesc, 1);// Hw set sequence number
+		SET_TX_DESC_EN_HWSEQ_92E(pDesc, 1);/* Hw set sequence number */
 		SET_TX_DESC_HWSEQ_SEL_92E(pDesc, pattrib->hw_ssn_sel);
-	} else {
+	} else
 		SET_TX_DESC_SEQ_92E(pDesc, pattrib->seqnum);
-	}
-		
-	if ((pmp_priv->bandwidth == CHANNEL_WIDTH_20) || (pmp_priv->bandwidth == CHANNEL_WIDTH_40)) {
+
+	if ((pmp_priv->bandwidth == CHANNEL_WIDTH_20) || (pmp_priv->bandwidth == CHANNEL_WIDTH_40))
 		SET_TX_DESC_DATA_BW_92E(pDesc, pmp_priv->bandwidth);
-	} else {
-		DBG_871X("%s:Err: unknown bandwidth %d, use 20M\n", __func__,pmp_priv->bandwidth);
+	else {
+		RTW_INFO("%s:Err: unknown bandwidth %d, use 20M\n", __func__, pmp_priv->bandwidth);
 		SET_TX_DESC_DATA_BW_92E(pDesc, CHANNEL_WIDTH_20);
 	}
-	
-	//SET_TX_DESC_DATA_SC_92E(pDesc, SCMapping_92E(padapter,pattrib));
-	
+
+	/* SET_TX_DESC_DATA_SC_92E(pDesc, SCMapping_92E(padapter,pattrib)); */
+
 	SET_TX_DESC_DISABLE_FB_92E(pDesc, 1);
 	SET_TX_DESC_USE_RATE_92E(pDesc, 1);
 	SET_TX_DESC_TX_RATE_92E(pDesc, pmp_priv->rateidx);
@@ -1551,9 +1679,8 @@ void fill_tx_desc_8723b(PADAPTER padapter)
 			SET_TX_DESC_DATA_SHORT_8723B(ptxdesc, 1);
 	}
 
-	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40) {
+	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
 		SET_TX_DESC_DATA_BW_8723B(ptxdesc, 1);
-	}
 
 	SET_TX_DESC_TX_RATE_8723B(ptxdesc, pmp_priv->rateidx);
 
@@ -1563,7 +1690,7 @@ void fill_tx_desc_8723b(PADAPTER padapter)
 #endif
 
 #if defined(CONFIG_RTL8703B)
-void fill_tx_desc_8703b(PADAPTER padapter) 
+void fill_tx_desc_8703b(PADAPTER padapter)
 {
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
@@ -1615,7 +1742,7 @@ void fill_tx_desc_8188f(PADAPTER padapter)
 		if (HwRateToMPTRate(pmp_priv->rateidx) <=  MPT_RATE_54M)
 			SET_TX_DESC_DATA_SHORT_8188F(ptxdesc, 1);
 
-	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40) 
+	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
 		SET_TX_DESC_DATA_BW_8188F(ptxdesc, 1);
 
 	SET_TX_DESC_TX_RATE_8188F(ptxdesc, pmp_priv->rateidx);
@@ -1625,25 +1752,88 @@ void fill_tx_desc_8188f(PADAPTER padapter)
 }
 #endif
 
+#if defined(CONFIG_RTL8188GTV)
+void fill_tx_desc_8188gtv(PADAPTER padapter)
+{
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
+	u8 *ptxdesc = pmp_priv->tx.desc;
+
+	SET_TX_DESC_AGG_BREAK_8188GTV(ptxdesc, 1);
+	SET_TX_DESC_MACID_8188GTV(ptxdesc, pattrib->mac_id);
+	SET_TX_DESC_QUEUE_SEL_8188GTV(ptxdesc, pattrib->qsel);
+
+	SET_TX_DESC_RATE_ID_8188GTV(ptxdesc, pattrib->raid);
+	SET_TX_DESC_SEQ_8188GTV(ptxdesc, pattrib->seqnum);
+	SET_TX_DESC_HWSEQ_EN_8188GTV(ptxdesc, 1);
+	SET_TX_DESC_USE_RATE_8188GTV(ptxdesc, 1);
+	SET_TX_DESC_DISABLE_FB_8188GTV(ptxdesc, 1);
+
+	if (pmp_priv->preamble)
+		if (HwRateToMPTRate(pmp_priv->rateidx) <=  MPT_RATE_54M)
+			SET_TX_DESC_DATA_SHORT_8188GTV(ptxdesc, 1);
+
+	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
+		SET_TX_DESC_DATA_BW_8188GTV(ptxdesc, 1);
+
+	SET_TX_DESC_TX_RATE_8188GTV(ptxdesc, pmp_priv->rateidx);
+
+	SET_TX_DESC_DATA_RATE_FB_LIMIT_8188GTV(ptxdesc, 0x1F);
+	SET_TX_DESC_RTS_RATE_FB_LIMIT_8188GTV(ptxdesc, 0xF);
+}
+#endif
+
+#if defined(CONFIG_RTL8723D)
+void fill_tx_desc_8723d(PADAPTER padapter)
+{
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
+	u8 *ptxdesc = pmp_priv->tx.desc;
+
+	SET_TX_DESC_BK_8723D(ptxdesc, 1);
+	SET_TX_DESC_MACID_8723D(ptxdesc, pattrib->mac_id);
+	SET_TX_DESC_QUEUE_SEL_8723D(ptxdesc, pattrib->qsel);
+
+	SET_TX_DESC_RATE_ID_8723D(ptxdesc, pattrib->raid);
+	SET_TX_DESC_SEQ_8723D(ptxdesc, pattrib->seqnum);
+	SET_TX_DESC_HWSEQ_EN_8723D(ptxdesc, 1);
+	SET_TX_DESC_USE_RATE_8723D(ptxdesc, 1);
+	SET_TX_DESC_DISABLE_FB_8723D(ptxdesc, 1);
+
+	if (pmp_priv->preamble) {
+		if (HwRateToMPTRate(pmp_priv->rateidx) <=  MPT_RATE_54M)
+			SET_TX_DESC_DATA_SHORT_8723D(ptxdesc, 1);
+	}
+
+	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
+		SET_TX_DESC_DATA_BW_8723D(ptxdesc, 1);
+
+	SET_TX_DESC_TX_RATE_8723D(ptxdesc, pmp_priv->rateidx);
+
+	SET_TX_DESC_DATA_RATE_FB_LIMIT_8723D(ptxdesc, 0x1F);
+	SET_TX_DESC_RTS_RATE_FB_LIMIT_8723D(ptxdesc, 0xF);
+}
+#endif
+
 static void Rtw_MPSetMacTxEDCA(PADAPTER padapter)
 {
 
-	rtw_write32(padapter, 0x508 , 0x00a422); //Disable EDCA BE Txop for MP pkt tx adjust Packet interval
-	//DBG_871X("%s:write 0x508~~~~~~ 0x%x\n", __func__,rtw_read32(padapter, 0x508));
-	PHY_SetMacReg(padapter, 0x458 ,bMaskDWord , 0x0);
-	//DBG_8192C("%s()!!!!! 0x460 = 0x%x\n" ,__func__,PHY_QueryBBReg(padapter, 0x460, bMaskDWord));
-	PHY_SetMacReg(padapter, 0x460 ,bMaskLWord , 0x0);//fast EDCA queue packet interval & time out vaule
-	//PHY_SetMacReg(padapter, ODM_EDCA_VO_PARAM ,bMaskLWord , 0x431C);
-	//PHY_SetMacReg(padapter, ODM_EDCA_BE_PARAM ,bMaskLWord , 0x431C);
-	//PHY_SetMacReg(padapter, ODM_EDCA_BK_PARAM ,bMaskLWord , 0x431C);
-	DBG_8192C("%s()!!!!! 0x460 = 0x%x\n" ,__func__,PHY_QueryBBReg(padapter, 0x460, bMaskDWord));
+	rtw_write32(padapter, 0x508 , 0x00a422); /* Disable EDCA BE Txop for MP pkt tx adjust Packet interval */
+	/* RTW_INFO("%s:write 0x508~~~~~~ 0x%x\n", __func__,rtw_read32(padapter, 0x508)); */
+	phy_set_mac_reg(padapter, 0x458 , bMaskDWord , 0x0);
+	/*RTW_INFO("%s()!!!!! 0x460 = 0x%x\n" ,__func__, phy_query_bb_reg(padapter, 0x460, bMaskDWord));*/
+	phy_set_mac_reg(padapter, 0x460 , bMaskLWord , 0x0); /* fast EDCA queue packet interval & time out value*/
+	/*phy_set_mac_reg(padapter, ODM_EDCA_VO_PARAM ,bMaskLWord , 0x431C);*/
+	/*phy_set_mac_reg(padapter, ODM_EDCA_BE_PARAM ,bMaskLWord , 0x431C);*/
+	/*phy_set_mac_reg(padapter, ODM_EDCA_BK_PARAM ,bMaskLWord , 0x431C);*/
+	RTW_INFO("%s()!!!!! 0x460 = 0x%x\n" , __func__, phy_query_bb_reg(padapter, 0x460, bMaskDWord));
 
 }
 
 void SetPacketTx(PADAPTER padapter)
 {
-	u8 *ptr, *pkt_start, *pkt_end,*fctrl;
-	u32 pkt_size,offset,startPlace,i;
+	u8 *ptr, *pkt_start, *pkt_end, *fctrl;
+	u32 pkt_size, offset, startPlace, i;
 	struct rtw_ieee80211_hdr *hdr;
 	u8 payload;
 	s32 bmcast;
@@ -1651,30 +1841,30 @@ void SetPacketTx(PADAPTER padapter)
 	struct mp_priv *pmp_priv;
 
 	pmp_priv = &padapter->mppriv;
-	
-	if (pmp_priv->tx.stop) return;
+
+	if (pmp_priv->tx.stop)
+		return;
 	pmp_priv->tx.sended = 0;
 	pmp_priv->tx.stop = 0;
 	pmp_priv->tx_pktcount = 0;
 
-	//3 1. update_attrib()
+	/* 3 1. update_attrib() */
 	pattrib = &pmp_priv->tx.attrib;
 	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
 	_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 	bmcast = IS_MCAST(pattrib->ra);
-	if (bmcast) {
-		pattrib->mac_id = 1;
+	if (bmcast) 
 		pattrib->psta = rtw_get_bcmc_stainfo(padapter);
-	} else {
-		pattrib->mac_id = 0;
+	else
 		pattrib->psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
-	}
+
+	pattrib->mac_id = pattrib->psta->cmn.mac_id;
 	pattrib->mbssid = 0;
-	
+
 	pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->pktlen;
 
-	//3 2. allocate xmit buffer
+	/* 3 2. allocate xmit buffer */
 	pkt_size = pattrib->last_txcmdsz;
 
 	if (pmp_priv->tx.pallocated_buf)
@@ -1683,7 +1873,7 @@ void SetPacketTx(PADAPTER padapter)
 	pmp_priv->tx.buf_size = pkt_size + XMITBUF_ALIGN_SZ;
 	pmp_priv->tx.pallocated_buf = rtw_zmalloc(pmp_priv->tx.buf_size);
 	if (pmp_priv->tx.pallocated_buf == NULL) {
-		DBG_871X("%s: malloc(%d) fail!!\n", __func__, pmp_priv->tx.buf_size);
+		RTW_INFO("%s: malloc(%d) fail!!\n", __func__, pmp_priv->tx.buf_size);
 		return;
 	}
 	pmp_priv->tx.buf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pmp_priv->tx.pallocated_buf), XMITBUF_ALIGN_SZ);
@@ -1693,101 +1883,121 @@ void SetPacketTx(PADAPTER padapter)
 	pkt_start = ptr;
 	pkt_end = pkt_start + pkt_size;
 
-	//3 3. init TX descriptor
+	/* 3 3. init TX descriptor */
 #if defined(CONFIG_RTL8188E)
-	if(IS_HARDWARE_TYPE_8188E(padapter))
+	if (IS_HARDWARE_TYPE_8188E(padapter))
 		fill_tx_desc_8188e(padapter);
 #endif
 
 #if defined(CONFIG_RTL8814A)
-	if(IS_HARDWARE_TYPE_8814A(padapter)) 
+	if (IS_HARDWARE_TYPE_8814A(padapter))
 		fill_tx_desc_8814a(padapter);
 #endif /* defined(CONFIG_RTL8814A) */
 
+#if defined(CONFIG_RTL8822B)
+	if (IS_HARDWARE_TYPE_8822B(padapter))
+		rtl8822b_prepare_mp_txdesc(padapter, pmp_priv);
+#endif /* CONFIG_RTL8822B */
+
+#if defined(CONFIG_RTL8821C)
+	if (IS_HARDWARE_TYPE_8821C(padapter))
+		rtl8821c_prepare_mp_txdesc(padapter, pmp_priv);
+#endif /* CONFIG_RTL8821C */
+
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-	if(IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter)) 
+	if (IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter))
 		fill_tx_desc_8812a(padapter);
 #endif
 
 #if defined(CONFIG_RTL8192E)
-	if(IS_HARDWARE_TYPE_8192E(padapter))
+	if (IS_HARDWARE_TYPE_8192E(padapter))
 		fill_tx_desc_8192e(padapter);
 #endif
 #if defined(CONFIG_RTL8723B)
-	if(IS_HARDWARE_TYPE_8723B(padapter))
+	if (IS_HARDWARE_TYPE_8723B(padapter))
 		fill_tx_desc_8723b(padapter);
 #endif
 #if defined(CONFIG_RTL8703B)
 	if (IS_HARDWARE_TYPE_8703B(padapter))
 		fill_tx_desc_8703b(padapter);
 #endif
-	
+
 #if defined(CONFIG_RTL8188F)
 	if (IS_HARDWARE_TYPE_8188F(padapter))
 		fill_tx_desc_8188f(padapter);
 #endif
 
-	//3 4. make wlan header, make_wlanhdr()
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(padapter))
+		fill_tx_desc_8188gtv(padapter);
+#endif
+
+#if defined(CONFIG_RTL8723D)
+	if (IS_HARDWARE_TYPE_8723D(padapter))
+		fill_tx_desc_8723d(padapter);
+#endif
+
+	/* 3 4. make wlan header, make_wlanhdr() */
 	hdr = (struct rtw_ieee80211_hdr *)pkt_start;
-	SetFrameSubType(&hdr->frame_ctl, pattrib->subtype);
-	//
-	SetFrDs(&hdr->frame_ctl);
-	_rtw_memcpy(hdr->addr1, pattrib->dst, ETH_ALEN); // DA
-	_rtw_memcpy(hdr->addr2, pattrib->src, ETH_ALEN); // SA
-	_rtw_memcpy(hdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN); // RA, BSSID
-
-	//3 5. make payload
+	set_frame_sub_type(&hdr->frame_ctl, pattrib->subtype);
+
+	_rtw_memcpy(hdr->addr1, pattrib->dst, ETH_ALEN); /* DA */
+	_rtw_memcpy(hdr->addr2, pattrib->src, ETH_ALEN); /* SA */
+	_rtw_memcpy(hdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN); /* RA, BSSID */
+
+	/* 3 5. make payload */
 	ptr = pkt_start + pattrib->hdrlen;
 
 	switch (pmp_priv->tx.payload) {
-		case 0:
-			payload = 0x00;
-			break;
-		case 1:
-			payload = 0x5a;
-			break;
-		case 2:
-			payload = 0xa5;
-			break;
-		case 3:
-			payload = 0xff;
-			break;
-		default:
-			payload = 0x00;
-			break;
+	case 0:
+		payload = 0x00;
+		break;
+	case 1:
+		payload = 0x5a;
+		break;
+	case 2:
+		payload = 0xa5;
+		break;
+	case 3:
+		payload = 0xff;
+		break;
+	default:
+		payload = 0x00;
+		break;
 	}
 	pmp_priv->TXradomBuffer = rtw_zmalloc(4096);
-	if(pmp_priv->TXradomBuffer == NULL)
-	{
-		DBG_871X("mp create random buffer fail!\n");
+	if (pmp_priv->TXradomBuffer == NULL) {
+		RTW_INFO("mp create random buffer fail!\n");
 		goto exit;
 	}
-	
-	
-	for(i=0;i<4096;i++)
-		pmp_priv->TXradomBuffer[i] = rtw_random32() %0xFF;
-	
-	//startPlace = (u32)(rtw_random32() % 3450);
-	_rtw_memcpy(ptr, pmp_priv->TXradomBuffer,pkt_end - ptr);
-	//_rtw_memset(ptr, payload, pkt_end - ptr);
-	rtw_mfree(pmp_priv->TXradomBuffer,4096);
-	
-	//3 6. start thread
+
+
+	for (i = 0; i < 4096; i++)
+		pmp_priv->TXradomBuffer[i] = rtw_random32() % 0xFF;
+
+	/* startPlace = (u32)(rtw_random32() % 3450); */
+	_rtw_memcpy(ptr, pmp_priv->TXradomBuffer, pkt_end - ptr);
+	/* _rtw_memset(ptr, payload, pkt_end - ptr); */
+	rtw_mfree(pmp_priv->TXradomBuffer, 4096);
+
+	/* 3 6. start thread */
 #ifdef PLATFORM_LINUX
 	pmp_priv->tx.PktTxThread = kthread_run(mp_xmit_packet_thread, pmp_priv, "RTW_MP_THREAD");
-	if (IS_ERR(pmp_priv->tx.PktTxThread))
-		DBG_871X("Create PktTx Thread Fail !!!!!\n");
+	if (IS_ERR(pmp_priv->tx.PktTxThread)) {
+		RTW_ERR("Create PktTx Thread Fail !!!!!\n");
+		pmp_priv->tx.PktTxThread = NULL;
+	}
 #endif
 #ifdef PLATFORM_FREEBSD
-{
-	struct proc *p;
-	struct thread *td;
-	pmp_priv->tx.PktTxThread = kproc_kthread_add(mp_xmit_packet_thread, pmp_priv,
-					&p, &td, RFHIGHPID, 0, "MPXmitThread", "MPXmitThread");
+	{
+		struct proc *p;
+		struct thread *td;
+		pmp_priv->tx.PktTxThread = kproc_kthread_add(mp_xmit_packet_thread, pmp_priv,
+			&p, &td, RFHIGHPID, 0, "MPXmitThread", "MPXmitThread");
 
-	if (pmp_priv->tx.PktTxThread < 0)
-		DBG_871X("Create PktTx Thread Fail !!!!!\n");
-}
+		if (pmp_priv->tx.PktTxThread < 0)
+			RTW_INFO("Create PktTx Thread Fail !!!!!\n");
+	}
 #endif
 
 	Rtw_MPSetMacTxEDCA(padapter);
@@ -1797,50 +2007,49 @@ exit:
 
 void SetPacketRx(PADAPTER pAdapter, u8 bStartRx, u8 bAB)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
 	struct mp_priv *pmppriv = &pAdapter->mppriv;
-	u8	type;
-	type = _HW_STATE_AP_;
-	if(bStartRx)
-	{
+
+
+	if (bStartRx) {
 #ifdef CONFIG_RTL8723B
-		PHY_SetMacReg(pAdapter, 0xe70, BIT23|BIT22, 0x3);// Power on adc  (in RX_WAIT_CCA state)
-		write_bbreg(pAdapter, 0xa01, BIT0, bDisable);// improve Rx performance by jerry	
-#endif
-		if(	pmppriv->bSetRxBssid == _TRUE ){
-			//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_PHYST_RXFF;	 
-			pHalData->ReceiveConfig = RCR_AAP | RCR_APM | RCR_AM | RCR_AB |RCR_AMF | RCR_APP_ICV | RCR_AMF | RCR_HTC_LOC_CTRL | RCR_APP_MIC | RCR_APP_PHYST_RXFF  ;
-			pHalData->ReceiveConfig |= ACRC32; 
-			
-			DBG_8192C("%s , pmppriv->network_macaddr =%x %x %x %x %x %x\n",__func__,
-								pmppriv->network_macaddr[0],pmppriv->network_macaddr[1],pmppriv->network_macaddr[2],pmppriv->network_macaddr[3],pmppriv->network_macaddr[4],pmppriv->network_macaddr[5]);
-			//Set_MSR(pAdapter, WIFI_FW_AP_STATE);
-			//rtw_hal_set_hwreg(pAdapter, HW_VAR_BSSID, pmppriv->network_macaddr);
-			//rtw_hal_set_hwreg(pAdapter, HW_VAR_SET_OPMODE, (u8 *)(&type));
-		}
-		else
-		{
-		pHalData->ReceiveConfig = AAP | APM | AM | AB | APP_ICV | ADF | AMF | HTC_LOC_CTRL | APP_MIC | APP_PHYSTS;
-		pHalData->ReceiveConfig |= ACRC32;
-		rtw_write32(pAdapter, REG_RCR, pHalData->ReceiveConfig);
-		// Accept all data frames
-		rtw_write16(pAdapter, REG_RXFLTMAP2, 0xFFFF);
-		// Accept CRC error and destination address
+		phy_set_mac_reg(pAdapter, 0xe70, BIT23 | BIT22, 0x3); /* Power on adc  (in RX_WAIT_CCA state) */
+		write_bbreg(pAdapter, 0xa01, BIT0, bDisable);/* improve Rx performance by jerry	 */
+#endif
+		pHalData->ReceiveConfig = RCR_AAP | RCR_APM | RCR_AM | RCR_AMF | RCR_HTC_LOC_CTRL;
+		pHalData->ReceiveConfig |= RCR_ACRC32;
+		pHalData->ReceiveConfig |= RCR_APP_PHYST_RXFF | RCR_APP_ICV | RCR_APP_MIC;
+
+		if (pmppriv->bSetRxBssid == _TRUE) {
+			RTW_INFO("%s: pmppriv->network_macaddr=" MAC_FMT "\n", __func__,
+				 MAC_ARG(pmppriv->network_macaddr));
+			pHalData->ReceiveConfig = 0;
+			pHalData->ReceiveConfig |= RCR_CBSSID_DATA | RCR_CBSSID_BCN |RCR_APM | RCR_AM | RCR_AB |RCR_AMF;
+			pHalData->ReceiveConfig |= RCR_APP_PHYST_RXFF;
+
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+			write_bbreg(pAdapter, 0x550, BIT3, bEnable);
+#endif
+			rtw_write16(pAdapter, REG_RXFLTMAP0, 0xFFEF); /* REG_RXFLTMAP0 (RX Filter Map Group 0) */
+
+		} else {
+			pHalData->ReceiveConfig |= RCR_ADF;
+			/* Accept all data frames */
+			rtw_write16(pAdapter, REG_RXFLTMAP2, 0xFFFF);
 		}
-	}
-	else
-	{
+
+		if (bAB)
+			pHalData->ReceiveConfig |= RCR_AB;
+	} else {
 #ifdef CONFIG_RTL8723B
-		PHY_SetMacReg(pAdapter, 0xe70, BIT23|BIT22, 0x00);// Power off adc  (in RX_WAIT_CCA state)
-		write_bbreg(pAdapter, 0xa01, BIT0, bEnable);// improve Rx performance by jerry	
+		phy_set_mac_reg(pAdapter, 0xe70, BIT23 | BIT22, 0x00); /* Power off adc  (in RX_WAIT_CCA state)*/
+		write_bbreg(pAdapter, 0xa01, BIT0, bEnable);/* improve Rx performance by jerry	 */
 #endif
-		rtw_write32(pAdapter, REG_RCR, 0);
+		pHalData->ReceiveConfig = 0;
+		rtw_write16(pAdapter, REG_RXFLTMAP0, 0xFFFF); /* REG_RXFLTMAP0 (RX Filter Map Group 0) */
 	}
 
-	if (bAB)
-		rtw_write32(pAdapter, REG_RCR, rtw_read32(pAdapter, REG_RCR)|RCR_AB);
-	else
-		rtw_write32(pAdapter, REG_RCR, rtw_read32(pAdapter, REG_RCR)&(~RCR_AB));
+	rtw_write32(pAdapter, REG_RCR, pHalData->ReceiveConfig);
 }
 
 void ResetPhyRxPktCount(PADAPTER pAdapter)
@@ -1849,21 +2058,21 @@ void ResetPhyRxPktCount(PADAPTER pAdapter)
 
 	for (i = 0; i <= 0xF; i++) {
 		phyrx_set = 0;
-		phyrx_set |= _RXERR_RPT_SEL(i);	//select
-		phyrx_set |= RXERR_RPT_RST;	// set counter to zero
+		phyrx_set |= _RXERR_RPT_SEL(i);	/* select */
+		phyrx_set |= RXERR_RPT_RST;	/* set counter to zero */
 		rtw_write32(pAdapter, REG_RXERR_RPT, phyrx_set);
 	}
 }
 
 static u32 GetPhyRxPktCounts(PADAPTER pAdapter, u32 selbit)
 {
-	//selection
+	/* selection */
 	u32 phyrx_set = 0, count = 0;
 
 	phyrx_set = _RXERR_RPT_SEL(selbit & 0xF);
 	rtw_write32(pAdapter, REG_RXERR_RPT, phyrx_set);
 
-	//Read packet count
+	/* Read packet count */
 	count = rtw_read32(pAdapter, REG_RXERR_RPT) & RXERR_COUNTER_MASK;
 
 	return count;
@@ -1891,19 +2100,19 @@ u32 GetPhyRxPktCRC32Error(PADAPTER pAdapter)
 	return OFDM_cnt + CCK_cnt + HT_cnt;
 }
 
-//reg 0x808[9:0]: FFT data x
-//reg 0x808[22]:  0  -->  1  to get 1 FFT data y
-//reg 0x8B4[15:0]: FFT data y report
+/* reg 0x808[9:0]: FFT data x
+ * reg 0x808[22]:  0  -->  1  to get 1 FFT data y
+ * reg 0x8B4[15:0]: FFT data y report */
 static u32 rtw_GetPSDData(PADAPTER pAdapter, u32 point)
 {
-	u32 psd_val=0;
-	
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
+	u32 psd_val = 0;
+
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
 	u16 psd_reg = 0x910;
-	u16 psd_regL= 0xF44;
-#else	
+	u16 psd_regL = 0xF44;
+#else
 	u16 psd_reg = 0x808;
-	u16 psd_regL= 0x8B4;
+	u16 psd_regL = 0x8B4;
 #endif
 
 	psd_val = rtw_read32(pAdapter, psd_reg);
@@ -1919,7 +2128,11 @@ static u32 rtw_GetPSDData(PADAPTER pAdapter, u32 point)
 	rtw_mdelay_os(1);
 
 	psd_val = rtw_read32(pAdapter, psd_regL);
+#if defined(CONFIG_RTL8821C)
+	psd_val = (psd_val & 0x00FFFFFF) / 32;
+#else
 	psd_val &= 0x0000FFFF;
+#endif
 
 	return psd_val;
 }
@@ -1934,106 +2147,92 @@ static u32 rtw_GetPSDData(PADAPTER pAdapter, u32 point)
  */
 u32 mp_query_psd(PADAPTER pAdapter, u8 *data)
 {
-	u32 i, psd_pts=0, psd_start=0, psd_stop=0;
-	u32 psd_data=0;
+	u32 i, psd_pts = 0, psd_start = 0, psd_stop = 0;
+	u32 psd_data = 0;
 
 
 #ifdef PLATFORM_LINUX
 	if (!netif_running(pAdapter->pnetdev)) {
-		RT_TRACE(_module_mp_, _drv_warning_, ("mp_query_psd: Fail! interface not opened!\n"));
 		return 0;
 	}
 #endif
 
 	if (check_fwstate(&pAdapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
-		RT_TRACE(_module_mp_, _drv_warning_, ("mp_query_psd: Fail! not in MP mode!\n"));
 		return 0;
 	}
 
-	if (strlen(data) == 0) { //default value
+	if (strlen(data) == 0) { /* default value */
 		psd_pts = 128;
 		psd_start = 64;
-		psd_stop = 128;   
-	} else {
+		psd_stop = 128;
+	} else
 		sscanf(data, "pts=%d,start=%d,stop=%d", &psd_pts, &psd_start, &psd_stop);
-	}
-	
-	data[0]='\0';
+
+	data[0] = '\0';
 
 	i = psd_start;
-	while (i < psd_stop)
-	{
-		if (i >= psd_pts) {
-			psd_data = rtw_GetPSDData(pAdapter, i-psd_pts);
-		} else {
+	while (i < psd_stop) {
+		if (i >= psd_pts)
+			psd_data = rtw_GetPSDData(pAdapter, i - psd_pts);
+		else
 			psd_data = rtw_GetPSDData(pAdapter, i);
-		}
 		sprintf(data, "%s%x ", data, psd_data);
 		i++;
 	}
 
-	#ifdef CONFIG_LONG_DELAY_ISSUE
+#ifdef CONFIG_LONG_DELAY_ISSUE
 	rtw_msleep_os(100);
-	#else
+#else
 	rtw_mdelay_os(100);
-	#endif
+#endif
 
-	return strlen(data)+1;
+	return strlen(data) + 1;
 }
 
 
 #if 0
-void _rtw_mp_xmit_priv (struct xmit_priv *pxmitpriv)
+void _rtw_mp_xmit_priv(struct xmit_priv *pxmitpriv)
 {
-	   int i,res;
-	  _adapter *padapter = pxmitpriv->adapter;
-	struct xmit_frame	*pxmitframe = (struct xmit_frame*) pxmitpriv->pxmit_frame_buf;
+	int i, res;
+	_adapter *padapter = pxmitpriv->adapter;
+	struct xmit_frame	*pxmitframe = (struct xmit_frame *) pxmitpriv->pxmit_frame_buf;
 	struct xmit_buf *pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmitbuf;
-	
+
 	u32 max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
 	u32 num_xmit_extbuf = NR_XMIT_EXTBUFF;
-	if(padapter->registrypriv.mp_mode ==0)
-	{
+	if (padapter->registrypriv.mp_mode == 0) {
 		max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
 		num_xmit_extbuf = NR_XMIT_EXTBUFF;
-	}
-	else
-	{
-			max_xmit_extbuf_size = 6000;
-			num_xmit_extbuf = 8;
+	} else {
+		max_xmit_extbuf_size = 6000;
+		num_xmit_extbuf = 8;
 	}
 
 	pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
-	for(i=0; i<num_xmit_extbuf; i++)
-	{
-		rtw_os_xmit_resource_free(padapter, pxmitbuf,(max_xmit_extbuf_size + XMITBUF_ALIGN_SZ), _FALSE);
-		
+	for (i = 0; i < num_xmit_extbuf; i++) {
+		rtw_os_xmit_resource_free(padapter, pxmitbuf, (max_xmit_extbuf_size + XMITBUF_ALIGN_SZ), _FALSE);
+
 		pxmitbuf++;
 	}
 
-	if(pxmitpriv->pallocated_xmit_extbuf) {
+	if (pxmitpriv->pallocated_xmit_extbuf)
 		rtw_vmfree(pxmitpriv->pallocated_xmit_extbuf, num_xmit_extbuf * sizeof(struct xmit_buf) + 4);
-	}
 
-	if(padapter->registrypriv.mp_mode ==0)
-	{
-			max_xmit_extbuf_size = 6000;
-			num_xmit_extbuf = 8;
-	}
-	else
-	{
+	if (padapter->registrypriv.mp_mode == 0) {
+		max_xmit_extbuf_size = 6000;
+		num_xmit_extbuf = 8;
+	} else {
 		max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
 		num_xmit_extbuf = NR_XMIT_EXTBUFF;
 	}
-	
-	// Init xmit extension buff
+
+	/* Init xmit extension buff */
 	_rtw_init_queue(&pxmitpriv->free_xmit_extbuf_queue);
 
 	pxmitpriv->pallocated_xmit_extbuf = rtw_zvmalloc(num_xmit_extbuf * sizeof(struct xmit_buf) + 4);
-	
-	if (pxmitpriv->pallocated_xmit_extbuf  == NULL){
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("alloc xmit_extbuf fail!\n"));
-		res= _FAIL;
+
+	if (pxmitpriv->pallocated_xmit_extbuf  == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
@@ -2041,19 +2240,19 @@ void _rtw_mp_xmit_priv (struct xmit_priv *pxmitpriv)
 
 	pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
 
-	for (i = 0; i < num_xmit_extbuf; i++)
-	{
+	for (i = 0; i < num_xmit_extbuf; i++) {
 		_rtw_init_listhead(&pxmitbuf->list);
 
 		pxmitbuf->priv_data = NULL;
 		pxmitbuf->padapter = padapter;
 		pxmitbuf->buf_tag = XMITBUF_MGNT;
 
-		if((res=rtw_os_xmit_resource_alloc(padapter, pxmitbuf,max_xmit_extbuf_size + XMITBUF_ALIGN_SZ, _TRUE)) == _FAIL) {
-			res= _FAIL;
+		res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, max_xmit_extbuf_size + XMITBUF_ALIGN_SZ, _TRUE);
+		if (res == _FAIL) {
+			res = _FAIL;
 			goto exit;
 		}
-		
+
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 		pxmitbuf->phead = pxmitbuf->pbuf;
 		pxmitbuf->pend = pxmitbuf->pbuf + max_xmit_extbuf_size;
@@ -2062,11 +2261,11 @@ void _rtw_mp_xmit_priv (struct xmit_priv *pxmitpriv)
 #endif
 
 		rtw_list_insert_tail(&pxmitbuf->list, &(pxmitpriv->free_xmit_extbuf_queue.queue));
-		#ifdef DBG_XMIT_BUF_EXT
-		pxmitbuf->no=i;
-		#endif
+#ifdef DBG_XMIT_BUF_EXT
+		pxmitbuf->no = i;
+#endif
 		pxmitbuf++;
-		
+
 	}
 
 	pxmitpriv->free_xmit_extbuf_cnt = num_xmit_extbuf;
@@ -2076,645 +2275,528 @@ exit:
 }
 #endif
 
-
-ULONG getPowerDiffByRate8188E(
-	IN	PADAPTER	pAdapter,
-	IN	u1Byte		CurrChannel,
-	IN	ULONG		RfPath
-	)
-{
-	PMPT_CONTEXT			pMptCtx = &(pAdapter->mppriv.MptCtx);
-	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
-	ULONG	PwrGroup=0;
-	ULONG	TxPower=0, Limit=0;
-	ULONG	Pathmapping = (RfPath == ODM_RF_PATH_A?0:8);
-
-	switch(pHalData->EEPROMRegulatory)
-	{
-		case 0: // driver-defined maximum power offset for longer communication range
-				// refer to power by rate table
-			PwrGroup = 0;
-			Limit = 0xff;
-			break;
-		case 1: // Power-limit table-defined maximum power offset range 
-				// choosed by min(power by rate, power limit).
-			{
-				if(pHalData->pwrGroupCnt == 1)
-					PwrGroup = 0;
-				if(pHalData->pwrGroupCnt >= 3)
-				{
-					if(CurrChannel <= 3)
-						PwrGroup = 0;
-					else if(CurrChannel >= 4 && CurrChannel <= 9)
-						PwrGroup = 1;
-					else if(CurrChannel > 9)
-						PwrGroup = 2;
-						
-					if(pHalData->CurrentChannelBW == CHANNEL_WIDTH_20)
-						PwrGroup++;
-					else
-						PwrGroup+=4;
-				}
-				Limit = 0xff;
-			}
-			break;
-		case 2: // not support power offset by rate.
-				// don't increase any power diff
-			PwrGroup = 0;
-			Limit = 0;
-			break;
-		default:
-			PwrGroup = 0;
-			Limit = 0xff;
-			break;
-	}
-
-
-	{
-		switch(pMptCtx->MptRateIndex)
-		{
-			case MPT_RATE_1M:
-			case MPT_RATE_2M:
-			case MPT_RATE_55M:
-			case MPT_RATE_11M:
-				//CCK rates, don't add any tx power index.
-				//RT_DISP(FPHY, PHY_TXPWR,("CCK rates!\n"));
-				break;
-			case MPT_RATE_6M:	//0xe00 [31:0] = 18M,12M,09M,06M
-				TxPower += ((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0+Pathmapping])&0xff);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][0] = 0x%x, OFDM 6M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0], TxPower));
-				break;
-			case MPT_RATE_9M:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0+Pathmapping])&0xff00)>>8);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][0] = 0x%x, OFDM 9M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0], TxPower));
-				break;
-			case MPT_RATE_12M:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0+Pathmapping])&0xff0000)>>16);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][0] = 0x%x, OFDM 12M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0], TxPower));
-				break;
-			case MPT_RATE_18M:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0+Pathmapping])&0xff000000)>>24);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][0] = 0x%x, OFDM 24M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][0], TxPower));
-				break;
-			case MPT_RATE_24M:	//0xe04[31:0] = 54M,48M,36M,24M
-				TxPower += ((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1+Pathmapping])&0xff);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][1] = 0x%x, OFDM 24M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1], TxPower));
-				break;
-			case MPT_RATE_36M:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1+Pathmapping])&0xff00)>>8);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][1] = 0x%x, OFDM 36M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1], TxPower));
-				break;
-			case MPT_RATE_48M:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1+Pathmapping])&0xff0000)>>16);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][1] = 0x%x, OFDM 48M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1], TxPower));
-				break;
-			case MPT_RATE_54M:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1+Pathmapping])&0xff000000)>>24);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][1] = 0x%x, OFDM 54M, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][1], TxPower));
-				break;
-			case MPT_RATE_MCS0: //0xe10[31:0]= MCS=03,02,01,00
-				TxPower += ((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2+Pathmapping])&0xff);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][2] = 0x%x, MCS0, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2], TxPower));
-				break;
-			case MPT_RATE_MCS1:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2+Pathmapping])&0xff00)>>8);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][2] = 0x%x, MCS1, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2], TxPower));
-				break;
-			case MPT_RATE_MCS2:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2+Pathmapping])&0xff0000)>>16);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][2] = 0x%x, MCS2, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2], TxPower));
-				break;
-			case MPT_RATE_MCS3:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2+Pathmapping])&0xff000000)>>24);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][2] = 0x%x, MCS3, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][2], TxPower));
-				break;
-			case MPT_RATE_MCS4: //0xe14[31:0]= MCS=07,06,05,04
-				TxPower += ((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3+Pathmapping])&0xff);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][3] = 0x%x, MCS4, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3], TxPower));
-				break;
-			case MPT_RATE_MCS5:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3+Pathmapping])&0xff00)>>8);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][3] = 0x%x, MCS5, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3], TxPower));
-				break;
-			case MPT_RATE_MCS6:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3+Pathmapping])&0xff0000)>>16);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][3] = 0x%x, MCS6, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3], TxPower));
-				break;
-			case MPT_RATE_MCS7:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3+Pathmapping])&0xff000000)>>24);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][3] = 0x%x, MCS7, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][3], TxPower));
-				break;
-				
-			case MPT_RATE_MCS8: //0xe18[31:0]= MCS=11,10,09,08
-				TxPower += ((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4+Pathmapping])&0xff);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][4] = 0x%x, MCS8, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4], TxPower));
-				break;
-			case MPT_RATE_MCS9:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4+Pathmapping])&0xff00)>>8);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][4] = 0x%x, MCS9, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4], TxPower));
-				break;
-			case MPT_RATE_MCS10:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4+Pathmapping])&0xff0000)>>16);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][4] = 0x%x, MCS10, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4], TxPower));
-				break;
-			case MPT_RATE_MCS11:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4+Pathmapping])&0xff000000)>>24);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][4] = 0x%x, MCS11, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][4], TxPower));
-				break;
-			case MPT_RATE_MCS12:	//0xe1c[31:0]= MCS=15,14,13,12
-				TxPower += ((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5+Pathmapping])&0xff);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][5] = 0x%x, MCS12, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5], TxPower));
-				break;
-			case MPT_RATE_MCS13:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5+Pathmapping])&0xff00)>>8);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][5] = 0x%x, MCS13, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5], TxPower));
-				break;
-			case MPT_RATE_MCS14:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5+Pathmapping])&0xff0000)>>16);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][5] = 0x%x, MCS14, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5], TxPower));
-				break;
-			case MPT_RATE_MCS15:
-				TxPower += (((pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5+Pathmapping])&0xff000000)>>24);
-				//RT_DISP(FPHY, PHY_TXPWR,("MCSTxPowerLevelOriginalOffset[%d][5] = 0x%x, MCS15, TxPower = %d\n", 
-				//	PwrGroup, pHalData->MCSTxPowerLevelOriginalOffset[PwrGroup][5], TxPower));
-				break;
-			default:
-				break;
-		}
-	}
-
-	if(TxPower > Limit)
-		TxPower = Limit;
-
-	return TxPower;
-}
-
-
-
-static	ULONG
-mpt_ProQueryCalTxPower_8188E(
-	IN	PADAPTER		pAdapter,
-	IN	u1Byte			RfPath	
-	)
+u8
+mpt_to_mgnt_rate(
+	IN	ULONG	MptRateIdx
+)
 {
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(pAdapter);
-	u1Byte				TxCount=TX_1S, i = 0;	//default set to 1S
-	//PMGNT_INFO			pMgntInfo = &(pAdapter->MgntInfo); 
-	ULONG				TxPower = 1, PwrGroup=0, PowerDiffByRate=0;
-	ULONG				TxPowerCCK = 1, TxPowerOFDM = 1, TxPowerBW20 = 1, TxPowerBW40 = 1 ; 
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u1Byte				CurrChannel = pHalData->CurrentChannel;
-	u1Byte				index = (CurrChannel -1);	
-	u1Byte				rf_path=(RfPath), rfPath;
-	u1Byte				limit = 0, rate = 0;
-
-	if(HAL_IsLegalChannel(pAdapter, CurrChannel) == FALSE)
-	{
-		CurrChannel = 1;
-	}	
-	
-	if(pMptCtx->MptRateIndex <= MPT_RATE_11M )
-	{
-		TxPower = pHalData->Index24G_CCK_Base[rf_path][index];	
-	}
-	else if(pMptCtx->MptRateIndex >= MPT_RATE_6M &&
-		pMptCtx->MptRateIndex <= MPT_RATE_54M )
-	{				
-		TxPower = pHalData->Index24G_BW40_Base[rf_path][index];
-	}
-	else if(pMptCtx->MptRateIndex >= MPT_RATE_MCS0 &&
-		pMptCtx->MptRateIndex <= MPT_RATE_MCS7 )
-	{
-		TxPower = pHalData->Index24G_BW40_Base[rf_path][index];
-	}
-	
-	//RT_DISP(FPHY, PHY_TXPWR, ("HT40 rate(%d) Tx power(RF-%c) = 0x%x\n", pMptCtx->MptRateIndex, ((rf_path==0)?'A':'B'), TxPower));
-
-
-	if(pMptCtx->MptRateIndex >= MPT_RATE_6M &&
-		pMptCtx->MptRateIndex <= MPT_RATE_54M )
-	{
-		TxPower += pHalData->OFDM_24G_Diff[rf_path][TxCount];
-		///RT_DISP(FPHY, PHY_TXPWR, ("+OFDM_PowerDiff(RF-%c) = 0x%x\n", ((rf_path==0)?'A':'B'), 
-		//	pHalData->OFDM_24G_Diff[rf_path][TxCount]));
-	}
-
-	if(pMptCtx->MptRateIndex >= MPT_RATE_MCS0)
-	{
-		if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_20)
-		{
-			TxPower += pHalData->BW20_24G_Diff[rf_path][TxCount];
-		//	RT_DISP(FPHY, PHY_TXPWR, ("+HT20_PowerDiff(RF-%c) = 0x%x\n", ((rf_path==0)?'A':'B'), 
-		//		pHalData->BW20_24G_Diff[rf_path][TxCount]));
-		}
-	}
-
-
-#ifdef ENABLE_POWER_BY_RATE
-	PowerDiffByRate = getPowerDiffByRate8188E(pAdapter, CurrChannel, RfPath);
-#else	
-	PowerDiffByRate = 0;
-#endif
-
-	// 2012/11/02 Awk: add power limit mechansim
-	if( pMptCtx->MptRateIndex <= MPT_RATE_11M )
-	{
-		rate = MGN_1M;
+	/* Mapped to MGN_XXX defined in MgntGen.h */
+	switch (MptRateIdx) {
+	/* CCK rate. */
+	case	MPT_RATE_1M:
+		return MGN_1M;
+	case	MPT_RATE_2M:
+		return MGN_2M;
+	case	MPT_RATE_55M:
+		return MGN_5_5M;
+	case	MPT_RATE_11M:
+		return MGN_11M;
+
+	/* OFDM rate. */
+	case	MPT_RATE_6M:
+		return MGN_6M;
+	case	MPT_RATE_9M:
+		return MGN_9M;
+	case	MPT_RATE_12M:
+		return MGN_12M;
+	case	MPT_RATE_18M:
+		return MGN_18M;
+	case	MPT_RATE_24M:
+		return MGN_24M;
+	case	MPT_RATE_36M:
+		return MGN_36M;
+	case	MPT_RATE_48M:
+		return MGN_48M;
+	case	MPT_RATE_54M:
+		return MGN_54M;
+
+	/* HT rate. */
+	case	MPT_RATE_MCS0:
+		return MGN_MCS0;
+	case	MPT_RATE_MCS1:
+		return MGN_MCS1;
+	case	MPT_RATE_MCS2:
+		return MGN_MCS2;
+	case	MPT_RATE_MCS3:
+		return MGN_MCS3;
+	case	MPT_RATE_MCS4:
+		return MGN_MCS4;
+	case	MPT_RATE_MCS5:
+		return MGN_MCS5;
+	case	MPT_RATE_MCS6:
+		return MGN_MCS6;
+	case	MPT_RATE_MCS7:
+		return MGN_MCS7;
+	case	MPT_RATE_MCS8:
+		return MGN_MCS8;
+	case	MPT_RATE_MCS9:
+		return MGN_MCS9;
+	case	MPT_RATE_MCS10:
+		return MGN_MCS10;
+	case	MPT_RATE_MCS11:
+		return MGN_MCS11;
+	case	MPT_RATE_MCS12:
+		return MGN_MCS12;
+	case	MPT_RATE_MCS13:
+		return MGN_MCS13;
+	case	MPT_RATE_MCS14:
+		return MGN_MCS14;
+	case	MPT_RATE_MCS15:
+		return MGN_MCS15;
+	case	MPT_RATE_MCS16:
+		return MGN_MCS16;
+	case	MPT_RATE_MCS17:
+		return MGN_MCS17;
+	case	MPT_RATE_MCS18:
+		return MGN_MCS18;
+	case	MPT_RATE_MCS19:
+		return MGN_MCS19;
+	case	MPT_RATE_MCS20:
+		return MGN_MCS20;
+	case	MPT_RATE_MCS21:
+		return MGN_MCS21;
+	case	MPT_RATE_MCS22:
+		return MGN_MCS22;
+	case	MPT_RATE_MCS23:
+		return MGN_MCS23;
+	case	MPT_RATE_MCS24:
+		return MGN_MCS24;
+	case	MPT_RATE_MCS25:
+		return MGN_MCS25;
+	case	MPT_RATE_MCS26:
+		return MGN_MCS26;
+	case	MPT_RATE_MCS27:
+		return MGN_MCS27;
+	case	MPT_RATE_MCS28:
+		return MGN_MCS28;
+	case	MPT_RATE_MCS29:
+		return MGN_MCS29;
+	case	MPT_RATE_MCS30:
+		return MGN_MCS30;
+	case	MPT_RATE_MCS31:
+		return MGN_MCS31;
+
+	/* VHT rate. */
+	case	MPT_RATE_VHT1SS_MCS0:
+		return MGN_VHT1SS_MCS0;
+	case	MPT_RATE_VHT1SS_MCS1:
+		return MGN_VHT1SS_MCS1;
+	case	MPT_RATE_VHT1SS_MCS2:
+		return MGN_VHT1SS_MCS2;
+	case	MPT_RATE_VHT1SS_MCS3:
+		return MGN_VHT1SS_MCS3;
+	case	MPT_RATE_VHT1SS_MCS4:
+		return MGN_VHT1SS_MCS4;
+	case	MPT_RATE_VHT1SS_MCS5:
+		return MGN_VHT1SS_MCS5;
+	case	MPT_RATE_VHT1SS_MCS6:
+		return MGN_VHT1SS_MCS6;
+	case	MPT_RATE_VHT1SS_MCS7:
+		return MGN_VHT1SS_MCS7;
+	case	MPT_RATE_VHT1SS_MCS8:
+		return MGN_VHT1SS_MCS8;
+	case	MPT_RATE_VHT1SS_MCS9:
+		return MGN_VHT1SS_MCS9;
+	case	MPT_RATE_VHT2SS_MCS0:
+		return MGN_VHT2SS_MCS0;
+	case	MPT_RATE_VHT2SS_MCS1:
+		return MGN_VHT2SS_MCS1;
+	case	MPT_RATE_VHT2SS_MCS2:
+		return MGN_VHT2SS_MCS2;
+	case	MPT_RATE_VHT2SS_MCS3:
+		return MGN_VHT2SS_MCS3;
+	case	MPT_RATE_VHT2SS_MCS4:
+		return MGN_VHT2SS_MCS4;
+	case	MPT_RATE_VHT2SS_MCS5:
+		return MGN_VHT2SS_MCS5;
+	case	MPT_RATE_VHT2SS_MCS6:
+		return MGN_VHT2SS_MCS6;
+	case	MPT_RATE_VHT2SS_MCS7:
+		return MGN_VHT2SS_MCS7;
+	case	MPT_RATE_VHT2SS_MCS8:
+		return MGN_VHT2SS_MCS8;
+	case	MPT_RATE_VHT2SS_MCS9:
+		return MGN_VHT2SS_MCS9;
+	case	MPT_RATE_VHT3SS_MCS0:
+		return MGN_VHT3SS_MCS0;
+	case	MPT_RATE_VHT3SS_MCS1:
+		return MGN_VHT3SS_MCS1;
+	case	MPT_RATE_VHT3SS_MCS2:
+		return MGN_VHT3SS_MCS2;
+	case	MPT_RATE_VHT3SS_MCS3:
+		return MGN_VHT3SS_MCS3;
+	case	MPT_RATE_VHT3SS_MCS4:
+		return MGN_VHT3SS_MCS4;
+	case	MPT_RATE_VHT3SS_MCS5:
+		return MGN_VHT3SS_MCS5;
+	case	MPT_RATE_VHT3SS_MCS6:
+		return MGN_VHT3SS_MCS6;
+	case	MPT_RATE_VHT3SS_MCS7:
+		return MGN_VHT3SS_MCS7;
+	case	MPT_RATE_VHT3SS_MCS8:
+		return MGN_VHT3SS_MCS8;
+	case	MPT_RATE_VHT3SS_MCS9:
+		return MGN_VHT3SS_MCS9;
+	case	MPT_RATE_VHT4SS_MCS0:
+		return MGN_VHT4SS_MCS0;
+	case	MPT_RATE_VHT4SS_MCS1:
+		return MGN_VHT4SS_MCS1;
+	case	MPT_RATE_VHT4SS_MCS2:
+		return MGN_VHT4SS_MCS2;
+	case	MPT_RATE_VHT4SS_MCS3:
+		return MGN_VHT4SS_MCS3;
+	case	MPT_RATE_VHT4SS_MCS4:
+		return MGN_VHT4SS_MCS4;
+	case	MPT_RATE_VHT4SS_MCS5:
+		return MGN_VHT4SS_MCS5;
+	case	MPT_RATE_VHT4SS_MCS6:
+		return MGN_VHT4SS_MCS6;
+	case	MPT_RATE_VHT4SS_MCS7:
+		return MGN_VHT4SS_MCS7;
+	case	MPT_RATE_VHT4SS_MCS8:
+		return MGN_VHT4SS_MCS8;
+	case	MPT_RATE_VHT4SS_MCS9:
+		return MGN_VHT4SS_MCS9;
+
+	case	MPT_RATE_LAST:	/* fully automatiMGN_VHT2SS_MCS1;	 */
+	default:
+		RTW_INFO("<===mpt_to_mgnt_rate(), Invalid Rate: %d!!\n", MptRateIdx);
+		return 0x0;
 	}
-	else if(pMptCtx->MptRateIndex >= MPT_RATE_6M &&
-		pMptCtx->MptRateIndex <= MPT_RATE_54M )
-	{				
-		rate = MGN_54M;
-	}
-	else if(pMptCtx->MptRateIndex >= MPT_RATE_MCS0 &&
-		pMptCtx->MptRateIndex <= MPT_RATE_MCS7 )
-	{
-		rate = MGN_MCS7;
-	}
-
-	limit = (u8)PHY_GetTxPowerLimit(pAdapter, pMptCtx->RegTxPwrLimit, 
-								   pHalData->CurrentBandType, 
-								   pHalData->CurrentChannelBW,RfPath, 
-								   rate, CurrChannel);
-
-	//RT_DISP(FPHY, PHY_TXPWR, ("+PowerDiffByRate(RF-%c) = 0x%x\n", ((rf_path==0)?'A':'B'), 
-	//	PowerDiffByRate));
-	TxPower += PowerDiffByRate;
-	//RT_DISP(FPHY, PHY_TXPWR, ("PowerDiffByRate limit value(RF-%c) = %d\n", ((rf_path==0)?'A':'B'), 
-	//	limit));
-
-	TxPower +=  limit > (s8) PowerDiffByRate ? PowerDiffByRate : limit;
-
-	return TxPower; 
 }
 
 
-u8 
-MptToMgntRate(
-	IN	ULONG	MptRateIdx
-	)
-{
-// Mapped to MGN_XXX defined in MgntGen.h
-	switch (MptRateIdx) 
-	{
-		/* CCK rate. */
-		case	MPT_RATE_1M:			return MGN_1M;		
-		case	MPT_RATE_2M:			return MGN_2M;		
-		case	MPT_RATE_55M:			return MGN_5_5M;	
-		case	MPT_RATE_11M:			return MGN_11M; 	
-											   
-		/* OFDM rate. */					   
-		case	MPT_RATE_6M:			return MGN_6M; 
-		case	MPT_RATE_9M:			return MGN_9M; 
-		case	MPT_RATE_12M:			return MGN_12M;
-		case	MPT_RATE_18M:			return MGN_18M;
-		case	MPT_RATE_24M:			return MGN_24M; 	
-		case	MPT_RATE_36M:			return MGN_36M;
-		case	MPT_RATE_48M:			return MGN_48M;
-		case	MPT_RATE_54M:			return MGN_54M;
-											   
-		/* HT rate. */						   
-		case	MPT_RATE_MCS0:			return MGN_MCS0; 
-		case	MPT_RATE_MCS1:			return MGN_MCS1; 
-		case	MPT_RATE_MCS2:			return MGN_MCS2; 
-		case	MPT_RATE_MCS3:			return MGN_MCS3; 
-		case	MPT_RATE_MCS4:			return MGN_MCS4;	
-		case	MPT_RATE_MCS5:			return MGN_MCS5;	
-		case	MPT_RATE_MCS6:			return MGN_MCS6;	
-		case	MPT_RATE_MCS7:			return MGN_MCS7;	
-		case	MPT_RATE_MCS8:			return MGN_MCS8;	
-		case	MPT_RATE_MCS9:			return MGN_MCS9;	
-		case	MPT_RATE_MCS10: 		return MGN_MCS10;	
-		case	MPT_RATE_MCS11: 		return MGN_MCS11;	
-		case	MPT_RATE_MCS12: 		return MGN_MCS12;	
-		case	MPT_RATE_MCS13: 		return MGN_MCS13;	
-		case	MPT_RATE_MCS14: 		return MGN_MCS14;	
-		case	MPT_RATE_MCS15: 		return MGN_MCS15;	
-		case	MPT_RATE_MCS16: 		return MGN_MCS16;
-		case	MPT_RATE_MCS17: 		return MGN_MCS17;
-		case	MPT_RATE_MCS18: 		return MGN_MCS18;
-		case	MPT_RATE_MCS19: 		return MGN_MCS19;
-		case	MPT_RATE_MCS20: 		return MGN_MCS20;
-		case	MPT_RATE_MCS21: 		return MGN_MCS21;
-		case	MPT_RATE_MCS22: 		return MGN_MCS22;
-		case	MPT_RATE_MCS23: 		return MGN_MCS23;
-		case	MPT_RATE_MCS24: 		return MGN_MCS24;
-		case	MPT_RATE_MCS25: 		return MGN_MCS25;
-		case	MPT_RATE_MCS26: 		return MGN_MCS26;
-		case	MPT_RATE_MCS27: 		return MGN_MCS27;
-		case	MPT_RATE_MCS28: 		return MGN_MCS28;
-		case	MPT_RATE_MCS29: 		return MGN_MCS29;
-		case	MPT_RATE_MCS30: 		return MGN_MCS30;
-		case	MPT_RATE_MCS31: 		return MGN_MCS31;
-											   
-		/* VHT rate. */ 					   
-		case	MPT_RATE_VHT1SS_MCS0:	return MGN_VHT1SS_MCS0;
-		case	MPT_RATE_VHT1SS_MCS1:	return MGN_VHT1SS_MCS1;
-		case	MPT_RATE_VHT1SS_MCS2:	return MGN_VHT1SS_MCS2;
-		case	MPT_RATE_VHT1SS_MCS3:	return MGN_VHT1SS_MCS3;
-		case	MPT_RATE_VHT1SS_MCS4:	return MGN_VHT1SS_MCS4;
-		case	MPT_RATE_VHT1SS_MCS5:	return MGN_VHT1SS_MCS5;
-		case	MPT_RATE_VHT1SS_MCS6:	return MGN_VHT1SS_MCS6;
-		case	MPT_RATE_VHT1SS_MCS7:	return MGN_VHT1SS_MCS7;
-		case	MPT_RATE_VHT1SS_MCS8:	return MGN_VHT1SS_MCS8;
-		case	MPT_RATE_VHT1SS_MCS9:	return MGN_VHT1SS_MCS9;
-		case	MPT_RATE_VHT2SS_MCS0:	return MGN_VHT2SS_MCS0; 
-		case	MPT_RATE_VHT2SS_MCS1:	return MGN_VHT2SS_MCS1; 
-		case	MPT_RATE_VHT2SS_MCS2:	return MGN_VHT2SS_MCS2; 
-		case	MPT_RATE_VHT2SS_MCS3:	return MGN_VHT2SS_MCS3; 
-		case	MPT_RATE_VHT2SS_MCS4:	return MGN_VHT2SS_MCS4; 
-		case	MPT_RATE_VHT2SS_MCS5:	return MGN_VHT2SS_MCS5; 
-		case	MPT_RATE_VHT2SS_MCS6:	return MGN_VHT2SS_MCS6; 
-		case	MPT_RATE_VHT2SS_MCS7:	return MGN_VHT2SS_MCS7; 
-		case	MPT_RATE_VHT2SS_MCS8:	return MGN_VHT2SS_MCS8; 
-		case	MPT_RATE_VHT2SS_MCS9:	return MGN_VHT2SS_MCS9; 
-		case	MPT_RATE_VHT3SS_MCS0:	return MGN_VHT3SS_MCS0; 
-		case	MPT_RATE_VHT3SS_MCS1:	return MGN_VHT3SS_MCS1; 
-		case	MPT_RATE_VHT3SS_MCS2:	return MGN_VHT3SS_MCS2; 
-		case	MPT_RATE_VHT3SS_MCS3:	return MGN_VHT3SS_MCS3; 
-		case	MPT_RATE_VHT3SS_MCS4:	return MGN_VHT3SS_MCS4; 
-		case	MPT_RATE_VHT3SS_MCS5:	return MGN_VHT3SS_MCS5; 
-		case	MPT_RATE_VHT3SS_MCS6:	return MGN_VHT3SS_MCS6; 
-		case	MPT_RATE_VHT3SS_MCS7:	return MGN_VHT3SS_MCS7; 
-		case	MPT_RATE_VHT3SS_MCS8:	return MGN_VHT3SS_MCS8; 
-		case	MPT_RATE_VHT3SS_MCS9:	return MGN_VHT3SS_MCS9; 
-		case	MPT_RATE_VHT4SS_MCS0:	return MGN_VHT4SS_MCS0; 
-		case	MPT_RATE_VHT4SS_MCS1:	return MGN_VHT4SS_MCS1; 
-		case	MPT_RATE_VHT4SS_MCS2:	return MGN_VHT4SS_MCS2; 
-		case	MPT_RATE_VHT4SS_MCS3:	return MGN_VHT4SS_MCS3; 
-		case	MPT_RATE_VHT4SS_MCS4:	return MGN_VHT4SS_MCS4; 
-		case	MPT_RATE_VHT4SS_MCS5:	return MGN_VHT4SS_MCS5; 
-		case	MPT_RATE_VHT4SS_MCS6:	return MGN_VHT4SS_MCS6; 
-		case	MPT_RATE_VHT4SS_MCS7:	return MGN_VHT4SS_MCS7; 
-		case	MPT_RATE_VHT4SS_MCS8:	return MGN_VHT4SS_MCS8; 
-		case	MPT_RATE_VHT4SS_MCS9:	return MGN_VHT4SS_MCS9; 
-		
-		case	MPT_RATE_LAST:	// fully automatiMGN_VHT2SS_MCS1;	
-		default:					  
-			DBG_871X("<===MptToMgntRate(), Invalid Rate: %d!!\n", MptRateIdx);
-			return 0x0; 					   
-	}										   
-}											   
-
-
 u8 HwRateToMPTRate(u8 rate)
 {
 	u8	ret_rate = MGN_1M;
 
-		switch (rate) {
-		case DESC_RATE1M:
-			ret_rate = MPT_RATE_1M;		break;
-		case DESC_RATE2M:
-			ret_rate = MPT_RATE_2M;		break;
-		case DESC_RATE5_5M:
-			ret_rate = MPT_RATE_55M;	break;
-		case DESC_RATE11M:
-			ret_rate = MPT_RATE_11M;	break;
-		case DESC_RATE6M:
-			ret_rate = MPT_RATE_6M;		break;
-		case DESC_RATE9M:
-			ret_rate = MPT_RATE_9M;		break;
-		case DESC_RATE12M:
-			ret_rate = MPT_RATE_12M;	break;
-		case DESC_RATE18M:
-			ret_rate = MPT_RATE_18M;	break;
-		case DESC_RATE24M:
-			ret_rate = MPT_RATE_24M;	break;
-		case DESC_RATE36M:
-			ret_rate = MPT_RATE_36M;	break;
-		case DESC_RATE48M:
-			ret_rate = MPT_RATE_48M;	break;
-		case DESC_RATE54M:
-			ret_rate = MPT_RATE_54M;	break;
-		case DESC_RATEMCS0:
-			ret_rate = MPT_RATE_MCS0;	break;
-		case DESC_RATEMCS1:
-			ret_rate = MPT_RATE_MCS1;	break;
-		case DESC_RATEMCS2:
-			ret_rate = MPT_RATE_MCS2;	break;
-		case DESC_RATEMCS3:
-			ret_rate = MPT_RATE_MCS3;	break;
-		case DESC_RATEMCS4:
-			ret_rate = MPT_RATE_MCS4;	break;
-		case DESC_RATEMCS5:
-			ret_rate = MPT_RATE_MCS5;	break;
-		case DESC_RATEMCS6:
-			ret_rate = MPT_RATE_MCS6;	break;
-		case DESC_RATEMCS7:
-			ret_rate = MPT_RATE_MCS7;	break;
-		case DESC_RATEMCS8:
-			ret_rate = MPT_RATE_MCS8;	break;
-		case DESC_RATEMCS9:
-			ret_rate = MPT_RATE_MCS9;	break;
-		case DESC_RATEMCS10:
-			ret_rate = MPT_RATE_MCS10;	break;
-		case DESC_RATEMCS11:
-			ret_rate = MPT_RATE_MCS11;	break;
-		case DESC_RATEMCS12:
-			ret_rate = MPT_RATE_MCS12;	break;
-		case DESC_RATEMCS13:
-			ret_rate = MPT_RATE_MCS13;	break;
-		case DESC_RATEMCS14:
-			ret_rate = MPT_RATE_MCS14;	break;
-		case DESC_RATEMCS15:
-			ret_rate = MPT_RATE_MCS15;	break;
-		case DESC_RATEMCS16:
-			ret_rate = MPT_RATE_MCS16;	break;
-		case DESC_RATEMCS17:
-			ret_rate = MPT_RATE_MCS17;	break;
-		case DESC_RATEMCS18:
-			ret_rate = MPT_RATE_MCS18;	break;
-		case DESC_RATEMCS19:
-			ret_rate = MPT_RATE_MCS19;	break;
-		case DESC_RATEMCS20:
-			ret_rate = MPT_RATE_MCS20;	break;
-		case DESC_RATEMCS21:
-			ret_rate = MPT_RATE_MCS21;	break;
-		case DESC_RATEMCS22:
-			ret_rate = MPT_RATE_MCS22;	break;
-		case DESC_RATEMCS23:
-			ret_rate = MPT_RATE_MCS23;	break;
-		case DESC_RATEMCS24:
-			ret_rate = MPT_RATE_MCS24;	break;
-		case DESC_RATEMCS25:
-			ret_rate = MPT_RATE_MCS25;	break;
-		case DESC_RATEMCS26:
-			ret_rate = MPT_RATE_MCS26;	break;
-		case DESC_RATEMCS27:
-			ret_rate = MPT_RATE_MCS27;	break;
-		case DESC_RATEMCS28:
-			ret_rate = MPT_RATE_MCS28;	break;
-		case DESC_RATEMCS29:
-			ret_rate = MPT_RATE_MCS29;	break;
-		case DESC_RATEMCS30:
-			ret_rate = MPT_RATE_MCS30;	break;
-		case DESC_RATEMCS31:
-			ret_rate = MPT_RATE_MCS31;	break;
-		case DESC_RATEVHTSS1MCS0:
-			ret_rate = MPT_RATE_VHT1SS_MCS0;		break;
-		case DESC_RATEVHTSS1MCS1:
-			ret_rate = MPT_RATE_VHT1SS_MCS1;		break;
-		case DESC_RATEVHTSS1MCS2:
-			ret_rate = MPT_RATE_VHT1SS_MCS2;		break;
-		case DESC_RATEVHTSS1MCS3:
-			ret_rate = MPT_RATE_VHT1SS_MCS3;		break;
-		case DESC_RATEVHTSS1MCS4:
-			ret_rate = MPT_RATE_VHT1SS_MCS4;		break;
-		case DESC_RATEVHTSS1MCS5:
-			ret_rate = MPT_RATE_VHT1SS_MCS5;		break;
-		case DESC_RATEVHTSS1MCS6:
-			ret_rate = MPT_RATE_VHT1SS_MCS6;		break;
-		case DESC_RATEVHTSS1MCS7:
-			ret_rate = MPT_RATE_VHT1SS_MCS7;		break;
-		case DESC_RATEVHTSS1MCS8:
-			ret_rate = MPT_RATE_VHT1SS_MCS8;		break;
-		case DESC_RATEVHTSS1MCS9:
-			ret_rate = MPT_RATE_VHT1SS_MCS9;		break;
-		case DESC_RATEVHTSS2MCS0:
-			ret_rate = MPT_RATE_VHT2SS_MCS0;		break;
-		case DESC_RATEVHTSS2MCS1:
-			ret_rate = MPT_RATE_VHT2SS_MCS1;		break;
-		case DESC_RATEVHTSS2MCS2:
-			ret_rate = MPT_RATE_VHT2SS_MCS2;		break;
-		case DESC_RATEVHTSS2MCS3:
-			ret_rate = MPT_RATE_VHT2SS_MCS3;		break;
-		case DESC_RATEVHTSS2MCS4:
-			ret_rate = MPT_RATE_VHT2SS_MCS4;		break;
-		case DESC_RATEVHTSS2MCS5:
-			ret_rate = MPT_RATE_VHT2SS_MCS5;		break;
-		case DESC_RATEVHTSS2MCS6:
-			ret_rate = MPT_RATE_VHT2SS_MCS6;		break;
-		case DESC_RATEVHTSS2MCS7:
-			ret_rate = MPT_RATE_VHT2SS_MCS7;		break;
-		case DESC_RATEVHTSS2MCS8:
-			ret_rate = MPT_RATE_VHT2SS_MCS8;		break;
-		case DESC_RATEVHTSS2MCS9:
-			ret_rate = MPT_RATE_VHT2SS_MCS9;		break;
-		case DESC_RATEVHTSS3MCS0:
-			ret_rate = MPT_RATE_VHT3SS_MCS0;		break;
-		case DESC_RATEVHTSS3MCS1:
-			ret_rate = MPT_RATE_VHT3SS_MCS1;		break;
-		case DESC_RATEVHTSS3MCS2:
-			ret_rate = MPT_RATE_VHT3SS_MCS2;		break;
-		case DESC_RATEVHTSS3MCS3:
-			ret_rate = MPT_RATE_VHT3SS_MCS3;		break;
-		case DESC_RATEVHTSS3MCS4:
-			ret_rate = MPT_RATE_VHT3SS_MCS4;		break;
-		case DESC_RATEVHTSS3MCS5:
-			ret_rate = MPT_RATE_VHT3SS_MCS5;		break;
-		case DESC_RATEVHTSS3MCS6:
-			ret_rate = MPT_RATE_VHT3SS_MCS6;		break;
-		case DESC_RATEVHTSS3MCS7:
-			ret_rate = MPT_RATE_VHT3SS_MCS7;		break;
-		case DESC_RATEVHTSS3MCS8:
-			ret_rate = MPT_RATE_VHT3SS_MCS8;		break;
-		case DESC_RATEVHTSS3MCS9:
-			ret_rate = MPT_RATE_VHT3SS_MCS9;		break;
-		case DESC_RATEVHTSS4MCS0:
-			ret_rate = MPT_RATE_VHT4SS_MCS0;		break;
-		case DESC_RATEVHTSS4MCS1:
-			ret_rate = MPT_RATE_VHT4SS_MCS1;		break;
-		case DESC_RATEVHTSS4MCS2:
-			ret_rate = MPT_RATE_VHT4SS_MCS2;		break;
-		case DESC_RATEVHTSS4MCS3:
-			ret_rate = MPT_RATE_VHT4SS_MCS3;		break;
-		case DESC_RATEVHTSS4MCS4:
-			ret_rate = MPT_RATE_VHT4SS_MCS4;		break;
-		case DESC_RATEVHTSS4MCS5:
-			ret_rate = MPT_RATE_VHT4SS_MCS5;		break;
-		case DESC_RATEVHTSS4MCS6:
-			ret_rate = MPT_RATE_VHT4SS_MCS6;		break;
-		case DESC_RATEVHTSS4MCS7:
-			ret_rate = MPT_RATE_VHT4SS_MCS7;		break;
-		case DESC_RATEVHTSS4MCS8:
-			ret_rate = MPT_RATE_VHT4SS_MCS8;		break;
-		case DESC_RATEVHTSS4MCS9:
-			ret_rate = MPT_RATE_VHT4SS_MCS9;		break;
+	switch (rate) {
+	case DESC_RATE1M:
+		ret_rate = MPT_RATE_1M;
+		break;
+	case DESC_RATE2M:
+		ret_rate = MPT_RATE_2M;
+		break;
+	case DESC_RATE5_5M:
+		ret_rate = MPT_RATE_55M;
+		break;
+	case DESC_RATE11M:
+		ret_rate = MPT_RATE_11M;
+		break;
+	case DESC_RATE6M:
+		ret_rate = MPT_RATE_6M;
+		break;
+	case DESC_RATE9M:
+		ret_rate = MPT_RATE_9M;
+		break;
+	case DESC_RATE12M:
+		ret_rate = MPT_RATE_12M;
+		break;
+	case DESC_RATE18M:
+		ret_rate = MPT_RATE_18M;
+		break;
+	case DESC_RATE24M:
+		ret_rate = MPT_RATE_24M;
+		break;
+	case DESC_RATE36M:
+		ret_rate = MPT_RATE_36M;
+		break;
+	case DESC_RATE48M:
+		ret_rate = MPT_RATE_48M;
+		break;
+	case DESC_RATE54M:
+		ret_rate = MPT_RATE_54M;
+		break;
+	case DESC_RATEMCS0:
+		ret_rate = MPT_RATE_MCS0;
+		break;
+	case DESC_RATEMCS1:
+		ret_rate = MPT_RATE_MCS1;
+		break;
+	case DESC_RATEMCS2:
+		ret_rate = MPT_RATE_MCS2;
+		break;
+	case DESC_RATEMCS3:
+		ret_rate = MPT_RATE_MCS3;
+		break;
+	case DESC_RATEMCS4:
+		ret_rate = MPT_RATE_MCS4;
+		break;
+	case DESC_RATEMCS5:
+		ret_rate = MPT_RATE_MCS5;
+		break;
+	case DESC_RATEMCS6:
+		ret_rate = MPT_RATE_MCS6;
+		break;
+	case DESC_RATEMCS7:
+		ret_rate = MPT_RATE_MCS7;
+		break;
+	case DESC_RATEMCS8:
+		ret_rate = MPT_RATE_MCS8;
+		break;
+	case DESC_RATEMCS9:
+		ret_rate = MPT_RATE_MCS9;
+		break;
+	case DESC_RATEMCS10:
+		ret_rate = MPT_RATE_MCS10;
+		break;
+	case DESC_RATEMCS11:
+		ret_rate = MPT_RATE_MCS11;
+		break;
+	case DESC_RATEMCS12:
+		ret_rate = MPT_RATE_MCS12;
+		break;
+	case DESC_RATEMCS13:
+		ret_rate = MPT_RATE_MCS13;
+		break;
+	case DESC_RATEMCS14:
+		ret_rate = MPT_RATE_MCS14;
+		break;
+	case DESC_RATEMCS15:
+		ret_rate = MPT_RATE_MCS15;
+		break;
+	case DESC_RATEMCS16:
+		ret_rate = MPT_RATE_MCS16;
+		break;
+	case DESC_RATEMCS17:
+		ret_rate = MPT_RATE_MCS17;
+		break;
+	case DESC_RATEMCS18:
+		ret_rate = MPT_RATE_MCS18;
+		break;
+	case DESC_RATEMCS19:
+		ret_rate = MPT_RATE_MCS19;
+		break;
+	case DESC_RATEMCS20:
+		ret_rate = MPT_RATE_MCS20;
+		break;
+	case DESC_RATEMCS21:
+		ret_rate = MPT_RATE_MCS21;
+		break;
+	case DESC_RATEMCS22:
+		ret_rate = MPT_RATE_MCS22;
+		break;
+	case DESC_RATEMCS23:
+		ret_rate = MPT_RATE_MCS23;
+		break;
+	case DESC_RATEMCS24:
+		ret_rate = MPT_RATE_MCS24;
+		break;
+	case DESC_RATEMCS25:
+		ret_rate = MPT_RATE_MCS25;
+		break;
+	case DESC_RATEMCS26:
+		ret_rate = MPT_RATE_MCS26;
+		break;
+	case DESC_RATEMCS27:
+		ret_rate = MPT_RATE_MCS27;
+		break;
+	case DESC_RATEMCS28:
+		ret_rate = MPT_RATE_MCS28;
+		break;
+	case DESC_RATEMCS29:
+		ret_rate = MPT_RATE_MCS29;
+		break;
+	case DESC_RATEMCS30:
+		ret_rate = MPT_RATE_MCS30;
+		break;
+	case DESC_RATEMCS31:
+		ret_rate = MPT_RATE_MCS31;
+		break;
+	case DESC_RATEVHTSS1MCS0:
+		ret_rate = MPT_RATE_VHT1SS_MCS0;
+		break;
+	case DESC_RATEVHTSS1MCS1:
+		ret_rate = MPT_RATE_VHT1SS_MCS1;
+		break;
+	case DESC_RATEVHTSS1MCS2:
+		ret_rate = MPT_RATE_VHT1SS_MCS2;
+		break;
+	case DESC_RATEVHTSS1MCS3:
+		ret_rate = MPT_RATE_VHT1SS_MCS3;
+		break;
+	case DESC_RATEVHTSS1MCS4:
+		ret_rate = MPT_RATE_VHT1SS_MCS4;
+		break;
+	case DESC_RATEVHTSS1MCS5:
+		ret_rate = MPT_RATE_VHT1SS_MCS5;
+		break;
+	case DESC_RATEVHTSS1MCS6:
+		ret_rate = MPT_RATE_VHT1SS_MCS6;
+		break;
+	case DESC_RATEVHTSS1MCS7:
+		ret_rate = MPT_RATE_VHT1SS_MCS7;
+		break;
+	case DESC_RATEVHTSS1MCS8:
+		ret_rate = MPT_RATE_VHT1SS_MCS8;
+		break;
+	case DESC_RATEVHTSS1MCS9:
+		ret_rate = MPT_RATE_VHT1SS_MCS9;
+		break;
+	case DESC_RATEVHTSS2MCS0:
+		ret_rate = MPT_RATE_VHT2SS_MCS0;
+		break;
+	case DESC_RATEVHTSS2MCS1:
+		ret_rate = MPT_RATE_VHT2SS_MCS1;
+		break;
+	case DESC_RATEVHTSS2MCS2:
+		ret_rate = MPT_RATE_VHT2SS_MCS2;
+		break;
+	case DESC_RATEVHTSS2MCS3:
+		ret_rate = MPT_RATE_VHT2SS_MCS3;
+		break;
+	case DESC_RATEVHTSS2MCS4:
+		ret_rate = MPT_RATE_VHT2SS_MCS4;
+		break;
+	case DESC_RATEVHTSS2MCS5:
+		ret_rate = MPT_RATE_VHT2SS_MCS5;
+		break;
+	case DESC_RATEVHTSS2MCS6:
+		ret_rate = MPT_RATE_VHT2SS_MCS6;
+		break;
+	case DESC_RATEVHTSS2MCS7:
+		ret_rate = MPT_RATE_VHT2SS_MCS7;
+		break;
+	case DESC_RATEVHTSS2MCS8:
+		ret_rate = MPT_RATE_VHT2SS_MCS8;
+		break;
+	case DESC_RATEVHTSS2MCS9:
+		ret_rate = MPT_RATE_VHT2SS_MCS9;
+		break;
+	case DESC_RATEVHTSS3MCS0:
+		ret_rate = MPT_RATE_VHT3SS_MCS0;
+		break;
+	case DESC_RATEVHTSS3MCS1:
+		ret_rate = MPT_RATE_VHT3SS_MCS1;
+		break;
+	case DESC_RATEVHTSS3MCS2:
+		ret_rate = MPT_RATE_VHT3SS_MCS2;
+		break;
+	case DESC_RATEVHTSS3MCS3:
+		ret_rate = MPT_RATE_VHT3SS_MCS3;
+		break;
+	case DESC_RATEVHTSS3MCS4:
+		ret_rate = MPT_RATE_VHT3SS_MCS4;
+		break;
+	case DESC_RATEVHTSS3MCS5:
+		ret_rate = MPT_RATE_VHT3SS_MCS5;
+		break;
+	case DESC_RATEVHTSS3MCS6:
+		ret_rate = MPT_RATE_VHT3SS_MCS6;
+		break;
+	case DESC_RATEVHTSS3MCS7:
+		ret_rate = MPT_RATE_VHT3SS_MCS7;
+		break;
+	case DESC_RATEVHTSS3MCS8:
+		ret_rate = MPT_RATE_VHT3SS_MCS8;
+		break;
+	case DESC_RATEVHTSS3MCS9:
+		ret_rate = MPT_RATE_VHT3SS_MCS9;
+		break;
+	case DESC_RATEVHTSS4MCS0:
+		ret_rate = MPT_RATE_VHT4SS_MCS0;
+		break;
+	case DESC_RATEVHTSS4MCS1:
+		ret_rate = MPT_RATE_VHT4SS_MCS1;
+		break;
+	case DESC_RATEVHTSS4MCS2:
+		ret_rate = MPT_RATE_VHT4SS_MCS2;
+		break;
+	case DESC_RATEVHTSS4MCS3:
+		ret_rate = MPT_RATE_VHT4SS_MCS3;
+		break;
+	case DESC_RATEVHTSS4MCS4:
+		ret_rate = MPT_RATE_VHT4SS_MCS4;
+		break;
+	case DESC_RATEVHTSS4MCS5:
+		ret_rate = MPT_RATE_VHT4SS_MCS5;
+		break;
+	case DESC_RATEVHTSS4MCS6:
+		ret_rate = MPT_RATE_VHT4SS_MCS6;
+		break;
+	case DESC_RATEVHTSS4MCS7:
+		ret_rate = MPT_RATE_VHT4SS_MCS7;
+		break;
+	case DESC_RATEVHTSS4MCS8:
+		ret_rate = MPT_RATE_VHT4SS_MCS8;
+		break;
+	case DESC_RATEVHTSS4MCS9:
+		ret_rate = MPT_RATE_VHT4SS_MCS9;
+		break;
 
-		default:
-			DBG_871X("HwRateToMRate(): Non supported Rate [%x]!!!\n", rate);
-			break;
+	default:
+		RTW_INFO("hw_rate_to_m_rate(): Non supported Rate [%x]!!!\n", rate);
+		break;
 	}
 	return ret_rate;
 }
 
 u8 rtw_mpRateParseFunc(PADAPTER pAdapter, u8 *targetStr)
 {
-	u16 i=0;
- 	u8* rateindex_Array[] = { "1M","2M","5.5M","11M","6M","9M","12M","18M","24M","36M","48M","54M",
- 								"HTMCS0","HTMCS1","HTMCS2","HTMCS3","HTMCS4","HTMCS5","HTMCS6","HTMCS7",
- 								"HTMCS8","HTMCS9","HTMCS10","HTMCS11","HTMCS12","HTMCS13","HTMCS14","HTMCS15",
- 								"HTMCS16","HTMCS17","HTMCS18","HTMCS19","HTMCS20","HTMCS21","HTMCS22","HTMCS23",
- 								"HTMCS24","HTMCS25","HTMCS26","HTMCS27","HTMCS28","HTMCS29","HTMCS30","HTMCS31",
- 								"VHT1MCS0","VHT1MCS1","VHT1MCS2","VHT1MCS3","VHT1MCS4","VHT1MCS5","VHT1MCS6","VHT1MCS7","VHT1MCS8","VHT1MCS9",
- 								"VHT2MCS0","VHT2MCS1","VHT2MCS2","VHT2MCS3","VHT2MCS4","VHT2MCS5","VHT2MCS6","VHT2MCS7","VHT2MCS8","VHT2MCS9",
- 								"VHT3MCS0","VHT3MCS1","VHT3MCS2","VHT3MCS3","VHT3MCS4","VHT3MCS5","VHT3MCS6","VHT3MCS7","VHT3MCS8","VHT3MCS9",
- 								"VHT4MCS0","VHT4MCS1","VHT4MCS2","VHT4MCS3","VHT4MCS4","VHT4MCS5","VHT4MCS6","VHT4MCS7","VHT4MCS8","VHT4MCS9"};
-
-	for(i=0;i<=83;i++){	
-		if(strcmp(targetStr, rateindex_Array[i]) == 0){
-			DBG_871X("%s , index = %d \n",__func__ ,i);
+	u16 i = 0;
+	u8 *rateindex_Array[] = { "1M", "2M", "5.5M", "11M", "6M", "9M", "12M", "18M", "24M", "36M", "48M", "54M",
+		"HTMCS0", "HTMCS1", "HTMCS2", "HTMCS3", "HTMCS4", "HTMCS5", "HTMCS6", "HTMCS7",
+		"HTMCS8", "HTMCS9", "HTMCS10", "HTMCS11", "HTMCS12", "HTMCS13", "HTMCS14", "HTMCS15",
+		"HTMCS16", "HTMCS17", "HTMCS18", "HTMCS19", "HTMCS20", "HTMCS21", "HTMCS22", "HTMCS23",
+		"HTMCS24", "HTMCS25", "HTMCS26", "HTMCS27", "HTMCS28", "HTMCS29", "HTMCS30", "HTMCS31",
+		"VHT1MCS0", "VHT1MCS1", "VHT1MCS2", "VHT1MCS3", "VHT1MCS4", "VHT1MCS5", "VHT1MCS6", "VHT1MCS7", "VHT1MCS8", "VHT1MCS9",
+		"VHT2MCS0", "VHT2MCS1", "VHT2MCS2", "VHT2MCS3", "VHT2MCS4", "VHT2MCS5", "VHT2MCS6", "VHT2MCS7", "VHT2MCS8", "VHT2MCS9",
+		"VHT3MCS0", "VHT3MCS1", "VHT3MCS2", "VHT3MCS3", "VHT3MCS4", "VHT3MCS5", "VHT3MCS6", "VHT3MCS7", "VHT3MCS8", "VHT3MCS9",
+		"VHT4MCS0", "VHT4MCS1", "VHT4MCS2", "VHT4MCS3", "VHT4MCS4", "VHT4MCS5", "VHT4MCS6", "VHT4MCS7", "VHT4MCS8", "VHT4MCS9"
+				};
+
+	for (i = 0; i <= 83; i++) {
+		if (strcmp(targetStr, rateindex_Array[i]) == 0) {
+			RTW_INFO("%s , index = %d\n", __func__ , i);
 			return i;
 		}
 	}
-	
-	printk("%s ,please input a Data RATE String as:",__func__);
-	for(i=0;i<=83;i++){	
-		printk("%s ",rateindex_Array[i]);
-		if(i%10==0)
+
+	printk("%s ,please input a Data RATE String as:", __func__);
+	for (i = 0; i <= 83; i++) {
+		printk("%s ", rateindex_Array[i]);
+		if (i % 10 == 0)
 			printk("\n");
-	}	
+	}
 	return _FAIL;
 }
 
+u8 rtw_mp_mode_check(PADAPTER pAdapter)
+{
+	PADAPTER primary_adapter = GET_PRIMARY_ADAPTER(pAdapter);
+
+	if (primary_adapter->registrypriv.mp_mode == 1)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+
 ULONG mpt_ProQueryCalTxPower(
 	PADAPTER	pAdapter,
-		u8		RfPath
-	)
+	u8		RfPath
+)
 {
 
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
 
 	ULONG			TxPower = 1;
 	u1Byte			rate = 0;
 	struct txpwr_idx_comp tic;
-	u8 mgn_rate = MptToMgntRate(pMptCtx->MptRateIndex);
+	u8 mgn_rate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
 
-	TxPower = rtw_hal_get_tx_power_index(pAdapter, RfPath, mgn_rate, pHalData->CurrentChannelBW, pHalData->CurrentChannel, &tic);
+	TxPower = rtw_hal_get_tx_power_index(pAdapter, RfPath, mgn_rate, pHalData->current_channel_bw, pHalData->current_channel, &tic);
 
 	RTW_INFO("bw=%d, ch=%d, rate=%d, txPower:%u = %u + (%d=%d:%d) + (%d) + (%d)\n",
-		pHalData->CurrentChannelBW, pHalData->CurrentChannel, mgn_rate
+		pHalData->current_channel_bw, pHalData->current_channel, mgn_rate
 		, TxPower, tic.base, (tic.by_rate > tic.limit ? tic.limit : tic.by_rate), tic.by_rate, tic.limit, tic.tpt, tic.ebias);
 
 	pAdapter->mppriv.txpoweridx = (u8)TxPower;
-	pMptCtx->TxPwrLevel[ODM_RF_PATH_A] = (u8)TxPower;
-	pMptCtx->TxPwrLevel[ODM_RF_PATH_B] = (u8)TxPower;
-	pMptCtx->TxPwrLevel[ODM_RF_PATH_C] = (u8)TxPower;
-	pMptCtx->TxPwrLevel[ODM_RF_PATH_D]  = (u8)TxPower;
+	pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)TxPower;
+	pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)TxPower;
+	pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)TxPower;
+	pMptCtx->TxPwrLevel[RF_PATH_D]  = (u8)TxPower;
 	hal_mpt_SetTxPower(pAdapter);
 
 	return TxPower;
@@ -2725,10 +2807,10 @@ static inline void dump_buf(u8 *buf, u32 len)
 {
 	u32 i;
 
-	DBG_871X("-----------------Len %d----------------\n", len);
+	RTW_INFO("-----------------Len %d----------------\n", len);
 	for (i = 0; i < len; i++)
-		DBG_871X("%2.2x-", *(buf + i));
-	DBG_871X("\n");
+		RTW_INFO("%2.2x-", *(buf + i));
+	RTW_INFO("\n");
 }
 
 void ByteToBit(
@@ -2740,7 +2822,7 @@ void ByteToBit(
 
 	for (i = 0; i < in_size; i++) {
 		for (j = 0; j < 8; j++) {
-			if (in[8*i+j])
+			if (in[8 * i + j])
 				out[i] |= (1 << j);
 		}
 	}
@@ -2757,7 +2839,7 @@ void CRC16_generator(
 	bool temp = 0, reg[] = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
 
 	for (i = 0; i < in_size; i++) {/* take one's complement and bit reverse*/
-		temp = in[i]^reg[15];
+		temp = in[i] ^ reg[15];
 		reg[15]	= reg[14];
 		reg[14]	= reg[13];
 		reg[13]	= reg[12];
@@ -2779,7 +2861,7 @@ void CRC16_generator(
 		reg[0]	= temp;
 	}
 	for (i = 0; i < 16; i++)	/* take one's complement and bit reverse*/
-		out[i] = 1-reg[15-i];
+		out[i] = 1 - reg[15 - i];
 }
 
 
@@ -2791,7 +2873,7 @@ void CRC16_generator(
 void CCK_generator(
 	PRT_PMAC_TX_INFO	pPMacTxInfo,
 	PRT_PMAC_PKT_INFO	pPMacPktInfo
-	)
+)
 {
 	double	ratio = 0;
 	bool	crc16_in[32] = {0}, crc16_out[16] = {0};
@@ -2821,23 +2903,23 @@ void CCK_generator(
 		break;
 	case 2:
 		pPMacTxInfo->SignalField = 0x37;
-		ratio = 8.0/5.5;
+		ratio = 8.0 / 5.5;
 		/*CRC16_in(1,0:7)=[1 1 1 0 1 1 0 0];*/
 		crc16_in[0] = crc16_in[1] = crc16_in[2] = crc16_in[4] = crc16_in[5] = 1;
 		break;
 	case 3:
 		pPMacTxInfo->SignalField = 0x6E;
-		ratio = 8.0/11.0;
+		ratio = 8.0 / 11.0;
 		/*CRC16_in(1,0:7)=[0 1 1 1 0 1 1 0];*/
 		crc16_in[1] = crc16_in[2] = crc16_in[3] = crc16_in[5] = crc16_in[6] = 1;
 		break;
 	}
 
-	LengthExact = PacketLength*ratio;
+	LengthExact = PacketLength * ratio;
 	LengthPSDU = ceil(LengthExact);
 
 	if ((pPMacPktInfo->MCS == 3) &&
-		((LengthPSDU-LengthExact) >= 0.727 || (LengthPSDU-LengthExact) <= -0.727))
+	    ((LengthPSDU - LengthExact) >= 0.727 || (LengthPSDU - LengthExact) <= -0.727))
 		LengthExtBit = 1;
 	else
 		LengthExtBit = 0;
@@ -2846,7 +2928,7 @@ void CCK_generator(
 	pPMacTxInfo->LENGTH = (UINT)LengthPSDU;
 	/* CRC16_in(1,16:31) = LengthPSDU[0:15]*/
 	for (i = 0; i < 16; i++)
-		crc16_in[i+16] = (pPMacTxInfo->LENGTH >> i) & 0x1;
+		crc16_in[i + 16] = (pPMacTxInfo->LENGTH >> i) & 0x1;
 
 	if (LengthExtBit == 0) {
 		pPMacTxInfo->ServiceField = 0x0;
@@ -2883,19 +2965,23 @@ void PMAC_Get_Pkt_Param(
 	else
 		pPMacPktInfo->Nss = 1;
 
-	DBG_871X("PMacTxInfo.Nss =%d\n", pPMacPktInfo->Nss);
+	RTW_INFO("PMacTxInfo.Nss =%d\n", pPMacPktInfo->Nss);
 
 	/*	MCS & TX_RATE_HEX*/
 	if (MPT_IS_CCK_RATE(TX_RATE)) {
 		switch (TX_RATE) {
 		case MPT_RATE_1M:
-			TX_RATE_HEX = MCS = 0; break;
+			TX_RATE_HEX = MCS = 0;
+			break;
 		case MPT_RATE_2M:
-			TX_RATE_HEX = MCS = 1; break;
+			TX_RATE_HEX = MCS = 1;
+			break;
 		case MPT_RATE_55M:
-			TX_RATE_HEX = MCS = 2; break;
+			TX_RATE_HEX = MCS = 2;
+			break;
 		case MPT_RATE_11M:
-			TX_RATE_HEX = MCS = 3; break;
+			TX_RATE_HEX = MCS = 3;
+			break;
 		}
 	} else if (MPT_IS_OFDM_RATE(TX_RATE)) {
 		MCS = TX_RATE - MPT_RATE_6M;
@@ -2919,13 +3005,13 @@ void PMAC_Get_Pkt_Param(
 	pPMacPktInfo->MCS = MCS;
 	pPMacTxInfo->TX_RATE_HEX = TX_RATE_HEX;
 
-	DBG_871X(" MCS=%d, TX_RATE_HEX =0x%x\n", MCS, pPMacTxInfo->TX_RATE_HEX);
+	RTW_INFO(" MCS=%d, TX_RATE_HEX =0x%x\n", MCS, pPMacTxInfo->TX_RATE_HEX);
 	/*	mSTBC & Nsts*/
 	pPMacPktInfo->Nsts = pPMacPktInfo->Nss;
 	if (pPMacTxInfo->bSTBC) {
 		if (pPMacPktInfo->Nss == 1) {
 			pPMacTxInfo->m_STBC = 2;
-			pPMacPktInfo->Nsts = pPMacPktInfo->Nss*2;
+			pPMacPktInfo->Nsts = pPMacPktInfo->Nss * 2;
 		} else
 			pPMacTxInfo->m_STBC = 1;
 	} else
@@ -2954,21 +3040,21 @@ UINT LDPC_parameter_generator(
 	if (R == 0)
 		CR	= 0.5;
 	else if (R == 1)
-		CR = 2./3.;
+		CR = 2. / 3.;
 	else if (R == 2)
-		CR = 3./4.;
+		CR = 3. / 4.;
 	else if (R == 3)
-		CR = 5./6.;
+		CR = 5. / 6.;
 
 	if (N_TCB <= 648.) {
 		N_CW	= 1.;
-		if (N_TCB >= N_pld+912.*(1.-CR))
+		if (N_TCB >= N_pld + 912.*(1. - CR))
 			L_LDPC	= 1296.;
 		else
 			L_LDPC	= 648.;
 	} else if (N_TCB <= 1296.) {
 		N_CW	= 1.;
-		if (N_TCB >= (double)N_pld + 1464.*(1.-CR))
+		if (N_TCB >= (double)N_pld + 1464.*(1. - CR))
 			L_LDPC	= 1944.;
 		else
 			L_LDPC	= 1296.;
@@ -2977,32 +3063,32 @@ UINT LDPC_parameter_generator(
 		L_LDPC	= 1944.;
 	} else if (N_TCB <= 2592.) {
 		N_CW	= 2.;
-		if (N_TCB >= N_pld+2916.*(1.-CR))
+		if (N_TCB >= N_pld + 2916.*(1. - CR))
 			L_LDPC	= 1944.;
 		else
 			L_LDPC	= 1296.;
 	} else {
-		N_CW = ceil(N_pld/1944./CR);
+		N_CW = ceil(N_pld / 1944. / CR);
 		L_LDPC	= 1944.;
 	}
 	/*	Number of information bits per CW*/
-	K_LDPC = L_LDPC*CR;
+	K_LDPC = L_LDPC * CR;
 	/*	Number of shortening bits					max(0, (N_CW * L_LDPC * R) - N_pld)*/
-	N_shrt = (N_CW*K_LDPC-N_pld) > 0. ? (N_CW*K_LDPC-N_pld) : 0.;
+	N_shrt = (N_CW * K_LDPC - N_pld) > 0. ? (N_CW * K_LDPC - N_pld) : 0.;
 	/*	Number of shortening bits per CW			N_spcw = rtfloor(N_shrt/N_CW)*/
-	N_spcw = rtfloor(N_shrt/N_CW);
+	N_spcw = rtfloor(N_shrt / N_CW);
 	/*	The first N_fshrt CWs shorten 1 bit more*/
 	N_fshrt = (double)((int)N_shrt % (int)N_CW);
 	/*	Number of data bits for the last N_CW-N_fshrt CWs*/
-	L_LDPC_info = K_LDPC-N_spcw;
+	L_LDPC_info = K_LDPC - N_spcw;
 	/*	Number of puncturing bits*/
-	N_punc = (N_CW*L_LDPC-N_TCB-N_shrt) > 0. ? (N_CW*L_LDPC-N_TCB-N_shrt) : 0.;
-	if (((N_punc > .1 * N_CW * L_LDPC * (1.-CR)) && (N_shrt < 1.2 * N_punc * CR/(1.-CR))) ||
-				(N_punc > 0.3*N_CW*L_LDPC*(1.-CR))) {
+	N_punc = (N_CW * L_LDPC - N_TCB - N_shrt) > 0. ? (N_CW * L_LDPC - N_TCB - N_shrt) : 0.;
+	if (((N_punc > .1 * N_CW * L_LDPC * (1. - CR)) && (N_shrt < 1.2 * N_punc * CR / (1. - CR))) ||
+	    (N_punc > 0.3 * N_CW * L_LDPC * (1. - CR))) {
 		/*cout << "*** N_TCB and N_punc are Recomputed ***" << endl;*/
 		VHTSIGA2B3 = 1;
-		N_TCB += (double)N_CBPSS*N_SS*m_STBC;
-		N_punc = (N_CW*L_LDPC-N_TCB-N_shrt) > 0. ? (N_CW*L_LDPC-N_TCB-N_shrt) : 0.;
+		N_TCB += (double)N_CBPSS * N_SS * m_STBC;
+		N_punc = (N_CW * L_LDPC - N_TCB - N_shrt) > 0. ? (N_CW * L_LDPC - N_TCB - N_shrt) : 0.;
 	} else
 		VHTSIGA2B3 = 0;
 
@@ -3026,7 +3112,7 @@ void PMAC_Nsym_generator(
 	UINT N_BPSC = 0, N_CBPS = 0, N_DBPS = 0, N_ES = 0, N_SYM = 0, N_pld = 0, N_TCB = 0;
 	int D_R = 0;
 
-	DBG_871X("TX_RATE = %d\n", TX_RATE);
+	RTW_INFO("TX_RATE = %d\n", TX_RATE);
 	/*	N_SD*/
 	if (pPMacTxInfo->BandWidth == 0)
 		N_SD = 52;
@@ -3051,96 +3137,108 @@ void PMAC_Nsym_generator(
 
 		switch (R) {
 		case 0:
-			CR = .5;	break;
+			CR = .5;
+			break;
 		case 1:
-			CR = 2./3.;	break;
+			CR = 2. / 3.;
+			break;
 		case 2:
-			CR = 3./4.;	break;
+			CR = 3. / 4.;
+			break;
 		case 3:
-			CR = 5./6.;	break;
+			CR = 5. / 6.;
+			break;
 		}
 
 		N_BPSC = N_BPSC_list[MCS_temp];
-		N_CBPS = N_BPSC*N_SD*pPMacPktInfo->Nss;
-		N_DBPS = (UINT)((double)N_CBPS*CR);
+		N_CBPS = N_BPSC * N_SD * pPMacPktInfo->Nss;
+		N_DBPS = (UINT)((double)N_CBPS * CR);
 
 		if (pPMacTxInfo->bLDPC == FALSE) {
-			N_ES = (UINT)ceil((double)(N_DBPS * pPMacPktInfo->Nss)/4./300.);
-			DBG_871X("N_ES = %d\n", N_ES);
+			N_ES = (UINT)ceil((double)(N_DBPS * pPMacPktInfo->Nss) / 4. / 300.);
+			RTW_INFO("N_ES = %d\n", N_ES);
 
 			/*	N_SYM = m_STBC* (8*length+16+6*N_ES) / (m_STBC*N_DBPS)*/
-			N_SYM = pPMacTxInfo->m_STBC*(UINT)ceil((double)(pPMacTxInfo->PacketLength*8+16+N_ES*6)/
-					(double)(N_DBPS*pPMacTxInfo->m_STBC));
+			N_SYM = pPMacTxInfo->m_STBC * (UINT)ceil((double)(pPMacTxInfo->PacketLength * 8 + 16 + N_ES * 6) /
+					(double)(N_DBPS * pPMacTxInfo->m_STBC));
 
 		} else {
 			N_ES = 1;
 			/*	N_pld = length * 8 + 16*/
-			N_pld = pPMacTxInfo->PacketLength*8+16;
-			DBG_871X("N_pld = %d\n", N_pld);
-			N_SYM = pPMacTxInfo->m_STBC*(UINT)ceil((double)(N_pld)/
-					(double)(N_DBPS*pPMacTxInfo->m_STBC));
-			DBG_871X("N_SYM = %d\n", N_SYM);
+			N_pld = pPMacTxInfo->PacketLength * 8 + 16;
+			RTW_INFO("N_pld = %d\n", N_pld);
+			N_SYM = pPMacTxInfo->m_STBC * (UINT)ceil((double)(N_pld) /
+					(double)(N_DBPS * pPMacTxInfo->m_STBC));
+			RTW_INFO("N_SYM = %d\n", N_SYM);
 			/*	N_avbits = N_CBPS *m_STBC *(N_pld/N_CBPS*R*m_STBC)*/
-			N_TCB = N_CBPS*N_SYM;
-			DBG_871X("N_TCB = %d\n", N_TCB);
+			N_TCB = N_CBPS * N_SYM;
+			RTW_INFO("N_TCB = %d\n", N_TCB);
 			SIGA2B3 = LDPC_parameter_generator(N_pld, N_CBPS, pPMacPktInfo->Nss, R, pPMacTxInfo->m_STBC, N_TCB);
-			DBG_871X("SIGA2B3 = %d\n", SIGA2B3);
-			N_SYM = N_SYM + SIGA2B3*pPMacTxInfo->m_STBC;
-			DBG_871X("N_SYM = %d\n", N_SYM);
+			RTW_INFO("SIGA2B3 = %d\n", SIGA2B3);
+			N_SYM = N_SYM + SIGA2B3 * pPMacTxInfo->m_STBC;
+			RTW_INFO("N_SYM = %d\n", N_SYM);
 		}
 	} else if (MPT_IS_VHT_RATE(TX_RATE)) {
 		R = R_list[pPMacPktInfo->MCS];
 
 		switch (R) {
 		case 0:
-			CR = .5;	break;
+			CR = .5;
+			break;
 		case 1:
-			CR = 2./3.;	break;
+			CR = 2. / 3.;
+			break;
 		case 2:
-			CR = 3./4.;	break;
+			CR = 3. / 4.;
+			break;
 		case 3:
-			CR = 5./6.;	break;
+			CR = 5. / 6.;
+			break;
 		}
 		N_BPSC = N_BPSC_list[pPMacPktInfo->MCS];
-		N_CBPS = N_BPSC*N_SD*pPMacPktInfo->Nss;
-		N_DBPS = (UINT)((double)N_CBPS*CR);
+		N_CBPS = N_BPSC * N_SD * pPMacPktInfo->Nss;
+		N_DBPS = (UINT)((double)N_CBPS * CR);
 		if (pPMacTxInfo->bLDPC == FALSE) {
 			if (pPMacTxInfo->bSGI)
-				N_ES = (UINT)ceil((double)(N_DBPS)/3.6/600.);
+				N_ES = (UINT)ceil((double)(N_DBPS) / 3.6 / 600.);
 			else
-				N_ES = (UINT)ceil((double)(N_DBPS)/4./600.);
+				N_ES = (UINT)ceil((double)(N_DBPS) / 4. / 600.);
 			/*	N_SYM = m_STBC* (8*length+16+6*N_ES) / (m_STBC*N_DBPS)*/
-			N_SYM = pPMacTxInfo->m_STBC*(UINT)ceil((double)(pPMacTxInfo->PacketLength*8+16+N_ES*6)/(double)(N_DBPS*pPMacTxInfo->m_STBC));
+			N_SYM = pPMacTxInfo->m_STBC * (UINT)ceil((double)(pPMacTxInfo->PacketLength * 8 + 16 + N_ES * 6) / (double)(N_DBPS * pPMacTxInfo->m_STBC));
 			SIGA2B3 = 0;
 		} else {
 			N_ES = 1;
 			/*	N_SYM = m_STBC* (8*length+N_service) / (m_STBC*N_DBPS)*/
-			N_SYM = pPMacTxInfo->m_STBC*(UINT)ceil((double)(pPMacTxInfo->PacketLength*8+16)/(double)(N_DBPS*pPMacTxInfo->m_STBC));
+			N_SYM = pPMacTxInfo->m_STBC * (UINT)ceil((double)(pPMacTxInfo->PacketLength * 8 + 16) / (double)(N_DBPS * pPMacTxInfo->m_STBC));
 			/*	N_avbits = N_sys_init * N_CBPS*/
 			N_TCB = N_CBPS * N_SYM;
 			/*	N_pld = N_sys_init * N_DBPS*/
 			N_pld = N_SYM * N_DBPS;
 			SIGA2B3 = LDPC_parameter_generator(N_pld, N_CBPS, pPMacPktInfo->Nss, R, pPMacTxInfo->m_STBC, N_TCB);
-			N_SYM = N_SYM + SIGA2B3*pPMacTxInfo->m_STBC;
+			N_SYM = N_SYM + SIGA2B3 * pPMacTxInfo->m_STBC;
 		}
 
 		switch (R) {
 		case 0:
-			D_R = 2;	break;
+			D_R = 2;
+			break;
 		case 1:
-			D_R = 3;	break;
+			D_R = 3;
+			break;
 		case 2:
-			D_R = 4;	break;
+			D_R = 4;
+			break;
 		case 3:
-			D_R = 6;	break;
+			D_R = 6;
+			break;
 		}
 
-		if (((N_CBPS/N_ES)%D_R) != 0) {
-			DBG_871X("MCS= %d is not supported when Nss=%d and BW= %d !!\n",  pPMacPktInfo->MCS, pPMacPktInfo->Nss, pPMacTxInfo->BandWidth);
+		if (((N_CBPS / N_ES) % D_R) != 0) {
+			RTW_INFO("MCS= %d is not supported when Nss=%d and BW= %d !!\n",  pPMacPktInfo->MCS, pPMacPktInfo->Nss, pPMacTxInfo->BandWidth);
 			return;
 		}
 
-		DBG_871X("MCS= %d Nss=%d and BW= %d !!\n",  pPMacPktInfo->MCS, pPMacPktInfo->Nss, pPMacTxInfo->BandWidth);
+		RTW_INFO("MCS= %d Nss=%d and BW= %d !!\n",  pPMacPktInfo->MCS, pPMacPktInfo->Nss, pPMacTxInfo->BandWidth);
 	}
 
 	pPMacPktInfo->N_sym = N_SYM;
@@ -3184,48 +3282,72 @@ void L_SIG_generator(
 
 		/*(L-SIG, HT-SIG, HT-STF, HT-LTF....HT-LTF, Data)*/
 		if (MPT_IS_VHT_RATE(pPMacTxInfo->TX_RATE))
-			OFDM_symbol = (UINT)ceil((double)(8+4+N_LTF*4+N_SYM*T_data+4)/4.);
+			OFDM_symbol = (UINT)ceil((double)(8 + 4 + N_LTF * 4 + N_SYM * T_data + 4) / 4.);
 		else
-			OFDM_symbol = (UINT)ceil((double)(8+4+N_LTF*4+N_SYM*T_data)/4.);
+			OFDM_symbol = (UINT)ceil((double)(8 + 4 + N_LTF * 4 + N_SYM * T_data) / 4.);
 
-		DBG_871X("%s , OFDM_symbol =%d\n", __func__, OFDM_symbol);
-		LENGTH = OFDM_symbol*3-3;
-		DBG_871X("%s , LENGTH =%d\n", __func__, LENGTH);
+		RTW_INFO("%s , OFDM_symbol =%d\n", __func__, OFDM_symbol);
+		LENGTH = OFDM_symbol * 3 - 3;
+		RTW_INFO("%s , LENGTH =%d\n", __func__, LENGTH);
 
 	}
 	/*	Rate Field*/
-		switch (mode) {
-		case	0:
-			sig_bi[0] = 1; sig_bi[1] = 1; sig_bi[2] = 0; sig_bi[3] = 1;
-			break;
-		case	1:
-			sig_bi[0] = 1; sig_bi[1] = 1; sig_bi[2] = 1; sig_bi[3] = 1;
-			break;
-		case	2:
-			sig_bi[0] = 0; sig_bi[1] = 1; sig_bi[2] = 0; sig_bi[3] = 1;
-			break;
-		case	3:
-			sig_bi[0] = 0; sig_bi[1] = 1; sig_bi[2] = 1; sig_bi[3] = 1;
-			break;
-		case	4:
-			sig_bi[0] = 1; sig_bi[1] = 0; sig_bi[2] = 0; sig_bi[3] = 1;
-			break;
-		case	5:
-			sig_bi[0] = 1; sig_bi[1] = 0; sig_bi[2] = 1; sig_bi[3] = 1;
-			break;
-		case	6:
-			sig_bi[0] = 0; sig_bi[1] = 0; sig_bi[2] = 0; sig_bi[3] = 1;
-			break;
-		case	7:
-			sig_bi[0] = 0; sig_bi[1] = 0; sig_bi[2] = 1; sig_bi[3] = 1;
-			break;
+	switch (mode) {
+	case	0:
+		sig_bi[0] = 1;
+		sig_bi[1] = 1;
+		sig_bi[2] = 0;
+		sig_bi[3] = 1;
+		break;
+	case	1:
+		sig_bi[0] = 1;
+		sig_bi[1] = 1;
+		sig_bi[2] = 1;
+		sig_bi[3] = 1;
+		break;
+	case	2:
+		sig_bi[0] = 0;
+		sig_bi[1] = 1;
+		sig_bi[2] = 0;
+		sig_bi[3] = 1;
+		break;
+	case	3:
+		sig_bi[0] = 0;
+		sig_bi[1] = 1;
+		sig_bi[2] = 1;
+		sig_bi[3] = 1;
+		break;
+	case	4:
+		sig_bi[0] = 1;
+		sig_bi[1] = 0;
+		sig_bi[2] = 0;
+		sig_bi[3] = 1;
+		break;
+	case	5:
+		sig_bi[0] = 1;
+		sig_bi[1] = 0;
+		sig_bi[2] = 1;
+		sig_bi[3] = 1;
+		break;
+	case	6:
+		sig_bi[0] = 0;
+		sig_bi[1] = 0;
+		sig_bi[2] = 0;
+		sig_bi[3] = 1;
+		break;
+	case	7:
+		sig_bi[0] = 0;
+		sig_bi[1] = 0;
+		sig_bi[2] = 1;
+		sig_bi[3] = 1;
+		break;
 	}
 	/*Reserved bit*/
 	sig_bi[4] = 0;
 
 	/*	Length Field*/
 	for (i = 0; i < 12; i++)
-		sig_bi[i+5] = (LENGTH>>i) & 1;
+		sig_bi[i + 5] = (LENGTH >> i) & 1;
 
 	/* Parity Bit*/
 	sig_bi[17] = 0;
@@ -3248,13 +3370,13 @@ void CRC8_generator(
 	bool	*out,
 	bool	*in,
 	UCHAR	in_size
-	)
+)
 {
 	UCHAR i = 0;
 	bool temp = 0, reg[] = {1, 1, 1, 1, 1, 1, 1, 1};
 
 	for (i = 0; i < in_size; i++) { /* take one's complement and bit reverse*/
-		temp = in[i]^reg[7];
+		temp = in[i] ^ reg[7];
 		reg[7]	= reg[6];
 		reg[6]	= reg[5];
 		reg[5]	= reg[4];
@@ -3264,9 +3386,9 @@ void CRC8_generator(
 		reg[1]	= reg[0] ^ temp;
 		reg[0]	= temp;
 	}
-		for (i = 0; i < 8; i++)/* take one's complement and bit reverse*/
-			out[i] = reg[7-i]^1;
-	}
+	for (i = 0; i < 8; i++)/* take one's complement and bit reverse*/
+		out[i] = reg[7 - i] ^ 1;
+}
 
 /*/================================================================================
 	HT-SIG1	MCS	CW	Length		24BIT + 24BIT
@@ -3277,7 +3399,7 @@ void CRC8_generator(
 void HT_SIG_generator(
 	PRT_PMAC_TX_INFO	pPMacTxInfo,
 	PRT_PMAC_PKT_INFO	pPMacPktInfo
-	)
+)
 {
 	UINT i;
 	bool sig_bi[48] = {0}, crc8[8] = {0};
@@ -3288,11 +3410,11 @@ void HT_SIG_generator(
 	sig_bi[7] = pPMacTxInfo->BandWidth;
 	/*	HT-Length Field*/
 	for (i = 0; i < 16; i++)
-		sig_bi[i+8] = (pPMacTxInfo->PacketLength >> i) & 0x1;
+		sig_bi[i + 8] = (pPMacTxInfo->PacketLength >> i) & 0x1;
 	/*	Smoothing;	1->allow smoothing*/
 	sig_bi[24] = 1;
 	/*Not Sounding*/
-	sig_bi[25] = 1-pPMacTxInfo->NDP_sound;
+	sig_bi[25] = 1 - pPMacTxInfo->NDP_sound;
 	/*Reserved bit*/
 	sig_bi[26] = 1;
 	/*/Aggregate*/
@@ -3317,13 +3439,13 @@ void HT_SIG_generator(
 		int	N_ELTF = pPMacTxInfo->Ntx - pPMacPktInfo->Nss;
 
 		for (i = 0; i < 2; i++)
-			sig_bi[32+i] = (N_ELTF>>i)%2;
+			sig_bi[32 + i] = (N_ELTF >> i) % 2;
 	}
 	/*	CRC-8*/
 	CRC8_generator(crc8, sig_bi, 34);
 
 	for (i = 0; i < 8; i++)
-		sig_bi[34+i] = crc8[i];
+		sig_bi[34 + i] = crc8[i];
 
 	/*Tail*/
 	for (i = 42; i < 48; i++)
@@ -3354,20 +3476,20 @@ void VHT_SIG_A_generator(
 
 	/*	BW Setting*/
 	for (i = 0; i < 2; i++)
-		sig_bi[i] = (pPMacTxInfo->BandWidth>>i) & 0x1;
+		sig_bi[i] = (pPMacTxInfo->BandWidth >> i) & 0x1;
 	/* Reserved Bit*/
 	sig_bi[2] = 1;
 	/*STBC Field*/
 	sig_bi[3] = pPMacTxInfo->bSTBC;
-	/*Group ID: Single User -> A value of 0 or 63 indicates an SU PPDU. */
+	/*Group ID: Single User->A value of 0 or 63 indicates an SU PPDU. */
 	for (i = 0; i < 6; i++)
-		sig_bi[4+i] = 0;
+		sig_bi[4 + i] = 0;
 	/*	N_STS/Partial AID*/
 	for (i = 0; i < 12; i++) {
 		if (i < 3)
-			sig_bi[10+i] = ((pPMacPktInfo->Nsts - 1)>>i) & 0x1;
+			sig_bi[10 + i] = ((pPMacPktInfo->Nsts - 1) >> i) & 0x1;
 		else
-			sig_bi[10+i] = 0;
+			sig_bi[10 + i] = 0;
 	}
 	/*TXOP_PS_NOT_ALLPWED*/
 	sig_bi[22]	= 0;
@@ -3375,7 +3497,7 @@ void VHT_SIG_A_generator(
 	sig_bi[23]	= 1;
 	/*Short GI*/
 	sig_bi[24] = pPMacTxInfo->bSGI;
-	if (pPMacTxInfo->bSGI > 0 && (pPMacPktInfo->N_sym%10) == 9)
+	if (pPMacTxInfo->bSGI > 0 && (pPMacPktInfo->N_sym % 10) == 9)
 		sig_bi[25] = 1;
 	else
 		sig_bi[25] = 0;
@@ -3384,7 +3506,7 @@ void VHT_SIG_A_generator(
 	sig_bi[27] = pPMacPktInfo->SIGA2B3;	/*/	Record Extra OFDM Symols is added or not when LDPC is used*/
 	/*SU MCS/MU[1-3] Coding*/
 	for (i = 0; i < 4; i++)
-		sig_bi[28+i] = (pPMacPktInfo->MCS>>i) & 0x1;
+		sig_bi[28 + i] = (pPMacPktInfo->MCS >> i) & 0x1;
 	/*SU Beamform */
 	sig_bi[32] = 0;	/*packet.TXBF_en;*/
 	/*Reserved Bit*/
@@ -3392,7 +3514,7 @@ void VHT_SIG_A_generator(
 	/*CRC-8*/
 	CRC8_generator(crc8, sig_bi, 34);
 	for (i = 0; i < 8; i++)
-		sig_bi[34+i]	= crc8[i];
+		sig_bi[34 + i]	= crc8[i];
 	/*Tail*/
 	for (i = 42; i < 48; i++)
 		sig_bi[i] = 0;
@@ -3435,31 +3557,35 @@ void VHT_SIG_B_generator(
 		bool *sigb_temp[29] = {0};
 
 		if (pPMacTxInfo->BandWidth == 0) {
-			len = 17;	res = 3;
+			len = 17;
+			res = 3;
 		} else if (pPMacTxInfo->BandWidth == 1) {
-			len = 19;	res = 2;
+			len = 19;
+			res = 2;
 		} else if (pPMacTxInfo->BandWidth == 2) {
-			len	= 21;	res	= 2;
+			len	= 21;
+			res	= 2;
 		} else {
-			len	= 21;	res	= 2;
+			len	= 21;
+			res	= 2;
 		}
-		total_len = len+res+tail;
-		crc8_in_len = len+res;
+		total_len = len + res + tail;
+		crc8_in_len = len + res;
 
 		/*Length Field*/
 		sigb_len = (pPMacTxInfo->PacketLength + 3) >> 2;
 
 		for (i = 0; i < len; i++)
-			sig_bi[i] = (sigb_len>>i) & 0x1;
+			sig_bi[i] = (sigb_len >> i) & 0x1;
 		/*Reserved Field*/
 		for (i = 0; i < res; i++)
-			sig_bi[len+i] = 1;
+			sig_bi[len + i] = 1;
 		/* CRC-8*/
 		CRC8_generator(crc8_bi, sig_bi, crc8_in_len);
 
 		/* Tail */
 		for (i = 0; i < tail; i++)
-			sig_bi[len+res+i] = 0;
+			sig_bi[len + res + i] = 0;
 	}
 
 	_rtw_memset(pPMacTxInfo->VHT_SIG_B, 0, 4);
@@ -3474,7 +3600,7 @@ void VHT_SIG_B_generator(
 =======================*/
 void VHT_Delimiter_generator(
 	PRT_PMAC_TX_INFO	pPMacTxInfo
-	)
+)
 {
 	bool sig_bi[32] = {0}, crc8[8] = {0};
 	UINT crc8_in_len = 16;
@@ -3490,12 +3616,12 @@ void VHT_Delimiter_generator(
 	sig_bi[3] = ((PacketLength - 4) >> 13) % 2;
 	/* Delimiter[15:4]: MPDU Length Low*/
 	for (j = 4; j < 16; j++)
-		sig_bi[j] = ((PacketLength - 4) >> (j-4)) % 2;
+		sig_bi[j] = ((PacketLength - 4) >> (j - 4)) % 2;
 	CRC8_generator(crc8, sig_bi, crc8_in_len);
 	for (j = 16; j < 24; j++) /* Delimiter[23:16]: CRC 8*/
-		sig_bi[j] = crc8[j-16];
+		sig_bi[j] = crc8[j - 16];
 	for (j = 24; j < 32; j++) /* Delimiter[31:24]: Signature ('4E' in Hex, 78 in Dec)*/
-		sig_bi[j]	= (78 >> (j-24)) % 2;
+		sig_bi[j]	= (78 >> (j - 24)) % 2;
 
 	_rtw_memset(pPMacTxInfo->VHT_Delimiter, 0, 4);
 	ByteToBit(pPMacTxInfo->VHT_Delimiter, sig_bi, 4);
@@ -3503,4 +3629,3 @@ void VHT_Delimiter_generator(
 
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp_ioctl.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp_ioctl.c
index ff0c66b3846e..08d4e980165f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp_ioctl.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_mp_ioctl.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,44 +12,35 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_MP_IOCTL_C_
 
 #include <drv_types.h>
 #include <rtw_mp_ioctl.h>
 #include "../hal/phydm/phydm_precomp.h"
 
-//****************  oid_rtl_seg_81_85   section start ****************
+/* ****************  oid_rtl_seg_81_85   section start **************** */
 NDIS_STATUS oid_rt_wireless_mode_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS status = NDIS_STATUS_SUCCESS;
 	PADAPTER Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->information_buf_len < sizeof(u8))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	if (poid_par_priv->type_of_oid == SET_OID) {
-		Adapter->registrypriv.wireless_mode = *(u8*)poid_par_priv->information_buf;
-	} else if (poid_par_priv->type_of_oid == QUERY_OID) {
-		*(u8*)poid_par_priv->information_buf = Adapter->registrypriv.wireless_mode;
+	if (poid_par_priv->type_of_oid == SET_OID)
+		Adapter->registrypriv.wireless_mode = *(u8 *)poid_par_priv->information_buf;
+	else if (poid_par_priv->type_of_oid == QUERY_OID) {
+		*(u8 *)poid_par_priv->information_buf = Adapter->registrypriv.wireless_mode;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-		 RT_TRACE(_module_mp_, _drv_info_, ("-query Wireless Mode=%d\n", Adapter->registrypriv.wireless_mode));
-	} else {
+	} else
 		status = NDIS_STATUS_NOT_ACCEPTED;
-	}
 
-_func_exit_;
 
 	return status;
 }
-//****************  oid_rtl_seg_81_87_80   section start ****************
+/* ****************  oid_rtl_seg_81_87_80   section start **************** */
 NDIS_STATUS oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -60,9 +52,7 @@ NDIS_STATUS oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS status = NDIS_STATUS_SUCCESS;
 	PADAPTER Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_write_bb_reg_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -72,24 +62,21 @@ _func_enter_;
 
 	pbbreg = (struct bb_reg_param *)(poid_par_priv->information_buf);
 
-	offset = (u16)(pbbreg->offset) & 0xFFF; //0ffset :0x800~0xfff
-	if (offset < BB_REG_BASE_ADDR) offset |= BB_REG_BASE_ADDR;
+	offset = (u16)(pbbreg->offset) & 0xFFF; /* 0ffset :0x800~0xfff */
+	if (offset < BB_REG_BASE_ADDR)
+		offset |= BB_REG_BASE_ADDR;
 
 	value = pbbreg->value;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("oid_rt_pro_write_bb_reg_hdl: offset=0x%03X value=0x%08X\n",
-		  offset, value));
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	write_bbreg(Adapter, offset, 0xFFFFFFFF, value);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -101,9 +88,7 @@ NDIS_STATUS oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS status = NDIS_STATUS_SUCCESS;
 	PADAPTER Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_read_bb_reg_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -113,8 +98,9 @@ _func_enter_;
 
 	pbbreg = (struct bb_reg_param *)(poid_par_priv->information_buf);
 
-	offset = (u16)(pbbreg->offset) & 0xFFF; //0ffset :0x800~0xfff
-	if (offset < BB_REG_BASE_ADDR) offset |= BB_REG_BASE_ADDR;
+	offset = (u16)(pbbreg->offset) & 0xFFF; /* 0ffset :0x800~0xfff */
+	if (offset < BB_REG_BASE_ADDR)
+		offset |= BB_REG_BASE_ADDR;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	value = read_bbreg(Adapter, offset, 0xFFFFFFFF);
@@ -123,14 +109,10 @@ _func_enter_;
 	pbbreg->value = value;
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("-oid_rt_pro_read_bb_reg_hdl: offset=0x%03X value:0x%08X\n",
-		  offset, value));
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -143,9 +125,7 @@ NDIS_STATUS oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS status = NDIS_STATUS_SUCCESS;
 	PADAPTER Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_write_rf_reg_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -166,19 +146,15 @@ _func_enter_;
 	offset = (u8)pbbreg->offset;
 	value = pbbreg->value;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("oid_rt_pro_write_rf_reg_hdl: path=%d offset=0x%02X value=0x%05X\n",
-		  path, offset, value));
 
 	_irqlevel_changed_(&oldirql, LOWER);
- 	write_rfreg(Adapter, path, offset, value);
+	write_rfreg(Adapter, path, offset, value);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -191,9 +167,7 @@ NDIS_STATUS oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv *poid_par_priv)
 	PADAPTER Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 	NDIS_STATUS status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_read_rf_reg_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -219,32 +193,25 @@ _func_enter_;
 
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("-oid_rt_pro_read_rf_reg_hdl: path=%d offset=0x%02X value=0x%05X\n",
-		  path, offset, value));
 
-_func_exit_;
 
 	return status;
 }
-//****************  oid_rtl_seg_81_87_00   section end****************
-//------------------------------------------------------------------------------
+/* ****************  oid_rtl_seg_81_87_00   section end****************
+ * ------------------------------------------------------------------------------ */
 
-//****************  oid_rtl_seg_81_80_00   section start ****************
-//------------------------------------------------------------------------------
+/* ****************  oid_rtl_seg_81_80_00   section start ****************
+ * ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_set_data_rate_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
 	_irqL		oldirql;
 #endif
-	u32		ratevalue;//4
+	u32		ratevalue;/* 4 */
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("+oid_rt_pro_set_data_rate_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -252,9 +219,7 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len != sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	ratevalue = *((u32*)poid_par_priv->information_buf);//4
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("oid_rt_pro_set_data_rate_hdl: data rate idx=%d\n", ratevalue));
+	ratevalue = *((u32 *)poid_par_priv->information_buf); /* 4 */
 	if (ratevalue >= MPT_RATE_LAST)
 		return NDIS_STATUS_INVALID_DATA;
 
@@ -264,11 +229,10 @@ _func_enter_;
 	SetDataRate(Adapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_start_test_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -278,9 +242,7 @@ NDIS_STATUS oid_rt_pro_start_test_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_start_test_hdl\n"));
 
 	if (Adapter->registrypriv.mp_mode == 0)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -290,10 +252,10 @@ _func_enter_;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
-	//IQCalibrateBcut(Adapter);
+	/* IQCalibrateBcut(Adapter); */
 
-	mode = *((u32*)poid_par_priv->information_buf);
-	Adapter->mppriv.mode = mode;// 1 for loopback
+	mode = *((u32 *)poid_par_priv->information_buf);
+	Adapter->mppriv.mode = mode;/* 1 for loopback */
 
 	if (mp_start_test(Adapter) == _FAIL) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
@@ -303,13 +265,11 @@ _func_enter_;
 exit:
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("-oid_rt_pro_start_test_hdl: mp_mode=%d\n", Adapter->mppriv.mode));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_stop_test_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -318,9 +278,7 @@ NDIS_STATUS oid_rt_pro_stop_test_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+Set OID_RT_PRO_STOP_TEST\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -329,13 +287,11 @@ _func_enter_;
 	mp_stop_test(Adapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("-Set OID_RT_PRO_STOP_TEST\n"));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_set_channel_direct_call_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -345,23 +301,20 @@ NDIS_STATUS oid_rt_pro_set_channel_direct_call_hdl(struct oid_par_priv *poid_par
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_set_channel_direct_call_hdl\n"));
 
 	if (poid_par_priv->information_buf_len != sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
 	if (poid_par_priv->type_of_oid == QUERY_OID) {
-		*((u32*)poid_par_priv->information_buf) = Adapter->mppriv.channel;
+		*((u32 *)poid_par_priv->information_buf) = Adapter->mppriv.channel;
 		return NDIS_STATUS_SUCCESS;
 	}
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	Channel = *((u32*)poid_par_priv->information_buf);
-	RT_TRACE(_module_mp_, _drv_notice_, ("oid_rt_pro_set_channel_direct_call_hdl: Channel=%d\n", Channel));
+	Channel = *((u32 *)poid_par_priv->information_buf);
 	if (Channel > 14)
 		return NDIS_STATUS_NOT_ACCEPTED;
 	Adapter->mppriv.channel = Channel;
@@ -370,11 +323,10 @@ _func_enter_;
 	SetChannel(Adapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_set_bandwidth_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -385,10 +337,7 @@ NDIS_STATUS oid_rt_set_bandwidth_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("+oid_rt_set_bandwidth_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -396,7 +345,7 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len < sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	bandwidth = *((u32*)poid_par_priv->information_buf);//4
+	bandwidth = *((u32 *)poid_par_priv->information_buf); /* 4 */
 	channel_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 
 	if (bandwidth != CHANNEL_WIDTH_40)
@@ -408,15 +357,11 @@ _func_enter_;
 	SetBandwidth(padapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("-oid_rt_set_bandwidth_hdl: bandwidth=%d channel_offset=%d\n",
-		  bandwidth, channel_offset));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_set_antenna_bb_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -426,32 +371,25 @@ NDIS_STATUS oid_rt_pro_set_antenna_bb_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_set_antenna_bb_hdl\n"));
 
 	if (poid_par_priv->information_buf_len != sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	if (poid_par_priv->type_of_oid == SET_OID)
-	{
-		antenna = *(u32*)poid_par_priv->information_buf;
+	if (poid_par_priv->type_of_oid == SET_OID) {
+		antenna = *(u32 *)poid_par_priv->information_buf;
 
 		Adapter->mppriv.antenna_tx = (u16)((antenna & 0xFFFF0000) >> 16);
 		Adapter->mppriv.antenna_rx = (u16)(antenna & 0x0000FFFF);
-		RT_TRACE(_module_mp_, _drv_notice_,
-			 ("oid_rt_pro_set_antenna_bb_hdl: tx_ant=0x%04x rx_ant=0x%04x\n",
-			  Adapter->mppriv.antenna_tx, Adapter->mppriv.antenna_rx));
 
 		_irqlevel_changed_(&oldirql, LOWER);
 		SetAntenna(Adapter);
 		_irqlevel_changed_(&oldirql, RAISE);
 	} else {
-		antenna = (Adapter->mppriv.antenna_tx << 16)|Adapter->mppriv.antenna_rx;
-		*(u32*)poid_par_priv->information_buf = antenna;
+		antenna = (Adapter->mppriv.antenna_tx << 16) | Adapter->mppriv.antenna_rx;
+		*(u32 *)poid_par_priv->information_buf = antenna;
 	}
 
-_func_exit_;
 
 	return status;
 }
@@ -465,9 +403,7 @@ NDIS_STATUS oid_rt_pro_set_tx_power_control_hdl(struct oid_par_priv *poid_par_pr
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("+oid_rt_pro_set_tx_power_control_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -475,132 +411,110 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len != sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	tx_pwr_idx = *((u32*)poid_par_priv->information_buf);
+	tx_pwr_idx = *((u32 *)poid_par_priv->information_buf);
 	if (tx_pwr_idx > MAX_TX_PWR_INDEX_N_MODE)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
 	Adapter->mppriv.txpoweridx = (u8)tx_pwr_idx;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("oid_rt_pro_set_tx_power_control_hdl: idx=0x%2x\n",
-		  Adapter->mppriv.txpoweridx));
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	SetTxPower(Adapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
 
-//------------------------------------------------------------------------------
-//****************  oid_rtl_seg_81_80_20   section start ****************
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------
+ * ****************  oid_rtl_seg_81_80_20   section start ****************
+ * ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_query_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	if (poid_par_priv->type_of_oid !=QUERY_OID) {
+	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
 
 	if (poid_par_priv->information_buf_len == sizeof(ULONG)) {
-		*(ULONG*)poid_par_priv->information_buf =  Adapter->mppriv.tx_pktcount;
+		*(ULONG *)poid_par_priv->information_buf =  Adapter->mppriv.tx_pktcount;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-	} else {
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_query_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
-	RT_TRACE(_module_mp_, _drv_alert_, ("===> oid_rt_pro_query_rx_packet_received_hdl.\n"));
 	if (poid_par_priv->information_buf_len == sizeof(ULONG)) {
-		*(ULONG*)poid_par_priv->information_buf =  Adapter->mppriv.rx_pktcount;
+		*(ULONG *)poid_par_priv->information_buf =  Adapter->mppriv.rx_pktcount;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-		RT_TRACE(_module_mp_, _drv_alert_, ("recv_ok:%d \n",Adapter->mppriv.rx_pktcount));
-	} else {
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_query_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
-	RT_TRACE(_module_mp_, _drv_alert_, ("===> oid_rt_pro_query_rx_packet_crc32_error_hdl.\n"));
 	if (poid_par_priv->information_buf_len == sizeof(ULONG)) {
-		*(ULONG*)poid_par_priv->information_buf =  Adapter->mppriv.rx_crcerrpktcount;
+		*(ULONG *)poid_par_priv->information_buf =  Adapter->mppriv.rx_crcerrpktcount;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-		RT_TRACE(_module_mp_, _drv_alert_, ("recv_err:%d \n",Adapter->mppriv.rx_crcerrpktcount));
-	} else {
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 
 NDIS_STATUS oid_rt_pro_reset_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
 
-	RT_TRACE(_module_mp_, _drv_alert_, ("===> oid_rt_pro_reset_tx_packet_sent_hdl.\n"));
 	Adapter->mppriv.tx_pktcount = 0;
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_reset_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	if (poid_par_priv->type_of_oid != SET_OID)
-	{
+	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
@@ -608,15 +522,13 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len == sizeof(ULONG)) {
 		Adapter->mppriv.rx_pktcount = 0;
 		Adapter->mppriv.rx_crcerrpktcount = 0;
-	} else {
+	} else
 		status = NDIS_STATUS_INVALID_LENGTH;
-	}
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_reset_phy_rx_packet_count_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -625,7 +537,6 @@ NDIS_STATUS oid_rt_reset_phy_rx_packet_count_hdl(struct oid_par_priv *poid_par_p
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
@@ -636,11 +547,10 @@ _func_enter_;
 	ResetPhyRxPktCount(Adapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_get_phy_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -649,9 +559,7 @@ NDIS_STATUS oid_rt_get_phy_rx_packet_received_hdl(struct oid_par_priv *poid_par_
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("+oid_rt_get_phy_rx_packet_received_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -660,18 +568,16 @@ _func_enter_;
 		return NDIS_STATUS_INVALID_LENGTH;
 
 	_irqlevel_changed_(&oldirql, LOWER);
-	*(ULONG*)poid_par_priv->information_buf = GetPhyRxPktReceived(Adapter);
+	*(ULONG *)poid_par_priv->information_buf = GetPhyRxPktReceived(Adapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("-oid_rt_get_phy_rx_packet_received_hdl: recv_ok=%d\n", *(ULONG*)poid_par_priv->information_buf));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_get_phy_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -680,9 +586,7 @@ NDIS_STATUS oid_rt_get_phy_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_p
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("+oid_rt_get_phy_rx_packet_crc32_error_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -692,18 +596,16 @@ _func_enter_;
 		return NDIS_STATUS_INVALID_LENGTH;
 
 	_irqlevel_changed_(&oldirql, LOWER);
-	*(ULONG*)poid_par_priv->information_buf = GetPhyRxPktCRC32Error(Adapter);
+	*(ULONG *)poid_par_priv->information_buf = GetPhyRxPktCRC32Error(Adapter);
 	_irqlevel_changed_(&oldirql, RAISE);
 
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("-oid_rt_get_phy_rx_packet_crc32_error_hdl: recv_err=%d\n", *(ULONG*)poid_par_priv->information_buf));
 
-_func_exit_;
 
 	return status;
 }
-//****************  oid_rtl_seg_81_80_20   section end ****************
+/* ****************  oid_rtl_seg_81_80_20   section end **************** */
 NDIS_STATUS oid_rt_pro_set_continuous_tx_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -713,22 +615,20 @@ NDIS_STATUS oid_rt_pro_set_continuous_tx_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_set_continuous_tx_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	bStartTest = *((u32*)poid_par_priv->information_buf);
+	bStartTest = *((u32 *)poid_par_priv->information_buf);
 
 	_irqlevel_changed_(&oldirql, LOWER);
-	SetContinuousTx(Adapter,(u8)bStartTest);
+	SetContinuousTx(Adapter, (u8)bStartTest);
 	if (bStartTest) {
 		struct mp_priv *pmp_priv = &Adapter->mppriv;
 		if (pmp_priv->tx.stop == 0) {
 			pmp_priv->tx.stop = 1;
-			DBG_871X("%s: pkt tx is running...\n", __func__);
+			RTW_INFO("%s: pkt tx is running...\n", __func__);
 			rtw_msleep_os(5);
 		}
 		pmp_priv->tx.stop = 0;
@@ -737,7 +637,6 @@ _func_enter_;
 	}
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
@@ -751,14 +650,12 @@ NDIS_STATUS oid_rt_pro_set_single_carrier_tx_hdl(struct oid_par_priv *poid_par_p
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_alert_, ("+oid_rt_pro_set_single_carrier_tx_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	bStartTest = *((u32*)poid_par_priv->information_buf);
+	bStartTest = *((u32 *)poid_par_priv->information_buf);
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	SetSingleCarrierTx(Adapter, (u8)bStartTest);
@@ -766,7 +663,7 @@ _func_enter_;
 		struct mp_priv *pmp_priv = &Adapter->mppriv;
 		if (pmp_priv->tx.stop == 0) {
 			pmp_priv->tx.stop = 1;
-			DBG_871X("%s: pkt tx is running...\n", __func__);
+			RTW_INFO("%s: pkt tx is running...\n", __func__);
 			rtw_msleep_os(5);
 		}
 		pmp_priv->tx.stop = 0;
@@ -775,7 +672,6 @@ _func_enter_;
 	}
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
@@ -789,14 +685,12 @@ NDIS_STATUS oid_rt_pro_set_carrier_suppression_tx_hdl(struct oid_par_priv *poid_
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_set_carrier_suppression_tx_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	bStartTest = *((u32*)poid_par_priv->information_buf);
+	bStartTest = *((u32 *)poid_par_priv->information_buf);
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	SetCarrierSuppressionTx(Adapter, (u8)bStartTest);
@@ -804,7 +698,7 @@ _func_enter_;
 		struct mp_priv *pmp_priv = &Adapter->mppriv;
 		if (pmp_priv->tx.stop == 0) {
 			pmp_priv->tx.stop = 1;
-			DBG_871X("%s: pkt tx is running...\n", __func__);
+			RTW_INFO("%s: pkt tx is running...\n", __func__);
 			rtw_msleep_os(5);
 		}
 		pmp_priv->tx.stop = 0;
@@ -813,7 +707,6 @@ _func_enter_;
 	}
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
@@ -823,29 +716,26 @@ NDIS_STATUS oid_rt_pro_set_single_tone_tx_hdl(struct oid_par_priv *poid_par_priv
 #ifdef PLATFORM_OS_XP
 	_irqL		oldirql;
 #endif
-	u32 		bStartTest;
+	u32		bStartTest;
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_alert_, ("+oid_rt_pro_set_single_tone_tx_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	bStartTest = *((u32*)poid_par_priv->information_buf);
+	bStartTest = *((u32 *)poid_par_priv->information_buf);
 
 	_irqlevel_changed_(&oldirql, LOWER);
-	SetSingleToneTx(Adapter,(u8)bStartTest);
+	SetSingleToneTx(Adapter, (u8)bStartTest);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
 
-NDIS_STATUS oid_rt_pro_set_modulation_hdl(struct oid_par_priv* poid_par_priv)
+NDIS_STATUS oid_rt_pro_set_modulation_hdl(struct oid_par_priv *poid_par_priv)
 {
 	return 0;
 }
@@ -858,7 +748,6 @@ NDIS_STATUS oid_rt_pro_trigger_gpio_hdl(struct oid_par_priv *poid_par_priv)
 	_irqL		oldirql;
 #endif
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -867,12 +756,11 @@ _func_enter_;
 	rtw_hal_set_hwreg(Adapter, HW_VAR_TRIGGER_GPIO_0, 0);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//****************  oid_rtl_seg_81_80_00   section end ****************
-//------------------------------------------------------------------------------
+/* ****************  oid_rtl_seg_81_80_00   section end ****************
+ * ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro8711_join_bss_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -885,7 +773,6 @@ NDIS_STATUS oid_rt_pro8711_join_bss_hdl(struct oid_par_priv *poid_par_priv)
 
 	PNDIS_802_11_SSID pssid;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -906,28 +793,24 @@ _func_enter_;
 
 	*poid_par_priv->bytes_rw = sizeof(NDIS_802_11_SSID);
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_read_register_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
 	_irqL		oldirql;
 #endif
-	pRW_Reg 	RegRWStruct;
+	pRW_Reg	RegRWStruct;
 	u32		offset, width;
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("+oid_rt_pro_read_register_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -942,44 +825,37 @@ _func_enter_;
 	_irqlevel_changed_(&oldirql, LOWER);
 
 	switch (width) {
-		case 1:
-			RegRWStruct->value = rtw_read8(Adapter, offset);
-			break;
-		case 2:
-			RegRWStruct->value = rtw_read16(Adapter, offset);
-			break;
-		default:
-			width = 4;
-			RegRWStruct->value = rtw_read32(Adapter, offset);
-			break;
+	case 1:
+		RegRWStruct->value = rtw_read8(Adapter, offset);
+		break;
+	case 2:
+		RegRWStruct->value = rtw_read16(Adapter, offset);
+		break;
+	default:
+		width = 4;
+		RegRWStruct->value = rtw_read32(Adapter, offset);
+		break;
 	}
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("oid_rt_pro_read_register_hdl: offset:0x%04X value:0x%X\n",
-		  offset, RegRWStruct->value));
 
 	_irqlevel_changed_(&oldirql, RAISE);
 
 	*poid_par_priv->bytes_rw = width;
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_write_register_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
 	_irqL		oldirql;
 #endif
-	pRW_Reg 	RegRWStruct;
+	pRW_Reg	RegRWStruct;
 	u32		offset, width, value;
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("+oid_rt_pro_write_register_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -994,41 +870,36 @@ _func_enter_;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
-	switch (RegRWStruct->width)
-	{
-		case 1:
-			if (value > 0xFF) {
-				status = NDIS_STATUS_NOT_ACCEPTED;
-				break;
-			}
-			rtw_write8(padapter, offset, (u8)value);
-			break;
-		case 2:
-			if (value > 0xFFFF) {
-				status = NDIS_STATUS_NOT_ACCEPTED;
-				break;
-			}
-			rtw_write16(padapter, offset, (u16)value);
-			break;
-		case 4:
-			rtw_write32(padapter, offset, value);
+	switch (RegRWStruct->width) {
+	case 1:
+		if (value > 0xFF) {
+			status = NDIS_STATUS_NOT_ACCEPTED;
 			break;
-		default:
+		}
+		rtw_write8(padapter, offset, (u8)value);
+		break;
+	case 2:
+		if (value > 0xFFFF) {
 			status = NDIS_STATUS_NOT_ACCEPTED;
 			break;
+		}
+		rtw_write16(padapter, offset, (u16)value);
+		break;
+	case 4:
+		rtw_write32(padapter, offset, value);
+		break;
+	default:
+		status = NDIS_STATUS_NOT_ACCEPTED;
+		break;
 	}
 
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("-oid_rt_pro_write_register_hdl: offset=0x%08X width=%d value=0x%X\n",
-		  offset, width, value));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_burst_read_register_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1039,9 +910,7 @@ NDIS_STATUS oid_rt_pro_burst_read_register_hdl(struct oid_par_priv *poid_par_pri
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_burst_read_register_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1054,16 +923,14 @@ _func_enter_;
 
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("-oid_rt_pro_burst_read_register_hdl\n"));
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_burst_write_register_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1074,9 +941,7 @@ NDIS_STATUS oid_rt_pro_burst_write_register_hdl(struct oid_par_priv *poid_par_pr
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_burst_write_register_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1087,22 +952,20 @@ _func_enter_;
 	rtw_write_mem(padapter, pBstRwReg->offset, (u32)pBstRwReg->len, pBstRwReg->Data);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_info_, ("-oid_rt_pro_burst_write_register_hdl\n"));
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_write_txcmd_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-	PADAPTER	Adapter = (PADAPTER)( poid_par_priv->adapter_context);
+	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 #ifdef PLATFORM_OS_XP
 	_irqL		oldirql;
@@ -1110,40 +973,30 @@ NDIS_STATUS oid_rt_pro_write_txcmd_hdl(struct oid_par_priv *poid_par_priv)
 
 	TX_CMD_Desc	*TxCmd_Info;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("+Set OID_RT_PRO_WRITE_TXCMD\n"));
 
-	TxCmd_Info=(TX_CMD_Desc*)poid_par_priv->information_buf;
+	TxCmd_Info = (TX_CMD_Desc *)poid_par_priv->information_buf;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("WRITE_TXCMD:Addr=%.8X\n", TxCmd_Info->offset));
-  	RT_TRACE(_module_mp_, _drv_info_, ("WRITE_TXCMD:1.)%.8X\n", (ULONG)TxCmd_Info->TxCMD.value[0]));
-	RT_TRACE(_module_mp_, _drv_info_, ("WRITE_TXCMD:2.)%.8X\n", (ULONG)TxCmd_Info->TxCMD.value[1]));
-	RT_TRACE(_module_mp_, _drv_info_, (("WRITE_TXCMD:3.)%.8X\n", (ULONG)TxCmd_Info->TxCMD.value[2]));
-	RT_TRACE(_module_mp_, _drv_info_, ("WRITE_TXCMD:4.)%.8X\n", (ULONG)TxCmd_Info->TxCMD.value[3]));
 
-	_irqlevel_changed_(&oldirql, LOWER);
+		 _irqlevel_changed_(&oldirql, LOWER);
 
-	rtw_write32(Adapter, TxCmd_Info->offset + 0, (unsigned int)TxCmd_Info->TxCMD.value[0]);
-	rtw_write32(Adapter, TxCmd_Info->offset + 4, (unsigned int)TxCmd_Info->TxCMD.value[1]);
+		rtw_write32(Adapter, TxCmd_Info->offset + 0, (unsigned int)TxCmd_Info->TxCMD.value[0]);
+		rtw_write32(Adapter, TxCmd_Info->offset + 4, (unsigned int)TxCmd_Info->TxCMD.value[1]);
 
-	_irqlevel_changed_(&oldirql, RAISE);
+		 _irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("-Set OID_RT_PRO_WRITE_TXCMD: status=0x%08X\n", status));
 
-_func_exit_;
 
-	return status;
+		 return status;
 #else
 	return 0;
 #endif
 }
 
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_read16_eeprom_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1154,9 +1007,7 @@ NDIS_STATUS oid_rt_pro_read16_eeprom_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("+Query OID_RT_PRO_READ16_EEPROM\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1169,11 +1020,7 @@ _func_enter_;
 
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_,  _drv_notice_,
-		 ("-Query OID_RT_PRO_READ16_EEPROM: offset=0x%x value=0x%x\n",
-		  pEEPROM->offset, pEEPROM->value));
 
-_func_exit_;
 
 	return status;
 #else
@@ -1181,8 +1028,8 @@ _func_exit_;
 #endif
 }
 
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_pro_write16_eeprom_hdl (struct oid_par_priv *poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_pro_write16_eeprom_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
 #ifdef PLATFORM_OS_XP
@@ -1192,9 +1039,7 @@ NDIS_STATUS oid_rt_pro_write16_eeprom_hdl (struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+Set OID_RT_PRO_WRITE16_EEPROM\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1207,24 +1052,22 @@ _func_enter_;
 
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro8711_wi_poll_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
-	PADAPTER	Adapter = (PADAPTER)( poid_par_priv->adapter_context);
+	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
 	struct mp_wiparam *pwi_param;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1239,54 +1082,48 @@ _func_enter_;
 
 	_rtw_memcpy(pwi_param, &Adapter->mppriv.workparam, sizeof(struct mp_wiparam));
 	Adapter->mppriv.act_in_progress = _FALSE;
-//	RT_TRACE(_module_mp_, _drv_info_, ("rf:%x\n", pwiparam->IoValue));
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro8711_pkt_loss_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
-	PADAPTER	Adapter = (PADAPTER)( poid_par_priv->adapter_context);
+	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro8711_pkt_loss_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	if (poid_par_priv->information_buf_len < sizeof(uint)*2) {
-		RT_TRACE(_module_mp_, _drv_err_, ("-oid_rt_pro8711_pkt_loss_hdl: buf_len=%d\n", (int)poid_par_priv->information_buf_len));
+	if (poid_par_priv->information_buf_len < sizeof(uint) * 2) {
 		return NDIS_STATUS_INVALID_LENGTH;
 	}
 
-	if (*(uint*)poid_par_priv->information_buf == 1)//init==1
+	if (*(uint *)poid_par_priv->information_buf == 1) /* init==1 */
 		Adapter->mppriv.rx_pktloss = 0;
 
-	*((uint*)poid_par_priv->information_buf+1) = Adapter->mppriv.rx_pktloss;
+	*((uint *)poid_par_priv->information_buf + 1) = Adapter->mppriv.rx_pktloss;
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_rd_attrib_mem_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
-	PADAPTER	Adapter = (PADAPTER)( poid_par_priv->adapter_context);
+	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 	struct io_queue *pio_queue = (struct io_queue *)Adapter->pio_queue;
 	struct intf_hdl	*pintfhdl = &pio_queue->intf;
 
@@ -1299,34 +1136,31 @@ NDIS_STATUS oid_rt_rd_attrib_mem_hdl(struct oid_par_priv *poid_par_priv)
 	void (*_attrib_read)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
 #endif
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+Query OID_RT_RD_ATTRIB_MEM\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
 #ifdef CONFIG_SDIO_HCI
 	_irqlevel_changed_(&oldirql, LOWER);
-{
-	u32 *plmem = (u32*)poid_par_priv->information_buf+2;
-	_attrib_read = pintfhdl->io_ops._attrib_read;
-	_attrib_read(pintfhdl, *((u32*)poid_par_priv->information_buf),
-				*((u32*)poid_par_priv->information_buf+1), (u8*)plmem);
-	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-}
+	{
+		u32 *plmem = (u32 *)poid_par_priv->information_buf + 2;
+		_attrib_read = pintfhdl->io_ops._attrib_read;
+		_attrib_read(pintfhdl, *((u32 *)poid_par_priv->information_buf),
+			*((u32 *)poid_par_priv->information_buf + 1), (u8 *)plmem);
+		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
+	}
 	_irqlevel_changed_(&oldirql, RAISE);
 #endif
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
-NDIS_STATUS oid_rt_wr_attrib_mem_hdl (struct oid_par_priv *poid_par_priv)
+/* ------------------------------------------------------------------------------ */
+NDIS_STATUS oid_rt_wr_attrib_mem_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
@@ -1342,30 +1176,28 @@ NDIS_STATUS oid_rt_wr_attrib_mem_hdl (struct oid_par_priv *poid_par_priv)
 	void (*_attrib_write)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
 #endif
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
 #ifdef CONFIG_SDIO_HCI
 	_irqlevel_changed_(&oldirql, LOWER);
-{
-	u32 *plmem = (u32*)poid_par_priv->information_buf + 2;
-	_attrib_write = pintfhdl->io_ops._attrib_write;
-	_attrib_write(pintfhdl, *(u32*)poid_par_priv->information_buf,
-				*((u32*)poid_par_priv->information_buf+1), (u8*)plmem);
-}
+	{
+		u32 *plmem = (u32 *)poid_par_priv->information_buf + 2;
+		_attrib_write = pintfhdl->io_ops._attrib_write;
+		_attrib_write(pintfhdl, *(u32 *)poid_par_priv->information_buf,
+			*((u32 *)poid_par_priv->information_buf + 1), (u8 *)plmem);
+	}
 	_irqlevel_changed_(&oldirql, RAISE);
 #endif
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS  oid_rt_pro_set_rf_intfs_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1376,28 +1208,25 @@ NDIS_STATUS  oid_rt_pro_set_rf_intfs_hdl(struct oid_par_priv *poid_par_priv)
 #endif
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+OID_RT_PRO_SET_RF_INTFS\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
-	if (rtw_setrfintfs_cmd(Adapter, *(unsigned char*)poid_par_priv->information_buf) == _FAIL)
+	if (rtw_setrfintfs_cmd(Adapter, *(unsigned char *)poid_par_priv->information_buf) == _FAIL)
 		status = NDIS_STATUS_NOT_ACCEPTED;
 
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_poll_rx_status_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1405,22 +1234,20 @@ NDIS_STATUS oid_rt_poll_rx_status_hdl(struct oid_par_priv *poid_par_priv)
 
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	_rtw_memcpy(poid_par_priv->information_buf, (unsigned char*)&Adapter->mppriv.rxstat, sizeof(struct recv_stat));
+	_rtw_memcpy(poid_par_priv->information_buf, (unsigned char *)&Adapter->mppriv.rxstat, sizeof(struct recv_stat));
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_cfg_debug_message_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1430,45 +1257,33 @@ NDIS_STATUS oid_rt_pro_cfg_debug_message_hdl(struct oid_par_priv *poid_par_priv)
 
 	PCFG_DBG_MSG_STRUCT pdbg_msg;
 
-_func_enter_;
 
-//	RT_TRACE(0xffffffffff,_drv_alert_,("===> oid_rt_pro_cfg_debug_message_hdl.\n"));
 
-#if 0//#ifdef CONFIG_DEBUG_RTL871X
+#if 0/*#ifdef CONFIG_DEBUG_RTL871X*/
 
 	pdbg_msg = (PCFG_DBG_MSG_STRUCT)(poid_par_priv->information_buf);
 
 	if (poid_par_priv->type_of_oid == SET_OID) {
-		RT_TRACE(0xffffffffff, _drv_alert_,
-			 ("===>Set level :0x%08x, H32:0x%08x L32:0x%08x\n",
-			  pdbg_msg->DebugLevel, pdbg_msg->DebugComponent_H32, pdbg_msg->DebugComponent_L32));
 
 		GlobalDebugLevel = pdbg_msg->DebugLevel;
 		GlobalDebugComponents = (pdbg_msg->DebugComponent_H32 << 32) | pdbg_msg->DebugComponent_L32;
-		RT_TRACE(0xffffffffff, _drv_alert_,
-			 ("===> Set level :0x%08x, component:0x%016x\n",
-			  GlobalDebugLevel, (u32)GlobalDebugComponents));
 	} else {
 		pdbg_msg->DebugLevel = GlobalDebugLevel;
 		pdbg_msg->DebugComponent_H32 = (u32)(GlobalDebugComponents >> 32);
 		pdbg_msg->DebugComponent_L32 = (u32)GlobalDebugComponents;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-		RT_TRACE(0xffffffffff, _drv_alert_,
-			 ("===>Query level:0x%08x H32:0x%08x L32:0x%08x\n",
-			  (u32)pdbg_msg->DebugLevel, (u32)pdbg_msg->DebugComponent_H32, (u32)pdbg_msg->DebugComponent_L32));
 	}
 
 #endif
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_set_data_rate_ex_hdl(struct oid_par_priv *poid_par_priv)
 {
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
@@ -1478,25 +1293,22 @@ NDIS_STATUS oid_rt_pro_set_data_rate_ex_hdl(struct oid_par_priv *poid_par_priv)
 #endif
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+OID_RT_PRO_SET_DATA_RATE_EX\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
-	if (rtw_setdatarate_cmd(Adapter, poid_par_priv->information_buf) !=_SUCCESS)
+	if (rtw_setdatarate_cmd(Adapter, poid_par_priv->information_buf) != _SUCCESS)
 		status = NDIS_STATUS_NOT_ACCEPTED;
 
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//-----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------- */
 NDIS_STATUS oid_rt_get_thermal_meter_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -1506,9 +1318,7 @@ NDIS_STATUS oid_rt_get_thermal_meter_hdl(struct oid_par_priv *poid_par_priv)
 	u8 thermal = 0;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_get_thermal_meter_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1520,14 +1330,13 @@ _func_enter_;
 	GetThermalMeter(Adapter, &thermal);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	*(u32*)poid_par_priv->information_buf = (u32)thermal;
+	*(u32 *)poid_par_priv->information_buf = (u32)thermal;
 	*poid_par_priv->bytes_rw = sizeof(u32);
 
-_func_exit_;
 
 	return status;
 }
-//-----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------- */
 NDIS_STATUS oid_rt_pro_read_tssi_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1538,9 +1347,7 @@ NDIS_STATUS oid_rt_pro_read_tssi_hdl(struct oid_par_priv *poid_par_priv)
 #endif
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_read_tssi_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1551,7 +1358,7 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len < sizeof(u8))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	//init workparam
+	/* init workparam */
 	Adapter->mppriv.act_in_progress = _TRUE;
 	Adapter->mppriv.workparam.bcompleted = _FALSE;
 	Adapter->mppriv.workparam.act_type = MPT_READ_TSSI;
@@ -1560,19 +1367,18 @@ _func_enter_;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
-	if (!rtw_gettssi_cmd(Adapter,0, (u8*)&Adapter->mppriv.workparam.io_value))
+	if (!rtw_gettssi_cmd(Adapter, 0, (u8 *)&Adapter->mppriv.workparam.io_value))
 		status = NDIS_STATUS_NOT_ACCEPTED;
 
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_set_power_tracking_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -1582,10 +1388,9 @@ NDIS_STATUS oid_rt_pro_set_power_tracking_hdl(struct oid_par_priv *poid_par_priv
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 
-_func_enter_;
 
-//	if (poid_par_priv->type_of_oid != SET_OID)
-//		return NDIS_STATUS_NOT_ACCEPTED;
+	/*	if (poid_par_priv->type_of_oid != SET_OID)
+	 *		return NDIS_STATUS_NOT_ACCEPTED; */
 
 	if (poid_par_priv->information_buf_len < sizeof(u8))
 		return NDIS_STATUS_INVALID_LENGTH;
@@ -1594,21 +1399,17 @@ _func_enter_;
 	if (poid_par_priv->type_of_oid == SET_OID) {
 		u8 enable;
 
-		enable = *(u8*)poid_par_priv->information_buf;
-		RT_TRACE(_module_mp_, _drv_notice_,
-			 ("+oid_rt_pro_set_power_tracking_hdl: enable=%d\n", enable));
+		enable = *(u8 *)poid_par_priv->information_buf;
 
 		SetPowerTracking(Adapter, enable);
-	} else {
-		GetPowerTracking(Adapter, (u8*)poid_par_priv->information_buf);
-	}
+	} else
+		GetPowerTracking(Adapter, (u8 *)poid_par_priv->information_buf);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//-----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------- */
 NDIS_STATUS oid_rt_pro_set_basic_rate_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1621,21 +1422,18 @@ NDIS_STATUS oid_rt_pro_set_basic_rate_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("+OID_RT_PRO_SET_BASIC_RATE\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 #if 0
-	ratevalue = *((u32*)poid_par_priv->information_buf);
+	ratevalue = *((u32 *)poid_par_priv->information_buf);
 
 	for (i = 0; i < NumRates; i++) {
 		if (ratevalue == mpdatarate[i])
 			datarates[i] = mpdatarate[i];
 		else
 			datarates[i] = 0xff;
-		RT_TRACE(_module_rtl871x_ioctl_c_, _drv_info_, ("basicrate_inx=%d\n", datarates[i]));
 	}
 
 	_irqlevel_changed_(&oldirql, LOWER);
@@ -1645,17 +1443,14 @@ _func_enter_;
 
 	_irqlevel_changed_(&oldirql, RAISE);
 #endif
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("-OID_RT_PRO_SET_BASIC_RATE: status=0x%08X\n", status));
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_qry_pwrstate_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1663,7 +1458,6 @@ NDIS_STATUS oid_rt_pro_qry_pwrstate_hdl(struct oid_par_priv *poid_par_priv)
 
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1675,18 +1469,14 @@ _func_enter_;
 	_rtw_memcpy(poid_par_priv->information_buf, &(adapter_to_pwrctl(Adapter)->pwr_mode), 8);
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("-oid_rt_pro_qry_pwrstate_hdl: pwr_mode=%d smart_ps=%d\n",
-		  adapter_to_pwrctl(Adapter)->pwr_mode, adapter_to_pwrctl(Adapter)->smart_ps));
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_set_pwrstate_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1696,9 +1486,7 @@ NDIS_STATUS oid_rt_pro_set_pwrstate_hdl(struct oid_par_priv *poid_par_priv)
 
 	uint pwr_mode, smart_ps;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+Set OID_RT_PRO_SET_PWRSTATE\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1714,14 +1502,13 @@ _func_enter_;
 
 	*poid_par_priv->bytes_rw = 8;
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_h2c_set_rate_table_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1735,7 +1522,6 @@ NDIS_STATUS oid_rt_pro_h2c_set_rate_table_hdl(struct oid_par_priv *poid_par_priv
 	struct setratable_parm *prate_table;
 	u8		res;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -1744,7 +1530,7 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len < sizeof(struct setratable_parm))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	prate_table = (struct setratable_parm*)poid_par_priv->information_buf;
+	prate_table = (struct setratable_parm *)poid_par_priv->information_buf;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	res = rtw_setrttbl_cmd(Adapter, prate_table);
@@ -1753,14 +1539,13 @@ _func_enter_;
 	if (res == _FAIL)
 		status = NDIS_STATUS_FAILURE;
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_h2c_get_rate_table_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1768,40 +1553,35 @@ NDIS_STATUS oid_rt_pro_h2c_get_rate_table_hdl(struct oid_par_priv *poid_par_priv
 
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	#if 0
-			struct mp_wi_cntx *pmp_wi_cntx=&(Adapter->mppriv.wi_cntx);
-			u8 res=_SUCCESS;
-			DEBUG_INFO(("===> Set OID_RT_PRO_H2C_GET_RATE_TABLE.\n"));
-
-			if(pmp_wi_cntx->bmp_wi_progress ==_TRUE){
-				DEBUG_ERR(("\n mp workitem is progressing, not allow to set another workitem right now!!!\n"));
-				Status = NDIS_STATUS_NOT_ACCEPTED;
-				break;
-			}
-			else{
-				pmp_wi_cntx->bmp_wi_progress=_TRUE;
-				pmp_wi_cntx->param.bcompleted=_FALSE;
-				pmp_wi_cntx->param.act_type=MPT_GET_RATE_TABLE;
-				pmp_wi_cntx->param.io_offset=0x0;
-				pmp_wi_cntx->param.bytes_cnt=sizeof(struct getratable_rsp);
-				pmp_wi_cntx->param.io_value=0xffffffff;
-
-				res=rtw_getrttbl_cmd(Adapter,(struct getratable_rsp *)pmp_wi_cntx->param.data);
-				*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-				if(res != _SUCCESS)
-				{
-					Status = NDIS_STATUS_NOT_ACCEPTED;
-				}
-			}
-			DEBUG_INFO(("\n <=== Set OID_RT_PRO_H2C_GET_RATE_TABLE.\n"));
-	#endif
+#if 0
+	struct mp_wi_cntx *pmp_wi_cntx = &(Adapter->mppriv.wi_cntx);
+	u8 res = _SUCCESS;
+	DEBUG_INFO(("===> Set OID_RT_PRO_H2C_GET_RATE_TABLE.\n"));
+
+	if (pmp_wi_cntx->bmp_wi_progress == _TRUE) {
+		DEBUG_ERR(("\n mp workitem is progressing, not allow to set another workitem right now!!!\n"));
+		Status = NDIS_STATUS_NOT_ACCEPTED;
+		break;
+	} else {
+		pmp_wi_cntx->bmp_wi_progress = _TRUE;
+		pmp_wi_cntx->param.bcompleted = _FALSE;
+		pmp_wi_cntx->param.act_type = MPT_GET_RATE_TABLE;
+		pmp_wi_cntx->param.io_offset = 0x0;
+		pmp_wi_cntx->param.bytes_cnt = sizeof(struct getratable_rsp);
+		pmp_wi_cntx->param.io_value = 0xffffffff;
+
+		res = rtw_getrttbl_cmd(Adapter, (struct getratable_rsp *)pmp_wi_cntx->param.data);
+		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
+		if (res != _SUCCESS)
+			Status = NDIS_STATUS_NOT_ACCEPTED;
+	}
+	DEBUG_INFO(("\n <=== Set OID_RT_PRO_H2C_GET_RATE_TABLE.\n"));
+#endif
 
-_func_exit_;
 
 	return status;
 #else
@@ -1809,7 +1589,7 @@ _func_exit_;
 #endif
 }
 
-//****************  oid_rtl_seg_87_12_00   section start ****************
+/* ****************  oid_rtl_seg_87_12_00   section start **************** */
 NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1825,68 +1605,61 @@ NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv *poid_par_priv)
 	if (poid_par_priv->information_buf_len < *poid_par_priv->bytes_needed)
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	if (poid_par_priv->type_of_oid == SET_OID)
-	{
-		encry_mode = *((u8*)poid_par_priv->information_buf);
-		switch (encry_mode)
-		{
-			case HW_CONTROL:
-				#if 0
-				Adapter->registrypriv.software_decrypt=_FALSE;
-				Adapter->registrypriv.software_encrypt=_FALSE;
-				#else
-				psecuritypriv->sw_decrypt = _FALSE;
-				psecuritypriv->sw_encrypt = _FALSE;
-				#endif
-				break;
-			case SW_CONTROL:
-				#if 0
-				Adapter->registrypriv.software_decrypt=_TRUE;
-				Adapter->registrypriv.software_encrypt=_TRUE;
-				#else
-				psecuritypriv->sw_decrypt = _TRUE;
-				psecuritypriv->sw_encrypt = _TRUE;
-				#endif
-				break;
-			case HW_ENCRY_SW_DECRY:
-				#if 0
-				Adapter->registrypriv.software_decrypt=_TRUE;
-				Adapter->registrypriv.software_encrypt=_FALSE;
-				#else
-				psecuritypriv->sw_decrypt = _TRUE;
-				psecuritypriv->sw_encrypt = _FALSE;
-				#endif
-				break;
-			case SW_ENCRY_HW_DECRY:
-				#if 0
-				Adapter->registrypriv.software_decrypt=_FALSE;
-				Adapter->registrypriv.software_encrypt=_TRUE;
-				#else
-				psecuritypriv->sw_decrypt = _FALSE;
-				psecuritypriv->sw_encrypt = _TRUE;
-				#endif
-				break;
+	if (poid_par_priv->type_of_oid == SET_OID) {
+		encry_mode = *((u8 *)poid_par_priv->information_buf);
+		switch (encry_mode) {
+		case HW_CONTROL:
+#if 0
+			Adapter->registrypriv.software_decrypt = _FALSE;
+			Adapter->registrypriv.software_encrypt = _FALSE;
+#else
+			psecuritypriv->sw_decrypt = _FALSE;
+			psecuritypriv->sw_encrypt = _FALSE;
+#endif
+			break;
+		case SW_CONTROL:
+#if 0
+			Adapter->registrypriv.software_decrypt = _TRUE;
+			Adapter->registrypriv.software_encrypt = _TRUE;
+#else
+			psecuritypriv->sw_decrypt = _TRUE;
+			psecuritypriv->sw_encrypt = _TRUE;
+#endif
+			break;
+		case HW_ENCRY_SW_DECRY:
+#if 0
+			Adapter->registrypriv.software_decrypt = _TRUE;
+			Adapter->registrypriv.software_encrypt = _FALSE;
+#else
+			psecuritypriv->sw_decrypt = _TRUE;
+			psecuritypriv->sw_encrypt = _FALSE;
+#endif
+			break;
+		case SW_ENCRY_HW_DECRY:
+#if 0
+			Adapter->registrypriv.software_decrypt = _FALSE;
+			Adapter->registrypriv.software_encrypt = _TRUE;
+#else
+			psecuritypriv->sw_decrypt = _FALSE;
+			psecuritypriv->sw_encrypt = _TRUE;
+#endif
+			break;
 		}
 
-		RT_TRACE(_module_rtl871x_ioctl_c_, _drv_notice_,
-			 ("-oid_rt_pro_encryption_ctrl_hdl: SET encry_mode=0x%x sw_encrypt=0x%x sw_decrypt=0x%x\n",
-			  encry_mode, psecuritypriv->sw_encrypt, psecuritypriv->sw_decrypt));
-	}
-	else {
-		#if 0
+	} else {
+#if 0
 		if (Adapter->registrypriv.software_encrypt == _FALSE) {
 			if (Adapter->registrypriv.software_decrypt == _FALSE)
 				encry_mode = HW_CONTROL;
 			else
 				encry_mode = HW_ENCRY_SW_DECRY;
-		}
-		else {
+		} else {
 			if (Adapter->registrypriv.software_decrypt == _FALSE)
 				encry_mode = SW_ENCRY_HW_DECRY;
 			else
 				encry_mode = SW_CONTROL;
 		}
-		#else
+#else
 
 		if ((psecuritypriv->sw_encrypt == _FALSE) && (psecuritypriv->sw_decrypt == _FALSE))
 			encry_mode = HW_CONTROL;
@@ -1897,14 +1670,11 @@ NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv *poid_par_priv)
 		else if ((psecuritypriv->sw_encrypt == _TRUE) && (psecuritypriv->sw_decrypt == _TRUE))
 			encry_mode = SW_CONTROL;
 
-		#endif
+#endif
 
-		*(u8*)poid_par_priv->information_buf =  encry_mode;
+		*(u8 *)poid_par_priv->information_buf =  encry_mode;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-		RT_TRACE(_module_mp_, _drv_notice_,
-			 ("-oid_rt_pro_encryption_ctrl_hdl: QUERY encry_mode=0x%x\n",
-			  encry_mode));
 	}
 
 	return status;
@@ -1912,7 +1682,7 @@ NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv *poid_par_priv)
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1924,7 +1694,7 @@ NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
 	struct sta_info *psta = NULL;
-	UCHAR 		*macaddr;
+	UCHAR		*macaddr;
 
 
 	if (poid_par_priv->type_of_oid != SET_OID)
@@ -1936,23 +1706,17 @@ NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv *poid_par_priv)
 
 	macaddr = (UCHAR *) poid_par_priv->information_buf ;
 
-	RT_TRACE(_module_rtl871x_ioctl_c_,_drv_notice_,
-		 ("OID_RT_PRO_ADD_STA_INFO: addr="MAC_FMT"\n", MAC_ARG(macaddr) ));
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
 	psta = rtw_get_stainfo(&Adapter->stapriv, macaddr);
 
-	if (psta == NULL) { // the sta have been in sta_info_queue => do nothing
+	if (psta == NULL) { /* the sta have been in sta_info_queue => do nothing */
 		psta = rtw_alloc_stainfo(&Adapter->stapriv, macaddr);
 
 		if (psta == NULL) {
-			RT_TRACE(_module_rtl871x_ioctl_c_,_drv_err_,("Can't alloc sta_info when OID_RT_PRO_ADD_STA_INFO\n"));
 			status = NDIS_STATUS_FAILURE;
 		}
-	} else { //(between drv has received this event before and  fw have not yet to set key to CAM_ENTRY)
-		RT_TRACE(_module_rtl871x_ioctl_c_, _drv_err_,
-			("Error: OID_RT_PRO_ADD_STA_INFO: sta has been in sta_hash_queue \n"));
 	}
 
 	_irqlevel_changed_(&oldirql, RAISE);
@@ -1962,7 +1726,7 @@ NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv *poid_par_priv)
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_dele_sta_info_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -1985,14 +1749,12 @@ NDIS_STATUS oid_rt_pro_dele_sta_info_hdl(struct oid_par_priv *poid_par_priv)
 		return NDIS_STATUS_INVALID_LENGTH;
 
 	macaddr = (UCHAR *) poid_par_priv->information_buf ;
-	RT_TRACE(_module_rtl871x_ioctl_c_,_drv_notice_,
-		 ("+OID_RT_PRO_ADD_STA_INFO: addr="MAC_FMT"\n", MAC_ARG(macaddr) ));
 
 	psta = rtw_get_stainfo(&Adapter->stapriv, macaddr);
 	if (psta != NULL) {
-		//_enter_critical(&(Adapter->stapriv.sta_hash_lock), &irqL);
+		/* _enter_critical(&(Adapter->stapriv.sta_hash_lock), &irqL); */
 		rtw_free_stainfo(Adapter, psta);
-		//_exit_critical(&(Adapter->stapriv.sta_hash_lock), &irqL);
+		/* _exit_critical(&(Adapter->stapriv.sta_hash_lock), &irqL); */
 	}
 
 	return status;
@@ -2000,7 +1762,7 @@ NDIS_STATUS oid_rt_pro_dele_sta_info_hdl(struct oid_par_priv *poid_par_priv)
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 #if 0
 static u32 mp_query_drv_var(_adapter *padapter, u8 offset, u32 var)
 {
@@ -2009,167 +1771,90 @@ static u32 mp_query_drv_var(_adapter *padapter, u8 offset, u32 var)
 	if (offset == 1) {
 		u16 tmp_blk_num;
 		tmp_blk_num = rtw_read16(padapter, SDIO_RX0_RDYBLK_NUM);
-		RT_TRACE(_module_mp_, _drv_err_, ("Query Information, mp_query_drv_var  SDIO_RX0_RDYBLK_NUM=0x%x   dvobj.rxblknum=0x%x\n", tmp_blk_num, adapter_to_dvobj(padapter)->rxblknum));
 		if (adapter_to_dvobj(padapter)->rxblknum != tmp_blk_num) {
-			RT_TRACE(_module_mp_,_drv_err_, ("Query Information, mp_query_drv_var  call recv rx\n"));
-		//	sd_recv_rxfifo(padapter);
+			/*	sd_recv_rxfifo(padapter); */
 		}
 	}
 
 #if 0
-	if(offset <=100){  //For setting data rate and query data rate
-		if(offset==100){ //For query data rate
-			RT_TRACE(_module_mp_, _drv_emerg_, ("\n mp_query_drv_var: offset(%d): query rate=0x%.2x \n",offset,padapter->registrypriv.tx_rate));
-			var=padapter->registrypriv.tx_rate;
-
+	if (offset <= 100) { /* For setting data rate and query data rate */
+		if (offset == 100) { /* For query data rate */
+			var = padapter->registrypriv.tx_rate;
+
+		} else if (offset < 0x1d) { /* For setting data rate */
+			padapter->registrypriv.tx_rate = offset;
+			var = padapter->registrypriv.tx_rate;
+			padapter->registrypriv.use_rate = _TRUE;
+		} else { /* not use the data rate */
+			padapter->registrypriv.use_rate = _FALSE;
 		}
-		else if(offset<0x1d){  //For setting data rate
-			padapter->registrypriv.tx_rate=offset;
-			var=padapter->registrypriv.tx_rate;
-			padapter->registrypriv.use_rate=_TRUE;
-			RT_TRACE(_module_mp_, _drv_emerg_, ("\n mp_query_drv_var: offset(%d): set rate=0x%.2x \n",offset,padapter->registrypriv.tx_rate));
-		}
-		else{ //not use the data rate
-			padapter->registrypriv.use_rate=_FALSE;
-			RT_TRACE(_module_mp_, _drv_emerg_, ("\n mp_query_drv_var: offset(%d) out of rate range\n",offset));
-		}
-	}
-	else if (offset<=110){  //for setting debug level
-		RT_TRACE(_module_mp_, _drv_emerg_, (" mp_query_drv_var: offset(%d) for set debug level\n",offset));
-		if(offset==110){ //For query data rate
-			RT_TRACE(_module_mp_, _drv_emerg_, (" mp_query_drv_var: offset(%d): query dbg level=0x%.2x \n",offset,padapter->registrypriv.dbg_level));
-			padapter->registrypriv.dbg_level=GlobalDebugLevel;
-			var=padapter->registrypriv.dbg_level;
-		}
-		else if(offset<110 && offset>100){
-			RT_TRACE(_module_mp_, _drv_emerg_, (" mp_query_drv_var: offset(%d): set dbg level=0x%.2x \n",offset,offset-100));
-			padapter->registrypriv.dbg_level=GlobalDebugLevel=offset-100;
-			var=padapter->registrypriv.dbg_level;
-			RT_TRACE(_module_mp_, _drv_emerg_, (" mp_query_drv_var(_drv_emerg_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
-			RT_TRACE(_module_mp_, _drv_alert_, (" mp_query_drv_var(_drv_alert_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
-			RT_TRACE(_module_mp_, _drv_crit_, (" mp_query_drv_var(_drv_crit_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
-			RT_TRACE(_module_mp_, _drv_err_, (" mp_query_drv_var(_drv_err_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
-			RT_TRACE(_module_mp_, _drv_warning_, (" mp_query_drv_var(_drv_warning_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
-			RT_TRACE(_module_mp_, _drv_notice_, (" mp_query_drv_var(_drv_notice_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
-			RT_TRACE(_module_mp_, _drv_info_, (" mp_query_drv_var(_drv_info_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
-			RT_TRACE(_module_mp_, _drv_debug_, (" mp_query_drv_var(_drv_debug_): offset(%d): set dbg level=0x%.2x \n",offset,GlobalDebugLevel));
+	} else if (offset <= 110) { /* for setting debug level */
+		if (offset == 110) { /* For query data rate */
+			padapter->registrypriv.dbg_level = GlobalDebugLevel;
+			var = padapter->registrypriv.dbg_level;
+		} else if (offset < 110 && offset > 100) {
+			padapter->registrypriv.dbg_level = GlobalDebugLevel = offset - 100;
+			var = padapter->registrypriv.dbg_level;
 
 		}
-	}
-	else if(offset >110 &&offset <116){
-		if(115==offset){
-			RT_TRACE(_module_mp_, _drv_emerg_, (" mp_query_drv_var(_drv_emerg_): offset(%d): query TRX access type: [tx_block_mode=%x,rx_block_mode=%x]\n",\
-															offset, adapter_to_dvobj(padapter)->tx_block_mode, adapter_to_dvobj(padapter)->rx_block_mode));
-		}
-		else {
-			switch(offset){
-				case 111:
-					adapter_to_dvobj(padapter)->tx_block_mode=1;
-					adapter_to_dvobj(padapter)->rx_block_mode=1;
-					RT_TRACE(_module_mp_, _drv_emerg_, \
-						(" mp_query_drv_var(_drv_emerg_): offset(%d): SET TRX access type:(TX block/RX block) [tx_block_mode=%x,rx_block_mode=%x]\n",\
-						offset, adapter_to_dvobj(padapter)->tx_block_mode, adapter_to_dvobj(padapter)->rx_block_mode));
-					break;
-				case 112:
-					adapter_to_dvobj(padapter)->tx_block_mode=1;
-					adapter_to_dvobj(padapter)->rx_block_mode=0;
-					RT_TRACE(_module_mp_, _drv_emerg_, \
-						(" mp_query_drv_var(_drv_emerg_): offset(%d): SET TRX access type:(TX block/RX byte) [tx_block_mode=%x,rx_block_mode=%x]\n",\
-						offset, adapter_to_dvobj(padapter)->tx_block_mode, adapter_to_dvobj(padapter)->rx_block_mode));
-					break;
-				case 113:
-					adapter_to_dvobj(padapter)->tx_block_mode=0;
-					adapter_to_dvobj(padapter)->rx_block_mode=1;
-					RT_TRACE(_module_mp_, _drv_emerg_, \
-						(" mp_query_drv_var(_drv_emerg_): offset(%d): SET TRX access type:(TX byte/RX block) [tx_block_mode=%x,rx_block_mode=%x]\n",\
-						offset, adapter_to_dvobj(padapter)->tx_block_mode, adapter_to_dvobj(padapter)->rx_block_mode));
-					break;
-				case 114:
-					adapter_to_dvobj(padapter)->tx_block_mode=0;
-					adapter_to_dvobj(padapter)->rx_block_mode=0;
-					RT_TRACE(_module_mp_, _drv_emerg_, \
-						(" mp_query_drv_var(_drv_emerg_): offset(%d): SET TRX access type:(TX byte/RX byte) [tx_block_mode=%x,rx_block_mode=%x]\n",\
-						offset, adapter_to_dvobj(padapter)->tx_block_mode, adapter_to_dvobj(padapter)->rx_block_mode));
-					break;
-				default :
-					break;
+	} else if (offset > 110 && offset < 116) {
+		if (115 == offset) {
+		} else {
+			switch (offset) {
+			case 111:
+				adapter_to_dvobj(padapter)->tx_block_mode = 1;
+				adapter_to_dvobj(padapter)->rx_block_mode = 1;
+				break;
+			case 112:
+				adapter_to_dvobj(padapter)->tx_block_mode = 1;
+				adapter_to_dvobj(padapter)->rx_block_mode = 0;
+				break;
+			case 113:
+				adapter_to_dvobj(padapter)->tx_block_mode = 0;
+				adapter_to_dvobj(padapter)->rx_block_mode = 1;
+				break;
+			case 114:
+				adapter_to_dvobj(padapter)->tx_block_mode = 0;
+				adapter_to_dvobj(padapter)->rx_block_mode = 0;
+				break;
+			default:
+				break;
 
 			}
 
 		}
 
-	}
-	else if(offset>=127){
+	} else if (offset >= 127) {
 		u64	prnt_dbg_comp;
 		u8   chg_idx;
 		u64	tmp_dbg_comp;
-		chg_idx=offset-0x80;
-		tmp_dbg_comp=BIT(chg_idx);
-		prnt_dbg_comp=padapter->registrypriv.dbg_component= GlobalDebugComponents;
-		RT_TRACE(_module_mp_, _drv_emerg_, (" 1: mp_query_drv_var: offset(%d;0x%x):for dbg conpoment prnt_dbg_comp=0x%.16x GlobalDebugComponents=0x%.16x padapter->registrypriv.dbg_component=0x%.16x\n",offset,offset,prnt_dbg_comp,GlobalDebugComponents,padapter->registrypriv.dbg_component));
-		if(offset==127){
-	//		prnt_dbg_comp=padapter->registrypriv.dbg_component= GlobalDebugComponents;
-			var=(u32)(padapter->registrypriv.dbg_component);
-			RT_TRACE(0xffffffff, _drv_emerg_, ("2: mp_query_drv_var: offset(%d;0x%x):for query dbg conpoment=0x%x(l) 0x%x(h)  GlobalDebugComponents=0x%x(l) 0x%x(h) \n",offset,offset,padapter->registrypriv.dbg_component,prnt_dbg_comp));
-			prnt_dbg_comp=GlobalDebugComponents;
-			RT_TRACE(0xffffffff, _drv_emerg_, ("2-1: mp_query_drv_var: offset(%d;0x%x):for query dbg conpoment=0x%x(l) 0x%x(h)  GlobalDebugComponents=0x%x(l) 0x%x(h)\n",offset,offset,padapter->registrypriv.dbg_component,prnt_dbg_comp));
-			prnt_dbg_comp=GlobalDebugComponents=padapter->registrypriv.dbg_component;
-			RT_TRACE(0xffffffff, _drv_emerg_, ("2-2: mp_query_drv_var: offset(%d;0x%x):for query dbg conpoment=0x%x(l) 0x%x(h)  GlobalDebugComponents=0x%x(l) 0x%x(h)\n",offset,offset,padapter->registrypriv.dbg_component,prnt_dbg_comp));
-
-		}
-		else{
-			RT_TRACE(0xffffffff, _drv_emerg_, ("3: mp_query_drv_var: offset(%d;0x%x):for query dbg conpoment=0x%x(l) 0x%x(h) GlobalDebugComponents=0x%x(l) 0x%x(h) chg_idx=%d\n",offset,offset,padapter->registrypriv.dbg_component,prnt_dbg_comp,chg_idx));
-			prnt_dbg_comp=GlobalDebugComponents;
-			RT_TRACE(0xffffffff, _drv_emerg_,("3-1: mp_query_drv_var: offset(%d;0x%x):for query dbg conpoment=0x%x(l) 0x%x(h)  GlobalDebugComponents=0x%x(l) 0x%x(h) chg_idx=%d\n",offset,offset,padapter->registrypriv.dbg_component,prnt_dbg_comp,chg_idx));// ("3-1: mp_query_drv_var: offset(%d;0x%x):before set dbg conpoment=0x%x chg_idx=%d or0x%x BIT(chg_idx[%d]=0x%x)\n",offset,offset,prnt_dbg_comp,chg_idx,chg_idx,(chg_idx),tmp_dbg_comp)
-			prnt_dbg_comp=GlobalDebugComponents=padapter->registrypriv.dbg_component;
-			RT_TRACE(0xffffffff, _drv_emerg_, ("3-2: mp_query_drv_var: offset(%d;0x%x):for query dbg conpoment=0x%x(l) 0x%x(h)  GlobalDebugComponents=0x%x(l) 0x%x(h)\n",offset,offset,padapter->registrypriv.dbg_component,prnt_dbg_comp));
-
-			if(GlobalDebugComponents&tmp_dbg_comp){
-				//this bit is already set, now clear it
-				GlobalDebugComponents=GlobalDebugComponents&(~tmp_dbg_comp);
-			}
-			else{
-				//this bit is not set, now set it.
-				GlobalDebugComponents =GlobalDebugComponents|tmp_dbg_comp;
+		chg_idx = offset - 0x80;
+		tmp_dbg_comp = BIT(chg_idx);
+		prnt_dbg_comp = padapter->registrypriv.dbg_component = GlobalDebugComponents;
+		if (offset == 127) {
+			/*		prnt_dbg_comp=padapter->registrypriv.dbg_component= GlobalDebugComponents; */
+			var = (u32)(padapter->registrypriv.dbg_component);
+			prnt_dbg_comp = GlobalDebugComponents;
+			prnt_dbg_comp = GlobalDebugComponents = padapter->registrypriv.dbg_component;
+
+		} else {
+			prnt_dbg_comp = GlobalDebugComponents;
+			prnt_dbg_comp = GlobalDebugComponents = padapter->registrypriv.dbg_component;
+
+			if (GlobalDebugComponents & tmp_dbg_comp) {
+				/* this bit is already set, now clear it */
+				GlobalDebugComponents = GlobalDebugComponents & (~tmp_dbg_comp);
+			} else {
+				/* this bit is not set, now set it. */
+				GlobalDebugComponents = GlobalDebugComponents | tmp_dbg_comp;
 			}
-			RT_TRACE(0xffffffff, _drv_emerg_, ("4: mp_query_drv_var: offset(%d;0x%x):before set dbg conpoment tmp_dbg_comp=0x%x GlobalDebugComponents=0x%x(l) 0x%x(h)",offset,offset,tmp_dbg_comp,prnt_dbg_comp));
-			prnt_dbg_comp=GlobalDebugComponents;
-			RT_TRACE(0xffffffff, _drv_emerg_, ("4-1: mp_query_drv_var: offset(%d;0x%x):before set dbg conpoment tmp_dbg_comp=0x%x GlobalDebugComponents=0x%x(l) 0x%x(h)",offset,offset,tmp_dbg_comp,prnt_dbg_comp));
-
-			RT_TRACE(_module_rtl871x_xmit_c_, _drv_emerg_, ("0: mp_query_drv_var(_module_rtl871x_xmit_c_:0): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,prnt_dbg_comp));
-			RT_TRACE(_module_xmit_osdep_c_, _drv_emerg_, ("1: mp_query_drv_var(_module_xmit_osdep_c_:1): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_recv_c_, _drv_emerg_, ("2: mp_query_drv_var(_module_rtl871x_recv_c_:2): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_recv_osdep_c_, _drv_emerg_, ("3: mp_query_drv_var(_module_recv_osdep_c_:3): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_mlme_c_, _drv_emerg_, ("4: mp_query_drv_var(_module_rtl871x_mlme_c_:4): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_mlme_osdep_c_, _drv_emerg_, (" 5:mp_query_drv_var(_module_mlme_osdep_c_:5): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_sta_mgt_c_, _drv_emerg_, ("6: mp_query_drv_var(_module_rtl871x_sta_mgt_c_:6): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_cmd_c_, _drv_emerg_, ("7: mp_query_drv_var(_module_rtl871x_cmd_c_:7): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_cmd_osdep_c_, _drv_emerg_, ("8: mp_query_drv_var(_module_cmd_osdep_c_:8): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_io_c_, _drv_emerg_, ("9: mp_query_drv_var(_module_rtl871x_io_c_:9): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_io_osdep_c_, _drv_emerg_, ("10: mp_query_drv_var(_module_io_osdep_c_:10): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_os_intfs_c_, _drv_emerg_, ("11: mp_query_drv_var(_module_os_intfs_c_:11): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_security_c_, _drv_emerg_, ("12: mp_query_drv_var(_module_rtl871x_security_c_:12): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_eeprom_c_, _drv_emerg_, ("13: mp_query_drv_var(_module_rtl871x_eeprom_c_:13): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_hal_init_c_, _drv_emerg_, ("14: mp_query_drv_var(_module_hal_init_c_:14): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_hci_hal_init_c_, _drv_emerg_, ("15: mp_query_drv_var(_module_hci_hal_init_c_:15): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_ioctl_c_, _drv_emerg_, ("16: mp_query_drv_var(_module_rtl871x_ioctl_c_:16): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_emerg_, ("17: mp_query_drv_var(_module_rtl871x_ioctl_set_c_:17): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_ioctl_query_c_, _drv_emerg_, ("18: mp_query_drv_var(_module_rtl871x_ioctl_query_c_:18): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_emerg_, ("19: mp_query_drv_var(_module_rtl871x_pwrctrl_c_:19): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_hci_intfs_c_, _drv_emerg_, ("20: mp_query_drv_var(_module_hci_intfs_c_:20): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_hci_ops_c_, _drv_emerg_, ("21: mp_query_drv_var(_module_hci_ops_c_:21): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_osdep_service_c_, _drv_emerg_, ("22: mp_query_drv_var(_module_osdep_service_c_:22): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_mp_, _drv_emerg_, ("23: mp_query_drv_var(_module_mp_:23): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			RT_TRACE(_module_hci_ops_os_c_, _drv_emerg_, ("24: mp_query_drv_var(_module_hci_ops_os_c_:24): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
-			var=(u32)(GlobalDebugComponents);
-			//GlobalDebugComponents=padapter->registrypriv.dbg_component;
-			RT_TRACE(0xffffffff, _drv_emerg_, (" ==mp_query_drv_var(_module_mp_): offset(%d;0x%x):before set dbg conpoment=0x%x(l) 0x%x(h)\n",offset,offset,GlobalDebugComponents));
+			prnt_dbg_comp = GlobalDebugComponents;
+
+			var = (u32)(GlobalDebugComponents);
+			/* GlobalDebugComponents=padapter->registrypriv.dbg_component; */
 
 		}
 	}
-	else{
-		RT_TRACE(_module_mp_, _drv_emerg_, ("\n mp_query_drv_var: offset(%d) >110\n",offset));
-	}
 #endif
 #endif
 
@@ -2197,7 +1882,6 @@ NDIS_STATUS oid_rt_pro_query_dr_variable_hdl(struct oid_par_priv *poid_par_priv)
 	if (poid_par_priv->information_buf_len < *poid_par_priv->bytes_needed)
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+Query Information, OID_RT_PRO_QUERY_DR_VARIABLE\n"));
 
 	pdrv_var = (struct _DR_VARIABLE_STRUCT_ *)poid_par_priv->information_buf;
 
@@ -2207,16 +1891,13 @@ NDIS_STATUS oid_rt_pro_query_dr_variable_hdl(struct oid_par_priv *poid_par_priv)
 
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("-oid_rt_pro_query_dr_variable_hdl: offset=0x%x valule=0x%x\n",
-		  pdrv_var->offset, pdrv_var->variable));
 
 	return status;
 #else
 	return 0;
 #endif
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
@@ -2224,9 +1905,8 @@ NDIS_STATUS oid_rt_pro_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv)
 
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-	RT_TRACE(_module_mp_, _drv_err_, ("oid_rt_pro_rx_packet_type_hdl...................\n"));
 
-	if (poid_par_priv->information_buf_len < sizeof (UCHAR)) {
+	if (poid_par_priv->information_buf_len < sizeof(UCHAR)) {
 		status = NDIS_STATUS_INVALID_LENGTH;
 		*poid_par_priv->bytes_needed = sizeof(UCHAR);
 		return status;
@@ -2234,32 +1914,21 @@ NDIS_STATUS oid_rt_pro_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv)
 
 	if (poid_par_priv->type_of_oid == SET_OID) {
 		Adapter->mppriv.rx_with_status = *(UCHAR *) poid_par_priv->information_buf;
-		RT_TRACE(_module_rtl871x_ioctl_c_,_drv_err_, ("Query Information, OID_RT_PRO_RX_PACKET_TYPE:%d \n",\
-												Adapter->mppriv.rx_with_status));
 
-		RT_TRACE(_module_rtl871x_ioctl_c_,_drv_err_,("MAC addr=0x%x:0x%x:0x%x:0x%x:0x%x:0x%x  \n",
-			Adapter->eeprompriv.mac_addr[0],Adapter->eeprompriv.mac_addr[1],Adapter->eeprompriv.mac_addr[2],\
-			Adapter->eeprompriv.mac_addr[3],Adapter->eeprompriv.mac_addr[4],Adapter->eeprompriv.mac_addr[5]));
 
-	}
-	else {
+	} else {
 		*(UCHAR *) poid_par_priv->information_buf = Adapter->mppriv.rx_with_status;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-		RT_TRACE(_module_rtl871x_ioctl_c_,_drv_err_, ("Query Information, OID_RT_PRO_RX_PACKET_TYPE:%d \n", \
-												Adapter->mppriv.rx_with_status));
 
-		//*(u32 *)&Adapter->eeprompriv.mac_addr[0]=rtw_read32(Adapter, 0x10250050);
-		//*(u16 *)&Adapter->eeprompriv.mac_addr[4]=rtw_read16(Adapter, 0x10250054);
-		RT_TRACE(_module_rtl871x_ioctl_c_,_drv_err_,("MAC addr=0x%x:0x%x:0x%x:0x%x:0x%x:0x%x  \n",
-			Adapter->eeprompriv.mac_addr[0],Adapter->eeprompriv.mac_addr[1],Adapter->eeprompriv.mac_addr[2],\
-			Adapter->eeprompriv.mac_addr[3],Adapter->eeprompriv.mac_addr[4],Adapter->eeprompriv.mac_addr[5]));
+		/* *(u32 *)&Adapter->eeprompriv.mac_addr[0]=rtw_read32(Adapter, 0x10250050); */
+		/* *(u16 *)&Adapter->eeprompriv.mac_addr[4]=rtw_read16(Adapter, 0x10250054); */
 	}
 #endif
 
 	return NDIS_STATUS_SUCCESS;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_read_efuse_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -2271,7 +1940,6 @@ NDIS_STATUS oid_rt_pro_read_efuse_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS status = NDIS_STATUS_SUCCESS;
 	PADAPTER Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -2284,30 +1952,24 @@ _func_enter_;
 	cnts = pefuse->cnts;
 	data = pefuse->data;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		("+oid_rt_pro_read_efuse_hd: buf_len=%d addr=%d cnts=%d\n",
-		 poid_par_priv->information_buf_len, addr, cnts));
 
 	EFUSE_GetEfuseDefinition(Adapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (PVOID)&max_available_size, _FALSE);
 
 	if ((addr + cnts) > max_available_size) {
-		RT_TRACE(_module_mp_, _drv_err_, ("!oid_rt_pro_read_efuse_hdl: parameter error!\n"));
 		return NDIS_STATUS_NOT_ACCEPTED;
 	}
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	if (rtw_efuse_access(Adapter, _FALSE, addr, cnts, data) == _FAIL) {
-		RT_TRACE(_module_mp_, _drv_err_, ("!oid_rt_pro_read_efuse_hdl: rtw_efuse_access FAIL!\n"));
 		status = NDIS_STATUS_FAILURE;
 	} else
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_write_efuse_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -2320,7 +1982,6 @@ NDIS_STATUS oid_rt_pro_write_efuse_hdl(struct oid_par_priv *poid_par_priv)
 	PADAPTER Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -2330,14 +1991,10 @@ _func_enter_;
 	cnts = pefuse->cnts;
 	data = pefuse->data;
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-		 ("+oid_rt_pro_write_efuse_hdl: buf_len=%d addr=0x%04x cnts=%d\n",
-		  poid_par_priv->information_buf_len, addr, cnts));
 
 	EFUSE_GetEfuseDefinition(Adapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (PVOID)&max_available_size, _FALSE);
 
 	if ((addr + cnts) > max_available_size) {
-		RT_TRACE(_module_mp_, _drv_err_, ("!oid_rt_pro_write_efuse_hdl: parameter error"));
 		return NDIS_STATUS_NOT_ACCEPTED;
 	}
 
@@ -2346,11 +2003,10 @@ _func_enter_;
 		status = NDIS_STATUS_FAILURE;
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_rw_efuse_pgpkt_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -2360,9 +2016,7 @@ NDIS_STATUS oid_rt_pro_rw_efuse_pgpkt_hdl(struct oid_par_priv *poid_par_priv)
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
-//	RT_TRACE(_module_mp_, _drv_info_, ("+oid_rt_pro_rw_efuse_pgpkt_hdl\n"));
 
 	*poid_par_priv->bytes_rw = 0;
 
@@ -2373,11 +2027,7 @@ _func_enter_;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
-	if (poid_par_priv->type_of_oid == QUERY_OID)
-	{
-		RT_TRACE(_module_mp_, _drv_notice_,
-			("oid_rt_pro_rw_efuse_pgpkt_hdl: Read offset=0x%x\n",\
-			ppgpkt->offset));
+	if (poid_par_priv->type_of_oid == QUERY_OID) {
 
 		Efuse_PowerSwitch(Adapter, _FALSE, _TRUE);
 		if (Efuse_PgPacketRead(Adapter, ppgpkt->offset, ppgpkt->data, _FALSE) == _TRUE)
@@ -2386,9 +2036,6 @@ _func_enter_;
 			status = NDIS_STATUS_FAILURE;
 		Efuse_PowerSwitch(Adapter, _FALSE, _FALSE);
 	} else {
-		RT_TRACE(_module_mp_, _drv_notice_,
-			("oid_rt_pro_rw_efuse_pgpkt_hdl: Write offset=0x%x word_en=0x%x\n",\
-			ppgpkt->offset, ppgpkt->word_en));
 
 		Efuse_PowerSwitch(Adapter, _TRUE, _TRUE);
 		if (Efuse_PgPacketWrite(Adapter, ppgpkt->offset, ppgpkt->word_en, ppgpkt->data, _FALSE) == _TRUE)
@@ -2400,14 +2047,11 @@ _func_enter_;
 
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("-oid_rt_pro_rw_efuse_pgpkt_hdl: status=0x%08X\n", status));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_get_efuse_current_size_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -2418,34 +2062,31 @@ NDIS_STATUS oid_rt_get_efuse_current_size_hdl(struct oid_par_priv *poid_par_priv
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	if (poid_par_priv->information_buf_len <sizeof(u32))
+	if (poid_par_priv->information_buf_len < sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	ret = efuse_GetCurrentSize(Adapter, &size);
 	_irqlevel_changed_(&oldirql, RAISE);
 	if (ret == _SUCCESS) {
-		*(u32*)poid_par_priv->information_buf = size;
+		*(u32 *)poid_par_priv->information_buf = size;
 		*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 	} else
 		status = NDIS_STATUS_FAILURE;
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_get_efuse_max_size_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -2453,38 +2094,30 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len < sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	*(u32*)poid_par_priv->information_buf = efuse_GetMaxSize(Adapter);
+	*(u32 *)poid_par_priv->information_buf = efuse_GetMaxSize(Adapter);
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("-oid_rt_get_efuse_max_size_hdl: size=%d status=0x%08X\n",
-		  *(int*)poid_par_priv->information_buf, status));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_efuse_hdl(struct oid_par_priv *poid_par_priv)
 {
 	NDIS_STATUS	status;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_info_, ("+oid_rt_pro_efuse_hdl\n"));
 
 	if (poid_par_priv->type_of_oid == QUERY_OID)
 		status = oid_rt_pro_read_efuse_hdl(poid_par_priv);
 	else
 		status = oid_rt_pro_write_efuse_hdl(poid_par_priv);
 
-	RT_TRACE(_module_mp_, _drv_info_, ("-oid_rt_pro_efuse_hdl: status=0x%08X\n", status));
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_pro_efuse_map_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -2493,11 +2126,9 @@ NDIS_STATUS oid_rt_pro_efuse_map_hdl(struct oid_par_priv *poid_par_priv)
 	u8		*data;
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
-	u16	mapLen=0;
+	u16	mapLen = 0;
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_pro_efuse_map_hdl\n"));
 
 	EFUSE_GetEfuseDefinition(Adapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&mapLen, _FALSE);
 
@@ -2506,42 +2137,30 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len < mapLen)
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	data = (u8*)poid_par_priv->information_buf;
+	data = (u8 *)poid_par_priv->information_buf;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
-	if (poid_par_priv->type_of_oid == QUERY_OID)
-	{
-		RT_TRACE(_module_mp_, _drv_info_,
-			("oid_rt_pro_efuse_map_hdl: READ\n"));
+	if (poid_par_priv->type_of_oid == QUERY_OID) {
 
 		if (rtw_efuse_map_read(Adapter, 0, mapLen, data) == _SUCCESS)
 			*poid_par_priv->bytes_rw = mapLen;
 		else {
-			RT_TRACE(_module_mp_, _drv_err_,
-				("oid_rt_pro_efuse_map_hdl: READ fail\n"));
 			status = NDIS_STATUS_FAILURE;
 		}
 	} else {
-		// SET_OID
-		RT_TRACE(_module_mp_, _drv_info_,
-			("oid_rt_pro_efuse_map_hdl: WRITE\n"));
+		/* SET_OID */
 
 		if (rtw_efuse_map_write(Adapter, 0, mapLen, data) == _SUCCESS)
 			*poid_par_priv->bytes_rw = mapLen;
 		else {
-			RT_TRACE(_module_mp_, _drv_err_,
-				("oid_rt_pro_efuse_map_hdl: WRITE fail\n"));
 			status = NDIS_STATUS_FAILURE;
 		}
 	}
 
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("-oid_rt_pro_efuse_map_hdl: status=0x%08X\n", status));
 
-_func_exit_;
 
 	return status;
 }
@@ -2558,25 +2177,23 @@ NDIS_STATUS oid_rt_set_crystal_cap_hdl(struct oid_par_priv *poid_par_priv)
 
 	u32		crystal_cap = 0;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	if (poid_par_priv->information_buf_len <sizeof(u32))
+	if (poid_par_priv->information_buf_len < sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	crystal_cap = *((u32*)poid_par_priv->information_buf);//4
+	crystal_cap = *((u32 *)poid_par_priv->information_buf); /* 4 */
 	if (crystal_cap > 0xf)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
 	Adapter->mppriv.curr_crystalcap = crystal_cap;
 
-	_irqlevel_changed_(&oldirql,LOWER);
+	_irqlevel_changed_(&oldirql, LOWER);
 	SetCrystalCap(Adapter);
-	_irqlevel_changed_(&oldirql,RAISE);
+	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 #endif
 	return status;
@@ -2588,13 +2205,11 @@ NDIS_STATUS oid_rt_set_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv)
 	_irqL		oldirql;
 #endif
 	u8		rx_pkt_type;
-//	u32		rcr_val32;
+	/*	u32		rcr_val32; */
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
-//	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context);
+	/*	PADAPTER	padapter = (PADAPTER)(poid_par_priv->adapter_context); */
 
-_func_enter_;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+oid_rt_set_rx_packet_type_hdl\n"));
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -2602,75 +2217,63 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len < sizeof(u8))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	rx_pkt_type = *((u8*)poid_par_priv->information_buf);//4
+	rx_pkt_type = *((u8 *)poid_par_priv->information_buf); /* 4 */
 
-	RT_TRACE(_module_mp_, _drv_info_, ("rx_pkt_type: %x\n",rx_pkt_type ));
 #if 0
 	_irqlevel_changed_(&oldirql, LOWER);
 #if 0
-	rcr_val8 = rtw_read8(Adapter, 0x10250048);//RCR
-	rcr_val8 &= ~(RCR_AB|RCR_AM|RCR_APM|RCR_AAP);
-
-	if(rx_pkt_type == RX_PKT_BROADCAST){
-		rcr_val8 |= (RCR_AB | RCR_ACRC32 );
-	}
-	else if(rx_pkt_type == RX_PKT_DEST_ADDR){
-		rcr_val8 |= (RCR_AAP| RCR_AM |RCR_ACRC32);
-	}
-	else if(rx_pkt_type == RX_PKT_PHY_MATCH){
-		rcr_val8 |= (RCR_APM|RCR_ACRC32);
-	}
-	else{
-		rcr_val8 &= ~(RCR_AAP|RCR_APM|RCR_AM|RCR_AB|RCR_ACRC32);
-	}
-	rtw_write8(padapter, 0x10250048,rcr_val8);
+	rcr_val8 = rtw_read8(Adapter, 0x10250048);/* RCR */
+	rcr_val8 &= ~(RCR_AB | RCR_AM | RCR_APM | RCR_AAP);
+
+	if (rx_pkt_type == RX_PKT_BROADCAST)
+		rcr_val8 |= (RCR_AB | RCR_ACRC32);
+	else if (rx_pkt_type == RX_PKT_DEST_ADDR)
+		rcr_val8 |= (RCR_AAP | RCR_AM | RCR_ACRC32);
+	else if (rx_pkt_type == RX_PKT_PHY_MATCH)
+		rcr_val8 |= (RCR_APM | RCR_ACRC32);
+	else
+		rcr_val8 &= ~(RCR_AAP | RCR_APM | RCR_AM | RCR_AB | RCR_ACRC32);
+	rtw_write8(padapter, 0x10250048, rcr_val8);
 #else
-	rcr_val32 = rtw_read32(padapter, RCR);//RCR = 0x10250048
-	rcr_val32 &= ~(RCR_CBSSID|RCR_AB|RCR_AM|RCR_APM|RCR_AAP);
+	rcr_val32 = rtw_read32(padapter, RCR);/* RCR = 0x10250048 */
+	rcr_val32 &= ~(RCR_CBSSID | RCR_AB | RCR_AM | RCR_APM | RCR_AAP);
 #if 0
-	if(rx_pkt_type == RX_PKT_BROADCAST){
-		rcr_val32 |= (RCR_AB|RCR_AM|RCR_APM|RCR_AAP|RCR_ACRC32);
-	}
-	else if(rx_pkt_type == RX_PKT_DEST_ADDR){
-		//rcr_val32 |= (RCR_CBSSID|RCR_AAP|RCR_AM|RCR_ACRC32);
-		rcr_val32 |= (RCR_CBSSID|RCR_APM|RCR_ACRC32);
-	}
-	else if(rx_pkt_type == RX_PKT_PHY_MATCH){
-		rcr_val32 |= (RCR_APM|RCR_ACRC32);
-		//rcr_val32 |= (RCR_AAP|RCR_ACRC32);
-	}
-	else{
-		rcr_val32 &= ~(RCR_AAP|RCR_APM|RCR_AM|RCR_AB|RCR_ACRC32);
-	}
+	if (rx_pkt_type == RX_PKT_BROADCAST)
+		rcr_val32 |= (RCR_AB | RCR_AM | RCR_APM | RCR_AAP | RCR_ACRC32);
+	else if (rx_pkt_type == RX_PKT_DEST_ADDR) {
+		/* rcr_val32 |= (RCR_CBSSID|RCR_AAP|RCR_AM|RCR_ACRC32); */
+		rcr_val32 |= (RCR_CBSSID | RCR_APM | RCR_ACRC32);
+	} else if (rx_pkt_type == RX_PKT_PHY_MATCH) {
+		rcr_val32 |= (RCR_APM | RCR_ACRC32);
+		/* rcr_val32 |= (RCR_AAP|RCR_ACRC32); */
+	} else
+		rcr_val32 &= ~(RCR_AAP | RCR_APM | RCR_AM | RCR_AB | RCR_ACRC32);
 #else
-	switch (rx_pkt_type)
-	{
-		case RX_PKT_BROADCAST :
-			rcr_val32 |= (RCR_AB|RCR_AM|RCR_APM|RCR_AAP|RCR_ACRC32);
-			break;
-		case RX_PKT_DEST_ADDR :
-			rcr_val32 |= (RCR_AB|RCR_AM|RCR_APM|RCR_AAP|RCR_ACRC32);
-			break;
-		case RX_PKT_PHY_MATCH:
-			rcr_val32 |= (RCR_APM|RCR_ACRC32);
-			break;
-		default:
-			rcr_val32 &= ~(RCR_AAP|RCR_APM|RCR_AM|RCR_AB|RCR_ACRC32);
-			break;
+	switch (rx_pkt_type) {
+	case RX_PKT_BROADCAST:
+		rcr_val32 |= (RCR_AB | RCR_AM | RCR_APM | RCR_AAP | RCR_ACRC32);
+		break;
+	case RX_PKT_DEST_ADDR:
+		rcr_val32 |= (RCR_AB | RCR_AM | RCR_APM | RCR_AAP | RCR_ACRC32);
+		break;
+	case RX_PKT_PHY_MATCH:
+		rcr_val32 |= (RCR_APM | RCR_ACRC32);
+		break;
+	default:
+		rcr_val32 &= ~(RCR_AAP | RCR_APM | RCR_AM | RCR_AB | RCR_ACRC32);
+		break;
 	}
 
-	if (rx_pkt_type == RX_PKT_DEST_ADDR) {
+	if (rx_pkt_type == RX_PKT_DEST_ADDR)
 		padapter->mppriv.check_mp_pkt = 1;
-	} else {
+	else
 		padapter->mppriv.check_mp_pkt = 0;
-	}
 #endif
 	rtw_write32(padapter, RCR, rcr_val32);
 
 #endif
 	_irqlevel_changed_(&oldirql, RAISE);
 #endif
-_func_exit_;
 
 	return status;
 }
@@ -2685,9 +2288,8 @@ NDIS_STATUS oid_rt_pro_set_tx_agc_offset_hdl(struct oid_par_priv *poid_par_priv)
 #endif
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 
-	u32 		txagc;
+	u32		txagc;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
@@ -2695,15 +2297,12 @@ _func_enter_;
 	if (poid_par_priv->information_buf_len < sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	txagc = *(u32*)poid_par_priv->information_buf;
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("oid_rt_pro_set_tx_agc_offset_hdl: 0x%08x\n", txagc));
+	txagc = *(u32 *)poid_par_priv->information_buf;
 
 	_irqlevel_changed_(&oldirql, LOWER);
 	SetTxAGCOffset(Adapter, txagc);
 	_irqlevel_changed_(&oldirql, RAISE);
 
-_func_exit_;
 
 	return status;
 #else
@@ -2720,30 +2319,26 @@ NDIS_STATUS oid_rt_pro_set_pkt_test_mode_hdl(struct oid_par_priv *poid_par_priv)
 
 	struct mlme_priv	*pmlmepriv = &Adapter->mlmepriv;
 	struct mp_priv		*pmppriv = &Adapter->mppriv;
-	u32 			type;
+	u32			type;
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID)
 		return NDIS_STATUS_NOT_ACCEPTED;
 
-	if (poid_par_priv->information_buf_len <sizeof(u32))
+	if (poid_par_priv->information_buf_len < sizeof(u32))
 		return NDIS_STATUS_INVALID_LENGTH;
 
-	type = *(u32*)poid_par_priv->information_buf;
+	type = *(u32 *)poid_par_priv->information_buf;
 
 	if (_LOOPBOOK_MODE_ == type) {
 		pmppriv->mode = type;
-		set_fwstate(pmlmepriv, WIFI_MP_LPBK_STATE); //append txdesc
-		RT_TRACE(_module_mp_, _drv_info_, ("test mode change to loopback mode:0x%08x.\n", get_fwstate(pmlmepriv)));
-	} else if (_2MAC_MODE_ == type){
+		set_fwstate(pmlmepriv, WIFI_MP_LPBK_STATE); /* append txdesc */
+	} else if (_2MAC_MODE_ == type) {
 		pmppriv->mode = type;
 		_clr_fwstate_(pmlmepriv, WIFI_MP_LPBK_STATE);
-		RT_TRACE(_module_mp_, _drv_info_, ("test mode change to 2mac mode:0x%08x.\n", get_fwstate(pmlmepriv)));
 	} else
 		status = NDIS_STATUS_NOT_ACCEPTED;
 
-_func_exit_;
 
 	return status;
 #else
@@ -2758,7 +2353,6 @@ unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)
 	struct mp_priv *pmp_priv;
 	struct pkt_attrib *pattrib;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("+%s\n", __func__));
 
 	pparm = (PMP_XMIT_PARM)poid_par_priv->information_buf;
 	padapter = (PADAPTER)poid_par_priv->adapter_context;
@@ -2768,9 +2362,9 @@ unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)
 		pparm->enable = !pmp_priv->tx.stop;
 		pparm->count = pmp_priv->tx.sended;
 	} else {
-		if (pparm->enable == 0) {
+		if (pparm->enable == 0)
 			pmp_priv->tx.stop = 1;
-		} else if (pmp_priv->tx.stop == 1) {
+		else if (pmp_priv->tx.stop == 1) {
 			pmp_priv->tx.stop = 0;
 			pmp_priv->tx.count = pparm->count;
 			pmp_priv->tx.payload = pparm->payload_type;
@@ -2794,39 +2388,38 @@ unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)
 	struct rtw_ieee80211_hdr *pwlanhdr;
 	unsigned short *fctrl;
 	int llc_sz, payload_len;
-	struct mp_xmit_frame *pxframe=  NULL;
-	struct mp_xmit_packet *pmp_xmitpkt = (struct mp_xmit_packet*)param;
+	struct mp_xmit_frame *pxframe =  NULL;
+	struct mp_xmit_packet *pmp_xmitpkt = (struct mp_xmit_packet *)param;
 	u8 addr3[] = {0x02, 0xE0, 0x4C, 0x87, 0x66, 0x55};
 
-//	DBG_871X("+mp_ioctl_xmit_packet_hdl\n");
+	/*	RTW_INFO("+mp_ioctl_xmit_packet_hdl\n"); */
 
 	pxframe = alloc_mp_xmitframe(&padapter->mppriv);
-	if (pxframe == NULL)
-	{
+	if (pxframe == NULL) {
 		DEBUG_ERR(("Can't alloc pmpframe %d:%s\n", __LINE__, __FILE__));
 		return -1;
 	}
 
-	//mp_xmit_pkt
+	/* mp_xmit_pkt */
 	payload_len = pmp_xmitpkt->len - 14;
-	pmp_pkt = (unsigned char*)pmp_xmitpkt->mem;
+	pmp_pkt = (unsigned char *)pmp_xmitpkt->mem;
 	pethhdr = (struct ethhdr *)pmp_pkt;
 
-	//DBG_871X("payload_len=%d, pkt_mem=0x%x\n", pmp_xmitpkt->len, (void*)pmp_xmitpkt->mem);
+	/* RTW_INFO("payload_len=%d, pkt_mem=0x%x\n", pmp_xmitpkt->len, (void*)pmp_xmitpkt->mem); */
 
-	//DBG_871X("pxframe=0x%x\n", (void*)pxframe);
-	//DBG_871X("pxframe->mem=0x%x\n", (void*)pxframe->mem);
+	/* RTW_INFO("pxframe=0x%x\n", (void*)pxframe); */
+	/* RTW_INFO("pxframe->mem=0x%x\n", (void*)pxframe->mem); */
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pxframe->attrib;
-	memset((u8 *)(pattrib), 0, sizeof (struct pkt_attrib));
+	memset((u8 *)(pattrib), 0, sizeof(struct pkt_attrib));
 	pattrib->pktlen = pmp_xmitpkt->len;
 	pattrib->ether_type = ntohs(pethhdr->h_proto);
 	pattrib->hdrlen = 24;
 	pattrib->nr_frags = 1;
 	pattrib->priority = 0;
 #ifndef CONFIG_MP_LINUX
-	if(IS_MCAST(pethhdr->h_dest))
+	if (IS_MCAST(pethhdr->h_dest))
 		pattrib->mac_id = 4;
 	else
 		pattrib->mac_id = 5;
@@ -2834,7 +2427,7 @@ unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)
 	pattrib->mac_id = 5;
 #endif
 
-	//
+	/*  */
 	memset(pxframe->mem, 0 , WLANHDR_OFFSET);
 	pframe = (u8 *)(pxframe->mem) + WLANHDR_OFFSET;
 
@@ -2842,7 +2435,7 @@ unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
-	SetFrameSubType(pframe, WIFI_DATA);
+	set_frame_sub_type(pframe, WIFI_DATA);
 
 	_rtw_memcpy(pwlanhdr->addr1, pethhdr->h_dest, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, pethhdr->h_source, ETH_ALEN);
@@ -2852,10 +2445,10 @@ unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)
 	pwlanhdr->seq_ctl = 0;
 	pframe += pattrib->hdrlen;
 
-	llc_sz= rtw_put_snap(pframe, pattrib->ether_type);
+	llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
 	pframe += llc_sz;
 
-	_rtw_memcpy(pframe, (void*)(pmp_pkt+14),  payload_len);
+	_rtw_memcpy(pframe, (void *)(pmp_pkt + 14),  payload_len);
 
 	pattrib->last_txcmdsz = pattrib->hdrlen + llc_sz + payload_len;
 
@@ -2865,7 +2458,7 @@ unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)
 	return _SUCCESS;
 }
 #endif
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_set_power_down_hdl(struct oid_par_priv *poid_par_priv)
 {
 #ifdef PLATFORM_OS_XP
@@ -2879,45 +2472,40 @@ NDIS_STATUS oid_rt_set_power_down_hdl(struct oid_par_priv *poid_par_priv)
 #endif
 #endif
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != SET_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
 		return status;
 	}
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("\n ===> Setoid_rt_set_power_down_hdl.\n"));
 
 	_irqlevel_changed_(&oldirql, LOWER);
 
 	bpwrup = *(u8 *)poid_par_priv->information_buf;
-	//CALL  the power_down function
+	/* CALL  the power_down function */
 #ifdef PLATFORM_LINUX
-#if defined(CONFIG_RTL8712) //Linux MP insmod unknown symbol
-	dev_power_down(padapter,bpwrup); 
+#if defined(CONFIG_RTL8712) /* Linux MP insmod unknown symbol */
+	dev_power_down(padapter, bpwrup);
 #endif
 #endif
 	_irqlevel_changed_(&oldirql, RAISE);
 
-	//DEBUG_ERR(("\n <=== Query OID_RT_PRO_READ_REGISTER.
-	//	Add:0x%08x Width:%d Value:0x%08x\n",RegRWStruct->offset,RegRWStruct->width,RegRWStruct->value));
+	/* DEBUG_ERR(("\n <=== Query OID_RT_PRO_READ_REGISTER. */
+	/*	Add:0x%08x Width:%d Value:0x%08x\n",RegRWStruct->offset,RegRWStruct->width,RegRWStruct->value)); */
 
-_func_exit_;
 
 	return status;
 }
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 NDIS_STATUS oid_rt_get_power_mode_hdl(struct oid_par_priv *poid_par_priv)
 {
 #if 0
 	NDIS_STATUS	status = NDIS_STATUS_SUCCESS;
 	PADAPTER	Adapter = (PADAPTER)(poid_par_priv->adapter_context);
-//#ifdef PLATFORM_OS_XP
-//	_irqL		oldirql;
-//#endif
+	/* #ifdef PLATFORM_OS_XP */
+	/*	_irqL		oldirql;
+	 * #endif */
 
-_func_enter_;
 
 	if (poid_par_priv->type_of_oid != QUERY_OID) {
 		status = NDIS_STATUS_NOT_ACCEPTED;
@@ -2928,19 +2516,15 @@ _func_enter_;
 		return status;
 	}
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("\n ===> oid_rt_get_power_mode_hdl.\n"));
 
-//	_irqlevel_changed_(&oldirql, LOWER);
-	*(int*)poid_par_priv->information_buf = Adapter->registrypriv.low_power ? POWER_LOW : POWER_NORMAL;
+	/*	_irqlevel_changed_(&oldirql, LOWER); */
+	*(int *)poid_par_priv->information_buf = Adapter->registrypriv.low_power ? POWER_LOW : POWER_NORMAL;
 	*poid_par_priv->bytes_rw = poid_par_priv->information_buf_len;
-//	_irqlevel_changed_(&oldirql, RAISE);
+	/*	_irqlevel_changed_(&oldirql, RAISE); */
 
-_func_exit_;
 
 	return status;
 #else
 	return 0;
 #endif
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_odm.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_odm.c
index 7b733a9a55c6..32dc79da6e23 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_odm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_odm.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,178 +12,62 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #include <rtw_odm.h>
 #include <hal_data.h>
 
-const char *odm_comp_str[] = {
-	/* BIT0 */"ODM_COMP_DIG",
-	/* BIT1 */"ODM_COMP_RA_MASK",
-	/* BIT2 */"ODM_COMP_DYNAMIC_TXPWR",
-	/* BIT3 */"ODM_COMP_FA_CNT",
-	/* BIT4 */"ODM_COMP_RSSI_MONITOR",
-	/* BIT5 */"ODM_COMP_CCK_PD",
-	/* BIT6 */"ODM_COMP_ANT_DIV",
-	/* BIT7 */"ODM_COMP_PWR_SAVE",
-	/* BIT8 */"ODM_COMP_PWR_TRAIN",
-	/* BIT9 */"ODM_COMP_RATE_ADAPTIVE",
-	/* BIT10 */"ODM_COMP_PATH_DIV",
-	/* BIT11 */"ODM_COMP_PSD",
-	/* BIT12 */"ODM_COMP_DYNAMIC_PRICCA",
-	/* BIT13 */"ODM_COMP_RXHP",
-	/* BIT14 */"ODM_COMP_MP",
-	/* BIT15 */"ODM_COMP_CFO_TRACKING",
-	/* BIT16 */"ODM_COMP_ACS",
-	/* BIT17 */"PHYDM_COMP_ADAPTIVITY",
-	/* BIT18 */"PHYDM_COMP_RA_DBG",
-	/* BIT19 */"PHYDM_COMP_TXBF",
-	/* BIT20 */"ODM_COMP_EDCA_TURBO",
-	/* BIT21 */"ODM_COMP_EARLY_MODE",
-	/* BIT22 */"ODM_FW_DEBUG_TRACE",
-	/* BIT23 */NULL,
-	/* BIT24 */"ODM_COMP_TX_PWR_TRACK",
-	/* BIT25 */"ODM_COMP_RX_GAIN_TRACK",
-	/* BIT26 */"ODM_COMP_CALIBRATION",
-	/* BIT27 */NULL,
-	/* BIT28 */"ODM_PHY_CONFIG",
-	/* BIT29 */"BEAMFORMING_DEBUG",
-	/* BIT30 */"ODM_COMP_COMMON",
-	/* BIT31 */"ODM_COMP_INIT",
-	/* BIT32 */"ODM_COMP_NOISY_DETECT",
-};
-
-#define RTW_ODM_COMP_MAX 33
-
-const char *odm_ability_str[] = {
-	/* BIT0 */"ODM_BB_DIG",
-	/* BIT1 */"ODM_BB_RA_MASK",
-	/* BIT2 */"ODM_BB_DYNAMIC_TXPWR",
-	/* BIT3 */"ODM_BB_FA_CNT",
-	/* BIT4 */"ODM_BB_RSSI_MONITOR",
-	/* BIT5 */"ODM_BB_CCK_PD",
-	/* BIT6 */"ODM_BB_ANT_DIV",
-	/* BIT7 */"ODM_BB_PWR_SAVE",
-	/* BIT8 */"ODM_BB_PWR_TRAIN",
-	/* BIT9 */"ODM_BB_RATE_ADAPTIVE",
-	/* BIT10 */"ODM_BB_PATH_DIV",
-	/* BIT11 */"ODM_BB_PSD",
-	/* BIT12 */"ODM_BB_RXHP",
-	/* BIT13 */"ODM_BB_ADAPTIVITY",
-	/* BIT14 */"ODM_BB_CFO_TRACKING",
-	/* BIT15 */"ODM_BB_NHM_CNT",
-	/* BIT16 */"ODM_BB_PRIMARY_CCA",
-	/* BIT17 */"ODM_BB_TXBF",
-	/* BIT18 */NULL,
-	/* BIT19 */NULL,
-	/* BIT20 */"ODM_MAC_EDCA_TURBO",
-	/* BIT21 */"ODM_MAC_EARLY_MODE",
-	/* BIT22 */NULL,
-	/* BIT23 */NULL,
-	/* BIT24 */"ODM_RF_TX_PWR_TRACK",
-	/* BIT25 */"ODM_RF_RX_GAIN_TRACK",
-	/* BIT26 */"ODM_RF_CALIBRATION",
-};
-
-#define RTW_ODM_ABILITY_MAX 27
-
-const char *odm_dbg_level_str[] = {
-	NULL,
-	"ODM_DBG_OFF",
-	"ODM_DBG_SERIOUS",
-	"ODM_DBG_WARNING",
-	"ODM_DBG_LOUD",
-	"ODM_DBG_TRACE",
-};
-
-#define RTW_ODM_DBG_LEVEL_NUM 6
-
-void rtw_odm_dbg_comp_msg(void *sel, _adapter *adapter)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &pHalData->odmpriv;
-	int cnt = 0;
-	u64 dbg_comp = 0;
-	int i;
-
-	rtw_hal_get_odm_var(adapter, HAL_ODM_DBG_FLAG, &dbg_comp, NULL);
-
-	DBG_871X_SEL_NL(sel, "odm.DebugComponents = 0x%016llx\n", dbg_comp);
-	for (i=0;i<RTW_ODM_COMP_MAX;i++) {
-		if (odm_comp_str[i])
-			DBG_871X_SEL_NL(sel, "%cBIT%-2d %s\n",
-				(BIT0 << i) & dbg_comp ? '+' : ' ', i, odm_comp_str[i]);
-	}
-}
-
-inline void rtw_odm_dbg_comp_set(_adapter *adapter, u64 comps)
-{
-	rtw_hal_set_odm_var(adapter, HAL_ODM_DBG_FLAG, &comps, _FALSE);
-}
-
-void rtw_odm_dbg_level_msg(void *sel, _adapter *adapter)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &pHalData->odmpriv;
-	int cnt = 0;
-	u32 dbg_level = 0;
-	int i;
-
-	rtw_hal_get_odm_var(adapter, HAL_ODM_DBG_LEVEL, &dbg_level, NULL);
-	DBG_871X_SEL_NL(sel, "odm.DebugLevel = %u\n", dbg_level);
-	for (i=0;i<RTW_ODM_DBG_LEVEL_NUM;i++) {
-		if (odm_dbg_level_str[i])
-			DBG_871X_SEL_NL(sel, "%u %s\n", i, odm_dbg_level_str[i]);
-	}
-}
-
-inline void rtw_odm_dbg_level_set(_adapter *adapter, u32 level)
-{
-	rtw_hal_set_odm_var(adapter, HAL_ODM_DBG_LEVEL, &level, _FALSE);
-}
-
-void rtw_odm_ability_msg(void *sel, _adapter *adapter)
+u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &pHalData->odmpriv;
-	int cnt = 0;
-	u32 ability = 0;
-	int i;
-
-	ability = rtw_phydm_ability_get(adapter);
-	DBG_871X_SEL_NL(sel, "odm.SupportAbility = 0x%08x\n", ability);
-	for (i=0;i<RTW_ODM_ABILITY_MAX;i++) {
-		if (odm_ability_str[i])
-			DBG_871X_SEL_NL(sel, "%cBIT%-2d %s\n",
-				(BIT0 << i) & ability ? '+' : ' ', i, odm_ability_str[i]);
+	struct dm_struct *podmpriv = &pHalData->odmpriv;
+	u32 result = 0;
+
+	switch (ops) {
+	case HAL_PHYDM_DIS_ALL_FUNC:
+		podmpriv->support_ability = DYNAMIC_FUNC_DISABLE;
+		halrf_cmn_info_set(podmpriv, HALRF_CMNINFO_ABILITY, DYNAMIC_FUNC_DISABLE);
+		break;
+	case HAL_PHYDM_FUNC_SET:
+		podmpriv->support_ability |= ability;
+		break;
+	case HAL_PHYDM_FUNC_CLR:
+		podmpriv->support_ability &= ~(ability);
+		break;
+	case HAL_PHYDM_ABILITY_BK:
+		/* dm flag backup*/
+		podmpriv->bk_support_ability = podmpriv->support_ability;
+		pHalData->bk_rf_ability = halrf_cmn_info_get(podmpriv, HALRF_CMNINFO_ABILITY);
+		break;
+	case HAL_PHYDM_ABILITY_RESTORE:
+		/* restore dm flag */
+		podmpriv->support_ability = podmpriv->bk_support_ability;
+		halrf_cmn_info_set(podmpriv, HALRF_CMNINFO_ABILITY, pHalData->bk_rf_ability);
+		break;
+	case HAL_PHYDM_ABILITY_SET:
+		podmpriv->support_ability = ability;
+		break;
+	case HAL_PHYDM_ABILITY_GET:
+		result = podmpriv->support_ability;
+		break;
 	}
-}
-
-inline void rtw_odm_ability_set(_adapter *adapter, u32 ability)
-{
-	rtw_phydm_ability_set(adapter, ability);
+	return result;
 }
 
 /* set ODM_CMNINFO_IC_TYPE based on chip_type */
 void rtw_odm_init_ic_type(_adapter *adapter)
 {
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &hal_data->odmpriv;
+	struct dm_struct *odm = adapter_to_phydm(adapter);
 	u4Byte ic_type = chip_type_to_odm_ic_type(rtw_get_chip_type(adapter));
 
 	rtw_warn_on(!ic_type);
 
-	ODM_CmnInfoInit(odm, ODM_CMNINFO_IC_TYPE, ic_type);
+	odm_cmn_info_init(odm, ODM_CMNINFO_IC_TYPE, ic_type);
 }
 
 void rtw_odm_adaptivity_ver_msg(void *sel, _adapter *adapter)
 {
-	DBG_871X_SEL_NL(sel, "ADAPTIVITY_VERSION "ADAPTIVITY_VERSION"\n");
+	RTW_PRINT_SEL(sel, "ADAPTIVITY_VERSION "ADAPTIVITY_VERSION"\n");
 }
 
 #define RTW_ADAPTIVITY_EN_DISABLE 0
@@ -191,19 +76,15 @@ void rtw_odm_adaptivity_ver_msg(void *sel, _adapter *adapter)
 void rtw_odm_adaptivity_en_msg(void *sel, _adapter *adapter)
 {
 	struct registry_priv *regsty = &adapter->registrypriv;
-	struct mlme_priv *mlme = &adapter->mlmepriv;
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &hal_data->odmpriv;
 
-	DBG_871X_SEL_NL(sel, "RTW_ADAPTIVITY_EN_");
+	RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_EN_");
 
-	if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_DISABLE) {
-		DBG_871X_SEL(sel, "DISABLE\n");
-	} else if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_ENABLE) {
-		DBG_871X_SEL(sel, "ENABLE\n");
-	} else {
-		DBG_871X_SEL(sel, "INVALID\n");
-	}
+	if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_DISABLE)
+		_RTW_PRINT_SEL(sel, "DISABLE\n");
+	else if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_ENABLE)
+		_RTW_PRINT_SEL(sel, "ENABLE\n");
+	else
+		_RTW_PRINT_SEL(sel, "INVALID\n");
 }
 
 #define RTW_ADAPTIVITY_MODE_NORMAL 0
@@ -213,15 +94,14 @@ void rtw_odm_adaptivity_mode_msg(void *sel, _adapter *adapter)
 {
 	struct registry_priv *regsty = &adapter->registrypriv;
 
-	DBG_871X_SEL_NL(sel, "RTW_ADAPTIVITY_MODE_");
+	RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_MODE_");
 
-	if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_NORMAL) {
-		DBG_871X_SEL(sel, "NORMAL\n");
-	} else if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_CARRIER_SENSE) {
-		DBG_871X_SEL(sel, "CARRIER_SENSE\n");
-	} else {
-		DBG_871X_SEL(sel, "INVALID\n");
-	}
+	if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_NORMAL)
+		_RTW_PRINT_SEL(sel, "NORMAL\n");
+	else if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_CARRIER_SENSE)
+		_RTW_PRINT_SEL(sel, "CARRIER_SENSE\n");
+	else
+		_RTW_PRINT_SEL(sel, "INVALID\n");
 }
 
 #define RTW_ADAPTIVITY_DML_DISABLE 0
@@ -231,22 +111,21 @@ void rtw_odm_adaptivity_dml_msg(void *sel, _adapter *adapter)
 {
 	struct registry_priv *regsty = &adapter->registrypriv;
 
-	DBG_871X_SEL_NL(sel, "RTW_ADAPTIVITY_DML_");
+	RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_DML_");
 
-	if (regsty->adaptivity_dml == RTW_ADAPTIVITY_DML_DISABLE) {
-		DBG_871X_SEL(sel, "DISABLE\n");
-	} else if (regsty->adaptivity_dml == RTW_ADAPTIVITY_DML_ENABLE) {
-		DBG_871X_SEL(sel, "ENABLE\n");
-	} else {
-		DBG_871X_SEL(sel, "INVALID\n");
-	}
+	if (regsty->adaptivity_dml == RTW_ADAPTIVITY_DML_DISABLE)
+		_RTW_PRINT_SEL(sel, "DISABLE\n");
+	else if (regsty->adaptivity_dml == RTW_ADAPTIVITY_DML_ENABLE)
+		_RTW_PRINT_SEL(sel, "ENABLE\n");
+	else
+		_RTW_PRINT_SEL(sel, "INVALID\n");
 }
 
 void rtw_odm_adaptivity_dc_backoff_msg(void *sel, _adapter *adapter)
 {
 	struct registry_priv *regsty = &adapter->registrypriv;
 
-	DBG_871X_SEL_NL(sel, "RTW_ADAPTIVITY_DC_BACKOFF:%u\n", regsty->adaptivity_dc_backoff);
+	RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_DC_BACKOFF:%u\n", regsty->adaptivity_dc_backoff);
 }
 
 void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter)
@@ -272,190 +151,305 @@ bool rtw_odm_adaptivity_needed(_adapter *adapter)
 
 void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter)
 {
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &pHalData->odmpriv;
+	struct dm_struct *odm = adapter_to_phydm(adapter);
 
 	rtw_odm_adaptivity_config_msg(sel, adapter);
 
-	DBG_871X_SEL_NL(sel, "%10s %16s %16s %22s %12s\n"
-		, "TH_L2H_ini", "TH_EDCCA_HL_diff", "TH_L2H_ini_mode2", "TH_EDCCA_HL_diff_mode2", "EDCCA_enable");
-	DBG_871X_SEL_NL(sel, "0x%-8x %-16d 0x%-14x %-22d %-12d\n"
-		, (u8)odm->TH_L2H_ini
-		, odm->TH_EDCCA_HL_diff
-		, (u8)odm->TH_L2H_ini_mode2
-		, odm->TH_EDCCA_HL_diff_mode2
-		, odm->EDCCA_enable
+	RTW_PRINT_SEL(sel, "%10s %16s %16s %22s %12s\n"
+		, "th_l2h_ini", "th_edcca_hl_diff", "th_l2h_ini_mode2", "th_edcca_hl_diff_mode2", "edcca_enable");
+	RTW_PRINT_SEL(sel, "0x%-8x %-16d 0x%-14x %-22d %-12d\n"
+		, (u8)odm->th_l2h_ini
+		, odm->th_edcca_hl_diff
+		, (u8)odm->th_l2h_ini_mode2
+		, odm->th_edcca_hl_diff_mode2
+		, odm->edcca_enable
 	);
 
-	DBG_871X_SEL_NL(sel, "%15s %9s\n", "AdapEnableState", "Adap_Flag");
-	DBG_871X_SEL_NL(sel, "%-15x %-9x\n"
-		, odm->Adaptivity_enable
+	RTW_PRINT_SEL(sel, "%15s %9s\n", "AdapEnableState", "Adap_Flag");
+	RTW_PRINT_SEL(sel, "%-15x %-9x\n"
+		, odm->adaptivity_enable
 		, odm->adaptivity_flag
 	);
 }
 
-void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 TH_L2H_ini, s8 TH_EDCCA_HL_diff, s8 TH_L2H_ini_mode2, s8 TH_EDCCA_HL_diff_mode2, u8 EDCCA_enable)
+void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff, s8 th_l2h_ini_mode2, s8 th_edcca_hl_diff_mode2, u8 edcca_enable)
 {
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &pHalData->odmpriv;
+	struct dm_struct *odm = adapter_to_phydm(adapter);
 
-	odm->TH_L2H_ini = TH_L2H_ini;
-	odm->TH_EDCCA_HL_diff = TH_EDCCA_HL_diff;
-	odm->TH_L2H_ini_mode2 = TH_L2H_ini_mode2;
-	odm->TH_EDCCA_HL_diff_mode2 = TH_EDCCA_HL_diff_mode2;
-	odm->EDCCA_enable = EDCCA_enable;
+	odm->th_l2h_ini = th_l2h_ini;
+	odm->th_edcca_hl_diff = th_edcca_hl_diff;
+	odm->th_l2h_ini_mode2 = th_l2h_ini_mode2;
+	odm->th_edcca_hl_diff_mode2 = th_edcca_hl_diff_mode2;
+	odm->edcca_enable = edcca_enable;
 }
 
 void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter)
 {
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	DM_ODM_T *odm = &(hal_data->odmpriv);	
-	
-	DBG_871X_SEL_NL(sel,"RxRate = %s, RSSI_A = %d(%%), RSSI_B = %d(%%)\n", 
-	HDATA_RATE(odm->RxRate), odm->RSSI_A, odm->RSSI_B);	
+	struct dm_struct *odm = adapter_to_phydm(adapter);
+
+	RTW_PRINT_SEL(sel, "rx_rate = %s, rssi_a = %d(%%), rssi_b = %d(%%)\n",
+		      HDATA_RATE(odm->rx_rate), odm->rssi_a, odm->rssi_b);
 }
 
 
-void rtw_odm_acquirespinlock(_adapter *adapter,	RT_SPINLOCK_TYPE type)
+void rtw_odm_acquirespinlock(_adapter *adapter,	enum rt_spinlock_type type)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
 	_irqL irqL;
 
-	switch(type)
-	{
-		case RT_IQK_SPINLOCK:
-			_enter_critical_bh(&pHalData->IQKSpinLock, &irqL);
-		default:
-			break;
+	switch (type) {
+	case RT_IQK_SPINLOCK:
+		_enter_critical_bh(&pHalData->IQKSpinLock, &irqL);
+	default:
+		break;
 	}
 }
 
-void rtw_odm_releasespinlock(_adapter *adapter,	RT_SPINLOCK_TYPE type)
+void rtw_odm_releasespinlock(_adapter *adapter,	enum rt_spinlock_type type)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
 	_irqL irqL;
 
-	switch(type)
-	{
-		case RT_IQK_SPINLOCK:
-			_exit_critical_bh(&pHalData->IQKSpinLock, &irqL);
-		default:
-			break;
+	switch (type) {
+	case RT_IQK_SPINLOCK:
+		_exit_critical_bh(&pHalData->IQKSpinLock, &irqL);
+	default:
+		break;
 	}
 }
 
-#ifdef CONFIG_DFS_MASTER
-VOID rtw_odm_radar_detect_reset(_adapter *adapter)
+inline u8 rtw_odm_get_dfs_domain(_adapter *adapter)
 {
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	PDM_ODM_T pDM_Odm = &(hal_data->odmpriv);
-
-	if (pDM_Odm->SupportICType & ODM_RTL8192D) {
-		ODM_SetBBReg(pDM_Odm, 0xc84 , BIT25, 0);
-		ODM_SetBBReg(pDM_Odm, 0xc84 , BIT25, 1);
-	} else if (pDM_Odm->SupportICType & ODM_RTL8821) {
-		ODM_SetBBReg(pDM_Odm, 0x924 , BIT15, 0);
-		ODM_SetBBReg(pDM_Odm, 0x924 , BIT15, 1);
-	} else {
-		/* not supported yet */
-		rtw_warn_on(1);
-	}
+#ifdef CONFIG_DFS_MASTER
+	struct dm_struct *pDM_Odm = adapter_to_phydm(adapter);
+
+	return pDM_Odm->dfs_region_domain;
+#else
+	return PHYDM_DFS_DOMAIN_UNKNOWN;
+#endif
 }
 
-VOID rtw_odm_radar_detect_disable(_adapter *adapter)
+inline u8 rtw_odm_dfs_domain_unknown(_adapter *adapter)
 {
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	PDM_ODM_T pDM_Odm = &(hal_data->odmpriv);
-
-	if (pDM_Odm->SupportICType & ODM_RTL8192D)
-		ODM_SetBBReg(pDM_Odm, 0xc84 , BIT25, 0);
-	else if (pDM_Odm->SupportICType & ODM_RTL8821)
-		ODM_SetBBReg(pDM_Odm, 0x924 , BIT15, 0);
-	else
-		rtw_warn_on(1);
+#ifdef CONFIG_DFS_MASTER
+	return rtw_odm_get_dfs_domain(adapter) == PHYDM_DFS_DOMAIN_UNKNOWN;
+#else
+	return 1;
+#endif
 }
 
-/* called after ch, bw is set, chance to adjust parameter for different ch conditions */
-VOID rtw_odm_radar_detect_enable(_adapter *adapter)
+#ifdef CONFIG_DFS_MASTER
+inline VOID rtw_odm_radar_detect_reset(_adapter *adapter)
 {
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	PDM_ODM_T pDM_Odm = &(hal_data->odmpriv);
-
-	if (pDM_Odm->SupportICType & ODM_RTL8192D) {
-		ODM_SetBBReg(pDM_Odm, 0xc38, BIT23 | BIT22, 2);
-		ODM_SetBBReg(pDM_Odm, 0x814, bMaskDWord, 0x04cc4d10);
-		ODM_SetBBReg(pDM_Odm, 0xc8c, BIT23 | BIT22, 3);
-		ODM_SetBBReg(pDM_Odm, 0xc30, 0xf, 0xa);
-		ODM_SetBBReg(pDM_Odm, 0xcdc, 0xf0000, 4);
-	} else if (pDM_Odm->SupportICType & ODM_RTL8821) {
-		ODM_SetBBReg(pDM_Odm, 0x814, 0x3fffffff, 0x04cc4d10);
-		ODM_SetBBReg(pDM_Odm, 0x834, bMaskByte0, 0x06);
-		ODM_SetBBReg(pDM_Odm, 0x918, bMaskDWord, 0x1c16ecdf);
-		ODM_SetBBReg(pDM_Odm, 0x924, bMaskDWord, 0x0152a400);
-		ODM_SetBBReg(pDM_Odm, 0x91c, bMaskDWord, 0x0fa21a20);
-		ODM_SetBBReg(pDM_Odm, 0x920, bMaskDWord, 0xe0f57204);
-	} else {
-		/* not supported yet */
-		rtw_warn_on(1);
-	}
+	phydm_radar_detect_reset(adapter_to_phydm(adapter));
+}
 
-	rtw_odm_radar_detect_reset(adapter);
+inline VOID rtw_odm_radar_detect_disable(_adapter *adapter)
+{
+	phydm_radar_detect_disable(adapter_to_phydm(adapter));
 }
 
-BOOLEAN rtw_odm_radar_detect(_adapter *adapter)
+/* called after ch, bw is set */
+inline VOID rtw_odm_radar_detect_enable(_adapter *adapter)
 {
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	PDM_ODM_T pDM_Odm = &(hal_data->odmpriv);
-	BOOLEAN enable_DFS = FALSE;
-	BOOLEAN bypass = FALSE;
-	BOOLEAN radar_detected = FALSE;
-
-	static u8Byte last_tx_unicast = 0;
-	static u8Byte last_rx_unicast = 0;
-	static u8Byte throughput = 0;
-	int tp_th = ((*pDM_Odm->pBandWidth == ODM_BW40M) ? 45 : 20); /*refer AP team's testing number*/
-
-	throughput = (*(pDM_Odm->pNumTxBytesUnicast) - last_tx_unicast) + (*(pDM_Odm->pNumRxBytesUnicast) - last_rx_unicast);
-	last_tx_unicast = *(pDM_Odm->pNumTxBytesUnicast);
-	last_rx_unicast = *(pDM_Odm->pNumRxBytesUnicast);
-
-	if (throughput>>18 > tp_th) {
-		if (pDM_Odm->SupportICType & ODM_RTL8192D)
-			ODM_SetBBReg(pDM_Odm, 0xcdc, BIT8|BIT9, 0);
-		bypass = TRUE;
-	} else {
-		if (pDM_Odm->SupportICType & ODM_RTL8192D)
-			ODM_SetBBReg(pDM_Odm, 0xcdc, BIT8|BIT9, 1);
-	}
+	phydm_radar_detect_enable(adapter_to_phydm(adapter));
+}
 
-	if (pDM_Odm->SupportICType & ODM_RTL8192D) {
-		if (ODM_GetBBReg(pDM_Odm , 0xc84, BIT25))
-			enable_DFS = TRUE;
-	} else if (pDM_Odm->SupportICType & ODM_RTL8821) {
-		if (ODM_GetBBReg(pDM_Odm , 0x924, BIT15))
-			enable_DFS = TRUE;
-	}
+inline BOOLEAN rtw_odm_radar_detect(_adapter *adapter)
+{
+	return phydm_radar_detect(adapter_to_phydm(adapter));
+}
+#endif /* CONFIG_DFS_MASTER */
 
-	if (pDM_Odm->SupportICType & ODM_RTL8192D) {
-		if (ODM_GetBBReg(pDM_Odm , 0xcf8, BIT23))
-			radar_detected = TRUE;
-	} else if (pDM_Odm->SupportICType & ODM_RTL8821) {
-		if (ODM_GetBBReg(pDM_Odm , 0xf98, BIT17))
-			radar_detected = TRUE;
+void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)
+{
+#ifndef DBG_RX_PHYSTATUS_CHINFO
+#define DBG_RX_PHYSTATUS_CHINFO 0
+#endif
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+	_adapter *adapter = rframe->u.hdr.adapter;
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	struct rx_pkt_attrib *attrib = &rframe->u.hdr.attrib;
+	u8 *wlanhdr = get_recvframe_data(rframe);
+
+	if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+		/*
+		* 8723D:
+		* type_0(CCK)
+		*     l_rxsc
+		*         is filled with primary channel SC, not real rxsc.
+		*         0:LSC, 1:USC
+		* type_1(OFDM)
+		*     rf_mode
+		*         RF bandwidth when RX
+		*     l_rxsc(legacy), ht_rxsc
+		*         see below RXSC N-series
+		* type_2(Not used)
+		*/
+		/*
+		* 8821C, 8822B:
+		* type_0(CCK)
+		*     l_rxsc
+		*         is filled with primary channel SC, not real rxsc.
+		*         0:LSC, 1:USC
+		* type_1(OFDM)
+		*     rf_mode
+		*         RF bandwidth when RX
+		*     l_rxsc(legacy), ht_rxsc
+		*         see below RXSC AC-series
+		* type_2(Not used)
+		*/
+
+		if ((*phys & 0xf) == 0) {
+			struct phy_status_rpt_jaguar2_type0 *phys_t0 = (struct phy_status_rpt_jaguar2_type0 *)phys;
+
+			if (DBG_RX_PHYSTATUS_CHINFO) {
+				RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u)\n"
+					, *phys & 0xf
+					, MAC_ARG(get_ta(wlanhdr))
+					, is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
+					, HDATA_RATE(attrib->data_rate)
+					, phys_t0->band, phys_t0->channel, phys_t0->rxsc
+				);
+			}
+
+		} else if ((*phys & 0xf) == 1) {
+			struct phy_status_rpt_jaguar2_type1 *phys_t1 = (struct phy_status_rpt_jaguar2_type1 *)phys;
+			u8 rxsc = (attrib->data_rate > DESC_RATE11M && attrib->data_rate < DESC_RATEMCS0) ? phys_t1->l_rxsc : phys_t1->ht_rxsc;
+			u8 pkt_cch = 0;
+			u8 pkt_bw = CHANNEL_WIDTH_20;
+
+			#if	ODM_IC_11N_SERIES_SUPPORT
+			if (phydm->support_ic_type & ODM_IC_11N_SERIES) {
+				/* RXSC N-series */
+				#define RXSC_DUP	0
+				#define RXSC_LSC	1
+				#define RXSC_USC	2
+				#define RXSC_40M	3
+
+				static const s8 cch_offset_by_rxsc[4] = {0, -2, 2, 0};
+
+				if (phys_t1->rf_mode == 0) {
+					pkt_cch = phys_t1->channel;
+					pkt_bw = CHANNEL_WIDTH_20;
+				} else if (phys_t1->rf_mode == 1) {
+					if (rxsc == RXSC_LSC || rxsc == RXSC_USC) {
+						pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
+						pkt_bw = CHANNEL_WIDTH_20;
+					} else if (rxsc == RXSC_40M) {
+						pkt_cch = phys_t1->channel;
+						pkt_bw = CHANNEL_WIDTH_40;
+					}
+				} else
+					rtw_warn_on(1);
+
+				goto type1_end;
+			}
+			#endif /* ODM_IC_11N_SERIES_SUPPORT */
+
+			#if	ODM_IC_11AC_SERIES_SUPPORT
+			if (phydm->support_ic_type & ODM_IC_11AC_SERIES) {
+				/* RXSC AC-series */
+				#define RXSC_DUP			0 /* 0: RX from all SC of current rf_mode */
+
+				#define RXSC_LL20M_OF_160M	8 /* 1~8: RX from 20MHz SC */
+				#define RXSC_L20M_OF_160M	6
+				#define RXSC_L20M_OF_80M	4
+				#define RXSC_L20M_OF_40M	2
+				#define RXSC_U20M_OF_40M	1
+				#define RXSC_U20M_OF_80M	3
+				#define RXSC_U20M_OF_160M	5
+				#define RXSC_UU20M_OF_160M	7
+
+				#define RXSC_L40M_OF_160M	12 /* 9~12: RX from 40MHz SC */
+				#define RXSC_L40M_OF_80M	10
+				#define RXSC_U40M_OF_80M	9
+				#define RXSC_U40M_OF_160M	11
+
+				#define RXSC_L80M_OF_160M	14 /* 13~14: RX from 80MHz SC */
+				#define RXSC_U80M_OF_160M	13
+
+				static const s8 cch_offset_by_rxsc[15] = {0, 2, -2, 6, -6, 10, -10, 14, -14, 4, -4, 12, -12, 8, -8};
+
+				if (phys_t1->rf_mode > 3) {
+					/* invalid rf_mode */
+					rtw_warn_on(1);
+					goto type1_end;
+				}
+
+				if (phys_t1->rf_mode == 0) {
+					/* RF 20MHz */
+					pkt_cch = phys_t1->channel;
+					pkt_bw = CHANNEL_WIDTH_20;
+					goto type1_end;
+				}
+
+				if (rxsc == 0) {
+					/* RF and RX with same BW */
+					if (attrib->data_rate >= DESC_RATEMCS0) {
+						pkt_cch = phys_t1->channel;
+						pkt_bw = phys_t1->rf_mode;
+					}
+					goto type1_end;
+				}
+
+				if ((phys_t1->rf_mode == 1 && rxsc >= 1 && rxsc <= 2) /* RF 40MHz, RX 20MHz */
+					|| (phys_t1->rf_mode == 2 && rxsc >= 1 && rxsc <= 4) /* RF 80MHz, RX 20MHz */
+					|| (phys_t1->rf_mode == 3 && rxsc >= 1 && rxsc <= 8) /* RF 160MHz, RX 20MHz */
+				) {
+					pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
+					pkt_bw = CHANNEL_WIDTH_20;
+				} else if ((phys_t1->rf_mode == 2 && rxsc >= 9 && rxsc <= 10) /* RF 80MHz, RX 40MHz */
+					|| (phys_t1->rf_mode == 3 && rxsc >= 9 && rxsc <= 12) /* RF 160MHz, RX 40MHz */
+				) {
+					if (attrib->data_rate >= DESC_RATEMCS0) {
+						pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
+						pkt_bw = CHANNEL_WIDTH_40;
+					}
+				} else if ((phys_t1->rf_mode == 3 && rxsc >= 13 && rxsc <= 14) /* RF 160MHz, RX 80MHz */
+				) {
+					if (attrib->data_rate >= DESC_RATEMCS0) {
+						pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
+						pkt_bw = CHANNEL_WIDTH_80;
+					}
+				} else
+					rtw_warn_on(1);
+
+			}
+			#endif /* ODM_IC_11AC_SERIES_SUPPORT */
+
+type1_end:
+			if (DBG_RX_PHYSTATUS_CHINFO) {
+				RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, rf_mode:%u, l_rxsc:%u, ht_rxsc:%u) => %u,%u\n"
+					, *phys & 0xf
+					, MAC_ARG(get_ta(wlanhdr))
+					, is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
+					, HDATA_RATE(attrib->data_rate)
+					, phys_t1->band, phys_t1->channel, phys_t1->rf_mode, phys_t1->l_rxsc, phys_t1->ht_rxsc
+					, pkt_cch, pkt_bw
+				);
+			}
+
+			/* for now, only return cneter channel of 20MHz packet */
+			if (pkt_cch && pkt_bw == CHANNEL_WIDTH_20)
+				attrib->ch = pkt_cch;
+
+		} else {
+			struct phy_status_rpt_jaguar2_type2 *phys_t2 = (struct phy_status_rpt_jaguar2_type2 *)phys;
+
+			if (DBG_RX_PHYSTATUS_CHINFO) {
+				RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u, ht_rxsc:%u)\n"
+					, *phys & 0xf
+					, MAC_ARG(get_ta(wlanhdr))
+					, is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
+					, HDATA_RATE(attrib->data_rate)
+					, phys_t2->band, phys_t2->channel, phys_t2->l_rxsc, phys_t2->ht_rxsc
+				);
+			}
+		}
 	}
+#endif /* (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1) */
 
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD
-		, ("Radar detect: enable_DFS:%d, radar_detected:%d, bypass:%d\n"
-			, enable_DFS, radar_detected, bypass));
-	if (0)
-		DBG_871X("Radar detect: enable_DFS:%d, radar_detected:%d, bypass:%d(throughput:%llu, tp_th:%d)\n"
-			, enable_DFS, radar_detected, bypass, throughput, tp_th);
-
-	if (enable_DFS && radar_detected)
-		rtw_odm_radar_detect_reset(adapter);
-
-exit:
-	return (enable_DFS && radar_detected && !bypass);
 }
-#endif /* CONFIG_DFS_MASTER */
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_p2p.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_p2p.c
index 1add6b6b2490..c205c69e037a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_p2p.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_p2p.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,31 +12,24 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_P2P_C_
 
 #include <drv_types.h>
 
 #ifdef CONFIG_P2P
 
-int rtw_p2p_is_channel_list_ok( u8 desired_ch, u8* ch_list, u8 ch_cnt )
+int rtw_p2p_is_channel_list_ok(u8 desired_ch, u8 *ch_list, u8 ch_cnt)
 {
 	int found = 0, i = 0;
 
-	for( i = 0; i < ch_cnt; i++ )
-	{
-		if ( ch_list[ i ] == desired_ch )
-		{
+	for (i = 0; i < ch_cnt; i++) {
+		if (ch_list[i] == desired_ch) {
 			found = 1;
 			break;
 		}
 	}
-	return( found );
+	return found ;
 }
 
 int is_any_client_associated(_adapter *padapter)
@@ -47,22 +41,22 @@ static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
 	_irqL irqL;
 	_list	*phead, *plist;
-	u32 len=0;
+	u32 len = 0;
 	u16 attr_len = 0;
 	u8 tmplen, *pdata_attr, *pstart, *pcur;
 	struct sta_info *psta = NULL;
 	_adapter *padapter = pwdinfo->padapter;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
 
 	pdata_attr = rtw_zmalloc(MAX_P2P_IE_LEN);
 
-	if(NULL == pdata_attr){
-		DBG_871X("%s pdata_attr malloc failed \n", __FUNCTION__);
+	if (NULL == pdata_attr) {
+		RTW_INFO("%s pdata_attr malloc failed\n", __FUNCTION__);
 		goto _exit;
 	}
-	
+
 	pstart = pdata_attr;
 	pcur = pdata_attr;
 
@@ -70,32 +64,30 @@ static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)
 	phead = &pstapriv->asoc_list;
 	plist = get_next(phead);
 
-	//look up sta asoc_queue
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)	
-	{		
+	/* look up sta asoc_queue */
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		
+
 		plist = get_next(plist);
-		
 
-		if(psta->is_p2p_device)
-		{
+
+		if (psta->is_p2p_device) {
 			tmplen = 0;
-			
+
 			pcur++;
-		
-			//P2P device address
+
+			/* P2P device address */
 			_rtw_memcpy(pcur, psta->dev_addr, ETH_ALEN);
 			pcur += ETH_ALEN;
 
-			//P2P interface address
-			_rtw_memcpy(pcur, psta->hwaddr, ETH_ALEN);
+			/* P2P interface address */
+			_rtw_memcpy(pcur, psta->cmn.mac_addr, ETH_ALEN);
 			pcur += ETH_ALEN;
 
 			*pcur = psta->dev_cap;
 			pcur++;
 
-			//*(u16*)(pcur) = cpu_to_be16(psta->config_methods);
+			/* *(u16*)(pcur) = cpu_to_be16(psta->config_methods); */
 			RTW_PUT_BE16(pcur, psta->config_methods);
 			pcur += 2;
 
@@ -105,16 +97,15 @@ static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)
 			*pcur = psta->num_of_secdev_type;
 			pcur++;
 
-			_rtw_memcpy(pcur, psta->secdev_types_list, psta->num_of_secdev_type*8);
-			pcur += psta->num_of_secdev_type*8;
-			
-			if(psta->dev_name_len>0)
-			{
-				//*(u16*)(pcur) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+			_rtw_memcpy(pcur, psta->secdev_types_list, psta->num_of_secdev_type * 8);
+			pcur += psta->num_of_secdev_type * 8;
+
+			if (psta->dev_name_len > 0) {
+				/* *(u16*)(pcur) = cpu_to_be16( WPS_ATTR_DEVICE_NAME ); */
 				RTW_PUT_BE16(pcur, WPS_ATTR_DEVICE_NAME);
 				pcur += 2;
 
-				//*(u16*)(pcur) = cpu_to_be16( psta->dev_name_len );
+				/* *(u16*)(pcur) = cpu_to_be16( psta->dev_name_len ); */
 				RTW_PUT_BE16(pcur, psta->dev_name_len);
 				pcur += 2;
 
@@ -123,28 +114,26 @@ static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)
 			}
 
 
-			tmplen = (u8)(pcur-pstart);
-			
-			*pstart = (tmplen-1);
+			tmplen = (u8)(pcur - pstart);
+
+			*pstart = (tmplen - 1);
 
 			attr_len += tmplen;
 
-			//pstart += tmplen;
+			/* pstart += tmplen; */
 			pstart = pcur;
-			
+
 		}
-		
-		
+
+
 	}
 	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 
-	if(attr_len>0)
-	{
+	if (attr_len > 0)
 		len = rtw_set_p2p_attr_content(pbuf, P2P_ATTR_GROUP_INFO, attr_len, pdata_attr);
-	}
 
 	rtw_mfree(pdata_attr, MAX_P2P_IE_LEN);
-	
+
 _exit:
 	return len;
 
@@ -159,20 +148,19 @@ static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)
 	unsigned short				*fctrl;
 	_adapter *padapter = pwdinfo->padapter;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);	
-	unsigned char category = RTW_WLAN_CATEGORY_P2P;//P2P action frame	
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	unsigned char category = RTW_WLAN_CATEGORY_P2P;/* P2P action frame	 */
 	u32	p2poui = cpu_to_be32(P2POUI);
 	u8	oui_subtype = P2P_GO_DISC_REQUEST;
-	u8	dialogToken=0;
+	u8	dialogToken = 0;
 
-	DBG_871X("[%s]\n", __FUNCTION__);
+	RTW_INFO("[%s]\n", __FUNCTION__);
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -190,18 +178,18 @@ static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//Build P2P action frame header
-	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));	
+	/* Build P2P action frame header */
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));		
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
 
-	//there is no IE in this P2P action frame
+	/* there is no IE in this P2P action frame */
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
@@ -210,7 +198,7 @@ static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)
 }
 
 static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 status, u8 dialogToken)
-{	
+{
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
@@ -218,22 +206,21 @@ static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 s
 	unsigned short				*fctrl;
 	_adapter *padapter = pwdinfo->padapter;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);	
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_DEVDISC_RESP;
 	u8 p2pie[8] = { 0x00 };
-	u32 p2pielen = 0;	
+	u32 p2pielen = 0;
 
-	DBG_871X("[%s]\n", __FUNCTION__);
-	
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	RTW_INFO("[%s]\n", __FUNCTION__);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -251,31 +238,31 @@ static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 s
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//Build P2P public action frame header
+	/* Build P2P public action frame header */
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));		
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
 
 
-	//Build P2P IE
-	//	P2P OUI
+	/* Build P2P IE */
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
 
-	// P2P_ATTR_STATUS
+	/* P2P_ATTR_STATUS */
 	p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_STATUS, 1, &status);
-	
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, p2pie, &pattrib->pktlen);	
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, p2pie, &pattrib->pktlen);
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
@@ -283,20 +270,20 @@ static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 s
 
 }
 
-static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8* raddr, u8* frame_body, u16 config_method)
+static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr, u8 *frame_body, u16 config_method)
 {
 	_adapter *padapter = pwdinfo->padapter;
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
-	u8			dialogToken = frame_body[7];	//	The Dialog Token of provisioning discovery request frame.
+	u8			dialogToken = frame_body[7];	/*	The Dialog Token of provisioning discovery request frame. */
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_PROVISION_DISC_RESP;
-	u8			wpsie[ 100 ] = { 0x00 };
+	u8			wpsie[100] = { 0x00 };
 	u8			wpsielen = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
-	
+
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	unsigned char					*pframe;
@@ -307,12 +294,11 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8* raddr,
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -330,7 +316,7 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8* raddr,
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -338,46 +324,46 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8* raddr,
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));		
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
 
 	wpsielen = 0;
-	//	WPS OUI
-	//*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+	/*	WPS OUI */
+	/* *(u32*) ( wpsie ) = cpu_to_be32( WPSOUI ); */
 	RTW_PUT_BE32(wpsie, WPSOUI);
 	wpsielen += 4;
 
 #if 0
-	//	WPS version
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 	wpsielen += 2;
 
-	//	Value:
-	wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 #endif
 
-	//	Config Method
-	//	Type:
-	//*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD );
+	/*	Config Method */
+	/*	Type: */
+	/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD ); */
 	RTW_PUT_BE16(wpsie + wpsielen, WPS_ATTR_CONF_METHOD);
 	wpsielen += 2;
 
-	//	Length:
-	//*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+	/*	Length: */
+	/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 ); */
 	RTW_PUT_BE16(wpsie + wpsielen, 0x0002);
 	wpsielen += 2;
 
-	//	Value:
-	//*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( config_method );
+	/*	Value: */
+	/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( config_method ); */
 	RTW_PUT_BE16(wpsie + wpsielen, config_method);
 	wpsielen += 2;
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen );	
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
 
 #ifdef CONFIG_WFD
 	wfdielen = build_provdisc_resp_wfd_ie(pwdinfo, pframe);
@@ -402,22 +388,21 @@ static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8
 	unsigned short				*fctrl;
 	_adapter *padapter = pwdinfo->padapter;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);	
-	unsigned char category = RTW_WLAN_CATEGORY_P2P;//P2P action frame	
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	unsigned char category = RTW_WLAN_CATEGORY_P2P;/* P2P action frame	 */
 	u32	p2poui = cpu_to_be32(P2POUI);
-	u8	oui_subtype = P2P_PRESENCE_RESPONSE;	
-	u8 p2pie[ MAX_P2P_IE_LEN] = { 0x00 };
+	u8	oui_subtype = P2P_PRESENCE_RESPONSE;
+	u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
 	u8 noa_attr_content[32] = { 0x00 };
 	u32 p2pielen = 0;
 
-	DBG_871X("[%s]\n", __FUNCTION__);
+	RTW_INFO("[%s]\n", __FUNCTION__);
 
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
 		return;
-	}
 
-	//update attribute
+	/* update attribute */
 	pattrib = &pmgntframe->attrib;
 	update_mgntframe_attrib(padapter, pattrib);
 
@@ -435,42 +420,42 @@ static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//Build P2P action frame header
-	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));	
+	/* Build P2P action frame header */
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));	
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
 
 
-	//Add P2P IE header
-	//	P2P OUI
+	/* Add P2P IE header */
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
 
-	//Add Status attribute in P2P IE 
+	/* Add Status attribute in P2P IE */
 	p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_STATUS, 1, &status);
 
-	//Add NoA attribute in P2P IE
-	noa_attr_content[0] = 0x1;//index
-	noa_attr_content[1] = 0x0;//CTWindow and OppPS Parameters
-	
-	//todo: Notice of Absence Descriptor(s)
-	
+	/* Add NoA attribute in P2P IE */
+	noa_attr_content[0] = 0x1;/* index */
+	noa_attr_content[1] = 0x0;/* CTWindow and OppPS Parameters */
+
+	/* todo: Notice of Absence Descriptor(s) */
+
 	p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_NOA, 2, noa_attr_content);
 
 
 
 	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, p2pie, &(pattrib->pktlen));
 
-	
+
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
 	dump_mgntframe(padapter, pmgntframe);
@@ -479,179 +464,169 @@ static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8
 
 u32 build_beacon_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 p2pie[ MAX_P2P_IE_LEN] = { 0x00 };
-	u16 capability=0;
-	u32 len=0, p2pielen = 0;
-	
+	u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
+	u16 capability = 0;
+	u32 len = 0, p2pielen = 0;
 
-	//	P2P OUI
+
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-
-	//	According to the P2P Specification, the beacon frame should contain 3 P2P attributes
-	//	1. P2P Capability
-	//	2. P2P Device ID
-	//	3. Notice of Absence ( NOA )	
-
-	//	P2P Capability ATTR
-	//	Type:
-	//	Length:
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
-	//	Be able to participate in additional P2P Groups and
-	//	support the P2P Invitation Procedure	
-	//	Group Capability Bitmap, 1 byte	
-	capability = P2P_DEVCAP_INVITATION_PROC|P2P_DEVCAP_CLIENT_DISCOVERABILITY;
-	capability |=  ((P2P_GRPCAP_GO | P2P_GRPCAP_INTRABSS) << 8);
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
-		capability |= (P2P_GRPCAP_GROUP_FORMATION<<8);
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+
+	/*	According to the P2P Specification, the beacon frame should contain 3 P2P attributes */
+	/*	1. P2P Capability */
+	/*	2. P2P Device ID */
+	/*	3. Notice of Absence ( NOA )	 */
+
+	/*	P2P Capability ATTR */
+	/*	Type: */
+	/*	Length: */
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
+	/*	Be able to participate in additional P2P Groups and */
+	/*	support the P2P Invitation Procedure	 */
+	/*	Group Capability Bitmap, 1 byte	 */
+	capability = P2P_DEVCAP_INVITATION_PROC | P2P_DEVCAP_CLIENT_DISCOVERABILITY;
+	capability |= ((P2P_GRPCAP_GO | P2P_GRPCAP_INTRABSS) << 8);
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
+		capability |= (P2P_GRPCAP_GROUP_FORMATION << 8);
 
 	capability = cpu_to_le16(capability);
 
-	p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_CAPABILITY, 2, (u8*)&capability);
+	p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_CAPABILITY, 2, (u8 *)&capability);
+
 
-	
-	// P2P Device ID ATTR
+	/* P2P Device ID ATTR */
 	p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_DEVICE_ID, ETH_ALEN, pwdinfo->device_addr);
 
-	
-	// Notice of Absence ATTR
-	//	Type: 
-	//	Length:
-	//	Value:
-	
-	//go_add_noa_attr(pwdinfo);
-	
-	
+
+	/* Notice of Absence ATTR */
+	/*	Type:  */
+	/*	Length: */
+	/*	Value: */
+
+	/* go_add_noa_attr(pwdinfo); */
+
+
 	pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
-	
-	
+
+
 	return len;
-	
+
 }
 
 #ifdef CONFIG_WFD
 u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u16 val16=0;
-	u32 len=0, wfdielen = 0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u16 val16 = 0;
+	u32 len = 0, wfdielen = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110812
-	//	According to the WFD Specification, the beacon frame should contain 4 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID
-	//	3. Coupled Sink Information
+	/*	Commented by Albert 20110812 */
+	/*	According to the WFD Specification, the beacon frame should contain 4 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID */
+	/*	3. Coupled Sink Information */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
+	/*	Value1: */
+	/*	WFD device information */
 
-	if ( P2P_ROLE_GO == pwdinfo->role )
-	{
-		if ( is_any_client_associated( pwdinfo->padapter ) )
-		{
-			//	WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery)
+	if (P2P_ROLE_GO == pwdinfo->role) {
+		if (is_any_client_associated(pwdinfo->padapter)) {
+			/*	WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) */
 			val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD;
-			RTW_PUT_BE16(wfdie + wfdielen, val16);			
-		}
-		else
-		{
-			//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery)
+			RTW_PUT_BE16(wfdie + wfdielen, val16);
+		} else {
+			/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
 			val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 			RTW_PUT_BE16(wfdie + wfdielen, val16);
 		}
 
-	}
-	else
-	{
-		//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
+	} else {
+		/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
 		val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 		RTW_PUT_BE16(wfdie + wfdielen, val16);
 	}
-	
+
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
 
@@ -661,116 +636,109 @@ exit:
 
 u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u16 val16=0;
-	u32 len=0, wfdielen = 0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u16 val16 = 0;
+	u32 len = 0, wfdielen = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110812
-	//	According to the WFD Specification, the probe request frame should contain 4 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID
-	//	3. Coupled Sink Information
+	/*	Commented by Albert 20110812 */
+	/*	According to the WFD Specification, the probe request frame should contain 4 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID */
+	/*	3. Coupled Sink Information */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
+	/*	Value1: */
+	/*	WFD device information */
 
-	if ( 1 == pwdinfo->wfd_tdls_enable )
-	{
-		//	WFD primary sink + available for WFD session + WiFi TDLS mode + WSC ( WFD Service Discovery )	
-		val16 = pwfd_info->wfd_device_type | 
-						WFD_DEVINFO_SESSION_AVAIL | 
-						WFD_DEVINFO_WSD |
-						WFD_DEVINFO_PC_TDLS;
-		RTW_PUT_BE16(wfdie + wfdielen, val16 );
-	}
-	else
-	{
-		//	WFD primary sink + available for WFD session + WiFi Direct mode + WSC ( WFD Service Discovery )	
+	if (1 == pwdinfo->wfd_tdls_enable) {
+		/*	WFD primary sink + available for WFD session + WiFi TDLS mode + WSC ( WFD Service Discovery )	 */
+		val16 = pwfd_info->wfd_device_type |
+			WFD_DEVINFO_SESSION_AVAIL |
+			WFD_DEVINFO_WSD |
+			WFD_DEVINFO_PC_TDLS;
+		RTW_PUT_BE16(wfdie + wfdielen, val16);
+	} else {
+		/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSC ( WFD Service Discovery )	 */
 		val16 = pwfd_info->wfd_device_type |
-						WFD_DEVINFO_SESSION_AVAIL | 
-						WFD_DEVINFO_WSD;
-		RTW_PUT_BE16(wfdie + wfdielen, val16 );
+			WFD_DEVINFO_SESSION_AVAIL |
+			WFD_DEVINFO_WSD;
+		RTW_PUT_BE16(wfdie + wfdielen, val16);
 	}
 
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
 
@@ -780,195 +748,188 @@ exit:
 
 u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunneled)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
+	u16 v16 = 0;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110812
-	//	According to the WFD Specification, the probe response frame should contain 4 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID
-	//	3. Coupled Sink Information
-	//	4. WFD Session Information
+	/*	Commented by Albert 20110812 */
+	/*	According to the WFD Specification, the probe response frame should contain 4 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID */
+	/*	3. Coupled Sink Information */
+	/*	4. WFD Session Information */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + available for WFD session + WiFi Direct mode
-	
-	if (  _TRUE == pwdinfo->session_available )
-	{
-		if ( P2P_ROLE_GO == pwdinfo->role )
-		{
-			if ( is_any_client_associated( pwdinfo->padapter ) )
-			{
-				if ( pwdinfo->wfd_tdls_enable )
-				{
-					//	TDLS mode + WSD ( WFD Service Discovery )
-					RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + available for WFD session + WiFi Direct mode */
+
+	if (_TRUE == pwdinfo->session_available) {
+		if (P2P_ROLE_GO == pwdinfo->role) {
+			if (is_any_client_associated(pwdinfo->padapter)) {
+				if (pwdinfo->wfd_tdls_enable) {
+					/*	TDLS mode + WSD ( WFD Service Discovery ) */
+					v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
+					RTW_PUT_BE16(wfdie + wfdielen, v16);
+				} else {
+					/*	WiFi Direct mode + WSD ( WFD Service Discovery ) */
+					v16 =  pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
+					RTW_PUT_BE16(wfdie + wfdielen, v16);
 				}
-				else
-				{
-					//	WiFi Direct mode + WSD ( WFD Service Discovery )
-					RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
-				}				
-			}
-			else
-			{
-				if ( pwdinfo->wfd_tdls_enable )
-				{
-					//	available for WFD session + TDLS mode + WSD ( WFD Service Discovery )
-					RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
+			} else {
+				if (pwdinfo->wfd_tdls_enable) {
+					/*	available for WFD session + TDLS mode + WSD ( WFD Service Discovery ) */
+					v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
+					RTW_PUT_BE16(wfdie + wfdielen, v16);
+				} else {
+					/*	available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
+					v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
+					RTW_PUT_BE16(wfdie + wfdielen, v16);
 				}
-				else
-				{
-					//	available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
-					RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
-				}				
-			}
-		}
-		else
-		{
-			if ( pwdinfo->wfd_tdls_enable )
-			{
-				//	available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
-				RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
 			}
-			else
-			{
-
-				//	available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
-				RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
+		} else {
+			if (pwdinfo->wfd_tdls_enable) {
+				/*	available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
+				v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
+				RTW_PUT_BE16(wfdie + wfdielen, v16);
+			} else {
+				/*	available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
+				v16 =  pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
+				RTW_PUT_BE16(wfdie + wfdielen, v16);
 			}
 		}
-	}
-	else
-	{
-		if ( pwdinfo->wfd_tdls_enable )
-		{
-			RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD |WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
-		}
-		else
-		{
-			RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
+	} else {
+		if (pwdinfo->wfd_tdls_enable) {
+			v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
+			RTW_PUT_BE16(wfdie + wfdielen, v16);
+		} else {
+			v16 =  pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
+			RTW_PUT_BE16(wfdie + wfdielen, v16);
 		}
-
 	}
 
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	{
-		//	WFD Session Information ATTR
-		//	Type:
-		wfdie[ wfdielen++ ] = WFD_ATTR_SESSION_INFO;
-
-		//	Length:
-		//	Note: In the WFD specification, the size of length field is 2.
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		/*	WFD Session Information ATTR */
+		/*	Type: */
+		wfdie[wfdielen++] = WFD_ATTR_SESSION_INFO;
+
+		/*	Length: */
+		/*	Note: In the WFD specification, the size of length field is 2. */
 		RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
 		wfdielen += 2;
 
-		//	Todo: to add the list of WFD device info descriptor in WFD group.
+		/*	Todo: to add the list of WFD device info descriptor in WFD group. */
 
 	}
 #ifdef CONFIG_CONCURRENT_MODE
 #ifdef CONFIG_TDLS
-	if ( ( tunneled == 0 ) && ( padapter->pbuddy_adapter->wdinfo.wfd_tdls_enable == 1 ) )
 	{
-		//	Alternative MAC Address ATTR
-		//	Type:
-		wfdie[ wfdielen++ ] = WFD_ATTR_ALTER_MAC;
-
-		//	Length:
-		//	Note: In the WFD specification, the size of length field is 2.
-		RTW_PUT_BE16(wfdie + wfdielen,  ETH_ALEN );
-		wfdielen += 2;
-
-		//	Value:
-		//	Alternative MAC Address
-		_rtw_memcpy(wfdie + wfdielen, adapter_mac_addr(padapter->pbuddy_adapter), ETH_ALEN);
-		//	This mac address is used to make the WFD session when TDLS is enable.
-
-		wfdielen += ETH_ALEN;
+		int i;
+		_adapter *iface = NULL;
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if ((iface) && rtw_is_adapter_up(iface)) {
+				if (iface == padapter)
+					continue;
+
+				if ((tunneled == 0) && (iface->wdinfo.wfd_tdls_enable == 1)) {
+					/*	Alternative MAC Address ATTR
+						Type:					*/
+					wfdie[wfdielen++] = WFD_ATTR_ALTER_MAC;
+
+					/*	Length:
+						Note: In the WFD specification, the size of length field is 2.*/
+					RTW_PUT_BE16(wfdie + wfdielen,  ETH_ALEN);
+					wfdielen += 2;
+
+					/*	Value:
+						Alternative MAC Address*/
+					_rtw_memcpy(wfdie + wfdielen, adapter_mac_addr(iface), ETH_ALEN);
+					wfdielen += ETH_ALEN;
+				}
+			}
+		}
 	}
-#endif // CONFIG_TDLS
-#endif // CONFIG_CONCURRENT_MODE
+
+#endif /* CONFIG_TDLS*/
+#endif /* CONFIG_CONCURRENT_MODE */
 
 	pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
 
@@ -978,10 +939,10 @@ exit:
 
 u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u16 val16=0;
-	u32 len=0, wfdielen = 0;
-	_adapter 					*padapter = NULL;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u16 val16 = 0;
+	u32 len = 0, wfdielen = 0;
+	_adapter					*padapter = NULL;
 	struct mlme_priv			*pmlmepriv = NULL;
 	struct wifi_display_info		*pwfd_info = NULL;
 
@@ -997,88 +958,84 @@ u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 
 	/* WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110812
-	//	According to the WFD Specification, the probe request frame should contain 4 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID
-	//	3. Coupled Sink Information
+	/*	Commented by Albert 20110812 */
+	/*	According to the WFD Specification, the probe request frame should contain 4 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID */
+	/*	3. Coupled Sink Information */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
 
@@ -1088,100 +1045,96 @@ exit:
 
 u32 build_assoc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
-	u16 val16=0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
+	u16 val16 = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110812
-	//	According to the WFD Specification, the probe request frame should contain 4 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID
-	//	3. Coupled Sink Information
+	/*	Commented by Albert 20110812 */
+	/*	According to the WFD Specification, the probe request frame should contain 4 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID */
+	/*	3. Coupled Sink Information */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
 
@@ -1191,100 +1144,96 @@ exit:
 
 u32 build_nego_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
-	u16 val16=0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
+	u16 val16 = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110825
-	//	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID ( Optional )
-	//	3. Local IP Adress ( Optional )
+	/*	Commented by Albert 20110825 */
+	/*	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID ( Optional ) */
+	/*	3. Local IP Adress ( Optional ) */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
 
@@ -1294,100 +1243,96 @@ exit:
 
 u32 build_nego_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
-	u16 val16=0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
+	u16 val16 = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110825
-	//	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID ( Optional )
-	//	3. Local IP Adress ( Optional )
+	/*	Commented by Albert 20110825 */
+	/*	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID ( Optional ) */
+	/*	3. Local IP Adress ( Optional ) */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
@@ -1398,100 +1343,96 @@ exit:
 
 u32 build_nego_confirm_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
-	u16 val16=0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
+	u16 val16 = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110825
-	//	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID ( Optional )
-	//	3. Local IP Adress ( Optional )
+	/*	Commented by Albert 20110825 */
+	/*	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID ( Optional ) */
+	/*	3. Local IP Adress ( Optional ) */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 
 	pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
@@ -1502,113 +1443,108 @@ exit:
 
 u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
-	u16 val16=0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
+	u16 val16 = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110825
-	//	According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID ( Optional )
-	//	3. Local IP Adress ( Optional )
+	/*	Commented by Albert 20110825 */
+	/*	According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID ( Optional ) */
+	/*	3. Local IP Adress ( Optional ) */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-
-	if ( P2P_ROLE_GO == pwdinfo->role )
-	{
-		//	WFD Session Information ATTR
-		//	Type:
-		wfdie[ wfdielen++ ] = WFD_ATTR_SESSION_INFO;
-
-		//	Length:
-		//	Note: In the WFD specification, the size of length field is 2.
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+
+	if (P2P_ROLE_GO == pwdinfo->role) {
+		/*	WFD Session Information ATTR */
+		/*	Type: */
+		wfdie[wfdielen++] = WFD_ATTR_SESSION_INFO;
+
+		/*	Length: */
+		/*	Note: In the WFD specification, the size of length field is 2. */
 		RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
 		wfdielen += 2;
 
-		//	Todo: to add the list of WFD device info descriptor in WFD group.
+		/*	Todo: to add the list of WFD device info descriptor in WFD group. */
 
 	}
 
@@ -1620,113 +1556,108 @@ exit:
 
 u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u16 val16=0;
-	u32 len=0, wfdielen = 0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u16 val16 = 0;
+	u32 len = 0, wfdielen = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110825
-	//	According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID ( Optional )
-	//	3. Local IP Adress ( Optional )
+	/*	Commented by Albert 20110825 */
+	/*	According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID ( Optional ) */
+	/*	3. Local IP Adress ( Optional ) */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-
-	if ( P2P_ROLE_GO == pwdinfo->role )
-	{
-		//	WFD Session Information ATTR
-		//	Type:
-		wfdie[ wfdielen++ ] = WFD_ATTR_SESSION_INFO;
-
-		//	Length:
-		//	Note: In the WFD specification, the size of length field is 2.
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+
+	if (P2P_ROLE_GO == pwdinfo->role) {
+		/*	WFD Session Information ATTR */
+		/*	Type: */
+		wfdie[wfdielen++] = WFD_ATTR_SESSION_INFO;
+
+		/*	Length: */
+		/*	Note: In the WFD specification, the size of length field is 2. */
 		RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
 		wfdielen += 2;
 
-		//	Todo: to add the list of WFD device info descriptor in WFD group.
+		/*	Todo: to add the list of WFD device info descriptor in WFD group. */
 
 	}
 
@@ -1738,100 +1669,96 @@ exit:
 
 u32 build_provdisc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
-	u16 val16=0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
+	u16 val16 = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110825
-	//	According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID ( Optional )
-	//	3. Local IP Adress ( Optional )
+	/*	Commented by Albert 20110825 */
+	/*	According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID ( Optional ) */
+	/*	3. Local IP Adress ( Optional ) */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
@@ -1842,100 +1769,96 @@ exit:
 
 u32 build_provdisc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 len=0, wfdielen = 0;
-	u16 val16=0;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 len = 0, wfdielen = 0;
+	u16 val16 = 0;
 	_adapter *padapter = pwdinfo->padapter;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info*	pwfd_info = padapter->wdinfo.wfd_info;
+	struct wifi_display_info	*pwfd_info = padapter->wdinfo.wfd_info;
 
 	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 		goto exit;
 
-	//	WFD OUI
+	/*	WFD OUI */
 	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	//	WFA WFD v1.0
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/*	WFA WFD v1.0 */
 
-	//	Commented by Albert 20110825
-	//	According to the WFD Specification, the provision discovery response frame should contain 3 WFD attributes
-	//	1. WFD Device Information
-	//	2. Associated BSSID ( Optional )
-	//	3. Local IP Adress ( Optional )
+	/*	Commented by Albert 20110825 */
+	/*	According to the WFD Specification, the provision discovery response frame should contain 3 WFD attributes */
+	/*	1. WFD Device Information */
+	/*	2. Associated BSSID ( Optional ) */
+	/*	3. Local IP Adress ( Optional ) */
 
 
-	//	WFD Device Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
+	/*	WFD Device Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value1:
-	//	WFD device information
-	//	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery )
+	/*	Value1: */
+	/*	WFD device information */
+	/*	WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
 	val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
 	RTW_PUT_BE16(wfdie + wfdielen, val16);
 	wfdielen += 2;
 
-	//	Value2:
-	//	Session Management Control Port
-	//	Default TCP port for RTSP messages is 554
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport );
+	/*	Value2: */
+	/*	Session Management Control Port */
+	/*	Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
 	wfdielen += 2;
 
-	//	Value3:
-	//	WFD Device Maximum Throughput
-	//	300Mbps is the maximum throughput
+	/*	Value3: */
+	/*	WFD Device Maximum Throughput */
+	/*	300Mbps is the maximum throughput */
 	RTW_PUT_BE16(wfdie + wfdielen, 300);
 	wfdielen += 2;
 
-	//	Associated BSSID ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
+	/*	Associated BSSID ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
 	wfdielen += 2;
 
-	//	Value:
-	//	Associated BSSID
-	if ( check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE )
-	{
-		_rtw_memcpy( wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN );
-	}
+	/*	Value: */
+	/*	Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
 	else
-	{
-		_rtw_memset( wfdie + wfdielen, 0x00, ETH_ALEN );
-	}
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
 
 	wfdielen += ETH_ALEN;
 
-	//	Coupled Sink Information ATTR
-	//	Type:
-	wfdie[ wfdielen++ ] = WFD_ATTR_COUPLED_SINK_INFO;
+	/*	Coupled Sink Information ATTR */
+	/*	Type: */
+	wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
 
-	//	Length:
-	//	Note: In the WFD specification, the size of length field is 2.
+	/*	Length: */
+	/*	Note: In the WFD specification, the size of length field is 2. */
 	RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
 	wfdielen += 2;
 
-	//	Value:
-	//	Coupled Sink Status bitmap
-	//	Not coupled/available for Coupling
-	wfdie[ wfdielen++ ] = 0;
-	//  MAC Addr.
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
-	wfdie[ wfdielen++ ] = 0;
+	/*	Value: */
+	/*	Coupled Sink Status bitmap */
+	/*	Not coupled/available for Coupling */
+	wfdie[wfdielen++] = 0;
+	/* MAC Addr. */
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
+	wfdie[wfdielen++] = 0;
 
 	rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
 
@@ -1946,178 +1869,163 @@ exit:
 
 u32 build_probe_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u8 p2pie[ MAX_P2P_IE_LEN] = { 0x00 };
-	u32 len=0, p2pielen = 0;	
+	u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
+	u32 len = 0, p2pielen = 0;
 #ifdef CONFIG_INTEL_WIDI
 	struct mlme_priv *pmlmepriv = &(pwdinfo->padapter->mlmepriv);
 	u8 zero_array_check[L2SDTA_SERVICE_VE_LEN] = { 0x00 };
 	u8 widi_version = 0, i = 0;
 
-	if( _rtw_memcmp( pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN ) == _FALSE )
-	{
+	if (_rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE)
 		widi_version = 35;
-	}
-	else if( pmlmepriv->num_p2p_sdt != 0 )
-	{
+	else if (pmlmepriv->num_p2p_sdt != 0)
 		widi_version = 40;
-	}
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20100907
-	//	According to the P2P Specification, the probe response frame should contain 5 P2P attributes
-	//	1. P2P Capability
-	//	2. Extended Listen Timing
-	//	3. Notice of Absence ( NOA )	( Only GO needs this )
-	//	4. Device Info
-	//	5. Group Info	( Only GO need this )
-
-	//	P2P Capability ATTR
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
-
-	//	Length:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20100907 */
+	/*	According to the P2P Specification, the probe response frame should contain 5 P2P attributes */
+	/*	1. P2P Capability */
+	/*	2. Extended Listen Timing */
+	/*	3. Notice of Absence ( NOA )	( Only GO needs this ) */
+	/*	4. Device Info */
+	/*	5. Group Info	( Only GO need this ) */
+
+	/*	P2P Capability ATTR */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+	/*	Length: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 ); */
 	RTW_PUT_LE16(p2pie + p2pielen, 0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
-	p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
-	
-	//	Group Capability Bitmap, 1 byte
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	{
-		p2pie[ p2pielen ] = (P2P_GRPCAP_GO | P2P_GRPCAP_INTRABSS);
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
+	p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
 
-		if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
-			p2pie[ p2pielen ] |= P2P_GRPCAP_GROUP_FORMATION;
+	/*	Group Capability Bitmap, 1 byte */
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		p2pie[p2pielen] = (P2P_GRPCAP_GO | P2P_GRPCAP_INTRABSS);
+
+		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
+			p2pie[p2pielen] |= P2P_GRPCAP_GROUP_FORMATION;
 
 		p2pielen++;
-	}
-	else if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) )
-	{
-		//	Group Capability Bitmap, 1 byte
-		if ( pwdinfo->persistent_supported )
-			p2pie[ p2pielen++ ] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
+	} else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)) {
+		/*	Group Capability Bitmap, 1 byte */
+		if (pwdinfo->persistent_supported)
+			p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
 		else
-			p2pie[ p2pielen++ ] = DMP_P2P_GRPCAP_SUPPORT;
+			p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
 	}
 
-	//	Extended Listen Timing ATTR
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_EX_LISTEN_TIMING;
+	/*	Extended Listen Timing ATTR */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
 
-	//	Length:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0004 );
+	/*	Length: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0004 ); */
 	RTW_PUT_LE16(p2pie + p2pielen, 0x0004);
 	p2pielen += 2;
 
-	//	Value:
-	//	Availability Period
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
+	/*	Value: */
+	/*	Availability Period */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF ); */
 	RTW_PUT_LE16(p2pie + p2pielen, 0xFFFF);
 	p2pielen += 2;
 
-	//	Availability Interval
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF );
+	/*	Availability Interval */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF ); */
 	RTW_PUT_LE16(p2pie + p2pielen, 0xFFFF);
 	p2pielen += 2;
 
 
-	// Notice of Absence ATTR
-	//	Type: 
-	//	Length:
-	//	Value:
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	{
-		//go_add_noa_attr(pwdinfo);
-	}	
+	/* Notice of Absence ATTR */
+	/*	Type:  */
+	/*	Length: */
+	/*	Value: */
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		/* go_add_noa_attr(pwdinfo); */
+	}
 
-	//	Device Info ATTR
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
+	/*	Device Info ATTR */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-	//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len ); */
 #ifdef CONFIG_INTEL_WIDI
-	if( widi_version == 35 )
-	{
+	if (widi_version == 35)
 		RTW_PUT_LE16(p2pie + p2pielen, 21 + 8 + pwdinfo->device_name_len);
-	}
-	else if( widi_version == 40 )
-	{
+	else if (widi_version == 40)
 		RTW_PUT_LE16(p2pie + p2pielen, 21 + 8 * pmlmepriv->num_p2p_sdt + pwdinfo->device_name_len);
-	}
 	else
-#endif //CONFIG_INTEL_WIDI
-	RTW_PUT_LE16(p2pie + p2pielen, 21 + pwdinfo->device_name_len);
+#endif /* CONFIG_INTEL_WIDI */
+		RTW_PUT_LE16(p2pie + p2pielen, 21 + pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	//	P2P Device Address
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN );
+	/*	Value: */
+	/*	P2P Device Address */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Config Method
-	//	This field should be big endian. Noted by P2P specification.
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->supported_wps_cm );
+	/*	Config Method */
+	/*	This field should be big endian. Noted by P2P specification. */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->supported_wps_cm ); */
 	RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->supported_wps_cm);
 	p2pielen += 2;
 
 #ifdef CONFIG_INTEL_WIDI
-	if( widi_version == 40 )
-	{
-		//	Primary Device Type
-		//	Category ID
-		//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
-		RTW_PUT_BE16(p2pie + p2pielen, pmlmepriv->p2p_pdt_cid );
+	if (widi_version == 40) {
+		/*	Primary Device Type */
+		/*	Category ID */
+		/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA ); */
+		RTW_PUT_BE16(p2pie + p2pielen, pmlmepriv->p2p_pdt_cid);
 		p2pielen += 2;
 
-		//	OUI
-		//*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
+		/*	OUI */
+		/* *(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI ); */
 		RTW_PUT_BE32(p2pie + p2pielen, WPSOUI);
 		p2pielen += 4;
 
-		//	Sub Category ID
-		//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+		/*	Sub Category ID */
+		/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER ); */
 		RTW_PUT_BE16(p2pie + p2pielen, pmlmepriv->p2p_pdt_scid);
 		p2pielen += 2;
-	}
-	else
-#endif //CONFIG_INTEL_WIDI
+	} else
+#endif /* CONFIG_INTEL_WIDI */
 	{
-		//	Primary Device Type
-		//	Category ID
-		//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+		/*	Primary Device Type */
+		/*	Category ID */
+		/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA ); */
 		RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_CID_MULIT_MEDIA);
 		p2pielen += 2;
 
-		//	OUI
-		//*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
+		/*	OUI */
+		/* *(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI ); */
 		RTW_PUT_BE32(p2pie + p2pielen, WPSOUI);
 		p2pielen += 4;
 
-		//	Sub Category ID
-		//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+		/*	Sub Category ID */
+		/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER ); */
 		RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_SCID_MEDIA_SERVER);
 		p2pielen += 2;
 	}
 
-	//	Number of Secondary Device Types
+	/*	Number of Secondary Device Types */
 #ifdef CONFIG_INTEL_WIDI
-	if( widi_version == 35 )
-	{
-		p2pie[ p2pielen++ ] = 0x01;
-		
+	if (widi_version == 35) {
+		p2pie[p2pielen++] = 0x01;
+
 		RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_CID_DISPLAYS);
 		p2pielen += 2;
 
@@ -2126,12 +2034,9 @@ u32 build_probe_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 
 		RTW_PUT_BE16(p2pie + p2pielen, P2P_SCID_WIDI_CONSUMER_SINK);
 		p2pielen += 2;
-	}
-	else if( widi_version == 40 )
-	{
-		p2pie[ p2pielen++ ] = pmlmepriv->num_p2p_sdt;
-		for( ; i < pmlmepriv->num_p2p_sdt; i++ )
-		{
+	} else if (widi_version == 40) {
+		p2pie[p2pielen++] = pmlmepriv->num_p2p_sdt;
+		for (; i < pmlmepriv->num_p2p_sdt; i++) {
 			RTW_PUT_BE16(p2pie + p2pielen, pmlmepriv->p2p_sdt_cid[i]);
 			p2pielen += 2;
 
@@ -2141,369 +2046,336 @@ u32 build_probe_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 			RTW_PUT_BE16(p2pie + p2pielen, pmlmepriv->p2p_sdt_scid[i]);
 			p2pielen += 2;
 		}
-	}
-	else
-#endif //CONFIG_INTEL_WIDI
-	p2pie[ p2pielen++ ] = 0x00;	//	No Secondary Device Type List
+	} else
+#endif /* CONFIG_INTEL_WIDI */
+		p2pie[p2pielen++] = 0x00;	/*	No Secondary Device Type List */
 
-	//	Device Name
-	//	Type:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+	/*	Device Name */
+	/*	Type: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME ); */
 	RTW_PUT_BE16(p2pie + p2pielen, WPS_ATTR_DEVICE_NAME);
 	p2pielen += 2;
 
-	//	Length:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len );
+	/*	Length: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len ); */
 	RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len );
+	/*	Value: */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
 	p2pielen += pwdinfo->device_name_len;
 
-	// Group Info ATTR
-	//	Type:
-	//	Length:
-	//	Value:
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	{
+	/* Group Info ATTR */
+	/*	Type: */
+	/*	Length: */
+	/*	Value: */
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
 		p2pielen += go_add_group_info_attr(pwdinfo, p2pie + p2pielen);
-	}
 
-	
+
 	pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
-	
+
 
 	return len;
-	
+
 }
 
-u32 build_prov_disc_request_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8* pssid, u8 ussidlen, u8* pdev_raddr )
+u32 build_prov_disc_request_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 *pssid, u8 ussidlen, u8 *pdev_raddr)
 {
-	u8 p2pie[ MAX_P2P_IE_LEN] = { 0x00 };
-	u32 len=0, p2pielen = 0;	
+	u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
+	u32 len = 0, p2pielen = 0;
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20110301
-	//	According to the P2P Specification, the provision discovery request frame should contain 3 P2P attributes
-	//	1. P2P Capability
-	//	2. Device Info
-	//	3. Group ID ( When joining an operating P2P Group )
-
-	//	P2P Capability ATTR
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
-
-	//	Length:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20110301 */
+	/*	According to the P2P Specification, the provision discovery request frame should contain 3 P2P attributes */
+	/*	1. P2P Capability */
+	/*	2. Device Info */
+	/*	3. Group ID ( When joining an operating P2P Group ) */
+
+	/*	P2P Capability ATTR */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+	/*	Length: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 ); */
 	RTW_PUT_LE16(p2pie + p2pielen, 0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
-	p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
-	
-	//	Group Capability Bitmap, 1 byte
-	if ( pwdinfo->persistent_supported )
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
+	p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
+
+	/*	Group Capability Bitmap, 1 byte */
+	if (pwdinfo->persistent_supported)
+		p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
 	else
-		p2pie[ p2pielen++ ] = DMP_P2P_GRPCAP_SUPPORT;
+		p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
 
 
-	//	Device Info ATTR
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
+	/*	Device Info ATTR */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
 
-	//	Length:
-	//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-	//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len ); */
 	RTW_PUT_LE16(p2pie + p2pielen, 21 + pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	//	P2P Device Address
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN );
+	/*	Value: */
+	/*	P2P Device Address */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Config Method
-	//	This field should be big endian. Noted by P2P specification.
-	if ( pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC )
-	{
-		//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_PBC );
+	/*	Config Method */
+	/*	This field should be big endian. Noted by P2P specification. */
+	if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC) {
+		/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_PBC ); */
 		RTW_PUT_BE16(p2pie + p2pielen, WPS_CONFIG_METHOD_PBC);
-	}
-	else
-	{
-		//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_DISPLAY );
+	} else {
+		/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_DISPLAY ); */
 		RTW_PUT_BE16(p2pie + p2pielen, WPS_CONFIG_METHOD_DISPLAY);
 	}
 
 	p2pielen += 2;
 
-	//	Primary Device Type
-	//	Category ID
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+	/*	Primary Device Type */
+	/*	Category ID */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA ); */
 	RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_CID_MULIT_MEDIA);
 	p2pielen += 2;
 
-	//	OUI
-	//*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
+	/*	OUI */
+	/* *(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI ); */
 	RTW_PUT_BE32(p2pie + p2pielen, WPSOUI);
 	p2pielen += 4;
 
-	//	Sub Category ID
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+	/*	Sub Category ID */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER ); */
 	RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_SCID_MEDIA_SERVER);
 	p2pielen += 2;
 
-	//	Number of Secondary Device Types
-	p2pie[ p2pielen++ ] = 0x00;	//	No Secondary Device Type List
+	/*	Number of Secondary Device Types */
+	p2pie[p2pielen++] = 0x00;	/*	No Secondary Device Type List */
 
-	//	Device Name
-	//	Type:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+	/*	Device Name */
+	/*	Type: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME ); */
 	RTW_PUT_BE16(p2pie + p2pielen, WPS_ATTR_DEVICE_NAME);
 	p2pielen += 2;
 
-	//	Length:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len );
+	/*	Length: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len ); */
 	RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len );
+	/*	Value: */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
 	p2pielen += pwdinfo->device_name_len;
 
-	if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) )
-	{
-		//	Added by Albert 2011/05/19
-		//	In this case, the pdev_raddr is the device address of the group owner.
-		
-		//	P2P Group ID ATTR
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_ID;
-
-		//	Length:
-		//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN + ussidlen );
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
+		/*	Added by Albert 2011/05/19 */
+		/*	In this case, the pdev_raddr is the device address of the group owner. */
+
+		/*	P2P Group ID ATTR */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
+
+		/*	Length: */
+		/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN + ussidlen ); */
 		RTW_PUT_LE16(p2pie + p2pielen, ETH_ALEN + ussidlen);
 		p2pielen += 2;
 
-		//	Value:
-		_rtw_memcpy( p2pie + p2pielen, pdev_raddr, ETH_ALEN );
+		/*	Value: */
+		_rtw_memcpy(p2pie + p2pielen, pdev_raddr, ETH_ALEN);
 		p2pielen += ETH_ALEN;
 
-		_rtw_memcpy( p2pie + p2pielen, pssid, ussidlen );
+		_rtw_memcpy(p2pie + p2pielen, pssid, ussidlen);
 		p2pielen += ussidlen;
-		
+
 	}
 
 	pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
-	
+
 
 	return len;
-	
+
 }
 
 
 u32 build_assoc_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 status_code)
 {
-	u8 p2pie[ MAX_P2P_IE_LEN] = { 0x00 };
-	u32 len=0, p2pielen = 0;	
+	u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
+	u32 len = 0, p2pielen = 0;
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
 
-	// According to the P2P Specification, the Association response frame should contain 2 P2P attributes
-	//	1. Status
-	//	2. Extended Listen Timing (optional)
+	/* According to the P2P Specification, the Association response frame should contain 2 P2P attributes */
+	/*	1. Status */
+	/*	2. Extended Listen Timing (optional) */
 
 
-	//	Status ATTR
+	/*	Status ATTR */
 	p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_STATUS, 1, &status_code);
 
 
-	// Extended Listen Timing ATTR
-	//	Type:
-	//	Length:
-	//	Value:
+	/* Extended Listen Timing ATTR */
+	/*	Type: */
+	/*	Length: */
+	/*	Value: */
 
 
 	pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
-	
+
 	return len;
-	
+
 }
 
 u32 build_deauth_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
 {
-	u32 len=0;
-	
+	u32 len = 0;
+
 	return len;
 }
 
 u32 process_probe_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
-{	
+{
 	u8 *p;
-	u32 ret=_FALSE;
+	u32 ret = _FALSE;
 	u8 *p2pie;
 	u32	p2pielen = 0;
-	int ssid_len=0, rate_cnt = 0;
+	int ssid_len = 0, rate_cnt = 0;
 
 	p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _SUPPORTEDRATES_IE_, (int *)&rate_cnt,
-			len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
+		       len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
 
-	if ( rate_cnt <= 4 )
-	{
-		int i, g_rate =0;
+	if (rate_cnt <= 4) {
+		int i, g_rate = 0;
 
-		for( i = 0; i < rate_cnt; i++ )
-		{
-			if ( ( ( *( p + 2 + i ) & 0xff ) != 0x02 ) &&
-				( ( *( p + 2 + i ) & 0xff ) != 0x04 ) &&
-				( ( *( p + 2 + i ) & 0xff ) != 0x0B ) &&
-				( ( *( p + 2 + i ) & 0xff ) != 0x16 ) )
-			{
+		for (i = 0; i < rate_cnt; i++) {
+			if (((*(p + 2 + i) & 0xff) != 0x02) &&
+			    ((*(p + 2 + i) & 0xff) != 0x04) &&
+			    ((*(p + 2 + i) & 0xff) != 0x0B) &&
+			    ((*(p + 2 + i) & 0xff) != 0x16))
 				g_rate = 1;
-			}
 		}
 
-		if ( g_rate == 0 )
-		{
-			//	There is no OFDM rate included in SupportedRates IE of this probe request frame
-			//	The driver should response this probe request.
+		if (g_rate == 0) {
+			/*	There is no OFDM rate included in SupportedRates IE of this probe request frame */
+			/*	The driver should response this probe request. */
 			return ret;
 		}
-	}
-	else
-	{
-		//	rate_cnt > 4 means the SupportRates IE contains the OFDM rate because the count of CCK rates are 4.
-		//	We should proceed the following check for this probe request.
+	} else {
+		/*	rate_cnt > 4 means the SupportRates IE contains the OFDM rate because the count of CCK rates are 4. */
+		/*	We should proceed the following check for this probe request. */
 	}
 
-	//	Added comments by Albert 20100906
-	//	There are several items we should check here.
-	//	1. This probe request frame must contain the P2P IE. (Done)
-	//	2. This probe request frame must contain the wildcard SSID. (Done)
-	//	3. Wildcard BSSID. (Todo)
-	//	4. Destination Address. ( Done in mgt_dispatcher function )
-	//	5. Requested Device Type in WSC IE. (Todo)
-	//	6. Device ID attribute in P2P IE. (Todo)
+	/*	Added comments by Albert 20100906 */
+	/*	There are several items we should check here. */
+	/*	1. This probe request frame must contain the P2P IE. (Done) */
+	/*	2. This probe request frame must contain the wildcard SSID. (Done) */
+	/*	3. Wildcard BSSID. (Todo) */
+	/*	4. Destination Address. ( Done in mgt_dispatcher function ) */
+	/*	5. Requested Device Type in WSC IE. (Todo) */
+	/*	6. Device ID attribute in P2P IE. (Todo) */
 
 	p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _SSID_IE_, (int *)&ssid_len,
-			len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);	
+		       len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
 
-	ssid_len &= 0xff;	//	Just last 1 byte is valid for ssid len of the probe request
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	{
-		if((p2pie=rtw_get_p2p_ie( pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_ , len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_ , NULL, &p2pielen)))
-		{
-			if ( (p != NULL) && _rtw_memcmp( ( void * ) ( p+2 ), ( void * ) pwdinfo->p2p_wildcard_ssid , 7 ))
-			{
-				//todo:
-				//Check Requested Device Type attributes in WSC IE.
-				//Check Device ID attribute in P2P IE
+	ssid_len &= 0xff;	/*	Just last 1 byte is valid for ssid len of the probe request */
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		p2pie = rtw_get_p2p_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_ , len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_ , NULL, &p2pielen);
+		if (p2pie) {
+			if ((p != NULL) && _rtw_memcmp((void *)(p + 2), (void *) pwdinfo->p2p_wildcard_ssid , 7)) {
+				/* todo: */
+				/* Check Requested Device Type attributes in WSC IE. */
+				/* Check Device ID attribute in P2P IE */
 
-				ret = _TRUE;			
-			}
-			else if ( (p != NULL) && ( ssid_len == 0 ) )
-			{
 				ret = _TRUE;
-			}
-		}
-		else
-		{
-			//non -p2p device
+			} else if ((p != NULL) && (ssid_len == 0))
+				ret = _TRUE;
+		} else {
+			/* non -p2p device */
 		}
-		
-	}	
 
-	
+	}
+
+
 	return ret;
-	
+
 }
 
 u32 process_assoc_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len, struct sta_info *psta)
 {
 	u8 status_code = P2P_STATUS_SUCCESS;
-	u8 *pbuf, *pattr_content=NULL;
+	u8 *pbuf, *pattr_content = NULL;
 	u32 attr_contentlen = 0;
-	u16 cap_attr=0;
-	unsigned short	frame_type, ie_offset=0;
-	u8 * ies;
+	u16 cap_attr = 0;
+	unsigned short	frame_type, ie_offset = 0;
+	u8 *ies;
 	u32 ies_len;
-	u8 * p2p_ie;
+	u8 *p2p_ie;
 	u32	p2p_ielen = 0;
 
-	if(!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
+	if (!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
 		return P2P_STATUS_FAIL_REQUEST_UNABLE;
 
-	frame_type = GetFrameSubType(pframe);
+	frame_type = get_frame_sub_type(pframe);
 	if (frame_type == WIFI_ASSOCREQ)
-	{
 		ie_offset = _ASOCREQ_IE_OFFSET_;
-	}	
-	else // WIFI_REASSOCREQ
-	{
+	else /* WIFI_REASSOCREQ */
 		ie_offset = _REASOCREQ_IE_OFFSET_;
-	}
-	
+
 	ies = pframe + WLAN_HDR_A3_LEN + ie_offset;
 	ies_len = len - WLAN_HDR_A3_LEN - ie_offset;
 
 	p2p_ie = rtw_get_p2p_ie(ies , ies_len , NULL, &p2p_ielen);
 
-	if ( !p2p_ie )
-	{
-		DBG_8192C( "[%s] P2P IE not Found!!\n", __FUNCTION__ );
+	if (!p2p_ie) {
+		RTW_INFO("[%s] P2P IE not Found!!\n", __FUNCTION__);
 		status_code =  P2P_STATUS_FAIL_INVALID_PARAM;
-	}
-	else
-	{
-		DBG_8192C( "[%s] P2P IE Found!!\n", __FUNCTION__ );
-	}
-	
-	while ( p2p_ie )
-	{
-		//Check P2P Capability ATTR
-		if( rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8*)&cap_attr, (uint*) &attr_contentlen) )
-		{
-			DBG_8192C( "[%s] Got P2P Capability Attr!!\n", __FUNCTION__ );
+	} else
+		RTW_INFO("[%s] P2P IE Found!!\n", __FUNCTION__);
+
+	while (p2p_ie) {
+		/* Check P2P Capability ATTR */
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *) &attr_contentlen)) {
+			RTW_INFO("[%s] Got P2P Capability Attr!!\n", __FUNCTION__);
 			cap_attr = le16_to_cpu(cap_attr);
-			psta->dev_cap = cap_attr&0xff;
+			psta->dev_cap = cap_attr & 0xff;
 		}
 
-		//Check Extended Listen Timing ATTR
-	
+		/* Check Extended Listen Timing ATTR */
 
-		//Check P2P Device Info ATTR
-		if(rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO, NULL, (uint*)&attr_contentlen))
-		{
-			DBG_8192C( "[%s] Got P2P DEVICE INFO Attr!!\n", __FUNCTION__ );		
+
+		/* Check P2P Device Info ATTR */
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO, NULL, (uint *)&attr_contentlen)) {
+			RTW_INFO("[%s] Got P2P DEVICE INFO Attr!!\n", __FUNCTION__);
 			pattr_content = pbuf = rtw_zmalloc(attr_contentlen);
-			if(pattr_content)
-			{
+			if (pattr_content) {
 				u8 num_of_secdev_type;
 				u16 dev_name_len;
-			
-		
-				rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO , pattr_content, (uint*)&attr_contentlen);
 
-				_rtw_memcpy(psta->dev_addr, 	pattr_content, ETH_ALEN);//P2P Device Address
+
+				rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO , pattr_content, (uint *)&attr_contentlen);
+
+				_rtw_memcpy(psta->dev_addr, 	pattr_content, ETH_ALEN);/* P2P Device Address */
 
 				pattr_content += ETH_ALEN;
 
-				_rtw_memcpy(&psta->config_methods, pattr_content, 2);//Config Methods
+				_rtw_memcpy(&psta->config_methods, pattr_content, 2);/* Config Methods */
 				psta->config_methods = be16_to_cpu(psta->config_methods);
 
 				pattr_content += 2;
@@ -2515,33 +2387,29 @@ u32 process_assoc_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint l
 				num_of_secdev_type = *pattr_content;
 				pattr_content += 1;
 
-				if(num_of_secdev_type==0)
-				{
+				if (num_of_secdev_type == 0)
 					psta->num_of_secdev_type = 0;
-				}
-				else
-				{
+				else {
 					u32 len;
 
 					psta->num_of_secdev_type = num_of_secdev_type;
 
-					len = (sizeof(psta->secdev_types_list)<(num_of_secdev_type*8)) ? (sizeof(psta->secdev_types_list)) : (num_of_secdev_type*8);
+					len = (sizeof(psta->secdev_types_list) < (num_of_secdev_type * 8)) ? (sizeof(psta->secdev_types_list)) : (num_of_secdev_type * 8);
 
 					_rtw_memcpy(psta->secdev_types_list, pattr_content, len);
-	
-					pattr_content += (num_of_secdev_type*8);
+
+					pattr_content += (num_of_secdev_type * 8);
 				}
 
 
-				//dev_name_len = attr_contentlen - ETH_ALEN - 2 - 8 - 1 - (num_of_secdev_type*8);
-				psta->dev_name_len=0;
-				if(WPS_ATTR_DEVICE_NAME == be16_to_cpu(*(u16*)pattr_content))
-				{				
-					dev_name_len = be16_to_cpu(*(u16*)(pattr_content+2));
+				/* dev_name_len = attr_contentlen - ETH_ALEN - 2 - 8 - 1 - (num_of_secdev_type*8); */
+				psta->dev_name_len = 0;
+				if (WPS_ATTR_DEVICE_NAME == be16_to_cpu(*(u16 *)pattr_content)) {
+					dev_name_len = be16_to_cpu(*(u16 *)(pattr_content + 2));
 
-					psta->dev_name_len = (sizeof(psta->dev_name)<dev_name_len) ? sizeof(psta->dev_name):dev_name_len;
+					psta->dev_name_len = (sizeof(psta->dev_name) < dev_name_len) ? sizeof(psta->dev_name) : dev_name_len;
 
-					_rtw_memcpy(psta->dev_name, pattr_content+4, psta->dev_name_len);
+					_rtw_memcpy(psta->dev_name, pattr_content + 4, psta->dev_name_len);
 				}
 
 				rtw_mfree(pbuf, attr_contentlen);
@@ -2550,9 +2418,9 @@ u32 process_assoc_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint l
 
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
-		
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
+
 	}
 
 	return status_code;
@@ -2567,85 +2435,71 @@ u32 process_p2p_devdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint le
 	_adapter *padapter = pwdinfo->padapter;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	u8 *p2p_ie;
-	u32	p2p_ielen = 0;	
-	
-	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+	u32	p2p_ielen = 0;
+
+	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
 
 	dialogToken = frame_body[7];
 	status = P2P_STATUS_FAIL_UNKNOWN_P2PGROUP;
-		
-	if ( (p2p_ie=rtw_get_p2p_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen)) )
-	{
-		u8 groupid[ 38 ] = { 0x00 };
-		u8 dev_addr[ETH_ALEN] = { 0x00 };		
+
+	p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
+	if (p2p_ie) {
+		u8 groupid[38] = { 0x00 };
+		u8 dev_addr[ETH_ALEN] = { 0x00 };
 		u32	attr_contentlen = 0;
 
-		if(rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen))
-		{
-			if(_rtw_memcmp(pwdinfo->device_addr, groupid, ETH_ALEN) && 
-				_rtw_memcmp(pwdinfo->p2p_group_ssid, groupid+ETH_ALEN, pwdinfo->p2p_group_ssid_len))
-			{
-				attr_contentlen=0;
-				if(rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_ID, dev_addr, &attr_contentlen))
-				{
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen)) {
+			if (_rtw_memcmp(pwdinfo->device_addr, groupid, ETH_ALEN) &&
+			    _rtw_memcmp(pwdinfo->p2p_group_ssid, groupid + ETH_ALEN, pwdinfo->p2p_group_ssid_len)) {
+				attr_contentlen = 0;
+				if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_ID, dev_addr, &attr_contentlen)) {
 					_irqL irqL;
-					_list	*phead, *plist;					
+					_list	*phead, *plist;
 
 					_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 					phead = &pstapriv->asoc_list;
 					plist = get_next(phead);
 
-					//look up sta asoc_queue
-					while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)	
-					{		
+					/* look up sta asoc_queue */
+					while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 						psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		
+
 						plist = get_next(plist);
 
-						if(psta->is_p2p_device && (psta->dev_cap&P2P_DEVCAP_CLIENT_DISCOVERABILITY) &&
-							_rtw_memcmp(psta->dev_addr, dev_addr, ETH_ALEN))
-						{
+						if (psta->is_p2p_device && (psta->dev_cap & P2P_DEVCAP_CLIENT_DISCOVERABILITY) &&
+						    _rtw_memcmp(psta->dev_addr, dev_addr, ETH_ALEN)) {
+
+							/* _exit_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
+							/* issue GO Discoverability Request */
+							issue_group_disc_req(pwdinfo, psta->cmn.mac_addr);
+							/* _enter_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
 
-							//_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-							//issue GO Discoverability Request
-							issue_group_disc_req(pwdinfo, psta->hwaddr);
-							//_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-							
 							status = P2P_STATUS_SUCCESS;
-							
+
 							break;
-						}
-						else
-						{
+						} else
 							status = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
-						}
-		
-					}				
+
+					}
 					_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-					
-				}
-				else
-				{
+
+				} else
 					status = P2P_STATUS_FAIL_INVALID_PARAM;
-				}
 
-			}
-			else
-			{
+			} else
 				status = P2P_STATUS_FAIL_INVALID_PARAM;
-			}
-			
-		}	
-		
+
+		}
+
 	}
 
-	
-	//issue Device Discoverability Response
-	issue_p2p_devdisc_resp(pwdinfo, GetAddr2Ptr(pframe), status, dialogToken);
-	
-	
-	return (status==P2P_STATUS_SUCCESS) ? _TRUE:_FALSE;
-	
+
+	/* issue Device Discoverability Response */
+	issue_p2p_devdisc_resp(pwdinfo, get_addr2_ptr(pframe), status, dialogToken);
+
+
+	return (status == P2P_STATUS_SUCCESS) ? _TRUE : _FALSE;
+
 }
 
 u32 process_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
@@ -2653,52 +2507,46 @@ u32 process_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint l
 	return _TRUE;
 }
 
-u8 process_p2p_provdisc_req(struct wifidirect_info *pwdinfo,  u8 *pframe, uint len )
+u8 process_p2p_provdisc_req(struct wifidirect_info *pwdinfo,  u8 *pframe, uint len)
 {
 	u8 *frame_body;
 	u8 *wpsie;
 	uint	wps_ielen = 0, attr_contentlen = 0;
 	u16	uconfig_method = 0;
-	
+
 
 	frame_body = (pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
 
-	if ( (wpsie=rtw_get_wps_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &wps_ielen)) )
-	{
-		if ( rtw_get_wps_attr_content( wpsie, wps_ielen, WPS_ATTR_CONF_METHOD , ( u8* ) &uconfig_method, &attr_contentlen) )
-		{
-			uconfig_method = be16_to_cpu( uconfig_method );
-			switch( uconfig_method )
-			{
-				case WPS_CM_DISPLYA:
-				{
-					_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3 );
-					break;
-				}
-				case WPS_CM_LABEL:
-				{
-					_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "lab", 3 );
-					break;
-				}
-				case WPS_CM_PUSH_BUTTON:
-				{
-					_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3 );
-					break;
-				}
-				case WPS_CM_KEYPAD:
-				{
-					_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3 );
-					break;
-				}
+	wpsie = rtw_get_wps_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &wps_ielen);
+	if (wpsie) {
+		if (rtw_get_wps_attr_content(wpsie, wps_ielen, WPS_ATTR_CONF_METHOD , (u8 *) &uconfig_method, &attr_contentlen)) {
+			uconfig_method = be16_to_cpu(uconfig_method);
+			switch (uconfig_method) {
+			case WPS_CM_DISPLYA: {
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3);
+				break;
+			}
+			case WPS_CM_LABEL: {
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "lab", 3);
+				break;
+			}
+			case WPS_CM_PUSH_BUTTON: {
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3);
+				break;
+			}
+			case WPS_CM_KEYPAD: {
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3);
+				break;
+			}
 			}
-			issue_p2p_provision_resp( pwdinfo, GetAddr2Ptr(pframe), frame_body, uconfig_method);
+			issue_p2p_provision_resp(pwdinfo, get_addr2_ptr(pframe), frame_body, uconfig_method);
 		}
 	}
-	DBG_871X( "[%s] config method = %s\n", __FUNCTION__, pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req );
+	RTW_INFO("[%s] config method = %s\n", __FUNCTION__, pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req);
 	return _TRUE;
-	
+
 }
-	
+
 u8 process_p2p_provdisc_resp(struct wifidirect_info *pwdinfo,  u8 *pframe)
 {
 
@@ -2713,15 +2561,12 @@ u8 rtw_p2p_get_peer_ch_list(struct wifidirect_info *pwdinfo, u8 *ch_content, u8
 	ch_content += 3;
 	ch_cnt -= 3;
 
-	while( ch_cnt > 0)
-	{
+	while (ch_cnt > 0) {
 		ch_content += 1;
 		ch_cnt -= 1;
 		temp = *ch_content;
-		for( i = 0 ; i < temp ; i++, j++ )
-		{
-			peer_ch_list[j] = *( ch_content + 1 + i );
-		}
+		for (i = 0 ; i < temp ; i++, j++)
+			peer_ch_list[j] = *(ch_content + 1 + i);
 		ch_content += (temp + 1);
 		ch_cnt -= (temp + 1);
 		ch_no += temp ;
@@ -2730,33 +2575,16 @@ u8 rtw_p2p_get_peer_ch_list(struct wifidirect_info *pwdinfo, u8 *ch_content, u8
 	return ch_no;
 }
 
-u8 rtw_p2p_check_peer_oper_ch(struct mlme_ext_priv *pmlmeext, u8 ch)
-{
-	u8 i = 0;
-
-	for( i = 0; i < pmlmeext->max_chan_nums; i++ )
-	{
-		if ( pmlmeext->channel_set[ i ].ChannelNum == ch )
-		{
-			return _SUCCESS;
-		}
-	}
-
-	return _FAIL;
-}
-
-u8 rtw_p2p_ch_inclusion(struct mlme_ext_priv *pmlmeext, u8 *peer_ch_list, u8 peer_ch_num, u8 *ch_list_inclusioned)
+u8 rtw_p2p_ch_inclusion(_adapter *adapter, u8 *peer_ch_list, u8 peer_ch_num, u8 *ch_list_inclusioned)
 {
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	int	i = 0, j = 0, temp = 0;
 	u8 ch_no = 0;
 
-	for( i = 0; i < peer_ch_num; i++ )
-	{
-		for( j = temp; j < pmlmeext->max_chan_nums; j++ )
-		{
-			if( *( peer_ch_list + i ) == pmlmeext->channel_set[ j ].ChannelNum )
-			{
-				ch_list_inclusioned[ ch_no++ ] = *( peer_ch_list + i );
+	for (i = 0; i < peer_ch_num; i++) {
+		for (j = temp; j < rfctl->max_chan_nums; j++) {
+			if (*(peer_ch_list + i) == rfctl->channel_set[j].ChannelNum) {
+				ch_list_inclusioned[ch_no++] = *(peer_ch_list + i);
 				temp = j;
 				break;
 			}
@@ -2766,12 +2594,12 @@ u8 rtw_p2p_ch_inclusion(struct mlme_ext_priv *pmlmeext, u8 *peer_ch_list, u8 pee
 	return ch_no;
 }
 
-u8 process_p2p_group_negotation_req( struct wifidirect_info *pwdinfo, u8 *pframe, uint len )
+u8 process_p2p_group_negotation_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
 {
 	_adapter *padapter = pwdinfo->padapter;
 	u8	result = P2P_STATUS_SUCCESS;
 	u32	p2p_ielen = 0, wps_ielen = 0;
-	u8 * ies;
+	u8 *ies;
 	u32 ies_len;
 	u8 *p2p_ie;
 	u8 *wpsie;
@@ -2780,61 +2608,43 @@ u8 process_p2p_group_negotation_req( struct wifidirect_info *pwdinfo, u8 *pframe
 #ifdef CONFIG_WFD
 #ifdef CONFIG_TDLS
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-#endif // CONFIG_TDLS	
-#endif // CONFIG_WFD
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = pwdinfo->padapter->pbuddy_adapter;
-	struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-	struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif
-
-	if ( (wpsie=rtw_get_wps_ie( pframe + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &wps_ielen)) )
-	{
-		//	Commented by Kurt 20120113
-		//	If some device wants to do p2p handshake without sending prov_disc_req
-		//	We have to get peer_req_cm from here.
-		if(_rtw_memcmp( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "000", 3) )
-		{
-			rtw_get_wps_attr_content( wpsie, wps_ielen, WPS_ATTR_DEVICE_PWID, (u8*) &wps_devicepassword_id, &wps_devicepassword_id_len);
-			wps_devicepassword_id = be16_to_cpu( wps_devicepassword_id );
-
-			if ( wps_devicepassword_id == WPS_DPID_USER_SPEC )
-			{
-				_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3 );
-			}
-			else if ( wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC )
-			{
-				_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3 );	
-			}
+#endif /* CONFIG_TDLS	 */
+#endif /* CONFIG_WFD */
+	wpsie = rtw_get_wps_ie(pframe + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &wps_ielen);
+	if (wpsie) {
+		/*	Commented by Kurt 20120113 */
+		/*	If some device wants to do p2p handshake without sending prov_disc_req */
+		/*	We have to get peer_req_cm from here. */
+		if (_rtw_memcmp(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "000", 3)) {
+			rtw_get_wps_attr_content(wpsie, wps_ielen, WPS_ATTR_DEVICE_PWID, (u8 *) &wps_devicepassword_id, &wps_devicepassword_id_len);
+			wps_devicepassword_id = be16_to_cpu(wps_devicepassword_id);
+
+			if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3);
+			else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3);
 			else
-			{
-				_rtw_memcpy( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3 );	
-			}
+				_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3);
 		}
-	}
-	else
-	{
-		DBG_871X( "[%s] WPS IE not Found!!\n", __FUNCTION__ );
+	} else {
+		RTW_INFO("[%s] WPS IE not Found!!\n", __FUNCTION__);
 		result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
-		return( result );
+		return result ;
 	}
 
 	ies = pframe + _PUBLIC_ACTION_IE_OFFSET_;
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
-					
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
 
-	if ( !p2p_ie )
-	{
-		DBG_871X( "[%s] P2P IE not Found!!\n", __FUNCTION__ );
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
+
+	if (!p2p_ie) {
+		RTW_INFO("[%s] P2P IE not Found!!\n", __FUNCTION__);
 		result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 	}
-	
-	while ( p2p_ie )
-	{
+
+	while (p2p_ie) {
 		u8	attr_content = 0x00;
 		u32	attr_contentlen = 0;
 		u8	ch_content[100] = { 0x00 };
@@ -2848,125 +2658,95 @@ u8 process_p2p_group_negotation_req( struct wifidirect_info *pwdinfo, u8 *pframe
 
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_ING);
 
-		//Check P2P Capability ATTR
-		if(rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8*)&cap_attr, (uint*)&attr_contentlen) )
-		{
+		/* Check P2P Capability ATTR */
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *)&attr_contentlen)) {
 			cap_attr = le16_to_cpu(cap_attr);
-	
+
 #if defined(CONFIG_WFD) && defined(CONFIG_TDLS)
-			if(!(cap_attr & P2P_GRPCAP_INTRABSS) )
+			if (!(cap_attr & P2P_GRPCAP_INTRABSS))
 				ptdlsinfo->ap_prohibited = _TRUE;
-#endif //defined(CONFIG_WFD) && defined(CONFIG_TDLS)
+#endif /* defined(CONFIG_WFD) && defined(CONFIG_TDLS) */
 		}
 
-		if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT , &attr_content, &attr_contentlen) )
-		{
-			DBG_871X( "[%s] GO Intent = %d, tie = %d\n", __FUNCTION__, attr_content >> 1, attr_content & 0x01 );
-			pwdinfo->peer_intent = attr_content;	//	include both intent and tie breaker values.
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT , &attr_content, &attr_contentlen)) {
+			RTW_INFO("[%s] GO Intent = %d, tie = %d\n", __FUNCTION__, attr_content >> 1, attr_content & 0x01);
+			pwdinfo->peer_intent = attr_content;	/*	include both intent and tie breaker values. */
 
-			if ( pwdinfo->intent == ( pwdinfo->peer_intent >> 1 ) )
-			{
-				//	Try to match the tie breaker value
-				if ( pwdinfo->intent == P2P_MAX_INTENT )
-				{
+			if (pwdinfo->intent == (pwdinfo->peer_intent >> 1)) {
+				/*	Try to match the tie breaker value */
+				if (pwdinfo->intent == P2P_MAX_INTENT) {
 					rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
 					result = P2P_STATUS_FAIL_BOTH_GOINTENT_15;
-				}
-				else
-				{
-					if ( attr_content & 0x01 )
-					{
+				} else {
+					if (attr_content & 0x01)
 						rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
-					}
 					else
-					{
 						rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-					}
-				}							
-			}
-			else if ( pwdinfo->intent > ( pwdinfo->peer_intent >> 1 ) )
-			{
+				}
+			} else if (pwdinfo->intent > (pwdinfo->peer_intent >> 1))
 				rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-			}
 			else
-			{
 				rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
-			}
 
-			if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-			{
-				//	Store the group id information.
-				_rtw_memcpy( pwdinfo->groupid_info.go_device_addr, pwdinfo->device_addr, ETH_ALEN );
-				_rtw_memcpy( pwdinfo->groupid_info.ssid, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen );		
+			if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+				/*	Store the group id information. */
+				_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, pwdinfo->device_addr, ETH_ALEN);
+				_rtw_memcpy(pwdinfo->groupid_info.ssid, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
 			}
 		}
 
 		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, (u8 *)listen_ch_attr, (uint *) &attr_contentlen) && attr_contentlen == 5)
 			pwdinfo->nego_req_info.peer_ch = listen_ch_attr[4];
-		
-		DBG_871X(FUNC_ADPT_FMT" listen channel :%u\n", FUNC_ADPT_ARG(padapter), pwdinfo->nego_req_info.peer_ch);
+
+		RTW_INFO(FUNC_ADPT_FMT" listen channel :%u\n", FUNC_ADPT_ARG(padapter), pwdinfo->nego_req_info.peer_ch);
 
 		attr_contentlen = 0;
-		if ( rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_INTENTED_IF_ADDR, pwdinfo->p2p_peer_interface_addr, &attr_contentlen ) )
-		{
-			if ( attr_contentlen != ETH_ALEN )
-			{
-				_rtw_memset( pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN );
-			}
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, pwdinfo->p2p_peer_interface_addr, &attr_contentlen)) {
+			if (attr_contentlen != ETH_ALEN)
+				_rtw_memset(pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN);
 		}
 
-		if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, ch_content, &ch_cnt) )
-		{
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, ch_content, &ch_cnt)) {
 			peer_ch_num = rtw_p2p_get_peer_ch_list(pwdinfo, ch_content, ch_cnt, peer_ch_list);
-			ch_num_inclusioned = rtw_p2p_ch_inclusion(&padapter->mlmeextpriv, peer_ch_list, peer_ch_num, ch_list_inclusioned);
+			ch_num_inclusioned = rtw_p2p_ch_inclusion(padapter, peer_ch_list, peer_ch_num, ch_list_inclusioned);
 
-			if( ch_num_inclusioned == 0)
-			{
-				DBG_871X( "[%s] No common channel in channel list!\n", __FUNCTION__ );
+			if (ch_num_inclusioned == 0) {
+				RTW_INFO("[%s] No common channel in channel list!\n", __FUNCTION__);
 				result = P2P_STATUS_FAIL_NO_COMMON_CH;
 				rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 				break;
 			}
 
-			if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-			{
-				if ( !rtw_p2p_is_channel_list_ok( pwdinfo->operating_channel, 
-												ch_list_inclusioned, ch_num_inclusioned) )
-				{
+			if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+				if (!rtw_p2p_is_channel_list_ok(pwdinfo->operating_channel,
+					ch_list_inclusioned, ch_num_inclusioned)) {
 #ifdef CONFIG_CONCURRENT_MODE
-					if (check_buddy_fwstate(padapter, _FW_LINKED)
-						&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-					{
-						DBG_871X( "[%s] desired channel NOT Found!\n", __FUNCTION__ );
+					if (rtw_mi_check_status(padapter, MI_LINKED)
+					    && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+						RTW_INFO("[%s] desired channel NOT Found!\n", __FUNCTION__);
 						result = P2P_STATUS_FAIL_NO_COMMON_CH;
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 						break;
-					}
-					else
-#endif //CONFIG_CONCURRENT_MODE
+					} else
+#endif /* CONFIG_CONCURRENT_MODE */
 					{
 						u8 operatingch_info[5] = { 0x00 }, peer_operating_ch = 0;
 						attr_contentlen = 0;
 
-						if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen) )
-						{		
+						if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen))
 							peer_operating_ch = operatingch_info[4];
-						}
 
-						if ( rtw_p2p_is_channel_list_ok( peer_operating_ch, 
-														ch_list_inclusioned, ch_num_inclusioned) )
-						{
+						if (rtw_p2p_is_channel_list_ok(peer_operating_ch,
+							ch_list_inclusioned, ch_num_inclusioned)) {
 							/**
 							 *	Change our operating channel as peer's for compatibility.
 							 */
 							pwdinfo->operating_channel = peer_operating_ch;
-							DBG_871X( "[%s] Change op ch to %02x as peer's\n", __FUNCTION__, pwdinfo->operating_channel);
-						}
-						else
-						{
-							// Take first channel of ch_list_inclusioned as operating channel
+							RTW_INFO("[%s] Change op ch to %02x as peer's\n", __FUNCTION__, pwdinfo->operating_channel);
+						} else {
+							/* Take first channel of ch_list_inclusioned as operating channel */
 							pwdinfo->operating_channel = ch_list_inclusioned[0];
-							DBG_871X( "[%s] Change op ch to %02x\n", __FUNCTION__, pwdinfo->operating_channel);
+							RTW_INFO("[%s] Change op ch to %02x\n", __FUNCTION__, pwdinfo->operating_channel);
 						}
 					}
 
@@ -2974,8 +2754,8 @@ u8 process_p2p_group_negotation_req( struct wifidirect_info *pwdinfo, u8 *pframe
 			}
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 
 	if (pwdinfo->ui_got_wps_info == P2P_NO_WPSINFO) {
@@ -2984,715 +2764,774 @@ u8 process_p2p_group_negotation_req( struct wifidirect_info *pwdinfo, u8 *pframe
 		return result;
 	}
 
-	#ifdef CONFIG_WFD
+#ifdef CONFIG_WFD
 	rtw_process_wfd_ies(padapter, pframe + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, __func__);
-	#endif
+#endif
 
-	return( result );
+	return result ;
 }
 
-u8 process_p2p_group_negotation_resp( struct wifidirect_info *pwdinfo, u8 *pframe, uint len )
+u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
 {
 	_adapter *padapter = pwdinfo->padapter;
 	u8	result = P2P_STATUS_SUCCESS;
 	u32	p2p_ielen, wps_ielen;
-	u8 * ies;
+	u8 *ies;
 	u32 ies_len;
-	u8 * p2p_ie;
+	u8 *p2p_ie;
 #ifdef CONFIG_WFD
 #ifdef CONFIG_TDLS
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-#endif // CONFIG_TDLS	
-#endif // CONFIG_WFD
+#endif /* CONFIG_TDLS	 */
+#endif /* CONFIG_WFD */
 
 	ies = pframe + _PUBLIC_ACTION_IE_OFFSET_;
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
 
-	//	Be able to know which one is the P2P GO and which one is P2P client.
-					
-	if ( rtw_get_wps_ie( ies, ies_len, NULL, &wps_ielen) )
-	{
+	/*	Be able to know which one is the P2P GO and which one is P2P client. */
 
-	}
-	else
-	{
-		DBG_871X( "[%s] WPS IE not Found!!\n", __FUNCTION__ );
+	if (rtw_get_wps_ie(ies, ies_len, NULL, &wps_ielen)) {
+
+	} else {
+		RTW_INFO("[%s] WPS IE not Found!!\n", __FUNCTION__);
 		result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 	}
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
-	if ( !p2p_ie )
-	{
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
+	if (!p2p_ie) {
 		rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 		result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
-	}
-	else
-	{
+	} else {
 
 		u8	attr_content = 0x00;
 		u32	attr_contentlen = 0;
 		u8	operatingch_info[5] = { 0x00 };
 		uint	ch_cnt = 0;
 		u8	ch_content[100] = { 0x00 };
-		u8	groupid[ 38 ];
+		u8	groupid[38];
 		u16	cap_attr;
 		u8	peer_ch_list[100] = { 0x00 };
 		u8	peer_ch_num = 0;
 		u8	ch_list_inclusioned[100] = { 0x00 };
 		u8	ch_num_inclusioned = 0;
 
-		while ( p2p_ie )	//	Found the P2P IE.
-		{
+		while (p2p_ie) {	/*	Found the P2P IE. */
 
-			//Check P2P Capability ATTR
-			if(rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8*)&cap_attr, (uint*)&attr_contentlen) )
-			{
+			/* Check P2P Capability ATTR */
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *)&attr_contentlen)) {
 				cap_attr = le16_to_cpu(cap_attr);
 #ifdef CONFIG_TDLS
-				if(!(cap_attr & P2P_GRPCAP_INTRABSS) )
+				if (!(cap_attr & P2P_GRPCAP_INTRABSS))
 					ptdlsinfo->ap_prohibited = _TRUE;
-#endif // CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 			}
 
 			rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, &attr_content, &attr_contentlen);
-			if ( attr_contentlen == 1 )
-			{			
-				DBG_871X( "[%s] Status = %d\n", __FUNCTION__, attr_content );
-				if ( attr_content == P2P_STATUS_SUCCESS )
-				{
-					//	Do nothing.
-				}
-				else
-				{
-					if ( P2P_STATUS_FAIL_INFO_UNAVAILABLE == attr_content ) {
+			if (attr_contentlen == 1) {
+				RTW_INFO("[%s] Status = %d\n", __FUNCTION__, attr_content);
+				if (attr_content == P2P_STATUS_SUCCESS) {
+					/*	Do nothing. */
+				} else {
+					if (P2P_STATUS_FAIL_INFO_UNAVAILABLE == attr_content)
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INFOR_NOREADY);
-					} else {
+					else
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
-					}
 					rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
 					result = attr_content;
 					break;
 				}
 			}
 
-			//	Try to get the peer's interface address
+			/*	Try to get the peer's interface address */
 			attr_contentlen = 0;
-			if ( rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_INTENTED_IF_ADDR, pwdinfo->p2p_peer_interface_addr, &attr_contentlen ) )
-			{
-				if ( attr_contentlen != ETH_ALEN )
-				{
-					_rtw_memset( pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN );
-				}
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, pwdinfo->p2p_peer_interface_addr, &attr_contentlen)) {
+				if (attr_contentlen != ETH_ALEN)
+					_rtw_memset(pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN);
 			}
-			
-			//	Try to get the peer's intent and tie breaker value.
+
+			/*	Try to get the peer's intent and tie breaker value. */
 			attr_content = 0x00;
 			attr_contentlen = 0;
-			if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT , &attr_content, &attr_contentlen) )
-			{
-				DBG_871X( "[%s] GO Intent = %d, tie = %d\n", __FUNCTION__, attr_content >> 1, attr_content & 0x01 );
-				pwdinfo->peer_intent = attr_content;	//	include both intent and tie breaker values.
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT , &attr_content, &attr_contentlen)) {
+				RTW_INFO("[%s] GO Intent = %d, tie = %d\n", __FUNCTION__, attr_content >> 1, attr_content & 0x01);
+				pwdinfo->peer_intent = attr_content;	/*	include both intent and tie breaker values. */
 
-				if ( pwdinfo->intent == ( pwdinfo->peer_intent >> 1 ) )
-				{
-					//	Try to match the tie breaker value
-					if ( pwdinfo->intent == P2P_MAX_INTENT )
-					{
+				if (pwdinfo->intent == (pwdinfo->peer_intent >> 1)) {
+					/*	Try to match the tie breaker value */
+					if (pwdinfo->intent == P2P_MAX_INTENT) {
 						rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
 						result = P2P_STATUS_FAIL_BOTH_GOINTENT_15;
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
-					}
-					else
-					{
+					} else {
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
 						rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
-						if ( attr_content & 0x01 )
-						{
+						if (attr_content & 0x01)
 							rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
-						}
 						else
-						{
 							rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-						}
-					}							
-				}
-				else if ( pwdinfo->intent > ( pwdinfo->peer_intent >> 1 ) )
-				{
+					}
+				} else if (pwdinfo->intent > (pwdinfo->peer_intent >> 1)) {
 					rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
 					rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
 					rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-				}
-				else
-				{
+				} else {
 					rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
 					rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
 					rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
 				}
 
-				if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-				{
-					//	Store the group id information.
-					_rtw_memcpy( pwdinfo->groupid_info.go_device_addr, pwdinfo->device_addr, ETH_ALEN );
-					_rtw_memcpy( pwdinfo->groupid_info.ssid, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen );
-		
+				if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+					/*	Store the group id information. */
+					_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, pwdinfo->device_addr, ETH_ALEN);
+					_rtw_memcpy(pwdinfo->groupid_info.ssid, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
+
 				}
 			}
-			
-			//	Try to get the operation channel information
-					
+
+			/*	Try to get the operation channel information */
+
 			attr_contentlen = 0;
-			if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen))
-			{
-				DBG_871X( "[%s] Peer's operating channel = %d\n", __FUNCTION__, operatingch_info[4] );
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen)) {
+				RTW_INFO("[%s] Peer's operating channel = %d\n", __FUNCTION__, operatingch_info[4]);
 				pwdinfo->peer_operating_ch = operatingch_info[4];
 			}
-			
-			//	Try to get the channel list information
-			if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, pwdinfo->channel_list_attr, &pwdinfo->channel_list_attr_len ) )
-			{
-				DBG_871X( "[%s] channel list attribute found, len = %d\n", __FUNCTION__,  pwdinfo->channel_list_attr_len );
+
+			/*	Try to get the channel list information */
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, pwdinfo->channel_list_attr, &pwdinfo->channel_list_attr_len)) {
+				RTW_INFO("[%s] channel list attribute found, len = %d\n", __FUNCTION__,  pwdinfo->channel_list_attr_len);
 
 				peer_ch_num = rtw_p2p_get_peer_ch_list(pwdinfo, pwdinfo->channel_list_attr, pwdinfo->channel_list_attr_len, peer_ch_list);
-				ch_num_inclusioned = rtw_p2p_ch_inclusion(&padapter->mlmeextpriv, peer_ch_list, peer_ch_num, ch_list_inclusioned);
+				ch_num_inclusioned = rtw_p2p_ch_inclusion(padapter, peer_ch_list, peer_ch_num, ch_list_inclusioned);
 
-				if( ch_num_inclusioned == 0)
-				{
-					DBG_871X( "[%s] No common channel in channel list!\n", __FUNCTION__ );
+				if (ch_num_inclusioned == 0) {
+					RTW_INFO("[%s] No common channel in channel list!\n", __FUNCTION__);
 					result = P2P_STATUS_FAIL_NO_COMMON_CH;
 					rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 					break;
 				}
 
-				if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-				{
-					if ( !rtw_p2p_is_channel_list_ok( pwdinfo->operating_channel, 
-													ch_list_inclusioned, ch_num_inclusioned) )
-					{
+				if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+					if (!rtw_p2p_is_channel_list_ok(pwdinfo->operating_channel,
+						ch_list_inclusioned, ch_num_inclusioned)) {
 #ifdef CONFIG_CONCURRENT_MODE
-						if (check_buddy_fwstate(padapter, _FW_LINKED)
-							&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-						{
-							DBG_871X( "[%s] desired channel NOT Found!\n", __FUNCTION__ );
+						if (rtw_mi_check_status(padapter, MI_LINKED)
+						    && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+							RTW_INFO("[%s] desired channel NOT Found!\n", __FUNCTION__);
 							result = P2P_STATUS_FAIL_NO_COMMON_CH;
 							rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 							break;
-						}
-						else
-#endif //CONFIG_CONCURRENT_MODE
+						} else
+#endif /* CONFIG_CONCURRENT_MODE */
 						{
 							u8 operatingch_info[5] = { 0x00 }, peer_operating_ch = 0;
 							attr_contentlen = 0;
 
-							if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen) )
-							{		
+							if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen))
 								peer_operating_ch = operatingch_info[4];
-							}
 
-							if ( rtw_p2p_is_channel_list_ok( peer_operating_ch, 
-															ch_list_inclusioned, ch_num_inclusioned) )
-							{
+							if (rtw_p2p_is_channel_list_ok(peer_operating_ch,
+								ch_list_inclusioned, ch_num_inclusioned)) {
 								/**
 								 *	Change our operating channel as peer's for compatibility.
 								 */
 								pwdinfo->operating_channel = peer_operating_ch;
-								DBG_871X( "[%s] Change op ch to %02x as peer's\n", __FUNCTION__, pwdinfo->operating_channel);
-							}
-							else
-							{
-								// Take first channel of ch_list_inclusioned as operating channel
+								RTW_INFO("[%s] Change op ch to %02x as peer's\n", __FUNCTION__, pwdinfo->operating_channel);
+							} else {
+								/* Take first channel of ch_list_inclusioned as operating channel */
 								pwdinfo->operating_channel = ch_list_inclusioned[0];
-								DBG_871X( "[%s] Change op ch to %02x\n", __FUNCTION__, pwdinfo->operating_channel);
+								RTW_INFO("[%s] Change op ch to %02x\n", __FUNCTION__, pwdinfo->operating_channel);
 							}
 						}
 
 					}
 				}
 
-			}
-			else
-			{
-				DBG_871X( "[%s] channel list attribute not found!\n", __FUNCTION__);
-			}
+			} else
+				RTW_INFO("[%s] channel list attribute not found!\n", __FUNCTION__);
 
-			//	Try to get the group id information if peer is GO
+			/*	Try to get the group id information if peer is GO */
 			attr_contentlen = 0;
-			_rtw_memset( groupid, 0x00, 38 );
-			if ( rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen) )
-			{
-				_rtw_memcpy( pwdinfo->groupid_info.go_device_addr, &groupid[0], ETH_ALEN );
-				_rtw_memcpy( pwdinfo->groupid_info.ssid, &groupid[6], attr_contentlen - ETH_ALEN );
+			_rtw_memset(groupid, 0x00, 38);
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen)) {
+				_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, &groupid[0], ETH_ALEN);
+				_rtw_memcpy(pwdinfo->groupid_info.ssid, &groupid[6], attr_contentlen - ETH_ALEN);
 			}
-			
-			//Get the next P2P IE
-			p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+
+			/* Get the next P2P IE */
+			p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 		}
-		
+
 	}
 
-	#ifdef CONFIG_WFD
+#ifdef CONFIG_WFD
 	rtw_process_wfd_ies(padapter, pframe + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, __func__);
-	#endif
+#endif
 
-	return( result );
+	return result ;
 
 }
 
-u8 process_p2p_group_negotation_confirm( struct wifidirect_info *pwdinfo, u8 *pframe, uint len )
+u8 process_p2p_group_negotation_confirm(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
 {
 	_adapter *padapter = pwdinfo->padapter;
-	u8 * ies;
+	u8 *ies;
 	u32 ies_len;
-	u8 * p2p_ie;
+	u8 *p2p_ie;
 	u32	p2p_ielen = 0;
 	u8	result = P2P_STATUS_SUCCESS;
 	ies = pframe + _PUBLIC_ACTION_IE_OFFSET_;
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
-	while ( p2p_ie )	//	Found the P2P IE.
-	{
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
+	while (p2p_ie) {	/*	Found the P2P IE. */
 		u8	attr_content = 0x00, operatingch_info[5] = { 0x00 };
-		u8	groupid[ 38 ] = { 0x00 };
+		u8	groupid[38] = { 0x00 };
 		u32	attr_contentlen = 0;
 
 		pwdinfo->negotiation_dialog_token = 1;
 		rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, &attr_content, &attr_contentlen);
-		if ( attr_contentlen == 1 )
-		{
-			DBG_871X( "[%s] Status = %d\n", __FUNCTION__, attr_content );
+		if (attr_contentlen == 1) {
+			RTW_INFO("[%s] Status = %d\n", __FUNCTION__, attr_content);
 			result = attr_content;
 
-			if ( attr_content == P2P_STATUS_SUCCESS )
-			{
-				u8	bcancelled = 0;
-																
-				_cancel_timer( &pwdinfo->restore_p2p_state_timer, &bcancelled );
+			if (attr_content == P2P_STATUS_SUCCESS) {
 
-				//	Commented by Albert 20100911
-				//	Todo: Need to handle the case which both Intents are the same.
+				_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+
+				/*	Commented by Albert 20100911 */
+				/*	Todo: Need to handle the case which both Intents are the same. */
 				rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
 				rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
-				if ( ( pwdinfo->intent ) > ( pwdinfo->peer_intent >> 1 ) )
-				{
+				if ((pwdinfo->intent) > (pwdinfo->peer_intent >> 1))
 					rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-				}
-				else if ( ( pwdinfo->intent ) < ( pwdinfo->peer_intent >> 1 ) )
-				{
+				else if ((pwdinfo->intent) < (pwdinfo->peer_intent >> 1))
 					rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
-				}
-				else
-				{
-					//	Have to compare the Tie Breaker
-					if ( pwdinfo->peer_intent & 0x01 )
-					{
+				else {
+					/*	Have to compare the Tie Breaker */
+					if (pwdinfo->peer_intent & 0x01)
 						rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
-					}
 					else
-					{
 						rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-					}
-				}								
-				
+				}
+
 #ifdef CONFIG_CONCURRENT_MODE
-				if (check_buddy_fwstate(padapter , _FW_LINKED)
-					&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-				{
-					//	Switch back to the AP channel soon.
-					_set_timer( &pwdinfo->ap_p2p_switch_timer, 100 );
+				if (rtw_mi_check_status(padapter, MI_LINKED)
+				    && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+					/*	Switch back to the AP channel soon. */
+					_set_timer(&pwdinfo->ap_p2p_switch_timer, 100);
 				}
-#endif				
-			}
-			else
-			{
+#endif
+			} else {
 				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
 				rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
 				break;
 			}
 		}
 
-		//	Try to get the group id information
+		/*	Try to get the group id information */
 		attr_contentlen = 0;
-		_rtw_memset( groupid, 0x00, 38 );
-		if ( rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen) )
-		{
-			DBG_871X( "[%s] Ssid = %s, ssidlen = %zu\n", __FUNCTION__, &groupid[ETH_ALEN], strlen(&groupid[ETH_ALEN]) );
-			_rtw_memcpy( pwdinfo->groupid_info.go_device_addr, &groupid[0], ETH_ALEN );
-			_rtw_memcpy( pwdinfo->groupid_info.ssid, &groupid[6], attr_contentlen - ETH_ALEN );			
+		_rtw_memset(groupid, 0x00, 38);
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen)) {
+			RTW_INFO("[%s] Ssid = %s, ssidlen = %zu\n", __FUNCTION__, &groupid[ETH_ALEN], strlen(&groupid[ETH_ALEN]));
+			_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, &groupid[0], ETH_ALEN);
+			_rtw_memcpy(pwdinfo->groupid_info.ssid, &groupid[6], attr_contentlen - ETH_ALEN);
 		}
 
 		attr_contentlen = 0;
-		if ( rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen) )
-		{		
-			DBG_871X( "[%s] Peer's operating channel = %d\n", __FUNCTION__, operatingch_info[4] );
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen)) {
+			RTW_INFO("[%s] Peer's operating channel = %d\n", __FUNCTION__, operatingch_info[4]);
 			pwdinfo->peer_operating_ch = operatingch_info[4];
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
-		
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
+
 	}
 
-	return( result );
+	return result ;
 }
 
 u8 process_p2p_presence_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
 {
-	u8 *frame_body;	
-	u8 dialogToken=0;
+	u8 *frame_body;
+	u8 dialogToken = 0;
 	u8 status = P2P_STATUS_SUCCESS;
-	
+
 	frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
 
 	dialogToken = frame_body[6];
 
-	//todo: check NoA attribute
+	/* todo: check NoA attribute */
 
-	issue_p2p_presence_resp(pwdinfo, GetAddr2Ptr(pframe), status, dialogToken);
+	issue_p2p_presence_resp(pwdinfo, get_addr2_ptr(pframe), status, dialogToken);
 
 	return _TRUE;
 }
 
-void find_phase_handler( _adapter*	padapter )
+void find_phase_handler(_adapter	*padapter)
 {
 	struct wifidirect_info  *pwdinfo = &padapter->wdinfo;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	NDIS_802_11_SSID 	ssid;
+	struct sitesurvey_parm parm;
 	_irqL				irqL;
 	u8					_status = 0;
 
-_func_enter_;
 
-	_rtw_memset((unsigned char*)&ssid, 0, sizeof(NDIS_802_11_SSID));
-	_rtw_memcpy(ssid.Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN );
-	ssid.SsidLength = P2P_WILDCARD_SSID_LEN;
+	rtw_init_sitesurvey_parm(padapter, &parm);
+	_rtw_memcpy(&parm.ssid[0].Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN);
+	parm.ssid[0].SsidLength = P2P_WILDCARD_SSID_LEN;
+	parm.ssid_num = 1;
 
 	rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
-		
+
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
-	_status = rtw_sitesurvey_cmd(padapter, &ssid, 1, NULL, 0);
+	_status = rtw_sitesurvey_cmd(padapter, &parm);
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
 
-_func_exit_;
 }
 
-void p2p_concurrent_handler(  _adapter* padapter );
+void p2p_concurrent_handler(_adapter *padapter);
 
-void restore_p2p_state_handler( _adapter*	padapter )
+void restore_p2p_state_handler(_adapter	*padapter)
 {
 	struct wifidirect_info  *pwdinfo = &padapter->wdinfo;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 
-_func_enter_;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
-	{
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
 		rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-	}
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-	{
-		_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-		struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-		struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;	
-	
-		if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_RSP))
-		{
-			set_channel_bwmode(padapter, pbuddy_mlmeext->cur_channel, pbuddy_mlmeext->cur_ch_offset, pbuddy_mlmeext->cur_bwmode);
-			
-			issue_nulldata(pbuddy_adapter, NULL, 0, 3, 500);
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		u8 union_ch = rtw_mi_get_union_chan(padapter);
+		u8 union_bw = rtw_mi_get_union_bw(padapter);
+		u8 union_offset = rtw_mi_get_union_offset(padapter);
+
+		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_RSP)) {
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_back_opch(padapter);
 		}
 	}
 #endif
 
 	rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-	
-	if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE))
-	{
+
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)) {
 #ifdef CONFIG_CONCURRENT_MODE
-		p2p_concurrent_handler( padapter );
+		p2p_concurrent_handler(padapter);
 #else
-		//	In the P2P client mode, the driver should not switch back to its listen channel
-		//	because this P2P client should stay at the operating channel of P2P GO.
-		set_channel_bwmode( padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+		/*	In the P2P client mode, the driver should not switch back to its listen channel */
+		/*	because this P2P client should stay at the operating channel of P2P GO. */
+		set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 #endif
 	}
-_func_exit_;
 }
 
-void pre_tx_invitereq_handler( _adapter*	padapter )
+void pre_tx_invitereq_handler(_adapter	*padapter)
 {
 	struct wifidirect_info  *pwdinfo = &padapter->wdinfo;
 	u8	val8 = 1;
-_func_enter_;
 
 	set_channel_bwmode(padapter, pwdinfo->invitereq_info.peer_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));	
+	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 	issue_probereq_p2p(padapter, NULL);
-	_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-	
-_func_exit_;
+	_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+
 }
 
-void pre_tx_provdisc_handler( _adapter*	padapter )
+void pre_tx_provdisc_handler(_adapter	*padapter)
 {
 	struct wifidirect_info  *pwdinfo = &padapter->wdinfo;
 	u8	val8 = 1;
-_func_enter_;
 
 	set_channel_bwmode(padapter, pwdinfo->tx_prov_disc_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 	issue_probereq_p2p(padapter, NULL);
-	_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-	
-_func_exit_;
+	_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+
 }
 
-void pre_tx_negoreq_handler( _adapter*	padapter )
+void pre_tx_negoreq_handler(_adapter	*padapter)
 {
 	struct wifidirect_info  *pwdinfo = &padapter->wdinfo;
 	u8	val8 = 1;
-_func_enter_;
 
 	set_channel_bwmode(padapter, pwdinfo->nego_req_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));	
+	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 	issue_probereq_p2p(padapter , NULL);
 	/* WIN Phone only accept unicast probe request when nego back */
 	issue_probereq_p2p(padapter , pwdinfo->nego_req_info.peerDevAddr);
-	_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-	
-_func_exit_;
+	_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+
 }
 
 #ifdef CONFIG_CONCURRENT_MODE
-void p2p_concurrent_handler( _adapter*	padapter )
+void p2p_concurrent_handler(_adapter	*padapter)
 {
 	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);	
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	//_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	//struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-	//struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	//struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
 	u8					val8;
-_func_enter_;
 
-	if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-	{
-		PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;			
-		struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+#ifdef CONFIG_IOCTL_CFG80211
+	if (pwdinfo->driver_interface == DRIVER_CFG80211
+		&& !rtw_cfg80211_get_is_roch(padapter))
+		return;
+#endif
 
-		pwdinfo->operating_channel = pbuddy_mlmeext->cur_channel;
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		u8 union_ch = rtw_mi_get_union_chan(padapter);
+		u8 union_bw = rtw_mi_get_union_bw(padapter);
+		u8 union_offset = rtw_mi_get_union_offset(padapter);
 
-		if( pwdinfo->driver_interface == DRIVER_CFG80211 )
-		{
-			DBG_871X("%s, switch ch back to buddy's cur_channel=%d\n", __func__, pbuddy_mlmeext->cur_channel);
+		pwdinfo->operating_channel = union_ch;
 
-			set_channel_bwmode(padapter, pbuddy_mlmeext->cur_channel, pbuddy_mlmeext->cur_ch_offset, pbuddy_mlmeext->cur_bwmode);
+		if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+			RTW_INFO("%s, switch ch back to union=%u,%u, %u\n"
+				, __func__, union_ch, union_bw, union_offset);
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_back_opch(padapter);
 
-			if (check_buddy_fwstate(padapter, WIFI_FW_STATION_STATE))
-				issue_nulldata(pbuddy_adapter, NULL, 0, 3, 500);
-		}
-		else if( pwdinfo->driver_interface == DRIVER_WEXT )
-		{
-			if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
-			{
-				//	Now, the driver stays on the AP's channel.
-				//	If the pwdinfo->ext_listen_period = 0, that means the P2P listen state is not available on listen channel.
-				if ( pwdinfo->ext_listen_period > 0 )
-				{
-					DBG_8192C( "[%s] P2P_STATE_IDLE, ext_listen_period = %d\n", __FUNCTION__, pwdinfo->ext_listen_period );
+		} else if (pwdinfo->driver_interface == DRIVER_WEXT) {
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
+				/*	Now, the driver stays on the AP's channel. */
+				/*	If the pwdinfo->ext_listen_period = 0, that means the P2P listen state is not available on listen channel. */
+				if (pwdinfo->ext_listen_period > 0) {
+					RTW_INFO("[%s] P2P_STATE_IDLE, ext_listen_period = %d\n", __FUNCTION__, pwdinfo->ext_listen_period);
 
-					if ( pbuddy_mlmeext->cur_channel != pwdinfo->listen_channel )
-					{
-						//	Will switch to listen channel so that need to send the NULL data with PW bit to AP.
-						issue_nulldata(pbuddy_adapter, NULL, 1, 3, 500);
+					if (union_ch != pwdinfo->listen_channel) {
+						rtw_leave_opch(padapter);
 						set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 					}
 
 					rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
-					if(!check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE) &&
-					   (pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
-					{
+
+					if (!rtw_mi_check_mlmeinfo_state(padapter, WIFI_FW_AP_STATE)) {
 						val8 = 1;
 						rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 					}
-					//	Todo: To check the value of pwdinfo->ext_listen_period is equal to 0 or not.
-					_set_timer( &pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_period );
+					/*	Todo: To check the value of pwdinfo->ext_listen_period is equal to 0 or not. */
+					_set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_period);
 				}
-			}
-			else if ( rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN) || 
-					rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL) ||
-					( rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) && pwdinfo->nego_req_info.benable == _FALSE ) ||
-					rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ) )
-			{
-				//	Now, the driver is in the listen state of P2P mode.
-				DBG_8192C( "[%s] P2P_STATE_IDLE, ext_listen_interval = %d\n", __FUNCTION__, pwdinfo->ext_listen_interval );
-
-				//	Commented by Albert 2012/11/01
-				//	If the AP's channel is the same as the listen channel, we should still be in the listen state
-				//	Other P2P device is still able to find this device out even this device is in the AP's channel.
-				//	So, configure this device to be able to receive the probe request frame and set it to listen state.
-				if ( pbuddy_mlmeext->cur_channel != pwdinfo->listen_channel )
-				{
-					set_channel_bwmode(padapter, pbuddy_mlmeext->cur_channel, pbuddy_mlmeext->cur_ch_offset, pbuddy_mlmeext->cur_bwmode);
-					if(!check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE) && (pmlmeinfo->state&0x03) != WIFI_FW_AP_STATE)
-					{						
+
+			} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN) ||
+				rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL) ||
+				(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) && pwdinfo->nego_req_info.benable == _FALSE) ||
+				rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ)) {
+				/*	Now, the driver is in the listen state of P2P mode. */
+				RTW_INFO("[%s] P2P_STATE_IDLE, ext_listen_interval = %d\n", __FUNCTION__, pwdinfo->ext_listen_interval);
+
+				/*	Commented by Albert 2012/11/01 */
+				/*	If the AP's channel is the same as the listen channel, we should still be in the listen state */
+				/*	Other P2P device is still able to find this device out even this device is in the AP's channel. */
+				/*	So, configure this device to be able to receive the probe request frame and set it to listen state. */
+				if (union_ch != pwdinfo->listen_channel) {
+
+					set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+					if (!rtw_mi_check_status(padapter, MI_AP_MODE)) {
 						val8 = 0;
 						rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 					}
 					rtw_p2p_set_state(pwdinfo, P2P_STATE_IDLE);
-					issue_nulldata(pbuddy_adapter, NULL, 0, 3, 500);
+					rtw_back_opch(padapter);
 				}
 
-				//	Todo: To check the value of pwdinfo->ext_listen_interval is equal to 0 or not.
-				_set_timer( &pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_interval );
-			}
-			else if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_OK))
-			{
-				//	The driver had finished the P2P handshake successfully.
+				/*	Todo: To check the value of pwdinfo->ext_listen_interval is equal to 0 or not. */
+				_set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_interval);
+
+			} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_OK)) {
+				/*	The driver had finished the P2P handshake successfully. */
 				val8 = 0;
 				rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
-				set_channel_bwmode(padapter, pbuddy_mlmeext->cur_channel, pbuddy_mlmeext->cur_ch_offset, pbuddy_mlmeext->cur_bwmode);
-				issue_nulldata(pbuddy_adapter, NULL, 0, 3, 500);
-			}
-			else if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ))
-			{
+				set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+				rtw_back_opch(padapter);
+
+			} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ)) {
 				val8 = 1;
 				set_channel_bwmode(padapter, pwdinfo->tx_prov_disc_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 				rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 				issue_probereq_p2p(padapter, NULL);
-				_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-			}
-			else if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) && pwdinfo->nego_req_info.benable == _TRUE)
-			{
+				_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+			} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) && pwdinfo->nego_req_info.benable == _TRUE) {
 				val8 = 1;
 				set_channel_bwmode(padapter, pwdinfo->nego_req_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 				rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 				issue_probereq_p2p(padapter, NULL);
-				_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-			}		
-			else if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ ) && pwdinfo->invitereq_info.benable == _TRUE)
-			{
+				_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+			} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ) && pwdinfo->invitereq_info.benable == _TRUE) {
 				/*
 				val8 = 1;
-			set_channel_bwmode(padapter, , HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+				set_channel_bwmode(padapter, , HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 				rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
 				issue_probereq_p2p(padapter, NULL);
 				_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
 				*/
 			}
 		}
-	}
-	else
-	{
+	} else {
 		/* In p2p+softap. When in P2P_STATE_GONEGO_OK, not back to listen channel.*/
 		if (!rtw_p2p_chk_state(pwdinfo , P2P_STATE_GONEGO_OK) || padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-			set_channel_bwmode(padapter , pwdinfo->listen_channel , HAL_PRIME_CHNL_OFFSET_DONT_CARE , CHANNEL_WIDTH_20);
+			set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 		else
-			DBG_871X("%s, buddy not linked, go nego ok, not back to listen channel\n", __func__);
+			RTW_INFO("%s, buddy not linked, go nego ok, not back to listen channel\n", __func__);
 	}
 
-_func_exit_;
 }
 #endif
 
 #ifdef CONFIG_IOCTL_CFG80211
-static void ro_ch_handler(_adapter *padapter)
+u8 roch_stay_in_cur_chan(_adapter *padapter)
+{
+	int i;
+	_adapter *iface;
+	struct mlme_priv *pmlmepriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	u8 rst = _FALSE;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {
+			pmlmepriv = &iface->mlmepriv;
+
+			if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS) == _TRUE) {
+				RTW_ERR(ADPT_FMT"- _FW_UNDER_LINKING |WIFI_UNDER_WPS (mlme state:0x%x)\n",
+						ADPT_ARG(iface), get_fwstate(&iface->mlmepriv));
+				rst = _TRUE;
+				break;
+			}
+			#ifdef CONFIG_AP_MODE
+			if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
+				if (rtw_ap_sta_linking_state_check(iface) == _TRUE) {
+					RTW_ERR(ADPT_FMT"- SoftAP/Mesh -have sta under linking\n", ADPT_ARG(iface));
+					rst = _TRUE;
+					break;
+				}
+			}
+			#endif
+		}
+	}
+
+	return rst;
+}
+
+static int ro_ch_handler(_adapter *adapter, u8 *buf)
 {
+	int ret = H2C_SUCCESS;
+	struct p2p_roch_parm *roch_parm = (struct p2p_roch_parm *)buf;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &adapter->cfg80211_wdinfo;
+	struct wifidirect_info *pwdinfo = &adapter->wdinfo;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	u8 ready_on_channel = _FALSE;
+	u8 remain_ch;
+	unsigned int duration;
+
+	_enter_critical_mutex(&pwdev_priv->roch_mutex, NULL);
+
+	if (rtw_cfg80211_get_is_roch(adapter) != _TRUE)
+		goto exit;
+
+	remain_ch = (u8)ieee80211_frequency_to_channel(roch_parm->ch.center_freq);
+	duration = roch_parm->duration;
+
+	RTW_INFO(FUNC_ADPT_FMT" ch:%u duration:%d, cookie:0x%llx\n"
+		, FUNC_ADPT_ARG(adapter), remain_ch, roch_parm->duration, roch_parm->cookie);
+
+	if (roch_parm->wdev && roch_parm->cookie) {
+		if (pcfg80211_wdinfo->ro_ch_wdev != roch_parm->wdev) {
+			RTW_WARN(FUNC_ADPT_FMT" ongoing wdev:%p, wdev:%p\n"
+				, FUNC_ADPT_ARG(adapter), pcfg80211_wdinfo->ro_ch_wdev, roch_parm->wdev);
+			rtw_warn_on(1);
+		}
+
+		if (pcfg80211_wdinfo->remain_on_ch_cookie != roch_parm->cookie) {
+			RTW_WARN(FUNC_ADPT_FMT" ongoing cookie:0x%llx, cookie:0x%llx\n"
+				, FUNC_ADPT_ARG(adapter), pcfg80211_wdinfo->remain_on_ch_cookie, roch_parm->cookie);
+			rtw_warn_on(1);
+		}
+	}
+
+	if (roch_stay_in_cur_chan(adapter) == _TRUE) {
+		remain_ch = rtw_mi_get_union_chan(adapter);
+		RTW_INFO(FUNC_ADPT_FMT" stay in union ch:%d\n", FUNC_ADPT_ARG(adapter), remain_ch);
+	}
+
+	#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_check_status(adapter, MI_LINKED) && (0 != rtw_mi_get_union_chan(adapter))) {
+		if ((remain_ch != rtw_mi_get_union_chan(adapter)) && !check_fwstate(&adapter->mlmepriv, _FW_LINKED)) {
+			if (remain_ch != pmlmeext->cur_channel
+				#ifdef RTW_ROCH_BACK_OP
+				|| ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1
+				#endif
+			) {
+				rtw_leave_opch(adapter);
+
+				#ifdef RTW_ROCH_BACK_OP
+				RTW_INFO("%s, set switch ch timer, duration=%d\n", __func__, duration - pwdinfo->ext_listen_interval);
+				ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
+				_set_timer(&pwdinfo->ap_p2p_switch_timer, duration - pwdinfo->ext_listen_interval);
+				#endif
+			}
+		}
+		ready_on_channel = _TRUE;
+	} else
+	#endif /* CONFIG_CONCURRENT_MODE */
+	{
+		if (remain_ch != rtw_get_oper_ch(adapter))
+			ready_on_channel = _TRUE;
+	}
+
+	if (ready_on_channel == _TRUE) {
+		#ifndef RTW_SINGLE_WIPHY
+		if (!check_fwstate(&adapter->mlmepriv, _FW_LINKED))
+		#endif
+		{
+			#ifdef CONFIG_CONCURRENT_MODE
+			if (rtw_get_oper_ch(adapter) != remain_ch)
+			#endif
+			{
+				/* if (!padapter->mlmepriv.LinkDetectInfo.bBusyTraffic) */
+				set_channel_bwmode(adapter, remain_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+			}
+		}
+	}
+
+	#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_ScanNotify(adapter, _TRUE);
+	#endif
+
+	RTW_INFO("%s, set ro ch timer, duration=%d\n", __func__, duration);
+	_set_timer(&pcfg80211_wdinfo->remain_on_ch_timer, duration);
+
+exit:
+	_exit_critical_mutex(&pwdev_priv->roch_mutex, NULL);
+
+	return ret;
+}
+
+static int cancel_ro_ch_handler(_adapter *padapter, u8 *buf)
+{
+	int ret = H2C_SUCCESS;
+	struct p2p_roch_parm *roch_parm = (struct p2p_roch_parm *)buf;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
 	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+	struct wireless_dev *wdev;
 	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	u8 ch, bw, offset;
-_func_enter_;
 
-	if (rtw_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
-		if (0)
-			DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-				FUNC_ADPT_ARG(padapter), ch, bw, offset);
+	_enter_critical_mutex(&pwdev_priv->roch_mutex, NULL);
+
+	if (rtw_cfg80211_get_is_roch(padapter) != _TRUE)
+		goto exit;
+
+	if (roch_parm->wdev && roch_parm->cookie) {
+		if (pcfg80211_wdinfo->ro_ch_wdev != roch_parm->wdev) {
+			RTW_WARN(FUNC_ADPT_FMT" ongoing wdev:%p, wdev:%p\n"
+				, FUNC_ADPT_ARG(padapter), pcfg80211_wdinfo->ro_ch_wdev, roch_parm->wdev);
+			rtw_warn_on(1);
+		}
+
+		if (pcfg80211_wdinfo->remain_on_ch_cookie != roch_parm->cookie) {
+			RTW_WARN(FUNC_ADPT_FMT" ongoing cookie:0x%llx, cookie:0x%llx\n"
+				, FUNC_ADPT_ARG(padapter), pcfg80211_wdinfo->remain_on_ch_cookie, roch_parm->cookie);
+			rtw_warn_on(1);
+		}
 	}
-	else if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->listen_channel) {
+
+#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_CONCURRENT_MODE)
+	_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif
+
+	if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
+				 FUNC_ADPT_ARG(padapter), ch, bw, offset);
+	} else if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->listen_channel) {
 		ch = pwdinfo->listen_channel;
 		bw = CHANNEL_WIDTH_20;
 		offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 		if (0)
-			DBG_871X(FUNC_ADPT_FMT" back to listen ch - ch:%u, bw:%u, offset:%u\n",
-				FUNC_ADPT_ARG(padapter), ch, bw, offset);
-	}
-	else {
+			RTW_INFO(FUNC_ADPT_FMT" back to listen ch - ch:%u, bw:%u, offset:%u\n",
+				 FUNC_ADPT_ARG(padapter), ch, bw, offset);
+	} else {
 		ch = pcfg80211_wdinfo->restore_channel;
 		bw = CHANNEL_WIDTH_20;
 		offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 		if (0)
-			DBG_871X(FUNC_ADPT_FMT" back to restore ch - ch:%u, bw:%u, offset:%u\n",
-				FUNC_ADPT_ARG(padapter), ch, bw, offset);
+			RTW_INFO(FUNC_ADPT_FMT" back to restore ch - ch:%u, bw:%u, offset:%u\n",
+				 FUNC_ADPT_ARG(padapter), ch, bw, offset);
 	}
 
 	set_channel_bwmode(padapter, ch, offset, bw);
+	rtw_back_opch(padapter);
 
 	rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
 #ifdef CONFIG_DEBUG_CFG80211
-	DBG_871X("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
+	RTW_INFO("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
 #endif
 
-	pcfg80211_wdinfo->is_ro_ch = _FALSE;
-	pcfg80211_wdinfo->last_ro_ch_time = rtw_get_current_time();
+	wdev = pcfg80211_wdinfo->ro_ch_wdev;
+
+	rtw_cfg80211_set_is_roch(padapter, _FALSE);
+	pcfg80211_wdinfo->ro_ch_wdev = NULL;
+	rtw_cfg80211_set_last_ro_ch_time(padapter);
 
-	DBG_871X("cfg80211_remain_on_channel_expired cookie:0x%llx, ch=%d, bw=%d, offset=%d\n"
+	rtw_cfg80211_remain_on_channel_expired(wdev
 		, pcfg80211_wdinfo->remain_on_ch_cookie
-		, rtw_get_oper_ch(padapter), rtw_get_oper_bw(padapter), rtw_get_oper_choffset(padapter));
+		, &pcfg80211_wdinfo->remain_on_ch_channel
+		, pcfg80211_wdinfo->remain_on_ch_type, GFP_KERNEL);
+
+	RTW_INFO("cfg80211_remain_on_channel_expired cookie:0x%llx\n"
+		, pcfg80211_wdinfo->remain_on_ch_cookie);
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_ScanNotify(padapter, _FALSE);
+#endif
 
-	rtw_cfg80211_remain_on_channel_expired(padapter, 
-		pcfg80211_wdinfo->remain_on_ch_cookie, 
-		&pcfg80211_wdinfo->remain_on_ch_channel,
-		pcfg80211_wdinfo->remain_on_ch_type, GFP_KERNEL);
+exit:
+	_exit_critical_mutex(&pwdev_priv->roch_mutex, NULL);
 
-_func_exit_;
+	return ret;
 }
 
-static void ro_ch_timer_process (void *FunctionContext)
+static void ro_ch_timer_process(void *FunctionContext)
 {
 	_adapter *adapter = (_adapter *)FunctionContext;
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
 
-	//printk("%s \n", __FUNCTION__);
-	
-#ifdef	CONFIG_CONCURRENT_MODE
-	ATOMIC_SET(&pwdev_priv->ro_ch_to, 1);
-#endif
-
-	p2p_protocol_wk_cmd( adapter, P2P_RO_CH_WK);
+	p2p_cancel_roch_cmd(adapter, 0, NULL, 0);
 }
 
 static void rtw_change_p2pie_op_ch(_adapter *padapter, const u8 *frame_body, u32 len, u8 ch)
 {
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
-	PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
 
-	ies = (u8*)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter))
+		return;
+#endif /* CONFIG_MCC_MODE */
+
+	ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
 
-	while ( p2p_ie ) {
+	while (p2p_ie) {
 		u32	attr_contentlen = 0;
 		u8 *pattr = NULL;
 
-		//Check P2P_ATTR_OPERATING_CH
+		/* Check P2P_ATTR_OPERATING_CH */
 		attr_contentlen = 0;
 		pattr = NULL;
-		if((pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint*)&attr_contentlen))!=NULL)
-		{
-			*(pattr+4) = ch;
-		}
+		pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint *)&attr_contentlen);
+		if (pattr != NULL)
+			*(pattr + 4) = ch;
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 }
 
@@ -3700,39 +3539,43 @@ static void rtw_change_p2pie_ch_list(_adapter *padapter, const u8 *frame_body, u
 {
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
-	PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
 
-	ies = (u8*)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter))
+		return;
+#endif /* CONFIG_MCC_MODE */
+
+	ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
 
 	while (p2p_ie) {
 		u32	attr_contentlen = 0;
 		u8 *pattr = NULL;
 
-		//Check P2P_ATTR_CH_LIST
-		if ((pattr=rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint*)&attr_contentlen))!=NULL) {
+		/* Check P2P_ATTR_CH_LIST */
+		pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint *)&attr_contentlen);
+		if (pattr != NULL) {
 			int i;
 			u32 num_of_ch;
 			u8 *pattr_temp = pattr + 3 ;
 
 			attr_contentlen -= 3;
-			
-			while (attr_contentlen>0) {
-				num_of_ch = *(pattr_temp+1);
 
-				for(i=0; i<num_of_ch; i++)
-					*(pattr_temp+2+i) = ch;
+			while (attr_contentlen > 0) {
+				num_of_ch = *(pattr_temp + 1);
+
+				for (i = 0; i < num_of_ch; i++)
+					*(pattr_temp + 2 + i) = ch;
 
-				pattr_temp += (2+num_of_ch);
-				attr_contentlen -= (2+num_of_ch);
+				pattr_temp += (2 + num_of_ch);
+				attr_contentlen -= (2 + num_of_ch);
 			}
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 }
 
@@ -3742,45 +3585,44 @@ static bool rtw_chk_p2pie_ch_list_with_buddy(_adapter *padapter, const u8 *frame
 #ifdef CONFIG_CONCURRENT_MODE
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
-	PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-	u8 buddy_ch = pbuddy_mlmeext->cur_channel;
+	u8 union_ch = rtw_mi_get_union_chan(padapter);
 
-	ies = (u8*)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
+	ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
 
 	while (p2p_ie) {
 		u32	attr_contentlen = 0;
 		u8 *pattr = NULL;
 
-		//Check P2P_ATTR_CH_LIST
-		if ((pattr=rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint*)&attr_contentlen))!=NULL) {
+		/* Check P2P_ATTR_CH_LIST */
+		pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint *)&attr_contentlen);
+		if (pattr != NULL) {
 			int i;
 			u32 num_of_ch;
 			u8 *pattr_temp = pattr + 3 ;
 
 			attr_contentlen -= 3;
 
-			while (attr_contentlen>0) {
-				num_of_ch = *(pattr_temp+1);
+			while (attr_contentlen > 0) {
+				num_of_ch = *(pattr_temp + 1);
 
-				for(i=0; i<num_of_ch; i++) {
-					if (*(pattr_temp+2+i) == buddy_ch) {
-						DBG_871X(FUNC_ADPT_FMT" ch_list fit buddy_ch:%u\n", FUNC_ADPT_ARG(padapter), buddy_ch);
+				for (i = 0; i < num_of_ch; i++) {
+					if (*(pattr_temp + 2 + i) == union_ch) {
+						RTW_INFO(FUNC_ADPT_FMT" ch_list fit buddy_ch:%u\n", FUNC_ADPT_ARG(padapter), union_ch);
 						fit = _TRUE;
 						break;
 					}
 				}
 
-				pattr_temp += (2+num_of_ch);
-				attr_contentlen -= (2+num_of_ch);
+				pattr_temp += (2 + num_of_ch);
+				attr_contentlen -= (2 + num_of_ch);
 			}
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 #endif
 	return fit;
@@ -3792,32 +3634,31 @@ static bool rtw_chk_p2pie_op_ch_with_buddy(_adapter *padapter, const u8 *frame_b
 #ifdef CONFIG_CONCURRENT_MODE
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
-	PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-	u8 buddy_ch = pbuddy_mlmeext->cur_channel;
+	u8 union_ch = rtw_mi_get_union_chan(padapter);
 
-	ies = (u8*)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
+	ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
 
 	while (p2p_ie) {
 		u32	attr_contentlen = 0;
 		u8 *pattr = NULL;
 
-		//Check P2P_ATTR_OPERATING_CH
+		/* Check P2P_ATTR_OPERATING_CH */
 		attr_contentlen = 0;
 		pattr = NULL;
-		if((pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint*)&attr_contentlen))!=NULL) {
-			if (*(pattr+4) == buddy_ch) {
-				DBG_871X(FUNC_ADPT_FMT" op_ch fit buddy_ch:%u\n", FUNC_ADPT_ARG(padapter), buddy_ch);
+		pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint *)&attr_contentlen);
+		if (pattr != NULL) {
+			if (*(pattr + 4) == union_ch) {
+				RTW_INFO(FUNC_ADPT_FMT" op_ch fit buddy_ch:%u\n", FUNC_ADPT_ARG(padapter), union_ch);
 				fit = _TRUE;
 				break;
 			}
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 #endif
 	return fit;
@@ -3828,51 +3669,64 @@ static void rtw_cfg80211_adjust_p2pie_channel(_adapter *padapter, const u8 *fram
 #ifdef CONFIG_CONCURRENT_MODE
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
-	PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;			
-	struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+	u8 union_ch = rtw_mi_get_union_chan(padapter);
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter))
+		return;
+#endif /* CONFIG_MCC_MODE */
 
-	ies = (u8*)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
+	ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
 	ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
-					
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen );
 
-	while ( p2p_ie )
-	{	
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
+
+	while (p2p_ie) {
 		u32	attr_contentlen = 0;
 		u8 *pattr = NULL;
-				
-		//Check P2P_ATTR_CH_LIST
-		if((pattr=rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint*)&attr_contentlen))!=NULL)
-		{
+
+		/* Check P2P_ATTR_CH_LIST */
+		pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint *)&attr_contentlen);
+		if (pattr != NULL) {
 			int i;
 			u32 num_of_ch;
 			u8 *pattr_temp = pattr + 3 ;
 
 			attr_contentlen -= 3;
-			
-			while(attr_contentlen>0)
-			{				
-				num_of_ch = *(pattr_temp+1);
-								
-				for(i=0; i<num_of_ch; i++)
-					*(pattr_temp+2+i) = pbuddy_mlmeext->cur_channel;//forcing to the same channel
-
-				pattr_temp += (2+num_of_ch);
-				attr_contentlen -= (2+num_of_ch);
-			}	
+
+			while (attr_contentlen > 0) {
+				num_of_ch = *(pattr_temp + 1);
+
+				for (i = 0; i < num_of_ch; i++) {
+					if (*(pattr_temp + 2 + i) && *(pattr_temp + 2 + i) != union_ch) {
+						#ifdef RTW_SINGLE_WIPHY
+						RTW_ERR("replace ch_list:%u with:%u\n", *(pattr_temp + 2 + i), union_ch);
+						#endif
+						*(pattr_temp + 2 + i) = union_ch; /*forcing to the same channel*/
+					}
+				}
+
+				pattr_temp += (2 + num_of_ch);
+				attr_contentlen -= (2 + num_of_ch);
+			}
 		}
 
-		//Check P2P_ATTR_OPERATING_CH
+		/* Check P2P_ATTR_OPERATING_CH */
 		attr_contentlen = 0;
 		pattr = NULL;
-		if((pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint*)&attr_contentlen))!=NULL)
-		{
-			*(pattr+4) = pbuddy_mlmeext->cur_channel;//forcing to the same channel			
+		pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint *)&attr_contentlen);
+		if (pattr != NULL) {
+			if (*(pattr + 4) && *(pattr + 4) != union_ch) {
+				#ifdef RTW_SINGLE_WIPHY
+				RTW_ERR("replace op_ch:%u with:%u\n", *(pattr + 4), union_ch);
+				#endif
+				*(pattr + 4) = union_ch; /*forcing to the same channel	*/
+			}
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
-		
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
+
 	}
 
 #endif
@@ -3893,8 +3747,8 @@ u32 rtw_xframe_build_wfd_ie(struct xmit_frame *xframe)
 	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
 		action = frame_body[1];
 		if (action == ACT_PUBLIC_VENDOR
-			&& _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
-		) {
+		    && _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
+		   ) {
 			OUI_Subtype = frame_body[6];
 			dialogToken = frame_body[7];
 
@@ -3931,10 +3785,10 @@ u32 rtw_xframe_build_wfd_ie(struct xmit_frame *xframe)
 		OUI_Subtype = frame_body[5];
 		dialogToken = frame_body[6];
 
-		#ifdef CONFIG_DEBUG_CFG80211
-		DBG_871X("ACTION_CATEGORY_P2P: OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n"
+#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("ACTION_CATEGORY_P2P: OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n"
 			, cpu_to_be32(*((u32 *)(frame_body + 1))), OUI_Subtype, dialogToken);
-		#endif
+#endif
 
 		switch (OUI_Subtype) {
 		case P2P_NOTICE_OF_ABSENCE:
@@ -3948,9 +3802,8 @@ u32 rtw_xframe_build_wfd_ie(struct xmit_frame *xframe)
 		default:
 			break;
 		}
-	} else {
-		DBG_871X("%s, action frame category=%d\n", __func__, category);
-	}
+	} else
+		RTW_INFO("%s, action frame category=%d\n", __func__, category);
 
 	xframe->attrib.pktlen += wfdielen;
 
@@ -3975,8 +3828,8 @@ bool rtw_xframe_del_wfd_ie(struct xmit_frame *xframe)
 	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
 		action = frame_body[1];
 		if (action == ACT_PUBLIC_VENDOR
-			&& _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
-		) {
+		    && _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
+		   ) {
 			OUI_Subtype = frame_body[6];
 
 			switch (OUI_Subtype) {
@@ -4044,7 +3897,8 @@ u8 *dump_p2p_attr_ch_list(u8 *p2p_ie, uint p2p_ielen, u8 *buf, u32 buf_len)
 	u8 ch_list[40];
 	bool continuous = _FALSE;
 
-	if ((pattr=rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, &attr_contentlen))!=NULL) {
+	pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, &attr_contentlen);
+	if (pattr != NULL) {
 		int i, j;
 		u32 num_of_ch;
 		u8 *pattr_temp = pattr + 3 ;
@@ -4053,33 +3907,32 @@ u8 *dump_p2p_attr_ch_list(u8 *p2p_ie, uint p2p_ielen, u8 *buf, u32 buf_len)
 
 		_rtw_memset(ch_list, 0, 40);
 
-		while (attr_contentlen>0) {
-			num_of_ch = *(pattr_temp+1);
+		while (attr_contentlen > 0) {
+			num_of_ch = *(pattr_temp + 1);
 
-			for(i=0; i<num_of_ch; i++) {
-				for (j=0;j<ch_cnt;j++) {
-					if (ch_list[j] == *(pattr_temp+2+i))
+			for (i = 0; i < num_of_ch; i++) {
+				for (j = 0; j < ch_cnt; j++) {
+					if (ch_list[j] == *(pattr_temp + 2 + i))
 						break;
 				}
-				if (j>=ch_cnt)
-					ch_list[ch_cnt++] = *(pattr_temp+2+i);
+				if (j >= ch_cnt)
+					ch_list[ch_cnt++] = *(pattr_temp + 2 + i);
 
 			}
 
-			pattr_temp += (2+num_of_ch);
-			attr_contentlen -= (2+num_of_ch);
+			pattr_temp += (2 + num_of_ch);
+			attr_contentlen -= (2 + num_of_ch);
 		}
 
-		for (j=0;j<ch_cnt;j++) {
-			if (j == 0) {
-				w_sz += snprintf(buf+w_sz, buf_len-w_sz, "%u", ch_list[j]);
-			} else if (ch_list[j] - ch_list[j-1] != 1) {
-				w_sz += snprintf(buf+w_sz, buf_len-w_sz, ", %u", ch_list[j]);
-			} else if (j != ch_cnt-1 && ch_list[j+1] - ch_list[j] == 1) {
+		for (j = 0; j < ch_cnt; j++) {
+			if (j == 0)
+				w_sz += snprintf(buf + w_sz, buf_len - w_sz, "%u", ch_list[j]);
+			else if (ch_list[j] - ch_list[j - 1] != 1)
+				w_sz += snprintf(buf + w_sz, buf_len - w_sz, ", %u", ch_list[j]);
+			else if (j != ch_cnt - 1 && ch_list[j + 1] - ch_list[j] == 1) {
 				/* empty */
-			} else {
-				w_sz += snprintf(buf+w_sz, buf_len-w_sz, "-%u", ch_list[j]);
-			}
+			} else
+				w_sz += snprintf(buf + w_sz, buf_len - w_sz, "-%u", ch_list[j]);
 		}
 	}
 	return buf;
@@ -4090,9 +3943,9 @@ u8 *dump_p2p_attr_ch_list(u8 *p2p_ie, uint p2p_ielen, u8 *buf, u32 buf_len)
  */
 bool rtw_p2p_nego_intent_compare(u8 req, u8 resp)
 {
-	if (req>>1 == resp >>1)
-		return  req&0x01 ? _TRUE : _FALSE;
-	else if (req>>1 > resp>>1)
+	if (req >> 1 == resp >> 1)
+		return  req & 0x01 ? _TRUE : _FALSE;
+	else if (req >> 1 > resp >> 1)
 		return _TRUE;
 	else
 		return _FALSE;
@@ -4102,7 +3955,7 @@ int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx)
 {
 	int is_p2p_frame = (-1);
 	unsigned char	*frame_body;
-	u8 category, action, OUI_Subtype, dialogToken=0;
+	u8 category, action, OUI_Subtype, dialogToken = 0;
 	u8 *p2p_ie = NULL;
 	uint p2p_ielen = 0;
 	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
@@ -4111,552 +3964,548 @@ int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx)
 	int op_ch = -1;
 	int listen_ch = -1;
 	u8 intent = 0;
-	
-	frame_body = (unsigned char *)(buf + sizeof(struct rtw_ieee80211_hdr_3addr));	
+	u8 *iaddr = NULL;
+	u8 *gbssid = NULL;
+
+	frame_body = (unsigned char *)(buf + sizeof(struct rtw_ieee80211_hdr_3addr));
 	category = frame_body[0];
-	//just for check
-	if(category == RTW_WLAN_CATEGORY_PUBLIC)
-	{
+	/* just for check */
+	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
 		action = frame_body[1];
 		if (action == ACT_PUBLIC_VENDOR
-			&& _rtw_memcmp(frame_body+2, P2P_OUI, 4) == _TRUE
-		)
-		{
+			&& _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
+		) {
 			OUI_Subtype = frame_body[6];
 			dialogToken = frame_body[7];
 			is_p2p_frame = OUI_Subtype;
+
 			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_871X("ACTION_CATEGORY_PUBLIC: ACT_PUBLIC_VENDOR, OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n",
-				cpu_to_be32( *( ( u32* ) ( frame_body + 2 ) ) ), OUI_Subtype, dialogToken);
+			RTW_INFO("ACTION_CATEGORY_PUBLIC: ACT_PUBLIC_VENDOR, OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n",
+				cpu_to_be32(*((u32 *)(frame_body + 2))), OUI_Subtype, dialogToken);
 			#endif
 
 			p2p_ie = rtw_get_p2p_ie(
-				(u8 *)buf+sizeof(struct rtw_ieee80211_hdr_3addr)+_PUBLIC_ACTION_IE_OFFSET_,
-				len-sizeof(struct rtw_ieee80211_hdr_3addr)-_PUBLIC_ACTION_IE_OFFSET_,
-				NULL, &p2p_ielen);
+				(u8 *)buf + sizeof(struct rtw_ieee80211_hdr_3addr) + _PUBLIC_ACTION_IE_OFFSET_
+				, len - sizeof(struct rtw_ieee80211_hdr_3addr) - _PUBLIC_ACTION_IE_OFFSET_
+				, NULL, &p2p_ielen);
 
-			switch( OUI_Subtype )//OUI Subtype
-			{
+			switch (OUI_Subtype) { /* OUI Subtype */
 				u8 *cont;
 				uint cont_len;
-				case P2P_GO_NEGO_REQ:
-				{
-					struct rtw_wdev_nego_info* nego_info = &pwdev_priv->nego_info;
-
-					if (tx) {
-						#ifdef CONFIG_DRV_ISSUE_PROV_REQ // IOT FOR S2
-						if(pwdev_priv->provdisc_req_issued == _FALSE)
-							rtw_cfg80211_issue_p2p_provision_request(padapter, buf, len);
-						#endif //CONFIG_DRV_ISSUE_PROV_REQ
+			case P2P_GO_NEGO_REQ: {
+				struct rtw_wdev_nego_info *nego_info = &pwdev_priv->nego_info;
 
-						//pwdev_priv->provdisc_req_issued = _FALSE;
-
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter , _FW_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-							rtw_cfg80211_adjust_p2pie_channel(padapter , frame_body , len-sizeof(struct rtw_ieee80211_hdr_3addr));
-						#endif
-					}
+				if (tx) {
+					#ifdef CONFIG_DRV_ISSUE_PROV_REQ /* IOT FOR S2 */
+					if (pwdev_priv->provdisc_req_issued == _FALSE)
+						rtw_cfg80211_issue_p2p_provision_request(padapter, buf, len);
+					#endif /* CONFIG_DRV_ISSUE_PROV_REQ */
 
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len)))
-						op_ch = *(cont+4);
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, NULL, &cont_len)))
-						listen_ch = *(cont+4);
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT, NULL, &cont_len)))
-						intent = *cont;
-
-					if (nego_info->token != dialogToken)
-						rtw_wdev_nego_info_init(nego_info);
-
-					_rtw_memcpy(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : GetAddr2Ptr(buf), ETH_ALEN);
-					nego_info->active = tx ? 1 : 0;
-					nego_info->token = dialogToken;
-					nego_info->req_op_ch = op_ch;
-					nego_info->req_listen_ch = listen_ch;
-					nego_info->req_intent = intent;
-					nego_info->state = 0;
-
-					dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
-					DBG_871X("RTW_%s:P2P_GO_NEGO_REQ, dialogToken=%d, intent:%u%s, listen_ch:%d, op_ch:%d, ch_list:%s, full_ch_in_p2p_handshake:%d\n" ,
-							(tx == _TRUE)?"Tx":"Rx" , dialogToken , (intent>>1) , intent&0x1 ? "+" : "-" , listen_ch , op_ch , ch_list_buf , padapter->registrypriv.full_ch_in_p2p_handshake);
-
-					if (!tx) {
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter, _FW_LINKED)
-							&& rtw_chk_p2pie_ch_list_with_buddy(padapter , frame_body , len-sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE
-							&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-						{
-							DBG_871X(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
-							rtw_change_p2pie_ch_list(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr), 0);
-						}
-						#endif
-					}
+					/* pwdev_priv->provdisc_req_issued = _FALSE; */
 
-					break;
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+						rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
+					#endif
 				}
-				case P2P_GO_NEGO_RESP:
-				{
-					struct rtw_wdev_nego_info* nego_info = &pwdev_priv->nego_info;
 
-					if (tx) {
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter , _FW_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-							rtw_cfg80211_adjust_p2pie_channel(padapter , frame_body , len-sizeof(struct rtw_ieee80211_hdr_3addr));
-						#endif
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
+				if (cont)
+					op_ch = *(cont + 4);
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, NULL, &cont_len);
+				if (cont)
+					listen_ch = *(cont + 4);
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT, NULL, &cont_len);
+				if (cont)
+					intent = *cont;
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, NULL, &cont_len);
+				if (cont && cont_len == 6)
+					iaddr = cont;
+
+				if (nego_info->token != dialogToken)
+					rtw_wdev_nego_info_init(nego_info);
+
+				_rtw_memcpy(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN);
+				if (iaddr)
+					_rtw_memcpy(tx ? nego_info->iface_addr : nego_info->peer_iface_addr, iaddr, ETH_ALEN);
+				nego_info->active = tx ? 1 : 0;
+				nego_info->token = dialogToken;
+				nego_info->req_op_ch = op_ch;
+				nego_info->req_listen_ch = listen_ch;
+				nego_info->req_intent = intent;
+				nego_info->state = 0;
+
+				dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
+				RTW_INFO("RTW_%s:P2P_GO_NEGO_REQ, dialogToken=%d, intent:%u%s, listen_ch:%d, op_ch:%d, ch_list:%s"
+					, (tx == _TRUE) ? "Tx" : "Rx" , dialogToken , (intent >> 1) , intent & 0x1 ? "+" : "-" , listen_ch , op_ch , ch_list_buf);
+				if (iaddr)
+					_RTW_INFO(", iaddr:"MAC_FMT, MAC_ARG(iaddr));
+				_RTW_INFO("\n");
+
+				if (!tx) {
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED)
+					    && rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE
+					    && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
+						rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
 					}
+					#endif
+				}
 
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len)))
-						op_ch = *(cont+4);
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT, NULL, &cont_len)))
-						intent = *cont;
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len)))
-						status = *cont;
-
-					if (nego_info->token == dialogToken && nego_info->state == 0
-						&& _rtw_memcmp(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : GetAddr2Ptr(buf), ETH_ALEN) == _TRUE
-					) {
-						nego_info->status = (status==-1) ? 0xff : status;
-						nego_info->rsp_op_ch= op_ch;
-						nego_info->rsp_intent = intent;
-						nego_info->state = 1;
-						if (status != 0)
-							nego_info->token = 0; /* init */
-					}
-
-					dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
-					DBG_871X("RTW_%s:P2P_GO_NEGO_RESP, dialogToken=%d, intent:%u%s, status:%d, op_ch:%d, ch_list:%s\n",
-							(tx==_TRUE)?"Tx":"Rx", dialogToken, (intent>>1), intent&0x1 ? "+" : "-", status, op_ch, ch_list_buf);
-
-					if (!tx) {
-						pwdev_priv->provdisc_req_issued = _FALSE;
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter, _FW_LINKED)
-							&& rtw_chk_p2pie_ch_list_with_buddy(padapter , frame_body , len-sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE
-							&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-						{
-							DBG_871X(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
-							rtw_change_p2pie_ch_list(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr), 0);
-						}
-						#endif
-					}
+				break;
+			}
+			case P2P_GO_NEGO_RESP: {
+				struct rtw_wdev_nego_info *nego_info = &pwdev_priv->nego_info;
+
+				if (tx) {
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+						rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
+					#endif
+				}
 
-					break;
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
+				if (cont)
+					op_ch = *(cont + 4);
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT, NULL, &cont_len);
+				if (cont)
+					intent = *cont;
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
+				if (cont)
+					status = *cont;
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, NULL, &cont_len);
+				if (cont && cont_len == 6)
+					iaddr = cont;
+
+				if (nego_info->token == dialogToken && nego_info->state == 0
+					&& _rtw_memcmp(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN) == _TRUE
+				) {
+					if (iaddr)
+						_rtw_memcpy(tx ? nego_info->iface_addr : nego_info->peer_iface_addr, iaddr, ETH_ALEN);
+					nego_info->status = (status == -1) ? 0xff : status;
+					nego_info->rsp_op_ch = op_ch;
+					nego_info->rsp_intent = intent;
+					nego_info->state = 1;
+					if (status != 0)
+						nego_info->token = 0; /* init */
 				}
-				case P2P_GO_NEGO_CONF:
-				{
-					struct rtw_wdev_nego_info* nego_info = &pwdev_priv->nego_info;
-					bool is_go = _FALSE;
 
-					if (tx) {
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter, _FW_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-							rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr));
-						#endif
+				dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
+				RTW_INFO("RTW_%s:P2P_GO_NEGO_RESP, dialogToken=%d, intent:%u%s, status:%d, op_ch:%d, ch_list:%s"
+					, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, (intent >> 1), intent & 0x1 ? "+" : "-", status, op_ch, ch_list_buf);
+				if (iaddr)
+					_RTW_INFO(", iaddr:"MAC_FMT, MAC_ARG(iaddr));
+				_RTW_INFO("\n");
+
+				if (!tx) {
+					pwdev_priv->provdisc_req_issued = _FALSE;
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED)
+					    && rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE
+					    && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
+						rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
 					}
+					#endif
+				}
 
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len)))
-						op_ch = *(cont+4);
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len)))
-						status = *cont;
-
-					if (nego_info->token == dialogToken && nego_info->state == 1
-						&& _rtw_memcmp(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : GetAddr2Ptr(buf), ETH_ALEN) == _TRUE
-					) {
-						nego_info->status = (status==-1) ? 0xff : status;
-						nego_info->conf_op_ch = (op_ch==-1) ? 0 : op_ch;
-						nego_info->state = 2;
-
-						if (status == 0) {
-							if (rtw_p2p_nego_intent_compare(nego_info->req_intent, nego_info->rsp_intent) ^ !tx)
-								is_go = _TRUE;
-						}
+				break;
+			}
+			case P2P_GO_NEGO_CONF: {
+				struct rtw_wdev_nego_info *nego_info = &pwdev_priv->nego_info;
+				bool is_go = _FALSE;
+
+				if (tx) {
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+						rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
+					#endif
+				}
 
-						nego_info->token = 0; /* init */
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
+				if (cont)
+					op_ch = *(cont + 4);
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
+				if (cont)
+					status = *cont;
+
+				if (nego_info->token == dialogToken && nego_info->state == 1
+				    && _rtw_memcmp(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN) == _TRUE
+				   ) {
+					nego_info->status = (status == -1) ? 0xff : status;
+					nego_info->conf_op_ch = (op_ch == -1) ? 0 : op_ch;
+					nego_info->state = 2;
+
+					if (status == 0) {
+						if (rtw_p2p_nego_intent_compare(nego_info->req_intent, nego_info->rsp_intent) ^ !tx)
+							is_go = _TRUE;
 					}
 
-					dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
-					DBG_871X("RTW_%s:P2P_GO_NEGO_CONF, dialogToken=%d, status:%d, op_ch:%d, ch_list:%s\n",
-						(tx==_TRUE)?"Tx":"Rx", dialogToken, status, op_ch, ch_list_buf);
+					nego_info->token = 0; /* init */
+				}
 
-					if (!tx) {
-					}
+				dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
+				RTW_INFO("RTW_%s:P2P_GO_NEGO_CONF, dialogToken=%d, status:%d, op_ch:%d, ch_list:%s\n"
+					, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, status, op_ch, ch_list_buf);
 
-					break;
+				if (!tx) {
 				}
-				case P2P_INVIT_REQ:
-				{
-					struct rtw_wdev_invit_info* invit_info = &pwdev_priv->invit_info;
-					int flags = -1;
-
-					if (tx) {
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter, _FW_LINKED)
-							&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-							rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr));
-						#endif
-					}
 
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INVITATION_FLAGS, NULL, &cont_len)))
-						flags = *cont;
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len)))
-						op_ch = *(cont+4);
-
-					if (invit_info->token != dialogToken)
-						rtw_wdev_invit_info_init(invit_info);
-
-					_rtw_memcpy(invit_info->peer_mac, tx ? GetAddr1Ptr(buf) : GetAddr2Ptr(buf), ETH_ALEN);
-					invit_info->active = tx ? 1 : 0;
-					invit_info->token = dialogToken;
-					invit_info->flags = (flags==-1) ? 0x0 : flags;
-					invit_info->req_op_ch= op_ch;
-					invit_info->state = 0;
-
-					dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
-					DBG_871X("RTW_%s:P2P_INVIT_REQ, dialogToken=%d, flags:0x%02x, op_ch:%d, ch_list:%s\n",
-							(tx==_TRUE)?"Tx":"Rx", dialogToken, flags, op_ch, ch_list_buf);
-
-					if (!tx) {
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter , _FW_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
-							if (op_ch != -1 && rtw_chk_p2pie_op_ch_with_buddy(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
-								DBG_871X(FUNC_ADPT_FMT" op_ch:%u has no intersect with buddy\n", FUNC_ADPT_ARG(padapter), op_ch);
-								rtw_change_p2pie_ch_list(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr), 0);
-							} else if (rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
-								DBG_871X(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
-								rtw_change_p2pie_ch_list(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr), 0);
-							}
-						}
-						#endif
-					}
-
-					break;
+				break;
+			}
+			case P2P_INVIT_REQ: {
+				struct rtw_wdev_invit_info *invit_info = &pwdev_priv->invit_info;
+				int flags = -1;
+
+				if (tx) {
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED)
+					    && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+						rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
+					#endif
 				}
-				case P2P_INVIT_RESP:
-				{
-					struct rtw_wdev_invit_info* invit_info = &pwdev_priv->invit_info;
 
-					if (tx) {
-						#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
-						if (check_buddy_fwstate(padapter , _FW_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
-							rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len-sizeof(struct rtw_ieee80211_hdr_3addr));
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INVITATION_FLAGS, NULL, &cont_len);
+				if (cont)
+					flags = *cont;
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
+				if (cont)
+					op_ch = *(cont + 4);
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_BSSID, NULL, &cont_len);
+				if (cont && cont_len == 6)
+					gbssid = cont;
+
+				if (invit_info->token != dialogToken)
+					rtw_wdev_invit_info_init(invit_info);
+
+				_rtw_memcpy(invit_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN);
+				if (gbssid)
+					_rtw_memcpy(invit_info->group_bssid, gbssid, ETH_ALEN);
+				invit_info->active = tx ? 1 : 0;
+				invit_info->token = dialogToken;
+				invit_info->flags = (flags == -1) ? 0x0 : flags;
+				invit_info->req_op_ch = op_ch;
+				invit_info->state = 0;
+
+				dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
+				RTW_INFO("RTW_%s:P2P_INVIT_REQ, dialogToken=%d, flags:0x%02x, op_ch:%d, ch_list:%s"
+					, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, flags, op_ch, ch_list_buf);
+				if (gbssid)
+					_RTW_INFO(", gbssid:"MAC_FMT, MAC_ARG(gbssid));
+				_RTW_INFO("\n");
+
+				if (!tx) {
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+						#if defined(CONFIG_P2P_INVITE_IOT)
+						if (op_ch != -1 && rtw_chk_p2pie_op_ch_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
+							RTW_INFO(FUNC_ADPT_FMT" op_ch:%u has no intersect with buddy\n", FUNC_ADPT_ARG(padapter), op_ch);
+							rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
+						} else
 						#endif
-					}
-
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len)))
-					{
-#ifdef CONFIG_P2P_INVITE_IOT
-						if(tx && *cont==7)
-						{
-							DBG_871X("TX_P2P_INVITE_RESP, status is no common channel, change to unknown group\n");
-							*cont = 8; //unknow group status
+						if (rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
+							RTW_INFO(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
+							rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
 						}
-#endif //CONFIG_P2P_INVITE_IOT
-						status = *cont;
-					}	
-					if ((cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len)))
-						op_ch = *(cont+4);
-
-					if (invit_info->token == dialogToken && invit_info->state == 0
-						&& _rtw_memcmp(invit_info->peer_mac, tx ? GetAddr1Ptr(buf) : GetAddr2Ptr(buf), ETH_ALEN) == _TRUE
-					) {
-						invit_info->status = (status==-1) ? 0xff : status;
-						invit_info->rsp_op_ch= op_ch;
-						invit_info->state = 1;
-						invit_info->token = 0; /* init */
 					}
+					#endif
+				}
 
-					dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
-					DBG_871X("RTW_%s:P2P_INVIT_RESP, dialogToken=%d, status:%d, op_ch:%d, ch_list:%s\n",
-							(tx==_TRUE)?"Tx":"Rx", dialogToken, status, op_ch, ch_list_buf);
+				break;
+			}
+			case P2P_INVIT_RESP: {
+				struct rtw_wdev_invit_info *invit_info = &pwdev_priv->invit_info;
+
+				if (tx) {
+					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
+					if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
+						rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
+					#endif
+				}
 
-					if (!tx) {
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
+				if (cont) {
+					#ifdef CONFIG_P2P_INVITE_IOT
+					if (tx && *cont == 7) {
+						RTW_INFO("TX_P2P_INVITE_RESP, status is no common channel, change to unknown group\n");
+						*cont = 8; /* unknow group status */
 					}
+					#endif /* CONFIG_P2P_INVITE_IOT */
+					status = *cont;
+				}
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
+				if (cont)
+					op_ch = *(cont + 4);
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_BSSID, NULL, &cont_len);
+				if (cont && cont_len == 6)
+					gbssid = cont;
+
+				if (invit_info->token == dialogToken && invit_info->state == 0
+				    && _rtw_memcmp(invit_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN) == _TRUE
+				   ) {
+					invit_info->status = (status == -1) ? 0xff : status;
+					invit_info->rsp_op_ch = op_ch;
+					invit_info->state = 1;
+					invit_info->token = 0; /* init */
+				}
 
-					break;
+				dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
+				RTW_INFO("RTW_%s:P2P_INVIT_RESP, dialogToken=%d, status:%d, op_ch:%d, ch_list:%s"
+					, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, status, op_ch, ch_list_buf);
+				if (gbssid)
+					_RTW_INFO(", gbssid:"MAC_FMT, MAC_ARG(gbssid));
+				_RTW_INFO("\n");
+
+				if (!tx) {
 				}
-				case P2P_DEVDISC_REQ:
-					DBG_871X("RTW_%s:P2P_DEVDISC_REQ, dialogToken=%d\n", (tx==_TRUE)?"Tx":"Rx", dialogToken);
-					break;
-				case P2P_DEVDISC_RESP:
-					cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
-					DBG_871X("RTW_%s:P2P_DEVDISC_RESP, dialogToken=%d, status:%d\n", (tx==_TRUE)?"Tx":"Rx", dialogToken, cont?*cont:-1);
-					break;
-				case P2P_PROVISION_DISC_REQ:
+
+				break;
+			}
+			case P2P_DEVDISC_REQ:
+				RTW_INFO("RTW_%s:P2P_DEVDISC_REQ, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
+				break;
+			case P2P_DEVDISC_RESP:
+				cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
+				RTW_INFO("RTW_%s:P2P_DEVDISC_RESP, dialogToken=%d, status:%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken, cont ? *cont : -1);
+				break;
+			case P2P_PROVISION_DISC_REQ: {
+				size_t frame_body_len = len - sizeof(struct rtw_ieee80211_hdr_3addr);
+				u8 *p2p_ie;
+				uint p2p_ielen = 0;
+				uint contentlen = 0;
+
+				RTW_INFO("RTW_%s:P2P_PROVISION_DISC_REQ, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
+
+				/* if(tx) */
 				{
-					size_t frame_body_len = len - sizeof(struct rtw_ieee80211_hdr_3addr);
-					u8 *p2p_ie;
-					uint p2p_ielen = 0;
-					uint contentlen = 0;
-					
-					DBG_871X("RTW_%s:P2P_PROVISION_DISC_REQ, dialogToken=%d\n", (tx==_TRUE)?"Tx":"Rx", dialogToken);
-
-					//if(tx)
-					{
-						pwdev_priv->provdisc_req_issued = _FALSE;
-					
-						if( (p2p_ie=rtw_get_p2p_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen)))
-						{	
-
-							if(rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, NULL, &contentlen))
-							{
-								pwdev_priv->provdisc_req_issued = _FALSE;//case: p2p_client join p2p GO
-							}
-							else
-							{
-								#ifdef CONFIG_DEBUG_CFG80211
-								DBG_871X("provdisc_req_issued is _TRUE\n");
-								#endif //CONFIG_DEBUG_CFG80211
-								pwdev_priv->provdisc_req_issued = _TRUE;//case: p2p_devices connection before Nego req.
-							}
-												
-						}						
-					}				
-				}	
-					break;
-				case P2P_PROVISION_DISC_RESP:
-					DBG_871X("RTW_%s:P2P_PROVISION_DISC_RESP, dialogToken=%d\n", (tx==_TRUE)?"Tx":"Rx", dialogToken);
-					break;
-				default:
-					DBG_871X("RTW_%s:OUI_Subtype=%d, dialogToken=%d\n", (tx==_TRUE)?"Tx":"Rx", OUI_Subtype, dialogToken);
-					break;	
+					pwdev_priv->provdisc_req_issued = _FALSE;
+
+					p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
+					if (p2p_ie) {
+
+						if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, NULL, &contentlen)) {
+							pwdev_priv->provdisc_req_issued = _FALSE;/* case: p2p_client join p2p GO */
+						} else {
+							#ifdef CONFIG_DEBUG_CFG80211
+							RTW_INFO("provdisc_req_issued is _TRUE\n");
+							#endif /*CONFIG_DEBUG_CFG80211*/
+							pwdev_priv->provdisc_req_issued = _TRUE;/* case: p2p_devices connection before Nego req. */
+						}
+
+					}
+				}
+			}
+			break;
+			case P2P_PROVISION_DISC_RESP:
+				RTW_INFO("RTW_%s:P2P_PROVISION_DISC_RESP, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
+				break;
+			default:
+				RTW_INFO("RTW_%s:OUI_Subtype=%d, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", OUI_Subtype, dialogToken);
+				break;
 			}
 
 		}
-		
-	}	
-	else if(category == RTW_WLAN_CATEGORY_P2P)
-	{
+
+	} else if (category == RTW_WLAN_CATEGORY_P2P) {
 		OUI_Subtype = frame_body[5];
 		dialogToken = frame_body[6];
 
 		#ifdef CONFIG_DEBUG_CFG80211
-		DBG_871X("ACTION_CATEGORY_P2P: OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n",
-			cpu_to_be32( *( ( u32* ) ( frame_body + 1 ) ) ), OUI_Subtype, dialogToken);
+		RTW_INFO("ACTION_CATEGORY_P2P: OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n",
+			cpu_to_be32(*((u32 *)(frame_body + 1))), OUI_Subtype, dialogToken);
 		#endif
 
 		is_p2p_frame = OUI_Subtype;
 
-		switch(OUI_Subtype)
-		{
-			case P2P_NOTICE_OF_ABSENCE:
-				DBG_871X("RTW_%s:P2P_NOTICE_OF_ABSENCE, dialogToken=%d\n", (tx==_TRUE)?"TX":"RX", dialogToken);
-				break;			
-			case P2P_PRESENCE_REQUEST:
-				DBG_871X("RTW_%s:P2P_PRESENCE_REQUEST, dialogToken=%d\n", (tx==_TRUE)?"TX":"RX", dialogToken);
-				break;			
-			case P2P_PRESENCE_RESPONSE:
-				DBG_871X("RTW_%s:P2P_PRESENCE_RESPONSE, dialogToken=%d\n", (tx==_TRUE)?"TX":"RX", dialogToken);
-				break;			
-			case P2P_GO_DISC_REQUEST:
-				DBG_871X("RTW_%s:P2P_GO_DISC_REQUEST, dialogToken=%d\n", (tx==_TRUE)?"TX":"RX", dialogToken);
-				break;			
-			default:
-				DBG_871X("RTW_%s:OUI_Subtype=%d, dialogToken=%d\n", (tx==_TRUE)?"TX":"RX", OUI_Subtype, dialogToken);
-				break;			
-		}	
+		switch (OUI_Subtype) {
+		case P2P_NOTICE_OF_ABSENCE:
+			RTW_INFO("RTW_%s:P2P_NOTICE_OF_ABSENCE, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
+			break;
+		case P2P_PRESENCE_REQUEST:
+			RTW_INFO("RTW_%s:P2P_PRESENCE_REQUEST, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
+			break;
+		case P2P_PRESENCE_RESPONSE:
+			RTW_INFO("RTW_%s:P2P_PRESENCE_RESPONSE, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
+			break;
+		case P2P_GO_DISC_REQUEST:
+			RTW_INFO("RTW_%s:P2P_GO_DISC_REQUEST, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
+			break;
+		default:
+			RTW_INFO("RTW_%s:OUI_Subtype=%d, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", OUI_Subtype, dialogToken);
+			break;
+		}
 
-	}	
-	else
-	{
-		DBG_871X("RTW_%s:action frame category=%d\n", (tx==_TRUE)?"TX":"RX", category);
 	}
 
 	return is_p2p_frame;
 }
 
-void rtw_init_cfg80211_wifidirect_info( _adapter*	padapter)
+void rtw_init_cfg80211_wifidirect_info(_adapter	*padapter)
 {
 	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
 
-	_rtw_memset(pcfg80211_wdinfo, 0x00, sizeof(struct cfg80211_wifidirect_info) );
-    
-	_init_timer( &pcfg80211_wdinfo->remain_on_ch_timer, padapter->pnetdev, ro_ch_timer_process, padapter );
+	_rtw_memset(pcfg80211_wdinfo, 0x00, sizeof(struct cfg80211_wifidirect_info));
+
+	rtw_init_timer(&pcfg80211_wdinfo->remain_on_ch_timer, padapter, ro_ch_timer_process, padapter);
 }
-#endif //CONFIG_IOCTL_CFG80211	
+#endif /* CONFIG_IOCTL_CFG80211	 */
 
-void p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType)
+s32 p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType, u8 *buf)
 {
-	struct wifidirect_info	*pwdinfo= &(padapter->wdinfo);
-	
-_func_enter_;
+	int ret = H2C_SUCCESS;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-	switch(intCmdType)
-	{
-		case P2P_FIND_PHASE_WK:
-		{
-			find_phase_handler( padapter );
-			break;
-		}
-		case P2P_RESTORE_STATE_WK:
-		{
-			restore_p2p_state_handler( padapter );
-			break;
-		}
-		case P2P_PRE_TX_PROVDISC_PROCESS_WK:
-		{
+	switch (intCmdType) {
+	case P2P_FIND_PHASE_WK:
+		find_phase_handler(padapter);
+		break;
+
+	case P2P_RESTORE_STATE_WK:
+		restore_p2p_state_handler(padapter);
+		break;
+
+	case P2P_PRE_TX_PROVDISC_PROCESS_WK:
 #ifdef CONFIG_CONCURRENT_MODE
-			if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-			{
-				p2p_concurrent_handler( padapter );
-			}
-			else
-			{
-				pre_tx_provdisc_handler( padapter );
-			}
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			p2p_concurrent_handler(padapter);
+		else
+			pre_tx_provdisc_handler(padapter);
 #else
-			pre_tx_provdisc_handler( padapter );
+		pre_tx_provdisc_handler(padapter);
 #endif
-			break;
-		}
-		case P2P_PRE_TX_INVITEREQ_PROCESS_WK:
-		{
+		break;
+
+	case P2P_PRE_TX_INVITEREQ_PROCESS_WK:
 #ifdef CONFIG_CONCURRENT_MODE
-			if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-			{
-				p2p_concurrent_handler( padapter );
-			}
-			else
-			{
-				pre_tx_invitereq_handler( padapter );
-			}
-#else			
-			pre_tx_invitereq_handler( padapter );
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			p2p_concurrent_handler(padapter);
+		else
+			pre_tx_invitereq_handler(padapter);
+#else
+		pre_tx_invitereq_handler(padapter);
 #endif
-			break;
-		}
-		case P2P_PRE_TX_NEGOREQ_PROCESS_WK:
-		{
+		break;
+
+	case P2P_PRE_TX_NEGOREQ_PROCESS_WK:
 #ifdef CONFIG_CONCURRENT_MODE
-			if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-			{
-				p2p_concurrent_handler( padapter );
-			}
-			else
-			{
-				pre_tx_negoreq_handler( padapter );
-			}
-#else			
-			pre_tx_negoreq_handler( padapter );
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			p2p_concurrent_handler(padapter);
+		else
+			pre_tx_negoreq_handler(padapter);
+#else
+		pre_tx_negoreq_handler(padapter);
 #endif
-			break;
-		}
-#ifdef CONFIG_P2P
+		break;
+
 #ifdef CONFIG_CONCURRENT_MODE
-		case P2P_AP_P2P_CH_SWITCH_PROCESS_WK:
-		{
-			p2p_concurrent_handler( padapter );
-			break;
-		}		
-#endif
+	case P2P_AP_P2P_CH_SWITCH_PROCESS_WK:
+		p2p_concurrent_handler(padapter);
+		break;
 #endif
+
 #ifdef CONFIG_IOCTL_CFG80211
-		case P2P_RO_CH_WK:
-		{
-			ro_ch_handler( padapter );
-			break;
-		}		
-#endif //CONFIG_IOCTL_CFG80211		
+	case P2P_RO_CH_WK:
+		ret = ro_ch_handler(padapter, buf);
+		break;
+	case P2P_CANCEL_RO_CH_WK:
+		ret = cancel_ro_ch_handler(padapter, buf);
+		break;
+#endif
 
+	default:
+		rtw_warn_on(1);
+		break;
 	}
-	
-_func_exit_;
+
+	return ret;
 }
 
 int process_p2p_cross_connect_ie(PADAPTER padapter, u8 *IEs, u32 IELength)
 {
 	int ret = _TRUE;
-	u8 * ies;
+	u8 *ies;
 	u32 ies_len;
-	u8 * p2p_ie;
+	u8 *p2p_ie;
 	u32	p2p_ielen = 0;
-	u8	p2p_attr[MAX_P2P_IE_LEN] = { 0x00 };// NoA length should be n*(13) + 2
+	u8	p2p_attr[MAX_P2P_IE_LEN] = { 0x00 };/* NoA length should be n*(13) + 2 */
 	u32	attr_contentlen = 0;
 
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-_func_enter_;
 
-	if(IELength <= _BEACON_IE_OFFSET_)
+	if (IELength <= _BEACON_IE_OFFSET_)
 		return ret;
-	
+
 	ies = IEs + _BEACON_IE_OFFSET_;
 	ies_len = IELength - _BEACON_IE_OFFSET_;
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen);
-	
-	while(p2p_ie)
-	{
-		// Get P2P Manageability IE.
-		if(rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_MANAGEABILITY, p2p_attr, &attr_contentlen))
-		{
-			if ((p2p_attr[0]&(BIT(0)|BIT(1))) == 0x01) {
-				ret = _FALSE; 
-			}
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
+
+	while (p2p_ie) {
+		/* Get P2P Manageability IE. */
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_MANAGEABILITY, p2p_attr, &attr_contentlen)) {
+			if ((p2p_attr[0] & (BIT(0) | BIT(1))) == 0x01)
+				ret = _FALSE;
 			break;
 		}
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 
-_func_exit_;
 	return ret;
 }
 
 #ifdef CONFIG_P2P_PS
 void process_p2p_ps_ie(PADAPTER padapter, u8 *IEs, u32 IELength)
 {
-	u8 * ies;
+	u8 *ies;
 	u32 ies_len;
-	u8 * p2p_ie;
+	u8 *p2p_ie;
 	u32	p2p_ielen = 0;
-	u8	noa_attr[MAX_P2P_IE_LEN] = { 0x00 };// NoA length should be n*(13) + 2
+	u8	noa_attr[MAX_P2P_IE_LEN] = { 0x00 };/* NoA length should be n*(13) + 2 */
 	u32	attr_contentlen = 0;
-	
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	u8	find_p2p = _FALSE, find_p2p_ps = _FALSE;
 	u8	noa_offset, noa_num, noa_index;
 
-_func_enter_;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
-	}
 #ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->iface_type != IFACE_PORT0) 
+#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
+	if (padapter->hw_port != HW_PORT0)
 		return;
 #endif
-	if(IELength <= _BEACON_IE_OFFSET_)
+#endif
+	if (IELength <= _BEACON_IE_OFFSET_)
 		return;
-	
+
 	ies = IEs + _BEACON_IE_OFFSET_;
 	ies_len = IELength - _BEACON_IE_OFFSET_;
 
-	p2p_ie = rtw_get_p2p_ie( ies, ies_len, NULL, &p2p_ielen);
-	
-	while(p2p_ie)
-	{
+	p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
+
+	while (p2p_ie) {
 		find_p2p = _TRUE;
-		// Get Notice of Absence IE.
-		if(rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_NOA, noa_attr, &attr_contentlen))
-		{
+		/* Get Notice of Absence IE. */
+		if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_NOA, noa_attr, &attr_contentlen)) {
 			find_p2p_ps = _TRUE;
 			noa_index = noa_attr[0];
 
-			if( (pwdinfo->p2p_ps_mode == P2P_PS_NONE) ||
-				(noa_index != pwdinfo->noa_index) )// if index change, driver should reconfigure related setting.
-			{
+			if ((pwdinfo->p2p_ps_mode == P2P_PS_NONE) ||
+			    (noa_index != pwdinfo->noa_index)) { /* if index change, driver should reconfigure related setting. */
 				pwdinfo->noa_index = noa_index;
 				pwdinfo->opp_ps = noa_attr[1] >> 7;
 				pwdinfo->ctwindow = noa_attr[1] & 0x7F;
 
 				noa_offset = 2;
 				noa_num = 0;
-				// NoA length should be n*(13) + 2
-				if(attr_contentlen > 2)
-				{
-					while(noa_offset < attr_contentlen)
-					{
-						//_rtw_memcpy(&wifidirect_info->noa_count[noa_num], &noa_attr[noa_offset], 1);
+				/* NoA length should be n*(13) + 2 */
+				if (attr_contentlen > 2) {
+					while (noa_offset < attr_contentlen) {
+						/* _rtw_memcpy(&wifidirect_info->noa_count[noa_num], &noa_attr[noa_offset], 1); */
 						pwdinfo->noa_count[noa_num] = noa_attr[noa_offset];
 						noa_offset += 1;
 
@@ -4674,136 +4523,138 @@ _func_enter_;
 				}
 				pwdinfo->noa_num = noa_num;
 
-				if( pwdinfo->opp_ps == 1 )
-				{
+				if (pwdinfo->opp_ps == 1) {
 					pwdinfo->p2p_ps_mode = P2P_PS_CTWINDOW;
-					// driver should wait LPS for entering CTWindow
-					if(adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
-					{
+					/* driver should wait LPS for entering CTWindow */
+					if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
 						p2p_ps_wk_cmd(padapter, P2P_PS_ENABLE, 1);
-					}
-				}
-				else if( pwdinfo->noa_num > 0 )
-				{
+				} else if (pwdinfo->noa_num > 0) {
 					pwdinfo->p2p_ps_mode = P2P_PS_NOA;
 					p2p_ps_wk_cmd(padapter, P2P_PS_ENABLE, 1);
-				}
-				else if( pwdinfo->p2p_ps_mode > P2P_PS_NONE)
-				{
+				} else if (pwdinfo->p2p_ps_mode > P2P_PS_NONE)
 					p2p_ps_wk_cmd(padapter, P2P_PS_DISABLE, 1);
-				}
 			}
 
-			break; // find target, just break.
+			break; /* find target, just break. */
 		}
 
-		//Get the next P2P IE
-		p2p_ie = rtw_get_p2p_ie(p2p_ie+p2p_ielen, ies_len -(p2p_ie -ies + p2p_ielen), NULL, &p2p_ielen);
+		/* Get the next P2P IE */
+		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 
 	}
 
-	if(find_p2p == _TRUE)
-	{
-		if( (pwdinfo->p2p_ps_mode > P2P_PS_NONE) && (find_p2p_ps == _FALSE) )
-		{
+	if (find_p2p == _TRUE) {
+		if ((pwdinfo->p2p_ps_mode > P2P_PS_NONE) && (find_p2p_ps == _FALSE))
 			p2p_ps_wk_cmd(padapter, P2P_PS_DISABLE, 1);
-		}
 	}
 
-_func_exit_;
 }
 
 void p2p_ps_wk_hdl(_adapter *padapter, u8 p2p_ps_state)
 {
 	struct pwrctrl_priv		*pwrpriv = adapter_to_pwrctl(padapter);
-	struct wifidirect_info	*pwdinfo= &(padapter->wdinfo);
-	
-_func_enter_;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	u32 ps_deny = 0;
+
+	/* Pre action for p2p state */
+	switch (p2p_ps_state) {
+	case P2P_PS_DISABLE:
+		pwdinfo->p2p_ps_state = p2p_ps_state;
+
+		rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
+
+		pwdinfo->noa_index = 0;
+		pwdinfo->ctwindow = 0;
+		pwdinfo->opp_ps = 0;
+		pwdinfo->noa_num = 0;
+		pwdinfo->p2p_ps_mode = P2P_PS_NONE;
+		if (pwrpriv->bFwCurrentInPSMode == _TRUE) {
+			if (pwrpriv->smart_ps == 0) {
+				pwrpriv->smart_ps = 2;
+				rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&(pwrpriv->pwr_mode)));
+			}
+		}
+		break;
+	case P2P_PS_ENABLE:
+		_enter_pwrlock(&adapter_to_pwrctl(padapter)->lock);
+		ps_deny = rtw_ps_deny_get(padapter);
+		_exit_pwrlock(&adapter_to_pwrctl(padapter)->lock);
+
+		if ((ps_deny & (PS_DENY_SCAN | PS_DENY_JOIN))
+			|| rtw_mi_check_fwstate(padapter, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING))) {
+			pwdinfo->p2p_ps_mode = P2P_PS_NONE;
+			RTW_DBG(FUNC_ADPT_FMT" Block P2P PS under site survey or LINKING\n", FUNC_ADPT_ARG(padapter));
+			return;
+		}
+		if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
+#ifdef CONFIG_MCC_MODE
+			if (MCC_EN(padapter)) {
+				if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+					RTW_INFO("P2P PS enble under MCC\n");
+					rtw_warn_on(1);
+				}
 
-	// Pre action for p2p state
-	switch(p2p_ps_state)
-	{
-		case P2P_PS_DISABLE:
+			}
+#endif /* CONFIG_MCC_MODE */
 			pwdinfo->p2p_ps_state = p2p_ps_state;
-			
-			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
 
-			pwdinfo->noa_index = 0;
-			pwdinfo->ctwindow = 0;
-			pwdinfo->opp_ps = 0;
-			pwdinfo->noa_num = 0;
-			pwdinfo->p2p_ps_mode = P2P_PS_NONE;
-			if(pwrpriv->bFwCurrentInPSMode == _TRUE)
-			{
-				if(pwrpriv->smart_ps == 0)
-				{
-					pwrpriv->smart_ps = 2;
+			if (pwdinfo->ctwindow > 0) {
+				if (pwrpriv->smart_ps != 0) {
+					pwrpriv->smart_ps = 0;
+					RTW_INFO("%s(): Enter CTW, change SmartPS\n", __FUNCTION__);
 					rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&(pwrpriv->pwr_mode)));
 				}
 			}
-			break;
-		case P2P_PS_ENABLE:
-			if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
-				pwdinfo->p2p_ps_state = p2p_ps_state;
-				
-				if( pwdinfo->ctwindow > 0 )
-				{
-					if(pwrpriv->smart_ps != 0)
-					{
-						pwrpriv->smart_ps = 0;
-						DBG_871X("%s(): Enter CTW, change SmartPS\n", __FUNCTION__);
-						rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&(pwrpriv->pwr_mode)));
-					}
-				}
-				rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
-			}
-			break;
-		case P2P_PS_SCAN:
-		case P2P_PS_SCAN_DONE:
-		case P2P_PS_ALLSTASLEEP:
-			if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
-				pwdinfo->p2p_ps_state = p2p_ps_state;
-				rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
-			}
-			break;
-		default:
-			break;
+			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
+		}
+		break;
+	case P2P_PS_SCAN:
+	case P2P_PS_SCAN_DONE:
+	case P2P_PS_ALLSTASLEEP:
+		if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
+			pwdinfo->p2p_ps_state = p2p_ps_state;
+			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
+		}
+		break;
+	default:
+		break;
 	}
 
-_func_exit_;
+#ifdef CONFIG_MCC_MODE
+	rtw_hal_mcc_process_noa(padapter);
+#endif /* CONFIG_MCC_MODE */
 }
 
-u8 p2p_ps_wk_cmd(_adapter*padapter, u8 p2p_ps_state, u8 enqueue)
+u8 p2p_ps_wk_cmd(_adapter *padapter, u8 p2p_ps_state, u8 enqueue)
 {
 	struct cmd_obj	*ph2c;
 	struct drvextra_cmd_parm	*pdrvextra_cmd_parm;
-	struct wifidirect_info	*pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
 	u8	res = _SUCCESS;
-	
-_func_enter_;
 
-	if ( rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) 
+
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
 #ifdef CONFIG_CONCURRENT_MODE
-		|| (padapter->iface_type != IFACE_PORT0) 
+#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
+	    || (padapter->hw_port != HW_PORT0)
 #endif
-		)
-	{
+#endif
+	   )
 		return res;
-	}
 
-	if(enqueue)
-	{
-		ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj));	
-		if(ph2c==NULL){
-			res= _FAIL;
+	if (enqueue) {
+		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (ph2c == NULL) {
+			res = _FAIL;
 			goto exit;
 		}
-		
-		pdrvextra_cmd_parm = (struct drvextra_cmd_parm*)rtw_zmalloc(sizeof(struct drvextra_cmd_parm)); 
-		if(pdrvextra_cmd_parm==NULL){
+
+		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (pdrvextra_cmd_parm == NULL) {
 			rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-			res= _FAIL;
+			res = _FAIL;
 			goto exit;
 		}
 
@@ -4815,149 +4666,132 @@ _func_enter_;
 		init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
 
 		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	}
-	else
-	{
+	} else
 		p2p_ps_wk_hdl(padapter, p2p_ps_state);
-	}
-	
+
 exit:
-	
-_func_exit_;
+
 
 	return res;
 
 }
-#endif // CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
-static void reset_ch_sitesurvey_timer_process (void *FunctionContext)
+static void reset_ch_sitesurvey_timer_process(void *FunctionContext)
 {
 	_adapter *adapter = (_adapter *)FunctionContext;
 	struct	wifidirect_info		*pwdinfo = &adapter->wdinfo;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
 
-	DBG_871X( "[%s] In\n", __FUNCTION__ );
-	//	Reset the operation channel information
+	RTW_INFO("[%s] In\n", __FUNCTION__);
+	/*	Reset the operation channel information */
 	pwdinfo->rx_invitereq_info.operation_ch[0] = 0;
 #ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
 	pwdinfo->rx_invitereq_info.operation_ch[1] = 0;
 	pwdinfo->rx_invitereq_info.operation_ch[2] = 0;
 	pwdinfo->rx_invitereq_info.operation_ch[3] = 0;
-#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH 
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
 	pwdinfo->rx_invitereq_info.scan_op_ch_only = 0;
 }
 
-static void reset_ch_sitesurvey_timer_process2 (void *FunctionContext)
+static void reset_ch_sitesurvey_timer_process2(void *FunctionContext)
 {
 	_adapter *adapter = (_adapter *)FunctionContext;
 	struct	wifidirect_info		*pwdinfo = &adapter->wdinfo;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
 
-	DBG_871X( "[%s] In\n", __FUNCTION__ );
-	//	Reset the operation channel information
+	RTW_INFO("[%s] In\n", __FUNCTION__);
+	/*	Reset the operation channel information */
 	pwdinfo->p2p_info.operation_ch[0] = 0;
 #ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
 	pwdinfo->p2p_info.operation_ch[1] = 0;
 	pwdinfo->p2p_info.operation_ch[2] = 0;
 	pwdinfo->p2p_info.operation_ch[3] = 0;
-#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
 	pwdinfo->p2p_info.scan_op_ch_only = 0;
 }
 
-static void restore_p2p_state_timer_process (void *FunctionContext)
+static void restore_p2p_state_timer_process(void *FunctionContext)
 {
 	_adapter *adapter = (_adapter *)FunctionContext;
 	struct	wifidirect_info		*pwdinfo = &adapter->wdinfo;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		return; 
-	
-	p2p_protocol_wk_cmd( adapter, P2P_RESTORE_STATE_WK );
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+		return;
+
+	p2p_protocol_wk_cmd(adapter, P2P_RESTORE_STATE_WK);
 }
 
-static void pre_tx_scan_timer_process (void *FunctionContext)
+static void pre_tx_scan_timer_process(void *FunctionContext)
 {
-	_adapter 							*adapter = (_adapter *) FunctionContext;
+	_adapter							*adapter = (_adapter *) FunctionContext;
 	struct	wifidirect_info				*pwdinfo = &adapter->wdinfo;
 	_irqL							irqL;
 	struct mlme_priv					*pmlmepriv = &adapter->mlmepriv;
 	u8								_status = 0;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
-	
+
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ))
-	{
-		if ( _TRUE == pwdinfo->tx_prov_disc_info.benable )	//	the provision discovery request frame is trigger to send or not
-		{
-			p2p_protocol_wk_cmd( adapter, P2P_PRE_TX_PROVDISC_PROCESS_WK );			
-			//issue_probereq_p2p(adapter, NULL);
-			//_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-		}
-	}
-	else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING))
-	{
-		if ( _TRUE == pwdinfo->nego_req_info.benable )
-		{
-			p2p_protocol_wk_cmd( adapter, P2P_PRE_TX_NEGOREQ_PROCESS_WK );
-		}
-	}
-	else if ( rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ ) )
-	{
-		if ( _TRUE == pwdinfo->invitereq_info.benable )
-		{
-			p2p_protocol_wk_cmd( adapter, P2P_PRE_TX_INVITEREQ_PROCESS_WK );
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ)) {
+		if (_TRUE == pwdinfo->tx_prov_disc_info.benable) {	/*	the provision discovery request frame is trigger to send or not */
+			p2p_protocol_wk_cmd(adapter, P2P_PRE_TX_PROVDISC_PROCESS_WK);
+			/* issue_probereq_p2p(adapter, NULL); */
+			/* _set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT ); */
 		}
-	}
-	else
-	{
-		DBG_8192C( "[%s] p2p_state is %d, ignore!!\n", __FUNCTION__, rtw_p2p_state(pwdinfo) );
-	}
-	
+	} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING)) {
+		if (_TRUE == pwdinfo->nego_req_info.benable)
+			p2p_protocol_wk_cmd(adapter, P2P_PRE_TX_NEGOREQ_PROCESS_WK);
+	} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ)) {
+		if (_TRUE == pwdinfo->invitereq_info.benable)
+			p2p_protocol_wk_cmd(adapter, P2P_PRE_TX_INVITEREQ_PROCESS_WK);
+	} else
+		RTW_INFO("[%s] p2p_state is %d, ignore!!\n", __FUNCTION__, rtw_p2p_state(pwdinfo));
+
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 }
 
-static void find_phase_timer_process (void *FunctionContext)
+static void find_phase_timer_process(void *FunctionContext)
 {
 	_adapter *adapter = (_adapter *)FunctionContext;
 	struct	wifidirect_info		*pwdinfo = &adapter->wdinfo;
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
 
 	adapter->wdinfo.find_phase_state_exchange_cnt++;
 
-	p2p_protocol_wk_cmd( adapter, P2P_FIND_PHASE_WK );
+	p2p_protocol_wk_cmd(adapter, P2P_FIND_PHASE_WK);
 }
 
 #ifdef CONFIG_CONCURRENT_MODE
-void ap_p2p_switch_timer_process (void *FunctionContext)
+void ap_p2p_switch_timer_process(void *FunctionContext)
 {
 	_adapter *adapter = (_adapter *)FunctionContext;
 	struct	wifidirect_info		*pwdinfo = &adapter->wdinfo;
-#ifdef CONFIG_IOCTL_CFG80211	
+#ifdef CONFIG_IOCTL_CFG80211
 	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
 #endif
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
 
 #ifdef CONFIG_IOCTL_CFG80211
 	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
 #endif
 
-	p2p_protocol_wk_cmd( adapter, P2P_AP_P2P_CH_SWITCH_PROCESS_WK );
+	p2p_protocol_wk_cmd(adapter, P2P_AP_P2P_CH_SWITCH_PROCESS_WK);
 }
 #endif
 
-void reset_global_wifidirect_info( _adapter* padapter )
+void reset_global_wifidirect_info(_adapter *padapter)
 {
 	struct wifidirect_info	*pwdinfo;
 
@@ -4969,12 +4803,12 @@ void reset_global_wifidirect_info( _adapter* padapter )
 }
 
 #ifdef CONFIG_WFD
-int rtw_init_wifi_display_info(_adapter* padapter)
+int rtw_init_wifi_display_info(_adapter *padapter)
 {
 	int	res = _SUCCESS;
 	struct wifi_display_info *pwfd_info = &padapter->wfd_info;
 
-	// Used in P2P and TDLS
+	/* Used in P2P and TDLS */
 	pwfd_info->init_rtsp_ctrlport = 554;
 #ifdef CONFIG_IOCTL_CFG80211
 	pwfd_info->rtsp_ctrlport = 0;
@@ -4982,18 +4816,18 @@ int rtw_init_wifi_display_info(_adapter* padapter)
 	pwfd_info->rtsp_ctrlport = pwfd_info->init_rtsp_ctrlport; /* set non-zero value for legacy wfd */
 #endif
 	pwfd_info->tdls_rtsp_ctrlport = 0;
-	pwfd_info->peer_rtsp_ctrlport = 0;	//	Reset to 0
+	pwfd_info->peer_rtsp_ctrlport = 0;	/*	Reset to 0 */
 	pwfd_info->wfd_enable = _FALSE;
 	pwfd_info->wfd_device_type = WFD_DEVINFO_PSINK;
 	pwfd_info->scan_result_type = SCAN_RESULT_P2P_ONLY;
 
-	// Used in P2P
+	/* Used in P2P */
 	pwfd_info->peer_session_avail = _TRUE;
 	pwfd_info->wfd_pc = _FALSE;
 
-	// Used in TDLS
-	_rtw_memset( pwfd_info->ip_address, 0x00, 4 );
-	_rtw_memset( pwfd_info->peer_ip_address, 0x00, 4 );
+	/* Used in TDLS */
+	_rtw_memset(pwfd_info->ip_address, 0x00, 4);
+	_rtw_memset(pwfd_info->peer_ip_address, 0x00, 4);
 	return res;
 
 }
@@ -5179,149 +5013,132 @@ exit:
 
 #endif /* CONFIG_WFD */
 
-void rtw_init_wifidirect_timers(_adapter* padapter)
+void rtw_init_wifidirect_timers(_adapter *padapter)
 {
 	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
 
-	_init_timer( &pwdinfo->find_phase_timer, padapter->pnetdev, find_phase_timer_process, padapter );
-	_init_timer( &pwdinfo->restore_p2p_state_timer, padapter->pnetdev, restore_p2p_state_timer_process, padapter );
-	_init_timer( &pwdinfo->pre_tx_scan_timer, padapter->pnetdev, pre_tx_scan_timer_process, padapter );
-	_init_timer( &pwdinfo->reset_ch_sitesurvey, padapter->pnetdev, reset_ch_sitesurvey_timer_process, padapter );
-	_init_timer( &pwdinfo->reset_ch_sitesurvey2, padapter->pnetdev, reset_ch_sitesurvey_timer_process2, padapter );
+	rtw_init_timer(&pwdinfo->find_phase_timer, padapter, find_phase_timer_process, padapter);
+	rtw_init_timer(&pwdinfo->restore_p2p_state_timer, padapter, restore_p2p_state_timer_process, padapter);
+	rtw_init_timer(&pwdinfo->pre_tx_scan_timer, padapter, pre_tx_scan_timer_process, padapter);
+	rtw_init_timer(&pwdinfo->reset_ch_sitesurvey, padapter, reset_ch_sitesurvey_timer_process, padapter);
+	rtw_init_timer(&pwdinfo->reset_ch_sitesurvey2, padapter, reset_ch_sitesurvey_timer_process2, padapter);
 #ifdef CONFIG_CONCURRENT_MODE
-	_init_timer( &pwdinfo->ap_p2p_switch_timer, padapter->pnetdev, ap_p2p_switch_timer_process, padapter );
+	rtw_init_timer(&pwdinfo->ap_p2p_switch_timer, padapter, ap_p2p_switch_timer_process, padapter);
 #endif
 }
 
-void rtw_init_wifidirect_addrs(_adapter* padapter, u8 *dev_addr, u8 *iface_addr)
+void rtw_init_wifidirect_addrs(_adapter *padapter, u8 *dev_addr, u8 *iface_addr)
 {
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
 
 	/*init device&interface address */
-	if (dev_addr) {
+	if (dev_addr)
 		_rtw_memcpy(pwdinfo->device_addr, dev_addr, ETH_ALEN);
-	}
-	if (iface_addr) {
+	if (iface_addr)
 		_rtw_memcpy(pwdinfo->interface_addr, iface_addr, ETH_ALEN);
-	}
 #endif
 }
 
-void init_wifidirect_info( _adapter* padapter, enum P2P_ROLE role)
+void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role)
 {
 	struct wifidirect_info	*pwdinfo;
 #ifdef CONFIG_WFD
 	struct wifi_display_info	*pwfd_info = &padapter->wfd_info;
 #endif
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct wifidirect_info	*pbuddy_wdinfo = NULL;
-	struct mlme_priv		*pbuddy_mlmepriv = NULL;
-	struct mlme_ext_priv	*pbuddy_mlmeext = NULL;
-#endif
-
+	u8 union_ch = 0;
 	pwdinfo = &padapter->wdinfo;
 
 	pwdinfo->padapter = padapter;
-	
-	//	1, 6, 11 are the social channel defined in the WiFi Direct specification.
+
+	/*	1, 6, 11 are the social channel defined in the WiFi Direct specification. */
 	pwdinfo->social_chan[0] = 1;
 	pwdinfo->social_chan[1] = 6;
 	pwdinfo->social_chan[2] = 11;
-	pwdinfo->social_chan[3] = 0;	//	channel 0 for scanning ending in site survey function.
+	pwdinfo->social_chan[3] = 0;	/*	channel 0 for scanning ending in site survey function. */
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (pbuddy_adapter) {
-		pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-		pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-		pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-	}
+	if (role != P2P_ROLE_DISABLE
+		&& pwdinfo->driver_interface != DRIVER_CFG80211
+	) {
+		#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			union_ch = rtw_mi_get_union_chan(padapter);
 
-	if ( ( check_buddy_fwstate(padapter, _FW_LINKED ) == _TRUE ) && 
-	      ( ( pbuddy_mlmeext->cur_channel == 1) || ( pbuddy_mlmeext->cur_channel == 6 ) || ( pbuddy_mlmeext->cur_channel == 11 ) )
-	   )
-	{
-		//	Use the AP's channel as the listen channel
-		//	This will avoid the channel switch between AP's channel and listen channel.
-		pwdinfo->listen_channel = pbuddy_mlmeext->cur_channel;
-	}
-	else
-#endif //CONFIG_CONCURRENT_MODE
-	{
-		//	Use the channel 11 as the listen channel
-		pwdinfo->listen_channel = 11;
+		if (union_ch != 0 &&
+			(union_ch == 1 || union_ch == 6 || union_ch == 11)
+		) {
+			/* Use the AP's channel as the listen channel */
+			/* This will avoid the channel switch between AP's channel and listen channel */
+			pwdinfo->listen_channel = union_ch;
+		} else
+		#endif /* CONFIG_CONCURRENT_MODE */
+		{
+			/* Use the channel 11 as the listen channel */
+			pwdinfo->listen_channel = 11;
+		}
 	}
 
-	if (role == P2P_ROLE_DEVICE)
-	{
+	if (role == P2P_ROLE_DEVICE) {
 		rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-		#ifdef CONFIG_CONCURRENT_MODE
-		if ( check_buddy_fwstate(padapter, _FW_LINKED ) == _TRUE )
-		{
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
 			rtw_p2p_set_state(pwdinfo, P2P_STATE_IDLE);
-		}
 		else
-		#endif
-		{
+#endif
 			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
-		}
+
 		pwdinfo->intent = 1;
 		rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_LISTEN);
-	}
-	else if (role == P2P_ROLE_CLIENT)
-	{
+	} else if (role == P2P_ROLE_CLIENT) {
 		rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
 		pwdinfo->intent = 1;
 		rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
-	}	
-	else if (role == P2P_ROLE_GO)
-	{
+	} else if (role == P2P_ROLE_GO) {
 		rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
 		pwdinfo->intent = 15;
 		rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
 	}
 
-//	Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 )	
-	pwdinfo->support_rate[0] = 0x8c;	//	6(B)
-	pwdinfo->support_rate[1] = 0x92;	//	9(B)
-	pwdinfo->support_rate[2] = 0x18;	//	12
-	pwdinfo->support_rate[3] = 0x24;	//	18
-	pwdinfo->support_rate[4] = 0x30;	//	24
-	pwdinfo->support_rate[5] = 0x48;	//	36
-	pwdinfo->support_rate[6] = 0x60;	//	48
-	pwdinfo->support_rate[7] = 0x6c;	//	54
+	/*	Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 )	 */
+	pwdinfo->support_rate[0] = 0x8c;	/*	6(B) */
+	pwdinfo->support_rate[1] = 0x92;	/*	9(B) */
+	pwdinfo->support_rate[2] = 0x18;	/*	12 */
+	pwdinfo->support_rate[3] = 0x24;	/*	18 */
+	pwdinfo->support_rate[4] = 0x30;	/*	24 */
+	pwdinfo->support_rate[5] = 0x48;	/*	36 */
+	pwdinfo->support_rate[6] = 0x60;	/*	48 */
+	pwdinfo->support_rate[7] = 0x6c;	/*	54 */
 
-	_rtw_memcpy( ( void* ) pwdinfo->p2p_wildcard_ssid, "DIRECT-", 7 );
+	_rtw_memcpy((void *) pwdinfo->p2p_wildcard_ssid, "DIRECT-", 7);
 
-	_rtw_memset( pwdinfo->device_name, 0x00, WPS_MAX_DEVICE_NAME_LEN );
+	_rtw_memset(pwdinfo->device_name, 0x00, WPS_MAX_DEVICE_NAME_LEN);
 	pwdinfo->device_name_len = 0;
 
-	_rtw_memset( &pwdinfo->invitereq_info, 0x00, sizeof( struct tx_invite_req_info ) );
-	pwdinfo->invitereq_info.token = 3;	//	Token used for P2P invitation request frame.
-	
-	_rtw_memset( &pwdinfo->inviteresp_info, 0x00, sizeof( struct tx_invite_resp_info ) );
+	_rtw_memset(&pwdinfo->invitereq_info, 0x00, sizeof(struct tx_invite_req_info));
+	pwdinfo->invitereq_info.token = 3;	/*	Token used for P2P invitation request frame. */
+
+	_rtw_memset(&pwdinfo->inviteresp_info, 0x00, sizeof(struct tx_invite_resp_info));
 	pwdinfo->inviteresp_info.token = 0;
 
 	pwdinfo->profileindex = 0;
-	_rtw_memset( &pwdinfo->profileinfo[ 0 ], 0x00, sizeof( struct profile_info ) * P2P_MAX_PERSISTENT_GROUP_NUM );
+	_rtw_memset(&pwdinfo->profileinfo[0], 0x00, sizeof(struct profile_info) * P2P_MAX_PERSISTENT_GROUP_NUM);
 
 	rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
 
-	pwdinfo->listen_dwell = ( u8 ) (( rtw_get_current_time() % 3 ) + 1);
-	//DBG_8192C( "[%s] listen_dwell time is %d00ms\n", __FUNCTION__, pwdinfo->listen_dwell );
+	pwdinfo->listen_dwell = (u8)((rtw_get_current_time() % 3) + 1);
+	/* RTW_INFO( "[%s] listen_dwell time is %d00ms\n", __FUNCTION__, pwdinfo->listen_dwell ); */
 
-	_rtw_memset( &pwdinfo->tx_prov_disc_info, 0x00, sizeof( struct tx_provdisc_req_info ) );
+	_rtw_memset(&pwdinfo->tx_prov_disc_info, 0x00, sizeof(struct tx_provdisc_req_info));
 	pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_NONE;
 
-	_rtw_memset( &pwdinfo->nego_req_info, 0x00, sizeof( struct tx_nego_req_info ) );
+	_rtw_memset(&pwdinfo->nego_req_info, 0x00, sizeof(struct tx_nego_req_info));
 
 	pwdinfo->device_password_id_for_nego = WPS_DPID_PBC;
 	pwdinfo->negotiation_dialog_token = 1;
 
-	_rtw_memset( pwdinfo->nego_ssid, 0x00, WLAN_SSID_MAXLEN );
+	_rtw_memset(pwdinfo->nego_ssid, 0x00, WLAN_SSID_MAXLEN);
 	pwdinfo->nego_ssidlen = 0;
 
 	pwdinfo->ui_got_wps_info = P2P_NO_WPSINFO;
@@ -5330,52 +5147,52 @@ void init_wifidirect_info( _adapter* padapter, enum P2P_ROLE role)
 	pwdinfo->wfd_info = pwfd_info;
 #else
 	pwdinfo->supported_wps_cm = WPS_CONFIG_METHOD_DISPLAY | WPS_CONFIG_METHOD_PBC | WPS_CONFIG_METHOD_KEYPAD;
-#endif //CONFIG_WFD
+#endif /* CONFIG_WFD */
 	pwdinfo->channel_list_attr_len = 0;
-	_rtw_memset( pwdinfo->channel_list_attr, 0x00, 100 );
+	_rtw_memset(pwdinfo->channel_list_attr, 0x00, 100);
 
-	_rtw_memset( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, 0x00, 4 );
-	_rtw_memset( pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, '0', 3 );
-	_rtw_memset( &pwdinfo->groupid_info, 0x00, sizeof( struct group_id_info ) );
+	_rtw_memset(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, 0x00, 4);
+	_rtw_memset(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, '0', 3);
+	_rtw_memset(&pwdinfo->groupid_info, 0x00, sizeof(struct group_id_info));
 #ifdef CONFIG_CONCURRENT_MODE
 #ifdef CONFIG_IOCTL_CFG80211
-	pwdinfo->ext_listen_interval = 1000; //The interval to be available with legacy AP during p2p0-find/scan
-	pwdinfo->ext_listen_period = 3000; //The time period to be available for P2P during nego
-#else //!CONFIG_IOCTL_CFG80211
-	//pwdinfo->ext_listen_interval = 3000;
-	//pwdinfo->ext_listen_period = 400;
+	pwdinfo->ext_listen_interval = 1000; /* The interval to be available with legacy AP during p2p0-find/scan */
+	pwdinfo->ext_listen_period = 3000; /* The time period to be available for P2P during nego */
+#else /* !CONFIG_IOCTL_CFG80211 */
+	/* pwdinfo->ext_listen_interval = 3000; */
+	/* pwdinfo->ext_listen_period = 400; */
 	pwdinfo->ext_listen_interval = 1000;
 	pwdinfo->ext_listen_period = 1000;
-#endif //!CONFIG_IOCTL_CFG80211
+#endif /* !CONFIG_IOCTL_CFG80211 */
 #endif
 
-// Commented by Kurt 20130319
-// For WiDi purpose: Use CFG80211 interface but controled WFD/RDS frame by driver itself.
+	/* Commented by Kurt 20130319
+	 * For WiDi purpose: Use CFG80211 interface but controled WFD/RDS frame by driver itself. */
 #ifdef CONFIG_IOCTL_CFG80211
 	pwdinfo->driver_interface = DRIVER_CFG80211;
 #else
 	pwdinfo->driver_interface = DRIVER_WEXT;
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 	pwdinfo->wfd_tdls_enable = 0;
-	_rtw_memset( pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN );
-	_rtw_memset( pwdinfo->p2p_peer_device_addr, 0x00, ETH_ALEN );
+	_rtw_memset(pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN);
+	_rtw_memset(pwdinfo->p2p_peer_device_addr, 0x00, ETH_ALEN);
 
 	pwdinfo->rx_invitereq_info.operation_ch[0] = 0;
-	pwdinfo->rx_invitereq_info.operation_ch[1] = 0;	//	Used to indicate the scan end in site survey function
+	pwdinfo->rx_invitereq_info.operation_ch[1] = 0;	/*	Used to indicate the scan end in site survey function */
 #ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
 	pwdinfo->rx_invitereq_info.operation_ch[2] = 0;
 	pwdinfo->rx_invitereq_info.operation_ch[3] = 0;
 	pwdinfo->rx_invitereq_info.operation_ch[4] = 0;
-#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
 	pwdinfo->rx_invitereq_info.scan_op_ch_only = 0;
 	pwdinfo->p2p_info.operation_ch[0] = 0;
-	pwdinfo->p2p_info.operation_ch[1] = 0;			//	Used to indicate the scan end in site survey function
+	pwdinfo->p2p_info.operation_ch[1] = 0;			/*	Used to indicate the scan end in site survey function */
 #ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
 	pwdinfo->p2p_info.operation_ch[2] = 0;
 	pwdinfo->p2p_info.operation_ch[3] = 0;
 	pwdinfo->p2p_info.operation_ch[4] = 0;
-#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
 	pwdinfo->p2p_info.scan_op_ch_only = 0;
 }
 
@@ -5386,7 +5203,7 @@ void init_wifidirect_info( _adapter* padapter, enum P2P_ROLE role)
  * @role: P2P role
  * Returns: The state name as a printable text string
  */
-const char * rtw_p2p_role_txt(enum P2P_ROLE role)
+const char *rtw_p2p_role_txt(enum P2P_ROLE role)
 {
 	switch (role) {
 	case P2P_ROLE_DISABLE:
@@ -5407,7 +5224,7 @@ const char * rtw_p2p_role_txt(enum P2P_ROLE role)
  * @state: P2P state
  * Returns: The state name as a printable text string
  */
-const char * rtw_p2p_state_txt(enum P2P_STATE state)
+const char *rtw_p2p_state_txt(enum P2P_STATE state)
 {
 	switch (state) {
 	case P2P_STATE_NONE:
@@ -5463,174 +5280,176 @@ const char * rtw_p2p_state_txt(enum P2P_STATE state)
 
 void dbg_rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line)
 {
-	if(!_rtw_p2p_chk_state(wdinfo, state)) {
+	if (!_rtw_p2p_chk_state(wdinfo, state)) {
 		enum P2P_STATE old_state = _rtw_p2p_state(wdinfo);
 		_rtw_p2p_set_state(wdinfo, state);
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d set_state from %s to %s\n", caller, line
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_state from %s to %s\n", caller, line
 			, rtw_p2p_state_txt(old_state), rtw_p2p_state_txt(_rtw_p2p_state(wdinfo))
-		);
+			);
 	} else {
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d set_state to same state %s\n", caller, line
-			, rtw_p2p_state_txt(_rtw_p2p_state(wdinfo))
-		);
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_state to same state %s\n", caller, line
+			 , rtw_p2p_state_txt(_rtw_p2p_state(wdinfo))
+			);
 	}
 }
 void dbg_rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line)
 {
-	if(_rtw_p2p_pre_state(wdinfo) != state) {
-		enum P2P_STATE old_state = _rtw_p2p_pre_state(wdinfo); 
+	if (_rtw_p2p_pre_state(wdinfo) != state) {
+		enum P2P_STATE old_state = _rtw_p2p_pre_state(wdinfo);
 		_rtw_p2p_set_pre_state(wdinfo, state);
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d set_pre_state from %s to %s\n", caller, line
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_pre_state from %s to %s\n", caller, line
 			, rtw_p2p_state_txt(old_state), rtw_p2p_state_txt(_rtw_p2p_pre_state(wdinfo))
-		);
+			);
 	} else {
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d set_pre_state to same state %s\n", caller, line
-			, rtw_p2p_state_txt(_rtw_p2p_pre_state(wdinfo))
-		);
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_pre_state to same state %s\n", caller, line
+			 , rtw_p2p_state_txt(_rtw_p2p_pre_state(wdinfo))
+			);
 	}
 }
 #if 0
 void dbg_rtw_p2p_restore_state(struct wifidirect_info *wdinfo, const char *caller, int line)
 {
-	if(wdinfo->pre_p2p_state != -1) {
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d restore from %s to %s\n", caller, line
+	if (wdinfo->pre_p2p_state != -1) {
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d restore from %s to %s\n", caller, line
 			, p2p_state_str[wdinfo->p2p_state], p2p_state_str[wdinfo->pre_p2p_state]
-		);
+			);
 		_rtw_p2p_restore_state(wdinfo);
 	} else {
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d restore no pre state, cur state %s\n", caller, line
-			, p2p_state_str[wdinfo->p2p_state]
-		);		
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d restore no pre state, cur state %s\n", caller, line
+			 , p2p_state_str[wdinfo->p2p_state]
+			);
 	}
 }
 #endif
 void dbg_rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role, const char *caller, int line)
 {
-	if(wdinfo->role != role) {
+	if (wdinfo->role != role) {
 		enum P2P_ROLE old_role = wdinfo->role;
 		_rtw_p2p_set_role(wdinfo, role);
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d set_role from %s to %s\n", caller, line
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_role from %s to %s\n", caller, line
 			, rtw_p2p_role_txt(old_role), rtw_p2p_role_txt(wdinfo->role)
-		);
+			);
 	} else {
-		DBG_871X("[CONFIG_DBG_P2P]%s:%d set_role to same role %s\n", caller, line
-			, rtw_p2p_role_txt(wdinfo->role)
-		);
+		RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_role to same role %s\n", caller, line
+			 , rtw_p2p_role_txt(wdinfo->role)
+			);
 	}
 }
-#endif //CONFIG_DBG_P2P
+#endif /* CONFIG_DBG_P2P */
 
 
 int rtw_p2p_enable(_adapter *padapter, enum P2P_ROLE role)
 {
 	int ret = _SUCCESS;
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 
-	if (role == P2P_ROLE_DEVICE || role == P2P_ROLE_CLIENT|| role == P2P_ROLE_GO)
-	{
+	if (role == P2P_ROLE_DEVICE || role == P2P_ROLE_CLIENT || role == P2P_ROLE_GO) {
 		u8 channel, ch_offset;
 		u16 bwmode;
 
-#ifdef CONFIG_CONCURRENT_MODE
-		_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-		struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-		//	Commented by Albert 2011/12/30
-		//	The driver just supports 1 P2P group operation.
-		//	So, this function will do nothing if the buddy adapter had enabled the P2P function.
-		if(!rtw_p2p_chk_state(pbuddy_wdinfo, P2P_STATE_NONE))
-		{
-			//	The buddy adapter had enabled the P2P function.
+#if defined(CONFIG_CONCURRENT_MODE) && (!defined(RTW_P2P_GROUP_INTERFACE) || !RTW_P2P_GROUP_INTERFACE)
+		/*	Commented by Albert 2011/12/30 */
+		/*	The driver just supports 1 P2P group operation. */
+		/*	So, this function will do nothing if the buddy adapter had enabled the P2P function. */
+		/*if(!rtw_p2p_chk_state(pbuddy_wdinfo, P2P_STATE_NONE))
+			return ret;*/
+		/*The buddy adapter had enabled the P2P function.*/
+		if (rtw_mi_buddy_stay_in_p2p_mode(padapter))
 			return ret;
-		}
-#endif //CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_CONCURRENT_MODE */
 
-		//leave IPS/Autosuspend
+		/* leave IPS/Autosuspend */
 		if (_FAIL == rtw_pwr_wakeup(padapter)) {
 			ret = _FAIL;
 			goto exit;
 		}
 
-		//	Added by Albert 2011/03/22
-		//	In the P2P mode, the driver should not support the b mode.
-		//	So, the Tx packet shouldn't use the CCK rate
-		update_tx_basic_rate(padapter, WIRELESS_11AGN);
+		/*	Added by Albert 2011/03/22 */
+		/*	In the P2P mode, the driver should not support the b mode. */
+		/*	So, the Tx packet shouldn't use the CCK rate */
+		#ifdef CONFIG_IOCTL_CFG80211
+		if (rtw_cfg80211_iface_has_p2p_group_cap(padapter))
+		#endif
+			update_tx_basic_rate(padapter, WIRELESS_11AGN);
 
-		//Enable P2P function
+		/* Enable P2P function */
 		init_wifidirect_info(padapter, role);
-				
-		rtw_hal_set_odm_var(padapter,HAL_ODM_P2P_STATE,NULL,_TRUE);
-		#ifdef CONFIG_WFD
+
+		#ifdef CONFIG_IOCTL_CFG80211
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
+			adapter_wdev_data(padapter)->p2p_enabled = _TRUE;
+		#endif
+
+		rtw_hal_set_odm_var(padapter, HAL_ODM_P2P_STATE, NULL, _TRUE);
+#ifdef CONFIG_WFD
 		if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 			rtw_hal_set_odm_var(padapter, HAL_ODM_WIFI_DISPLAY_STATE, NULL, _TRUE);
-		#endif
-		
-	}
-	else if (role == P2P_ROLE_DISABLE)
-	{
+#endif
+
+	} else if (role == P2P_ROLE_DISABLE) {
 #ifdef CONFIG_INTEL_WIDI
-		if( padapter->mlmepriv.p2p_reject_disable == _TRUE )
+		if (padapter->mlmepriv.p2p_reject_disable == _TRUE)
 			return ret;
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-#ifdef CONFIG_IOCTL_CFG80211
-		if( padapter->wdinfo.driver_interface == DRIVER_CFG80211 )
+		#ifdef CONFIG_IOCTL_CFG80211
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
 			adapter_wdev_data(padapter)->p2p_enabled = _FALSE;
-#endif //CONFIG_IOCTL_CFG80211
-
+		#endif
 
-		//Disable P2P function
-		if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		{
-			_cancel_timer_ex( &pwdinfo->find_phase_timer );
-			_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
-			_cancel_timer_ex( &pwdinfo->pre_tx_scan_timer);
-			_cancel_timer_ex( &pwdinfo->reset_ch_sitesurvey);
-			_cancel_timer_ex( &pwdinfo->reset_ch_sitesurvey2);
-			reset_ch_sitesurvey_timer_process( padapter );
-			reset_ch_sitesurvey_timer_process2( padapter );
-			#ifdef CONFIG_CONCURRENT_MODE			
-			_cancel_timer_ex( &pwdinfo->ap_p2p_switch_timer);
-			#endif
+		pwdinfo->listen_channel = 0;
+
+		/* Disable P2P function */
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			_cancel_timer_ex(&pwdinfo->find_phase_timer);
+			_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+			_cancel_timer_ex(&pwdinfo->pre_tx_scan_timer);
+			_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
+			_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey2);
+			reset_ch_sitesurvey_timer_process(padapter);
+			reset_ch_sitesurvey_timer_process2(padapter);
+#ifdef CONFIG_CONCURRENT_MODE
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif
 			rtw_p2p_set_state(pwdinfo, P2P_STATE_NONE);
 			rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_NONE);
 			rtw_p2p_set_role(pwdinfo, P2P_ROLE_DISABLE);
 			_rtw_memset(&pwdinfo->rx_prov_disc_info, 0x00, sizeof(struct rx_provdisc_req_info));
 
 			/* Remove profiles in wifidirect_info structure. */
-			_rtw_memset( &pwdinfo->profileinfo[ 0 ], 0x00, sizeof( struct profile_info ) * P2P_MAX_PERSISTENT_GROUP_NUM );
+			_rtw_memset(&pwdinfo->profileinfo[0], 0x00, sizeof(struct profile_info) * P2P_MAX_PERSISTENT_GROUP_NUM);
 			pwdinfo->profileindex = 0;
 		}
 
-		rtw_hal_set_odm_var(padapter,HAL_ODM_P2P_STATE,NULL,_FALSE);
-		#ifdef CONFIG_WFD
+		rtw_hal_set_odm_var(padapter, HAL_ODM_P2P_STATE, NULL, _FALSE);
+#ifdef CONFIG_WFD
 		if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
 			rtw_hal_set_odm_var(padapter, HAL_ODM_WIFI_DISPLAY_STATE, NULL, _FALSE);
-		#endif
+#endif
 
 		if (_FAIL == rtw_pwr_wakeup(padapter)) {
 			ret = _FAIL;
 			goto exit;
 		}
 
-		//Restore to initial setting.
+		/* Restore to initial setting. */
 		update_tx_basic_rate(padapter, padapter->registrypriv.wireless_mode);
 
 #ifdef CONFIG_INTEL_WIDI
 		rtw_reset_widi_info(padapter);
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-		//For WiDi purpose.
+		/* For WiDi purpose. */
 #ifdef CONFIG_IOCTL_CFG80211
 		pwdinfo->driver_interface = DRIVER_CFG80211;
 #else
 		pwdinfo->driver_interface = DRIVER_WEXT;
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 	}
-	
-exit:	
+
+exit:
 	return ret;
 }
 
-#endif //CONFIG_P2P
-
+#endif /* CONFIG_P2P */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_pwrctrl.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_pwrctrl.c
index 2f0b7000c3b0..bb758aed346d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_pwrctrl.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_pwrctrl.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_PWRCTRL_C_
 
 #include <drv_types.h>
@@ -27,41 +23,40 @@ int rtw_fw_ps_state(PADAPTER padapter)
 {
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-	int ret=_FAIL, dont_care=0;
-	u16 fw_ps_state=0;
+	int ret = _FAIL, dont_care = 0;
+	u16 fw_ps_state = 0;
 	u32 start_time;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct registry_priv  *registry_par = &padapter->registrypriv;
-	
-	if(registry_par->check_fw_ps != 1)
+
+	if (registry_par->check_fw_ps != 1)
 		return _SUCCESS;
-	
+
 	_enter_pwrlock(&pwrpriv->check_32k_lock);
-	
+
 	if (RTW_CANNOT_RUN(padapter)) {
-		DBG_871X("%s: bSurpriseRemoved=%s , hw_init_completed=%d, bDriverStopped=%s\n", __func__
-			, rtw_is_surprise_removed(padapter)?"True":"False"
-			, rtw_get_hw_init_completed(padapter)
-			, rtw_is_drv_stopped(padapter)?"True":"False");
+		RTW_INFO("%s: bSurpriseRemoved=%s , hw_init_completed=%d, bDriverStopped=%s\n", __func__
+			 , rtw_is_surprise_removed(padapter) ? "True" : "False"
+			 , rtw_get_hw_init_completed(padapter)
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False");
 		goto exit_fw_ps_state;
 	}
 	rtw_hal_set_hwreg(padapter, HW_VAR_SET_REQ_FW_PS, (u8 *)&dont_care);
 	{
-		//4. if 0x88[7]=1, driver set cmd to leave LPS/IPS. 
-		//Else, hw will keep in active mode.
-		//debug info:
-		//0x88[7] = 32kpermission, 
-		//0x88[6:0] = current_ps_state
-		//0x89[7:0] = last_rpwm
+		/* 4. if 0x88[7]=1, driver set cmd to leave LPS/IPS. */
+		/* Else, hw will keep in active mode. */
+		/* debug info: */
+		/* 0x88[7] = 32kpermission, */
+		/* 0x88[6:0] = current_ps_state */
+		/* 0x89[7:0] = last_rpwm */
 
 		rtw_hal_get_hwreg(padapter, HW_VAR_FW_PS_STATE, (u8 *)&fw_ps_state);
-		
-		if((fw_ps_state & 0x80) == 0)
-			ret=_SUCCESS;
-		else
-		{
+
+		if ((fw_ps_state & 0x80) == 0)
+			ret = _SUCCESS;
+		else {
 			pdbgpriv->dbg_poll_fail_cnt++;
-			DBG_871X("%s: fw_ps_state=%04x \n", __FUNCTION__, fw_ps_state);
+			RTW_INFO("%s: fw_ps_state=%04x\n", __FUNCTION__, fw_ps_state);
 		}
 	}
 
@@ -72,65 +67,72 @@ exit_fw_ps_state:
 }
 
 #ifdef CONFIG_IPS
-void _ips_enter(_adapter * padapter)
+void _ips_enter(_adapter *padapter)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 
-	pwrpriv->bips_processing = _TRUE;	
+	pwrpriv->bips_processing = _TRUE;
 
-	// syn ips_mode with request
+	/* syn ips_mode with request */
 	pwrpriv->ips_mode = pwrpriv->ips_mode_req;
-	
-	pwrpriv->ips_enter_cnts++;	
-	DBG_871X("==>ips_enter cnts:%d\n",pwrpriv->ips_enter_cnts);
 
-	if(rf_off == pwrpriv->change_rfpwrstate )
-	{	
+	pwrpriv->ips_enter_cnts++;
+	RTW_INFO("==>ips_enter cnts:%d\n", pwrpriv->ips_enter_cnts);
+
+	if (rf_off == pwrpriv->change_rfpwrstate) {
 		pwrpriv->bpower_saving = _TRUE;
-		DBG_871X_LEVEL(_drv_always_, "nolinked power save enter\n");
+		RTW_PRINT("nolinked power save enter\n");
 
-		if(pwrpriv->ips_mode == IPS_LEVEL_2)
+		if (pwrpriv->ips_mode == IPS_LEVEL_2)
 			pwrpriv->bkeepfwalive = _TRUE;
-		
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS		
+		pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 		rtw_ips_pwr_down(padapter);
 		pwrpriv->rf_pwrstate = rf_off;
-	}	
-	pwrpriv->bips_processing = _FALSE;	
-	
+	}
+	pwrpriv->bips_processing = _FALSE;
+
 }
 
-void ips_enter(_adapter * padapter)
+void ips_enter(_adapter *padapter)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 
 
 #ifdef CONFIG_BT_COEXIST
 	rtw_btcoex_IpsNotify(padapter, pwrpriv->ips_mode_req);
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 	_enter_pwrlock(&pwrpriv->lock);
 	_ips_enter(padapter);
 	_exit_pwrlock(&pwrpriv->lock);
 }
 
-int _ips_leave(_adapter * padapter)
+int _ips_leave(_adapter *padapter)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	int result = _SUCCESS;
 
-	if((pwrpriv->rf_pwrstate == rf_off) &&(!pwrpriv->bips_processing))
-	{
+	if ((pwrpriv->rf_pwrstate == rf_off) && (!pwrpriv->bips_processing)) {
 		pwrpriv->bips_processing = _TRUE;
 		pwrpriv->change_rfpwrstate = rf_on;
 		pwrpriv->ips_leave_cnts++;
-		DBG_871X("==>ips_leave cnts:%d\n",pwrpriv->ips_leave_cnts);
+		RTW_INFO("==>ips_leave cnts:%d\n", pwrpriv->ips_leave_cnts);
 
-		if ((result = rtw_ips_pwr_up(padapter)) == _SUCCESS) {
+		result = rtw_ips_pwr_up(padapter);
+		if (result == _SUCCESS)
 			pwrpriv->rf_pwrstate = rf_on;
-		}
-		DBG_871X_LEVEL(_drv_always_, "nolinked power save leave\n");
 		
-		DBG_871X("==> ips_leave.....LED(0x%08x)...\n",rtw_read32(padapter,0x4c));
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS	
+		pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+		RTW_PRINT("nolinked power save leave\n");
+
+		RTW_INFO("==> ips_leave.....LED(0x%08x)...\n", rtw_read32(padapter, 0x4c));
 		pwrpriv->bips_processing = _FALSE;
 
 		pwrpriv->bkeepfwalive = _FALSE;
@@ -140,113 +142,94 @@ int _ips_leave(_adapter * padapter)
 	return result;
 }
 
-int ips_leave(_adapter * padapter)
+int ips_leave(_adapter *padapter)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	int ret;
 
-	if(!is_primary_adapter(padapter))
+	if (!is_primary_adapter(padapter))
 		return _SUCCESS;
 
 	_enter_pwrlock(&pwrpriv->lock);
 	ret = _ips_leave(padapter);
 #ifdef DBG_CHECK_FW_PS_STATE
-	if(rtw_fw_ps_state(padapter) == _FAIL)
-	{
-		DBG_871X("ips leave doesn't leave 32k\n");
+	if (rtw_fw_ps_state(padapter) == _FAIL) {
+		RTW_INFO("ips leave doesn't leave 32k\n");
 		pdbgpriv->dbg_leave_ips_fail_cnt++;
 	}
-#endif //DBG_CHECK_FW_PS_STATE
+#endif /* DBG_CHECK_FW_PS_STATE */
 	_exit_pwrlock(&pwrpriv->lock);
 
 	if (_SUCCESS == ret)
-		ODM_DMReset(&GET_HAL_DATA(padapter)->odmpriv);
+		odm_dm_reset(&GET_HAL_DATA(padapter)->odmpriv);
 
 #ifdef CONFIG_BT_COEXIST
 	if (_SUCCESS == ret)
 		rtw_btcoex_IpsNotify(padapter, IPS_NONE);
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 	return ret;
 }
 #endif /* CONFIG_IPS */
 
 #ifdef CONFIG_AUTOSUSPEND
-extern void autosuspend_enter(_adapter* padapter);	
-extern int autoresume_enter(_adapter* padapter);
+	extern void autosuspend_enter(_adapter *padapter);
+	extern int autoresume_enter(_adapter *padapter);
 #endif
 
 #ifdef SUPPORT_HW_RFOFF_DETECTED
-int rtw_hw_suspend(_adapter *padapter );
-int rtw_hw_resume(_adapter *padapter);
+	int rtw_hw_suspend(_adapter *padapter);
+	int rtw_hw_resume(_adapter *padapter);
 #endif
 
 bool rtw_pwr_unassociated_idle(_adapter *adapter)
 {
-	_adapter *buddy = adapter->pbuddy_adapter;
-	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	u8 i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct xmit_priv *pxmit_priv = &adapter->xmitpriv;
+	struct mlme_priv *pmlmepriv;
 #ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &(adapter->wdinfo);
-#ifdef CONFIG_IOCTL_CFG80211
-	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &adapter->cfg80211_wdinfo;
-#endif
+	struct wifidirect_info	*pwdinfo;
 #endif
 
 	bool ret = _FALSE;
 
-	if (adapter_to_pwrctl(adapter)->bpower_saving ==_TRUE ) {
-		//DBG_871X("%s: already in LPS or IPS mode\n", __func__);
+	if (adapter_to_pwrctl(adapter)->bpower_saving == _TRUE) {
+		/* RTW_INFO("%s: already in LPS or IPS mode\n", __func__); */
 		goto exit;
 	}
 
-	if (adapter_to_pwrctl(adapter)->ips_deny_time >= rtw_get_current_time()) {
-		//DBG_871X("%s ips_deny_time\n", __func__);
-		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)
-		#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
-		|| pcfg80211_wdinfo->is_ro_ch
-		#elif defined(CONFIG_P2P)
-		|| !rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
-		#endif
-		#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
-		|| rtw_get_passing_time_ms(pcfg80211_wdinfo->last_ro_ch_time) < 3000
-		#endif
-	) {
+	if (rtw_time_after(adapter_to_pwrctl(adapter)->ips_deny_time, rtw_get_current_time())) {
+		/* RTW_INFO("%s ips_deny_time\n", __func__); */
 		goto exit;
 	}
 
-	/* consider buddy, if exist */
-	if (buddy) {
-		struct mlme_priv *b_pmlmepriv = &(buddy->mlmepriv);
-		#ifdef CONFIG_P2P
-		struct wifidirect_info *b_pwdinfo = &(buddy->wdinfo);
-		#ifdef CONFIG_IOCTL_CFG80211
-		struct cfg80211_wifidirect_info *b_pcfg80211_wdinfo = &buddy->cfg80211_wdinfo;
-		#endif
-		#endif
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			pmlmepriv = &(iface->mlmepriv);
+#ifdef CONFIG_P2P
+			pwdinfo = &(iface->wdinfo);
+#endif
+			if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE | WIFI_SITE_MONITOR)
+				|| check_fwstate(pmlmepriv, WIFI_UNDER_LINKING | WIFI_UNDER_WPS)
+				|| MLME_IS_AP(iface)
+				|| MLME_IS_MESH(iface)
+				|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE)
+				#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
+				|| rtw_cfg80211_get_is_roch(iface) == _TRUE
+				|| (rtw_cfg80211_is_ro_ch_once(adapter)
+					&& rtw_cfg80211_get_last_ro_ch_passing_ms(adapter) < 3000)
+				#elif defined(CONFIG_P2P)
+				|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)
+				|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN)
+				#endif
+			)
+				goto exit;
 
-		if (check_fwstate(b_pmlmepriv, WIFI_ASOC_STATE|WIFI_SITE_MONITOR)
-			|| check_fwstate(b_pmlmepriv, WIFI_UNDER_LINKING|WIFI_UNDER_WPS)
-			|| check_fwstate(b_pmlmepriv, WIFI_AP_STATE)
-			|| check_fwstate(b_pmlmepriv, WIFI_ADHOC_MASTER_STATE|WIFI_ADHOC_STATE)
-			#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
-			|| b_pcfg80211_wdinfo->is_ro_ch
-			#elif defined(CONFIG_P2P)
-			|| !rtw_p2p_chk_state(b_pwdinfo, P2P_STATE_NONE)
-			#endif
-			#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
-			|| rtw_get_passing_time_ms(b_pcfg80211_wdinfo->last_ro_ch_time) < 3000
-			#endif
-		) {
-			goto exit;
 		}
 	}
 
@@ -256,16 +239,15 @@ bool rtw_pwr_unassociated_idle(_adapter *adapter)
 #endif
 
 #ifdef CONFIG_INTEL_PROXIM
-	if(adapter->proximity.proxim_on==_TRUE){
+	if (adapter->proximity.proxim_on == _TRUE)
 		return;
-	}
 #endif
 
 	if (pxmit_priv->free_xmitbuf_cnt != NR_XMITBUFF ||
-		pxmit_priv->free_xmit_extbuf_cnt != NR_XMIT_EXTBUFF) {
-		DBG_871X_LEVEL(_drv_always_, "There are some pkts to transmit\n");
-		DBG_871X_LEVEL(_drv_always_, "free_xmitbuf_cnt: %d, free_xmit_extbuf_cnt: %d\n", 
-			pxmit_priv->free_xmitbuf_cnt, pxmit_priv->free_xmit_extbuf_cnt);	
+	    pxmit_priv->free_xmit_extbuf_cnt != NR_XMIT_EXTBUFF) {
+		RTW_PRINT("There are some pkts to transmit\n");
+		RTW_PRINT("free_xmitbuf_cnt: %d, free_xmit_extbuf_cnt: %d\n",
+			pxmit_priv->free_xmitbuf_cnt, pxmit_priv->free_xmit_extbuf_cnt);
 		goto exit;
 	}
 
@@ -280,94 +262,83 @@ exit:
  * ATTENTION:
  *	rtw_ps_processor() doesn't handle LPS.
  */
-void rtw_ps_processor(_adapter*padapter)
+void rtw_ps_processor(_adapter *padapter)
 {
 #ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-#endif //CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 #ifdef SUPPORT_HW_RFOFF_DETECTED
 	rt_rf_power_state rfpwrstate;
-#endif //SUPPORT_HW_RFOFF_DETECTED
+#endif /* SUPPORT_HW_RFOFF_DETECTED */
 	u32 ps_deny = 0;
 
 	_enter_pwrlock(&adapter_to_pwrctl(padapter)->lock);
 	ps_deny = rtw_ps_deny_get(padapter);
 	_exit_pwrlock(&adapter_to_pwrctl(padapter)->lock);
-	if (ps_deny != 0)
-	{
-		DBG_871X(FUNC_ADPT_FMT ": ps_deny=0x%08X, skip power save!\n",
-			FUNC_ADPT_ARG(padapter), ps_deny);
+	if (ps_deny != 0) {
+		RTW_INFO(FUNC_ADPT_FMT ": ps_deny=0x%08X, skip power save!\n",
+			 FUNC_ADPT_ARG(padapter), ps_deny);
 		goto exit;
 	}
 
-	if(pwrpriv->bInSuspend == _TRUE){//system suspend or autosuspend
+	if (pwrpriv->bInSuspend == _TRUE) { /* system suspend or autosuspend */
 		pdbgpriv->dbg_ps_insuspend_cnt++;
-		DBG_871X("%s, pwrpriv->bInSuspend == _TRUE ignore this process\n",__FUNCTION__);
+		RTW_INFO("%s, pwrpriv->bInSuspend == _TRUE ignore this process\n", __FUNCTION__);
 		return;
-	}	
+	}
 
 	pwrpriv->ps_processing = _TRUE;
 
 #ifdef SUPPORT_HW_RFOFF_DETECTED
-	if(pwrpriv->bips_processing == _TRUE)
+	if (pwrpriv->bips_processing == _TRUE)
 		goto exit;
-	
-	//DBG_871X("==> fw report state(0x%x)\n",rtw_read8(padapter,0x1ca));	
-	if(pwrpriv->bHWPwrPindetect) 
-	{
-	#ifdef CONFIG_AUTOSUSPEND
-		if(padapter->registrypriv.usbss_enable)
-		{
-			if(pwrpriv->rf_pwrstate == rf_on)
-			{
-				if(padapter->net_closed == _TRUE)
+
+	/* RTW_INFO("==> fw report state(0x%x)\n",rtw_read8(padapter,0x1ca));	 */
+	if (pwrpriv->bHWPwrPindetect) {
+#ifdef CONFIG_AUTOSUSPEND
+		if (padapter->registrypriv.usbss_enable) {
+			if (pwrpriv->rf_pwrstate == rf_on) {
+				if (padapter->net_closed == _TRUE)
 					pwrpriv->ps_flag = _TRUE;
 
 				rfpwrstate = RfOnOffDetect(padapter);
-				DBG_871X("@@@@- #1  %s==> rfstate:%s \n",__FUNCTION__,(rfpwrstate==rf_on)?"rf_on":"rf_off");
-				if(rfpwrstate!= pwrpriv->rf_pwrstate)
-				{
-					if(rfpwrstate == rf_off)
-					{
+				RTW_INFO("@@@@- #1  %s==> rfstate:%s\n", __FUNCTION__, (rfpwrstate == rf_on) ? "rf_on" : "rf_off");
+				if (rfpwrstate != pwrpriv->rf_pwrstate) {
+					if (rfpwrstate == rf_off) {
 						pwrpriv->change_rfpwrstate = rf_off;
-						
-						pwrpriv->bkeepfwalive = _TRUE;	
-						pwrpriv->brfoffbyhw = _TRUE;						
-						
-						autosuspend_enter(padapter);							
+
+						pwrpriv->bkeepfwalive = _TRUE;
+						pwrpriv->brfoffbyhw = _TRUE;
+
+						autosuspend_enter(padapter);
 					}
 				}
-			}			
-		}
-		else
-	#endif //CONFIG_AUTOSUSPEND
+			}
+		} else
+#endif /* CONFIG_AUTOSUSPEND */
 		{
 			rfpwrstate = RfOnOffDetect(padapter);
-			DBG_871X("@@@@- #2  %s==> rfstate:%s \n",__FUNCTION__,(rfpwrstate==rf_on)?"rf_on":"rf_off");
+			RTW_INFO("@@@@- #2  %s==> rfstate:%s\n", __FUNCTION__, (rfpwrstate == rf_on) ? "rf_on" : "rf_off");
 
-			if(rfpwrstate!= pwrpriv->rf_pwrstate)
-			{
-				if(rfpwrstate == rf_off)
-				{	
-					pwrpriv->change_rfpwrstate = rf_off;														
+			if (rfpwrstate != pwrpriv->rf_pwrstate) {
+				if (rfpwrstate == rf_off) {
+					pwrpriv->change_rfpwrstate = rf_off;
 					pwrpriv->brfoffbyhw = _TRUE;
-					rtw_hw_suspend(padapter );	
-				}
-				else
-				{
+					rtw_hw_suspend(padapter);
+				} else {
 					pwrpriv->change_rfpwrstate = rf_on;
-					rtw_hw_resume(padapter );			
+					rtw_hw_resume(padapter);
 				}
-				DBG_871X("current rf_pwrstate(%s)\n",(pwrpriv->rf_pwrstate == rf_off)?"rf_off":"rf_on");
+				RTW_INFO("current rf_pwrstate(%s)\n", (pwrpriv->rf_pwrstate == rf_off) ? "rf_off" : "rf_on");
 			}
 		}
-		pwrpriv->pwr_state_check_cnts ++;	
+		pwrpriv->pwr_state_check_cnts++;
 	}
-#endif //SUPPORT_HW_RFOFF_DETECTED
+#endif /* SUPPORT_HW_RFOFF_DETECTED */
 
 	if (pwrpriv->ips_mode_req == IPS_NONE)
 		goto exit;
@@ -375,47 +346,42 @@ void rtw_ps_processor(_adapter*padapter)
 	if (rtw_pwr_unassociated_idle(padapter) == _FALSE)
 		goto exit;
 
-	if((pwrpriv->rf_pwrstate == rf_on) && ((pwrpriv->pwr_state_check_cnts%4)==0))
-	{
-		DBG_871X("==>%s .fw_state(%x)\n",__FUNCTION__,get_fwstate(pmlmepriv));
-		#if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
-		#else
+	if ((pwrpriv->rf_pwrstate == rf_on) && ((pwrpriv->pwr_state_check_cnts % 4) == 0)) {
+		RTW_INFO("==>%s .fw_state(%x)\n", __FUNCTION__, get_fwstate(pmlmepriv));
+#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
+#else
 		pwrpriv->change_rfpwrstate = rf_off;
-		#endif
-		#ifdef CONFIG_AUTOSUSPEND
-		if(padapter->registrypriv.usbss_enable)
-		{
-			if(pwrpriv->bHWPwrPindetect) 
+#endif
+#ifdef CONFIG_AUTOSUSPEND
+		if (padapter->registrypriv.usbss_enable) {
+			if (pwrpriv->bHWPwrPindetect)
 				pwrpriv->bkeepfwalive = _TRUE;
-			
-			if(padapter->net_closed == _TRUE)
+
+			if (padapter->net_closed == _TRUE)
 				pwrpriv->ps_flag = _TRUE;
 
-			#if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
-			if (_TRUE==pwrpriv->bInternalAutoSuspend) {
-				DBG_871X("<==%s .pwrpriv->bInternalAutoSuspend)(%x)\n",__FUNCTION__,pwrpriv->bInternalAutoSuspend);
-			} else {
+#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
+			if (_TRUE == pwrpriv->bInternalAutoSuspend)
+				RTW_INFO("<==%s .pwrpriv->bInternalAutoSuspend)(%x)\n", __FUNCTION__, pwrpriv->bInternalAutoSuspend);
+			else {
 				pwrpriv->change_rfpwrstate = rf_off;
-				DBG_871X("<==%s .pwrpriv->bInternalAutoSuspend)(%x) call autosuspend_enter\n",__FUNCTION__,pwrpriv->bInternalAutoSuspend);
+				RTW_INFO("<==%s .pwrpriv->bInternalAutoSuspend)(%x) call autosuspend_enter\n", __FUNCTION__, pwrpriv->bInternalAutoSuspend);
 				autosuspend_enter(padapter);
-			}		
-			#else
+			}
+#else
 			autosuspend_enter(padapter);
-			#endif	//if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
-		}		
-		else if(pwrpriv->bHWPwrPindetect)
+#endif	/* if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND) */
+		} else if (pwrpriv->bHWPwrPindetect) {
+		} else
+#endif /* CONFIG_AUTOSUSPEND */
 		{
-		}
-		else
-		#endif //CONFIG_AUTOSUSPEND
-		{
-			#if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
+#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
 			pwrpriv->change_rfpwrstate = rf_off;
-			#endif	//defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
+#endif	/* defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND) */
 
-			#ifdef CONFIG_IPS
-			ips_enter(padapter);			
-			#endif
+#ifdef CONFIG_IPS
+			ips_enter(padapter);
+#endif
 		}
 	}
 exit:
@@ -426,10 +392,9 @@ exit:
 	return;
 }
 
-void pwr_state_check_handler(RTW_TIMER_HDL_ARGS);
-void pwr_state_check_handler(RTW_TIMER_HDL_ARGS)
+void pwr_state_check_handler(void *ctx)
 {
-	_adapter *padapter = (_adapter *)FunctionContext;
+	_adapter *padapter = (_adapter *)ctx;
 	rtw_ps_cmd(padapter);
 }
 
@@ -437,67 +402,113 @@ void pwr_state_check_handler(RTW_TIMER_HDL_ARGS)
 void	traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets)
 {
 #ifdef CONFIG_CHECK_LEAVE_LPS
-	static u32 start_time = 0;
+	static systime start_time = 0;
 	static u32 xmit_cnt = 0;
 	u8	bLeaveLPS = _FALSE;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 
-	
 
-	if(tx) //from tx
-	{
+
+	if (tx) { /* from tx */
 		xmit_cnt += tx_packets;
 
-		if (start_time== 0)
-			start_time= rtw_get_current_time();
+		if (start_time == 0)
+			start_time = rtw_get_current_time();
 
-		if (rtw_get_passing_time_ms(start_time) > 2000) // 2 sec == watch dog timer
-		{		
-			if(xmit_cnt > 8)
-			{
-				if ((adapter_to_pwrctl(padapter)->bLeisurePs) 
-					&& (adapter_to_pwrctl(padapter)->pwr_mode != PS_MODE_ACTIVE)
+		if (rtw_get_passing_time_ms(start_time) > 2000) { /* 2 sec == watch dog timer */
+			if (xmit_cnt > 8) {
+				if ((adapter_to_pwrctl(padapter)->bLeisurePs)
+				    && (adapter_to_pwrctl(padapter)->pwr_mode != PS_MODE_ACTIVE)
 #ifdef CONFIG_BT_COEXIST
-					&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
+				    && (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
 #endif
-					)
-				{
-					//DBG_871X("leave lps via Tx = %d\n", xmit_cnt);			
+				   ) {
+					/* RTW_INFO("leave lps via Tx = %d\n", xmit_cnt);			 */
 					bLeaveLPS = _TRUE;
 				}
 			}
 
-			start_time= rtw_get_current_time();
+			start_time = rtw_get_current_time();
 			xmit_cnt = 0;
 		}
 
-	}
-	else // from rx path
-	{
-		if(pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4/*2*/)
-		{
+	} else { /* from rx path */
+		if (pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4/*2*/) {
 			if ((adapter_to_pwrctl(padapter)->bLeisurePs)
-				&& (adapter_to_pwrctl(padapter)->pwr_mode != PS_MODE_ACTIVE)
-#ifdef CONFIG_BT_COEXIST		
-				&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
+			    && (adapter_to_pwrctl(padapter)->pwr_mode != PS_MODE_ACTIVE)
+#ifdef CONFIG_BT_COEXIST
+			    && (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
 #endif
-				)
-			{	
-				//DBG_871X("leave lps via Rx = %d\n", pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);	
+			   ) {
+				/* RTW_INFO("leave lps via Rx = %d\n", pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);	 */
 				bLeaveLPS = _TRUE;
 			}
-		}	
-	}	
+		}
+	}
 
-	if(bLeaveLPS)
-	{
-		//DBG_871X("leave lps via %s, Tx = %d, Rx = %d \n", tx?"Tx":"Rx", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod,pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);	
-		//rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1);
-		rtw_lps_ctrl_wk_cmd(padapter, tx?LPS_CTRL_TX_TRAFFIC_LEAVE:LPS_CTRL_RX_TRAFFIC_LEAVE, tx?0:1);
+	if (bLeaveLPS) {
+		/* RTW_INFO("leave lps via %s, Tx = %d, Rx = %d\n", tx?"Tx":"Rx", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod,pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);	 */
+		/* rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1); */
+		rtw_lps_ctrl_wk_cmd(padapter, tx ? LPS_CTRL_TX_TRAFFIC_LEAVE : LPS_CTRL_RX_TRAFFIC_LEAVE, tx ? 0 : 1);
 	}
-#endif //CONFIG_CHECK_LEAVE_LPS
-}		
+#endif /* CONFIG_CHECK_LEAVE_LPS */
+}
 
+#ifdef CONFIG_LPS_LCLK
+u8 rtw_cpwm_polling(_adapter *adapter, u8 cpwm_orig)
+{
+	u8 result = _FAIL;
+	u8 cpwm_now;
+	u8 poll_cnt = 0;
+	systime start_time;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct debug_priv *pdbgpriv = &(adapter_to_dvobj(adapter)->drv_dbg);
+
+	/*RTW_INFO("%s.....\n", __func__);*/
+
+	start_time = rtw_get_current_time();
+
+	/* polling cpwm */
+	do {
+		rtw_msleep_os(1);
+		poll_cnt++;
+		cpwm_now = 0;
+		rtw_hal_get_hwreg(adapter, HW_VAR_CPWM, &cpwm_now);
+
+		if ((cpwm_orig ^ cpwm_now) & 0x80) {
+			pwrpriv->cpwm = PS_STATE_S4;
+			pwrpriv->cpwm_tog = cpwm_now & PS_TOGGLE;
+			#ifdef DBG_CHECK_FW_PS_STATE
+			RTW_INFO("%s: polling cpwm OK! poll_cnt=%d, cpwm_orig=%02x, cpwm_now=%02x , 0x100=0x%x\n"
+				, __func__, poll_cnt, cpwm_orig, cpwm_now, rtw_read8(adapter, REG_CR));
+			if (rtw_fw_ps_state(adapter) == _FAIL) {
+				RTW_INFO("leave 32k but fw state in 32k\n");
+				pdbgpriv->dbg_rpwm_toogle_cnt++;
+			}
+			#endif /* DBG_CHECK_FW_PS_STATE */
+			result = _SUCCESS;
+			break;
+		}
+
+		if (rtw_get_passing_time_ms(start_time) > LPS_RPWM_WAIT_MS) {
+			RTW_ERR("%s: polling cpwm timeout! poll_cnt=%d, cpwm_orig=%02x, cpwm_now=%02x\n"
+				, __func__, poll_cnt, cpwm_orig, cpwm_now);
+			#ifdef DBG_CHECK_FW_PS_STATE
+			if (rtw_fw_ps_state(adapter) == _FAIL) {
+				RTW_INFO("rpwm timeout and fw ps state in 32k\n");
+				pdbgpriv->dbg_rpwm_timeout_fail_cnt++;
+			}
+			#endif /* DBG_CHECK_FW_PS_STATE */
+
+			#ifdef CONFIG_LPS_RPWM_TIMER
+			_set_timer(&pwrpriv->pwr_rpwm_timer, 1);
+			#endif /* CONFIG_LPS_RPWM_TIMER */
+			break;
+		}
+	} while (1);
+	return result;
+}
+#endif
 /*
  * Description:
  *	This function MUST be called under power lock protect
@@ -511,150 +522,89 @@ void rtw_set_rpwm(PADAPTER padapter, u8 pslv)
 {
 	u8	rpwm;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-#ifdef CONFIG_DETECT_CPWM_BY_POLLING
+#ifdef CONFIG_LPS_LCLK
 	u8 cpwm_orig;
-#endif // CONFIG_DETECT_CPWM_BY_POLLING
+#endif
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-_func_enter_;
 
 	pslv = PS_STATE(pslv);
 
 #ifdef CONFIG_LPS_RPWM_TIMER
 	if (pwrpriv->brpwmtimeout == _TRUE)
-	{
-		DBG_871X("%s: RPWM timeout, force to set RPWM(0x%02X) again!\n", __FUNCTION__, pslv);
-	}
+		RTW_INFO("%s: RPWM timeout, force to set RPWM(0x%02X) again!\n", __FUNCTION__, pslv);
 	else
-#endif // CONFIG_LPS_RPWM_TIMER
+#endif /* CONFIG_LPS_RPWM_TIMER */
 	{
-		if ( (pwrpriv->rpwm == pslv)
+		if ((pwrpriv->rpwm == pslv)
 #ifdef CONFIG_LPS_LCLK
-			|| ((pwrpriv->rpwm >= PS_STATE_S2)&&(pslv >= PS_STATE_S2))
+		    || ((pwrpriv->rpwm >= PS_STATE_S2) && (pslv >= PS_STATE_S2))
 #endif
-			)
-		{
-			RT_TRACE(_module_rtl871x_pwrctrl_c_,_drv_err_,
-				("%s: Already set rpwm[0x%02X], new=0x%02X!\n", __FUNCTION__, pwrpriv->rpwm, pslv));
+			|| (pwrpriv->lps_level == LPS_NORMAL)
+		   ) {
 			return;
 		}
 	}
 
 	if (rtw_is_surprise_removed(padapter) ||
-		(!rtw_is_hw_init_completed(padapter)))
-	{
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-				("%s: SurpriseRemoved(%s) hw_init_completed(%s)\n"
-				, __func__
-				, rtw_is_surprise_removed(padapter)?"True":"False"
-				, rtw_is_hw_init_completed(padapter)?"True":"False"));
+	    (!rtw_is_hw_init_completed(padapter))) {
 
 		pwrpriv->cpwm = PS_STATE_S4;
 
 		return;
 	}
 
-	if (rtw_is_drv_stopped(padapter)) {
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-				 ("%s: change power state(0x%02X) when DriverStopped\n", __FUNCTION__, 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", __FUNCTION__, pslv));
+	if (rtw_is_drv_stopped(padapter))
+		if (pslv < PS_STATE_S2)
 			return;
-		}
-	}
 
 	rpwm = pslv | pwrpriv->tog;
 #ifdef CONFIG_LPS_LCLK
-	// only when from PS_STATE S0/S1 to S2 and higher needs ACK
+	/* only when from PS_STATE S0/S1 to S2 and higher needs ACK */
 	if ((pwrpriv->cpwm < PS_STATE_S2) && (pslv >= PS_STATE_S2))
 		rpwm |= PS_ACK;
 #endif
-	RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-			 ("rtw_set_rpwm: rpwm=0x%02x cpwm=0x%02x\n", rpwm, pwrpriv->cpwm));
 
 	pwrpriv->rpwm = pslv;
 
-#ifdef CONFIG_DETECT_CPWM_BY_POLLING
+#ifdef CONFIG_LPS_LCLK
 	cpwm_orig = 0;
 	if (rpwm & PS_ACK)
-	{
 		rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_orig);
-	}
 #endif
 
 #if defined(CONFIG_LPS_RPWM_TIMER) && !defined(CONFIG_DETECT_CPWM_BY_POLLING)
 	if (rpwm & PS_ACK)
 		_set_timer(&pwrpriv->pwr_rpwm_timer, LPS_RPWM_WAIT_MS);
-#endif // CONFIG_LPS_RPWM_TIMER & !CONFIG_DETECT_CPWM_BY_POLLING
+#endif /* CONFIG_LPS_RPWM_TIMER & !CONFIG_DETECT_CPWM_BY_POLLING */
 	rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
 
 	pwrpriv->tog += 0x80;
 
 #ifdef CONFIG_LPS_LCLK
-	// No LPS 32K, No Ack
-	if (rpwm & PS_ACK)
-	{
+	/* No LPS 32K, No Ack */
+	if (rpwm & PS_ACK) {
 #ifdef CONFIG_DETECT_CPWM_BY_POLLING
-		u32 start_time;
-		u8 cpwm_now;
-		u8 poll_cnt=0;
-
-		start_time = rtw_get_current_time();
-
-		// polling cpwm
-		do {
-			rtw_msleep_os(1);
-			poll_cnt++;
-			cpwm_now = 0;
-			rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_now);
-			if ((cpwm_orig ^ cpwm_now) & 0x80)
-			{
-				pwrpriv->cpwm = PS_STATE_S4;
-				pwrpriv->cpwm_tog = cpwm_now & PS_TOGGLE;
-#ifdef DBG_CHECK_FW_PS_STATE
-				DBG_871X("%s: polling cpwm OK! poll_cnt=%d, cpwm_orig=%02x, cpwm_now=%02x , 0x100=0x%x\n"
-				, __FUNCTION__,poll_cnt, cpwm_orig, cpwm_now, rtw_read8(padapter, REG_CR));
-				if(rtw_fw_ps_state(padapter) == _FAIL)
-				{
-					DBG_871X("leave 32k but fw state in 32k\n");
-					pdbgpriv->dbg_rpwm_toogle_cnt++;
-				}
-#endif //DBG_CHECK_FW_PS_STATE
-				break;
-			}
-
-			if (rtw_get_passing_time_ms(start_time) > LPS_RPWM_WAIT_MS)
-			{
-				DBG_871X("%s: polling cpwm timeout! poll_cnt=%d, cpwm_orig=%02x, cpwm_now=%02x \n", __FUNCTION__,poll_cnt, cpwm_orig, cpwm_now);
-#ifdef DBG_CHECK_FW_PS_STATE
-				if(rtw_fw_ps_state(padapter) == _FAIL)
-				{
-					DBG_871X("rpwm timeout and fw ps state in 32k\n");
-					pdbgpriv->dbg_rpwm_timeout_fail_cnt++;
-				}
-#endif //DBG_CHECK_FW_PS_STATE
-#ifdef CONFIG_LPS_RPWM_TIMER
-				_set_timer(&pwrpriv->pwr_rpwm_timer, 1);
-#endif // CONFIG_LPS_RPWM_TIMER
-				break;
-			}
-		} while (1);
-#endif // CONFIG_DETECT_CPWM_BY_POLLING
-	}
-	else
-#endif // CONFIG_LPS_LCLK
+		rtw_cpwm_polling(padapter, cpwm_orig);
+		#else
+		#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
+		if (pwrpriv->wowlan_mode == _TRUE ||
+			pwrpriv->wowlan_ap_mode == _TRUE ||
+			pwrpriv->wowlan_p2p_mode == _TRUE)
+				rtw_cpwm_polling(padapter, cpwm_orig);
+		#endif /*#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)*/
+		#endif /*#ifdef CONFIG_DETECT_CPWM_BY_POLLING*/
+	} else
+#endif /* CONFIG_LPS_LCLK */
 	{
 		pwrpriv->cpwm = pslv;
 	}
 
-_func_exit_;
 }
 
-u8 PS_RDY_CHECK(_adapter * padapter)
+u8 PS_RDY_CHECK(_adapter *padapter)
 {
-	u32 curr_time, delta_time;
+	u32 delta_ms;
 	struct pwrctrl_priv	*pwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 #ifdef CONFIG_P2P
@@ -665,53 +615,46 @@ u8 PS_RDY_CHECK(_adapter * padapter)
 #endif /* CONFIG_P2P */
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-	if(_TRUE == pwrpriv->bInSuspend && pwrpriv->wowlan_mode)
+	if (_TRUE == pwrpriv->bInSuspend && pwrpriv->wowlan_mode)
 		return _TRUE;
-	else if(_TRUE == pwrpriv->bInSuspend && pwrpriv->wowlan_ap_mode)
+	else if (_TRUE == pwrpriv->bInSuspend && pwrpriv->wowlan_ap_mode)
 		return _TRUE;
 	else if (_TRUE == pwrpriv->bInSuspend)
 		return _FALSE;
 #else
-	if(_TRUE == pwrpriv->bInSuspend )
+	if (_TRUE == pwrpriv->bInSuspend)
 		return _FALSE;
 #endif
 
-	curr_time = rtw_get_current_time();	
-
-	delta_time = curr_time -pwrpriv->DelayLPSLastTimeStamp;
-
-	if(delta_time < LPS_DELAY_TIME)
-	{		
+	delta_ms = rtw_get_passing_time_ms(pwrpriv->DelayLPSLastTimeStamp);
+	if (delta_ms < LPS_DELAY_MS)
 		return _FALSE;
-	}
 
 	if (check_fwstate(pmlmepriv, 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)
+		|| check_fwstate(pmlmepriv, WIFI_UNDER_LINKING | WIFI_UNDER_WPS)
+		|| MLME_IS_AP(padapter)
+		|| MLME_IS_MESH(padapter)
+		|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE)
 		#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
-		|| pcfg80211_wdinfo->is_ro_ch
-		#elif defined(CONFIG_P2P)
-		|| !rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
+		|| rtw_cfg80211_get_is_roch(padapter) == _TRUE
 		#endif
 		|| rtw_is_scan_deny(padapter)
-#ifdef CONFIG_TDLS
-		// TDLS link is established.
-		|| ( padapter->tdlsinfo.link_established == _TRUE )
-#endif // CONFIG_TDLS		
+		#ifdef CONFIG_TDLS
+		/* TDLS link is established. */
+		|| (padapter->tdlsinfo.link_established == _TRUE)
+		#endif /* CONFIG_TDLS		 */
 	)
 		return _FALSE;
 
-	if( (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) && (padapter->securitypriv.binstallGrpkey == _FALSE) )
-	{
-		DBG_871X("Group handshake still in progress !!!\n");
+	if ((padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) && (padapter->securitypriv.binstallGrpkey == _FALSE)) {
+		RTW_INFO("Group handshake still in progress !!!\n");
 		return _FALSE;
 	}
 
 #ifdef CONFIG_IOCTL_CFG80211
 	if (!rtw_cfg80211_pwr_mgmt(padapter))
 		return _FALSE;
-#endif	
+#endif
 
 	return _TRUE;
 }
@@ -720,308 +663,340 @@ u8 PS_RDY_CHECK(_adapter * padapter)
 void rtw_set_fw_in_ips_mode(PADAPTER padapter, u8 enable)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	int cnt=0;
-	u32 start_time;
+	int cnt = 0;
+	systime start_time;
 	u8 val8 = 0;
 	u8 cpwm_orig = 0, cpwm_now = 0;
-	u8 parm[H2C_INACTIVE_PS_LEN]={0};
+	u8 parm[H2C_INACTIVE_PS_LEN] = {0};
 
 	if (padapter->netif_up == _FALSE) {
-		DBG_871X("%s: ERROR, netif is down\n", __func__);
+		RTW_INFO("%s: ERROR, netif is down\n", __func__);
 		return;
 	}
 
-	//u8 cmd_param; //BIT0:enable, BIT1:NoConnect32k
+	/* u8 cmd_param; */ /* BIT0:enable, BIT1:NoConnect32k */
 	if (enable) {
 #ifdef CONFIG_BT_COEXIST
 		rtw_btcoex_IpsNotify(padapter, pwrpriv->ips_mode_req);
 #endif
-		//Enter IPS
-		DBG_871X("%s: issue H2C to FW when entering IPS\n", __func__);
+		/* Enter IPS */
+		RTW_INFO("%s: issue H2C to FW when entering IPS\n", __func__);
 
+		parm[0] = 0x1;/* suggest by Isaac.Hsu*/
 #ifdef CONFIG_PNO_SUPPORT
-		parm[0] = 0x03;
-		parm[1] = pwrpriv->pnlo_info->fast_scan_iterations;
-		parm[2] = pwrpriv->pnlo_info->slow_scan_period;
-#else
-		parm[0] = 0x03;
-		parm[1] = 0x0;
-		parm[2] = 0x0;
-#endif//CONFIG_PNO_SUPPORT
+		if (pwrpriv->pno_inited) {
+			parm[1] = pwrpriv->pnlo_info->fast_scan_iterations;
+			parm[2] = pwrpriv->pnlo_info->slow_scan_period;
+		}
+#endif
 
-		rtw_hal_fill_h2c_cmd(padapter, //H2C_FWLPS_IN_IPS_,
-					H2C_INACTIVE_PS_,
-					H2C_INACTIVE_PS_LEN, parm);
-		//poll 0x1cc to make sure H2C command already finished by FW; MAC_0x1cc=0 means H2C done by FW.
-		do{
+		rtw_hal_fill_h2c_cmd(padapter, /* H2C_FWLPS_IN_IPS_, */
+				     H2C_INACTIVE_PS_,
+				     H2C_INACTIVE_PS_LEN, parm);
+		/* poll 0x1cc to make sure H2C command already finished by FW; MAC_0x1cc=0 means H2C done by FW. */
+		do {
 			val8 = rtw_read8(padapter, REG_HMETFR);
 			cnt++;
-			DBG_871X("%s  polling REG_HMETFR=0x%x, cnt=%d \n",
-					__func__, val8, cnt);
+			RTW_INFO("%s  polling REG_HMETFR=0x%x, cnt=%d\n",
+				 __func__, val8, cnt);
 			rtw_mdelay_os(10);
-		}while(cnt<100 && (val8!=0));
+		} while (cnt < 100 && (val8 != 0));
 
-		//H2C done, enter 32k
+#ifdef CONFIG_LPS_LCLK
+		/* H2C done, enter 32k */
 		if (val8 == 0) {
-			//ser rpwm to enter 32k
-			val8 = rtw_read8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1);
-			DBG_871X("%s: read rpwm=%02x\n", __FUNCTION__, val8);
+			/* ser rpwm to enter 32k */
+			rtw_hal_get_hwreg(padapter, HW_VAR_RPWM_TOG, &val8);
+			RTW_INFO("%s: read rpwm=%02x\n", __FUNCTION__, val8);
 			val8 += 0x80;
 			val8 |= BIT(0);
-			rtw_write8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1, val8);
-			DBG_871X("%s: write rpwm=%02x\n", __FUNCTION__, val8);
+			rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&val8));
+			RTW_INFO("%s: write rpwm=%02x\n", __FUNCTION__, val8);
 			adapter_to_pwrctl(padapter)->tog = (val8 + 0x80) & 0x80;
 			cnt = val8 = 0;
 			if (parm[1] == 0 || parm[2] == 0) {
 				do {
 					val8 = rtw_read8(padapter, REG_CR);
 					cnt++;
-					DBG_871X("%s  polling 0x100=0x%x, cnt=%d \n",
-							__func__, val8, cnt);
-					DBG_871X("%s 0x08:%02x, 0x03:%02x\n",
-							__func__,
-							rtw_read8(padapter, 0x08),
-							rtw_read8(padapter, 0x03));
+					RTW_INFO("%s  polling 0x100=0x%x, cnt=%d\n",
+						 __func__, val8, cnt);
+					RTW_INFO("%s 0x08:%02x, 0x03:%02x\n",
+						 __func__,
+						 rtw_read8(padapter, 0x08),
+						 rtw_read8(padapter, 0x03));
 					rtw_mdelay_os(10);
-				} while(cnt<20 && (val8!=0xEA));
+				} while (cnt < 20 && (val8 != 0xEA));
 			}
 		}
+#endif
 	} else {
-		//Leave IPS
-		DBG_871X("%s: Leaving IPS in FWLPS state\n", __func__);
+		/* Leave IPS */
+		RTW_INFO("%s: Leaving IPS in FWLPS state\n", __func__);
 
-		//for polling cpwm
+#ifdef CONFIG_LPS_LCLK
+		/* for polling cpwm */
 		cpwm_orig = 0;
 		rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_orig);
 
-		//ser rpwm
-		val8 = rtw_read8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1);
-		val8 &= 0x80;
+		/* ser rpwm */
+		rtw_hal_get_hwreg(padapter, HW_VAR_RPWM_TOG, &val8);
 		val8 += 0x80;
 		val8 |= BIT(6);
-		rtw_write8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1, val8);
-		DBG_871X("%s: write rpwm=%02x\n", __FUNCTION__, val8);
+		rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&val8));
+		RTW_INFO("%s: write rpwm=%02x\n", __FUNCTION__, val8);
 		adapter_to_pwrctl(padapter)->tog = (val8 + 0x80) & 0x80;
 
-		//do polling cpwm
+		/* do polling cpwm */
 		start_time = rtw_get_current_time();
 		do {
 
 			rtw_mdelay_os(1);
 
 			rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_now);
-			if ((cpwm_orig ^ cpwm_now) & 0x80) {
+			if ((cpwm_orig ^ cpwm_now) & 0x80)
 				break;
-			}
 
-			if (rtw_get_passing_time_ms(start_time) > 100)
-			{
-				DBG_871X("%s: polling cpwm timeout when leaving IPS in FWLPS state\n", __FUNCTION__);
+			if (rtw_get_passing_time_ms(start_time) > 100) {
+				RTW_INFO("%s: polling cpwm timeout when leaving IPS in FWLPS state\n", __FUNCTION__);
 				break;
 			}
 		} while (1);
 
+#endif
 		parm[0] = 0x0;
 		parm[1] = 0x0;
 		parm[2] = 0x0;
 		rtw_hal_fill_h2c_cmd(padapter, H2C_INACTIVE_PS_,
-					H2C_INACTIVE_PS_LEN, parm);
+				     H2C_INACTIVE_PS_LEN, parm);
 #ifdef CONFIG_BT_COEXIST
 		rtw_btcoex_IpsNotify(padapter, IPS_NONE);
 #endif
 	}
 }
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 
 void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode, const char *msg)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 #ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-#endif //CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 #ifdef CONFIG_TDLS
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	_irqL irqL;
 	int i, j;
 	_list	*plist, *phead;
 	struct sta_info *ptdls_sta;
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
+#ifdef CONFIG_LPS_PG
+	u8 lps_pg_hdl_id = 0;
+#endif
 
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-			 ("%s: PowerMode=%d Smart_PS=%d\n",
-			  __FUNCTION__, 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));
+	if (ps_mode > PM_Card_Disable) {
 		return;
 	}
 
-	if (pwrpriv->pwr_mode == ps_mode)
-	{
-		if (PS_MODE_ACTIVE == ps_mode) return;
+	if (pwrpriv->pwr_mode == ps_mode) {
+		if (PS_MODE_ACTIVE == ps_mode)
+			return;
 
 #ifndef CONFIG_BT_COEXIST
-		if ((pwrpriv->smart_ps == smart_ps) &&
-			(pwrpriv->bcn_ant_mode == bcn_ant_mode))
-		{
-			return;
-		}
-#endif // !CONFIG_BT_COEXIST
+#ifdef CONFIG_WMMPS_STA	
+		if (!rtw_is_wmmps_mode(padapter))
+#endif /* CONFIG_WMMPS_STA */
+			if ((pwrpriv->smart_ps == smart_ps) &&
+			    (pwrpriv->bcn_ant_mode == bcn_ant_mode))
+				return;
+#endif /* !CONFIG_BT_COEXIST */
+	}
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	if (PS_MODE_ACTIVE != ps_mode) {
+		rtw_set_ps_rsvd_page(padapter);
+		rtw_set_default_port_id(padapter);
 	}
+#endif
+
+#ifdef CONFIG_LPS_PG
+	if ((PS_MODE_ACTIVE != ps_mode) && (pwrpriv->blpspg_info_up)) {
+		/*rtw_hal_set_lps_pg_info(padapter);*/
+		lps_pg_hdl_id = LPS_PG_INFO_CFG;
+		rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
+	}
+#endif
 
 #ifdef CONFIG_LPS_LCLK
 	_enter_pwrlock(&pwrpriv->lock);
 #endif
 
-	//if(pwrpriv->pwr_mode == PS_MODE_ACTIVE)
-	if(ps_mode == PS_MODE_ACTIVE)
-	{
+	/* if(pwrpriv->pwr_mode == PS_MODE_ACTIVE) */
+	if (ps_mode == PS_MODE_ACTIVE) {
 		if (1
 #ifdef CONFIG_BT_COEXIST
-			&& (((rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
+		    && (((rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
 #ifdef CONFIG_P2P_PS
-					&& (pwdinfo->opp_ps == 0)
-#endif // CONFIG_P2P_PS
-					)
-				|| ((rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
-					&& (rtw_btcoex_IsLpsOn(padapter) == _FALSE))
-				)
-#else // !CONFIG_BT_COEXIST
-#ifdef CONFIG_P2P_PS
-			&& (pwdinfo->opp_ps == 0)
-#endif // CONFIG_P2P_PS
-#endif // !CONFIG_BT_COEXIST
+			 && (pwdinfo->opp_ps == 0)
+#endif /* CONFIG_P2P_PS */
 			)
-		{
-			DBG_871X(FUNC_ADPT_FMT" Leave 802.11 power save - %s\n",
-				FUNC_ADPT_ARG(padapter), msg);
+			|| ((rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
+			    && (rtw_btcoex_IsLpsOn(padapter) == _FALSE))
+		       )
+#else /* !CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P_PS
+		    && (pwdinfo->opp_ps == 0)
+#endif /* CONFIG_P2P_PS */
+#endif /* !CONFIG_BT_COEXIST */
+		   ) {
+			RTW_INFO(FUNC_ADPT_FMT" Leave 802.11 power save - %s\n",
+				 FUNC_ADPT_ARG(padapter), msg);
 
 			if (pwrpriv->lps_leave_cnts < UINT_MAX)
 				pwrpriv->lps_leave_cnts++;
 			else
 				pwrpriv->lps_leave_cnts = 0;
 #ifdef CONFIG_TDLS
-			for(i=0; i< NUM_STA; i++)
-			{
+			for (i = 0; i < NUM_STA; i++) {
 				phead = &(pstapriv->sta_hash[i]);
 				plist = get_next(phead);
 
-				while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-				{
+				while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 					ptdls_sta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
 
-					if( ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE )
-						issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->hwaddr, 0, 0, 0);
+					if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
+						issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 0, 0, 0);
 					plist = get_next(plist);
 				}
 			}
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 			pwrpriv->pwr_mode = ps_mode;
 			rtw_set_rpwm(padapter, PS_STATE_S4);
-			
+
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
 			if (pwrpriv->wowlan_mode == _TRUE ||
-					pwrpriv->wowlan_ap_mode == _TRUE ||
-					pwrpriv->wowlan_p2p_mode == _TRUE)
-			{
-				u32 start_time, delay_ms;
+			    pwrpriv->wowlan_ap_mode == _TRUE ||
+			    pwrpriv->wowlan_p2p_mode == _TRUE) {
+				systime start_time;
+				u32 delay_ms;
 				u8 val8;
 				delay_ms = 20;
 				start_time = rtw_get_current_time();
-				do { 
+				do {
 					rtw_hal_get_hwreg(padapter, HW_VAR_SYS_CLKR, &val8);
-					if (!(val8 & BIT(4))){ //0x08 bit4 =1 --> in 32k, bit4 = 0 --> leave 32k
+					if (!(val8 & BIT(4))) { /* 0x08 bit4 =1 --> in 32k, bit4 = 0 --> leave 32k */
 						pwrpriv->cpwm = PS_STATE_S4;
 						break;
 					}
-					if (rtw_get_passing_time_ms(start_time) > delay_ms)
-					{
-						DBG_871X("%s: Wait for FW 32K leave more than %u ms!!!\n", 
-								__FUNCTION__, delay_ms);
+					if (rtw_get_passing_time_ms(start_time) > delay_ms) {
+						RTW_INFO("%s: Wait for FW 32K leave more than %u ms!!!\n",
+							__FUNCTION__, delay_ms);
 						pdbgpriv->dbg_wow_leave_ps_fail_cnt++;
 						break;
 					}
 					rtw_usleep_os(100);
-				} while (1); 
+				} while (1);
+			}
+#endif
+#ifdef CONFIG_LPS_PG
+			if (pwrpriv->lps_level == LPS_PG) {
+				lps_pg_hdl_id = LPS_PG_REDLEMEM;
+				rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
 			}
 #endif
 			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
+
+#ifdef CONFIG_LPS_PG
+			if (pwrpriv->lps_level == LPS_PG) {
+				lps_pg_hdl_id = LPS_PG_RESEND_H2C;
+				rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
+			}
+#endif
+
+#ifdef CONFIG_LPS_POFF
+			rtw_hal_set_hwreg(padapter, HW_VAR_LPS_POFF_SET_MODE,
+					  (u8 *)(&ps_mode));
+#endif /*CONFIG_LPS_POFF*/
+
 			pwrpriv->bFwCurrentInPSMode = _FALSE;
 
 #ifdef CONFIG_BT_COEXIST
 			rtw_btcoex_LpsNotify(padapter, ps_mode);
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 		}
-	}
-	else
-	{
+	} else {
 		if ((PS_RDY_CHECK(padapter) && check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE))
 #ifdef CONFIG_BT_COEXIST
-			|| ((rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
-				&& (rtw_btcoex_IsLpsOn(padapter) == _TRUE))
+		    || ((rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
+			&& (rtw_btcoex_IsLpsOn(padapter) == _TRUE))
 #endif
 #ifdef CONFIG_P2P_WOWLAN
-			||( _TRUE == pwrpriv->wowlan_p2p_mode)
-#endif //CONFIG_P2P_WOWLAN
-			)
-		{
+		    || (_TRUE == pwrpriv->wowlan_p2p_mode)
+#endif /* CONFIG_P2P_WOWLAN */
+		   ) {
 			u8 pslv;
 
-			DBG_871X(FUNC_ADPT_FMT" Enter 802.11 power save - %s\n",
-				FUNC_ADPT_ARG(padapter), msg);
+			RTW_INFO(FUNC_ADPT_FMT" Enter 802.11 power save - %s\n",
+				 FUNC_ADPT_ARG(padapter), msg);
 
 			if (pwrpriv->lps_enter_cnts < UINT_MAX)
 				pwrpriv->lps_enter_cnts++;
 			else
 				pwrpriv->lps_enter_cnts = 0;
 #ifdef CONFIG_TDLS
-			for(i=0; i< NUM_STA; i++)
-			{
+			for (i = 0; i < NUM_STA; i++) {
 				phead = &(pstapriv->sta_hash[i]);
 				plist = get_next(phead);
 
-				while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-				{
+				while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 					ptdls_sta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
 
-					if( ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE )
-						issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->hwaddr, 1, 0, 0);
+					if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
+						issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 1, 0, 0);
 					plist = get_next(plist);
 				}
 			}
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 #ifdef CONFIG_BT_COEXIST
 			rtw_btcoex_LpsNotify(padapter, ps_mode);
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
+
+#ifdef CONFIG_LPS_POFF
+			rtw_hal_set_hwreg(padapter, HW_VAR_LPS_POFF_SET_MODE,
+					  (u8 *)(&ps_mode));
+#endif /*CONFIG_LPS_POFF*/
 
 			pwrpriv->bFwCurrentInPSMode = _TRUE;
 			pwrpriv->pwr_mode = ps_mode;
 			pwrpriv->smart_ps = smart_ps;
 			pwrpriv->bcn_ant_mode = bcn_ant_mode;
+
+#ifdef CONFIG_WMMPS_STA	
+			pwrpriv->wmm_smart_ps = pregistrypriv->wmm_smart_ps;
+#endif /* CONFIG_WMMPS_STA */
+			
 			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
 
 #ifdef CONFIG_P2P_PS
-			// Set CTWindow after LPS
-			if(pwdinfo->opp_ps == 1)
+			/* Set CTWindow after LPS */
+			if (pwdinfo->opp_ps == 1)
 				p2p_ps_wk_cmd(padapter, P2P_PS_ENABLE, 0);
-#endif //CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
 			pslv = PS_STATE_S2;
 #ifdef CONFIG_LPS_LCLK
 			if (pwrpriv->alives == 0)
 				pslv = PS_STATE_S0;
-#endif // CONFIG_LPS_LCLK
+#endif /* CONFIG_LPS_LCLK */
 
 #ifdef CONFIG_BT_COEXIST
 			if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
-				&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE))
-			{
+			    && (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
 				u8 val8;
 
 				val8 = rtw_btcoex_LpsVal(padapter);
@@ -1029,7 +1004,7 @@ _func_enter_;
 					pslv = PS_STATE_S2;
 
 			}
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 			rtw_set_rpwm(padapter, pslv);
 		}
@@ -1039,7 +1014,6 @@ _func_enter_;
 	_exit_pwrlock(&pwrpriv->lock);
 #endif
 
-_func_exit_;
 }
 
 /*
@@ -1050,28 +1024,26 @@ _func_exit_;
  */
 s32 LPS_RF_ON_check(PADAPTER padapter, u32 delay_ms)
 {
-	u32 start_time;
+	systime start_time;
 	u8 bAwake = _FALSE;
 	s32 err = 0;
 
 
 	start_time = rtw_get_current_time();
-	while (1)
-	{
+	while (1) {
 		rtw_hal_get_hwreg(padapter, HW_VAR_FWLPS_RF_ON, &bAwake);
 		if (_TRUE == bAwake)
 			break;
 
 		if (rtw_is_surprise_removed(padapter)) {
 			err = -2;
-			DBG_871X("%s: device surprise removed!!\n", __FUNCTION__);
+			RTW_INFO("%s: device surprise removed!!\n", __FUNCTION__);
 			break;
 		}
 
-		if (rtw_get_passing_time_ms(start_time) > delay_ms)
-		{
+		if (rtw_get_passing_time_ms(start_time) > delay_ms) {
 			err = -1;
-			DBG_871X("%s: Wait for FW LPS leave more than %u ms!!!\n", __FUNCTION__, delay_ms);
+			RTW_INFO("%s: Wait for FW LPS leave more than %u ms!!!\n", __FUNCTION__, delay_ms);
 			break;
 		}
 		rtw_usleep_os(100);
@@ -1080,23 +1052,23 @@ s32 LPS_RF_ON_check(PADAPTER padapter, u32 delay_ms)
 	return err;
 }
 
-//
-//	Description:
-//		Enter the leisure power save mode.
-//
+/*
+ *	Description:
+ *		Enter the leisure power save mode.
+ *   */
 void LPS_Enter(PADAPTER padapter, const char *msg)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct pwrctrl_priv	*pwrpriv = dvobj_to_pwrctl(dvobj);
 	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	_adapter *buddy = padapter->pbuddy_adapter;
 	int n_assoc_iface = 0;
 	int i;
 	char buf[32] = {0};
 
-_func_enter_;
 
-//	DBG_871X("+LeisurePSEnter\n");
+	/*	RTW_INFO("+LeisurePSEnter\n"); */
+	if (GET_HAL_DATA(padapter)->bFWReady == _FALSE)
+		return;
 
 #ifdef CONFIG_BT_COEXIST
 	if (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
@@ -1111,9 +1083,11 @@ _func_enter_;
 	if (n_assoc_iface != 1)
 		return;
 
+#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
 	/* Skip lps enter request for adapter not port0 */
-	if (get_iface_type(padapter) != IFACE_PORT0)
+	if (get_hw_port(padapter) != HW_PORT0)
 		return;
+#endif
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		if (PS_RDY_CHECK(dvobj->padapters[i]) == _FALSE)
@@ -1121,37 +1095,42 @@ _func_enter_;
 	}
 
 #ifdef CONFIG_P2P_PS
-	if(padapter->wdinfo.p2p_ps_mode == P2P_PS_NOA)
-	{
-		return;//supporting p2p client ps NOA via H2C_8723B_P2P_PS_OFFLOAD 
+	if (padapter->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
+		return;/* supporting p2p client ps NOA via H2C_8723B_P2P_PS_OFFLOAD */
 	}
-#endif //CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
-	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)
-			{
+	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) {
+
+#ifdef CONFIG_WMMPS_STA
+				if (rtw_is_wmmps_mode(padapter))
+					msg = "WMMPS_IDLE";
+#endif /* CONFIG_WMMPS_STA */
+				
 				sprintf(buf, "WIFI-%s", msg);
 				pwrpriv->bpower_saving = _TRUE;
+				
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 				rtw_set_ps_mode(padapter, pwrpriv->power_mgnt, padapter->registrypriv.smart_ps, 0, buf);
 			}
-		}
-		else
+		} else
 			pwrpriv->LpsIdleCount++;
 	}
 
-//	DBG_871X("-LeisurePSEnter\n");
+	/*	RTW_INFO("-LeisurePSEnter\n"); */
 
-_func_exit_;
 }
 
-//
-//	Description:
-//		Leave the leisure power save mode.
-//
+/*
+ *	Description:
+ *		Leave the leisure power save mode.
+ *   */
 void LPS_Leave(PADAPTER padapter, const char *msg)
 {
 #define LPS_LEAVE_TIMEOUT_MS 100
@@ -1163,38 +1142,57 @@ void LPS_Leave(PADAPTER padapter, const char *msg)
 	char buf[32] = {0};
 	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
 
-_func_enter_;
 
-//	DBG_871X("+LeisurePSLeave\n");
+	/*	RTW_INFO("+LeisurePSLeave\n"); */
 
 #ifdef CONFIG_BT_COEXIST
 	if (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
 		return;
 #endif
 
-	if (pwrpriv->bLeisurePs)
-	{
-		if(pwrpriv->pwr_mode != PS_MODE_ACTIVE)
-		{
+	if (pwrpriv->bLeisurePs) {
+		if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
+
+#ifdef CONFIG_WMMPS_STA
+			if (rtw_is_wmmps_mode(padapter))
+				msg = "WMMPS_BUSY";
+#endif /* CONFIG_WMMPS_STA */
+			
 			sprintf(buf, "WIFI-%s", msg);
 			rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, buf);
 
-			if(pwrpriv->pwr_mode == PS_MODE_ACTIVE)
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS	
+			pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+			if (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
 				LPS_RF_ON_check(padapter, LPS_LEAVE_TIMEOUT_MS);
 		}
 	}
 
 	pwrpriv->bpower_saving = _FALSE;
 #ifdef DBG_CHECK_FW_PS_STATE
-	if(rtw_fw_ps_state(padapter) == _FAIL)
-	{
-		DBG_871X("leave lps, fw in 32k\n");
+	if (rtw_fw_ps_state(padapter) == _FAIL) {
+		RTW_INFO("leave lps, fw in 32k\n");
 		pdbgpriv->dbg_leave_lps_fail_cnt++;
 	}
-#endif //DBG_CHECK_FW_PS_STATE
-//	DBG_871X("-LeisurePSLeave\n");
+#endif /* DBG_CHECK_FW_PS_STATE
+ * 	RTW_INFO("-LeisurePSLeave\n"); */
+
+}
 
-_func_exit_;
+void rtw_wow_lps_level_decide(_adapter *adapter, u8 wow_en)
+{
+#if defined(CONFIG_USB_HCI) && defined(CONFIG_LPS_LCLK)
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+
+	if (wow_en) {
+		pwrpriv->lps_level_bk = pwrpriv->lps_level;
+		pwrpriv->lps_level = LPS_LCLK;
+	} else
+		pwrpriv->lps_level = pwrpriv->lps_level_bk;
+#endif
 }
 #endif
 
@@ -1207,27 +1205,21 @@ void LeaveAllPowerSaveModeDirect(PADAPTER Adapter)
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 #ifndef CONFIG_DETECT_CPWM_BY_POLLING
 	u8 cpwm_orig, cpwm_now;
-	u32 start_time;
-#endif // CONFIG_DETECT_CPWM_BY_POLLING
+	systime start_time;
+#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
 
-_func_enter_;
 
-	DBG_871X("%s.....\n",__FUNCTION__);
+	RTW_INFO("%s.....\n", __FUNCTION__);
 
 	if (rtw_is_surprise_removed(Adapter)) {
-		DBG_871X(FUNC_ADPT_FMT ": bSurpriseRemoved=_TRUE Skip!\n", FUNC_ADPT_ARG(Adapter));
+		RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=_TRUE Skip!\n", FUNC_ADPT_ARG(Adapter));
 		return;
 	}
 
-	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
-#ifdef CONFIG_CONCURRENT_MODE
-		|| (check_buddy_fwstate(Adapter,_FW_LINKED) == _TRUE)
-#endif
-		)
-	{ //connect
+	if (rtw_mi_check_status(Adapter, MI_LINKED)) { /*connect*/
 
-		if(pwrpriv->pwr_mode == PS_MODE_ACTIVE) {
-			DBG_871X("%s: Driver Already Leave LPS\n",__FUNCTION__);
+		if (pwrpriv->pwr_mode == PS_MODE_ACTIVE) {
+			RTW_INFO("%s: Driver Already Leave LPS\n", __FUNCTION__);
 			return;
 		}
 
@@ -1237,95 +1229,83 @@ _func_enter_;
 #ifndef CONFIG_DETECT_CPWM_BY_POLLING
 		cpwm_orig = 0;
 		rtw_hal_get_hwreg(Adapter, HW_VAR_CPWM, &cpwm_orig);
-#endif //CONFIG_DETECT_CPWM_BY_POLLING
+#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
 		rtw_set_rpwm(Adapter, PS_STATE_S4);
 
 #ifndef CONFIG_DETECT_CPWM_BY_POLLING
 
 		start_time = rtw_get_current_time();
 
-		// polling cpwm
+		/* polling cpwm */
 		do {
 			rtw_mdelay_os(1);
 
 			rtw_hal_get_hwreg(Adapter, HW_VAR_CPWM, &cpwm_now);
-			if ((cpwm_orig ^ cpwm_now) & 0x80)
-			{
+			if ((cpwm_orig ^ cpwm_now) & 0x80) {
 				pwrpriv->cpwm = PS_STATE_S4;
 				pwrpriv->cpwm_tog = cpwm_now & PS_TOGGLE;
 #ifdef DBG_CHECK_FW_PS_STATE
-				DBG_871X("%s: polling cpwm OK! cpwm_orig=%02x, cpwm_now=%02x, 0x100=0x%x \n"
-				, __FUNCTION__, cpwm_orig, cpwm_now, rtw_read8(Adapter, REG_CR));
-				if(rtw_fw_ps_state(Adapter) == _FAIL)
-				{
-					DBG_871X("%s: leave 32k but fw state in 32k\n", __FUNCTION__);
+				RTW_INFO("%s: polling cpwm OK! cpwm_orig=%02x, cpwm_now=%02x, 0x100=0x%x\n"
+					, __FUNCTION__, cpwm_orig, cpwm_now, rtw_read8(Adapter, REG_CR));
+				if (rtw_fw_ps_state(Adapter) == _FAIL) {
+					RTW_INFO("%s: leave 32k but fw state in 32k\n", __FUNCTION__);
 					pdbgpriv->dbg_rpwm_toogle_cnt++;
 				}
-#endif //DBG_CHECK_FW_PS_STATE
+#endif /* DBG_CHECK_FW_PS_STATE */
 				break;
 			}
 
-			if (rtw_get_passing_time_ms(start_time) > LPS_RPWM_WAIT_MS)
-			{
-				DBG_871X("%s: polling cpwm timeout! cpwm_orig=%02x, cpwm_now=%02x \n", __FUNCTION__, cpwm_orig, cpwm_now);
+			if (rtw_get_passing_time_ms(start_time) > LPS_RPWM_WAIT_MS) {
+				RTW_INFO("%s: polling cpwm timeout! cpwm_orig=%02x, cpwm_now=%02x\n", __FUNCTION__, cpwm_orig, cpwm_now);
 #ifdef DBG_CHECK_FW_PS_STATE
-				if(rtw_fw_ps_state(Adapter) == _FAIL)
-				{
-					DBG_871X("rpwm timeout and fw ps state in 32k\n");
+				if (rtw_fw_ps_state(Adapter) == _FAIL) {
+					RTW_INFO("rpwm timeout and fw ps state in 32k\n");
 					pdbgpriv->dbg_rpwm_timeout_fail_cnt++;
 				}
-#endif //DBG_CHECK_FW_PS_STATE
+#endif /* DBG_CHECK_FW_PS_STATE */
 				break;
 			}
 		} while (1);
-#endif // CONFIG_DETECT_CPWM_BY_POLLING
+#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
 
-	_exit_pwrlock(&pwrpriv->lock);
+		_exit_pwrlock(&pwrpriv->lock);
 #endif
 
 #ifdef CONFIG_P2P_PS
 		p2p_ps_wk_cmd(pri_padapter, P2P_PS_DISABLE, 0);
-#endif //CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
 #ifdef CONFIG_LPS
 		rtw_lps_ctrl_wk_cmd(pri_padapter, LPS_CTRL_LEAVE, 0);
 #endif
-	}
-	else
-	{
-		if(pwrpriv->rf_pwrstate== rf_off)
-		{
-			#ifdef CONFIG_AUTOSUSPEND
-			if(Adapter->registrypriv.usbss_enable)
-			{
-				#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+	} else {
+		if (pwrpriv->rf_pwrstate == rf_off) {
+#ifdef CONFIG_AUTOSUSPEND
+			if (Adapter->registrypriv.usbss_enable) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 				usb_disable_autosuspend(adapter_to_dvobj(Adapter)->pusbdev);
-				#elif (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,22) && LINUX_VERSION_CODE<=KERNEL_VERSION(2,6,34))
-				adapter_to_dvobj(Adapter)->pusbdev->autosuspend_disabled = Adapter->bDisableAutosuspend;//autosuspend disabled by the user
-				#endif
-			}
-			else
-			#endif
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 34))
+				adapter_to_dvobj(Adapter)->pusbdev->autosuspend_disabled = Adapter->bDisableAutosuspend;/* autosuspend disabled by the user */
+#endif
+			} else
+#endif
 			{
 #if defined(CONFIG_FWLPS_IN_IPS) || defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_RTL8188E)
-				#ifdef CONFIG_IPS
-				if(_FALSE == ips_leave(pri_padapter))
-				{
-					DBG_871X("======> ips_leave fail.............\n");			
-				}
-				#endif
-#endif //CONFIG_SWLPS_IN_IPS || (CONFIG_PLATFORM_SPRD && CONFIG_RTL8188E)
+#ifdef CONFIG_IPS
+				if (_FALSE == ips_leave(pri_padapter))
+					RTW_INFO("======> ips_leave fail.............\n");
+#endif
+#endif /* CONFIG_SWLPS_IN_IPS || (CONFIG_PLATFORM_SPRD && CONFIG_RTL8188E) */
 			}
 		}
 	}
 
-_func_exit_;
 }
 
-//
-// Description: Leave all power save mode: LPS, FwLPS, IPS if needed.
-// Move code to function by tynli. 2010.03.26. 
-//
+/*
+ * Description: Leave all power save mode: LPS, FwLPS, IPS if needed.
+ * Move code to function by tynli. 2010.03.26.
+ *   */
 void LeaveAllPowerSaveMode(IN PADAPTER Adapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(Adapter);
@@ -1334,19 +1314,17 @@ void LeaveAllPowerSaveMode(IN PADAPTER Adapter)
 	int n_assoc_iface = 0;
 	int i;
 
-_func_enter_;
 
-	//DBG_871X("%s.....\n",__FUNCTION__);
+	/* RTW_INFO("%s.....\n",__FUNCTION__); */
 
-	if (_FALSE == Adapter->bup)
-	{
-		DBG_871X(FUNC_ADPT_FMT ": bup=%d Skip!\n",
-			FUNC_ADPT_ARG(Adapter), Adapter->bup);
+	if (_FALSE == Adapter->bup) {
+		RTW_INFO(FUNC_ADPT_FMT ": bup=%d Skip!\n",
+			 FUNC_ADPT_ARG(Adapter), Adapter->bup);
 		return;
 	}
 
 	if (rtw_is_surprise_removed(Adapter)) {
-		DBG_871X(FUNC_ADPT_FMT ": bSurpriseRemoved=_TRUE Skip!\n", FUNC_ADPT_ARG(Adapter));
+		RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=_TRUE Skip!\n", FUNC_ADPT_ARG(Adapter));
 		return;
 	}
 
@@ -1355,15 +1333,21 @@ _func_enter_;
 			n_assoc_iface++;
 	}
 
-	if (n_assoc_iface)
-	{ //connect
+	if (n_assoc_iface) {
+		/* connect */
 #ifdef CONFIG_LPS_LCLK
 		enqueue = 1;
 #endif
 
 #ifdef CONFIG_P2P_PS
-		p2p_ps_wk_cmd(Adapter, P2P_PS_DISABLE, enqueue);
-#endif //CONFIG_P2P_PS
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			_adapter *iface = dvobj->padapters[i];
+			struct wifidirect_info *pwdinfo = &(iface->wdinfo);
+
+			if (pwdinfo->p2p_ps_mode > P2P_PS_NONE)
+				p2p_ps_wk_cmd(iface, P2P_PS_DISABLE, enqueue);
+		}
+#endif /* CONFIG_P2P_PS */
 
 #ifdef CONFIG_LPS
 		rtw_lps_ctrl_wk_cmd(Adapter, LPS_CTRL_LEAVE, enqueue);
@@ -1371,37 +1355,29 @@ _func_enter_;
 
 #ifdef CONFIG_LPS_LCLK
 		LPS_Leave_check(Adapter);
-#endif	
-	}
-	else
-	{
-		if(adapter_to_pwrctl(Adapter)->rf_pwrstate== rf_off)
-		{
-			#ifdef CONFIG_AUTOSUSPEND
-			if(Adapter->registrypriv.usbss_enable)
-			{
-				#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+#endif
+	} else {
+		if (adapter_to_pwrctl(Adapter)->rf_pwrstate == rf_off) {
+#ifdef CONFIG_AUTOSUSPEND
+			if (Adapter->registrypriv.usbss_enable) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 				usb_disable_autosuspend(adapter_to_dvobj(Adapter)->pusbdev);
-				#elif (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,22) && LINUX_VERSION_CODE<=KERNEL_VERSION(2,6,34))
-				adapter_to_dvobj(Adapter)->pusbdev->autosuspend_disabled = Adapter->bDisableAutosuspend;//autosuspend disabled by the user
-				#endif
-			}
-			else
-			#endif
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 34))
+				adapter_to_dvobj(Adapter)->pusbdev->autosuspend_disabled = Adapter->bDisableAutosuspend;/* autosuspend disabled by the user */
+#endif
+			} else
+#endif
 			{
 #if defined(CONFIG_FWLPS_IN_IPS) || defined(CONFIG_SWLPS_IN_IPS) || (defined(CONFIG_PLATFORM_SPRD) && defined(CONFIG_RTL8188E))
-				#ifdef CONFIG_IPS
-				if(_FALSE == ips_leave(Adapter))
-				{
-					DBG_871X("======> ips_leave fail.............\n");			
-				}
-				#endif
-#endif //CONFIG_SWLPS_IN_IPS || (CONFIG_PLATFORM_SPRD && CONFIG_RTL8188E)
-			}				
-		}	
+#ifdef CONFIG_IPS
+				if (_FALSE == ips_leave(Adapter))
+					RTW_INFO("======> ips_leave fail.............\n");
+#endif
+#endif /* CONFIG_SWLPS_IN_IPS || (CONFIG_PLATFORM_SPRD && CONFIG_RTL8188E) */
+			}
+		}
 	}
 
-_func_exit_;
 }
 
 #ifdef CONFIG_LPS_LCLK
@@ -1409,10 +1385,9 @@ void LPS_Leave_check(
 	PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrpriv;
-	u32	start_time;
+	systime	start_time;
 	u8	bReady;
 
-_func_enter_;
 
 	pwrpriv = adapter_to_pwrctl(padapter);
 
@@ -1420,36 +1395,31 @@ _func_enter_;
 	start_time = rtw_get_current_time();
 
 	rtw_yield_os();
-	
-	while(1)
-	{
+
+	while (1) {
 		_enter_pwrlock(&pwrpriv->lock);
 
 		if (rtw_is_surprise_removed(padapter)
-			|| (!rtw_is_hw_init_completed(padapter))
+		    || (!rtw_is_hw_init_completed(padapter))
 #ifdef CONFIG_USB_HCI
-			|| rtw_is_drv_stopped(padapter)
+		    || rtw_is_drv_stopped(padapter)
 #endif
-			|| (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
-			)
-		{
+		    || (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
+		   )
 			bReady = _TRUE;
-		}
 
 		_exit_pwrlock(&pwrpriv->lock);
 
-		if(_TRUE == bReady)
+		if (_TRUE == bReady)
 			break;
 
-		if(rtw_get_passing_time_ms(start_time)>100)
-		{
-			DBG_871X("Wait for cpwm event  than 100 ms!!!\n");
+		if (rtw_get_passing_time_ms(start_time) > 100) {
+			RTW_INFO("Wait for cpwm event  than 100 ms!!!\n");
 			break;
 		}
 		rtw_msleep_os(1);
 	}
 
-_func_exit_;
 }
 
 /*
@@ -1465,14 +1435,15 @@ void cpwm_int_hdl(
 {
 	struct pwrctrl_priv *pwrpriv;
 
-_func_enter_;
+	if (!padapter)
+		goto exit;
+
+	if (RTW_CANNOT_RUN(padapter))
+		goto exit;
 
 	pwrpriv = adapter_to_pwrctl(padapter);
 #if 0
 	if (pwrpriv->cpwm_tog == (preportpwrstate->state & PS_TOGGLE)) {
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-				 ("cpwm_int_hdl: tog(old)=0x%02x cpwm(new)=0x%02x toggle bit didn't change!?\n",
-				  pwrpriv->cpwm_tog, preportpwrstate->state));
 		goto exit;
 	}
 #endif
@@ -1480,19 +1451,17 @@ _func_enter_;
 	_enter_pwrlock(&pwrpriv->lock);
 
 #ifdef CONFIG_LPS_RPWM_TIMER
-	if (pwrpriv->rpwm < PS_STATE_S2)
-	{
-		DBG_871X("%s: Redundant CPWM Int. RPWM=0x%02X CPWM=0x%02x\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
+	if (pwrpriv->rpwm < PS_STATE_S2) {
+		RTW_INFO("%s: Redundant CPWM Int. RPWM=0x%02X CPWM=0x%02x\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
 		_exit_pwrlock(&pwrpriv->lock);
 		goto exit;
 	}
-#endif // CONFIG_LPS_RPWM_TIMER
+#endif /* CONFIG_LPS_RPWM_TIMER */
 
 	pwrpriv->cpwm = PS_STATE(preportpwrstate->state);
 	pwrpriv->cpwm_tog = preportpwrstate->state & PS_TOGGLE;
 
-	if (pwrpriv->cpwm >= PS_STATE_S2)
-	{
+	if (pwrpriv->cpwm >= PS_STATE_S2) {
 		if (pwrpriv->alives & CMD_ALIVE)
 			_rtw_up_sema(&padapter->cmdpriv.cmd_queue_sema);
 
@@ -1503,26 +1472,56 @@ _func_enter_;
 	_exit_pwrlock(&pwrpriv->lock);
 
 exit:
-	RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-			 ("cpwm_int_hdl: cpwm=0x%02x\n", pwrpriv->cpwm));
-
-_func_exit_;
+	return;
 }
 
 static void cpwm_event_callback(struct work_struct *work)
 {
 	struct pwrctrl_priv *pwrpriv = container_of(work, struct pwrctrl_priv, cpwm_event);
 	struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
-	_adapter *adapter = dvobj->padapters[IFACE_ID0];
+	_adapter *adapter = dvobj_get_primary_adapter(dvobj);
 	struct reportpwrstate_parm report;
 
-	//DBG_871X("%s\n",__FUNCTION__);
+	/* RTW_INFO("%s\n",__FUNCTION__); */
 
 	report.state = PS_STATE_S2;
 	cpwm_int_hdl(adapter, &report);
 }
 
+static void dma_event_callback(struct work_struct *work)
+{
+	struct pwrctrl_priv *pwrpriv = container_of(work, struct pwrctrl_priv, dma_event);
+	struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
+	_adapter *adapter = dvobj_get_primary_adapter(dvobj);
+
+	rtw_unregister_tx_alive(adapter);
+}
+
 #ifdef CONFIG_LPS_RPWM_TIMER
+
+#define DBG_CPWM_CHK_FAIL
+#if defined(DBG_CPWM_CHK_FAIL) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+#define CPU_EXCEPTION_CODE 0xFAFAFAFA
+static void rtw_cpwm_chk_fail_debug(_adapter *padapter)
+{
+	u32 cpu_state;
+
+	cpu_state = rtw_read32(padapter, 0x10FC);
+
+	RTW_INFO("[PS-DBG] Reg_10FC =0x%08x\n", cpu_state);
+	RTW_INFO("[PS-DBG] Reg_10F8 =0x%08x\n", rtw_read32(padapter, 0x10F8));
+
+	if (cpu_state == CPU_EXCEPTION_CODE) {
+		RTW_INFO("[PS-DBG] Reg_48C =0x%08x\n", rtw_read32(padapter, 0x48C));
+		RTW_INFO("[PS-DBG] Reg_490 =0x%08x\n", rtw_read32(padapter, 0x490));
+		RTW_INFO("[PS-DBG] Reg_494 =0x%08x\n", rtw_read32(padapter, 0x494));
+		RTW_INFO("[PS-DBG] Reg_498 =0x%08x\n", rtw_read32(padapter, 0x498));
+		RTW_INFO("[PS-DBG] Reg_49C =0x%08x\n", rtw_read32(padapter, 0x49C));
+		RTW_INFO("[PS-DBG] Reg_4A0 =0x%08x\n", rtw_read32(padapter, 0x4A0));
+		RTW_INFO("[PS-DBG] Reg_1BC =0x%08x\n", rtw_read32(padapter, 0x1BC));
+	}
+}
+#endif
 static void rpwmtimeout_workitem_callback(struct work_struct *work)
 {
 	PADAPTER padapter;
@@ -1532,27 +1531,35 @@ static void rpwmtimeout_workitem_callback(struct work_struct *work)
 
 	pwrpriv = container_of(work, struct pwrctrl_priv, rpwmtimeoutwi);
 	dvobj = pwrctl_to_dvobj(pwrpriv);
-	padapter = dvobj->padapters[IFACE_ID0];
-//	DBG_871X("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
+	padapter = dvobj_get_primary_adapter(dvobj);
+
+	if (!padapter)
+		return;
+
+	if (RTW_CANNOT_RUN(padapter))
+		return;
 
 	_enter_pwrlock(&pwrpriv->lock);
-	if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2))
-	{
-		DBG_871X("%s: rpwm=0x%02X cpwm=0x%02X CPWM done!\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
+	if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2)) {
+		RTW_INFO("%s: rpwm=0x%02X cpwm=0x%02X CPWM done!\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
 		goto exit;
 	}
 	_exit_pwrlock(&pwrpriv->lock);
 
-	if (rtw_read8(padapter, 0x100) != 0xEA)
-	{
+#if defined(DBG_CPWM_CHK_FAIL) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+	RTW_INFO("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
+	rtw_cpwm_chk_fail_debug(padapter);
+#endif
+
+	if (rtw_read8(padapter, 0x100) != 0xEA) {
 #if 1
 		struct reportpwrstate_parm report;
 
 		report.state = PS_STATE_S2;
-		DBG_871X("\n%s: FW already leave 32K!\n\n", __func__);
+		RTW_INFO("\n%s: FW already leave 32K!\n\n", __func__);
 		cpwm_int_hdl(padapter, &report);
 #else
-		DBG_871X("\n%s: FW already leave 32K!\n\n", __func__);
+		RTW_INFO("\n%s: FW already leave 32K!\n\n", __func__);
 		cpwm_event_callback(&pwrpriv->cpwm_event);
 #endif
 		return;
@@ -1560,9 +1567,8 @@ static void rpwmtimeout_workitem_callback(struct work_struct *work)
 
 	_enter_pwrlock(&pwrpriv->lock);
 
-	if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2))
-	{
-		DBG_871X("%s: cpwm=%d, nothing to do!\n", __func__, pwrpriv->cpwm);
+	if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2)) {
+		RTW_INFO("%s: cpwm=%d, nothing to do!\n", __func__, pwrpriv->cpwm);
 		goto exit;
 	}
 	pwrpriv->brpwmtimeout = _TRUE;
@@ -1584,17 +1590,22 @@ static void pwr_rpwm_timeout_handler(void *FunctionContext)
 
 	padapter = (PADAPTER)FunctionContext;
 	pwrpriv = adapter_to_pwrctl(padapter);
-	DBG_871X("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
+	if (!padapter)
+		return;
 
-	if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2))
-	{
-		DBG_871X("+%s: cpwm=%d, nothing to do!\n", __func__, pwrpriv->cpwm);
+	if (RTW_CANNOT_RUN(padapter))
+		return;
+
+	RTW_INFO("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
+
+	if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2)) {
+		RTW_INFO("+%s: cpwm=%d, nothing to do!\n", __func__, pwrpriv->cpwm);
 		return;
 	}
 
 	_set_workitem(&pwrpriv->rpwmtimeoutwi);
 }
-#endif // CONFIG_LPS_RPWM_TIMER
+#endif /* CONFIG_LPS_RPWM_TIMER */
 
 __inline static void register_task_alive(struct pwrctrl_priv *pwrctrl, u32 tag)
 {
@@ -1617,7 +1628,7 @@ __inline static void unregister_task_alive(struct pwrctrl_priv *pwrctrl, u32 tag
  *
  *	Constraint:
  *		1. this function will request pwrctrl->lock
- * 
+ *
  * Return Value:
  *	_SUCCESS	hardware is ready for I/O
  *	_FAIL		can't I/O right now
@@ -1628,7 +1639,6 @@ s32 rtw_register_task_alive(PADAPTER padapter, u32 task)
 	struct pwrctrl_priv *pwrctrl;
 	u8 pslv;
 
-_func_enter_;
 
 	res = _SUCCESS;
 	pwrctrl = adapter_to_pwrctl(padapter);
@@ -1638,14 +1648,9 @@ _func_enter_;
 
 	register_task_alive(pwrctrl, task);
 
-	if (pwrctrl->bFwCurrentInPSMode == _TRUE)
-	{
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-				 ("%s: task=0x%x cpwm=0x%02x alives=0x%08x\n",
-				  __FUNCTION__, task, pwrctrl->cpwm, pwrctrl->alives));
+	if (pwrctrl->bFwCurrentInPSMode == _TRUE) {
 
-		if (pwrctrl->cpwm < pslv)
-		{
+		if (pwrctrl->cpwm < pslv) {
 			if (pwrctrl->cpwm < PS_STATE_S2)
 				res = _FAIL;
 			if (pwrctrl->rpwm < pslv)
@@ -1656,16 +1661,14 @@ _func_enter_;
 	_exit_pwrlock(&pwrctrl->lock);
 
 #ifdef CONFIG_DETECT_CPWM_BY_POLLING
-	if (_FAIL == res)
-	{
+	if (_FAIL == res) {
 		if (pwrctrl->cpwm >= PS_STATE_S2)
 			res = _SUCCESS;
 	}
-#endif // CONFIG_DETECT_CPWM_BY_POLLING
+#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
 
-_func_exit_;
 
-	return res;	
+	return res;
 }
 
 /*
@@ -1683,15 +1686,13 @@ void rtw_unregister_task_alive(PADAPTER padapter, u32 task)
 	struct pwrctrl_priv *pwrctrl;
 	u8 pslv;
 
-_func_enter_;
 
 	pwrctrl = adapter_to_pwrctl(padapter);
 	pslv = PS_STATE_S0;
 
 #ifdef CONFIG_BT_COEXIST
 	if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
-		&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE))
-	{
+	    && (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
 		u8 val8;
 
 		val8 = rtw_btcoex_LpsVal(padapter);
@@ -1699,21 +1700,16 @@ _func_enter_;
 			pslv = PS_STATE_S2;
 
 	}
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 	_enter_pwrlock(&pwrctrl->lock);
 
 	unregister_task_alive(pwrctrl, task);
 
 	if ((pwrctrl->pwr_mode != PS_MODE_ACTIVE)
-		&& (pwrctrl->bFwCurrentInPSMode == _TRUE))
-	{
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-				 ("%s: cpwm=0x%02x alives=0x%08x\n",
-				  __FUNCTION__, pwrctrl->cpwm, pwrctrl->alives));
+	    && (pwrctrl->bFwCurrentInPSMode == _TRUE)) {
 
-		if (pwrctrl->cpwm > pslv)
-		{
+		if (pwrctrl->cpwm > pslv) {
 			if ((pslv >= PS_STATE_S2) || (pwrctrl->alives == 0))
 				rtw_set_rpwm(padapter, pslv);
 		}
@@ -1721,18 +1717,17 @@ _func_enter_;
 
 	_exit_pwrlock(&pwrctrl->lock);
 
-_func_exit_;
 }
 
 /*
  * Caller: rtw_xmit_thread
- * 
+ *
  * Check if the fw_pwrstate is okay for xmit.
  * If not (cpwm is less than S3), then the sub-routine
- * will raise the cpwm to be greater than or equal to S3. 
+ * will raise the cpwm to be greater than or equal to S3.
  *
  * Calling Context: Passive
- * 
+ *
  * Return Value:
  *	 _SUCCESS	rtw_xmit_thread can write fifo/txcmd afterwards.
  *	 _FAIL		rtw_xmit_thread can not do anything.
@@ -1743,7 +1738,6 @@ s32 rtw_register_tx_alive(PADAPTER padapter)
 	struct pwrctrl_priv *pwrctrl;
 	u8 pslv;
 
-_func_enter_;
 
 	res = _SUCCESS;
 	pwrctrl = adapter_to_pwrctl(padapter);
@@ -1753,14 +1747,9 @@ _func_enter_;
 
 	register_task_alive(pwrctrl, XMIT_ALIVE);
 
-	if (pwrctrl->bFwCurrentInPSMode == _TRUE)
-	{
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-				 ("rtw_register_tx_alive: cpwm=0x%02x alives=0x%08x\n",
-				  pwrctrl->cpwm, pwrctrl->alives));
+	if (pwrctrl->bFwCurrentInPSMode == _TRUE) {
 
-		if (pwrctrl->cpwm < pslv)
-		{
+		if (pwrctrl->cpwm < pslv) {
 			if (pwrctrl->cpwm < PS_STATE_S2)
 				res = _FAIL;
 			if (pwrctrl->rpwm < pslv)
@@ -1771,16 +1760,14 @@ _func_enter_;
 	_exit_pwrlock(&pwrctrl->lock);
 
 #ifdef CONFIG_DETECT_CPWM_BY_POLLING
-	if (_FAIL == res)
-	{
+	if (_FAIL == res) {
 		if (pwrctrl->cpwm >= PS_STATE_S2)
 			res = _SUCCESS;
 	}
-#endif // CONFIG_DETECT_CPWM_BY_POLLING
+#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
 
-_func_exit_;
 
-	return res;	
+	return res;
 }
 
 /*
@@ -1802,7 +1789,6 @@ s32 rtw_register_cmd_alive(PADAPTER padapter)
 	struct pwrctrl_priv *pwrctrl;
 	u8 pslv;
 
-_func_enter_;
 
 	res = _SUCCESS;
 	pwrctrl = adapter_to_pwrctl(padapter);
@@ -1812,14 +1798,9 @@ _func_enter_;
 
 	register_task_alive(pwrctrl, CMD_ALIVE);
 
-	if (pwrctrl->bFwCurrentInPSMode == _TRUE)
-	{
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_info_,
-				 ("rtw_register_cmd_alive: cpwm=0x%02x alives=0x%08x\n",
-				  pwrctrl->cpwm, pwrctrl->alives));
+	if (pwrctrl->bFwCurrentInPSMode == _TRUE) {
 
-		if (pwrctrl->cpwm < pslv)
-		{
+		if (pwrctrl->cpwm < pslv) {
 			if (pwrctrl->cpwm < PS_STATE_S2)
 				res = _FAIL;
 			if (pwrctrl->rpwm < pslv)
@@ -1830,14 +1811,12 @@ _func_enter_;
 	_exit_pwrlock(&pwrctrl->lock);
 
 #ifdef CONFIG_DETECT_CPWM_BY_POLLING
-	if (_FAIL == res)
-	{
+	if (_FAIL == res) {
 		if (pwrctrl->cpwm >= PS_STATE_S2)
 			res = _SUCCESS;
 	}
-#endif // CONFIG_DETECT_CPWM_BY_POLLING
+#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
 
-_func_exit_;
 
 	return res;
 }
@@ -1855,20 +1834,15 @@ s32 rtw_register_rx_alive(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrctrl;
 
-_func_enter_;
 
 	pwrctrl = adapter_to_pwrctl(padapter);
 
 	_enter_pwrlock(&pwrctrl->lock);
 
 	register_task_alive(pwrctrl, RECV_ALIVE);
-	RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-			 ("rtw_register_rx_alive: cpwm=0x%02x alives=0x%08x\n",
-			  pwrctrl->cpwm, pwrctrl->alives));
 
 	_exit_pwrlock(&pwrctrl->lock);
 
-_func_exit_;
 
 	return _SUCCESS;
 }
@@ -1886,20 +1860,15 @@ s32 rtw_register_evt_alive(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrctrl;
 
-_func_enter_;
 
 	pwrctrl = adapter_to_pwrctl(padapter);
 
 	_enter_pwrlock(&pwrctrl->lock);
 
 	register_task_alive(pwrctrl, EVT_ALIVE);
-	RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-			 ("rtw_register_evt_alive: cpwm=0x%02x alives=0x%08x\n",
-			  pwrctrl->cpwm, pwrctrl->alives));
 
 	_exit_pwrlock(&pwrctrl->lock);
 
-_func_exit_;
 
 	return _SUCCESS;
 }
@@ -1914,17 +1883,17 @@ _func_exit_;
 void rtw_unregister_tx_alive(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrctrl;
-	u8 pslv;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	u8 pslv, i;
 
-_func_enter_;
 
 	pwrctrl = adapter_to_pwrctl(padapter);
 	pslv = PS_STATE_S0;
 
 #ifdef CONFIG_BT_COEXIST
 	if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
-		&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE))
-	{
+	    && (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
 		u8 val8;
 
 		val8 = rtw_btcoex_LpsVal(padapter);
@@ -1932,35 +1901,27 @@ _func_enter_;
 			pslv = PS_STATE_S2;
 
 	}
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 #ifdef CONFIG_P2P_PS
-	if(padapter->wdinfo.p2p_ps_mode > P2P_PS_NONE)
-	{
-		pslv = PS_STATE_S2;
-	}
-#ifdef CONFIG_CONCURRENT_MODE
-	else if(rtw_buddy_adapter_up(padapter))
-	{
-		if(padapter->pbuddy_adapter->wdinfo.p2p_ps_mode > P2P_PS_NONE)
-			pslv = PS_STATE_S2;
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			if (iface->wdinfo.p2p_ps_mode > P2P_PS_NONE) {
+				pslv = PS_STATE_S2;
+				break;
+			}
+		}
 	}
 #endif
-#endif
-
 	_enter_pwrlock(&pwrctrl->lock);
 
 	unregister_task_alive(pwrctrl, XMIT_ALIVE);
 
 	if ((pwrctrl->pwr_mode != PS_MODE_ACTIVE)
-		&& (pwrctrl->bFwCurrentInPSMode == _TRUE))
-	{
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-				 ("%s: cpwm=0x%02x alives=0x%08x\n",
-				  __FUNCTION__, pwrctrl->cpwm, pwrctrl->alives));
+	    && (pwrctrl->bFwCurrentInPSMode == _TRUE)) {
 
-		if (pwrctrl->cpwm > pslv)
-		{
+		if (pwrctrl->cpwm > pslv) {
 			if ((pslv >= PS_STATE_S2) || (pwrctrl->alives == 0))
 				rtw_set_rpwm(padapter, pslv);
 		}
@@ -1968,7 +1929,6 @@ _func_enter_;
 
 	_exit_pwrlock(&pwrctrl->lock);
 
-_func_exit_;
 }
 
 /*
@@ -1980,18 +1940,18 @@ _func_exit_;
  */
 void rtw_unregister_cmd_alive(PADAPTER padapter)
 {
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct pwrctrl_priv *pwrctrl;
-	u8 pslv;
+	u8 pslv, i;
 
-_func_enter_;
 
 	pwrctrl = adapter_to_pwrctl(padapter);
 	pslv = PS_STATE_S0;
 
 #ifdef CONFIG_BT_COEXIST
 	if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
-		&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE))
-	{
+	    && (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
 		u8 val8;
 
 		val8 = rtw_btcoex_LpsVal(padapter);
@@ -1999,20 +1959,18 @@ _func_enter_;
 			pslv = PS_STATE_S2;
 
 	}
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 #ifdef CONFIG_P2P_PS
-	if(padapter->wdinfo.p2p_ps_mode > P2P_PS_NONE)
-	{
-		pslv = PS_STATE_S2;
-	}
-#ifdef CONFIG_CONCURRENT_MODE
-	else if(rtw_buddy_adapter_up(padapter))
-	{
-		if(padapter->pbuddy_adapter->wdinfo.p2p_ps_mode > P2P_PS_NONE)
-			pslv = PS_STATE_S2;
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			if (iface->wdinfo.p2p_ps_mode > P2P_PS_NONE) {
+				pslv = PS_STATE_S2;
+				break;
+			}
+		}
 	}
-#endif
 #endif
 
 	_enter_pwrlock(&pwrctrl->lock);
@@ -2020,14 +1978,9 @@ _func_enter_;
 	unregister_task_alive(pwrctrl, CMD_ALIVE);
 
 	if ((pwrctrl->pwr_mode != PS_MODE_ACTIVE)
-		&& (pwrctrl->bFwCurrentInPSMode == _TRUE))
-	{
-		RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_info_,
-				 ("%s: cpwm=0x%02x alives=0x%08x\n",
-				  __FUNCTION__, pwrctrl->cpwm, pwrctrl->alives));
+	    && (pwrctrl->bFwCurrentInPSMode == _TRUE)) {
 
-		if (pwrctrl->cpwm > pslv)
-		{
+		if (pwrctrl->cpwm > pslv) {
 			if ((pslv >= PS_STATE_S2) || (pwrctrl->alives == 0))
 				rtw_set_rpwm(padapter, pslv);
 		}
@@ -2035,7 +1988,6 @@ _func_enter_;
 
 	_exit_pwrlock(&pwrctrl->lock);
 
-_func_exit_;
 }
 
 /*
@@ -2045,7 +1997,6 @@ void rtw_unregister_rx_alive(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrctrl;
 
-_func_enter_;
 
 	pwrctrl = adapter_to_pwrctl(padapter);
 
@@ -2053,87 +2004,87 @@ _func_enter_;
 
 	unregister_task_alive(pwrctrl, RECV_ALIVE);
 
-	RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-			 ("rtw_unregister_rx_alive: cpwm=0x%02x alives=0x%08x\n",
-			  pwrctrl->cpwm, pwrctrl->alives));
 
 	_exit_pwrlock(&pwrctrl->lock);
 
-_func_exit_;
 }
 
 void rtw_unregister_evt_alive(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrctrl;
 
-_func_enter_;
 
 	pwrctrl = adapter_to_pwrctl(padapter);
 
 	unregister_task_alive(pwrctrl, EVT_ALIVE);
 
-	RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-			 ("rtw_unregister_evt_alive: cpwm=0x%02x alives=0x%08x\n",
-			  pwrctrl->cpwm, pwrctrl->alives));
 
 	_exit_pwrlock(&pwrctrl->lock);
 
-_func_exit_;
 }
 #endif	/* CONFIG_LPS_LCLK */
 
 #ifdef CONFIG_RESUME_IN_WORKQUEUE
-static void resume_workitem_callback(struct work_struct *work);
-#endif //CONFIG_RESUME_IN_WORKQUEUE
+	static void resume_workitem_callback(struct work_struct *work);
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
 
 void rtw_init_pwrctrl_priv(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
-	int i = 0;
+	struct registry_priv  *registry_par = &padapter->registrypriv;
+
 	u8 val8 = 0;
 
 #if defined(CONFIG_CONCURRENT_MODE)
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
+	if (!is_primary_adapter(padapter))
 		return;
 #endif
 
-_func_enter_;
 
 #ifdef PLATFORM_WINDOWS
-	pwrctrlpriv->pnp_current_pwr_state=NdisDeviceStateD0;
+	pwrctrlpriv->pnp_current_pwr_state = NdisDeviceStateD0;
 #endif
 
 	_init_pwrlock(&pwrctrlpriv->lock);
 	_init_pwrlock(&pwrctrlpriv->check_32k_lock);
 	pwrctrlpriv->rf_pwrstate = rf_on;
-	pwrctrlpriv->ips_enter_cnts=0;
-	pwrctrlpriv->ips_leave_cnts=0;
-	pwrctrlpriv->lps_enter_cnts=0;
-	pwrctrlpriv->lps_leave_cnts=0;
+	pwrctrlpriv->ips_enter_cnts = 0;
+	pwrctrlpriv->ips_leave_cnts = 0;
+	pwrctrlpriv->lps_enter_cnts = 0;
+	pwrctrlpriv->lps_leave_cnts = 0;
 	pwrctrlpriv->bips_processing = _FALSE;
 
 	pwrctrlpriv->ips_mode = padapter->registrypriv.ips_mode;
 	pwrctrlpriv->ips_mode_req = padapter->registrypriv.ips_mode;
+	pwrctrlpriv->ips_deny_time = rtw_get_current_time();
+	pwrctrlpriv->lps_level = padapter->registrypriv.lps_level;
 
 	pwrctrlpriv->pwr_state_check_interval = RTW_PWR_STATE_CHK_INTERVAL;
 	pwrctrlpriv->pwr_state_check_cnts = 0;
+	#ifdef CONFIG_AUTOSUSPEND
 	pwrctrlpriv->bInternalAutoSuspend = _FALSE;
+	#endif
 	pwrctrlpriv->bInSuspend = _FALSE;
 	pwrctrlpriv->bkeepfwalive = _FALSE;
 
 #ifdef CONFIG_AUTOSUSPEND
 #ifdef SUPPORT_HW_RFOFF_DETECTED
-	pwrctrlpriv->pwr_state_check_interval = (pwrctrlpriv->bHWPwrPindetect) ?1000:2000;		
+	pwrctrlpriv->pwr_state_check_interval = (pwrctrlpriv->bHWPwrPindetect) ? 1000 : 2000;
 #endif
 #endif
 
 	pwrctrlpriv->LpsIdleCount = 0;
-	//pwrctrlpriv->FWCtrlPSMode =padapter->registrypriv.power_mgnt;// PS_MODE_MIN;
+
+#ifdef CONFIG_LPS_PG
+	pwrctrlpriv->lpspg_rsvd_page_locate = 0;
+#endif
+
+	/* pwrctrlpriv->FWCtrlPSMode =padapter->registrypriv.power_mgnt; */ /* PS_MODE_MIN; */
 	if (padapter->registrypriv.mp_mode == 1)
-		pwrctrlpriv->power_mgnt =PS_MODE_ACTIVE ;
-	else	
-		pwrctrlpriv->power_mgnt =padapter->registrypriv.power_mgnt;// PS_MODE_MIN;
-	pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt)?_TRUE:_FALSE;
+		pwrctrlpriv->power_mgnt = PS_MODE_ACTIVE ;
+	else
+		pwrctrlpriv->power_mgnt = padapter->registrypriv.power_mgnt; /* PS_MODE_MIN; */
+	pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt) ? _TRUE : _FALSE;
 
 	pwrctrlpriv->bFwCurrentInPSMode = _FALSE;
 
@@ -2152,59 +2103,74 @@ _func_enter_;
 
 	_init_workitem(&pwrctrlpriv->cpwm_event, cpwm_event_callback, NULL);
 
+	_init_workitem(&pwrctrlpriv->dma_event, dma_event_callback, NULL);
+
 #ifdef CONFIG_LPS_RPWM_TIMER
 	pwrctrlpriv->brpwmtimeout = _FALSE;
 	_init_workitem(&pwrctrlpriv->rpwmtimeoutwi, rpwmtimeout_workitem_callback, NULL);
-	_init_timer(&pwrctrlpriv->pwr_rpwm_timer, padapter->pnetdev, pwr_rpwm_timeout_handler, padapter);
-#endif // CONFIG_LPS_RPWM_TIMER
-#endif // CONFIG_LPS_LCLK
+	rtw_init_timer(&pwrctrlpriv->pwr_rpwm_timer, padapter, pwr_rpwm_timeout_handler, padapter);
+#endif /* CONFIG_LPS_RPWM_TIMER */
+#endif /* CONFIG_LPS_LCLK */
 
-	rtw_init_timer(&pwrctrlpriv->pwr_state_check_timer, padapter, pwr_state_check_handler);
+	rtw_init_timer(&pwrctrlpriv->pwr_state_check_timer, padapter, pwr_state_check_handler, padapter);
 
 	pwrctrlpriv->wowlan_mode = _FALSE;
 	pwrctrlpriv->wowlan_ap_mode = _FALSE;
 	pwrctrlpriv->wowlan_p2p_mode = _FALSE;
+	pwrctrlpriv->wowlan_in_resume = _FALSE;
+	pwrctrlpriv->wowlan_last_wake_reason = 0;
 
-	#ifdef CONFIG_RESUME_IN_WORKQUEUE
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
 	_init_workitem(&pwrctrlpriv->resume_work, resume_workitem_callback, NULL);
 	pwrctrlpriv->rtw_workqueue = create_singlethread_workqueue("rtw_workqueue");
-	#endif //CONFIG_RESUME_IN_WORKQUEUE
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
 
-	#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
+#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
 	pwrctrlpriv->early_suspend.suspend = NULL;
 	rtw_register_early_suspend(pwrctrlpriv);
-	#endif //CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER
+#endif /* CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER */
 
 #ifdef CONFIG_GPIO_WAKEUP
 	/*default low active*/
 	pwrctrlpriv->is_high_active = HIGH_ACTIVE;
+
+	#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
+	if (pwrctrlpriv->is_high_active == 0)
+		rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
+	else
+		rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
+	#else
 	val8 = (pwrctrlpriv->is_high_active == 0) ? 1 : 0;
-	rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
 	rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
-	DBG_871X("%s: set GPIO_%d %d as default.\n",
+	RTW_INFO("%s: set GPIO_%d %d as default.\n",
 		 __func__, WAKEUP_GPIO_IDX, val8);
+	#endif /*CONFIG_WAKEUP_GPIO_INPUT_MODE*/
 #endif /* CONFIG_GPIO_WAKEUP */
 
 #ifdef CONFIG_WOWLAN
-	pwrctrlpriv->wowlan_pattern_idx = 0;
-	for (i = 0 ; i < MAX_WKFM_NUM; i++) {
-		_rtw_memset(pwrctrlpriv->patterns[i].content, '\0',
-				sizeof(pwrctrlpriv->patterns[i].content));
-		_rtw_memset(pwrctrlpriv->patterns[i].mask, '\0',
-				sizeof(pwrctrlpriv->patterns[i].mask));
-		pwrctrlpriv->patterns[i].len = 0;
-	}
 
+	if (registry_par->wakeup_event & BIT(1))
+		pwrctrlpriv->default_patterns_en = _TRUE;
+	else
+		pwrctrlpriv->default_patterns_en = _FALSE;
+
+	rtw_wow_pattern_sw_reset(padapter);
 #ifdef CONFIG_PNO_SUPPORT
 	pwrctrlpriv->pno_inited = _FALSE;
 	pwrctrlpriv->pnlo_info = NULL;
 	pwrctrlpriv->pscan_info = NULL;
 	pwrctrlpriv->pno_ssid_list = NULL;
-	pwrctrlpriv->pno_in_resume = _TRUE;
 #endif /* CONFIG_PNO_SUPPORT */
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+	_rtw_mutex_init(&pwrctrlpriv->wowlan_pattern_cam_mutex);
+#endif
+	pwrctrlpriv->wowlan_aoac_rpt_loc = 0;
 #endif /* CONFIG_WOWLAN */
 
-_func_exit_;
+#ifdef CONFIG_LPS_POFF
+	rtw_hal_set_hwreg(padapter, HW_VAR_LPS_POFF_INIT, 0);
+#endif
+
 
 }
 
@@ -2214,21 +2180,32 @@ void rtw_free_pwrctrl_priv(PADAPTER adapter)
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(adapter);
 
 #if defined(CONFIG_CONCURRENT_MODE)
-	if (adapter->adapter_type != PRIMARY_ADAPTER)
+	if (!is_primary_adapter(adapter))
 		return;
-#endif	
+#endif
 
-_func_enter_;
 
-	//_rtw_memset((unsigned char *)pwrctrlpriv, 0, sizeof(struct pwrctrl_priv));
+	/* _rtw_memset((unsigned char *)pwrctrlpriv, 0, sizeof(struct pwrctrl_priv)); */
 
 
-	#ifdef CONFIG_RESUME_IN_WORKQUEUE
-	if (pwrctrlpriv->rtw_workqueue) { 
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+	if (pwrctrlpriv->rtw_workqueue) {
 		flush_workqueue(pwrctrlpriv->rtw_workqueue);
 		destroy_workqueue(pwrctrlpriv->rtw_workqueue);
 	}
+#endif
+
+#ifdef CONFIG_LPS_POFF
+	rtw_hal_set_hwreg(adapter, HW_VAR_LPS_POFF_DEINIT, 0);
+#endif
+
+#ifdef CONFIG_LPS_LCLK
+	_cancel_workitem_sync(&pwrctrlpriv->cpwm_event);
+	_cancel_workitem_sync(&pwrctrlpriv->dma_event);
+	#ifdef CONFIG_LPS_RPWM_TIMER
+	_cancel_workitem_sync(&pwrctrlpriv->rpwmtimeoutwi);
 	#endif
+#endif /* CONFIG_LPS_LCLK */
 
 #ifdef CONFIG_WOWLAN
 #ifdef CONFIG_PNO_SUPPORT
@@ -2241,16 +2218,19 @@ _func_enter_;
 	if (pwrctrlpriv->pno_ssid_list != NULL)
 		printk("****** pno_ssid_list memory leak********\n");
 #endif
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+	_rtw_mutex_free(&pwrctrlpriv->wowlan_pattern_cam_mutex);
+#endif
+
 #endif /* CONFIG_WOWLAN */
 
-	#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
+#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
 	rtw_unregister_early_suspend(pwrctrlpriv);
-	#endif //CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER
+#endif /* CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER */
 
 	_free_pwrlock(&pwrctrlpriv->lock);
 	_free_pwrlock(&pwrctrlpriv->check_32k_lock);
 
-_func_exit_;
 }
 
 #ifdef CONFIG_RESUME_IN_WORKQUEUE
@@ -2260,9 +2240,9 @@ static void resume_workitem_callback(struct work_struct *work)
 {
 	struct pwrctrl_priv *pwrpriv = container_of(work, struct pwrctrl_priv, resume_work);
 	struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
-	_adapter *adapter = dvobj->padapters[IFACE_ID0];
+	_adapter *adapter = dvobj_get_primary_adapter(dvobj);
 
-	DBG_871X("%s\n",__FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	rtw_resume_process(adapter);
 
@@ -2271,18 +2251,18 @@ static void resume_workitem_callback(struct work_struct *work)
 
 void rtw_resume_in_workqueue(struct pwrctrl_priv *pwrpriv)
 {
-	// accquire system's suspend lock preventing from falliing asleep while resume in workqueue
-	//rtw_lock_suspend();
+	/* accquire system's suspend lock preventing from falliing asleep while resume in workqueue */
+	/* rtw_lock_suspend(); */
 
 	rtw_resume_lock_suspend();
-	
-	#if 1
-	queue_work(pwrpriv->rtw_workqueue, &pwrpriv->resume_work);	
-	#else
+
+#if 1
+	queue_work(pwrpriv->rtw_workqueue, &pwrpriv->resume_work);
+#else
 	_set_workitem(&pwrpriv->resume_work);
-	#endif
+#endif
 }
-#endif //CONFIG_RESUME_IN_WORKQUEUE
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
 
 #if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
 inline bool rtw_is_earlysuspend_registered(struct pwrctrl_priv *pwrpriv)
@@ -2306,7 +2286,7 @@ extern int rtw_resume_process(_adapter *padapter);
 static void rtw_early_suspend(struct early_suspend *h)
 {
 	struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
-	DBG_871X("%s\n",__FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	rtw_set_do_late_resume(pwrpriv, _FALSE);
 }
@@ -2315,11 +2295,11 @@ static void rtw_late_resume(struct early_suspend *h)
 {
 	struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
 	struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
-	_adapter *adapter = dvobj->padapters[IFACE_ID0];
+	_adapter *adapter = dvobj_get_primary_adapter(dvobj);
 
-	DBG_871X("%s\n",__FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	if(pwrpriv->do_late_resume) {
+	if (pwrpriv->do_late_resume) {
 		rtw_set_do_late_resume(pwrpriv, _FALSE);
 		rtw_resume_process(adapter);
 	}
@@ -2327,39 +2307,39 @@ static void rtw_late_resume(struct early_suspend *h)
 
 void rtw_register_early_suspend(struct pwrctrl_priv *pwrpriv)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	//jeff: set the early suspend level before blank screen, so we wll do late resume after scree is lit
+	/* jeff: set the early suspend level before blank screen, so we wll do late resume after scree is lit */
 	pwrpriv->early_suspend.level = EARLY_SUSPEND_LEVEL_BLANK_SCREEN - 20;
 	pwrpriv->early_suspend.suspend = rtw_early_suspend;
 	pwrpriv->early_suspend.resume = rtw_late_resume;
-	register_early_suspend(&pwrpriv->early_suspend);	
+	register_early_suspend(&pwrpriv->early_suspend);
+
 
-	
 }
 
 void rtw_unregister_early_suspend(struct pwrctrl_priv *pwrpriv)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	rtw_set_do_late_resume(pwrpriv, _FALSE);
 
-	if (pwrpriv->early_suspend.suspend) 
+	if (pwrpriv->early_suspend.suspend)
 		unregister_early_suspend(&pwrpriv->early_suspend);
 
 	pwrpriv->early_suspend.suspend = NULL;
 	pwrpriv->early_suspend.resume = NULL;
 }
-#endif //CONFIG_HAS_EARLYSUSPEND
+#endif /* CONFIG_HAS_EARLYSUSPEND */
 
 #ifdef CONFIG_ANDROID_POWER
 #if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-extern int rtw_resume_process(PADAPTER padapter);
+	extern int rtw_resume_process(PADAPTER padapter);
 #endif
 static void rtw_early_suspend(android_early_suspend_t *h)
 {
 	struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
-	DBG_871X("%s\n",__FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	rtw_set_do_late_resume(pwrpriv, _FALSE);
 }
@@ -2368,47 +2348,47 @@ static void rtw_late_resume(android_early_suspend_t *h)
 {
 	struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
 	struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
-	_adapter *adapter = dvobj->padapters[IFACE_ID0];
+	_adapter *adapter = dvobj_get_primary_adapter(dvobj);
 
-	DBG_871X("%s\n",__FUNCTION__);
-	if(pwrpriv->do_late_resume) {
-		#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	RTW_INFO("%s\n", __FUNCTION__);
+	if (pwrpriv->do_late_resume) {
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 		rtw_set_do_late_resume(pwrpriv, _FALSE);
 		rtw_resume_process(adapter);
-		#endif
+#endif
 	}
 }
 
 void rtw_register_early_suspend(struct pwrctrl_priv *pwrpriv)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	//jeff: set the early suspend level before blank screen, so we wll do late resume after scree is lit
+	/* jeff: set the early suspend level before blank screen, so we wll do late resume after scree is lit */
 	pwrpriv->early_suspend.level = ANDROID_EARLY_SUSPEND_LEVEL_BLANK_SCREEN - 20;
 	pwrpriv->early_suspend.suspend = rtw_early_suspend;
 	pwrpriv->early_suspend.resume = rtw_late_resume;
-	android_register_early_suspend(&pwrpriv->early_suspend);	
+	android_register_early_suspend(&pwrpriv->early_suspend);
 }
 
 void rtw_unregister_early_suspend(struct pwrctrl_priv *pwrpriv)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	rtw_set_do_late_resume(pwrpriv, _FALSE);
 
-	if (pwrpriv->early_suspend.suspend) 
+	if (pwrpriv->early_suspend.suspend)
 		android_unregister_early_suspend(&pwrpriv->early_suspend);
 
 	pwrpriv->early_suspend.suspend = NULL;
 	pwrpriv->early_suspend.resume = NULL;
 }
-#endif //CONFIG_ANDROID_POWER
+#endif /* CONFIG_ANDROID_POWER */
 
-u8 rtw_interface_ps_func(_adapter *padapter,HAL_INTF_PS_FUNC efunc_id,u8* val)
+u8 rtw_interface_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val)
 {
 	u8 bResult = _TRUE;
-	rtw_hal_intf_ps_func(padapter,efunc_id,val);
-	
+	rtw_hal_intf_ps_func(padapter, efunc_id, val);
+
 	return bResult;
 }
 
@@ -2433,7 +2413,7 @@ int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)
 	struct mlme_priv *pmlmepriv;
 	int ret = _SUCCESS;
 	int i;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 
 	/* for LPS */
 	LeaveAllPowerSaveMode(padapter);
@@ -2442,113 +2422,110 @@ int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)
 	padapter = GET_PRIMARY_ADAPTER(padapter);
 	pmlmepriv = &padapter->mlmepriv;
 
-	if (pwrpriv->ips_deny_time < rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms))
+	if (rtw_time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
 		pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms);
 
 
 	if (pwrpriv->ps_processing) {
-		DBG_871X("%s wait ps_processing...\n", __func__);
+		RTW_INFO("%s wait ps_processing...\n", __func__);
 		while (pwrpriv->ps_processing && rtw_get_passing_time_ms(start) <= 3000)
 			rtw_msleep_os(10);
 		if (pwrpriv->ps_processing)
-			DBG_871X("%s wait ps_processing timeout\n", __func__);
+			RTW_INFO("%s wait ps_processing timeout\n", __func__);
 		else
-			DBG_871X("%s wait ps_processing done\n", __func__);
+			RTW_INFO("%s wait ps_processing done\n", __func__);
 	}
 
 #ifdef DBG_CONFIG_ERROR_DETECT
 	if (rtw_hal_sreset_inprogress(padapter)) {
-		DBG_871X("%s wait sreset_inprogress...\n", __func__);
+		RTW_INFO("%s wait sreset_inprogress...\n", __func__);
 		while (rtw_hal_sreset_inprogress(padapter) && rtw_get_passing_time_ms(start) <= 4000)
 			rtw_msleep_os(10);
 		if (rtw_hal_sreset_inprogress(padapter))
-			DBG_871X("%s wait sreset_inprogress timeout\n", __func__);
+			RTW_INFO("%s wait sreset_inprogress timeout\n", __func__);
 		else
-			DBG_871X("%s wait sreset_inprogress done\n", __func__);
+			RTW_INFO("%s wait sreset_inprogress done\n", __func__);
 	}
 #endif
 
-	if (pwrpriv->bInternalAutoSuspend == _FALSE && pwrpriv->bInSuspend) {
-		DBG_871X("%s wait bInSuspend...\n", __func__);
-		while (pwrpriv->bInSuspend 
-			&& ((rtw_get_passing_time_ms(start) <= 3000 && !rtw_is_do_late_resume(pwrpriv))
-				|| (rtw_get_passing_time_ms(start) <= 500 && rtw_is_do_late_resume(pwrpriv)))
+	if (pwrpriv->bInSuspend
+		#ifdef CONFIG_AUTOSUSPEND
+		&& pwrpriv->bInternalAutoSuspend == _FALSE
+		#endif
 		) {
+		RTW_INFO("%s wait bInSuspend...\n", __func__);
+		while (pwrpriv->bInSuspend
+		       && ((rtw_get_passing_time_ms(start) <= 3000 && !rtw_is_do_late_resume(pwrpriv))
+			|| (rtw_get_passing_time_ms(start) <= 500 && rtw_is_do_late_resume(pwrpriv)))
+		      )
 			rtw_msleep_os(10);
-		}
 		if (pwrpriv->bInSuspend)
-			DBG_871X("%s wait bInSuspend timeout\n", __func__);
+			RTW_INFO("%s wait bInSuspend timeout\n", __func__);
 		else
-			DBG_871X("%s wait bInSuspend done\n", __func__);
+			RTW_INFO("%s wait bInSuspend done\n", __func__);
 	}
 
-	//System suspend is not allowed to wakeup
-	if((pwrpriv->bInternalAutoSuspend == _FALSE) && (_TRUE == pwrpriv->bInSuspend )){
+	/* System suspend is not allowed to wakeup */
+	if ((_TRUE == pwrpriv->bInSuspend)
+		#ifdef CONFIG_AUTOSUSPEND
+		&& (pwrpriv->bInternalAutoSuspend == _FALSE)
+		#endif
+	) {
 		ret = _FAIL;
 		goto exit;
 	}
-
-	//block???
-	if((pwrpriv->bInternalAutoSuspend == _TRUE)  && (padapter->net_closed == _TRUE)) {
+#ifdef CONFIG_AUTOSUSPEND
+	/* usb autosuspend block??? */
+	if ((pwrpriv->bInternalAutoSuspend == _TRUE)  && (padapter->net_closed == _TRUE)) {
 		ret = _FAIL;
 		goto exit;
 	}
-
-	//I think this should be check in IPS, LPS, autosuspend functions...
-	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
-	{
-#if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
-		if(_TRUE==pwrpriv->bInternalAutoSuspend){
-			if(0==pwrpriv->autopm_cnt){
-			#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,33))				
-				if (usb_autopm_get_interface(adapter_to_dvobj(padapter)->pusbintf) < 0) 
-				{
-					DBG_871X( "can't get autopm: \n");
-				}			
-			#elif (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,20))				
+#endif
+	/* I think this should be check in IPS, LPS, autosuspend functions... */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
+		if (_TRUE == pwrpriv->bInternalAutoSuspend) {
+			if (0 == pwrpriv->autopm_cnt) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+				if (usb_autopm_get_interface(adapter_to_dvobj(padapter)->pusbintf) < 0)
+					RTW_INFO("can't get autopm:\n");
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
 				usb_autopm_disable(adapter_to_dvobj(padapter)->pusbintf);
-			#else
+#else
 				usb_autoresume_device(adapter_to_dvobj(padapter)->pusbdev, 1);
-			#endif
-			pwrpriv->autopm_cnt++;
+#endif
+				pwrpriv->autopm_cnt++;
 			}
-#endif	//#if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
-		ret = _SUCCESS;
-		goto exit;
-#if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
+#endif	/* #if defined (CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND) */
+			ret = _SUCCESS;
+			goto exit;
+#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
 		}
-#endif	//#if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND)
-	}	
+#endif	/* #if defined (CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND) */
+	}
 
-	if(rf_off == pwrpriv->rf_pwrstate )
-	{		
+	if (rf_off == pwrpriv->rf_pwrstate) {
 #ifdef CONFIG_USB_HCI
 #ifdef CONFIG_AUTOSUSPEND
-		 if(pwrpriv->brfoffbyhw==_TRUE)
-		{
-			DBG_8192C("hw still in rf_off state ...........\n");
+		if (pwrpriv->brfoffbyhw == _TRUE) {
+			RTW_INFO("hw still in rf_off state ...........\n");
 			ret = _FAIL;
 			goto exit;
-		}
-		else if(padapter->registrypriv.usbss_enable)
-		{
-			DBG_8192C("%s call autoresume_enter....\n",__FUNCTION__);
-			if(_FAIL ==  autoresume_enter(padapter))
-			{
-				DBG_8192C("======> autoresume fail.............\n");
+		} else if (padapter->registrypriv.usbss_enable) {
+			RTW_INFO("%s call autoresume_enter....\n", __FUNCTION__);
+			if (_FAIL ==  autoresume_enter(padapter)) {
+				RTW_INFO("======> autoresume fail.............\n");
 				ret = _FAIL;
 				goto exit;
-			}	
-		}
-		else
+			}
+		} else
 #endif
 #endif
 		{
 #ifdef CONFIG_IPS
-			DBG_8192C("%s call ips_leave....\n",__FUNCTION__);
-			if(_FAIL ==  ips_leave(padapter))
-			{
-				DBG_8192C("======> ips_leave fail.............\n");
+			RTW_INFO("%s call ips_leave....\n", __FUNCTION__);
+			if (_FAIL ==  ips_leave(padapter)) {
+				RTW_INFO("======> ips_leave fail.............\n");
 				ret = _FAIL;
 				goto exit;
 			}
@@ -2556,22 +2533,22 @@ int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)
 		}
 	}
 
-	//TODO: the following checking need to be merged...
+	/* TODO: the following checking need to be merged... */
 	if (rtw_is_drv_stopped(padapter)
-		|| !padapter->bup
-		|| !rtw_is_hw_init_completed(padapter)
-	) {
-		DBG_8192C("%s: bDriverStopped=%s, bup=%d, hw_init_completed=%u\n"
-			, caller
-			, rtw_is_drv_stopped(padapter)?"True":"False"
-			, padapter->bup
-			, rtw_get_hw_init_completed(padapter));
-		ret= _FALSE;
+	    || !padapter->bup
+	    || !rtw_is_hw_init_completed(padapter)
+	   ) {
+		RTW_INFO("%s: bDriverStopped=%s, bup=%d, hw_init_completed=%u\n"
+			 , caller
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			 , padapter->bup
+			 , rtw_get_hw_init_completed(padapter));
+		ret = _FALSE;
 		goto exit;
 	}
 
 exit:
-	if (pwrpriv->ips_deny_time < rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms))
+	if (rtw_time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
 		pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms);
 	return ret;
 
@@ -2579,29 +2556,33 @@ exit:
 
 int rtw_pm_set_lps(_adapter *padapter, u8 mode)
 {
-	int	ret = 0;	
+	int	ret = 0;
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
-	
-	if ( mode < PS_MODE_NUM )
-	{
-		if(pwrctrlpriv->power_mgnt !=mode)
-		{
-			if(PS_MODE_ACTIVE == mode)
-			{
+
+	if (mode < PS_MODE_NUM) {
+		if (pwrctrlpriv->power_mgnt != mode) {
+			if (PS_MODE_ACTIVE == mode)
 				LeaveAllPowerSaveMode(padapter);
-			}
 			else
-			{
 				pwrctrlpriv->LpsIdleCount = 2;
-			}
 			pwrctrlpriv->power_mgnt = mode;
-			pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt)?_TRUE:_FALSE;
+			pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt) ? _TRUE : _FALSE;
 		}
-	}
+	} else
+		ret = -EINVAL;
+
+	return ret;
+}
+
+int rtw_pm_set_lps_level(_adapter *padapter, u8 level)
+{
+	int	ret = 0;
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+
+	if (level < LPS_LEVEL_MAX)
+		pwrctrlpriv->lps_level = level;
 	else
-	{
 		ret = -EINVAL;
-	}
 
 	return ret;
 }
@@ -2610,20 +2591,17 @@ int rtw_pm_set_ips(_adapter *padapter, u8 mode)
 {
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 
-	if( mode == IPS_NORMAL || mode == IPS_LEVEL_2 ) {
+	if (mode == IPS_NORMAL || mode == IPS_LEVEL_2) {
 		rtw_ips_mode_req(pwrctrlpriv, mode);
-		DBG_871X("%s %s\n", __FUNCTION__, mode == IPS_NORMAL?"IPS_NORMAL":"IPS_LEVEL_2");
+		RTW_INFO("%s %s\n", __FUNCTION__, mode == IPS_NORMAL ? "IPS_NORMAL" : "IPS_LEVEL_2");
 		return 0;
-	} 
-	else if(mode ==IPS_NONE){
+	} else if (mode == IPS_NONE) {
 		rtw_ips_mode_req(pwrctrlpriv, mode);
-		DBG_871X("%s %s\n", __FUNCTION__, "IPS_NONE");
+		RTW_INFO("%s %s\n", __FUNCTION__, "IPS_NONE");
 		if (!rtw_is_surprise_removed(padapter) && (_FAIL == rtw_pwr_wakeup(padapter)))
 			return -EFAULT;
-	}
-	else {
+	} else
 		return -EINVAL;
-	}
 	return 0;
 }
 
@@ -2637,22 +2615,21 @@ void rtw_ps_deny(PADAPTER padapter, PS_DENY_REASON reason)
 	s32 ret;
 
 
-//	DBG_871X("+" FUNC_ADPT_FMT ": Request PS deny for %d (0x%08X)\n",
-//		FUNC_ADPT_ARG(padapter), reason, BIT(reason));
+	/* 	RTW_INFO("+" FUNC_ADPT_FMT ": Request PS deny for %d (0x%08X)\n",
+	 *		FUNC_ADPT_ARG(padapter), reason, BIT(reason)); */
 
 	pwrpriv = adapter_to_pwrctl(padapter);
 
 	_enter_pwrlock(&pwrpriv->lock);
-	if (pwrpriv->ps_deny & BIT(reason))
-	{
-		DBG_871X(FUNC_ADPT_FMT ": [WARNING] Reason %d had been set before!!\n",
-			FUNC_ADPT_ARG(padapter), reason);
+	if (pwrpriv->ps_deny & BIT(reason)) {
+		RTW_INFO(FUNC_ADPT_FMT ": [WARNING] Reason %d had been set before!!\n",
+			 FUNC_ADPT_ARG(padapter), reason);
 	}
 	pwrpriv->ps_deny |= BIT(reason);
 	_exit_pwrlock(&pwrpriv->lock);
 
-//	DBG_871X("-" FUNC_ADPT_FMT ": Now PS deny for 0x%08X\n",
-//		FUNC_ADPT_ARG(padapter), pwrpriv->ps_deny);
+	/* 	RTW_INFO("-" FUNC_ADPT_FMT ": Now PS deny for 0x%08X\n",
+	 *		FUNC_ADPT_ARG(padapter), pwrpriv->ps_deny); */
 }
 
 /*
@@ -2664,22 +2641,21 @@ void rtw_ps_deny_cancel(PADAPTER padapter, PS_DENY_REASON reason)
 	struct pwrctrl_priv *pwrpriv;
 
 
-//	DBG_871X("+" FUNC_ADPT_FMT ": Cancel PS deny for %d(0x%08X)\n",
-//		FUNC_ADPT_ARG(padapter), reason, BIT(reason));
+	/* 	RTW_INFO("+" FUNC_ADPT_FMT ": Cancel PS deny for %d(0x%08X)\n",
+	 *		FUNC_ADPT_ARG(padapter), reason, BIT(reason)); */
 
 	pwrpriv = adapter_to_pwrctl(padapter);
 
 	_enter_pwrlock(&pwrpriv->lock);
-	if ((pwrpriv->ps_deny & BIT(reason)) == 0)
-	{
-		DBG_871X(FUNC_ADPT_FMT ": [ERROR] Reason %d had been canceled before!!\n",
-			FUNC_ADPT_ARG(padapter), reason);
+	if ((pwrpriv->ps_deny & BIT(reason)) == 0) {
+		RTW_INFO(FUNC_ADPT_FMT ": [ERROR] Reason %d had been canceled before!!\n",
+			 FUNC_ADPT_ARG(padapter), reason);
 	}
 	pwrpriv->ps_deny &= ~BIT(reason);
 	_exit_pwrlock(&pwrpriv->lock);
 
-//	DBG_871X("-" FUNC_ADPT_FMT ": Now PS deny for 0x%08X\n",
-//		FUNC_ADPT_ARG(padapter), pwrpriv->ps_deny);
+	/* 	RTW_INFO("-" FUNC_ADPT_FMT ": Now PS deny for 0x%08X\n",
+	 *		FUNC_ADPT_ARG(padapter), pwrpriv->ps_deny); */
 }
 
 /*
@@ -2696,4 +2672,3 @@ u32 rtw_ps_deny_get(PADAPTER padapter)
 
 	return deny;
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_recv.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_recv.c
index b66f93517357..6144d5d9389a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_recv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_recv.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,26 +12,21 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_RECV_C_
 
 #include <drv_types.h>
 #include <hal_data.h>
 
-#if defined (PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
 
-#error "Shall be Linux or Windows, but not both!\n"
+	#error "Shall be Linux or Windows, but not both!\n"
 
 #endif
 
 
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
-void rtw_signal_stat_timer_hdl(RTW_TIMER_HDL_ARGS);
+static void rtw_signal_stat_timer_hdl(void *ctx);
 
 enum {
 	SIGNAL_STAT_CALC_PROFILE_0 = 0,
@@ -43,28 +39,26 @@ u8 signal_stat_calc_profile[SIGNAL_STAT_CALC_PROFILE_MAX][2] = {
 	{3, 7}	/* Profile 1 => pre_stat : curr_stat = 3 : 7 */
 };
 
-#ifndef RTW_SIGNAL_STATE_CALC_PROFILE	
-#define RTW_SIGNAL_STATE_CALC_PROFILE SIGNAL_STAT_CALC_PROFILE_1
+#ifndef RTW_SIGNAL_STATE_CALC_PROFILE
+	#define RTW_SIGNAL_STATE_CALC_PROFILE SIGNAL_STAT_CALC_PROFILE_1
 #endif
 
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
 void _rtw_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv)
 {
 
 
-_func_enter_;
 
-	_rtw_memset((u8 *)psta_recvpriv, 0, sizeof (struct sta_recv_priv));
+	_rtw_memset((u8 *)psta_recvpriv, 0, sizeof(struct sta_recv_priv));
 
 	_rtw_spinlock_init(&psta_recvpriv->lock);
 
-	//for(i=0; i<MAX_RX_NUMBLKS; i++)
-	//	_rtw_init_queue(&psta_recvpriv->blk_strms[i]);
+	/* for(i=0; i<MAX_RX_NUMBLKS; i++) */
+	/*	_rtw_init_queue(&psta_recvpriv->blk_strms[i]); */
 
 	_rtw_init_queue(&psta_recvpriv->defrag_q);
 
-_func_exit_;
 
 }
 
@@ -73,19 +67,17 @@ sint _rtw_init_recv_priv(struct recv_priv *precvpriv, _adapter *padapter)
 	sint i;
 
 	union recv_frame *precvframe;
+	sint	res = _SUCCESS;
 
-	sint	res=_SUCCESS;
-
-_func_enter_;
 
-	// We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc().
-	//_rtw_memset((unsigned char *)precvpriv, 0, sizeof (struct  recv_priv));
+	/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
+	/* _rtw_memset((unsigned char *)precvpriv, 0, sizeof (struct  recv_priv)); */
 
 	_rtw_spinlock_init(&precvpriv->lock);
 
 #ifdef CONFIG_RECV_THREAD_MODE
 	_rtw_init_sema(&precvpriv->recv_sema, 0);
-	_rtw_init_sema(&precvpriv->terminate_recvthread_sema, 0);
+
 #endif
 
 	_rtw_init_queue(&precvpriv->free_recv_queue);
@@ -100,25 +92,30 @@ _func_enter_;
 	precvpriv->pre_rtp_rxseq = 0;
 	precvpriv->cur_rtp_rxseq = 0;
 
+#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
+	precvpriv->store_law_data_flag = 1;
+#else
+	precvpriv->store_law_data_flag = 0;
+#endif
+
 	rtw_os_recv_resource_init(precvpriv, padapter);
 
 	precvpriv->pallocated_frame_buf = rtw_zvmalloc(NR_RECVFRAME * sizeof(union recv_frame) + RXFRAME_ALIGN_SZ);
-	
-	if(precvpriv->pallocated_frame_buf==NULL){
-		res= _FAIL;
+
+	if (precvpriv->pallocated_frame_buf == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
-	//_rtw_memset(precvpriv->pallocated_frame_buf, 0, NR_RECVFRAME * sizeof(union recv_frame) + RXFRAME_ALIGN_SZ);
+	/* _rtw_memset(precvpriv->pallocated_frame_buf, 0, NR_RECVFRAME * sizeof(union recv_frame) + RXFRAME_ALIGN_SZ); */
 
 	precvpriv->precv_frame_buf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(precvpriv->pallocated_frame_buf), RXFRAME_ALIGN_SZ);
-	//precvpriv->precv_frame_buf = precvpriv->pallocated_frame_buf + RXFRAME_ALIGN_SZ -
-	//						((SIZE_PTR) (precvpriv->pallocated_frame_buf) &(RXFRAME_ALIGN_SZ-1));
+	/* precvpriv->precv_frame_buf = precvpriv->pallocated_frame_buf + RXFRAME_ALIGN_SZ - */
+	/*						((SIZE_PTR) (precvpriv->pallocated_frame_buf) &(RXFRAME_ALIGN_SZ-1)); */
 
-	precvframe = (union recv_frame*) precvpriv->precv_frame_buf;
+	precvframe = (union recv_frame *) precvpriv->precv_frame_buf;
 
 
-	for(i=0; i < NR_RECVFRAME ; i++)
-	{
+	for (i = 0; i < NR_RECVFRAME ; i++) {
 		_rtw_init_listhead(&(precvframe->u.list));
 
 		rtw_list_insert_tail(&(precvframe->u.list), &(precvpriv->free_recv_queue.queue));
@@ -127,7 +124,7 @@ _func_enter_;
 
 		precvframe->u.hdr.len = 0;
 
-		precvframe->u.hdr.adapter =padapter;
+		precvframe->u.hdr.adapter = padapter;
 		precvframe++;
 
 	}
@@ -143,17 +140,16 @@ _func_enter_;
 	res = rtw_hal_init_recv_priv(padapter);
 
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
-	rtw_init_timer(&precvpriv->signal_stat_timer, padapter, RTW_TIMER_HDL_NAME(signal_stat));
+	rtw_init_timer(&precvpriv->signal_stat_timer, padapter, rtw_signal_stat_timer_hdl, padapter);
 
-	precvpriv->signal_stat_sampling_interval = 2000; //ms
-	//precvpriv->signal_stat_converging_constant = 5000; //ms
+	precvpriv->signal_stat_sampling_interval = 2000; /* ms */
+	/* precvpriv->signal_stat_converging_constant = 5000; */ /* ms */
 
 	rtw_set_signal_stat_timer(precvpriv);
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
 exit:
 
-_func_exit_;
 
 	return res;
 
@@ -163,9 +159,8 @@ void rtw_mfree_recv_priv_lock(struct recv_priv *precvpriv);
 void rtw_mfree_recv_priv_lock(struct recv_priv *precvpriv)
 {
 	_rtw_spinlock_free(&precvpriv->lock);
-#ifdef CONFIG_RECV_THREAD_MODE	
+#ifdef CONFIG_RECV_THREAD_MODE
 	_rtw_free_sema(&precvpriv->recv_sema);
-	_rtw_free_sema(&precvpriv->terminate_recvthread_sema);
 #endif
 
 	_rtw_spinlock_free(&precvpriv->free_recv_queue.lock);
@@ -175,14 +170,13 @@ void rtw_mfree_recv_priv_lock(struct recv_priv *precvpriv)
 
 #ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
 	_rtw_spinlock_free(&precvpriv->recv_buf_pending_queue.lock);
-#endif	// CONFIG_USE_USB_BUFFER_ALLOC_RX
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
 }
 
-void _rtw_free_recv_priv (struct recv_priv *precvpriv)
+void _rtw_free_recv_priv(struct recv_priv *precvpriv)
 {
 	_adapter	*padapter = precvpriv->adapter;
 
-_func_enter_;
 
 	rtw_free_uc_swdec_pending_queue(padapter);
 
@@ -190,13 +184,11 @@ _func_enter_;
 
 	rtw_os_recv_resource_free(precvpriv);
 
-	if(precvpriv->pallocated_frame_buf) {
+	if (precvpriv->pallocated_frame_buf)
 		rtw_vmfree(precvpriv->pallocated_frame_buf, NR_RECVFRAME * sizeof(union recv_frame) + RXFRAME_ALIGN_SZ);
-	}
 
 	rtw_hal_free_recv_priv(padapter);
 
-_func_exit_;
 
 }
 
@@ -213,21 +205,17 @@ bool rtw_rframe_del_wfd_ie(union recv_frame *rframe, u8 ies_offset)
 	return ies_len_ori != ies_len;
 }
 
-union recv_frame *_rtw_alloc_recvframe (_queue *pfree_recv_queue)
+union recv_frame *_rtw_alloc_recvframe(_queue *pfree_recv_queue)
 {
 
 	union recv_frame  *precvframe;
 	_list	*plist, *phead;
 	_adapter *padapter;
 	struct recv_priv *precvpriv;
-_func_enter_;
 
-	if(_rtw_queue_empty(pfree_recv_queue) == _TRUE)
-	{
+	if (_rtw_queue_empty(pfree_recv_queue) == _TRUE)
 		precvframe = NULL;
-	}
-	else
-	{
+	else {
 		phead = get_list_head(pfree_recv_queue);
 
 		plist = get_next(phead);
@@ -235,25 +223,24 @@ _func_enter_;
 		precvframe = LIST_CONTAINOR(plist, union recv_frame, u);
 
 		rtw_list_delete(&precvframe->u.hdr.list);
-		padapter=precvframe->u.hdr.adapter;
-		if(padapter !=NULL){
-			precvpriv=&padapter->recvpriv;
-			if(pfree_recv_queue == &precvpriv->free_recv_queue)
+		padapter = precvframe->u.hdr.adapter;
+		if (padapter != NULL) {
+			precvpriv = &padapter->recvpriv;
+			if (pfree_recv_queue == &precvpriv->free_recv_queue)
 				precvpriv->free_recvframe_cnt--;
 		}
 	}
 
-_func_exit_;
 
 	return precvframe;
 
 }
 
-union recv_frame *rtw_alloc_recvframe (_queue *pfree_recv_queue)
+union recv_frame *rtw_alloc_recvframe(_queue *pfree_recv_queue)
 {
 	_irqL irqL;
 	union recv_frame  *precvframe;
-	
+
 	_enter_critical_bh(&pfree_recv_queue->lock, &irqL);
 
 	precvframe = _rtw_alloc_recvframe(pfree_recv_queue);
@@ -268,27 +255,24 @@ void rtw_init_recvframe(union recv_frame *precvframe, struct recv_priv *precvpri
 	/* Perry: This can be removed */
 	_rtw_init_listhead(&precvframe->u.hdr.list);
 
-	precvframe->u.hdr.len=0;
+	precvframe->u.hdr.len = 0;
 }
 
 int rtw_free_recvframe(union recv_frame *precvframe, _queue *pfree_recv_queue)
 {
 	_irqL irqL;
-	_adapter *padapter=precvframe->u.hdr.adapter;
+	_adapter *padapter = precvframe->u.hdr.adapter;
 	struct recv_priv *precvpriv = &padapter->recvpriv;
 
-_func_enter_;
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->adapter_type > PRIMARY_ADAPTER)
-	{
-		padapter = padapter->pbuddy_adapter;//get primary_padapter
-		precvpriv = &padapter->recvpriv;
-		pfree_recv_queue = &precvpriv->free_recv_queue;
-		precvframe->u.hdr.adapter = padapter;		
-	}	
+	padapter = GET_PRIMARY_ADAPTER(padapter);
+	precvpriv = &padapter->recvpriv;
+	pfree_recv_queue = &precvpriv->free_recv_queue;
+	precvframe->u.hdr.adapter = padapter;
 #endif
 
+
 	rtw_os_free_recvframe(precvframe);
 
 
@@ -300,14 +284,13 @@ _func_enter_;
 
 	rtw_list_insert_tail(&(precvframe->u.hdr.list), get_list_head(pfree_recv_queue));
 
-	if(padapter !=NULL){
-		if(pfree_recv_queue == &precvpriv->free_recv_queue)
-				precvpriv->free_recvframe_cnt++;
+	if (padapter != NULL) {
+		if (pfree_recv_queue == &precvpriv->free_recv_queue)
+			precvpriv->free_recvframe_cnt++;
 	}
 
-      _exit_critical_bh(&pfree_recv_queue->lock, &irqL);
+	_exit_critical_bh(&pfree_recv_queue->lock, &irqL);
 
-_func_exit_;
 
 	return _SUCCESS;
 
@@ -319,12 +302,11 @@ _func_exit_;
 sint _rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue)
 {
 
-	_adapter *padapter=precvframe->u.hdr.adapter;
+	_adapter *padapter = precvframe->u.hdr.adapter;
 	struct recv_priv *precvpriv = &padapter->recvpriv;
 
-_func_enter_;
 
-	//_rtw_init_listhead(&(precvframe->u.hdr.list));
+	/* _rtw_init_listhead(&(precvframe->u.hdr.list)); */
 	rtw_list_delete(&(precvframe->u.hdr.list));
 
 
@@ -335,7 +317,6 @@ _func_enter_;
 			precvpriv->free_recvframe_cnt++;
 	}
 
-_func_exit_;
 
 	return _SUCCESS;
 }
@@ -344,11 +325,11 @@ sint rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue)
 {
 	sint ret;
 	_irqL irqL;
-	
-	//_spinlock(&pfree_recv_queue->lock);
+
+	/* _spinlock(&pfree_recv_queue->lock); */
 	_enter_critical_bh(&queue->lock, &irqL);
 	ret = _rtw_enqueue_recvframe(precvframe, queue);
-	//_rtw_spinunlock(&pfree_recv_queue->lock);
+	/* _rtw_spinunlock(&pfree_recv_queue->lock); */
 	_exit_critical_bh(&queue->lock, &irqL);
 
 	return ret;
@@ -374,29 +355,26 @@ using spinlock to protect
 
 void rtw_free_recvframe_queue(_queue *pframequeue,  _queue *pfree_recv_queue)
 {
-	union	recv_frame 	*precvframe;
+	union	recv_frame	*precvframe;
 	_list	*plist, *phead;
 
-_func_enter_;
 	_rtw_spinlock(&pframequeue->lock);
 
 	phead = get_list_head(pframequeue);
 	plist = get_next(phead);
 
-	while(rtw_end_of_queue_search(phead, plist) == _FALSE)
-	{
+	while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
 		precvframe = LIST_CONTAINOR(plist, union recv_frame, u);
 
 		plist = get_next(plist);
 
-		//rtw_list_delete(&precvframe->u.hdr.list); // will do this in rtw_free_recvframe()
+		/* rtw_list_delete(&precvframe->u.hdr.list); */ /* will do this in rtw_free_recvframe() */
 
 		rtw_free_recvframe(precvframe, pfree_recv_queue);
 	}
 
 	_rtw_spinunlock(&pframequeue->lock);
 
-_func_exit_;
 
 }
 
@@ -404,13 +382,13 @@ u32 rtw_free_uc_swdec_pending_queue(_adapter *adapter)
 {
 	u32 cnt = 0;
 	union recv_frame *pending_frame;
-	while((pending_frame=rtw_alloc_recvframe(&adapter->recvpriv.uc_swdec_pending_queue))) {
+	while ((pending_frame = rtw_alloc_recvframe(&adapter->recvpriv.uc_swdec_pending_queue))) {
 		rtw_free_recvframe(pending_frame, &adapter->recvpriv.free_recv_queue);
 		cnt++;
 	}
 
 	if (cnt)
-		DBG_871X(FUNC_ADPT_FMT" dequeue %d\n", FUNC_ADPT_ARG(adapter), cnt);
+		RTW_INFO(FUNC_ADPT_FMT" dequeue %d\n", FUNC_ADPT_ARG(adapter), cnt);
 
 	return cnt;
 }
@@ -432,43 +410,40 @@ sint rtw_enqueue_recvbuf_to_head(struct recv_buf *precvbuf, _queue *queue)
 
 sint rtw_enqueue_recvbuf(struct recv_buf *precvbuf, _queue *queue)
 {
-	_irqL irqL;	
+	_irqL irqL;
 #ifdef CONFIG_SDIO_HCI
 	_enter_critical_bh(&queue->lock, &irqL);
 #else
 	_enter_critical_ex(&queue->lock, &irqL);
-#endif/*#ifdef  CONFIG_SDIO_HCI*/
+#endif/*#ifdef CONFIG_SDIO_HCI*/
 
 	rtw_list_delete(&precvbuf->list);
 
 	rtw_list_insert_tail(&precvbuf->list, get_list_head(queue));
-#ifdef CONFIG_SDIO_HCI	
+#ifdef CONFIG_SDIO_HCI
 	_exit_critical_bh(&queue->lock, &irqL);
 #else
 	_exit_critical_ex(&queue->lock, &irqL);
-#endif/*#ifdef  CONFIG_SDIO_HCI*/
+#endif/*#ifdef CONFIG_SDIO_HCI*/
 	return _SUCCESS;
-	
+
 }
 
-struct recv_buf *rtw_dequeue_recvbuf (_queue *queue)
+struct recv_buf *rtw_dequeue_recvbuf(_queue *queue)
 {
 	_irqL irqL;
 	struct recv_buf *precvbuf;
-	_list	*plist, *phead;	
+	_list	*plist, *phead;
 
 #ifdef CONFIG_SDIO_HCI
 	_enter_critical_bh(&queue->lock, &irqL);
 #else
 	_enter_critical_ex(&queue->lock, &irqL);
-#endif/*#ifdef  CONFIG_SDIO_HCI*/
-	
-	if(_rtw_queue_empty(queue) == _TRUE)
-	{
+#endif/*#ifdef CONFIG_SDIO_HCI*/
+
+	if (_rtw_queue_empty(queue) == _TRUE)
 		precvbuf = NULL;
-	}
-	else
-	{
+	else {
 		phead = get_list_head(queue);
 
 		plist = get_next(phead);
@@ -476,152 +451,107 @@ struct recv_buf *rtw_dequeue_recvbuf (_queue *queue)
 		precvbuf = LIST_CONTAINOR(plist, struct recv_buf, list);
 
 		rtw_list_delete(&precvbuf->list);
-		
+
 	}
 
 #ifdef CONFIG_SDIO_HCI
 	_exit_critical_bh(&queue->lock, &irqL);
 #else
 	_exit_critical_ex(&queue->lock, &irqL);
-#endif/*#ifdef  CONFIG_SDIO_HCI*/
+#endif/*#ifdef CONFIG_SDIO_HCI*/
 
 	return precvbuf;
 
 }
 
 sint recvframe_chkmic(_adapter *adapter,  union recv_frame *precvframe);
-sint recvframe_chkmic(_adapter *adapter,  union recv_frame *precvframe){
+sint recvframe_chkmic(_adapter *adapter,  union recv_frame *precvframe)
+{
 
-	sint	i,res=_SUCCESS;
+	sint	i, res = _SUCCESS;
 	u32	datalen;
 	u8	miccode[8];
-	u8	bmic_err=_FALSE,brpt_micerror = _TRUE;
-	u8	*pframe, *payload,*pframemic;
+	u8	bmic_err = _FALSE, brpt_micerror = _TRUE;
+	u8	*pframe, *payload, *pframemic;
 	u8	*mickey;
-	//u8	*iv,rxdata_key_idx=0;
+	/* u8	*iv,rxdata_key_idx=0; */
 	struct	sta_info		*stainfo;
-	struct	rx_pkt_attrib	*prxattrib=&precvframe->u.hdr.attrib;
-	struct 	security_priv	*psecuritypriv=&adapter->securitypriv;
+	struct	rx_pkt_attrib	*prxattrib = &precvframe->u.hdr.attrib;
+	struct	security_priv	*psecuritypriv = &adapter->securitypriv;
 
 	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-_func_enter_;
 
-	stainfo=rtw_get_stainfo(&adapter->stapriv ,&prxattrib->ta[0]);
+	stainfo = rtw_get_stainfo(&adapter->stapriv , &prxattrib->ta[0]);
 
-	if(prxattrib->encrypt ==_TKIP_)
-	{
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("\n recvframe_chkmic:prxattrib->encrypt ==_TKIP_\n"));
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("\n recvframe_chkmic:da=0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x\n",
-			prxattrib->ra[0],prxattrib->ra[1],prxattrib->ra[2],prxattrib->ra[3],prxattrib->ra[4],prxattrib->ra[5]));
+	if (prxattrib->encrypt == _TKIP_) {
 
-		//calculate mic code
-		if(stainfo!= NULL)
-		{
-			if(IS_MCAST(prxattrib->ra))
-			{
-				//mickey=&psecuritypriv->dot118021XGrprxmickey.skey[0];
-				//iv = precvframe->u.hdr.rx_data+prxattrib->hdrlen;
-				//rxdata_key_idx =( ((iv[3])>>6)&0x3) ;
-				mickey=&psecuritypriv->dot118021XGrprxmickey[prxattrib->key_index].skey[0];
-				
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("\n recvframe_chkmic: bcmc key \n"));
-				//DBG_871X("\n recvframe_chkmic: bcmc key psecuritypriv->dot118021XGrpKeyid(%d),pmlmeinfo->key_index(%d) ,recv key_id(%d)\n",
-				//								psecuritypriv->dot118021XGrpKeyid,pmlmeinfo->key_index,rxdata_key_idx);
-				
-				if(psecuritypriv->binstallGrpkey==_FALSE)
-				{
-					res=_FAIL;
-					RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("\n recvframe_chkmic:didn't install group key!!!!!!!!!!\n"));
-					DBG_871X("\n recvframe_chkmic:didn't install group key!!!!!!!!!!\n");
+		/* calculate mic code */
+		if (stainfo != NULL) {
+			if (IS_MCAST(prxattrib->ra)) {
+				/* mickey=&psecuritypriv->dot118021XGrprxmickey.skey[0]; */
+				/* iv = precvframe->u.hdr.rx_data+prxattrib->hdrlen; */
+				/* rxdata_key_idx =( ((iv[3])>>6)&0x3) ; */
+				mickey = &psecuritypriv->dot118021XGrprxmickey[prxattrib->key_index].skey[0];
+
+				/* RTW_INFO("\n recvframe_chkmic: bcmc key psecuritypriv->dot118021XGrpKeyid(%d),pmlmeinfo->key_index(%d) ,recv key_id(%d)\n", */
+				/*								psecuritypriv->dot118021XGrpKeyid,pmlmeinfo->key_index,rxdata_key_idx); */
+
+				if (psecuritypriv->binstallGrpkey == _FALSE) {
+					res = _FAIL;
+					RTW_INFO("\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_,("\n recvframe_chkmic: unicast key \n"));
+			} else {
+				mickey = &stainfo->dot11tkiprxmickey.skey[0];
 			}
 
-			datalen=precvframe->u.hdr.len-prxattrib->hdrlen-prxattrib->iv_len-prxattrib->icv_len-8;//icv_len included the mic code
-			pframe=precvframe->u.hdr.rx_data;
-			payload=pframe+prxattrib->hdrlen+prxattrib->iv_len;
+			datalen = precvframe->u.hdr.len - prxattrib->hdrlen - prxattrib->iv_len - prxattrib->icv_len - 8; /* icv_len included the mic code */
+			pframe = precvframe->u.hdr.rx_data;
+			payload = pframe + prxattrib->hdrlen + prxattrib->iv_len;
 
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("\n prxattrib->iv_len=%d prxattrib->icv_len=%d\n",prxattrib->iv_len,prxattrib->icv_len));
 
-			//rtw_seccalctkipmic(&stainfo->dot11tkiprxmickey.skey[0],pframe,payload, datalen ,&miccode[0],(unsigned char)prxattrib->priority); //care the length of the data
+			/* rtw_seccalctkipmic(&stainfo->dot11tkiprxmickey.skey[0],pframe,payload, datalen ,&miccode[0],(unsigned char)prxattrib->priority); */ /* care the length of the data */
 
-			rtw_seccalctkipmic(mickey,pframe,payload, datalen ,&miccode[0],(unsigned char)prxattrib->priority); //care the length of the data
+			rtw_seccalctkipmic(mickey, pframe, payload, datalen , &miccode[0], (unsigned char)prxattrib->priority); /* care the length of the data */
 
-			pframemic=payload+datalen;
+			pframemic = payload + datalen;
 
-			bmic_err=_FALSE;
+			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) ",i,miccode[i],i,*(pframemic+i)));
-					bmic_err=_TRUE;
+			for (i = 0; i < 8; i++) {
+				if (miccode[i] != *(pframemic + i)) {
+					bmic_err = _TRUE;
 				}
 			}
 
 
-			if(bmic_err==_TRUE){
-
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("\n *(pframemic-8)-*(pframemic-1)=0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x\n",
-					*(pframemic-8),*(pframemic-7),*(pframemic-6),*(pframemic-5),*(pframemic-4),*(pframemic-3),*(pframemic-2),*(pframemic-1)));
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("\n *(pframemic-16)-*(pframemic-9)=0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x\n",
-					*(pframemic-16),*(pframemic-15),*(pframemic-14),*(pframemic-13),*(pframemic-12),*(pframemic-11),*(pframemic-10),*(pframemic-9)));
+			if (bmic_err == _TRUE) {
 
-				{
-					uint i;
-					RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("\n ======demp packet (len=%d)======\n",precvframe->u.hdr.len));
-					for(i=0;i<precvframe->u.hdr.len;i=i+8){
-						RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x:0x%02x",
-							*(precvframe->u.hdr.rx_data+i),*(precvframe->u.hdr.rx_data+i+1),
-							*(precvframe->u.hdr.rx_data+i+2),*(precvframe->u.hdr.rx_data+i+3),
-							*(precvframe->u.hdr.rx_data+i+4),*(precvframe->u.hdr.rx_data+i+5),
-							*(precvframe->u.hdr.rx_data+i+6),*(precvframe->u.hdr.rx_data+i+7)));
-					}
-					RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("\n ======demp packet end [len=%d]======\n",precvframe->u.hdr.len));
-					RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("\n hrdlen=%d, \n",prxattrib->hdrlen));
-				}
 
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("ra=0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x psecuritypriv->binstallGrpkey=%d ",
-					prxattrib->ra[0],prxattrib->ra[1],prxattrib->ra[2],
-					prxattrib->ra[3],prxattrib->ra[4],prxattrib->ra[5],psecuritypriv->binstallGrpkey));
 
-				// double check key_index for some timing issue ,
-				// cannot compare with psecuritypriv->dot118021XGrpKeyid also cause timing issue
-				if((IS_MCAST(prxattrib->ra)==_TRUE)  && (prxattrib->key_index != pmlmeinfo->key_index ))
+				/* double check key_index for some timing issue , */
+				/* cannot compare with psecuritypriv->dot118021XGrpKeyid also cause timing issue */
+				if ((IS_MCAST(prxattrib->ra) == _TRUE)  && (prxattrib->key_index != pmlmeinfo->key_index))
 					brpt_micerror = _FALSE;
-				
-				if((prxattrib->bdecrypted ==_TRUE)&& (brpt_micerror == _TRUE))
-				{
-					rtw_handle_tkip_mic_err(adapter, stainfo, (u8)IS_MCAST(prxattrib->ra));			
-					RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" mic error :prxattrib->bdecrypted=%d ",prxattrib->bdecrypted));
-					DBG_871X(" mic error :prxattrib->bdecrypted=%d\n",prxattrib->bdecrypted);
-				}
-				else
-				{
-					RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" mic error :prxattrib->bdecrypted=%d ",prxattrib->bdecrypted));
-					DBG_871X(" mic error :prxattrib->bdecrypted=%d\n",prxattrib->bdecrypted);
+
+				if ((prxattrib->bdecrypted == _TRUE) && (brpt_micerror == _TRUE)) {
+					rtw_handle_tkip_mic_err(adapter, stainfo, (u8)IS_MCAST(prxattrib->ra));
+					RTW_INFO(" mic error :prxattrib->bdecrypted=%d\n", prxattrib->bdecrypted);
+				} else {
+					RTW_INFO(" mic error :prxattrib->bdecrypted=%d\n", prxattrib->bdecrypted);
 				}
 
-				res=_FAIL;
+				res = _FAIL;
 
-			}
-			else{
-				//mic checked ok
-				if((psecuritypriv->bcheck_grpkey ==_FALSE)&&(IS_MCAST(prxattrib->ra)==_TRUE)){
-					psecuritypriv->bcheck_grpkey =_TRUE;
-					RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("psecuritypriv->bcheck_grpkey =_TRUE"));
+			} else {
+				/* mic checked ok */
+				if ((psecuritypriv->bcheck_grpkey == _FALSE) && (IS_MCAST(prxattrib->ra) == _TRUE)) {
+					psecuritypriv->bcheck_grpkey = _TRUE;
 				}
 			}
 
 		}
-		else
-		{
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("recvframe_chkmic: rtw_get_stainfo==NULL!!!\n"));
-		}
 
 		recvframe_pull_tail(precvframe, 8);
 
@@ -629,69 +559,71 @@ _func_enter_;
 
 exit:
 
-_func_exit_;
 
 	return res;
 
 }
 
-//decrypt and set the ivlen,icvlen of the recv_frame
-union recv_frame * decryptor(_adapter *padapter,union recv_frame *precv_frame);
-union recv_frame * decryptor(_adapter *padapter,union recv_frame *precv_frame)
+/*#define DBG_RX_SW_DECRYPTOR*/
+
+/* decrypt and set the ivlen,icvlen of the recv_frame */
+union recv_frame *decryptor(_adapter *padapter, union recv_frame *precv_frame);
+union recv_frame *decryptor(_adapter *padapter, union recv_frame *precv_frame)
 {
 
 	struct rx_pkt_attrib *prxattrib = &precv_frame->u.hdr.attrib;
-	struct security_priv *psecuritypriv=&padapter->securitypriv;
-	union recv_frame *return_packet=precv_frame;
-	u32	 res=_SUCCESS;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	union recv_frame *return_packet = precv_frame;
+	u32	 res = _SUCCESS;
 
-_func_enter_;
 
 	DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt);
 
-	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->u.hdr.rx_data+prxattrib->hdrlen;
-		prxattrib->key_index = ( ((iv[3])>>6)&0x3) ;
+	if (prxattrib->encrypt > 0) {
+		u8 *iv = precv_frame->u.hdr.rx_data + prxattrib->hdrlen;
+		prxattrib->key_index = (((iv[3]) >> 6) & 0x3) ;
 
-		if(prxattrib->key_index > WEP_KEYS)
-		{
-			DBG_871X("prxattrib->key_index(%d) > WEP_KEYS \n", prxattrib->key_index);
+		if (prxattrib->key_index > WEP_KEYS) {
+			RTW_INFO("prxattrib->key_index(%d) > WEP_KEYS\n", prxattrib->key_index);
 
-			switch(prxattrib->encrypt){
-				case _WEP40_:
-				case _WEP104_:
-					prxattrib->key_index = psecuritypriv->dot11PrivacyKeyIndex;
-					break;
-				case _TKIP_:			
-				case _AES_:						
-				default:
-					prxattrib->key_index = psecuritypriv->dot118021XGrpKeyid;
-					break;
-			}	
-		}			
+			switch (prxattrib->encrypt) {
+			case _WEP40_:
+			case _WEP104_:
+				prxattrib->key_index = psecuritypriv->dot11PrivacyKeyIndex;
+				break;
+			case _TKIP_:
+			case _AES_:
+			default:
+				prxattrib->key_index = psecuritypriv->dot118021XGrpKeyid;
+				break;
+			}
+		}
 	}
 
-	if((prxattrib->encrypt>0) && ((prxattrib->bdecrypted==0) ||(psecuritypriv->sw_decrypt==_TRUE)))
-	{
+	if (prxattrib->encrypt && !prxattrib->bdecrypted) {
+		if (GetFrameType(get_recvframe_data(precv_frame)) == WIFI_DATA
+			#ifdef CONFIG_CONCURRENT_MODE
+			&& !IS_MCAST(prxattrib->ra) /* bc/mc packets may use sw decryption for concurrent mode */
+			#endif
+		)
+			psecuritypriv->hw_decrypted = _FALSE;
 
-#ifdef CONFIG_CONCURRENT_MODE
-		if(!IS_MCAST(prxattrib->ra))//bc/mc packets use sw decryption for concurrent mode
-#endif			
-			psecuritypriv->hw_decrypted=_FALSE;
-
-		#ifdef DBG_RX_DECRYPTOR
-		DBG_871X("[%s] %d:prxstat->bdecrypted:%d,  prxattrib->encrypt:%d,  Setting psecuritypriv->hw_decrypted = %d\n",
-			__FUNCTION__,
-			__LINE__,
-			prxattrib->bdecrypted,
-			prxattrib->encrypt,
-			psecuritypriv->hw_decrypted);
-		#endif
+#ifdef DBG_RX_SW_DECRYPTOR
+		RTW_INFO(ADPT_FMT" - sec_type:%s DO SW decryption\n",
+			ADPT_ARG(padapter), security_type_str(prxattrib->encrypt));
+#endif
 
-		switch(prxattrib->encrypt){
+#ifdef DBG_RX_DECRYPTOR
+		RTW_INFO("[%s] %d:prxstat->bdecrypted:%d,  prxattrib->encrypt:%d,  Setting psecuritypriv->hw_decrypted = %d\n",
+			 __FUNCTION__,
+			 __LINE__,
+			 prxattrib->bdecrypted,
+			 prxattrib->encrypt,
+			 psecuritypriv->hw_decrypted);
+#endif
+
+		switch (prxattrib->encrypt) {
 		case _WEP40_:
 		case _WEP104_:
 			DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_wep);
@@ -703,83 +635,79 @@ _func_enter_;
 			break;
 		case _AES_:
 			DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_aes);
-			res = rtw_aes_decrypt(padapter, (u8 * )precv_frame);
+			res = rtw_aes_decrypt(padapter, (u8 *)precv_frame);
 			break;
 #ifdef CONFIG_WAPI_SUPPORT
 		case _SMS4_:
 			DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_wapi);
-			rtw_sms4_decrypt(padapter, (u8 * )precv_frame);
+			rtw_sms4_decrypt(padapter, (u8 *)precv_frame);
 			break;
 #endif
 		default:
-				break;
+			break;
 		}
-	}
-	else if(prxattrib->bdecrypted==1
-		&& prxattrib->encrypt >0
-		&& (psecuritypriv->busetkipkey==1 || prxattrib->encrypt !=_TKIP_ )
-		)
-	{
+	} else if (prxattrib->bdecrypted == 1
+		   && prxattrib->encrypt > 0
+		&& (psecuritypriv->busetkipkey == 1 || prxattrib->encrypt != _TKIP_)
+		  ) {
 #if 0
-		if((prxstat->icv==1)&&(prxattrib->encrypt!=_AES_))
-		{
-			psecuritypriv->hw_decrypted=_FALSE;
+		if ((prxstat->icv == 1) && (prxattrib->encrypt != _AES_)) {
+			psecuritypriv->hw_decrypted = _FALSE;
 
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("psecuritypriv->hw_decrypted=_FALSE"));
 
 			rtw_free_recvframe(precv_frame, &padapter->recvpriv.free_recv_queue);
 
-			return_packet=NULL;
+			return_packet = NULL;
 
-		}
-		else
+		} else
 #endif
 		{
 			DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_hw);
 
-			psecuritypriv->hw_decrypted=_TRUE;
-			#ifdef DBG_RX_DECRYPTOR
-			DBG_871X("[%s] %d:prxstat->bdecrypted:%d,  prxattrib->encrypt:%d,  Setting psecuritypriv->hw_decrypted = %d\n",
-				__FUNCTION__,
-				__LINE__,
-				prxattrib->bdecrypted,
-				prxattrib->encrypt,
-				psecuritypriv->hw_decrypted);
+			psecuritypriv->hw_decrypted = _TRUE;
+#ifdef DBG_RX_DECRYPTOR
+			RTW_INFO("[%s] %d:prxstat->bdecrypted:%d,  prxattrib->encrypt:%d,  Setting psecuritypriv->hw_decrypted = %d\n",
+				 __FUNCTION__,
+				 __LINE__,
+				 prxattrib->bdecrypted,
+				 prxattrib->encrypt,
+				 psecuritypriv->hw_decrypted);
 
-			#endif
+#endif
 		}
-	}
-	else {
+	} else {
 		DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_unknown);
-		#ifdef DBG_RX_DECRYPTOR
-		DBG_871X("[%s] %d:prxstat->bdecrypted:%d,  prxattrib->encrypt:%d,  Setting psecuritypriv->hw_decrypted = %d\n",
-			__FUNCTION__,
-			__LINE__,
-			prxattrib->bdecrypted,
-			prxattrib->encrypt,
-			psecuritypriv->hw_decrypted);
-		#endif
+#ifdef DBG_RX_DECRYPTOR
+		RTW_INFO("[%s] %d:prxstat->bdecrypted:%d,  prxattrib->encrypt:%d,  Setting psecuritypriv->hw_decrypted = %d\n",
+			 __FUNCTION__,
+			 __LINE__,
+			 prxattrib->bdecrypted,
+			 prxattrib->encrypt,
+			 psecuritypriv->hw_decrypted);
+#endif
 	}
-	
-	if(res == _FAIL)
-	{
-		rtw_free_recvframe(return_packet,&padapter->recvpriv.free_recv_queue);			
+
+	#ifdef CONFIG_RTW_MESH
+	if (res != _FAIL
+		&& !prxattrib->amsdu
+		&& prxattrib->mesh_ctrl_present)
+		res = rtw_mesh_rx_validate_mctrl_non_amsdu(padapter, precv_frame);
+	#endif
+
+	if (res == _FAIL) {
+		rtw_free_recvframe(return_packet, &padapter->recvpriv.free_recv_queue);
 		return_packet = NULL;
-	}
-	else
-	{
+	} else
 		prxattrib->bdecrypted = _TRUE;
-	}
-	//recvframe_chkmic(adapter, precv_frame);   //move to recvframme_defrag function
+	/* recvframe_chkmic(adapter, precv_frame);   */ /* move to recvframme_defrag function */
 
-_func_exit_;
 
 	return return_packet;
 
 }
-//###set the security information in the recv_frame
-union recv_frame * portctrl(_adapter *adapter,union recv_frame * precv_frame);
-union recv_frame * portctrl(_adapter *adapter,union recv_frame * precv_frame)
+/* ###set the security information in the recv_frame */
+union recv_frame *portctrl(_adapter *adapter, union recv_frame *precv_frame);
+union recv_frame *portctrl(_adapter *adapter, union recv_frame *precv_frame)
 {
 	u8 *psta_addr = NULL;
 	u8 *ptr;
@@ -788,11 +716,10 @@ union recv_frame * portctrl(_adapter *adapter,union recv_frame * precv_frame)
 	struct sta_info *psta;
 	struct sta_priv *pstapriv ;
 	union recv_frame *prtnframe;
-	u16	ether_type=0;
-	u16  eapol_type = 0x888e;//for Funia BD's WPA issue  
+	u16	ether_type = 0;
+	u16  eapol_type = 0x888e;/* for Funia BD's WPA issue  */
 	struct rx_pkt_attrib *pattrib;
 
-_func_enter_;
 
 	pstapriv = &adapter->stapriv;
 
@@ -807,226 +734,245 @@ _func_enter_;
 
 	psta = rtw_get_stainfo(pstapriv, psta_addr);
 
-	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("########portctrl:adapter->securitypriv.dot11AuthAlgrthm=%d\n",adapter->securitypriv.dot11AuthAlgrthm));
 
-	if(auth_alg==2)
-	{
-		if ((psta!=NULL) && (psta->ieee8021x_blocked))
-		{
-			//blocked
-			//only accept EAPOL frame
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("########portctrl:psta->ieee8021x_blocked==1\n"));
+	if (auth_alg == dot11AuthAlgrthm_8021X) {
+		if ((psta != NULL) && (psta->ieee8021x_blocked)) {
+			/* blocked */
+			/* only accept EAPOL frame */
 
-			prtnframe=precv_frame;
+			prtnframe = precv_frame;
 
-			//get ether_type
-			ptr=ptr+pfhdr->attrib.hdrlen+pfhdr->attrib.iv_len+LLC_HEADER_SIZE;
-			_rtw_memcpy(&ether_type,ptr, 2);
-			ether_type= ntohs((unsigned short )ether_type);
+			/* get ether_type */
+			ptr = ptr + pfhdr->attrib.hdrlen + pfhdr->attrib.iv_len + LLC_HEADER_SIZE;
+			_rtw_memcpy(&ether_type, ptr, 2);
+			ether_type = ntohs((unsigned short)ether_type);
 
-		        if (ether_type == eapol_type) {
-				prtnframe=precv_frame;
-			}
+			if (ether_type == eapol_type)
+				prtnframe = precv_frame;
 			else {
-				//free this frame
+				/* free this frame */
 				rtw_free_recvframe(precv_frame, &adapter->recvpriv.free_recv_queue);
-				prtnframe=NULL;
-			}
-		}
-		else
-		{
-			//allowed
-			//check decryption status, and decrypt the frame if needed
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("########portctrl:psta->ieee8021x_blocked==0\n"));
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("portctrl:precv_frame->hdr.attrib.privacy=%x\n",precv_frame->u.hdr.attrib.privacy));
-
-			if (pattrib->bdecrypted == 0)
-			{
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("portctrl:prxstat->decrypted=%x\n", pattrib->bdecrypted));
+				prtnframe = NULL;
 			}
+		} else {
+			/* allowed */
+			/* check decryption status, and decrypt the frame if needed */
 
-			prtnframe=precv_frame;
-			//check is the EAPOL frame or not (Rekey)
-			//if(ether_type == eapol_type){
-			//	RT_TRACE(_module_rtl871x_recv_c_,_drv_notice_,("########portctrl:ether_type == 0x888e\n"));
-				//check Rekey
-
-			//	prtnframe=precv_frame;
-			//}
-			//else{
-			//	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("########portctrl:ether_type=0x%04x\n", ether_type));
-			//}
+
+			prtnframe = precv_frame;
+			/* check is the EAPOL frame or not (Rekey) */
+			/* if(ether_type == eapol_type){ */
+			/* check Rekey */
+
+			/*	prtnframe=precv_frame; */
+			/* } */
 		}
-	}
-	else
-	{
-		prtnframe=precv_frame;
-	}
+	} else
+		prtnframe = precv_frame;
 
-_func_exit_;
 
-		return prtnframe;
+	return prtnframe;
 
 }
 
-sint recv_decache(union recv_frame *precv_frame, u8 bretry, struct stainfo_rxcache *prxcache);
-sint recv_decache(union recv_frame *precv_frame, u8 bretry, struct stainfo_rxcache *prxcache)
+sint recv_decache(union recv_frame *precv_frame, u16 *tid_rxseq)
 {
+	struct sta_info *sta = precv_frame->u.hdr.psta;
+
 	sint tid = precv_frame->u.hdr.attrib.priority;
+	u16 seq_ctrl = ((precv_frame->u.hdr.attrib.seq_num & 0xffff) << 4) |
+		       (precv_frame->u.hdr.attrib.frag_num & 0xf);
 
-	u16 seq_ctrl = ( (precv_frame->u.hdr.attrib.seq_num&0xffff) << 4) |
-		(precv_frame->u.hdr.attrib.frag_num & 0xf);
+	if (tid > 15)
+		return _FAIL;
 
-_func_enter_;
+	if (seq_ctrl == tid_rxseq[tid]) {
+		/* for non-AMPDU case	*/
+		sta->sta_stats.duplicate_cnt++;
 
-	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));
+		if (sta->sta_stats.duplicate_cnt % 100 == 0)
+			RTW_INFO("%s: tid=%u seq=%d frag=%d\n", __func__
+				, tid, precv_frame->u.hdr.attrib.seq_num
+				, precv_frame->u.hdr.attrib.frag_num);
 
 		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]));
+	tid_rxseq[tid] = seq_ctrl;
 
-			return _FAIL;
+	return _SUCCESS;
+}
+
+/* VALID_PN_CHK
+ * Return true when PN is legal, otherwise false.
+ * Legal PN:
+ *	1. If old PN is 0, any PN is legal
+ *	2. PN > old PN
+ */
+#define PN_LESS_CHK(a, b)	(((a-b) & 0x800000000000) != 0)
+#define VALID_PN_CHK(new, old)	(((old) == 0) || PN_LESS_CHK(old, new))
+#define CCMPH_2_KEYID(ch)	(((ch) & 0x00000000c0000000) >> 30)
+sint recv_ucast_pn_decache(union recv_frame *precv_frame);
+sint recv_ucast_pn_decache(union recv_frame *precv_frame)
+{
+	_adapter *padapter = precv_frame->u.hdr.adapter;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct sta_info *sta = precv_frame->u.hdr.psta;
+	struct stainfo_rxcache *prxcache = &sta->sta_recvpriv.rxcache;
+	u8 *pdata = precv_frame->u.hdr.rx_data;
+	u32 data_len = precv_frame->u.hdr.len;
+	sint tid = precv_frame->u.hdr.attrib.priority;
+	u64 tmp_iv_hdr = 0;
+	u64 curr_pn = 0, pkt_pn = 0;
+
+	if (tid > 15)
+		return _FAIL;
+
+	if (pattrib->encrypt == _AES_) {
+		tmp_iv_hdr = le64_to_cpu(*(u64*)(pdata + pattrib->hdrlen));
+		pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
+		tmp_iv_hdr = le64_to_cpu(*(u64*)prxcache->iv[tid]);
+		curr_pn = CCMPH_2_PN(tmp_iv_hdr);
+
+		if (!VALID_PN_CHK(pkt_pn, curr_pn)) {
+			/* return _FAIL; */
+		} else {
+			prxcache->last_tid = tid;
+			_rtw_memcpy(prxcache->iv[tid],
+				    (pdata + pattrib->hdrlen),
+				    sizeof(prxcache->iv[tid]));
 		}
 	}
 
-	prxcache->tid_rxseq[tid] = seq_ctrl;
+	return _SUCCESS;
+}
 
-_func_exit_;
+sint recv_bcast_pn_decache(union recv_frame *precv_frame);
+sint recv_bcast_pn_decache(union recv_frame *precv_frame)
+{
+	_adapter *padapter = precv_frame->u.hdr.adapter;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	u8 *pdata = precv_frame->u.hdr.rx_data;
+	u32 data_len = precv_frame->u.hdr.len;
+	u64 tmp_iv_hdr = 0;
+	u64 curr_pn = 0, pkt_pn = 0;
+	u8 key_id;
+
+	if ((pattrib->encrypt == _AES_) &&
+		(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)) {		
+
+		tmp_iv_hdr = le64_to_cpu(*(u64*)(pdata + pattrib->hdrlen));
+		key_id = CCMPH_2_KEYID(tmp_iv_hdr);
+		pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
+	
+		curr_pn = le64_to_cpu(*(u64*)psecuritypriv->iv_seq[key_id]);
+		curr_pn &= 0x0000ffffffffffff;
 
-	return _SUCCESS;
+		if (!VALID_PN_CHK(pkt_pn, curr_pn))
+			return _FAIL;
+
+		*(u64*)psecuritypriv->iv_seq[key_id] = cpu_to_le64(pkt_pn);
+	}
 
+	return _SUCCESS;
 }
 
-void process_pwrbit_data(_adapter *padapter, union recv_frame *precv_frame);
-void process_pwrbit_data(_adapter *padapter, union recv_frame *precv_frame)
+void process_pwrbit_data(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *psta)
 {
 #ifdef CONFIG_AP_MODE
 	unsigned char pwrbit;
 	u8 *ptr = precv_frame->u.hdr.rx_data;
 	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta=NULL;
-
-	psta = rtw_get_stainfo(pstapriv, pattrib->src);
 
 	pwrbit = GetPwrMgt(ptr);
 
-	if(psta)
-	{
-		if(pwrbit)
-		{
-			if(!(psta->state & WIFI_SLEEP_STATE))
-			{
-				//psta->state |= WIFI_SLEEP_STATE;
-				//pstapriv->sta_dz_bitmap |= BIT(psta->aid);
-
-				stop_sta_xmit(padapter, psta);
+	if (pwrbit) {
+		if (!(psta->state & WIFI_SLEEP_STATE)) {
+			/* psta->state |= WIFI_SLEEP_STATE; */
+			/* rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, BIT(psta->cmn.aid)); */
 
-				//DBG_871X("to sleep, sta_dz_bitmap=%x\n", pstapriv->sta_dz_bitmap);
-			}
+			stop_sta_xmit(padapter, psta);
+			/* RTW_INFO_DUMP("to sleep, sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len); */
 		}
-		else
-		{
-			if(psta->state & WIFI_SLEEP_STATE)
-			{
-				//psta->state ^= WIFI_SLEEP_STATE;
-				//pstapriv->sta_dz_bitmap &= ~BIT(psta->aid);
-
-				wakeup_sta_to_xmit(padapter, psta);
+	} else {
+		if (psta->state & WIFI_SLEEP_STATE) {
+			/* psta->state ^= WIFI_SLEEP_STATE; */
+			/* rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, BIT(psta->cmn.aid)); */
 
-				//DBG_871X("to wakeup, sta_dz_bitmap=%x\n", pstapriv->sta_dz_bitmap);
-			}
+			wakeup_sta_to_xmit(padapter, psta);
+			/* RTW_INFO_DUMP("to wakeup, sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len); */
 		}
-
 	}
-
 #endif
 }
 
-void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame);
-void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame)
+void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *psta)
 {
-#ifdef CONFIG_AP_MODE		
+#ifdef CONFIG_AP_MODE
 	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta=NULL;
-
-	psta = rtw_get_stainfo(pstapriv, pattrib->src);
-	
-	if(!psta) return;
 
 #ifdef CONFIG_TDLS
-	if( !(psta->tdls_sta_state & TDLS_LINKED_STATE ) )
-	{
-#endif //CONFIG_TDLS
+	if (!(psta->tdls_sta_state & TDLS_LINKED_STATE)) {
+#endif /* CONFIG_TDLS */
 
-	if(!psta->qos_option)
-		return;
+		if (!psta->qos_option)
+			return;
+
+		if (!(psta->qos_info & 0xf))
+			return;
 
-	if(!(psta->qos_info&0xf))
-		return;
-		
 #ifdef CONFIG_TDLS
 	}
-#endif //CONFIG_TDLS		
+#endif /* CONFIG_TDLS		 */
 
-	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 (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
+		if (wmmps_ac) {
+			if (psta->sleepq_ac_len > 0) {
+				/* process received triggered frame */
 				xmit_delivery_enabled_frames(padapter, psta);
-			}
-			else
-			{
-				//issue one qos null frame with More data bit = 0 and the EOSP bit set (=1)
-				issue_qos_nulldata(padapter, psta->hwaddr, (u16)pattrib->priority, 0, 0);
+			} else {
+				/* issue one qos null frame with More data bit = 0 and the EOSP bit set (=1) */
+				issue_qos_nulldata(padapter, psta->cmn.mac_addr, (u16)pattrib->priority, 0, 0, 0);
 			}
 		}
-				
+
 	}
 
-	
-#endif	
+
+#endif
 
 }
 
 #ifdef CONFIG_TDLS
 sint OnTDLS(_adapter *adapter, union recv_frame *precv_frame)
 {
-	struct rx_pkt_attrib	*pattrib = & precv_frame->u.hdr.attrib;
+	struct rx_pkt_attrib	*pattrib = &precv_frame->u.hdr.attrib;
 	sint ret = _SUCCESS;
 	u8 *paction = get_recvframe_data(precv_frame);
 	u8 category_field = 1;
@@ -1034,61 +980,77 @@ sint OnTDLS(_adapter *adapter, union recv_frame *precv_frame)
 	u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a };
 #endif /* CONFIG_WFD */
 	struct tdls_info *ptdlsinfo = &(adapter->tdlsinfo);
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	struct sta_priv *pstapriv = &(adapter->stapriv);
+	struct sta_info *ptdls_sta = NULL;
 
 	/* point to action field */
-	paction+=pattrib->hdrlen 
-			+ pattrib->iv_len 
-			+ SNAP_SIZE 
-			+ ETH_TYPE_LEN 
-			+ PAYLOAD_TYPE_LEN 
-			+ category_field;
+	paction += pattrib->hdrlen
+		   + pattrib->iv_len
+		   + SNAP_SIZE
+		   + ETH_TYPE_LEN
+		   + PAYLOAD_TYPE_LEN
+		   + category_field;
 
-	DBG_871X("[TDLS] Recv %s from "MAC_FMT"\n", rtw_tdls_action_txt(*paction), MAC_ARG(pattrib->src));
+	RTW_INFO("[TDLS] Recv %s from "MAC_FMT" with SeqNum = %d\n", rtw_tdls_action_txt(*paction), MAC_ARG(pattrib->src), GetSequence(get_recvframe_data(precv_frame)));
 
 	if (hal_chk_wl_func(adapter, WL_FUNC_TDLS) == _FALSE) {
-		DBG_871X("Ignore tdls frame since hal doesn't support tdls\n");
+		RTW_INFO("Ignore tdls frame since hal doesn't support tdls\n");
 		ret = _FAIL;
 		return ret;
 	}
 
-	if (ptdlsinfo->tdls_enable == _FALSE) {
-		DBG_871X("recv tdls frame, "
-				"but tdls haven't enabled\n");
+	if (rtw_is_tdls_enabled(adapter) == _FALSE) {
+		RTW_INFO("recv tdls frame, "
+			 "but tdls haven't enabled\n");
 		ret = _FAIL;
 		return ret;
 	}
-	
-	switch(*paction){
+
+	ptdls_sta = rtw_get_stainfo(pstapriv, get_sa(ptr));
+	if (ptdls_sta == NULL) {
+		switch (*paction) {
+		case TDLS_SETUP_REQUEST:
+		case TDLS_DISCOVERY_REQUEST:
+			break;
+		default:
+			RTW_INFO("[TDLS] %s - Direct Link Peer = "MAC_FMT" not found for action = %d\n", __func__, MAC_ARG(get_sa(ptr)), *paction);
+			ret = _FAIL;
+			goto exit;
+		}
+	}
+
+	switch (*paction) {
 	case TDLS_SETUP_REQUEST:
-		ret=On_TDLS_Setup_Req(adapter, precv_frame);
+		ret = On_TDLS_Setup_Req(adapter, precv_frame, ptdls_sta);
 		break;
 	case TDLS_SETUP_RESPONSE:
-		ret=On_TDLS_Setup_Rsp(adapter, precv_frame);
+		ret = On_TDLS_Setup_Rsp(adapter, precv_frame, ptdls_sta);
 		break;
 	case TDLS_SETUP_CONFIRM:
-		ret=On_TDLS_Setup_Cfm(adapter, precv_frame);
+		ret = On_TDLS_Setup_Cfm(adapter, precv_frame, ptdls_sta);
 		break;
 	case TDLS_TEARDOWN:
-		ret=On_TDLS_Teardown(adapter, precv_frame);
+		ret = On_TDLS_Teardown(adapter, precv_frame, ptdls_sta);
 		break;
 	case TDLS_DISCOVERY_REQUEST:
-		ret=On_TDLS_Dis_Req(adapter, precv_frame);
+		ret = On_TDLS_Dis_Req(adapter, precv_frame);
 		break;
 	case TDLS_PEER_TRAFFIC_INDICATION:
-		ret=On_TDLS_Peer_Traffic_Indication(adapter, precv_frame);
+		ret = On_TDLS_Peer_Traffic_Indication(adapter, precv_frame, ptdls_sta);
 		break;
 	case TDLS_PEER_TRAFFIC_RESPONSE:
-		ret=On_TDLS_Peer_Traffic_Rsp(adapter, precv_frame);
+		ret = On_TDLS_Peer_Traffic_Rsp(adapter, precv_frame, ptdls_sta);
 		break;
-#ifdef CONFIG_TDLS_CH_SW		
+#ifdef CONFIG_TDLS_CH_SW
 	case TDLS_CHANNEL_SWITCH_REQUEST:
-		ret=On_TDLS_Ch_Switch_Req(adapter, precv_frame);
+		ret = On_TDLS_Ch_Switch_Req(adapter, precv_frame, ptdls_sta);
 		break;
 	case TDLS_CHANNEL_SWITCH_RESPONSE:
-		ret=On_TDLS_Ch_Switch_Rsp(adapter, precv_frame);
+		ret = On_TDLS_Ch_Switch_Rsp(adapter, precv_frame, ptdls_sta);
 		break;
-#endif		
-#ifdef CONFIG_WFD			
+#endif
+#ifdef CONFIG_WFD
 	/* First byte of WFA OUI */
 	case 0x50:
 		if (_rtw_memcmp(WFA_OUI, paction, 3)) {
@@ -1096,37 +1058,36 @@ sint OnTDLS(_adapter *adapter, union recv_frame *precv_frame)
 			if (*(paction + 3) == 0x04) {
 				/* WFDTDLS: for sigma test, do not setup direct link automatically */
 				ptdlsinfo->dev_discovered = _TRUE;
-				DBG_871X("recv tunneled probe request frame\n");
+				RTW_INFO("recv tunneled probe request frame\n");
 				issue_tunneled_probe_rsp(adapter, precv_frame);
 			}
-			/* Probe response frame */ 
+			/* Probe response frame */
 			if (*(paction + 3) == 0x05) {
 				/* WFDTDLS: for sigma test, do not setup direct link automatically */
 				ptdlsinfo->dev_discovered = _TRUE;
-				DBG_871X("recv tunneled probe response frame\n");
+				RTW_INFO("recv tunneled probe response frame\n");
 			}
 		}
 		break;
 #endif /* CONFIG_WFD */
 	default:
-		DBG_871X("receive TDLS frame %d but not support\n", *paction);
-		ret=_FAIL;
+		RTW_INFO("receive TDLS frame %d but not support\n", *paction);
+		ret = _FAIL;
 		break;
 	}
 
 exit:
 	return ret;
-	
+
 }
 #endif /* CONFIG_TDLS */
 
-void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info*sta);
-void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info*sta)
+void count_rx_stats(_adapter *padapter, union 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->u.hdr.attrib;
+	struct rx_pkt_attrib	*pattrib = &prframe->u.hdr.attrib;
 	struct recv_priv		*precvpriv = &padapter->recvpriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
@@ -1136,268 +1097,221 @@ void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_in
 
 	padapter->mlmepriv.LinkDetectInfo.NumRxOkInPeriod++;
 
-	if( (!MacAddr_isBcst(pattrib->dst)) && (!IS_MCAST(pattrib->dst))){
+	if ((!MacAddr_isBcst(pattrib->dst)) && (!IS_MCAST(pattrib->dst)))
 		padapter->mlmepriv.LinkDetectInfo.NumRxUnicastOkInPeriod++;
-	}
 
-	if(sta)
+	if (sta)
 		psta = sta;
 	else
 		psta = prframe->u.hdr.psta;
 
-	if(psta)
-	{
+	if (psta) {
+		u8 is_ra_bmc = IS_MCAST(pattrib->ra);
+
 		pstats = &psta->sta_stats;
 
+		pstats->last_rx_time = rtw_get_current_time();
 		pstats->rx_data_pkts++;
 		pstats->rx_bytes += sz;
-		
-		/*record rx packets for every tid*/	
-		pstats->rx_data_qos_pkts[pattrib->priority]++;
+		if (is_broadcast_mac_addr(pattrib->ra)) {
+			pstats->rx_data_bc_pkts++;
+			pstats->rx_bc_bytes += sz;
+		} else if (is_ra_bmc) {
+			pstats->rx_data_mc_pkts++;
+			pstats->rx_mc_bytes += sz;
+		}
 
-#ifdef CONFIG_TDLS
-		if(psta->tdls_sta_state & TDLS_LINKED_STATE)
-		{
-			struct sta_info *pap_sta = NULL;
-			pap_sta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
-			if(pap_sta)
-			{
-				pstats = &pap_sta->sta_stats;
-				pstats->rx_data_pkts++;
-				pstats->rx_bytes += sz;
-			}
+		if (!is_ra_bmc) {
+			pstats->rxratecnt[pattrib->data_rate]++;
+			/*record rx packets for every tid*/
+			pstats->rx_data_qos_pkts[pattrib->priority]++;
 		}
-#endif //CONFIG_TDLS
+#ifdef CONFIG_DYNAMIC_SOML
+		rtw_dyn_soml_byte_update(padapter, pattrib->data_rate, sz);
+#endif
 	}
 
 #ifdef CONFIG_CHECK_LEAVE_LPS
 	traffic_check_for_leave_lps(padapter, _FALSE, 0);
-#endif //CONFIG_LPS
+#endif /* CONFIG_LPS */
 
 }
 
 sint sta2sta_data_frame(
 	_adapter *adapter,
 	union recv_frame *precv_frame,
-	struct sta_info**psta
-);
-sint sta2sta_data_frame(
-	_adapter *adapter,
-	union recv_frame *precv_frame,
-	struct sta_info**psta
+	struct sta_info **psta
 )
 {
 	u8 *ptr = precv_frame->u.hdr.rx_data;
 	sint ret = _SUCCESS;
-	struct rx_pkt_attrib *pattrib = & precv_frame->u.hdr.attrib;
-	struct	sta_priv 		*pstapriv = &adapter->stapriv;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct	sta_priv		*pstapriv = &adapter->stapriv;
 	struct	mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 	u8 *mybssid  = get_bssid(pmlmepriv);
 	u8 *myhwaddr = adapter_mac_addr(adapter);
-	u8 * sta_addr = NULL;
+	u8 *sta_addr = pattrib->ta;
 	sint bmcast = IS_MCAST(pattrib->dst);
 
-#ifdef CONFIG_TDLS	
+#ifdef CONFIG_TDLS
 	struct tdls_info *ptdlsinfo = &adapter->tdlsinfo;
 #ifdef CONFIG_TDLS_CH_SW
 	struct tdls_ch_switch *pchsw_info = &ptdlsinfo->chsw_info;
 #endif
-	struct sta_info *ptdls_sta=NULL;
-	u8 *psnap_type=ptr+pattrib->hdrlen + pattrib->iv_len+SNAP_SIZE;
-	//frame body located after [+2]: ether-type, [+1]: payload type
-	u8 *pframe_body = psnap_type+2+1;
+	struct sta_info *ptdls_sta = NULL;
+	u8 *psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
+	/* frame body located after [+2]: ether-type, [+1]: payload type */
+	u8 *pframe_body = psnap_type + 2 + 1;
 #endif
 
-_func_enter_;
 
-	//DBG_871X("[%s] %d, seqnum:%d\n", __FUNCTION__, __LINE__, pattrib->seq_num);
+	/* RTW_INFO("[%s] %d, seqnum:%d\n", __FUNCTION__, __LINE__, pattrib->seq_num); */
 
 	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
-		(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE))
-	{
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
 
-		// filter packets that SA is myself or multicast or broadcast
-		if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)){
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" SA==myself \n"));
-			ret= _FAIL;
+		/* filter packets that SA is myself or multicast or broadcast */
+		if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)) {
+			ret = _FAIL;
 			goto exit;
 		}
 
-		if( (!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN))	&& (!bmcast) ){
-			ret= _FAIL;
+		if ((!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN))	&& (!bmcast)) {
+			ret = _FAIL;
 			goto exit;
 		}
 
-		if( _rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
-		   _rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
-		   (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN)) ) {
-			ret= _FAIL;
+		if (_rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
+		    _rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
+		    (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))) {
+			ret = _FAIL;
 			goto exit;
 		}
 
-		sta_addr = pattrib->src;
-
-	}
-	else if(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-	{
+	} else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
 #ifdef CONFIG_TDLS
 
 		/* direct link data transfer */
 		if (ptdlsinfo->link_established == _TRUE) {
-			ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->src);
+			*psta = ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->ta);
 			if (ptdls_sta == NULL) {
-				ret=_FAIL;
+				ret = _FAIL;
 				goto exit;
 			} else if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
 				/* filter packets that SA is myself or multicast or broadcast */
 				if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)) {
-					ret= _FAIL;
+					ret = _FAIL;
 					goto exit;
 				}
 				/* da should be for me */
 				if ((!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN)) && (!bmcast)) {
-					ret= _FAIL;
+					ret = _FAIL;
 					goto exit;
 				}
 				/* check BSSID */
 				if (_rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
-				     _rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
-				     (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))) {
-					ret= _FAIL;
+				    _rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
+				    (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))) {
+					ret = _FAIL;
 					goto exit;
 				}
 
 #ifdef CONFIG_TDLS_CH_SW
-				pchsw_info->ch_sw_state |= TDLS_PEER_AT_OFF_STATE;
-
-				if(ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) {
-					if (!(pchsw_info->ch_sw_state & TDLS_PEER_AT_OFF_STATE)) {
-						DBG_871X("%s %d\n", __FUNCTION__, __LINE__);
-						issue_nulldata_to_TDLS_peer_STA(adapter, ptdls_sta->hwaddr, 0, 0, 0);
+				if (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) {
+					if (adapter->mlmeextpriv.cur_channel != rtw_get_oper_ch(adapter)) {
 						pchsw_info->ch_sw_state |= TDLS_PEER_AT_OFF_STATE;
+						if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
+							_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
 						/* On_TDLS_Peer_Traffic_Rsp(adapter, precv_frame); */
 					}
 				}
 #endif
 
 				/* process UAPSD tdls sta */
-				process_pwrbit_data(adapter, precv_frame);
+				process_pwrbit_data(adapter, precv_frame, ptdls_sta);
 
 				/* if NULL-frame, check pwrbit */
-				if ((GetFrameSubType(ptr) & WIFI_DATA_NULL) == WIFI_DATA_NULL) {
+				if ((get_frame_sub_type(ptr) & WIFI_DATA_NULL) == WIFI_DATA_NULL) {
 					/* NULL-frame with pwrbit=1, buffer_STA should buffer frames for sleep_STA */
 					if (GetPwrMgt(ptr)) {
 						/* it would be triggered when we are off channel and receiving NULL DATA */
 						/* we can confirm that peer STA is at off channel */
-						DBG_871X("TDLS: recv peer null frame with pwr bit 1\n");
-						//ptdls_sta->tdls_sta_state|=TDLS_PEER_SLEEP_STATE;
+						RTW_INFO("TDLS: recv peer null frame with pwr bit 1\n");
+						/* ptdls_sta->tdls_sta_state|=TDLS_PEER_SLEEP_STATE; */
 					}
 
 					/* TODO: Updated BSSID's seq. */
-					//DBG_871X("drop Null Data\n");
+					/* RTW_INFO("drop Null Data\n"); */
 					ptdls_sta->tdls_sta_state &= ~(TDLS_WAIT_PTR_STATE);
-					ret= _FAIL;
+					ret = _FAIL;
 					goto exit;
 				}
 
 				/* receive some of all TDLS management frames, process it at ON_TDLS */
 				if (_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_TDLS, 2)) {
-					ret= OnTDLS(adapter, precv_frame);
+					ret = OnTDLS(adapter, precv_frame);
 					goto exit;
 				}
 
-				if ((GetFrameSubType(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE) {
-					process_wmmps_data(adapter, precv_frame);
-				}
+				if ((get_frame_sub_type(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE)
+					process_wmmps_data(adapter, precv_frame, ptdls_sta);
 
 				ptdls_sta->tdls_sta_state &= ~(TDLS_WAIT_PTR_STATE);
 
 			}
-
-			sta_addr = pattrib->src;
-			
-		}		
-		else
+		} else
 #endif /* CONFIG_TDLS */
 		{
-			// For Station mode, sa and bssid should always be BSSID, and DA is my mac-address
-			if(!_rtw_memcmp(pattrib->bssid, pattrib->src, ETH_ALEN) )
-			{
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("bssid != TA under STATION_MODE; drop pkt\n"));
-				ret= _FAIL;
+			/* For Station mode, sa and bssid should always be BSSID, and DA is my mac-address */
+			if (!_rtw_memcmp(pattrib->bssid, pattrib->src, ETH_ALEN)) {
+				ret = _FAIL;
 				goto exit;
+			}
 		}
 
-		sta_addr = pattrib->bssid;
-		}
-
-	}
-	else if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
-		if (bmcast)
-		{
-			// For AP mode, if DA == MCAST, then BSSID should be also MCAST
-			if (!IS_MCAST(pattrib->bssid)){
-					ret= _FAIL;
-					goto exit;
+	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+		if (bmcast) {
+			/* For AP mode, if DA == MCAST, then BSSID should be also MCAST */
+			if (!IS_MCAST(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(!_rtw_memcmp(pattrib->bssid, pattrib->dst, ETH_ALEN)) {
-				ret= _FAIL;
+		} else { /* not mc-frame */
+			/* For AP mode, if DA is non-MCAST, then it must be BSSID, and bssid == BSSID */
+			if (!_rtw_memcmp(pattrib->bssid, pattrib->dst, ETH_ALEN)) {
+				ret = _FAIL;
 				goto exit;
 			}
-
-			sta_addr = pattrib->src;
 		}
 
-	}
-	else if(check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
-	{
+	} else if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) {
 		_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
-		_rtw_memcpy(pattrib->src, GetAddr2Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
 		_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
 		_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 		_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
 
 		sta_addr = mybssid;
-	}
-	else
-	{
+	} else
 		ret  = _FAIL;
-	}
 
-
-
-	if(bmcast)
-		*psta = rtw_get_bcmc_stainfo(adapter);
-	else
-		*psta = rtw_get_stainfo(pstapriv, sta_addr); // get ap_info
-
-#ifdef CONFIG_TDLS
-	if(ptdls_sta != NULL)
-	{
-		*psta = ptdls_sta;
-	}
-#endif //CONFIG_TDLS
+#ifdef CONFIG_TDLS
+	if (ptdls_sta == NULL)
+#endif
+		*psta = rtw_get_stainfo(pstapriv, sta_addr);
 
 	if (*psta == NULL) {
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("can't get psta under sta2sta_data_frame ; drop pkt\n"));
 #ifdef CONFIG_MP_INCLUDED
-		if (adapter->registrypriv.mp_mode == 1)
-		{
-			if(check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
+		if (adapter->registrypriv.mp_mode == 1) {
+			if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
 				adapter->mppriv.rx_pktloss++;
 		}
 #endif
-		ret= _FAIL;
+		ret = _FAIL;
 		goto exit;
 	}
 
 exit:
-_func_exit_;
 	return ret;
 
 }
@@ -1405,167 +1319,136 @@ _func_exit_;
 sint ap2sta_data_frame(
 	_adapter *adapter,
 	union recv_frame *precv_frame,
-	struct sta_info**psta );
-sint ap2sta_data_frame(
-	_adapter *adapter,
-	union recv_frame *precv_frame,
-	struct sta_info**psta )
+	struct sta_info **psta)
 {
 	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib *pattrib = & precv_frame->u.hdr.attrib;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
 	sint ret = _SUCCESS;
-	struct	sta_priv 		*pstapriv = &adapter->stapriv;
+	struct	sta_priv		*pstapriv = &adapter->stapriv;
 	struct	mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 	u8 *mybssid  = get_bssid(pmlmepriv);
 	u8 *myhwaddr = adapter_mac_addr(adapter);
 	sint bmcast = IS_MCAST(pattrib->dst);
 
-_func_enter_;
 
 	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-		&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE 
-			|| check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE	)
-		)
-	{
+	    && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE
+		|| check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
+	   ) {
 
-		// filter packets that SA is myself or multicast or broadcast
-		if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)){
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" SA==myself \n"));
+		/* filter packets that SA is myself or multicast or broadcast */
+		if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)) {
 			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s SA="MAC_FMT", myhwaddr="MAC_FMT"\n",
-				__FUNCTION__, MAC_ARG(pattrib->src), MAC_ARG(myhwaddr));
-			#endif			
-			ret= _FAIL;
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" SA="MAC_FMT", myhwaddr="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->src), MAC_ARG(myhwaddr));
+			#endif
+			ret = _FAIL;
 			goto exit;
 		}
 
-		// da should be for me
-		if((!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN))&& (!bmcast))
-		{
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,
-				(" ap2sta_data_frame:  compare DA fail; DA="MAC_FMT"\n", MAC_ARG(pattrib->dst)));
+		/* da should be for me */
+		if ((!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN)) && (!bmcast)) {
 			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s DA="MAC_FMT"\n", __func__, MAC_ARG(pattrib->dst));
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->dst));
 			#endif
-			ret= _FAIL;
+			ret = _FAIL;
 			goto exit;
 		}
 
 
-		// check BSSID
-		if( _rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
-		     _rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
-		     (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN)) )
-		{
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,
-				(" ap2sta_data_frame:  compare BSSID fail ; BSSID="MAC_FMT"\n", MAC_ARG(pattrib->bssid)));
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("mybssid="MAC_FMT"\n", MAC_ARG(mybssid)));
+		/* check BSSID */
+		if (_rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
+		    _rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
+		    (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))) {
 			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s BSSID="MAC_FMT", mybssid="MAC_FMT"\n",
-				__FUNCTION__, MAC_ARG(pattrib->bssid), MAC_ARG(mybssid));
-			DBG_871X( "this adapter = %d, buddy adapter = %d\n", adapter->adapter_type, adapter->pbuddy_adapter->adapter_type );
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" BSSID="MAC_FMT", mybssid="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->bssid), MAC_ARG(mybssid));
 			#endif
 
-			if(!bmcast)
-			{
-				DBG_871X("issue_deauth to the nonassociated ap=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->bssid));
+			if (!bmcast) {
+				RTW_INFO(ADPT_FMT" -issue_deauth to the nonassociated ap=" MAC_FMT " for the reason(7)\n", ADPT_ARG(adapter), MAC_ARG(pattrib->bssid));
 				issue_deauth(adapter, pattrib->bssid, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
 			}
 
-			ret= _FAIL;
+			ret = _FAIL;
 			goto exit;
 		}
 
-		if(bmcast)
-			*psta = rtw_get_bcmc_stainfo(adapter);
-		else
-			*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); // get ap_info
-
+		*psta = rtw_get_stainfo(pstapriv, pattrib->ta);
 		if (*psta == NULL) {
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("ap2sta: can't get psta under STATION_MODE ; drop pkt\n"));
 			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s can't get psta under STATION_MODE ; drop pkt\n", __FUNCTION__);
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" can't get psta under STATION_MODE ; drop pkt\n"
+				, FUNC_ADPT_ARG(adapter));
 			#endif
-			ret= _FAIL;
+			ret = _FAIL;
 			goto exit;
 		}
 
-		if ((GetFrameSubType(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE) {
+		/*if ((get_frame_sub_type(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE) {
 		}
+		*/
 
-		if (GetFrameSubType(ptr) & BIT(6)) {
+		if (get_frame_sub_type(ptr) & BIT(6)) {
 			/* 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) == _TRUE) &&
-		     (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) )
-	{
+	} else if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) &&
+		   (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
 		_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
-		_rtw_memcpy(pattrib->src, GetAddr2Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
 		_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
 		_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 		_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
 
-		//
-		if(adapter->mppriv.bRTWSmbCfg==_FALSE)
-			_rtw_memcpy(pattrib->bssid,  mybssid, ETH_ALEN);
 
-
-		*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); // get sta_info
+		*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); /* get sta_info */
 		if (*psta == NULL) {
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("can't get psta under MP_MODE ; drop pkt\n"));
 			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s can't get psta under WIFI_MP_STATE ; drop pkt\n", __FUNCTION__);
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" can't get psta under WIFI_MP_STATE ; drop pkt\n"
+				, FUNC_ADPT_ARG(adapter));
 			#endif
-			ret= _FAIL;
+			ret = _FAIL;
 			goto exit;
 		}
 
 
-	}
-	else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
+	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
 		/* Special case */
 		ret = RTW_RX_HANDLED;
 		goto exit;
-	}
-	else
-	{
-		if(_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN)&& (!bmcast))
-		{
-			*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); // get sta_info
-			if (*psta == NULL)
-			{
-	
-				//for AP multicast issue , modify by yiwei 
-				static u32 send_issue_deauth_time=0;
-			
-				//DBG_871X("After send deauth , %u ms has elapsed.\n", rtw_get_passing_time_ms(send_issue_deauth_time));
-				
-				if(rtw_get_passing_time_ms(send_issue_deauth_time) > 10000 || send_issue_deauth_time == 0 )
-				{
-					send_issue_deauth_time = rtw_get_current_time(); 
-					
-					DBG_871X("issue_deauth to the ap=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->bssid));
-					
+	} else {
+		if (_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN) && (!bmcast)) {
+			*psta = rtw_get_stainfo(pstapriv, pattrib->ta);
+			if (*psta == NULL) {
+
+				/* for AP multicast issue , modify by yiwei */
+				static systime send_issue_deauth_time = 0;
+
+				/* RTW_INFO("After send deauth , %u ms has elapsed.\n", rtw_get_passing_time_ms(send_issue_deauth_time)); */
+
+				if (rtw_get_passing_time_ms(send_issue_deauth_time) > 10000 || send_issue_deauth_time == 0) {
+					send_issue_deauth_time = rtw_get_current_time();
+
+					RTW_INFO("issue_deauth to the ap=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->bssid));
+
 					issue_deauth(adapter, pattrib->bssid, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
 				}
 			}
-		}	
-	
+		}
+
 		ret = _FAIL;
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s fw_state:0x%x\n", __FUNCTION__, get_fwstate(pmlmepriv));
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" fw_state:0x%x\n"
+			, FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
 		#endif
 	}
 
 exit:
 
-_func_exit_;
 
 	return ret;
 
@@ -1574,86 +1457,82 @@ _func_exit_;
 sint sta2ap_data_frame(
 	_adapter *adapter,
 	union recv_frame *precv_frame,
-	struct sta_info**psta );
-sint sta2ap_data_frame(
-	_adapter *adapter,
-	union recv_frame *precv_frame,
-	struct sta_info**psta )
+	struct sta_info **psta)
 {
 	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib *pattrib = & precv_frame->u.hdr.attrib;
-	struct	sta_priv 		*pstapriv = &adapter->stapriv;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct	sta_priv		*pstapriv = &adapter->stapriv;
 	struct	mlme_priv	*pmlmepriv = &adapter->mlmepriv;
-	unsigned char *mybssid  = get_bssid(pmlmepriv);	
-	sint ret=_SUCCESS;
+	unsigned char *mybssid  = get_bssid(pmlmepriv);
+	sint ret = _SUCCESS;
 
-_func_enter_;
 
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
-		//For AP mode, RA=BSSID, TX=STA(SRC_ADDR), A3=DST_ADDR
-		if(!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))
-		{
-			ret= _FAIL;
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+		/* For AP mode, RA=BSSID, TX=STA(SRC_ADDR), A3=DST_ADDR */
+		if (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN)) {
+			ret = _FAIL;
 			goto exit;
 		}
 
-		*psta = rtw_get_stainfo(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_871X("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
+		*psta = rtw_get_stainfo(pstapriv, pattrib->ta);
+		if (*psta == NULL) {
+			#ifdef CONFIG_DFS_MASTER
+			struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+			/* prevent RX tasklet blocks cmd_thread */
+			if (rfctl->radar_detected == 1)
+				goto bypass_deauth7;
+			#endif
+
+			RTW_INFO("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
 
 			issue_deauth(adapter, pattrib->src, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
 
+#ifdef CONFIG_DFS_MASTER
+bypass_deauth7:
+#endif
 			ret = RTW_RX_HANDLED;
 			goto exit;
 		}
 
-		process_pwrbit_data(adapter, precv_frame);
+		process_pwrbit_data(adapter, precv_frame, *psta);
 
-		if ((GetFrameSubType(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE) {
-			process_wmmps_data(adapter, precv_frame);
-		}
+		if ((get_frame_sub_type(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE)
+			process_wmmps_data(adapter, precv_frame, *psta);
 
-		if (GetFrameSubType(ptr) & BIT(6)) {
+		if (get_frame_sub_type(ptr) & BIT(6)) {
 			/* 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) == _TRUE) &&
-		     (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) )
-	{
-		//DBG_871X("%s ,in WIFI_MP_STATE \n",__func__);
+	} else if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) &&
+		   (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+		/* RTW_INFO("%s ,in WIFI_MP_STATE\n",__func__); */
 		_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
-		_rtw_memcpy(pattrib->src, GetAddr2Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
 		_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
 		_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 		_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-		//
-		if(adapter->mppriv.bRTWSmbCfg == _FALSE)
-			_rtw_memcpy(pattrib->bssid,  mybssid, ETH_ALEN);
 
-		*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); // get sta_info
+
+		*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); /* get sta_info */
 		if (*psta == NULL) {
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("can't get psta under MP_MODE ; drop pkt\n"));
 			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s can't get psta under WIFI_MP_STATE ; drop pkt\n", __FUNCTION__);
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" can't get psta under WIFI_MP_STATE ; drop pkt\n"
+				, FUNC_ADPT_ARG(adapter));
 			#endif
-			ret= _FAIL;
+			ret = _FAIL;
 			goto exit;
 		}
 
-	}
-	else {
+	} else {
 		u8 *myhwaddr = adapter_mac_addr(adapter);
 		if (!_rtw_memcmp(pattrib->ra, myhwaddr, ETH_ALEN)) {
 			ret = RTW_RX_HANDLED;
 			goto exit;
 		}
-		DBG_871X("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
+		RTW_INFO("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
 		issue_deauth(adapter, pattrib->src, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
 		ret = RTW_RX_HANDLED;
 		goto exit;
@@ -1661,7 +1540,6 @@ _func_enter_;
 
 exit:
 
-_func_exit_;
 
 	return ret;
 
@@ -1673,88 +1551,78 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	u8 *pframe = precv_frame->u.hdr.rx_data;
-	struct sta_info *psta=NULL;
-	//uint len = precv_frame->u.hdr.len;
-		
-	//DBG_871X("+validate_recv_ctrl_frame\n");
+	struct sta_info *psta = NULL;
+	/* uint len = precv_frame->u.hdr.len; */
+
+	/* RTW_INFO("+validate_recv_ctrl_frame\n"); */
 
 	if (GetFrameType(pframe) != WIFI_CTRL_TYPE)
-	{		
 		return _FAIL;
-	}
 
-	//receive the frames that ra(a1) is my address
+	/* receive the frames that ra(a1) is my address */
 	if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN))
 		return _FAIL;
 
-	psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));
-	if (psta==NULL)
-	{
+	psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+	if (psta == NULL)
 		return _FAIL;
-	}
 
-	//for rx pkt statistics
+	/* for rx pkt statistics */
+	psta->sta_stats.last_rx_time = rtw_get_current_time();
 	psta->sta_stats.rx_ctrl_pkts++;
 
-	//only handle ps-poll
-	if(GetFrameSubType(pframe) == WIFI_PSPOLL)
-	{
+	/* only handle ps-poll */
+	if (get_frame_sub_type(pframe) == WIFI_PSPOLL) {
 #ifdef CONFIG_AP_MODE
 		u16 aid;
-		u8 wmmps_ac=0;	
-	
+		u8 wmmps_ac = 0;
+
 		aid = GetAid(pframe);
-		if(psta->aid!=aid)
-		{
+		if (psta->cmn.aid != aid)
 			return _FAIL;
-		}
 
-		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;	
+		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)
+		if (wmmps_ac)
 			return _FAIL;
 
-		if(psta->state & WIFI_STA_ALIVE_CHK_STATE)
-		{					
-			DBG_871X("%s alive check-rx ps-poll\n", __func__);
+		if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
+			RTW_INFO("%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&BIT(psta->aid)))
-		{
-			_irqL irqL;	 
+		if ((psta->state & WIFI_SLEEP_STATE) && (rtw_tim_map_is_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid))) {
+			_irqL irqL;
 			_list	*xmitframe_plist, *xmitframe_phead;
-			struct xmit_frame *pxmitframe=NULL;
+			struct xmit_frame *pxmitframe = NULL;
 			struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-		
-			//_enter_critical_bh(&psta->sleep_q.lock, &irqL);
+
+			/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
 			_enter_critical_bh(&pxmitpriv->lock, &irqL);
 
 			xmitframe_phead = get_list_head(&psta->sleep_q);
 			xmitframe_plist = get_next(xmitframe_phead);
 
-			if ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE)
-			{			
+			if ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
 				pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
 
 				xmitframe_plist = get_next(xmitframe_plist);
@@ -1763,138 +1631,350 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 
 				psta->sleepq_len--;
 
-				if(psta->sleepq_len>0)
+				if (psta->sleepq_len > 0)
 					pxmitframe->attrib.mdata = 1;
 				else
 					pxmitframe->attrib.mdata = 0;
 
 				pxmitframe->attrib.triggered = 1;
 
-				//DBG_871X("handling ps-poll, q_len=%d, tim=%x\n", psta->sleepq_len, pstapriv->tim_bitmap);
+				/* RTW_INFO("handling ps-poll, q_len=%d\n", psta->sleepq_len); */
+				/* RTW_INFO_DUMP("handling, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 
 #if 0
 				_exit_critical_bh(&psta->sleep_q.lock, &irqL);
-				if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
-				{
+				if (rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
 					rtw_os_xmit_complete(padapter, pxmitframe);
-				}
-				_enter_critical_bh(&psta->sleep_q.lock, &irqL);	
+				_enter_critical_bh(&psta->sleep_q.lock, &irqL);
 #endif
 				rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
 
-				if(psta->sleepq_len==0)
-				{
-					pstapriv->tim_bitmap &= ~BIT(psta->aid);
+				if (psta->sleepq_len == 0) {
+					rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-					//DBG_871X("after handling ps-poll, tim=%x\n", pstapriv->tim_bitmap);
+					/* RTW_INFO("after handling ps-poll\n"); */
+					/* RTW_INFO_DUMP("after handling, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 
-					//upate BCN for TIM IE
-					//update_BCNTIM(padapter);		
+					/* upate BCN for TIM IE */
+					/* update_BCNTIM(padapter);		 */
 					update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
 				}
-				
-				//_exit_critical_bh(&psta->sleep_q.lock, &irqL);
+
+				/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
 				_exit_critical_bh(&pxmitpriv->lock, &irqL);
-				
-			}
-			else
-			{
-				//_exit_critical_bh(&psta->sleep_q.lock, &irqL);
+
+			} else {
+				/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
 				_exit_critical_bh(&pxmitpriv->lock, &irqL);
-			
-				//DBG_871X("no buffered packets to xmit\n");
-				if(pstapriv->tim_bitmap&BIT(psta->aid))
-				{
-					if(psta->sleepq_len==0)
-					{
-						DBG_871X("no buffered packets to xmit\n");
-
-						//issue nulldata with More data bit = 0 to indicate we have no buffered packets
-						issue_nulldata_in_interrupt(padapter, psta->hwaddr, 0);
-					}
-					else
-					{
-						DBG_871X("error!psta->sleepq_len=%d\n", psta->sleepq_len);
-						psta->sleepq_len=0;						
+
+				/* RTW_INFO("no buffered packets to xmit\n"); */
+				if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
+					if (psta->sleepq_len == 0) {
+						RTW_INFO("no buffered packets to xmit\n");
+
+						/* issue nulldata with More data bit = 0 to indicate we have no buffered packets */
+						issue_nulldata(padapter, psta->cmn.mac_addr, 0, 0, 0);
+					} else {
+						RTW_INFO("error!psta->sleepq_len=%d\n", psta->sleepq_len);
+						psta->sleepq_len = 0;
 					}
-				
-					pstapriv->tim_bitmap &= ~BIT(psta->aid);					
 
-					//upate BCN for TIM IE
-					//update_BCNTIM(padapter);
+					rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
+
+					/* upate BCN for TIM IE */
+					/* update_BCNTIM(padapter); */
 					update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
 				}
-			}				
+			}
 		}
-#endif //CONFIG_AP_MODE
-	}
-	else if(GetFrameSubType(pframe) == WIFI_NDPA) {
+#endif /* CONFIG_AP_MODE */
+	} else if (get_frame_sub_type(pframe) == WIFI_NDPA) {
 #ifdef CONFIG_BEAMFORMING
-		beamforming_get_ndpa_frame(padapter, precv_frame);
+		rtw_beamforming_get_ndpa_frame(padapter, precv_frame);
 #endif/*CONFIG_BEAMFORMING*/
+	} else if (get_frame_sub_type(pframe) == WIFI_BAR) {
+		rtw_process_bar_frame(padapter, precv_frame);
 	}
 
 	return _FAIL;
 
 }
 
-union recv_frame* recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame);
-sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame);
-sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+static sint validate_mgmt_protect(_adapter *adapter, union recv_frame *precv_frame)
 {
-	//struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+#define DBG_VALIDATE_MGMT_PROTECT 0
+#define DBG_VALIDATE_MGMT_DEC 0
 
-	RT_TRACE(_module_rtl871x_recv_c_, _drv_info_, ("+validate_recv_mgnt_frame\n"));
+	struct security_priv *sec = &adapter->securitypriv;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct sta_info	*psta = precv_frame->u.hdr.psta;
+	u8 *ptr;
+	u8 type;
+	u8 subtype;
+	u8 is_bmc;
+	u8 category = 0xFF;
 
-#if 0
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
-#ifdef CONFIG_NATIVEAP_MLME
-		mgt_dispatcher(padapter, precv_frame);
-#else
-		rtw_hostapd_mlme_rx(padapter, precv_frame);
+#ifdef CONFIG_IEEE80211W
+	const u8 *igtk;
+	u16 igtk_id;
+	u64* ipn;
+#endif
+
+	u8 *mgmt_DATA;
+	u32 data_len = 0;
+
+	sint ret;
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		if (!adapter->mesh_info.mesh_auth_id)
+			return pattrib->privacy ? _FAIL : _SUCCESS;
+	} else
 #endif
+	if (SEC_IS_BIP_KEY_INSTALLED(sec) == _FALSE)
+		return _SUCCESS;
+
+	ptr = precv_frame->u.hdr.rx_data;
+	type = GetFrameType(ptr);
+	subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
+	is_bmc = IS_MCAST(GetAddr1Ptr(ptr));
+
+#if DBG_VALIDATE_MGMT_PROTECT
+	if (subtype == WIFI_DEAUTH) {
+		RTW_INFO(FUNC_ADPT_FMT" bmc:%u, deauth, privacy:%u, encrypt:%u, bdecrypted:%u\n"
+			, FUNC_ADPT_ARG(adapter)
+			, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+	} else if (subtype == WIFI_DISASSOC) {
+		RTW_INFO(FUNC_ADPT_FMT" bmc:%u, disassoc, privacy:%u, encrypt:%u, bdecrypted:%u\n"
+			, FUNC_ADPT_ARG(adapter)
+			, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+	} if (subtype == WIFI_ACTION) {
+		if (pattrib->privacy) {
+			RTW_INFO(FUNC_ADPT_FMT" bmc:%u, action(?), privacy:%u, encrypt:%u, bdecrypted:%u\n"
+				, FUNC_ADPT_ARG(adapter)
+				, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+		} else {
+			RTW_INFO(FUNC_ADPT_FMT" bmc:%u, action(%u), privacy:%u, encrypt:%u, bdecrypted:%u\n"
+				, FUNC_ADPT_ARG(adapter), is_bmc
+				, *(ptr + sizeof(struct rtw_ieee80211_hdr_3addr))
+				, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+		}
 	}
-	else
+#endif
+
+	if (!pattrib->privacy) {
+		if (!psta || !(psta->flags & WLAN_STA_MFP)) {
+			/* peer is not MFP capable, no need to check */
+			goto exit;
+		}
+
+		if (subtype == WIFI_ACTION)
+			category = *(ptr + sizeof(struct rtw_ieee80211_hdr_3addr));
+	
+		if (is_bmc) {
+			/* broadcast cases */
+			if (subtype == WIFI_ACTION) {
+				if (CATEGORY_IS_GROUP_PRIVACY(category)) {
+					/* drop broadcast group privacy action frame without encryption */
+					#if DBG_VALIDATE_MGMT_PROTECT
+					RTW_INFO(FUNC_ADPT_FMT" broadcast gp action(%u) w/o encrypt\n"
+						, FUNC_ADPT_ARG(adapter), category);
+					#endif
+					goto fail;
+				}
+				if (CATEGORY_IS_ROBUST(category)) {
+					/* broadcast robust action frame need BIP check */
+					goto bip_verify;
+				}
+			}
+			if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC) {
+				/* broadcast deauth or disassoc frame need BIP check */
+				goto bip_verify;
+			}
+			goto exit;
+
+		} else {
+			/* unicast cases */
+			#ifdef CONFIG_IEEE80211W
+			if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC) {
+				if (!MLME_IS_MESH(adapter)) {
+					unsigned short reason = le16_to_cpu(*(unsigned short *)(ptr + WLAN_HDR_A3_LEN));
+
+					#if DBG_VALIDATE_MGMT_PROTECT
+					RTW_INFO(FUNC_ADPT_FMT" unicast %s, reason=%d w/o encrypt\n"
+						, FUNC_ADPT_ARG(adapter), subtype == WIFI_DEAUTH ? "deauth" : "disassoc", reason);
+					#endif
+					if (reason == 6 || reason == 7) {
+						/* issue sa query request */
+						issue_action_SA_Query(adapter, psta->cmn.mac_addr, 0, 0, IEEE80211W_RIGHT_KEY);
+					}
+				}
+				goto fail;
+			}
+			#endif
+
+			if (subtype == WIFI_ACTION && CATEGORY_IS_ROBUST(category)) {
+				if (psta->bpairwise_key_installed == _TRUE) {
+					#if DBG_VALIDATE_MGMT_PROTECT
+					RTW_INFO(FUNC_ADPT_FMT" unicast robust action(%d) w/o encrypt\n"
+						, FUNC_ADPT_ARG(adapter), category);
+					#endif
+					goto fail;
+				}
+			}
+			goto exit;
+		}
+
+bip_verify:
+#ifdef CONFIG_IEEE80211W
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(adapter)) {
+			if (psta->igtk_bmp) {
+				igtk = psta->igtk.skey;
+				igtk_id = psta->igtk_id;
+				ipn = &psta->igtk_pn.val;
+			} else {
+				/* mesh MFP without IGTK */
+				goto exit;
+			}
+		} else
+		#endif
+		{
+			igtk = sec->dot11wBIPKey[sec->dot11wBIPKeyid].skey;
+			igtk_id = sec->dot11wBIPKeyid;
+			ipn = &sec->dot11wBIPrxpn.val;
+		}
+
+		/* verify BIP MME IE */
+		ret = rtw_BIP_verify(adapter
+			, get_recvframe_data(precv_frame)
+			, get_recvframe_len(precv_frame)
+			, igtk, igtk_id, ipn);
+		if (ret == _FAIL) {
+			/* RTW_INFO("802.11w BIP verify fail\n"); */
+			goto fail;
+
+		} else if (ret == RTW_RX_HANDLED) {
+			#if DBG_VALIDATE_MGMT_PROTECT
+			RTW_INFO(FUNC_ADPT_FMT" none protected packet\n", FUNC_ADPT_ARG(adapter));
+			#endif
+			goto fail;
+		}
+#endif /* CONFIG_IEEE80211W */
+		goto exit;
+	}
+
+	/* cases to decrypt mgmt frame */
+	pattrib->bdecrypted = 0;
+	pattrib->encrypt = _AES_;
+	pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	/* set iv and icv length */
+	SET_ICE_IV_LEN(pattrib->iv_len, pattrib->icv_len, pattrib->encrypt);
+	_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
+
+	/* actual management data frame body */
+	data_len = pattrib->pkt_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
+	mgmt_DATA = rtw_zmalloc(data_len);
+	if (mgmt_DATA == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT" mgmt allocate fail  !!!!!!!!!\n", FUNC_ADPT_ARG(adapter));
+		goto fail;
+	}
+
+#if DBG_VALIDATE_MGMT_DEC
+	/* dump the packet content before decrypt */
+	{
+		int pp;
+
+		printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
+		for (pp = 0; pp < pattrib->pkt_len; pp++)
+		printk(" %02x ", ptr[pp]);
+		printk("\n");
+	}
+#endif
+
+	precv_frame = decryptor(adapter, precv_frame);
+	/* save actual management data frame body */
+	_rtw_memcpy(mgmt_DATA, ptr + pattrib->hdrlen + pattrib->iv_len, data_len);
+	/* overwrite the iv field */
+	_rtw_memcpy(ptr + pattrib->hdrlen, mgmt_DATA, data_len);
+	/* remove the iv and icv length */
+	pattrib->pkt_len = pattrib->pkt_len - pattrib->iv_len - pattrib->icv_len;
+	rtw_mfree(mgmt_DATA, data_len);
+
+#if DBG_VALIDATE_MGMT_DEC
+	/* print packet content after decryption */
 	{
-		mgt_dispatcher(padapter, precv_frame);
+		int pp;
+
+		printk("after decryption pattrib->pktlen = %d @@=>", pattrib->pkt_len);
+		for (pp = 0; pp < pattrib->pkt_len; pp++)
+		printk(" %02x ", ptr[pp]);
+		printk("\n");
+	}
+#endif
+
+	if (!precv_frame) {
+		#if DBG_VALIDATE_MGMT_PROTECT
+		RTW_INFO(FUNC_ADPT_FMT" mgmt descrypt fail  !!!!!!!!!\n", FUNC_ADPT_ARG(adapter));
+		#endif
+		goto fail;
+	}
+
+exit:
+	return _SUCCESS;
+
+fail:
+	return _FAIL;
+
+}
+#endif /* defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH) */
+
+union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame);
+
+sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)
+{
+	struct sta_info *psta = precv_frame->u.hdr.psta
+		= rtw_get_stainfo(&padapter->stapriv, get_addr2_ptr(precv_frame->u.hdr.rx_data));
+
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+	if (validate_mgmt_protect(padapter, precv_frame) == _FAIL) {
+		DBG_COUNTER(padapter->rx_logs.core_rx_pre_mgmt_err_80211w);
+		goto exit;
 	}
 #endif
 
 	precv_frame = recvframe_chk_defrag(padapter, precv_frame);
-	if (precv_frame == NULL) {
-		RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,("%s: fragment packet\n",__FUNCTION__));
+	if (precv_frame == NULL)
 		return _SUCCESS;
-	}
 
-	{
-		//for rx pkt statistics
-		struct sta_info *psta = rtw_get_stainfo(&padapter->stapriv, GetAddr2Ptr(precv_frame->u.hdr.rx_data));
-		if (psta) {
-			psta->sta_stats.rx_mgnt_pkts++;
-			if (GetFrameSubType(precv_frame->u.hdr.rx_data) == WIFI_BEACON)
-				psta->sta_stats.rx_beacon_pkts++;
-			else if (GetFrameSubType(precv_frame->u.hdr.rx_data) == WIFI_PROBEREQ)
-				psta->sta_stats.rx_probereq_pkts++;
-			else if (GetFrameSubType(precv_frame->u.hdr.rx_data) == WIFI_PROBERSP) {
-				if (_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(precv_frame->u.hdr.rx_data), ETH_ALEN) == _TRUE)
-					psta->sta_stats.rx_probersp_pkts++;
-				else if (is_broadcast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data))
-					|| is_multicast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data)))
-					psta->sta_stats.rx_probersp_bm_pkts++;
-				else 
-					psta->sta_stats.rx_probersp_uo_pkts++;
-			}
+	/* for rx pkt statistics */
+	if (psta) {
+		psta->sta_stats.last_rx_time = rtw_get_current_time();
+		psta->sta_stats.rx_mgnt_pkts++;
+		if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_BEACON)
+			psta->sta_stats.rx_beacon_pkts++;
+		else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBEREQ)
+			psta->sta_stats.rx_probereq_pkts++;
+		else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBERSP) {
+			if (_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(precv_frame->u.hdr.rx_data), ETH_ALEN) == _TRUE)
+				psta->sta_stats.rx_probersp_pkts++;
+			else if (is_broadcast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data))
+				|| is_multicast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data)))
+				psta->sta_stats.rx_probersp_bm_pkts++;
+			else
+				psta->sta_stats.rx_probersp_uo_pkts++;
 		}
 	}
 
 #ifdef CONFIG_INTEL_PROXIM
-	if(padapter->proximity.proxim_on==_TRUE)
-	{
-		struct rx_pkt_attrib * pattrib=&precv_frame->u.hdr.attrib;
-		 struct recv_stat* prxstat=( struct recv_stat * )  precv_frame->u.hdr.rx_head ;
-		 u8 * pda,*psa,*pbssid,*ptr;
-		 ptr=precv_frame->u.hdr.rx_data; 
+	if (padapter->proximity.proxim_on == _TRUE) {
+		struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+		struct recv_stat *prxstat = (struct recv_stat *)  precv_frame->u.hdr.rx_head ;
+		u8 *pda, *psa, *pbssid, *ptr;
+		ptr = precv_frame->u.hdr.rx_data;
 		pda = get_da(ptr);
 		psa = get_sa(ptr);
 		pbssid = get_hdr_bssid(ptr);
@@ -1905,8 +1985,7 @@ sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)
 
 		_rtw_memcpy(pattrib->bssid, pbssid, ETH_ALEN);
 
-	switch(pattrib->to_fr_ds)
-	{
+		switch (pattrib->to_fr_ds) {
 		case 0:
 			_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
 			_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
@@ -1924,346 +2003,229 @@ sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)
 
 		case 3:
 			_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
-			_rtw_memcpy(pattrib->ta, GetAddr2Ptr(ptr), ETH_ALEN);
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" case 3\n"));
+			_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
 			break;
 
 		default:
 			break;
 
-		}	
-			pattrib->priority=0;
-			pattrib->hdrlen = pattrib->to_fr_ds==3 ? 30 : 24;
+		}
+		pattrib->priority = 0;
+		pattrib->hdrlen = pattrib->to_fr_ds == 3 ? 30 : 24;
 
-		 padapter->proximity.proxim_rx(padapter,precv_frame);
+		padapter->proximity.proxim_rx(padapter, precv_frame);
 	}
 #endif
 	mgt_dispatcher(padapter, precv_frame);
 
+exit:
 	return _SUCCESS;
 
 }
 
-sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame);
 sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)
 {
-	u8 bretry;
-	u8 *psa, *pda, *pbssid;
+	u8 bretry, a4_shift;
 	struct sta_info *psta = NULL;
 	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib	*pattrib = & precv_frame->u.hdr.attrib;
-	struct sta_priv 	*pstapriv = &adapter->stapriv;
-	struct security_priv	*psecuritypriv = &adapter->securitypriv;	
+	struct rx_pkt_attrib	*pattrib = &precv_frame->u.hdr.attrib;
+	struct sta_priv	*pstapriv = &adapter->stapriv;
+	struct security_priv	*psecuritypriv = &adapter->securitypriv;
 	sint ret = _SUCCESS;
 
-_func_enter_;
-
 	bretry = GetRetry(ptr);
-	pda = get_da(ptr);
-	psa = get_sa(ptr);
-	pbssid = get_hdr_bssid(ptr);
-
-	if(pbssid == NULL){
-		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s pbssid == NULL\n", __func__);
-		#endif
-		ret= _FAIL;
-		goto exit;
-	}
-
-	_rtw_memcpy(pattrib->dst, pda, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, psa, ETH_ALEN);
-
-	_rtw_memcpy(pattrib->bssid, pbssid, ETH_ALEN);
+	a4_shift = (pattrib->to_fr_ds == 3) ? ETH_ALEN : 0;
 
-	switch(pattrib->to_fr_ds)
-	{
-		case 0:
-			_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
-			_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
-			ret = sta2sta_data_frame(adapter, precv_frame, &psta);
-			break;
+	/* some address fields are different when using AMSDU */
+	if (pattrib->qos)
+		pattrib->amsdu = GetAMsdu(ptr + WLAN_HDR_A3_LEN + a4_shift);
+	else
+		pattrib->amsdu = 0;
 
-		case 1:
-			_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
-			_rtw_memcpy(pattrib->ta, pbssid, ETH_ALEN);
-			ret = ap2sta_data_frame(adapter, precv_frame, &psta);
-			break;
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		ret = rtw_mesh_rx_data_validate_hdr(adapter, precv_frame, &psta);
+		goto pre_validate_status_chk;
+	}
+#endif
 
-		case 2:
-			_rtw_memcpy(pattrib->ra, pbssid, ETH_ALEN);
-			_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
-			ret = sta2ap_data_frame(adapter, precv_frame, &psta);
-			break;
+	switch (pattrib->to_fr_ds) {
+	case 0:
+		_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
+		ret = sta2sta_data_frame(adapter, precv_frame, &psta);
+		break;
 
-		case 3:
-			_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
-			_rtw_memcpy(pattrib->ta, GetAddr2Ptr(ptr), ETH_ALEN);
-			ret =_FAIL;
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" case 3\n"));
-			break;
+	case 1:
+		_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->src, GetAddr3Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->bssid, get_addr2_ptr(ptr), ETH_ALEN);
+		ret = ap2sta_data_frame(adapter, precv_frame, &psta);
+		break;
 
-		default:
-			ret =_FAIL;
-			break;
+	case 2:
+		_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->dst, GetAddr3Ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
+		_rtw_memcpy(pattrib->bssid, GetAddr1Ptr(ptr), ETH_ALEN);
+		ret = sta2ap_data_frame(adapter, precv_frame, &psta);
+		break;
 
+	case 3:
+	default:
+		/* WDS is not supported */
+		ret = _FAIL;
+		break;
 	}
 
-	if(ret ==_FAIL){
+pre_validate_status_chk:
+	if (ret == _FAIL) {
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s case:%d, res:%d\n", __FUNCTION__, pattrib->to_fr_ds, ret);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" case:%d, res:%d, ra="MAC_FMT", ta="MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), pattrib->to_fr_ds, ret, MAC_ARG(GetAddr1Ptr(ptr)), MAC_ARG(get_addr2_ptr(ptr)));
 		#endif
 		goto exit;
-	} else if (ret == RTW_RX_HANDLED) {
+	} else if (ret == RTW_RX_HANDLED)
 		goto exit;
-	}
 
 
-	if(psta==NULL){
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" after to_fr_ds_chk; psta==NULL \n"));
+	if (psta == NULL) {
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s psta == NULL\n", __func__);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" psta == NULL, ra="MAC_FMT", ta="MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(GetAddr1Ptr(ptr)), MAC_ARG(get_addr2_ptr(ptr)));
 		#endif
-		ret= _FAIL;
+		ret = _FAIL;
 		goto exit;
 	}
-	
-	//psta->rssi = prxcmd->rssi;
-	//psta->signal_quality= prxcmd->sq;
+
 	precv_frame->u.hdr.psta = psta;
-		
 
-	pattrib->amsdu=0;
 	pattrib->ack_policy = 0;
-	//parsing QC field
-	if(pattrib->qos == 1)
-	{
-		pattrib->priority = GetPriority((ptr + 24));
-		pattrib->ack_policy = GetAckpolicy((ptr + 24));
-		pattrib->amsdu = GetAMsdu((ptr + 24));
-		pattrib->hdrlen = pattrib->to_fr_ds==3 ? 32 : 26;
 
-		if(pattrib->priority!=0 && pattrib->priority!=3)
-			adapter->recvpriv.bIsAnyNonBEPkts = _TRUE;
+	/* parsing QC field */
+	if (pattrib->qos == 1) {
+		pattrib->priority = GetPriority((ptr + WLAN_HDR_A3_LEN + a4_shift)); /* point to Qos field*/
+		pattrib->ack_policy = GetAckpolicy((ptr + WLAN_HDR_A3_LEN + a4_shift));
+		pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN + a4_shift;
+		if (pattrib->priority != 0 && pattrib->priority != 3)
+			adapter->recvpriv.is_any_non_be_pkts = _TRUE;
 		else
-			adapter->recvpriv.bIsAnyNonBEPkts = _FALSE;
-	}
-	else
-	{
-		pattrib->priority=0;
-		pattrib->hdrlen = pattrib->to_fr_ds==3 ? 30 : 24;
+			adapter->recvpriv.is_any_non_be_pkts = _FALSE;
+	} else {
+		pattrib->priority = 0;
+		pattrib->hdrlen = WLAN_HDR_A3_LEN + a4_shift;
 	}
 
 
-	if(pattrib->order)//HT-CTRL 11n
-	{
+	if (pattrib->order) /* HT-CTRL 11n */
 		pattrib->hdrlen += 4;
-	}
-
-	precv_frame->u.hdr.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"));
-		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s recv_decache return _FAIL\n", __func__);
-		#endif
-		ret= _FAIL;
-		goto exit;
+	/* decache, drop duplicate recv packets */
+	if (!IS_MCAST(pattrib->ra)) {
+		precv_frame->u.hdr.preorder_ctrl = &psta->recvreorder_ctrl[pattrib->priority];
+		if (recv_decache(precv_frame, psta->sta_recvpriv.rxcache.tid_rxseq) == _FAIL) {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_decache uc return _FAIL for sta="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
+			#endif
+			ret = _FAIL;
+			goto exit;
+		}
+		if (recv_ucast_pn_decache(precv_frame) == _FAIL) {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_ucast_pn_decache return _FAIL for sta="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
+			#endif
+			ret = _FAIL;
+			goto exit;
+		}
+	} else {
+		precv_frame->u.hdr.preorder_ctrl = NULL;
+		if (recv_decache(precv_frame, psta->sta_recvpriv.bmc_tid_rxseq) == _FAIL) {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_decache bmc return _FAIL for sta="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
+			#endif
+			ret = _FAIL;
+			goto exit;
+		}
+		if (recv_bcast_pn_decache(precv_frame) == _FAIL) {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_bcast_pn_decache return _FAIL for sta="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
+			#endif
+			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_,("\n ^^^^^^^^^^^IS_MCAST(pattrib->ra(0x%02x))=%d^^^^^^^^^^^^^^^6\n", pattrib->ra[0],IS_MCAST(pattrib->ra)));
-
+	if (pattrib->privacy) {
 #ifdef CONFIG_TDLS
-		if((psta->tdls_sta_state & TDLS_LINKED_STATE) && (psta->dot118021XPrivacy==_AES_))
-		{
-			pattrib->encrypt=psta->dot118021XPrivacy;
-		}
+		if ((psta->tdls_sta_state & TDLS_LINKED_STATE) && (psta->dot118021XPrivacy == _AES_))
+			pattrib->encrypt = psta->dot118021XPrivacy;
 		else
-#endif //CONFIG_TDLS
-		GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, IS_MCAST(pattrib->ra));
+#endif /* CONFIG_TDLS */
+			GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, IS_MCAST(pattrib->ra));
 
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("\n pattrib->encrypt=%d\n",pattrib->encrypt));
 
 		SET_ICE_IV_LEN(pattrib->iv_len, pattrib->icv_len, pattrib->encrypt);
-	}
-	else
-	{
+	} else {
 		pattrib->encrypt = 0;
 		pattrib->iv_len = pattrib->icv_len = 0;
 	}
 
-exit:
-
-_func_exit_;
+#ifdef CONFIG_RTW_MESH
+	if (!pattrib->amsdu
+		&& pattrib->mesh_ctrl_present
+		&& (!pattrib->encrypt || pattrib->bdecrypted))
+		ret = rtw_mesh_rx_validate_mctrl_non_amsdu(adapter, precv_frame);
+#endif
 
+exit:
 	return ret;
 }
 
-#ifdef CONFIG_IEEE80211W
-static sint validate_80211w_mgmt(_adapter *adapter, union recv_frame *precv_frame)
-{
-	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct rx_pkt_attrib *pattrib = & precv_frame->u.hdr.attrib;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct sta_info	*psta;
-	struct sta_priv		*pstapriv = &adapter->stapriv;
-	u8 type;
-	u8 subtype;
-			
-	type =  GetFrameType(ptr);
-	subtype = GetFrameSubType(ptr); //bit(7)~bit(2)
-			
-	if (adapter->securitypriv.binstallBIPkey == _TRUE)
-	{
-		//unicast management frame decrypt
-		if(pattrib->privacy && !(IS_MCAST(GetAddr1Ptr(ptr))) && 
-			(subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC || subtype == WIFI_ACTION))
-		{
-			u8 *ppp, *mgmt_DATA;
-			u32 data_len=0;
-			ppp = GetAddr2Ptr(ptr);
-			
-			pattrib->bdecrypted = 0;
-			pattrib->encrypt = _AES_;
-			pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-			//set iv and icv length
-			SET_ICE_IV_LEN(pattrib->iv_len, pattrib->icv_len, pattrib->encrypt);
-			_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
-			_rtw_memcpy(pattrib->ta, GetAddr2Ptr(ptr), ETH_ALEN);
-			//actual management data frame body
-			data_len = pattrib->pkt_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
-			mgmt_DATA = rtw_zmalloc(data_len);
-			if(mgmt_DATA == NULL)
-			{
-				DBG_871X("%s mgmt allocate fail  !!!!!!!!!\n", __FUNCTION__);
-				goto validate_80211w_fail;
-			}
-			/* //dump the packet content before decrypt
-			{
-				int pp;
-				printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
-				for(pp=0;pp< pattrib->pkt_len; pp++)
-					printk(" %02x ", ptr[pp]);
-				printk("\n");
-			}*/
-			
-			precv_frame = decryptor(adapter, precv_frame);
-			//save actual management data frame body
-			_rtw_memcpy(mgmt_DATA, ptr+pattrib->hdrlen+pattrib->iv_len, data_len);
-			//overwrite the iv field
-			_rtw_memcpy(ptr+pattrib->hdrlen, mgmt_DATA, data_len);
-			//remove the iv and icv length
-			pattrib->pkt_len = pattrib->pkt_len - pattrib->iv_len - pattrib->icv_len;
-			rtw_mfree(mgmt_DATA, data_len);
-			/* //print packet content after decryption
-			{
-				int pp;
-				printk("after decryption pattrib->pktlen = %d @@=>", pattrib->pkt_len);
-				for(pp=0;pp< pattrib->pkt_len; pp++)
-					printk(" %02x ", ptr[pp]);
-				printk("\n");
-			}*/
-			if(!precv_frame)
-			{
-				DBG_871X("%s mgmt descrypt fail  !!!!!!!!!\n", __FUNCTION__);
-				goto validate_80211w_fail;
-			}
-		}
-		else if(IS_MCAST(GetAddr1Ptr(ptr)) &&
-			(subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC))
-		{
-			sint BIP_ret = _SUCCESS;
-			//verify BIP MME IE of broadcast/multicast de-auth/disassoc packet
-			BIP_ret = rtw_BIP_verify(adapter, (u8 * )precv_frame);
-			if(BIP_ret == _FAIL)
-			{
-				//DBG_871X("802.11w BIP verify fail\n");
-				goto validate_80211w_fail;
-			}
-			else if(BIP_ret == RTW_RX_HANDLED)
-			{
-				DBG_871X("802.11w recv none protected packet\n");
-				//drop pkt, don't issue sa query request
-				/* issue_action_SA_Query(adapter, NULL, 0, 0, 0); */
-				goto validate_80211w_fail;
-			}
-		}//802.11w protect
-		else
-		{
-			psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(ptr));
-			
-			if (subtype == WIFI_ACTION && psta && psta->bpairwise_key_installed == _TRUE) {
-				//according 802.11-2012 standard, these five types are not robust types
-				if( ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_PUBLIC          &&
-					ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_HT              &&
-					ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_UNPROTECTED_WNM &&
-					ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_SELF_PROTECTED  &&
-					ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_P2P)
-				{
-					DBG_871X("action frame category=%d should robust\n", ptr[WLAN_HDR_A3_LEN]);
-					goto validate_80211w_fail;
-				}
-			}
-			else if(subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC)
-			{
-				unsigned short	reason;
-				reason = le16_to_cpu(*(unsigned short *)(ptr + WLAN_HDR_A3_LEN));
-				DBG_871X("802.11w recv none protected packet, reason=%d\n", reason);
-				if(reason == 6 || reason == 7)
-				{
-					//issue sa query request
-					issue_action_SA_Query(adapter, NULL, 0, 0, IEEE80211W_RIGHT_KEY);
-				}
-				goto validate_80211w_fail;
-			}
-		}
-	}
-	return _SUCCESS;
-			
-validate_80211w_fail:
-	return _FAIL;
-	
-}
-#endif //CONFIG_IEEE80211W
-
 static inline void dump_rx_packet(u8 *ptr)
 {
 	int i;
 
-	DBG_871X("############################# \n");
-	for(i=0; i<64;i=i+8)
-		DBG_871X("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(ptr+i),
-		*(ptr+i+1), *(ptr+i+2) ,*(ptr+i+3) ,*(ptr+i+4),*(ptr+i+5), *(ptr+i+6), *(ptr+i+7));
-	DBG_871X("############################# \n");
+	RTW_INFO("#############################\n");
+	for (i = 0; i < 64; i = i + 8)
+		RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(ptr + i),
+			*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
+	RTW_INFO("#############################\n");
 }
 
 sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame);
 sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame)
 {
-	//shall check frame subtype, to / from ds, da, bssid
+	/* shall check frame subtype, to / from ds, da, bssid */
 
-	//then call check if rx seq/frag. duplicated.
+	/* then call check if rx seq/frag. duplicated. */
 
 	u8 type;
 	u8 subtype;
 	sint retval = _SUCCESS;
 
-	struct rx_pkt_attrib *pattrib = & precv_frame->u.hdr.attrib;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct recv_priv  *precvpriv = &adapter->recvpriv;
 
 	u8 *ptr = precv_frame->u.hdr.rx_data;
-	u8  ver =(unsigned char) (*ptr)&0x3 ;
+	u8  ver = (unsigned char)(*ptr) & 0x3 ;
 #ifdef CONFIG_FIND_BEST_CHANNEL
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
 #endif
 
 #ifdef CONFIG_TDLS
 	struct tdls_info *ptdlsinfo = &adapter->tdlsinfo;
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 #ifdef CONFIG_WAPI_SUPPORT
 	PRT_WAPI_T	pWapiInfo = &adapter->wapiInfo;
 	struct recv_frame_hdr *phdr = &precv_frame->u.hdr;
@@ -2272,47 +2234,43 @@ sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame)
 	u8	external_len = 0;
 #endif
 
-_func_enter_;
 
 #ifdef CONFIG_FIND_BEST_CHANNEL
 	if (pmlmeext->sitesurvey_res.state == SCAN_PROCESS) {
-		int ch_set_idx = rtw_ch_set_search_ch(pmlmeext->channel_set, rtw_get_oper_ch(adapter));
+		int ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, rtw_get_oper_ch(adapter));
 		if (ch_set_idx >= 0)
-			pmlmeext->channel_set[ch_set_idx].rx_count++;
+			rfctl->channel_set[ch_set_idx].rx_count++;
 	}
 #endif
 
 #ifdef CONFIG_TDLS
-	if(ptdlsinfo->ch_sensing==1 && ptdlsinfo->cur_channel !=0){
-		ptdlsinfo->collect_pkt_num[ptdlsinfo->cur_channel-1]++;
-	}
-#endif //CONFIG_TDLS
+	if (ptdlsinfo->ch_sensing == 1 && ptdlsinfo->cur_channel != 0)
+		ptdlsinfo->collect_pkt_num[ptdlsinfo->cur_channel - 1]++;
+#endif /* CONFIG_TDLS */
 
 #ifdef RTK_DMP_PLATFORM
-	if ( 0 )
-	{
-		DBG_871X("++\n");
+	if (0) {
+		RTW_INFO("++\n");
 		{
 			int i;
-			for(i=0; i<64;i=i+8)
-				DBG_871X("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:", *(ptr+i),
-				*(ptr+i+1), *(ptr+i+2) ,*(ptr+i+3) ,*(ptr+i+4),*(ptr+i+5), *(ptr+i+6), *(ptr+i+7));
+			for (i = 0; i < 64; i = i + 8)
+				RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:", *(ptr + i),
+					*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
 
 		}
-		DBG_871X("--\n");
+		RTW_INFO("--\n");
 	}
-#endif //RTK_DMP_PLATFORM
+#endif /* RTK_DMP_PLATFORM */
 
-	//add version chk
-	if(ver!=0){
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("validate_recv_data_frame fail! (ver!=0)\n"));
-		retval= _FAIL;
+	/* add version chk */
+	if (ver != 0) {
+		retval = _FAIL;
 		DBG_COUNTER(adapter->rx_logs.core_rx_pre_ver_err);
 		goto exit;
 	}
 
 	type =  GetFrameType(ptr);
-	subtype = GetFrameSubType(ptr); //bit(7)~bit(2)
+	subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
 
 	pattrib->to_fr_ds = get_tofr_ds(ptr);
 
@@ -2325,240 +2283,173 @@ _func_enter_;
 	pattrib->privacy = GetPrivacy(ptr);
 	pattrib->order = GetOrder(ptr);
 #ifdef CONFIG_WAPI_SUPPORT
-	sc = (pattrib->seq_num<<4) | pattrib->frag_num;
+	sc = (pattrib->seq_num << 4) | pattrib->frag_num;
 #endif
 
-#if 1 //Dump rx packets
-{
-	u8 bDumpRxPkt = 0;
-
-	rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_RXPKT, &(bDumpRxPkt));
-	if (bDumpRxPkt == 1) //dump all rx packets
-		dump_rx_packet(ptr);
-	else if ((bDumpRxPkt == 2) && (type == WIFI_MGT_TYPE))
-		dump_rx_packet(ptr);
-	else if ((bDumpRxPkt == 3) && (type == WIFI_DATA_TYPE))
-		dump_rx_packet(ptr);
-}
-#endif
-	switch (type)
+#if 1 /* Dump rx packets */
 	{
-		case WIFI_MGT_TYPE: //mgnt
-			DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt);
-#ifdef CONFIG_IEEE80211W
-			if(validate_80211w_mgmt(adapter, precv_frame) == _FAIL)
-			{
-				retval = _FAIL;
-				DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt_err_80211w);
-				break;
-			}
-#endif //CONFIG_IEEE80211W
-			
-			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"));
-				DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt_err);
-			}
-			retval = _FAIL; // only data frame return _SUCCESS
-			break;
-		case WIFI_CTRL_TYPE: //ctrl
-			DBG_COUNTER(adapter->rx_logs.core_rx_pre_ctrl);
-			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"));
-				DBG_COUNTER(adapter->rx_logs.core_rx_pre_ctrl_err);
-			}
-			retval = _FAIL; // only data frame return _SUCCESS
-			break;
-		case WIFI_DATA_TYPE: //data
-			DBG_COUNTER(adapter->rx_logs.core_rx_pre_data);
+		u8 bDumpRxPkt = 0;
+
+		rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_RXPKT, &(bDumpRxPkt));
+		if (bDumpRxPkt == 1) /* dump all rx packets */
+			dump_rx_packet(ptr);
+		else if ((bDumpRxPkt == 2) && (type == WIFI_MGT_TYPE))
+			dump_rx_packet(ptr);
+		else if ((bDumpRxPkt == 3) && (type == WIFI_DATA_TYPE))
+			dump_rx_packet(ptr);
+	}
+#endif
+	switch (type) {
+	case WIFI_MGT_TYPE: /* mgnt */
+		DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt);
+		retval = validate_recv_mgnt_frame(adapter, precv_frame);
+		if (retval == _FAIL) {
+			DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt_err);
+		}
+		retval = _FAIL; /* only data frame return _SUCCESS */
+		break;
+	case WIFI_CTRL_TYPE: /* ctrl */
+		DBG_COUNTER(adapter->rx_logs.core_rx_pre_ctrl);
+		retval = validate_recv_ctrl_frame(adapter, precv_frame);
+		if (retval == _FAIL) {
+			DBG_COUNTER(adapter->rx_logs.core_rx_pre_ctrl_err);
+		}
+		retval = _FAIL; /* only data frame return _SUCCESS */
+		break;
+	case WIFI_DATA_TYPE: /* data */
+		DBG_COUNTER(adapter->rx_logs.core_rx_pre_data);
 #ifdef CONFIG_WAPI_SUPPORT
-			if(pattrib->qos)
-				external_len = 2;
-			else
-				external_len= 0;
-			
-			wai_pkt = rtw_wapi_is_wai_packet(adapter,ptr);
+		if (pattrib->qos)
+			external_len = 2;
+		else
+			external_len = 0;
 
-			phdr->bIsWaiPacket = wai_pkt;
+		wai_pkt = rtw_wapi_is_wai_packet(adapter, ptr);
 
-			if(wai_pkt !=0){
-				if(sc != adapter->wapiInfo.wapiSeqnumAndFragNum)
-				{
-					adapter->wapiInfo.wapiSeqnumAndFragNum = sc;
-				}
-				else
-				{
-					retval = _FAIL;
-					DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_wapi_seq_err);
-					break;
-				}
+		phdr->bIsWaiPacket = wai_pkt;
+
+		if (wai_pkt != 0) {
+			if (sc != adapter->wapiInfo.wapiSeqnumAndFragNum)
+				adapter->wapiInfo.wapiSeqnumAndFragNum = sc;
+			else {
+				retval = _FAIL;
+				DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_wapi_seq_err);
+				break;
 			}
-			else{
+		} else {
 
-					if(rtw_wapi_drop_for_key_absent(adapter,GetAddr2Ptr(ptr))){
-						retval=_FAIL;
-						WAPI_TRACE(WAPI_RX,"drop for key absent for rx \n");
-						DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_wapi_key_err);
-						break;
-					}
+			if (rtw_wapi_drop_for_key_absent(adapter, get_addr2_ptr(ptr))) {
+				retval = _FAIL;
+				WAPI_TRACE(WAPI_RX, "drop for key absent for rx\n");
+				DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_wapi_key_err);
+				break;
 			}
+		}
 
 #endif
 
-			pattrib->qos = (subtype & BIT(7))? 1:0;
-			retval = validate_recv_data_frame(adapter, precv_frame);
-			if (retval == _FAIL)
-			{
-				struct recv_priv *precvpriv = &adapter->recvpriv;
-				//RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("validate_recv_data_frame fail\n"));
-				precvpriv->rx_drop++;
-				DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_err);
-			}
-			else if (retval == _SUCCESS)
-			{
-#ifdef DBG_RX_DUMP_EAP
+		pattrib->qos = (subtype & BIT(7)) ? 1 : 0;
+		retval = validate_recv_data_frame(adapter, precv_frame);
+		if (retval == _FAIL) {
+			precvpriv->dbg_rx_drop_count++;
+			DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_err);
+		} else if (retval == _SUCCESS) {
+			#ifdef DBG_RX_DUMP_EAP
+			if (!pattrib->encrypt || pattrib->bdecrypted) {
 				u8 bDumpRxPkt;
 				u16 eth_type;
 
-				// dump eapol
+				/* dump eapol */
 				rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_RXPKT, &(bDumpRxPkt));
-				// get ether_type
-				_rtw_memcpy(&eth_type, ptr + pattrib->hdrlen + pattrib->iv_len + LLC_HEADER_SIZE, 2);
+				/* get ether_type */
+				_rtw_memcpy(&eth_type, ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + LLC_HEADER_SIZE, 2);
 				eth_type = ntohs((unsigned short) eth_type);
 				if ((bDumpRxPkt == 4) && (eth_type == 0x888e))
 					dump_rx_packet(ptr);
-#endif
-			}
-			else
-			{
-				DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_handled);
 			}
-			break;
-		default:
-			DBG_COUNTER(adapter->rx_logs.core_rx_pre_unknown);
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("validate_recv_data_frame fail! type=0x%x\n", type));
-			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME validate_recv_data_frame fail! type=0x%x\n", type);
 			#endif
-			retval = _FAIL;
-			break;
+		} else
+			DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_handled);
+		break;
+	default:
+		DBG_COUNTER(adapter->rx_logs.core_rx_pre_unknown);
+		#ifdef DBG_RX_DROP_FRAME
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" fail! type=0x%x\n"
+			, FUNC_ADPT_ARG(adapter), type);
+		#endif
+		retval = _FAIL;
+		break;
 	}
 
 exit:
 
-_func_exit_;
 
 	return retval;
 }
 
 
-//remove the wlanhdr and add the eth_hdr
+/* remove the wlanhdr and add the eth_hdr */
 #if 1
-
-sint wlanhdr_to_ethhdr ( union recv_frame *precvframe);
-sint wlanhdr_to_ethhdr ( union recv_frame *precvframe)
+sint wlanhdr_to_ethhdr(union recv_frame *precvframe)
 {
 	sint	rmv_len;
 	u16	eth_type, len;
 	u8	bsnaphdr;
 	u8	*psnap_type;
 	struct ieee80211_snap_hdr	*psnap;
-	
-	sint ret=_SUCCESS;
-	_adapter			*adapter =precvframe->u.hdr.adapter;
+
+	sint ret = _SUCCESS;
+	_adapter			*adapter = precvframe->u.hdr.adapter;
 	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 
-	u8	*ptr = get_recvframe_data(precvframe) ; // point to frame_ctrl field
-	struct rx_pkt_attrib *pattrib = & precvframe->u.hdr.attrib;
+	u8	*ptr = get_recvframe_data(precvframe) ; /* point to frame_ctrl field */
+	struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
 
-_func_enter_;
 
-	if(pattrib->encrypt){
-		recvframe_pull_tail(precvframe, pattrib->icv_len);	
-	}
+	if (pattrib->encrypt)
+		recvframe_pull_tail(precvframe, pattrib->icv_len);
 
-	psnap=(struct ieee80211_snap_hdr	*)(ptr+pattrib->hdrlen + pattrib->iv_len);
-	psnap_type=ptr+pattrib->hdrlen + pattrib->iv_len+SNAP_SIZE;
+	psnap = (struct ieee80211_snap_hdr *)(ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib));
+	psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + SNAP_SIZE;
 	/* convert hdr + possible LLC headers into Ethernet header */
-	//eth_type = (psnap_type[0] << 8) | psnap_type[1];
-	if((_rtw_memcmp(psnap, rtw_rfc1042_header, SNAP_SIZE) &&
-		(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_IPX, 2) == _FALSE) && 
-		(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_AARP, 2)==_FALSE) )||
-		//eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) ||
-		 _rtw_memcmp(psnap, rtw_bridge_tunnel_header, SNAP_SIZE)){
+	/* eth_type = (psnap_type[0] << 8) | psnap_type[1]; */
+	if ((_rtw_memcmp(psnap, rtw_rfc1042_header, SNAP_SIZE) &&
+	     (_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_IPX, 2) == _FALSE) &&
+	     (_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_AARP, 2) == _FALSE)) ||
+	    /* eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) || */
+	    _rtw_memcmp(psnap, rtw_bridge_tunnel_header, SNAP_SIZE)) {
 		/* remove RFC1042 or Bridge-Tunnel encapsulation and replace EtherType */
 		bsnaphdr = _TRUE;
-	}
-	else {
+	} else {
 		/* Leave Ethernet header part of hdr and full payload */
 		bsnaphdr = _FALSE;
 	}
 
-	rmv_len = pattrib->hdrlen + pattrib->iv_len +(bsnaphdr?SNAP_SIZE:0);
+	rmv_len = pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + (bsnaphdr ? SNAP_SIZE : 0);
 	len = precvframe->u.hdr.len - rmv_len;
 
-	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("\n===pattrib->hdrlen: %x,  pattrib->iv_len:%x ===\n\n", pattrib->hdrlen,  pattrib->iv_len));
 
-	_rtw_memcpy(&eth_type, ptr+rmv_len, 2);
-	eth_type= ntohs((unsigned short )eth_type); //pattrib->ether_type
+	_rtw_memcpy(&eth_type, ptr + rmv_len, 2);
+	eth_type = ntohs((unsigned short)eth_type); /* pattrib->ether_type */
 	pattrib->eth_type = eth_type;
 
-#ifdef CONFIG_AUTO_AP_MODE
-	if (0x8899 == pattrib->eth_type)
-	{
-		struct sta_info *psta = precvframe->u.hdr.psta;
-		
-		DBG_871X("wlan rx: got eth_type=0x%x\n", pattrib->eth_type);					
-		
-		if (psta && psta->isrc && psta->pid>0)
-		{
-			u16 rx_pid;
-
-			rx_pid = *(u16*)(ptr+rmv_len+2);
-			
-			DBG_871X("wlan rx(pid=0x%x): sta("MAC_FMT") pid=0x%x\n", 
-				rx_pid, MAC_ARG(psta->hwaddr), psta->pid);
-
-			if(rx_pid == psta->pid)
-			{
-				int i;
-				u16 len = *(u16*)(ptr+rmv_len+4);
-				//u16 ctrl_type = *(u16*)(ptr+rmv_len+6);
-
-				//DBG_871X("RC: len=0x%x, ctrl_type=0x%x\n", len, ctrl_type); 
-				DBG_871X("RC: len=0x%x\n", len); 
-
-				for(i=0;i<len;i++)
-					DBG_871X("0x%x\n", *(ptr+rmv_len+6+i));
-					//DBG_871X("0x%x\n", *(ptr+rmv_len+8+i));
-
-				DBG_871X("RC-end\n"); 
-			}			
-		}		
-	}
-#endif //CONFIG_AUTO_AP_MODE
 
-	if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE))	   	
-	{
-		ptr += rmv_len ;	
+	if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)) {
+		ptr += rmv_len ;
 		*ptr = 0x87;
-		*(ptr+1) = 0x12;
+		*(ptr + 1) = 0x12;
 
 		eth_type = 0x8712;
-		// append rx status for mp test packets
-		ptr = recvframe_pull(precvframe, (rmv_len-sizeof(struct ethhdr)+2)-24);
+		/* append rx status for mp test packets */
+		ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + 2) - 24);
 		if (!ptr) {
 			ret = _FAIL;
 			goto exiting;
 		}
 		_rtw_memcpy(ptr, get_rxmem(precvframe), 24);
-		ptr+=24;
-	}
-	else {
-		ptr = recvframe_pull(precvframe, (rmv_len-sizeof(struct ethhdr)+ (bsnaphdr?2:0)));
+		ptr += 24;
+	} else {
+		ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + (bsnaphdr ? 2 : 0)));
 		if (!ptr) {
 			ret = _FAIL;
 			goto exiting;
@@ -2567,23 +2458,24 @@ _func_enter_;
 
 	if (ptr) {
 		_rtw_memcpy(ptr, pattrib->dst, ETH_ALEN);
-		_rtw_memcpy(ptr+ETH_ALEN, pattrib->src, ETH_ALEN);
+		_rtw_memcpy(ptr + ETH_ALEN, pattrib->src, ETH_ALEN);
 
-		if(!bsnaphdr) {
+		if (!bsnaphdr) {
 			len = htons(len);
-			_rtw_memcpy(ptr+12, &len, 2);
+			_rtw_memcpy(ptr + 12, &len, 2);
 		}
+
+		rtw_rframe_set_os_pkt(precvframe);
 	}
 
 exiting:
-_func_exit_;	
 	return ret;
 
 }
 
 #else
 
-sint wlanhdr_to_ethhdr ( union recv_frame *precvframe)
+sint wlanhdr_to_ethhdr(union recv_frame *precvframe)
 {
 	sint rmv_len;
 	u16 eth_type;
@@ -2591,123 +2483,104 @@ sint wlanhdr_to_ethhdr ( union recv_frame *precvframe)
 	u8	*psnap_type;
 	struct ieee80211_snap_hdr	*psnap;
 
-	sint ret=_SUCCESS;
-	_adapter	*adapter =precvframe->u.hdr.adapter;
+	sint ret = _SUCCESS;
+	_adapter	*adapter = precvframe->u.hdr.adapter;
 	struct	mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 
-	u8* ptr = get_recvframe_data(precvframe) ; // point to frame_ctrl field
-	struct rx_pkt_attrib *pattrib = & precvframe->u.hdr.attrib;
+	u8 *ptr = get_recvframe_data(precvframe) ; /* point to frame_ctrl field */
+	struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
 	struct _vlan *pvlan = NULL;
 
-_func_enter_;
 
-	psnap=(struct ieee80211_snap_hdr	*)(ptr+pattrib->hdrlen + pattrib->iv_len);
-	psnap_type=ptr+pattrib->hdrlen + pattrib->iv_len+SNAP_SIZE;
-	if (psnap->dsap==0xaa && psnap->ssap==0xaa && psnap->ctrl==0x03)
-	{
+	psnap = (struct ieee80211_snap_hdr *)(ptr + pattrib->hdrlen + pattrib->iv_len);
+	psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
+	if (psnap->dsap == 0xaa && psnap->ssap == 0xaa && psnap->ctrl == 0x03) {
 		if (_rtw_memcmp(psnap->oui, oui_rfc1042, WLAN_IEEE_OUI_LEN))
-			bsnaphdr=_TRUE;//wlan_pkt_format = WLAN_PKT_FORMAT_SNAP_RFC1042;	
+			bsnaphdr = _TRUE; /* wlan_pkt_format = WLAN_PKT_FORMAT_SNAP_RFC1042;	 */
 		else if (_rtw_memcmp(psnap->oui, SNAP_HDR_APPLETALK_DDP, WLAN_IEEE_OUI_LEN) &&
-			_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_DDP, 2) )
-			bsnaphdr=_TRUE;	//wlan_pkt_format = WLAN_PKT_FORMAT_APPLETALK;
-		else if (_rtw_memcmp( psnap->oui, oui_8021h, WLAN_IEEE_OUI_LEN))
-			bsnaphdr=_TRUE;	//wlan_pkt_format = WLAN_PKT_FORMAT_SNAP_TUNNEL;
+			_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_DDP, 2))
+			bsnaphdr = _TRUE;	/* wlan_pkt_format = WLAN_PKT_FORMAT_APPLETALK; */
+		else if (_rtw_memcmp(psnap->oui, oui_8021h, WLAN_IEEE_OUI_LEN))
+			bsnaphdr = _TRUE;	/* wlan_pkt_format = WLAN_PKT_FORMAT_SNAP_TUNNEL; */
 		else {
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("drop pkt due to invalid frame format!\n"));
-			ret= _FAIL;
+			ret = _FAIL;
 			goto exit;
 		}
 
 	} else
-		bsnaphdr=_FALSE;//wlan_pkt_format = WLAN_PKT_FORMAT_OTHERS;
+		bsnaphdr = _FALSE; /* wlan_pkt_format = WLAN_PKT_FORMAT_OTHERS; */
 
-	rmv_len = pattrib->hdrlen + pattrib->iv_len +(bsnaphdr?SNAP_SIZE:0);
-	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("===pattrib->hdrlen: %x,  pattrib->iv_len:%x ===\n", pattrib->hdrlen,  pattrib->iv_len));
+	rmv_len = pattrib->hdrlen + pattrib->iv_len + (bsnaphdr ? SNAP_SIZE : 0);
 
-	if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
-	{
+	if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) {
 		ptr += rmv_len ;
 		*ptr = 0x87;
-		*(ptr+1) = 0x12;
+		*(ptr + 1) = 0x12;
 
-		//back to original pointer
+		/* back to original pointer */
 		ptr -= rmv_len;
 	}
 
 	ptr += rmv_len ;
 
 	_rtw_memcpy(&eth_type, ptr, 2);
-	eth_type= ntohs((unsigned short )eth_type); //pattrib->ether_type
-	ptr +=2;
+	eth_type = ntohs((unsigned short)eth_type); /* pattrib->ether_type */
+	ptr += 2;
 
-	if(pattrib->encrypt){
+	if (pattrib->encrypt)
 		recvframe_pull_tail(precvframe, pattrib->icv_len);
-	}
 
-	if(eth_type == 0x8100) //vlan
-	{
+	if (eth_type == 0x8100) { /* vlan */
 		pvlan = (struct _vlan *) ptr;
 
-		//eth_type = get_vlan_encap_proto(pvlan);
-		//eth_type = pvlan->h_vlan_encapsulated_proto;//?
+		/* eth_type = get_vlan_encap_proto(pvlan); */
+		/* eth_type = pvlan->h_vlan_encapsulated_proto; */ /* ? */
 		rmv_len += 4;
-		ptr+=4;
+		ptr += 4;
 	}
 
-	if(eth_type==0x0800)//ip
-	{
-		//struct iphdr*  piphdr = (struct iphdr*) ptr;
-		//__u8 tos = (unsigned char)(pattrib->priority & 0xff);
+	if (eth_type == 0x0800) { /* ip */
+		/* struct iphdr*  piphdr = (struct iphdr*) ptr; */
+		/* __u8 tos = (unsigned char)(pattrib->priority & 0xff); */
 
-		//piphdr->tos = tos;
+		/* piphdr->tos = tos; */
 
-		//if (piphdr->protocol == 0x06)
-		//{
-		//	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("@@@===recv tcp len:%d @@@===\n", precvframe->u.hdr.len));
-		//}
-	}
-	else if(eth_type==0x8712)// append rx status for mp test packets
-	{
-		//ptr -= 16;
-		//_rtw_memcpy(ptr, get_rxmem(precvframe), 16);
-	}
-	else
-	{
+	} else if (eth_type == 0x8712) { /* append rx status for mp test packets */
+		/* ptr -= 16; */
+		/* _rtw_memcpy(ptr, get_rxmem(precvframe), 16); */
+	} else {
 #ifdef PLATFORM_OS_XP
 		NDIS_PACKET_8021Q_INFO VlanPriInfo;
 		UINT32 UserPriority = precvframe->u.hdr.attrib.priority;
-		UINT32 VlanID = (pvlan!=NULL ? get_vlan_id(pvlan) : 0 );
+		UINT32 VlanID = (pvlan != NULL ? get_vlan_id(pvlan) : 0);
 
-		VlanPriInfo.Value =          // Get current value.
-				NDIS_PER_PACKET_INFO_FROM_PACKET(precvframe->u.hdr.pkt, Ieee8021QInfo);
+		VlanPriInfo.Value =          /* Get current value. */
+			NDIS_PER_PACKET_INFO_FROM_PACKET(precvframe->u.hdr.pkt, Ieee8021QInfo);
 
 		VlanPriInfo.TagHeader.UserPriority = UserPriority;
 		VlanPriInfo.TagHeader.VlanId =  VlanID ;
 
-		VlanPriInfo.TagHeader.CanonicalFormatId = 0; // Should be zero.
-		VlanPriInfo.TagHeader.Reserved = 0; // Should be zero.
+		VlanPriInfo.TagHeader.CanonicalFormatId = 0; /* Should be zero. */
+		VlanPriInfo.TagHeader.Reserved = 0; /* Should be zero. */
 		NDIS_PER_PACKET_INFO_FROM_PACKET(precvframe->u.hdr.pkt, Ieee8021QInfo) = VlanPriInfo.Value;
 #endif
 	}
 
-	if(eth_type==0x8712)// append rx status for mp test packets
-	{
-		ptr = recvframe_pull(precvframe, (rmv_len-sizeof(struct ethhdr)+2)-24);
+	if (eth_type == 0x8712) { /* append rx status for mp test packets */
+		ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + 2) - 24);
 		_rtw_memcpy(ptr, get_rxmem(precvframe), 24);
-		ptr+=24;
-	}
-	else
-		ptr = recvframe_pull(precvframe, (rmv_len-sizeof(struct ethhdr)+2));
+		ptr += 24;
+	} else
+		ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + 2));
 
 	_rtw_memcpy(ptr, pattrib->dst, ETH_ALEN);
-	_rtw_memcpy(ptr+ETH_ALEN, pattrib->src, ETH_ALEN);
+	_rtw_memcpy(ptr + ETH_ALEN, pattrib->src, ETH_ALEN);
 
 	eth_type = htons((unsigned short)eth_type) ;
-	_rtw_memcpy(ptr+12, &eth_type, 2);
+	_rtw_memcpy(ptr + 12, &eth_type, 2);
 
 exit:
 
-_func_exit_;
 
 	return ret;
 }
@@ -2729,38 +2602,39 @@ static void recvframe_expand_pkt(
 
 	pfhdr = &prframe->u.hdr;
 
-	//	6 is for IP header 8 bytes alignment in QoS packet case.
+	/*	6 is for IP header 8 bytes alignment in QoS packet case. */
 	if (pfhdr->attrib.qos)
 		shift_sz = 6;
 	else
 		shift_sz = 0;
 
-	// for first fragment packet, need to allocate
-	// (1536 + RXDESC_SIZE + drvinfo_sz) to reassemble packet
-	//	8 is for skb->data 8 bytes alignment.
-//	alloc_sz = _RND(1536 + RXDESC_SIZE + pfhdr->attrib.drvinfosize + shift_sz + 8, 128);
-	alloc_sz = 1664; // round (1536 + 24 + 32 + shift_sz + 8) to 128 bytes alignment
+	/* for first fragment packet, need to allocate */
+	/* (1536 + RXDESC_SIZE + drvinfo_sz) to reassemble packet */
+	/*	8 is for skb->data 8 bytes alignment.
+	*	alloc_sz = _RND(1536 + RXDESC_SIZE + pfhdr->attrib.drvinfosize + shift_sz + 8, 128); */
+	alloc_sz = 1664; /* round (1536 + 24 + 32 + shift_sz + 8) to 128 bytes alignment */
 
-	//3 1. alloc new skb
-	// prepare extra space for 4 bytes alignment
+	/* 3 1. alloc new skb */
+	/* prepare extra space for 4 bytes alignment */
 	ppkt = rtw_skb_alloc(alloc_sz);
 
-	if (!ppkt) return; // no way to expand
+	if (!ppkt)
+		return; /* no way to expand */
 
-	//3 2. Prepare new skb to replace & release old skb
-	// force ppkt->data at 8-byte alignment address
+	/* 3 2. Prepare new skb to replace & release old skb */
+	/* force ppkt->data at 8-byte alignment address */
 	skb_reserve(ppkt, 8 - ((SIZE_PTR)ppkt->data & 7));
-	// force ip_hdr at 8-byte alignment address according to shift_sz
+	/* force ip_hdr at 8-byte alignment address according to shift_sz */
 	skb_reserve(ppkt, shift_sz);
 
-	// copy data to new pkt
+	/* copy data to new pkt */
 	ptr = skb_put(ppkt, pfhdr->len);
 	if (ptr)
 		_rtw_memcpy(ptr, pfhdr->rx_data, pfhdr->len);
 
 	rtw_skb_free(pfhdr->pkt);
 
-	// attach new pkt to recvframe
+	/* attach new pkt to recvframe */
 	pfhdr->pkt = ppkt;
 	pfhdr->rx_head = ppkt->head;
 	pfhdr->rx_data = ppkt->data;
@@ -2772,32 +2646,30 @@ static void recvframe_expand_pkt(
 #endif
 #endif
 
-//perform defrag
-union recv_frame * recvframe_defrag(_adapter *adapter,_queue *defrag_q);
-union recv_frame * recvframe_defrag(_adapter *adapter,_queue *defrag_q)
+/* perform defrag */
+union recv_frame *recvframe_defrag(_adapter *adapter, _queue *defrag_q);
+union recv_frame *recvframe_defrag(_adapter *adapter, _queue *defrag_q)
 {
-	_list	 *plist, *phead;
-	u8	*data,wlanhdr_offset;
+	_list	*plist, *phead;
+	u8	*data, wlanhdr_offset;
 	u8	curfragnum;
-	struct recv_frame_hdr *pfhdr,*pnfhdr;
-	union recv_frame* prframe, *pnextrframe;
+	struct recv_frame_hdr *pfhdr, *pnfhdr;
+	union recv_frame *prframe, *pnextrframe;
 	_queue	*pfree_recv_queue;
 
-_func_enter_;
 
-	curfragnum=0;
-	pfree_recv_queue=&adapter->recvpriv.free_recv_queue;
+	curfragnum = 0;
+	pfree_recv_queue = &adapter->recvpriv.free_recv_queue;
 
 	phead = get_list_head(defrag_q);
 	plist = get_next(phead);
 	prframe = LIST_CONTAINOR(plist, union recv_frame, u);
-	pfhdr=&prframe->u.hdr;
+	pfhdr = &prframe->u.hdr;
 	rtw_list_delete(&(prframe->u.list));
 
-	if(curfragnum!=pfhdr->attrib.frag_num)
-	{
-		//the first fragment number must be 0
-		//free the whole queue
+	if (curfragnum != pfhdr->attrib.frag_num) {
+		/* the first fragment number must be 0 */
+		/* free the whole queue */
 		rtw_free_recvframe(prframe, pfree_recv_queue);
 		rtw_free_recvframe_queue(defrag_q, pfree_recv_queue);
 
@@ -2812,24 +2684,22 @@ _func_enter_;
 
 	curfragnum++;
 
-	plist= get_list_head(defrag_q);
+	plist = get_list_head(defrag_q);
 
 	plist = get_next(plist);
 
-	data=get_recvframe_data(prframe);
+	data = get_recvframe_data(prframe);
 
-	while(rtw_end_of_queue_search(phead, plist) == _FALSE)
-	{
+	while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
 		pnextrframe = LIST_CONTAINOR(plist, union recv_frame , u);
-		pnfhdr=&pnextrframe->u.hdr;
+		pnfhdr = &pnextrframe->u.hdr;
 
 
-		//check the fragment sequence  (2nd ~n fragment frame)
+		/* 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
+		if (curfragnum != pnfhdr->attrib.frag_num) {
+			/* the fragment number must be increasing  (after decache) */
+			/* release the defrag_q & prframe */
 			rtw_free_recvframe(prframe, pfree_recv_queue);
 			rtw_free_recvframe_queue(defrag_q, pfree_recv_queue);
 			return NULL;
@@ -2837,38 +2707,36 @@ _func_enter_;
 
 		curfragnum++;
 
-		//copy the 2nd~n fragment frame's payload to the first fragment
-		//get the 2nd~last fragment frame's payload
+		/* 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;
 
 		recvframe_pull(pnextrframe, wlanhdr_offset);
 
-		//append  to first fragment frame's tail (if privacy frame, pull the ICV)
+		/* append  to first fragment frame's tail (if privacy frame, pull the ICV) */
 		recvframe_pull_tail(prframe, pfhdr->attrib.icv_len);
 
-		//memcpy
+		/* memcpy */
 		_rtw_memcpy(pfhdr->rx_tail, pnfhdr->rx_data, pnfhdr->len);
 
 		recvframe_put(prframe, pnfhdr->len);
 
-		pfhdr->attrib.icv_len=pnfhdr->attrib.icv_len;
+		pfhdr->attrib.icv_len = pnfhdr->attrib.icv_len;
 		plist = get_next(plist);
 
 	};
 
-	//free the defrag_q queue and return the prframe
+	/* free the defrag_q queue and return the prframe */
 	rtw_free_recvframe_queue(defrag_q, pfree_recv_queue);
 
-	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("Performance defrag!!!!!\n"));
 
-_func_exit_;
 
 	return prframe;
 }
 
-//check if need to defrag, if needed queue the frame to defrag_q
-union recv_frame* recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame)
+/* check if need to defrag, if needed queue the frame to defrag_q */
+union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame)
 {
 	u8	ismfrag;
 	u8	fragnum;
@@ -2878,9 +2746,8 @@ union recv_frame* recvframe_chk_defrag(PADAPTER padapter, union recv_frame *prec
 	struct sta_priv *pstapriv;
 	_list *phead;
 	union recv_frame *prtnframe = NULL;
-	_queue *pfree_recv_queue, *pdefrag_q;
+	_queue *pfree_recv_queue, *pdefrag_q = NULL;
 
-_func_enter_;
 
 	pstapriv = &padapter->stapriv;
 
@@ -2888,174 +2755,340 @@ _func_enter_;
 
 	pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
 
-	//need to define struct of wlan header frame ctrl
+	/* 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_stainfo(pstapriv, psta_addr);
-	if (psta == NULL)
-	{
+	if (psta == NULL) {
 		u8 type = GetFrameType(pfhdr->rx_data);
 		if (type != WIFI_DATA_TYPE) {
 			psta = rtw_get_bcmc_stainfo(padapter);
-			pdefrag_q = &psta->sta_recvpriv.defrag_q;
+			if (psta)
+				pdefrag_q = &psta->sta_recvpriv.defrag_q;
 		} else
 			pdefrag_q = NULL;
-	}
-	else
+	} else
 		pdefrag_q = &psta->sta_recvpriv.defrag_q;
 
-	if ((ismfrag==0) && (fragnum==0))
-	{
-		prtnframe = precv_frame;//isn't a fragment frame
+	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(_rtw_queue_empty(pdefrag_q) == _FALSE)
-				{
-					//free current defrag_q
+	if (ismfrag == 1) {
+		/* 0~(n-1) fragment frame */
+		/* enqueue to defraf_g */
+		if (pdefrag_q != NULL) {
+			if (fragnum == 0) {
+				/* the first fragment */
+				if (_rtw_queue_empty(pdefrag_q) == _FALSE) {
+					/* free current defrag_q */
 					rtw_free_recvframe_queue(pdefrag_q, pfree_recv_queue);
 				}
 			}
 
 
-			//Then enqueue the 0~(n-1) fragment into the defrag_q
+			/* Then enqueue the 0~(n-1) fragment into the defrag_q */
 
-			//_rtw_spinlock(&pdefrag_q->lock);
+			/* _rtw_spinlock(&pdefrag_q->lock); */
 			phead = get_list_head(pdefrag_q);
 			rtw_list_insert_tail(&pfhdr->list, phead);
-			//_rtw_spinunlock(&pdefrag_q->lock);
+			/* _rtw_spinunlock(&pdefrag_q->lock); */
 
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("Enqueuq: ismfrag = %d, fragnum= %d\n", ismfrag,fragnum));
 
-			prtnframe=NULL;
+			prtnframe = NULL;
 
-		}
-		else
-		{
-			//can't find this ta's defrag_queue, so free this recv_frame
+		} else {
+			/* can't find this ta's defrag_queue, so free this recv_frame */
 			rtw_free_recvframe(precv_frame, pfree_recv_queue);
-			prtnframe=NULL;
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("Free because pdefrag_q ==NULL: ismfrag = %d, fragnum= %d\n", ismfrag, fragnum));
+			prtnframe = NULL;
 		}
 
 	}
 
-	if((ismfrag==0)&&(fragnum!=0))
-	{
-		//the last fragment frame
-		//enqueue the last fragment
-		if(pdefrag_q != NULL)
-		{
-			//_rtw_spinlock(&pdefrag_q->lock);
+	if ((ismfrag == 0) && (fragnum != 0)) {
+		/* the last fragment frame */
+		/* enqueue the last fragment */
+		if (pdefrag_q != NULL) {
+			/* _rtw_spinlock(&pdefrag_q->lock); */
 			phead = get_list_head(pdefrag_q);
-			rtw_list_insert_tail(&pfhdr->list,phead);
-			//_rtw_spinunlock(&pdefrag_q->lock);
+			rtw_list_insert_tail(&pfhdr->list, phead);
+			/* _rtw_spinunlock(&pdefrag_q->lock); */
 
-			//call recvframe_defrag to defrag
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("defrag: ismfrag = %d, fragnum= %d\n", ismfrag, fragnum));
+			/* call recvframe_defrag to defrag */
 			precv_frame = recvframe_defrag(padapter, pdefrag_q);
-			prtnframe=precv_frame;
+			prtnframe = precv_frame;
 
-		}
-		else
-		{
-			//can't find this ta's defrag_queue, so free this recv_frame
+		} else {
+			/* can't find this ta's defrag_queue, so free this recv_frame */
 			rtw_free_recvframe(precv_frame, pfree_recv_queue);
-			prtnframe=NULL;
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("Free because pdefrag_q ==NULL: ismfrag = %d, fragnum= %d\n", ismfrag,fragnum));
+			prtnframe = NULL;
 		}
 
 	}
 
 
-	if((prtnframe!=NULL)&&(prtnframe->u.hdr.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_recvframe(prtnframe,pfree_recv_queue);
-			prtnframe=NULL;
+	if ((prtnframe != NULL) && (prtnframe->u.hdr.attrib.privacy)) {
+		/* after defrag we must check tkip mic code */
+		if (recvframe_chkmic(padapter,  prtnframe) == _FAIL) {
+			rtw_free_recvframe(prtnframe, pfree_recv_queue);
+			prtnframe = NULL;
 		}
 	}
 
-_func_exit_;
 
 	return prtnframe;
 
 }
 
+static int rtw_recv_indicatepkt_check(union recv_frame *rframe, u8 *ehdr_pos, u32 pkt_len)
+{
+	_adapter *adapter = rframe->u.hdr.adapter;
+	struct recv_priv *recvpriv = &adapter->recvpriv;
+	struct ethhdr *ehdr = (struct ethhdr *)ehdr_pos;
+	int ret = _FAIL;
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (rtw_wapi_check_for_drop(adapter, rframe, ehdr_pos)) {
+		#ifdef DBG_RX_DROP_FRAME
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" rtw_wapi_check_for_drop\n"
+			, FUNC_ADPT_ARG(adapter));
+		#endif
+		goto exit;
+	}
+#endif
+
+	if (rframe->u.hdr.psta)
+		rtw_st_ctl_rx(rframe->u.hdr.psta, ehdr_pos);
+
+	if (ntohs(ehdr->h_proto) == 0x888e)
+		RTW_PRINT("recv eapol packet\n");
+
+	if (recvpriv->sink_udpport > 0)
+		rtw_sink_rtp_seq_dbg(adapter, ehdr_pos);
+
+#ifdef DBG_UDP_PKT_LOSE_11AC
+	#define PAYLOAD_LEN_LOC_OF_IP_HDR 0x10 /*ethernet payload length location of ip header (DA + SA+eth_type+(version&hdr_len)) */
+
+	if (ntohs(ehdr->h_proto) == ETH_P_ARP) {
+		/* ARP Payload length will be 42bytes or 42+18(tailer)=60bytes*/
+		if (pkt_len != 42 && pkt_len != 60)
+			RTW_INFO("Error !!%s,ARP Payload length %u not correct\n" , __func__ , pkt_len);
+	} else if (ntohs(ehdr->h_proto) == ETH_P_IP) {
+		if (be16_to_cpu(*((u16 *)(ehdr_pos + PAYLOAD_LEN_LOC_OF_IP_HDR))) != (pkt_len) - ETH_HLEN) {
+			RTW_INFO("Error !!%s,Payload length not correct\n" , __func__);
+			RTW_INFO("%s, IP header describe Total length=%u\n" , __func__ , be16_to_cpu(*((u16 *)(ehdr_pos + PAYLOAD_LEN_LOC_OF_IP_HDR))));
+			RTW_INFO("%s, Pkt real length=%u\n" , __func__ , (pkt_len) - ETH_HLEN);
+		}
+	}
+#endif
+
+#ifdef CONFIG_AUTO_AP_MODE
+	if (ntohs(ehdr->h_proto) == 0x8899)
+		rtw_auto_ap_rx_msg_dump(adapter, rframe, ehdr_pos);
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+static void recv_free_fwd_resource(_adapter *adapter, struct xmit_frame *fwd_frame, _list *b2u_list)
+{
+	struct xmit_priv *xmitpriv = &adapter->xmitpriv;
+
+	if (fwd_frame)
+		rtw_free_xmitframe(xmitpriv, fwd_frame);
+
+#ifdef CONFIG_RTW_MESH
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (!rtw_is_list_empty(b2u_list)) {
+		struct xmit_frame *b2uframe;
+		_list *list;
+
+		list = get_next(b2u_list);
+		while (rtw_end_of_queue_search(b2u_list, list) == _FALSE) {
+			b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+			list = get_next(list);
+			rtw_list_delete(&b2uframe->list);
+			rtw_free_xmitframe(xmitpriv, b2uframe);
+		}
+	}
+#endif
+#endif /* CONFIG_RTW_MESH */
+}
+
+static void recv_fwd_pkt_hdl(_adapter *adapter, _pkt *pkt
+	, u8 act, struct xmit_frame *fwd_frame, _list *b2u_list)
+{
+	struct xmit_priv *xmitpriv = &adapter->xmitpriv;
+	_pkt *fwd_pkt = pkt;
+
+	if (act & RTW_RX_MSDU_ACT_INDICATE) {
+		fwd_pkt = rtw_os_pkt_copy(pkt);
+		if (!fwd_pkt) {
+			#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME %s rtw_os_pkt_copy fail\n", __func__);
+			#endif
+			recv_free_fwd_resource(adapter, fwd_frame, b2u_list);
+			goto exit;
+		}
+	}
+
+#ifdef CONFIG_RTW_MESH
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (!rtw_is_list_empty(b2u_list)) {
+		_list *list = get_next(b2u_list);
+		struct xmit_frame *b2uframe;
+
+		while (rtw_end_of_queue_search(b2u_list, list) == _FALSE) {
+			b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+			list = get_next(list);
+			rtw_list_delete(&b2uframe->list);
+
+			if (!fwd_frame && rtw_is_list_empty(b2u_list)) /* the last fwd_pkt */
+				b2uframe->pkt = fwd_pkt;
+			else
+				b2uframe->pkt = rtw_os_pkt_copy(fwd_pkt);
+			if (!b2uframe->pkt) {
+				rtw_free_xmitframe(xmitpriv, b2uframe);
+				continue;
+			}
+
+			rtw_xmit_posthandle(adapter, b2uframe, b2uframe->pkt);
+		}
+	}
+#endif
+#endif /* CONFIG_RTW_MESH */
+
+	if (fwd_frame) {
+		fwd_frame->pkt = fwd_pkt;
+		if (rtw_xmit_posthandle(adapter, fwd_frame, fwd_pkt) < 0) {
+			#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit_posthandle fail\n", __func__);
+			#endif
+			xmitpriv->tx_drop++;
+		}
+	}
+
+exit:
+	return;
+}
+
 int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)
 {
+	struct rx_pkt_attrib *rattrib = &prframe->u.hdr.attrib;
 	int	a_len, padding_len;
-	u16	nSubframe_Length;	
+	u16	nSubframe_Length;
 	u8	nr_subframes, i;
 	u8	*pdata;
-	_pkt *sub_pkt,*subframes[MAX_SUBFRAME_COUNT];
+	_pkt *sub_pkt, *subframes[MAX_SUBFRAME_COUNT];
 	struct recv_priv *precvpriv = &padapter->recvpriv;
 	_queue *pfree_recv_queue = &(precvpriv->free_recv_queue);
+	const u8 *da, *sa;
+	int act;
+	struct xmit_frame *fwd_frame;
+	_list b2u_list;
+	u8 mctrl_len = 0;
 	int	ret = _SUCCESS;
 
 	nr_subframes = 0;
 
-	recvframe_pull(prframe, prframe->u.hdr.attrib.hdrlen);
-	
-	if(prframe->u.hdr.attrib.iv_len >0)
-	{
-		recvframe_pull(prframe, prframe->u.hdr.attrib.iv_len);
-	}
+	recvframe_pull(prframe, rattrib->hdrlen);
 
-	a_len = prframe->u.hdr.len;
+	if (rattrib->iv_len > 0)
+		recvframe_pull(prframe, rattrib->iv_len);
 
+	a_len = prframe->u.hdr.len;
 	pdata = prframe->u.hdr.rx_data;
 
-	while(a_len > ETH_HLEN) {
-
+	while (a_len > ETH_HLEN) {
 		/* Offset 12 denote 2 mac address */
 		nSubframe_Length = RTW_GET_BE16(pdata + 12);
-
-		if( a_len < (ETHERNET_HEADER_SIZE + nSubframe_Length) ) {
-			DBG_871X("nRemain_Length is %d and nSubframe_Length is : %d\n",a_len,nSubframe_Length);
+		if (a_len < (ETHERNET_HEADER_SIZE + nSubframe_Length)) {
+			RTW_INFO("nRemain_Length is %d and nSubframe_Length is : %d\n", a_len, nSubframe_Length);
 			break;
 		}
 
-		sub_pkt = rtw_os_alloc_msdu_pkt(prframe, nSubframe_Length, pdata);
+		act = RTW_RX_MSDU_ACT_INDICATE;
+		fwd_frame = NULL;
+
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter)) {
+			u8 *mda = pdata, *msa = pdata + ETH_ALEN;
+			struct rtw_ieee80211s_hdr *mctrl = (struct rtw_ieee80211s_hdr *)(pdata + ETH_HLEN);
+			int v_ret;
+
+			v_ret = rtw_mesh_rx_data_validate_mctrl(padapter, prframe
+				, mctrl, mda, msa, &mctrl_len, &da, &sa);
+			if (v_ret != _SUCCESS)
+				goto move_to_next;
+
+			act = rtw_mesh_rx_msdu_act_check(prframe
+				, mda, msa, da, sa, mctrl, &fwd_frame, &b2u_list);
+		} else
+		#endif
+		{
+			da = pdata;
+			sa = pdata + ETH_ALEN;
+		}
+
+		if (!act)
+			goto move_to_next;
+
+		rtw_led_rx_control(padapter, da);
+
+		sub_pkt = rtw_os_alloc_msdu_pkt(prframe, da, sa
+			, pdata + ETH_HLEN + mctrl_len, nSubframe_Length - mctrl_len);
 		if (sub_pkt == NULL) {
-			DBG_871X("%s(): allocate sub packet fail !!!\n",__FUNCTION__);
+			if (act & RTW_RX_MSDU_ACT_INDICATE) {
+				#ifdef DBG_RX_DROP_FRAME
+				RTW_INFO("DBG_RX_DROP_FRAME %s rtw_os_alloc_msdu_pkt fail\n", __func__);
+				#endif
+			}
+			if (act & RTW_RX_MSDU_ACT_FORWARD) {
+				#ifdef DBG_TX_DROP_FRAME
+				RTW_INFO("DBG_TX_DROP_FRAME %s rtw_os_alloc_msdu_pkt fail\n", __func__);
+				#endif
+				recv_free_fwd_resource(padapter, fwd_frame, &b2u_list);
+			}
 			break;
 		}
 
+		#ifdef CONFIG_RTW_MESH
+		if (act & RTW_RX_MSDU_ACT_FORWARD) {
+			recv_fwd_pkt_hdl(padapter, sub_pkt, act, fwd_frame, &b2u_list);
+			if (!(act & RTW_RX_MSDU_ACT_INDICATE))
+				goto move_to_next;
+		}
+		#endif
+
+		if (rtw_recv_indicatepkt_check(prframe, rtw_os_pkt_data(sub_pkt), rtw_os_pkt_len(sub_pkt)) == _SUCCESS)
+			subframes[nr_subframes++] = sub_pkt;
+		else
+			rtw_os_pkt_free(sub_pkt);
+
+move_to_next:
 		/* move the data point to data content */
 		pdata += ETH_HLEN;
 		a_len -= ETH_HLEN;
 
-		subframes[nr_subframes++] = sub_pkt;
-
-		if(nr_subframes >= MAX_SUBFRAME_COUNT) {
-			DBG_871X("ParseSubframe(): Too many Subframes! Packets dropped!\n");
+		if (nr_subframes >= MAX_SUBFRAME_COUNT) {
+			RTW_WARN("ParseSubframe(): Too many Subframes! Packets dropped!\n");
 			break;
 		}
 
 		pdata += nSubframe_Length;
 		a_len -= nSubframe_Length;
-		if(a_len != 0) {
-			padding_len = 4 - ((nSubframe_Length + ETH_HLEN) & (4-1));
-			if(padding_len == 4) {
+		if (a_len != 0) {
+			padding_len = 4 - ((nSubframe_Length + ETH_HLEN) & (4 - 1));
+			if (padding_len == 4)
 				padding_len = 0;
-			}
 
-			if(a_len < padding_len) {
-				DBG_871X("ParseSubframe(): a_len < padding_len !\n");
+			if (a_len < padding_len) {
+				RTW_INFO("ParseSubframe(): a_len < padding_len !\n");
 				break;
 			}
 			pdata += padding_len;
@@ -3063,97 +3096,178 @@ int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)
 		}
 	}
 
-	for(i=0; i<nr_subframes; i++){
+	for (i = 0; i < nr_subframes; i++) {
 		sub_pkt = subframes[i];
 
 		/* Indicat the packets to upper layer */
-		if (sub_pkt) {
-			rtw_os_recv_indicate_pkt(padapter, sub_pkt, &prframe->u.hdr.attrib);
-		}
+		if (sub_pkt)
+			rtw_os_recv_indicate_pkt(padapter, sub_pkt, prframe);
 	}
 
 	prframe->u.hdr.len = 0;
-	rtw_free_recvframe(prframe, pfree_recv_queue);//free this recv_frame
-	
+	rtw_free_recvframe(prframe, pfree_recv_queue);/* free this recv_frame */
+
 	return ret;
 }
 
-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)
+static int recv_process_mpdu(_adapter *padapter, union recv_frame *prframe)
+{
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
+	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
+	int ret;
+
+	if (pattrib->amsdu) {
+		ret = amsdu_to_msdu(padapter, prframe);
+		if (ret != _SUCCESS) {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" amsdu_to_msdu fail\n"
+				, FUNC_ADPT_ARG(padapter));
+			#endif
+			rtw_free_recvframe(prframe, pfree_recv_queue);
+			goto exit;
+		}
+	} else {
+		int act = RTW_RX_MSDU_ACT_INDICATE;
+		struct xmit_frame *fwd_frame = NULL;
+		_list b2u_list;
+
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter) && pattrib->mesh_ctrl_present) {
+			act = rtw_mesh_rx_msdu_act_check(prframe
+				, pattrib->mda, pattrib->msa
+				, pattrib->dst, pattrib->src
+				, (struct rtw_ieee80211s_hdr *)(get_recvframe_data(prframe) + pattrib->hdrlen + pattrib->iv_len)
+				, &fwd_frame, &b2u_list);
+		}
+		#endif
+
+		if (!act) {
+			rtw_free_recvframe(prframe, pfree_recv_queue);
+			ret = _FAIL;
+			goto exit;
+		}
+
+		rtw_led_rx_control(padapter, pattrib->dst);
+
+		ret = wlanhdr_to_ethhdr(prframe);
+		if (ret != _SUCCESS) {
+			if (act & RTW_RX_MSDU_ACT_INDICATE) {
+				#ifdef DBG_RX_DROP_FRAME
+				RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" wlanhdr_to_ethhdr: drop pkt\n"
+					, FUNC_ADPT_ARG(padapter));
+				#endif
+			}
+			if (act & RTW_RX_MSDU_ACT_FORWARD) {
+				#ifdef DBG_TX_DROP_FRAME
+				RTW_INFO("DBG_TX_DROP_FRAME %s wlanhdr_to_ethhdr fail\n", __func__);
+				#endif
+				recv_free_fwd_resource(padapter, fwd_frame, &b2u_list);
+			}
+			rtw_free_recvframe(prframe, pfree_recv_queue);
+			goto exit;
+		}
+
+		#ifdef CONFIG_RTW_MESH
+		if (act & RTW_RX_MSDU_ACT_FORWARD) {
+			recv_fwd_pkt_hdl(padapter, prframe->u.hdr.pkt, act, fwd_frame, &b2u_list);
+			if (!(act & RTW_RX_MSDU_ACT_INDICATE)) {
+				prframe->u.hdr.pkt = NULL;
+				rtw_free_recvframe(prframe, pfree_recv_queue);
+				goto exit;
+			}
+		}
+		#endif
+
+		if (!RTW_CANNOT_RUN(padapter)) {
+			ret = rtw_recv_indicatepkt_check(prframe
+				, get_recvframe_data(prframe), get_recvframe_len(prframe));
+			if (ret != _SUCCESS) {
+				rtw_free_recvframe(prframe, pfree_recv_queue);
+				goto exit;
+			}
+
+			/* indicate this recv_frame */
+			ret = rtw_recv_indicatepkt(padapter, prframe);
+			if (ret != _SUCCESS) {
+				#ifdef DBG_RX_DROP_FRAME
+				RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" rtw_recv_indicatepkt fail!\n"
+					, FUNC_ADPT_ARG(padapter));
+				#endif
+				goto exit;
+			}
+		} else {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DS:%u SR:%u\n"
+				, FUNC_ADPT_ARG(padapter)
+				, rtw_is_drv_stopped(padapter)
+				, rtw_is_surprise_removed(padapter));
+			#endif
+			ret = _SUCCESS; /* don't count as packet drop */
+			rtw_free_recvframe(prframe, pfree_recv_queue);
+		}
+	}
+
+exit:
+	return ret;
+}
+
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
+static int check_indicate_seq(struct recv_reorder_ctrl *preorder_ctrl, u16 seq_num)
 {
 	PADAPTER padapter = preorder_ctrl->padapter;
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+	struct recv_priv  *precvpriv = &padapter->recvpriv;
 	u8	wsize = preorder_ctrl->wsize_b;
-	u16	wend = (preorder_ctrl->indicate_seq + wsize -1) & 0xFFF;//% 4096;
+	u16	wend = (preorder_ctrl->indicate_seq + wsize - 1) & 0xFFF; /* % 4096; */
 
-	// Rx Reorder initialize condition.
-	if (preorder_ctrl->indicate_seq == 0xFFFF)
-	{
+	/* Rx Reorder initialize condition. */
+	if (preorder_ctrl->indicate_seq == 0xFFFF) {
 		preorder_ctrl->indicate_seq = seq_num;
 		#ifdef DBG_RX_SEQ
-		DBG_871X("DBG_RX_SEQ %s:%d init IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-			preorder_ctrl->indicate_seq, seq_num);
+		RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_INIT indicate_seq:%d, seq_num:%d\n"
+			, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
 		#endif
-
-		//DbgPrint("check_indicate_seq, 1st->indicate_seq=%d\n", precvpriv->indicate_seq);
 	}
 
-	//DbgPrint("enter->check_indicate_seq(): IndicateSeq: %d, NewSeq: %d\n", precvpriv->indicate_seq, seq_num);
-
-	// Drop out the packet which SeqNum is smaller than WinStart
-	if( SN_LESS(seq_num, preorder_ctrl->indicate_seq) )
-	{
-		//RT_TRACE(COMP_RX_REORDER, DBG_LOUD, ("CheckRxTsIndicateSeq(): Packet Drop! IndicateSeq: %d, NewSeq: %d\n", pTS->RxIndicateSeq, NewSeqNum));
-		//DbgPrint("CheckRxTsIndicateSeq(): Packet Drop! IndicateSeq: %d, NewSeq: %d\n", precvpriv->indicate_seq, seq_num);
-
+	/* Drop out the packet which SeqNum is smaller than WinStart */
+	if (SN_LESS(seq_num, preorder_ctrl->indicate_seq)) {
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("%s IndicateSeq: %d > NewSeq: %d\n", __FUNCTION__, 
-			preorder_ctrl->indicate_seq, seq_num);
+		RTW_INFO(FUNC_ADPT_FMT" tid:%u indicate_seq:%d > seq_num:%d\n"
+			, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
 		#endif
-
-
 		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) )
-	{
+	/*
+	* 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;
-
 		#ifdef DBG_RX_SEQ
-		DBG_871X("DBG_RX_SEQ %s:%d SN_EQUAL IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-			preorder_ctrl->indicate_seq, seq_num);
+		RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_EQUAL indicate_seq:%d, seq_num:%d\n"
+			, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
 		#endif
-	}
-	else if(SN_LESS(wend, seq_num))
-	{
-		//RT_TRACE(COMP_RX_REORDER, DBG_LOUD, ("CheckRxTsIndicateSeq(): Window Shift! IndicateSeq: %d, NewSeq: %d\n", pTS->RxIndicateSeq, NewSeqNum));
-		//DbgPrint("CheckRxTsIndicateSeq(): Window Shift! IndicateSeq: %d, NewSeq: %d\n", precvpriv->indicate_seq, seq_num);
 
-		// boundary situation, when seq_num cross 0xFFF
-		if(seq_num >= (wsize - 1))
-			preorder_ctrl->indicate_seq = seq_num + 1 -wsize;
+	} 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;
-		pdbgpriv->dbg_rx_ampdu_window_shift_cnt++;
+
+		precvpriv->dbg_rx_ampdu_window_shift_cnt++;
 		#ifdef DBG_RX_SEQ
-		DBG_871X("DBG_RX_SEQ %s:%d SN_LESS(wend, seq_num) IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-			preorder_ctrl->indicate_seq, seq_num);
+		RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_LESS(wend, seq_num) indicate_seq:%d, seq_num:%d\n"
+			, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
 		#endif
 	}
 
-	//DbgPrint("exit->check_indicate_seq(): IndicateSeq: %d, NewSeq: %d\n", precvpriv->indicate_seq, seq_num);
-
 	return _TRUE;
 }
 
-int enqueue_reorder_recvframe(struct recv_reorder_ctrl *preorder_ctrl, union recv_frame *prframe);
-int enqueue_reorder_recvframe(struct recv_reorder_ctrl *preorder_ctrl, union recv_frame *prframe)
+static int enqueue_reorder_recvframe(struct recv_reorder_ctrl *preorder_ctrl, union recv_frame *prframe)
 {
 	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
 	_queue *ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
@@ -3161,145 +3275,123 @@ int enqueue_reorder_recvframe(struct recv_reorder_ctrl *preorder_ctrl, union rec
 	union recv_frame *pnextrframe;
 	struct rx_pkt_attrib *pnextattrib;
 
-	//DbgPrint("+enqueue_reorder_recvframe()\n");
+	/* DbgPrint("+enqueue_reorder_recvframe()\n"); */
 
-	//_enter_critical_ex(&ppending_recvframe_queue->lock, &irql);
-	//_rtw_spinlock_ex(&ppending_recvframe_queue->lock);
+	/* _enter_critical_ex(&ppending_recvframe_queue->lock, &irql); */
+	/* _rtw_spinlock_ex(&ppending_recvframe_queue->lock); */
 
 
 	phead = get_list_head(ppending_recvframe_queue);
 	plist = get_next(phead);
 
-	while(rtw_end_of_queue_search(phead, plist) == _FALSE)
-	{
+	while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
 		pnextrframe = LIST_CONTAINOR(plist, union recv_frame, u);
 		pnextattrib = &pnextrframe->u.hdr.attrib;
 
-		if(SN_LESS(pnextattrib->seq_num, pattrib->seq_num))
-		{
+		if (SN_LESS(pnextattrib->seq_num, pattrib->seq_num))
 			plist = get_next(plist);
-		}
-		else if( SN_EQUAL(pnextattrib->seq_num, pattrib->seq_num))
-		{
-			//Duplicate entry is found!! Do not insert current entry.
-			//RT_TRACE(COMP_RX_REORDER, DBG_TRACE, ("InsertRxReorderList(): Duplicate packet is dropped!! IndicateSeq: %d, NewSeq: %d\n", pTS->RxIndicateSeq, SeqNum));
+		else if (SN_EQUAL(pnextattrib->seq_num, pattrib->seq_num)) {
+			/* Duplicate entry is found!! Do not insert current entry. */
 
-			//_exit_critical_ex(&ppending_recvframe_queue->lock, &irql);
+			/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
 
 			return _FALSE;
-		}
-		else
-		{
+		} else
 			break;
-		}
 
-		//DbgPrint("enqueue_reorder_recvframe():while\n");
+		/* DbgPrint("enqueue_reorder_recvframe():while\n"); */
 
 	}
 
 
-	//_enter_critical_ex(&ppending_recvframe_queue->lock, &irql);
-	//_rtw_spinlock_ex(&ppending_recvframe_queue->lock);
+	/* _enter_critical_ex(&ppending_recvframe_queue->lock, &irql); */
+	/* _rtw_spinlock_ex(&ppending_recvframe_queue->lock); */
 
 	rtw_list_delete(&(prframe->u.hdr.list));
 
 	rtw_list_insert_tail(&(prframe->u.hdr.list), plist);
 
-	//_rtw_spinunlock_ex(&ppending_recvframe_queue->lock);
-	//_exit_critical_ex(&ppending_recvframe_queue->lock, &irql);
+	/* _rtw_spinunlock_ex(&ppending_recvframe_queue->lock); */
+	/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
 
 
-	//RT_TRACE(COMP_RX_REORDER, DBG_TRACE, ("InsertRxReorderList(): Pkt insert into buffer!! IndicateSeq: %d, NewSeq: %d\n", pTS->RxIndicateSeq, SeqNum));
 	return _TRUE;
 
 }
 
-void recv_indicatepkts_pkt_loss_cnt(struct debug_priv *pdbgpriv, u64 prev_seq, u64 current_seq);
-void recv_indicatepkts_pkt_loss_cnt(struct debug_priv *pdbgpriv, u64 prev_seq, u64 current_seq)
+static void recv_indicatepkts_pkt_loss_cnt(_adapter *padapter, u64 prev_seq, u64 current_seq)
 {
-	if(current_seq < prev_seq)
-	{
-		pdbgpriv->dbg_rx_ampdu_loss_count+= (4096 + current_seq - prev_seq);
+	struct recv_priv *precvpriv = &padapter->recvpriv;
 
-	}
-	else
-	{
-		pdbgpriv->dbg_rx_ampdu_loss_count+= (current_seq - prev_seq);
+	if (current_seq < prev_seq) {
+		precvpriv->dbg_rx_ampdu_loss_count += (4096 + current_seq - prev_seq);
+		precvpriv->rx_drop += (4096 + current_seq - prev_seq);
+	} else {
+		precvpriv->dbg_rx_ampdu_loss_count += (current_seq - prev_seq);
+		precvpriv->rx_drop += (current_seq - prev_seq);
 	}
 }
-int recv_indicatepkts_in_order(_adapter *padapter, struct recv_reorder_ctrl *preorder_ctrl, int bforced);
-int recv_indicatepkts_in_order(_adapter *padapter, struct recv_reorder_ctrl *preorder_ctrl, int bforced)
+
+static int recv_indicatepkts_in_order(_adapter *padapter, struct recv_reorder_ctrl *preorder_ctrl, int bforced)
 {
-	//_irqL irql;
-	//u8 bcancelled;
+	/* _irqL irql; */
 	_list	*phead, *plist;
 	union recv_frame *prframe;
 	struct rx_pkt_attrib *pattrib;
-	//u8 index = 0;
+	/* u8 index = 0; */
 	int bPktInBuf = _FALSE;
 	struct recv_priv *precvpriv = &padapter->recvpriv;
 	_queue *ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 
 	DBG_COUNTER(padapter->rx_logs.core_rx_post_indicate_in_oder);
 
-	//DbgPrint("+recv_indicatepkts_in_order\n");
+	/* DbgPrint("+recv_indicatepkts_in_order\n"); */
 
-	//_enter_critical_ex(&ppending_recvframe_queue->lock, &irql);
-	//_rtw_spinlock_ex(&ppending_recvframe_queue->lock);
+	/* _enter_critical_ex(&ppending_recvframe_queue->lock, &irql); */
+	/* _rtw_spinlock_ex(&ppending_recvframe_queue->lock); */
 
-	phead = 	get_list_head(ppending_recvframe_queue);
+	phead =	get_list_head(ppending_recvframe_queue);
 	plist = get_next(phead);
 
 #if 0
-	// Check if there is any other indication thread running.
-	if(pTS->RxIndicateState == RXTS_INDICATE_PROCESSING)
+	/* Check if there is any other indication thread running. */
+	if (pTS->RxIndicateState == RXTS_INDICATE_PROCESSING)
 		return;
 #endif
 
-	// Handling some condition for forced indicate case.
-	if(bforced==_TRUE)
-	{
-		pdbgpriv->dbg_rx_ampdu_forced_indicate_count++;
-		if(rtw_is_list_empty(phead))
-		{
-			// _exit_critical_ex(&ppending_recvframe_queue->lock, &irql);
-			//_rtw_spinunlock_ex(&ppending_recvframe_queue->lock);
+	/* Handling some condition for forced indicate case. */
+	if (bforced == _TRUE) {
+		precvpriv->dbg_rx_ampdu_forced_indicate_count++;
+		if (rtw_is_list_empty(phead)) {
+			/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
+			/* _rtw_spinunlock_ex(&ppending_recvframe_queue->lock); */
 			return _TRUE;
 		}
-	
+
 		prframe = LIST_CONTAINOR(plist, union recv_frame, u);
-		pattrib = &prframe->u.hdr.attrib;	
+		pattrib = &prframe->u.hdr.attrib;
 
 		#ifdef DBG_RX_SEQ
-		DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-			preorder_ctrl->indicate_seq, pattrib->seq_num);
+		RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u FORCE indicate_seq:%d, seq_num:%d\n"
+			, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, pattrib->seq_num);
 		#endif
-		recv_indicatepkts_pkt_loss_cnt(pdbgpriv,preorder_ctrl->indicate_seq,pattrib->seq_num);
-		preorder_ctrl->indicate_seq = pattrib->seq_num;		
-		
+		recv_indicatepkts_pkt_loss_cnt(padapter, preorder_ctrl->indicate_seq, pattrib->seq_num);
+		preorder_ctrl->indicate_seq = pattrib->seq_num;
 	}
 
-	// Prepare indication list and indication.
-	// Check if there is any packet need indicate.
-	while(!rtw_is_list_empty(phead))
-	{
-	
+	/* Prepare indication list and indication. */
+	/* Check if there is any packet need indicate. */
+	while (!rtw_is_list_empty(phead)) {
+
 		prframe = LIST_CONTAINOR(plist, union recv_frame, u);
 		pattrib = &prframe->u.hdr.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));
+		if (!SN_LESS(preorder_ctrl->indicate_seq, pattrib->seq_num)) {
 
 #if 0
-			// This protect buffer from overflow.
-			if(index >= REORDER_WIN_SIZE)
-			{
-				RT_ASSERT(FALSE, ("IndicateRxReorderList(): Buffer overflow!! \n"));
+			/* This protect buffer from overflow. */
+			if (index >= REORDER_WIN_SIZE) {
+				RT_ASSERT(FALSE, ("IndicateRxReorderList(): Buffer overflow!!\n"));
 				bPktInBuf = TRUE;
 				break;
 			}
@@ -3308,227 +3400,105 @@ int recv_indicatepkts_in_order(_adapter *padapter, struct recv_reorder_ctrl *pre
 			plist = get_next(plist);
 			rtw_list_delete(&(prframe->u.hdr.list));
 
-			if(SN_EQUAL(preorder_ctrl->indicate_seq, pattrib->seq_num))
-			{
+			if (SN_EQUAL(preorder_ctrl->indicate_seq, pattrib->seq_num)) {
 				preorder_ctrl->indicate_seq = (preorder_ctrl->indicate_seq + 1) & 0xFFF;
 				#ifdef DBG_RX_SEQ
-				DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-					preorder_ctrl->indicate_seq, pattrib->seq_num);
+				RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_EQUAL indicate_seq:%d, seq_num:%d\n"
+					, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, pattrib->seq_num);
 				#endif
 			}
 
 #if 0
 			index++;
-			if(index==1)
-			{
-				//Cancel previous pending timer.
-				//PlatformCancelTimer(Adapter, &pTS->RxPktPendingTimer);
-				if(bforced!=_TRUE)
-				{
-					//DBG_871X("_cancel_timer(&preorder_ctrl->reordering_ctrl_timer, &bcancelled);\n");
-					_cancel_timer(&preorder_ctrl->reordering_ctrl_timer, &bcancelled);
+			if (index == 1) {
+				/* Cancel previous pending timer. */
+				/* PlatformCancelTimer(Adapter, &pTS->RxPktPendingTimer); */
+				if (bforced != _TRUE) {
+					/* RTW_INFO("_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);\n"); */
+					_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
 				}
 			}
 #endif
 
-			//Set this as a lock to make sure that only one thread is indicating packet.
-			//pTS->RxIndicateState = RXTS_INDICATE_PROCESSING;
+			/* Set this as a lock to make sure that only one thread is indicating packet. */
+			/* pTS->RxIndicateState = RXTS_INDICATE_PROCESSING; */
 
-			// Indicate packets
-			//RT_ASSERT((index<=REORDER_WIN_SIZE), ("RxReorderIndicatePacket(): Rx Reorder buffer full!! \n"));
+			/* Indicate packets */
+			/* RT_ASSERT((index<=REORDER_WIN_SIZE), ("RxReorderIndicatePacket(): Rx Reorder buffer full!!\n")); */
 
 
-			//indicate this recv_frame
-			//DbgPrint("recv_indicatepkts_in_order, indicate_seq=%d, seq_num=%d\n", precvpriv->indicate_seq, pattrib->seq_num);
-			if(!pattrib->amsdu)
-			{
-				//DBG_871X("recv_indicatepkts_in_order, amsdu!=1, indicate_seq=%d, seq_num=%d\n", preorder_ctrl->indicate_seq, pattrib->seq_num);
+			/* indicate this recv_frame */
+			/* DbgPrint("recv_indicatepkts_in_order, indicate_seq=%d, seq_num=%d\n", precvpriv->indicate_seq, pattrib->seq_num); */
+			if (recv_process_mpdu(padapter, prframe) != _SUCCESS)
+				precvpriv->dbg_rx_drop_count++;
 
-				if (!RTW_CANNOT_RUN(padapter))
-					rtw_recv_indicatepkt(padapter, prframe);/*indicate this recv_frame*/
-
-			}
-			else if(pattrib->amsdu==1)
-			{
-				if(amsdu_to_msdu(padapter, prframe)!=_SUCCESS)
-				{
-					rtw_free_recvframe(prframe, &precvpriv->free_recv_queue);
-				}
-			}
-			else
-			{
-				//error condition;
-			}
-
-
-			//Update local variables.
+			/* Update local variables. */
 			bPktInBuf = _FALSE;
 
-		}
-		else
-		{
+		} else {
 			bPktInBuf = _TRUE;
 			break;
 		}
 
-		//DbgPrint("recv_indicatepkts_in_order():while\n");
+		/* DbgPrint("recv_indicatepkts_in_order():while\n"); */
 
 	}
 
-	//_rtw_spinunlock_ex(&ppending_recvframe_queue->lock);
-	//_exit_critical_ex(&ppending_recvframe_queue->lock, &irql);
+	/* _rtw_spinunlock_ex(&ppending_recvframe_queue->lock); */
+	/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
+
+#if 0
+	/* Release the indication lock and set to new indication step. */
+	if (bPktInBuf) {
+		/*  Set new pending timer. */
+		/* pTS->RxIndicateState = RXTS_INDICATE_REORDER; */
+		/* PlatformSetTimer(Adapter, &pTS->RxPktPendingTimer, pHTInfo->RxReorderPendingTime); */
 
-/*
-	//Release the indication lock and set to new indication step.
-	if(bPktInBuf)
-	{
-		// Set new pending timer.
-		//pTS->RxIndicateState = RXTS_INDICATE_REORDER;
-		//PlatformSetTimer(Adapter, &pTS->RxPktPendingTimer, pHTInfo->RxReorderPendingTime);
-		//DBG_871X("_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME)\n");
 		_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);
+	} else {
+		/* pTS->RxIndicateState = RXTS_INDICATE_IDLE; */
 	}
-	else
-	{
-		//pTS->RxIndicateState = RXTS_INDICATE_IDLE;
-	}
-*/
-	//_exit_critical_ex(&ppending_recvframe_queue->lock, &irql);
+#endif
+	/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
 
-	//return _TRUE;
+	/* return _TRUE; */
 	return bPktInBuf;
 
 }
 
-int recv_indicatepkt_reorder(_adapter *padapter, union recv_frame *prframe);
-int recv_indicatepkt_reorder(_adapter *padapter, union recv_frame *prframe)
+static int recv_indicatepkt_reorder(_adapter *padapter, union recv_frame *prframe)
 {
 	_irqL irql;
 	int retval = _SUCCESS;
 	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
 	struct recv_reorder_ctrl *preorder_ctrl = prframe->u.hdr.preorder_ctrl;
-	_queue *ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-
-	DBG_COUNTER(padapter->rx_logs.core_rx_post_indicate_reoder);
-
-	if(!pattrib->amsdu)
-	{
-		//s1.
-                retval = wlanhdr_to_ethhdr(prframe);
-                if (retval != _SUCCESS)
-                {
-                        RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("wlanhdr_to_ethhdr: drop pkt \n"));
-                        #ifdef DBG_RX_DROP_FRAME
-                        DBG_871X("DBG_RX_DROP_FRAME %s wlanhdr_to_ethhdr error!\n", __FUNCTION__);
-                        #endif
-                        return retval;
-                }
-
-		//if ((pattrib->qos!=1) /*|| pattrib->priority!=0 || IS_MCAST(pattrib->ra)*/
-		//	|| (pattrib->eth_type==0x0806) || (pattrib->ack_policy!=0))
-		if (pattrib->qos!=1)
-		{
-			if (!RTW_CANNOT_RUN(padapter)) {
-				RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_, ("@@@@  recv_indicatepkt_reorder -recv_func recv_indicatepkt\n" ));
-
-				rtw_recv_indicatepkt(padapter, prframe);
-				return _SUCCESS;
-
-			}
-			
-			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s pattrib->qos !=1\n", __FUNCTION__);
-			#endif
-			
-			return _FAIL;
-		
-		}
-
-		if (preorder_ctrl->enable == _FALSE)
-		{
-			//indicate this recv_frame			
-			preorder_ctrl->indicate_seq = pattrib->seq_num;
-			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq, pattrib->seq_num);
-			#endif
-			
-			rtw_recv_indicatepkt(padapter, prframe);		
-			
-			preorder_ctrl->indicate_seq = (preorder_ctrl->indicate_seq + 1)%4096;
-			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq, pattrib->seq_num);
-			#endif
-			
-			return _SUCCESS;	
-		}			
-
-#ifndef CONFIG_RECV_REORDERING_CTRL
-		//indicate this recv_frame
-		rtw_recv_indicatepkt(padapter, prframe);
-		return _SUCCESS;
-#endif
-
-	}
-	else if(pattrib->amsdu==1) //temp filter -> means didn't support A-MSDUs in a A-MPDU
-	{
-		if (preorder_ctrl->enable == _FALSE)
-		{
-			preorder_ctrl->indicate_seq = pattrib->seq_num;
-			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq, pattrib->seq_num);
-			#endif
-
-			retval = amsdu_to_msdu(padapter, prframe);
-
-			preorder_ctrl->indicate_seq = (preorder_ctrl->indicate_seq + 1)%4096;
-			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d, NewSeq: %d\n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq, pattrib->seq_num);
-			#endif
-
-			if(retval != _SUCCESS){
-				#ifdef DBG_RX_DROP_FRAME
-				DBG_871X("DBG_RX_DROP_FRAME %s amsdu_to_msdu fail\n", __FUNCTION__);
-				#endif
-			}
+	_queue *ppending_recvframe_queue = preorder_ctrl ? &preorder_ctrl->pending_recvframe_queue : NULL;
+	struct recv_priv  *precvpriv = &padapter->recvpriv;
 
-			return retval;
-		}
-	}
-	else
-	{
+	if (!pattrib->qos || !preorder_ctrl || preorder_ctrl->enable == _FALSE)
+		goto _success_exit;
 
-	}
+	DBG_COUNTER(padapter->rx_logs.core_rx_post_indicate_reoder);
 
 	_enter_critical_bh(&ppending_recvframe_queue->lock, &irql);
 
-	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))
-	{
-		pdbgpriv->dbg_rx_ampdu_drop_count++;
-		//pHTInfo->RxReorderDropCounter++;
-		//ReturnRFDList(Adapter, pRfd);
-		//RT_TRACE(COMP_RX_REORDER, DBG_TRACE, ("RxReorderIndicatePacket() ==> Packet Drop!!\n"));
-		//_exit_critical_ex(&ppending_recvframe_queue->lock, &irql);
-		//return _FAIL;
+	/* s2. check if winstart_b(indicate_seq) needs to been updated */
+	if (!check_indicate_seq(preorder_ctrl, pattrib->seq_num)) {
+		precvpriv->dbg_rx_ampdu_drop_count++;
+		/* pHTInfo->RxReorderDropCounter++; */
+		/* ReturnRFDList(Adapter, pRfd); */
+		/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
+		/* return _FAIL; */
 
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s check_indicate_seq fail\n", __FUNCTION__);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" check_indicate_seq fail\n"
+			, FUNC_ADPT_ARG(padapter));
 		#endif
-#if 0		
+#if 0
 		rtw_recv_indicatepkt(padapter, prframe);
 
 		_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
-		
+
 		goto _success_exit;
 #else
 		goto _err_exit;
@@ -3536,45 +3506,43 @@ int recv_indicatepkt_reorder(_adapter *padapter, union recv_frame *prframe)
 	}
 
 
-	//s3. Insert all packet into Reorder Queue to maintain its ordering.
-	if(!enqueue_reorder_recvframe(preorder_ctrl, prframe))
-	{
-		//DbgPrint("recv_indicatepkt_reorder, enqueue_reorder_recvframe fail!\n");
-		//_exit_critical_ex(&ppending_recvframe_queue->lock, &irql);
-		//return _FAIL;
+	/* s3. Insert all packet into Reorder Queue to maintain its ordering. */
+	if (!enqueue_reorder_recvframe(preorder_ctrl, prframe)) {
+		/* DbgPrint("recv_indicatepkt_reorder, enqueue_reorder_recvframe fail!\n"); */
+		/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
+		/* return _FAIL; */
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s enqueue_reorder_recvframe fail\n", __FUNCTION__);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" enqueue_reorder_recvframe fail\n"
+			, FUNC_ADPT_ARG(padapter));
 		#endif
 		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.
-	//
+	/* 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. */
+	/*  */
 
-	//recv_indicatepkts_in_order(padapter, preorder_ctrl, _TRUE);
-	if(recv_indicatepkts_in_order(padapter, preorder_ctrl, _FALSE)==_TRUE)
-	{
+	/* recv_indicatepkts_in_order(padapter, preorder_ctrl, _TRUE); */
+	if (recv_indicatepkts_in_order(padapter, preorder_ctrl, _FALSE) == _TRUE) {
 		if (!preorder_ctrl->bReorderWaiting) {
 			preorder_ctrl->bReorderWaiting = _TRUE;
-		_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);
+			_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);
 		}
 		_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
-	}
-	else
-	{
+	} else {
 		preorder_ctrl->bReorderWaiting = _FALSE;
 		_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
 		_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
 	}
 
+	return RTW_RX_HANDLED;
 
 _success_exit:
 
@@ -3582,7 +3550,7 @@ _success_exit:
 
 _err_exit:
 
-        _exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
+	_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
 
 	return _FAIL;
 }
@@ -3599,210 +3567,186 @@ void rtw_reordering_ctrl_timeout_handler(void *pcontext)
 	if (RTW_CANNOT_RUN(padapter))
 		return;
 
-	//DBG_871X("+rtw_reordering_ctrl_timeout_handler()=>\n");
+	/* RTW_INFO("+rtw_reordering_ctrl_timeout_handler()=>\n"); */
 
 	_enter_critical_bh(&ppending_recvframe_queue->lock, &irql);
 
-	if (preorder_ctrl) {
+	if (preorder_ctrl)
 		preorder_ctrl->bReorderWaiting = _FALSE;
-	}
 
-	if(recv_indicatepkts_in_order(padapter, preorder_ctrl, _TRUE)==_TRUE)
-	{
-		_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);		
-	}
+	if (recv_indicatepkts_in_order(padapter, preorder_ctrl, _TRUE) == _TRUE)
+		_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);
 
 	_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
 
 }
+#endif /* defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL) */
 
-int process_recv_indicatepkts(_adapter *padapter, union recv_frame *prframe);
-int process_recv_indicatepkts(_adapter *padapter, union recv_frame *prframe)
+static void recv_set_iseq_before_mpdu_process(union recv_frame *rframe, u16 seq_num, const char *caller)
 {
-	int retval = _SUCCESS;
-	//struct recv_priv *precvpriv = &padapter->recvpriv;
-	//struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-#ifdef CONFIG_TDLS
-	struct sta_info *psta = prframe->u.hdr.psta;
-#endif //CONFIG_TDLS
-
-#ifdef CONFIG_80211N_HT
-
-	struct ht_priv	*phtpriv = &pmlmepriv->htpriv;
-	
-	DBG_COUNTER(padapter->rx_logs.core_rx_post_indicate);
-
-#ifdef CONFIG_TDLS
-	if( (phtpriv->ht_option==_TRUE) ||
-		((psta->tdls_sta_state & TDLS_LINKED_STATE) && 
-		 (psta->htpriv.ht_option==_TRUE) &&
-		 (psta->htpriv.ampdu_enable==_TRUE))) //B/G/N Mode
-#else
-	if(phtpriv->ht_option==_TRUE)  //B/G/N Mode
-#endif //CONFIG_TDLS
-	{
-		//prframe->u.hdr.preorder_ctrl = &precvpriv->recvreorder_ctrl[pattrib->priority];
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
+	struct recv_reorder_ctrl *reorder_ctrl = rframe->u.hdr.preorder_ctrl;
 
-		if(recv_indicatepkt_reorder(padapter, prframe)!=_SUCCESS)// including perform A-MPDU Rx Ordering Buffer Control
-		{
-			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s recv_indicatepkt_reorder error!\n", __FUNCTION__);
-			#endif
-		
-			if (!RTW_CANNOT_RUN(padapter))	{
-				retval = _FAIL;
-				return retval;
-			}
-		}
+	if (reorder_ctrl) {
+		reorder_ctrl->indicate_seq = seq_num;
+		#ifdef DBG_RX_SEQ
+		RTW_INFO("DBG_RX_SEQ %s("ADPT_FMT")-B tid:%u indicate_seq:%d, seq_num:%d\n"
+			, caller, ADPT_ARG(reorder_ctrl->padapter)
+			, reorder_ctrl->tid, reorder_ctrl->indicate_seq, seq_num);
+		#endif
 	}
-	else //B/G mode
 #endif
-	{
-		retval=wlanhdr_to_ethhdr (prframe);
-		if(retval != _SUCCESS)
-		{
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("wlanhdr_to_ethhdr: drop pkt \n"));
-			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s wlanhdr_to_ethhdr error!\n", __FUNCTION__);
-			#endif
-			return retval;
-		}
-
-		if (!RTW_CANNOT_RUN(padapter)) {
-			//indicate this recv_frame
-			RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_, ("@@@@ process_recv_indicatepkts- recv_func recv_indicatepkt\n" ));
-			rtw_recv_indicatepkt(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(%s) OR bSurpriseRemoved(%s)"
-				, rtw_is_drv_stopped(padapter)?"True":"False"
-				, rtw_is_surprise_removed(padapter)?"True":"False"));
-			retval = _FAIL;
-			return retval;
-		}
-
-	}
+}
 
-	return retval;
+static void recv_set_iseq_after_mpdu_process(union recv_frame *rframe, u16 seq_num, const char *caller)
+{
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
+	struct recv_reorder_ctrl *reorder_ctrl = rframe->u.hdr.preorder_ctrl;
 
+	if (reorder_ctrl) {
+		reorder_ctrl->indicate_seq = (reorder_ctrl->indicate_seq + 1) % 4096;
+		#ifdef DBG_RX_SEQ
+		RTW_INFO("DBG_RX_SEQ %s("ADPT_FMT")-A tid:%u indicate_seq:%d, seq_num:%d\n"
+			, caller, ADPT_ARG(reorder_ctrl->padapter)
+			, reorder_ctrl->tid, reorder_ctrl->indicate_seq, seq_num);
+		#endif
+	}
+#endif
 }
 
 #ifdef CONFIG_MP_INCLUDED
 int validate_mp_recv_frame(_adapter *adapter, union recv_frame *precv_frame)
 {
 	int ret = _SUCCESS;
-	u8 *ptr = precv_frame->u.hdr.rx_data;	
-	u8 type,subtype;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	u8 type, subtype;
+	struct mp_priv *pmppriv = &adapter->mppriv;
+	struct mp_tx		*pmptx;
+	unsigned char	*sa , *da, *bs;
 
-	if(!adapter->mppriv.bmac_filter)	
-		return ret;
-#if 0	
-	if (1){
+	pmptx = &pmppriv->tx;
+
+#if 0
+	if (1) {
 		u8 bDumpRxPkt;
 		type =  GetFrameType(ptr);
-		subtype = GetFrameSubType(ptr); //bit(7)~bit(2)	
-		
+		subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2)	 */
+
 		rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_RXPKT, &(bDumpRxPkt));
-		if(bDumpRxPkt ==1){//dump all rx packets
+		if (bDumpRxPkt == 1) { /* dump all rx packets */
 			int i;
-			DBG_871X("############ type:0x%02x subtype:0x%02x ################# \n",type,subtype);
-			
-			for(i=0; i<64;i=i+8)
-				DBG_871X("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(ptr+i),
-				*(ptr+i+1), *(ptr+i+2) ,*(ptr+i+3) ,*(ptr+i+4),*(ptr+i+5), *(ptr+i+6), *(ptr+i+7));
-			DBG_871X("############################# \n");
+			RTW_INFO("############ type:0x%02x subtype:0x%02x #################\n", type, subtype);
+
+			for (i = 0; i < 64; i = i + 8)
+				RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(ptr + i),
+					*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
+			RTW_INFO("#############################\n");
 		}
 	}
-#endif		
+#endif
+	if (pmppriv->bloopback) {
+		if (_rtw_memcmp(ptr + 24, pmptx->buf + 24, precv_frame->u.hdr.len - 24) == _FALSE) {
+			RTW_INFO("Compare payload content Fail !!!\n");
+			ret = _FAIL;
+		}
+	}
+ 	if (pmppriv->bSetRxBssid == _TRUE) {
+
+		sa = get_addr2_ptr(ptr);
+		da = GetAddr1Ptr(ptr);
+		bs = GetAddr3Ptr(ptr);
+		type =	GetFrameType(ptr);
+		subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2)  */
+
+		if (_rtw_memcmp(bs, adapter->mppriv.network_macaddr, ETH_ALEN) == _FALSE)
+			ret = _FAIL;
+
+		RTW_DBG("############ type:0x%02x subtype:0x%02x #################\n", type, subtype);
+		RTW_DBG("A2 sa %02X:%02X:%02X:%02X:%02X:%02X \n", *(sa) , *(sa + 1), *(sa+ 2), *(sa + 3), *(sa + 4), *(sa + 5));
+		RTW_DBG("A1 da %02X:%02X:%02X:%02X:%02X:%02X \n", *(da) , *(da + 1), *(da+ 2), *(da + 3), *(da + 4), *(da + 5));
+		RTW_DBG("A3 bs %02X:%02X:%02X:%02X:%02X:%02X \n --------------------------\n", *(bs) , *(bs + 1), *(bs+ 2), *(bs + 3), *(bs + 4), *(bs + 5));
+	}
+
+	if (!adapter->mppriv.bmac_filter)
+		return ret;
 
-	if(_rtw_memcmp( GetAddr2Ptr(ptr), adapter->mppriv.mac_filter, ETH_ALEN) == _FALSE )
+	if (_rtw_memcmp(get_addr2_ptr(ptr), adapter->mppriv.mac_filter, ETH_ALEN) == _FALSE)
 		ret = _FAIL;
 
 	return ret;
 }
-#endif
 
-static sint MPwlanhdr_to_ethhdr ( union recv_frame *precvframe)
+static sint MPwlanhdr_to_ethhdr(union recv_frame *precvframe)
 {
 	sint	rmv_len;
 	u16 eth_type, len;
 	u8	bsnaphdr;
 	u8	*psnap_type;
-	u8 mcastheadermac[]={0x01,0x00,0x5e};
-	
+	u8 mcastheadermac[] = {0x01, 0x00, 0x5e};
+
 	struct ieee80211_snap_hdr	*psnap;
-	
-	sint ret=_SUCCESS;
-	_adapter			*adapter =precvframe->u.hdr.adapter;
+
+	sint ret = _SUCCESS;
+	_adapter			*adapter = precvframe->u.hdr.adapter;
 	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 
-	u8	*ptr = get_recvframe_data(precvframe) ; // point to frame_ctrl field
-	struct rx_pkt_attrib *pattrib = & precvframe->u.hdr.attrib;
+	u8	*ptr = get_recvframe_data(precvframe) ; /* point to frame_ctrl field */
+	struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
 
-_func_enter_;
 
-	if(pattrib->encrypt){
-		recvframe_pull_tail(precvframe, pattrib->icv_len);	
-	}
+	if (pattrib->encrypt)
+		recvframe_pull_tail(precvframe, pattrib->icv_len);
 
-	psnap=(struct ieee80211_snap_hdr	*)(ptr+pattrib->hdrlen + pattrib->iv_len);
-	psnap_type=ptr+pattrib->hdrlen + pattrib->iv_len+SNAP_SIZE;
+	psnap = (struct ieee80211_snap_hdr *)(ptr + pattrib->hdrlen + pattrib->iv_len);
+	psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
 	/* convert hdr + possible LLC headers into Ethernet header */
-	//eth_type = (psnap_type[0] << 8) | psnap_type[1];
-	if((_rtw_memcmp(psnap, rtw_rfc1042_header, SNAP_SIZE) &&
-		(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_IPX, 2) == _FALSE) && 
-		(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_AARP, 2)==_FALSE) )||
-		//eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) ||
-		 _rtw_memcmp(psnap, rtw_bridge_tunnel_header, SNAP_SIZE)){
+	/* eth_type = (psnap_type[0] << 8) | psnap_type[1]; */
+	if ((_rtw_memcmp(psnap, rtw_rfc1042_header, SNAP_SIZE) &&
+	     (_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_IPX, 2) == _FALSE) &&
+	     (_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_AARP, 2) == _FALSE)) ||
+	    /* eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) || */
+	    _rtw_memcmp(psnap, rtw_bridge_tunnel_header, SNAP_SIZE)) {
 		/* remove RFC1042 or Bridge-Tunnel encapsulation and replace EtherType */
 		bsnaphdr = _TRUE;
-	}
-	else {
+	} else {
 		/* Leave Ethernet header part of hdr and full payload */
 		bsnaphdr = _FALSE;
 	}
 
-	rmv_len = pattrib->hdrlen + pattrib->iv_len +(bsnaphdr?SNAP_SIZE:0);
+	rmv_len = pattrib->hdrlen + pattrib->iv_len + (bsnaphdr ? SNAP_SIZE : 0);
 	len = precvframe->u.hdr.len - rmv_len;
 
-	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("\n===pattrib->hdrlen: %x,  pattrib->iv_len:%x ===\n\n", pattrib->hdrlen,	pattrib->iv_len));
 
-	_rtw_memcpy(&eth_type, ptr+rmv_len, 2);
-	eth_type= ntohs((unsigned short )eth_type); //pattrib->ether_type
+	_rtw_memcpy(&eth_type, ptr + rmv_len, 2);
+	eth_type = ntohs((unsigned short)eth_type); /* pattrib->ether_type */
 	pattrib->eth_type = eth_type;
 
 	{
-		ptr = recvframe_pull(precvframe, (rmv_len-sizeof(struct ethhdr)+ (bsnaphdr?2:0)));
+		ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + (bsnaphdr ? 2 : 0)));
 	}
 
 	_rtw_memcpy(ptr, pattrib->dst, ETH_ALEN);
-	_rtw_memcpy(ptr+ETH_ALEN, pattrib->src, ETH_ALEN);
+	_rtw_memcpy(ptr + ETH_ALEN, pattrib->src, ETH_ALEN);
 
-	if(!bsnaphdr) {
+	if (!bsnaphdr) {
 		len = htons(len);
-		_rtw_memcpy(ptr+12, &len, 2);
+		_rtw_memcpy(ptr + 12, &len, 2);
 	}
-	
 
-		len = htons(pattrib->seq_num);
-		//DBG_871X("wlan seq = %d ,seq_num =%x\n",len,pattrib->seq_num);
-		_rtw_memcpy(ptr+12,&len, 2);
-	if(adapter->mppriv.bRTWSmbCfg==_TRUE)
-	{
-//		if(_rtw_memcmp(mcastheadermac, pattrib->dst, 3) == _TRUE)//SimpleConfig Dest.
-//			_rtw_memcpy(ptr+ETH_ALEN, pattrib->bssid, ETH_ALEN);
 
-		if(_rtw_memcmp(mcastheadermac, pattrib->bssid, 3) == _TRUE) //SimpleConfig Dest.
+	len = htons(pattrib->seq_num);
+	/* RTW_INFO("wlan seq = %d ,seq_num =%x\n",len,pattrib->seq_num); */
+	_rtw_memcpy(ptr + 12, &len, 2);
+	if (adapter->mppriv.bRTWSmbCfg == _TRUE) {
+		/* if(_rtw_memcmp(mcastheadermac, pattrib->dst, 3) == _TRUE) */ /* SimpleConfig Dest. */
+		/*			_rtw_memcpy(ptr+ETH_ALEN, pattrib->bssid, ETH_ALEN); */
+
+		if (_rtw_memcmp(mcastheadermac, pattrib->bssid, 3) == _TRUE) /* SimpleConfig Dest. */
 			_rtw_memcpy(ptr, pattrib->bssid, ETH_ALEN);
 
 	}
 
-	
-_func_exit_;	
+
 	return ret;
 
 }
@@ -3817,34 +3761,28 @@ int mp_recv_frame(_adapter *padapter, union recv_frame *rframe)
 #ifdef CONFIG_MP_INCLUDED
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct mp_priv *pmppriv = &padapter->mppriv;
-#endif //CONFIG_MP_INCLUDED
+#endif /* CONFIG_MP_INCLUDED */
 	u8 type;
 	u8 *ptr = rframe->u.hdr.rx_data;
 	u8 *psa, *pda, *pbssid;
 	struct sta_info *psta = NULL;
-    	DBG_COUNTER(padapter->rx_logs.core_rx_pre);
-    	
-	if ( (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) )//&&(padapter->mppriv.check_mp_pkt == 0))
-	{
-		if (pattrib->crc_err == 1){
+	DBG_COUNTER(padapter->rx_logs.core_rx_pre);
+
+	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) { /* &&(padapter->mppriv.check_mp_pkt == 0)) */
+		if (pattrib->crc_err == 1)
 			padapter->mppriv.rx_crcerrpktcount++;
-		}
-		else{
-			if(_SUCCESS == validate_mp_recv_frame(padapter, rframe))
+		else {
+			if (_SUCCESS == validate_mp_recv_frame(padapter, rframe))
 				padapter->mppriv.rx_pktcount++;
 			else
 				padapter->mppriv.rx_pktcount_filter_out++;
 		}
 
-		if(pmppriv->rx_bindicatePkt == _FALSE)
-		{
-			//RT_TRACE(_module_rtl871x_recv_c_, _drv_alert_, ("MP - Not in loopback mode , drop pkt \n"));
+		if (pmppriv->rx_bindicatePkt == _FALSE) {
 			ret = _FAIL;
-			rtw_free_recvframe(rframe, pfree_recv_queue);//free this recv_frame
+			rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
 			goto exit;
-		}
-		else 
-		{				
+		} else {
 			type =	GetFrameType(ptr);
 			pattrib->to_fr_ds = get_tofr_ds(ptr);
 			pattrib->frag_num = GetFragNum(ptr);
@@ -3854,137 +3792,127 @@ int mp_recv_frame(_adapter *padapter, union recv_frame *rframe)
 			pattrib->mdata = GetMData(ptr);
 			pattrib->privacy = GetPrivacy(ptr);
 			pattrib->order = GetOrder(ptr);
-	
-			if(type ==WIFI_DATA_TYPE)
-			{
+
+			if (type == WIFI_DATA_TYPE) {
 				pda = get_da(ptr);
 				psa = get_sa(ptr);
 				pbssid = get_hdr_bssid(ptr);
-				
+
 				_rtw_memcpy(pattrib->dst, pda, ETH_ALEN);
 				_rtw_memcpy(pattrib->src, psa, ETH_ALEN);
 				_rtw_memcpy(pattrib->bssid, pbssid, ETH_ALEN);
-			
-			switch(pattrib->to_fr_ds)
-			{
-			case 0:
-				_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
-				_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
-				ret = sta2sta_data_frame(padapter, rframe, &psta);
-				break;
 
-			case 1:
-		
-				_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
-				_rtw_memcpy(pattrib->ta, pbssid, ETH_ALEN);
-				ret = ap2sta_data_frame(padapter, rframe, &psta);
-		
-				break;
+				switch (pattrib->to_fr_ds) {
+				case 0:
+					_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
+					_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
+					ret = sta2sta_data_frame(padapter, rframe, &psta);
+					break;
 
-			case 2:
-				_rtw_memcpy(pattrib->ra, pbssid, ETH_ALEN);
-				_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
-				ret = sta2ap_data_frame(padapter, rframe, &psta);
-				break;
+				case 1:
 
-			case 3:
-				_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
-				_rtw_memcpy(pattrib->ta, GetAddr2Ptr(ptr), ETH_ALEN);
-				ret =_FAIL;
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" case 3\n"));
-				break;
+					_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
+					_rtw_memcpy(pattrib->ta, pbssid, ETH_ALEN);
+					ret = ap2sta_data_frame(padapter, rframe, &psta);
 
-			default:
-				ret =_FAIL;
-				break;
-			}
-		
-			ret = MPwlanhdr_to_ethhdr (rframe);
-				
-			if (ret != _SUCCESS)
-			{
-				RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("wlanhdr_to_ethhdr: drop pkt \n"));
-				#ifdef DBG_RX_DROP_FRAME
-					DBG_871X("DBG_RX_DROP_FRAME %s wlanhdr_to_ethhdr: drop pkt\n", __FUNCTION__);
-				#endif
-					rtw_free_recvframe(rframe, pfree_recv_queue);//free this recv_frame
+					break;
+
+				case 2:
+					_rtw_memcpy(pattrib->ra, pbssid, ETH_ALEN);
+					_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
+					ret = sta2ap_data_frame(padapter, rframe, &psta);
+					break;
+
+				case 3:
+					_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
+					_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
+					ret = _FAIL;
+					break;
+
+				default:
+					ret = _FAIL;
+					break;
+				}
+
+				ret = MPwlanhdr_to_ethhdr(rframe);
+
+				if (ret != _SUCCESS) {
+					#ifdef DBG_RX_DROP_FRAME
+					RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" wlanhdr_to_ethhdr: drop pkt\n"
+						, FUNC_ADPT_ARG(padapter));
+					#endif
+					rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
 					ret = _FAIL;
 					goto exit;
 				}
 				if (!RTW_CANNOT_RUN(padapter)) {
-					RT_TRACE(_module_rtl871x_recv_c_, _drv_alert_, ("@@@@ recv_func: recv_func rtw_recv_indicatepkt\n" ));
-							//indicate this recv_frame
+					/* indicate this recv_frame */
 					ret = rtw_recv_indicatepkt(padapter, rframe);
-					if (ret != _SUCCESS)
-					{	
-					#ifdef DBG_RX_DROP_FRAME
-								DBG_871X("DBG_RX_DROP_FRAME %s rtw_recv_indicatepkt fail!\n", __FUNCTION__);
-					#endif
-								rtw_free_recvframe(rframe, pfree_recv_queue);//free this recv_frame
-								ret = _FAIL;
+					if (ret != _SUCCESS) {
+						#ifdef DBG_RX_DROP_FRAME
+						RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" rtw_recv_indicatepkt fail!\n"
+							, FUNC_ADPT_ARG(padapter));
+						#endif
+						rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
+						ret = _FAIL;
 
-								goto exit;
+						goto exit;
 					}
-				}
-				else
-				{
-					RT_TRACE(_module_rtl871x_recv_c_, _drv_alert_, ("@@@@  recv_func: rtw_free_recvframe\n" ));
-					RT_TRACE(_module_rtl871x_recv_c_, _drv_debug_, ("recv_func:bDriverStopped(%s) OR bSurpriseRemoved(%s)"
-						, rtw_is_drv_stopped(padapter)?"True":"False"
-						, rtw_is_surprise_removed(padapter)?"True":"False"));
+				} else {
 					#ifdef DBG_RX_DROP_FRAME
-						DBG_871X("DBG_RX_DROP_FRAME %s ecv_func:bDriverStopped(%s) OR bSurpriseRemoved(%s)\n", __func__,
-									rtw_is_drv_stopped(padapter)?"True":"False",
-									rtw_is_surprise_removed(padapter)?"True":"False");
+					RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" bDriverStopped(%s) OR bSurpriseRemoved(%s)\n"
+						, FUNC_ADPT_ARG(padapter)
+						, rtw_is_drv_stopped(padapter) ? "True" : "False"
+						, rtw_is_surprise_removed(padapter) ? "True" : "False");
 					#endif
 					ret = _FAIL;
-					rtw_free_recvframe(rframe, pfree_recv_queue);//free this recv_frame
-						goto exit;
+					rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
+					goto exit;
 				}
 
 			}
 		}
-				
+
 	}
 
-	RT_TRACE(_module_rtl871x_recv_c_, _drv_info_, ("recv_func: validate_recv_frame fail! drop pkt\n"));
-	rtw_free_recvframe(rframe, pfree_recv_queue);//free this recv_frame
+	rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
 	ret = _FAIL;
 
 exit:
-		return ret;
+	return ret;
 
 }
+#endif
 
 static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe, u8 *buf)
 {
-#define CHAN2FREQ(a) ((a < 14)?(2407+5*a):(5000+5*a))
+#define CHAN2FREQ(a) ((a < 14) ? (2407+5*a) : (5000+5*a))
 
 #if 0
-#define RTW_RX_RADIOTAP_PRESENT (                 \
-		(1 << IEEE80211_RADIOTAP_TSFT)              | \
-		(1 << IEEE80211_RADIOTAP_FLAGS)             | \
-		(1 << IEEE80211_RADIOTAP_RATE)              | \
-		(1 << IEEE80211_RADIOTAP_CHANNEL)           | \
-		(0 << IEEE80211_RADIOTAP_FHSS)              | \
-		(1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL)     | \
-		(1 << IEEE80211_RADIOTAP_DBM_ANTNOISE)      | \
-		(0 << IEEE80211_RADIOTAP_LOCK_QUALITY)      | \
-		(0 << IEEE80211_RADIOTAP_TX_ATTENUATION)    | \
-		(0 << IEEE80211_RADIOTAP_DB_TX_ATTENUATION) | \
-		(0 << IEEE80211_RADIOTAP_DBM_TX_POWER)      | \
-		(1 << IEEE80211_RADIOTAP_ANTENNA)           | \
-		(1 << IEEE80211_RADIOTAP_DB_ANTSIGNAL)      | \
-		(0 << IEEE80211_RADIOTAP_DB_ANTNOISE)       | \
-		(0 << IEEE80211_RADIOTAP_RX_FLAGS)          | \
-		(0 << IEEE80211_RADIOTAP_TX_FLAGS)          | \
-		(0 << IEEE80211_RADIOTAP_RTS_RETRIES)       | \
-		(0 << IEEE80211_RADIOTAP_DATA_RETRIES)      | \
-		(0 << IEEE80211_RADIOTAP_MCS)               | \
-		(0 << IEEE80211_RADIOTAP_RADIOTAP_NAMESPACE)| \
-		(0 << IEEE80211_RADIOTAP_VENDOR_NAMESPACE)  | \
-		(0 << IEEE80211_RADIOTAP_EXT)               | \
-		0)
+#define RTW_RX_RADIOTAP_PRESENT (\
+				 (1 << IEEE80211_RADIOTAP_TSFT)              | \
+				 (1 << IEEE80211_RADIOTAP_FLAGS)             | \
+				 (1 << IEEE80211_RADIOTAP_RATE)              | \
+				 (1 << IEEE80211_RADIOTAP_CHANNEL)           | \
+				 (0 << IEEE80211_RADIOTAP_FHSS)              | \
+				 (1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL)     | \
+				 (1 << IEEE80211_RADIOTAP_DBM_ANTNOISE)      | \
+				 (0 << IEEE80211_RADIOTAP_LOCK_QUALITY)      | \
+				 (0 << IEEE80211_RADIOTAP_TX_ATTENUATION)    | \
+				 (0 << IEEE80211_RADIOTAP_DB_TX_ATTENUATION) | \
+				 (0 << IEEE80211_RADIOTAP_DBM_TX_POWER)      | \
+				 (1 << IEEE80211_RADIOTAP_ANTENNA)           | \
+				 (1 << IEEE80211_RADIOTAP_DB_ANTSIGNAL)      | \
+				 (0 << IEEE80211_RADIOTAP_DB_ANTNOISE)       | \
+				 (0 << IEEE80211_RADIOTAP_RX_FLAGS)          | \
+				 (0 << IEEE80211_RADIOTAP_TX_FLAGS)          | \
+				 (0 << IEEE80211_RADIOTAP_RTS_RETRIES)       | \
+				 (0 << IEEE80211_RADIOTAP_DATA_RETRIES)      | \
+				 (0 << IEEE80211_RADIOTAP_MCS)               | \
+				 (0 << IEEE80211_RADIOTAP_RADIOTAP_NAMESPACE)| \
+				 (0 << IEEE80211_RADIOTAP_VENDOR_NAMESPACE)  | \
+				 (0 << IEEE80211_RADIOTAP_EXT)               | \
+				 0)
 
 	/* (0 << IEEE80211_RADIOTAP_AMPDU_STATUS)      | \ */
 	/* (0 << IEEE80211_RADIOTAP_VHT)               | \ */
@@ -4064,6 +3992,7 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	/* always append FCS */
 	hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_FCS;
 
+
 	if (0)
 		hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_DATAPAD;
 
@@ -4093,15 +4022,15 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	tmp_16bit = 0;
 	rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_CHANNEL);
 	tmp_16bit = CHAN2FREQ(rtw_get_oper_ch(padapter));
-	/*tmp_16bit = CHAN2FREQ(pHalData->CurrentChannel);*/
+	/*tmp_16bit = CHAN2FREQ(pHalData->current_channel);*/
 	memcpy(&hdr_buf[rt_len], &tmp_16bit, 2);
 	rt_len += 2;
 
 	/* channel flags */
 	tmp_16bit = 0;
-	if (pHalData->CurrentBandType == 0) 
+	if (pHalData->current_band_type == 0)
 		tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_2GHZ);
-	else 
+	else
 		tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_5GHZ);
 
 	if (pattrib->data_rate < 12) {
@@ -4112,15 +4041,14 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 			/* OFDM */
 			tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_OFDM);
 		}
-	} else {
+	} else
 		tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_DYN);
-	}
 	memcpy(&hdr_buf[rt_len], &tmp_16bit, 2);
 	rt_len += 2;
 
 	/* dBm Antenna Signal */
 	rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL);
-	hdr_buf[rt_len] = pattrib->phy_info.RecvSignalPower;
+	hdr_buf[rt_len] = pattrib->phy_info.recv_signal_power;
 	rt_len += 1;
 
 #if 0
@@ -4131,7 +4059,7 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 
 	/* Signal Quality */
 	rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_LOCK_QUALITY);
-	hdr_buf[rt_len] = pattrib->phy_info.SignalQuality;
+	hdr_buf[rt_len] = pattrib->phy_info.signal_quality;
 	rt_len += 1;
 #endif
 
@@ -4156,15 +4084,15 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 
 		/* bandwidth */
 		hdr_buf[rt_len] |= BIT0;
-		hdr_buf[rt_len+1] |= (pattrib->bw & 0x03);
+		hdr_buf[rt_len + 1] |= (pattrib->bw & 0x03);
 
 		/* guard interval */
 		hdr_buf[rt_len] |= BIT2;
-		hdr_buf[rt_len+1] |= (pattrib->sgi & 0x01) << 2;
+		hdr_buf[rt_len + 1] |= (pattrib->sgi & 0x01) << 2;
 
 		/* STBC */
 		hdr_buf[rt_len] |= BIT5;
-		hdr_buf[rt_len+1] |= (pattrib->stbc & 0x03) << 5;
+		hdr_buf[rt_len + 1] |= (pattrib->stbc & 0x03) << 5;
 
 		rt_len += 2;
 
@@ -4191,27 +4119,27 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 
 		/* STBC */
 		tmp_16bit |= BIT0;
-		hdr_buf[rt_len+2] |= (pattrib->stbc & 0x01);
+		hdr_buf[rt_len + 2] |= (pattrib->stbc & 0x01);
 
 		/* Guard interval */
 		tmp_16bit |= BIT2;
-		hdr_buf[rt_len+2] |= (pattrib->sgi & 0x01) << 2;
+		hdr_buf[rt_len + 2] |= (pattrib->sgi & 0x01) << 2;
 
 		/* LDPC extra OFDM symbol */
 		tmp_16bit |= BIT4;
-		hdr_buf[rt_len+2] |= (pattrib->ldpc & 0x01) << 4;
+		hdr_buf[rt_len + 2] |= (pattrib->ldpc & 0x01) << 4;
 
 		memcpy(&hdr_buf[rt_len], &tmp_16bit, 2);
 		rt_len += 3;
 
 		/* bandwidth */
-		if (pattrib->bw == 0) 
+		if (pattrib->bw == 0)
 			hdr_buf[rt_len] |= 0;
-		else if (pattrib->bw == 1) 
+		else if (pattrib->bw == 1)
 			hdr_buf[rt_len] |= 1;
-		else if (pattrib->bw == 2) 
+		else if (pattrib->bw == 2)
 			hdr_buf[rt_len] |= 4;
-		else if (pattrib->bw == 3) 
+		else if (pattrib->bw == 3)
 			hdr_buf[rt_len] |= 11;
 		rt_len += 1;
 
@@ -4248,7 +4176,7 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	/* push to skb */
 	pskb = (_pkt *)buf;
 	if (skb_headroom(pskb) < rt_len) {
-		DBG_871X("%s:%d %s headroom is too small.\n", __FILE__, __LINE__, __func__);
+		RTW_INFO("%s:%d %s headroom is too small.\n", __FILE__, __LINE__, __func__);
 		ret = _FAIL;
 		return ret;
 	}
@@ -4257,9 +4185,8 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	if (ptr) {
 		rtap_hdr->it_len = cpu_to_le16(rt_len);
 		memcpy(ptr, rtap_hdr, rt_len);
-	} else {
+	} else
 		ret = _FAIL;
-	}
 
 	return ret;
 
@@ -4320,8 +4247,7 @@ int recv_func_prehandle(_adapter *padapter, union recv_frame *rframe)
 	_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
 
 #ifdef DBG_RX_COUNTER_DUMP
-	if( padapter->dump_rx_cnt_mode & DUMP_DRV_RX_COUNTER )
-	{
+	if (padapter->dump_rx_cnt_mode & DUMP_DRV_RX_COUNTER) {
 		if (pattrib->crc_err == 1)
 			padapter->drv_rx_cnt_crcerror++;
 		else
@@ -4330,28 +4256,25 @@ int recv_func_prehandle(_adapter *padapter, union recv_frame *rframe)
 #endif
 
 #ifdef CONFIG_MP_INCLUDED
-	if (padapter->registrypriv.mp_mode == 1 || padapter->mppriv.bRTWSmbCfg ==_TRUE)
-	{
-		mp_recv_frame(padapter,rframe);
+	if (padapter->registrypriv.mp_mode == 1 || padapter->mppriv.bRTWSmbCfg == _TRUE) {
+		mp_recv_frame(padapter, rframe);
 		ret = _FAIL;
 		goto exit;
-        }
-	else
+	} else
 #endif
 	{
-	//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_recvframe(rframe, pfree_recv_queue);//free this recv_frame
-		goto exit;
-	}
+		/* check the frame crtl field and decache */
+		ret = validate_recv_frame(padapter, rframe);
+		if (ret != _SUCCESS) {
+			rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
+			goto exit;
+		}
 	}
 exit:
 	return ret;
 }
 
+/*#define DBG_RX_BMC_FRAME*/
 int recv_func_posthandle(_adapter *padapter, union recv_frame *prframe)
 {
 	int ret = _SUCCESS;
@@ -4361,68 +4284,69 @@ int recv_func_posthandle(_adapter *padapter, union recv_frame *prframe)
 	_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
 #ifdef CONFIG_TDLS
 	u8 *psnap_type, *pcategory;
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 	DBG_COUNTER(padapter->rx_logs.core_rx_post);
 
-	// DATA FRAME
-	rtw_led_control(padapter, LED_CTL_RX);
-
 	prframe = decryptor(padapter, prframe);
 	if (prframe == NULL) {
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("decryptor: drop pkt\n"));
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s decryptor: drop pkt\n", __FUNCTION__);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" decryptor: drop pkt\n"
+			, FUNC_ADPT_ARG(padapter));
 		#endif
 		ret = _FAIL;
 		DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_err);
 		goto _recv_data_drop;
 	}
 
+#ifdef DBG_RX_BMC_FRAME
+	if (IS_MCAST(pattrib->ra))
+		RTW_INFO("%s =>"ADPT_FMT" Rx BC/MC from "MAC_FMT"\n", __func__, ADPT_ARG(padapter), MAC_ARG(pattrib->ta));
+#endif
+
 #if 0
-	if ( padapter->adapter_type == PRIMARY_ADAPTER )
-	{
-		DBG_871X("+++\n");
+	if (is_primary_adapter(padapter)) {
+		RTW_INFO("+++\n");
 		{
 			int i;
 			u8	*ptr = get_recvframe_data(prframe);
-			for(i=0; i<140;i=i+8)
-				DBG_871X("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:", *(ptr+i),
-				*(ptr+i+1), *(ptr+i+2) ,*(ptr+i+3) ,*(ptr+i+4),*(ptr+i+5), *(ptr+i+6), *(ptr+i+7));
+			for (i = 0; i < 140; i = i + 8)
+				RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:", *(ptr + i),
+					*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
 
 		}
-		DBG_871X("---\n");
+		RTW_INFO("---\n");
 	}
 #endif
 
 #ifdef CONFIG_TDLS
-	//check TDLS frame
-	psnap_type = get_recvframe_data(orig_prframe) + pattrib->hdrlen + pattrib->iv_len+SNAP_SIZE;
+	/* check TDLS frame */
+	psnap_type = get_recvframe_data(orig_prframe) + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
 	pcategory = psnap_type + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
 
-	if((_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_TDLS, ETH_TYPE_LEN)) &&
-		((*pcategory==RTW_WLAN_CATEGORY_TDLS) || (*pcategory==RTW_WLAN_CATEGORY_P2P))){
+	if ((_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_TDLS, ETH_TYPE_LEN)) &&
+	    ((*pcategory == RTW_WLAN_CATEGORY_TDLS) || (*pcategory == RTW_WLAN_CATEGORY_P2P))) {
 		ret = OnTDLS(padapter, prframe);
-		if(ret == _FAIL)
+		if (ret == _FAIL)
 			goto _exit_recv_func;
 	}
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 	prframe = recvframe_chk_defrag(padapter, prframe);
-	if(prframe==NULL)	{
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("recvframe_chk_defrag: drop pkt\n"));
+	if (prframe == NULL)	{
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s recvframe_chk_defrag: drop pkt\n", __FUNCTION__);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recvframe_chk_defrag: drop pkt\n"
+			, FUNC_ADPT_ARG(padapter));
 		#endif
 		DBG_COUNTER(padapter->rx_logs.core_rx_post_defrag_err);
-		goto _recv_data_drop;		
+		goto _recv_data_drop;
 	}
 
-	prframe=portctrl(padapter, prframe);
+	prframe = portctrl(padapter, prframe);
 	if (prframe == NULL) {
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("portctrl: drop pkt \n"));
 		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s portctrl: drop pkt\n", __FUNCTION__);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" portctrl: drop pkt\n"
+			, FUNC_ADPT_ARG(padapter));
 		#endif
 		ret = _FAIL;
 		DBG_COUNTER(padapter->rx_logs.core_rx_post_portctrl_err);
@@ -4435,96 +4359,36 @@ int recv_func_posthandle(_adapter *padapter, union recv_frame *prframe)
 	rtw_wapi_update_info(padapter, prframe);
 #endif
 
-#ifdef CONFIG_80211N_HT
-	ret = process_recv_indicatepkts(padapter, prframe);
-	if (ret != _SUCCESS)
-	{
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("recv_func: process_recv_indicatepkts fail! \n"));
-		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s process_recv_indicatepkts fail!\n", __FUNCTION__);
-		#endif
-		rtw_free_recvframe(orig_prframe, pfree_recv_queue);//free this recv_frame
-		DBG_COUNTER(padapter->rx_logs.core_rx_post_indicate_err);
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
+	/* including perform A-MPDU Rx Ordering Buffer Control */
+	ret = recv_indicatepkt_reorder(padapter, prframe);
+	if (ret == _FAIL) {
+		rtw_free_recvframe(orig_prframe, pfree_recv_queue);
 		goto _recv_data_drop;
-	}
-#else // CONFIG_80211N_HT
-	if (!pattrib->amsdu)
-	{
-		ret = wlanhdr_to_ethhdr (prframe);
-		if (ret != _SUCCESS)
-		{
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("wlanhdr_to_ethhdr: drop pkt \n"));
-			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s wlanhdr_to_ethhdr: drop pkt\n", __FUNCTION__);
-			#endif
-			rtw_free_recvframe(orig_prframe, pfree_recv_queue);//free this recv_frame
-			goto _recv_data_drop;
-		}
-
-		if (!RTW_CANNOT_RUN(padapter)) {
-			RT_TRACE(_module_rtl871x_recv_c_, _drv_alert_, ("@@@@ recv_func: recv_func rtw_recv_indicatepkt\n" ));
-			//indicate this recv_frame
-			ret = rtw_recv_indicatepkt(padapter, prframe);
-			if (ret != _SUCCESS)
-			{	
-				#ifdef DBG_RX_DROP_FRAME
-				DBG_871X("DBG_RX_DROP_FRAME %s rtw_recv_indicatepkt fail!\n", __FUNCTION__);
-				#endif
-				goto _recv_data_drop;
-			}
-		}
-		else
-		{
-			RT_TRACE(_module_rtl871x_recv_c_, _drv_alert_, ("@@@@  recv_func: rtw_free_recvframe\n" ));
-			RT_TRACE(_module_rtl871x_recv_c_, _drv_debug_, ("recv_func:bDriverStopped(%d) OR bSurpriseRemoved(%d)", padapter->bDriverStopped, padapter->bSurpriseRemoved));
-			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s ecv_func:bDriverStopped(%s) OR bSurpriseRemoved(%s)\n", __func__
-				, rtw_is_drv_stopped(padapter)?"True":"False"
-				, rtw_is_surprise_removed(padapter)?"True":"False");
-			#endif
-			ret = _FAIL;
-			rtw_free_recvframe(orig_prframe, pfree_recv_queue); //free this recv_frame
-		}
-
-	}
-	else if(pattrib->amsdu==1)
-	{
+	} else if (ret == RTW_RX_HANDLED) /* queued OR indicated in order */
+		goto _exit_recv_func;
+#endif
 
-		ret = amsdu_to_msdu(padapter, prframe);
-		if(ret != _SUCCESS)
-		{
-			#ifdef DBG_RX_DROP_FRAME
-			DBG_871X("DBG_RX_DROP_FRAME %s amsdu_to_msdu fail\n", __FUNCTION__);
-			#endif
-			rtw_free_recvframe(orig_prframe, pfree_recv_queue);
-			goto _recv_data_drop;
-		}
-	}
-	else
-	{
-		#ifdef DBG_RX_DROP_FRAME
-		DBG_871X("DBG_RX_DROP_FRAME %s what is this condition??\n", __FUNCTION__);
-		#endif
+	recv_set_iseq_before_mpdu_process(prframe, pattrib->seq_num, __func__);
+	ret = recv_process_mpdu(padapter, prframe);
+	recv_set_iseq_after_mpdu_process(prframe, pattrib->seq_num, __func__);
+	if (ret == _FAIL)
 		goto _recv_data_drop;
-	}
-#endif // CONFIG_80211N_HT
 
 _exit_recv_func:
 	return ret;
 
 _recv_data_drop:
-	precvpriv->rx_drop++;
+	precvpriv->dbg_rx_drop_count++;
 	return ret;
 }
 
-
-int recv_func(_adapter *padapter, union recv_frame *rframe);
 int recv_func(_adapter *padapter, union recv_frame *rframe)
 {
 	int ret;
 	struct rx_pkt_attrib *prxattrib = &rframe->u.hdr.attrib;
 	struct recv_priv *recvpriv = &padapter->recvpriv;
-	struct security_priv *psecuritypriv=&padapter->securitypriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
 
 	if (check_fwstate(mlmepriv, WIFI_MONITOR_STATE)) {
@@ -4536,41 +4400,39 @@ int recv_func(_adapter *padapter, union recv_frame *rframe)
 		goto exit;
 	} else
 
-	/* check if need to handle uc_swdec_pending_queue*/
-	if (check_fwstate(mlmepriv, WIFI_STATION_STATE) && psecuritypriv->busetkipkey)
-	{
-		union recv_frame *pending_frame;
-		int cnt = 0;
+		/* check if need to handle uc_swdec_pending_queue*/
+		if (check_fwstate(mlmepriv, WIFI_STATION_STATE) && psecuritypriv->busetkipkey) {
+			union recv_frame *pending_frame;
+			int cnt = 0;
 
-		while((pending_frame=rtw_alloc_recvframe(&padapter->recvpriv.uc_swdec_pending_queue))) {
-			cnt++;
-			DBG_COUNTER(padapter->rx_logs.core_rx_dequeue);
-			recv_func_posthandle(padapter, pending_frame);
-		}
+			while ((pending_frame = rtw_alloc_recvframe(&padapter->recvpriv.uc_swdec_pending_queue))) {
+				cnt++;
+				DBG_COUNTER(padapter->rx_logs.core_rx_dequeue);
+				recv_func_posthandle(padapter, pending_frame);
+			}
 
-		if (cnt)
-			DBG_871X(FUNC_ADPT_FMT" dequeue %d from uc_swdec_pending_queue\n",
-				FUNC_ADPT_ARG(padapter), cnt);
-	}
+			if (cnt)
+				RTW_INFO(FUNC_ADPT_FMT" dequeue %d from uc_swdec_pending_queue\n",
+					 FUNC_ADPT_ARG(padapter), cnt);
+		}
 
 	DBG_COUNTER(padapter->rx_logs.core_rx);
 	ret = recv_func_prehandle(padapter, rframe);
 
-	if(ret == _SUCCESS) {
-		
+	if (ret == _SUCCESS) {
+
 		/* check if need to enqueue into uc_swdec_pending_queue*/
 		if (check_fwstate(mlmepriv, WIFI_STATION_STATE) &&
-			!IS_MCAST(prxattrib->ra) && prxattrib->encrypt>0 &&
-			(prxattrib->bdecrypted == 0 ||psecuritypriv->sw_decrypt == _TRUE) &&
-			psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPAPSK &&
-			!psecuritypriv->busetkipkey)
-		{
+		    !IS_MCAST(prxattrib->ra) && prxattrib->encrypt > 0 &&
+		    (prxattrib->bdecrypted == 0 || psecuritypriv->sw_decrypt == _TRUE) &&
+		    psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPAPSK &&
+		    !psecuritypriv->busetkipkey) {
 			DBG_COUNTER(padapter->rx_logs.core_rx_enqueue);
 			rtw_enqueue_recvframe(rframe, &padapter->recvpriv.uc_swdec_pending_queue);
-			//DBG_871X("%s: no key, enqueue uc_swdec_pending_queue\n", __func__);
+			/* RTW_INFO("%s: no key, enqueue uc_swdec_pending_queue\n", __func__); */
 
-			if (recvpriv->free_recvframe_cnt < NR_RECVFRAME/4) {
-				/* to prevent from recvframe starvation, get recvframe from uc_swdec_pending_queue to free_recvframe_cnt  */
+			if (recvpriv->free_recvframe_cnt < NR_RECVFRAME / 4) {
+				/* to prevent from recvframe starvation, get recvframe from uc_swdec_pending_queue to free_recvframe_cnt */
 				rframe = rtw_alloc_recvframe(&padapter->recvpriv.uc_swdec_pending_queue);
 				if (rframe)
 					goto do_posthandle;
@@ -4591,27 +4453,23 @@ s32 rtw_recv_entry(union recv_frame *precvframe)
 {
 	_adapter *padapter;
 	struct recv_priv *precvpriv;
-	s32 ret=_SUCCESS;
+	s32 ret = _SUCCESS;
 
-_func_enter_;
 
-//	RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("+rtw_recv_entry\n"));
 
 	padapter = precvframe->u.hdr.adapter;
 
 	precvpriv = &padapter->recvpriv;
 
 
-	if ((ret = recv_func(padapter, precvframe)) == _FAIL)
-	{
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("rtw_recv_entry: recv_func return fail!!!\n"));
+	ret = recv_func(padapter, precvframe);
+	if (ret == _FAIL) {
 		goto _recv_entry_drop;
 	}
 
 
 	precvpriv->rx_pkts++;
 
-_func_exit_;
 
 	return ret;
 
@@ -4622,18 +4480,17 @@ _recv_entry_drop:
 		padapter->mppriv.rx_pktloss = precvpriv->rx_drop;
 #endif
 
-	//RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,("_recv_entry_drop\n"));
 
-_func_exit_;
 
 	return ret;
 }
 
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
-void rtw_signal_stat_timer_hdl(RTW_TIMER_HDL_ARGS){
-	_adapter *adapter = (_adapter *)FunctionContext;
+static void rtw_signal_stat_timer_hdl(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
 	struct recv_priv *recvpriv = &adapter->recvpriv;
-	
+
 	u32 tmp_s, tmp_q;
 	u8 avg_signal_strength = 0;
 	u8 avg_signal_qual = 0;
@@ -4641,44 +4498,42 @@ void rtw_signal_stat_timer_hdl(RTW_TIMER_HDL_ARGS){
 	u32 num_signal_qual = 0;
 	u8 ratio_pre_stat = 0, ratio_curr_stat = 0, ratio_total = 0, ratio_profile = SIGNAL_STAT_CALC_PROFILE_0;
 
-	if(adapter->recvpriv.is_signal_dbg) {
-		//update the user specific value, signal_strength_dbg, to signal_strength, rssi
-		adapter->recvpriv.signal_strength= adapter->recvpriv.signal_strength_dbg;
-		adapter->recvpriv.rssi=(s8)translate_percentage_to_dbm((u8)adapter->recvpriv.signal_strength_dbg);
+	if (adapter->recvpriv.is_signal_dbg) {
+		/* update the user specific value, signal_strength_dbg, to signal_strength, rssi */
+		adapter->recvpriv.signal_strength = adapter->recvpriv.signal_strength_dbg;
+		adapter->recvpriv.rssi = (s8)translate_percentage_to_dbm((u8)adapter->recvpriv.signal_strength_dbg);
 	} else {
 
-		if(recvpriv->signal_strength_data.update_req == 0) {// update_req is clear, means we got rx
+		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 accquired, we can re-stat the signal values
+			/* after avg_vals are accquired, 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
+
+		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 accquired, we can re-stat the signal values
+			/* after avg_vals are accquired, we can re-stat the signal values */
 			recvpriv->signal_qual_data.update_req = 1;
 		}
 
 		if (num_signal_strength == 0) {
 			if (rtw_get_on_cur_ch_time(adapter) == 0
-				|| rtw_get_passing_time_ms(rtw_get_on_cur_ch_time(adapter)) < 2 * adapter->mlmeextpriv.mlmext_info.bcn_interval
-			) {
+			    || rtw_get_passing_time_ms(rtw_get_on_cur_ch_time(adapter)) < 2 * adapter->mlmeextpriv.mlmext_info.bcn_interval
+			   )
 				goto set_timer;
-			}
 		}
 
-		if(check_fwstate(&adapter->mlmepriv, _FW_UNDER_SURVEY) == _TRUE
-			|| check_fwstate(&adapter->mlmepriv, _FW_LINKED) == _FALSE
-		) { 
+		if (check_fwstate(&adapter->mlmepriv, _FW_UNDER_SURVEY) == _TRUE
+		    || check_fwstate(&adapter->mlmepriv, _FW_LINKED) == _FALSE
+		   )
 			goto set_timer;
-		}
 
-		#ifdef CONFIG_CONCURRENT_MODE
-		if (check_buddy_fwstate(adapter, _FW_UNDER_SURVEY) == _TRUE)
+#ifdef CONFIG_CONCURRENT_MODE
+		if (rtw_mi_buddy_check_fwstate(adapter, _FW_UNDER_SURVEY) == _TRUE)
 			goto set_timer;
-		#endif
+#endif
 
 		if (RTW_SIGNAL_STATE_CALC_PROFILE < SIGNAL_STAT_CALC_PROFILE_MAX)
 			ratio_profile = RTW_SIGNAL_STATE_CALC_PROFILE;
@@ -4687,7 +4542,7 @@ void rtw_signal_stat_timer_hdl(RTW_TIMER_HDL_ARGS){
 		ratio_curr_stat = signal_stat_calc_profile[ratio_profile][1];
 		ratio_total = ratio_pre_stat + ratio_curr_stat;
 
-		//update value of signal_strength, rssi, signal_qual
+		/* update value of signal_strength, rssi, signal_qual */
 		tmp_s = (ratio_curr_stat * avg_signal_strength + ratio_pre_stat * recvpriv->signal_strength);
 		if (tmp_s % ratio_total)
 			tmp_s = tmp_s / ratio_total + 1;
@@ -4708,139 +4563,129 @@ void rtw_signal_stat_timer_hdl(RTW_TIMER_HDL_ARGS){
 		recvpriv->rssi = (s8)translate_percentage_to_dbm(tmp_s);
 		recvpriv->signal_qual = tmp_q;
 
-		#if defined(DBG_RX_SIGNAL_DISPLAY_PROCESSING) && 1
-		DBG_871X(FUNC_ADPT_FMT" signal_strength:%3u, rssi:%3d, signal_qual:%3u"
-			", num_signal_strength:%u, num_signal_qual:%u"
-			", on_cur_ch_ms:%d"
-			"\n"
-			, FUNC_ADPT_ARG(adapter)
-			, recvpriv->signal_strength
-			, recvpriv->rssi
-			, recvpriv->signal_qual
-			, num_signal_strength, num_signal_qual
+#if defined(DBG_RX_SIGNAL_DISPLAY_PROCESSING) && 1
+		RTW_INFO(FUNC_ADPT_FMT" signal_strength:%3u, rssi:%3d, signal_qual:%3u"
+			 ", num_signal_strength:%u, num_signal_qual:%u"
+			 ", on_cur_ch_ms:%d"
+			 "\n"
+			 , FUNC_ADPT_ARG(adapter)
+			 , recvpriv->signal_strength
+			 , recvpriv->rssi
+			 , recvpriv->signal_qual
+			 , num_signal_strength, num_signal_qual
 			, rtw_get_on_cur_ch_time(adapter) ? rtw_get_passing_time_ms(rtw_get_on_cur_ch_time(adapter)) : 0
-		);
-		#endif
+			);
+#endif
 	}
 
 set_timer:
 	rtw_set_signal_stat_timer(recvpriv);
-	
+
 }
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
-static void rx_process_rssi(_adapter *padapter,union recv_frame *prframe)
+static void rx_process_rssi(_adapter *padapter, union recv_frame *prframe)
 {
 	u32	last_rssi, tmp_val;
 	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
-	struct signal_stat * signal_stat = &padapter->recvpriv.signal_strength_data;
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+	struct signal_stat *signal_stat = &padapter->recvpriv.signal_strength_data;
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
-	//DBG_8192C("process_rssi=> pattrib->rssil(%d) signal_strength(%d)\n ",pattrib->RecvSignalPower,pattrib->signal_strength);
-	//if(pRfd->Status.bPacketToSelf || pRfd->Status.bPacketBeacon)
+	/* RTW_INFO("process_rssi=> pattrib->rssil(%d) signal_strength(%d)\n ",pattrib->recv_signal_power,pattrib->signal_strength); */
+	/* if(pRfd->Status.bPacketToSelf || pRfd->Status.bPacketBeacon) */
 	{
-	#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
-		if(signal_stat->update_req) {
+#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
+		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;		
-	#else //CONFIG_NEW_SIGNAL_STAT_PROCESS
-	
-		//Adapter->RxStats.RssiCalculateCnt++;	//For antenna Test
-		if(padapter->recvpriv.signal_strength_data.total_num++ >= PHY_RSSI_SLID_WIN_MAX)
-		{
+		signal_stat->total_val  += pattrib->phy_info.signal_strength;
+		signal_stat->avg_val = signal_stat->total_val / signal_stat->total_num;
+#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+
+		/* Adapter->RxStats.RssiCalculateCnt++;	 */ /* For antenna Test */
+		if (padapter->recvpriv.signal_strength_data.total_num++ >= PHY_RSSI_SLID_WIN_MAX) {
 			padapter->recvpriv.signal_strength_data.total_num = PHY_RSSI_SLID_WIN_MAX;
 			last_rssi = padapter->recvpriv.signal_strength_data.elements[padapter->recvpriv.signal_strength_data.index];
 			padapter->recvpriv.signal_strength_data.total_val -= last_rssi;
 		}
-		padapter->recvpriv.signal_strength_data.total_val  +=pattrib->phy_info.SignalStrength;
+		padapter->recvpriv.signal_strength_data.total_val  += pattrib->phy_info.signal_strength;
 
-		padapter->recvpriv.signal_strength_data.elements[padapter->recvpriv.signal_strength_data.index++] = pattrib->phy_info.SignalStrength;
-		if(padapter->recvpriv.signal_strength_data.index >= PHY_RSSI_SLID_WIN_MAX)
+		padapter->recvpriv.signal_strength_data.elements[padapter->recvpriv.signal_strength_data.index++] = pattrib->phy_info.signal_strength;
+		if (padapter->recvpriv.signal_strength_data.index >= PHY_RSSI_SLID_WIN_MAX)
 			padapter->recvpriv.signal_strength_data.index = 0;
 
 
-		tmp_val = padapter->recvpriv.signal_strength_data.total_val/padapter->recvpriv.signal_strength_data.total_num;
-		
-		if(padapter->recvpriv.is_signal_dbg) {
-			padapter->recvpriv.signal_strength= padapter->recvpriv.signal_strength_dbg;
-			padapter->recvpriv.rssi=(s8)translate_percentage_to_dbm(padapter->recvpriv.signal_strength_dbg);
+		tmp_val = padapter->recvpriv.signal_strength_data.total_val / padapter->recvpriv.signal_strength_data.total_num;
+
+		if (padapter->recvpriv.is_signal_dbg) {
+			padapter->recvpriv.signal_strength = padapter->recvpriv.signal_strength_dbg;
+			padapter->recvpriv.rssi = (s8)translate_percentage_to_dbm(padapter->recvpriv.signal_strength_dbg);
 		} else {
-			padapter->recvpriv.signal_strength= tmp_val;
-			padapter->recvpriv.rssi=(s8)translate_percentage_to_dbm(tmp_val);
+			padapter->recvpriv.signal_strength = tmp_val;
+			padapter->recvpriv.rssi = (s8)translate_percentage_to_dbm(tmp_val);
 		}
 
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("UI RSSI = %d, ui_rssi.TotalVal = %d, ui_rssi.TotalNum = %d\n", tmp_val, padapter->recvpriv.signal_strength_data.total_val,padapter->recvpriv.signal_strength_data.total_num));
-	#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 	}
 }
 
-static void rx_process_link_qual(_adapter *padapter,union recv_frame *prframe)
+static void rx_process_link_qual(_adapter *padapter, union recv_frame *prframe)
 {
-	u32	last_evm=0, tmpVal;
- 	struct rx_pkt_attrib *pattrib;
+	u32	last_evm = 0, tmpVal;
+	struct rx_pkt_attrib *pattrib;
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
-	struct signal_stat * signal_stat;
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+	struct signal_stat *signal_stat;
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
-	if(prframe == NULL || padapter==NULL){
+	if (prframe == NULL || padapter == NULL)
 		return;
-	}
 
 	pattrib = &prframe->u.hdr.attrib;
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	signal_stat = &padapter->recvpriv.signal_qual_data;
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
-	//DBG_8192C("process_link_qual=> pattrib->signal_qual(%d)\n ",pattrib->signal_qual);
+	/* RTW_INFO("process_link_qual=> pattrib->signal_qual(%d)\n ",pattrib->signal_qual); */
 
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
-	if(signal_stat->update_req) {
+	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->total_val  += pattrib->phy_info.signal_quality;
 	signal_stat->avg_val = signal_stat->total_val / signal_stat->total_num;
-	
-#else //CONFIG_NEW_SIGNAL_STAT_PROCESS
-	if(pattrib->phy_info.SignalQuality != 0)
-	{
-			//
-			// 1. Record the general EVM to the sliding window.
-			//
-			if(padapter->recvpriv.signal_qual_data.total_num++ >= PHY_LINKQUALITY_SLID_WIN_MAX)
-			{
-				padapter->recvpriv.signal_qual_data.total_num = PHY_LINKQUALITY_SLID_WIN_MAX;
-				last_evm = padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index];
-				padapter->recvpriv.signal_qual_data.total_val -= last_evm;
-			}
-			padapter->recvpriv.signal_qual_data.total_val += pattrib->phy_info.SignalQuality;
 
-			padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index++] = pattrib->phy_info.SignalQuality;
-			if(padapter->recvpriv.signal_qual_data.index >= PHY_LINKQUALITY_SLID_WIN_MAX)
-				padapter->recvpriv.signal_qual_data.index = 0;
+#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+	if (pattrib->phy_info.signal_quality != 0) {
+		/*  */
+		/* 1. Record the general EVM to the sliding window. */
+		/*  */
+		if (padapter->recvpriv.signal_qual_data.total_num++ >= PHY_LINKQUALITY_SLID_WIN_MAX) {
+			padapter->recvpriv.signal_qual_data.total_num = PHY_LINKQUALITY_SLID_WIN_MAX;
+			last_evm = padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index];
+			padapter->recvpriv.signal_qual_data.total_val -= last_evm;
+		}
+		padapter->recvpriv.signal_qual_data.total_val += pattrib->phy_info.signal_quality;
+
+		padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index++] = pattrib->phy_info.signal_quality;
+		if (padapter->recvpriv.signal_qual_data.index >= PHY_LINKQUALITY_SLID_WIN_MAX)
+			padapter->recvpriv.signal_qual_data.index = 0;
 
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_info_,("Total SQ=%d  pattrib->signal_qual= %d\n", padapter->recvpriv.signal_qual_data.total_val, pattrib->phy_info.SignalQuality));
 
-			// <1> Showed on UI for user, in percentage.
-			tmpVal = padapter->recvpriv.signal_qual_data.total_val/padapter->recvpriv.signal_qual_data.total_num;
-			padapter->recvpriv.signal_qual=(u8)tmpVal;
+		/* <1> Showed on UI for user, in percentage. */
+		tmpVal = padapter->recvpriv.signal_qual_data.total_val / padapter->recvpriv.signal_qual_data.total_num;
+		padapter->recvpriv.signal_qual = (u8)tmpVal;
 
 	}
-	else
-	{
-		RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,(" pattrib->signal_qual =%d\n", pattrib->phy_info.SignalQuality));
-	}
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 }
 
 void rx_process_phy_info(_adapter *padapter, union recv_frame *rframe)
@@ -4849,113 +4694,122 @@ void rx_process_phy_info(_adapter *padapter, union recv_frame *rframe)
 	rx_process_rssi(padapter, rframe);
 
 	/* Check PWDB */
-	//process_PWDB(padapter, rframe); 
+	/* process_PWDB(padapter, rframe); */
+
+	/* UpdateRxSignalStatistics8192C(Adapter, pRfd); */
 
-	//UpdateRxSignalStatistics8192C(Adapter, pRfd);
-	
 	/* Check EVM */
 	rx_process_link_qual(padapter, rframe);
-	#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
-	rtw_store_phy_info( padapter, rframe);
-	#endif
+	rtw_store_phy_info(padapter, rframe);
 }
 
 void rx_query_phy_status(
 	union recv_frame	*precvframe,
 	u8 *pphy_status)
 {
-	PADAPTER 			padapter = precvframe->u.hdr.adapter;
+	PADAPTER			padapter = precvframe->u.hdr.adapter;
 	struct rx_pkt_attrib	*pattrib = &precvframe->u.hdr.attrib;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);	
-	PODM_PHY_INFO_T 	pPHYInfo  = (PODM_PHY_INFO_T)(&pattrib->phy_info);
+	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
+	struct phydm_phyinfo_struct *p_phy_info = &pattrib->phy_info;
 	u8					*wlanhdr;
-	ODM_PACKET_INFO_T	pkt_info;
-	u8 *sa;
+	struct phydm_perpkt_info_struct pkt_info;
+	u8 *ta, *ra;
+	u8 is_ra_bmc;
 	struct sta_priv *pstapriv;
 	struct sta_info *psta = NULL;
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-	//_irqL		irqL;
-	
-	pkt_info.bPacketMatchBSSID =_FALSE;
-	pkt_info.bPacketToSelf = _FALSE;
-	pkt_info.bPacketBeacon = _FALSE;
-
-	wlanhdr = get_recvframe_data(precvframe);
-
-	pkt_info.bPacketMatchBSSID = (!IsFrameTypeCtrl(wlanhdr))
-		&& (!pattrib->icv_err) && (!pattrib->crc_err)
-		&& _rtw_memcmp(get_hdr_bssid(wlanhdr), get_bssid(&padapter->mlmepriv), ETH_ALEN);
+	struct recv_priv  *precvpriv = &padapter->recvpriv;
+	/* _irqL		irqL; */
 
-	pkt_info.bToSelf = (!pattrib->icv_err) && (!pattrib->crc_err)
-		&& _rtw_memcmp(get_ra(wlanhdr), adapter_mac_addr(padapter), ETH_ALEN);
+	pkt_info.is_packet_match_bssid = _FALSE;
+	pkt_info.is_packet_to_self = _FALSE;
+	pkt_info.is_packet_beacon = _FALSE;
+	pkt_info.ppdu_cnt = pattrib->ppdu_cnt;
+	pkt_info.station_id = 0xFF;
 
-	pkt_info.bPacketToSelf = pkt_info.bPacketMatchBSSID
-		&& _rtw_memcmp(get_ra(wlanhdr), adapter_mac_addr(padapter), ETH_ALEN);
-
-	pkt_info.bPacketBeacon = pkt_info.bPacketMatchBSSID
-		&& (GetFrameSubType(wlanhdr) == WIFI_BEACON);
-
-	sa = get_ta(wlanhdr);
+	wlanhdr = get_recvframe_data(precvframe);
 
-	pkt_info.StationID = 0xFF;
+	ta = get_ta(wlanhdr);
+	ra = get_ra(wlanhdr);
+	is_ra_bmc = IS_MCAST(ra);
 
-	if (_rtw_memcmp(adapter_mac_addr(padapter), sa, ETH_ALEN) == _TRUE) {
-		static u32 start_time = 0;
+	if (_rtw_memcmp(adapter_mac_addr(padapter), ta, ETH_ALEN) == _TRUE) {
+		static systime start_time = 0;
 
 #if 0 /*For debug */
 		if (IsFrameTypeCtrl(wlanhdr)) {
-				DBG_871X("-->Control frame: Y\n");
-				DBG_871X("-->pkt_len: %d\n", pattrib->pkt_len);
-				DBG_871X("-->Sub Type = 0x%X\n", GetFrameSubType(wlanhdr));
+			RTW_INFO("-->Control frame: Y\n");
+			RTW_INFO("-->pkt_len: %d\n", pattrib->pkt_len);
+			RTW_INFO("-->Sub Type = 0x%X\n", get_frame_sub_type(wlanhdr));
 		}
 
 		/* Dump first 40 bytes of header */
 		int i = 0;
 
 		for (i = 0; i < 40; i++)
-			DBG_871X("%d: %X\n", i, *((u8 *)wlanhdr + i));
+			RTW_INFO("%d: %X\n", i, *((u8 *)wlanhdr + i));
 
-		DBG_871X("\n");
+		RTW_INFO("\n");
 #endif
 
 		if ((start_time == 0) || (rtw_get_passing_time_ms(start_time) > 5000)) {
-			DBG_871X_LEVEL(_drv_always_, "Warning!!! %s: Confilc mac addr!!\n", __func__);
+			RTW_PRINT("Warning!!! %s: Confilc mac addr!!\n", __func__);
 			start_time = rtw_get_current_time();
 		}
-		pdbgpriv->dbg_rx_conflic_mac_addr_cnt++;
-	} else{
+		precvpriv->dbg_rx_conflic_mac_addr_cnt++;
+	} else {
 		pstapriv = &padapter->stapriv;
-		psta = rtw_get_stainfo(pstapriv, sa);
+		psta = rtw_get_stainfo(pstapriv, ta);
 		if (psta)
-			pkt_info.StationID = psta->mac_id;
+			pkt_info.station_id = psta->cmn.mac_id;
+	}
+
+	pkt_info.is_packet_match_bssid = (!IsFrameTypeCtrl(wlanhdr))
+		&& (!pattrib->icv_err) && (!pattrib->crc_err)
+		&& ((!MLME_IS_MESH(padapter) && _rtw_memcmp(get_hdr_bssid(wlanhdr), get_bssid(&padapter->mlmepriv), ETH_ALEN))
+			|| (MLME_IS_MESH(padapter) && psta));
+
+	pkt_info.is_to_self = (!pattrib->icv_err) && (!pattrib->crc_err)
+		&& _rtw_memcmp(ra, adapter_mac_addr(padapter), ETH_ALEN);
+
+	pkt_info.is_packet_to_self = pkt_info.is_packet_match_bssid
+		&& _rtw_memcmp(ra, adapter_mac_addr(padapter), ETH_ALEN);
+
+	pkt_info.is_packet_beacon = pkt_info.is_packet_match_bssid
+				 && (get_frame_sub_type(wlanhdr) == WIFI_BEACON);
+
+	if (psta && IsFrameTypeData(wlanhdr)) {
+		if (is_ra_bmc)
+			psta->curr_rx_rate_bmc = pattrib->data_rate;
+		else
+			psta->curr_rx_rate = pattrib->data_rate;
 	}
+	pkt_info.data_rate = pattrib->data_rate;
 
-	pkt_info.DataRate = pattrib->data_rate;
+	odm_phy_status_query(&pHalData->odmpriv, p_phy_info, pphy_status, &pkt_info);
 
-	//_enter_critical_bh(&pHalData->odm_stainfo_lock, &irqL);
-	ODM_PhyStatusQuery(&pHalData->odmpriv, pPHYInfo, pphy_status, &pkt_info);
-	if (psta)
-		psta->rssi = pattrib->phy_info.RecvSignalPower;
-	//_exit_critical_bh(&pHalData->odm_stainfo_lock, &irqL);
+	/* If bw is initial value, get from phy status */
+	if (pattrib->bw == CHANNEL_WIDTH_MAX)
+		pattrib->bw = p_phy_info->band_width;
 
 	{
 		precvframe->u.hdr.psta = NULL;
-		if (pkt_info.bPacketMatchBSSID
-			&& (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
+		if ((!MLME_IS_MESH(padapter) && pkt_info.is_packet_match_bssid)
+			|| (MLME_IS_MESH(padapter) && psta)
+			|| padapter->registrypriv.mp_mode == 1
 		) {
 			if (psta) {
 				precvframe->u.hdr.psta = psta;
 				rx_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->u.hdr.psta = psta;
-			}
+		} else if (pkt_info.is_packet_to_self || pkt_info.is_packet_beacon) {
+
+			if (psta)
+				precvframe->u.hdr.psta = psta;
 			rx_process_phy_info(padapter, precvframe);
 		}
 	}
+
+	rtw_odm_parse_rx_phy_status_chinfo(precvframe, pphy_status);
 }
 /*
 * Increase and check if the continual_no_rx_packet of this @param pmlmepriv is larger than MAX_CONTINUAL_NORXPACKET_COUNT
@@ -4964,13 +4818,13 @@ void rx_query_phy_status(
 */
 int rtw_inc_and_chk_continual_no_rx_packet(struct sta_info *sta, int tid_index)
 {
-	
+
 	int ret = _FALSE;
 	int value = ATOMIC_INC_RETURN(&sta->continual_no_rx_packet[tid_index]);
 
-	if (value >= MAX_CONTINUAL_NORXPACKET_COUNT) 
+	if (value >= MAX_CONTINUAL_NORXPACKET_COUNT)
 		ret = _TRUE;
-	
+
 	return ret;
 }
 
@@ -4978,8 +4832,65 @@ int rtw_inc_and_chk_continual_no_rx_packet(struct sta_info *sta, int tid_index)
 * Set the continual_no_rx_packet of this @param pmlmepriv to 0
 */
 void rtw_reset_continual_no_rx_packet(struct sta_info *sta, int tid_index)
-{	
-	ATOMIC_SET(&sta->continual_no_rx_packet[tid_index], 0);	
+{
+	ATOMIC_SET(&sta->continual_no_rx_packet[tid_index], 0);
+}
+
+u8 adapter_allow_bmc_data_rx(_adapter *adapter)
+{
+	if (check_fwstate(&adapter->mlmepriv, WIFI_MONITOR_STATE | WIFI_MP_STATE) == _TRUE)
+		return 1;
+
+	if (MLME_IS_AP(adapter))
+		return 0;
+
+	if (rtw_linked_check(adapter) == _FALSE)
+		return 0;
+
+	return 1;
+}
+
+s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status)
+{
+	s32 ret = _SUCCESS;
+	u8 *pbuf = precvframe->u.hdr.rx_data;
+	u8 *pda = get_ra(pbuf);
+	u8 ra_is_bmc = IS_MCAST(pda);
+#ifdef CONFIG_CONCURRENT_MODE
+	_adapter *iface = NULL;
+	_adapter *primary_padapter = precvframe->u.hdr.adapter;
+
+	#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(primary_padapter))
+		goto bypass_concurrent_hdl;
+	#endif
+
+	if (ra_is_bmc == _FALSE) { /*unicast packets*/
+		iface = rtw_get_iface_by_macddr(primary_padapter , pda);
+		if (NULL == iface) {
+			RTW_INFO("%s [WARN] Cannot find appropriate adapter - mac_addr : "MAC_FMT"\n", __func__, MAC_ARG(pda));
+			/*rtw_warn_on(1);*/
+		} else
+			precvframe->u.hdr.adapter = iface;
+	} else   /* Handle BC/MC Packets	*/
+		rtw_mi_buddy_clone_bcmc_packet(primary_padapter, precvframe, pphy_status);
+bypass_concurrent_hdl:
+#endif /* CONFIG_CONCURRENT_MODE */
+
+	/* skip unnecessary bmc data frame for primary adapter */
+	if (ra_is_bmc == _TRUE && GetFrameType(pbuf) == WIFI_DATA_TYPE
+		&& !adapter_allow_bmc_data_rx(precvframe->u.hdr.adapter)
+	) {
+		rtw_free_recvframe(precvframe, &precvframe->u.hdr.adapter->recvpriv.free_recv_queue);
+		goto exit;
+	}
+
+	if (pphy_status)
+		rx_query_phy_status(precvframe, pphy_status);
+	ret = rtw_recv_entry(precvframe);
+
+exit:
+	return ret;
 }
 
 #ifdef CONFIG_RECV_THREAD_MODE
@@ -4988,7 +4899,11 @@ thread_return rtw_recv_thread(thread_context context)
 	_adapter *adapter = (_adapter *)context;
 	struct recv_priv *recvpriv = &adapter->recvpriv;
 	s32 err = _SUCCESS;
+#ifdef PLATFORM_LINUX
+	struct sched_param param = { .sched_priority = 1 };
 
+	sched_setscheduler(current, SCHED_FIFO, &param);
+#endif /* PLATFORM_LINUX */
 	thread_enter("RTW_RECV_THREAD");
 
 	RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(adapter));
@@ -5001,8 +4916,10 @@ thread_return rtw_recv_thread(thread_context context)
 		}
 
 		if (RTW_CANNOT_RUN(adapter)) {
-			RTW_INFO(FUNC_ADPT_FMT" DS:%d, SR:%d\n", FUNC_ADPT_ARG(adapter)
-				, rtw_is_drv_stopped(adapter), rtw_is_surprise_removed(adapter));
+			RTW_DBG(FUNC_ADPT_FMT "- bDriverStopped(%s) bSurpriseRemoved(%s)\n",
+				FUNC_ADPT_ARG(adapter),
+				rtw_is_drv_stopped(adapter) ? "True" : "False",
+				rtw_is_surprise_removed(adapter) ? "True" : "False");
 			goto exit;
 		}
 
@@ -5020,9 +4937,62 @@ thread_return rtw_recv_thread(thread_context context)
 	} while (err != _FAIL);
 
 exit:
-	_rtw_up_sema(&adapter->recvpriv.terminate_recvthread_sema);
-	RTW_INFO(FUNC_ADPT_FMT" exit\n", FUNC_ADPT_ARG(adapter));
-	thread_exit();
+
+	RTW_INFO(FUNC_ADPT_FMT " Exit\n", FUNC_ADPT_ARG(adapter));
+
+	rtw_thread_wait_stop();
+
+	return 0;
 }
 #endif /* CONFIG_RECV_THREAD_MODE */
 
+#if DBG_RX_BH_TRACKING
+void rx_bh_tk_set_stage(struct recv_priv *recv, u32 s)
+{
+	recv->rx_bh_stage = s;
+}
+
+void rx_bh_tk_set_buf(struct recv_priv *recv, void *buf, void *data, u32 dlen)
+{
+	if (recv->rx_bh_cbuf)
+		recv->rx_bh_lbuf = recv->rx_bh_cbuf;
+	recv->rx_bh_cbuf = buf;
+	if (buf) {
+		recv->rx_bh_cbuf_data = data;
+		recv->rx_bh_cbuf_dlen = dlen;
+		recv->rx_bh_buf_dq_cnt++;
+	} else {
+		recv->rx_bh_cbuf_data = NULL;
+		recv->rx_bh_cbuf_dlen = 0;
+	}
+}
+
+void rx_bh_tk_set_buf_pos(struct recv_priv *recv, void *pos)
+{
+	if (recv->rx_bh_cbuf) {
+		recv->rx_bh_cbuf_pos = pos - recv->rx_bh_cbuf_data;
+	} else {
+		rtw_warn_on(1);
+		recv->rx_bh_cbuf_pos = 0;
+	}
+}
+
+void rx_bh_tk_set_frame(struct recv_priv *recv, void *frame)
+{
+	recv->rx_bh_cframe = frame;
+}
+
+void dump_rx_bh_tk(void *sel, struct recv_priv *recv)
+{
+	RTW_PRINT_SEL(sel, "[RXBHTK]s:%u, buf_dqc:%u, lbuf:%p, cbuf:%p, dlen:%u, pos:%u, cframe:%p\n"
+		, recv->rx_bh_stage
+		, recv->rx_bh_buf_dq_cnt
+		, recv->rx_bh_lbuf
+		, recv->rx_bh_cbuf
+		, recv->rx_bh_cbuf_dlen
+		, recv->rx_bh_cbuf_pos
+		, recv->rx_bh_cframe
+	);
+}
+#endif /* DBG_RX_BH_TRACKING */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rf.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rf.c
index 4d80673f74e0..899f500b666e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rf.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_RF_C_
 
 #include <drv_types.h>
@@ -514,22 +510,24 @@ exit:
 	return valid;
 }
 
-const char *const _ch_width_str[] = {
+const char *const _ch_width_str[CHANNEL_WIDTH_MAX] = {
 	"20MHz",
 	"40MHz",
 	"80MHz",
 	"160MHz",
 	"80_80MHz",
-	"CHANNEL_WIDTH_MAX",
+	"5MHz",
+	"10MHz",
 };
 
-const u8 _ch_width_to_bw_cap[] = {
+const u8 _ch_width_to_bw_cap[CHANNEL_WIDTH_MAX] = {
 	BW_CAP_20M,
 	BW_CAP_40M,
 	BW_CAP_80M,
 	BW_CAP_160M,
 	BW_CAP_80_80M,
-	0,
+	BW_CAP_5M,
+	BW_CAP_10M,
 };
 
 const char *const _band_str[] = {
@@ -546,6 +544,30 @@ const u8 _band_to_band_cap[] = {
 	0,
 };
 
+const u8 _rf_type_to_rf_tx_cnt[] = {
+	1, /*RF_1T1R*/
+	1, /*RF_1T2R*/
+	2, /*RF_2T2R*/
+	2, /*RF_2T3R*/
+	2, /*RF_2T4R*/
+	3, /*RF_3T3R*/
+	3, /*RF_3T4R*/
+	4, /*RF_4T4R*/
+	1, /*RF_TYPE_MAX*/
+};
+
+const u8 _rf_type_to_rf_rx_cnt[] = {
+	1, /*RF_1T1R*/
+	2, /*RF_1T2R*/
+	2, /*RF_2T2R*/
+	3, /*RF_2T3R*/
+	4, /*RF_2T4R*/
+	3, /*RF_3T3R*/
+	4, /*RF_3T4R*/
+	4, /*RF_4T4R*/
+	1, /*RF_TYPE_MAX*/
+};
+
 #ifdef CONFIG_80211AC_VHT
 #define COUNTRY_CHPLAN_ASSIGN_EN_11AC(_val) , .en_11ac = (_val)
 #else
@@ -571,57 +593,160 @@ const u8 _band_to_band_cap[] = {
 
 #elif RTW_DEF_MODULE_REGULATORY_CERT
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AE_HMC_M2)
-static const struct country_chplan RTL8821AE_HMC_M2_country_chplan_map[] = {
-	COUNTRY_CHPLAN_ENT("CN", 0x51, 1, 0xFB), /* China */
-	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0xFB), /* Russia(fac/gost), Kaliningrad */
-	COUNTRY_CHPLAN_ENT("UA", 0x26, 0, 0xFB), /* Ukraine */
+/* leave def_module_flags empty, def_module_flags check is done on country_chplan_map */
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AE_HMC_M2) /* 2013 certify */
+static const struct country_chplan RTL8821AE_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CL", 0x30, 1, 0), /* Chile */
+	COUNTRY_CHPLAN_ENT("CN", 0x51, 1, 0), /* China */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("MY", 0x47, 1, 0), /* Malaysia */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
 };
-static const u16 RTL8821AE_HMC_M2_country_chplan_map_sz = sizeof(RTL8821AE_HMC_M2_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AU)
-static const struct country_chplan RTL8821AU_country_chplan_map[] = {
-	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0xFB), /* Russia(fac/gost), Kaliningrad */
-	COUNTRY_CHPLAN_ENT("UA", 0x26, 0, 0xFB), /* Ukraine */
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AU) /* 2014 certify */
+static const struct country_chplan RTL8821AU_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0), /* Russia(fac/gost), Kaliningrad */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
 };
-static const u16 RTL8821AU_country_chplan_map_sz = sizeof(RTL8821AU_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AENF_NGFF)
-static const struct country_chplan RTL8812AENF_NGFF_country_chplan_map[] = {
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AENF_NGFF) /* 2014 certify */
+static const struct country_chplan RTL8812AENF_NGFF_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
 };
-static const u16 RTL8812AENF_NGFF_country_chplan_map_sz = sizeof(RTL8812AENF_NGFF_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AEBT_HMC)
-static const struct country_chplan RTL8812AEBT_HMC_country_chplan_map[] = {
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AEBT_HMC) /* 2013 certify */
+static const struct country_chplan RTL8812AEBT_HMC_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0), /* Russia(fac/gost), Kaliningrad */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
 };
-static const u16 RTL8812AEBT_HMC_country_chplan_map_sz = sizeof(RTL8812AEBT_HMC_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8188EE_HMC_M2)
-static const struct country_chplan RTL8188EE_HMC_M2_country_chplan_map[] = {
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8188EE_HMC_M2) /* 2012 certify */
+static const struct country_chplan RTL8188EE_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0), /* Barbados */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0), /* Haiti */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0), /* Seychelles */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+	COUNTRY_CHPLAN_ENT("VC", 0x34, 1, 0), /* Saint Vincent and the Grenadines */
 };
-static const u16 RTL8188EE_HMC_M2_country_chplan_map_sz = sizeof(RTL8188EE_HMC_M2_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BE_HMC_M2)
-static const struct country_chplan RTL8723BE_HMC_M2_country_chplan_map[] = {
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BE_HMC_M2) /* 2013 certify */
+static const struct country_chplan RTL8723BE_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("BS", 0x34, 1, 0), /* Bahamas */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
 };
-static const u16 RTL8723BE_HMC_M2_country_chplan_map_sz = sizeof(RTL8723BE_HMC_M2_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BS_NGFF1216)
-static const struct country_chplan RTL8723BS_NGFF1216_country_chplan_map[] = {
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BS_NGFF1216) /* 2014 certify */
+static const struct country_chplan RTL8723BS_NGFF1216_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0), /* Barbados */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0), /* Haiti */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
 };
-static const u16 RTL8723BS_NGFF1216_country_chplan_map_sz = sizeof(RTL8723BS_NGFF1216_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8192EEBT_HMC_M2)
-static const struct country_chplan RTL8192EEBT_HMC_M2_country_chplan_map[] = {
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8192EEBT_HMC_M2) /* 2013 certify */
+static const struct country_chplan RTL8192EEBT_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0), /* Seychelles */
+	COUNTRY_CHPLAN_ENT("ST", 0x34, 1, 0), /* Sao Tome and Principe */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723DE_NGFF1630) /* 2016 certify */
+static const struct country_chplan RTL8723DE_NGFF1630_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x2A, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8822BE) /* 2016 certify */
+static const struct country_chplan RTL8822BE_country_chplan_exc_map[] = {
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821CE) /* 2016 certify */
+static const struct country_chplan RTL8821CE_country_chplan_exc_map[] = {
 };
-static const u16 RTL8192EEBT_HMC_M2_country_chplan_map_sz = sizeof(RTL8192EEBT_HMC_M2_country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
 /**
@@ -639,29 +764,38 @@ static const struct country_chplan *rtw_def_module_get_chplan_from_country(const
 
 	/* TODO: runtime selection for multi driver */
 #if (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AE_HMC_M2)
-	hal_map = RTL8821AE_HMC_M2_country_chplan_map;
-	hal_map_sz = RTL8821AE_HMC_M2_country_chplan_map_sz;
+	hal_map = RTL8821AE_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8821AE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
 #elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AU)
-	hal_map = RTL8821AU_country_chplan_map;
-	hal_map_sz = RTL8821AU_country_chplan_map_sz;
+	hal_map = RTL8821AU_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8821AU_country_chplan_exc_map) / sizeof(struct country_chplan);
 #elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AENF_NGFF)
-	hal_map = RTL8812AENF_NGFF_country_chplan_map;
-	hal_map_sz = RTL8812AENF_NGFF_country_chplan_map_sz;
+	hal_map = RTL8812AENF_NGFF_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8812AENF_NGFF_country_chplan_exc_map) / sizeof(struct country_chplan);
 #elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AEBT_HMC)
-	hal_map = RTL8812AEBT_HMC_country_chplan_map;
-	hal_map_sz = RTL8812AEBT_HMC_country_chplan_map_sz;
+	hal_map = RTL8812AEBT_HMC_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8812AEBT_HMC_country_chplan_exc_map) / sizeof(struct country_chplan);
 #elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8188EE_HMC_M2)
-	hal_map = RTL8188EE_HMC_M2_country_chplan_map;
-	hal_map_sz = RTL8188EE_HMC_M2_country_chplan_map_sz;
+	hal_map = RTL8188EE_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8188EE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
 #elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BE_HMC_M2)
-	hal_map = RTL8723BE_HMC_M2_country_chplan_map;
-	hal_map_sz = RTL8723BE_HMC_M2_country_chplan_map_sz;
+	hal_map = RTL8723BE_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8723BE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
 #elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BS_NGFF1216)
-	hal_map = RTL8723BS_NGFF1216_country_chplan_map;
-	hal_map_sz = RTL8723BS_NGFF1216_country_chplan_map_sz;
+	hal_map = RTL8723BS_NGFF1216_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8723BS_NGFF1216_country_chplan_exc_map) / sizeof(struct country_chplan);
 #elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8192EEBT_HMC_M2)
-	hal_map = RTL8192EEBT_HMC_M2_country_chplan_map;
-	hal_map_sz = RTL8192EEBT_HMC_M2_country_chplan_map_sz;
+	hal_map = RTL8192EEBT_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8192EEBT_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723DE_NGFF1630)
+	hal_map = RTL8723DE_NGFF1630_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8723DE_NGFF1630_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8822BE)
+	hal_map = RTL8822BE_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8822BE_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821CE)
+	hal_map = RTL8821CE_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8821CE_country_chplan_exc_map) / sizeof(struct country_chplan);
 #endif
 
 	if (hal_map == NULL || hal_map_sz == 0)
@@ -680,239 +814,238 @@ exit:
 #endif /* CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP or RTW_DEF_MODULE_REGULATORY_CERT */
 
 static const struct country_chplan country_chplan_map[] = {
-	COUNTRY_CHPLAN_ENT("AD", 0x26, 1, 0x00), /* Andorra */
-	COUNTRY_CHPLAN_ENT("AE", 0x26, 1, 0xFB), /* United Arab Emirates */
-	COUNTRY_CHPLAN_ENT("AF", 0x42, 1, 0x00), /* Afghanistan */
-	COUNTRY_CHPLAN_ENT("AG", 0x30, 1, 0x00), /* Antigua & Barbuda */
-	COUNTRY_CHPLAN_ENT("AI", 0x26, 1, 0x00), /* Anguilla(UK) */
-	COUNTRY_CHPLAN_ENT("AL", 0x26, 1, 0xF1), /* Albania */
-	COUNTRY_CHPLAN_ENT("AM", 0x26, 1, 0xB0), /* Armenia */
-	COUNTRY_CHPLAN_ENT("AO", 0x26, 1, 0xE0), /* Angola */
-	COUNTRY_CHPLAN_ENT("AQ", 0x26, 1, 0x00), /* Antarctica */
-	COUNTRY_CHPLAN_ENT("AR", 0x57, 1, 0xF3), /* Argentina */
-	COUNTRY_CHPLAN_ENT("AS", 0x34, 1, 0x00), /* American Samoa */
-	COUNTRY_CHPLAN_ENT("AT", 0x26, 1, 0xFB), /* Austria */
-	COUNTRY_CHPLAN_ENT("AU", 0x45, 1, 0xFB), /* Australia */
-	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0xB0), /* Aruba */
-	COUNTRY_CHPLAN_ENT("AZ", 0x26, 1, 0xF1), /* Azerbaijan */
-	COUNTRY_CHPLAN_ENT("BA", 0x26, 1, 0xF1), /* Bosnia & Herzegovina */
-	COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0x50), /* Barbados */
-	COUNTRY_CHPLAN_ENT("BD", 0x26, 1, 0xF1), /* Bangladesh */
-	COUNTRY_CHPLAN_ENT("BE", 0x26, 1, 0xFB), /* Belgium */
-	COUNTRY_CHPLAN_ENT("BF", 0x26, 1, 0xB0), /* Burkina Faso */
-	COUNTRY_CHPLAN_ENT("BG", 0x26, 1, 0xF1), /* Bulgaria */
-	COUNTRY_CHPLAN_ENT("BH", 0x47, 1, 0xF1), /* Bahrain */
-	COUNTRY_CHPLAN_ENT("BI", 0x26, 1, 0xB0), /* Burundi */
-	COUNTRY_CHPLAN_ENT("BJ", 0x26, 1, 0xB0), /* Benin */
-	COUNTRY_CHPLAN_ENT("BN", 0x47, 1, 0x10), /* Brunei */
-	COUNTRY_CHPLAN_ENT("BO", 0x30, 1, 0xF1), /* Bolivia */
-	COUNTRY_CHPLAN_ENT("BR", 0x34, 1, 0xF1), /* Brazil */
-	COUNTRY_CHPLAN_ENT("BS", 0x34, 1, 0x20), /* Bahamas */
-	COUNTRY_CHPLAN_ENT("BW", 0x26, 1, 0xF1), /* Botswana */
-	COUNTRY_CHPLAN_ENT("BY", 0x26, 1, 0xF1), /* Belarus */
-	COUNTRY_CHPLAN_ENT("BZ", 0x34, 1, 0x00), /* Belize */
-	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0xFB), /* Canada */
-	COUNTRY_CHPLAN_ENT("CC", 0x26, 1, 0x00), /* Cocos (Keeling) Islands (Australia) */
-	COUNTRY_CHPLAN_ENT("CD", 0x26, 1, 0xB0), /* Congo, Republic of the */
-	COUNTRY_CHPLAN_ENT("CF", 0x26, 1, 0xB0), /* Central African Republic */
-	COUNTRY_CHPLAN_ENT("CG", 0x26, 1, 0xB0), /* Congo, Democratic Republic of the. Zaire */
-	COUNTRY_CHPLAN_ENT("CH", 0x26, 1, 0xFB), /* Switzerland */
-	COUNTRY_CHPLAN_ENT("CI", 0x26, 1, 0xF1), /* Cote d'Ivoire */
-	COUNTRY_CHPLAN_ENT("CK", 0x26, 1, 0x00), /* Cook Islands */
-	COUNTRY_CHPLAN_ENT("CL", 0x30, 1, 0xF1), /* Chile */
-	COUNTRY_CHPLAN_ENT("CM", 0x26, 1, 0xB0), /* Cameroon */
-	COUNTRY_CHPLAN_ENT("CN", 0x48, 1, 0xFB), /* China */
-	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0xF1), /* Colombia */
-	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0xF1), /* Costa Rica */
-	COUNTRY_CHPLAN_ENT("CV", 0x26, 1, 0xB0), /* Cape Verde */
-	COUNTRY_CHPLAN_ENT("CX", 0x45, 1, 0x00), /* Christmas Island (Australia) */
-	COUNTRY_CHPLAN_ENT("CY", 0x26, 1, 0xFB), /* Cyprus */
-	COUNTRY_CHPLAN_ENT("CZ", 0x26, 1, 0xFB), /* Czech Republic */
-	COUNTRY_CHPLAN_ENT("DE", 0x26, 1, 0xFB), /* Germany */
-	COUNTRY_CHPLAN_ENT("DJ", 0x26, 1, 0x80), /* Djibouti */
-	COUNTRY_CHPLAN_ENT("DK", 0x26, 1, 0xFB), /* Denmark */
-	COUNTRY_CHPLAN_ENT("DM", 0x34, 1, 0x00), /* Dominica */
-	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0xF1), /* Dominican Republic */
-	COUNTRY_CHPLAN_ENT("DZ", 0x26, 1, 0xF1), /* Algeria */
-	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0xF1), /* Ecuador */
-	COUNTRY_CHPLAN_ENT("EE", 0x26, 1, 0xFB), /* Estonia */
-	COUNTRY_CHPLAN_ENT("EG", 0x47, 0, 0xF1), /* Egypt */
-	COUNTRY_CHPLAN_ENT("EH", 0x47, 1, 0x80), /* Western Sahara */
-	COUNTRY_CHPLAN_ENT("ER", 0x26, 1, 0x00), /* Eritrea */
-	COUNTRY_CHPLAN_ENT("ES", 0x26, 1, 0xFB), /* Spain, Canary Islands, Ceuta, Melilla */
-	COUNTRY_CHPLAN_ENT("ET", 0x26, 1, 0xB0), /* Ethiopia */
-	COUNTRY_CHPLAN_ENT("FI", 0x26, 1, 0xFB), /* Finland */
-	COUNTRY_CHPLAN_ENT("FJ", 0x34, 1, 0x00), /* Fiji */
-	COUNTRY_CHPLAN_ENT("FK", 0x26, 1, 0x00), /* Falkland Islands (Islas Malvinas) (UK) */
-	COUNTRY_CHPLAN_ENT("FM", 0x34, 1, 0x00), /* Micronesia, Federated States of (USA) */
-	COUNTRY_CHPLAN_ENT("FO", 0x26, 1, 0x00), /* Faroe Islands (Denmark) */
-	COUNTRY_CHPLAN_ENT("FR", 0x26, 1, 0xFB), /* France */
-	COUNTRY_CHPLAN_ENT("GA", 0x26, 1, 0xB0), /* Gabon */
-	COUNTRY_CHPLAN_ENT("GB", 0x26, 1, 0xFB), /* Great Britain (United Kingdom; England) */
-	COUNTRY_CHPLAN_ENT("GD", 0x34, 1, 0xB0), /* Grenada */
-	COUNTRY_CHPLAN_ENT("GE", 0x26, 1, 0x00), /* Georgia */
-	COUNTRY_CHPLAN_ENT("GF", 0x26, 1, 0x80), /* French Guiana */
-	COUNTRY_CHPLAN_ENT("GG", 0x26, 1, 0x00), /* Guernsey (UK) */
-	COUNTRY_CHPLAN_ENT("GH", 0x26, 1, 0xF1), /* Ghana */
-	COUNTRY_CHPLAN_ENT("GI", 0x26, 1, 0x00), /* Gibraltar (UK) */
-	COUNTRY_CHPLAN_ENT("GL", 0x26, 1, 0x00), /* Greenland (Denmark) */
-	COUNTRY_CHPLAN_ENT("GM", 0x26, 1, 0xB0), /* Gambia */
-	COUNTRY_CHPLAN_ENT("GN", 0x26, 1, 0x10), /* Guinea */
-	COUNTRY_CHPLAN_ENT("GP", 0x26, 1, 0x00), /* Guadeloupe (France) */
-	COUNTRY_CHPLAN_ENT("GQ", 0x26, 1, 0xB0), /* Equatorial Guinea */
-	COUNTRY_CHPLAN_ENT("GR", 0x26, 1, 0xFB), /* Greece */
-	COUNTRY_CHPLAN_ENT("GS", 0x26, 1, 0x00), /* South Georgia and the Sandwich Islands (UK) */
-	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0xF1), /* Guatemala */
-	COUNTRY_CHPLAN_ENT("GU", 0x34, 1, 0x00), /* Guam (USA) */
-	COUNTRY_CHPLAN_ENT("GW", 0x26, 1, 0xB0), /* Guinea-Bissau */
-	COUNTRY_CHPLAN_ENT("GY", 0x44, 1, 0x00), /* Guyana */
-	COUNTRY_CHPLAN_ENT("HK", 0x26, 1, 0xFB), /* Hong Kong */
-	COUNTRY_CHPLAN_ENT("HM", 0x45, 1, 0x00), /* Heard and McDonald Islands (Australia) */
-	COUNTRY_CHPLAN_ENT("HN", 0x32, 1, 0xF1), /* Honduras */
-	COUNTRY_CHPLAN_ENT("HR", 0x26, 1, 0xF9), /* Croatia */
-	COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0x50), /* Haiti */
-	COUNTRY_CHPLAN_ENT("HU", 0x26, 1, 0xFB), /* Hungary */
-	COUNTRY_CHPLAN_ENT("ID", 0x54, 0, 0xF3), /* Indonesia */
-	COUNTRY_CHPLAN_ENT("IE", 0x26, 1, 0xFB), /* Ireland */
-	COUNTRY_CHPLAN_ENT("IL", 0x47, 1, 0xF1), /* Israel */
-	COUNTRY_CHPLAN_ENT("IM", 0x26, 1, 0x00), /* Isle of Man (UK) */
-	COUNTRY_CHPLAN_ENT("IN", 0x47, 1, 0xF1), /* India */
-	COUNTRY_CHPLAN_ENT("IQ", 0x26, 1, 0x00), /* Iraq */
-	COUNTRY_CHPLAN_ENT("IR", 0x26, 0, 0x00), /* Iran */
-	COUNTRY_CHPLAN_ENT("IS", 0x26, 1, 0xFB), /* Iceland */
-	COUNTRY_CHPLAN_ENT("IT", 0x26, 1, 0xFB), /* Italy */
-	COUNTRY_CHPLAN_ENT("JE", 0x26, 1, 0x00), /* Jersey (UK) */
-	COUNTRY_CHPLAN_ENT("JM", 0x51, 1, 0xF1), /* Jamaica */
-	COUNTRY_CHPLAN_ENT("JO", 0x49, 1, 0xFB), /* Jordan */
-	COUNTRY_CHPLAN_ENT("JP", 0x27, 1, 0xFF), /* Japan- Telec */
-	COUNTRY_CHPLAN_ENT("KE", 0x47, 1, 0xF9), /* Kenya */
-	COUNTRY_CHPLAN_ENT("KG", 0x26, 1, 0xF1), /* Kyrgyzstan */
-	COUNTRY_CHPLAN_ENT("KH", 0x26, 1, 0xF1), /* Cambodia */
-	COUNTRY_CHPLAN_ENT("KI", 0x26, 1, 0x00), /* Kiribati */
-	COUNTRY_CHPLAN_ENT("KN", 0x34, 1, 0x00), /* Saint Kitts and Nevis */
-	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0xFB), /* South Korea */
-	COUNTRY_CHPLAN_ENT("KW", 0x47, 1, 0xFB), /* Kuwait */
-	COUNTRY_CHPLAN_ENT("KY", 0x34, 1, 0x00), /* Cayman Islands (UK) */
-	COUNTRY_CHPLAN_ENT("KZ", 0x26, 1, 0x00), /* Kazakhstan */
-	COUNTRY_CHPLAN_ENT("LA", 0x26, 1, 0x00), /* Laos */
-	COUNTRY_CHPLAN_ENT("LB", 0x26, 1, 0xF1), /* Lebanon */
-	COUNTRY_CHPLAN_ENT("LC", 0x34, 1, 0x00), /* Saint Lucia */
-	COUNTRY_CHPLAN_ENT("LI", 0x26, 1, 0xFB), /* Liechtenstein */
-	COUNTRY_CHPLAN_ENT("LK", 0x26, 1, 0xF1), /* Sri Lanka */
-	COUNTRY_CHPLAN_ENT("LR", 0x26, 1, 0xB0), /* Liberia */
-	COUNTRY_CHPLAN_ENT("LS", 0x26, 1, 0xF1), /* Lesotho */
-	COUNTRY_CHPLAN_ENT("LT", 0x26, 1, 0xFB), /* Lithuania */
-	COUNTRY_CHPLAN_ENT("LU", 0x26, 1, 0xFB), /* Luxembourg */
-	COUNTRY_CHPLAN_ENT("LV", 0x26, 1, 0xFB), /* Latvia */
-	COUNTRY_CHPLAN_ENT("LY", 0x26, 1, 0x00), /* Libya */
-	COUNTRY_CHPLAN_ENT("MA", 0x47, 1, 0xF1), /* Morocco */
-	COUNTRY_CHPLAN_ENT("MC", 0x26, 1, 0xFB), /* Monaco */
-	COUNTRY_CHPLAN_ENT("MD", 0x26, 1, 0xF1), /* Moldova */
-	COUNTRY_CHPLAN_ENT("ME", 0x26, 1, 0xF1), /* Montenegro */
-	COUNTRY_CHPLAN_ENT("MF", 0x34, 1, 0x00), /* Saint Martin */
-	COUNTRY_CHPLAN_ENT("MG", 0x26, 1, 0x20), /* Madagascar */
-	COUNTRY_CHPLAN_ENT("MH", 0x34, 1, 0x00), /* Marshall Islands (USA) */
-	COUNTRY_CHPLAN_ENT("MK", 0x26, 1, 0xF1), /* Republic of Macedonia (FYROM) */
-	COUNTRY_CHPLAN_ENT("ML", 0x26, 1, 0xB0), /* Mali */
-	COUNTRY_CHPLAN_ENT("MM", 0x26, 1, 0x00), /* Burma (Myanmar) */
-	COUNTRY_CHPLAN_ENT("MN", 0x26, 1, 0x00), /* Mongolia */
-	COUNTRY_CHPLAN_ENT("MO", 0x26, 1, 0x00), /* Macau */
-	COUNTRY_CHPLAN_ENT("MP", 0x34, 1, 0x00), /* Northern Mariana Islands (USA) */
-	COUNTRY_CHPLAN_ENT("MQ", 0x26, 1, 0x40), /* Martinique (France) */
-	COUNTRY_CHPLAN_ENT("MR", 0x26, 1, 0xA0), /* Mauritania */
-	COUNTRY_CHPLAN_ENT("MS", 0x26, 1, 0x00), /* Montserrat (UK) */
-	COUNTRY_CHPLAN_ENT("MT", 0x26, 1, 0xFB), /* Malta */
-	COUNTRY_CHPLAN_ENT("MU", 0x26, 1, 0xB0), /* Mauritius */
-	COUNTRY_CHPLAN_ENT("MV", 0x26, 1, 0x00), /* Maldives */
-	COUNTRY_CHPLAN_ENT("MW", 0x26, 1, 0xB0), /* Malawi */
-	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0xF1), /* Mexico */
-	COUNTRY_CHPLAN_ENT("MY", 0x47, 1, 0xF1), /* Malaysia */
-	COUNTRY_CHPLAN_ENT("MZ", 0x26, 1, 0xF1), /* Mozambique */
-	COUNTRY_CHPLAN_ENT("NA", 0x26, 0, 0x00), /* Namibia */
-	COUNTRY_CHPLAN_ENT("NC", 0x26, 1, 0x00), /* New Caledonia */
-	COUNTRY_CHPLAN_ENT("NE", 0x26, 1, 0xB0), /* Niger */
-	COUNTRY_CHPLAN_ENT("NF", 0x45, 1, 0x00), /* Norfolk Island (Australia) */
-	COUNTRY_CHPLAN_ENT("NG", 0x50, 1, 0xF9), /* Nigeria */
-	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0xF1), /* Nicaragua */
-	COUNTRY_CHPLAN_ENT("NL", 0x26, 1, 0xFB), /* Netherlands */
-	COUNTRY_CHPLAN_ENT("NO", 0x26, 1, 0xFB), /* Norway */
-	COUNTRY_CHPLAN_ENT("NP", 0x47, 1, 0xF0), /* Nepal */
-	COUNTRY_CHPLAN_ENT("NR", 0x26, 1, 0x00), /* Nauru */
-	COUNTRY_CHPLAN_ENT("NU", 0x45, 1, 0x00), /* Niue */
-	COUNTRY_CHPLAN_ENT("NZ", 0x45, 1, 0xFB), /* New Zealand */
-	COUNTRY_CHPLAN_ENT("OM", 0x26, 1, 0xF9), /* Oman */
-	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0xF1), /* Panama */
-	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0xF1), /* Peru */
-	COUNTRY_CHPLAN_ENT("PF", 0x26, 1, 0x00), /* French Polynesia (France) */
-	COUNTRY_CHPLAN_ENT("PG", 0x26, 1, 0xF1), /* Papua New Guinea */
-	COUNTRY_CHPLAN_ENT("PH", 0x26, 1, 0xF1), /* Philippines */
-	COUNTRY_CHPLAN_ENT("PK", 0x51, 1, 0xF1), /* Pakistan */
-	COUNTRY_CHPLAN_ENT("PL", 0x26, 1, 0xFB), /* Poland */
-	COUNTRY_CHPLAN_ENT("PM", 0x26, 1, 0x00), /* Saint Pierre and Miquelon (France) */
-	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0xF1), /* Puerto Rico */
-	COUNTRY_CHPLAN_ENT("PT", 0x26, 1, 0xFB), /* Portugal */
-	COUNTRY_CHPLAN_ENT("PW", 0x34, 1, 0x00), /* Palau */
-	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0xF1), /* Paraguay */
-	COUNTRY_CHPLAN_ENT("QA", 0x51, 1, 0xF9), /* Qatar */
-	COUNTRY_CHPLAN_ENT("RE", 0x26, 1, 0x00), /* Reunion (France) */
-	COUNTRY_CHPLAN_ENT("RO", 0x26, 1, 0xF1), /* Romania */
-	COUNTRY_CHPLAN_ENT("RS", 0x26, 1, 0xF1), /* Serbia, Kosovo */
-	COUNTRY_CHPLAN_ENT("RU", 0x59, 1, 0xFB), /* Russia(fac/gost), Kaliningrad */
-	COUNTRY_CHPLAN_ENT("RW", 0x26, 1, 0xB0), /* Rwanda */
-	COUNTRY_CHPLAN_ENT("SA", 0x26, 1, 0xFB), /* Saudi Arabia */
-	COUNTRY_CHPLAN_ENT("SB", 0x26, 1, 0x00), /* Solomon Islands */
-	COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0x90), /* Seychelles */
-	COUNTRY_CHPLAN_ENT("SE", 0x26, 1, 0xFB), /* Sweden */
-	COUNTRY_CHPLAN_ENT("SG", 0x47, 1, 0xFB), /* Singapore */
-	COUNTRY_CHPLAN_ENT("SH", 0x26, 1, 0x00), /* Saint Helena (UK) */
-	COUNTRY_CHPLAN_ENT("SI", 0x26, 1, 0xFB), /* Slovenia */
-	COUNTRY_CHPLAN_ENT("SJ", 0x26, 1, 0x00), /* Svalbard (Norway) */
-	COUNTRY_CHPLAN_ENT("SK", 0x26, 1, 0xFB), /* Slovakia */
-	COUNTRY_CHPLAN_ENT("SL", 0x26, 1, 0xB0), /* Sierra Leone */
-	COUNTRY_CHPLAN_ENT("SM", 0x26, 1, 0x00), /* San Marino */
-	COUNTRY_CHPLAN_ENT("SN", 0x26, 1, 0xF1), /* Senegal */
-	COUNTRY_CHPLAN_ENT("SO", 0x26, 1, 0x00), /* Somalia */
-	COUNTRY_CHPLAN_ENT("SR", 0x34, 1, 0x00), /* Suriname */
-	COUNTRY_CHPLAN_ENT("ST", 0x34, 1, 0x80), /* Sao Tome and Principe */
-	COUNTRY_CHPLAN_ENT("SV", 0x30, 1, 0xF1), /* El Salvador */
-	COUNTRY_CHPLAN_ENT("SX", 0x34, 1, 0x00), /* Sint Marteen */
-	COUNTRY_CHPLAN_ENT("SZ", 0x26, 1, 0x20), /* Swaziland */
-	COUNTRY_CHPLAN_ENT("TC", 0x26, 1, 0x00), /* Turks and Caicos Islands (UK) */
-	COUNTRY_CHPLAN_ENT("TD", 0x26, 1, 0xB0), /* Chad */
-	COUNTRY_CHPLAN_ENT("TF", 0x26, 1, 0x80), /* French Southern and Antarctic Lands (FR Southern Territories) */
-	COUNTRY_CHPLAN_ENT("TG", 0x26, 1, 0xB0), /* Togo */
-	COUNTRY_CHPLAN_ENT("TH", 0x26, 1, 0xF1), /* Thailand */
-	COUNTRY_CHPLAN_ENT("TJ", 0x26, 1, 0x40), /* Tajikistan */
-	COUNTRY_CHPLAN_ENT("TK", 0x45, 1, 0x00), /* Tokelau */
-	COUNTRY_CHPLAN_ENT("TM", 0x26, 1, 0x00), /* Turkmenistan */
-	COUNTRY_CHPLAN_ENT("TN", 0x47, 1, 0xF1), /* Tunisia */
-	COUNTRY_CHPLAN_ENT("TO", 0x26, 1, 0x00), /* Tonga */
-	COUNTRY_CHPLAN_ENT("TR", 0x26, 1, 0xF1), /* Turkey, Northern Cyprus */
-	COUNTRY_CHPLAN_ENT("TT", 0x42, 1, 0xF1), /* Trinidad & Tobago */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0xFF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("TZ", 0x26, 1, 0xF0), /* Tanzania */
-	COUNTRY_CHPLAN_ENT("UA", 0x26, 1, 0xFB), /* Ukraine */
-	COUNTRY_CHPLAN_ENT("UG", 0x26, 1, 0xF1), /* Uganda */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0xFF), /* United States of America (USA) */
-	COUNTRY_CHPLAN_ENT("UY", 0x34, 1, 0xF1), /* Uruguay */
-	COUNTRY_CHPLAN_ENT("UZ", 0x47, 1, 0xF0), /* Uzbekistan */
-	COUNTRY_CHPLAN_ENT("VA", 0x26, 1, 0x00), /* Holy See (Vatican City) */
-	COUNTRY_CHPLAN_ENT("VC", 0x34, 1, 0x10), /* Saint Vincent and the Grenadines */
-	COUNTRY_CHPLAN_ENT("VE", 0x30, 1, 0xF1), /* Venezuela */
-	COUNTRY_CHPLAN_ENT("VI", 0x34, 1, 0x00), /* United States Virgin Islands (USA) */
-	COUNTRY_CHPLAN_ENT("VN", 0x26, 1, 0xF1), /* Vietnam */
-	COUNTRY_CHPLAN_ENT("VU", 0x26, 1, 0x00), /* Vanuatu */
-	COUNTRY_CHPLAN_ENT("WF", 0x26, 1, 0x00), /* Wallis and Futuna (France) */
-	COUNTRY_CHPLAN_ENT("WS", 0x34, 1, 0x00), /* Samoa */
-	COUNTRY_CHPLAN_ENT("YE", 0x26, 1, 0x40), /* Yemen */
-	COUNTRY_CHPLAN_ENT("YT", 0x26, 1, 0x80), /* Mayotte (France) */
-	COUNTRY_CHPLAN_ENT("ZA", 0x26, 1, 0xF1), /* South Africa */
-	COUNTRY_CHPLAN_ENT("ZM", 0x26, 1, 0xB0), /* Zambia */
-	COUNTRY_CHPLAN_ENT("ZW", 0x26, 1, 0xF1), /* Zimbabwe */
+	COUNTRY_CHPLAN_ENT("AD", 0x26, 1, 0x000), /* Andorra */
+	COUNTRY_CHPLAN_ENT("AE", 0x26, 1, 0x7FB), /* United Arab Emirates */
+	COUNTRY_CHPLAN_ENT("AF", 0x42, 1, 0x000), /* Afghanistan */
+	COUNTRY_CHPLAN_ENT("AG", 0x26, 1, 0x000), /* Antigua & Barbuda */
+	COUNTRY_CHPLAN_ENT("AI", 0x26, 1, 0x000), /* Anguilla(UK) */
+	COUNTRY_CHPLAN_ENT("AL", 0x26, 1, 0x7F1), /* Albania */
+	COUNTRY_CHPLAN_ENT("AM", 0x26, 1, 0x6B0), /* Armenia */
+	COUNTRY_CHPLAN_ENT("AN", 0x26, 1, 0x7F1), /* Netherlands Antilles */
+	COUNTRY_CHPLAN_ENT("AO", 0x47, 1, 0x6E0), /* Angola */
+	COUNTRY_CHPLAN_ENT("AQ", 0x26, 1, 0x000), /* Antarctica */
+	COUNTRY_CHPLAN_ENT("AR", 0x61, 1, 0x7F3), /* Argentina */
+	COUNTRY_CHPLAN_ENT("AS", 0x76, 1, 0x000), /* American Samoa */
+	COUNTRY_CHPLAN_ENT("AT", 0x26, 1, 0x7FB), /* Austria */
+	COUNTRY_CHPLAN_ENT("AU", 0x45, 1, 0x7FB), /* Australia */
+	COUNTRY_CHPLAN_ENT("AW", 0x76, 1, 0x0B0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("AZ", 0x26, 1, 0x7F1), /* Azerbaijan */
+	COUNTRY_CHPLAN_ENT("BA", 0x26, 1, 0x7F1), /* Bosnia & Herzegovina */
+	COUNTRY_CHPLAN_ENT("BB", 0x76, 1, 0x650), /* Barbados */
+	COUNTRY_CHPLAN_ENT("BD", 0x26, 1, 0x7F1), /* Bangladesh */
+	COUNTRY_CHPLAN_ENT("BE", 0x26, 1, 0x7FB), /* Belgium */
+	COUNTRY_CHPLAN_ENT("BF", 0x26, 1, 0x6B0), /* Burkina Faso */
+	COUNTRY_CHPLAN_ENT("BG", 0x26, 1, 0x7F1), /* Bulgaria */
+	COUNTRY_CHPLAN_ENT("BH", 0x47, 1, 0x7F1), /* Bahrain */
+	COUNTRY_CHPLAN_ENT("BI", 0x26, 1, 0x6B0), /* Burundi */
+	COUNTRY_CHPLAN_ENT("BJ", 0x26, 1, 0x6B0), /* Benin */
+	COUNTRY_CHPLAN_ENT("BN", 0x47, 1, 0x610), /* Brunei */
+	COUNTRY_CHPLAN_ENT("BO", 0x73, 1, 0x7F1), /* Bolivia */
+	COUNTRY_CHPLAN_ENT("BR", 0x62, 1, 0x7F1), /* Brazil */
+	COUNTRY_CHPLAN_ENT("BS", 0x76, 1, 0x620), /* Bahamas */
+	COUNTRY_CHPLAN_ENT("BW", 0x26, 1, 0x6F1), /* Botswana */
+	COUNTRY_CHPLAN_ENT("BY", 0x26, 1, 0x7F1), /* Belarus */
+	COUNTRY_CHPLAN_ENT("BZ", 0x76, 1, 0x000), /* Belize */
+	COUNTRY_CHPLAN_ENT("CA", 0x2B, 1, 0x7FB), /* Canada */
+	COUNTRY_CHPLAN_ENT("CC", 0x26, 1, 0x000), /* Cocos (Keeling) Islands (Australia) */
+	COUNTRY_CHPLAN_ENT("CD", 0x26, 1, 0x6B0), /* Congo, Republic of the */
+	COUNTRY_CHPLAN_ENT("CF", 0x26, 1, 0x6B0), /* Central African Republic */
+	COUNTRY_CHPLAN_ENT("CG", 0x26, 1, 0x6B0), /* Congo, Democratic Republic of the. Zaire */
+	COUNTRY_CHPLAN_ENT("CH", 0x26, 1, 0x7FB), /* Switzerland */
+	COUNTRY_CHPLAN_ENT("CI", 0x26, 1, 0x7F1), /* Cote d'Ivoire */
+	COUNTRY_CHPLAN_ENT("CK", 0x26, 1, 0x000), /* Cook Islands */
+	COUNTRY_CHPLAN_ENT("CL", 0x2D, 1, 0x7F1), /* Chile */
+	COUNTRY_CHPLAN_ENT("CM", 0x26, 1, 0x6B0), /* Cameroon */
+	COUNTRY_CHPLAN_ENT("CN", 0x48, 1, 0x7FB), /* China */
+	COUNTRY_CHPLAN_ENT("CO", 0x76, 1, 0x7F1), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x76, 1, 0x7F1), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("CV", 0x26, 1, 0x6B0), /* Cape Verde */
+	COUNTRY_CHPLAN_ENT("CX", 0x45, 1, 0x000), /* Christmas Island (Australia) */
+	COUNTRY_CHPLAN_ENT("CY", 0x26, 1, 0x7FB), /* Cyprus */
+	COUNTRY_CHPLAN_ENT("CZ", 0x26, 1, 0x7FB), /* Czech Republic */
+	COUNTRY_CHPLAN_ENT("DE", 0x26, 1, 0x7FB), /* Germany */
+	COUNTRY_CHPLAN_ENT("DJ", 0x26, 1, 0x680), /* Djibouti */
+	COUNTRY_CHPLAN_ENT("DK", 0x26, 1, 0x7FB), /* Denmark */
+	COUNTRY_CHPLAN_ENT("DM", 0x76, 1, 0x000), /* Dominica */
+	COUNTRY_CHPLAN_ENT("DO", 0x76, 1, 0x7F1), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("DZ", 0x26, 1, 0x7F1), /* Algeria */
+	COUNTRY_CHPLAN_ENT("EC", 0x76, 1, 0x7F1), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("EE", 0x26, 1, 0x7FB), /* Estonia */
+	COUNTRY_CHPLAN_ENT("EG", 0x47, 1, 0x7F1), /* Egypt */
+	COUNTRY_CHPLAN_ENT("EH", 0x47, 1, 0x680), /* Western Sahara */
+	COUNTRY_CHPLAN_ENT("ER", 0x26, 1, 0x000), /* Eritrea */
+	COUNTRY_CHPLAN_ENT("ES", 0x26, 1, 0x7FB), /* Spain, Canary Islands, Ceuta, Melilla */
+	COUNTRY_CHPLAN_ENT("ET", 0x26, 1, 0x4B0), /* Ethiopia */
+	COUNTRY_CHPLAN_ENT("FI", 0x26, 1, 0x7FB), /* Finland */
+	COUNTRY_CHPLAN_ENT("FJ", 0x76, 1, 0x600), /* Fiji */
+	COUNTRY_CHPLAN_ENT("FK", 0x26, 1, 0x000), /* Falkland Islands (Islas Malvinas) (UK) */
+	COUNTRY_CHPLAN_ENT("FM", 0x76, 1, 0x000), /* Micronesia, Federated States of (USA) */
+	COUNTRY_CHPLAN_ENT("FO", 0x26, 1, 0x000), /* Faroe Islands (Denmark) */
+	COUNTRY_CHPLAN_ENT("FR", 0x26, 1, 0x7FB), /* France */
+	COUNTRY_CHPLAN_ENT("GA", 0x26, 1, 0x6B0), /* Gabon */
+	COUNTRY_CHPLAN_ENT("GB", 0x26, 1, 0x7FB), /* Great Britain (United Kingdom; England) */
+	COUNTRY_CHPLAN_ENT("GD", 0x34, 1, 0x0B0), /* Grenada */
+	COUNTRY_CHPLAN_ENT("GE", 0x26, 1, 0x600), /* Georgia */
+	COUNTRY_CHPLAN_ENT("GF", 0x26, 1, 0x080), /* French Guiana */
+	COUNTRY_CHPLAN_ENT("GG", 0x26, 1, 0x000), /* Guernsey (UK) */
+	COUNTRY_CHPLAN_ENT("GH", 0x26, 1, 0x7F1), /* Ghana */
+	COUNTRY_CHPLAN_ENT("GI", 0x26, 1, 0x600), /* Gibraltar (UK) */
+	COUNTRY_CHPLAN_ENT("GL", 0x26, 1, 0x600), /* Greenland (Denmark) */
+	COUNTRY_CHPLAN_ENT("GM", 0x26, 1, 0x6B0), /* Gambia */
+	COUNTRY_CHPLAN_ENT("GN", 0x26, 1, 0x610), /* Guinea */
+	COUNTRY_CHPLAN_ENT("GP", 0x26, 1, 0x600), /* Guadeloupe (France) */
+	COUNTRY_CHPLAN_ENT("GQ", 0x26, 1, 0x6B0), /* Equatorial Guinea */
+	COUNTRY_CHPLAN_ENT("GR", 0x26, 1, 0x7FB), /* Greece */
+	COUNTRY_CHPLAN_ENT("GS", 0x26, 1, 0x000), /* South Georgia and the Sandwich Islands (UK) */
+	COUNTRY_CHPLAN_ENT("GT", 0x61, 1, 0x7F1), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("GU", 0x76, 1, 0x600), /* Guam (USA) */
+	COUNTRY_CHPLAN_ENT("GW", 0x26, 1, 0x6B0), /* Guinea-Bissau */
+	COUNTRY_CHPLAN_ENT("GY", 0x44, 1, 0x000), /* Guyana */
+	COUNTRY_CHPLAN_ENT("HK", 0x26, 1, 0x7FB), /* Hong Kong */
+	COUNTRY_CHPLAN_ENT("HM", 0x45, 1, 0x000), /* Heard and McDonald Islands (Australia) */
+	COUNTRY_CHPLAN_ENT("HN", 0x32, 1, 0x7F1), /* Honduras */
+	COUNTRY_CHPLAN_ENT("HR", 0x26, 1, 0x7F9), /* Croatia */
+	COUNTRY_CHPLAN_ENT("HT", 0x76, 1, 0x650), /* Haiti */
+	COUNTRY_CHPLAN_ENT("HU", 0x26, 1, 0x7FB), /* Hungary */
+	COUNTRY_CHPLAN_ENT("ID", 0x3D, 0, 0x7F3), /* Indonesia */
+	COUNTRY_CHPLAN_ENT("IE", 0x26, 1, 0x7FB), /* Ireland */
+	COUNTRY_CHPLAN_ENT("IL", 0x47, 1, 0x7F1), /* Israel */
+	COUNTRY_CHPLAN_ENT("IM", 0x26, 1, 0x000), /* Isle of Man (UK) */
+	COUNTRY_CHPLAN_ENT("IN", 0x48, 1, 0x7F1), /* India */
+	COUNTRY_CHPLAN_ENT("IQ", 0x26, 1, 0x000), /* Iraq */
+	COUNTRY_CHPLAN_ENT("IR", 0x26, 0, 0x000), /* Iran */
+	COUNTRY_CHPLAN_ENT("IS", 0x26, 1, 0x7FB), /* Iceland */
+	COUNTRY_CHPLAN_ENT("IT", 0x26, 1, 0x7FB), /* Italy */
+	COUNTRY_CHPLAN_ENT("JE", 0x26, 1, 0x000), /* Jersey (UK) */
+	COUNTRY_CHPLAN_ENT("JM", 0x51, 1, 0x7F1), /* Jamaica */
+	COUNTRY_CHPLAN_ENT("JO", 0x49, 1, 0x7FB), /* Jordan */
+	COUNTRY_CHPLAN_ENT("JP", 0x27, 1, 0x7FF), /* Japan- Telec */
+	COUNTRY_CHPLAN_ENT("KE", 0x47, 1, 0x7F9), /* Kenya */
+	COUNTRY_CHPLAN_ENT("KG", 0x26, 1, 0x7F1), /* Kyrgyzstan */
+	COUNTRY_CHPLAN_ENT("KH", 0x26, 1, 0x7F1), /* Cambodia */
+	COUNTRY_CHPLAN_ENT("KI", 0x26, 1, 0x000), /* Kiribati */
+	COUNTRY_CHPLAN_ENT("KN", 0x76, 1, 0x000), /* Saint Kitts and Nevis */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0x7FB), /* South Korea */
+	COUNTRY_CHPLAN_ENT("KW", 0x47, 1, 0x7FB), /* Kuwait */
+	COUNTRY_CHPLAN_ENT("KY", 0x76, 1, 0x000), /* Cayman Islands (UK) */
+	COUNTRY_CHPLAN_ENT("KZ", 0x26, 1, 0x700), /* Kazakhstan */
+	COUNTRY_CHPLAN_ENT("LA", 0x26, 1, 0x000), /* Laos */
+	COUNTRY_CHPLAN_ENT("LB", 0x26, 1, 0x7F1), /* Lebanon */
+	COUNTRY_CHPLAN_ENT("LC", 0x76, 1, 0x000), /* Saint Lucia */
+	COUNTRY_CHPLAN_ENT("LI", 0x26, 1, 0x7FB), /* Liechtenstein */
+	COUNTRY_CHPLAN_ENT("LK", 0x26, 1, 0x7F1), /* Sri Lanka */
+	COUNTRY_CHPLAN_ENT("LR", 0x26, 1, 0x6B0), /* Liberia */
+	COUNTRY_CHPLAN_ENT("LS", 0x26, 1, 0x7F1), /* Lesotho */
+	COUNTRY_CHPLAN_ENT("LT", 0x26, 1, 0x7FB), /* Lithuania */
+	COUNTRY_CHPLAN_ENT("LU", 0x26, 1, 0x7FB), /* Luxembourg */
+	COUNTRY_CHPLAN_ENT("LV", 0x26, 1, 0x7FB), /* Latvia */
+	COUNTRY_CHPLAN_ENT("LY", 0x26, 1, 0x000), /* Libya */
+	COUNTRY_CHPLAN_ENT("MA", 0x47, 1, 0x7F1), /* Morocco */
+	COUNTRY_CHPLAN_ENT("MC", 0x26, 1, 0x7FB), /* Monaco */
+	COUNTRY_CHPLAN_ENT("MD", 0x26, 1, 0x7F1), /* Moldova */
+	COUNTRY_CHPLAN_ENT("ME", 0x26, 1, 0x7F1), /* Montenegro */
+	COUNTRY_CHPLAN_ENT("MF", 0x76, 1, 0x000), /* Saint Martin */
+	COUNTRY_CHPLAN_ENT("MG", 0x26, 1, 0x620), /* Madagascar */
+	COUNTRY_CHPLAN_ENT("MH", 0x76, 1, 0x000), /* Marshall Islands (USA) */
+	COUNTRY_CHPLAN_ENT("MK", 0x26, 1, 0x7F1), /* Republic of Macedonia (FYROM) */
+	COUNTRY_CHPLAN_ENT("ML", 0x26, 1, 0x6B0), /* Mali */
+	COUNTRY_CHPLAN_ENT("MM", 0x26, 1, 0x000), /* Burma (Myanmar) */
+	COUNTRY_CHPLAN_ENT("MN", 0x26, 1, 0x000), /* Mongolia */
+	COUNTRY_CHPLAN_ENT("MO", 0x26, 1, 0x600), /* Macau */
+	COUNTRY_CHPLAN_ENT("MP", 0x76, 1, 0x000), /* Northern Mariana Islands (USA) */
+	COUNTRY_CHPLAN_ENT("MQ", 0x26, 1, 0x640), /* Martinique (France) */
+	COUNTRY_CHPLAN_ENT("MR", 0x26, 1, 0x6A0), /* Mauritania */
+	COUNTRY_CHPLAN_ENT("MS", 0x26, 1, 0x000), /* Montserrat (UK) */
+	COUNTRY_CHPLAN_ENT("MT", 0x26, 1, 0x7FB), /* Malta */
+	COUNTRY_CHPLAN_ENT("MU", 0x26, 1, 0x6B0), /* Mauritius */
+	COUNTRY_CHPLAN_ENT("MV", 0x47, 1, 0x000), /* Maldives */
+	COUNTRY_CHPLAN_ENT("MW", 0x26, 1, 0x6B0), /* Malawi */
+	COUNTRY_CHPLAN_ENT("MX", 0x61, 1, 0x7F1), /* Mexico */
+	COUNTRY_CHPLAN_ENT("MY", 0x63, 1, 0x7F1), /* Malaysia */
+	COUNTRY_CHPLAN_ENT("MZ", 0x26, 1, 0x7F1), /* Mozambique */
+	COUNTRY_CHPLAN_ENT("NA", 0x26, 1, 0x700), /* Namibia */
+	COUNTRY_CHPLAN_ENT("NC", 0x26, 1, 0x000), /* New Caledonia */
+	COUNTRY_CHPLAN_ENT("NE", 0x26, 1, 0x6B0), /* Niger */
+	COUNTRY_CHPLAN_ENT("NF", 0x45, 1, 0x000), /* Norfolk Island (Australia) */
+	COUNTRY_CHPLAN_ENT("NG", 0x75, 1, 0x7F9), /* Nigeria */
+	COUNTRY_CHPLAN_ENT("NI", 0x76, 1, 0x7F1), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("NL", 0x26, 1, 0x7FB), /* Netherlands */
+	COUNTRY_CHPLAN_ENT("NO", 0x26, 1, 0x7FB), /* Norway */
+	COUNTRY_CHPLAN_ENT("NP", 0x47, 1, 0x6F0), /* Nepal */
+	COUNTRY_CHPLAN_ENT("NR", 0x26, 1, 0x000), /* Nauru */
+	COUNTRY_CHPLAN_ENT("NU", 0x45, 1, 0x000), /* Niue */
+	COUNTRY_CHPLAN_ENT("NZ", 0x45, 1, 0x7FB), /* New Zealand */
+	COUNTRY_CHPLAN_ENT("OM", 0x26, 1, 0x7F9), /* Oman */
+	COUNTRY_CHPLAN_ENT("PA", 0x76, 1, 0x7F1), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x76, 1, 0x7F1), /* Peru */
+	COUNTRY_CHPLAN_ENT("PF", 0x26, 1, 0x000), /* French Polynesia (France) */
+	COUNTRY_CHPLAN_ENT("PG", 0x26, 1, 0x7F1), /* Papua New Guinea */
+	COUNTRY_CHPLAN_ENT("PH", 0x26, 1, 0x7F1), /* Philippines */
+	COUNTRY_CHPLAN_ENT("PK", 0x51, 1, 0x7F1), /* Pakistan */
+	COUNTRY_CHPLAN_ENT("PL", 0x26, 1, 0x7FB), /* Poland */
+	COUNTRY_CHPLAN_ENT("PM", 0x26, 1, 0x000), /* Saint Pierre and Miquelon (France) */
+	COUNTRY_CHPLAN_ENT("PR", 0x76, 1, 0x7F1), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PT", 0x26, 1, 0x7FB), /* Portugal */
+	COUNTRY_CHPLAN_ENT("PW", 0x76, 1, 0x000), /* Palau */
+	COUNTRY_CHPLAN_ENT("PY", 0x76, 1, 0x7F1), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("QA", 0x51, 1, 0x7F9), /* Qatar */
+	COUNTRY_CHPLAN_ENT("RE", 0x26, 1, 0x000), /* Reunion (France) */
+	COUNTRY_CHPLAN_ENT("RO", 0x26, 1, 0x7F1), /* Romania */
+	COUNTRY_CHPLAN_ENT("RS", 0x26, 1, 0x7F1), /* Serbia, Kosovo */
+	COUNTRY_CHPLAN_ENT("RU", 0x59, 1, 0x7FB), /* Russia(fac/gost), Kaliningrad */
+	COUNTRY_CHPLAN_ENT("RW", 0x26, 1, 0x0B0), /* Rwanda */
+	COUNTRY_CHPLAN_ENT("SA", 0x26, 1, 0x7FB), /* Saudi Arabia */
+	COUNTRY_CHPLAN_ENT("SB", 0x26, 1, 0x000), /* Solomon Islands */
+	COUNTRY_CHPLAN_ENT("SC", 0x76, 1, 0x690), /* Seychelles */
+	COUNTRY_CHPLAN_ENT("SE", 0x26, 1, 0x7FB), /* Sweden */
+	COUNTRY_CHPLAN_ENT("SG", 0x26, 1, 0x7FB), /* Singapore */
+	COUNTRY_CHPLAN_ENT("SH", 0x26, 1, 0x000), /* Saint Helena (UK) */
+	COUNTRY_CHPLAN_ENT("SI", 0x26, 1, 0x7FB), /* Slovenia */
+	COUNTRY_CHPLAN_ENT("SJ", 0x26, 1, 0x000), /* Svalbard (Norway) */
+	COUNTRY_CHPLAN_ENT("SK", 0x26, 1, 0x7FB), /* Slovakia */
+	COUNTRY_CHPLAN_ENT("SL", 0x26, 1, 0x6B0), /* Sierra Leone */
+	COUNTRY_CHPLAN_ENT("SM", 0x26, 1, 0x000), /* San Marino */
+	COUNTRY_CHPLAN_ENT("SN", 0x26, 1, 0x7F1), /* Senegal */
+	COUNTRY_CHPLAN_ENT("SO", 0x26, 1, 0x000), /* Somalia */
+	COUNTRY_CHPLAN_ENT("SR", 0x74, 1, 0x000), /* Suriname */
+	COUNTRY_CHPLAN_ENT("ST", 0x76, 1, 0x680), /* Sao Tome and Principe */
+	COUNTRY_CHPLAN_ENT("SV", 0x30, 1, 0x7F1), /* El Salvador */
+	COUNTRY_CHPLAN_ENT("SX", 0x76, 1, 0x000), /* Sint Marteen */
+	COUNTRY_CHPLAN_ENT("SZ", 0x26, 1, 0x020), /* Swaziland */
+	COUNTRY_CHPLAN_ENT("TC", 0x26, 1, 0x000), /* Turks and Caicos Islands (UK) */
+	COUNTRY_CHPLAN_ENT("TD", 0x26, 1, 0x6B0), /* Chad */
+	COUNTRY_CHPLAN_ENT("TF", 0x26, 1, 0x680), /* French Southern and Antarctic Lands (FR Southern Territories) */
+	COUNTRY_CHPLAN_ENT("TG", 0x26, 1, 0x6B0), /* Togo */
+	COUNTRY_CHPLAN_ENT("TH", 0x26, 1, 0x7F1), /* Thailand */
+	COUNTRY_CHPLAN_ENT("TJ", 0x26, 1, 0x640), /* Tajikistan */
+	COUNTRY_CHPLAN_ENT("TK", 0x45, 1, 0x000), /* Tokelau */
+	COUNTRY_CHPLAN_ENT("TM", 0x26, 1, 0x000), /* Turkmenistan */
+	COUNTRY_CHPLAN_ENT("TN", 0x47, 1, 0x7F1), /* Tunisia */
+	COUNTRY_CHPLAN_ENT("TO", 0x26, 1, 0x000), /* Tonga */
+	COUNTRY_CHPLAN_ENT("TR", 0x26, 1, 0x7F1), /* Turkey, Northern Cyprus */
+	COUNTRY_CHPLAN_ENT("TT", 0x42, 1, 0x3F1), /* Trinidad & Tobago */
+	COUNTRY_CHPLAN_ENT("TW", 0x76, 1, 0x7FF), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("TZ", 0x26, 1, 0x6F0), /* Tanzania */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 1, 0x7FB), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("UG", 0x26, 1, 0x6F1), /* Uganda */
+	COUNTRY_CHPLAN_ENT("US", 0x76, 1, 0x7FF), /* United States of America (USA) */
+	COUNTRY_CHPLAN_ENT("UY", 0x30, 1, 0x7F1), /* Uruguay */
+	COUNTRY_CHPLAN_ENT("UZ", 0x47, 1, 0x6F0), /* Uzbekistan */
+	COUNTRY_CHPLAN_ENT("VA", 0x26, 1, 0x000), /* Holy See (Vatican City) */
+	COUNTRY_CHPLAN_ENT("VC", 0x76, 1, 0x010), /* Saint Vincent and the Grenadines */
+	COUNTRY_CHPLAN_ENT("VE", 0x30, 1, 0x7F1), /* Venezuela */
+	COUNTRY_CHPLAN_ENT("VI", 0x76, 1, 0x000), /* United States Virgin Islands (USA) */
+	COUNTRY_CHPLAN_ENT("VN", 0x26, 1, 0x7F1), /* Vietnam */
+	COUNTRY_CHPLAN_ENT("VU", 0x26, 1, 0x000), /* Vanuatu */
+	COUNTRY_CHPLAN_ENT("WF", 0x26, 1, 0x000), /* Wallis and Futuna (France) */
+	COUNTRY_CHPLAN_ENT("WS", 0x76, 1, 0x000), /* Samoa */
+	COUNTRY_CHPLAN_ENT("YE", 0x26, 1, 0x040), /* Yemen */
+	COUNTRY_CHPLAN_ENT("YT", 0x26, 1, 0x680), /* Mayotte (France) */
+	COUNTRY_CHPLAN_ENT("ZA", 0x26, 1, 0x7F1), /* South Africa */
+	COUNTRY_CHPLAN_ENT("ZM", 0x26, 1, 0x6B0), /* Zambia */
+	COUNTRY_CHPLAN_ENT("ZW", 0x26, 1, 0x7F1), /* Zimbabwe */
 };
 
-u16 const country_chplan_map_sz = sizeof(country_chplan_map) / sizeof(struct country_chplan);
-
 /*
 * rtw_get_chplan_from_country -
 * @country_code: string of country code
@@ -921,6 +1054,9 @@ u16 const country_chplan_map_sz = sizeof(country_chplan_map) / sizeof(struct cou
 */
 const struct country_chplan *rtw_get_chplan_from_country(const char *country_code)
 {
+#if RTW_DEF_MODULE_REGULATORY_CERT
+	const struct country_chplan *exc_ent = NULL;
+#endif
 	const struct country_chplan *ent = NULL;
 	const struct country_chplan *map = NULL;
 	u16 map_sz = 0;
@@ -930,18 +1066,15 @@ const struct country_chplan *rtw_get_chplan_from_country(const char *country_cod
 	code[0] = alpha_to_upper(country_code[0]);
 	code[1] = alpha_to_upper(country_code[1]);
 
-#if !defined(CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP) && RTW_DEF_MODULE_REGULATORY_CERT
-	ent = rtw_def_module_get_chplan_from_country(code);
-	if (ent != NULL)
-		goto exit;
-#endif
-
 #ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
 	map = CUSTOMIZED_country_chplan_map;
-	map_sz = CUSTOMIZED_country_chplan_map_sz;
+	map_sz = sizeof(CUSTOMIZED_country_chplan_map) / sizeof(struct country_chplan);
 #else
+	#if RTW_DEF_MODULE_REGULATORY_CERT
+	exc_ent = rtw_def_module_get_chplan_from_country(code);
+	#endif
 	map = country_chplan_map;
-	map_sz = country_chplan_map_sz;
+	map_sz = sizeof(country_chplan_map) / sizeof(struct country_chplan);
 #endif
 
 	for (i = 0; i < map_sz; i++) {
@@ -953,13 +1086,640 @@ const struct country_chplan *rtw_get_chplan_from_country(const char *country_cod
 
 exit:
 	#if RTW_DEF_MODULE_REGULATORY_CERT
-	if (ent && !(COUNTRY_CHPLAN_DEF_MODULE_FALGS(ent) & RTW_DEF_MODULE_REGULATORY_CERT))
-		ent = NULL;
+	if (!ent || !(COUNTRY_CHPLAN_DEF_MODULE_FALGS(ent) & RTW_DEF_MODULE_REGULATORY_CERT))
+		exc_ent = ent = NULL;
+	if (exc_ent)
+		ent = exc_ent;
 	#endif
 
 	return ent;
 }
 
+const char *const _regd_str[] = {
+	"NONE",
+	"FCC",
+	"MKK",
+	"ETSI",
+	"IC",
+	"KCC",
+	"ACMA",
+	"CHILE",
+	"WW",
+};
+
+#ifdef CONFIG_TXPWR_LIMIT
+void _dump_regd_exc_list(void *sel, struct rf_ctl_t *rfctl)
+{
+	struct regd_exc_ent *ent;
+	_list *cur, *head;
+
+	RTW_PRINT_SEL(sel, "regd_exc_num:%u\n", rfctl->regd_exc_num);
+
+	if (!rfctl->regd_exc_num)
+		goto exit;
+
+	RTW_PRINT_SEL(sel, "%-7s %-6s %-9s\n", "country", "domain", "regd_name");
+
+	head = &rfctl->reg_exc_list;
+	cur = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		u8 has_country;
+
+		ent = LIST_CONTAINOR(cur, struct regd_exc_ent, list);
+		cur = get_next(cur);
+		has_country = (ent->country[0] == '\0' && ent->country[1] == '\0') ? 0 : 1;
+
+		RTW_PRINT_SEL(sel, "     %c%c   0x%02x %s\n"
+			, has_country ? ent->country[0] : '0'
+			, has_country ? ent->country[1] : '0'
+			, ent->domain
+			, ent->regd_name
+		);
+	}
+
+exit:
+	return;
+}
+
+inline void dump_regd_exc_list(void *sel, struct rf_ctl_t *rfctl)
+{
+	_irqL irqL;
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+	_dump_regd_exc_list(sel, rfctl);
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+}
+
+void rtw_regd_exc_add_with_nlen(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name, u32 nlen)
+{
+	struct regd_exc_ent *ent;
+	_irqL irqL;
+
+	if (!regd_name || !nlen) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	ent = (struct regd_exc_ent *)rtw_zmalloc(sizeof(struct regd_exc_ent) + nlen + 1);
+	if (!ent)
+		goto exit;
+
+	_rtw_init_listhead(&ent->list);
+	if (country)
+		_rtw_memcpy(ent->country, country, 2);
+	ent->domain = domain;
+	_rtw_memcpy(ent->regd_name, regd_name, nlen);
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	rtw_list_insert_tail(&ent->list, &rfctl->reg_exc_list);
+	rfctl->regd_exc_num++;
+
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+exit:
+	return;
+}
+
+inline void rtw_regd_exc_add(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name)
+{
+	rtw_regd_exc_add_with_nlen(rfctl, country, domain, regd_name, strlen(regd_name));
+}
+
+struct regd_exc_ent *_rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain)
+{
+	struct regd_exc_ent *ent;
+	_list *cur, *head;
+	u8 match = 0;
+
+	head = &rfctl->reg_exc_list;
+	cur = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		u8 has_country;
+
+		ent = LIST_CONTAINOR(cur, struct regd_exc_ent, list);
+		cur = get_next(cur);
+		has_country = (ent->country[0] == '\0' && ent->country[1] == '\0') ? 0 : 1;
+
+		/* entry has country condition to match */
+		if (has_country) {
+			if (!country)
+				continue;
+			if (ent->country[0] != country[0]
+				|| ent->country[1] != country[1])
+				continue;
+		}
+
+		/* entry has domain condition to match */
+		if (ent->domain != 0xFF) {
+			if (domain == 0xFF)
+				continue;
+			if (ent->domain != domain)
+				continue;
+		}
+
+		match = 1;
+		break;
+	}
+
+exit:
+	if (match)
+		return ent;
+	else
+		return NULL;
+}
+
+inline struct regd_exc_ent *rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain)
+{
+	struct regd_exc_ent *ent;
+	_irqL irqL;
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+	ent = _rtw_regd_exc_search(rfctl, country, domain);
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	return ent;
+}
+
+void rtw_regd_exc_list_free(struct rf_ctl_t *rfctl)
+{
+	struct regd_exc_ent *ent;
+	_irqL irqL;
+	_list *cur, *head;
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	head = &rfctl->reg_exc_list;
+	cur = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		ent = LIST_CONTAINOR(cur, struct regd_exc_ent, list);
+		cur = get_next(cur);
+		rtw_list_delete(&ent->list);
+		rtw_mfree((u8 *)ent, sizeof(struct regd_exc_ent) + strlen(ent->regd_name) + 1);
+	}
+	rfctl->regd_exc_num = 0;
+
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+}
+
+void dump_txpwr_lmt(void *sel, _adapter *adapter)
+{
+#define TMP_STR_LEN 16
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	_irqL irqL;
+	char fmt[16];
+	char tmp_str[TMP_STR_LEN];
+	s8 *lmt_idx = NULL;
+	int bw, band, ch_num, tlrs, ntx_idx, rs, i, path;
+	u8 ch, n, rfpath_num;
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	_dump_regd_exc_list(sel, rfctl);
+	RTW_PRINT_SEL(sel, "\n");
+
+	if (!rfctl->txpwr_regd_num)
+		goto release_lock;
+
+	lmt_idx = rtw_malloc(sizeof(s8) * RF_PATH_MAX * rfctl->txpwr_regd_num);
+	if (!lmt_idx) {
+		RTW_ERR("%s alloc fail\n", __func__);
+		goto release_lock;
+	}
+
+	RTW_PRINT_SEL(sel, "txpwr_lmt_2g_cck_ofdm_state:0x%02x\n", rfctl->txpwr_lmt_2g_cck_ofdm_state);
+	#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
+		RTW_PRINT_SEL(sel, "txpwr_lmt_5g_cck_ofdm_state:0x%02x\n", rfctl->txpwr_lmt_5g_cck_ofdm_state);
+		RTW_PRINT_SEL(sel, "txpwr_lmt_5g_20_40_ref:0x%02x\n", rfctl->txpwr_lmt_5g_20_40_ref);
+	#endif
+	RTW_PRINT_SEL(sel, "\n");
+
+	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
+		if (!hal_is_band_support(adapter, band))
+			continue;
+
+		rfpath_num = (band == BAND_ON_2_4G ? hal_spec->rfpath_num_2g : hal_spec->rfpath_num_5g);
+
+		for (bw = 0; bw < MAX_5G_BANDWIDTH_NUM; bw++) {
+
+			if (bw >= CHANNEL_WIDTH_160)
+				break;
+			if (band == BAND_ON_2_4G && bw >= CHANNEL_WIDTH_80)
+				break;
+
+			if (band == BAND_ON_2_4G)
+				ch_num = CENTER_CH_2G_NUM;
+			else
+				ch_num = center_chs_5g_num(bw);
+
+			if (ch_num == 0) {
+				rtw_warn_on(1);
+				break;
+			}
+
+			for (tlrs = TXPWR_LMT_RS_CCK; tlrs < TXPWR_LMT_RS_NUM; tlrs++) {
+
+				if (band == BAND_ON_2_4G && tlrs == TXPWR_LMT_RS_VHT)
+					continue;
+				if (band == BAND_ON_5G && tlrs == TXPWR_LMT_RS_CCK)
+					continue;
+				if (bw > CHANNEL_WIDTH_20 && (tlrs == TXPWR_LMT_RS_CCK || tlrs == TXPWR_LMT_RS_OFDM))
+					continue;
+				if (bw > CHANNEL_WIDTH_40 && tlrs == TXPWR_LMT_RS_HT)
+					continue;
+				if (tlrs == TXPWR_LMT_RS_VHT && !IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
+					continue;
+
+				for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
+					struct txpwr_lmt_ent *ent;
+					_list *cur, *head;
+
+					if (ntx_idx >= hal_spec->tx_nss_num)
+						continue;
+
+					/* bypass CCK multi-TX is not defined */
+					if (tlrs == TXPWR_LMT_RS_CCK && ntx_idx > RF_1TX) {
+						if (band == BAND_ON_2_4G
+							&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_CCK_1T << ntx_idx)))
+							continue;
+					}
+
+					/* bypass OFDM multi-TX is not defined */
+					if (tlrs == TXPWR_LMT_RS_OFDM && ntx_idx > RF_1TX) {
+						if (band == BAND_ON_2_4G
+							&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
+							continue;
+						#ifdef CONFIG_IEEE80211_BAND_5GHZ
+						if (band == BAND_ON_5G
+							&& !(rfctl->txpwr_lmt_5g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
+							continue;
+						#endif
+					}
+
+					/* bypass 5G 20M, 40M pure reference */
+					#ifdef CONFIG_IEEE80211_BAND_5GHZ
+					if (band == BAND_ON_5G && (bw == CHANNEL_WIDTH_20 || bw == CHANNEL_WIDTH_40)) {
+						if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_HT_FROM_VHT) {
+							if (tlrs == TXPWR_LMT_RS_HT)
+								continue;
+						} else if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_VHT_FROM_HT) {
+							if (tlrs == TXPWR_LMT_RS_VHT && bw <= CHANNEL_WIDTH_40)
+								continue;
+						}
+					}
+					#endif
+
+					/* choose n-SS mapping rate section to get lmt diff value */
+					if (tlrs == TXPWR_LMT_RS_CCK)
+						rs = CCK;
+					else if (tlrs == TXPWR_LMT_RS_OFDM)
+						rs = OFDM;
+					else if (tlrs == TXPWR_LMT_RS_HT)
+						rs = HT_1SS + ntx_idx;
+					else if (tlrs == TXPWR_LMT_RS_VHT)
+						rs = VHT_1SS + ntx_idx;
+					else {
+						RTW_ERR("%s invalid tlrs %u\n", __func__, tlrs);
+						continue;
+					}
+
+					RTW_PRINT_SEL(sel, "[%s][%s][%s][%uT]\n"
+						, band_str(band)
+						, ch_width_str(bw)
+						, txpwr_lmt_rs_str(tlrs)
+						, ntx_idx + 1
+					);
+
+					/* header for limit in db */
+					RTW_PRINT_SEL(sel, "%3s ", "ch");
+
+					head = &rfctl->txpwr_lmt_list;
+					cur = get_next(head);
+					while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+						ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+						cur = get_next(cur);
+
+						sprintf(fmt, "%%%zus%%s ", strlen(ent->regd_name) < 4 ? 5 - strlen(ent->regd_name) : 1);
+						snprintf(tmp_str, TMP_STR_LEN, fmt
+							, strcmp(ent->regd_name, rfctl->regd_name) == 0 ? "*" : ""
+							, ent->regd_name);
+						_RTW_PRINT_SEL(sel, "%s", tmp_str);
+					}
+					sprintf(fmt, "%%%zus%%s ", strlen(regd_str(TXPWR_LMT_WW)) < 4 ? 5 - strlen(regd_str(TXPWR_LMT_WW)) : 1);
+					snprintf(tmp_str, TMP_STR_LEN, fmt
+						, strcmp(rfctl->regd_name, regd_str(TXPWR_LMT_WW)) == 0 ? "*" : ""
+						, regd_str(TXPWR_LMT_WW));
+					_RTW_PRINT_SEL(sel, "%s", tmp_str);
+
+					/* header for limit offset */
+					for (path = 0; path < RF_PATH_MAX; path++) {
+						if (path >= rfpath_num)
+							break;
+						_RTW_PRINT_SEL(sel, "|");
+						head = &rfctl->txpwr_lmt_list;
+						cur = get_next(head);
+						while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+							ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+							cur = get_next(cur);
+							_RTW_PRINT_SEL(sel, "%3c "
+								, strcmp(ent->regd_name, rfctl->regd_name) == 0 ? rf_path_char(path) : ' ');
+						}
+						_RTW_PRINT_SEL(sel, "%3c "
+								, strcmp(rfctl->regd_name, regd_str(TXPWR_LMT_WW)) == 0 ? rf_path_char(path) : ' ');
+					}
+					_RTW_PRINT_SEL(sel, "\n");
+
+					for (n = 0; n < ch_num; n++) {
+						s8 lmt;
+						s8 lmt_offset;
+						u8 base;
+
+						if (band == BAND_ON_2_4G)
+							ch = n + 1;
+						else
+							ch = center_chs_5g(bw, n);
+
+						if (ch == 0) {
+							rtw_warn_on(1);
+							break;
+						}
+
+						/* dump limit in db */
+						RTW_PRINT_SEL(sel, "%3u ", ch);
+						head = &rfctl->txpwr_lmt_list;
+						cur = get_next(head);
+						while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+							ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+							cur = get_next(cur);
+							lmt = phy_get_txpwr_lmt_abs(adapter, ent->regd_name, band, bw, tlrs, ntx_idx, ch, 0);
+							if (lmt == MAX_POWER_INDEX) {
+								sprintf(fmt, "%%%zus ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) + 1 : 5);
+								snprintf(tmp_str, TMP_STR_LEN, fmt, "NA");
+								_RTW_PRINT_SEL(sel, "%s", tmp_str);
+							} else {
+								if (lmt == -1) { /* -0.5 */
+									sprintf(fmt, "%%%zus ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) + 1 : 5);
+									snprintf(tmp_str, TMP_STR_LEN, fmt, "-0.5");
+									_RTW_PRINT_SEL(sel, "%s", tmp_str);
+								} else if (lmt % 2) { /* n.5 */
+									sprintf(fmt, "%%%zud.5 ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) - 1 : 3);
+									snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
+									_RTW_PRINT_SEL(sel, "%s", tmp_str);
+								} else { /* n */
+									sprintf(fmt, "%%%zud ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) + 1 : 5);
+									snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
+									_RTW_PRINT_SEL(sel, "%s", tmp_str);
+								}
+							}
+						}
+						lmt = phy_get_txpwr_lmt_abs(adapter, regd_str(TXPWR_LMT_WW), band, bw, tlrs, ntx_idx, ch, 0);
+						if (lmt == MAX_POWER_INDEX) {
+							sprintf(fmt, "%%%zus ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 5);
+							snprintf(tmp_str, TMP_STR_LEN, fmt, "NA");
+							_RTW_PRINT_SEL(sel, "%s", tmp_str);
+						} else {
+							if (lmt == -1) { /* -0.5 */
+								sprintf(fmt, "%%%zus ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 5);
+								snprintf(tmp_str, TMP_STR_LEN, fmt, "-0.5");
+								_RTW_PRINT_SEL(sel, "%s", tmp_str);
+							} else if (lmt % 2) { /* n.5 */
+								sprintf(fmt, "%%%zud.5 ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) - 1 : 3);
+								snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
+								_RTW_PRINT_SEL(sel, "%s", tmp_str);
+							} else { /* n */
+								sprintf(fmt, "%%%zud ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 5);
+								snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
+								_RTW_PRINT_SEL(sel, "%s", tmp_str);
+							}
+						}
+
+						/* dump limit offset of each path */
+						for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
+							if (path >= rfpath_num)
+								break;
+
+							base = PHY_GetTxPowerByRateBase(adapter, band, path, rs);
+
+							_RTW_PRINT_SEL(sel, "|");
+							head = &rfctl->txpwr_lmt_list;
+							cur = get_next(head);
+							i = 0;
+							while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+								ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+								cur = get_next(cur);
+								lmt_offset = phy_get_txpwr_lmt(adapter, ent->regd_name, band, bw, path, rs, ntx_idx, ch, 0);
+								if (lmt_offset == MAX_POWER_INDEX) {
+									*(lmt_idx + i * RF_PATH_MAX + path) = MAX_POWER_INDEX;
+									_RTW_PRINT_SEL(sel, "%3s ", "NA");
+								} else {
+									*(lmt_idx + i * RF_PATH_MAX + path) = lmt_offset + base;
+									_RTW_PRINT_SEL(sel, "%3d ", lmt_offset);
+								}
+								i++;
+							}
+							lmt_offset = phy_get_txpwr_lmt(adapter, regd_str(TXPWR_LMT_WW), band, bw, path, rs, ntx_idx, ch, 0);
+							if (lmt_offset == MAX_POWER_INDEX)
+								_RTW_PRINT_SEL(sel, "%3s ", "NA");
+							else
+								_RTW_PRINT_SEL(sel, "%3d ", lmt_offset);
+
+						}
+
+						/* compare limit_idx of each path, print 'x' when mismatch */
+						if (rfpath_num > 1) {
+							for (i = 0; i < rfctl->txpwr_regd_num; i++) {
+								for (path = 0; path < RF_PATH_MAX; path++) {
+									if (path >= rfpath_num)
+										break;
+									if (*(lmt_idx + i * RF_PATH_MAX + path) != *(lmt_idx + i * RF_PATH_MAX + ((path + 1) % rfpath_num)))
+										break;
+								}
+								if (path >= rfpath_num)
+									_RTW_PRINT_SEL(sel, " ");
+								else
+									_RTW_PRINT_SEL(sel, "x");
+							}
+						}
+						_RTW_PRINT_SEL(sel, "\n");
+
+					}
+					RTW_PRINT_SEL(sel, "\n");
+				}
+			} /* loop for rate sections */
+		} /* loop for bandwidths */
+	} /* loop for bands */
+
+	if (lmt_idx)
+		rtw_mfree(lmt_idx, sizeof(s8) * RF_PATH_MAX * rfctl->txpwr_regd_num);
+
+release_lock:
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+}
+
+/* search matcing first, if not found, alloc one */
+void rtw_txpwr_lmt_add_with_nlen(struct rf_ctl_t *rfctl, const char *regd_name, u32 nlen
+	, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt)
+{
+	struct txpwr_lmt_ent *ent;
+	_irqL irqL;
+	_list *cur, *head;
+	s8 pre_lmt;
+
+	if (!regd_name || !nlen) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	/* search for existed entry */
+	head = &rfctl->txpwr_lmt_list;
+	cur = get_next(head);
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+		cur = get_next(cur);
+
+		if (strlen(ent->regd_name) == nlen
+			&& _rtw_memcmp(ent->regd_name, regd_name, nlen) == _TRUE)
+			goto chk_lmt_val;
+	}
+
+	/* alloc new one */
+	ent = (struct txpwr_lmt_ent *)rtw_zvmalloc(sizeof(struct txpwr_lmt_ent) + nlen + 1);
+	if (!ent)
+		goto release_lock;
+
+	_rtw_init_listhead(&ent->list);
+	_rtw_memcpy(ent->regd_name, regd_name, nlen);
+	{
+		u8 j, k, l, m;
+
+		for (j = 0; j < MAX_2_4G_BANDWIDTH_NUM; ++j)
+			for (k = 0; k < TXPWR_LMT_RS_NUM_2G; ++k)
+				for (m = 0; m < CENTER_CH_2G_NUM; ++m)
+					for (l = 0; l < MAX_TX_COUNT; ++l)
+						ent->lmt_2g[j][k][m][l] = MAX_POWER_INDEX;
+		#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		for (j = 0; j < MAX_5G_BANDWIDTH_NUM; ++j)
+			for (k = 0; k < TXPWR_LMT_RS_NUM_5G; ++k)
+				for (m = 0; m < CENTER_CH_5G_ALL_NUM; ++m)
+					for (l = 0; l < MAX_TX_COUNT; ++l)
+						ent->lmt_5g[j][k][m][l] = MAX_POWER_INDEX;
+		#endif
+	}
+
+	rtw_list_insert_tail(&ent->list, &rfctl->txpwr_lmt_list);
+	rfctl->txpwr_regd_num++;
+
+chk_lmt_val:
+	if (band == BAND_ON_2_4G)
+		pre_lmt = ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx];
+	#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	else if (band == BAND_ON_5G)
+		pre_lmt = ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx];
+	#endif
+	else
+		goto release_lock;
+
+	if (pre_lmt != MAX_POWER_INDEX)
+		RTW_PRINT("duplicate txpwr_lmt for [%s][%s][%s][%s][%uT][%d]\n"
+			, regd_name, band_str(band), ch_width_str(bw), txpwr_lmt_rs_str(tlrs), ntx_idx + 1
+			, band == BAND_ON_2_4G ? ch_idx + 1 : center_ch_5g_all[ch_idx]);
+
+	lmt = rtw_min(pre_lmt, lmt);
+	if (band == BAND_ON_2_4G)
+		ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx] = lmt;
+	#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	else if (band == BAND_ON_5G)
+		ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx] = lmt;
+	#endif
+
+	if (0)
+		RTW_PRINT("%s, %4s, %6s, %7s, %uT, ch%3d = %d\n"
+			, regd_name, band_str(band), ch_width_str(bw), txpwr_lmt_rs_str(tlrs), ntx_idx + 1
+			, band == BAND_ON_2_4G ? ch_idx + 1 : center_ch_5g_all[ch_idx]
+			, lmt);
+
+release_lock:
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+exit:
+	return;
+}
+
+inline void rtw_txpwr_lmt_add(struct rf_ctl_t *rfctl, const char *regd_name
+	, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt)
+{
+	rtw_txpwr_lmt_add_with_nlen(rfctl, regd_name, strlen(regd_name)
+		, band, bw, tlrs, ntx_idx, ch_idx, lmt);
+}
+
+struct txpwr_lmt_ent *_rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name)
+{
+	struct txpwr_lmt_ent *ent;
+	_list *cur, *head;
+	u8 found = 0;
+
+	head = &rfctl->txpwr_lmt_list;
+	cur = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+		cur = get_next(cur);
+
+		if (strcmp(ent->regd_name, regd_name) == 0) {
+			found = 1;
+			break;
+		}
+	}
+
+	if (found)
+		return ent;
+	return NULL;
+}
+
+inline struct txpwr_lmt_ent *rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name)
+{
+	struct txpwr_lmt_ent *ent;
+	_irqL irqL;
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+	ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_name);
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	return ent;
+}
+
+void rtw_txpwr_lmt_list_free(struct rf_ctl_t *rfctl)
+{
+	struct txpwr_lmt_ent *ent;
+	_irqL irqL;
+	_list *cur, *head;
+
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	head = &rfctl->txpwr_lmt_list;
+	cur = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+		cur = get_next(cur);
+		if (ent->regd_name == rfctl->regd_name)
+			rfctl->regd_name = regd_str(TXPWR_LMT_NONE);
+		rtw_list_delete(&ent->list);
+		rtw_vmfree((u8 *)ent, sizeof(struct txpwr_lmt_ent) + strlen(ent->regd_name) + 1);
+	}
+	rfctl->txpwr_regd_num = 0;
+
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+}
+#endif /* CONFIG_TXPWR_LIMIT */
+
 int rtw_ch_to_bb_gain_sel(int ch)
 {
 	int sel = -1;
@@ -986,7 +1746,7 @@ s8 rtw_rf_get_kfree_tx_gain_offset(_adapter *padapter, u8 path, u8 ch)
 {
 	s8 kfree_offset = 0;
 
-#ifdef CONFIG_RF_GAIN_OFFSET
+#ifdef CONFIG_RF_POWER_TRIM
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 	struct kfree_data_t *kfree_data = GET_KFREE_DATA(padapter);
 	s8 bb_gain_sel = rtw_ch_to_bb_gain_sel(ch);
@@ -998,58 +1758,101 @@ s8 rtw_rf_get_kfree_tx_gain_offset(_adapter *padapter, u8 path, u8 ch)
 
 	if (kfree_data->flag & KFREE_FLAG_ON) {
 		kfree_offset = kfree_data->bb_gain[bb_gain_sel][path];
-		if (1)
-			DBG_871X("%s path:%u, ch:%u, bb_gain_sel:%d, kfree_offset:%d\n"
+		if (IS_HARDWARE_TYPE_8723D(padapter))
+			RTW_INFO("%s path:%s, ch:%u, bb_gain_sel:%d, kfree_offset:%d\n"
+				, __func__, (path == 0)?"S1":"S0", 
+				ch, bb_gain_sel, kfree_offset);
+		else
+			RTW_INFO("%s path:%u, ch:%u, bb_gain_sel:%d, kfree_offset:%d\n"
 				, __func__, path, ch, bb_gain_sel, kfree_offset);
 	}
 exit:
-#endif /* CONFIG_RF_GAIN_OFFSET */
+#endif /* CONFIG_RF_POWER_TRIM */
 	return kfree_offset;
 }
 
 void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset)
 {
 	u8 write_value;
-
-	DBG_871X("kfree gain_offset 0x55:0x%x ", rtw_hal_read_rfreg(adapter, path, 0x55, 0xffffffff));
+	u8 target_path = 0;
+	u32 val32 = 0;
+
+	if (IS_HARDWARE_TYPE_8723D(adapter)) {
+		target_path = RF_PATH_A; /*in 8723D case path means S0/S1*/
+		if (path == PPG_8723D_S1)
+			RTW_INFO("kfree gain_offset 0x55:0x%x ",
+			rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff));
+		else if (path == PPG_8723D_S0)
+			RTW_INFO("kfree gain_offset 0x65:0x%x ",
+			rtw_hal_read_rfreg(adapter, target_path, 0x65, 0xffffffff));
+	} else {
+		target_path = path;
+		RTW_INFO("kfree gain_offset 0x55:0x%x ", rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff));
+	}
+	
 	switch (rtw_get_chip_type(adapter)) {
+#ifdef CONFIG_RTL8723D
+	case RTL8723D:
+		write_value = RF_TX_GAIN_OFFSET_8723D(offset);
+		if (path == PPG_8723D_S1)
+			rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0f8000, write_value);
+		else if (path == PPG_8723D_S0)
+			rtw_hal_write_rfreg(adapter, target_path, 0x65, 0x0f8000, write_value);
+		break;
+#endif /* CONFIG_RTL8723D */
 #ifdef CONFIG_RTL8703B
 	case RTL8703B:
 		write_value = RF_TX_GAIN_OFFSET_8703B(offset);
-		rtw_hal_write_rfreg(adapter, path, 0x55, 0x0fc000, write_value);
+		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
 		break;
 #endif /* CONFIG_RTL8703B */
 #ifdef CONFIG_RTL8188F
 	case RTL8188F:
 		write_value = RF_TX_GAIN_OFFSET_8188F(offset);
-		rtw_hal_write_rfreg(adapter, path, 0x55, 0x0fc000, write_value);
+		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
 		break;
 #endif /* CONFIG_RTL8188F */
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		write_value = RF_TX_GAIN_OFFSET_8188GTV(offset);
+		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
+		break;
+#endif /* CONFIG_RTL8188GTV */
 #ifdef CONFIG_RTL8192E
 	case RTL8192E:
 		write_value = RF_TX_GAIN_OFFSET_8192E(offset);
-		rtw_hal_write_rfreg(adapter, path, 0x55, 0x0f8000, write_value);
+		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0f8000, write_value);
 		break;
 #endif /* CONFIG_RTL8188F */
 
 #ifdef CONFIG_RTL8821A
 	case RTL8821:
 		write_value = RF_TX_GAIN_OFFSET_8821A(offset);
-		rtw_hal_write_rfreg(adapter, path, 0x55, 0x0f8000, write_value);
+		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0f8000, write_value);
 		break;
 #endif /* CONFIG_RTL8821A */
-#ifdef CONFIG_RTL8814A
-		case RTL8814A:
-		DBG_871X("\nkfree by PhyDM on the sw CH. path %d\n", path);
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	case RTL8814A:
+	case RTL8822B:
+	case RTL8821C:
+		RTW_INFO("\nkfree by PhyDM on the sw CH. path %d\n", path);
 		break;
-#endif /* CONFIG_RTL8821A */
+#endif /* CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
 
 	default:
 		rtw_warn_on(1);
 		break;
 	}
-
-	DBG_871X(" after :0x%x\n", rtw_hal_read_rfreg(adapter, path, 0x55, 0xffffffff));
+	
+	if (IS_HARDWARE_TYPE_8723D(adapter)) {
+		if (path == PPG_8723D_S1)
+			val32 = rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff);
+		else if (path == PPG_8723D_S0)
+			val32 = rtw_hal_read_rfreg(adapter, target_path, 0x65, 0xffffffff);
+	} else {
+		val32 = rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff);
+	}
+	RTW_INFO(" after :0x%x\n", val32);
 }
 
 void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch)
@@ -1058,41 +1861,56 @@ void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch)
 	s8 kfree_offset = 0;
 	s8 tx_pwr_track_offset = 0; /* TODO: 8814A should consider tx pwr track when setting tx gain offset */
 	s8 total_offset;
-	int i;
+	int i, total = 0;
+
+	if (IS_HARDWARE_TYPE_8723D(adapter))
+		total = 2; /* S1 and S0 */
+	else
+		total = hal_data->NumTotalRFPath;
 
-	for (i = 0; i < hal_data->NumTotalRFPath; i++) {
+	for (i = 0; i < total; i++) {
 		kfree_offset = rtw_rf_get_kfree_tx_gain_offset(adapter, i, ch);
 		total_offset = kfree_offset + tx_pwr_track_offset;
 		rtw_rf_set_tx_gain_offset(adapter, i, total_offset);
 	}
 }
 
-bool rtw_is_dfs_range(u32 hi, u32 lo)
+inline u8 rtw_is_dfs_range(u32 hi, u32 lo)
 {
-	return rtw_is_range_overlap(hi, lo, 5720 + 10, 5260 - 10) ? _TRUE : _FALSE;
+	return rtw_is_range_overlap(hi, lo, 5720 + 10, 5260 - 10);
 }
 
-bool rtw_is_dfs_ch(u8 ch, u8 bw, u8 offset)
+u8 rtw_is_dfs_ch(u8 ch)
 {
 	u32 hi, lo;
 
-	if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
-		return _FALSE;
+	if (!rtw_chbw_to_freq_range(ch, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE, &hi, &lo))
+		return 0;
+
+	return rtw_is_dfs_range(hi, lo);
+}
+
+u8 rtw_is_dfs_chbw(u8 ch, u8 bw, u8 offset)
+{
+	u32 hi, lo;
+
+	if (!rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo))
+		return 0;
 
-	return rtw_is_dfs_range(hi, lo) ? _TRUE : _FALSE;
+	return rtw_is_dfs_range(hi, lo);
 }
 
-bool rtw_is_long_cac_range(u32 hi, u32 lo)
+bool rtw_is_long_cac_range(u32 hi, u32 lo, u8 dfs_region)
 {
-	return rtw_is_range_overlap(hi, lo, 5660 + 10, 5600 - 10) ? _TRUE : _FALSE;
+	return (dfs_region == PHYDM_DFS_DOMAIN_ETSI && rtw_is_range_overlap(hi, lo, 5650, 5600)) ? _TRUE : _FALSE;
 }
 
-bool rtw_is_long_cac_ch(u8 ch, u8 bw, u8 offset)
+bool rtw_is_long_cac_ch(u8 ch, u8 bw, u8 offset, u8 dfs_region)
 {
 	u32 hi, lo;
 
 	if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
 		return _FALSE;
 
-	return rtw_is_long_cac_range(hi, lo) ? _TRUE : _FALSE;
+	return rtw_is_long_cac_range(hi, lo, dfs_region) ? _TRUE : _FALSE;
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rm.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rm.c
new file mode 100644
index 000000000000..e2472f6804c5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rm.c
@@ -0,0 +1,2494 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+#include "rtw_rm_fsm.h"
+
+#define pstr(s) s+strlen(s)
+
+u8 rm_post_event_hdl(_adapter *padapter, u8 *pbuf)
+{
+#ifdef CONFIG_RTW_80211K
+	struct rm_event *pev = (struct rm_event *)pbuf;
+
+	_rm_post_event(padapter, pev->rmid, pev->evid);
+	rm_handler(padapter, pev);
+#endif
+	return H2C_SUCCESS;
+}
+
+#ifdef CONFIG_RTW_80211K
+
+/* 802.11-2012 Table E-1 Operationg classes in United States */
+static RT_OPERATING_CLASS RTW_OP_CLASS_US[] = {
+	/* 0, OP_CLASS_NULL */	{  0,  0, {}},
+	/* 1, OP_CLASS_1 */	{115,  4, {36, 40, 44, 48}},
+	/* 2, OP_CLASS_2 */	{118,  4, {52, 56, 60, 64}},
+	/* 3, OP_CLASS_3 */	{124,  4, {149, 153, 157, 161}},
+	/* 4, OP_CLASS_4 */	{121, 11, {100, 104, 108, 112, 116, 120, 124,
+						128, 132, 136, 140}},
+	/* 5, OP_CLASS_5 */	{125,  5, {149, 153, 157, 161, 165}},
+	/* 6, OP_CLASS_12 */	{ 81, 11, {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11}}
+};
+
+struct cmd_meas_type_ {
+	u8 id;
+	char *name;
+};
+
+char *rm_type_req_name(u8 meas_type) {
+
+	switch (meas_type) {
+	case basic_req:
+		return "basic_req";
+	case cca_req:
+		return "cca_req";
+	case rpi_histo_req:
+		return "rpi_histo_req";
+	case ch_load_req:
+		return "ch_load_req";
+	case noise_histo_req:
+		return "noise_histo_req";
+	case bcn_req:
+		return "bcn_req";
+	case frame_req:
+		return "frame_req";
+	case sta_statis_req:
+		return "sta_statis_req";
+	}
+	return "unknown_req";
+};
+
+char *rm_type_rep_name(u8 meas_type) {
+
+	switch (meas_type) {
+	case basic_rep:
+		return "basic_rep";
+	case cca_rep:
+		return "cca_rep";
+	case rpi_histo_rep:
+		return "rpi_histo_rep";
+	case ch_load_rep:
+		return "ch_load_rep";
+	case noise_histo_rep:
+		return "noise_histo_rep";
+	case bcn_rep:
+		return "bcn_rep";
+	case frame_rep:
+		return "frame_rep";
+	case sta_statis_rep:
+		return "sta_statis_rep";
+	}
+	return "unknown_rep";
+};
+
+char *rm_en_cap_name(enum rm_cap_en en)
+{
+	switch (en) {
+	case RM_LINK_MEAS_CAP_EN:
+		return "RM_LINK_MEAS_CAP_EN";
+	case RM_NB_REP_CAP_EN:
+		return "RM_NB_REP_CAP_EN";
+	case RM_PARAL_MEAS_CAP_EN:
+		return "RM_PARAL_MEAS_CAP_EN";
+	case RM_REPEAT_MEAS_CAP_EN:
+		return "RM_REPEAT_MEAS_CAP_EN";
+	case RM_BCN_PASSIVE_MEAS_CAP_EN:
+		return "RM_BCN_PASSIVE_MEAS_CAP_EN";
+	case RM_BCN_ACTIVE_MEAS_CAP_EN:
+		return "RM_BCN_ACTIVE_MEAS_CAP_EN";
+	case RM_BCN_TABLE_MEAS_CAP_EN:
+		return "RM_BCN_TABLE_MEAS_CAP_EN";
+	case RM_BCN_MEAS_REP_COND_CAP_EN:
+		return "RM_BCN_MEAS_REP_COND_CAP_EN";
+
+	case RM_FRAME_MEAS_CAP_EN:
+		return "RM_FRAME_MEAS_CAP_EN";
+	case RM_CH_LOAD_CAP_EN:
+		return "RM_CH_LOAD_CAP_EN";
+	case RM_NOISE_HISTO_CAP_EN:
+		return "RM_NOISE_HISTO_CAP_EN";
+	case RM_STATIS_MEAS_CAP_EN:
+		return "RM_STATIS_MEAS_CAP_EN";
+	case RM_LCI_MEAS_CAP_EN:
+		return "RM_LCI_MEAS_CAP_EN";
+	case RM_LCI_AMIMUTH_CAP_EN:
+		return "RM_LCI_AMIMUTH_CAP_EN";
+	case RM_TRANS_STREAM_CAT_MEAS_CAP_EN:
+		return "RM_TRANS_STREAM_CAT_MEAS_CAP_EN";
+	case RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN:
+		return "RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN";
+
+	case RM_AP_CH_REP_CAP_EN:
+		return "RM_AP_CH_REP_CAP_EN";
+	case RM_RM_MIB_CAP_EN:
+		return "RM_RM_MIB_CAP_EN";
+	case RM_OP_CH_MAX_MEAS_DUR0:
+		return "RM_OP_CH_MAX_MEAS_DUR0";
+	case RM_OP_CH_MAX_MEAS_DUR1:
+		return "RM_OP_CH_MAX_MEAS_DUR1";
+	case RM_OP_CH_MAX_MEAS_DUR2:
+		return "RM_OP_CH_MAX_MEAS_DUR2";
+	case RM_NONOP_CH_MAX_MEAS_DUR0:
+		return "RM_NONOP_CH_MAX_MEAS_DUR0";
+	case RM_NONOP_CH_MAX_MEAS_DUR1:
+		return "RM_NONOP_CH_MAX_MEAS_DUR1";
+	case RM_NONOP_CH_MAX_MEAS_DUR2:
+		return "RM_NONOP_CH_MAX_MEAS_DUR2";
+
+	case RM_MEAS_PILOT_CAP0:
+		return "RM_MEAS_PILOT_CAP0";		/* 24-26 */
+	case RM_MEAS_PILOT_CAP1:
+		return "RM_MEAS_PILOT_CAP1";
+	case RM_MEAS_PILOT_CAP2:
+		return "RM_MEAS_PILOT_CAP2";
+	case RM_MEAS_PILOT_TRANS_INFO_CAP_EN:
+		return "RM_MEAS_PILOT_TRANS_INFO_CAP_EN";
+	case RM_NB_REP_TSF_OFFSET_CAP_EN:
+		return "RM_NB_REP_TSF_OFFSET_CAP_EN";
+	case RM_RCPI_MEAS_CAP_EN:
+		return "RM_RCPI_MEAS_CAP_EN";		/* 29 */
+	case RM_RSNI_MEAS_CAP_EN:
+		return "RM_RSNI_MEAS_CAP_EN";
+	case RM_BSS_AVG_ACCESS_DELAY_CAP_EN:
+		return "RM_BSS_AVG_ACCESS_DELAY_CAP_EN";
+
+	case RM_AVALB_ADMIS_CAPACITY_CAP_EN:
+		return "RM_AVALB_ADMIS_CAPACITY_CAP_EN";
+	case RM_ANT_CAP_EN:
+		return "RM_ANT_CAP_EN";
+	case RM_RSVD:
+	case RM_MAX:
+	default:
+		break;
+	}
+	return "unknown";
+}
+
+int rm_en_cap_chk_and_set(struct rm_obj *prm, enum rm_cap_en en)
+{
+	int idx;
+	u8 cap;
+
+
+	if (en >= RM_MAX)
+		return _FALSE;
+
+	idx = en / 8;
+	cap = prm->psta->padapter->rmpriv.rm_en_cap_def[idx];
+
+	if (!(cap & BIT(en - (idx*8)))) {
+		RTW_INFO("RM: %s incapable\n",rm_en_cap_name(en));
+		rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
+		return _FALSE;
+	}
+	return _SUCCESS;
+}
+
+static u8 rm_get_oper_class_via_ch(u8 ch)
+{
+	int i,j,sz;
+
+
+	sz = sizeof(RTW_OP_CLASS_US)/sizeof(struct _RT_OPERATING_CLASS);
+
+	for (i = 0; i < sz; i++) {
+		for (j = 0; j < RTW_OP_CLASS_US[i].Len; j++) {
+			if ( ch == RTW_OP_CLASS_US[i].Channel[j]) {
+				RTW_INFO("RM: ch %u in oper_calss %u\n",
+					ch, RTW_OP_CLASS_US[i].global_op_class);
+				return RTW_OP_CLASS_US[i].global_op_class;
+				break;
+			}
+		}
+	}
+	return 0;
+}
+
+static u8 rm_get_ch_set(
+	struct rtw_ieee80211_channel *pch_set, u8 op_class, u8 ch_num)
+{
+	int i,j,sz;
+	u8 ch_amount = 0;
+
+
+	sz = sizeof(RTW_OP_CLASS_US)/sizeof(struct _RT_OPERATING_CLASS);
+
+	if (ch_num != 0) {
+		pch_set[0].hw_value = ch_num;
+		ch_amount = 1;
+		RTW_INFO("RM: meas_ch->hw_value = %u\n", pch_set->hw_value);
+		goto done;
+	}
+
+	for (i = 0; i < sz; i++) {
+
+		if (RTW_OP_CLASS_US[i].global_op_class == op_class) {
+
+			for (j = 0; j < RTW_OP_CLASS_US[i].Len; j++) {
+				pch_set[j].hw_value =
+					RTW_OP_CLASS_US[i].Channel[j];
+				RTW_INFO("RM: meas_ch[%d].hw_value = %u\n",
+					j, pch_set[j].hw_value);
+			}
+			ch_amount = RTW_OP_CLASS_US[i].Len;
+			break;
+		}
+	}
+done:
+	return ch_amount;
+}
+
+static int is_wildcard_bssid(u8 *bssid)
+{
+	int i;
+	u8 val8 = 0xff;
+
+
+	for (i=0;i<6;i++)
+		val8 &= bssid[i];
+
+	if (val8 == 0xff)
+		return _SUCCESS;
+	return _FALSE;
+}
+
+/* for caller outside rm */
+u8 rm_add_nb_req(_adapter *padapter, struct sta_info *psta)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct rm_obj *prm;
+
+
+	prm = rm_alloc_rmobj(padapter);
+
+	if (prm == NULL) {
+		RTW_ERR("RM: unable to alloc rm obj for requeset\n");
+		return _FALSE;
+	}
+
+	prm->psta = psta;
+	prm->q.category = RTW_WLAN_CATEGORY_RADIO_MEAS;
+	prm->q.diag_token = pmlmeinfo->dialogToken++;
+	prm->q.m_token = 1;
+
+	prm->rmid = psta->cmn.aid << 16
+		| prm->q.diag_token << 8
+		| RM_MASTER;
+
+	prm->q.action_code = RM_ACT_NB_REP_REQ;
+
+	#if 0
+	if (pmac) { /* find sta_info according to bssid */
+		pmac += 4; /* skip mac= */
+		if (hwaddr_parse(pmac, bssid) == NULL) {
+			sprintf(pstr(s), "Err: \nincorrect mac format\n");
+			return _FAIL;
+		}
+		psta = rm_get_sta(padapter, 0xff, bssid);
+	}
+	#endif
+
+	/* enquee rmobj */
+	rm_enqueue_rmobj(padapter, prm, _FALSE);
+
+	RTW_INFO("RM: rmid=%x add req to " MAC_FMT "\n",
+		prm->rmid, MAC_ARG(psta->cmn.mac_addr));
+
+	return _SUCCESS;
+}
+
+
+static u8 *build_wlan_hdr(_adapter *padapter, struct xmit_frame *pmgntframe,
+	struct sta_info *psta, u16 frame_type)
+{
+	u8 *pframe;
+	u16 *fctrl;
+	struct pkt_attrib *pattr;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+
+
+	/* update attribute */
+	pattr = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattr);
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, psta->cmn.mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3,
+		get_my_bssid(&(pmlmeinfo->network)),ETH_ALEN);
+
+	RTW_INFO("RM: dst = " MAC_FMT "\n", MAC_ARG(pwlanhdr->addr1));
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	SetFragNum(pframe, 0);
+
+	set_frame_sub_type(pframe, WIFI_ACTION);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattr->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	return pframe;
+}
+
+void rm_set_rep_mode(struct rm_obj *prm, u8 mode)
+{
+
+	RTW_INFO("RM: rmid=%x set %s\n",
+		prm->rmid,
+		mode|MEAS_REP_MOD_INCAP?"INCAP":
+		mode|MEAS_REP_MOD_REFUSE?"REFUSE":
+		mode|MEAS_REP_MOD_LATE?"LATE":"");
+
+	prm->p.m_mode |= mode;
+}
+
+int issue_null_reply(struct rm_obj *prm)
+{
+	int len=0, my_len;
+	u8 *pframe, m_mode;
+	_adapter *padapter = prm->psta->padapter;
+	struct pkt_attrib *pattr;
+	struct xmit_frame *pmgntframe;
+	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+
+
+	m_mode = prm->p.m_mode;
+	if (m_mode || prm->p.rpt == 0) {
+		RTW_INFO("RM: rmid=%x reply (%s repeat=%d)\n",
+			prm->rmid,
+			m_mode&MEAS_REP_MOD_INCAP?"INCAP":
+			m_mode&MEAS_REP_MOD_REFUSE?"REFUSE":
+			m_mode&MEAS_REP_MOD_LATE?"LATE":"no content",
+			prm->p.rpt);
+	}
+
+	switch (prm->p.action_code) {
+	case RM_ACT_RADIO_MEAS_REQ:
+		len = 8;
+		break;
+	case RM_ACT_NB_REP_REQ:
+		len = 3;
+		break;
+	case RM_ACT_LINK_MEAS_REQ:
+		len = 3;
+		break;
+	default:
+		break;
+	}
+
+	if (len==0)
+		return _FALSE;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		RTW_ERR("RM: %s alloc xmit_frame fail\n",__func__);
+		return _FALSE;
+	}
+	pattr = &pmgntframe->attrib;
+	pframe = build_wlan_hdr(padapter, pmgntframe, prm->psta, WIFI_ACTION);
+	pframe = rtw_set_fixed_ie(pframe, 3, &prm->p.category, &pattr->pktlen);
+
+	my_len = 0;
+	if (len>5) {
+		prm->p.len = len - 3 - 2;
+		pframe = rtw_set_fixed_ie(pframe, len - 3,
+			&prm->p.e_id, &my_len);
+	}
+
+	pattr->pktlen += my_len;
+	pattr->last_txcmdsz = pattr->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
+
+	return _SUCCESS;
+}
+
+int ready_for_scan(struct rm_obj *prm)
+{
+	_adapter *padapter = prm->psta->padapter;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+
+	if (rtw_is_scan_deny(padapter))
+		return _FALSE;
+
+	if (!rtw_is_adapter_up(padapter))
+		return _FALSE;
+
+	if (rtw_mi_busy_traffic_check(padapter, _FALSE))
+		return _FALSE;
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE)
+		&& check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+		RTW_INFO(FUNC_ADPT_FMT" WIFI_AP_STATE && WIFI_UNDER_WPS\n",
+		FUNC_ADPT_ARG(padapter));
+		return _FALSE;
+	}
+	if (check_fwstate(pmlmepriv,
+		(_FW_UNDER_SURVEY | _FW_UNDER_LINKING)) == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT" _FW_UNDER_SURVEY|_FW_UNDER_LINKING\n",
+			FUNC_ADPT_ARG(padapter));
+		return _FALSE;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter,
+		(_FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS))) {
+		RTW_INFO(FUNC_ADPT_FMT", but buddy_intf is under scanning or linking or wps_phase\n",
+			FUNC_ADPT_ARG(padapter));
+		return _FALSE;
+	}
+#endif
+	return _SUCCESS;
+}
+
+int rm_sitesurvey(struct rm_obj *prm)
+{
+	int meas_ch_num=0;
+	u8 ch_num=0, op_class=0, val8;
+	struct rtw_ieee80211_channel *pch_set;
+	struct sitesurvey_parm parm;
+
+
+	RTW_INFO("RM: rmid=%x %s\n",prm->rmid, __func__);
+
+	pch_set = &prm->q.ch_set[0];
+
+	_rtw_memset(pch_set, 0,
+		sizeof(struct rtw_ieee80211_channel) * MAX_OP_CHANNEL_SET_NUM);
+
+	if (prm->q.ch_num == 0) {
+		/* ch_num=0   : scan all ch in operating class */
+		op_class = prm->q.op_class;
+
+	} else if (prm->q.ch_num == 255) {
+		/* 802.11 p.499 */
+		/* ch_num=255 : scan all ch in current operating class */
+		op_class = rm_get_oper_class_via_ch(
+			(u8)prm->psta->padapter->mlmeextpriv.cur_channel);
+	} else
+		ch_num = prm->q.ch_num;
+
+	/* get means channel */
+	meas_ch_num = rm_get_ch_set(pch_set, op_class, ch_num);
+	prm->q.ch_set_ch_amount = meas_ch_num;
+
+	_rtw_memset(&parm, 0, sizeof(struct sitesurvey_parm));
+	_rtw_memcpy(parm.ch, pch_set,
+		sizeof(struct rtw_ieee80211_channel) * MAX_OP_CHANNEL_SET_NUM);
+
+	_rtw_memcpy(&parm.ssid[0], &prm->q.opt.bcn.ssid, IW_ESSID_MAX_SIZE);
+
+	parm.ssid_num = 1;
+	parm.scan_mode = prm->q.m_mode;
+	parm.ch_num = meas_ch_num;
+	parm.igi = 0;
+	parm.token = prm->rmid;
+	parm.duration = prm->q.meas_dur;
+	/* parm.bw = BW_20M; */
+
+	rtw_sitesurvey_cmd(prm->psta->padapter, &parm);
+
+	return _SUCCESS;
+}
+
+static u8 translate_percentage_to_rcpi(u32 SignalStrengthIndex)
+{
+	s32 SignalPower; /* in dBm. */
+	u8 rcpi;
+
+	/* Translate to dBm (x=y-100) */
+	SignalPower = SignalStrengthIndex - 100;
+
+	/* RCPI = Int{(Power in dBm + 110)*2} for 0dBm > Power > -110dBm
+	 *    0	: power <= -110.0 dBm
+	 *    1	: power =  -109.5 dBm
+	 *    2	: power =  -109.0 dBm
+	 */
+
+	rcpi = (SignalPower + 110)*2;
+	return rcpi;
+}
+
+static int rm_parse_ch_load_s_elem(struct rm_obj *prm, u8 *pbody, int req_len)
+{
+	u8 *popt_id;
+	int i, p=0; /* position */
+	int len = req_len;
+
+
+	prm->q.opt_s_elem_len = len;
+#if (RM_MORE_DBG_MSG)
+	RTW_INFO("RM: opt_s_elem_len=%d\n", len);
+#endif
+	while (len) {
+
+		switch (pbody[p]) {
+		case ch_load_rep_info:
+			/* check RM_EN */
+			rm_en_cap_chk_and_set(prm, RM_CH_LOAD_CAP_EN);
+
+			_rtw_memcpy(&(prm->q.opt.clm.rep_cond),
+				&pbody[p+2], sizeof(prm->q.opt.clm.rep_cond));
+
+			RTW_INFO("RM: ch_load_rep_info=%u:%u\n",
+				prm->q.opt.clm.rep_cond.cond,
+				prm->q.opt.clm.rep_cond.threshold);
+			break;
+		default:
+			break;
+
+		}
+		len = len - (int)pbody[p+1] - 2;
+		p = p + (int)pbody[p+1] + 2;
+#if (RM_MORE_DBG_MSG)
+		RTW_INFO("RM: opt_s_elem_len=%d\n",len);
+#endif
+	}
+	return _SUCCESS;
+}
+
+static int rm_parse_noise_histo_s_elem(struct rm_obj *prm,
+	u8 *pbody, int req_len)
+{
+	u8 *popt_id;
+	int i, p=0; /* position */
+	int len = req_len;
+
+
+	prm->q.opt_s_elem_len = len;
+#if (RM_MORE_DBG_MSG)
+	RTW_INFO("RM: opt_s_elem_len=%d\n", len);
+#endif
+
+	while (len) {
+
+		switch (pbody[p]) {
+		case noise_histo_rep_info:
+			/* check RM_EN */
+			rm_en_cap_chk_and_set(prm, RM_NOISE_HISTO_CAP_EN);
+
+			_rtw_memcpy(&(prm->q.opt.nhm.rep_cond),
+				&pbody[p+2], sizeof(prm->q.opt.nhm.rep_cond));
+
+			RTW_INFO("RM: noise_histo_rep_info=%u:%u\n",
+				prm->q.opt.nhm.rep_cond.cond,
+				prm->q.opt.nhm.rep_cond.threshold);
+			break;
+		default:
+			break;
+
+       		}
+		len = len - (int)pbody[p+1] - 2;
+		p = p + (int)pbody[p+1] + 2;
+#if (RM_MORE_DBG_MSG)
+		RTW_INFO("RM: opt_s_elem_len=%d\n",len);
+#endif
+	}
+	return _SUCCESS;
+}
+
+static int rm_parse_bcn_req_s_elem(struct rm_obj *prm, u8 *pbody, int req_len)
+{
+	u8 *popt_id;
+	int i, p=0; /* position */
+	int len = req_len;
+
+
+	/* opt length,2:pbody[0]+ pbody[1] */
+	/* first opt id : pbody[18] */
+
+	prm->q.opt_s_elem_len = len;
+#if (RM_MORE_DBG_MSG)
+	RTW_INFO("RM: opt_s_elem_len=%d\n", len);
+#endif
+
+	popt_id = prm->q.opt.bcn.opt_id;
+	while (len && prm->q.opt.bcn.opt_id_num < BCN_REQ_OPT_MAX_NUM) {
+
+		switch (pbody[p]) {
+		case bcn_req_ssid:
+			RTW_INFO("bcn_req_ssid\n");
+
+#if (DBG_BCN_REQ_WILDCARD)
+			RTW_INFO("DBG set ssid to WILDCARD\n");
+#else
+#if (DBG_BCN_REQ_SSID)
+			RTW_INFO("DBG set ssid to %s\n",DBG_BCN_REQ_SSID_NAME);
+			i = strlen(DBG_BCN_REQ_SSID_NAME);
+			prm->q.opt.bcn.ssid.SsidLength = i;
+			_rtw_memcpy(&(prm->q.opt.bcn.ssid.Ssid),
+				DBG_BCN_REQ_SSID_NAME, i);
+
+#else /* original */
+			prm->q.opt.bcn.ssid.SsidLength = pbody[p+1];
+			_rtw_memcpy(&(prm->q.opt.bcn.ssid.Ssid),
+				&pbody[p+2], pbody[p+1]);
+#endif
+#endif
+
+			RTW_INFO("RM: bcn_req_ssid=%s\n",
+				prm->q.opt.bcn.ssid.Ssid);
+
+			popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
+			break;
+
+		case bcn_req_rep_info:
+			/* check RM_EN */
+			rm_en_cap_chk_and_set(prm, RM_BCN_MEAS_REP_COND_CAP_EN);
+
+			_rtw_memcpy(&(prm->q.opt.bcn.rep_cond),
+				&pbody[p+2], sizeof(prm->q.opt.bcn.rep_cond));
+
+			RTW_INFO("bcn_req_rep_info=%u:%u\n",
+				prm->q.opt.bcn.rep_cond.cond,
+				prm->q.opt.bcn.rep_cond.threshold);
+
+			/*popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];*/
+			break;
+
+		case bcn_req_rep_detail:
+#if DBG_BCN_REQ_DETAIL
+			prm->q.opt.bcn.rep_detail = 2; /* all IE in beacon */
+#else
+			prm->q.opt.bcn.rep_detail = pbody[p+2];
+#endif
+			popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
+
+#if (RM_MORE_DBG_MSG)
+			RTW_INFO("RM: report_detail=%d\n",
+				prm->q.opt.bcn.rep_detail);
+#endif
+			break;
+
+		case bcn_req_req:
+			RTW_INFO("RM: bcn_req_req\n");
+
+			prm->q.opt.bcn.req_start = rtw_malloc(pbody[p+1]);
+
+			if (prm->q.opt.bcn.req_start == NULL) {
+				RTW_ERR("RM: req_start malloc fail!!\n");
+				break;
+			}
+
+			for (i = 0; i < pbody[p+1]; i++)
+				*((prm->q.opt.bcn.req_start)+i) =
+					pbody[p+2+i];
+
+			prm->q.opt.bcn.req_len = pbody[p+1];
+			popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
+			break;
+
+		case bcn_req_ac_ch_rep:
+#if (RM_MORE_DBG_MSG)
+			RTW_INFO("RM: bcn_req_ac_ch_rep\n");
+#endif
+			popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
+			break;
+
+		default:
+			break;
+
+       		}
+		len = len - (int)pbody[p+1] - 2;
+		p = p + (int)pbody[p+1] + 2;
+#if (RM_MORE_DBG_MSG)
+		RTW_INFO("RM: opt_s_elem_len=%d\n",len);
+#endif
+	}
+
+	return _SUCCESS;
+}
+
+static int rm_parse_meas_req(struct rm_obj *prm, u8 *pbody)
+{
+	int p; /* position */
+	int req_len;
+
+
+	req_len = (int)pbody[1];
+	p = 5;
+
+	prm->q.op_class = pbody[p++];
+	prm->q.ch_num = pbody[p++];
+	prm->q.rand_intvl = le16_to_cpu(*(u16*)(&pbody[p]));
+	p+=2;
+	prm->q.meas_dur = le16_to_cpu(*(u16*)(&pbody[p]));
+	p+=2;
+
+	if (prm->q.m_type == bcn_req) {
+		/*
+		 * 0: passive
+		 * 1: active
+		 * 2: bcn_table
+		 */
+		prm->q.m_mode = pbody[p++];
+
+		/* BSSID */
+		_rtw_memcpy(&(prm->q.bssid), &pbody[p], 6);
+		p+=6;
+
+		/*
+		 * default, used when Reporting detail subelement
+		 * is not included in Beacon Request
+		 */
+		prm->q.opt.bcn.rep_detail = 2;
+	}
+
+	if (req_len-(p-2) <= 0) /* without sub-element */
+		return _SUCCESS;
+
+	switch (prm->q.m_type) {
+	case bcn_req:
+		rm_parse_bcn_req_s_elem(prm, &pbody[p], req_len-(p-2));
+		break;
+	case ch_load_req:
+		rm_parse_ch_load_s_elem(prm, &pbody[p], req_len-(p-2));
+		break;
+	case noise_histo_req:
+		rm_parse_noise_histo_s_elem(prm, &pbody[p], req_len-(p-2));
+		break;
+	default:
+		break;
+	}
+
+	return _SUCCESS;
+}
+
+/* receive measurement request */
+int rm_recv_radio_mens_req(_adapter *padapter,
+	union recv_frame *precv_frame, struct sta_info *psta)
+{
+	struct rm_obj *prm;
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	u8 *pdiag_body = (u8 *)(precv_frame->u.hdr.rx_data +
+		sizeof(struct rtw_ieee80211_hdr_3addr));
+	u8 *pmeas_body = &pdiag_body[5];
+	u8 rmid, update = 0;
+
+
+#if 0
+	/* search existing rm_obj */
+	rmid = psta->cmn.aid << 16
+		| pdiag_body[2] << 8
+		| RM_SLAVE;
+
+	prm = rm_get_rmobj(padapter, rmid);
+	if (prm) {
+		RTW_INFO("RM: Found an exist meas rmid=%u\n", rmid);
+		update = 1;
+	} else
+#endif
+	prm = rm_alloc_rmobj(padapter);
+
+	if (prm == NULL) {
+		RTW_ERR("RM: unable to alloc rm obj for requeset\n");
+		return _FALSE;
+	}
+
+	prm->psta = psta;
+	prm->q.diag_token = pdiag_body[2];
+	prm->q.rpt = le16_to_cpu(*(u16*)(&pdiag_body[3]));
+
+	/* Figure 8-104 Measurement Requested format */
+	prm->q.e_id = pmeas_body[0];
+	prm->q.m_token = pmeas_body[2];
+	prm->q.m_mode = pmeas_body[3];
+	prm->q.m_type = pmeas_body[4];
+
+	prm->rmid = psta->cmn.aid << 16
+		| prm->q.diag_token << 8
+		| RM_SLAVE;
+
+	RTW_INFO("RM: rmid=%x, bssid " MAC_FMT "\n", prm->rmid,
+		MAC_ARG(prm->psta->cmn.mac_addr));
+
+#if (RM_MORE_DBG_MSG)
+	RTW_INFO("RM: element_id = %d\n", prm->q.e_id);
+	RTW_INFO("RM: length = %d\n", (int)pmeas_body[1]);
+	RTW_INFO("RM: meas_token = %d\n", prm->q.m_token);
+	RTW_INFO("RM: meas_mode = %d\n", prm->q.m_mode);
+	RTW_INFO("RM: meas_type = %d\n", prm->q.m_type);
+#endif
+
+	if (prm->q.e_id != _MEAS_REQ_IE_) /* 38 */
+		return _FALSE;
+
+	switch (prm->q.m_type) {
+	case bcn_req:
+		RTW_INFO("RM: recv beacon_request\n");
+		switch (prm->q.m_mode) {
+		case bcn_req_passive:
+			rm_en_cap_chk_and_set(prm, RM_BCN_PASSIVE_MEAS_CAP_EN);
+			break;
+		case bcn_req_active:
+			rm_en_cap_chk_and_set(prm, RM_BCN_ACTIVE_MEAS_CAP_EN);
+			break;
+		case bcn_req_bcn_table:
+			rm_en_cap_chk_and_set(prm, RM_BCN_TABLE_MEAS_CAP_EN);
+			break;
+		default:
+			rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
+			break;
+		}
+		break;
+	case ch_load_req:
+		RTW_INFO("RM: recv ch_load_request\n");
+		rm_en_cap_chk_and_set(prm, RM_CH_LOAD_CAP_EN);
+		break;
+	case noise_histo_req:
+		RTW_INFO("RM: recv noise_histogram_request\n");
+		rm_en_cap_chk_and_set(prm, RM_NOISE_HISTO_CAP_EN);
+		break;
+	default:
+		RTW_INFO("RM: recv unknown request type 0x%02x\n",
+			prm->q.m_type);
+		rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
+		goto done;
+       }
+	rm_parse_meas_req(prm, pmeas_body);
+done:
+	if (!update)
+		rm_enqueue_rmobj(padapter, prm, _FALSE);
+
+	return _SUCCESS;
+}
+
+/* receive measurement report */
+int rm_recv_radio_mens_rep(_adapter *padapter,
+	union recv_frame *precv_frame, struct sta_info *psta)
+{
+	int ret = _FALSE;
+	struct rm_obj *prm;
+	u32 rmid;
+	u8 *pdiag_body = (u8 *)(precv_frame->u.hdr.rx_data +
+		sizeof(struct rtw_ieee80211_hdr_3addr));
+	u8 *pmeas_body = &pdiag_body[3];
+
+
+	rmid = psta->cmn.aid << 16
+		| pdiag_body[2] << 8
+		| RM_MASTER;
+
+	prm = rm_get_rmobj(padapter, rmid);
+	if (prm == NULL)
+		return _FALSE;
+
+	prm->p.action_code = pdiag_body[1];
+	prm->p.diag_token = pdiag_body[2];
+
+	/* Figure 8-140 Measuremnt Report format */
+	prm->p.e_id = pmeas_body[0];
+	prm->p.m_token = pmeas_body[2];
+	prm->p.m_mode = pmeas_body[3];
+	prm->p.m_type = pmeas_body[4];
+
+	RTW_INFO("RM: rmid=%x, bssid " MAC_FMT "\n", prm->rmid,
+		MAC_ARG(prm->psta->cmn.mac_addr));
+
+#if (RM_MORE_DBG_MSG)
+	RTW_INFO("RM: element_id = %d\n", prm->p.e_id);
+	RTW_INFO("RM: length = %d\n", (int)pmeas_body[1]);
+	RTW_INFO("RM: meas_token = %d\n", prm->p.m_token);
+	RTW_INFO("RM: meas_mode = %d\n", prm->p.m_mode);
+	RTW_INFO("RM: meas_type = %d\n", prm->p.m_type);
+#endif
+	if (prm->p.e_id != _MEAS_RSP_IE_) /* 39 */
+		return _FALSE;
+
+	RTW_INFO("RM: recv %s\n", rm_type_rep_name(prm->p.m_type));
+	rm_post_event(padapter, prm->rmid, RM_EV_recv_rep);
+
+	return ret;
+}
+
+int rm_radio_mens_nb_rep(_adapter *padapter,
+	union recv_frame *precv_frame, struct sta_info *psta)
+{
+	u8 *pdiag_body = (u8 *)(precv_frame->u.hdr.rx_data +
+		sizeof(struct rtw_ieee80211_hdr_3addr));
+	u8 *pmeas_body = &pdiag_body[3];
+	u32 len = precv_frame->u.hdr.len;
+	u32 rmid;
+	struct rm_obj *prm;
+
+
+	rmid = psta->cmn.aid << 16
+		| pdiag_body[2] << 8
+		| RM_MASTER;
+
+	prm = rm_get_rmobj(padapter, rmid);
+	if (prm == NULL)
+		return _FALSE;
+
+	prm->p.action_code = pdiag_body[1];
+	prm->p.diag_token = pdiag_body[2];
+	prm->p.e_id = pmeas_body[0];
+
+	RTW_INFO("RM: rmid=%x, bssid " MAC_FMT "\n", prm->rmid,
+		MAC_ARG(prm->psta->cmn.mac_addr));
+
+#if (RM_MORE_DBG_MSG)
+	RTW_INFO("RM: element_id = %d\n", prm->p.e_id);
+	RTW_INFO("RM: length = %d\n", (int)pmeas_body[1]);
+#endif
+	rm_post_event(padapter, prm->rmid, RM_EV_recv_rep);
+
+#ifdef CONFIG_LAYER2_ROAMING
+	if (rtw_wnm_btm_candidates_survey(padapter
+			,(pdiag_body + 3)
+			,(len - sizeof(struct rtw_ieee80211_hdr_3addr))
+			,_FALSE) == _FAIL)
+		return _FALSE;
+#endif
+	rtw_cfg80211_rx_rrm_action(padapter, precv_frame);
+
+	return _TRUE;
+}
+
+unsigned int rm_on_action(_adapter *padapter, union recv_frame *precv_frame)
+{
+	u32 ret = _FAIL;
+	u8 *pframe = NULL;
+	u8 *pframe_body = NULL;
+	u8 action_code = 0;
+	u8 diag_token = 0;
+	struct rtw_ieee80211_hdr_3addr *whdr;
+	struct sta_info *psta;
+
+
+	pframe = precv_frame->u.hdr.rx_data;
+
+	/* check RA matches or not */
+	if (!_rtw_memcmp(adapter_mac_addr(padapter),
+		GetAddr1Ptr(pframe), ETH_ALEN))
+		goto exit;
+
+	whdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
+	RTW_INFO("RM: %s bssid = " MAC_FMT "\n",
+		__func__, MAC_ARG(whdr->addr2));
+
+	psta = rtw_get_stainfo(&padapter->stapriv, whdr->addr2);
+
+        if (!psta) {
+		RTW_ERR("RM: psta not found\n");
+                goto exit;
+        }
+
+	pframe_body = (unsigned char *)(pframe +
+		sizeof(struct rtw_ieee80211_hdr_3addr));
+
+	/* Figure 8-438 radio measurement request frame Action field format */
+	/* Category = pframe_body[0] = 5 (Radio Measurement) */
+	action_code = pframe_body[1];
+	diag_token = pframe_body[2];
+
+#if (RM_MORE_DBG_MSG)
+	RTW_INFO("RM: %s radio_action=%x, diag_token=%x\n", __func__,
+		action_code, diag_token);
+#endif
+
+	switch (action_code) {
+
+	case RM_ACT_RADIO_MEAS_REQ:
+		RTW_INFO("RM: RM_ACT_RADIO_MEAS_REQ\n");
+		ret = rm_recv_radio_mens_req(padapter, precv_frame, psta);
+		break;
+
+	case RM_ACT_RADIO_MEAS_REP:
+		RTW_INFO("RM: RM_ACT_RADIO_MEAS_REP\n");
+		ret = rm_recv_radio_mens_rep(padapter, precv_frame, psta);
+		break;
+
+	case RM_ACT_LINK_MEAS_REQ:
+		RTW_INFO("RM: RM_ACT_LINK_MEAS_REQ\n");
+		break;
+
+	case RM_ACT_LINK_MEAS_REP:
+		RTW_INFO("RM: RM_ACT_LINK_MEAS_REP\n");
+		break;
+
+	case RM_ACT_NB_REP_REQ:
+		RTW_INFO("RM: RM_ACT_NB_REP_REQ\n");
+		break;
+
+	case RM_ACT_NB_REP_RESP:
+		RTW_INFO("RM: RM_ACT_NB_REP_RESP\n");
+		ret = rm_radio_mens_nb_rep(padapter, precv_frame, psta);
+		break;
+
+	default:
+		/* TODO reply incabable */
+		RTW_ERR("RM: unknown specturm management action %2x\n",
+			action_code);
+		break;
+	}
+exit:
+	return ret;
+}
+
+static u8 *rm_gen_bcn_detail_elem(_adapter *padapter, u8 *pframe,
+	struct rm_obj *prm, struct wlan_network *pnetwork,
+	unsigned int *fr_len)
+{
+	WLAN_BSSID_EX *pbss = &pnetwork->network;
+	unsigned int my_len;
+	int j, k, len;
+	u8 *plen;
+	u8 *ptr;
+	u8 val8, eid;
+
+
+	my_len = 0;
+	/* Reporting Detail values
+	 * 0: No fixed length fields or elements
+	 * 1: All fixed length fields and any requested elements
+	 *    in the Request info element if present
+	 * 2: All fixed length fields and elements
+	 * 3-255: Reserved
+	 */
+
+	/* report_detail = 0 */
+	if (prm->q.opt.bcn.rep_detail == 0
+		|| prm->q.opt.bcn.rep_detail > 2) {
+		return pframe;
+	}
+
+	/* ID */
+	val8 = 1; /* 1:reported frame body */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	plen = pframe;
+	val8 = 0;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* report_detail = 2 */
+	if (prm->q.opt.bcn.rep_detail == 2) {
+		pframe = rtw_set_fixed_ie(pframe, pbss->IELength - 4,
+			pbss->IEs, &my_len); /* -4 remove FCS */
+		goto done;
+	}
+
+	/* report_detail = 1 */
+	/* all fixed lenght fields */
+	pframe = rtw_set_fixed_ie(pframe,
+		_FIXED_IE_LENGTH_, pbss->IEs, &my_len);
+
+	for (j = 0; j < prm->q.opt.bcn.opt_id_num; j++) {
+		switch (prm->q.opt.bcn.opt_id[j]) {
+		case bcn_req_ssid:
+			/* SSID */
+#if (RM_MORE_DBG_MSG)
+			RTW_INFO("RM: bcn_req_ssid\n");
+#endif
+			pframe = rtw_set_ie(pframe, _SSID_IE_,
+				pbss->Ssid.SsidLength,
+				pbss->Ssid.Ssid, &my_len);
+			break;
+		case bcn_req_req:
+			if (prm->q.opt.bcn.req_start == NULL)
+				break;
+#if (RM_MORE_DBG_MSG)
+			RTW_INFO("RM: bcn_req_req");
+#endif
+			for (k=0; k<prm->q.opt.bcn.req_len; k++) {
+				eid = prm->q.opt.bcn.req_start[k];
+
+				val8 = pbss->IELength - _FIXED_IE_LENGTH_;
+				ptr = rtw_get_ie(pbss->IEs + _FIXED_IE_LENGTH_,
+					eid, &len, val8);
+
+				if (!ptr)
+					continue;
+#if (RM_MORE_DBG_MSG)
+				switch (eid) {
+				case EID_QBSSLoad:
+					RTW_INFO("RM: EID_QBSSLoad\n");
+					break;
+				case EID_HTCapability:
+					RTW_INFO("RM: EID_HTCapability\n");
+					break;
+				case _MDIE_:
+					RTW_INFO("RM: EID_MobilityDomain\n");
+					break;
+				default:
+					RTW_INFO("RM: EID %d todo\n",eid);
+					break;
+				}
+#endif
+				pframe = rtw_set_ie(pframe, eid,
+					len,ptr+2, &my_len);
+			} /* for() */
+			break;
+		case bcn_req_ac_ch_rep:
+		default:
+			RTW_INFO("RM: OPT %d TODO\n",prm->q.opt.bcn.opt_id[j]);
+			break;
+		}
+	}
+done:
+	/*
+	 * update my length
+	 * content length does NOT include ID and LEN
+	 */
+	val8 = my_len - 2;
+	rtw_set_fixed_ie(plen, 1, &val8, &j);
+
+	/* update length to caller */
+	*fr_len += my_len;
+
+	return pframe;
+}
+
+static u8 rm_get_rcpi(struct rm_obj *prm, struct wlan_network *pnetwork)
+{
+	return translate_percentage_to_rcpi(
+		pnetwork->network.PhyInfo.SignalStrength);
+}
+
+static u8 rm_get_rsni(struct rm_obj *prm, struct wlan_network *pnetwork)
+{
+	int i;
+	u8 val8, snr;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(prm->psta->padapter);
+
+
+	if (pnetwork->network.PhyInfo.is_cck_rate) {
+		/* current HW doesn't have CCK RSNI */
+		/* 255 indicates RSNI is unavailable */
+		val8 = 255;
+	} else {
+		snr = 0;
+		for (i = 0; i < pHalData->NumTotalRFPath; i++) {
+			snr += pnetwork->network.PhyInfo.rx_snr[i];
+		}
+		snr = snr / pHalData->NumTotalRFPath;
+		val8 = (u8)(snr + 10)*2;
+	}
+	return val8;
+}
+
+u8 rm_bcn_req_cond_mach(struct rm_obj *prm, struct wlan_network *pnetwork)
+{
+	u8 val8;
+
+
+	switch(prm->q.opt.bcn.rep_cond.cond) {
+	case bcn_rep_cond_immediately:
+		return _SUCCESS;
+	case bcn_req_cond_rcpi_greater:
+		val8 = rm_get_rcpi(prm, pnetwork);
+		if (val8 > prm->q.opt.bcn.rep_cond.threshold)
+			return _SUCCESS;
+		break;
+	case bcn_req_cond_rcpi_less:
+		val8 = rm_get_rcpi(prm, pnetwork);
+		if (val8 < prm->q.opt.bcn.rep_cond.threshold)
+			return _SUCCESS;
+		break;
+	case bcn_req_cond_rsni_greater:
+		val8 = rm_get_rsni(prm, pnetwork);
+		if (val8 != 255 && val8 > prm->q.opt.bcn.rep_cond.threshold)
+			return _SUCCESS;
+		break;
+	case bcn_req_cond_rsni_less:
+		val8 = rm_get_rsni(prm, pnetwork);
+		if (val8 != 255 && val8 < prm->q.opt.bcn.rep_cond.threshold)
+			return _SUCCESS;
+		break;
+	default:
+		RTW_ERR("RM: bcn_req cond %u not support\n",
+			prm->q.opt.bcn.rep_cond.cond);
+		break;
+	}
+	return _FALSE;
+}
+
+static u8 *rm_bcn_rep_fill_scan_resule (struct rm_obj *prm,
+	u8 *pframe, struct wlan_network *pnetwork, unsigned int *fr_len)
+{
+	int snr, i;
+	u8 val8, *plen;
+	u16 val16;
+	u32 val32;
+	u64 val64;
+	PWLAN_BSSID_EX pbss;
+	unsigned int my_len;
+	_adapter *padapter = prm->psta->padapter;
+
+
+	my_len = 0;
+	/* meas ID */
+	val8 = EID_MeasureReport;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* remember position form elelment length */
+	plen = pframe;
+
+	/* meas_rpt_len */
+	/* default 3 = mode + token + type but no beacon content */
+	val8 = 3;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* meas_token */
+	val8 = prm->q.m_token;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* meas_rpt_mode F8-141 */
+	val8 = prm->p.m_mode;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* meas_type T8-81 */
+	val8 = bcn_rep;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	if (pnetwork == NULL)
+		goto done;
+
+	pframe = rtw_set_fixed_ie(pframe, 1, &prm->q.op_class, &my_len);
+
+	/* channel */
+	pbss = &pnetwork->network;
+	val8 = pbss->Configuration.DSConfig;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* Actual Measurement StartTime */
+	val64 = cpu_to_le64(prm->meas_start_time);
+	pframe = rtw_set_fixed_ie(pframe, 8, (u8 *)&val64, &my_len);
+
+	/* Measurement Duration */
+	val16 = prm->meas_end_time - prm->meas_start_time;
+	val16 = cpu_to_le16(val16);
+	pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
+
+	/* TODO
+	 * ReportedFrameInformation:
+	 * 0 :beacon or probe rsp
+	 * 1 :pilot frame
+	 */
+	val8 = 0; /* report frame info */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* RCPI */
+	val8 = rm_get_rcpi(prm, pnetwork);
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* RSNI */
+	val8 = rm_get_rsni(prm, pnetwork);
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* BSSID */
+	pframe = rtw_set_fixed_ie(pframe, 6, (u8 *)&pbss->MacAddress, &my_len);
+
+	/*
+	 * AntennaID
+	 * 0: unknown
+	 * 255: multiple antenna (Diversity)
+	 */
+	val8 = 0;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* ParentTSF */
+	val32 = prm->meas_start_time + pnetwork->network.PhyInfo.free_cnt;
+	pframe = rtw_set_fixed_ie(pframe, 4, (u8 *)&val32, &my_len);
+
+	/*
+	 * Generate Beacon detail
+	 */
+	pframe = rm_gen_bcn_detail_elem(padapter, pframe,
+		prm, pnetwork, &my_len);
+done:
+	/*
+	 * update my length
+	 * content length does NOT include ID and LEN
+	 */
+	val8 = my_len - 2;
+	rtw_set_fixed_ie(plen, 1, &val8, &i);
+
+	/* update length to caller */
+	*fr_len += my_len;
+
+	return pframe;
+}
+
+static u8 *rm_gen_bcn_rep_ie (struct rm_obj *prm,
+	u8 *pframe, struct wlan_network *pnetwork, unsigned int *fr_len)
+{
+	int snr, i;
+	u8 val8, *plen;
+	u16 val16;
+	u32 val32;
+	u64 val64;
+	unsigned int my_len;
+	_adapter *padapter = prm->psta->padapter;
+
+
+	my_len = 0;
+	plen = pframe + 1;
+	pframe = rtw_set_fixed_ie(pframe, 7, &prm->p.e_id, &my_len);
+
+	/* Actual Measurement StartTime */
+	val64 = cpu_to_le64(prm->meas_start_time);
+	pframe = rtw_set_fixed_ie(pframe, 8, (u8 *)&val64, &my_len);
+
+	/* Measurement Duration */
+	val16 = prm->meas_end_time - prm->meas_start_time;
+	val16 = cpu_to_le16(val16);
+	pframe = rtw_set_fixed_ie(pframe, 2, (u8*)&val16, &my_len);
+
+	/* TODO
+	* ReportedFrameInformation:
+	* 0 :beacon or probe rsp
+	* 1 :pilot frame
+	*/
+	val8 = 0; /* report frame info */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* RCPI */
+	val8 = rm_get_rcpi(prm, pnetwork);
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* RSNI */
+	val8 = rm_get_rsni(prm, pnetwork);
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* BSSID */
+	pframe = rtw_set_fixed_ie(pframe, 6,
+		(u8 *)&pnetwork->network.MacAddress, &my_len);
+
+	/*
+	 * AntennaID
+	 * 0: unknown
+	 * 255: multiple antenna (Diversity)
+	 */
+	val8 = 0;
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* ParentTSF */
+	val32 = prm->meas_start_time + pnetwork->network.PhyInfo.free_cnt;
+	pframe = rtw_set_fixed_ie(pframe, 4, (u8 *)&val32, &my_len);
+
+	/* Generate Beacon detail */
+	pframe = rm_gen_bcn_detail_elem(padapter, pframe,
+		prm, pnetwork, &my_len);
+done:
+	/*
+	* update my length
+	* content length does NOT include ID and LEN
+	*/
+	val8 = my_len - 2;
+	rtw_set_fixed_ie(plen, 1, &val8, &i);
+
+	/* update length to caller */
+	*fr_len += my_len;
+
+	return pframe;
+}
+
+static int retrieve_scan_result(struct rm_obj *prm)
+{
+	_irqL irqL;
+	_list *plist, *phead;
+	_queue *queue;
+	_adapter *padapter = prm->psta->padapter;
+	struct rtw_ieee80211_channel *pch_set;
+	struct wlan_network *pnetwork = NULL;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	int i, meas_ch_num=0;
+	PWLAN_BSSID_EX pbss;
+	unsigned int matched_network;
+	int len, my_len;
+	u8 buf_idx, *pbuf = NULL, *tmp_buf = NULL;
+
+
+	tmp_buf = rtw_malloc(MAX_XMIT_EXTBUF_SZ);
+	if (tmp_buf == NULL)
+		return 0;
+
+	my_len = 0;
+	buf_idx = 0;
+	matched_network = 0;
+	queue = &(pmlmepriv->scanned_queue);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	/* get requested measurement channel set */
+	pch_set = prm->q.ch_set;
+	meas_ch_num = prm->q.ch_set_ch_amount;
+
+	/* search scan queue to find requested SSID */
+	while (1) {
+
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		pbss = &pnetwork->network;
+
+		/*
+		* report network if requested channel set contains
+		* the channel matchs selected network
+		*/
+		if (rtw_chset_search_ch(adapter_to_chset(padapter),
+			pbss->Configuration.DSConfig) == 0)
+			goto next;
+
+		if (rtw_mlme_band_check(padapter, pbss->Configuration.DSConfig)
+			== _FALSE)
+			goto next;
+
+		if (rtw_validate_ssid(&(pbss->Ssid)) == _FALSE)
+			goto next;
+
+		/* go through measurement requested channels */
+		for (i = 0; i < meas_ch_num; i++) {
+
+			/* match channel */
+			if (pch_set[i].hw_value != pbss->Configuration.DSConfig)
+				continue;
+
+			/* match bssid */
+			if (is_wildcard_bssid(prm->q.bssid) == FALSE)
+				if (_rtw_memcmp(prm->q.bssid,
+					pbss->MacAddress, 6) == _FALSE) {
+					continue;
+				}
+			/*
+			 * default wildcard SSID. wildcard SSID:
+			 * A SSID value (null) used to represent all SSIDs
+			 */
+
+			/* match ssid */
+			if ((prm->q.opt.bcn.ssid.SsidLength > 0) &&
+				_rtw_memcmp(prm->q.opt.bcn.ssid.Ssid,
+				pbss->Ssid.Ssid,
+				prm->q.opt.bcn.ssid.SsidLength) == _FALSE)
+				continue;
+
+			/* match condition */
+			if (rm_bcn_req_cond_mach(prm, pnetwork) == _FALSE) {
+				RTW_INFO("RM: condition mismatch ch %u ssid %s bssid "MAC_FMT"\n",
+					pch_set[i].hw_value, pbss->Ssid.Ssid,
+					MAC_ARG(pbss->MacAddress));
+				RTW_INFO("RM: condition %u:%u\n",
+					prm->q.opt.bcn.rep_cond.cond,
+					prm->q.opt.bcn.rep_cond.threshold);
+				continue;
+			}
+
+			/* Found a matched SSID */
+			matched_network++;
+
+			RTW_INFO("RM: ch %u Found %s bssid "MAC_FMT"\n",
+				pch_set[i].hw_value, pbss->Ssid.Ssid,
+				MAC_ARG(pbss->MacAddress));
+
+			len = 0;
+			_rtw_memset(tmp_buf, 0, MAX_XMIT_EXTBUF_SZ);
+			rm_gen_bcn_rep_ie(prm, tmp_buf, pnetwork, &len);
+new_packet:
+			if (my_len == 0) {
+				pbuf = rtw_malloc(MAX_XMIT_EXTBUF_SZ);
+				if (pbuf == NULL)
+					goto fail;
+				prm->buf[buf_idx].pbuf = pbuf;
+			}
+
+			if ((MAX_XMIT_EXTBUF_SZ - (my_len+len+24+4)) > 0) {
+				pbuf = rtw_set_fixed_ie(pbuf,
+					len, tmp_buf, &my_len);
+				prm->buf[buf_idx].len = my_len;
+			} else {
+				if (my_len == 0) /* not enough space */
+					goto fail;
+
+				my_len = 0;
+				buf_idx++;
+				goto new_packet;
+			}
+		} /* for() */
+next:
+		plist = get_next(plist);
+	} /* while() */
+fail:
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	if (tmp_buf)
+		rtw_mfree(tmp_buf, MAX_XMIT_EXTBUF_SZ);
+
+	RTW_INFO("RM: Found %d matched %s\n", matched_network,
+		prm->q.opt.bcn.ssid.Ssid);
+
+	if (prm->buf[buf_idx].pbuf)
+		return buf_idx+1;
+
+	return 0;
+}
+
+int issue_beacon_rep(struct rm_obj *prm)
+{
+	int i, my_len;
+	u8 *pframe;
+	_adapter *padapter = prm->psta->padapter;
+	struct pkt_attrib *pattr;
+	struct xmit_frame *pmgntframe;
+	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+	int pkt_num;
+
+
+	pkt_num = retrieve_scan_result(prm);
+
+	if (pkt_num == 0) {
+		issue_null_reply(prm);
+		return _SUCCESS;
+	}
+
+	for (i=0;i<pkt_num;i++) {
+
+		pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+		if (pmgntframe == NULL) {
+			RTW_ERR("RM: %s alloc xmit_frame fail\n",__func__);
+			goto fail;
+		}
+		pattr = &pmgntframe->attrib;
+		pframe = build_wlan_hdr(padapter,
+			pmgntframe, prm->psta, WIFI_ACTION);
+		pframe = rtw_set_fixed_ie(pframe,
+			3, &prm->p.category, &pattr->pktlen);
+
+		my_len = 0;
+		pframe = rtw_set_fixed_ie(pframe,
+			prm->buf[i].len, prm->buf[i].pbuf, &my_len);
+
+		pattr->pktlen += my_len;
+		pattr->last_txcmdsz = pattr->pktlen;
+		dump_mgntframe(padapter, pmgntframe);
+	}
+fail:
+	for (i=0;i<pkt_num;i++) {
+		if (prm->buf[i].pbuf) {
+			rtw_mfree(prm->buf[i].pbuf, MAX_XMIT_EXTBUF_SZ);
+			prm->buf[i].pbuf = NULL;
+			prm->buf[i].len = 0;
+		}
+	}
+	return _SUCCESS;
+}
+
+/* neighbor request */
+int issue_nb_req(struct rm_obj *prm)
+{
+	_adapter *padapter = prm->psta->padapter;
+	struct sta_info *psta = prm->psta;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct xmit_frame *pmgntframe = NULL;
+	struct pkt_attrib *pattr = NULL;
+	u8 val8;
+	u8 *pframe = NULL;
+
+
+	RTW_INFO("RM: %s\n", __func__);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		RTW_ERR("RM: %s alloc xmit_frame fail\n",__func__);
+		return _FALSE;
+	}
+	pattr = &pmgntframe->attrib;
+	pframe = build_wlan_hdr(padapter, pmgntframe, psta, WIFI_ACTION);
+	pframe = rtw_set_fixed_ie(pframe,
+		3, &prm->q.category, &pattr->pktlen);
+
+	if (prm->q.pssid) {
+
+		u8 sub_ie[64] = {0};
+		u8 *pie = &sub_ie[2];
+
+		RTW_INFO("RM: Send NB Req to "MAC_FMT" for(SSID) %s searching\n",
+			MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
+			pmlmepriv->cur_network.network.Ssid.Ssid);
+
+		val8 = strlen(prm->q.pssid);
+		sub_ie[0] = 0; /*SSID*/
+		sub_ie[1] = val8;
+
+		_rtw_memcpy(pie, prm->q.pssid, val8);
+
+		pframe = rtw_set_fixed_ie(pframe, val8 + 2,
+			sub_ie, &pattr->pktlen);
+	} else {
+
+		if (!pmlmepriv->cur_network.network.Ssid.SsidLength)
+			RTW_INFO("RM: Send NB Req to "MAC_FMT"\n",
+				MAC_ARG(pmlmepriv->cur_network.network.MacAddress));
+		else {
+			u8 sub_ie[64] = {0};
+			u8 *pie = &sub_ie[2];
+
+			RTW_INFO("RM: Send NB Req to "MAC_FMT" for(SSID) %s searching\n",
+				MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
+				pmlmepriv->cur_network.network.Ssid.Ssid);
+
+			sub_ie[0] = 0; /*SSID*/
+			sub_ie[1] = pmlmepriv->cur_network.network.Ssid.SsidLength;
+
+			_rtw_memcpy(pie, pmlmepriv->cur_network.network.Ssid.Ssid,
+				pmlmepriv->cur_network.network.Ssid.SsidLength);
+
+			pframe = rtw_set_fixed_ie(pframe,
+				pmlmepriv->cur_network.network.Ssid.SsidLength + 2,
+				sub_ie, &pattr->pktlen);
+		}
+	}
+
+	pattr->last_txcmdsz = pattr->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
+
+	return _SUCCESS;
+}
+
+static u8 *rm_gen_bcn_req_s_elem(_adapter *padapter,
+	u8 *pframe, unsigned int *fr_len)
+{
+	u8 val8;
+	unsigned int my_len = 0;
+	u8 bssid[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+
+	val8 = bcn_req_active; /* measurement mode T8-64 */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	pframe = rtw_set_fixed_ie(pframe, 6, bssid, &my_len);
+
+	/* update length to caller */
+	*fr_len += my_len;
+
+	/* optional subelements */
+	return pframe;
+}
+
+static u8 *rm_gen_ch_load_req_s_elem(_adapter *padapter,
+	u8 *pframe, unsigned int *fr_len)
+{
+	u8 val8;
+	unsigned int my_len = 0;
+
+
+	val8 = 1; /* 1: channel load T8-60 */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	val8 = 2; /* channel load length = 2 (extensible)  */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	val8 = 0; /* channel load condition : 0 (issue when meas done) T8-61 */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	val8 = 0; /* channel load reference value : 0 */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* update length to caller */
+	*fr_len += my_len;
+
+	return pframe;
+}
+
+static u8 *rm_gen_noise_histo_req_s_elem(_adapter *padapter,
+	u8 *pframe, unsigned int *fr_len)
+{
+	u8 val8;
+	unsigned int my_len = 0;
+
+
+	val8 = 1; /* 1: noise histogram T8-62 */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	val8 = 2; /* noise histogram length = 2 (extensible)  */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	val8 = 0; /* noise histogram condition : 0 (issue when meas done) T8-63 */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	val8 = 0; /* noise histogram reference value : 0 */
+	pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+
+	/* update length to caller */
+	*fr_len += my_len;
+
+	return pframe;
+}
+
+int issue_radio_meas_req(struct rm_obj *prm)
+{
+	u8 val8;
+	u8 *pframe;
+	u8 *plen;
+	u16 val16;
+	int my_len, i;
+	struct xmit_frame *pmgntframe;
+	struct pkt_attrib *pattr;
+	_adapter *padapter = prm->psta->padapter;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+
+
+	RTW_INFO("RM: %s - %s\n", __func__, rm_type_req_name(prm->q.m_type));
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		RTW_ERR("RM: %s alloc xmit_frame fail\n",__func__);
+		return _FALSE;
+	}
+	pattr = &pmgntframe->attrib;
+	pframe = build_wlan_hdr(padapter, pmgntframe, prm->psta, WIFI_ACTION);
+	pframe = rtw_set_fixed_ie(pframe, 3, &prm->q.category, &pattr->pktlen);
+
+	/* repeat */
+	val16 = cpu_to_le16(prm->q.rpt);
+	pframe = rtw_set_fixed_ie(pframe, 2,
+		(unsigned char *)&(val16), &pattr->pktlen);
+
+	my_len = 0;
+	plen = pframe + 1;
+	pframe = rtw_set_fixed_ie(pframe, 7, &prm->q.e_id, &my_len);
+
+	/* random interval */
+	val16 = 100; /* 100 TU */
+	val16 = cpu_to_le16(val16);
+	pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
+
+	/* measurement duration */
+	val16 = 100;
+	val16 = cpu_to_le16(val16);
+	pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
+
+	/* optional subelement */
+	switch (prm->q.m_type) {
+	case bcn_req:
+		pframe = rm_gen_bcn_req_s_elem(padapter, pframe, &my_len);
+		break;
+	case ch_load_req:
+		pframe = rm_gen_ch_load_req_s_elem(padapter, pframe, &my_len);
+		break;
+	case noise_histo_req:
+		pframe = rm_gen_noise_histo_req_s_elem(padapter,
+			pframe, &my_len);
+		break;
+	case basic_req:
+	default:
+		break;
+	}
+
+	/* length */
+	val8 = (u8)my_len - 2;
+	rtw_set_fixed_ie(plen, 1, &val8, &i);
+
+	pattr->pktlen += my_len;
+
+	pattr->last_txcmdsz = pattr->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
+
+	return _SUCCESS;
+}
+
+/* noise histogram */
+static u8 rm_get_anpi(struct rm_obj *prm, struct wlan_network *pnetwork)
+{
+	return translate_percentage_to_rcpi(
+		pnetwork->network.PhyInfo.SignalStrength);
+}
+
+int rm_radio_meas_report_cond(struct rm_obj *prm)
+{
+	u8 val8;
+	int i;
+
+
+	switch (prm->q.m_type) {
+	case ch_load_req:
+
+		val8 = prm->p.ch_load;
+		switch (prm->q.opt.clm.rep_cond.cond) {
+		case ch_load_cond_immediately:
+			return _SUCCESS;
+		case ch_load_cond_anpi_equal_greater:
+			if (val8 >= prm->q.opt.clm.rep_cond.threshold)
+				return _SUCCESS;
+		case ch_load_cond_anpi_equal_less:
+			if (val8 <= prm->q.opt.clm.rep_cond.threshold)
+				return _SUCCESS;
+		default:
+			break;
+		}
+		break;
+	case noise_histo_req:
+		val8 = prm->p.anpi;
+		switch (prm->q.opt.nhm.rep_cond.cond) {
+		case noise_histo_cond_immediately:
+			return _SUCCESS;
+		case noise_histo_cond_anpi_equal_greater:
+			if (val8 >= prm->q.opt.nhm.rep_cond.threshold)
+				return _SUCCESS;
+			break;
+		case noise_histo_cond_anpi_equal_less:
+			if (val8 <= prm->q.opt.nhm.rep_cond.threshold)
+				return _SUCCESS;
+			break;
+		default:
+			break;
+		}
+		break;
+	default:
+		break;
+	}
+	return _FAIL;
+}
+
+int retrieve_radio_meas_result(struct rm_obj *prm)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(prm->psta->padapter);
+	int i, ch = -1;
+	u8 val8;
+
+
+	ch = rtw_chset_search_ch(adapter_to_chset(prm->psta->padapter),
+		prm->q.ch_num);
+
+	if ((ch == -1) || (ch >= MAX_CHANNEL_NUM)) {
+		RTW_ERR("RM: get ch(CH:%d) fail\n", prm->q.ch_num);
+		ch = 0;
+	}
+
+	switch (prm->q.m_type) {
+	case ch_load_req:
+#ifdef CONFIG_RTW_ACS
+		val8 = hal_data->acs.clm_ratio[ch];
+#else
+		val8 = 0;
+#endif
+		prm->p.ch_load = val8;
+		break;
+	case noise_histo_req:
+#ifdef CONFIG_RTW_ACS
+		/* ANPI */
+		prm->p.anpi = hal_data->acs.nhm_ratio[ch];
+
+		/* IPI 0~10 */
+		for (i=0;i<11;i++)
+			prm->p.ipi[i] = hal_data->acs.nhm[ch][i];
+		
+#else
+		val8 = 0;
+		prm->p.anpi = val8;
+		for (i=0;i<11;i++)
+			prm->p.ipi[i] = val8;
+#endif
+		break;
+	default:
+		break;
+	}
+	return _SUCCESS;
+}
+
+int issue_radio_meas_rep(struct rm_obj *prm)
+{
+	u8 val8;
+	u8 *pframe;
+	u8 *plen;
+	u16 val16;
+	u64 val64;
+	unsigned int my_len;
+	_adapter *padapter = prm->psta->padapter;
+	struct xmit_frame *pmgntframe;
+	struct pkt_attrib *pattr;
+	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+	struct sta_info *psta = prm->psta;
+	int i;
+
+
+	RTW_INFO("RM: %s\n", __func__);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		RTW_ERR("RM: ERR %s alloc xmit_frame fail\n",__func__);
+		return _FALSE;
+	}
+	pattr = &pmgntframe->attrib;
+	pframe = build_wlan_hdr(padapter, pmgntframe, psta, WIFI_ACTION);
+	pframe = rtw_set_fixed_ie(pframe, 3,
+		&prm->p.category, &pattr->pktlen);
+
+	my_len = 0;
+	plen = pframe + 1;
+	pframe = rtw_set_fixed_ie(pframe, 7, &prm->p.e_id, &my_len);
+
+	/* Actual Meas start time - 8 bytes */
+	val64 = cpu_to_le64(prm->meas_start_time);
+	pframe = rtw_set_fixed_ie(pframe, 8, (u8 *)&val64, &my_len);
+
+	/* measurement duration */
+	val16 = prm->meas_end_time - prm->meas_start_time;
+	val16 = cpu_to_le16(val16);
+	pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
+
+	/* optional subelement */
+	switch (prm->q.m_type) {
+	case ch_load_req:
+		val8 = prm->p.ch_load;
+		pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+		break;
+	case noise_histo_req:
+		/*
+		 * AntennaID
+		 * 0: unknown
+		 * 255: multiple antenna (Diversity)
+		 */
+		val8 = 0;
+		pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+		/* ANPI */
+		val8 = prm->p.anpi;
+		pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+		/* IPI 0~10 */
+		for (i=0;i<11;i++) {
+			val8 = prm->p.ipi[i];
+			pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
+		}
+		break;
+	default:
+		break;
+	}
+done:
+	/* length */
+	val8 = (u8)my_len-2;
+	rtw_set_fixed_ie(plen, 1, &val8, &i); /* use variable i to ignore it */
+
+	pattr->pktlen += my_len;
+	pattr->last_txcmdsz = pattr->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
+
+	return _SUCCESS;
+}
+
+void rtw_ap_parse_sta_rm_en_cap(_adapter *padapter,
+	struct sta_info *psta, struct rtw_ieee802_11_elems *elem)
+{
+	if (elem->rm_en_cap) {
+		RTW_INFO("assoc.rm_en_cap="RM_CAP_FMT"\n",
+			RM_CAP_ARG(elem->rm_en_cap));
+		_rtw_memcpy(psta->rm_en_cap,
+			(elem->rm_en_cap), elem->rm_en_cap_len);
+	}
+}
+
+void RM_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
+{
+	int i;
+
+	_rtw_memcpy(&padapter->rmpriv.rm_en_cap_assoc, pIE->data, pIE->Length);
+	RTW_INFO("assoc.rm_en_cap="RM_CAP_FMT"\n", RM_CAP_ARG(pIE->data));
+}
+
+/* Debug command */
+
+#if (RM_SUPPORT_IWPRIV_DBG)
+static int hex2num(char c)
+{
+	if (c >= '0' && c <= '9')
+		return c - '0';
+	if (c >= 'a' && c <= 'f')
+		return c - 'a' + 10;
+	if (c >= 'A' && c <= 'F')
+		return c - 'A' + 10;
+	return -1;
+}
+
+int hex2byte(const char *hex)
+{
+	int a, b;
+	a = hex2num(*hex++);
+	if (a < 0)
+		return -1;
+	b = hex2num(*hex++);
+	if (b < 0)
+		return -1;
+	return (a << 4) | b;
+}
+
+static char * hwaddr_parse(char *txt, u8 *addr)
+{
+	size_t i;
+
+	for (i = 0; i < ETH_ALEN; i++) {
+		int a;
+
+		a = hex2byte(txt);
+		if (a < 0)
+			return NULL;
+		txt += 2;
+		addr[i] = a;
+		if (i < ETH_ALEN - 1 && *txt++ != ':')
+			return NULL;
+	}
+	return txt;
+}
+
+void rm_dbg_list_sta(_adapter *padapter, char *s)
+{
+	int i;
+	_irqL irqL;
+	struct sta_info *psta;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	_list *plist, *phead;
+
+
+	sprintf(pstr(s), "\n");
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
+
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist,
+				struct sta_info, hash_list);
+
+			plist = get_next(plist);
+
+			sprintf(pstr(s), "=========================================\n");
+			sprintf(pstr(s), "mac=" MAC_FMT "\n",
+				MAC_ARG(psta->cmn.mac_addr));
+			sprintf(pstr(s), "state=0x%x, aid=%d, macid=%d\n",
+				psta->state, psta->cmn.aid, psta->cmn.mac_id);
+			sprintf(pstr(s), "rm_cap="RM_CAP_FMT"\n",
+				RM_CAP_ARG(psta->rm_en_cap));
+		}
+
+	}
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	sprintf(pstr(s), "=========================================\n");
+}
+
+void rm_dbg_help(_adapter *padapter, char *s)
+{
+	int i;
+
+
+	sprintf(pstr(s), "\n");
+	sprintf(pstr(s), "rrm list_sta\n");
+	sprintf(pstr(s), "rrm list_meas\n");
+
+	sprintf(pstr(s), "rrm add_meas <aid=1|mac=>,m=<bcn|clm|nhm|nb>,rpt=\n");
+	sprintf(pstr(s), "rrm run_meas <aid=1|evid=>\n");
+	sprintf(pstr(s), "rrm del_meas\n");
+
+	sprintf(pstr(s), "rrm run_meas rmid=xxxx,ev=xx\n");
+	sprintf(pstr(s), "rrm activate\n");
+
+	for (i=0;i<RM_EV_max;i++)
+		sprintf(pstr(s), "\t%2d %s\n",i, rm_event_name(i) );
+	sprintf(pstr(s), "\n");
+}
+
+struct sta_info *rm_get_sta(_adapter *padapter, u16 aid, u8* pbssid)
+{
+	int i;
+	_irqL irqL;
+	struct sta_info *psta = NULL;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	_list *plist, *phead;
+
+
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
+
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist,
+				struct sta_info, hash_list);
+
+			plist = get_next(plist);
+
+			if (psta->cmn.aid == aid)
+				goto done;
+
+			if (pbssid && _rtw_memcmp(psta->cmn.mac_addr,
+				pbssid, 6))
+				goto done;
+		}
+
+	}
+	psta = NULL;
+done:
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	return psta;
+}
+
+static int rm_dbg_modify_meas(_adapter *padapter, char *s)
+{
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct mlme_ext_info *pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
+	struct rm_obj *prm;
+	struct sta_info *psta;
+	char *pmac, *ptr, *paid, *prpt, *pnbp, *pclm, *pnhm, *pbcn;
+	unsigned val;
+	u8 bssid[ETH_ALEN];
+
+
+	/* example :
+	* rrm add_meas <aid=1|mac=>,m=<nb|clm|nhm|bcn>,<rept=>
+	* rrm run_meas <aid=1|evid=>
+	*/
+	paid = strstr(s, "aid=");
+	pmac = strstr(s, "mac=");
+	pbcn = strstr(s, "m=bcn");
+	pclm = strstr(s, "m=clm");
+	pnhm = strstr(s, "m=nhm");
+	pnbp = strstr(s, "m=nb");
+	prpt = strstr(s, "rpt=");
+
+	/* set all ',' to NULL (end of line) */
+	ptr = s;
+	while (ptr) {
+		ptr = strchr(ptr, ',');
+		if (ptr) {
+			*(ptr) = 0x0;
+			ptr++;
+		}
+	}
+	prm = (struct rm_obj *)prmpriv->prm_sel;
+	prm->q.m_token = 1;
+	psta = prm->psta;
+
+	if (paid) { /* find sta_info according to aid */
+		paid += 4; /* skip aid= */
+		sscanf(paid, "%u", &val); /* aid=x */
+		psta = rm_get_sta(padapter, val, NULL);
+
+	} else if (pmac) { /* find sta_info according to bssid */
+		pmac += 4; /* skip mac= */
+		if (hwaddr_parse(pmac, bssid) == NULL) {
+			sprintf(pstr(s), "Err: \nincorrect mac format\n");
+			return _FAIL;
+		}
+		psta = rm_get_sta(padapter, 0xff, bssid);
+	}
+
+	if (psta) {
+		prm->psta = psta;
+
+#if 0
+		prm->q.diag_token = psta->rm_diag_token++;
+#else
+		/* TODO dialog should base on sta_info */
+		prm->q.diag_token = pmlmeinfo->dialogToken++;
+#endif
+		prm->rmid = psta->cmn.aid << 16
+			| prm->q.diag_token << 8
+			| RM_MASTER;
+	} else
+		return _FAIL;
+
+	prm->q.action_code = RM_ACT_RADIO_MEAS_REQ;
+	if (pbcn) {
+		prm->q.m_type = bcn_req;
+	} else if (pnhm) {
+		prm->q.m_type = noise_histo_req;
+	} else if (pclm) {
+		prm->q.m_type = ch_load_req;
+	} else if (pnbp) {
+		prm->q.action_code = RM_ACT_NB_REP_REQ;
+	} else
+		return _FAIL;
+
+	if (prpt) {
+		prpt += 4; /* skip rpt= */
+		sscanf(prpt, "%u", &val);
+		prm->q.rpt = (u8)val;
+	}
+
+	return _SUCCESS;
+}
+
+static void rm_dbg_activate_meas(_adapter *padapter, char *s)
+{
+	struct rm_priv *prmpriv = &(padapter->rmpriv);
+	struct rm_obj *prm;
+
+
+	if (prmpriv->prm_sel == NULL) {
+		sprintf(pstr(s), "\nErr: No inActivate measurement\n");
+		return;
+	}
+	prm = (struct rm_obj *)prmpriv->prm_sel;
+
+	/* verify attributes */
+	if (prm->psta == NULL) {
+		sprintf(pstr(s), "\nErr: inActivate meas has no psta\n");
+		return;
+	}
+
+	/* measure current channel */
+	prm->q.ch_num = padapter->mlmeextpriv.cur_channel;
+	prm->q.op_class = rm_get_oper_class_via_ch(prm->q.ch_num);
+
+	/* enquee rmobj */
+	rm_enqueue_rmobj(padapter, prm, _FALSE);
+
+	sprintf(pstr(s), "\nActivate rmid=%x, state=%s, meas_type=%s\n",
+		prm->rmid, rm_state_name(prm->state),
+		rm_type_req_name(prm->q.m_type));
+
+	sprintf(pstr(s), "aid=%d, mac=" MAC_FMT "\n",
+		prm->psta->cmn.aid, MAC_ARG(prm->psta->cmn.mac_addr));
+
+	/* clearn inActivate prm info */
+	prmpriv->prm_sel = NULL;
+}
+
+static void rm_dbg_add_meas(_adapter *padapter, char *s)
+{
+	struct rm_priv *prmpriv = &(padapter->rmpriv);
+	struct rm_obj *prm;
+	char *pact;
+
+
+	/* example :
+	* rrm add_meas <aid=1|mac=>,m=<nb_req|clm_req|nhm_req>
+	* rrm run_meas <aid=1|evid=>
+	*/
+	prm = (struct rm_obj *)prmpriv->prm_sel;
+	if (prm == NULL)
+		prm = rm_alloc_rmobj(padapter);
+
+	if (prm == NULL) {
+		sprintf(pstr(s), "\nErr: alloc meas fail\n");
+		return;
+	}
+
+        prmpriv->prm_sel = prm;
+
+	pact = strstr(s, "act");
+	if (rm_dbg_modify_meas(padapter, s) == _FAIL) {
+
+		sprintf(pstr(s), "\nErr: add meas fail\n");
+		rm_free_rmobj(prm);
+		prmpriv->prm_sel = NULL;
+		return;
+	}
+	prm->q.category = RTW_WLAN_CATEGORY_RADIO_MEAS;
+	prm->q.e_id = _MEAS_REQ_IE_; /* 38 */
+
+	if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ)
+		sprintf(pstr(s), "\nAdd rmid=%x, meas_type=%s ok\n",
+			prm->rmid, rm_type_req_name(prm->q.m_type));
+	else  if (prm->q.action_code == RM_ACT_NB_REP_REQ) 
+		sprintf(pstr(s), "\nAdd rmid=%x, meas_type=bcn_req ok\n",
+			prm->rmid);
+
+	if (prm->psta)
+		sprintf(pstr(s), "mac="MAC_FMT"\n",
+			MAC_ARG(prm->psta->cmn.mac_addr));
+
+	if (pact)
+		rm_dbg_activate_meas(padapter, pstr(s));
+}
+
+static void rm_dbg_del_meas(_adapter *padapter, char *s)
+{
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct rm_obj *prm = (struct rm_obj *)prmpriv->prm_sel;
+
+
+	if (prm) {
+		sprintf(pstr(s), "\ndelete rmid=%x\n",prm->rmid);
+
+		/* free inActivate meas - enqueue yet  */
+		prmpriv->prm_sel = NULL;
+		rtw_mfree(prmpriv->prm_sel, sizeof(struct rm_obj));
+	} else
+		sprintf(pstr(s), "Err: no inActivate measurement\n");
+}
+
+static void rm_dbg_run_meas(_adapter *padapter, char *s)
+{
+	struct rm_obj *prm;
+	char *pevid, *prmid;
+	u32 rmid, evid;
+
+
+	prmid = strstr(s, "rmid="); /* hex */
+	pevid = strstr(s, "evid="); /* dec */
+
+	if (prmid && pevid) {
+		prmid += 5; /* rmid= */
+		sscanf(prmid, "%x", &rmid);
+
+		pevid += 5; /* evid= */
+		sscanf(pevid, "%u", &evid);
+	} else {
+		sprintf(pstr(s), "\nErr: incorrect attribute\n");
+		return;
+	}
+
+	prm = rm_get_rmobj(padapter, rmid);
+
+	if (!prm) {
+		sprintf(pstr(s), "\nErr: measurement not found\n");
+		return;
+	}
+
+	if (evid >= RM_EV_max) {
+		sprintf(pstr(s), "\nErr: wrong event id\n");
+		return;
+	}
+
+	rm_post_event(padapter, prm->rmid, evid);
+	sprintf(pstr(s), "\npost %s to rmid=%x\n",rm_event_name(evid), rmid);
+}
+
+static void rm_dbg_show_meas(struct rm_obj *prm, char *s)
+{
+	struct sta_info *psta;
+
+	psta = prm->psta;
+
+	if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
+
+		sprintf(pstr(s), "\nrmid=%x, meas_type=%s\n",
+			prm->rmid, rm_type_req_name(prm->q.m_type));
+
+	} else  if (prm->q.action_code == RM_ACT_NB_REP_REQ) {
+
+		sprintf(pstr(s), "\nrmid=%x, action=neighbor_req\n",
+			prm->rmid);
+	} else
+		sprintf(pstr(s), "\nrmid=%x, action=unknown\n",
+			prm->rmid);
+
+	if (psta)
+		sprintf(pstr(s), "aid=%d, mac="MAC_FMT"\n",
+			psta->cmn.aid, MAC_ARG(psta->cmn.mac_addr));
+
+	sprintf(pstr(s), "clock=%d, state=%s, rpt=%u/%u\n",
+		(int)ATOMIC_READ(&prm->pclock->counter),
+		rm_state_name(prm->state), prm->p.rpt, prm->q.rpt);
+}
+
+static void rm_dbg_list_meas(_adapter *padapter, char *s)
+{
+	int meas_amount;
+	_irqL irqL;
+	struct rm_obj *prm;
+	struct sta_info *psta;
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	_queue *queue = &prmpriv->rm_queue;
+	_list *plist, *phead;
+
+
+	sprintf(pstr(s), "\n");
+	_enter_critical(&queue->lock, &irqL);
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+	meas_amount = 0;
+
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		prm = LIST_CONTAINOR(plist, struct rm_obj, list);
+		meas_amount++;
+		plist = get_next(plist);
+		psta = prm->psta;
+		sprintf(pstr(s), "=========================================\n");
+
+		rm_dbg_show_meas(prm, s);
+	}
+	_exit_critical(&queue->lock, &irqL);
+
+	sprintf(pstr(s), "=========================================\n");
+
+	if (meas_amount==0) {
+		sprintf(pstr(s), "No Activate measurement\n");
+		sprintf(pstr(s), "=========================================\n");
+	}
+
+	if (prmpriv->prm_sel == NULL)
+		sprintf(pstr(s), "\nNo inActivate measurement\n");
+	else {
+		sprintf(pstr(s), "\ninActivate measurement\n");
+		rm_dbg_show_meas((struct rm_obj *)prmpriv->prm_sel, s);
+	}
+}
+#endif /* RM_SUPPORT_IWPRIV_DBG */
+
+void rm_dbg_cmd(_adapter *padapter, char *s)
+{
+	unsigned val;
+	char *paid;
+	struct sta_info *psta=NULL;
+
+#if (RM_SUPPORT_IWPRIV_DBG)
+	if (_rtw_memcmp(s, "help", 4)) {
+		rm_dbg_help(padapter, s);
+
+	} else if (_rtw_memcmp(s, "list_sta", 8)) {
+		rm_dbg_list_sta(padapter, s);
+
+	} else if (_rtw_memcmp(s, "list_meas", 9)) {
+		rm_dbg_list_meas(padapter, s);
+
+	} else if (_rtw_memcmp(s, "add_meas", 8)) {
+		rm_dbg_add_meas(padapter, s);
+
+	} else if (_rtw_memcmp(s, "del_meas", 8)) {
+		rm_dbg_del_meas(padapter, s);
+
+	} else if (_rtw_memcmp(s, "activate", 8)) {
+		rm_dbg_activate_meas(padapter, s);
+
+	} else if (_rtw_memcmp(s, "run_meas", 8)) {
+		rm_dbg_run_meas(padapter, s);
+	} else if (_rtw_memcmp(s, "nb", 2)) {
+
+		paid = strstr(s, "aid=");
+
+		if (paid) { /* find sta_info according to aid */
+			paid += 4; /* skip aid= */
+			sscanf(paid, "%u", &val); /* aid=x */
+			psta = rm_get_sta(padapter, val, NULL);
+
+			if (psta)
+				rm_add_nb_req(padapter, psta);
+		}
+	}
+#else
+	sprintf(pstr(s), "\n");
+	sprintf(pstr(s), "rrm debug command was disabled\n");
+#endif
+}
+#endif /* CONFIG_RTW_80211K */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rm_fsm.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rm_fsm.c
new file mode 100644
index 000000000000..d377f40f16e9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rm_fsm.c
@@ -0,0 +1,999 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+#include "rtw_rm_fsm.h"
+
+#ifdef CONFIG_RTW_80211K
+
+struct fsm_state {
+	u8 *name;
+	int(*fsm_func)(struct rm_obj *prm, enum RM_EV_ID evid);
+};
+
+static void rm_state_initial(struct rm_obj *prm);
+static void rm_state_goto(struct rm_obj *prm, enum RM_STATE rm_state);
+static void rm_state_run(struct rm_obj *prm, enum RM_EV_ID evid);
+static struct rm_event *rm_dequeue_ev(_queue *queue);
+static struct rm_obj *rm_dequeue_rm(_queue *queue);
+
+void rm_timer_callback(void *data)
+{
+	int i;
+	_adapter *padapter = (_adapter *)data;
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct rm_clock *pclock;
+
+
+	/* deal with clock */
+	for (i=0;i<RM_TIMER_NUM;i++) {
+		pclock = &prmpriv->clock[i];
+		if (pclock->prm == NULL
+			||(ATOMIC_READ(&(pclock->counter)) == 0))
+			continue;
+
+		ATOMIC_DEC(&(pclock->counter));
+
+		if (ATOMIC_READ(&(pclock->counter)) == 0)
+			rm_post_event(pclock->prm->psta->padapter,
+				pclock->prm->rmid, prmpriv->clock[i].evid);
+	}
+	_set_timer(&prmpriv->rm_timer, CLOCK_UNIT);
+}
+
+int rtw_init_rm(_adapter *padapter)
+{
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+
+
+	RTW_INFO("RM: %s\n",__func__);
+	_rtw_init_queue(&(prmpriv->rm_queue));
+	_rtw_init_queue(&(prmpriv->ev_queue));
+
+	/* bit 0-7 */
+	prmpriv->rm_en_cap_def[0] = 0
+		/*| BIT(RM_LINK_MEAS_CAP_EN)*/
+		| BIT(RM_NB_REP_CAP_EN)
+		/*| BIT(RM_PARAL_MEAS_CAP_EN)*/
+		| BIT(RM_REPEAT_MEAS_CAP_EN)
+		| BIT(RM_BCN_PASSIVE_MEAS_CAP_EN)
+		| BIT(RM_BCN_ACTIVE_MEAS_CAP_EN)
+		| BIT(RM_BCN_TABLE_MEAS_CAP_EN)
+		/*| BIT(RM_BCN_MEAS_REP_COND_CAP_EN)*/;
+
+	/* bit  8-15 */
+	prmpriv->rm_en_cap_def[1] = 0
+		/*| BIT(RM_FRAME_MEAS_CAP_EN - 8)*/
+#ifdef CONFIG_RTW_ACS
+		| BIT(RM_CH_LOAD_CAP_EN - 8)
+		| BIT(RM_NOISE_HISTO_CAP_EN - 8)
+#endif
+		/*| BIT(RM_STATIS_MEAS_CAP_EN - 8)*/
+		/*| BIT(RM_LCI_MEAS_CAP_EN - 8)*/
+		/*| BIT(RM_LCI_AMIMUTH_CAP_EN - 8)*/
+		/*| BIT(RM_TRANS_STREAM_CAT_MEAS_CAP_EN - 8)*/
+		/*| BIT(RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN - 8)*/;
+
+	/* bit 16-23 */
+	prmpriv->rm_en_cap_def[2] = 0
+		/*| BIT(RM_AP_CH_REP_CAP_EN - 16)*/
+		/*| BIT(RM_RM_MIB_CAP_EN - 16)*/
+		/*| BIT(RM_OP_CH_MAX_MEAS_DUR0 - 16)*/
+		/*| BIT(RM_OP_CH_MAX_MEAS_DUR1 - 16)*/
+		/*| BIT(RM_OP_CH_MAX_MEAS_DUR2 - 16)*/
+		/*| BIT(RM_NONOP_CH_MAX_MEAS_DUR0 - 16)*/
+		/*| BIT(RM_NONOP_CH_MAX_MEAS_DUR1 - 16)*/
+		/*| BIT(RM_NONOP_CH_MAX_MEAS_DUR2 - 16)*/;
+
+	/* bit 24-31 */
+	prmpriv->rm_en_cap_def[3] = 0
+		/*| BIT(RM_MEAS_PILOT_CAP0 - 24)*/
+		/*| BIT(RM_MEAS_PILOT_CAP1 - 24)*/
+		/*| BIT(RM_MEAS_PILOT_CAP2 - 24)*/
+		/*| BIT(RM_MEAS_PILOT_TRANS_INFO_CAP_EN - 24)*/
+		/*| BIT(RM_NB_REP_TSF_OFFSET_CAP_EN - 24)*/
+		| BIT(RM_RCPI_MEAS_CAP_EN - 24)
+		| BIT(RM_RSNI_MEAS_CAP_EN - 24)
+		/*| BIT(RM_BSS_AVG_ACCESS_DELAY_CAP_EN - 24)*/;
+
+	/* bit 32-39 */
+	prmpriv->rm_en_cap_def[4] = 0
+		/*| BIT(RM_BSS_AVG_ACCESS_DELAY_CAP_EN - 32)*/
+		/*| BIT(RM_AVALB_ADMIS_CAPACITY_CAP_EN - 32)*/
+		/*| BIT(RM_ANT_CAP_EN - 32)*/;
+
+	prmpriv->enable = _TRUE;
+
+	/* clock timer */
+	rtw_init_timer(&prmpriv->rm_timer,
+		padapter, rm_timer_callback, padapter);
+	_set_timer(&prmpriv->rm_timer, CLOCK_UNIT);
+
+	return _SUCCESS;
+}
+
+int rtw_deinit_rm(_adapter *padapter)
+{
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct rm_obj *prm;
+	struct rm_event *pev;
+
+
+	RTW_INFO("RM: %s\n",__func__);
+	prmpriv->enable = _FALSE;
+	_cancel_timer_ex(&prmpriv->rm_timer);
+
+	/* free all events and measurements */
+	while((pev = rm_dequeue_ev(&prmpriv->ev_queue)) != NULL)
+		rtw_mfree((void *)pev, sizeof(struct rm_event));
+
+	while((prm = rm_dequeue_rm(&prmpriv->rm_queue)) != NULL)
+		rm_state_run(prm, RM_EV_cancel);
+
+	_rtw_deinit_queue(&(prmpriv->rm_queue));
+	_rtw_deinit_queue(&(prmpriv->ev_queue));
+
+	return _SUCCESS;
+}
+
+int rtw_free_rm_priv(_adapter *padapter)
+{
+	return rtw_deinit_rm(padapter);
+}
+
+static int rm_enqueue_ev(_queue *queue, struct rm_event *obj, bool to_head)
+{
+	_irqL irqL;
+
+
+	if (obj == NULL)
+		return _FAIL;
+
+	_enter_critical(&queue->lock, &irqL);
+
+	if (to_head)
+		rtw_list_insert_head(&obj->list, &queue->queue);
+	else
+		rtw_list_insert_tail(&obj->list, &queue->queue);
+
+	_exit_critical(&queue->lock, &irqL);
+
+	return _SUCCESS;
+}
+
+static void rm_set_clock(struct rm_obj *prm, u32 ms, enum RM_EV_ID evid)
+{
+	ATOMIC_SET(&(prm->pclock->counter), (ms/CLOCK_UNIT));
+	prm->pclock->evid = evid;
+}
+
+static struct rm_clock *rm_alloc_clock(_adapter *padapter, struct rm_obj *prm)
+{
+	int i;
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct rm_clock *pclock = NULL;
+
+
+	for (i=0;i<RM_TIMER_NUM;i++) {
+		pclock = &prmpriv->clock[i];
+
+		if (pclock->prm == NULL) {
+			pclock->prm = prm;
+			ATOMIC_SET(&(pclock->counter), 0);
+			pclock->evid = RM_EV_max;
+			break;
+		}
+	}
+	return pclock;
+}
+
+static void rm_cancel_clock(struct rm_obj *prm)
+{
+	ATOMIC_SET(&(prm->pclock->counter), 0);
+	prm->pclock->evid = RM_EV_max;
+}
+
+static void rm_free_clock(struct rm_clock *pclock)
+{
+	pclock->prm = NULL;
+	ATOMIC_SET(&(pclock->counter), 0);
+	pclock->evid = RM_EV_max;
+}
+
+static int is_list_linked(const struct list_head *head)
+{
+	return head->prev != NULL;
+}
+
+void rm_free_rmobj(struct rm_obj *prm)
+{
+	if (is_list_linked(&prm->list))
+		rtw_list_delete(&prm->list);
+
+	if (prm->q.pssid)
+		rtw_mfree(prm->q.pssid, strlen(prm->q.pssid)+1);
+
+	if (prm->q.opt.bcn.req_start)
+		rtw_mfree(prm->q.opt.bcn.req_start,
+			prm->q.opt.bcn.req_len);
+
+	if (prm->pclock)
+		rm_free_clock(prm->pclock);
+
+	rtw_mfree((void *)prm, sizeof(struct rm_obj));
+}
+
+struct rm_obj *rm_alloc_rmobj(_adapter *padapter)
+{
+	struct rm_obj *prm;
+
+
+	prm = (struct rm_obj *)rtw_malloc(sizeof(struct rm_obj));
+	if (prm == NULL)
+		return NULL;
+
+	_rtw_memset(prm, 0, sizeof(struct rm_obj));
+
+	/* alloc timer */
+	if ((prm->pclock = rm_alloc_clock(padapter, prm)) == NULL) {
+		rm_free_rmobj(prm);
+		return NULL;
+	}
+	return prm;
+}
+
+int rm_enqueue_rmobj(_adapter *padapter, struct rm_obj *prm, bool to_head)
+{
+	_irqL irqL;
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	_queue *queue = &prmpriv->rm_queue;
+
+
+	if (prm == NULL)
+		return _FAIL;
+
+	_enter_critical(&queue->lock, &irqL);
+	if (to_head)
+		rtw_list_insert_head(&prm->list, &queue->queue);
+	else
+		rtw_list_insert_tail(&prm->list, &queue->queue);
+	_exit_critical(&queue->lock, &irqL);
+
+	rm_state_initial(prm);
+
+	return _SUCCESS;
+}
+
+static struct rm_obj *rm_dequeue_rm(_queue *queue)
+{
+	_irqL irqL;
+	struct rm_obj *prm;
+
+
+	_enter_critical(&queue->lock, &irqL);
+	if (rtw_is_list_empty(&(queue->queue)))
+		prm = NULL;
+	else {
+		prm = LIST_CONTAINOR(get_next(&(queue->queue)),
+			struct rm_obj, list);
+		/* rtw_list_delete(&prm->list); */
+	}
+	_exit_critical(&queue->lock, &irqL);
+
+	return prm;
+}
+
+static struct rm_event *rm_dequeue_ev(_queue *queue)
+{
+	_irqL irqL;
+	struct rm_event *ev;
+
+
+	_enter_critical(&queue->lock, &irqL);
+	if (rtw_is_list_empty(&(queue->queue)))
+		ev = NULL;
+	else {
+		ev = LIST_CONTAINOR(get_next(&(queue->queue)),
+			struct rm_event, list);
+		rtw_list_delete(&ev->list);
+	}
+	_exit_critical(&queue->lock, &irqL);
+
+	return ev;
+}
+
+static struct rm_obj *_rm_get_rmobj(_queue *queue, u32 rmid)
+{
+	_irqL irqL;
+	_list *phead, *plist;
+	struct rm_obj *prm = NULL;
+
+
+	if (rmid == 0)
+		return NULL;
+
+	_enter_critical(&queue->lock, &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+
+		prm = LIST_CONTAINOR(plist, struct rm_obj, list);
+		if (rmid == (prm->rmid)) {
+			_exit_critical(&queue->lock, &irqL);
+			return prm;
+		}
+		plist = get_next(plist);
+	}
+	_exit_critical(&queue->lock, &irqL);
+
+	return NULL;
+}
+
+struct sta_info *rm_get_psta(_adapter *padapter, u32 rmid)
+{
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct rm_obj *prm;
+
+
+	prm = _rm_get_rmobj(&prmpriv->rm_queue, rmid);
+
+	if (prm)
+		return prm->psta;
+
+	return NULL;
+}
+
+struct rm_obj *rm_get_rmobj(_adapter *padapter, u32 rmid)
+{
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+
+	return _rm_get_rmobj(&prmpriv->rm_queue, rmid);
+}
+
+u8 rtw_rm_post_envent_cmd(_adapter *padapter, u32 rmid, u8 evid)
+{
+	struct cmd_obj *pcmd;
+	struct rm_event *pev;
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	u8 res = _SUCCESS;
+
+
+	pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (pcmd == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+	pev = (struct rm_event*)rtw_zmalloc(sizeof(struct rm_event));
+
+	if (pev == NULL) {
+		rtw_mfree((u8 *) pcmd, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+	pev->rmid = rmid;
+	pev->evid = evid;
+
+	init_h2fwcmd_w_parm_no_rsp(pcmd, pev, GEN_CMD_CODE(_RM_POST_EVENT));
+	res = rtw_enqueue_cmd(pcmdpriv, pcmd);
+exit:
+	return res;
+}
+
+int rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid)
+{
+	if (padapter->rmpriv.enable == _FALSE)
+		return _FALSE;
+
+	RTW_INFO("RM: post asyn %s to rmid=%x\n", rm_event_name(evid), rmid);
+	rtw_rm_post_envent_cmd(padapter, rmid, evid);
+	return _SUCCESS;
+}
+
+int _rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid)
+{
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct rm_event *pev;
+
+	if (evid >= RM_EV_max || rmid == 0)
+		return _FALSE;
+
+	pev = (struct rm_event *)rtw_malloc(sizeof(struct rm_event));
+	if (pev == NULL)
+		return _FALSE;
+
+	pev->rmid = rmid;
+	pev->evid = evid;
+
+	RTW_INFO("RM: post sync %s to rmid=%x\n", rm_event_name(evid), rmid);
+	rm_enqueue_ev(&prmpriv->ev_queue, pev, FALSE);
+
+	return _SUCCESS;
+}
+
+static void rm_bcast_aid_handler(_adapter *padapter, struct rm_event *pev)
+{
+	_irqL irqL;
+	_list *phead, *plist;
+	_queue *queue = &padapter->rmpriv.rm_queue;
+	struct rm_obj *prm;
+
+
+	_enter_critical(&queue->lock, &irqL);
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+
+		prm = LIST_CONTAINOR(plist, struct rm_obj, list);
+		plist = get_next(plist);
+		if (RM_GET_AID(pev->rmid) == RM_GET_AID(prm->rmid)) {
+			_exit_critical(&queue->lock, &irqL);
+			rm_state_run(prm, pev->evid);
+			_enter_critical(&queue->lock, &irqL);
+		}
+	}
+	_exit_critical(&queue->lock, &irqL);
+	return;
+}
+
+/* main handler of RM (Resource Management) */
+void rm_handler(_adapter *padapter, struct rm_event *pe)
+{
+	int i;
+	struct rm_priv *prmpriv = &padapter->rmpriv;
+	struct rm_obj *prm;
+	struct rm_event *pev;
+
+
+	/* dequeue event */
+	while((pev = rm_dequeue_ev(&prmpriv->ev_queue)) != NULL)
+	{
+		if (RM_IS_ID_FOR_ALL(pev->rmid)) {
+			/* apply to all aid mateched measurement */
+			rm_bcast_aid_handler(padapter, pev);
+			rtw_mfree((void *)pev, sizeof(struct rm_event));
+			continue;
+		}
+
+		/* retrieve rmobj */
+		prm = _rm_get_rmobj(&prmpriv->rm_queue, pev->rmid);
+		if (prm == NULL) {
+			RTW_ERR("RM: rmid=%x event=%s doesn't find rm obj\n",
+				pev->rmid, rm_event_name(pev->evid));
+			rtw_mfree((void *)pev, sizeof(struct rm_event));
+			return;
+		}
+		/* run state machine */
+		rm_state_run(prm, pev->evid);
+		rtw_mfree((void *)pev, sizeof(struct rm_event));
+	}
+}
+
+static int rm_issue_meas_req(struct rm_obj *prm)
+{
+	switch (prm->q.action_code) {
+	case RM_ACT_RADIO_MEAS_REQ:
+		switch (prm->q.m_type) {
+		case bcn_req:
+		case ch_load_req:
+		case noise_histo_req:
+			issue_radio_meas_req(prm);
+			break;
+		default:
+			break;
+		} /* meas_type */
+		break;
+	case RM_ACT_NB_REP_REQ:
+		/* issue neighbor request */
+		issue_nb_req(prm);
+		break;
+	case RM_ACT_LINK_MEAS_REQ:
+	default:
+		return _FALSE;
+	} /* action_code */
+
+	return _SUCCESS;
+}
+
+/*
+* RM state machine
+*/
+
+static int rm_state_idle(struct rm_obj *prm, enum RM_EV_ID evid)
+{
+	_adapter *padapter = prm->psta->padapter;
+	u8 val8;
+	u32 val32;
+
+
+	prm->p.category = RTW_WLAN_CATEGORY_RADIO_MEAS;
+
+	switch (evid) {
+	case RM_EV_state_in:
+		switch (prm->q.action_code) {
+		case RM_ACT_RADIO_MEAS_REQ:
+			/* copy attrib from meas_req to meas_rep */
+			prm->p.action_code = RM_ACT_RADIO_MEAS_REP;
+			prm->p.diag_token = prm->q.diag_token;
+			prm->p.e_id = _MEAS_RSP_IE_;
+			prm->p.m_token = prm->q.m_token;
+			prm->p.m_type = prm->q.m_type;
+			prm->p.rpt = prm->q.rpt;
+			prm->p.ch_num = prm->q.ch_num;
+			prm->p.op_class = prm->q.op_class;
+
+			if (prm->q.m_type == ch_load_req
+				|| prm->q.m_type == noise_histo_req) {
+				/*
+				 * phydm measure current ch periodically
+				 * scan current ch is not necessary
+				 */
+				val8 = padapter->mlmeextpriv.cur_channel;
+				if (prm->q.ch_num == val8)
+					prm->poll_mode = 1;
+			}
+			RTW_INFO("RM: rmid=%x %s switch in repeat=%u\n",
+				prm->rmid, rm_type_req_name(prm->q.m_type),
+				prm->q.rpt);
+			break;
+		case RM_ACT_NB_REP_REQ:
+			prm->p.action_code = RM_ACT_NB_REP_RESP;
+			RTW_INFO("RM: rmid=%x Neighbor request switch in\n",
+				prm->rmid);
+			break;
+		case RM_ACT_LINK_MEAS_REQ:
+			prm->p.action_code = RM_ACT_LINK_MEAS_REP;
+			rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
+			RTW_INFO("RM: rmid=%x Link meas switch in\n",
+				prm->rmid);
+			break;
+		default:
+			prm->p.action_code = prm->q.action_code;
+			rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
+			RTW_INFO("RM: rmid=%x recv unknown action %d\n",
+				prm->rmid,prm->p.action_code);
+			break;
+		} /* switch() */
+
+		if (prm->rmid & RM_MASTER) {
+			if (rm_issue_meas_req(prm) == _SUCCESS)
+				rm_state_goto(prm, RM_ST_WAIT_MEAS);
+			else
+				rm_state_goto(prm, RM_ST_END);
+			return _SUCCESS;
+		} else {
+			rm_state_goto(prm, RM_ST_DO_MEAS);
+			return _SUCCESS;
+		}
+
+		if (prm->p.m_mode) {
+			issue_null_reply(prm);
+			rm_state_goto(prm, RM_ST_END);
+			return _SUCCESS;
+		}
+		if (prm->q.rand_intvl) {
+			/* get low tsf to generate random interval */
+			val32 = rtw_read32(padapter, REG_TSFTR);
+			val32 = val32 % prm->q.rand_intvl;
+			RTW_INFO("RM: rmid=%x rand_intval=%d, rand=%d\n",
+				prm->rmid, (int)prm->q.rand_intvl,val32);
+			rm_set_clock(prm, prm->q.rand_intvl,
+				RM_EV_delay_timer_expire);
+			return _SUCCESS;
+		}
+		break;
+	case RM_EV_delay_timer_expire:
+		rm_state_goto(prm, RM_ST_DO_MEAS);
+		break;
+	case RM_EV_cancel:
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_state_out:
+		rm_cancel_clock(prm);
+		break;
+	default:
+		break;
+	}
+	return _SUCCESS;
+}
+
+/* we do the measuring */
+static int rm_state_do_meas(struct rm_obj *prm, enum RM_EV_ID evid)
+{
+	_adapter *padapter = prm->psta->padapter;
+	u8 val8;
+	u64 val64;
+
+
+	switch (evid) {
+	case RM_EV_state_in:
+		if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
+			switch (prm->q.m_type) {
+			case bcn_req:
+				if (prm->q.m_mode == bcn_req_bcn_table) {
+					RTW_INFO("RM: rmid=%x Beacon table\n",
+						prm->rmid);
+					_rm_post_event(padapter, prm->rmid,
+						RM_EV_survey_done);
+					return _SUCCESS;
+				}
+				break;
+			case ch_load_req:
+			case noise_histo_req:
+				if (prm->poll_mode)
+					_rm_post_event(padapter, prm->rmid,
+						RM_EV_survey_done);
+				return _SUCCESS;
+			default:
+				rm_state_goto(prm, RM_ST_END);
+				return _SUCCESS;
+			}
+
+			if (!ready_for_scan(prm)) {
+				prm->wait_busy = RM_BUSY_TRAFFIC_TIMES;
+				RTW_INFO("RM: wait busy traffic - %d\n",
+					prm->wait_busy);
+				rm_set_clock(prm, RM_WAIT_BUSY_TIMEOUT,
+					RM_EV_busy_timer_expire);
+				return _SUCCESS;
+			}
+		}
+		_rm_post_event(padapter, prm->rmid, RM_EV_start_meas);
+		break;
+	case RM_EV_start_meas:
+		if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
+			/* resotre measurement start time */
+			rtw_hal_get_hwreg(padapter, HW_VAR_TSF, (u8 *)&val64);
+			prm->meas_start_time = val64;
+
+			switch (prm->q.m_type) {
+			case bcn_req:
+				val8 = 1; /* Enable free run counter */
+				rtw_hal_set_hwreg(padapter,
+					HW_VAR_FREECNT, &val8);
+				rm_sitesurvey(prm);
+				break;
+			case ch_load_req:
+			case noise_histo_req:
+				rm_sitesurvey(prm);
+				break;
+			default:
+				rm_state_goto(prm, RM_ST_END);
+				return _SUCCESS;
+				break;
+			}
+		}
+		/* handle measurement timeout */
+		rm_set_clock(prm, RM_MEAS_TIMEOUT, RM_EV_meas_timer_expire);
+		break;
+	case RM_EV_survey_done:
+		if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
+			switch (prm->q.m_type) {
+			case bcn_req:
+				rm_cancel_clock(prm);
+				rm_state_goto(prm, RM_ST_SEND_REPORT);
+				return _SUCCESS;
+			case ch_load_req:
+			case noise_histo_req:
+				retrieve_radio_meas_result(prm);
+
+				if (rm_radio_meas_report_cond(prm) == _SUCCESS)
+					rm_state_goto(prm, RM_ST_SEND_REPORT);
+				else
+					rm_set_clock(prm, RM_COND_INTVL,
+						RM_EV_retry_timer_expire);
+				break;
+			default:
+				rm_state_goto(prm, RM_ST_END);
+				return _SUCCESS;
+			}
+		}
+		break;
+	case RM_EV_meas_timer_expire:
+		RTW_INFO("RM: rmid=%x measurement timeount\n",prm->rmid);
+		rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
+		issue_null_reply(prm);
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_busy_timer_expire:
+		if (!ready_for_scan(prm) && prm->wait_busy--) {
+			RTW_INFO("RM: wait busy - %d\n",prm->wait_busy);
+			rm_set_clock(prm, RM_WAIT_BUSY_TIMEOUT,
+				RM_EV_busy_timer_expire);
+			break;
+		}
+		else if (prm->wait_busy <= 0) {
+			RTW_INFO("RM: wait busy timeout\n");
+			rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
+			issue_null_reply(prm);
+			rm_state_goto(prm, RM_ST_END);
+			return _SUCCESS;
+		}
+		_rm_post_event(padapter, prm->rmid, RM_EV_start_meas);
+		break;
+	case RM_EV_request_timer_expire:
+		rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
+		issue_null_reply(prm);
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_retry_timer_expire:
+		/* expired due to meas condition mismatch, meas again */
+		_rm_post_event(padapter, prm->rmid, RM_EV_start_meas);
+		break;
+	case RM_EV_cancel:
+		rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
+		issue_null_reply(prm);
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_state_out:
+		rm_cancel_clock(prm);
+		/* resotre measurement end time */
+		rtw_hal_get_hwreg(padapter, HW_VAR_TSF, (u8 *)&val64);
+		_rtw_memcpy(&prm->meas_end_time, (char *)&val64, sizeof(u64));
+
+		val8 = 0; /* Disable free run counter */
+		rtw_hal_set_hwreg(padapter, HW_VAR_FREECNT, &val8);
+		break;
+	default:
+		break;
+	}
+
+	return _SUCCESS;
+}
+
+static int rm_state_wait_meas(struct rm_obj *prm, enum RM_EV_ID evid)
+{
+	u8 val8;
+	u64 val64;
+
+
+	switch (evid) {
+	case RM_EV_state_in:
+		/* we create meas_req, waiting for peer report */
+		rm_set_clock(prm, RM_REQ_TIMEOUT,
+			RM_EV_request_timer_expire);
+		break;
+	case RM_EV_recv_rep:
+		rm_state_goto(prm, RM_ST_RECV_REPORT);
+		break;
+	case RM_EV_request_timer_expire:
+	case RM_EV_cancel:
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_state_out:
+		rm_cancel_clock(prm);
+		break;
+	default:
+		break;
+	}
+	return _SUCCESS;
+}
+
+static int rm_state_send_report(struct rm_obj *prm, enum RM_EV_ID evid)
+{
+	u8 val8;
+
+
+	switch (evid) {
+	case RM_EV_state_in:
+		/* we have to issue report */
+		switch (prm->q.m_type) {
+		case bcn_req:
+			issue_beacon_rep(prm);
+			break;
+		case ch_load_req:
+		case noise_histo_req:
+			issue_radio_meas_rep(prm);
+			break;
+		default:
+			rm_state_goto(prm, RM_ST_END);
+			return _SUCCESS;
+		}
+
+		/* check repeat */
+		if (prm->p.rpt) {
+			RTW_INFO("RM: rmid=%x repeat=%u/%u\n",
+				prm->rmid, prm->p.rpt,
+				prm->q.rpt);
+			prm->p.rpt--;
+			/*
+			* we recv meas_req,
+			* delay for a wihile and than meas again
+			*/
+			if (prm->poll_mode)
+				rm_set_clock(prm, RM_REPT_POLL_INTVL,
+					RM_EV_repeat_delay_expire);
+			else
+				rm_set_clock(prm, RM_REPT_SCAN_INTVL,
+					RM_EV_repeat_delay_expire);
+			return _SUCCESS;
+		}
+		/* we are done */
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_repeat_delay_expire:
+		rm_state_goto(prm, RM_ST_DO_MEAS);
+		break;
+	case RM_EV_cancel:
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_state_out:
+		rm_cancel_clock(prm);
+		break;
+	default:
+		break;
+	}
+	return _SUCCESS;
+}
+
+static int rm_state_recv_report(struct rm_obj *prm, enum RM_EV_ID evid)
+{
+	u8 val8;
+
+
+	switch (evid) {
+	case RM_EV_state_in:
+		/* we issue meas_req, got peer's meas report */
+		switch (prm->p.action_code) {
+		case RM_ACT_RADIO_MEAS_REP:
+			/* check refuse, incapable and repeat */
+			val8 = prm->p.m_mode;
+			if (val8) {
+				RTW_INFO("RM: rmid=%x peer reject (%s repeat=%d)\n",
+					prm->rmid,
+					val8|MEAS_REP_MOD_INCAP?"INCAP":
+					val8|MEAS_REP_MOD_REFUSE?"REFUSE":
+					val8|MEAS_REP_MOD_LATE?"LATE":"",
+					prm->p.rpt);
+				rm_state_goto(prm, RM_ST_END);
+				return _SUCCESS;
+			}
+			break;
+		case RM_ACT_NB_REP_RESP:
+			/* report to upper layer if needing */
+			rm_state_goto(prm, RM_ST_END);
+			return _SUCCESS;
+		default:
+			rm_state_goto(prm, RM_ST_END);
+			return _SUCCESS;
+		}
+		/* check repeat */
+		if (prm->p.rpt) {
+			RTW_INFO("RM: rmid=%x repeat=%u/%u\n",
+				prm->rmid, prm->p.rpt,
+				prm->q.rpt);
+			prm->p.rpt--;
+			/* waitting more report */
+			rm_state_goto(prm, RM_ST_WAIT_MEAS);
+			break;
+		}
+		/* we are done */
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_cancel:
+		rm_state_goto(prm, RM_ST_END);
+		break;
+	case RM_EV_state_out:
+		rm_cancel_clock(prm);
+		break;
+	default:
+		break;
+	}
+	return _SUCCESS;
+}
+
+static int rm_state_end(struct rm_obj *prm, enum RM_EV_ID evid)
+{
+	switch (evid) {
+	case RM_EV_state_in:
+		_rm_post_event(prm->psta->padapter, prm->rmid, RM_EV_state_out);
+		break;
+
+	case RM_EV_cancel:
+	case RM_EV_state_out:
+	default:
+		rm_free_rmobj(prm);
+		break;
+	}
+	return _SUCCESS;
+}
+
+struct fsm_state rm_fsm[] = {
+	{"RM_ST_IDLE",		rm_state_idle},
+	{"RM_ST_DO_MEAS",	rm_state_do_meas},
+	{"RM_ST_WAIT_MEAS", 	rm_state_wait_meas},
+	{"RM_ST_SEND_REPORT", 	rm_state_send_report},
+	{"RM_ST_RECV_REPORT", 	rm_state_recv_report},
+	{"RM_ST_END", 		rm_state_end}
+};
+
+char *rm_state_name(enum RM_STATE state)
+{
+	return rm_fsm[state].name;
+}
+
+char *rm_event_name(enum RM_EV_ID evid)
+{
+	switch(evid) {
+	case RM_EV_state_in:
+		return "RM_EV_state_in";
+	case RM_EV_busy_timer_expire:
+		return "RM_EV_busy_timer_expire";
+	case RM_EV_delay_timer_expire:
+		return "RM_EV_delay_timer_expire";
+	case RM_EV_meas_timer_expire:
+		return "RM_EV_meas_timer_expire";
+	case RM_EV_repeat_delay_expire:
+		return "RM_EV_repeat_delay_expire";
+	case RM_EV_retry_timer_expire:
+		return "RM_EV_retry_timer_expire";
+	case RM_EV_request_timer_expire:
+		return "RM_EV_request_timer_expire";
+	case RM_EV_wait_report:
+		return "RM_EV_wait_report";
+	case RM_EV_start_meas:
+		return "RM_EV_start_meas";
+	case RM_EV_survey_done:
+		return "RM_EV_survey_done";
+	case RM_EV_recv_rep:
+		return "RM_EV_recv_report";
+	case RM_EV_cancel:
+		return "RM_EV_cancel";
+	case RM_EV_state_out:
+		return "RM_EV_state_out";
+	case RM_EV_max:
+		return "RM_EV_max";
+	default:
+		return "RM_EV_unknown";
+	}
+	return "UNKNOWN";
+}
+
+static void rm_state_initial(struct rm_obj *prm)
+{
+	prm->state = RM_ST_IDLE;
+
+	RTW_INFO("\n");
+	RTW_INFO("RM: rmid=%x %-18s -> %s\n",prm->rmid,
+		"new measurement", rm_fsm[prm->state].name);
+
+	rm_post_event(prm->psta->padapter, prm->rmid, RM_EV_state_in);
+}
+
+static void rm_state_run(struct rm_obj *prm, enum RM_EV_ID evid)
+{
+	RTW_INFO("RM: rmid=%x %-18s    %s\n",prm->rmid,
+		rm_fsm[prm->state].name,rm_event_name(evid));
+
+	rm_fsm[prm->state].fsm_func(prm, evid);
+}
+
+static void rm_state_goto(struct rm_obj *prm, enum RM_STATE rm_state)
+{
+	if (prm->state == rm_state)
+		return;
+
+	rm_state_run(prm, RM_EV_state_out);
+
+	RTW_INFO("\n");
+	RTW_INFO("RM: rmid=%x %-18s -> %s\n",prm->rmid,
+		rm_fsm[prm->state].name, rm_fsm[rm_state].name);
+
+	prm->state = rm_state;
+	rm_state_run(prm, RM_EV_state_in);
+}
+#endif /* CONFIG_RTW_80211K */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rson.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rson.c
new file mode 100644
index 000000000000..3100ac714bc7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_rson.c
@@ -0,0 +1,596 @@
+/* SPDX-License-Identifier: GPL-2.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.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
+ *
+ *
+ ******************************************************************************/
+#define _RTW_RSON_C_
+
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_REPEATER_SON
+
+/********	Custommize Part	***********************/
+
+unsigned char	RTW_RSON_OUI[] = {0xFA, 0xFA, 0xFA};
+#define RSON_SCORE_DIFF_TH				8
+
+/*
+	Calculate the corresponding score.
+*/
+inline u8 rtw_cal_rson_score(struct rtw_rson_struct *cand_rson_data, NDIS_802_11_RSSI  Rssi)
+{
+	if ((cand_rson_data->hopcnt == RTW_RSON_HC_NOTREADY)
+		|| (cand_rson_data->connectible == RTW_RSON_DENYCONNECT))
+		return RTW_RSON_SCORE_NOTCNNT;
+
+	return RTW_RSON_SCORE_MAX - (cand_rson_data->hopcnt * 10) + (Rssi/10);
+}
+
+/*************************************************/
+
+
+static u8 rtw_rson_block_bssid_idx = 0;
+u8 rtw_rson_block_bssid[10][6] = {
+			/*{0x02, 0xE0, 0x4C, 0x07, 0xC3, 0xF6}*/
+};
+
+/* fake root, regard a real AP as a SO root */
+static u8 rtw_rson_root_bssid_idx = 0;
+u8 rtw_rson_root_bssid[10][6] = {
+			/*{0x1c, 0x5f, 0x2b, 0x5a, 0x60, 0x24}*/
+};
+
+int is_match_bssid(u8 *mac, u8 bssid_array[][6], int num)
+{
+	int i;
+
+	for (i = 0; i < num; i++)
+		if (_rtw_memcmp(mac, bssid_array[i], 6) == _TRUE)
+			return _TRUE;
+	return _FALSE;
+}
+
+void init_rtw_rson_data(struct dvobj_priv *dvobj)
+{
+	/*Aries  todo.  if pdvobj->rson_data.ver == 1 */
+	dvobj->rson_data.ver = RTW_RSON_VER;
+	dvobj->rson_data.id = CONFIG_RTW_REPEATER_SON_ID;
+#ifdef CONFIG_RTW_REPEATER_SON_ROOT
+	dvobj->rson_data.hopcnt = RTW_RSON_HC_ROOT;
+	dvobj->rson_data.connectible = RTW_RSON_ALLOWCONNECT;
+#else
+	dvobj->rson_data.hopcnt = RTW_RSON_HC_NOTREADY;
+	dvobj->rson_data.connectible = RTW_RSON_DENYCONNECT;
+#endif
+	dvobj->rson_data.loading = 0;
+	_rtw_memset(dvobj->rson_data.res, 0xAA, sizeof(dvobj->rson_data.res));
+}
+
+void	rtw_rson_get_property_str(_adapter *padapter, char *rson_data_str)
+{
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+
+	sprintf(rson_data_str, "version : \t%d\nid : \t\t%08x\nhop count : \t%d\nconnectible : \t%s\nloading : \t%d\nreserve : \t%16ph\n",
+		pdvobj->rson_data.ver,
+		pdvobj->rson_data.id,
+		pdvobj->rson_data.hopcnt,
+		pdvobj->rson_data.connectible ? "connectable":"unconnectable",
+		pdvobj->rson_data.loading,
+		pdvobj->rson_data.res);
+}
+
+int str2hexbuf(char *str, u8 *hexbuf, int len)
+{
+	u8 *p;
+	int i, slen, idx = 0;
+
+	p = (unsigned char *)str;
+	if ((*p != '0') || (*(p+1) != 'x'))
+		return _FALSE;
+	slen = strlen(str);
+	if (slen > (len*2) + 2)
+		return _FALSE;
+	p += 2;
+	for (i = 0 ; i < len; i++, idx = idx+2) {
+		hexbuf[i] = key_2char2num(p[idx], p[idx + 1]);
+		if (slen <= idx+2)
+			break;
+	}
+	return _TRUE;
+}
+
+int rtw_rson_set_property(_adapter *padapter, char *field, char *value)
+{
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+	int num = 0;
+
+	if (_rtw_memcmp(field, (u8 *)"ver", 3) == _TRUE)
+		pdvobj->rson_data.ver = rtw_atoi(value);
+	else if (_rtw_memcmp(field, (u8 *)"id", 2) == _TRUE)
+		num = sscanf(value, "%08x",   &(pdvobj->rson_data.id));
+	else if (_rtw_memcmp(field, (u8 *)"hc", 2) == _TRUE)
+		num = sscanf(value, "%hhu", &(pdvobj->rson_data.hopcnt));
+	else if (_rtw_memcmp(field, (u8 *)"cnt", 3) == _TRUE)
+		num = sscanf(value, "%hhu", &(pdvobj->rson_data.connectible));
+	else if (_rtw_memcmp(field, (u8 *)"loading", 2) == _TRUE)
+		num = sscanf(value, "%hhu", &(pdvobj->rson_data.loading));
+	else if (_rtw_memcmp(field, (u8 *)"res", 2) == _TRUE) {
+		str2hexbuf(value, pdvobj->rson_data.res, 16);
+		return 1;
+	} else
+		return _FALSE;
+	return num;
+}
+
+/*
+	return :	TRUE  -- competitor is taking advantage than condidate
+			FALSE -- we should continue keeping candidate
+*/
+int rtw_rson_choose(struct wlan_network **candidate, struct wlan_network *competitor)
+{
+	s16 comp_score = 0, cand_score = 0;
+	struct rtw_rson_struct rson_cand, rson_comp;
+
+	if (is_match_bssid(competitor->network.MacAddress, rtw_rson_block_bssid, rtw_rson_block_bssid_idx) == _TRUE)
+		return _FALSE;
+
+	if ((competitor == NULL)
+		|| (rtw_get_rson_struct(&(competitor->network), &rson_comp) != _TRUE)
+		|| (rson_comp.id != CONFIG_RTW_REPEATER_SON_ID))
+		return _FALSE;
+
+	comp_score = rtw_cal_rson_score(&rson_comp, competitor->network.Rssi);
+	if (comp_score == RTW_RSON_SCORE_NOTCNNT)
+		return _FALSE;
+
+	if (*candidate == NULL)
+		return _TRUE;
+	if (rtw_get_rson_struct(&((*candidate)->network), &rson_cand) != _TRUE)
+		return _FALSE;
+
+	cand_score = rtw_cal_rson_score(&rson_cand, (*candidate)->network.Rssi);
+	RTW_INFO("%s: competitor_score=%d,  candidate_score=%d\n", __func__, comp_score, cand_score);
+	if (comp_score - cand_score > RSON_SCORE_DIFF_TH)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+inline u8 rtw_rson_varify_ie(u8 *p)
+{
+	u8 *ptr = NULL;
+	u8 ver;
+	u32 id;
+	u8 hopcnt;
+	u8 allcnnt;
+
+	ptr = p + 2 + sizeof(RTW_RSON_OUI);
+	ver = *ptr;
+
+	/*	for (ver == 1)	*/
+	if (ver != 1)
+		return _FALSE;
+
+	return _TRUE;
+}
+
+/*
+	Parsing RTK self-organization vendor IE
+*/
+int rtw_get_rson_struct(WLAN_BSSID_EX *bssid, struct  rtw_rson_struct *rson_data)
+{
+	sint  limit = 0;
+	u32	len;
+	u8	*p;
+
+	if ((rson_data == NULL) || (bssid == NULL))
+		return -EINVAL;
+
+	/*	Default		*/
+	rson_data->id = 0;
+	rson_data->ver = 0;
+	rson_data->hopcnt = 0;
+	rson_data->connectible = 0;
+	rson_data->loading = 0;
+	/*	fake root		*/
+	if (is_match_bssid(bssid->MacAddress, rtw_rson_root_bssid, rtw_rson_root_bssid_idx) == _TRUE) {
+		rson_data->id = CONFIG_RTW_REPEATER_SON_ID;
+		rson_data->ver = RTW_RSON_VER;
+		rson_data->hopcnt = RTW_RSON_HC_ROOT;
+		rson_data->connectible = RTW_RSON_ALLOWCONNECT;
+		rson_data->loading = 0;
+		return _TRUE;
+	}
+	limit = bssid->IELength - _BEACON_IE_OFFSET_;
+
+	for (p = bssid->IEs + _BEACON_IE_OFFSET_; ; p += (len + 2)) {
+		p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &len, limit);
+		limit -= len;
+		if ((p == NULL) || (len == 0))
+			break;
+		if (p && (_rtw_memcmp(p + 2, RTW_RSON_OUI, sizeof(RTW_RSON_OUI)) == _TRUE)
+			&& rtw_rson_varify_ie(p)) {
+			p = p + 2 + sizeof(RTW_RSON_OUI);
+			rson_data->ver = *p;
+			/*	for (ver == 1)		*/
+			p = p + 1;
+			rson_data->id = le32_to_cpup((__le32 *)p);
+			p = p + 4;
+			rson_data->hopcnt = *p;
+			p = p + 1;
+			rson_data->connectible = *p;
+			p = p + 1;
+			rson_data->loading = *p;
+
+			return _TRUE;
+		}
+	}
+	return -EBADMSG;
+}
+
+u32 rtw_rson_append_ie(_adapter *padapter, unsigned char *pframe, u32 *len)
+{
+	u8 *ptr, *ori, ie_len = 0;
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+/*	static int iii = 0;*/
+
+	if ((!pdvobj) || (!pframe))
+		return 0;
+	ptr = ori = pframe;
+	*ptr++ = _VENDOR_SPECIFIC_IE_;
+	*ptr++ = ie_len = sizeof(RTW_RSON_OUI)+sizeof(pdvobj->rson_data);
+	_rtw_memcpy(ptr, RTW_RSON_OUI, sizeof(RTW_RSON_OUI));
+	ptr = ptr + sizeof(RTW_RSON_OUI);
+	*ptr++ = pdvobj->rson_data.ver;
+	*(s32 *)ptr = cpu_to_le32(pdvobj->rson_data.id);
+	ptr = ptr + sizeof(pdvobj->rson_data.id);
+	*ptr++ = pdvobj->rson_data.hopcnt;
+	*ptr++ = pdvobj->rson_data.connectible;
+	*ptr++ = pdvobj->rson_data.loading;
+	_rtw_memcpy(ptr, pdvobj->rson_data.res, sizeof(pdvobj->rson_data.res));
+	pframe = ptr;
+/*
+	iii = iii % 20;
+	if (iii++ == 0)
+		RTW_INFO("%s : RTW RSON IE : %20ph\n", __func__, ori);
+*/
+	*len += (ie_len+2);
+	return ie_len;
+
+}
+
+void rtw_rson_do_disconnect(_adapter *padapter)
+{
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+#ifndef CONFIG_RTW_REPEATER_SON_ROOT
+	pdvobj->rson_data.ver = RTW_RSON_VER;
+	pdvobj->rson_data.id = CONFIG_RTW_REPEATER_SON_ID;
+	pdvobj->rson_data.hopcnt = RTW_RSON_HC_NOTREADY;
+	pdvobj->rson_data.connectible = RTW_RSON_DENYCONNECT;
+	pdvobj->rson_data.loading = 0;
+	rtw_mi_tx_beacon_hdl(padapter);
+#endif
+}
+
+void rtw_rson_join_done(_adapter *padapter)
+{
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+	WLAN_BSSID_EX	*cur_network = NULL;
+	struct rtw_rson_struct  rson_data;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	if (!padapter->mlmepriv.cur_network_scanned)
+		return;
+	cur_network = &(padapter->mlmepriv.cur_network_scanned->network);
+	if (rtw_get_rson_struct(cur_network, &rson_data) != _TRUE) {
+		RTW_ERR("%s: try to join a improper network(%s)\n", __func__, cur_network->Ssid.Ssid);
+		return;
+	}
+
+#ifndef CONFIG_RTW_REPEATER_SON_ROOT
+	/* update rson_data */
+	pdvobj->rson_data.ver = RTW_RSON_VER;
+	pdvobj->rson_data.id = rson_data.id;
+	pdvobj->rson_data.hopcnt = rson_data.hopcnt + 1;
+	pdvobj->rson_data.connectible = RTW_RSON_ALLOWCONNECT;
+	pdvobj->rson_data.loading = 0;
+	rtw_mi_tx_beacon_hdl(padapter);
+#endif
+}
+
+int rtw_rson_isupdate_roamcan(struct mlme_priv *mlme
+	, struct wlan_network **candidate, struct wlan_network *competitor)
+{
+	struct rtw_rson_struct  rson_cand, rson_comp, rson_curr;
+	s16 comp_score, cand_score, curr_score;
+
+	if ((competitor == NULL)
+		|| (rtw_get_rson_struct(&(competitor->network), &rson_comp) != _TRUE)
+		|| (rson_comp.id != CONFIG_RTW_REPEATER_SON_ID))
+		return _FALSE;
+
+	if (is_match_bssid(competitor->network.MacAddress, rtw_rson_block_bssid, rtw_rson_block_bssid_idx) == _TRUE)
+		return _FALSE;
+
+	if ((!mlme->cur_network_scanned)
+		|| (mlme->cur_network_scanned == competitor)
+		|| (rtw_get_rson_struct(&(mlme->cur_network_scanned->network), &rson_curr)) != _TRUE)
+		return _FALSE;
+
+	if (rtw_get_passing_time_ms((u32)competitor->last_scanned) >= mlme->roam_scanr_exp_ms)
+		return _FALSE;
+
+	comp_score = rtw_cal_rson_score(&rson_comp, competitor->network.Rssi);
+	curr_score = rtw_cal_rson_score(&rson_curr, mlme->cur_network_scanned->network.Rssi);
+	if (comp_score - curr_score < RSON_SCORE_DIFF_TH)
+		return _FALSE;
+
+	if (*candidate == NULL)
+		return _TRUE;
+
+	if (rtw_get_rson_struct(&((*candidate)->network), &rson_cand) != _TRUE) {
+		RTW_ERR("%s : Unable to get rson_struct from candidate(%s -- " MAC_FMT")\n",
+				__func__, (*candidate)->network.Ssid.Ssid, MAC_ARG((*candidate)->network.MacAddress));
+		return _FALSE;
+	}
+	cand_score = rtw_cal_rson_score(&rson_cand, (*candidate)->network.Rssi);
+	RTW_DBG("comp_score=%d , cand_score=%d , curr_score=%d\n", comp_score, cand_score, curr_score);
+	if (cand_score < comp_score)
+		return _TRUE;
+
+#if 0		/*	Handle 11R protocol	*/
+#ifdef CONFIG_RTW_80211R
+	if (rtw_chk_ft_flags(adapter, RTW_FT_SUPPORTED)) {
+		ptmp = rtw_get_ie(&competitor->network.IEs[12], _MDIE_, &mdie_len, competitor->network.IELength-12);
+		if (ptmp) {
+			if (!_rtw_memcmp(&pftpriv->mdid, ptmp+2, 2))
+				goto exit;
+
+			/*The candidate don't support over-the-DS*/
+			if (rtw_chk_ft_flags(adapter, RTW_FT_STA_OVER_DS_SUPPORTED)) {
+				if ((rtw_chk_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED) && !(*(ptmp+4) & 0x01)) ||
+					(!rtw_chk_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED) && (*(ptmp+4) & 0x01))) {
+					RTW_INFO("FT: ignore the candidate(" MAC_FMT ") for over-the-DS\n", MAC_ARG(competitor->network.MacAddress));
+					rtw_clr_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED);
+					goto exit;
+				}
+			}
+		} else
+			goto exit;
+	}
+#endif
+#endif
+	return _FALSE;
+}
+
+void rtw_rson_show_survey_info(struct seq_file *m, _list *plist, _list *phead)
+{
+	struct wlan_network	*pnetwork = NULL;
+	struct rtw_rson_struct  rson_data;
+	s16 rson_score;
+	u16  index = 0;
+
+	RTW_PRINT_SEL(m, "%5s  %-17s  %3s  %5s %14s  %10s  %-3s  %5s %32s\n", "index", "bssid", "ch", "id", "hop_cnt", "loading", "RSSI", "score", "ssid");
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (!pnetwork)
+			break;
+
+		_rtw_memset(&rson_data, 0, sizeof(rson_data));
+		rson_score = 0;
+		if (rtw_get_rson_struct(&(pnetwork->network), &rson_data) == _TRUE)
+			rson_score = rtw_cal_rson_score(&rson_data, pnetwork->network.Rssi);
+		RTW_PRINT_SEL(m, "%5d  "MAC_FMT" %3d  0x%08x %6d %10d   %6d %6d   %32s\n",
+			      ++index,
+			      MAC_ARG(pnetwork->network.MacAddress),
+			      pnetwork->network.Configuration.DSConfig,
+			      rson_data.id,
+			      rson_data.hopcnt,
+			      rson_data.loading,
+			      (int)pnetwork->network.Rssi,
+			      rson_score,
+			      pnetwork->network.Ssid.Ssid);
+		plist = get_next(plist);
+		}
+
+}
+
+/*
+	Description :	As a AP role, We need to check the qualify of associating STA.
+					We also need to check if we are ready to be associated.
+
+	return :	TRUE  -- AP REJECT this STA
+				FALSE -- AP ACCEPT this STA
+*/
+u8 rtw_rson_ap_check_sta(_adapter *padapter, u8 *pframe, uint pkt_len, unsigned short ie_offset)
+{
+	struct wlan_network	*pnetwork = NULL;
+	struct rtw_rson_struct  rson_target;
+	struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
+	int len = 0;
+	u8 ret = _FALSE;
+	u8 *p;
+
+#ifndef CONFIG_RTW_REPEATER_SON_ROOT
+	_rtw_memset(&rson_target, 0, sizeof(rson_target));
+	for (p = pframe + WLAN_HDR_A3_LEN + ie_offset; ; p += (len + 2)) {
+		p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &len, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
+
+		if ((p == NULL) || (len == 0))
+			break;
+
+		if (p && (_rtw_memcmp(p + 2, RTW_RSON_OUI, sizeof(RTW_RSON_OUI)) == _TRUE)
+			&& rtw_rson_varify_ie(p)) {
+			p = p + 2 + sizeof(RTW_RSON_OUI);
+			rson_target.ver = *p;
+			/*	for (ver == 1)		*/
+			p = p + 1;
+			rson_target.id = le32_to_cpup((__le32 *)p);
+			p = p + 4;
+			rson_target.hopcnt = *p;
+			p = p + 1;
+			rson_target.connectible = *p;
+			p = p + 1;
+			rson_target.loading = *p;
+			break;
+		}
+	}
+
+	if (rson_target.id == 0)		/*	Normal STA, not a RSON STA	*/
+		ret = _FALSE;
+	else if (rson_target.id != pdvobj->rson_data.id) {
+		ret = _TRUE;
+		RTW_INFO("%s : Reject AssoReq because RSON ID not match, STA=%08x, our=%08x\n",
+				__func__, rson_target.id, pdvobj->rson_data.id);
+	} else if ((pdvobj->rson_data.hopcnt == RTW_RSON_HC_NOTREADY)
+		|| (pdvobj->rson_data.connectible == RTW_RSON_DENYCONNECT)) {
+		ret = _TRUE;
+		RTW_INFO("%s : Reject AssoReq becuase our hopcnt=%d or connectbile=%d\n",
+				__func__, pdvobj->rson_data.hopcnt, pdvobj->rson_data.connectible);
+	}
+#endif
+	return ret;
+}
+
+u8 rtw_rson_scan_wk_cmd(_adapter *padapter, int op)
+{
+	struct cmd_obj *ph2c;
+	struct drvextra_cmd_parm *pdrvextra_cmd_parm;
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	u8 *extra_cmd_buf;
+	u8 res = _SUCCESS;
+
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+	pdrvextra_cmd_parm->ec_id = RSON_SCAN_WK_CID;
+	pdrvextra_cmd_parm->type = op;
+	pdrvextra_cmd_parm->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_cmd(pcmdpriv, ph2c);
+
+exit:
+	return res;
+
+}
+
+void rtw_rson_scan_cmd_hdl(_adapter *padapter, int op)
+{
+	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 val8;
+
+	if (mlmeext_chk_scan_state(pmlmeext, SCAN_DISABLE) != _TRUE)
+		return;
+	if (op == RSON_SCAN_PROCESS) {
+		padapter->rtw_rson_scanstage = RSON_SCAN_PROCESS;
+		val8 = 0x1e;
+		rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &val8, _FALSE);
+		val8 = 1;
+		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
+		issue_probereq(padapter, NULL, NULL);
+		/*	stop rson_scan after 100ms	*/
+		_set_timer(&(pmlmeext->rson_scan_timer), 100);
+	} else if  (op == RSON_SCAN_DISABLE) {
+		padapter->rtw_rson_scanstage = RSON_SCAN_DISABLE;
+		val8 = 0;
+		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
+		val8 = 0xff;
+		rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &val8, _FALSE);
+		/*	report_surveydone_event(padapter);*/
+		if (pmlmepriv->to_join == _TRUE) {
+			if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) != _TRUE) {
+				int s_ret;
+
+				set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
+				pmlmepriv->to_join = _FALSE;
+				s_ret = rtw_select_and_join_from_scanned_queue(pmlmepriv);
+				if (s_ret == _SUCCESS)
+					_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
+				else if (s_ret == 2) {
+					_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
+					rtw_indicate_connect(padapter);
+				} else {
+					RTW_INFO("try_to_join, but select scanning queue fail, to_roam:%d\n", rtw_to_roam(padapter));
+					if (rtw_to_roam(padapter) != 0) {
+						if (rtw_dec_to_roam(padapter) == 0) {
+							rtw_set_to_roam(padapter, 0);
+#ifdef CONFIG_INTEL_WIDI
+							if (padapter->mlmepriv.widi_state == INTEL_WIDI_STATE_ROAMING) {
+								_rtw_memset(pmlmepriv->sa_ext, 0x00, L2SDTA_SERVICE_VE_LEN);
+								intel_widi_wk_cmd(padapter, INTEL_WIDI_LISTEN_WK, NULL, 0);
+								RTW_INFO("change to widi listen\n");
+							}
+#endif /* CONFIG_INTEL_WIDI */
+							rtw_free_assoc_resources(padapter, _TRUE);
+							rtw_indicate_disconnect(padapter, 0, _FALSE);
+						} else
+							pmlmepriv->to_join = _TRUE;
+					} else
+						rtw_indicate_disconnect(padapter, 0, _FALSE);
+					_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
+				}
+			}
+		} else {
+			if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE)) {
+				if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
+				    && check_fwstate(pmlmepriv, _FW_LINKED)) {
+					if (rtw_select_roaming_candidate(pmlmepriv) == _SUCCESS) {
+#ifdef CONFIG_RTW_80211R
+						if (rtw_chk_ft_flags(padapter, RTW_FT_OVER_DS_SUPPORTED)) {
+							start_clnt_ft_action(adapter, (u8 *)pmlmepriv->roam_network->network.MacAddress);
+						} else {
+							/*wait a little time to retrieve packets buffered in the current ap while scan*/
+							_set_timer(&pmlmeext->ft_roam_timer, 30);
+						}
+#else
+						receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress
+							, WLAN_REASON_ACTIVE_ROAM, _FALSE);
+#endif
+					}
+				}
+			}
+			issue_action_BSSCoexistPacket(padapter);
+			issue_action_BSSCoexistPacket(padapter);
+			issue_action_BSSCoexistPacket(padapter);
+		}
+	} else {
+		RTW_ERR("%s : improper parameter -- op = %d\n", __func__, op);
+	}
+}
+
+#endif	/* CONFIG_RTW_REPEATER_SON */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sdio.c
new file mode 100644
index 000000000000..328a2284c6aa
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sdio.c
@@ -0,0 +1,131 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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_SDIO_C_
+
+#include <drv_types.h>		/* struct dvobj_priv and etc. */
+#include <drv_types_sdio.h>	/* RTW_SDIO_ADDR_CMD52_GEN */
+
+/*
+ * Description:
+ *	Use SDIO cmd52 or cmd53 to read/write data
+ *
+ * Parameters:
+ *	d	pointer of device object(struct dvobj_priv)
+ *	addr	SDIO address, 17 bits
+ *	buf	buffer for I/O
+ *	len	length
+ *	write	0:read, 1:write
+ *	cmd52	0:cmd52, 1:cmd53
+ *
+ * Return:
+ *	_SUCCESS	I/O ok.
+ *	_FAIL		I/O fail.
+ */
+static u8 sdio_io(struct dvobj_priv *d, u32 addr, void *buf, size_t len, u8 write, u8 cmd52)
+{
+	u32 addr_drv;	/* address with driver defined bit */
+	int err;
+	u8 retry = 0;
+	u8 stop_retry = _FALSE;	/* flag for stopping retry or not */
+
+
+	if (rtw_is_surprise_removed(dvobj_get_primary_adapter(d))) {
+		RTW_ERR("%s: bSurpriseRemoved, skip %s 0x%05x, %zu bytes\n",
+			__FUNCTION__, write?"write":"read", addr, len);
+		return _FAIL;
+	}
+
+	addr_drv = addr;
+	if (cmd52)
+		addr_drv = RTW_SDIO_ADDR_CMD52_GEN(addr_drv);
+
+	do {
+		if (write)
+			err = d->intf_ops->write(d, addr_drv, buf, len, 0);
+		else
+			err = d->intf_ops->read(d, addr_drv, buf, len, 0);
+		if (!err) {
+			if (retry) {
+				RTW_INFO("%s: Retry %s OK! addr=0x%05x %zu bytes, retry=%u,%u\n",
+					 __FUNCTION__, write?"write":"read",
+					 addr, len, retry, ATOMIC_READ(&d->continual_io_error));
+				RTW_INFO_DUMP("Data: ", buf, len);
+			}
+			rtw_reset_continual_io_error(d);
+			break;
+		}
+		RTW_ERR("%s: %s FAIL! error(%d) addr=0x%05x %zu bytes, retry=%u,%u\n",
+			__FUNCTION__, write?"write":"read", err, addr, len,
+			retry, ATOMIC_READ(&d->continual_io_error));
+
+		retry++;
+		stop_retry = rtw_inc_and_chk_continual_io_error(d);
+		if ((err == -1) || (stop_retry == _TRUE) || (retry > SD_IO_TRY_CNT)) {
+			/* critical error, unrecoverable */
+			RTW_ERR("%s: Fatal error! Set surprise remove flag ON! (retry=%u,%u)\n",
+				__FUNCTION__, retry, ATOMIC_READ(&d->continual_io_error));
+			rtw_set_surprise_removed(dvobj_get_primary_adapter(d));
+			return _FAIL;
+		}
+
+		/* WLAN IOREG or SDIO Local */
+		if ((addr & 0x10000) || !(addr & 0xE000)) {
+			RTW_WARN("%s: Retry %s addr=0x%05x %zu bytes, retry=%u,%u\n",
+				 __FUNCTION__, write?"write":"read", addr, len,
+				 retry, ATOMIC_READ(&d->continual_io_error));
+			continue;
+		}
+		return _FAIL;
+	} while (1);
+
+	return _SUCCESS;
+}
+
+u8 rtw_sdio_read_cmd52(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
+{
+	return sdio_io(d, addr, buf, len, 0, 1);
+}
+
+u8 rtw_sdio_read_cmd53(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
+{
+	return sdio_io(d, addr, buf, len, 0, 0);
+}
+
+u8 rtw_sdio_write_cmd52(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
+{
+	return sdio_io(d, addr, buf, len, 1, 1);
+}
+
+u8 rtw_sdio_write_cmd53(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
+{
+	return sdio_io(d, addr, buf, len, 1, 0);
+}
+
+u8 rtw_sdio_f0_read(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
+{
+	int err;
+	u8 ret;
+
+
+	ret = _SUCCESS;
+	addr = RTW_SDIO_ADDR_F0_GEN(addr);
+
+	err = d->intf_ops->read(d, addr, buf, len, 0);
+	if (err)
+		ret = _FAIL;
+
+	return ret;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_security.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_security.c
index 8dac771ca080..26b342699486 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_security.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_security.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define  _RTW_SECURITY_C_
 
 #include <drv_types.h>
@@ -45,53 +41,59 @@ const char *security_type_str(u8 value)
 }
 
 #ifdef DBG_SW_SEC_CNT
-#define WEP_SW_ENC_CNT_INC(sec, ra) \
+#define WEP_SW_ENC_CNT_INC(sec, ra) do {\
 	if (is_broadcast_mac_addr(ra)) \
 		sec->wep_sw_enc_cnt_bc++; \
 	else if (is_multicast_mac_addr(ra)) \
 		sec->wep_sw_enc_cnt_mc++; \
 	else \
-		sec->wep_sw_enc_cnt_uc++;
+		sec->wep_sw_enc_cnt_uc++; \
+	} while (0)
 
-#define WEP_SW_DEC_CNT_INC(sec, ra) \
+#define WEP_SW_DEC_CNT_INC(sec, ra) do {\
 	if (is_broadcast_mac_addr(ra)) \
 		sec->wep_sw_dec_cnt_bc++; \
 	else if (is_multicast_mac_addr(ra)) \
 		sec->wep_sw_dec_cnt_mc++; \
 	else \
-		sec->wep_sw_dec_cnt_uc++;
+		sec->wep_sw_dec_cnt_uc++; \
+	} while (0)
 
-#define TKIP_SW_ENC_CNT_INC(sec, ra) \
+#define TKIP_SW_ENC_CNT_INC(sec, ra) do {\
 	if (is_broadcast_mac_addr(ra)) \
 		sec->tkip_sw_enc_cnt_bc++; \
 	else if (is_multicast_mac_addr(ra)) \
 		sec->tkip_sw_enc_cnt_mc++; \
 	else \
-		sec->tkip_sw_enc_cnt_uc++;
+		sec->tkip_sw_enc_cnt_uc++; \
+	} while (0)
 
-#define TKIP_SW_DEC_CNT_INC(sec, ra) \
+#define TKIP_SW_DEC_CNT_INC(sec, ra) do {\
 	if (is_broadcast_mac_addr(ra)) \
 		sec->tkip_sw_dec_cnt_bc++; \
 	else if (is_multicast_mac_addr(ra)) \
 		sec->tkip_sw_dec_cnt_mc++; \
 	else \
-		sec->tkip_sw_dec_cnt_uc++;
+		sec->tkip_sw_dec_cnt_uc++; \
+	} while (0)
 
-#define AES_SW_ENC_CNT_INC(sec, ra) \
+#define AES_SW_ENC_CNT_INC(sec, ra) do {\
 	if (is_broadcast_mac_addr(ra)) \
 		sec->aes_sw_enc_cnt_bc++; \
 	else if (is_multicast_mac_addr(ra)) \
 		sec->aes_sw_enc_cnt_mc++; \
 	else \
-		sec->aes_sw_enc_cnt_uc++;
+		sec->aes_sw_enc_cnt_uc++; \
+	} while (0)
 
-#define AES_SW_DEC_CNT_INC(sec, ra) \
+#define AES_SW_DEC_CNT_INC(sec, ra) do {\
 	if (is_broadcast_mac_addr(ra)) \
 		sec->aes_sw_dec_cnt_bc++; \
 	else if (is_multicast_mac_addr(ra)) \
 		sec->aes_sw_dec_cnt_mc++; \
 	else \
-		sec->aes_sw_dec_cnt_uc++;
+		sec->aes_sw_dec_cnt_uc++; \
+	} while (0)
 #else
 #define WEP_SW_ENC_CNT_INC(sec, ra)
 #define WEP_SW_DEC_CNT_INC(sec, ra)
@@ -101,26 +103,24 @@ const char *security_type_str(u8 value)
 #define AES_SW_DEC_CNT_INC(sec, ra)
 #endif /* DBG_SW_SEC_CNT */
 
-//=====WEP related===== 
+/* *****WEP related***** */
 
 #define CRC32_POLY 0x04c11db7
 
-struct arc4context
-{
+struct arc4context {
 	u32 x;
 	u32 y;
 	u8 state[256];
 };
 
 
-static void arcfour_init(struct arc4context 	*parc4ctx, u8 * key,u32	key_len)
+static void arcfour_init(struct arc4context	*parc4ctx, u8 *key, u32	key_len)
 {
 	u32	t, u;
 	u32	keyindex;
 	u32	stateindex;
-	u8 * state;
+	u8 *state;
 	u32	counter;
-_func_enter_;
 	state = parc4ctx->state;
 	parc4ctx->x = 0;
 	parc4ctx->y = 0;
@@ -128,8 +128,7 @@ _func_enter_;
 		state[counter] = (u8)counter;
 	keyindex = 0;
 	stateindex = 0;
-	for (counter = 0; counter < 256; counter++)
-	{
+	for (counter = 0; counter < 256; counter++) {
 		t = state[counter];
 		stateindex = (stateindex + key[keyindex] + t) & 0xff;
 		u = state[stateindex];
@@ -138,15 +137,13 @@ _func_enter_;
 		if (++keyindex >= key_len)
 			keyindex = 0;
 	}
-_func_exit_;	
 }
-static u32 arcfour_byte(	struct arc4context	*parc4ctx)
+static u32 arcfour_byte(struct arc4context	*parc4ctx)
 {
 	u32 x;
 	u32 y;
 	u32 sx, sy;
-	u8 * state;
-_func_enter_;
+	u8 *state;
 	state = parc4ctx->state;
 	x = (parc4ctx->x + 1) & 0xff;
 	sx = state[x];
@@ -156,51 +153,46 @@ _func_enter_;
 	parc4ctx->y = y;
 	state[y] = (u8)sx;
 	state[x] = (u8)sy;
-_func_exit_;	
 	return state[(sx + sy) & 0xff];
 }
-              
-           
-static void arcfour_encrypt(	struct arc4context	*parc4ctx, 
-	u8 * dest,
-	u8 * src, 
-	u32 len)
+
+
+static void arcfour_encrypt(struct arc4context	*parc4ctx,
+			    u8 *dest,
+			    u8 *src,
+			    u32 len)
 {
 	u32	i;
-_func_enter_;	
 	for (i = 0; i < len; i++)
 		dest[i] = src[i] ^ (unsigned char)arcfour_byte(parc4ctx);
-_func_exit_;		
 }
 
 static sint bcrc32initialized = 0;
 static u32 crc32_table[256];
 
 
-static u8 crc32_reverseBit( u8 data)
+static u8 crc32_reverseBit(u8 data)
 {
-	return( (u8)((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 (u8)((data << 7) & 0x80) | ((data << 5) & 0x40) | ((data << 3) & 0x20) | ((data << 1) & 0x10) | ((data >> 1) & 0x08) | ((data >> 3) & 0x04) | ((data >> 5) & 0x02) | ((
+				data >> 7) & 0x01) ;
 }
 
 static void crc32_init(void)
 {
-_func_enter_;	
-	if (bcrc32initialized == 1) 
+	if (bcrc32initialized == 1)
 		goto exit;
-	else{
+	else {
 		sint i, j;
 		u32 c;
-		u8 *p=(u8 *)&c, *p1;
+		u8 *p = (u8 *)&c, *p1;
 		u8 k;
 
 		c = 0x12340000;
 
-		for (i = 0; i < 256; ++i) 
-		{
+		for (i = 0; i < 256; ++i) {
 			k = crc32_reverseBit((u8)i);
-			for (c = ((u32)k) << 24, j = 8; j > 0; --j){
+			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]);
@@ -208,26 +200,23 @@ _func_enter_;
 			p1[2] = crc32_reverseBit(p[1]);
 			p1[3] = crc32_reverseBit(p[0]);
 		}
-		bcrc32initialized= 1;
+		bcrc32initialized = 1;
 	}
-exit:	
-_func_exit_;			
+exit:
+	return;
 }
 
 static u32 getcrc32(u8 *buf, sint len)
 {
 	u8 *p;
 	u32  crc;
-_func_enter_;	
-	if (bcrc32initialized == 0) crc32_init();
+	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);
-	}
-_func_exit_;				
+	for (p = buf; len > 0; ++p, --len)
+		crc = crc32_table[(crc ^ *p) & 0xff] ^ (crc >> 8);
 	return ~crc;    /* transmit complement, per CRC-32 spec */
 }
 
@@ -236,269 +225,233 @@ _func_exit_;
 	Need to consider the fragment  situation
 */
 void rtw_wep_encrypt(_adapter *padapter, u8 *pxmitframe)
-{																	// exclude ICV
-	
+{
+	/* exclude ICV */
+
 	unsigned char	crc[4];
 	struct arc4context	 mycontext;
 
-	sint	curfragnum,length;
+	sint	curfragnum, length;
 	u32	keylength;
 
-	u8	*pframe, *payload,*iv;    //,*wepkey
+	u8	*pframe, *payload, *iv;   /* ,*wepkey */
 	u8	wepkey[16];
-	u8   hw_hdr_offset=0;
-	struct	pkt_attrib	 *pattrib = &((struct xmit_frame*)pxmitframe)->attrib;
-	struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
-	struct	xmit_priv		*pxmitpriv=&padapter->xmitpriv;
-	
-_func_enter_;	
-
-	
-	if(((struct xmit_frame*)pxmitframe)->buf_addr==NULL)
+	u8   hw_hdr_offset = 0;
+	struct	pkt_attrib	*pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
+	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
+	struct	xmit_priv		*pxmitpriv = &padapter->xmitpriv;
+
+
+
+	if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
 		return;
 
 #ifdef CONFIG_USB_TX_AGGREGATION
 	hw_hdr_offset = TXDESC_SIZE +
-		 (((struct xmit_frame*)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);	
+		(((struct xmit_frame *)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);
+#else
+#ifdef CONFIG_TX_EARLY_MODE
+	hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
 #else
-	#ifdef CONFIG_TX_EARLY_MODE
-	hw_hdr_offset = TXDESC_OFFSET+EARLY_MODE_INFO_SIZE;
-	#else
 	hw_hdr_offset = TXDESC_OFFSET;
-	#endif
+#endif
 #endif
 
-	pframe = ((struct xmit_frame*)pxmitframe)->buf_addr + hw_hdr_offset;
-	
-	//start to encrypt each fragment
-	if((pattrib->encrypt==_WEP40_)||(pattrib->encrypt==_WEP104_))
-	{
-		keylength=psecuritypriv->dot11DefKeylen[psecuritypriv->dot11PrivacyKeyIndex];
+	pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + hw_hdr_offset;
 
-		for(curfragnum=0;curfragnum<pattrib->nr_frags;curfragnum++)
-		{
-			iv=pframe+pattrib->hdrlen;
+	/* start to encrypt each fragment */
+	if ((pattrib->encrypt == _WEP40_) || (pattrib->encrypt == _WEP104_)) {
+		keylength = psecuritypriv->dot11DefKeylen[psecuritypriv->dot11PrivacyKeyIndex];
+
+		for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
+			iv = pframe + pattrib->hdrlen;
 			_rtw_memcpy(&wepkey[0], iv, 3);
-			_rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[psecuritypriv->dot11PrivacyKeyIndex].skey[0],keylength);
-			payload=pframe+pattrib->iv_len+pattrib->hdrlen;
+			_rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[psecuritypriv->dot11PrivacyKeyIndex].skey[0], 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;
 
-			if((curfragnum+1)==pattrib->nr_frags)
-			{	//the last fragment
-			
-				length=pattrib->last_txcmdsz-pattrib->hdrlen-pattrib->iv_len- pattrib->icv_len;
-			
-				*((u32 *)crc)=cpu_to_le32(getcrc32(payload,length));
+				*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length));
 
-				arcfour_init(&mycontext, wepkey,3+keylength);
+				arcfour_init(&mycontext, wepkey, 3 + keylength);
 				arcfour_encrypt(&mycontext, payload, payload, length);
-				arcfour_encrypt(&mycontext, payload+length, crc, 4);
+				arcfour_encrypt(&mycontext, payload + length, crc, 4);
 
-			}
-			else
-			{
-			length=pxmitpriv->frag_len-pattrib->hdrlen-pattrib->iv_len-pattrib->icv_len ;
-				*((u32 *)crc)=cpu_to_le32(getcrc32(payload,length));
-				arcfour_init(&mycontext, wepkey,3+keylength);
+			} else {
+				length = pxmitpriv->frag_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len ;
+				*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length));
+				arcfour_init(&mycontext, wepkey, 3 + keylength);
 				arcfour_encrypt(&mycontext, payload, payload, length);
-				arcfour_encrypt(&mycontext, payload+length, crc, 4);
-	
-			pframe+=pxmitpriv->frag_len;
-			pframe=(u8 *)RND4((SIZE_PTR)(pframe));
+				arcfour_encrypt(&mycontext, payload + length, crc, 4);
+
+				pframe += pxmitpriv->frag_len;
+				pframe = (u8 *)RND4((SIZE_PTR)(pframe));
 
 			}
-			
-		}		
+
+		}
 
 		WEP_SW_ENC_CNT_INC(psecuritypriv, pattrib->ra);
 	}
-	
-_func_exit_;						
+
 
 }
 
 void rtw_wep_decrypt(_adapter  *padapter, u8 *precvframe)
-{								
-	// exclude ICV
+{
+	/* exclude ICV */
 	u8	crc[4];
 	struct arc4context	 mycontext;
-	sint 	length;
+	sint	length;
 	u32	keylength;
-	u8	*pframe, *payload,*iv,wepkey[16];
+	u8	*pframe, *payload, *iv, wepkey[16];
 	u8	 keyindex;
-	struct	rx_pkt_attrib	 *prxattrib = &(((union recv_frame*)precvframe)->u.hdr.attrib);
-	struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
+	struct	rx_pkt_attrib	*prxattrib = &(((union recv_frame *)precvframe)->u.hdr.attrib);
+	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
 
-_func_enter_;	
 
-	pframe=(unsigned char *)((union recv_frame*)precvframe)->u.hdr.rx_data;
-	
-	//start to decrypt recvframe
-	if((prxattrib->encrypt==_WEP40_)||(prxattrib->encrypt==_WEP104_))
-	{
-		iv=pframe+prxattrib->hdrlen;
-		//keyindex=(iv[3]&0x3);
+	pframe = (unsigned char *)((union recv_frame *)precvframe)->u.hdr.rx_data;
+
+	/* start to decrypt recvframe */
+	if ((prxattrib->encrypt == _WEP40_) || (prxattrib->encrypt == _WEP104_)) {
+		iv = pframe + prxattrib->hdrlen;
+		/* keyindex=(iv[3]&0x3); */
 		keyindex = prxattrib->key_index;
-		keylength=psecuritypriv->dot11DefKeylen[keyindex];
+		keylength = psecuritypriv->dot11DefKeylen[keyindex];
 		_rtw_memcpy(&wepkey[0], iv, 3);
-		//_rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[psecuritypriv->dot11PrivacyKeyIndex].skey[0],keylength);
-		_rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[keyindex].skey[0],keylength);
-		length= ((union recv_frame *)precvframe)->u.hdr.len-prxattrib->hdrlen-prxattrib->iv_len;
-
-		payload=pframe+prxattrib->iv_len+prxattrib->hdrlen;
-		
-		//decrypt payload include icv
-		arcfour_init(&mycontext, wepkey,3+keylength);
+		/* _rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[psecuritypriv->dot11PrivacyKeyIndex].skey[0],keylength); */
+		_rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[keyindex].skey[0], keylength);
+		length = ((union recv_frame *)precvframe)->u.hdr.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
-		*((u32 *)crc)=le32_to_cpu(getcrc32(payload,length-4));
-		
-		if(crc[3]!=payload[length-1] || crc[2]!=payload[length-2] || crc[1]!=payload[length-3] || crc[0]!=payload[length-4])
-		{
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_wep_decrypt:icv error crc[3](%x)!=payload[length-1](%x) || crc[2](%x)!=payload[length-2](%x) || crc[1](%x)!=payload[length-3](%x) || crc[0](%x)!=payload[length-4](%x)\n",
-						crc[3],payload[length-1],crc[2],payload[length-2],crc[1],payload[length-3],crc[0],payload[length-4]));
-		}
+
+		/* calculate icv and compare the icv */
+		*((u32 *)crc) = le32_to_cpu(getcrc32(payload, length - 4));
+
 
 		WEP_SW_DEC_CNT_INC(psecuritypriv, prxattrib->ra);
 	}
-	
-_func_exit_;		
+
 
 	return;
-	
+
 }
 
-//3 		=====TKIP related=====
+/* 3		=====TKIP related===== */
 
-static u32 secmicgetuint32( u8 * p )
-// Convert from Byte[] to Us4Byte32 in a portable way
+static u32 secmicgetuint32(u8 *p)
+/* Convert from Byte[] to Us4Byte32 in a portable way */
 {
 	s32 i;
 	u32 res = 0;
-_func_enter_;		
-	for( i=0; i<4; i++ )
-	{
-		res |= ((u32)(*p++)) << (8*i);
-	}
-_func_exit_;		
+	for (i = 0; i < 4; i++)
+		res |= ((u32)(*p++)) << (8 * i);
 	return res;
 }
 
-static void secmicputuint32( u8 * p, u32 val )
-// Convert from Us4Byte32 to Byte[] in a portable way
+static void secmicputuint32(u8 *p, u32 val)
+/* Convert from Us4Byte32 to Byte[] in a portable way */
 {
 	long i;
-_func_enter_;			
-	for( i=0; i<4; i++ )
-	{
-		*p++ = (u8) (val & 0xff);
+	for (i = 0; i < 4; i++) {
+		*p++ = (u8)(val & 0xff);
 		val >>= 8;
 	}
-_func_exit_;		
 }
 
 static void secmicclear(struct mic_data *pmicdata)
 {
-// Reset the state to the empty message.
-_func_enter_;	
+	/* Reset the state to the empty message. */
 	pmicdata->L = pmicdata->K0;
 	pmicdata->R = pmicdata->K1;
 	pmicdata->nBytesInM = 0;
 	pmicdata->M = 0;
-_func_exit_;	
 }
 
-void rtw_secmicsetkey(struct mic_data *pmicdata, u8 * key )
+void rtw_secmicsetkey(struct mic_data *pmicdata, u8 *key)
 {
-	// Set the key
-_func_enter_;		
-	pmicdata->K0 = secmicgetuint32( key );
-	pmicdata->K1 = secmicgetuint32( key + 4 );
-	// and reset the message
+	/* Set the key */
+	pmicdata->K0 = secmicgetuint32(key);
+	pmicdata->K1 = secmicgetuint32(key + 4);
+	/* and reset the message */
 	secmicclear(pmicdata);
-_func_exit_;		
 }
 
-void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b )
+void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b)
 {
-_func_enter_;	
-	// Append the byte to our word-sized buffer
-	pmicdata->M |= ((unsigned long)b) << (8*pmicdata->nBytesInM);
+	/* 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 )
-	{
+	/* Process the word if it is full. */
+	if (pmicdata->nBytesInM >= 4) {
 		pmicdata->L ^= pmicdata->M;
-		pmicdata->R ^= ROL32( pmicdata->L, 17 );
+		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->R ^= ROL32(pmicdata->L, 3);
 		pmicdata->L += pmicdata->R;
-		pmicdata->R ^= ROR32( pmicdata->L, 2 );
+		pmicdata->R ^= ROR32(pmicdata->L, 2);
 		pmicdata->L += pmicdata->R;
-		// Clear the buffer
+		/* Clear the buffer */
 		pmicdata->M = 0;
 		pmicdata->nBytesInM = 0;
 	}
-_func_exit_;			
 }
 
-void rtw_secmicappend(struct mic_data *pmicdata, u8 * src, u32 nbytes )
+void rtw_secmicappend(struct mic_data *pmicdata, u8 *src, u32 nbytes)
 {
-_func_enter_;	
-	// This is simple
-	while( nbytes > 0 )
-	{
-		rtw_secmicappendbyte(pmicdata, *src++ );
+	/* This is simple */
+	while (nbytes > 0) {
+		rtw_secmicappendbyte(pmicdata, *src++);
 		nbytes--;
 	}
-_func_exit_;			
 }
 
-void rtw_secgetmic(struct mic_data *pmicdata, u8 * dst )
+void rtw_secgetmic(struct mic_data *pmicdata, u8 *dst)
 {
-_func_enter_;	
-	// Append the minimum padding
-	rtw_secmicappendbyte(pmicdata, 0x5a );
-	rtw_secmicappendbyte(pmicdata, 0 );
-	rtw_secmicappendbyte(pmicdata, 0 );
-	rtw_secmicappendbyte(pmicdata, 0 );
-	rtw_secmicappendbyte(pmicdata, 0 );
-	// and then zeroes until the length is a multiple of 4
-	while( pmicdata->nBytesInM != 0 )
-	{
-		rtw_secmicappendbyte(pmicdata, 0 );
-	}
-	// The appendByte function has already computed the result.
-	secmicputuint32( dst, pmicdata->L );
-	secmicputuint32( dst+4, pmicdata->R );
-	// Reset to the empty message.
+	/* Append the minimum padding */
+	rtw_secmicappendbyte(pmicdata, 0x5a);
+	rtw_secmicappendbyte(pmicdata, 0);
+	rtw_secmicappendbyte(pmicdata, 0);
+	rtw_secmicappendbyte(pmicdata, 0);
+	rtw_secmicappendbyte(pmicdata, 0);
+	/* and then zeroes until the length is a multiple of 4 */
+	while (pmicdata->nBytesInM != 0)
+		rtw_secmicappendbyte(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);
-_func_exit_;		
 }
 
 
-void rtw_seccalctkipmic(u8 * key,u8 *header,u8 *data,u32 data_len,u8 *mic_code, u8 pri)
+void rtw_seccalctkipmic(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};
-_func_enter_;		
+	u8 priority[4] = {0x0, 0x0, 0x0, 0x0};
 	rtw_secmicsetkey(&micdata, key);
-	priority[0]=pri;
-	
+	priority[0] = pri;
+
 	/* Michael MIC pseudo header: DA, SA, 3 x 0, Priority */
-	if(header[1]&1){   //ToDS==1
-			rtw_secmicappend(&micdata, &header[16], 6);  //DA
-		if(header[1]&2)  //From Ds==1
+	if (header[1] & 1) { /* ToDS==1 */
+		rtw_secmicappend(&micdata, &header[16], 6);  /* DA */
+		if (header[1] & 2) /* From Ds==1 */
 			rtw_secmicappend(&micdata, &header[24], 6);
 		else
-			rtw_secmicappend(&micdata, &header[10], 6);		
-	}	
-	else{	//ToDS==0
-		rtw_secmicappend(&micdata, &header[4], 6);   //DA
-		if(header[1]&2)  //From Ds==1
+			rtw_secmicappend(&micdata, &header[10], 6);
+	} else {	/* ToDS==0 */
+		rtw_secmicappend(&micdata, &header[4], 6);   /* DA */
+		if (header[1] & 2) /* From Ds==1 */
 			rtw_secmicappend(&micdata, &header[16], 6);
 		else
 			rtw_secmicappend(&micdata, &header[10], 6);
@@ -506,113 +459,112 @@ _func_enter_;
 	}
 	rtw_secmicappend(&micdata, &priority[0], 4);
 
-	
+
 	rtw_secmicappend(&micdata, data, data_len);
 
-	rtw_secgetmic(&micdata,mic_code);
-_func_exit_;	
+	rtw_secgetmic(&micdata, mic_code);
 }
 
 
 
 
-/* macros for extraction/creation of unsigned char/unsigned short values  */
+/* 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   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))
+#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)])
+/* 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 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)     */
+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,
-  }
+		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
 *
@@ -629,31 +581,29 @@ static const unsigned short Sbox1[2][256]=       /* Sbox for hash (can be in ROM
 *
 **********************************************************************
 */
-static void phase1(u16 *p1k,const u8 *tk,const u8 *ta,u32 iv32)
+static void phase1(u16 *p1k, const u8 *tk, const u8 *ta, u32 iv32)
 {
 	sint  i;
-_func_enter_;
-	/* Initialize the 80 bits of P1K[] from IV32 and TA[0..5]     */
+	/* 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]);
+	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" */
-        }
-_func_exit_;
-}
- 
+	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" */
+	}
+}
+
 
 /*
 **********************************************************************
@@ -678,55 +628,54 @@ _func_exit_;
 *
 **********************************************************************
 */
-static void phase2(u8 *rc4key,const u8 *tk,const u16 *p1k,u16 iv16)
+static void phase2(u8 *rc4key, const u8 *tk, const u16 *p1k, u16 iv16)
 {
 	sint  i;
-	u16 PPK[6];                          /* temporary key for mixing    */
-_func_enter_;
-	/* 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          */
+	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]           */
+	/* 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  */
+	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[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   */
+	/*       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}.               */
+	/*       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[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]);
+
+	/* 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]);
 	}
-_func_exit_;	
 }
 
 
-//The hlen isn't include the IV
+/* The hlen isn't include the IV */
 u32	rtw_tkip_encrypt(_adapter *padapter, u8 *pxmitframe)
-{																	// exclude ICV
+{
+	/* exclude ICV */
 	u16	pnl;
 	u32	pnh;
 	u8	rc4key[16];
@@ -734,162 +683,151 @@ u32	rtw_tkip_encrypt(_adapter *padapter, u8 *pxmitframe)
 	u8	crc[4];
 	u8   hw_hdr_offset = 0;
 	struct arc4context mycontext;
-	sint 			curfragnum,length;
+	sint			curfragnum, length;
 	u32	prwskeylen;
 
-	u8	*pframe, *payload,*iv,*prwskey;
+	u8	*pframe, *payload, *iv, *prwskey;
 	union pn48 dot11txpn;
-	//struct	sta_info		*stainfo;
-	struct	pkt_attrib	 *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
-	struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
-	struct	xmit_priv		*pxmitpriv=&padapter->xmitpriv;
-	u32	res=_SUCCESS;
-_func_enter_;
-
-	if(((struct xmit_frame*)pxmitframe)->buf_addr==NULL)
+	/* struct	sta_info		*stainfo; */
+	struct	pkt_attrib	*pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
+	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
+	struct	xmit_priv		*pxmitpriv = &padapter->xmitpriv;
+	u32	res = _SUCCESS;
+
+	if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
 		return _FAIL;
 
 #ifdef CONFIG_USB_TX_AGGREGATION
 	hw_hdr_offset = TXDESC_SIZE +
-		 (((struct xmit_frame*)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);	
+		(((struct xmit_frame *)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);
+#else
+#ifdef CONFIG_TX_EARLY_MODE
+	hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
 #else
-	#ifdef CONFIG_TX_EARLY_MODE
-	hw_hdr_offset = TXDESC_OFFSET+EARLY_MODE_INFO_SIZE;
-	#else
 	hw_hdr_offset = TXDESC_OFFSET;
-	#endif
+#endif
 #endif
 
-	pframe = ((struct xmit_frame*)pxmitframe)->buf_addr + hw_hdr_offset;
-	//4 start to encrypt each fragment
-	if(pattrib->encrypt==_TKIP_){
+	pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + hw_hdr_offset;
+	/* 4 start to encrypt each fragment */
+	if (pattrib->encrypt == _TKIP_) {
 
-/*
-		if(pattrib->psta)
-		{
-			stainfo = pattrib->psta;
-		}
-		else
-		{
-			DBG_871X("%s, call rtw_get_stainfo()\n", __func__);
-			stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
-		}	
-*/	
-		//if (stainfo!=NULL)
+		/*
+				if(pattrib->psta)
+				{
+					stainfo = pattrib->psta;
+				}
+				else
+				{
+					RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+					stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
+				}
+		*/
+		/* if (stainfo!=NULL) */
 		{
-/*
-			if(!(stainfo->state &_FW_LINKED))
-			{
-				DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
-				return _FAIL;
-			}
-*/			
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_tkip_encrypt: stainfo!=NULL!!!\n"));
+			/*
+						if(!(stainfo->state &_FW_LINKED))
+						{
+							RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
+							return _FAIL;
+						}
+			*/
 
-			if(IS_MCAST(pattrib->ra))
-			{
-				prwskey=psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
-			}
-			else
-			{
-				//prwskey=&stainfo->dot118021x_UncstKey.skey[0];
-				prwskey=pattrib->dot118021x_UncstKey.skey;
+			if (IS_MCAST(pattrib->ra))
+				prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
+			else {
+				/* prwskey=&stainfo->dot118021x_UncstKey.skey[0]; */
+				prwskey = pattrib->dot118021x_UncstKey.skey;
 			}
 
-			prwskeylen=16;
+			prwskeylen = 16;
+
+			for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
+				iv = pframe + pattrib->hdrlen;
+				payload = pframe + pattrib->iv_len + pattrib->hdrlen;
 
-			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);
+				pnl = (u16)(dot11txpn.val);
+				pnh = (u32)(dot11txpn.val >> 16);
 
-				phase1((u16 *)&ttkey[0],prwskey,&pattrib->ta[0],pnh);
+				phase1((u16 *)&ttkey[0], prwskey, &pattrib->ta[0], pnh);
 
-				phase2(&rc4key[0],prwskey,(u16 *)&ttkey[0],pnl);	
+				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));
-					*((u32 *)crc)=cpu_to_le32(getcrc32(payload,length));/* modified by Amy*/
+				if ((curfragnum + 1) == pattrib->nr_frags) {	/* 4 the last fragment */
+					length = pattrib->last_txcmdsz - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
+					*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length)); /* modified by Amy*/
 
-					arcfour_init(&mycontext, rc4key,16);
+					arcfour_init(&mycontext, rc4key, 16);
 					arcfour_encrypt(&mycontext, payload, payload, length);
-					arcfour_encrypt(&mycontext, payload+length, crc, 4);
+					arcfour_encrypt(&mycontext, payload + length, crc, 4);
 
-				}
-				else{
-					length=pxmitpriv->frag_len-pattrib->hdrlen-pattrib->iv_len-pattrib->icv_len ;
-					*((u32 *)crc)=cpu_to_le32(getcrc32(payload,length));/* modified by Amy*/
-					arcfour_init(&mycontext,rc4key,16);
+				} else {
+					length = pxmitpriv->frag_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len ;
+					*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length)); /* modified by Amy*/
+					arcfour_init(&mycontext, rc4key, 16);
 					arcfour_encrypt(&mycontext, payload, payload, length);
-					arcfour_encrypt(&mycontext, payload+length, crc, 4);
-	
-				pframe+=pxmitpriv->frag_len;
-				pframe=(u8 *)RND4((SIZE_PTR)(pframe));
+					arcfour_encrypt(&mycontext, payload + length, crc, 4);
+
+					pframe += pxmitpriv->frag_len;
+					pframe = (u8 *)RND4((SIZE_PTR)(pframe));
 
 				}
 			}
 
-			TKIP_SW_ENC_CNT_INC(psecuritypriv,pattrib->ra);
-		}
-/*
-		else{
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_tkip_encrypt: stainfo==NULL!!!\n"));
-                        DBG_871X("%s, psta==NUL\n", __func__);
-			res=_FAIL;
+			TKIP_SW_ENC_CNT_INC(psecuritypriv, pattrib->ra);
 		}
-*/		
-						
+		/*
+				else{
+					RTW_INFO("%s, psta==NUL\n", __func__);
+					res=_FAIL;
+				}
+		*/
+
 	}
-_func_exit_;	
 	return res;
-				
+
 }
 
 
-//The hlen isn't include the IV
+/* The hlen isn't include the IV */
 u32 rtw_tkip_decrypt(_adapter *padapter, u8 *precvframe)
-{																	// exclude ICV
+{
+	/* exclude ICV */
 	u16 pnl;
 	u32 pnh;
 	u8   rc4key[16];
 	u8   ttkey[16];
 	u8	crc[4];
 	struct arc4context mycontext;
-	sint 			length;
+	sint			length;
 	u32	prwskeylen;
 
-	u8	*pframe, *payload,*iv,*prwskey;
+	u8	*pframe, *payload, *iv, *prwskey;
 	union pn48 dot11txpn;
 	struct	sta_info		*stainfo;
-	struct	rx_pkt_attrib	 *prxattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
-	struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
-//	struct	recv_priv		*precvpriv=&padapter->recvpriv;
-	u32		res=_SUCCESS;
+	struct	rx_pkt_attrib	*prxattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
+	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
+	/*	struct	recv_priv		*precvpriv=&padapter->recvpriv; */
+	u32		res = _SUCCESS;
 
-_func_enter_;
 
-	pframe=(unsigned char *)((union recv_frame*)precvframe)->u.hdr.rx_data;
-	
-	//4 start to decrypt recvframe
-	if(prxattrib->encrypt==_TKIP_){
+	pframe = (unsigned char *)((union recv_frame *)precvframe)->u.hdr.rx_data;
 
-		stainfo=rtw_get_stainfo(&padapter->stapriv ,&prxattrib->ta[0] );
-		if (stainfo!=NULL){
+	/* 4 start to decrypt recvframe */
+	if (prxattrib->encrypt == _TKIP_) {
 
-			if(IS_MCAST(prxattrib->ra))
-			{
-				static u32 start = 0;
+		stainfo = rtw_get_stainfo(&padapter->stapriv , &prxattrib->ta[0]);
+		if (stainfo != NULL) {
+
+			if (IS_MCAST(prxattrib->ra)) {
+				static systime start = 0;
 				static u32 no_gkey_bc_cnt = 0;
 				static u32 no_gkey_mc_cnt = 0;
 
-				if(psecuritypriv->binstallGrpkey==_FALSE)
-				{
-					res=_FAIL;
+				if (psecuritypriv->binstallGrpkey == _FALSE) {
+					res = _FAIL;
 
 					if (start == 0)
 						start = rtw_get_current_time();
@@ -901,7 +839,7 @@ _func_enter_;
 
 					if (rtw_get_passing_time_ms(start) > 1000) {
 						if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
-							DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
+							RTW_PRINT(FUNC_ADPT_FMT" no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
 								FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
 						}
 						start = rtw_get_current_time();
@@ -912,66 +850,58 @@ _func_enter_;
 				}
 
 				if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
-					DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" gkey installed. no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
+					RTW_PRINT(FUNC_ADPT_FMT" gkey installed. no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
 						FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
 				}
 				start = 0;
 				no_gkey_bc_cnt = 0;
 				no_gkey_mc_cnt = 0;
 
-				//DBG_871X("rx bc/mc packets, to perform sw rtw_tkip_decrypt\n");
-				//prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
+				/* RTW_INFO("rx bc/mc packets, to perform sw rtw_tkip_decrypt\n"); */
+				/* prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey; */
 				prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
-				prwskeylen=16;
+				prwskeylen = 16;
+			} else {
+				prwskey = &stainfo->dot118021x_UncstKey.skey[0];
+				prwskeylen = 16;
 			}
-			else
-			{
-				prwskey=&stainfo->dot118021x_UncstKey.skey[0];
-				prwskeylen=16;
-			}
-			
-			iv=pframe+prxattrib->hdrlen;
-			payload=pframe+prxattrib->iv_len+prxattrib->hdrlen;
-			length= ((union recv_frame *)precvframe)->u.hdr.len-prxattrib->hdrlen-prxattrib->iv_len;
-				
+
+			iv = pframe + prxattrib->hdrlen;
+			payload = pframe + prxattrib->iv_len + prxattrib->hdrlen;
+			length = ((union recv_frame *)precvframe)->u.hdr.len - prxattrib->hdrlen - prxattrib->iv_len;
+
 			GET_TKIP_PN(iv, dot11txpn);
 
-			pnl=(u16)(dot11txpn.val);
-			pnh=(u32)(dot11txpn.val>>16);
+			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);
 
-			phase1((u16 *)&ttkey[0],prwskey,&prxattrib->ta[0],pnh);
-			phase2(&rc4key[0],prwskey,(unsigned short *)&ttkey[0],pnl);	
+			/* 4 decrypt payload include icv */
 
-			//4 decrypt payload include icv
-					
-			arcfour_init(&mycontext, rc4key,16);
+			arcfour_init(&mycontext, rc4key, 16);
 			arcfour_encrypt(&mycontext, payload, payload, length);
 
-			*((u32 *)crc)=le32_to_cpu(getcrc32(payload,length-4));
+			*((u32 *)crc) = le32_to_cpu(getcrc32(payload, length - 4));
 
-			if(crc[3]!=payload[length-1] || crc[2]!=payload[length-2] || crc[1]!=payload[length-3] || crc[0]!=payload[length-4])
-			{
-			    RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_wep_decrypt:icv error crc[3](%x)!=payload[length-1](%x) || crc[2](%x)!=payload[length-2](%x) || crc[1](%x)!=payload[length-3](%x) || crc[0](%x)!=payload[length-4](%x)\n",
-						crc[3],payload[length-1],crc[2],payload[length-2],crc[1],payload[length-3],crc[0],payload[length-4]));
-				res=_FAIL;
+			if (crc[3] != payload[length - 1] || crc[2] != payload[length - 2] || crc[1] != payload[length - 3] || crc[0] != payload[length - 4]) {
+				res = _FAIL;
 			}
 
 			TKIP_SW_DEC_CNT_INC(psecuritypriv, prxattrib->ra);
+		} else {
+			res = _FAIL;
 		}
-		else{
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_tkip_decrypt: stainfo==NULL!!!\n"));
-			res=_FAIL;
-		}
-						
+
 	}
-_func_exit_;	
 exit:
 	return res;
-				
+
 }
 
 
-//3			=====AES related=====
+/* 3			=====AES related===== */
 
 
 
@@ -980,41 +910,40 @@ exit:
 /******** 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
-    };
+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 ****/
@@ -1022,31 +951,31 @@ exit:
 
 static void bitwise_xor(u8 *ina, u8 *inb, u8 *out);
 static void construct_mic_iv(
-                        u8 *mic_header1,
-                        sint qc_exists,
-                        sint a4_exists,
-                        u8 *mpdu,
-                        uint payload_length,
-                        u8 * pn_vector,
-                        uint frtype);// add for CONFIG_IEEE80211W, none 11w also can use
+	u8 *mic_header1,
+	sint qc_exists,
+	sint a4_exists,
+	u8 *mpdu,
+	uint payload_length,
+	u8 *pn_vector,
+	uint frtype);/* add for CONFIG_IEEE80211W, none 11w also can use */
 static void construct_mic_header1(
-                        u8 *mic_header1,
-                        sint header_length,
-                        u8 *mpdu,
-                        uint frtype);// add for CONFIG_IEEE80211W, none 11w also can use
+	u8 *mic_header1,
+	sint header_length,
+	u8 *mpdu,
+	uint frtype);/* add for CONFIG_IEEE80211W, none 11w also can use */
 static void construct_mic_header2(
-                    u8 *mic_header2,
-                    u8 *mpdu,
-                    sint a4_exists,
-                    sint qc_exists);
+	u8 *mic_header2,
+	u8 *mpdu,
+	sint a4_exists,
+	sint qc_exists);
 static void construct_ctr_preload(
-                        u8 *ctr_preload,
-                        sint a4_exists,
-                        sint qc_exists,
-                        u8 *mpdu,
-                        u8 *pn_vector,
-                        sint c,
-                        uint frtype);// add for CONFIG_IEEE80211W, none 11w also can use
+	u8 *ctr_preload,
+	sint a4_exists,
+	sint qc_exists,
+	u8 *mpdu,
+	u8 *pn_vector,
+	sint c,
+	uint frtype);/* add for CONFIG_IEEE80211W, none 11w also can use */
 static void xor_128(u8 *a, u8 *b, u8 *out);
 static void xor_32(u8 *a, u8 *b, u8 *out);
 static u8 sbox(u8 a);
@@ -1054,417 +983,379 @@ static void next_key(u8 *key, sint round);
 static void byte_sub(u8 *in, u8 *out);
 static void shift_row(u8 *in, u8 *out);
 static void mix_column(u8 *in, u8 *out);
-#ifndef PLATFORM_FREEBSD 
-static void add_round_key( u8 *shiftrow_in,
-                    u8 *mcol_in,
-                    u8 *block_in,
-                    sint round,
-                    u8 *out);
-#endif //PLATFORM_FREEBSD
+#ifndef PLATFORM_FREEBSD
+static void add_round_key(u8 *shiftrow_in,
+			  u8 *mcol_in,
+			  u8 *block_in,
+			  sint round,
+			  u8 *out);
+#endif /* PLATFORM_FREEBSD */
 static void aes128k128d(u8 *key, u8 *data, u8 *ciphertext);
 
 
 /****************************************/
-/* aes128k128d()                        */
-/* Performs a 128 bit AES encrypt with  */
-/* 128 bit data.                        */
+/* aes128k128d()                       */
+/* Performs a 128 bit AES encrypt with */
+/* 128 bit data.                       */
 /****************************************/
 static void xor_128(u8 *a, u8 *b, u8 *out)
 {
-    sint i;
-_func_enter_;	
-    for (i=0;i<16; i++)
-    {
-        out[i] = a[i] ^ b[i];
-    }
-_func_exit_;		
+	sint i;
+	for (i = 0; i < 16; i++)
+		out[i] = a[i] ^ b[i];
 }
 
 
 static void xor_32(u8 *a, u8 *b, u8 *out)
 {
-    sint i;
-_func_enter_;		
-    for (i=0;i<4; i++)
-    {
-        out[i] = a[i] ^ b[i];
-    }
-_func_exit_;		
+	sint i;
+	for (i = 0; i < 4; i++)
+		out[i] = a[i] ^ b[i];
 }
 
 
 static u8 sbox(u8 a)
 {
-    return sbox_table[(sint)a];
+	return sbox_table[(sint)a];
 }
 
 
 static void next_key(u8 *key, sint round)
 {
-    u8 rcon;
-    u8 sbox_key[4];
-    u8 rcon_table[12] =
-    {
-        0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80,
-        0x1b, 0x36, 0x36, 0x36
-    };
-_func_enter_;		
-    sbox_key[0] = sbox(key[13]);
-    sbox_key[1] = sbox(key[14]);
-    sbox_key[2] = sbox(key[15]);
-    sbox_key[3] = sbox(key[12]);
+	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];
+	rcon = rcon_table[round];
 
-    xor_32(&key[0], sbox_key, &key[0]);
-    key[0] = key[0] ^ rcon;
+	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]);
-_func_exit_;		
+	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)
 {
-    sint i;
-_func_enter_;			
-    for (i=0; i< 16; i++)
-    {
-        out[i] = sbox(in[i]);
-    }
-_func_exit_;	
+	sint i;
+	for (i = 0; i < 16; i++)
+		out[i] = sbox(in[i]);
 }
 
 
 static void shift_row(u8 *in, u8 *out)
 {
-_func_enter_;	
-    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];
-_func_exit_;		
+	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)
 {
-    sint 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];
-_func_enter_;	
-    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);
-_func_exit_;		
+	sint 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)
 {
-    sint round;
-    sint i;
-    u8 intermediatea[16];
-    u8 intermediateb[16];
-    u8 round_key[16];
-_func_enter_;	
-    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);
-        }
-    }
-_func_exit_;	
+	sint round;
+	sint 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  */
-/* Baron think the function is construct CCM    */
-/* nonce                                        */
+/* construct_mic_iv()                          */
+/* Builds the MIC IV from header fields and PN */
+/* Baron think the function is construct CCM   */
+/* nonce                                       */
 /************************************************/
 static void construct_mic_iv(
-                        u8 *mic_iv,
-                        sint qc_exists,
-                        sint a4_exists,
-                        u8 *mpdu,
-                        uint payload_length,
-                        u8 *pn_vector,
-                        uint frtype// add for CONFIG_IEEE80211W, none 11w also can use
-                        )
-{
-    sint i;
-_func_enter_;	
-    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;
-#ifdef CONFIG_IEEE80211W
-	//802.11w management frame should set management bit(4)
-    if(frtype == WIFI_MGT_TYPE)
+	u8 *mic_iv,
+	sint qc_exists,
+	sint a4_exists,
+	u8 *mpdu,
+	uint payload_length,
+	u8 *pn_vector,
+	uint frtype/* add for CONFIG_IEEE80211W, none 11w also can use */
+)
+{
+	sint 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;
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+	/* 802.11w management frame should set management bit(4) */
+	if (frtype == WIFI_MGT_TYPE)
 		mic_iv[1] |= BIT(4);
-#endif //CONFIG_IEEE80211W
-    for (i = 2; i < 8; i++)
-        mic_iv[i] = mpdu[i + 8];                    /* mic_iv[2:7] = A2[0:5] = mpdu[10:15] */
-    #ifdef CONSISTENT_PN_ORDER
-        for (i = 8; i < 14; i++)
-            mic_iv[i] = pn_vector[i - 8];           /* mic_iv[8:13] = PN[0:5] */
-    #else
-        for (i = 8; i < 14; i++)
-            mic_iv[i] = pn_vector[13 - i];          /* mic_iv[8:13] = PN[5:0] */
-    #endif
-    mic_iv[14] = (unsigned char) (payload_length / 256);
-    mic_iv[15] = (unsigned char) (payload_length % 256);
-_func_exit_;		
+#endif
+	for (i = 2; i < 8; i++)
+		mic_iv[i] = mpdu[i + 8];                    /* mic_iv[2:7] = A2[0:5] = mpdu[10:15] */
+#ifdef CONSISTENT_PN_ORDER
+	for (i = 8; i < 14; i++)
+		mic_iv[i] = pn_vector[i - 8];           /* mic_iv[8:13] = PN[0:5] */
+#else
+	for (i = 8; i < 14; i++)
+		mic_iv[i] = pn_vector[13 - i];          /* mic_iv[8:13] = PN[5:0] */
+#endif
+	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.                               */
-/* Build AAD SC,A1,A2                           */
+/* construct_mic_header1()                     */
+/* Builds the first MIC header block from      */
+/* header fields.                              */
+/* Build AAD SC,A1,A2                          */
 /************************************************/
 static void construct_mic_header1(
-                        u8 *mic_header1,
-                        sint header_length,
-                        u8 *mpdu,
-                        uint frtype// add for CONFIG_IEEE80211W, none 11w also can use
-                        )
-{
-_func_enter_;	
-    mic_header1[0] = (u8)((header_length - 2) / 256);
-    mic_header1[1] = (u8)((header_length - 2) % 256);
-#ifdef CONFIG_IEEE80211W
-    //802.11w management frame don't AND subtype bits 4,5,6 of frame control field
-    if(frtype == WIFI_MGT_TYPE)
+	u8 *mic_header1,
+	sint header_length,
+	u8 *mpdu,
+	uint frtype/* add for CONFIG_IEEE80211W, none 11w also can use */
+)
+{
+	mic_header1[0] = (u8)((header_length - 2) / 256);
+	mic_header1[1] = (u8)((header_length - 2) % 256);
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+	/* 802.11w management frame don't AND subtype bits 4,5,6 of frame control field */
+	if (frtype == WIFI_MGT_TYPE)
 		mic_header1[2] = mpdu[0];
 	else
-#endif //CONFIG_IEEE80211W
+#endif
 		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];
-_func_exit_;	
+
+	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.                               */
+/* construct_mic_header2()                     */
+/* Builds the last MIC header block from       */
+/* header fields.                              */
 /************************************************/
 static void construct_mic_header2(
-                u8 *mic_header2,
-                u8 *mpdu,
-                sint a4_exists,
-                sint qc_exists
-                )
+	u8 *mic_header2,
+	u8 *mpdu,
+	sint a4_exists,
+	sint qc_exists
+)
 {
-    sint i;
-_func_enter_;	
-    for (i = 0; i<16; i++) mic_header2[i]=0x00;
+	sint 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[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] = mpdu[22] & 0xf0;   /* SC */
-    mic_header2[6] = 0x00;
-    mic_header2[7] = 0x00; /* mpdu[23]; */
+	/* mic_header2[6] = mpdu[22] & 0xf0;    SC */
+	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) {
+		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) {
+		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 */
+	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;
-    }
+		mic_header2[14] = mpdu[30] & 0x0f;
+		mic_header2[15] = mpdu[31] & 0x00;
+	}
 
-_func_exit_;	
 }
 
 
 /************************************************/
-/* construct_mic_header2()                      */
-/* Builds the last MIC header block from        */
-/* header fields.                               */
-/* Baron think the function is construct CCM    */
-/* nonce                                        */
+/* construct_mic_header2()                     */
+/* Builds the last MIC header block from       */
+/* header fields.                              */
+/* Baron think the function is construct CCM   */
+/* nonce                                       */
 /************************************************/
 static void construct_ctr_preload(
-                        u8 *ctr_preload,
-                        sint a4_exists,
-                        sint qc_exists,
-                        u8 *mpdu,
-                        u8 *pn_vector,
-                        sint c,
-                        uint frtype // add for CONFIG_IEEE80211W, none 11w also can use
-                        )
-{
-    sint i = 0;
-_func_enter_;		
-    for (i=0; i<16; i++) ctr_preload[i] = 0x00;
-    i = 0;
-	
-    ctr_preload[0] = 0x01;                                  /* flag */
-    if (qc_exists && a4_exists) 
+	u8 *ctr_preload,
+	sint a4_exists,
+	sint qc_exists,
+	u8 *mpdu,
+	u8 *pn_vector,
+	sint c,
+	uint frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
+)
+{
+	sint 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) 
+	if (qc_exists && !a4_exists)
 		ctr_preload[1] = mpdu[24] & 0x0f;
-#ifdef CONFIG_IEEE80211W
-	//802.11w management frame should set management bit(4)
-	if(frtype == WIFI_MGT_TYPE)
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+	/* 802.11w management frame should set management bit(4) */
+	if (frtype == WIFI_MGT_TYPE)
 		ctr_preload[1] |= BIT(4);
-#endif //CONFIG_IEEE80211W
-    for (i = 2; i < 8; i++)
-        ctr_preload[i] = mpdu[i + 8];                       /* ctr_preload[2:7] = A2[0:5] = mpdu[10:15] */
-    #ifdef CONSISTENT_PN_ORDER
-      for (i = 8; i < 14; i++)
-            ctr_preload[i] =    pn_vector[i - 8];           /* ctr_preload[8:13] = PN[0:5] */
-    #else
-      for (i = 8; i < 14; i++)
-            ctr_preload[i] =    pn_vector[13 - i];          /* ctr_preload[8:13] = PN[5:0] */
-    #endif
-    ctr_preload[14] =  (unsigned char) (c / 256); /* Ctr */
-    ctr_preload[15] =  (unsigned char) (c % 256);
-_func_exit_;		
+#endif
+	for (i = 2; i < 8; i++)
+		ctr_preload[i] = mpdu[i + 8];                       /* ctr_preload[2:7] = A2[0:5] = mpdu[10:15] */
+#ifdef CONSISTENT_PN_ORDER
+	for (i = 8; i < 14; i++)
+		ctr_preload[i] =    pn_vector[i - 8];           /* ctr_preload[8:13] = PN[0:5] */
+#else
+	for (i = 8; i < 14; i++)
+		ctr_preload[i] =    pn_vector[13 - i];          /* ctr_preload[8:13] = PN[5:0] */
+#endif
+	ctr_preload[14] = (unsigned char)(c / 256);   /* Ctr */
+	ctr_preload[15] = (unsigned char)(c % 256);
 }
 
 
 /************************************/
-/* bitwise_xor()                    */
-/* A 128 bit, bitwise exclusive or  */
+/* bitwise_xor()                   */
+/* A 128 bit, bitwise exclusive or */
 /************************************/
 static void bitwise_xor(u8 *ina, u8 *inb, u8 *out)
 {
-    sint i;
-_func_enter_;		
-    for (i=0; i<16; i++)
-    {
-        out[i] = ina[i] ^ inb[i];
-    }
-_func_exit_;		
+	sint i;
+	for (i = 0; i < 16; i++)
+		out[i] = ina[i] ^ inb[i];
 }
 
 
 static sint aes_cipher(u8 *key, uint	hdrlen,
-			u8 *pframe, uint plen)
+		       u8 *pframe, uint plen)
 {
-//	/*static*/ unsigned char	message[MAX_MSG_SIZE];
+	/*	static unsigned char	message[MAX_MSG_SIZE]; */
 	uint	qc_exists, a4_exists, i, j, payload_remainder,
 		num_blocks, payload_index;
 
@@ -1479,12 +1370,11 @@ static sint aes_cipher(u8 *key, uint	hdrlen,
 	u8 aes_out[16];
 	u8 padded_buffer[16];
 	u8 mic[8];
-//	uint	offset = 0;
+	/*	uint	offset = 0; */
 	uint	frtype  = GetFrameType(pframe);
-	uint	frsubtype  = GetFrameSubType(pframe);
-	
-_func_enter_;		
-	frsubtype=frsubtype>>4;
+	uint	frsubtype  = get_frame_sub_type(pframe);
+
+	frsubtype = frsubtype >> 4;
 
 
 	_rtw_memset((void *)mic_iv, 0, 16);
@@ -1495,166 +1385,159 @@ _func_enter_;
 	_rtw_memset((void *)aes_out, 0, 16);
 	_rtw_memset((void *)padded_buffer, 0, 16);
 
-	if ((hdrlen == WLAN_HDR_A3_LEN )||(hdrlen ==  WLAN_HDR_A3_QOS_LEN))
+	if ((hdrlen == WLAN_HDR_A3_LEN) || (hdrlen ==  WLAN_HDR_A3_QOS_LEN))
 		a4_exists = 0;
 	else
 		a4_exists = 1;
 
 	if (
-		((frtype|frsubtype) == WIFI_DATA_CFACK) ||
-		((frtype|frsubtype) == WIFI_DATA_CFPOLL)||
-		((frtype|frsubtype) == WIFI_DATA_CFACKPOLL))
-		{
-			qc_exists = 1;
-					if(hdrlen !=  WLAN_HDR_A3_QOS_LEN){
-				 
-					hdrlen += 2;
-			}
-		}
-	// add for CONFIG_IEEE80211W, none 11w also can use
+		((frtype | frsubtype) == WIFI_DATA_CFACK) ||
+		((frtype | frsubtype) == WIFI_DATA_CFPOLL) ||
+		((frtype | frsubtype) == WIFI_DATA_CFACKPOLL)) {
+		qc_exists = 1;
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
+			hdrlen += 2;
+	}
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
 	else if ((frtype == WIFI_DATA) &&
-		((frsubtype == 0x08) ||
-		(frsubtype == 0x09)||
-		(frsubtype == 0x0a)||
-		(frsubtype == 0x0b)))
-		{
-			if(hdrlen !=  WLAN_HDR_A3_QOS_LEN){
-				 
-					hdrlen += 2;
-			}
-			qc_exists = 1;
-		}
-	else
+		 ((frsubtype == 0x08) ||
+		  (frsubtype == 0x09) ||
+		  (frsubtype == 0x0a) ||
+		  (frsubtype == 0x0b))) {
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
+			hdrlen += 2;
+		qc_exists = 1;
+	} 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];
-	
+	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,	 //message,
-                        plen,
-                        pn_vector,
-                        frtype // add for CONFIG_IEEE80211W, none 11w also can use
-                        );
-
-    construct_mic_header1(
-                            mic_header1,
-                            hdrlen,
-                            pframe,	//message
-                            frtype // add for CONFIG_IEEE80211W, none 11w also can use
-                            );
-    construct_mic_header2(
-                            mic_header2,
-                            pframe,	//message,
-                            a4_exists,
-                            qc_exists
-                            );
+		mic_iv,
+		qc_exists,
+		a4_exists,
+		pframe,	 /* message, */
+		plen,
+		pn_vector,
+		frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
+	);
+
+	construct_mic_header1(
+		mic_header1,
+		hdrlen,
+		pframe,	/* message */
+		frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
+	);
+	construct_mic_header2(
+		mic_header2,
+		pframe,	/* message, */
+		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);//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] = pframe[payload_index++];//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++)
-    	pframe[payload_index+j] = mic[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,
-                                pframe,	//message,
-                                pn_vector,
-                                i+1,
-                                frtype); // add for CONFIG_IEEE80211W, none 11w also can use
-        aes128k128d(key, ctr_preload, aes_out);
-        bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);//bitwise_xor(aes_out, &message[payload_index], chain_buffer);
-        for (j=0; j<16;j++) pframe[payload_index++] = chain_buffer[j];//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,
-                                pframe,	//message,
-                                pn_vector,
-                                num_blocks+1,
-                                frtype); // add for CONFIG_IEEE80211W, none 11w also can use
-
-        for (j = 0; j < 16; j++) padded_buffer[j] = 0x00;
-        for (j = 0; j < payload_remainder; j++)
-        {
-            padded_buffer[j] = pframe[payload_index+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++) pframe[payload_index++] = chain_buffer[j];//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,
-                        pframe,	//message,
-                        pn_vector,
-                        0,
-                        frtype); // add for CONFIG_IEEE80211W, none 11w also can use
-
-    for (j = 0; j < 16; j++) padded_buffer[j] = 0x00;
-    for (j = 0; j < 8; j++)
-    {
-        padded_buffer[j] = pframe[j+hdrlen+8+plen];//padded_buffer[j] = message[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];//for (j=0; j<8;j++) message[payload_index++] = chain_buffer[j];
-_func_exit_;		
+	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);/* 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] = pframe[payload_index++];/* 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++)
+		pframe[payload_index + j] = mic[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,
+			pframe,	/* message, */
+			pn_vector,
+			i + 1,
+			frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
+		aes128k128d(key, ctr_preload, aes_out);
+		bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);/* bitwise_xor(aes_out, &message[payload_index], chain_buffer); */
+		for (j = 0; j < 16; j++)
+			pframe[payload_index++] = chain_buffer[j];/* 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,
+			pframe,	/* message, */
+			pn_vector,
+			num_blocks + 1,
+			frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
+
+		for (j = 0; j < 16; j++)
+			padded_buffer[j] = 0x00;
+		for (j = 0; j < payload_remainder; j++) {
+			padded_buffer[j] = pframe[payload_index + 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++)
+			pframe[payload_index++] = chain_buffer[j];/* 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,
+		pframe,	/* message, */
+		pn_vector,
+		0,
+		frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
+
+	for (j = 0; j < 16; j++)
+		padded_buffer[j] = 0x00;
+	for (j = 0; j < 8; j++) {
+		padded_buffer[j] = pframe[j + hdrlen + 8 + plen]; /* padded_buffer[j] = message[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];/* for (j=0; j<8;j++) message[payload_index++] = chain_buffer[j]; */
 	return _SUCCESS;
 }
 
@@ -1663,131 +1546,123 @@ _func_exit_;
 
 
 u32	rtw_aes_encrypt(_adapter *padapter, u8 *pxmitframe)
-{	// exclude ICV
+{
+	/* exclude ICV */
 
 
-	/*static*/ 
-//	unsigned char	message[MAX_MSG_SIZE];
+	/*static*/
+	/*	unsigned char	message[MAX_MSG_SIZE]; */
 
-    	/* Intermediate Buffers */
-	sint 	curfragnum,length;
+	/* Intermediate Buffers */
+	sint	curfragnum, length;
 	u32	prwskeylen;
-	u8	*pframe,*prwskey;	//, *payload,*iv
+	u8	*pframe, *prwskey;	/* , *payload,*iv */
 	u8   hw_hdr_offset = 0;
-	//struct	sta_info		*stainfo=NULL;
-	struct	pkt_attrib	 *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
-	struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
-	struct	xmit_priv		*pxmitpriv=&padapter->xmitpriv;
+	/* struct	sta_info		*stainfo=NULL; */
+	struct	pkt_attrib	*pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
+	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
+	struct	xmit_priv		*pxmitpriv = &padapter->xmitpriv;
 
-//	uint	offset = 0;
-	u32 res=_SUCCESS;
-_func_enter_;		
+	/*	uint	offset = 0; */
+	u32 res = _SUCCESS;
 
-	if(((struct xmit_frame*)pxmitframe)->buf_addr==NULL)
+	if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
 		return _FAIL;
 
 #ifdef CONFIG_USB_TX_AGGREGATION
 	hw_hdr_offset = TXDESC_SIZE +
-		 (((struct xmit_frame*)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);
+		(((struct xmit_frame *)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);
+#else
+#ifdef CONFIG_TX_EARLY_MODE
+	hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
 #else
-	#ifdef CONFIG_TX_EARLY_MODE
-	hw_hdr_offset = TXDESC_OFFSET+EARLY_MODE_INFO_SIZE;
-	#else
 	hw_hdr_offset = TXDESC_OFFSET;
-	#endif	
+#endif
 #endif
 
-	pframe = ((struct xmit_frame*)pxmitframe)->buf_addr + hw_hdr_offset;
+	pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + hw_hdr_offset;
 
-	//4 start to encrypt each fragment
-	if((pattrib->encrypt==_AES_)){
-/*
-		if(pattrib->psta)
-		{
-			stainfo = pattrib->psta;
-		}
-		else
-		{
-			DBG_871X("%s, call rtw_get_stainfo()\n", __func__);
-			stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
-		}
-*/		
-		//if (stainfo!=NULL)
+	/* 4 start to encrypt each fragment */
+	if ((pattrib->encrypt == _AES_)) {
+		/*
+				if(pattrib->psta)
+				{
+					stainfo = pattrib->psta;
+				}
+				else
+				{
+					RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+					stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
+				}
+		*/
+		/* if (stainfo!=NULL) */
 		{
-/*
-			if(!(stainfo->state &_FW_LINKED))
-			{
-				DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
-				return _FAIL;
-			}
-*/
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_aes_encrypt: stainfo!=NULL!!!\n"));
+			/*
+						if(!(stainfo->state &_FW_LINKED))
+						{
+							RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
+							return _FAIL;
+						}
+			*/
 
-			if(IS_MCAST(pattrib->ra))
-			{
-				prwskey=psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
-			}
-			else
-			{
-				//prwskey=&stainfo->dot118021x_UncstKey.skey[0];
-				prwskey=pattrib->dot118021x_UncstKey.skey;
+			if (IS_MCAST(pattrib->ra))
+				prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
+			else {
+				/* prwskey=&stainfo->dot118021x_UncstKey.skey[0]; */
+				prwskey = pattrib->dot118021x_UncstKey.skey;
 			}
 
 #ifdef CONFIG_TDLS
 			{
 				/* Swencryption */
 				struct	sta_info		*ptdls_sta;
-				ptdls_sta=rtw_get_stainfo(&padapter->stapriv ,&pattrib->dst[0] );
-				if((ptdls_sta != NULL) && (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) )
-				{
-					DBG_871X("[%s] for tdls link\n", __FUNCTION__);
-					prwskey=&ptdls_sta->tpk.tk[0];
+				ptdls_sta = rtw_get_stainfo(&padapter->stapriv , &pattrib->dst[0]);
+				if ((ptdls_sta != NULL) && (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)) {
+					RTW_INFO("[%s] for tdls link\n", __FUNCTION__);
+					prwskey = &ptdls_sta->tpk.tk[0];
 				}
 			}
-#endif //CONFIG_TDLS
-
-			prwskeylen=16;
-	
-			for(curfragnum=0;curfragnum<pattrib->nr_frags;curfragnum++){
-			
-				if((curfragnum+1)==pattrib->nr_frags){	//4 the last fragment
-					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=(u8*)RND4((SIZE_PTR)(pframe));
+#endif /* CONFIG_TDLS */
+
+			prwskeylen = 16;
+
+			for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
+
+				if ((curfragnum + 1) == pattrib->nr_frags) {	/* 4 the last fragment */
+					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 = (u8 *)RND4((SIZE_PTR)(pframe));
 
 				}
 			}
 
 			AES_SW_ENC_CNT_INC(psecuritypriv, pattrib->ra);
 		}
-/*
-		else{
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_aes_encrypt: stainfo==NULL!!!\n"));
-			DBG_871X("%s, psta==NUL\n", __func__);
-			res=_FAIL;
-		}
-*/
+		/*
+				else{
+					RTW_INFO("%s, psta==NUL\n", __func__);
+					res=_FAIL;
+				}
+		*/
 	}
 
 
 
-_func_exit_;
-		return res;
+	return res;
 }
 
 static sint aes_decipher(u8 *key, uint	hdrlen,
-			u8 *pframe, uint plen)
+			 u8 *pframe, uint plen)
 {
 	static u8	message[MAX_MSG_SIZE];
 	uint	qc_exists, a4_exists, i, j, payload_remainder,
-			num_blocks, payload_index;
+		num_blocks, payload_index;
 	sint res = _SUCCESS;
 	u8 pn_vector[6];
 	u8 mic_iv[16];
@@ -1795,18 +1670,17 @@ static sint aes_decipher(u8 *key, uint	hdrlen,
 	u8 mic_header2[16];
 	u8 ctr_preload[16];
 
-    /* Intermediate Buffers */
+	/* Intermediate Buffers */
 	u8 chain_buffer[16];
 	u8 aes_out[16];
 	u8 padded_buffer[16];
 	u8 mic[8];
 
 
-//	uint	offset = 0;
+	/*	uint	offset = 0; */
 	uint	frtype  = GetFrameType(pframe);
-	uint	frsubtype  = GetFrameSubType(pframe);
-_func_enter_;			
-	frsubtype=frsubtype>>4;
+	uint	frsubtype  = get_frame_sub_type(pframe);
+	frsubtype = frsubtype >> 4;
 
 
 	_rtw_memset((void *)mic_iv, 0, 16);
@@ -1817,284 +1691,272 @@ _func_enter_;
 	_rtw_memset((void *)aes_out, 0, 16);
 	_rtw_memset((void *)padded_buffer, 0, 16);
 
-	//start to decrypt the payload
+	/* start to decrypt the payload */
 
-	num_blocks = (plen-8) / 16; //(plen including LLC, payload_length and mic )
+	num_blocks = (plen - 8) / 16; /* (plen including LLC, payload_length and mic ) */
 
-	payload_remainder = (plen-8) % 16;
+	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];
+	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 == WLAN_HDR_A3_LEN )||(hdrlen ==  WLAN_HDR_A3_QOS_LEN))
+	if ((hdrlen == WLAN_HDR_A3_LEN) || (hdrlen ==  WLAN_HDR_A3_QOS_LEN))
 		a4_exists = 0;
 	else
 		a4_exists = 1;
 
 	if (
-		((frtype|frsubtype) == WIFI_DATA_CFACK) ||
-		((frtype|frsubtype) == WIFI_DATA_CFPOLL)||
-		((frtype|frsubtype) == WIFI_DATA_CFACKPOLL))
-		{
-			qc_exists = 1;
-					if(hdrlen !=  WLAN_HDR_A3_QOS_LEN){
-				 
-					hdrlen += 2;
-			}
-		}//only for data packet . add for CONFIG_IEEE80211W, none 11w also can use
+		((frtype | frsubtype) == WIFI_DATA_CFACK) ||
+		((frtype | frsubtype) == WIFI_DATA_CFPOLL) ||
+		((frtype | frsubtype) == WIFI_DATA_CFACKPOLL)) {
+		qc_exists = 1;
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
+			hdrlen += 2;
+	} /* only for data packet . add for CONFIG_IEEE80211W, none 11w also can use */
 	else if ((frtype == WIFI_DATA) &&
-		((frsubtype == 0x08) ||
-		(frsubtype == 0x09)||
-		(frsubtype == 0x0a)||
-		(frsubtype == 0x0b)))
-		{
-			if(hdrlen !=  WLAN_HDR_A3_QOS_LEN){
-				 
-					hdrlen += 2;
-			}
-			qc_exists = 1;
-		}
-	else
+		 ((frsubtype == 0x08) ||
+		  (frsubtype == 0x09) ||
+		  (frsubtype == 0x0a) ||
+		  (frsubtype == 0x0b))) {
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
+			hdrlen += 2;
+		qc_exists = 1;
+	} 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,
-                                frtype // add for CONFIG_IEEE80211W, none 11w also can use
-                            );
-
-        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,
-                                frtype // add for CONFIG_IEEE80211W, none 11w also can use
-                            );
-
-        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)
-		_rtw_memcpy((void *)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];
-
-
-	
+	/* 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,
+			frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
+		);
+
+		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,
+			frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
+		);
+
+		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)
+		_rtw_memcpy((void *)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,
-                        frtype // add for CONFIG_IEEE80211W, none 11w also can use
-                        );
-
-    construct_mic_header1(
-                            mic_header1,
-                            hdrlen,
-                            message,
-                            frtype // add for CONFIG_IEEE80211W, none 11w also can use
-                            );
-    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,
-                                frtype); // add for CONFIG_IEEE80211W, none 11w also can use
-        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,
-                                frtype); // add for CONFIG_IEEE80211W, none 11w also can use
-
-        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,
-                        frtype); // add for CONFIG_IEEE80211W, none 11w also can use
-
-    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_,("aes_decipher:mic check error mic[%d]: pframe(%x) != message(%x) \n",
-						i,pframe[hdrlen+8+plen-8+i],message[hdrlen+8+plen-8+i]));
-			DBG_871X("aes_decipher:mic check error mic[%d]: pframe(%x) != message(%x) \n",
-						i,pframe[hdrlen+8+plen-8+i],message[hdrlen+8+plen-8+i]);
+		mic_iv,
+		qc_exists,
+		a4_exists,
+		message,
+		plen - 8,
+		pn_vector,
+		frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
+	);
+
+	construct_mic_header1(
+		mic_header1,
+		hdrlen,
+		message,
+		frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
+	);
+	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,
+			frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
+		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,
+			frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
+
+		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,
+		frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
+
+	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]) {
+			RTW_INFO("aes_decipher:mic check error mic[%d]: pframe(%x) != message(%x)\n",
+				i, pframe[hdrlen + 8 + plen - 8 + i], message[hdrlen + 8 + plen - 8 + i]);
 			res = _FAIL;
 		}
 	}
-_func_exit_;	
 	return res;
 }
 
 u32	rtw_aes_decrypt(_adapter *padapter, u8 *precvframe)
-{	// exclude ICV
+{
+	/* exclude ICV */
 
 
-	/*static*/ 
-//	unsigned char	message[MAX_MSG_SIZE];
+	/*static*/
+	/*	unsigned char	message[MAX_MSG_SIZE]; */
 
 
-    	/* Intermediate Buffers */
+	/* Intermediate Buffers */
 
 
-	sint 		length;
+	sint		length;
 	u32	prwskeylen;
-	u8	*pframe,*prwskey;	//, *payload,*iv
+	u8	*pframe, *prwskey;	/* , *payload,*iv */
 	struct	sta_info		*stainfo;
-	struct	rx_pkt_attrib	 *prxattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
-	struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
-//	struct	recv_priv		*precvpriv=&padapter->recvpriv;
-	u32	res=_SUCCESS;
-_func_enter_;	 
-	pframe=(unsigned char *)((union recv_frame*)precvframe)->u.hdr.rx_data;
-	//4 start to encrypt each fragment
-	if((prxattrib->encrypt==_AES_)){
-
-		stainfo=rtw_get_stainfo(&padapter->stapriv ,&prxattrib->ta[0] );
-		if (stainfo!=NULL){
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_aes_decrypt: stainfo!=NULL!!!\n"));
-
-			if(IS_MCAST(prxattrib->ra))
-			{
-				static u32 start = 0;
+	struct	rx_pkt_attrib	*prxattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
+	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
+	/*	struct	recv_priv		*precvpriv=&padapter->recvpriv; */
+	u32	res = _SUCCESS;
+	pframe = (unsigned char *)((union recv_frame *)precvframe)->u.hdr.rx_data;
+	/* 4 start to encrypt each fragment */
+	if ((prxattrib->encrypt == _AES_)) {
+
+		stainfo = rtw_get_stainfo(&padapter->stapriv , &prxattrib->ta[0]);
+		if (stainfo != NULL) {
+
+			if (IS_MCAST(prxattrib->ra)) {
+				static systime start = 0;
 				static u32 no_gkey_bc_cnt = 0;
 				static u32 no_gkey_mc_cnt = 0;
 
-				//DBG_871X("rx bc/mc packets, to perform sw rtw_aes_decrypt\n");
-				//prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
-				if(psecuritypriv->binstallGrpkey==_FALSE)
-				{
-					res=_FAIL;
+				/* RTW_INFO("rx bc/mc packets, to perform sw rtw_aes_decrypt\n"); */
+				/* prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey; */
+				if ((!MLME_IS_MESH(padapter) && psecuritypriv->binstallGrpkey == _FALSE)
+					#ifdef CONFIG_RTW_MESH
+					|| !(stainfo->gtk_bmp | BIT(prxattrib->key_index))
+					#endif
+				) {
+					res = _FAIL;
 
 					if (start == 0)
 						start = rtw_get_current_time();
@@ -2106,7 +1968,7 @@ _func_enter_;
 
 					if (rtw_get_passing_time_ms(start) > 1000) {
 						if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
-							DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
+							RTW_PRINT(FUNC_ADPT_FMT" no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
 								FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
 						}
 						start = rtw_get_current_time();
@@ -2118,166 +1980,164 @@ _func_enter_;
 				}
 
 				if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
-					DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" gkey installed. no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
+					RTW_PRINT(FUNC_ADPT_FMT" gkey installed. no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
 						FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
 				}
 				start = 0;
 				no_gkey_bc_cnt = 0;
 				no_gkey_mc_cnt = 0;
 
-				prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
-				if(psecuritypriv->dot118021XGrpKeyid != prxattrib->key_index)
+				#ifdef CONFIG_RTW_MESH
+				if (MLME_IS_MESH(padapter)) {
+					/* TODO: multiple GK? */
+					prwskey = &stainfo->gtk.skey[0];
+				} else
+				#endif
 				{
-					DBG_871X("not match packet_index=%d, install_index=%d \n"
-					, prxattrib->key_index, psecuritypriv->dot118021XGrpKeyid);
-					res=_FAIL;
-					goto exit;
+					prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
+					if (psecuritypriv->dot118021XGrpKeyid != prxattrib->key_index) {
+						RTW_DBG("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= ((union recv_frame *)precvframe)->u.hdr.len-prxattrib->hdrlen-prxattrib->iv_len;
-			/*// add for CONFIG_IEEE80211W, debug
-			if(0)
-			printk("@@@@@@@@@@@@@@@@@@ length=%d, prxattrib->hdrlen=%d, prxattrib->pkt_len=%d \n"
-			, length, prxattrib->hdrlen, prxattrib->pkt_len);
-			if(0)
-			{
+			} else
+				prwskey = &stainfo->dot118021x_UncstKey.skey[0];
+
+			length = ((union recv_frame *)precvframe)->u.hdr.len - prxattrib->hdrlen - prxattrib->iv_len;
+#if 0
+			/*  add for CONFIG_IEEE80211W, debug */
+			if (0)
+				printk("@@@@@@@@@@@@@@@@@@ length=%d, prxattrib->hdrlen=%d, prxattrib->pkt_len=%d\n"
+				       , length, prxattrib->hdrlen, prxattrib->pkt_len);
+			if (0) {
 				int no;
-				//test print PSK
+				/* test print PSK */
 				printk("PSK key below:\n");
-				for(no=0;no<16;no++)
+				for (no = 0; no < 16; no++)
 					printk(" %02x ", prwskey[no]);
 				printk("\n");
 			}
-			if(0)
-			{
+			if (0) {
 				int no;
-				//test print PSK
+				/* test print PSK */
 				printk("frame:\n");
-				for(no=0;no<prxattrib->pkt_len;no++)
+				for (no = 0; no < prxattrib->pkt_len; no++)
 					printk(" %02x ", pframe[no]);
 				printk("\n");
-			}*/
+			}
+#endif
 
-			res= aes_decipher(prwskey,prxattrib->hdrlen,pframe, length);
+			res = aes_decipher(prwskey, prxattrib->hdrlen, pframe, length);
 
 			AES_SW_DEC_CNT_INC(psecuritypriv, prxattrib->ra);
+		} else {
+			res = _FAIL;
 		}
-		else{
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("rtw_aes_decrypt: stainfo==NULL!!!\n"));
-			res=_FAIL;
-		}
-						
+
 	}
-_func_exit_;	
 exit:
 	return res;
 }
 
 #ifdef CONFIG_IEEE80211W
-u32	rtw_BIP_verify(_adapter *padapter, u8 *precvframe)
+u32	rtw_BIP_verify(_adapter *padapter, u8 *whdr_pos, sint flen
+	, const u8 *key, u16 keyid, u64* ipn)
 {
-	struct rx_pkt_attrib *pattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
-	u8 *pframe;
-	u8 *BIP_AAD, *p;
-	u32	res=_FAIL;
+	u8 *BIP_AAD, *mme;
+	u32	res = _FAIL;
 	uint len, ori_len;
+	u16 pkt_keyid = 0;
+	u64 pkt_ipn = 0;
 	struct rtw_ieee80211_hdr *pwlanhdr;
 	u8 mic[16];
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	ori_len = pattrib->pkt_len-WLAN_HDR_A3_LEN+BIP_AAD_SIZE;
+
+	mme = whdr_pos + flen - 18;
+	if (*mme != _MME_IE_)
+		return RTW_RX_HANDLED;
+
+	/* copy key index */
+	_rtw_memcpy(&pkt_keyid, mme + 2, 2);
+	pkt_keyid = le16_to_cpu(pkt_keyid);
+	if (pkt_keyid != keyid) {
+		RTW_INFO("BIP key index error!\n");
+		return _FAIL;
+	}
+
+	/* save packet number */
+	_rtw_memcpy(&pkt_ipn, mme + 4, 6);
+	pkt_ipn = le64_to_cpu(pkt_ipn);
+	/* BIP packet number should bigger than previous BIP packet */
+	if (pkt_ipn <= *ipn) { /* wrap around? */
+		RTW_INFO("replay BIP packet\n");
+		return _FAIL;
+	}
+
+	ori_len = flen - WLAN_HDR_A3_LEN + BIP_AAD_SIZE;
 	BIP_AAD = rtw_zmalloc(ori_len);
-	
-	if(BIP_AAD == NULL)
-	{
-		DBG_871X("BIP AAD allocate fail\n");
+	if (BIP_AAD == NULL) {
+		RTW_INFO("BIP AAD allocate fail\n");
 		return _FAIL;
 	}
-	//PKT start
-	pframe=(unsigned char *)((union recv_frame*)precvframe)->u.hdr.rx_data;
-	//mapping to wlan header
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-	//save the frame body + MME
-	_rtw_memcpy(BIP_AAD+BIP_AAD_SIZE, pframe+WLAN_HDR_A3_LEN, pattrib->pkt_len-WLAN_HDR_A3_LEN);
-	//find MME IE pointer
-	p = rtw_get_ie(BIP_AAD+BIP_AAD_SIZE, _MME_IE_, &len, pattrib->pkt_len-WLAN_HDR_A3_LEN);
-	//Baron
-	if(p)
+
+	/* mapping to wlan header */
+	pwlanhdr = (struct rtw_ieee80211_hdr *)whdr_pos;
+
+	/* save the frame body + MME */
+	_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, whdr_pos + WLAN_HDR_A3_LEN, flen - WLAN_HDR_A3_LEN);
+
+	/* point mme to the copy */
+	mme = BIP_AAD + ori_len - 18;
+
+	/* clear the MIC field of MME to zero */
+	_rtw_memset(mme + 10, 0, 8);
+
+	/* conscruct AAD, copy frame control field */
+	_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
+	ClearRetry(BIP_AAD);
+	ClearPwrMgt(BIP_AAD);
+	ClearMData(BIP_AAD);
+	/* conscruct AAD, copy address 1 to address 3 */
+	_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
+
+	if (omac1_aes_128(key, BIP_AAD, ori_len, mic))
+		goto BIP_exit;
+
+#if 0
+	/* management packet content */
 	{
-		u16 keyid=0;
-		u64 temp_ipn=0;
-		//save packet number
-		_rtw_memcpy(&temp_ipn, p+4, 6);
-		temp_ipn = le64_to_cpu(temp_ipn);
-		//BIP packet number should bigger than previous BIP packet
-		if (temp_ipn < pmlmeext->mgnt_80211w_IPN_rx) {
-			DBG_871X("replay BIP packet\n");
-			goto BIP_exit;
-		}
-		//copy key index
-		_rtw_memcpy(&keyid, p+2, 2);
-		keyid = le16_to_cpu(keyid);
-		if(keyid != padapter->securitypriv.dot11wBIPKeyid)
-		{
-			DBG_871X("BIP key index error!\n");
-			goto BIP_exit;
-		}
-		//clear the MIC field of MME to zero
-		_rtw_memset(p+2+len-8, 0, 8);
-		
-		//conscruct AAD, copy frame control field
-		_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
-		ClearRetry(BIP_AAD);
-		ClearPwrMgt(BIP_AAD);
-		ClearMData(BIP_AAD);
-		//conscruct AAD, copy address 1 to address 3
-		_rtw_memcpy(BIP_AAD+2, pwlanhdr->addr1, 18);
-		
-		if(omac1_aes_128(padapter->securitypriv.dot11wBIPKey[padapter->securitypriv.dot11wBIPKeyid].skey
-			, BIP_AAD, ori_len, mic))
-			goto BIP_exit;
-		
-		/*//management packet content
-		{
-			int pp;
-			DBG_871X("pkt: ");
-			for(pp=0;pp< pattrib->pkt_len; pp++)
-				printk(" %02x ", pframe[pp]);
-			DBG_871X("\n");
-			//BIP AAD + management frame body + MME(MIC is zero)
-			DBG_871X("AAD+PKT: ");
-			for(pp=0;pp< ori_len; pp++)
-				DBG_871X(" %02x ", BIP_AAD[pp]);
-			DBG_871X("\n");
-			//show the MIC result
-			DBG_871X("mic: ");
-			for(pp=0;pp<16; pp++)
-				DBG_871X(" %02x ", mic[pp]);
-			DBG_871X("\n");
-		}
-		*/
-		//MIC field should be last 8 bytes of packet (packet without FCS)
-		if(_rtw_memcmp(mic, pframe+pattrib->pkt_len-8, 8))
-		{
-			pmlmeext->mgnt_80211w_IPN_rx = temp_ipn;
-			res=_SUCCESS;
-		}
-		else
-			DBG_871X("BIP MIC error!\n");
-		
+		int pp;
+		RTW_INFO("pkt: ");
+		for (pp = 0; pp < flen; pp++)
+			printk(" %02x ", whdr_pos[pp]);
+		RTW_INFO("\n");
+		/* BIP AAD + management frame body + MME(MIC is zero) */
+		RTW_INFO("AAD+PKT: ");
+		for (pp = 0; pp < ori_len; pp++)
+			RTW_INFO(" %02x ", BIP_AAD[pp]);
+		RTW_INFO("\n");
+		/* show the MIC result */
+		RTW_INFO("mic: ");
+		for (pp = 0; pp < 16; pp++)
+			RTW_INFO(" %02x ", mic[pp]);
+		RTW_INFO("\n");
 	}
-	else
-		res = RTW_RX_HANDLED;
+#endif
+
+	/* MIC field should be last 8 bytes of packet (packet without FCS) */
+	if (_rtw_memcmp(mic, whdr_pos + flen - 8, 8)) {
+		*ipn = pkt_ipn;
+		res = _SUCCESS;
+	} else
+		RTW_INFO("BIP MIC error!\n");
+
 BIP_exit:
 
 	rtw_mfree(BIP_AAD, ori_len);
 	return res;
 }
-#endif //CONFIG_IEEE80211W
+#endif /* CONFIG_IEEE80211W */
 
 #ifndef PLATFORM_FREEBSD
 /* compress 512-bits */
@@ -2288,9 +2148,8 @@ static int sha256_compress(struct sha256_state *md, unsigned char *buf)
 	int i;
 
 	/* copy state into S */
-	for (i = 0; i < 8; i++) {
+	for (i = 0; i < 8; i++)
 		S[i] = md->state[i];
-	}
 
 	/* copy the state into 512-bits into W[0..15] */
 	for (i = 0; i < 16; i++)
@@ -2299,26 +2158,33 @@ static int sha256_compress(struct sha256_state *md, unsigned char *buf)
 	/* fill W[16..63] */
 	for (i = 16; i < 64; i++) {
 		W[i] = Gamma1(W[i - 2]) + W[i - 7] + Gamma0(W[i - 15]) +
-			W[i - 16];
-	}        
+		       W[i - 16];
+	}
 
 	/* Compress */
-#define RND(a,b,c,d,e,f,g,h,i)                          \
+#define RND(a, b, c, d, e, f, g, h, i)                          do {\
 	t0 = h + Sigma1(e) + Ch(e, f, g) + K[i] + W[i];	\
 	t1 = Sigma0(a) + Maj(a, b, c);			\
 	d += t0;					\
-	h  = t0 + t1;
+	h  = t0 + t1;	\
+	} while (0)
 
 	for (i = 0; i < 64; ++i) {
 		RND(S[0], S[1], S[2], S[3], S[4], S[5], S[6], S[7], i);
-		t = S[7]; S[7] = S[6]; S[6] = S[5]; S[5] = S[4]; 
-		S[4] = S[3]; S[3] = S[2]; S[2] = S[1]; S[1] = S[0]; S[0] = t;
+		t = S[7];
+		S[7] = S[6];
+		S[6] = S[5];
+		S[5] = S[4];
+		S[4] = S[3];
+		S[3] = S[2];
+		S[2] = S[1];
+		S[1] = S[0];
+		S[0] = t;
 	}
 
 	/* feedback */
-	for (i = 0; i < 8; i++) {
+	for (i = 0; i < 8; i++)
 		md->state[i] = md->state[i] + S[i];
-	}
 	return 0;
 }
 
@@ -2350,7 +2216,7 @@ static int sha256_process(struct sha256_state *md, unsigned char *in,
 	unsigned long n;
 #define block_size 64
 
-	if (md->curlen > sizeof(md->buf))
+	if (md->curlen >= sizeof(md->buf))
 		return -1;
 
 	while (inlen > 0) {
@@ -2403,17 +2269,15 @@ static int sha256_done(struct sha256_state *md, unsigned char *out)
 	 * encoding like normal.
 	 */
 	if (md->curlen > 56) {
-		while (md->curlen < 64) {
+		while (md->curlen < 64)
 			md->buf[md->curlen++] = (unsigned char) 0;
-		}
 		sha256_compress(md, md->buf);
 		md->curlen = 0;
 	}
 
 	/* pad upto 56 bytes of zeroes */
-	while (md->curlen < 56) {
+	while (md->curlen < 56)
 		md->buf[md->curlen++] = (unsigned char) 0;
-	}
 
 	/* store length */
 	WPA_PUT_BE64(md->buf + 56, md->length);
@@ -2435,7 +2299,7 @@ static int sha256_done(struct sha256_state *md, unsigned char *out)
  * Returns: 0 on success, -1 of failure
  */
 static int sha256_vector(size_t num_elem, u8 *addr[], size_t *len,
-		  u8 *mac)
+			 u8 *mac)
 {
 	struct sha256_state ctx;
 	size_t i;
@@ -2457,9 +2321,9 @@ static u8 os_strlen(const char *s)
 	return p - s;
 }
 
-static int os_memcmp(void *s1, void *s2, u8 n)
+static int os_memcmp(const void *s1, const void *s2, u8 n)
 {
-	unsigned char *p1 = s1, *p2 = s2;
+	const unsigned char *p1 = s1, *p2 = s2;
 
 	if (n == 0)
 		return 0;
@@ -2485,7 +2349,7 @@ static int os_memcmp(void *s1, void *s2, u8 n)
  * @mac: Buffer for the hash (32 bytes)
  */
 static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
-			u8 *addr[], size_t *len, u8 *mac)
+			       u8 *addr[], size_t *len, u8 *mac)
 {
 	unsigned char k_pad[64]; /* padding - key XORd with ipad/opad */
 	unsigned char tk[32];
@@ -2500,12 +2364,12 @@ static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
 		return;
 	}
 
-        /* if key is longer than 64 bytes reset it to key = SHA256(key) */
-        if (key_len > 64) {
+	/* if key is longer than 64 bytes reset it to key = SHA256(key) */
+	if (key_len > 64) {
 		sha256_vector(1, &key, &key_len, tk);
 		key = tk;
 		key_len = 32;
-        }
+	}
 
 	/* the HMAC_SHA256 transform looks like:
 	 *
@@ -2545,7 +2409,7 @@ static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
 	_len[1] = 32;
 	sha256_vector(2, _addr, _len, mac);
 }
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 /**
  * sha256_prf - SHA256-based Pseudo-Random Function (IEEE 802.11r, 8.5.1.5.2)
  * @key: Key for PRF
@@ -2559,9 +2423,9 @@ static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
  * This function is used to derive new, cryptographically separate keys from a
  * given key.
  */
-#ifndef PLATFORM_FREEBSD //Baron
+#ifndef PLATFORM_FREEBSD /* Baron */
 static void sha256_prf(u8 *key, size_t key_len, char *label,
-		u8 *data, size_t data_len, u8 *buf, size_t buf_len)
+		       u8 *data, size_t data_len, u8 *buf, size_t buf_len)
 {
 	u16 counter = 1;
 	size_t pos, plen;
@@ -2596,174 +2460,174 @@ static void sha256_prf(u8 *key, size_t key_len, char *label,
 		counter++;
 	}
 }
-#endif //PLATFORM_FREEBSD Baron
+#endif /* PLATFORM_FREEBSD Baron */
 
 /* AES tables*/
 const u32 Te0[256] = {
-    0xc66363a5U, 0xf87c7c84U, 0xee777799U, 0xf67b7b8dU,
-    0xfff2f20dU, 0xd66b6bbdU, 0xde6f6fb1U, 0x91c5c554U,
-    0x60303050U, 0x02010103U, 0xce6767a9U, 0x562b2b7dU,
-    0xe7fefe19U, 0xb5d7d762U, 0x4dababe6U, 0xec76769aU,
-    0x8fcaca45U, 0x1f82829dU, 0x89c9c940U, 0xfa7d7d87U,
-    0xeffafa15U, 0xb25959ebU, 0x8e4747c9U, 0xfbf0f00bU,
-    0x41adadecU, 0xb3d4d467U, 0x5fa2a2fdU, 0x45afafeaU,
-    0x239c9cbfU, 0x53a4a4f7U, 0xe4727296U, 0x9bc0c05bU,
-    0x75b7b7c2U, 0xe1fdfd1cU, 0x3d9393aeU, 0x4c26266aU,
-    0x6c36365aU, 0x7e3f3f41U, 0xf5f7f702U, 0x83cccc4fU,
-    0x6834345cU, 0x51a5a5f4U, 0xd1e5e534U, 0xf9f1f108U,
-    0xe2717193U, 0xabd8d873U, 0x62313153U, 0x2a15153fU,
-    0x0804040cU, 0x95c7c752U, 0x46232365U, 0x9dc3c35eU,
-    0x30181828U, 0x379696a1U, 0x0a05050fU, 0x2f9a9ab5U,
-    0x0e070709U, 0x24121236U, 0x1b80809bU, 0xdfe2e23dU,
-    0xcdebeb26U, 0x4e272769U, 0x7fb2b2cdU, 0xea75759fU,
-    0x1209091bU, 0x1d83839eU, 0x582c2c74U, 0x341a1a2eU,
-    0x361b1b2dU, 0xdc6e6eb2U, 0xb45a5aeeU, 0x5ba0a0fbU,
-    0xa45252f6U, 0x763b3b4dU, 0xb7d6d661U, 0x7db3b3ceU,
-    0x5229297bU, 0xdde3e33eU, 0x5e2f2f71U, 0x13848497U,
-    0xa65353f5U, 0xb9d1d168U, 0x00000000U, 0xc1eded2cU,
-    0x40202060U, 0xe3fcfc1fU, 0x79b1b1c8U, 0xb65b5bedU,
-    0xd46a6abeU, 0x8dcbcb46U, 0x67bebed9U, 0x7239394bU,
-    0x944a4adeU, 0x984c4cd4U, 0xb05858e8U, 0x85cfcf4aU,
-    0xbbd0d06bU, 0xc5efef2aU, 0x4faaaae5U, 0xedfbfb16U,
-    0x864343c5U, 0x9a4d4dd7U, 0x66333355U, 0x11858594U,
-    0x8a4545cfU, 0xe9f9f910U, 0x04020206U, 0xfe7f7f81U,
-    0xa05050f0U, 0x783c3c44U, 0x259f9fbaU, 0x4ba8a8e3U,
-    0xa25151f3U, 0x5da3a3feU, 0x804040c0U, 0x058f8f8aU,
-    0x3f9292adU, 0x219d9dbcU, 0x70383848U, 0xf1f5f504U,
-    0x63bcbcdfU, 0x77b6b6c1U, 0xafdada75U, 0x42212163U,
-    0x20101030U, 0xe5ffff1aU, 0xfdf3f30eU, 0xbfd2d26dU,
-    0x81cdcd4cU, 0x180c0c14U, 0x26131335U, 0xc3ecec2fU,
-    0xbe5f5fe1U, 0x359797a2U, 0x884444ccU, 0x2e171739U,
-    0x93c4c457U, 0x55a7a7f2U, 0xfc7e7e82U, 0x7a3d3d47U,
-    0xc86464acU, 0xba5d5de7U, 0x3219192bU, 0xe6737395U,
-    0xc06060a0U, 0x19818198U, 0x9e4f4fd1U, 0xa3dcdc7fU,
-    0x44222266U, 0x542a2a7eU, 0x3b9090abU, 0x0b888883U,
-    0x8c4646caU, 0xc7eeee29U, 0x6bb8b8d3U, 0x2814143cU,
-    0xa7dede79U, 0xbc5e5ee2U, 0x160b0b1dU, 0xaddbdb76U,
-    0xdbe0e03bU, 0x64323256U, 0x743a3a4eU, 0x140a0a1eU,
-    0x924949dbU, 0x0c06060aU, 0x4824246cU, 0xb85c5ce4U,
-    0x9fc2c25dU, 0xbdd3d36eU, 0x43acacefU, 0xc46262a6U,
-    0x399191a8U, 0x319595a4U, 0xd3e4e437U, 0xf279798bU,
-    0xd5e7e732U, 0x8bc8c843U, 0x6e373759U, 0xda6d6db7U,
-    0x018d8d8cU, 0xb1d5d564U, 0x9c4e4ed2U, 0x49a9a9e0U,
-    0xd86c6cb4U, 0xac5656faU, 0xf3f4f407U, 0xcfeaea25U,
-    0xca6565afU, 0xf47a7a8eU, 0x47aeaee9U, 0x10080818U,
-    0x6fbabad5U, 0xf0787888U, 0x4a25256fU, 0x5c2e2e72U,
-    0x381c1c24U, 0x57a6a6f1U, 0x73b4b4c7U, 0x97c6c651U,
-    0xcbe8e823U, 0xa1dddd7cU, 0xe874749cU, 0x3e1f1f21U,
-    0x964b4bddU, 0x61bdbddcU, 0x0d8b8b86U, 0x0f8a8a85U,
-    0xe0707090U, 0x7c3e3e42U, 0x71b5b5c4U, 0xcc6666aaU,
-    0x904848d8U, 0x06030305U, 0xf7f6f601U, 0x1c0e0e12U,
-    0xc26161a3U, 0x6a35355fU, 0xae5757f9U, 0x69b9b9d0U,
-    0x17868691U, 0x99c1c158U, 0x3a1d1d27U, 0x279e9eb9U,
-    0xd9e1e138U, 0xebf8f813U, 0x2b9898b3U, 0x22111133U,
-    0xd26969bbU, 0xa9d9d970U, 0x078e8e89U, 0x339494a7U,
-    0x2d9b9bb6U, 0x3c1e1e22U, 0x15878792U, 0xc9e9e920U,
-    0x87cece49U, 0xaa5555ffU, 0x50282878U, 0xa5dfdf7aU,
-    0x038c8c8fU, 0x59a1a1f8U, 0x09898980U, 0x1a0d0d17U,
-    0x65bfbfdaU, 0xd7e6e631U, 0x844242c6U, 0xd06868b8U,
-    0x824141c3U, 0x299999b0U, 0x5a2d2d77U, 0x1e0f0f11U,
-    0x7bb0b0cbU, 0xa85454fcU, 0x6dbbbbd6U, 0x2c16163aU,
+	0xc66363a5U, 0xf87c7c84U, 0xee777799U, 0xf67b7b8dU,
+	0xfff2f20dU, 0xd66b6bbdU, 0xde6f6fb1U, 0x91c5c554U,
+	0x60303050U, 0x02010103U, 0xce6767a9U, 0x562b2b7dU,
+	0xe7fefe19U, 0xb5d7d762U, 0x4dababe6U, 0xec76769aU,
+	0x8fcaca45U, 0x1f82829dU, 0x89c9c940U, 0xfa7d7d87U,
+	0xeffafa15U, 0xb25959ebU, 0x8e4747c9U, 0xfbf0f00bU,
+	0x41adadecU, 0xb3d4d467U, 0x5fa2a2fdU, 0x45afafeaU,
+	0x239c9cbfU, 0x53a4a4f7U, 0xe4727296U, 0x9bc0c05bU,
+	0x75b7b7c2U, 0xe1fdfd1cU, 0x3d9393aeU, 0x4c26266aU,
+	0x6c36365aU, 0x7e3f3f41U, 0xf5f7f702U, 0x83cccc4fU,
+	0x6834345cU, 0x51a5a5f4U, 0xd1e5e534U, 0xf9f1f108U,
+	0xe2717193U, 0xabd8d873U, 0x62313153U, 0x2a15153fU,
+	0x0804040cU, 0x95c7c752U, 0x46232365U, 0x9dc3c35eU,
+	0x30181828U, 0x379696a1U, 0x0a05050fU, 0x2f9a9ab5U,
+	0x0e070709U, 0x24121236U, 0x1b80809bU, 0xdfe2e23dU,
+	0xcdebeb26U, 0x4e272769U, 0x7fb2b2cdU, 0xea75759fU,
+	0x1209091bU, 0x1d83839eU, 0x582c2c74U, 0x341a1a2eU,
+	0x361b1b2dU, 0xdc6e6eb2U, 0xb45a5aeeU, 0x5ba0a0fbU,
+	0xa45252f6U, 0x763b3b4dU, 0xb7d6d661U, 0x7db3b3ceU,
+	0x5229297bU, 0xdde3e33eU, 0x5e2f2f71U, 0x13848497U,
+	0xa65353f5U, 0xb9d1d168U, 0x00000000U, 0xc1eded2cU,
+	0x40202060U, 0xe3fcfc1fU, 0x79b1b1c8U, 0xb65b5bedU,
+	0xd46a6abeU, 0x8dcbcb46U, 0x67bebed9U, 0x7239394bU,
+	0x944a4adeU, 0x984c4cd4U, 0xb05858e8U, 0x85cfcf4aU,
+	0xbbd0d06bU, 0xc5efef2aU, 0x4faaaae5U, 0xedfbfb16U,
+	0x864343c5U, 0x9a4d4dd7U, 0x66333355U, 0x11858594U,
+	0x8a4545cfU, 0xe9f9f910U, 0x04020206U, 0xfe7f7f81U,
+	0xa05050f0U, 0x783c3c44U, 0x259f9fbaU, 0x4ba8a8e3U,
+	0xa25151f3U, 0x5da3a3feU, 0x804040c0U, 0x058f8f8aU,
+	0x3f9292adU, 0x219d9dbcU, 0x70383848U, 0xf1f5f504U,
+	0x63bcbcdfU, 0x77b6b6c1U, 0xafdada75U, 0x42212163U,
+	0x20101030U, 0xe5ffff1aU, 0xfdf3f30eU, 0xbfd2d26dU,
+	0x81cdcd4cU, 0x180c0c14U, 0x26131335U, 0xc3ecec2fU,
+	0xbe5f5fe1U, 0x359797a2U, 0x884444ccU, 0x2e171739U,
+	0x93c4c457U, 0x55a7a7f2U, 0xfc7e7e82U, 0x7a3d3d47U,
+	0xc86464acU, 0xba5d5de7U, 0x3219192bU, 0xe6737395U,
+	0xc06060a0U, 0x19818198U, 0x9e4f4fd1U, 0xa3dcdc7fU,
+	0x44222266U, 0x542a2a7eU, 0x3b9090abU, 0x0b888883U,
+	0x8c4646caU, 0xc7eeee29U, 0x6bb8b8d3U, 0x2814143cU,
+	0xa7dede79U, 0xbc5e5ee2U, 0x160b0b1dU, 0xaddbdb76U,
+	0xdbe0e03bU, 0x64323256U, 0x743a3a4eU, 0x140a0a1eU,
+	0x924949dbU, 0x0c06060aU, 0x4824246cU, 0xb85c5ce4U,
+	0x9fc2c25dU, 0xbdd3d36eU, 0x43acacefU, 0xc46262a6U,
+	0x399191a8U, 0x319595a4U, 0xd3e4e437U, 0xf279798bU,
+	0xd5e7e732U, 0x8bc8c843U, 0x6e373759U, 0xda6d6db7U,
+	0x018d8d8cU, 0xb1d5d564U, 0x9c4e4ed2U, 0x49a9a9e0U,
+	0xd86c6cb4U, 0xac5656faU, 0xf3f4f407U, 0xcfeaea25U,
+	0xca6565afU, 0xf47a7a8eU, 0x47aeaee9U, 0x10080818U,
+	0x6fbabad5U, 0xf0787888U, 0x4a25256fU, 0x5c2e2e72U,
+	0x381c1c24U, 0x57a6a6f1U, 0x73b4b4c7U, 0x97c6c651U,
+	0xcbe8e823U, 0xa1dddd7cU, 0xe874749cU, 0x3e1f1f21U,
+	0x964b4bddU, 0x61bdbddcU, 0x0d8b8b86U, 0x0f8a8a85U,
+	0xe0707090U, 0x7c3e3e42U, 0x71b5b5c4U, 0xcc6666aaU,
+	0x904848d8U, 0x06030305U, 0xf7f6f601U, 0x1c0e0e12U,
+	0xc26161a3U, 0x6a35355fU, 0xae5757f9U, 0x69b9b9d0U,
+	0x17868691U, 0x99c1c158U, 0x3a1d1d27U, 0x279e9eb9U,
+	0xd9e1e138U, 0xebf8f813U, 0x2b9898b3U, 0x22111133U,
+	0xd26969bbU, 0xa9d9d970U, 0x078e8e89U, 0x339494a7U,
+	0x2d9b9bb6U, 0x3c1e1e22U, 0x15878792U, 0xc9e9e920U,
+	0x87cece49U, 0xaa5555ffU, 0x50282878U, 0xa5dfdf7aU,
+	0x038c8c8fU, 0x59a1a1f8U, 0x09898980U, 0x1a0d0d17U,
+	0x65bfbfdaU, 0xd7e6e631U, 0x844242c6U, 0xd06868b8U,
+	0x824141c3U, 0x299999b0U, 0x5a2d2d77U, 0x1e0f0f11U,
+	0x7bb0b0cbU, 0xa85454fcU, 0x6dbbbbd6U, 0x2c16163aU,
 };
 const u32 Td0[256] = {
-    0x51f4a750U, 0x7e416553U, 0x1a17a4c3U, 0x3a275e96U,
-    0x3bab6bcbU, 0x1f9d45f1U, 0xacfa58abU, 0x4be30393U,
-    0x2030fa55U, 0xad766df6U, 0x88cc7691U, 0xf5024c25U,
-    0x4fe5d7fcU, 0xc52acbd7U, 0x26354480U, 0xb562a38fU,
-    0xdeb15a49U, 0x25ba1b67U, 0x45ea0e98U, 0x5dfec0e1U,
-    0xc32f7502U, 0x814cf012U, 0x8d4697a3U, 0x6bd3f9c6U,
-    0x038f5fe7U, 0x15929c95U, 0xbf6d7aebU, 0x955259daU,
-    0xd4be832dU, 0x587421d3U, 0x49e06929U, 0x8ec9c844U,
-    0x75c2896aU, 0xf48e7978U, 0x99583e6bU, 0x27b971ddU,
-    0xbee14fb6U, 0xf088ad17U, 0xc920ac66U, 0x7dce3ab4U,
-    0x63df4a18U, 0xe51a3182U, 0x97513360U, 0x62537f45U,
-    0xb16477e0U, 0xbb6bae84U, 0xfe81a01cU, 0xf9082b94U,
-    0x70486858U, 0x8f45fd19U, 0x94de6c87U, 0x527bf8b7U,
-    0xab73d323U, 0x724b02e2U, 0xe31f8f57U, 0x6655ab2aU,
-    0xb2eb2807U, 0x2fb5c203U, 0x86c57b9aU, 0xd33708a5U,
-    0x302887f2U, 0x23bfa5b2U, 0x02036abaU, 0xed16825cU,
-    0x8acf1c2bU, 0xa779b492U, 0xf307f2f0U, 0x4e69e2a1U,
-    0x65daf4cdU, 0x0605bed5U, 0xd134621fU, 0xc4a6fe8aU,
-    0x342e539dU, 0xa2f355a0U, 0x058ae132U, 0xa4f6eb75U,
-    0x0b83ec39U, 0x4060efaaU, 0x5e719f06U, 0xbd6e1051U,
-    0x3e218af9U, 0x96dd063dU, 0xdd3e05aeU, 0x4de6bd46U,
-    0x91548db5U, 0x71c45d05U, 0x0406d46fU, 0x605015ffU,
-    0x1998fb24U, 0xd6bde997U, 0x894043ccU, 0x67d99e77U,
-    0xb0e842bdU, 0x07898b88U, 0xe7195b38U, 0x79c8eedbU,
-    0xa17c0a47U, 0x7c420fe9U, 0xf8841ec9U, 0x00000000U,
-    0x09808683U, 0x322bed48U, 0x1e1170acU, 0x6c5a724eU,
-    0xfd0efffbU, 0x0f853856U, 0x3daed51eU, 0x362d3927U,
-    0x0a0fd964U, 0x685ca621U, 0x9b5b54d1U, 0x24362e3aU,
-    0x0c0a67b1U, 0x9357e70fU, 0xb4ee96d2U, 0x1b9b919eU,
-    0x80c0c54fU, 0x61dc20a2U, 0x5a774b69U, 0x1c121a16U,
-    0xe293ba0aU, 0xc0a02ae5U, 0x3c22e043U, 0x121b171dU,
-    0x0e090d0bU, 0xf28bc7adU, 0x2db6a8b9U, 0x141ea9c8U,
-    0x57f11985U, 0xaf75074cU, 0xee99ddbbU, 0xa37f60fdU,
-    0xf701269fU, 0x5c72f5bcU, 0x44663bc5U, 0x5bfb7e34U,
-    0x8b432976U, 0xcb23c6dcU, 0xb6edfc68U, 0xb8e4f163U,
-    0xd731dccaU, 0x42638510U, 0x13972240U, 0x84c61120U,
-    0x854a247dU, 0xd2bb3df8U, 0xaef93211U, 0xc729a16dU,
-    0x1d9e2f4bU, 0xdcb230f3U, 0x0d8652ecU, 0x77c1e3d0U,
-    0x2bb3166cU, 0xa970b999U, 0x119448faU, 0x47e96422U,
-    0xa8fc8cc4U, 0xa0f03f1aU, 0x567d2cd8U, 0x223390efU,
-    0x87494ec7U, 0xd938d1c1U, 0x8ccaa2feU, 0x98d40b36U,
-    0xa6f581cfU, 0xa57ade28U, 0xdab78e26U, 0x3fadbfa4U,
-    0x2c3a9de4U, 0x5078920dU, 0x6a5fcc9bU, 0x547e4662U,
-    0xf68d13c2U, 0x90d8b8e8U, 0x2e39f75eU, 0x82c3aff5U,
-    0x9f5d80beU, 0x69d0937cU, 0x6fd52da9U, 0xcf2512b3U,
-    0xc8ac993bU, 0x10187da7U, 0xe89c636eU, 0xdb3bbb7bU,
-    0xcd267809U, 0x6e5918f4U, 0xec9ab701U, 0x834f9aa8U,
-    0xe6956e65U, 0xaaffe67eU, 0x21bccf08U, 0xef15e8e6U,
-    0xbae79bd9U, 0x4a6f36ceU, 0xea9f09d4U, 0x29b07cd6U,
-    0x31a4b2afU, 0x2a3f2331U, 0xc6a59430U, 0x35a266c0U,
-    0x744ebc37U, 0xfc82caa6U, 0xe090d0b0U, 0x33a7d815U,
-    0xf104984aU, 0x41ecdaf7U, 0x7fcd500eU, 0x1791f62fU,
-    0x764dd68dU, 0x43efb04dU, 0xccaa4d54U, 0xe49604dfU,
-    0x9ed1b5e3U, 0x4c6a881bU, 0xc12c1fb8U, 0x4665517fU,
-    0x9d5eea04U, 0x018c355dU, 0xfa877473U, 0xfb0b412eU,
-    0xb3671d5aU, 0x92dbd252U, 0xe9105633U, 0x6dd64713U,
-    0x9ad7618cU, 0x37a10c7aU, 0x59f8148eU, 0xeb133c89U,
-    0xcea927eeU, 0xb761c935U, 0xe11ce5edU, 0x7a47b13cU,
-    0x9cd2df59U, 0x55f2733fU, 0x1814ce79U, 0x73c737bfU,
-    0x53f7cdeaU, 0x5ffdaa5bU, 0xdf3d6f14U, 0x7844db86U,
-    0xcaaff381U, 0xb968c43eU, 0x3824342cU, 0xc2a3405fU,
-    0x161dc372U, 0xbce2250cU, 0x283c498bU, 0xff0d9541U,
-    0x39a80171U, 0x080cb3deU, 0xd8b4e49cU, 0x6456c190U,
-    0x7bcb8461U, 0xd532b670U, 0x486c5c74U, 0xd0b85742U,
+	0x51f4a750U, 0x7e416553U, 0x1a17a4c3U, 0x3a275e96U,
+	0x3bab6bcbU, 0x1f9d45f1U, 0xacfa58abU, 0x4be30393U,
+	0x2030fa55U, 0xad766df6U, 0x88cc7691U, 0xf5024c25U,
+	0x4fe5d7fcU, 0xc52acbd7U, 0x26354480U, 0xb562a38fU,
+	0xdeb15a49U, 0x25ba1b67U, 0x45ea0e98U, 0x5dfec0e1U,
+	0xc32f7502U, 0x814cf012U, 0x8d4697a3U, 0x6bd3f9c6U,
+	0x038f5fe7U, 0x15929c95U, 0xbf6d7aebU, 0x955259daU,
+	0xd4be832dU, 0x587421d3U, 0x49e06929U, 0x8ec9c844U,
+	0x75c2896aU, 0xf48e7978U, 0x99583e6bU, 0x27b971ddU,
+	0xbee14fb6U, 0xf088ad17U, 0xc920ac66U, 0x7dce3ab4U,
+	0x63df4a18U, 0xe51a3182U, 0x97513360U, 0x62537f45U,
+	0xb16477e0U, 0xbb6bae84U, 0xfe81a01cU, 0xf9082b94U,
+	0x70486858U, 0x8f45fd19U, 0x94de6c87U, 0x527bf8b7U,
+	0xab73d323U, 0x724b02e2U, 0xe31f8f57U, 0x6655ab2aU,
+	0xb2eb2807U, 0x2fb5c203U, 0x86c57b9aU, 0xd33708a5U,
+	0x302887f2U, 0x23bfa5b2U, 0x02036abaU, 0xed16825cU,
+	0x8acf1c2bU, 0xa779b492U, 0xf307f2f0U, 0x4e69e2a1U,
+	0x65daf4cdU, 0x0605bed5U, 0xd134621fU, 0xc4a6fe8aU,
+	0x342e539dU, 0xa2f355a0U, 0x058ae132U, 0xa4f6eb75U,
+	0x0b83ec39U, 0x4060efaaU, 0x5e719f06U, 0xbd6e1051U,
+	0x3e218af9U, 0x96dd063dU, 0xdd3e05aeU, 0x4de6bd46U,
+	0x91548db5U, 0x71c45d05U, 0x0406d46fU, 0x605015ffU,
+	0x1998fb24U, 0xd6bde997U, 0x894043ccU, 0x67d99e77U,
+	0xb0e842bdU, 0x07898b88U, 0xe7195b38U, 0x79c8eedbU,
+	0xa17c0a47U, 0x7c420fe9U, 0xf8841ec9U, 0x00000000U,
+	0x09808683U, 0x322bed48U, 0x1e1170acU, 0x6c5a724eU,
+	0xfd0efffbU, 0x0f853856U, 0x3daed51eU, 0x362d3927U,
+	0x0a0fd964U, 0x685ca621U, 0x9b5b54d1U, 0x24362e3aU,
+	0x0c0a67b1U, 0x9357e70fU, 0xb4ee96d2U, 0x1b9b919eU,
+	0x80c0c54fU, 0x61dc20a2U, 0x5a774b69U, 0x1c121a16U,
+	0xe293ba0aU, 0xc0a02ae5U, 0x3c22e043U, 0x121b171dU,
+	0x0e090d0bU, 0xf28bc7adU, 0x2db6a8b9U, 0x141ea9c8U,
+	0x57f11985U, 0xaf75074cU, 0xee99ddbbU, 0xa37f60fdU,
+	0xf701269fU, 0x5c72f5bcU, 0x44663bc5U, 0x5bfb7e34U,
+	0x8b432976U, 0xcb23c6dcU, 0xb6edfc68U, 0xb8e4f163U,
+	0xd731dccaU, 0x42638510U, 0x13972240U, 0x84c61120U,
+	0x854a247dU, 0xd2bb3df8U, 0xaef93211U, 0xc729a16dU,
+	0x1d9e2f4bU, 0xdcb230f3U, 0x0d8652ecU, 0x77c1e3d0U,
+	0x2bb3166cU, 0xa970b999U, 0x119448faU, 0x47e96422U,
+	0xa8fc8cc4U, 0xa0f03f1aU, 0x567d2cd8U, 0x223390efU,
+	0x87494ec7U, 0xd938d1c1U, 0x8ccaa2feU, 0x98d40b36U,
+	0xa6f581cfU, 0xa57ade28U, 0xdab78e26U, 0x3fadbfa4U,
+	0x2c3a9de4U, 0x5078920dU, 0x6a5fcc9bU, 0x547e4662U,
+	0xf68d13c2U, 0x90d8b8e8U, 0x2e39f75eU, 0x82c3aff5U,
+	0x9f5d80beU, 0x69d0937cU, 0x6fd52da9U, 0xcf2512b3U,
+	0xc8ac993bU, 0x10187da7U, 0xe89c636eU, 0xdb3bbb7bU,
+	0xcd267809U, 0x6e5918f4U, 0xec9ab701U, 0x834f9aa8U,
+	0xe6956e65U, 0xaaffe67eU, 0x21bccf08U, 0xef15e8e6U,
+	0xbae79bd9U, 0x4a6f36ceU, 0xea9f09d4U, 0x29b07cd6U,
+	0x31a4b2afU, 0x2a3f2331U, 0xc6a59430U, 0x35a266c0U,
+	0x744ebc37U, 0xfc82caa6U, 0xe090d0b0U, 0x33a7d815U,
+	0xf104984aU, 0x41ecdaf7U, 0x7fcd500eU, 0x1791f62fU,
+	0x764dd68dU, 0x43efb04dU, 0xccaa4d54U, 0xe49604dfU,
+	0x9ed1b5e3U, 0x4c6a881bU, 0xc12c1fb8U, 0x4665517fU,
+	0x9d5eea04U, 0x018c355dU, 0xfa877473U, 0xfb0b412eU,
+	0xb3671d5aU, 0x92dbd252U, 0xe9105633U, 0x6dd64713U,
+	0x9ad7618cU, 0x37a10c7aU, 0x59f8148eU, 0xeb133c89U,
+	0xcea927eeU, 0xb761c935U, 0xe11ce5edU, 0x7a47b13cU,
+	0x9cd2df59U, 0x55f2733fU, 0x1814ce79U, 0x73c737bfU,
+	0x53f7cdeaU, 0x5ffdaa5bU, 0xdf3d6f14U, 0x7844db86U,
+	0xcaaff381U, 0xb968c43eU, 0x3824342cU, 0xc2a3405fU,
+	0x161dc372U, 0xbce2250cU, 0x283c498bU, 0xff0d9541U,
+	0x39a80171U, 0x080cb3deU, 0xd8b4e49cU, 0x6456c190U,
+	0x7bcb8461U, 0xd532b670U, 0x486c5c74U, 0xd0b85742U,
 };
 const u8 Td4s[256] = {
-    0x52U, 0x09U, 0x6aU, 0xd5U, 0x30U, 0x36U, 0xa5U, 0x38U,
-    0xbfU, 0x40U, 0xa3U, 0x9eU, 0x81U, 0xf3U, 0xd7U, 0xfbU,
-    0x7cU, 0xe3U, 0x39U, 0x82U, 0x9bU, 0x2fU, 0xffU, 0x87U,
-    0x34U, 0x8eU, 0x43U, 0x44U, 0xc4U, 0xdeU, 0xe9U, 0xcbU,
-    0x54U, 0x7bU, 0x94U, 0x32U, 0xa6U, 0xc2U, 0x23U, 0x3dU,
-    0xeeU, 0x4cU, 0x95U, 0x0bU, 0x42U, 0xfaU, 0xc3U, 0x4eU,
-    0x08U, 0x2eU, 0xa1U, 0x66U, 0x28U, 0xd9U, 0x24U, 0xb2U,
-    0x76U, 0x5bU, 0xa2U, 0x49U, 0x6dU, 0x8bU, 0xd1U, 0x25U,
-    0x72U, 0xf8U, 0xf6U, 0x64U, 0x86U, 0x68U, 0x98U, 0x16U,
-    0xd4U, 0xa4U, 0x5cU, 0xccU, 0x5dU, 0x65U, 0xb6U, 0x92U,
-    0x6cU, 0x70U, 0x48U, 0x50U, 0xfdU, 0xedU, 0xb9U, 0xdaU,
-    0x5eU, 0x15U, 0x46U, 0x57U, 0xa7U, 0x8dU, 0x9dU, 0x84U,
-    0x90U, 0xd8U, 0xabU, 0x00U, 0x8cU, 0xbcU, 0xd3U, 0x0aU,
-    0xf7U, 0xe4U, 0x58U, 0x05U, 0xb8U, 0xb3U, 0x45U, 0x06U,
-    0xd0U, 0x2cU, 0x1eU, 0x8fU, 0xcaU, 0x3fU, 0x0fU, 0x02U,
-    0xc1U, 0xafU, 0xbdU, 0x03U, 0x01U, 0x13U, 0x8aU, 0x6bU,
-    0x3aU, 0x91U, 0x11U, 0x41U, 0x4fU, 0x67U, 0xdcU, 0xeaU,
-    0x97U, 0xf2U, 0xcfU, 0xceU, 0xf0U, 0xb4U, 0xe6U, 0x73U,
-    0x96U, 0xacU, 0x74U, 0x22U, 0xe7U, 0xadU, 0x35U, 0x85U,
-    0xe2U, 0xf9U, 0x37U, 0xe8U, 0x1cU, 0x75U, 0xdfU, 0x6eU,
-    0x47U, 0xf1U, 0x1aU, 0x71U, 0x1dU, 0x29U, 0xc5U, 0x89U,
-    0x6fU, 0xb7U, 0x62U, 0x0eU, 0xaaU, 0x18U, 0xbeU, 0x1bU,
-    0xfcU, 0x56U, 0x3eU, 0x4bU, 0xc6U, 0xd2U, 0x79U, 0x20U,
-    0x9aU, 0xdbU, 0xc0U, 0xfeU, 0x78U, 0xcdU, 0x5aU, 0xf4U,
-    0x1fU, 0xddU, 0xa8U, 0x33U, 0x88U, 0x07U, 0xc7U, 0x31U,
-    0xb1U, 0x12U, 0x10U, 0x59U, 0x27U, 0x80U, 0xecU, 0x5fU,
-    0x60U, 0x51U, 0x7fU, 0xa9U, 0x19U, 0xb5U, 0x4aU, 0x0dU,
-    0x2dU, 0xe5U, 0x7aU, 0x9fU, 0x93U, 0xc9U, 0x9cU, 0xefU,
-    0xa0U, 0xe0U, 0x3bU, 0x4dU, 0xaeU, 0x2aU, 0xf5U, 0xb0U,
-    0xc8U, 0xebU, 0xbbU, 0x3cU, 0x83U, 0x53U, 0x99U, 0x61U,
-    0x17U, 0x2bU, 0x04U, 0x7eU, 0xbaU, 0x77U, 0xd6U, 0x26U,
-    0xe1U, 0x69U, 0x14U, 0x63U, 0x55U, 0x21U, 0x0cU, 0x7dU,
+	0x52U, 0x09U, 0x6aU, 0xd5U, 0x30U, 0x36U, 0xa5U, 0x38U,
+	0xbfU, 0x40U, 0xa3U, 0x9eU, 0x81U, 0xf3U, 0xd7U, 0xfbU,
+	0x7cU, 0xe3U, 0x39U, 0x82U, 0x9bU, 0x2fU, 0xffU, 0x87U,
+	0x34U, 0x8eU, 0x43U, 0x44U, 0xc4U, 0xdeU, 0xe9U, 0xcbU,
+	0x54U, 0x7bU, 0x94U, 0x32U, 0xa6U, 0xc2U, 0x23U, 0x3dU,
+	0xeeU, 0x4cU, 0x95U, 0x0bU, 0x42U, 0xfaU, 0xc3U, 0x4eU,
+	0x08U, 0x2eU, 0xa1U, 0x66U, 0x28U, 0xd9U, 0x24U, 0xb2U,
+	0x76U, 0x5bU, 0xa2U, 0x49U, 0x6dU, 0x8bU, 0xd1U, 0x25U,
+	0x72U, 0xf8U, 0xf6U, 0x64U, 0x86U, 0x68U, 0x98U, 0x16U,
+	0xd4U, 0xa4U, 0x5cU, 0xccU, 0x5dU, 0x65U, 0xb6U, 0x92U,
+	0x6cU, 0x70U, 0x48U, 0x50U, 0xfdU, 0xedU, 0xb9U, 0xdaU,
+	0x5eU, 0x15U, 0x46U, 0x57U, 0xa7U, 0x8dU, 0x9dU, 0x84U,
+	0x90U, 0xd8U, 0xabU, 0x00U, 0x8cU, 0xbcU, 0xd3U, 0x0aU,
+	0xf7U, 0xe4U, 0x58U, 0x05U, 0xb8U, 0xb3U, 0x45U, 0x06U,
+	0xd0U, 0x2cU, 0x1eU, 0x8fU, 0xcaU, 0x3fU, 0x0fU, 0x02U,
+	0xc1U, 0xafU, 0xbdU, 0x03U, 0x01U, 0x13U, 0x8aU, 0x6bU,
+	0x3aU, 0x91U, 0x11U, 0x41U, 0x4fU, 0x67U, 0xdcU, 0xeaU,
+	0x97U, 0xf2U, 0xcfU, 0xceU, 0xf0U, 0xb4U, 0xe6U, 0x73U,
+	0x96U, 0xacU, 0x74U, 0x22U, 0xe7U, 0xadU, 0x35U, 0x85U,
+	0xe2U, 0xf9U, 0x37U, 0xe8U, 0x1cU, 0x75U, 0xdfU, 0x6eU,
+	0x47U, 0xf1U, 0x1aU, 0x71U, 0x1dU, 0x29U, 0xc5U, 0x89U,
+	0x6fU, 0xb7U, 0x62U, 0x0eU, 0xaaU, 0x18U, 0xbeU, 0x1bU,
+	0xfcU, 0x56U, 0x3eU, 0x4bU, 0xc6U, 0xd2U, 0x79U, 0x20U,
+	0x9aU, 0xdbU, 0xc0U, 0xfeU, 0x78U, 0xcdU, 0x5aU, 0xf4U,
+	0x1fU, 0xddU, 0xa8U, 0x33U, 0x88U, 0x07U, 0xc7U, 0x31U,
+	0xb1U, 0x12U, 0x10U, 0x59U, 0x27U, 0x80U, 0xecU, 0x5fU,
+	0x60U, 0x51U, 0x7fU, 0xa9U, 0x19U, 0xb5U, 0x4aU, 0x0dU,
+	0x2dU, 0xe5U, 0x7aU, 0x9fU, 0x93U, 0xc9U, 0x9cU, 0xefU,
+	0xa0U, 0xe0U, 0x3bU, 0x4dU, 0xaeU, 0x2aU, 0xf5U, 0xb0U,
+	0xc8U, 0xebU, 0xbbU, 0x3cU, 0x83U, 0x53U, 0x99U, 0x61U,
+	0x17U, 0x2bU, 0x04U, 0x7eU, 0xbaU, 0x77U, 0xd6U, 0x26U,
+	0xe1U, 0x69U, 0x14U, 0x63U, 0x55U, 0x21U, 0x0cU, 0x7dU,
 };
 const u8 rcons[] = {
 	0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1B, 0x36
@@ -2775,13 +2639,13 @@ const u8 rcons[] = {
  *
  * @return	the number of rounds for the given cipher key size.
  */
-#ifndef PLATFORM_FREEBSD //Baron
+#ifndef PLATFORM_FREEBSD /* Baron */
 static void rijndaelKeySetupEnc(u32 rk[/*44*/], const u8 cipherKey[])
 {
 	int i;
 	u32 temp;
 
-	rk[0] = GETU32(cipherKey     );
+	rk[0] = GETU32(cipherKey);
 	rk[1] = GETU32(cipherKey +  4);
 	rk[2] = GETU32(cipherKey +  8);
 	rk[3] = GETU32(cipherKey + 12);
@@ -2809,28 +2673,29 @@ static void rijndaelEncrypt(u32 rk[/*44*/], u8 pt[16], u8 ct[16])
 	 * map byte array block to cipher state
 	 * and add initial round key:
 	 */
-	s0 = GETU32(pt     ) ^ rk[0];
+	s0 = GETU32(pt) ^ rk[0];
 	s1 = GETU32(pt +  4) ^ rk[1];
 	s2 = GETU32(pt +  8) ^ rk[2];
 	s3 = GETU32(pt + 12) ^ rk[3];
 
-#define ROUND(i,d,s) \
-d##0 = TE0(s##0) ^ TE1(s##1) ^ TE2(s##2) ^ TE3(s##3) ^ rk[4 * i]; \
-d##1 = TE0(s##1) ^ TE1(s##2) ^ TE2(s##3) ^ TE3(s##0) ^ rk[4 * i + 1]; \
-d##2 = TE0(s##2) ^ TE1(s##3) ^ TE2(s##0) ^ TE3(s##1) ^ rk[4 * i + 2]; \
-d##3 = TE0(s##3) ^ TE1(s##0) ^ TE2(s##1) ^ TE3(s##2) ^ rk[4 * i + 3]
+#define ROUND(i, d, s) do {\
+	d##0 = TE0(s##0) ^ TE1(s##1) ^ TE2(s##2) ^ TE3(s##3) ^ rk[4 * i]; \
+	d##1 = TE0(s##1) ^ TE1(s##2) ^ TE2(s##3) ^ TE3(s##0) ^ rk[4 * i + 1]; \
+	d##2 = TE0(s##2) ^ TE1(s##3) ^ TE2(s##0) ^ TE3(s##1) ^ rk[4 * i + 2]; \
+	d##3 = TE0(s##3) ^ TE1(s##0) ^ TE2(s##1) ^ TE3(s##2) ^ rk[4 * i + 3]; \
+	} while (0)
 
 #ifdef FULL_UNROLL
 
-	ROUND(1,t,s);
-	ROUND(2,s,t);
-	ROUND(3,t,s);
-	ROUND(4,s,t);
-	ROUND(5,t,s);
-	ROUND(6,s,t);
-	ROUND(7,t,s);
-	ROUND(8,s,t);
-	ROUND(9,t,s);
+	ROUND(1, t, s);
+	ROUND(2, s, t);
+	ROUND(3, t, s);
+	ROUND(4, s, t);
+	ROUND(5, t, s);
+	ROUND(6, s, t);
+	ROUND(7, t, s);
+	ROUND(8, s, t);
+	ROUND(9, t, s);
 
 	rk += Nr << 2;
 
@@ -2839,11 +2704,11 @@ d##3 = TE0(s##3) ^ TE1(s##0) ^ TE2(s##1) ^ TE3(s##2) ^ rk[4 * i + 3]
 	/* Nr - 1 full rounds: */
 	r = Nr >> 1;
 	for (;;) {
-		ROUND(1,t,s);
+		ROUND(1, t, s);
 		rk += 8;
 		if (--r == 0)
 			break;
-		ROUND(0,s,t);
+		ROUND(0, s, t);
 	}
 
 #endif /* ?FULL_UNROLL */
@@ -2864,12 +2729,12 @@ d##3 = TE0(s##3) ^ TE1(s##0) ^ TE2(s##1) ^ TE3(s##2) ^ rk[4 * i + 3]
 	PUTU32(ct + 12, s3);
 }
 
-static void * aes_encrypt_init(u8 *key, size_t len)
+static void *aes_encrypt_init(const u8 *key, size_t len)
 {
 	u32 *rk;
 	if (len != 16)
 		return NULL;
-	rk = (u32*)rtw_malloc(AES_PRIV_SIZE);
+	rk = (u32 *)rtw_malloc(AES_PRIV_SIZE);
 	if (rk == NULL)
 		return NULL;
 	rijndaelKeySetupEnc(rk, key);
@@ -2914,12 +2779,12 @@ static void aes_encrypt_deinit(void *ctx)
  * OMAC1 was standardized with the name CMAC by NIST in a Special Publication
  * (SP) 800-38B.
  */
-static int omac1_aes_128_vector(u8 *key, size_t num_elem,
-							 u8 *addr[], size_t *len, u8 *mac)
+static int omac1_aes_128_vector(const u8 *key, size_t num_elem,
+			 const u8 *addr[], const size_t *len, u8 *mac)
 {
 	void *ctx;
 	u8 cbc[AES_BLOCK_SIZE], pad[AES_BLOCK_SIZE];
-	u8 *pos, *end;
+	const u8 *pos, *end;
 	size_t i, e, left, total_len;
 
 	ctx = aes_encrypt_init(key, 16);
@@ -2986,12 +2851,237 @@ static int omac1_aes_128_vector(u8 *key, size_t num_elem,
  * This is a mode for using block cipher (AES in this case) for authentication.
  * OMAC1 was standardized with the name CMAC by NIST in a Special Publication
  * (SP) 800-38B.
- */ //modify for CONFIG_IEEE80211W
-int omac1_aes_128(u8 *key, u8 *data, size_t data_len, u8 *mac)
+ */ /* modify for CONFIG_IEEE80211W */
+int omac1_aes_128(const u8 *key, const u8 *data, size_t data_len, u8 *mac)
 {
 	return omac1_aes_128_vector(key, 1, &data, &data_len, mac);
 }
-#endif //PLATFORM_FREEBSD Baron
+#endif /* PLATFORM_FREEBSD Baron */
+
+#ifdef CONFIG_RTW_MESH_AEK
+/* for AES-SIV */
+#define os_memset _rtw_memset
+#define os_memcpy _rtw_memcpy
+#define os_malloc rtw_malloc
+#define bin_clear_free(bin, len) \
+	do { \
+		if (bin) { \
+			os_memset(bin, 0, len); \
+			rtw_mfree(bin, len); \
+		} \
+	} while (0)
+
+static const u8 zero[AES_BLOCK_SIZE];
+
+static void dbl(u8 *pad)
+{
+	int i, carry;
+
+	carry = pad[0] & 0x80;
+	for (i = 0; i < AES_BLOCK_SIZE - 1; i++)
+		pad[i] = (pad[i] << 1) | (pad[i + 1] >> 7);
+	pad[AES_BLOCK_SIZE - 1] <<= 1;
+	if (carry)
+		pad[AES_BLOCK_SIZE - 1] ^= 0x87;
+}
+
+static void xor(u8 *a, const u8 *b)
+{
+	int i;
+
+	for (i = 0; i < AES_BLOCK_SIZE; i++)
+		*a++ ^= *b++;
+}
+
+static void xorend(u8 *a, int alen, const u8 *b, int blen)
+{
+	int i;
+
+	if (alen < blen)
+		return;
+
+	for (i = 0; i < blen; i++)
+		a[alen - blen + i] ^= b[i];
+}
+
+static void pad_block(u8 *pad, const u8 *addr, size_t len)
+{
+	os_memset(pad, 0, AES_BLOCK_SIZE);
+	os_memcpy(pad, addr, len);
+
+	if (len < AES_BLOCK_SIZE)
+		pad[len] = 0x80;
+}
+
+static int aes_s2v(const u8 *key, size_t num_elem, const u8 *addr[],
+		   size_t *len, u8 *mac)
+{
+	u8 tmp[AES_BLOCK_SIZE], tmp2[AES_BLOCK_SIZE];
+	u8 *buf = NULL;
+	int ret;
+	size_t i;
+
+	if (!num_elem) {
+		os_memcpy(tmp, zero, sizeof(zero));
+		tmp[AES_BLOCK_SIZE - 1] = 1;
+		return omac1_aes_128(key, tmp, sizeof(tmp), mac);
+	}
+
+	ret = omac1_aes_128(key, zero, sizeof(zero), tmp);
+	if (ret)
+		return ret;
+
+	for (i = 0; i < num_elem - 1; i++) {
+		ret = omac1_aes_128(key, addr[i], len[i], tmp2);
+		if (ret)
+			return ret;
+
+		dbl(tmp);
+		xor(tmp, tmp2);
+	}
+	if (len[i] >= AES_BLOCK_SIZE) {
+		buf = os_malloc(len[i]);
+		if (!buf)
+			return -ENOMEM;
+
+		os_memcpy(buf, addr[i], len[i]);
+		xorend(buf, len[i], tmp, AES_BLOCK_SIZE);
+		ret = omac1_aes_128(key, buf, len[i], mac);
+		bin_clear_free(buf, len[i]);
+		return ret;
+	}
+
+	dbl(tmp);
+	pad_block(tmp2, addr[i], len[i]);
+	xor(tmp, tmp2);
+
+	return omac1_aes_128(key, tmp, sizeof(tmp), mac);
+}
+
+/**
+ * aes_128_ctr_encrypt - AES-128 CTR mode encryption
+ * @key: Key for encryption (16 bytes)
+ * @nonce: Nonce for counter mode (16 bytes)
+ * @data: Data to encrypt in-place
+ * @data_len: Length of data in bytes
+ * Returns: 0 on success, -1 on failure
+ */
+int aes_128_ctr_encrypt(const u8 *key, const u8 *nonce,
+			u8 *data, size_t data_len)
+{
+	void *ctx;
+	size_t j, len, left = data_len;
+	int i;
+	u8 *pos = data;
+	u8 counter[AES_BLOCK_SIZE], buf[AES_BLOCK_SIZE];
+
+	ctx = aes_encrypt_init(key, 16);
+	if (ctx == NULL)
+		return -1;
+	os_memcpy(counter, nonce, AES_BLOCK_SIZE);
+
+	while (left > 0) {
+		#if 0
+		aes_encrypt(ctx, counter, buf);
+		#else
+		aes_128_encrypt(ctx, counter, buf);
+		#endif
+
+		len = (left < AES_BLOCK_SIZE) ? left : AES_BLOCK_SIZE;
+		for (j = 0; j < len; j++)
+			pos[j] ^= buf[j];
+		pos += len;
+		left -= len;
+
+		for (i = AES_BLOCK_SIZE - 1; i >= 0; i--) {
+			counter[i]++;
+			if (counter[i])
+				break;
+		}
+	}
+	aes_encrypt_deinit(ctx);
+	return 0;
+}
+
+int aes_siv_encrypt(const u8 *key, const u8 *pw,
+		    size_t pwlen, size_t num_elem,
+		    const u8 *addr[], const size_t *len, u8 *out)
+{
+	const u8 *_addr[6];
+	size_t _len[6];
+	const u8 *k1 = key, *k2 = key + 16;
+	u8 v[AES_BLOCK_SIZE];
+	size_t i;
+	u8 *iv, *crypt_pw;
+
+	if (num_elem > ARRAY_SIZE(_addr) - 1)
+		return -1;
+
+	for (i = 0; i < num_elem; i++) {
+		_addr[i] = addr[i];
+		_len[i] = len[i];
+	}
+	_addr[num_elem] = pw;
+	_len[num_elem] = pwlen;
+
+	if (aes_s2v(k1, num_elem + 1, _addr, _len, v))
+		return -1;
+
+	iv = out;
+	crypt_pw = out + AES_BLOCK_SIZE;
+
+	os_memcpy(iv, v, AES_BLOCK_SIZE);
+	os_memcpy(crypt_pw, pw, pwlen);
+
+	/* zero out 63rd and 31st bits of ctr (from right) */
+	v[8] &= 0x7f;
+	v[12] &= 0x7f;
+	return aes_128_ctr_encrypt(k2, v, crypt_pw, pwlen);
+}
+
+int aes_siv_decrypt(const u8 *key, const u8 *iv_crypt, size_t iv_c_len,
+		    size_t num_elem, const u8 *addr[], const size_t *len,
+		    u8 *out)
+{
+	const u8 *_addr[6];
+	size_t _len[6];
+	const u8 *k1 = key, *k2 = key + 16;
+	size_t crypt_len;
+	size_t i;
+	int ret;
+	u8 iv[AES_BLOCK_SIZE];
+	u8 check[AES_BLOCK_SIZE];
+
+	if (iv_c_len < AES_BLOCK_SIZE || num_elem > ARRAY_SIZE(_addr) - 1)
+		return -1;
+	crypt_len = iv_c_len - AES_BLOCK_SIZE;
+
+	for (i = 0; i < num_elem; i++) {
+		_addr[i] = addr[i];
+		_len[i] = len[i];
+	}
+	_addr[num_elem] = out;
+	_len[num_elem] = crypt_len;
+
+	os_memcpy(iv, iv_crypt, AES_BLOCK_SIZE);
+	os_memcpy(out, iv_crypt + AES_BLOCK_SIZE, crypt_len);
+
+	iv[8] &= 0x7f;
+	iv[12] &= 0x7f;
+
+	ret = aes_128_ctr_encrypt(k2, iv, out, crypt_len);
+	if (ret)
+		return ret;
+
+	ret = aes_s2v(k1, num_elem + 1, _addr, _len, check);
+	if (ret)
+		return ret;
+	if (os_memcmp(check, iv_crypt, AES_BLOCK_SIZE) == 0)
+		return 0;
+
+	return -1;
+}
+#endif /* CONFIG_RTW_MESH_AEK */
 
 #ifdef CONFIG_TDLS
 void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta)
@@ -3029,16 +3119,16 @@ void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta)
 	 * added by the KDF anyway..
 	 */
 
-	if (os_memcmp(adapter_mac_addr(padapter), psta->hwaddr, ETH_ALEN) < 0) {
+	if (os_memcmp(adapter_mac_addr(padapter), psta->cmn.mac_addr, ETH_ALEN) < 0) {
 		_rtw_memcpy(data, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(data + ETH_ALEN, psta->hwaddr, ETH_ALEN);
+		_rtw_memcpy(data + ETH_ALEN, psta->cmn.mac_addr, ETH_ALEN);
 	} else {
-		_rtw_memcpy(data, psta->hwaddr, ETH_ALEN);
+		_rtw_memcpy(data, psta->cmn.mac_addr, ETH_ALEN);
 		_rtw_memcpy(data + ETH_ALEN, adapter_mac_addr(padapter), ETH_ALEN);
 	}
 	_rtw_memcpy(data + 2 * ETH_ALEN, get_bssid(pmlmepriv), ETH_ALEN);
 
-	sha256_prf(key_input, SHA256_MAC_LEN, "TDLS PMK", data, sizeof(data), (u8 *) &psta->tpk, sizeof(psta->tpk));	
+	sha256_prf(key_input, SHA256_MAC_LEN, "TDLS PMK", data, sizeof(data), (u8 *) &psta->tpk, sizeof(psta->tpk));
 
 
 }
@@ -3054,19 +3144,19 @@ void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta)
  *
  * Calculate MIC for TDLS frame.
  */
-int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq, 
-							u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie,
-							u8 *mic)
+int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
+		      u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie,
+		      u8 *mic)
 {
 	u8 *buf, *pos;
 	struct wpa_tdls_ftie *_ftie;
 	struct wpa_tdls_lnkid *_lnkid;
 	int ret;
 	int len = 2 * ETH_ALEN + 1 + 2 + lnkid[1] + 2 + rsnie[1] +
-		2 + timeoutie[1] + 2 + ftie[1];
+		  2 + timeoutie[1] + 2 + ftie[1];
 	buf = rtw_zmalloc(len);
 	if (!buf) {
-		DBG_871X("TDLS: No memory for MIC calculation\n");
+		RTW_INFO("TDLS: No memory for MIC calculation\n");
 		return -1;
 	}
 
@@ -3094,7 +3184,7 @@ int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
 	_ftie = (struct wpa_tdls_ftie *) pos;
 	_rtw_memset(_ftie->mic, 0, TDLS_MIC_LEN);
 	pos += 2 + ftie[1];
- 
+
 	ret = omac1_aes_128(kck, buf, pos - buf, mic);
 	rtw_mfree(buf, len);
 	return ret;
@@ -3113,17 +3203,17 @@ int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
  *
  * Calculate MIC for TDLS TEARDOWN frame according to Section 10.22.5 in IEEE 802.11 - 2012.
  */
-int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason, 
-	u8 dialog_token, u8 trans_seq, u8 *ftie, u8 *mic)
+int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason,
+			       u8 dialog_token, u8 trans_seq, u8 *ftie, u8 *mic)
 {
 	u8 *buf, *pos;
 	struct wpa_tdls_ftie *_ftie;
 	int ret;
 	int len = 2 + lnkid[1] + 2 + 1 + 1 + 2 + ftie[1];
-	
+
 	buf = rtw_zmalloc(len);
 	if (!buf) {
-		DBG_871X("TDLS: No memory for MIC calculation\n");
+		RTW_INFO("TDLS: No memory for MIC calculation\n");
 		return -1;
 	}
 
@@ -3151,7 +3241,7 @@ int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason,
 }
 
 int tdls_verify_mic(u8 *kck, u8 trans_seq,
-							u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie)
+		    u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie)
 {
 	u8 *buf, *pos;
 	int len;
@@ -3160,11 +3250,10 @@ int tdls_verify_mic(u8 *kck, u8 trans_seq,
 	u8 *rx_ftie, *tmp_ftie;
 
 	if (lnkid == NULL || rsnie == NULL ||
-	    timeoutie == NULL || ftie == NULL){
+	    timeoutie == NULL || ftie == NULL)
 		return _FAIL;
-	}
-	
-	len = 2 * ETH_ALEN + 1 + 2 + 18 + 2 + *(rsnie+1) + 2 + *(timeoutie+1) + 2 + *(ftie+1);
+
+	len = 2 * ETH_ALEN + 1 + 2 + 18 + 2 + *(rsnie + 1) + 2 + *(timeoutie + 1) + 2 + *(ftie + 1);
 
 	buf = rtw_zmalloc(len);
 	if (buf == NULL)
@@ -3183,95 +3272,69 @@ int tdls_verify_mic(u8 *kck, u8 trans_seq,
 	_rtw_memcpy(pos, lnkid, 2 + 18);
 	pos += 2 + 18;
 	/* 5) RSN IE */
-	_rtw_memcpy(pos, rsnie, 2 + *(rsnie+1));
-	pos += 2 + *(rsnie+1);
+	_rtw_memcpy(pos, rsnie, 2 + *(rsnie + 1));
+	pos += 2 + *(rsnie + 1);
 	/* 6) Timeout Interval IE */
-	_rtw_memcpy(pos, timeoutie, 2 + *(timeoutie+1));
-	pos += 2 + *(timeoutie+1);
+	_rtw_memcpy(pos, timeoutie, 2 + *(timeoutie + 1));
+	pos += 2 + *(timeoutie + 1);
 	/* 7) FTIE, with the MIC field of the FTIE set to 0 */
-	_rtw_memcpy(pos, ftie, 2 + *(ftie+1));
+	_rtw_memcpy(pos, ftie, 2 + *(ftie + 1));
 	pos += 2;
-	tmp_ftie = (u8 *) (pos+2);
+	tmp_ftie = (u8 *)(pos + 2);
 	_rtw_memset(tmp_ftie, 0, 16);
-	pos += *(ftie+1);
+	pos += *(ftie + 1);
 
 	ret = omac1_aes_128(kck, buf, pos - buf, mic);
 	rtw_mfree(buf, len);
 	if (ret)
 		return _FAIL;
-	rx_ftie = ftie+4;
+	rx_ftie = ftie + 4;
 
 	if (os_memcmp(mic, rx_ftie, 16) == 0) {
-		//Valid MIC
+		/* Valid MIC */
 		return _SUCCESS;
 	}
 
-	//Invalid MIC
-	DBG_871X( "[%s] Invalid MIC\n", __FUNCTION__);
+	/* Invalid MIC */
+	RTW_INFO("[%s] Invalid MIC\n", __FUNCTION__);
 	return _FAIL;
 
 }
-#endif //CONFIG_TDLS
-
-void rtw_use_tkipkey_handler(RTW_TIMER_HDL_ARGS)
-{
-        _adapter *padapter = (_adapter *)FunctionContext;
-
-_func_enter_;			
-
-	RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("^^^rtw_use_tkipkey_handler ^^^\n"));
-	
-/*
-	if (RTW_CANNOT_RUN(padapter)) {
-			RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("^^^rtw_use_tkipkey_handler (padapter->bDriverStopped %s)(padapter->bSurpriseRemoved %s)^^^\n"
-			, rtw_is_drv_stopped(padapter)?"True":"False"
-			, rtw_is_surprise_removed(padapter)?"True":"False"));
-
-		return;
-	}
-	*/
-	
-	padapter->securitypriv.busetkipkey=_TRUE;
-
-	RT_TRACE(_module_rtl871x_security_c_,_drv_err_,("^^^rtw_use_tkipkey_handler padapter->securitypriv.busetkipkey=%d^^^\n",padapter->securitypriv.busetkipkey));
-
-_func_exit_;	
-
-}
+#endif /* CONFIG_TDLS */
 
 /* Restore HW wep key setting according to key_mask */
 void rtw_sec_restore_wep_key(_adapter *adapter)
 {
-	struct security_priv* securitypriv=&(adapter->securitypriv);
+	struct security_priv *securitypriv = &(adapter->securitypriv);
 	sint keyid;
 
-	if((_WEP40_ == securitypriv->dot11PrivacyAlgrthm) ||(_WEP104_ == securitypriv->dot11PrivacyAlgrthm)) {
-		for(keyid=0;keyid<4;keyid++){
-			if(securitypriv->key_mask & BIT(keyid)){
-				if(keyid == securitypriv->dot11PrivacyKeyIndex)
-					rtw_set_key(adapter,securitypriv, keyid, 1, _FALSE);
+	if ((_WEP40_ == securitypriv->dot11PrivacyAlgrthm) || (_WEP104_ == securitypriv->dot11PrivacyAlgrthm)) {
+		for (keyid = 0; keyid < 4; keyid++) {
+			if (securitypriv->key_mask & BIT(keyid)) {
+				if (keyid == securitypriv->dot11PrivacyKeyIndex)
+					rtw_set_key(adapter, securitypriv, keyid, 1, _FALSE);
 				else
-					rtw_set_key(adapter,securitypriv, keyid, 0, _FALSE);
+					rtw_set_key(adapter, securitypriv, keyid, 0, _FALSE);
 			}
 		}
 	}
 }
 
-u8 rtw_handle_tkip_countermeasure(_adapter* adapter, const char *caller)
+u8 rtw_handle_tkip_countermeasure(_adapter *adapter, const char *caller)
 {
-	struct security_priv* securitypriv=&(adapter->securitypriv);
+	struct security_priv *securitypriv = &(adapter->securitypriv);
 	u8 status = _SUCCESS;
 
 	if (securitypriv->btkip_countermeasure == _TRUE) {
 		u32 passing_ms = rtw_get_passing_time_ms(securitypriv->btkip_countermeasure_time);
-		if (passing_ms > 60*1000) {
-			DBG_871X_LEVEL(_drv_always_, "%s("ADPT_FMT") countermeasure time:%ds > 60s \n",
-				caller, ADPT_ARG(adapter), passing_ms/1000);
+		if (passing_ms > 60 * 1000) {
+			RTW_PRINT("%s("ADPT_FMT") countermeasure time:%ds > 60s\n",
+				  caller, ADPT_ARG(adapter), passing_ms / 1000);
 			securitypriv->btkip_countermeasure = _FALSE;
 			securitypriv->btkip_countermeasure_time = 0;
 		} else {
-			DBG_871X_LEVEL(_drv_always_, "%s("ADPT_FMT") countermeasure time:%ds < 60s \n",
-				caller, ADPT_ARG(adapter), passing_ms/1000);
+			RTW_PRINT("%s("ADPT_FMT") countermeasure time:%ds < 60s\n",
+				  caller, ADPT_ARG(adapter), passing_ms / 1000);
 			status = _FAIL;
 		}
 	}
@@ -3305,7 +3368,7 @@ u16 rtw_cal_crc16(u8 data, u16 crc)
 		crc_bit11 = ((crc & BIT11) ? 1 : 0) ^ shift_in;
 
 		if (crc_bit11 == 0)
-			crc_result &= (~BIT12); 
+			crc_result &= (~BIT12);
 		else
 			crc_result |= BIT12;
 
@@ -3335,7 +3398,7 @@ u16 rtw_calc_crc(u8  *pdata, int length)
 {
 	u16 crc = 0xffff;
 	int i;
-	
+
 	for (i = 0; i < length; i++)
 		crc = rtw_cal_crc16(pdata[i], crc);
 	/* get 1' complement */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sreset.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sreset.c
index e5d5661d32c2..2e3223ac9ecd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sreset.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sreset.c
@@ -1,369 +1,333 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#include <drv_types.h>
-#include <hal_data.h>
-#include <rtw_sreset.h>
-
-void sreset_init_value(_adapter *padapter)
-{
-#if defined(DBG_CONFIG_ERROR_DETECT)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-
-	_rtw_mutex_init(&psrtpriv->silentreset_mutex);
-	psrtpriv->silent_reset_inprogress = _FALSE;
-	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
-	psrtpriv->last_tx_time =0;
-	psrtpriv->last_tx_complete_time =0;
-#endif
-}
-void sreset_reset_value(_adapter *padapter)
-{
-#if defined(DBG_CONFIG_ERROR_DETECT)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-
-	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
-	psrtpriv->last_tx_time =0;
-	psrtpriv->last_tx_complete_time =0;
-#endif
-}
-
-u8 sreset_get_wifi_status(_adapter *padapter)
-{
-#if defined(DBG_CONFIG_ERROR_DETECT)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-
-	u8 status = WIFI_STATUS_SUCCESS;
-	u32 val32 = 0;
-	_irqL irqL;
-	if(psrtpriv->silent_reset_inprogress == _TRUE)
-        {
-		return status;
-	}
-	val32 =rtw_read32(padapter,REG_TXDMA_STATUS);
-	if(val32==0xeaeaeaea){
-		psrtpriv->Wifi_Error_Status = WIFI_IF_NOT_EXIST;
-	}
-	else if(val32!=0){
-		DBG_8192C("txdmastatu(%x)\n",val32);
-		psrtpriv->Wifi_Error_Status = WIFI_MAC_TXDMA_ERROR;
-	}
-
-	if(WIFI_STATUS_SUCCESS !=psrtpriv->Wifi_Error_Status)
-	{
-		DBG_8192C("==>%s error_status(0x%x) \n",__FUNCTION__,psrtpriv->Wifi_Error_Status);
-		status = (psrtpriv->Wifi_Error_Status &( ~(USB_READ_PORT_FAIL|USB_WRITE_PORT_FAIL)));
-	}
-	DBG_8192C("==> %s wifi_status(0x%x)\n",__FUNCTION__,status);
-
-	//status restore
-	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
-
-	return status;
-#else
-	return WIFI_STATUS_SUCCESS;
-#endif
-}
-
-void sreset_set_wifi_error_status(_adapter *padapter, u32 status)
-{
-#if defined(DBG_CONFIG_ERROR_DETECT)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	pHalData->srestpriv.Wifi_Error_Status = status;
-#endif
-}
-
-void sreset_set_trigger_point(_adapter *padapter, s32 tgp)
-{
-#if defined(DBG_CONFIG_ERROR_DETECT)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	pHalData->srestpriv.dbg_trigger_point = tgp;
-#endif
-}
-
-bool sreset_inprogress(_adapter *padapter)
-{
-#if defined(DBG_CONFIG_ERROR_RESET)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	return pHalData->srestpriv.silent_reset_inprogress;
-#else
-	return _FALSE;
-#endif
-}
-
-void sreset_restore_security_station(_adapter *padapter)
-{
-	u8 EntryId = 0;
-	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-	struct sta_priv * pstapriv = &padapter->stapriv;
-	struct sta_info *psta;
-	struct security_priv* psecuritypriv=&(padapter->securitypriv);
-	struct mlme_ext_info	*pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
-
-	{
-		u8 val8;
-
-		if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X) {
-			val8 = 0xcc;
-		#ifdef CONFIG_WAPI_SUPPORT
-		} else if (padapter->wapiInfo.bWapiEnable && pmlmeinfo->auth_algo == dot11AuthAlgrthm_WAPI) {
-			//Disable TxUseDefaultKey, RxUseDefaultKey, RxBroadcastUseDefaultKey.
-			val8 = 0x4c;
-		#endif
-		} else {
-			val8 = 0xcf;
-		}
-		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
-	}
-
-	#if 0
-	if (	( padapter->securitypriv.dot11PrivacyAlgrthm == _WEP40_ ) ||
-		( padapter->securitypriv.dot11PrivacyAlgrthm == _WEP104_ ))
-	{
-
-		for(EntryId=0; EntryId<4; EntryId++)
-		{
-			if(EntryId == psecuritypriv->dot11PrivacyKeyIndex)
-				rtw_set_key(padapter,&padapter->securitypriv, EntryId, 1,_FALSE);
-			else
-				rtw_set_key(padapter,&padapter->securitypriv, EntryId, 0,_FALSE);
-		}
-
-	}
-	else
-	#endif
-	if((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
-		(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_))
-	{
-		psta = rtw_get_stainfo(pstapriv, get_bssid(mlmepriv));
-		if (psta == NULL) {
-			//DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail \n"));
-		}
-		else
-		{
-			//pairwise key
-			rtw_setstakey_cmd(padapter, psta, UNICAST_KEY,_FALSE);
-			//group key
-			rtw_set_key(padapter,&padapter->securitypriv,padapter->securitypriv.dot118021XGrpKeyid, 0,_FALSE);
-		}
-	}
-}
-
-void sreset_restore_network_station(_adapter *padapter)
-{
-	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8 doiqk = _FALSE;
-
-	#if 0
-	{
-	//=======================================================
-	// reset related register of Beacon control
-
-	//set MSR to nolink
-	Set_MSR(padapter, _HW_STATE_NOLINK_);		
-	// reject all data frame
-	rtw_write16(padapter, REG_RXFLTMAP2,0x00);
-	//reset TSF
-	rtw_write8(padapter, REG_DUAL_TSF_RST, (BIT(0)|BIT(1)));
-
-	// disable update TSF
-	SetBcnCtrlReg(padapter, BIT(4), 0);
-
-	//=======================================================
-	}
-	#endif
-	
-	rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure,_FALSE);
-
-	{
-		u8 threshold;
-		#ifdef CONFIG_USB_HCI
-		// 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;
-			rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
-		} else {
-			threshold = 1;
-			rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
-		}
-		#endif
-	}
-
-	doiqk = _TRUE;
-	rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK , &doiqk);
-
-	set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-	doiqk = _FALSE;
-	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
-	//disable dynamic functions, such as high power, DIG
-	/*rtw_phydm_func_disable_all(padapter);*/
-	
-	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmlmeinfo->network.MacAddress);
-
-	{
-		u8	join_type = 0;
-		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
-	}
-
-	Set_MSR(padapter, (pmlmeinfo->state & 0x3));
-
-	mlmeext_joinbss_event_callback(padapter, 1);
-	//restore Sequence No.
-	rtw_hal_set_hwreg(padapter, HW_VAR_RESTORE_HW_SEQ, 0);
-
-	sreset_restore_security_station(padapter);
-}
-
-
-void sreset_restore_network_status(_adapter *padapter)
-{
-	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
-		sreset_restore_network_station(padapter);
-	} else if (check_fwstate(mlmepriv, WIFI_AP_STATE)) {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_AP_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
-		rtw_ap_restore_network(padapter);
-	} else if (check_fwstate(mlmepriv, WIFI_ADHOC_STATE)) {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
-	} else {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
-	}
-}
-
-void sreset_stop_adapter(_adapter *padapter)
-{
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
-
-	if (padapter == NULL)
-		return;
-
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-
-	rtw_netif_stop_queue(padapter->pnetdev);
-
-	rtw_cancel_all_timer(padapter);
-
-	/* TODO: OS and HCI independent */
-	#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
-	tasklet_kill(&pxmitpriv->xmit_tasklet);
-	#endif
-
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
-		rtw_scan_abort(padapter);
-
-	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING))
-	{
-		rtw_set_to_roam(padapter, 0);
-		_rtw_join_timeout_handler(padapter);
-	}
-
-}
-
-void sreset_start_adapter(_adapter *padapter)
-{
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
-
-	if (padapter == NULL)
-		return;
-
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-
-	if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-		sreset_restore_network_status(padapter);
-	}
-
-	/* TODO: OS and HCI independent */
-	#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
-	tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
-	#endif
-
-	if (is_primary_adapter(padapter))
-		_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 2000);
-
-	rtw_netif_wake_queue(padapter->pnetdev);
-}
-
-void sreset_reset(_adapter *padapter)
-{
-#ifdef DBG_CONFIG_ERROR_RESET
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
-	_irqL irqL;
-	u32 start = rtw_get_current_time();
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-
-	DBG_871X("%s\n", __FUNCTION__);
-
-	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
-
-
-#ifdef CONFIG_LPS
-	rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "SRESET");
-#endif//#ifdef CONFIG_LPS
-	
-	_enter_pwrlock(&pwrpriv->lock);
-
-	psrtpriv->silent_reset_inprogress = _TRUE;
-	pwrpriv->change_rfpwrstate = rf_off;
-
-	sreset_stop_adapter(padapter);
-	#ifdef CONFIG_CONCURRENT_MODE
-	sreset_stop_adapter(padapter->pbuddy_adapter);
-	#endif
-
-	#ifdef CONFIG_IPS
-	_ips_enter(padapter);
-	_ips_leave(padapter);
-	#endif
-
-	sreset_start_adapter(padapter);
-	#ifdef CONFIG_CONCURRENT_MODE
-	sreset_start_adapter(padapter->pbuddy_adapter);
-	#endif
-
-	psrtpriv->silent_reset_inprogress = _FALSE;
-
-	_exit_pwrlock(&pwrpriv->lock);
-
-	DBG_871X("%s done in %d ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
-	pdbgpriv->dbg_sreset_cnt++;
-#endif
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+#include <rtw_sreset.h>
+
+void sreset_init_value(_adapter *padapter)
+{
+#if defined(DBG_CONFIG_ERROR_DETECT)
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+
+	_rtw_mutex_init(&psrtpriv->silentreset_mutex);
+	psrtpriv->silent_reset_inprogress = _FALSE;
+	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
+	psrtpriv->last_tx_time = 0;
+	psrtpriv->last_tx_complete_time = 0;
+#endif
+}
+void sreset_reset_value(_adapter *padapter)
+{
+#if defined(DBG_CONFIG_ERROR_DETECT)
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+
+	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
+	psrtpriv->last_tx_time = 0;
+	psrtpriv->last_tx_complete_time = 0;
+#endif
+}
+
+u8 sreset_get_wifi_status(_adapter *padapter)
+{
+#if defined(DBG_CONFIG_ERROR_DETECT)
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+
+	u8 status = WIFI_STATUS_SUCCESS;
+	u32 val32 = 0;
+	_irqL irqL;
+	if (psrtpriv->silent_reset_inprogress == _TRUE)
+		return status;
+	val32 = rtw_read32(padapter, REG_TXDMA_STATUS);
+	if (val32 == 0xeaeaeaea)
+		psrtpriv->Wifi_Error_Status = WIFI_IF_NOT_EXIST;
+	else if (val32 != 0) {
+		RTW_INFO("txdmastatu(%x)\n", val32);
+		psrtpriv->Wifi_Error_Status = WIFI_MAC_TXDMA_ERROR;
+	}
+
+	if (WIFI_STATUS_SUCCESS != psrtpriv->Wifi_Error_Status) {
+		RTW_INFO("==>%s error_status(0x%x)\n", __FUNCTION__, psrtpriv->Wifi_Error_Status);
+		status = (psrtpriv->Wifi_Error_Status & (~(USB_READ_PORT_FAIL | USB_WRITE_PORT_FAIL)));
+	}
+	RTW_INFO("==> %s wifi_status(0x%x)\n", __FUNCTION__, status);
+
+	/* status restore */
+	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
+
+	return status;
+#else
+	return WIFI_STATUS_SUCCESS;
+#endif
+}
+
+void sreset_set_wifi_error_status(_adapter *padapter, u32 status)
+{
+#if defined(DBG_CONFIG_ERROR_DETECT)
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	pHalData->srestpriv.Wifi_Error_Status = status;
+#endif
+}
+
+void sreset_set_trigger_point(_adapter *padapter, s32 tgp)
+{
+#if defined(DBG_CONFIG_ERROR_DETECT)
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	pHalData->srestpriv.dbg_trigger_point = tgp;
+#endif
+}
+
+bool sreset_inprogress(_adapter *padapter)
+{
+#if defined(DBG_CONFIG_ERROR_RESET)
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	return pHalData->srestpriv.silent_reset_inprogress;
+#else
+	return _FALSE;
+#endif
+}
+
+void sreset_restore_security_station(_adapter *padapter)
+{
+	u8 EntryId = 0;
+	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct mlme_ext_info	*pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
+
+	{
+		u8 val8;
+
+		if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X) {
+			val8 = 0xcc;
+#ifdef CONFIG_WAPI_SUPPORT
+		} else if (padapter->wapiInfo.bWapiEnable && pmlmeinfo->auth_algo == dot11AuthAlgrthm_WAPI) {
+			/* Disable TxUseDefaultKey, RxUseDefaultKey, RxBroadcastUseDefaultKey. */
+			val8 = 0x4c;
+#endif
+		} else
+			val8 = 0xcf;
+		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
+	}
+
+	if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
+	    (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
+		psta = rtw_get_stainfo(pstapriv, get_bssid(mlmepriv));
+		if (psta == NULL) {
+			/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
+		} else {
+			/* pairwise key */
+			rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _FALSE);
+			/* group key */
+			rtw_set_key(padapter, &padapter->securitypriv, padapter->securitypriv.dot118021XGrpKeyid, 0, _FALSE);
+		}
+	}
+}
+
+void sreset_restore_network_station(_adapter *padapter)
+{
+	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8 doiqk = _FALSE;
+
+#if 0
+	{
+		/* ======================================================= */
+		/* reset related register of Beacon control */
+
+		/* set MSR to nolink */
+		Set_MSR(padapter, _HW_STATE_NOLINK_);
+		/* reject all data frame */
+		rtw_write16(padapter, REG_RXFLTMAP2, 0x00);
+		/* reset TSF */
+		rtw_write8(padapter, REG_DUAL_TSF_RST, (BIT(0) | BIT(1)));
+
+		/* disable update TSF */
+		SetBcnCtrlReg(padapter, BIT(4), 0);
+
+		/* ======================================================= */
+	}
+#endif
+
+	rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, RTW_CMDF_DIRECTLY);
+
+	{
+		u8 threshold;
+#ifdef CONFIG_USB_HCI
+		/* 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;
+			rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
+		} else {
+			threshold = 1;
+			rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
+		}
+#endif
+	}
+
+	doiqk = _TRUE;
+	rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK , &doiqk);
+
+	set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
+
+	doiqk = _FALSE;
+	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+	/* disable dynamic functions, such as high power, DIG */
+	/*rtw_phydm_func_disable_all(padapter);*/
+
+	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmlmeinfo->network.MacAddress);
+
+	{
+		u8	join_type = 0;
+		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTING);
+	}
+
+	Set_MSR(padapter, (pmlmeinfo->state & 0x3));
+
+	mlmeext_joinbss_event_callback(padapter, 1);
+	/* restore Sequence No. */
+	rtw_hal_set_hwreg(padapter, HW_VAR_RESTORE_HW_SEQ, 0);
+
+	sreset_restore_security_station(padapter);
+}
+
+
+void sreset_restore_network_status(_adapter *padapter)
+{
+	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
+		RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
+		sreset_restore_network_station(padapter);
+	} else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+		RTW_INFO(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(padapter), MLME_IS_AP(padapter) ? "AP" : "MESH");
+		rtw_ap_restore_network(padapter);
+	} else if (check_fwstate(mlmepriv, WIFI_ADHOC_STATE))
+		RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
+	else
+		RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
+}
+
+void sreset_stop_adapter(_adapter *padapter)
+{
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+
+	if (padapter == NULL)
+		return;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	rtw_netif_stop_queue(padapter->pnetdev);
+
+	rtw_cancel_all_timer(padapter);
+
+	/* TODO: OS and HCI independent */
+#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
+	tasklet_kill(&pxmitpriv->xmit_tasklet);
+#endif
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
+		rtw_scan_abort(padapter);
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
+		rtw_set_to_roam(padapter, 0);
+		rtw_join_timeout_handler(padapter);
+	}
+
+}
+
+void sreset_start_adapter(_adapter *padapter)
+{
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+
+	if (padapter == NULL)
+		return;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED))
+		sreset_restore_network_status(padapter);
+
+	/* TODO: OS and HCI independent */
+#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
+	tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
+#endif
+
+	if (is_primary_adapter(padapter))
+		_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
+
+	rtw_netif_wake_queue(padapter->pnetdev);
+}
+
+void sreset_reset(_adapter *padapter)
+{
+#ifdef DBG_CONFIG_ERROR_RESET
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
+	_irqL irqL;
+	systime start = rtw_get_current_time();
+	struct dvobj_priv *psdpriv = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
+
+
+#ifdef CONFIG_LPS
+	rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "SRESET");
+#endif/* #ifdef CONFIG_LPS */
+
+	_enter_pwrlock(&pwrpriv->lock);
+
+	psrtpriv->silent_reset_inprogress = _TRUE;
+	pwrpriv->change_rfpwrstate = rf_off;
+
+	rtw_mi_sreset_adapter_hdl(padapter, _FALSE);/*sreset_stop_adapter*/
+#ifdef CONFIG_IPS
+	_ips_enter(padapter);
+	_ips_leave(padapter);
+#endif
+	rtw_mi_sreset_adapter_hdl(padapter, _TRUE);/*sreset_start_adapter*/
+
+	psrtpriv->silent_reset_inprogress = _FALSE;
+
+	_exit_pwrlock(&pwrpriv->lock);
+
+	RTW_INFO("%s done in %d ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
+	pdbgpriv->dbg_sreset_cnt++;
+
+	psrtpriv->self_dect_fw = _FALSE;
+	psrtpriv->rx_cnt = 0;
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sta_mgt.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sta_mgt.c
index b24e7874ef74..8d55df34a289 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sta_mgt.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_sta_mgt.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_STA_MGT_C_
 
 #include <drv_types.h>
 
-#if defined (PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
 
-#error "Shall be Linux or Windows, but not both!\n"
+	#error "Shall be Linux or Windows, but not both!\n"
 
 #endif
 
@@ -133,6 +129,46 @@ inline bool rtw_st_ctl_chk_reg_rule(struct st_ctl_t *st_ctl, _adapter *adapter,
 	return ret;
 }
 
+void rtw_st_ctl_rx(struct sta_info *sta, u8 *ehdr_pos)
+{
+	_adapter *adapter = sta->padapter;
+	struct ethhdr *etherhdr = (struct ethhdr *)ehdr_pos;
+
+	if (ntohs(etherhdr->h_proto) == ETH_P_IP) {
+		u8 *ip = ehdr_pos + ETH_HLEN;
+
+		if (GET_IPV4_PROTOCOL(ip) == 0x06  /* TCP */
+			&& rtw_st_ctl_chk_reg_s_proto(&sta->st_ctl, 0x06) == _TRUE
+		) {
+			u8 *tcp = ip + GET_IPV4_IHL(ip) * 4;
+
+			if (rtw_st_ctl_chk_reg_rule(&sta->st_ctl, adapter, IPV4_DST(ip), TCP_DST(tcp), IPV4_SRC(ip), TCP_SRC(tcp)) == _TRUE) {
+				if (GET_TCP_SYN(tcp) && GET_TCP_ACK(tcp)) {
+					session_tracker_add_cmd(adapter, sta
+						, IPV4_DST(ip), TCP_DST(tcp)
+						, IPV4_SRC(ip), TCP_SRC(tcp));
+					if (DBG_SESSION_TRACKER)
+						RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" SYN-ACK\n"
+							, FUNC_ADPT_ARG(adapter)
+							, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp))
+							, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp)));
+				}
+				if (GET_TCP_FIN(tcp)) {
+					session_tracker_del_cmd(adapter, sta
+						, IPV4_DST(ip), TCP_DST(tcp)
+						, IPV4_SRC(ip), TCP_SRC(tcp));
+					if (DBG_SESSION_TRACKER)
+						RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" FIN\n"
+							, FUNC_ADPT_ARG(adapter)
+							, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp))
+							, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp)));
+				}
+			}
+
+		}
+	}
+}
+
 #define SESSION_TRACKER_FMT IP_FMT":"PORT_FMT" "IP_FMT":"PORT_FMT" %u %d"
 #define SESSION_TRACKER_ARG(st) IP_ARG(&(st)->local_naddr), PORT_ARG(&(st)->local_port), IP_ARG(&(st)->remote_naddr), PORT_ARG(&(st)->remote_port), (st)->status, rtw_get_passing_time_ms((st)->set_time)
 
@@ -147,7 +183,7 @@ void dump_st_ctl(void *sel, struct st_ctl_t *st_ctl)
 		return;
 
 	for (i = 0; i < SESSION_TRACKER_REG_ID_NUM; i++)
-		DBG_871X_SEL_NL(sel, "reg%d: %u %p\n", i, st_ctl->reg[i].s_proto, st_ctl->reg[i].rule);
+		RTW_PRINT_SEL(sel, "reg%d: %u %p\n", i, st_ctl->reg[i].s_proto, st_ctl->reg[i].rule);
 
 	_enter_critical_bh(&st_ctl->tracker_q.lock, &irqL);
 	phead = &st_ctl->tracker_q.queue;
@@ -156,7 +192,7 @@ void dump_st_ctl(void *sel, struct st_ctl_t *st_ctl)
 		st = LIST_CONTAINOR(plist, struct session_tracker, list);
 		plist = get_next(plist);
 
-		DBG_871X_SEL_NL(sel, SESSION_TRACKER_FMT"\n", SESSION_TRACKER_ARG(st));
+		RTW_PRINT_SEL(sel, SESSION_TRACKER_FMT"\n", SESSION_TRACKER_ARG(st));
 	}
 	_exit_critical_bh(&st_ctl->tracker_q.lock, &irqL);
 
@@ -165,92 +201,63 @@ void dump_st_ctl(void *sel, struct st_ctl_t *st_ctl)
 void _rtw_init_stainfo(struct sta_info *psta);
 void _rtw_init_stainfo(struct sta_info *psta)
 {
+	_rtw_memset((u8 *)psta, 0, sizeof(struct sta_info));
 
-_func_enter_;
-
-	_rtw_memset((u8 *)psta, 0, sizeof (struct sta_info));
-
-	 _rtw_spinlock_init(&psta->lock);
+	_rtw_spinlock_init(&psta->lock);
 	_rtw_init_listhead(&psta->list);
 	_rtw_init_listhead(&psta->hash_list);
-	//_rtw_init_listhead(&psta->asoc_list);
-	//_rtw_init_listhead(&psta->sleep_list);
-	//_rtw_init_listhead(&psta->wakeup_list);	
+	/* _rtw_init_listhead(&psta->asoc_list); */
+	/* _rtw_init_listhead(&psta->sleep_list); */
+	/* _rtw_init_listhead(&psta->wakeup_list);	 */
 
 	_rtw_init_queue(&psta->sleep_q);
-	psta->sleepq_len = 0;
 
 	_rtw_init_sta_xmit_priv(&psta->sta_xmitpriv);
 	_rtw_init_sta_recv_priv(&psta->sta_recvpriv);
-	
-#ifdef CONFIG_AP_MODE
 
+#ifdef CONFIG_AP_MODE
 	_rtw_init_listhead(&psta->asoc_list);
-
 	_rtw_init_listhead(&psta->auth_list);
-	
-	psta->expire_to = 0;
-	
-	psta->flags = 0;
-	
-	psta->capability = 0;
-
 	psta->bpairwise_key_installed = _FALSE;
 
-
-#ifdef CONFIG_NATIVEAP_MLME
-	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->ht_40mhz_intolerant = 0;
-#endif	
-
-#ifdef CONFIG_TX_MCAST2UNI
-	psta->under_exist_checking = 0;
-#endif	// CONFIG_TX_MCAST2UNI
-	
-	psta->keep_alive_trycnt = 0;
-
-#endif	// CONFIG_AP_MODE	
+#ifdef CONFIG_RTW_80211R
+	psta->ft_pairwise_key_installed = _FALSE;
+#endif
+#endif /* CONFIG_AP_MODE	 */
 
 	rtw_st_ctl_init(&psta->st_ctl);
-
-_func_exit_;	
-
 }
 
 u32	_rtw_init_sta_priv(struct	sta_priv *pstapriv)
 {
+	_adapter *adapter = container_of(pstapriv, _adapter, stapriv);
+	struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
 	struct sta_info *psta;
 	s32 i;
+	u32 ret = _FAIL;
 
-_func_enter_;	
+	pstapriv->padapter = adapter;
 
-	pstapriv->pallocated_stainfo_buf = rtw_zvmalloc (sizeof(struct sta_info) * NUM_STA+ 4);
-	
-	if(!pstapriv->pallocated_stainfo_buf)
-		return _FAIL;
+	pstapriv->pallocated_stainfo_buf = rtw_zvmalloc(sizeof(struct sta_info) * NUM_STA + 4);
+	if (!pstapriv->pallocated_stainfo_buf)
+		goto exit;
 
-	pstapriv->pstainfo_buf = pstapriv->pallocated_stainfo_buf + 4 - 
-		((SIZE_PTR)(pstapriv->pallocated_stainfo_buf ) & 3);
+	pstapriv->pstainfo_buf = pstapriv->pallocated_stainfo_buf + 4 -
+			 ((SIZE_PTR)(pstapriv->pallocated_stainfo_buf) & 3);
 
 	_rtw_init_queue(&pstapriv->free_sta_queue);
 
 	_rtw_spinlock_init(&pstapriv->sta_hash_lock);
-	
-	//_rtw_init_queue(&pstapriv->asoc_q);
+
+	/* _rtw_init_queue(&pstapriv->asoc_q); */
 	pstapriv->asoc_sta_count = 0;
 	_rtw_init_queue(&pstapriv->sleep_q);
 	_rtw_init_queue(&pstapriv->wakeup_q);
 
 	psta = (struct sta_info *)(pstapriv->pstainfo_buf);
 
-		
-	for(i = 0; i < NUM_STA; i++)
-	{
+
+	for (i = 0; i < NUM_STA; i++) {
 		_rtw_init_stainfo(psta);
 
 		_rtw_init_listhead(&(pstapriv->sta_hash[i]));
@@ -263,9 +270,19 @@ _func_enter_;
 	pstapriv->adhoc_expire_to = 4; /* 4 * 2 = 8 sec */
 
 #ifdef CONFIG_AP_MODE
-
-	pstapriv->sta_dz_bitmap = 0;
-	pstapriv->tim_bitmap = 0;
+	pstapriv->max_aid = macid_ctl->num;
+	pstapriv->rr_aid = 0;
+	pstapriv->started_aid = 1;
+	pstapriv->sta_aid = rtw_zmalloc(pstapriv->max_aid * sizeof(struct sta_info *));
+	if (!pstapriv->sta_aid)
+		goto exit;
+	pstapriv->aid_bmp_len = AID_BMP_LEN(pstapriv->max_aid);
+	pstapriv->sta_dz_bitmap = rtw_zmalloc(pstapriv->aid_bmp_len);
+	if (!pstapriv->sta_dz_bitmap)
+		goto exit;
+	pstapriv->tim_bitmap = rtw_zmalloc(pstapriv->aid_bmp_len);
+	if (!pstapriv->tim_bitmap)
+		goto exit;
 
 	_rtw_init_listhead(&pstapriv->asoc_list);
 	_rtw_init_listhead(&pstapriv->auth_list);
@@ -274,34 +291,54 @@ _func_enter_;
 	pstapriv->asoc_list_cnt = 0;
 	pstapriv->auth_list_cnt = 0;
 
-	pstapriv->auth_to = 3; // 3*2 = 6 sec 
+	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 = 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. */
 #ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-	pstapriv->expire_to = 3; // 3*2 = 6 sec
+	pstapriv->expire_to = 3; /* 3*2 = 6 sec */
 #else
-	pstapriv->expire_to = 60;// 60*2 = 120 sec = 2 min, expire after no any traffic.
-#endif	
+	pstapriv->expire_to = 60;/* 60*2 = 120 sec = 2 min, expire after no any traffic. */
+#endif
 #ifdef CONFIG_ATMEL_RC_PATCH
-	_rtw_memset(  pstapriv->atmel_rc_pattern, 0, ETH_ALEN);
-#endif	
+	_rtw_memset(pstapriv->atmel_rc_pattern, 0, ETH_ALEN);
+#endif
 	pstapriv->max_num_sta = NUM_STA;
-		
+
 #endif
-	
-_func_exit_;		
 
-	return _SUCCESS;
-	
+#if CONFIG_RTW_MACADDR_ACL
+	for (i = 0; i < RTW_ACL_PERIOD_NUM; i++)
+		rtw_macaddr_acl_init(adapter, i);
+#endif
+
+#if CONFIG_RTW_PRE_LINK_STA
+	rtw_pre_link_sta_ctl_init(pstapriv);
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	if (ret != _SUCCESS) {
+		if (pstapriv->pallocated_stainfo_buf)
+			rtw_vmfree(pstapriv->pallocated_stainfo_buf, sizeof(struct sta_info) * NUM_STA + 4);
+		#ifdef CONFIG_AP_MODE
+		if (pstapriv->sta_aid)
+			rtw_mfree(pstapriv->sta_aid, pstapriv->max_aid * sizeof(struct sta_info *));
+		if (pstapriv->sta_dz_bitmap)
+			rtw_mfree(pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+		#endif
+	}
+
+	return ret;
 }
 
 inline int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta)
 {
-	int offset = (((u8 *)sta) - stapriv->pstainfo_buf)/sizeof(struct sta_info);
+	int offset = (((u8 *)sta) - stapriv->pstainfo_buf) / sizeof(struct sta_info);
 
 	if (!stainfo_offset_valid(offset))
-		DBG_871X("%s invalid offset(%d), out of range!!!", __func__, offset);
+		RTW_INFO("%s invalid offset(%d), out of range!!!", __func__, offset);
 
 	return offset;
 }
@@ -309,7 +346,7 @@ inline int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta)
 inline struct sta_info *rtw_get_stainfo_by_offset(struct sta_priv *stapriv, int offset)
 {
 	if (!stainfo_offset_valid(offset))
-		DBG_871X("%s invalid offset(%d), out of range!!!", __func__, offset);
+		RTW_INFO("%s invalid offset(%d), out of range!!!", __func__, offset);
 
 	return (struct sta_info *)(stapriv->pstainfo_buf + offset * sizeof(struct sta_info));
 }
@@ -317,7 +354,6 @@ inline struct sta_info *rtw_get_stainfo_by_offset(struct sta_priv *stapriv, int
 void	_rtw_free_sta_xmit_priv_lock(struct sta_xmit_priv *psta_xmitpriv);
 void	_rtw_free_sta_xmit_priv_lock(struct sta_xmit_priv *psta_xmitpriv)
 {
-_func_enter_;
 
 	_rtw_spinlock_free(&psta_xmitpriv->lock);
 
@@ -325,73 +361,61 @@ _func_enter_;
 	_rtw_spinlock_free(&(psta_xmitpriv->bk_q.sta_pending.lock));
 	_rtw_spinlock_free(&(psta_xmitpriv->vi_q.sta_pending.lock));
 	_rtw_spinlock_free(&(psta_xmitpriv->vo_q.sta_pending.lock));
-_func_exit_;	
 }
 
 static void	_rtw_free_sta_recv_priv_lock(struct sta_recv_priv *psta_recvpriv)
 {
-_func_enter_;	
 
 	_rtw_spinlock_free(&psta_recvpriv->lock);
 
 	_rtw_spinlock_free(&(psta_recvpriv->defrag_q.lock));
 
-_func_exit_;
 
 }
 
 void rtw_mfree_stainfo(struct sta_info *psta);
 void rtw_mfree_stainfo(struct sta_info *psta)
 {
-_func_enter_;
 
-	if(&psta->lock != NULL)
-		 _rtw_spinlock_free(&psta->lock);
+	if (&psta->lock != NULL)
+		_rtw_spinlock_free(&psta->lock);
 
 	_rtw_free_sta_xmit_priv_lock(&psta->sta_xmitpriv);
 	_rtw_free_sta_recv_priv_lock(&psta->sta_recvpriv);
-	
-_func_exit_;	
+
 }
 
 
-// this function is used to free the memory of lock || sema for all stainfos
-void rtw_mfree_all_stainfo(struct sta_priv *pstapriv );
-void rtw_mfree_all_stainfo(struct sta_priv *pstapriv )
+/* this function is used to free the memory of lock || sema for all stainfos */
+void rtw_mfree_all_stainfo(struct sta_priv *pstapriv);
+void rtw_mfree_all_stainfo(struct sta_priv *pstapriv)
 {
 	_irqL	 irqL;
 	_list	*plist, *phead;
 	struct sta_info *psta = NULL;
-	
-_func_enter_;	
+
 
 	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
 	phead = get_list_head(&pstapriv->free_sta_queue);
 	plist = get_next(phead);
-		
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-	{
-		psta = LIST_CONTAINOR(plist, struct sta_info ,list);
+
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info , list);
 		plist = get_next(plist);
 
 		rtw_mfree_stainfo(psta);
 	}
-	
+
 	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-_func_exit_;	
 
 }
 
 void rtw_mfree_sta_priv_lock(struct	sta_priv *pstapriv);
 void rtw_mfree_sta_priv_lock(struct	sta_priv *pstapriv)
 {
-#ifdef CONFIG_AP_MODE
-	struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-#endif
-
-	 rtw_mfree_all_stainfo(pstapriv); //be done before free sta_hash_lock
+	rtw_mfree_all_stainfo(pstapriv); /* be done before free sta_hash_lock */
 
 	_rtw_spinlock_free(&pstapriv->free_sta_queue.lock);
 
@@ -402,62 +426,80 @@ void rtw_mfree_sta_priv_lock(struct	sta_priv *pstapriv)
 #ifdef CONFIG_AP_MODE
 	_rtw_spinlock_free(&pstapriv->asoc_list_lock);
 	_rtw_spinlock_free(&pstapriv->auth_list_lock);
-	_rtw_spinlock_free(&pacl_list->acl_node_q.lock);
 #endif
 
 }
 
 u32	_rtw_free_sta_priv(struct	sta_priv *pstapriv)
 {
-	_irqL 	irqL;
+	_irqL	irqL;
 	_list	*phead, *plist;
 	struct sta_info *psta = NULL;
 	struct recv_reorder_ctrl *preorder_ctrl;
-	int 	index;
+	int	index;
 
-_func_enter_;
-	if(pstapriv){
+	if (pstapriv) {
 
-		/*	delete all reordering_ctrl_timer		*/ 
+		/*	delete all reordering_ctrl_timer		*/
 		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-		for(index = 0; index < NUM_STA; index++)
-		{
+		for (index = 0; index < NUM_STA; index++) {
 			phead = &(pstapriv->sta_hash[index]);
 			plist = get_next(phead);
-			
-			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-			{
-				int i;	
-				psta = LIST_CONTAINOR(plist, struct sta_info ,hash_list);
+
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				int i;
+				psta = LIST_CONTAINOR(plist, struct sta_info , hash_list);
 				plist = get_next(plist);
 
-				for(i=0; i < 16 ; i++)
-				{
+				for (i = 0; i < 16 ; i++) {
 					preorder_ctrl = &psta->recvreorder_ctrl[i];
-					_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);	
+					_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
 				}
 			}
 		}
 		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 		/*===============================*/
-		
+
 		rtw_mfree_sta_priv_lock(pstapriv);
 
-		if(pstapriv->pallocated_stainfo_buf) {
-			rtw_vmfree(pstapriv->pallocated_stainfo_buf, sizeof(struct sta_info)*NUM_STA+4);
-		}
+#if CONFIG_RTW_MACADDR_ACL
+		for (index = 0; index < RTW_ACL_PERIOD_NUM; index++)
+			rtw_macaddr_acl_deinit(pstapriv->padapter, index);
+#endif
+
+#if CONFIG_RTW_PRE_LINK_STA
+		rtw_pre_link_sta_ctl_deinit(pstapriv);
+#endif
+
+		if (pstapriv->pallocated_stainfo_buf)
+			rtw_vmfree(pstapriv->pallocated_stainfo_buf, sizeof(struct sta_info) * NUM_STA + 4);
+		#ifdef CONFIG_AP_MODE
+		if (pstapriv->sta_aid)
+			rtw_mfree(pstapriv->sta_aid, pstapriv->max_aid * sizeof(struct sta_info *));
+		if (pstapriv->sta_dz_bitmap)
+			rtw_mfree(pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+		if (pstapriv->tim_bitmap)
+			rtw_mfree(pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
+		#endif
 	}
-	
-_func_exit_;
+
 	return _SUCCESS;
 }
 
 
-//struct	sta_info *rtw_alloc_stainfo(_queue *pfree_sta_queue, unsigned char *hwaddr)
-struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr) 
-{	
+static void rtw_init_recv_timer(struct recv_reorder_ctrl *preorder_ctrl)
+{
+	_adapter *padapter = preorder_ctrl->padapter;
+
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
+	rtw_init_timer(&(preorder_ctrl->reordering_ctrl_timer), padapter, rtw_reordering_ctrl_timeout_handler, preorder_ctrl);
+#endif
+}
+
+/* struct	sta_info *rtw_alloc_stainfo(_queue *pfree_sta_queue, unsigned char *hwaddr) */
+struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, const u8 *hwaddr)
+{
 	_irqL irqL, irqL2;
-	uint tmp_aid;
 	s32	index;
 	_list	*phash_list;
 	struct sta_info	*psta;
@@ -465,92 +507,78 @@ struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr)
 	struct recv_reorder_ctrl *preorder_ctrl;
 	int i = 0;
 	u16  wRxSeqInitialValue = 0xffff;
-	
-_func_enter_;	
+
 
 	pfree_sta_queue = &pstapriv->free_sta_queue;
 
-	//_enter_critical_bh(&(pfree_sta_queue->lock), &irqL);
+	/* _enter_critical_bh(&(pfree_sta_queue->lock), &irqL); */
 	_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
-	if (_rtw_queue_empty(pfree_sta_queue) == _TRUE)
-	{
-		//_exit_critical_bh(&(pfree_sta_queue->lock), &irqL);
+	if (_rtw_queue_empty(pfree_sta_queue) == _TRUE) {
+		/* _exit_critical_bh(&(pfree_sta_queue->lock), &irqL); */
 		_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
 		psta = NULL;
-	}
-	else
-	{
+	} else {
 		psta = LIST_CONTAINOR(get_next(&pfree_sta_queue->queue), struct sta_info, list);
-		
+
 		rtw_list_delete(&(psta->list));
 
-		//_exit_critical_bh(&(pfree_sta_queue->lock), &irqL);
-		
-		tmp_aid = psta->aid;	
-	
+		/* _exit_critical_bh(&(pfree_sta_queue->lock), &irqL); */
 		_rtw_init_stainfo(psta);
 
 		psta->padapter = pstapriv->padapter;
 
-		_rtw_memcpy(psta->hwaddr, hwaddr, ETH_ALEN);
+		_rtw_memcpy(psta->cmn.mac_addr, hwaddr, ETH_ALEN);
 
 		index = wifi_mac_hash(hwaddr);
 
-		RT_TRACE(_module_rtl871x_sta_mgt_c_,_drv_info_,("rtw_alloc_stainfo: index  = %x", index));
 
-		if(index >= NUM_STA){
-			RT_TRACE(_module_rtl871x_sta_mgt_c_,_drv_err_,("ERROR=> rtw_alloc_stainfo: index >= NUM_STA"));
-			psta= NULL;	
+		if (index >= NUM_STA) {
+			psta = NULL;
 			goto exit;
 		}
 		phash_list = &(pstapriv->sta_hash[index]);
 
-		//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
 
 		rtw_list_insert_tail(&psta->hash_list, phash_list);
 
-		pstapriv->asoc_sta_count ++ ;
+		pstapriv->asoc_sta_count++;
 
-		//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
 
-// Commented by Albert 2009/08/13
-// 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.
+		/* Commented by Albert 2009/08/13
+		 * 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++ )
-		{
-                     _rtw_memcpy( &psta->sta_recvpriv.rxcache.tid_rxseq[ i ], &wRxSeqInitialValue, 2 );
+		for (i = 0; i < 16; i++) {
+			_rtw_memcpy(&psta->sta_recvpriv.rxcache.tid_rxseq[i], &wRxSeqInitialValue, 2);
+			_rtw_memcpy(&psta->sta_recvpriv.bmc_tid_rxseq[i], &wRxSeqInitialValue, 2);
+			_rtw_memset(&psta->sta_recvpriv.rxcache.iv[i], 0, sizeof(psta->sta_recvpriv.rxcache.iv[i]));
 		}
 
-		RT_TRACE(_module_rtl871x_sta_mgt_c_,_drv_info_,("alloc number_%d stainfo  with hwaddr = %x %x %x %x %x %x  \n", 
-		pstapriv->asoc_sta_count , hwaddr[0], hwaddr[1], hwaddr[2],hwaddr[3],hwaddr[4],hwaddr[5]));
-
-		init_addba_retry_timer(pstapriv->padapter, psta);
+		rtw_init_timer(&psta->addba_retry_timer, psta->padapter, addba_timer_hdl, psta);
 #ifdef CONFIG_IEEE80211W
-		init_dot11w_expire_timer(pstapriv->padapter, psta);
+		rtw_init_timer(&psta->dot11w_expire_timer, psta->padapter, sa_query_timer_hdl, psta);
 #endif /* CONFIG_IEEE80211W */
 #ifdef CONFIG_TDLS
 		rtw_init_tdls_timer(pstapriv->padapter, psta);
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-		//for A-MPDU Rx reordering buffer control
-		for(i=0; i < 16 ; i++)
-		{
+		/* 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->tid = i;
 			preorder_ctrl->enable = _FALSE;
-		
 			preorder_ctrl->indicate_seq = 0xffff;
 			#ifdef DBG_RX_SEQ
-			DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d\n", __FUNCTION__, __LINE__,
-				preorder_ctrl->indicate_seq);
+			RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_CLEAR indicate_seq:%d\n"
+				, FUNC_ADPT_ARG(pstapriv->padapter), i, preorder_ctrl->indicate_seq);
 			#endif
-			preorder_ctrl->wend_b= 0xffff;       
-			//preorder_ctrl->wsize_b = (NR_RECVBUFF-2);
-			preorder_ctrl->wsize_b = 64;//64;
+			preorder_ctrl->wend_b = 0xffff;
+			/* preorder_ctrl->wsize_b = (NR_RECVBUFF-2); */
+			preorder_ctrl->wsize_b = 64;/* 64; */
 			preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
 
 			_rtw_init_queue(&preorder_ctrl->pending_recvframe_queue);
@@ -559,57 +587,69 @@ _func_enter_;
 		}
 
 
-		//init for DM
-		psta->rssi_stat.UndecoratedSmoothedPWDB = (-1);
-		psta->rssi_stat.UndecoratedSmoothedCCK = (-1);
+		/* init for DM */
+		psta->cmn.rssi_stat.rssi = (-1);
+		psta->cmn.rssi_stat.rssi_cck = (-1);
+		psta->cmn.rssi_stat.rssi_ofdm = (-1);
 #ifdef CONFIG_ATMEL_RC_PATCH
 		psta->flag_atmel_rc = 0;
 #endif
 		/* init for the sequence number of received management frame */
 		psta->RxMgmtFrameSeqNum = 0xffff;
-		psta->ra_rpt_linked = _FALSE;
 
-		//alloc mac id for non-bc/mc station,
 		rtw_alloc_macid(pstapriv->padapter, psta);
 
 	}
-	
+
 exit:
 
 	_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
 
-_func_exit_;
-
-	return psta;
 
+	if (psta)
+		rtw_mi_update_iface_status(&(pstapriv->padapter->mlmepriv), 0);
 
+	return psta;
 }
 
 
-// using pstapriv->sta_hash_lock to protect
+/* using pstapriv->sta_hash_lock to protect */
 u32	rtw_free_stainfo(_adapter *padapter , struct sta_info *psta)
-{	
+{
 	int i;
 	_irqL irqL0;
 	_queue *pfree_sta_queue;
 	struct recv_reorder_ctrl *preorder_ctrl;
 	struct	sta_xmit_priv	*pstaxmitpriv;
-	struct	xmit_priv	*pxmitpriv= &padapter->xmitpriv;
+	struct	xmit_priv	*pxmitpriv = &padapter->xmitpriv;
 	struct	sta_priv *pstapriv = &padapter->stapriv;
 	struct hw_xmit *phwxmit;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
 	int pending_qcnt[4];
+	u8 is_pre_link_sta = _FALSE;
 
-_func_enter_;	
-	
 	if (psta == NULL)
 		goto exit;
 
-	_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
-	rtw_list_delete(&psta->hash_list);
-	RT_TRACE(_module_rtl871x_sta_mgt_c_,_drv_err_,("\n free number_%d stainfo  with hwaddr = 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x  \n",pstapriv->asoc_sta_count , psta->hwaddr[0], psta->hwaddr[1], psta->hwaddr[2],psta->hwaddr[3],psta->hwaddr[4],psta->hwaddr[5]));
-	pstapriv->asoc_sta_count --;
-	_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
+#ifdef CONFIG_RTW_80211K
+	rm_post_event(padapter, RM_ID_FOR_ALL(psta->cmn.aid), RM_EV_cancel);
+#endif
 
+	is_pre_link_sta = rtw_is_pre_link_sta(pstapriv, psta->cmn.mac_addr);
+
+	if (is_pre_link_sta == _FALSE) {
+		_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
+		rtw_list_delete(&psta->hash_list);
+		pstapriv->asoc_sta_count--;
+		_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
+		rtw_mi_update_iface_status(&(padapter->mlmepriv), 0);
+	} else {
+		_enter_critical_bh(&psta->lock, &irqL0);
+		psta->state = WIFI_FW_PRE_LINK;
+		_exit_critical_bh(&psta->lock, &irqL0);
+	}
 
 	_enter_critical_bh(&psta->lock, &irqL0);
 	psta->state &= ~_FW_LINKED;
@@ -619,64 +659,64 @@ _func_enter_;
 
 
 	pstaxmitpriv = &psta->sta_xmitpriv;
-	
-	//rtw_list_delete(&psta->sleep_list);
-	
-	//rtw_list_delete(&psta->wakeup_list);
-	
+
+	/* rtw_list_delete(&psta->sleep_list); */
+
+	/* rtw_list_delete(&psta->wakeup_list); */
+
 	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
-	
+
 	rtw_free_xmitframe_queue(pxmitpriv, &psta->sleep_q);
 	psta->sleepq_len = 0;
-	
-	//vo
-	//_enter_critical_bh(&(pxmitpriv->vo_pending.lock), &irqL0);
-	rtw_free_xmitframe_queue( pxmitpriv, &pstaxmitpriv->vo_q.sta_pending);
+
+	/* vo */
+	/* _enter_critical_bh(&(pxmitpriv->vo_pending.lock), &irqL0); */
+	rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->vo_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
 	phwxmit = pxmitpriv->hwxmits;
 	phwxmit->accnt -= pstaxmitpriv->vo_q.qcnt;
 	pending_qcnt[0] = pstaxmitpriv->vo_q.qcnt;
 	pstaxmitpriv->vo_q.qcnt = 0;
-	//_exit_critical_bh(&(pxmitpriv->vo_pending.lock), &irqL0);
+	/* _exit_critical_bh(&(pxmitpriv->vo_pending.lock), &irqL0); */
 
-	//vi
-	//_enter_critical_bh(&(pxmitpriv->vi_pending.lock), &irqL0);
-	rtw_free_xmitframe_queue( pxmitpriv, &pstaxmitpriv->vi_q.sta_pending);
+	/* vi */
+	/* _enter_critical_bh(&(pxmitpriv->vi_pending.lock), &irqL0); */
+	rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->vi_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
-	phwxmit = pxmitpriv->hwxmits+1;
+	phwxmit = pxmitpriv->hwxmits + 1;
 	phwxmit->accnt -= pstaxmitpriv->vi_q.qcnt;
 	pending_qcnt[1] = pstaxmitpriv->vi_q.qcnt;
 	pstaxmitpriv->vi_q.qcnt = 0;
-	//_exit_critical_bh(&(pxmitpriv->vi_pending.lock), &irqL0);
+	/* _exit_critical_bh(&(pxmitpriv->vi_pending.lock), &irqL0); */
 
-	//be
-	//_enter_critical_bh(&(pxmitpriv->be_pending.lock), &irqL0);
-	rtw_free_xmitframe_queue( pxmitpriv, &pstaxmitpriv->be_q.sta_pending);
+	/* be */
+	/* _enter_critical_bh(&(pxmitpriv->be_pending.lock), &irqL0); */
+	rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->be_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
-	phwxmit = pxmitpriv->hwxmits+2;
+	phwxmit = pxmitpriv->hwxmits + 2;
 	phwxmit->accnt -= pstaxmitpriv->be_q.qcnt;
 	pending_qcnt[2] = pstaxmitpriv->be_q.qcnt;
 	pstaxmitpriv->be_q.qcnt = 0;
-	//_exit_critical_bh(&(pxmitpriv->be_pending.lock), &irqL0);
-	
-	//bk
-	//_enter_critical_bh(&(pxmitpriv->bk_pending.lock), &irqL0);
-	rtw_free_xmitframe_queue( pxmitpriv, &pstaxmitpriv->bk_q.sta_pending);
+	/* _exit_critical_bh(&(pxmitpriv->be_pending.lock), &irqL0); */
+
+	/* bk */
+	/* _enter_critical_bh(&(pxmitpriv->bk_pending.lock), &irqL0); */
+	rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->bk_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
-	phwxmit = pxmitpriv->hwxmits+3;
+	phwxmit = pxmitpriv->hwxmits + 3;
 	phwxmit->accnt -= pstaxmitpriv->bk_q.qcnt;
 	pending_qcnt[3] = pstaxmitpriv->bk_q.qcnt;
 	pstaxmitpriv->bk_q.qcnt = 0;
-	//_exit_critical_bh(&(pxmitpriv->bk_pending.lock), &irqL0);
+	/* _exit_critical_bh(&(pxmitpriv->bk_pending.lock), &irqL0); */
 
 	rtw_os_wake_queue_at_free_stainfo(padapter, pending_qcnt);
 
 	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
-	
-	
-	// re-init sta_info; 20061114 // will be init in alloc_stainfo
-	//_rtw_init_sta_xmit_priv(&psta->sta_xmitpriv);
-	//_rtw_init_sta_recv_priv(&psta->sta_recvpriv);
+
+
+	/* re-init sta_info; 20061114 */ /* will be init in alloc_stainfo */
+	/* _rtw_init_sta_xmit_priv(&psta->sta_xmitpriv); */
+	/* _rtw_init_sta_recv_priv(&psta->sta_recvpriv); */
 #ifdef CONFIG_IEEE80211W
 	_cancel_timer_ex(&psta->dot11w_expire_timer);
 #endif /* CONFIG_IEEE80211W */
@@ -684,66 +724,64 @@ _func_enter_;
 
 #ifdef CONFIG_TDLS
 	psta->tdls_sta_state = TDLS_STATE_NONE;
-	rtw_free_tdls_timer(psta);
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-	//for A-MPDU Rx reordering buffer control, cancel reordering_ctrl_timer
-	for(i=0; i < 16 ; i++)
-	{
+	/* for A-MPDU Rx reordering buffer control, cancel reordering_ctrl_timer */
+	for (i = 0; i < 16 ; i++) {
 		_irqL irqL;
 		_list	*phead, *plist;
 		union recv_frame *prframe;
 		_queue *ppending_recvframe_queue;
 		_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
-	
+
 		preorder_ctrl = &psta->recvreorder_ctrl[i];
-		
-		_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);		
 
-		
+		_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
+
+
 		ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
 
 		_enter_critical_bh(&ppending_recvframe_queue->lock, &irqL);
 
-		phead = 	get_list_head(ppending_recvframe_queue);
+		phead =	get_list_head(ppending_recvframe_queue);
 		plist = get_next(phead);
-		
-		while(!rtw_is_list_empty(phead))
-		{	
+
+		while (!rtw_is_list_empty(phead)) {
 			prframe = LIST_CONTAINOR(plist, union recv_frame, u);
-			
+
 			plist = get_next(plist);
-			
+
 			rtw_list_delete(&(prframe->u.hdr.list));
 
 			rtw_free_recvframe(prframe, pfree_recv_queue);
 		}
 
 		_exit_critical_bh(&ppending_recvframe_queue->lock, &irqL);
-		
+
 	}
 
-	if (!(psta->state & WIFI_AP_STATE))
+	if (!((psta->state & WIFI_AP_STATE) || MacAddr_isBcst(psta->cmn.mac_addr)) && is_pre_link_sta == _FALSE)
 		rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _FALSE);
-			
 
-	//release mac id for non-bc/mc station,
-	rtw_release_macid(pstapriv->padapter, psta);
+
+	/* release mac id for non-bc/mc station, */
+	if (is_pre_link_sta == _FALSE)
+		rtw_release_macid(pstapriv->padapter, psta);
 
 #ifdef CONFIG_AP_MODE
 
-/*
-	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL0);
-	rtw_list_delete(&psta->asoc_list);	
-	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL0);
-*/
+	/*
+		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL0);
+		rtw_list_delete(&psta->asoc_list);
+		_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL0);
+	*/
 	_enter_critical_bh(&pstapriv->auth_list_lock, &irqL0);
 	if (!rtw_is_list_empty(&psta->auth_list)) {
 		rtw_list_delete(&psta->auth_list);
 		pstapriv->auth_list_cnt--;
 	}
 	_exit_critical_bh(&pstapriv->auth_list_lock, &irqL0);
-	
+
 	psta->expire_to = 0;
 #ifdef CONFIG_ATMEL_RC_PATCH
 	psta->flag_atmel_rc = 0;
@@ -760,45 +798,44 @@ _func_enter_;
 	psta->has_legacy_ac = 0;
 
 #ifdef CONFIG_NATIVEAP_MLME
-	
-	pstapriv->sta_dz_bitmap &=~BIT(psta->aid);
-	pstapriv->tim_bitmap &=~BIT(psta->aid);	
 
-	//rtw_indicate_sta_disassoc_event(padapter, psta);
+	if (pmlmeinfo->state == _HW_STATE_AP_) {
+		rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
+		rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-	if ((psta->aid >0)&&(pstapriv->sta_aid[psta->aid - 1] == psta))
-	{
-		pstapriv->sta_aid[psta->aid - 1] = NULL;
-		psta->aid = 0;
-	}	
-	
-#endif	// CONFIG_NATIVEAP_MLME	
+		/* rtw_indicate_sta_disassoc_event(padapter, psta); */
+
+		if ((psta->cmn.aid > 0) && (pstapriv->sta_aid[psta->cmn.aid - 1] == psta)) {
+			pstapriv->sta_aid[psta->cmn.aid - 1] = NULL;
+			psta->cmn.aid = 0;
+		}
+	}
+
+#endif /* CONFIG_NATIVEAP_MLME	 */
 
 #ifdef CONFIG_TX_MCAST2UNI
 	psta->under_exist_checking = 0;
-#endif	// CONFIG_TX_MCAST2UNI
+#endif /* CONFIG_TX_MCAST2UNI */
 
-#endif	// CONFIG_AP_MODE	
+#endif /* CONFIG_AP_MODE	 */
 
 	rtw_st_ctl_deinit(&psta->st_ctl);
 
-	 _rtw_spinlock_free(&psta->lock);
+	if (is_pre_link_sta == _FALSE) {
+		_rtw_spinlock_free(&psta->lock);
 
-	//_enter_critical_bh(&(pfree_sta_queue->lock), &irqL0);
-	_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);	
-	rtw_list_insert_tail(&psta->list, get_list_head(pfree_sta_queue));
-	_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
-	//_exit_critical_bh(&(pfree_sta_queue->lock), &irqL0);
+		/* _enter_critical_bh(&(pfree_sta_queue->lock), &irqL0); */
+		_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
+		rtw_list_insert_tail(&psta->list, get_list_head(pfree_sta_queue));
+		_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
+		/* _exit_critical_bh(&(pfree_sta_queue->lock), &irqL0); */
+	}
 
 exit:
-	
-_func_exit_;	
-
 	return _SUCCESS;
-	
 }
 
-// free all stainfo which in sta_hash[all]
+/* free all stainfo which in sta_hash[all] */
 void rtw_free_all_stainfo(_adapter *padapter)
 {
 	_irqL	 irqL;
@@ -806,59 +843,52 @@ void rtw_free_all_stainfo(_adapter *padapter)
 	s32	index;
 	struct sta_info *psta = NULL;
 	struct	sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info* pbcmc_stainfo =rtw_get_bcmc_stainfo( padapter);
+	struct sta_info *pbcmc_stainfo = rtw_get_bcmc_stainfo(padapter);
 	u8 free_sta_num = 0;
 	char free_sta_list[NUM_STA];
 	int stainfo_offset;
-	
-_func_enter_;	
 
-	if(pstapriv->asoc_sta_count==1)
+
+	if (pstapriv->asoc_sta_count == 1)
 		goto exit;
 
 	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-	for(index=0; index< NUM_STA; index++)
-	{
+	for (index = 0; index < NUM_STA; index++) {
 		phead = &(pstapriv->sta_hash[index]);
 		plist = get_next(phead);
-		
-		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-		{
-			psta = LIST_CONTAINOR(plist, struct sta_info ,hash_list);
+
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info , hash_list);
 
 			plist = get_next(plist);
 
-			if(pbcmc_stainfo!=psta)
-			{
-				rtw_list_delete(&psta->hash_list);
-				//rtw_free_stainfo(padapter , psta);
+			if (pbcmc_stainfo != psta) {
+				if (rtw_is_pre_link_sta(pstapriv, psta->cmn.mac_addr) == _FALSE)
+					rtw_list_delete(&psta->hash_list);
+
 				stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
-				if (stainfo_offset_valid(stainfo_offset)) {
+				if (stainfo_offset_valid(stainfo_offset))
 					free_sta_list[free_sta_num++] = stainfo_offset;
-				}
-			}	
-			
+			}
+
 		}
 	}
-	
+
 	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
 
-	for (index = 0; index < free_sta_num; index++) 
-	{
+	for (index = 0; index < free_sta_num; index++) {
 		psta = rtw_get_stainfo_by_offset(pstapriv, free_sta_list[index]);
 		rtw_free_stainfo(padapter , psta);
 	}
-	
-exit:	
-	
-_func_exit_;	
 
+exit:
+	return;
 }
 
 /* any station allocated can be searched by hash list */
-struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, u8 *hwaddr)
+struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, const u8 *hwaddr)
 {
 
 	_irqL	 irqL;
@@ -866,156 +896,435 @@ struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, u8 *hwaddr)
 	_list	*plist, *phead;
 
 	struct sta_info *psta = NULL;
-	
+
 	u32	index;
 
-	u8 *addr;
+	const u8 *addr;
 
-	u8 bc_addr[ETH_ALEN] = {0xff,0xff,0xff,0xff,0xff,0xff};
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 
-_func_enter_;
 
-	if(hwaddr==NULL)
+	if (hwaddr == NULL)
 		return NULL;
-		
-	if(IS_MCAST(hwaddr))
-	{
+
+	if (IS_MCAST(hwaddr))
 		addr = bc_addr;
-	}
 	else
-	{
 		addr = hwaddr;
-	}
 
 	index = wifi_mac_hash(addr);
 
 	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-	
+
 	phead = &(pstapriv->sta_hash[index]);
 	plist = get_next(phead);
 
 
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-	{
-	
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+
 		psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
-		
-		if ((_rtw_memcmp(psta->hwaddr, addr, ETH_ALEN))== _TRUE) 
-		{ // if found the matched address
+
+		if ((_rtw_memcmp(psta->cmn.mac_addr, addr, ETH_ALEN)) == _TRUE) {
+			/* if found the matched address */
 			break;
 		}
-		psta=NULL;
+		psta = NULL;
 		plist = get_next(plist);
 	}
 
 	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-_func_exit_;	
 	return psta;
-	
+
 }
 
-u32 rtw_init_bcmc_stainfo(_adapter* padapter)
+u32 rtw_init_bcmc_stainfo(_adapter *padapter)
 {
 
-	struct sta_info 	*psta;
+	struct sta_info	*psta;
 	struct tx_servq	*ptxservq;
-	u32 res=_SUCCESS;
-	NDIS_802_11_MAC_ADDRESS	bcast_addr= {0xff,0xff,0xff,0xff,0xff,0xff};
-	
+	u32 res = _SUCCESS;
+	NDIS_802_11_MAC_ADDRESS	bcast_addr = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
 	struct	sta_priv *pstapriv = &padapter->stapriv;
-	//_queue	*pstapending = &padapter->xmitpriv.bm_pending; 
-	
-_func_enter_;
+	/* _queue	*pstapending = &padapter->xmitpriv.bm_pending; */
+
 
 	psta = rtw_alloc_stainfo(pstapriv, bcast_addr);
-	
-	if(psta==NULL){
-		res=_FAIL;
-		RT_TRACE(_module_rtl871x_sta_mgt_c_,_drv_err_,("rtw_alloc_stainfo fail"));
+
+	if (psta == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 #ifdef CONFIG_BEAMFORMING
-	psta->txbf_gid = 63;
-	psta->txbf_paid = 0;
+	psta->cmn.bf_info.g_id = 63;
+	psta->cmn.bf_info.p_aid = 0;
 #endif
-	ptxservq= &(psta->sta_xmitpriv.be_q);
 
-/*
-	_enter_critical(&pstapending->lock, &irqL0);
+	ptxservq = &(psta->sta_xmitpriv.be_q);
+
+	/*
+		_enter_critical(&pstapending->lock, &irqL0);
+
+		if (rtw_is_list_empty(&ptxservq->tx_pending))
+			rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(pstapending));
 
-	if (rtw_is_list_empty(&ptxservq->tx_pending))
-		rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(pstapending));
+		_exit_critical(&pstapending->lock, &irqL0);
+	*/
 
-	_exit_critical(&pstapending->lock, &irqL0);
-*/
-	
 exit:
-_func_exit_;		
 	return _SUCCESS;
 
 }
 
 
-struct sta_info* rtw_get_bcmc_stainfo(_adapter* padapter)
+struct sta_info *rtw_get_bcmc_stainfo(_adapter *padapter)
 {
-	struct sta_info 	*psta;
-	struct sta_priv 	*pstapriv = &padapter->stapriv;
-	u8 bc_addr[ETH_ALEN] = {0xff,0xff,0xff,0xff,0xff,0xff};
-_func_enter_;
-	 psta = rtw_get_stainfo(pstapriv, bc_addr);
-_func_exit_;		 
+	struct sta_info	*psta;
+	struct sta_priv	*pstapriv = &padapter->stapriv;
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	psta = rtw_get_stainfo(pstapriv, bc_addr);
 	return psta;
 
 }
 
-u8 rtw_access_ctrl(_adapter *padapter, u8 *mac_addr)
+#ifdef CONFIG_AP_MODE
+u16 rtw_aid_alloc(_adapter *adapter, struct sta_info *sta)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u16 aid, i, used_cnt = 0;
+
+	for (i = 0; i < stapriv->max_aid; i++) {
+		aid = ((i + stapriv->started_aid - 1) % stapriv->max_aid) + 1;
+		if (stapriv->sta_aid[aid - 1] == NULL)
+			break;
+		if (++used_cnt >= stapriv->max_num_sta)
+			break;
+	}
+
+	/* check for aid limit and assoc limit  */
+	if (i >= stapriv->max_aid || used_cnt >= stapriv->max_num_sta)
+		aid = 0;
+
+	sta->cmn.aid = aid;
+	if (aid) {
+		stapriv->sta_aid[aid - 1] = sta;
+		if (stapriv->rr_aid)
+			stapriv->started_aid = (aid % stapriv->max_aid) + 1;
+	}
+
+	return aid;
+}
+
+void dump_aid_status(void *sel, _adapter *adapter)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u8 *aid_bmp;
+	u16 i, used_cnt = 0;
+
+	aid_bmp = rtw_zmalloc(stapriv->aid_bmp_len);
+	if (!aid_bmp)
+		return;
+
+	for (i = 1; i <= stapriv->max_aid; i++) {
+		if (stapriv->sta_aid[i - 1]) {
+			aid_bmp[i / 8] |= BIT(i % 8);
+			++used_cnt;
+		}
+	}
+
+	RTW_PRINT_SEL(sel, "used_cnt:%u/%u\n", used_cnt, stapriv->max_aid);
+	RTW_MAP_DUMP_SEL(sel, "aid_map:", aid_bmp, stapriv->aid_bmp_len);
+	RTW_PRINT_SEL(sel, "\n");
+
+	RTW_PRINT_SEL(sel, "%-2s %-11s\n", "rr", "started_aid");
+	RTW_PRINT_SEL(sel, "%2d %11d\n", stapriv->rr_aid, stapriv->started_aid);
+
+	rtw_mfree(aid_bmp, stapriv->aid_bmp_len);
+}
+#endif /* CONFIG_AP_MODE */
+
+#if CONFIG_RTW_MACADDR_ACL
+const char *const _acl_period_str[RTW_ACL_PERIOD_NUM] = {
+	"DEV",
+	"BSS",
+};
+
+const char *const _acl_mode_str[RTW_ACL_MODE_MAX] = {
+	"DISABLED",
+	"ACCEPT_UNLESS_LISTED",
+	"DENY_UNLESS_LISTED",
+};
+
+u8 _rtw_access_ctrl(_adapter *adapter, u8 period, const u8 *mac_addr)
 {
 	u8 res = _TRUE;
-#ifdef  CONFIG_AP_MODE
 	_irqL irqL;
-	_list	*plist, *phead;
-	struct rtw_wlan_acl_node *paclnode;
+	_list *list, *head;
+	struct rtw_wlan_acl_node *acl_node;
 	u8 match = _FALSE;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-	_queue	*pacl_node_q =&pacl_list->acl_node_q;
-	
-	_enter_critical_bh(&(pacl_node_q->lock), &irqL);
-	phead = get_list_head(pacl_node_q);
-	plist = get_next(phead);		
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-	{
-		paclnode = LIST_CONTAINOR(plist, struct rtw_wlan_acl_node, list);
-		plist = get_next(plist);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+	_queue	*acl_node_q;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
+	if (acl->mode != RTW_ACL_MODE_ACCEPT_UNLESS_LISTED
+		&& acl->mode != RTW_ACL_MODE_DENY_UNLESS_LISTED)
+		goto exit;
+
+	_enter_critical_bh(&(acl_node_q->lock), &irqL);
+	head = get_list_head(acl_node_q);
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
+		list = get_next(list);
 
-		if(_rtw_memcmp(paclnode->addr, mac_addr, ETH_ALEN))
-		{
-			if(paclnode->valid == _TRUE)
-			{
+		if (_rtw_memcmp(acl_node->addr, mac_addr, ETH_ALEN)) {
+			if (acl_node->valid == _TRUE) {
 				match = _TRUE;
 				break;
 			}
-		}		
-	}	
-	_exit_critical_bh(&(pacl_node_q->lock), &irqL);
-	
-
-	if(pacl_list->mode == 1)//accept unless in deny list
-	{
-		res = (match == _TRUE) ?  _FALSE:_TRUE;
-	}	
-	else if(pacl_list->mode == 2)//deny unless in accept list
-	{
-		res = (match == _TRUE) ?  _TRUE:_FALSE;
+		}
 	}
-	else
-	{
-		 res = _TRUE;
-	}		
-	
-#endif
+	_exit_critical_bh(&(acl_node_q->lock), &irqL);
 
+	if (acl->mode == RTW_ACL_MODE_ACCEPT_UNLESS_LISTED)
+		res = (match == _TRUE) ?  _FALSE : _TRUE;
+	else /* RTW_ACL_MODE_DENY_UNLESS_LISTED */
+		res = (match == _TRUE) ?  _TRUE : _FALSE;
+
+exit:
 	return res;
+}
+
+u8 rtw_access_ctrl(_adapter *adapter, const u8 *mac_addr)
+{
+	int i;
+
+	for (i = 0; i < RTW_ACL_PERIOD_NUM; i++)
+		if (_rtw_access_ctrl(adapter, i, mac_addr) == _FALSE)
+			return _FALSE;
+
+	return _TRUE;
+}
+
+void dump_macaddr_acl(void *sel, _adapter *adapter)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+	int i, j;
+
+	for (j = 0; j < RTW_ACL_PERIOD_NUM; j++) {
+		RTW_PRINT_SEL(sel, "period:%s(%d)\n", acl_period_str(j), j);
+
+		acl = &stapriv->acl_list[j];
+		RTW_PRINT_SEL(sel, "mode:%s(%d)\n", acl_mode_str(acl->mode), acl->mode);
+		RTW_PRINT_SEL(sel, "num:%d/%d\n", acl->num, NUM_ACL);
+		for (i = 0; i < NUM_ACL; i++) {
+			if (acl->aclnode[i].valid == _FALSE)
+				continue;
+			RTW_PRINT_SEL(sel, MAC_FMT"\n", MAC_ARG(acl->aclnode[i].addr));
+		}
+		RTW_PRINT_SEL(sel, "\n");
+	}
+}
+#endif /* CONFIG_RTW_MACADDR_ACL */
+
+bool rtw_is_pre_link_sta(struct sta_priv *stapriv, u8 *addr)
+{
+#if CONFIG_RTW_PRE_LINK_STA
+	struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
+	struct sta_info *sta = NULL;
+	u8 exist = _FALSE;
+	int i;
+	_irqL irqL;
+
+	_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+	for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
+		if (pre_link_sta_ctl->node[i].valid == _TRUE
+			&& _rtw_memcmp(pre_link_sta_ctl->node[i].addr, addr, ETH_ALEN) == _TRUE
+		) {
+			exist = _TRUE;
+			break;
+		}
+	}
+	_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+
+	return exist;
+#else
+	return _FALSE;
+#endif
+}
+
+#if CONFIG_RTW_PRE_LINK_STA
+struct sta_info *rtw_pre_link_sta_add(struct sta_priv *stapriv, u8 *hwaddr)
+{
+	struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
+	struct pre_link_sta_node_t *node = NULL;
+	struct sta_info *sta = NULL;
+	u8 exist = _FALSE;
+	int i;
+	_irqL irqL;
+
+	if (rtw_check_invalid_mac_address(hwaddr, _FALSE) == _TRUE)
+		goto exit;
+
+	_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+	for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
+		if (pre_link_sta_ctl->node[i].valid == _TRUE
+			&& _rtw_memcmp(pre_link_sta_ctl->node[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			node = &pre_link_sta_ctl->node[i];
+			exist = _TRUE;
+			break;
+		}
+
+		if (node == NULL && pre_link_sta_ctl->node[i].valid == _FALSE)
+			node = &pre_link_sta_ctl->node[i];
+	}
+
+	if (exist == _FALSE && node) {
+		_rtw_memcpy(node->addr, hwaddr, ETH_ALEN);
+		node->valid = _TRUE;
+		pre_link_sta_ctl->num++;
+	}
+	_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+
+	if (node == NULL)
+		goto exit;
+
+	sta = rtw_get_stainfo(stapriv, hwaddr);
+	if (sta)
+		goto odm_hook;
+
+	sta = rtw_alloc_stainfo(stapriv, hwaddr);
+	if (!sta)
+		goto exit;
+
+	sta->state = WIFI_FW_PRE_LINK;
+
+odm_hook:
+	rtw_hal_set_odm_var(stapriv->padapter, HAL_ODM_STA_INFO, sta, _TRUE);
+
+exit:
+	return sta;
+}
+
+void rtw_pre_link_sta_del(struct sta_priv *stapriv, u8 *hwaddr)
+{
+	struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
+	struct pre_link_sta_node_t *node = NULL;
+	struct sta_info *sta = NULL;
+	u8 exist = _FALSE;
+	int i;
+	_irqL irqL;
+
+	if (rtw_check_invalid_mac_address(hwaddr, _FALSE) == _TRUE)
+		goto exit;
+
+	_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+	for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
+		if (pre_link_sta_ctl->node[i].valid == _TRUE
+			&& _rtw_memcmp(pre_link_sta_ctl->node[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			node = &pre_link_sta_ctl->node[i];
+			exist = _TRUE;
+			break;
+		}
+	}
+
+	if (exist == _TRUE && node) {
+		node->valid = _FALSE;
+		pre_link_sta_ctl->num--;
+	}
+	_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+
+	if (exist == _FALSE)
+		goto exit;
 
+	sta = rtw_get_stainfo(stapriv, hwaddr);
+	if (!sta)
+		goto exit;
+
+	if (sta->state == WIFI_FW_PRE_LINK)
+		rtw_free_stainfo(stapriv->padapter, sta);
+
+exit:
+	return;
+}
+
+void rtw_pre_link_sta_ctl_reset(struct sta_priv *stapriv)
+{
+	struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
+	struct pre_link_sta_node_t *node = NULL;
+	struct sta_info *sta = NULL;
+	int i, j = 0;
+	_irqL irqL;
+
+	u8 addrs[RTW_PRE_LINK_STA_NUM][ETH_ALEN];
+
+	_rtw_memset(addrs, 0, RTW_PRE_LINK_STA_NUM * ETH_ALEN);
+
+	_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+	for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
+		if (pre_link_sta_ctl->node[i].valid == _FALSE)
+			continue;
+		_rtw_memcpy(&(addrs[j][0]), pre_link_sta_ctl->node[i].addr, ETH_ALEN);
+		pre_link_sta_ctl->node[i].valid = _FALSE;
+		pre_link_sta_ctl->num--;
+		j++;
+	}
+	_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
+
+	for (i = 0; i < j; i++) {
+		sta = rtw_get_stainfo(stapriv, &(addrs[i][0]));
+		if (!sta)
+			continue;
+
+		if (sta->state == WIFI_FW_PRE_LINK)
+			rtw_free_stainfo(stapriv->padapter, sta);
+	}
+}
+
+void rtw_pre_link_sta_ctl_init(struct sta_priv *stapriv)
+{
+	struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
+	int i;
+
+	_rtw_spinlock_init(&pre_link_sta_ctl->lock);
+	pre_link_sta_ctl->num = 0;
+	for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++)
+		pre_link_sta_ctl->node[i].valid = _FALSE;
+}
+
+void rtw_pre_link_sta_ctl_deinit(struct sta_priv *stapriv)
+{
+	struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
+	int i;
+
+	rtw_pre_link_sta_ctl_reset(stapriv);
+
+	_rtw_spinlock_free(&pre_link_sta_ctl->lock);
+}
+
+void dump_pre_link_sta_ctl(void *sel, struct sta_priv *stapriv)
+{
+	struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
+	int i;
+
+	RTW_PRINT_SEL(sel, "num:%d/%d\n", pre_link_sta_ctl->num, RTW_PRE_LINK_STA_NUM);
+
+	for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
+		if (pre_link_sta_ctl->node[i].valid == _FALSE)
+			continue;
+		RTW_PRINT_SEL(sel, MAC_FMT"\n", MAC_ARG(pre_link_sta_ctl->node[i].addr));
+	}
 }
+#endif /* CONFIG_RTW_PRE_LINK_STA */
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_tdls.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_tdls.c
index 7e68cd83f8aa..3f5d58d8965d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_tdls.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_tdls.c
@@ -1,3157 +1,3506 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#define _RTW_TDLS_C_
-
-#include <drv_types.h>
-
-#ifdef CONFIG_TDLS
-#define ONE_SEC 	1000 /* 1000 ms */
-
-extern unsigned char MCS_rate_2R[16];
-extern unsigned char MCS_rate_1R[16];
-extern void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame);
-
-void rtw_reset_tdls_info(_adapter* padapter)
-{
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-
-	ptdlsinfo->ap_prohibited = _FALSE;
-	
-	/* For TDLS channel switch, currently we only allow it to work in wifi logo test mode */
-	if (padapter->registrypriv.wifi_spec == 1)
-	{
-		ptdlsinfo->ch_switch_prohibited = _FALSE;
-	}
-	else
-	{
-		ptdlsinfo->ch_switch_prohibited = _TRUE;
-	}
-
-	ptdlsinfo->link_established = _FALSE;
-	ptdlsinfo->sta_cnt = 0;
-	ptdlsinfo->sta_maximum = _FALSE;
-
-#ifdef CONFIG_TDLS_CH_SW
-	ptdlsinfo->chsw_info.ch_sw_state = TDLS_STATE_NONE;
-	ATOMIC_SET(&ptdlsinfo->chsw_info.chsw_on, _FALSE);
-	ptdlsinfo->chsw_info.off_ch_num = 0;
-	ptdlsinfo->chsw_info.ch_offset = 0;
-	ptdlsinfo->chsw_info.cur_time = 0;
-	ptdlsinfo->chsw_info.delay_switch_back = _FALSE;
-	ptdlsinfo->chsw_info.dump_stack = _FALSE;
-#endif
-	
-	ptdlsinfo->ch_sensing = 0;
-	ptdlsinfo->watchdog_count = 0;
-	ptdlsinfo->dev_discovered = _FALSE;
-
-#ifdef CONFIG_WFD
-	ptdlsinfo->wfd_info = &padapter->wfd_info;
-#endif
-}
-
-int rtw_init_tdls_info(_adapter* padapter)
-{
-	int	res = _SUCCESS;
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-
-	rtw_reset_tdls_info(padapter);
-
-	ptdlsinfo->tdls_enable = _TRUE;
-#ifdef CONFIG_TDLS_DRIVER_SETUP
-	ptdlsinfo->driver_setup = _TRUE;
-#else
-	ptdlsinfo->driver_setup = _FALSE;
-#endif /* CONFIG_TDLS_DRIVER_SETUP */
-
-	_rtw_spinlock_init(&ptdlsinfo->cmd_lock);
-	_rtw_spinlock_init(&ptdlsinfo->hdl_lock);
-
-	return res;
-
-}
-
-void rtw_free_tdls_info(struct tdls_info *ptdlsinfo)
-{
-	_rtw_spinlock_free(&ptdlsinfo->cmd_lock);
-	_rtw_spinlock_free(&ptdlsinfo->hdl_lock);
-
-	_rtw_memset(ptdlsinfo, 0, sizeof(struct tdls_info) );
-
-}
-
-int check_ap_tdls_prohibited(u8 *pframe, u8 pkt_len)
-{
-	u8 tdls_prohibited_bit = 0x40; /* bit(38); TDLS_prohibited */
-
-	if (pkt_len < 5) {
-		return _FALSE;
-	}
-
-	pframe += 4;
-	if ((*pframe) & tdls_prohibited_bit)
-		return _TRUE;
-
-	return _FALSE;
-}
-
-int check_ap_tdls_ch_switching_prohibited(u8 *pframe, u8 pkt_len)
-{
-	u8 tdls_ch_swithcing_prohibited_bit = 0x80; /* bit(39); TDLS_channel_switching prohibited */
-
-	if (pkt_len < 5) {
-		return _FALSE;
-	}
-
-	pframe += 4;
-	if ((*pframe) & tdls_ch_swithcing_prohibited_bit)
-		return _TRUE;
-
-	return _FALSE;
-}
-
-int _issue_nulldata_to_TDLS_peer_STA(_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 rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short				*fctrl, *qc;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
-
-	pattrib->hdrlen +=2;
-	pattrib->qos_en = _TRUE;
-	pattrib->eosp = 1;
-	pattrib->ack_policy = 0;
-	pattrib->mdata = 0;	
-	pattrib->retry_ctrl = _FALSE;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-
-	if (power_mode)
-		SetPwrMgt(fctrl);
-
-	qc = (unsigned short *)(pframe + pattrib->hdrlen - 2);
-	
-	SetPriority(qc, 7);	/* Set priority to VO */
-
-	SetEOSP(qc, pattrib->eosp);
-
-	SetAckpolicy(qc, pattrib->ack_policy);
-
-	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_QOS_DATA_NULL);
-
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	if (wait_ack)
-		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	else {
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
-	}
-
-exit:
-	return ret;
-
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_TDLS_C_
+
+#include <drv_types.h>
+#include <hal_data.h>
+
+#ifdef CONFIG_TDLS
+#define ONE_SEC 	1000 /* 1000 ms */
+
+extern unsigned char MCS_rate_2R[16];
+extern unsigned char MCS_rate_1R[16];
+
+inline void rtw_tdls_set_link_established(_adapter *adapter, bool en)
+{
+	adapter->tdlsinfo.link_established = en;
+	rtw_mi_update_iface_status(&(adapter->mlmepriv), 0);
+}
+
+void rtw_reset_tdls_info(_adapter *padapter)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	ptdlsinfo->ap_prohibited = _FALSE;
+
+	/* For TDLS channel switch, currently we only allow it to work in wifi logo test mode */
+	if (padapter->registrypriv.wifi_spec == 1)
+		ptdlsinfo->ch_switch_prohibited = _FALSE;
+	else
+		ptdlsinfo->ch_switch_prohibited = _TRUE;
+
+	rtw_tdls_set_link_established(padapter, _FALSE);
+	ptdlsinfo->sta_cnt = 0;
+	ptdlsinfo->sta_maximum = _FALSE;
+
+#ifdef CONFIG_TDLS_CH_SW
+	ptdlsinfo->chsw_info.ch_sw_state = TDLS_STATE_NONE;
+	ATOMIC_SET(&ptdlsinfo->chsw_info.chsw_on, _FALSE);
+	ptdlsinfo->chsw_info.off_ch_num = 0;
+	ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	ptdlsinfo->chsw_info.cur_time = 0;
+	ptdlsinfo->chsw_info.delay_switch_back = _FALSE;
+	ptdlsinfo->chsw_info.dump_stack = _FALSE;
+#endif
+
+	ptdlsinfo->ch_sensing = 0;
+	ptdlsinfo->watchdog_count = 0;
+	ptdlsinfo->dev_discovered = _FALSE;
+
+#ifdef CONFIG_WFD
+	ptdlsinfo->wfd_info = &padapter->wfd_info;
+#endif
+
+	ptdlsinfo->tdls_sctx = NULL;
+}
+
+int rtw_init_tdls_info(_adapter *padapter)
+{
+	int	res = _SUCCESS;
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	rtw_reset_tdls_info(padapter);
+
+#ifdef CONFIG_TDLS_DRIVER_SETUP
+	ptdlsinfo->driver_setup = _TRUE;
+#else
+	ptdlsinfo->driver_setup = _FALSE;
+#endif /* CONFIG_TDLS_DRIVER_SETUP */
+
+	_rtw_spinlock_init(&ptdlsinfo->cmd_lock);
+	_rtw_spinlock_init(&ptdlsinfo->hdl_lock);
+
+	return res;
+
+}
+
+void rtw_free_tdls_info(struct tdls_info *ptdlsinfo)
+{
+	_rtw_spinlock_free(&ptdlsinfo->cmd_lock);
+	_rtw_spinlock_free(&ptdlsinfo->hdl_lock);
+
+	_rtw_memset(ptdlsinfo, 0, sizeof(struct tdls_info));
+
+}
+
+void rtw_free_all_tdls_sta(_adapter *padapter, u8 enqueue_cmd)
+{
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	_irqL	 irqL;
+	_list	*plist, *phead;
+	s32	index;
+	struct sta_info *psta = NULL;
+	struct sta_info *ptdls_sta[NUM_STA];
+	u8 empty_hwaddr[ETH_ALEN] = { 0x00 };
+
+	_rtw_memset(ptdls_sta, 0x00, sizeof(ptdls_sta));
+
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+	for (index = 0; index < NUM_STA; index++) {
+		phead = &(pstapriv->sta_hash[index]);
+		plist = get_next(phead);
+
+		while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+
+			plist = get_next(plist);
+
+			if (psta->tdls_sta_state != TDLS_STATE_NONE)
+				ptdls_sta[index] = psta;
+		}
+	}
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+	for (index = 0; index < NUM_STA; index++) {
+		if (ptdls_sta[index]) {
+			struct TDLSoption_param tdls_param;
+
+			psta = ptdls_sta[index];
+
+			RTW_INFO("Do tear down to "MAC_FMT" by enqueue_cmd = %d\n", MAC_ARG(psta->cmn.mac_addr), enqueue_cmd);
+
+			_rtw_memcpy(&(tdls_param.addr), psta->cmn.mac_addr, ETH_ALEN);
+			tdls_param.option = TDLS_TEARDOWN_STA_NO_WAIT;
+			tdls_hdl(padapter, (unsigned char *)&(tdls_param));
+
+			rtw_tdls_teardown_pre_hdl(padapter, psta);
+
+			if (enqueue_cmd == _TRUE)
+				rtw_tdls_cmd(padapter, psta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+			else
+			 {
+				tdls_param.option = TDLS_TEARDOWN_STA_LOCALLY_POST;
+				tdls_hdl(padapter, (unsigned char *)&(tdls_param));
+			}
+		}
+	}
+}
+
+int check_ap_tdls_prohibited(u8 *pframe, u8 pkt_len)
+{
+	u8 tdls_prohibited_bit = 0x40; /* bit(38); TDLS_prohibited */
+
+	if (pkt_len < 5)
+		return _FALSE;
+
+	pframe += 4;
+	if ((*pframe) & tdls_prohibited_bit)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+int check_ap_tdls_ch_switching_prohibited(u8 *pframe, u8 pkt_len)
+{
+	u8 tdls_ch_swithcing_prohibited_bit = 0x80; /* bit(39); TDLS_channel_switching prohibited */
+
+	if (pkt_len < 5)
+		return _FALSE;
+
+	pframe += 4;
+	if ((*pframe) & tdls_ch_swithcing_prohibited_bit)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+u8 rtw_is_tdls_enabled(_adapter *padapter)
+{
+	return padapter->registrypriv.en_tdls;
+}
+
+void rtw_set_tdls_enable(_adapter *padapter, u8 enable)
+{
+	padapter->registrypriv.en_tdls = enable;
+	RTW_INFO("%s: en_tdls = %d\n", __func__, rtw_is_tdls_enabled(padapter));
+}
+
+void rtw_enable_tdls_func(_adapter *padapter)
+{
+	if (rtw_is_tdls_enabled(padapter) == _TRUE)
+		return;
+
+#if 0
+#ifdef CONFIG_MCC_MODE
+	if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC) == _TRUE) {
+		RTW_INFO("[TDLS] MCC is running, can't enable TDLS !\n");
+		return;
+	}
+#endif
+#endif
+	rtw_set_tdls_enable(padapter, _TRUE);
+}
+
+void rtw_disable_tdls_func(_adapter *padapter, u8 enqueue_cmd)
+{
+	if (rtw_is_tdls_enabled(padapter) == _FALSE)
+		return;
+
+	rtw_free_all_tdls_sta(padapter, enqueue_cmd);
+	rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
+	rtw_reset_tdls_info(padapter);
+
+	rtw_set_tdls_enable(padapter, _FALSE);
+}
+
+u8 rtw_is_tdls_sta_existed(_adapter *padapter)
+{
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta;
+	int i = 0;
+	_irqL irqL;
+	_list	*plist, *phead;
+	u8 ret = _FALSE;
+
+	if (rtw_is_tdls_enabled(padapter) == _FALSE)
+		return _FALSE;
+
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+			plist = get_next(plist);
+			if (psta->tdls_sta_state != TDLS_STATE_NONE) {
+				ret = _TRUE;
+				goto Exit;
+			}
+		}
+	}
+
+Exit:
+
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+	return ret;
+}
+
+u8 rtw_tdls_is_setup_allowed(_adapter *padapter)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	if (is_client_associated_to_ap(padapter) == _FALSE)
+		return _FALSE;
+
+	if (ptdlsinfo->ap_prohibited == _TRUE)
+		return _FALSE;
+
+	return _TRUE;
+}
+
+#ifdef CONFIG_TDLS_CH_SW
+u8 rtw_tdls_is_chsw_allowed(_adapter *padapter)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	if (ptdlsinfo->ch_switch_prohibited == _TRUE)
+		return _FALSE;
+
+	if (padapter->registrypriv.wifi_spec == 0)
+		return _FALSE;
+
+	return _TRUE;
+}
+#endif
+
+int _issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int wait_ms)
+{
+	int ret = _FAIL;
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	unsigned char					*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	unsigned short				*fctrl, *qc;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+
+	pattrib->hdrlen += 2;
+	pattrib->qos_en = _TRUE;
+	pattrib->eosp = 1;
+	pattrib->ack_policy = 0;
+	pattrib->mdata = 0;
+	pattrib->retry_ctrl = _FALSE;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	if (power_mode)
+		SetPwrMgt(fctrl);
+
+	qc = (unsigned short *)(pframe + pattrib->hdrlen - 2);
+
+	SetPriority(qc, 7);	/* Set priority to VO */
+
+	SetEOSP(qc, pattrib->eosp);
+
+	SetAckpolicy(qc, pattrib->ack_policy);
+
+	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	if (wait_ms)
+		ret = dump_mgntframe_and_wait_ack_timeout(padapter, pmgntframe, wait_ms);
+	else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
+
+exit:
+	return ret;
+
+}
+
 /*
  *wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
  *wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
  *try_cnt means the maximal TX count to try
  */
-int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)
-{
-	int ret;
-	int i = 0;
-	u32 start = rtw_get_current_time();
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	#if 0
-	psta = rtw_get_stainfo(&padapter->stapriv, da);
-	if (psta) {
-		if (power_mode)
-			rtw_hal_macid_sleep(padapter, psta->mac_id);
-		else
-			rtw_hal_macid_wakeup(padapter, psta->mac_id);
-	} else {
-		DBG_871X(FUNC_ADPT_FMT ": Can't find sta info for " MAC_FMT ", skip macid %s!!\n",
-			FUNC_ADPT_ARG(padapter), MAC_ARG(da), power_mode?"sleep":"wakeup");
-		rtw_warn_on(1);
-	}
-	#endif
-
-	do {
-		ret = _issue_nulldata_to_TDLS_peer_STA(padapter, da, power_mode, wait_ms>0 ? _TRUE : _FALSE);
-
-		i++;
-
-		if (RTW_CANNOT_RUN(padapter))
-			break;
-
-		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
-			rtw_msleep_os(wait_ms);
-
-	} while ((i < try_cnt) && (ret==_FAIL || wait_ms==0));
-
-	if (ret != _FAIL) {
-		ret = _SUCCESS;
-		#ifndef DBG_XMIT_ACK
-		goto exit;
-		#endif
-	}
-
-	if (try_cnt && wait_ms) {
-		if (da)
-			DBG_871X(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
-		else
-			DBG_871X(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
-				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
-				ret==_SUCCESS?", acked":"", i, try_cnt, rtw_get_passing_time_ms(start));
-	}
-exit:
-	return ret;
-}
-
-void free_tdls_sta(_adapter *padapter, struct sta_info *ptdls_sta)
-{
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	_irqL irqL;
-	
-	/* free peer sta_info */
-	_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-	if (ptdlsinfo->sta_cnt != 0)
-		ptdlsinfo->sta_cnt--;
-	_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-	/* -2: AP + BC/MC sta, -4: default key */
-	if (ptdlsinfo->sta_cnt < MAX_ALLOWED_TDLS_STA_NUM) {
-		ptdlsinfo->sta_maximum = _FALSE;
-		_rtw_memset( &ptdlsinfo->ss_record, 0x00, sizeof(struct tdls_ss_record) );
-	}
-
-	/* clear cam */
-	rtw_clearstakey_cmd(padapter, ptdls_sta, _TRUE);
-
-	if (ptdlsinfo->sta_cnt == 0) {
-		rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
-		ptdlsinfo->link_established = _FALSE;
-	}
-	else
-		DBG_871X("Remain tdls sta:%02x\n", ptdlsinfo->sta_cnt);
-
-	rtw_free_stainfo(padapter,  ptdls_sta);
-	
-}
-
-
-/* TDLS encryption(if needed) will always be CCMP */
-void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta)
-{
-	ptdls_sta->dot118021XPrivacy=_AES_;
-	rtw_setstakey_cmd(padapter, ptdls_sta, TDLS_KEY, _TRUE);
-}
-
-#ifdef CONFIG_80211N_HT
-void rtw_tdls_process_ht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
-{
-	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;
-	u8	max_AMPDU_len, min_MPDU_spacing;
-	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, cur_beamform_cap = 0;
-	
-	/* Save HT capabilities in the sta object */
-	_rtw_memset(&ptdls_sta->htpriv.ht_cap, 0, sizeof(struct rtw_ieee80211_ht_cap));
-	if (data && Length >= sizeof(struct rtw_ieee80211_ht_cap)) {
-		ptdls_sta->flags |= WLAN_STA_HT;
-		ptdls_sta->flags |= WLAN_STA_WME;
-
-		_rtw_memcpy(&ptdls_sta->htpriv.ht_cap, data, sizeof(struct rtw_ieee80211_ht_cap));			
-	} else
-		ptdls_sta->flags &= ~WLAN_STA_HT;
-
-	if (ptdls_sta->flags & WLAN_STA_HT) {
-		if (padapter->registrypriv.ht_enable == _TRUE) {
-			ptdls_sta->htpriv.ht_option = _TRUE;
-			ptdls_sta->qos_option = _TRUE;
-		} else {
-			ptdls_sta->htpriv.ht_option = _FALSE;
-			ptdls_sta->qos_option = _FALSE;
-		}
-	}
-
-	/* HT related cap */
-	if (ptdls_sta->htpriv.ht_option) {
-		/* Check if sta supports rx ampdu */
-		if (padapter->registrypriv.ampdu_enable == 1)
-			ptdls_sta->htpriv.ampdu_enable = _TRUE;
-
-		/* AMPDU Parameters field */
-		/* Get MIN of MAX AMPDU Length Exp */
-		if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3) > (data[2] & 0x3))
-			max_AMPDU_len = (data[2] & 0x3);
-		else
-			max_AMPDU_len = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3);
-		/* Get MAX of MIN MPDU Start Spacing */
-		if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) > (data[2] & 0x1c))
-			min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c);
-		else
-			min_MPDU_spacing = (data[2] & 0x1c);
-		ptdls_sta->htpriv.rx_ampdu_min_spacing = max_AMPDU_len | min_MPDU_spacing;
-
-		/* Check if sta support s Short GI 20M */
-		if (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SGI_20))
-			ptdls_sta->htpriv.sgi_20m = _TRUE;
-
-		/* Check if sta support s Short GI 40M */
-		if (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SGI_40))
-			ptdls_sta->htpriv.sgi_40m = _TRUE;
-
-		/* Bwmode would still followed AP's setting */
-		if (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH)) {
-			if (padapter->mlmeextpriv.cur_bwmode >= CHANNEL_WIDTH_40)
-				ptdls_sta->bw_mode = CHANNEL_WIDTH_40;
-			ptdls_sta->htpriv.ch_offset = padapter->mlmeextpriv.cur_ch_offset;
-		}
-
-		/* Config LDPC Coding Capability */
-		if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX) && GET_HT_CAP_ELE_LDPC_CAP(data)) {
+int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)
+{
+	int ret;
+	int i = 0;
+	systime start = rtw_get_current_time();
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+#if 0
+	psta = rtw_get_stainfo(&padapter->stapriv, da);
+	if (psta) {
+		if (power_mode)
+			rtw_hal_macid_sleep(padapter, psta->cmn.mac_id);
+		else
+			rtw_hal_macid_wakeup(padapter, psta->cmn.mac_id);
+	} else {
+		RTW_INFO(FUNC_ADPT_FMT ": Can't find sta info for " MAC_FMT ", skip macid %s!!\n",
+			FUNC_ADPT_ARG(padapter), MAC_ARG(da), power_mode ? "sleep" : "wakeup");
+		rtw_warn_on(1);
+	}
+#endif
+
+	do {
+		ret = _issue_nulldata_to_TDLS_peer_STA(padapter, da, power_mode, wait_ms);
+
+		i++;
+
+		if (RTW_CANNOT_RUN(padapter))
+			break;
+
+		if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
+			rtw_msleep_os(wait_ms);
+
+	} while ((i < try_cnt) && (ret == _FAIL || wait_ms == 0));
+
+	if (ret != _FAIL) {
+		ret = _SUCCESS;
+#ifndef DBG_XMIT_ACK
+		goto exit;
+#endif
+	}
+
+	if (try_cnt && wait_ms) {
+		if (da)
+			RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+		else
+			RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
+				FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
+				ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
+	}
+exit:
+	return ret;
+}
+
+/* TDLS encryption(if needed) will always be CCMP */
+void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta)
+{
+	ptdls_sta->dot118021XPrivacy = _AES_;
+	rtw_setstakey_cmd(padapter, ptdls_sta, TDLS_KEY, _TRUE);
+}
+
+#ifdef CONFIG_80211N_HT
+void rtw_tdls_process_ht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
+{
+	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;
+	u8	max_AMPDU_len, min_MPDU_spacing;
+	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, cur_beamform_cap = 0;
+
+	/* Save HT capabilities in the sta object */
+	_rtw_memset(&ptdls_sta->htpriv.ht_cap, 0, sizeof(struct rtw_ieee80211_ht_cap));
+	if (data && Length >= sizeof(struct rtw_ieee80211_ht_cap)) {
+		ptdls_sta->flags |= WLAN_STA_HT;
+		ptdls_sta->flags |= WLAN_STA_WME;
+
+		_rtw_memcpy(&ptdls_sta->htpriv.ht_cap, data, sizeof(struct rtw_ieee80211_ht_cap));
+	} else {
+		ptdls_sta->flags &= ~WLAN_STA_HT;
+		return;
+	}
+
+	if (ptdls_sta->flags & WLAN_STA_HT) {
+		if (padapter->registrypriv.ht_enable == _TRUE) {
+			ptdls_sta->htpriv.ht_option = _TRUE;
+			ptdls_sta->qos_option = _TRUE;
+		} else {
+			ptdls_sta->htpriv.ht_option = _FALSE;
+			ptdls_sta->qos_option = _FALSE;
+		}
+	}
+
+	/* HT related cap */
+	if (ptdls_sta->htpriv.ht_option) {
+		/* Check if sta supports rx ampdu */
+		if (padapter->registrypriv.ampdu_enable == 1)
+			ptdls_sta->htpriv.ampdu_enable = _TRUE;
+
+		/* AMPDU Parameters field */
+		/* Get MIN of MAX AMPDU Length Exp */
+		if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3) > (data[2] & 0x3))
+			max_AMPDU_len = (data[2] & 0x3);
+		else
+			max_AMPDU_len = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3);
+		/* Get MAX of MIN MPDU Start Spacing */
+		if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) > (data[2] & 0x1c))
+			min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c);
+		else
+			min_MPDU_spacing = (data[2] & 0x1c);
+		ptdls_sta->htpriv.rx_ampdu_min_spacing = max_AMPDU_len | min_MPDU_spacing;
+
+		/* Check if sta support s Short GI 20M */
+		if ((phtpriv->sgi_20m == _TRUE) && (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SGI_20)))
+			ptdls_sta->htpriv.sgi_20m = _TRUE;
+
+		/* Check if sta support s Short GI 40M */
+		if ((phtpriv->sgi_40m == _TRUE) && (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SGI_40)))
+			ptdls_sta->htpriv.sgi_40m = _TRUE;
+
+		/* Bwmode would still followed AP's setting */
+		if (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH)) {
+			if (padapter->mlmeextpriv.cur_bwmode >= CHANNEL_WIDTH_40)
+				ptdls_sta->cmn.bw_mode = CHANNEL_WIDTH_40;
+			ptdls_sta->htpriv.ch_offset = padapter->mlmeextpriv.cur_ch_offset;
+		}
+
+		/* Config LDPC Coding Capability */
+		if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX) && GET_HT_CAP_ELE_LDPC_CAP(data)) {
 			SET_FLAG(cur_ldpc_cap, (LDPC_HT_ENABLE_TX | LDPC_HT_CAP_TX));
-			DBG_871X("Enable HT Tx LDPC!\n");
+			RTW_INFO("Enable HT Tx LDPC!\n");
 		}
-		ptdls_sta->htpriv.ldpc_cap = cur_ldpc_cap;
+		ptdls_sta->htpriv.ldpc_cap = cur_ldpc_cap;
 
-		/* Config STBC setting */
-		if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(data)) {
-			SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX));
-			DBG_871X("Enable HT Tx STBC!\n");
+		/* Config STBC setting */
+		if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(data)) {
+			SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX));
+			RTW_INFO("Enable HT Tx STBC!\n");
 		}
-		ptdls_sta->htpriv.stbc_cap = cur_stbc_cap;
+		ptdls_sta->htpriv.stbc_cap = cur_stbc_cap;
 
 #ifdef CONFIG_BEAMFORMING
-		/* Config Tx beamforming setting */
-		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) && 
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(data)) {
+		/* Config Tx beamforming setting */
+		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(data))
 			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
-		}
 
 		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(data)) {
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(data))
 			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
-		}
-		ptdls_sta->htpriv.beamform_cap = cur_beamform_cap;
-		if (cur_beamform_cap)
-			DBG_871X("Client HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
-#endif /* CONFIG_BEAMFORMING */
-	}
-
-}
-
-u8 *rtw_tdls_set_ht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	rtw_ht_use_default_setting(padapter);
-
-	rtw_restructure_ht_ie(padapter, NULL, pframe, 0, &(pattrib->pktlen), padapter->mlmeextpriv.cur_channel);
-
-	return pframe + pattrib->pktlen;
-}
-#endif
-
-#ifdef CONFIG_80211AC_VHT
-void rtw_tdls_process_vht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
-{
-	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct vht_priv			*pvhtpriv = &pmlmepriv->vhtpriv;
-	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, cur_beamform_cap = 0, rf_type = RF_1T1R;
-	u8	*pcap_mcs;
-	u8	vht_mcs[2];
-	
-	_rtw_memset(&ptdls_sta->vhtpriv, 0, sizeof(struct vht_priv));
-	if (data && Length == 12) {
-		ptdls_sta->flags |= WLAN_STA_VHT;
-
-		_rtw_memcpy(ptdls_sta->vhtpriv.vht_cap, data, 12);
-
-#if 0
-		if (elems.vht_op_mode_notify && elems.vht_op_mode_notify_len == 1) {
+		ptdls_sta->htpriv.beamform_cap = cur_beamform_cap;
+		if (cur_beamform_cap)
+			RTW_INFO("Client HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
+#endif /* CONFIG_BEAMFORMING */
+	}
+
+}
+
+u8 *rtw_tdls_set_ht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	rtw_ht_use_default_setting(padapter);
+
+	if (padapter->registrypriv.wifi_spec == 1) {
+		padapter->mlmepriv.htpriv.sgi_20m = _FALSE;
+		padapter->mlmepriv.htpriv.sgi_40m = _FALSE;
+	}
+
+	rtw_restructure_ht_ie(padapter, NULL, pframe, 0, &(pattrib->pktlen), padapter->mlmeextpriv.cur_channel);
+
+	return pframe + pattrib->pktlen;
+}
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+void rtw_tdls_process_vht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct vht_priv			*pvhtpriv = &pmlmepriv->vhtpriv;
+	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, cur_beamform_cap = 0, rf_type = RF_1T1R, tx_nss = 0;
+	u8	*pcap_mcs;
+
+	_rtw_memset(&ptdls_sta->vhtpriv, 0, sizeof(struct vht_priv));
+	if (data && Length == 12) {
+		ptdls_sta->flags |= WLAN_STA_VHT;
+
+		_rtw_memcpy(ptdls_sta->vhtpriv.vht_cap, data, 12);
+
+#if 0
+		if (elems.vht_op_mode_notify && elems.vht_op_mode_notify_len == 1)
 			_rtw_memcpy(&pstat->vhtpriv.vht_op_mode_notify, elems.vht_op_mode_notify, 1);
-		} else /* for Frame without Operating Mode notify ie; default: 80M */ {
+		else /* for Frame without Operating Mode notify ie; default: 80M */
 			pstat->vhtpriv.vht_op_mode_notify = CHANNEL_WIDTH_80;
-		}
-#else
-		ptdls_sta->vhtpriv.vht_op_mode_notify = CHANNEL_WIDTH_80;
-#endif
-	} else
-		ptdls_sta->flags &= ~WLAN_STA_VHT;
-
-	if (ptdls_sta->flags & WLAN_STA_VHT) {
-		if (REGSTY_IS_11AC_ENABLE(&padapter->registrypriv)
-			&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-			&& (!pmlmepriv->country_ent || COUNTRY_CHPLAN_EN_11AC(pmlmepriv->country_ent)))
-			ptdls_sta->vhtpriv.vht_option = _TRUE;
-		else 
-			ptdls_sta->vhtpriv.vht_option = _FALSE;
-	}
-
-	/* B4 Rx LDPC */
-	if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX) && 
-		GET_VHT_CAPABILITY_ELE_RX_LDPC(data)) {
+#else
+		ptdls_sta->vhtpriv.vht_op_mode_notify = CHANNEL_WIDTH_80;
+#endif
+	} else {
+		ptdls_sta->flags &= ~WLAN_STA_VHT;
+		return;
+	}
+
+	if (ptdls_sta->flags & WLAN_STA_VHT) {
+		if (REGSTY_IS_11AC_ENABLE(&padapter->registrypriv)
+		    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+		    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent)))
+			ptdls_sta->vhtpriv.vht_option = _TRUE;
+		else
+			ptdls_sta->vhtpriv.vht_option = _FALSE;
+	}
+
+	/* B4 Rx LDPC */
+	if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX) &&
+	    GET_VHT_CAPABILITY_ELE_RX_LDPC(data)) {
 		SET_FLAG(cur_ldpc_cap, (LDPC_VHT_ENABLE_TX | LDPC_VHT_CAP_TX));
-		DBG_871X("Current VHT LDPC Setting = %02X\n", cur_ldpc_cap);
+		RTW_INFO("Current VHT LDPC Setting = %02X\n", cur_ldpc_cap);
 	}
-	ptdls_sta->vhtpriv.ldpc_cap = cur_ldpc_cap;
+	ptdls_sta->vhtpriv.ldpc_cap = cur_ldpc_cap;
+
+	/* B5 Short GI for 80 MHz */
+	ptdls_sta->vhtpriv.sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI80M(data) & pvhtpriv->sgi_80m) ? _TRUE : _FALSE;
 
-	/* B5 Short GI for 80 MHz */
-	ptdls_sta->vhtpriv.sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI80M(data) & pvhtpriv->sgi_80m) ? _TRUE : _FALSE;
-
-	/* B8 B9 B10 Rx STBC */
-	if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX) && 
-		GET_VHT_CAPABILITY_ELE_RX_STBC(data)) {
-		SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));	
-		DBG_871X("Current VHT STBC Setting = %02X\n", cur_stbc_cap);
+	/* B8 B9 B10 Rx STBC */
+	if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX) &&
+	    GET_VHT_CAPABILITY_ELE_RX_STBC(data)) {
+		SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));
+		RTW_INFO("Current VHT STBC Setting = %02X\n", cur_stbc_cap);
 	}
-	ptdls_sta->vhtpriv.stbc_cap = cur_stbc_cap;
+	ptdls_sta->vhtpriv.stbc_cap = cur_stbc_cap;
 
-	/* B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee */
-	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) && 
-		GET_VHT_CAPABILITY_ELE_SU_BFEE(data)) {
+	#ifdef CONFIG_BEAMFORMING
+	/* B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee */
+	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) &&
+	    GET_VHT_CAPABILITY_ELE_SU_BFEE(data))
 		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
-	}
 
-	/* B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer */
+	/* B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer */
 	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) &&
-		GET_VHT_CAPABILITY_ELE_SU_BFER(data)) {
+	    GET_VHT_CAPABILITY_ELE_SU_BFER(data))
 		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
-	}
-	ptdls_sta->vhtpriv.beamform_cap = cur_beamform_cap;
-	if (cur_beamform_cap)
-		DBG_871X("Current VHT Beamforming Setting = %02X\n", cur_beamform_cap);
-
-	/* B23 B24 B25 Maximum A-MPDU Length Exponent */
-	ptdls_sta->vhtpriv.ampdu_len = GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(data);
+	ptdls_sta->vhtpriv.beamform_cap = cur_beamform_cap;
+	if (cur_beamform_cap)
+		RTW_INFO("Current VHT Beamforming Setting = %02X\n", cur_beamform_cap);
+	#endif /*CONFIG_BEAMFORMING*/
 
-	pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(data);
-	_rtw_memcpy(vht_mcs, pcap_mcs, 2);
+	/* B23 B24 B25 Maximum A-MPDU Length Exponent */
+	ptdls_sta->vhtpriv.ampdu_len = GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(data);
 
+	pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(data);
 	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-	if ((rf_type == RF_1T1R) || (rf_type == RF_1T2R))
-		vht_mcs[0] |= 0xfc;
-	else if (rf_type == RF_2T2R)
-		vht_mcs[0] |= 0xf0;
-	else if (rf_type == RF_3T3R)
-		vht_mcs[0] |= 0xc0;
-
-	_rtw_memcpy(ptdls_sta->vhtpriv.vht_mcs_map, vht_mcs, 2);
-
-	ptdls_sta->vhtpriv.vht_highest_rate = rtw_get_vht_highest_rate(ptdls_sta->vhtpriv.vht_mcs_map);
-}
-
-u8 *rtw_tdls_set_aid(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	return rtw_set_ie(pframe, EID_AID, 2, (u8 *)&(padapter->mlmepriv.cur_network.aid), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_vht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	u32 ie_len = 0;
-	
-	rtw_vht_use_default_setting(padapter);
-
-	ie_len = rtw_build_vht_cap_ie(padapter, pframe);
-	pattrib->pktlen += ie_len;
-	
-	return pframe + ie_len;
-}
-
-u8 *rtw_tdls_set_vht_operation(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 channel)
-{
-	u32 ie_len = 0;
-
-	ie_len = rtw_build_vht_operation_ie(padapter, pframe, channel);
-	pattrib->pktlen += ie_len;
-	
-	return pframe + ie_len;
-}
-
-u8 *rtw_tdls_set_vht_op_mode_notify(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 bw)
-{
-	u32 ie_len = 0;
-	
-	ie_len = rtw_build_vht_op_mode_notify_ie(padapter, pframe, bw);
-	pattrib->pktlen += ie_len;
-
-	return pframe + ie_len;
-}
-#endif
-
-
-u8 *rtw_tdls_set_sup_ch(struct mlme_ext_priv *pmlmeext, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	u8 sup_ch[30 * 2] = {0x00}, ch_set_idx = 0, sup_ch_idx = 2;	
-
-	do {
-		if (pmlmeext->channel_set[ch_set_idx].ChannelNum <= 14) {
-			sup_ch[0] = 1;	/* First channel number */
-			sup_ch[1] = pmlmeext->channel_set[ch_set_idx].ChannelNum;	/* Number of channel */
-		} else {
-			sup_ch[sup_ch_idx++] = pmlmeext->channel_set[ch_set_idx].ChannelNum;
-			sup_ch[sup_ch_idx++] = 1;
-		}
-		ch_set_idx++;
-	} while (pmlmeext->channel_set[ch_set_idx].ChannelNum != 0 && ch_set_idx < MAX_CHANNEL_NUM);
-
-	return rtw_set_ie(pframe, _SUPPORTED_CH_IE_, sup_ch_idx, sup_ch, &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_rsnie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib,  int init, struct sta_info *ptdls_sta)
-{
-	u8 *p = NULL;
-	int len = 0;
-
-	if (ptxmgmt->len > 0)
-		p = rtw_get_ie(ptxmgmt->buf, _RSN_IE_2_, &len, ptxmgmt->len);
-
-	if (p != NULL)
-		return rtw_set_ie(pframe, _RSN_IE_2_, len, p+2, &(pattrib->pktlen));
-	else
-		if (init == _TRUE)
-			return rtw_set_ie(pframe, _RSN_IE_2_, sizeof(TDLS_RSNIE), TDLS_RSNIE, &(pattrib->pktlen));
-		else
-			return rtw_set_ie(pframe, _RSN_IE_2_, sizeof(ptdls_sta->TDLS_RSNIE), ptdls_sta->TDLS_RSNIE, &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_ext_cap(u8 *pframe, struct pkt_attrib *pattrib)
-{
-	return rtw_set_ie(pframe, _EXT_CAP_IE_ , sizeof(TDLS_EXT_CAPIE), TDLS_EXT_CAPIE, &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_qos_cap(u8 *pframe, struct pkt_attrib *pattrib)
-{
-	return rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, sizeof(TDLS_WMMIE), TDLS_WMMIE,  &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_ftie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, u8 *ANonce, u8 *SNonce)
-{
-	struct wpa_tdls_ftie FTIE = {0};
-	u8 *p = NULL;
-	int len = 0;
-
-	if (ptxmgmt->len > 0)
-		p = rtw_get_ie(ptxmgmt->buf, _FTIE_, &len, ptxmgmt->len);
-
-	if (p != NULL)
-		return rtw_set_ie(pframe, _FTIE_, len, p+2, &(pattrib->pktlen));
-	else {
-		if (ANonce != NULL)
-			_rtw_memcpy(FTIE.Anonce, ANonce, WPA_NONCE_LEN);
-		if (SNonce != NULL)
-			_rtw_memcpy(FTIE.Snonce, SNonce, WPA_NONCE_LEN);
-		return rtw_set_ie(pframe, _FTIE_ , 82, (u8 *)FTIE.mic_ctrl, &(pattrib->pktlen));
-	}
-}
-
-u8 *rtw_tdls_set_timeout_interval(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, int init, struct sta_info *ptdls_sta)
-{
-	u8 timeout_itvl[5];	/* set timeout interval to maximum value */
-	u32 timeout_interval= TPK_RESEND_COUNT;
-	u8 *p = NULL;
-	int len = 0;
-
-	if (ptxmgmt->len > 0)
-		p = rtw_get_ie(ptxmgmt->buf, _TIMEOUT_ITVL_IE_, &len, ptxmgmt->len);
-
-	if (p != NULL)
-		return rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, len, p+2, &(pattrib->pktlen));
-	else {
-		/* Timeout interval */
-		timeout_itvl[0]=0x02;
-		if (init == _TRUE)
-			_rtw_memcpy(timeout_itvl+1, &timeout_interval, 4);
-		else
-			_rtw_memcpy(timeout_itvl+1, (u8 *)(&ptdls_sta->TDLS_PeerKey_Lifetime), 4);
-
-		return rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, 5, timeout_itvl, &(pattrib->pktlen));
-	}
-}
-
-u8 *rtw_tdls_set_bss_coexist(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	u8 iedata=0;
-
-	if (padapter->mlmepriv.num_FortyMHzIntolerant > 0)
-		iedata |= BIT(2);	/* 20 MHz BSS Width Request */
-
-	/* Information Bit should be set by TDLS test plan 5.9 */
-	iedata |= BIT(0);
-	return rtw_set_ie(pframe, EID_BSSCoexistence, 1, &iedata, &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_payload_type(u8 *pframe, struct pkt_attrib *pattrib)
-{
-	u8 payload_type = 0x02;
-	return rtw_set_fixed_ie(pframe, 1, &(payload_type), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_category(u8 *pframe, struct pkt_attrib *pattrib, u8 category)
-{
-	return rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_action(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
-{
-	return rtw_set_fixed_ie(pframe, 1, &(ptxmgmt->action_code), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_status_code(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
-{
-	return rtw_set_fixed_ie(pframe, 2, (u8 *)&(ptxmgmt->status_code), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_dialog(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
-{
-	u8 dialogtoken = 1;
-	if (ptxmgmt->dialog_token)
-		return rtw_set_fixed_ie(pframe, 1, &(ptxmgmt->dialog_token), &(pattrib->pktlen));
-	else
-		return rtw_set_fixed_ie(pframe, 1, &(dialogtoken), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_reg_class(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)
-{
-	u8 reg_class = 1;
-	return rtw_set_fixed_ie(pframe, 1, &(reg_class), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_capability(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &pmlmeext->mlmext_info;
-	u8 cap_from_ie[2] = {0};
-
-	_rtw_memcpy(cap_from_ie, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
-
-	return rtw_set_fixed_ie(pframe, 2, cap_from_ie, &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_supported_rate(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	u8 bssrate[NDIS_802_11_LENGTH_RATES_EX];
- 	int bssrate_len = 0;
-	u8 more_supportedrates = 0;
-
-	rtw_set_supported_rate(bssrate, (padapter->registrypriv.wireless_mode == WIRELESS_MODE_MAX) ? padapter->mlmeextpriv.cur_wireless_mode : padapter->registrypriv.wireless_mode); 
-	bssrate_len = rtw_get_rateset_len(bssrate);
-
-	if (bssrate_len > 8) {
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
-		more_supportedrates = 1;
-	} else {
-		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
-	}
-
-	/* extended supported rates */
-	if (more_supportedrates == 1) {
-		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
-	}
-
-	return pframe;
-}
-
-u8 *rtw_tdls_set_sup_reg_class(u8 *pframe, struct pkt_attrib *pattrib)
-{
-	return rtw_set_ie(pframe, _SRC_IE_ , sizeof(TDLS_SRC), TDLS_SRC, &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_linkid(u8 *pframe, struct pkt_attrib *pattrib, u8 init)
-{
-	u8 link_id_addr[18] = {0};
-	if (init == _TRUE) {
-		_rtw_memcpy(link_id_addr, pattrib->ra, 6);
-		_rtw_memcpy((link_id_addr+6), pattrib->src, 6);
-		_rtw_memcpy((link_id_addr+12), pattrib->dst, 6);
-	} else {
-		_rtw_memcpy(link_id_addr, pattrib->ra, 6);
-		_rtw_memcpy((link_id_addr+6), pattrib->dst, 6);
-		_rtw_memcpy((link_id_addr+12), pattrib->src, 6);
-	}
-	return rtw_set_ie(pframe, _LINK_ID_IE_, 18, link_id_addr, &(pattrib->pktlen));
-}
-
-#ifdef CONFIG_TDLS_CH_SW
-u8 *rtw_tdls_set_target_ch(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	u8 target_ch = 1;
-	if (padapter->tdlsinfo.chsw_info.off_ch_num)
-		return rtw_set_fixed_ie(pframe, 1, &(padapter->tdlsinfo.chsw_info.off_ch_num), &(pattrib->pktlen));
-	else
-		return rtw_set_fixed_ie(pframe, 1, &(target_ch), &(pattrib->pktlen));
-}
-
-u8 *rtw_tdls_set_ch_sw(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)
-{
-	u8 ch_switch_timing[4] = {0};
-	u16 switch_time = (ptdls_sta->ch_switch_time >= CH_SWITCH_TIME * 1000) ? 
-		ptdls_sta->ch_switch_time : CH_SWITCH_TIME;
-	u16 switch_timeout = (ptdls_sta->ch_switch_timeout >= CH_SWITCH_TIMEOUT * 1000) ? 
-		ptdls_sta->ch_switch_timeout : CH_SWITCH_TIMEOUT;
-
-	_rtw_memcpy(ch_switch_timing, &switch_time, 2);
-	_rtw_memcpy(ch_switch_timing + 2, &switch_timeout, 2);
-
-	return rtw_set_ie(pframe, _CH_SWITCH_TIMING_,  4, ch_switch_timing, &(pattrib->pktlen));
-}
-#endif
-
-u8 *rtw_tdls_set_wmm_params(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
-{
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);	
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8 wmm_param_ele[24] = {0};
-
-	if (&pmlmeinfo->WMM_param) {
-		_rtw_memcpy(wmm_param_ele, WMM_PARA_OUI, 6);
-		if (_rtw_memcmp(&pmlmeinfo->WMM_param, &wmm_param_ele[6], 18) == _TRUE)
-			/* Use default WMM Param */
-			_rtw_memcpy(wmm_param_ele + 6, (u8 *)&TDLS_WMM_PARAM_IE, sizeof(TDLS_WMM_PARAM_IE));
-		else	
-			_rtw_memcpy(wmm_param_ele + 6, (u8 *)&pmlmeinfo->WMM_param, sizeof(pmlmeinfo->WMM_param));
-		return rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_,  24, wmm_param_ele, &(pattrib->pktlen));		
-	}
-	else
-		return pframe;
-}
-
-#ifdef CONFIG_WFD
-void rtw_tdls_process_wfd_ie(struct tdls_info *ptdlsinfo, u8 *ptr, u8 length)
-{
-	u8 *wfd_ie;
-	u32	wfd_ielen = 0;
-
-	if (!hal_chk_wl_func(tdls_info_to_adapter(ptdlsinfo), WL_FUNC_MIRACAST))
-		return;
-
-	/* Try to get the TCP port information when receiving the negotiation response. */
-
-	wfd_ie = rtw_get_wfd_ie(ptr, length, NULL, &wfd_ielen);
-	while (wfd_ie) {
-		u8 *attr_content;
-		u32	attr_contentlen = 0;
-		int	i;
-
-		DBG_871X( "[%s] WFD IE Found!!\n", __FUNCTION__ );
-		attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &attr_contentlen);
-		if (attr_content && attr_contentlen) {
-			ptdlsinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16( attr_content + 2 );
-			DBG_871X( "[%s] Peer PORT NUM = %d\n", __FUNCTION__, ptdlsinfo->wfd_info->peer_rtsp_ctrlport );
-		}
-
-		attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_LOCAL_IP_ADDR, NULL, &attr_contentlen);
-		if (attr_content && attr_contentlen) {
-			_rtw_memcpy(ptdlsinfo->wfd_info->peer_ip_address, ( attr_content + 1 ), 4);
-			DBG_871X("[%s] Peer IP = %02u.%02u.%02u.%02u\n", __FUNCTION__, 
-				ptdlsinfo->wfd_info->peer_ip_address[0], ptdlsinfo->wfd_info->peer_ip_address[1],
-				ptdlsinfo->wfd_info->peer_ip_address[2], ptdlsinfo->wfd_info->peer_ip_address[3]);
-		}
-
-		wfd_ie = rtw_get_wfd_ie(wfd_ie + wfd_ielen, (ptr + length) - (wfd_ie + wfd_ielen), NULL, &wfd_ielen);
-	}
-}
-
-int issue_tunneled_probe_req(_adapter *padapter)
-{
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	u8 baddr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff}; 
-	struct tdls_txmgmt txmgmt;
-	int ret = _FAIL;
-
-	DBG_871X("[%s]\n", __FUNCTION__);
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	txmgmt.action_code = TUNNELED_PROBE_REQ;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, baddr, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-	dump_mgntframe(padapter, pmgntframe);
-	ret = _SUCCESS;
-exit:
-
-	return ret;
-}
-
-int issue_tunneled_probe_rsp(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct tdls_txmgmt txmgmt;
-	int ret = _FAIL;
-
-	DBG_871X("[%s]\n", __FUNCTION__);
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	txmgmt.action_code = TUNNELED_PROBE_RSP;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, precv_frame->u.hdr.attrib.src, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-	dump_mgntframe(padapter, pmgntframe);
-	ret = _SUCCESS;
-exit:
-
-	return ret;
-}
-#endif /* CONFIG_WFD */
-
-int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)
-{
-	struct tdls_info	*ptdlsinfo = &padapter->tdlsinfo;
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *ptdls_sta= NULL;
-	_irqL irqL;
-	int ret = _FAIL;
-	/* Retry timer should be set at least 301 sec, using TPK_count counting 301 times. */
-	u32 timeout_interval= TPK_RESEND_COUNT;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	ptxmgmt->action_code = TDLS_SETUP_REQUEST;
-	if (ptdlsinfo->ap_prohibited == _TRUE)
-		goto exit;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-
-	/* init peer sta_info */
-	ptdls_sta = rtw_get_stainfo(pstapriv, ptxmgmt->peer);
-	if (ptdls_sta == NULL) {
-		ptdls_sta = rtw_alloc_stainfo(pstapriv, ptxmgmt->peer);
-		if (ptdls_sta == NULL) {
-			DBG_871X("[%s] rtw_alloc_stainfo fail\n", __FUNCTION__);	
-			rtw_free_xmitbuf(pxmitpriv,pmgntframe->pxmitbuf);
-			rtw_free_xmitframe(pxmitpriv, pmgntframe);
-			goto exit;
-		}
-	}
-	
-	if(!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
-		ptdlsinfo->sta_cnt++;
-
-	if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
-		ptdlsinfo->sta_maximum  = _TRUE;
-
-	ptdls_sta->tdls_sta_state |= TDLS_RESPONDER_STATE;
-
-	if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
-		ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
-		_set_timer(&ptdls_sta->handshake_timer, TDLS_HANDSHAKE_TIME);
-	}
-
-	pattrib->qsel = pattrib->priority;
-
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) !=_SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv,pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-
-	if (wait_ack) {
-		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	} else {
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
-	}
-
-exit:
-
-	return ret;
-}
-
-int _issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)
-{
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info	*ptdls_sta=NULL;
-	_irqL irqL;
-	int ret = _FAIL;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	ptxmgmt->action_code = TDLS_TEARDOWN;
-	ptdls_sta = rtw_get_stainfo(pstapriv, ptxmgmt->peer);
-	if (ptdls_sta == NULL) {
-		DBG_871X("Np tdls_sta for tearing down\n");
-		goto exit;
-	}
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	rtw_set_scan_deny(padapter, 550);
-
-	rtw_scan_abort(padapter);
-#ifdef CONFIG_CONCURRENT_MODE		
-	if (rtw_buddy_adapter_up(padapter))	
-		rtw_scan_abort(padapter->pbuddy_adapter);
-#endif /* CONFIG_CONCURRENT_MODE */
-
-	pattrib = &pmgntframe->attrib;
-
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-
-	if (rtw_tdls_is_driver_setup(padapter) == _TRUE) 
-		if(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
-			if (pattrib->encrypt) 
-				_cancel_timer_ex(&ptdls_sta->TPK_timer);
-
-	if (wait_ack) {
-		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	} else {
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
-	}
-
-	if (ret == _SUCCESS && rtw_tdls_is_driver_setup(padapter))
-		rtw_tdls_cmd(padapter, ptxmgmt->peer, TDLS_TEAR_STA);
-
-exit:
-
-	return ret;
-}
-
-int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)
-{
-	int ret = _FAIL;
-	
-	ret = _issue_tdls_teardown(padapter, ptxmgmt, wait_ack);
-	if ((ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_) && (ret == _FAIL)) {
-		/* Change status code and send teardown again via AP */
-		ptxmgmt->status_code = _RSON_TDLS_TEAR_TOOFAR_;
-		ret = _issue_tdls_teardown(padapter, ptxmgmt, wait_ack);
-	}
-
-	return ret;
-}
-
-int issue_tdls_dis_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
-{
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	int ret = _FAIL;
-	
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-	
-	ptxmgmt->action_code = TDLS_DISCOVERY_REQUEST;
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-	dump_mgntframe(padapter, pmgntframe);
-	DBG_871X("issue tdls dis req\n");
-
-	ret = _SUCCESS;
-exit:
-
-	return ret;
-}
-
-int issue_tdls_setup_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
-{
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	int ret = _FAIL;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	ptxmgmt->action_code = TDLS_SETUP_RESPONSE;		
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(&(padapter->mlmepriv)), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-
-	dump_mgntframe(padapter, pmgntframe);
-
-	ret = _SUCCESS;
-exit:
-
-	return ret;
-
-}
-
-int issue_tdls_setup_cfm(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
-{
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	int ret = _FAIL;
-	
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-	
-	ptxmgmt->action_code = TDLS_SETUP_CONFIRM;
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(&padapter->mlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;		
-	}
-
-	dump_mgntframe(padapter, pmgntframe);
-
-	ret = _SUCCESS;
-exit:
-
-	return ret;
-
-}
-
-/* TDLS Discovery Response frame is a management action frame */
-int issue_tdls_dis_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 privacy)
-{
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	unsigned char			*pframe;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short		*fctrl;
-	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	int ret = _FAIL;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-
-	/* unicast probe request frame */
-	_rtw_memcpy(pwlanhdr->addr1, ptxmgmt->peer, ETH_ALEN);
-	_rtw_memcpy(pattrib->dst, pwlanhdr->addr1, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->src, pwlanhdr->addr2, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, pwlanhdr->addr3, ETH_ALEN);
-
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
-
-	pframe += sizeof (struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof (struct rtw_ieee80211_hdr_3addr);
-
-	rtw_build_tdls_dis_rsp_ies(padapter, pmgntframe, pframe, ptxmgmt, privacy);
-
-	pattrib->nr_frags = 1;
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(padapter, pmgntframe);
-	ret = _SUCCESS;
-
-exit:
-	return ret;
-}
-
-int issue_tdls_peer_traffic_rsp(_adapter *padapter, struct sta_info *ptdls_sta, struct tdls_txmgmt *ptxmgmt)
-{
-	struct xmit_frame	*pmgntframe;
-	struct pkt_attrib	*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-	int ret = _FAIL;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	ptxmgmt->action_code = TDLS_PEER_TRAFFIC_RESPONSE;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptdls_sta->hwaddr, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) !=_SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv,pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;	
-	}
-
-	dump_mgntframe(padapter, pmgntframe);
-	ret = _SUCCESS;
-
-exit:
-
-	return ret;
-}
-
-int issue_tdls_peer_traffic_indication(_adapter *padapter, struct sta_info *ptdls_sta)
-{
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct tdls_txmgmt txmgmt;
-	int ret = _FAIL;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	txmgmt.action_code = TDLS_PEER_TRAFFIC_INDICATION;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptdls_sta->hwaddr, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	/* PTI frame's priority should be AC_VO */
-	pattrib->priority = 7; 
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-
-	dump_mgntframe(padapter, pmgntframe);
-	ret = _SUCCESS;
-	
-exit:
-
-	return ret;
-}
-
-int issue_tdls_ch_switch_req(_adapter *padapter, struct sta_info *ptdls_sta)
-{
-	struct xmit_frame	*pmgntframe;
-	struct pkt_attrib	*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-	struct tdls_txmgmt txmgmt;
-	int ret = _FAIL;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	if (padapter->tdlsinfo.ch_switch_prohibited == _TRUE)
-	{	DBG_871X("[TDLS] Ignore %s since ch_switch_prohibited = _TRUE\n", __FUNCTION__);
-		goto exit;
-	}
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	txmgmt.action_code = TDLS_CHANNEL_SWITCH_REQUEST;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptdls_sta->hwaddr, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) !=_SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv,pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-
-	dump_mgntframe(padapter, pmgntframe);
-	ret = _SUCCESS;
-exit:
-
-	return ret;
-}
-
-int issue_tdls_ch_switch_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)
-{
-	struct xmit_frame	*pmgntframe;
-	struct pkt_attrib	*pattrib;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-	int ret = _FAIL;
-
-	DBG_871X("[TDLS] %s\n", __FUNCTION__);
-
-	if (padapter->tdlsinfo.ch_switch_prohibited == _TRUE)
-	{	DBG_871X("[TDLS] Ignore %s since ch_switch_prohibited = _TRUE\n", __FUNCTION__);
-		goto exit;
-	}
-
-	ptxmgmt->action_code = TDLS_CHANNEL_SWITCH_RESPONSE;
-
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		goto exit;
-
-	pattrib = &pmgntframe->attrib;
-
-	pmgntframe->frame_tag = DATA_FRAMETAG;
-	pattrib->ether_type = 0x890d;
-
-	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
-	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
-	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
-
-	update_tdls_attrib(padapter, pattrib);
-	pattrib->qsel = pattrib->priority;
-/*
-	_enter_critical_bh(&pxmitpriv->lock, &irqL);
-	if(xmitframe_enqueue_for_tdls_sleeping_sta(padapter, pmgntframe)==_TRUE){
-		_exit_critical_bh(&pxmitpriv->lock, &irqL);
-		return _FALSE;
-	}
-*/
-	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) !=_SUCCESS) {
-		rtw_free_xmitbuf(pxmitpriv,pmgntframe->pxmitbuf);
-		rtw_free_xmitframe(pxmitpriv, pmgntframe);
-		goto exit;
-	}
-
-	if (wait_ack) {
-		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
-	} else {
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
-	}
-	ret = _SUCCESS;
-exit:
-
-	return ret;
-}
-
-int On_TDLS_Dis_Rsp(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct sta_info *ptdls_sta = NULL, *psta = rtw_get_stainfo(&(padapter->stapriv), get_bssid(&(padapter->mlmepriv)));
-	struct recv_priv *precvpriv = &(padapter->recvpriv);
-	u8 *ptr = precv_frame->u.hdr.rx_data, *psa;
-	struct rx_pkt_attrib *pattrib = &(precv_frame->u.hdr.attrib);
-	struct tdls_info *ptdlsinfo = &(padapter->tdlsinfo);
-	u8 empty_addr[ETH_ALEN] = { 0x00 };
-	int UndecoratedSmoothedPWDB;
-	struct tdls_txmgmt txmgmt;	
-	int ret = _SUCCESS;
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	/* WFDTDLS: for sigma test, not to setup direct link automatically */
-	ptdlsinfo->dev_discovered = _TRUE;
-
-	psa = get_sa(ptr);
-	ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), psa);
-	if (ptdls_sta != NULL)
-		ptdls_sta->sta_stats.rx_tdls_disc_rsp_pkts++;
-
-#ifdef CONFIG_TDLS_AUTOSETUP
-	if (ptdls_sta != NULL) {
-		/* Record the tdls sta with lowest signal strength */
-		if (ptdlsinfo->sta_maximum == _TRUE && ptdls_sta->alive_count >= 1 ) {
-			if (_rtw_memcmp(ptdlsinfo->ss_record.macaddr, empty_addr, ETH_ALEN)) {
-				_rtw_memcpy(ptdlsinfo->ss_record.macaddr, psa, ETH_ALEN);
-				ptdlsinfo->ss_record.RxPWDBAll = pattrib->phy_info.RxPWDBAll;
-			} else {
-				if (ptdlsinfo->ss_record.RxPWDBAll < pattrib->phy_info.RxPWDBAll) {
-					_rtw_memcpy(ptdlsinfo->ss_record.macaddr, psa, ETH_ALEN);
-					ptdlsinfo->ss_record.RxPWDBAll = pattrib->phy_info.RxPWDBAll;
-				}
-			}
-		}
-	} else {
-		if (ptdlsinfo->sta_maximum == _TRUE) {
-			if (_rtw_memcmp( ptdlsinfo->ss_record.macaddr, empty_addr, ETH_ALEN)) {
-				/* All traffics are busy, do not set up another direct link. */
-				ret = _FAIL;
-				goto exit;
-			} else {
-				if (pattrib->phy_info.RxPWDBAll > ptdlsinfo->ss_record.RxPWDBAll) {
-					_rtw_memcpy(txmgmt.peer, ptdlsinfo->ss_record.macaddr, ETH_ALEN);
-					/* issue_tdls_teardown(padapter, ptdlsinfo->ss_record.macaddr, _FALSE); */
-				} else {
-					ret = _FAIL;
-					goto exit;
-				}
-			}
-		}
-
-		rtw_hal_get_def_var(padapter, HAL_DEF_UNDERCORATEDSMOOTHEDPWDB, &UndecoratedSmoothedPWDB);
-
-		if (pattrib->phy_info.RxPWDBAll + TDLS_SIGNAL_THRESH >= UndecoratedSmoothedPWDB) {
-			DBG_871X("pattrib->RxPWDBAll=%d, pdmpriv->UndecoratedSmoothedPWDB=%d\n", pattrib->phy_info.RxPWDBAll, UndecoratedSmoothedPWDB);
-			_rtw_memcpy(txmgmt.peer, psa, ETH_ALEN);
-			issue_tdls_setup_req(padapter, &txmgmt, _FALSE);
-		}
-	}
-#endif /* CONFIG_TDLS_AUTOSETUP */
-
-exit:
-	return ret;
-
-}
-
-sint On_TDLS_Setup_Req(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	u8 *psa, *pmyid;
-	struct sta_info *ptdls_sta= NULL;
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-	_irqL irqL;
-	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
-	u8 *prsnie, *ppairwise_cipher;
-	u8 i, k;
-	u8 ccmp_included=0, rsnie_included=0;
-	u16 j, pairwise_count;
-	u8 SNonce[32];
-	u32 timeout_interval = TPK_RESEND_COUNT;
-	sint parsing_length;	/* Frame body length, without icv_len */
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 FIXED_IE = 5;
-	unsigned char		supportRate[16];
-	int				supportRateNum = 0;
-	struct tdls_txmgmt txmgmt;
-
-	if (ptdlsinfo->ap_prohibited == _TRUE)
-		goto exit;
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	psa = get_sa(ptr);
-	ptdls_sta = rtw_get_stainfo(pstapriv, psa);
-
-	pmyid = adapter_mac_addr(padapter);
-	ptr +=prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len+LLC_HEADER_SIZE+ETH_TYPE_LEN+PAYLOAD_TYPE_LEN;
-	parsing_length= ((union recv_frame *)precv_frame)->u.hdr.len
-			-prx_pkt_attrib->hdrlen
-			-prx_pkt_attrib->iv_len
-			-prx_pkt_attrib->icv_len
-			-LLC_HEADER_SIZE
-			-ETH_TYPE_LEN
-			-PAYLOAD_TYPE_LEN
-			-FIXED_IE;
-
-	if (ptdls_sta == NULL) {
-		ptdls_sta = rtw_alloc_stainfo(pstapriv, psa);
-	} else {
-		if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
-			/* If the direct link is already set up */
-			/* Process as re-setup after tear down */
-			DBG_871X("re-setup a direct link\n");
-		}
-		/* Already receiving TDLS setup request */
-		else if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE) {
-			DBG_871X("receive duplicated TDLS setup request frame in handshaking\n");
-			goto exit;
-		}
-		/* When receiving and sending setup_req to the same link at the same time */
-		/* STA with higher MAC_addr would be initiator */
-		else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE) {
-			DBG_871X("receive setup_req after sending setup_req\n");
-			for (i=0;i<6;i++){
-				if(*(pmyid+i)==*(psa+i)){
-				}
-				else if(*(pmyid+i)>*(psa+i)){
-					ptdls_sta->tdls_sta_state = TDLS_INITIATOR_STATE;
-					break;
-				}else if(*(pmyid+i)<*(psa+i)){
-					goto exit;
-				}
-			}
-		}
-	}
-
-	if (ptdls_sta) {
-		txmgmt.dialog_token = *(ptr+2);	/* Copy dialog token */
-		txmgmt.status_code = _STATS_SUCCESSFUL_;
-
-		/* Parsing information element */
-		for (j=FIXED_IE; j<parsing_length;) {
-
-			pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr+ j);
-
-			switch (pIE->ElementID) {
-			case _SUPPORTEDRATES_IE_:
-				_rtw_memcpy(supportRate, pIE->data, pIE->Length);
-				supportRateNum = pIE->Length;
-				break;
-			case _COUNTRY_IE_:
-				break;
-			case _EXT_SUPPORTEDRATES_IE_:
-				if (supportRateNum<=sizeof(supportRate)) {
-					_rtw_memcpy(supportRate+supportRateNum, pIE->data, pIE->Length);
-					supportRateNum += pIE->Length;
-				}
-				break;
-			case _SUPPORTED_CH_IE_:
-				break;
-			case _RSN_IE_2_:
-				rsnie_included=1;
-				if (prx_pkt_attrib->encrypt) {
-					prsnie=(u8*)pIE;
-					/* Check CCMP pairwise_cipher presence. */
-					ppairwise_cipher=prsnie+10;
-					_rtw_memcpy(ptdls_sta->TDLS_RSNIE, pIE->data, pIE->Length);
-					pairwise_count = *(u16*)(ppairwise_cipher-2);
-					for (k=0; k<pairwise_count; k++) {
-						if (_rtw_memcmp( ppairwise_cipher+4*k, RSN_CIPHER_SUITE_CCMP, 4)==_TRUE)
-							ccmp_included=1;
-					}
-
-					if (ccmp_included == 0)
-						txmgmt.status_code=_STATS_INVALID_RSNIE_;
-				}
-				break;
-			case _EXT_CAP_IE_:
-				break;
-			case _VENDOR_SPECIFIC_IE_:
-				break;
-			case _FTIE_:
-				if (prx_pkt_attrib->encrypt)
-					_rtw_memcpy(SNonce, (ptr+j+52), 32);
-				break;
-			case _TIMEOUT_ITVL_IE_:
-				if (prx_pkt_attrib->encrypt)
-					timeout_interval = cpu_to_le32(*(u32*)(ptr+j+3));
-				break;
-			case _RIC_Descriptor_IE_:
-				break;
-#ifdef CONFIG_80211N_HT				
-			case _HT_CAPABILITY_IE_:
-				rtw_tdls_process_ht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
-				break;
-#endif	
-#ifdef CONFIG_80211AC_VHT				
-			case EID_AID:
-				break;
-			case EID_VHTCapability:
-				rtw_tdls_process_vht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
-				break;
-#endif
-			case EID_BSSCoexistence:
-				break;
-			case _LINK_ID_IE_:
-				if (_rtw_memcmp(get_bssid(pmlmepriv), pIE->data, 6) == _FALSE)
-					txmgmt.status_code=_STATS_NOT_IN_SAME_BSS_;
-				break;
-			default:
-				break;
-			}
-
-			j += (pIE->Length + 2);
-			
-		}
-
-		/* Check status code */
-		/* If responder STA has/hasn't security on AP, but request hasn't/has RSNIE, it should reject */
-		if (txmgmt.status_code == _STATS_SUCCESSFUL_) {
-			if (rsnie_included && prx_pkt_attrib->encrypt == 0)
-				txmgmt.status_code = _STATS_SEC_DISABLED_;
-			else if (rsnie_included==0 && prx_pkt_attrib->encrypt)
-				txmgmt.status_code = _STATS_INVALID_PARAMETERS_;
-
-#ifdef CONFIG_WFD
-			/* WFD test plan version 0.18.2 test item 5.1.5 */
-			/* SoUT does not use TDLS if AP uses weak security */
-			if (padapter->wdinfo.wfd_tdls_enable && (rsnie_included && prx_pkt_attrib->encrypt != _AES_))
-					txmgmt.status_code = _STATS_SEC_DISABLED_;
-#endif /* CONFIG_WFD */
-		}
-
-		ptdls_sta->tdls_sta_state|= TDLS_INITIATOR_STATE;
-		if (prx_pkt_attrib->encrypt) {
-			_rtw_memcpy(ptdls_sta->SNonce, SNonce, 32);
-
-			if (timeout_interval <= 300) 
-				ptdls_sta->TDLS_PeerKey_Lifetime = TPK_RESEND_COUNT;
-			else
-				ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
-		}
-
-		/* Update station supportRate */
-		ptdls_sta->bssratelen = supportRateNum;
-		_rtw_memcpy(ptdls_sta->bssrateset, supportRate, supportRateNum);
-
-		if (!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
-			ptdlsinfo->sta_cnt++;
-		/* -2: AP + BC/MC sta, -4: default key */
-		if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
-			ptdlsinfo->sta_maximum = _TRUE;
-
-#ifdef CONFIG_WFD
-		rtw_tdls_process_wfd_ie(ptdlsinfo, ptr + FIXED_IE, parsing_length);
-#endif
-
-	}else {
-		goto exit;
-	}
-
-	_rtw_memcpy(txmgmt.peer, prx_pkt_attrib->src, ETH_ALEN);
-
-	if (rtw_tdls_is_driver_setup(padapter)) {
-		issue_tdls_setup_rsp(padapter, &txmgmt);
-
-		if (txmgmt.status_code==_STATS_SUCCESSFUL_) {
-			_set_timer( &ptdls_sta->handshake_timer, TDLS_HANDSHAKE_TIME);
-		}else {
-			free_tdls_sta(padapter, ptdls_sta);
-		}
-	}
-		
-exit:
-	
-	return _SUCCESS;
-}
-
-int On_TDLS_Setup_Rsp(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct sta_info *ptdls_sta= NULL;
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	_irqL irqL;
-	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
-	u8 *psa;
-	u16 status_code=0;
-	sint parsing_length;	/* Frame body length, without icv_len */
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 FIXED_IE =7;
-	u8 ANonce[32];
-	u8  *pftie=NULL, *ptimeout_ie=NULL, *plinkid_ie=NULL, *prsnie=NULL, *pftie_mic=NULL, *ppairwise_cipher=NULL;
-	u16 pairwise_count, j, k;
-	u8 verify_ccmp=0;
-	unsigned char		supportRate[16];
-	int				supportRateNum = 0;
-	struct tdls_txmgmt txmgmt;
-	int ret = _SUCCESS;
-	u32 timeout_interval = TPK_RESEND_COUNT;
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	psa = get_sa(ptr);
-	ptdls_sta = rtw_get_stainfo(pstapriv, psa);
-
-	if (NULL == ptdls_sta) {
-		ret = _FAIL;
-		goto exit;
-	}
-
-	ptr +=prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len+LLC_HEADER_SIZE+ETH_TYPE_LEN+PAYLOAD_TYPE_LEN;
-	parsing_length= ((union recv_frame *)precv_frame)->u.hdr.len
-			-prx_pkt_attrib->hdrlen
-			-prx_pkt_attrib->iv_len
-			-prx_pkt_attrib->icv_len
-			-LLC_HEADER_SIZE
-			-ETH_TYPE_LEN
-			-PAYLOAD_TYPE_LEN
-			-FIXED_IE;
-
-	_rtw_memcpy(&status_code, ptr+2, 2);
-	
-	if (status_code != 0) {
-		DBG_871X( "[TDLS] %s status_code = %d, free_tdls_sta\n", __FUNCTION__, status_code );
-		free_tdls_sta(padapter, ptdls_sta);
-		ret = _FAIL;
-		goto exit;
-	}
-
-	status_code = 0;
-
-	/* parsing information element */
-	for (j = FIXED_IE; j<parsing_length;) {
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr+ j);
-
-		switch (pIE->ElementID) {
-		case _SUPPORTEDRATES_IE_:
-			_rtw_memcpy(supportRate, pIE->data, pIE->Length);
-			supportRateNum = pIE->Length;
-			break;
-		case _COUNTRY_IE_:
-			break;
-		case _EXT_SUPPORTEDRATES_IE_:
-			if (supportRateNum<=sizeof(supportRate)) {
-				_rtw_memcpy(supportRate+supportRateNum, pIE->data, pIE->Length);
-				supportRateNum += pIE->Length;
-			}
-			break;
-		case _SUPPORTED_CH_IE_:
-			break;
-		case _RSN_IE_2_:
-			prsnie=(u8*)pIE;
-			/* Check CCMP pairwise_cipher presence. */
-			ppairwise_cipher=prsnie+10;
-			_rtw_memcpy(&pairwise_count, (u16*)(ppairwise_cipher-2), 2);
-			for (k=0;k<pairwise_count;k++) {
-				if (_rtw_memcmp( ppairwise_cipher+4*k, RSN_CIPHER_SUITE_CCMP, 4) == _TRUE)
-					verify_ccmp=1;
-			}
-		case _EXT_CAP_IE_:
-			break;
-		case _VENDOR_SPECIFIC_IE_:
-			if (_rtw_memcmp((u8 *)pIE + 2, WMM_INFO_OUI, 6) == _TRUE) {	
-				/* WMM Info ID and OUI */
-				if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
-					ptdls_sta->qos_option = _TRUE;
-			}
-			break;
-		case _FTIE_:
-			pftie=(u8*)pIE;
-			_rtw_memcpy(ANonce, (ptr+j+20), 32);
-			break;
-		case _TIMEOUT_ITVL_IE_:
-			ptimeout_ie=(u8*)pIE;
-			timeout_interval = cpu_to_le32(*(u32*)(ptimeout_ie+3));
-			break;
-		case _RIC_Descriptor_IE_:
-			break;
-#ifdef CONFIG_80211N_HT			
-		case _HT_CAPABILITY_IE_:
-			rtw_tdls_process_ht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
-			break;
-#endif			
-#ifdef CONFIG_80211AC_VHT
-		case EID_AID:
-			/* todo in the future if necessary */
-			break;
-		case EID_VHTCapability:
-			rtw_tdls_process_vht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
-			break;
-		case EID_OpModeNotification:
-			rtw_process_vht_op_mode_notify(padapter, pIE->data, ptdls_sta);
-			break;	
-#endif
-		case EID_BSSCoexistence:
-			break;
-		case _LINK_ID_IE_:
-			plinkid_ie=(u8*)pIE;
-			break;
-		default:
-			break;
-		}
-
-		j += (pIE->Length + 2);
-
-	}
-
-	ptdls_sta->bssratelen = supportRateNum;
-	_rtw_memcpy(ptdls_sta->bssrateset, supportRate, supportRateNum);
-	_rtw_memcpy(ptdls_sta->ANonce, ANonce, 32);
-
-#ifdef CONFIG_WFD
-	rtw_tdls_process_wfd_ie(ptdlsinfo, ptr + FIXED_IE, parsing_length);
-#endif
-
-	if (status_code != _STATS_SUCCESSFUL_) {
-		txmgmt.status_code = status_code;
-	} else {
-		if (prx_pkt_attrib->encrypt) {
-			if (verify_ccmp == 1) {
-				txmgmt.status_code = _STATS_SUCCESSFUL_;
-				if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
-					wpa_tdls_generate_tpk(padapter, ptdls_sta);
-					if (tdls_verify_mic(ptdls_sta->tpk.kck, 2, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL) {
-						DBG_871X( "[TDLS] %s tdls_verify_mic fail, free_tdls_sta\n", __FUNCTION__);
-						free_tdls_sta(padapter, ptdls_sta);
-						ret = _FAIL;
-						goto exit;
-					}
-					ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
-				}
-			}
-			else
-			{
-				txmgmt.status_code = _STATS_INVALID_RSNIE_;
-			}
-
-		}else{
-			txmgmt.status_code = _STATS_SUCCESSFUL_;
-		}
-	}
-
-	if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
-		_rtw_memcpy(txmgmt.peer, prx_pkt_attrib->src, ETH_ALEN);
-		issue_tdls_setup_cfm(padapter, &txmgmt);
-
-		if (txmgmt.status_code == _STATS_SUCCESSFUL_) {
-			ptdlsinfo->link_established = _TRUE;
-
-			if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE) {
-				ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
-				ptdls_sta->state |= _FW_LINKED;
-				_cancel_timer_ex( &ptdls_sta->handshake_timer);
-			}
-
-			if (prx_pkt_attrib->encrypt)
-				rtw_tdls_set_key(padapter, ptdls_sta);
-
-			rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_ESTABLISHED);
-
-		}
-	}
-
-exit:
-	if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
-		return ret;
-	else
-		return _SUCCESS;
-
-}
-
-int On_TDLS_Setup_Cfm(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct sta_info *ptdls_sta= NULL;
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	_irqL irqL;
-	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
-	u8 *psa; 
-	u16 status_code=0;
-	sint parsing_length;
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 FIXED_IE =5;
-	u8  *pftie=NULL, *ptimeout_ie=NULL, *plinkid_ie=NULL, *prsnie=NULL, *pftie_mic=NULL, *ppairwise_cipher=NULL;
-	u16 j, pairwise_count;
-	int ret = _SUCCESS;
-
-	psa = get_sa(ptr);
-	ptdls_sta = rtw_get_stainfo(pstapriv, psa);
-
-	if (ptdls_sta == NULL) {
-		DBG_871X("[%s] Direct Link Peer = "MAC_FMT" not found\n", __FUNCTION__, MAC_ARG(psa));
-		ret = _FAIL;
-		goto exit;
-	}
-
-	ptr +=prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len+LLC_HEADER_SIZE+ETH_TYPE_LEN+PAYLOAD_TYPE_LEN;
-	parsing_length= ((union recv_frame *)precv_frame)->u.hdr.len
-			-prx_pkt_attrib->hdrlen
-			-prx_pkt_attrib->iv_len
-			-prx_pkt_attrib->icv_len
-			-LLC_HEADER_SIZE
-			-ETH_TYPE_LEN
-			-PAYLOAD_TYPE_LEN
-			-FIXED_IE;
-
-	_rtw_memcpy(&status_code, ptr+2, 2);
-
-	if (status_code!= 0) {
-		DBG_871X("[%s] status_code = %d\n, free_tdls_sta", __FUNCTION__, status_code);
-		free_tdls_sta(padapter, ptdls_sta);
-		ret = _FAIL;
-		goto exit;
-	}
-
-	/* Parsing information element */
-	for (j = FIXED_IE; j < parsing_length;) {
-
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
-
-		switch (pIE->ElementID) {
-			case _RSN_IE_2_:
-				prsnie = (u8 *)pIE;
-				break;
-			case _VENDOR_SPECIFIC_IE_:
-				if (_rtw_memcmp((u8 *)pIE + 2, WMM_PARA_OUI, 6) == _TRUE) {	
-					/* WMM Parameter ID and OUI */
-					ptdls_sta->qos_option = _TRUE;
-				}
-				break;				
-			case _FTIE_:
-				pftie = (u8 *)pIE;
-				break;
-			case _TIMEOUT_ITVL_IE_:
-				ptimeout_ie = (u8 *)pIE;
-				break;
-#ifdef CONFIG_80211N_HT				
-			case _HT_EXTRA_INFO_IE_:
-				break;
-#endif
-#ifdef CONFIG_80211AC_VHT
-			case EID_VHTOperation:
-				break;
-			case EID_OpModeNotification:
-				rtw_process_vht_op_mode_notify(padapter, pIE->data, ptdls_sta);
-				break;	
-#endif
-			case _LINK_ID_IE_:
-				plinkid_ie = (u8 *)pIE;
-				break;
-			default:
-				break;
-		}
-
-		j += (pIE->Length + 2);
-		
-	}
-
-	if (prx_pkt_attrib->encrypt) {
-		/* Verify mic in FTIE MIC field */
-		if (rtw_tdls_is_driver_setup(padapter) &&
-			(tdls_verify_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL)) {
-			free_tdls_sta(padapter, ptdls_sta);
-			ret = _FAIL;
-			goto exit;
-		}
-	}
-
-	if (rtw_tdls_is_driver_setup(padapter)) {
-		ptdlsinfo->link_established = _TRUE;
-
-		if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE) {
-			ptdls_sta->tdls_sta_state|=TDLS_LINKED_STATE;
-			ptdls_sta->state |= _FW_LINKED;
-			_cancel_timer_ex(&ptdls_sta->handshake_timer);
-		}
-
-		if (prx_pkt_attrib->encrypt) {
-			rtw_tdls_set_key(padapter, ptdls_sta);
-
-			/* Start  TPK timer */
-			ptdls_sta->TPK_count = 0;
-			_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
-		}
-
-		rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_ESTABLISHED);
-	}
-
-exit:
-	return ret;
-
-}
-
-int On_TDLS_Dis_Req(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta_ap;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	sint parsing_length;	/* Frame body length, without icv_len */
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 FIXED_IE = 3, *dst;
-	u16 j;
-	struct tdls_txmgmt txmgmt;
-	int ret = _SUCCESS;
-
-	if (rtw_tdls_is_driver_setup(padapter) == _FALSE)
-		goto exit;
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	ptr +=prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len+LLC_HEADER_SIZE+ETH_TYPE_LEN+PAYLOAD_TYPE_LEN;
-	txmgmt.dialog_token = *(ptr+2);
-	_rtw_memcpy(&txmgmt.peer, precv_frame->u.hdr.attrib.src, ETH_ALEN);
-	txmgmt.action_code = TDLS_DISCOVERY_RESPONSE;
-	parsing_length= ((union recv_frame *)precv_frame)->u.hdr.len
-			-prx_pkt_attrib->hdrlen
-			-prx_pkt_attrib->iv_len
-			-prx_pkt_attrib->icv_len
-			-LLC_HEADER_SIZE
-			-ETH_TYPE_LEN
-			-PAYLOAD_TYPE_LEN
-			-FIXED_IE;
-
-	/* Parsing information element */
-	for (j=FIXED_IE; j<parsing_length;) {
-
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr+ j);
-
-		switch (pIE->ElementID) {
-		case _LINK_ID_IE_:
-			psta_ap = rtw_get_stainfo(pstapriv, pIE->data);
-			if (psta_ap == NULL)
-				goto exit;
-			dst = pIE->data + 12;
-			if (MacAddr_isBcst(dst) == _FALSE && (_rtw_memcmp(adapter_mac_addr(padapter), dst, 6) == _FALSE))
-				goto exit;
-			break;
-		default:
-			break;
-		}
-
-		j += (pIE->Length + 2);
-		
-	}
-
-	issue_tdls_dis_rsp(padapter, &txmgmt, prx_pkt_attrib->privacy);
-		
-exit:
-	return ret;
-	
-}
-
-int On_TDLS_Teardown(_adapter *padapter, union recv_frame *precv_frame)
-{
-	u8 *psa;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);	
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct sta_priv 	*pstapriv = &padapter->stapriv;
-	struct sta_info *ptdls_sta= NULL;
-	_irqL irqL;
-	u8 reason;
-
-	reason = *(ptr + prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN + 2);
-	DBG_871X("[TDLS] %s Reason code(%d)\n", __FUNCTION__,reason);
-
-	psa = get_sa(ptr);
-
-	ptdls_sta = rtw_get_stainfo(pstapriv, psa);
-	if (ptdls_sta != NULL) {
-		if (rtw_tdls_is_driver_setup(padapter))
-			rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_TEAR_STA);
-	}
-
-	return _SUCCESS;
-	
-}
-
-#if 0
-u8 TDLS_check_ch_state(uint state){
-	if (state & TDLS_CH_SWITCH_ON_STATE &&
-		state & TDLS_PEER_AT_OFF_STATE) {
-		if (state & TDLS_PEER_SLEEP_STATE)
-			return 2;	/* U-APSD + ch. switch */
-		else
-			return 1;	/* ch. switch */
-	}else
-		return 0;
-}
-#endif
-
-int On_TDLS_Peer_Traffic_Indication(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct rx_pkt_attrib	*pattrib = &precv_frame->u.hdr.attrib;
-	struct sta_info *ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pattrib->src);	
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct tdls_txmgmt txmgmt;
-
-	ptr +=pattrib->hdrlen + pattrib->iv_len+LLC_HEADER_SIZE+ETH_TYPE_LEN+PAYLOAD_TYPE_LEN;
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-
-	if (ptdls_sta != NULL) {
-		txmgmt.dialog_token = *(ptr+2);
-		issue_tdls_peer_traffic_rsp(padapter, ptdls_sta, &txmgmt);
-		//issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->hwaddr, 0, 0, 0);
-	} else {
-		DBG_871X("from unknown sta:"MAC_FMT"\n", MAC_ARG(pattrib->src));
-		return _FAIL;
-	}
-
-	return _SUCCESS;
-}
-
-/* We process buffered data for 1. U-APSD, 2. ch. switch, 3. U-APSD + ch. switch here */
-int On_TDLS_Peer_Traffic_Rsp(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct rx_pkt_attrib	*pattrib = & precv_frame->u.hdr.attrib;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->src);
-	u8 wmmps_ac=0;
-	/* u8 state=TDLS_check_ch_state(ptdls_sta->tdls_sta_state); */
-	int i;
-	
-	ptdls_sta->sta_stats.rx_data_pkts++;
-
-	ptdls_sta->tdls_sta_state &= ~(TDLS_WAIT_PTR_STATE);
-
-	/* Check 4-AC queue bit */
-	if (ptdls_sta->uapsd_vo || ptdls_sta->uapsd_vi || ptdls_sta->uapsd_be || ptdls_sta->uapsd_bk)
-		wmmps_ac=1;
-
-	/* If it's a direct link and have buffered frame */
-	if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
-		if (wmmps_ac) {
-			_irqL irqL;	 
-			_list	*xmitframe_plist, *xmitframe_phead;
-			struct xmit_frame *pxmitframe=NULL;
-		
-			_enter_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);	
-
-			xmitframe_phead = get_list_head(&ptdls_sta->sleep_q);
-			xmitframe_plist = get_next(xmitframe_phead);
-
-			/* transmit buffered frames */
-			while (rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist) == _FALSE) {
-				pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
-				xmitframe_plist = get_next(xmitframe_plist);
-				rtw_list_delete(&pxmitframe->list);
-
-				ptdls_sta->sleepq_len--;
-				ptdls_sta->sleepq_ac_len--;
-				if (ptdls_sta->sleepq_len>0) {
-					pxmitframe->attrib.mdata = 1;
-					pxmitframe->attrib.eosp = 0;
-				} else {
-					pxmitframe->attrib.mdata = 0;
-					pxmitframe->attrib.eosp = 1;
-				}
-				pxmitframe->attrib.triggered = 1;
-
-				rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
-			}
-
-			if (ptdls_sta->sleepq_len==0)
-				DBG_871X("no buffered packets for tdls to xmit\n");
-			else {
-				DBG_871X("error!psta->sleepq_len=%d\n", ptdls_sta->sleepq_len);
-				ptdls_sta->sleepq_len=0;
-			}
-
-			_exit_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);			
-		
-		}
-
-	}
-
-	return _SUCCESS;
-}
-
-#ifdef CONFIG_TDLS_CH_SW
-sint On_TDLS_Ch_Switch_Req(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
-	struct sta_info *ptdls_sta= NULL;
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
-	u8 *psa; 
-	sint parsing_length;
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 FIXED_IE = 4;
-	u16 j;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct tdls_txmgmt txmgmt;
-	u16 switch_time= CH_SWITCH_TIME * 1000, switch_timeout=CH_SWITCH_TIMEOUT * 1000;
-
-	if (padapter->tdlsinfo.ch_switch_prohibited == _TRUE)
-	{	DBG_871X("[TDLS] Ignore %s since ch_switch_prohibited = _TRUE\n", __FUNCTION__);
-		return _SUCCESS;
-	}
-	
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	psa = get_sa(ptr);
-	ptdls_sta = rtw_get_stainfo(pstapriv, psa);
-
-	ptdls_sta->ch_switch_time=switch_time;
-	ptdls_sta->ch_switch_timeout=switch_timeout;
-
-	ptr +=prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len+LLC_HEADER_SIZE+ETH_TYPE_LEN+PAYLOAD_TYPE_LEN;
-	parsing_length= ((union recv_frame *)precv_frame)->u.hdr.len
-			-prx_pkt_attrib->hdrlen
-			-prx_pkt_attrib->iv_len
-			-prx_pkt_attrib->icv_len
-			-LLC_HEADER_SIZE
-			-ETH_TYPE_LEN
-			-PAYLOAD_TYPE_LEN
-			-FIXED_IE;
-
-	pchsw_info->off_ch_num = *(ptr + 2);
-
-	if (*(ptr + 2) == 2) {
-		pchsw_info->off_ch_num = 11;
-	}
-
-	if (pchsw_info->off_ch_num != pmlmeext->cur_channel) {
-		pchsw_info->delay_switch_back = _FALSE;
-	}
-
-	/* Parsing information element */
-	for (j=FIXED_IE; j<parsing_length;) {
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr+ j);
-
-		switch (pIE->ElementID) {
-		case EID_SecondaryChnlOffset:
-			padapter->tdlsinfo.chsw_info.ch_offset = *(pIE->data);
-			break;
-		case _LINK_ID_IE_:
-			break;
-		case _CH_SWITCH_TIMING_:
-			ptdls_sta->ch_switch_time = (RTW_GET_LE16(pIE->data) >= CH_SWITCH_TIME * 1000) ?
-				RTW_GET_LE16(pIE->data) : CH_SWITCH_TIME * 1000;
-			ptdls_sta->ch_switch_timeout = (RTW_GET_LE16(pIE->data + 2) >= CH_SWITCH_TIMEOUT * 1000) ?
-				RTW_GET_LE16(pIE->data + 2) : CH_SWITCH_TIMEOUT * 1000;
-			DBG_871X("%s ch_switch_time:%d, ch_switch_timeout:%d\n"
-				, __FUNCTION__, RTW_GET_LE16(pIE->data), RTW_GET_LE16(pIE->data + 2));
-		default:
-			break;
-		}
-
-		j += (pIE->Length + 2);
-	}
-
-	/* Todo: check status */
-	txmgmt.status_code = 0;
-	_rtw_memcpy(txmgmt.peer, psa, ETH_ALEN);
-	
-	ATOMIC_SET(&pchsw_info->chsw_on, _TRUE);
-
-	rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_CH_SW_RESP);
-
-	return _SUCCESS;
-}
-
-sint On_TDLS_Ch_Switch_Rsp(_adapter *padapter, union recv_frame *precv_frame)
-{
-	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
-	struct sta_info *ptdls_sta= NULL;
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
-	u8 *psa; 
-	sint parsing_length;
-	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 FIXED_IE = 4;
-	u16 status_code, j, switch_time, switch_timeout;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	int ret = _SUCCESS;
-
-	if (padapter->tdlsinfo.ch_switch_prohibited == _TRUE)
-	{	DBG_871X("[TDLS] Ignore %s since ch_switch_prohibited = _TRUE\n", __FUNCTION__);
-		return _SUCCESS;
-	}
-
-	psa = get_sa(ptr);
-	ptdls_sta = rtw_get_stainfo(pstapriv, psa);
-
-	/* If we receive Unsolicited TDLS Channel Switch Response when channel switch is running, */
-	/* we will go back to base channel and terminate this channel switch procedure */
-	if (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) {
-		if (pmlmeext->cur_channel != rtw_get_oper_ch(padapter)) {
-			DBG_871X("receive unsolicited channel switch response \n");
-			rtw_tdls_cmd(padapter, NULL, TDLS_CH_SW_BACK);
-			goto exit;
-		}
-	}
-
-	ptr +=prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE+ETH_TYPE_LEN+PAYLOAD_TYPE_LEN;
-	parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
-			-prx_pkt_attrib->hdrlen
-			-prx_pkt_attrib->iv_len
-			-prx_pkt_attrib->icv_len
-			-LLC_HEADER_SIZE
-			-ETH_TYPE_LEN
-			-PAYLOAD_TYPE_LEN
-			-FIXED_IE;
-
-	_rtw_memcpy(&status_code, ptr+2, 2);
-
-	if (status_code != 0) {
-		DBG_871X("[%s] status_code:%d\n", __FUNCTION__, status_code);
-		pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE);
-		ATOMIC_SET(&pchsw_info->chsw_on, _FALSE);
-		ret = _FAIL;
-		goto exit;
-	}
-	
-	/* Parsing information element */
-	for (j = FIXED_IE; j < parsing_length;) {
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr+ j);
-
-		switch (pIE->ElementID) {
-		case _LINK_ID_IE_:
-			break;
-		case _CH_SWITCH_TIMING_:
-			_rtw_memcpy(&switch_time, pIE->data, 2);
-			if (switch_time > ptdls_sta->ch_switch_time)
-				_rtw_memcpy(&ptdls_sta->ch_switch_time, &switch_time, 2);
-
-			_rtw_memcpy(&switch_timeout, pIE->data + 2, 2);
-			if (switch_timeout > ptdls_sta->ch_switch_timeout)
-				_rtw_memcpy(&ptdls_sta->ch_switch_timeout, &switch_timeout, 2);
-			break;
-		default:
-			break;
-		}
-
-		j += (pIE->Length + 2);
-	}
-
-	if ((pmlmeext->cur_channel == rtw_get_oper_ch(padapter)) &&
-		(pchsw_info->ch_sw_state & TDLS_WAIT_CH_RSP_STATE)) {
-		ATOMIC_SET(&pchsw_info->chsw_on, _TRUE);
-		rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_CH_SW);
-	}
-
-exit:
-	return ret;
-}
-#endif /* CONFIG_TDLS_CH_SW */
-
-#ifdef CONFIG_WFD
-void wfd_ie_tdls(_adapter * padapter, u8 *pframe, u32 *pktlen )
-{
-	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct wifi_display_info	*pwfd_info = padapter->tdlsinfo.wfd_info;
-	u8 wfdie[ MAX_WFD_IE_LEN] = { 0x00 };
-	u32 wfdielen = 0;
-
-	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
-		return;
-
-	/* WFD OUI */
-	wfdielen = 0;
-	wfdie[ wfdielen++ ] = 0x50;
-	wfdie[ wfdielen++ ] = 0x6F;
-	wfdie[ wfdielen++ ] = 0x9A;
-	wfdie[ wfdielen++ ] = 0x0A;	/* WFA WFD v1.0 */
-
-	/*
-	 *	Commented by Albert 20110825
-	 *	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes
-	 *	1. WFD Device Information
-	 *	2. Associated BSSID ( Optional )
-	 *	3. Local IP Adress ( Optional )
-	 */
-
-	/* WFD Device Information ATTR */
-	/* Type: */
-	wfdie[ wfdielen++ ] = WFD_ATTR_DEVICE_INFO;
-
-	/* Length: */
-	/* Note: In the WFD specification, the size of length field is 2. */
-	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
-	wfdielen += 2;
-
-	/* Value1: */
-	/* WFD device information */
-	/* available for WFD session + Preferred TDLS + WSD ( WFD Service Discovery ) */
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL 
-								| WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_WSD);
-	wfdielen += 2;
-
-	/* Value2: */
-	/* Session Management Control Port */
-	/* Default TCP port for RTSP messages is 554 */
-	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->tdls_rtsp_ctrlport);
-	wfdielen += 2;
-
-	/* Value3: */
-	/* WFD Device Maximum Throughput */
-	/* 300Mbps is the maximum throughput */
-	RTW_PUT_BE16(wfdie + wfdielen, 300);
-	wfdielen += 2;
-
-	/* Associated BSSID ATTR */
-	/* Type: */
-	wfdie[ wfdielen++ ] = WFD_ATTR_ASSOC_BSSID;
-
-	/* Length: */
-	/* Note: In the WFD specification, the size of length field is 2. */
-	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
-	wfdielen += 2;
-
-	/* Value: */
-	/* Associated BSSID */
-	if (check_fwstate( pmlmepriv, _FW_LINKED) == _TRUE)
-		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[ 0 ], ETH_ALEN);
-	else
-		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
-
-	/* Local IP Address ATTR */
-	wfdie[ wfdielen++ ] = WFD_ATTR_LOCAL_IP_ADDR;
-
-	/* Length: */
-	/* Note: In the WFD specification, the size of length field is 2. */
-	RTW_PUT_BE16(wfdie + wfdielen, 0x0005);
-	wfdielen += 2;
-
-	/* Version: */
-	/* 0x01: Version1;IPv4 */
-	wfdie[ wfdielen++ ] = 0x01;	
-
-	/* IPv4 Address */
-	_rtw_memcpy( wfdie + wfdielen, pwfd_info->ip_address, 4 );
-	wfdielen += 4;
-	
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, pktlen);
-	
-}
-#endif /* CONFIG_WFD */
-
-void rtw_build_tdls_setup_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct sta_info *ptdls_sta=rtw_get_stainfo( (&padapter->stapriv) , pattrib->dst);
-
- 	int i = 0 ;
-	u32 time;
-	u8 *pframe_head;
-
-	/* SNonce */
-	if (pattrib->encrypt) {
-		for (i=0;i<8;i++) {
-			time=rtw_get_current_time();
-			_rtw_memcpy(&ptdls_sta->SNonce[4*i], (u8 *)&time, 4);
-		}
-	}
-
-	pframe_head = pframe;	/* For rtw_tdls_set_ht_cap() */
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-
-	pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
-	pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
-	pframe = rtw_tdls_set_sup_ch(&(padapter->mlmeextpriv), pframe, pattrib);
-	pframe = rtw_tdls_set_sup_reg_class(pframe, pattrib);
-
-	if (pattrib->encrypt)
-		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib,  _TRUE, ptdls_sta);
-
-	pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
-
-	if (pattrib->encrypt) {
-		pframe = rtw_tdls_set_ftie(ptxmgmt
-									, pframe
-									, pattrib
-									, NULL
-									, ptdls_sta->SNonce);
-
-		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
-	}
-
-#ifdef CONFIG_80211N_HT
-	/* Sup_reg_classes(optional) */
-	if (pregistrypriv->ht_enable == _TRUE)
-		pframe = rtw_tdls_set_ht_cap(padapter, pframe_head, pattrib);
-#endif
-
-	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
-
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-
-	if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
-		pframe = rtw_tdls_set_qos_cap(pframe, pattrib);
-
-#ifdef CONFIG_80211AC_VHT
-	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
-		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
-		&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-		&& (!padapter->mlmepriv.country_ent || COUNTRY_CHPLAN_EN_11AC(padapter->mlmepriv.country_ent))
-	) {
-		pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
-		pframe = rtw_tdls_set_vht_cap(padapter, pframe, pattrib);
-	}
-#endif
-
-#ifdef CONFIG_WFD
-	if (padapter->wdinfo.wfd_tdls_enable == 1)
-		wfd_ie_tdls(padapter, pframe, &(pattrib->pktlen));
-#endif
-
-}
-
-void rtw_build_tdls_setup_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct sta_info *ptdls_sta;
-	u8 k; /* for random ANonce */
-	u8  *pftie=NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL;
-	u32 time;
-	u8 *pframe_head;
-
-	ptdls_sta = rtw_get_stainfo( &(padapter->stapriv) , pattrib->dst);
-
-	if (ptdls_sta == NULL)
-		DBG_871X("[%s] %d ptdls_sta is NULL\n", __FUNCTION__, __LINE__);
-
-	if (pattrib->encrypt && ptdls_sta != NULL) {
-		for (k=0;k<8;k++) {
-			time = rtw_get_current_time();
-			_rtw_memcpy(&ptdls_sta->ANonce[4*k], (u8*)&time, 4);
-		}
-	}
-
-	pframe_head = pframe;
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
-
-	if (ptxmgmt->status_code != 0) {
-		DBG_871X("[%s] status_code:%04x \n", __FUNCTION__, ptxmgmt->status_code);
-		return;
-	}
-	
-	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
-	pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
-	pframe = rtw_tdls_set_sup_ch(&(padapter->mlmeextpriv), pframe, pattrib);
-	pframe = rtw_tdls_set_sup_reg_class(pframe, pattrib);
-
-	if (pattrib->encrypt) {
-		prsnie = pframe;
-		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib,  _FALSE, ptdls_sta);
-	}
-
-	pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
-
-	if (pattrib->encrypt) {
-		if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
-			wpa_tdls_generate_tpk(padapter, ptdls_sta);
-
-		pftie = pframe;
-		pftie_mic = pframe+4;
-		pframe = rtw_tdls_set_ftie(ptxmgmt
-									, pframe
-									, pattrib
-									, ptdls_sta->ANonce
-									, ptdls_sta->SNonce);
-
-		ptimeout_ie = pframe;
-		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _FALSE, ptdls_sta);
-	}
-
-#ifdef CONFIG_80211N_HT
-	/* Sup_reg_classes(optional) */
-	if (pregistrypriv->ht_enable == _TRUE)
-		pframe = rtw_tdls_set_ht_cap(padapter, pframe_head, pattrib);
-#endif
-
-	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
-
-	plinkid_ie = pframe;
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
-
-	/* Fill FTIE mic */
-	if (pattrib->encrypt && rtw_tdls_is_driver_setup(padapter) == _TRUE)
-		wpa_tdls_ftie_mic(ptdls_sta->tpk.kck, 2, plinkid_ie, prsnie, ptimeout_ie, pftie, pftie_mic);
-
-	if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
-		pframe = rtw_tdls_set_qos_cap(pframe, pattrib);
-
-#ifdef CONFIG_80211AC_VHT
-	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
-		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
-		&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-		&& (!padapter->mlmepriv.country_ent || COUNTRY_CHPLAN_EN_11AC(padapter->mlmepriv.country_ent))
-	) {
-		pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
-		pframe = rtw_tdls_set_vht_cap(padapter, pframe, pattrib);
-		pframe = rtw_tdls_set_vht_op_mode_notify(padapter, pframe, pattrib, pmlmeext->cur_bwmode);
-	}
-#endif
-
-#ifdef CONFIG_WFD
-	if (padapter->wdinfo.wfd_tdls_enable)
-		wfd_ie_tdls(padapter, pframe, &(pattrib->pktlen));
-#endif
-
-}
-
-void rtw_build_tdls_setup_cfm_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct sta_info *ptdls_sta=rtw_get_stainfo( (&padapter->stapriv) , pattrib->dst);
-
-	unsigned int ie_len;
-	unsigned char *p;
-	u8 wmm_param_ele[24] = {0};
-	u8  *pftie=NULL, *ptimeout_ie=NULL, *plinkid_ie=NULL, *prsnie=NULL, *pftie_mic=NULL;
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-
-	if (ptxmgmt->status_code!=0)
-		return;
-	
-	if (pattrib->encrypt) {
-		prsnie = pframe;
-		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
-	}
-	
-	if (pattrib->encrypt) {
-		pftie = pframe;
-		pftie_mic = pframe+4;
-		pframe = rtw_tdls_set_ftie(ptxmgmt
-									, pframe
-									, pattrib
-									, ptdls_sta->ANonce
-									, ptdls_sta->SNonce);
-
-		ptimeout_ie = pframe;
-		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
-
-		if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
-			/* Start TPK timer */
-			ptdls_sta->TPK_count=0;
-			_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
-		}
-	}
-
-	/* HT operation; todo */
-	
-	plinkid_ie = pframe;
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-
-	if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
-		wpa_tdls_ftie_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie, pftie_mic);
-
-	if (ptdls_sta->qos_option == _TRUE)
-		pframe = rtw_tdls_set_wmm_params(padapter, pframe, pattrib);
-
-#ifdef CONFIG_80211AC_VHT
-	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE)
-		&& (ptdls_sta->vhtpriv.vht_option == _TRUE) && (pmlmeext->cur_channel > 14)
-		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
-		&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-		&& (!padapter->mlmepriv.country_ent || COUNTRY_CHPLAN_EN_11AC(padapter->mlmepriv.country_ent))
-	) {
-		pframe = rtw_tdls_set_vht_operation(padapter, pframe, pattrib, pmlmeext->cur_channel);
-		pframe = rtw_tdls_set_vht_op_mode_notify(padapter, pframe, pattrib, pmlmeext->cur_bwmode);
-	}
-#endif
-}
-
-void rtw_build_tdls_teardown_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct sta_info *ptdls_sta = rtw_get_stainfo( &(padapter->stapriv) , pattrib->dst);
-	u8  *pftie = NULL, *pftie_mic = NULL, *plinkid_ie = NULL;
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
-
-	if (pattrib->encrypt) {
-		pftie = pframe;
-		pftie_mic = pframe + 4;
-		pframe = rtw_tdls_set_ftie(ptxmgmt
-									, pframe
-									, pattrib
-									, ptdls_sta->ANonce
-									, ptdls_sta->SNonce);
-	}
-
-	plinkid_ie = pframe;
-	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
-	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-
-	if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
-		wpa_tdls_teardown_ftie_mic(ptdls_sta->tpk.kck, plinkid_ie, ptxmgmt->status_code, 1, 4, pftie, pftie_mic);
-}
-
-void rtw_build_tdls_dis_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-	struct pkt_attrib *pattrib = &pxmitframe->attrib;
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-
-}
-
-void rtw_build_tdls_dis_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, u8 privacy)
-{
-	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	u8 *pframe_head, pktlen_index;
-
-	pktlen_index = pattrib->pktlen;
-	pframe_head = pframe;
-
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_PUBLIC);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
-
-	pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
-
-	pframe = rtw_tdls_set_sup_ch(pmlmeext, pframe, pattrib);
-
-	if (privacy)
-		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _TRUE, NULL);
-
-	pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
-
-	if (privacy) {
-		pframe = rtw_tdls_set_ftie(ptxmgmt, pframe, pattrib, NULL, NULL);
-		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib,  _TRUE, NULL);
-	}
-
-#ifdef CONFIG_80211N_HT
-	if (pregistrypriv->ht_enable == _TRUE)
-		pframe = rtw_tdls_set_ht_cap(padapter, pframe_head - pktlen_index, pattrib);
-#endif
-
-	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
-
-}
-
-
-void rtw_build_tdls_peer_traffic_indication_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	u8 AC_queue=0;
-	struct sta_info *ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pattrib->dst);
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-
-	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
-	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-
-	/* PTI control */
-	/* PU buffer status */
-	if (ptdls_sta->uapsd_bk & BIT(1))
-		AC_queue=BIT(0);
-	if (ptdls_sta->uapsd_be & BIT(1))
-		AC_queue=BIT(1);
-	if (ptdls_sta->uapsd_vi & BIT(1))
-		AC_queue=BIT(2);
-	if (ptdls_sta->uapsd_vo & BIT(1))
-		AC_queue=BIT(3);
-	pframe = rtw_set_ie(pframe, _PTI_BUFFER_STATUS_, 1, &AC_queue, &(pattrib->pktlen));
-	
-}
-
-void rtw_build_tdls_peer_traffic_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct sta_info *ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pattrib->dst);
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-
-	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
-	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-}
-
-#ifdef CONFIG_TDLS_CH_SW
-void rtw_build_tdls_ch_switch_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct sta_priv 	*pstapriv = &padapter->stapriv;
-	struct sta_info *ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->dst);
-	u16 switch_time= CH_SWITCH_TIME * 1000, switch_timeout=CH_SWITCH_TIMEOUT * 1000;
-
-	ptdls_sta->ch_switch_time=switch_time;
-	ptdls_sta->ch_switch_timeout=switch_timeout;
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_target_ch(padapter, pframe, pattrib);
-	pframe = rtw_tdls_set_reg_class(pframe, pattrib, ptdls_sta);
-
-	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
-	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-
-	pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
-
-}
-
-void rtw_build_tdls_ch_switch_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
-{
-
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct sta_priv 	*pstapriv = &padapter->stapriv;	
-	struct sta_info *ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->dst);
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
-	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
-
-	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
-	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
-
-	pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
-}
-#endif
-
-#ifdef CONFIG_WFD
-void rtw_build_tunneled_probe_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe)
-{
-
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
-	struct wifidirect_info *pbuddy_wdinfo = &padapter->pbuddy_adapter->wdinfo;
-	u8 category = RTW_WLAN_CATEGORY_P2P;
-	u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a};
-	u8 probe_req = 4;
-	u8 wfdielen = 0;
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 3, WFA_OUI, &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(probe_req), &(pattrib->pktlen));
-
-	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
-		wfdielen = build_probe_req_wfd_ie(pwdinfo, pframe);
-		pframe += wfdielen;
-		pattrib->pktlen += wfdielen;
-	} else if (!rtw_p2p_chk_state(pbuddy_wdinfo, P2P_STATE_NONE)) {
-		wfdielen = build_probe_req_wfd_ie(pbuddy_wdinfo, pframe);
-		pframe += wfdielen;
-		pattrib->pktlen += wfdielen;
-	}
-	
-}
-
-void rtw_build_tunneled_probe_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe)
-{
-
-	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
-	struct wifidirect_info *pbuddy_wdinfo = &padapter->pbuddy_adapter->wdinfo;
-	u8 category = RTW_WLAN_CATEGORY_P2P;
-	u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a};
-	u8 probe_rsp = 5;
-	u8 wfdielen = 0;
-
-	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
-	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 3, WFA_OUI, &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(probe_rsp), &(pattrib->pktlen));
-
-	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
-		wfdielen = build_probe_resp_wfd_ie(pwdinfo, pframe, 1);
-		pframe += wfdielen;
-		pattrib->pktlen += wfdielen;
-	} else if (!rtw_p2p_chk_state(pbuddy_wdinfo, P2P_STATE_NONE)) {
-		wfdielen = build_probe_resp_wfd_ie(pbuddy_wdinfo, pframe, 1);
-		pframe += wfdielen;
-		pattrib->pktlen += wfdielen;
-	}
-
-}
-#endif /* CONFIG_WFD */
-
-void _tdls_tpk_timer_hdl(void *FunctionContext)
-{
-	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
-	struct tdls_txmgmt txmgmt;
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	ptdls_sta->TPK_count++;
-	/* TPK_timer expired in a second */
-	/* Retry timer should set at least 301 sec. */
-	if (ptdls_sta->TPK_count >= ptdls_sta->TDLS_PeerKey_Lifetime) {
-		DBG_871X("[TDLS] %s, Re-Setup TDLS link with "MAC_FMT" since TPK lifetime expires!\n", __FUNCTION__, MAC_ARG(ptdls_sta->hwaddr));
-		ptdls_sta->TPK_count=0;
-		_rtw_memcpy(txmgmt.peer, ptdls_sta->hwaddr, ETH_ALEN);
-		issue_tdls_setup_req(ptdls_sta->padapter, &txmgmt, _FALSE);
-	}
-
-	_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
-}
-
-#ifdef CONFIG_TDLS_CH_SW
-void _tdls_ch_switch_timer_hdl(void *FunctionContext)
-{
-	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
-	_adapter *padapter = ptdls_sta->padapter;
-	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
-
-	//DBG_871X("%s %d, tdls_sta_state:0x%08x\n", __FUNCTION__, __LINE__, ptdls_sta->tdls_sta_state);
-
-	if (padapter->mlmeextpriv.cur_channel != rtw_get_oper_ch(padapter)) {
-		if (!(pchsw_info->ch_sw_state & TDLS_PEER_AT_OFF_STATE)) {
-			rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_CH_SW_BACK);
-			ATOMIC_SET(&pchsw_info->chsw_on, _FALSE);
-			DBG_871X("[TDLS] %s, can't get traffic from op_ch:%d\n", __FUNCTION__, rtw_get_oper_ch(padapter));
-		} else {
-			//DBG_871X("%s %d\n", __FUNCTION__, __LINE__);
-			//_set_timer(&ptdls_sta->delay_timer, padapter->mlmeextpriv.mlmext_info.bcn_interval - 5 - ptdls_sta->ch_switch_timeout/1000);
-		}
-	} else {
-		//DBG_871X("%s %d, op_ch:%d, tdls_state:0x%08x\n", __FUNCTION__, __LINE__, rtw_get_oper_ch(padapter), ptdls_sta->tdls_sta_state);
-	}
-
-#if 0
-	if (!(pchsw_info->ch_sw_state & TDLS_PEER_AT_OFF_STATE)) {
-		//SelectChannel(padapter, padapter->mlmeextpriv.cur_channel);
-		ATOMIC_SET(&pchsw_info->chsw_on, _FALSE);
-		DBG_871X("%s %d, op_ch:%d, tdls_state:0x%08x\n", __FUNCTION__, __LINE__, rtw_get_oper_ch(padapter), ptdls_sta->tdls_sta_state);
-	}
-
-	if (pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE) {
-		if (padapter->mlmeextpriv.cur_channel != rtw_get_oper_ch(padapter)) {
-			DBG_871X("%s %d\n", __FUNCTION__, __LINE__);
-			_set_timer(&ptdls_sta->delay_timer, padapter->mlmeextpriv.mlmext_info.bcn_interval - 5 - ptdls_sta->ch_switch_timeout/1000);
-			//_set_timer(&ptdls_sta->delay_timer, 1000);
-		} else {
-			DBG_871X("%s %d\n", __FUNCTION__, __LINE__);
-			issue_tdls_ch_switch_req(padapter, ptdls_sta);
-			//_set_timer(&ptdls_sta->delay_timer, 500);
-		}
-	}
-#endif
-}
-
-void _tdls_delay_timer_hdl(void *FunctionContext)
-{
-	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
-	_adapter *padapter = ptdls_sta->padapter;
-	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
-
-	DBG_871X("[TDLS] %s, op_ch:%d, tdls_state:0x%08x\n", __FUNCTION__, rtw_get_oper_ch(padapter), ptdls_sta->tdls_sta_state);
-	pchsw_info->delay_switch_back = _TRUE;
-}
-#endif
-
-void _tdls_handshake_timer_hdl(void *FunctionContext)
-{
-	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
-	_adapter *padapter = ptdls_sta->padapter;
-	struct tdls_txmgmt txmgmt;
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	_rtw_memcpy(txmgmt.peer, ptdls_sta->hwaddr, ETH_ALEN);
-	txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
-
-	if (ptdls_sta != NULL) {
-		DBG_871X("[TDLS] Handshake time out\n");
-		if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) 
-		{
-			issue_tdls_teardown(padapter, &txmgmt, _TRUE);
-		}
-		else
-		{
-			rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_TEAR_STA);
-		}
-	}
-}
-
-void _tdls_pti_timer_hdl(void *FunctionContext)
-{
-	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
-	_adapter *padapter = ptdls_sta->padapter;
-	struct tdls_txmgmt txmgmt;
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	_rtw_memcpy(txmgmt.peer, ptdls_sta->hwaddr, ETH_ALEN);
-	txmgmt.status_code = _RSON_TDLS_TEAR_TOOFAR_;
-
-	if (ptdls_sta != NULL) {
-		if (ptdls_sta->tdls_sta_state & TDLS_WAIT_PTR_STATE) {
-			DBG_871X("[TDLS] Doesn't receive PTR from peer dev:"MAC_FMT"; "
-				"Send TDLS Tear Down\n", MAC_ARG(ptdls_sta->hwaddr));
-			issue_tdls_teardown(padapter, &txmgmt, _FALSE);
-		}
-	}
-}
-
-void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta)
-{
-	psta->padapter=padapter;
-	_init_timer(&psta->TPK_timer, padapter->pnetdev, _tdls_tpk_timer_hdl, psta);
-#ifdef CONFIG_TDLS_CH_SW	
-	_init_timer(&psta->ch_sw_timer, padapter->pnetdev, _tdls_ch_switch_timer_hdl, psta);
-	_init_timer(&psta->delay_timer, padapter->pnetdev, _tdls_delay_timer_hdl, psta);
-#endif
-	_init_timer(&psta->handshake_timer, padapter->pnetdev, _tdls_handshake_timer_hdl, psta);
-	_init_timer(&psta->pti_timer, padapter->pnetdev, _tdls_pti_timer_hdl, psta);
-}
-
-void rtw_free_tdls_timer(struct sta_info *psta)
-{
-	_cancel_timer_ex(&psta->TPK_timer);
-#ifdef CONFIG_TDLS_CH_SW	
-	_cancel_timer_ex(&psta->ch_sw_timer);
-	_cancel_timer_ex(&psta->delay_timer);
-#endif
-	_cancel_timer_ex(&psta->handshake_timer);
-	_cancel_timer_ex(&psta->pti_timer);
-}
-
-u32 update_mask_tdls(_adapter *padapter, struct sta_info *psta)
-{
-	unsigned char sta_band = 0;
-	unsigned int tx_ra_bitmap=0;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	WLAN_BSSID_EX *pcur_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
-
-	rtw_hal_update_sta_rate_mask(padapter, psta);
-	tx_ra_bitmap = psta->ra_mask;
-
-	if (pcur_network->Configuration.DSConfig > 14) {
-		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;
-
-	psta->raid = rtw_hal_networktype_to_raid(padapter,psta);
-	tx_ra_bitmap |= ((psta->raid<<28)&0xf0000000);
-	return tx_ra_bitmap;
-}
-
-int rtw_tdls_is_driver_setup(_adapter *padapter)
-{
-	return padapter->tdlsinfo.driver_setup;
-}
-
-const char * rtw_tdls_action_txt(enum TDLS_ACTION_FIELD action)
-{
-	switch (action) {
-	case TDLS_SETUP_REQUEST:
-		return "TDLS_SETUP_REQUEST";
-	case TDLS_SETUP_RESPONSE:
-		return "TDLS_SETUP_RESPONSE";
-	case TDLS_SETUP_CONFIRM:
-		return "TDLS_SETUP_CONFIRM";
-	case TDLS_TEARDOWN:
-		return "TDLS_TEARDOWN";
-	case TDLS_PEER_TRAFFIC_INDICATION:
-		return "TDLS_PEER_TRAFFIC_INDICATION";
-	case TDLS_CHANNEL_SWITCH_REQUEST:
-		return "TDLS_CHANNEL_SWITCH_REQUEST";
-	case TDLS_CHANNEL_SWITCH_RESPONSE:
-		return "TDLS_CHANNEL_SWITCH_RESPONSE";
-	case TDLS_PEER_PSM_REQUEST:
-		return "TDLS_PEER_PSM_REQUEST";
-	case TDLS_PEER_PSM_RESPONSE:
-		return "TDLS_PEER_PSM_RESPONSE";
-	case TDLS_PEER_TRAFFIC_RESPONSE:
-		return "TDLS_PEER_TRAFFIC_RESPONSE";
-	case TDLS_DISCOVERY_REQUEST:
-		return "TDLS_DISCOVERY_REQUEST";
-	case TDLS_DISCOVERY_RESPONSE:
-		return "TDLS_DISCOVERY_RESPONSE";
-	default:
-		return "UNKNOWN";
-	}
-}
-
-#endif /* CONFIG_TDLS */
+	tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
+	rtw_vht_nss_to_mcsmap(tx_nss, ptdls_sta->vhtpriv.vht_mcs_map, pcap_mcs);
+	ptdls_sta->vhtpriv.vht_highest_rate = rtw_get_vht_highest_rate(ptdls_sta->vhtpriv.vht_mcs_map);
+}
+
+void rtw_tdls_process_vht_operation(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
+{
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct registry_priv *regsty = adapter_to_regsty(padapter);
+	u8 operation_bw = 0;
+
+	if (GET_VHT_OPERATION_ELE_CHL_WIDTH(data) >= 1) {
+
+		operation_bw = CHANNEL_WIDTH_80;
+
+		if (hal_is_bw_support(padapter, operation_bw) && REGSTY_IS_BW_5G_SUPPORT(regsty, operation_bw)
+			&& (operation_bw <= pmlmeext->cur_bwmode))
+			ptdls_sta->cmn.bw_mode = operation_bw;
+		else
+			ptdls_sta->cmn.bw_mode = pmlmeext->cur_bwmode;
+	} else
+		ptdls_sta->cmn.bw_mode = pmlmeext->cur_bwmode;
+}
+
+void rtw_tdls_process_vht_op_mode_notify(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
+{
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct registry_priv *regsty = adapter_to_regsty(padapter);
+	u8	target_bw;
+	u8	target_rxss, current_rxss;
+
+	if (pvhtpriv->vht_option == _FALSE)
+		return;
+
+	target_bw = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(data);
+	target_rxss = (GET_VHT_OPERATING_MODE_FIELD_RX_NSS(data) + 1);
+
+	if (hal_is_bw_support(padapter, target_bw) && REGSTY_IS_BW_5G_SUPPORT(regsty, target_bw)
+		&& (target_bw <= pmlmeext->cur_bwmode))
+		ptdls_sta->cmn.bw_mode = target_bw;
+	else
+		ptdls_sta->cmn.bw_mode = pmlmeext->cur_bwmode;
+
+	current_rxss = rtw_vht_mcsmap_to_nss(ptdls_sta->vhtpriv.vht_mcs_map);
+	if (target_rxss != current_rxss) {
+		u8	vht_mcs_map[2] = {};
+
+		rtw_vht_nss_to_mcsmap(target_rxss, vht_mcs_map, ptdls_sta->vhtpriv.vht_mcs_map);
+		_rtw_memcpy(ptdls_sta->vhtpriv.vht_mcs_map, vht_mcs_map, 2);
+	}
+}
+
+u8 *rtw_tdls_set_aid(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	return rtw_set_ie(pframe, EID_AID, 2, (u8 *)&(padapter->mlmepriv.cur_network.aid), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_vht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	u32 ie_len = 0;
+
+	rtw_vht_use_default_setting(padapter);
+
+	ie_len = rtw_build_vht_cap_ie(padapter, pframe);
+	pattrib->pktlen += ie_len;
+
+	return pframe + ie_len;
+}
+
+u8 *rtw_tdls_set_vht_operation(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 channel)
+{
+	u32 ie_len = 0;
+
+	ie_len = rtw_build_vht_operation_ie(padapter, pframe, channel);
+	pattrib->pktlen += ie_len;
+
+	return pframe + ie_len;
+}
+
+u8 *rtw_tdls_set_vht_op_mode_notify(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 bw)
+{
+	u32 ie_len = 0;
+
+	ie_len = rtw_build_vht_op_mode_notify_ie(padapter, pframe, bw);
+	pattrib->pktlen += ie_len;
+
+	return pframe + ie_len;
+}
+#endif
+
+
+u8 *rtw_tdls_set_sup_ch(_adapter *adapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u8 sup_ch[30 * 2] = {0x00}, ch_set_idx = 0, sup_ch_idx = 2;
+
+	while (ch_set_idx < rfctl->max_chan_nums && rfctl->channel_set[ch_set_idx].ChannelNum != 0) {
+		if (rfctl->channel_set[ch_set_idx].ChannelNum <= 14) {
+			/* TODO: fix 2.4G supported channel when channel doesn't start from 1 and continuous */
+			sup_ch[0] = 1;	/* First channel number */
+			sup_ch[1] = rfctl->channel_set[ch_set_idx].ChannelNum;	/* Number of channel */
+		} else {
+			sup_ch[sup_ch_idx++] = rfctl->channel_set[ch_set_idx].ChannelNum;
+			sup_ch[sup_ch_idx++] = 1;
+		}
+		ch_set_idx++;
+	}
+
+	return rtw_set_ie(pframe, _SUPPORTED_CH_IE_, sup_ch_idx, sup_ch, &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_rsnie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib,  int init, struct sta_info *ptdls_sta)
+{
+	u8 *p = NULL;
+	int len = 0;
+
+	if (ptxmgmt->len > 0)
+		p = rtw_get_ie(ptxmgmt->buf, _RSN_IE_2_, &len, ptxmgmt->len);
+
+	if (p != NULL)
+		return rtw_set_ie(pframe, _RSN_IE_2_, len, p + 2, &(pattrib->pktlen));
+	else if (init == _TRUE)
+		return rtw_set_ie(pframe, _RSN_IE_2_, sizeof(TDLS_RSNIE), TDLS_RSNIE, &(pattrib->pktlen));
+	else
+		return rtw_set_ie(pframe, _RSN_IE_2_, sizeof(ptdls_sta->TDLS_RSNIE), ptdls_sta->TDLS_RSNIE, &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_ext_cap(u8 *pframe, struct pkt_attrib *pattrib)
+{
+	return rtw_set_ie(pframe, _EXT_CAP_IE_ , sizeof(TDLS_EXT_CAPIE), TDLS_EXT_CAPIE, &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_qos_cap(u8 *pframe, struct pkt_attrib *pattrib)
+{
+	return rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, sizeof(TDLS_WMMIE), TDLS_WMMIE,  &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_ftie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, u8 *ANonce, u8 *SNonce)
+{
+	struct wpa_tdls_ftie FTIE = {0};
+	u8 *p = NULL;
+	int len = 0;
+
+	if (ptxmgmt->len > 0)
+		p = rtw_get_ie(ptxmgmt->buf, _FTIE_, &len, ptxmgmt->len);
+
+	if (p != NULL)
+		return rtw_set_ie(pframe, _FTIE_, len, p + 2, &(pattrib->pktlen));
+	else {
+		if (ANonce != NULL)
+			_rtw_memcpy(FTIE.Anonce, ANonce, WPA_NONCE_LEN);
+		if (SNonce != NULL)
+			_rtw_memcpy(FTIE.Snonce, SNonce, WPA_NONCE_LEN);
+
+		return rtw_set_ie(pframe, _FTIE_, TDLS_FTIE_DATA_LEN,
+						  (u8 *)FTIE.data, &(pattrib->pktlen));
+	}
+}
+
+u8 *rtw_tdls_set_timeout_interval(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, int init, struct sta_info *ptdls_sta)
+{
+	u8 timeout_itvl[5];	/* set timeout interval to maximum value */
+	u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
+	u8 *p = NULL;
+	int len = 0;
+
+	if (ptxmgmt->len > 0)
+		p = rtw_get_ie(ptxmgmt->buf, _TIMEOUT_ITVL_IE_, &len, ptxmgmt->len);
+
+	if (p != NULL)
+		return rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, len, p + 2, &(pattrib->pktlen));
+	else {
+		/* Timeout interval */
+		timeout_itvl[0] = 0x02;
+		if (init == _TRUE)
+			_rtw_memcpy(timeout_itvl + 1, &timeout_interval, 4);
+		else
+			_rtw_memcpy(timeout_itvl + 1, (u8 *)(&ptdls_sta->TDLS_PeerKey_Lifetime), 4);
+
+		return rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, 5, timeout_itvl, &(pattrib->pktlen));
+	}
+}
+
+u8 *rtw_tdls_set_bss_coexist(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	u8 iedata = 0;
+
+	if (padapter->mlmepriv.num_FortyMHzIntolerant > 0)
+		iedata |= BIT(2);	/* 20 MHz BSS Width Request */
+
+	/* Information Bit should be set by TDLS test plan 5.9 */
+	iedata |= BIT(0);
+	return rtw_set_ie(pframe, EID_BSSCoexistence, 1, &iedata, &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_payload_type(u8 *pframe, struct pkt_attrib *pattrib)
+{
+	u8 payload_type = 0x02;
+	return rtw_set_fixed_ie(pframe, 1, &(payload_type), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_category(u8 *pframe, struct pkt_attrib *pattrib, u8 category)
+{
+	return rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_action(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
+{
+	return rtw_set_fixed_ie(pframe, 1, &(ptxmgmt->action_code), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_status_code(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
+{
+	return rtw_set_fixed_ie(pframe, 2, (u8 *)&(ptxmgmt->status_code), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_dialog(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
+{
+	u8 dialogtoken = 1;
+	if (ptxmgmt->dialog_token)
+		return rtw_set_fixed_ie(pframe, 1, &(ptxmgmt->dialog_token), &(pattrib->pktlen));
+	else
+		return rtw_set_fixed_ie(pframe, 1, &(dialogtoken), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_reg_class(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)
+{
+	u8 reg_class = 22;
+	return rtw_set_fixed_ie(pframe, 1, &(reg_class), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_second_channel_offset(u8 *pframe, struct pkt_attrib *pattrib, u8 ch_offset)
+{
+	return rtw_set_ie(pframe, EID_SecondaryChnlOffset , 1, &ch_offset, &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_capability(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &pmlmeext->mlmext_info;
+	u8 cap_from_ie[2] = {0};
+
+	_rtw_memcpy(cap_from_ie, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
+
+	return rtw_set_fixed_ie(pframe, 2, cap_from_ie, &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_supported_rate(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	u8 bssrate[NDIS_802_11_LENGTH_RATES_EX];
+	int bssrate_len = 0;
+	u8 more_supportedrates = 0;
+
+	rtw_set_supported_rate(bssrate, (padapter->registrypriv.wireless_mode == WIRELESS_MODE_MAX) ? padapter->mlmeextpriv.cur_wireless_mode : padapter->registrypriv.wireless_mode);
+	bssrate_len = rtw_get_rateset_len(bssrate);
+
+	if (bssrate_len > 8) {
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
+		more_supportedrates = 1;
+	} else
+		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
+
+	/* extended supported rates */
+	if (more_supportedrates == 1)
+		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
+
+	return pframe;
+}
+
+u8 *rtw_tdls_set_sup_reg_class(u8 *pframe, struct pkt_attrib *pattrib)
+{
+	return rtw_set_ie(pframe, _SRC_IE_ , sizeof(TDLS_SRC), TDLS_SRC, &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_linkid(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 init)
+{
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	u8 link_id_addr[18] = {0};
+
+	_rtw_memcpy(link_id_addr, get_my_bssid(&(pmlmeinfo->network)), 6);
+
+	if (init == _TRUE) {
+		_rtw_memcpy((link_id_addr + 6), pattrib->src, 6);
+		_rtw_memcpy((link_id_addr + 12), pattrib->dst, 6);
+	} else {
+		_rtw_memcpy((link_id_addr + 6), pattrib->dst, 6);
+		_rtw_memcpy((link_id_addr + 12), pattrib->src, 6);
+	}
+	return rtw_set_ie(pframe, _LINK_ID_IE_, 18, link_id_addr, &(pattrib->pktlen));
+}
+
+#ifdef CONFIG_TDLS_CH_SW
+u8 *rtw_tdls_set_target_ch(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	u8 target_ch = 1;
+	if (padapter->tdlsinfo.chsw_info.off_ch_num)
+		return rtw_set_fixed_ie(pframe, 1, &(padapter->tdlsinfo.chsw_info.off_ch_num), &(pattrib->pktlen));
+	else
+		return rtw_set_fixed_ie(pframe, 1, &(target_ch), &(pattrib->pktlen));
+}
+
+u8 *rtw_tdls_set_ch_sw(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)
+{
+	u8 ch_switch_timing[4] = {0};
+	u16 switch_time = (ptdls_sta->ch_switch_time >= TDLS_CH_SWITCH_TIME * 1000) ?
+			  ptdls_sta->ch_switch_time : TDLS_CH_SWITCH_TIME;
+	u16 switch_timeout = (ptdls_sta->ch_switch_timeout >= TDLS_CH_SWITCH_TIMEOUT * 1000) ?
+		     ptdls_sta->ch_switch_timeout : TDLS_CH_SWITCH_TIMEOUT;
+
+	_rtw_memcpy(ch_switch_timing, &switch_time, 2);
+	_rtw_memcpy(ch_switch_timing + 2, &switch_timeout, 2);
+
+	return rtw_set_ie(pframe, _CH_SWITCH_TIMING_,  4, ch_switch_timing, &(pattrib->pktlen));
+}
+
+void rtw_tdls_set_ch_sw_oper_control(_adapter *padapter, u8 enable)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+
+	if (enable == _TRUE) {
+#ifdef CONFIG_TDLS_CH_SW_V2
+		pHalData->ch_switch_offload = _TRUE;
+#endif
+
+#ifdef CONFIG_TDLS_CH_SW_BY_DRV
+		pHalData->ch_switch_offload = _FALSE;
+#endif
+	}
+	else
+		pHalData->ch_switch_offload = _FALSE;
+	
+	if (ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on) != enable)
+		ATOMIC_SET(&padapter->tdlsinfo.chsw_info.chsw_on, enable);
+
+	rtw_hal_set_hwreg(padapter, HW_VAR_TDLS_BCN_EARLY_C2H_RPT, &enable);
+	RTW_INFO("[TDLS] %s Bcn Early C2H Report\n", (enable == _TRUE) ? "Start" : "Stop");
+}
+
+void rtw_tdls_ch_sw_back_to_base_chnl(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv;
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+
+	pmlmepriv = &padapter->mlmepriv;
+
+	if ((ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) &&
+	    (padapter->mlmeextpriv.cur_channel != rtw_get_oper_ch(padapter)))
+		rtw_tdls_cmd(padapter, pchsw_info->addr, TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED);
+}
+
+static void rtw_tdls_chsw_oper_init(_adapter *padapter, u32 timeout_ms)
+{
+	struct submit_ctx	*chsw_sctx = &padapter->tdlsinfo.chsw_info.chsw_sctx;
+
+	rtw_sctx_init(chsw_sctx, timeout_ms);
+}
+
+static int rtw_tdls_chsw_oper_wait(_adapter *padapter)
+{
+	struct submit_ctx	*chsw_sctx = &padapter->tdlsinfo.chsw_info.chsw_sctx;
+
+	return rtw_sctx_wait(chsw_sctx, __func__);
+}
+
+void rtw_tdls_chsw_oper_done(_adapter *padapter)
+{
+	struct submit_ctx	*chsw_sctx = &padapter->tdlsinfo.chsw_info.chsw_sctx;
+
+	rtw_sctx_done(&chsw_sctx);
+}
+
+s32 rtw_tdls_do_ch_sw(_adapter *padapter, struct sta_info *ptdls_sta, u8 chnl_type, u8 channel, u8 channel_offset, u16 bwmode, u16 ch_switch_time)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	u32 ch_sw_time_start, ch_sw_time_spent, wait_time;
+	u8 take_care_iqk;
+	s32 ret = _FAIL;
+
+	ch_sw_time_start = rtw_systime_to_ms(rtw_get_current_time());
+
+	/* set mac_id sleep before channel switch */
+	rtw_hal_macid_sleep(padapter, ptdls_sta->cmn.mac_id);
+
+#if defined(CONFIG_TDLS_CH_SW_BY_DRV) || defined(CONFIG_TDLS_CH_SW_V2)
+	set_channel_bwmode(padapter, channel, channel_offset, bwmode);
+	ret = _SUCCESS;
+#else
+	rtw_tdls_chsw_oper_init(padapter, TDLS_CH_SWITCH_OPER_OFFLOAD_TIMEOUT);
+
+	/* channel switch IOs offload to FW */
+	if (rtw_hal_ch_sw_oper_offload(padapter, channel, channel_offset, bwmode) == _SUCCESS) {
+		if (rtw_tdls_chsw_oper_wait(padapter) == _SUCCESS) {
+			/* set channel and bw related variables in driver */
+			_enter_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
+
+			rtw_set_oper_ch(padapter, channel);
+			rtw_set_oper_choffset(padapter, channel_offset);
+			rtw_set_oper_bw(padapter, bwmode);
+
+			center_ch = rtw_get_center_ch(channel, bwmode, channel_offset);
+			pHalData->current_channel = center_ch;
+			pHalData->CurrentCenterFrequencyIndex1 = center_ch;
+			pHalData->current_channel_bw = bwmode;
+			pHalData->nCur40MhzPrimeSC = channel_offset;
+
+			if (bwmode == CHANNEL_WIDTH_80) {
+				if (center_ch > channel)
+					chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
+				else if (center_ch < channel)
+					chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
+				else
+					chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			}
+			pHalData->nCur80MhzPrimeSC = chnl_offset80;
+
+			pHalData->CurrentCenterFrequencyIndex1 = center_ch;
+
+			_exit_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
+
+			rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
+			if (take_care_iqk == _TRUE)
+				rtw_hal_ch_sw_iqk_info_restore(padapter, CH_SW_USE_CASE_TDLS);
+
+			ret = _SUCCESS;
+		} else
+			RTW_INFO("[TDLS] chsw oper wait fail !!\n");
+	}
+#endif
+
+	if (ret == _SUCCESS) {
+		ch_sw_time_spent = rtw_systime_to_ms(rtw_get_current_time()) - ch_sw_time_start;
+		if (chnl_type == TDLS_CH_SW_OFF_CHNL) {
+			if ((u32)ch_switch_time / 1000 > ch_sw_time_spent)
+				wait_time = (u32)ch_switch_time / 1000 - ch_sw_time_spent;
+			else
+				wait_time = 0;
+
+			if (wait_time > 0)
+				rtw_msleep_os(wait_time);
+		}
+	}
+
+	/* set mac_id wakeup after channel switch */
+	rtw_hal_macid_wakeup(padapter, ptdls_sta->cmn.mac_id);
+
+	return ret;
+}
+#endif
+
+u8 *rtw_tdls_set_wmm_params(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
+{
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8 wmm_param_ele[24] = {0};
+
+	if (&pmlmeinfo->WMM_param) {
+		_rtw_memcpy(wmm_param_ele, WMM_PARA_OUI, 6);
+		if (_rtw_memcmp(&pmlmeinfo->WMM_param, &wmm_param_ele[6], 18) == _TRUE)
+			/* Use default WMM Param */
+			_rtw_memcpy(wmm_param_ele + 6, (u8 *)&TDLS_WMM_PARAM_IE, sizeof(TDLS_WMM_PARAM_IE));
+		else
+			_rtw_memcpy(wmm_param_ele + 6, (u8 *)&pmlmeinfo->WMM_param, sizeof(pmlmeinfo->WMM_param));
+		return rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_,  24, wmm_param_ele, &(pattrib->pktlen));
+	} else
+		return pframe;
+}
+
+#ifdef CONFIG_WFD
+void rtw_tdls_process_wfd_ie(struct tdls_info *ptdlsinfo, u8 *ptr, u8 length)
+{
+	u8 *wfd_ie;
+	u32	wfd_ielen = 0;
+
+	if (!hal_chk_wl_func(tdls_info_to_adapter(ptdlsinfo), WL_FUNC_MIRACAST))
+		return;
+
+	/* Try to get the TCP port information when receiving the negotiation response. */
+
+	wfd_ie = rtw_get_wfd_ie(ptr, length, NULL, &wfd_ielen);
+	while (wfd_ie) {
+		u8 *attr_content;
+		u32	attr_contentlen = 0;
+		int	i;
+
+		RTW_INFO("[%s] WFD IE Found!!\n", __FUNCTION__);
+		attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &attr_contentlen);
+		if (attr_content && attr_contentlen) {
+			ptdlsinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
+			RTW_INFO("[%s] Peer PORT NUM = %d\n", __FUNCTION__, ptdlsinfo->wfd_info->peer_rtsp_ctrlport);
+		}
+
+		attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_LOCAL_IP_ADDR, NULL, &attr_contentlen);
+		if (attr_content && attr_contentlen) {
+			_rtw_memcpy(ptdlsinfo->wfd_info->peer_ip_address, (attr_content + 1), 4);
+			RTW_INFO("[%s] Peer IP = %02u.%02u.%02u.%02u\n", __FUNCTION__,
+				ptdlsinfo->wfd_info->peer_ip_address[0], ptdlsinfo->wfd_info->peer_ip_address[1],
+				ptdlsinfo->wfd_info->peer_ip_address[2], ptdlsinfo->wfd_info->peer_ip_address[3]);
+		}
+
+		wfd_ie = rtw_get_wfd_ie(wfd_ie + wfd_ielen, (ptr + length) - (wfd_ie + wfd_ielen), NULL, &wfd_ielen);
+	}
+}
+
+int issue_tunneled_probe_req(_adapter *padapter)
+{
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	u8 baddr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	struct tdls_txmgmt txmgmt;
+	int ret = _FAIL;
+
+	RTW_INFO("[%s]\n", __FUNCTION__);
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	txmgmt.action_code = TUNNELED_PROBE_REQ;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, baddr, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+	dump_mgntframe(padapter, pmgntframe);
+	ret = _SUCCESS;
+exit:
+
+	return ret;
+}
+
+int issue_tunneled_probe_rsp(_adapter *padapter, union recv_frame *precv_frame)
+{
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct tdls_txmgmt txmgmt;
+	int ret = _FAIL;
+
+	RTW_INFO("[%s]\n", __FUNCTION__);
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	txmgmt.action_code = TUNNELED_PROBE_RSP;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, precv_frame->u.hdr.attrib.src, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+	dump_mgntframe(padapter, pmgntframe);
+	ret = _SUCCESS;
+exit:
+
+	return ret;
+}
+#endif /* CONFIG_WFD */
+
+int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)
+{
+	struct tdls_info	*ptdlsinfo = &padapter->tdlsinfo;
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *ptdls_sta = NULL;
+	_irqL irqL;
+	int ret = _FAIL;
+	/* Retry timer should be set at least 301 sec, using TPK_count counting 301 times. */
+	u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	if (rtw_tdls_is_setup_allowed(padapter) == _FALSE)
+		goto exit;
+
+	if (IS_MCAST(ptxmgmt->peer))
+		goto exit;
+
+	ptdls_sta = rtw_get_stainfo(pstapriv, ptxmgmt->peer);
+	if (ptdlsinfo->sta_maximum == _TRUE) {
+		if (ptdls_sta == NULL)
+			goto exit;
+		else if (!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
+			goto exit;
+	}
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	if (ptdls_sta == NULL) {
+		ptdls_sta = rtw_alloc_stainfo(pstapriv, ptxmgmt->peer);
+		if (ptdls_sta == NULL) {
+			RTW_INFO("[%s] rtw_alloc_stainfo fail\n", __FUNCTION__);
+			rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+			rtw_free_xmitframe(pxmitpriv, pmgntframe);
+			goto exit;
+		}
+		ptdlsinfo->sta_cnt++;
+	}
+
+	ptxmgmt->action_code = TDLS_SETUP_REQUEST;
+
+	pattrib = &pmgntframe->attrib;
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+
+	if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
+		ptdlsinfo->sta_maximum  = _TRUE;
+
+	ptdls_sta->tdls_sta_state |= TDLS_RESPONDER_STATE;
+
+	if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
+		ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
+		_set_timer(&ptdls_sta->handshake_timer, TDLS_HANDSHAKE_TIME);
+	}
+
+	pattrib->qsel = pattrib->priority;
+
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	if (wait_ack)
+		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
+	else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
+
+exit:
+
+	return ret;
+}
+
+int _issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta, u8 wait_ack)
+{
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	_irqL irqL;
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	ptxmgmt->action_code = TDLS_TEARDOWN;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	rtw_mi_set_scan_deny(padapter, 550);
+	rtw_mi_scan_abort(padapter, _TRUE);
+
+	pattrib = &pmgntframe->attrib;
+
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+
+	if (ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_)
+		_rtw_memcpy(pattrib->ra, ptxmgmt->peer, ETH_ALEN);
+	else
+		_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
+
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
+		if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
+			if (pattrib->encrypt)
+				_cancel_timer_ex(&ptdls_sta->TPK_timer);
+
+	if (wait_ack)
+		ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
+	else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
+
+exit:
+
+	return ret;
+}
+
+int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)
+{
+	struct sta_info *ptdls_sta = NULL;
+	int ret = _FAIL;
+
+	ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), ptxmgmt->peer);
+	if (ptdls_sta == NULL) {
+		RTW_INFO("No tdls_sta for tearing down\n");
+		goto exit;
+	}
+
+	ret = _issue_tdls_teardown(padapter, ptxmgmt, ptdls_sta, wait_ack);
+	if ((ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_) && (ret == _FAIL)) {
+		/* Change status code and send teardown again via AP */
+		ptxmgmt->status_code = _RSON_TDLS_TEAR_TOOFAR_;
+		ret = _issue_tdls_teardown(padapter, ptxmgmt, ptdls_sta, wait_ack);
+	}
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptxmgmt->peer, TDLS_TEARDOWN_STA_LOCALLY_POST);
+	}
+
+exit:
+	return ret;
+}
+
+int issue_tdls_dis_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
+{
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	ptxmgmt->action_code = TDLS_DISCOVERY_REQUEST;
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+	dump_mgntframe(padapter, pmgntframe);
+	RTW_INFO("issue tdls dis req\n");
+
+	ret = _SUCCESS;
+exit:
+
+	return ret;
+}
+
+int issue_tdls_setup_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
+{
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	ptxmgmt->action_code = TDLS_SETUP_RESPONSE;
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, get_bssid(&(padapter->mlmepriv)), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	dump_mgntframe(padapter, pmgntframe);
+
+	ret = _SUCCESS;
+exit:
+
+	return ret;
+
+}
+
+int issue_tdls_setup_cfm(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	ptxmgmt->action_code = TDLS_SETUP_CONFIRM;
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, get_bssid(&padapter->mlmepriv), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	dump_mgntframe(padapter, pmgntframe);
+
+	ret = _SUCCESS;
+exit:
+
+	return ret;
+
+}
+
+/* TDLS Discovery Response frame is a management action frame */
+int issue_tdls_dis_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 privacy)
+{
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	unsigned char			*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	unsigned short		*fctrl;
+	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	/* unicast probe request frame */
+	_rtw_memcpy(pwlanhdr->addr1, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->dst, pwlanhdr->addr1, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->src, pwlanhdr->addr2, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, pwlanhdr->addr3, ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	rtw_build_tdls_dis_rsp_ies(padapter, pmgntframe, pframe, ptxmgmt, privacy);
+
+	pattrib->nr_frags = 1;
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(padapter, pmgntframe);
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+int issue_tdls_peer_traffic_rsp(_adapter *padapter, struct sta_info *ptdls_sta, struct tdls_txmgmt *ptxmgmt)
+{
+	struct xmit_frame	*pmgntframe;
+	struct pkt_attrib	*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	ptxmgmt->action_code = TDLS_PEER_TRAFFIC_RESPONSE;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	dump_mgntframe(padapter, pmgntframe);
+	ret = _SUCCESS;
+
+exit:
+
+	return ret;
+}
+
+int issue_tdls_peer_traffic_indication(_adapter *padapter, struct sta_info *ptdls_sta)
+{
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct tdls_txmgmt txmgmt;
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	txmgmt.action_code = TDLS_PEER_TRAFFIC_INDICATION;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	/* PTI frame's priority should be AC_VO */
+	pattrib->priority = 7;
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	dump_mgntframe(padapter, pmgntframe);
+	ret = _SUCCESS;
+
+exit:
+
+	return ret;
+}
+
+#ifdef CONFIG_TDLS_CH_SW
+int issue_tdls_ch_switch_req(_adapter *padapter, struct sta_info *ptdls_sta)
+{
+	struct xmit_frame	*pmgntframe;
+	struct pkt_attrib	*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	struct tdls_txmgmt txmgmt;
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
+		goto exit;
+	}
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	txmgmt.action_code = TDLS_CHANNEL_SWITCH_REQUEST;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	dump_mgntframe(padapter, pmgntframe);
+	ret = _SUCCESS;
+exit:
+
+	return ret;
+}
+
+int issue_tdls_ch_switch_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)
+{
+	struct xmit_frame	*pmgntframe;
+	struct pkt_attrib	*pattrib;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	int ret = _FAIL;
+
+	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
+
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
+		goto exit;
+	}
+
+	ptxmgmt->action_code = TDLS_CHANNEL_SWITCH_RESPONSE;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		goto exit;
+
+	pattrib = &pmgntframe->attrib;
+
+	pmgntframe->frame_tag = DATA_FRAMETAG;
+	pattrib->ether_type = 0x890d;
+
+	_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pattrib->ra, ptxmgmt->peer, ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
+
+	update_tdls_attrib(padapter, pattrib);
+	pattrib->qsel = pattrib->priority;
+	/*
+		_enter_critical_bh(&pxmitpriv->lock, &irqL);
+		if(xmitframe_enqueue_for_tdls_sleeping_sta(padapter, pmgntframe)==_TRUE){
+			_exit_critical_bh(&pxmitpriv->lock, &irqL);
+			return _FALSE;
+		}
+	*/
+	if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		goto exit;
+	}
+
+	if (wait_ack)
+		ret = dump_mgntframe_and_wait_ack_timeout(padapter, pmgntframe, 10);
+	else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
+exit:
+
+	return ret;
+}
+#endif
+
+int On_TDLS_Dis_Rsp(_adapter *padapter, union recv_frame *precv_frame)
+{
+	struct sta_info *ptdls_sta = NULL, *psta = rtw_get_stainfo(&(padapter->stapriv), get_bssid(&(padapter->mlmepriv)));
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	u8 *ptr = precv_frame->u.hdr.rx_data, *psa;
+	struct rx_pkt_attrib *pattrib = &(precv_frame->u.hdr.attrib);
+	struct tdls_info *ptdlsinfo = &(padapter->tdlsinfo);
+	u8 empty_addr[ETH_ALEN] = { 0x00 };
+	int rssi = 0;
+	struct tdls_txmgmt txmgmt;
+	int ret = _SUCCESS;
+
+	if (psta)
+		rssi = psta->cmn.rssi_stat.rssi;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	/* WFDTDLS: for sigma test, not to setup direct link automatically */
+	ptdlsinfo->dev_discovered = _TRUE;
+
+	psa = get_sa(ptr);
+	ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), psa);
+	if (ptdls_sta != NULL)
+		ptdls_sta->sta_stats.rx_tdls_disc_rsp_pkts++;
+
+#ifdef CONFIG_TDLS_AUTOSETUP
+	if (ptdls_sta != NULL) {
+		/* Record the tdls sta with lowest signal strength */
+		if (ptdlsinfo->sta_maximum == _TRUE && ptdls_sta->alive_count >= 1) {
+			if (_rtw_memcmp(ptdlsinfo->ss_record.macaddr, empty_addr, ETH_ALEN)) {
+				_rtw_memcpy(ptdlsinfo->ss_record.macaddr, psa, ETH_ALEN);
+				ptdlsinfo->ss_record.RxPWDBAll = pattrib->phy_info.rx_pwdb_all;
+			} else {
+				if (ptdlsinfo->ss_record.RxPWDBAll < pattrib->phy_info.rx_pwdb_all) {
+					_rtw_memcpy(ptdlsinfo->ss_record.macaddr, psa, ETH_ALEN);
+					ptdlsinfo->ss_record.RxPWDBAll = pattrib->phy_info.rx_pwdb_all;
+				}
+			}
+		}
+	} else {
+		if (ptdlsinfo->sta_maximum == _TRUE) {
+			if (_rtw_memcmp(ptdlsinfo->ss_record.macaddr, empty_addr, ETH_ALEN)) {
+				/* All traffics are busy, do not set up another direct link. */
+				ret = _FAIL;
+				goto exit;
+			} else {
+				if (pattrib->phy_info.rx_pwdb_all > ptdlsinfo->ss_record.RxPWDBAll) {
+					_rtw_memcpy(txmgmt.peer, ptdlsinfo->ss_record.macaddr, ETH_ALEN);
+					/* issue_tdls_teardown(padapter, ptdlsinfo->ss_record.macaddr, _FALSE); */
+				} else {
+					ret = _FAIL;
+					goto exit;
+				}
+			}
+		}
+
+
+		if (pattrib->phy_info.rx_pwdb_all + TDLS_SIGNAL_THRESH >= rssi) {
+			RTW_INFO("pattrib->RxPWDBAll=%d, pdmpriv->undecorated_smoothed_pwdb=%d\n", pattrib->phy_info.rx_pwdb_all, rssi);
+			_rtw_memcpy(txmgmt.peer, psa, ETH_ALEN);
+			issue_tdls_setup_req(padapter, &txmgmt, _FALSE);
+		}
+	}
+#endif /* CONFIG_TDLS_AUTOSETUP */
+
+exit:
+	return ret;
+
+}
+
+sint On_TDLS_Setup_Req(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	u8 *psa, *pmyid;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	_irqL irqL;
+	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
+	u8 *prsnie, *ppairwise_cipher;
+	u8 i, k;
+	u8 ccmp_included = 0, rsnie_included = 0;
+	u16 j, pairwise_count;
+	u8 SNonce[32];
+	u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
+	sint parsing_length;	/* Frame body length, without icv_len */
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	u8 FIXED_IE = 5;
+	unsigned char		supportRate[16];
+	int				supportRateNum = 0;
+	struct tdls_txmgmt txmgmt;
+
+	if (rtw_tdls_is_setup_allowed(padapter) == _FALSE)
+		goto exit;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	psa = get_sa(ptr);
+
+	if (ptdlsinfo->sta_maximum == _TRUE) {
+		if (ptdls_sta == NULL)
+			goto exit;
+		else if (!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
+			goto exit;
+	}
+
+	pmyid = adapter_mac_addr(padapter);
+	ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
+	parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
+			 - prx_pkt_attrib->hdrlen
+			 - prx_pkt_attrib->iv_len
+			 - prx_pkt_attrib->icv_len
+			 - LLC_HEADER_SIZE
+			 - ETH_TYPE_LEN
+			 - PAYLOAD_TYPE_LEN;
+
+	if (ptdls_sta == NULL) {
+		ptdls_sta = rtw_alloc_stainfo(pstapriv, psa);
+		if (ptdls_sta == NULL)
+			goto exit;
+		
+		ptdlsinfo->sta_cnt++;
+	}
+	else {
+		if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
+			/* If the direct link is already set up */
+			/* Process as re-setup after tear down */
+			RTW_INFO("re-setup a direct link\n");
+		}
+		/* Already receiving TDLS setup request */
+		else if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE) {
+			RTW_INFO("receive duplicated TDLS setup request frame in handshaking\n");
+			goto exit;
+		}
+		/* When receiving and sending setup_req to the same link at the same time */
+		/* STA with higher MAC_addr would be initiator */
+		else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE) {
+			RTW_INFO("receive setup_req after sending setup_req\n");
+			for (i = 0; i < 6; i++) {
+				if (*(pmyid + i) == *(psa + i)) {
+				} else if (*(pmyid + i) > *(psa + i)) {
+					ptdls_sta->tdls_sta_state = TDLS_INITIATOR_STATE;
+					break;
+				} else if (*(pmyid + i) < *(psa + i))
+					goto exit;
+			}
+		}
+	}
+
+	if (ptdls_sta) {
+		txmgmt.dialog_token = *(ptr + 2);	/* Copy dialog token */
+		txmgmt.status_code = _STATS_SUCCESSFUL_;
+
+		/* Parsing information element */
+		for (j = FIXED_IE; j < parsing_length;) {
+
+			pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
+
+			switch (pIE->ElementID) {
+			case _SUPPORTEDRATES_IE_:
+				_rtw_memcpy(supportRate, pIE->data, pIE->Length);
+				supportRateNum = pIE->Length;
+				break;
+			case _COUNTRY_IE_:
+				break;
+			case _EXT_SUPPORTEDRATES_IE_:
+				if (supportRateNum < sizeof(supportRate)) {
+					_rtw_memcpy(supportRate + supportRateNum, pIE->data, pIE->Length);
+					supportRateNum += pIE->Length;
+				}
+				break;
+			case _SUPPORTED_CH_IE_:
+				break;
+			case _RSN_IE_2_:
+				rsnie_included = 1;
+				if (prx_pkt_attrib->encrypt) {
+					prsnie = (u8 *)pIE;
+					/* Check CCMP pairwise_cipher presence. */
+					ppairwise_cipher = prsnie + 10;
+					_rtw_memcpy(ptdls_sta->TDLS_RSNIE, pIE->data, pIE->Length);
+					pairwise_count = *(u16 *)(ppairwise_cipher - 2);
+					for (k = 0; k < pairwise_count; k++) {
+						if (_rtw_memcmp(ppairwise_cipher + 4 * k, RSN_CIPHER_SUITE_CCMP, 4) == _TRUE)
+							ccmp_included = 1;
+					}
+
+					if (ccmp_included == 0)
+						txmgmt.status_code = _STATS_INVALID_RSNIE_;
+				}
+				break;
+			case _EXT_CAP_IE_:
+				break;
+			case _VENDOR_SPECIFIC_IE_:
+				break;
+			case _FTIE_:
+				if (prx_pkt_attrib->encrypt)
+					_rtw_memcpy(SNonce, (ptr + j + 52), 32);
+				break;
+			case _TIMEOUT_ITVL_IE_:
+				if (prx_pkt_attrib->encrypt)
+					timeout_interval = cpu_to_le32(*(u32 *)(ptr + j + 3));
+				break;
+			case _RIC_Descriptor_IE_:
+				break;
+#ifdef CONFIG_80211N_HT
+			case _HT_CAPABILITY_IE_:
+				rtw_tdls_process_ht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
+				break;
+#endif
+#ifdef CONFIG_80211AC_VHT
+			case EID_AID:
+				break;
+			case EID_VHTCapability:
+				rtw_tdls_process_vht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
+				break;
+#endif
+			case EID_BSSCoexistence:
+				break;
+			case _LINK_ID_IE_:
+				if (_rtw_memcmp(get_bssid(pmlmepriv), pIE->data, 6) == _FALSE)
+					txmgmt.status_code = _STATS_NOT_IN_SAME_BSS_;
+				break;
+			default:
+				break;
+			}
+
+			j += (pIE->Length + 2);
+
+		}
+
+		/* Check status code */
+		/* If responder STA has/hasn't security on AP, but request hasn't/has RSNIE, it should reject */
+		if (txmgmt.status_code == _STATS_SUCCESSFUL_) {
+			if (rsnie_included && prx_pkt_attrib->encrypt == 0)
+				txmgmt.status_code = _STATS_SEC_DISABLED_;
+			else if (rsnie_included == 0 && prx_pkt_attrib->encrypt)
+				txmgmt.status_code = _STATS_INVALID_PARAMETERS_;
+
+#ifdef CONFIG_WFD
+			/* WFD test plan version 0.18.2 test item 5.1.5 */
+			/* SoUT does not use TDLS if AP uses weak security */
+			if (padapter->wdinfo.wfd_tdls_enable && (rsnie_included && prx_pkt_attrib->encrypt != _AES_))
+				txmgmt.status_code = _STATS_SEC_DISABLED_;
+#endif /* CONFIG_WFD */
+		}
+
+		ptdls_sta->tdls_sta_state |= TDLS_INITIATOR_STATE;
+		if (prx_pkt_attrib->encrypt) {
+			_rtw_memcpy(ptdls_sta->SNonce, SNonce, 32);
+
+			if (timeout_interval <= 300)
+				ptdls_sta->TDLS_PeerKey_Lifetime = TDLS_TPK_RESEND_COUNT;
+			else
+				ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
+		}
+
+		/* Update station supportRate */
+		ptdls_sta->bssratelen = supportRateNum;
+		_rtw_memcpy(ptdls_sta->bssrateset, supportRate, supportRateNum);
+
+		/* -2: AP + BC/MC sta, -4: default key */
+		if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
+			ptdlsinfo->sta_maximum = _TRUE;
+
+#ifdef CONFIG_WFD
+		rtw_tdls_process_wfd_ie(ptdlsinfo, ptr + FIXED_IE, parsing_length);
+#endif
+
+	} else
+		goto exit;
+
+	_rtw_memcpy(txmgmt.peer, prx_pkt_attrib->src, ETH_ALEN);
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		issue_tdls_setup_rsp(padapter, &txmgmt);
+
+		if (txmgmt.status_code == _STATS_SUCCESSFUL_)
+			_set_timer(&ptdls_sta->handshake_timer, TDLS_HANDSHAKE_TIME);
+		else {
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+		}
+	}
+
+exit:
+
+	return _SUCCESS;
+}
+
+int On_TDLS_Setup_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	_irqL irqL;
+	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
+	u8 *psa;
+	u16 status_code = 0;
+	sint parsing_length;	/* Frame body length, without icv_len */
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	u8 FIXED_IE = 7;
+	u8 ANonce[32];
+	u8  *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL, *ppairwise_cipher = NULL;
+	u16 pairwise_count, j, k;
+	u8 verify_ccmp = 0;
+	unsigned char		supportRate[16];
+	int				supportRateNum = 0;
+	struct tdls_txmgmt txmgmt;
+	int ret = _SUCCESS;
+	u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	psa = get_sa(ptr);
+
+	ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
+	parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
+			 - prx_pkt_attrib->hdrlen
+			 - prx_pkt_attrib->iv_len
+			 - prx_pkt_attrib->icv_len
+			 - LLC_HEADER_SIZE
+			 - ETH_TYPE_LEN
+			 - PAYLOAD_TYPE_LEN;
+
+	_rtw_memcpy(&status_code, ptr + 2, 2);
+
+	if (status_code != 0) {
+		RTW_INFO("[TDLS] %s status_code = %d, free_tdls_sta\n", __FUNCTION__, status_code);
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+		ret = _FAIL;
+		goto exit;
+	}
+
+	status_code = 0;
+
+	/* parsing information element */
+	for (j = FIXED_IE; j < parsing_length;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
+
+		switch (pIE->ElementID) {
+		case _SUPPORTEDRATES_IE_:
+			_rtw_memcpy(supportRate, pIE->data, pIE->Length);
+			supportRateNum = pIE->Length;
+			break;
+		case _COUNTRY_IE_:
+			break;
+		case _EXT_SUPPORTEDRATES_IE_:
+			if (supportRateNum < sizeof(supportRate)) {
+				_rtw_memcpy(supportRate + supportRateNum, pIE->data, pIE->Length);
+				supportRateNum += pIE->Length;
+			}
+			break;
+		case _SUPPORTED_CH_IE_:
+			break;
+		case _RSN_IE_2_:
+			prsnie = (u8 *)pIE;
+			/* Check CCMP pairwise_cipher presence. */
+			ppairwise_cipher = prsnie + 10;
+			_rtw_memcpy(&pairwise_count, (u16 *)(ppairwise_cipher - 2), 2);
+			for (k = 0; k < pairwise_count; k++) {
+				if (_rtw_memcmp(ppairwise_cipher + 4 * k, RSN_CIPHER_SUITE_CCMP, 4) == _TRUE)
+					verify_ccmp = 1;
+			}
+		case _EXT_CAP_IE_:
+			break;
+		case _VENDOR_SPECIFIC_IE_:
+			if (_rtw_memcmp((u8 *)pIE + 2, WMM_INFO_OUI, 6) == _TRUE) {
+				/* WMM Info ID and OUI */
+				if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
+					ptdls_sta->qos_option = _TRUE;
+			}
+			break;
+		case _FTIE_:
+			pftie = (u8 *)pIE;
+			_rtw_memcpy(ANonce, (ptr + j + 20), 32);
+			break;
+		case _TIMEOUT_ITVL_IE_:
+			ptimeout_ie = (u8 *)pIE;
+			timeout_interval = cpu_to_le32(*(u32 *)(ptimeout_ie + 3));
+			break;
+		case _RIC_Descriptor_IE_:
+			break;
+#ifdef CONFIG_80211N_HT
+		case _HT_CAPABILITY_IE_:
+			rtw_tdls_process_ht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
+			break;
+#endif
+#ifdef CONFIG_80211AC_VHT
+		case EID_AID:
+			/* todo in the future if necessary */
+			break;
+		case EID_VHTCapability:
+			rtw_tdls_process_vht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
+			break;
+		case EID_OpModeNotification:
+			rtw_tdls_process_vht_op_mode_notify(padapter, ptdls_sta, pIE->data, pIE->Length);
+			break;
+#endif
+		case EID_BSSCoexistence:
+			break;
+		case _LINK_ID_IE_:
+			plinkid_ie = (u8 *)pIE;
+			break;
+		default:
+			break;
+		}
+
+		j += (pIE->Length + 2);
+
+	}
+
+	ptdls_sta->bssratelen = supportRateNum;
+	_rtw_memcpy(ptdls_sta->bssrateset, supportRate, supportRateNum);
+	_rtw_memcpy(ptdls_sta->ANonce, ANonce, 32);
+
+#ifdef CONFIG_WFD
+	rtw_tdls_process_wfd_ie(ptdlsinfo, ptr + FIXED_IE, parsing_length);
+#endif
+
+	if (prx_pkt_attrib->encrypt) {
+		if (verify_ccmp == 1) {
+			txmgmt.status_code = _STATS_SUCCESSFUL_;
+			if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
+				wpa_tdls_generate_tpk(padapter, ptdls_sta);
+				if (tdls_verify_mic(ptdls_sta->tpk.kck, 2, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL) {
+					RTW_INFO("[TDLS] %s tdls_verify_mic fail, free_tdls_sta\n", __FUNCTION__);
+					rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+					rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+					ret = _FAIL;
+					goto exit;
+				}
+				ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
+			}
+		} else
+			txmgmt.status_code = _STATS_INVALID_RSNIE_;
+	} else
+		txmgmt.status_code = _STATS_SUCCESSFUL_;
+
+	if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
+		_rtw_memcpy(txmgmt.peer, prx_pkt_attrib->src, ETH_ALEN);
+		issue_tdls_setup_cfm(padapter, &txmgmt);
+
+		if (txmgmt.status_code == _STATS_SUCCESSFUL_) {
+			rtw_tdls_set_link_established(padapter, _TRUE);
+
+			if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE) {
+				ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
+				ptdls_sta->state |= _FW_LINKED;
+				_cancel_timer_ex(&ptdls_sta->handshake_timer);
+			}
+
+			if (prx_pkt_attrib->encrypt)
+				rtw_tdls_set_key(padapter, ptdls_sta);
+
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_ESTABLISHED);
+
+		}
+	}
+
+exit:
+	if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
+		return ret;
+	else
+		return _SUCCESS;
+
+}
+
+int On_TDLS_Setup_Cfm(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	_irqL irqL;
+	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
+	u8 *psa;
+	u16 status_code = 0;
+	sint parsing_length;
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	u8 FIXED_IE = 5;
+	u8  *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL, *ppairwise_cipher = NULL;
+	u16 j, pairwise_count;
+	int ret = _SUCCESS;
+
+	psa = get_sa(ptr);
+
+	ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
+	parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
+			 - prx_pkt_attrib->hdrlen
+			 - prx_pkt_attrib->iv_len
+			 - prx_pkt_attrib->icv_len
+			 - LLC_HEADER_SIZE
+			 - ETH_TYPE_LEN
+			 - PAYLOAD_TYPE_LEN;
+
+	_rtw_memcpy(&status_code, ptr + 2, 2);
+
+	if (status_code != 0) {
+		RTW_INFO("[%s] status_code = %d\n, free_tdls_sta", __FUNCTION__, status_code);
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* Parsing information element */
+	for (j = FIXED_IE; j < parsing_length;) {
+
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
+
+		switch (pIE->ElementID) {
+		case _RSN_IE_2_:
+			prsnie = (u8 *)pIE;
+			break;
+		case _VENDOR_SPECIFIC_IE_:
+			if (_rtw_memcmp((u8 *)pIE + 2, WMM_PARA_OUI, 6) == _TRUE) {
+				/* WMM Parameter ID and OUI */
+				ptdls_sta->qos_option = _TRUE;
+			}
+			break;
+		case _FTIE_:
+			pftie = (u8 *)pIE;
+			break;
+		case _TIMEOUT_ITVL_IE_:
+			ptimeout_ie = (u8 *)pIE;
+			break;
+#ifdef CONFIG_80211N_HT
+		case _HT_EXTRA_INFO_IE_:
+			break;
+#endif
+#ifdef CONFIG_80211AC_VHT
+		case EID_VHTOperation:
+			rtw_tdls_process_vht_operation(padapter, ptdls_sta, pIE->data, pIE->Length);
+			break;
+		case EID_OpModeNotification:
+			rtw_tdls_process_vht_op_mode_notify(padapter, ptdls_sta, pIE->data, pIE->Length);
+			break;
+#endif
+		case _LINK_ID_IE_:
+			plinkid_ie = (u8 *)pIE;
+			break;
+		default:
+			break;
+		}
+
+		j += (pIE->Length + 2);
+
+	}
+
+	if (prx_pkt_attrib->encrypt) {
+		/* Verify mic in FTIE MIC field */
+		if (rtw_tdls_is_driver_setup(padapter) &&
+		    (tdls_verify_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL)) {
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+			ret = _FAIL;
+			goto exit;
+		}
+	}
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		rtw_tdls_set_link_established(padapter, _TRUE);
+
+		if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE) {
+			ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
+			ptdls_sta->state |= _FW_LINKED;
+			_cancel_timer_ex(&ptdls_sta->handshake_timer);
+		}
+
+		if (prx_pkt_attrib->encrypt) {
+			rtw_tdls_set_key(padapter, ptdls_sta);
+
+			/* Start  TPK timer */
+			ptdls_sta->TPK_count = 0;
+			_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
+		}
+
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_ESTABLISHED);
+	}
+
+exit:
+	return ret;
+
+}
+
+int On_TDLS_Dis_Req(_adapter *padapter, union recv_frame *precv_frame)
+{
+	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta_ap;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	sint parsing_length;	/* Frame body length, without icv_len */
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	u8 FIXED_IE = 3, *dst;
+	u16 j;
+	struct tdls_txmgmt txmgmt;
+	int ret = _SUCCESS;
+
+	if (rtw_tdls_is_driver_setup(padapter) == _FALSE)
+		goto exit;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
+	txmgmt.dialog_token = *(ptr + 2);
+	_rtw_memcpy(&txmgmt.peer, precv_frame->u.hdr.attrib.src, ETH_ALEN);
+	txmgmt.action_code = TDLS_DISCOVERY_RESPONSE;
+	parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
+			 - prx_pkt_attrib->hdrlen
+			 - prx_pkt_attrib->iv_len
+			 - prx_pkt_attrib->icv_len
+			 - LLC_HEADER_SIZE
+			 - ETH_TYPE_LEN
+			 - PAYLOAD_TYPE_LEN;
+
+	/* Parsing information element */
+	for (j = FIXED_IE; j < parsing_length;) {
+
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
+
+		switch (pIE->ElementID) {
+		case _LINK_ID_IE_:
+			psta_ap = rtw_get_stainfo(pstapriv, pIE->data);
+			if (psta_ap == NULL)
+				goto exit;
+			dst = pIE->data + 12;
+			if (MacAddr_isBcst(dst) == _FALSE && (_rtw_memcmp(adapter_mac_addr(padapter), dst, 6) == _FALSE))
+				goto exit;
+			break;
+		default:
+			break;
+		}
+
+		j += (pIE->Length + 2);
+
+	}
+
+	issue_tdls_dis_rsp(padapter, &txmgmt, prx_pkt_attrib->privacy);
+
+exit:
+	return ret;
+
+}
+
+int On_TDLS_Teardown(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct sta_priv	*pstapriv = &padapter->stapriv;
+	_irqL irqL;
+	u8 reason;
+
+	reason = *(ptr + prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN + 2);
+	RTW_INFO("[TDLS] %s Reason code(%d)\n", __FUNCTION__, reason);
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+	}
+
+	return _SUCCESS;
+
+}
+
+#if 0
+u8 TDLS_check_ch_state(uint state)
+{
+	if (state & TDLS_CH_SWITCH_ON_STATE &&
+	    state & TDLS_PEER_AT_OFF_STATE) {
+		if (state & TDLS_PEER_SLEEP_STATE)
+			return 2;	/* U-APSD + ch. switch */
+		else
+			return 1;	/* ch. switch */
+	} else
+		return 0;
+}
+#endif
+
+int On_TDLS_Peer_Traffic_Indication(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	struct rx_pkt_attrib	*pattrib = &precv_frame->u.hdr.attrib;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	struct tdls_txmgmt txmgmt;
+
+	ptr += pattrib->hdrlen + pattrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+
+		txmgmt.dialog_token = *(ptr + 2);
+		issue_tdls_peer_traffic_rsp(padapter, ptdls_sta, &txmgmt);
+		/* issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 0, 0, 0); */
+
+	return _SUCCESS;
+}
+
+/* We process buffered data for 1. U-APSD, 2. ch. switch, 3. U-APSD + ch. switch here */
+int On_TDLS_Peer_Traffic_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct rx_pkt_attrib	*pattrib = &precv_frame->u.hdr.attrib;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 wmmps_ac = 0;
+	/* u8 state=TDLS_check_ch_state(ptdls_sta->tdls_sta_state); */
+	int i;
+
+	ptdls_sta->sta_stats.rx_data_pkts++;
+
+	ptdls_sta->tdls_sta_state &= ~(TDLS_WAIT_PTR_STATE);
+
+	/* Check 4-AC queue bit */
+	if (ptdls_sta->uapsd_vo || ptdls_sta->uapsd_vi || ptdls_sta->uapsd_be || ptdls_sta->uapsd_bk)
+		wmmps_ac = 1;
+
+	/* If it's a direct link and have buffered frame */
+	if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
+		if (wmmps_ac) {
+			_irqL irqL;
+			_list	*xmitframe_plist, *xmitframe_phead;
+			struct xmit_frame *pxmitframe = NULL;
+
+			_enter_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
+
+			xmitframe_phead = get_list_head(&ptdls_sta->sleep_q);
+			xmitframe_plist = get_next(xmitframe_phead);
+
+			/* transmit buffered frames */
+			while (rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist) == _FALSE) {
+				pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
+				xmitframe_plist = get_next(xmitframe_plist);
+				rtw_list_delete(&pxmitframe->list);
+
+				ptdls_sta->sleepq_len--;
+				ptdls_sta->sleepq_ac_len--;
+				if (ptdls_sta->sleepq_len > 0) {
+					pxmitframe->attrib.mdata = 1;
+					pxmitframe->attrib.eosp = 0;
+				} else {
+					pxmitframe->attrib.mdata = 0;
+					pxmitframe->attrib.eosp = 1;
+				}
+				pxmitframe->attrib.triggered = 1;
+
+				rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
+			}
+
+			if (ptdls_sta->sleepq_len == 0)
+				RTW_INFO("no buffered packets for tdls to xmit\n");
+			else {
+				RTW_INFO("error!psta->sleepq_len=%d\n", ptdls_sta->sleepq_len);
+				ptdls_sta->sleepq_len = 0;
+			}
+
+			_exit_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
+
+		}
+
+	}
+
+	return _SUCCESS;
+}
+
+#ifdef CONFIG_TDLS_CH_SW
+sint On_TDLS_Ch_Switch_Req(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
+	sint parsing_length;
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	u8 FIXED_IE = 4;
+	u16 j;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	u8 zaddr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	u16 switch_time = TDLS_CH_SWITCH_TIME * 1000, switch_timeout = TDLS_CH_SWITCH_TIMEOUT * 1000;
+	u8 take_care_iqk;
+
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
+		return _FAIL;
+	}
+
+	ptdls_sta->ch_switch_time = switch_time;
+	ptdls_sta->ch_switch_timeout = switch_timeout;
+
+	ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
+	parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
+			 - prx_pkt_attrib->hdrlen
+			 - prx_pkt_attrib->iv_len
+			 - prx_pkt_attrib->icv_len
+			 - LLC_HEADER_SIZE
+			 - ETH_TYPE_LEN
+			 - PAYLOAD_TYPE_LEN;
+
+	pchsw_info->off_ch_num = *(ptr + 2);
+
+	if ((*(ptr + 2) == 2) && (hal_is_band_support(padapter, BAND_ON_5G)))
+		pchsw_info->off_ch_num = 44;
+
+	if (pchsw_info->off_ch_num != pmlmeext->cur_channel)
+		pchsw_info->delay_switch_back = _FALSE;
+
+	/* Parsing information element */
+	for (j = FIXED_IE; j < parsing_length;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
+
+		switch (pIE->ElementID) {
+		case EID_SecondaryChnlOffset:
+			switch (*(pIE->data)) {
+			case EXTCHNL_OFFSET_UPPER:
+				pchsw_info->ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+				break;
+
+			case EXTCHNL_OFFSET_LOWER:
+				pchsw_info->ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+				break;
+
+			default:
+				pchsw_info->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+				break;
+			}
+			break;
+		case _LINK_ID_IE_:
+			break;
+		case _CH_SWITCH_TIMING_:
+			ptdls_sta->ch_switch_time = (RTW_GET_LE16(pIE->data) >= TDLS_CH_SWITCH_TIME * 1000) ?
+				RTW_GET_LE16(pIE->data) : TDLS_CH_SWITCH_TIME * 1000;
+			ptdls_sta->ch_switch_timeout = (RTW_GET_LE16(pIE->data + 2) >= TDLS_CH_SWITCH_TIMEOUT * 1000) ?
+				RTW_GET_LE16(pIE->data + 2) : TDLS_CH_SWITCH_TIMEOUT * 1000;
+			RTW_INFO("[TDLS] %s ch_switch_time:%d, ch_switch_timeout:%d\n"
+				, __FUNCTION__, RTW_GET_LE16(pIE->data), RTW_GET_LE16(pIE->data + 2));
+		default:
+			break;
+		}
+
+		j += (pIE->Length + 2);
+	}
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
+	if (take_care_iqk == _TRUE) {
+		u8 central_chnl;
+		u8 bw_mode;
+
+		bw_mode = (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20;
+		central_chnl = rtw_get_center_ch(pchsw_info->off_ch_num, bw_mode, pchsw_info->ch_offset);
+		if (rtw_hal_ch_sw_iqk_info_search(padapter, central_chnl, bw_mode) < 0) {
+			if (!(pchsw_info->ch_sw_state & TDLS_CH_SWITCH_PREPARE_STATE))
+				rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_PREPARE);
+
+			return _FAIL;
+		}
+	}
+
+	/* cancel ch sw monitor timer for responder */
+	if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
+		_cancel_timer_ex(&ptdls_sta->ch_sw_monitor_timer);
+
+	if (_rtw_memcmp(pchsw_info->addr, zaddr, ETH_ALEN) == _TRUE)
+		_rtw_memcpy(pchsw_info->addr, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+
+	if (ATOMIC_READ(&pchsw_info->chsw_on) == _FALSE)
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
+
+	rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_RESP);
+
+	return _SUCCESS;
+}
+
+sint On_TDLS_Ch_Switch_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
+{
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *ptr = precv_frame->u.hdr.rx_data;
+	struct rx_pkt_attrib	*prx_pkt_attrib = &precv_frame->u.hdr.attrib;
+	sint parsing_length;
+	PNDIS_802_11_VARIABLE_IEs	pIE;
+	u8 FIXED_IE = 4;
+	u16 status_code, j, switch_time, switch_timeout;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	int ret = _SUCCESS;
+
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
+		return _SUCCESS;
+	}
+
+	/* If we receive Unsolicited TDLS Channel Switch Response when channel switch is running, */
+	/* we will go back to base channel and terminate this channel switch procedure */
+	if (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) {
+		if (pmlmeext->cur_channel != rtw_get_oper_ch(padapter)) {
+			RTW_INFO("[TDLS] Rx unsolicited channel switch response\n");
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_BASE_CHNL);
+			goto exit;
+		}
+	}
+
+	ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
+	parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
+			 - prx_pkt_attrib->hdrlen
+			 - prx_pkt_attrib->iv_len
+			 - prx_pkt_attrib->icv_len
+			 - LLC_HEADER_SIZE
+			 - ETH_TYPE_LEN
+			 - PAYLOAD_TYPE_LEN;
+
+	_rtw_memcpy(&status_code, ptr + 2, 2);
+
+	if (status_code != 0) {
+		RTW_INFO("[TDLS] %s status_code:%d\n", __func__, status_code);
+		pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE);
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END);
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* Parsing information element */
+	for (j = FIXED_IE; j < parsing_length;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
+
+		switch (pIE->ElementID) {
+		case _LINK_ID_IE_:
+			break;
+		case _CH_SWITCH_TIMING_:
+			_rtw_memcpy(&switch_time, pIE->data, 2);
+			if (switch_time > ptdls_sta->ch_switch_time)
+				_rtw_memcpy(&ptdls_sta->ch_switch_time, &switch_time, 2);
+
+			_rtw_memcpy(&switch_timeout, pIE->data + 2, 2);
+			if (switch_timeout > ptdls_sta->ch_switch_timeout)
+				_rtw_memcpy(&ptdls_sta->ch_switch_timeout, &switch_timeout, 2);
+			break;
+		default:
+			break;
+		}
+
+		j += (pIE->Length + 2);
+	}
+
+	if ((pmlmeext->cur_channel == rtw_get_oper_ch(padapter)) &&
+	    (pchsw_info->ch_sw_state & TDLS_WAIT_CH_RSP_STATE)) {
+		if (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE)
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_OFF_CHNL);
+	}
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_TDLS_CH_SW */
+
+#ifdef CONFIG_WFD
+void wfd_ie_tdls(_adapter *padapter, u8 *pframe, u32 *pktlen)
+{
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct wifi_display_info	*pwfd_info = padapter->tdlsinfo.wfd_info;
+	u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
+	u32 wfdielen = 0;
+	u16 v16 = 0;
+
+	if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
+		return;
+
+	/* WFD OUI */
+	wfdielen = 0;
+	wfdie[wfdielen++] = 0x50;
+	wfdie[wfdielen++] = 0x6F;
+	wfdie[wfdielen++] = 0x9A;
+	wfdie[wfdielen++] = 0x0A;	/* WFA WFD v1.0 */
+
+	/*
+	 *	Commented by Albert 20110825
+	 *	According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes
+	 *	1. WFD Device Information
+	 *	2. Associated BSSID ( Optional )
+	 *	3. Local IP Adress ( Optional )
+	 */
+
+	/* WFD Device Information ATTR */
+	/* Type: */
+	wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
+
+	/* Length: */
+	/* Note: In the WFD specification, the size of length field is 2. */
+	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
+	wfdielen += 2;
+
+	/* Value1: */
+	/* WFD device information */
+	/* available for WFD session + Preferred TDLS + WSD ( WFD Service Discovery ) */
+	v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL
+		| WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_WSD;
+	RTW_PUT_BE16(wfdie + wfdielen, v16);
+	wfdielen += 2;
+
+	/* Value2: */
+	/* Session Management Control Port */
+	/* Default TCP port for RTSP messages is 554 */
+	RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->tdls_rtsp_ctrlport);
+	wfdielen += 2;
+
+	/* Value3: */
+	/* WFD Device Maximum Throughput */
+	/* 300Mbps is the maximum throughput */
+	RTW_PUT_BE16(wfdie + wfdielen, 300);
+	wfdielen += 2;
+
+	/* Associated BSSID ATTR */
+	/* Type: */
+	wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
+
+	/* Length: */
+	/* Note: In the WFD specification, the size of length field is 2. */
+	RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
+	wfdielen += 2;
+
+	/* Value: */
+	/* Associated BSSID */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+		_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
+	else
+		_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
+
+	/* Local IP Address ATTR */
+	wfdie[wfdielen++] = WFD_ATTR_LOCAL_IP_ADDR;
+
+	/* Length: */
+	/* Note: In the WFD specification, the size of length field is 2. */
+	RTW_PUT_BE16(wfdie + wfdielen, 0x0005);
+	wfdielen += 2;
+
+	/* Version: */
+	/* 0x01: Version1;IPv4 */
+	wfdie[wfdielen++] = 0x01;
+
+	/* IPv4 Address */
+	_rtw_memcpy(wfdie + wfdielen, pwfd_info->ip_address, 4);
+	wfdielen += 4;
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, pktlen);
+
+}
+#endif /* CONFIG_WFD */
+
+void rtw_build_tdls_setup_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	int i = 0 ;
+	u32 time;
+	u8 *pframe_head;
+
+	/* SNonce */
+	if (pattrib->encrypt) {
+		for (i = 0; i < 8; i++) {
+			time = rtw_get_current_time();
+			_rtw_memcpy(&ptdls_sta->SNonce[4 * i], (u8 *)&time, 4);
+		}
+	}
+
+	pframe_head = pframe;	/* For rtw_tdls_set_ht_cap() */
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
+
+	pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_sup_ch(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_sup_reg_class(pframe, pattrib);
+
+	if (pattrib->encrypt)
+		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib,  _TRUE, ptdls_sta);
+
+	pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
+
+	if (pattrib->encrypt) {
+		pframe = rtw_tdls_set_ftie(ptxmgmt
+					   , pframe
+					   , pattrib
+					   , NULL
+					   , ptdls_sta->SNonce);
+
+		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
+	}
+
+#ifdef CONFIG_80211N_HT
+	/* Sup_reg_classes(optional) */
+	if (pregistrypriv->ht_enable == _TRUE)
+		pframe = rtw_tdls_set_ht_cap(padapter, pframe_head, pattrib);
+#endif
+
+	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
+
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+
+	if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
+		pframe = rtw_tdls_set_qos_cap(pframe, pattrib);
+
+#ifdef CONFIG_80211AC_VHT
+	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
+	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
+	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+	   ) {
+		pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
+		pframe = rtw_tdls_set_vht_cap(padapter, pframe, pattrib);
+	}
+#endif
+
+#ifdef CONFIG_WFD
+	if (padapter->wdinfo.wfd_tdls_enable == 1)
+		wfd_ie_tdls(padapter, pframe, &(pattrib->pktlen));
+#endif
+
+}
+
+void rtw_build_tdls_setup_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	u8 k; /* for random ANonce */
+	u8  *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL;
+	u32 time;
+	u8 *pframe_head;
+
+	if (pattrib->encrypt) {
+		for (k = 0; k < 8; k++) {
+			time = rtw_get_current_time();
+			_rtw_memcpy(&ptdls_sta->ANonce[4 * k], (u8 *)&time, 4);
+		}
+	}
+
+	pframe_head = pframe;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
+
+	if (ptxmgmt->status_code != 0) {
+		RTW_INFO("[%s] status_code:%04x\n", __FUNCTION__, ptxmgmt->status_code);
+		return;
+	}
+
+	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_sup_ch(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_sup_reg_class(pframe, pattrib);
+
+	if (pattrib->encrypt) {
+		prsnie = pframe;
+		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib,  _FALSE, ptdls_sta);
+	}
+
+	pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
+
+	if (pattrib->encrypt) {
+		if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
+			wpa_tdls_generate_tpk(padapter, ptdls_sta);
+
+		pftie = pframe;
+		pftie_mic = pframe + 4;
+		pframe = rtw_tdls_set_ftie(ptxmgmt
+					   , pframe
+					   , pattrib
+					   , ptdls_sta->ANonce
+					   , ptdls_sta->SNonce);
+
+		ptimeout_ie = pframe;
+		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _FALSE, ptdls_sta);
+	}
+
+#ifdef CONFIG_80211N_HT
+	/* Sup_reg_classes(optional) */
+	if (pregistrypriv->ht_enable == _TRUE)
+		pframe = rtw_tdls_set_ht_cap(padapter, pframe_head, pattrib);
+#endif
+
+	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
+
+	plinkid_ie = pframe;
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
+
+	/* Fill FTIE mic */
+	if (pattrib->encrypt && rtw_tdls_is_driver_setup(padapter) == _TRUE)
+		wpa_tdls_ftie_mic(ptdls_sta->tpk.kck, 2, plinkid_ie, prsnie, ptimeout_ie, pftie, pftie_mic);
+
+	if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
+		pframe = rtw_tdls_set_qos_cap(pframe, pattrib);
+
+#ifdef CONFIG_80211AC_VHT
+	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
+	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
+	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+	   ) {
+		pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
+		pframe = rtw_tdls_set_vht_cap(padapter, pframe, pattrib);
+		pframe = rtw_tdls_set_vht_op_mode_notify(padapter, pframe, pattrib, pmlmeext->cur_bwmode);
+	}
+#endif
+
+#ifdef CONFIG_WFD
+	if (padapter->wdinfo.wfd_tdls_enable)
+		wfd_ie_tdls(padapter, pframe, &(pattrib->pktlen));
+#endif
+
+}
+
+void rtw_build_tdls_setup_cfm_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+
+	unsigned int ie_len;
+	unsigned char *p;
+	u8 wmm_param_ele[24] = {0};
+	u8  *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
+
+	if (ptxmgmt->status_code != 0)
+		return;
+
+	if (pattrib->encrypt) {
+		prsnie = pframe;
+		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
+	}
+
+	if (pattrib->encrypt) {
+		pftie = pframe;
+		pftie_mic = pframe + 4;
+		pframe = rtw_tdls_set_ftie(ptxmgmt
+					   , pframe
+					   , pattrib
+					   , ptdls_sta->ANonce
+					   , ptdls_sta->SNonce);
+
+		ptimeout_ie = pframe;
+		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
+
+		if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
+			/* Start TPK timer */
+			ptdls_sta->TPK_count = 0;
+			_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
+		}
+	}
+
+	/* HT operation; todo */
+
+	plinkid_ie = pframe;
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+
+	if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
+		wpa_tdls_ftie_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie, pftie_mic);
+
+	if (ptdls_sta->qos_option == _TRUE)
+		pframe = rtw_tdls_set_wmm_params(padapter, pframe, pattrib);
+
+#ifdef CONFIG_80211AC_VHT
+	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE)
+	    && (ptdls_sta->vhtpriv.vht_option == _TRUE) && (pmlmeext->cur_channel > 14)
+	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
+	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+	   ) {
+		pframe = rtw_tdls_set_vht_operation(padapter, pframe, pattrib, pmlmeext->cur_channel);
+		pframe = rtw_tdls_set_vht_op_mode_notify(padapter, pframe, pattrib, pmlmeext->cur_bwmode);
+	}
+#endif
+}
+
+void rtw_build_tdls_teardown_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	u8  *pftie = NULL, *pftie_mic = NULL, *plinkid_ie = NULL;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
+
+	if (pattrib->encrypt) {
+		pftie = pframe;
+		pftie_mic = pframe + 4;
+		pframe = rtw_tdls_set_ftie(ptxmgmt
+					   , pframe
+					   , pattrib
+					   , ptdls_sta->ANonce
+					   , ptdls_sta->SNonce);
+	}
+
+	plinkid_ie = pframe;
+	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
+	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+
+	if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
+		wpa_tdls_teardown_ftie_mic(ptdls_sta->tpk.kck, plinkid_ie, ptxmgmt->status_code, 1, 4, pftie, pftie_mic);
+}
+
+void rtw_build_tdls_dis_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
+{
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+
+}
+
+void rtw_build_tdls_dis_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, u8 privacy)
+{
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	u8 *pframe_head, pktlen_index;
+
+	pktlen_index = pattrib->pktlen;
+	pframe_head = pframe;
+
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_PUBLIC);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
+
+	pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
+
+	pframe = rtw_tdls_set_sup_ch(padapter, pframe, pattrib);
+
+	if (privacy)
+		pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _TRUE, NULL);
+
+	pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
+
+	if (privacy) {
+		pframe = rtw_tdls_set_ftie(ptxmgmt, pframe, pattrib, NULL, NULL);
+		pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib,  _TRUE, NULL);
+	}
+
+#ifdef CONFIG_80211N_HT
+	if (pregistrypriv->ht_enable == _TRUE)
+		pframe = rtw_tdls_set_ht_cap(padapter, pframe_head - pktlen_index, pattrib);
+#endif
+
+	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
+
+}
+
+
+void rtw_build_tdls_peer_traffic_indication_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	u8 AC_queue = 0;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
+
+	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
+	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+
+	/* PTI control */
+	/* PU buffer status */
+	if (ptdls_sta->uapsd_bk & BIT(1))
+		AC_queue = BIT(0);
+	if (ptdls_sta->uapsd_be & BIT(1))
+		AC_queue = BIT(1);
+	if (ptdls_sta->uapsd_vi & BIT(1))
+		AC_queue = BIT(2);
+	if (ptdls_sta->uapsd_vo & BIT(1))
+		AC_queue = BIT(3);
+	pframe = rtw_set_ie(pframe, _PTI_BUFFER_STATUS_, 1, &AC_queue, &(pattrib->pktlen));
+
+}
+
+void rtw_build_tdls_peer_traffic_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
+
+	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
+	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+}
+
+#ifdef CONFIG_TDLS_CH_SW
+void rtw_build_tdls_ch_switch_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	struct sta_priv	*pstapriv = &padapter->stapriv;
+	u16 switch_time = TDLS_CH_SWITCH_TIME * 1000, switch_timeout = TDLS_CH_SWITCH_TIMEOUT * 1000;
+
+	ptdls_sta->ch_switch_time = switch_time;
+	ptdls_sta->ch_switch_timeout = switch_timeout;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_target_ch(padapter, pframe, pattrib);
+	pframe = rtw_tdls_set_reg_class(pframe, pattrib, ptdls_sta);
+
+	if (ptdlsinfo->chsw_info.ch_offset != HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
+		switch (ptdlsinfo->chsw_info.ch_offset) {
+		case HAL_PRIME_CHNL_OFFSET_LOWER:
+			pframe = rtw_tdls_set_second_channel_offset(pframe, pattrib, SCA);
+			break;
+		case HAL_PRIME_CHNL_OFFSET_UPPER:
+			pframe = rtw_tdls_set_second_channel_offset(pframe, pattrib, SCB);
+			break;
+		}
+	}
+
+	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
+	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+
+	pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
+
+}
+
+void rtw_build_tdls_ch_switch_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
+{
+
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	struct sta_priv	*pstapriv = &padapter->stapriv;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
+	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
+	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
+
+	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
+	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
+
+	pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
+}
+#endif
+
+#ifdef CONFIG_WFD
+void rtw_build_tunneled_probe_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe)
+{
+	u8 i;
+	_adapter *iface = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
+	struct wifidirect_info *pwdinfo;
+
+	u8 category = RTW_WLAN_CATEGORY_P2P;
+	u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a};
+	u8 probe_req = 4;
+	u8 wfdielen = 0;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 3, WFA_OUI, &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(probe_req), &(pattrib->pktlen));
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			pwdinfo = &iface->wdinfo;
+			if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+				wfdielen = build_probe_req_wfd_ie(pwdinfo, pframe);
+				pframe += wfdielen;
+				pattrib->pktlen += wfdielen;
+			}
+		}
+	}
+}
+
+void rtw_build_tunneled_probe_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe)
+{
+	u8 i;
+	_adapter *iface = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
+	struct wifidirect_info *pwdinfo;
+	u8 category = RTW_WLAN_CATEGORY_P2P;
+	u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a};
+	u8 probe_rsp = 5;
+	u8 wfdielen = 0;
+
+	pframe = rtw_tdls_set_payload_type(pframe, pattrib);
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 3, WFA_OUI, &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(probe_rsp), &(pattrib->pktlen));
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			pwdinfo = &iface->wdinfo;
+			if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+				wfdielen = build_probe_resp_wfd_ie(pwdinfo, pframe, 1);
+				pframe += wfdielen;
+				pattrib->pktlen += wfdielen;
+			}
+		}
+	}
+}
+#endif /* CONFIG_WFD */
+
+void _tdls_tpk_timer_hdl(void *FunctionContext)
+{
+	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
+	struct tdls_txmgmt txmgmt;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	ptdls_sta->TPK_count++;
+	/* TPK_timer expired in a second */
+	/* Retry timer should set at least 301 sec. */
+	if (ptdls_sta->TPK_count >= (ptdls_sta->TDLS_PeerKey_Lifetime - 3)) {
+		RTW_INFO("[TDLS] %s, Re-Setup TDLS link with "MAC_FMT" since TPK lifetime expires!\n",
+			__FUNCTION__, MAC_ARG(ptdls_sta->cmn.mac_addr));
+		ptdls_sta->TPK_count = 0;
+		_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+		issue_tdls_setup_req(ptdls_sta->padapter, &txmgmt, _FALSE);
+	}
+
+	_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
+}
+
+#ifdef CONFIG_TDLS_CH_SW
+void _tdls_ch_switch_timer_hdl(void *FunctionContext)
+{
+	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
+	_adapter *padapter = ptdls_sta->padapter;
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+
+	rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END_TO_BASE_CHNL);
+	RTW_INFO("[TDLS] %s, can't get traffic from op_ch:%d\n", __func__, rtw_get_oper_ch(padapter));
+}
+
+void _tdls_delay_timer_hdl(void *FunctionContext)
+{
+	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
+	_adapter *padapter = ptdls_sta->padapter;
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+
+	RTW_INFO("[TDLS] %s, op_ch:%d, tdls_state:0x%08x\n", __func__, rtw_get_oper_ch(padapter), ptdls_sta->tdls_sta_state);
+	pchsw_info->delay_switch_back = _TRUE;
+}
+
+void _tdls_stay_on_base_chnl_timer_hdl(void *FunctionContext)
+{
+	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
+	_adapter *padapter = ptdls_sta->padapter;
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+
+	if (ptdls_sta != NULL) {
+		issue_tdls_ch_switch_req(padapter, ptdls_sta);
+		pchsw_info->ch_sw_state |= TDLS_WAIT_CH_RSP_STATE;
+	}
+}
+
+void _tdls_ch_switch_monitor_timer_hdl(void *FunctionContext)
+{
+	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
+	_adapter *padapter = ptdls_sta->padapter;
+	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
+
+	rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END);
+	RTW_INFO("[TDLS] %s, does not receive ch sw req\n", __func__);
+}
+
+#endif
+
+void _tdls_handshake_timer_hdl(void *FunctionContext)
+{
+	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
+	_adapter *padapter = NULL;
+	struct tdls_txmgmt txmgmt;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+	txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
+
+	if (ptdls_sta != NULL) {
+		padapter = ptdls_sta->padapter;
+
+		RTW_INFO("[TDLS] Handshake time out\n");
+		if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA);
+		else
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY);
+	}
+}
+
+void _tdls_pti_timer_hdl(void *FunctionContext)
+{
+	struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
+	_adapter *padapter = NULL;
+	struct tdls_txmgmt txmgmt;
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
+	txmgmt.status_code = _RSON_TDLS_TEAR_TOOFAR_;
+
+	if (ptdls_sta != NULL) {
+		padapter = ptdls_sta->padapter;
+
+		if (ptdls_sta->tdls_sta_state & TDLS_WAIT_PTR_STATE) {
+			RTW_INFO("[TDLS] Doesn't receive PTR from peer dev:"MAC_FMT"; "
+				"Send TDLS Tear Down\n", MAC_ARG(ptdls_sta->cmn.mac_addr));
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA);
+		}
+	}
+}
+
+void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta)
+{
+	psta->padapter = padapter;
+	rtw_init_timer(&psta->TPK_timer, padapter, _tdls_tpk_timer_hdl, psta);
+#ifdef CONFIG_TDLS_CH_SW
+	rtw_init_timer(&psta->ch_sw_timer, padapter, _tdls_ch_switch_timer_hdl, psta);
+	rtw_init_timer(&psta->delay_timer, padapter, _tdls_delay_timer_hdl, psta);
+	rtw_init_timer(&psta->stay_on_base_chnl_timer, padapter, _tdls_stay_on_base_chnl_timer_hdl, psta);
+	rtw_init_timer(&psta->ch_sw_monitor_timer, padapter, _tdls_ch_switch_monitor_timer_hdl, psta);
+#endif
+	rtw_init_timer(&psta->handshake_timer, padapter, _tdls_handshake_timer_hdl, psta);
+	rtw_init_timer(&psta->pti_timer, padapter, _tdls_pti_timer_hdl, psta);
+}
+
+void rtw_cancel_tdls_timer(struct sta_info *psta)
+{
+	_cancel_timer_ex(&psta->TPK_timer);
+#ifdef CONFIG_TDLS_CH_SW
+	_cancel_timer_ex(&psta->ch_sw_timer);
+	_cancel_timer_ex(&psta->delay_timer);
+	_cancel_timer_ex(&psta->stay_on_base_chnl_timer);
+	_cancel_timer_ex(&psta->ch_sw_monitor_timer);
+#endif
+	_cancel_timer_ex(&psta->handshake_timer);
+	_cancel_timer_ex(&psta->pti_timer);
+}
+
+void rtw_tdls_teardown_pre_hdl(_adapter *padapter, struct sta_info *psta)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	_irqL irqL;
+
+	rtw_cancel_tdls_timer(psta);
+
+	_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
+	if (ptdlsinfo->sta_cnt != 0)
+		ptdlsinfo->sta_cnt--;
+	_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
+
+	if (ptdlsinfo->sta_cnt < MAX_ALLOWED_TDLS_STA_NUM) {
+		ptdlsinfo->sta_maximum = _FALSE;
+		_rtw_memset(&ptdlsinfo->ss_record, 0x00, sizeof(struct tdls_ss_record));
+	}
+
+	if (ptdlsinfo->sta_cnt == 0)
+		rtw_tdls_set_link_established(padapter, _FALSE);
+	else
+		RTW_INFO("Remain tdls sta:%02x\n", ptdlsinfo->sta_cnt);
+}
+
+void rtw_tdls_teardown_post_hdl(_adapter *padapter, struct sta_info *psta, u8 enqueue_cmd)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	/* Clear cam */
+	rtw_clearstakey_cmd(padapter, psta, enqueue_cmd);
+
+	/* Update sta media status */
+	if (enqueue_cmd)
+		rtw_sta_media_status_rpt_cmd(padapter, psta, 0);
+	else
+		rtw_sta_media_status_rpt(padapter, psta, 0);
+
+	/* Set RCR if necessary */
+	if (ptdlsinfo->sta_cnt == 0) {
+		if (enqueue_cmd)
+			rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
+		else
+			rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_NOLINK);
+	}
+
+	/* Free tdls sta info */
+	rtw_free_stainfo(padapter,  psta);
+}
+
+int rtw_tdls_is_driver_setup(_adapter *padapter)
+{
+	return padapter->tdlsinfo.driver_setup;
+}
+
+const char *rtw_tdls_action_txt(enum TDLS_ACTION_FIELD action)
+{
+	switch (action) {
+	case TDLS_SETUP_REQUEST:
+		return "TDLS_SETUP_REQUEST";
+	case TDLS_SETUP_RESPONSE:
+		return "TDLS_SETUP_RESPONSE";
+	case TDLS_SETUP_CONFIRM:
+		return "TDLS_SETUP_CONFIRM";
+	case TDLS_TEARDOWN:
+		return "TDLS_TEARDOWN";
+	case TDLS_PEER_TRAFFIC_INDICATION:
+		return "TDLS_PEER_TRAFFIC_INDICATION";
+	case TDLS_CHANNEL_SWITCH_REQUEST:
+		return "TDLS_CHANNEL_SWITCH_REQUEST";
+	case TDLS_CHANNEL_SWITCH_RESPONSE:
+		return "TDLS_CHANNEL_SWITCH_RESPONSE";
+	case TDLS_PEER_PSM_REQUEST:
+		return "TDLS_PEER_PSM_REQUEST";
+	case TDLS_PEER_PSM_RESPONSE:
+		return "TDLS_PEER_PSM_RESPONSE";
+	case TDLS_PEER_TRAFFIC_RESPONSE:
+		return "TDLS_PEER_TRAFFIC_RESPONSE";
+	case TDLS_DISCOVERY_REQUEST:
+		return "TDLS_DISCOVERY_REQUEST";
+	case TDLS_DISCOVERY_RESPONSE:
+		return "TDLS_DISCOVERY_RESPONSE";
+	default:
+		return "UNKNOWN";
+	}
+}
+
+#endif /* CONFIG_TDLS */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_vht.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_vht.c
index 0bdc2a38e7e5..3966a13465f9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_vht.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_vht.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,60 +12,163 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_VHT_C
 
 #include <drv_types.h>
+#include <hal_data.h>
 
 #ifdef CONFIG_80211AC_VHT
-// 				20/40/80,	ShortGI,	MCS Rate 
-const u16 VHT_MCS_DATA_RATE[3][2][30] = 
-	{	{	{13, 26, 39, 52, 78, 104, 117, 130, 156, 156,
-			 26, 52, 78, 104, 156, 208, 234, 260, 312, 312,
-			 39, 78, 117, 156, 234, 312, 351, 390, 468, 520},			// Long GI, 20MHz
-			{14, 29, 43, 58, 87, 116, 130, 144, 173, 173,
+const u16 _vht_max_mpdu_len[] = {
+	3895,
+	7991,
+	11454,
+	0,
+};
+
+const u8 _vht_sup_ch_width_set_to_bw_cap[] = {
+	BW_CAP_80M,
+	BW_CAP_80M | BW_CAP_160M,
+	BW_CAP_80M | BW_CAP_160M | BW_CAP_80_80M,
+	0,
+};
+
+const char *const _vht_sup_ch_width_set_str[] = {
+	"80MHz",
+	"160MHz",
+	"160MHz & 80+80MHz",
+	"BW-RSVD",
+};
+
+void dump_vht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len)
+{
+	if (buf_len != VHT_CAP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid VHT capability IE len:%d != %d\n", buf_len, VHT_CAP_IE_LEN);
+		return;
+	}
+
+	RTW_PRINT_SEL(sel, "cap_info:%02x %02x %02x %02x: MAX_MPDU_LEN:%u %s%s%s%s%s RX-STBC:%u MAX_AMPDU_LEN:%u\n"
+		, *(buf), *(buf + 1), *(buf + 2), *(buf + 3)
+		, vht_max_mpdu_len(GET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(buf))
+		, vht_sup_ch_width_set_str(GET_VHT_CAPABILITY_ELE_CHL_WIDTH(buf))
+		, GET_VHT_CAPABILITY_ELE_RX_LDPC(buf) ? " RX-LDPC" : ""
+		, GET_VHT_CAPABILITY_ELE_SHORT_GI80M(buf) ? " SGI-80" : ""
+		, GET_VHT_CAPABILITY_ELE_SHORT_GI160M(buf) ? " SGI-160" : ""
+		, GET_VHT_CAPABILITY_ELE_TX_STBC(buf) ? " TX-STBC" : ""
+		, GET_VHT_CAPABILITY_ELE_RX_STBC(buf)
+		, VHT_MAX_AMPDU_LEN(GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(buf))
+	);
+}
+
+void dump_vht_cap_ie(void *sel, const u8 *ie, u32 ie_len)
+{
+	const u8 *pos = ie;
+	u16 id;
+	u16 len;
+
+	const u8 *vht_cap_ie;
+	sint vht_cap_ielen;
+
+	vht_cap_ie = rtw_get_ie(ie, WLAN_EID_VHT_CAPABILITY, &vht_cap_ielen, ie_len);
+	if (!ie || vht_cap_ie != ie)
+		return;
+
+	dump_vht_cap_ie_content(sel, vht_cap_ie + 2, vht_cap_ielen);
+}
+
+const char *const _vht_op_ch_width_str[] = {
+	"20 or 40MHz",
+	"80MHz",
+	"160MHz",
+	"80+80MHz",
+	"BW-RSVD",
+};
+
+void dump_vht_op_ie_content(void *sel, const u8 *buf, u32 buf_len)
+{
+	if (buf_len != VHT_OP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid VHT operation IE len:%d != %d\n", buf_len, VHT_OP_IE_LEN);
+		return;
+	}
+
+	RTW_PRINT_SEL(sel, "%s, ch0:%u, ch1:%u\n"
+		, vht_op_ch_width_str(GET_VHT_OPERATION_ELE_CHL_WIDTH(buf))
+		, GET_VHT_OPERATION_ELE_CENTER_FREQ1(buf)
+		, GET_VHT_OPERATION_ELE_CENTER_FREQ2(buf)
+	);
+}
+
+void dump_vht_op_ie(void *sel, const u8 *ie, u32 ie_len)
+{
+	const u8 *pos = ie;
+	u16 id;
+	u16 len;
+
+	const u8 *vht_op_ie;
+	sint vht_op_ielen;
+
+	vht_op_ie = rtw_get_ie(ie, WLAN_EID_VHT_OPERATION, &vht_op_ielen, ie_len);
+	if (!ie || vht_op_ie != ie)
+		return;
+
+	dump_vht_op_ie_content(sel, vht_op_ie + 2, vht_op_ielen);
+}
+
+/*				20/40/80,	ShortGI,	MCS Rate  */
+const u16 VHT_MCS_DATA_RATE[3][2][30] = {
+	{	{
+			13, 26, 39, 52, 78, 104, 117, 130, 156, 156,
+			26, 52, 78, 104, 156, 208, 234, 260, 312, 312,
+			39, 78, 117, 156, 234, 312, 351, 390, 468, 520
+		},			/* Long GI, 20MHz */
+		{
+			14, 29, 43, 58, 87, 116, 130, 144, 173, 173,
 			29, 58, 87, 116, 173, 231, 260, 289, 347, 347,
-			43,	87, 130, 173, 260, 347,390,	433,	520, 578}	},		// Short GI, 20MHz
-		{	{27, 54, 81, 108, 162, 216, 243, 270, 324, 360, 
+			43,	87, 130, 173, 260, 347, 390,	433,	520, 578
+		}
+	},		/* Short GI, 20MHz */
+	{	{
+			27, 54, 81, 108, 162, 216, 243, 270, 324, 360,
 			54, 108, 162, 216, 324, 432, 486, 540, 648, 720,
-			81, 162, 243, 324, 486, 648, 729, 810, 972, 1080}, 		// Long GI, 40MHz
-			{30, 60, 90, 120, 180, 240, 270, 300,360, 400, 
+			81, 162, 243, 324, 486, 648, 729, 810, 972, 1080
+		}, 		/* Long GI, 40MHz */
+		{
+			30, 60, 90, 120, 180, 240, 270, 300, 360, 400,
 			60, 120, 180, 240, 360, 480, 540, 600, 720, 800,
-			90, 180, 270, 360, 540, 720, 810, 900, 1080, 1200}},		// Short GI, 40MHz
-		{	{59, 117,  176, 234, 351, 468, 527, 585, 702, 780,
+			90, 180, 270, 360, 540, 720, 810, 900, 1080, 1200
+		}
+	},		/* Short GI, 40MHz */
+	{	{
+			59, 117,  176, 234, 351, 468, 527, 585, 702, 780,
 			117, 234, 351, 468, 702, 936, 1053, 1170, 1404, 1560,
-			176, 351, 527, 702, 1053, 1404, 1580, 1755, 2106, 2340},	/* Long GI, 80MHz */
-			{65, 130, 195, 260, 390, 520, 585, 650, 780, 867, 
-			130, 260, 390, 520, 780, 1040, 1170, 1300, 1560,1734,
-			195, 390, 585, 780, 1170, 1560, 1755, 1950, 2340, 2600}	}	/* Short GI, 80MHz */
-	};
+			176, 351, 527, 702, 1053, 1404, 1580, 1755, 2106, 2340
+		},	/* Long GI, 80MHz */
+		{
+			65, 130, 195, 260, 390, 520, 585, 650, 780, 867,
+			130, 260, 390, 520, 780, 1040, 1170, 1300, 1560, 1734,
+			195, 390, 585, 780, 1170, 1560, 1755, 1950, 2340, 2600
+		}
+	}	/* Short GI, 80MHz */
+};
 
 u8	rtw_get_vht_highest_rate(u8 *pvht_mcs_map)
 {
 	u8	i, j;
 	u8	bit_map;
 	u8	vht_mcs_rate = 0;
-	
-	for(i = 0; i < 2; i++)
-	{
-		if(pvht_mcs_map[i] != 0xff)
-		{
-			for(j = 0; j < 8; j += 2)
-			{
+
+	for (i = 0; i < 2; i++) {
+		if (pvht_mcs_map[i] != 0xff) {
+			for (j = 0; j < 8; j += 2) {
 				bit_map = (pvht_mcs_map[i] >> j) & 3;
-				
-				if(bit_map != 3)
-					vht_mcs_rate = MGN_VHT1SS_MCS7 + 10*j/2 + i*40 + bit_map;  //VHT rate indications begin from 0x90
+
+				if (bit_map != 3)
+					vht_mcs_rate = MGN_VHT1SS_MCS7 + 10 * j / 2 + i * 40 + bit_map; /* VHT rate indications begin from 0x90 */
 			}
 		}
 	}
-	
-	/* DBG_871X("HighestVHTMCSRate is %x\n", vht_mcs_rate); */
+
+	/* RTW_INFO("HighestVHTMCSRate is %x\n", vht_mcs_rate); */
 	return vht_mcs_rate;
 }
 
@@ -73,210 +177,228 @@ u8	rtw_vht_mcsmap_to_nss(u8 *pvht_mcs_map)
 	u8	i, j;
 	u8	bit_map;
 	u8	nss = 0;
-	
-	for(i = 0; i < 2; i++)
-	{
-		if(pvht_mcs_map[i] != 0xff)
-		{
-			for(j = 0; j < 8; j += 2)
-			{
+
+	for (i = 0; i < 2; i++) {
+		if (pvht_mcs_map[i] != 0xff) {
+			for (j = 0; j < 8; j += 2) {
 				bit_map = (pvht_mcs_map[i] >> j) & 3;
-				
-				if(bit_map != 3)
+
+				if (bit_map != 3)
 					nss++;
 			}
 		}
 	}
-	
-	/* DBG_871X("%s : %dSS\n", __FUNCTION__, nss); */
+
+	/* RTW_INFO("%s : %dSS\n", __FUNCTION__, nss); */
 	return nss;
 }
 
-void	rtw_vht_nss_to_mcsmap(u8 nss, u8 *target_mcs_map, u8 *cur_mcs_map)
+void rtw_vht_nss_to_mcsmap(u8 nss, u8 *target_mcs_map, u8 *cur_mcs_map)
 {
 	u8	i, j;
 	u8	cur_rate, target_rate;
-	
-	for(i = 0; i < 2; i++)
-	{
+
+	for (i = 0; i < 2; i++) {
 		target_mcs_map[i] = 0;
-		for(j = 0; j < 8; j+=2)
-		{
+		for (j = 0; j < 8; j += 2) {
 			cur_rate = (cur_mcs_map[i] >> j) & 3;
-			if(cur_rate == 3)  //0x3 indicates not supported that num of SS
+			if (cur_rate == 3) /* 0x3 indicates not supported that num of SS */
 				target_rate = 3;
-			else if(nss <= ((j/2)+i*4))
+			else if (nss <= ((j / 2) + i * 4))
 				target_rate = 3;
-			else	
+			else
 				target_rate = cur_rate;
 
 			target_mcs_map[i] |= (target_rate << j);
 		}
 	}
-	
-	//DBG_871X("%s : %dSS\n", __FUNCTION__, nss);
+
+	/* RTW_INFO("%s : %dSS\n", __FUNCTION__, nss); */
 }
 
 u16	rtw_vht_mcs_to_data_rate(u8 bw, u8 short_GI, u8 vht_mcs_rate)
 {
-	if(vht_mcs_rate > MGN_VHT3SS_MCS9)
+	if (vht_mcs_rate > MGN_VHT3SS_MCS9)
 		vht_mcs_rate = MGN_VHT3SS_MCS9;
-	/* DBG_871X("bw=%d, short_GI=%d, ((vht_mcs_rate - MGN_VHT1SS_MCS0)&0x3f)=%d\n", bw, short_GI, ((vht_mcs_rate - MGN_VHT1SS_MCS0)&0x3f)); */
-	return VHT_MCS_DATA_RATE[bw][short_GI][((vht_mcs_rate - MGN_VHT1SS_MCS0)&0x3f)];
+	/* RTW_INFO("bw=%d, short_GI=%d, ((vht_mcs_rate - MGN_VHT1SS_MCS0)&0x3f)=%d\n", bw, short_GI, ((vht_mcs_rate - MGN_VHT1SS_MCS0)&0x3f)); */
+	return VHT_MCS_DATA_RATE[bw][short_GI][((vht_mcs_rate - MGN_VHT1SS_MCS0) & 0x3f)];
 }
 
 void	rtw_vht_use_default_setting(_adapter *padapter)
 {
-	struct mlme_priv 		*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
 	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
 	BOOLEAN		bHwLDPCSupport = _FALSE, bHwSTBCSupport = _FALSE;
+#ifdef CONFIG_BEAMFORMING
 	BOOLEAN		bHwSupportBeamformer = _FALSE, bHwSupportBeamformee = _FALSE;
+	u8	mu_bfer, mu_bfee;
+#endif /* CONFIG_BEAMFORMING */
 	u8	rf_type = 0;
+	u8 tx_nss, rx_nss;
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	pvhtpriv->sgi_80m = TEST_FLAG(pregistrypriv->short_gi, BIT2) ? _TRUE : _FALSE;
 
-	// LDPC support
+	/* LDPC support */
 	rtw_hal_get_def_var(padapter, HAL_DEF_RX_LDPC, (u8 *)&bHwLDPCSupport);
 	CLEAR_FLAGS(pvhtpriv->ldpc_cap);
-	if(bHwLDPCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->ldpc_cap, BIT0))
+	if (bHwLDPCSupport) {
+		if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT0))
 			SET_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_RX);
 	}
 	rtw_hal_get_def_var(padapter, HAL_DEF_TX_LDPC, (u8 *)&bHwLDPCSupport);
-	if(bHwLDPCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->ldpc_cap, BIT1))
+	if (bHwLDPCSupport) {
+		if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT1))
 			SET_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX);
 	}
 	if (pvhtpriv->ldpc_cap)
-		DBG_871X("[VHT] Support LDPC = 0x%02X\n", pvhtpriv->ldpc_cap);
+		RTW_INFO("[VHT] Support LDPC = 0x%02X\n", pvhtpriv->ldpc_cap);
 
-	// STBC
+	/* STBC */
 	rtw_hal_get_def_var(padapter, HAL_DEF_TX_STBC, (u8 *)&bHwSTBCSupport);
 	CLEAR_FLAGS(pvhtpriv->stbc_cap);
-	if(bHwSTBCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->stbc_cap, BIT1))
+	if (bHwSTBCSupport) {
+		if (TEST_FLAG(pregistrypriv->stbc_cap, BIT1))
 			SET_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX);
 	}
 	rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)&bHwSTBCSupport);
-	if(bHwSTBCSupport)
-	{
-		if(TEST_FLAG(pregistrypriv->stbc_cap, BIT0))
+	if (bHwSTBCSupport) {
+		if (TEST_FLAG(pregistrypriv->stbc_cap, BIT0))
 			SET_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_RX);
 	}
 	if (pvhtpriv->stbc_cap)
-		DBG_871X("[VHT] Support STBC = 0x%02X\n", pvhtpriv->stbc_cap);
+		RTW_INFO("[VHT] Support STBC = 0x%02X\n", pvhtpriv->stbc_cap);
 
-	// Beamforming setting
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&bHwSupportBeamformer);
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&bHwSupportBeamformee);
+	/* Beamforming setting */
 	CLEAR_FLAGS(pvhtpriv->beamform_cap);
-	if (TEST_FLAG(pregistrypriv->beamform_cap, BIT0) && bHwSupportBeamformer) {
-		#ifdef CONFIG_CONCURRENT_MODE
-			if ((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE) {
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+	/* only enable beamforming in STA client mode */
+	if (MLME_IS_STA(padapter) && !MLME_IS_GC(padapter)
+				  && !MLME_IS_ADHOC(padapter)
+				  && !MLME_IS_MESH(padapter))
+#endif
+	{
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER,
+			(u8 *)&bHwSupportBeamformer);
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE,
+			(u8 *)&bHwSupportBeamformee);
+		mu_bfer = _FALSE;
+		mu_bfee = _FALSE;
+		rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMER, &mu_bfer);
+		rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMEE, &mu_bfee);
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT0) && bHwSupportBeamformer) {
+#ifdef CONFIG_CONCURRENT_MODE
+			if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
 				SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
-				DBG_871X("[VHT] CONCURRENT AP Support Beamformer\n");
+				RTW_INFO("[VHT] CONCURRENT AP Support Beamformer\n");
+				if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(2))
+				    && (_TRUE == mu_bfer)) {
+					SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
+					RTW_INFO("[VHT] Support MU-MIMO AP\n");
+				}
 			} else
-			DBG_871X("[VHT] CONCURRENT not AP ;not allow  Support Beamformer\n");
-		#else
+				RTW_INFO("[VHT] CONCURRENT not AP ;not allow  Support Beamformer\n");
+#else
 			SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
-			DBG_871X("[VHT] Support Beamformer\n");
-		#endif
-	}
-	if(TEST_FLAG(pregistrypriv->beamform_cap, BIT1) && bHwSupportBeamformee)
-	{
-		SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
-		DBG_871X("[VHT] Support Beamformee\n");
+			RTW_INFO("[VHT] Support Beamformer\n");
+			if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(2))
+			    && (_TRUE == mu_bfer)
+			    && ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
+				SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
+				RTW_INFO("[VHT] Support MU-MIMO AP\n");
+			}
+#endif
+		}
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT1) && bHwSupportBeamformee) {
+			SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
+			RTW_INFO("[VHT] Support Beamformee\n");
+			if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(3))
+			    && (_TRUE == mu_bfee)
+			    && ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)) {
+				SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
+				RTW_INFO("[VHT] Support MU-MIMO STA\n");
+			}
+		}
 	}
+#endif /* CONFIG_BEAMFORMING */
 
 	pvhtpriv->ampdu_len = pregistrypriv->ampdu_factor;
 
 	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+	tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
+	rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
 
-	if (rf_type == RF_3T3R)
-		pvhtpriv->vht_mcs_map[0] = 0xea;	/* support 1SS MCS 0~9 2SS MCS 0~9 3SS MCS 0~9 */
-	else if(rf_type == RF_2T2R)
-		pvhtpriv->vht_mcs_map[0] = 0xfa;	/* support 1SS MCS 0~9 2SS MCS 0~9 */
-	else
-		pvhtpriv->vht_mcs_map[0] = 0xfe;	/* Only support 1SS MCS 0~9; */
-	pvhtpriv->vht_mcs_map[1] = 0xff;
-
-	if(pregistrypriv->vht_rate_sel == 1)
-	{			
-		pvhtpriv->vht_mcs_map[0] = 0xfc;	// support 1SS MCS 0~7
-	}
-	else if(pregistrypriv->vht_rate_sel == 2)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xfd;	// Support 1SS MCS 0~8
-	}
-	else if(pregistrypriv->vht_rate_sel == 3)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xfe;	// Support 1SS MCS 0~9
-	}
-	else if(pregistrypriv->vht_rate_sel == 4)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xf0;	// support 1SS MCS 0~7 2SS MCS 0~7
-	}
-	else if(pregistrypriv->vht_rate_sel == 5)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xf5;	// support 1SS MCS 0~8 2SS MCS 0~8
-	}
-	else if(pregistrypriv->vht_rate_sel == 6)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xfa;	// support 1SS MCS 0~9 2SS MCS 0~9
-	}
-	else if(pregistrypriv->vht_rate_sel == 7)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xf8;	// support 1SS MCS 0-7 2SS MCS 0~9
-	}
-	else if(pregistrypriv->vht_rate_sel == 8)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xf9;	// support 1SS MCS 0-8 2SS MCS 0~9
-	}
-	else if(pregistrypriv->vht_rate_sel == 9)
-	{
-		pvhtpriv->vht_mcs_map[0] = 0xf4;	// support 1SS MCS 0-7 2SS MCS 0~8
-	}
-
+	/* for now, vhtpriv.vht_mcs_map comes from RX NSS */
+	rtw_vht_nss_to_mcsmap(rx_nss, pvhtpriv->vht_mcs_map, pregistrypriv->vht_rx_mcs_map);
 	pvhtpriv->vht_highest_rate = rtw_get_vht_highest_rate(pvhtpriv->vht_mcs_map);
 }
 
-u64	rtw_vht_rate_to_bitmap(u8 *pVHTRate)
+u64	rtw_vht_mcs_map_to_bitmap(u8 *mcs_map, u8 nss)
 {
+	u8 i, j, tmp;
+	u64 bitmap = 0;
+	u8 bits_nss = nss * 2;
 
-	u8	i,j , tmpRate;
-	u64	RateBitmap = 0;
-	u8 Bits_3ss = 6;
-		
-	for(i = j= 0; i < Bits_3ss; i+=2, j+=10)
-	{
+	for (i = j = 0; i < bits_nss; i += 2, j += 10) {
 		/* every two bits means single sptial stream */
-		tmpRate = (pVHTRate[0] >> i) & 3;
+		tmp = (mcs_map[i / 8] >> i) & 3;
 
-		switch(tmpRate){
+		switch (tmp) {
 		case 2:
-			RateBitmap = RateBitmap | (0x03ff << j);
+			bitmap = bitmap | (0x03ff << j);
 			break;
 		case 1:
-			RateBitmap = RateBitmap | (0x01ff << j);
-		break;
-
+			bitmap = bitmap | (0x01ff << j);
+			break;
 		case 0:
-			RateBitmap = RateBitmap | (0x00ff << j);
-		break;
-
+			bitmap = bitmap | (0x00ff << j);
+			break;
 		default:
 			break;
 		}
 	}
-	DBG_871X("RateBitmap=%016llx , pVHTRate[0]=%02x, pVHTRate[1]=%02x\n", RateBitmap, pVHTRate[0], pVHTRate[1]);
-	return RateBitmap;
+
+	RTW_INFO("vht_mcs_map=%02x %02x, nss=%u => bitmap=%016llx\n"
+		, mcs_map[0], mcs_map[1], nss, bitmap);
+
+	return bitmap;
 }
 
+#ifdef CONFIG_BEAMFORMING
+void update_sta_vht_info_apmode_bf_cap(_adapter *padapter, struct sta_info *psta)
+{
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct vht_priv	*pvhtpriv_ap = &pmlmepriv->vhtpriv;
+	struct vht_priv	*pvhtpriv_sta = &psta->vhtpriv;
+	u16	cur_beamform_cap = 0;
+
+	/* B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee */
+	if (TEST_FLAG(pvhtpriv_ap->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) &&
+	    GET_VHT_CAPABILITY_ELE_SU_BFEE(pvhtpriv_sta->vht_cap)) {
+		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
+		/*Shift to BEAMFORMING_VHT_BEAMFORMER_STS_CAP*/
+		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pvhtpriv_sta->vht_cap) << 8);
+	}
+
+	/* B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer */
+	if (TEST_FLAG(pvhtpriv_ap->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) &&
+	    GET_VHT_CAPABILITY_ELE_SU_BFER(pvhtpriv_sta->vht_cap)) {
+		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
+		/*Shit to BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM*/
+		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pvhtpriv_sta->vht_cap) << 12);
+	}
+
+	if (cur_beamform_cap)
+		RTW_INFO("Current STA(%d) VHT Beamforming Setting = %02X\n", psta->cmn.aid, cur_beamform_cap);
+
+	pvhtpriv_sta->beamform_cap = cur_beamform_cap;
+	psta->cmn.bf_info.vht_beamform_cap = cur_beamform_cap;
+}
+#endif
+
 void	update_sta_vht_info_apmode(_adapter *padapter, PVOID sta)
 {
 	struct sta_info	*psta = (struct sta_info *)sta;
@@ -284,83 +406,75 @@ void	update_sta_vht_info_apmode(_adapter *padapter, PVOID sta)
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct vht_priv	*pvhtpriv_ap = &pmlmepriv->vhtpriv;
 	struct vht_priv	*pvhtpriv_sta = &psta->vhtpriv;
-	struct ht_priv		*phtpriv_sta = &psta->htpriv;
-	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, bw_mode = 0;
-	u16	cur_beamform_cap = 0;
+	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0;
+	s8 bw_mode = -1;
 	u8	*pcap_mcs;
 
-	if (pvhtpriv_sta->vht_option == _FALSE) {
+	if (pvhtpriv_sta->vht_option == _FALSE)
 		return;
+
+	if (pvhtpriv_sta->op_present) {
+		switch (GET_VHT_OPERATION_ELE_CHL_WIDTH(pvhtpriv_sta->vht_op)) {
+		case 1: /* 80MHz */
+		case 2: /* 160MHz */
+		case 3: /* 80+80 */
+			bw_mode = CHANNEL_WIDTH_80; /* only support up to 80MHz for now */
+			break;
+		}
 	}
 
-	bw_mode = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(&pvhtpriv_sta->vht_op_mode_notify);
-	
-	//if (bw_mode > psta->bw_mode)
-	psta->bw_mode = bw_mode;
+	if (pvhtpriv_sta->notify_present)
+		bw_mode = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(&pvhtpriv_sta->vht_op_mode_notify);
+	else if (MLME_IS_AP(padapter)) {
+		/* for VHT client without Operating Mode Notify IE; minimal 80MHz */
+		if (bw_mode < CHANNEL_WIDTH_80)
+			bw_mode = CHANNEL_WIDTH_80;
+	}
 
-	// B4 Rx LDPC
-	if (TEST_FLAG(pvhtpriv_ap->ldpc_cap, LDPC_VHT_ENABLE_TX) && 
-		GET_VHT_CAPABILITY_ELE_RX_LDPC(pvhtpriv_sta->vht_cap))
-	{
+	if (bw_mode != -1)
+		psta->cmn.bw_mode = bw_mode; /* update bw_mode only if get value from VHT IEs */
+
+	psta->cmn.ra_info.is_vht_enable = _TRUE;
+
+	/* B4 Rx LDPC */
+	if (TEST_FLAG(pvhtpriv_ap->ldpc_cap, LDPC_VHT_ENABLE_TX) &&
+	    GET_VHT_CAPABILITY_ELE_RX_LDPC(pvhtpriv_sta->vht_cap)) {
 		SET_FLAG(cur_ldpc_cap, (LDPC_VHT_ENABLE_TX | LDPC_VHT_CAP_TX));
-		DBG_871X("Current STA(%d) VHT LDPC = %02X\n", psta->aid, cur_ldpc_cap);
+		RTW_INFO("Current STA(%d) VHT LDPC = %02X\n", psta->cmn.aid, cur_ldpc_cap);
 	}
 	pvhtpriv_sta->ldpc_cap = cur_ldpc_cap;
 
-	if (psta->bw_mode > pmlmeext->cur_bwmode)
-		psta->bw_mode = pmlmeext->cur_bwmode;
+	if (psta->cmn.bw_mode > pmlmeext->cur_bwmode)
+		psta->cmn.bw_mode = pmlmeext->cur_bwmode;
 
-	if (psta->bw_mode == CHANNEL_WIDTH_80) {
-		// B5 Short GI for 80 MHz
+	if (psta->cmn.bw_mode == CHANNEL_WIDTH_80) {
+		/* B5 Short GI for 80 MHz */
 		pvhtpriv_sta->sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI80M(pvhtpriv_sta->vht_cap) & pvhtpriv_ap->sgi_80m) ? _TRUE : _FALSE;
-		//DBG_871X("Current STA ShortGI80MHz = %d\n", pvhtpriv_sta->sgi_80m);
-	} else if (psta->bw_mode >= CHANNEL_WIDTH_160) {
-		// B5 Short GI for 80 MHz
+		/* RTW_INFO("Current STA ShortGI80MHz = %d\n", pvhtpriv_sta->sgi_80m); */
+	} else if (psta->cmn.bw_mode >= CHANNEL_WIDTH_160) {
+		/* B5 Short GI for 80 MHz */
 		pvhtpriv_sta->sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI160M(pvhtpriv_sta->vht_cap) & pvhtpriv_ap->sgi_80m) ? _TRUE : _FALSE;
-		//DBG_871X("Current STA ShortGI160MHz = %d\n", pvhtpriv_sta->sgi_80m);
+		/* RTW_INFO("Current STA ShortGI160MHz = %d\n", pvhtpriv_sta->sgi_80m); */
 	}
 
-	// B8 B9 B10 Rx STBC
-	if (TEST_FLAG(pvhtpriv_ap->stbc_cap, STBC_VHT_ENABLE_TX) && 
-		GET_VHT_CAPABILITY_ELE_RX_STBC(pvhtpriv_sta->vht_cap))
-	{
-		SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));	
-		DBG_871X("Current STA(%d) VHT STBC = %02X\n", psta->aid, cur_stbc_cap);
+	/* B8 B9 B10 Rx STBC */
+	if (TEST_FLAG(pvhtpriv_ap->stbc_cap, STBC_VHT_ENABLE_TX) &&
+	    GET_VHT_CAPABILITY_ELE_RX_STBC(pvhtpriv_sta->vht_cap)) {
+		SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));
+		RTW_INFO("Current STA(%d) VHT STBC = %02X\n", psta->cmn.aid, cur_stbc_cap);
 	}
 	pvhtpriv_sta->stbc_cap = cur_stbc_cap;
 
 #ifdef CONFIG_BEAMFORMING
-	// B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee
-	if (TEST_FLAG(pvhtpriv_ap->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) && 
-		GET_VHT_CAPABILITY_ELE_SU_BFEE(pvhtpriv_sta->vht_cap))
-	{
-		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
-		/*Shift to BEAMFORMING_VHT_BEAMFORMER_STS_CAP*/
-		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pvhtpriv_sta->vht_cap)<<8);
-	}
+	update_sta_vht_info_apmode_bf_cap(padapter, psta);
+#endif
 
-	// B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer
-	if (TEST_FLAG(pvhtpriv_ap->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) &&
-		GET_VHT_CAPABILITY_ELE_SU_BFER(pvhtpriv_sta->vht_cap))
-	{
-		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
-		/*Shit to BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM*/
-		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pvhtpriv_sta->vht_cap)<<12);
-	}
-	pvhtpriv_sta->beamform_cap = cur_beamform_cap;
-	if (cur_beamform_cap) {
-		DBG_871X("Current STA(%d) VHT Beamforming Setting = %02X\n", psta->aid, cur_beamform_cap);
-	}
- #endif
-
-	// B23 B24 B25 Maximum A-MPDU Length Exponent
+	/* B23 B24 B25 Maximum A-MPDU Length Exponent */
 	pvhtpriv_sta->ampdu_len = GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pvhtpriv_sta->vht_cap);
 
 	pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pvhtpriv_sta->vht_cap);
 	_rtw_memcpy(pvhtpriv_sta->vht_mcs_map, pcap_mcs, 2);
-
 	pvhtpriv_sta->vht_highest_rate = rtw_get_vht_highest_rate(pvhtpriv_sta->vht_mcs_map);
-
 }
 
 void	update_hw_vht_param(_adapter *padapter)
@@ -373,141 +487,176 @@ void	update_hw_vht_param(_adapter *padapter)
 
 	ht_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;
 
-	if(pvhtpriv->ampdu_len > ht_AMPDU_len)
+	if (pvhtpriv->ampdu_len > ht_AMPDU_len)
 		rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&pvhtpriv->ampdu_len));
 }
 
 void VHT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 {
-	struct mlme_priv 		*pmlmepriv = &padapter->mlmepriv;
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, rf_type = RF_1T1R;
+	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, rf_type = RF_1T1R, tx_nss = 0;
 	u16	cur_beamform_cap = 0;
 	u8	*pcap_mcs;
-	u8	vht_mcs[2];
 
-	if(pIE==NULL) return;
+	if (pIE == NULL)
+		return;
 
-	if(pvhtpriv->vht_option == _FALSE)	return;
+	if (pvhtpriv->vht_option == _FALSE)
+		return;
 
 	pmlmeinfo->VHT_enable = 1;
 
-	// B4 Rx LDPC
-	if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX) && 
-		GET_VHT_CAPABILITY_ELE_RX_LDPC(pIE->data))
-	{
+	/* B4 Rx LDPC */
+	if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX) &&
+	    GET_VHT_CAPABILITY_ELE_RX_LDPC(pIE->data)) {
 		SET_FLAG(cur_ldpc_cap, (LDPC_VHT_ENABLE_TX | LDPC_VHT_CAP_TX));
-		DBG_871X("Current VHT LDPC Setting = %02X\n", cur_ldpc_cap);
+		RTW_INFO("Current VHT LDPC Setting = %02X\n", cur_ldpc_cap);
 	}
 	pvhtpriv->ldpc_cap = cur_ldpc_cap;
 
-	// B5 Short GI for 80 MHz
+	/* B5 Short GI for 80 MHz */
 	pvhtpriv->sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI80M(pIE->data) & pvhtpriv->sgi_80m) ? _TRUE : _FALSE;
-	//DBG_871X("Current ShortGI80MHz = %d\n", pvhtpriv->sgi_80m);
+	/* RTW_INFO("Current ShortGI80MHz = %d\n", pvhtpriv->sgi_80m); */
 
-	// B8 B9 B10 Rx STBC
-	if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX) && 
-		GET_VHT_CAPABILITY_ELE_RX_STBC(pIE->data))
-	{
-		SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));	
-		DBG_871X("Current VHT STBC Setting = %02X\n", cur_stbc_cap);
+	/* B8 B9 B10 Rx STBC */
+	if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX) &&
+	    GET_VHT_CAPABILITY_ELE_RX_STBC(pIE->data)) {
+		SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));
+		RTW_INFO("Current VHT STBC Setting = %02X\n", cur_stbc_cap);
 	}
 	pvhtpriv->stbc_cap = cur_stbc_cap;
 #ifdef CONFIG_BEAMFORMING
-	// B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee
-	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) && 
-		GET_VHT_CAPABILITY_ELE_SU_BFEE(pIE->data))
-	{
+#ifdef RTW_BEAMFORMING_VERSION_2
+	/*
+	 * B11 SU Beamformer Capable,
+	 * the target supports Beamformer and we are Beamformee
+	 */
+	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)
+	    && GET_VHT_CAPABILITY_ELE_SU_BFER(pIE->data)) {
+		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
+
+		/* Shift to BEAMFORMING_VHT_BEAMFORMEE_STS_CAP */
+		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pIE->data) << 8);
+
+		/*
+		 * B19 MU Beamformer Capable,
+		 * the target supports Beamformer and we are Beamformee
+		 */
+		if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)
+		    && GET_VHT_CAPABILITY_ELE_MU_BFER(pIE->data))
+			SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
+	}
+
+	/*
+	 * B12 SU Beamformee Capable,
+	 * the target supports Beamformee and we are Beamformer
+	 */
+	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)
+	    && GET_VHT_CAPABILITY_ELE_SU_BFEE(pIE->data)) {
+		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
+
+		/* Shit to BEAMFORMING_VHT_BEAMFORMER_SOUND_DIM */
+		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pIE->data) << 12);
+
+		/*
+		 * B20 MU Beamformee Capable,
+		 * the target supports Beamformee and we are Beamformer
+		 */
+		if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)
+		    && GET_VHT_CAPABILITY_ELE_MU_BFEE(pIE->data))
+			SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
+	}
+
+	pvhtpriv->beamform_cap = cur_beamform_cap;
+	RTW_INFO("Current VHT Beamforming Setting=0x%04X\n", cur_beamform_cap);
+#else /* !RTW_BEAMFORMING_VERSION_2 */
+	/* B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee */
+	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) &&
+	    GET_VHT_CAPABILITY_ELE_SU_BFEE(pIE->data)) {
 		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
 		/*Shift to BEAMFORMING_VHT_BEAMFORMER_STS_CAP*/
-		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pIE->data)<<8);
+		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pIE->data) << 8);
 	}
 
-	// B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer
+	/* B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer */
 	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) &&
-		GET_VHT_CAPABILITY_ELE_SU_BFER(pIE->data))
-	{
+	    GET_VHT_CAPABILITY_ELE_SU_BFER(pIE->data)) {
 		SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
 		/*Shit to BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM*/
-		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pIE->data)<<12);
-		
+		SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pIE->data) << 12);
+
 	}
 	pvhtpriv->beamform_cap = cur_beamform_cap;
-	if (cur_beamform_cap) {
-		DBG_871X("Current VHT Beamforming Setting = %02X\n", cur_beamform_cap);
-	}
- #endif
-	// B23 B24 B25 Maximum A-MPDU Length Exponent
+	if (cur_beamform_cap)
+		RTW_INFO("Current VHT Beamforming Setting = %02X\n", cur_beamform_cap);
+#endif /* !RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+	/* B23 B24 B25 Maximum A-MPDU Length Exponent */
 	pvhtpriv->ampdu_len = GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pIE->data);
 
 	pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pIE->data);
-	_rtw_memcpy(vht_mcs, pcap_mcs, 2);
-
 	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-	if ((rf_type == RF_1T1R) || (rf_type == RF_1T2R))
-		vht_mcs[0] |= 0xfc;
-	else if (rf_type == RF_2T2R)
-		vht_mcs[0] |= 0xf0;
-	else if (rf_type == RF_3T3R)
-		vht_mcs[0] |= 0xc0;
-
-	_rtw_memcpy(pvhtpriv->vht_mcs_map, vht_mcs, 2);
-
+	tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
+	rtw_vht_nss_to_mcsmap(tx_nss, pvhtpriv->vht_mcs_map, pcap_mcs);
 	pvhtpriv->vht_highest_rate = rtw_get_vht_highest_rate(pvhtpriv->vht_mcs_map);
 }
 
 void VHT_operation_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 {
-	struct mlme_priv 		*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
 
-	if(pIE==NULL) return;
+	if (pIE == NULL)
+		return;
 
-	if(pvhtpriv->vht_option == _FALSE)	return;
+	if (pvhtpriv->vht_option == _FALSE)
+		return;
 }
 
 void rtw_process_vht_op_mode_notify(_adapter *padapter, u8 *pframe, PVOID sta)
 {
 	struct sta_info		*psta = (struct sta_info *)sta;
-	struct mlme_priv 		*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct registry_priv *regsty = adapter_to_regsty(padapter);
 	u8	target_bw;
 	u8	target_rxss, current_rxss;
 	u8	update_ra = _FALSE;
-	u8	vht_mcs_map[2] = {};
 
-	if(pvhtpriv->vht_option == _FALSE)
+	if (pvhtpriv->vht_option == _FALSE)
 		return;
 
 	target_bw = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(pframe);
-	target_rxss = (GET_VHT_OPERATING_MODE_FIELD_RX_NSS(pframe)+1);
+	target_rxss = (GET_VHT_OPERATING_MODE_FIELD_RX_NSS(pframe) + 1);
 
-	if (target_bw != psta->bw_mode) {
+	if (target_bw != psta->cmn.bw_mode) {
 		if (hal_is_bw_support(padapter, target_bw)
-			&& REGSTY_IS_BW_5G_SUPPORT(regsty, target_bw)
-		) {
+		    && REGSTY_IS_BW_5G_SUPPORT(regsty, target_bw)
+		   ) {
 			update_ra = _TRUE;
-			psta->bw_mode = target_bw;
+			psta->cmn.bw_mode = target_bw;
 		}
 	}
 
 	current_rxss = rtw_vht_mcsmap_to_nss(psta->vhtpriv.vht_mcs_map);
 	if (target_rxss != current_rxss) {
+		u8	vht_mcs_map[2] = {};
+
 		update_ra = _TRUE;
 
 		rtw_vht_nss_to_mcsmap(target_rxss, vht_mcs_map, psta->vhtpriv.vht_mcs_map);
 		_rtw_memcpy(psta->vhtpriv.vht_mcs_map, vht_mcs_map, 2);
-		
-		rtw_hal_update_sta_rate_mask(padapter, psta);
+
+		rtw_hal_update_sta_ra_info(padapter, psta);
 	}
 
-	if (update_ra) {
+	if (update_ra)
 		rtw_dm_ra_mask_wk_cmd(padapter, (u8 *)psta);
-	}
 }
 
 u32	rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel)
@@ -515,20 +664,18 @@ u32	rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel)
 	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
-	//struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	u8	ChnlWidth, center_freq, bw_mode, rf_type = 0;
+	/* struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv; */
+	u8	ChnlWidth, center_freq, bw_mode;
 	u32	len = 0;
 	u8	operation[5];
-	
-	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-	
+
 	_rtw_memset(operation, 0, 5);
 
 	bw_mode = REGSTY_BW_5G(pregistrypriv); /* TODO: control op bw with other info */
 
 	if (hal_chk_bw_cap(padapter, BW_CAP_80M | BW_CAP_160M)
-		&& REGSTY_BW_5G(pregistrypriv) >= CHANNEL_WIDTH_80
-	) {
+	    && REGSTY_BW_5G(pregistrypriv) >= CHANNEL_WIDTH_80
+	   ) {
 		center_freq = rtw_get_center_ch(channel, bw_mode, HAL_PRIME_CHNL_OFFSET_LOWER);
 		ChnlWidth = 1;
 	} else {
@@ -536,40 +683,13 @@ u32	rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel)
 		ChnlWidth = 0;
 	}
 
-	
+
 	SET_VHT_OPERATION_ELE_CHL_WIDTH(operation, ChnlWidth);
-	//center frequency
-	SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(operation, center_freq);//Todo: need to set correct center channel
-	SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(operation,0);
-	
-	if (padapter->registrypriv.rf_config != RF_MAX_TYPE)
-		rf_type = padapter->registrypriv.rf_config;
-	
-	switch (rf_type) {
-	case RF_1T1R:
-	operation[3] = 0xfe;
-	operation[4] = 0xff;
-	break;
-	case RF_1T2R:
-	case RF_2T2R:
-	case RF_2T2R_GREEN:
-	operation[3] = 0xfa;
-	operation[4] = 0xff;
-	break;
-	case RF_2T3R:
-	case RF_2T4R:
-	case RF_3T3R:
-	case RF_3T4R:
-	operation[3] = 0xea;
-	operation[4] = 0xff;
-	break;
-	case RF_4T4R:
-	operation[3] = 0xaa;
-	operation[4] = 0xff;
-	break;
-	default:
-	DBG_871X("%s, %d, unknown rf type\n", __func__, __LINE__);
-	}
+	/* center frequency */
+	SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(operation, center_freq);/* Todo: need to set correct center channel */
+	SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(operation, 0);
+
+	_rtw_memcpy(operation + 3, pvhtpriv->vht_mcs_map, 2);
 
 	rtw_set_ie(pbuf, EID_VHTOperation, 5, operation, &len);
 
@@ -578,26 +698,19 @@ u32	rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel)
 
 u32	rtw_build_vht_op_mode_notify_ie(_adapter *padapter, u8 *pbuf, u8 bw)
 {
-	//struct registry_priv *pregistrypriv = &padapter->registrypriv;
+	/* struct registry_priv *pregistrypriv = &padapter->registrypriv; */
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv	*pvhtpriv = &pmlmepriv->vhtpriv;
 	u32	len = 0;
-	u8	opmode = 0, rf_type = 0;
+	u8	opmode = 0;
 	u8	chnl_width, rx_nss;
 
 	chnl_width = bw;
-
-	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-	if(rf_type == RF_3T3R)
-		rx_nss = 3;
-	else if(rf_type == RF_2T2R)
-		rx_nss = 2;
-	else
-		rx_nss = 1;
+	rx_nss = rtw_vht_mcsmap_to_nss(pvhtpriv->vht_mcs_map);
 
 	SET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(&opmode, chnl_width);
-	SET_VHT_OPERATING_MODE_FIELD_RX_NSS(&opmode, (rx_nss-1));
-	SET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE(&opmode, 0); //Todo
+	SET_VHT_OPERATING_MODE_FIELD_RX_NSS(&opmode, (rx_nss - 1));
+	SET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE(&opmode, 0); /* Todo */
 
 	pvhtpriv->vht_op_mode_notify = opmode;
 
@@ -612,86 +725,118 @@ u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
 	u16	HighestRate;
 	u8	*pcap, *pcap_mcs;
 	u32	len = 0;
+	u32 rx_packet_offset, max_recvbuf_sz;
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv	*pvhtpriv = &pmlmepriv->vhtpriv;
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 	pcap = pvhtpriv->vht_cap;
 	_rtw_memset(pcap, 0, 32);
-	
+
 	/* B0 B1 Maximum MPDU Length */
-	SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 2); 
-	
+	rtw_hal_get_def_var(padapter, HAL_DEF_RX_PACKET_OFFSET, &rx_packet_offset);
+	rtw_hal_get_def_var(padapter, HAL_DEF_MAX_RECVBUF_SZ, &max_recvbuf_sz);
+
+	RTW_DBG("%s, line%d, Available RX buf size = %d bytes\n.", __FUNCTION__, __LINE__, max_recvbuf_sz - rx_packet_offset);
+
+	if ((max_recvbuf_sz - rx_packet_offset) >= 11454) {
+		SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 2);
+		RTW_INFO("%s, line%d, Set MAX MPDU len = 11454 bytes\n.", __FUNCTION__, __LINE__);
+	} else if ((max_recvbuf_sz - rx_packet_offset) >= 7991) {
+		SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 1);
+		RTW_INFO("%s, line%d, Set MAX MPDU len = 7991 bytes\n.", __FUNCTION__, __LINE__);
+	} else if ((max_recvbuf_sz - rx_packet_offset) >= 3895) {
+		SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 0);
+		RTW_INFO("%s, line%d, Set MAX MPDU len = 3895 bytes\n.", __FUNCTION__, __LINE__);
+	} else
+		RTW_ERR("%s, line%d, Error!! Available RX buf size < 3895 bytes\n.", __FUNCTION__, __LINE__);
+
 	/* B2 B3 Supported Channel Width Set */
 	if (hal_chk_bw_cap(padapter, BW_CAP_160M) && REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_160)) {
 		if (hal_chk_bw_cap(padapter, BW_CAP_80_80M) && REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_80_80))
 			SET_VHT_CAPABILITY_ELE_CHL_WIDTH(pcap, 2);
 		else
 			SET_VHT_CAPABILITY_ELE_CHL_WIDTH(pcap, 1);
-	} else {
+	} else
 		SET_VHT_CAPABILITY_ELE_CHL_WIDTH(pcap, 0);
-	}
 
-	// B4 Rx LDPC
-	if(TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_RX))
-	{
+	/* B4 Rx LDPC */
+	if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_RX)) {
 		SET_VHT_CAPABILITY_ELE_RX_LDPC(pcap, 1);
+		RTW_INFO("[VHT] Declare supporting RX LDPC\n");
 	}
 
-	// B5 ShortGI for 80MHz
-	SET_VHT_CAPABILITY_ELE_SHORT_GI80M(pcap, pvhtpriv->sgi_80m? 1 : 0); // We can receive Short GI of 80M
+	/* B5 ShortGI for 80MHz */
+	SET_VHT_CAPABILITY_ELE_SHORT_GI80M(pcap, pvhtpriv->sgi_80m ? 1 : 0); /* We can receive Short GI of 80M */
+	if (pvhtpriv->sgi_80m)
+		RTW_INFO("[VHT] Declare supporting SGI 80MHz\n");
 
-	// B6 ShortGI for 160MHz
-	//SET_VHT_CAPABILITY_ELE_SHORT_GI160M(pcap, pvhtpriv->sgi_80m? 1 : 0);
+	/* B6 ShortGI for 160MHz */
+	/* SET_VHT_CAPABILITY_ELE_SHORT_GI160M(pcap, pvhtpriv->sgi_80m? 1 : 0); */
 
-	// B7 Tx STBC
-	if(TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX))
-	{
+	/* B7 Tx STBC */
+	if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX)) {
 		SET_VHT_CAPABILITY_ELE_TX_STBC(pcap, 1);
+		RTW_INFO("[VHT] Declare supporting TX STBC\n");
 	}
 
-	// B8 B9 B10 Rx STBC
-	if(TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_RX))
-	{
+	/* B8 B9 B10 Rx STBC */
+	if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_RX)) {
 		rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)(&rx_stbc_nss));
-		
+
 		SET_VHT_CAPABILITY_ELE_RX_STBC(pcap, rx_stbc_nss);
+		RTW_INFO("[VHT] Declare supporting RX STBC = %d\n", rx_stbc_nss);
 	}
-
-	// B11 SU Beamformer Capable
-	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {		
+	#ifdef CONFIG_BEAMFORMING
+	/* B11 SU Beamformer Capable */
+	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
 		SET_VHT_CAPABILITY_ELE_SU_BFER(pcap, 1);
-		// B16 17 18 Number of Sounding Dimensions
+		RTW_INFO("[VHT] Declare supporting SU Bfer\n");
+		/* B16 17 18 Number of Sounding Dimensions */
 		rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
 		SET_VHT_CAPABILITY_ELE_SOUNDING_DIMENSIONS(pcap, rf_num);
+		/* B19 MU Beamformer Capable */
+		if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
+			SET_VHT_CAPABILITY_ELE_MU_BFER(pcap, 1);
+			RTW_INFO("[VHT] Declare supporting MU Bfer\n");
+		}
 	}
 
-	// B12 SU Beamformee Capable
+	/* B12 SU Beamformee Capable */
 	if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) {
 		SET_VHT_CAPABILITY_ELE_SU_BFEE(pcap, 1);
-		// B13 14 15 Compressed Steering Number of Beamformer Antennas Supported
+		RTW_INFO("[VHT] Declare supporting SU Bfee\n");
+
 		rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
+
+		/* IOT action suggested by Yu Chen 2017/3/3 */
+#ifdef CONFIG_80211AC_VHT
+		if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) &&
+			!pvhtpriv->ap_is_mu_bfer)
+			rf_num = (rf_num >= 2 ? 2 : rf_num);
+#endif
+		/* B13 14 15 Compressed Steering Number of Beamformer Antennas Supported */
 		SET_VHT_CAPABILITY_ELE_BFER_ANT_SUPP(pcap, rf_num);
+		/* B20 SU Beamformee Capable */
+		if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)) {
+			SET_VHT_CAPABILITY_ELE_MU_BFEE(pcap, 1);
+			RTW_INFO("[VHT] Declare supporting MU Bfee\n");
+		}
 	}
+	#endif/*CONFIG_BEAMFORMING*/
 
-	// B19 MU Beamformer Capable
-	SET_VHT_CAPABILITY_ELE_MU_BFER(pcap, 0);  //HW don't support mu bfee/bfer
-	// B20 MU Beamformee Capable
-	SET_VHT_CAPABILITY_ELE_MU_BFEE(pcap, 0);
-	// B21 VHT TXOP PS
+	/* B21 VHT TXOP PS */
 	SET_VHT_CAPABILITY_ELE_TXOP_PS(pcap, 0);
-	// B22 +HTC-VHT Capable
+	/* B22 +HTC-VHT Capable */
 	SET_VHT_CAPABILITY_ELE_HTC_VHT(pcap, 1);
-	// B23 24 25 Maximum A-MPDU Length Exponent
+	/* B23 24 25 Maximum A-MPDU Length Exponent */
 	if (pregistrypriv->ampdu_factor != 0xFE)
-	{
 		SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pcap, pregistrypriv->ampdu_factor);
-	}
 	else
-	{
 		SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pcap, 7);
-	}
-	// B26 27 VHT Link Adaptation Capable
+	/* B26 27 VHT Link Adaptation Capable */
 	SET_VHT_CAPABILITY_ELE_LINK_ADAPTION(pcap, 0);
 
 	pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pcap);
@@ -703,11 +848,11 @@ u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
 	/* find the largest bw supported by both registry and hal */
 	bw = hal_largest_bw(padapter, REGSTY_BW_5G(pregistrypriv));
 
-	HighestRate = VHT_MCS_DATA_RATE[bw][pvhtpriv->sgi_80m][((pvhtpriv->vht_highest_rate - MGN_VHT1SS_MCS0)&0x3f)];
-	HighestRate = (HighestRate+1) >> 1;
+	HighestRate = VHT_MCS_DATA_RATE[bw][pvhtpriv->sgi_80m][((pvhtpriv->vht_highest_rate - MGN_VHT1SS_MCS0) & 0x3f)];
+	HighestRate = (HighestRate + 1) >> 1;
 
-	SET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(pcap, HighestRate); //indicate we support highest rx rate is 600Mbps.
-	SET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(pcap, HighestRate); //indicate we support highest tx rate is 600Mbps.
+	SET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(pcap, HighestRate); /* indicate we support highest rx rate is 600Mbps. */
+	SET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(pcap, HighestRate); /* indicate we support highest tx rate is 600Mbps. */
 
 	pbuf = rtw_set_ie(pbuf, EID_VHTCapability, 12, pcap, &len);
 
@@ -716,63 +861,103 @@ u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
 
 u32 rtw_restructure_vht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len)
 {
-	u32	ielen=0, out_len=0;
-	u8	cap_len=0, notify_len=0, notify_bw=0, operation_bw=0, supported_chnl_width=0;
-	u8	*p, *pframe;
+	u32	ielen;
+	u8 max_bw;
+	u8 oper_ch, oper_bw = CHANNEL_WIDTH_20, oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	u8 *out_vht_op_ie, *ht_op_ie, *vht_cap_ie, *vht_op_ie;
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv	*pvhtpriv = &pmlmepriv->vhtpriv;
 
 	rtw_vht_use_default_setting(padapter);
 
-	p = rtw_get_ie(in_ie+12, EID_VHTCapability, &ielen, in_len-12);
-	if (p && ielen>0) {
-		supported_chnl_width = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p+2);
-		
-		// VHT Capabilities element
-		cap_len = rtw_build_vht_cap_ie(padapter, out_ie+*pout_len);
-		*pout_len += cap_len;
-
-		// Get HT BW
-		p = rtw_get_ie(in_ie+12, _HT_EXTRA_INFO_IE_, &ielen, in_len-12);
-		if (p && ielen>0) {
-			struct HT_info_element *pht_info = (struct HT_info_element *)(p+2);
-			if (pht_info->infos[0] & BIT(2))
-				operation_bw = CHANNEL_WIDTH_40;
-			else
-				operation_bw = CHANNEL_WIDTH_20;
-		}
+	ht_op_ie = rtw_get_ie(in_ie + 12, WLAN_EID_HT_OPERATION, &ielen, in_len - 12);
+	if (!ht_op_ie || ielen != HT_OP_IE_LEN)
+		goto exit;
+	vht_cap_ie = rtw_get_ie(in_ie + 12, EID_VHTCapability, &ielen, in_len - 12);
+	if (!vht_cap_ie || ielen != VHT_CAP_IE_LEN)
+		goto exit;
+	vht_op_ie = rtw_get_ie(in_ie + 12, EID_VHTOperation, &ielen, in_len - 12);
+	if (!vht_op_ie || ielen != VHT_OP_IE_LEN)
+		goto exit;
+
+	/* VHT Capabilities element */
+	*pout_len += rtw_build_vht_cap_ie(padapter, out_ie + *pout_len);
 
-		// VHT Operation element
-		p = rtw_get_ie(in_ie+12, EID_VHTOperation, &ielen, in_len-12);
-		if (p && ielen>0) {
-			out_len = *pout_len;
-			if (GET_VHT_OPERATION_ELE_CHL_WIDTH(p+2) >= 1) {
-				if (supported_chnl_width == 2)
-					operation_bw = CHANNEL_WIDTH_80_80;
-				else if (supported_chnl_width == 1)
-					operation_bw = CHANNEL_WIDTH_160;
-				else
-					operation_bw = CHANNEL_WIDTH_80;
+
+	/* VHT Operation element */
+	out_vht_op_ie = out_ie + *pout_len;
+	rtw_set_ie(out_vht_op_ie, EID_VHTOperation, VHT_OP_IE_LEN, vht_op_ie + 2 , pout_len);
+
+	/* get primary channel from HT_OP_IE */
+	oper_ch = GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2);
+
+	/* find the largest bw supported by both registry and hal */
+	max_bw = hal_largest_bw(padapter, REGSTY_BW_5G(pregistrypriv));
+
+	if (max_bw >= CHANNEL_WIDTH_40) {
+		/* get bw offset form HT_OP_IE */
+		if (GET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2)) {
+			switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2)) {
+			case SCA:
+				oper_bw = CHANNEL_WIDTH_40;
+				oper_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+				break;
+			case SCB:
+				oper_bw = CHANNEL_WIDTH_40;
+				oper_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+				break;
 			}
-			pframe = rtw_set_ie(out_ie+out_len, EID_VHTOperation, ielen, p+2 , pout_len);
 		}
 
-		/* find the largest bw supported by both registry and hal */
-		notify_bw = hal_largest_bw(padapter, REGSTY_BW_5G(pregistrypriv));
+		if (oper_bw == CHANNEL_WIDTH_40) {
+			switch (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2)) {
+			case 1: /* 80MHz */
+			case 2: /* 160MHz */
+			case 3: /* 80+80 */
+				oper_bw = CHANNEL_WIDTH_80; /* only support up to 80MHz for now */
+				break;
+			}
 
-		if (notify_bw > operation_bw)
-			notify_bw = operation_bw;
+			oper_bw = rtw_min(oper_bw, max_bw);
 
-		// Operating Mode Notification element
-		notify_len = rtw_build_vht_op_mode_notify_ie(padapter, out_ie+*pout_len, notify_bw);
-		*pout_len += notify_len;
+			/* try downgrage bw to fit in channel plan setting */
+			while (!rtw_chset_is_chbw_valid(adapter_to_chset(padapter), oper_ch, oper_bw, oper_offset)) {
+				oper_bw--;
+				if (oper_bw == CHANNEL_WIDTH_20) {
+					oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+					break;
+				}
+			}
+		}
+	}
+
+	rtw_warn_on(!rtw_chset_is_chbw_valid(adapter_to_chset(padapter), oper_ch, oper_bw, oper_offset));
 
-		pvhtpriv->vht_option = _TRUE;
+	/* update VHT_OP_IE */
+	if (oper_bw < CHANNEL_WIDTH_80) {
+		SET_VHT_OPERATION_ELE_CHL_WIDTH(out_vht_op_ie + 2, 0);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(out_vht_op_ie + 2, 0);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(out_vht_op_ie + 2, 0);
+	} else if (oper_bw == CHANNEL_WIDTH_80) {
+		u8 cch = rtw_get_center_ch(oper_ch, oper_bw, oper_offset);
+
+		SET_VHT_OPERATION_ELE_CHL_WIDTH(out_vht_op_ie + 2, 1);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(out_vht_op_ie + 2, cch);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(out_vht_op_ie + 2, 0);
+	} else {
+		RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(padapter), oper_bw);
+		rtw_warn_on(1);
 	}
-	
-	return (pvhtpriv->vht_option);
-	
+
+	/* Operating Mode Notification element */
+	*pout_len += rtw_build_vht_op_mode_notify_ie(padapter, out_ie + *pout_len, oper_bw);
+
+	pvhtpriv->vht_option = _TRUE;
+
+exit:
+	return pvhtpriv->vht_option;
+
 }
 
 void VHTOnAssocRsp(_adapter *padapter)
@@ -782,8 +967,8 @@ void VHTOnAssocRsp(_adapter *padapter)
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	u8	ht_AMPDU_len;
-	
-	DBG_871X("%s\n", __FUNCTION__);
+
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	if (!pmlmeinfo->HT_enable)
 		return;
@@ -793,11 +978,78 @@ void VHTOnAssocRsp(_adapter *padapter)
 
 	ht_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;
 
-	if(pvhtpriv->ampdu_len > ht_AMPDU_len)
+	if (pvhtpriv->ampdu_len > ht_AMPDU_len)
 		rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&pvhtpriv->ampdu_len));
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MAX_TIME, (u8 *)(&pvhtpriv->vht_highest_rate));
 }
 
-#endif //CONFIG_80211AC_VHT
+void rtw_vht_ies_attach(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u8 cap_len, operation_len;
+	uint len = 0;
+	sint ie_len = 0;
+	u8 *p = NULL;
+
+	p = rtw_get_ie(pnetwork->IEs + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len,
+			(pnetwork->IELength - _BEACON_IE_OFFSET_));
+	if (p && ie_len > 0)
+		return;
+
+	rtw_vht_use_default_setting(padapter);
+
+	/* VHT Operation mode notifiy bit in Extended IE (127) */
+	SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(pmlmepriv->ext_capab_ie_data, 1);
+	pmlmepriv->ext_capab_ie_len = 10;
+	rtw_set_ie(pnetwork->IEs + pnetwork->IELength, EID_EXTCapability, 8, pmlmepriv->ext_capab_ie_data, &len);
+	pnetwork->IELength += pmlmepriv->ext_capab_ie_len;
+
+	/* VHT Capabilities element */
+	cap_len = rtw_build_vht_cap_ie(padapter, pnetwork->IEs + pnetwork->IELength);
+	pnetwork->IELength += cap_len;
+
+	/* VHT Operation element */
+	operation_len = rtw_build_vht_operation_ie(padapter, pnetwork->IEs + pnetwork->IELength,
+										pnetwork->Configuration.DSConfig);
+	pnetwork->IELength += operation_len;
+
+	rtw_check_for_vht20(padapter, pnetwork->IEs + _BEACON_IE_OFFSET_, pnetwork->IELength - _BEACON_IE_OFFSET_);
+
+	pmlmepriv->vhtpriv.vht_option = _TRUE;
+}
+
+void rtw_vht_ies_detach(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	rtw_remove_bcn_ie(padapter, pnetwork, EID_EXTCapability);
+	rtw_remove_bcn_ie(padapter, pnetwork, EID_VHTCapability);
+	rtw_remove_bcn_ie(padapter, pnetwork, EID_VHTOperation);
+
+	pmlmepriv->vhtpriv.vht_option = _FALSE;
+}
 
+void rtw_check_for_vht20(_adapter *adapter, u8 *ies, int ies_len)
+{
+	u8 ht_ch, ht_bw, ht_offset;
+	u8 vht_ch, vht_bw, vht_offset;
+
+	rtw_ies_get_chbw(ies, ies_len, &ht_ch, &ht_bw, &ht_offset, 1, 0);
+	rtw_ies_get_chbw(ies, ies_len, &vht_ch, &vht_bw, &vht_offset, 1, 1);
+
+	if (ht_bw == CHANNEL_WIDTH_20 && vht_bw >= CHANNEL_WIDTH_80) {
+		u8 *vht_op_ie;
+		int vht_op_ielen;
+
+		RTW_INFO(FUNC_ADPT_FMT" vht80 is not allowed without ht40\n", FUNC_ADPT_ARG(adapter));
+		vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
+		if (vht_op_ie && vht_op_ielen) {
+			RTW_INFO(FUNC_ADPT_FMT" switch to vht20\n", FUNC_ADPT_ARG(adapter));
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
+		}
+	}
+}
+#endif /* CONFIG_80211AC_VHT */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi.c
index a7d574cc46d1..67bbdf713ca7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi.c
@@ -1,1327 +1,1313 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifdef CONFIG_WAPI_SUPPORT
-
-#include <linux/unistd.h>
-#include <linux/etherdevice.h>
-#include <drv_types.h>
-#include <rtw_wapi.h>
-
-
-u32 wapi_debug_component =
-//				WAPI_INIT	|
-//				WAPI_API    	|
-//				WAPI_TX    	|
-//				WAPI_RX    	|
-				WAPI_ERR ; //always open err flags on
-
-void WapiFreeAllStaInfo(_adapter *padapter)
-{
-	PRT_WAPI_T				pWapiInfo;
-	PRT_WAPI_STA_INFO		pWapiStaInfo;
-	PRT_WAPI_BKID			pWapiBkid;
-
-	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
-	pWapiInfo = &padapter->wapiInfo;
-
-	//Pust to Idle List
-	rtw_wapi_return_all_sta_info(padapter);
-
-	//Sta Info List
-	while(!list_empty(&(pWapiInfo->wapiSTAIdleList)))
-	{
-		pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAIdleList.next, RT_WAPI_STA_INFO, list);
-		list_del_init(&pWapiStaInfo->list);
-	}
-
-	//BKID List
-	while(!list_empty(&(pWapiInfo->wapiBKIDIdleList)))
-	{
-		pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDIdleList.next, RT_WAPI_BKID, list);
-		list_del_init(&pWapiBkid->list);
-	}
-	WAPI_TRACE(WAPI_INIT, "<=========== %s\n", __FUNCTION__);
-	return;
-}
-
-void WapiSetIE(_adapter *padapter)
-{
-	PRT_WAPI_T		pWapiInfo = &(padapter->wapiInfo);
-	//PRT_WAPI_BKID	pWapiBkid;
-	u16		protocolVer = 1;
-	u16		akmCnt = 1;
-	u16		suiteCnt = 1;
-	u16		capability = 0;
-	u8		OUI[3];
-
-	OUI[0] = 0x00;
-	OUI[1] = 0x14;
-	OUI[2] = 0x72;
-
-	pWapiInfo->wapiIELength = 0;
-//protocol version
-	memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength, &protocolVer, 2);
-	pWapiInfo->wapiIELength +=2;
-//akm
-	memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength, &akmCnt, 2);
-	pWapiInfo->wapiIELength +=2;
-
-	if(pWapiInfo->bWapiPSK){
-		memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength,OUI, 3);
-		pWapiInfo->wapiIELength +=3;
-		pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x2;
-		pWapiInfo->wapiIELength +=1;
-	}else{
-		memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength,OUI, 3);
-		pWapiInfo->wapiIELength +=3;
-		pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
-		pWapiInfo->wapiIELength +=1;
-	}
-
-//usk
-	memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength, &suiteCnt, 2);
-	pWapiInfo->wapiIELength +=2;
-	memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength,OUI, 3);
-	pWapiInfo->wapiIELength +=3;
-	pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
-	pWapiInfo->wapiIELength +=1;
-
-//msk
-	memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength,OUI, 3);
-	pWapiInfo->wapiIELength +=3;
-	pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
-	pWapiInfo->wapiIELength +=1;
-
-//Capbility
-	memcpy(pWapiInfo->wapiIE+pWapiInfo->wapiIELength, &capability, 2);
-	pWapiInfo->wapiIELength +=2;
-}
-
-
-/*  PN1 > PN2, return 1,
- *  else return 0.
- */
-u32 WapiComparePN(u8 *PN1, u8 *PN2)
-{
-	char i;
-
-	if ((NULL == PN1) || (NULL == PN2))
-		return 1;
-
-	// overflow case
-	if ((PN2[15] - PN1[15]) & 0x80)
-		return 1;
-
-	for (i=16; i>0; i--)
-	{
-		if(PN1[i-1] == PN2[i-1])
-		    	continue;
-		else if(PN1[i-1] > PN2[i-1])
-			return 1;
-		else
-			return 0;
-	}
-
-	return 0;
-}
-
-u8
-WapiGetEntryForCamWrite(_adapter *padapter,u8 *pMacAddr,u8 KID,BOOLEAN IsMsk)
-{
-	PRT_WAPI_T		pWapiInfo=NULL;
-	//PRT_WAPI_CAM_ENTRY	pEntry=NULL;
-	u8 i=0;
-	u8 ret = 0xff;
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	pWapiInfo =  &padapter->wapiInfo;
-
-	//exist?
-	for(i=0;i<WAPI_CAM_ENTRY_NUM;i++)
-	{
-		if(pWapiInfo->wapiCamEntry[i].IsUsed
-			&& (_rtw_memcmp(pMacAddr, pWapiInfo->wapiCamEntry[i].PeerMacAddr, ETH_ALEN) == _TRUE)
-			&& pWapiInfo->wapiCamEntry[i].keyidx == KID
-			&& pWapiInfo->wapiCamEntry[i].type == IsMsk)
-		{
-			ret = pWapiInfo->wapiCamEntry[i].entry_idx; //cover it
-			break;
-		}
-	}
-
-	if(i == WAPI_CAM_ENTRY_NUM) //not found
-	{
-		for(i=0;i<WAPI_CAM_ENTRY_NUM;i++)
-		{
-			if(pWapiInfo->wapiCamEntry[i].IsUsed == 0)
-			{
-				pWapiInfo->wapiCamEntry[i].IsUsed = 1;
-				pWapiInfo->wapiCamEntry[i].type = IsMsk;
-				pWapiInfo->wapiCamEntry[i].keyidx = KID;
-				_rtw_memcpy(pWapiInfo->wapiCamEntry[i].PeerMacAddr, pMacAddr,ETH_ALEN);
-				ret = pWapiInfo->wapiCamEntry[i].entry_idx;
-				break;
-			}
-		}
-	}
-
-	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
-	return ret;
-
-/*
-	if(RTIsListEmpty(&pWapiInfo->wapiCamIdleList)){
-		RT_TRACE(COMP_SEC,DBG_LOUD,("No Entry for wapi!!!\n"));
-		return 0;
-	}
-
-	pEntry = (PRT_WAPI_CAM_ENTRY)RTRemoveHeadList(&pWapiInfo->wapiCamIdleList);
-	RTInsertTailList(&pWapiInfo->wapiCamUsedList, &pEntry->list);
-
-	RT_TRACE(COMP_SEC,DBG_LOUD,("<====WapiGetCamEntry(),Get Entry Idx:%d.but we just return 4 for test\n",pEntry->entry_idx));
-
-	return pEntry->entry_idx;*/
-}
-
-u8 WapiGetEntryForCamClear(_adapter *padapter,u8 *pPeerMac,u8 keyid,u8 IsMsk)
-{
-	PRT_WAPI_T		pWapiInfo=NULL;
-	u8		i=0;
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	pWapiInfo =  &padapter->wapiInfo;
-
-	for(i=0;i<WAPI_CAM_ENTRY_NUM;i++)
-	{
-		if(pWapiInfo->wapiCamEntry[i].IsUsed
-			&& (_rtw_memcmp(pPeerMac, pWapiInfo->wapiCamEntry[i].PeerMacAddr, ETH_ALEN) == _TRUE)
-			&& pWapiInfo->wapiCamEntry[i].keyidx == keyid
-			&& pWapiInfo->wapiCamEntry[i].type == IsMsk)
-		{
-				pWapiInfo->wapiCamEntry[i].IsUsed = 0;
-				pWapiInfo->wapiCamEntry[i].keyidx = 2;
-				_rtw_memset(pWapiInfo->wapiCamEntry[i].PeerMacAddr,0,ETH_ALEN);
-
-				WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
-				return pWapiInfo->wapiCamEntry[i].entry_idx;
-		}
-	}
-
-	WAPI_TRACE(WAPI_API,"<====WapiGetReturnCamEntry(), No this cam entry.\n");
-	return 0xff;
-/*
-	if(RTIsListEmpty(&pWapiInfo->wapiCamUsedList)){
-		RT_TRACE(COMP_SEC,DBG_LOUD,("No Entry for wapi!!!\n"));
-		return FALSE;
-	}
-
-	pList = &pWapiInfo->wapiCamUsedList;
-	while(pList->Flink != &pWapiInfo->wapiCamUsedList)
-	{
-		pEntry = (PRT_WAPI_CAM_ENTRY)pList->Flink;
-		if(PlatformCompareMemory(pPeerMac,pEntry->PeerMacAddr, ETHER_ADDRLEN)== 0
-			&& keyid == pEntry->keyidx)
-		{
-			RTRemoveEntryList(pList);
-			RTInsertHeadList(&pWapiInfo->wapiCamIdleList, pList);
-			return pEntry->entry_idx;
-		}
-		pList = pList->Flink;
-	}
-
-	return 0;
-*/
-}
-
-void
-WapiResetAllCamEntry(_adapter *padapter)
-{
-	PRT_WAPI_T		pWapiInfo;
-	int				i;
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	pWapiInfo =  &padapter->wapiInfo;
-
-	for (i=0;i<WAPI_CAM_ENTRY_NUM;i++)
-	{
-		_rtw_memset(pWapiInfo->wapiCamEntry[i].PeerMacAddr, 0, ETH_ALEN);
-		pWapiInfo->wapiCamEntry[i].IsUsed = 0;
-	 	pWapiInfo->wapiCamEntry[i].keyidx = 2; //invalid
-	 	pWapiInfo->wapiCamEntry[i].entry_idx = 4+i*2;
- 	}
-
-	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
-
-	return;
-}
-
-u8 WapiWriteOneCamEntry(
-	_adapter 	*padapter,
-	u8 			*pMacAddr,
-	u8 			KeyId,
-	u8			EntryId,
-	u8 			EncAlg,
-	u8 			bGroupKey,
-	u8 			*pKey
-)
-{
-	u8 retVal = 0;
-	u16 usConfig = 0;
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	if(EntryId >= 32)
-	{
-		WAPI_TRACE(WAPI_ERR, "<=== CamAddOneEntry(): ulKeyId exceed!\n");
-		return retVal;
-	}
-
-	usConfig=usConfig|(0x01<<15)|((u16)(EncAlg)<<2)|(KeyId);
-
-	if(EncAlg == _SMS4_ )
-	{
-		if(bGroupKey == 1)
-			usConfig |= (0x01<<6);
-		if((EntryId % 2)==1)  // ==0 sec key; == 1mic key
-			usConfig |= (0x01<<5);
-	}
-
-	write_cam(padapter, EntryId, usConfig, pMacAddr, pKey);
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-    	return 1;
-}
-
-void rtw_wapi_init(_adapter *padapter)
-{
-	PRT_WAPI_T		pWapiInfo;
-	int				i;
-
-	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
-	RT_ASSERT_RET(padapter);
-
-	if (!padapter->WapiSupport)
-	{
-		WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
-		return;
-	}
-
-	pWapiInfo =  &padapter->wapiInfo;
-	pWapiInfo->bWapiEnable = false;
-
-	//Init BKID List
-	INIT_LIST_HEAD(&pWapiInfo->wapiBKIDIdleList);
-	INIT_LIST_HEAD(&pWapiInfo->wapiBKIDStoreList);
-	for(i=0;i<WAPI_MAX_BKID_NUM;i++)
-	{
-		list_add_tail(&pWapiInfo->wapiBKID[i].list, &pWapiInfo->wapiBKIDIdleList);
-	}
-
-	//Init STA List
-	INIT_LIST_HEAD(&pWapiInfo->wapiSTAIdleList);
-	INIT_LIST_HEAD(&pWapiInfo->wapiSTAUsedList);
-	for(i=0;i<WAPI_MAX_STAINFO_NUM;i++)
-	{
-		list_add_tail(&pWapiInfo->wapiSta[i].list, &pWapiInfo->wapiSTAIdleList);
-	}
-
-	 for (i=0;i<WAPI_CAM_ENTRY_NUM;i++)
-	 {
-		pWapiInfo->wapiCamEntry[i].IsUsed = 0;
-	 	pWapiInfo->wapiCamEntry[i].keyidx = 2; //invalid
-	 	pWapiInfo->wapiCamEntry[i].entry_idx = 4+i*2;
- 	}
-
-	WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
-}
-
-void rtw_wapi_free(_adapter *padapter)
-{
-	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
-	RT_ASSERT_RET(padapter);
-
-	if (!padapter->WapiSupport)
-	{
-		WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
-		return;
-	}
-
-	WapiFreeAllStaInfo(padapter);
-
-	WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
-}
-
-void rtw_wapi_disable_tx(_adapter *padapter)
-{
-	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
-	RT_ASSERT_RET(padapter);
-
-	if (!padapter->WapiSupport)
-	{
-		WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
-		return;
-	}
-
-	padapter->wapiInfo.wapiTxMsk.bTxEnable = false;
-	padapter->wapiInfo.wapiTxMsk.bSet = false;
-
-	WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
-}
-
-u8 rtw_wapi_is_wai_packet(_adapter* padapter,u8 *pkt_data)
-{
-	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
-	struct security_priv   *psecuritypriv = &padapter->securitypriv;
-	PRT_WAPI_STA_INFO pWapiSta = NULL;
-	u8 WaiPkt = 0, *pTaddr, bFind = false;
-	u8 Offset_TypeWAI = 0 ;	// (mac header len + llc length)
-	
-	WAPI_TRACE(WAPI_TX|WAPI_RX, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return 0;
-	}
-
-	 Offset_TypeWAI = 24 + 6 ;
-
-	//YJ,add,091103. Data frame may also have skb->data[30]=0x88 and skb->data[31]=0xb4.
-	if ((pkt_data[1]&0x40) !=0)
-	{
-		//DBG_871X("data is privacy \n");
-	    	return 0;
-	}
-	
-	pTaddr = GetAddr2Ptr(pkt_data);
-	if(list_empty(&pWapiInfo->wapiSTAUsedList)){
-		bFind = false;
-	}else{
-		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list){
-			if (_rtw_memcmp(pTaddr, pWapiSta->PeerMacAddr, 6) == _TRUE) {
-				bFind = true;
-				break;
-			}
-		}
-	}
-
-	WAPI_TRACE(WAPI_TX|WAPI_RX, "%s: bFind=%d pTaddr="MAC_FMT"\n", __FUNCTION__, bFind, MAC_ARG(pTaddr));
-
-	if (pkt_data[0] == WIFI_QOS_DATA_TYPE)
-	{
-		Offset_TypeWAI += 2;
-	}
-
-	// 88b4?
-	if( (pkt_data[Offset_TypeWAI]==0x88) && (pkt_data[Offset_TypeWAI+1]==0xb4) ){
-		WaiPkt = pkt_data[Offset_TypeWAI+5];
-
-		psecuritypriv->hw_decrypted = _TRUE;
-	}else{
-		WAPI_TRACE(WAPI_TX|WAPI_RX, "%s(): non wai packet\n",__FUNCTION__);
-	}
-
-	WAPI_TRACE(WAPI_TX|WAPI_RX, "%s(): Recvd WAI frame. IsWAIPkt(%d)\n",__FUNCTION__, WaiPkt);
-
-	return	WaiPkt;
-}
-
-
-void rtw_wapi_update_info(_adapter *padapter, union recv_frame *precv_frame)
-{
-	PRT_WAPI_T     pWapiInfo = &(padapter->wapiInfo);
-	struct recv_frame_hdr *precv_hdr;
-	u8 	*ptr;
-	u8 	*pTA;
-	u8 	*pRecvPN;
-
-
-	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return;
-	}
-
-	precv_hdr = &precv_frame->u.hdr;
-	ptr = precv_hdr->rx_data;
-
-	if (precv_hdr->attrib.qos == 1)
-	{
-		precv_hdr->UserPriority = GetTid(ptr);
-	}
-	else
-	{
-		precv_hdr->UserPriority = 0;
-	}
-
-	pTA = GetAddr2Ptr(ptr);
-	_rtw_memcpy((u8 *)precv_hdr->WapiSrcAddr, pTA, 6);
-	pRecvPN = ptr + precv_hdr->attrib.hdrlen + 2;
-	_rtw_memcpy((u8 *)precv_hdr->WapiTempPN, pRecvPN, 16);
-
-	WAPI_TRACE(WAPI_RX, "<========== %s\n", __FUNCTION__);
-}
-
-/****************************************************************************
-TRUE-----------------Drop
-FALSE---------------- handle
-add to support WAPI to N-mode
-*****************************************************************************/
-u8 rtw_wapi_check_for_drop(
-	_adapter *padapter,
-	union recv_frame *precv_frame
-)
-{
-	PRT_WAPI_T     pWapiInfo = &(padapter->wapiInfo);
-	u8			*pLastRecvPN = NULL;
-	u8			bFind = false;
-	PRT_WAPI_STA_INFO	pWapiSta = NULL;
-	u8 			bDrop = false;
-	struct recv_frame_hdr *precv_hdr = &precv_frame->u.hdr;
-	u8					WapiAEPNInitialValueSrc[16] = {0x37,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-	u8 					WapiAEMultiCastPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-	u8 					*ptr = precv_frame->u.hdr.rx_data;
-	int					i;
-
-	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return false;
-	}
-
-	if(precv_hdr->bIsWaiPacket !=0)
-	{
-		if(precv_hdr->bIsWaiPacket== 0x8)
-		{
-
-			DBG_871X("rtw_wapi_check_for_drop: dump packet \n");
-			for(i=0;i<50;i++)
-			{
-				DBG_871X("%02X  ",ptr[i]);
-				if((i+1) %8 ==0)
-					DBG_871X("\n");
-			}
-			DBG_871X("\n rtw_wapi_check_for_drop: dump packet \n");
-
-			for(i=0;i<16;i++)
-			{
-				if(ptr[i+27] !=0)
-					break;
-			}
-
-			if(i== 16)
-			{
-				WAPI_TRACE(WAPI_RX,"rtw_wapi_check_for_drop: drop with zero BKID \n");
-				return true;
-			}
-			else
-			{
-				return false;
-			}
-		}
-			else
-				return false;
-	}
-
-	if(list_empty(&pWapiInfo->wapiSTAUsedList)){
-		bFind = false;
-	}else{
-		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-			if (_rtw_memcmp(precv_hdr->WapiSrcAddr, pWapiSta->PeerMacAddr, ETH_ALEN) == _TRUE) {
-				bFind = true;
-				break;
-			}
-		}
-	}
-	WAPI_TRACE(WAPI_RX, "%s: bFind=%d prxb->WapiSrcAddr="MAC_FMT"\n", __FUNCTION__, bFind, MAC_ARG(precv_hdr->WapiSrcAddr));
-
-	if(bFind)
-	{
-		if(IS_MCAST(precv_hdr->attrib.ra))
-		{
-			WAPI_TRACE(WAPI_RX,"rtw_wapi_check_for_drop: multicast case \n");
-			pLastRecvPN = pWapiSta->lastRxMulticastPN;
-		}
-		else
-		{
-			WAPI_TRACE(WAPI_RX,"rtw_wapi_check_for_drop: unicast case \n");
-			switch(precv_hdr->UserPriority)
-			{
-				case 0:
-				case 3:
-					pLastRecvPN = pWapiSta->lastRxUnicastPNBEQueue;
-					break;
-				case 1:
-				case 2:
-					pLastRecvPN = pWapiSta->lastRxUnicastPNBKQueue;
-					break;
-				case 4:
-				case 5:
-					pLastRecvPN = pWapiSta->lastRxUnicastPNVIQueue;
-					break;
-				case 6:
-				case 7:
-					pLastRecvPN = pWapiSta->lastRxUnicastPNVOQueue;
-					break;
-				default:
-					WAPI_TRACE(WAPI_ERR,"%s: Unknown TID \n",__FUNCTION__);
-					break;
-			}
-		}
-
-		if(!WapiComparePN(precv_hdr->WapiTempPN,pLastRecvPN))
-		{
-			WAPI_TRACE(WAPI_RX,"%s: Equal PN!!\n",__FUNCTION__);
-			if(IS_MCAST(precv_hdr->attrib.ra))
-				_rtw_memcpy(pLastRecvPN,WapiAEMultiCastPNInitialValueSrc,16);
-			else
-				_rtw_memcpy(pLastRecvPN,WapiAEPNInitialValueSrc,16);
-			bDrop = true;
-		}
-		else
-		{
-			_rtw_memcpy(pLastRecvPN,precv_hdr->WapiTempPN,16);
-		}
-	}
-
-	WAPI_TRACE(WAPI_RX, "<========== %s\n", __FUNCTION__);
-	return bDrop;
-}
-
-void rtw_build_probe_resp_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
-{
-	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
-	u8 WapiIELength = 0;
-
-	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport)  || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
-		return;
-	}
-
-	WapiSetIE(padapter);
-	WapiIELength = pWapiInfo->wapiIELength;
-	pframe[0] = _WAPI_IE_;
-	pframe[1] = WapiIELength;
-	_rtw_memcpy(pframe+2, pWapiInfo->wapiIE, WapiIELength);
-	pframe += WapiIELength+2;
-	pattrib->pktlen += WapiIELength+2;
-
-	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
-}
-
-void rtw_build_beacon_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
-{
-	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
-	u8 WapiIELength = 0;
-	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport)  || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
-		return;
-	}
-
-	WapiSetIE(padapter);
-	WapiIELength = pWapiInfo->wapiIELength;
-	pframe[0] = _WAPI_IE_;
-	pframe[1] = WapiIELength;
-	_rtw_memcpy(pframe+2, pWapiInfo->wapiIE, WapiIELength);
-	pframe += WapiIELength+2;
-	pattrib->pktlen += WapiIELength+2;
-
-	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
-}
-
-void rtw_build_assoc_req_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
-{
-	PRT_WAPI_BKID		pWapiBKID;
-	u16					bkidNum;
-	PRT_WAPI_T			pWapiInfo = &(padapter->wapiInfo);
-	u8					WapiIELength = 0;
-
-	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
-		return;
-	}
-
-	WapiSetIE(padapter);
-	WapiIELength = pWapiInfo->wapiIELength;
-	bkidNum = 0;
-	if(!list_empty(&(pWapiInfo->wapiBKIDStoreList))){
-		list_for_each_entry(pWapiBKID, &pWapiInfo->wapiBKIDStoreList, list) {
-			bkidNum ++;
-			_rtw_memcpy(pWapiInfo->wapiIE+WapiIELength+2, pWapiBKID->bkid,16);
-			WapiIELength += 16;
-		}
-	}
-	_rtw_memcpy(pWapiInfo->wapiIE+WapiIELength, &bkidNum, 2);
-	WapiIELength += 2;
-
-	 pframe[0] = _WAPI_IE_;
-	 pframe[1] = WapiIELength;
-	_rtw_memcpy(pframe+2, pWapiInfo->wapiIE, WapiIELength);
-	pframe += WapiIELength+2;
-	pattrib->pktlen += WapiIELength+2;
-	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
-}
-
-void rtw_wapi_on_assoc_ok(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
-{
-	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
-	PRT_WAPI_STA_INFO pWapiSta;
-	u8 WapiAEPNInitialValueSrc[16] = {0x37,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-	//u8 WapiASUEPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-	u8 WapiAEMultiCastPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-
-	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return;
-	}
-
-	pWapiSta =(PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAIdleList.next, RT_WAPI_STA_INFO, list);
-	list_del_init(&pWapiSta->list);
-	list_add_tail(&pWapiSta->list, &pWapiInfo->wapiSTAUsedList);
-	_rtw_memcpy(pWapiSta->PeerMacAddr,padapter->mlmeextpriv.mlmext_info.network.MacAddress,6);
-	_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
-	_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
-
-	//For chenk PN error with Qos Data after s3: add by ylb 20111114
-	_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue,WapiAEPNInitialValueSrc,16);
-	_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue,WapiAEPNInitialValueSrc,16);
-	_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue,WapiAEPNInitialValueSrc,16);
-	_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue,WapiAEPNInitialValueSrc,16);
-
-	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
-}
-
-
-void rtw_wapi_return_one_sta_info(_adapter *padapter, u8 *MacAddr)
-{
-	PRT_WAPI_T				pWapiInfo;
-	PRT_WAPI_STA_INFO		pWapiStaInfo = NULL;
-	PRT_WAPI_BKID			pWapiBkid = NULL;
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
-
-	pWapiInfo = &padapter->wapiInfo;
-
-	WAPI_TRACE(WAPI_API, "==========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return;
-	}
-
-       if(check_fwstate(pmlmepriv, WIFI_STATION_STATE))
-       {
-             while(!list_empty(&(pWapiInfo->wapiBKIDStoreList)))
-                 {
-                        pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDStoreList.next, RT_WAPI_BKID, list);
-                           list_del_init(&pWapiBkid->list);
-                           _rtw_memset(pWapiBkid->bkid,0,16);
-                        list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDIdleList);
-                 }
-        }
-
-
-	WAPI_TRACE(WAPI_API, " %s: after clear bkid \n", __FUNCTION__);
-
-
-	//Remove STA info
-	if(list_empty(&(pWapiInfo->wapiSTAUsedList))){
-		WAPI_TRACE(WAPI_API, " %s: wapiSTAUsedList is null \n", __FUNCTION__);
-		return;
-	}else{
-
-		WAPI_TRACE(WAPI_API, " %s: wapiSTAUsedList is not null \n", __FUNCTION__);
-#if 0
-		pWapiStaInfo=(PRT_WAPI_STA_INFO)list_entry((pWapiInfo->wapiSTAUsedList.next),RT_WAPI_STA_INFO,list);
-
-		list_for_each_entry(pWapiStaInfo, &(pWapiInfo->wapiSTAUsedList), list) {
-
-			DBG_871X("MAC Addr %02x-%02x-%02x-%02x-%02x-%02x \n",MacAddr[0],MacAddr[1],MacAddr[2],MacAddr[3],MacAddr[4],MacAddr[5]);
-
-
-			DBG_871X("peer Addr %02x-%02x-%02x-%02x-%02x-%02x \n",pWapiStaInfo->PeerMacAddr[0],pWapiStaInfo->PeerMacAddr[1],pWapiStaInfo->PeerMacAddr[2],pWapiStaInfo->PeerMacAddr[3],pWapiStaInfo->PeerMacAddr[4],pWapiStaInfo->PeerMacAddr[5]);
-
-			if(pWapiStaInfo == NULL)
-			{
-				WAPI_TRACE(WAPI_API, " %s: pWapiStaInfo == NULL Case \n", __FUNCTION__);
-				return;
-			}
-
-			if(pWapiStaInfo->PeerMacAddr == NULL)
-			{
-				WAPI_TRACE(WAPI_API, " %s: pWapiStaInfo->PeerMacAddr == NULL Case \n", __FUNCTION__);
-				return;
-			}
-
-			if(MacAddr == NULL)
-			{
-				WAPI_TRACE(WAPI_API, " %s: MacAddr == NULL Case \n", __FUNCTION__);
-				return;
-			}
-
-			if (_rtw_memcmp(pWapiStaInfo->PeerMacAddr, MacAddr, ETH_ALEN) == _TRUE) {
-				pWapiStaInfo->bAuthenticateInProgress = false;
-				pWapiStaInfo->bSetkeyOk = false;
-				_rtw_memset(pWapiStaInfo->PeerMacAddr,0,ETH_ALEN);
-				list_del_init(&pWapiStaInfo->list);
-				list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
-				break;
-			}
-
-		}
-#endif
-
-		while(!list_empty(&(pWapiInfo->wapiSTAUsedList)))
-		{
-			pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAUsedList.next, RT_WAPI_STA_INFO, list);
-
-			DBG_871X("peer Addr %02x-%02x-%02x-%02x-%02x-%02x \n",pWapiStaInfo->PeerMacAddr[0],pWapiStaInfo->PeerMacAddr[1],pWapiStaInfo->PeerMacAddr[2],pWapiStaInfo->PeerMacAddr[3],pWapiStaInfo->PeerMacAddr[4],pWapiStaInfo->PeerMacAddr[5]);
-
-			list_del_init(&pWapiStaInfo->list);
-			memset(pWapiStaInfo->PeerMacAddr,0,ETH_ALEN);
-			pWapiStaInfo->bSetkeyOk = 0;
-			list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
-		}
-
-	}
-
-        WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
-	return;
-}
-
-void rtw_wapi_return_all_sta_info(_adapter *padapter)
-{
-	PRT_WAPI_T				pWapiInfo;
-	PRT_WAPI_STA_INFO		pWapiStaInfo;
-	PRT_WAPI_BKID			pWapiBkid;
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	pWapiInfo = &padapter->wapiInfo;
-
-	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return;
-	}
-
-	//Sta Info List
-	while(!list_empty(&(pWapiInfo->wapiSTAUsedList)))
-	{
-		pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAUsedList.next, RT_WAPI_STA_INFO, list);
-		list_del_init(&pWapiStaInfo->list);
-		memset(pWapiStaInfo->PeerMacAddr,0,ETH_ALEN);
-		pWapiStaInfo->bSetkeyOk = 0;
-		list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
-	}
-
-	//BKID List
-	while(!list_empty(&(pWapiInfo->wapiBKIDStoreList)))
-	{
-		pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDStoreList.next, RT_WAPI_BKID, list);
-		list_del_init(&pWapiBkid->list);
-		memset(pWapiBkid->bkid,0,16);
-		list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDIdleList);
-	}
-	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
-}
-
-void rtw_wapi_clear_cam_entry(_adapter *padapter, u8 *pMacAddr)
-{
-	u8 UcIndex = 0;
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return;
-	}
-
-	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 0, 0);
-	if(UcIndex != 0xff){
-		//CAM_mark_invalid(Adapter, UcIndex);
-		CAM_empty_entry(padapter, UcIndex);
-	}
-
-	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 1, 0);
-	if(UcIndex != 0xff){
-		//CAM_mark_invalid(Adapter, UcIndex);
-		CAM_empty_entry(padapter, UcIndex);
-	}
-
-	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 0, 1);
-	if(UcIndex != 0xff){
-		//CAM_mark_invalid(Adapter, UcIndex);
-		CAM_empty_entry(padapter, UcIndex);
-	}
-
-	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 1, 1);
-	if(UcIndex != 0xff){
-		//CAM_mark_invalid(padapter, UcIndex);
-		CAM_empty_entry(padapter, UcIndex);
-	}
-
-	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
-}
-
-void rtw_wapi_clear_all_cam_entry(_adapter *padapter)
-{
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return;
-	}
-
-	invalidate_cam_all(padapter); // is this ok?
-	WapiResetAllCamEntry(padapter);
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-}
-
-void rtw_wapi_set_key(_adapter *padapter, RT_WAPI_KEY *pWapiKey, RT_WAPI_STA_INFO *pWapiSta, u8 bGroupKey, u8 bUseDefaultKey)
-{
-	PRT_WAPI_T		pWapiInfo =  &padapter->wapiInfo;
-	u8				*pMacAddr = pWapiSta->PeerMacAddr;
-	u32 EntryId = 0;
-	BOOLEAN IsPairWise = false ;
-	u8 EncAlgo;
-
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_API, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
-		return;
-	}
-
-	EncAlgo = _SMS4_;
-
-	//For Tx bc/mc pkt,use defualt key entry
-	if(bUseDefaultKey)
-	{
-		// when WAPI update key, keyid will be 0 or 1 by turns.
-		if (pWapiKey->keyId == 0)
-			EntryId = 0;
-		else
-			EntryId = 2;
-	}
-	else
-	{
-		// tx/rx unicast pkt, or rx broadcast, find the key entry by peer's MacAddr
-		EntryId = WapiGetEntryForCamWrite(padapter,pMacAddr,pWapiKey->keyId,bGroupKey);
-	}
-
-	if(EntryId == 0xff){
-		WAPI_TRACE(WAPI_API, "===>No entry for WAPI setkey! !!\n");
-		return;
-	}
-
-	//EntryId is also used to diff Sec key and Mic key
-	//Sec Key
-	WapiWriteOneCamEntry(padapter,
-					pMacAddr,
-					pWapiKey->keyId, //keyid
-					EntryId,	//entry
-					EncAlgo, //type
-					bGroupKey, //pairwise or group key
-					pWapiKey->dataKey);
-	//MIC key
-	WapiWriteOneCamEntry(padapter,
-					pMacAddr,
-					pWapiKey->keyId, //keyid
-					EntryId+1,	//entry
-					EncAlgo, //type
-					bGroupKey, //pairwise or group key
-					pWapiKey->micKey);
-
-	WAPI_TRACE(WAPI_API, "Set Wapi Key :KeyId:%d,EntryId:%d,PairwiseKey:%d.\n",pWapiKey->keyId,EntryId,!bGroupKey);
-	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
-
-}
-
-#if 0
-//YJ,test,091013
-void wapi_test_set_key(struct _adapter *padapter, u8* buf)
-{ /*Data: keyType(1) + bTxEnable(1) + bAuthenticator(1) + bUpdate(1) + PeerAddr(6) + DataKey(16) + MicKey(16) + KeyId(1)*/
-	PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
-	PRT_WAPI_BKID		pWapiBkid;
-	PRT_WAPI_STA_INFO	pWapiSta;
-	u8					data[43];
-	bool					bTxEnable;
-	bool					bUpdate;
-	bool					bAuthenticator;
-	u8					PeerAddr[6];
-	u8					WapiAEPNInitialValueSrc[16] = {0x37,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-	u8					WapiASUEPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-	u8					WapiAEMultiCastPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-
-	WAPI_TRACE(WAPI_INIT, "===========>%s\n", __FUNCTION__);
-
-	if (!padapter->WapiSupport){
-	    return;
-	}
-
-	copy_from_user(data, buf, 43);
-	bTxEnable = data[1];
-	bAuthenticator = data[2];
-	bUpdate = data[3];
- 	memcpy(PeerAddr,data+4,6);
-
-	if(data[0] == 0x3){
-		if(!list_empty(&(pWapiInfo->wapiBKIDIdleList))){
-			pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDIdleList.next, RT_WAPI_BKID, list);
-			list_del_init(&pWapiBkid->list);
-			memcpy(pWapiBkid->bkid, data+10, 16);
-			WAPI_DATA(WAPI_INIT, "SetKey - BKID", pWapiBkid->bkid, 16);
-			list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDStoreList);
-		}
-	}else{
-		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-			if(!memcmp(pWapiSta->PeerMacAddr,PeerAddr,6)){
-				pWapiSta->bAuthenticatorInUpdata = false;
-				switch(data[0]){
-				case 1:              //usk
-					if(bAuthenticator){         //authenticator
-						memcpy(pWapiSta->lastTxUnicastPN,WapiAEPNInitialValueSrc,16);
-						if(!bUpdate) {     //first
-							WAPI_TRACE(WAPI_INIT,"AE fisrt set usk \n");
-							pWapiSta->wapiUsk.bSet = true;
-							memcpy(pWapiSta->wapiUsk.dataKey,data+10,16);
-							memcpy(pWapiSta->wapiUsk.micKey,data+26,16);
-							pWapiSta->wapiUsk.keyId = *(data+42);
-							pWapiSta->wapiUsk.bTxEnable = true;
-							WAPI_DATA(WAPI_INIT, "SetKey - AE USK Data Key", pWapiSta->wapiUsk.dataKey, 16);
-							WAPI_DATA(WAPI_INIT, "SetKey - AE USK Mic Key", pWapiSta->wapiUsk.micKey, 16);
-						}
-						else               //update
-						{
-							WAPI_TRACE(WAPI_INIT, "AE update usk \n");
-							pWapiSta->wapiUskUpdate.bSet = true;
-							pWapiSta->bAuthenticatorInUpdata = true;
-							memcpy(pWapiSta->wapiUskUpdate.dataKey,data+10,16);
-							memcpy(pWapiSta->wapiUskUpdate.micKey,data+26,16);
-							memcpy(pWapiSta->lastRxUnicastPNBEQueue,WapiASUEPNInitialValueSrc,16);
-							memcpy(pWapiSta->lastRxUnicastPNBKQueue,WapiASUEPNInitialValueSrc,16);
-							memcpy(pWapiSta->lastRxUnicastPNVIQueue,WapiASUEPNInitialValueSrc,16);
-							memcpy(pWapiSta->lastRxUnicastPNVOQueue,WapiASUEPNInitialValueSrc,16);
-							memcpy(pWapiSta->lastRxUnicastPN,WapiASUEPNInitialValueSrc,16);
-							pWapiSta->wapiUskUpdate.keyId = *(data+42);
-							pWapiSta->wapiUskUpdate.bTxEnable = true;
-						}
-					}
-					else{
-						if(!bUpdate){
-							WAPI_TRACE(WAPI_INIT,"ASUE fisrt set usk \n");
-							if(bTxEnable){
-								pWapiSta->wapiUsk.bTxEnable = true;
-								memcpy(pWapiSta->lastTxUnicastPN,WapiASUEPNInitialValueSrc,16);
-							}else{
-								pWapiSta->wapiUsk.bSet = true;
-								memcpy(pWapiSta->wapiUsk.dataKey,data+10,16);
-								memcpy(pWapiSta->wapiUsk.micKey,data+26,16);
-								pWapiSta->wapiUsk.keyId = *(data+42);
-								pWapiSta->wapiUsk.bTxEnable = false;
-							}
-						}else{
-							WAPI_TRACE(WAPI_INIT,"ASUE update usk \n");
-							if(bTxEnable){
-								pWapiSta->wapiUskUpdate.bTxEnable = true;
-								if(pWapiSta->wapiUskUpdate.bSet){
-									memcpy(pWapiSta->wapiUsk.dataKey,pWapiSta->wapiUskUpdate.dataKey,16);
-									memcpy(pWapiSta->wapiUsk.micKey,pWapiSta->wapiUskUpdate.micKey,16);
-									pWapiSta->wapiUsk.keyId=pWapiSta->wapiUskUpdate.keyId;
-									memcpy(pWapiSta->lastRxUnicastPNBEQueue,WapiASUEPNInitialValueSrc,16);
-									memcpy(pWapiSta->lastRxUnicastPNBKQueue,WapiASUEPNInitialValueSrc,16);
-									memcpy(pWapiSta->lastRxUnicastPNVIQueue,WapiASUEPNInitialValueSrc,16);
-									memcpy(pWapiSta->lastRxUnicastPNVOQueue,WapiASUEPNInitialValueSrc,16);
-									memcpy(pWapiSta->lastRxUnicastPN,WapiASUEPNInitialValueSrc,16);
-									pWapiSta->wapiUskUpdate.bTxEnable = false;
-									pWapiSta->wapiUskUpdate.bSet = false;
-								}
-								memcpy(pWapiSta->lastTxUnicastPN,WapiASUEPNInitialValueSrc,16);
-							}else{
-								pWapiSta->wapiUskUpdate.bSet = true;
-								memcpy(pWapiSta->wapiUskUpdate.dataKey,data+10,16);
-								memcpy(pWapiSta->wapiUskUpdate.micKey,data+26,16);
-								pWapiSta->wapiUskUpdate.keyId = *(data+42);
-								pWapiSta->wapiUskUpdate.bTxEnable = false;
-							}
-						}
-					}
-					break;
-				case 2:		//msk
-					if(bAuthenticator){          //authenticator
-						pWapiInfo->wapiTxMsk.bSet = true;
-						memcpy(pWapiInfo->wapiTxMsk.dataKey,data+10,16);
-						memcpy(pWapiInfo->wapiTxMsk.micKey,data+26,16);
-						pWapiInfo->wapiTxMsk.keyId = *(data+42);
-						pWapiInfo->wapiTxMsk.bTxEnable = true;
-						memcpy(pWapiInfo->lastTxMulticastPN,WapiAEMultiCastPNInitialValueSrc,16);
-
-						if(!bUpdate){      //first
-							WAPI_TRACE(WAPI_INIT, "AE fisrt set msk \n");
-							if(!pWapiSta->bSetkeyOk)
-								pWapiSta->bSetkeyOk = true;
-							pWapiInfo->bFirstAuthentiateInProgress= false;
-						}else{               //update
-							WAPI_TRACE(WAPI_INIT,"AE update msk \n");
-						}
-
-						WAPI_DATA(WAPI_INIT, "SetKey - AE MSK Data Key", pWapiInfo->wapiTxMsk.dataKey, 16);
-						WAPI_DATA(WAPI_INIT, "SetKey - AE MSK Mic Key", pWapiInfo->wapiTxMsk.micKey, 16);
-					}
-					else{
-						if(!bUpdate){
-							WAPI_TRACE(WAPI_INIT,"ASUE fisrt set msk \n");
-							pWapiSta->wapiMsk.bSet = true;
-							memcpy(pWapiSta->wapiMsk.dataKey,data+10,16);
-							memcpy(pWapiSta->wapiMsk.micKey,data+26,16);
-							pWapiSta->wapiMsk.keyId = *(data+42);
-							pWapiSta->wapiMsk.bTxEnable = false;
-							if(!pWapiSta->bSetkeyOk)
-								pWapiSta->bSetkeyOk = true;
-							pWapiInfo->bFirstAuthentiateInProgress= false;
-							WAPI_DATA(WAPI_INIT, "SetKey - ASUE MSK Data Key", pWapiSta->wapiMsk.dataKey, 16);
-							WAPI_DATA(WAPI_INIT, "SetKey - ASUE MSK Mic Key", pWapiSta->wapiMsk.micKey, 16);
-						}else{
-							WAPI_TRACE(WAPI_INIT,"ASUE update msk \n");
-							pWapiSta->wapiMskUpdate.bSet = true;
-							memcpy(pWapiSta->wapiMskUpdate.dataKey,data+10,16);
-							memcpy(pWapiSta->wapiMskUpdate.micKey,data+26,16);
-							pWapiSta->wapiMskUpdate.keyId = *(data+42);
-							pWapiSta->wapiMskUpdate.bTxEnable = false;
-						}
-					}
-					break;
-				default:
-					WAPI_TRACE(WAPI_ERR,"Unknown Flag \n");
-					break;
-				}
-			}
-		}
-	}
-	WAPI_TRACE(WAPI_INIT, "<===========%s\n", __FUNCTION__);
-}
-
-
-void wapi_test_init(struct _adapter *padapter)
-{
-	u8 keybuf[100];
-	u8 mac_addr[6]={0x00,0xe0,0x4c,0x72,0x04,0x70};
-	u8 UskDataKey[16]={0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f};
-	u8 UskMicKey[16]={0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f};
-	u8 UskId = 0;
-	u8 MskDataKey[16]={0x20,0x21,0x22,0x23,0x24,0x25,0x26,0x27,0x28,0x29,0x2a,0x2b,0x2c,0x2d,0x2e,0x2f};
-	u8 MskMicKey[16]={0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39,0x3a,0x3b,0x3c,0x3d,0x3e,0x3f};
-	u8 MskId = 0;
-
-	WAPI_TRACE(WAPI_INIT, "===========>%s\n", __FUNCTION__);
-
-	//Enable Wapi
-	WAPI_TRACE(WAPI_INIT, "%s: Enable wapi!!!!\n", __FUNCTION__);
-	padapter->wapiInfo.bWapiEnable = true;
-	padapter->pairwise_key_type = KEY_TYPE_SMS4;
-	ieee->group_key_type = KEY_TYPE_SMS4;
-	padapter->wapiInfo.extra_prefix_len = WAPI_EXT_LEN;
-	padapter->wapiInfo.extra_postfix_len = SMS4_MIC_LEN;
-
-	//set usk
-	WAPI_TRACE(WAPI_INIT, "%s: Set USK!!!!\n", __FUNCTION__);
-	memset(keybuf,0,100);
-	keybuf[0] = 1;                           //set usk
-	keybuf[1] = 1; 				//enable tx
-	keybuf[2] = 1; 				//AE
-	keybuf[3] = 0; 				//not update
-
-	memcpy(keybuf+4,mac_addr,6);
-	memcpy(keybuf+10,UskDataKey,16);
-	memcpy(keybuf+26,UskMicKey,16);
-	keybuf[42]=UskId;
-	wapi_test_set_key(padapter, keybuf);
-
-	memset(keybuf,0,100);
-	keybuf[0] = 1;                           //set usk
-	keybuf[1] = 1; 				//enable tx
-	keybuf[2] = 0; 				//AE
-	keybuf[3] = 0; 				//not update
-
-	memcpy(keybuf+4,mac_addr,6);
-	memcpy(keybuf+10,UskDataKey,16);
-	memcpy(keybuf+26,UskMicKey,16);
-	keybuf[42]=UskId;
-	wapi_test_set_key(padapter, keybuf);
-
-	//set msk
-	WAPI_TRACE(WAPI_INIT, "%s: Set MSK!!!!\n", __FUNCTION__);
-	memset(keybuf,0,100);
-	keybuf[0] = 2;                                //set msk
-	keybuf[1] = 1;                               //Enable TX
-	keybuf[2] = 1; 				//AE
-	keybuf[3] = 0;                              //not update
-	memcpy(keybuf+4,mac_addr,6);
-	memcpy(keybuf+10,MskDataKey,16);
-	memcpy(keybuf+26,MskMicKey,16);
-	keybuf[42] = MskId;
-	wapi_test_set_key(padapter, keybuf);
-
-	memset(keybuf,0,100);
-	keybuf[0] = 2;                                //set msk
-	keybuf[1] = 1;                               //Enable TX
-	keybuf[2] = 0; 				//AE
-	keybuf[3] = 0;                              //not update
-	memcpy(keybuf+4,mac_addr,6);
-	memcpy(keybuf+10,MskDataKey,16);
-	memcpy(keybuf+26,MskMicKey,16);
-	keybuf[42] = MskId;
-	wapi_test_set_key(padapter, keybuf);
-	WAPI_TRACE(WAPI_INIT, "<===========%s\n", __FUNCTION__);
-}
-#endif
-
-void rtw_wapi_get_iv(_adapter *padapter,u8 *pRA, u8*IV)
-{
-	PWLAN_HEADER_WAPI_EXTENSION pWapiExt = NULL;
-       PRT_WAPI_T         pWapiInfo = &padapter->wapiInfo;
-	bool	bPNOverflow = false;
-	bool	bFindMatchPeer = false;
-	PRT_WAPI_STA_INFO  pWapiSta = NULL;
-
-	pWapiExt = (PWLAN_HEADER_WAPI_EXTENSION)IV;
-
-	WAPI_DATA(WAPI_RX,"wapi_get_iv: pra",pRA,6);
-
-	if(IS_MCAST(pRA)){
-		if(!pWapiInfo->wapiTxMsk.bTxEnable){
-			 WAPI_TRACE(WAPI_ERR,"%s: bTxEnable = 0!!\n",__FUNCTION__);
-			 return;
-		}
-
-		if(pWapiInfo->wapiTxMsk.keyId <= 1){
-			 pWapiExt->KeyIdx = pWapiInfo->wapiTxMsk.keyId;
-			 pWapiExt->Reserved = 0;
-			 bPNOverflow = WapiIncreasePN(pWapiInfo->lastTxMulticastPN, 1);
-			 memcpy(pWapiExt->PN, pWapiInfo->lastTxMulticastPN, 16);
-		}
-	}
-	else
-	{
-		if(list_empty(&pWapiInfo->wapiSTAUsedList)){
-			WAPI_TRACE(WAPI_RX,"rtw_wapi_get_iv: list is empty \n");
-			_rtw_memset(IV,10,18);
-			return;
-		}
-		else{
-				list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list){
-					WAPI_DATA(WAPI_RX,"rtw_wapi_get_iv: peermacaddr ",pWapiSta->PeerMacAddr,6);
-					if (_rtw_memcmp((u8*)pWapiSta->PeerMacAddr, pRA, 6) == _TRUE) {
-						bFindMatchPeer = true;
-						break;
-					}
-				}
-
-				WAPI_TRACE(WAPI_RX,"bFindMatchPeer: %d \n",bFindMatchPeer);
-				WAPI_DATA(WAPI_RX,"Addr",pRA,6);
-
-				if (bFindMatchPeer){
-					if((!pWapiSta->wapiUskUpdate.bTxEnable) && (!pWapiSta->wapiUsk.bTxEnable))
-						return;
-
-					if (pWapiSta->wapiUsk.keyId <= 1){
-						if(pWapiSta->wapiUskUpdate.bTxEnable)
-							pWapiExt->KeyIdx = pWapiSta->wapiUskUpdate.keyId;
-						else
-							pWapiExt->KeyIdx = pWapiSta->wapiUsk.keyId;
-
-						pWapiExt->Reserved = 0;
-						bPNOverflow = WapiIncreasePN(pWapiSta->lastTxUnicastPN, 2);
-						_rtw_memcpy(pWapiExt->PN, pWapiSta->lastTxUnicastPN, 16);
-
-					}
-				}
-		}
-
-	}
-
-}
-
-bool rtw_wapi_drop_for_key_absent(_adapter *padapter,u8 *pRA)
-{
-	PRT_WAPI_T         pWapiInfo = &padapter->wapiInfo;
-	bool				bFindMatchPeer = false;
-	bool				bDrop = false;
-	PRT_WAPI_STA_INFO  pWapiSta = NULL;
-	struct security_priv 		*psecuritypriv = &padapter->securitypriv;
-
-	WAPI_DATA(WAPI_RX,"rtw_wapi_drop_for_key_absent: ra ",pRA,6);
-
-	if(psecuritypriv->dot11PrivacyAlgrthm == _SMS4_)
-	{
-		if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
-			return true;
-
-		if(IS_MCAST(pRA)){
-			if(!pWapiInfo->wapiTxMsk.bTxEnable){
-				bDrop = true;
-				WAPI_TRACE(WAPI_RX,"rtw_wapi_drop_for_key_absent: multicast key is absent \n");
-				return bDrop;
-			}
-		}
-		else{
-				if(!list_empty(&pWapiInfo->wapiSTAUsedList)){
-					list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list){
-						WAPI_DATA(WAPI_RX,"rtw_wapi_drop_for_key_absent: pWapiSta->PeerMacAddr ",pWapiSta->PeerMacAddr,6);
-						if (_rtw_memcmp(pRA, pWapiSta->PeerMacAddr, 6) == _TRUE){
-							bFindMatchPeer = true;
-							break;
-						}
-					}
-					if (bFindMatchPeer)	{
-						if (!pWapiSta->wapiUsk.bTxEnable){
-							bDrop = true;
-							WAPI_TRACE(WAPI_RX,"rtw_wapi_drop_for_key_absent: unicast key is absent \n");
-							return bDrop;
-						}
-					}
-					else{
-						bDrop = true;
-						WAPI_TRACE(WAPI_RX,"rtw_wapi_drop_for_key_absent: no peer find \n");
-						return bDrop;
-					}
-
-				}
-				else{
-						bDrop = true;
-						WAPI_TRACE(WAPI_RX,"rtw_wapi_drop_for_key_absent: no sta  exist \n");
-						return bDrop;
-				}
-		}
-	}
-	else
-	{
-		return bDrop;
-	}
-
-	return bDrop;
-}
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#ifdef CONFIG_WAPI_SUPPORT
+
+#include <linux/unistd.h>
+#include <linux/etherdevice.h>
+#include <drv_types.h>
+#include <rtw_wapi.h>
+
+
+u32 wapi_debug_component =
+	/*				WAPI_INIT	|
+	 *				WAPI_API	|
+	 *				WAPI_TX	|
+	 *				WAPI_RX	| */
+	WAPI_ERR ; /* always open err flags on */
+
+void WapiFreeAllStaInfo(_adapter *padapter)
+{
+	PRT_WAPI_T				pWapiInfo;
+	PRT_WAPI_STA_INFO		pWapiStaInfo;
+	PRT_WAPI_BKID			pWapiBkid;
+
+	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
+	pWapiInfo = &padapter->wapiInfo;
+
+	/* Pust to Idle List */
+	rtw_wapi_return_all_sta_info(padapter);
+
+	/* Sta Info List */
+	while (!list_empty(&(pWapiInfo->wapiSTAIdleList))) {
+		pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAIdleList.next, RT_WAPI_STA_INFO, list);
+		list_del_init(&pWapiStaInfo->list);
+	}
+
+	/* BKID List */
+	while (!list_empty(&(pWapiInfo->wapiBKIDIdleList))) {
+		pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDIdleList.next, RT_WAPI_BKID, list);
+		list_del_init(&pWapiBkid->list);
+	}
+	WAPI_TRACE(WAPI_INIT, "<=========== %s\n", __FUNCTION__);
+	return;
+}
+
+void WapiSetIE(_adapter *padapter)
+{
+	PRT_WAPI_T		pWapiInfo = &(padapter->wapiInfo);
+	/* PRT_WAPI_BKID	pWapiBkid; */
+	u16		protocolVer = 1;
+	u16		akmCnt = 1;
+	u16		suiteCnt = 1;
+	u16		capability = 0;
+	u8		OUI[3];
+
+	OUI[0] = 0x00;
+	OUI[1] = 0x14;
+	OUI[2] = 0x72;
+
+	pWapiInfo->wapiIELength = 0;
+	/* protocol version */
+	memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &protocolVer, 2);
+	pWapiInfo->wapiIELength += 2;
+	/* akm */
+	memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &akmCnt, 2);
+	pWapiInfo->wapiIELength += 2;
+
+	if (pWapiInfo->bWapiPSK) {
+		memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
+		pWapiInfo->wapiIELength += 3;
+		pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x2;
+		pWapiInfo->wapiIELength += 1;
+	} else {
+		memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
+		pWapiInfo->wapiIELength += 3;
+		pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
+		pWapiInfo->wapiIELength += 1;
+	}
+
+	/* usk */
+	memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &suiteCnt, 2);
+	pWapiInfo->wapiIELength += 2;
+	memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
+	pWapiInfo->wapiIELength += 3;
+	pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
+	pWapiInfo->wapiIELength += 1;
+
+	/* msk */
+	memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
+	pWapiInfo->wapiIELength += 3;
+	pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
+	pWapiInfo->wapiIELength += 1;
+
+	/* Capbility */
+	memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &capability, 2);
+	pWapiInfo->wapiIELength += 2;
+}
+
+
+/*  PN1 > PN2, return 1,
+ *  else return 0.
+ */
+u32 WapiComparePN(u8 *PN1, u8 *PN2)
+{
+	char i;
+
+	if ((NULL == PN1) || (NULL == PN2))
+		return 1;
+
+	/* overflow case */
+	if ((PN2[15] - PN1[15]) & 0x80)
+		return 1;
+
+	for (i = 16; i > 0; i--) {
+		if (PN1[i - 1] == PN2[i - 1])
+			continue;
+		else if (PN1[i - 1] > PN2[i - 1])
+			return 1;
+		else
+			return 0;
+	}
+
+	return 0;
+}
+
+u8
+WapiGetEntryForCamWrite(_adapter *padapter, u8 *pMacAddr, u8 KID, BOOLEAN IsMsk)
+{
+	PRT_WAPI_T		pWapiInfo = NULL;
+	/* PRT_WAPI_CAM_ENTRY	pEntry=NULL; */
+	u8 i = 0;
+	u8 ret = 0xff;
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	pWapiInfo =  &padapter->wapiInfo;
+
+	/* exist? */
+	for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
+		if (pWapiInfo->wapiCamEntry[i].IsUsed
+		    && (_rtw_memcmp(pMacAddr, pWapiInfo->wapiCamEntry[i].PeerMacAddr, ETH_ALEN) == _TRUE)
+		    && pWapiInfo->wapiCamEntry[i].keyidx == KID
+		    && pWapiInfo->wapiCamEntry[i].type == IsMsk) {
+			ret = pWapiInfo->wapiCamEntry[i].entry_idx; /* cover it */
+			break;
+		}
+	}
+
+	if (i == WAPI_CAM_ENTRY_NUM) { /* not found */
+		for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
+			if (pWapiInfo->wapiCamEntry[i].IsUsed == 0) {
+				pWapiInfo->wapiCamEntry[i].IsUsed = 1;
+				pWapiInfo->wapiCamEntry[i].type = IsMsk;
+				pWapiInfo->wapiCamEntry[i].keyidx = KID;
+				_rtw_memcpy(pWapiInfo->wapiCamEntry[i].PeerMacAddr, pMacAddr, ETH_ALEN);
+				ret = pWapiInfo->wapiCamEntry[i].entry_idx;
+				break;
+			}
+		}
+	}
+
+	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
+	return ret;
+
+	/*
+		if(RTIsListEmpty(&pWapiInfo->wapiCamIdleList)) {
+			return 0;
+		}
+
+		pEntry = (PRT_WAPI_CAM_ENTRY)RTRemoveHeadList(&pWapiInfo->wapiCamIdleList);
+		RTInsertTailList(&pWapiInfo->wapiCamUsedList, &pEntry->list);
+
+
+		return pEntry->entry_idx;*/
+}
+
+u8 WapiGetEntryForCamClear(_adapter *padapter, u8 *pPeerMac, u8 keyid, u8 IsMsk)
+{
+	PRT_WAPI_T		pWapiInfo = NULL;
+	u8		i = 0;
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	pWapiInfo =  &padapter->wapiInfo;
+
+	for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
+		if (pWapiInfo->wapiCamEntry[i].IsUsed
+		    && (_rtw_memcmp(pPeerMac, pWapiInfo->wapiCamEntry[i].PeerMacAddr, ETH_ALEN) == _TRUE)
+		    && pWapiInfo->wapiCamEntry[i].keyidx == keyid
+		    && pWapiInfo->wapiCamEntry[i].type == IsMsk) {
+			pWapiInfo->wapiCamEntry[i].IsUsed = 0;
+			pWapiInfo->wapiCamEntry[i].keyidx = 2;
+			_rtw_memset(pWapiInfo->wapiCamEntry[i].PeerMacAddr, 0, ETH_ALEN);
+
+			WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
+			return pWapiInfo->wapiCamEntry[i].entry_idx;
+		}
+	}
+
+	WAPI_TRACE(WAPI_API, "<====WapiGetReturnCamEntry(), No this cam entry.\n");
+	return 0xff;
+	/*
+		if(RTIsListEmpty(&pWapiInfo->wapiCamUsedList)) {
+			return FALSE;
+		}
+
+		pList = &pWapiInfo->wapiCamUsedList;
+		while(pList->Flink != &pWapiInfo->wapiCamUsedList)
+		{
+			pEntry = (PRT_WAPI_CAM_ENTRY)pList->Flink;
+			if(PlatformCompareMemory(pPeerMac,pEntry->PeerMacAddr, ETHER_ADDRLEN)== 0
+				&& keyid == pEntry->keyidx)
+			{
+				RTRemoveEntryList(pList);
+				RTInsertHeadList(&pWapiInfo->wapiCamIdleList, pList);
+				return pEntry->entry_idx;
+			}
+			pList = pList->Flink;
+		}
+
+		return 0;
+	*/
+}
+
+void
+WapiResetAllCamEntry(_adapter *padapter)
+{
+	PRT_WAPI_T		pWapiInfo;
+	int				i;
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	pWapiInfo =  &padapter->wapiInfo;
+
+	for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
+		_rtw_memset(pWapiInfo->wapiCamEntry[i].PeerMacAddr, 0, ETH_ALEN);
+		pWapiInfo->wapiCamEntry[i].IsUsed = 0;
+		pWapiInfo->wapiCamEntry[i].keyidx = 2; /* invalid */
+		pWapiInfo->wapiCamEntry[i].entry_idx = 4 + i * 2;
+	}
+
+	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
+
+	return;
+}
+
+u8 WapiWriteOneCamEntry(
+	_adapter	*padapter,
+	u8			*pMacAddr,
+	u8			KeyId,
+	u8			EntryId,
+	u8			EncAlg,
+	u8			bGroupKey,
+	u8			*pKey
+)
+{
+	u8 retVal = 0;
+	u16 usConfig = 0;
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	if (EntryId >= 32) {
+		WAPI_TRACE(WAPI_ERR, "<=== CamAddOneEntry(): ulKeyId exceed!\n");
+		return retVal;
+	}
+
+	usConfig = usConfig | (0x01 << 15) | ((u16)(EncAlg) << 2) | (KeyId);
+
+	if (EncAlg == _SMS4_) {
+		if (bGroupKey == 1)
+			usConfig |= (0x01 << 6);
+		if ((EntryId % 2) == 1) /* ==0 sec key; == 1mic key */
+			usConfig |= (0x01 << 5);
+	}
+
+	write_cam(padapter, EntryId, usConfig, pMacAddr, pKey);
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+	return 1;
+}
+
+void rtw_wapi_init(_adapter *padapter)
+{
+	PRT_WAPI_T		pWapiInfo;
+	int				i;
+
+	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
+	RT_ASSERT_RET(padapter);
+
+	if (!padapter->WapiSupport) {
+		WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
+		return;
+	}
+
+	pWapiInfo =  &padapter->wapiInfo;
+	pWapiInfo->bWapiEnable = false;
+
+	/* Init BKID List */
+	INIT_LIST_HEAD(&pWapiInfo->wapiBKIDIdleList);
+	INIT_LIST_HEAD(&pWapiInfo->wapiBKIDStoreList);
+	for (i = 0; i < WAPI_MAX_BKID_NUM; i++)
+		list_add_tail(&pWapiInfo->wapiBKID[i].list, &pWapiInfo->wapiBKIDIdleList);
+
+	/* Init STA List */
+	INIT_LIST_HEAD(&pWapiInfo->wapiSTAIdleList);
+	INIT_LIST_HEAD(&pWapiInfo->wapiSTAUsedList);
+	for (i = 0; i < WAPI_MAX_STAINFO_NUM; i++)
+		list_add_tail(&pWapiInfo->wapiSta[i].list, &pWapiInfo->wapiSTAIdleList);
+
+	for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
+		pWapiInfo->wapiCamEntry[i].IsUsed = 0;
+		pWapiInfo->wapiCamEntry[i].keyidx = 2; /* invalid */
+		pWapiInfo->wapiCamEntry[i].entry_idx = 4 + i * 2;
+	}
+
+	WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
+}
+
+void rtw_wapi_free(_adapter *padapter)
+{
+	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
+	RT_ASSERT_RET(padapter);
+
+	if (!padapter->WapiSupport) {
+		WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
+		return;
+	}
+
+	WapiFreeAllStaInfo(padapter);
+
+	WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
+}
+
+void rtw_wapi_disable_tx(_adapter *padapter)
+{
+	WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
+	RT_ASSERT_RET(padapter);
+
+	if (!padapter->WapiSupport) {
+		WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
+		return;
+	}
+
+	padapter->wapiInfo.wapiTxMsk.bTxEnable = false;
+	padapter->wapiInfo.wapiTxMsk.bSet = false;
+
+	WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
+}
+
+u8 rtw_wapi_is_wai_packet(_adapter *padapter, u8 *pkt_data)
+{
+	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv   *psecuritypriv = &padapter->securitypriv;
+	PRT_WAPI_STA_INFO pWapiSta = NULL;
+	u8 WaiPkt = 0, *pTaddr, bFind = false;
+	u8 Offset_TypeWAI = 0 ;	/* (mac header len + llc length) */
+
+	WAPI_TRACE(WAPI_TX | WAPI_RX, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return 0;
+	}
+
+	Offset_TypeWAI = 24 + 6 ;
+
+	/* YJ,add,091103. Data frame may also have skb->data[30]=0x88 and skb->data[31]=0xb4. */
+	if ((pkt_data[1] & 0x40) != 0) {
+		/* RTW_INFO("data is privacy\n"); */
+		return 0;
+	}
+
+	pTaddr = get_addr2_ptr(pkt_data);
+	if (list_empty(&pWapiInfo->wapiSTAUsedList))
+		bFind = false;
+	else {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (_rtw_memcmp(pTaddr, pWapiSta->PeerMacAddr, 6) == _TRUE) {
+				bFind = true;
+				break;
+			}
+		}
+	}
+
+	WAPI_TRACE(WAPI_TX | WAPI_RX, "%s: bFind=%d pTaddr="MAC_FMT"\n", __FUNCTION__, bFind, MAC_ARG(pTaddr));
+
+	if (pkt_data[0] == WIFI_QOS_DATA_TYPE)
+		Offset_TypeWAI += 2;
+
+	/* 88b4? */
+	if ((pkt_data[Offset_TypeWAI] == 0x88) && (pkt_data[Offset_TypeWAI + 1] == 0xb4)) {
+		WaiPkt = pkt_data[Offset_TypeWAI + 5];
+
+		psecuritypriv->hw_decrypted = _TRUE;
+	} else
+		WAPI_TRACE(WAPI_TX | WAPI_RX, "%s(): non wai packet\n", __FUNCTION__);
+
+	WAPI_TRACE(WAPI_TX | WAPI_RX, "%s(): Recvd WAI frame. IsWAIPkt(%d)\n", __FUNCTION__, WaiPkt);
+
+	return	WaiPkt;
+}
+
+
+void rtw_wapi_update_info(_adapter *padapter, union recv_frame *precv_frame)
+{
+	PRT_WAPI_T     pWapiInfo = &(padapter->wapiInfo);
+	struct recv_frame_hdr *precv_hdr;
+	u8	*ptr;
+	u8	*pTA;
+	u8	*pRecvPN;
+
+
+	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return;
+	}
+
+	precv_hdr = &precv_frame->u.hdr;
+	ptr = precv_hdr->rx_data;
+
+	if (precv_hdr->attrib.qos == 1)
+		precv_hdr->UserPriority = GetTid(ptr);
+	else
+		precv_hdr->UserPriority = 0;
+
+	pTA = get_addr2_ptr(ptr);
+	_rtw_memcpy((u8 *)precv_hdr->WapiSrcAddr, pTA, 6);
+	pRecvPN = ptr + precv_hdr->attrib.hdrlen + 2;
+	_rtw_memcpy((u8 *)precv_hdr->WapiTempPN, pRecvPN, 16);
+
+	WAPI_TRACE(WAPI_RX, "<========== %s\n", __FUNCTION__);
+}
+
+/****************************************************************************
+TRUE-----------------Drop
+FALSE---------------- handle
+add to support WAPI to N-mode
+*****************************************************************************/
+u8 rtw_wapi_check_for_drop(
+	_adapter *padapter,
+	union recv_frame *precv_frame,
+	u8 *ehdr_ops
+)
+{
+	PRT_WAPI_T     pWapiInfo = &(padapter->wapiInfo);
+	u8			*pLastRecvPN = NULL;
+	u8			bFind = false;
+	PRT_WAPI_STA_INFO	pWapiSta = NULL;
+	u8			bDrop = false;
+	struct recv_frame_hdr *precv_hdr = &precv_frame->u.hdr;
+	u8					WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					*ptr = ehdr_ops;
+	int					i;
+
+	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return false;
+	}
+
+	if (precv_hdr->bIsWaiPacket != 0) {
+		if (precv_hdr->bIsWaiPacket == 0x8) {
+
+			RTW_INFO("rtw_wapi_check_for_drop: dump packet\n");
+			for (i = 0; i < 50; i++) {
+				RTW_INFO("%02X  ", ptr[i]);
+				if ((i + 1) % 8 == 0)
+					RTW_INFO("\n");
+			}
+			RTW_INFO("\n rtw_wapi_check_for_drop: dump packet\n");
+
+			for (i = 0; i < 16; i++) {
+				if (ptr[i + 27] != 0)
+					break;
+			}
+
+			if (i == 16) {
+				WAPI_TRACE(WAPI_RX, "rtw_wapi_check_for_drop: drop with zero BKID\n");
+				return true;
+			} else
+				return false;
+		} else
+			return false;
+	}
+
+	if (list_empty(&pWapiInfo->wapiSTAUsedList))
+		bFind = false;
+	else {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (_rtw_memcmp(precv_hdr->WapiSrcAddr, pWapiSta->PeerMacAddr, ETH_ALEN) == _TRUE) {
+				bFind = true;
+				break;
+			}
+		}
+	}
+	WAPI_TRACE(WAPI_RX, "%s: bFind=%d prxb->WapiSrcAddr="MAC_FMT"\n", __FUNCTION__, bFind, MAC_ARG(precv_hdr->WapiSrcAddr));
+
+	if (bFind) {
+		if (IS_MCAST(precv_hdr->attrib.ra)) {
+			WAPI_TRACE(WAPI_RX, "rtw_wapi_check_for_drop: multicast case\n");
+			pLastRecvPN = pWapiSta->lastRxMulticastPN;
+		} else {
+			WAPI_TRACE(WAPI_RX, "rtw_wapi_check_for_drop: unicast case\n");
+			switch (precv_hdr->UserPriority) {
+			case 0:
+			case 3:
+				pLastRecvPN = pWapiSta->lastRxUnicastPNBEQueue;
+				break;
+			case 1:
+			case 2:
+				pLastRecvPN = pWapiSta->lastRxUnicastPNBKQueue;
+				break;
+			case 4:
+			case 5:
+				pLastRecvPN = pWapiSta->lastRxUnicastPNVIQueue;
+				break;
+			case 6:
+			case 7:
+				pLastRecvPN = pWapiSta->lastRxUnicastPNVOQueue;
+				break;
+			default:
+				WAPI_TRACE(WAPI_ERR, "%s: Unknown TID\n", __FUNCTION__);
+				break;
+			}
+		}
+
+		if (!WapiComparePN(precv_hdr->WapiTempPN, pLastRecvPN)) {
+			WAPI_TRACE(WAPI_RX, "%s: Equal PN!!\n", __FUNCTION__);
+			if (IS_MCAST(precv_hdr->attrib.ra))
+				_rtw_memcpy(pLastRecvPN, WapiAEMultiCastPNInitialValueSrc, 16);
+			else
+				_rtw_memcpy(pLastRecvPN, WapiAEPNInitialValueSrc, 16);
+			bDrop = true;
+		} else
+			_rtw_memcpy(pLastRecvPN, precv_hdr->WapiTempPN, 16);
+	}
+
+	WAPI_TRACE(WAPI_RX, "<========== %s\n", __FUNCTION__);
+	return bDrop;
+}
+
+void rtw_build_probe_resp_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
+{
+	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
+	u8 WapiIELength = 0;
+
+	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport)  || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
+		return;
+	}
+
+	WapiSetIE(padapter);
+	WapiIELength = pWapiInfo->wapiIELength;
+	pframe[0] = _WAPI_IE_;
+	pframe[1] = WapiIELength;
+	_rtw_memcpy(pframe + 2, pWapiInfo->wapiIE, WapiIELength);
+	pframe += WapiIELength + 2;
+	pattrib->pktlen += WapiIELength + 2;
+
+	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
+}
+
+void rtw_build_beacon_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
+{
+	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
+	u8 WapiIELength = 0;
+	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport)  || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
+		return;
+	}
+
+	WapiSetIE(padapter);
+	WapiIELength = pWapiInfo->wapiIELength;
+	pframe[0] = _WAPI_IE_;
+	pframe[1] = WapiIELength;
+	_rtw_memcpy(pframe + 2, pWapiInfo->wapiIE, WapiIELength);
+	pframe += WapiIELength + 2;
+	pattrib->pktlen += WapiIELength + 2;
+
+	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
+}
+
+void rtw_build_assoc_req_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
+{
+	PRT_WAPI_BKID		pWapiBKID;
+	u16					bkidNum;
+	PRT_WAPI_T			pWapiInfo = &(padapter->wapiInfo);
+	u8					WapiIELength = 0;
+
+	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
+		return;
+	}
+
+	WapiSetIE(padapter);
+	WapiIELength = pWapiInfo->wapiIELength;
+	bkidNum = 0;
+	if (!list_empty(&(pWapiInfo->wapiBKIDStoreList))) {
+		list_for_each_entry(pWapiBKID, &pWapiInfo->wapiBKIDStoreList, list) {
+			bkidNum++;
+			_rtw_memcpy(pWapiInfo->wapiIE + WapiIELength + 2, pWapiBKID->bkid, 16);
+			WapiIELength += 16;
+		}
+	}
+	_rtw_memcpy(pWapiInfo->wapiIE + WapiIELength, &bkidNum, 2);
+	WapiIELength += 2;
+
+	pframe[0] = _WAPI_IE_;
+	pframe[1] = WapiIELength;
+	_rtw_memcpy(pframe + 2, pWapiInfo->wapiIE, WapiIELength);
+	pframe += WapiIELength + 2;
+	pattrib->pktlen += WapiIELength + 2;
+	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
+}
+
+void rtw_wapi_on_assoc_ok(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
+{
+	PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
+	PRT_WAPI_STA_INFO pWapiSta;
+	u8 WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	/* u8 WapiASUEPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ; */
+	u8 WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+
+	WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return;
+	}
+
+	pWapiSta = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAIdleList.next, RT_WAPI_STA_INFO, list);
+	list_del_init(&pWapiSta->list);
+	list_add_tail(&pWapiSta->list, &pWapiInfo->wapiSTAUsedList);
+	_rtw_memcpy(pWapiSta->PeerMacAddr, padapter->mlmeextpriv.mlmext_info.network.MacAddress, 6);
+	_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
+	_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
+
+	/* For chenk PN error with Qos Data after s3: add by ylb 20111114 */
+	_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiAEPNInitialValueSrc, 16);
+	_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiAEPNInitialValueSrc, 16);
+	_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiAEPNInitialValueSrc, 16);
+	_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiAEPNInitialValueSrc, 16);
+
+	WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
+}
+
+
+void rtw_wapi_return_one_sta_info(_adapter *padapter, u8 *MacAddr)
+{
+	PRT_WAPI_T				pWapiInfo;
+	PRT_WAPI_STA_INFO		pWapiStaInfo = NULL;
+	PRT_WAPI_BKID			pWapiBkid = NULL;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+
+	pWapiInfo = &padapter->wapiInfo;
+
+	WAPI_TRACE(WAPI_API, "==========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return;
+	}
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+		while (!list_empty(&(pWapiInfo->wapiBKIDStoreList))) {
+			pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDStoreList.next, RT_WAPI_BKID, list);
+			list_del_init(&pWapiBkid->list);
+			_rtw_memset(pWapiBkid->bkid, 0, 16);
+			list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDIdleList);
+		}
+	}
+
+
+	WAPI_TRACE(WAPI_API, " %s: after clear bkid\n", __FUNCTION__);
+
+
+	/* Remove STA info */
+	if (list_empty(&(pWapiInfo->wapiSTAUsedList))) {
+		WAPI_TRACE(WAPI_API, " %s: wapiSTAUsedList is null\n", __FUNCTION__);
+		return;
+	} else {
+
+		WAPI_TRACE(WAPI_API, " %s: wapiSTAUsedList is not null\n", __FUNCTION__);
+#if 0
+		pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry((pWapiInfo->wapiSTAUsedList.next), RT_WAPI_STA_INFO, list);
+
+		list_for_each_entry(pWapiStaInfo, &(pWapiInfo->wapiSTAUsedList), list) {
+
+			RTW_INFO("MAC Addr %02x-%02x-%02x-%02x-%02x-%02x\n", MacAddr[0], MacAddr[1], MacAddr[2], MacAddr[3], MacAddr[4], MacAddr[5]);
+
+
+			RTW_INFO("peer Addr %02x-%02x-%02x-%02x-%02x-%02x\n", pWapiStaInfo->PeerMacAddr[0], pWapiStaInfo->PeerMacAddr[1], pWapiStaInfo->PeerMacAddr[2], pWapiStaInfo->PeerMacAddr[3],
+				pWapiStaInfo->PeerMacAddr[4], pWapiStaInfo->PeerMacAddr[5]);
+
+			if (pWapiStaInfo == NULL) {
+				WAPI_TRACE(WAPI_API, " %s: pWapiStaInfo == NULL Case\n", __FUNCTION__);
+				return;
+			}
+
+			if (pWapiStaInfo->PeerMacAddr == NULL) {
+				WAPI_TRACE(WAPI_API, " %s: pWapiStaInfo->PeerMacAddr == NULL Case\n", __FUNCTION__);
+				return;
+			}
+
+			if (MacAddr == NULL) {
+				WAPI_TRACE(WAPI_API, " %s: MacAddr == NULL Case\n", __FUNCTION__);
+				return;
+			}
+
+			if (_rtw_memcmp(pWapiStaInfo->PeerMacAddr, MacAddr, ETH_ALEN) == _TRUE) {
+				pWapiStaInfo->bAuthenticateInProgress = false;
+				pWapiStaInfo->bSetkeyOk = false;
+				_rtw_memset(pWapiStaInfo->PeerMacAddr, 0, ETH_ALEN);
+				list_del_init(&pWapiStaInfo->list);
+				list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
+				break;
+			}
+
+		}
+#endif
+
+		while (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
+			pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAUsedList.next, RT_WAPI_STA_INFO, list);
+
+			RTW_INFO("peer Addr %02x-%02x-%02x-%02x-%02x-%02x\n", pWapiStaInfo->PeerMacAddr[0], pWapiStaInfo->PeerMacAddr[1], pWapiStaInfo->PeerMacAddr[2], pWapiStaInfo->PeerMacAddr[3],
+				pWapiStaInfo->PeerMacAddr[4], pWapiStaInfo->PeerMacAddr[5]);
+
+			list_del_init(&pWapiStaInfo->list);
+			memset(pWapiStaInfo->PeerMacAddr, 0, ETH_ALEN);
+			pWapiStaInfo->bSetkeyOk = 0;
+			list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
+		}
+
+	}
+
+	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
+	return;
+}
+
+void rtw_wapi_return_all_sta_info(_adapter *padapter)
+{
+	PRT_WAPI_T				pWapiInfo;
+	PRT_WAPI_STA_INFO		pWapiStaInfo;
+	PRT_WAPI_BKID			pWapiBkid;
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	pWapiInfo = &padapter->wapiInfo;
+
+	if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return;
+	}
+
+	/* Sta Info List */
+	while (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
+		pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAUsedList.next, RT_WAPI_STA_INFO, list);
+		list_del_init(&pWapiStaInfo->list);
+		memset(pWapiStaInfo->PeerMacAddr, 0, ETH_ALEN);
+		pWapiStaInfo->bSetkeyOk = 0;
+		list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
+	}
+
+	/* BKID List */
+	while (!list_empty(&(pWapiInfo->wapiBKIDStoreList))) {
+		pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDStoreList.next, RT_WAPI_BKID, list);
+		list_del_init(&pWapiBkid->list);
+		memset(pWapiBkid->bkid, 0, 16);
+		list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDIdleList);
+	}
+	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
+}
+
+void rtw_wapi_clear_cam_entry(_adapter *padapter, u8 *pMacAddr)
+{
+	u8 UcIndex = 0;
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return;
+	}
+
+	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 0, 0);
+	if (UcIndex != 0xff) {
+		/* CAM_mark_invalid(Adapter, UcIndex); */
+		CAM_empty_entry(padapter, UcIndex);
+	}
+
+	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 1, 0);
+	if (UcIndex != 0xff) {
+		/* CAM_mark_invalid(Adapter, UcIndex); */
+		CAM_empty_entry(padapter, UcIndex);
+	}
+
+	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 0, 1);
+	if (UcIndex != 0xff) {
+		/* CAM_mark_invalid(Adapter, UcIndex); */
+		CAM_empty_entry(padapter, UcIndex);
+	}
+
+	UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 1, 1);
+	if (UcIndex != 0xff) {
+		/* CAM_mark_invalid(padapter, UcIndex); */
+		CAM_empty_entry(padapter, UcIndex);
+	}
+
+	WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
+}
+
+void rtw_wapi_clear_all_cam_entry(_adapter *padapter)
+{
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
+		WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return;
+	}
+
+	invalidate_cam_all(padapter); /* is this ok? */
+	WapiResetAllCamEntry(padapter);
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+}
+
+void rtw_wapi_set_key(_adapter *padapter, RT_WAPI_KEY *pWapiKey, RT_WAPI_STA_INFO *pWapiSta, u8 bGroupKey, u8 bUseDefaultKey)
+{
+	PRT_WAPI_T		pWapiInfo =  &padapter->wapiInfo;
+	u8				*pMacAddr = pWapiSta->PeerMacAddr;
+	u32 EntryId = 0;
+	BOOLEAN IsPairWise = false ;
+	u8 EncAlgo;
+
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
+		WAPI_TRACE(WAPI_API, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
+		return;
+	}
+
+	EncAlgo = _SMS4_;
+
+	/* For Tx bc/mc pkt,use defualt key entry */
+	if (bUseDefaultKey) {
+		/* when WAPI update key, keyid will be 0 or 1 by turns. */
+		if (pWapiKey->keyId == 0)
+			EntryId = 0;
+		else
+			EntryId = 2;
+	} else {
+		/* tx/rx unicast pkt, or rx broadcast, find the key entry by peer's MacAddr */
+		EntryId = WapiGetEntryForCamWrite(padapter, pMacAddr, pWapiKey->keyId, bGroupKey);
+	}
+
+	if (EntryId == 0xff) {
+		WAPI_TRACE(WAPI_API, "===>No entry for WAPI setkey! !!\n");
+		return;
+	}
+
+	/* EntryId is also used to diff Sec key and Mic key */
+	/* Sec Key */
+	WapiWriteOneCamEntry(padapter,
+			     pMacAddr,
+			     pWapiKey->keyId, /* keyid */
+			     EntryId,	/* entry */
+			     EncAlgo, /* type */
+			     bGroupKey, /* pairwise or group key */
+			     pWapiKey->dataKey);
+	/* MIC key */
+	WapiWriteOneCamEntry(padapter,
+			     pMacAddr,
+			     pWapiKey->keyId, /* keyid */
+			     EntryId + 1,	/* entry */
+			     EncAlgo, /* type */
+			     bGroupKey, /* pairwise or group key */
+			     pWapiKey->micKey);
+
+	WAPI_TRACE(WAPI_API, "Set Wapi Key :KeyId:%d,EntryId:%d,PairwiseKey:%d.\n", pWapiKey->keyId, EntryId, !bGroupKey);
+	WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
+
+}
+
+#if 0
+/* YJ,test,091013 */
+void wapi_test_set_key(struct _adapter *padapter, u8 *buf)
+{
+	/*Data: keyType(1) + bTxEnable(1) + bAuthenticator(1) + bUpdate(1) + PeerAddr(6) + DataKey(16) + MicKey(16) + KeyId(1)*/
+	PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
+	PRT_WAPI_BKID		pWapiBkid;
+	PRT_WAPI_STA_INFO	pWapiSta;
+	u8					data[43];
+	bool					bTxEnable;
+	bool					bUpdate;
+	bool					bAuthenticator;
+	u8					PeerAddr[6];
+	u8					WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					WapiASUEPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+
+	WAPI_TRACE(WAPI_INIT, "===========>%s\n", __FUNCTION__);
+
+	if (!padapter->WapiSupport)
+		return;
+
+	copy_from_user(data, buf, 43);
+	bTxEnable = data[1];
+	bAuthenticator = data[2];
+	bUpdate = data[3];
+	memcpy(PeerAddr, data + 4, 6);
+
+	if (data[0] == 0x3) {
+		if (!list_empty(&(pWapiInfo->wapiBKIDIdleList))) {
+			pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDIdleList.next, RT_WAPI_BKID, list);
+			list_del_init(&pWapiBkid->list);
+			memcpy(pWapiBkid->bkid, data + 10, 16);
+			WAPI_DATA(WAPI_INIT, "SetKey - BKID", pWapiBkid->bkid, 16);
+			list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDStoreList);
+		}
+	} else {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (!memcmp(pWapiSta->PeerMacAddr, PeerAddr, 6)) {
+				pWapiSta->bAuthenticatorInUpdata = false;
+				switch (data[0]) {
+				case 1:              /* usk */
+					if (bAuthenticator) {       /* authenticator */
+						memcpy(pWapiSta->lastTxUnicastPN, WapiAEPNInitialValueSrc, 16);
+						if (!bUpdate) {    /* first */
+							WAPI_TRACE(WAPI_INIT, "AE fisrt set usk\n");
+							pWapiSta->wapiUsk.bSet = true;
+							memcpy(pWapiSta->wapiUsk.dataKey, data + 10, 16);
+							memcpy(pWapiSta->wapiUsk.micKey, data + 26, 16);
+							pWapiSta->wapiUsk.keyId = *(data + 42);
+							pWapiSta->wapiUsk.bTxEnable = true;
+							WAPI_DATA(WAPI_INIT, "SetKey - AE USK Data Key", pWapiSta->wapiUsk.dataKey, 16);
+							WAPI_DATA(WAPI_INIT, "SetKey - AE USK Mic Key", pWapiSta->wapiUsk.micKey, 16);
+						} else {           /* update */
+							WAPI_TRACE(WAPI_INIT, "AE update usk\n");
+							pWapiSta->wapiUskUpdate.bSet = true;
+							pWapiSta->bAuthenticatorInUpdata = true;
+							memcpy(pWapiSta->wapiUskUpdate.dataKey, data + 10, 16);
+							memcpy(pWapiSta->wapiUskUpdate.micKey, data + 26, 16);
+							memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiASUEPNInitialValueSrc, 16);
+							memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiASUEPNInitialValueSrc, 16);
+							memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiASUEPNInitialValueSrc, 16);
+							memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiASUEPNInitialValueSrc, 16);
+							memcpy(pWapiSta->lastRxUnicastPN, WapiASUEPNInitialValueSrc, 16);
+							pWapiSta->wapiUskUpdate.keyId = *(data + 42);
+							pWapiSta->wapiUskUpdate.bTxEnable = true;
+						}
+					} else {
+						if (!bUpdate) {
+							WAPI_TRACE(WAPI_INIT, "ASUE fisrt set usk\n");
+							if (bTxEnable) {
+								pWapiSta->wapiUsk.bTxEnable = true;
+								memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
+							} else {
+								pWapiSta->wapiUsk.bSet = true;
+								memcpy(pWapiSta->wapiUsk.dataKey, data + 10, 16);
+								memcpy(pWapiSta->wapiUsk.micKey, data + 26, 16);
+								pWapiSta->wapiUsk.keyId = *(data + 42);
+								pWapiSta->wapiUsk.bTxEnable = false;
+							}
+						} else {
+							WAPI_TRACE(WAPI_INIT, "ASUE update usk\n");
+							if (bTxEnable) {
+								pWapiSta->wapiUskUpdate.bTxEnable = true;
+								if (pWapiSta->wapiUskUpdate.bSet) {
+									memcpy(pWapiSta->wapiUsk.dataKey, pWapiSta->wapiUskUpdate.dataKey, 16);
+									memcpy(pWapiSta->wapiUsk.micKey, pWapiSta->wapiUskUpdate.micKey, 16);
+									pWapiSta->wapiUsk.keyId = pWapiSta->wapiUskUpdate.keyId;
+									memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiASUEPNInitialValueSrc, 16);
+									memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiASUEPNInitialValueSrc, 16);
+									memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiASUEPNInitialValueSrc, 16);
+									memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiASUEPNInitialValueSrc, 16);
+									memcpy(pWapiSta->lastRxUnicastPN, WapiASUEPNInitialValueSrc, 16);
+									pWapiSta->wapiUskUpdate.bTxEnable = false;
+									pWapiSta->wapiUskUpdate.bSet = false;
+								}
+								memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
+							} else {
+								pWapiSta->wapiUskUpdate.bSet = true;
+								memcpy(pWapiSta->wapiUskUpdate.dataKey, data + 10, 16);
+								memcpy(pWapiSta->wapiUskUpdate.micKey, data + 26, 16);
+								pWapiSta->wapiUskUpdate.keyId = *(data + 42);
+								pWapiSta->wapiUskUpdate.bTxEnable = false;
+							}
+						}
+					}
+					break;
+				case 2:		/* msk */
+					if (bAuthenticator) {        /* authenticator */
+						pWapiInfo->wapiTxMsk.bSet = true;
+						memcpy(pWapiInfo->wapiTxMsk.dataKey, data + 10, 16);
+						memcpy(pWapiInfo->wapiTxMsk.micKey, data + 26, 16);
+						pWapiInfo->wapiTxMsk.keyId = *(data + 42);
+						pWapiInfo->wapiTxMsk.bTxEnable = true;
+						memcpy(pWapiInfo->lastTxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
+
+						if (!bUpdate) {    /* first */
+							WAPI_TRACE(WAPI_INIT, "AE fisrt set msk\n");
+							if (!pWapiSta->bSetkeyOk)
+								pWapiSta->bSetkeyOk = true;
+							pWapiInfo->bFirstAuthentiateInProgress = false;
+						} else                /* update */
+							WAPI_TRACE(WAPI_INIT, "AE update msk\n");
+
+						WAPI_DATA(WAPI_INIT, "SetKey - AE MSK Data Key", pWapiInfo->wapiTxMsk.dataKey, 16);
+						WAPI_DATA(WAPI_INIT, "SetKey - AE MSK Mic Key", pWapiInfo->wapiTxMsk.micKey, 16);
+					} else {
+						if (!bUpdate) {
+							WAPI_TRACE(WAPI_INIT, "ASUE fisrt set msk\n");
+							pWapiSta->wapiMsk.bSet = true;
+							memcpy(pWapiSta->wapiMsk.dataKey, data + 10, 16);
+							memcpy(pWapiSta->wapiMsk.micKey, data + 26, 16);
+							pWapiSta->wapiMsk.keyId = *(data + 42);
+							pWapiSta->wapiMsk.bTxEnable = false;
+							if (!pWapiSta->bSetkeyOk)
+								pWapiSta->bSetkeyOk = true;
+							pWapiInfo->bFirstAuthentiateInProgress = false;
+							WAPI_DATA(WAPI_INIT, "SetKey - ASUE MSK Data Key", pWapiSta->wapiMsk.dataKey, 16);
+							WAPI_DATA(WAPI_INIT, "SetKey - ASUE MSK Mic Key", pWapiSta->wapiMsk.micKey, 16);
+						} else {
+							WAPI_TRACE(WAPI_INIT, "ASUE update msk\n");
+							pWapiSta->wapiMskUpdate.bSet = true;
+							memcpy(pWapiSta->wapiMskUpdate.dataKey, data + 10, 16);
+							memcpy(pWapiSta->wapiMskUpdate.micKey, data + 26, 16);
+							pWapiSta->wapiMskUpdate.keyId = *(data + 42);
+							pWapiSta->wapiMskUpdate.bTxEnable = false;
+						}
+					}
+					break;
+				default:
+					WAPI_TRACE(WAPI_ERR, "Unknown Flag\n");
+					break;
+				}
+			}
+		}
+	}
+	WAPI_TRACE(WAPI_INIT, "<===========%s\n", __FUNCTION__);
+}
+
+
+void wapi_test_init(struct _adapter *padapter)
+{
+	u8 keybuf[100];
+	u8 mac_addr[6] = {0x00, 0xe0, 0x4c, 0x72, 0x04, 0x70};
+	u8 UskDataKey[16] = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f};
+	u8 UskMicKey[16] = {0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f};
+	u8 UskId = 0;
+	u8 MskDataKey[16] = {0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f};
+	u8 MskMicKey[16] = {0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f};
+	u8 MskId = 0;
+
+	WAPI_TRACE(WAPI_INIT, "===========>%s\n", __FUNCTION__);
+
+	/* Enable Wapi */
+	WAPI_TRACE(WAPI_INIT, "%s: Enable wapi!!!!\n", __FUNCTION__);
+	padapter->wapiInfo.bWapiEnable = true;
+	padapter->pairwise_key_type = KEY_TYPE_SMS4;
+	ieee->group_key_type = KEY_TYPE_SMS4;
+	padapter->wapiInfo.extra_prefix_len = WAPI_EXT_LEN;
+	padapter->wapiInfo.extra_postfix_len = SMS4_MIC_LEN;
+
+	/* set usk */
+	WAPI_TRACE(WAPI_INIT, "%s: Set USK!!!!\n", __FUNCTION__);
+	memset(keybuf, 0, 100);
+	keybuf[0] = 1;                           /* set usk */
+	keybuf[1] = 1; 				/* enable tx */
+	keybuf[2] = 1; 				/* AE */
+	keybuf[3] = 0; 				/* not update */
+
+	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 10, UskDataKey, 16);
+	memcpy(keybuf + 26, UskMicKey, 16);
+	keybuf[42] = UskId;
+	wapi_test_set_key(padapter, keybuf);
+
+	memset(keybuf, 0, 100);
+	keybuf[0] = 1;                           /* set usk */
+	keybuf[1] = 1; 				/* enable tx */
+	keybuf[2] = 0; 				/* AE */
+	keybuf[3] = 0; 				/* not update */
+
+	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 10, UskDataKey, 16);
+	memcpy(keybuf + 26, UskMicKey, 16);
+	keybuf[42] = UskId;
+	wapi_test_set_key(padapter, keybuf);
+
+	/* set msk */
+	WAPI_TRACE(WAPI_INIT, "%s: Set MSK!!!!\n", __FUNCTION__);
+	memset(keybuf, 0, 100);
+	keybuf[0] = 2;                                /* set msk */
+	keybuf[1] = 1;                               /* Enable TX */
+	keybuf[2] = 1; 				/* AE */
+	keybuf[3] = 0;                              /* not update */
+	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 10, MskDataKey, 16);
+	memcpy(keybuf + 26, MskMicKey, 16);
+	keybuf[42] = MskId;
+	wapi_test_set_key(padapter, keybuf);
+
+	memset(keybuf, 0, 100);
+	keybuf[0] = 2;                                /* set msk */
+	keybuf[1] = 1;                               /* Enable TX */
+	keybuf[2] = 0; 				/* AE */
+	keybuf[3] = 0;                              /* not update */
+	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 10, MskDataKey, 16);
+	memcpy(keybuf + 26, MskMicKey, 16);
+	keybuf[42] = MskId;
+	wapi_test_set_key(padapter, keybuf);
+	WAPI_TRACE(WAPI_INIT, "<===========%s\n", __FUNCTION__);
+}
+#endif
+
+void rtw_wapi_get_iv(_adapter *padapter, u8 *pRA, u8 *IV)
+{
+	PWLAN_HEADER_WAPI_EXTENSION pWapiExt = NULL;
+	PRT_WAPI_T         pWapiInfo = &padapter->wapiInfo;
+	bool	bPNOverflow = false;
+	bool	bFindMatchPeer = false;
+	PRT_WAPI_STA_INFO  pWapiSta = NULL;
+
+	pWapiExt = (PWLAN_HEADER_WAPI_EXTENSION)IV;
+
+	WAPI_DATA(WAPI_RX, "wapi_get_iv: pra", pRA, 6);
+
+	if (IS_MCAST(pRA)) {
+		if (!pWapiInfo->wapiTxMsk.bTxEnable) {
+			WAPI_TRACE(WAPI_ERR, "%s: bTxEnable = 0!!\n", __FUNCTION__);
+			return;
+		}
+
+		if (pWapiInfo->wapiTxMsk.keyId <= 1) {
+			pWapiExt->KeyIdx = pWapiInfo->wapiTxMsk.keyId;
+			pWapiExt->Reserved = 0;
+			bPNOverflow = WapiIncreasePN(pWapiInfo->lastTxMulticastPN, 1);
+			memcpy(pWapiExt->PN, pWapiInfo->lastTxMulticastPN, 16);
+		}
+	} else {
+		if (list_empty(&pWapiInfo->wapiSTAUsedList)) {
+			WAPI_TRACE(WAPI_RX, "rtw_wapi_get_iv: list is empty\n");
+			_rtw_memset(IV, 10, 18);
+			return;
+		} else {
+			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+				WAPI_DATA(WAPI_RX, "rtw_wapi_get_iv: peermacaddr ", pWapiSta->PeerMacAddr, 6);
+				if (_rtw_memcmp((u8 *)pWapiSta->PeerMacAddr, pRA, 6) == _TRUE) {
+					bFindMatchPeer = true;
+					break;
+				}
+			}
+
+			WAPI_TRACE(WAPI_RX, "bFindMatchPeer: %d\n", bFindMatchPeer);
+			WAPI_DATA(WAPI_RX, "Addr", pRA, 6);
+
+			if (bFindMatchPeer) {
+				if ((!pWapiSta->wapiUskUpdate.bTxEnable) && (!pWapiSta->wapiUsk.bTxEnable))
+					return;
+
+				if (pWapiSta->wapiUsk.keyId <= 1) {
+					if (pWapiSta->wapiUskUpdate.bTxEnable)
+						pWapiExt->KeyIdx = pWapiSta->wapiUskUpdate.keyId;
+					else
+						pWapiExt->KeyIdx = pWapiSta->wapiUsk.keyId;
+
+					pWapiExt->Reserved = 0;
+					bPNOverflow = WapiIncreasePN(pWapiSta->lastTxUnicastPN, 2);
+					_rtw_memcpy(pWapiExt->PN, pWapiSta->lastTxUnicastPN, 16);
+
+				}
+			}
+		}
+
+	}
+
+}
+
+bool rtw_wapi_drop_for_key_absent(_adapter *padapter, u8 *pRA)
+{
+	PRT_WAPI_T         pWapiInfo = &padapter->wapiInfo;
+	bool				bFindMatchPeer = false;
+	bool				bDrop = false;
+	PRT_WAPI_STA_INFO  pWapiSta = NULL;
+	struct security_priv		*psecuritypriv = &padapter->securitypriv;
+
+	WAPI_DATA(WAPI_RX, "rtw_wapi_drop_for_key_absent: ra ", pRA, 6);
+
+	if (psecuritypriv->dot11PrivacyAlgrthm == _SMS4_) {
+		if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
+			return true;
+
+		if (IS_MCAST(pRA)) {
+			if (!pWapiInfo->wapiTxMsk.bTxEnable) {
+				bDrop = true;
+				WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: multicast key is absent\n");
+				return bDrop;
+			}
+		} else {
+			if (!list_empty(&pWapiInfo->wapiSTAUsedList)) {
+				list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+					WAPI_DATA(WAPI_RX, "rtw_wapi_drop_for_key_absent: pWapiSta->PeerMacAddr ", pWapiSta->PeerMacAddr, 6);
+					if (_rtw_memcmp(pRA, pWapiSta->PeerMacAddr, 6) == _TRUE) {
+						bFindMatchPeer = true;
+						break;
+					}
+				}
+				if (bFindMatchPeer)	{
+					if (!pWapiSta->wapiUsk.bTxEnable) {
+						bDrop = true;
+						WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: unicast key is absent\n");
+						return bDrop;
+					}
+				} else {
+					bDrop = true;
+					WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: no peer find\n");
+					return bDrop;
+				}
+
+			} else {
+				bDrop = true;
+				WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: no sta  exist\n");
+				return bDrop;
+			}
+		}
+	} else
+		return bDrop;
+
+	return bDrop;
+}
+
+void rtw_wapi_set_set_encryption(_adapter *padapter, struct ieee_param *param)
+{
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
+	PRT_WAPI_STA_INFO	pWapiSta;
+	u8					WapiASUEPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+
+	if (param->u.crypt.set_tx == 1) {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (_rtw_memcmp(pWapiSta->PeerMacAddr, param->sta_addr, 6)) {
+				_rtw_memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
+
+				pWapiSta->wapiUsk.bSet = true;
+				_rtw_memcpy(pWapiSta->wapiUsk.dataKey, param->u.crypt.key, 16);
+				_rtw_memcpy(pWapiSta->wapiUsk.micKey, param->u.crypt.key + 16, 16);
+				pWapiSta->wapiUsk.keyId = param->u.crypt.idx ;
+				pWapiSta->wapiUsk.bTxEnable = true;
+
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
+				pWapiSta->wapiUskUpdate.bTxEnable = false;
+				pWapiSta->wapiUskUpdate.bSet = false;
+
+				if (psecuritypriv->sw_encrypt == false || psecuritypriv->sw_decrypt == false) {
+					/* set unicast key for ASUE */
+					rtw_wapi_set_key(padapter, &pWapiSta->wapiUsk, pWapiSta, false, false);
+				}
+			}
+		}
+	} else {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (_rtw_memcmp(pWapiSta->PeerMacAddr, get_bssid(pmlmepriv), 6)) {
+				pWapiSta->wapiMsk.bSet = true;
+				_rtw_memcpy(pWapiSta->wapiMsk.dataKey, param->u.crypt.key, 16);
+				_rtw_memcpy(pWapiSta->wapiMsk.micKey, param->u.crypt.key + 16, 16);
+				pWapiSta->wapiMsk.keyId = param->u.crypt.idx ;
+				pWapiSta->wapiMsk.bTxEnable = false;
+				if (!pWapiSta->bSetkeyOk)
+					pWapiSta->bSetkeyOk = true;
+				pWapiSta->bAuthenticateInProgress = false;
+
+				_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
+
+				if (psecuritypriv->sw_decrypt == false) {
+					/* set rx broadcast key for ASUE */
+					rtw_wapi_set_key(padapter, &pWapiSta->wapiMsk, pWapiSta, true, false);
+				}
+			}
+		}
+	}
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi_sms4.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi_sms4.c
index 75f10ab4752e..5eaa5be44c91 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi_sms4.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wapi_sms4.c
@@ -1,924 +1,923 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifdef CONFIG_WAPI_SUPPORT
-
-#include <linux/unistd.h>
-#include <linux/etherdevice.h>
-#include <drv_types.h>
-#include <rtw_wapi.h>
-
-
-#ifdef CONFIG_WAPI_SW_SMS4
-
-#define WAPI_LITTLE_ENDIAN
-//#define BIG_ENDIAN
-#define ENCRYPT  0
-#define DECRYPT  1
-
-
-/**********************************************************
- **********************************************************/
-const u8 Sbox[256] = {
-0xd6,0x90,0xe9,0xfe,0xcc,0xe1,0x3d,0xb7,0x16,0xb6,0x14,0xc2,0x28,0xfb,0x2c,0x05,
-0x2b,0x67,0x9a,0x76,0x2a,0xbe,0x04,0xc3,0xaa,0x44,0x13,0x26,0x49,0x86,0x06,0x99,
-0x9c,0x42,0x50,0xf4,0x91,0xef,0x98,0x7a,0x33,0x54,0x0b,0x43,0xed,0xcf,0xac,0x62,
-0xe4,0xb3,0x1c,0xa9,0xc9,0x08,0xe8,0x95,0x80,0xdf,0x94,0xfa,0x75,0x8f,0x3f,0xa6,
-0x47,0x07,0xa7,0xfc,0xf3,0x73,0x17,0xba,0x83,0x59,0x3c,0x19,0xe6,0x85,0x4f,0xa8,
-0x68,0x6b,0x81,0xb2,0x71,0x64,0xda,0x8b,0xf8,0xeb,0x0f,0x4b,0x70,0x56,0x9d,0x35,
-0x1e,0x24,0x0e,0x5e,0x63,0x58,0xd1,0xa2,0x25,0x22,0x7c,0x3b,0x01,0x21,0x78,0x87,
-0xd4,0x00,0x46,0x57,0x9f,0xd3,0x27,0x52,0x4c,0x36,0x02,0xe7,0xa0,0xc4,0xc8,0x9e,
-0xea,0xbf,0x8a,0xd2,0x40,0xc7,0x38,0xb5,0xa3,0xf7,0xf2,0xce,0xf9,0x61,0x15,0xa1,
-0xe0,0xae,0x5d,0xa4,0x9b,0x34,0x1a,0x55,0xad,0x93,0x32,0x30,0xf5,0x8c,0xb1,0xe3,
-0x1d,0xf6,0xe2,0x2e,0x82,0x66,0xca,0x60,0xc0,0x29,0x23,0xab,0x0d,0x53,0x4e,0x6f,
-0xd5,0xdb,0x37,0x45,0xde,0xfd,0x8e,0x2f,0x03,0xff,0x6a,0x72,0x6d,0x6c,0x5b,0x51,
-0x8d,0x1b,0xaf,0x92,0xbb,0xdd,0xbc,0x7f,0x11,0xd9,0x5c,0x41,0x1f,0x10,0x5a,0xd8,
-0x0a,0xc1,0x31,0x88,0xa5,0xcd,0x7b,0xbd,0x2d,0x74,0xd0,0x12,0xb8,0xe5,0xb4,0xb0,
-0x89,0x69,0x97,0x4a,0x0c,0x96,0x77,0x7e,0x65,0xb9,0xf1,0x09,0xc5,0x6e,0xc6,0x84,
-0x18,0xf0,0x7d,0xec,0x3a,0xdc,0x4d,0x20,0x79,0xee,0x5f,0x3e,0xd7,0xcb,0x39,0x48
-};
-
-const u32 CK[32] = {
-	0x00070e15, 0x1c232a31, 0x383f464d, 0x545b6269,
-	0x70777e85, 0x8c939aa1, 0xa8afb6bd, 0xc4cbd2d9,
-	0xe0e7eef5, 0xfc030a11, 0x181f262d, 0x343b4249,
-	0x50575e65, 0x6c737a81, 0x888f969d, 0xa4abb2b9,
-	0xc0c7ced5, 0xdce3eaf1, 0xf8ff060d, 0x141b2229,
-	0x30373e45, 0x4c535a61, 0x686f767d, 0x848b9299,
-	0xa0a7aeb5, 0xbcc3cad1, 0xd8dfe6ed, 0xf4fb0209,
-	0x10171e25, 0x2c333a41, 0x484f565d, 0x646b7279 };
-
-#define Rotl(_x, _y) (((_x) << (_y)) | ((_x) >> (32 - (_y))))
-
-#define ByteSub(_A) (Sbox[(_A) >> 24 & 0xFF] << 24 | \
-                     Sbox[(_A) >> 16 & 0xFF] << 16 | \
-                     Sbox[(_A) >>  8 & 0xFF] <<  8 | \
-                     Sbox[(_A) & 0xFF])
-
-#define L1(_B) ((_B) ^ Rotl(_B, 2) ^ Rotl(_B, 10) ^ Rotl(_B, 18) ^ Rotl(_B, 24))
-#define L2(_B) ((_B) ^ Rotl(_B, 13) ^ Rotl(_B, 23))
-
-static void
-xor_block(void *dst, void *src1, void *src2)
-/* 128-bit xor: *dst = *src1 xor *src2. Pointers must be 32-bit aligned  */
-{
-    ((u32 *)dst)[0] = ((u32 *)src1)[0] ^ ((u32 *)src2)[0];
-    ((u32 *)dst)[1] = ((u32 *)src1)[1] ^ ((u32 *)src2)[1];
-    ((u32 *)dst)[2] = ((u32 *)src1)[2] ^ ((u32 *)src2)[2];
-    ((u32 *)dst)[3] = ((u32 *)src1)[3] ^ ((u32 *)src2)[3];
-}
-
-
-void SMS4Crypt(u8 *Input, u8 *Output, u32 *rk)
-{
-	 u32 r, mid, x0, x1, x2, x3, *p;
-	 p = (u32 *)Input;
-	 x0 = p[0];
-	 x1 = p[1];
-	 x2 = p[2];
-	 x3 = p[3];
-#ifdef WAPI_LITTLE_ENDIAN
-	 x0 = Rotl(x0, 16); x0 = ((x0 & 0x00FF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
-	 x1 = Rotl(x1, 16); x1 = ((x1 & 0x00FF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
-	 x2 = Rotl(x2, 16); x2 = ((x2 & 0x00FF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
-	 x3 = Rotl(x3, 16); x3 = ((x3 & 0x00FF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
-#endif
-	 for (r = 0; r < 32; r += 4)
-	 {
-		  mid = x1 ^ x2 ^ x3 ^ rk[r + 0];
-		  mid = ByteSub(mid);
-		  x0 ^= L1(mid);
-		  mid = x2 ^ x3 ^ x0 ^ rk[r + 1];
-		  mid = ByteSub(mid);
-		  x1 ^= L1(mid);
-		  mid = x3 ^ x0 ^ x1 ^ rk[r + 2];
-		  mid = ByteSub(mid);
-		  x2 ^= L1(mid);
-		  mid = x0 ^ x1 ^ x2 ^ rk[r + 3];
-		  mid = ByteSub(mid);
-		  x3 ^= L1(mid);
-	 }
-#ifdef WAPI_LITTLE_ENDIAN
-	 x0 = Rotl(x0, 16); x0 = ((x0 & 0x00FF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
-	 x1 = Rotl(x1, 16); x1 = ((x1 & 0x00FF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
-	 x2 = Rotl(x2, 16); x2 = ((x2 & 0x00FF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
-	 x3 = Rotl(x3, 16); x3 = ((x3 & 0x00FF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
-#endif
-	 p = (u32 *)Output;
-	 p[0] = x3;
-	 p[1] = x2;
-	 p[2] = x1;
-	 p[3] = x0;
-}
-
-
-
-void SMS4KeyExt(u8 *Key, u32 *rk, u32 CryptFlag)
-{
-	 u32 r, mid, x0, x1, x2, x3, *p;
-
-	 p = (u32 *)Key;
-	 x0 = p[0];
-	 x1 = p[1];
-	 x2 = p[2];
-	 x3 = p[3];
-#ifdef WAPI_LITTLE_ENDIAN
-	 x0 = Rotl(x0, 16); x0 = ((x0 & 0xFF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
-	 x1 = Rotl(x1, 16); x1 = ((x1 & 0xFF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
-	 x2 = Rotl(x2, 16); x2 = ((x2 & 0xFF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
-	 x3 = Rotl(x3, 16); x3 = ((x3 & 0xFF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
-#endif
-
-	 x0 ^= 0xa3b1bac6;
-	 x1 ^= 0x56aa3350;
-	 x2 ^= 0x677d9197;
-	 x3 ^= 0xb27022dc;
-	 for (r = 0; r < 32; r += 4)
-	 {
-		  mid = x1 ^ x2 ^ x3 ^ CK[r + 0];
-		  mid = ByteSub(mid);
-		  rk[r + 0] = x0 ^= L2(mid);
-		  mid = x2 ^ x3 ^ x0 ^ CK[r + 1];
-		  mid = ByteSub(mid);
-		  rk[r + 1] = x1 ^= L2(mid);
-		  mid = x3 ^ x0 ^ x1 ^ CK[r + 2];
-		  mid = ByteSub(mid);
-		  rk[r + 2] = x2 ^= L2(mid);
-		  mid = x0 ^ x1 ^ x2 ^ CK[r + 3];
-		  mid = ByteSub(mid);
-		  rk[r + 3] = x3 ^= L2(mid);
-	 }
-	 if (CryptFlag == DECRYPT)
-	 {
-	 	  for (r = 0; r < 16; r++)
-	 	  	 mid = rk[r], rk[r] = rk[31 - r], rk[31 - r] = mid;
-	 }
-}
-
-
-void WapiSMS4Cryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
-                                                u8 *Output, u16 *OutputLength, u32 CryptFlag)
-{
-	u32 blockNum,i,j, rk[32];
-	u16 remainder;
-	u8 blockIn[16],blockOut[16], tempIV[16], k;
-
-	*OutputLength = 0;
-	remainder = InputLength & 0x0F;
-	blockNum = InputLength >> 4;
-	if(remainder !=0)
-		blockNum++;
-	else
-		remainder = 16;
-
-	for(k=0;k<16;k++)
-		tempIV[k] = IV[15-k];
-
-	memcpy(blockIn, tempIV, 16);
-
-      SMS4KeyExt((u8 *)Key, rk,CryptFlag);
-
-	for(i=0; i<blockNum-1; i++)
-	{
-		SMS4Crypt((u8 *)blockIn, blockOut, rk);
-             xor_block(&Output[i*16], &Input[i*16], blockOut);
-		memcpy(blockIn,blockOut,16);
-	}
-
-	*OutputLength = i*16;
-
-	SMS4Crypt((u8 *)blockIn, blockOut, rk);
-
-	for(j=0; j<remainder; j++)
-	{
-		Output[i*16+j] = Input[i*16+j] ^ blockOut[j];
-	}
-      *OutputLength += remainder;
-
-}
-
-void WapiSMS4Encryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
-                                                    u8 *Output, u16 *OutputLength)
-{
-
-	WapiSMS4Cryption(Key, IV, Input, InputLength, Output, OutputLength, ENCRYPT);
-}
-
-void WapiSMS4Decryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
-                                                    u8 *Output, u16 *OutputLength)
-{
-	// OFB mode: is also ENCRYPT flag
-	WapiSMS4Cryption(Key, IV, Input, InputLength, Output, OutputLength, ENCRYPT);
-}
-
-void WapiSMS4CalculateMic(u8 *Key, u8 *IV, u8 *Input1, u8 Input1Length,
-                                                 u8 *Input2, u16 Input2Length, u8 *Output, u8 *OutputLength)
-{
-	u32 blockNum, i, remainder, rk[32];
-	u8 BlockIn[16], BlockOut[16], TempBlock[16], tempIV[16], k;
-
-	*OutputLength = 0;
-	remainder = Input1Length & 0x0F;
-	blockNum = Input1Length >> 4;
-
-	for(k=0;k<16;k++)
-		tempIV[k] = IV[15-k];
-
-	memcpy(BlockIn, tempIV, 16);
-
-	SMS4KeyExt((u8 *)Key, rk, ENCRYPT);
-
-	SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
-
-	for(i=0; i<blockNum; i++){
-		xor_block(BlockIn, (Input1+i*16), BlockOut);
-		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
-	}
-
-	if(remainder !=0){
-		memset(TempBlock, 0, 16);
-		memcpy(TempBlock, (Input1+blockNum*16), remainder);
-
-		xor_block(BlockIn, TempBlock, BlockOut);
-		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
-      }
-
-	remainder = Input2Length & 0x0F;
-	blockNum = Input2Length >> 4;
-
-  	for(i=0; i<blockNum; i++){
-		xor_block(BlockIn, (Input2+i*16), BlockOut);
-		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
-	}
-
-	if(remainder !=0){
-		memset(TempBlock, 0, 16);
-		memcpy(TempBlock, (Input2+blockNum*16), remainder);
-
-		xor_block(BlockIn, TempBlock, BlockOut);
-		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
-	}
-
-	memcpy(Output, BlockOut, 16);
-	*OutputLength = 16;
-}
-
-void SecCalculateMicSMS4(
-	u8		KeyIdx,
-	u8        *MicKey,
-	u8        *pHeader,
-	u8        *pData,
-	u16       DataLen,
-	u8        *MicBuffer
-	)
-{
-#if 0
-	struct ieee80211_hdr_3addr_qos *header;
-	u8 TempBuf[34], TempLen = 32, MicLen, QosOffset, *IV;
-	u16 *pTemp, fc;
-
-	WAPI_TRACE(WAPI_TX|WAPI_RX, "=========>%s\n", __FUNCTION__);
-
-	header = (struct ieee80211_hdr_3addr_qos *)pHeader;
-	memset(TempBuf, 0, 34);
-	memcpy(TempBuf, pHeader, 2); //FrameCtrl
-	pTemp = (u16*)TempBuf;
-	*pTemp &= 0xc78f;       //bit4,5,6,11,12,13
-
-	memcpy((TempBuf+2), (pHeader+4), 12); //Addr1, Addr2
-	memcpy((TempBuf+14), (pHeader+22), 2); // SeqCtrl
-	pTemp = (u16*)(TempBuf + 14);
-	*pTemp &= 0x000f;
-
-	memcpy((TempBuf+16), (pHeader+16), 6); //Addr3
-
-	fc = le16_to_cpu(header->frame_ctl);
-
-
-
-	if (GetFrDs((u16*)&fc) && GetToDs((u16 *)&fc))
-	{
-		memcpy((TempBuf+22), (pHeader+24), 6);
-		QosOffset = 30;
-	}else{
-		memset((TempBuf+22), 0, 6);
-		QosOffset = 24;
-	}
-
-	if((fc & 0x0088) == 0x0088){
-		memcpy((TempBuf+28), (pHeader+QosOffset), 2);
-		TempLen += 2;
-		//IV = pHeader + QosOffset + 2 + SNAP_SIZE + sizeof(u16) + 2;
-		IV = pHeader + QosOffset + 2 + 2;
-	}else{
-		IV = pHeader + QosOffset + 2;
-		//IV = pHeader + QosOffset + SNAP_SIZE + sizeof(u16) + 2;
-	}
-
-	TempBuf[TempLen-1] = (u8)(DataLen & 0xff);
-	TempBuf[TempLen-2] = (u8)((DataLen & 0xff00)>>8);
-	TempBuf[TempLen-4] = KeyIdx;
-
-	WAPI_DATA(WAPI_TX, "CalculateMic - KEY", MicKey, 16);
-	WAPI_DATA(WAPI_TX, "CalculateMic - IV", IV, 16);
-	WAPI_DATA(WAPI_TX, "CalculateMic - TempBuf", TempBuf, TempLen);
-	WAPI_DATA(WAPI_TX, "CalculateMic - pData", pData, DataLen);
-
-	WapiSMS4CalculateMic(MicKey, IV, TempBuf, TempLen,
-	                                             pData, DataLen, MicBuffer, &MicLen);
-
-	if (MicLen != 16)
-		WAPI_TRACE(WAPI_ERR,"%s: MIC Length Error!!\n",__FUNCTION__);
-
-	WAPI_TRACE(WAPI_TX|WAPI_RX, "<=========%s\n", __FUNCTION__);
-#endif
-}
-
-/* AddCount: 1 or 2.
- *  If overflow, return 1,
- *  else return 0.
- */
-u8 WapiIncreasePN(u8 *PN, u8 AddCount)
-{
-	u8  i;
-
-	if (NULL == PN)
-		return 1;
-	//YJ,test,091102
-	/*
-	if(AddCount == 2){
-		DBG_8192C("############################%s(): PN[0]=0x%x\n", __FUNCTION__, PN[0]);
-		if(PN[0] == 0x48){
-			PN[0] += AddCount;
-			return 1;
-		}else{
-			PN[0] += AddCount;
-			return 0;
-		}
-	}
-	*/
-	//YJ,test,091102,end
-
-	for (i=0; i<16; i++)
-	{
-		if (PN[i] + AddCount <= 0xff)
-		{
-			PN[i] += AddCount;
-			return 0;
-		}
-		else
-		{
-			PN[i] += AddCount;
-			AddCount = 1;
-		}
-	}
-	return 1;
-}
-
-
-void WapiGetLastRxUnicastPNForQoSData(
-	u8 			UserPriority,
-	PRT_WAPI_STA_INFO    pWapiStaInfo,
-	u8 *PNOut
-)
-{
-	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
-	switch(UserPriority)
-	{
-		case 0:
-		case 3:
-			      memcpy(PNOut,pWapiStaInfo->lastRxUnicastPNBEQueue,16);
-			      break;
-		case 1:
-		case 2:
-			      memcpy(PNOut,pWapiStaInfo->lastRxUnicastPNBKQueue,16);
-			      break;
-		case 4:
-		case 5:
-			      memcpy(PNOut,pWapiStaInfo->lastRxUnicastPNVIQueue,16);
-			      break;
-		case 6:
-		case 7:
-			      memcpy(PNOut,pWapiStaInfo->lastRxUnicastPNVOQueue,16);
-			      break;
-		default:
-				WAPI_TRACE(WAPI_ERR, "%s: Unknown TID \n", __FUNCTION__);
-				break;
-	}
-	WAPI_TRACE(WAPI_RX, "<=========== %s\n", __FUNCTION__);
-}
-
-
-void WapiSetLastRxUnicastPNForQoSData(
-	u8 		UserPriority,
-	u8           *PNIn,
-	PRT_WAPI_STA_INFO    pWapiStaInfo
-)
-{
-	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
-	switch(UserPriority)
-	{
-		case 0:
-		case 3:
-			      memcpy(pWapiStaInfo->lastRxUnicastPNBEQueue,PNIn,16);
-			      break;
-		case 1:
-		case 2:
-			      memcpy(pWapiStaInfo->lastRxUnicastPNBKQueue,PNIn,16);
-			      break;
-		case 4:
-		case 5:
-			      memcpy(pWapiStaInfo->lastRxUnicastPNVIQueue,PNIn,16);
-			      break;
-		case 6:
-		case 7:
-			      memcpy(pWapiStaInfo->lastRxUnicastPNVOQueue,PNIn,16);
-			      break;
-		default:
-				WAPI_TRACE(WAPI_ERR, "%s: Unknown TID \n", __FUNCTION__);
-				break;
-	}
-	WAPI_TRACE(WAPI_RX, "<=========== %s\n", __FUNCTION__);
-}
-
-
-/****************************************************************************
- FALSE not RX-Reorder
- TRUE do RX Reorder
-add to support WAPI to N-mode
-*****************************************************************************/
-u8 WapiCheckPnInSwDecrypt(
-	_adapter *padapter,
-	struct sk_buff *pskb
-)
-{
-	u8 				ret = false;
-
-#if 0
-	struct ieee80211_hdr_3addr_qos *header;
-	u16 				fc;
-	u8				*pDaddr, *pTaddr, *pRaddr;
-
-	header = (struct ieee80211_hdr_3addr_qos *)pskb->data;
-	pTaddr = header->addr2;
-	pRaddr = header->addr1;
-	fc = le16_to_cpu(header->frame_ctl);
-
-	if(GetToDs(&fc))
-		pDaddr = header->addr3;
-	else
-		pDaddr = header->addr1;
-
-	if ((_rtw_memcmp(pRaddr, padapter->pnetdev->dev_addr, ETH_ALEN) == 0)
-		&&	! (pDaddr)
-		&& (GetFrameType(&fc) == WIFI_QOS_DATA_TYPE))
-		//&& ieee->pHTInfo->bCurrentHTSupport &&
-		//ieee->pHTInfo->bCurRxReorderEnable)
-		ret = false;
-	else
-		ret = true;
-#endif
-	WAPI_TRACE(WAPI_RX, "%s: return %d\n", __FUNCTION__, ret);
-	return ret;
-}
-
-int SecSMS4HeaderFillIV(_adapter *padapter, u8 *pxmitframe)
-{
-	struct pkt_attrib *pattrib = &((struct xmit_frame*)pxmitframe)->attrib;
-	u8 * frame = ((struct xmit_frame *)pxmitframe)->buf_addr + TXDESC_OFFSET;
-	u8 *pSecHeader = NULL, *pos = NULL, *pRA = NULL;
-	u8 bPNOverflow = false, bFindMatchPeer = false, hdr_len = 0;
-	PWLAN_HEADER_WAPI_EXTENSION pWapiExt = NULL;
-	PRT_WAPI_T         pWapiInfo = &padapter->wapiInfo;
-	PRT_WAPI_STA_INFO  pWapiSta = NULL;
-	int ret = 0;
-
-	WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
-
-	return ret;
-#if 0
-	hdr_len = sMacHdrLng;
-	if (GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE)
-	{
-		hdr_len += 2;
-	}
-	//hdr_len += SNAP_SIZE + sizeof(u16);
-
-	pos = skb_push(pskb, padapter->wapiInfo.extra_prefix_len);
-	memmove(pos, pos+padapter->wapiInfo.extra_prefix_len, hdr_len);
-
-	pSecHeader = pskb->data + hdr_len;
-	pWapiExt = (PWLAN_HEADER_WAPI_EXTENSION)pSecHeader;
-	pRA = pskb->data + 4;
-
-	WAPI_DATA(WAPI_TX, "FillIV - Before Fill IV", pskb->data, pskb->len);
-
-	//Address 1 is always receiver's address
-	if( IS_MCAST(pRA) ){
-		if(!pWapiInfo->wapiTxMsk.bTxEnable){
-			WAPI_TRACE(WAPI_ERR,"%s: bTxEnable = 0!!\n",__FUNCTION__);
-			return -2;
-		}
-		if(pWapiInfo->wapiTxMsk.keyId <= 1){
-			pWapiExt->KeyIdx = pWapiInfo->wapiTxMsk.keyId;
-			pWapiExt->Reserved = 0;
-			bPNOverflow = WapiIncreasePN(pWapiInfo->lastTxMulticastPN, 1);
-			memcpy(pWapiExt->PN, pWapiInfo->lastTxMulticastPN, 16);
-			if (bPNOverflow){
-				// Update MSK Notification.
-				WAPI_TRACE(WAPI_ERR,"===============>%s():multicast PN overflow\n",__FUNCTION__);
-				rtw_wapi_app_event_handler(padapter,NULL,0,pRA, false, false, true, 0, false);
-			}
-		}else{
-			WAPI_TRACE(WAPI_ERR,"%s: Invalid Wapi Multicast KeyIdx!!\n",__FUNCTION__);
-			ret = -3;
-		}
-	}
-    	else{
-		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-			if(!memcmp(pWapiSta->PeerMacAddr,pRA,6)){
-    				bFindMatchPeer = true;
-				break;
-			}
-		}
-		if (bFindMatchPeer){
-			if((!pWapiSta->wapiUskUpdate.bTxEnable) && (!pWapiSta->wapiUsk.bTxEnable)){
-				WAPI_TRACE(WAPI_ERR,"%s: bTxEnable = 0!!\n",__FUNCTION__);
-				return -4;
-			}
-			if (pWapiSta->wapiUsk.keyId <= 1){
-				if(pWapiSta->wapiUskUpdate.bTxEnable)
-					pWapiExt->KeyIdx = pWapiSta->wapiUskUpdate.keyId;
-				else
-					pWapiExt->KeyIdx = pWapiSta->wapiUsk.keyId;
-
-				pWapiExt->Reserved = 0;
-				bPNOverflow = WapiIncreasePN(pWapiSta->lastTxUnicastPN, 2);
-				memcpy(pWapiExt->PN, pWapiSta->lastTxUnicastPN, 16);
-				if (bPNOverflow){
-					// Update USK Notification.
-					WAPI_TRACE(WAPI_ERR,"===============>%s():unicast PN overflow\n",__FUNCTION__);
-					rtw_wapi_app_event_handler(padapter,NULL,0,pWapiSta->PeerMacAddr, false, true, false, 0, false);
-				}
-			}else{
-				WAPI_TRACE(WAPI_ERR,"%s: Invalid Wapi Unicast KeyIdx!!\n",__FUNCTION__);
-				ret = -5;
-			}
-		}
-		else{
-			WAPI_TRACE(WAPI_ERR,"%s: Can not find Peer Sta "MAC_FMT"!!\n",__FUNCTION__, MAC_ARG(pRA));
-			ret = -6;
-		}
-    	}
-
-	WAPI_DATA(WAPI_TX, "FillIV - After Fill IV", pskb->data, pskb->len);
-	WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
-	return ret;
-#endif
-}
-
-// WAPI SW Enc: must have done Coalesce!
-void SecSWSMS4Encryption(
-	_adapter *padapter,
-	u8 * pxmitframe
-	)
-{
-	PRT_WAPI_T		pWapiInfo = &padapter->wapiInfo;
-	PRT_WAPI_STA_INFO   pWapiSta = NULL;
-	u8 *pframe = ((struct xmit_frame*)pxmitframe)->buf_addr + TXDESC_SIZE;
-	struct pkt_attrib *pattrib = &((struct xmit_frame*)pxmitframe)->attrib;
-
-	u8 *SecPtr = NULL, *pRA, *pMicKey = NULL, *pDataKey = NULL, *pIV = NULL;
-	u8 IVOffset, DataOffset, bFindMatchPeer = false, KeyIdx = 0, MicBuffer[16];
-	u16 OutputLength;
-
-	WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
-
-	WAPI_TRACE(WAPI_TX,"hdrlen: %d \n",pattrib->hdrlen);
-
-	return;
-
-	DataOffset = pattrib->hdrlen + pattrib->iv_len;
-
-	pRA = pframe + 4;
-
-
-	if( IS_MCAST(pRA) ){
-		KeyIdx = pWapiInfo->wapiTxMsk.keyId;
-		pIV = pWapiInfo->lastTxMulticastPN;
-		pMicKey = pWapiInfo->wapiTxMsk.micKey;
-		pDataKey = pWapiInfo->wapiTxMsk.dataKey;
-	}else{
-		if (!list_empty(&(pWapiInfo->wapiSTAUsedList))){
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if (0 == memcmp(pWapiSta->PeerMacAddr, pRA, 6)){
-					bFindMatchPeer = true;
-					break;
-				}
-			}
-
-			if (bFindMatchPeer){
-				if (pWapiSta->wapiUskUpdate.bTxEnable){
-					KeyIdx = pWapiSta->wapiUskUpdate.keyId;
-					WAPI_TRACE(WAPI_TX, "%s(): Use update USK!! KeyIdx=%d\n", __FUNCTION__, KeyIdx);
-					pIV = pWapiSta->lastTxUnicastPN;
-					pMicKey = pWapiSta->wapiUskUpdate.micKey;
-					pDataKey = pWapiSta->wapiUskUpdate.dataKey;
-				}else{
-					KeyIdx = pWapiSta->wapiUsk.keyId;
-					WAPI_TRACE(WAPI_TX, "%s(): Use USK!! KeyIdx=%d\n", __FUNCTION__, KeyIdx);
-					pIV = pWapiSta->lastTxUnicastPN;
-					pMicKey = pWapiSta->wapiUsk.micKey;
-					pDataKey = pWapiSta->wapiUsk.dataKey;
-				}
-  			}else{
-				WAPI_TRACE(WAPI_ERR,"%s: Can not find Peer Sta!!\n",__FUNCTION__);
-				return;
-			}
-		}else{
-			WAPI_TRACE(WAPI_ERR,"%s: wapiSTAUsedList is empty!!\n",__FUNCTION__);
-			return;
-		}
-	}
-
-	SecPtr = pframe;
-	SecCalculateMicSMS4(KeyIdx, pMicKey, SecPtr, (SecPtr+DataOffset), pattrib->pktlen, MicBuffer);
-
-	WAPI_DATA(WAPI_TX, "Encryption - MIC", MicBuffer, padapter->wapiInfo.extra_postfix_len);
-
-	memcpy(pframe+pattrib->hdrlen+pattrib->iv_len+pattrib->pktlen-pattrib->icv_len,
-			(u8 *)MicBuffer,
-			padapter->wapiInfo.extra_postfix_len
-			);
-
-
-	WapiSMS4Encryption(pDataKey, pIV, (SecPtr+DataOffset),pattrib->pktlen+pattrib->icv_len, (SecPtr+DataOffset), &OutputLength);
-
-	WAPI_DATA(WAPI_TX, "Encryption - After SMS4 encryption",pframe,pattrib->hdrlen+pattrib->iv_len+pattrib->pktlen);
-
-	WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
-}
-
-u8 SecSWSMS4Decryption(
-	_adapter *padapter,
-	u8 		*precv_frame,
-	struct recv_priv *precv_priv
-	)
-{
-	PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
-	struct recv_frame_hdr *precv_hdr;
-	PRT_WAPI_STA_INFO   pWapiSta = NULL;
-	u8 IVOffset, DataOffset, bFindMatchPeer = false, bUseUpdatedKey = false;
-	u8 KeyIdx, MicBuffer[16], lastRxPNforQoS[16];
-	u8 *pRA, *pTA, *pMicKey, *pDataKey, *pLastRxPN, *pRecvPN, *pSecData, *pRecvMic, *pos;
-	u8 TID = 0;
-	u16 OutputLength, DataLen;
-	u8   bQosData;
-	struct sk_buff * 	pskb;
-
-	WAPI_TRACE(WAPI_RX, "=========>%s\n", __FUNCTION__);
-
-	return 0;
-
-	precv_hdr = &((union recv_frame*)precv_frame)->u.hdr;
-	pskb = (struct sk_buff *)(precv_hdr->rx_data);
-	precv_hdr->bWapiCheckPNInDecrypt = WapiCheckPnInSwDecrypt(padapter, pskb);
-	WAPI_TRACE(WAPI_RX, "=========>%s: check PN  %d\n", __FUNCTION__,precv_hdr->bWapiCheckPNInDecrypt);
-	WAPI_DATA(WAPI_RX, "Decryption - Before decryption", pskb->data, pskb->len);
-
-	IVOffset = sMacHdrLng;
-	bQosData = GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE;
-	if (bQosData){
-		IVOffset += 2;
-	}
-
-	//if(GetHTC())
-	//	IVOffset += 4;
-
-	//IVOffset += SNAP_SIZE + sizeof(u16);
-
-	DataOffset = IVOffset + padapter->wapiInfo.extra_prefix_len;
-
-	pRA = pskb->data + 4;
-	pTA = pskb->data + 10;
-	KeyIdx = *(pskb->data + IVOffset);
-	pRecvPN = pskb->data + IVOffset + 2;
-	pSecData = pskb->data + DataOffset;
-	DataLen = pskb->len - DataOffset;
-	pRecvMic = pskb->data + pskb->len - padapter->wapiInfo.extra_postfix_len;
-	TID = GetTid(pskb->data);
-
-	if (!list_empty(&(pWapiInfo->wapiSTAUsedList))){
-		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-			if (0 == memcmp(pWapiSta->PeerMacAddr, pTA, 6)){
-				bFindMatchPeer = true;
-				break;
-			}
-		}
-	}
-
-	if (!bFindMatchPeer){
-		WAPI_TRACE(WAPI_ERR, "%s: Can not find Peer Sta "MAC_FMT" for Key Info!!!\n", __FUNCTION__, MAC_ARG(pTA));
-		return false;
-	}
-
-	if( IS_MCAST(pRA) ){
-		WAPI_TRACE(WAPI_RX, "%s: Multicast decryption !!!\n", __FUNCTION__);
-		if (pWapiSta->wapiMsk.keyId == KeyIdx && pWapiSta->wapiMsk.bSet){
-			pLastRxPN = pWapiSta->lastRxMulticastPN;
-			if (!WapiComparePN(pRecvPN, pLastRxPN)){
-				WAPI_TRACE(WAPI_ERR, "%s: MSK PN is not larger than last, Dropped!!!\n", __FUNCTION__);
-				WAPI_DATA(WAPI_ERR, "pRecvPN:", pRecvPN, 16);
-				WAPI_DATA(WAPI_ERR, "pLastRxPN:", pLastRxPN, 16);
-				return false;
-			}
-
-			memcpy(pLastRxPN, pRecvPN, 16);
-			pMicKey = pWapiSta->wapiMsk.micKey;
-			pDataKey = pWapiSta->wapiMsk.dataKey;
-		}else if (pWapiSta->wapiMskUpdate.keyId == KeyIdx && pWapiSta->wapiMskUpdate.bSet){
-			WAPI_TRACE(WAPI_RX, "%s: Use Updated MSK for Decryption !!!\n", __FUNCTION__);
-			bUseUpdatedKey = true;
-			memcpy(pWapiSta->lastRxMulticastPN, pRecvPN, 16);
-			pMicKey = pWapiSta->wapiMskUpdate.micKey;
-			pDataKey = pWapiSta->wapiMskUpdate.dataKey;
-		}else{
-			WAPI_TRACE(WAPI_ERR, "%s: Can not find MSK with matched KeyIdx(%d), Dropped !!!\n", __FUNCTION__,KeyIdx);
-			return false;
-		}
-	}
-	else{
-		WAPI_TRACE(WAPI_RX, "%s: Unicast decryption !!!\n", __FUNCTION__);
-		if (pWapiSta->wapiUsk.keyId == KeyIdx && pWapiSta->wapiUsk.bSet){
-			WAPI_TRACE(WAPI_RX, "%s: Use USK for Decryption!!!\n", __FUNCTION__);
-			if(precv_hdr->bWapiCheckPNInDecrypt){
-				if(GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE){
-					WapiGetLastRxUnicastPNForQoSData(TID, pWapiSta, lastRxPNforQoS);
-					pLastRxPN = lastRxPNforQoS;
-				}else{
-					pLastRxPN = pWapiSta->lastRxUnicastPN;
-				}
-				if (!WapiComparePN(pRecvPN, pLastRxPN)){
-					return false;
-				}
-				if(bQosData){
-					WapiSetLastRxUnicastPNForQoSData(TID, pRecvPN, pWapiSta);
-				}else{
-					memcpy(pWapiSta->lastRxUnicastPN, pRecvPN, 16);
-				}
-			}else{
-				memcpy(precv_hdr->WapiTempPN,pRecvPN,16);
-			}
-
-			if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE))
-			{
-				if ((pRecvPN[0] & 0x1) == 0){
-					WAPI_TRACE(WAPI_ERR, "%s: Rx USK PN is not odd when Infra STA mode, Dropped !!!\n", __FUNCTION__);
-					return false;
-				}
-			}
-
-			pMicKey = pWapiSta->wapiUsk.micKey;
-			pDataKey = pWapiSta->wapiUsk.dataKey;
-		}
-		else if (pWapiSta->wapiUskUpdate.keyId == KeyIdx && pWapiSta->wapiUskUpdate.bSet ){
-			WAPI_TRACE(WAPI_RX, "%s: Use Updated USK for Decryption!!!\n", __FUNCTION__);
-			if(pWapiSta->bAuthenticatorInUpdata)
-				bUseUpdatedKey = true;
-			else
-				bUseUpdatedKey = false;
-
-			if(bQosData){
-				WapiSetLastRxUnicastPNForQoSData(TID, pRecvPN, pWapiSta);
-			}else{
-				memcpy(pWapiSta->lastRxUnicastPN, pRecvPN, 16);
-			}
-			pMicKey = pWapiSta->wapiUskUpdate.micKey;
-			pDataKey = pWapiSta->wapiUskUpdate.dataKey;
-		}else{
-			WAPI_TRACE(WAPI_ERR, "%s: No valid USK!!!KeyIdx=%d pWapiSta->wapiUsk.keyId=%d pWapiSta->wapiUskUpdate.keyId=%d\n", __FUNCTION__, KeyIdx, pWapiSta->wapiUsk.keyId, pWapiSta->wapiUskUpdate.keyId);
-			//dump_buf(pskb->data,pskb->len);
-			return false;
-		}
-	}
-
-	WAPI_DATA(WAPI_RX, "Decryption - DataKey", pDataKey, 16);
-	WAPI_DATA(WAPI_RX, "Decryption - IV", pRecvPN, 16);
-	WapiSMS4Decryption(pDataKey, pRecvPN, pSecData, DataLen, pSecData, &OutputLength);
-
-	if (OutputLength != DataLen)
-		WAPI_TRACE(WAPI_ERR, "%s:  Output Length Error!!!!\n", __FUNCTION__);
-
-	WAPI_DATA(WAPI_RX, "Decryption - After decryption", pskb->data, pskb->len);
-
-	DataLen -= padapter->wapiInfo.extra_postfix_len;
-
-	SecCalculateMicSMS4(KeyIdx, pMicKey, pskb->data, pSecData, DataLen, MicBuffer);
-
-	WAPI_DATA(WAPI_RX, "Decryption - MIC received", pRecvMic, SMS4_MIC_LEN);
-	WAPI_DATA(WAPI_RX, "Decryption - MIC calculated", MicBuffer, SMS4_MIC_LEN);
-
-	if (0 == memcmp(MicBuffer, pRecvMic, padapter->wapiInfo.extra_postfix_len)){
-		WAPI_TRACE(WAPI_RX, "%s: Check MIC OK!!\n", __FUNCTION__);
-		if (bUseUpdatedKey){
-			// delete the old key
-			if ( IS_MCAST(pRA) ){
-				WAPI_TRACE(WAPI_API, "%s(): AE use new update MSK!!\n", __FUNCTION__);
-				pWapiSta->wapiMsk.keyId = pWapiSta->wapiMskUpdate.keyId;
-				memcpy(pWapiSta->wapiMsk.dataKey, pWapiSta->wapiMskUpdate.dataKey, 16);
-				memcpy(pWapiSta->wapiMsk.micKey, pWapiSta->wapiMskUpdate.micKey, 16);
-				pWapiSta->wapiMskUpdate.bTxEnable = pWapiSta->wapiMskUpdate.bSet = false;
-			}else{
-				WAPI_TRACE(WAPI_API, "%s(): AE use new update USK!!\n", __FUNCTION__);
-				pWapiSta->wapiUsk.keyId = pWapiSta->wapiUskUpdate.keyId;
-				memcpy(pWapiSta->wapiUsk.dataKey, pWapiSta->wapiUskUpdate.dataKey, 16);
-				memcpy(pWapiSta->wapiUsk.micKey, pWapiSta->wapiUskUpdate.micKey, 16);
-				pWapiSta->wapiUskUpdate.bTxEnable = pWapiSta->wapiUskUpdate.bSet = false;
-			}
-		}
-	}else{
-		WAPI_TRACE(WAPI_ERR, "%s:  Check MIC Error, Dropped !!!!\n", __FUNCTION__);
-		return false;
-	}
-
-	pos = pskb->data;
-	memmove(pos+padapter->wapiInfo.extra_prefix_len, pos, IVOffset);
-	skb_pull(pskb, padapter->wapiInfo.extra_prefix_len);
-
-	WAPI_TRACE(WAPI_RX, "<=========%s\n", __FUNCTION__);
-
-	return true;
-}
-
-u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe)
-{
-
-	u8	*pframe;
-	u32 res = _SUCCESS;
-
-	WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_TX, "<========== %s, WAPI not supported or enabled!\n", __FUNCTION__);
-		return _FAIL;
-	}
-
-	if(((struct xmit_frame*)pxmitframe)->buf_addr==NULL)
-		return _FAIL;
-
-	pframe = ((struct xmit_frame*)pxmitframe)->buf_addr + TXDESC_OFFSET;
-
-	SecSWSMS4Encryption(padapter, pxmitframe);
-
-	WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
-	return res;
-}
-
-u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe)
-{
-	u8	*pframe;
-	u32 res = _SUCCESS;
-
-	WAPI_TRACE(WAPI_RX, "=========>%s\n", __FUNCTION__);
-
-	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable))
-	{
-		WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or enabled!\n", __FUNCTION__);
-		return _FAIL;
-	}
-
-
-	//drop packet when hw decrypt fail
-       //return tempraily
-	return _FAIL;
-
-	//pframe=(unsigned char *)((union recv_frame*)precvframe)->u.hdr.rx_data;
-
-	if (false == SecSWSMS4Decryption(padapter, precvframe, &padapter->recvpriv))
-	{
-		WAPI_TRACE(WAPI_ERR, "%s():SMS4 decrypt frame error\n",__FUNCTION__);
-		return _FAIL;
-	}
-
-	WAPI_TRACE(WAPI_RX, "<=========%s\n", __FUNCTION__);
-	return res;
-}
-
-#else
-
-u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe)
-{
-	WAPI_TRACE(WAPI_TX, "=========>Dummy %s\n", __FUNCTION__);
-	WAPI_TRACE(WAPI_TX, "<=========Dummy %s\n", __FUNCTION__);
-	return _SUCCESS;
-}
-
-u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe)
-{
-	WAPI_TRACE(WAPI_RX, "=========>Dummy %s\n", __FUNCTION__);
-	WAPI_TRACE(WAPI_RX, "<=========Dummy %s\n", __FUNCTION__);
-	return _SUCCESS;
-}
-
-#endif
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#ifdef CONFIG_WAPI_SUPPORT
+
+#include <linux/unistd.h>
+#include <linux/etherdevice.h>
+#include <drv_types.h>
+#include <rtw_wapi.h>
+
+
+#ifdef CONFIG_WAPI_SW_SMS4
+
+#define WAPI_LITTLE_ENDIAN
+/* #define BIG_ENDIAN */
+#define ENCRYPT  0
+#define DECRYPT  1
+
+
+/**********************************************************
+ **********************************************************/
+const u8 Sbox[256] = {
+	0xd6, 0x90, 0xe9, 0xfe, 0xcc, 0xe1, 0x3d, 0xb7, 0x16, 0xb6, 0x14, 0xc2, 0x28, 0xfb, 0x2c, 0x05,
+	0x2b, 0x67, 0x9a, 0x76, 0x2a, 0xbe, 0x04, 0xc3, 0xaa, 0x44, 0x13, 0x26, 0x49, 0x86, 0x06, 0x99,
+	0x9c, 0x42, 0x50, 0xf4, 0x91, 0xef, 0x98, 0x7a, 0x33, 0x54, 0x0b, 0x43, 0xed, 0xcf, 0xac, 0x62,
+	0xe4, 0xb3, 0x1c, 0xa9, 0xc9, 0x08, 0xe8, 0x95, 0x80, 0xdf, 0x94, 0xfa, 0x75, 0x8f, 0x3f, 0xa6,
+	0x47, 0x07, 0xa7, 0xfc, 0xf3, 0x73, 0x17, 0xba, 0x83, 0x59, 0x3c, 0x19, 0xe6, 0x85, 0x4f, 0xa8,
+	0x68, 0x6b, 0x81, 0xb2, 0x71, 0x64, 0xda, 0x8b, 0xf8, 0xeb, 0x0f, 0x4b, 0x70, 0x56, 0x9d, 0x35,
+	0x1e, 0x24, 0x0e, 0x5e, 0x63, 0x58, 0xd1, 0xa2, 0x25, 0x22, 0x7c, 0x3b, 0x01, 0x21, 0x78, 0x87,
+	0xd4, 0x00, 0x46, 0x57, 0x9f, 0xd3, 0x27, 0x52, 0x4c, 0x36, 0x02, 0xe7, 0xa0, 0xc4, 0xc8, 0x9e,
+	0xea, 0xbf, 0x8a, 0xd2, 0x40, 0xc7, 0x38, 0xb5, 0xa3, 0xf7, 0xf2, 0xce, 0xf9, 0x61, 0x15, 0xa1,
+	0xe0, 0xae, 0x5d, 0xa4, 0x9b, 0x34, 0x1a, 0x55, 0xad, 0x93, 0x32, 0x30, 0xf5, 0x8c, 0xb1, 0xe3,
+	0x1d, 0xf6, 0xe2, 0x2e, 0x82, 0x66, 0xca, 0x60, 0xc0, 0x29, 0x23, 0xab, 0x0d, 0x53, 0x4e, 0x6f,
+	0xd5, 0xdb, 0x37, 0x45, 0xde, 0xfd, 0x8e, 0x2f, 0x03, 0xff, 0x6a, 0x72, 0x6d, 0x6c, 0x5b, 0x51,
+	0x8d, 0x1b, 0xaf, 0x92, 0xbb, 0xdd, 0xbc, 0x7f, 0x11, 0xd9, 0x5c, 0x41, 0x1f, 0x10, 0x5a, 0xd8,
+	0x0a, 0xc1, 0x31, 0x88, 0xa5, 0xcd, 0x7b, 0xbd, 0x2d, 0x74, 0xd0, 0x12, 0xb8, 0xe5, 0xb4, 0xb0,
+	0x89, 0x69, 0x97, 0x4a, 0x0c, 0x96, 0x77, 0x7e, 0x65, 0xb9, 0xf1, 0x09, 0xc5, 0x6e, 0xc6, 0x84,
+	0x18, 0xf0, 0x7d, 0xec, 0x3a, 0xdc, 0x4d, 0x20, 0x79, 0xee, 0x5f, 0x3e, 0xd7, 0xcb, 0x39, 0x48
+};
+
+const u32 CK[32] = {
+	0x00070e15, 0x1c232a31, 0x383f464d, 0x545b6269,
+	0x70777e85, 0x8c939aa1, 0xa8afb6bd, 0xc4cbd2d9,
+	0xe0e7eef5, 0xfc030a11, 0x181f262d, 0x343b4249,
+	0x50575e65, 0x6c737a81, 0x888f969d, 0xa4abb2b9,
+	0xc0c7ced5, 0xdce3eaf1, 0xf8ff060d, 0x141b2229,
+	0x30373e45, 0x4c535a61, 0x686f767d, 0x848b9299,
+	0xa0a7aeb5, 0xbcc3cad1, 0xd8dfe6ed, 0xf4fb0209,
+	0x10171e25, 0x2c333a41, 0x484f565d, 0x646b7279
+};
+
+#define Rotl(_x, _y) (((_x) << (_y)) | ((_x) >> (32 - (_y))))
+
+#define ByteSub(_A) (Sbox[(_A) >> 24 & 0xFF] << 24 | \
+		     Sbox[(_A) >> 16 & 0xFF] << 16 | \
+		     Sbox[(_A) >>  8 & 0xFF] <<  8 | \
+		     Sbox[(_A) & 0xFF])
+
+#define L1(_B) ((_B) ^ Rotl(_B, 2) ^ Rotl(_B, 10) ^ Rotl(_B, 18) ^ Rotl(_B, 24))
+#define L2(_B) ((_B) ^ Rotl(_B, 13) ^ Rotl(_B, 23))
+
+static void
+xor_block(void *dst, void *src1, void *src2)
+/* 128-bit xor: *dst = *src1 xor *src2. Pointers must be 32-bit aligned */
+{
+	((u32 *)dst)[0] = ((u32 *)src1)[0] ^ ((u32 *)src2)[0];
+	((u32 *)dst)[1] = ((u32 *)src1)[1] ^ ((u32 *)src2)[1];
+	((u32 *)dst)[2] = ((u32 *)src1)[2] ^ ((u32 *)src2)[2];
+	((u32 *)dst)[3] = ((u32 *)src1)[3] ^ ((u32 *)src2)[3];
+}
+
+
+void SMS4Crypt(u8 *Input, u8 *Output, u32 *rk)
+{
+	u32 r, mid, x0, x1, x2, x3, *p;
+	p = (u32 *)Input;
+	x0 = p[0];
+	x1 = p[1];
+	x2 = p[2];
+	x3 = p[3];
+#ifdef WAPI_LITTLE_ENDIAN
+	x0 = Rotl(x0, 16);
+	x0 = ((x0 & 0x00FF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
+	x1 = Rotl(x1, 16);
+	x1 = ((x1 & 0x00FF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
+	x2 = Rotl(x2, 16);
+	x2 = ((x2 & 0x00FF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
+	x3 = Rotl(x3, 16);
+	x3 = ((x3 & 0x00FF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
+#endif
+	for (r = 0; r < 32; r += 4) {
+		mid = x1 ^ x2 ^ x3 ^ rk[r + 0];
+		mid = ByteSub(mid);
+		x0 ^= L1(mid);
+		mid = x2 ^ x3 ^ x0 ^ rk[r + 1];
+		mid = ByteSub(mid);
+		x1 ^= L1(mid);
+		mid = x3 ^ x0 ^ x1 ^ rk[r + 2];
+		mid = ByteSub(mid);
+		x2 ^= L1(mid);
+		mid = x0 ^ x1 ^ x2 ^ rk[r + 3];
+		mid = ByteSub(mid);
+		x3 ^= L1(mid);
+	}
+#ifdef WAPI_LITTLE_ENDIAN
+	x0 = Rotl(x0, 16);
+	x0 = ((x0 & 0x00FF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
+	x1 = Rotl(x1, 16);
+	x1 = ((x1 & 0x00FF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
+	x2 = Rotl(x2, 16);
+	x2 = ((x2 & 0x00FF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
+	x3 = Rotl(x3, 16);
+	x3 = ((x3 & 0x00FF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
+#endif
+	p = (u32 *)Output;
+	p[0] = x3;
+	p[1] = x2;
+	p[2] = x1;
+	p[3] = x0;
+}
+
+
+
+void SMS4KeyExt(u8 *Key, u32 *rk, u32 CryptFlag)
+{
+	u32 r, mid, x0, x1, x2, x3, *p;
+
+	p = (u32 *)Key;
+	x0 = p[0];
+	x1 = p[1];
+	x2 = p[2];
+	x3 = p[3];
+#ifdef WAPI_LITTLE_ENDIAN
+	x0 = Rotl(x0, 16);
+	x0 = ((x0 & 0xFF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
+	x1 = Rotl(x1, 16);
+	x1 = ((x1 & 0xFF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
+	x2 = Rotl(x2, 16);
+	x2 = ((x2 & 0xFF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
+	x3 = Rotl(x3, 16);
+	x3 = ((x3 & 0xFF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
+#endif
+
+	x0 ^= 0xa3b1bac6;
+	x1 ^= 0x56aa3350;
+	x2 ^= 0x677d9197;
+	x3 ^= 0xb27022dc;
+	for (r = 0; r < 32; r += 4) {
+		mid = x1 ^ x2 ^ x3 ^ CK[r + 0];
+		mid = ByteSub(mid);
+		rk[r + 0] = x0 ^= L2(mid);
+		mid = x2 ^ x3 ^ x0 ^ CK[r + 1];
+		mid = ByteSub(mid);
+		rk[r + 1] = x1 ^= L2(mid);
+		mid = x3 ^ x0 ^ x1 ^ CK[r + 2];
+		mid = ByteSub(mid);
+		rk[r + 2] = x2 ^= L2(mid);
+		mid = x0 ^ x1 ^ x2 ^ CK[r + 3];
+		mid = ByteSub(mid);
+		rk[r + 3] = x3 ^= L2(mid);
+	}
+	if (CryptFlag == DECRYPT) {
+		for (r = 0; r < 16; r++)
+			mid = rk[r], rk[r] = rk[31 - r], rk[31 - r] = mid;
+	}
+}
+
+
+void WapiSMS4Cryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
+		      u8 *Output, u16 *OutputLength, u32 CryptFlag)
+{
+	u32 blockNum, i, j, rk[32];
+	u16 remainder;
+	u8 blockIn[16], blockOut[16], tempIV[16], k;
+
+	*OutputLength = 0;
+	remainder = InputLength & 0x0F;
+	blockNum = InputLength >> 4;
+	if (remainder != 0)
+		blockNum++;
+	else
+		remainder = 16;
+
+	for (k = 0; k < 16; k++)
+		tempIV[k] = IV[15 - k];
+
+	memcpy(blockIn, tempIV, 16);
+
+	SMS4KeyExt((u8 *)Key, rk, CryptFlag);
+
+	for (i = 0; i < blockNum - 1; i++) {
+		SMS4Crypt((u8 *)blockIn, blockOut, rk);
+		xor_block(&Output[i * 16], &Input[i * 16], blockOut);
+		memcpy(blockIn, blockOut, 16);
+	}
+
+	*OutputLength = i * 16;
+
+	SMS4Crypt((u8 *)blockIn, blockOut, rk);
+
+	for (j = 0; j < remainder; j++)
+		Output[i * 16 + j] = Input[i * 16 + j] ^ blockOut[j];
+	*OutputLength += remainder;
+
+}
+
+void WapiSMS4Encryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
+			u8 *Output, u16 *OutputLength)
+{
+
+	WapiSMS4Cryption(Key, IV, Input, InputLength, Output, OutputLength, ENCRYPT);
+}
+
+void WapiSMS4Decryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
+			u8 *Output, u16 *OutputLength)
+{
+	/* OFB mode: is also ENCRYPT flag */
+	WapiSMS4Cryption(Key, IV, Input, InputLength, Output, OutputLength, ENCRYPT);
+}
+
+void WapiSMS4CalculateMic(u8 *Key, u8 *IV, u8 *Input1, u8 Input1Length,
+		  u8 *Input2, u16 Input2Length, u8 *Output, u8 *OutputLength)
+{
+	u32 blockNum, i, remainder, rk[32];
+	u8 BlockIn[16], BlockOut[16], TempBlock[16], tempIV[16], k;
+
+	*OutputLength = 0;
+	remainder = Input1Length & 0x0F;
+	blockNum = Input1Length >> 4;
+
+	for (k = 0; k < 16; k++)
+		tempIV[k] = IV[15 - k];
+
+	memcpy(BlockIn, tempIV, 16);
+
+	SMS4KeyExt((u8 *)Key, rk, ENCRYPT);
+
+	SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
+
+	for (i = 0; i < blockNum; i++) {
+		xor_block(BlockIn, (Input1 + i * 16), BlockOut);
+		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
+	}
+
+	if (remainder != 0) {
+		memset(TempBlock, 0, 16);
+		memcpy(TempBlock, (Input1 + blockNum * 16), remainder);
+
+		xor_block(BlockIn, TempBlock, BlockOut);
+		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
+	}
+
+	remainder = Input2Length & 0x0F;
+	blockNum = Input2Length >> 4;
+
+	for (i = 0; i < blockNum; i++) {
+		xor_block(BlockIn, (Input2 + i * 16), BlockOut);
+		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
+	}
+
+	if (remainder != 0) {
+		memset(TempBlock, 0, 16);
+		memcpy(TempBlock, (Input2 + blockNum * 16), remainder);
+
+		xor_block(BlockIn, TempBlock, BlockOut);
+		SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
+	}
+
+	memcpy(Output, BlockOut, 16);
+	*OutputLength = 16;
+}
+
+void SecCalculateMicSMS4(
+	u8		KeyIdx,
+	u8        *MicKey,
+	u8        *pHeader,
+	u8        *pData,
+	u16       DataLen,
+	u8        *MicBuffer
+)
+{
+#if 0
+	struct ieee80211_hdr_3addr_qos *header;
+	u8 TempBuf[34], TempLen = 32, MicLen, QosOffset, *IV;
+	u16 *pTemp, fc;
+
+	WAPI_TRACE(WAPI_TX | WAPI_RX, "=========>%s\n", __FUNCTION__);
+
+	header = (struct ieee80211_hdr_3addr_qos *)pHeader;
+	memset(TempBuf, 0, 34);
+	memcpy(TempBuf, pHeader, 2); /* FrameCtrl */
+	pTemp = (u16 *)TempBuf;
+	*pTemp &= 0xc78f;       /* bit4,5,6,11,12,13 */
+
+	memcpy((TempBuf + 2), (pHeader + 4), 12); /* Addr1, Addr2 */
+	memcpy((TempBuf + 14), (pHeader + 22), 2); /* SeqCtrl */
+	pTemp = (u16 *)(TempBuf + 14);
+	*pTemp &= 0x000f;
+
+	memcpy((TempBuf + 16), (pHeader + 16), 6); /* Addr3 */
+
+	fc = le16_to_cpu(header->frame_ctl);
+
+
+
+	if (GetFrDs((u16 *)&fc) && GetToDs((u16 *)&fc)) {
+		memcpy((TempBuf + 22), (pHeader + 24), 6);
+		QosOffset = 30;
+	} else {
+		memset((TempBuf + 22), 0, 6);
+		QosOffset = 24;
+	}
+
+	if ((fc & 0x0088) == 0x0088) {
+		memcpy((TempBuf + 28), (pHeader + QosOffset), 2);
+		TempLen += 2;
+		/* IV = pHeader + QosOffset + 2 + SNAP_SIZE + sizeof(u16) + 2; */
+		IV = pHeader + QosOffset + 2 + 2;
+	} else {
+		IV = pHeader + QosOffset + 2;
+		/* IV = pHeader + QosOffset + SNAP_SIZE + sizeof(u16) + 2; */
+	}
+
+	TempBuf[TempLen - 1] = (u8)(DataLen & 0xff);
+	TempBuf[TempLen - 2] = (u8)((DataLen & 0xff00) >> 8);
+	TempBuf[TempLen - 4] = KeyIdx;
+
+	WAPI_DATA(WAPI_TX, "CalculateMic - KEY", MicKey, 16);
+	WAPI_DATA(WAPI_TX, "CalculateMic - IV", IV, 16);
+	WAPI_DATA(WAPI_TX, "CalculateMic - TempBuf", TempBuf, TempLen);
+	WAPI_DATA(WAPI_TX, "CalculateMic - pData", pData, DataLen);
+
+	WapiSMS4CalculateMic(MicKey, IV, TempBuf, TempLen,
+			     pData, DataLen, MicBuffer, &MicLen);
+
+	if (MicLen != 16)
+		WAPI_TRACE(WAPI_ERR, "%s: MIC Length Error!!\n", __FUNCTION__);
+
+	WAPI_TRACE(WAPI_TX | WAPI_RX, "<=========%s\n", __FUNCTION__);
+#endif
+}
+
+/* AddCount: 1 or 2.
+ *  If overflow, return 1,
+ *  else return 0.
+ */
+u8 WapiIncreasePN(u8 *PN, u8 AddCount)
+{
+	u8  i;
+
+	if (NULL == PN)
+		return 1;
+	/* YJ,test,091102 */
+	/*
+	if(AddCount == 2){
+		RTW_INFO("############################%s(): PN[0]=0x%x\n", __FUNCTION__, PN[0]);
+		if(PN[0] == 0x48){
+			PN[0] += AddCount;
+			return 1;
+		}else{
+			PN[0] += AddCount;
+			return 0;
+		}
+	}
+	*/
+	/* YJ,test,091102,end */
+
+	for (i = 0; i < 16; i++) {
+		if (PN[i] + AddCount <= 0xff) {
+			PN[i] += AddCount;
+			return 0;
+		} else {
+			PN[i] += AddCount;
+			AddCount = 1;
+		}
+	}
+	return 1;
+}
+
+
+void WapiGetLastRxUnicastPNForQoSData(
+	u8			UserPriority,
+	PRT_WAPI_STA_INFO    pWapiStaInfo,
+	u8 *PNOut
+)
+{
+	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
+	switch (UserPriority) {
+	case 0:
+	case 3:
+		memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNBEQueue, 16);
+		break;
+	case 1:
+	case 2:
+		memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNBKQueue, 16);
+		break;
+	case 4:
+	case 5:
+		memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNVIQueue, 16);
+		break;
+	case 6:
+	case 7:
+		memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNVOQueue, 16);
+		break;
+	default:
+		WAPI_TRACE(WAPI_ERR, "%s: Unknown TID\n", __FUNCTION__);
+		break;
+	}
+	WAPI_TRACE(WAPI_RX, "<=========== %s\n", __FUNCTION__);
+}
+
+
+void WapiSetLastRxUnicastPNForQoSData(
+	u8		UserPriority,
+	u8           *PNIn,
+	PRT_WAPI_STA_INFO    pWapiStaInfo
+)
+{
+	WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
+	switch (UserPriority) {
+	case 0:
+	case 3:
+		memcpy(pWapiStaInfo->lastRxUnicastPNBEQueue, PNIn, 16);
+		break;
+	case 1:
+	case 2:
+		memcpy(pWapiStaInfo->lastRxUnicastPNBKQueue, PNIn, 16);
+		break;
+	case 4:
+	case 5:
+		memcpy(pWapiStaInfo->lastRxUnicastPNVIQueue, PNIn, 16);
+		break;
+	case 6:
+	case 7:
+		memcpy(pWapiStaInfo->lastRxUnicastPNVOQueue, PNIn, 16);
+		break;
+	default:
+		WAPI_TRACE(WAPI_ERR, "%s: Unknown TID\n", __FUNCTION__);
+		break;
+	}
+	WAPI_TRACE(WAPI_RX, "<=========== %s\n", __FUNCTION__);
+}
+
+
+/****************************************************************************
+ FALSE not RX-Reorder
+ TRUE do RX Reorder
+add to support WAPI to N-mode
+*****************************************************************************/
+u8 WapiCheckPnInSwDecrypt(
+	_adapter *padapter,
+	struct sk_buff *pskb
+)
+{
+	u8				ret = false;
+
+#if 0
+	struct ieee80211_hdr_3addr_qos *header;
+	u16				fc;
+	u8				*pDaddr, *pTaddr, *pRaddr;
+
+	header = (struct ieee80211_hdr_3addr_qos *)pskb->data;
+	pTaddr = header->addr2;
+	pRaddr = header->addr1;
+	fc = le16_to_cpu(header->frame_ctl);
+
+	if (GetToDs(&fc))
+		pDaddr = header->addr3;
+	else
+		pDaddr = header->addr1;
+
+	if ((_rtw_memcmp(pRaddr, padapter->pnetdev->dev_addr, ETH_ALEN) == 0)
+	    &&	!(pDaddr)
+	    && (GetFrameType(&fc) == WIFI_QOS_DATA_TYPE))
+		/* && ieee->pHTInfo->bCurrentHTSupport && */
+		/* ieee->pHTInfo->bCurRxReorderEnable) */
+		ret = false;
+	else
+		ret = true;
+#endif
+	WAPI_TRACE(WAPI_RX, "%s: return %d\n", __FUNCTION__, ret);
+	return ret;
+}
+
+int SecSMS4HeaderFillIV(_adapter *padapter, u8 *pxmitframe)
+{
+	struct pkt_attrib *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
+	u8 *frame = ((struct xmit_frame *)pxmitframe)->buf_addr + TXDESC_OFFSET;
+	u8 *pSecHeader = NULL, *pos = NULL, *pRA = NULL;
+	u8 bPNOverflow = false, bFindMatchPeer = false, hdr_len = 0;
+	PWLAN_HEADER_WAPI_EXTENSION pWapiExt = NULL;
+	PRT_WAPI_T         pWapiInfo = &padapter->wapiInfo;
+	PRT_WAPI_STA_INFO  pWapiSta = NULL;
+	int ret = 0;
+
+	WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
+
+	return ret;
+#if 0
+	hdr_len = sMacHdrLng;
+	if (GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE)
+		hdr_len += 2;
+	/* hdr_len += SNAP_SIZE + sizeof(u16); */
+
+	pos = skb_push(pskb, padapter->wapiInfo.extra_prefix_len);
+	memmove(pos, pos + padapter->wapiInfo.extra_prefix_len, hdr_len);
+
+	pSecHeader = pskb->data + hdr_len;
+	pWapiExt = (PWLAN_HEADER_WAPI_EXTENSION)pSecHeader;
+	pRA = pskb->data + 4;
+
+	WAPI_DATA(WAPI_TX, "FillIV - Before Fill IV", pskb->data, pskb->len);
+
+	/* Address 1 is always receiver's address */
+	if (IS_MCAST(pRA)) {
+		if (!pWapiInfo->wapiTxMsk.bTxEnable) {
+			WAPI_TRACE(WAPI_ERR, "%s: bTxEnable = 0!!\n", __FUNCTION__);
+			return -2;
+		}
+		if (pWapiInfo->wapiTxMsk.keyId <= 1) {
+			pWapiExt->KeyIdx = pWapiInfo->wapiTxMsk.keyId;
+			pWapiExt->Reserved = 0;
+			bPNOverflow = WapiIncreasePN(pWapiInfo->lastTxMulticastPN, 1);
+			memcpy(pWapiExt->PN, pWapiInfo->lastTxMulticastPN, 16);
+			if (bPNOverflow) {
+				/* Update MSK Notification. */
+				WAPI_TRACE(WAPI_ERR, "===============>%s():multicast PN overflow\n", __FUNCTION__);
+				rtw_wapi_app_event_handler(padapter, NULL, 0, pRA, false, false, true, 0, false);
+			}
+		} else {
+			WAPI_TRACE(WAPI_ERR, "%s: Invalid Wapi Multicast KeyIdx!!\n", __FUNCTION__);
+			ret = -3;
+		}
+	} else {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (!memcmp(pWapiSta->PeerMacAddr, pRA, 6)) {
+				bFindMatchPeer = true;
+				break;
+			}
+		}
+		if (bFindMatchPeer) {
+			if ((!pWapiSta->wapiUskUpdate.bTxEnable) && (!pWapiSta->wapiUsk.bTxEnable)) {
+				WAPI_TRACE(WAPI_ERR, "%s: bTxEnable = 0!!\n", __FUNCTION__);
+				return -4;
+			}
+			if (pWapiSta->wapiUsk.keyId <= 1) {
+				if (pWapiSta->wapiUskUpdate.bTxEnable)
+					pWapiExt->KeyIdx = pWapiSta->wapiUskUpdate.keyId;
+				else
+					pWapiExt->KeyIdx = pWapiSta->wapiUsk.keyId;
+
+				pWapiExt->Reserved = 0;
+				bPNOverflow = WapiIncreasePN(pWapiSta->lastTxUnicastPN, 2);
+				memcpy(pWapiExt->PN, pWapiSta->lastTxUnicastPN, 16);
+				if (bPNOverflow) {
+					/* Update USK Notification. */
+					WAPI_TRACE(WAPI_ERR, "===============>%s():unicast PN overflow\n", __FUNCTION__);
+					rtw_wapi_app_event_handler(padapter, NULL, 0, pWapiSta->PeerMacAddr, false, true, false, 0, false);
+				}
+			} else {
+				WAPI_TRACE(WAPI_ERR, "%s: Invalid Wapi Unicast KeyIdx!!\n", __FUNCTION__);
+				ret = -5;
+			}
+		} else {
+			WAPI_TRACE(WAPI_ERR, "%s: Can not find Peer Sta "MAC_FMT"!!\n", __FUNCTION__, MAC_ARG(pRA));
+			ret = -6;
+		}
+	}
+
+	WAPI_DATA(WAPI_TX, "FillIV - After Fill IV", pskb->data, pskb->len);
+	WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
+	return ret;
+#endif
+}
+
+/* WAPI SW Enc: must have done Coalesce! */
+void SecSWSMS4Encryption(
+	_adapter *padapter,
+	u8 *pxmitframe
+)
+{
+	PRT_WAPI_T		pWapiInfo = &padapter->wapiInfo;
+	PRT_WAPI_STA_INFO   pWapiSta = NULL;
+	u8 *pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + TXDESC_SIZE;
+	struct pkt_attrib *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
+
+	u8 *SecPtr = NULL, *pRA, *pMicKey = NULL, *pDataKey = NULL, *pIV = NULL;
+	u8 IVOffset, DataOffset, bFindMatchPeer = false, KeyIdx = 0, MicBuffer[16];
+	u16 OutputLength;
+
+	WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
+
+	WAPI_TRACE(WAPI_TX, "hdrlen: %d\n", pattrib->hdrlen);
+
+	return;
+
+	DataOffset = pattrib->hdrlen + pattrib->iv_len;
+
+	pRA = pframe + 4;
+
+
+	if (IS_MCAST(pRA)) {
+		KeyIdx = pWapiInfo->wapiTxMsk.keyId;
+		pIV = pWapiInfo->lastTxMulticastPN;
+		pMicKey = pWapiInfo->wapiTxMsk.micKey;
+		pDataKey = pWapiInfo->wapiTxMsk.dataKey;
+	} else {
+		if (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
+			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+				if (0 == memcmp(pWapiSta->PeerMacAddr, pRA, 6)) {
+					bFindMatchPeer = true;
+					break;
+				}
+			}
+
+			if (bFindMatchPeer) {
+				if (pWapiSta->wapiUskUpdate.bTxEnable) {
+					KeyIdx = pWapiSta->wapiUskUpdate.keyId;
+					WAPI_TRACE(WAPI_TX, "%s(): Use update USK!! KeyIdx=%d\n", __FUNCTION__, KeyIdx);
+					pIV = pWapiSta->lastTxUnicastPN;
+					pMicKey = pWapiSta->wapiUskUpdate.micKey;
+					pDataKey = pWapiSta->wapiUskUpdate.dataKey;
+				} else {
+					KeyIdx = pWapiSta->wapiUsk.keyId;
+					WAPI_TRACE(WAPI_TX, "%s(): Use USK!! KeyIdx=%d\n", __FUNCTION__, KeyIdx);
+					pIV = pWapiSta->lastTxUnicastPN;
+					pMicKey = pWapiSta->wapiUsk.micKey;
+					pDataKey = pWapiSta->wapiUsk.dataKey;
+				}
+			} else {
+				WAPI_TRACE(WAPI_ERR, "%s: Can not find Peer Sta!!\n", __FUNCTION__);
+				return;
+			}
+		} else {
+			WAPI_TRACE(WAPI_ERR, "%s: wapiSTAUsedList is empty!!\n", __FUNCTION__);
+			return;
+		}
+	}
+
+	SecPtr = pframe;
+	SecCalculateMicSMS4(KeyIdx, pMicKey, SecPtr, (SecPtr + DataOffset), pattrib->pktlen, MicBuffer);
+
+	WAPI_DATA(WAPI_TX, "Encryption - MIC", MicBuffer, padapter->wapiInfo.extra_postfix_len);
+
+	memcpy(pframe + pattrib->hdrlen + pattrib->iv_len + pattrib->pktlen - pattrib->icv_len,
+	       (u8 *)MicBuffer,
+	       padapter->wapiInfo.extra_postfix_len
+	      );
+
+
+	WapiSMS4Encryption(pDataKey, pIV, (SecPtr + DataOffset), pattrib->pktlen + pattrib->icv_len, (SecPtr + DataOffset), &OutputLength);
+
+	WAPI_DATA(WAPI_TX, "Encryption - After SMS4 encryption", pframe, pattrib->hdrlen + pattrib->iv_len + pattrib->pktlen);
+
+	WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
+}
+
+u8 SecSWSMS4Decryption(
+	_adapter *padapter,
+	u8		*precv_frame,
+	struct recv_priv *precv_priv
+)
+{
+	PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
+	struct recv_frame_hdr *precv_hdr;
+	PRT_WAPI_STA_INFO   pWapiSta = NULL;
+	u8 IVOffset, DataOffset, bFindMatchPeer = false, bUseUpdatedKey = false;
+	u8 KeyIdx, MicBuffer[16], lastRxPNforQoS[16];
+	u8 *pRA, *pTA, *pMicKey, *pDataKey, *pLastRxPN, *pRecvPN, *pSecData, *pRecvMic, *pos;
+	u8 TID = 0;
+	u16 OutputLength, DataLen;
+	u8   bQosData;
+	struct sk_buff	*pskb;
+
+	WAPI_TRACE(WAPI_RX, "=========>%s\n", __FUNCTION__);
+
+	return 0;
+
+	precv_hdr = &((union recv_frame *)precv_frame)->u.hdr;
+	pskb = (struct sk_buff *)(precv_hdr->rx_data);
+	precv_hdr->bWapiCheckPNInDecrypt = WapiCheckPnInSwDecrypt(padapter, pskb);
+	WAPI_TRACE(WAPI_RX, "=========>%s: check PN  %d\n", __FUNCTION__, precv_hdr->bWapiCheckPNInDecrypt);
+	WAPI_DATA(WAPI_RX, "Decryption - Before decryption", pskb->data, pskb->len);
+
+	IVOffset = sMacHdrLng;
+	bQosData = GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE;
+	if (bQosData)
+		IVOffset += 2;
+
+	/* if(GetHTC()) */
+	/*	IVOffset += 4; */
+
+	/* IVOffset += SNAP_SIZE + sizeof(u16); */
+
+	DataOffset = IVOffset + padapter->wapiInfo.extra_prefix_len;
+
+	pRA = pskb->data + 4;
+	pTA = pskb->data + 10;
+	KeyIdx = *(pskb->data + IVOffset);
+	pRecvPN = pskb->data + IVOffset + 2;
+	pSecData = pskb->data + DataOffset;
+	DataLen = pskb->len - DataOffset;
+	pRecvMic = pskb->data + pskb->len - padapter->wapiInfo.extra_postfix_len;
+	TID = GetTid(pskb->data);
+
+	if (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (0 == memcmp(pWapiSta->PeerMacAddr, pTA, 6)) {
+				bFindMatchPeer = true;
+				break;
+			}
+		}
+	}
+
+	if (!bFindMatchPeer) {
+		WAPI_TRACE(WAPI_ERR, "%s: Can not find Peer Sta "MAC_FMT" for Key Info!!!\n", __FUNCTION__, MAC_ARG(pTA));
+		return false;
+	}
+
+	if (IS_MCAST(pRA)) {
+		WAPI_TRACE(WAPI_RX, "%s: Multicast decryption !!!\n", __FUNCTION__);
+		if (pWapiSta->wapiMsk.keyId == KeyIdx && pWapiSta->wapiMsk.bSet) {
+			pLastRxPN = pWapiSta->lastRxMulticastPN;
+			if (!WapiComparePN(pRecvPN, pLastRxPN)) {
+				WAPI_TRACE(WAPI_ERR, "%s: MSK PN is not larger than last, Dropped!!!\n", __FUNCTION__);
+				WAPI_DATA(WAPI_ERR, "pRecvPN:", pRecvPN, 16);
+				WAPI_DATA(WAPI_ERR, "pLastRxPN:", pLastRxPN, 16);
+				return false;
+			}
+
+			memcpy(pLastRxPN, pRecvPN, 16);
+			pMicKey = pWapiSta->wapiMsk.micKey;
+			pDataKey = pWapiSta->wapiMsk.dataKey;
+		} else if (pWapiSta->wapiMskUpdate.keyId == KeyIdx && pWapiSta->wapiMskUpdate.bSet) {
+			WAPI_TRACE(WAPI_RX, "%s: Use Updated MSK for Decryption !!!\n", __FUNCTION__);
+			bUseUpdatedKey = true;
+			memcpy(pWapiSta->lastRxMulticastPN, pRecvPN, 16);
+			pMicKey = pWapiSta->wapiMskUpdate.micKey;
+			pDataKey = pWapiSta->wapiMskUpdate.dataKey;
+		} else {
+			WAPI_TRACE(WAPI_ERR, "%s: Can not find MSK with matched KeyIdx(%d), Dropped !!!\n", __FUNCTION__, KeyIdx);
+			return false;
+		}
+	} else {
+		WAPI_TRACE(WAPI_RX, "%s: Unicast decryption !!!\n", __FUNCTION__);
+		if (pWapiSta->wapiUsk.keyId == KeyIdx && pWapiSta->wapiUsk.bSet) {
+			WAPI_TRACE(WAPI_RX, "%s: Use USK for Decryption!!!\n", __FUNCTION__);
+			if (precv_hdr->bWapiCheckPNInDecrypt) {
+				if (GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE) {
+					WapiGetLastRxUnicastPNForQoSData(TID, pWapiSta, lastRxPNforQoS);
+					pLastRxPN = lastRxPNforQoS;
+				} else
+					pLastRxPN = pWapiSta->lastRxUnicastPN;
+				if (!WapiComparePN(pRecvPN, pLastRxPN))
+					return false;
+				if (bQosData)
+					WapiSetLastRxUnicastPNForQoSData(TID, pRecvPN, pWapiSta);
+				else
+					memcpy(pWapiSta->lastRxUnicastPN, pRecvPN, 16);
+			} else
+				memcpy(precv_hdr->WapiTempPN, pRecvPN, 16);
+
+			if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE)) {
+				if ((pRecvPN[0] & 0x1) == 0) {
+					WAPI_TRACE(WAPI_ERR, "%s: Rx USK PN is not odd when Infra STA mode, Dropped !!!\n", __FUNCTION__);
+					return false;
+				}
+			}
+
+			pMicKey = pWapiSta->wapiUsk.micKey;
+			pDataKey = pWapiSta->wapiUsk.dataKey;
+		} else if (pWapiSta->wapiUskUpdate.keyId == KeyIdx && pWapiSta->wapiUskUpdate.bSet) {
+			WAPI_TRACE(WAPI_RX, "%s: Use Updated USK for Decryption!!!\n", __FUNCTION__);
+			if (pWapiSta->bAuthenticatorInUpdata)
+				bUseUpdatedKey = true;
+			else
+				bUseUpdatedKey = false;
+
+			if (bQosData)
+				WapiSetLastRxUnicastPNForQoSData(TID, pRecvPN, pWapiSta);
+			else
+				memcpy(pWapiSta->lastRxUnicastPN, pRecvPN, 16);
+			pMicKey = pWapiSta->wapiUskUpdate.micKey;
+			pDataKey = pWapiSta->wapiUskUpdate.dataKey;
+		} else {
+			WAPI_TRACE(WAPI_ERR, "%s: No valid USK!!!KeyIdx=%d pWapiSta->wapiUsk.keyId=%d pWapiSta->wapiUskUpdate.keyId=%d\n", __FUNCTION__, KeyIdx, pWapiSta->wapiUsk.keyId,
+				   pWapiSta->wapiUskUpdate.keyId);
+			/* dump_buf(pskb->data,pskb->len); */
+			return false;
+		}
+	}
+
+	WAPI_DATA(WAPI_RX, "Decryption - DataKey", pDataKey, 16);
+	WAPI_DATA(WAPI_RX, "Decryption - IV", pRecvPN, 16);
+	WapiSMS4Decryption(pDataKey, pRecvPN, pSecData, DataLen, pSecData, &OutputLength);
+
+	if (OutputLength != DataLen)
+		WAPI_TRACE(WAPI_ERR, "%s:  Output Length Error!!!!\n", __FUNCTION__);
+
+	WAPI_DATA(WAPI_RX, "Decryption - After decryption", pskb->data, pskb->len);
+
+	DataLen -= padapter->wapiInfo.extra_postfix_len;
+
+	SecCalculateMicSMS4(KeyIdx, pMicKey, pskb->data, pSecData, DataLen, MicBuffer);
+
+	WAPI_DATA(WAPI_RX, "Decryption - MIC received", pRecvMic, SMS4_MIC_LEN);
+	WAPI_DATA(WAPI_RX, "Decryption - MIC calculated", MicBuffer, SMS4_MIC_LEN);
+
+	if (0 == memcmp(MicBuffer, pRecvMic, padapter->wapiInfo.extra_postfix_len)) {
+		WAPI_TRACE(WAPI_RX, "%s: Check MIC OK!!\n", __FUNCTION__);
+		if (bUseUpdatedKey) {
+			/* delete the old key */
+			if (IS_MCAST(pRA)) {
+				WAPI_TRACE(WAPI_API, "%s(): AE use new update MSK!!\n", __FUNCTION__);
+				pWapiSta->wapiMsk.keyId = pWapiSta->wapiMskUpdate.keyId;
+				memcpy(pWapiSta->wapiMsk.dataKey, pWapiSta->wapiMskUpdate.dataKey, 16);
+				memcpy(pWapiSta->wapiMsk.micKey, pWapiSta->wapiMskUpdate.micKey, 16);
+				pWapiSta->wapiMskUpdate.bTxEnable = pWapiSta->wapiMskUpdate.bSet = false;
+			} else {
+				WAPI_TRACE(WAPI_API, "%s(): AE use new update USK!!\n", __FUNCTION__);
+				pWapiSta->wapiUsk.keyId = pWapiSta->wapiUskUpdate.keyId;
+				memcpy(pWapiSta->wapiUsk.dataKey, pWapiSta->wapiUskUpdate.dataKey, 16);
+				memcpy(pWapiSta->wapiUsk.micKey, pWapiSta->wapiUskUpdate.micKey, 16);
+				pWapiSta->wapiUskUpdate.bTxEnable = pWapiSta->wapiUskUpdate.bSet = false;
+			}
+		}
+	} else {
+		WAPI_TRACE(WAPI_ERR, "%s:  Check MIC Error, Dropped !!!!\n", __FUNCTION__);
+		return false;
+	}
+
+	pos = pskb->data;
+	memmove(pos + padapter->wapiInfo.extra_prefix_len, pos, IVOffset);
+	skb_pull(pskb, padapter->wapiInfo.extra_prefix_len);
+
+	WAPI_TRACE(WAPI_RX, "<=========%s\n", __FUNCTION__);
+
+	return true;
+}
+
+u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe)
+{
+
+	u8	*pframe;
+	u32 res = _SUCCESS;
+
+	WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
+		WAPI_TRACE(WAPI_TX, "<========== %s, WAPI not supported or enabled!\n", __FUNCTION__);
+		return _FAIL;
+	}
+
+	if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
+		return _FAIL;
+
+	pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + TXDESC_OFFSET;
+
+	SecSWSMS4Encryption(padapter, pxmitframe);
+
+	WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
+	return res;
+}
+
+u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe)
+{
+	u8	*pframe;
+	u32 res = _SUCCESS;
+
+	WAPI_TRACE(WAPI_RX, "=========>%s\n", __FUNCTION__);
+
+	if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
+		WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or enabled!\n", __FUNCTION__);
+		return _FAIL;
+	}
+
+
+	/* drop packet when hw decrypt fail
+	* return tempraily */
+	return _FAIL;
+
+	/* pframe=(unsigned char *)((union recv_frame*)precvframe)->u.hdr.rx_data; */
+
+	if (false == SecSWSMS4Decryption(padapter, precvframe, &padapter->recvpriv)) {
+		WAPI_TRACE(WAPI_ERR, "%s():SMS4 decrypt frame error\n", __FUNCTION__);
+		return _FAIL;
+	}
+
+	WAPI_TRACE(WAPI_RX, "<=========%s\n", __FUNCTION__);
+	return res;
+}
+
+#else
+
+u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe)
+{
+	WAPI_TRACE(WAPI_TX, "=========>Dummy %s\n", __FUNCTION__);
+	WAPI_TRACE(WAPI_TX, "<=========Dummy %s\n", __FUNCTION__);
+	return _SUCCESS;
+}
+
+u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe)
+{
+	WAPI_TRACE(WAPI_RX, "=========>Dummy %s\n", __FUNCTION__);
+	WAPI_TRACE(WAPI_RX, "<=========Dummy %s\n", __FUNCTION__);
+	return _SUCCESS;
+}
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wlan_util.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wlan_util.c
index a21ae67327b5..570f6c08fa1a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wlan_util.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_wlan_util.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,18 +12,19 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_WLAN_UTIL_C_
 
 #include <drv_types.h>
+#include <hal_data.h>
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-#include <linux/inetdevice.h>
+	#include <linux/inetdevice.h>
+	#define ETH_TYPE_OFFSET	12
+	#define PROTOCOL_OFFSET	23
+	#define IP_OFFSET	30
+	#define IPv6_OFFSET	38
+	#define IPv6_PROTOCOL_OFFSET	20
 #endif
 
 unsigned char ARTHEROS_OUI1[] = {0x00, 0x03, 0x7f};
@@ -47,7 +49,7 @@ extern unsigned char RSN_TKIP_CIPHER[4];
 
 #define R2T_PHY_DELAY	(0)
 
-//#define WAIT_FOR_BCN_TO_MIN	(3000)
+/* #define WAIT_FOR_BCN_TO_MIN	(3000) */
 #define WAIT_FOR_BCN_TO_MIN	(6000)
 #define WAIT_FOR_BCN_TO_MAX	(20000)
 
@@ -55,32 +57,64 @@ extern unsigned char RSN_TKIP_CIPHER[4];
 #define DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD 3
 
 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
+	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
+	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
+	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
 };
 
+/* test if rate is defined in rtw_basic_rate_cck */
+bool rtw_is_basic_rate_cck(u8 rate)
+{
+	int i;
+
+	for (i = 0; i < 4; i++)
+		if ((rtw_basic_rate_cck[i] & 0x7F) == (rate & 0x7F))
+			return 1;
+	return 0;
+}
+
+/* test if rate is defined in rtw_basic_rate_ofdm */
+bool rtw_is_basic_rate_ofdm(u8 rate)
+{
+	int i;
+
+	for (i = 0; i < 3; i++)
+		if ((rtw_basic_rate_ofdm[i] & 0x7F) == (rate & 0x7F))
+			return 1;
+	return 0;
+}
+
+/* test if rate is defined in rtw_basic_rate_mix */
+bool rtw_is_basic_rate_mix(u8 rate)
+{
+	int i;
+
+	for (i = 0; i < 7; i++)
+		if ((rtw_basic_rate_mix[i] & 0x7F) == (rate & 0x7F))
+			return 1;
+	return 0;
+}
+
 int new_bcn_max = 3;
 
 int cckrates_included(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) )
+
+	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;
 	}
 
@@ -91,230 +125,72 @@ int cckrates_included(unsigned char *rate, int ratelen)
 int cckratesonly_included(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) )
+
+	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;
 }
 
-s8 rtw_get_tx_nss(_adapter *adapter, struct sta_info *psta)
+s8 rtw_get_sta_rx_nss(_adapter *adapter, struct sta_info *psta)
 {
-	u8 rf_type = RF_1T1R, custom_rf_type, vht_mcs[2];
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	u8 rf_type = RF_1T1R, custom_rf_type;
 	s8 nss = 1;
 
-	custom_rf_type = adapter->registrypriv.rf_config;
-	rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-	
 	if (!psta)
 		return nss;
-	
-	/* rf_config is dependent on efuse or sw config */
-	if (custom_rf_type != RF_MAX_TYPE)
+
+	custom_rf_type = adapter->registrypriv.rf_config;
+	rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+	if (RF_TYPE_VALID(custom_rf_type))
 		rf_type = custom_rf_type;
-	
-#ifdef CONFIG_80211AC_VHT
-	if (psta->vhtpriv.vht_option) {
-		u8 vht_mcs[2];
-		struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
-		struct vht_priv	*pvhtpriv_ap = &pmlmepriv->vhtpriv;
-		
-		_rtw_memcpy(vht_mcs, psta->vhtpriv.vht_mcs_map, 2);
-		/* doesn't support 5~8 SS so far */
-		vht_mcs[1] = 0xff;
-		switch (rf_type) {
-		case RF_1T1R:
-		case RF_1T2R:
-			vht_mcs[0] |= 0xfc;
-			break;
-		case RF_2T2R:
-		case RF_2T4R:
-		case RF_2T2R_GREEN:
-		case RF_2T3R:
-			vht_mcs[0] |= 0xf0;
-			break;
-		case RF_3T3R:
-		case RF_3T4R:
-			vht_mcs[0] |= 0xc0;
-			break;
-		default:
-			DBG_871X("%s,%d, unknown rf type\n", __func__, __LINE__);
-			break;
-		}
-		nss = rtw_vht_mcsmap_to_nss(vht_mcs);
-	} else
-#endif /* CONFIG_80211AC_VHT */
-	if (psta->htpriv.ht_option) {
-		u8 supp_mcs_set[4];
 
-		_rtw_memcpy(supp_mcs_set, psta->htpriv.ht_cap.supp_mcs_set, 4);
-		
-		switch (rf_type) {
-		case RF_1T1R:
-		case RF_1T2R:
-			supp_mcs_set[1] = supp_mcs_set[2] = supp_mcs_set[3] = 0;
-			break;
-		case RF_2T2R:
-		case RF_2T4R:
-		case RF_2T2R_GREEN:
-		case RF_2T3R:
-			supp_mcs_set[2] = supp_mcs_set[3] = 0;
-			break;
-		case RF_3T3R:
-		case RF_3T4R:
-			supp_mcs_set[3] = 0;
-			break;
-		default:
-			DBG_871X("%s,%d, unknown rf type\n", __func__, __LINE__);
-			break;
-		}
-		nss = rtw_ht_mcsset_to_nss(supp_mcs_set);
-	}
-	
-	DBG_871X("%s: %d SS, rf_type=%d\n", __func__, nss, rf_type);
+	nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
+
+#ifdef CONFIG_80211N_HT
+	#ifdef CONFIG_80211AC_VHT
+	if (psta->vhtpriv.vht_option)
+		nss = rtw_min(nss, rtw_vht_mcsmap_to_nss(psta->vhtpriv.vht_mcs_map));
+	else
+	#endif /* CONFIG_80211AC_VHT */
+	if (psta->htpriv.ht_option)
+		nss = rtw_min(nss, rtw_ht_mcsset_to_nss(psta->htpriv.ht_cap.supp_mcs_set));
+#endif /*CONFIG_80211N_HT*/
+	RTW_INFO("%s: %d SS\n", __func__, nss);
 	return nss;
 }
 
-u8 networktype_to_raid(_adapter *adapter,struct sta_info *psta)
+s8 rtw_get_sta_tx_nss(_adapter *adapter, struct sta_info *psta)
 {
-	unsigned char raid;
-	switch(psta->wireless_mode)
-	{
-		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;
-	
-}
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	u8 rf_type = RF_1T1R, custom_rf_type;
+	s8 nss = 1;
 
-u8 networktype_to_raid_ex(_adapter *adapter, struct sta_info *psta)
-{
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	u8 raid = RATEID_IDX_BGN_40M_1SS, cur_rf_type, rf_type, custom_rf_type;
-	s8 tx_nss;
+	if (!psta)
+		return nss;
 
-	tx_nss = rtw_get_tx_nss(adapter, psta);
+	custom_rf_type = adapter->registrypriv.rf_config;
+	rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+	if (RF_TYPE_VALID(custom_rf_type))
+		rf_type = custom_rf_type;
 
-	switch(psta->wireless_mode)
-	{
-		case WIRELESS_11B:
-			raid = RATEID_IDX_B;
-			break;
-		case WIRELESS_11A:
-		case WIRELESS_11G:
-			raid = RATEID_IDX_G;
-			break;
-		case WIRELESS_11BG:
-			raid = RATEID_IDX_BG;
-			break;
-		case WIRELESS_11_24N:
-		case WIRELESS_11_5N:
-		case WIRELESS_11A_5N:
-		case WIRELESS_11G_24N:
-			if (tx_nss == 1)
-				raid = RATEID_IDX_GN_N1SS;
-			else if (tx_nss == 2)
-				raid = RATEID_IDX_GN_N2SS;
-			else if (tx_nss == 3)
-				raid = RATEID_IDX_BGN_3SS;
-			else
-				DBG_871X("tx_nss error!(tx_nss=%d)\n", tx_nss);
-			break;
-		case WIRELESS_11B_24N:
-		case WIRELESS_11BG_24N:
-			if (psta->bw_mode == CHANNEL_WIDTH_20) {
-				if (tx_nss == 1)
-					raid = RATEID_IDX_BGN_20M_1SS_BN;
-				else if (tx_nss == 2)
-					raid = RATEID_IDX_BGN_20M_2SS_BN;
-				else if (tx_nss == 3)
-					raid = RATEID_IDX_BGN_3SS;
-				else
-				DBG_871X("tx_nss error!(tx_nss=%d)\n", tx_nss);
-			} else {
-				if (tx_nss == 1)
-					raid = RATEID_IDX_BGN_40M_1SS;
-				else if (tx_nss == 2)
-					raid = RATEID_IDX_BGN_40M_2SS;
-				else if (tx_nss == 3)
-					raid = RATEID_IDX_BGN_3SS;
-				else
-				DBG_871X("tx_nss error!(tx_nss=%d)\n", tx_nss);
-			}
-			break;
-#ifdef CONFIG_80211AC_VHT
-		case WIRELESS_11_5AC:
-			if (tx_nss == 1)
-				raid = RATEID_IDX_VHT_1SS;
-			else if (tx_nss == 2)
-				raid = RATEID_IDX_VHT_2SS;
-			else if (tx_nss == 3)
-				raid = RATEID_IDX_VHT_3SS;
-			else
-				DBG_871X("tx_nss error!(tx_nss=%d)\n", tx_nss);
-			break;
-		case WIRELESS_11_24AC:
-			if (psta->bw_mode >= CHANNEL_WIDTH_80)
-			{
-				if (tx_nss == 1)
-					raid = RATEID_IDX_VHT_1SS;
-				else if (tx_nss == 2)
-					raid = RATEID_IDX_VHT_2SS;
-				else if (tx_nss == 3)
-					raid = RATEID_IDX_VHT_3SS;
-				else
-					DBG_871X("tx_nss error!(tx_nss=%d)\n", tx_nss);
-			}
-			else
-			{
-				if (tx_nss == 1)
-					raid = RATEID_IDX_MIX1;
-				else if (tx_nss == 2)
-					raid = RATEID_IDX_MIX2;
-				else if (tx_nss == 3)
-					raid = RATEID_IDX_VHT_3SS;
-				else
-					DBG_871X("tx_nss error!(tx_nss=%d)\n", tx_nss);
-			}
-			break;
-#endif
-		default:
-			DBG_871X("unexpected wireless mode!(psta->wireless_mode=%x)\n", psta->wireless_mode);
-			break;	
+	nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
 
-	}
-	
-	/* DBG_871X("psta->wireless_mode=%x,  tx_nss=%d\n", psta->wireless_mode, tx_nss); */
-	
-	return raid;
-	
+#ifdef CONFIG_80211N_HT
+	#ifdef CONFIG_80211AC_VHT
+	if (psta->vhtpriv.vht_option)
+		nss = rtw_min(nss, rtw_vht_mcsmap_to_nss(psta->vhtpriv.vht_mcs_map));
+	else
+	#endif /* CONFIG_80211AC_VHT */
+	if (psta->htpriv.ht_option)
+		nss = rtw_min(nss, rtw_ht_mcsset_to_nss(psta->htpriv.ht_cap.supp_mcs_set));
+#endif /*CONFIG_80211N_HT*/
+	RTW_INFO("%s: %d SS\n", __func__, nss);
+	return nss;
 }
 
 u8 judge_network_type(_adapter *padapter, unsigned char *rate, int ratelen)
@@ -322,39 +198,28 @@ u8 judge_network_type(_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 (pmlmeext->cur_channel > 14) {
 		if (pmlmeinfo->VHT_enable)
 			network_type = WIRELESS_11AC;
 		else if (pmlmeinfo->HT_enable)
 			network_type = WIRELESS_11_5N;
 
 		network_type |= WIRELESS_11A;
-	}
-	else
-	{
+	} else {
 		if (pmlmeinfo->HT_enable)
-		{
 			network_type = WIRELESS_11_24N;
-		}
 
 		if ((cckratesonly_included(rate, ratelen)) == _TRUE)
-		{
 			network_type |= WIRELESS_11B;
-		}
-		else if((cckrates_included(rate, ratelen)) == _TRUE)
-		{
+		else if ((cckrates_included(rate, ratelen)) == _TRUE)
 			network_type |= WIRELESS_11BG;
-		}
 		else
-		{
 			network_type |= WIRELESS_11G;
-		}
 	}
-		
-	return 	network_type;
+
+	return	network_type;
 }
 
 unsigned char ratetbl_val_2wifirate(unsigned char rate);
@@ -362,55 +227,54 @@ unsigned char ratetbl_val_2wifirate(unsigned char rate)
 {
 	unsigned char val = 0;
 
-	switch (rate & 0x7f) 
-	{
-		case 0:
-			val = IEEE80211_CCK_RATE_1MB;
-			break;
+	switch (rate & 0x7f) {
+	case 0:
+		val = IEEE80211_CCK_RATE_1MB;
+		break;
 
-		case 1:
-			val = IEEE80211_CCK_RATE_2MB;
-			break;
+	case 1:
+		val = IEEE80211_CCK_RATE_2MB;
+		break;
 
-		case 2:
-			val = IEEE80211_CCK_RATE_5MB;
-			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 3:
+		val = IEEE80211_CCK_RATE_11MB;
+		break;
 
-		case 5:
-			val = IEEE80211_OFDM_RATE_9MB;
-			break;
+	case 4:
+		val = IEEE80211_OFDM_RATE_6MB;
+		break;
 
-		case 6:
-			val = IEEE80211_OFDM_RATE_12MB;
-			break;
-			
-		case 7:
-			val = IEEE80211_OFDM_RATE_18MB;
-			break;
+	case 5:
+		val = IEEE80211_OFDM_RATE_9MB;
+		break;
 
-		case 8:
-			val = IEEE80211_OFDM_RATE_24MB;
-			break;
-			
-		case 9:
-			val = IEEE80211_OFDM_RATE_36MB;
-			break;
+	case 6:
+		val = IEEE80211_OFDM_RATE_12MB;
+		break;
 
-		case 10:
-			val = IEEE80211_OFDM_RATE_48MB;
-			break;
-		
-		case 11:
-			val = IEEE80211_OFDM_RATE_54MB;
-			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;
 
 	}
 
@@ -424,20 +288,16 @@ int is_basicrate(_adapter *padapter, unsigned char rate)
 	int i;
 	unsigned char val;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	
-	for(i = 0; i < NumRates; i++)
-	{
+
+	for (i = 0; i < NumRates; i++) {
 		val = pmlmeext->basicrate[i];
 
-		if ((val != 0xff) && (val != 0xfe))
-		{
+		if ((val != 0xff) && (val != 0xfe)) {
 			if (rate == ratetbl_val_2wifirate(val))
-			{
 				return _TRUE;
-			}
 		}
 	}
-	
+
 	return _FALSE;
 }
 
@@ -449,29 +309,28 @@ unsigned int ratetbl2rateset(_adapter *padapter, unsigned char *rateset)
 	unsigned int	len = 0;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-	for (i = 0; i < NumRates; i++)
-	{
+	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 (rtw_get_oper_ch(padapter) > 14 && rate < _6M_RATE_) /*5G no support CCK rate*/
+			continue;
 
-				if (is_basicrate(padapter, rate) == _TRUE)
-				{
-					rate |= IEEE80211_BASIC_RATE_MASK;
-				}
-				
-				rateset[len] = rate;
-				len++;
-				break;
+		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;
@@ -488,10 +347,10 @@ void get_rate_set(_adapter *padapter, unsigned char *pbssrate, int *bssrate_len)
 
 void set_mcs_rate_by_mask(u8 *mcs_set, u32 mask)
 {
-	u8 mcs_rate_1r = (u8)(mask&0xff);
-	u8 mcs_rate_2r = (u8)((mask>>8)&0xff);
-	u8 mcs_rate_3r = (u8)((mask>>16)&0xff);
-	u8 mcs_rate_4r = (u8)((mask>>24)&0xff);
+	u8 mcs_rate_1r = (u8)(mask & 0xff);
+	u8 mcs_rate_2r = (u8)((mask >> 8) & 0xff);
+	u8 mcs_rate_3r = (u8)((mask >> 16) & 0xff);
+	u8 mcs_rate_4r = (u8)((mask >> 24) & 0xff);
 
 	mcs_set[0] &= mcs_rate_1r;
 	mcs_set[1] &= mcs_rate_2r;
@@ -507,21 +366,19 @@ void UpdateBrateTbl(
 	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++)
-	{
+	/* 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;
+		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;
 		}
 	}
 
@@ -532,43 +389,22 @@ void UpdateBrateTblForSoftAP(u8 *bssrateset, u32 bssratelen)
 	u8	i;
 	u8	rate;
 
-	for(i=0;i<bssratelen;i++)
-	{
+	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;
+		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;
 		}
 	}
 
 }
-static void Set_NETYPE1_MSR(_adapter *padapter, u8 type)
-{
-	rtw_hal_set_hwreg(padapter, HW_VAR_MEDIA_STATUS1, (u8 *)(&type));
-}
-
-static void Set_NETYPE0_MSR(_adapter *padapter, u8 type)
-{
-	rtw_hal_set_hwreg(padapter, HW_VAR_MEDIA_STATUS, (u8 *)(&type));
-}
-
 void Set_MSR(_adapter *padapter, u8 type)
 {
-#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->iface_type == IFACE_PORT1)
-	{
-		Set_NETYPE1_MSR(padapter, type);
-	}
-	else
-#endif
-	{
-		Set_NETYPE0_MSR(padapter, type);
-	}
+	rtw_hal_set_hwreg(padapter, HW_VAR_MEDIA_STATUS, (u8 *)(&type));
 }
 
 inline u8 rtw_get_oper_ch(_adapter *adapter)
@@ -585,28 +421,28 @@ inline void rtw_set_oper_ch(_adapter *adapter, u8 ch)
 	int i = 0;
 #endif  /* DBG_CH_SWITCH */
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	
+
 	if (dvobj->oper_channel != ch) {
 		dvobj->on_oper_ch_time = rtw_get_current_time();
 
 #ifdef DBG_CH_SWITCH
-		cnt += snprintf(msg+cnt, len-cnt, "switch to ch %3u", ch);
+		cnt += snprintf(msg + cnt, len - cnt, "switch to ch %3u", ch);
 
 		for (i = 0; i < dvobj->iface_nums; i++) {
 			_adapter *iface = dvobj->padapters[i];
-			cnt += snprintf(msg+cnt, len-cnt, " ["ADPT_FMT":", ADPT_ARG(iface));
+			cnt += snprintf(msg + cnt, len - cnt, " ["ADPT_FMT":", ADPT_ARG(iface));
 			if (iface->mlmeextpriv.cur_channel == ch)
-				cnt += snprintf(msg+cnt, len-cnt, "C");
+				cnt += snprintf(msg + cnt, len - cnt, "C");
 			else
-				cnt += snprintf(msg+cnt, len-cnt, "_");
+				cnt += snprintf(msg + cnt, len - cnt, "_");
 			if (iface->wdinfo.listen_channel == ch && !rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_NONE))
-				cnt += snprintf(msg+cnt, len-cnt, "L");
+				cnt += snprintf(msg + cnt, len - cnt, "L");
 			else
-				cnt += snprintf(msg+cnt, len-cnt, "_");
-			cnt += snprintf(msg+cnt, len-cnt, "]");
+				cnt += snprintf(msg + cnt, len - cnt, "_");
+			cnt += snprintf(msg + cnt, len - cnt, "]");
 		}
 
-		DBG_871X(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(adapter), msg);
+		RTW_INFO(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(adapter), msg);
 #endif /* DBG_CH_SWITCH */
 	}
 
@@ -633,97 +469,118 @@ inline void rtw_set_oper_choffset(_adapter *adapter, u8 offset)
 	adapter_to_dvobj(adapter)->oper_ch_offset = offset;
 }
 
-u8 rtw_get_offset_by_ch(u8 channel)
+u8 rtw_get_offset_by_chbw(u8 ch, u8 bw, u8 *r_offset)
 {
+	u8 valid = 1;
 	u8 offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 
-	if(channel>=1 && channel<=4)
-	{
-		offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-	}
-	else if(channel>=5 && channel<=14)
-	{
-		offset = HAL_PRIME_CHNL_OFFSET_UPPER;						
-	}
-	else
-	{
-		switch(channel)
-		{
-			case 36:
-			case 44:
-			case 52:
-			case 60:
-			case 100:
-			case 108:
-			case 116:
-			case 124:
-			case 132:
-			case 149:
-			case 157:
-				offset = HAL_PRIME_CHNL_OFFSET_LOWER;				
-				break;		
-			case 40:
-			case 48:
-			case 56:
-			case 64:
-			case 104:
-			case 112:
-			case 120:
-			case 128:
-			case 136:
-			case 153:
-			case 161:				
-				offset = HAL_PRIME_CHNL_OFFSET_UPPER;				
-				break;				
-			default:
-				offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-				break;
-		}
+	if (bw == CHANNEL_WIDTH_20)
+		goto exit;
 
+	if (bw >= CHANNEL_WIDTH_80 && ch <= 14) {
+		valid = 0;
+		goto exit;
 	}
 
-	return offset;
-		
+	if (ch >= 1 && ch <= 4)
+		offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+	else if (ch >= 5 && ch <= 9) {
+		if (*r_offset == HAL_PRIME_CHNL_OFFSET_LOWER || *r_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
+			offset = *r_offset; /* both lower and upper is valid, obey input value */
+		else
+			offset = HAL_PRIME_CHNL_OFFSET_UPPER; /* default use upper */
+	} else if (ch >= 10 && ch <= 13)
+		offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+	else if (ch == 14) {
+		valid = 0; /* ch14 doesn't support 40MHz bandwidth */
+		goto exit;
+	} else if (ch >= 36 && ch <= 177) {
+		switch (ch) {
+		case 36:
+		case 44:
+		case 52:
+		case 60:
+		case 100:
+		case 108:
+		case 116:
+		case 124:
+		case 132:
+		case 140:
+		case 149:
+		case 157:
+		case 165:
+		case 173:
+			offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+			break;
+		case 40:
+		case 48:
+		case 56:
+		case 64:
+		case 104:
+		case 112:
+		case 120:
+		case 128:
+		case 136:
+		case 144:
+		case 153:
+		case 161:
+		case 169:
+		case 177:
+			offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+			break;
+		default:
+			valid = 0;
+			break;
+		}
+	} else
+		valid = 0;
+
+exit:
+	if (valid && r_offset)
+		*r_offset = offset;
+	return valid;
 }
 
-u8	rtw_get_center_ch(u8 channel, u8 chnl_bw, u8 chnl_offset)
+u8 rtw_get_center_ch(u8 channel, u8 chnl_bw, u8 chnl_offset)
 {
-	u8	center_ch = channel;
+	u8 center_ch = channel;
 
-	if(chnl_bw == CHANNEL_WIDTH_80)
-	{
-		if((channel == 36) || (channel == 40) || (channel == 44) || (channel == 48) )
+	if (chnl_bw == CHANNEL_WIDTH_80) {
+		if (channel == 36 || channel == 40 || channel == 44 || channel == 48)
 			center_ch = 42;
-		if((channel == 52) || (channel == 56) || (channel == 60) || (channel == 64) )
+		else if (channel == 52 || channel == 56 || channel == 60 || channel == 64)
 			center_ch = 58;
-		if((channel == 100) || (channel == 104) || (channel == 108) || (channel == 112) )
+		else if (channel == 100 || channel == 104 || channel == 108 || channel == 112)
 			center_ch = 106;
-		if((channel == 116) || (channel == 120) || (channel == 124) || (channel == 128) )
+		else if (channel == 116 || channel == 120 || channel == 124 || channel == 128)
 			center_ch = 122;
-		if((channel == 132) || (channel == 136) || (channel == 140) || (channel == 144) )
+		else if (channel == 132 || channel == 136 || channel == 140 || channel == 144)
 			center_ch = 138;
-		if((channel == 149) || (channel == 153) || (channel == 157) || (channel == 161) )
+		else if (channel == 149 || channel == 153 || channel == 157 || channel == 161)
 			center_ch = 155;
-		else if(channel <= 14)
+		else if (channel == 165 || channel == 169 || channel == 173 || channel == 177)
+			center_ch = 171;
+		else if (channel <= 14)
 			center_ch = 7;
-	}
-	else if(chnl_bw == CHANNEL_WIDTH_40)
-	{
+	} else if (chnl_bw == CHANNEL_WIDTH_40) {
 		if (chnl_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
 			center_ch = channel + 2;
 		else
 			center_ch = channel - 2;
-	}
+	} else if (chnl_bw == CHANNEL_WIDTH_20)
+		center_ch = channel;
+	else
+		rtw_warn_on(1);
 
 	return center_ch;
 }
 
-inline u32 rtw_get_on_oper_ch_time(_adapter *adapter)
+inline systime rtw_get_on_oper_ch_time(_adapter *adapter)
 {
 	return adapter_to_dvobj(adapter)->on_oper_ch_time;
 }
 
-inline u32 rtw_get_on_cur_ch_time(_adapter *adapter)
+inline systime rtw_get_on_cur_ch_time(_adapter *adapter)
 {
 	if (adapter->mlmeextpriv.cur_channel == adapter_to_dvobj(adapter)->oper_channel)
 		return adapter_to_dvobj(adapter)->on_oper_ch_time;
@@ -735,81 +592,89 @@ void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char
 {
 	u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+#if (defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)) || defined(CONFIG_MCC_MODE)
+	u8 iqk_info_backup = _FALSE;
+#endif
 
-	if ( padapter->bNotifyChannelChange )
-	{
-		DBG_871X( "[%s] ch = %d, offset = %d, bwmode = %d\n", __FUNCTION__, channel, channel_offset, bwmode );
-	}
+	if (padapter->bNotifyChannelChange)
+		RTW_INFO("[%s] ch = %d, offset = %d, bwmode = %d\n", __FUNCTION__, channel, channel_offset, bwmode);
 
 	center_ch = rtw_get_center_ch(channel, bwmode, channel_offset);
 
-	if(bwmode == CHANNEL_WIDTH_80)
-	{
-		if(center_ch > channel)
+	if (bwmode == CHANNEL_WIDTH_80) {
+		if (center_ch > channel)
 			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
-		else if(center_ch < channel)
+		else if (center_ch < channel)
 			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
 		else
 			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 	}
 	_enter_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
 
-#ifdef CONFIG_DFS_MASTER
-{
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	bool ori_overlap_radar_detect_ch = rtw_rfctl_overlap_radar_detect_ch(rfctl);
-	bool new_overlap_radar_detect_ch = _rtw_rfctl_overlap_radar_detect_ch(rfctl, channel, bwmode, channel_offset);
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter)) {
+		/* driver doesn't set channel setting reg under MCC */
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+			RTW_INFO("Warning: Do not set channel setting reg MCC mode\n");
+	}
+#endif
 
-	if (!ori_overlap_radar_detect_ch && new_overlap_radar_detect_ch)
-		rtw_odm_radar_detect_enable(padapter);
+#ifdef CONFIG_DFS_MASTER
+	{
+		struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+		bool ori_overlap_radar_detect_ch = rtw_rfctl_overlap_radar_detect_ch(rfctl);
+		bool new_overlap_radar_detect_ch = _rtw_rfctl_overlap_radar_detect_ch(rfctl, channel, bwmode, channel_offset);
 
-	if (new_overlap_radar_detect_ch && IS_UNDER_CAC(rfctl)) {
-		u8 pause = 0xFF;
+		if (new_overlap_radar_detect_ch && IS_CH_WAITING(rfctl)) {
+			u8 pause = 0xFF;
 
-		rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &pause);
-	}
+			rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &pause);
+		}
 #endif /* CONFIG_DFS_MASTER */
 
-	//set Channel
-	//saved channel/bw info
-	rtw_set_oper_ch(padapter, channel);
-	rtw_set_oper_bw(padapter, bwmode);
-	rtw_set_oper_choffset(padapter, channel_offset);
+		/* set Channel */
+		/* saved channel/bw info */
+		rtw_set_oper_ch(padapter, channel);
+		rtw_set_oper_bw(padapter, bwmode);
+		rtw_set_oper_choffset(padapter, channel_offset);
+
+#if (defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)) || defined(CONFIG_MCC_MODE)
+		/* To check if we need to backup iqk info after switch chnl & bw */
+		{
+			u8 take_care_iqk, do_iqk;
+
+			rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
+			rtw_hal_get_hwreg(padapter, HW_VAR_DO_IQK, &do_iqk);
+			if ((take_care_iqk == _TRUE) && (do_iqk == _TRUE))
+				iqk_info_backup = _TRUE;
+		}
+#endif
 
-	rtw_hal_set_chnl_bw(padapter, center_ch, bwmode, channel_offset, chnl_offset80); // set center channel
+		rtw_hal_set_chnl_bw(padapter, center_ch, bwmode, channel_offset, chnl_offset80); /* set center channel */
+
+#if (defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)) || defined(CONFIG_MCC_MODE)
+		if (iqk_info_backup == _TRUE)
+			rtw_hal_ch_sw_iqk_info_backup(padapter);
+#endif
 
 #ifdef CONFIG_DFS_MASTER
-	if (ori_overlap_radar_detect_ch && !new_overlap_radar_detect_ch) {
-		u8 pause = 0x00;
+		if (new_overlap_radar_detect_ch)
+			rtw_odm_radar_detect_enable(padapter);
+		else if (ori_overlap_radar_detect_ch) {
+			u8 pause = 0x00;
 
-		rtw_odm_radar_detect_disable(padapter);
-		rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &pause);
+			rtw_odm_radar_detect_disable(padapter);
+			rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &pause);
+		}
 	}
-}
 #endif /* CONFIG_DFS_MASTER */
 
 	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
 }
 
-int get_bsstype(unsigned short capability)
-{
-	if (capability & BIT(0))
-	{
-		return WIFI_FW_AP_STATE;
-	}
-	else if (capability & BIT(1))
-	{
-		return WIFI_FW_ADHOC_STATE;
-	}
-	else
-	{
-		return 0;		
-	}
-}
-
 __inline u8 *get_my_bssid(WLAN_BSSID_EX *pnetwork)
-{	
-	return (pnetwork->MacAddress); 
+{
+	return pnetwork->MacAddress;
 }
 
 u16 get_beacon_interval(WLAN_BSSID_EX *bss)
@@ -817,7 +682,7 @@ u16 get_beacon_interval(WLAN_BSSID_EX *bss)
 	unsigned short val;
 	_rtw_memcpy((unsigned char *)&val, rtw_get_beacon_interval_from_ie(bss->IEs), 2);
 
-	return le16_to_cpu(val);	
+	return le16_to_cpu(val);
 
 }
 
@@ -826,35 +691,27 @@ int is_client_associated_to_ap(_adapter *padapter)
 	struct mlme_ext_priv	*pmlmeext;
 	struct mlme_ext_info	*pmlmeinfo;
 
-	if(!padapter)
+	if (!padapter)
 		return _FAIL;
 
 	pmlmeext = &padapter->mlmeextpriv;
 	pmlmeinfo = &(pmlmeext->mlmext_info);
-	
-	if ((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) && ((pmlmeinfo->state&0x03) == WIFI_FW_STATION_STATE))
-	{
+
+	if ((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) && ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE))
 		return _TRUE;
-	}
 	else
-	{
 		return _FAIL;
-	}
 }
 
 int is_client_associated_to_ibss(_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) == WIFI_FW_ADHOC_STATE))
-	{
+
+	if ((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) && ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
 		return _TRUE;
-	}
 	else
-	{
 		return _FAIL;
-	}
 }
 
 int is_IBSS_empty(_adapter *padapter)
@@ -865,7 +722,7 @@ int is_IBSS_empty(_adapter *padapter)
 	for (i = 0; i < macid_ctl->num; i++) {
 		if (!rtw_macid_is_used(macid_ctl, i))
 			continue;
-		if (rtw_macid_get_if_g(macid_ctl, i) != padapter->iface_id)
+		if (!rtw_macid_is_iface_specific(macid_ctl, i, padapter))
 			continue;
 		if (!GET_H2CCMD_MSRRPT_PARM_OPMODE(&macid_ctl->h2c_msr[i]))
 			continue;
@@ -879,22 +736,16 @@ int is_IBSS_empty(_adapter *padapter)
 unsigned int decide_wait_for_beacon_timeout(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));
-	}
+		return bcn_interval << 2;
 }
 
 void CAM_empty_entry(
-	PADAPTER     	Adapter,	
-	u8 			ucIndex
+	PADAPTER	Adapter,
+	u8			ucIndex
 )
 {
 	rtw_hal_set_hwreg(Adapter, HW_VAR_CAM_EMPTY_ENTRY, (u8 *)(&ucIndex));
@@ -918,7 +769,7 @@ void invalidate_cam_all(_adapter *padapter)
 void _clear_cam_entry(_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};
+	unsigned char null_key[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
 
 	rtw_sec_write_cam_ent(padapter, entry, 0, null_sta, null_key);
 }
@@ -926,10 +777,10 @@ void _clear_cam_entry(_adapter *padapter, u8 entry)
 inline void write_cam(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
 {
 #ifdef CONFIG_WRITE_CACHE_ONLY
-	write_cam_cache(adapter, id ,ctrl, mac, key);
+	write_cam_cache(adapter, id , ctrl, mac, key);
 #else
 	rtw_sec_write_cam_ent(adapter, id, ctrl, mac, key);
-	write_cam_cache(adapter, id ,ctrl, mac, key);
+	write_cam_cache(adapter, id , ctrl, mac, key);
 #endif
 }
 
@@ -952,7 +803,6 @@ inline void write_cam_from_cache(_adapter *adapter, u8 id)
 
 	rtw_sec_write_cam_ent(adapter, id, cache.ctrl, cache.mac, cache.key);
 }
-
 void write_cam_cache(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
@@ -981,53 +831,10 @@ void clear_cam_cache(_adapter *adapter, u8 id)
 	_exit_critical_bh(&cam_ctl->lock, &irqL);
 }
 
-s16 rtw_get_camid(_adapter *adapter, struct sta_info *sta, s16 kid)
+inline bool _rtw_camctl_chk_cap(_adapter *adapter, u8 cap)
 {
-	u8 macid;
-	s16 camid;
-
-	//cam_entry:
-	//0~3 for default key
-
-	//for concurrent mode (ap+sta, sta+sta):
-	//default key is disable, using sw encrypt/decrypt
-	//camid 0, 1, 2, 3 is default entry for default key/group key
-	//macid = 1 is for bc/mc stainfo, no mapping to camid
-	//macid = 0 mapping to camid 4
-	//for macid >=2, camid = macid+3;
-
-	if (sta) {
-		struct mlme_ext_info *mlmeinfo = &adapter->mlmeextpriv.mlmext_info;
-		macid = sta->mac_id;
-
-		if((mlmeinfo->state&0x03) == WIFI_FW_AP_STATE) {
-			if((macid == 1) || (macid>(NUM_STA-4))){
-				DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" failed, mac_id=%d\n", FUNC_ADPT_ARG(adapter), macid);
-				camid = -1;
-				goto exit;
-			}
-		}
-
-		if(macid==0)
-			camid = 4;
-		else if(macid >=2)
-			camid = macid + 3;
-		else
-			camid = 4;
-	}
-	else {
-		/* default key is disabled */
-		camid = -1;
-	}
-
-exit:
-	return (s16)camid;
-}
-
-inline bool _rtw_camctl_chk_cap(_adapter *adapter, u8 cap)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
 
 	if (cam_ctl->sec_cap & cap)
 		return _TRUE;
@@ -1084,36 +891,36 @@ inline bool _rtw_camctl_chk_flags(_adapter *adapter, u32 flags)
 
 void dump_sec_cam_map(void *sel, struct sec_cam_bmp *map, u8 max_num)
 {
-	DBG_871X_SEL_NL(sel, "0x%08x\n", map->m0);
+	RTW_PRINT_SEL(sel, "0x%08x\n", map->m0);
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
 	if (max_num && max_num > 32)
-		DBG_871X_SEL_NL(sel, "0x%08x\n", map->m1);
+		RTW_PRINT_SEL(sel, "0x%08x\n", map->m1);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
 	if (max_num && max_num > 64)
-		DBG_871X_SEL_NL(sel, "0x%08x\n", map->m2);
+		RTW_PRINT_SEL(sel, "0x%08x\n", map->m2);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
 	if (max_num && max_num > 96)
-		DBG_871X_SEL_NL(sel, "0x%08x\n", map->m3);
+		RTW_PRINT_SEL(sel, "0x%08x\n", map->m3);
 #endif
 }
 
 inline bool rtw_sec_camid_is_set(struct sec_cam_bmp *map, u8 id)
 {
 	if (id < 32)
-		return (map->m0 & BIT(id));
+		return map->m0 & BIT(id);
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
 	else if (id < 64)
-		return (map->m1 & BIT(id - 32));
+		return map->m1 & BIT(id - 32);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
 	else if (id < 96)
-		return (map->m2 & BIT(id - 64));
+		return map->m2 & BIT(id - 64);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
 	else if (id < 128)
-		return (map->m3 & BIT(id - 96));
+		return map->m3 & BIT(id - 96);
 #endif
 	else
 		rtw_warn_on(1);
@@ -1147,15 +954,15 @@ inline void rtw_sec_cam_map_clr(struct sec_cam_bmp *map, u8 id)
 		map->m0 &= ~BIT(id);
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
 	else if (id < 64)
-		map->m1 &= ~BIT(id-32);
+		map->m1 &= ~BIT(id - 32);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
 	else if (id < 96)
-		map->m2 &= ~BIT(id-64);
+		map->m2 &= ~BIT(id - 64);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
 	else if (id < 128)
-		map->m3 &= ~BIT(id-96);
+		map->m3 &= ~BIT(id - 96);
 #endif
 	else
 		rtw_warn_on(1);
@@ -1191,18 +998,18 @@ inline bool rtw_sec_camid_is_drv_forbid(struct cam_ctl_t *cam_ctl, u8 id)
 #endif
 
 	if (id < 32)
-		return (forbid_map.m0 & BIT(id));
+		return forbid_map.m0 & BIT(id);
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
 	else if (id < 64)
-		return (forbid_map.m1 & BIT(id - 32));
+		return forbid_map.m1 & BIT(id - 32);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
 	else if (id < 96)
-		return (forbid_map.m2 & BIT(id - 64));
+		return forbid_map.m2 & BIT(id - 64);
 #endif
 #if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
 	else if (id < 128)
-		return (forbid_map.m3 & BIT(id - 96));
+		return forbid_map.m3 & BIT(id - 96);
 #endif
 	else
 		rtw_warn_on(1);
@@ -1219,12 +1026,12 @@ bool _rtw_sec_camid_is_used(struct cam_ctl_t *cam_ctl, u8 id)
 		goto exit;
 	}
 
-	#if 0 /* for testing */
+#if 0 /* for testing */
 	if (rtw_sec_camid_is_drv_forbid(cam_ctl, id)) {
 		ret = _TRUE;
 		goto exit;
 	}
-	#endif
+#endif
 
 	ret = rtw_sec_camid_is_set(&cam_ctl->used, id);
 
@@ -1243,6 +1050,26 @@ inline bool rtw_sec_camid_is_used(struct cam_ctl_t *cam_ctl, u8 id)
 
 	return ret;
 }
+u8 rtw_get_sec_camid(_adapter *adapter, u8 max_bk_key_num, u8 *sec_key_id)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	int i;
+	_irqL irqL;
+	u8 sec_cam_num = 0;
+
+	_enter_critical_bh(&cam_ctl->lock, &irqL);
+	for (i = 0; i < cam_ctl->num; i++) {
+		if (_rtw_sec_camid_is_used(cam_ctl, i)) {
+			sec_key_id[sec_cam_num++] = i;
+			if (sec_cam_num == max_bk_key_num)
+				break;
+		}
+	}
+	_exit_critical_bh(&cam_ctl->lock, &irqL);
+
+	return sec_cam_num;
+}
 
 inline bool _rtw_camid_is_gk(_adapter *adapter, u8 cam_id)
 {
@@ -1257,8 +1084,8 @@ inline bool _rtw_camid_is_gk(_adapter *adapter, u8 cam_id)
 
 	if (_rtw_sec_camid_is_used(cam_ctl, cam_id) == _FALSE)
 		goto exit;
-	
-	ret = (dvobj->cam_cache[cam_id].ctrl&BIT6)?_TRUE:_FALSE;
+
+	ret = (dvobj->cam_cache[cam_id].ctrl & BIT6) ? _TRUE : _FALSE;
 
 exit:
 	return ret;
@@ -1285,9 +1112,9 @@ bool cam_cache_chk(_adapter *adapter, u8 id, u8 *addr, s16 kid, s8 gk)
 
 	if (addr && _rtw_memcmp(dvobj->cam_cache[id].mac, addr, ETH_ALEN) == _FALSE)
 		goto exit;
-	if (kid >= 0 && kid != (dvobj->cam_cache[id].ctrl&0x03))
+	if (kid >= 0 && kid != (dvobj->cam_cache[id].ctrl & 0x03))
 		goto exit;
-	if (gk != -1 && (gk?_TRUE:_FALSE) != _rtw_camid_is_gk(adapter, id))
+	if (gk != -1 && (gk ? _TRUE : _FALSE) != _rtw_camid_is_gk(adapter, id))
 		goto exit;
 
 	ret = _TRUE;
@@ -1312,10 +1139,10 @@ s16 _rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk)
 
 	if (0) {
 		if (addr)
-			DBG_871X(FUNC_ADPT_FMT" addr:"MAC_FMT" kid:%d, gk:%d, return cam_id:%d\n"
+			RTW_INFO(FUNC_ADPT_FMT" addr:"MAC_FMT" kid:%d, gk:%d, return cam_id:%d\n"
 				, FUNC_ADPT_ARG(adapter), MAC_ARG(addr), kid, gk, cam_id);
 		else
-			DBG_871X(FUNC_ADPT_FMT" addr:%p kid:%d, gk:%d, return cam_id:%d\n"
+			RTW_INFO(FUNC_ADPT_FMT" addr:%p kid:%d, gk:%d, return cam_id:%d\n"
 				, FUNC_ADPT_ARG(adapter), addr, kid, gk, cam_id);
 	}
 
@@ -1336,88 +1163,113 @@ s16 rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk)
 	return cam_id;
 }
 
-s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used)
+s16 rtw_get_camid(_adapter *adapter, u8 *addr, s16 kid, u8 gk)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
-	_irqL irqL;
+	int i;
+#if 0 /* for testing */
+	static u8 start_id = 0;
+#else
+	u8 start_id = 0;
+#endif
 	s16 cam_id = -1;
 
-	*used = _FALSE;
+	if (addr == NULL) {
+		RTW_PRINT(FUNC_ADPT_FMT" mac_address is NULL\n"
+			  , FUNC_ADPT_ARG(adapter));
+		rtw_warn_on(1);
+		goto _exit;
+	}
 
-	_enter_critical_bh(&cam_ctl->lock, &irqL);
+	/* find cam entry which has the same addr, kid (, gk bit) */
+	if (_rtw_camctl_chk_cap(adapter, SEC_CAP_CHK_BMC) == _TRUE)
+		i = _rtw_camid_search(adapter, addr, kid, gk);
+	else
+		i = _rtw_camid_search(adapter, addr, kid, -1);
 
-#ifdef DYNAMIC_CAMID_ALLOC
-	{
-		struct mlme_ext_info *mlmeinfo = &adapter->mlmeextpriv.mlmext_info;
-
-		if((((mlmeinfo->state&0x03) == WIFI_FW_AP_STATE) || ((mlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE))
-			&& !sta) {
-			/* AP/Ad-hoc mode group key: static alloction to default key by key ID */
-			if (kid > 3) {
-				DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" group key with invalid key id:%u\n"
-					, FUNC_ADPT_ARG(adapter), kid);
-				rtw_warn_on(1);
-				goto bitmap_handle;
-			}
-			cam_id = kid;
-		}
-		else {
-			int i;
-			u8 *addr = sta?sta->hwaddr:NULL;
-			#if 0 /* for testing */
-			static u8 start_id = 0;
-			#else
-			u8 start_id = 0;
-			#endif
+	if (i >= 0) {
+		cam_id = i;
+		goto _exit;
+	}
 
-			if(!sta) {
-				if (!(mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
-					/* bypass STA mode group key setting before connected(ex:WEP) because bssid is not ready */
-					goto bitmap_handle;
-				}
+	for (i = 0; i < cam_ctl->num; i++) {
+		/* bypass default key which is allocated statically */
+#ifndef CONFIG_CONCURRENT_MODE
+		if (((i + start_id) % cam_ctl->num) < 4)
+			continue;
+#endif
+		if (_rtw_sec_camid_is_used(cam_ctl, ((i + start_id) % cam_ctl->num)) == _FALSE)
+			break;
+	}
 
-				addr = get_bssid(&adapter->mlmepriv);
-			}
+	if (i == cam_ctl->num) {
+		RTW_PRINT(FUNC_ADPT_FMT" %s key with "MAC_FMT" id:%u no room\n"
+			, FUNC_ADPT_ARG(adapter), gk ? "group" : "pairwise", MAC_ARG(addr), kid);
+		rtw_warn_on(1);
+		goto _exit;
+	}
 
-			/* find cam entry which has the same addr, kid (, gk bit) */
-			if (_rtw_camctl_chk_cap(adapter, SEC_CAP_CHK_BMC) == _TRUE)
-				i = _rtw_camid_search(adapter, addr, kid, sta?_FALSE:_TRUE);
-			else
-				i = _rtw_camid_search(adapter, addr, kid, -1);
+	cam_id = ((i + start_id) % cam_ctl->num);
+	start_id = ((i + start_id + 1) % cam_ctl->num);
 
-			if (i >= 0) {
-				cam_id = i;
-				goto bitmap_handle;
-			}
+_exit:
+	return cam_id;
+}
+
+s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, u8 gk, bool *used)
+{
+	struct mlme_ext_info *mlmeinfo = &adapter->mlmeextpriv.mlmext_info;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	_irqL irqL;
+	s16 cam_id = -1;
 
-			for (i = 0; i < cam_ctl->num; i++) {
-				/* bypass default key which is allocated statically */
-				if (((i + start_id) % cam_ctl->num) < 4)
-					continue;
+	*used = _FALSE;
 
-				if (_rtw_sec_camid_is_used(cam_ctl, ((i + start_id) % cam_ctl->num)) == _FALSE)
-					break;
-			}
+	_enter_critical_bh(&cam_ctl->lock, &irqL);
 
-			if (i == cam_ctl->num) {
-				if (sta)
-					DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" pairwise key with "MAC_FMT" id:%u no room\n"
-					, FUNC_ADPT_ARG(adapter), MAC_ARG(addr), kid);
-				else
-					DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" group key with "MAC_FMT" id:%u no room\n"
-					, FUNC_ADPT_ARG(adapter), MAC_ARG(addr), kid);
-				rtw_warn_on(1);
+	if ((((mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((mlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
+	    && !sta) {
+		/*
+		* 1. non-STA mode WEP key
+		* 2. group TX key
+		*/
+#ifndef CONFIG_CONCURRENT_MODE
+		/* static alloction to default key by key ID when concurrent is not defined */
+		if (kid > 3) {
+			RTW_PRINT(FUNC_ADPT_FMT" group key with invalid key id:%u\n"
+				  , FUNC_ADPT_ARG(adapter), kid);
+			rtw_warn_on(1);
+			goto bitmap_handle;
+		}
+		cam_id = kid;
+#else
+		u8 *addr = adapter_mac_addr(adapter);
+
+		cam_id = rtw_get_camid(adapter, addr, kid, gk);
+		if (1)
+			RTW_PRINT(FUNC_ADPT_FMT" group key with "MAC_FMT" assigned cam_id:%u\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(addr), cam_id);
+#endif
+	} else {
+		/*
+		* 1. STA mode WEP key
+		* 2. STA mode group RX key
+		* 3. sta key (pairwise, group RX)
+		*/
+		u8 *addr = sta ? sta->cmn.mac_addr : NULL;
+
+		if (!sta) {
+			if (!(mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
+				/* bypass STA mode group key setting before connected(ex:WEP) because bssid is not ready */
 				goto bitmap_handle;
 			}
-
-			cam_id = ((i + start_id) % cam_ctl->num);
-			start_id = ((i + start_id + 1) % cam_ctl->num);
+			addr = get_bssid(&adapter->mlmepriv);/*A2*/
 		}
+		cam_id = rtw_get_camid(adapter, addr, kid, gk);
 	}
-#else
-	cam_id = rtw_get_camid(adapter, sta, kid);
-#endif /* DYNAMIC_CAMID_ALLOC */
+
 
 bitmap_handle:
 	if (cam_id >= 0) {
@@ -1430,6 +1282,20 @@ bitmap_handle:
 	return cam_id;
 }
 
+void rtw_camid_set(_adapter *adapter, u8 cam_id)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	_irqL irqL;
+
+	_enter_critical_bh(&cam_ctl->lock, &irqL);
+
+	if (cam_id < cam_ctl->num)
+		rtw_sec_cam_map_set(&cam_ctl->used, cam_id);
+
+	_exit_critical_bh(&cam_ctl->lock, &irqL);
+}
+
 void rtw_camid_free(_adapter *adapter, u8 cam_id)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
@@ -1444,60 +1310,156 @@ void rtw_camid_free(_adapter *adapter, u8 cam_id)
 	_exit_critical_bh(&cam_ctl->lock, &irqL);
 }
 
+/*Must pause TX/RX before use this API*/
+inline void rtw_sec_cam_swap(_adapter *adapter, u8 cam_id_a, u8 cam_id_b)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	struct sec_cam_ent cache_a, cache_b;
+	_irqL irqL;
+	bool cam_a_used, cam_b_used;
+
+	if (1)
+		RTW_INFO(ADPT_FMT" - sec_cam %d,%d swap\n", ADPT_ARG(adapter), cam_id_a, cam_id_b);
+
+	if (cam_id_a == cam_id_b)
+		return;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	rtw_mi_update_ap_bmc_camid(adapter, cam_id_a, cam_id_b);
+#endif
+
+	/*setp-1. backup org cam_info*/
+	_enter_critical_bh(&cam_ctl->lock, &irqL);
+
+	cam_a_used = _rtw_sec_camid_is_used(cam_ctl, cam_id_a);
+	cam_b_used = _rtw_sec_camid_is_used(cam_ctl, cam_id_b);
+
+	if (cam_a_used)
+		_rtw_memcpy(&cache_a, &dvobj->cam_cache[cam_id_a], sizeof(struct sec_cam_ent));
+
+	if (cam_b_used)
+		_rtw_memcpy(&cache_b, &dvobj->cam_cache[cam_id_b], sizeof(struct sec_cam_ent));
+
+	_exit_critical_bh(&cam_ctl->lock, &irqL);
+
+	/*setp-2. clean cam_info*/
+	if (cam_a_used) {
+		rtw_camid_free(adapter, cam_id_a);
+		clear_cam_entry(adapter, cam_id_a);
+	}
+	if (cam_b_used) {
+		rtw_camid_free(adapter, cam_id_b);
+		clear_cam_entry(adapter, cam_id_b);
+	}
+
+	/*setp-3. set cam_info*/
+	if (cam_a_used) {
+		write_cam(adapter, cam_id_b, cache_a.ctrl, cache_a.mac, cache_a.key);
+		rtw_camid_set(adapter, cam_id_b);
+	}
+
+	if (cam_b_used) {
+		write_cam(adapter, cam_id_a, cache_b.ctrl, cache_b.mac, cache_b.key);
+		rtw_camid_set(adapter, cam_id_a);
+	}
+}
+
+s16 rtw_get_empty_cam_entry(_adapter *adapter, u8 start_camid)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	_irqL irqL;
+	int i;
+	s16 cam_id = -1;
+
+	_enter_critical_bh(&cam_ctl->lock, &irqL);
+	for (i = start_camid; i < cam_ctl->num; i++) {
+		if (_FALSE == _rtw_sec_camid_is_used(cam_ctl, i)) {
+			cam_id = i;
+			break;
+		}
+	}
+	_exit_critical_bh(&cam_ctl->lock, &irqL);
+
+	return cam_id;
+}
+void rtw_clean_dk_section(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
+	s16 ept_cam_id;
+	int i;
+
+	for (i = 0; i < 4; i++) {
+		if (rtw_sec_camid_is_used(cam_ctl, i)) {
+			ept_cam_id = rtw_get_empty_cam_entry(adapter, 4);
+			if (ept_cam_id > 0)
+				rtw_sec_cam_swap(adapter, i, ept_cam_id);
+		}
+	}
+}
+void rtw_clean_hw_dk_cam(_adapter *adapter)
+{
+	int i;
+
+	for (i = 0; i < 4; i++)
+		rtw_sec_clr_cam_ent(adapter, i);
+		/*_clear_cam_entry(adapter, i);*/
+}
+
 void flush_all_cam_entry(_adapter *padapter)
 {
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct security_priv *psecpriv = &padapter->securitypriv;
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if(check_buddy_fwstate(padapter, _FW_LINKED) == _TRUE)
-	{
-		if(check_fwstate(pmlmepriv, WIFI_STATION_STATE))
-		{
-			struct sta_priv	*pstapriv = &padapter->stapriv;
-			struct sta_info	*psta;
-
-			psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
-			if(psta) {
-				if(psta->state & WIFI_AP_STATE)
-				{}   //clear cam when ap free per sta_info        
-				else {
-					rtw_clearstakey_cmd(padapter, psta, _FALSE);
-				}
-			}
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+		struct sta_priv	*pstapriv = &padapter->stapriv;
+		struct sta_info		*psta;
+
+		psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
+		if (psta) {
+			if (psta->state & WIFI_AP_STATE) {
+				/*clear cam when ap free per sta_info*/
+			} else
+				rtw_clearstakey_cmd(padapter, psta, _FALSE);
 		}
-		else if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-		{
-			/* clear default key */
-			int i, cam_id;
-			u8 null_addr[ETH_ALEN]= {0,0,0,0,0,0};
-
-			for (i=0;i<4;i++) {
-				cam_id = rtw_camid_search(padapter, null_addr, i, -1);
-				if (cam_id >= 0) {
-					clear_cam_entry(padapter, cam_id);
-					rtw_camid_free(padapter, cam_id);
-				}
+	} else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+#if 1
+		int cam_id = -1;
+		u8 *addr = adapter_mac_addr(padapter);
+
+		while ((cam_id = rtw_camid_search(padapter, addr, -1, -1)) >= 0) {
+			RTW_PRINT("clear wep or group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(addr), cam_id);
+			clear_cam_entry(padapter, cam_id);
+			rtw_camid_free(padapter, cam_id);
+		}
+#else
+		/* clear default key */
+		int i, cam_id;
+		u8 null_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
+
+		for (i = 0; i < 4; i++) {
+			cam_id = rtw_camid_search(padapter, null_addr, i, -1);
+			if (cam_id >= 0) {
+				clear_cam_entry(padapter, cam_id);
+				rtw_camid_free(padapter, cam_id);
 			}
-
-			/* clear default key related key search setting */
-			#ifdef DYNAMIC_CAMID_ALLOC
-			rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8*)_FALSE);
-			#endif
-
-			/* leave pairwise key when ap free per sta_info */
 		}
-	}
-	else
-#endif //CONFIG_CONCURRENT_MODE
-	{
-		invalidate_cam_all(padapter);
 		/* clear default key related key search setting */
-		#ifdef DYNAMIC_CAMID_ALLOC
-		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8*)_FALSE);
-		#endif
+		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8 *)_FALSE);
+#endif
 	}
+
+#else /*NON CONFIG_CONCURRENT_MODE*/
+
+	invalidate_cam_all(padapter);
+	/* clear default key related key search setting */
+	rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8 *)_FALSE);
+#endif
 }
 
 #if defined(CONFIG_P2P) && defined(CONFIG_WFD)
@@ -1511,11 +1473,11 @@ void rtw_process_wfd_ie(_adapter *adapter, u8 *wfd_ie, u8 wfd_ielen, const char
 	if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
 		return;
 
-	DBG_871X("[%s] Found WFD IE\n", tag);
+	RTW_INFO("[%s] Found WFD IE\n", tag);
 	attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &attr_contentlen);
 	if (attr_content && attr_contentlen) {
 		wdinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
-		DBG_871X("[%s] Peer PORT NUM = %d\n", tag, wdinfo->wfd_info->peer_rtsp_ctrlport);
+		RTW_INFO("[%s] Peer PORT NUM = %d\n", tag, wdinfo->wfd_info->peer_rtsp_ctrlport);
 	}
 }
 
@@ -1537,48 +1499,39 @@ void rtw_process_wfd_ies(_adapter *adapter, u8 *ies, u8 ies_len, const char *tag
 
 int WMM_param_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs	pIE)
 {
-	//struct registry_priv	*pregpriv = &padapter->registrypriv;
+	/* 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->qospriv.qos_option==0)
-	{
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (pmlmepriv->qospriv.qos_option == 0) {
 		pmlmeinfo->WMM_enable = 0;
 		return _FALSE;
-	}	
-	
-	if(_rtw_memcmp(&(pmlmeinfo->WMM_param), (pIE->data + 6), sizeof(struct WMM_para_element)))
-	{
-		return _FALSE;
 	}
+
+	if (_rtw_memcmp(&(pmlmeinfo->WMM_param), (pIE->data + 6), sizeof(struct WMM_para_element)))
+		return _FALSE;
 	else
-	{
 		_rtw_memcpy(&(pmlmeinfo->WMM_param), (pIE->data + 6), sizeof(struct WMM_para_element));
-	}
 	pmlmeinfo->WMM_enable = 1;
 	return _TRUE;
 
-	/*if (pregpriv->wifi_spec == 1)
-	{
-		if (pmlmeinfo->WMM_enable == 1)
-		{
-			//todo: compare the parameter set count & decide wheher to update or not
+#if 0
+	if (pregpriv->wifi_spec == 1) {
+		if (pmlmeinfo->WMM_enable == 1) {
+			/* todo: compare the parameter set count & decide wheher to update or not */
 			return _FAIL;
-		}
-		else
-		{
+		} else {
 			pmlmeinfo->WMM_enable = 1;
 			_rtw_rtw_memcpy(&(pmlmeinfo->WMM_param), (pIE->data + 6), sizeof(struct WMM_para_element));
 			return _TRUE;
 		}
-	}
-	else
-	{
+	} else {
 		pmlmeinfo->WMM_enable = 0;
 		return _FAIL;
-	}*/
-	
+	}
+#endif
+
 }
 
 void WMMOnAssocRsp(_adapter *padapter)
@@ -1592,22 +1545,25 @@ void WMMOnAssocRsp(_adapter *padapter)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct xmit_priv		*pxmitpriv = &padapter->xmitpriv;
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
+#ifdef CONFIG_WMMPS_STA
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct qos_priv	*pqospriv = &pmlmepriv->qospriv;
+#endif /* CONFIG_WMMPS_STA */	
 
 	acm_mask = 0;
 
-	if (IsSupported5G(pmlmeext->cur_wireless_mode) || 
-		(pmlmeext->cur_wireless_mode & WIRELESS_11_24N) )
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) ||
+	    (pmlmeext->cur_wireless_mode & WIRELESS_11_24N))
 		aSifsTime = 16;
 	else
 		aSifsTime = 10;
 
-	if (pmlmeinfo->WMM_enable == 0)
-	{
+	if (pmlmeinfo->WMM_enable == 0) {
 		padapter->mlmepriv.acm_mask = 0;
 
 		AIFS = aSifsTime + (2 * pmlmeinfo->slotTime);
 
-		if (pmlmeext->cur_wireless_mode & (WIRELESS_11G |WIRELESS_11A)) {
+		if (pmlmeext->cur_wireless_mode & (WIRELESS_11G | WIRELESS_11A)) {
 			ECWMin = 4;
 			ECWMax = 10;
 		} else if (pmlmeext->cur_wireless_mode & WIRELESS_11B) {
@@ -1629,17 +1585,14 @@ void WMMOnAssocRsp(_adapter *padapter)
 		TXOP = 0x2f;
 		acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
 		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
-	}
-	else
-	{
+	} else {
 		edca[0] = edca[1] = edca[2] = edca[3] = 0;
 
-		for (i = 0; i < 4; i++)  
-		{
+		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 = 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);
@@ -1648,66 +1601,61 @@ void WMMOnAssocRsp(_adapter *padapter)
 
 			acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
 
-			switch (ACI)
-			{
-				case 0x0:
-					rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
-					acm_mask |= (ACM? BIT(1):0);
-					edca[XMIT_BE_QUEUE] = acParm;
-					break;
-
-				case 0x1:
-					rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
-					//acm_mask |= (ACM? BIT(0):0);
-					edca[XMIT_BK_QUEUE] = acParm;
-					break;
-
-				case 0x2:
-					rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
-					acm_mask |= (ACM? BIT(2):0);
-					edca[XMIT_VI_QUEUE] = acParm;
-					break;
-
-				case 0x3:
-					rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
-					acm_mask |= (ACM? BIT(3):0);
-					edca[XMIT_VO_QUEUE] = acParm;
-					break;							
+			switch (ACI) {
+			case 0x0:
+				rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
+				acm_mask |= (ACM ? BIT(1) : 0);
+				edca[XMIT_BE_QUEUE] = acParm;
+				break;
+
+			case 0x1:
+				rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
+				/* acm_mask |= (ACM? BIT(0):0); */
+				edca[XMIT_BK_QUEUE] = acParm;
+				break;
+
+			case 0x2:
+				rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
+				acm_mask |= (ACM ? BIT(2) : 0);
+				edca[XMIT_VI_QUEUE] = acParm;
+				break;
+
+			case 0x3:
+				rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
+				acm_mask |= (ACM ? BIT(3) : 0);
+				edca[XMIT_VO_QUEUE] = acParm;
+				break;
 			}
 
-			DBG_871X("WMM(%x): %x, %x\n", ACI, ACM, acParm);
+			RTW_INFO("WMM(%x): %x, %x\n", ACI, ACM, acParm);
 		}
 
-		if(padapter->registrypriv.acm_method == 1)
+		if (padapter->registrypriv.acm_method == 1)
 			rtw_hal_set_hwreg(padapter, HW_VAR_ACM_CTRL, (u8 *)(&acm_mask));
 		else
 			padapter->mlmepriv.acm_mask = acm_mask;
 
-		inx[0] = 0; inx[1] = 1; inx[2] = 2; inx[3] = 3;
+		inx[0] = 0;
+		inx[1] = 1;
+		inx[2] = 2;
+		inx[3] = 3;
 
-		if(pregpriv->wifi_spec==1)
-		{
-			u32	j, tmp, 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))
-					{
+		if (pregpriv->wifi_spec == 1) {
+			u32	j, tmp, 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))
+					else if ((edca[j] & 0xFFFF) == (edca[i] & 0xFFFF)) {
+						/* compare TXOP */
+						if ((edca[j] >> 16) > (edca[i] >> 16))
 							change_inx = _TRUE;
 					}
-				
-					if(change_inx)
-					{
+
+					if (change_inx) {
 						tmp = edca[i];
 						edca[i] = edca[j];
 						edca[j] = tmp;
@@ -1722,10 +1670,18 @@ void WMMOnAssocRsp(_adapter *padapter)
 			}
 		}
 
-		for(i=0; i<4; i++) {
+		for (i = 0; i < 4; i++) {
 			pxmitpriv->wmm_para_seq[i] = inx[i];
-			DBG_871X("wmm_para_seq(%d): %d\n", i, pxmitpriv->wmm_para_seq[i]);
+			RTW_INFO("wmm_para_seq(%d): %d\n", i, pxmitpriv->wmm_para_seq[i]);
 		}
+		
+#ifdef CONFIG_WMMPS_STA
+		/* if AP supports UAPSD function, driver must set each uapsd TID to coresponding mac register 0x693 */
+		if (pmlmeinfo->WMM_param.QoS_info & AP_SUPPORTED_UAPSD) {
+			pqospriv->uapsd_ap_supported = 1;
+			rtw_hal_set_hwreg(padapter, HW_VAR_UAPSD_TID, NULL);
+		}
+#endif /* CONFIG_WMMPS_STA */
 	}
 }
 
@@ -1734,24 +1690,26 @@ static void bwmode_update_check(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pI
 #ifdef CONFIG_80211N_HT
 	unsigned char	 new_bwmode;
 	unsigned char  new_ch_offset;
-	struct HT_info_element	 *pHT_info;
+	struct HT_info_element	*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;
-	u8	cbw40_enable=0;
+	u8	cbw40_enable = 0;
 
-	if(!pIE)
+	if (!pIE)
 		return;
 
-	if(phtpriv->ht_option == _FALSE)	return;
+	if (phtpriv->ht_option == _FALSE)
+		return;
 
-	if(pmlmeext->cur_bwmode >= CHANNEL_WIDTH_80)	return;
+	if (pmlmeext->cur_bwmode >= CHANNEL_WIDTH_80)
+		return;
 
-	if(pIE->Length > sizeof(struct HT_info_element))
+	if (pIE->Length > sizeof(struct HT_info_element))
 		return;
-	
+
 	pHT_info = (struct HT_info_element *)pIE->data;
 
 	if (hal_chk_bw_cap(padapter, BW_CAP_40M)) {
@@ -1764,83 +1722,71 @@ static void bwmode_update_check(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pI
 		}
 	}
 
-	if((pHT_info->infos[0] & BIT(2)) && cbw40_enable)
-	{
+	if ((pHT_info->infos[0] & BIT(2)) && cbw40_enable) {
 		new_bwmode = CHANNEL_WIDTH_40;
 
-		switch (pHT_info->infos[0] & 0x3)
-		{
-			case 1:
-				new_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-				break;
-			
-			case 3:
-				new_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-				break;
-				
-			default:
-				new_bwmode = CHANNEL_WIDTH_20;
-				new_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-				break;
+		switch (pHT_info->infos[0] & 0x3) {
+		case 1:
+			new_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+			break;
+
+		case 3:
+			new_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+			break;
+
+		default:
+			new_bwmode = CHANNEL_WIDTH_20;
+			new_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			break;
 		}
-	}
-	else
-	{
+	} else {
 		new_bwmode = 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)
-		&& new_bwmode < pmlmeext->cur_bwmode
-	) {
+	    && new_bwmode < pmlmeext->cur_bwmode
+	   ) {
 		pmlmeinfo->bwmode_updated = _TRUE;
-		
+
 		pmlmeext->cur_bwmode = new_bwmode;
 		pmlmeext->cur_ch_offset = new_ch_offset;
 
-		//update HT info also
+		/* update HT info also */
 		HT_info_handler(padapter, pIE);
-	}
-	else
-	{
+	} else
 		pmlmeinfo->bwmode_updated = _FALSE;
-	}
-		
 
-	if(_TRUE == pmlmeinfo->bwmode_updated)
-	{
+
+	if (_TRUE == pmlmeinfo->bwmode_updated) {
 		struct sta_info *psta;
-		WLAN_BSSID_EX 	*cur_network = &(pmlmeinfo->network);
+		WLAN_BSSID_EX	*cur_network = &(pmlmeinfo->network);
 		struct sta_priv	*pstapriv = &padapter->stapriv;
-	
-		//set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
 
-		
-		//update ap's stainfo
+		/* set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
+
+
+		/* update ap's stainfo */
 		psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
-		if(psta)
-		{
+		if (psta) {
 			struct ht_priv	*phtpriv_sta = &psta->htpriv;
-			
-			if(phtpriv_sta->ht_option)
-			{				
-				// bwmode				
-				psta->bw_mode = pmlmeext->cur_bwmode;
-				phtpriv_sta->ch_offset = pmlmeext->cur_ch_offset;		
-			}
-			else
-			{
-				psta->bw_mode = CHANNEL_WIDTH_20;
+
+			if (phtpriv_sta->ht_option) {
+				/* bwmode				 */
+				psta->cmn.bw_mode = pmlmeext->cur_bwmode;
+				phtpriv_sta->ch_offset = pmlmeext->cur_ch_offset;
+			} else {
+				psta->cmn.bw_mode = CHANNEL_WIDTH_20;
 				phtpriv_sta->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 			}
 
 			rtw_dm_ra_mask_wk_cmd(padapter, (u8 *)psta);
 		}
 
-		//pmlmeinfo->bwmode_updated = _FALSE;//bwmode_updated done, reset it!
-	}	
-#endif //CONFIG_80211N_HT
+		/* pmlmeinfo->bwmode_updated = _FALSE; */ /* bwmode_updated done, reset it! */
+	}
+#endif /* CONFIG_80211N_HT */
 }
 
 void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
@@ -1849,166 +1795,163 @@ void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 	unsigned int	i;
 	u8	rf_type = RF_1T1R;
 	u8	max_AMPDU_len, min_MPDU_spacing;
-	u8	cur_ldpc_cap=0, cur_stbc_cap=0, cur_beamform_cap=0;
+	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, cur_beamform_cap = 0, tx_nss = 0;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv 		*pmlmepriv = &padapter->mlmepriv;	
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv			*phtpriv = &pmlmepriv->htpriv;
-	struct registry_priv 	*pregistrypriv = &padapter->registrypriv;
-	
-	if(pIE==NULL) return;
-	
-	if(phtpriv->ht_option == _FALSE)	return;
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+
+	if (pIE == NULL)
+		return;
+
+	if (phtpriv->ht_option == _FALSE)
+		return;
 
 	pmlmeinfo->HT_caps_enable = 1;
-	
-	for (i = 0; i < (pIE->Length); i++)
-	{
-		if (i != 2)
-		{
-			//	Commented by Albert 2010/07/12
-			//	Got the endian issue here.
+
+	for (i = 0; i < (pIE->Length); i++) {
+		if (i != 2) {
+			/*	Commented by Albert 2010/07/12 */
+			/*	Got the endian issue here. */
 			pmlmeinfo->HT_caps.u.HT_cap[i] &= (pIE->data[i]);
-		}
-		else
-		{
+		} else {
 			/* AMPDU Parameters field */
 
 			/* Get MIN of MAX AMPDU Length Exp */
 			if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3) > (pIE->data[i] & 0x3))
-			{
 				max_AMPDU_len = (pIE->data[i] & 0x3);
-			}
 			else
-			{
 				max_AMPDU_len = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3);
-			}
 
 			/* Get MAX of MIN MPDU Start Spacing */
 			if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) > (pIE->data[i] & 0x1c))
-			{
 				min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c);
-			}
 			else
-			{
 				min_MPDU_spacing = (pIE->data[i] & 0x1c);
-			}
 
 			pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para = max_AMPDU_len | min_MPDU_spacing;
 		}
 	}
 
-	//	Commented by Albert 2010/07/12
-	//	Have to handle the endian issue after copying.
-	//	HT_ext_caps didn't be used yet.	
-	pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info = le16_to_cpu( pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info );
-	pmlmeinfo->HT_caps.u.HT_cap_element.HT_ext_caps = le16_to_cpu( pmlmeinfo->HT_caps.u.HT_cap_element.HT_ext_caps );
+	/*	Commented by Albert 2010/07/12 */
+	/*	Have to handle the endian issue after copying. */
+	/*	HT_ext_caps didn't be used yet.	 */
+	pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info = le16_to_cpu(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info);
+	pmlmeinfo->HT_caps.u.HT_cap_element.HT_ext_caps = le16_to_cpu(pmlmeinfo->HT_caps.u.HT_cap_element.HT_ext_caps);
 
-	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-
-
-	//update the MCS set
+	/* update the MCS set */
 	for (i = 0; i < 16; i++)
 		pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate[i] &= pmlmeext->default_supported_mcs_set[i];
-			
-	//update the MCS rates
-	switch(rf_type)
-	{
-		case RF_1T1R:
-		case RF_1T2R:
-			set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_1R);							
-			break;
-		case RF_2T2R:
-			#ifdef CONFIG_DISABLE_MCS13TO15
-			if(pmlmeext->cur_bwmode == CHANNEL_WIDTH_40 && pregistrypriv->wifi_spec != 1 )				
-				set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R_13TO15_OFF);				
-			else
-				set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R);
-#else //CONFIG_DISABLE_MCS13TO15
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+	tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
+
+	switch (tx_nss) {
+	case 1:
+		set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_1R);
+		break;
+	case 2:
+		#ifdef CONFIG_DISABLE_MCS13TO15
+		if (pmlmeext->cur_bwmode == CHANNEL_WIDTH_40 && pregistrypriv->wifi_spec != 1)
+			set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R_13TO15_OFF);
+		else
+		#endif
 			set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R);
-#endif //CONFIG_DISABLE_MCS13TO15
-			break;
-		case RF_3T3R:
-			set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_3R);
-			break;
-		default:
-			DBG_871X("[warning] rf_type %d is not expected\n", rf_type);
+		break;
+	case 3:
+		set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_3R);
+		break;
+	case 4:
+		set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_4R);
+		break;
+	default:
+		RTW_WARN("rf_type:%d or tx_nss:%u is not expected\n", rf_type, hal_spec->tx_nss_num);
 	}
 
 	if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-		// Config STBC setting
-		if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_TX_STBC(pIE->data))
-		{
+		/* Config STBC setting */
+		if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(pIE->data)) {
 			SET_FLAG(cur_stbc_cap, STBC_HT_ENABLE_TX);
-			DBG_871X("Enable HT Tx STBC !\n");
+			RTW_INFO("Enable HT Tx STBC !\n");
 		}
 		phtpriv->stbc_cap = cur_stbc_cap;
 
 #ifdef CONFIG_BEAMFORMING
-		// Config Tx beamforming setting
-		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) && 
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data))
-		{
+		/* Config Tx beamforming setting */
+		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data)) {
 			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
 			/* Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
 			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pIE->data) << 6);
 		}
 
 		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data))
-		{
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data)) {
 			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
 			/* Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
 			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pIE->data) << 4);
 		}
 		phtpriv->beamform_cap = cur_beamform_cap;
-		if (cur_beamform_cap) {
-			DBG_871X("AP HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
-		}
+		if (cur_beamform_cap)
+			RTW_INFO("AP HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
 #endif /*CONFIG_BEAMFORMING*/
 	} else {
 		/*WIFI_STATION_STATEorI_ADHOC_STATE or WIFI_ADHOC_MASTER_STATE*/
-		// Config LDPC Coding Capability
-		if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX) && GET_HT_CAP_ELE_LDPC_CAP(pIE->data))
-		{
+		/* Config LDPC Coding Capability */
+		if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX) && GET_HT_CAP_ELE_LDPC_CAP(pIE->data)) {
 			SET_FLAG(cur_ldpc_cap, (LDPC_HT_ENABLE_TX | LDPC_HT_CAP_TX));
-			DBG_871X("Enable HT Tx LDPC!\n");
+			RTW_INFO("Enable HT Tx LDPC!\n");
 		}
 		phtpriv->ldpc_cap = cur_ldpc_cap;
 
-		// Config STBC setting
-		if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(pIE->data))
-		{
-			SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX) );
-			DBG_871X("Enable HT Tx STBC!\n");
+		/* Config STBC setting */
+		if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(pIE->data)) {
+			SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX));
+			RTW_INFO("Enable HT Tx STBC!\n");
 		}
 		phtpriv->stbc_cap = cur_stbc_cap;
 
 #ifdef CONFIG_BEAMFORMING
-		// Config Tx beamforming setting
-		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) && 
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data))
-		{
+#ifdef RTW_BEAMFORMING_VERSION_2
+		/* Config beamforming setting */
+		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data)) {
+			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
+			/* Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
+			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pIE->data) << 6);
+		}
+
+		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data)) {
+			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
+			/* Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
+			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pIE->data) << 4);
+		}
+#else /* !RTW_BEAMFORMING_VERSION_2 */
+		/* Config Tx beamforming setting */
+		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data)) {
 			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
 			/* Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
 			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pIE->data) << 6);
 		}
 
 		if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
-			GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data))
-		{
+		    GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data)) {
 			SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
 			/* Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
 			SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pIE->data) << 4);
 		}
+#endif /* !RTW_BEAMFORMING_VERSION_2 */
 		phtpriv->beamform_cap = cur_beamform_cap;
-		if (cur_beamform_cap) {
-			DBG_871X("Client HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
-		}
+		if (cur_beamform_cap)
+			RTW_INFO("Client HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
 #endif /*CONFIG_BEAMFORMING*/
 	}
 
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 }
 
 void HT_info_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
@@ -2016,20 +1959,22 @@ void HT_info_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 #ifdef CONFIG_80211N_HT
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv 		*pmlmepriv = &padapter->mlmepriv;	
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv			*phtpriv = &pmlmepriv->htpriv;
 
-	if(pIE==NULL) return;
+	if (pIE == NULL)
+		return;
 
-	if(phtpriv->ht_option == _FALSE)	return;
+	if (phtpriv->ht_option == _FALSE)
+		return;
 
 
-	if(pIE->Length > sizeof(struct HT_info_element))
+	if (pIE->Length > sizeof(struct HT_info_element))
 		return;
-	
+
 	pmlmeinfo->HT_info_enable = 1;
 	_rtw_memcpy(&(pmlmeinfo->HT_info), pIE->data, pIE->Length);
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 	return;
 }
 
@@ -2037,84 +1982,78 @@ void HTOnAssocRsp(_adapter *padapter)
 {
 	unsigned char		max_AMPDU_len;
 	unsigned char		min_MPDU_spacing;
-	//struct registry_priv	 *pregpriv = &padapter->registrypriv;
+	/* struct registry_priv	 *pregpriv = &padapter->registrypriv; */
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	
-	DBG_871X("%s\n", __FUNCTION__);
+
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	if ((pmlmeinfo->HT_info_enable) && (pmlmeinfo->HT_caps_enable))
-	{
 		pmlmeinfo->HT_enable = 1;
-	}
-	else
-	{
+	else {
 		pmlmeinfo->HT_enable = 0;
-		//set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
+		/* set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
 		return;
 	}
-	
-	//handle A-MPDU parameter field
-	/* 	
+
+	/* 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	
+		AMPDU_para [4:2]:Min MPDU Start Spacing
 	*/
-	max_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;	
-	
-	min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;	
+	max_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;
+
+	min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MIN_SPACE, (u8 *)(&min_MPDU_spacing));
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&max_AMPDU_len));
 
-#if 0 //move to rtw_update_ht_cap()
+#if 0 /* move to rtw_update_ht_cap() */
 	if ((pregpriv->bw_mode > 0) &&
-		(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & BIT(1)) && 
-		(pmlmeinfo->HT_info.infos[0] & BIT(2)))
-	{
-		//switch to the 40M Hz mode accoring to the AP
+	    (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & BIT(1)) &&
+	    (pmlmeinfo->HT_info.infos[0] & BIT(2))) {
+		/* switch to the 40M Hz mode accoring to the AP */
 		pmlmeext->cur_bwmode = CHANNEL_WIDTH_40;
-		switch ((pmlmeinfo->HT_info.infos[0] & 0x3))
-		{
-			case EXTCHNL_OFFSET_UPPER:
-				pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-				break;
-			
-			case EXTCHNL_OFFSET_LOWER:
-				pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-				break;
-				
-			default:
-				pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-				break;
+		switch ((pmlmeinfo->HT_info.infos[0] & 0x3)) {
+		case EXTCHNL_OFFSET_UPPER:
+			pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+			break;
+
+		case EXTCHNL_OFFSET_LOWER:
+			pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+			break;
+
+		default:
+			pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			break;
 		}
 	}
 #endif
 
-	//set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
+	/* set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
 
-#if 0 //move to rtw_update_ht_cap()
-	//
-	// Config SM Power Save setting
-	//
+#if 0 /* move to rtw_update_ht_cap() */
+	/*  */
+	/* Config SM Power Save setting */
+	/*  */
 	pmlmeinfo->SM_PS = (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & 0x0C) >> 2;
-	if(pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC)
-	{
-		/*u8 i;
-		//update the MCS rates
+	if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC) {
+#if 0
+		u8 i;
+		/* update the MCS rates */
 		for (i = 0; i < 16; i++)
-		{
 			pmlmeinfo->HT_caps.HT_cap_element.MCS_rate[i] &= MCS_rate_1R[i];
-		}*/
-		DBG_871X("%s(): WLAN_HT_CAP_SM_PS_STATIC\n",__FUNCTION__);
+#endif
+		RTW_INFO("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __FUNCTION__);
 	}
 
-	//
-	// Config current HT Protection mode.
-	//
+	/*  */
+	/* Config current HT Protection mode. */
+	/*  */
 	pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3;
 #endif
-	
+
 }
 
 void ERP_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
@@ -2122,57 +2061,53 @@ void ERP_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	if(pIE->Length>1)
+	if (pIE->Length > 1)
 		return;
-	
+
 	pmlmeinfo->ERP_enable = 1;
 	_rtw_memcpy(&(pmlmeinfo->ERP_IE), pIE->data, pIE->Length);
 }
 
 void VCS_update(_adapter *padapter, struct sta_info *psta)
 {
-	struct registry_priv	 *pregpriv = &padapter->registrypriv;
+	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);
 
-	switch (pregpriv->vrtl_carrier_sense)/* 0:off 1:on 2:auto */
-	{
-		case 0: //off
-			psta->rtsen = 0;
+	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 == 1) { /* 1:RTS/CTS 2:CTS to self */
+			psta->rtsen = 1;
 			psta->cts2self = 0;
-			break;
-			
-		case 1: //on
-			if (pregpriv->vcs_type == 1) /* 1:RTS/CTS 2:CTS to self */
-			{
+		} else {
+			psta->rtsen = 0;
+			psta->cts2self = 1;
+		}
+		break;
+
+	case 2: /* auto */
+	default:
+		if (((pmlmeinfo->ERP_enable) && (pmlmeinfo->ERP_IE & BIT(1)))
+			/*||(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)*/
+		) {
+			if (pregpriv->vcs_type == 1) {
 				psta->rtsen = 1;
 				psta->cts2self = 0;
-			}
-			else
-			{
+			} else {
 				psta->rtsen = 0;
 				psta->cts2self = 1;
 			}
-			break;
-			
-		case 2: //auto
-		default:
-			if (((pmlmeinfo->ERP_enable) && (pmlmeinfo->ERP_IE & BIT(1)))
-				/*||(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)*/
-				) {
-				if (pregpriv->vcs_type == 1) {
-					psta->rtsen = 1;
-					psta->cts2self = 0;
-				} else {
-					psta->rtsen = 0;
-					psta->cts2self = 1;
-				}
-			} else {
-				psta->rtsen = 0;
-				psta->cts2self = 0;
-			}	
-			break;
+		} else {
+			psta->rtsen = 0;
+			psta->cts2self = 0;
+		}
+		break;
 	}
 }
 
@@ -2182,28 +2117,78 @@ void	update_ldpc_stbc_cap(struct sta_info *psta)
 
 #ifdef CONFIG_80211AC_VHT
 	if (psta->vhtpriv.vht_option) {
-		if(TEST_FLAG(psta->vhtpriv.ldpc_cap, LDPC_VHT_ENABLE_TX))
-			psta->ldpc = 1;
+		if (TEST_FLAG(psta->vhtpriv.ldpc_cap, LDPC_VHT_ENABLE_TX))
+			psta->cmn.ldpc_en = VHT_LDPC_EN;
+		else
+			psta->cmn.ldpc_en = 0;
 
-		if(TEST_FLAG(psta->vhtpriv.stbc_cap, STBC_VHT_ENABLE_TX))
-			psta->stbc = 1;
-	}
-	else
-#endif //CONFIG_80211AC_VHT
-	if (psta->htpriv.ht_option) {
-		if(TEST_FLAG(psta->htpriv.ldpc_cap, LDPC_HT_ENABLE_TX))
-			psta->ldpc = 1;
+		if (TEST_FLAG(psta->vhtpriv.stbc_cap, STBC_VHT_ENABLE_TX))
+			psta->cmn.stbc_en = VHT_STBC_EN;
+		else
+			psta->cmn.stbc_en = 0;
+	} else
+#endif /* CONFIG_80211AC_VHT */
+		if (psta->htpriv.ht_option) {
+			if (TEST_FLAG(psta->htpriv.ldpc_cap, LDPC_HT_ENABLE_TX))
+				psta->cmn.ldpc_en = HT_LDPC_EN;
+			else
+				psta->cmn.ldpc_en = 0;
 
-		if(TEST_FLAG(psta->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
-			psta->stbc = 1;
-	} else {
-		psta->ldpc = 0;
-		psta->stbc = 0;
+			if (TEST_FLAG(psta->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
+				psta->cmn.stbc_en = HT_STBC_EN;
+			else
+				psta->cmn.stbc_en = 0;
+		} else {
+			psta->cmn.ldpc_en = 0;
+			psta->cmn.stbc_en = 0;
+		}
+
+#endif /* CONFIG_80211N_HT */
+}
+
+int check_ielen(u8 *start, uint len)
+{
+	int left = len;
+	u8 *pos = start;
+	int unknown = 0;
+	u8 id, elen;
+
+	while (left >= 2) {
+		id = *pos++;
+		elen = *pos++;
+		left -= 2;
+
+		if (elen > left) {
+			RTW_INFO("IEEE 802.11 element parse failed (id=%d elen=%d left=%lu)\n",
+					id, elen, (unsigned long) left);
+			return _FALSE;
+		}
+		if ((id == WLAN_EID_VENDOR_SPECIFIC) && (elen < 4))
+				return _FALSE;
+
+		left -= elen;
+		pos += elen;
 	}
+	if (left)
+		return _FALSE;
 
-#endif //CONFIG_80211N_HT
+	return _TRUE;
 }
 
+int validate_beacon_len(u8 *pframe, u32 len)
+{
+	u8 ie_offset = _BEACON_IE_OFFSET_ + sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	if (len < ie_offset) {
+		RTW_INFO("%s: incorrect beacon length(%d)\n", __func__, len);
+		return _FALSE;
+	}
+
+	if (check_ielen(pframe + ie_offset, len - ie_offset) == _FALSE)
+		return _FALSE;
+
+	return _TRUE;
+}
 
 /*
  * rtw_get_bcn_keys: get beacon keys from recv frame
@@ -2215,7 +2200,7 @@ void	update_ldpc_stbc_cap(struct sta_info *psta)
  *	WLAN_EID_PWR_CONSTRAINT
  */
 int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
-		struct beacon_keys *recv_beacon)
+		     struct beacon_keys *recv_beacon)
 {
 	int left;
 	u16 capability;
@@ -2255,42 +2240,41 @@ int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
 	/* Checking for channel */
 	if (elems.ds_params && elems.ds_params_len == sizeof(recv_beacon->bcn_channel))
 		_rtw_memcpy(&recv_beacon->bcn_channel, elems.ds_params,
-				sizeof(recv_beacon->bcn_channel));
+			    sizeof(recv_beacon->bcn_channel));
 	else if (pht_info)
 		/* In 5G, some ap do not have DSSET IE checking HT info for channel */
 		recv_beacon->bcn_channel = pht_info->primary_channel;
 	else {
 		/* we don't find channel IE, so don't check it */
-		//DBG_871X("Oops: %s we don't find channel IE, so don't check it \n", __func__);
+		/* RTW_INFO("Oops: %s we don't find channel IE, so don't check it\n", __func__); */
 		recv_beacon->bcn_channel = Adapter->mlmeextpriv.cur_channel;
 	}
 
 	/* checking SSID */
 	if (elems.ssid) {
-	       if (elems.ssid_len > sizeof(recv_beacon->ssid))
+		if (elems.ssid_len > sizeof(recv_beacon->ssid))
 			return _FALSE;
 
-	       _rtw_memcpy(recv_beacon->ssid, elems.ssid, elems.ssid_len);
-	       recv_beacon->ssid_len = elems.ssid_len;
-	} else; // means hidden ssid
+		_rtw_memcpy(recv_beacon->ssid, elems.ssid, elems.ssid_len);
+		recv_beacon->ssid_len = elems.ssid_len;
+	} else
+		; /* means hidden ssid */
 
 	/* checking RSN first */
 	if (elems.rsn_ie && elems.rsn_ie_len) {
 		recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WPA2;
 		rtw_parse_wpa2_ie(elems.rsn_ie - 2, elems.rsn_ie_len + 2,
 			&recv_beacon->group_cipher, &recv_beacon->pairwise_cipher,
-			&recv_beacon->is_8021x);
+				  &recv_beacon->is_8021x, NULL);
 	}
 	/* checking WPA secon */
 	else if (elems.wpa_ie && elems.wpa_ie_len) {
 		recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WPA;
 		rtw_parse_wpa_ie(elems.wpa_ie - 2, elems.wpa_ie_len + 2,
 			&recv_beacon->group_cipher, &recv_beacon->pairwise_cipher,
-			&recv_beacon->is_8021x);
-	}
-	else if (capability & BIT(4)) {
+				 &recv_beacon->is_8021x);
+	} else if (capability & BIT(4))
 		recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WEP;
-	}
 
 	return _TRUE;
 }
@@ -2304,13 +2288,13 @@ void rtw_dump_bcn_keys(struct beacon_keys *recv_beacon)
 	_rtw_memcpy(ssid, recv_beacon->ssid, recv_beacon->ssid_len);
 	ssid[recv_beacon->ssid_len] = '\0';
 
-	DBG_871X("%s: ssid = %s\n", __func__, ssid);
-	DBG_871X("%s: channel = %x\n", __func__, recv_beacon->bcn_channel);
-	DBG_871X("%s: ht_cap = %x\n", __func__,	recv_beacon->ht_cap_info);
-	DBG_871X("%s: ht_info_infos_0_sco = %x\n", __func__, recv_beacon->ht_info_infos_0_sco);
-	DBG_871X("%s: sec=%d, group = %x, pair = %x, 8021X = %x\n", __func__,
-		recv_beacon->encryp_protocol, recv_beacon->group_cipher,
-		recv_beacon->pairwise_cipher, recv_beacon->is_8021x);
+	RTW_INFO("%s: ssid = %s\n", __func__, ssid);
+	RTW_INFO("%s: channel = %x\n", __func__, recv_beacon->bcn_channel);
+	RTW_INFO("%s: ht_cap = %x\n", __func__,	recv_beacon->ht_cap_info);
+	RTW_INFO("%s: ht_info_infos_0_sco = %x\n", __func__, recv_beacon->ht_info_infos_0_sco);
+	RTW_INFO("%s: sec=%d, group = %x, pair = %x, 8021X = %x\n", __func__,
+		 recv_beacon->encryp_protocol, recv_beacon->group_cipher,
+		 recv_beacon->pairwise_cipher, recv_beacon->is_8021x);
 }
 
 int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
@@ -2320,8 +2304,8 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 	unsigned char		*p;
 	unsigned short	val16, subtype;
 	struct wlan_network *cur_network = &(Adapter->mlmepriv.cur_network);
-	//u8 wpa_ie[255],rsn_ie[255];
-	u16 wpa_len=0,rsn_len=0;
+	/* u8 wpa_ie[255],rsn_ie[255]; */
+	u16 wpa_len = 0, rsn_len = 0;
 	u8 encryp_protocol = 0;
 	WLAN_BSSID_EX *bssid;
 	int group_cipher = 0, pairwise_cipher = 0, is_8021x = 0;
@@ -2329,11 +2313,11 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 	u32 wpa_ielen = 0;
 	u8 *pbssid = GetAddr3Ptr(pframe);
 	u32 hidden_ssid = 0;
-	u8 cur_network_type, network_type=0;
+	u8 cur_network_type, network_type = 0;
 	struct HT_info_element *pht_info = NULL;
 	struct rtw_ieee80211_ht_cap *pht_cap = NULL;
 	u32 bcn_channel;
-	unsigned short 	ht_cap_info;
+	unsigned short	ht_cap_info;
 	unsigned char	ht_info_infos_0;
 #endif
 	unsigned int len;
@@ -2348,80 +2332,72 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 	len = packet_len - sizeof(struct rtw_ieee80211_hdr_3addr);
 
 	if (len > MAX_IE_SZ) {
-		DBG_871X("%s IE too long for survey event\n", __func__);
+		RTW_WARN("%s IE too long for survey event\n", __func__);
 		return _FAIL;
 	}
 
 	if (_rtw_memcmp(cur_network->network.MacAddress, pbssid, 6) == _FALSE) {
-		DBG_871X("Oops: rtw_check_network_encrypt linked but recv other bssid bcn\n" MAC_FMT MAC_FMT,
-				MAC_ARG(pbssid), MAC_ARG(cur_network->network.MacAddress));
+		RTW_WARN("Oops: rtw_check_network_encrypt linked but recv other bssid bcn\n" MAC_FMT MAC_FMT,
+			MAC_ARG(pbssid), MAC_ARG(cur_network->network.MacAddress));
 		return _TRUE;
 	}
 
 	if (rtw_get_bcn_keys(Adapter, pframe, packet_len, &recv_beacon) == _FALSE)
-		return _TRUE; // parsing failed => broken IE
+		return _TRUE; /* parsing failed => broken IE */
 
-	// don't care hidden ssid, use current beacon ssid directly
+	/* don't care hidden ssid, use current beacon ssid directly */
 	if (recv_beacon.ssid_len == 0) {
-	       _rtw_memcpy(recv_beacon.ssid, pmlmepriv->cur_beacon_keys.ssid,
-			       pmlmepriv->cur_beacon_keys.ssid_len);
-	       recv_beacon.ssid_len = pmlmepriv->cur_beacon_keys.ssid_len;
+		_rtw_memcpy(recv_beacon.ssid, pmlmepriv->cur_beacon_keys.ssid,
+			    pmlmepriv->cur_beacon_keys.ssid_len);
+		recv_beacon.ssid_len = pmlmepriv->cur_beacon_keys.ssid_len;
 	}
 
 	if (_rtw_memcmp(&recv_beacon, &pmlmepriv->cur_beacon_keys, sizeof(recv_beacon)) == _TRUE)
-	{
 		pmlmepriv->new_beacon_cnts = 0;
-	}
 	else if ((pmlmepriv->new_beacon_cnts == 0) ||
-		_rtw_memcmp(&recv_beacon, &pmlmepriv->new_beacon_keys, sizeof(recv_beacon)) == _FALSE)
-	{
-		DBG_871X_LEVEL(_drv_err_, "%s: start new beacon (seq=%d)\n", __func__, GetSequence(pframe));
+		_rtw_memcmp(&recv_beacon, &pmlmepriv->new_beacon_keys, sizeof(recv_beacon)) == _FALSE) {
+		RTW_DBG("%s: start new beacon (seq=%d)\n", __func__, GetSequence(pframe));
 
 		if (pmlmepriv->new_beacon_cnts == 0) {
-			DBG_871X_LEVEL(_drv_err_, "%s: cur beacon key\n", __func__);
-			DBG_871X_EXP(_drv_err_, rtw_dump_bcn_keys(&pmlmepriv->cur_beacon_keys));
+			RTW_ERR("%s: cur beacon key\n", __func__);
+			RTW_DBG_EXPR(rtw_dump_bcn_keys(&pmlmepriv->cur_beacon_keys));
 		}
 
-		DBG_871X_LEVEL(_drv_err_, "%s: new beacon key\n", __func__);
-		DBG_871X_EXP(_drv_err_, rtw_dump_bcn_keys(&recv_beacon));
+		RTW_DBG("%s: new beacon key\n", __func__);
+		RTW_DBG_EXPR(rtw_dump_bcn_keys(&recv_beacon));
 
 		memcpy(&pmlmepriv->new_beacon_keys, &recv_beacon, sizeof(recv_beacon));
 		pmlmepriv->new_beacon_cnts = 1;
-	}
-	else
-	{
-		DBG_871X_LEVEL(_drv_err_, "%s: new beacon again (seq=%d)\n", __func__, GetSequence(pframe));
+	} else {
+		RTW_DBG("%s: new beacon again (seq=%d)\n", __func__, GetSequence(pframe));
 		pmlmepriv->new_beacon_cnts++;
 	}
 
-	// if counter >= max, it means beacon is changed really
-	if (pmlmepriv->new_beacon_cnts >= new_bcn_max)
-	{
-		DBG_871X_LEVEL(_drv_err_, "%s: new beacon occur!!\n", __func__);
-
-		// check bw mode change only?
+	/* if counter >= max, it means beacon is changed really */
+	if (pmlmepriv->new_beacon_cnts >= new_bcn_max) {
+		/* check bw mode change only? */
 		pmlmepriv->cur_beacon_keys.ht_cap_info = recv_beacon.ht_cap_info;
 		pmlmepriv->cur_beacon_keys.ht_info_infos_0_sco = recv_beacon.ht_info_infos_0_sco;
-
 		if (_rtw_memcmp(&recv_beacon, &pmlmepriv->cur_beacon_keys,
-					sizeof(recv_beacon)) == _FALSE) {
-			// beacon is changed, have to do disconnect/connect
+				sizeof(recv_beacon)) == _FALSE) {
+			/* beacon is changed, have to do disconnect/connect */
+			RTW_WARN("%s: new beacon occur!!\n", __func__);
 			return _FAIL;
 		}
 
-		DBG_871X("%s bw mode change\n", __func__);
-		DBG_871X("%s bcn now: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
-				cur_network->BcnInfo.ht_cap_info,
-				cur_network->BcnInfo.ht_info_infos_0);
+		RTW_INFO("%s bw mode change\n", __func__);
+		RTW_INFO("%s bcn now: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
+			 cur_network->BcnInfo.ht_cap_info,
+			 cur_network->BcnInfo.ht_info_infos_0);
 
 		cur_network->BcnInfo.ht_cap_info = recv_beacon.ht_cap_info;
 		cur_network->BcnInfo.ht_info_infos_0 =
 			(cur_network->BcnInfo.ht_info_infos_0 & (~0x03)) |
 			recv_beacon.ht_info_infos_0_sco;
 
-		DBG_871X("%s bcn link: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
-				cur_network->BcnInfo.ht_cap_info,
-				cur_network->BcnInfo.ht_info_infos_0);
+		RTW_INFO("%s bcn link: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
+			 cur_network->BcnInfo.ht_cap_info,
+			 cur_network->BcnInfo.ht_info_infos_0);
 
 		memcpy(&pmlmepriv->cur_beacon_keys, &recv_beacon, sizeof(recv_beacon));
 		pmlmepriv->new_beacon_cnts = 0;
@@ -2432,19 +2408,18 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 #if 0
 	bssid = (WLAN_BSSID_EX *)rtw_zmalloc(sizeof(WLAN_BSSID_EX));
 	if (bssid == NULL) {
-		DBG_871X("%s rtw_zmalloc fail !!!\n", __func__);
+		RTW_INFO("%s rtw_zmalloc fail !!!\n", __func__);
 		return _TRUE;
 	}
 
-	if ((pmlmepriv->timeBcnInfoChkStart != 0) && (rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart) > DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS))
-	{
+	if ((pmlmepriv->timeBcnInfoChkStart != 0) && (rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart) > DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS)) {
 		pmlmepriv->timeBcnInfoChkStart = 0;
 		pmlmepriv->NumOfBcnInfoChkFail = 0;
 	}
 
-	subtype = GetFrameSubType(pframe) >> 4;
+	subtype = get_frame_sub_type(pframe) >> 4;
 
-	if(subtype==WIFI_BEACON)
+	if (subtype == WIFI_BEACON)
 		bssid->Reserved[0] = 1;
 
 	bssid->Length = sizeof(WLAN_BSSID_EX) - MAX_IE_SZ + len;
@@ -2456,64 +2431,62 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 	/* check bw and channel offset */
 	/* parsing HT_CAP_IE */
 	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _HT_CAPABILITY_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-	if(p && len>0) {
-			pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
-			ht_cap_info = pht_cap->cap_info;
-	} else {
-			ht_cap_info = 0;
-	}
+	if (p && len > 0) {
+		pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
+		ht_cap_info = pht_cap->cap_info;
+	} else
+		ht_cap_info = 0;
 	/* parsing HT_INFO_IE */
 	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _HT_ADD_INFO_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-	if(p && len>0) {
-			pht_info = (struct HT_info_element *)(p + 2);
-			ht_info_infos_0 = pht_info->infos[0];
-	} else {
-			ht_info_infos_0 = 0;
-	}
+	if (p && len > 0) {
+		pht_info = (struct HT_info_element *)(p + 2);
+		ht_info_infos_0 = pht_info->infos[0];
+	} else
+		ht_info_infos_0 = 0;
 	if (ht_cap_info != cur_network->BcnInfo.ht_cap_info ||
-		((ht_info_infos_0&0x03) != (cur_network->BcnInfo.ht_info_infos_0&0x03))) {
-			DBG_871X("%s bcn now: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
-						   	ht_cap_info, ht_info_infos_0);
-			DBG_871X("%s bcn link: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
-						   	cur_network->BcnInfo.ht_cap_info, cur_network->BcnInfo.ht_info_infos_0);
-			DBG_871X("%s bw mode change\n", __func__);
-			{	
-				//bcn_info_update
-				cur_network->BcnInfo.ht_cap_info = ht_cap_info;
-				cur_network->BcnInfo.ht_info_infos_0 = ht_info_infos_0;
-				//to do : need to check that whether modify related register of BB or not 
-			}
-			//goto _mismatch;
+	    ((ht_info_infos_0 & 0x03) != (cur_network->BcnInfo.ht_info_infos_0 & 0x03))) {
+		RTW_INFO("%s bcn now: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
+			 ht_cap_info, ht_info_infos_0);
+		RTW_INFO("%s bcn link: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
+			cur_network->BcnInfo.ht_cap_info, cur_network->BcnInfo.ht_info_infos_0);
+		RTW_INFO("%s bw mode change\n", __func__);
+		{
+			/* bcn_info_update */
+			cur_network->BcnInfo.ht_cap_info = ht_cap_info;
+			cur_network->BcnInfo.ht_info_infos_0 = ht_info_infos_0;
+			/* to do : need to check that whether modify related register of BB or not */
+		}
+		/* goto _mismatch; */
 	}
 
 	/* Checking for channel */
 	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _DSSET_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-	if (p) {
-			bcn_channel = *(p + 2);
-	} else {/* In 5G, some ap do not have DSSET IE checking HT info for channel */
-			rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _HT_ADD_INFO_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-			if(pht_info) {
-					bcn_channel = pht_info->primary_channel;
-			} else { /* we don't find channel IE, so don't check it */
-					//DBG_871X("Oops: %s we don't find channel IE, so don't check it \n", __func__);
-					bcn_channel = Adapter->mlmeextpriv.cur_channel;
-			}
+	if (p)
+		bcn_channel = *(p + 2);
+	else {/* In 5G, some ap do not have DSSET IE checking HT info for channel */
+		rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _HT_ADD_INFO_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
+		if (pht_info)
+			bcn_channel = pht_info->primary_channel;
+		else { /* we don't find channel IE, so don't check it */
+			/* RTW_INFO("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_871X("%s beacon channel:%d cur channel:%d disconnect\n", __func__,
-						   bcn_channel, Adapter->mlmeextpriv.cur_channel);
-			goto _mismatch;
+		RTW_INFO("%s beacon channel:%d cur channel:%d disconnect\n", __func__,
+			 bcn_channel, Adapter->mlmeextpriv.cur_channel);
+		goto _mismatch;
 	}
 
 	/* checking SSID */
-	if ((p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _SSID_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_)) == NULL) {
-		DBG_871X("%s marc: cannot find SSID for survey event\n", __func__);
+	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _SSID_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
+	if (p == NULL) {
+		RTW_INFO("%s marc: cannot find SSID for survey event\n", __func__);
 		hidden_ssid = _TRUE;
-	} else {
+	} else
 		hidden_ssid = _FALSE;
-	}
 
-	if((NULL != p) && (_FALSE == hidden_ssid && (*(p + 1)))) {
+	if ((NULL != p) && (_FALSE == hidden_ssid && (*(p + 1)))) {
 		_rtw_memcpy(bssid->Ssid.Ssid, (p + 2), *(p + 1));
 		bssid->Ssid.SsidLength = *(p + 1);
 	} else {
@@ -2521,15 +2494,11 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 		bssid->Ssid.Ssid[0] = '\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__, bssid->Ssid.Ssid,
-				bssid->Ssid.SsidLength, cur_network->network.Ssid.Ssid,
-				cur_network->network.Ssid.SsidLength));
 
 	if (_rtw_memcmp(bssid->Ssid.Ssid, cur_network->network.Ssid.Ssid, 32) == _FALSE ||
-			bssid->Ssid.SsidLength != cur_network->network.Ssid.SsidLength) {
+	    bssid->Ssid.SsidLength != cur_network->network.Ssid.SsidLength) {
 		if (bssid->Ssid.Ssid[0] != '\0' && bssid->Ssid.SsidLength != 0) { /* not hidden ssid */
-			DBG_871X("%s(), SSID is not match\n", __func__);
+			RTW_INFO("%s(), SSID is not match\n", __func__);
 			goto _mismatch;
 		}
 	}
@@ -2542,61 +2511,48 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 	else
 		bssid->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,bssid->Privacy));
 	if (cur_network->network.Privacy != bssid->Privacy) {
-		DBG_871X("%s(), privacy is not match\n",__func__);
+		RTW_INFO("%s(), privacy is not match\n", __func__);
 		goto _mismatch;
 	}
 
-	rtw_get_sec_ie(bssid->IEs, bssid->IELength, NULL,&rsn_len,NULL,&wpa_len);
+	rtw_get_sec_ie(bssid->IEs, bssid->IELength, NULL, &rsn_len, NULL, &wpa_len);
 
-	if (rsn_len > 0) {
+	if (rsn_len > 0)
 		encryp_protocol = ENCRYP_PROTOCOL_WPA2;
-	} else if (wpa_len > 0) {
+	else if (wpa_len > 0)
 		encryp_protocol = ENCRYP_PROTOCOL_WPA;
-	} else {
+	else {
 		if (bssid->Privacy)
 			encryp_protocol = ENCRYP_PROTOCOL_WEP;
 	}
 
 	if (cur_network->BcnInfo.encryp_protocol != encryp_protocol) {
-		DBG_871X("%s(): enctyp is not match\n",__func__);
+		RTW_INFO("%s(): enctyp is not match\n", __func__);
 		goto _mismatch;
 	}
 
 	if (encryp_protocol == ENCRYP_PROTOCOL_WPA || encryp_protocol == ENCRYP_PROTOCOL_WPA2) {
-		pbuf = rtw_get_wpa_ie(&bssid->IEs[12], &wpa_ielen, bssid->IELength-12);
-		if(pbuf && (wpa_ielen>0)) {
-			if (_SUCCESS == rtw_parse_wpa_ie(pbuf, wpa_ielen+2, &group_cipher, &pairwise_cipher, &is_8021x)) {
-				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));
-			}
+		pbuf = rtw_get_wpa_ie(&bssid->IEs[12], &wpa_ielen, bssid->IELength - 12);
+		if (pbuf && (wpa_ielen > 0)) {
+			rtw_parse_wpa_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is_8021x);
 		} else {
-			pbuf = rtw_get_wpa2_ie(&bssid->IEs[12], &wpa_ielen, bssid->IELength-12);
+			pbuf = rtw_get_wpa2_ie(&bssid->IEs[12], &wpa_ielen, bssid->IELength - 12);
 
-			if(pbuf && (wpa_ielen>0)) {
-				if (_SUCCESS == rtw_parse_wpa2_ie(pbuf, wpa_ielen+2, &group_cipher, &pairwise_cipher, &is_8021x)) {
-					RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,
-							("%s pnetwork->pairwise_cipher: %d, pnetwork->group_cipher is %d, is_802x is %d\n",
-							 __func__, pairwise_cipher, group_cipher, is_8021x));
-				}
+			if (pbuf && (wpa_ielen > 0)) {
+				rtw_parse_wpa2_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is_8021x, NULL);
 			}
 		}
 
-		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_871X("%s pairwise_cipher(%x:%x) or group_cipher(%x:%x) is not match\n",__func__,
-					pairwise_cipher, cur_network->BcnInfo.pairwise_cipher,
-					group_cipher, cur_network->BcnInfo.group_cipher);
+			RTW_INFO("%s pairwise_cipher(%x:%x) or group_cipher(%x:%x) is not match\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_871X("%s authentication is not match\n", __func__);
+			RTW_INFO("%s authentication is not match\n", __func__);
 			goto _mismatch;
 		}
 	}
@@ -2608,17 +2564,14 @@ _mismatch:
 	rtw_mfree((u8 *)bssid, sizeof(WLAN_BSSID_EX));
 
 	if (pmlmepriv->NumOfBcnInfoChkFail == 0)
-	{
 		pmlmepriv->timeBcnInfoChkStart = rtw_get_current_time();
-	}
 
 	pmlmepriv->NumOfBcnInfoChkFail++;
-	DBG_871X("%s by "ADPT_FMT" - NumOfChkFail = %d (SeqNum of this Beacon frame = %d).\n", __func__, ADPT_ARG(Adapter), pmlmepriv->NumOfBcnInfoChkFail, GetSequence(pframe));
+	RTW_INFO("%s by "ADPT_FMT" - NumOfChkFail = %d (SeqNum of this Beacon frame = %d).\n", __func__, ADPT_ARG(Adapter), pmlmepriv->NumOfBcnInfoChkFail, GetSequence(pframe));
 
-	if ((pmlmepriv->timeBcnInfoChkStart != 0) && (rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart) <= DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS) 
-		&& (pmlmepriv->NumOfBcnInfoChkFail >= DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD))
-	{
-		DBG_871X("%s by "ADPT_FMT" - NumOfChkFail = %d >= threshold : %d (in %d ms), return FAIL.\n", __func__, ADPT_ARG(Adapter), pmlmepriv->NumOfBcnInfoChkFail, 
+	if ((pmlmepriv->timeBcnInfoChkStart != 0) && (rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart) <= DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS)
+	    && (pmlmepriv->NumOfBcnInfoChkFail >= DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD)) {
+		RTW_INFO("%s by "ADPT_FMT" - NumOfChkFail = %d >= threshold : %d (in %d ms), return FAIL.\n", __func__, ADPT_ARG(Adapter), pmlmepriv->NumOfBcnInfoChkFail,
 			DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD, rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart));
 		pmlmepriv->timeBcnInfoChkStart = 0;
 		pmlmepriv->NumOfBcnInfoChkFail = 0;
@@ -2634,91 +2587,82 @@ void update_beacon_info(_adapter *padapter, u8 *pframe, uint pkt_len, struct sta
 	unsigned int i;
 	unsigned int len;
 	PNDIS_802_11_VARIABLE_IEs	pIE;
-		
+
 #ifdef CONFIG_TDLS
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	u8 tdls_prohibited[] = { 0x00, 0x00, 0x00, 0x00, 0x10 }; //bit(38): TDLS_prohibited
-#endif //CONFIG_TDLS
-		
+	u8 tdls_prohibited[] = { 0x00, 0x00, 0x00, 0x00, 0x10 }; /* bit(38): TDLS_prohibited */
+#endif /* CONFIG_TDLS */
+
 	len = pkt_len - (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN);
 
-	for (i = 0; i < len;)
-	{
+	for (i = 0; i < len;) {
 		pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN) + i);
-		
-		switch (pIE->ElementID)
-		{
-			case _VENDOR_SPECIFIC_IE_:		
-				//to update WMM paramter set while receiving beacon
-				if (_rtw_memcmp(pIE->data, WMM_PARA_OUI, 6) && pIE->Length == WLAN_WMM_LEN)	//WMM
-				{
-					(WMM_param_handler(padapter, pIE))? report_wmm_edca_update(padapter): 0;
-				}
 
-				break;
+		switch (pIE->ElementID) {
+		case _VENDOR_SPECIFIC_IE_:
+			/* to update WMM paramter set while receiving beacon */
+			if (_rtw_memcmp(pIE->data, WMM_PARA_OUI, 6) && pIE->Length == WLAN_WMM_LEN)	/* WMM */
+				(WMM_param_handler(padapter, pIE)) ? report_wmm_edca_update(padapter) : 0;
 
-			case _HT_EXTRA_INFO_IE_:	//HT info				
-				//HT_info_handler(padapter, pIE);
-				bwmode_update_check(padapter, pIE);
-				break;
+			break;
+
+		case _HT_EXTRA_INFO_IE_:	/* HT info */
+			/* HT_info_handler(padapter, pIE); */
+			bwmode_update_check(padapter, pIE);
+			break;
 #ifdef CONFIG_80211AC_VHT
-			case EID_OpModeNotification:
-				rtw_process_vht_op_mode_notify(padapter, pIE->data, psta);
-				break;
-#endif //CONFIG_80211AC_VHT
-			case _ERPINFO_IE_:
-				ERP_IE_handler(padapter, pIE);
-				VCS_update(padapter, psta);
-				break;
+		case EID_OpModeNotification:
+			rtw_process_vht_op_mode_notify(padapter, pIE->data, psta);
+			break;
+#endif /* CONFIG_80211AC_VHT */
+		case _ERPINFO_IE_:
+			ERP_IE_handler(padapter, pIE);
+			VCS_update(padapter, psta);
+			break;
 
 #ifdef CONFIG_TDLS
-			case _EXT_CAP_IE_:
-				if( check_ap_tdls_prohibited(pIE->data, pIE->Length) == _TRUE )
-					ptdlsinfo->ap_prohibited = _TRUE;
-				if (check_ap_tdls_ch_switching_prohibited(pIE->data, pIE->Length) == _TRUE)
-					ptdlsinfo->ch_switch_prohibited = _TRUE;
-				break;
-#endif //CONFIG_TDLS
-			default:
-				break;
+		case _EXT_CAP_IE_:
+			if (check_ap_tdls_prohibited(pIE->data, pIE->Length) == _TRUE)
+				ptdlsinfo->ap_prohibited = _TRUE;
+			if (check_ap_tdls_ch_switching_prohibited(pIE->data, pIE->Length) == _TRUE)
+				ptdlsinfo->ch_switch_prohibited = _TRUE;
+			break;
+#endif /* CONFIG_TDLS */
+		default:
+			break;
 		}
-		
+
 		i += (pIE->Length + 2);
 	}
 }
 
 #ifdef CONFIG_DFS
-void process_csa_ie(_adapter *padapter, u8 *pframe, uint pkt_len)
+void process_csa_ie(_adapter *padapter, u8 *ies, uint ies_len)
 {
 	unsigned int i;
-	unsigned int len;
 	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 new_ch_no = 0; 
+	u8 new_ch_no = 0;
 
-	if(padapter->mlmepriv.handle_dfs == _TRUE )
+	if (padapter->mlmepriv.handle_dfs == _TRUE)
 		return;
-	
-	len = pkt_len - (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN);
 
-	for (i = 0; i < len;)
-	{
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN) + i);
-		
-		switch (pIE->ElementID)
-		{
-			case _CH_SWTICH_ANNOUNCE_:
-				padapter->mlmepriv.handle_dfs = _TRUE;
-				_rtw_memcpy(&new_ch_no, pIE->data+1, 1);
-				rtw_set_csa_cmd(padapter, new_ch_no);
-				break;
-			default:
-				break;
+	for (i = 0; i + 1 < ies_len;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(ies + i);
+
+		switch (pIE->ElementID) {
+		case _CH_SWTICH_ANNOUNCE_:
+			padapter->mlmepriv.handle_dfs = _TRUE;
+			_rtw_memcpy(&new_ch_no, pIE->data + 1, 1);
+			rtw_set_csa_cmd(padapter, new_ch_no);
+			break;
+		default:
+			break;
 		}
-		
+
 		i += (pIE->Length + 2);
 	}
 }
-#endif //CONFIG_DFS
+#endif /* CONFIG_DFS */
 
 unsigned int is_ap_in_tkip(_adapter *padapter)
 {
@@ -2726,85 +2670,69 @@ unsigned int is_ap_in_tkip(_adapter *padapter)
 	PNDIS_802_11_VARIABLE_IEs	pIE;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
 
-	if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY)
-	{
-		for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;)
-		{
+	if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY) {
+		for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;) {
 			pIE = (PNDIS_802_11_VARIABLE_IEs)(pmlmeinfo->network.IEs + i);
-		
-			switch (pIE->ElementID)
-			{
-				case _VENDOR_SPECIFIC_IE_:
-					if ((_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4)) && (_rtw_memcmp((pIE->data + 12), WPA_TKIP_CIPHER, 4))) 
-					{
-						return _TRUE;
-					}
-					break;
-				
-				case _RSN_IE_2_:
-					if (_rtw_memcmp((pIE->data + 8), RSN_TKIP_CIPHER, 4)) 
-					{
-						return _TRUE;
-					}
-					
-				default:
-					break;
+
+			switch (pIE->ElementID) {
+			case _VENDOR_SPECIFIC_IE_:
+				if ((_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4)) && (_rtw_memcmp((pIE->data + 12), WPA_TKIP_CIPHER, 4)))
+					return _TRUE;
+				break;
+
+			case _RSN_IE_2_:
+				if (_rtw_memcmp((pIE->data + 8), RSN_TKIP_CIPHER, 4))
+					return _TRUE;
+
+			default:
+				break;
 			}
-		
+
 			i += (pIE->Length + 2);
 		}
-		
+
 		return _FALSE;
-	}
-	else
-	{
+	} else
 		return _FALSE;
-	}
-	
+
 }
 
-unsigned int should_forbid_n_rate(_adapter * padapter)
+unsigned int should_forbid_n_rate(_adapter *padapter)
 {
 	u32 i;
 	PNDIS_802_11_VARIABLE_IEs	pIE;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	WLAN_BSSID_EX  *cur_network = &pmlmepriv->cur_network.network;
 
-	if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY)
-	{
-		for (i = sizeof(NDIS_802_11_FIXED_IEs); i < cur_network->IELength;)
-		{
+	if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY) {
+		for (i = sizeof(NDIS_802_11_FIXED_IEs); i < cur_network->IELength;) {
 			pIE = (PNDIS_802_11_VARIABLE_IEs)(cur_network->IEs + i);
 
-			switch (pIE->ElementID)
-			{
-				case _VENDOR_SPECIFIC_IE_:
-					if (_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4) &&
-						((_rtw_memcmp((pIE->data + 12), WPA_CIPHER_SUITE_CCMP, 4)) ||
-						  (_rtw_memcmp((pIE->data + 16), WPA_CIPHER_SUITE_CCMP, 4))))
-						return _FALSE;
-					break;
-
-				case _RSN_IE_2_:
-					if  ((_rtw_memcmp((pIE->data + 8), RSN_CIPHER_SUITE_CCMP, 4))  ||
-					       (_rtw_memcmp((pIE->data + 12), RSN_CIPHER_SUITE_CCMP, 4)))
-						return _FALSE;
-
-				default:
-					break;
+			switch (pIE->ElementID) {
+			case _VENDOR_SPECIFIC_IE_:
+				if (_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4) &&
+				    ((_rtw_memcmp((pIE->data + 12), WPA_CIPHER_SUITE_CCMP, 4)) ||
+				     (_rtw_memcmp((pIE->data + 16), WPA_CIPHER_SUITE_CCMP, 4))))
+					return _FALSE;
+				break;
+
+			case _RSN_IE_2_:
+				if ((_rtw_memcmp((pIE->data + 8), RSN_CIPHER_SUITE_CCMP, 4))  ||
+				    (_rtw_memcmp((pIE->data + 12), RSN_CIPHER_SUITE_CCMP, 4)))
+					return _FALSE;
+
+			default:
+				break;
 			}
 
 			i += (pIE->Length + 2);
 		}
 
 		return _TRUE;
-	}
-	else
-	{
+	} else
 		return _FALSE;
-	}
 
 }
 
@@ -2815,37 +2743,31 @@ unsigned int is_ap_in_wep(_adapter *padapter)
 	PNDIS_802_11_VARIABLE_IEs	pIE;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
 
-	if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY)
-	{
-		for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;)
-		{
+	if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY) {
+		for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;) {
 			pIE = (PNDIS_802_11_VARIABLE_IEs)(pmlmeinfo->network.IEs + i);
 
-			switch (pIE->ElementID)
-			{
-				case _VENDOR_SPECIFIC_IE_:
-					if (_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4))
-						return _FALSE;
-					break;
-
-				case _RSN_IE_2_:
+			switch (pIE->ElementID) {
+			case _VENDOR_SPECIFIC_IE_:
+				if (_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4))
 					return _FALSE;
+				break;
+
+			case _RSN_IE_2_:
+				return _FALSE;
 
-				default:
-					break;
+			default:
+				break;
 			}
 
 			i += (pIE->Length + 2);
 		}
 
 		return _TRUE;
-	}
-	else
-	{
+	} else
 		return _FALSE;
-	}
 
 }
 
@@ -2855,72 +2777,68 @@ int wifirate2_ratetbl_inx(unsigned char rate)
 	int	inx = 0;
 	rate = rate & 0x7f;
 
-	switch (rate) 
-	{
-		case 54*2:
-			inx = 11;
-			break;
+	switch (rate) {
+	case 54*2:
+		inx = 11;
+		break;
 
-		case 48*2:
-			inx = 10;
-			break;
+	case 48*2:
+		inx = 10;
+		break;
 
-		case 36*2:
-			inx = 9;
-			break;
+	case 36*2:
+		inx = 9;
+		break;
 
-		case 24*2:
-			inx = 8;
-			break;
-			
-		case 18*2:
-			inx = 7;
-			break;
+	case 24*2:
+		inx = 8;
+		break;
 
-		case 12*2:
-			inx = 6;
-			break;
+	case 18*2:
+		inx = 7;
+		break;
 
-		case 9*2:
-			inx = 5;
-			break;
-			
-		case 6*2:
-			inx = 4;
-			break;
+	case 12*2:
+		inx = 6;
+		break;
 
-		case 11*2:
-			inx = 3;
-			break;
-		case 11:
-			inx = 2;
-			break;
+	case 9*2:
+		inx = 5;
+		break;
 
-		case 2*2:
-			inx = 1;
-			break;
-		
-		case 1*2:
-			inx = 0;
-			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;	
+	return inx;
 }
 
 unsigned int update_basic_rate(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++)
-	{
+
+	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_inx(*(ptn + i));
-		}
 	}
 	return mask;
 }
@@ -2929,23 +2847,12 @@ unsigned int update_supported_rate(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;
-		
+
+	num_of_rate = (ptn_sz > NumRates) ? NumRates : ptn_sz;
+
 	for (i = 0; i < num_of_rate; i++)
-	{
 		mask |= 0x1 << wifirate2_ratetbl_inx(*(ptn + i));
-	}
-
-	return mask;
-}
 
-unsigned int update_MCS_rate(struct HT_caps_element *pHT_caps)
-{
-	unsigned int mask = 0;
-	
-	mask = ((pHT_caps->u.HT_cap_element.MCS_rate[0] << 12) | (pHT_caps->u.HT_cap_element.MCS_rate[1] << 20));
-						
 	return mask;
 }
 
@@ -2954,31 +2861,25 @@ int support_short_GI(_adapter *padapter, struct HT_caps_element *pHT_caps, u8 bw
 	unsigned char					bit_offset;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	
+
 	if (!(pmlmeinfo->HT_enable))
-		return _FAIL; 
+		return _FAIL;
+
+	bit_offset = (bwmode & CHANNEL_WIDTH_40) ? 6 : 5;
 
-	bit_offset = (bwmode & CHANNEL_WIDTH_40)? 6: 5;
-	
 	if (pHT_caps->u.HT_cap_element.HT_caps_info & (0x1 << bit_offset))
-	{
 		return _SUCCESS;
-	}
 	else
-	{
 		return _FAIL;
-	}		
 }
 
-unsigned char get_highest_rate_idx(u32 mask)
+unsigned char get_highest_rate_idx(u64 mask)
 {
 	int i;
-	unsigned char rate_idx=0;
+	unsigned char rate_idx = 0;
 
-	for(i=31; i>=0; i--)
-	{
-		if(mask & BIT(i))
-		{
+	for (i = 63; i >= 0; i--) {
+		if ((mask >> i) & 0x01) {
 			rate_idx = i;
 			break;
 		}
@@ -2986,74 +2887,63 @@ unsigned char get_highest_rate_idx(u32 mask)
 
 	return rate_idx;
 }
-
-unsigned char get_highest_mcs_rate(struct HT_caps_element *pHT_caps);
-unsigned char get_highest_mcs_rate(struct HT_caps_element *pHT_caps)
+unsigned char get_lowest_rate_idx_ex(u64 mask, int start_bit)
 {
-	int i, mcs_rate;
-	
-	mcs_rate = (pHT_caps->u.HT_cap_element.MCS_rate[0] | (pHT_caps->u.HT_cap_element.MCS_rate[1] << 8));
-	
-	for (i = 15; i >= 0; i--)
-	{
-		if (mcs_rate & (0x1 << i))
-		{
+	int i;
+	unsigned char rate_idx = 0;
+
+	for (i = start_bit; i < 64; i++) {
+		if ((mask >> i) & 0x01) {
+			rate_idx = i;
 			break;
 		}
 	}
-	
-	return i;
-}
 
-void Update_RA_Entry(_adapter *padapter, struct sta_info *psta)
-{
-	rtw_hal_update_ra_mask(psta, psta->rssi_level);
+	return rate_idx;
 }
 
-void enable_rate_adaptive(_adapter *padapter, struct sta_info *psta);
-void enable_rate_adaptive(_adapter *padapter, struct sta_info *psta)
+void Update_RA_Entry(_adapter *padapter, struct sta_info *psta)
 {
-	Update_RA_Entry(padapter, psta);
+	rtw_hal_update_ra_mask(psta);
 }
 
 void set_sta_rate(_adapter *padapter, struct sta_info *psta)
 {
-	//rate adaptive	
-	enable_rate_adaptive(padapter, psta);
+	/* rate adaptive	 */
+	rtw_hal_update_ra_mask(psta);
 }
 
-// Update RRSR and Rate for USERATE
+/* Update RRSR and Rate for USERATE */
 void update_tx_basic_rate(_adapter *padapter, u8 wirelessmode)
 {
 	NDIS_802_11_RATES_EX	supported_rates;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 #ifdef CONFIG_P2P
-	struct wifidirect_info*	pwdinfo = &padapter->wdinfo;
+	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
 
-	//	Added by Albert 2011/03/22
-	//	In the P2P mode, the driver should not support the b mode.
-	//	So, the Tx packet shouldn't use the CCK rate
-	if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+	/*	Added by Albert 2011/03/22 */
+	/*	In the P2P mode, the driver should not support the b mode. */
+	/*	So, the Tx packet shouldn't use the CCK rate */
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 #ifdef CONFIG_INTEL_WIDI
 	if (padapter->mlmepriv.widi_state != INTEL_WIDI_STATE_NONE)
 		return;
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
 	_rtw_memset(supported_rates, 0, NDIS_802_11_LENGTH_RATES_EX);
 
-	//clear B mod if current channel is in 5G band, avoid tx cck rate in 5G band.
-	if(pmlmeext->cur_channel > 14)
+	/* clear B mod if current channel is in 5G band, avoid tx cck rate in 5G band. */
+	if (pmlmeext->cur_channel > 14)
 		wirelessmode &= ~(WIRELESS_11B);
 
-	if ((wirelessmode & WIRELESS_11B) && (wirelessmode == WIRELESS_11B)) {
+	if ((wirelessmode & WIRELESS_11B) && (wirelessmode == WIRELESS_11B))
 		_rtw_memcpy(supported_rates, rtw_basic_rate_cck, 4);
-	} else if (wirelessmode & WIRELESS_11B) {
+	else if (wirelessmode & WIRELESS_11B)
 		_rtw_memcpy(supported_rates, rtw_basic_rate_mix, 7);
-	} else {
+	else
 		_rtw_memcpy(supported_rates, rtw_basic_rate_ofdm, 3);
-	}
 
 	if (wirelessmode & WIRELESS_11B)
 		update_mgnt_tx_rate(padapter, IEEE80211_CCK_RATE_1MB);
@@ -3068,158 +2958,150 @@ unsigned char check_assoc_AP(u8 *pframe, uint len)
 	unsigned int	i;
 	PNDIS_802_11_VARIABLE_IEs	pIE;
 
-	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < len;)
-	{
+	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < len;) {
 		pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + i);
-		
-		switch (pIE->ElementID)
-		{
-			case _VENDOR_SPECIFIC_IE_:
-				if ((_rtw_memcmp(pIE->data, ARTHEROS_OUI1, 3)) || (_rtw_memcmp(pIE->data, ARTHEROS_OUI2, 3)))
-				{
-					DBG_871X("link to Artheros AP\n");
-					return HT_IOT_PEER_ATHEROS;
-				}
-				else if (	(_rtw_memcmp(pIE->data, BROADCOM_OUI1, 3))
-						|| (_rtw_memcmp(pIE->data, BROADCOM_OUI2, 3))
-						|| (_rtw_memcmp(pIE->data, BROADCOM_OUI3, 3)))						
-				{
-					DBG_871X("link to Broadcom AP\n");
-					return HT_IOT_PEER_BROADCOM;
-				}
-				else if (_rtw_memcmp(pIE->data, MARVELL_OUI, 3))
-				{
-					DBG_871X("link to Marvell AP\n");
-					return HT_IOT_PEER_MARVELL;
-				}
-				else if (_rtw_memcmp(pIE->data, RALINK_OUI, 3))
-				{
-					DBG_871X("link to Ralink AP\n");
-					return HT_IOT_PEER_RALINK;
-				}
-				else if (_rtw_memcmp(pIE->data, CISCO_OUI, 3))
-				{
-					DBG_871X("link to Cisco AP\n");
-					return HT_IOT_PEER_CISCO;
-				}
-				else if (_rtw_memcmp(pIE->data, REALTEK_OUI, 3))
-				{
-					u32	Vender = HT_IOT_PEER_REALTEK;
-
-					if(pIE->Length >= 5) {
-						if(pIE->data[4]==1)
-						{
-							//if(pIE->data[5] & RT_HT_CAP_USE_LONG_PREAMBLE)
-							//	bssDesc->BssHT.RT2RT_HT_Mode |= RT_HT_CAP_USE_LONG_PREAMBLE;
-
-							if(pIE->data[5] & RT_HT_CAP_USE_92SE)
-							{
-								//bssDesc->BssHT.RT2RT_HT_Mode |= RT_HT_CAP_USE_92SE;
-								Vender = HT_IOT_PEER_REALTEK_92SE;
-							}
+
+		switch (pIE->ElementID) {
+		case _VENDOR_SPECIFIC_IE_:
+			if ((_rtw_memcmp(pIE->data, ARTHEROS_OUI1, 3)) || (_rtw_memcmp(pIE->data, ARTHEROS_OUI2, 3))) {
+				RTW_INFO("link to Artheros AP\n");
+				return HT_IOT_PEER_ATHEROS;
+			} else if ((_rtw_memcmp(pIE->data, BROADCOM_OUI1, 3))
+				   || (_rtw_memcmp(pIE->data, BROADCOM_OUI2, 3))
+				|| (_rtw_memcmp(pIE->data, BROADCOM_OUI3, 3))) {
+				RTW_INFO("link to Broadcom AP\n");
+				return HT_IOT_PEER_BROADCOM;
+			} else if (_rtw_memcmp(pIE->data, MARVELL_OUI, 3)) {
+				RTW_INFO("link to Marvell AP\n");
+				return HT_IOT_PEER_MARVELL;
+			} else if (_rtw_memcmp(pIE->data, RALINK_OUI, 3)) {
+				RTW_INFO("link to Ralink AP\n");
+				return HT_IOT_PEER_RALINK;
+			} else if (_rtw_memcmp(pIE->data, CISCO_OUI, 3)) {
+				RTW_INFO("link to Cisco AP\n");
+				return HT_IOT_PEER_CISCO;
+			} else if (_rtw_memcmp(pIE->data, REALTEK_OUI, 3)) {
+				u32	Vender = HT_IOT_PEER_REALTEK;
+
+				if (pIE->Length >= 5) {
+					if (pIE->data[4] == 1) {
+						/* if(pIE->data[5] & RT_HT_CAP_USE_LONG_PREAMBLE) */
+						/*	bssDesc->BssHT.RT2RT_HT_Mode |= RT_HT_CAP_USE_LONG_PREAMBLE; */
+
+						if (pIE->data[5] & RT_HT_CAP_USE_92SE) {
+							/* bssDesc->BssHT.RT2RT_HT_Mode |= RT_HT_CAP_USE_92SE; */
+							Vender = HT_IOT_PEER_REALTEK_92SE;
 						}
+					}
+
+					if (pIE->data[5] & RT_HT_CAP_USE_SOFTAP)
+						Vender = HT_IOT_PEER_REALTEK_SOFTAP;
 
-						if(pIE->data[5] & RT_HT_CAP_USE_SOFTAP)
-							Vender = HT_IOT_PEER_REALTEK_SOFTAP;
-
-						if(pIE->data[4] == 2)
-						{
-							if(pIE->data[6] & RT_HT_CAP_USE_JAGUAR_BCUT) {
-								Vender = HT_IOT_PEER_REALTEK_JAGUAR_BCUTAP;
-								DBG_871X("link to Realtek JAGUAR_BCUTAP\n");
-							}
-							if(pIE->data[6] & RT_HT_CAP_USE_JAGUAR_CCUT) {
-								Vender = HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP;
-								DBG_871X("link to Realtek JAGUAR_CCUTAP\n");
-							}
+					if (pIE->data[4] == 2) {
+						if (pIE->data[6] & RT_HT_CAP_USE_JAGUAR_BCUT) {
+							Vender = HT_IOT_PEER_REALTEK_JAGUAR_BCUTAP;
+							RTW_INFO("link to Realtek JAGUAR_BCUTAP\n");
+						}
+						if (pIE->data[6] & RT_HT_CAP_USE_JAGUAR_CCUT) {
+							Vender = HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP;
+							RTW_INFO("link to Realtek JAGUAR_CCUTAP\n");
 						}
 					}
-				
-					DBG_871X("link to Realtek AP\n");
-					return Vender;
-				}
-				else if (_rtw_memcmp(pIE->data, AIRGOCAP_OUI,3))
-				{
-					DBG_871X("link to Airgo Cap\n");
-					return HT_IOT_PEER_AIRGO;
-				}
-				else
-				{
-					break;
 				}
-						
-			default:
+
+				RTW_INFO("link to Realtek AP\n");
+				return Vender;
+			} else if (_rtw_memcmp(pIE->data, AIRGOCAP_OUI, 3)) {
+				RTW_INFO("link to Airgo Cap\n");
+				return HT_IOT_PEER_AIRGO;
+			} else
 				break;
+
+		default:
+			break;
 		}
-				
+
 		i += (pIE->Length + 2);
 	}
-	
-	DBG_871X("link to new AP\n");
+
+	RTW_INFO("link to new AP\n");
 	return HT_IOT_PEER_UNKNOWN;
 }
 
+#ifdef CONFIG_80211AC_VHT
+unsigned char get_vht_mu_bfer_cap(u8 *pframe, uint len)
+{
+	unsigned int i;
+	unsigned int mu_bfer=0;
+	PNDIS_802_11_VARIABLE_IEs pIE;
+
+	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < len;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + i);
+
+		switch (pIE->ElementID) {
+
+		case EID_VHTCapability:
+			mu_bfer = GET_VHT_CAPABILITY_ELE_MU_BFER(pIE->data);
+			break;
+		default:
+			break;
+		}
+		i += (pIE->Length + 2);
+	}
+	return mu_bfer;
+}
+#endif
+
 void update_capinfo(PADAPTER Adapter, u16 updateCap)
 {
 	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	BOOLEAN		ShortPreamble;
 
-	// Check preamble mode, 2005.01.06, by rcnjko.
-	// Mark to update preamble value forever, 2008.03.18 by lanhsin
-	//if( pMgntInfo->RegPreambleMode == PREAMBLE_AUTO )
+	/* Check preamble mode, 2005.01.06, by rcnjko. */
+	/* Mark to update preamble value forever, 2008.03.18 by lanhsin */
+	/* if( pMgntInfo->RegPreambleMode == PREAMBLE_AUTO ) */
 	{
-			
-		if(updateCap & cShortPreamble)
-		{ // Short Preamble
-			if(pmlmeinfo->preamble_mode != PREAMBLE_SHORT) // PREAMBLE_LONG or PREAMBLE_AUTO
-			{
+
+		if (updateCap & cShortPreamble) {
+			/* Short Preamble */
+			if (pmlmeinfo->preamble_mode != PREAMBLE_SHORT) { /* PREAMBLE_LONG or PREAMBLE_AUTO */
 				ShortPreamble = _TRUE;
 				pmlmeinfo->preamble_mode = PREAMBLE_SHORT;
-				rtw_hal_set_hwreg( Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble );
+				rtw_hal_set_hwreg(Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble);
 			}
-		}
-		else
-		{ // Long Preamble
-			if(pmlmeinfo->preamble_mode != PREAMBLE_LONG)  // PREAMBLE_SHORT or PREAMBLE_AUTO
-			{
+		} else {
+			/* Long Preamble */
+			if (pmlmeinfo->preamble_mode != PREAMBLE_LONG) { /* PREAMBLE_SHORT or PREAMBLE_AUTO */
 				ShortPreamble = _FALSE;
 				pmlmeinfo->preamble_mode = PREAMBLE_LONG;
-				rtw_hal_set_hwreg( Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble );
+				rtw_hal_set_hwreg(Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble);
 			}
 		}
 	}
 
-	if ( updateCap & cIBSS ) {
-		//Filen: See 802.11-2007 p.91
+	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_11_24N | WIRELESS_11A | WIRELESS_11_5N | WIRELESS_11AC))
-		{
+	} else {
+		/* Filen: See 802.11-2007 p.90 */
+		if (pmlmeext->cur_wireless_mode & (WIRELESS_11_24N | WIRELESS_11A | WIRELESS_11_5N | WIRELESS_11AC))
 			pmlmeinfo->slotTime = SHORT_SLOT_TIME;
-		}
-		else if( pmlmeext->cur_wireless_mode & (WIRELESS_11G))
-		{
-			if( (updateCap & cShortSlotTime) /* && (!(pMgntInfo->pHTInfo->RT2RT_HT_Mode & RT_HT_CAP_USE_LONG_PREAMBLE)) */)
-			{ // Short Slot Time
+		else if (pmlmeext->cur_wireless_mode & (WIRELESS_11G)) {
+			if ((updateCap & cShortSlotTime) /* && (!(pMgntInfo->pHTInfo->RT2RT_HT_Mode & RT_HT_CAP_USE_LONG_PREAMBLE)) */) {
+				/* Short Slot Time */
 				pmlmeinfo->slotTime = SHORT_SLOT_TIME;
-			}
-			else
-			{ // Long Slot Time
+			} else {
+				/* Long Slot Time */
 				pmlmeinfo->slotTime = NON_SHORT_SLOT_TIME;
 			}
-		}
-		else
-		{
-			//B Mode
+		} else {
+			/* B Mode */
 			pmlmeinfo->slotTime = NON_SHORT_SLOT_TIME;
 		}
- 	}
- 
-	rtw_hal_set_hwreg( Adapter, HW_VAR_SLOT_TIME, &pmlmeinfo->slotTime );
+	}
+
+	rtw_hal_set_hwreg(Adapter, HW_VAR_SLOT_TIME, &pmlmeinfo->slotTime);
 
 }
 
@@ -3235,71 +3117,64 @@ void update_wireless_mode(_adapter *padapter)
 	u32 SIFS_Timer;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
 	unsigned char			*rate = cur_network->SupportedRates;
 #ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo= &(padapter->wdinfo);
-#endif //CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 
 	ratelen = rtw_get_rateset_len(cur_network->SupportedRates);
 
 	if ((pmlmeinfo->HT_info_enable) && (pmlmeinfo->HT_caps_enable))
-	{
 		pmlmeinfo->HT_enable = 1;
-	}
 
-	if(pmlmeext->cur_channel > 14)
-	{
+	if (pmlmeext->cur_channel > 14) {
 		if (pmlmeinfo->VHT_enable)
 			network_type = WIRELESS_11AC;
 		else if (pmlmeinfo->HT_enable)
 			network_type = WIRELESS_11_5N;
 
 		network_type |= WIRELESS_11A;
-	}
-	else
-	{
+	} else {
 		if (pmlmeinfo->VHT_enable)
 			network_type = WIRELESS_11AC;
 		else if (pmlmeinfo->HT_enable)
 			network_type = WIRELESS_11_24N;
-	
+
 		if ((cckratesonly_included(rate, ratelen)) == _TRUE)
-		{
 			network_type |= WIRELESS_11B;
-		}
-		else if((cckrates_included(rate, ratelen)) == _TRUE)
-		{
+		else if ((cckrates_included(rate, ratelen)) == _TRUE)
 			network_type |= WIRELESS_11BG;
-		}
 		else
-		{
 			network_type |= WIRELESS_11G;
-		}
 	}
 
 	pmlmeext->cur_wireless_mode = network_type & padapter->registrypriv.wireless_mode;
-	/* DBG_871X("network_type=%02x, padapter->registrypriv.wireless_mode=%02x\n", network_type, padapter->registrypriv.wireless_mode); */
-/*
-	if((pmlmeext->cur_wireless_mode==WIRELESS_11G) ||
-		(pmlmeext->cur_wireless_mode==WIRELESS_11BG))//WIRELESS_MODE_G)
-		SIFS_Timer = 0x0a0a;//CCK
+	/* RTW_INFO("network_type=%02x, padapter->registrypriv.wireless_mode=%02x\n", network_type, padapter->registrypriv.wireless_mode); */
+#if 0
+	if ((pmlmeext->cur_wireless_mode == WIRELESS_11G) ||
+	    (pmlmeext->cur_wireless_mode == WIRELESS_11BG)) /* WIRELESS_MODE_G) */
+		SIFS_Timer = 0x0a0a;/* CCK */
 	else
-		SIFS_Timer = 0x0e0e;//pHalData->SifsTime; //OFDM
-*/
-	
-	SIFS_Timer = 0x0a0a0808; //0x0808 -> for CCK, 0x0a0a -> for OFDM
-                             //change this value if having IOT issues.
-		
-	rtw_hal_set_hwreg( padapter, HW_VAR_RESP_SIFS,  (u8 *)&SIFS_Timer);
+		SIFS_Timer = 0x0e0e;/* pHalData->SifsTime; //OFDM */
+#endif
+
+	SIFS_Timer = 0x0a0a0808; /* 0x0808->for CCK, 0x0a0a->for OFDM
+                              * change this value if having IOT issues. */
+
+	rtw_hal_set_hwreg(padapter, HW_VAR_RESP_SIFS, (u8 *)&SIFS_Timer);
 
-	rtw_hal_set_hwreg( padapter, HW_VAR_WIRELESS_MODE,  (u8 *)&(pmlmeext->cur_wireless_mode));
+	rtw_hal_set_hwreg(padapter, HW_VAR_WIRELESS_MODE, (u8 *)&(pmlmeext->cur_wireless_mode));
 
 	if ((pmlmeext->cur_wireless_mode & WIRELESS_11B)
-#ifdef CONFIG_P2P
-		&& rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
-#endif /* CONFIG_P2P */
-		)
+		#ifdef CONFIG_P2P
+		&& (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
+			#ifdef CONFIG_IOCTL_CFG80211
+			|| !rtw_cfg80211_iface_has_p2p_group_cap(padapter)
+			#endif
+			)
+		#endif
+	)
 		update_mgnt_tx_rate(padapter, IEEE80211_CCK_RATE_1MB);
 	else
 		update_mgnt_tx_rate(padapter, IEEE80211_OFDM_RATE_6MB);
@@ -3313,36 +3188,32 @@ void fire_write_MAC_cmd(_adapter *padapter, unsigned int addr, unsigned int valu
 	struct reg_rw_parm			*pwriteMacPara;
 	struct cmd_priv					*pcmdpriv = &(padapter->cmdpriv);
 
-	if ((ph2c = (struct cmd_obj*)rtw_zmalloc(sizeof(struct cmd_obj))) == NULL)
-	{
+	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (ph2c == NULL)
 		return;
-	}	
 
-	if ((pwriteMacPara = (struct reg_rw_parm*)rtw_malloc(sizeof(struct reg_rw_parm))) == NULL) 
-	{		
+	pwriteMacPara = (struct reg_rw_parm *)rtw_malloc(sizeof(struct reg_rw_parm));
+	if (pwriteMacPara == NULL) {
 		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
 		return;
 	}
-	
+
 	pwriteMacPara->rw = 1;
 	pwriteMacPara->addr = addr;
 	pwriteMacPara->value = value;
-	
+
 	init_h2fwcmd_w_parm_no_rsp(ph2c, pwriteMacPara, GEN_CMD_CODE(_Write_MACREG));
 	rtw_enqueue_cmd(pcmdpriv, ph2c);
-#endif	
+#endif
 }
 
 void update_sta_basic_rate(struct sta_info *psta, u8 wireless_mode)
 {
-	if(IsSupportedTxCCK(wireless_mode))
-	{
-		// Only B, B/G, and B/G/N AP could use CCK rate
+	if (IsSupportedTxCCK(wireless_mode)) {
+		/* Only B, B/G, and B/G/N AP could use CCK rate */
 		_rtw_memcpy(psta->bssrateset, rtw_basic_rate_cck, 4);
 		psta->bssratelen = 4;
-	}
-	else
-	{
+	} else {
 		_rtw_memcpy(psta->bssrateset, rtw_basic_rate_ofdm, 3);
 		psta->bssratelen = 3;
 	}
@@ -3379,7 +3250,7 @@ ext_rate:
 		int i;
 
 		for (i = 0; i < *rate_num; i++)
-			DBG_871X("rate:0x%02x\n", *(rate_set + i));
+			RTW_INFO("rate:0x%02x\n", *(rate_set + i));
 	}
 
 	return _SUCCESS;
@@ -3388,13 +3259,12 @@ ext_rate:
 void process_addba_req(_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;
+	u16 tid, start_seq, param;
+	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);
-	u8 size;
+	u8 size, accept = _FALSE;
 
 	psta = rtw_get_stainfo(pstapriv, addr);
 	if (!psta)
@@ -3403,44 +3273,63 @@ void process_addba_req(_adapter *padapter, u8 *paddba_req, u8 *addr)
 	start_seq = le16_to_cpu(preq->BA_starting_seqctrl) >> 4;
 
 	param = le16_to_cpu(preq->BA_para_set);
-	tid = (param>>2)&0x0f;
+	tid = (param >> 2) & 0x0f;
 
-	preorder_ctrl = &psta->recvreorder_ctrl[tid];
 
-	#ifdef CONFIG_UPDATE_INDICATE_SEQ_WHILE_PROCESS_ADDBA_REQ
-	preorder_ctrl->indicate_seq = start_seq;
-	#ifdef DBG_RX_SEQ
-	DBG_871X("DBG_RX_SEQ %s:%d IndicateSeq: %d, start_seq: %d\n", __func__, __LINE__,
-		preorder_ctrl->indicate_seq, start_seq);
-	#endif
-	#else
-	preorder_ctrl->indicate_seq = 0xffff;
-	#endif
-
-	preorder_ctrl->enable = rtw_rx_ampdu_is_accept(padapter);
-	size = rtw_rx_ampdu_size(padapter);
-
-	if (preorder_ctrl->enable == _TRUE) {
-		preorder_ctrl->ampdu_size = size;
-		issue_addba_rsp(padapter, addr, tid, 0, size);
-	} else {
-		issue_addba_rsp(padapter, addr, tid, 37, size); /* reject ADDBA Req */
+	accept = rtw_rx_ampdu_is_accept(padapter);
+	if (padapter->fix_rx_ampdu_size != RX_AMPDU_SIZE_INVALID)
+		size = padapter->fix_rx_ampdu_size;
+	else {
+		size = rtw_rx_ampdu_size(padapter);
+		size = rtw_min(size, rx_ampdu_size_sta_limit(padapter, psta));
 	}
 
+	if (accept == _TRUE)
+		rtw_addbarsp_cmd(padapter, addr, tid, 0, size, start_seq);
+	else
+		rtw_addbarsp_cmd(padapter, addr, tid, 37, size, start_seq); /* reject ADDBA Req */
+
+exit:
+	return;
+}
+
+void rtw_process_bar_frame(_adapter *padapter, union recv_frame *precv_frame)
+{
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	struct sta_info *psta = NULL;
+	struct recv_reorder_ctrl *preorder_ctrl = NULL;
+	u8 tid = 0;
+	u16 start_seq=0;
+
+	psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+	if (psta == NULL)
+		goto exit;
+
+	tid = ((cpu_to_le16((*(u16 *)(pframe + 16))) & 0xf000) >> 12);
+	preorder_ctrl = &psta->recvreorder_ctrl[tid];
+	start_seq = ((cpu_to_le16(*(u16 *)(pframe + 18))) >> 4);
+	preorder_ctrl->indicate_seq = start_seq;
+
+	/* for Debug use */
+	if (0)
+		RTW_INFO(FUNC_ADPT_FMT" tid=%d, start_seq=%d\n", FUNC_ADPT_ARG(padapter),  tid, start_seq);
+
 exit:
 	return;
 }
 
 void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
-{	
-	u8* pIE;
+{
+	u8 *pIE;
 	u32 *pbuf;
-		
+
 	pIE = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
-	pbuf = (u32*)pIE;
+	pbuf = (u32 *)pIE;
+
+	pmlmeext->TSFValue = le32_to_cpu(*(pbuf + 1));
 
-	pmlmeext->TSFValue = le32_to_cpu(*(pbuf+1));
-	
 	pmlmeext->TSFValue = pmlmeext->TSFValue << 32;
 
 	pmlmeext->TSFValue |= le32_to_cpu(*pbuf);
@@ -3452,11 +3341,11 @@ void correct_TSF(_adapter *padapter, struct mlme_ext_priv *pmlmeext)
 }
 
 void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
-{	
+{
 	int i;
-	u8* pIE;
+	u8 *pIE;
 	u32 *pbuf;
-	u64 tsf=0;
+	u64 tsf = 0;
 	u32 delay_ms;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
@@ -3464,44 +3353,40 @@ void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
 	pmlmeext->bcn_cnt++;
 
 	pIE = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
-	pbuf = (u32*)pIE;
+	pbuf = (u32 *)pIE;
 
-	tsf = le32_to_cpu(*(pbuf+1));	
+	tsf = le32_to_cpu(*(pbuf + 1));
 	tsf = tsf << 32;
 	tsf |= le32_to_cpu(*pbuf);
 
-	//DBG_871X("%s(): tsf_upper= 0x%08x, tsf_lower=0x%08x\n", __func__, (u32)(tsf>>32), (u32)tsf);
+	/* RTW_INFO("%s(): tsf_upper= 0x%08x, tsf_lower=0x%08x\n", __func__, (u32)(tsf>>32), (u32)tsf); */
 
-	//delay = (timestamp mod 1024*100)/1000 (unit: ms)
-	//delay_ms = do_div(tsf, (pmlmeinfo->bcn_interval*1024))/1000;
-	delay_ms = rtw_modular64(tsf, (pmlmeinfo->bcn_interval*1024));
-	delay_ms = delay_ms/1000;
+	/* delay = (timestamp mod 1024*100)/1000 (unit: ms) */
+	/* delay_ms = do_div(tsf, (pmlmeinfo->bcn_interval*1024))/1000; */
+	delay_ms = rtw_modular64(tsf, (pmlmeinfo->bcn_interval * 1024));
+	delay_ms = delay_ms / 1000;
 
-	if(delay_ms >= 8)
-	{
+	if (delay_ms >= 8) {
 		pmlmeext->bcn_delay_cnt[8]++;
-		//pmlmeext->bcn_delay_ratio[8] = (pmlmeext->bcn_delay_cnt[8] * 100) /pmlmeext->bcn_cnt;
-	}
-	else
-	{
+		/* pmlmeext->bcn_delay_ratio[8] = (pmlmeext->bcn_delay_cnt[8] * 100) /pmlmeext->bcn_cnt; */
+	} else {
 		pmlmeext->bcn_delay_cnt[delay_ms]++;
-		//pmlmeext->bcn_delay_ratio[delay_ms] = (pmlmeext->bcn_delay_cnt[delay_ms] * 100) /pmlmeext->bcn_cnt;
+		/* pmlmeext->bcn_delay_ratio[delay_ms] = (pmlmeext->bcn_delay_cnt[delay_ms] * 100) /pmlmeext->bcn_cnt; */
 	}
 
-/*
-	DBG_871X("%s(): (a)bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt);
+	/*
+		RTW_INFO("%s(): (a)bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt);
 
 
-	for(i=0; i<9; i++)
-	{
-		DBG_871X("%s():bcn_delay_cnt[%d]=%d,  bcn_delay_ratio[%d]=%d\n", __func__, i, 
-			pmlmeext->bcn_delay_cnt[i] , i, pmlmeext->bcn_delay_ratio[i]);			
-	}	
-*/
+		for(i=0; i<9; i++)
+		{
+			RTW_INFO("%s():bcn_delay_cnt[%d]=%d,  bcn_delay_ratio[%d]=%d\n", __func__, i,
+				pmlmeext->bcn_delay_cnt[i] , i, pmlmeext->bcn_delay_ratio[i]);
+		}
+	*/
 
-	//dump for  adaptive_early_32k
-	if(pmlmeext->bcn_cnt > 100 && (pmlmeext->adaptive_tsf_done==_TRUE))
-	{	
+	/* dump for  adaptive_early_32k */
+	if (pmlmeext->bcn_cnt > 100 && (pmlmeext->adaptive_tsf_done == _TRUE)) {
 		u8 ratio_20_delay, ratio_80_delay;
 		u8 DrvBcnEarly, DrvBcnTimeOut;
 
@@ -3509,43 +3394,40 @@ void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
 		ratio_80_delay = 0;
 		DrvBcnEarly = 0xff;
 		DrvBcnTimeOut = 0xff;
-	
-		DBG_871X("%s(): bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt);
 
-		for(i=0; i<9; i++)
-		{
-			pmlmeext->bcn_delay_ratio[i] = (pmlmeext->bcn_delay_cnt[i] * 100) /pmlmeext->bcn_cnt;
-			
-		
-			//DBG_871X("%s():bcn_delay_cnt[%d]=%d,  bcn_delay_ratio[%d]=%d\n", __func__, i, 
-			//	pmlmeext->bcn_delay_cnt[i] , i, pmlmeext->bcn_delay_ratio[i]);
+		RTW_INFO("%s(): bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt);
+
+		for (i = 0; i < 9; i++) {
+			pmlmeext->bcn_delay_ratio[i] = (pmlmeext->bcn_delay_cnt[i] * 100) / pmlmeext->bcn_cnt;
+
+
+			/* RTW_INFO("%s():bcn_delay_cnt[%d]=%d,  bcn_delay_ratio[%d]=%d\n", __func__, i,  */
+			/*	pmlmeext->bcn_delay_cnt[i] , i, pmlmeext->bcn_delay_ratio[i]); */
 
 			ratio_20_delay += pmlmeext->bcn_delay_ratio[i];
 			ratio_80_delay += pmlmeext->bcn_delay_ratio[i];
-		
-			if(ratio_20_delay > 20 && DrvBcnEarly == 0xff)
-			{			
+
+			if (ratio_20_delay > 20 && DrvBcnEarly == 0xff) {
 				DrvBcnEarly = i;
-				//DBG_871X("%s(): DrvBcnEarly = %d\n", __func__, DrvBcnEarly);
-			}	
+				/* RTW_INFO("%s(): DrvBcnEarly = %d\n", __func__, DrvBcnEarly); */
+			}
 
-			if(ratio_80_delay > 80 && DrvBcnTimeOut == 0xff)
-			{
+			if (ratio_80_delay > 80 && DrvBcnTimeOut == 0xff) {
 				DrvBcnTimeOut = i;
-				//DBG_871X("%s(): DrvBcnTimeOut = %d\n", __func__, DrvBcnTimeOut);
+				/* RTW_INFO("%s(): DrvBcnTimeOut = %d\n", __func__, DrvBcnTimeOut); */
 			}
-			
-			//reset adaptive_early_32k cnt
+
+			/* reset adaptive_early_32k cnt */
 			pmlmeext->bcn_delay_cnt[i] = 0;
-			pmlmeext->bcn_delay_ratio[i] = 0;			
-		}	
+			pmlmeext->bcn_delay_ratio[i] = 0;
+		}
 
 		pmlmeext->DrvBcnEarly = DrvBcnEarly;
 		pmlmeext->DrvBcnTimeOut = DrvBcnTimeOut;
 
-		pmlmeext->bcn_cnt = 0;		
-	}	
-	
+		pmlmeext->bcn_cnt = 0;
+	}
+
 }
 
 
@@ -3554,40 +3436,38 @@ void beacon_timing_control(_adapter *padapter)
 	rtw_hal_bcn_related_reg_setting(padapter);
 }
 
-#define CONFIG_SHARED_BMC_MACID
-
 void dump_macid_map(void *sel, struct macid_bmp *map, u8 max_num)
 {
-	DBG_871X_SEL_NL(sel, "0x%08x\n", map->m0);
+	RTW_PRINT_SEL(sel, "0x%08x\n", map->m0);
 #if (MACID_NUM_SW_LIMIT > 32)
 	if (max_num && max_num > 32)
-		DBG_871X_SEL_NL(sel, "0x%08x\n", map->m1);
+		RTW_PRINT_SEL(sel, "0x%08x\n", map->m1);
 #endif
 #if (MACID_NUM_SW_LIMIT > 64)
 	if (max_num && max_num > 64)
-		DBG_871X_SEL_NL(sel, "0x%08x\n", map->m2);
+		RTW_PRINT_SEL(sel, "0x%08x\n", map->m2);
 #endif
 #if (MACID_NUM_SW_LIMIT > 96)
 	if (max_num && max_num > 96)
-		DBG_871X_SEL_NL(sel, "0x%08x\n", map->m3);
+		RTW_PRINT_SEL(sel, "0x%08x\n", map->m3);
 #endif
 }
 
 inline bool rtw_macid_is_set(struct macid_bmp *map, u8 id)
 {
 	if (id < 32)
-		return (map->m0 & BIT(id));
+		return map->m0 & BIT(id);
 #if (MACID_NUM_SW_LIMIT > 32)
 	else if (id < 64)
-		return (map->m1 & BIT(id-32));
+		return map->m1 & BIT(id - 32);
 #endif
 #if (MACID_NUM_SW_LIMIT > 64)
 	else if (id < 96)
-		return (map->m2 & BIT(id-64));
+		return map->m2 & BIT(id - 64);
 #endif
 #if (MACID_NUM_SW_LIMIT > 96)
 	else if (id < 128)
-		return (map->m3 & BIT(id-96));
+		return map->m3 & BIT(id - 96);
 #endif
 	else
 		rtw_warn_on(1);
@@ -3601,15 +3481,15 @@ inline void rtw_macid_map_set(struct macid_bmp *map, u8 id)
 		map->m0 |= BIT(id);
 #if (MACID_NUM_SW_LIMIT > 32)
 	else if (id < 64)
-		map->m1 |= BIT(id-32);
+		map->m1 |= BIT(id - 32);
 #endif
 #if (MACID_NUM_SW_LIMIT > 64)
 	else if (id < 96)
-		map->m2 |= BIT(id-64);
+		map->m2 |= BIT(id - 64);
 #endif
 #if (MACID_NUM_SW_LIMIT > 96)
 	else if (id < 128)
-		map->m3 |= BIT(id-96);
+		map->m3 |= BIT(id - 96);
 #endif
 	else
 		rtw_warn_on(1);
@@ -3621,15 +3501,15 @@ inline void rtw_macid_map_clr(struct macid_bmp *map, u8 id)
 		map->m0 &= ~BIT(id);
 #if (MACID_NUM_SW_LIMIT > 32)
 	else if (id < 64)
-		map->m1 &= ~BIT(id-32);
+		map->m1 &= ~BIT(id - 32);
 #endif
 #if (MACID_NUM_SW_LIMIT > 64)
 	else if (id < 96)
-		map->m2 &= ~BIT(id-64);
+		map->m2 &= ~BIT(id - 64);
 #endif
 #if (MACID_NUM_SW_LIMIT > 96)
 	else if (id < 128)
-		map->m3 &= ~BIT(id-96);
+		map->m3 &= ~BIT(id - 96);
 #endif
 	else
 		rtw_warn_on(1);
@@ -3645,82 +3525,146 @@ inline bool rtw_macid_is_bmc(struct macid_ctl_t *macid_ctl, u8 id)
 	return rtw_macid_is_set(&macid_ctl->bmc, id);
 }
 
-inline s8 rtw_macid_get_if_g(struct macid_ctl_t *macid_ctl, u8 id)
+inline u8 rtw_macid_get_iface_bmp(struct macid_ctl_t *macid_ctl, u8 id)
 {
 	int i;
+	u8 iface_bmp = 0;
 
-#ifdef CONFIG_SHARED_BMC_MACID
-	if (rtw_macid_is_bmc(macid_ctl,id))
-		return -1;
-#endif
-
-	for (i=0;i<IFACE_ID_MAX;i++) {
+	for (i = 0; i < CONFIG_IFACE_NUMBER; i++) {
 		if (rtw_macid_is_set(&macid_ctl->if_g[i], id))
-			return i;
+			iface_bmp |= BIT(i);
+	}
+	return iface_bmp;
+}
+
+inline bool rtw_macid_is_iface_shared(struct macid_ctl_t *macid_ctl, u8 id)
+{
+	int i;
+	u8 iface_bmp = 0;
+
+	for (i = 0; i < CONFIG_IFACE_NUMBER; i++) {
+		if (rtw_macid_is_set(&macid_ctl->if_g[i], id)) {
+			if (iface_bmp)
+				return 1;
+			iface_bmp |= BIT(i);
+		}
+	}
+
+	return 0;
+}
+
+inline bool rtw_macid_is_iface_specific(struct macid_ctl_t *macid_ctl, u8 id, _adapter *adapter)
+{
+	int i;
+	u8 iface_bmp = 0;
+
+	for (i = 0; i < CONFIG_IFACE_NUMBER; i++) {
+		if (rtw_macid_is_set(&macid_ctl->if_g[i], id)) {
+			if (iface_bmp || i != adapter->iface_id)
+				return 0;
+			iface_bmp |= BIT(i);
+		}
 	}
-	return -1;
+
+	return iface_bmp ? 1 : 0;
 }
 
 inline s8 rtw_macid_get_ch_g(struct macid_ctl_t *macid_ctl, u8 id)
 {
 	int i;
 
-	for (i=0;i<2;i++) {
+	for (i = 0; i < 2; i++) {
 		if (rtw_macid_is_set(&macid_ctl->ch_g[i], id))
 			return i;
 	}
 	return -1;
 }
 
+/*Record bc's mac-id and sec-cam-id*/
+inline void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+
+	macid_ctl->iface_bmc[padapter->iface_id] = mac_id;
+}
+inline u8 rtw_iface_bcmc_id_get(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+
+	return macid_ctl->iface_bmc[padapter->iface_id];
+}
+
 void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta)
 {
 	int i;
 	_irqL irqL;
-	u8 bc_addr[ETH_ALEN] = {0xff,0xff,0xff,0xff,0xff,0xff};
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
 	struct macid_bmp *used_map = &macid_ctl->used;
-	//static u8 last_id = 0; /* for testing */
+	/* static u8 last_id = 0;  for testing */
 	u8 last_id = 0;
+	u8 is_bc_sta = _FALSE;
 
-	if (_rtw_memcmp(psta->hwaddr, adapter_mac_addr(padapter), ETH_ALEN)) {
-		psta->mac_id = macid_ctl->num;
+	if (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), ETH_ALEN)) {
+		psta->cmn.mac_id = macid_ctl->num;
 		return;
 	}
 
-#ifdef CONFIG_SHARED_BMC_MACID
-	if(_rtw_memcmp(psta->hwaddr, bc_addr, ETH_ALEN)) {
-		/* use shared broadcast & multicast macid 1 */
-		_enter_critical_bh(&macid_ctl->lock, &irqL);
-		rtw_macid_map_set(used_map, 1);
-		rtw_macid_map_set(&macid_ctl->bmc, 1);
-		for (i=0;i<IFACE_ID_MAX;i++)
-			rtw_macid_map_set(&macid_ctl->if_g[padapter->iface_id], 1);
-		macid_ctl->sta[1] = psta;
-		/* TODO ch_g? */
-		_exit_critical_bh(&macid_ctl->lock, &irqL);
-		i = 1;
+	if (_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN)) {
+		is_bc_sta = _TRUE;
+		rtw_iface_bcmc_id_set(padapter, INVALID_SEC_MAC_CAM_ID);	/*init default value*/
+	}
+
+	if (is_bc_sta
+		#ifdef CONFIG_CONCURRENT_MODE
+		&& (MLME_IS_STA(padapter) || MLME_IS_NULL(padapter))
+		#endif
+	) {
+		/* STA mode have no BMC data TX, shared with this macid */
+		/* When non-concurrent, only one BMC data TX is used, shared with this macid */
+		/* TODO: When concurrent, non-security BMC data TX may use this, but will not control by specific macid sleep */
+		i = RTW_DEFAULT_MGMT_MACID;
 		goto assigned;
 	}
-#endif
 
 	_enter_critical_bh(&macid_ctl->lock, &irqL);
 
-	for (i=last_id;i<macid_ctl->num;i++) {
-		#ifdef CONFIG_SHARED_BMC_MACID
-		if (i == 1)
-			continue;
-		#endif
-		if (!rtw_macid_is_used(macid_ctl, i))
-			break;
+	for (i = last_id; i < macid_ctl->num; i++) {
+#ifdef CONFIG_MCC_MODE
+		/* macid 0/1 reserve for mcc for mgnt queue macid */
+		if (MCC_EN(padapter)) {
+			if (i == MCC_ROLE_STA_GC_MGMT_QUEUE_MACID)
+				continue;
+			if (i == MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID)
+				continue;
+		}
+#endif /* CONFIG_MCC_MODE */
+
+		if (is_bc_sta) {
+			struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
+
+			if ((!rtw_macid_is_used(macid_ctl, i)) && (!rtw_sec_camid_is_used(cam_ctl, i)))
+				break;
+		} else {
+			if (!rtw_macid_is_used(macid_ctl, i))
+				break;
+		}
 	}
 
 	if (i < macid_ctl->num) {
 
 		rtw_macid_map_set(used_map, i);
 
-		if(_rtw_memcmp(psta->hwaddr, bc_addr, ETH_ALEN))
+		if (is_bc_sta) {
+			struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
+
 			rtw_macid_map_set(&macid_ctl->bmc, i);
+			rtw_iface_bcmc_id_set(padapter, i);
+			rtw_sec_cam_map_set(&cam_ctl->used, i);
+		}
 
 		rtw_macid_map_set(&macid_ctl->if_g[padapter->iface_id], i);
 		macid_ctl->sta[i] = psta;
@@ -3734,19 +3678,18 @@ void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta)
 	_exit_critical_bh(&macid_ctl->lock, &irqL);
 
 	if (i >= macid_ctl->num) {
-		psta->mac_id = macid_ctl->num;
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" if%u, hwaddr:"MAC_FMT" no available macid\n"
-			, FUNC_ADPT_ARG(padapter), padapter->iface_id+1, MAC_ARG(psta->hwaddr));
+		psta->cmn.mac_id = macid_ctl->num;
+		RTW_ERR(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" no available macid\n"
+			, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1, MAC_ARG(psta->cmn.mac_addr));
 		rtw_warn_on(1);
 		goto exit;
-	} else {
+	} else
 		goto assigned;
-	}
 
 assigned:
-	psta->mac_id = i;
-	DBG_871X(FUNC_ADPT_FMT" if%u, hwaddr:"MAC_FMT" macid:%u\n"
-		, FUNC_ADPT_ARG(padapter), padapter->iface_id+1, MAC_ARG(psta->hwaddr), psta->mac_id);
+	psta->cmn.mac_id = i;
+	RTW_INFO(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u\n"
+		, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
 
 exit:
 	return;
@@ -3755,54 +3698,84 @@ exit:
 void rtw_release_macid(_adapter *padapter, struct sta_info *psta)
 {
 	_irqL irqL;
-	u8 bc_addr[ETH_ALEN] = {0xff,0xff,0xff,0xff,0xff,0xff};
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	u8 ifbmp;
+	int i;
 
-	if (_rtw_memcmp(psta->hwaddr, adapter_mac_addr(padapter), ETH_ALEN))
-		return;
-
-#ifdef CONFIG_SHARED_BMC_MACID
-	if(_rtw_memcmp(psta->hwaddr, bc_addr, ETH_ALEN))
-		return;
+	if (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), ETH_ALEN))
+		goto exit;
 
-	if (psta->mac_id == 1) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" if%u, hwaddr:"MAC_FMT" with macid:%u\n"
-			, FUNC_ADPT_ARG(padapter), padapter->iface_id+1, MAC_ARG(psta->hwaddr), psta->mac_id);
+	if (psta->cmn.mac_id >= macid_ctl->num) {
+		RTW_WARN(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u not valid\n"
+			, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
+			, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
 		rtw_warn_on(1);
-		return;
+		goto exit;
 	}
-#endif
+
+	if (psta->cmn.mac_id == RTW_DEFAULT_MGMT_MACID)
+		goto msg;
 
 	_enter_critical_bh(&macid_ctl->lock, &irqL);
 
-	if (psta->mac_id < macid_ctl->num) {
-		int i;
+	if (!rtw_macid_is_used(macid_ctl, psta->cmn.mac_id)) {
+		RTW_WARN(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u not used\n"
+			, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
+			, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
+		_exit_critical_bh(&macid_ctl->lock, &irqL);
+		rtw_warn_on(1);
+		goto exit;
+	}
 
-		if (!rtw_macid_is_used(macid_ctl, psta->mac_id)) {
-			DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" if%u, hwaddr:"MAC_FMT" macid:%u not used\n"
-				, FUNC_ADPT_ARG(padapter), padapter->iface_id+1, MAC_ARG(psta->hwaddr), psta->mac_id);
-			rtw_warn_on(1);
-		}
+	ifbmp = rtw_macid_get_iface_bmp(macid_ctl, psta->cmn.mac_id);
+	if (!(ifbmp & BIT(padapter->iface_id))) {
+		RTW_WARN(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u not used by self\n"
+			, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
+			, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
+		_exit_critical_bh(&macid_ctl->lock, &irqL);
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN)) {
+		struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
+		u8 id = rtw_iface_bcmc_id_get(padapter);
+
+		if ((id != INVALID_SEC_MAC_CAM_ID) && (id < cam_ctl->num))
+			rtw_sec_cam_map_clr(&cam_ctl->used, id);
 
-		rtw_macid_map_clr(&macid_ctl->used, psta->mac_id);
-		rtw_macid_map_clr(&macid_ctl->bmc, psta->mac_id);
-		for (i=0;i<IFACE_ID_MAX;i++)
-			rtw_macid_map_clr(&macid_ctl->if_g[i], psta->mac_id);
-		for (i=0;i<2;i++)
-			rtw_macid_map_clr(&macid_ctl->ch_g[i], psta->mac_id);
-		macid_ctl->sta[psta->mac_id] = NULL;
+		rtw_iface_bcmc_id_set(padapter, INVALID_SEC_MAC_CAM_ID);
+	}
+
+	rtw_macid_map_clr(&macid_ctl->if_g[padapter->iface_id], psta->cmn.mac_id);
+
+	ifbmp &= ~BIT(padapter->iface_id);
+	if (!ifbmp) { /* only used by self */
+		rtw_macid_map_clr(&macid_ctl->used, psta->cmn.mac_id);
+		rtw_macid_map_clr(&macid_ctl->bmc, psta->cmn.mac_id);
+		for (i = 0; i < 2; i++)
+			rtw_macid_map_clr(&macid_ctl->ch_g[i], psta->cmn.mac_id);
+		macid_ctl->sta[psta->cmn.mac_id] = NULL;
 	}
 
 	_exit_critical_bh(&macid_ctl->lock, &irqL);
 
-	psta->mac_id = macid_ctl->num;
+msg:
+	RTW_INFO(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u\n"
+		, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
+		, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id
+	);
+
+exit:
+	psta->cmn.mac_id = macid_ctl->num;
 }
 
-//For 8188E RA
+/* For 8188E RA */
 u8 rtw_search_max_mac_id(_adapter *padapter)
 {
-	u8 max_mac_id=0;
+	u8 max_mac_id = 0;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
 	int i;
@@ -3811,15 +3784,15 @@ u8 rtw_search_max_mac_id(_adapter *padapter)
 	/* TODO: Only search for connected macid? */
 
 	_enter_critical_bh(&macid_ctl->lock, &irqL);
-	for(i=(macid_ctl->num-1); i>0 ; i--) {
-		if (!rtw_macid_is_used(macid_ctl, i))
+	for (i = (macid_ctl->num - 1); i > 0 ; i--) {
+		if (rtw_macid_is_used(macid_ctl, i))
 			break;
 	}
 	_exit_critical_bh(&macid_ctl->lock, &irqL);
 	max_mac_id = i;
 
 	return max_mac_id;
-}		
+}
 
 inline void rtw_macid_ctl_set_h2c_msr(struct macid_ctl_t *macid_ctl, u8 id, u8 h2c_msr)
 {
@@ -3830,7 +3803,7 @@ inline void rtw_macid_ctl_set_h2c_msr(struct macid_ctl_t *macid_ctl, u8 id, u8 h
 
 	macid_ctl->h2c_msr[id] = h2c_msr;
 	if (0)
-		DBG_871X("macid:%u, h2c_msr:"H2C_MSR_FMT"\n", id, H2C_MSR_ARG(&macid_ctl->h2c_msr[id]));
+		RTW_INFO("macid:%u, h2c_msr:"H2C_MSR_FMT"\n", id, H2C_MSR_ARG(&macid_ctl->h2c_msr[id]));
 }
 
 inline void rtw_macid_ctl_set_bw(struct macid_ctl_t *macid_ctl, u8 id, u8 bw)
@@ -3881,8 +3854,31 @@ inline void rtw_macid_ctl_set_rate_bmp1(struct macid_ctl_t *macid_ctl, u8 id, u3
 		RTW_INFO("macid:%u, rate_bmp1:0x%08X\n", id, macid_ctl->rate_bmp1[id]);
 }
 
+inline void rtw_macid_ctl_init_sleep_reg(struct macid_ctl_t *macid_ctl, u16 m0, u16 m1, u16 m2, u16 m3)
+{
+	macid_ctl->reg_sleep_m0 = m0;
+#if (MACID_NUM_SW_LIMIT > 32)
+	macid_ctl->reg_sleep_m1 = m1;
+#endif
+#if (MACID_NUM_SW_LIMIT > 64)
+	macid_ctl->reg_sleep_m2 = m2;
+#endif
+#if (MACID_NUM_SW_LIMIT > 96)
+	macid_ctl->reg_sleep_m3 = m3;
+#endif
+}
+
 inline void rtw_macid_ctl_init(struct macid_ctl_t *macid_ctl)
 {
+	int i;
+	u8 id = RTW_DEFAULT_MGMT_MACID;
+
+	rtw_macid_map_set(&macid_ctl->used, id);
+	rtw_macid_map_set(&macid_ctl->bmc, id);
+	for (i = 0; i < CONFIG_IFACE_NUMBER; i++)
+		rtw_macid_map_set(&macid_ctl->if_g[i], id);
+	macid_ctl->sta[id] = NULL;
+
 	_rtw_spinlock_init(&macid_ctl->lock);
 }
 
@@ -3891,105 +3887,183 @@ inline void rtw_macid_ctl_deinit(struct macid_ctl_t *macid_ctl)
 	_rtw_spinlock_free(&macid_ctl->lock);
 }
 
+inline bool rtw_bmp_is_set(const u8 *bmp, u8 bmp_len, u8 id)
+{
+	if (id / 8 >= bmp_len)
+		return 0;
+
+	return bmp[id / 8] & BIT(id % 8);
+}
+
+inline void rtw_bmp_set(u8 *bmp, u8 bmp_len, u8 id)
+{
+	if (id / 8 < bmp_len)
+		bmp[id / 8] |= BIT(id % 8);
+}
+
+inline void rtw_bmp_clear(u8 *bmp, u8 bmp_len, u8 id)
+{
+	if (id / 8 < bmp_len)
+		bmp[id / 8] &= ~BIT(id % 8);
+}
+
+inline bool rtw_bmp_not_empty(const u8 *bmp, u8 bmp_len)
+{
+	int i;
+
+	for (i = 0; i < bmp_len; i++) {
+		if (bmp[i])
+			return 1;
+	}
+
+	return 0;
+}
+
+inline bool rtw_bmp_not_empty_exclude_bit0(const u8 *bmp, u8 bmp_len)
+{
+	int i;
+
+	for (i = 0; i < bmp_len; i++) {
+		if (i == 0) {
+			if (bmp[i] & 0xFE)
+				return 1;
+		} else {
+			if (bmp[i])
+				return 1;
+		}
+	}
+
+	return 0;
+}
+
+#ifdef CONFIG_AP_MODE
+/* Check the id be set or not in map , if yes , return a none zero value*/
+bool rtw_tim_map_is_set(_adapter *padapter, const u8 *map, u8 id)
+{
+	return rtw_bmp_is_set(map, padapter->stapriv.aid_bmp_len, id);
+}
+
+/* Set the id into map array*/
+void rtw_tim_map_set(_adapter *padapter, u8 *map, u8 id)
+{
+	rtw_bmp_set(map, padapter->stapriv.aid_bmp_len, id);
+}
+
+/* Clear the id from map array*/
+void rtw_tim_map_clear(_adapter *padapter, u8 *map, u8 id)
+{
+	rtw_bmp_clear(map, padapter->stapriv.aid_bmp_len, id);
+}
+
+/* Check have anyone bit be set , if yes return true*/
+bool rtw_tim_map_anyone_be_set(_adapter *padapter, const u8 *map)
+{
+	return rtw_bmp_not_empty(map, padapter->stapriv.aid_bmp_len);
+}
+
+/* Check have anyone bit be set exclude bit0 , if yes return true*/
+bool rtw_tim_map_anyone_be_set_exclude_aid0(_adapter *padapter, const u8 *map)
+{
+	return rtw_bmp_not_empty_exclude_bit0(map, padapter->stapriv.aid_bmp_len);
+}
+#endif /* CONFIG_AP_MODE */
+
 #if 0
 unsigned int setup_beacon_frame(_adapter *padapter, unsigned char *beacon_frame)
 {
 	unsigned short				ATIMWindow;
 	unsigned char					*pframe;
-	struct tx_desc 				*ptxdesc;
-	struct rtw_ieee80211_hdr 	*pwlanhdr;
+	struct tx_desc				*ptxdesc;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short				*fctrl;
 	unsigned int					rate_len, len = 0;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
 	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-	
+
 	_rtw_memset(beacon_frame, 0, 256);
-	
+
 	pframe = beacon_frame + TXDESC_SIZE;
-	
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;	
-	
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
-	
+
 	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
-	
-	SetFrameSubType(pframe, WIFI_BEACON);
-	
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);	
+
+	set_frame_sub_type(pframe, WIFI_BEACON);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	len = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//timestamp will be inserted by hardware
+	/* timestamp will be inserted by hardware */
 	pframe += 8;
 	len += 8;
 
-	// beacon interval: 2 bytes
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2); 
+	/* beacon interval: 2 bytes */
+	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
 
 	pframe += 2;
 	len += 2;
 
-	// capability info: 2 bytes
+	/* capability info: 2 bytes */
 	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
 
 	pframe += 2;
 	len += 2;
 
-	// SSID
+	/* SSID */
 	pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &len);
 
-	// supported rates...
+	/* supported rates... */
 	rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
-	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8)? 8: rate_len), cur_network->SupportedRates, &len);
+	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &len);
 
-	// DS parameter set
+	/* DS parameter set */
 	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &len);
 
-	// IBSS Parameter Set...
-	//ATIMWindow = cur->Configuration.ATIMWindow;
+	/* IBSS Parameter Set... */
+	/* ATIMWindow = cur->Configuration.ATIMWindow; */
 	ATIMWindow = 0;
 	pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &len);
 
-	//todo: ERP IE
-	
-	// EXTERNDED SUPPORTED RATE
+	/* todo: ERP IE */
+
+	/* EXTERNDED SUPPORTED RATE */
 	if (rate_len > 8)
-	{
 		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &len);
-	}
 
-	if ((len + TXDESC_SIZE) > 256)
-	{
-		//DBG_871X("marc: beacon frame too large\n");
+	if ((len + TXDESC_SIZE) > 256) {
+		/* RTW_INFO("marc: beacon frame too large\n"); */
 		return 0;
 	}
 
-	//fill the tx descriptor
+	/* fill the tx descriptor */
 	ptxdesc = (struct tx_desc *)beacon_frame;
-	
-	//offset 0	
-	ptxdesc->txdw0 |= cpu_to_le32(len & 0x0000ffff); 
-	ptxdesc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) << OFFSET_SHT) & 0x00ff0000); //default = 32 bytes for TX Desc
-	
-	//offset 4	
+
+	/* offset 0	 */
+	ptxdesc->txdw0 |= cpu_to_le32(len & 0x0000ffff);
+	ptxdesc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) << OFFSET_SHT) & 0x00ff0000); /* default = 32 bytes for TX Desc */
+
+	/* offset 4	 */
 	ptxdesc->txdw1 |= cpu_to_le32((0x10 << QSEL_SHT) & 0x00001f00);
-	
-	//offset 8		
+
+	/* offset 8		 */
 	ptxdesc->txdw2 |= cpu_to_le32(BMC);
 	ptxdesc->txdw2 |= cpu_to_le32(BK);
 
-	//offset 16		
+	/* offset 16		 */
 	ptxdesc->txdw4 = 0x80000000;
-	
-	//offset 20
-	ptxdesc->txdw5 = 0x00000000; //1M	
-	
-	return (len + TXDESC_SIZE);
+
+	/* offset 20 */
+	ptxdesc->txdw5 = 0x00000000; /* 1M	 */
+
+	return len + TXDESC_SIZE;
 }
 #endif
 
@@ -3997,12 +4071,12 @@ _adapter *dvobj_get_port0_adapter(struct dvobj_priv *dvobj)
 {
 	_adapter *port0_iface = NULL;
 	int i;
-	for (i=0;i<dvobj->iface_nums;i++) {
-		if (get_iface_type(dvobj->padapters[i]) == IFACE_PORT0)
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (get_hw_port(dvobj->padapters[i]) == HW_PORT0)
 			break;
 	}
 
-	if (i<0 || i>=dvobj->iface_nums)
+	if (i < 0 || i >= dvobj->iface_nums)
 		rtw_warn_on(1);
 	else
 		port0_iface = dvobj->padapters[i];
@@ -4010,32 +4084,98 @@ _adapter *dvobj_get_port0_adapter(struct dvobj_priv *dvobj)
 	return port0_iface;
 }
 
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-void rtw_get_current_ip_address(PADAPTER padapter, u8 *pcurrentip)
+_adapter *dvobj_get_unregisterd_adapter(struct dvobj_priv *dvobj)
 {
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct in_device *my_ip_ptr = padapter->pnetdev->ip_ptr;
-	u8 ipaddress[4];
-	
-	if ( (pmlmeinfo->state & WIFI_FW_LINKING_STATE) ||
-			pmlmeinfo->state & WIFI_FW_AP_STATE) {
-		if ( my_ip_ptr != NULL ) {
-			struct in_ifaddr *my_ifa_list  = my_ip_ptr->ifa_list ;
-			if ( my_ifa_list != NULL ) {
-				ipaddress[0] = my_ifa_list->ifa_address & 0xFF;
-				ipaddress[1] = (my_ifa_list->ifa_address >> 8) & 0xFF;
-				ipaddress[2] = (my_ifa_list->ifa_address >> 16) & 0xFF;
-				ipaddress[3] = my_ifa_list->ifa_address >> 24;
-				DBG_871X("%s: %d.%d.%d.%d ==========\n", __func__, 
-						ipaddress[0], ipaddress[1], ipaddress[2], ipaddress[3]);
-				_rtw_memcpy(pcurrentip, ipaddress, 4);
+	_adapter *adapter = NULL;
+	int i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (dvobj->padapters[i]->registered == 0)
+			break;
+	}
+
+	if (i < dvobj->iface_nums)
+		adapter = dvobj->padapters[i];
+
+	return adapter;
+}
+
+_adapter *dvobj_get_adapter_by_addr(struct dvobj_priv *dvobj, u8 *addr)
+{
+	_adapter *adapter = NULL;
+	int i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (_rtw_memcmp(dvobj->padapters[i]->mac_addr, addr, ETH_ALEN) == _TRUE)
+			break;
+	}
+
+	if (i < dvobj->iface_nums)
+		adapter = dvobj->padapters[i];
+
+	return adapter;
+}
+
+#ifdef CONFIG_WOWLAN
+bool rtw_wowlan_parser_pattern_cmd(u8 *input, char *pattern,
+				   int *pattern_len, char *bit_mask)
+{
+	char *cp = NULL, *end = NULL;
+	size_t len = 0;
+	int pos = 0, mask_pos = 0, res = 0;
+	u8 member[2] = {0};
+
+	cp = strchr(input, '=');
+	if (cp) {
+		*cp = 0;
+		cp++;
+		input = cp;
+	}
+
+	while (1) {
+		cp = strchr(input, ':');
+
+		if (cp) {
+			len = strlen(input) - strlen(cp);
+			*cp = 0;
+			cp++;
+		} else
+			len = 2;
+
+		if (bit_mask && (strcmp(input, "-") == 0 ||
+				 strcmp(input, "xx") == 0 ||
+				 strcmp(input, "--") == 0)) {
+			/* skip this byte and leave mask bit unset */
+		} else {
+			u8 hex;
+
+			strncpy(member, input, len);
+			if (!rtw_check_pattern_valid(member, sizeof(member))) {
+				RTW_INFO("%s:[ERROR] pattern is invalid!!\n",
+					 __func__);
+				goto error;
 			}
+
+			res = sscanf(member, "%02hhx", &hex);
+			pattern[pos] = hex;
+			mask_pos = pos / 8;
+			if (bit_mask)
+				bit_mask[mask_pos] |= 1 << (pos % 8);
 		}
+
+		pos++;
+		if (!cp)
+			break;
+		input = cp;
 	}
+
+	(*pattern_len) = pos;
+
+	return _TRUE;
+error:
+	return _FALSE;
 }
-#endif
-#ifdef CONFIG_WOWLAN
+
 bool rtw_check_pattern_valid(u8 *input, u8 len)
 {
 	int i = 0;
@@ -4053,200 +4193,154 @@ bool rtw_check_pattern_valid(u8 *input, u8 len)
 exit:
 	return res;
 }
-
-bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)
+void rtw_wow_pattern_sw_reset(_adapter *adapter)
 {
-	u32 data_l = 0, data_h = 0, rx_dma_buff_sz = 0, page_sz = 0;
-	u16 offset, rx_buf_ptr = 0;
-	u16 cam_start_offset = 0;
-	u16 ctrl_l = 0, ctrl_h = 0;
-	u8 count = 0, tmp = 0;
-	int i = 0;
-	bool res = _TRUE;
+	int i;
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(adapter);
 
-	if (idx > MAX_WKFM_NUM) {
-		DBG_871X("[Error]: %s, pattern index is out of range\n",
-			 __func__);
-		return _FALSE;
-	}
+	if (pwrctrlpriv->default_patterns_en == _TRUE)
+		pwrctrlpriv->wowlan_pattern_idx = DEFAULT_PATTERN_NUM;
+	else
+		pwrctrlpriv->wowlan_pattern_idx = 0;
 
-	rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ_WOW,
-			    (u8 *)&rx_dma_buff_sz);
-	
-	if (rx_dma_buff_sz == 0) {
-		DBG_871X("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
-		return _FALSE;
+	for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++) {
+		_rtw_memset(pwrctrlpriv->patterns[i].content, '\0', sizeof(pwrctrlpriv->patterns[i].content));
+		_rtw_memset(pwrctrlpriv->patterns[i].mask, '\0', sizeof(pwrctrlpriv->patterns[i].mask));
+		pwrctrlpriv->patterns[i].len = 0;
 	}
+}
 
-	rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
-	
-	if (page_sz == 0) {
-		DBG_871X("[Error]: %s, page_sz is 0!!\n", __func__);
-		return _FALSE;
-	}
+u8 rtw_set_default_pattern(_adapter *adapter)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	u8 index = 0;
+	u8 multicast_addr[3] = {0x01, 0x00, 0x5e};
+	u8 multicast_ip[4] = {0xe0, 0x28, 0x28, 0x2a};
 
-	offset = (u16)PageNum(rx_dma_buff_sz, page_sz);
-	cam_start_offset = offset * page_sz;
+	u8 unicast_mask[5] = {0x3f, 0x70, 0x80, 0xc0, 0x03};
+	u8 icmpv6_mask[7] = {0x00, 0x70, 0x10, 0x00, 0xc0, 0xc0, 0x3f};
+	u8 multicast_mask[5] = {0x07, 0x70, 0x80, 0xc0, 0x03};
 
-	ctrl_l = 0x0;
-	ctrl_h = 0x0;
+	u8 ip_protocol[3] = {0x08, 0x00, 0x45};
+	u8 ipv6_protocol[3] = {0x86, 0xdd, 0x60};
 
-	/* Enable RX packet buffer access */
-	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, RXPKT_BUF_SELECT);
+	u8 *target = NULL;
 
-	/* Read the WKFM CAM */
-	for (i = 0; i < (WKFMCAM_ADDR_NUM / 2); i++) {
-		/*
-		 * Set Rx packet buffer offset.
-		 * RxBufer pointer increases 1, we can access 8 bytes in Rx packet buffer.
-		 * CAM start offset (unit: 1 byte) =  Index*WKFMCAM_SIZE
-		 * RxBufer pointer addr = (CAM start offset + per entry offset of a WKFMCAM)/8
-		 * * Index: The index of the wake up frame mask
-		 * * WKFMCAM_SIZE: the total size of one WKFM CAM
-		 * * per entry offset of a WKFM CAM: Addr i * 4 bytes
-		 */
-		rx_buf_ptr =
-			(cam_start_offset + idx*WKFMCAM_SIZE + i*8) >> 3;
-		rtw_write16(adapter, REG_PKTBUF_DBG_CTRL, rx_buf_ptr);
-
-		rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
-		data_l = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_L);
-		data_h = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_H);
-
-		DBG_871X("[%d]: %08x %08x\n", i, data_h, data_l);
-
-		count = 0;
-
-		do {
-			tmp = rtw_read8(adapter, REG_RXPKTBUF_CTRL);
-			rtw_udelay_os(2);
-			count++;
-		} while (!tmp && count < 100);
-
-		if (count >= 100) {
-			DBG_871X("%s count:%d\n", __func__, count);
-			res = _FALSE;
-		}
+	if (pwrpriv->default_patterns_en == _FALSE)
+		return 0;
+
+	for (index = 0 ; index < DEFAULT_PATTERN_NUM ; index++) {
+		_rtw_memset(pwrpriv->patterns[index].content, 0,
+			    sizeof(pwrpriv->patterns[index].content));
+		_rtw_memset(pwrpriv->patterns[index].mask, 0,
+			    sizeof(pwrpriv->patterns[index].mask));
+		pwrpriv->patterns[index].len = 0;
 	}
 
-	/* Disable RX packet buffer access */
-	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL,
-		   DISABLE_TRXPKT_BUF_ACCESS);
-	return res;
-}
+	/*TCP/ICMP unicast*/
+	for (index = 0 ; index < DEFAULT_PATTERN_NUM ; index++) {
+		switch (index) {
+		case 0:
+			target = pwrpriv->patterns[index].content;
+			_rtw_memcpy(target, adapter_mac_addr(adapter),
+				    ETH_ALEN);
 
-bool rtw_write_to_frame_mask(_adapter *adapter, u8 idx,
-				 struct  rtl_wow_pattern *context)
-{
-	u32 data = 0, rx_dma_buff_sz = 0, page_sz = 0;
-	u16 offset, rx_buf_ptr = 0;
-	u16 cam_start_offset = 0;
-	u16 ctrl_l = 0, ctrl_h = 0;
-	u8 count = 0, tmp = 0;
-	int res = 0, i = 0;
+			target += ETH_TYPE_OFFSET;
+			_rtw_memcpy(target, &ip_protocol,
+				    sizeof(ip_protocol));
 
-	if (idx > MAX_WKFM_NUM) {
-		DBG_871X("[Error]: %s, pattern index is out of range\n",
-			 __func__);
-		return _FALSE;
-	}
+			/* TCP */
+			target += (PROTOCOL_OFFSET - ETH_TYPE_OFFSET);
+			_rtw_memset(target, 0x06, 1);
 
-	rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ_WOW,
-			    (u8 *)&rx_dma_buff_sz);
-	
-	if (rx_dma_buff_sz == 0) {
-		DBG_871X("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
-		return _FALSE;
-	}
+			target += (IP_OFFSET - PROTOCOL_OFFSET);
 
-	rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
-	
-	if (page_sz == 0) {
-		DBG_871X("[Error]: %s, page_sz is 0!!\n", __func__);
-		return _FALSE;
-	}
+			_rtw_memcpy(target, pmlmeinfo->ip_addr,
+				    RTW_IP_ADDR_LEN);
 
-	offset = (u16)PageNum(rx_dma_buff_sz, page_sz);
+			_rtw_memcpy(pwrpriv->patterns[index].mask,
+				    &unicast_mask, sizeof(unicast_mask));
+
+			pwrpriv->patterns[index].len =
+				IP_OFFSET + RTW_IP_ADDR_LEN;
+			break;
+		case 1:
+			target = pwrpriv->patterns[index].content;
+			_rtw_memcpy(target, adapter_mac_addr(adapter),
+				    ETH_ALEN);
 
-	cam_start_offset = offset * page_sz;
+			target += ETH_TYPE_OFFSET;
+			_rtw_memcpy(target, &ip_protocol, sizeof(ip_protocol));
 
-	if (IS_HARDWARE_TYPE_8188E(adapter)) {
-		ctrl_l = 0x0001;
-		ctrl_h = 0x0001;
-	} else {
-		ctrl_l = 0x0f01;
-		ctrl_h = 0xf001;
-	}
+			/* ICMP */
+			target += (PROTOCOL_OFFSET - ETH_TYPE_OFFSET);
+			_rtw_memset(target, 0x01, 1);
 
-	/* Enable RX packet buffer access */
-	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, RXPKT_BUF_SELECT);
+			target += (IP_OFFSET - PROTOCOL_OFFSET);
+			_rtw_memcpy(target, pmlmeinfo->ip_addr,
+				    RTW_IP_ADDR_LEN);
 
-	/* Write the WKFM CAM */
-	for (i = 0; i < WKFMCAM_ADDR_NUM; i++) {
-		/*
-		 * Set Rx packet buffer offset.
-		 * RxBufer pointer increases 1, we can access 8 bytes in Rx packet buffer.
-		 * CAM start offset (unit: 1 byte) =  Index*WKFMCAM_SIZE
-		 * RxBufer pointer addr = (CAM start offset + per entry offset of a WKFMCAM)/8
-		 * * Index: The index of the wake up frame mask
-		 * * WKFMCAM_SIZE: the total size of one WKFM CAM
-		 * * per entry offset of a WKFM CAM: Addr i * 4 bytes
-		 */
-		rx_buf_ptr =
-			(cam_start_offset + idx*WKFMCAM_SIZE + i*4) >> 3;
-		rtw_write16(adapter, REG_PKTBUF_DBG_CTRL, rx_buf_ptr);
+			_rtw_memcpy(pwrpriv->patterns[index].mask,
+				    &unicast_mask, sizeof(unicast_mask));
+			pwrpriv->patterns[index].len =
 
-		if (i == 0) {
-			if (context->type == PATTERN_VALID)
-				data = BIT(31);
-			else if (context->type == PATTERN_BROADCAST)
-				data = BIT(31) | BIT(26);
-			else if (context->type == PATTERN_MULTICAST)
-				data = BIT(31) | BIT(25);
-			else if (context->type == PATTERN_UNICAST)
-				data = BIT(31) | BIT(24);
-
-			if (context->crc != 0)
-				data |= context->crc;
-
-			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_L, data);
-			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
-		} else if (i == 1) {
-			data = 0;
-			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_H, data);
-			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_h);
-		} else if (i == 2 || i == 4) {
-			data = context->mask[i - 2];
-			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_L, data);
-			/* write to RX packet buffer*/
-			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
-		} else if (i == 3 || i == 5) {
-			data = context->mask[i - 2];
-			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_H, data);
-			/* write to RX packet buffer*/
-			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_h);
-		}
+				IP_OFFSET + RTW_IP_ADDR_LEN;
+			break;
+#ifdef CONFIG_IPV6
+		case 2:
+			if (pwrpriv->wowlan_ns_offload_en == _TRUE) {
+				target = pwrpriv->patterns[index].content;
+				target += ETH_TYPE_OFFSET;
+
+				_rtw_memcpy(target, &ipv6_protocol,
+					    sizeof(ipv6_protocol));
+
+				/* ICMPv6 */
+				target += (IPv6_PROTOCOL_OFFSET -
+					   ETH_TYPE_OFFSET);
+				_rtw_memset(target, 0x3a, 1);
+
+				target += (IPv6_OFFSET - IPv6_PROTOCOL_OFFSET);
+				_rtw_memcpy(target, pmlmeinfo->ip6_addr,
+					    RTW_IPv6_ADDR_LEN);
+
+				_rtw_memcpy(pwrpriv->patterns[index].mask,
+					    &icmpv6_mask, sizeof(icmpv6_mask));
+				pwrpriv->patterns[index].len =
+					IPv6_OFFSET + RTW_IPv6_ADDR_LEN;
+			}
+			break;
+#endif /*CONFIG_IPV6*/
+		case 3:
+			target = pwrpriv->patterns[index].content;
+			_rtw_memcpy(target, &multicast_addr,
+				    sizeof(multicast_addr));
 
-		count = 0;
-		do {
-			tmp = rtw_read8(adapter, REG_RXPKTBUF_CTRL);
-			rtw_udelay_os(2);
-			count++;
-		} while (tmp && count < 100);
+			target += ETH_TYPE_OFFSET;
+			_rtw_memcpy(target, &ip_protocol, sizeof(ip_protocol));
 
-		if (count >= 100)
-			res = _FALSE;
-		else
-			res = _TRUE;
-	}
+			/* UDP */
+			target += (PROTOCOL_OFFSET - ETH_TYPE_OFFSET);
+			_rtw_memset(target, 0x11, 1);
 
-	/* Disable RX packet buffer access */
-	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL,
-		   DISABLE_TRXPKT_BUF_ACCESS);
+			target += (IP_OFFSET - PROTOCOL_OFFSET);
+			_rtw_memcpy(target, &multicast_ip,
+				    sizeof(multicast_ip));
 
-	return res;
-}
+			_rtw_memcpy(pwrpriv->patterns[index].mask,
+				    &multicast_mask, sizeof(multicast_mask));
 
+			pwrpriv->patterns[index].len =
+				IP_OFFSET + sizeof(multicast_ip);
+			break;
+		default:
+			break;
+		}
+	}
+	return index;
+}
 
 void rtw_dump_priv_pattern(_adapter *adapter, u8 idx)
 {
@@ -4256,102 +4350,73 @@ void rtw_dump_priv_pattern(_adapter *adapter, u8 idx)
 	u8 val8 = 0;
 	int i = 0, j = 0, len = 0, max_len = 0;
 
-	DBG_871X("=========[%d]========\n", idx);
+	RTW_INFO("=========[%d]========\n", idx);
 
-	DBG_871X(">>>priv_pattern_content:\n");
+	RTW_INFO(">>>priv_pattern_content:\n");
 	p_str = str_1;
 	max_len = sizeof(str_1);
-	for (i = 0 ; i < MAX_WKFM_PATTERN_SIZE/8 ; i++) {
+	for (i = 0 ; i < MAX_WKFM_PATTERN_SIZE / 8 ; i++) {
 		_rtw_memset(p_str, 0, max_len);
 		len = 0;
 		for (j = 0 ; j < 8 ; j++) {
-			val8 = pwrctl->patterns[idx].content[i*8 + j];
+			val8 = pwrctl->patterns[idx].content[i * 8 + j];
 			len += snprintf(p_str + len, max_len - len,
 					"%02x ", val8);
 		}
-		DBG_871X("%s\n", p_str);
+		RTW_INFO("%s\n", p_str);
 	}
 
-	DBG_871X(">>>priv_pattern_mask:\n");
-	for (i = 0 ; i < MAX_WKFM_SIZE/8 ; i++) {
+	RTW_INFO(">>>priv_pattern_mask:\n");
+	for (i = 0 ; i < MAX_WKFM_SIZE / 8 ; i++) {
 		_rtw_memset(p_str, 0, max_len);
 		len = 0;
 		for (j = 0 ; j < 8 ; j++) {
-			val8 = pwrctl->patterns[idx].mask[i*8 + j];
+			val8 = pwrctl->patterns[idx].mask[i * 8 + j];
 			len += snprintf(p_str + len, max_len - len,
 					"%02x ", val8);
 		}
-		DBG_871X("%s\n", p_str);
+		RTW_INFO("%s\n", p_str);
 	}
+
+	RTW_INFO(">>>priv_pattern_len:\n");
+	RTW_INFO("%s: len: %d\n", __func__, pwrctl->patterns[idx].len);
 }
 
-void rtw_clean_pattern(_adapter *adapter)
+void rtw_wow_pattern_sw_dump(_adapter *adapter)
 {
-	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
-	struct rtl_wow_pattern zero_pattern;
-	int i = 0;
-
-	_rtw_memset(&zero_pattern, 0, sizeof(struct rtl_wow_pattern));
-
-	zero_pattern.type = PATTERN_INVALID;
-
-	for (i = 0; i < MAX_WKFM_NUM; i++)
-		rtw_write_to_frame_mask(adapter, i, &zero_pattern);
+	int i;
 
-	pwrctl->wowlan_pattern_idx = 0;
-	rtw_write8(adapter, REG_WKFMCAM_NUM, pwrctl->wowlan_pattern_idx);
+	RTW_INFO("********[RTK priv-patterns]*********\n");
+	for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++)
+		rtw_dump_priv_pattern(adapter, i);
 }
 
-void rtw_get_sec_iv(PADAPTER padapter, u8*pcur_dot11txpn, u8 *StaAddr)
+void rtw_get_sec_iv(PADAPTER padapter, u8 *pcur_dot11txpn, u8 *StaAddr)
 {
 	struct sta_info		*psta;
 	struct security_priv *psecpriv = &padapter->securitypriv;
 
 	_rtw_memset(pcur_dot11txpn, 0, 8);
-	if(NULL == StaAddr)
-		return; 
+	if (NULL == StaAddr)
+		return;
 	psta = rtw_get_stainfo(&padapter->stapriv, StaAddr);
-	DBG_871X("%s(): StaAddr: %02x %02x %02x %02x %02x %02x\n", 
-		__func__, StaAddr[0], StaAddr[1], StaAddr[2],
-		StaAddr[3], StaAddr[4], StaAddr[5]);
+	RTW_INFO("%s(): StaAddr: %02x %02x %02x %02x %02x %02x\n",
+		 __func__, StaAddr[0], StaAddr[1], StaAddr[2],
+		 StaAddr[3], StaAddr[4], StaAddr[5]);
 
-	if(psta)
-	{
-		if (psecpriv->dot11PrivacyAlgrthm != _NO_PRIVACY_ && psta->dot11txpn.val > 0)
-			psta->dot11txpn.val--;
-		AES_IV(pcur_dot11txpn, psta->dot11txpn, 0);
+	if (psta) {
+		if (psecpriv->dot11PrivacyAlgrthm == _AES_)
+			AES_IV(pcur_dot11txpn, psta->dot11txpn, 0);
+		else if (psecpriv->dot11PrivacyAlgrthm == _TKIP_)
+			TKIP_IV(pcur_dot11txpn, psta->dot11txpn, 0);
 
-		DBG_871X("%s(): CurrentIV: %02x %02x %02x %02x %02x %02x %02x %02x \n"
-		, __func__, pcur_dot11txpn[0],pcur_dot11txpn[1],
-		pcur_dot11txpn[2],pcur_dot11txpn[3], pcur_dot11txpn[4],
-		pcur_dot11txpn[5],pcur_dot11txpn[6],pcur_dot11txpn[7]);
+		RTW_INFO("%s(): CurrentIV: %02x %02x %02x %02x %02x %02x %02x %02x\n"
+			 , __func__, pcur_dot11txpn[0], pcur_dot11txpn[1],
+			pcur_dot11txpn[2], pcur_dot11txpn[3], pcur_dot11txpn[4],
+			pcur_dot11txpn[5], pcur_dot11txpn[6], pcur_dot11txpn[7]);
 	}
 }
-void rtw_set_sec_pn(PADAPTER padapter)
-{
-        struct sta_info         *psta;
-        struct mlme_ext_priv    *pmlmeext = &(padapter->mlmeextpriv);
-        struct mlme_ext_info    *pmlmeinfo = &(pmlmeext->mlmext_info);
-        struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-		struct security_priv *psecpriv = &padapter->securitypriv;
-
-        psta = rtw_get_stainfo(&padapter->stapriv,
-			get_my_bssid(&pmlmeinfo->network));
-
-        if(psta)
-        {
-		if (pwrpriv->wowlan_fw_iv > psta->dot11txpn.val)
-		{
-			if (psecpriv->dot11PrivacyAlgrthm != _NO_PRIVACY_)
-				psta->dot11txpn.val = pwrpriv->wowlan_fw_iv + 2;
-		} else {
-			DBG_871X("%s(): FW IV is smaller than driver\n", __func__);
-			psta->dot11txpn.val += 2;
-		}
-		DBG_871X("%s: dot11txpn: 0x%016llx\n", __func__ ,psta->dot11txpn.val);
-        }
-}
-#endif //CONFIG_WOWLAN
+#endif /* CONFIG_WOWLAN */
 
 #ifdef CONFIG_PNO_SUPPORT
 #define	CSCAN_TLV_TYPE_SSID_IE	'S'
@@ -4362,14 +4427,15 @@ void rtw_set_sec_pn(PADAPTER padapter)
 /*
  *  SSIDs list parsing from cscan tlv list
  */
-int rtw_parse_ssid_list_tlv(char** list_str, pno_ssid_t* ssid,
-	int max, int *bytes_left) {
-	char* str;
+int rtw_parse_ssid_list_tlv(char **list_str, pno_ssid_t *ssid,
+			    int max, int *bytes_left)
+{
+	char *str;
 
 	int idx = 0;
 
 	if ((list_str == NULL) || (*list_str == NULL) || (*bytes_left < 0)) {
-		DBG_871X("%s error paramters\n", __func__);
+		RTW_INFO("%s error paramters\n", __func__);
 		return -1;
 	}
 
@@ -4378,7 +4444,7 @@ int rtw_parse_ssid_list_tlv(char** list_str, pno_ssid_t* ssid,
 
 		if (str[0] != CSCAN_TLV_TYPE_SSID_IE) {
 			*list_str = str;
-			DBG_871X("nssid=%d left_parse=%d %d\n", idx, *bytes_left, str[0]);
+			RTW_INFO("nssid=%d left_parse=%d %d\n", idx, *bytes_left, str[0]);
 			return idx;
 		}
 
@@ -4389,40 +4455,38 @@ int rtw_parse_ssid_list_tlv(char** list_str, pno_ssid_t* ssid,
 		if (str[0] == 0) {
 			/* Broadcast SSID */
 			ssid[idx].SSID_len = 0;
-			memset((char*)ssid[idx].SSID, 0x0, WLAN_SSID_MAXLEN);
+			memset((char *)ssid[idx].SSID, 0x0, WLAN_SSID_MAXLEN);
 			*bytes_left -= 1;
 			str += 1;
 
-			DBG_871X("BROADCAST SCAN  left=%d\n", *bytes_left);
-		}
-		else if (str[0] <= WLAN_SSID_MAXLEN) {
-			 /* Get proper SSID size */
+			RTW_INFO("BROADCAST SCAN  left=%d\n", *bytes_left);
+		} else if (str[0] <= WLAN_SSID_MAXLEN) {
+			/* Get proper SSID size */
 			ssid[idx].SSID_len = str[0];
 			*bytes_left -= 1;
 			str += 1;
 
 			/* Get SSID */
 			if (ssid[idx].SSID_len > *bytes_left) {
-				DBG_871X("%s out of memory range len=%d but left=%d\n",
-				__func__, ssid[idx].SSID_len, *bytes_left);
+				RTW_INFO("%s out of memory range len=%d but left=%d\n",
+					__func__, ssid[idx].SSID_len, *bytes_left);
 				return -1;
 			}
 
-			memcpy((char*)ssid[idx].SSID, str, ssid[idx].SSID_len);
+			memcpy((char *)ssid[idx].SSID, str, ssid[idx].SSID_len);
 
 			*bytes_left -= ssid[idx].SSID_len;
 			str += ssid[idx].SSID_len;
 
-			DBG_871X("%s :size=%d left=%d\n",
-				(char*)ssid[idx].SSID, ssid[idx].SSID_len, *bytes_left);
-		}
-		else {
-			DBG_871X("### SSID size more that %d\n", str[0]);
+			RTW_INFO("%s :size=%d left=%d\n",
+				(char *)ssid[idx].SSID, ssid[idx].SSID_len, *bytes_left);
+		} else {
+			RTW_INFO("### SSID size more that %d\n", str[0]);
 			return -1;
 		}
 
 		if (idx++ >  max) {
-			DBG_871X("%s number of SSIDs more that %d\n", __func__, idx);
+			RTW_INFO("%s number of SSIDs more that %d\n", __func__, idx);
 			return -1;
 		}
 	}
@@ -4431,7 +4495,8 @@ int rtw_parse_ssid_list_tlv(char** list_str, pno_ssid_t* ssid,
 	return idx;
 }
 
-int rtw_parse_cipher_list(struct pno_nlo_info *nlo_info, char* list_str) {
+int rtw_parse_cipher_list(struct pno_nlo_info *nlo_info, char *list_str)
+{
 
 	char *pch, *pnext, *pend;
 	u8 key_len = 0, index = 0;
@@ -4439,7 +4504,7 @@ int rtw_parse_cipher_list(struct pno_nlo_info *nlo_info, char* list_str) {
 	pch = list_str;
 
 	if (nlo_info == NULL || list_str == NULL) {
-		DBG_871X("%s error paramters\n", __func__);
+		RTW_INFO("%s error paramters\n", __func__);
 		return -1;
 	}
 
@@ -4449,26 +4514,25 @@ int rtw_parse_cipher_list(struct pno_nlo_info *nlo_info, char* list_str) {
 			pch = pnext + strlen(CIPHER_IE);
 			pend = strstr(pch, "}");
 			if (strncmp(pch, CIPHER_NONE,
-						strlen(CIPHER_NONE)) == 0) {
+				    strlen(CIPHER_NONE)) == 0)
 				nlo_info->ssid_cipher_info[index] = 0x00;
-			} else if (strncmp(pch, CIPHER_WPA_PSK,
-						strlen(CIPHER_WPA_PSK)) == 0) {
+			else if (strncmp(pch, CIPHER_WPA_PSK,
+					 strlen(CIPHER_WPA_PSK)) == 0)
 				nlo_info->ssid_cipher_info[index] = 0x66;
-			} else if (strncmp(pch, CIPHER_WPA_EAP,
-						strlen(CIPHER_WPA_EAP)) == 0) {
+			else if (strncmp(pch, CIPHER_WPA_EAP,
+					 strlen(CIPHER_WPA_EAP)) == 0)
 				nlo_info->ssid_cipher_info[index] = 0x01;
-			}
-			index ++;
+			index++;
 			pch = pend + 1;
-		} else {
+		} else
 			break;
-		}
 	}
 	return 0;
 }
 
-int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t* ssid,
-	int num, int pno_time, int pno_repeat, int pno_freq_expo_max) {
+int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t *ssid,
+		 int num, int pno_time, int pno_repeat, int pno_freq_expo_max)
+{
 
 	int i = 0;
 	struct file *fp;
@@ -4477,7 +4541,7 @@ int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t* ssid,
 	u8 *source = NULL;
 	long len = 0;
 
-	DBG_871X("+%s+\n", __func__);
+	RTW_INFO("+%s+\n", __func__);
 
 	nlo_info->fast_scan_period = pno_time;
 	nlo_info->ssid_num = num & BIT_LEN_MASK_32(8);
@@ -4488,7 +4552,7 @@ int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t* ssid,
 	if (nlo_info->hidden_ssid_num > 8)
 		nlo_info->hidden_ssid_num = 8;
 
-	//TODO: channel list and probe index is all empty.
+	/* TODO: channel list and probe index is all empty. */
 	for (i = 0 ; i < num ; i++) {
 		nlo_info->ssid_length[i]
 			= ssid[i].SSID_len;
@@ -4497,15 +4561,15 @@ int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t* ssid,
 	/* cipher array */
 	fp = filp_open("/data/misc/wifi/wpa_supplicant.conf", O_RDONLY,  0644);
 	if (IS_ERR(fp)) {
-		DBG_871X("Error, wpa_supplicant.conf doesn't exist.\n");
-		DBG_871X("Error, cipher array using default value.\n");
+		RTW_INFO("Error, wpa_supplicant.conf doesn't exist.\n");
+		RTW_INFO("Error, cipher array using default value.\n");
 		return 0;
 	}
 
 	len = i_size_read(fp->f_path.dentry->d_inode);
 	if (len < 0 || len > 2048) {
-		DBG_871X("Error, file size is bigger than 2048.\n");
-		DBG_871X("Error, cipher array using default value.\n");
+		RTW_INFO("Error, file size is bigger than 2048.\n");
+		RTW_INFO("Error, cipher array using default value.\n");
 		return 0;
 	}
 
@@ -4523,27 +4587,29 @@ int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t* ssid,
 	set_fs(fs);
 	filp_close(fp, NULL);
 
-	DBG_871X("-%s-\n", __func__);
+	RTW_INFO("-%s-\n", __func__);
 	return 0;
 }
 
 int rtw_dev_ssid_list_set(struct pno_ssid_list *pno_ssid_list,
-	pno_ssid_t* ssid, u8 num) {
+			  pno_ssid_t *ssid, u8 num)
+{
 
 	int i = 0;
-	if(num > MAX_PNO_LIST_COUNT)
+	if (num > MAX_PNO_LIST_COUNT)
 		num = MAX_PNO_LIST_COUNT;
 
 	for (i = 0 ; i < num ; i++) {
 		_rtw_memcpy(&pno_ssid_list->node[i].SSID,
-			ssid[i].SSID, ssid[i].SSID_len);
+			    ssid[i].SSID, ssid[i].SSID_len);
 		pno_ssid_list->node[i].SSID_len = ssid[i].SSID_len;
 	}
 	return 0;
 }
 
-int rtw_dev_scan_info_set(_adapter *padapter, pno_ssid_t* ssid,
-	unsigned char ch, unsigned char ch_offset, unsigned short bw_mode) {
+int rtw_dev_scan_info_set(_adapter *padapter, pno_ssid_t *ssid,
+	  unsigned char ch, unsigned char ch_offset, unsigned short bw_mode)
+{
 
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	struct pno_scan_info *scan_info = pwrctl->pscan_info;
@@ -4554,7 +4620,7 @@ int rtw_dev_scan_info_set(_adapter *padapter, pno_ssid_t* ssid,
 	scan_info->orig_bw = bw_mode;
 	scan_info->orig_40_offset = ch_offset;
 
-	for(i = 0 ; i < scan_info->channel_num ; i++) {
+	for (i = 0 ; i < scan_info->channel_num ; i++) {
 		if (i < 11)
 			scan_info->ssid_channel_info[i].active = 1;
 		else
@@ -4563,19 +4629,20 @@ int rtw_dev_scan_info_set(_adapter *padapter, pno_ssid_t* ssid,
 		scan_info->ssid_channel_info[i].timeout = 100;
 
 		scan_info->ssid_channel_info[i].tx_power =
-			PHY_GetTxPowerIndex(padapter, 0, 0x02, bw_mode, i+1);
+			phy_get_tx_power_index(padapter, 0, 0x02, bw_mode, i + 1);
 
-		scan_info->ssid_channel_info[i].channel = i+1;
+		scan_info->ssid_channel_info[i].channel = i + 1;
 	}
 
-	DBG_871X("%s, channel_num: %d, orig_ch: %d, orig_bw: %d orig_40_offset: %d\n",
-		__func__, scan_info->channel_num, scan_info->orig_ch,
-		scan_info->orig_bw, scan_info->orig_40_offset);
+	RTW_INFO("%s, channel_num: %d, orig_ch: %d, orig_bw: %d orig_40_offset: %d\n",
+		 __func__, scan_info->channel_num, scan_info->orig_ch,
+		 scan_info->orig_bw, scan_info->orig_40_offset);
 	return 0;
 }
 
-int rtw_dev_pno_set(struct net_device *net, pno_ssid_t* ssid, int num,
-	int pno_time, int pno_repeat, int pno_freq_expo_max) {
+int rtw_dev_pno_set(struct net_device *net, pno_ssid_t *ssid, int num,
+		    int pno_time, int pno_repeat, int pno_freq_expo_max)
+{
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
@@ -4584,44 +4651,44 @@ int rtw_dev_pno_set(struct net_device *net, pno_ssid_t* ssid, int num,
 	int ret = -1;
 
 	if (num == 0) {
-		DBG_871X("%s, nssid is zero, no need to setup pno ssid list\n", __func__);
+		RTW_INFO("%s, nssid is zero, no need to setup pno ssid list\n", __func__);
 		return 0;
 	}
 
 	if (pwrctl == NULL) {
-		DBG_871X("%s, ERROR: pwrctl is NULL\n", __func__);
+		RTW_INFO("%s, ERROR: pwrctl is NULL\n", __func__);
 		return -1;
 	} else {
 		pwrctl->pnlo_info =
-			(pno_nlo_info_t*)rtw_zmalloc(sizeof(pno_nlo_info_t));
+			(pno_nlo_info_t *)rtw_zmalloc(sizeof(pno_nlo_info_t));
 		pwrctl->pno_ssid_list =
-			(pno_ssid_list_t*)rtw_zmalloc(sizeof(pno_ssid_list_t));
+			(pno_ssid_list_t *)rtw_zmalloc(sizeof(pno_ssid_list_t));
 		pwrctl->pscan_info =
-			(pno_scan_info_t*)rtw_zmalloc(sizeof(pno_scan_info_t));
+			(pno_scan_info_t *)rtw_zmalloc(sizeof(pno_scan_info_t));
 	}
 
 	if (pwrctl->pnlo_info == NULL ||
-		pwrctl->pscan_info == NULL ||
-		pwrctl->pno_ssid_list == NULL){
-		DBG_871X("%s, ERROR: alloc nlo_info, ssid_list, scan_info fail\n", __func__);
+	    pwrctl->pscan_info == NULL ||
+	    pwrctl->pno_ssid_list == NULL) {
+		RTW_INFO("%s, ERROR: alloc nlo_info, ssid_list, scan_info fail\n", __func__);
 		goto failing;
 	}
 
-	pwrctl->pno_in_resume = _FALSE;
+	pwrctl->wowlan_in_resume = _FALSE;
 
 	pwrctl->pno_inited = _TRUE;
 	/* NLO Info */
 	ret = rtw_dev_nlo_info_set(pwrctl->pnlo_info, ssid, num,
-			pno_time, pno_repeat, pno_freq_expo_max);
+				   pno_time, pno_repeat, pno_freq_expo_max);
 
 	/* SSID Info */
 	ret = rtw_dev_ssid_list_set(pwrctl->pno_ssid_list, ssid, num);
 
 	/* SCAN Info */
 	ret = rtw_dev_scan_info_set(padapter, ssid, pmlmeext->cur_channel,
-			pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
+			    pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
 
-	DBG_871X("+%s num: %d, pno_time: %d, pno_repeat:%d, pno_freq_expo_max:%d+\n",
+	RTW_INFO("+%s num: %d, pno_time: %d, pno_repeat:%d, pno_freq_expo_max:%d+\n",
 		 __func__, num, pno_time, pno_repeat, pno_freq_expo_max);
 
 	return 0;
@@ -4644,54 +4711,40 @@ failing:
 }
 
 #ifdef CONFIG_PNO_SET_DEBUG
-void rtw_dev_pno_debug(struct net_device *net) {
+void rtw_dev_pno_debug(struct net_device *net)
+{
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	int i = 0, j = 0;
 
-	DBG_871X("*******NLO_INFO********\n");
-	DBG_871X("ssid_num: %d\n", pwrctl->pnlo_info->ssid_num);
-	DBG_871X("fast_scan_iterations: %d\n",
-			pwrctl->pnlo_info->fast_scan_iterations);
-	DBG_871X("fast_scan_period: %d\n", pwrctl->pnlo_info->fast_scan_period);
-	DBG_871X("slow_scan_period: %d\n", pwrctl->pnlo_info->slow_scan_period);
-	DBG_871X("ssid_length: ");
-	for (i = 0 ; i < MAX_PNO_LIST_COUNT ; i++) {
-		printk("%d, ", pwrctl->pnlo_info->ssid_length[i]);
-	}
-	DBG_871X("\n");
+	RTW_INFO("*******NLO_INFO********\n");
+	RTW_INFO("ssid_num: %d\n", pwrctl->pnlo_info->ssid_num);
+	RTW_INFO("fast_scan_iterations: %d\n",
+		 pwrctl->pnlo_info->fast_scan_iterations);
+	RTW_INFO("fast_scan_period: %d\n", pwrctl->pnlo_info->fast_scan_period);
+	RTW_INFO("slow_scan_period: %d\n", pwrctl->pnlo_info->slow_scan_period);
 
-	DBG_871X("cipher_info: ");
-	for (i = 0 ; i < MAX_PNO_LIST_COUNT ; i++) {
-		DBG_871X("%d, ", pwrctl->pnlo_info->ssid_cipher_info[i]);
-	}
-	DBG_871X("\n");
 
-	DBG_871X("channel_info: ");
-	for (i = 0 ; i < MAX_PNO_LIST_COUNT ; i++) {
-		DBG_871X("%d, ", pwrctl->pnlo_info->ssid_channel_info[i]);
-	}
-	DBG_871X("\n");
 
-	DBG_871X("******SSID_LISD******\n");
 	for (i = 0 ; i < MAX_PNO_LIST_COUNT ; i++) {
-		DBG_871X("[%d]SSID: %s \n", i,
-			pwrctl->pno_ssid_list->node[i].SSID);
-	}
-
-	DBG_871X("******SCAN_INFO******\n");
-	DBG_871X("ch_num: %d\n", pwrctl->pscan_info->channel_num);
-	DBG_871X("orig_ch: %d\n", pwrctl->pscan_info->orig_ch);
-	DBG_871X("orig bw: %d\n", pwrctl->pscan_info->orig_bw);
-	DBG_871X("orig 40 offset: %d\n", pwrctl->pscan_info->orig_40_offset);
-	for(i = 0 ; i < MAX_SCAN_LIST_COUNT ; i++) {
-		DBG_871X("[%02d] avtive:%d, timeout:%d, tx_power:%d, ch:%02d\n",
-			i, pwrctl->pscan_info->ssid_channel_info[i].active,
-			pwrctl->pscan_info->ssid_channel_info[i].timeout,
-			pwrctl->pscan_info->ssid_channel_info[i].tx_power,
-			pwrctl->pscan_info->ssid_channel_info[i].channel);
-	}
-	DBG_871X("*****************\n");
-}
-#endif //CONFIG_PNO_SET_DEBUG
-#endif //CONFIG_PNO_SUPPORT
+		RTW_INFO("%d SSID (%s) length (%d) cipher(%x) channel(%d)\n",
+			i, pwrctl->pno_ssid_list->node[i].SSID, pwrctl->pnlo_info->ssid_length[i],
+			pwrctl->pnlo_info->ssid_cipher_info[i], pwrctl->pnlo_info->ssid_channel_info[i]);
+	}
+
+	RTW_INFO("******SCAN_INFO******\n");
+	RTW_INFO("ch_num: %d\n", pwrctl->pscan_info->channel_num);
+	RTW_INFO("orig_ch: %d\n", pwrctl->pscan_info->orig_ch);
+	RTW_INFO("orig bw: %d\n", pwrctl->pscan_info->orig_bw);
+	RTW_INFO("orig 40 offset: %d\n", pwrctl->pscan_info->orig_40_offset);
+	for (i = 0 ; i < MAX_SCAN_LIST_COUNT ; i++) {
+		RTW_INFO("[%02d] avtive:%d, timeout:%d, tx_power:%d, ch:%02d\n",
+			 i, pwrctl->pscan_info->ssid_channel_info[i].active,
+			 pwrctl->pscan_info->ssid_channel_info[i].timeout,
+			 pwrctl->pscan_info->ssid_channel_info[i].tx_power,
+			 pwrctl->pscan_info->ssid_channel_info[i].channel);
+	}
+	RTW_INFO("*****************\n");
+}
+#endif /* CONFIG_PNO_SET_DEBUG */
+#endif /* CONFIG_PNO_SUPPORT */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_xmit.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_xmit.c
index dc57bd46088e..4d69b8ac0dc3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_xmit.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/core/rtw_xmit.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTW_XMIT_C_
 
 #include <drv_types.h>
 #include <hal_data.h>
 
-#if defined (PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
-#error "Shall be Linux or Windows, but not both!\n"
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+	#error "Shall be Linux or Windows, but not both!\n"
 #endif
 
 
@@ -32,25 +28,22 @@ static u8 RFC1042_OUI[P80211_OUI_LEN] = { 0x00, 0x00, 0x00 };
 
 static void _init_txservq(struct tx_servq *ptxservq)
 {
-_func_enter_;
 	_rtw_init_listhead(&ptxservq->tx_pending);
 	_rtw_init_queue(&ptxservq->sta_pending);
 	ptxservq->qcnt = 0;
-_func_exit_;		
 }
 
 
 void	_rtw_init_sta_xmit_priv(struct sta_xmit_priv *psta_xmitpriv)
-{	
-	
-_func_enter_;
+{
 
-	_rtw_memset((unsigned char *)psta_xmitpriv, 0, sizeof (struct sta_xmit_priv));
+
+	_rtw_memset((unsigned char *)psta_xmitpriv, 0, sizeof(struct sta_xmit_priv));
 
 	_rtw_spinlock_init(&psta_xmitpriv->lock);
-	
-	//for(i = 0 ; i < MAX_NUMBLKS; i++)
-	//	_init_txservq(&(psta_xmitpriv->blk_q[i]));
+
+	/* 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);
@@ -58,80 +51,90 @@ _func_enter_;
 	_init_txservq(&psta_xmitpriv->vo_q);
 	_rtw_init_listhead(&psta_xmitpriv->legacy_dz);
 	_rtw_init_listhead(&psta_xmitpriv->apsd);
-	
-_func_exit_;	
+
+
+}
+
+void rtw_init_xmit_block(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	_rtw_spinlock_init(&dvobj->xmit_block_lock);
+	dvobj->xmit_block = XMIT_BLOCK_NONE;
 
 }
+void rtw_free_xmit_block(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	_rtw_spinlock_free(&dvobj->xmit_block_lock);
+}
 
 s32	_rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, _adapter *padapter)
 {
 	int i;
 	struct xmit_buf *pxmitbuf;
 	struct xmit_frame *pxframe;
-	sint	res=_SUCCESS;   
-	
-_func_enter_;   	
+	sint	res = _SUCCESS;
+
+
+	/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
+	/* _rtw_memset((unsigned char *)pxmitpriv, 0, sizeof(struct xmit_priv)); */
 
-	// We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc().
-	//_rtw_memset((unsigned char *)pxmitpriv, 0, sizeof(struct xmit_priv));
-	
 	_rtw_spinlock_init(&pxmitpriv->lock);
 	_rtw_spinlock_init(&pxmitpriv->lock_sctx);
 	_rtw_init_sema(&pxmitpriv->xmit_sema, 0);
-	_rtw_init_sema(&pxmitpriv->terminate_xmitthread_sema, 0);
 
-	/* 
+	/*
 	Please insert all the queue initializaiton using _rtw_init_queue below
 	*/
 
 	pxmitpriv->adapter = padapter;
-	
-	//for(i = 0 ; i < MAX_NUMBLKS; i++)
-	//	_rtw_init_queue(&pxmitpriv->blk_strms[i]);
-	
+
+	/* for(i = 0 ; i < MAX_NUMBLKS; i++) */
+	/*	_rtw_init_queue(&pxmitpriv->blk_strms[i]); */
+
 	_rtw_init_queue(&pxmitpriv->be_pending);
 	_rtw_init_queue(&pxmitpriv->bk_pending);
 	_rtw_init_queue(&pxmitpriv->vi_pending);
 	_rtw_init_queue(&pxmitpriv->vo_pending);
 	_rtw_init_queue(&pxmitpriv->bm_pending);
 
-	//_rtw_init_queue(&pxmitpriv->legacy_dz_queue);
-	//_rtw_init_queue(&pxmitpriv->apsd_queue);
+	/* _rtw_init_queue(&pxmitpriv->legacy_dz_queue); */
+	/* _rtw_init_queue(&pxmitpriv->apsd_queue); */
 
 	_rtw_init_queue(&pxmitpriv->free_xmit_queue);
 
-	/*	
-	Please allocate memory with the sz = (struct xmit_frame) * NR_XMITFRAME, 
+	/*
+	Please allocate memory with the sz = (struct xmit_frame) * NR_XMITFRAME,
 	and initialize free_xmit_frame below.
 	Please also apply  free_txobj to link_up all the xmit_frames...
 	*/
 
 	pxmitpriv->pallocated_frame_buf = rtw_zvmalloc(NR_XMITFRAME * sizeof(struct xmit_frame) + 4);
-	
-	if (pxmitpriv->pallocated_frame_buf  == NULL){
-		pxmitpriv->pxmit_frame_buf =NULL;
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("alloc xmit_frame fail!\n"));	
-		res= _FAIL;
+
+	if (pxmitpriv->pallocated_frame_buf  == NULL) {
+		pxmitpriv->pxmit_frame_buf = NULL;
+		res = _FAIL;
 		goto exit;
 	}
 	pxmitpriv->pxmit_frame_buf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->pallocated_frame_buf), 4);
-	//pxmitpriv->pxmit_frame_buf = pxmitpriv->pallocated_frame_buf + 4 -
-	//						((SIZE_PTR) (pxmitpriv->pallocated_frame_buf) &3);
+	/* pxmitpriv->pxmit_frame_buf = pxmitpriv->pallocated_frame_buf + 4 - */
+	/*						((SIZE_PTR) (pxmitpriv->pallocated_frame_buf) &3); */
 
-	pxframe = (struct xmit_frame*) pxmitpriv->pxmit_frame_buf;
+	pxframe = (struct xmit_frame *) pxmitpriv->pxmit_frame_buf;
 
-	for (i = 0; i < NR_XMITFRAME; i++)
-	{
+	for (i = 0; i < NR_XMITFRAME; i++) {
 		_rtw_init_listhead(&(pxframe->list));
 
 		pxframe->padapter = padapter;
 		pxframe->frame_tag = NULL_FRAMETAG;
 
-		pxframe->pkt = NULL;		
+		pxframe->pkt = NULL;
 
 		pxframe->buf_addr = NULL;
 		pxframe->pxmitbuf = NULL;
- 
+
 		rtw_list_insert_tail(&(pxframe->list), &(pxmitpriv->free_xmit_queue.queue));
 
 		pxframe++;
@@ -142,26 +145,24 @@ _func_enter_;
 	pxmitpriv->frag_len = MAX_FRAG_THRESHOLD;
 
 
-	//init xmit_buf
+	/* init xmit_buf */
 	_rtw_init_queue(&pxmitpriv->free_xmitbuf_queue);
 	_rtw_init_queue(&pxmitpriv->pending_xmitbuf_queue);
 
 	pxmitpriv->pallocated_xmitbuf = rtw_zvmalloc(NR_XMITBUFF * sizeof(struct xmit_buf) + 4);
-	
-	if (pxmitpriv->pallocated_xmitbuf  == NULL){
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("alloc xmit_buf fail!\n"));
-		res= _FAIL;
+
+	if (pxmitpriv->pallocated_xmitbuf  == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
 	pxmitpriv->pxmitbuf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->pallocated_xmitbuf), 4);
-	//pxmitpriv->pxmitbuf = pxmitpriv->pallocated_xmitbuf + 4 -
-	//						((SIZE_PTR) (pxmitpriv->pallocated_xmitbuf) &3);
+	/* pxmitpriv->pxmitbuf = pxmitpriv->pallocated_xmitbuf + 4 - */
+	/*						((SIZE_PTR) (pxmitpriv->pallocated_xmitbuf) &3); */
 
-	pxmitbuf = (struct xmit_buf*)pxmitpriv->pxmitbuf;
+	pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmitbuf;
 
-	for (i = 0; i < NR_XMITBUFF; i++)
-	{
+	for (i = 0; i < NR_XMITBUFF; i++) {
 		_rtw_init_listhead(&pxmitbuf->list);
 
 		pxmitbuf->priv_data = NULL;
@@ -169,12 +170,12 @@ _func_enter_;
 		pxmitbuf->buf_tag = XMITBUF_DATA;
 
 		/* Tx buf allocation may fail sometimes, so sleep and retry. */
-		if((res=rtw_os_xmit_resource_alloc(padapter, pxmitbuf,(MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE)) == _FAIL) {
+		res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
+		if (res == _FAIL) {
 			rtw_msleep_os(10);
-			res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf,(MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
-			if (res == _FAIL) {
+			res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
+			if (res == _FAIL)
 				goto exit;
-			}
 		}
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
@@ -187,29 +188,28 @@ _func_enter_;
 		pxmitbuf->flags = XMIT_VO_QUEUE;
 
 		rtw_list_insert_tail(&pxmitbuf->list, &(pxmitpriv->free_xmitbuf_queue.queue));
-		#ifdef DBG_XMIT_BUF
-		pxmitbuf->no=i;
-		#endif
+#ifdef DBG_XMIT_BUF
+		pxmitbuf->no = i;
+#endif
 
 		pxmitbuf++;
-		
+
 	}
 
 	pxmitpriv->free_xmitbuf_cnt = NR_XMITBUFF;
 
-	/* init xframe_ext queue,  the same count as extbuf  */
+	/* init xframe_ext queue,  the same count as extbuf */
 	_rtw_init_queue(&pxmitpriv->free_xframe_ext_queue);
-	
+
 	pxmitpriv->xframe_ext_alloc_addr = rtw_zvmalloc(NR_XMIT_EXTBUFF * sizeof(struct xmit_frame) + 4);
-	
-	if (pxmitpriv->xframe_ext_alloc_addr  == NULL){
+
+	if (pxmitpriv->xframe_ext_alloc_addr  == NULL) {
 		pxmitpriv->xframe_ext = NULL;
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("alloc xframe_ext fail!\n"));	
-		res= _FAIL;
+		res = _FAIL;
 		goto exit;
 	}
 	pxmitpriv->xframe_ext = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->xframe_ext_alloc_addr), 4);
-	pxframe = (struct xmit_frame*)pxmitpriv->xframe_ext;
+	pxframe = (struct xmit_frame *)pxmitpriv->xframe_ext;
 
 	for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
 		_rtw_init_listhead(&(pxframe->list));
@@ -217,47 +217,46 @@ _func_enter_;
 		pxframe->padapter = padapter;
 		pxframe->frame_tag = NULL_FRAMETAG;
 
-		pxframe->pkt = NULL;		
+		pxframe->pkt = NULL;
 
 		pxframe->buf_addr = NULL;
 		pxframe->pxmitbuf = NULL;
-		
+
 		pxframe->ext_tag = 1;
- 
+
 		rtw_list_insert_tail(&(pxframe->list), &(pxmitpriv->free_xframe_ext_queue.queue));
 
 		pxframe++;
 	}
 	pxmitpriv->free_xframe_ext_cnt = NR_XMIT_EXTBUFF;
 
-	// Init xmit extension buff
+	/* Init xmit extension buff */
 	_rtw_init_queue(&pxmitpriv->free_xmit_extbuf_queue);
 
 	pxmitpriv->pallocated_xmit_extbuf = rtw_zvmalloc(NR_XMIT_EXTBUFF * sizeof(struct xmit_buf) + 4);
-	
-	if (pxmitpriv->pallocated_xmit_extbuf  == NULL){
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("alloc xmit_extbuf fail!\n"));
-		res= _FAIL;
+
+	if (pxmitpriv->pallocated_xmit_extbuf  == NULL) {
+		res = _FAIL;
 		goto exit;
 	}
 
 	pxmitpriv->pxmit_extbuf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->pallocated_xmit_extbuf), 4);
 
-	pxmitbuf = (struct xmit_buf*)pxmitpriv->pxmit_extbuf;
+	pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
 
-	for (i = 0; i < NR_XMIT_EXTBUFF; i++)
-	{
+	for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
 		_rtw_init_listhead(&pxmitbuf->list);
 
 		pxmitbuf->priv_data = NULL;
 		pxmitbuf->padapter = padapter;
 		pxmitbuf->buf_tag = XMITBUF_MGNT;
 
-		if((res=rtw_os_xmit_resource_alloc(padapter, pxmitbuf,MAX_XMIT_EXTBUF_SZ + XMITBUF_ALIGN_SZ, _TRUE)) == _FAIL) {
-			res= _FAIL;
+		res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, MAX_XMIT_EXTBUF_SZ + XMITBUF_ALIGN_SZ, _TRUE);
+		if (res == _FAIL) {
+			res = _FAIL;
 			goto exit;
 		}
-		
+
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 		pxmitbuf->phead = pxmitbuf->pbuf;
 		pxmitbuf->pend = pxmitbuf->pbuf + MAX_XMIT_EXTBUF_SZ;
@@ -266,16 +265,16 @@ _func_enter_;
 #endif
 
 		rtw_list_insert_tail(&pxmitbuf->list, &(pxmitpriv->free_xmit_extbuf_queue.queue));
-		#ifdef DBG_XMIT_BUF_EXT
-		pxmitbuf->no=i;
-		#endif
+#ifdef DBG_XMIT_BUF_EXT
+		pxmitbuf->no = i;
+#endif
 		pxmitbuf++;
-		
+
 	}
 
 	pxmitpriv->free_xmit_extbuf_cnt = NR_XMIT_EXTBUFF;
 
-	for (i = 0; i<CMDBUF_MAX; i++) {
+	for (i = 0; i < CMDBUF_MAX; i++) {
 		pxmitbuf = &pxmitpriv->pcmd_xmitbuf[i];
 		if (pxmitbuf) {
 			_rtw_init_listhead(&pxmitbuf->list);
@@ -284,8 +283,9 @@ _func_enter_;
 			pxmitbuf->padapter = padapter;
 			pxmitbuf->buf_tag = XMITBUF_CMD;
 
-			if((res=rtw_os_xmit_resource_alloc(padapter, pxmitbuf, MAX_CMDBUF_SZ+XMITBUF_ALIGN_SZ, _TRUE)) == _FAIL) {
-				res= _FAIL;
+			res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, MAX_CMDBUF_SZ + XMITBUF_ALIGN_SZ, _TRUE);
+			if (res == _FAIL) {
+				res = _FAIL;
 				goto exit;
 			}
 
@@ -295,24 +295,22 @@ _func_enter_;
 			pxmitbuf->len = 0;
 			pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
 #endif
-			pxmitbuf->alloc_sz = MAX_CMDBUF_SZ+XMITBUF_ALIGN_SZ;
+			pxmitbuf->alloc_sz = MAX_CMDBUF_SZ + XMITBUF_ALIGN_SZ;
 		}
 	}
 
 	rtw_alloc_hwxmits(padapter);
 	rtw_init_hwxmits(pxmitpriv->hwxmits, pxmitpriv->hwxmit_entry);
 
-        for (i = 0; i < 4; i ++)
-	{
+	for (i = 0; i < 4; i++)
 		pxmitpriv->wmm_para_seq[i] = i;
-	}
 
 #ifdef CONFIG_USB_HCI
-	pxmitpriv->txirp_cnt=1;
+	pxmitpriv->txirp_cnt = 1;
 
 	_rtw_init_sema(&(pxmitpriv->tx_retevt), 0);
 
-	//per AC pending irp
+	/* per AC pending irp */
 	pxmitpriv->beq_cnt = 0;
 	pxmitpriv->bkq_cnt = 0;
 	pxmitpriv->viq_cnt = 0;
@@ -323,24 +321,48 @@ _func_enter_;
 #ifdef CONFIG_XMIT_ACK
 	pxmitpriv->ack_tx = _FALSE;
 	_rtw_mutex_init(&pxmitpriv->ack_tx_mutex);
-	rtw_sctx_init(&pxmitpriv->ack_tx_ops, 0);	
+	rtw_sctx_init(&pxmitpriv->ack_tx_ops, 0);
 #endif
 
+#ifdef CONFIG_TX_AMSDU
+	rtw_init_timer(&(pxmitpriv->amsdu_vo_timer), padapter,
+		rtw_amsdu_vo_timeout_handler, padapter);
+	pxmitpriv->amsdu_vo_timeout = RTW_AMSDU_TIMER_UNSET;
+
+	rtw_init_timer(&(pxmitpriv->amsdu_vi_timer), padapter,
+		rtw_amsdu_vi_timeout_handler, padapter);
+	pxmitpriv->amsdu_vi_timeout = RTW_AMSDU_TIMER_UNSET;
+
+	rtw_init_timer(&(pxmitpriv->amsdu_be_timer), padapter,
+		rtw_amsdu_be_timeout_handler, padapter);
+	pxmitpriv->amsdu_be_timeout = RTW_AMSDU_TIMER_UNSET;
+
+	rtw_init_timer(&(pxmitpriv->amsdu_bk_timer), padapter,
+		rtw_amsdu_bk_timeout_handler, padapter);
+	pxmitpriv->amsdu_bk_timeout = RTW_AMSDU_TIMER_UNSET;
+
+	pxmitpriv->amsdu_debug_set_timer = 0;
+	pxmitpriv->amsdu_debug_timeout = 0;
+	pxmitpriv->amsdu_debug_coalesce_one = 0;
+	pxmitpriv->amsdu_debug_coalesce_two = 0;
+#endif
+#ifdef DBG_TXBD_DESC_DUMP
+	pxmitpriv->dump_txbd_desc = 0;
+#endif
+	rtw_init_xmit_block(padapter);
 	rtw_hal_init_xmit_priv(padapter);
 
 exit:
 
-_func_exit_;	
 
 	return res;
 }
 
-void  rtw_mfree_xmit_priv_lock (struct xmit_priv *pxmitpriv);
-void  rtw_mfree_xmit_priv_lock (struct xmit_priv *pxmitpriv)
+void  rtw_mfree_xmit_priv_lock(struct xmit_priv *pxmitpriv);
+void  rtw_mfree_xmit_priv_lock(struct xmit_priv *pxmitpriv)
 {
 	_rtw_spinlock_free(&pxmitpriv->lock);
 	_rtw_free_sema(&pxmitpriv->xmit_sema);
-	_rtw_free_sema(&pxmitpriv->terminate_xmitthread_sema);
 
 	_rtw_spinlock_free(&pxmitpriv->be_pending.lock);
 	_rtw_spinlock_free(&pxmitpriv->bk_pending.lock);
@@ -348,8 +370,8 @@ void  rtw_mfree_xmit_priv_lock (struct xmit_priv *pxmitpriv)
 	_rtw_spinlock_free(&pxmitpriv->vo_pending.lock);
 	_rtw_spinlock_free(&pxmitpriv->bm_pending.lock);
 
-	//_rtw_spinlock_free(&pxmitpriv->legacy_dz_queue.lock);
-	//_rtw_spinlock_free(&pxmitpriv->apsd_queue.lock);
+	/* _rtw_spinlock_free(&pxmitpriv->legacy_dz_queue.lock); */
+	/* _rtw_spinlock_free(&pxmitpriv->apsd_queue.lock); */
 
 	_rtw_spinlock_free(&pxmitpriv->free_xmit_queue.lock);
 	_rtw_spinlock_free(&pxmitpriv->free_xmitbuf_queue.lock);
@@ -357,48 +379,43 @@ void  rtw_mfree_xmit_priv_lock (struct xmit_priv *pxmitpriv)
 }
 
 
-void _rtw_free_xmit_priv (struct xmit_priv *pxmitpriv)
+void _rtw_free_xmit_priv(struct xmit_priv *pxmitpriv)
 {
-       int i;
-      _adapter *padapter = pxmitpriv->adapter;
-	struct xmit_frame	*pxmitframe = (struct xmit_frame*) pxmitpriv->pxmit_frame_buf;
+	int i;
+	_adapter *padapter = pxmitpriv->adapter;
+	struct xmit_frame	*pxmitframe = (struct xmit_frame *) pxmitpriv->pxmit_frame_buf;
 	struct xmit_buf *pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmitbuf;
-	
- _func_enter_;   
+
 
 	rtw_hal_free_xmit_priv(padapter);
- 
+
 	rtw_mfree_xmit_priv_lock(pxmitpriv);
- 
- 	if(pxmitpriv->pxmit_frame_buf==NULL)
+
+	if (pxmitpriv->pxmit_frame_buf == NULL)
 		goto out;
-	
-	for(i=0; i<NR_XMITFRAME; i++)
-	{	
+
+	for (i = 0; i < NR_XMITFRAME; i++) {
 		rtw_os_xmit_complete(padapter, pxmitframe);
 
 		pxmitframe++;
-	}		
-	
-	for(i=0; i<NR_XMITBUFF; i++)
-	{
-		rtw_os_xmit_resource_free(padapter, pxmitbuf,(MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
-		
+	}
+
+	for (i = 0; i < NR_XMITBUFF; i++) {
+		rtw_os_xmit_resource_free(padapter, pxmitbuf, (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
+
 		pxmitbuf++;
 	}
 
-	if(pxmitpriv->pallocated_frame_buf) {
+	if (pxmitpriv->pallocated_frame_buf)
 		rtw_vmfree(pxmitpriv->pallocated_frame_buf, NR_XMITFRAME * sizeof(struct xmit_frame) + 4);
-	}
-	
 
-	if(pxmitpriv->pallocated_xmitbuf) {
+
+	if (pxmitpriv->pallocated_xmitbuf)
 		rtw_vmfree(pxmitpriv->pallocated_xmitbuf, NR_XMITBUFF * sizeof(struct xmit_buf) + 4);
-	}
 
-	/* free xframe_ext queue,  the same count as extbuf  */
-	if ((pxmitframe = (struct xmit_frame*)pxmitpriv->xframe_ext)) {
-		for (i=0; i<NR_XMIT_EXTBUFF; i++) {
+	/* free xframe_ext queue,  the same count as extbuf */
+	if ((pxmitframe = (struct xmit_frame *)pxmitpriv->xframe_ext)) {
+		for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
 			rtw_os_xmit_complete(padapter, pxmitframe);
 			pxmitframe++;
 		}
@@ -407,44 +424,40 @@ void _rtw_free_xmit_priv (struct xmit_priv *pxmitpriv)
 		rtw_vmfree(pxmitpriv->xframe_ext_alloc_addr, NR_XMIT_EXTBUFF * sizeof(struct xmit_frame) + 4);
 	_rtw_spinlock_free(&pxmitpriv->free_xframe_ext_queue.lock);
 
-	// free xmit extension buff
+	/* free xmit extension buff */
 	_rtw_spinlock_free(&pxmitpriv->free_xmit_extbuf_queue.lock);
 
 	pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
-	for(i=0; i<NR_XMIT_EXTBUFF; i++)
-	{
-		rtw_os_xmit_resource_free(padapter, pxmitbuf,(MAX_XMIT_EXTBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
-		
+	for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
+		rtw_os_xmit_resource_free(padapter, pxmitbuf, (MAX_XMIT_EXTBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
+
 		pxmitbuf++;
 	}
 
-	if(pxmitpriv->pallocated_xmit_extbuf) {
+	if (pxmitpriv->pallocated_xmit_extbuf)
 		rtw_vmfree(pxmitpriv->pallocated_xmit_extbuf, NR_XMIT_EXTBUFF * sizeof(struct xmit_buf) + 4);
-	}
 
-	for (i=0; i<CMDBUF_MAX; i++) {
+	for (i = 0; i < CMDBUF_MAX; i++) {
 		pxmitbuf = &pxmitpriv->pcmd_xmitbuf[i];
-		if(pxmitbuf!=NULL)
-			rtw_os_xmit_resource_free(padapter, pxmitbuf, MAX_CMDBUF_SZ+XMITBUF_ALIGN_SZ , _TRUE);
+		if (pxmitbuf != NULL)
+			rtw_os_xmit_resource_free(padapter, pxmitbuf, MAX_CMDBUF_SZ + XMITBUF_ALIGN_SZ , _TRUE);
 	}
 
 	rtw_free_hwxmits(padapter);
 
-#ifdef CONFIG_XMIT_ACK	
-	_rtw_mutex_free(&pxmitpriv->ack_tx_mutex);	
-#endif	
-
-out:	
-
-_func_exit_;		
-
+#ifdef CONFIG_XMIT_ACK
+	_rtw_mutex_free(&pxmitpriv->ack_tx_mutex);
+#endif
+	rtw_free_xmit_block(padapter);
+out:
+	return;
 }
 
 u8 rtw_get_tx_bw_mode(_adapter *adapter, struct sta_info *sta)
 {
 	u8 bw;
 
-	bw = sta->bw_mode;
+	bw = sta->cmn.bw_mode;
 	if (MLME_STATE(adapter) & WIFI_ASOC_STATE) {
 		if (adapter->mlmeextpriv.cur_channel <= 14)
 			bw = rtw_min(bw, ADAPTER_TX_BW_2G(adapter));
@@ -466,17 +479,15 @@ void rtw_get_adapter_tx_rate_bmp_by_bw(_adapter *adapter, u8 bw, u16 *r_bmp_cck_
 	u32 bmp_vht = 0;
 	int i;
 
-	#if 0
 	if (adapter->fix_rate != 0xFF && adapter->fix_bw != 0xFF)
 		fix_bw = adapter->fix_bw;
-	#endif
 
 	/* TODO: adapter->fix_rate */
 
 	for (i = 0; i < macid_ctl->num; i++) {
 		if (!rtw_macid_is_used(macid_ctl, i))
 			continue;
-		if (rtw_macid_get_if_g(macid_ctl, i) != adapter->iface_id)
+		if (!rtw_macid_is_iface_specific(macid_ctl, i, adapter))
 			continue;
 
 		if (bw == CHANNEL_WIDTH_20) /* CCK, OFDM always 20MHz */
@@ -514,7 +525,7 @@ void rtw_get_shared_macid_tx_rate_bmp_by_bw(struct dvobj_priv *dvobj, u8 bw, u16
 	for (i = 0; i < macid_ctl->num; i++) {
 		if (!rtw_macid_is_used(macid_ctl, i))
 			continue;
-		if (rtw_macid_get_if_g(macid_ctl, i) != -1)
+		if (!rtw_macid_is_iface_shared(macid_ctl, i))
 			continue;
 
 		if (bw == CHANNEL_WIDTH_20) /* CCK, OFDM always 20MHz */
@@ -639,7 +650,7 @@ void rtw_update_tx_rate_bmp(struct dvobj_priv *dvobj)
 
 		/* TODO: per rfpath and rate section handling? */
 		if (update_ht_rs == _TRUE || update_vht_rs == _TRUE)
-			rtw_hal_set_tx_power_level(dvobj_get_primary_adapter(dvobj), hal_data->CurrentChannel);
+			rtw_hal_set_tx_power_level(dvobj_get_primary_adapter(dvobj), hal_data->current_channel);
 	}
 }
 
@@ -751,127 +762,107 @@ static void update_attrib_vcs_info(_adapter *padapter, struct xmit_frame *pxmitf
 {
 	u32	sz;
 	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
-	//struct sta_info	*psta = pattrib->psta;
+	/* 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_871X("%s, call rtw_get_stainfo()\n", __func__);
-		psta=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
-	}
+	/*
+		if(pattrib->psta)
+		{
+			psta = pattrib->psta;
+		}
+		else
+		{
+			RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+			psta=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
+		}
 
-        if(psta==NULL)
-	{
-		DBG_871X("%s, psta==NUL\n", __func__);
-		return;
-	}
+		if(psta==NULL)
+		{
+			RTW_INFO("%s, psta==NUL\n", __func__);
+			return;
+		}
 
-	if(!(psta->state &_FW_LINKED))
-	{
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
-		return;
-	}
-*/
+		if(!(psta->state &_FW_LINKED))
+		{
+			RTW_INFO("%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
-	{
+	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)
-		{
+	/* (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(pattrib->rtsen)
+		else {
+			if (pattrib->rtsen)
 				pattrib->vcs_mode = RTS_CTS;
-			else if(pattrib->cts2self)
+			else if (pattrib->cts2self)
 				pattrib->vcs_mode = CTS_TO_SELF;
 			else
 				pattrib->vcs_mode = NONE_VCS;
 		}
-	}
-	else
-	{
-		while (_TRUE)
-		{
-#if 0 //Todo
-			//check IOT action
-			if(pHTInfo->IOTAction & HT_IOT_ACT_FORCED_CTS2SELF)
-			{
+	} else {
+		while (_TRUE) {
+#if 0 /* Todo */
+			/* check IOT action */
+			if (pHTInfo->IOTAction & HT_IOT_ACT_FORCED_CTS2SELF) {
 				pattrib->vcs_mode = CTS_TO_SELF;
 				pattrib->rts_rate = MGN_24M;
 				break;
-			}
-			else if(pHTInfo->IOTAction & (HT_IOT_ACT_FORCED_RTS|HT_IOT_ACT_PURE_N_MODE))
-			{
+			} else if (pHTInfo->IOTAction & (HT_IOT_ACT_FORCED_RTS | HT_IOT_ACT_PURE_N_MODE)) {
 				pattrib->vcs_mode = RTS_CTS;
 				pattrib->rts_rate = MGN_24M;
 				break;
 			}
 #endif
 
-			//IOT action
-			if((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_ATHEROS) && (pattrib->ampdu_en==_TRUE) &&
-				(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_ ))
-			{
+			/* IOT action */
+			if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_ATHEROS) && (pattrib->ampdu_en == _TRUE) &&
+			    (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
 				pattrib->vcs_mode = CTS_TO_SELF;
 				break;
-			}	
-			
+			}
 
-			//check ERP protection
-			if(pattrib->rtsen || pattrib->cts2self)
-			{
-				if(pattrib->rtsen)
+
+			/* check ERP protection */
+			if (pattrib->rtsen || pattrib->cts2self) {
+				if (pattrib->rtsen)
 					pattrib->vcs_mode = RTS_CTS;
-				else if(pattrib->cts2self)
+				else if (pattrib->cts2self)
 					pattrib->vcs_mode = CTS_TO_SELF;
 
 				break;
 			}
 
-			//check HT op mode
-			if(pattrib->ht_en)
-			{
+			/* 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) )
-				{
+				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)
-			{
+			/* check rts */
+			if (sz > padapter->registrypriv.rts_thresh) {
 				pattrib->vcs_mode = RTS_CTS;
 				break;
 			}
 
-			//to do list: check MIMO power save condition.
+			/* to do list: check MIMO power save condition. */
 
-			//check AMPDU aggregation for TXOP
-			if((pattrib->ampdu_en==_TRUE) && (!IS_HARDWARE_TYPE_8812(padapter)))
-			{
+			/* check AMPDU aggregation for TXOP */
+			if ((pattrib->ampdu_en == _TRUE) && (!IS_HARDWARE_TYPE_8812(padapter))) {
 				pattrib->vcs_mode = RTS_CTS;
 				break;
 			}
@@ -881,15 +872,46 @@ static void update_attrib_vcs_info(_adapter *padapter, struct xmit_frame *pxmitf
 		}
 	}
 
-	//for debug : force driver control vrtl_carrier_sense.
-	if(padapter->driver_vcs_en==1)
-	{
-		//u8 driver_vcs_en; //Enable=1, Disable=0 driver control vrtl_carrier_sense.
-		//u8 driver_vcs_type;//force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1.
+	/* for debug : force driver control vrtl_carrier_sense. */
+	if (padapter->driver_vcs_en == 1) {
+		/* u8 driver_vcs_en; */ /* Enable=1, Disable=0 driver control vrtl_carrier_sense. */
+		/* u8 driver_vcs_type; */ /* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. */
 		pattrib->vcs_mode = padapter->driver_vcs_type;
-	}	
-	
+	}
+
+}
+
+#ifdef CONFIG_WMMPS_STA
+/*
+ * update_attrib_trigger_frame_info
+ * For Station mode, if a specific TID of driver setting and an AP support uapsd function, the data 
+ * frame with corresponding TID will be a trigger frame when driver is in wmm power saving mode.
+ * 
+ * Arguments:
+ * @padapter: _adapter pointer.
+ * @pattrib: pkt_attrib pointer.
+ *
+ * Auther: Arvin Liu
+ * Date: 2017/06/05
+ */
+static void update_attrib_trigger_frame_info(_adapter *padapter, struct pkt_attrib *pattrib) {
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct pwrctrl_priv 	*pwrpriv = adapter_to_pwrctl(padapter); 
+	struct qos_priv 	*pqospriv = &pmlmepriv->qospriv;
+	u8 trigger_frame_en = 0;
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+		if ((pwrpriv->pwr_mode == PS_MODE_MIN) || (pwrpriv->pwr_mode == PS_MODE_MAX)) {
+			if((pqospriv->uapsd_ap_supported) && ((pqospriv->uapsd_tid & BIT(pattrib->priority)) == _TRUE)) {
+				trigger_frame_en = 1;
+				RTW_INFO("[WMMPS]"FUNC_ADPT_FMT": This is a Trigger Frame\n", FUNC_ADPT_ARG(padapter));
+			}
+		}
+	}
+
+	pattrib->trigger_frame = trigger_frame_en;
 }
+#endif /* CONFIG_WMMPS_STA */
 
 static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)
 {
@@ -898,45 +920,56 @@ static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattri
 
 	pattrib->rtsen = psta->rtsen;
 	pattrib->cts2self = psta->cts2self;
-	
+
 	pattrib->mdata = 0;
 	pattrib->eosp = 0;
-	pattrib->triggered=0;
+	pattrib->triggered = 0;
 	pattrib->ampdu_spacing = 0;
-	
-	//qos_en, ht_en, init rate, ,bw, ch_offset, sgi
+
+	/* qos_en, ht_en, init rate, ,bw, ch_offset, sgi */
 	pattrib->qos_en = psta->qos_option;
-	
-	pattrib->raid = psta->raid;
+
+	pattrib->raid = psta->cmn.ra_info.rate_id;
 
 	bw = rtw_get_tx_bw_mode(padapter, psta);
 	pattrib->bwmode = rtw_min(bw, mlmeext->cur_bwmode);
 	pattrib->sgi = query_ra_short_GI(psta, pattrib->bwmode);
 
-	pattrib->ldpc = psta->ldpc;
-	pattrib->stbc = psta->stbc;
+	pattrib->ldpc = psta->cmn.ldpc_en;
+	pattrib->stbc = psta->cmn.stbc_en;
 
 #ifdef CONFIG_80211N_HT
 	pattrib->ht_en = psta->htpriv.ht_option;
 	pattrib->ch_offset = psta->htpriv.ch_offset;
 	pattrib->ampdu_en = _FALSE;
 
-	if(padapter->driver_ampdu_spacing != 0xFF) //driver control AMPDU Density for peer sta's rx
+	if (padapter->driver_ampdu_spacing != 0xFF) /* driver control AMPDU Density for peer sta's rx */
 		pattrib->ampdu_spacing = padapter->driver_ampdu_spacing;
 	else
 		pattrib->ampdu_spacing = psta->htpriv.rx_ampdu_min_spacing;
-#endif //CONFIG_80211N_HT
-	//if(pattrib->ht_en && psta->htpriv.ampdu_enable)
-	//{
-	//	if(psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority))
-	//		pattrib->ampdu_en = _TRUE;
-	//}	
+
+	/* check if enable ampdu */
+	if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
+		if (psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority)) {
+			pattrib->ampdu_en = _TRUE;
+			if (psta->htpriv.tx_amsdu_enable == _TRUE)
+				pattrib->amsdu_ampdu_en = _TRUE;
+			else
+				pattrib->amsdu_ampdu_en = _FALSE;
+		}
+	}
+#endif /* CONFIG_80211N_HT */
+	/* if(pattrib->ht_en && psta->htpriv.ampdu_enable) */
+	/* { */
+	/*	if(psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority)) */
+	/*		pattrib->ampdu_en = _TRUE; */
+	/* }	 */
 
 #ifdef CONFIG_TDLS
-	if (pattrib->direct_link==_TRUE) {
+	if (pattrib->direct_link == _TRUE) {
 		psta = pattrib->ptdls_sta;
 
-		pattrib->raid = psta->raid;
+		pattrib->raid = psta->cmn.ra_info.rate_id;
 #ifdef CONFIG_80211N_HT
 		pattrib->bwmode = rtw_get_tx_bw_mode(padapter, psta);
 		pattrib->ht_en = psta->htpriv.ht_option;
@@ -949,7 +982,7 @@ static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattri
 	pattrib->retry_ctrl = _FALSE;
 
 #ifdef CONFIG_AUTO_AP_MODE
-	if(psta->isrc && psta->pid>0)
+	if (psta->isrc && psta->pid > 0)
 		pattrib->pctrl = _TRUE;
 #endif
 
@@ -962,57 +995,50 @@ static s32 update_attrib_sec_info(_adapter *padapter, struct pkt_attrib *pattrib
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	sint bmcast = IS_MCAST(pattrib->ra);
 
-	_rtw_memset(pattrib->dot118021x_UncstKey.skey,  0, 16);		
+	_rtw_memset(pattrib->dot118021x_UncstKey.skey,  0, 16);
 	_rtw_memset(pattrib->dot11tkiptxmickey.skey,  0, 16);
-	pattrib->mac_id = psta->mac_id;
+	pattrib->mac_id = psta->cmn.mac_id;
 
-	if (psta->ieee8021x_blocked == _TRUE)
-	{
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("\n psta->ieee8021x_blocked == _TRUE \n"));
+	if (psta->ieee8021x_blocked == _TRUE) {
 
 		pattrib->encrypt = 0;
 
-		if((pattrib->ether_type != 0x888e) && (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _FALSE))
-		{
-			RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("\npsta->ieee8021x_blocked == _TRUE,  pattrib->ether_type(%.4x) != 0x888e\n",pattrib->ether_type));
-			#ifdef DBG_TX_DROP_FRAME
-			DBG_871X("DBG_TX_DROP_FRAME %s psta->ieee8021x_blocked == _TRUE,  pattrib->ether_type(%04x) != 0x888e\n", __FUNCTION__,pattrib->ether_type);
-			#endif
+		if ((pattrib->ether_type != 0x888e) && (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _FALSE)) {
+#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME %s psta->ieee8021x_blocked == _TRUE,  pattrib->ether_type(%04x) != 0x888e\n", __FUNCTION__, pattrib->ether_type);
+#endif
 			res = _FAIL;
 			goto exit;
 		}
-	}
-	else
-	{
+	} else {
 		GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, bmcast);
-		
+
 #ifdef CONFIG_WAPI_SUPPORT
-		if(pattrib->ether_type == 0x88B4)
-			pattrib->encrypt=_NO_PRIVACY_;
+		if (pattrib->ether_type == 0x88B4)
+			pattrib->encrypt = _NO_PRIVACY_;
 #endif
 
-		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:
+		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;
+			break;
+		default:
+			pattrib->key_idx = 0;
+			break;
 		}
 
-		//For WPS 1.0 WEP, driver should not encrypt EAPOL Packet for WPS handshake.
-		if (((pattrib->encrypt ==_WEP40_)||(pattrib->encrypt ==_WEP104_)) && (pattrib->ether_type == 0x888e))
-			pattrib->encrypt=_NO_PRIVACY_;
-		
+		/* For WPS 1.0 WEP, driver should not encrypt EAPOL Packet for WPS handshake. */
+		if (((pattrib->encrypt == _WEP40_) || (pattrib->encrypt == _WEP104_)) && (pattrib->ether_type == 0x888e))
+			pattrib->encrypt = _NO_PRIVACY_;
+
 	}
 
 #ifdef CONFIG_TDLS
@@ -1020,133 +1046,118 @@ static s32 update_attrib_sec_info(_adapter *padapter, struct pkt_attrib *pattrib
 		if (pattrib->encrypt > 0)
 			pattrib->encrypt = _AES_;
 	}
-#endif 
-	
-	switch (pattrib->encrypt)
-	{
-		case _WEP40_:
-		case _WEP104_:
-			pattrib->iv_len = 4;
-			pattrib->icv_len = 4;
-			WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
-			break;
+#endif
 
-		case _TKIP_:
-			pattrib->iv_len = 8;
-			pattrib->icv_len = 4;
-
-			if(psecuritypriv->busetkipkey==_FAIL)
-			{				
-				#ifdef DBG_TX_DROP_FRAME
-				DBG_871X("DBG_TX_DROP_FRAME %s psecuritypriv->busetkipkey(%d)==_FAIL drop packet\n", __FUNCTION__, psecuritypriv->busetkipkey);
-				#endif
-				res =_FAIL;
-				goto exit;
-			}
+	switch (pattrib->encrypt) {
+	case _WEP40_:
+	case _WEP104_:
+		pattrib->iv_len = 4;
+		pattrib->icv_len = 4;
+		WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+		break;
 
-			if(bmcast)
-				TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
-			else
-				TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
+	case _TKIP_:
+		pattrib->iv_len = 8;
+		pattrib->icv_len = 4;
+
+		if (psecuritypriv->busetkipkey == _FAIL) {
+#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME %s psecuritypriv->busetkipkey(%d)==_FAIL drop packet\n", __FUNCTION__, psecuritypriv->busetkipkey);
+#endif
+			res = _FAIL;
+			goto exit;
+		}
 
+		if (bmcast)
+			TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+		else
+			TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
 
-			_rtw_memcpy(pattrib->dot11tkiptxmickey.skey, psta->dot11tkiptxmickey.skey, 16);
-			
-			break;
-			
-		case _AES_:
-			
-			pattrib->iv_len = 8;
-			pattrib->icv_len = 8;
-			
-			if(bmcast)
-				AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
-			else
-				AES_IV(pattrib->iv, psta->dot11txpn, 0);
-			
-			break;
+
+		_rtw_memcpy(pattrib->dot11tkiptxmickey.skey, psta->dot11tkiptxmickey.skey, 16);
+
+		break;
+
+	case _AES_:
+
+		pattrib->iv_len = 8;
+		pattrib->icv_len = 8;
+
+		if (bmcast)
+			AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+		else
+			AES_IV(pattrib->iv, psta->dot11txpn, 0);
+
+		break;
 
 #ifdef CONFIG_WAPI_SUPPORT
-		case _SMS4_:
-			pattrib->iv_len = 18;
-			pattrib->icv_len = 16;
-			rtw_wapi_get_iv(padapter,pattrib->ra,pattrib->iv);			
-			break;
+	case _SMS4_:
+		pattrib->iv_len = 18;
+		pattrib->icv_len = 16;
+		rtw_wapi_get_iv(padapter, pattrib->ra, pattrib->iv);
+		break;
 #endif
-		default:
-			pattrib->iv_len = 0;
-			pattrib->icv_len = 0;
-			break;
+	default:
+		pattrib->iv_len = 0;
+		pattrib->icv_len = 0;
+		break;
 	}
 
-	if(pattrib->encrypt>0)
-		_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);		
+	if (pattrib->encrypt > 0)
+		_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);
 
-	RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-		("update_attrib: encrypt=%d  securitypriv.sw_encrypt=%d\n",
-		pattrib->encrypt, padapter->securitypriv.sw_encrypt));
 
 	if (pattrib->encrypt &&
-		((padapter->securitypriv.sw_encrypt == _TRUE) || (psecuritypriv->hw_decrypted == _FALSE)))
-	{
+	    ((padapter->securitypriv.sw_encrypt == _TRUE) || (psecuritypriv->hw_decrypted == _FALSE))) {
 		pattrib->bswenc = _TRUE;
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,
-			("update_attrib: encrypt=%d securitypriv.hw_decrypted=%d bswenc=_TRUE\n",
-			pattrib->encrypt, padapter->securitypriv.sw_encrypt));
 	} else {
 		pattrib->bswenc = _FALSE;
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("update_attrib: bswenc=_FALSE\n"));
 	}
 
-#if defined(CONFIG_CONCURRENT_MODE) && !defined(DYNAMIC_CAMID_ALLOC)
-	if((pattrib->encrypt && bmcast) || (pattrib->encrypt ==_WEP40_) || (pattrib->encrypt ==_WEP104_))
-	{
-		pattrib->bswenc = _TRUE;//force using sw enc.
-	}
+#if defined(CONFIG_CONCURRENT_MODE)
+	pattrib->bmc_camid = padapter->securitypriv.dot118021x_bmc_cam_id;
 #endif
-#ifdef DYNAMIC_CAMID_ALLOC
+
 	if (pattrib->encrypt && bmcast && _rtw_camctl_chk_flags(padapter, SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH))
 		pattrib->bswenc = _TRUE;
-#endif
 
 #ifdef CONFIG_WAPI_SUPPORT
-	if(pattrib->encrypt == _SMS4_)
+	if (pattrib->encrypt == _SMS4_)
 		pattrib->bswenc = _FALSE;
 #endif
 
 exit:
 
 	return res;
-	
+
 }
 
 u8	qos_acm(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_871X("qos_acm(): invalid pattrib->priority: %d!!!\n", priority);
-			break;
+	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:
+		RTW_INFO("qos_acm(): invalid pattrib->priority: %d!!!\n", priority);
+		break;
 	}
 
 	return change_priority;
@@ -1160,21 +1171,21 @@ static void set_qos(struct pkt_file *ppktfile, struct pkt_attrib *pattrib)
 
 
 	_rtw_open_pktfile(ppktfile->pkt, ppktfile);
-	_rtw_pktfile_read(ppktfile, (unsigned char*)&etherhdr, ETH_HLEN);
+	_rtw_pktfile_read(ppktfile, (unsigned char *)&etherhdr, ETH_HLEN);
 
-	// get UserPriority from IP hdr
+	/* get UserPriority from IP hdr */
 	if (pattrib->ether_type == 0x0800) {
-		_rtw_pktfile_read(ppktfile, (u8*)&ip_hdr, sizeof(ip_hdr));
-//		UserPriority = (ntohs(ip_hdr.tos) >> 5) & 0x3;
+		_rtw_pktfile_read(ppktfile, (u8 *)&ip_hdr, sizeof(ip_hdr));
+		/*		UserPriority = (ntohs(ip_hdr.tos) >> 5) & 0x3; */
 		UserPriority = ip_hdr.tos >> 5;
 	}
-/* 
-	else if (pattrib->ether_type == 0x888e) {
-		// "When priority processing of data frames is supported,
-		// a STA's SME should send EAPOL-Key frames at the highest priority."
-		UserPriority = 7;
-	}
-*/
+	/*
+		else if (pattrib->ether_type == 0x888e) {
+
+
+			UserPriority = 7;
+		}
+	*/
 	pattrib->priority = UserPriority;
 	pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
 	pattrib->subtype = WIFI_QOS_DATA_TYPE;
@@ -1189,25 +1200,24 @@ u8 rtw_check_tdls_established(_adapter *padapter, struct pkt_attrib *pattrib)
 	if (padapter->tdlsinfo.link_established == _TRUE) {
 		pattrib->ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pattrib->dst);
 #if 1
-		if((pattrib->ptdls_sta!=NULL)&&
-			(pattrib->ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)&&
-			(pattrib->ether_type!=0x0806)){
-				pattrib->direct_link = _TRUE;
-				//DBG_871X("send ptk to "MAC_FMT" using direct link\n", MAC_ARG(pattrib->dst));
+		if ((pattrib->ptdls_sta != NULL) &&
+		    (pattrib->ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) &&
+		    (pattrib->ether_type != 0x0806)) {
+			pattrib->direct_link = _TRUE;
+			/* RTW_INFO("send ptk to "MAC_FMT" using direct link\n", MAC_ARG(pattrib->dst)); */
 		}
 #else
 		if (pattrib->ptdls_sta != NULL &&
-			pattrib->ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
-				pattrib->direct_link = _TRUE;
-				#if 0
-				DBG_871X("send ptk to "MAC_FMT" using direct link\n", MAC_ARG(pattrib->dst));
-				#endif
+		    pattrib->ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
+			pattrib->direct_link = _TRUE;
+#if 0
+			RTW_INFO("send ptk to "MAC_FMT" using direct link\n", MAC_ARG(pattrib->dst));
+#endif
 		}
 
 		/* ARP frame may be helped by AP*/
-		if (pattrib->ether_type != 0x0806) {
-				pattrib->direct_link = _FALSE;
-		}	
+		if (pattrib->ether_type != 0x0806)
+			pattrib->direct_link = _FALSE;
 #endif
 	}
 
@@ -1221,36 +1231,35 @@ s32 update_tdls_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
 	struct sta_priv		*pstapriv = &padapter->stapriv;
 	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct qos_priv		*pqospriv= &pmlmepriv->qospriv;
+	struct qos_priv		*pqospriv = &pmlmepriv->qospriv;
+
+	s32 res = _SUCCESS;
 
-	s32 res=_SUCCESS;
-	
 	psta = rtw_get_stainfo(pstapriv, pattrib->ra);
-	if (psta == NULL)	{ 
-		res =_FAIL;
+	if (psta == NULL)	{
+		res = _FAIL;
 		goto exit;
 	}
 
-	pattrib->mac_id = psta->mac_id;
+	pattrib->mac_id = psta->cmn.mac_id;
 	pattrib->psta = psta;
 	pattrib->ack_policy = 0;
-	// get ether_hdr_len
+	/* get ether_hdr_len */
 	pattrib->pkt_hdrlen = ETH_HLEN;
 
-	// [TDLS] TODO: setup req/rsp should be AC_BK
+	/* [TDLS] TODO: setup req/rsp should be AC_BK */
 	if (pqospriv->qos_option &&  psta->qos_option) {
-		pattrib->priority = 4;	//tdls management frame should be AC_VI
+		pattrib->priority = 4;	/* tdls management frame should be AC_VI */
 		pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
 		pattrib->subtype = WIFI_QOS_DATA_TYPE;
 	} else {
 		pattrib->priority = 0;
 		pattrib->hdrlen = WLAN_HDR_A3_LEN;
-		pattrib->subtype = WIFI_DATA_TYPE;	
+		pattrib->subtype = WIFI_DATA_TYPE;
 	}
 
-	//TODO:_lock
-	if(update_attrib_sec_info(padapter, pattrib, psta) == _FAIL)
-	{
+	/* TODO:_lock */
+	if (update_attrib_sec_info(padapter, pattrib, psta) == _FAIL) {
 		res = _FAIL;
 		goto exit;
 	}
@@ -1263,20 +1272,21 @@ exit:
 	return res;
 }
 
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-//get non-qos hw_ssn control register,mapping to REG_HW_SEQ0,1,2,3
+/*get non-qos hw_ssn control register,mapping to REG_HW_SEQ0,1,2,3*/
 inline u8 rtw_get_hwseq_no(_adapter *padapter)
 {
 	u8 hwseq_num = 0;
 #ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->adapter_type == SECONDARY_ADAPTER)
+	if (!is_primary_adapter(padapter))
 		hwseq_num = 1;
-	//else
-	//	hwseq_num = 2;
-#endif //CONFIG_CONCURRENT_MODE
+	/* else */
+	/*	hwseq_num = 2; */
+#endif /* CONFIG_CONCURRENT_MODE */
 	return hwseq_num;
 }
+
 static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattrib)
 {
 	uint i;
@@ -1288,56 +1298,53 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 	struct sta_priv		*pstapriv = &padapter->stapriv;
 	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-	struct qos_priv		*pqospriv= &pmlmepriv->qospriv;
-	struct xmit_priv 		*pxmitpriv = &padapter->xmitpriv;
+	struct qos_priv		*pqospriv = &pmlmepriv->qospriv;
+	struct xmit_priv		*pxmitpriv = &padapter->xmitpriv;
 	sint res = _SUCCESS;
 
- _func_enter_;
 
 	DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib);
 
 	_rtw_open_pktfile(pkt, &pktfile);
-	i = _rtw_pktfile_read(&pktfile, (u8*)&etherhdr, ETH_HLEN);
+	i = _rtw_pktfile_read(&pktfile, (u8 *)&etherhdr, ETH_HLEN);
 
 	pattrib->ether_type = ntohs(etherhdr.h_proto);
 
+	if (MLME_IS_MESH(padapter)) /* address resolve is done for mesh */
+		goto get_sta_info;
 
 	_rtw_memcpy(pattrib->dst, &etherhdr.h_dest, ETH_ALEN);
 	_rtw_memcpy(pattrib->src, &etherhdr.h_source, ETH_ALEN);
 
-
 	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
-		(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
 		_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 		_rtw_memcpy(pattrib->ta, adapter_mac_addr(padapter), ETH_ALEN);
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_adhoc);
-	}
-	else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+	} else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
 #ifdef CONFIG_TDLS
 		if (rtw_check_tdls_established(padapter, pattrib) == _TRUE)
 			_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);	/* For TDLS direct link Tx, set ra to be same to dst */
 		else
 #endif
-		_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
+			_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
 		_rtw_memcpy(pattrib->ta, adapter_mac_addr(padapter), ETH_ALEN);
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_sta);
-	}
-	else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
+	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
 		_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 		_rtw_memcpy(pattrib->ta, get_bssid(pmlmepriv), ETH_ALEN);
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_ap);
-	} 
-	else
+	} else
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_unknown);
 
+get_sta_info:
 	bmcast = IS_MCAST(pattrib->ra);
 	if (bmcast) {
 		psta = rtw_get_bcmc_stainfo(padapter);
 		if (psta == NULL) { /* if we cannot get psta => drop the pkt */
 			DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_sta);
-			RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_, ("\nupdate_attrib => get sta_info fail, ra:" MAC_FMT "\n", MAC_ARG(pattrib->ra)));
 			#ifdef DBG_TX_DROP_FRAME
-			DBG_871X("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
+			RTW_INFO("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
 			#endif
 			res = _FAIL;
 			goto exit;
@@ -1346,9 +1353,8 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 		psta = rtw_get_stainfo(pstapriv, pattrib->ra);
 		if (psta == NULL) { /* if we cannot get psta => drop the pkt */
 			DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_ucast_sta);
-			RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_, ("\nupdate_attrib => get sta_info fail, ra:" MAC_FMT"\n", MAC_ARG(pattrib->ra)));
 			#ifdef DBG_TX_DROP_FRAME
-			DBG_871X("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
+			RTW_INFO("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
 			#endif
 			res = _FAIL;
 			goto exit;
@@ -1361,7 +1367,8 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 
 	if (!(psta->state & _FW_LINKED)) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_link);
-		DBG_871X("%s, psta("MAC_FMT")->state(0x%x) != _FW_LINKED\n", __func__, MAC_ARG(psta->hwaddr), psta->state);
+		RTW_INFO("%s-"ADPT_FMT" psta("MAC_FMT")->state(0x%x) != _FW_LINKED\n",
+			__func__, ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr), psta->state);
 		res = _FAIL;
 		goto exit;
 	}
@@ -1399,7 +1406,7 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 					pattrib->dhcp_pkt = 1;
 					DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_dhcp);
 					if (0)
-						DBG_871X("send DHCP packet\n");
+						RTW_INFO("send DHCP packet\n");
 				}
 			}
 
@@ -1416,7 +1423,7 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 						, IPV4_SRC(ip), TCP_SRC(tcp)
 						, IPV4_SRC(ip), TCP_DST(tcp));
 					if (DBG_SESSION_TRACKER)
-						DBG_871X(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" SYN-ACK\n"
+						RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" SYN-ACK\n"
 							, FUNC_ADPT_ARG(padapter)
 							, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp))
 							, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp)));
@@ -1426,7 +1433,7 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 						, IPV4_SRC(ip), TCP_SRC(tcp)
 						, IPV4_SRC(ip), TCP_DST(tcp));
 					if (DBG_SESSION_TRACKER)
-						DBG_871X(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" FIN\n"
+						RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" FIN\n"
 							, FUNC_ADPT_ARG(padapter)
 							, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp))
 							, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp)));
@@ -1434,42 +1441,38 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 			}
 		}
 
-	} else if (0x888e == pattrib->ether_type) {
-		DBG_871X_LEVEL(_drv_always_, "send eapol packet\n");
-	}
+	} else if (0x888e == pattrib->ether_type)
+		RTW_PRINT("send eapol packet\n");
 
 	if ((pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
-		rtw_set_scan_deny(padapter, 3000);
+		rtw_mi_set_scan_deny(padapter, 3000);
 
 #ifdef CONFIG_LPS
-	// If EAPOL , ARP , OR DHCP packet, driver must be in active mode.
+	/* If EAPOL , ARP , OR DHCP packet, driver must be in active mode. */
 #ifdef CONFIG_WAPI_SUPPORT
-	if ( (pattrib->ether_type == 0x88B4) || (pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1) )
-#else //!CONFIG_WAPI_SUPPORT
+	if ((pattrib->ether_type == 0x88B4) || (pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
+#else /* !CONFIG_WAPI_SUPPORT */
 #if 0
-	if ( (pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1) )
-#else // only ICMP/DHCP packets is as SPECIAL_PACKET, and leave LPS when tx IMCP/DHCP packets.
-	//if ((pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1) )
-	if (pattrib->icmp_pkt==1)
-	{
+	if ((pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
+#else /* only ICMP/DHCP packets is as SPECIAL_PACKET, and leave LPS when tx IMCP/DHCP packets. */
+	/* if ((pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1) ) */
+	if (pattrib->icmp_pkt == 1)
 		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1);
-	}
-	else if(pattrib->dhcp_pkt==1)
-#endif 
+	else if (pattrib->dhcp_pkt == 1)
+#endif
 #endif
 	{
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_active);
 		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_SPECIAL_PACKET, 1);
 	}
-#endif //CONFIG_LPS
+#endif /* CONFIG_LPS */
 
 #ifdef CONFIG_BEAMFORMING
 	update_attrib_txbf_info(padapter, pattrib, psta);
 #endif
 
-	//TODO:_lock
-	if(update_attrib_sec_info(padapter, pattrib, psta) == _FAIL)
-	{
+	/* TODO:_lock */
+	if (update_attrib_sec_info(padapter, pattrib, psta) == _FAIL) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_sec);
 		res = _FAIL;
 		goto exit;
@@ -1477,33 +1480,40 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 
 	update_attrib_phy_info(padapter, pattrib, psta);
 
-	//DBG_8192C("%s ==> mac_id(%d)\n",__FUNCTION__,pattrib->mac_id );
-	
+	/* RTW_INFO("%s ==> mac_id(%d)\n",__FUNCTION__,pattrib->mac_id ); */
+
 	pattrib->psta = psta;
-	//TODO:_unlock
-	
-	pattrib->pctrl = 0;	
-		
+	/* TODO:_unlock */
+
+	pattrib->pctrl = 0;
+
 	pattrib->ack_policy = 0;
-	// get ether_hdr_len
-	pattrib->pkt_hdrlen = ETH_HLEN;//(pattrib->ether_type == 0x8100) ? (14 + 4 ): 14; //vlan tag
+	/* get ether_hdr_len */
+	pattrib->pkt_hdrlen = ETH_HLEN;/* (pattrib->ether_type == 0x8100) ? (14 + 4 ): 14; */ /* vlan tag */
 
 	pattrib->hdrlen = WLAN_HDR_A3_LEN;
-	pattrib->subtype = WIFI_DATA_TYPE;	
+	pattrib->subtype = WIFI_DATA_TYPE;
 	pattrib->priority = 0;
-	
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE|WIFI_ADHOC_STATE|WIFI_ADHOC_MASTER_STATE))
-	{
-		if(pattrib->qos_en)
+
+	if (bmcast)
+		pattrib->rate = psta->init_rate;
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE
+		| WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)
+	) {
+		if (pattrib->qos_en) {
 			set_qos(&pktfile, pattrib);
-	}
-	else
-	{
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter))
+				rtw_mesh_tx_set_whdr_mctrl_len(pattrib->mesh_frame_mode, pattrib);
+			#endif
+		}
+	} else {
 #ifdef CONFIG_TDLS
 		if (pattrib->direct_link == _TRUE) {
 			if (pattrib->qos_en)
 				set_qos(&pktfile, pattrib);
-		} else 
+		} else
 #endif
 		{
 			if (pqospriv->qos_option) {
@@ -1515,183 +1525,164 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 		}
 	}
 
-	//pattrib->priority = 5; //force to used VI queue, for testing
+#ifdef CONFIG_WMMPS_STA
+	update_attrib_trigger_frame_info(padapter, pattrib);
+#endif /* CONFIG_WMMPS_STA */	
+
+	/* pattrib->priority = 5; */ /* force to used VI queue, for testing */
 	pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
 	rtw_set_tx_chksum_offload(pkt, pattrib);
 
 exit:
 
-_func_exit_;
 
 	return res;
 }
 
-static s32 xmitframe_addmic(_adapter *padapter, struct xmit_frame *pxmitframe){
-	sint 			curfragnum,length;
-	u8	*pframe, *payload,mic[8];
+static s32 xmitframe_addmic(_adapter *padapter, struct xmit_frame *pxmitframe)
+{
+	sint			curfragnum, length;
+	u8	*pframe, *payload, mic[8];
 	struct	mic_data		micdata;
-	//struct	sta_info		*stainfo;
-	struct	qos_priv   *pqospriv= &(padapter->mlmepriv.qospriv);	
-	struct	pkt_attrib	 *pattrib = &pxmitframe->attrib;
-	struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
-	struct	xmit_priv		*pxmitpriv=&padapter->xmitpriv;
-	u8 priority[4]={0x0,0x0,0x0,0x0};
+	/* struct	sta_info		*stainfo; */
+	struct	qos_priv   *pqospriv = &(padapter->mlmepriv.qospriv);
+	struct	pkt_attrib	*pattrib = &pxmitframe->attrib;
+	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
+	struct	xmit_priv		*pxmitpriv = &padapter->xmitpriv;
+	u8 priority[4] = {0x0, 0x0, 0x0, 0x0};
 	u8 hw_hdr_offset = 0;
 	sint bmcst = IS_MCAST(pattrib->ra);
 
-/*
-	if(pattrib->psta)
-	{
-		stainfo = pattrib->psta;
-	}
-	else
-	{
-		DBG_871X("%s, call rtw_get_stainfo()\n", __func__);
-		stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0]);
-	}	
-	
-	if(stainfo==NULL)
-	{
-		DBG_871X("%s, psta==NUL\n", __func__);
-		return _FAIL;
-	}
+	/*
+		if(pattrib->psta)
+		{
+			stainfo = pattrib->psta;
+		}
+		else
+		{
+			RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+			stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0]);
+		}
 
-	if(!(stainfo->state &_FW_LINKED))
-	{
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
-		return _FAIL;
-	}
-*/
+		if(stainfo==NULL)
+		{
+			RTW_INFO("%s, psta==NUL\n", __func__);
+			return _FAIL;
+		}
+
+		if(!(stainfo->state &_FW_LINKED))
+		{
+			RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
+			return _FAIL;
+		}
+	*/
 
-_func_enter_;
 
 #ifdef CONFIG_USB_TX_AGGREGATION
-	hw_hdr_offset = TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);;	
+	hw_hdr_offset = TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);;
+#else
+#ifdef CONFIG_TX_EARLY_MODE
+	hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
 #else
-	#ifdef CONFIG_TX_EARLY_MODE
-	hw_hdr_offset = TXDESC_OFFSET+ EARLY_MODE_INFO_SIZE;
-	#else
 	hw_hdr_offset = TXDESC_OFFSET;
-	#endif
-#endif	
-	
-	if(pattrib->encrypt ==_TKIP_)//if(psecuritypriv->dot11PrivacyAlgrthm==_TKIP_PRIVACY_) 
-	{
-		//encode mic code
-		//if(stainfo!= NULL)
+#endif
+#endif
+
+	if (pattrib->encrypt == _TKIP_) { /* if(psecuritypriv->dot11PrivacyAlgrthm==_TKIP_PRIVACY_) */
+		/* encode mic code */
+		/* if(stainfo!= NULL) */
 		{
-			u8 null_key[16]={0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0};
+			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(_rtw_memcmp(psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey, null_key, 16)==_TRUE){
-					//DbgPrint("\nxmitframe_addmic:stainfo->dot11tkiptxmickey==0\n");
-					//rtw_msleep_os(10);
+
+			if (bmcst) {
+				if (_rtw_memcmp(psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey, null_key, 16) == _TRUE) {
+					/* DbgPrint("\nxmitframe_addmic:stainfo->dot11tkiptxmickey==0\n"); */
+					/* rtw_msleep_os(10); */
 					return _FAIL;
-				}				
-				//start to calculate the mic code
+				}
+				/* start to calculate the mic code */
 				rtw_secmicsetkey(&micdata, psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey);
-			}
-			else
-			{
-				if(_rtw_memcmp(&pattrib->dot11tkiptxmickey.skey[0],null_key, 16)==_TRUE){
-					//DbgPrint("\nxmitframe_addmic:stainfo->dot11tkiptxmickey==0\n");
-					//rtw_msleep_os(10);
+			} else {
+				if (_rtw_memcmp(&pattrib->dot11tkiptxmickey.skey[0], null_key, 16) == _TRUE) {
+					/* DbgPrint("\nxmitframe_addmic:stainfo->dot11tkiptxmickey==0\n"); */
+					/* rtw_msleep_os(10); */
 					return _FAIL;
 				}
-				//start to calculate the mic code
+				/* start to calculate the mic code */
 				rtw_secmicsetkey(&micdata, &pattrib->dot11tkiptxmickey.skey[0]);
 			}
-			
-			if(pframe[1]&1){   //ToDS==1
-				rtw_secmicappend(&micdata, &pframe[16], 6);  //DA
-				if(pframe[1]&2)  //From Ds==1
+
+			if (pframe[1] & 1) { /* ToDS==1 */
+				rtw_secmicappend(&micdata, &pframe[16], 6);  /* DA */
+				if (pframe[1] & 2) /* From Ds==1 */
 					rtw_secmicappend(&micdata, &pframe[24], 6);
 				else
-				rtw_secmicappend(&micdata, &pframe[10], 6);		
-			}	
-			else{	//ToDS==0
-				rtw_secmicappend(&micdata, &pframe[4], 6);   //DA
-				if(pframe[1]&2)  //From Ds==1
+					rtw_secmicappend(&micdata, &pframe[10], 6);
+			} else {	/* ToDS==0 */
+				rtw_secmicappend(&micdata, &pframe[4], 6);   /* DA */
+				if (pframe[1] & 2) /* From Ds==1 */
 					rtw_secmicappend(&micdata, &pframe[16], 6);
 				else
 					rtw_secmicappend(&micdata, &pframe[10], 6);
 
 			}
 
-                    //if(pqospriv->qos_option==1)
-                    if(pattrib->qos_en)
-				priority[0]=(u8)pxmitframe->attrib.priority;
+			/* if(pqospriv->qos_option==1) */
+			if (pattrib->qos_en)
+				priority[0] = (u8)pxmitframe->attrib.priority;
+
 
-			
 			rtw_secmicappend(&micdata, &priority[0], 4);
-	
-			payload=pframe;
-
-			for(curfragnum=0;curfragnum<pattrib->nr_frags;curfragnum++){
-				payload=(u8 *)RND4((SIZE_PTR)(payload));
-				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",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_secmicappend(&micdata, payload,length);
-					payload=payload+length;
-				}
-				else{
-					length=pxmitpriv->frag_len-pattrib->hdrlen-pattrib->iv_len-( (pattrib->bswenc) ? pattrib->icv_len : 0);
+
+			payload = pframe;
+
+			for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
+				payload = (u8 *)RND4((SIZE_PTR)(payload));
+
+				payload = payload + 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_secmicappend(&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",curfragnum,length,pattrib->icv_len));
+					payload = payload + length;
+				} else {
+					length = pxmitpriv->frag_len - pattrib->hdrlen - pattrib->iv_len - ((pattrib->bswenc) ? pattrib->icv_len : 0);
+					rtw_secmicappend(&micdata, payload, length);
+					payload = payload + length + pattrib->icv_len;
 				}
 			}
-			rtw_secgetmic(&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 \n\
-  mic[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
-
-			_rtw_memcpy(payload, &(mic[0]),8);
-			pattrib->last_txcmdsz+=8;
-			
-			RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("\n ========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 ",
-					*(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_stainfo==NULL!!!\n"));
-			}
-*/		
+			rtw_secgetmic(&micdata, &(mic[0]));
+			/* add mic code  and add the mic code length in last_txcmdsz */
+
+			_rtw_memcpy(payload, &(mic[0]), 8);
+			pattrib->last_txcmdsz += 8;
+
+			payload = payload - pattrib->last_txcmdsz + 8;
+		}
 	}
-	
-_func_exit_;
+
 
 	return _SUCCESS;
 }
 
-static s32 xmitframe_swencrypt(_adapter *padapter, struct xmit_frame *pxmitframe){
+/*#define DBG_TX_SW_ENCRYPTOR*/
+
+static s32 xmitframe_swencrypt(_adapter *padapter, struct xmit_frame *pxmitframe)
+{
 
-	struct	pkt_attrib	 *pattrib = &pxmitframe->attrib;
-	//struct 	security_priv	*psecuritypriv=&padapter->securitypriv;
-	
-_func_enter_;
+	struct	pkt_attrib	*pattrib = &pxmitframe->attrib;
+	/* struct 	security_priv	*psecuritypriv=&padapter->securitypriv; */
 
-	//if((psecuritypriv->sw_encrypt)||(pattrib->bswenc))	
-	if(pattrib->bswenc)
-	{
-		//DBG_871X("start xmitframe_swencrypt\n");
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_alert_,("### xmitframe_swencrypt\n"));
-		switch(pattrib->encrypt){
+
+	/* if((psecuritypriv->sw_encrypt)||(pattrib->bswenc))	 */
+	if (pattrib->bswenc) {
+#ifdef DBG_TX_SW_ENCRYPTOR
+		RTW_INFO(ADPT_FMT" - sec_type:%s DO SW encryption\n",
+			ADPT_ARG(padapter), security_type_str(pattrib->encrypt));
+#endif
+
+		switch (pattrib->encrypt) {
 		case _WEP40_:
 		case _WEP104_:
 			rtw_wep_encrypt(padapter, (u8 *)pxmitframe);
@@ -1700,26 +1691,23 @@ _func_enter_;
 			rtw_tkip_encrypt(padapter, (u8 *)pxmitframe);
 			break;
 		case _AES_:
-			rtw_aes_encrypt(padapter, (u8 * )pxmitframe);
+			rtw_aes_encrypt(padapter, (u8 *)pxmitframe);
 			break;
 #ifdef CONFIG_WAPI_SUPPORT
 		case _SMS4_:
-			rtw_sms4_encrypt(padapter, (u8 * )pxmitframe);
+			rtw_sms4_encrypt(padapter, (u8 *)pxmitframe);
 #endif
 		default:
-				break;
+			break;
 		}
 
-	} else {
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_notice_,("### xmitframe_hwencrypt\n"));
 	}
 
-_func_exit_;
 
 	return _SUCCESS;
 }
 
-s32 rtw_make_wlanhdr (_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib)
+s32 rtw_make_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib)
 {
 	u16 *qc;
 
@@ -1730,98 +1718,101 @@ s32 rtw_make_wlanhdr (_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib)
 	sint res = _SUCCESS;
 	u16 *fctrl = &pwlanhdr->frame_ctl;
 
-	//struct sta_info *psta;
+	/* struct sta_info *psta; */
 
-	//sint bmcst = IS_MCAST(pattrib->ra);
+	/* sint bmcst = IS_MCAST(pattrib->ra); */
 
-_func_enter_;
 
-/*
-	psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-	if(pattrib->psta != psta)
-	{
-		DBG_871X("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
-		return;
-	}
+	/*
+		psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
+		if(pattrib->psta != psta)
+		{
+			RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
+			return;
+		}
 
-	if(psta==NULL)
-	{
-		DBG_871X("%s, psta==NUL\n", __func__);
-		return _FAIL;
-	}
+		if(psta==NULL)
+		{
+			RTW_INFO("%s, psta==NUL\n", __func__);
+			return _FAIL;
+		}
 
-	if(!(psta->state &_FW_LINKED))
-	{
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
-		return _FAIL;
-	}
-*/
+		if(!(psta->state &_FW_LINKED))
+		{
+			RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
+			return _FAIL;
+		}
+	*/
 
 	_rtw_memset(hdr, 0, WLANHDR_OFFSET);
 
-	SetFrameSubType(fctrl, pattrib->subtype);
+	set_frame_sub_type(fctrl, pattrib->subtype);
 
-	if (pattrib->subtype & WIFI_DATA_TYPE)
-	{
+	if (pattrib->subtype & WIFI_DATA_TYPE) {
 		if ((check_fwstate(pmlmepriv,  WIFI_STATION_STATE) == _TRUE)) {
 #ifdef CONFIG_TDLS
-			if(pattrib->direct_link == _TRUE){
-				//TDLS data transfer, ToDS=0, FrDs=0
+			if (pattrib->direct_link == _TRUE) {
+				/* TDLS data transfer, ToDS=0, FrDs=0 */
 				_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
 				_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
 				_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
 
 				if (pattrib->qos_en)
 					qos_option = _TRUE;
-			} 
-			else
-#endif //CONFIG_TDLS
+			} else
+#endif /* CONFIG_TDLS */
 			{
-				//to_ds = 1, fr_ds = 0;
-				// 1.Data transfer to AP
-				// 2.Arp pkt will relayed by AP
-				SetToDs(fctrl);							
+				/* to_ds = 1, fr_ds = 0; */
+				/* 1.Data transfer to AP */
+				/* 2.Arp pkt will relayed by AP */
+				SetToDs(fctrl);
 				_rtw_memcpy(pwlanhdr->addr1, get_bssid(pmlmepriv), ETH_ALEN);
 				_rtw_memcpy(pwlanhdr->addr2, pattrib->ta, ETH_ALEN);
 				_rtw_memcpy(pwlanhdr->addr3, pattrib->dst, ETH_ALEN);
 
 				if (pqospriv->qos_option)
 					qos_option = _TRUE;
-			} 
-		}
-		else if ((check_fwstate(pmlmepriv,  WIFI_AP_STATE) == _TRUE) ) {
-			//to_ds = 0, fr_ds = 1;
+			}
+		} else if ((check_fwstate(pmlmepriv,  WIFI_AP_STATE) == _TRUE)) {
+			/* to_ds = 0, fr_ds = 1; */
 			SetFrDs(fctrl);
 			_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr2, get_bssid(pmlmepriv), ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr3, pattrib->src, ETH_ALEN);
 
-			if(pattrib->qos_en)
+			if (pattrib->qos_en)
 				qos_option = _TRUE;
-		}
-		else if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
-		(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
+		} else if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
+			(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
 			_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr2, pattrib->ta, ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
 
-			if(pattrib->qos_en)
+			if (pattrib->qos_en)
 				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)));
+#ifdef CONFIG_RTW_MESH
+		} else if (check_fwstate(pmlmepriv, WIFI_MESH_STATE) == _TRUE) {
+			rtw_mesh_tx_build_whdr(padapter, pattrib, fctrl, pwlanhdr);
+			if (pattrib->qos_en)
+				qos_option = _TRUE;
+			else {
+				RTW_WARN("[%s] !qos_en in Mesh\n", __FUNCTION__);
+				res = _FAIL;
+				goto exit;
+			}
+#endif
+		} else {
 			res = _FAIL;
 			goto exit;
 		}
 
-		if(pattrib->mdata)
+		if (pattrib->mdata)
 			SetMData(fctrl);
 
 		if (pattrib->encrypt)
 			SetPrivacy(fctrl);
 
-		if (qos_option)
-		{
+		if (qos_option) {
 			qc = (unsigned short *)(hdr + pattrib->hdrlen - 2);
 
 			if (pattrib->priority)
@@ -1830,35 +1821,46 @@ _func_enter_;
 			SetEOSP(qc, pattrib->eosp);
 
 			SetAckpolicy(qc, pattrib->ack_policy);
+
+			if(pattrib->amsdu)
+				SetAMsdu(qc, pattrib->amsdu);
+#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter)) {
+				/* active: don't care, light sleep: 0, deep sleep: 1*/
+				set_mps_lv(qc, 0); //TBD
+
+				/* TBD: temporary set (rspi, eosp) = (0, 1) which means End MPSP */
+				set_rspi(qc, 0);
+				SetEOSP(qc, 1);
+				
+				set_mctrl_present(qc, 1);
+			}
+#endif
 		}
 
-		//TODO: fill HT Control Field
+		/* TODO: fill HT Control Field */
 
-		//Update Seq Num will be handled by f/w
+		/* Update Seq Num will be handled by f/w */
 		{
 			struct sta_info *psta;
 			psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-			if(pattrib->psta != psta)
-			{
-				DBG_871X("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
+			if (pattrib->psta != psta) {
+				RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
 				return _FAIL;
 			}
 
-			if(psta==NULL)
-			{
-				DBG_871X("%s, psta==NUL\n", __func__);
+			if (psta == NULL) {
+				RTW_INFO("%s, psta==NUL\n", __func__);
 				return _FAIL;
 			}
 
-			if(!(psta->state &_FW_LINKED))
-			{
-				DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
+			if (!(psta->state & _FW_LINKED)) {
+				RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
 				return _FAIL;
 			}
 
-		
-			if(psta)
-			{
+
+			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];
@@ -1866,53 +1868,44 @@ _func_enter_;
 				SetSeqNum(hdr, pattrib->seqnum);
 
 #ifdef CONFIG_80211N_HT
-				//check if enable ampdu
-				if(pattrib->ht_en && psta->htpriv.ampdu_enable)
-				{
-					if(psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority))
+#if 0 /* move into update_attrib_phy_info(). */
+				/* check if enable ampdu */
+				if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
+					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 == _TRUE)
-				{					
+#endif
+				/* re-check if enable ampdu by BA_starting_seqctrl */
+				if (pattrib->ampdu_en == _TRUE) {
 					u16 tx_seq;
 
 					tx_seq = psta->BA_starting_seqctrl[pattrib->priority & 0x0f];
-		
-					//check BA_starting_seqctrl
-					if(SN_LESS(pattrib->seqnum, tx_seq))
-					{
-						//DBG_871X("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_871X("tx ampdu over run\n");
-						psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (pattrib->seqnum+1)&0xfff;
-						pattrib->ampdu_en = _TRUE;//AGG EN
+
+					/* check BA_starting_seqctrl */
+					if (SN_LESS(pattrib->seqnum, tx_seq)) {
+						/* RTW_INFO("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 {
+						/* RTW_INFO("tx ampdu over run\n"); */
+						psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (pattrib->seqnum + 1) & 0xfff;
+						pattrib->ampdu_en = _TRUE;/* AGG EN */
 					}
 
 				}
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 			}
 		}
-		
-	}
-	else
-	{
+
+	} else {
 
 	}
 
 exit:
 
-_func_exit_;
 
 	return res;
 }
@@ -1921,194 +1914,200 @@ s32 rtw_txframes_pending(_adapter *padapter)
 {
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 
-	return ((_rtw_queue_empty(&pxmitpriv->be_pending) == _FALSE) || 
-			 (_rtw_queue_empty(&pxmitpriv->bk_pending) == _FALSE) || 
-			 (_rtw_queue_empty(&pxmitpriv->vi_pending) == _FALSE) ||
-			 (_rtw_queue_empty(&pxmitpriv->vo_pending) == _FALSE));
+	return ((_rtw_queue_empty(&pxmitpriv->be_pending) == _FALSE) ||
+		(_rtw_queue_empty(&pxmitpriv->bk_pending) == _FALSE) ||
+		(_rtw_queue_empty(&pxmitpriv->vi_pending) == _FALSE) ||
+		(_rtw_queue_empty(&pxmitpriv->vo_pending) == _FALSE));
 }
 
 s32 rtw_txframes_sta_ac_pending(_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_871X("%s, call rtw_get_stainfo()\n", __func__);
-		psta=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0]);
-	}	
-*/
+	/*
+		if(pattrib->psta)
+		{
+			psta = pattrib->psta;
+		}
+		else
+		{
+			RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+			psta=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0]);
+		}
+	*/
 	psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-	if(pattrib->psta != psta)
-	{
-		DBG_871X("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
+	if (pattrib->psta != psta) {
+		RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
 		return 0;
 	}
 
-	if(psta==NULL)
-	{
-		DBG_871X("%s, psta==NUL\n", __func__);
+	if (psta == NULL) {
+		RTW_INFO("%s, psta==NUL\n", __func__);
 		return 0;
 	}
 
-	if(!(psta->state &_FW_LINKED))
-	{
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
+	if (!(psta->state & _FW_LINKED)) {
+		RTW_INFO("%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;	
+	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;
 }
 
 #ifdef CONFIG_TDLS
 
-int rtw_build_tdls_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
+int rtw_build_tdls_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
 {
-	int res=_SUCCESS;
+	struct pkt_attrib *pattrib = &pxmitframe->attrib;
+	struct sta_info *ptdls_sta = NULL;
+	int res = _SUCCESS;
 
-	switch(ptxmgmt->action_code){
-		case TDLS_SETUP_REQUEST:
-			rtw_build_tdls_setup_req_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
-		case TDLS_SETUP_RESPONSE:
-			rtw_build_tdls_setup_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
-		case TDLS_SETUP_CONFIRM:
-			rtw_build_tdls_setup_cfm_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
-		case TDLS_TEARDOWN:
-			rtw_build_tdls_teardown_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
+	ptdls_sta = rtw_get_stainfo((&padapter->stapriv), pattrib->dst);
+	if (ptdls_sta == NULL) {
+		switch (ptxmgmt->action_code) {
 		case TDLS_DISCOVERY_REQUEST:
-			rtw_build_tdls_dis_req_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;			
-		case TDLS_PEER_TRAFFIC_INDICATION:
-			rtw_build_tdls_peer_traffic_indication_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
-#ifdef CONFIG_TDLS_CH_SW			
-		case TDLS_CHANNEL_SWITCH_REQUEST:
-			rtw_build_tdls_ch_switch_req_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
-		case TDLS_CHANNEL_SWITCH_RESPONSE:
-			rtw_build_tdls_ch_switch_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
-#endif			
-		case TDLS_PEER_TRAFFIC_RESPONSE:
-			rtw_build_tdls_peer_traffic_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt);
-			break;
-#ifdef CONFIG_WFD			
 		case TUNNELED_PROBE_REQ:
-			rtw_build_tunneled_probe_req_ies(padapter, pxmitframe, pframe);
-			break;
 		case TUNNELED_PROBE_RSP:
-			rtw_build_tunneled_probe_rsp_ies(padapter, pxmitframe, pframe);
 			break;
-#endif //CONFIG_WFD
 		default:
-			res=_FAIL;
-			break;
+			RTW_INFO("[TDLS] %s - Direct Link Peer = "MAC_FMT" not found for action = %d\n", __func__, MAC_ARG(pattrib->dst), ptxmgmt->action_code);
+			res = _FAIL;
+			goto exit;
+		}
+	}
+
+	switch (ptxmgmt->action_code) {
+	case TDLS_SETUP_REQUEST:
+		rtw_build_tdls_setup_req_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+	case TDLS_SETUP_RESPONSE:
+		rtw_build_tdls_setup_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+	case TDLS_SETUP_CONFIRM:
+		rtw_build_tdls_setup_cfm_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+	case TDLS_TEARDOWN:
+		rtw_build_tdls_teardown_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+	case TDLS_DISCOVERY_REQUEST:
+		rtw_build_tdls_dis_req_ies(padapter, pxmitframe, pframe, ptxmgmt);
+		break;
+	case TDLS_PEER_TRAFFIC_INDICATION:
+		rtw_build_tdls_peer_traffic_indication_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+#ifdef CONFIG_TDLS_CH_SW
+	case TDLS_CHANNEL_SWITCH_REQUEST:
+		rtw_build_tdls_ch_switch_req_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+	case TDLS_CHANNEL_SWITCH_RESPONSE:
+		rtw_build_tdls_ch_switch_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+#endif
+	case TDLS_PEER_TRAFFIC_RESPONSE:
+		rtw_build_tdls_peer_traffic_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
+		break;
+#ifdef CONFIG_WFD
+	case TUNNELED_PROBE_REQ:
+		rtw_build_tunneled_probe_req_ies(padapter, pxmitframe, pframe);
+		break;
+	case TUNNELED_PROBE_RSP:
+		rtw_build_tunneled_probe_rsp_ies(padapter, pxmitframe, pframe);
+		break;
+#endif /* CONFIG_WFD */
+	default:
+		res = _FAIL;
+		break;
 	}
 
+exit:
 	return res;
 }
 
-s32 rtw_make_tdls_wlanhdr (_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
+s32 rtw_make_tdls_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
 {
 	u16 *qc;
 	struct rtw_ieee80211_hdr *pwlanhdr = (struct rtw_ieee80211_hdr *)hdr;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct qos_priv *pqospriv = &pmlmepriv->qospriv;
-	struct sta_priv 	*pstapriv = &padapter->stapriv;
-	struct sta_info *psta=NULL, *ptdls_sta=NULL;
-	u8 tdls_seq=0, baddr[ETH_ALEN] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
+	struct sta_priv	*pstapriv = &padapter->stapriv;
+	struct sta_info *psta = NULL, *ptdls_sta = NULL;
+	u8 tdls_seq = 0, baddr[ETH_ALEN] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
 
 	sint res = _SUCCESS;
 	u16 *fctrl = &pwlanhdr->frame_ctl;
 
-_func_enter_;
 
 	_rtw_memset(hdr, 0, WLANHDR_OFFSET);
 
-	SetFrameSubType(fctrl, pattrib->subtype);
+	set_frame_sub_type(fctrl, pattrib->subtype);
 
-	switch(ptxmgmt->action_code){
-		case TDLS_SETUP_REQUEST:
-		case TDLS_SETUP_RESPONSE:
-		case TDLS_SETUP_CONFIRM:
-		case TDLS_PEER_TRAFFIC_INDICATION:
+	switch (ptxmgmt->action_code) {
+	case TDLS_SETUP_REQUEST:
+	case TDLS_SETUP_RESPONSE:
+	case TDLS_SETUP_CONFIRM:
+	case TDLS_PEER_TRAFFIC_INDICATION:
 	case TDLS_PEER_PSM_REQUEST:
-		case TUNNELED_PROBE_REQ:
-		case TUNNELED_PROBE_RSP:
-		case TDLS_DISCOVERY_REQUEST:
+	case TUNNELED_PROBE_REQ:
+	case TUNNELED_PROBE_RSP:
+	case TDLS_DISCOVERY_REQUEST:
+		SetToDs(fctrl);
+		_rtw_memcpy(pwlanhdr->addr1, get_bssid(pmlmepriv), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, pattrib->dst, ETH_ALEN);
+		break;
+	case TDLS_CHANNEL_SWITCH_REQUEST:
+	case TDLS_CHANNEL_SWITCH_RESPONSE:
+	case TDLS_PEER_PSM_RESPONSE:
+	case TDLS_PEER_TRAFFIC_RESPONSE:
+		_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
+		tdls_seq = 1;
+		break;
+	case TDLS_TEARDOWN:
+		if (ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_) {
+			_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
+			_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
+			_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
+			tdls_seq = 1;
+		} else {
 			SetToDs(fctrl);
 			_rtw_memcpy(pwlanhdr->addr1, get_bssid(pmlmepriv), ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
 			_rtw_memcpy(pwlanhdr->addr3, pattrib->dst, ETH_ALEN);
-			break;
-		case TDLS_CHANNEL_SWITCH_REQUEST:
-		case TDLS_CHANNEL_SWITCH_RESPONSE:
-		case TDLS_PEER_PSM_RESPONSE:
-		case TDLS_PEER_TRAFFIC_RESPONSE:
-			_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
-			tdls_seq=1;
-			break;
-		case TDLS_TEARDOWN:
-			if(ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_)
-			{
-				_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
-				_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
-				_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
-				tdls_seq=1;
-			}
-			else
-			{
-				SetToDs(fctrl);		
-				_rtw_memcpy(pwlanhdr->addr1, get_bssid(pmlmepriv), ETH_ALEN);
-				_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
-				_rtw_memcpy(pwlanhdr->addr3, pattrib->dst, ETH_ALEN);
-			}
-			break;
+		}
+		break;
 	}
 
 	if (pattrib->encrypt)
 		SetPrivacy(fctrl);
 
-	if(ptxmgmt->action_code == TDLS_PEER_TRAFFIC_RESPONSE)
-	{
+	if (ptxmgmt->action_code == TDLS_PEER_TRAFFIC_RESPONSE)
 		SetPwrMgt(fctrl);
-	}
 
-	if (pqospriv->qos_option)
-	{
+	if (pqospriv->qos_option) {
 		qc = (unsigned short *)(hdr + pattrib->hdrlen - 2);
 		if (pattrib->priority)
 			SetPriority(qc, pattrib->priority);
@@ -2116,29 +2115,29 @@ _func_enter_;
 	}
 
 	psta = pattrib->psta;
- 
-	//  1. update seq_num per link by sta_info
-	//  2. rewrite encrypt to _AES_, also rewrite iv_len, icv_len
-	if(tdls_seq==1){
-		ptdls_sta=rtw_get_stainfo(pstapriv, pattrib->dst);
-		if(ptdls_sta){
+
+	/* 1. update seq_num per link by sta_info */
+	/* 2. rewrite encrypt to _AES_, also rewrite iv_len, icv_len */
+	if (tdls_seq == 1) {
+		ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->dst);
+		if (ptdls_sta) {
 			ptdls_sta->sta_xmitpriv.txseq_tid[pattrib->priority]++;
 			ptdls_sta->sta_xmitpriv.txseq_tid[pattrib->priority] &= 0xFFF;
 			pattrib->seqnum = ptdls_sta->sta_xmitpriv.txseq_tid[pattrib->priority];
 			SetSeqNum(hdr, pattrib->seqnum);
 
-			if (pattrib->encrypt){
-				pattrib->encrypt= _AES_;
-				pattrib->iv_len=8;
-				pattrib->icv_len=8;
+			if (pattrib->encrypt) {
+				pattrib->encrypt = _AES_;
+				pattrib->iv_len = 8;
+				pattrib->icv_len = 8;
 				pattrib->bswenc = _FALSE;
 			}
-			pattrib->mac_id = ptdls_sta->mac_id;
-		}else{
-			res=_FAIL;
+			pattrib->mac_id = ptdls_sta->cmn.mac_id;
+		} else {
+			res = _FAIL;
 			goto exit;
 		}
-	}else if(psta){
+	} else 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];
@@ -2148,12 +2147,11 @@ _func_enter_;
 
 exit:
 
-_func_exit_;
 
 	return res;
 }
 
-s32 rtw_xmit_tdls_coalesce(_adapter * padapter, struct xmit_frame * pxmitframe, struct tdls_txmgmt *ptxmgmt)
+s32 rtw_xmit_tdls_coalesce(_adapter *padapter, struct xmit_frame *pxmitframe, struct tdls_txmgmt *ptxmgmt)
 {
 	s32 llc_sz;
 
@@ -2166,20 +2164,18 @@ s32 rtw_xmit_tdls_coalesce(_adapter * padapter, struct xmit_frame * pxmitframe,
 	u8 *pbuf_start;
 	s32 bmcst = IS_MCAST(pattrib->ra);
 	s32 res = _SUCCESS;
-	
-_func_enter_;
 
-	if (pattrib->psta) {
+
+	if (pattrib->psta)
 		psta = pattrib->psta;
-	} else {	
-		if(bmcst) {
+	else {
+		if (bmcst)
 			psta = rtw_get_bcmc_stainfo(padapter);
-		} else {
+		else
 			psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-	        }
 	}
 
-	if (psta==NULL) {
+	if (psta == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
@@ -2200,29 +2196,26 @@ _func_enter_;
 	pframe = mem_start;
 	pframe += pattrib->hdrlen;
 
-	//adding icv, if necessary...
-	if (pattrib->iv_len)
-	{
-		if (psta != NULL)
-		{
-			switch(pattrib->encrypt)
-			{
-				case _WEP40_:
-				case _WEP104_:
-						WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);	
-					break;
-				case _TKIP_:			
-					if(bmcst)
-						TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
-					else
-						TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
-					break;			
-				case _AES_:
-					if(bmcst)
-						AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
-					else
-						AES_IV(pattrib->iv, psta->dot11txpn, 0);
-					break;
+	/* adding icv, if necessary... */
+	if (pattrib->iv_len) {
+		if (psta != NULL) {
+			switch (pattrib->encrypt) {
+			case _WEP40_:
+			case _WEP104_:
+				WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+				break;
+			case _TKIP_:
+				if (bmcst)
+					TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+				else
+					TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
+				break;
+			case _AES_:
+				if (bmcst)
+					AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+				else
+					AES_IV(pattrib->iv, psta->dot11txpn, 0);
+				break;
 			}
 		}
 
@@ -2234,38 +2227,36 @@ _func_enter_;
 	llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
 	pframe += llc_sz;
 
-	//pattrib->pktlen will be counted in rtw_build_tdls_ies
+	/* pattrib->pktlen will be counted in rtw_build_tdls_ies */
 	pattrib->pktlen = 0;
 
 	rtw_build_tdls_ies(padapter, pxmitframe, pframe, ptxmgmt);
 
-	if ((pattrib->icv_len >0 )&& (pattrib->bswenc)) {
+	if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
 		pframe += pattrib->pktlen;
-		_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len); 
+		_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
 		pframe += pattrib->icv_len;
 	}
 
 	pattrib->nr_frags = 1;
-	pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len + llc_sz + 
-			((pattrib->bswenc) ? pattrib->icv_len : 0) + pattrib->pktlen;
-	
-	if (xmitframe_addmic(padapter, pxmitframe) == _FAIL)
-	{
+	pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len + llc_sz +
+		((pattrib->bswenc) ? pattrib->icv_len : 0) + pattrib->pktlen;
+
+	if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
 		res = _FAIL;
 		goto exit;
 	}
 
 	xmitframe_swencrypt(padapter, pxmitframe);
-	
+
 	update_attrib_vcs_info(padapter, pxmitframe);
-	
-exit:	
-	
-_func_exit_;	
+
+exit:
+
 
 	return res;
 }
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 /*
  * Calculate wlan 802.11 packet MAX size from pkt_attrib
@@ -2275,15 +2266,264 @@ u32 rtw_calculate_wlan_pkt_size_by_attribue(struct pkt_attrib *pattrib)
 {
 	u32	len = 0;
 
-	len = pattrib->hdrlen + pattrib->iv_len; // WLAN Header and IV
-	len += SNAP_SIZE + sizeof(u16); // LLC
-	len += pattrib->pktlen;
-	if (pattrib->encrypt == _TKIP_) len += 8; // MIC
-	len += ((pattrib->bswenc) ? pattrib->icv_len : 0); // ICV
+	len = pattrib->hdrlen /* WLAN Header */
+		+ pattrib->iv_len /* IV */
+		+ XATTRIB_GET_MCTRL_LEN(pattrib)
+		+ SNAP_SIZE + sizeof(u16) /* LLC */
+		+ pattrib->pktlen
+		+ (pattrib->encrypt == _TKIP_ ? 8 : 0) /* MIC */
+		+ (pattrib->bswenc ? pattrib->icv_len : 0) /* ICV */
+		;
 
 	return len;
 }
 
+#ifdef CONFIG_TX_AMSDU
+s32 check_amsdu(struct xmit_frame *pxmitframe)
+{
+	struct pkt_attrib *pattrib;
+	s32 ret = _TRUE;
+
+	if (!pxmitframe)
+		ret = _FALSE;
+
+	pattrib = &pxmitframe->attrib;
+
+	if (IS_MCAST(pattrib->ra))
+		ret = _FALSE;
+
+	if ((pattrib->ether_type == 0x888e) ||
+		(pattrib->ether_type == 0x0806) ||
+		(pattrib->ether_type == 0x88b4) ||
+		(pattrib->dhcp_pkt == 1))
+		ret = _FALSE;
+
+	if ((pattrib->encrypt == _WEP40_) ||
+	    (pattrib->encrypt == _WEP104_) ||
+	    (pattrib->encrypt == _TKIP_))
+		ret = _FALSE;
+
+	if (!pattrib->qos_en)
+		ret = _FALSE;
+
+	if (IS_AMSDU_AMPDU_NOT_VALID(pattrib))
+		ret = _FALSE;
+
+	return ret;
+}
+
+s32 check_amsdu_tx_support(_adapter *padapter)
+{
+	struct dvobj_priv *pdvobjpriv;
+	int tx_amsdu;
+	int tx_amsdu_rate;
+	int current_tx_rate;
+	s32 ret = _FALSE;
+
+	pdvobjpriv = adapter_to_dvobj(padapter);
+	tx_amsdu = padapter->tx_amsdu;
+	tx_amsdu_rate = padapter->tx_amsdu_rate;
+	current_tx_rate = pdvobjpriv->traffic_stat.cur_tx_tp;
+
+	if (tx_amsdu == 1)
+		ret = _TRUE;
+	else if (tx_amsdu == 2 && (tx_amsdu_rate == 0 || current_tx_rate > tx_amsdu_rate))
+		ret = _TRUE;
+	else
+		ret = _FALSE;
+
+	return ret;
+}
+
+s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitframe, struct xmit_frame *pxmitframe_queue)
+{
+
+	struct pkt_file pktfile;
+	struct pkt_attrib *pattrib;
+	_pkt *pkt;
+
+	struct pkt_file pktfile_queue;
+	struct pkt_attrib *pattrib_queue;
+	_pkt *pkt_queue;
+
+	s32 llc_sz, mem_sz;
+
+	s32 padding = 0;
+
+	u8 *pframe, *mem_start;
+	u8 hw_hdr_offset;
+
+	u16* len;
+	u8 *pbuf_start;
+	s32 res = _SUCCESS;
+
+	if (pxmitframe->buf_addr == NULL) {
+		RTW_INFO("==> %s buf_addr==NULL\n", __FUNCTION__);
+		return _FAIL;
+	}
+
+
+	pbuf_start = pxmitframe->buf_addr;
+
+#ifdef CONFIG_USB_TX_AGGREGATION
+	hw_hdr_offset =  TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
+#else
+#ifdef CONFIG_TX_EARLY_MODE /* for SDIO && Tx Agg */
+	hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
+#else
+	hw_hdr_offset = TXDESC_OFFSET;
+#endif
+#endif
+
+	mem_start = pbuf_start + hw_hdr_offset; //for DMA
+
+	pattrib = &pxmitframe->attrib;
+
+	pattrib->amsdu = 1;
+
+	if (rtw_make_wlanhdr(padapter, mem_start, pattrib) == _FAIL) {
+		RTW_INFO("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n");
+		res = _FAIL;
+		goto exit;
+	}
+
+	llc_sz = 0;
+
+	pframe = mem_start;
+
+	//SetMFrag(mem_start);
+	ClearMFrag(mem_start);
+
+	pframe += pattrib->hdrlen;
+
+	/* adding icv, if necessary... */
+	if (pattrib->iv_len) {
+		_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len); // queue or new?
+
+		RTW_DBG("rtw_xmitframe_coalesce: 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;
+	}
+
+	pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len;
+
+	if(pxmitframe_queue)
+	{
+		pattrib_queue = &pxmitframe_queue->attrib;
+		pkt_queue = pxmitframe_queue->pkt;
+
+		_rtw_open_pktfile(pkt_queue, &pktfile_queue);
+		_rtw_pktfile_read(&pktfile_queue, NULL, pattrib_queue->pkt_hdrlen);
+
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter)) {
+			/* mDA(6), mSA(6), len(2), mctrl */
+			_rtw_memcpy(pframe, pattrib_queue->mda, ETH_ALEN);
+			pframe += ETH_ALEN;
+			_rtw_memcpy(pframe, pattrib_queue->msa, ETH_ALEN);
+			pframe += ETH_ALEN;
+			len = (u16*)pframe;
+			pframe += 2;
+			rtw_mesh_tx_build_mctrl(padapter, pattrib_queue, pframe);
+			pframe += XATTRIB_GET_MCTRL_LEN(pattrib_queue);
+		} else
+		#endif
+		{
+			/* 802.3 MAC Header DA(6)  SA(6)  Len(2)*/
+			_rtw_memcpy(pframe, pattrib_queue->dst, ETH_ALEN);
+			pframe += ETH_ALEN;
+			_rtw_memcpy(pframe, pattrib_queue->src, ETH_ALEN);
+			pframe += ETH_ALEN;
+			len = (u16*)pframe;
+			pframe += 2;
+		}
+
+		llc_sz = rtw_put_snap(pframe, pattrib_queue->ether_type);
+		pframe += llc_sz;
+
+		mem_sz = _rtw_pktfile_read(&pktfile_queue, pframe, pattrib_queue->pktlen);
+		pframe += mem_sz;
+
+		*len = htons(XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz);
+
+		//calc padding
+		padding = 4 - ((ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz) & (4-1));
+		if(padding == 4)
+			padding = 0;
+
+		//_rtw_memset(pframe,0xaa, padding);
+		pframe += padding;
+
+		pattrib->last_txcmdsz += ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz + padding ;
+	}
+
+	//2nd mpdu
+
+	pkt = pxmitframe->pkt;
+	_rtw_open_pktfile(pkt, &pktfile);
+	_rtw_pktfile_read(&pktfile, NULL, pattrib->pkt_hdrlen);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		/* mDA(6), mSA(6), len(2), mctrl */
+		_rtw_memcpy(pframe, pattrib->mda, ETH_ALEN);
+		pframe += ETH_ALEN;
+		_rtw_memcpy(pframe, pattrib->msa, ETH_ALEN);
+		pframe += ETH_ALEN;
+		len = (u16*)pframe;
+		pframe += 2;
+		rtw_mesh_tx_build_mctrl(padapter, pattrib, pframe);
+		pframe += XATTRIB_GET_MCTRL_LEN(pattrib);
+	} else
+#endif
+	{
+		/* 802.3 MAC Header  DA(6)  SA(6)  Len(2) */
+		_rtw_memcpy(pframe, pattrib->dst, ETH_ALEN);
+		pframe += ETH_ALEN;
+		_rtw_memcpy(pframe, pattrib->src, ETH_ALEN);
+		pframe += ETH_ALEN;
+		len = (u16*)pframe;
+		pframe += 2;
+	}
+
+	llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
+	pframe += llc_sz;
+
+	mem_sz = _rtw_pktfile_read(&pktfile, pframe, pattrib->pktlen);
+
+	pframe += mem_sz;
+
+	*len = htons(XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz + mem_sz);
+
+	//the last ampdu has no padding
+	padding = 0;
+
+	pattrib->nr_frags = 1;
+
+	pattrib->last_txcmdsz += ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz + mem_sz + padding +
+		((pattrib->bswenc) ? pattrib->icv_len : 0) ;
+
+	if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
+		_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
+		pframe += pattrib->icv_len;
+	}
+
+	if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
+		RTW_INFO("xmitframe_addmic(padapter, pxmitframe)==_FAIL\n");
+		res = _FAIL;
+		goto exit;
+	}
+
+	xmitframe_swencrypt(padapter, pxmitframe);
+
+	pattrib->vcs_mode = NONE_VCS;
+
+exit:
+	return res;
+}
+#endif /* CONFIG_TX_AMSDU */
+
 /*
 
 This sub-routine will perform all the following:
@@ -2293,7 +2533,7 @@ This sub-routine will perform all the following:
 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. 
+6. apply sw-encrypt, if necessary.
 
 */
 s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe)
@@ -2307,9 +2547,9 @@ s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxm
 	u8 *pframe, *mem_start;
 	u8 hw_hdr_offset;
 
-	//struct sta_info		*psta;
-	//struct sta_priv		*pstapriv = &padapter->stapriv;
-	//struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	/* struct sta_info		*psta; */
+	/* struct sta_priv		*pstapriv = &padapter->stapriv; */
+	/* struct mlme_priv	*pmlmepriv = &padapter->mlmepriv; */
 	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
 
 	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
@@ -2319,54 +2559,52 @@ s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxm
 	s32 bmcst = IS_MCAST(pattrib->ra);
 	s32 res = _SUCCESS;
 
-_func_enter_;
 
-/*
-	if (pattrib->psta)
-	{
-		psta = pattrib->psta;
-	} else
-	{	
-		DBG_871X("%s, call rtw_get_stainfo()\n", __func__);
-		psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-	}
+	/*
+		if (pattrib->psta)
+		{
+			psta = pattrib->psta;
+		} else
+		{
+			RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+			psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
+		}
 
-	if(psta==NULL)
-        {
-		
-		DBG_871X("%s, psta==NUL\n", __func__);
-		return _FAIL;
-	}
+		if(psta==NULL)
+		{
+
+			RTW_INFO("%s, psta==NUL\n", __func__);
+			return _FAIL;
+		}
 
 
-	if(!(psta->state &_FW_LINKED))
-	{
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
-		return _FAIL;
-	}
-*/
-	if (pxmitframe->buf_addr == NULL){
-		DBG_8192C("==> %s buf_addr==NULL \n",__FUNCTION__);
+		if(!(psta->state &_FW_LINKED))
+		{
+			RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
+			return _FAIL;
+		}
+	*/
+	if (pxmitframe->buf_addr == NULL) {
+		RTW_INFO("==> %s buf_addr==NULL\n", __FUNCTION__);
 		return _FAIL;
 	}
 
 	pbuf_start = pxmitframe->buf_addr;
-	
+
 #ifdef CONFIG_USB_TX_AGGREGATION
 	hw_hdr_offset =  TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
 #else
-	#ifdef CONFIG_TX_EARLY_MODE //for SDIO && Tx Agg
+#ifdef CONFIG_TX_EARLY_MODE /* for SDIO && Tx Agg */
 	hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
-	#else
+#else
 	hw_hdr_offset = TXDESC_OFFSET;
-	#endif
+#endif
 #endif
 
 	mem_start = pbuf_start +	hw_hdr_offset;
 
 	if (rtw_make_wlanhdr(padapter, mem_start, pattrib) == _FAIL) {
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n"));
-		DBG_8192C("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n");
+		RTW_INFO("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n");
 		res = _FAIL;
 		goto exit;
 	}
@@ -2375,10 +2613,9 @@ _func_enter_;
 	_rtw_pktfile_read(&pktfile, NULL, pattrib->pkt_hdrlen);
 
 	frg_inx = 0;
-	frg_len = pxmitpriv->frag_len - 4;//2346-4 = 2342
+	frg_len = pxmitpriv->frag_len - 4;/* 2346-4 = 2342 */
 
-	while (1)
-	{
+	while (1) {
 		llc_sz = 0;
 
 		mpdu_len = frg_len;
@@ -2390,48 +2627,42 @@ _func_enter_;
 		pframe += pattrib->hdrlen;
 		mpdu_len -= pattrib->hdrlen;
 
-		//adding icv, if necessary...
-		if (pattrib->iv_len)
-		{
-/*		
-			//if (check_fwstate(pmlmepriv, WIFI_MP_STATE))
-			//	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
-			//else
-			//	psta = rtw_get_stainfo(pstapriv, pattrib->ra);
+		/* adding icv, if necessary... */
+		if (pattrib->iv_len) {
+#if 0
+			/* if (check_fwstate(pmlmepriv, WIFI_MP_STATE)) */
+			/*	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv)); */
+			/* else */
+			/*	psta = rtw_get_stainfo(pstapriv, pattrib->ra); */
 
-			if (psta != NULL)
-			{
-				switch(pattrib->encrypt)
-				{
-					case _WEP40_:
-					case _WEP104_:
-							WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);	
-						break;
-					case _TKIP_:			
-						if(bmcst)
-							TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
-						else
-							TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
-						break;			
-					case _AES_:
-						if(bmcst)
-							AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
-						else
-							AES_IV(pattrib->iv, psta->dot11txpn, 0);
-						break;
+			if (psta != NULL) {
+				switch (pattrib->encrypt) {
+				case _WEP40_:
+				case _WEP104_:
+					WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+					break;
+				case _TKIP_:
+					if (bmcst)
+						TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+					else
+						TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
+					break;
+				case _AES_:
+					if (bmcst)
+						AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
+					else
+						AES_IV(pattrib->iv, psta->dot11txpn, 0);
+					break;
 #ifdef CONFIG_WAPI_SUPPORT
-					case _SMS4_:
-						rtw_wapi_get_iv(padapter,pattrib->ra,pattrib->iv);
-						break;
+				case _SMS4_:
+					rtw_wapi_get_iv(padapter, pattrib->ra, pattrib->iv);
+					break;
 #endif
 				}
 			}
-*/
+#endif
 			_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
 
-			RT_TRACE(_module_rtl871x_xmit_c_, _drv_notice_,
-				 ("rtw_xmitframe_coalesce: 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;
 
@@ -2439,315 +2670,397 @@ _func_enter_;
 		}
 
 		if (frg_inx == 0) {
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter)) {
+				rtw_mesh_tx_build_mctrl(padapter, pattrib, pframe);
+				pframe += XATTRIB_GET_MCTRL_LEN(pattrib);
+				mpdu_len -= XATTRIB_GET_MCTRL_LEN(pattrib);
+			}
+			#endif
+
 			llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
 			pframe += llc_sz;
 			mpdu_len -= llc_sz;
 		}
 
-		if ((pattrib->icv_len >0) && (pattrib->bswenc)) {
+		if ((pattrib->icv_len > 0) && (pattrib->bswenc))
 			mpdu_len -= pattrib->icv_len;
-		}
 
 
 		if (bmcst) {
-			// don't do fragment to broadcat/multicast packets
+			/* don't do fragment to broadcat/multicast packets */
 			mem_sz = _rtw_pktfile_read(&pktfile, pframe, pattrib->pktlen);
-		} else {
+		} else
 			mem_sz = _rtw_pktfile_read(&pktfile, pframe, mpdu_len);
-		}
 
 		pframe += mem_sz;
 
-		if ((pattrib->icv_len >0 )&& (pattrib->bswenc)) {
-			_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len); 
+		if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
+			_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
 			pframe += pattrib->icv_len;
 		}
 
 		frg_inx++;
 
-		if (bmcst || (rtw_endofpktfile(&pktfile) == _TRUE))
-		{
+		if (bmcst || (rtw_endofpktfile(&pktfile) == _TRUE)) {
 			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;
-			
+			pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len +
+				((pattrib->nr_frags == 1) ? (XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz) : 0) +
+				((pattrib->bswenc) ? pattrib->icv_len : 0) + mem_sz;
+
 			ClearMFrag(mem_start);
 
 			break;
-		} else {
-			RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("%s: There're still something in packet!\n", __FUNCTION__));
 		}
 
 		addr = (SIZE_PTR)(pframe);
 
 		mem_start = (unsigned char *)RND4(addr) + hw_hdr_offset;
-		_rtw_memcpy(mem_start, pbuf_start + hw_hdr_offset, pattrib->hdrlen);	
-		
+		_rtw_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_8192C("xmitframe_addmic(padapter, pxmitframe)==_FAIL\n");
+	if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
+		RTW_INFO("xmitframe_addmic(padapter, pxmitframe)==_FAIL\n");
 		res = _FAIL;
 		goto exit;
 	}
 
 	xmitframe_swencrypt(padapter, pxmitframe);
 
-	if(bmcst == _FALSE)
+	if (bmcst == _FALSE)
 		update_attrib_vcs_info(padapter, pxmitframe);
 	else
 		pattrib->vcs_mode = NONE_VCS;
 
-exit:	
-	
-_func_exit_;	
+exit:
+
 
 	return res;
 }
 
-#ifdef CONFIG_IEEE80211W
-//broadcast or multicast management pkt use BIP, unicast management pkt use CCMP encryption
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+/*
+ * CCMP encryption for unicast robust mgmt frame and broadcast group privicy action
+ * BIP for broadcast robust mgmt frame
+ */
 s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe)
 {
+#define DBG_MGMT_XMIT_COALESEC_DUMP 0
+#define DBG_MGMT_XMIT_BIP_DUMP 0
+#define DBG_MGMT_XMIT_ENC_DUMP 0
+
 	struct pkt_file pktfile;
 	s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
 	SIZE_PTR addr;
-	u8 *pframe, *mem_start = NULL, *tmp_buf=NULL;
+	u8 *pframe, *mem_start = NULL, *tmp_buf = NULL;
 	u8 hw_hdr_offset, subtype ;
+	u8 category = 0xFF;
 	struct sta_info		*psta = NULL;
 	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
 	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
 	u8 *pbuf_start;
 	s32 bmcst = IS_MCAST(pattrib->ra);
 	s32 res = _FAIL;
-	u8 *BIP_AAD=NULL;
-	u8 *MGMT_body=NULL;
-	
+	u8 *BIP_AAD = NULL;
+	u8 *MGMT_body = NULL;
+
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u8 MME[_MME_IE_LENGTH_];
-	
+
 	_irqL irqL;
 	u32	ori_len;
+	union pn48 *pn = NULL;
+	u8 kid;
+
+	if (pxmitframe->buf_addr == NULL) {
+		RTW_WARN(FUNC_ADPT_FMT" pxmitframe->buf_addr\n"
+			, FUNC_ADPT_ARG(padapter));
+		return _FAIL;
+	}
+
 	mem_start = pframe = (u8 *)(pxmitframe->buf_addr) + TXDESC_OFFSET;
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-	
-_func_enter_;
-	ori_len = BIP_AAD_SIZE+pattrib->pktlen;
+	subtype = get_frame_sub_type(pframe); /* bit(7)~bit(2) */
+
+	/* check if robust mgmt frame */
+	if (subtype != WIFI_DEAUTH && subtype != WIFI_DISASSOC && subtype != WIFI_ACTION)
+		return _SUCCESS;
+	if (subtype == WIFI_ACTION) {
+		category = *(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+		if (CATEGORY_IS_NON_ROBUST(category))
+			return _SUCCESS;
+	}
+	if (!bmcst) {
+		if (pattrib->psta)
+			psta = pattrib->psta;
+		else
+			pattrib->psta = psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
+		if (psta == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast sta == NULL\n", FUNC_ADPT_ARG(padapter));
+			return _FAIL;
+		}
+		if (!(psta->flags & WLAN_STA_MFP)) {
+			/* peer is not MFP capable, no need to encrypt */
+			return _SUCCESS;
+		}
+		if (psta->bpairwise_key_installed != _TRUE) {
+			RTW_INFO(FUNC_ADPT_FMT" PTK is not installed\n"
+				, FUNC_ADPT_ARG(padapter));
+			return _FAIL;
+		}
+	}
+
+	ori_len = BIP_AAD_SIZE + pattrib->pktlen;
 	tmp_buf = BIP_AAD = rtw_zmalloc(ori_len);
-	subtype = GetFrameSubType(pframe); //bit(7)~bit(2)
-	
-	if(BIP_AAD == NULL)
+	if (BIP_AAD == NULL)
 		return _FAIL;
-			
+
 	_enter_critical_bh(&padapter->security_key_mutex, &irqL);
-	
-	
-	//IGTK key is not install, it may not support 802.11w
-	if(padapter->securitypriv.binstallBIPkey != _TRUE)
-	{
-		DBG_871X("no instll BIP key\n");
-		goto xmitframe_coalesce_success;
-	}
-	//station mode doesn't need TX BIP, just ready the code
-	if(bmcst)
-	{
-		int frame_body_len;
-		u8 mic[16];
-		
-		_rtw_memset(MME, 0, _MME_IE_LENGTH_);
-				
-		//other types doesn't need the BIP
-		if(GetFrameSubType(pframe) != WIFI_DEAUTH && GetFrameSubType(pframe) != WIFI_DISASSOC)
-			goto xmitframe_coalesce_fail;
-		
-		MGMT_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
-		pframe += pattrib->pktlen;
-		
-		//octent 0 and 1 is key index ,BIP keyid is 4 or 5, LSB only need octent 0
-		MME[0]=padapter->securitypriv.dot11wBIPKeyid;
-		//copy packet number
-		_rtw_memcpy(&MME[2], &pmlmeext->mgnt_80211w_IPN, 6);
-		//increase the packet number
-		pmlmeext->mgnt_80211w_IPN++;
-		
-		//add MME IE with MIC all zero, MME string doesn't include element id and length
-		pframe = rtw_set_ie(pframe, _MME_IE_ , 16 , MME, &(pattrib->pktlen));
-		pattrib->last_txcmdsz = pattrib->pktlen;
-		// total frame length - header length
-		frame_body_len = pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr);
-		
-		//conscruct AAD, copy frame control field
-		_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
-		ClearRetry(BIP_AAD);
-		ClearPwrMgt(BIP_AAD);
-		ClearMData(BIP_AAD);
-		//conscruct AAD, copy address 1 to address 3
-		_rtw_memcpy(BIP_AAD+2, pwlanhdr->addr1, 18);
-		//copy management fram body
-		_rtw_memcpy(BIP_AAD+BIP_AAD_SIZE, MGMT_body, frame_body_len);
-		/*//dump total packet include MME with zero MIC
-		{
-			int i;
-			printk("Total packet: ");
-			for(i=0; i < BIP_AAD_SIZE+frame_body_len; i++)
-				printk(" %02x ", BIP_AAD[i]);
-			printk("\n");
-		}*/
-		//calculate mic
-		if(omac1_aes_128(padapter->securitypriv.dot11wBIPKey[padapter->securitypriv.dot11wBIPKeyid].skey
-			, BIP_AAD, BIP_AAD_SIZE+frame_body_len, mic))
-			goto xmitframe_coalesce_fail;
-		
-		/*//dump calculated mic result
-		{
-			int i;
-			printk("Calculated mic result: ");
-			for(i=0; i<16; i++)
-				printk(" %02x ", mic[i]);
-			printk("\n");
-		}*/
-		//copy right BIP mic value, total is 128bits, we use the 0~63 bits
-		_rtw_memcpy(pframe-8, mic, 8);
-		/*/dump all packet after mic ok
-		{
-			int pp;
-			printk("pattrib->pktlen = %d \n", pattrib->pktlen);
-			for(pp=0;pp< pattrib->pktlen; pp++)
-				printk(" %02x ", mem_start[pp]);
-			printk("\n");
-		}*/
-	}
-	else //unicast mgmt frame TX
-	{
-		//start to encrypt mgmt frame
-		if(subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC ||
-			subtype == WIFI_REASSOCREQ || subtype == WIFI_ACTION)
-		{
+
+	if (bmcst) {
+		if (subtype == WIFI_ACTION && CATEGORY_IS_GROUP_PRIVACY(category)) {
+			/* broadcast group privacy action frame */
+			#if DBG_MGMT_XMIT_COALESEC_DUMP
+			RTW_INFO(FUNC_ADPT_FMT" broadcast gp action(%u)\n"
+				, FUNC_ADPT_ARG(padapter), category);
+			#endif
+
 			if (pattrib->psta)
 				psta = pattrib->psta;
 			else
-			{
-				psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-			}
-		
-			if(psta==NULL)
-			{
-				
-				DBG_871X("%s, psta==NUL\n", __func__);
+				pattrib->psta = psta = rtw_get_bcmc_stainfo(padapter);
+			if (psta == NULL) {
+				RTW_INFO(FUNC_ADPT_FMT" broadcast sta == NULL\n"
+					, FUNC_ADPT_ARG(padapter));
 				goto xmitframe_coalesce_fail;
 			}
-		
-			if (pxmitframe->buf_addr == NULL) {
-				DBG_871X("%s, pxmitframe->buf_addr\n", __func__);
+			if (padapter->securitypriv.binstallGrpkey != _TRUE) {
+				RTW_INFO(FUNC_ADPT_FMT" GTK is not installed\n"
+					, FUNC_ADPT_ARG(padapter));
 				goto xmitframe_coalesce_fail;
 			}
-			
-			//DBG_871X("%s, action frame category=%d \n", __func__, pframe[WLAN_HDR_A3_LEN]);
-			//according 802.11-2012 standard, these five types are not robust types
-			if(subtype == WIFI_ACTION && 
-			(pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_PUBLIC ||
-			pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_HT ||
-			pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_UNPROTECTED_WNM ||
-			pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_SELF_PROTECTED  ||
-			pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_P2P))
-				goto xmitframe_coalesce_fail;
-			//before encrypt dump the management packet content
-			/*{
-				int i;
-				printk("Management pkt: ");
-				for(i=0; i<pattrib->pktlen; i++)
-				printk(" %02x ", pframe[i]);
-				printk("=======\n");
-			}*/
-			if(pattrib->encrypt>0)
-				_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);
-			
-			/* To use wrong key */
-			if (pattrib->key_type == IEEE80211W_WRONG_KEY) {
-				DBG_871X("use wrong key\n");
-				pattrib->dot118021x_UncstKey.skey[0] = 0xff;
-			}
-			
-			//bakeup original management packet
-			_rtw_memcpy(tmp_buf, pframe, pattrib->pktlen);
-			//move to data portion
-			pframe += pattrib->hdrlen;
-			
-			//802.11w unicast management packet must be _AES_
-			pattrib->iv_len = 8;
-			//it's MIC of AES
-			pattrib->icv_len = 8;
-			
-			switch(pattrib->encrypt)
-			{
-				case _AES_:
-						//set AES IV header
-						AES_IV(pattrib->iv, psta->dot11wtxpn, 0);
-					break;
-				default:
-					goto xmitframe_coalesce_fail;
+
+			pn = &psta->dot11txpn;
+			kid = padapter->securitypriv.dot118021XGrpKeyid;
+		} else {
+			#ifdef CONFIG_IEEE80211W
+			/* broadcast robust mgmt frame, using BIP */
+			int frame_body_len;
+			u8 mic[16];
+
+			/* IGTK key is not install ex: mesh MFP without IGTK */
+			if (SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) != _TRUE)
+				goto xmitframe_coalesce_success;
+
+			#if DBG_MGMT_XMIT_COALESEC_DUMP
+			if (subtype == WIFI_DEAUTH)
+				RTW_INFO(FUNC_ADPT_FMT" braodcast deauth\n", FUNC_ADPT_ARG(padapter));
+			else if (subtype == WIFI_DISASSOC)
+				RTW_INFO(FUNC_ADPT_FMT" braodcast disassoc\n", FUNC_ADPT_ARG(padapter));
+			else if (subtype == WIFI_ACTION) {
+				RTW_INFO(FUNC_ADPT_FMT" braodcast action(%u)\n"
+					, FUNC_ADPT_ARG(padapter), category);
 			}
-			//insert iv header into management frame
-			_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
-			pframe += pattrib->iv_len;
-			//copy mgmt data portion after CCMP header
-			_rtw_memcpy(pframe, tmp_buf+pattrib->hdrlen, pattrib->pktlen-pattrib->hdrlen);
-			//move pframe to end of mgmt pkt
-			pframe += pattrib->pktlen-pattrib->hdrlen;
-			//add 8 bytes CCMP IV header to length
-			pattrib->pktlen += pattrib->iv_len;
-			/*//dump management packet include AES IV header
+			#endif
+
+			_rtw_memset(MME, 0, _MME_IE_LENGTH_);
+
+			MGMT_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
+			pframe += pattrib->pktlen;
+
+			/* octent 0 and 1 is key index ,BIP keyid is 4 or 5, LSB only need octent 0 */
+			MME[0] = padapter->securitypriv.dot11wBIPKeyid;
+			/* increase PN and apply to packet */
+			padapter->securitypriv.dot11wBIPtxpn.val++;
+			RTW_PUT_LE64(&MME[2], padapter->securitypriv.dot11wBIPtxpn.val);
+
+			/* add MME IE with MIC all zero, MME string doesn't include element id and length */
+			pframe = rtw_set_ie(pframe, _MME_IE_ , 16 , MME, &(pattrib->pktlen));
+			pattrib->last_txcmdsz = pattrib->pktlen;
+			/* total frame length - header length */
+			frame_body_len = pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr);
+
+			/* conscruct AAD, copy frame control field */
+			_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
+			ClearRetry(BIP_AAD);
+			ClearPwrMgt(BIP_AAD);
+			ClearMData(BIP_AAD);
+			/* conscruct AAD, copy address 1 to address 3 */
+			_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
+			/* copy management fram body */
+			_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, MGMT_body, frame_body_len);
+
+			#if DBG_MGMT_XMIT_BIP_DUMP
+			/* dump total packet include MME with zero MIC */
 			{
 				int i;
-				printk("Management pkt + IV: ");
-				//for(i=0; i<pattrib->pktlen; i++)
-				//printk(" %02x ", mem_start[i]);
-				printk("@@@@@@@@@@@@@\n");
-			}*/
-			
-			if ((pattrib->icv_len >0 )&& (pattrib->bswenc)) {
-				_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len); 
-				pframe += pattrib->icv_len;
+				printk("Total packet: ");
+				for (i = 0; i < BIP_AAD_SIZE + frame_body_len; i++)
+					printk(" %02x ", BIP_AAD[i]);
+				printk("\n");
 			}
-			//add 8 bytes MIC
-			pattrib->pktlen += pattrib->icv_len;
-			//set final tx command size
-			pattrib->last_txcmdsz = pattrib->pktlen;
-	
-			//set protected bit must be beofre SW encrypt
-			SetPrivacy(mem_start);
-			/*//dump management packet include AES header
+			#endif
+
+			/* calculate mic */
+			if (omac1_aes_128(padapter->securitypriv.dot11wBIPKey[padapter->securitypriv.dot11wBIPKeyid].skey
+				  , BIP_AAD, BIP_AAD_SIZE + frame_body_len, mic))
+				goto xmitframe_coalesce_fail;
+
+			#if DBG_MGMT_XMIT_BIP_DUMP
+			/* dump calculated mic result */
 			{
 				int i;
-				printk("prepare to enc Management pkt + IV: ");
-				for(i=0; i<pattrib->pktlen; i++)
-				printk(" %02x ", mem_start[i]);
-				printk("@@@@@@@@@@@@@\n");
-			}*/
-			//software encrypt
-			xmitframe_swencrypt(padapter, pxmitframe);
+				printk("Calculated mic result: ");
+				for (i = 0; i < 16; i++)
+					printk(" %02x ", mic[i]);
+				printk("\n");
+			}
+			#endif
+
+			/* copy right BIP mic value, total is 128bits, we use the 0~63 bits */
+			_rtw_memcpy(pframe - 8, mic, 8);
+
+			#if DBG_MGMT_XMIT_BIP_DUMP
+			/*dump all packet after mic ok */
+			{
+				int pp;
+				printk("pattrib->pktlen = %d\n", pattrib->pktlen);
+				for(pp=0;pp< pattrib->pktlen; pp++)
+					printk(" %02x ", mem_start[pp]);
+				printk("\n");
+			}
+			#endif
+
+			#endif /* CONFIG_IEEE80211W */
+
+			goto xmitframe_coalesce_success;
+		}
+	}
+	else {
+		/* unicast robust mgmt frame */
+		#if DBG_MGMT_XMIT_COALESEC_DUMP
+		if (subtype == WIFI_DEAUTH) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast deauth to "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(pattrib->ra));
+		} else if (subtype == WIFI_DISASSOC) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast disassoc to "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(pattrib->ra));
+		} else if (subtype == WIFI_ACTION) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast action(%u) to "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), category, MAC_ARG(pattrib->ra));
+		}
+		#endif
+
+		_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);
+
+		/* To use wrong key */
+		if (pattrib->key_type == IEEE80211W_WRONG_KEY) {
+			RTW_INFO("use wrong key\n");
+			pattrib->dot118021x_UncstKey.skey[0] = 0xff;
 		}
+
+		pn = &psta->dot11txpn;
+		kid = 0;
+	}
+
+	#if DBG_MGMT_XMIT_ENC_DUMP
+	/* before encrypt dump the management packet content */
+	{
+		int i;
+		printk("Management pkt: ");
+		for(i=0; i<pattrib->pktlen; i++)
+		printk(" %02x ", pframe[i]);
+		printk("=======\n");
+	}
+	#endif
+
+	/* bakeup original management packet */
+	_rtw_memcpy(tmp_buf, pframe, pattrib->pktlen);
+	/* move to data portion */
+	pframe += pattrib->hdrlen;
+
+	/* 802.11w encrypted management packet must be _AES_ */
+	if (pattrib->key_type != IEEE80211W_NO_KEY) {
+		pattrib->encrypt = _AES_;
+		pattrib->bswenc = _TRUE;
+	}
+
+	pattrib->iv_len = 8;
+	/* it's MIC of AES */
+	pattrib->icv_len = 8;
+
+	switch (pattrib->encrypt) {
+	case _AES_:
+		/* set AES IV header */
+		AES_IV(pattrib->iv, (*pn), kid);
+		break;
+	default:
+		goto xmitframe_coalesce_fail;
+	}
+
+	/* insert iv header into management frame */
+	_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
+	pframe += pattrib->iv_len;
+	/* copy mgmt data portion after CCMP header */
+	_rtw_memcpy(pframe, tmp_buf + pattrib->hdrlen, pattrib->pktlen - pattrib->hdrlen);
+	/* move pframe to end of mgmt pkt */
+	pframe += pattrib->pktlen - pattrib->hdrlen;
+	/* add 8 bytes CCMP IV header to length */
+	pattrib->pktlen += pattrib->iv_len;
+
+	#if DBG_MGMT_XMIT_ENC_DUMP
+	/* dump management packet include AES IV header */
+	{
+		int i;
+		printk("Management pkt + IV: ");
+		/* for(i=0; i<pattrib->pktlen; i++) */
+
+		printk("@@@@@@@@@@@@@\n");
+	}
+	#endif
+
+	if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
+		_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
+		pframe += pattrib->icv_len;
+	}
+	/* add 8 bytes MIC */
+	pattrib->pktlen += pattrib->icv_len;
+	/* set final tx command size */
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	/* set protected bit must be beofre SW encrypt */
+	SetPrivacy(mem_start);
+
+	#if DBG_MGMT_XMIT_ENC_DUMP
+	/* dump management packet include AES header */
+	{
+		int i;
+		printk("prepare to enc Management pkt + IV: ");
+		for (i = 0; i < pattrib->pktlen; i++)
+			printk(" %02x ", mem_start[i]);
+		printk("@@@@@@@@@@@@@\n");
 	}
+	#endif
+
+	/* software encrypt */
+	xmitframe_swencrypt(padapter, pxmitframe);
 
 xmitframe_coalesce_success:
 	_exit_critical_bh(&padapter->security_key_mutex, &irqL);
 	rtw_mfree(BIP_AAD, ori_len);
-_func_exit_;
 	return _SUCCESS;
-	
+
 xmitframe_coalesce_fail:
 	_exit_critical_bh(&padapter->security_key_mutex, &irqL);
 	rtw_mfree(BIP_AAD, ori_len);
-_func_exit_;
 
 	return _FAIL;
 }
-#endif //CONFIG_IEEE80211W
+#endif /* defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH) */
 
 /* Logical Link Control(LLC) SubNetwork Attachment Point(SNAP) header
  * IEEE LLC/SNAP header contains 8 octets
@@ -2761,7 +3074,6 @@ s32 rtw_put_snap(u8 *data, u16 h_proto)
 	struct ieee80211_snap_hdr *snap;
 	u8 *oui;
 
-_func_enter_;
 
 	snap = (struct ieee80211_snap_hdr *)data;
 	snap->dsap = 0xaa;
@@ -2772,14 +3084,13 @@ _func_enter_;
 		oui = P802_1H_OUI;
 	else
 		oui = RFC1042_OUI;
-	
+
 	snap->oui[0] = oui[0];
 	snap->oui[1] = oui[1];
 	snap->oui[2] = oui[2];
 
 	*(u16 *)(data + SNAP_SIZE) = htons(h_proto);
 
-_func_exit_;
 
 	return SNAP_SIZE + sizeof(u16);
 }
@@ -2792,44 +3103,36 @@ void rtw_update_protection(_adapter *padapter, u8 *ie, uint ie_len)
 	sint	 erp_len;
 	struct	xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	struct	registry_priv *pregistrypriv = &padapter->registrypriv;
-	
-_func_enter_;
-	
-	switch(pxmitpriv->vcs_setting)
-	{
-		case DISABLE_VCS:
+
+
+	switch (pxmitpriv->vcs_setting) {
+	case DISABLE_VCS:
+		pxmitpriv->vcs = NONE_VCS;
+		break;
+
+	case ENABLE_VCS:
+		break;
+
+	case AUTO_VCS:
+	default:
+		perp = rtw_get_ie(ie, _ERPINFO_IE_, &erp_len, ie_len);
+		if (perp == NULL)
 			pxmitpriv->vcs = NONE_VCS;
-			break;
-	
-		case ENABLE_VCS:
-			break;
-	
-		case AUTO_VCS:
-		default:
-			perp = rtw_get_ie(ie, _ERPINFO_IE_, &erp_len, ie_len);
-			if(perp == NULL)
-			{
-				pxmitpriv->vcs = NONE_VCS;
-			}
-			else
-			{
-				protection = (*(perp + 2)) & BIT(1);
-				if (protection)
-				{
-					if(pregistrypriv->vcs_type == RTS_CTS)
-						pxmitpriv->vcs = RTS_CTS;
-					else
-						pxmitpriv->vcs = CTS_TO_SELF;
-				}
+		else {
+			protection = (*(perp + 2)) & BIT(1);
+			if (protection) {
+				if (pregistrypriv->vcs_type == RTS_CTS)
+					pxmitpriv->vcs = RTS_CTS;
 				else
-					pxmitpriv->vcs = NONE_VCS;
-			}
+					pxmitpriv->vcs = CTS_TO_SELF;
+			} else
+				pxmitpriv->vcs = NONE_VCS;
+		}
+
+		break;
 
-			break;			
-	
 	}
 
-_func_exit_;
 
 }
 
@@ -2841,8 +3144,7 @@ void rtw_count_tx_stats(PADAPTER padapter, struct xmit_frame *pxmitframe, int sz
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	u8	pkt_num = 1;
 
-	if ((pxmitframe->frame_tag&0x0f) == DATA_FRAMETAG)
-	{
+	if ((pxmitframe->frame_tag & 0x0f) == DATA_FRAMETAG) {
 #if defined(CONFIG_USB_TX_AGGREGATION) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 		pkt_num = pxmitframe->agg_num;
 #endif
@@ -2853,27 +3155,18 @@ void rtw_count_tx_stats(PADAPTER padapter, struct xmit_frame *pxmitframe, int sz
 		pxmitpriv->tx_bytes += sz;
 
 		psta = pxmitframe->attrib.psta;
-		if (psta)
-		{
+		if (psta) {
 			pstats = &psta->sta_stats;
 
 			pstats->tx_pkts += pkt_num;
 
 			pstats->tx_bytes += sz;
-#ifdef CONFIG_TDLS
-			if(pxmitframe->attrib.ptdls_sta != NULL)
-			{
-				pstats = &(pxmitframe->attrib.ptdls_sta->sta_stats);
-				pstats->tx_pkts += pkt_num;
-				pstats->tx_bytes += sz;
-			}
-#endif //CONFIG_TDLS
 		}
-		
+
 #ifdef CONFIG_CHECK_LEAVE_LPS
-		//traffic_check_for_leave_lps(padapter, _TRUE);
-#endif //CONFIG_LPS
-		
+		/* traffic_check_for_leave_lps(padapter, _TRUE); */
+#endif /* CONFIG_LPS */
+
 	}
 }
 
@@ -2882,7 +3175,6 @@ static struct xmit_buf *__rtw_alloc_cmd_xmitbuf(struct xmit_priv *pxmitpriv,
 {
 	struct xmit_buf *pxmitbuf =  NULL;
 
-_func_enter_;
 
 	pxmitbuf = &pxmitpriv->pcmd_xmitbuf[buf_type];
 	if (pxmitbuf !=  NULL) {
@@ -2896,20 +3188,22 @@ _func_enter_;
 #endif
 #ifdef CONFIG_PCI_HCI
 		pxmitbuf->len = 0;
+#ifdef CONFIG_TRX_BD_ARCH
+		/*pxmitbuf->buf_desc = NULL;*/
+#else
 		pxmitbuf->desc = NULL;
+#endif
 #endif
 
 		if (pxmitbuf->sctx) {
-			DBG_871X("%s pxmitbuf->sctx is not NULL\n", __func__);
+			RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
 			rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
 		}
-	} else {
-		DBG_871X("%s fail, no xmitbuf available !!!\n", __func__);
-	}
+	} else
+		RTW_INFO("%s fail, no xmitbuf available !!!\n", __func__);
 
 exit:
 
-_func_exit_;
 
 	return pxmitbuf;
 }
@@ -2920,14 +3214,15 @@ struct xmit_frame *__rtw_alloc_cmdxmitframe(struct xmit_priv *pxmitpriv,
 	struct xmit_frame		*pcmdframe;
 	struct xmit_buf		*pxmitbuf;
 
-	if ((pcmdframe = rtw_alloc_xmitframe(pxmitpriv)) == NULL)
-	{
-		DBG_871X("%s, alloc xmitframe fail\n", __FUNCTION__);
+	pcmdframe = rtw_alloc_xmitframe(pxmitpriv);
+	if (pcmdframe == NULL) {
+		RTW_INFO("%s, alloc xmitframe fail\n", __FUNCTION__);
 		return NULL;
 	}
 
-	if ((pxmitbuf = __rtw_alloc_cmd_xmitbuf(pxmitpriv, buf_type)) == NULL) {
-		DBG_871X("%s, alloc xmitbuf fail\n", __FUNCTION__);
+	pxmitbuf = __rtw_alloc_cmd_xmitbuf(pxmitpriv, buf_type);
+	if (pxmitbuf == NULL) {
+		RTW_INFO("%s, alloc xmitbuf fail\n", __FUNCTION__);
 		rtw_free_xmitframe(pxmitpriv, pcmdframe);
 		return NULL;
 	}
@@ -2938,6 +3233,9 @@ struct xmit_frame *__rtw_alloc_cmdxmitframe(struct xmit_priv *pxmitpriv,
 
 	pcmdframe->buf_addr = pxmitbuf->pbuf;
 
+	/* initial memory to zero */
+	_rtw_memset(pcmdframe->buf_addr, 0, MAX_CMDBUF_SZ);
+
 	pxmitbuf->priv_data = pcmdframe;
 
 	return pcmdframe;
@@ -2951,13 +3249,12 @@ struct xmit_buf *rtw_alloc_xmitbuf_ext(struct xmit_priv *pxmitpriv)
 	_list *plist, *phead;
 	_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
 
-_func_enter_;
 
 	_enter_critical(&pfree_queue->lock, &irqL);
 
-	if(_rtw_queue_empty(pfree_queue) == _TRUE) {
+	if (_rtw_queue_empty(pfree_queue) == _TRUE)
 		pxmitbuf = NULL;
-	} else {
+	else {
 
 		phead = get_list_head(pfree_queue);
 
@@ -2968,14 +3265,13 @@ _func_enter_;
 		rtw_list_delete(&(pxmitbuf->list));
 	}
 
-	if (pxmitbuf !=  NULL)
-	{
+	if (pxmitbuf !=  NULL) {
 		pxmitpriv->free_xmit_extbuf_cnt--;
-		#ifdef DBG_XMIT_BUF_EXT
-		DBG_871X("DBG_XMIT_BUF_EXT ALLOC no=%d,  free_xmit_extbuf_cnt=%d\n",pxmitbuf->no, pxmitpriv->free_xmit_extbuf_cnt);
-		#endif
-		
-	
+#ifdef DBG_XMIT_BUF_EXT
+		RTW_INFO("DBG_XMIT_BUF_EXT ALLOC no=%d,  free_xmit_extbuf_cnt=%d\n", pxmitbuf->no, pxmitpriv->free_xmit_extbuf_cnt);
+#endif
+
+
 		pxmitbuf->priv_data = NULL;
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
@@ -2985,11 +3281,15 @@ _func_enter_;
 #endif
 #ifdef CONFIG_PCI_HCI
 		pxmitbuf->len = 0;
+#ifdef CONFIG_TRX_BD_ARCH
+		/*pxmitbuf->buf_desc = NULL;*/
+#else
 		pxmitbuf->desc = NULL;
+#endif
 #endif
 
 		if (pxmitbuf->sctx) {
-			DBG_871X("%s pxmitbuf->sctx is not NULL\n", __func__);
+			RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
 			rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
 		}
 
@@ -2997,7 +3297,6 @@ _func_enter_;
 
 	_exit_critical(&pfree_queue->lock, &irqL);
 
-_func_exit_;
 
 	return pxmitbuf;
 }
@@ -3007,12 +3306,9 @@ s32 rtw_free_xmitbuf_ext(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
 	_irqL irqL;
 	_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
 
-_func_enter_;
 
-	if(pxmitbuf==NULL)
-	{
+	if (pxmitbuf == NULL)
 		return _FAIL;
-	}
 
 	_enter_critical(&pfree_queue->lock, &irqL);
 
@@ -3020,16 +3316,15 @@ _func_enter_;
 
 	rtw_list_insert_tail(&(pxmitbuf->list), get_list_head(pfree_queue));
 	pxmitpriv->free_xmit_extbuf_cnt++;
-	#ifdef DBG_XMIT_BUF_EXT
-	DBG_871X("DBG_XMIT_BUF_EXT FREE no=%d, free_xmit_extbuf_cnt=%d\n",pxmitbuf->no ,pxmitpriv->free_xmit_extbuf_cnt);
-	#endif
+#ifdef DBG_XMIT_BUF_EXT
+	RTW_INFO("DBG_XMIT_BUF_EXT FREE no=%d, free_xmit_extbuf_cnt=%d\n", pxmitbuf->no , pxmitpriv->free_xmit_extbuf_cnt);
+#endif
 
 	_exit_critical(&pfree_queue->lock, &irqL);
 
-_func_exit_;
 
 	return _SUCCESS;
-} 
+}
 
 struct xmit_buf *rtw_alloc_xmitbuf(struct xmit_priv *pxmitpriv)
 {
@@ -3038,15 +3333,14 @@ struct xmit_buf *rtw_alloc_xmitbuf(struct xmit_priv *pxmitpriv)
 	_list *plist, *phead;
 	_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
 
-_func_enter_;
 
-	//DBG_871X("+rtw_alloc_xmitbuf\n");
+	/* RTW_INFO("+rtw_alloc_xmitbuf\n"); */
 
 	_enter_critical(&pfree_xmitbuf_queue->lock, &irqL);
 
-	if(_rtw_queue_empty(pfree_xmitbuf_queue) == _TRUE) {
+	if (_rtw_queue_empty(pfree_xmitbuf_queue) == _TRUE)
 		pxmitbuf = NULL;
-	} else {
+	else {
 
 		phead = get_list_head(pfree_xmitbuf_queue);
 
@@ -3057,13 +3351,12 @@ _func_enter_;
 		rtw_list_delete(&(pxmitbuf->list));
 	}
 
-	if (pxmitbuf !=  NULL)
-	{
+	if (pxmitbuf !=  NULL) {
 		pxmitpriv->free_xmitbuf_cnt--;
-		#ifdef DBG_XMIT_BUF
-		DBG_871X("DBG_XMIT_BUF ALLOC no=%d,  free_xmitbuf_cnt=%d\n",pxmitbuf->no, pxmitpriv->free_xmitbuf_cnt);
-		#endif
-		//DBG_871X("alloc, free_xmitbuf_cnt=%d\n", pxmitpriv->free_xmitbuf_cnt);
+#ifdef DBG_XMIT_BUF
+		RTW_INFO("DBG_XMIT_BUF ALLOC no=%d,  free_xmitbuf_cnt=%d\n", pxmitbuf->no, pxmitpriv->free_xmitbuf_cnt);
+#endif
+		/* RTW_INFO("alloc, free_xmitbuf_cnt=%d\n", pxmitpriv->free_xmitbuf_cnt); */
 
 		pxmitbuf->priv_data = NULL;
 
@@ -3075,24 +3368,25 @@ _func_enter_;
 #endif
 #ifdef CONFIG_PCI_HCI
 		pxmitbuf->len = 0;
+#ifdef CONFIG_TRX_BD_ARCH
+		/*pxmitbuf->buf_desc = NULL;*/
+#else
 		pxmitbuf->desc = NULL;
+#endif
 #endif
 
 		if (pxmitbuf->sctx) {
-			DBG_871X("%s pxmitbuf->sctx is not NULL\n", __func__);
+			RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
 			rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
 		}
 	}
-	#ifdef DBG_XMIT_BUF
+#ifdef DBG_XMIT_BUF
 	else
-	{
-		DBG_871X("DBG_XMIT_BUF rtw_alloc_xmitbuf return NULL\n");
-	}
-	#endif
+		RTW_INFO("DBG_XMIT_BUF rtw_alloc_xmitbuf return NULL\n");
+#endif
 
 	_exit_critical(&pfree_xmitbuf_queue->lock, &irqL);
 
-_func_exit_;
 
 	return pxmitbuf;
 }
@@ -3102,71 +3396,63 @@ s32 rtw_free_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
 	_irqL irqL;
 	_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
 
-_func_enter_;
 
-	//DBG_871X("+rtw_free_xmitbuf\n");
+	/* RTW_INFO("+rtw_free_xmitbuf\n"); */
 
-	if(pxmitbuf==NULL)
-	{
+	if (pxmitbuf == NULL)
 		return _FAIL;
-	}
 
 	if (pxmitbuf->sctx) {
-		DBG_871X("%s pxmitbuf->sctx is not NULL\n", __func__);
+		RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
 		rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_FREE);
 	}
 
-	if(pxmitbuf->buf_tag == XMITBUF_CMD) {
-	}
-	else if(pxmitbuf->buf_tag == XMITBUF_MGNT) {
+	if (pxmitbuf->buf_tag == XMITBUF_CMD) {
+	} else if (pxmitbuf->buf_tag == XMITBUF_MGNT)
 		rtw_free_xmitbuf_ext(pxmitpriv, pxmitbuf);
-	}
-	else
-	{
+	else {
 		_enter_critical(&pfree_xmitbuf_queue->lock, &irqL);
 
-		rtw_list_delete(&pxmitbuf->list);	
+		rtw_list_delete(&pxmitbuf->list);
 
 		rtw_list_insert_tail(&(pxmitbuf->list), get_list_head(pfree_xmitbuf_queue));
 
 		pxmitpriv->free_xmitbuf_cnt++;
-		//DBG_871X("FREE, free_xmitbuf_cnt=%d\n", pxmitpriv->free_xmitbuf_cnt);
-		#ifdef DBG_XMIT_BUF
-		DBG_871X("DBG_XMIT_BUF FREE no=%d, free_xmitbuf_cnt=%d\n",pxmitbuf->no ,pxmitpriv->free_xmitbuf_cnt);
-		#endif
+		/* RTW_INFO("FREE, free_xmitbuf_cnt=%d\n", pxmitpriv->free_xmitbuf_cnt); */
+#ifdef DBG_XMIT_BUF
+		RTW_INFO("DBG_XMIT_BUF FREE no=%d, free_xmitbuf_cnt=%d\n", pxmitbuf->no , pxmitpriv->free_xmitbuf_cnt);
+#endif
 		_exit_critical(&pfree_xmitbuf_queue->lock, &irqL);
 	}
 
-_func_exit_;	 
 
-	return _SUCCESS;	
-} 
+	return _SUCCESS;
+}
 
 void rtw_init_xmitframe(struct xmit_frame *pxframe)
 {
-	if (pxframe !=  NULL)//default value setting
-	{
+	if (pxframe !=  NULL) { /* default value setting */
 		pxframe->buf_addr = NULL;
 		pxframe->pxmitbuf = NULL;
 
 		_rtw_memset(&pxframe->attrib, 0, sizeof(struct pkt_attrib));
-		//pxframe->attrib.psta = NULL;
+		/* pxframe->attrib.psta = NULL; */
 
 		pxframe->frame_tag = DATA_FRAMETAG;
 
 #ifdef CONFIG_USB_HCI
 		pxframe->pkt = NULL;
 #ifdef USB_PACKET_OFFSET_SZ
-		pxframe->pkt_offset = (PACKET_OFFSET_SZ/8);
+		pxframe->pkt_offset = (PACKET_OFFSET_SZ / 8);
 #else
-		pxframe->pkt_offset = 1;//default use pkt_offset to fill tx desc
+		pxframe->pkt_offset = 1;/* default use pkt_offset to fill tx desc */
 #endif
 
 #ifdef CONFIG_USB_TX_AGGREGATION
 		pxframe->agg_num = 1;
 #endif
 
-#endif //#ifdef CONFIG_USB_HCI
+#endif /* #ifdef CONFIG_USB_HCI */
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 		pxframe->pg_num = 1;
@@ -3191,11 +3477,11 @@ Otherwise, we must use _enter/_exit critical to protect free_xmit_queue...
 Must be very very cautious...
 
 */
-struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)//(_queue *pfree_xmit_queue)
+struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)/* (_queue *pfree_xmit_queue) */
 {
 	/*
 		Please remember to use all the osdep_service api,
-		and lock/unlock or _enter/_exit critical to protect 
+		and lock/unlock or _enter/_exit critical to protect
 		pfree_xmit_queue
 	*/
 
@@ -3204,12 +3490,10 @@ struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)//(_queue *pf
 	_list *plist, *phead;
 	_queue *pfree_xmit_queue = &pxmitpriv->free_xmit_queue;
 
-_func_enter_;
 
 	_enter_critical_bh(&pfree_xmit_queue->lock, &irqL);
 
 	if (_rtw_queue_empty(pfree_xmit_queue) == _TRUE) {
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_alloc_xmitframe:%d\n", pxmitpriv->free_xmitframe_cnt));
 		pxframe =  NULL;
 	} else {
 		phead = get_list_head(pfree_xmit_queue);
@@ -3220,14 +3504,12 @@ _func_enter_;
 
 		rtw_list_delete(&(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));
 	}
 
 	_exit_critical_bh(&pfree_xmit_queue->lock, &irqL);
 
 	rtw_init_xmitframe(pxframe);
 
-_func_exit_;
 
 	return pxframe;
 }
@@ -3239,12 +3521,10 @@ struct xmit_frame *rtw_alloc_xmitframe_ext(struct xmit_priv *pxmitpriv)
 	_list *plist, *phead;
 	_queue *queue = &pxmitpriv->free_xframe_ext_queue;
 
-_func_enter_;
 
 	_enter_critical_bh(&queue->lock, &irqL);
 
 	if (_rtw_queue_empty(queue) == _TRUE) {
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_alloc_xmitframe_ext:%d\n", pxmitpriv->free_xframe_ext_cnt));
 		pxframe =  NULL;
 	} else {
 		phead = get_list_head(queue);
@@ -3253,14 +3533,12 @@ _func_enter_;
 
 		rtw_list_delete(&(pxframe->list));
 		pxmitpriv->free_xframe_ext_cnt--;
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, ("rtw_alloc_xmitframe_ext():free_xmitframe_cnt=%d\n", pxmitpriv->free_xframe_ext_cnt));
 	}
 
 	_exit_critical_bh(&queue->lock, &irqL);
 
 	rtw_init_xmitframe(pxframe);
 
-_func_exit_;
 
 	return pxframe;
 }
@@ -3271,10 +3549,10 @@ struct xmit_frame *rtw_alloc_xmitframe_once(struct xmit_priv *pxmitpriv)
 	u8 *alloc_addr;
 
 	alloc_addr = rtw_zmalloc(sizeof(struct xmit_frame) + 4);
-	
+
 	if (alloc_addr == NULL)
 		goto exit;
-		
+
 	pxframe = (struct xmit_frame *)N_BYTE_ALIGMENT((SIZE_PTR)(alloc_addr), 4);
 	pxframe->alloc_addr = alloc_addr;
 
@@ -3288,54 +3566,50 @@ struct xmit_frame *rtw_alloc_xmitframe_once(struct xmit_priv *pxmitpriv)
 
 	rtw_init_xmitframe(pxframe);
 
-	DBG_871X("################## %s ##################\n", __func__);
+	RTW_INFO("################## %s ##################\n", __func__);
 
 exit:
 	return pxframe;
 }
 
 s32 rtw_free_xmitframe(struct xmit_priv *pxmitpriv, struct xmit_frame *pxmitframe)
-{	
+{
 	_irqL irqL;
 	_queue *queue = NULL;
 	_adapter *padapter = pxmitpriv->adapter;
 	_pkt *pndis_pkt = NULL;
 
-_func_enter_;	
 
 	if (pxmitframe == NULL) {
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("======rtw_free_xmitframe():pxmitframe==NULL!!!!!!!!!!\n"));
 		goto exit;
 	}
 
-	if (pxmitframe->pkt){
+	if (pxmitframe->pkt) {
 		pndis_pkt = pxmitframe->pkt;
 		pxmitframe->pkt = NULL;
 	}
 
 	if (pxmitframe->alloc_addr) {
-		DBG_871X("################## %s with alloc_addr ##################\n", __func__);
+		RTW_INFO("################## %s with alloc_addr ##################\n", __func__);
 		rtw_mfree(pxmitframe->alloc_addr, sizeof(struct xmit_frame) + 4);
 		goto check_pkt_complete;
 	}
 
 	if (pxmitframe->ext_tag == 0)
 		queue = &pxmitpriv->free_xmit_queue;
-	else if(pxmitframe->ext_tag == 1)
+	else if (pxmitframe->ext_tag == 1)
 		queue = &pxmitpriv->free_xframe_ext_queue;
 	else
 		rtw_warn_on(1);
 
 	_enter_critical_bh(&queue->lock, &irqL);
 
-	rtw_list_delete(&pxmitframe->list);	
+	rtw_list_delete(&pxmitframe->list);
 	rtw_list_insert_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_xmitframe():free_xmitframe_cnt=%d\n", pxmitpriv->free_xmitframe_cnt));
-	} else if(pxmitframe->ext_tag == 1) {
+	} else if (pxmitframe->ext_tag == 1) {
 		pxmitpriv->free_xframe_ext_cnt++;
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_debug_, ("rtw_free_xmitframe():free_xframe_ext_cnt=%d\n", pxmitpriv->free_xframe_ext_cnt));
 	} else {
 	}
 
@@ -3343,12 +3617,11 @@ _func_enter_;
 
 check_pkt_complete:
 
-	if(pndis_pkt)
+	if (pndis_pkt)
 		rtw_os_pkt_complete(padapter, pndis_pkt);
 
 exit:
 
-_func_exit_;
 
 	return _SUCCESS;
 }
@@ -3357,38 +3630,32 @@ void rtw_free_xmitframe_queue(struct xmit_priv *pxmitpriv, _queue *pframequeue)
 {
 	_irqL irqL;
 	_list	*plist, *phead;
-	struct	xmit_frame 	*pxmitframe;
+	struct	xmit_frame	*pxmitframe;
 
-_func_enter_;	
 
 	_enter_critical_bh(&(pframequeue->lock), &irqL);
 
 	phead = get_list_head(pframequeue);
 	plist = get_next(phead);
-	
-	while (rtw_end_of_queue_search(phead, plist) == _FALSE)
-	{
-			
+
+	while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
+
 		pxmitframe = LIST_CONTAINOR(plist, struct xmit_frame, list);
 
-		plist = get_next(plist); 
-		
-		rtw_free_xmitframe(pxmitpriv,pxmitframe);
-			
+		plist = get_next(plist);
+
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+
 	}
 	_exit_critical_bh(&(pframequeue->lock), &irqL);
 
-_func_exit_;
 }
 
 s32 rtw_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
 	DBG_COUNTER(padapter->tx_logs.core_tx_enqueue);
-	if (rtw_xmit_classifier(padapter, pxmitframe) == _FAIL)
-	{
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-			 ("rtw_xmitframe_enqueue: drop xmit pkt for classifier fail\n"));
-//		pxmitframe->pkt = NULL;
+	if (rtw_xmit_classifier(padapter, pxmitframe) == _FAIL) {
+		/*		pxmitframe->pkt = NULL; */
 		return _FAIL;
 	}
 
@@ -3398,50 +3665,68 @@ s32 rtw_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)
 static struct xmit_frame *dequeue_one_xmitframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit, struct tx_servq *ptxservq, _queue *pframe_queue)
 {
 	_list	*xmitframe_plist, *xmitframe_phead;
-	struct	xmit_frame	*pxmitframe=NULL;
+	struct	xmit_frame	*pxmitframe = NULL;
 
 	xmitframe_phead = get_list_head(pframe_queue);
 	xmitframe_plist = get_next(xmitframe_phead);
 
-	while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE)
-	{
+	while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
 		pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
 
 		/* xmitframe_plist = get_next(xmitframe_plist); */
 
-/*#ifdef RTK_DMP_PLATFORM
-#ifdef CONFIG_USB_TX_AGGREGATION
-		if((ptxservq->qcnt>0) && (ptxservq->qcnt<=2))
-		{
-			pxmitframe = NULL;
+		/*#ifdef RTK_DMP_PLATFORM
+		#ifdef CONFIG_USB_TX_AGGREGATION
+				if((ptxservq->qcnt>0) && (ptxservq->qcnt<=2))
+				{
+					pxmitframe = NULL;
 
-			tasklet_schedule(&pxmitpriv->xmit_tasklet);
+					tasklet_schedule(&pxmitpriv->xmit_tasklet);
 
-			break;
-		}
-#endif
-#endif*/
+					break;
+				}
+		#endif
+		#endif*/
 		rtw_list_delete(&pxmitframe->list);
 
 		ptxservq->qcnt--;
 
-		//rtw_list_insert_tail(&pxmitframe->list, &phwxmit->pending);
+		/* rtw_list_insert_tail(&pxmitframe->list, &phwxmit->pending); */
+
+		/* ptxservq->qcnt--; */
+
+		break;
+
+		/* pxmitframe = NULL; */
+
+	}
 
-		//ptxservq->qcnt--;
+	return pxmitframe;
+}
 
-		break;		
+static struct xmit_frame *get_one_xmitframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit, struct tx_servq *ptxservq, _queue *pframe_queue)
+{
+	_list	*xmitframe_plist, *xmitframe_phead;
+	struct	xmit_frame	*pxmitframe = NULL;
 
-		//pxmitframe = NULL;
+	xmitframe_phead = get_list_head(pframe_queue);
+	xmitframe_plist = get_next(xmitframe_phead);
 
+	while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
+		pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
+		break;
 	}
 
 	return pxmitframe;
 }
 
-struct xmit_frame* rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i, sint entry)
+struct xmit_frame *rtw_get_xframe(struct xmit_priv *pxmitpriv, int *num_frame)
 {
 	_irqL irqL0;
 	_list *sta_plist, *sta_phead;
+	struct hw_xmit *phwxmit_i = pxmitpriv->hwxmits;
+	sint entry =  pxmitpriv->hwxmit_entry;
+
 	struct hw_xmit *phwxmit;
 	struct tx_servq *ptxservq = NULL;
 	_queue *pframe_queue = NULL;
@@ -3449,61 +3734,117 @@ struct xmit_frame* rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmi
 	_adapter *padapter = pxmitpriv->adapter;
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 	int i, inx[4];
+
 #ifdef CONFIG_USB_HCI
-//	int j, tmp, acirp_cnt[4];
+	/*	int j, tmp, acirp_cnt[4]; */
 #endif
 
-_func_enter_;
+	inx[0] = 0;
+	inx[1] = 1;
+	inx[2] = 2;
+	inx[3] = 3;
 
-	inx[0] = 0; inx[1] = 1; inx[2] = 2; inx[3] = 3;
+	*num_frame = 0;
 
-	if(pregpriv->wifi_spec==1)
-	{
+	/*No amsdu when wifi_spec on*/
+	if (pregpriv->wifi_spec == 1) {
+		return NULL;
+	}
+
+	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
+
+	for (i = 0; i < entry; i++) {
+		phwxmit = phwxmit_i + inx[i];
+
+		sta_phead = get_list_head(phwxmit->sta_queue);
+		sta_plist = get_next(sta_phead);
+
+		while ((rtw_end_of_queue_search(sta_phead, sta_plist)) == _FALSE) {
+
+			ptxservq = LIST_CONTAINOR(sta_plist, struct tx_servq, tx_pending);
+			pframe_queue = &ptxservq->sta_pending;
+
+			if(ptxservq->qcnt)
+			{
+				*num_frame = ptxservq->qcnt;
+				pxmitframe = get_one_xmitframe(pxmitpriv, phwxmit, ptxservq, pframe_queue);
+				goto exit;
+			}
+			sta_plist = get_next(sta_plist);
+		}
+	}
+
+exit:
+
+	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
+
+	return pxmitframe;
+}
+
+
+struct xmit_frame *rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i, sint entry)
+{
+	_irqL irqL0;
+	_list *sta_plist, *sta_phead;
+	struct hw_xmit *phwxmit;
+	struct tx_servq *ptxservq = NULL;
+	_queue *pframe_queue = NULL;
+	struct xmit_frame *pxmitframe = NULL;
+	_adapter *padapter = pxmitpriv->adapter;
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+	int i, inx[4];
+#ifdef CONFIG_USB_HCI
+	/*	int j, tmp, acirp_cnt[4]; */
+#endif
+
+
+	inx[0] = 0;
+	inx[1] = 1;
+	inx[2] = 2;
+	inx[3] = 3;
+
+	if (pregpriv->wifi_spec == 1) {
 		int j, tmp, acirp_cnt[4];
 #if 0
-		if(flags<XMIT_QUEUE_ENTRY)
-		{
-			//priority exchange according to the completed xmitbuf flags.
+		if (flags < XMIT_QUEUE_ENTRY) {
+			/* priority exchange according to the completed xmitbuf flags. */
 			inx[flags] = 0;
 			inx[0] = flags;
 		}
-#endif	
-	
+#endif
+
 #if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_PCI_HCI)
-		for(j=0; j<4; j++)
+		for (j = 0; j < 4; j++)
 			inx[j] = pxmitpriv->wmm_para_seq[j];
 #endif
 	}
 
 	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
 
-	for(i = 0; i < entry; i++) 
-	{
+	for (i = 0; i < entry; i++) {
 		phwxmit = phwxmit_i + inx[i];
 
-		//_enter_critical_ex(&phwxmit->sta_queue->lock, &irqL0);
+		/* _enter_critical_ex(&phwxmit->sta_queue->lock, &irqL0); */
 
 		sta_phead = get_list_head(phwxmit->sta_queue);
 		sta_plist = get_next(sta_phead);
 
-		while ((rtw_end_of_queue_search(sta_phead, sta_plist)) == _FALSE)
-		{
+		while ((rtw_end_of_queue_search(sta_phead, sta_plist)) == _FALSE) {
 
-			ptxservq= LIST_CONTAINOR(sta_plist, struct tx_servq, tx_pending);
+			ptxservq = LIST_CONTAINOR(sta_plist, struct tx_servq, tx_pending);
 
 			pframe_queue = &ptxservq->sta_pending;
 
 			pxmitframe = dequeue_one_xmitframe(pxmitpriv, phwxmit, ptxservq, pframe_queue);
 
-			if(pxmitframe)
-			{
+			if (pxmitframe) {
 				phwxmit->accnt--;
 
-				//Remove sta node when there is no pending packets.
-				if(_rtw_queue_empty(pframe_queue)) //must be done after get_next and before break
+				/* Remove sta node when there is no pending packets. */
+				if (_rtw_queue_empty(pframe_queue)) /* must be done after get_next and before break */
 					rtw_list_delete(&ptxservq->tx_pending);
 
-				//_exit_critical_ex(&phwxmit->sta_queue->lock, &irqL0);
+				/* _exit_critical_ex(&phwxmit->sta_queue->lock, &irqL0); */
 
 				goto exit;
 			}
@@ -3512,7 +3853,7 @@ _func_enter_;
 
 		}
 
-		//_exit_critical_ex(&phwxmit->sta_queue->lock, &irqL0);
+		/* _exit_critical_ex(&phwxmit->sta_queue->lock, &irqL0); */
 
 	}
 
@@ -3520,116 +3861,98 @@ exit:
 
 	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
 
-_func_exit_;
-
 	return pxmitframe;
 }
 
 #if 1
 struct tx_servq *rtw_get_sta_pending(_adapter *padapter, struct sta_info *psta, sint up, u8 *ac)
 {
-	struct tx_servq *ptxservq=NULL;
-	
-_func_enter_;	
+	struct tx_servq *ptxservq = NULL;
+
+
+	switch (up) {
+	case 1:
+	case 2:
+		ptxservq = &(psta->sta_xmitpriv.bk_q);
+		*(ac) = 3;
+		break;
+
+	case 4:
+	case 5:
+		ptxservq = &(psta->sta_xmitpriv.vi_q);
+		*(ac) = 1;
+		break;
+
+	case 6:
+	case 7:
+		ptxservq = &(psta->sta_xmitpriv.vo_q);
+		*(ac) = 0;
+		break;
+
+	case 0:
+	case 3:
+	default:
+		ptxservq = &(psta->sta_xmitpriv.be_q);
+		*(ac) = 2;
+		break;
+
+	}
+
+
+	return ptxservq;
+}
+#else
+__inline static struct tx_servq *rtw_get_sta_pending
+(_adapter *padapter, _queue **ppstapending, struct sta_info *psta, sint up)
+{
+	struct tx_servq *ptxservq;
+	struct hw_xmit *phwxmits =  padapter->xmitpriv.hwxmits;
+
+
+#ifdef CONFIG_RTL8711
 
-	switch (up) 
+	if (IS_MCAST(psta->cmn.mac_addr)) {
+		ptxservq = &(psta->sta_xmitpriv.be_q); /* we will use be_q to queue bc/mc frames in BCMC_stainfo */
+		*ppstapending = &padapter->xmitpriv.bm_pending;
+	} else
+#endif
 	{
+		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_pending : BK \n"));
+			*ppstapending = &padapter->xmitpriv.bk_pending;
+			(phwxmits + 3)->accnt++;
 			break;
 
 		case 4:
 		case 5:
 			ptxservq = &(psta->sta_xmitpriv.vi_q);
-			*(ac) = 1;
-			RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_get_sta_pending : VI\n"));
+			*ppstapending = &padapter->xmitpriv.vi_pending;
+			(phwxmits + 1)->accnt++;
 			break;
 
 		case 6:
 		case 7:
 			ptxservq = &(psta->sta_xmitpriv.vo_q);
-			*(ac) = 0;
-			RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_get_sta_pending : VO \n"));			
+			*ppstapending = &padapter->xmitpriv.vo_pending;
+			(phwxmits + 0)->accnt++;
 			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_pending : BE \n"));				
-		break;
-		
-	}
-
-_func_exit_;
-
-	return ptxservq;			
-}
-#else
-__inline static struct tx_servq *rtw_get_sta_pending
-	(_adapter *padapter, _queue **ppstapending, struct sta_info *psta, sint up)
-{
-	struct tx_servq *ptxservq;
-	struct hw_xmit *phwxmits =  padapter->xmitpriv.hwxmits;
-	
-_func_enter_;	
-
-#ifdef CONFIG_RTL8711
-
-	if(IS_MCAST(psta->hwaddr))
-	{
-		ptxservq = &(psta->sta_xmitpriv.be_q); // we will use be_q to queue bc/mc frames in BCMC_stainfo
-		*ppstapending = &padapter->xmitpriv.bm_pending; 
-	}
-	else
-#endif		
-	{
-		switch (up) 
-		{
-			case 1:
-			case 2:
-				ptxservq = &(psta->sta_xmitpriv.bk_q);
-				*ppstapending = &padapter->xmitpriv.bk_pending;
-				(phwxmits+3)->accnt++;
-				RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_get_sta_pending : BK \n"));
-				break;
-
-			case 4:
-			case 5:
-				ptxservq = &(psta->sta_xmitpriv.vi_q);
-				*ppstapending = &padapter->xmitpriv.vi_pending;
-				(phwxmits+1)->accnt++;
-				RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_get_sta_pending : VI\n"));
-				break;
-
-			case 6:
-			case 7:
-				ptxservq = &(psta->sta_xmitpriv.vo_q);
-				*ppstapending = &padapter->xmitpriv.vo_pending;
-				(phwxmits+0)->accnt++;
-				RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_get_sta_pending : VO \n"));			
-				break;
-
-			case 0:
-			case 3:
-			default:
-				ptxservq = &(psta->sta_xmitpriv.be_q);
-				*ppstapending = &padapter->xmitpriv.be_pending;
-				(phwxmits+2)->accnt++;
-				RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("rtw_get_sta_pending : BE \n"));				
+			*ppstapending = &padapter->xmitpriv.be_pending;
+			(phwxmits + 2)->accnt++;
 			break;
-			
+
 		}
 
 	}
 
-_func_exit_;
 
-	return ptxservq;			
+	return ptxservq;
 }
 #endif
 
@@ -3639,7 +3962,7 @@ _func_exit_;
  */
 s32 rtw_xmit_classifier(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
-	//_irqL irqL0;
+	/* _irqL irqL0; */
 	u8	ac_index;
 	struct sta_info	*psta;
 	struct tx_servq	*ptxservq;
@@ -3648,63 +3971,57 @@ s32 rtw_xmit_classifier(_adapter *padapter, struct xmit_frame *pxmitframe)
 	struct hw_xmit	*phwxmits =  padapter->xmitpriv.hwxmits;
 	sint res = _SUCCESS;
 
-_func_enter_;
 
 	DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class);
 
-/*
-	if (pattrib->psta) {
-		psta = pattrib->psta;		
-	} else {
-		DBG_871X("%s, call rtw_get_stainfo()\n", __func__);
-		psta = rtw_get_stainfo(pstapriv, pattrib->ra);
-	}
-*/	
+	/*
+		if (pattrib->psta) {
+			psta = pattrib->psta;
+		} else {
+			RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+			psta = rtw_get_stainfo(pstapriv, pattrib->ra);
+		}
+	*/
 
 	psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-	if(pattrib->psta != psta)
-	{
+	if (pattrib->psta != psta) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class_err_sta);
-		DBG_871X("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
+		RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
 		return _FAIL;
 	}
 
 	if (psta == NULL) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class_err_nosta);
 		res = _FAIL;
-		DBG_8192C("rtw_xmit_classifier: psta == NULL\n");
-		RT_TRACE(_module_rtl871x_xmit_c_,_drv_err_,("rtw_xmit_classifier: psta == NULL\n"));
+		RTW_INFO("rtw_xmit_classifier: psta == NULL\n");
 		goto exit;
 	}
 
-	if(!(psta->state &_FW_LINKED))
-	{
+	if (!(psta->state & _FW_LINKED)) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class_err_fwlink);
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
+		RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
 		return _FAIL;
 	}
 
 	ptxservq = rtw_get_sta_pending(padapter, psta, pattrib->priority, (u8 *)(&ac_index));
 
-	//_enter_critical(&pstapending->lock, &irqL0);
+	/* _enter_critical(&pstapending->lock, &irqL0); */
 
-	if (rtw_is_list_empty(&ptxservq->tx_pending)) {
+	if (rtw_is_list_empty(&ptxservq->tx_pending))
 		rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(phwxmits[ac_index].sta_queue));
-	}
 
-	//_enter_critical(&ptxservq->sta_pending.lock, &irqL1);
+	/* _enter_critical(&ptxservq->sta_pending.lock, &irqL1); */
 
 	rtw_list_insert_tail(&pxmitframe->list, get_list_head(&ptxservq->sta_pending));
 	ptxservq->qcnt++;
 	phwxmits[ac_index].accnt++;
 
-	//_exit_critical(&ptxservq->sta_pending.lock, &irqL1);
+	/* _exit_critical(&ptxservq->sta_pending.lock, &irqL1); */
 
-	//_exit_critical(&pstapending->lock, &irqL0);
+	/* _exit_critical(&pstapending->lock, &irqL0); */
 
 exit:
 
-_func_exit_;
 
 	return res;
 }
@@ -3718,64 +4035,58 @@ void rtw_alloc_hwxmits(_adapter *padapter)
 
 	pxmitpriv->hwxmits = NULL;
 
-	pxmitpriv->hwxmits = (struct hw_xmit *)rtw_zmalloc(sizeof (struct hw_xmit) * pxmitpriv->hwxmit_entry);	
+	pxmitpriv->hwxmits = (struct hw_xmit *)rtw_zmalloc(sizeof(struct hw_xmit) * pxmitpriv->hwxmit_entry);
 
-	if(pxmitpriv->hwxmits == NULL)
-	{
-		DBG_871X("alloc hwxmits fail!...\n");
+	if (pxmitpriv->hwxmits == NULL) {
+		RTW_INFO("alloc hwxmits fail!...\n");
 		return;
 	}
-	
+
 	hwxmits = pxmitpriv->hwxmits;
 
-	if(pxmitpriv->hwxmit_entry == 5)
-	{
-		//pxmitpriv->bmc_txqueue.head = 0;
-		//hwxmits[0] .phwtxqueue = &pxmitpriv->bmc_txqueue;
+	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;
+
+		/* 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;
+		/* 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;
+
+		/* 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;
+		/* 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;
+	} 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;
+		/* 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;
+		/* 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;
+
+		/* pxmitpriv->bk_txqueue.head = 0; */
+		/* hwxmits[3] .phwtxqueue = &pxmitpriv->bk_txqueue; */
 		hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
-	}
-	else
-	{
-		
+	} else {
+
 
 	}
-	
+
 
 }
 
@@ -3785,22 +4096,19 @@ void rtw_free_hwxmits(_adapter *padapter)
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 
 	hwxmits = pxmitpriv->hwxmits;
-	if(hwxmits)
-		rtw_mfree((u8 *)hwxmits, (sizeof (struct hw_xmit) * pxmitpriv->hwxmit_entry));
+	if (hwxmits)
+		rtw_mfree((u8 *)hwxmits, (sizeof(struct hw_xmit) * pxmitpriv->hwxmit_entry));
 }
 
 void rtw_init_hwxmits(struct hw_xmit *phwxmit, sint entry)
 {
 	sint i;
-_func_enter_;	
-	for(i = 0; i < entry; i++, phwxmit++)
-	{
-		//_rtw_spinlock_init(&phwxmit->xmit_lock);
-		//_rtw_init_listhead(&phwxmit->pending);		
-		//phwxmit->txcmdcnt = 0;
+	for (i = 0; i < entry; i++, phwxmit++) {
+		/* _rtw_spinlock_init(&phwxmit->xmit_lock); */
+		/* _rtw_init_listhead(&phwxmit->pending);		 */
+		/* phwxmit->txcmdcnt = 0; */
 		phwxmit->accnt = 0;
 	}
-_func_exit_;	
 }
 
 #ifdef CONFIG_BR_EXT
@@ -3809,217 +4117,212 @@ int rtw_br_client_tx(_adapter *padapter, struct sk_buff **pskb)
 	struct sk_buff *skb = *pskb;
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	_irqL irqL;
-	//if(check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE)
+	/* if(check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE) */
 	{
 		void dhcp_flag_bcast(_adapter *priv, struct sk_buff *skb);
-		int res, is_vlan_tag=0, i, do_nat25=1;
-		unsigned short vlan_hdr=0;
+		int res, is_vlan_tag = 0, i, do_nat25 = 1;
+		unsigned short vlan_hdr = 0;
 		void *br_port = NULL;
 
-		//mac_clone_handle_frame(priv, skb);
+		/* mac_clone_handle_frame(priv, skb); */
 
 #if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
 		br_port = padapter->pnetdev->br_port;
-#else   // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+#else   /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
 		rcu_read_lock();
 		br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
 		rcu_read_unlock();
-#endif  // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
 		_enter_critical_bh(&padapter->br_ext_lock, &irqL);
-		if (	!(skb->data[0] & 1) &&
-				br_port &&
-				memcmp(skb->data+MACADDRLEN, padapter->br_mac, MACADDRLEN) &&
-				*((unsigned short *)(skb->data+MACADDRLEN*2)) != __constant_htons(ETH_P_8021Q) &&
-				*((unsigned short *)(skb->data+MACADDRLEN*2)) == __constant_htons(ETH_P_IP) &&
-				!memcmp(padapter->scdb_mac, skb->data+MACADDRLEN, MACADDRLEN) && padapter->scdb_entry) {
-			memcpy(skb->data+MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
+		if (!(skb->data[0] & 1) &&
+		    br_port &&
+		    memcmp(skb->data + MACADDRLEN, padapter->br_mac, MACADDRLEN) &&
+		    *((unsigned short *)(skb->data + MACADDRLEN * 2)) != __constant_htons(ETH_P_8021Q) &&
+		    *((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_IP) &&
+		    !memcmp(padapter->scdb_mac, skb->data + MACADDRLEN, MACADDRLEN) && padapter->scdb_entry) {
+			memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
 			padapter->scdb_entry->ageing_timer = jiffies;
 			_exit_critical_bh(&padapter->br_ext_lock, &irqL);
-		}
-		else
-		//if (!priv->pmib->ethBrExtInfo.nat25_disable) 		
+		} else
+			/* if (!priv->pmib->ethBrExtInfo.nat25_disable)		 */
 		{
-//			if (priv->dev->br_port &&
-//				 !memcmp(skb->data+MACADDRLEN, priv->br_mac, MACADDRLEN)) {
+			/*			if (priv->dev->br_port &&
+			 *				 !memcmp(skb->data+MACADDRLEN, priv->br_mac, MACADDRLEN)) { */
 #if 1
-			if (*((unsigned short *)(skb->data+MACADDRLEN*2)) == __constant_htons(ETH_P_8021Q)) {
+			if (*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_8021Q)) {
 				is_vlan_tag = 1;
-				vlan_hdr = *((unsigned short *)(skb->data+MACADDRLEN*2+2));
-				for (i=0; i<6; i++)
-					*((unsigned short *)(skb->data+MACADDRLEN*2+2-i*2)) = *((unsigned short *)(skb->data+MACADDRLEN*2-2-i*2));
+				vlan_hdr = *((unsigned short *)(skb->data + MACADDRLEN * 2 + 2));
+				for (i = 0; i < 6; i++)
+					*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2 - i * 2)) = *((unsigned short *)(skb->data + MACADDRLEN * 2 - 2 - i * 2));
 				skb_pull(skb, 4);
 			}
-			//if SA == br_mac && skb== IP  => copy SIP to br_ip ?? why
-			if (!memcmp(skb->data+MACADDRLEN, padapter->br_mac, MACADDRLEN) &&
-				(*((unsigned short *)(skb->data+MACADDRLEN*2)) == __constant_htons(ETH_P_IP)))
-				memcpy(padapter->br_ip, skb->data+WLAN_ETHHDR_LEN+12, 4);
+			/* if SA == br_mac && skb== IP  => copy SIP to br_ip ?? why */
+			if (!memcmp(skb->data + MACADDRLEN, padapter->br_mac, MACADDRLEN) &&
+			    (*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_IP)))
+				memcpy(padapter->br_ip, skb->data + WLAN_ETHHDR_LEN + 12, 4);
 
-			if (*((unsigned short *)(skb->data+MACADDRLEN*2)) == __constant_htons(ETH_P_IP)) {
-				if (memcmp(padapter->scdb_mac, skb->data+MACADDRLEN, MACADDRLEN)) {
+			if (*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_IP)) {
+				if (memcmp(padapter->scdb_mac, skb->data + MACADDRLEN, MACADDRLEN)) {
 					void *scdb_findEntry(_adapter *priv, unsigned char *macAddr, unsigned char *ipAddr);
-					
-					if ((padapter->scdb_entry = (struct nat25_network_db_entry *)scdb_findEntry(padapter,
-								skb->data+MACADDRLEN, skb->data+WLAN_ETHHDR_LEN+12)) != NULL) {
-						memcpy(padapter->scdb_mac, skb->data+MACADDRLEN, MACADDRLEN);
-						memcpy(padapter->scdb_ip, skb->data+WLAN_ETHHDR_LEN+12, 4);
+
+					padapter->scdb_entry = (struct nat25_network_db_entry *)scdb_findEntry(padapter,
+						skb->data + MACADDRLEN, skb->data + WLAN_ETHHDR_LEN + 12);
+					if (padapter->scdb_entry != NULL) {
+						memcpy(padapter->scdb_mac, skb->data + MACADDRLEN, MACADDRLEN);
+						memcpy(padapter->scdb_ip, skb->data + WLAN_ETHHDR_LEN + 12, 4);
 						padapter->scdb_entry->ageing_timer = jiffies;
 						do_nat25 = 0;
 					}
-				}
-				else {
+				} else {
 					if (padapter->scdb_entry) {
 						padapter->scdb_entry->ageing_timer = jiffies;
 						do_nat25 = 0;
-					}
-					else {
+					} else {
 						memset(padapter->scdb_mac, 0, MACADDRLEN);
 						memset(padapter->scdb_ip, 0, 4);
 					}
 				}
 			}
 			_exit_critical_bh(&padapter->br_ext_lock, &irqL);
-#endif // 1
-			if (do_nat25)
-			{
+#endif /* 1 */
+			if (do_nat25) {
 				int nat25_db_handle(_adapter *priv, struct sk_buff *skb, int method);
 				if (nat25_db_handle(padapter, skb, NAT25_CHECK) == 0) {
 					struct sk_buff *newskb;
 
 					if (is_vlan_tag) {
 						skb_push(skb, 4);
-						for (i=0; i<6; i++)
-							*((unsigned short *)(skb->data+i*2)) = *((unsigned short *)(skb->data+4+i*2));
-						*((unsigned short *)(skb->data+MACADDRLEN*2)) = __constant_htons(ETH_P_8021Q);
-						*((unsigned short *)(skb->data+MACADDRLEN*2+2)) = vlan_hdr;
+						for (i = 0; i < 6; i++)
+							*((unsigned short *)(skb->data + i * 2)) = *((unsigned short *)(skb->data + 4 + i * 2));
+						*((unsigned short *)(skb->data + MACADDRLEN * 2)) = __constant_htons(ETH_P_8021Q);
+						*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2)) = vlan_hdr;
 					}
 
 					newskb = rtw_skb_copy(skb);
 					if (newskb == NULL) {
-						//priv->ext_stats.tx_drops++;
+						/* priv->ext_stats.tx_drops++; */
 						DEBUG_ERR("TX DROP: rtw_skb_copy fail!\n");
-						//goto stop_proc;
+						/* goto stop_proc; */
 						return -1;
 					}
 					rtw_skb_free(skb);
 
 					*pskb = skb = newskb;
 					if (is_vlan_tag) {
-						vlan_hdr = *((unsigned short *)(skb->data+MACADDRLEN*2+2));
-						for (i=0; i<6; i++)
-							*((unsigned short *)(skb->data+MACADDRLEN*2+2-i*2)) = *((unsigned short *)(skb->data+MACADDRLEN*2-2-i*2));
+						vlan_hdr = *((unsigned short *)(skb->data + MACADDRLEN * 2 + 2));
+						for (i = 0; i < 6; i++)
+							*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2 - i * 2)) = *((unsigned short *)(skb->data + MACADDRLEN * 2 - 2 - i * 2));
 						skb_pull(skb, 4);
 					}
 				}
 
 				if (skb_is_nonlinear(skb))
 					DEBUG_ERR("%s(): skb_is_nonlinear!!\n", __FUNCTION__);
-					
+
 
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18))
 				res = skb_linearize(skb, GFP_ATOMIC);
-#else	// (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18))
+#else	/* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18)) */
 				res = skb_linearize(skb);
-#endif	// (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18))
-				if (res < 0) {				
-						DEBUG_ERR("TX DROP: skb_linearize fail!\n");
-						//goto free_and_stop;
-						return -1;
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18)) */
+				if (res < 0) {
+					DEBUG_ERR("TX DROP: skb_linearize fail!\n");
+					/* goto free_and_stop; */
+					return -1;
 				}
-				
+
 				res = nat25_db_handle(padapter, skb, NAT25_INSERT);
 				if (res < 0) {
 					if (res == -2) {
-						//priv->ext_stats.tx_drops++;
+						/* priv->ext_stats.tx_drops++; */
 						DEBUG_ERR("TX DROP: nat25_db_handle fail!\n");
-						//goto free_and_stop;
+						/* goto free_and_stop; */
 						return -1;
 
 					}
-					// we just print warning message and let it go
-					//DEBUG_WARN("%s()-%d: nat25_db_handle INSERT Warning!\n", __FUNCTION__, __LINE__);
-					//return -1; // return -1 will cause system crash on 2011/08/30!
+					/* we just print warning message and let it go */
+					/* DEBUG_WARN("%s()-%d: nat25_db_handle INSERT Warning!\n", __FUNCTION__, __LINE__); */
+					/* return -1; */ /* return -1 will cause system crash on 2011/08/30! */
 					return 0;
 				}
 			}
 
-			memcpy(skb->data+MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
+			memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
 
 			dhcp_flag_bcast(padapter, skb);
 
 			if (is_vlan_tag) {
 				skb_push(skb, 4);
-				for (i=0; i<6; i++)
-					*((unsigned short *)(skb->data+i*2)) = *((unsigned short *)(skb->data+4+i*2));
-				*((unsigned short *)(skb->data+MACADDRLEN*2)) = __constant_htons(ETH_P_8021Q);
-				*((unsigned short *)(skb->data+MACADDRLEN*2+2)) = vlan_hdr;
+				for (i = 0; i < 6; i++)
+					*((unsigned short *)(skb->data + i * 2)) = *((unsigned short *)(skb->data + 4 + i * 2));
+				*((unsigned short *)(skb->data + MACADDRLEN * 2)) = __constant_htons(ETH_P_8021Q);
+				*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2)) = vlan_hdr;
 			}
 		}
-#if 0		
-		else{
-			if (*((unsigned short *)(skb->data+MACADDRLEN*2)) == __constant_htons(ETH_P_8021Q)) {
+#if 0
+		else {
+			if (*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_8021Q))
 				is_vlan_tag = 1;
+
+			if (is_vlan_tag) {
+				if (ICMPV6_MCAST_MAC(skb->data) && ICMPV6_PROTO1A_VALN(skb->data))
+					memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
+			} else {
+				if (ICMPV6_MCAST_MAC(skb->data) && ICMPV6_PROTO1A(skb->data))
+					memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
 			}
-				
-			if(is_vlan_tag){
-				if(ICMPV6_MCAST_MAC(skb->data) && ICMPV6_PROTO1A_VALN(skb->data)){
-                                        memcpy(skb->data+MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
-				}
-			}else
-			{
-				if(ICMPV6_MCAST_MAC(skb->data) && ICMPV6_PROTO1A(skb->data)){
-                                        memcpy(skb->data+MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
-				}
-			}	
 		}
-#endif	// 0
+#endif /* 0 */
 
-		// check if SA is equal to our MAC
-		if (memcmp(skb->data+MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN)) {
-			//priv->ext_stats.tx_drops++;
+		/* check if SA is equal to our MAC */
+		if (memcmp(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN)) {
+			/* priv->ext_stats.tx_drops++; */
 			DEBUG_ERR("TX DROP: untransformed frame SA:%02X%02X%02X%02X%02X%02X!\n",
-				skb->data[6],skb->data[7],skb->data[8],skb->data[9],skb->data[10],skb->data[11]);
-			//goto free_and_stop;
+				skb->data[6], skb->data[7], skb->data[8], skb->data[9], skb->data[10], skb->data[11]);
+			/* goto free_and_stop; */
 			return -1;
 		}
 	}
 	return 0;
 }
-#endif	// CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
 
 u32 rtw_get_ff_hwaddr(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;		
-			
+	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 0x13:
+		addr = TXCMD_QUEUE_INX;
+		break;
+	case 0x12:
+	default:
+		addr = MGT_QUEUE_INX;
+		break;
+
 	}
 
 	return addr;
@@ -4029,16 +4332,28 @@ u32 rtw_get_ff_hwaddr(struct xmit_frame *pxmitframe)
 static void do_queue_select(_adapter	*padapter, struct pkt_attrib *pattrib)
 {
 	u8 qsel;
-		
+
 	qsel = pattrib->priority;
-	RT_TRACE(_module_rtl871x_xmit_c_,_drv_info_,("### do_queue_select priority=%d ,qsel = %d\n",pattrib->priority ,qsel));
 
-#ifdef CONFIG_CONCURRENT_MODE	
-//	if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
-//		qsel = 7;//
-#endif
-	
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter)) {
+		/* Under MCC */
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
+			if (padapter->mcc_adapterpriv.role == MCC_ROLE_GO
+			    || padapter->mcc_adapterpriv.role == MCC_ROLE_AP) {
+				pattrib->qsel = QSLT_VO; /* AP interface VO queue */
+			} else {
+				pattrib->qsel = QSLT_BE; /* STA interface BE queue */
+			}
+		} else
+			/* Not Under MCC */
+			pattrib->qsel = qsel;
+	} else
+		/* Not enable MCC */
+		pattrib->qsel = qsel;
+#else /* !CONFIG_MCC_MODE */
 	pattrib->qsel = qsel;
+#endif /* CONFIG_MCC_MODE */
 }
 
 /*
@@ -4052,18 +4367,18 @@ static void do_queue_select(_adapter	*padapter, struct pkt_attrib *pattrib)
  #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
 s32 rtw_monitor_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;
 	u16 frame_ctl;
-	unsigned char src_mac_addr[6];
-	unsigned char dst_mac_addr[6];
-	struct rtw_ieee80211_hdr *dot11_hdr;
-	struct ieee80211_radiotap_header *rtap_hdr;
+	struct ieee80211_radiotap_header rtap_hdr;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct pkt_file pktfile;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct pkt_attrib	*pattrib;
+	struct xmit_frame		*pmgntframe;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	unsigned char	*pframe;
+	u8 dummybuf[32];
+	int len = skb->len, rtap_len;
 
 	if (skb)
 		rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
@@ -4071,118 +4386,129 @@ s32 rtw_monitor_xmit_entry(struct sk_buff *skb, struct net_device *ndev)
 	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))
+	_rtw_open_pktfile((_pkt *)skb, &pktfile);
+	_rtw_pktfile_read(&pktfile, (u8 *)(&rtap_hdr), sizeof(struct ieee80211_radiotap_header));
+	rtap_len = ieee80211_get_radiotap_len((u8 *)(&rtap_hdr));
+	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 != 12) {
-		DBG_8192C("radiotap len (should be 14): %d\n", rtap_len);
+		RTW_INFO("radiotap len (should be 14): %d\n", rtap_len);
+		goto fail;
+	}
+	_rtw_pktfile_read(&pktfile, dummybuf, rtap_len-sizeof(struct ieee80211_radiotap_header));
+	len = len - rtap_len;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		rtw_udelay_os(500);
 		goto fail;
 	}
 
-	/* Skip the ratio tap header */
-	skb_pull(skb, rtap_len);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+//	_rtw_memcpy(pframe, (void *)checking, len);
+	_rtw_pktfile_read(&pktfile, pframe, len);
 
-	dot11_hdr = (struct rtw_ieee80211_hdr *)skb->data;
-	frame_ctl = le16_to_cpu(dot11_hdr->frame_ctl);
-	/* Check if the QoS bit is set */
 
+	/* Check DATA/MGNT frames */
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	frame_ctl = le16_to_cpu(pwlanhdr->frame_ctl);
 	if ((frame_ctl & RTW_IEEE80211_FCTL_FTYPE) == RTW_IEEE80211_FTYPE_DATA) {
 
-		struct xmit_frame		*pmgntframe;
-		struct pkt_attrib	*pattrib;
-		unsigned char	*pframe;
-		struct rtw_ieee80211_hdr *pwlanhdr;
-		struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-		struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-		u8 *buf = skb->data;
-		u32 len = skb->len;
-		u8 category, action;
-		int type = -1;
-
-		pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-		if (pmgntframe == NULL) {
-			rtw_udelay_os(500);
-			goto fail;
-		}
 		pattrib = &pmgntframe->attrib;
-
 		update_monitor_frame_attrib(padapter, pattrib);
 
-		pattrib->retry_ctrl = _FALSE;
-
-		_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-		pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-		_rtw_memcpy(pframe, (void *)buf, len);
-
-		pattrib->pktlen = len;
-
-		pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
 		if (is_broadcast_mac_addr(pwlanhdr->addr3) || is_broadcast_mac_addr(pwlanhdr->addr1))
 			pattrib->rate = MGN_24M;
 
-		pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
-		pattrib->seqnum = pmlmeext->mgnt_seq;
-		pmlmeext->mgnt_seq++;
-
-		pattrib->last_txcmdsz = pattrib->pktlen;
-
-		dump_mgntframe(padapter, pmgntframe);
-
 	} else {
-		struct xmit_frame		*pmgntframe;
-		struct pkt_attrib	*pattrib;
-		unsigned char	*pframe;
-		struct rtw_ieee80211_hdr *pwlanhdr;
-		struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-		struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-		u8 *buf = skb->data;
-		u32 len = skb->len;
-		u8 category, action;
-		int type = -1;
-
-		pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-		if (pmgntframe == NULL)
-			goto fail;
 
 		pattrib = &pmgntframe->attrib;
 		update_mgntframe_attrib(padapter, pattrib);
-		pattrib->retry_ctrl = _FALSE;
 
-		_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+	}
+	pattrib->retry_ctrl = _FALSE;
+	pattrib->pktlen = len;
+	pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
+	pattrib->seqnum = pmlmeext->mgnt_seq;
+	pmlmeext->mgnt_seq++;
+	pattrib->last_txcmdsz = pattrib->pktlen;
 
-		pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	dump_mgntframe(padapter, pmgntframe);
 
-		_rtw_memcpy(pframe, (void *)buf, len);
+fail:
+	rtw_endofpktfile(&pktfile);
+	rtw_skb_free(skb);
+	return 0;
+}
+#endif
 
-		pattrib->pktlen = len;
+/*
+ * The main transmit(tx) entry post handle
+ *
+ * Return
+ *	1	enqueue
+ *	0	success, hardware will handle this xmit frame(packet)
+ *	<0	fail
+ */
+s32 rtw_xmit_posthandle(_adapter *padapter, struct xmit_frame *pxmitframe, _pkt *pkt)
+{
+#ifdef CONFIG_AP_MODE
+	_irqL irqL0;
+#endif
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	s32 res;
 
-		pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	res = update_attrib(padapter, pkt, &pxmitframe->attrib);
 
-		pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
-		pattrib->seqnum = pmlmeext->mgnt_seq;
-		pmlmeext->mgnt_seq++;
+#ifdef CONFIG_MCC_MODE
+	/* record data kernel TX to driver to check MCC concurrent TX */
+	rtw_hal_mcc_calc_tx_bytes_from_kernel(padapter, pxmitframe->attrib.pktlen);
+#endif /* CONFIG_MCC_MODE */
 
-		pattrib->last_txcmdsz = pattrib->pktlen;
+#ifdef CONFIG_WAPI_SUPPORT
+	if (pxmitframe->attrib.ether_type != 0x88B4) {
+		if (rtw_wapi_drop_for_key_absent(padapter, pxmitframe->attrib.ra)) {
+			WAPI_TRACE(WAPI_RX, "drop for key absend when tx\n");
+			res = _FAIL;
+		}
+	}
+#endif
+	if (res == _FAIL) {
+		/*RTW_INFO("%s-"ADPT_FMT" update attrib fail\n", __func__, ADPT_ARG(padapter));*/
+#ifdef DBG_TX_DROP_FRAME
+		RTW_INFO("DBG_TX_DROP_FRAME %s update attrib fail\n", __FUNCTION__);
+#endif
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+		return -1;
+	}
+	pxmitframe->pkt = pkt;
 
-		dump_mgntframe(padapter, pmgntframe);
+	rtw_led_tx_control(padapter, pxmitframe->attrib.dst);
 
-	}
+	do_queue_select(padapter, &pxmitframe->attrib);
 
-fail:
+#ifdef CONFIG_AP_MODE
+	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
+	if (xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe) == _TRUE) {
+		_exit_critical_bh(&pxmitpriv->lock, &irqL0);
+		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue);
+		return 1;
+	}
+	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
+#endif
 
-		rtw_skb_free(skb);
+	/* pre_xmitframe */
+	if (rtw_hal_xmit(padapter, pxmitframe) == _FALSE)
+		return 1;
 
-		return 0;
+	return 0;
 }
-#endif
+
 /*
  * The main transmit(tx) entry
  *
@@ -4193,22 +4519,20 @@ fail:
  */
 s32 rtw_xmit(_adapter *padapter, _pkt **ppkt)
 {
-	static u32 start = 0;
+	static systime start = 0;
 	static u32 drop_cnt = 0;
-#ifdef CONFIG_AP_MODE
-	_irqL irqL0;
-#endif
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	struct xmit_frame *pxmitframe = NULL;
-#ifdef CONFIG_BR_EXT
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	void *br_port = NULL;
-#endif	// CONFIG_BR_EXT
-
 	s32 res;
 
 	DBG_COUNTER(padapter->tx_logs.core_tx);
 
+	if (IS_CH_WAITING(adapter_to_rfctl(padapter)))
+		return -1;
+
+	if (rtw_linked_check(padapter) == _FALSE)
+		return -1;
+
 	if (start == 0)
 		start = rtw_get_current_time();
 
@@ -4216,157 +4540,156 @@ s32 rtw_xmit(_adapter *padapter, _pkt **ppkt)
 
 	if (rtw_get_passing_time_ms(start) > 2000) {
 		if (drop_cnt)
-			DBG_871X("DBG_TX_DROP_FRAME %s no more pxmitframe, drop_cnt:%u\n", __FUNCTION__, drop_cnt);
+			RTW_INFO("DBG_TX_DROP_FRAME %s no more pxmitframe, drop_cnt:%u\n", __FUNCTION__, drop_cnt);
 		start = rtw_get_current_time();
 		drop_cnt = 0;
 	}
 
 	if (pxmitframe == NULL) {
-		drop_cnt ++;
-		RT_TRACE(_module_xmit_osdep_c_, _drv_err_, ("rtw_xmit: no more pxmitframe\n"));
+		drop_cnt++;
+		/*RTW_INFO("%s-"ADPT_FMT" no more xmitframe\n", __func__, ADPT_ARG(padapter));*/
 		DBG_COUNTER(padapter->tx_logs.core_tx_err_pxmitframe);
 		return -1;
 	}
 
 #ifdef CONFIG_BR_EXT
+	if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE) {
+		void *br_port = NULL;
 
-#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-	br_port = padapter->pnetdev->br_port;
-#else   // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-	rcu_read_lock();
-	br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
-	rcu_read_unlock();
-#endif  // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-
-	if( br_port && check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE)
-	{
-		res = rtw_br_client_tx(padapter, ppkt);
-		if (res == -1)
-		{
-			rtw_free_xmitframe(pxmitpriv, pxmitframe);
-			DBG_COUNTER(padapter->tx_logs.core_tx_err_brtx);
-			return -1;
-		}
-	}	
-
-#endif	// CONFIG_BR_EXT
-
-	res = update_attrib(padapter, *ppkt, &pxmitframe->attrib);
+		#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+		br_port = padapter->pnetdev->br_port;
+		#else
+		rcu_read_lock();
+		br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
+		rcu_read_unlock();
+		#endif
 
-#ifdef CONFIG_WAPI_SUPPORT
-	if(pxmitframe->attrib.ether_type != 0x88B4)
-	{
-		if(rtw_wapi_drop_for_key_absent(padapter, pxmitframe->attrib.ra))
-		{
-			WAPI_TRACE(WAPI_RX,"drop for key absend when tx \n");
-			res = _FAIL;
+		if (br_port) {
+			res = rtw_br_client_tx(padapter, ppkt);
+			if (res == -1) {
+				rtw_free_xmitframe(pxmitpriv, pxmitframe);
+				DBG_COUNTER(padapter->tx_logs.core_tx_err_brtx);
+				return -1;
+			}
 		}
 	}
-#endif
-	if (res == _FAIL) {
-		RT_TRACE(_module_xmit_osdep_c_, _drv_err_, ("rtw_xmit: update attrib fail\n"));
-		#ifdef DBG_TX_DROP_FRAME
-		DBG_871X("DBG_TX_DROP_FRAME %s update attrib fail\n", __FUNCTION__);
-		#endif
-		rtw_free_xmitframe(pxmitpriv, pxmitframe);
-		return -1;
-	}
-	pxmitframe->pkt = *ppkt;
+#endif /* CONFIG_BR_EXT */
 
-	rtw_led_control(padapter, LED_CTL_TX);
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		_list b2u_list;
 
-	do_queue_select(padapter, &pxmitframe->attrib);
+		res = rtw_mesh_addr_resolve(padapter, pxmitframe, *ppkt, &b2u_list);
+		if (res == RTW_RA_RESOLVING)
+			return 1;
+		if (res == _FAIL)
+			return -1;
 
-#ifdef CONFIG_AP_MODE
-	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
-	if(xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe) == _TRUE)
-	{
-		_exit_critical_bh(&pxmitpriv->lock, &irqL0);
-		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue);
-		return 1;		
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (!rtw_is_list_empty(&b2u_list)) {
+			_list *list = get_next(&b2u_list);
+			struct xmit_frame *b2uframe;
+
+			while ((rtw_end_of_queue_search(&b2u_list, list)) == _FALSE) {
+				b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+				list = get_next(list);
+				rtw_list_delete(&b2uframe->list);
+
+				b2uframe->pkt = rtw_os_pkt_copy(*ppkt);
+				if (!b2uframe->pkt) {
+					if (res == RTW_BMC_NO_NEED)
+						res = _SUCCESS;
+					rtw_free_xmitframe(pxmitpriv, b2uframe);
+					continue;
+				}
+
+				rtw_xmit_posthandle(padapter, b2uframe, b2uframe->pkt);
+			}
+		}
+		#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
+
+		if (res == RTW_BMC_NO_NEED) {
+			rtw_free_xmitframe(&padapter->xmitpriv, pxmitframe);
+			return 0;
+		}
 	}
-	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
-#endif
+#endif /* CONFIG_RTW_MESH */
 
-	//pre_xmitframe
-	if (rtw_hal_xmit(padapter, pxmitframe) == _FALSE)
-		return 1;
+	pxmitframe->pkt = NULL; /* let rtw_xmit_posthandle not to free pkt inside */
+	res = rtw_xmit_posthandle(padapter, pxmitframe, *ppkt);
 
-	return 0;
+	return res;
 }
 
 #ifdef CONFIG_TDLS
 sint xmitframe_enqueue_for_tdls_sleeping_sta(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
-	sint ret=_FALSE;
+	sint ret = _FALSE;
 
 	_irqL irqL;
-	struct sta_info *ptdls_sta=NULL;
+	struct sta_info *ptdls_sta = NULL;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct pkt_attrib *pattrib = &pxmitframe->attrib;
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	int i;
-	
-	ptdls_sta=rtw_get_stainfo(pstapriv, pattrib->dst);
-	if(ptdls_sta==NULL){
+
+	ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->dst);
+	if (ptdls_sta == NULL)
 		return ret;
-	}else if(ptdls_sta->tdls_sta_state&TDLS_LINKED_STATE){
+	else if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
 
-		if(pattrib->triggered==1)
-		{
+		if (pattrib->triggered == 1) {
 			ret = _TRUE;
 			return ret;
 		}
 
-		_enter_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);	
-		
-		if(ptdls_sta->state&WIFI_SLEEP_STATE)
-		{
+		_enter_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
+
+		if (ptdls_sta->state & WIFI_SLEEP_STATE) {
 			rtw_list_delete(&pxmitframe->list);
-		
-			//_enter_critical_bh(&psta->sleep_q.lock, &irqL);	
-			
+
+			/* _enter_critical_bh(&psta->sleep_q.lock, &irqL);	 */
+
 			rtw_list_insert_tail(&pxmitframe->list, get_list_head(&ptdls_sta->sleep_q));
-			
+
 			ptdls_sta->sleepq_len++;
 			ptdls_sta->sleepq_ac_len++;
 
-			//indicate 4-AC queue bit in TDLS peer traffic indication
-			switch(pattrib->priority)
-			{
-				case 1:
-				case 2:
-					ptdls_sta->uapsd_bk |= BIT(1);
-					break;
-				case 4:
-				case 5:
-					ptdls_sta->uapsd_vi |= BIT(1);
-					break;
-				case 6:
-				case 7:
-					ptdls_sta->uapsd_vo |= BIT(1);
-					break;
-				case 0:
-				case 3:
-				default:
-					ptdls_sta->uapsd_be |= BIT(1);
-					break;
+			/* indicate 4-AC queue bit in TDLS peer traffic indication */
+			switch (pattrib->priority) {
+			case 1:
+			case 2:
+				ptdls_sta->uapsd_bk |= BIT(1);
+				break;
+			case 4:
+			case 5:
+				ptdls_sta->uapsd_vi |= BIT(1);
+				break;
+			case 6:
+			case 7:
+				ptdls_sta->uapsd_vo |= BIT(1);
+				break;
+			case 0:
+			case 3:
+			default:
+				ptdls_sta->uapsd_be |= BIT(1);
+				break;
 			}
 
 			/* Transmit TDLS PTI via AP */
-			if(ptdls_sta->sleepq_len==1)
-				rtw_tdls_cmd(padapter, ptdls_sta->hwaddr, TDLS_ISSUE_PTI);
+			if (ptdls_sta->sleepq_len == 1)
+				rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_ISSUE_PTI);
 
 			ret = _TRUE;
 		}
 
-		_exit_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);	
+		_exit_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
 	}
 
 	return ret;
-	
+
 }
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 #define RTW_HIQ_FILTER_ALLOW_ALL 0
 #define RTW_HIQ_FILTER_ALLOW_SPECIAL 1
@@ -4378,36 +4701,31 @@ inline bool xmitframe_hiq_filter(struct xmit_frame *xmitframe)
 	_adapter *adapter = xmitframe->padapter;
 	struct registry_priv *registry = &adapter->registrypriv;
 
-if (rtw_get_intf_type(adapter) != RTW_PCIE) {
-
-	if (adapter->registrypriv.wifi_spec == 1) {
+	if (adapter->registrypriv.wifi_spec == 1)
 		allow = _TRUE;
-	} else if (registry->hiq_filter == RTW_HIQ_FILTER_ALLOW_SPECIAL) {
-	
+	else if (registry->hiq_filter == RTW_HIQ_FILTER_ALLOW_SPECIAL) {
+
 		struct pkt_attrib *attrib = &xmitframe->attrib;
 
 		if (attrib->ether_type == 0x0806
-			|| attrib->ether_type == 0x888e
-			#ifdef CONFIG_WAPI_SUPPORT
-			|| attrib->ether_type == 0x88B4
-			#endif
-			|| attrib->dhcp_pkt
-		) {
+		    || attrib->ether_type == 0x888e
+#ifdef CONFIG_WAPI_SUPPORT
+		    || attrib->ether_type == 0x88B4
+#endif
+		    || attrib->dhcp_pkt
+		   ) {
 			if (0)
-				DBG_871X(FUNC_ADPT_FMT" ether_type:0x%04x%s\n", FUNC_ADPT_ARG(xmitframe->padapter)
-					, attrib->ether_type, attrib->dhcp_pkt?" DHCP":"");
+				RTW_INFO(FUNC_ADPT_FMT" ether_type:0x%04x%s\n", FUNC_ADPT_ARG(xmitframe->padapter)
+					, attrib->ether_type, attrib->dhcp_pkt ? " DHCP" : "");
 			allow = _TRUE;
 		}
-	}
-	else if (registry->hiq_filter == RTW_HIQ_FILTER_ALLOW_ALL) {
+	} else if (registry->hiq_filter == RTW_HIQ_FILTER_ALLOW_ALL)
 		allow = _TRUE;
-	}
-	else if (registry->hiq_filter == RTW_HIQ_FILTER_DENY_ALL) {
-	}
-	else {
+	else if (registry->hiq_filter == RTW_HIQ_FILTER_DENY_ALL)
+		allow = _FALSE;
+	else
 		rtw_warn_on(1);
-	}
-}
+
 	return allow;
 }
 
@@ -4416,8 +4734,8 @@ if (rtw_get_intf_type(adapter) != RTW_PCIE) {
 sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
 	_irqL irqL;
-	sint ret=_FALSE;
-	struct sta_info *psta=NULL;
+	sint 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;
@@ -4425,181 +4743,159 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 	bool update_tim = _FALSE;
 #ifdef CONFIG_TDLS
 
-	if( padapter->tdlsinfo.link_established == _TRUE )
-	{
+	if (padapter->tdlsinfo.link_established == _TRUE)
 		ret = xmitframe_enqueue_for_tdls_sleeping_sta(padapter, pxmitframe);
-	}
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _FALSE)
-	{
+	if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter)) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_fwstate);
-	    return ret;
-	}
-/*
-	if(pattrib->psta)
-	{
-		psta = pattrib->psta;
-	}
-	else
-	{
-		DBG_871X("%s, call rtw_get_stainfo()\n", __func__);
-		psta=rtw_get_stainfo(pstapriv, pattrib->ra);
+		return ret;
 	}
-*/
+	/*
+		if(pattrib->psta)
+		{
+			psta = pattrib->psta;
+		}
+		else
+		{
+			RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
+			psta=rtw_get_stainfo(pstapriv, pattrib->ra);
+		}
+	*/
 	psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-	if(pattrib->psta != psta)
-	{
+	if (pattrib->psta != psta) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_sta);
-		DBG_871X("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
+		RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
 		return _FALSE;
 	}
 
-	if(psta==NULL)
-	{
+	if (psta == NULL) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_nosta);
-		DBG_871X("%s, psta==NUL\n", __func__);
+		RTW_INFO("%s, psta==NUL\n", __func__);
 		return _FALSE;
 	}
 
-	if(!(psta->state &_FW_LINKED))
-	{
+	if (!(psta->state & _FW_LINKED)) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_link);
-		DBG_871X("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
+		RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
 		return _FALSE;
 	}
 
-	if(pattrib->triggered==1)
-	{
+	if (pattrib->triggered == 1) {
 		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_trigger);
-		//DBG_871X("directly xmit pspoll_triggered packet\n");
+		/* RTW_INFO("directly xmit pspoll_triggered packet\n"); */
 
-		//pattrib->triggered=0;
+		/* pattrib->triggered=0; */
 		if (bmcst && xmitframe_hiq_filter(pxmitframe) == _TRUE)
-			pattrib->qsel = QSLT_HIGH;//HIQ
+			pattrib->qsel = QSLT_HIGH;/* HIQ */
 
 		return ret;
 	}
 
 
-	if(bmcst)
-	{
-		_enter_critical_bh(&psta->sleep_q.lock, &irqL);	
-	
-		if(pstapriv->sta_dz_bitmap)//if anyone sta is in ps mode
-		{
-			//pattrib->qsel = QSLT_HIGH;//HIQ
-			
+	if (bmcst) {
+		_enter_critical_bh(&psta->sleep_q.lock, &irqL);
+
+		if (rtw_tim_map_anyone_be_set(padapter, pstapriv->sta_dz_bitmap)) { /* if anyone sta is in ps mode */
+			/* pattrib->qsel = QSLT_HIGH; */ /* HIQ */
+
 			rtw_list_delete(&pxmitframe->list);
-			
-			//_enter_critical_bh(&psta->sleep_q.lock, &irqL);	
-			
+
+			/*_enter_critical_bh(&psta->sleep_q.lock, &irqL);*/
+
 			rtw_list_insert_tail(&pxmitframe->list, get_list_head(&psta->sleep_q));
-			
+
 			psta->sleepq_len++;
 
-			if (!(pstapriv->tim_bitmap & BIT(0)))
+			if (!(rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)))
 				update_tim = _TRUE;
 
-			pstapriv->tim_bitmap |= BIT(0);//
-			pstapriv->sta_dz_bitmap |= BIT(0);
+			rtw_tim_map_set(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, 0);
 
-			//DBG_871X("enqueue, sq_len=%d, tim=%x\n", psta->sleepq_len, pstapriv->tim_bitmap);
-			if (padapter->registrypriv.wifi_spec == 1) {
-				/*
-				*if (update_tim == _TRUE)
-				*	rtw_chk_hi_queue_cmd(padapter);
-				*/
-			} else {
+			/* RTW_INFO("enqueue, sq_len=%d\n", psta->sleepq_len); */
+			/* RTW_INFO_DUMP("enqueue, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
+			if (update_tim == _TRUE) {
+				if (is_broadcast_mac_addr(pattrib->ra))
+					_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "buffer BC");
+				else
+					_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "buffer MC");
+			} else
+				chk_bmc_sleepq_cmd(padapter);
 
-				if (update_tim == _TRUE) {
-					if (is_broadcast_mac_addr(pattrib->ra))
-						_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "buffer BC");
-					else
-						_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "buffer MC");
-				} else {
-					chk_bmc_sleepq_cmd(padapter);
-				}
-			}
+			/*_exit_critical_bh(&psta->sleep_q.lock, &irqL);*/
 
-			//_exit_critical_bh(&psta->sleep_q.lock, &irqL);				
-			
-			ret = _TRUE;			
+			ret = _TRUE;
 
 			DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_mcast);
-			
 		}
-		
-		_exit_critical_bh(&psta->sleep_q.lock, &irqL);	
-		
+
+		_exit_critical_bh(&psta->sleep_q.lock, &irqL);
+
 		return ret;
-		
+
 	}
-	
 
-	_enter_critical_bh(&psta->sleep_q.lock, &irqL);	
-	
-	if(psta->state&WIFI_SLEEP_STATE)
-	{
-		u8 wmmps_ac=0;
-	
-		if(pstapriv->sta_dz_bitmap&BIT(psta->aid))	
-		{			
+
+	_enter_critical_bh(&psta->sleep_q.lock, &irqL);
+
+	if (psta->state & WIFI_SLEEP_STATE) {
+		u8 wmmps_ac = 0;
+
+		if (rtw_tim_map_is_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid)) {
 			rtw_list_delete(&pxmitframe->list);
-		
-			//_enter_critical_bh(&psta->sleep_q.lock, &irqL);	
-			
+
+			/* _enter_critical_bh(&psta->sleep_q.lock, &irqL);	 */
+
 			rtw_list_insert_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;
+			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)
+			if (wmmps_ac)
 				psta->sleepq_ac_len++;
 
-			if(((psta->has_legacy_ac) && (!wmmps_ac)) ||((!psta->has_legacy_ac)&&(wmmps_ac)))
-			{
-				if (!(pstapriv->tim_bitmap & BIT(psta->aid)))
+			if (((psta->has_legacy_ac) && (!wmmps_ac)) || ((!psta->has_legacy_ac) && (wmmps_ac))) {
+				if (!(rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)))
 					update_tim = _TRUE;
 
-				pstapriv->tim_bitmap |= BIT(psta->aid);
+				rtw_tim_map_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-				//DBG_871X("enqueue, sq_len=%d, tim=%x\n", psta->sleepq_len, pstapriv->tim_bitmap);
+				/* RTW_INFO("enqueue, sq_len=%d\n", psta->sleepq_len); */
+				/* RTW_INFO_DUMP("enqueue, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 
-				if(update_tim == _TRUE)
-				{
-					//DBG_871X("sleepq_len==1, update BCNTIM\n");
-					//upate BCN for TIM IE
+				if (update_tim == _TRUE) {
+					/* RTW_INFO("sleepq_len==1, update BCNTIM\n"); */
+					/* upate BCN for TIM IE */
 					_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "buffer UC");
 				}
 			}
 
-			//_exit_critical_bh(&psta->sleep_q.lock, &irqL);			
+			/* _exit_critical_bh(&psta->sleep_q.lock, &irqL);			 */
 
-			//if(psta->sleepq_len > (NR_XMITFRAME>>3))
-			//{
-			//	wakeup_sta_to_xmit(padapter, psta);
-			//}	
+			/* if(psta->sleepq_len > (NR_XMITFRAME>>3)) */
+			/* { */
+			/*	wakeup_sta_to_xmit(padapter, psta); */
+			/* }	 */
 
 			ret = _TRUE;
 
@@ -4608,10 +4904,10 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 
 	}
 
-	_exit_critical_bh(&psta->sleep_q.lock, &irqL);	
+	_exit_critical_bh(&psta->sleep_q.lock, &irqL);
 
 	return ret;
-	
+
 }
 
 static void dequeue_xmitframes_to_sleeping_queue(_adapter *padapter, struct sta_info *psta, _queue *pframequeue)
@@ -4621,163 +4917,149 @@ static void dequeue_xmitframes_to_sleeping_queue(_adapter *padapter, struct sta_
 	u8	ac_index;
 	struct tx_servq	*ptxservq;
 	struct pkt_attrib	*pattrib;
-	struct xmit_frame 	*pxmitframe;
+	struct xmit_frame	*pxmitframe;
 	struct hw_xmit *phwxmits =  padapter->xmitpriv.hwxmits;
-	
+
 	phead = get_list_head(pframequeue);
 	plist = get_next(phead);
-	
-	while (rtw_end_of_queue_search(phead, plist) == _FALSE)
-	{			
+
+	while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
 		pxmitframe = LIST_CONTAINOR(plist, struct xmit_frame, list);
 
 		plist = get_next(plist);
-		
+
 		pattrib = &pxmitframe->attrib;
 
 		pattrib->triggered = 0;
-  		
-		ret = xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe);	
 
-		if(_TRUE == ret)
-		{
+		ret = xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe);
+
+		if (_TRUE == ret) {
 			ptxservq = rtw_get_sta_pending(padapter, psta, pattrib->priority, (u8 *)(&ac_index));
 
 			ptxservq->qcnt--;
 			phwxmits[ac_index].accnt--;
+		} else {
+			/* RTW_INFO("xmitframe_enqueue_for_sleeping_sta return _FALSE\n"); */
 		}
-		else
-		{
-			//DBG_871X("xmitframe_enqueue_for_sleeping_sta return _FALSE\n");
-		}
-		
+
 	}
-	
+
 }
 
 void stop_sta_xmit(_adapter *padapter, struct sta_info *psta)
-{	
-	_irqL irqL0;	
+{
+	_irqL irqL0;
 	struct sta_info *psta_bmc;
 	struct sta_xmit_priv *pstaxmitpriv;
-	struct sta_priv *pstapriv = &padapter->stapriv;	
-	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;	
-	
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+
 	pstaxmitpriv = &psta->sta_xmitpriv;
 
-	//for BC/MC Frames
+	/* for BC/MC Frames */
 	psta_bmc = rtw_get_bcmc_stainfo(padapter);
-	
-			
+
+
 	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
 
 	psta->state |= WIFI_SLEEP_STATE;
-	
+
 #ifdef CONFIG_TDLS
-	if( !(psta->tdls_sta_state & TDLS_LINKED_STATE) )
-#endif //CONFIG_TDLS
-	pstapriv->sta_dz_bitmap |= BIT(psta->aid);
-	
-	
+	if (!(psta->tdls_sta_state & TDLS_LINKED_STATE))
+#endif /* CONFIG_TDLS */
+		rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
 
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vo_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
-
-
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vi_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
-
-
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->be_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
-	
-
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->bk_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
 
 #ifdef CONFIG_TDLS
 	if (!(psta->tdls_sta_state & TDLS_LINKED_STATE) && (psta_bmc != NULL)) {
-#endif //CONFIG_TDLS
-
+#endif /* CONFIG_TDLS */
 
-	//for BC/MC Frames
-	pstaxmitpriv = &psta_bmc->sta_xmitpriv;
-	dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->be_q.sta_pending);
-	rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
-	
+		/* for BC/MC Frames */
+		pstaxmitpriv = &psta_bmc->sta_xmitpriv;
+		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->vo_q.sta_pending);
+		rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
+		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->vi_q.sta_pending);
+		rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
+		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->be_q.sta_pending);
+		rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
+		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->bk_q.sta_pending);
+		rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
 
-#ifdef CONFIG_TDLS	
-		}
-#endif //CONFIG_TDLS	
+#ifdef CONFIG_TDLS
+	}
+#endif /* CONFIG_TDLS	 */
 	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
-	
 
-}	
+
+}
 
 void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)
-{	 
-	_irqL irqL;	 
-	u8 update_mask=0, wmmps_ac=0;
+{
+	_irqL irqL;
+	u8 update_mask = 0, wmmps_ac = 0;
 	struct sta_info *psta_bmc;
 	_list	*xmitframe_plist, *xmitframe_phead;
-	struct xmit_frame *pxmitframe=NULL;
+	struct xmit_frame *pxmitframe = NULL;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 
 	psta_bmc = rtw_get_bcmc_stainfo(padapter);
-	
 
-	//_enter_critical_bh(&psta->sleep_q.lock, &irqL);
+
+	/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
 	_enter_critical_bh(&pxmitpriv->lock, &irqL);
 
 	xmitframe_phead = get_list_head(&psta->sleep_q);
 	xmitframe_plist = get_next(xmitframe_phead);
 
-	while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE)
-	{
+	while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
 		pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
 
 		xmitframe_plist = get_next(xmitframe_plist);
 
 		rtw_list_delete(&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;
+		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)
+		if (psta->sleepq_len > 0)
 			pxmitframe->attrib.mdata = 1;
 		else
 			pxmitframe->attrib.mdata = 0;
 
-		if(wmmps_ac)
-		{
+		if (wmmps_ac) {
 			psta->sleepq_ac_len--;
-			if(psta->sleepq_ac_len>0)
-			{
+			if (psta->sleepq_ac_len > 0) {
 				pxmitframe->attrib.mdata = 1;
 				pxmitframe->attrib.eosp = 0;
-			}
-			else
-			{
+			} else {
 				pxmitframe->attrib.mdata = 0;
 				pxmitframe->attrib.eosp = 1;
 			}
@@ -4785,65 +5067,61 @@ void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)
 
 		pxmitframe->attrib.triggered = 1;
 
-/*
-		_exit_critical_bh(&psta->sleep_q.lock, &irqL);
-		if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
-		{
-			rtw_os_xmit_complete(padapter, pxmitframe);
-		}
-		_enter_critical_bh(&psta->sleep_q.lock, &irqL);
-*/
+		/*
+				_exit_critical_bh(&psta->sleep_q.lock, &irqL);
+				if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
+				{
+					rtw_os_xmit_complete(padapter, pxmitframe);
+				}
+				_enter_critical_bh(&psta->sleep_q.lock, &irqL);
+		*/
 		rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
 
 
 	}
 
-	if(psta->sleepq_len==0)
-	{
+	if (psta->sleepq_len == 0) {
 #ifdef CONFIG_TDLS
-		if( psta->tdls_sta_state & TDLS_LINKED_STATE )
-		{
-			if(psta->state&WIFI_SLEEP_STATE)
+		if (psta->tdls_sta_state & TDLS_LINKED_STATE) {
+			if (psta->state & WIFI_SLEEP_STATE)
 				psta->state ^= WIFI_SLEEP_STATE;
 
 			_exit_critical_bh(&pxmitpriv->lock, &irqL);
 			return;
 		}
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-		if (pstapriv->tim_bitmap & BIT(psta->aid)) {
-			//DBG_871X("wakeup to xmit, qlen==0, update_BCNTIM, tim=%x\n", pstapriv->tim_bitmap);
-			//upate BCN for TIM IE
-			//update_BCNTIM(padapter);
+		if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
+			/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
+			/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
+			/* upate BCN for TIM IE */
+			/* update_BCNTIM(padapter); */
 			update_mask = BIT(0);
 		}
 
-		pstapriv->tim_bitmap &= ~BIT(psta->aid);
+		rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-		if(psta->state&WIFI_SLEEP_STATE)
+		if (psta->state & WIFI_SLEEP_STATE)
 			psta->state ^= WIFI_SLEEP_STATE;
 
-		if(psta->state & WIFI_STA_ALIVE_CHK_STATE)
-		{
-			DBG_871X("%s alive check\n", __func__);
+		if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
+			RTW_INFO("%s alive check\n", __func__);
 			psta->expire_to = pstapriv->expire_to;
 			psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
 		}
 
-		pstapriv->sta_dz_bitmap &= ~BIT(psta->aid);
+		rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
 	}
 
-	//for BC/MC Frames
-	if(!psta_bmc)
+	/* for BC/MC Frames */
+	if (!psta_bmc)
 		goto _exit;
 
-	if((pstapriv->sta_dz_bitmap&0xfffe) == 0x0)//no any sta in ps mode
-	{
+	if (!(rtw_tim_map_anyone_be_set_exclude_aid0(padapter, pstapriv->sta_dz_bitmap))) { /* no any sta in ps mode */
 		xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
 		xmitframe_plist = get_next(xmitframe_phead);
 
-		while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE)
-		{
+		while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
 			pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
 
 			xmitframe_plist = get_next(xmitframe_plist);
@@ -4851,102 +5129,99 @@ void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)
 			rtw_list_delete(&pxmitframe->list);
 
 			psta_bmc->sleepq_len--;
-			if(psta_bmc->sleepq_len>0)
+			if (psta_bmc->sleepq_len > 0)
 				pxmitframe->attrib.mdata = 1;
 			else
 				pxmitframe->attrib.mdata = 0;
 
 
 			pxmitframe->attrib.triggered = 1;
-/*
-			_exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
-			if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
-			{
-				rtw_os_xmit_complete(padapter, pxmitframe);
-			}
-			_enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
-
-*/
+			/*
+						_exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
+						if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
+						{
+							rtw_os_xmit_complete(padapter, pxmitframe);
+						}
+						_enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
+
+			*/
 			rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
 
 		}
 
-		if(psta_bmc->sleepq_len==0)
-		{
-			if (pstapriv->tim_bitmap & BIT(0)) {
-				//DBG_871X("wakeup to xmit, qlen==0, update_BCNTIM, tim=%x\n", pstapriv->tim_bitmap);
-				//upate BCN for TIM IE
-				//update_BCNTIM(padapter);
+		if (psta_bmc->sleepq_len == 0) {
+			if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) {
+				/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
+				/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
+				/* upate BCN for TIM IE */
+				/* update_BCNTIM(padapter); */
 				update_mask |= BIT(1);
 			}
-			pstapriv->tim_bitmap &= ~BIT(0);
-			pstapriv->sta_dz_bitmap &= ~BIT(0);
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
 		}
 
-	}	
+	}
 
 _exit:
 
-	//_exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);	
+	/* _exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);	 */
 	_exit_critical_bh(&pxmitpriv->lock, &irqL);
 
-	if(update_mask)
-	{
-		//update_BCNTIM(padapter);
-		if ((update_mask & (BIT(0)|BIT(1))) == (BIT(0)|BIT(1)))
+	if (update_mask) {
+		/* update_BCNTIM(padapter); */
+		if ((update_mask & (BIT(0) | BIT(1))) == (BIT(0) | BIT(1)))
 			_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "clear UC&BMC");
 		else if ((update_mask & BIT(1)) == BIT(1))
 			_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "clear BMC");
 		else
 			_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "clear UC");
 	}
-	
+
 }
 
 void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta)
 {
 	_irqL irqL;
-	u8 wmmps_ac=0;
+	u8 wmmps_ac = 0;
 	_list	*xmitframe_plist, *xmitframe_phead;
-	struct xmit_frame *pxmitframe=NULL;
+	struct xmit_frame *pxmitframe = NULL;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 
 
-	//_enter_critical_bh(&psta->sleep_q.lock, &irqL);
+	/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
 	_enter_critical_bh(&pxmitpriv->lock, &irqL);
 
 	xmitframe_phead = get_list_head(&psta->sleep_q);
 	xmitframe_plist = get_next(xmitframe_phead);
 
-	while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE)
-	{			
+	while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
 		pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
 
 		xmitframe_plist = get_next(xmitframe_plist);
 
-		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;	
+		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)
+
+		if (!wmmps_ac)
 			continue;
 
 		rtw_list_delete(&pxmitframe->list);
@@ -4954,13 +5229,10 @@ void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta)
 		psta->sleepq_len--;
 		psta->sleepq_ac_len--;
 
-		if(psta->sleepq_ac_len>0)
-		{
+		if (psta->sleepq_ac_len > 0) {
 			pxmitframe->attrib.mdata = 1;
 			pxmitframe->attrib.eosp = 0;
-		}
-		else
-		{
+		} else {
 			pxmitframe->attrib.mdata = 0;
 			pxmitframe->attrib.eosp = 1;
 		}
@@ -4968,28 +5240,27 @@ void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta)
 		pxmitframe->attrib.triggered = 1;
 		rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
 
-		if((psta->sleepq_ac_len==0) && (!psta->has_legacy_ac) && (wmmps_ac))
-		{
+		if ((psta->sleepq_ac_len == 0) && (!psta->has_legacy_ac) && (wmmps_ac)) {
 #ifdef CONFIG_TDLS
-			if(psta->tdls_sta_state & TDLS_LINKED_STATE )
-			{
-				//_exit_critical_bh(&psta->sleep_q.lock, &irqL);
+			if (psta->tdls_sta_state & TDLS_LINKED_STATE) {
+				/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
 				goto exit;
 			}
-#endif //CONFIG_TDLS
-			pstapriv->tim_bitmap &= ~BIT(psta->aid);
+#endif /* CONFIG_TDLS */
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-			//DBG_871X("wakeup to xmit, qlen==0, update_BCNTIM, tim=%x\n", pstapriv->tim_bitmap);
-			//upate BCN for TIM IE
-			//update_BCNTIM(padapter);
+			/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
+			/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
+			/* upate BCN for TIM IE */
+			/* update_BCNTIM(padapter); */
 			update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
-			//update_mask = BIT(0);
+			/* update_mask = BIT(0); */
 		}
-	
-	}	
+
+	}
 
 exit:
-	//_exit_critical_bh(&psta->sleep_q.lock, &irqL);	
+	/* _exit_critical_bh(&psta->sleep_q.lock, &irqL);	 */
 	_exit_critical_bh(&pxmitpriv->lock, &irqL);
 
 	return;
@@ -5013,14 +5284,10 @@ void enqueue_pending_xmitbuf(
 	rtw_list_insert_tail(&pxmitbuf->list, get_list_head(pqueue));
 	_exit_critical_bh(&pqueue->lock, &irql);
 
-
-
 #if defined(CONFIG_SDIO_HCI) && defined(CONFIG_CONCURRENT_MODE)
-	if (pri_adapter->adapter_type > PRIMARY_ADAPTER)
-		pri_adapter = pri_adapter->pbuddy_adapter;
-#endif  //SDIO_HCI + CONCURRENT
+	pri_adapter = GET_PRIMARY_ADAPTER(pri_adapter);
+#endif /*SDIO_HCI + CONCURRENT*/
 	_rtw_up_sema(&(pri_adapter->xmitpriv.xmit_sema));
-
 }
 
 void enqueue_pending_xmitbuf_to_head(
@@ -5028,10 +5295,7 @@ void enqueue_pending_xmitbuf_to_head(
 	struct xmit_buf *pxmitbuf)
 {
 	_irqL irql;
-	_queue *pqueue;
-	_adapter *pri_adapter = pxmitpriv->adapter;
-
-	pqueue = &pxmitpriv->pending_xmitbuf_queue;
+	_queue *pqueue = &pxmitpriv->pending_xmitbuf_queue;
 
 	_enter_critical_bh(&pqueue->lock, &irql);
 	rtw_list_delete(&pxmitbuf->list);
@@ -5039,7 +5303,7 @@ void enqueue_pending_xmitbuf_to_head(
 	_exit_critical_bh(&pqueue->lock, &irql);
 }
 
-struct xmit_buf* dequeue_pending_xmitbuf(
+struct xmit_buf *dequeue_pending_xmitbuf(
 	struct xmit_priv *pxmitpriv)
 {
 	_irqL irql;
@@ -5052,8 +5316,7 @@ struct xmit_buf* dequeue_pending_xmitbuf(
 
 	_enter_critical_bh(&pqueue->lock, &irql);
 
-	if (_rtw_queue_empty(pqueue) == _FALSE)
-	{
+	if (_rtw_queue_empty(pqueue) == _FALSE) {
 		_list *plist, *phead;
 
 		phead = get_list_head(pqueue);
@@ -5067,53 +5330,32 @@ struct xmit_buf* dequeue_pending_xmitbuf(
 	return pxmitbuf;
 }
 
-struct xmit_buf* dequeue_pending_xmitbuf_under_survey(
+static struct xmit_buf *dequeue_pending_xmitbuf_ext(
 	struct xmit_priv *pxmitpriv)
 {
 	_irqL irql;
 	struct xmit_buf *pxmitbuf;
-#ifdef CONFIG_USB_HCI	
-	struct xmit_frame *pxmitframe;
-#endif 
 	_queue *pqueue;
 
-
 	pxmitbuf = NULL;
 	pqueue = &pxmitpriv->pending_xmitbuf_queue;
 
 	_enter_critical_bh(&pqueue->lock, &irql);
 
-	if (_rtw_queue_empty(pqueue) == _FALSE)
-	{
+	if (_rtw_queue_empty(pqueue) == _FALSE) {
 		_list *plist, *phead;
-		u8 type;
+		u8 type = 0;
 
 		phead = get_list_head(pqueue);
 		plist = phead;
 		do {
 			plist = get_next(plist);
-				if (plist == phead) break;
-			
-			pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
+			if (plist == phead)
+				break;
 
-#ifdef CONFIG_USB_HCI
-			pxmitframe = (struct xmit_frame*)pxmitbuf->priv_data;
-			if(pxmitframe)
-			{
-				type = GetFrameSubType(pxmitbuf->pbuf + TXDESC_SIZE + pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
-			}
-			else
-			{
-				DBG_871X("%s, !!!ERROR!!! For USB, TODO ITEM \n", __FUNCTION__);
-			}
-#else
-			type = GetFrameSubType(pxmitbuf->pbuf + TXDESC_OFFSET);
-#endif
+			pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
 
-			if ((type == WIFI_PROBEREQ) ||
-				(type == WIFI_DATA_NULL) ||
-				(type == WIFI_QOS_DATA_NULL))
-			{
+			if (pxmitbuf->buf_tag == XMITBUF_MGNT) {
 				rtw_list_delete(&pxmitbuf->list);
 				break;
 			}
@@ -5126,6 +5368,21 @@ struct xmit_buf* dequeue_pending_xmitbuf_under_survey(
 	return pxmitbuf;
 }
 
+struct xmit_buf *select_and_dequeue_pending_xmitbuf(_adapter *padapter)
+{
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	struct xmit_buf *pxmitbuf = NULL;
+
+	if (_TRUE == rtw_is_xmit_blocked(padapter))
+		return pxmitbuf;
+
+	pxmitbuf = dequeue_pending_xmitbuf_ext(pxmitpriv);
+	if (pxmitbuf == NULL && rtw_xmit_ac_blocked(padapter) != _TRUE)
+		pxmitbuf = dequeue_pending_xmitbuf(pxmitpriv);
+
+	return pxmitbuf;
+}
+
 sint check_pending_xmitbuf(
 	struct xmit_priv *pxmitpriv)
 {
@@ -5137,7 +5394,7 @@ sint check_pending_xmitbuf(
 
 	_enter_critical_bh(&pqueue->lock, &irql);
 
-	if(_rtw_queue_empty(pqueue) == _FALSE)
+	if (_rtw_queue_empty(pqueue) == _FALSE)
 		ret = _TRUE;
 
 	_exit_critical_bh(&pqueue->lock, &irql);
@@ -5161,20 +5418,96 @@ thread_return rtw_xmit_thread(thread_context context)
 		flush_signals_thread();
 	} while (_SUCCESS == err);
 
-	_rtw_up_sema(&padapter->xmitpriv.terminate_xmitthread_sema);
+	RTW_INFO(FUNC_ADPT_FMT " Exit\n", FUNC_ADPT_ARG(padapter));
+
+	rtw_thread_wait_stop();
 
-	thread_exit();
+	return 0;
+}
+#endif
+
+#ifdef DBG_XMIT_BLOCK
+void dump_xmit_block(void *sel, _adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	RTW_PRINT_SEL(sel, "[XMIT-BLOCK] xmit_block :0x%02x\n", dvobj->xmit_block);
+	if (dvobj->xmit_block & XMIT_BLOCK_REDLMEM)
+		RTW_PRINT_SEL(sel, "Reason:%s\n", "XMIT_BLOCK_REDLMEM");
+	if (dvobj->xmit_block & XMIT_BLOCK_SUSPEND)
+		RTW_PRINT_SEL(sel, "Reason:%s\n", "XMIT_BLOCK_SUSPEND");
+	if (dvobj->xmit_block == XMIT_BLOCK_NONE)
+		RTW_PRINT_SEL(sel, "Reason:%s\n", "XMIT_BLOCK_NONE");
+}
+void dump_xmit_block_info(void *sel, const char *fun_name, _adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	RTW_INFO("\n"ADPT_FMT" call %s\n", ADPT_ARG(padapter), fun_name);
+	dump_xmit_block(sel, padapter);
 }
+#define DBG_XMIT_BLOCK_DUMP(adapter)	dump_xmit_block_info(RTW_DBGDUMP, __func__, adapter)
 #endif
 
+void rtw_set_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason)
+{
+	_irqL irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	_enter_critical_bh(&dvobj->xmit_block_lock, &irqL);
+	dvobj->xmit_block |= reason;
+	_exit_critical_bh(&dvobj->xmit_block_lock, &irqL);
+
+	#ifdef DBG_XMIT_BLOCK
+	DBG_XMIT_BLOCK_DUMP(padapter);
+	#endif
+}
+
+void rtw_clr_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason)
+{
+	_irqL irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	_enter_critical_bh(&dvobj->xmit_block_lock, &irqL);
+	dvobj->xmit_block &= ~reason;
+	_exit_critical_bh(&dvobj->xmit_block_lock, &irqL);
+
+	#ifdef DBG_XMIT_BLOCK
+	DBG_XMIT_BLOCK_DUMP(padapter);
+	#endif
+}
+bool rtw_is_xmit_blocked(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	#ifdef DBG_XMIT_BLOCK
+	DBG_XMIT_BLOCK_DUMP(padapter);
+	#endif
+	return ((dvobj->xmit_block) ? _TRUE : _FALSE);
+}
+
 bool rtw_xmit_ac_blocked(_adapter *adapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	_adapter *iface;
 	struct mlme_ext_priv *mlmeext;
 	struct mlme_ext_info *mlmeextinfo;
 	bool blocked = _FALSE;
 	int i;
+#ifdef DBG_CONFIG_ERROR_DETECT
+#ifdef DBG_CONFIG_ERROR_RESET
+#ifdef CONFIG_USB_HCI
+	if (rtw_hal_sreset_inprogress(adapter) == _TRUE) {
+		blocked = _TRUE;
+		goto exit;
+	}
+#endif/* #ifdef CONFIG_USB_HCI */
+#endif/* #ifdef DBG_CONFIG_ERROR_RESET */
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+
+	if (rfctl->offch_state != OFFCHS_NONE)
+		blocked = _TRUE;
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
@@ -5196,14 +5529,227 @@ bool rtw_xmit_ac_blocked(_adapter *adapter)
 		}
 	}
 
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(adapter)) {
+		if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
+			if (MCC_STOP(adapter)) {
+				blocked = _TRUE;
+				goto exit;
+			}
+		}
+	}
+#endif /*  CONFIG_MCC_MODE */
+
 exit:
 	return blocked;
 }
 
+#ifdef CONFIG_TX_AMSDU
+void rtw_amsdu_vo_timeout_handler(void *FunctionContext)
+{
+	_adapter *adapter = (_adapter *)FunctionContext;
+
+	adapter->xmitpriv.amsdu_vo_timeout = RTW_AMSDU_TIMER_TIMEOUT;
+
+	tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
+}
+
+void rtw_amsdu_vi_timeout_handler(void *FunctionContext)
+{
+	_adapter *adapter = (_adapter *)FunctionContext;
+
+	adapter->xmitpriv.amsdu_vi_timeout = RTW_AMSDU_TIMER_TIMEOUT;
+
+	tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
+}
+
+void rtw_amsdu_be_timeout_handler(void *FunctionContext)
+{
+	_adapter *adapter = (_adapter *)FunctionContext;
+
+	adapter->xmitpriv.amsdu_be_timeout = RTW_AMSDU_TIMER_TIMEOUT;
+
+	if (printk_ratelimit())
+		RTW_INFO("%s Timeout!\n",__FUNCTION__);
+
+	tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
+}
+
+void rtw_amsdu_bk_timeout_handler(void *FunctionContext)
+{
+	_adapter *adapter = (_adapter *)FunctionContext;
+
+	adapter->xmitpriv.amsdu_bk_timeout = RTW_AMSDU_TIMER_TIMEOUT;
+
+	tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
+}
+
+u8 rtw_amsdu_get_timer_status(_adapter *padapter, u8 priority)
+{
+	struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
+
+	u8 status =  RTW_AMSDU_TIMER_UNSET;
+
+	switch(priority)
+	{
+		case 1:
+		case 2:
+			status = pxmitpriv->amsdu_bk_timeout;
+			break;
+		case 4:
+		case 5:
+			status = pxmitpriv->amsdu_vi_timeout;
+			break;
+		case 6:
+		case 7:
+			status = pxmitpriv->amsdu_vo_timeout;
+			break;
+		case 0:
+		case 3:
+		default:
+			status = pxmitpriv->amsdu_be_timeout;
+			break;
+	}
+	return status;
+}
+
+void rtw_amsdu_set_timer_status(_adapter *padapter, u8 priority, u8 status)
+{
+	struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
+
+	switch(priority)
+	{
+		case 1:
+		case 2:
+			pxmitpriv->amsdu_bk_timeout = status;
+			break;
+		case 4:
+		case 5:
+			pxmitpriv->amsdu_vi_timeout = status;
+			break;
+		case 6:
+		case 7:
+			pxmitpriv->amsdu_vo_timeout = status;
+			break;
+		case 0:
+		case 3:
+		default:
+			pxmitpriv->amsdu_be_timeout = status;
+			break;
+	}
+}
+
+void rtw_amsdu_set_timer(_adapter *padapter, u8 priority)
+{
+	struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
+
+	_timer* amsdu_timer = NULL;
+
+	switch(priority)
+	{
+		case 1:
+		case 2:
+			amsdu_timer = &pxmitpriv->amsdu_bk_timer;
+			break;
+		case 4:
+		case 5:
+			amsdu_timer = &pxmitpriv->amsdu_vi_timer;
+			break;
+		case 6:
+		case 7:
+			amsdu_timer = &pxmitpriv->amsdu_vo_timer;
+			break;
+		case 0:
+		case 3:
+		default:
+			amsdu_timer = &pxmitpriv->amsdu_be_timer;
+			break;
+	}
+	_set_timer(amsdu_timer, 1);
+}
+
+void rtw_amsdu_cancel_timer(_adapter *padapter, u8 priority)
+{
+	struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
+	_timer* amsdu_timer = NULL;
+
+	switch(priority)
+	{
+		case 1:
+		case 2:
+			amsdu_timer = &pxmitpriv->amsdu_bk_timer;
+			break;
+		case 4:
+		case 5:
+			amsdu_timer = &pxmitpriv->amsdu_vi_timer;
+			break;
+		case 6:
+		case 7:
+			amsdu_timer = &pxmitpriv->amsdu_vo_timer;
+			break;
+		case 0:
+		case 3:
+		default:
+			amsdu_timer = &pxmitpriv->amsdu_be_timer;
+			break;
+	}
+	_cancel_timer_ex(amsdu_timer);
+}
+#endif /* CONFIG_TX_AMSDU */
+
+#ifdef DBG_TXBD_DESC_DUMP
+static struct rtw_tx_desc_backup tx_backup[HW_QUEUE_ENTRY][TX_BAK_FRMAE_CNT];
+static u8 backup_idx[HW_QUEUE_ENTRY];
+
+void rtw_tx_desc_backup(_adapter *padapter, struct xmit_frame *pxmitframe, u8 desc_size, u8 hwq)
+{
+	u16 reg_rp;
+	u16 reg_wp;
+	u32 tmp32;
+	u8 *pxmit_buf;
+
+	if (rtw_get_hw_init_completed(padapter) == _FALSE)
+		return;
+
+	pxmit_buf = pxmitframe->pxmitbuf->pbuf;
+
+	_rtw_memcpy(tx_backup[hwq][backup_idx[hwq]].tx_bak_desc, pxmit_buf, desc_size);
+	_rtw_memcpy(tx_backup[hwq][backup_idx[hwq]].tx_bak_data_hdr, pxmit_buf+desc_size, TX_BAK_DATA_LEN);
+
+	tmp32 = rtw_read32(padapter, get_txbd_rw_reg(hwq));
+
+	tx_backup[hwq][backup_idx[hwq]].tx_bak_rp = (tmp32>>16)&0xfff;
+	tx_backup[hwq][backup_idx[hwq]].tx_bak_wp = tmp32&0xfff;
+
+	tx_backup[hwq][backup_idx[hwq]].tx_desc_size = desc_size;
+
+	backup_idx[hwq] = (backup_idx[hwq] + 1) % TX_BAK_FRMAE_CNT;
+}
+
+void rtw_tx_desc_backup_reset(void)
+{
+	int i, j;
+
+	for (i = 0; i < HW_QUEUE_ENTRY; i++) {
+		for (j = 0; j < TX_BAK_FRMAE_CNT; j++)
+			_rtw_memset(&tx_backup[i][j], 0, sizeof(struct rtw_tx_desc_backup));
+
+		backup_idx[i] = 0;
+	}
+}
+
+u8 rtw_get_tx_desc_backup(_adapter *padapter, u8 hwq, struct rtw_tx_desc_backup **pbak)
+{
+	*pbak = &tx_backup[hwq][0];
+
+	return backup_idx[hwq];
+}
+#endif
+
 void rtw_sctx_init(struct submit_ctx *sctx, int timeout_ms)
 {
 	sctx->timeout_ms = timeout_ms;
-	sctx->submit_time= rtw_get_current_time();
+	sctx->submit_time = rtw_get_current_time();
 #ifdef PLATFORM_LINUX /* TODO: add condition wating interface for other os */
 	init_completion(&sctx->done);
 #endif
@@ -5213,30 +5759,28 @@ void rtw_sctx_init(struct submit_ctx *sctx, int timeout_ms)
 int rtw_sctx_wait(struct submit_ctx *sctx, const char *msg)
 {
 	int ret = _FAIL;
-	unsigned long expire; 
+	unsigned long expire;
 	int status = 0;
 
 #ifdef PLATFORM_LINUX
-	expire= sctx->timeout_ms ? msecs_to_jiffies(sctx->timeout_ms) : MAX_SCHEDULE_TIMEOUT;
+	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_871X("%s timeout: %s\n", __func__, msg);
-	} else {
+		RTW_INFO("%s timeout: %s\n", __func__, msg);
+	} else
 		status = sctx->status;
-	}
 #endif
 
-	if (status == RTW_SCTX_DONE_SUCCESS) {
+	if (status == RTW_SCTX_DONE_SUCCESS)
 		ret = _SUCCESS;
-	}
 
 	return ret;
 }
 
 bool rtw_sctx_chk_waring_status(int status)
 {
-	switch(status) {
+	switch (status) {
 	case RTW_SCTX_DONE_UNKNOWN:
 	case RTW_SCTX_DONE_BUF_ALLOC:
 	case RTW_SCTX_DONE_BUF_FREE:
@@ -5253,11 +5797,11 @@ void rtw_sctx_done_err(struct submit_ctx **sctx, int status)
 {
 	if (*sctx) {
 		if (rtw_sctx_chk_waring_status(status))
-			DBG_871X("%s status:%d\n", __func__, status);
+			RTW_INFO("%s status:%d\n", __func__, status);
 		(*sctx)->status = status;
-		#ifdef PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 		complete(&((*sctx)->done));
-		#endif
+#endif
 		*sctx = NULL;
 	}
 }
@@ -5268,63 +5812,8 @@ void rtw_sctx_done(struct submit_ctx **sctx)
 }
 
 #ifdef CONFIG_XMIT_ACK
-
-#ifdef CONFIG_XMIT_ACK_POLLING
-s32 c2h_evt_hdl(_adapter *adapter, u8 *c2h_evt, c2h_id_filter filter);
-
-/**
- * rtw_ack_tx_polling -
- * @pxmitpriv: xmit_priv to address ack_tx_ops
- * @timeout_ms: timeout msec
- *
- * Init ack_tx_ops and then do c2h_evt_hdl() and polling ack_tx_ops repeatedly
- * till tx report or timeout
- * Returns: _SUCCESS if TX report ok, _FAIL for others
- */
-int rtw_ack_tx_polling(struct xmit_priv *pxmitpriv, u32 timeout_ms)
-{
-	int ret = _FAIL;
-	struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
-	_adapter *adapter = container_of(pxmitpriv, _adapter, xmitpriv);
-
-	pack_tx_ops->submit_time = rtw_get_current_time();
-	pack_tx_ops->timeout_ms = timeout_ms;
-	pack_tx_ops->status = RTW_SCTX_SUBMITTED;
-
-	do {
-		c2h_evt_hdl(adapter, NULL, rtw_hal_c2h_id_filter_ccx(adapter));
-		if (pack_tx_ops->status != RTW_SCTX_SUBMITTED)
-			break;
-
-		if (rtw_is_drv_stopped(adapter)) {
-			pack_tx_ops->status = RTW_SCTX_DONE_DRV_STOP;
-			break;
-		}
-		if (rtw_is_surprise_removed(adapter)) {
-			pack_tx_ops->status = RTW_SCTX_DONE_DEV_REMOVE;
-			break;
-		}
-		
-		rtw_msleep_os(10);
-	} while (rtw_get_passing_time_ms(pack_tx_ops->submit_time) < timeout_ms);
-
-	if (pack_tx_ops->status == RTW_SCTX_SUBMITTED) {
-		pack_tx_ops->status = RTW_SCTX_DONE_TIMEOUT;
-		DBG_871X("%s timeout\n", __func__);
-	}
-
-	if (pack_tx_ops->status == RTW_SCTX_DONE_SUCCESS)
-		ret = _SUCCESS;
-
-	return ret;
-}
-#endif
-
 int rtw_ack_tx_wait(struct xmit_priv *pxmitpriv, u32 timeout_ms)
 {
-#ifdef CONFIG_XMIT_ACK_POLLING
-	return rtw_ack_tx_polling(pxmitpriv, timeout_ms);
-#else
 	struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
 
 	pack_tx_ops->submit_time = rtw_get_current_time();
@@ -5332,18 +5821,15 @@ int rtw_ack_tx_wait(struct xmit_priv *pxmitpriv, u32 timeout_ms)
 	pack_tx_ops->status = RTW_SCTX_SUBMITTED;
 
 	return rtw_sctx_wait(pack_tx_ops, __func__);
-#endif
 }
 
 void rtw_ack_tx_done(struct xmit_priv *pxmitpriv, int status)
 {
 	struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
-	
-	if (pxmitpriv->ack_tx) {
+
+	if (pxmitpriv->ack_tx)
 		rtw_sctx_done_err(&pack_tx_ops, status);
-	} else {
-		DBG_871X("%s ack_tx not set\n", __func__);
-	}
+	else
+		RTW_INFO("%s ack_tx not set\n", __func__);
 }
-#endif //CONFIG_XMIT_ACK
-
+#endif /* CONFIG_XMIT_ACK */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/HalPwrSeqCmd.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/HalPwrSeqCmd.c
index 732c4d8f8b13..ae95ca814807 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/HalPwrSeqCmd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/HalPwrSeqCmd.c
@@ -1,183 +1,186 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-/*++
-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>
-
-
-//
-//	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 HalPwrSeqCmdParsing(
-	PADAPTER		padapter,
-	u8				CutVersion,
-	u8				FabVersion,
-	u8				InterfaceType,
-	WLAN_PWR_CFG	PwrSeqCmd[])
-{
-	WLAN_PWR_CFG 	PwrCfgCmd = {0};
-	u8				bPollingBit = _FALSE;
-	u32				AryIdx = 0;
-	u8				value = 0;
-	u32				offset = 0;
-	u32				pollingCount = 0; // polling autoload done.
-	u32				maxPollingCnt = 5000;
-
-	do {
-		PwrCfgCmd = PwrSeqCmd[AryIdx];
-
-		RT_TRACE(_module_hal_init_c_ , _drv_info_,
-				 ("HalPwrSeqCmdParsing: 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_, ("HalPwrSeqCmdParsing: PWR_CMD_READ\n"));
-					break;
-
-				case PWR_CMD_WRITE:
-					RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_WRITE\n"));
-					offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
-
-#ifdef CONFIG_SDIO_HCI
-					//
-					// <Roger_Notes> We should deal with interface specific address mapping for some interfaces, e.g., SDIO interface
-					// 2011.07.07.
-					//
-					if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
-					{
-						// Read Back SDIO Local value
-						value = SdioLocalCmd52Read1Byte(padapter, offset);
-
-						value &= ~(GET_PWR_CFG_MASK(PwrCfgCmd));
-						value |= (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd));
-
-						// Write Back SDIO Local value
-						SdioLocalCmd52Write1Byte(padapter, offset, value);
-					}
-					else
-#endif
-					{
-#ifdef CONFIG_GSPI_HCI
-						if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
-							offset = SPI_LOCAL_OFFSET | offset;
-#endif
-						// Read the value from system register
-						value = rtw_read8(padapter, offset);
-
-						value=value&(~(GET_PWR_CFG_MASK(PwrCfgCmd)));
-						value=value|(GET_PWR_CFG_VALUE(PwrCfgCmd)&GET_PWR_CFG_MASK(PwrCfgCmd));
-
-						// Write the value back to sytem register
-						rtw_write8(padapter, offset, value);
-					}
-					break;
-
-				case PWR_CMD_POLLING:
-					RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_POLLING\n"));
-
-					bPollingBit = _FALSE;
-					offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
-#ifdef CONFIG_GSPI_HCI
-					if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
-						offset = SPI_LOCAL_OFFSET | offset;
-#endif
-					do {
-#ifdef CONFIG_SDIO_HCI
-						if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
-							value = SdioLocalCmd52Read1Byte(padapter, offset);
-						else
-#endif
-							value = rtw_read8(padapter, offset);
-
-						value=value&GET_PWR_CFG_MASK(PwrCfgCmd);
-						if (value == (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd)))
-							bPollingBit = _TRUE;
-						else
-							rtw_udelay_os(10);
-
-						if (pollingCount++ > maxPollingCnt) {
-							DBG_871X_LEVEL(_drv_err_, "HalPwrSeqCmdParsing: Fail to polling Offset[%#x]=%02x\n", offset, value);
-							return _FALSE;
-						}
-					} while (!bPollingBit);
-
-					break;
-
-				case PWR_CMD_DELAY:
-					RT_TRACE(_module_hal_init_c_ , _drv_info_, ("HalPwrSeqCmdParsing: PWR_CMD_DELAY\n"));
-					if (GET_PWR_CFG_VALUE(PwrCfgCmd) == PWRSEQ_DELAY_US)
-						rtw_udelay_os(GET_PWR_CFG_OFFSET(PwrCfgCmd));
-					else
-						rtw_udelay_os(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_, ("HalPwrSeqCmdParsing: PWR_CMD_END\n"));
-					return _TRUE;
-					break;
-
-				default:
-					RT_TRACE(_module_hal_init_c_ , _drv_err_, ("HalPwrSeqCmdParsing: Unknown CMD!!\n"));
-					break;
-			}
-		}
-
-		AryIdx++;//Add Array Index
-	}while(1);
-
-	return _TRUE;
-}
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+
+/*
+ *	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 HalPwrSeqCmdParsing(
+	PADAPTER		padapter,
+	u8				CutVersion,
+	u8				FabVersion,
+	u8				InterfaceType,
+	WLAN_PWR_CFG	PwrSeqCmd[])
+{
+	WLAN_PWR_CFG	PwrCfgCmd = {0};
+	u8				bPollingBit = _FALSE;
+	u8				bHWICSupport = _FALSE;
+	u32				AryIdx = 0;
+	u8				value = 0;
+	u32				offset = 0;
+	u8				flag = 0;
+	u32				pollingCount = 0; /* polling autoload done. */
+	u32				maxPollingCnt = 5000;
+
+	do {
+		PwrCfgCmd = PwrSeqCmd[AryIdx];
+
+
+		/* 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:
+				break;
+
+			case PWR_CMD_WRITE:
+				offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
+
+#ifdef CONFIG_SDIO_HCI
+				/*  */
+				/* <Roger_Notes> We should deal with interface specific address mapping for some interfaces, e.g., SDIO interface */
+				/* 2011.07.07. */
+				/*  */
+				if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO) {
+					/* Read Back SDIO Local value */
+					value = SdioLocalCmd52Read1Byte(padapter, offset);
+
+					value &= ~(GET_PWR_CFG_MASK(PwrCfgCmd));
+					value |= (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd));
+
+					/* Write Back SDIO Local value */
+					SdioLocalCmd52Write1Byte(padapter, offset, value);
+				} else
+#endif
+				{
+#ifdef CONFIG_GSPI_HCI
+					if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
+						offset = SPI_LOCAL_OFFSET | offset;
+#endif
+					/* Read the value from system register */
+					value = rtw_read8(padapter, offset);
+
+					value = value & (~(GET_PWR_CFG_MASK(PwrCfgCmd)));
+					value = value | (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd));
+
+					/* Write the value back to sytem register */
+					rtw_write8(padapter, offset, value);
+				}
+				break;
+
+			case PWR_CMD_POLLING:
+
+				bPollingBit = _FALSE;
+				offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
+
+				rtw_hal_get_hwreg(padapter, HW_VAR_PWR_CMD, &bHWICSupport);
+				if (bHWICSupport && offset == 0x06) {
+					flag = 0;
+					maxPollingCnt = 100000;
+				} else
+					maxPollingCnt = 5000;
+
+#ifdef CONFIG_GSPI_HCI
+				if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
+					offset = SPI_LOCAL_OFFSET | offset;
+#endif
+				do {
+#ifdef CONFIG_SDIO_HCI
+					if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
+						value = SdioLocalCmd52Read1Byte(padapter, offset);
+					else
+#endif
+						value = rtw_read8(padapter, offset);
+
+					value = value & GET_PWR_CFG_MASK(PwrCfgCmd);
+					if (value == (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd)))
+						bPollingBit = _TRUE;
+					else
+						rtw_udelay_os(10);
+
+					if (pollingCount++ > maxPollingCnt) {
+						RTW_ERR("HalPwrSeqCmdParsing: Fail to polling Offset[%#x]=%02x\n", offset, value);
+
+						/* For PCIE + USB package poll power bit timeout issue only modify 8821AE and 8723BE */
+						if (bHWICSupport && offset == 0x06  && flag == 0) {
+
+							RTW_ERR("[WARNING] PCIE polling(0x%X) timeout(%d), Toggle 0x04[3] and try again.\n", offset, maxPollingCnt);
+							if (IS_HARDWARE_TYPE_8723DE(padapter))
+								PlatformEFIOWrite1Byte(padapter, 0x40, (PlatformEFIORead1Byte(padapter, 0x40)) & (~BIT3));
+
+							PlatformEFIOWrite1Byte(padapter, 0x04, PlatformEFIORead1Byte(padapter, 0x04) | BIT3);
+							PlatformEFIOWrite1Byte(padapter, 0x04, PlatformEFIORead1Byte(padapter, 0x04) & ~BIT3);
+
+							if (IS_HARDWARE_TYPE_8723DE(padapter))
+								PlatformEFIOWrite1Byte(padapter, 0x40, PlatformEFIORead1Byte(padapter, 0x40)|BIT3);
+
+							/* Retry Polling Process one more time */
+							pollingCount = 0;
+							flag = 1;
+						} else {
+							return _FALSE;
+						}
+					}
+				} while (!bPollingBit);
+
+				break;
+
+			case PWR_CMD_DELAY:
+				if (GET_PWR_CFG_VALUE(PwrCfgCmd) == PWRSEQ_DELAY_US)
+					rtw_udelay_os(GET_PWR_CFG_OFFSET(PwrCfgCmd));
+				else
+					rtw_udelay_os(GET_PWR_CFG_OFFSET(PwrCfgCmd) * 1000);
+				break;
+
+			case PWR_CMD_END:
+				/* When this command is parsed, end the process */
+				return _TRUE;
+				break;
+
+			default:
+				break;
+			}
+		}
+
+		AryIdx++;/* Add Array Index */
+	} while (1);
+
+	return _TRUE;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8188c2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8188c2Ant.c
deleted file mode 100644
index ac82d7336115..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8188c2Ant.c
+++ /dev/null
@@ -1,1988 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for 92CE/92CU BT 1 Antenna Co-exist mechanism
-//
-// By cosa 02/11/2011
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8188c2Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8188C_2ANT	GLCoexDm8188c2Ant;
-static PCOEX_DM_8188C_2ANT 	pCoexDm=&GLCoexDm8188c2Ant;
-static COEX_STA_8188C_2ANT	GLCoexSta8188c2Ant;
-static PCOEX_STA_8188C_2ANT	pCoexSta=&GLCoexSta8188c2Ant;
-
-//============================================================
-// local function start with btdm_
-//============================================================
-u1Byte
-halbtc8188c2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8188C_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8188C_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8188C_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-u1Byte
-halbtc8188c2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	u1Byte				algorithm=BT_8188C_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-	
-	if(!pStackInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No profile exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pStackInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bA2dpExist)
-		numOfDiffProfile++;
-
-	if(pStackInfo->bScoExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO algorithm\n"));
-		algorithm = BT_8188C_2ANT_COEX_ALGO_SCO;
-	}
-	else
-	{
-		if(numOfDiffProfile == 1)
-		{
-			if(pStackInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8188C_2ANT_COEX_ALGO_HID;
-			}
-			else if(pStackInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8188C_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pStackInfo->bPanExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN only\n"));
-				algorithm = BT_8188C_2ANT_COEX_ALGO_PAN;
-			}
-		}
-		else
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-				algorithm = BT_8188C_2ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist )
-			{				
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN\n"));
-				algorithm = BT_8188C_2ANT_COEX_ALGO_HID_PAN;
-			}
-			else if( pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{				
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN + A2DP\n"));
-				algorithm = BT_8188C_2ANT_COEX_ALGO_PAN_A2DP;
-			}
-		}		
-	}
-	return algorithm;
-}
-
-VOID
-halbtc8188c2ant_SetFwBalance(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bBalanceOn,
-	IN	u1Byte			ms0,
-	IN	u1Byte			ms1
-	)
-{
-	u1Byte	H2C_Parameter[3] ={0};
-
-	if(bBalanceOn)
-	{
-		H2C_Parameter[2] = 1;
-		H2C_Parameter[1] = ms1;
-		H2C_Parameter[0] = ms0;
-	}
-	else
-	{
-		H2C_Parameter[2] = 0;
-		H2C_Parameter[1] = 0;
-		H2C_Parameter[0] = 0;
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], 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]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0xc, 3, H2C_Parameter);	
-}
-
-VOID
-halbtc8188c2ant_Balance(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bBalanceOn,
-	IN	u1Byte			ms0,
-	IN	u1Byte			ms1
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Balance %s\n", 
-		(bForceExec? "force to":""), (bBalanceOn? "ON":"OFF")));
-	pCoexDm->bCurBalanceOn = bBalanceOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBalanceOn == pCoexDm->bCurBalanceOn)
-			return;
-	}
-	halbtc8188c2ant_SetFwBalance(pBtCoexist, bBalanceOn, ms0, ms1);
-
-	pCoexDm->bPreBalanceOn = pCoexDm->bCurBalanceOn;
-}
-
-VOID
-halbtc8188c2ant_SetFwDiminishWifi(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN 		bDacOn,
-	IN	BOOLEAN 		bInterruptOn,
-	IN	u1Byte			fwDacSwingLvl,
-	IN	BOOLEAN 		bNavOn
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-
-	if((pBtCoexist->stackInfo.minBtRssi <= -5) && (fwDacSwingLvl == 0x20))
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], DiminishWiFi 0x20 original, but set 0x18 for Low RSSI!\n"));
-		fwDacSwingLvl = 0x18;
-	}
-
-	H2C_Parameter[2] = 0;
-	H2C_Parameter[1] = fwDacSwingLvl;
-	H2C_Parameter[0] = 0;
-	if(bDacOn)
-	{
-		H2C_Parameter[2] |= 0x01;	//BIT0
-		if(bInterruptOn)
-		{
-			H2C_Parameter[2] |= 0x02;	//BIT1
-		}
-	}
-	if(bNavOn)
-	{
-		H2C_Parameter[2] |= 0x08;	//BIT3
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bDacOn=%s, bInterruptOn=%s, bNavOn=%s, write 0xe=0x%x\n", 
-		(bDacOn?"ON":"OFF"), (bInterruptOn?"ON":"OFF"), (bNavOn?"ON":"OFF"),
-		(H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2])));
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0xe, 3, H2C_Parameter);
-}
-
-VOID
-halbtc8188c2ant_DiminishWifi(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacOn,
-	IN	BOOLEAN			bInterruptOn,
-	IN	u1Byte			fwDacSwingLvl,
-	IN	BOOLEAN			bNavOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set Diminish Wifi, bDacOn=%s, bInterruptOn=%s, fwDacSwingLvl=%d, bNavOn=%s\n", 
-		(bForceExec? "force to":""), (bDacOn? "ON":"OFF"), (bInterruptOn? "ON":"OFF"), fwDacSwingLvl, (bNavOn? "ON":"OFF")));
-
-	pCoexDm->bCurDacOn = bDacOn;
-	pCoexDm->bCurInterruptOn = bInterruptOn;
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-	pCoexDm->bCurNavOn = bNavOn;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacOn==pCoexDm->bCurDacOn) &&
-			(pCoexDm->bPreInterruptOn==pCoexDm->bCurInterruptOn) &&
-			(pCoexDm->preFwDacSwingLvl==pCoexDm->curFwDacSwingLvl) &&
-			(pCoexDm->bPreNavOn==pCoexDm->bCurNavOn) )
-			return;
-	}
-	halbtc8188c2ant_SetFwDiminishWifi(pBtCoexist, bDacOn, bInterruptOn, fwDacSwingLvl, bNavOn);
-
-	pCoexDm->bPreDacOn = pCoexDm->bCurDacOn;
-	pCoexDm->bPreInterruptOn = pCoexDm->bCurInterruptOn;
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-	pCoexDm->bPreNavOn = pCoexDm->bCurNavOn;
-}
-
-VOID
-halbtc8188c2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xf0, 0xf);		
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xf0, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8188c2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8188c2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8188c2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte	tmpU1;
-
-	tmpU1 = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd);
-	if(bLowPenaltyRa)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set low penalty!!\n"));
-		tmpU1 &= ~BIT2;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set normal!!\n"));
-		tmpU1 |= BIT2;
-	}
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, tmpU1);
-}
-
-VOID
-halbtc8188c2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8188c2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8188c2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	u4Byte	dacSwingLvl;
-
-	if(bSwDacSwingOn)
-	{		
-		if((pBtCoexist->stackInfo.minBtRssi <= -5) && (swDacSwingLvl == 0x20))
-		{
-			dacSwingLvl = 0x18;
-		}
-		else
-		{
-			dacSwingLvl = swDacSwingLvl;
-		}
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xfc000000, dacSwingLvl);
-	}
-	else
-	{
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xfc000000, 0x30);
-	}
-}
-
-VOID
-halbtc8188c2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8188c2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8188c2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc04,0x3a07611);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc04,0x3a05611);
-	}
-}
-
-VOID
-halbtc8188c2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8188c2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8188c2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4e1c0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4d1d0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4c1e0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4b1f0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4a200001);
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xdc000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x90000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x51000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x12000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1a, 0xfffff, 0x00255);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x641c0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x631d0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x621e0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x611f0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x60200001);
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x32000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x71000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xb0000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xfc000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1a, 0xfffff, 0x10255);
-	}
-
-	// set rssiAdjustVal for wifi module.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-
-VOID
-halbtc8188c2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8188c2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8188c2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u4Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8188c2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u4Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8188c2ant_SetCoexTable(pBtCoexist, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8188c2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw mechanism
-	halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-	halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-	// sw mechanism
-	halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-}
-VOID
-halbtc8188c2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-
-VOID
-halbtc8188c2ant_MonitorBtState(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	BOOLEAN			stateChange=FALSE;
-	u4Byte 			BT_Polling, Ratio_Act, Ratio_STA;
-	u4Byte 			BT_Active, BT_State;
-	u4Byte			regBTActive=0, regBTState=0, regBTPolling=0;
-	u4Byte			btBusyThresh=0;
-	u4Byte			fwVer=0;
-	static BOOLEAN	bBtBusyTraffic=FALSE;
-	BOOLEAN			bRejApAggPkt=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FirmwareVersion = 0x%x(%d)\n", fwVer, fwVer));
-	if(fwVer < 62)
-	{
-		regBTActive = 0x488;
-		regBTState = 0x48c;
-		regBTPolling = 0x490;
-	}
-	else
-	{
-		regBTActive = 0x444;
-		regBTState = 0x448;
-		if(fwVer >= 74)
-			regBTPolling = 0x44c;
-		else
-			regBTPolling = 0x700;
-	}
-	btBusyThresh = 60;
-	
-	BT_Active = pBtCoexist->fBtcRead4Byte(pBtCoexist, regBTActive);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT_Active(0x%x)=0x%x\n", regBTActive, BT_Active));
-	BT_Active = BT_Active & 0x00ffffff;
-
-	BT_State = pBtCoexist->fBtcRead4Byte(pBtCoexist, regBTState);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT_State(0x%x)=0x%x\n", regBTState, BT_State));
-	BT_State = BT_State & 0x00ffffff;
-
-	BT_Polling = pBtCoexist->fBtcRead4Byte(pBtCoexist, regBTPolling);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT_Polling(0x%x)=0x%x\n", regBTPolling, BT_Polling));
-
-	if(BT_Active==0xffffffff && BT_State==0xffffffff && BT_Polling==0xffffffff )
-		return;
-
-	// 2011/05/04 MH For Slim combo test meet a problem. Surprise remove and WLAN is running
-	// DHCP process. At the same time, the register read value might be zero. And cause BSOD 0x7f
-	// EXCEPTION_DIVIDED_BY_ZERO. In This case, the stack content may always be wrong due to 
-	// HW divide trap.
-	if (BT_Polling==0)
-		return;
-	
-	Ratio_Act = BT_Active*1000/BT_Polling;
-	Ratio_STA = BT_State*1000/BT_Polling;
-		
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ratio_Act=%d\n", Ratio_Act));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ratio_STA=%d\n", Ratio_STA));
-
-	if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		if(Ratio_STA < 60)	// BT PAN idle
-		{
-		}
-		else
-		{
-			// Check if BT PAN (under BT 2.1) is uplink or downlink
-			if((Ratio_Act/Ratio_STA) < 2)
-			{	// BT PAN Uplink
-				pCoexSta->bBtUplink = TRUE;
-			}
-			else
-			{	// BT PAN downlink
-				pCoexSta->bBtUplink = FALSE;
-			}
-		}
-	}	
-	
-	// Check BT is idle or not
-	if(!pBtCoexist->stackInfo.bBtLinkExist)
-	{
-		pCoexSta->bBtBusy = FALSE;
-	}
-	else
-	{
-		if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-		{
-			if(Ratio_Act<20)
-			{
-				pCoexSta->bBtBusy = FALSE;
-			}
-			else
-			{
-				pCoexSta->bBtBusy = TRUE;
-			}
-		}
-		else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-		{
-			if(Ratio_STA < btBusyThresh)
-			{
-				pCoexSta->bBtBusy = FALSE;
-			}
-			else
-			{
-				pCoexSta->bBtBusy = TRUE;
-			}
-
-			if( (Ratio_STA < btBusyThresh) ||
-				(Ratio_Act<180 && Ratio_STA<130) )
-			{
-				pCoexSta->bA2dpBusy = FALSE;
-			}
-			else
-			{
-				pCoexSta->bA2dpBusy = TRUE;
-			}
-		}
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &pCoexSta->bBtBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &pCoexSta->bBtBusy);
-	
-	if(bBtBusyTraffic != pCoexSta->bBtBusy)
-	{	// BT idle or BT non-idle
-		bBtBusyTraffic = pCoexSta->bBtBusy;
-		stateChange = TRUE;
-	}
-
-	if(stateChange)
-	{
-		if(!pCoexSta->bBtBusy)
-		{
-			halbtc8188c2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_CoexAllOff(pBtCoexist);
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-		}
-		else
-		{
-			halbtc8188c2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8188c2ant_RfShrink(pBtCoexist, NORMAL_EXEC, TRUE);
-		}
-	}
-
-	if(stateChange)
-	{
-		bRejApAggPkt = pCoexSta->bBtBusy;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejApAggPkt);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionA2dpBc4(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			wifiRssiState;
-	u4Byte			wifiBw, wifiTrafficDir;
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-	
-	if(pCoexSta->bBtBusy)
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			// fw mechanism first
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0xc, 0x18);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x20, FALSE);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-			}
-
-			// sw mechanism 
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-		}
-		else
-		{
-			wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0xc, 0x18);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x20, FALSE);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-			}
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-			}
-			else
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-			}
-		}
-	}
-	else
-	{
-		halbtc8188c2ant_CoexAllOff(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionA2dpBc8(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			wifiRssiState;
-	u4Byte			wifiBw, wifiTrafficDir;
-	BOOLEAN			bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	if(pCoexSta->bA2dpBusy && bWifiBusy)
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-		wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-
-		// fw mechanism first
-		if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0xc, 0x18);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-		else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x10, 0x18);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-
-		// sw mechanism 
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-		else
-		{
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-			else
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-	}
-	else if(pCoexSta->bA2dpBusy)
-	{
-		// fw mechanism first
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, TRUE, 0x18, FALSE);
-
-		// sw mechanism 
-		halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-	}
-	else
-	{
-		halbtc8188c2ant_CoexAllOff(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionA2dpBc4(pBtCoexist);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionA2dpBc8(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionPanBc4(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-	if(bBtHsOn)
-	{
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-	}
-	else
-	{
-		if(pCoexSta->bBtBusy && bWifiBusy)
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x10);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-		else
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-		}
-	}
-	// sw mechanism
-	halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-}
-
-VOID
-halbtc8188c2ant_ActionPanBc8(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw, wifiTrafficDir;
-	s4Byte		wifiRssi;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(bBtHsOn)
-	{
-		halbtc8188c2ant_CoexAllOff(pBtCoexist);
-	}
-	else
-	{
-		wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 3, 25, 50);
-
-		if(pCoexSta->bBtBusy && bWifiBusy)
-		{
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				// fw mechanism first
-				if(pCoexSta->bBtUplink)
-				{
-					halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x20);
-					halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				else
-				{
-					halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-					halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-				}
-				// sw mechanism 
-				if(BTC_WIFI_BW_HT40 == wifiBw)
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				}
-				else
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				}
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				if(pCoexSta->bBtUplink)
-				{
-					halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-				else
-				{
-					halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-				}
-			}
-			else if( (wifiRssiState == BTC_RSSI_STATE_MEDIUM) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_MEDIUM) )
-			{
-				// fw mechanism first
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x20);
-
-				if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-				{
-					halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-				{
-					if(BTC_WIFI_BW_HT40 == wifiBw)
-						halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);//BT_FW_NAV_ON);
-					else
-						halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				// sw mechanism 
-				if(BTC_WIFI_BW_HT40 == wifiBw)
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				}
-				else
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				}
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-			else
-			{
-				// fw mechanism first
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x20);
-				
-				if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-				{
-					halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-				{
-					if(pCoexSta->bBtUplink)
-					{
-						if(BTC_WIFI_BW_HT40 == wifiBw)
-						{
-							halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);//BT_FW_NAV_ON);
-						}
-						else
-						{
-							halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-						}						
-					}
-					else
-					{
-						halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-					}
-				}
-				// sw mechanism 
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-		else if(pCoexSta->bBtBusy && !bWifiBusy && (wifiRssi < 30))
-		{
-			// fw mechanism first
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x0a, 0x20);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-			// sw mechanism 
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-		else
-		{
-			halbtc8188c2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionPan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionPanBc4(pBtCoexist);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionPanBc8(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte		wifiBw, wifiTrafficDir;
-	BOOLEAN 	bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-	if(BTC_WIFI_BW_LEGACY == wifiBw)
-	{
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-		halbtc8188c2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-	}
-	else if(!bWifiBusy)
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-	}
-	else if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-	{
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-		halbtc8188c2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-	}
-	else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-	}
-	// sw mechanism
-	halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-}
-
-
-VOID
-halbtc8188c2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState;
-	u4Byte	wifiBw;
-
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-		
-		// fw mechanism
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-		// sw mechanism
-		halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			// fw mechanism first
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism 
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-		else
-		{
-			wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-			// fw mechanism first
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-			else
-			{			
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);	
-			}
-		}
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionHidA2dpBc4(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw, wifiTrafficDir;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-
-	if(pCoexSta->bBtBusy)
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			// fw mechanism first
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x7, 0x20);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x20, FALSE);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-			}
-
-			// sw mechanism 
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-		}
-		else
-		{
-			wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-			// fw mechanism first
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x7, 0x20);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x20, FALSE);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-			}
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-			else
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-		}
-	}
-	else
-	{
-		halbtc8188c2ant_CoexAllOff(pBtCoexist);
-	}
-}
-VOID
-halbtc8188c2ant_ActionHidA2dpBc8(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw;
-	
-	if(pCoexSta->bBtBusy)
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			// fw mechanism first
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism 
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-		}
-		else
-		{
-			wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-			// fw mechanism
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-			else
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-		}
-	}
-	else
-	{
-		halbtc8188c2ant_CoexAllOff(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionHidA2dpBc4(pBtCoexist);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionHidA2dpBc8(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionHidPanBc4(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u4Byte		wifiBw, wifiTrafficDir;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	
-	if(bBtHsOn)
-	{	
-		halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-		halbtc8188c2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-	}
-	else
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-		if(BTC_WIFI_BW_LEGACY == wifiBw)
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-			halbtc8188c2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-		}
-		else if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-			
-			halbtc8188c2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-		}
-		else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x10);					
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-		else if(!bWifiBusy)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-		}			
-	}
-	halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-}
-VOID
-halbtc8188c2ant_ActionHidPanBc8(	
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw, wifiTrafficDir;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!bBtHsOn)
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 2, 25, 0);
-		if((pCoexSta->bBtBusy && bWifiBusy))
-		{
-			// fw mechanism first
-			if(pCoexSta->bBtUplink)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x15, 0x20);
-			}
-			else
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x10, 0x20);
-			}
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-				if(BTC_WIFI_BW_HT40 == wifiBw)
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-					halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-				else
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-			}
-			else
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-		else
-		{
-			halbtc8188c2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-	else
-	{
-		if(BTC_INTF_USB == pBtCoexist->chipInterface)
-		{	
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-				halbtc8188c2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-		}
-		else 
-		{
-			if(pCoexSta->bBtBusy)
-			{
-				// fw mechanism
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-				// sw mechanism
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-			}
-			else
-			{
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionHidPan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{		
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionHidPanBc4(pBtCoexist);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionHidPanBc8(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionPanA2dpBc4(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-	if(bBtHsOn)
-	{
-		if(pCoexSta->bBtBusy)
-		{
-			// fw mechanism
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-		}
-		else
-		{
-			halbtc8188c2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-	else
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		if(pCoexSta->bBtBusy && bWifiBusy)
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x10);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-		else
-		{
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-		}			
-		// sw mechanism
-		halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-	}
-}
-VOID
-halbtc8188c2ant_ActionPanA2dpBc8(	
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!bBtHsOn)
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		wifiRssiState = halbtc8188c2ant_WifiRssiState(pBtCoexist, 0, 2, 25, 0);
-		if((pCoexSta->bBtBusy && bWifiBusy))
-		{
-			// fw mechanism first
-			if(pCoexSta->bBtUplink)
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x15, 0x20);
-			}
-			else
-			{
-				halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x10, 0x20);
-			}
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-				if(BTC_WIFI_BW_HT40 == wifiBw)
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-					halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-				else	
-				{
-					halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-			}
-			else
-			{
-				halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-		else
-		{
-			halbtc8188c2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-	else
-	{
-		if(pCoexSta->bBtBusy)
-		{
-			// fw mechanism
-			halbtc8188c2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8188c2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism			
-			halbtc8188c2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-		}
-		else
-		{
-			halbtc8188c2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-	}
-}
-
-VOID
-halbtc8188c2ant_ActionPanA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionPanA2dpBc4(pBtCoexist);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8188c2ant_ActionPanA2dpBc8(pBtCoexist);
-	}
-}
-
-//============================================================
-// extern function start with EXhalbtc8188c2ant_
-//============================================================
-VOID
-EXhalbtc8188c2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8188c2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	u1Byte	u1Tmp=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	// backup rf 0x1e value
-	pCoexDm->btRf0x1eBackup = 
-		pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xf0);
-
-	if( (BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType) ||
-		(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType) )
-	{
-		u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd) & BIT0;
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, u1Tmp);
-		
-		halbtc8188c2ant_CoexTable(pBtCoexist, FORCE_EXEC, 0xaaaa9aaa, 0xffbd0040, 0x40000010);
-	}
-}
-
-VOID
-EXhalbtc8188c2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8188c2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8188c2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-	
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "[Action Manual control]!!");
-		CL_PRINTF(cliBuf);
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-	
-	if(pStackInfo->bProfileNotified)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-			pStackInfo->bScoExist, pStackInfo->bHidExist, pStackInfo->bPanExist, pStackInfo->bA2dpExist);
-		CL_PRINTF(cliBuf);	
-
-		pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-	}
-	
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x40", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x6c4/0x6c8/0x6cc(coexTable)", \
-		u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8188c2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		halbtc8188c2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		//halbtc8188c2ant_InitCoexDm(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8188c2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		halbtc8188c2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		halbtc8188c2ant_InitCoexDm(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8188c2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8188c2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8188c2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{	
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-	
-}
-
-VOID
-EXhalbtc8188c2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8188c2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-}
-
-VOID
-EXhalbtc8188c2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	EXhalbtc8188c2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8188c2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u1Byte	algorithm;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Periodical!!\n"));
-
-	// NOTE:
-	// sw mechanism must be done after fw mechanism
-	// 
-
-	if((BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType) ||
-		(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType) )
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_GET_BT_RSSI, NULL);
-
-		halbtc8188c2ant_MonitorBtState(pBtCoexist);
-		algorithm = halbtc8188c2ant_ActionAlgorithm(pBtCoexist);	
-		pCoexDm->curAlgorithm = algorithm;
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8188C_2ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO\n"));
-				halbtc8188c2ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8188C_2ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID\n"));
-				halbtc8188c2ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8188C_2ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP\n"));
-				halbtc8188c2ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8188C_2ANT_COEX_ALGO_PAN:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN\n"));
-				halbtc8188c2ant_ActionPan(pBtCoexist);
-				break;
-			case BT_8188C_2ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP\n"));
-				halbtc8188c2ant_ActionHidA2dp(pBtCoexist);
-				break;
-			case BT_8188C_2ANT_COEX_ALGO_HID_PAN:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+HID\n"));
-				halbtc8188c2ant_ActionHidPan(pBtCoexist);
-				break;
-			case BT_8188C_2ANT_COEX_ALGO_PAN_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP\n"));
-				halbtc8188c2ant_ActionPanA2dp(pBtCoexist);
-				break;
-			default:
-				break;
-		}
-	}
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8188c2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8188c2Ant.h
deleted file mode 100644
index 64e55aa01bf0..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8188c2Ant.h
+++ /dev/null
@@ -1,150 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8188C 2Ant BT Co-exist definition
-//===========================================
-#define		BTC_RSSI_COEX_THRESH_TOL_8188C_2ANT		6
-
-typedef enum _BT_INFO_SRC_8188C_2ANT{
-	BT_INFO_SRC_8188C_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8188C_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8188C_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8188C_2ANT_MAX
-}BT_INFO_SRC_8188C_2ANT,*PBT_INFO_SRC_8188C_2ANT;
-
-typedef enum _BT_8188C_2ANT_BT_STATUS{
-	BT_8188C_2ANT_BT_STATUS_IDLE				= 0x0,
-	BT_8188C_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,
-	BT_8188C_2ANT_BT_STATUS_NON_IDLE			= 0x2,
-	BT_8188C_2ANT_BT_STATUS_MAX
-}BT_8188C_2ANT_BT_STATUS,*PBT_8188C_2ANT_BT_STATUS;
-
-typedef enum _BT_8188C_2ANT_COEX_ALGO{
-	BT_8188C_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8188C_2ANT_COEX_ALGO_SCO					= 0x1,
-	BT_8188C_2ANT_COEX_ALGO_HID					= 0x2,
-	BT_8188C_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8188C_2ANT_COEX_ALGO_PAN					= 0x4,
-	BT_8188C_2ANT_COEX_ALGO_HID_A2DP			= 0x5,
-	BT_8188C_2ANT_COEX_ALGO_HID_PAN				= 0x6,
-	BT_8188C_2ANT_COEX_ALGO_PAN_A2DP			= 0x7,
-	BT_8188C_2ANT_COEX_ALGO_MAX
-}BT_8188C_2ANT_COEX_ALGO,*PBT_8188C_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8188C_2ANT{
-	// fw mechanism
-	BOOLEAN		bPreBalanceOn;
-	BOOLEAN		bCurBalanceOn;
-
-	// diminishWifi
-	BOOLEAN		bPreDacOn;
-	BOOLEAN		bCurDacOn;
-	BOOLEAN 	bPreInterruptOn;
-	BOOLEAN		bCurInterruptOn;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN 	bPreNavOn;
-	BOOLEAN		bCurNavOn;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	//u4Byte		preVal0x6c0;
-	//u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u4Byte		preVal0x6cc;
-	u4Byte		curVal0x6cc;
-	//BOOLEAN		bLimitedDig;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	//u1Byte		btStatus;
-	//u1Byte		wifiChnlInfo[3];
-} COEX_DM_8188C_2ANT, *PCOEX_DM_8188C_2ANT;
-
-typedef struct _COEX_STA_8188C_2ANT{
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bBtBusy;
-	BOOLEAN					bBtUplink;
-	BOOLEAN					bBtDownLink;
-	BOOLEAN					bA2dpBusy;
-}COEX_STA_8188C_2ANT, *PCOEX_STA_8188C_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8188c2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8188c2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8188c2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8188c2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8188c2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8188c2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8188c2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8188c2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8188c2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8188c2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8188c2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8188c2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8188c2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192d2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192d2Ant.c
deleted file mode 100644
index 6f8e68f48d1a..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192d2Ant.c
+++ /dev/null
@@ -1,1993 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for 92D BT 2 Antenna Co-exist mechanism
-//
-// By cosa 02/11/2011
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8192d2Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8192D_2ANT	GLCoexDm8192d2Ant;
-static PCOEX_DM_8192D_2ANT 	pCoexDm=&GLCoexDm8192d2Ant;
-static COEX_STA_8192D_2ANT	GLCoexSta8192d2Ant;
-static PCOEX_STA_8192D_2ANT	pCoexSta=&GLCoexSta8192d2Ant;
-
-//============================================================
-// local function start with btdm_
-//============================================================
-u1Byte
-halbtc8192d2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192D_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192D_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8192D_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-u1Byte
-halbtc8192d2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8192D_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	
-	if(!pStackInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No profile exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pStackInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bA2dpExist)
-		numOfDiffProfile++;
-
-	if(pStackInfo->bScoExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO algorithm\n"));
-		algorithm = BT_8192D_2ANT_COEX_ALGO_SCO;
-	}
-	else
-	{
-		if(numOfDiffProfile == 1)
-		{
-			if(pStackInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8192D_2ANT_COEX_ALGO_HID;
-			}
-			else if(pStackInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8192D_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pStackInfo->bPanExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN only\n"));
-				algorithm = BT_8192D_2ANT_COEX_ALGO_PAN;
-			}
-		}
-		else
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-				algorithm = BT_8192D_2ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist )
-			{				
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN\n"));
-				algorithm = BT_8192D_2ANT_COEX_ALGO_HID_PAN;
-			}
-			else if( pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{				
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN + A2DP\n"));
-				algorithm = BT_8192D_2ANT_COEX_ALGO_PAN_A2DP;
-			}
-		}		
-	}
-	return algorithm;
-}
-
-VOID
-halbtc8192d2ant_SetFwBalance(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bBalanceOn,
-	IN	u1Byte			ms0,
-	IN	u1Byte			ms1
-	)
-{
-	u1Byte	H2C_Parameter[3] ={0};
-
-	if(bBalanceOn)
-	{
-		H2C_Parameter[2] = 1;
-		H2C_Parameter[1] = ms1;
-		H2C_Parameter[0] = ms0;
-	}
-	else
-	{
-		H2C_Parameter[2] = 0;
-		H2C_Parameter[1] = 0;
-		H2C_Parameter[0] = 0;
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], 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]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0xc, 3, H2C_Parameter);	
-}
-
-VOID
-halbtc8192d2ant_Balance(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bBalanceOn,
-	IN	u1Byte			ms0,
-	IN	u1Byte			ms1
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Balance %s\n", 
-		(bForceExec? "force to":""), (bBalanceOn? "ON":"OFF")));
-	pCoexDm->bCurBalanceOn = bBalanceOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBalanceOn == pCoexDm->bCurBalanceOn)
-			return;
-	}
-	halbtc8192d2ant_SetFwBalance(pBtCoexist, bBalanceOn, ms0, ms1);
-
-	pCoexDm->bPreBalanceOn = pCoexDm->bCurBalanceOn;
-}
-
-VOID
-halbtc8192d2ant_SetFwDiminishWifi(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN 		bDacOn,
-	IN	BOOLEAN 		bInterruptOn,
-	IN	u1Byte			fwDacSwingLvl,
-	IN	BOOLEAN 		bNavOn
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-
-	if((pBtCoexist->stackInfo.minBtRssi <= -5) && (fwDacSwingLvl == 0x20))
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], DiminishWiFi 0x20 original, but set 0x18 for Low RSSI!\n"));
-		fwDacSwingLvl = 0x18;
-	}
-
-	H2C_Parameter[2] = 0;
-	H2C_Parameter[1] = fwDacSwingLvl;
-	H2C_Parameter[0] = 0;
-	if(bDacOn)
-	{
-		H2C_Parameter[2] |= 0x01;	//BIT0
-		if(bInterruptOn)
-		{
-			H2C_Parameter[2] |= 0x02;	//BIT1
-		}
-	}
-	if(bNavOn)
-	{
-		H2C_Parameter[2] |= 0x08;	//BIT3
-	}
-		
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bDacOn=%s, bInterruptOn=%s, bNavOn=%s, write 0x12=0x%x\n", 
-		(bDacOn?"ON":"OFF"), (bInterruptOn?"ON":"OFF"), (bNavOn?"ON":"OFF"),
-		(H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2])));		
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x12, 3, H2C_Parameter);
-}
-
-
-VOID
-halbtc8192d2ant_DiminishWifi(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacOn,
-	IN	BOOLEAN			bInterruptOn,
-	IN	u1Byte			fwDacSwingLvl,
-	IN	BOOLEAN			bNavOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set Diminish Wifi, bDacOn=%s, bInterruptOn=%s, fwDacSwingLvl=%d, bNavOn=%s\n", 
-		(bForceExec? "force to":""), (bDacOn? "ON":"OFF"), (bInterruptOn? "ON":"OFF"), fwDacSwingLvl, (bNavOn? "ON":"OFF")));
-
-	pCoexDm->bCurDacOn = bDacOn;
-	pCoexDm->bCurInterruptOn = bInterruptOn;
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-	pCoexDm->bCurNavOn = bNavOn;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacOn==pCoexDm->bCurDacOn) &&
-			(pCoexDm->bPreInterruptOn==pCoexDm->bCurInterruptOn) &&
-			(pCoexDm->preFwDacSwingLvl==pCoexDm->curFwDacSwingLvl) &&
-			(pCoexDm->bPreNavOn==pCoexDm->bCurNavOn) )
-			return;
-	}
-	halbtc8192d2ant_SetFwDiminishWifi(pBtCoexist, bDacOn, bInterruptOn, fwDacSwingLvl, bNavOn);
-
-	pCoexDm->bPreDacOn = pCoexDm->bCurDacOn;
-	pCoexDm->bPreInterruptOn = pCoexDm->bCurInterruptOn;
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-	pCoexDm->bPreNavOn = pCoexDm->bCurNavOn;
-}
-
-VOID
-halbtc8192d2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xf2ff7);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-
-VOID
-halbtc8192d2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8192d2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8192d2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte	tmpU1;
-
-	tmpU1 = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd);
-	if(bLowPenaltyRa)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set low penalty!!\n"));
-		tmpU1 &= ~BIT2;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set normal!!\n"));
-		tmpU1 |= BIT2;
-	}
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, tmpU1);
-}
-
-VOID
-halbtc8192d2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8192d2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8192d2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	u4Byte	dacSwingLvl;
-
-	if(bSwDacSwingOn)
-	{		
-		if((pBtCoexist->stackInfo.minBtRssi <= -5) && (swDacSwingLvl == 0x20))
-		{
-			dacSwingLvl = 0x18;
-		}
-		else
-		{
-			dacSwingLvl = swDacSwingLvl;
-		}
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xfc000000, dacSwingLvl);
-	}
-	else
-	{
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xfc000000, 0x30);
-	}
-}
-
-VOID
-halbtc8192d2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8192d2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8192d2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc04,0x3a07611);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc04,0x3a05611);
-	}
-}
-
-VOID
-halbtc8192d2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8192d2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8192d2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1a, 0xfffff, 0xa99);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xd4000);
-		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b000001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b010001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b020001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b030001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b040001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b050001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b060001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b070001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b080001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b090001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b0A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7b0B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7a0C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x790D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x780E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x770F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x76100001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x75110001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x74120001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x73130001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x72140001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x71150001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x70160001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6f170001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6e180001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6d190001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6c1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6b1B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6a1C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x691D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x4f1E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x4e1F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x4d200001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x4c210001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x4b220001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x4a230001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x49240001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x48250001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x47260001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x46270001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x45280001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x44290001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x432A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x422B0001);
-
-		rssiAdjustVal = 12;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1a, 0xfffff, 0x30a99);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xdc000);
-
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7B000001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7B010001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7B020001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7B030001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7B040001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7B050001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7B060001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x7A070001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x79080001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x78090001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x770A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x760B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x750C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x740D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x730E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x720F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x71100001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x70110001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6F120001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6E130001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6D140001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6C150001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6B160001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6A170001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x69180001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x68190001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x671A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x661B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x651C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x641D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x631E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x621F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x61200001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x60210001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x49220001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x48230001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x47240001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x46250001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x45260001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x44270001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x43280001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x42290001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x412A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x402B0001);
-	}
-
-	// set rssiAdjustVal for wifi module.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-
-
-VOID
-halbtc8192d2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8192d2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8192d2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u4Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8192d2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u4Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8192d2ant_SetCoexTable(pBtCoexist, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8192d2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw mechanism
-	halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-	halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-	// sw mechanism
-	halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-}
-VOID
-halbtc8192d2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-halbtc8192d2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte			btActive
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte		btDisableCnt=0;
-	BOOLEAN			bBtDisabled=FALSE, bForceToRoam=FALSE;
-	u4Byte			u4Tmp=0;
-
-	// This function check if bt is disabled
-	if(btActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-
-		bForceToRoam = TRUE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_FORCE_TO_ROAM, &bForceToRoam);
-
-		bPreBtDisabled = bBtDisabled;
-	}
-}
-
-VOID
-halbtc8192d2ant_MonitorBtState(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	BOOLEAN 		stateChange=FALSE;
-	u4Byte			BT_Polling, Ratio_Act, Ratio_STA;
-	u4Byte			BT_Active, BT_State;
-	u4Byte			regBTActive=0, regBTState=0, regBTPolling=0;
-	u4Byte			btBusyThresh=0;
-	u4Byte			fwVer=0;
-	static BOOLEAN	bBtBusyTraffic=FALSE;
-	BOOLEAN 		bRejApAggPkt=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FirmwareVersion = 0x%x(%d)\n", fwVer, fwVer));
-	
-	regBTActive = 0x444;
-	regBTState = 0x448;
-	regBTPolling = 0x44c;	
-	
-	btBusyThresh = 40;
-	
-	BT_Active = pBtCoexist->fBtcRead4Byte(pBtCoexist, regBTActive);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT_Active(0x%x)=0x%x\n", regBTActive, BT_Active));
-	BT_Active = BT_Active & 0x00ffffff;
-
-	BT_State = pBtCoexist->fBtcRead4Byte(pBtCoexist, regBTState);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT_State(0x%x)=0x%x\n", regBTState, BT_State));
-	BT_State = BT_State & 0x00ffffff;
-
-	BT_Polling = pBtCoexist->fBtcRead4Byte(pBtCoexist, regBTPolling);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT_Polling(0x%x)=0x%x\n", regBTPolling, BT_Polling));
-
-	if(BT_Active==0xffffffff && BT_State==0xffffffff && BT_Polling==0xffffffff )
-		return;
-
-	// 2011/05/04 MH For Slim combo test meet a problem. Surprise remove and WLAN is running
-	// DHCP process. At the same time, the register read value might be zero. And cause BSOD 0x7f
-	// EXCEPTION_DIVIDED_BY_ZERO. In This case, the stack content may always be wrong due to 
-	// HW divide trap.
-	if (BT_Polling==0)
-		return;
-
-	halbtc8192d2ant_MonitorBtEnableDisable(pBtCoexist, BT_Active);
-	
-	Ratio_Act = BT_Active*1000/BT_Polling;
-	Ratio_STA = BT_State*1000/BT_Polling;
-		
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ratio_Act=%d\n", Ratio_Act));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ratio_STA=%d\n", Ratio_STA));
-
-	if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		if(Ratio_STA < 60)	// BT PAN idle
-		{
-		}
-		else
-		{
-			// Check if BT PAN (under BT 2.1) is uplink or downlink
-			if((Ratio_Act/Ratio_STA) < 2)
-			{	// BT PAN Uplink
-				pCoexSta->bBtUplink = TRUE;
-			}
-			else
-			{	// BT PAN downlink
-				pCoexSta->bBtUplink = FALSE;
-			}
-		}
-	}	
-	
-	// Check BT is idle or not
-	if(!pBtCoexist->stackInfo.bBtLinkExist)
-	{
-		pCoexSta->bBtBusy = FALSE;
-	}
-	else
-	{
-		if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-		{
-			if(Ratio_Act<20)
-			{
-				pCoexSta->bBtBusy = FALSE;
-			}
-			else
-			{
-				pCoexSta->bBtBusy = TRUE;
-			}
-		}
-		else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-		{
-			if(Ratio_STA < btBusyThresh)
-			{
-				pCoexSta->bBtBusy = FALSE;
-			}
-			else
-			{
-				pCoexSta->bBtBusy = TRUE;
-			}
-
-			if( (Ratio_STA < btBusyThresh) ||
-				(Ratio_Act<180 && Ratio_STA<130) )
-			{
-				pCoexSta->bA2dpBusy = FALSE;
-			}
-			else
-			{
-				pCoexSta->bA2dpBusy = TRUE;
-			}
-		}
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &pCoexSta->bBtBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &pCoexSta->bBtBusy);
-	
-	if(bBtBusyTraffic != pCoexSta->bBtBusy)
-	{	// BT idle or BT non-idle
-		bBtBusyTraffic = pCoexSta->bBtBusy;
-		stateChange = TRUE;
-	}
-
-	if(stateChange)
-	{
-		if(!pCoexSta->bBtBusy)
-		{
-			halbtc8192d2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_CoexAllOff(pBtCoexist);
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-		}
-		else
-		{
-			halbtc8192d2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8192d2ant_RfShrink(pBtCoexist, NORMAL_EXEC, TRUE);
-		}
-	}
-
-	if(stateChange)
-	{
-		bRejApAggPkt = pCoexSta->bBtBusy;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejApAggPkt);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-	}
-}
-
-VOID
-halbtc8192d2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			wifiRssiState, wifiRssiState1=BTC_RSSI_STATE_HIGH;
-	u4Byte			wifiBw, wifiTrafficDir;
-	BOOLEAN 		bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-
-	wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-	if(pCoexSta->bA2dpBusy && bWifiBusy)
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			wifiRssiState1 = halbtc8192d2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		}
-		else
-		{
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				wifiRssiState1 = halbtc8192d2ant_WifiRssiState(pBtCoexist, 1, 2, 25, 0);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				wifiRssiState1 = halbtc8192d2ant_WifiRssiState(pBtCoexist, 1, 2, 40, 0);
-			}
-		}
-
-		// fw mechanism first
-		if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-		{
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0xc, 0x18);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-		else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-		{
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x10, 0x18);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-
-		// sw mechanism 
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-		}
-		else
-		{
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		}
-		
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-		else
-		{
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-			else
-			{
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-	}
-	else if(pCoexSta->bA2dpBusy)
-	{
-		// fw mechanism first
-		halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, TRUE, 0x18, FALSE);
-
-		// sw mechanism 
-		halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-	}
-	else
-	{
-		halbtc8192d2ant_CoexAllOff(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8192d2ant_ActionPan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN 	bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState, wifiRssiState1;
-	u4Byte		wifiBw, wifiTrafficDir;
-	s4Byte		wifiRssi;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-
-	if(bBtHsOn)
-	{
-		halbtc8192d2ant_CoexAllOff(pBtCoexist);
-	}
-	else
-	{
-		wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 3, 25, 50);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			wifiRssiState1 = halbtc8192d2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		}
-		else
-		{			
-			wifiRssiState1 = halbtc8192d2ant_WifiRssiState(pBtCoexist, 1, 2, 25, 0);
-		}
-
-		if(pCoexSta->bBtBusy && bWifiBusy)
-		{
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				// fw mechanism first
-				if(pCoexSta->bBtUplink)
-				{
-					halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x20);
-					halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				else
-				{
-					halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-					halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-				}
-				// sw mechanism 
-				if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-					(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				}
-				else
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				}
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				if(pCoexSta->bBtUplink)
-				{
-					halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-				else
-				{
-					halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-				}
-			}
-			else if( (wifiRssiState == BTC_RSSI_STATE_MEDIUM) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_MEDIUM) )
-			{
-				// fw mechanism first
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x20);
-
-				if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-				{
-					halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-				{
-					if(BTC_WIFI_BW_HT40 == wifiBw)
-						halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);//BT_FW_NAV_ON);
-					else
-						halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				// sw mechanism 
-				if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-					(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				}
-				else
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				}
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-			else
-			{
-				// fw mechanism first
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x20);
-				
-				if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-				{
-					halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-				}
-				else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-				{
-					if(pCoexSta->bBtUplink)
-					{
-						if(BTC_WIFI_BW_HT40 == wifiBw)
-						{
-							halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);//BT_FW_NAV_ON);
-						}
-						else
-						{
-							halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-						}						
-					}
-					else
-					{
-						halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-					}
-				}
-				// sw mechanism 
-				if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-					(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-				}
-				else
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				}
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-		else if(pCoexSta->bBtBusy && 
-				!bWifiBusy &&
-				(wifiRssi < 30))
-		{
-			// fw mechanism first
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x0a, 0x20);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-			// sw mechanism 
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-		else
-		{
-			halbtc8192d2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-}
-
-
-VOID
-halbtc8192d2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiTrafficDir;
-	BOOLEAN 	bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-	if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-	{
-		wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 2, 45, 0);
-	}
-	else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-	{
-		wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 2, 20, 0);
-	}
-		
-	if(pCoexSta->bBtBusy && bWifiBusy)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			// fw mechanism first
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-			
-			// sw mechanism 			
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-		}
-		else
-		{
-			// fw mechanism first
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, TRUE, 0x18, FALSE);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x15, 0x15);
-				halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x30, FALSE);
-			}			
-			// sw mechanism 
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-	}
-	else
-	{
-		halbtc8192d2ant_CoexAllOff(pBtCoexist);
-	}
-}
-
-
-
-VOID
-halbtc8192d2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState;
-	u4Byte	wifiBw;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism first
-		halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-		// sw mechanism 		
-		halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-	}
-	else
-	{
-		// fw mechanism first
-		halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-		else
-		{
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-	}
-}
-
-VOID
-halbtc8192d2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1;
-	u4Byte		wifiBw;
-
-	if(pCoexSta->bBtBusy)
-	{
-		wifiRssiState1 = halbtc8192d2ant_WifiRssiState(pBtCoexist, 1, 2, 35, 0);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			// fw mechanism first
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-
-			// sw mechanism 
-			if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			}
-			else
-			{
-				halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			}
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-		}
-		else
-		{
-			wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-			// fw mechanism
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism 
-			if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			}
-			else
-			{
-				halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			}
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-			else
-			{
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-		}
-	}
-	else
-	{
-		halbtc8192d2ant_CoexAllOff(pBtCoexist);
-	}
-}
-
-
-VOID
-halbtc8192d2ant_ActionHidPanBc4(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u4Byte		wifiBw, wifiTrafficDir;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	
-	if(bBtHsOn)
-	{
-		halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-		halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-		halbtc8192d2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-	}
-	else
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-		if(BTC_WIFI_BW_LEGACY == wifiBw)
-		{
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-			halbtc8192d2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-		}
-		else if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-		{
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-			
-			halbtc8192d2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-		}
-		else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x10);					
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-		else if(!bWifiBusy)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-		}			
-	}
-	halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-}
-VOID
-halbtc8192d2ant_ActionHidPanBc8(	
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw, wifiTrafficDir;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!bBtHsOn)
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 2, 25, 0);
-		if((pCoexSta->bBtBusy && bWifiBusy))
-		{
-			// fw mechanism first
-			if(pCoexSta->bBtUplink)
-			{
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x15, 0x20);
-			}
-			else
-			{
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x10, 0x20);
-			}
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-				if(BTC_WIFI_BW_HT40 == wifiBw)
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-					halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-				else
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-			}
-			else
-			{
-				halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-		else
-		{
-			halbtc8192d2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-	else
-	{
-		if(BTC_INTF_USB == pBtCoexist->chipInterface)
-		{	
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-			if(BTC_WIFI_TRAFFIC_TX == wifiTrafficDir)
-			{
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-
-				halbtc8192d2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x000000f0, 0x40000010);
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0xa0);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-			else if(BTC_WIFI_TRAFFIC_RX == wifiTrafficDir)
-			{
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-			}
-		}
-		else 
-		{
-			if(pCoexSta->bBtBusy)
-			{
-				// fw mechanism
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-				halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-				// sw mechanism
-				halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-			}
-			else
-			{
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-	}
-}
-
-VOID
-halbtc8192d2ant_ActionHidPan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{		
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8192d2ant_ActionHidPanBc4(pBtCoexist);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8192d2ant_ActionHidPanBc8(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8192d2ant_ActionPanA2dpBc4(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x0);
-	if(bBtHsOn)
-	{
-		if(pCoexSta->bBtBusy)
-		{
-			// fw mechanism
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-		}
-		else
-		{
-			halbtc8192d2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-	else
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		if(pCoexSta->bBtBusy && bWifiBusy)
-		{
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x20, 0x10);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-		}
-		else
-		{
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x0, FALSE);
-		}			
-		// sw mechanism
-		halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-	}
-}
-VOID
-halbtc8192d2ant_ActionPanA2dpBc8(	
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bBtHsOn=FALSE, bWifiBusy=FALSE;
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!bBtHsOn)
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		wifiRssiState = halbtc8192d2ant_WifiRssiState(pBtCoexist, 0, 2, 25, 0);
-		if((pCoexSta->bBtBusy && bWifiBusy))
-		{
-			// fw mechanism first
-			if(pCoexSta->bBtUplink)
-			{
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x15, 0x20);
-			}
-			else
-			{
-				halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, TRUE, 0x10, 0x20);
-			}
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x20, FALSE);
-
-			// sw mechanism 
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-				if(BTC_WIFI_BW_HT40 == wifiBw)
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-					halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-				else	
-				{
-					halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-					halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-				}
-			}
-			else
-			{
-				halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-				halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-			}
-		}
-		else
-		{
-			halbtc8192d2ant_CoexAllOff(pBtCoexist);
-		}
-	}
-	else
-	{
-		if(pCoexSta->bBtBusy)
-		{
-			// fw mechanism
-			halbtc8192d2ant_Balance(pBtCoexist, NORMAL_EXEC, FALSE, 0, 0);
-			halbtc8192d2ant_DiminishWifi(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0, FALSE);
-
-			// sw mechanism			
-			halbtc8192d2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x20);
-		}
-		else
-		{
-			halbtc8192d2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0x30);
-		}
-	}
-}
-
-VOID
-halbtc8192d2ant_ActionPanA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	if(BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8192d2ant_ActionPanA2dpBc4(pBtCoexist);
-	}
-	else if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		halbtc8192d2ant_ActionPanA2dpBc8(pBtCoexist);
-	}
-}
-
-BOOLEAN
-halbtc8192d2ant_IsBtCoexistEnter(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			macPhyMode;
-	BOOLEAN			bRet=TRUE;
-	BOOLEAN			bWifiUnder5G=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_MAC_PHY_MODE, &macPhyMode);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-	
-	if(BTC_SMSP != macPhyMode)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Only support single mac single phy!!\n"));
-		bRet = FALSE;
-	}
-
-	if(bWifiUnder5G)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under 5G or A band\n"));
-		halbtc8192d2ant_CoexAllOff(pBtCoexist);
-		bRet = FALSE;
-	}
-
-	return bRet;
-}
-
-//============================================================
-// extern function start with EXhalbtc8192d2ant_
-//============================================================
-VOID
-EXhalbtc8192d2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8192d2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	u1Byte	u1Tmp=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	// backup rf 0x1e value
-	pCoexDm->btRf0x1eBackup = 
-		pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);
-
-	if( (BTC_CHIP_CSR_BC4 == pBtCoexist->boardInfo.btChipType) ||
-		(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType) )
-	{
-		u1Tmp =  pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd) & BIT0;
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, u1Tmp);
-		
-		halbtc8192d2ant_CoexTable(pBtCoexist, FORCE_EXEC, 0xaaaa9aaa, 0xffbd0040, 0x40000010);
-
-		// switch control, here we set pathA to control
-		// 0x878[13] = 1, 0:pathB, 1:pathA(default)
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x878, BIT13, 0x1);
-		
-		// antsel control, here we use phy0 and enable antsel.
-		// 0x87c[16:15] = b'11, enable antsel, antsel output pin
-		// 0x87c[30] = 0, 0: phy0, 1:phy 1
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x87c, bMaskDWord, 0x1fff8);
-		
-		// antsel to Bt or Wifi, it depends Bt on/off.
-		// 0x860[9:8] = 'b10, b10:Bt On, WL2G off(default), b01:Bt off, WL2G on.
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x860, BIT9|BIT8, 0x2);
-		
-		// sw/hw control switch, here we set sw control
-		// 0x870[9:8] = 'b11 sw control, 'b00 hw control
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x870, BIT9|BIT8, 0x3);
-	}
-}
-
-VOID
-EXhalbtc8192d2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8192d2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8192d2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-	
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "[Action Manual control]!!");
-		CL_PRINTF(cliBuf);
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-	
-	if(pStackInfo->bProfileNotified)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-			pStackInfo->bScoExist, pStackInfo->bHidExist, pStackInfo->bPanExist, pStackInfo->bA2dpExist);
-		CL_PRINTF(cliBuf);	
-
-		pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-	}
-	
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x40", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x6c4/0x6c8/0x6cc(coexTable)", \
-		u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8192d2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		halbtc8192d2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		//halbtc8192d2ant_InitCoexDm(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8192d2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		halbtc8192d2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		halbtc8192d2ant_InitCoexDm(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8192d2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8192d2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8192d2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{	
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}	
-}
-
-VOID
-EXhalbtc8192d2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8192d2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-}
-
-VOID
-EXhalbtc8192d2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	EXhalbtc8192d2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8192d2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u1Byte	algorithm;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Periodical!!\n"));
-
-	// NOTE:
-	// sw mechanism must be done after fw mechanism
-	// 
-	if(!halbtc8192d2ant_IsBtCoexistEnter(pBtCoexist))
-		return;
-
-	if(BTC_CHIP_CSR_BC8 == pBtCoexist->boardInfo.btChipType)
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_GET_BT_RSSI, NULL);
-
-		halbtc8192d2ant_MonitorBtState(pBtCoexist);
-		algorithm = halbtc8192d2ant_ActionAlgorithm(pBtCoexist);	
-		pCoexDm->curAlgorithm = algorithm;
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8192D_2ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO\n"));
-				halbtc8192d2ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8192D_2ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID\n"));
-				halbtc8192d2ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8192D_2ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP\n"));
-				halbtc8192d2ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8192D_2ANT_COEX_ALGO_PAN:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN\n"));
-				halbtc8192d2ant_ActionPan(pBtCoexist);
-				break;
-			case BT_8192D_2ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP\n"));
-				halbtc8192d2ant_ActionHidA2dp(pBtCoexist);
-				break;
-			case BT_8192D_2ANT_COEX_ALGO_HID_PAN:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+HID\n"));
-				halbtc8192d2ant_ActionHidPan(pBtCoexist);
-				break;
-			case BT_8192D_2ANT_COEX_ALGO_PAN_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP\n"));
-				halbtc8192d2ant_ActionPanA2dp(pBtCoexist);
-				break;
-			default:
-				break;
-		}
-	}
-}
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192d2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192d2Ant.h
deleted file mode 100644
index d21fd68db5d2..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192d2Ant.h
+++ /dev/null
@@ -1,171 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8192D 2Ant BT Co-exist definition
-//===========================================
-#define		BTC_RSSI_COEX_THRESH_TOL_8192D_2ANT		6
-
-typedef enum _BT_INFO_SRC_8192D_2ANT{
-	BT_INFO_SRC_8192D_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8192D_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8192D_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8192D_2ANT_MAX
-}BT_INFO_SRC_8192D_2ANT,*PBT_INFO_SRC_8192D_2ANT;
-
-typedef enum _BT_8192D_2ANT_BT_STATUS{
-	BT_8192D_2ANT_BT_STATUS_IDLE				= 0x0,
-	BT_8192D_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,
-	BT_8192D_2ANT_BT_STATUS_NON_IDLE			= 0x2,
-	BT_8192D_2ANT_BT_STATUS_MAX
-}BT_8192D_2ANT_BT_STATUS,*PBT_8192D_2ANT_BT_STATUS;
-
-typedef enum _BT_8192D_2ANT_COEX_ALGO{
-	BT_8192D_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8192D_2ANT_COEX_ALGO_SCO					= 0x1,
-	BT_8192D_2ANT_COEX_ALGO_HID					= 0x2,
-	BT_8192D_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8192D_2ANT_COEX_ALGO_PAN					= 0x4,
-	BT_8192D_2ANT_COEX_ALGO_HID_A2DP			= 0x5,
-	BT_8192D_2ANT_COEX_ALGO_HID_PAN				= 0x6,
-	BT_8192D_2ANT_COEX_ALGO_PAN_A2DP			= 0x7,
-	BT_8192D_2ANT_COEX_ALGO_MAX
-}BT_8192D_2ANT_COEX_ALGO,*PBT_8192D_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8192D_2ANT{
-	// fw mechanism
-	BOOLEAN		bPreBalanceOn;
-	BOOLEAN		bCurBalanceOn;
-
-	// diminishWifi
-	BOOLEAN		bPreDacOn;
-	BOOLEAN		bCurDacOn;
-	BOOLEAN 	bPreInterruptOn;
-	BOOLEAN		bCurInterruptOn;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN 	bPreNavOn;
-	BOOLEAN		bCurNavOn;
-
-
-	
-
-	
-	//BOOLEAN		bPreDecBtPwr;
-	//BOOLEAN		bCurDecBtPwr;
-
-	//u1Byte		preFwDacSwingLvl;
-	//u1Byte		curFwDacSwingLvl;
-	//BOOLEAN		bCurIgnoreWlanAct;
-	//BOOLEAN		bPreIgnoreWlanAct;
-	//u1Byte		prePsTdma;
-	//u1Byte		curPsTdma;
-	//u1Byte		psTdmaPara[5];
-	//u1Byte		psTdmaDuAdjType;
-	//BOOLEAN		bResetTdmaAdjust;
-	//BOOLEAN		bPrePsTdmaOn;
-	//BOOLEAN		bCurPsTdmaOn;
-	//BOOLEAN		bPreBtAutoReport;
-	//BOOLEAN		bCurBtAutoReport;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	//u4Byte		preVal0x6c0;
-	//u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u4Byte		preVal0x6cc;
-	u4Byte		curVal0x6cc;
-	//BOOLEAN		bLimitedDig;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	//u1Byte		btStatus;
-	//u1Byte		wifiChnlInfo[3];
-} COEX_DM_8192D_2ANT, *PCOEX_DM_8192D_2ANT;
-
-typedef struct _COEX_STA_8192D_2ANT{
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bBtBusy;
-	BOOLEAN					bBtUplink;
-	BOOLEAN					bBtDownLink;
-	BOOLEAN					bA2dpBusy;
-}COEX_STA_8192D_2ANT, *PCOEX_STA_8192D_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8192d2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192d2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8192d2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192d2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192d2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192d2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192d2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192d2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8192d2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8192d2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8192d2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8192d2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8192d2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e1Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e1Ant.c
deleted file mode 100644
index bcde0c67b4da..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e1Ant.c
+++ /dev/null
@@ -1,3739 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8192E Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8192e1Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8192E_1ANT		GLCoexDm8192e1Ant;
-static PCOEX_DM_8192E_1ANT 	pCoexDm=&GLCoexDm8192e1Ant;
-static COEX_STA_8192E_1ANT		GLCoexSta8192e1Ant;
-static PCOEX_STA_8192E_1ANT	pCoexSta=&GLCoexSta8192e1Ant;
-
-const char *const GLBtInfoSrc8192e1Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8192e1Ant=20140527;
-u4Byte	GLCoexVer8192e1Ant=0x4f;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8192e1ant_
-//============================================================
-u1Byte
-halbtc8192e1ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8192e1ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8192e1ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-VOID
-halbtc8192e1ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-VOID
-halbtc8192e1ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-VOID
-halbtc8192e1ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8192e1ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType
-	)
-{
-	switch(raMaskType)
-	{
-		case 0:	// normal mode
-			halbtc8192e1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0);
-			break;
-		case 1:	// disable cck 1/2
-			halbtc8192e1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x00000003);
-			break;
-		case 2:	// disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4
-			halbtc8192e1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0001f1f7);
-			break;
-		default:
-			break;
-	}
-
-	halbtc8192e1ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8192e1ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8192e1ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-}
-
-VOID
-halbtc8192e1ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-VOID
-halbtc8192e1ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8192e1ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp, u4Tmp1;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp, u1Tmp1;
-	s4Byte			wifiRssi;
-	static u1Byte		NumOfBtCounterChk = 0;
-
-       //to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS
-	//if (! (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e) & 0x8) ) 
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->highPriorityTx = 65535;
-		pCoexSta->highPriorityRx = 65535;
-		pCoexSta->lowPriorityTx = 65535;
-		pCoexSta->lowPriorityRx = 65535;
-		return;
-	}
-		
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	if( (pCoexSta->lowPriorityTx >= 1050)  && (!pCoexSta->bC2hBtInquiryPage))
-		pCoexSta->popEventCnt++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		regHPRx, regHPTx, regLPRx, regLPTx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-
-	if ((regHPTx == 0) && (regHPRx ==0) && (regLPTx == 0) && (regLPRx == 0))
-	{
-		NumOfBtCounterChk++;
-		if (NumOfBtCounterChk >= 3)
-		{
-			halbtc8192e1ant_QueryBtInfo(pBtCoexist);
-			NumOfBtCounterChk = 0;
-		}
-	}
-}
-
-
-VOID
-halbtc8192e1ant_MonitorWiFiCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u2Byte 	u2Tmp[3];
-	s4Byte	wifiRssi=0;
-	BOOLEAN bWifiBusy = FALSE, bWifiUnderBMode = FALSE;
-	static u1Byte nCCKLockCounter = 0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->nCRCOK_CCK = 0;
-		pCoexSta->nCRCOK_11g = 0;
-		pCoexSta->nCRCOK_11n = 0;
-		pCoexSta->nCRCOK_11nAgg = 0;
-
-		pCoexSta->nCRCErr_CCK = 0;
-		pCoexSta->nCRCErr_11g = 0;
-		pCoexSta->nCRCErr_11n = 0;
-		pCoexSta->nCRCErr_11nAgg = 0;	
-	}
-	else
-	{
-		pCoexSta->nCRCOK_CCK	= pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf88);
-		pCoexSta->nCRCOK_11g 	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf94);
-		pCoexSta->nCRCOK_11n	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf90);
-		pCoexSta->nCRCOK_11nAgg= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfb8);
-
-		pCoexSta->nCRCErr_CCK 	 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf84);
-		pCoexSta->nCRCErr_11g 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf96);
-		pCoexSta->nCRCErr_11n 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf92);
-		pCoexSta->nCRCErr_11nAgg = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfba);		
-	}
-
-
-	//reset counter
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x0);
-
-	if ( (bWifiBusy) && (wifiRssi >= 30) && (!bWifiUnderBMode))
-	{
-		if ( (pCoexDm->btStatus == BT_8192E_1ANT_BT_STATUS_ACL_BUSY) ||
-			(pCoexDm->btStatus == BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-			(pCoexDm->btStatus == BT_8192E_1ANT_BT_STATUS_SCO_BUSY) )
-		{
-			if (pCoexSta->nCRCOK_CCK >(pCoexSta->nCRCOK_11g + pCoexSta->nCRCOK_11n + 
-				pCoexSta->nCRCOK_11nAgg) )
-			{
-				if (nCCKLockCounter < 5)
-				 nCCKLockCounter++;
-			}
-			else
-			{
-				if (nCCKLockCounter > 0)
-				 nCCKLockCounter--;
-			}
-
-		}
-		else
-		{
-			if (nCCKLockCounter > 0)
-			  nCCKLockCounter--;
-		}
-	}
-	else
-	{
-		if (nCCKLockCounter > 0)
-			nCCKLockCounter--;
-	}
-
-	if (!pCoexSta->bPreCCKLock)
-	{
-
-		if (nCCKLockCounter >= 5)
-		 pCoexSta->bCCKLock = TRUE;
-		else
-		 pCoexSta->bCCKLock = FALSE;			
-	}
-	else
-	{
-		if (nCCKLockCounter == 0)
-		 pCoexSta->bCCKLock = FALSE;
-		else
-		 pCoexSta->bCCKLock = TRUE;		
-	}
-
-	pCoexSta->bPreCCKLock =  pCoexSta->bCCKLock;	
-		
-
-}
-
-BOOLEAN
-halbtc8192e1ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN bWifiConnected=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8192e1ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8192e1ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8192E_1ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO only\n"));
-			algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID only\n"));
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP only\n"));
-				algorithm = BT_8192E_1ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(HS) only\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(EDR) only\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID\n"));
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(HS)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(EDR)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP\n"));
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(HS)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(EDR)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(HS)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(EDR)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8192e1ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8192e1ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8192e1ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8192e1ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!") ));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8192e1ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8192e1ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8192e1ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8192e1ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8192e1ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8192e1ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** CoexTable(%d) **********\n", type));
-	
-	pCoexSta->nCoexTableType = type;
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaa5a5a, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0xaa5a5a5a, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 7:
-			halbtc8192e1ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8192e1ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8192e1ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8192e1ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8192e1ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8192e1ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8192e1ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8192e1ant_SwMechanism(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN 		bLowPenaltyRA
-	) 
-{
-	halbtc8192e1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8192e1ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	u4Byte			u4Tmp=0;
-	
-	if(bInitHwCfg)
-	{	
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x944, 0x24);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x930, 0x700700);		
-		if(pBtCoexist->chipInterface == BTC_INTF_USB)
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30430004);
-		else
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30030004);
-
-		// 0x4c[27][24]='00', Set Antenna to BB
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp &= ~BIT24;
-		u4Tmp &= ~BIT27;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-	}
-	else if(bWifiOff)
-	{
-		if(pBtCoexist->chipInterface == BTC_INTF_USB)
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30430004);
-		else
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30030004);
-
-		// 0x4c[27][24]='11', Set Antenna to BT, 0x64[8:7]=0, 0x64[2]=1
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp |= BIT24;
-		u4Tmp |= BIT27;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-	}
-	
-	// ext switch setting
-	switch(antPosType)
-	{
-		case BTC_ANT_PATH_WIFI:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x92c, 0x4);
-			break;
-		case BTC_ANT_PATH_BT:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x92c, 0x20);
-			break;
-		default:
-		case BTC_ANT_PATH_PTA:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x92c, 0x4);
-			break;
-	}
-}
-
-VOID
-halbtc8192e1ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		if(byte1&BIT4 && !(byte1&BIT5))
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-			realByte1 &= ~BIT4;
-			realByte1 |= BIT5;
-
-			realByte5 |= BIT5;
-			realByte5 &= ~BIT6;
-		}
-	}
-
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-
-VOID
-halbtc8192e1ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	PBTC_BOARD_INFO	pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bTurnOnByCnt=FALSE, bWifiBusy=FALSE, bWiFiNoisy=FALSE;
-	u1Byte			psTdmaTypeByCnt=0, rssiAdjustVal=0;
-	u1Byte			psTdmaByte4Val = 0x50, psTdmaByte0Val = 0x51, psTdmaByte3Val =  0x10;
-	s1Byte			nWiFiDurationAdjust = 0x0;
-
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);	
-
-	if (pCoexDm->bCurPsTdmaOn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-			pCoexDm->curPsTdma));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(off, %d) **********\n", 
-			pCoexDm->curPsTdma));
-	}
-			
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}
-
-	if (pCoexSta->nScanAPNum <= 5)
-	 	nWiFiDurationAdjust = 5;
-	else if  (pCoexSta->nScanAPNum >= 40)
-	 	nWiFiDurationAdjust = -15;	
-	else if  (pCoexSta->nScanAPNum >= 20)
-	 	nWiFiDurationAdjust = -10;	
-	
-	if (!pCoexSta->bForceLpsOn)  //only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30
-	{
-		psTdmaByte0Val = 0x61;  //no null-pkt
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle
-	}
-	
-	if (  (type == 3) || (type == 13) || (type == 14) )
-		psTdmaByte4Val = psTdmaByte4Val & 0xbf;  //no dynamic slot for multi-profile
-	
-	if (pBtLinkInfo->bSlaveRole == TRUE)
-		psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-		
-	if(bTurnOn)
-	{	 
-		switch(type)
-		{
-			default:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1a, 0x1a, 0x0, psTdmaByte4Val);
-				break;
-			case 1:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);								
-				break;
-			case 2:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x2d+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);							
-				break;
-			case 3:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1d, 0x1d, 0x0, psTdmaByte4Val);
-				break;
-			case 4:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x14, 0x0);
-				break;
-			case 5:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x61, 0x15, 0x3, 0x11, 0x11);
-				break;
-			case 6:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x61, 0x20, 0x3, 0x11, 0x11);
-				break;
-			case 7:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x13, 0xc, 0x5, 0x0, 0x0);
-				break;
-			case 8:	
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;
-			case 9:	
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;
-			case 10:	
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0xa, 0x0, 0x40);
-				break;
-			case 11:	
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x03, psTdmaByte3Val, psTdmaByte4Val);			
-				break;
-			case 12:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x51, 0x0a, 0x0a, 0x0, 0x50);
-				break;
-			case 13:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x51, 0x12, 0x12, 0x0, psTdmaByte4Val);
-				break;
-			case 14:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x51, 0x21, 0x3, 0x10, psTdmaByte4Val);
-				break;
-			case 15:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0x3, 0x8, 0x0);
-				break;
-			case 16:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x10, 0x0);
-				break;
-			case 18:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;			
-			case 20:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x61, 0x3f, 0x03, 0x11, 0x10);
-				break;
-			case 21:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x11);
-				break;
-			case 22:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x10);
-				break;
-			case 23:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x18);
-				break;
-			case 24:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x3, 0x31, 0x18);
-				break;
-			case 25:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 26:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 27:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x98);
-				break;
-			case 28:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x69, 0x25, 0x3, 0x31, 0x0);
-				break;
-			case 29:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xab, 0x1a, 0x1a, 0x1, 0x10);
-				break;
-			case 30:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x51, 0x30, 0x3, 0x10, 0x10);
-				break;
-			case 31:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1a, 0x1a, 0, 0x58);
-				break;
-			case 32:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x61, 0x35, 0x3, 0x11, 0x11);
-				break;
-			case 33:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xa3, 0x25, 0x3, 0x30, 0x90);
-				break;
-			case 34:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x53, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 35:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x63, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 36:
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x12, 0x3, 0x14, 0x50);
-				break;
-			case 40: // SoftAP only with no sta associated,BT disable ,TDMA mode for power saving
-				/* here softap mode screen off will cost 70-80mA for phone */
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x23, 0x18, 0x00, 0x10, 0x24);
-				break;	
-		}
-	}
-	else
-	{		
-
-		// disable PS tdma
-		switch(type)
-		{
-			case 8: //PTA Control
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-				halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FALSE, FALSE);
-				break;
-			case 0:
-			default:  //Software control, Antenna at BT side
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, FALSE);
-				break;
-			case 9:   //Software control, Antenna at WiFi side
-				halbtc8192e1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_WIFI, FALSE, FALSE);
-				break;			
-		}
-	}
-	rssiAdjustVal =0;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssiAdjustVal);
-
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-		pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948),   pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765), pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67)));
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8192e1ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// sw all off
-	halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-
-	// hw all off
-	halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-BOOLEAN
-halbtc8192e1ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected && 
-		BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n"));
-		
- 		//halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-
-		//halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT connected-idle!!\n"));
-
-		//halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-
-		//halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE != pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT Busy!!\n"));
-
-		//halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-		
-		bCommon = TRUE;
-	}
-	else
-	{
-		if (bWifiBusy)			
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-		}
-		
-		bCommon = FALSE;
-	}
-	
-	return bCommon;
-}
-
-
-VOID
-halbtc8192e1ant_TdmaDurationAdjustForAcl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0, btInfoExt;
-	static BOOLEAN	bPreWifiBusy=FALSE;
-	BOOLEAN			bWifiBusy = FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjustForAcl()\n"));
-
-	if(BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY == wifiStatus) 
-		bWifiBusy = TRUE;
-	else
-		bWifiBusy = FALSE;	 	
-
-	if( (BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN == wifiStatus) ||
-		(BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifiStatus) ||
-		(BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT == wifiStatus) )
-	{
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 3 &&
-			pCoexDm->curPsTdma != 9 )
-		{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-			pCoexDm->psTdmaDuAdjType = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n= 3;
-			result = 0;
-			WaitCount = 0;
-		}		
-		return;
-	}
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-		pCoexDm->psTdmaDuAdjType = 2;
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-		retryCount = pCoexSta->btRetryCnt;
-		btInfoExt = pCoexSta->btInfoExt;
-
-		if ( (pCoexSta->lowPriorityTx) > 1050 ||  (pCoexSta->lowPriorityRx) > 1250 )
-			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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		if(result == -1)
-		{
-			if( (BT_INFO_8192E_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 1)
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-				pCoexDm->psTdmaDuAdjType = 11;
-			}
-		}
-		else if(result == 1)
-		{
-			if( (BT_INFO_8192E_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 11)
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-				pCoexDm->psTdmaDuAdjType = 1;
-			}
-		}
-		else	  //no change
-		{
-			/* Bryant Modify	
-			if(bWifiBusy != bPreWifiBusy)  //if busy / idle change
-			{
-				bPreWifiBusy = bWifiBusy;
-				halbtc8192e1ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, pCoexDm->curPsTdma);
-			}
-			*/
-		
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-				pCoexDm->curPsTdma));
-		}
-
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 9 &&
-			pCoexDm->curPsTdma != 11 )
-		{
-			// recover to previous adjust type
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-	}
-}
-
-VOID
-halbtc8192e1ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8192e1ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8192e1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8192e1ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.			
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8192e1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8192e1ant_ActionWifiOnly(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9);	
-}
-
-VOID
-halbtc8192e1ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte		btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-			halbtc8192e1ant_ActionWifiOnly(pBtCoexist);
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		}
-	}
-}
-
-//=============================================
-//
-//	Software Coex Mechanism start
-//
-//=============================================
-
-// SCO only or SCO+PAN(HS)
-
-/*
-VOID
-halbtc8192e1ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-
-VOID
-halbtc8192e1ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8192e1ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8192e1ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8192e1ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(HS) only
-VOID
-halbtc8192e1ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8192e1ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8192e1ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8192e1ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-VOID
-halbtc8192e1ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-*/
-
-//=============================================
-//
-//	Non-Software Coex Mechanism start
-//
-//=============================================
-VOID
-halbtc8192e1ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8192e1ant_ActionHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-	halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8192e1ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bWifiConnected=FALSE, bApEnable=FALSE, bWifiBusy=FALSE, bBtBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	if((!bWifiConnected) && (!pCoexSta->bWiFiIsHighPriTask))
-	{
-		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-
-	 	halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);		
-	}
-	else if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist) || (pBtLinkInfo->bA2dpExist))
-	{
-		// SCO/HID/A2DP  busy
-		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if ((pBtLinkInfo->bPanExist) || (bWifiBusy))
-	{
-		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);		
-		
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	else
-	{
-		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	}
-}
-
-VOID
-halbtc8192e1ant_ActionBtScoHidOnlyBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	// tdma and coex table
-
-	if(pBtLinkInfo->bScoExist)
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-	else //HID
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-}
-
-VOID
-halbtc8192e1ant_ActionWifiConnectedBtAclBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	u1Byte		btRssiState;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	btRssiState = halbtc8192e1ant_BtRssiState(2, 28, 0);	
-
-	if ( (pCoexSta->lowPriorityRx >= 1000)  && (pCoexSta->lowPriorityRx != 65535) )
-	{
-		pBtLinkInfo->bSlaveRole = TRUE;
-	}
-	else
-	{
-		pBtLinkInfo->bSlaveRole = FALSE;
-	}
-
-	if(pBtLinkInfo->bHidOnly)  //HID
-	{
-		halbtc8192e1ant_ActionBtScoHidOnlyBusy(pBtCoexist, wifiStatus);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		return;
-	}
-	else if(pBtLinkInfo->bA2dpOnly)  //A2DP		
-	{
-		if(BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifiStatus)
-		{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		else
-		{
-			halbtc8192e1ant_TdmaDurationAdjustForAcl(pBtCoexist, wifiStatus);
-#if 0
-			if (pCoexSta->bCCKLock)
-				halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-			else
-#endif				
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = TRUE;
-		}
-	}
-	else if ( ((pBtLinkInfo->bA2dpExist) && (pBtLinkInfo->bPanExist)) ||
-		       (pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist&&pBtLinkInfo->bPanExist) ) //A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP)
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else if(pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist)  //HID+A2DP
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-	}
-	else if( (pBtLinkInfo->bPanOnly) || (pBtLinkInfo->bHidExist&&pBtLinkInfo->bPanExist) ) //PAN(OPP,FTP), HID+PAN(OPP,FTP)			
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{		
-		//BT no-profile busy (0x9)
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);	
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}	
-}
-
-VOID
-halbtc8192e1ant_ActionWifiNotConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// power save state
-	halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	halbtc8192e1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8192e1ant_ActionWifiNotConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8192E_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-		{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	 	else
-	 	{
-		        halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-	}
-	else if( (BT_8192E_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8192e1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8192e1ant_ActionWifiNotConnectedAssoAuth(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if( (pBtLinkInfo->bScoExist)  || (pBtLinkInfo->bHidExist) ||  (pBtLinkInfo->bA2dpExist) )
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if (pBtLinkInfo->bPanExist)   			
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else	
-	{		
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8192e1ant_ActionWifiConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8192E_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-	 	{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	 	else
-	 	{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	}
-	else if( (BT_8192E_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8192e1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8192e1ant_ActionWifiConnectedSpecialPacket(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-
-	halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist) || (pBtLinkInfo->bA2dpExist))
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if(pBtLinkInfo->bPanExist) 
-	{
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else	
-	{		
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8192e1ant_ActionWifiConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN 	bWifiBusy=FALSE;
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-	BOOLEAN		bUnder4way=FALSE, bApEnable=FALSE;
-	u4Byte		wifiBw;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect()===>\n"));
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-	if(bUnder4way)
-	{
-		halbtc8192e1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n"));
-		return;
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	if(bScan || bLink || bRoam)
-	{
-		if(bScan)	
-			halbtc8192e1ant_ActionWifiConnectedScan(pBtCoexist);
-		else
-			halbtc8192e1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	
-	// power save state
-	if(!bApEnable && BT_8192E_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus && !pBtCoexist->btLinkInfo.bHidOnly)
-	{
-		if(pBtCoexist->btLinkInfo.bA2dpOnly)	//A2DP
-			{			
-			if(!bWifiBusy)
-		     		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);				
-			else //busy
-			{
-				if  (pCoexSta->nScanAPNum >= BT_8192E_1ANT_WIFI_NOISY_THRESH)  //no force LPS, no PS-TDMA, use pure TDMA
-				{
- 					halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);								
-				}
-				else
-				{
-					halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);					
-				}
-			}
-		}
-		else if ((pCoexSta->bPanExist == FALSE) && (pCoexSta->bA2dpExist == FALSE) && (pCoexSta->bHidExist == FALSE))
- 			halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-	else
-		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(!bWifiBusy)
-	{
-		if(BT_8192E_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8192e1ant_ActionWifiConnectedBtAclBusy(pBtCoexist, 
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else if( (BT_8192E_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8192e1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else
-		{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			
-			if ( (pCoexSta->highPriorityTx) + (pCoexSta->highPriorityRx) <= 60 )
-				halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-			else
-				halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7); 		 
-		}
-	}
-	else
-	{
-		if(BT_8192E_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8192e1ant_ActionWifiConnectedBtAclBusy(pBtCoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else if( (BT_8192E_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8192e1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else 
-		{
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-				
-			if ( (pCoexSta->highPriorityTx) + (pCoexSta->highPriorityRx) <= 60 )
-				halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-			else
-				halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7); 
-		}
-	}
-}
-
-VOID
-halbtc8192e1ant_RunSwCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte				algorithm=0;
-
-	algorithm = halbtc8192e1ant_ActionAlgorithm(pBtCoexist);
-	pCoexDm->curAlgorithm = algorithm;
-
-	if(halbtc8192e1ant_IsCommonAction(pBtCoexist))
-	{
-
-	}
-	else
-	{
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8192E_1ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = SCO.\n"));
-				//halbtc8192e1ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID.\n"));
-				//halbtc8192e1ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP.\n"));
-				//halbtc8192e1ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP+PAN(HS).\n"));
-				//halbtc8192e1ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR).\n"));
-				//halbtc8192e1ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HS mode.\n"));
-				//halbtc8192e1ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN+A2DP.\n"));
-				//halbtc8192e1ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR)+HID.\n"));
-				//halbtc8192e1ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP+PAN.\n"));
-				//halbtc8192e1ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8192E_1ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP.\n"));
-				//halbtc8192e1ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = coexist All Off!!\n"));
-				//halbtc8192e1ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8192e1ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bIncreaseScanDevNum=FALSE;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	BOOLEAN	bMiracastPlusBt=FALSE;
-	u1Byte	aggBufSize=5;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pBtCoexist->bStopCoexDm)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	if( (BT_8192E_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8192E_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bIncreaseScanDevNum = TRUE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_INC_SCAN_DEV_NUM, &bIncreaseScanDevNum);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  Multi-Port numOfWifiLink = %d, wifiLinkStatus = 0x%x\n", numOfWifiLink,wifiLinkStatus) );
-
-		if(pBtLinkInfo->bBtLinkExist)
-		{
-			halbtc8192e1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1);
-			bMiracastPlusBt = TRUE;
-		}
-		else
-		{
-			halbtc8192e1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-			bMiracastPlusBt = FALSE;
-		}
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-		halbtc8192e1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-
-		if ( (pBtLinkInfo->bA2dpExist) && (pCoexSta->bC2hBtInquiryPage) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );	
-			halbtc8192e1ant_ActionBtInquiry(pBtCoexist);
-		}
-		else
-			halbtc8192e1ant_ActionWifiMultiPort(pBtCoexist);
-		
-		return;
-	}
-	else
-	{
-		bMiracastPlusBt = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-	}
-
-	if ( (pBtLinkInfo->bBtLinkExist) && (bWifiConnected) )
-	{
-		halbtc8192e1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1); 
-
-		if(pBtLinkInfo->bScoExist)
-			halbtc8192e1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x5);
-		else
-			halbtc8192e1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-
-		halbtc8192e1ant_SwMechanism(pBtCoexist, TRUE);
-		halbtc8192e1ant_RunSwCoexistMechanism(pBtCoexist);  //just print debug message
-	}
-	else
-	{
-		halbtc8192e1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0); 
-
-		halbtc8192e1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x5);
-
-		halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-		halbtc8192e1ant_RunSwCoexistMechanism(pBtCoexist); ////just print debug message
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );		
-		halbtc8192e1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8192e1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	
-	if(!bWifiConnected)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is non connected-idle !!!\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-		if(bScan || bLink || bRoam)
-		{
-			 if (bScan)	
-		   		halbtc8192e1ant_ActionWifiNotConnectedScan(pBtCoexist);	
-			 else
-		    		halbtc8192e1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);	
-		}
-		else
-			halbtc8192e1ant_ActionWifiNotConnected(pBtCoexist);
-	}
-	else	// wifi LPS/Busy
-	{
-		halbtc8192e1ant_ActionWifiConnected(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8192e1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-
-	// sw all off
-	halbtc8192e1ant_SwMechanism(pBtCoexist, FALSE);
-	
-	//halbtc8192e1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8192e1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	pCoexSta->popEventCnt = 0;
-}
-
-VOID
-halbtc8192e1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	u4Byte	u4Tmp=0;
-	u2Byte	u2Tmp=0;
-	u1Byte	u1Tmp=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 1Ant Init HW Config!!\n"));
-
-	// antenna sw ctrl to bt
-	halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, TRUE, FALSE);
-	
-	halbtc8192e1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	// antenna switch control parameter
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x858, 0x55555555);
-
-	// coex parameters
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x1);
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	// enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-
-	// enable PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x20);
-	// enable mailbox interface
-	u2Tmp = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x40);
-	u2Tmp |= BIT9;
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x40, u2Tmp);
-
-	// enable PTA I2C mailbox 
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x101);
-	u1Tmp |= BIT4;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x101, u1Tmp);
-
-	// enable bt clock when wifi is disabled.
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x93);
-	u1Tmp |= BIT0;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x93, u1Tmp);
-	// enable bt clock when suspend.
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x7);
-	u1Tmp |= BIT0;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x7, u1Tmp);
-}
-
-
-/*
-VOID
-halbtc8192e1ant_WifiOffHwCfg(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// set wlan_act to low
-	//pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-}
-*/
-
-//============================================================
-// work around function start with wa_halbtc8192e1ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8192e1ant_
-//============================================================
-VOID
-EXhalbtc8192e1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-#if 0
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u1Byte u1Tmp=0x0;
-	u2Byte u2Tmp=0x0;
-
-	pBtCoexist->bStopCoexDm = TRUE;
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x67, 0x20);
-
-	// enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly.
-	u2Tmp = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x2);
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x2, u2Tmp|BIT0|BIT1);
-
-	// set GRAN_BT = 1
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18);
-	// set WLAN_ACT = 0
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);	
-
-	// 
-	// S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info)
-	// Local setting bit define
-	//	BIT0: "0" for no antenna inverse; "1" for antenna inverse 
-	//	BIT1: "0" for internal switch; "1" for external switch
-	//	BIT2: "0" for one antenna; "1" for two antenna
-	// NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-		
-	 	u1Tmp |= 0x1;	// antenna inverse
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0xfe08, u1Tmp);
-
-		pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-	}
-	else
-	{
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-			// set to S1
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x280);
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-			u1Tmp |= 0x1;	// antenna inverse
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-		}
-
-		if(pBtCoexist->chipInterface == BTC_INTF_PCI)
-		{
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x384, u1Tmp);
-		}
-		else if(pBtCoexist->chipInterface == BTC_INTF_SDIO)
-		{
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x60, u1Tmp);
-		}
-	}
-#endif
-}
-
-VOID
-EXhalbtc8192e1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8192e1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8192e1ant_InitHwConfig(pBtCoexist, bWifiOnly);
-	pBtCoexist->bStopCoexDm = FALSE;
-}
-
-VOID
-EXhalbtc8192e1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-
-	pBtCoexist->bStopCoexDm = FALSE;
-	
-	halbtc8192e1ant_InitCoexDm(pBtCoexist);
-
-	halbtc8192e1ant_QueryBtInfo(pBtCoexist);
-}
-
-VOID
-EXhalbtc8192e1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}	
-	if(pBtCoexist->bStopCoexDm)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%d/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8192e1Ant, GLCoexVer8192e1Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist);
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);	
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8192E_1ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8192e1Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	if(!pBtCoexist->bManualControl)
-	{
-		// Sw mechanism	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %d ", "DelBA/ BtCtrlAgg/ AggSize", \
-			(pBtCoexist->btInfo.bRejectAggPkt? "Yes":"No"), (pBtCoexist->btInfo.bBtCtrlAggBufSize? "Yes":"No"),
-				pBtCoexist->btInfo.aggBufSize);
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Rate Mask", \
-				pBtCoexist->btInfo.raMask);
-		CL_PRINTF(cliBuf);
-	
-		// Fw mechanism		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-		CL_PRINTF(cliBuf);	
-
-		psTdmaCase = pCoexDm->curPsTdma;
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase, pCoexDm->bAutoTdmaAdjust);
-		CL_PRINTF(cliBuf);
-
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Latest error condition(should be 0)", \
-			pCoexDm->errorCondition);
-		CL_PRINTF(cliBuf);
-		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IgnWlanAct", \
-			pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-	}
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc04);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xd04);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x90c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0xc04/ 0xd04/ 0x90c", \
-		u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x778", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-	
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x92c);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x930);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x92c/ 0x930", \
-		(u1Tmp[0]), u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4f);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x40/ 0x4f", \
-		u1Tmp[0], u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(hp rx[31:16]/tx[15:0])", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(lp rx[31:16]/tx[15:0])", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8192E_1ANT == 1)
-	halbtc8192e1ant_MonitorBtCtr(pBtCoexist);
-#endif
-	
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-VOID
-EXhalbtc8192e1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u4Byte	u4Tmp=0;
-
-	if(pBtCoexist->bManualControl ||	pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);	
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-
-		halbtc8192e1ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8192e1ant_InitCoexDm(pBtCoexist);
-		halbtc8192e1ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8192e1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(pBtCoexist->bManualControl || pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8192e1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN bWifiConnected=FALSE, bBtHsOn=FALSE;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	u1Byte u1Tmpa, u1Tmpb;
-	u4Byte u4Tmp;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm )
-		return;
-
-	if(BTC_SCAN_START == type)
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-
-		halbtc8192e1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-		u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-		u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-		  
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-			u4Tmp,  u1Tmpa, u1Tmpb));
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &pCoexSta->nScanAPNum);		
-	}	
-
-	if(pBtCoexist->btInfo.bBtDisabled)
-		return;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	halbtc8192e1ant_QueryBtInfo(pBtCoexist);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8192e1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8192e1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8192e1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-	
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8192e1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8192e1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_SCAN_START == type)
-	{	
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8192e1ant_ActionWifiNotConnectedScan(pBtCoexist);
-		}
-		else	// wifi is connected
-		{
-			halbtc8192e1ant_ActionWifiConnectedScan(pBtCoexist);
-		}
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8192e1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8192e1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8192e1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		 pCoexSta->bWiFiIsHighPriTask = TRUE;
-		 RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));	
-		 pCoexDm->nArpCnt = 0;
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));	
-		//pCoexDm->nArpCnt = 0;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8192e1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8192e1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8192e1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8192e1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8192e1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));		
-		halbtc8192e1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-		
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-		if(!bWifiConnected) // non-connected scan
-		{
-			halbtc8192e1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8192e1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8192e1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	BOOLEAN			bWifiUnderBMode = FALSE;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-
-		//Set CCK Tx/Rx high Pri except 11b mode
-		if (bWifiUnderBMode)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x00); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x00); //CCK Rx
-		}
-		else
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x10); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x10); //CCK Rx
-		}
-		
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-		pCoexDm->nArpCnt = 0;
-
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x0); //CCK Tx
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x0); //CCK Rx
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		//H2C_Parameter[0] = 0x1;
-		H2C_Parameter[0] = 0x0;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-		
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);
-}
-
-VOID
-EXhalbtc8192e1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bBtHsOn=FALSE;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if( BTC_PACKET_DHCP == type || 
-		BTC_PACKET_EAPOL == type ||
-		BTC_PACKET_ARP == type )
-	{
-		if(BTC_PACKET_ARP == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet ARP notify\n"));		 
-
-			pCoexDm->nArpCnt++;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ARP Packet Count = %d\n", pCoexDm->nArpCnt));
-			
-			if(pCoexDm->nArpCnt >= 10) // if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecialPacket(pBtCoexist) 
-			{
-				pCoexSta->bWiFiIsHighPriTask = FALSE;					
-			}			
-			else
-			{
-				pCoexSta->bWiFiIsHighPriTask = TRUE;
-			}
-		}
-		else
-		{
-			pCoexSta->bWiFiIsHighPriTask = TRUE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet DHCP or EAPOL notify\n"));		 
-		}
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet [Type = %d] notify\n", type));
-	}
-
-	pCoexSta->specialPktPeriodCnt = 0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8192e1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8192e1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8192e1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8192e1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8192e1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if( BTC_PACKET_DHCP == type ||
-		BTC_PACKET_EAPOL == type || 
-		( (BTC_PACKET_ARP == type ) && (pCoexSta->bWiFiIsHighPriTask) ) )
-	{
-		halbtc8192e1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8192e1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte				btInfo=0;
-	u1Byte				i, rspSource=0;
-	BOOLEAN				bWifiConnected=FALSE;
-	BOOLEAN				bBtBusy=FALSE;
-	
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8192E_1ANT_MAX)
-		rspSource = BT_INFO_SRC_8192E_1ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(BT_INFO_SRC_8192E_1ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		if (pCoexSta->btRetryCnt >= 1)
-			pCoexSta->popEventCnt++;
-
-		if (pCoexSta->btInfoC2h[rspSource][2]&0x20)
-			pCoexSta->bC2hBtPage = TRUE;
-		else
-			pCoexSta->bC2hBtPage = FALSE;			
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2-90;
-			//pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-		if(!pCoexSta->bBtTxRxMask)
-		{
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */				
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n"));
-			pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15);
-		}
-		
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if(pCoexSta->btInfoExt & BIT1)
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				EXhalbtc8192e1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8192e1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-				
-		if(pCoexSta->btInfoExt & BIT3)
-		{
-			if(!pBtCoexist->bManualControl && !pBtCoexist->bStopCoexDm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-				halbtc8192e1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-			}
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-#if(BT_AUTO_REPORT_ONLY_8192E_1ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8192e1ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-		
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8192E_1ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8192E_1ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8192E_1ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8192E_1ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8192E_1ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8192E_1ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-	}
-
-	halbtc8192e1ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	btInfo = btInfo & 0x1f;  //mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41)
-	
-	if(!(btInfo&BT_INFO_8192E_1ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8192E_1ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8192E_1ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8192E_1ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8192E_1ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8192E_1ANT_B_ACL_BUSY)
-	{
-		if(BT_8192E_1ANT_BT_STATUS_ACL_BUSY != pCoexDm->btStatus)
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->btStatus = BT_8192E_1ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8192E_1ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-
-	if( (BT_8192E_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8192E_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		bBtBusy = TRUE;
-	else
-		bBtBusy = FALSE;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	halbtc8192e1ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8192e1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	)
-{
-	u4Byte	u4Tmp;
-	u1Byte	u1Tmpa,u1Tmpb, u1Tmpc;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF Status notify\n"));
-
-	if(BTC_RF_ON == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned ON!!\n"));
-		pBtCoexist->bStopCoexDm = FALSE;
-	}
-	else if(BTC_RF_OFF == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned OFF!!\n"));
-		
-		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);
-		
-		halbtc8192e1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		pBtCoexist->bStopCoexDm = TRUE;
-
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-		u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
- 		u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-		u1Tmpc = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x, 0x76e=0x%x\n",
-			u4Tmp,  u1Tmpa, u1Tmpb, u1Tmpc));
-
-	}
-}
-
-VOID
-EXhalbtc8192e1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u4Byte	u4Tmp;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8192e1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-	halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);
-
-	halbtc8192e1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-
-	EXhalbtc8192e1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-
-	pBtCoexist->bStopCoexDm = TRUE;	
-}
-
-VOID
-EXhalbtc8192e1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-
-		halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8192e1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-		halbtc8192e1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);
-
-		pBtCoexist->bStopCoexDm = TRUE;
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		pBtCoexist->bStopCoexDm = FALSE;
-		halbtc8192e1ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8192e1ant_InitCoexDm(pBtCoexist);
-		halbtc8192e1ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8192e1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], *****************Coex DM Reset*****************\n"));
-
-	halbtc8192e1ant_InitHwConfig(pBtCoexist, FALSE);
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x2, 0xfffff, 0x0);
-	halbtc8192e1ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8192e1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8192e1Ant, GLCoexVer8192e1Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8192E_1ANT == 0)
-	halbtc8192e1ant_QueryBtInfo(pBtCoexist);
-	halbtc8192e1ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	halbtc8192e1ant_MonitorBtCtr(pBtCoexist);
-	halbtc8192e1ant_MonitorWiFiCtr(pBtCoexist);
-
-	if( halbtc8192e1ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust )
-	{
-
-			halbtc8192e1ant_RunCoexistMechanism(pBtCoexist);	
-	}
-
-	pCoexSta->specialPktPeriodCnt++;
-#endif
-}
-
-
-VOID
-EXhalbtc8192e1ant_DbgControl(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				opCode,
-	IN	u1Byte				opLen,
-	IN	pu1Byte				pData
-	)
-{
-	switch(opCode)
-	{
-		case BTC_DBG_SET_COEX_NORMAL:
-			pBtCoexist->bManualControl = FALSE;
-			halbtc8192e1ant_InitCoexDm(pBtCoexist);
-			break;
-		case BTC_DBG_SET_COEX_WIFI_ONLY:
-			pBtCoexist->bManualControl = TRUE;
-			halbtc8192e1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9);	
-			break;
-		case BTC_DBG_SET_COEX_BT_ONLY:
-			// todo
-			break;
-		default:
-			break;
-	}
-}
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e1Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e1Ant.h
deleted file mode 100644
index ed4fcd117e5d..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e1Ant.h
+++ /dev/null
@@ -1,255 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8192E 1ANT BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8192E_1ANT				1
-
-#define	BT_INFO_8192E_1ANT_B_FTP						BIT7
-#define	BT_INFO_8192E_1ANT_B_A2DP					BIT6
-#define	BT_INFO_8192E_1ANT_B_HID						BIT5
-#define	BT_INFO_8192E_1ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8192E_1ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8192E_1ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8192E_1ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8192E_1ANT_B_CONNECTION				BIT0
-
-#define	BT_INFO_8192E_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT		2
-
-#define  BT_8192E_1ANT_WIFI_NOISY_THRESH								30   //max: 255
-
-typedef enum _BT_INFO_SRC_8192E_1ANT{
-	BT_INFO_SRC_8192E_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8192E_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8192E_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8192E_1ANT_MAX
-}BT_INFO_SRC_8192E_1ANT,*PBT_INFO_SRC_8192E_1ANT;
-
-typedef enum _BT_8192E_1ANT_BT_STATUS{
-	BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8192E_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8192E_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8192E_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8192E_1ANT_BT_STATUS_MAX
-}BT_8192E_1ANT_BT_STATUS,*PBT_8192E_1ANT_BT_STATUS;
-
-typedef enum _BT_8192E_1ANT_WIFI_STATUS{
-	BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT				= 0x3,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8192E_1ANT_WIFI_STATUS_MAX
-}BT_8192E_1ANT_WIFI_STATUS,*PBT_8192E_1ANT_WIFI_STATUS;
-
-typedef enum _BT_8192E_1ANT_COEX_ALGO{
-	BT_8192E_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8192E_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8192E_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8192E_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8192E_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8192E_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8192E_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8192E_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8192E_1ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8192E_1ANT_COEX_ALGO,*PBT_8192E_1ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8192E_1ANT{
-	// fw mechanism
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	// sw mechanism
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	u4Byte		backupArfrCnt1;	// Auto Rate Fallback Retry cnt
-	u4Byte		backupArfrCnt2;	// Auto Rate Fallback Retry cnt
-	u2Byte		backupRetryLimit;
-	u1Byte		backupAmpduMaxTime;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-	u1Byte		preArfrType;
-	u1Byte		curArfrType;
-	u1Byte		preRetryLimitType;
-	u1Byte		curRetryLimitType;
-	u1Byte		preAmpduTimeType;
-	u1Byte		curAmpduTimeType;
-	u4Byte		nArpCnt;
-
-	u1Byte		errorCondition;
-} COEX_DM_8192E_1ANT, *PCOEX_DM_8192E_1ANT;
-
-typedef struct _COEX_STA_8192E_1ANT{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					specialPktPeriodCnt;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	s1Byte					btRssi;
-	BOOLEAN					bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8192E_1ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8192E_1ANT_MAX];
-	BOOLEAN					bC2hBtInquiryPage;
-	BOOLEAN					bC2hBtPage;				//Add for win8.1 page out issue
-	BOOLEAN					bWiFiIsHighPriTask;		//Add for win8.1 page out issue
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	u4Byte					popEventCnt;
-	u1Byte					nScanAPNum;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;	
-
-	BOOLEAN					bCCKLock;
-	BOOLEAN					bPreCCKLock;
-	u1Byte					nCoexTableType;
-
-	BOOLEAN					bForceLpsOn;
-}COEX_STA_8192E_1ANT, *PCOEX_STA_8192E_1ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8192e1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192e1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192e1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8192e1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192e1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8192e1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8192e1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8192e1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	);
-VOID
-EXhalbtc8192e1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8192e1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8192e1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8192e1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8192e1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192e1ant_DbgControl(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				opCode,
-	IN	u1Byte				opLen,
-	IN	pu1Byte 			pData
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e2Ant.c
deleted file mode 100644
index 889262e5ccf0..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e2Ant.c
+++ /dev/null
@@ -1,5028 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8192E Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8192E_2ANT		GLCoexDm8192e2Ant;
-static PCOEX_DM_8192E_2ANT 	pCoexDm=&GLCoexDm8192e2Ant;
-static COEX_STA_8192E_2ANT		GLCoexSta8192e2Ant;
-static PCOEX_STA_8192E_2ANT	pCoexSta=&GLCoexSta8192e2Ant;
-
-const char *const GLBtInfoSrc8192e2Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8192e2Ant=20150615;
-u4Byte	GLCoexVer8192e2Ant=0x41;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8192e2ant_
-//============================================================
-u1Byte
-halbtc8192e2ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8192e2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;				
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8192e2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-		}
-	}
-}
-
-u4Byte
-halbtc8192e2ant_DecideRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				ssType,
-	IN	u4Byte				raMaskType
-	)
-{
-	u4Byte	disRaMask=0x0;
-	
-	switch(raMaskType)
-	{
-		case 0: // normal mode
-			if(ssType == 2)
-				disRaMask = 0x0;			// enable 2ss
-			else
-				disRaMask = 0xfff00000;		// disable 2ss
-			break;
-		case 1: // disable cck 1/2
-			if(ssType == 2)
-				disRaMask = 0x00000003;		// enable 2ss
-			else
-				disRaMask = 0xfff00003;		// disable 2ss
-			break;
-		case 2: // disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4
-			if(ssType == 2)
-				disRaMask = 0x0001f1f7;		// enable 2ss
-			else
-				disRaMask = 0xfff1f1f7;		// disable 2ss
-			break;
-		default:
-			break;
-	}
-
-	return disRaMask;
-}
-
-VOID
-halbtc8192e2ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-VOID
-halbtc8192e2ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-VOID
-halbtc8192e2ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-VOID
-halbtc8192e2ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8192e2ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType
-	)
-{
-	u4Byte	disRaMask=0x0;
-
-	pCoexDm->curRaMaskType = raMaskType;
-	disRaMask = halbtc8192e2ant_DecideRaMask(pBtCoexist, pCoexDm->curSsType, raMaskType);
-	halbtc8192e2ant_UpdateRaMask(pBtCoexist, bForceExec, disRaMask);
-
-	halbtc8192e2ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8192e2ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8192e2ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-}
-
-VOID
-halbtc8192e2ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-VOID
-halbtc8192e2ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8192e2ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-BOOLEAN
-halbtc8192e2ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN	bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte			wifiRssiState=BTC_RSSI_STATE_HIGH;
-	
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-
-
-		wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist,3, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-
-		if ( (BTC_RSSI_STATE_HIGH ==wifiRssiState ) ||  (BTC_RSSI_STATE_LOW ==wifiRssiState ))
-		{
-			return TRUE;
-		}
-	
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8192e2ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8192e2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	PBTC_STACK_INFO 	pStackInfo=&pBtCoexist->stackInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8192E_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-		
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-
-
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO only\n"));
-			algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8192E_2ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8192E_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(HS) only\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(EDR) only\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID\n"));
-				algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(HS)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(EDR)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO_PAN;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(pStackInfo->numOfHid >= 2)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID*2 + A2DP\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-				else
-				{			
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(HS)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(EDR)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(HS)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(EDR)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO_PAN;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8192e2ant_SetFwDacSwingLevel(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			dacSwingLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	// There are several type of dacswing
-	// 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6
-	H2C_Parameter[0] = dacSwingLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Set Dac Swing Level=0x%x\n", dacSwingLvl));
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x64=0x%x\n", H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x64, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8192e2ant_SetFwDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = decBtPwrLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], decrease Bt Power level = %d, FW write 0x62=0x%x\n", 
-		decBtPwrLvl, H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x62, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8192e2ant_DecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s Dec BT power level = %d\n",  
-		(bForceExec? "force to":""), decBtPwrLvl));
-	pCoexDm->curBtDecPwrLvl = decBtPwrLvl;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], preBtDecPwrLvl=%d, curBtDecPwrLvl=%d\n", 
-			pCoexDm->preBtDecPwrLvl, pCoexDm->curBtDecPwrLvl));
-#if 0	// work around, avoid h2c command fail.
-		if(pCoexDm->preBtDecPwrLvl == pCoexDm->curBtDecPwrLvl) 
-			return;
-#endif
-	}
-	halbtc8192e2ant_SetFwDecBtPwr(pBtCoexist, pCoexDm->curBtDecPwrLvl);
-
-	pCoexDm->preBtDecPwrLvl = pCoexDm->curBtDecPwrLvl;
-}
-
-VOID
-halbtc8192e2ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8192e2ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPreBtAutoReport=%d, bCurBtAutoReport=%d\n", 
-			pCoexDm->bPreBtAutoReport, pCoexDm->bCurBtAutoReport));
-
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8192e2ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8192e2ant_FwDacSwingLvl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			fwDacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set FW Dac Swing level = %d\n",  
-		(bForceExec? "force to":""), fwDacSwingLvl));
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], preFwDacSwingLvl=%d, curFwDacSwingLvl=%d\n", 
-			pCoexDm->preFwDacSwingLvl, pCoexDm->curFwDacSwingLvl));
-
-		if(pCoexDm->preFwDacSwingLvl == pCoexDm->curFwDacSwingLvl) 
-			return;
-	}
-
-	halbtc8192e2ant_SetFwDacSwingLevel(pBtCoexist, pCoexDm->curFwDacSwingLvl);
-
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-}
-
-VOID
-halbtc8192e2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xffffc);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8192e2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPreRfRxLpfShrink=%d, bCurRfRxLpfShrink=%d\n", 
-			pCoexDm->bPreRfRxLpfShrink, pCoexDm->bCurRfRxLpfShrink));
-
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8192e2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8192e2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!")) );
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8192e2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	//return;
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPreLowPenaltyRa=%d, bCurLowPenaltyRa=%d\n", 
-			pCoexDm->bPreLowPenaltyRa, pCoexDm->bCurLowPenaltyRa));
-
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8192e2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8192e2ant_SetDacSwingReg(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte			level
-	)
-{
-	u1Byte	val=(u1Byte)level;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Write SwDacSwing = 0x%x\n", level));
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x883, 0x3e, val);
-}
-
-VOID
-halbtc8192e2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	if(bSwDacSwingOn)
-	{
-		halbtc8192e2ant_SetDacSwingReg(pBtCoexist, swDacSwingLvl);
-	}
-	else
-	{
-		halbtc8192e2ant_SetDacSwingReg(pBtCoexist, 0x18);
-	}
-}
-
-
-VOID
-halbtc8192e2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPreDacSwingOn=%d, preDacSwingLvl=0x%x, bCurDacSwingOn=%d, curDacSwingLvl=0x%x\n", 
-			pCoexDm->bPreDacSwingOn, pCoexDm->preDacSwingLvl,
-			pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl));
-
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8192e2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8192e2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc05, 0x30, 0x3);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc05, 0x30, 0x1);
-	}
-}
-
-VOID
-halbtc8192e2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPreAdcBackOff=%d, bCurAdcBackOff=%d\n", 
-			pCoexDm->bPreAdcBackOff, pCoexDm->bCurAdcBackOff));
-
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8192e2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8192e2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	//=================BB AGC Gain Table
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x0a1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x091B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x081C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x071D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x061E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x051F0001);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table Off!\n"));
-	 	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xaa1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa91B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa81C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa71D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa61E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa51F0001);
-	}
-	
-#if 0	
-	//=================RF Gain
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x1);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x0);
-
-	// set rssiAdjustVal for wifi module.
-	if(bAgcTableEn)
-	{
-		rssiAdjustVal = 8;
-	}
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-#endif
-
-}
-
-VOID
-halbtc8192e2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPreAgcTableEn=%d, bCurAgcTableEn=%d\n", 
-			pCoexDm->bPreAgcTableEn, pCoexDm->bCurAgcTableEn));
-
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8192e2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8192e2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8192e2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], preVal0x6c0=0x%x, preVal0x6c4=0x%x, preVal0x6c8=0x%x, preVal0x6cc=0x%x !!\n", 
-			pCoexDm->preVal0x6c0, pCoexDm->preVal0x6c4, pCoexDm->preVal0x6c8, pCoexDm->preVal0x6cc));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], curVal0x6c0=0x%x, curVal0x6c4=0x%x, curVal0x6c8=0x%x, curVal0x6cc=0x%x !!\n", 
-			pCoexDm->curVal0x6c0, pCoexDm->curVal0x6c4, pCoexDm->curVal0x6c8, pCoexDm->curVal0x6cc));
-	
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8192e2ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8192e2ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexSta->nCoexTableType = type;
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5ffb5ffb, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0x5fdf5fdf, 0x5fdb5fdb, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0xdfffdfff, 0x5ffb5ffb, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0x5ddd5ddd, 0x5fdb5fdb, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 7:
-			if(pCoexSta->nScanAPNum <= NOISY_AP_NUM_THRESH)
-				halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0xffffffff, 0xfafafafa, 0xffffff, 0x3);
-			else
-				halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0xffffffff, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 8:
-			halbtc8192e2ant_CoexTable(pBtCoexist, bForceExec, 0x5f5f5f5f, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8192e2ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-
-VOID
-halbtc8192e2ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPreIgnoreWlanAct = %d, bCurIgnoreWlanAct = %d!!\n", 
-			pCoexDm->bPreIgnoreWlanAct, pCoexDm->bCurIgnoreWlanAct));
-
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8192e2ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-
-VOID
-halbtc8192e2ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-
-VOID
-halbtc8192e2ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], preLps/curLps=0x%x/0x%x, preRpwm/curRpwm=0x%x/0x%x!!\n", 
-			pCoexDm->preLps, pCoexDm->curLps, pCoexDm->preRpwm, pCoexDm->curRpwm));
-
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], LPS-RPWM_Last=0x%x , LPS-RPWM_Now=0x%x!!\n", 
-				 pCoexDm->preRpwm, pCoexDm->curRpwm));
-
-			return;
-		}
-	}
-	halbtc8192e2ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-
-
-VOID
-halbtc8192e2ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		if(byte1&BIT4 && !(byte1&BIT5))
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-			realByte1 &= ~BIT4;
-			realByte1 |= BIT5;
-
-			realByte5 |= BIT5;
-			realByte5 &= ~BIT6;
-		}
-	}
-
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-
-VOID
-halbtc8192e2ant_SwMechanism1(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bShrinkRxLPF,
-	IN	BOOLEAN 	bLowPenaltyRA,
-	IN	BOOLEAN		bLimitedDIG, 
-	IN	BOOLEAN		bBTLNAConstrain
-	) 
-{
-	/*
-	u4Byte	wifiBw;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	
-	if(BTC_WIFI_BW_HT40 != wifiBw)  //only shrink RF Rx LPF for HT40
-	{
-		if (bShrinkRxLPF)
-			bShrinkRxLPF = FALSE;
-	}
-	*/
-	
-	halbtc8192e2ant_RfShrink(pBtCoexist, NORMAL_EXEC, bShrinkRxLPF);
-	//halbtc8192e2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8192e2ant_SwMechanism2(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bAGCTableShift,
-	IN	BOOLEAN 	bADCBackOff,
-	IN	BOOLEAN		bSWDACSwing,
-	IN	u4Byte		dacSwingLvl
-	) 
-{
-	halbtc8192e2ant_AgcTable(pBtCoexist, NORMAL_EXEC, bAGCTableShift);
-	//halbtc8192e2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, bADCBackOff);
-	halbtc8192e2ant_DacSwing(pBtCoexist, NORMAL_EXEC, bSWDACSwing, dacSwingLvl);
-}
-
-VOID
-halbtc8192e2ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	u4Byte			u4Tmp=0;
-	
-	if(bInitHwCfg)
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x944, 0x24);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x930, 0x700700);		
-		if(pBtCoexist->chipInterface == BTC_INTF_USB)
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30430004);
-		else
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30030004);
-
-		// 0x4c[27][24]='00', Set Antenna to BB
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp &= ~BIT24;
-		u4Tmp &= ~BIT27;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-	}
-	else if(bWifiOff)
-	{
-		if(pBtCoexist->chipInterface == BTC_INTF_USB)
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30430004);
-		else
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x64, 0x30030004);
-
-		// 0x4c[27][24]='11', Set Antenna to BT, 0x64[8:7]=0, 0x64[2]=1
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp |= BIT24;
-		u4Tmp |= BIT27;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-	}
-	
-	// ext switch setting
-	switch(antPosType)
-	{
-		case BTC_ANT_PATH_WIFI:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x92c, 0x4);
-			break;
-		case BTC_ANT_PATH_BT:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x92c, 0x20);
-			break;
-		default:
-		case BTC_ANT_PATH_PTA:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x92c, 0x4);
-			break;
-	}
-}
-
-VOID
-halbtc8192e2ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN			bTurnOnByCnt=FALSE;
-	u1Byte			psTdmaTypeByCnt=0;
-	s1Byte			nWiFiDurationAdjust = 0x0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-		(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPrePsTdmaOn = %d, bCurPsTdmaOn = %d!!\n", 
-			pCoexDm->bPrePsTdmaOn, pCoexDm->bCurPsTdmaOn));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], prePsTdma = %d, curPsTdma = %d!!\n", 
-			pCoexDm->prePsTdma, pCoexDm->curPsTdma));
-
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-
-	if  (pCoexSta->nScanAPNum >= 40)
-	 	nWiFiDurationAdjust = -15;	
-	else if  (pCoexSta->nScanAPNum >= 20)
-	 	nWiFiDurationAdjust = -10;	
-
-/*	
-	if (!pCoexSta->bForceLpsOn)  //only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30
-	{
-		psTdmaByte0Val = 0x61;  //no null-pkt
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle
-	}
-
-	
-	if (  (type == 3) || (type == 13) || (type == 14) )
-	{
-		psTdmaByte4Val = psTdmaByte4Val & 0xbf;  //no dynamic slot for multi-profile
-	
-		if (!bWifiBusy)
-		 psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-	}
-	
-	if (pBtLinkInfo->bSlaveRole == TRUE)
-		psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-	
-*/
-	if(bTurnOn)
-	{
-		switch(type)
-		{
-			case 1:
-			default:	//d1,wb
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x11, 0x10);
-				break;
-			case 2:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x32, 0x03, 0x11, 0x10);
-				break;
-			case 3:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x28, 0x03, 0x11, 0x10);
-				break;
-			case 4:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1e, 0x03, 0x11, 0x10);
-				break;
-			case 5:		//d1,pb,TXpause
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x63, 0x3c, 0x03, 0x90, 0x10);
-				break;
-			case 6:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x63, 0x32, 0x03, 0x90, 0x10);
-				break;
-			case 7:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x63, 0x28, 0x03, 0x90, 0x10);
-				break;
-			case 8: 
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x63, 0x1e, 0x03, 0x90, 0x10);
-				break;
-			case 9:		//d1,bb
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x31, 0x10);
-				break;
-			case 10:	
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x32, 0x03, 0x31, 0x10);
-				break;
-			case 11:	
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x28, 0x03, 0x31, 0x10);
-				break;
-			case 12:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1e, 0x03, 0x31, 0x10);
-				break;
-			case 13:	//d1,bb,TXpause
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x30, 0x10);
-				break;
-			case 14:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x32, 0x03, 0x30, 0x10);
-				break;
-			case 15:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x28, 0x03, 0x30, 0x10);
-				break;
-			case 16:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1e, 0x03, 0x30, 0x10);
-				break;
-			case 17:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x61, 0x20, 0x03, 0x10, 0x10);
-				break;
-			case 18:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				break;			
-			case 19:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0xe1, 0x90);
-				break;
-			case 20:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0x60, 0x90);
-				break;
-			case 21:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x61, 0x35, 0x03, 0x11, 0x11);
-				break;	
-			case 71:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				break;
-
-			// following cases is for wifi rssi low // bad antenna isolation, started from 81
-			case 80:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x53, 0x3c, 0x3, 0x90, 0x50);
-				break;
-			case 81:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x53, 0x3a+nWiFiDurationAdjust, 0x3, 0x90, 0x50);
-				break;
-			case 82:
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x53, 0x30+nWiFiDurationAdjust, 0x03, 0x90, 0x50);
-				break;
-	   		case 83:
-	   			halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x53, 0x21, 0x03, 0x90, 0x50);
-	   			break;
-	   		case 84:
-	   			halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x53, 0x15, 0x3, 0x90, 0x50);
-	   			break;
-	   		case 85:
-	   			halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x53, 0x3a, 0x03, 0x90, 0x50);
-	   			break;
-	   		case 86:
-	   			halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x53, 0x21, 0x03, 0x90, 0x50);
-	   			break;
-
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(type)
-		{
-			default:
-			case 0:  //ANT2PTA, 0x778=1
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-				halbtc8192e2ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FALSE, FALSE);
-				break;
-			case 1:  //ANT2BT, 0x778=3
-				halbtc8192e2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x8, 0x0);
-				delay_ms(5);
-				halbtc8192e2ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, FALSE);
-				break;
-
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8192e2ant_SetSwitchSsType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				ssType
-	)
-{
-	u1Byte	mimoPs=BTC_MIMO_PS_DYNAMIC;
-	u4Byte	disRaMask=0x0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], REAL set SS Type = %d\n", ssType));
-	
-	disRaMask = halbtc8192e2ant_DecideRaMask(pBtCoexist, ssType, pCoexDm->curRaMaskType);
-	halbtc8192e2ant_UpdateRaMask(pBtCoexist, FORCE_EXEC, disRaMask);
-	
-	if(ssType == 1)
-	{		
-		halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-		// switch ofdm path
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xc04, 0x11);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xd04, 0x1);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x90c, 0x81111111);
-		// switch cck patch
-		//pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xe77, 0x4, 0x1);
-		//pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xa07, 0x81);
-		mimoPs=BTC_MIMO_PS_STATIC;
-	}
-	else if(ssType == 2)
-	{
-		halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xc04, 0x33);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xd04, 0x3);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x90c, 0x81121313);
-		// remove, if 0xe77[2]=0x0 then CCK will fail, advised by Jenyu
-		//pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xe77, 0x4, 0x0);
-		//pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xa07, 0x41);
-		mimoPs=BTC_MIMO_PS_DYNAMIC;
-	}
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_SEND_MIMO_PS, &mimoPs);	// set rx 1ss or 2ss
-}
-
-VOID
-halbtc8192e2ant_SwitchSsType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				newSsType
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], %s Switch SS Type = %d\n",  
-		(bForceExec? "force to":""), newSsType));
-	pCoexDm->curSsType = newSsType;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preSsType == pCoexDm->curSsType) 
-			return;
-	}
-	halbtc8192e2ant_SetSwitchSsType(pBtCoexist, pCoexDm->curSsType);
-
-	pCoexDm->preSsType = pCoexDm->curSsType;
-}
-
-VOID
-halbtc8192e2ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8192e2ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	BOOLEAN 	bApEnable=FALSE;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		psType = BTC_PS_WIFI_NATIVE;
-		lpsVal = 0x0;
-		rpwmVal = 0x0;		
-	}
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8192e2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8192e2ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8192e2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-
-VOID
-halbtc8192e2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-    halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8192e2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-	
-	halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8192e2ant_DecBtPwr(pBtCoexist, FORCE_EXEC, 0);
-
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-	halbtc8192e2ant_SwitchSsType(pBtCoexist, FORCE_EXEC, 2);
-	
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-//	BOOLEAN	bLowPwrDisable=TRUE;
-	
-//	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-//	halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 1);
-
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 21);
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionWiFiLinkProcess(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-
-}
-
-BOOLEAN
-halbtc8192e2ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-	BOOLEAN			bBtHsOn=FALSE, bLowPwrDisable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(pBtLinkInfo->bScoExist || pBtLinkInfo->bHidExist)
-	{
-		halbtc8192e2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 0, 0, 0);
-	}
-	else
-	{
-		halbtc8192e2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-	}
-
-	if(!bWifiConnected)
-	{
-//		bLowPwrDisable = FALSE;
-//		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-					
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-connected idle!!\n"));
-
-		if( (BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus) ||
-			(BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-		{
-//			halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 2);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-		else
-		{			
-//			halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		
-		halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-		
- 		halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		bCommon = TRUE;
-	}
-	else
-	{
-		if(BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-//			bLowPwrDisable = FALSE;
-//			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-//			halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 2);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);		
-			halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-			halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else if(BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-//			bLowPwrDisable = TRUE;
-//			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bBtHsOn)
-				return FALSE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-//			halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 2);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-			halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-			halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8192e2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else
-		{
-//			bLowPwrDisable = TRUE;
-//			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bWifiBusy)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-				bCommon = FALSE;
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-
-				halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-//				halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 1);
-				halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 21);
-				halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);	
-				halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-				halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-				bCommon = TRUE;
-			}
-		}	
-	}
-
-	return bCommon;
-}
-
-
-VOID
-halbtc8192e2ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bScoHid,
-	IN	BOOLEAN			bTxPause,
-	IN	u1Byte			maxInterval
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-		{
-			if(bScoHid)
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;	
-					}
-					else
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-			else
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->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 = pCoexSta->btRetryCnt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-		if(maxInterval == 1)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-					pCoexDm->psTdmaDuAdjType = 13;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				
-				if(result == -1)
-				{					
-					if(pCoexDm->curPsTdma == 5)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;
-					}
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-					pCoexDm->psTdmaDuAdjType = 1;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-					pCoexDm->psTdmaDuAdjType = 9;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 2)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 3)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-		if( !bScan && !bLink && !bRoam)
-		{
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-}
-
-VOID
-halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(
-	IN	PBTC_COEXIST		pBtCoexist//,
-	//IN	u1Byte				wifiStatus
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0, btInfoExt;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow()\n"));
-#if 0
-	if( (BT_8192E_2ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN == wifiStatus) ||
-		(BT_8192E_2ANT_WIFI_STATUS_CONNECTED_SCAN == wifiStatus) ||
-		(BT_8192E_2ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT == wifiStatus) )
-	{
-		if( pCoexDm->curPsTdma != 81 &&
-			pCoexDm->curPsTdma != 82 &&
-			pCoexDm->curPsTdma != 83 &&
-			pCoexDm->curPsTdma != 84 )
-		{
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-			pCoexDm->psTdmaDuAdjType = 82;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n= 3;
-			result = 0;
-			WaitCount = 0;
-		}		
-		return;
-	}
-#endif
-	pCoexDm->bAutoTdmaAdjust = FALSE;
-
-	retryCount = pCoexSta->btRetryCnt;
-	btInfoExt = pCoexSta->btInfoExt;
-
-	if(!pCoexDm->bAutoTdmaAdjustLowRssi)
-	{
-		pCoexDm->bAutoTdmaAdjustLowRssi = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjustForWifiRssiLow()!!\n"));
-
-/*
-		if(BT_INFO_8192E_2ANT_A2DP_BASIC_RATE(btInfoExt))
-		{
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-			pCoexDm->psTdmaDuAdjType = 83;
-		}
-		else
-*/
-		{
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 81);
-		pCoexDm->psTdmaDuAdjType = 81;
-		}
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-//		retryCount = pCoexSta->btRetryCnt;
-//		btInfoExt = pCoexSta->btInfoExt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		result = 0;
-		WaitCount++; 
-		  
-		if ( (pCoexSta->lowPriorityTx) > 1050 ||  (pCoexSta->lowPriorityRx) > 1250 )
-			retryCount++;	
-				
-		if(retryCount == 0)  // no retry in the last 2-second duration
-		{
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;				 
-
-			if(up >= n)	// if 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		if(result == -1)
-		{
-/*
-			if( (BT_INFO_8192E_2ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 81) ||(pCoexDm->curPsTdma == 82)) )
-				if( (BT_INFO_8192E_2ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-					((pCoexDm->curPsTdma == 81) ||(pCoexDm->curPsTdma == 82)) )
-
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 84);
-				pCoexDm->psTdmaDuAdjType = 84;
-			}
-*/
-			if(pCoexDm->curPsTdma == 80)
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 81);
-				pCoexDm->psTdmaDuAdjType = 81;
-			}
-			else if(pCoexDm->curPsTdma == 81)
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-				pCoexDm->psTdmaDuAdjType = 82;
-			}
-			else if(pCoexDm->curPsTdma == 82)
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-				pCoexDm->psTdmaDuAdjType = 83;
-			}
-			else if(pCoexDm->curPsTdma == 83)
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 84);
-				pCoexDm->psTdmaDuAdjType = 84;
-			}
-		}
-		else if(result == 1)
-		{
-/*
-			if( (BT_INFO_8192E_2ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 81) ||(pCoexDm->curPsTdma == 82)) )
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-				pCoexDm->psTdmaDuAdjType = 83;
-			}
-*/
-			if(pCoexDm->curPsTdma == 84)
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-				pCoexDm->psTdmaDuAdjType = 83;
-			}
-			else if(pCoexDm->curPsTdma == 83)
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-				pCoexDm->psTdmaDuAdjType = 82;
-			}
-			else if(pCoexDm->curPsTdma == 82)
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 81);
-				pCoexDm->psTdmaDuAdjType = 81;
-			}
-			else if((pCoexDm->curPsTdma == 81)&&((pCoexSta->nScanAPNum <= NOISY_AP_NUM_THRESH)))
-			{
-				halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 80);
-				pCoexDm->psTdmaDuAdjType = 80;
-			}
-
-		}
-
-		if( pCoexDm->curPsTdma != 80 &&
-			pCoexDm->curPsTdma != 81 &&
-			pCoexDm->curPsTdma != 82 &&
-			pCoexDm->curPsTdma != 83 &&
-			pCoexDm->curPsTdma != 84 )
-		{
-			// recover to previous adjust type
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-	}
-}
-
-VOID
-halbtc8192e2ant_GetBtRssiThreshold(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte				pThres0,
-	IN	pu1Byte				pThres1
-	)
-{
-	u1Byte antType, btThreshold=0;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_ANT_TYPE, &antType);
-
-	switch(antType)
-	{
-		case BTC_ANT_TYPE_0:	// 92E with SPDT
-			*pThres0 = 100;
-			*pThres1 = 100;
-			break;
-		case BTC_ANT_TYPE_1:	//92E without SPDT, poor antenna isolation
-			*pThres0 = 34;
-			*pThres1 = 42;
-			break;
-		case BTC_ANT_TYPE_2:	//92E without SPDT, normal antenna isolation
-			*pThres0 = 34;		//92E with coupler, goodl antenna isolation
-			*pThres1 = 42;
-			break;
-		case BTC_ANT_TYPE_3:
-			*pThres0 = 34;
-			*pThres1 = 42;
-			break;
-		case BTC_ANT_TYPE_4:
-			*pThres0 = 34;
-			*pThres1 = 42;
-			break;
-		default:
-			break;
-	}
-}
-
-
-//undefined
-VOID
-halbtc8192e2ant_ActionUndefined(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// power save state
-	halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	// coex table
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	
-	// pstdma
-	halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-	
-	// decrease BT power
-	halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-
-// SCO only or SCO+PAN(HS)
-VOID
-halbtc8192e2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-		u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-		u4Byte		wifiBw;
-		u1Byte		btThresh0=0, btThresh1=0;
-		BOOLEAN 	bApEnable=FALSE;
-	
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	
-		halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-		btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-	
-		wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-		//	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-	
-		// power save state
-		if((bApEnable == TRUE) || (BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState))))
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	//		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, TRUE, 0x50, 0x4);
-	
-		// coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		else
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	
-		// pstdma
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)))
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		else
-			halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-	
-		// decrease BT power
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionScoPan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-	BOOLEAN 		bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	//	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if((bApEnable == TRUE) || (BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	else
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-
-	// pstdm
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);	//shielding room
-	else if (BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 10);	//open space	//antenna at BT
-	else	//low RSSI
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 86);
-
-
-/*	
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH)  // BT HIGH RSSI & shielding room
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	//shielding room
-	else if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);		//open space 
-	else	//low RSSI
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		anttype=0;
-	BOOLEAN 	bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-//	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-//	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-	if(anttype == 0)//ANTTYPE = 0   92E 2ant with SPDT
-	{
-		// power save state & pstdma & coex table
-       	pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else if(anttype == 1) //92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation
-	{		
-		// power save state & pstdma & coex table
-       	pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else if(anttype == 2)//ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 9);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);	
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 9);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 9);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-		}
-	}
-	else if(anttype == 3)	//ANTTYPE = 3,  92E 3ant with good ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-	}
-	else	//ANTTYPE = 4 for test
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-
-	// power save state
-	halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// coex table
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-
-	// decrease BT power
-	halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8192e2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		anttype=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-//	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-//	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-//	anttype = 4;
-
-	if(anttype == 0)//ANTTYPE = 0   92E 2ant with SPDT
-	{
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-	else if(anttype == 1) //92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);	//shielding room
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-
-	}
-	else if(anttype == 2)//ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);	
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-	else if(anttype == 3)	//ANTTYPE = 3,  92E 3ant with good ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-	}
-	else	//ANTTYPE = 4 for test
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH)  // BT HIGH RSSI & shielding room
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	//shielding room
-	else if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x06);		//open space 
-	else	//low RSSI
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-//	halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 1);
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-
-	if( (btRssiState == BTC_RSSI_STATE_LOW) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_LOW) )
-	{
-		halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 2);
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else if( (btRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_MEDIUM) )
-	{
-		halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 2);
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	}
-	else if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 2);
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-	}
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	//	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);	//shielding room
-	else if (BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);	//open space	//antenna at BT
-	else	//low RSSI
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 85);
-
-/*	
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH)  // BT HIGH RSSI & shielding room
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	//shielding room
-	else if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);		//open space 
-	else	//low RSSI
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-//PAN(HS) only
-VOID
-halbtc8192e2ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-//	halbtc8192e2ant_SwitchSsType(pBtCoexist, NORMAL_EXEC, 1);
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-
-	if( (btRssiState == BTC_RSSI_STATE_LOW) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_LOW) )
-	{
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else if( (btRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_MEDIUM) )
-	{
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	}
-	else if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8192e2ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	//	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if((BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);	//shielding room
-	else if (BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);	//open space	//antenna at BT
-	else	//low RSSI
-{
-		pCoexDm->bAutoTdmaAdjust = FALSE;   
-                pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 86);
-}
-
-/*	
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH)  // BT HIGH RSSI & shielding room
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	//shielding room
-	else if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);		//open space 
-	else	//low RSSI
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	//	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if((BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-	else
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdm
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-	    halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);	//shielding room
-	else if (BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-	    halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);	//open space	//antenna at BT
-	else	//low RSSI
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 86);
-
-/*	
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH)  // BT HIGH RSSI & shielding room
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	//shielding room
-	else if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);		//open space 
-	else	//low RSSI
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8192e2ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	//	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if((BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-	else
-		halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0); //6
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);	//shielding room
-	else if (BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);	//open space	//antenna at BT
-	else	//low RSSI
-	{
-		pCoexDm->bAutoTdmaAdjust = FALSE;   
-                pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;
-		halbtc8192e2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 86);
-         }
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH)  // BT HIGH RSSI & shielding room
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/	
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	//shielding room
-	else if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);		//open space 
-	else	//low RSSI
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0, anttype=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-	
-	//	halbtc8192e2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	//	btRssiState = halbtc8192e2ant_BtRssiState(3, btThresh0, btThresh1);
-	
-	wifiRssiState = halbtc8192e2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8192e2ant_BtRssiState(3, 34, 42);
-	
-	if(anttype == 0)//ANTTYPE = 0	92E 2ant with SPDT
-	{
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-		else
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-	}
-	else if(anttype == 1) //92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-		else
-		{
-				halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-				halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-				halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-	}
-	else if(anttype == 2)//ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);	
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-	}
-	else if(anttype == 3)	//ANTTYPE = 3,  92E 3ant with good ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8192e2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-	}
-	else	//ANTTYPE = 4 for test
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8192e2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8192e2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8192e2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH)  // BT HIGH RSSI & shielding room
-		halbtc8192e2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-		
-	// limited Rx
-	halbtc8192e2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-		
-	// fw dac swing level
-	halbtc8192e2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	// sw mechanism
-	halbtc8192e2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	//shielding room
-	else if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH))
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x06); 	//open space 
-	else	//low RSSI
-		halbtc8192e2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8192e2ant_ActionBtWhckTest(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-
-}
-
-VOID
-halbtc8192e2ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{		
-
-}
-
-VOID
-halbtc8192e2ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN				bWifiUnder5G=FALSE;
-	u1Byte				btInfoOriginal=0, btRetryCnt=0;
-	u1Byte				algorithm=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	algorithm = halbtc8192e2ant_ActionAlgorithm(pBtCoexist);
-	if(pCoexSta->bC2hBtInquiryPage && (BT_8192E_2ANT_COEX_ALGO_PANHS!=algorithm))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under inquiry/page scan !!\n"));
-		halbtc8192e2ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-
-	pCoexDm->curAlgorithm = algorithm;
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Algorithm = %d \n", pCoexDm->curAlgorithm));
-
-	if(halbtc8192e2ant_IsCommonAction(pBtCoexist))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant common.\n"));
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;
-	}
-	else
-	{
-		if(pCoexDm->curAlgorithm != pCoexDm->preAlgorithm)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 
-				pCoexDm->preAlgorithm, pCoexDm->curAlgorithm));
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;
-		}
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8192E_2ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO.\n"));
-				halbtc8192e2ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_SCO_PAN:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO+PAN(EDR).\n"));
-				halbtc8192e2ant_ActionScoPan(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID.\n"));
-				halbtc8192e2ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP.\n"));
-				halbtc8192e2ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n"));
-				halbtc8192e2ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n"));
-				halbtc8192e2ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HS mode.\n"));
-				halbtc8192e2ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n"));
-				halbtc8192e2ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-				halbtc8192e2ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-				halbtc8192e2ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8192E_2ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n"));
-				halbtc8192e2ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = undefined!!\n"));
-				halbtc8192e2ant_ActionUndefined(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8192e2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp
-	)
-{
-	u4Byte	u4Tmp=0;
-	u2Byte	u2Tmp=0;
-	u1Byte	u1Tmp=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	if(bBackUp)
-	{
-		// backup rf 0x1e value
-		pCoexDm->btRf0x1eBackup = 
-			pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);
-
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-
-	// antenna sw ctrl to bt
-	halbtc8192e2ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, TRUE, FALSE);
-
-	halbtc8192e2ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	// antenna switch control parameter
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x858, 0x55555555);
-
-	// coex parameters
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x3);
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	// enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-
-	// enable PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x20);
-	// enable mailbox interface
-	u2Tmp = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x40);
-	u2Tmp |= BIT9;
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x40, u2Tmp);
-
-	// enable PTA I2C mailbox 
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x101);
-	u1Tmp |= BIT4;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x101, u1Tmp);
-
-	// enable bt clock when wifi is disabled.
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x93);
-	u1Tmp |= BIT0;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x93, u1Tmp);
-	// enable bt clock when suspend.
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x7);
-	u1Tmp |= BIT0;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x7, u1Tmp);
-}
-
-//============================================================
-// work around function start with wa_halbtc8192e2ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8192e2ant_
-//============================================================
-VOID
-EXhalbtc8192e2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8192e2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8192e2ant_InitHwConfig(pBtCoexist, TRUE);
-}
-
-VOID
-EXhalbtc8192e2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8192e2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8192e2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u2Byte				u2Tmp[4];
-	u4Byte				u4Tmp[4];
-	u4Byte				faOfdm, faCck;
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Antenna type:", \
-		pBoardInfo->antType);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%d/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8192e2Ant, GLCoexVer8192e2Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-		pStackInfo->bScoExist, pStackInfo->bHidExist, pStackInfo->bPanExist, pStackInfo->bA2dpExist);
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8192E_2ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8192e2Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-/*
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "SS Type", \
-		pCoexDm->curSsType);
-	CL_PRINTF(cliBuf);
-*/
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Rate Mask", \
-			pBtCoexist->btInfo.raMask);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);	
-
-	psTdmaCase = pCoexDm->curPsTdma;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)", "PS TDMA", \
-		pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-		pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-		pCoexDm->psTdmaPara[4], psTdmaCase, pCoexDm->bAutoTdmaAdjust);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "DecBtPwr/ IgnWlanAct", \
-		pCoexDm->curBtDecPwrLvl, pCoexDm->bCurIgnoreWlanAct);
-	CL_PRINTF(cliBuf);
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "backup ARFR1/ARFR2/RL/AMaxTime", \
-		pCoexDm->backupArfrCnt1, pCoexDm->backupArfrCnt2, pCoexDm->backupRetryLimit, pCoexDm->backupAmpduMaxTime);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-	u2Tmp[0] = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "0x430/0x434/0x42a/0x456", \
-		u4Tmp[0], u4Tmp[1], u2Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc04);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xd04);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x90c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0xc04/ 0xd04/ 0x90c", \
-		u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x778", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-	
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x92c);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x930);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x92c/ 0x930", \
-		(u1Tmp[0]), u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4f);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x40/ 0x4f", \
-		u1Tmp[0], u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-	
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(hp rx[31:16]/tx[15:0])", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(lp rx[31:16]/tx[15:0])", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8192E_2ANT == 1)
-	halbtc8192e2ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8192e2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		halbtc8192e2ant_CoexAllOff(pBtCoexist);
-		halbtc8192e2ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8192e2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8192e2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &pCoexSta->nScanAPNum);
-
-	}
-}
-
-VOID
-EXhalbtc8192e2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8192e2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-
-	
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-	
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);	
-}
-
-VOID
-EXhalbtc8192e2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8192e2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtBusy=FALSE, bLimitedDig=FALSE;
-	BOOLEAN			bWifiConnected=FALSE;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8192E_2ANT_MAX)
-		rspSource = BT_INFO_SRC_8192E_2ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(BT_INFO_SRC_8192E_2ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2+10;
-		
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if( (pCoexSta->btInfoExt & BIT1) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-			if(bWifiConnected)
-			{
-				EXhalbtc8192e2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8192e2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-		
-		if( (pCoexSta->btInfoExt & BIT3) )
-		{
-			if(!pBtCoexist->bManualControl && !pBtCoexist->bStopCoexDm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-				halbtc8192e2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-			}
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-
-#if(BT_AUTO_REPORT_ONLY_8192E_2ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8192e2ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8192E_2ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8192E_2ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8192E_2ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8192E_2ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8192E_2ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8192E_2ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-	}
-
-	halbtc8192e2ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	if(!(btInfo&BT_INFO_8192E_2ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8192E_2ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8192E_2ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8192E_2ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8192E_2ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8192E_2ANT_B_ACL_BUSY)
-	{
-		pCoexDm->btStatus = BT_8192E_2ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8192E_2ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-	
-	if( (BT_8192E_2ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8192E_2ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8192E_2ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bBtBusy = TRUE;
-		bLimitedDig = TRUE;
-	}
-	else
-	{
-		bBtBusy = FALSE;
-		bLimitedDig = FALSE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	pCoexDm->bLimitedDig = bLimitedDig;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bLimitedDig);
-
-	halbtc8192e2ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8192e2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8192e2ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);
-	halbtc8192e2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	EXhalbtc8192e2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8192e2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n", 
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n", 
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n", 
-			GLCoexVerDate8192e2Ant, GLCoexVer8192e2Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8192E_2ANT == 0)
-	halbtc8192e2ant_QueryBtInfo(pBtCoexist);
-	halbtc8192e2ant_MonitorBtCtr(pBtCoexist);
-	halbtc8192e2ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	if( halbtc8192e2ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust)
-	{
-		halbtc8192e2ant_RunCoexistMechanism(pBtCoexist);
-	}
-#endif
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e2Ant.h
deleted file mode 100644
index 5c01aceb3470..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8192e2Ant.h
+++ /dev/null
@@ -1,232 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8192E 2Ant BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8192E_2ANT				0
-
-#define	BT_INFO_8192E_2ANT_B_FTP						BIT7
-#define	BT_INFO_8192E_2ANT_B_A2DP					BIT6
-#define	BT_INFO_8192E_2ANT_B_HID						BIT5
-#define	BT_INFO_8192E_2ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8192E_2ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8192E_2ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8192E_2ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8192E_2ANT_B_CONNECTION				BIT0
-
-#define	BT_INFO_8192E_2ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT		2
-#define 	NOISY_AP_NUM_THRESH						5
-
-typedef enum _BT_INFO_SRC_8192E_2ANT{
-	BT_INFO_SRC_8192E_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8192E_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8192E_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8192E_2ANT_MAX
-}BT_INFO_SRC_8192E_2ANT,*PBT_INFO_SRC_8192E_2ANT;
-
-typedef enum _BT_8192E_2ANT_BT_STATUS{
-	BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8192E_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8192E_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8192E_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8192E_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8192E_2ANT_BT_STATUS_MAX
-}BT_8192E_2ANT_BT_STATUS,*PBT_8192E_2ANT_BT_STATUS;
-
-typedef enum _BT_8192E_2ANT_COEX_ALGO{
-	BT_8192E_2ANT_COEX_ALGO_UNDEFINED		= 0x0,
-	BT_8192E_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8192E_2ANT_COEX_ALGO_SCO_PAN			= 0x2,
-	BT_8192E_2ANT_COEX_ALGO_HID				= 0x3,
-	BT_8192E_2ANT_COEX_ALGO_A2DP			= 0x4,
-	BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS		= 0x5,
-	BT_8192E_2ANT_COEX_ALGO_PANEDR			= 0x6,
-	BT_8192E_2ANT_COEX_ALGO_PANHS			= 0x7,
-	BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x8,
-	BT_8192E_2ANT_COEX_ALGO_PANEDR_HID		= 0x9,
-	BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0xa,
-	BT_8192E_2ANT_COEX_ALGO_HID_A2DP		= 0xb,
-	BT_8192E_2ANT_COEX_ALGO_MAX				= 0xc
-}BT_8192E_2ANT_COEX_ALGO,*PBT_8192E_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8192E_2ANT{
-	// fw mechanism
-	u1Byte		preBtDecPwrLvl;
-	u1Byte		curBtDecPwrLvl;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bResetTdmaAdjust;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bAutoTdmaAdjustLowRssi;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	u4Byte		backupArfrCnt1;	// Auto Rate Fallback Retry cnt
-	u4Byte		backupArfrCnt2;	// Auto Rate Fallback Retry cnt
-	u2Byte		backupRetryLimit;
-	u1Byte		backupAmpduMaxTime;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	u1Byte		preSsType;
-	u1Byte		curSsType;
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-	u1Byte		curRaMaskType;
-	u1Byte		preArfrType;
-	u1Byte		curArfrType;
-	u1Byte		preRetryLimitType;
-	u1Byte		curRetryLimitType;
-	u1Byte		preAmpduTimeType;
-	u1Byte		curAmpduTimeType;
-} COEX_DM_8192E_2ANT, *PCOEX_DM_8192E_2ANT;
-
-typedef struct _COEX_STA_8192E_2ANT{	
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8192E_2ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8192E_2ANT_MAX];
-	BOOLEAN					bC2hBtInquiryPage;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	u1Byte					nScanAPNum;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;
-
-	u1Byte					nCoexTableType;
-	BOOLEAN					bForceLpsOn;
-
-	u1Byte					disVerInfoCnt;
-}COEX_STA_8192E_2ANT, *PCOEX_STA_8192E_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8192e2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192e2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8192e2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8192e2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8192e2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8192e2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8192e2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8192e2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8192e2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8192e2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b1Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b1Ant.c
deleted file mode 100644
index 2feeb6ad9454..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b1Ant.c
+++ /dev/null
@@ -1,5240 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8703B Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8703b1Ant.tmh"
-#endif
-
-#if (RTL8703B_SUPPORT == 1)
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8703B_1ANT		GLCoexDm8703b1Ant;
-static PCOEX_DM_8703B_1ANT 	pCoexDm=&GLCoexDm8703b1Ant;
-static COEX_STA_8703B_1ANT		GLCoexSta8703b1Ant;
-static PCOEX_STA_8703B_1ANT	pCoexSta=&GLCoexSta8703b1Ant;
-static PSDSCAN_STA_8703B_1ANT	GLPsdScan8703b1Ant;
-static PPSDSCAN_STA_8703B_1ANT pPsdScan = &GLPsdScan8703b1Ant;
-
-
-const char *const GLBtInfoSrc8703b1Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8703b1Ant=20150904;
-u4Byte	GLCoexVer8703b1Ant=0x04;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8703b1ant_
-//============================================================
-u1Byte
-halbtc8703b1ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8703b1ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8703b1ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-VOID
-halbtc8703b1ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-VOID
-halbtc8703b1ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-VOID
-halbtc8703b1ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8703b1ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType
-	)
-{
-	switch(raMaskType)
-	{
-		case 0:	// normal mode
-			halbtc8703b1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0);
-			break;
-		case 1:	// disable cck 1/2
-			halbtc8703b1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x00000003);
-			break;
-		case 2:	// disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4
-			halbtc8703b1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0001f1f7);
-			break;
-		default:
-			break;
-	}
-
-	halbtc8703b1ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8703b1ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8703b1ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-}
-
-VOID
-halbtc8703b1ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-VOID
-halbtc8703b1ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8703b1ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp, u4Tmp1;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp, u1Tmp1;
-	s4Byte			wifiRssi;
-	static u1Byte		NumOfBtCounterChk = 0;
-	
-       //to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS
-	//if (! (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e) & 0x8) ) 
-
-	if (pCoexSta->bUnderIps)
-	{
-		//pCoexSta->highPriorityTx = 65535;
-		//pCoexSta->highPriorityRx = 65535;
-		//pCoexSta->lowPriorityTx = 65535;
-		//pCoexSta->lowPriorityRx = 65535;
-		//return;
-	}
-		
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	if( (pCoexSta->lowPriorityTx > 1150)  && (!pCoexSta->bC2hBtInquiryPage))
-		pCoexSta->popEventCnt++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		regHPRx, regHPTx, regLPRx, regLPTx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-
-	if ((regHPTx == 0) && (regHPRx ==0) && (regLPTx == 0) && (regLPRx == 0))
-	{
-		NumOfBtCounterChk++;
-		if (NumOfBtCounterChk >= 3)
-		{
-			halbtc8703b1ant_QueryBtInfo(pBtCoexist);
-			NumOfBtCounterChk = 0;
-		}
-	}
-}
-
-
-VOID
-halbtc8703b1ant_MonitorWiFiCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u2Byte 	u2Tmp[3];
-	s4Byte	wifiRssi=0;
-	BOOLEAN bWifiBusy = FALSE, bWifiUnderBMode = FALSE;
-	static u1Byte nCCKLockCounter = 0;
-	u4Byte	TotalCnt;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->nCRCOK_CCK = 0;
-		pCoexSta->nCRCOK_11g = 0;
-		pCoexSta->nCRCOK_11n = 0;
-		pCoexSta->nCRCOK_11nAgg = 0;
-
-		pCoexSta->nCRCErr_CCK = 0;
-		pCoexSta->nCRCErr_11g = 0;
-		pCoexSta->nCRCErr_11n = 0;
-		pCoexSta->nCRCErr_11nAgg = 0;	
-	}
-	else
-	{
-		pCoexSta->nCRCOK_CCK	= pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf88);
-		pCoexSta->nCRCOK_11g 	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf94);
-		pCoexSta->nCRCOK_11n	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf90);
-		pCoexSta->nCRCOK_11nAgg= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfb8);
-
-		pCoexSta->nCRCErr_CCK 	 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf84);
-		pCoexSta->nCRCErr_11g 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf96);
-		pCoexSta->nCRCErr_11n 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf92);
-		pCoexSta->nCRCErr_11nAgg = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfba);		
-	}
-
-
-	//reset counter
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x0);
-
-	if ( (bWifiBusy) && (wifiRssi >= 30) && (!bWifiUnderBMode))
-	{
-		TotalCnt = pCoexSta->nCRCOK_CCK + pCoexSta->nCRCOK_11g + pCoexSta->nCRCOK_11n + 
-				pCoexSta->nCRCOK_11nAgg;
-	
-		if ( (pCoexDm->btStatus == BT_8703B_1ANT_BT_STATUS_ACL_BUSY) ||
-			(pCoexDm->btStatus == BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-			(pCoexDm->btStatus == BT_8703B_1ANT_BT_STATUS_SCO_BUSY) )
-		{
-			if (pCoexSta->nCRCOK_CCK >(TotalCnt -pCoexSta->nCRCOK_CCK)) 
-			{
-				if (nCCKLockCounter < 3)
-				 nCCKLockCounter++;
-			}
-			else
-			{
-				if (nCCKLockCounter > 0)
-				 nCCKLockCounter--;
-			}
-
-		}
-		else
-		{
-			if (nCCKLockCounter > 0)
-			  nCCKLockCounter--;
-		}
-	}
-	else
-	{
-		if (nCCKLockCounter > 0)
-			nCCKLockCounter--;
-	}
-
-	if (!pCoexSta->bPreCCKLock)
-	{
-
-		if (nCCKLockCounter >= 3)
-		 pCoexSta->bCCKLock = TRUE;
-		else
-		 pCoexSta->bCCKLock = FALSE;			
-	}
-	else
-	{
-		if (nCCKLockCounter == 0)
-		 pCoexSta->bCCKLock = FALSE;
-		else
-		 pCoexSta->bCCKLock = TRUE;		
-	}
-
-	if  (pCoexSta->bCCKLock)
-		pCoexSta->bCCKEverLock = TRUE;
-	
-	pCoexSta->bPreCCKLock =  pCoexSta->bCCKLock;	
-		
-
-}
-
-BOOLEAN
-halbtc8703b1ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN bWifiConnected=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8703b1ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-	pBtLinkInfo->bBtHiPriLinkExist = pCoexSta->bBtHiPriLinkExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-VOID
-halbtc8703b1ant_UpdateWifiChannelInfo(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	BOOLEAN			bWifiUnderBMode = FALSE;
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;  //enable BT AFH skip WL channel for 8703b because BT Rx LO interference
-		//H2C_Parameter[0] = 0x0;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-		
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);
-
-}
-
-u1Byte
-halbtc8703b1ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8703B_1ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO only\n"));
-			algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID only\n"));
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP only\n"));
-				algorithm = BT_8703B_1ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(HS) only\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(EDR) only\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID\n"));
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(HS)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(EDR)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP\n"));
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(HS)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(EDR)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(HS)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(EDR)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8703b1ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8703b1ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8703b1ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID halbtc8703b1ant_WriteScoreBoard(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u2Byte				scoreboardval				
-	)
-{
-	u2Byte  val;
-
-	val = (scoreboardval & 0x7fff) | 0x8000;
-
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0xaa, val);
-
-#if 0
-	u1Byte			H2C_Parameter[3] ={0,0,0};
-	
-
-	// write "Set Status"
-	H2C_Parameter[0] = 0x2;   
-
-	// write score board 15-bit value to H2C parameter
-	H2C_Parameter[1] = scoreboardval & 0xff;
-	H2C_Parameter[2] = (scoreboardval & 0x7f00) >> 8;
-
-	// Set Interrupt to BT
-	H2C_Parameter[2] = H2C_Parameter[2] | 0x80; 
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Write  BT Scoreboard: H2C 0x71[1:0]= %02x%02x\n", 
-	                             H2C_Parameter[2], H2C_Parameter[1]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x71, 3, H2C_Parameter);
-
-#endif 
-}
-
-VOID halbtc8703b1ant_ReadScoreBoard(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN   u2Byte*				uScoreBoardVal
-	)
-{
-
-	*uScoreBoardVal = (pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xaa)) & 0x7fff;
-
-
-
-#if 0
-	u1Byte			H2C_Parameter[3] ={0,0,0};
-
-	// write "Get Status"
-	H2C_Parameter[0] = 0x1;   
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Read  BT Scoreboard!!\n"));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x71, 3, H2C_Parameter);
-
-	//the BT Scoreboard will be returned by C2H from  EXhalbtc8703b1ant_ScoreBoardStatusNotify()
-#endif	
-}
-
-VOID halbtc8703b1ant_PostActiveStateToBT(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiActive
-	)
-{
-
-	if(bWifiActive)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Post WL = Active in Scoreboard!!\n"));
-		halbtc8703b1ant_WriteScoreBoard(pBtCoexist, 0x0001);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Post WL = Non-Active in Scoreboard!!\n"));
-		halbtc8703b1ant_WriteScoreBoard(pBtCoexist, 0x0000);
-	}
-
-	// The BT should set "No Shunt-down" mode if WL = Active for BT Synthesizer on/off interference WL Lo issue at 8703b b-cut.
-
-}
-
-VOID
-halbtc8703b1ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!") ));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8703b1ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8703b1ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-u4Byte
-halbtc8703b1ant_LTECoex_InDirectReadReg(
-IN	PBTC_COEXIST		pBtCoexist,
-IN 	u2Byte				RegAddr
-)	
-{
-	u4Byte j =0;
-
-	
-	//wait for ready bit before access 0x7c0		
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x7c0, 0x800F0000|RegAddr);
-
-	do
-	{
-		j++;
-	}while( ((pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x7c3) & BIT5) ==0) && (j <BT_8703B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT) );
-
-
-	return(pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x7c8));   //get read data
-
-}
-
-VOID
-halbtc8703b1ant_LTECoex_InDirectWriteReg(
-IN	PBTC_COEXIST		pBtCoexist,
-IN 	u2Byte				RegAddr,
-IN 	u4Byte				BitMask,
-IN	u4Byte				RegValue
-)
-{
-	u4Byte val, i=0, j=0, bitpos = 0;
-	
-
-	if (BitMask == 0x0)
-	 return;	
-	if (BitMask == 0xffffffff)
-	{
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x7c4, RegValue); //put write data
-
-		//wait for ready bit before access 0x7c0
-		do
-		{
-			j++;
-		}while( ((pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x7c3) & BIT5) ==0) && (j <BT_8703B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT) );
-		
-		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x7c0, 0xc00F0000|RegAddr);
-	}
-	else
-	{
-            for(i=0; i<=31; i++)
-            	{
-			if ( ((BitMask >> i) & 0x1) == 0x1)
-			{
-				bitpos = i;
-				break;
-			}
-            	}
-
-		//read back register value before write 
-		val = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, RegAddr);
-		val = (val & (~BitMask)) | (RegValue << bitpos);
-
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x7c4, val); //put write data
-
-		//wait for ready bit before access 0x7c0		
-		do
-		{
-			j++;
-		}while( ((pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x7c3) & BIT5) ==0) && (j <BT_8703B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT) );
-		
-		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x7c0, 0xc00F0000|RegAddr);
-		
-	}
-
-}
-
-void
-halbtc8703b1ant_LTECoex_Enable(
-IN	PBTC_COEXIST		pBtCoexist,
-IN	BOOLEAN				bEnable
-)
-{
-	u1Byte val;
-	
-	val =  (bEnable)? 1 : 0; 
-	halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, 0x80, val);  //0x38[7]
-
-}
-
-void
-halbtc8703b1ant_LTECoex_PathControlOwner(
-IN	PBTC_COEXIST		pBtCoexist,
-IN	BOOLEAN				bWiFiControl
-)
-{
-	u1Byte val;
-	
-	val =  (bWiFiControl)? 1 : 0; 
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x73, 0x4, val); //0x70[26]
-
-}
-
-void
-halbtc8703b1ant_LTECoex_Set_GNT_BT(
-IN	PBTC_COEXIST		pBtCoexist,
-IN	u1Byte				nControlBlock,
-IN	BOOLEAN				bSWControl,
-IN	u1Byte				nState
-)
-{
-	u4Byte val=0, BitMask;
-	
-	nState = nState & 0x1;	
-	val =  (bSWControl)? ((nState<<1) | 0x1) : 0; 
-
-	switch(nControlBlock)
-	{
-		case BT_8703B_1ANT_GNT_BLOCK_RFC_BB:	
-		default:
-			BitMask = 0xc000;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[15:14]
-			BitMask = 0x0c00;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[11:10]						
-			break;
-		case BT_8703B_1ANT_GNT_BLOCK_RFC:
-			BitMask = 0xc000;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[15:14]
-			break;
-		case BT_8703B_1ANT_GNT_BLOCK_BB:
-			BitMask = 0x0c00;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[11:10]
-			break;
-
-	}
-	
-}
-
-void
-halbtc8703b1ant_LTECoex_Set_GNT_WL(
-IN	PBTC_COEXIST		pBtCoexist,
-IN	u1Byte				nControlBlock,
-IN	BOOLEAN				bSWControl,
-IN	u1Byte				nState
-)
-{
-	u4Byte val=0, BitMask;
-	
-	nState = nState & 0x1;	
-	val =  (bSWControl)? ((nState<<1) | 0x1) : 0; 
-
-	switch(nControlBlock)
-	{
-		case BT_8703B_1ANT_GNT_BLOCK_RFC_BB:	
-		default:
-			BitMask = 0x3000;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[13:12]
-			BitMask = 0x0300;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[9:8]						
-			break;
-		case BT_8703B_1ANT_GNT_BLOCK_RFC:
-			BitMask = 0x3000;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[13:12]
-			break;
-		case BT_8703B_1ANT_GNT_BLOCK_BB:
-			BitMask = 0x0300;
-			halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, 0x38, BitMask, val); // 0x38[9:8]
-			break;
-
-	}
-
-}
-
-void
-halbtc8703b1ant_LTECoex_Set_CoexTable(
-IN	PBTC_COEXIST		pBtCoexist,
-IN	u1Byte				nTableType,
-IN	u2Byte				nTableContent
-)
-{
- 	u2Byte RegAddr = 0x0000;
-
-	switch(nTableType)
-	{
-		case BT_8703B_1ANT_CTT_WL_VS_LTE:
-			RegAddr = 0xa0;
-			break;
-		case BT_8703B_1ANT_CTT_BT_VS_LTE:
-			RegAddr = 0xa4;
-			break;
-	}
-
-	if (RegAddr != 0x0000)
-		halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, RegAddr, 0xffff, nTableContent); // 0xa0[15:0] or 0xa4[15:0]
-
-
-}
-
-
-void
-halbtc8703b1ant_LTECoex_Set_BreakTable(
-IN	PBTC_COEXIST		pBtCoexist,
-IN	u1Byte				nTableType,
-IN	u1Byte				nTableContent
-)
-{
-	u2Byte RegAddr = 0x0000;
-
-	switch(nTableType)
-	{
-		case BT_8703B_1ANT_LBTT_WL_BREAK_LTE:
-			RegAddr = 0xa8;
-			break;
-		case BT_8703B_1ANT_LBTT_BT_BREAK_LTE:
-			RegAddr = 0xac;
-			break;
-		case BT_8703B_1ANT_LBTT_LTE_BREAK_WL:
-			RegAddr = 0xb0;
-			break;
-		case BT_8703B_1ANT_LBTT_LTE_BREAK_BT:
-			RegAddr = 0xb4;
-			break;	
-	}
-
-	if (RegAddr != 0x0000)
-		halbtc8703b1ant_LTECoex_InDirectWriteReg(pBtCoexist, RegAddr, 0xff, nTableContent); // 0xa8[15:0] or 0xb4[15:0]
-
-
-}
-
-VOID
-halbtc8703b1ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8703b1ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8703b1ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8703b1ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	PBTC_BOARD_INFO	pBoardInfo=&pBtCoexist->boardInfo;
-
-	u4Byte	nBreakTable;
-	u1Byte	nSelectTable;	
-
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], ********** CoexTable(%d) **********\n", type));
-	
-	pCoexSta->nCoexTableType = type;
-
-	if (pCoexSta->bConCurrentRxModeOn == TRUE)
-	{
-		nBreakTable = 0xf0ffffff;  //set WL hi-pri can break BT
-		nSelectTable = 0xb; 		//set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS)
-	}
-	else
-	{
-		nBreakTable = 0xffffff;
-		nSelectTable = 0x3;
-	}
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, nBreakTable, nSelectTable);
-			break;
-		case 1:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, nBreakTable, nSelectTable);
-			break;
-		case 2:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0xaa5a5a5a, 0xaa5a5a5a, nBreakTable, nSelectTable);
-			break;
-		case 3:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0xaa555555, 0xaa5a5a5a, nBreakTable, nSelectTable);
-			break;
-		case 4:
-			//if (  (pCoexSta->bCCKEverLock)  &&  (pCoexSta->nScanAPNum <= 5) )
-			//	halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0xaa555555, 0xaaaa5a5a, nBreakTable, nSelectTable);
-			//else
-				halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0xaa555555, 0xaa5a5a5a, nBreakTable, nSelectTable);
-			break;
-		case 5:
-			//if (  (pCoexSta->bCCKEverLock)  &&  (pCoexSta->nScanAPNum <= 5) )
-			//	halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0xaa555555, 0xaaaa5a5a, nBreakTable, nSelectTable);
-			//else
-				halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, nBreakTable, nSelectTable);
-			break;
-		case 6:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaaaaaa, nBreakTable, nSelectTable);
-			break;
-		case 7:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, nBreakTable, nSelectTable);
-			break;
-		case 8:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, nBreakTable, nSelectTable);
-			break;
-		case 9:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, nBreakTable, nSelectTable);
-			break;
-		case 10:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, nBreakTable, nSelectTable);
-			break;
-		case 11:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, nBreakTable, nSelectTable);
-			break;
-		case 12:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, nBreakTable, nSelectTable);
-			break;
-		case 13:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0xaaaaaaaa, nBreakTable, nSelectTable);
-			break;
-		case 14:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5ada5ada, nBreakTable, nSelectTable);
-			break;
-		case 15:
-			halbtc8703b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0xaaaaaaaa, nBreakTable, nSelectTable);
-			break;	
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8703b1ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8703b1ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8703b1ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8703b1ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8703b1ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8703b1ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8703b1ant_SwMechanism(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN 		bLowPenaltyRA
-	) 
-{
-	halbtc8703b1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8703b1ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	PBTC_BOARD_INFO pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte			fwVer=0, u4Tmp=0, cntBtCalChk=0;
-	BOOLEAN			bPgExtSwitch=FALSE;
-	BOOLEAN			bUseExtSwitch=FALSE;
-	BOOLEAN			bIsInMpMode = FALSE;
-	u1Byte			H2C_Parameter[2] ={0}, u1Tmp = 0;
-	u4Byte			u4Tmp1=0, u4Tmp2=0;
-
-	pCoexDm->curAntPosType = antPosType;	
-
-#if 1	
-		u4Tmp1 = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x38);
-		u4Tmp2 = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x54);
-		u1Tmp  = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x73);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** (Before Setup) 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n", u1Tmp, u4Tmp1, u4Tmp2));
-#endif
-
-	if(bInitHwCfg)
-	{	
-		//Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required)
-		halbtc8703b1ant_LTECoex_Enable(pBtCoexist, 0x0);
-
-		//GNT_WL_LTE always = 1 (this should be config if LTE coex is required)
-		halbtc8703b1ant_LTECoex_Set_CoexTable(pBtCoexist, BT_8703B_1ANT_CTT_WL_VS_LTE, 0xffff);
-
-		//GNT_BT_LTE always = 1 (this should be config if LTE coex is required)
-		halbtc8703b1ant_LTECoex_Set_CoexTable(pBtCoexist, BT_8703B_1ANT_CTT_BT_VS_LTE, 0xffff);
-
-		// Wait If BT IQK running, because Path control owner is at BT during BT IQK (setup by WiFi firmware)  
-		while(cntBtCalChk <= 20)
-		{
-				u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x49d);
-				cntBtCalChk++;
-				if(u1Tmp & BIT0)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n", cntBtCalChk));
-					delay_ms(50);
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** BT is NOT calibrating (wait cnt=%d)**********\n", cntBtCalChk));
-					break;
-				}
-		}
-		
-		//set Path control owner to WL at initial step
-		halbtc8703b1ant_LTECoex_PathControlOwner(pBtCoexist, BT_8703B_1ANT_PCO_WLSIDE);			
-	}
-	else if(bWifiOff)
-	{		
-		//Disable LTE Coex Function in WiFi side 
-		halbtc8703b1ant_LTECoex_Enable(pBtCoexist, 0x0);
-
-		//if MP mode
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_IS_IN_MP_MODE, &bIsInMpMode);
-		if(bIsInMpMode)	
-			halbtc8703b1ant_LTECoex_PathControlOwner(pBtCoexist, BT_8703B_1ANT_PCO_WLSIDE); //set Path control owner to WiFI
-		else
-			halbtc8703b1ant_LTECoex_PathControlOwner(pBtCoexist, BT_8703B_1ANT_PCO_BTSIDE);//set Path control owner to BT		
-	}
-	else
-	{			
-			halbtc8703b1ant_LTECoex_PathControlOwner(pBtCoexist, BT_8703B_1ANT_PCO_WLSIDE);		
-	}
-	
-	
-	if(bForceExec || (pCoexDm->curAntPosType != pCoexDm->preAntPosType) || bInitHwCfg || bWifiOff)
-	{
-		// internal switch setting
-		switch(antPosType)
-		{
-			case BTC_ANT_PATH_WIFI:
-				// set GNT_BT to low
-				halbtc8703b1ant_LTECoex_Set_GNT_BT(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW, BT_8703B_1ANT_SIG_STA_SET_TO_LOW);
-				//Set GNT_WL to high
-				halbtc8703b1ant_LTECoex_Set_GNT_WL(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW, BT_8703B_1ANT_SIG_STA_SET_TO_HIGH);
-				break;
-			case BTC_ANT_PATH_BT:
-				halbtc8703b1ant_LTECoex_PathControlOwner(pBtCoexist, BT_8703B_1ANT_PCO_BTSIDE);
-				// set GNT_BT to high
-				/* halbtc8703b1ant_LTECoex_Set_GNT_BT(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW, BT_8703B_1ANT_SIG_STA_SET_TO_HIGH); */
-				//Set GNT_WL to low
-				/* halbtc8703b1ant_LTECoex_Set_GNT_WL(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW, BT_8703B_1ANT_SIG_STA_SET_TO_LOW); */
-				break;
-			default:
-			case BTC_ANT_PATH_PTA:
-				// set GNT_BT to PTA
-				halbtc8703b1ant_LTECoex_Set_GNT_BT(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA, BT_8703B_1ANT_SIG_STA_SET_BY_HW);
-				//Set GNT_WL to PTA
-				halbtc8703b1ant_LTECoex_Set_GNT_WL(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA, BT_8703B_1ANT_SIG_STA_SET_BY_HW);
-				break;
-		}
-	}
-	
-#if 1
-	u4Tmp1 = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x38);
-	u4Tmp2 = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x54);
-	u1Tmp  = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x73);
-
-	if(bInitHwCfg)
-		{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** (After Init) 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n", u1Tmp, u4Tmp1, u4Tmp2));
-		}
-	else if (bWifiOff)
-		{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** (After WiFi off) 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n", u1Tmp, u4Tmp1, u4Tmp2));
-		}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** (After Run time) 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n", u1Tmp, u4Tmp1, u4Tmp2));
-	}
-#endif	
-	
-	pCoexDm->preAntPosType = pCoexDm->curAntPosType;
-}
-
-
-VOID
-halbtc8703b1ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		if(byte1&BIT4 && !(byte1&BIT5))
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-			realByte1 &= ~BIT4;
-			realByte1 |= BIT5;
-
-			realByte5 |= BIT5;
-			realByte5 &= ~BIT6;
-		}
-	}
-
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-
-VOID
-halbtc8703b1ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	PBTC_BOARD_INFO	pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bTurnOnByCnt=FALSE, bWifiBusy=FALSE, bWiFiNoisy=FALSE;
-	u1Byte			psTdmaTypeByCnt=0, rssiAdjustVal=0;
-	u1Byte			psTdmaByte4Val = 0x50, psTdmaByte0Val = 0x51, psTdmaByte3Val =  0x10;
-	s1Byte			nWiFiDurationAdjust = 0x0;
-	static BOOLEAN	 bPreWifiBusy=FALSE;
-
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);	
-
-	if (bWifiBusy != bPreWifiBusy)
-	{
-		bForceExec = TRUE;	
-		bPreWifiBusy = bWifiBusy;
-	}
-
-	if (pCoexDm->bCurPsTdmaOn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-				pCoexDm->curPsTdma));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(off, %d) **********\n", 
-				pCoexDm->curPsTdma));
-	}
-			
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}
-
-	// Adjust WiFi slot by AP number
-	if (pCoexSta->nScanAPNum <= 5)
-		nWiFiDurationAdjust = 5;
-	else if  (pCoexSta->nScanAPNum >= 40)
-		nWiFiDurationAdjust = -15;	
-	else if  (pCoexSta->nScanAPNum >= 20)
-		nWiFiDurationAdjust = -10;	
-	
-	// for A2DP only case, PS-TDMA/ TDMA
-	if ((type == 1) || (type == 2) || (type == 9) || (type == 11) || (type == 101)
-		|| (type == 102) || (type == 109) || (type == 101) || (type == 7) )
-	{
-		if (!pCoexSta->bForceLpsOn)  //Native power save TDMA, only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30
-	{
-			psTdmaByte0Val = 0x61;  //no null-pkt (TDMA)
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-
-			if (type == 7)
-				psTdmaByte4Val = 0x14;  //BT-Auto-Slot
-			else
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle, no dynamic slot
-	}
-		else
-		{
-			psTdmaByte0Val = 0x51;  //null-pkt (PS-TDMA)
-			psTdmaByte3Val = 0x10; //tx-pause at BT-slot
-
-			if (type == 7)
-				psTdmaByte4Val = 0x14;  //BT-Auto-Slot
-			else
-			psTdmaByte4Val = 0x50; // 0x778 = d/1 toggle, dynamic slot
-		}
-	}
-	else if ((type == 3) ||(type == 4) || (type == 13) || (type == 14) || (type == 103) || (type == 113) || (type == 114))
-	{
-		psTdmaByte0Val = 0x51;  //null-pkt (PS-TDMA)
-		psTdmaByte3Val = 0x10; //tx-pause at BT-slot
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle, no dynamic slot
-	}
-	else  //native power save case
-	{
-		psTdmaByte0Val = 0x61;  //no null-pkt  (TDMA)
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-		psTdmaByte4Val = 0x11; // 0x778 = d/1 toggle, no dynamic slot
-		//psTdmaByte4Va is not defne for 0x778 = d/1, 1/1 case 
-		}
-		 
-	//	for A2DP slave 
-	if ((pBtLinkInfo->bSlaveRole == TRUE)	&& (pBtLinkInfo->bA2dpExist))
-		psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-		
-	//  (for Antenna Detection Mechanism)	
-	if (type > 100)
-	{
-		psTdmaByte0Val = psTdmaByte0Val | 0x82; //set antenna control by SW	
-		psTdmaByte3Val = psTdmaByte3Val | 0x60;  //set antenna no toggle, control by antenna diversity
-	}
-
-		
-	if(bTurnOn)
-	{	 
-		switch(type)
-		{
-			default:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1a, 0x1a, 0x0, psTdmaByte4Val);
-				break;
-			case 1:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);								
-				break;
-			case 2:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x2d+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);							
-				break;
-			case 3:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 4:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 5:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x15, 0x3, psTdmaByte3Val, 0x11);
-				break;
-			case 6:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x20, 0x3, psTdmaByte3Val, 0x11);
-				break;
-			case 7:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x1e, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 8:	
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1e, 0x3, 0x10, 0x14);
-				break;
-			case 9:	
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;
-			case 10:	
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0xa, 0x0, 0x40);
-				break;
-			case 11:	
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x03, psTdmaByte3Val, psTdmaByte4Val);			
-				break;
-			case 12:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x0a, 0x0a, 0x0, 0x50);
-				break;
-			case 13:
-				 if (pCoexSta->nScanAPNum <= 3) // for Lenovo CPT test A2DP + OPP
-				 	halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a, 0x3, psTdmaByte3Val, psTdmaByte4Val);
-				 else	
-					halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 14:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;
-			case 15:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0x3, 0x8, 0x0);
-				break;
-			case 16:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x10, 0x0);
-				break;
-			case 18:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;			
-			case 20:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3f, 0x03, psTdmaByte3Val, 0x10);
-				break;
-			case 21:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x11);
-				break;
-			case 22:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, 0x10);
-				break;
-			case 23:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x18);
-				break;
-			case 24:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x3, 0x31, 0x18);
-				break;
-			case 25:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 26:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 27:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x98);
-				break;
-			case 28:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x69, 0x25, 0x3, 0x31, 0x0);
-				break;
-			case 29:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xab, 0x1a, 0x1a, 0x1, 0x10);
-				break;
-			case 30:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x30, 0x3, 0x10, 0x10);
-				break;
-			case 31:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1a, 0x1a, 0, 0x58);
-				break;
-			case 32:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x35, 0x3, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 33:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x35, 0x3, psTdmaByte3Val, 0x10);
-				break;
-			case 34:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x53, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 35:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x63, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 36:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x12, 0x3, 0x14, 0x50);
-				break;
-			case 40: // SoftAP only with no sta associated,BT disable ,TDMA mode for power saving
-				/* here softap mode screen off will cost 70-80mA for phone */
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x23, 0x18, 0x00, 0x10, 0x24);
-				break;	
-				
-			// 1-Ant translate to 2-Ant (for Antenna Detection Mechanism)
-			case 101:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);								
-				break;
-			case 102:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x2d+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);							
-				break;
-			case 103:
-				//halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1d, 0x1d, 0x0, psTdmaByte4Val);
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 105:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x15, 0x3, psTdmaByte3Val, 0x11);
-				break;
-			case 106:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x20, 0x3, psTdmaByte3Val, 0x11);
-				break;	
-			case 109:	
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;			
-			case 111:	
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x03, psTdmaByte3Val, psTdmaByte4Val);			
-				break;	
-			case 113:
-				//halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x12, 0x12, 0x0, psTdmaByte4Val);
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 114:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;	
-			case 120:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3f, 0x03, psTdmaByte3Val, 0x10);
-				break;			
-			case 122:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, 0x10);
-				break;
-			case 132:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;	
-			case 133:
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, 0x11);
-				break;		
-				
-		}
-	}
-	else
-	{		
-
-		// disable PS tdma
-		switch(type)
-		{
-			case 8: //PTA Control
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-				break;
-			case 0:
-			default:  //Software control, Antenna at BT side
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				break;
-			case 1: // 2-Ant, 0x778=3, antenna control by antenna diversity
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x48, 0x0);
-				break;
-#if 0
-			case 9:   //Software control, Antenna at WiFi side
-				halbtc8703b1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);				
-				halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_WIFI, FALSE, FALSE);
-				break;			
-#endif
-		}
-	}
-	rssiAdjustVal =0;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssiAdjustVal);
-
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-		pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948),   pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765), pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67)));
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-BOOLEAN
-halbtc8703b1ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected && 
-		BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n"));
-		
- 		//halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-
-		//halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT connected-idle!!\n"));
-
-		//halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-
-		//halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE != pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT Busy!!\n"));
-
-		//halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-		
-		bCommon = TRUE;
-	}
-	else
-	{
-		if (bWifiBusy)			
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-		}
-		
-		bCommon = FALSE;
-	}
-	
-	return bCommon;
-}
-
-
-VOID
-halbtc8703b1ant_TdmaDurationAdjustForAcl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0, btInfoExt;
-	static BOOLEAN	bPreWifiBusy=FALSE;
-	BOOLEAN			bWifiBusy = FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjustForAcl()\n"));
-
-	if(BT_8703B_1ANT_WIFI_STATUS_CONNECTED_BUSY == wifiStatus) 
-		bWifiBusy = TRUE;
-	else
-		bWifiBusy = FALSE;	 	
-
-	if( (BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN == wifiStatus) ||
-		(BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifiStatus) ||
-		(BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT == wifiStatus) )
-	{
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 3 &&
-			pCoexDm->curPsTdma != 9 )
-		{
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-			pCoexDm->psTdmaDuAdjType = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n= 3;
-			result = 0;
-			WaitCount = 0;
-		}		
-		return;
-	}
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-		pCoexDm->psTdmaDuAdjType = 2;
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-		retryCount = pCoexSta->btRetryCnt;
-		btInfoExt = pCoexSta->btInfoExt;
-
-		if ( (pCoexSta->lowPriorityTx) > 1050 ||  (pCoexSta->lowPriorityRx) > 1250 )
-			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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		if(result == -1)
-		{
-/*			if( (BT_INFO_8703B_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else */ if(pCoexDm->curPsTdma == 1)
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-				pCoexDm->psTdmaDuAdjType = 11;
-			}
-		}
-		else if(result == 1)
-		{
-/*			if( (BT_INFO_8703B_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else */ if(pCoexDm->curPsTdma == 11)
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-				pCoexDm->psTdmaDuAdjType = 1;
-			}
-		}
-		else	  //no change
-		{
-			/* Bryant Modify	
-			if(bWifiBusy != bPreWifiBusy)  //if busy / idle change
-			{
-				bPreWifiBusy = bWifiBusy;
-				halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, pCoexDm->curPsTdma);
-			}
-			*/
-		
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-				pCoexDm->curPsTdma));
-		}
-
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 9 &&
-			pCoexDm->curPsTdma != 11 )
-		{
-			// recover to previous adjust type
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-	}
-}
-
-VOID
-halbtc8703b1ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8703b1ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			pCoexSta->bForceLpsOn = FALSE;
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			
-			break;
-		case BTC_PS_LPS_ON:
-			pCoexSta->bForceLpsOn = TRUE;
-			halbtc8703b1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8703b1ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.			
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			
-			break;
-		case BTC_PS_LPS_OFF:
-			pCoexSta->bForceLpsOn = FALSE;
-			halbtc8703b1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8703b1ant_ActionWifiOnly(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-	halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-}
-
-VOID
-halbtc8703b1ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte		btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-			halbtc8703b1ant_ActionWifiOnly(pBtCoexist);
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		}
-	}
-}
-
-//=============================================
-//
-//	Software Coex Mechanism start
-//
-//=============================================
-
-// SCO only or SCO+PAN(HS)
-
-/*
-VOID
-halbtc8703b1ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-
-VOID
-halbtc8703b1ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8703b1ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8703b1ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8703b1ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(HS) only
-VOID
-halbtc8703b1ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8703b1ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8703b1ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8703b1ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-VOID
-halbtc8703b1ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-*/
-
-//=============================================
-//
-//	Non-Software Coex Mechanism start
-//
-//=============================================
-VOID
-halbtc8703b1ant_ActionBtWhckTest(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8703b1ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8703b1ant_ActionHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-	halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8703b1ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bWifiConnected=FALSE, bApEnable=FALSE, bWifiBusy=FALSE, bBtBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	if ( (!bWifiConnected) && (!pCoexSta->bWiFiIsHighPriTask) )
-	{
-		halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	 	halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);		
-	}
-	else if( (pBtLinkInfo->bScoExist) || 	(pBtLinkInfo->bHidExist) || 	(pBtLinkInfo->bA2dpExist)  )
-	{
-		// SCO/HID/A2DP busy
-		halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if ( (pBtLinkInfo->bPanExist) || (bWifiBusy) )
-	{
-		halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-
-		//for BT inquiry/page fail after S4 resume
-		//halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);		
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	else
-	{
-		halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	 	halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);		
-		
-
-		//halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		//halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);				
-	}
-}
-
-VOID
-halbtc8703b1ant_ActionBtScoHidOnlyBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	// tdma and coex table
-
-	if(pBtLinkInfo->bScoExist)
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-	else //HID
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-}
-
-VOID
-halbtc8703b1ant_ActionWifiConnectedBtAclBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	u1Byte		btRssiState;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	btRssiState = halbtc8703b1ant_BtRssiState(2, 28, 0);	
-
-	if ( (pCoexSta->lowPriorityRx >= 950)  && (!pCoexSta->bUnderIps)  
-			&&  (pCoexSta->lowPriorityRx >= pCoexSta->lowPriorityTx)  && (!pCoexSta->bC2hBtInquiryPage))
-	{
-		pBtLinkInfo->bSlaveRole = TRUE;
-	}
-	else
-	{
-		pBtLinkInfo->bSlaveRole = FALSE;
-	}
-
-	if(pBtLinkInfo->bHidOnly)  //HID
-	{
-		halbtc8703b1ant_ActionBtScoHidOnlyBusy(pBtCoexist, wifiStatus);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		return;
-	}
-	else if(pBtLinkInfo->bA2dpOnly)  //A2DP		
-	{
-		if(BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifiStatus)
-		{
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		else
-		{
-			//halbtc8703b1ant_TdmaDurationAdjustForAcl(pBtCoexist, wifiStatus);
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = TRUE;
-		}
-	}
-	else if ( ((pBtLinkInfo->bA2dpExist) && (pBtLinkInfo->bPanExist)) ||
-		       (pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist&&pBtLinkInfo->bPanExist) ) //A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP)
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else if(pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist)  //HID+A2DP
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	else if( (pBtLinkInfo->bPanOnly) || (pBtLinkInfo->bHidExist&&pBtLinkInfo->bPanExist) ) //PAN(OPP,FTP), HID+PAN(OPP,FTP)			
-	{
-		if(BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifiStatus)
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-		else
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-			
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{		
-		//BT no-profile busy (0x9)
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 33);	
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}	
-}
-
-VOID
-halbtc8703b1ant_ActionWifiNotConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// power save state
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8703b1ant_ActionWifiNotConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8703B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-		{
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-	 	else
-	 	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);			
-		}
-	}
-	else if( (BT_8703B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8703b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8703b1ant_ActionWifiNotConnectedAssoAuth(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if( (pBtLinkInfo->bScoExist)  || (pBtLinkInfo->bHidExist) ||  (pBtLinkInfo->bA2dpExist) )
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 4);		
-	}
-	else if (pBtLinkInfo->bPanExist)   			
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 4);		
-	}
-	else
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8703b1ant_ActionWifiConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8703B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-		{
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-	 	else
-	 	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	}
-	else if( (BT_8703B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8703b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8703b1ant_ActionWifiConnectedSpecialPacket(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN bWifiBusy = FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	//no special packet process for both WiFi and BT very busy
-	if ((bWifiBusy) && ((pBtLinkInfo->bPanExist) || (pCoexSta->nNumOfProfile >= 2)))
-	 return;	
-
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist))
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);		
-	}
-	else if  (pBtLinkInfo->bA2dpExist)
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if(pBtLinkInfo->bPanExist)
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else
-	{
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8703b1ant_ActionWifiConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN 	bWifiBusy=FALSE;
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-	BOOLEAN		bUnder4way=FALSE, bApEnable=FALSE;
-	u4Byte		wifiBw;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect()===>\n"));
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-	if(bUnder4way)
-	{
-		halbtc8703b1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n"));
-		return;
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	if(bScan || bLink || bRoam)
-	{
-		if(bScan)	
-			halbtc8703b1ant_ActionWifiConnectedScan(pBtCoexist);
-		else
-			halbtc8703b1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	
-	// power save state
-	if(!bApEnable && BT_8703B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus && !pBtCoexist->btLinkInfo.bHidOnly)
-	{
-		if(pBtCoexist->btLinkInfo.bA2dpOnly)	//A2DP
-			{			
-			if(!bWifiBusy)
-				halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);				
-			else //busy
-			{
-				if  (pCoexSta->nScanAPNum >= BT_8703B_1ANT_WIFI_NOISY_THRESH)  //no force LPS, no PS-TDMA, use pure TDMA
-				{
-			halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-				}
-				else
-				{
-					halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);					
-				}
-			}
-		}
-		else if ((pCoexSta->bPanExist == FALSE) && (pCoexSta->bA2dpExist == FALSE) && (pCoexSta->bHidExist == FALSE))
- 			halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-	else
-		halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(!bWifiBusy)
-	{
-		if(BT_8703B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8703b1ant_ActionWifiConnectedBtAclBusy(pBtCoexist, 
-				BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else if( (BT_8703B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8703b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else
-		{
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);		 
-		}
-	}
-	else
-	{
-		if(BT_8703B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8703b1ant_ActionWifiConnectedBtAclBusy(pBtCoexist,
-				BT_8703B_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else if( (BT_8703B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8703b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8703B_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else 
-		{
-			//halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);	
-			//halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);	
-			halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);	
-		}
-	}
-}
-
-VOID
-halbtc8703b1ant_RunSwCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte				algorithm=0;
-
-	algorithm = halbtc8703b1ant_ActionAlgorithm(pBtCoexist);
-	pCoexDm->curAlgorithm = algorithm;
-
-	if(halbtc8703b1ant_IsCommonAction(pBtCoexist))
-	{
-
-	}
-	else
-	{
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8703B_1ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = SCO.\n"));
-				//halbtc8703b1ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID.\n"));
-				//halbtc8703b1ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP.\n"));
-				//halbtc8703b1ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP+PAN(HS).\n"));
-				//halbtc8703b1ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR).\n"));
-				//halbtc8703b1ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HS mode.\n"));
-				//halbtc8703b1ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN+A2DP.\n"));
-				//halbtc8703b1ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR)+HID.\n"));
-				//halbtc8703b1ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP+PAN.\n"));
-				//halbtc8703b1ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8703B_1ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP.\n"));
-				//halbtc8703b1ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = coexist All Off!!\n"));
-				//halbtc8703b1ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8703b1ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bIncreaseScanDevNum=FALSE;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	BOOLEAN	bMiracastPlusBt=FALSE;
-	u1Byte	aggBufSize=5;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0, wifiBw;
-	u1Byte	iotPeer=BTC_IOT_PEER_UNKNOWN;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pBtCoexist->bStopCoexDm)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	if(pCoexSta->bBtWhckTest)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under WHCK TEST!!!\n"));
-		halbtc8703b1ant_ActionBtWhckTest(pBtCoexist);
-		return;
-	}
-
-	if( (BT_8703B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8703B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bIncreaseScanDevNum = TRUE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_INC_SCAN_DEV_NUM, &bIncreaseScanDevNum);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  Multi-Port numOfWifiLink = %d, wifiLinkStatus = 0x%x\n", numOfWifiLink,wifiLinkStatus) );
-
-		if(pBtLinkInfo->bBtLinkExist)
-		{
-			halbtc8703b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1);
-			bMiracastPlusBt = TRUE;
-		}
-		else
-		{
-		halbtc8703b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-			bMiracastPlusBt = FALSE;
-		}
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-		halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-
-		if ( (pBtLinkInfo->bA2dpExist) && (pCoexSta->bC2hBtInquiryPage) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );	
-			halbtc8703b1ant_ActionBtInquiry(pBtCoexist);
-		}
-		else
-		halbtc8703b1ant_ActionWifiMultiPort(pBtCoexist);
-		
-		return;
-	}
-	else
-	{
-		bMiracastPlusBt = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if ( (pBtLinkInfo->bBtLinkExist) && (bWifiConnected) )
-	{
-		halbtc8703b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1); 
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_IOT_PEER, &iotPeer);
-
-		if(BTC_IOT_PEER_CISCO != iotPeer)
-		{
-			if(pBtLinkInfo->bScoExist)//if (pBtLinkInfo->bBtHiPriLinkExist)
-				halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x5);	
-			else
-				halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x5);
-		}
-		else
-		{
-			if(pBtLinkInfo->bScoExist)
-				halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x5);
-			else
-			{
-				if (BTC_WIFI_BW_HT40==wifiBw)
-					halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x10);	
-				else
-					halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-			}
-		}
-
-		halbtc8703b1ant_SwMechanism(pBtCoexist, TRUE);
-		halbtc8703b1ant_RunSwCoexistMechanism(pBtCoexist);  //just print debug message
-	}
-	else
-	{
-		halbtc8703b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-		halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x5);
-
-		halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-		halbtc8703b1ant_RunSwCoexistMechanism(pBtCoexist); ////just print debug message
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );		
-		halbtc8703b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8703b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	
-	if(!bWifiConnected)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is non connected-idle !!!\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-		if(bScan || bLink || bRoam)
-		{
-			 if (bScan)	
-		   		halbtc8703b1ant_ActionWifiNotConnectedScan(pBtCoexist);	
-			 else
-		    		halbtc8703b1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);	
-		}
-		else
-			halbtc8703b1ant_ActionWifiNotConnected(pBtCoexist);
-	}
-	else	// wifi LPS/Busy
-	{
-		halbtc8703b1ant_ActionWifiConnected(pBtCoexist);
-	}
-}
-
-u4Byte
-halbtc8703b1ant_PSD_Log2Base(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte				val
-	
-	)
-{
-	u1Byte 	i,j;
-	u4Byte	tmp, tmp2, val_integerdB=0, tindex, shiftcount=0;
-	u4Byte 	result,val_fractiondB=0,Table_fraction[21]= {0,432, 332, 274, 232, 200,
-								   174, 151,132,115,100,86,74,62,51,42,
-								   32,23,15,7,0};
-
-	if (val == 0)
-	 return 0;
-
-	tmp = val;
-
-	while(1)
-	{
-		if (tmp == 1)
-			break;	
-		else
-		{
-			tmp = (tmp >> 1);
-			shiftcount++;				
-		}
-	}
-	
-
-	val_integerdB = shiftcount+1;
-
-	tmp2=1;
-	for (j=1; j<= val_integerdB;j++)
-	  tmp2 = tmp2*2; 		
-	
-	tmp = (val*100) /tmp2;
-	tindex = tmp/5;
-
-	if (tindex > 20)
-	 tindex = 20;
-
-	val_fractiondB = Table_fraction[tindex];
-
-	result = val_integerdB*100 - val_fractiondB;			
-
-	return (result);
-
-
-}
-
-VOID
-halbtc8703b1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-
-	// sw all off
-	halbtc8703b1ant_SwMechanism(pBtCoexist, FALSE);
-	
-	//halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	//halbtc8703b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	pCoexSta->popEventCnt = 0;
-}
-
-VOID
-halbtc8703b1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte				u4Tmp=0;//, fwVer;
-	u2Byte				u2Tmp=0;
-	u1Byte				u1Tmp=0, u1Tmpa=0, u1Tmpb=0;
-	u1Byte				H2C_Parameter[2] ={0};
-
-	u4Byte				u4Tmp1=0, u4Tmp2=0;
-
-			
-	u4Tmp1 = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x38);
-	u4Tmp2 = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x54);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** (Before Init HW config) 0x38= 0x%x, 0x54= 0x%x**********\n", u4Tmp1, u4Tmp2));
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 1Ant Init HW Config!!\n"));
-
-
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x550, 0x8, 0x1);  //enable TBTT nterrupt
-
-	//BT report packet sample rate	
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, 0x5);
-	
-	// Enable BT counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x1);		
-
-	//Enable PTA (3-wire function form BT side)
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x41, 0x02, 0x1);
-
-	//Enable PTA (tx/rx signal form WiFi side)
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x4c6, 0x10, 0x1);
-
-	//enable GNT_WL/GNT_BT debug signal to GPIO14/15
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x73, 0x8, 0x1);
-
-	//enable GNT_WL
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x4e, 0x40, 0x0);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x1, 0x0);
-
-	halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	
-	//Antenna config
-	if(bWifiOnly)
-	{
-		pCoexSta->bConCurrentRxModeOn = FALSE;
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_WIFI, FORCE_EXEC, TRUE, FALSE);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_WIFI, FORCE_EXEC, FALSE, FALSE);
-	}
-	else
-	{
-		pCoexSta->bConCurrentRxModeOn = TRUE;		
-	   	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x953, 0x2, 0x1);
-		//RF 0x1[0] = 0 -> Set GNT_WL_RF_Rx always = 1 for con-current Rx
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0x1, 0x0);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, TRUE, FALSE);
-	}
-
-	// PTA parameter
-	halbtc8703b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-}
-
-
-
-VOID
-halbtc8703b1ant_PSD_ShowData(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	pu1Byte		cliBuf=pBtCoexist->cliBuf;
-	u4Byte		nDeltaFreqPerPoint;
-	u4Byte		freq,freq1,freq2,n=0,i=0, j=0, m=0, PsdRep1, PsdRep2;
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n\n============[PSD info]  (%d)============\n",
-		 	pPsdScan->nPSDGenCount);
-	CL_PRINTF(cliBuf);
-
-	if (pPsdScan->nPSDGenCount == 0)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n No Data !!\n");
-		CL_PRINTF(cliBuf);
-		return;
-	}
-
-	if (pPsdScan->nPSDPoint == 0)
-		nDeltaFreqPerPoint = 0;
-	else			
-		nDeltaFreqPerPoint = pPsdScan->nPSDBandWidth/pPsdScan->nPSDPoint;		
-
-	//if (pPsdScan->bIsPSDShowMaxOnly)
-	if (0)
-	{	
-		PsdRep1 = pPsdScan->nPSDMaxValue/100;
-		PsdRep2 = pPsdScan->nPSDMaxValue - PsdRep1 * 100;
-				
-		freq = ((pPsdScan->nRealCentFreq-20) * 1000000 + pPsdScan->nPSDMaxValuePoint * nDeltaFreqPerPoint);
-		freq1 = freq/1000000;
-		freq2 = freq/1000 - freq1 * 1000;
-
-		if (freq2 < 100)	
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq = %d.0%d MHz",  
-			  freq1, freq2);
-		else
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq = %d.%d MHz",  
-			  freq1, freq2);
-
-		if (PsdRep2 < 10)	
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, ", Value = %d.0%d dB, (%d) \n",  
-			  PsdRep1, PsdRep2, pPsdScan->nPSDMaxValue);
-		else
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, ", Value = %d.%d dB, (%d)\n",  
-			  PsdRep1, PsdRep2, pPsdScan->nPSDMaxValue);
-		
-		CL_PRINTF(cliBuf);
-	}
-	else
-	{
-		m = pPsdScan->nPSDStartPoint;
-		n = pPsdScan->nPSDStartPoint;
-		i = 1;
-		j = 1;				
-
-	 while(1)
-	 {
-		do
-		{
-			freq = ((pPsdScan->nRealCentFreq-20) * 1000000 + m * nDeltaFreqPerPoint);
-			freq1 = freq/1000000;
-			freq2 = freq/1000 - freq1 * 1000;
-			
-			if (i ==1)
-			{
-				if (freq2 == 0)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq%6d.000", freq1);
-				else if (freq2 < 100)	
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq%6d.0%2d", freq1,freq2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq%6d.%3d", freq1,freq2);
-			}
-			else if  ( (i%8 == 0) || (m == pPsdScan->nPSDStopPoint) )
-			{
-				if (freq2 == 0)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.000\n", freq1);
-				else if (freq2 < 100)	
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.0%2d\n", freq1,freq2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.%3d\n", freq1,freq2);
-			}			
-			else
-			{
-				if (freq2 == 0)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.000", freq1);
-				else if (freq2 < 100)	
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.0%2d", freq1,freq2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.%3d", freq1,freq2);
-			}
-
-			i++;					
-			m++;
-			CL_PRINTF(cliBuf);
-
-		}while(  (i <= 8) && (m <= pPsdScan->nPSDStopPoint));	
-		
-		
-		do
-		{
-			PsdRep1 = pPsdScan->nPSDReport_MaxHold[n]/100;
-			PsdRep2 = pPsdScan->nPSDReport_MaxHold[n] - PsdRep1 * 100;
-				
-			if (j ==1)
-			{
-				if (PsdRep2 <10)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Val %7d.0%d", PsdRep1,PsdRep2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Val %7d.%d", PsdRep1,PsdRep2);
-			}
-			else if ( (j%8 == 0)  || (n == pPsdScan->nPSDStopPoint) )
-			{
-				if (PsdRep2 <10)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.0%d\n", PsdRep1,PsdRep2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.%d\n", PsdRep1,PsdRep2);
-			}
-			else
-			{
-				if (PsdRep2 <10)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.0%d", PsdRep1,PsdRep2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.%d", PsdRep1,PsdRep2);
-			}
-
-			j++;
-			n++;
-			CL_PRINTF(cliBuf);
-			
-		} while(  (j <= 8) && (n <= pPsdScan->nPSDStopPoint));		
-
-		if  ( (m > pPsdScan->nPSDStopPoint) || (n > pPsdScan->nPSDStopPoint) )
-		 break;
-		else
-		{
-			i = 1;
-			j = 1;
-		}
-		
-	 }	
-	}
-
-
-}
-
-VOID
-halbtc8703b1ant_PSD_MaxHoldData(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte				GenCount
-	)
-{
-		 u4Byte	i=0, i_max=0, val_max=0, j;
-		 
-		if (GenCount== 1)
-		{
-			memcpy(pPsdScan->nPSDReport_MaxHold, pPsdScan->nPSDReport, BT_8703B_1ANT_ANTDET_PSD_POINTS*sizeof(u4Byte));
-
-			for (i= pPsdScan->nPSDStartPoint; i<=pPsdScan->nPSDStopPoint; i++)
-			{
-				//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Max_Hold i = %d, PSDReport = %d dB\n", i,  pPsdScan->nPSDReport_MaxHold[i]));
-			}
-
-			pPsdScan->nPSDMaxValuePoint = 0;
-			pPsdScan->nPSDMaxValue = 0;
-
-		}	
-		else
-		{
-			for (i= pPsdScan->nPSDStartPoint; i<=pPsdScan->nPSDStopPoint; i++)
-			{
-				if (pPsdScan->nPSDReport[i] > pPsdScan->nPSDReport_MaxHold[i])
-			 	pPsdScan->nPSDReport_MaxHold[i] = pPsdScan->nPSDReport[i];	
-
-				//search Max Value
-				if (i ==pPsdScan->nPSDStartPoint )
-				{
-					i_max = i;
-					val_max = pPsdScan->nPSDReport_MaxHold[i];
-				}
-				else
-				{
-					if (pPsdScan->nPSDReport_MaxHold[i] > val_max)
-					{
-						i_max = i;
-						val_max = pPsdScan->nPSDReport_MaxHold[i];
-					}
-				}
-
-				//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Max_Hold i = %d, PSDReport = %d dB\n", i,  pPsdScan->nPSDReport_MaxHold[i]));
-
-			}
-	
-			pPsdScan->nPSDMaxValuePoint = i_max;
-			pPsdScan->nPSDMaxValue = val_max;
-
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Max_Hold i_Max = %d, PSDReport_Max = %d dB\n", pPsdScan->nPSDMaxValuePoint
-			//		,pPsdScan->nPSDMaxValue));
-		}
-
-
-}
-
-u4Byte
-halbtc8703b1ant_PSD_GetData(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte				nPoint
-	)
-{
-	//reg 0x808[9:0]: FFT data x
-	//reg 0x808[22]: 0-->1 to get 1 FFT data y
-	//reg 0x8b4[15:0]: FFT data y report
-
-	u4Byte val = 0, psd_report =0;
-	
-	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x808);
-
-	val &= 0xffbffc00;
-	val |= nPoint;
-	
-	 pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x808, val);
-
-	val |= 0x00400000;
-	 pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x808, val);
-
-
-	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x8b4);
-
-	psd_report = val & 0x0000ffff;
-	 
-	return psd_report;
-}
-
-
-VOID
-halbtc8703b1ant_PSD_SweepPoint(
-IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte				centFreq,
-	IN	s4Byte				offset,
-	IN	u4Byte				span,
-	IN	u4Byte				points,
-	IN	u4Byte				avgnum
-	)
-{
-	u4Byte	 i,val,n,k=0;
-	u4Byte	nPoints=0, psd_report=0;
-	u4Byte	nStartP=0, nStopP=0, nDeltaFreqPerPoint=156250;
-	u4Byte    nPSDCenterFreq=20*10^6, freq,freq1,freq2;	
-	BOOLEAN outloop = FALSE;
-	u1Byte	 flag = 0;	
-	u4Byte 	tmp, PsdRep1, PsdRep2;
-	u4Byte	WiFi_OriginalChannel = 1;
-
-	pPsdScan->bIsPSDRunning = TRUE;
-	
-	do
-	{
-		switch(flag)
-		{
-		   case 0:  //Get PSD parameters
-		   default:	
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), centFreq=0x%x, offset=0x%x, span=0x%x\n", 
-		       //     centFreq, offset, span));
-
-			pPsdScan->nPSDBandWidth = 40*1000000;
-			pPsdScan->nPSDPoint = points;
-			pPsdScan->nPSDStartBase = points/2; 
-			pPsdScan->nPSDAvgNum = avgnum;
-			pPsdScan->nRealCentFreq = centFreq;
-			pPsdScan->nRealOffset = offset;
-			pPsdScan->nRealSpan = span;
-		
-			
-			nPoints = pPsdScan->nPSDPoint;
-			nDeltaFreqPerPoint = pPsdScan->nPSDBandWidth/pPsdScan->nPSDPoint;
-
-			//PSD point setup
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x808);
-			val &= 0xffff0fff;				
-			
-			switch(pPsdScan->nPSDPoint)
-			{
-				case 128:
-					val |= 0x0;
-					break;
-				case 256:
-				default:	
-					val |=0x00004000;
-				 	break;
-				case 512:	
-					val |= 0x00008000;
-					break;
-				case 1024:	
-					val |= 0x0000c000;
-					break;
-			}			
-					
-			switch(pPsdScan->nPSDAvgNum)
-			{
-				case 1:
-					val |= 0x0;
-					break;
-				case 8:				
-					val |=0x00001000;
-				 	break;
-				case 16:	
-					val |= 0x00002000;
-					break;
-				case 32:
-				default:	
-					val |= 0x00003000;
-					break;
-			}
-			 pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x808, val);
-
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), PSD BW= %d, DeltaFreq=%d\n"
-		 	//	, pPsdScan->nPSDBandWidth, nDeltaFreqPerPoint));
-			flag = 1;
-			break;
-		  case 1:	  //calculate the PSD point index from freq/offset/span
-		  	nPSDCenterFreq = pPsdScan->nPSDBandWidth /2 +offset*(1000000);
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), PSD Center Freq = %d\n", (centFreq + offset)));
-			
-			nStartP = pPsdScan->nPSDStartBase + (nPSDCenterFreq - span *(1000000)/2) /nDeltaFreqPerPoint;
-			pPsdScan->nPSDStartPoint = nStartP - pPsdScan->nPSDStartBase;
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Start PSD Poin Matrix Index = %d\n", pPsdScan->nPSDStartPoint));
-
-			nStopP = pPsdScan->nPSDStartBase + (nPSDCenterFreq + span *(1000000)/2) /nDeltaFreqPerPoint;
-			pPsdScan->nPSDStopPoint = nStopP - pPsdScan->nPSDStartBase-1;
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Stop PSD Poin Matrix Index = %d\n",pPsdScan->nPSDStopPoint));
-
-			flag = 2;
-			break;
-		  case 2:  //set RF channel/BW/Mode
-
-		  	//set 3-wire off
-		  	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x88c);
-			val |= 0x00300000;
-			 pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x88c,val);
-
-			//CCK off
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x800);
-			val &= 0xfeffffff;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x800,val);		
-
-			//store WiFi original channel
-			WiFi_OriginalChannel = pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff);
-
-			//Set RF channel
-		       if (centFreq == 2484)
-				pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff, 0xe); 
-			else
-				pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff, (centFreq-2412)/5 + 1); //WiFi TRx Mask on
-
-			//Set  RF mode = Rx, RF Gain = 0x8a0
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x0, 0xfffff, 0x308a0);
-
-			//Set RF Rx filter corner
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0x3e4);
-
-			//Set TRx mask off
-			//un-lock TRx Mask setup
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdd, 0x80, 0x1);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdf, 0x1, 0x1);
-
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-			flag = 3;
-			break;
-		  case 3:
-		  	memset(pPsdScan->nPSDReport,0, pPsdScan->nPSDPoint*sizeof(u4Byte));
-			nStartP = pPsdScan->nPSDStartPoint + pPsdScan->nPSDStartBase;
-			nStopP = pPsdScan->nPSDStopPoint +  pPsdScan->nPSDStartBase + 1;
-				
-			i = nStartP;
-
-			while (i < nStopP)
-			{
-				if (i >= nPoints)
-				{
-					psd_report = halbtc8703b1ant_PSD_GetData(pBtCoexist,i-nPoints);
-				}
-				else
-				{
-					psd_report = halbtc8703b1ant_PSD_GetData(pBtCoexist,i);
-				}
-
-				if (psd_report == 0)
-					tmp = 0;
-				else
-					//tmp =  20*log10((double)psd_report);
-					//20*log2(x)/log2(10), log2Base return theresult of the psd_report*100
-					tmp = 6 * halbtc8703b1ant_PSD_Log2Base(pBtCoexist, psd_report);				
-
-				n = i-pPsdScan->nPSDStartBase;
-				pPsdScan->nPSDReport[n] =  tmp;
-				PsdRep1 = pPsdScan->nPSDReport[n] /100;
-				PsdRep2 = pPsdScan->nPSDReport[n] - PsdRep1 * 100;
-				
-				freq =  ((centFreq-20) * 1000000 + n * nDeltaFreqPerPoint);
-				freq1 = freq/1000000;
-				freq2 = freq/1000 - freq1 * 1000;
-/*
-				if (freq2 < 100)
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), i = %d (%d.0%d MHz)", n, freq1, freq2));
-				else
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), i = %d (%d.%d MHz)", n, freq1, freq2));
-
-				if (PsdRep2 < 10)
-					RT_TRACE(COMP_COEX, DBG_LOUD, (", PSDReport = %d (%d.0%d dB)\n",psd_report, PsdRep1, PsdRep2));
-				else
-					RT_TRACE(COMP_COEX, DBG_LOUD, (", PSDReport = %d (%d.%d dB)\n",psd_report, PsdRep1,PsdRep2));	
-*/
-				i++;
-
-				k=0;
-
-				//Add Delay between PSD point
-				while(1)
-				{
-					if (k++ > 20000)
-					 break;
-				}
-
-				//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint()==============\n"));
-			}	
-
-			flag = 100;
-			break;
-		  case 99:	//error
-
-			outloop = TRUE;
-			break;
-		  case 100: //recovery 
-
-		  	//set 3-wire on
-		  	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x88c);
-			val &=0xffcfffff;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x88c,val);
-
-			//CCK on
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x800);
-			val |= 0x01000000;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x800,val);	
-
-			//PSD off
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x808);
-			val &=0xffbfffff;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x808,val);
-			
-		  	//TRx Mask on
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780);
-
-			//lock TRx Mask setup
-		  	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdd, 0x80, 0x0);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdf, 0x1, 0x0);
-
-			//Set RF Rx filter corner
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0x0);
-
-			//restore WiFi original channel
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff, WiFi_OriginalChannel); 
-			
-			outloop = TRUE;
-			break;
-
-		}		
-			
-	}while (!outloop);
-
-
-
-	pPsdScan->bIsPSDRunning = FALSE;
-
-
-}
-
-//============================================================
-// work around function start with wa_halbtc8703b1ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8703b1ant_
-//============================================================
-VOID
-EXhalbtc8703b1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u1Byte u1Tmp=0x0;
-	u2Byte u2Tmp=0x0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx Execute 8703b 1-Ant PowerOn Setting xxxxxxxxxxxxxxxx!!\n"));
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("Ant Det Finish = %s, Ant Det Number  = %d\n",  
-		 (pBoardInfo->btdmAntDetFinish? "Yes":"No"), pBoardInfo->btdmAntNumByAntDet));
-
-	pBtCoexist->bStopCoexDm = TRUE;
-
-	// enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly.
-	u2Tmp = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x2);
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x2, u2Tmp|BIT0|BIT1);
-
-	//set Path control owner to WiFi
-	halbtc8703b1ant_LTECoex_PathControlOwner(pBtCoexist, BT_8703B_1ANT_PCO_WLSIDE);
-
-	// set GNT_BT to high
-	halbtc8703b1ant_LTECoex_Set_GNT_BT(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW, BT_8703B_1ANT_SIG_STA_SET_TO_HIGH);
-	//Set GNT_WL to low
-	halbtc8703b1ant_LTECoex_Set_GNT_WL(pBtCoexist, BT_8703B_1ANT_GNT_BLOCK_RFC_BB, BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW, BT_8703B_1ANT_SIG_STA_SET_TO_LOW);
-
-	// set WLAN_ACT = 0
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);	
-
-	// 
-	// S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info)
-	// Local setting bit define
-	//	BIT0: "0" for no antenna inverse; "1" for antenna inverse 
-	//	BIT1: "0" for internal switch; "1" for external switch
-	//	BIT2: "0" for one antenna; "1" for two antenna
-	// NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0
-
-	u1Tmp = 0;
-	pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
-
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{		
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0xfe08, u1Tmp);
-	}
-	else if(pBtCoexist->chipInterface == BTC_INTF_SDIO)
-	{
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x60, u1Tmp);
-	}
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], **********  LTE coex Reg 0x38 (Power-On) = 0x%x**********\n", halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x38)));
-		
-
-#if 0	
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-
-	 	u1Tmp |= 0x1;	// antenna inverse
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0xfe08, u1Tmp);
-
-		pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-	}
-	else
-	{
-
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-			// set to S1
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x280);
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-			u1Tmp |= 0x1;	// antenna inverse
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-		}
-
-
-
-		if(pBtCoexist->chipInterface == BTC_INTF_PCI)
-		{	
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x384, u1Tmp);
-		}
-		else if(pBtCoexist->chipInterface == BTC_INTF_SDIO)
-		{
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x60, u1Tmp);
-		}	
-	}
-
-#endif	
-}
-
-VOID
-EXhalbtc8703b1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8703b1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8703b1ant_InitHwConfig(pBtCoexist, TRUE, bWifiOnly);
-	pBtCoexist->bStopCoexDm = FALSE;
-}
-
-VOID
-EXhalbtc8703b1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-
-	pBtCoexist->bStopCoexDm = FALSE;
-	
-	halbtc8703b1ant_InitCoexDm(pBtCoexist);
-
-	halbtc8703b1ant_QueryBtInfo(pBtCoexist);
-}
-
-VOID
-EXhalbtc8703b1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u2Byte				u2Tmp[4];
-	u4Byte				u4Tmp[4];
-	u4Byte				faOfdm, faCck;
-	u4Byte				fwVer=0, btPatchVer=0;
-	static u1Byte			PopReportIn10s = 0;	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-	if(pBtCoexist->bStopCoexDm)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	if (pPsdScan->bAntDet_TryCount == 0)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "Ant PG Num/ Mech/ Pos",
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos);
-	CL_PRINTF(cliBuf);	
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d  (%d/%d/%d)", "Ant PG Num/ Mech(Ant_Det)/ Pos", 
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNumByAntDet, pBoardInfo->btdmAntPos, 
-		pPsdScan->bAntDet_TryCount, pPsdScan->bAntDet_FailCount, pPsdScan->nAntDet_Result);		
-		CL_PRINTF(cliBuf);
-
-		if (pBoardInfo->btdmAntDetFinish)
-		{
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "Ant Det PSD Value",  pPsdScan->nAntDet_PeakVal);		
-			CL_PRINTF(cliBuf);
-		}
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8703b1Ant, GLCoexVer8703b1Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s", "WifibHiPri/ Ccklock/ CckEverLock", \
-		(pCoexSta->bWiFiIsHighPriTask? "Yes":"No"),
-		(pCoexSta->bCCKLock? "Yes":"No"),
-		(pCoexSta->bCCKEverLock? "Yes":"No"));
-	CL_PRINTF(cliBuf);
-
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-	
-	PopReportIn10s++;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d/ %d] ", "BT [status/ rssi/ retryCnt/ popCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt, pCoexSta->popEventCnt);
-	CL_PRINTF(cliBuf);
-	
-	if (PopReportIn10s >= 5)
-	{
-		pCoexSta->popEventCnt = 0;	
-		PopReportIn10s = 0;
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d / %d", "SCO/HID/PAN/A2DP/Hi-Pri", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist, pBtLinkInfo->bBtHiPriLinkExist);
-	CL_PRINTF(cliBuf);
-
-	if (pStackInfo->bProfileNotified)
-	{
-		pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);	
-	}
-	else
-	{
-		btInfoExt = pCoexSta->btInfoExt;
-		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s", "BT Role/A2DP rate", \
-		(pBtLinkInfo->bSlaveRole )? "Slave":"Master", (btInfoExt&BIT0)? "BR":"EDR");
-		CL_PRINTF(cliBuf);	
-	}	
-
-
-	for(i=0; i<BT_INFO_SRC_8703B_1ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8703b1Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	
-	if(pBtCoexist->bManualControl)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism] (before Manual)============");			
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	}	
-
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ 0x%x", "SM[LowPenaltyRA]/RA Mask", \
-			pCoexDm->bCurLowPenaltyRa, pBtCoexist->btInfo.raMask);
-		CL_PRINTF(cliBuf);
-
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %d ", "NoAggr/ CtrlAggr/ AggrSize", \
-			(pBtCoexist->btInfo.bRejectAggPkt? "Yes":"No"), (pBtCoexist->btInfo.bBtCtrlAggBufSize? "Yes":"No"),
-				pBtCoexist->btInfo.aggBufSize);
-		CL_PRINTF(cliBuf);
-		
-		// Fw mechanism		
-		if(pBtCoexist->bManualControl)
-		{
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism] (before Manual) ============");			
-		}
-		else
-		{
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-		}
-		
-		CL_PRINTF(cliBuf);	
-
-		psTdmaCase = pCoexDm->curPsTdma;
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase, 
-			(pCoexDm->bCurPsTdmaOn? "On":"Off"),
-			(pCoexDm->bAutoTdmaAdjust? "Adj":"Fix") );
-		
-		CL_PRINTF(cliBuf);
-		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "WL/BT Coex Table Type", \
-			pCoexSta->nCoexTableType);
-		CL_PRINTF(cliBuf);
-
-		u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-		u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-		u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x6c0/0x6c4/0x6c8(coexTable)", \
-					u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-		CL_PRINTF(cliBuf);
-
-		u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-		u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6cc);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x778/0x6cc/IgnWlanAct", \
-		u1Tmp[0], u4Tmp[0],  pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-
-		u4Tmp[0] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0xa0);
-		u4Tmp[1] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0xa4);
-
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "LTE Coex Table W_L/B_L", \
-			u4Tmp[0]&0xffff, u4Tmp[1]&0xffff);
-		CL_PRINTF(cliBuf);
-
-		u4Tmp[0] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0xa8);
-		u4Tmp[1] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0xac);
-		u4Tmp[2] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0xb0);
-		u4Tmp[3] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0xb4);
-
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "LTE Break Table W_L/B_L/L_W/L_B", \
-			u4Tmp[0]&0xffff, u4Tmp[1]&0xffff, u4Tmp[2]&0xffff, u4Tmp[3]&0xffff);
-		CL_PRINTF(cliBuf);
-				
-		// Hw setting		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-		CL_PRINTF(cliBuf);
-	
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-	u2Tmp[0] = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "0x430/0x434/0x42a/0x456", \
-		u4Tmp[0], u4Tmp[1], u2Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-
-	u4Tmp[0] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x38);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x73);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %s", "LTE CoexOn/Path Ctrl Owner", \
-	 ((u4Tmp[0]&BIT7)>> 7), ((u1Tmp[0]&BIT2)? "WL":"BT"));
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "LTE 3Wire/OPMode/UART/UARTMode", \
-	 ((u4Tmp[0]&BIT6)>> 6), ((u4Tmp[0]&(BIT5|BIT4))>> 4),((u4Tmp[0]&BIT3)>> 3), (u4Tmp[0]&(BIT2|BIT1|BIT0)));
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s", "GNT_WL_SWCtrl/GNT_BT_SWCtrl/Dbg", \
-	 ((u4Tmp[0]&BIT12)>> 12), ((u4Tmp[0]&BIT14)>> 14), ((u1Tmp[0]&BIT3)? "On":"Off"));
-	CL_PRINTF(cliBuf);
-	
-	u4Tmp[0] = halbtc8703b1ant_LTECoex_InDirectReadReg(pBtCoexist, 0x54);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "GNT_WL/GNT_BT/LTE_Busy/UART_Busy", \
-		((u4Tmp[0]&BIT2)>> 2), ((u4Tmp[0]&BIT3)>> 3),  ((u4Tmp[0]&BIT1)>> 1),  (u4Tmp[0]&BIT0));
-	CL_PRINTF(cliBuf);
-
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4c6);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x4c6[4]/0x40[5] (WL/BT PTA)", \
-		((u1Tmp[0] & BIT4)>>4), ((u1Tmp[1] & BIT5)>>5));
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x953);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ %s", "0x550(bcn ctrl)/0x522/4-RxAGC", \
-		u4Tmp[0], u1Tmp[0], (u1Tmp[1]&0x2)? "On": "Off");
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda8);
-	u4Tmp[3] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcf0);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5b);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-
-	faOfdm = ((u4Tmp[0]&0xffff0000) >> 16) +  ((u4Tmp[1]&0xffff0000) >> 16) + (u4Tmp[1] & 0xffff) +  (u4Tmp[2] & 0xffff) + \
-		             ((u4Tmp[3]&0xffff0000) >> 16) + (u4Tmp[3] & 0xffff) ;
-	faCck = (u1Tmp[0] << 8) + u1Tmp[1];
-
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "0xc50/OFDM-CCA/OFDM-FA/CCK-FA", \
-		u4Tmp[1]&0xff, u4Tmp[0]&0xffff, faOfdm, faCck);
-	CL_PRINTF(cliBuf);
-
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_OK CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCOK_CCK, pCoexSta->nCRCOK_11g, pCoexSta->nCRCOK_11n, pCoexSta->nCRCOK_11nAgg);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_Err CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCErr_CCK, pCoexSta->nCRCErr_11g, pCoexSta->nCRCErr_11n, pCoexSta->nCRCErr_11nAgg);
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(high-pri rx/tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri rx/tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-
-	halbtc8703b1ant_ReadScoreBoard(pBtCoexist, 	&u2Tmp[0]);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %04x", "ScoreBoard[14:0] (from BT)", u2Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-#if(BT_AUTO_REPORT_ONLY_8703B_1ANT == 1)
-	//halbtc8703b1ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8703b1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u4Byte	u4Tmp=0;
-
-	if(pBtCoexist->bManualControl ||	pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		
-		//Write WL "Active" in Score-board for LPS off
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, FALSE);
-		
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);	
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-
-		halbtc8703b1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8703b1ant_InitCoexDm(pBtCoexist);
-		halbtc8703b1ant_QueryBtInfo(pBtCoexist);
-
-		pCoexSta->bUnderIps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8703b1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(pBtCoexist->bManualControl || pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-
-		if (pCoexSta->bForceLpsOn == TRUE)  // LPS No-32K
-		{
-			//Write WL "Active" in Score-board for PS-TDMA
-			halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-	
-		}
-		else   //  LPS-32K, need check if this h2c 0x71 can work?? (2015/08/28)
-		{
-			//Write WL "Non-Active" in Score-board for Native-PS
-			halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, FALSE);
-
-		}
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-
-		
-		//Write WL "Active" in Score-board for LPS off
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-		
-	}
-}
-
-VOID
-EXhalbtc8703b1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	u1Byte u1Tmpa, u1Tmpb;
-	u4Byte u4Tmp;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm )
-		return;
-
-	if(BTC_SCAN_START == type)
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-		halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);		
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &pCoexSta->nScanAPNum);		
-	}
-
-	if(pBtCoexist->btInfo.bBtDisabled)
-		return;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	halbtc8703b1ant_QueryBtInfo(pBtCoexist);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8703b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8703b1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-	
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8703b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8703b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_SCAN_START == type)
-	{	
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8703b1ant_ActionWifiNotConnectedScan(pBtCoexist);
-		}
-		else	// wifi is connected
-		{
-			halbtc8703b1ant_ActionWifiConnectedScan(pBtCoexist);
-		}
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8703b1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8703b1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8703b1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-		halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-		 RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));	
-		 pCoexDm->nArpCnt = 0;
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));	
-		//pCoexDm->nArpCnt = 0;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8703b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8703b1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8703b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8703b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));		
-		halbtc8703b1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-		
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-		if(!bWifiConnected) // non-connected scan
-		{
-			halbtc8703b1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8703b1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8703b1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	BOOLEAN			bWifiUnderBMode = FALSE;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-		halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-
-		//Set CCK Tx/Rx high Pri except 11b mode
-		if (bWifiUnderBMode)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x00); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x00); //CCK Rx
-		}
-		else
-		{
-			//pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x10); //CCK Tx
-			//pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x10); //CCK Rx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x00); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x10); //CCK Rx
-		}
-		
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, FALSE);
-		pCoexDm->nArpCnt = 0;
-
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x0); //CCK Tx
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x0); //CCK Rx
-
-		pCoexSta->bCCKEverLock = FALSE;
-	}
-
-	halbtc8703b1ant_UpdateWifiChannelInfo(pBtCoexist, type);	
-	
-}
-
-VOID
-EXhalbtc8703b1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bBtHsOn=FALSE;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE, bUnder4way=FALSE;
-	u1Byte	aggBufSize=5;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if( BTC_PACKET_DHCP == type || 
-		BTC_PACKET_EAPOL == type ||
-		BTC_PACKET_ARP == type )
-	{
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-		
-		if (BTC_PACKET_ARP == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet ARP notify\n"));		 
-
-			pCoexDm->nArpCnt++;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ARP Packet Count = %d\n", pCoexDm->nArpCnt));
-			
-			if((pCoexDm->nArpCnt >= 10) && (!bUnder4way)) // if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecialPacket(pBtCoexist) 
-			{
-				pCoexSta->bWiFiIsHighPriTask = FALSE;					
-			}			
-			else
-			{
-				pCoexSta->bWiFiIsHighPriTask = TRUE;
-			}
-		}
-		else
-		{
-			pCoexSta->bWiFiIsHighPriTask = TRUE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet DHCP or EAPOL notify\n"));		 
-		}
-	} 
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet [Type = %d] notify\n", type));
-	}
-
-	pCoexSta->specialPktPeriodCnt = 0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8703b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8703b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8703b1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8703b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8703b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if( BTC_PACKET_DHCP == type ||
-		BTC_PACKET_EAPOL == type || 
-		( (BTC_PACKET_ARP == type ) && (pCoexSta->bWiFiIsHighPriTask) ) )
-		{
-		halbtc8703b1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8703b1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte				btInfo=0;
-	u1Byte				i, rspSource=0;
-	BOOLEAN				bWifiConnected=FALSE;
-	BOOLEAN				bBtBusy=FALSE;
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8703B_1ANT_MAX)
-		rspSource = BT_INFO_SRC_8703B_1ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	// if 0xff, it means BT is under WHCK test
-	if (btInfo == 0xff)
-		pCoexSta->bBtWhckTest = TRUE;
-	else
-		pCoexSta->bBtWhckTest = FALSE;
-
-	if(BT_INFO_SRC_8703B_1ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		if (pCoexSta->btRetryCnt >= 1)
-			pCoexSta->popEventCnt++;
-
-		if (pCoexSta->btInfoC2h[rspSource][2]&0x20)
-			pCoexSta->bC2hBtPage = TRUE;
-		else
-			pCoexSta->bC2hBtPage = FALSE;			
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2-90;
-			//pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-		
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-
-				
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if(pCoexSta->btInfoExt & BIT1)
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				halbtc8703b1ant_UpdateWifiChannelInfo(pBtCoexist, BTC_MEDIA_CONNECT);				
-			}
-			else
-			{
-				halbtc8703b1ant_UpdateWifiChannelInfo(pBtCoexist, BTC_MEDIA_DISCONNECT);					
-			}
-		}
-				
-		if(pCoexSta->btInfoExt & BIT3)
-		{
-			if(!pBtCoexist->bManualControl && !pBtCoexist->bStopCoexDm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-				halbtc8703b1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-			}
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-#if(BT_AUTO_REPORT_ONLY_8703B_1ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8703b1ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-		
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8703B_1ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	pCoexSta->nNumOfProfile = 0;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8703B_1ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-
-		pCoexSta->bBtHiPriLinkExist = FALSE;		
-	}
-	else	// connection exists
-	{		
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8703B_1ANT_B_FTP)
-		{
-			pCoexSta->bPanExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8703B_1ANT_B_A2DP)
-		{
-			pCoexSta->bA2dpExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8703B_1ANT_B_HID)
-		{
-			pCoexSta->bHidExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8703B_1ANT_B_SCO_ESCO)
-		{
-			pCoexSta->bScoExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bScoExist = FALSE;
-
-		if ((pCoexSta->bHidExist == FALSE) && (pCoexSta->bC2hBtInquiryPage == FALSE) &&( pCoexSta->bScoExist == FALSE))
-		{
-			if (pCoexSta->highPriorityTx  + pCoexSta->highPriorityRx >= 160) 		
-			{
-				pCoexSta->bHidExist = TRUE;
-				pCoexSta->wrongProfileNotification++;
-				pCoexSta->nNumOfProfile++;
-				btInfo = btInfo | 0x28;
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT HID = true (Hi-Pri > 160)!\n"));
-			}
-		}
-
-		//Add Hi-Pri Tx/Rx counter to avoid false detection
-		if (((pCoexSta->bHidExist) || (pCoexSta->bScoExist)) && (pCoexSta->highPriorityTx + pCoexSta->highPriorityRx >= 160)
-			 && (!pCoexSta->bC2hBtInquiryPage))
-			pCoexSta->bBtHiPriLinkExist = TRUE;
-		else
-			pCoexSta->bBtHiPriLinkExist = FALSE;
-			
-		if((btInfo&BT_INFO_8703B_1ANT_B_ACL_BUSY) && (pCoexSta->nNumOfProfile == 0))
-		{
-			if (pCoexSta->lowPriorityTx + pCoexSta->lowPriorityRx >= 160)
-			{
-				pCoexSta->bPanExist = TRUE;
-				pCoexSta->nNumOfProfile++;
-				pCoexSta->wrongProfileNotification++;
-				btInfo = btInfo | 0x88;				
-			}
-		}
-	}
-
-	halbtc8703b1ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	btInfo = btInfo & 0x1f;  //mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41)
-	
-	if(!(btInfo&BT_INFO_8703B_1ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8703B_1ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8703B_1ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8703B_1ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8703B_1ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8703B_1ANT_B_ACL_BUSY)
-	{
-		if(BT_8703B_1ANT_BT_STATUS_ACL_BUSY != pCoexDm->btStatus)
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->btStatus = BT_8703B_1ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8703B_1ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-
-	if( (BT_8703B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8703B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		bBtBusy = TRUE;
-	else
-		bBtBusy = FALSE;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	halbtc8703b1ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8703b1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	)
-{
-	u4Byte	u4Tmp;
-	u1Byte	u1Tmpa,u1Tmpb, u1Tmpc;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF Status notify\n"));
-
-	if(BTC_RF_ON == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned ON!!\n"));
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-		halbtc8703b1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		pBtCoexist->bStopCoexDm = FALSE;
-	}
-	else if(BTC_RF_OFF == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned OFF!!\n"));
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, FALSE);
-		
-		halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);		
-		halbtc8703b1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		pBtCoexist->bStopCoexDm = TRUE;
-
-	}
-}
-
-VOID
-EXhalbtc8703b1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u4Byte	u4Tmp;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, FALSE);
-
-	halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8703b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-	halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);	
-
-	halbtc8703b1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-
-	EXhalbtc8703b1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-
-	pBtCoexist->bStopCoexDm = TRUE;	
-}
-
-VOID
-EXhalbtc8703b1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, FALSE);
-
-		halbtc8703b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8703b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8703b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		halbtc8703b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);		
-
-		pBtCoexist->bStopCoexDm = TRUE;
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		halbtc8703b1ant_PostActiveStateToBT(pBtCoexist, TRUE);
-		
-		pBtCoexist->bStopCoexDm = FALSE;
-		halbtc8703b1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8703b1ant_InitCoexDm(pBtCoexist);
-		halbtc8703b1ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-
-VOID
-EXhalbtc8703b1ant_ScoreBoardStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	//
-
-
-}
-
-VOID
-EXhalbtc8703b1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], *****************Coex DM Reset*****************\n"));
-
-	halbtc8703b1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x2, 0xfffff, 0x0);
-	halbtc8703b1ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8703b1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n", 
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n", 
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8703b1Ant, GLCoexVer8703b1Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8703B_1ANT == 0)
-	halbtc8703b1ant_QueryBtInfo(pBtCoexist);
-	halbtc8703b1ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	halbtc8703b1ant_MonitorBtCtr(pBtCoexist);
-	halbtc8703b1ant_MonitorWiFiCtr(pBtCoexist);
-#if BT_8703B_1ANT_ANTDET_ENABLE
-	halbtc8703b1ant_MonitorBtEnableDisable(pBtCoexist);
-#endif
-
-	if( halbtc8703b1ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust )
-	{
-
-		halbtc8703b1ant_RunCoexistMechanism(pBtCoexist);	
-	}
-
-	pCoexSta->specialPktPeriodCnt++;
-
-#endif
-}
-
-VOID
-EXhalbtc8703b1ant_AntennaDetection(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	)
-{
-	  //No Antenna Detection required because 8730b is only 1-Ant
-}
-
-VOID
-EXhalbtc8703b1ant_AntennaIsolation(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	)
-{
-
-
-}
-
-VOID
-EXhalbtc8703b1ant_PSDScan(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	)
-{
-
-
-}
-
-VOID
-EXhalbtc8703b1ant_DisplayAntDetection(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-
-}
-
-#endif
-
-#else	// #if (RTL8723B_SUPPORT == 1)
-VOID
-EXhalbtc8703b1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-VOID
-EXhalbtc8703b1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-VOID
-EXhalbtc8703b1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	){}
-VOID
-EXhalbtc8703b1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-VOID
-EXhalbtc8703b1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8703b1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8703b1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8703b1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8703b1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	){}
-VOID
-EXhalbtc8703b1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	){}
-VOID
-EXhalbtc8703b1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	){}
-VOID
-EXhalbtc8703b1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	){}
-VOID
-EXhalbtc8703b1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	){}
-VOID
-EXhalbtc8703b1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	){}
-VOID
-EXhalbtc8703b1ant_ScoreBoardStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	){}
-VOID
-EXhalbtc8703b1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	){}
-VOID
-EXhalbtc8703b1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	){}
-VOID
-EXhalbtc8703b1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-VOID
-EXhalbtc8703b1ant_AntennaDetection(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	){}
-VOID
-EXhalbtc8703b1ant_DisplayAntDetection(
-	IN	PBTC_COEXIST			pBtCoexist
-	){}
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b1Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b1Ant.h
deleted file mode 100644
index bbbdfc6b0907..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b1Ant.h
+++ /dev/null
@@ -1,387 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8703B 1ANT BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8703B_1ANT				1
-
-#define	BT_INFO_8703B_1ANT_B_FTP						BIT7
-#define	BT_INFO_8703B_1ANT_B_A2DP					BIT6
-#define	BT_INFO_8703B_1ANT_B_HID						BIT5
-#define	BT_INFO_8703B_1ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8703B_1ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8703B_1ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8703B_1ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8703B_1ANT_B_CONNECTION				BIT0
-
-#define	BT_INFO_8703B_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT		2
-
-#define  BT_8703B_1ANT_WIFI_NOISY_THRESH							30   //max: 255
-
-//for Antenna detection
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_BACKGROUND					50
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			55
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_1ANT							35
-#define	BT_8703B_1ANT_ANTDET_RETRY_INTERVAL							10	//retry timer if ant det is fail, unit: second
-#define	BT_8703B_1ANT_ANTDET_ENABLE									0
-#define	BT_8703B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE				0
-
-#define	BT_8703B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
-
-typedef enum _BT_8703B_1ANT_SIGNAL_STATE{
-	BT_8703B_1ANT_SIG_STA_SET_TO_LOW		= 0x0,
-	BT_8703B_1ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8703B_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,
-	BT_8703B_1ANT_SIG_STA_MAX
-}BT_8703B_1ANT_SIGNAL_STATE,*PBT_8703B_1ANT_SIGNAL_STATE;
-
-typedef enum _BT_8703B_1ANT_PATH_CTRL_OWNER{
-	BT_8703B_1ANT_PCO_BTSIDE		= 0x0,
-	BT_8703B_1ANT_PCO_WLSIDE	= 0x1,
-	BT_8703B_1ANT_PCO_MAX
-}BT_8703B_1ANT_PATH_CTRL_OWNER,*PBT_8703B_1ANT_PATH_CTRL_OWNER;
-
-typedef enum _BT_8703B_1ANT_GNT_CTRL_TYPE{
-	BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,
-	BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,
-	BT_8703B_1ANT_GNT_TYPE_MAX
-}BT_8703B_1ANT_GNT_CTRL_TYPE,*PBT_8703B_1ANT_GNT_CTRL_TYPE;
-
-typedef enum _BT_8703B_1ANT_GNT_CTRL_BLOCK{
-	BT_8703B_1ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8703B_1ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8703B_1ANT_GNT_BLOCK_BB			= 0x2,
-	BT_8703B_1ANT_GNT_BLOCK_MAX
-}BT_8703B_1ANT_GNT_CTRL_BLOCK,*PBT_8703B_1ANT_GNT_CTRL_BLOCK;
-
-typedef enum _BT_8703B_1ANT_LTE_COEX_TABLE_TYPE{
-	BT_8703B_1ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8703B_1ANT_CTT_BT_VS_LTE			= 0x1,
-	BT_8703B_1ANT_CTT_MAX
-}BT_8703B_1ANT_LTE_COEX_TABLE_TYPE,*PBT_8703B_1ANT_LTE_COEX_TABLE_TYPE;
-
-typedef enum _BT_8703B_1ANT_LTE_BREAK_TABLE_TYPE{
-	BT_8703B_1ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8703B_1ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8703B_1ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8703B_1ANT_LBTT_LTE_BREAK_BT				= 0x3,
-	BT_8703B_1ANT_LBTT_MAX
-}BT_8703B_1ANT_LTE_BREAK_TABLE_TYPE,*PBT_8703B_1ANT_LTE_BREAK_TABLE_TYPE;
-
-typedef enum _BT_INFO_SRC_8703B_1ANT{
-	BT_INFO_SRC_8703B_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8703B_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8703B_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8703B_1ANT_MAX
-}BT_INFO_SRC_8703B_1ANT,*PBT_INFO_SRC_8703B_1ANT;
-
-typedef enum _BT_8703B_1ANT_BT_STATUS{
-	BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8703B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8703B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8703B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8703B_1ANT_BT_STATUS_MAX
-}BT_8703B_1ANT_BT_STATUS,*PBT_8703B_1ANT_BT_STATUS;
-
-typedef enum _BT_8703B_1ANT_WIFI_STATUS{
-	BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT				= 0x3,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8703B_1ANT_WIFI_STATUS_MAX
-}BT_8703B_1ANT_WIFI_STATUS,*PBT_8703B_1ANT_WIFI_STATUS;
-
-typedef enum _BT_8703B_1ANT_COEX_ALGO{
-	BT_8703B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8703B_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8703B_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8703B_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8703B_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8703B_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8703B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8703B_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8703B_1ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8703B_1ANT_COEX_ALGO,*PBT_8703B_1ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8703B_1ANT{
-	// hw setting
-	u1Byte		preAntPosType;
-	u1Byte		curAntPosType;
-	// fw mechanism
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	// sw mechanism
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	u4Byte		backupArfrCnt1;	// Auto Rate Fallback Retry cnt
-	u4Byte		backupArfrCnt2;	// Auto Rate Fallback Retry cnt
-	u2Byte		backupRetryLimit;
-	u1Byte		backupAmpduMaxTime;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-	u1Byte		preArfrType;
-	u1Byte		curArfrType;
-	u1Byte		preRetryLimitType;
-	u1Byte		curRetryLimitType;
-	u1Byte		preAmpduTimeType;
-	u1Byte		curAmpduTimeType;
-	u4Byte		nArpCnt;
-
-	u1Byte		errorCondition;
-} COEX_DM_8703B_1ANT, *PCOEX_DM_8703B_1ANT;
-
-typedef struct _COEX_STA_8703B_1ANT{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-	BOOLEAN					bBtHiPriLinkExist;
-	u1Byte					nNumOfProfile;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					specialPktPeriodCnt;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	s1Byte					btRssi;
-	BOOLEAN					bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8703B_1ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8703B_1ANT_MAX];
-	BOOLEAN					bBtWhckTest;
-	BOOLEAN					bC2hBtInquiryPage;
-	BOOLEAN					bC2hBtPage;				//Add for win8.1 page out issue
-	BOOLEAN					bWiFiIsHighPriTask;		//Add for win8.1 page out issue
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	u4Byte					popEventCnt;
-	u1Byte					nScanAPNum;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;	
-
-	BOOLEAN					bCCKLock;
-	BOOLEAN					bPreCCKLock;
-	BOOLEAN					bCCKEverLock;
-	u1Byte					nCoexTableType;
-
-	BOOLEAN					bForceLpsOn;
-	u4Byte					wrongProfileNotification;
-
-	BOOLEAN					bConCurrentRxModeOn;
-
-	u2Byte					nScoreBoard;
-}COEX_STA_8703B_1ANT, *PCOEX_STA_8703B_1ANT;
-
-#define  BT_8703B_1ANT_ANTDET_PSD_POINTS			256	//MAX:1024
-#define  BT_8703B_1ANT_ANTDET_PSD_AVGNUM			1	//MAX:3
-#define	BT_8703B_1ANT_ANTDET_BUF_LEN				16
-
-typedef struct _PSDSCAN_STA_8703B_1ANT{
-
-u4Byte		 	nAntDet_BTLEChannel;  //BT LE Channel ex:2412
-u4Byte			nAntDet_BTTxTime;
-u4Byte			nAntDet_PrePSDScanPeakVal;
-BOOLEAN			nAntDet_IsAntDetAvailable;
-u4Byte			nAntDet_PSDScanPeakVal;
-BOOLEAN			nAntDet_IsBTReplyAvailable;
-u4Byte			nAntDet_PSDScanPeakFreq;
-
-u1Byte			nAntDet_Result;
-u1Byte			nAntDet_PeakVal[BT_8703B_1ANT_ANTDET_BUF_LEN];
-u1Byte			nAntDet_PeakFreq[BT_8703B_1ANT_ANTDET_BUF_LEN];
-u4Byte			bAntDet_TryCount;
-u4Byte			bAntDet_FailCount;
-u4Byte			nAntDet_IntevalCount;
-u4Byte			nAntDet_ThresOffset;
-
-u4Byte			nRealCentFreq;
-s4Byte			nRealOffset;
-u4Byte			nRealSpan;
-	
-u4Byte			nPSDBandWidth;  //unit: Hz
-u4Byte			nPSDPoint;		//128/256/512/1024
-u4Byte			nPSDReport[1024];  //unit:dB (20logx), 0~255
-u4Byte			nPSDReport_MaxHold[1024];  //unit:dB (20logx), 0~255
-u4Byte			nPSDStartPoint;
-u4Byte			nPSDStopPoint;
-u4Byte			nPSDMaxValuePoint;
-u4Byte			nPSDMaxValue;
-u4Byte			nPSDStartBase;
-u4Byte			nPSDAvgNum;	// 1/8/16/32
-u4Byte			nPSDGenCount;
-BOOLEAN			bIsPSDRunning;
-BOOLEAN			bIsPSDShowMaxOnly;
-} PSDSCAN_STA_8703B_1ANT, *PPSDSCAN_STA_8703B_1ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8703b1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8703b1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8703b1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8703b1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8703b1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8703b1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8703b1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8703b1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	);
-VOID
-EXhalbtc8703b1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8703b1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8703b1ant_ScoreBoardStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8703b1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8703b1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8703b1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8703b1ant_AntennaDetection(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	);
-VOID
-EXhalbtc8703b1ant_AntennaIsolation(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	);
-
-VOID
-EXhalbtc8703b1ant_PSDScan(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	);
-VOID
-EXhalbtc8703b1ant_DisplayAntDetection(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b2Ant.c
deleted file mode 100644
index c0ed795cd81b..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b2Ant.c
+++ /dev/null
@@ -1,4865 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8703B Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8703b2Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8703B_2ANT		GLCoexDm8703b2Ant;
-static PCOEX_DM_8703B_2ANT 	pCoexDm=&GLCoexDm8703b2Ant;
-static COEX_STA_8703B_2ANT		GLCoexSta8703b2Ant;
-static PCOEX_STA_8703B_2ANT	pCoexSta=&GLCoexSta8703b2Ant;
-
-const char *const GLBtInfoSrc8703b2Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8703b2Ant=20140903;
-u4Byte	GLCoexVer8703b2Ant=0x43;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8703b2ant_
-//============================================================
-u1Byte
-halbtc8703b2ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8703B_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8703b2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8703B_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8703B_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8703b2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-		}
-	}
-}
-
-VOID
-halbtc8703b2ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-}
-
-VOID
-halbtc8703b2ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	if ( (pCoexSta->lowPriorityRx >= 950)  &&  (pCoexSta->lowPriorityRx >= pCoexSta->lowPriorityTx) && (!pCoexSta->bUnderIps) )
-	{
-		pBtLinkInfo->bSlaveRole = TRUE;
-	}
-	else
-	{
-		pBtLinkInfo->bSlaveRole = FALSE;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8703b2ant_MonitorWiFiCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u2Byte 	u2Tmp[3];
-	s4Byte	wifiRssi=0;
-	BOOLEAN bWifiBusy = FALSE, bWifiUnderBMode = FALSE;
-	static u1Byte nCCKLockCounter = 0;
-
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->nCRCOK_CCK = 0;
-		pCoexSta->nCRCOK_11g = 0;
-		pCoexSta->nCRCOK_11n = 0;
-		pCoexSta->nCRCOK_11nAgg = 0;
-
-		pCoexSta->nCRCErr_CCK = 0;
-		pCoexSta->nCRCErr_11g = 0;
-		pCoexSta->nCRCErr_11n = 0;
-		pCoexSta->nCRCErr_11nAgg = 0;	
-	}
-	else
-	{
-		pCoexSta->nCRCOK_CCK	= pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf88);
-		pCoexSta->nCRCOK_11g 	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf94);
-		pCoexSta->nCRCOK_11n	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf90);
-		pCoexSta->nCRCOK_11nAgg= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfb8);
-
-		pCoexSta->nCRCErr_CCK 	 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf84);
-		pCoexSta->nCRCErr_11g 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf96);
-		pCoexSta->nCRCErr_11n 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf92);
-		pCoexSta->nCRCErr_11nAgg = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfba);		
-	}
-
-	//reset counter
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x0);
-}
-
-VOID
-halbtc8703b2ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-BOOLEAN
-halbtc8703b2ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN	bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte			wifiRssiState=BTC_RSSI_STATE_HIGH;
-	
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-
-
-		wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist,3, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-
-		if ( (BTC_RSSI_STATE_HIGH ==wifiRssiState ) ||  (BTC_RSSI_STATE_LOW ==wifiRssiState ))
-		{
-			return TRUE;
-		}
-	
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8703b2ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO 	pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-#if(BT_AUTO_REPORT_ONLY_8703B_2ANT == 1)	// profile from bt patch
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-#else	// profile from bt stack
-	pBtLinkInfo->bBtLinkExist = pStackInfo->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pStackInfo->bScoExist;
-	pBtLinkInfo->bA2dpExist = pStackInfo->bA2dpExist;
-	pBtLinkInfo->bPanExist = pStackInfo->bPanExist;
-	pBtLinkInfo->bHidExist = pStackInfo->bHidExist;
-
-	//for win-8 stack HID report error
-	if(!pStackInfo->bHidExist)
-		pStackInfo->bHidExist = pCoexSta->bHidExist;  //sync  BTInfo with BT firmware and stack
-	// when stack HID report error, here we use the info from bt fw.
-	if(!pStackInfo->bBtLinkExist)
-		pStackInfo->bBtLinkExist = pCoexSta->bBtLinkExist;	
-#endif
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8703b2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8703B_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-		
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO only\n"));
-			algorithm = BT_8703B_2ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8703B_2ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8703B_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(HS) only\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(EDR) only\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID\n"));
-				algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(HS)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(EDR)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-#if 0
-				if(pStackInfo->numOfHid >= 2)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID*2 + A2DP\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-				else
-#endif
-				{			
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(HS)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(EDR)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(HS)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(EDR)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8703B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8703b2ant_SetFwDacSwingLevel(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			dacSwingLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	// There are several type of dacswing
-	// 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6
-	H2C_Parameter[0] = dacSwingLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Set Dac Swing Level=0x%x\n", dacSwingLvl));
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x64=0x%x\n", H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x64, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8703b2ant_SetFwDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = decBtPwrLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], decrease Bt Power level = %d, FW write 0x62=0x%x\n", 
-		decBtPwrLvl, H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x62, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8703b2ant_DecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s Dec BT power level = %d\n",  
-		(bForceExec? "force to":""), decBtPwrLvl));
-	pCoexDm->curBtDecPwrLvl = decBtPwrLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preBtDecPwrLvl == pCoexDm->curBtDecPwrLvl) 
-			return;
-	}
-	halbtc8703b2ant_SetFwDecBtPwr(pBtCoexist, pCoexDm->curBtDecPwrLvl);
-
-	pCoexDm->preBtDecPwrLvl = pCoexDm->curBtDecPwrLvl;
-}
-
-VOID
-halbtc8703b2ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8703b2ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8703b2ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8703b2ant_FwDacSwingLvl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			fwDacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set FW Dac Swing level = %d\n",  
-		(bForceExec? "force to":""), fwDacSwingLvl));
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preFwDacSwingLvl == pCoexDm->curFwDacSwingLvl) 
-			return;
-	}
-
-	halbtc8703b2ant_SetFwDacSwingLevel(pBtCoexist, pCoexDm->curFwDacSwingLvl);
-
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-}
-
-VOID
-halbtc8703b2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xffffc);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8703b2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8703b2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8703b2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!")) );
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8703b2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	//return;
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8703b2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8703b2ant_SetDacSwingReg(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte			level
-	)
-{
-	u1Byte	val=(u1Byte)level;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Write SwDacSwing = 0x%x\n", level));
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x883, 0x3e, val);
-}
-
-VOID
-halbtc8703b2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	if(bSwDacSwingOn)
-	{
-		halbtc8703b2ant_SetDacSwingReg(pBtCoexist, swDacSwingLvl);
-	}
-	else
-	{
-		halbtc8703b2ant_SetDacSwingReg(pBtCoexist, 0x18);
-	}
-}
-
-
-VOID
-halbtc8703b2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8703b2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8703b2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc05, 0x30, 0x3);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc05, 0x30, 0x1);
-	}
-}
-
-VOID
-halbtc8703b2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8703b2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8703b2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	//=================BB AGC Gain Table
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6e1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6d1B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6c1C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6b1D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6a1E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x691F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x68200001);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table Off!\n"));
-	 	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xaa1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa91B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa81C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa71D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa61E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa51F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa4200001);
-	}
-	
-	
-	//=================RF Gain
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x1);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x0);
-
-	// set rssiAdjustVal for wifi module.
-	if(bAgcTableEn)
-	{
-		rssiAdjustVal = 8;
-	}
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-VOID
-halbtc8703b2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8703b2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8703b2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8703b2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8703b2ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8703b2ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexSta->nCoexTableType = type;
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5afa5afa, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x5ada5ada, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0xffffffff, 0xffffffff, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5fff5fff, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55ff55ff, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 7:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 8:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 9:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 10:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 11:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 12:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 13:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 14:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 15:
-			halbtc8703b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8703b2ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8703b2ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8703b2ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8703b2ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8703b2ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8703b2ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8703b2ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-
-
-	 if ( (pCoexSta->bA2dpExist) && (pCoexSta->bHidExist) )
-	 {
-		byte5 = byte5 | 0x1;
-	 }
-	 
-	H2C_Parameter[0] = byte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = byte5;
-
-	pCoexDm->psTdmaPara[0] = byte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = byte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x60(5bytes)=0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-VOID
-halbtc8703b2ant_SwMechanism1(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bShrinkRxLPF,
-	IN	BOOLEAN 	bLowPenaltyRA,
-	IN	BOOLEAN		bLimitedDIG, 
-	IN	BOOLEAN		bBTLNAConstrain
-	) 
-{
-	/*
-	u4Byte	wifiBw;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	
-	if(BTC_WIFI_BW_HT40 != wifiBw)  //only shrink RF Rx LPF for HT40
-	{
-		if (bShrinkRxLPF)
-			bShrinkRxLPF = FALSE;
-	}
-	*/
-	
-	//halbtc8703b2ant_RfShrink(pBtCoexist, NORMAL_EXEC, bShrinkRxLPF);
-	halbtc8703b2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8703b2ant_SwMechanism2(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bAGCTableShift,
-	IN	BOOLEAN 	bADCBackOff,
-	IN	BOOLEAN		bSWDACSwing,
-	IN	u4Byte		dacSwingLvl
-	) 
-{
-	//halbtc8703b2ant_AgcTable(pBtCoexist, NORMAL_EXEC, bAGCTableShift);
-	//halbtc8703b2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, bADCBackOff);
-	//halbtc8703b2ant_DacSwing(pBtCoexist, NORMAL_EXEC, bSWDACSwing, dacSwingLvl);
-}
-
-VOID
-halbtc8703b2ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	PBTC_BOARD_INFO pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte			fwVer=0, u4Tmp=0;
-	BOOLEAN			bPgExtSwitch=FALSE;
-	BOOLEAN			bUseExtSwitch=FALSE;
-	u1Byte			H2C_Parameter[2] ={0};
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_EXT_SWITCH, &bPgExtSwitch);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);	// [31:16]=fw ver, [15:0]=fw sub ver
-
-	if((fwVer>0 && fwVer<0xc0000) || bPgExtSwitch)
-		bUseExtSwitch = TRUE;
-
-	if(bInitHwCfg)
-	{
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x39, 0x8, 0x1);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x974, 0xff);
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x944, 0x3, 0x3);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x930, 0x77);
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x1);
-
-		if(fwVer >= 0x180000)
-		{
-			/* Use H2C to set GNT_BT to High to avoid A2DP click */
-			H2C_Parameter[0] = 1;
-		pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-		}
-		else
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18);
-		}
-		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); //WiFi TRx Mask off
-		//remove due to interrupt is disabled that polling c2h will fail and delay 100ms.
-		//pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x01); //BT TRx Mask off
-
-		if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-		{
-			//tell firmware "no antenna inverse"
-			H2C_Parameter[0] = 0;
-		}
-		else
-		{
-			//tell firmware "antenna inverse"
-			H2C_Parameter[0] = 1;
-		}
-
-		if (bUseExtSwitch)
-		{
-			//ext switch type
-			H2C_Parameter[1] = 1;
-		}
-		else
-		{
-			//int switch type
-			H2C_Parameter[1] = 0;
-		}
-		pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-	}
-	else
-	{
-		if(fwVer >= 0x180000)
-		{
-			/* Use H2C to set GNT_BT to "Control by PTA"*/
-			H2C_Parameter[0] = 0;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);			
-		}
-		else
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x0);
-		}
-	}
-
-	// ext switch setting
-	if(bUseExtSwitch)
-	{
-		if (bInitHwCfg)
-		{
-			// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-			u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-			u4Tmp &=~BIT23;
-			u4Tmp |= BIT24;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-		}
-		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0); // fixed internal switch S1->WiFi, S0->BT
-		switch(antPosType)
-		{
-			case BTC_ANT_WIFI_AT_MAIN:
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x1);	// ext switch main at wifi
-				break;
-			case BTC_ANT_WIFI_AT_AUX:
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x2);	// ext switch aux at wifi
-				break;
-		}	
-	}
-	else	// internal switch
-	{
-		if (bInitHwCfg)
-		{
-			// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-			u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-			u4Tmp |= BIT23;
-			u4Tmp &=~BIT24;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-		}
-		
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x64, 0x1, 0x0); //fixed external switch S1->Main, S0->Aux
-		switch(antPosType)
-		{
-			case BTC_ANT_WIFI_AT_MAIN:
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0); // fixed internal switch S1->WiFi, S0->BT
-				break;
-			case BTC_ANT_WIFI_AT_AUX:
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x280); // fixed internal switch S0->WiFi, S1->BT
-				break;
-		}
-	}
-}
-
-VOID
-halbtc8703b2ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN			bTurnOnByCnt=FALSE;
-	u1Byte			psTdmaTypeByCnt=0;
-	u1Byte			wifiRssiState1, btRssiState;
-
-	
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-		(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if (!(BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState)) && bTurnOn)
-	{
-		type = type +100;  //for WiFi RSSI low or BT RSSI low
-		pCoexDm->bIsSwitchTo1dot5Ant = TRUE;
-	}
-	else
-	{
-		pCoexDm->bIsSwitchTo1dot5Ant = FALSE;
-	}
-
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-	if(bTurnOn)
-	{
-		switch(type)
-		{
-			case 1:
-			default:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 2:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x03, 0xf1, 0x90);
-				break;
-			case 3:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0xf1, 0x90);
-				break;
-			case 4:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x03, 0xf1, 0x90);
-				break;
-			case 5:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x3, 0x70, 0x90);				
-				break;
-			case 6:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x3, 0x70, 0x90);
-				break;
-			case 7:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0x70, 0x90);
-				break;
-			case 8:	
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x10, 0x3, 0x70, 0x90);
-				break;
-			case 9:	
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 10:	
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x03, 0xf1, 0x90);
-				break;
-			case 11:	
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0xe1, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0xf1, 0x90);
-				break;
-			case 12:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x3, 0xf1, 0x90);
-				break;
-			case 13:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x3, 0x70, 0x90);		
-				break;
-			case 14:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x3, 0x70, 0x90);		
-				break;
-			case 15:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0x60, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0x70, 0x90);		
-				break;
-			case 16:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0x60, 0x90);
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x3, 0x70, 0x90);		
-				break;
-			case 17:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x2f, 0x2f, 0x60, 0x90);
-				break;
-			case 18:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				break;			
-			case 19:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0xe1, 0x90);
-				break;
-			case 20:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0x60, 0x90);
-				break;
-			case 21:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x03, 0x70, 0x90);
-				break;	
-			case 71:
-				//halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 101:
-			case 105:
-			case 171:	
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x3a, 0x03, 0x70, 0x50);
-				break;
-			case 102:
-			case 106:
-			case 110:
-			case 114:	
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x2d, 0x03, 0x70, 0x50);
-				break;	
-			case 103:
-			case 107:
-			case 111:
-			case 115:	
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1c, 0x03, 0x70, 0x50);
-				break;		
-			case 104:
-			case 108:
-			case 112:
-			case 116:	
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x10, 0x03, 0x70, 0x50);
-				break;	
-			case 109:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 113:	
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x70, 0x90);
-				break;
-			case 121:	
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x03, 0x70, 0x90);
-				break;	
-			case 22:
-			case 122:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x35, 0x03, 0x71, 0x11);
-				break;
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(type)
-		{
-			case 0:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-			case 1:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x48, 0x0);
-				break;
-			default:
-				halbtc8703b2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8703b2ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8703b2ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8703b2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8703b2ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.			
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8703b2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-
-VOID
-halbtc8703b2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8703b2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8703b2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8703b2ant_DecBtPwr(pBtCoexist, FORCE_EXEC, 0);
-
-	halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8703b2ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	BOOLEAN	bWifiConnected=FALSE;
-	BOOLEAN	bLowPwrDisable=TRUE;
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-	
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-
-	if(bScan || bLink || bRoam)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi link process + BT Inq/Page!!\n"));
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-	}
-	else if(bWifiConnected)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT Inq/Page!!\n"));
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi no-link + BT Inq/Page!!\n"));
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	}	
-	
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-/*
-	pCoexDm->bNeedRecover0x948 = TRUE;
-	pCoexDm->backup0x948 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-
-	halbtc8703b2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_AUX, FALSE, FALSE);
-*/	
-}
-
-
-VOID
-halbtc8703b2ant_ActionWiFiLinkProcess(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u1Byte 	u1Tmpa, u1Tmpb;
-	
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-	halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-
-	halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-
-	 u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-        u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	 u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-
-	 RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x76e=0x%x\n",
-	   	      u4Tmp,  u1Tmpa, u1Tmpb));
-}
-
-BOOLEAN
-halbtc8703b2ant_ActionWifiIdleProcess(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	//wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES-20, 0);
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-
-	// define the office environment
-	if(BTC_RSSI_HIGH(wifiRssiState1) && 
-			(pCoexSta->bHidExist == TRUE) && (pCoexSta->bA2dpExist == TRUE))
-	{
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi  idle process for BT HID+A2DP exist!!\n"));
-		
-		halbtc8703b2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x6);
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-		// sw all off
-		halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	  	return TRUE;
-	}
-	else
-	{
-		halbtc8703b2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-		return FALSE;	
-	}
-	
-	
-}
-
-
-
-BOOLEAN
-halbtc8703b2ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			btRssiState=BTC_RSSI_STATE_HIGH;
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-	BOOLEAN			bBtHsOn=FALSE, bLowPwrDisable=FALSE;
-	BOOLEAN			bAsus8703b=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected)
-	{
-		bLowPwrDisable = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-		halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-connected idle!!\n"));
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-		
- 		halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		bCommon = TRUE;
-	}
-	else
-	{
-		if(BT_8703B_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-			halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-			halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);		
-			halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0xb);
-			halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	      	halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else if(BT_8703B_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bBtHsOn)
-				return FALSE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-			halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-			halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-			halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-			halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0xb);
-			halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else
-		{
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bWifiBusy)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-#if 0				
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_IS_ASUS_8703B, &bAsus8703b);
-				if(!bAsus8703b)
-					bCommon = FALSE;
-				else
-					bCommon = halbtc8703b2ant_ActionWifiIdleProcess(pBtCoexist);	
-#else
-				bCommon = FALSE;
-#endif
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-				//bCommon = FALSE;	
-				bCommon = halbtc8703b2ant_ActionWifiIdleProcess(pBtCoexist);			
-			}
-		}	
-	}
-
-	return bCommon;
-}
-VOID
-halbtc8703b2ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bScoHid,
-	IN	BOOLEAN			bTxPause,
-	IN	u1Byte			maxInterval
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-		{
-			if(bScoHid)
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;	
-					}
-					else
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-			else
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->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 = pCoexSta->btRetryCnt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-		if(maxInterval == 1)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-
-				if(pCoexDm->curPsTdma == 71)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-					pCoexDm->psTdmaDuAdjType = 13;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				
-				if(result == -1)
-				{					
-					if(pCoexDm->curPsTdma == 5)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;
-					}
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-					pCoexDm->psTdmaDuAdjType = 71;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-					pCoexDm->psTdmaDuAdjType = 9;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 71)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-						pCoexDm->psTdmaDuAdjType = 71;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 2)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 3)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-		if( !bScan && !bLink && !bRoam)
-		{
-			halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-}
-
-// SCO only or SCO+PAN(HS)
-VOID
-halbtc8703b2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, btRssiState;
-	u4Byte	wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 4);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for SCO quality at 11b/g mode
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-	else  //for SCO quality & wifi performance balance at 11n mode
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-	}
-
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-	halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); //for voice quality
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x4);			
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x4);	
-		}		
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x4);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x4);
-		}		
-	}
-}
-
-
-VOID
-halbtc8703b2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, btRssiState;	
-	u4Byte	wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 9);
-	}
-
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-	
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-	}
-	else
-	{
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-	}
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}	
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8703b2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-
-	// define the office environment
-	if( (apNum >= 10) && BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		//DbgPrint(" AP#>10(%d)\n", apNum);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-		
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);	
-		halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-		halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);			
-					
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-		// sw mechanism
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x18);		
-		}
-		return;
-		
-	}
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-		
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-	
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-	}
-	else
-	{
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-	}
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8703b2ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 2);
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8703b2ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState,wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 10);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-	}
-	else
-	{
-		halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-	}
-	
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-
-//PAN(HS) only
-VOID
-halbtc8703b2ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8703b2ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))		
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	else
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 12);
-		
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-		else
-			halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-	}
-	
-	// sw mechanism	
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8703b2ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))	
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 3);
-			//halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 11);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780);
-		}
-		else
-		{
-			halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-			//halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		}
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 2);
-	}
-	else
-	{
-		halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		//halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-	}
-	
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8703b2ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState,wifiRssiState1,  btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8703b2ant_BtRssiState(2, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-		else
-			halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-	}
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8703b2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8703b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	//btRssiState = halbtc8703b2ant_BtRssiState(2, 29, 0);
-	wifiRssiState1 = halbtc8703b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8703b2ant_BtRssiState(3, BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES, 37);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8703b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x5);
-
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_LEGACY == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(btRssiState))
-			halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		else if(BTC_RSSI_MEDIUM(btRssiState))
-			halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-			halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else	
-	{	// only 802.11N mode we have to dec bt power to 4 degree
-		if(BTC_RSSI_HIGH(btRssiState))
-		{
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-			// need to check ap Number of Not
-			if(apNum < 10)
-				halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-			else
-				halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		}
-		else if(BTC_RSSI_MEDIUM(btRssiState))
-			halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		else	
-			halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8703b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-	}
-	
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8703b2ant_ActionBtWhckTest(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8703b2ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{		
-	halbtc8703b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8703b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8703b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8703b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8703b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8703b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-}
-
-VOID
-halbtc8703b2ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN				bWifiUnder5G=FALSE, bBtHsOn=FALSE;
-	u1Byte				btInfoOriginal=0, btRetryCnt=0;
-	u1Byte				algorithm=0;
-	u4Byte				numOfWifiLink=0;
-	u4Byte				wifiLinkStatus=0;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bMiracastPlusBt=FALSE;
-	BOOLEAN				bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	if(pCoexSta->bBtWhckTest)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under WHCK TEST!!!\n"));
-		halbtc8703b2ant_ActionBtWhckTest(pBtCoexist);
-		return;
-	}
-
-	algorithm = halbtc8703b2ant_ActionAlgorithm(pBtCoexist);
-	if(pCoexSta->bC2hBtInquiryPage && (BT_8703B_2ANT_COEX_ALGO_PANHS!=algorithm))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under inquiry/page scan !!\n"));
-		halbtc8703b2ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else
-	{
-		/*
-		if(pCoexDm->bNeedRecover0x948)
-		{
-			pCoexDm->bNeedRecover0x948 = FALSE;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, pCoexDm->backup0x948);
-		}
-		*/
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-	if(bScan || bLink || bRoam)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], WiFi is under Link Process !!\n"));
-		halbtc8703b2ant_ActionWiFiLinkProcess(pBtCoexist);
-		return;
-	}
-
-	//for P2P
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  Multi-Port numOfWifiLink = %d, wifiLinkStatus = 0x%x\n", numOfWifiLink,wifiLinkStatus) );
-
-		if(pBtLinkInfo->bBtLinkExist)
-		{
-			bMiracastPlusBt = TRUE;
-		}
-		else
-		{
-			bMiracastPlusBt = FALSE;
-		}
-		
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-		halbtc8703b2ant_ActionWifiMultiPort(pBtCoexist);
-		
-		return;
-	}
-	else
-	{
-		bMiracastPlusBt = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-	}
-
-	pCoexDm->curAlgorithm = algorithm;
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Algorithm = %d \n", pCoexDm->curAlgorithm));
-
-	if(halbtc8703b2ant_IsCommonAction(pBtCoexist))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant common.\n"));
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{
-		if(pCoexDm->curAlgorithm != pCoexDm->preAlgorithm)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 
-				pCoexDm->preAlgorithm, pCoexDm->curAlgorithm));
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8703B_2ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO.\n"));
-				halbtc8703b2ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID.\n"));
-				halbtc8703b2ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP.\n"));
-				halbtc8703b2ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n"));
-				halbtc8703b2ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n"));
-				halbtc8703b2ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HS mode.\n"));
-				halbtc8703b2ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n"));
-				halbtc8703b2ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-				halbtc8703b2ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-				halbtc8703b2ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8703B_2ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n"));
-				halbtc8703b2ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n"));
-				halbtc8703b2ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8703b2ant_WifiOffHwCfg(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN	bIsInMpMode = FALSE;
-	u1Byte H2C_Parameter[2] ={0};
-	u4Byte fwVer=0;
-
-	// set wlan_act to low
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780); //WiFi goto standby while GNT_BT 0-->1
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	if(fwVer >= 0x180000)
-	{
-	/* Use H2C to set GNT_BT to HIGH */
-	H2C_Parameter[0] = 1;
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-	}
-	else
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18);
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_IS_IN_MP_MODE, &bIsInMpMode);
-	if(!bIsInMpMode)
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x0); //BT select s0/s1 is controlled by BT
-	else
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x1); //BT select s0/s1 is controlled by WiFi
-}
-
-VOID
-halbtc8703b2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte	u4Tmp=0, fwVer;
-	u2Byte				u2Tmp=0;
-	u1Byte	u1Tmp=0;
-	u1Byte				H2C_Parameter[2] ={0};
-		
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	// backup rf 0x1e value
-	pCoexDm->btRf0x1eBackup = 
-		pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);	
-
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	//Antenna config	
-	halbtc8703b2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_MAIN, TRUE, FALSE);
-	pCoexSta->disVerInfoCnt = 0;
-
-	// PTA parameter
-	halbtc8703b2ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-	
-	// Enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4); //0x76e[3] =1, WLAN_Act control by PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x3);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x1);
-}
-
-//============================================================
-// work around function start with wa_halbtc8703b2ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8703b2ant_
-//============================================================
-VOID
-EXhalbtc8703b2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u2Byte u2Tmp=0x0;
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x67, 0x20);
-
-	// enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly.
-	u2Tmp = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x2);
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x2, u2Tmp|BIT0|BIT1);
-
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-		pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-	}
-	else
-	{
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-			// set to S1
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-		}
-	}
-}
-
-VOID
-EXhalbtc8703b2ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u1Byte u1Tmp=0x4; /* Set BIT2 by default since it's 2ant case */
-
-	// 
-	// S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info)
-	// Local setting bit define
-	//	BIT0: "0" for no antenna inverse; "1" for antenna inverse 
-	//	BIT1: "0" for internal switch; "1" for external switch
-	//	BIT2: "0" for one antenna; "1" for two antenna
-	// NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-	 	u1Tmp |= 0x1;	// antenna inverse
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0xfe08, u1Tmp);
-	}
-	else
-	{
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			u1Tmp |= 0x1;	// antenna inverse
-		}
-
-		if(pBtCoexist->chipInterface == BTC_INTF_PCI)
-		{	
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x384, u1Tmp);
-		}
-		else if(pBtCoexist->chipInterface == BTC_INTF_SDIO)
-		{
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x60, u1Tmp);
-		}			
-	}
-}
-
-VOID
-EXhalbtc8703b2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8703b2ant_InitHwConfig(pBtCoexist, TRUE);
-}
-
-VOID
-EXhalbtc8703b2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8703b2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8703b2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-	u4Byte				faOfdm, faCck;
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8703b2Ant, GLCoexVer8703b2Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %ddBm/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8703B_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8703B_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi-100, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist);
-	CL_PRINTF(cliBuf);
-
-	if (pStackInfo->bProfileNotified)
-	{
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Role", \
-		(pBtLinkInfo->bSlaveRole )? "Slave":"Master");
-		CL_PRINTF(cliBuf);	
-	}	
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8703B_2ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8703b2Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	// Sw mechanism	
-	if(pBtCoexist->bManualControl)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism] (before Manual)============");			
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism] (before Manual) ============");			
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	}
-
-	psTdmaCase = pCoexDm->curPsTdma;
-
-	if (pCoexDm->bIsSwitchTo1dot5Ant)
-		psTdmaCase = psTdmaCase + 100;
-		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)", "PS TDMA", \
-		pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-		pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase, 
-			(pCoexDm->bCurPsTdmaOn? "On":"Off"),
-			(pCoexDm->bAutoTdmaAdjust? "Adj":"Fix") );
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Coex Table Type", \
-			pCoexSta->nCoexTableType);
-		CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "DecBtPwr/ IgnWlanAct", \
-		pCoexDm->curBtDecPwrLvl, pCoexDm->bCurIgnoreWlanAct);
-	CL_PRINTF(cliBuf);
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x880);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x778/0x880[29:25]", \
-		u1Tmp[0], (u4Tmp[0]&0x3e000000) >> 25);
-	CL_PRINTF(cliBuf);
-
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x948/ 0x67[5] / 0x765", \
-		u4Tmp[0], ((u1Tmp[0]&0x20)>> 5), u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-	
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x92c);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x930);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x944);	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x92c[1:0]/ 0x930[7:0]/0x944[1:0]", \
-		u4Tmp[0]&0x3, u4Tmp[1]&0xff, u4Tmp[2]&0x3);
-	CL_PRINTF(cliBuf);
-
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x39);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-	u1Tmp[2] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x64);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "0x38[11]/0x40/0x4c[24:23]/0x64[0]", \
-		((u1Tmp[0] & 0x8)>>3), u1Tmp[1], ((u4Tmp[0]&0x01800000)>>23), u1Tmp[2]&0x1);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x49c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xc50(dig)/0x49c(null-drop)", \
-		u4Tmp[0]&0xff, u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda8);
-	u4Tmp[3] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcf0);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5b);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-
-	faOfdm = ((u4Tmp[0]&0xffff0000) >> 16) +  ((u4Tmp[1]&0xffff0000) >> 16) + (u4Tmp[1] & 0xffff) +  (u4Tmp[2] & 0xffff) + \
-		             ((u4Tmp[3]&0xffff0000) >> 16) + (u4Tmp[3] & 0xffff) ;
-	faCck = (u1Tmp[0] << 8) + u1Tmp[1];
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "OFDM-CCA/OFDM-FA/CCK-FA", \
-		u4Tmp[0]&0xffff, faOfdm, faCck);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_OK CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCOK_CCK, pCoexSta->nCRCOK_11g, pCoexSta->nCRCOK_11n, pCoexSta->nCRCOK_11nAgg);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_Err CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCErr_CCK, pCoexSta->nCRCErr_11g, pCoexSta->nCRCErr_11n, pCoexSta->nCRCErr_11nAgg);
-	CL_PRINTF(cliBuf);	
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(high-pri rx/tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri rx/tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8703B_2ANT == 1)
-	//halbtc8703b2ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8703b2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		halbtc8703b2ant_WifiOffHwCfg(pBtCoexist);
-		halbtc8703b2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		halbtc8703b2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-		halbtc8703b2ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8703b2ant_InitCoexDm(pBtCoexist);
-		halbtc8703b2ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8703b2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8703b2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u4Byte 	u4Tmp;
-	u1Byte 	u1Tmpa, u1Tmpb;	
-	
-
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-	u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-	
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-	}
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x76e=0x%x\n",
-		u4Tmp,  u1Tmpa, u1Tmpb));
-}
-
-VOID
-EXhalbtc8703b2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8703b2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	u1Byte			apNum=0;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-		{
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-			if(apNum < 10)
-				H2C_Parameter[2] = 0x30;
-			else
-				H2C_Parameter[2] = 0x20;
-	}
-	}
-	
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);	
-}
-
-VOID
-EXhalbtc8703b2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8703b2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtBusy=FALSE, bLimitedDig=FALSE;
-	BOOLEAN			bWifiConnected=FALSE;
-	static BOOLEAN		bPreScoExist=FALSE;
-	u4Byte				raMask=0x0;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8703B_2ANT_MAX)
-		rspSource = BT_INFO_SRC_8703B_2ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), return for Manual CTRL<===\n"));
-		return;
-	}
-
-	// if 0xff, it means BT is under WHCK test
-	if (btInfo == 0xff)
-		pCoexSta->bBtWhckTest = TRUE;
-	else
-		pCoexSta->bBtWhckTest = FALSE;
-
-	if(BT_INFO_SRC_8703B_2ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-		if (pCoexSta->bBtTxRxMask)
-		{
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x01 => Need to switch BT TRx Mask */				
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x01\n"));
-			pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x01);
-		}
-
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if( (pCoexSta->btInfoExt & BIT1) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				EXhalbtc8703b2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8703b2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-		
-		if( (pCoexSta->btInfoExt & BIT3) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-			halbtc8703b2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-#if(BT_AUTO_REPORT_ONLY_8703B_2ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8703b2ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8703B_2ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8703B_2ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8703B_2ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8703B_2ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8703B_2ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8703B_2ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-
-		if ( (pCoexSta->bHidExist == FALSE) && (pCoexSta->bC2hBtInquiryPage == FALSE) && (pCoexSta->bScoExist == FALSE))
-		{
-			if (pCoexSta->highPriorityTx  + pCoexSta->highPriorityRx >= 160) 		
-			{
-				pCoexSta->bHidExist = TRUE;
-				btInfo = btInfo | 0x20;
-			}
-		}
-	}
-
-	halbtc8703b2ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	if(!(btInfo&BT_INFO_8703B_2ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8703B_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8703B_2ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8703B_2ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8703B_2ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8703B_2ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8703B_2ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8703B_2ANT_B_ACL_BUSY)
-	{
-		pCoexDm->btStatus = BT_8703B_2ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8703B_2ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-	
-	if( (BT_8703B_2ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8703B_2ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8703B_2ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bBtBusy = TRUE;
-		bLimitedDig = TRUE;
-	}
-	else
-	{
-		bBtBusy = FALSE;
-		bLimitedDig = FALSE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	pCoexDm->bLimitedDig = bLimitedDig;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bLimitedDig);
-
-	halbtc8703b2ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8703b2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8703b2ant_WifiOffHwCfg(pBtCoexist);
-	//remove due to interrupt is disabled that polling c2h will fail and delay 100ms.
-	//pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15); //BT goto standby while GNT_BT 1-->0
-	halbtc8703b2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	
-	EXhalbtc8703b2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8703b2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		halbtc8703b2ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8703b2ant_InitCoexDm(pBtCoexist);
-		halbtc8703b2ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8703b2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	//static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(pCoexSta->disVerInfoCnt <= 5)
-	{
-		pCoexSta->disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8703b2Ant, GLCoexVer8703b2Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-
-		if (pCoexSta->disVerInfoCnt == 3)
-		{
-			//Antenna config to set 0x765 = 0x0 (GNT_BT control by PTA) after initial 
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set GNT_BT control by PTA\n"));
-			halbtc8703b2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_MAIN, FALSE, FALSE);
-		}
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8703B_2ANT == 0)
-	halbtc8703b2ant_QueryBtInfo(pBtCoexist);
-	halbtc8703b2ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	halbtc8703b2ant_MonitorBtCtr(pBtCoexist);
-	halbtc8703b2ant_MonitorWiFiCtr(pBtCoexist);
-	
-	if( halbtc8703b2ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust)
-	{
-		halbtc8703b2ant_RunCoexistMechanism(pBtCoexist);
-	}
-#endif
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b2Ant.h
deleted file mode 100644
index d879f6234a56..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8703b2Ant.h
+++ /dev/null
@@ -1,229 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8703B 2Ant BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8703B_2ANT				1
-
-
-#define	BT_INFO_8703B_2ANT_B_FTP						BIT7
-#define	BT_INFO_8703B_2ANT_B_A2DP					BIT6
-#define	BT_INFO_8703B_2ANT_B_HID						BIT5
-#define	BT_INFO_8703B_2ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8703B_2ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8703B_2ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8703B_2ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8703B_2ANT_B_CONNECTION				BIT0
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8703B_2ANT		2
-
-
-#define	BT_8703B_2ANT_WIFI_RSSI_COEXSWITCH_THRES				42  //WiFi RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation
-#define	BT_8703B_2ANT_BT_RSSI_COEXSWITCH_THRES				46 //BT RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation
-
-typedef enum _BT_INFO_SRC_8703B_2ANT{
-	BT_INFO_SRC_8703B_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8703B_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8703B_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8703B_2ANT_MAX
-}BT_INFO_SRC_8703B_2ANT,*PBT_INFO_SRC_8703B_2ANT;
-
-typedef enum _BT_8703B_2ANT_BT_STATUS{
-	BT_8703B_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8703B_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8703B_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8703B_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8703B_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8703B_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8703B_2ANT_BT_STATUS_MAX
-}BT_8703B_2ANT_BT_STATUS,*PBT_8703B_2ANT_BT_STATUS;
-
-typedef enum _BT_8703B_2ANT_COEX_ALGO{
-	BT_8703B_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8703B_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8703B_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8703B_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8703B_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8703B_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8703B_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8703B_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8703B_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8703B_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8703B_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8703B_2ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8703B_2ANT_COEX_ALGO,*PBT_8703B_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8703B_2ANT{
-	// fw mechanism
-	u1Byte		preBtDecPwrLvl;
-	u1Byte		curBtDecPwrLvl;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bResetTdmaAdjust;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	BOOLEAN		bNeedRecover0x948;
-	u4Byte		backup0x948;
-
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	BOOLEAN		bIsSwitchTo1dot5Ant;
-} COEX_DM_8703B_2ANT, *PCOEX_DM_8703B_2ANT;
-
-typedef struct _COEX_STA_8703B_2ANT{	
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	BOOLEAN				bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8703B_2ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8703B_2ANT_MAX];
-	BOOLEAN 				bBtWhckTest;
-	BOOLEAN					bC2hBtInquiryPage;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;
-
-	u1Byte					nCoexTableType;
-	BOOLEAN					bForceLpsOn;
-
-	u1Byte					disVerInfoCnt;
-}COEX_STA_8703B_2ANT, *PCOEX_STA_8703B_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8703b2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8703b2ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8703b2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8703b2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8703b2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8703b2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8703b2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8703b2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8703b2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8703b2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8703b2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8703b2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a1Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a1Ant.c
deleted file mode 100644
index bcb2ffe91800..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a1Ant.c
+++ /dev/null
@@ -1,1545 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8723A Co-exist mechanism
-//
-// History
-// 2012/08/22 Cosa first check in.
-// 2012/11/14 Cosa Revise for 8723A 1Ant out sourcing.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8723a1Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8723A_1ANT	GLCoexDm8723a1Ant;
-static PCOEX_DM_8723A_1ANT 	pCoexDm=&GLCoexDm8723a1Ant;
-static COEX_STA_8723A_1ANT	GLCoexSta8723a1Ant;
-static PCOEX_STA_8723A_1ANT	pCoexSta=&GLCoexSta8723a1Ant;
-
-const char *const GLBtInfoSrc8723a1Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8723a1ant_
-//============================================================
-VOID
-halbtc8723a1ant_Reg0x550Bit3(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSet
-	)
-{
-	u1Byte	u1tmp=0;
-	
-	u1tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x550);
-	if(bSet)
-	{
-		u1tmp |= BIT3;
-	}
-	else
-	{
-		u1tmp &= ~BIT3;
-	}
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x550, u1tmp);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], set 0x550[3]=%d\n", (bSet? 1:0)));
-}
-
-VOID
-halbtc8723a1ant_NotifyFwScan(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			scanType
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	if(BTC_SCAN_START == scanType)
-		H2C_Parameter[0] = 0x1;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Notify FW for wifi scan, write 0x3b=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x3b, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8723a1ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x38=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x38, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8723a1ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xf0ff7);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8723a1ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8723a1ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8723a1ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte	tmpU1;
-
-	tmpU1 = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd);
-	tmpU1 |= BIT0;
-	if(bLowPenaltyRa)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set low penalty!!\n"));
-		tmpU1 &= ~BIT2;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set normal!!\n"));
-		tmpU1 |= BIT2;
-	}
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, tmpU1);
-}
-
-VOID
-halbtc8723a1ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	return;
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8723a1ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8723a1ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8723a1ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8723a1ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8723a1ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x25=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x25, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8723a1ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8723a1ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8723a1ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	// byte1[1:0] != 0 means enable pstdma
-	// for 2Ant bt coexist, if byte1 != 0 means enable pstdma
-	if(byte1)
-	{
-		if(bApEnable)
-		{
-			if(type != 5 && type != 12)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-				realByte1 &= ~BIT4;
-				realByte1 |= BIT5;
-
-				realByte5 |= BIT5;
-				realByte5 &= ~BIT6;
-			}
-		}
-	}
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-	
-	RT_TRACE(COMP_COEX, DBG_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]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x3a, 5, H2C_Parameter);
-}
-
-VOID
-halbtc8723a1ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-		(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));		
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-	if(pCoexDm->bCurPsTdmaOn)
-	{
-		switch(pCoexDm->curPsTdma)
-		{
-			case 1:
-			default:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x1a, 0x1a, 0x0, 0x40);
-				break;
-			case 2:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x12, 0x12, 0x0, 0x40);
-				break;
-			case 3:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x93, 0x3f, 0x3, 0x10, 0x40);
-				break;
-			case 4:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x93, 0x15, 0x3, 0x10, 0x0);
-				break;
-			case 5:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0xa9, 0x15, 0x3, 0x35, 0xc0);
-				break;
-			
-			case 8: 
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;
-			case 9: 
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0xa, 0xa, 0x0, 0x40);
-				break;
-			case 10:	
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0xa, 0xa, 0x0, 0x40);
-				break;
-			case 11:	
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x5, 0x5, 0x0, 0x40);
-				break;
-			case 12:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0xa9, 0xa, 0x3, 0x15, 0xc0);
-				break;
-	
-			case 18:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;			
-
-			case 20:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x2a, 0x2a, 0x0, 0x0);
-				break;
-			case 21:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x93, 0x20, 0x3, 0x10, 0x40);
-				break;
-			case 22:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x1a, 0x1a, 0x2, 0x40);
-				break;
-			case 23:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x12, 0x12, 0x2, 0x40);
-				break;
-			case 24:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0xa, 0xa, 0x2, 0x40);
-				break;
-			case 25:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x5, 0x5, 0x2, 0x40);
-				break;
-			case 26:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;
-			case 27:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x13, 0x5, 0x5, 0x2, 0x40);
-				break;
-			case 28:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x3, 0x2f, 0x2f, 0x0, 0x0);
-				break;
-
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(pCoexDm->curPsTdma)
-		{
-			case 8:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x8, 0x0, 0x0, 0x0, 0x0);		
-				break;
-			case 0:
-			default:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x0, 0x0, 0x0, 0x0, 0x0);
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x860, 0x210);
-				break;
-			case 9:
-				halbtc8723a1ant_SetFwPstdma(pBtCoexist, type, 0x0, 0x0, 0x0, 0x0, 0x0);
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x860, 0x110);
-				break;
-
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-
-VOID
-halbtc8723a1ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-	halbtc8723a1ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-
-	// sw all off
-	halbtc8723a1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a1ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	// hw all off
-	halbtc8723a1ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-}
-
-VOID
-halbtc8723a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// force to reset coex mechanism
-	halbtc8723a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-}
-
-VOID
-halbtc8723a1ant_BtEnableAction(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-}
-
-VOID
-halbtc8723a1ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8723a1ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-	
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-			halbtc8723a1ant_BtEnableAction(pBtCoexist);
-		}
-		else
-		{
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		}
-	}
-}
-
-VOID
-halbtc8723a1ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-	u1Byte			btState;
-	BOOLEAN			bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-	u4Byte			wifiBw;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	btState = pCoexDm->btStatus;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], TdmaDurationAdjust()\n"));
-	if(pCoexDm->psTdmaGlobalCnt != pCoexDm->psTdmaMonitorCnt)
-	{
-		pCoexDm->psTdmaMonitorCnt = 0;
-		pCoexDm->psTdmaGlobalCnt = 0;
-	}
-	if(pCoexDm->psTdmaMonitorCnt == 0)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], first run BT A2DP + WiFi busy state!!\n"));
-		if(btState == BT_STATE_8723A_1ANT_ACL_ONLY_BUSY)
-		{
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-			pCoexDm->psTdmaDuAdjType = 1;
-		}
-		else
-		{
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			pCoexDm->psTdmaDuAdjType = 22;
-		}
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-		retryCount = pCoexSta->btRetryCnt;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;	
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-		
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT TxRx counter H+L <= 1200\n"));
-			if(btState != BT_STATE_8723A_1ANT_ACL_ONLY_BUSY)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], NOT ACL only busy!\n"));
-				if(BTC_WIFI_BW_HT40 != wifiBw)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 20MHz\n"));
-					if(result == -1)
-					{
-						if(pCoexDm->curPsTdma == 22)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-							pCoexDm->psTdmaDuAdjType = 23;
-						}
-						else if(pCoexDm->curPsTdma == 23)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 24);
-							pCoexDm->psTdmaDuAdjType = 24;
-						}
-						else if(pCoexDm->curPsTdma == 24)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 25);
-							pCoexDm->psTdmaDuAdjType = 25;
-						}
-					} 
-					else if (result == 1)
-					{
-						if(pCoexDm->curPsTdma == 25)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 24);
-							pCoexDm->psTdmaDuAdjType = 24;
-						}
-						else if(pCoexDm->curPsTdma == 24)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-							pCoexDm->psTdmaDuAdjType = 23;
-						}
-						else if(pCoexDm->curPsTdma == 23)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-							pCoexDm->psTdmaDuAdjType = 22;
-						}
-					}
-					// error handle, if not in the following state,
-					// set psTdma again.
-					if( (pCoexDm->psTdmaDuAdjType != 22) &&
-						(pCoexDm->psTdmaDuAdjType != 23) &&
-						(pCoexDm->psTdmaDuAdjType != 24) &&
-						(pCoexDm->psTdmaDuAdjType != 25) )
-					{
-						RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], duration case out of handle!!\n"));
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-						pCoexDm->psTdmaDuAdjType = 23;
-					}
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 40MHz\n"));
-					if(result == -1)
-					{
-						if(pCoexDm->curPsTdma == 23)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 24);
-							pCoexDm->psTdmaDuAdjType = 24;
-						}
-						else if(pCoexDm->curPsTdma == 24)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 25);
-							pCoexDm->psTdmaDuAdjType = 25;
-						}
-						else if(pCoexDm->curPsTdma == 25)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 27);
-							pCoexDm->psTdmaDuAdjType = 27;
-						}
-					} 
-					else if (result == 1)
-					{
-						if(pCoexDm->curPsTdma == 27)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 25);
-							pCoexDm->psTdmaDuAdjType = 25;
-						}
-						else if(pCoexDm->curPsTdma == 25)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 24);
-							pCoexDm->psTdmaDuAdjType = 24;
-						}
-						else if(pCoexDm->curPsTdma == 24)
-						{
-							halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-							pCoexDm->psTdmaDuAdjType = 23;
-						}
-					}
-					// error handle, if not in the following state,
-					// set psTdma again.
-					if( (pCoexDm->psTdmaDuAdjType != 23) &&
-						(pCoexDm->psTdmaDuAdjType != 24) &&
-						(pCoexDm->psTdmaDuAdjType != 25) &&
-						(pCoexDm->psTdmaDuAdjType != 27) )
-					{
-						RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], duration case out of handle!!\n"));
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 24);
-						pCoexDm->psTdmaDuAdjType = 24;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ACL only busy\n"));
-				if (result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-				}
-
-				// error handle, if not in the following state,
-				// set psTdma again.
-				if( (pCoexDm->psTdmaDuAdjType != 1) &&
-					(pCoexDm->psTdmaDuAdjType != 2) &&
-					(pCoexDm->psTdmaDuAdjType != 9) &&
-					(pCoexDm->psTdmaDuAdjType != 11) )
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], duration case out of handle!!\n"));
-					halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-		if( !bScan && !bLink &&	!bRoam)
-		{
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-	pCoexDm->psTdmaMonitorCnt++;
-}
-
-
-VOID
-halbtc8723a1ant_CoexForWifiConnect(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bWifiConnected=FALSE, bWifiBusy=FALSE;
-	u1Byte		btState, btInfoOriginal=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	btState = pCoexDm->btStatus;
-	btInfoOriginal = pCoexSta->btInfoC2h[BT_INFO_SRC_8723A_1ANT_BT_RSP][0];
-
-	if(bWifiConnected)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi connected!!\n"));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-		
-		if( !bWifiBusy &&
-			((BT_STATE_8723A_1ANT_NO_CONNECTION == btState) ||
-			(BT_STATE_8723A_1ANT_CONNECT_IDLE == btState)) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], [Wifi is idle] or [Bt is non connected idle or Bt is connected idle]!!\n"));
-
-			if(BT_STATE_8723A_1ANT_NO_CONNECTION == btState)
-				halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9);
-			else if(BT_STATE_8723A_1ANT_CONNECT_IDLE == btState)
-				halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-
-			pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xff000000, 0xc0);
-		}
-		else
-		{
-			if( (BT_STATE_8723A_1ANT_SCO_ONLY_BUSY == btState) ||
-				(BT_STATE_8723A_1ANT_ACL_SCO_BUSY == btState) ||
-				(BT_STATE_8723A_1ANT_HID_BUSY == btState) ||
-				(BT_STATE_8723A_1ANT_HID_SCO_BUSY == btState) )
-			{
-				pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xff000000, 0x60);
-			}
-			else
-			{
-				pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xff000000, 0xc0);
-			}
-			switch(btState)
-			{
-				case BT_STATE_8723A_1ANT_NO_CONNECTION:
-					halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					break;
-				case BT_STATE_8723A_1ANT_CONNECT_IDLE:
-					halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					break;
-				case BT_STATE_8723A_1ANT_INQ_OR_PAG:
-					halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					break;
-				case BT_STATE_8723A_1ANT_SCO_ONLY_BUSY:
-				case BT_STATE_8723A_1ANT_ACL_SCO_BUSY:
-				case BT_STATE_8723A_1ANT_HID_BUSY:
-				case BT_STATE_8723A_1ANT_HID_SCO_BUSY:
-					halbtc8723a1ant_TdmaDurationAdjust(pBtCoexist);
-					break;
-				case BT_STATE_8723A_1ANT_ACL_ONLY_BUSY:
-					if (btInfoOriginal&BT_INFO_8723A_1ANT_B_A2DP)
-					{
-						halbtc8723a1ant_TdmaDurationAdjust(pBtCoexist);
-					}
-					else if(btInfoOriginal&BT_INFO_8723A_1ANT_B_FTP)
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-					}
-					else if( (btInfoOriginal&BT_INFO_8723A_1ANT_B_A2DP) &&
-							(btInfoOriginal&BT_INFO_8723A_1ANT_B_FTP) )
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					}
-					else
-					{
-						halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-					}
-					break;
-				default:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], error!!!, undefined case in halbtc8723a1ant_CoexForWifiConnect()!!\n"));
-					break;
-			}
-		}
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is disconnected!!\n"));
-	}
-
-	pCoexDm->psTdmaGlobalCnt++;
-}
-
-//============================================================
-// work around function start with wa_halbtc8723a1ant_
-//============================================================
-VOID
-wa_halbtc8723a1ant_MonitorC2h(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u1Byte	tmp1b=0x0;
-	u4Byte	curC2hTotalCnt=0x0;
-	static u4Byte	preC2hTotalCnt=0x0, sameCntPollingTime=0x0;
-
-	curC2hTotalCnt+=pCoexSta->btInfoC2hCnt[BT_INFO_SRC_8723A_1ANT_BT_RSP];
-
-	if(curC2hTotalCnt == preC2hTotalCnt)
-	{
-		sameCntPollingTime++;
-	}
-	else
-	{
-		preC2hTotalCnt = curC2hTotalCnt;
-		sameCntPollingTime = 0;
-	}
-
-	if(sameCntPollingTime >= 2)
-	{
-		tmp1b = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x1af);
-		if(tmp1b != 0x0)
-		{
-			pCoexSta->c2hHangDetectCnt++;
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x1af, 0x0);
-		}
-	}
-}
-
-//============================================================
-// extern function start with EXhalbtc8723a1ant_
-//============================================================
-VOID
-EXhalbtc8723a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 1Ant Init HW Config!!\n"));
-
-	// backup rf 0x1e value
-	pCoexDm->btRf0x1eBackup = 
-		pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x20);
-
-	// enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-	
-	// coex table
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, 0x0);			// 1-Ant coex
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, 0xffff);		// wifi break table
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, 0x55555555);	//coex table
-
-	// antenna switch control parameter
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x858, 0xaaaaaaaa);
-	
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x860, 0x210);	//set antenna at wifi side if ANTSW is software control
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x870, 0x300);	//SPDT(connected with TRSW) control by hardware PTA
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x874, 0x22804000);	//ANTSW keep by GNT_BT
-
-	// coexistence parameters
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x1);	// enable RTK mode PTA
-}
-
-VOID
-EXhalbtc8723a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8723a1ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8723a1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-	
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "[Action Manual control]!!");
-		CL_PRINTF(cliBuf);
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8723A_1ANT_BT_STATUS_IDLE == pCoexDm->btStatus)? "idle":(  (BT_8723A_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy"))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-	
-	if(pStackInfo->bProfileNotified)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-			pStackInfo->bScoExist, pStackInfo->bHidExist, pStackInfo->bPanExist, pStackInfo->bA2dpExist);
-		CL_PRINTF(cliBuf);	
-
-		pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-	}
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8723A_1ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8723a1Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "write 0x1af=0x0 num", \
-		pCoexSta->c2hHangDetectCnt);
-	CL_PRINTF(cliBuf);
-	
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);	
-	
-	if(!pBtCoexist->bManualControl)
-	{
-		psTdmaCase = pCoexDm->curPsTdma;
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase);
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IgnWlanAct", \
-			pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-	}
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x783);
-	u1Tmp[2] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x796);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x778/ 0x783/ 0x796", \
-		u1Tmp[0], u1Tmp[1], u1Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x880);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x880", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x40", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x484);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x484(rate adaptive)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda8);
-	u4Tmp[3] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xdac);
-	CL_SPRINTF(cliBuf, 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]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770 (hp rx[31:16]/tx[15:0])", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(lp rx[31:16]/tx[15:0])", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8723a1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		halbtc8723a1ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		//halbtc8723a1ant_InitCoexDm(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8723a1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	}
-}
-
-VOID
-EXhalbtc8723a1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN		bWifiConnected=FALSE;
-	
-	halbtc8723a1ant_NotifyFwScan(pBtCoexist, type);
-
-	if(pBtCoexist->btInfo.bBtDisabled)
-	{
-		halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9); 
-	}
-	else
-	{
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-		if(BTC_SCAN_START == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-			if(!bWifiConnected)	// non-connected scan
-			{
-				//set 0x550[3]=1 before PsTdma
-				halbtc8723a1ant_Reg0x550Bit3(pBtCoexist, TRUE);
-			}
-
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-		}
-		else if(BTC_SCAN_FINISH == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-			if(!bWifiConnected)	// non-connected scan
-			{
-				halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); 
-			}
-			else
-			{
-				halbtc8723a1ant_CoexForWifiConnect(pBtCoexist);
-			}
-		}
-	}
-}
-
-VOID
-EXhalbtc8723a1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN		bWifiConnected=FALSE;
-		
-	if(pBtCoexist->btInfo.bBtDisabled)
-	{
-		halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9); 
-	}
-	else
-	{
-		if(BTC_ASSOCIATE_START == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-			//set 0x550[3]=1 before PsTdma
-			halbtc8723a1ant_Reg0x550Bit3(pBtCoexist, TRUE);
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);	// extend wifi slot	
-		}
-		else if(BTC_ASSOCIATE_FINISH == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(!bWifiConnected)	// non-connected scan
-			{
-				halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-			}
-			else
-			{
-				halbtc8723a1ant_CoexForWifiConnect(pBtCoexist);
-			}
-		}
-	}
-}
-
-VOID
-EXhalbtc8723a1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8723a1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-		if(pBtCoexist->btInfo.bBtDisabled)
-		{
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9);	
-		}
-		else
-		{
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 18);
-		}		
-	}
-}
-
-VOID
-EXhalbtc8723a1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtHsOn=FALSE, bBtBusy=FALSE, bForceLps=FALSE;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-	
-	rspSource = BT_INFO_SRC_8723A_1ANT_BT_RSP;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 0)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(BT_INFO_SRC_8723A_1ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =
-			pCoexSta->btInfoC2h[rspSource][1];
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][2]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][3];
-	}
-		
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8723A_1ANT_B_INQ_PAGE)
-	{
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	}
-	else
-	{
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-	}
-	btInfo &= ~BIT2;
-	if(!(btInfo & BIT0))
-	{
-		pCoexDm->btStatus = BT_STATE_8723A_1ANT_NO_CONNECTION;
-		bForceLps = FALSE;
-	}
-	else
-	{
-		bForceLps = TRUE;
-		if(btInfo == 0x1)
-		{
-			pCoexDm->btStatus = BT_STATE_8723A_1ANT_CONNECT_IDLE;
-		}
-		else if(btInfo == 0x9)
-		{
-			pCoexDm->btStatus = BT_STATE_8723A_1ANT_ACL_ONLY_BUSY;
-			bBtBusy = TRUE;
-		}
-		else if(btInfo == 0x13)
-		{
-			pCoexDm->btStatus = BT_STATE_8723A_1ANT_SCO_ONLY_BUSY;
-			bBtBusy = TRUE;
-		}
-		else if(btInfo == 0x1b)
-		{
-			pCoexDm->btStatus = BT_STATE_8723A_1ANT_ACL_SCO_BUSY;
-			bBtBusy = TRUE;
-		}
-		else if(btInfo == 0x29)
-		{
-			pCoexDm->btStatus = BT_STATE_8723A_1ANT_HID_BUSY;
-			bBtBusy = TRUE;
-		}
-		else if(btInfo == 0x3b)
-		{
-			pCoexDm->btStatus = BT_STATE_8723A_1ANT_HID_SCO_BUSY;
-			bBtBusy = TRUE;
-		}
-	}
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bBtBusy);
-	if(bForceLps)
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-	else
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-
-	if( (BT_STATE_8723A_1ANT_NO_CONNECTION == pCoexDm->btStatus) ||
-		(BT_STATE_8723A_1ANT_CONNECT_IDLE == pCoexDm->btStatus) )
-	{
-		if(pCoexSta->bC2hBtInquiryPage)
-			pCoexDm->btStatus = BT_STATE_8723A_1ANT_INQ_OR_PAG;
-	}
-}
-
-VOID
-EXhalbtc8723a1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	halbtc8723a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-	
-	halbtc8723a1ant_LowPenaltyRa(pBtCoexist, FORCE_EXEC, FALSE);
-	halbtc8723a1ant_RfShrink(pBtCoexist, FORCE_EXEC, FALSE);
-
-	halbtc8723a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	EXhalbtc8723a1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8723a1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE, bWifiConnected=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 1Ant Periodical!!\n"));
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	// work around for c2h hang
-	wa_halbtc8723a1ant_MonitorC2h(pBtCoexist);	
-
-	halbtc8723a1ant_QueryBtInfo(pBtCoexist);
-	halbtc8723a1ant_MonitorBtCtr(pBtCoexist);
-	halbtc8723a1ant_MonitorBtEnableDisable(pBtCoexist);
-
-	
-	if(bScan)
-		return;
-	if(bLink)
-		return;
-
-	if(bWifiConnected)
-	{
-		if(pBtCoexist->btInfo.bBtDisabled)
-		{
-			halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9);
-			
-			halbtc8723a1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a1ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-		}
-		else
-		{
-			halbtc8723a1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a1ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a1ant_CoexForWifiConnect(pBtCoexist);
-		}
-	}
-	else
-	{
-		halbtc8723a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-
-		halbtc8723a1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a1ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-	}
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a1Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a1Ant.h
deleted file mode 100644
index e4f6b6d64c09..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a1Ant.h
+++ /dev/null
@@ -1,172 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8723A 1Ant BT Co-exist definition
-//===========================================
-#define	BT_INFO_8723A_1ANT_B_FTP						BIT7
-#define	BT_INFO_8723A_1ANT_B_A2DP					BIT6
-#define	BT_INFO_8723A_1ANT_B_HID						BIT5
-#define	BT_INFO_8723A_1ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8723A_1ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8723A_1ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8723A_1ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8723A_1ANT_B_CONNECTION				BIT0
-
-typedef enum _BT_STATE_8723A_1ANT{
-	BT_STATE_8723A_1ANT_DISABLED				= 0,
-	BT_STATE_8723A_1ANT_NO_CONNECTION		= 1,
-	BT_STATE_8723A_1ANT_CONNECT_IDLE		= 2,
-	BT_STATE_8723A_1ANT_INQ_OR_PAG			= 3,
-	BT_STATE_8723A_1ANT_ACL_ONLY_BUSY		= 4,
-	BT_STATE_8723A_1ANT_SCO_ONLY_BUSY		= 5,
-	BT_STATE_8723A_1ANT_ACL_SCO_BUSY			= 6,
-	BT_STATE_8723A_1ANT_HID_BUSY				= 7,
-	BT_STATE_8723A_1ANT_HID_SCO_BUSY			= 8,
-	BT_STATE_8723A_1ANT_MAX
-}BT_STATE_8723A_1ANT, *PBT_STATE_8723A_1ANT;
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8723A_1ANT		2
-
-typedef enum _BT_INFO_SRC_8723A_1ANT{
-	BT_INFO_SRC_8723A_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723A_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8723A_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8723A_1ANT_MAX
-}BT_INFO_SRC_8723A_1ANT,*PBT_INFO_SRC_8723A_1ANT;
-
-typedef enum _BT_8723A_1ANT_BT_STATUS{
-	BT_8723A_1ANT_BT_STATUS_IDLE				= 0x0,
-	BT_8723A_1ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,
-	BT_8723A_1ANT_BT_STATUS_NON_IDLE			= 0x2,
-	BT_8723A_1ANT_BT_STATUS_MAX
-}BT_8723A_1ANT_BT_STATUS,*PBT_8723A_1ANT_BT_STATUS;
-
-typedef enum _BT_8723A_1ANT_COEX_ALGO{
-	BT_8723A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8723A_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8723A_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8723A_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8723A_1ANT_COEX_ALGO_PANEDR			= 0x4,
-	BT_8723A_1ANT_COEX_ALGO_PANHS			= 0x5,
-	BT_8723A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x6,
-	BT_8723A_1ANT_COEX_ALGO_PANEDR_HID		= 0x7,
-	BT_8723A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x8,
-	BT_8723A_1ANT_COEX_ALGO_HID_A2DP			= 0x9,
-	BT_8723A_1ANT_COEX_ALGO_MAX
-}BT_8723A_1ANT_COEX_ALGO,*PBT_8723A_1ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8723A_1ANT{
-	// fw mechanism
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	u4Byte		psTdmaMonitorCnt;
-	u4Byte		psTdmaGlobalCnt;
-	BOOLEAN		bResetTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-} COEX_DM_8723A_1ANT, *PCOEX_DM_8723A_1ANT;
-
-typedef struct _COEX_STA_8723A_1ANT{
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	u1Byte					preBtRssiState;
-	u1Byte					preBtRssiState1;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8723A_1ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8723A_1ANT_MAX];
-	BOOLEAN					bC2hBtInquiryPage;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	//BOOLEAN					bHoldForStackOperation;
-	//u1Byte					bHoldPeriodCnt;
-	// this is for c2h hang work-around
-	u4Byte					c2hHangDetectCnt;
-}COEX_STA_8723A_1ANT, *PCOEX_STA_8723A_1ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8723a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723a1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723a1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723a1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8723a1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723a1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723a1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a2Ant.c
deleted file mode 100644
index b53a536d7a4e..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a2Ant.c
+++ /dev/null
@@ -1,3747 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8723A Co-exist mechanism
-//
-// History
-// 2012/08/22 Cosa first check in.
-// 2012/11/14 Cosa Revise for 8723A 2Ant out sourcing.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8723a2Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8723A_2ANT	GLCoexDm8723a2Ant;
-static PCOEX_DM_8723A_2ANT 	pCoexDm=&GLCoexDm8723a2Ant;
-static COEX_STA_8723A_2ANT	GLCoexSta8723a2Ant;
-static PCOEX_STA_8723A_2ANT	pCoexSta=&GLCoexSta8723a2Ant;
-
-const char *const GLBtInfoSrc8723a2Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8723a2ant_
-//============================================================
-BOOLEAN
-halbtc8723a2ant_IsWifiIdle(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bWifiConnected=FALSE, bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-	if(bWifiConnected)
-		return FALSE;
-	if(bScan)
-		return FALSE;
-	if(bLink)
-		return FALSE;
-	if(bRoam)
-		return FALSE;
-
-	return TRUE;
-}
-
-BOOLEAN
-halbtc8723a2ant_IsWifiConnectedIdle(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bWifiConnected=FALSE, bScan=FALSE, bLink=FALSE, bRoam=FALSE, bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(bScan)
-		return FALSE;
-	if(bLink)
-		return FALSE;
-	if(bRoam)
-		return FALSE;
-	if(bWifiConnected && !bWifiBusy)
-		return TRUE;
-	else 
-		return FALSE;
-}
-
-u1Byte
-halbtc8723a2ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8723a2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8723a2ant_IndicateWifiChnlBwInfo(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-		
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x19=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x19, 3, H2C_Parameter);
-}
-
-VOID
-halbtc8723a2ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x38=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x38, 1, H2C_Parameter);
-}
-u1Byte
-halbtc8723a2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	BOOLEAN				bBtHsOn=FALSE, bBtBusy=FALSE, bLimitedDig=FALSE;
-	u1Byte				algorithm=BT_8723A_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	//======================
-	// here we get BT status first
-	//======================
-	pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_IDLE;
-	
-	if((pStackInfo->bScoExist) ||(bBtHsOn) ||(pStackInfo->bHidExist))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO or HID or HS exists, set BT non-idle !!!\n"));
-		pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_NON_IDLE;
-	}
-	else
-	{
-		// A2dp profile
-		if( (pBtCoexist->stackInfo.numOfLink == 1) &&
-			(pStackInfo->bA2dpExist) )
-		{		
-			if( (pCoexSta->lowPriorityTx+	pCoexSta->lowPriorityRx) < 100)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP, low priority tx+rx < 100, set BT connected-idle!!!\n"));
-				pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE;
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP, low priority tx+rx >= 100, set BT non-idle!!!\n"));
-				pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_NON_IDLE;
-			}
-		}
-		// Pan profile
-		if( (pBtCoexist->stackInfo.numOfLink == 1) &&
-			(pStackInfo->bPanExist) )
-		{		
-			if((pCoexSta->lowPriorityTx+	pCoexSta->lowPriorityRx) < 600)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN, low priority tx+rx < 600, set BT connected-idle!!!\n"));
-				pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE;
-			}
-			else
-			{
-				if(pCoexSta->lowPriorityTx)
-				{
-					if((pCoexSta->lowPriorityRx /pCoexSta->lowPriorityTx)>9 )
-					{
-						RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN, low priority rx/tx > 9, set BT connected-idle!!!\n"));
-						pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE;
-					}
-				}
-			}
-			if(BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE != pCoexDm->btStatus)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN, set BT non-idle!!!\n"));
-				pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_NON_IDLE;
-			}
-		}
-		// Pan+A2dp profile
-		if( (pBtCoexist->stackInfo.numOfLink == 2) &&
-			(pStackInfo->bA2dpExist) &&
-			(pStackInfo->bPanExist) )
-		{
-			if((pCoexSta->lowPriorityTx+	pCoexSta->lowPriorityRx) < 600)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN+A2DP, low priority tx+rx < 600, set BT connected-idle!!!\n"));
-				pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE;
-			}
-			else
-			{
-				if(pCoexSta->lowPriorityTx)
-				{
-					if((pCoexSta->lowPriorityRx /pCoexSta->lowPriorityTx)>9 )
-					{
-						RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN+A2DP, low priority rx/tx > 9, set BT connected-idle!!!\n"));
-						pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE;
-					}
-				}
-			}
-			if(BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE != pCoexDm->btStatus)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN+A2DP, set BT non-idle!!!\n"));
-				pCoexDm->btStatus = BT_8723A_2ANT_BT_STATUS_NON_IDLE;
-			}
-		}
-	}
-	if(BT_8723A_2ANT_BT_STATUS_IDLE != pCoexDm->btStatus)
-	{
-		bBtBusy = TRUE;
-		bLimitedDig = TRUE;
-	}
-	else
-	{
-		bBtBusy = FALSE;
-		bLimitedDig = FALSE;
-	}
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bLimitedDig);
-	//======================
-
-	if(!pStackInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No profile exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pStackInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO only\n"));
-			algorithm = BT_8723A_2ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pStackInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8723A_2ANT_COEX_ALGO_HID;
-			}
-			else if(pStackInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8723A_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pStackInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(HS) only\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(EDR) only\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			if(pStackInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID\n"));
-				algorithm = BT_8723A_2ANT_COEX_ALGO_HID;
-			}
-			else if(pStackInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8723A_2ANT_COEX_ALGO_SCO;
-			}
-			else if(pStackInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(HS)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(EDR)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-				algorithm = BT_8723A_2ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(HS)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(EDR)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(HS)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(EDR)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8723A_2ANT_COEX_ALGO_HID;
-			}
-			else if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8723A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-BOOLEAN
-halbtc8723a2ant_NeedToDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bRet=FALSE;
-	BOOLEAN		bBtHsOn=FALSE, bWifiConnected=FALSE;
-	s4Byte		btHsRssi=0;
-	u1Byte		btRssiState=BTC_RSSI_STATE_HIGH;
-
-	btRssiState = halbtc8723a2ant_BtRssiState(2, 42, 0);
-
-	if(!pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn))
-		return FALSE;
-	if(!pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected))
-		return FALSE;
-	if(!pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_HS_RSSI, &btHsRssi))
-		return FALSE;
-	if(BTC_RSSI_LOW(btRssiState))
-		return FALSE;
-
-	if(bWifiConnected)
-	{
-		if(bBtHsOn)
-		{
-			if(btHsRssi > 37)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Need to decrease bt power for HS mode!!\n"));
-				bRet = TRUE;
-			}
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Need to decrease bt power for Wifi is connected!!\n"));
-			bRet = TRUE;
-		}
-	}
-	
-	return bRet;
-}
-
-VOID
-halbtc8723a2ant_SetFwDacSwingLevel(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			dacSwingLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	// There are several type of dacswing
-	// 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6
-	H2C_Parameter[0] = dacSwingLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Set Dac Swing Level=0x%x\n", dacSwingLvl));
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x29=0x%x\n", H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x29, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8723a2ant_SetFwDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bDecBtPwr
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bDecBtPwr)
-	{
-		H2C_Parameter[0] |= BIT1;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], decrease Bt Power : %s, FW write 0x21=0x%x\n", 
-		(bDecBtPwr? "Yes!!":"No!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x21, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8723a2ant_DecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDecBtPwr
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s Dec BT power = %s\n",  
-		(bForceExec? "force to":""), ((bDecBtPwr)? "ON":"OFF")));
-	pCoexDm->bCurDecBtPwr = bDecBtPwr;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreDecBtPwr == pCoexDm->bCurDecBtPwr) 
-			return;
-	}
-	halbtc8723a2ant_SetFwDecBtPwr(pBtCoexist, pCoexDm->bCurDecBtPwr);
-
-	pCoexDm->bPreDecBtPwr = pCoexDm->bCurDecBtPwr;
-}
-
-VOID
-halbtc8723a2ant_FwDacSwingLvl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			fwDacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set FW Dac Swing level = %d\n",  
-		(bForceExec? "force to":""), fwDacSwingLvl));
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preFwDacSwingLvl == pCoexDm->curFwDacSwingLvl) 
-			return;
-	}
-
-	halbtc8723a2ant_SetFwDacSwingLevel(pBtCoexist, pCoexDm->curFwDacSwingLvl);
-
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-}
-
-VOID
-halbtc8723a2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xf0ff7);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8723a2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8723a2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8723a2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte	tmpU1;
-
-	tmpU1 = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd);
-	tmpU1 |= BIT0;
-	if(bLowPenaltyRa)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set low penalty!!\n"));
-		tmpU1 &= ~BIT2;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set normal!!\n"));
-		tmpU1 |= BIT2;
-	}
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, tmpU1);
-}
-
-VOID
-halbtc8723a2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	return;
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8723a2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8723a2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	if(bSwDacSwingOn)
-	{
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xff000000, swDacSwingLvl);
-	}
-	else
-	{
-		pBtCoexist->fBtcSetBbReg(pBtCoexist, 0x880, 0xff000000, 0xc0);
-	}
-}
-
-
-VOID
-halbtc8723a2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8723a2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8723a2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc04,0x3a07611);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc04,0x3a05611);
-	}
-}
-
-VOID
-halbtc8723a2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8723a2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8723a2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4e1c0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4d1d0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4c1e0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4b1f0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x4a200001);
-		
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xdc000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x90000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x51000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x12000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1a, 0xfffff, 0x00355);
-		
-		rssiAdjustVal = 6;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x641c0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x631d0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x621e0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x611f0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78,0x60200001);
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x32000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0x71000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xb0000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x12, 0xfffff, 0xfc000);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1a, 0xfffff, 0x30355);
-	}
-
-	// set rssiAdjustVal for wifi module.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-
-VOID
-halbtc8723a2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8723a2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8723a2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8723a2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8723a2ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8723a2ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x25=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x25, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8723a2ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8723a2ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8723a2ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-
-	H2C_Parameter[0] = byte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = byte5;
-
-	pCoexDm->psTdmaPara[0] = byte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = byte5;
-	
-	RT_TRACE(COMP_COEX, DBG_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]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x3a, 5, H2C_Parameter);
-}
-
-VOID
-halbtc8723a2ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	u4Byte	btTxRxCnt=0;
-
-	btTxRxCnt = pCoexSta->highPriorityTx+pCoexSta->highPriorityRx+
-				pCoexSta->lowPriorityTx+pCoexSta->lowPriorityRx;
-
-	if(btTxRxCnt > 3000)
-	{		
-		pCoexDm->bCurPsTdmaOn = TRUE;
-		pCoexDm->curPsTdma = 8;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], turn ON PS TDMA, type=%d for BT tx/rx counters=%d(>3000)\n", 
-			pCoexDm->curPsTdma, btTxRxCnt));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-			(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));		
-		pCoexDm->bCurPsTdmaOn = bTurnOn;
-		pCoexDm->curPsTdma = type;
-	}
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-	if(pCoexDm->bCurPsTdmaOn)
-	{
-		switch(pCoexDm->curPsTdma)
-		{
-			case 1:
-			default:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x98);
-				break;
-			case 2:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x98);
-				break;
-			case 3:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0xe1, 0x98);
-				break;
-			case 4:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x5, 0x5, 0xe1, 0x80);
-				break;
-			case 5:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x98);
-				break;
-			case 6:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x98);
-				break;
-			case 7:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0x60, 0x98);
-				break;
-			case 8: 
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x5, 0x5, 0x60, 0x80);
-				break;
-			case 9: 
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x98);
-				break;
-			case 10:	
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x98);
-				break;
-			case 11:	
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0xe1, 0x98);
-				break;
-			case 12:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x98);
-				break;
-			case 13:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x98);
-				break;
-			case 14:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x98);
-				break;
-			case 15:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0x60, 0x98);
-				break;
-			case 16:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0x60, 0x98);
-				break;
-			case 17:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x2f, 0x2f, 0x60, 0x80);
-				break;
-			case 18:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x98);
-				break;			
-			case 19:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0xe1, 0x98);
-				break;
-			case 20:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0x60, 0x98);
-				break;
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(pCoexDm->curPsTdma)
-		{
-			case 0:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x8, 0x0);
-				break;
-			case 1:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				break;
-			default:
-				halbtc8723a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x8, 0x0);
-				break;
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-
-VOID
-halbtc8723a2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-	halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-	halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-	halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	// sw all off
-	halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-
-	// hw all off
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-}
-
-VOID
-halbtc8723a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// force to reset coex mechanism
-	halbtc8723a2ant_CoexTable(pBtCoexist, FORCE_EXEC, 0x55555555, 0xffff, 0x3);
-	halbtc8723a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-	halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 0x20);
-	halbtc8723a2ant_DecBtPwr(pBtCoexist, FORCE_EXEC, FALSE);
-	halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-
-	halbtc8723a2ant_AgcTable(pBtCoexist, FORCE_EXEC, FALSE);
-	halbtc8723a2ant_AdcBackOff(pBtCoexist, FORCE_EXEC, FALSE);
-	halbtc8723a2ant_LowPenaltyRa(pBtCoexist, FORCE_EXEC, FALSE);
-	halbtc8723a2ant_RfShrink(pBtCoexist, FORCE_EXEC, FALSE);
-	halbtc8723a2ant_DacSwing(pBtCoexist, FORCE_EXEC, FALSE, 0xc0);
-}
-
-VOID
-halbtc8723a2ant_BtInquiryPage(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN	bLowPwrDisable=TRUE;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-	halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-}
-
-VOID
-halbtc8723a2ant_BtEnableAction(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bWifiConnected=FALSE;
-	
-	// Here we need to resend some wifi info to BT
-	// because bt is reset and loss of the info.						
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	if(bWifiConnected)
-	{
-		halbtc8723a2ant_IndicateWifiChnlBwInfo(pBtCoexist, BTC_MEDIA_CONNECT);
-	}
-	else
-	{
-		halbtc8723a2ant_IndicateWifiChnlBwInfo(pBtCoexist, BTC_MEDIA_DISCONNECT);
-	}
-
-	halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-}
-
-VOID
-halbtc8723a2ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8723a2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-			halbtc8723a2ant_BtEnableAction(pBtCoexist);
-		}
-	}
-}
-
-BOOLEAN
-halbtc8723a2ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE;
-	BOOLEAN			bLowPwrDisable=FALSE;
-
-	if(!pStackInfo->bBtLinkExist)
-	{
-		bLowPwrDisable = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-	}
-	else
-	{
-		bLowPwrDisable = TRUE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	if(halbtc8723a2ant_IsWifiIdle(pBtCoexist) && 
-		BT_8723A_2ANT_BT_STATUS_IDLE == pCoexDm->btStatus)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi idle + Bt idle!!\n"));
-			
-		halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-		halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-
-		bCommon = TRUE;
-	}
-	else if(!halbtc8723a2ant_IsWifiIdle(pBtCoexist) && 
-			(BT_8723A_2ANT_BT_STATUS_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-idle + BT idle!!\n"));
-
-		halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-		halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-
-		bCommon = TRUE;
-	}
-	else if(halbtc8723a2ant_IsWifiIdle(pBtCoexist) && 
-		(BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi idle + Bt connected idle!!\n"));
-		
-		halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-		halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-
-		bCommon = TRUE;
-	}
-	else if(!halbtc8723a2ant_IsWifiIdle(pBtCoexist) && 
-		(BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-idle + Bt connected idle!!\n"));
-
-		halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-		halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-
-		bCommon = TRUE;
-	}
-	else if(halbtc8723a2ant_IsWifiIdle(pBtCoexist) && 
-			(BT_8723A_2ANT_BT_STATUS_NON_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi idle + BT non-idle!!\n"));
-		
-		halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-		halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		
-		bCommon = TRUE;
-	}
-	else if(halbtc8723a2ant_IsWifiConnectedIdle(pBtCoexist) && 
-			(BT_8723A_2ANT_BT_STATUS_NON_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected-idle + BT non-idle!!\n"));
-
-		halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-		halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-		halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		
-		bCommon = TRUE;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-idle + BT non-idle!!\n"));
-		halbtc8723a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x20);
-		
-		bCommon = FALSE;
-	}
-	
-	return bCommon;
-}
-VOID
-halbtc8723a2ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bScoHid,
-	IN	BOOLEAN			bTxPause,
-	IN	u1Byte			maxInterval
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-	if(pCoexDm->bResetTdmaAdjust)
-	{
-		pCoexDm->bResetTdmaAdjust = FALSE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-		{
-			if(bScoHid)
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;	
-					}
-					else
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-			else
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->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 = pCoexSta->btRetryCnt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-		if(maxInterval == 1)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-					pCoexDm->psTdmaDuAdjType = 13;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				
-				if(result == -1)
-				{					
-					if(pCoexDm->curPsTdma == 5)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;
-					}
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-					pCoexDm->psTdmaDuAdjType = 1;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-					pCoexDm->psTdmaDuAdjType = 9;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 2)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 3)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-		if( !bScan && !bLink && !bRoam)
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-}
-
-// SCO only or SCO+PAN(HS)
-VOID
-halbtc8723a2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, wifiRssiState1;
-	u4Byte	wifiBw;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-		}
-
-		// sw mechanism		
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}		
-	}
-}
-
-
-VOID
-halbtc8723a2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, wifiRssiState1;
-	u4Byte	wifiBw;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		}
-
-		// sw mechanism
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}		
-	}
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8723a2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp rate, 1:basic /0:edr
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-			}
-			else
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp rate, 1:basic /0:edr
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-			}
-			else
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-			}
-		}
-
-		// sw mechanism		
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp rate, 1:basic /0:edr
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-			}
-			else
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp rate, 1:basic /0:edr
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-			}
-			else
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-			}
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}		
-	}
-}
-
-VOID
-halbtc8723a2ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btInfoExt;
-	u4Byte		wifiBw;
-	
-	btInfoExt = pCoexSta->btInfoExt;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-			
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-		}
-
-		// sw mechanism
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-	}
-}
-
-
-//PAN(HS) only
-VOID
-halbtc8723a2ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState;
-	u4Byte		wifiBw;
-
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-		}
-		else
-		{
-			halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-		}
-		halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-
-		// sw mechanism		
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-		else
-		{
-			halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-	}
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8723a2ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-			}
-		}
-
-		// sw mechanism
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 47, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-			}
-		}
-
-		// sw mechanism
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-	}
-}
-
-VOID
-halbtc8723a2ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1;
-	u4Byte		wifiBw;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10); 
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14); 
-		}
-
-		// sw mechanism
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-		}
-		else
-		{
-			halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-	}
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8723a2ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-			
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-			}
-		}
-		
-		// sw mechanism
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-			}
-		}
-
-		// sw mechanism
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-	}
-}
-
-VOID
-halbtc8723a2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-
-	if(halbtc8723a2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8723a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	halbtc8723a2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0xffff, 0x3);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 37, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 1);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 1);
-			}
-		}
-		
-		// sw mechanism
-		halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-		halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-		halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-	}
-	else
-	{
-		wifiRssiState = halbtc8723a2ant_WifiRssiState(pBtCoexist, 0, 2, 27, 0);
-		wifiRssiState1 = halbtc8723a2ant_WifiRssiState(pBtCoexist, 1, 2, 47, 0);
-		
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 1);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8723a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 1);
-			}
-		}
-
-		// sw mechanism
-		if( (wifiRssiState1 == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState1 == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, TRUE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-		else
-		{
-			halbtc8723a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, FALSE);
-			halbtc8723a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, FALSE, 0xc0);
-		}
-	}
-}
-
-VOID
-halbtc8723a2ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	u1Byte				btInfoOriginal=0, btRetryCnt=0;
-	u1Byte				algorithm=0;
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Manual control!!!\n"));
-		return;
-	}
-
-	if(pStackInfo->bProfileNotified)
-	{
-		if(pCoexSta->bHoldForStackOperation)
-		{
-			// if bt inquiry/page/pair, do not execute.
-			return;
-		}
-		
-		algorithm = halbtc8723a2ant_ActionAlgorithm(pBtCoexist);
-		if(pCoexSta->bHoldPeriodCnt && (BT_8723A_2ANT_COEX_ALGO_PANHS!=algorithm))
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex],Hold BT inquiry/page scan setting (cnt = %d)!!\n", 
-				pCoexSta->bHoldPeriodCnt));
-			if(pCoexSta->bHoldPeriodCnt >= 6)
-			{
-				pCoexSta->bHoldPeriodCnt = 0;
-				// next time the coexist parameters should be reset again.
-			}
-			else
-				pCoexSta->bHoldPeriodCnt++;
-			return;
-		}
-
-		pCoexDm->curAlgorithm = algorithm;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Algorithm = %d \n", pCoexDm->curAlgorithm));
-		if(halbtc8723a2ant_IsCommonAction(pBtCoexist))
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant common.\n"));
-			pCoexDm->bResetTdmaAdjust = TRUE;
-		}
-		else
-		{
-			if(pCoexDm->curAlgorithm != pCoexDm->preAlgorithm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 
-					pCoexDm->preAlgorithm, pCoexDm->curAlgorithm));
-				pCoexDm->bResetTdmaAdjust = TRUE;
-			}
-			switch(pCoexDm->curAlgorithm)
-			{
-				case BT_8723A_2ANT_COEX_ALGO_SCO:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO.\n"));
-					halbtc8723a2ant_ActionSco(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_HID:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID.\n"));
-					halbtc8723a2ant_ActionHid(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_A2DP:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP.\n"));
-					halbtc8723a2ant_ActionA2dp(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_PANEDR:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n"));
-					halbtc8723a2ant_ActionPanEdr(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_PANHS:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HS mode.\n"));
-					halbtc8723a2ant_ActionPanHs(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_PANEDR_A2DP:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n"));
-					halbtc8723a2ant_ActionPanEdrA2dp(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_PANEDR_HID:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-					halbtc8723a2ant_ActionPanEdrHid(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-					halbtc8723a2ant_ActionHidA2dpPanEdr(pBtCoexist);
-					break;
-				case BT_8723A_2ANT_COEX_ALGO_HID_A2DP:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n"));
-					halbtc8723a2ant_ActionHidA2dp(pBtCoexist);
-					break;
-				default:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n"));
-					halbtc8723a2ant_CoexAllOff(pBtCoexist);
-					break;
-			}
-			pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-		}
-	}
-}
-
-//============================================================
-// work around function start with wa_halbtc8723a2ant_
-//============================================================
-VOID
-wa_halbtc8723a2ant_MonitorC2h(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u1Byte	tmp1b=0x0;
-	u4Byte	curC2hTotalCnt=0x0;
-	static u4Byte	preC2hTotalCnt=0x0, sameCntPollingTime=0x0;
-
-	curC2hTotalCnt+=pCoexSta->btInfoC2hCnt[BT_INFO_SRC_8723A_2ANT_BT_RSP];
-
-	if(curC2hTotalCnt == preC2hTotalCnt)
-	{
-		sameCntPollingTime++;
-	}
-	else
-	{
-		preC2hTotalCnt = curC2hTotalCnt;
-		sameCntPollingTime = 0;
-	}
-
-	if(sameCntPollingTime >= 2)
-	{
-		tmp1b = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x1af);
-		if(tmp1b != 0x0)
-		{
-			pCoexSta->c2hHangDetectCnt++;
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x1af, 0x0);
-		}
-	}
-}
-
-//============================================================
-// extern function start with EXhalbtc8723a2ant_
-//============================================================
-VOID
-EXhalbtc8723a2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8723a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	u4Byte	u4Tmp=0;
-	u1Byte	u1Tmp=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	// backup rf 0x1e value
-	pCoexDm->btRf0x1eBackup = 
-		pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);
-
-	// Enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x3);
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x20);
-}
-
-VOID
-EXhalbtc8723a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8723a2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8723a2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-	
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "[Action Manual control]!!");
-		CL_PRINTF(cliBuf);
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8723A_2ANT_BT_STATUS_IDLE == pCoexDm->btStatus)? "idle":(  (BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy"))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-	
-	if(pStackInfo->bProfileNotified)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-			pStackInfo->bScoExist, pStackInfo->bHidExist, pStackInfo->bPanExist, pStackInfo->bA2dpExist);
-		CL_PRINTF(cliBuf);	
-
-		pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-	}
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8723A_2ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8723a2Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "write 0x1af=0x0 num", \
-		pCoexSta->c2hHangDetectCnt);
-	CL_PRINTF(cliBuf);
-	
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);	
-	
-	if(!pBtCoexist->bManualControl)
-	{
-		psTdmaCase = pCoexDm->curPsTdma;
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase);
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "DecBtPwr/ IgnWlanAct", \
-			pCoexDm->bCurDecBtPwr, pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-	}
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x783);
-	u1Tmp[2] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x796);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x778/ 0x783/ 0x796", \
-		u1Tmp[0], u1Tmp[1], u1Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x880);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x880", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x40", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x484);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x484(rate adaptive)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda8);
-	u4Tmp[3] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xdac);
-	CL_SPRINTF(cliBuf, 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]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770 (hp rx[31:16]/tx[15:0])", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(lp rx[31:16]/tx[15:0])", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8723a2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		halbtc8723a2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		//halbtc8723a2ant_InitCoexDm(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8723a2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8723a2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8723a2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8723a2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-
-	halbtc8723a2ant_IndicateWifiChnlBwInfo(pBtCoexist, type);
-}
-
-VOID
-EXhalbtc8723a2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8723a2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtBusy=FALSE, bLimitedDig=FALSE;
-	BOOLEAN			bWifiConnected=FALSE, bBtHsOn=FALSE;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-	
-	rspSource = BT_INFO_SRC_8723A_2ANT_BT_RSP;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 0)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(BT_INFO_SRC_8723A_2ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =
-			pCoexSta->btInfoC2h[rspSource][1];
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][2]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][3];
-	}
-		
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8723A_2ANT_B_INQ_PAGE)
-	{
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	}
-	else
-	{
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8723a2ant_StackOperationNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(BTC_STACK_OP_INQ_PAGE_PAIR_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], StackOP Inquiry/page/pair start notify\n"));
-		pCoexSta->bHoldForStackOperation = TRUE;
-		pCoexSta->bHoldPeriodCnt = 1;
-		halbtc8723a2ant_BtInquiryPage(pBtCoexist);
-	}
-	else if(BTC_STACK_OP_INQ_PAGE_PAIR_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], StackOP Inquiry/page/pair finish notify\n"));
-		pCoexSta->bHoldForStackOperation = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8723a2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8723a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	EXhalbtc8723a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8723a2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Periodical!!\n"));
-
-	// work around for c2h hang
-	wa_halbtc8723a2ant_MonitorC2h(pBtCoexist);
-	
-	halbtc8723a2ant_QueryBtInfo(pBtCoexist);
-	halbtc8723a2ant_MonitorBtCtr(pBtCoexist);
-	halbtc8723a2ant_MonitorBtEnableDisable(pBtCoexist);
-
-	halbtc8723a2ant_RunCoexistMechanism(pBtCoexist);
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a2Ant.h
deleted file mode 100644
index 3d0d9deebbc2..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723a2Ant.h
+++ /dev/null
@@ -1,185 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8723A 2Ant BT Co-exist definition
-//===========================================
-#define	BT_INFO_8723A_2ANT_B_FTP						BIT7
-#define	BT_INFO_8723A_2ANT_B_A2DP					BIT6
-#define	BT_INFO_8723A_2ANT_B_HID						BIT5
-#define	BT_INFO_8723A_2ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8723A_2ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8723A_2ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8723A_2ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8723A_2ANT_B_CONNECTION				BIT0
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT		2
-
-typedef enum _BT_INFO_SRC_8723A_2ANT{
-	BT_INFO_SRC_8723A_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723A_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8723A_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8723A_2ANT_MAX
-}BT_INFO_SRC_8723A_2ANT,*PBT_INFO_SRC_8723A_2ANT;
-
-typedef enum _BT_8723A_2ANT_BT_STATUS{
-	BT_8723A_2ANT_BT_STATUS_IDLE				= 0x0,
-	BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,
-	BT_8723A_2ANT_BT_STATUS_NON_IDLE			= 0x2,
-	BT_8723A_2ANT_BT_STATUS_MAX
-}BT_8723A_2ANT_BT_STATUS,*PBT_8723A_2ANT_BT_STATUS;
-
-typedef enum _BT_8723A_2ANT_COEX_ALGO{
-	BT_8723A_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8723A_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8723A_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8723A_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8723A_2ANT_COEX_ALGO_PANEDR			= 0x4,
-	BT_8723A_2ANT_COEX_ALGO_PANHS			= 0x5,
-	BT_8723A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x6,
-	BT_8723A_2ANT_COEX_ALGO_PANEDR_HID		= 0x7,
-	BT_8723A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x8,
-	BT_8723A_2ANT_COEX_ALGO_HID_A2DP			= 0x9,
-	BT_8723A_2ANT_COEX_ALGO_MAX
-}BT_8723A_2ANT_COEX_ALGO,*PBT_8723A_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8723A_2ANT{
-	// fw mechanism
-	BOOLEAN		bPreDecBtPwr;
-	BOOLEAN		bCurDecBtPwr;
-	//BOOLEAN		bPreBtLnaConstrain;
-	//BOOLEAN		bCurBtLnaConstrain;
-	//u1Byte		bPreBtPsdMode;
-	//u1Byte		bCurBtPsdMode;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bResetTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	//BOOLEAN		bPreBtAutoReport;
-	//BOOLEAN		bCurBtAutoReport;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-} COEX_DM_8723A_2ANT, *PCOEX_DM_8723A_2ANT;
-
-typedef struct _COEX_STA_8723A_2ANT{
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	u1Byte					preBtRssiState;
-	u1Byte					preBtRssiState1;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8723A_2ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8723A_2ANT_MAX];
-	BOOLEAN					bC2hBtInquiryPage;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	BOOLEAN					bHoldForStackOperation;
-	u1Byte					bHoldPeriodCnt;
-	// this is for c2h hang work-around
-	u4Byte					c2hHangDetectCnt;
-}COEX_STA_8723A_2ANT, *PCOEX_STA_8723A_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8723a2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8723a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723a2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723a2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723a2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723a2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723a2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723a2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8723a2ant_StackOperationNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723a2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b1Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b1Ant.c
deleted file mode 100644
index 0effd8656627..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b1Ant.c
+++ /dev/null
@@ -1,5639 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8723B Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8723b1Ant.tmh"
-#endif
-
-//#include <Math.h>
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8723B_1ANT		GLCoexDm8723b1Ant;
-static PCOEX_DM_8723B_1ANT 	pCoexDm=&GLCoexDm8723b1Ant;
-static COEX_STA_8723B_1ANT		GLCoexSta8723b1Ant;
-static PCOEX_STA_8723B_1ANT	pCoexSta=&GLCoexSta8723b1Ant;
-static PSDSCAN_STA_8723B_1ANT	GLPsdScan8723b1Ant;
-static PPSDSCAN_STA_8723B_1ANT pPsdScan = &GLPsdScan8723b1Ant;
-
-
-const char *const GLBtInfoSrc8723b1Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8723b1Ant=20150119;
-u4Byte	GLCoexVer8723b1Ant=0x58;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8723b1ant_
-//============================================================
-u1Byte
-halbtc8723b1ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8723b1ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8723b1ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-VOID
-halbtc8723b1ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-VOID
-halbtc8723b1ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-VOID
-halbtc8723b1ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8723b1ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType
-	)
-{
-	switch(raMaskType)
-	{
-		case 0:	// normal mode
-			halbtc8723b1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0);
-			break;
-		case 1:	// disable cck 1/2
-			halbtc8723b1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x00000003);
-			break;
-		case 2:	// disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4
-			halbtc8723b1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0001f1f7);
-			break;
-		default:
-			break;
-	}
-
-	halbtc8723b1ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8723b1ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8723b1ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-}
-
-VOID
-halbtc8723b1ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-VOID
-halbtc8723b1ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8723b1ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp, u4Tmp1;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp, u1Tmp1;
-	s4Byte			wifiRssi;
-	static u4Byte		NumOfBtCounterChk = 0;
-	
-       //to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS
-	//if (! (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e) & 0x8) ) 
-
-	if (pCoexSta->bUnderIps)
-	{
-		//pCoexSta->highPriorityTx = 65535;
-		//pCoexSta->highPriorityRx = 65535;
-		//pCoexSta->lowPriorityTx = 65535;
-		//pCoexSta->lowPriorityRx = 65535;
-		//return;
-	}
-		
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	if( (pCoexSta->lowPriorityTx > 1050)  && (!pCoexSta->bC2hBtInquiryPage))
-		pCoexSta->popEventCnt++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		regHPRx, regHPTx, regLPRx, regLPTx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-
-	// This part is for wifi FW and driver to update BT's status as disabled.
-	// The flow is as the following 
-	// 1. disable BT
-	// 2. if all BT Tx/Rx counter=0, after 6 sec we query bt info
-	// 3. Because BT will not rsp from mailbox, so wifi fw will know BT is disabled
-	// 4. FW will rsp c2h for BT that driver will know BT is disabled.
-	if ((regHPTx == 0) && (regHPRx ==0) && (regLPTx == 0) && (regLPRx == 0))
-	{
-		NumOfBtCounterChk++;
-		if (NumOfBtCounterChk == 3)
-{
-			halbtc8723b1ant_QueryBtInfo(pBtCoexist);
-		}
-	}
-	else
-	{
-			NumOfBtCounterChk = 0;
-		}
-	}
-
-
-VOID
-halbtc8723b1ant_MonitorWiFiCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u2Byte 	u2Tmp[3];
-	s4Byte	wifiRssi=0;
-	BOOLEAN bWifiBusy = FALSE, bWifiUnderBMode = FALSE;
-	static u1Byte nCCKLockCounter = 0;
-	u4Byte	TotalCnt;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->nCRCOK_CCK = 0;
-		pCoexSta->nCRCOK_11g = 0;
-		pCoexSta->nCRCOK_11n = 0;
-		pCoexSta->nCRCOK_11nAgg = 0;
-
-		pCoexSta->nCRCErr_CCK = 0;
-		pCoexSta->nCRCErr_11g = 0;
-		pCoexSta->nCRCErr_11n = 0;
-		pCoexSta->nCRCErr_11nAgg = 0;	
-	}
-	else
-	{
-		pCoexSta->nCRCOK_CCK	= pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf88);
-		pCoexSta->nCRCOK_11g 	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf94);
-		pCoexSta->nCRCOK_11n	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf90);
-		pCoexSta->nCRCOK_11nAgg= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfb8);
-
-		pCoexSta->nCRCErr_CCK 	 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf84);
-		pCoexSta->nCRCErr_11g 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf96);
-		pCoexSta->nCRCErr_11n 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf92);
-		pCoexSta->nCRCErr_11nAgg = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfba);		
-	}
-
-
-	//reset counter
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x0);
-
-	if ( (bWifiBusy) && (wifiRssi >= 30) && (!bWifiUnderBMode))
-	{
-		TotalCnt = pCoexSta->nCRCOK_CCK + pCoexSta->nCRCOK_11g + pCoexSta->nCRCOK_11n + 
-				pCoexSta->nCRCOK_11nAgg;
-	
-		if ( (pCoexDm->btStatus == BT_8723B_1ANT_BT_STATUS_ACL_BUSY) ||
-			(pCoexDm->btStatus == BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-			(pCoexDm->btStatus == BT_8723B_1ANT_BT_STATUS_SCO_BUSY) )
-		{
-			if (pCoexSta->nCRCOK_CCK >(TotalCnt -pCoexSta->nCRCOK_CCK)) 
-			{
-				if (nCCKLockCounter < 3)
-				 nCCKLockCounter++;
-			}
-			else
-			{
-				if (nCCKLockCounter > 0)
-				 nCCKLockCounter--;
-			}
-
-		}
-		else
-		{
-			if (nCCKLockCounter > 0)
-			  nCCKLockCounter--;
-		}
-	}
-	else
-	{
-		if (nCCKLockCounter > 0)
-			nCCKLockCounter--;
-	}
-
-	if (!pCoexSta->bPreCCKLock)
-	{
-
-		if (nCCKLockCounter >= 3)
-		 pCoexSta->bCCKLock = TRUE;
-		else
-		 pCoexSta->bCCKLock = FALSE;			
-	}
-	else
-	{
-		if (nCCKLockCounter == 0)
-		 pCoexSta->bCCKLock = FALSE;
-		else
-		 pCoexSta->bCCKLock = TRUE;		
-	}
-
-	if  (pCoexSta->bCCKLock)
-		pCoexSta->bCCKEverLock = TRUE;
-	
-	pCoexSta->bPreCCKLock =  pCoexSta->bCCKLock;	
-		
-
-}
-
-BOOLEAN
-halbtc8723b1ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN bWifiConnected=FALSE;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-
-	     
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8723b1ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-	pBtLinkInfo->bBtHiPriLinkExist = pCoexSta->bBtHiPriLinkExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8723b1ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8723B_1ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO only\n"));
-			algorithm = BT_8723B_1ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID only\n"));
-				algorithm = BT_8723B_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP only\n"));
-				algorithm = BT_8723B_1ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(HS) only\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(EDR) only\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID\n"));
-				algorithm = BT_8723B_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8723B_1ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(HS)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(EDR)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP\n"));
-				algorithm = BT_8723B_1ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(HS)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(EDR)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(HS)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(EDR)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8723B_1ANT_COEX_ALGO_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8723B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8723b1ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8723b1ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8723b1ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8723b1ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!") ));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8723b1ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8723b1ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8723b1ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8723b1ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8723b1ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8723b1ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	PBTC_BOARD_INFO	pBoardInfo=&pBtCoexist->boardInfo;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE	
-	if (pBoardInfo->btdmAntNumByAntDet == 2)
-	{
-		if (type == 3)
-			type = 14;
-		else if (type == 4)
-			type  = 13;
-		else if (type == 5)
-			type = 8;
-	}
-#endif
-#endif
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], ********** CoexTable(%d) **********\n", type));
-	
-	pCoexSta->nCoexTableType = type;
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 4:
-			if  ( pCoexSta->bCCKEverLock) 
-				halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-			else
-				halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaa5a5a, 0xffffff, 0x3);
-			break;
-		case 5:
-			if  ( pCoexSta->bCCKEverLock) 
-				halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0xaaaa5a5a, 0xaaaa5a5a, 0xffffff, 0x3);
-			else
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 7:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 8:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 9:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 10:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 11:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 12:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 13:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 14:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 15:
-			halbtc8723b1ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;	
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8723b1ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8723b1ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8723b1ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8723b1ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8723b1ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8723b1ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8723b1ant_SwMechanism(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN 		bLowPenaltyRA
-	) 
-{
-	halbtc8723b1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8723b1ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	PBTC_BOARD_INFO pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte			fwVer=0, u4Tmp=0, cntBtCalChk=0;
-	BOOLEAN			bPgExtSwitch=FALSE;
-	BOOLEAN			bUseExtSwitch=FALSE;
-	BOOLEAN			bIsInMpMode = FALSE;
-	u1Byte			H2C_Parameter[2] ={0}, u1Tmp = 0;
-
-	pCoexDm->curAntPosType = antPosType;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_EXT_SWITCH, &bPgExtSwitch);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);	// [31:16]=fw ver, [15:0]=fw sub ver
-
-	if((fwVer>0 && fwVer<0xc0000) || bPgExtSwitch)
-		bUseExtSwitch = TRUE;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE
-		if (antPosType == BTC_ANT_PATH_PTA)
-		{
-			if ((pBoardInfo->btdmAntDetFinish) && (pBoardInfo->btdmAntNumByAntDet == 2))
-			{
-				if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-					antPosType = BTC_ANT_PATH_WIFI;
-				else
-					antPosType = BTC_ANT_PATH_BT;
-			}
-		}
-#endif		
-#endif
-
-	if(bInitHwCfg)
-	{
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780); //WiFi TRx Mask on
-		//remove due to interrupt is disabled that polling c2h will fail and delay 100ms.
-		//pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15); //BT TRx Mask on
-
-		if(fwVer >= 0x180000)
-		{
-		/* Use H2C to set GNT_BT to HIGH */
-		H2C_Parameter[0] = 1;
-		pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-		}
-		else
-		{
-			// set grant_bt to high
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18); 
-		}
-		//set wlan_act control by PTA
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4); 
-
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x0); //BT select s0/s1 is controlled by BT
-
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x39, 0x8, 0x1);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x974, 0xff);
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x944, 0x3, 0x3);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x930, 0x77);
-	}
-	else if(bWifiOff)
-	{
-		if(fwVer >= 0x180000)
-		{
-		/* Use H2C to set GNT_BT to HIGH */
-		H2C_Parameter[0] = 1;
-		pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-		}
-		else
-		{
-			// set grant_bt to high
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18); 
-		}
-		//set wlan_act to always low
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-		
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_IS_IN_MP_MODE, &bIsInMpMode);
-		if(!bIsInMpMode)	
-			pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x0); //BT select s0/s1 is controlled by BT
-		else
-			pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x1); //BT select s0/s1 is controlled by WiFi
-	
-		// 0x4c[24:23]=00, Set Antenna control by BT_RFE_CTRL	BT Vendor 0xac=0xf002
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp &= ~BIT23;
-		u4Tmp &= ~BIT24;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-	}
-	else
-	{			
-		/* Use H2C to set GNT_BT to LOW */
-		if(fwVer >= 0x180000)
-		{
-		if (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765) != 0)
-		{		
-			H2C_Parameter[0] = 0;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-		}
-		}
-		else
-		{
-			// BT calibration check
-			while(cntBtCalChk <= 20)
-			{
-				u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x49d);
-				cntBtCalChk++;
-				if(u1Tmp & BIT0)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n", cntBtCalChk));
-					delay_ms(50);
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** BT is NOT calibrating (wait cnt=%d)**********\n", cntBtCalChk));
-					break;
-				}
-			}
-
-			// set grant_bt to PTA
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x0);
-		}
-
-		if (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e) != 0xc)
-		{
-			//set wlan_act control by PTA
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc); 
-		}
-
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x1); //BT select s0/s1 is controlled by WiFi
-	}
-	
-	if(bUseExtSwitch)
-	{
-		if(bInitHwCfg)
-		{
-			// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-			u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-			u4Tmp &=~BIT23;
-			u4Tmp |= BIT24;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0); // fixed internal switch S1->WiFi, S0->BT
-
-			if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-			{
-				//tell firmware "no antenna inverse"
-				H2C_Parameter[0] = 0;
-				H2C_Parameter[1] = 1;  //ext switch type
-				pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);	
-			}
-			else
-			{
-				//tell firmware "antenna inverse"
-				H2C_Parameter[0] = 1;
-				H2C_Parameter[1] = 1;  //ext switch type
-				pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);	
-			}
-		}
-		
-		if(bForceExec || (pCoexDm->curAntPosType != pCoexDm->preAntPosType))
-		{
-			// ext switch setting
-			switch(antPosType)
-			{
-				case BTC_ANT_PATH_WIFI:
-					if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-						pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x1);
-					else
-						pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x2);
-					break;
-				case BTC_ANT_PATH_BT:
-					if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-						pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x2);
-					else					
-						pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x1);
-					break;
-				default:
-				case BTC_ANT_PATH_PTA:
-					if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-						pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x1);
-					else
-						pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x2);
-					break;
-			}
-		}
-	}
-	else
-	{
-		if(bInitHwCfg)
-		{
-			// 0x4c[23]=1, 0x4c[24]=0  Antenna control by 0x64
-			u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-			u4Tmp |= BIT23;
-			u4Tmp &=~BIT24;	      
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-
-			//Fix Ext switch Main->S1, Aux->S0
-			pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x64, 0x1, 0x0); 
-
-			if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-			{
-	
-				//tell firmware "no antenna inverse"
-				H2C_Parameter[0] = 0;
-				H2C_Parameter[1] = 0;  //internal switch type
-				pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);	
-			}
-			else
-			{
-		
-				//tell firmware "antenna inverse"
-				H2C_Parameter[0] = 1;
-				H2C_Parameter[1] = 0;  //internal switch type
-				pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);	
-			}
-		}
-	
-		if(bForceExec || (pCoexDm->curAntPosType != pCoexDm->preAntPosType))
-		{
-			// internal switch setting
-			switch(antPosType)
-			{
-				case BTC_ANT_PATH_WIFI:
-					if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-						pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-					else
-						pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x280);
-					break;
-				case BTC_ANT_PATH_BT:
-					if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
- 						pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x280);
-					else
-						pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-					break;
-				default:
-				case BTC_ANT_PATH_PTA:
-					if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-						pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x200);					
-					else
-						pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x80);
-					break;
-			}
-		}
-	}
-
-	pCoexDm->preAntPosType = pCoexDm->curAntPosType;
-}
-
-VOID
-halbtc8723b1ant_SetAntPathDCut(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bAntennaAux,	//For 1-Ant--> 1: Antenna at S0, 0: Antenna at S1. Set 0 for 2-Ant
-	IN	BOOLEAN				bExtSwitch,		// 1: Ext Switch (SPDT) exist on module, 0: no Ext Switch (SPDT) exist on module
-	IN	BOOLEAN				bTwoAntenna,	// 1: 2-Antenna, 0:1-Antenna
-	IN	u1Byte				antennaPos,		//Set Antenna Pos, For 1-Ant: BTC_ANT_PATH_WIFI, BTC_ANT_PATH_BT, BTC_ANT_PATH_PTA, For 2-Ant:BTC_ANT_WIFI_AT_MAIN, BTC_ANT_WIFI_AT_Aux
-	IN	u1Byte				wifiState		//BTC_WIFI_STAT_INIT, BTC_WIFI_STAT_IQK, BTC_WIFI_STAT_NORMAL_OFF, BTC_WIFI_STAT_MP_OFF, BTC_WIFI_STAT_NORMAL, BTC_WIFI_STAT_ANT_DIV
-	)
-{
-	u1Byte	dataLen=5;
-	u1Byte	buf[6] = {0};
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set BT Ant, bAntennaAux/bExtSwitch/bTwoAntenna/antennaPos/wifiState=%d/%d/%d/%d/%d\n",
-		bAntennaAux, bExtSwitch, bTwoAntenna, antennaPos, wifiState));
-
-	buf[0] = dataLen; 
-	
-	if(bAntennaAux)
-		buf[1] = 0x1;
-	
-	if(bExtSwitch)
-		buf[2] = 0x1;			
-	
-	if(bTwoAntenna)
-		buf[3] = 0x1;
-
-	buf[4] = antennaPos;
-
-	buf[5] = wifiState;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_8723B_ANT, (PVOID)&buf[0]);	
-}
-
-VOID
-halbtc8723b1ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		if(byte1&BIT4 && !(byte1&BIT5))
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-			realByte1 &= ~BIT4;
-			realByte1 |= BIT5;
-
-			realByte5 |= BIT5;
-			realByte5 &= ~BIT6;
-		}
-	}
-
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-
-VOID
-halbtc8723b1ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	PBTC_BOARD_INFO	pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bTurnOnByCnt=FALSE, bWifiBusy=FALSE, bWiFiNoisy=FALSE;
-	u1Byte			psTdmaTypeByCnt=0, rssiAdjustVal=0;
-	u1Byte			psTdmaByte4Val = 0x50, psTdmaByte0Val = 0x51, psTdmaByte3Val =  0x10;
-	s1Byte			nWiFiDurationAdjust = 0x0;
-	static BOOLEAN	 bPreWifiBusy=FALSE;
-
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE
-	if (pBoardInfo->btdmAntNumByAntDet == 2)
-	{
-		if (bTurnOn)
-			type = type +100;  //for WiFi RSSI low or BT RSSI low
-		else
-			type = 1; //always translate to TDMA(off,1) for TDMA-off case
-	}
-	
-#endif	
-#endif
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);	
-
-	if (bWifiBusy != bPreWifiBusy)
-	{
-		bForceExec = TRUE;	
-		bPreWifiBusy = bWifiBusy;
-	}
-
-	if (pCoexDm->bCurPsTdmaOn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-				pCoexDm->curPsTdma));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(off, %d) **********\n", 
-				pCoexDm->curPsTdma));
-	}
-			
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}
-
-	if (pCoexSta->nScanAPNum <= 5)
-	{
-		nWiFiDurationAdjust = 5;
-		
-		if (pCoexSta->nA2DPBitPool >= 35)
-		  nWiFiDurationAdjust = -10;
-		else if (pCoexSta->nA2DPBitPool >= 45)
-		  nWiFiDurationAdjust = -15;	
-	}
-	else if  (pCoexSta->nScanAPNum >= 40)
-	{
-		nWiFiDurationAdjust = -15;	
-
-		if (pCoexSta->nA2DPBitPool < 35)
-		  nWiFiDurationAdjust = -5;
-		else if (pCoexSta->nA2DPBitPool < 45)
-		  nWiFiDurationAdjust = -10; 
-	}
-	else if  (pCoexSta->nScanAPNum >= 20)
-	{
-		nWiFiDurationAdjust = -10;	
-	
-		if (pCoexSta->nA2DPBitPool >= 45)
-		  nWiFiDurationAdjust = -15;
-	}	
-	else
-	{
-		nWiFiDurationAdjust = 0;	       
-		
-		if (pCoexSta->nA2DPBitPool >= 35)
-		  nWiFiDurationAdjust = -10;
-		else if (pCoexSta->nA2DPBitPool >= 45)
-		  nWiFiDurationAdjust = -15;	
-	}
-	
-	if ((type == 1) || (type == 2) || (type == 9) || (type == 11) || (type == 101)
-		|| (type == 102) || (type == 109) || (type == 101))
-	{
-		if (!pCoexSta->bForceLpsOn)  //Native power save TDMA, only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30
-	{
-		psTdmaByte0Val = 0x61;  //no null-pkt
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle, no dynamic slot
-	}
-		else
-		{
-			psTdmaByte0Val = 0x51;  //null-pkt
-			psTdmaByte3Val = 0x10; //tx-pause at BT-slot
-			psTdmaByte4Val = 0x50; // 0x778 = d/1 toggle, dynamic slot
-		}
-	}
-	else if ((type == 3) || (type == 13) || (type == 14) || (type == 103) || (type == 113) || (type == 114))
-	{
-		psTdmaByte0Val = 0x51;  //null-pkt
-		psTdmaByte3Val = 0x10; //tx-pause at BT-slot
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle, no dynamic slot
-#if 0	
-		if (!bWifiBusy)
-			psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-#endif		
-	}
-	else  //native power save case
-	{
-		psTdmaByte0Val = 0x61;  //no null-pkt
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-		psTdmaByte4Val = 0x11; // 0x778 = d/1 toggle, no dynamic slot
-		//psTdmaByte4Va is not defne for 0x778 = d/1, 1/1 case 
-		}
-		 
-	//if (pBtLinkInfo->bSlaveRole == TRUE)
-	if ((pBtLinkInfo->bSlaveRole == TRUE)	&& (pBtLinkInfo->bA2dpExist))
-		psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-		
-	if (type > 100)
-	{
-		psTdmaByte0Val = psTdmaByte0Val | 0x82; //set antenna control by SW	
-		psTdmaByte3Val = psTdmaByte3Val | 0x60;  //set antenna no toggle, control by antenna diversity
-	}
-
-		
-	if(bTurnOn)
-	{	 
-		switch(type)
-		{
-			default:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1a, 0x1a, 0x0, psTdmaByte4Val);
-				break;
-			case 1:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);								
-				break;
-			case 2:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x2d+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);							
-				break;
-			case 3:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 4:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x14, 0x0);
-				break;
-			case 5:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x15, 0x3, psTdmaByte3Val, 0x11);
-				break;
-			case 6:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x20, 0x3, psTdmaByte3Val, 0x11);
-				break;
-			case 7:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x13, 0xc, 0x5, 0x0, 0x0);
-				break;
-			case 8:	
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;
-			case 9:	
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;
-			case 10:	
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0xa, 0x0, 0x40);
-				break;
-			case 11:	
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x03, psTdmaByte3Val, psTdmaByte4Val);			
-				break;
-			case 12:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x0a, 0x0a, 0x0, 0x50);
-				break;
-			case 13:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 14:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;
-			case 15:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0x3, 0x8, 0x0);
-				break;
-			case 16:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x10, 0x0);
-				break;
-			case 18:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;			
-			case 20:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3f, 0x03, psTdmaByte3Val, 0x10);
-				break;
-			case 21:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x11);
-				break;
-			case 22:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, 0x10);
-				break;
-			case 23:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x18);
-				break;
-			case 24:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x3, 0x31, 0x18);
-				break;
-			case 25:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 26:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 27:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x98);
-				break;
-			case 28:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x69, 0x25, 0x3, 0x31, 0x0);
-				break;
-			case 29:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xab, 0x1a, 0x1a, 0x1, 0x10);
-				break;
-			case 30:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x30, 0x3, 0x10, 0x10);
-				break;
-			case 31:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1a, 0x1a, 0, 0x58);
-				break;
-			case 32:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x35, 0x3, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 33:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x35, 0x3, psTdmaByte3Val, 0x10);
-				break;
-			case 34:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x53, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 35:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x63, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 36:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x12, 0x3, 0x14, 0x50);
-				break;
-			case 40: // SoftAP only with no sta associated,BT disable ,TDMA mode for power saving
-				/* here softap mode screen off will cost 70-80mA for phone */
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x23, 0x18, 0x00, 0x10, 0x24);
-				break;	
-				
-			//for 1-Ant translate to 2-Ant	
-			case 101:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);								
-				break;
-			case 102:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x2d+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);							
-				break;
-			case 103:
-				//halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1d, 0x1d, 0x0, psTdmaByte4Val);
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 105:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x15, 0x3, psTdmaByte3Val, 0x11);
-				break;
-			case 106:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x20, 0x3, psTdmaByte3Val, 0x11);
-				break;	
-			case 109:	
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;			
-			case 111:	
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x03, psTdmaByte3Val, psTdmaByte4Val);			
-				break;	
-			case 113:
-				//halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x51, 0x12, 0x12, 0x0, psTdmaByte4Val);
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);
-				break;
-			case 114:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;	
-			case 120:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3f, 0x03, psTdmaByte3Val, 0x10);
-				break;			
-			case 122:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, 0x10);
-				break;
-			case 132:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, psTdmaByte4Val);
-				break;	
-			case 133:
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x25, 0x03, psTdmaByte3Val, 0x11);
-				break;		
-				
-		}
-	}
-	else
-	{		
-
-		// disable PS tdma
-		switch(type)
-		{
-			case 8: //PTA Control
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-				break;
-			case 0:
-			default:  //Software control, Antenna at BT side
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				break;
-			case 1: // 2-Ant, 0x778=3, antenna control by antenna diversity
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x48, 0x0);
-				break;
-#if 0
-			case 9:   //Software control, Antenna at WiFi side
-				halbtc8723b1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				//halbtc8723b1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_WIFI, BTC_WIFI_STAT_NORMAL);
-				halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_WIFI, FALSE, FALSE);
-				break;			
-#endif
-		}
-	}
-	rssiAdjustVal =0;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssiAdjustVal);
-
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-		pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948),   pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765), pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67)));
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-BOOLEAN
-halbtc8723b1ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected && 
-		BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n"));
-		
- 		//halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-
-		//halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT connected-idle!!\n"));
-
-		//halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-
-		//halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE != pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT Busy!!\n"));
-
-		//halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-		
-		bCommon = TRUE;
-	}
-	else
-	{
-		if (bWifiBusy)			
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-		}
-		
-		bCommon = FALSE;
-	}
-	
-	return bCommon;
-}
-
-
-VOID
-halbtc8723b1ant_TdmaDurationAdjustForAcl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0, btInfoExt;
-	static BOOLEAN	bPreWifiBusy=FALSE;
-	BOOLEAN			bWifiBusy = FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjustForAcl()\n"));
-
-	if(BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY == wifiStatus) 
-		bWifiBusy = TRUE;
-	else
-		bWifiBusy = FALSE;	 	
-
-	if( (BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN == wifiStatus) ||
-		(BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifiStatus) ||
-		(BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT == wifiStatus) )
-	{
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 3 &&
-			pCoexDm->curPsTdma != 9 )
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-			pCoexDm->psTdmaDuAdjType = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n= 3;
-			result = 0;
-			WaitCount = 0;
-		}		
-		return;
-	}
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-		pCoexDm->psTdmaDuAdjType = 2;
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-		retryCount = pCoexSta->btRetryCnt;
-		btInfoExt = pCoexSta->btInfoExt;
-
-		if ( (pCoexSta->lowPriorityTx) > 1050 ||  (pCoexSta->lowPriorityRx) > 1250 )
-			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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		if(result == -1)
-		{
-/*			if( (BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else */ if(pCoexDm->curPsTdma == 1)
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-				pCoexDm->psTdmaDuAdjType = 11;
-			}
-		}
-		else if(result == 1)
-		{
-/*			if( (BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else */ if(pCoexDm->curPsTdma == 11)
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-				pCoexDm->psTdmaDuAdjType = 1;
-			}
-		}
-		else	  //no change
-		{
-			/* Bryant Modify	
-			if(bWifiBusy != bPreWifiBusy)  //if busy / idle change
-			{
-				bPreWifiBusy = bWifiBusy;
-				halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, pCoexDm->curPsTdma);
-			}
-			*/
-		
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-				pCoexDm->curPsTdma));
-		}
-
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 9 &&
-			pCoexDm->curPsTdma != 11 )
-		{
-			// recover to previous adjust type
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-	}
-}
-
-VOID
-halbtc8723b1ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8723b1ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8723b1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8723b1ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.			
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8723b1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8723b1ant_ActionWifiOnly(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-	halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-}
-
-VOID
-halbtc8723b1ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte		btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n",  btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n",  (bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-
-		bPreBtDisabled = bBtDisabled;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		if(bBtDisabled)
-		{
-			halbtc8723b1ant_ActionWifiOnly(pBtCoexist);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		}
-	}
-}
-
-//=============================================
-//
-//	Software Coex Mechanism start
-//
-//=============================================
-
-// SCO only or SCO+PAN(HS)
-
-/*
-VOID
-halbtc8723b1ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-
-VOID
-halbtc8723b1ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8723b1ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8723b1ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8723b1ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(HS) only
-VOID
-halbtc8723b1ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8723b1ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8723b1ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8723b1ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-VOID
-halbtc8723b1ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-*/
-
-//=============================================
-//
-//	Non-Software Coex Mechanism start
-//
-//=============================================
-VOID
-halbtc8723b1ant_ActionBtWhckTest(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8723b1ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8723b1ant_ActionHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-	halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8723b1ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bWifiConnected=FALSE, bApEnable=FALSE, bWifiBusy=FALSE, bBtBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	if ( (!bWifiConnected) && (!pCoexSta->bWiFiIsHighPriTask) )
-	{
-		halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	 	halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);		
-	}
-	else if( (pBtLinkInfo->bScoExist) || 	(pBtLinkInfo->bHidExist) || 	(pBtLinkInfo->bA2dpExist)  )
-	{
-		// SCO/HID/A2DP busy
-		halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-		if (pCoexSta->bC2hBtRemoteNameReq)
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 33);
-		else 
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if ( (pBtLinkInfo->bPanExist) || (bWifiBusy) )
-	{
-		halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-
-		if (pCoexSta->bC2hBtRemoteNameReq)
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 33);
-		else	 	
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	else
-	{
-		halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	 	halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);		
-		
-	}
-}
-
-VOID
-halbtc8723b1ant_ActionBtScoHidOnlyBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	// tdma and coex table
-
-	if(pBtLinkInfo->bScoExist)
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-	else //HID
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-}
-
-VOID
-halbtc8723b1ant_ActionWifiConnectedBtAclBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	u1Byte		btRssiState;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	btRssiState = halbtc8723b1ant_BtRssiState(2, 28, 0);	
-
-	if ( (pCoexSta->lowPriorityRx >= 950)  && (!pCoexSta->bUnderIps) )
-	{
-		pBtLinkInfo->bSlaveRole = TRUE;
-	}
-	else
-	{
-		pBtLinkInfo->bSlaveRole = FALSE;
-	}
-
-	if(pBtLinkInfo->bHidOnly)  //HID
-	{
-		halbtc8723b1ant_ActionBtScoHidOnlyBusy(pBtCoexist, wifiStatus);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		return;
-	}
-	else if(pBtLinkInfo->bA2dpOnly)  //A2DP		
-	{
-		if(BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifiStatus)
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		else
-		{
-			halbtc8723b1ant_TdmaDurationAdjustForAcl(pBtCoexist, wifiStatus);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = TRUE;
-		}
-	}
-	else if ( ((pBtLinkInfo->bA2dpExist) && (pBtLinkInfo->bPanExist)) ||
-		       (pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist&&pBtLinkInfo->bPanExist) ) //A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP)
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else if(pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist)  //HID+A2DP
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-	}
-	else if( (pBtLinkInfo->bPanOnly) || (pBtLinkInfo->bHidExist&&pBtLinkInfo->bPanExist) ) //PAN(OPP,FTP), HID+PAN(OPP,FTP)			
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{		
-		//BT no-profile busy (0x9)
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 33);	
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}	
-}
-
-VOID
-halbtc8723b1ant_ActionWifiNotConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// power save state
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8723b1ant_ActionWifiNotConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8723B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-	 	else
-	 	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);			
-		}
-	}
-	else if( (BT_8723B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8723b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8723b1ant_ActionWifiNotConnectedAssoAuth(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if( (pBtLinkInfo->bScoExist)  || (pBtLinkInfo->bHidExist) ||  (pBtLinkInfo->bA2dpExist) )
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 4);		
-	}
-	else if (pBtLinkInfo->bPanExist)   			
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 4);		
-	}
-	else
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8723b1ant_ActionWifiConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8723B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-	 	else
-	 	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	}
-	else if( (BT_8723B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8723b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8723b1ant_ActionWifiConnectedSpecialPacket(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN bWifiBusy = FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	//no special packet process for both WiFi and BT very busy
-	if ((bWifiBusy) && ((pBtLinkInfo->bPanExist) || (pCoexSta->nNumOfProfile >= 2)))
-	 return;	
-
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist))
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);		
-	}
-	else if  (pBtLinkInfo->bA2dpExist)
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if(pBtLinkInfo->bPanExist)
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else
-	{
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8723b1ant_ActionWifiConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN 	bWifiBusy=FALSE;
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-	BOOLEAN		bUnder4way=FALSE, bApEnable=FALSE;
-	u4Byte		wifiBw;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect()===>\n"));
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-	if(bUnder4way)
-	{
-		halbtc8723b1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n"));
-		return;
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	if(bScan || bLink || bRoam)
-	{
-		if(bScan)	
-			halbtc8723b1ant_ActionWifiConnectedScan(pBtCoexist);
-		else
-			halbtc8723b1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	
-	// power save state
-	if(!bApEnable && BT_8723B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus && !pBtCoexist->btLinkInfo.bHidOnly)
-	{
-		if(pBtCoexist->btLinkInfo.bA2dpOnly)	//A2DP
-			{			
-			if(!bWifiBusy)
-				halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);				
-			else //busy
-			{
-				if  (pCoexSta->nScanAPNum >= BT_8723B_1ANT_WIFI_NOISY_THRESH)  //no force LPS, no PS-TDMA, use pure TDMA
-				{
-			halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-				}
-				else
-				{
-					halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);					
-				}
-			}
-		}
-		else if ((pCoexSta->bPanExist == FALSE) && (pCoexSta->bA2dpExist == FALSE) && (pCoexSta->bHidExist == FALSE))
- 			halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-	else
-		halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(!bWifiBusy)
-	{
-		if(BT_8723B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8723b1ant_ActionWifiConnectedBtAclBusy(pBtCoexist, 
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else if( (BT_8723B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8723b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-			if ( (pCoexSta->highPriorityTx) + (pCoexSta->highPriorityRx) <= 60 )
-				halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-			else
-				halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7); 		 
-		}
-	}
-	else
-	{
-		if(BT_8723B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8723b1ant_ActionWifiConnectedBtAclBusy(pBtCoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else if( (BT_8723B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8723b1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else 
-		{
-			halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);	
-			if ( (pCoexSta->highPriorityTx) + (pCoexSta->highPriorityRx) <= 60 )
-				halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-			else
-				halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7); 
-		}
-	}
-}
-
-VOID
-halbtc8723b1ant_RunSwCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte				algorithm=0;
-
-	algorithm = halbtc8723b1ant_ActionAlgorithm(pBtCoexist);
-	pCoexDm->curAlgorithm = algorithm;
-
-	if(halbtc8723b1ant_IsCommonAction(pBtCoexist))
-	{
-
-	}
-	else
-	{
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8723B_1ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = SCO.\n"));
-				//halbtc8723b1ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID.\n"));
-				//halbtc8723b1ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP.\n"));
-				//halbtc8723b1ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP+PAN(HS).\n"));
-				//halbtc8723b1ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR).\n"));
-				//halbtc8723b1ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HS mode.\n"));
-				//halbtc8723b1ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN+A2DP.\n"));
-				//halbtc8723b1ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR)+HID.\n"));
-				//halbtc8723b1ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP+PAN.\n"));
-				//halbtc8723b1ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8723B_1ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP.\n"));
-				//halbtc8723b1ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = coexist All Off!!\n"));
-				//halbtc8723b1ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8723b1ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE, bWifiBusy = FALSE;
-	BOOLEAN	bIncreaseScanDevNum=FALSE;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	BOOLEAN	bMiracastPlusBt=FALSE;
-	u1Byte	aggBufSize=5;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0, wifiBw;
-	u1Byte	iotPeer=BTC_IOT_PEER_UNKNOWN;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pBtCoexist->bStopCoexDm)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	if(pCoexSta->bBtWhckTest)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under WHCK TEST!!!\n"));
-		halbtc8723b1ant_ActionBtWhckTest(pBtCoexist);
-		return;
-	}
-
-	if( (BT_8723B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8723B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bIncreaseScanDevNum = TRUE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_INC_SCAN_DEV_NUM, &bIncreaseScanDevNum);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  Multi-Port numOfWifiLink = %d, wifiLinkStatus = 0x%x\n", numOfWifiLink,wifiLinkStatus) );
-
-		if(pBtLinkInfo->bBtLinkExist)
-		{
-			halbtc8723b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1);
-			bMiracastPlusBt = TRUE;
-		}
-		else
-		{
-		halbtc8723b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-			bMiracastPlusBt = FALSE;
-		}
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-		halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-
-		if ((  (pBtLinkInfo->bA2dpExist) || (bWifiBusy) ) && (pCoexSta->bC2hBtInquiryPage) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );	
-			halbtc8723b1ant_ActionBtInquiry(pBtCoexist);
-		}
-		else
-		halbtc8723b1ant_ActionWifiMultiPort(pBtCoexist);
-		
-		return;
-	}
-	else
-	{
-		bMiracastPlusBt = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if ( (pBtLinkInfo->bBtLinkExist) && (bWifiConnected) )
-	{
-		halbtc8723b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1); 
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_IOT_PEER, &iotPeer);
-
-		if(BTC_IOT_PEER_CISCO != iotPeer)
-		{
-			if(pBtLinkInfo->bScoExist)//if (pBtLinkInfo->bBtHiPriLinkExist)
-				//halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x5);				
-				halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x5);
-			else
-				halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x5);
-				//halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);		
-		}
-		else
-		{
-			if(pBtLinkInfo->bScoExist)
-				halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x5);
-			else
-			{
-				if (BTC_WIFI_BW_HT40==wifiBw)
-					halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x10);	
-				else
-					halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-			}
-		}
-
-		halbtc8723b1ant_SwMechanism(pBtCoexist, TRUE);
-		halbtc8723b1ant_RunSwCoexistMechanism(pBtCoexist);  //just print debug message
-	}
-	else
-	{
-		halbtc8723b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-		halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x5);
-
-		halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-		halbtc8723b1ant_RunSwCoexistMechanism(pBtCoexist); ////just print debug message
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );		
-		halbtc8723b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8723b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	
-	if(!bWifiConnected)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is non connected-idle !!!\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-		if(bScan || bLink || bRoam)
-		{
-			 if (bScan)	
-		   		halbtc8723b1ant_ActionWifiNotConnectedScan(pBtCoexist);	
-			 else
-		    		halbtc8723b1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);	
-		}
-		else
-			halbtc8723b1ant_ActionWifiNotConnected(pBtCoexist);
-	}
-	else	// wifi LPS/Busy
-	{
-		halbtc8723b1ant_ActionWifiConnected(pBtCoexist);
-	}
-}
-
-u4Byte
-halbtc8723b1ant_PSD_Log2Base(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte				val
-	
-	)
-{
-	u1Byte 	i,j;
-	u4Byte	tmp, tmp2, val_integerdB=0, tindex, shiftcount=0;
-	u4Byte 	result,val_fractiondB=0,Table_fraction[21]= {0,432, 332, 274, 232, 200,
-								   174, 151,132,115,100,86,74,62,51,42,
-								   32,23,15,7,0};
-
-	if (val == 0)
-	 return 0;
-
-	tmp = val;
-
-	while(1)
-	{
-		if (tmp == 1)
-			break;	
-		else
-		{
-			tmp = (tmp >> 1);
-			shiftcount++;				
-		}
-	}
-	
-
-	val_integerdB = shiftcount+1;
-
-	tmp2=1;
-	for (j=1; j<= val_integerdB;j++)
-	  tmp2 = tmp2*2; 		
-	
-	tmp = (val*100) /tmp2;
-	tindex = tmp/5;
-
-	if (tindex > 20)
-	 tindex = 20;
-
-	val_fractiondB = Table_fraction[tindex];
-
-	result = val_integerdB*100 - val_fractiondB;			
-
-	return (result);
-
-
-}
-
-VOID
-halbtc8723b1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-
-	// sw all off
-	halbtc8723b1ant_SwMechanism(pBtCoexist, FALSE);
-	
-	//halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	//halbtc8723b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	pCoexSta->popEventCnt = 0;
-}
-
-VOID
-halbtc8723b1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte				u4Tmp=0;//, fwVer;
-	u2Byte				u2Tmp=0;
-	u1Byte				u1Tmp=0, u1Tmpa=0, u1Tmpb=0;
-	u1Byte				H2C_Parameter[2] ={0};
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 1Ant Init HW Config!!\n"));
-
-	pPsdScan->nAntDet_IsAntDetAvailable = FALSE;
-
-	//0xf0[15:12] --> Chip Cut information 
-	pCoexSta->nCutVersion = (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xf1) & 0xf0) >> 4;
-	
-#if 0//move to BTC_MEDIA_CONNECT
-	if(bBackUp)
-	{
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-#endif
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x550, 0x8, 0x1);  //enable TBTT nterrupt
-
-	// 0x790[5:0]=0x5	
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, 0x5);
-	
-	// Enable counter statistics
-	//pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc); //0x76e[3] =1, WLAN_Act control by PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x1);
-
-
-	//pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x1); //BT select s0/s1 is controlled by WiFi
-
-	halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	
-	//Antenna config
-	if(bWifiOnly)
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_WIFI, FORCE_EXEC, TRUE, FALSE);
-	else
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, TRUE, FALSE);
-
-#if 0
-	if(bWifiOnly)
-	{
-		halbtc8723b1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_WIFI, BTC_WIFI_STAT_INIT);
-		halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	}
-	else
-		halbtc8723b1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_INIT);		
-#endif
-
-
-
-	// PTA parameter
-	halbtc8723b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-	u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-
-	 RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-			u4Tmp,  u1Tmpa, u1Tmpb));
-}
-
-
-
-
-
-VOID
-halbtc8723b1ant_MechanismSwitch(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bSwitchTo2Antenna
-	)
-{
-
-	if (bSwitchTo2Antenna)  // 1-Ant -> 2-Ant
-	{
-		//un-lock TRx Mask setup for 8723b f-cut
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdd, 0x80, 0x1);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdf, 0x1, 0x1);
-		//WiFi TRx Mask on				
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 
-
-		//BT TRx Mask un-lock 0x2c[0], 0x30[0] = 1
-		pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x2c, 0x7c45); 
-		pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x30, 0x7c45); 
-	
-		//BT TRx Mask on
-		pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x1); 
-
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, FALSE);
-	}
-	else
-	{
-		//WiFi TRx Mask on				
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780); 
-
-		//lock TRx Mask setup for 8723b f-cut
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdd, 0x80, 0x0);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdf, 0x1, 0x0);
-
-		//BT TRx Mask on
-		pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15); 
-
-		//BT TRx Mask ock 0x2c[0], 0x30[0]  = 0
-		pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x2c, 0x7c44); 
-		pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x30, 0x7c44); 
-		
-
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-	}
-
-}
-
-
-
-
-VOID
-halbtc8723b1ant_PSD_ShowAntennaDetectResult(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	pu1Byte		cliBuf=pBtCoexist->cliBuf;
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n============[Antenna Detection info]  ============\n");
-	CL_PRINTF(cliBuf);
-
-	if (pPsdScan->nAntDet_Result == 1) 
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (>%d)", "Ant Det Result", "2-Antenna (Bad-Isolation)", 
-				BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else if (pPsdScan->nAntDet_Result == 2)
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)", "Ant Det Result", "2-Antenna (Good-Isolation)", 
-				BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION+pPsdScan->nAntDet_ThresOffset, BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)", "Ant Det Result", "1-Antenna",
-				BT_8723B_1ANT_ANTDET_PSDTHRES_1ANT, BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION+pPsdScan->nAntDet_ThresOffset);
-
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s ", "Antenna Detection Finish",
-							(pBoardInfo->btdmAntDetFinish? "Yes":"No"));	
-	CL_PRINTF(cliBuf);
-
-	switch(pPsdScan->nAntDet_Result)
-	{
-		case 0:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(BT is not available)");
-			break;
-		case 1:  // 2-Ant bad-isolation
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(BT is available)");
-			break;
-		case 2:  // 2-Ant good-isolation
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(BT is available)");
-			break;
-		case 3:  // 1-Ant 
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(BT is available)");
-			break;
-		case 4:  
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(Uncertainty result)");
-			break;
-		case 5:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(Pre-Scan fai)");
-			break;	
-		case 6:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(WiFi is Scanning)");
-			break;	
-		case 7:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(BT is not idle)");
-			break;	
-		case 8:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(Abort by WiFi Scanning)");
-			break;		
-		case 9:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(Antenna Init is not ready)");
-			break;	
-		case 10:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(BT is Inquiry or page)");
-			break;	
-		case 11:
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "(BT is Disabled)");
-			break;		
-}
-	CL_PRINTF(cliBuf);	
-
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Ant Detect Total Count",pPsdScan->bAntDet_TryCount);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Ant Detect Fail Count",pPsdScan->bAntDet_FailCount);
-	CL_PRINTF(cliBuf);
-
-	if ( (!pBoardInfo->btdmAntDetFinish) && (pPsdScan->nAntDet_Result != 5) )
-	 return;	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Response",(pPsdScan->nAntDet_Result? "ok":"fail"));
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ms", "BT Tx Time", pPsdScan->nAntDet_BTTxTime);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "BT Tx Ch", pPsdScan->nAntDet_BTLEChannel);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "WiFi PSD Cent-Ch/Offset/Span", 
-				pPsdScan->nRealCentFreq, pPsdScan->nRealOffset, pPsdScan->nRealSpan);
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dB", "PSD Pre-Scan Peak Value", pPsdScan->nAntDet_PrePSDScanPeakVal/100);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (<= %d)", "PSD Pre-Scan result", 
-				(pPsdScan->nAntDet_Result != 5? "ok":"fail"), BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND+pPsdScan->nAntDet_ThresOffset);	
-	CL_PRINTF(cliBuf);
-	
-	if (pPsdScan->nAntDet_Result == 5)
-		return;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s dB", "PSD Scan Peak Value", pPsdScan->nAntDet_PeakVal);
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s MHz", "PSD Scan Peak Freq", pPsdScan->nAntDet_PeakFreq);
-	CL_PRINTF(cliBuf);
-
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "TFBGA Package", 
-			(pBoardInfo->bTfbgaPackage)?  "Yes":"No");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "PSD Threshold Offset", pPsdScan->nAntDet_ThresOffset);
-	CL_PRINTF(cliBuf);
-
-}
-
-VOID
-halbtc8723b1ant_PSD_ShowData(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	pu1Byte		cliBuf=pBtCoexist->cliBuf;
-	u4Byte		nDeltaFreqPerPoint;
-	u4Byte		freq,freq1,freq2,n=0,i=0, j=0, m=0, PsdRep1, PsdRep2;
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n\n============[PSD info]  (%d)============\n",
-		 	pPsdScan->nPSDGenCount);
-	CL_PRINTF(cliBuf);
-
-	if (pPsdScan->nPSDGenCount == 0)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n No Data !!\n");
-		CL_PRINTF(cliBuf);
-		return;
-	}
-
-	if (pPsdScan->nPSDPoint == 0)
-		nDeltaFreqPerPoint = 0;
-	else			
-		nDeltaFreqPerPoint = pPsdScan->nPSDBandWidth/pPsdScan->nPSDPoint;		
-
-	//if (pPsdScan->bIsPSDShowMaxOnly)
-	if (0)
-	{	
-		PsdRep1 = pPsdScan->nPSDMaxValue/100;
-		PsdRep2 = pPsdScan->nPSDMaxValue - PsdRep1 * 100;
-				
-		freq = ((pPsdScan->nRealCentFreq-20) * 1000000 + pPsdScan->nPSDMaxValuePoint * nDeltaFreqPerPoint);
-		freq1 = freq/1000000;
-		freq2 = freq/1000 - freq1 * 1000;
-
-		if (freq2 < 100)	
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq = %d.0%d MHz",  
-			  freq1, freq2);
-		else
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq = %d.%d MHz",  
-			  freq1, freq2);
-
-		if (PsdRep2 < 10)	
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, ", Value = %d.0%d dB, (%d) \n",  
-			  PsdRep1, PsdRep2, pPsdScan->nPSDMaxValue);
-		else
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, ", Value = %d.%d dB, (%d)\n",  
-			  PsdRep1, PsdRep2, pPsdScan->nPSDMaxValue);
-		
-		CL_PRINTF(cliBuf);
-	}
-	else
-	{
-		m = pPsdScan->nPSDStartPoint;
-		n = pPsdScan->nPSDStartPoint;
-		i = 1;
-		j = 1;				
-
-	 while(1)
-	 {
-		do
-		{
-			freq = ((pPsdScan->nRealCentFreq-20) * 1000000 + m * nDeltaFreqPerPoint);
-			freq1 = freq/1000000;
-			freq2 = freq/1000 - freq1 * 1000;
-			
-			if (i ==1)
-			{
-				if (freq2 == 0)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq%6d.000", freq1);
-				else if (freq2 < 100)	
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq%6d.0%2d", freq1,freq2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Freq%6d.%3d", freq1,freq2);
-			}
-			else if  ( (i%8 == 0) || (m == pPsdScan->nPSDStopPoint) )
-			{
-				if (freq2 == 0)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.000\n", freq1);
-				else if (freq2 < 100)	
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.0%2d\n", freq1,freq2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.%3d\n", freq1,freq2);
-			}			
-			else
-			{
-				if (freq2 == 0)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.000", freq1);
-				else if (freq2 < 100)	
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.0%2d", freq1,freq2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%6d.%3d", freq1,freq2);
-			}
-
-			i++;					
-			m++;
-			CL_PRINTF(cliBuf);
-
-		}while(  (i <= 8) && (m <= pPsdScan->nPSDStopPoint));	
-		
-		
-		do
-		{
-			PsdRep1 = pPsdScan->nPSDReport_MaxHold[n]/100;
-			PsdRep2 = pPsdScan->nPSDReport_MaxHold[n] - PsdRep1 * 100;
-				
-			if (j ==1)
-			{
-				if (PsdRep2 <10)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Val %7d.0%d", PsdRep1,PsdRep2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n Val %7d.%d", PsdRep1,PsdRep2);
-			}
-			else if ( (j%8 == 0)  || (n == pPsdScan->nPSDStopPoint) )
-			{
-				if (PsdRep2 <10)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.0%d\n", PsdRep1,PsdRep2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.%d\n", PsdRep1,PsdRep2);
-			}
-			else
-			{
-				if (PsdRep2 <10)
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.0%d", PsdRep1,PsdRep2);
-				else
-					CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "%7d.%d", PsdRep1,PsdRep2);
-			}
-
-			j++;
-			n++;
-			CL_PRINTF(cliBuf);
-			
-		} while(  (j <= 8) && (n <= pPsdScan->nPSDStopPoint));		
-
-		if  ( (m > pPsdScan->nPSDStopPoint) || (n > pPsdScan->nPSDStopPoint) )
-		 break;
-		else
-		{
-			i = 1;
-			j = 1;
-		}
-		
-	 }	
-	}
-
-
-}
-
-VOID
-halbtc8723b1ant_PSD_MaxHoldData(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte				GenCount
-	)
-{
-		 u4Byte	i=0, i_max=0, val_max=0, j;
-		 
-		if (GenCount== 1)
-		{
-			memcpy(pPsdScan->nPSDReport_MaxHold, pPsdScan->nPSDReport, BT_8723B_1ANT_ANTDET_PSD_POINTS*sizeof(u4Byte));
-
-			for (i= pPsdScan->nPSDStartPoint; i<=pPsdScan->nPSDStopPoint; i++)
-			{
-				//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Max_Hold i = %d, PSDReport = %d dB\n", i,  pPsdScan->nPSDReport_MaxHold[i]));
-			}
-
-			pPsdScan->nPSDMaxValuePoint = 0;
-			pPsdScan->nPSDMaxValue = 0;
-
-		}	
-		else
-		{
-			for (i= pPsdScan->nPSDStartPoint; i<=pPsdScan->nPSDStopPoint; i++)
-			{
-				if (pPsdScan->nPSDReport[i] > pPsdScan->nPSDReport_MaxHold[i])
-					pPsdScan->nPSDReport_MaxHold[i] = pPsdScan->nPSDReport[i];
-
-				//search Max Value
-				if (i ==pPsdScan->nPSDStartPoint )
-				{
-					i_max = i;
-					val_max = pPsdScan->nPSDReport_MaxHold[i];
-				}
-				else
-				{
-					if (pPsdScan->nPSDReport_MaxHold[i] > val_max)
-					{
-						i_max = i;
-						val_max = pPsdScan->nPSDReport_MaxHold[i];
-					}
-				}
-
-				//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Max_Hold i = %d, PSDReport = %d dB\n", i,  pPsdScan->nPSDReport_MaxHold[i]));
-
-			}
-	
-			pPsdScan->nPSDMaxValuePoint = i_max;
-			pPsdScan->nPSDMaxValue = val_max;
-
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Max_Hold i_Max = %d, PSDReport_Max = %d dB\n", pPsdScan->nPSDMaxValuePoint
-			//		,pPsdScan->nPSDMaxValue));
-		}
-
-
-}
-
-u4Byte
-halbtc8723b1ant_PSD_GetData(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte				nPoint
-	)
-{
-	//reg 0x808[9:0]: FFT data x
-	//reg 0x808[22]: 0-->1 to get 1 FFT data y
-	//reg 0x8b4[15:0]: FFT data y report
-
-	u4Byte val = 0, psd_report =0;
-	
-	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x808);
-
-	val &= 0xffbffc00;
-	val |= nPoint;
-	
-	 pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x808, val);
-
-	val |= 0x00400000;
-	 pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x808, val);
-
-
-	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x8b4);
-
-	psd_report = val & 0x0000ffff;
-	 
-	return psd_report;
-}
-
-
-VOID
-halbtc8723b1ant_PSD_SweepPoint(
-IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte				centFreq,
-	IN	s4Byte				offset,
-	IN	u4Byte				span,
-	IN	u4Byte				points,
-	IN	u4Byte				avgnum
-	)
-{
-	u4Byte	 i,val,n,k=0;
-	u4Byte	nPoints=0, psd_report=0;
-	u4Byte	nStartP=0, nStopP=0, nDeltaFreqPerPoint=156250;
-	u4Byte    nPSDCenterFreq=20*10^6, freq,freq1,freq2;	
-	BOOLEAN outloop = FALSE;
-	u1Byte	 flag = 0;	
-	u4Byte 	tmp, PsdRep1, PsdRep2;
-	u4Byte	WiFi_OriginalChannel = 1;
-
-	pPsdScan->bIsPSDRunning = TRUE;
-	
-	do
-	{
-		switch(flag)
-		{
-		   case 0:  //Get PSD parameters
-		   default:	
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), centFreq=0x%x, offset=0x%x, span=0x%x\n", 
-		       //     centFreq, offset, span));
-
-			pPsdScan->nPSDBandWidth = 40*1000000;
-			pPsdScan->nPSDPoint = points;
-			pPsdScan->nPSDStartBase = points/2; 
-			pPsdScan->nPSDAvgNum = avgnum;
-			pPsdScan->nRealCentFreq = centFreq;
-			pPsdScan->nRealOffset = offset;
-			pPsdScan->nRealSpan = span;
-		
-			
-			nPoints = pPsdScan->nPSDPoint;
-			nDeltaFreqPerPoint = pPsdScan->nPSDBandWidth/pPsdScan->nPSDPoint;
-
-			//PSD point setup
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x808);
-			val &= 0xffff0fff;				
-			
-			switch(pPsdScan->nPSDPoint)
-			{
-				case 128:
-					val |= 0x0;
-					break;
-				case 256:
-				default:	
-					val |=0x00004000;
-				 	break;
-				case 512:	
-					val |= 0x00008000;
-					break;
-				case 1024:	
-					val |= 0x0000c000;
-					break;
-			}			
-					
-			switch(pPsdScan->nPSDAvgNum)
-			{
-				case 1:
-					val |= 0x0;
-					break;
-				case 8:				
-					val |=0x00001000;
-				 	break;
-				case 16:	
-					val |= 0x00002000;
-					break;
-				case 32:
-				default:	
-					val |= 0x00003000;
-					break;
-			}
-			 pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x808, val);
-
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), PSD BW= %d, DeltaFreq=%d\n"
-		 	//	, pPsdScan->nPSDBandWidth, nDeltaFreqPerPoint));
-			flag = 1;
-			break;
-		  case 1:	  //calculate the PSD point index from freq/offset/span
-		  	nPSDCenterFreq = pPsdScan->nPSDBandWidth /2 +offset*(1000000);
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), PSD Center Freq = %d\n", (centFreq + offset)));
-			
-			nStartP = pPsdScan->nPSDStartBase + (nPSDCenterFreq - span *(1000000)/2) /nDeltaFreqPerPoint;
-			pPsdScan->nPSDStartPoint = nStartP - pPsdScan->nPSDStartBase;
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Start PSD Poin Matrix Index = %d\n", pPsdScan->nPSDStartPoint));
-
-			nStopP = pPsdScan->nPSDStartBase + (nPSDCenterFreq + span *(1000000)/2) /nDeltaFreqPerPoint;
-			pPsdScan->nPSDStopPoint = nStopP - pPsdScan->nPSDStartBase-1;
-			//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), Stop PSD Poin Matrix Index = %d\n",pPsdScan->nPSDStopPoint));
-
-			flag = 2;
-			break;
-		  case 2:  //set RF channel/BW/Mode
-
-		  	//set 3-wire off
-		  	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x88c);
-			val |= 0x00300000;
-			 pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x88c,val);
-
-			//CCK off
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x800);
-			val &= 0xfeffffff;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x800,val);		
-
-			//store WiFi original channel
-			WiFi_OriginalChannel = pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff);
-
-			//Set RF channel
-		       if (centFreq == 2484)
-				pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff, 0xe); 
-			else
-				pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff, (centFreq-2412)/5 + 1); //WiFi TRx Mask on
-
-			//Set  RF mode = Rx, RF Gain = 0x8a0
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x0, 0xfffff, 0x308a0);
-
-			//Set RF Rx filter corner
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0x3e4);
-
-			//Set TRx mask off
-			//un-lock TRx Mask setup
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdd, 0x80, 0x1);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdf, 0x1, 0x1);
-
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-			flag = 3;
-			break;
-		  case 3:
-		  	memset(pPsdScan->nPSDReport,0, pPsdScan->nPSDPoint*sizeof(u4Byte));
-			nStartP = pPsdScan->nPSDStartPoint + pPsdScan->nPSDStartBase;
-			nStopP = pPsdScan->nPSDStopPoint +  pPsdScan->nPSDStartBase + 1;
-				
-			i = nStartP;
-
-			while (i < nStopP)
-			{
-				if (i >= nPoints)
-				{
-					psd_report = halbtc8723b1ant_PSD_GetData(pBtCoexist,i-nPoints);
-				}
-				else
-				{
-					psd_report = halbtc8723b1ant_PSD_GetData(pBtCoexist,i);
-				}
-
-				if (psd_report == 0)
-					tmp = 0;
-				else
-					//tmp =  20*log10((double)psd_report);
-					//20*log2(x)/log2(10), log2Base return theresult of the psd_report*100
-					tmp = 6 * halbtc8723b1ant_PSD_Log2Base(pBtCoexist, psd_report);				
-
-				n = i-pPsdScan->nPSDStartBase;
-				pPsdScan->nPSDReport[n] =  tmp;
-				PsdRep1 = pPsdScan->nPSDReport[n] /100;
-				PsdRep2 = pPsdScan->nPSDReport[n] - PsdRep1 * 100;
-				
-				freq =  ((centFreq-20) * 1000000 + n * nDeltaFreqPerPoint);
-				freq1 = freq/1000000;
-				freq2 = freq/1000 - freq1 * 1000;
-/*
-				if (freq2 < 100)
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), i = %d (%d.0%d MHz)", n, freq1, freq2));
-				else
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint(), i = %d (%d.%d MHz)", n, freq1, freq2));
-
-				if (PsdRep2 < 10)
-					RT_TRACE(COMP_COEX, DBG_LOUD, (", PSDReport = %d (%d.0%d dB)\n",psd_report, PsdRep1, PsdRep2));
-				else
-					RT_TRACE(COMP_COEX, DBG_LOUD, (", PSDReport = %d (%d.%d dB)\n",psd_report, PsdRep1,PsdRep2));	
-*/
-				i++;
-
-				k=0;
-
-				//Add Delay between PSD point
-				while(1)
-				{
-					if (k++ > 20000)
-					 break;
-				}
-
-				//RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx SweepPSDPoint()==============\n"));
-			}	
-
-			flag = 100;
-			break;
-		  case 99:	//error
-
-			outloop = TRUE;
-			break;
-		  case 100: //recovery 
-
-		  	//set 3-wire on
-		  	val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x88c);
-			val &=0xffcfffff;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x88c,val);
-
-			//CCK on
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x800);
-			val |= 0x01000000;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x800,val);	
-
-			//PSD off
-			val = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x808);
-			val &=0xffbfffff;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist,0x808,val);
-			
-		  	//TRx Mask on
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780);
-
-			//lock TRx Mask setup
-		  	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdd, 0x80, 0x0);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xdf, 0x1, 0x0);
-
-			//Set RF Rx filter corner
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0x0);
-
-			//restore WiFi original channel
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x18, 0x3ff, WiFi_OriginalChannel); 
-			
-			outloop = TRUE;
-			break;
-
-		}		
-			
-	}while (!outloop);
-
-
-
-	pPsdScan->bIsPSDRunning = FALSE;
-
-
-}
-
-VOID
-halbtc8723b1ant_PSD_AntennaDetection(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					BTTxTime,
-	IN	u4Byte					BTLEChannel
-	)
-{
-	u4Byte 	realseconds = 0, i=0, j=0;
-	u4Byte	WLPSD_CentFreq = 2484, WLPSD_Span = 2, WLPSD_SweepCount = 50; 
-	s4Byte 	WLPSD_Offset = -4;
-	u1Byte 	BTLECh[13] = {3,6,8,11,13,16,18,21,23,26,28,31,33};
-
-	u1Byte	H2C_Parameter[3] ={0},u1Tmpa,u1Tmpb;
-	
-	u1Byte	state=0;
-	BOOLEAN		outloop = FALSE, BTResp = FALSE, bScan ,bRoam;
-	u4Byte		freq,freq1,freq2,PsdRep1, PsdRep2, nDeltaFreqPerPoint,u4Tmp;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-
-	pBoardInfo->btdmAntDetFinish = FALSE;	
-	memset(pPsdScan->nAntDet_PeakVal, 0, 16*sizeof(UCHAR));
-	memset(pPsdScan->nAntDet_PeakFreq, 0, 16*sizeof(UCHAR));
-
-	if (pBoardInfo->bTfbgaPackage) //for TFBGA
-		pPsdScan->nAntDet_ThresOffset = 5;
-	else
-		pPsdScan->nAntDet_ThresOffset = 0;
-
-	do
-	{
-		switch(state)
-		{
-			case 0:
-				if (BTLEChannel == 39)
-				 WLPSD_CentFreq = 2484;
-				else
-				{
-					for (i=1; i<=13; i++)
-					{
-						if (BTLECh[i-1] == BTLEChannel)
-						{
-							 WLPSD_CentFreq = 2412 + (i-1) * 5;
-							 break;
-						}
-					}
-
-					if (i == 14)
-					{
-
-						RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Abort!!, Invalid LE channel = %d\n ",  BTLEChannel));
-						outloop = TRUE;
-						break;					
-					}
-				}
-				
-				WLPSD_SweepCount = BTTxTime * 238 /100;  //BTTxTime/0.42								
-
-				if (WLPSD_SweepCount % 5 != 0)
-					WLPSD_SweepCount = (WLPSD_SweepCount/5 + 1) * 5;
-
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), BT_LETxTime=%d,  BT_LECh = %d\n", BTTxTime, BTLEChannel));
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), WLPSD_CentFreq=%d,  WLPSD_Offset = %d, WLPSD_Span = %d, WLPSD_SweepCount = %d\n",
-									WLPSD_CentFreq, WLPSD_Offset, WLPSD_Span,WLPSD_SweepCount));
-				
-				state = 1;
-				break;
-			case 1: //stop coex DM & set antenna path
-	//Stop Coex DM
-	pBtCoexist->bStopCoexDm = TRUE;
-
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Stop Coex DM!!\n"));
-
-				//set native power save
-				halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-				//Set TDMA off, 				
-				halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);				
-
-				//Set coex table
-				halbtc8723b1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-				if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Main Port\n"));
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Aux Port\n"));
-				}
-		
-	//Set Antenna path, switch WiFi to un-certain antenna port
-	halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, FALSE);
-
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to BT!!\n"));
-
-				//Set AFH mask on at WiFi channel 2472MHz +/- 10MHz
-				H2C_Parameter[0] = 0x1;
-				H2C_Parameter[1] = 0xd;
-				H2C_Parameter[2] = 0x14;
-
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-									H2C_Parameter[1],H2C_Parameter[2]));
-	
-				pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);
-
-				u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-       			u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-				u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	
-				 RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x778=0x%x\n",
-	   	      				u4Tmp,  u1Tmpa, u1Tmpb));
-
-				state =2;
-				break;
-			case 2:	//Pre-sweep background psd
-				for (pPsdScan->nPSDGenCount=1; pPsdScan->nPSDGenCount<=3; pPsdScan->nPSDGenCount++)
-	{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), PSDGenCount = %d\n ",  pPsdScan->nPSDGenCount));
-					halbtc8723b1ant_PSD_SweepPoint(pBtCoexist, WLPSD_CentFreq, WLPSD_Offset, WLPSD_Span, BT_8723B_1ANT_ANTDET_PSD_POINTS, BT_8723B_1ANT_ANTDET_PSD_AVGNUM);				
-					halbtc8723b1ant_PSD_MaxHoldData(pBtCoexist,  pPsdScan->nPSDGenCount);					
-				}
-		
-				pPsdScan->nAntDet_PrePSDScanPeakVal = pPsdScan->nPSDMaxValue;
-	
-				if (pPsdScan->nPSDMaxValue > (BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND+pPsdScan->nAntDet_ThresOffset)*100)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Abort Antenna Detection!! becaus background = %d > thres (%d)\n",
-						pPsdScan->nPSDMaxValue/100, BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND+pPsdScan->nAntDet_ThresOffset));
-					pBoardInfo->btdmAntDetFinish = FALSE;
-					pBoardInfo->btdmAntNumByAntDet = 1;
-					pPsdScan->nAntDet_Result = 5;
-					state = 99;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Start Antenna Detection!! becaus background = %d <= thres (%d)\n",
-						pPsdScan->nPSDMaxValue/100, BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND+pPsdScan->nAntDet_ThresOffset));
-					state = 3;
-				}
-				break;
-			case 3:	
-				BTResp = pBtCoexist->fBtcSetBtAntDetection(pBtCoexist, (u1Byte)(BTTxTime&0xff), (u1Byte)(BTLEChannel&0xff)); 
-	
-				for (pPsdScan->nPSDGenCount=1; pPsdScan->nPSDGenCount<=WLPSD_SweepCount; pPsdScan->nPSDGenCount++)
-		{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), PSDGenCount = %d\n ",  pPsdScan->nPSDGenCount));
-					halbtc8723b1ant_PSD_SweepPoint(pBtCoexist, WLPSD_CentFreq, WLPSD_Offset, WLPSD_Span, BT_8723B_1ANT_ANTDET_PSD_POINTS, BT_8723B_1ANT_ANTDET_PSD_AVGNUM);				
-					halbtc8723b1ant_PSD_MaxHoldData(pBtCoexist,  pPsdScan->nPSDGenCount);	
-
-					pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-					pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-					if (bScan ||bRoam)
-			{
-						pBoardInfo->btdmAntDetFinish = FALSE;
-						pBoardInfo->btdmAntNumByAntDet = 1;
-						pPsdScan->nAntDet_Result = 8;
-						state = 99;	
-						break;
-			}
-		}	
-
-				pPsdScan->nAntDet_PSDScanPeakVal = pPsdScan->nPSDMaxValue;
-				pPsdScan->nAntDet_PSDScanPeakFreq = pPsdScan->nPSDMaxValuePoint;
-				state = 4;
-				break;
-			case 4:				
-
-				if (pPsdScan->nPSDPoint == 0)
-					nDeltaFreqPerPoint = 0;
-		else
-					nDeltaFreqPerPoint = pPsdScan->nPSDBandWidth/pPsdScan->nPSDPoint;		
-
-				PsdRep1 = pPsdScan->nPSDMaxValue/100;
-				PsdRep2 = pPsdScan->nPSDMaxValue - PsdRep1 * 100;
-				
-				freq = ((pPsdScan->nRealCentFreq-20) * 1000000 + pPsdScan->nPSDMaxValuePoint * nDeltaFreqPerPoint);
-				freq1 = freq/1000000;
-				freq2 = freq/1000 - freq1 * 1000;
-
-				if (freq2 < 100)
-		{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.0%d MHz", freq1, freq2));
-					CL_SPRINTF(pPsdScan->nAntDet_PeakFreq, BT_8723B_1ANT_ANTDET_BUF_LEN, "%d.0%d", freq1,freq2);
-				}
-				else
-			{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.%d MHz",  freq1, freq2));
-					CL_SPRINTF(pPsdScan->nAntDet_PeakFreq, BT_8723B_1ANT_ANTDET_BUF_LEN, "%d.%d", freq1,freq2);
-				}
-
-				if (PsdRep2 < 10)	
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, (", Value = %d.0%d dB\n",   PsdRep1, PsdRep2));
-					CL_SPRINTF(pPsdScan->nAntDet_PeakVal, BT_8723B_1ANT_ANTDET_BUF_LEN, "%d.0%d", PsdRep1,PsdRep2);
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, (", Value = %d.%d dB\n",PsdRep1, PsdRep2));
-					CL_SPRINTF(pPsdScan->nAntDet_PeakVal, BT_8723B_1ANT_ANTDET_BUF_LEN, "%d.%d", PsdRep1,PsdRep2);
-				}
-
-				pPsdScan->nAntDet_IsBTReplyAvailable = TRUE;
-				
-				if (BTResp == FALSE)
-				{
-					pPsdScan->nAntDet_IsBTReplyAvailable = FALSE;
-					pPsdScan->nAntDet_Result = 0;
-					pBoardInfo->btdmAntDetFinish = FALSE;
-					pBoardInfo->btdmAntNumByAntDet = 1;
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), BT Response = Fail \n "));
-				}
-				else if (pPsdScan->nPSDMaxValue > (BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION)*100)
-				{
-					pPsdScan->nAntDet_Result = 1;
-					pBoardInfo->btdmAntDetFinish = TRUE;
-					pBoardInfo->btdmAntNumByAntDet = 2;
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Bad-Isolation!! \n"));
-				}
-				else if (pPsdScan->nPSDMaxValue > (BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION+pPsdScan->nAntDet_ThresOffset)*100)
-					{
-					pPsdScan->nAntDet_Result = 2;
-					pBoardInfo->btdmAntDetFinish = TRUE;
-					pBoardInfo->btdmAntNumByAntDet = 2;
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Good-Isolation!! \n"));
-				}
-				else if (pPsdScan->nPSDMaxValue > (BT_8723B_1ANT_ANTDET_PSDTHRES_1ANT)*100)
-				{
-					pPsdScan->nAntDet_Result = 3;
-					pBoardInfo->btdmAntDetFinish = TRUE;
-					pBoardInfo->btdmAntNumByAntDet = 1;
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant!!\n"));
-					}
-				else
-				{
-					pPsdScan->nAntDet_Result = 4;
-					pBoardInfo->btdmAntDetFinish = FALSE;
-					pBoardInfo->btdmAntNumByAntDet = 1;
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant, un-certainity!!\n"));
-				}
-
-				state = 99;
-				break;
-			case 99:  //restore setup
-			
-				//Set AFH mask off at WiFi channel 2472MHz +/- 10MHz
-				H2C_Parameter[0] = 0x0;
-				H2C_Parameter[1] = 0x0;
-				H2C_Parameter[2] = 0x0;
-	
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-					H2C_Parameter[1],H2C_Parameter[2]));		
-
-				pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);
-				
-				//Set Antenna Path					
-				halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to PTA\n!!"));
-
-				//Resume Coex DM
-				pBtCoexist->bStopCoexDm = FALSE;
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Resume Coex DM\n!!"));
-
-				//stimulate coex running
-				halbtc8723b1ant_RunCoexistMechanism(pBtCoexist);
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Stimulate Coex running\n!!"));
-
-				outloop = TRUE;
-				break;
-			}
-	
-	}while(!outloop);
-	
-
-
-		}
-
-VOID
-halbtc8723b1ant_PSD_AntennaDetectionCheck(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u4Byte AntDetCount = 0, AntDetFailCount = 0;
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	
-	BOOLEAN bScan, bRoam;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);	
-
-
-	pPsdScan->nAntDet_BTTxTime = 20;  //0.42ms*50 = 20ms
-	pPsdScan->nAntDet_BTLEChannel = 39;		
-
-	AntDetCount++;
-	
-	pPsdScan->bAntDet_TryCount = AntDetCount;	
-			
-	if (bScan ||bRoam)
-		{
-		pBoardInfo->btdmAntDetFinish = FALSE;
-		pPsdScan->nAntDet_Result = 6;
-	}
-	else if(pBtCoexist->btInfo.bBtDisabled)
-	{
-		pBoardInfo->btdmAntDetFinish = FALSE;
-		pPsdScan->nAntDet_Result = 11;
-	}
-	else if (pCoexSta->nNumOfProfile >= 1) 
-	{
-		pBoardInfo->btdmAntDetFinish = FALSE;
-		pPsdScan->nAntDet_Result = 7;
-	}
-	else if (!pPsdScan->nAntDet_IsAntDetAvailable)  //Antenna initial setup is not ready
-	{
-		pBoardInfo->btdmAntDetFinish = FALSE;
-		pPsdScan->nAntDet_Result = 9;
-	}
-	else if (pCoexSta->bC2hBtInquiryPage)
-		{
-		pBoardInfo->btdmAntDetFinish = FALSE;
-		pPsdScan->nAntDet_Result = 10;
-		}
-		else
-		{
-		halbtc8723b1ant_PSD_AntennaDetection(pBtCoexist,  pPsdScan->nAntDet_BTTxTime, pPsdScan->nAntDet_BTLEChannel);			
-		}
-
-	if (!pBoardInfo->btdmAntDetFinish)
-		AntDetFailCount++;
-
-	pPsdScan->bAntDet_FailCount = AntDetFailCount;
-
-}
-
-
-//============================================================
-// work around function start with wa_halbtc8723b1ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8723b1ant_
-//============================================================
-VOID
-EXhalbtc8723b1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u1Byte u1Tmp=0x0;
-	u2Byte u2Tmp=0x0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx Execute 8723b 1-Ant PowerOn Setting xxxxxxxxxxxxxxxx!!\n"));
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("Ant Det Finish = %s, Ant Det Number  = %d\n",  
-		 (pBoardInfo->btdmAntDetFinish? "Yes":"No"), pBoardInfo->btdmAntNumByAntDet));
-
-	pBtCoexist->bStopCoexDm = TRUE;
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x67, 0x20);
-
-	// enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly.
-	u2Tmp = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x2);
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x2, u2Tmp|BIT0|BIT1);
-
-	// set GRAN_BT = 1
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18);
-	// set WLAN_ACT = 0
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);	
-
-	// 
-	// S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info)
-	// Local setting bit define
-	//	BIT0: "0" for no antenna inverse; "1" for antenna inverse 
-	//	BIT1: "0" for internal switch; "1" for external switch
-	//	BIT2: "0" for one antenna; "1" for two antenna
-	// NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-
-	 	u1Tmp |= 0x1;	// antenna inverse
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0xfe08, u1Tmp);
-
-		pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-	}
-	else
-	{
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-			// set to S1
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x280);
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-			u1Tmp |= 0x1;	// antenna inverse
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-		}
-
-		if(pBtCoexist->chipInterface == BTC_INTF_PCI)
-		{	
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x384, u1Tmp);
-		}
-		else if(pBtCoexist->chipInterface == BTC_INTF_SDIO)
-		{
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x60, u1Tmp);
-		}			
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8723b1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8723b1ant_InitHwConfig(pBtCoexist, TRUE, bWifiOnly);
-	pBtCoexist->bStopCoexDm = FALSE;
-}
-
-VOID
-EXhalbtc8723b1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-
-	pBtCoexist->bStopCoexDm = FALSE;
-	
-	halbtc8723b1ant_InitCoexDm(pBtCoexist);
-
-	halbtc8723b1ant_QueryBtInfo(pBtCoexist);
-}
-
-VOID
-EXhalbtc8723b1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u2Byte				u2Tmp[4];
-	u4Byte				u4Tmp[4];
-	u4Byte				faOfdm, faCck;
-	u4Byte				fwVer=0, btPatchVer=0;
-	static u1Byte			PopReportIn10s = 0;	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-	if(pBtCoexist->bStopCoexDm)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	if (pPsdScan->bAntDet_TryCount == 0)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "Ant PG Num/ Mech/ Pos",
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos);
-	CL_PRINTF(cliBuf);	
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d  (%d/%d/%d)", "Ant PG Num/ Mech(Ant_Det)/ Pos", 
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNumByAntDet, pBoardInfo->btdmAntPos, 
-		pPsdScan->bAntDet_TryCount, pPsdScan->bAntDet_FailCount, pPsdScan->nAntDet_Result);		
-		CL_PRINTF(cliBuf);
-
-		if (pBoardInfo->btdmAntDetFinish)
-		{
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "Ant Det PSD Value",  pPsdScan->nAntDet_PeakVal);		
-			CL_PRINTF(cliBuf);
-		}
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)/ %c", "Version Coex/ Fw/ Patch/ Cut", \
-		GLCoexVerDate8723b1Ant, GLCoexVer8723b1Ant, fwVer, btPatchVer, btPatchVer, pCoexSta->nCutVersion+65);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s", "WifibHiPri/ Ccklock/ CckEverLock", \
-		(pCoexSta->bWiFiIsHighPriTask? "Yes":"No"),
-		(pCoexSta->bCCKLock? "Yes":"No"),
-		(pCoexSta->bCCKEverLock? "Yes":"No"));
-	CL_PRINTF(cliBuf);
-
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-	
-	PopReportIn10s++;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d/ %d] ", "BT [status/ rssi/ retryCnt/ popCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt, pCoexSta->popEventCnt);
-	CL_PRINTF(cliBuf);
-	
-	if (PopReportIn10s >= 5)
-	{
-		pCoexSta->popEventCnt = 0;	
-		PopReportIn10s = 0;
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d / %d / %d", "SCO/HID/PAN/A2DP/NameReq/WHQL", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist, pCoexSta->bC2hBtRemoteNameReq, pCoexSta->bBtWhckTest );
-	CL_PRINTF(cliBuf);
-
-	if (pStackInfo->bProfileNotified)
-	{
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);	
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Role", \
-		(pBtLinkInfo->bSlaveRole )? "Slave":"Master");
-		CL_PRINTF(cliBuf);	
-	}	
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d", "A2DP Rate/Bitpool", \
-		(btInfoExt&BIT0)? "BR":"EDR", pCoexSta->nA2DPBitPool);
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8723B_1ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8723b1Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	
-	if(pBtCoexist->bManualControl)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism] (before Manual)============");			
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	}	
-
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "SM[LowPenaltyRA]", \
-			pCoexDm->bCurLowPenaltyRa);
-		CL_PRINTF(cliBuf);
-
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %d ", "DelBA/ BtCtrlAgg/ AggSize", \
-			(pBtCoexist->btInfo.bRejectAggPkt? "Yes":"No"), (pBtCoexist->btInfo.bBtCtrlAggBufSize? "Yes":"No"),
-				pBtCoexist->btInfo.aggBufSize);
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Rate Mask", \
-				pBtCoexist->btInfo.raMask);
-		CL_PRINTF(cliBuf);
-
-		// Fw mechanism		
-		if(pBtCoexist->bManualControl)
-		{
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism] (before Manual) ============");			
-		}
-		else
-		{
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-		}
-		
-		CL_PRINTF(cliBuf);	
-
-		psTdmaCase = pCoexDm->curPsTdma;
-		if (pBoardInfo->btdmAntNumByAntDet == 2)
-		{
-			if (pCoexDm->bCurPsTdmaOn)
-				psTdmaCase = psTdmaCase +100;  //for WiFi RSSI low or BT RSSI low
-			else
-				psTdmaCase = 1; //always translate to TDMA(off,1) for TDMA-off case
-		}
-		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase, 
-			(pCoexDm->bCurPsTdmaOn? "On":"Off"),
-			(pCoexDm->bAutoTdmaAdjust? "Adj":"Fix") );
-		
-		CL_PRINTF(cliBuf);
-		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Coex Table Type", \
-			pCoexSta->nCoexTableType);
-		CL_PRINTF(cliBuf);
-		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "IgnWlanAct", \
-			pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-	
-		/*
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Latest error condition(should be 0)", \
-			pCoexDm->errorCondition);
-		CL_PRINTF(cliBuf);
-		*/
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "backup ARFR1/ARFR2/RL/AMaxTime", \
-		pCoexDm->backupArfrCnt1, pCoexDm->backupArfrCnt2, pCoexDm->backupRetryLimit, pCoexDm->backupAmpduMaxTime);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-	u2Tmp[0] = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "0x430/0x434/0x42a/0x456", \
-		u4Tmp[0], u4Tmp[1], u2Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6cc);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x880);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x778/0x6cc/0x880[29:25]", \
-		u1Tmp[0], u4Tmp[0],  (u4Tmp[1]&0x3e000000) >> 25);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x764);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "0x948/ 0x67[5] / 0x764 / 0x76e", \
-		u4Tmp[0], ((u1Tmp[0]&0x20)>> 5), (u4Tmp[1] & 0xffff), u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x92c);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x930);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x944);	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x92c[1:0]/ 0x930[7:0]/0x944[1:0]", \
-		u4Tmp[0]&0x3, u4Tmp[1]&0xff, u4Tmp[2]&0x3);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x39);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-	u1Tmp[2] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x64);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "0x38[11]/0x40/0x4c[24:23]/0x64[0]", \
-		((u1Tmp[0] & 0x8)>>3), u1Tmp[1], ((u4Tmp[0]&0x01800000)>>23), u1Tmp[2]&0x1);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x49c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xc50(dig)/0x49c(null-drop)", \
-		u4Tmp[0]&0xff, u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda8);
-	u4Tmp[3] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcf0);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5b);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-
-	faOfdm = ((u4Tmp[0]&0xffff0000) >> 16) +  ((u4Tmp[1]&0xffff0000) >> 16) + (u4Tmp[1] & 0xffff) +  (u4Tmp[2] & 0xffff) + \
-		             ((u4Tmp[3]&0xffff0000) >> 16) + (u4Tmp[3] & 0xffff) ;
-	faCck = (u1Tmp[0] << 8) + u1Tmp[1];
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "OFDM-CCA/OFDM-FA/CCK-FA", \
-		u4Tmp[0]&0xffff, faOfdm, faCck);
-	CL_PRINTF(cliBuf);
-
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_OK CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCOK_CCK, pCoexSta->nCRCOK_11g, pCoexSta->nCRCOK_11n, pCoexSta->nCRCOK_11nAgg);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_Err CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCErr_CCK, pCoexSta->nCRCErr_11g, pCoexSta->nCRCErr_11n, pCoexSta->nCRCErr_11nAgg);
-	CL_PRINTF(cliBuf);	
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x6c0/0x6c4/0x6c8(coexTable)", \
-		u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(high-pri rx/tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri rx/tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8723B_1ANT == 1)
-	//halbtc8723b1ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8723b1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u4Byte	u4Tmp=0;
-
-	if(pBtCoexist->bManualControl ||	pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		//halbtc8723b1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-
-		halbtc8723b1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8723b1ant_InitCoexDm(pBtCoexist);
-		halbtc8723b1ant_QueryBtInfo(pBtCoexist);
-
-		pCoexSta->bUnderIps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(pBtCoexist->bManualControl || pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	u1Byte u1Tmpa, u1Tmpb;
-	u4Byte u4Tmp;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm )
-		return;
-
-	if(BTC_SCAN_START == type)
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-		pPsdScan->nAntDet_IsAntDetAvailable = TRUE;
-		halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-		u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-		u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-          
-	   
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-			u4Tmp,  u1Tmpa, u1Tmpb));
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &pCoexSta->nScanAPNum);		
-	}
-
-	if(pBtCoexist->btInfo.bBtDisabled)
-		return;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	halbtc8723b1ant_QueryBtInfo(pBtCoexist);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8723b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8723b1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-	
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8723b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8723b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_SCAN_START == type)
-	{	
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8723b1ant_ActionWifiNotConnectedScan(pBtCoexist);
-		}
-		else	// wifi is connected
-		{
-			halbtc8723b1ant_ActionWifiConnectedScan(pBtCoexist);
-		}
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8723b1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8723b1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-		 pPsdScan->nAntDet_IsAntDetAvailable = TRUE;
-		halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-		 RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));	
-		 pCoexDm->nArpCnt = 0;
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));	
-		//pCoexDm->nArpCnt = 0;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8723b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8723b1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8723b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8723b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));		
-		halbtc8723b1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-		
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-		if(!bWifiConnected) // non-connected scan
-		{
-			halbtc8723b1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8723b1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	BOOLEAN			bWifiUnderBMode = FALSE;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-		halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-		pPsdScan->nAntDet_IsAntDetAvailable = TRUE;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-
-		//Set CCK Tx/Rx high Pri except 11b mode
-		if (bWifiUnderBMode)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x00); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x00); //CCK Rx
-		}
-		else
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x10); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x10); //CCK Rx
-		}
-		
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-		pCoexDm->nArpCnt = 0;
-
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x0); //CCK Tx
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x0); //CCK Rx
-
-		pCoexSta->bCCKEverLock = FALSE;
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		//H2C_Parameter[0] = 0x1;
-		H2C_Parameter[0] = 0x0;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-		
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);
-}
-
-VOID
-EXhalbtc8723b1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bBtHsOn=FALSE;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE, bUnder4way=FALSE;
-	u1Byte	aggBufSize=5;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if( BTC_PACKET_DHCP == type || 
-		BTC_PACKET_EAPOL == type ||
-		BTC_PACKET_ARP == type )
-	{
-		if (BTC_PACKET_ARP == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet ARP notify\n"));		 
-
-			pCoexDm->nArpCnt++;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ARP Packet Count = %d\n", pCoexDm->nArpCnt));
-			
-			if((pCoexDm->nArpCnt >= 10) && (!bUnder4way)) // if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecialPacket(pBtCoexist) 
-			{
-				pCoexSta->bWiFiIsHighPriTask = FALSE;					
-			}			
-			else
-			{
-				pCoexSta->bWiFiIsHighPriTask = TRUE;
-			}
-		}
-		else
-		{
-			pCoexSta->bWiFiIsHighPriTask = TRUE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet DHCP or EAPOL notify\n"));		 
-		}
-	} 
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet [Type = %d] notify\n", type));
-	}
-
-	pCoexSta->specialPktPeriodCnt = 0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8723b1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8723b1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8723b1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8723b1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8723b1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if( BTC_PACKET_DHCP == type ||
-		BTC_PACKET_EAPOL == type || 
-		( (BTC_PACKET_ARP == type ) && (pCoexSta->bWiFiIsHighPriTask) ) )
-		{
-		halbtc8723b1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte				btInfo=0;
-	u1Byte				i, rspSource=0;
-	BOOLEAN				bWifiConnected=FALSE;
-	BOOLEAN				bBtBusy=FALSE;
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8723B_1ANT_MAX)
-		rspSource = BT_INFO_SRC_8723B_1ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	// if 0xff, it means BT is under WHCK test
-	if (btInfo == 0xff)
-		pCoexSta->bBtWhckTest = TRUE;
-	else
-		pCoexSta->bBtWhckTest = FALSE;
-
-	if(BT_INFO_SRC_8723B_1ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		if (pCoexSta->btRetryCnt >= 1)
-			pCoexSta->popEventCnt++;
-
-		if (pCoexSta->btInfoC2h[rspSource][2]&0x20)
-			pCoexSta->bC2hBtRemoteNameReq = TRUE;
-		else
-			pCoexSta->bC2hBtRemoteNameReq = FALSE;			
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2-90;
-			//pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-		
-		if (pCoexSta->btInfoC2h[rspSource][1] == 0x49)
-		{
-			pCoexSta->nA2DPBitPool = 
-				pCoexSta->btInfoC2h[rspSource][6]; 
-		}
-		else
-			pCoexSta->nA2DPBitPool = 0;
-
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE
-		if ((pBoardInfo->btdmAntDetFinish) && (pBoardInfo->btdmAntNumByAntDet == 2))
-		{
-			if(pCoexSta->bBtTxRxMask)
-			{
-				/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */				
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x1\n"));
-
-				//BT TRx Mask un-lock 0x2c[0], 0x30[0] = 1
-				pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x2c, 0x7c45); 
-				pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x30, 0x7c45); 
-	
-				pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x1);
-			}	
-		}
-		else	
-#endif			
-#endif
-
-		{
-			if(!pCoexSta->bBtTxRxMask)
-			{
-				/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */				
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n"));
-				pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15);
-
-				//BT TRx Mask lock 0x2c[0], 0x30[0] = 0
-				pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x2c, 0x7c44); 
-				pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x30, 0x7c44); 	
-			}
-		}
-		
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if(pCoexSta->btInfoExt & BIT1)
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				EXhalbtc8723b1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8723b1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-				
-		if(pCoexSta->btInfoExt & BIT3)
-		{
-			if(!pBtCoexist->bManualControl && !pBtCoexist->bStopCoexDm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-				halbtc8723b1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-			}
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-#if(BT_AUTO_REPORT_ONLY_8723B_1ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8723b1ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-		
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8723B_1ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	pCoexSta->nNumOfProfile = 0;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8723B_1ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-
-		pCoexSta->bBtHiPriLinkExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8723B_1ANT_B_FTP)
-		{
-			pCoexSta->bPanExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8723B_1ANT_B_A2DP)
-		{
-			pCoexSta->bA2dpExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8723B_1ANT_B_HID)
-		{
-			pCoexSta->bHidExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8723B_1ANT_B_SCO_ESCO)
-		{
-			pCoexSta->bScoExist = TRUE;
-			pCoexSta->nNumOfProfile++;
-		}
-		else
-			pCoexSta->bScoExist = FALSE;
-
-		if ((pCoexSta->bHidExist == FALSE) && (pCoexSta->bC2hBtInquiryPage == FALSE) &&( pCoexSta->bScoExist == FALSE))
-		{
-			if (pCoexSta->highPriorityTx  + pCoexSta->highPriorityRx >= 160) 		
-			{
-				pCoexSta->bHidExist = TRUE;
-				pCoexSta->wrongProfileNotification++;
-				pCoexSta->nNumOfProfile++;
-				btInfo = btInfo | 0x28;
-			}
-		}
-
-		//Add Hi-Pri Tx/Rx counter to avoid false detection
-		if (((pCoexSta->bHidExist) || (pCoexSta->bScoExist)) && (pCoexSta->highPriorityTx + pCoexSta->highPriorityRx >= 160)
-			 && (!pCoexSta->bC2hBtInquiryPage))
-			pCoexSta->bBtHiPriLinkExist = TRUE;
-			
-		if((btInfo&BT_INFO_8723B_1ANT_B_ACL_BUSY) && (pCoexSta->nNumOfProfile == 0))
-		{
-			if (pCoexSta->lowPriorityTx + pCoexSta->lowPriorityRx >= 160)
-			{
-				pCoexSta->bPanExist = TRUE;
-				pCoexSta->nNumOfProfile++;
-				pCoexSta->wrongProfileNotification++;
-				btInfo = btInfo | 0x88;
-			}
-		}
-	}
-
-	halbtc8723b1ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	btInfo = btInfo & 0x1f;  //mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41)
-	
-	if(!(btInfo&BT_INFO_8723B_1ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8723B_1ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8723B_1ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8723B_1ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8723B_1ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8723B_1ANT_B_ACL_BUSY)
-	{
-		if(BT_8723B_1ANT_BT_STATUS_ACL_BUSY != pCoexDm->btStatus)
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->btStatus = BT_8723B_1ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8723B_1ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-
-	if( (BT_8723B_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8723B_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		bBtBusy = TRUE;
-	else
-		bBtBusy = FALSE;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	halbtc8723b1ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8723b1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	)
-{
-	u4Byte	u4Tmp;
-	u1Byte	u1Tmpa,u1Tmpb, u1Tmpc;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF Status notify\n"));
-
-	if(BTC_RF_ON == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned ON!!\n"));
-		pBtCoexist->bStopCoexDm = FALSE;
-	}
-	else if(BTC_RF_OFF == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned OFF!!\n"));
-		
-		halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		//halbtc8723b1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF);
-		
-		halbtc8723b1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		pBtCoexist->bStopCoexDm = TRUE;
-
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-		u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
- 		u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-		u1Tmpc = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x, 0x76e=0x%x\n",
-			u4Tmp,  u1Tmpa, u1Tmpb, u1Tmpc));
-
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u4Byte	u4Tmp;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8723b1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-	halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-	//halbtc8723b1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF);
-
-	halbtc8723b1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-
-	EXhalbtc8723b1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-
-	pBtCoexist->bStopCoexDm = TRUE;	
-}
-
-VOID
-EXhalbtc8723b1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-
-		halbtc8723b1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8723b1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8723b1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		halbtc8723b1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-		//halbtc8723b1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF);
-
-		pBtCoexist->bStopCoexDm = TRUE;
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		pBtCoexist->bStopCoexDm = FALSE;
-		halbtc8723b1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8723b1ant_InitCoexDm(pBtCoexist);
-		halbtc8723b1ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8723b1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], *****************Coex DM Reset*****************\n"));
-
-	halbtc8723b1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x2, 0xfffff, 0x0);
-	halbtc8723b1ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8723b1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n", 
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n", 
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8723b1Ant, GLCoexVer8723b1Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8723B_1ANT == 0)
-	halbtc8723b1ant_QueryBtInfo(pBtCoexist);
-	halbtc8723b1ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	halbtc8723b1ant_MonitorBtCtr(pBtCoexist);
-	halbtc8723b1ant_MonitorWiFiCtr(pBtCoexist);
-#if BT_8723B_1ANT_ANTDET_ENABLE
-	halbtc8723b1ant_MonitorBtEnableDisable(pBtCoexist);
-#endif
-
-	if ( (pCoexSta->highPriorityTx  + pCoexSta->highPriorityRx < 50) && (pBtLinkInfo->bHidExist == TRUE))
-	{
-		pBtLinkInfo->bHidExist  = FALSE;
-	}
-
-	if( halbtc8723b1ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust )
-	{
-		halbtc8723b1ant_RunCoexistMechanism(pBtCoexist);	
-	}
-
-	pCoexSta->specialPktPeriodCnt++;
-
-	// sample to set bt to execute Ant detection
-	//pBtCoexist->fBtcSetBtAntDetection(pBtCoexist, 20, 14);
-/*
-	if (pPsdScan->bIsAntDetEnable)
-	{
-		 if (pPsdScan->nPSDGenCount > pPsdScan->realseconds)
-			pPsdScan->nPSDGenCount = 0;
-		 
-		halbtc8723b1ant_AntennaDetection(pBtCoexist, pPsdScan->realcentFreq,  pPsdScan->realoffset, pPsdScan->realspan,  pPsdScan->realseconds);	
-		pPsdScan->nPSDGenTotalCount +=2;
-		pPsdScan->nPSDGenCount += 2;
-	}
-*/	 	
-#endif
-}
-
-VOID
-EXhalbtc8723b1ant_AntennaDetection(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	)
-{
-	static u4Byte AntDetCount = 0, AntDetFailCount = 0;
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;	
-	BOOLEAN bScan, bRoam;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE	
-
-	if (seconds == 0)
-	{
-		pPsdScan->bAntDet_TryCount	= 0;
-		pPsdScan->bAntDet_FailCount	= 0;
-		AntDetCount = 0;
-		AntDetFailCount = 0;
-		pBoardInfo->btdmAntDetFinish = FALSE;
-		pBoardInfo->btdmAntNumByAntDet = 1;
-		return;
-	}
-
-	if (!pBoardInfo->btdmAntDetFinish)
-	{
-		pPsdScan->nAntDet_IntevalCount = pPsdScan->nAntDet_IntevalCount+2;
-
-		if (pPsdScan->nAntDet_IntevalCount >= BT_8723B_1ANT_ANTDET_RETRY_INTERVAL)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is up, Try Detect!!\n"));
-			halbtc8723b1ant_PSD_AntennaDetectionCheck(pBtCoexist);	
-			
-			if (pBoardInfo->btdmAntDetFinish)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Success!!\n"));
-#if 1
-				if (pBoardInfo->btdmAntNumByAntDet == 2)
-					halbtc8723b1ant_MechanismSwitch(pBtCoexist, TRUE);
-				else
-					halbtc8723b1ant_MechanismSwitch(pBtCoexist, FALSE);	
-#endif
-			}
-			else
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Fail!!\n"));
-				
-			pPsdScan->nAntDet_IntevalCount = 0;
-		}
-	else
-	{	
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is not up! (%d)\n", pPsdScan->nAntDet_IntevalCount));
-		}
-			
-	}
-#endif
-		
-		
-/*
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);	
-
-
-	pPsdScan->nAntDet_BTTxTime = seconds;  //0.42ms*50 = 20ms
-	pPsdScan->nAntDet_BTLEChannel = centFreq;		
-		
-	if (seconds == 0)
-		{
-		pPsdScan->bAntDet_TryCount	= 0;
-		pPsdScan->bAntDet_FailCount	= 0;
-		AntDetCount = 0;
-		AntDetFailCount = 0;
-		pBoardInfo->btdmAntDetFinish = FALSE;
-		pBoardInfo->btdmAntNumByAntDet = 1;
-			 return;
-	}
-	else
-	{
- 		AntDetCount++;
-	
-		pPsdScan->bAntDet_TryCount = AntDetCount;	
-				
-		if (bScan ||bRoam)
-		{
-			pBoardInfo->btdmAntDetFinish = FALSE;
-			pPsdScan->nAntDet_Result = 6;
-		}
-		else if (pCoexSta->nNumOfProfile >= 1) 
-		{
-			pBoardInfo->btdmAntDetFinish = FALSE;
-			pPsdScan->nAntDet_Result = 7;
-		}			
-		else if (!pPsdScan->nAntDet_IsAntDetAvailable)  //Antenna initial setup is not ready
-		{
-			pBoardInfo->btdmAntDetFinish = FALSE;
-			pPsdScan->nAntDet_Result = 9;
-		}				
-		else if (pCoexSta->bC2hBtInquiryPage)
-		{
-			pBoardInfo->btdmAntDetFinish = FALSE;
-			pPsdScan->nAntDet_Result = 10;
-		}	
-		else
-		{
-			//halbtc8723b1ant_PSD_AntennaDetection(pBtCoexist,  pPsdScan->nAntDet_BTTxTime, pPsdScan->nAntDet_BTLEChannel);			
-	}
-
-		if (!pBoardInfo->btdmAntDetFinish)
-			AntDetFailCount++;
-
-		pPsdScan->bAntDet_FailCount = AntDetFailCount;
-	}
-*/
-}
-
-VOID
-EXhalbtc8723b1ant_AntennaIsolation(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	)
-{
-
-
-}
-
-VOID
-EXhalbtc8723b1ant_PSDScan(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	)
-{
-
-
-}
-
-VOID
-EXhalbtc8723b1ant_DisplayAntDetection(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-	if (pPsdScan->bAntDet_TryCount != 0)
-	{
-		halbtc8723b1ant_PSD_ShowAntennaDetectResult(pBtCoexist);
-
-		if (pBoardInfo->btdmAntDetFinish)
-			halbtc8723b1ant_PSD_ShowData(pBtCoexist);
-		return;
-	}
-#endif
-	
-	//halbtc8723b1ant_ShowPSDData(pBtCoexist);
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b1Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b1Ant.h
deleted file mode 100644
index 5575bb5e87f5..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b1Ant.h
+++ /dev/null
@@ -1,338 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8723B 1ANT BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8723B_1ANT				1
-
-#define	BT_INFO_8723B_1ANT_B_FTP						BIT7
-#define	BT_INFO_8723B_1ANT_B_A2DP					BIT6
-#define	BT_INFO_8723B_1ANT_B_HID						BIT5
-#define	BT_INFO_8723B_1ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8723B_1ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8723B_1ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8723B_1ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8723B_1ANT_B_CONNECTION				BIT0
-
-#define	BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT		2
-
-#define  BT_8723B_1ANT_WIFI_NOISY_THRESH								50 //30   //max: 255								
-
-//for Antenna detection
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND					50
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			55
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_1ANT							35
-#define	BT_8723B_1ANT_ANTDET_RETRY_INTERVAL							10	//retry timer if ant det is fail, unit: second
-#define	BT_8723B_1ANT_ANTDET_ENABLE									0
-#define	BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE				0
-
-typedef enum _BT_INFO_SRC_8723B_1ANT{
-	BT_INFO_SRC_8723B_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723B_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8723B_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8723B_1ANT_MAX
-}BT_INFO_SRC_8723B_1ANT,*PBT_INFO_SRC_8723B_1ANT;
-
-typedef enum _BT_8723B_1ANT_BT_STATUS{
-	BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8723B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8723B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8723B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8723B_1ANT_BT_STATUS_MAX
-}BT_8723B_1ANT_BT_STATUS,*PBT_8723B_1ANT_BT_STATUS;
-
-typedef enum _BT_8723B_1ANT_WIFI_STATUS{
-	BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT				= 0x3,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8723B_1ANT_WIFI_STATUS_MAX
-}BT_8723B_1ANT_WIFI_STATUS,*PBT_8723B_1ANT_WIFI_STATUS;
-
-typedef enum _BT_8723B_1ANT_COEX_ALGO{
-	BT_8723B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8723B_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8723B_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8723B_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8723B_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8723B_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8723B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8723B_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8723B_1ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8723B_1ANT_COEX_ALGO,*PBT_8723B_1ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8723B_1ANT{
-	// hw setting
-	u1Byte		preAntPosType;
-	u1Byte		curAntPosType;
-	// fw mechanism
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	// sw mechanism
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	u4Byte		backupArfrCnt1;	// Auto Rate Fallback Retry cnt
-	u4Byte		backupArfrCnt2;	// Auto Rate Fallback Retry cnt
-	u2Byte		backupRetryLimit;
-	u1Byte		backupAmpduMaxTime;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-	u1Byte		preArfrType;
-	u1Byte		curArfrType;
-	u1Byte		preRetryLimitType;
-	u1Byte		curRetryLimitType;
-	u1Byte		preAmpduTimeType;
-	u1Byte		curAmpduTimeType;
-	u4Byte		nArpCnt;
-
-	u1Byte		errorCondition;
-} COEX_DM_8723B_1ANT, *PCOEX_DM_8723B_1ANT;
-
-typedef struct _COEX_STA_8723B_1ANT{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-	BOOLEAN					bBtHiPriLinkExist;
-	u1Byte					nNumOfProfile;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					specialPktPeriodCnt;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	s1Byte					btRssi;
-	BOOLEAN					bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8723B_1ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8723B_1ANT_MAX];
-	BOOLEAN					bBtWhckTest;
-	BOOLEAN					bC2hBtInquiryPage;
-	BOOLEAN					bC2hBtRemoteNameReq;				
-	BOOLEAN					bWiFiIsHighPriTask;		//Add for win8.1 page out issue
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	u4Byte					popEventCnt;
-	u1Byte					nScanAPNum;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;	
-
-	BOOLEAN					bCCKLock;
-	BOOLEAN					bPreCCKLock;
-	BOOLEAN					bCCKEverLock;
-	u1Byte					nCoexTableType;
-
-	BOOLEAN					bForceLpsOn;
-	u4Byte					wrongProfileNotification;
-
-	u1Byte					nA2DPBitPool;
-	u1Byte					nCutVersion;
-}COEX_STA_8723B_1ANT, *PCOEX_STA_8723B_1ANT;
-
-#define  BT_8723B_1ANT_ANTDET_PSD_POINTS			256	//MAX:1024
-#define  BT_8723B_1ANT_ANTDET_PSD_AVGNUM			1	//MAX:3
-#define	BT_8723B_1ANT_ANTDET_BUF_LEN				16
-
-typedef struct _PSDSCAN_STA_8723B_1ANT{
-
-u4Byte		 	nAntDet_BTLEChannel;  //BT LE Channel ex:2412
-u4Byte			nAntDet_BTTxTime;
-u4Byte			nAntDet_PrePSDScanPeakVal;
-BOOLEAN			nAntDet_IsAntDetAvailable;
-u4Byte			nAntDet_PSDScanPeakVal;
-BOOLEAN			nAntDet_IsBTReplyAvailable;
-u4Byte			nAntDet_PSDScanPeakFreq;
-
-u1Byte			nAntDet_Result;
-u1Byte			nAntDet_PeakVal[BT_8723B_1ANT_ANTDET_BUF_LEN];
-u1Byte			nAntDet_PeakFreq[BT_8723B_1ANT_ANTDET_BUF_LEN];
-u4Byte			bAntDet_TryCount;
-u4Byte			bAntDet_FailCount;
-u4Byte			nAntDet_IntevalCount;
-u4Byte			nAntDet_ThresOffset;
-
-u4Byte			nRealCentFreq;
-s4Byte			nRealOffset;
-u4Byte			nRealSpan;
-	
-u4Byte			nPSDBandWidth;  //unit: Hz
-u4Byte			nPSDPoint;		//128/256/512/1024
-u4Byte			nPSDReport[1024];  //unit:dB (20logx), 0~255
-u4Byte			nPSDReport_MaxHold[1024];  //unit:dB (20logx), 0~255
-u4Byte			nPSDStartPoint;
-u4Byte			nPSDStopPoint;
-u4Byte			nPSDMaxValuePoint;
-u4Byte			nPSDMaxValue;
-u4Byte			nPSDStartBase;
-u4Byte			nPSDAvgNum;	// 1/8/16/32
-u4Byte			nPSDGenCount;
-BOOLEAN			bIsPSDRunning;
-BOOLEAN			bIsPSDShowMaxOnly;
-} PSDSCAN_STA_8723B_1ANT, *PPSDSCAN_STA_8723B_1ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8723b1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723b1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723b1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8723b1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723b1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723b1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723b1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8723b1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	);
-VOID
-EXhalbtc8723b1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723b1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8723b1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723b1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723b1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723b1ant_AntennaDetection(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	);
-VOID
-EXhalbtc8723b1ant_AntennaIsolation(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	);
-
-VOID
-EXhalbtc8723b1ant_PSDScan(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	);
-VOID
-EXhalbtc8723b1ant_DisplayAntDetection(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b2Ant.c
deleted file mode 100644
index aa58bc1f9f90..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b2Ant.c
+++ /dev/null
@@ -1,4934 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8723B Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8723b2Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8723B_2ANT		GLCoexDm8723b2Ant;
-static PCOEX_DM_8723B_2ANT 	pCoexDm=&GLCoexDm8723b2Ant;
-static COEX_STA_8723B_2ANT		GLCoexSta8723b2Ant;
-static PCOEX_STA_8723B_2ANT	pCoexSta=&GLCoexSta8723b2Ant;
-
-const char *const GLBtInfoSrc8723b2Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8723b2Ant=20150119;
-u4Byte	GLCoexVer8723b2Ant=0x44;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8723b2ant_
-//============================================================
-u1Byte
-halbtc8723b2ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8723b2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8723b2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n",  btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n",  (bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-
-		bPreBtDisabled = bBtDisabled;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		if(bBtDisabled)
-		{
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		}
-	}
-}
-
-
-VOID
-halbtc8723b2ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-}
-
-VOID
-halbtc8723b2ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	if( (pCoexSta->lowPriorityTx > 1050)  && (!pCoexSta->bC2hBtInquiryPage))
-		pCoexSta->popEventCnt++;
-
-	if ( (pCoexSta->lowPriorityRx >= 950)  &&  (pCoexSta->lowPriorityRx >= pCoexSta->lowPriorityTx) && (!pCoexSta->bUnderIps) )
-	{
-		pBtLinkInfo->bSlaveRole = TRUE;
-	}
-	else
-	{
-		pBtLinkInfo->bSlaveRole = FALSE;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8723b2ant_MonitorWiFiCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u2Byte 	u2Tmp[3];
-	s4Byte	wifiRssi=0;
-	BOOLEAN bWifiBusy = FALSE, bWifiUnderBMode = FALSE;
-	static u1Byte nCCKLockCounter = 0;
-
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->nCRCOK_CCK = 0;
-		pCoexSta->nCRCOK_11g = 0;
-		pCoexSta->nCRCOK_11n = 0;
-		pCoexSta->nCRCOK_11nAgg = 0;
-
-		pCoexSta->nCRCErr_CCK = 0;
-		pCoexSta->nCRCErr_11g = 0;
-		pCoexSta->nCRCErr_11n = 0;
-		pCoexSta->nCRCErr_11nAgg = 0;	
-	}
-	else
-	{
-		pCoexSta->nCRCOK_CCK	= pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf88);
-		pCoexSta->nCRCOK_11g 	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf94);
-		pCoexSta->nCRCOK_11n	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf90);
-		pCoexSta->nCRCOK_11nAgg= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfb8);
-
-		pCoexSta->nCRCErr_CCK 	 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf84);
-		pCoexSta->nCRCErr_11g 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf96);
-		pCoexSta->nCRCErr_11n 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf92);
-		pCoexSta->nCRCErr_11nAgg = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfba);		
-	}
-
-	//reset counter
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x0);
-}
-
-VOID
-halbtc8723b2ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-BOOLEAN
-halbtc8723b2ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN	bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte			wifiRssiState=BTC_RSSI_STATE_HIGH;
-	
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-
-
-		wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist,3, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-
-		if ( (BTC_RSSI_STATE_HIGH ==wifiRssiState ) ||  (BTC_RSSI_STATE_LOW ==wifiRssiState ))
-		{
-			return TRUE;
-		}
-	
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8723b2ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO 	pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-#if(BT_AUTO_REPORT_ONLY_8723B_2ANT == 1)	// profile from bt patch
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-#else	// profile from bt stack
-	pBtLinkInfo->bBtLinkExist = pStackInfo->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pStackInfo->bScoExist;
-	pBtLinkInfo->bA2dpExist = pStackInfo->bA2dpExist;
-	pBtLinkInfo->bPanExist = pStackInfo->bPanExist;
-	pBtLinkInfo->bHidExist = pStackInfo->bHidExist;
-
-	//for win-8 stack HID report error
-	if(!pStackInfo->bHidExist)
-		pStackInfo->bHidExist = pCoexSta->bHidExist;  //sync  BTInfo with BT firmware and stack
-	// when stack HID report error, here we use the info from bt fw.
-	if(!pStackInfo->bBtLinkExist)
-		pStackInfo->bBtLinkExist = pCoexSta->bBtLinkExist;	
-#endif
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8723b2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8723B_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-		
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO only\n"));
-			algorithm = BT_8723B_2ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8723B_2ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8723B_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(HS) only\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(EDR) only\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID\n"));
-				algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(HS)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(EDR)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-#if 0
-				if(pStackInfo->numOfHid >= 2)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID*2 + A2DP\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-				else
-#endif
-				{			
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(HS)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(EDR)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(HS)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(EDR)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8723b2ant_SetFwDacSwingLevel(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			dacSwingLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	// There are several type of dacswing
-	// 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6
-	H2C_Parameter[0] = dacSwingLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Set Dac Swing Level=0x%x\n", dacSwingLvl));
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x64=0x%x\n", H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x64, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8723b2ant_SetFwDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = decBtPwrLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], decrease Bt Power level = %d, FW write 0x62=0x%x\n", 
-		decBtPwrLvl, H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x62, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8723b2ant_DecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s Dec BT power level = %d\n",  
-		(bForceExec? "force to":""), decBtPwrLvl));
-	pCoexDm->curBtDecPwrLvl = decBtPwrLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preBtDecPwrLvl == pCoexDm->curBtDecPwrLvl) 
-			return;
-	}
-	halbtc8723b2ant_SetFwDecBtPwr(pBtCoexist, pCoexDm->curBtDecPwrLvl);
-
-	pCoexDm->preBtDecPwrLvl = pCoexDm->curBtDecPwrLvl;
-}
-
-VOID
-halbtc8723b2ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8723b2ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8723b2ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8723b2ant_FwDacSwingLvl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			fwDacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set FW Dac Swing level = %d\n",  
-		(bForceExec? "force to":""), fwDacSwingLvl));
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preFwDacSwingLvl == pCoexDm->curFwDacSwingLvl) 
-			return;
-	}
-
-	halbtc8723b2ant_SetFwDacSwingLevel(pBtCoexist, pCoexDm->curFwDacSwingLvl);
-
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-}
-
-VOID
-halbtc8723b2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xffffc);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8723b2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8723b2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8723b2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!")) );
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8723b2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	//return;
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8723b2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8723b2ant_SetDacSwingReg(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte			level
-	)
-{
-	u1Byte	val=(u1Byte)level;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Write SwDacSwing = 0x%x\n", level));
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x883, 0x3e, val);
-}
-
-VOID
-halbtc8723b2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	if(bSwDacSwingOn)
-	{
-		halbtc8723b2ant_SetDacSwingReg(pBtCoexist, swDacSwingLvl);
-	}
-	else
-	{
-		halbtc8723b2ant_SetDacSwingReg(pBtCoexist, 0x18);
-	}
-}
-
-
-VOID
-halbtc8723b2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8723b2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8723b2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc05, 0x30, 0x3);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc05, 0x30, 0x1);
-	}
-}
-
-VOID
-halbtc8723b2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8723b2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8723b2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	//=================BB AGC Gain Table
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6e1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6d1B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6c1C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6b1D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6a1E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x691F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x68200001);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table Off!\n"));
-	 	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xaa1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa91B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa81C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa71D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa61E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa51F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa4200001);
-	}
-	
-	
-	//=================RF Gain
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x1);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x0);
-
-	// set rssiAdjustVal for wifi module.
-	if(bAgcTableEn)
-	{
-		rssiAdjustVal = 8;
-	}
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-VOID
-halbtc8723b2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8723b2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8723b2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8723b2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8723b2ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8723b2ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexSta->nCoexTableType = type;
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5afa5afa, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x5ada5ada, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0xffffffff, 0xffffffff, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5fff5fff, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55ff55ff, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 7:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 8:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 9:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 10:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 11:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 12:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 13:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 14:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 15:
-			halbtc8723b2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8723b2ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8723b2ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8723b2ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8723b2ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8723b2ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8723b2ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8723b2ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-
-
-	 if ( (pCoexSta->bA2dpExist) && (pCoexSta->bHidExist) )
-	 {
-		byte5 = byte5 | 0x1;
-	 }
-	 
-	H2C_Parameter[0] = byte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = byte5;
-
-	pCoexDm->psTdmaPara[0] = byte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = byte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x60(5bytes)=0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-VOID
-halbtc8723b2ant_SwMechanism1(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bShrinkRxLPF,
-	IN	BOOLEAN 	bLowPenaltyRA,
-	IN	BOOLEAN		bLimitedDIG, 
-	IN	BOOLEAN		bBTLNAConstrain
-	) 
-{
-	/*
-	u4Byte	wifiBw;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	
-	if(BTC_WIFI_BW_HT40 != wifiBw)  //only shrink RF Rx LPF for HT40
-	{
-		if (bShrinkRxLPF)
-			bShrinkRxLPF = FALSE;
-	}
-	*/
-	
-	//halbtc8723b2ant_RfShrink(pBtCoexist, NORMAL_EXEC, bShrinkRxLPF);
-	halbtc8723b2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8723b2ant_SwMechanism2(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bAGCTableShift,
-	IN	BOOLEAN 	bADCBackOff,
-	IN	BOOLEAN		bSWDACSwing,
-	IN	u4Byte		dacSwingLvl
-	) 
-{
-	//halbtc8723b2ant_AgcTable(pBtCoexist, NORMAL_EXEC, bAGCTableShift);
-	//halbtc8723b2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, bADCBackOff);
-	//halbtc8723b2ant_DacSwing(pBtCoexist, NORMAL_EXEC, bSWDACSwing, dacSwingLvl);
-}
-
-VOID
-halbtc8723b2ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	PBTC_BOARD_INFO pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte			fwVer=0, u4Tmp=0;
-	BOOLEAN			bPgExtSwitch=FALSE;
-	BOOLEAN			bUseExtSwitch=FALSE;
-	u1Byte			H2C_Parameter[2] ={0};
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_EXT_SWITCH, &bPgExtSwitch);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);	// [31:16]=fw ver, [15:0]=fw sub ver
-
-	if((fwVer>0 && fwVer<0xc0000) || bPgExtSwitch)
-		bUseExtSwitch = TRUE;
-
-	if(bInitHwCfg)
-	{
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x39, 0x8, 0x1);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x974, 0xff);
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x944, 0x3, 0x3);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x930, 0x77);
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x1);
-
-		if(fwVer >= 0x180000)
-		{
-			/* Use H2C to set GNT_BT to High to avoid A2DP click */
-			H2C_Parameter[0] = 1;
-		pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-		}
-		else
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18);
-		}
-		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); //WiFi TRx Mask off
-		//remove due to interrupt is disabled that polling c2h will fail and delay 100ms.
-		//pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x01); //BT TRx Mask off
-
-		if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-		{
-			//tell firmware "no antenna inverse"
-			H2C_Parameter[0] = 0;
-		}
-		else
-		{
-			//tell firmware "antenna inverse"
-			H2C_Parameter[0] = 1;
-		}
-
-		if (bUseExtSwitch)
-		{
-			//ext switch type
-			H2C_Parameter[1] = 1;
-		}
-		else
-		{
-			//int switch type
-			H2C_Parameter[1] = 0;
-		}
-		pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-	}
-	else
-	{
-		if(fwVer >= 0x180000)
-		{
-			/* Use H2C to set GNT_BT to "Control by PTA"*/
-			H2C_Parameter[0] = 0;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);			
-		}
-		else
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x0);
-		}
-	}
-
-	// ext switch setting
-	if(bUseExtSwitch)
-	{
-		if (bInitHwCfg)
-		{
-			// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-			u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-			u4Tmp &=~BIT23;
-			u4Tmp |= BIT24;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-		}
-		
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0); // fixed internal switch S1->WiFi, S0->BT
-		switch(antPosType)
-		{
-			case BTC_ANT_WIFI_AT_MAIN:
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x1);	// ext switch main at wifi
-				break;
-			case BTC_ANT_WIFI_AT_AUX:
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x92c, 0x3, 0x2);	// ext switch aux at wifi
-				break;
-		}	
-	}
-	else	// internal switch
-	{
-		if (bInitHwCfg)
-		{
-			// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-			u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-			u4Tmp |= BIT23;
-			u4Tmp &=~BIT24;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-		}
-		
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x64, 0x1, 0x0); //fixed external switch S1->Main, S0->Aux
-		switch(antPosType)
-		{
-			case BTC_ANT_WIFI_AT_MAIN:
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0); // fixed internal switch S1->WiFi, S0->BT
-				break;
-			case BTC_ANT_WIFI_AT_AUX:
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x280); // fixed internal switch S0->WiFi, S1->BT
-				break;
-		}
-	}
-}
-
-VOID
-halbtc8723b2ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN			bTurnOnByCnt=FALSE;
-	u1Byte			psTdmaTypeByCnt=0;
-	u1Byte			wifiRssiState1, btRssiState;
-	s1Byte			nWiFiDurationAdjust = 0x0;
-	u1Byte			psTdmaByte4Modify = 0x0;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-
-	
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-		(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if (!(BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState)) && bTurnOn)
-	{
-		type = type +100;  //for WiFi RSSI low or BT RSSI low
-		pCoexDm->bIsSwitchTo1dot5Ant = TRUE;
-	}
-	else
-	{
-		pCoexDm->bIsSwitchTo1dot5Ant = FALSE;
-	}
-
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-
-	if (pCoexSta->nScanAPNum <= 5)
-	{	       	
-		if (pCoexSta->nA2DPBitPool >= 45)
-		  nWiFiDurationAdjust = -15;
-		else if (pCoexSta->nA2DPBitPool >= 35)
-		  nWiFiDurationAdjust = -10;	
-		else
- 		  nWiFiDurationAdjust = 5;		
-	}
-	else  if  (pCoexSta->nScanAPNum <= 20)
-	{		   	
-		if (pCoexSta->nA2DPBitPool >= 45)
-		  nWiFiDurationAdjust = -15;
-		else if (pCoexSta->nA2DPBitPool >= 35)
-		  nWiFiDurationAdjust = -10;
-		else
- 		 nWiFiDurationAdjust = 0;	    	
-	}
-	else if  (pCoexSta->nScanAPNum <= 40)
-	{
-	 	if (pCoexSta->nA2DPBitPool >= 45)
-		  nWiFiDurationAdjust = -15;
-		else if (pCoexSta->nA2DPBitPool >= 35)
-		  nWiFiDurationAdjust = -10;	
-		else
- 		  nWiFiDurationAdjust = -5;	
-	}
-	else
-	{
-	 	if (pCoexSta->nA2DPBitPool >= 45)
-		  nWiFiDurationAdjust = -15;
-		else if (pCoexSta->nA2DPBitPool >= 35)
-		  nWiFiDurationAdjust = -10;	
-		else
- 		  nWiFiDurationAdjust = -10;	
-	}
-
-	if ( (pBtLinkInfo->bSlaveRole == TRUE)	&& (pBtLinkInfo->bA2dpExist) )
-		psTdmaByte4Modify = 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-		
-	
-	if(bTurnOn)
-	{
-		switch(type)
-		{
-			case 1:
-			default:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c+nWiFiDurationAdjust, 0x03, 0xf1, 0x90|psTdmaByte4Modify);
-				break;
-			case 2:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d+nWiFiDurationAdjust, 0x03, 0xf1,  0x90|psTdmaByte4Modify);
-				break;
-			case 3:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0xf1,  0x90|psTdmaByte4Modify);
-				break;
-			case 4:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x03, 0xf1,  0x90|psTdmaByte4Modify);
-				break;
-			case 5:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c+nWiFiDurationAdjust, 0x3, 0x70,  0x90|psTdmaByte4Modify);				
-				break;
-			case 6:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d+nWiFiDurationAdjust, 0x3, 0x70,  0x90|psTdmaByte4Modify);
-				break;
-			case 7:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0x70,  0x90|psTdmaByte4Modify);
-				break;
-			case 8:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x10, 0x3, 0x70,  0x90|psTdmaByte4Modify);
-				break;
-			case 9:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c+nWiFiDurationAdjust, 0x03, 0xf1,  0x90|psTdmaByte4Modify);
-				break;
-			case 10:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d+nWiFiDurationAdjust, 0x03, 0xf1,  0x90|psTdmaByte4Modify);
-				break;
-			case 11:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0xf1,  0x90|psTdmaByte4Modify);
-				break;
-			case 12:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x3, 0xf1,  0x90|psTdmaByte4Modify);
-				break;
-			case 13:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c+nWiFiDurationAdjust, 0x3, 0x70,  0x90|psTdmaByte4Modify);		
-				break;
-			case 14:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d+nWiFiDurationAdjust, 0x3, 0x70,  0x90|psTdmaByte4Modify);		
-				break;
-			case 15:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0x70,  0x90|psTdmaByte4Modify);		
-				break;
-			case 16:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x3, 0x70,  0x90|psTdmaByte4Modify);		
-				break;
-			case 17:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x2f, 0x2f, 0x60, 0x90);
-				break;
-			case 18:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				break;			
-			case 19:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0xe1, 0x90);
-				break;
-			case 20:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0x60, 0x90);
-				break;
-			case 21:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x03, 0x70, 0x90);
-				break;	
-			case 71:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c+nWiFiDurationAdjust, 0x03, 0xf1, 0x90);
-				break;
-			case 101:
-			case 105:
-			case 171:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x3a+nWiFiDurationAdjust, 0x03, 0x70, 0x50|psTdmaByte4Modify);
-				break;
-			case 102:
-			case 106:
-			case 110:
-			case 114:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x2d+nWiFiDurationAdjust, 0x03, 0x70, 0x50|psTdmaByte4Modify);
-				break;	
-			case 103:
-			case 107:
-			case 111:
-			case 115:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1c, 0x03, 0x70, 0x50|psTdmaByte4Modify);
-				break;		
-			case 104:
-			case 108:
-			case 112:
-			case 116:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x10, 0x03, 0x70, 0x50|psTdmaByte4Modify);
-				break;	
-			case 109:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90|psTdmaByte4Modify);
-				break;
-			case 113:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x70, 0x90|psTdmaByte4Modify);
-				break;
-			case 121:	
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x03, 0x70, 0x90|psTdmaByte4Modify);
-				break;	
-			case 22:
-			case 122:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x35, 0x03, 0x71, 0x11);
-				break;
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(type)
-		{
-			case 0:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-			case 1:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x48, 0x0);
-				break;
-			default:
-				halbtc8723b2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8723b2ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8723b2ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8723b2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8723b2ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.			
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8723b2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-
-VOID
-halbtc8723b2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8723b2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8723b2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8723b2ant_DecBtPwr(pBtCoexist, FORCE_EXEC, 0);
-
-	halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	pCoexSta->popEventCnt = 0;
-
-}
-
-VOID
-halbtc8723b2ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	BOOLEAN	bWifiConnected=FALSE;
-	BOOLEAN	bLowPwrDisable=TRUE;
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-	
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-
-	if(bScan || bLink || bRoam)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi link process + BT Inq/Page!!\n"));
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-	}
-	else if(bWifiConnected)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT Inq/Page!!\n"));
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi no-link + BT Inq/Page!!\n"));
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	}	
-	
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-/*
-	pCoexDm->bNeedRecover0x948 = TRUE;
-	pCoexDm->backup0x948 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-
-	halbtc8723b2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_AUX, FALSE, FALSE);
-*/	
-}
-
-
-VOID
-halbtc8723b2ant_ActionWiFiLinkProcess(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u1Byte 	u1Tmpa, u1Tmpb;
-	
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-	halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-
-	halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-
-	 u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-        u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	 u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-
-	 RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x76e=0x%x\n",
-	   	      u4Tmp,  u1Tmpa, u1Tmpb));
-}
-
-BOOLEAN
-halbtc8723b2ant_ActionWifiIdleProcess(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	//wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES-20, 0);
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-
-	// define the office environment
-	if(BTC_RSSI_HIGH(wifiRssiState1) && 
-			(pCoexSta->bHidExist == TRUE) && (pCoexSta->bA2dpExist == TRUE))
-	{
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi  idle process for BT HID+A2DP exist!!\n"));
-		
-		halbtc8723b2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x6);
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-		// sw all off
-		halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	  	return TRUE;
-	}
-	else
-	{
-		halbtc8723b2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-		return FALSE;	
-	}
-	
-	
-}
-
-
-
-BOOLEAN
-halbtc8723b2ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			btRssiState=BTC_RSSI_STATE_HIGH;
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-	BOOLEAN			bBtHsOn=FALSE, bLowPwrDisable=FALSE;
-	BOOLEAN			bAsus8723b=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected)
-	{
-		bLowPwrDisable = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-		halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-connected idle!!\n"));
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-		
- 		halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		bCommon = TRUE;
-	}
-	else
-	{
-		if(BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-			halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-			halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);		
-			halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0xb);
-			halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	      	halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else if(BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bBtHsOn)
-				return FALSE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-			halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-			halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-			halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-			halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0xb);
-			halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else
-		{
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bWifiBusy)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_IS_ASUS_8723B, &bAsus8723b);
-				if(!bAsus8723b)
-					bCommon = FALSE;
-				else
-					bCommon = halbtc8723b2ant_ActionWifiIdleProcess(pBtCoexist);	
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-				//bCommon = FALSE;	
-				bCommon = halbtc8723b2ant_ActionWifiIdleProcess(pBtCoexist);			
-			}
-		}	
-	}
-
-	return bCommon;
-}
-VOID
-halbtc8723b2ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bScoHid,
-	IN	BOOLEAN			bTxPause,
-	IN	u1Byte			maxInterval
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-		{
-			if(bScoHid)
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;	
-					}
-					else
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-			else
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->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 = pCoexSta->btRetryCnt;
-
-		if ( (pCoexSta->lowPriorityTx) > 1050 ||  (pCoexSta->lowPriorityRx) > 1250 )
-			retryCount++;
-		
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-		if(maxInterval == 1)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-
-				if(pCoexDm->curPsTdma == 71)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-					pCoexDm->psTdmaDuAdjType = 13;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				
-				if(result == -1)
-				{					
-					if(pCoexDm->curPsTdma == 5)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;
-					}
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-					pCoexDm->psTdmaDuAdjType = 71;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-					pCoexDm->psTdmaDuAdjType = 9;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 71)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-						pCoexDm->psTdmaDuAdjType = 71;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 2)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 3)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-		if( !bScan && !bLink && !bRoam)
-		{
-			halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-}
-
-// SCO only or SCO+PAN(HS)
-VOID
-halbtc8723b2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, btRssiState;
-	u4Byte	wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 4);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for SCO quality at 11b/g mode
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-	else  //for SCO quality & wifi performance balance at 11n mode
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-	}
-
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-	halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); //for voice quality
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x4);			
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x4);	
-		}		
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x4);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x4);
-		}		
-	}
-}
-
-
-VOID
-halbtc8723b2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, btRssiState;	
-	u4Byte	wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 9);
-	}
-
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-	
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-	}
-	else
-	{
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-	}
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}	
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8723b2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-
-	// define the office environment
-	if( (apNum >= 10) && BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		//DbgPrint(" AP#>10(%d)\n", apNum);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-		
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);	
-		halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-		halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);			
-					
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-		// sw mechanism
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x18);		
-		}
-		return;
-		
-	}
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-		
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-	
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-	}
-	else
-	{
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-	}
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8723b2ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 2);
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8723b2ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState,wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 10);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-	}
-	else
-	{
-		halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-	}
-	
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-
-//PAN(HS) only
-VOID
-halbtc8723b2ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8723b2ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))		
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	else
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 12);
-		
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-		else
-			halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-	}
-	
-	// sw mechanism	
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8723b2ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))	
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 3);
-			//halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 11);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780);
-		}
-		else
-		{
-			halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-			//halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		}
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 2);
-	}
-	else
-	{
-		halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		//halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-	}
-	
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8723b2ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState,wifiRssiState1,  btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8723b2ant_BtRssiState(2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-		else
-			halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-	}
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8723b2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8723b2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	//btRssiState = halbtc8723b2ant_BtRssiState(2, 29, 0);
-	wifiRssiState1 = halbtc8723b2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8723b2ant_BtRssiState(3, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES, 37);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x5);
-
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_LEGACY == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(btRssiState))
-			halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		else if(BTC_RSSI_MEDIUM(btRssiState))
-			halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-			halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else	
-	{	// only 802.11N mode we have to dec bt power to 4 degree
-		if(BTC_RSSI_HIGH(btRssiState))
-		{
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-			// need to check ap Number of Not
-			if(apNum < 10)
-				halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-			else
-				halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		}
-		else if(BTC_RSSI_MEDIUM(btRssiState))
-			halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		else	
-			halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8723b2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-	}
-	
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8723b2ant_ActionBtWhckTest(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8723b2ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{		
-	halbtc8723b2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8723b2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8723b2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8723b2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8723b2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8723b2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-}
-
-VOID
-halbtc8723b2ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN				bWifiUnder5G=FALSE, bBtHsOn=FALSE;
-	u1Byte				btInfoOriginal=0, btRetryCnt=0;
-	u1Byte				algorithm=0;
-	u4Byte				numOfWifiLink=0;
-	u4Byte				wifiLinkStatus=0;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bMiracastPlusBt=FALSE;
-	BOOLEAN				bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	if(pCoexSta->bBtWhckTest)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under WHCK TEST!!!\n"));
-		halbtc8723b2ant_ActionBtWhckTest(pBtCoexist);
-		return;
-	}
-
-	algorithm = halbtc8723b2ant_ActionAlgorithm(pBtCoexist);
-	if(pCoexSta->bC2hBtInquiryPage && (BT_8723B_2ANT_COEX_ALGO_PANHS!=algorithm))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under inquiry/page scan !!\n"));
-		halbtc8723b2ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else
-	{
-		/*
-		if(pCoexDm->bNeedRecover0x948)
-		{
-			pCoexDm->bNeedRecover0x948 = FALSE;
-			pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, pCoexDm->backup0x948);
-		}
-		*/
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-	if(bScan || bLink || bRoam)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], WiFi is under Link Process !!\n"));
-		halbtc8723b2ant_ActionWiFiLinkProcess(pBtCoexist);
-		return;
-	}
-
-	//for P2P
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  Multi-Port numOfWifiLink = %d, wifiLinkStatus = 0x%x\n", numOfWifiLink,wifiLinkStatus) );
-
-		if(pBtLinkInfo->bBtLinkExist)
-		{
-			bMiracastPlusBt = TRUE;
-		}
-		else
-		{
-			bMiracastPlusBt = FALSE;
-		}
-		
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-		halbtc8723b2ant_ActionWifiMultiPort(pBtCoexist);
-		
-		return;
-	}
-	else
-	{
-		bMiracastPlusBt = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-	}
-
-	pCoexDm->curAlgorithm = algorithm;
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Algorithm = %d \n", pCoexDm->curAlgorithm));
-
-	if(halbtc8723b2ant_IsCommonAction(pBtCoexist))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant common.\n"));
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{
-		if(pCoexDm->curAlgorithm != pCoexDm->preAlgorithm)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 
-				pCoexDm->preAlgorithm, pCoexDm->curAlgorithm));
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8723B_2ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO.\n"));
-				halbtc8723b2ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID.\n"));
-				halbtc8723b2ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP.\n"));
-				halbtc8723b2ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n"));
-				halbtc8723b2ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n"));
-				halbtc8723b2ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HS mode.\n"));
-				halbtc8723b2ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n"));
-				halbtc8723b2ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-				halbtc8723b2ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-				halbtc8723b2ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8723B_2ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n"));
-				halbtc8723b2ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n"));
-				halbtc8723b2ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8723b2ant_WifiOffHwCfg(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN	bIsInMpMode = FALSE;
-	u1Byte H2C_Parameter[2] ={0};
-	u4Byte fwVer=0;
-
-	// set wlan_act to low
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780); //WiFi goto standby while GNT_BT 0-->1
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	if(fwVer >= 0x180000)
-	{
-	/* Use H2C to set GNT_BT to HIGH */
-	H2C_Parameter[0] = 1;
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-	}
-	else
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18);
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_IS_IN_MP_MODE, &bIsInMpMode);
-	if(!bIsInMpMode)
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x0); //BT select s0/s1 is controlled by BT
-	else
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x67, 0x20, 0x1); //BT select s0/s1 is controlled by WiFi
-}
-
-VOID
-halbtc8723b2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte	u4Tmp=0, fwVer;
-	u2Byte				u2Tmp=0;
-	u1Byte	u1Tmp=0;
-	u1Byte				H2C_Parameter[2] ={0};
-		
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	//0xf0[15:12] --> Chip Cut information 
-	pCoexSta->nCutVersion = (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xf1) & 0xf0) >> 4;
-
-	// backup rf 0x1e value
-	pCoexDm->btRf0x1eBackup = 
-		pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);	
-
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	//Antenna config	
-	halbtc8723b2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_MAIN, TRUE, FALSE);
-	pCoexSta->disVerInfoCnt = 0;
-
-	// PTA parameter
-	halbtc8723b2ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-	
-	// Enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4); //0x76e[3] =1, WLAN_Act control by PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x3);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x1);
-}
-
-//============================================================
-// work around function start with wa_halbtc8723b2ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8723b2ant_
-//============================================================
-VOID
-EXhalbtc8723b2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u2Byte u2Tmp=0x0;
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x67, 0x20);
-
-	// enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly.
-	u2Tmp = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x2);
-	pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x2, u2Tmp|BIT0|BIT1);
-
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x948, 0x0);
-
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-		pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-	}
-	else
-	{
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-			// set to S1
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			pBoardInfo->btdmAntPos = BTC_ANTENNA_AT_AUX_PORT;
-		}
-	}
-}
-
-VOID
-EXhalbtc8723b2ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u1Byte u1Tmp=0x4; /* Set BIT2 by default since it's 2ant case */
-
-	// 
-	// S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info)
-	// Local setting bit define
-	//	BIT0: "0" for no antenna inverse; "1" for antenna inverse 
-	//	BIT1: "0" for internal switch; "1" for external switch
-	//	BIT2: "0" for one antenna; "1" for two antenna
-	// NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-	 	u1Tmp |= 0x1;	// antenna inverse
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0xfe08, u1Tmp);
-	}
-	else
-	{
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			u1Tmp |= 0x1;	// antenna inverse
-		}
-
-		if(pBtCoexist->chipInterface == BTC_INTF_PCI)
-		{	
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x384, u1Tmp);
-		}
-		else if(pBtCoexist->chipInterface == BTC_INTF_SDIO)
-		{
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x60, u1Tmp);
-		}			
-	}
-}
-
-VOID
-EXhalbtc8723b2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8723b2ant_InitHwConfig(pBtCoexist, TRUE);
-}
-
-VOID
-EXhalbtc8723b2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8723b2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8723b2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-	u4Byte				faOfdm, faCck;
-	u4Byte				fwVer=0, btPatchVer=0;
-	static u1Byte			PopReportIn10s = 0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)/ %c", "Version Coex/ Fw/ Patch/ Cut", \
-		GLCoexVerDate8723b2Ant, GLCoexVer8723b2Ant, fwVer, btPatchVer, btPatchVer, pCoexSta->nCutVersion+65);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	PopReportIn10s++;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d/ %d] ", "BT [status/ rssi/ retryCnt/ popCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi-100, pCoexSta->btRetryCnt, pCoexSta->popEventCnt);
-	CL_PRINTF(cliBuf);
-
-	if (PopReportIn10s >= 5)
-	{
-		pCoexSta->popEventCnt = 0;	
-		PopReportIn10s = 0;
-	}
-	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d / %d / %d", "SCO/HID/PAN/A2DP/NameReq/WHQL", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist, pCoexSta->bC2hBtRemoteNameReq, pCoexSta->bBtWhckTest );
-	CL_PRINTF(cliBuf);
-
-	if (pStackInfo->bProfileNotified)
-	{
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Role", \
-		(pBtLinkInfo->bSlaveRole )? "Slave":"Master");
-		CL_PRINTF(cliBuf);	
-	}	
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "A2DP Rate/Bitpool", \
-		(btInfoExt&BIT0)? "BR":"EDR", pCoexSta->nA2DPBitPool);
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8723B_2ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8723b2Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	// Sw mechanism	
-	if(pBtCoexist->bManualControl)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism] (before Manual)============");			
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism] (before Manual) ============");			
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	}
-
-	psTdmaCase = pCoexDm->curPsTdma;
-
-	if (pCoexDm->bIsSwitchTo1dot5Ant)
-		psTdmaCase = psTdmaCase + 100;
-		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)", "PS TDMA", \
-		pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-		pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase, 
-			(pCoexDm->bCurPsTdmaOn? "On":"Off"),
-			(pCoexDm->bAutoTdmaAdjust? "Adj":"Fix") );
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Coex Table Type", \
-			pCoexSta->nCoexTableType);
-		CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "DecBtPwr/ IgnWlanAct", \
-		pCoexDm->curBtDecPwrLvl, pCoexDm->bCurIgnoreWlanAct);
-	CL_PRINTF(cliBuf);
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x880);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x778/0x880[29:25]", \
-		u1Tmp[0], (u4Tmp[0]&0x3e000000) >> 25);
-	CL_PRINTF(cliBuf);
-
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x67);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x948/ 0x67[5] / 0x765", \
-		u4Tmp[0], ((u1Tmp[0]&0x20)>> 5), u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-	
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x92c);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x930);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x944);	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x92c[1:0]/ 0x930[7:0]/0x944[1:0]", \
-		u4Tmp[0]&0x3, u4Tmp[1]&0xff, u4Tmp[2]&0x3);
-	CL_PRINTF(cliBuf);
-
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x39);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-	u1Tmp[2] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x64);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "0x38[11]/0x40/0x4c[24:23]/0x64[0]", \
-		((u1Tmp[0] & 0x8)>>3), u1Tmp[1], ((u4Tmp[0]&0x01800000)>>23), u1Tmp[2]&0x1);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x49c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xc50(dig)/0x49c(null-drop)", \
-		u4Tmp[0]&0xff, u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda8);
-	u4Tmp[3] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcf0);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5b);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-
-	faOfdm = ((u4Tmp[0]&0xffff0000) >> 16) +  ((u4Tmp[1]&0xffff0000) >> 16) + (u4Tmp[1] & 0xffff) +  (u4Tmp[2] & 0xffff) + \
-		             ((u4Tmp[3]&0xffff0000) >> 16) + (u4Tmp[3] & 0xffff) ;
-	faCck = (u1Tmp[0] << 8) + u1Tmp[1];
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "OFDM-CCA/OFDM-FA/CCK-FA", \
-		u4Tmp[0]&0xffff, faOfdm, faCck);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_OK CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCOK_CCK, pCoexSta->nCRCOK_11g, pCoexSta->nCRCOK_11n, pCoexSta->nCRCOK_11nAgg);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_Err CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCErr_CCK, pCoexSta->nCRCErr_11g, pCoexSta->nCRCErr_11n, pCoexSta->nCRCErr_11nAgg);
-	CL_PRINTF(cliBuf);	
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(high-pri rx/tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri rx/tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8723B_2ANT == 1)
-	//halbtc8723b2ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8723b2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		halbtc8723b2ant_WifiOffHwCfg(pBtCoexist);
-		halbtc8723b2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		halbtc8723b2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-		halbtc8723b2ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8723b2ant_InitCoexDm(pBtCoexist);
-		halbtc8723b2ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8723b2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8723b2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u4Byte 	u4Tmp;
-	u1Byte 	u1Tmpa, u1Tmpb;	
-	
-
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x948);
-	u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-	
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &pCoexSta->nScanAPNum);		
-	}
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x76e=0x%x\n",
-		u4Tmp,  u1Tmpa, u1Tmpb));
-}
-
-VOID
-EXhalbtc8723b2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8723b2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	u1Byte			apNum=0;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-		{
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-			if(apNum < 10)
-				H2C_Parameter[2] = 0x30;
-			else
-				H2C_Parameter[2] = 0x20;
-	}
-	}
-	
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);	
-}
-
-VOID
-EXhalbtc8723b2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8723b2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtBusy=FALSE, bLimitedDig=FALSE;
-	BOOLEAN			bWifiConnected=FALSE;
-	static BOOLEAN		bPreScoExist=FALSE;
-	u4Byte				raMask=0x0;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8723B_2ANT_MAX)
-		rspSource = BT_INFO_SRC_8723B_2ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), return for Manual CTRL<===\n"));
-		return;
-	}
-
-	// if 0xff, it means BT is under WHCK test
-	if (btInfo == 0xff)
-		pCoexSta->bBtWhckTest = TRUE;
-	else
-		pCoexSta->bBtWhckTest = FALSE;
-
-	if(BT_INFO_SRC_8723B_2ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		if (pCoexSta->btRetryCnt >= 1)
-			pCoexSta->popEventCnt++;
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		if (pCoexSta->btInfoC2h[rspSource][2]&0x20)
-			pCoexSta->bC2hBtRemoteNameReq = TRUE;
-		else
-			pCoexSta->bC2hBtRemoteNameReq = FALSE;			
-
-		if (pCoexSta->btInfoC2h[rspSource][1] == 0x49)
-		{
-			pCoexSta->nA2DPBitPool = 
-				pCoexSta->btInfoC2h[rspSource][6]; 
-		}
-		else
-			pCoexSta->nA2DPBitPool = 0;
-
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-		if (pCoexSta->bBtTxRxMask)
-		{
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x01 => Need to switch BT TRx Mask */				
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x01\n"));
-			pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x01);
-		}
-
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if( (pCoexSta->btInfoExt & BIT1) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				EXhalbtc8723b2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8723b2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-		
-		if( (pCoexSta->btInfoExt & BIT3) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-			halbtc8723b2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-#if(BT_AUTO_REPORT_ONLY_8723B_2ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8723b2ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8723B_2ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8723B_2ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8723B_2ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8723B_2ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8723B_2ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8723B_2ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-
-		if ( (pCoexSta->bHidExist == FALSE) && (pCoexSta->bC2hBtInquiryPage == FALSE) && (pCoexSta->bScoExist == FALSE))
-		{
-			if (pCoexSta->highPriorityTx  + pCoexSta->highPriorityRx >= 160) 		
-			{
-				pCoexSta->bHidExist = TRUE;
-				btInfo = btInfo | 0x28;
-			}
-		}
-	}
-
-	halbtc8723b2ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	if(!(btInfo&BT_INFO_8723B_2ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8723B_2ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8723B_2ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8723B_2ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8723B_2ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8723B_2ANT_B_ACL_BUSY)
-	{
-		pCoexDm->btStatus = BT_8723B_2ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8723B_2ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-	
-	if( (BT_8723B_2ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8723B_2ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bBtBusy = TRUE;
-		bLimitedDig = TRUE;
-	}
-	else
-	{
-		bBtBusy = FALSE;
-		bLimitedDig = FALSE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	pCoexDm->bLimitedDig = bLimitedDig;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bLimitedDig);
-
-	halbtc8723b2ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8723b2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8723b2ant_WifiOffHwCfg(pBtCoexist);
-	//remove due to interrupt is disabled that polling c2h will fail and delay 100ms.
-	//pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15); //BT goto standby while GNT_BT 1-->0
-	halbtc8723b2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	
-	EXhalbtc8723b2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8723b2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		halbtc8723b2ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8723b2ant_InitCoexDm(pBtCoexist);
-		halbtc8723b2ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8723b2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	//static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(pCoexSta->disVerInfoCnt <= 5)
-	{
-		pCoexSta->disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8723b2Ant, GLCoexVer8723b2Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-
-		if (pCoexSta->disVerInfoCnt == 3)
-		{
-			//Antenna config to set 0x765 = 0x0 (GNT_BT control by PTA) after initial 
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set GNT_BT control by PTA\n"));
-			halbtc8723b2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_MAIN, FALSE, FALSE);
-		}
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8723B_2ANT == 0)
-	halbtc8723b2ant_QueryBtInfo(pBtCoexist);
-	halbtc8723b2ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	halbtc8723b2ant_MonitorBtCtr(pBtCoexist);
-	halbtc8723b2ant_MonitorWiFiCtr(pBtCoexist);
-	
-	//for some BT speaker that Hi-Pri pkt appear begore start play, this will cause HID exist
-	if ( (pCoexSta->highPriorityTx  + pCoexSta->highPriorityRx < 50) && (pBtLinkInfo->bHidExist == TRUE))
-	{
-		pBtLinkInfo->bHidExist  = FALSE;
-	}
-	
-	if( halbtc8723b2ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust)
-	{
-		halbtc8723b2ant_RunCoexistMechanism(pBtCoexist);
-	}
-#endif
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b2Ant.h
deleted file mode 100644
index 348dae834199..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8723b2Ant.h
+++ /dev/null
@@ -1,235 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8723B 2Ant BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8723B_2ANT				1
-
-
-#define	BT_INFO_8723B_2ANT_B_FTP						BIT7
-#define	BT_INFO_8723B_2ANT_B_A2DP					BIT6
-#define	BT_INFO_8723B_2ANT_B_HID						BIT5
-#define	BT_INFO_8723B_2ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8723B_2ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8723B_2ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8723B_2ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8723B_2ANT_B_CONNECTION				BIT0
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT		2
-
-
-#define	BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES				42  //WiFi RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation
-#define	BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES				46 //BT RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation
-
-typedef enum _BT_INFO_SRC_8723B_2ANT{
-	BT_INFO_SRC_8723B_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723B_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8723B_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8723B_2ANT_MAX
-}BT_INFO_SRC_8723B_2ANT,*PBT_INFO_SRC_8723B_2ANT;
-
-typedef enum _BT_8723B_2ANT_BT_STATUS{
-	BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8723B_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8723B_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8723B_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8723B_2ANT_BT_STATUS_MAX
-}BT_8723B_2ANT_BT_STATUS,*PBT_8723B_2ANT_BT_STATUS;
-
-typedef enum _BT_8723B_2ANT_COEX_ALGO{
-	BT_8723B_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8723B_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8723B_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8723B_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8723B_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8723B_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8723B_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8723B_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8723B_2ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8723B_2ANT_COEX_ALGO,*PBT_8723B_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8723B_2ANT{
-	// fw mechanism
-	u1Byte		preBtDecPwrLvl;
-	u1Byte		curBtDecPwrLvl;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bResetTdmaAdjust;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	BOOLEAN		bNeedRecover0x948;
-	u4Byte		backup0x948;
-
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	BOOLEAN		bIsSwitchTo1dot5Ant;
-} COEX_DM_8723B_2ANT, *PCOEX_DM_8723B_2ANT;
-
-typedef struct _COEX_STA_8723B_2ANT{	
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	BOOLEAN				bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8723B_2ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8723B_2ANT_MAX];
-	BOOLEAN 				bBtWhckTest;
-	BOOLEAN					bC2hBtInquiryPage;
-	BOOLEAN					bC2hBtRemoteNameReq;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	u4Byte					popEventCnt;
-    	u1Byte					nScanAPNum;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;
-
-	u1Byte					nCoexTableType;
-	BOOLEAN					bForceLpsOn;
-
-	u1Byte					disVerInfoCnt;
-
-	u1Byte					nA2DPBitPool;
-	u1Byte					nCutVersion;
-}COEX_STA_8723B_2ANT, *PCOEX_STA_8723B_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8723b2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723b2ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723b2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8723b2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8723b2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8723b2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723b2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8723b2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8723b2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723b2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8723b2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8723b2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a1Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a1Ant.c
deleted file mode 100644
index cd8ff0a8b31a..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a1Ant.c
+++ /dev/null
@@ -1,3718 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8812A Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8812a1Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8812A_1ANT		GLCoexDm8812a1Ant;
-static PCOEX_DM_8812A_1ANT 	pCoexDm=&GLCoexDm8812a1Ant;
-static COEX_STA_8812A_1ANT		GLCoexSta8812a1Ant;
-static PCOEX_STA_8812A_1ANT	pCoexSta=&GLCoexSta8812a1Ant;
-
-const char *const GLBtInfoSrc8812a1Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8812a1Ant=20140708;
-u4Byte	GLCoexVer8812a1Ant=0x52;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8812a1ant_
-//============================================================
-u1Byte
-halbtc8812a1ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8812a1ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8812a1ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-//to check 0x430/0x434 is correct??
-VOID
-halbtc8812a1ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-//to check 0x42a ??
-VOID
-halbtc8812a1ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-//to check 0x456??
-VOID
-halbtc8812a1ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8812a1ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType
-	)
-{
-	switch(raMaskType)
-	{
-		case 0:	// normal mode
-			halbtc8812a1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0);
-			break;
-		case 1:	// disable cck 1/2
-			halbtc8812a1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x00000003);
-			break;
-		case 2:	// disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4
-			halbtc8812a1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0001f1f7);
-			break;
-		default:
-			break;
-	}
-
-	halbtc8812a1ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8812a1ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8812a1ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-}
-
-VOID
-halbtc8812a1ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-VOID
-halbtc8812a1ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	u1Byte	dataLen=3;
-	u1Byte	buf[5] = {0};
-
-	if(!pBtCoexist->btInfo.bBtDisabled)
-	{
-		if(!pCoexSta->btInfoQueryCnt ||
-			(pCoexSta->btInfoC2hCnt[BT_INFO_SRC_8812A_1ANT_BT_RSP]-pCoexSta->btInfoQueryCnt)>2)
-		{
-			buf[0] = dataLen;
-			buf[1] = 0x1;	// polling enable, 1=enable, 0=disable
-			buf[2] = 0x2;	// polling time in seconds
-			buf[3] = 0x1;	// auto report enable, 1=enable, 0=disable
-				
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_INFO, (PVOID)&buf[0]);
-		}
-	}
-	pCoexSta->btInfoQueryCnt++;
-}
-
-VOID
-halbtc8812a1ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp, u4Tmp1;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp, u1Tmp1;
-	s4Byte			wifiRssi;
-	static u1Byte		NumOfBtCounterChk = 0;
-		
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	if( (pCoexSta->lowPriorityTx > 1150)  && (!pCoexSta->bC2hBtInquiryPage))
-		pCoexSta->popEventCnt++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		regHPRx, regHPTx, regLPRx, regLPTx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-
-	if ((regHPTx == 0) && (regHPRx ==0) && (regLPTx == 0) && (regLPRx == 0))
-	{
-		NumOfBtCounterChk++;
-		if (NumOfBtCounterChk >= 3)
-		{
-			halbtc8812a1ant_QueryBtInfo(pBtCoexist);
-			NumOfBtCounterChk = 0;
-		}
-	}
-}
-
-//to check registers
-VOID
-halbtc8812a1ant_MonitorWiFiCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u2Byte 	u2Tmp[3];
-	s4Byte	wifiRssi=0;
-	BOOLEAN bWifiBusy = FALSE, bWifiUnderBMode = FALSE;
-	static u1Byte nCCKLockCounter = 0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->nCRCOK_CCK = 0;
-		pCoexSta->nCRCOK_11g = 0;
-		pCoexSta->nCRCOK_11n = 0;
-		pCoexSta->nCRCOK_11nAgg = 0;
-
-		pCoexSta->nCRCErr_CCK = 0;
-		pCoexSta->nCRCErr_11g = 0;
-		pCoexSta->nCRCErr_11n = 0;
-		pCoexSta->nCRCErr_11nAgg = 0;	
-	}
-	else
-	{
-		pCoexSta->nCRCOK_CCK	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf04);
-		pCoexSta->nCRCOK_11g 	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf14);
-		pCoexSta->nCRCOK_11n	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf10);
-		pCoexSta->nCRCOK_11nAgg= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf40);
-
-		pCoexSta->nCRCErr_CCK 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf06);
-		pCoexSta->nCRCErr_11g 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf16);
-		pCoexSta->nCRCErr_11n 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf12);
-		pCoexSta->nCRCErr_11nAgg = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf42);		
-	}
-
-
-	//reset counter
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xb58, 0x1, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xb58, 0x1, 0x0);
-
-	if ( (bWifiBusy) && (wifiRssi >= 30) && (!bWifiUnderBMode))
-	{
-		if ( (pCoexDm->btStatus == BT_8812A_1ANT_BT_STATUS_ACL_BUSY) ||
-			(pCoexDm->btStatus == BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-			(pCoexDm->btStatus == BT_8812A_1ANT_BT_STATUS_SCO_BUSY) )
-		{
-			if (pCoexSta->nCRCOK_CCK >(pCoexSta->nCRCOK_11g + pCoexSta->nCRCOK_11n + 
-				pCoexSta->nCRCOK_11nAgg) )
-			{
-				if (nCCKLockCounter < 5)
-				 nCCKLockCounter++;
-			}
-			else
-			{
-				if (nCCKLockCounter > 0)
-				 nCCKLockCounter--;
-			}
-
-		}
-		else
-		{
-			if (nCCKLockCounter > 0)
-			  nCCKLockCounter--;
-		}
-	}
-	else
-	{
-		if (nCCKLockCounter > 0)
-			nCCKLockCounter--;
-	}
-
-	if (!pCoexSta->bPreCCKLock)
-	{
-
-		if (nCCKLockCounter >= 5)
-		 pCoexSta->bCCKLock = TRUE;
-		else
-		 pCoexSta->bCCKLock = FALSE;			
-	}
-	else
-	{
-		if (nCCKLockCounter == 0)
-		 pCoexSta->bCCKLock = FALSE;
-		else
-		 pCoexSta->bCCKLock = TRUE;		
-	}
-
-	pCoexSta->bPreCCKLock =  pCoexSta->bCCKLock;	
-		
-
-}
-
-BOOLEAN
-halbtc8812a1ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN bWifiConnected=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8812a1ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8812a1ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8812A_1ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO only\n"));
-			algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID only\n"));
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP only\n"));
-				algorithm = BT_8812A_1ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(HS) only\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(EDR) only\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID\n"));
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(HS)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(EDR)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP\n"));
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(HS)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(EDR)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(HS)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(EDR)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8812a1ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8812a1ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8812a1ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-//to check
-VOID
-halbtc8812a1ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte	tmpU1;
-
-	tmpU1 = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd);
-	tmpU1 |= BIT0;
-	if(bLowPenaltyRa)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set low penalty!!\n"));
-		tmpU1 &= ~BIT2;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set normal!!\n"));
-		tmpU1 |= BIT2;
-	}
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, tmpU1);
-}
-
-VOID
-halbtc8812a1ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8812a1ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8812a1ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8812a1ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8812a1ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8812a1ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** CoexTable(%d) **********\n", type));
-	
-	pCoexSta->nCoexTableType = type;
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaa5a5a, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0xaa5a5a5a, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 7:
-			halbtc8812a1ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8812a1ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte	dataLen=3;
-	u1Byte	buf[5] = {0};
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Ignore Wlan_Act\n",
-		(bEnable? "Enable":"Disable")));
-
-	buf[0] = dataLen;
-	buf[1] = 0x1;			// OP_Code
-	buf[2] = 0x1;			// OP_Code_Length
-	if(bEnable)
-		buf[3] = 0x1;		// OP_Code_Content
-	else
-		buf[3] = 0x0;
-		
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);	
-}
-
-VOID
-halbtc8812a1ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8812a1ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8812a1ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8812a1ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8812a1ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8812a1ant_SwMechanism(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN 		bLowPenaltyRA
-	) 
-{
-	halbtc8812a1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-//to check bForceExec
-VOID
-halbtc8812a1ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	u1Byte			u1Tmp=0;
-
-	pCoexDm->curAntPosType = antPosType;
-	
-	if(bInitHwCfg)
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb3, 0x77);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x900, 0x00000400);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76d, 0x1);
-	}
-	else if(bWifiOff)
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb3, 0x77);
-		u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb7);
-		u1Tmp &= ~BIT3;
-		u1Tmp |= BIT2;
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb7, u1Tmp);
-	}
-
-	if(bForceExec || (pCoexDm->curAntPosType != pCoexDm->preAntPosType))
-	{		
-		// ext switch setting
-		switch(antPosType)
-		{
-			case BTC_ANT_PATH_WIFI:
-				u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb7);
-				u1Tmp |= BIT3;
-				u1Tmp &= ~BIT2; 		
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb7, u1Tmp);
-				break;
-			case BTC_ANT_PATH_BT:
-				u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb7);
-				u1Tmp &= ~BIT3;
-				u1Tmp |= BIT2;
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb7, u1Tmp);
-				break;
-			default:
-			case BTC_ANT_PATH_PTA:
-				u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb7);
-				u1Tmp |= BIT3;
-				u1Tmp &= ~BIT2; 		
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb7, u1Tmp);
-				break;
-		}
-	}
-	
-	pCoexDm->preAntPosType = pCoexDm->curAntPosType;
-}
-
-VOID
-halbtc8812a1ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		if(byte1&BIT4 && !(byte1&BIT5))
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-			realByte1 &= ~BIT4;
-			realByte1 |= BIT5;
-
-			realByte5 |= BIT5;
-			realByte5 &= ~BIT6;
-		}
-	}
-
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-
-VOID
-halbtc8812a1ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	PBTC_BOARD_INFO	pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bTurnOnByCnt=FALSE, bWifiBusy=FALSE, bWiFiNoisy=FALSE;
-	u1Byte			psTdmaTypeByCnt=0, rssiAdjustVal=0;
-	u1Byte			psTdmaByte4Val = 0x50, psTdmaByte0Val = 0x51, psTdmaByte3Val =  0x10;
-	s1Byte			nWiFiDurationAdjust = 0x0;
-	static BOOLEAN	 bPreWifiBusy=FALSE;
-
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);	
-
-	if (bWifiBusy != bPreWifiBusy)
-	{
-		 bForceExec = TRUE;	
-		 bPreWifiBusy = bWifiBusy;
-	}
-
-	if (pCoexDm->bCurPsTdmaOn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-			pCoexDm->curPsTdma));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(off, %d) **********\n", 
-			pCoexDm->curPsTdma));
-	}
-			
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}
-
-	if (pCoexSta->nScanAPNum <= 5)
-	 	nWiFiDurationAdjust = 2;
-	else if  (pCoexSta->nScanAPNum >= 40)
-	 	nWiFiDurationAdjust = -15;	
-	else if  (pCoexSta->nScanAPNum >= 20)
-	 	nWiFiDurationAdjust = -10;	
-	
-	if (!pCoexSta->bForceLpsOn)  //only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30
-	{
-		psTdmaByte0Val = 0x61;  //no null-pkt
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle
-	}
-	
-	if (  (type == 3) || (type == 13) || (type == 14) )
-	{
-		psTdmaByte4Val = psTdmaByte4Val & 0xbf;  //no dynamic slot for multi-profile
-	
-		if (!bWifiBusy)
-		 psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-	}
-	
-	if (pBtLinkInfo->bSlaveRole == TRUE)
-		psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-		
-	if(bTurnOn)
-	{	 
-		switch(type)
-		{
-			default:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1a, 0x1a, 0x0, psTdmaByte4Val);
-				break;
-			case 1:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x3a+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);								
-				break;
-			case 2:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x2d+nWiFiDurationAdjust, 0x03, psTdmaByte3Val, psTdmaByte4Val);							
-				break;
-			case 3:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1d, 0x1d, 0x0, psTdmaByte4Val);
-				break;
-			case 4:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x14, 0x0);
-				break;
-			case 5:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x15, 0x3, 0x11, 0x11);
-				break;
-			case 6:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x20, 0x3, 0x11, 0x11);
-				break;
-			case 7:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x13, 0xc, 0x5, 0x0, 0x0);
-				break;
-			case 8:	
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;
-			case 9:	
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x3, psTdmaByte3Val, psTdmaByte4Val);				
-				break;
-			case 10:	
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0xa, 0x0, 0x40);
-				break;
-			case 11:	
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, psTdmaByte0Val, 0x21, 0x03, psTdmaByte3Val, psTdmaByte4Val);			
-				break;
-			case 12:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x0a, 0x0a, 0x0, 0x50);
-				break;
-			case 13:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x12, 0x12, 0x0, psTdmaByte4Val);
-				break;
-			case 14:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x21, 0x3, 0x10, psTdmaByte4Val);
-				break;
-			case 15:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0x3, 0x8, 0x0);
-				break;
-			case 16:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x10, 0x0);
-				break;
-			case 18:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;			
-			case 20:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x3f, 0x03, 0x11, 0x10);
-				break;
-			case 21:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x11);
-				break;
-			case 22:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x10);
-				break;
-			case 23:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x18);
-				break;
-			case 24:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x3, 0x31, 0x18);
-				break;
-			case 25:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 26:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				break;
-			case 27:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x98);
-				break;
-			case 28:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x69, 0x25, 0x3, 0x31, 0x0);
-				break;
-			case 29:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xab, 0x1a, 0x1a, 0x1, 0x10);
-				break;
-			case 30:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x30, 0x3, 0x10, 0x10);
-				break;
-			case 31:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1a, 0x1a, 0, 0x58);
-				break;
-			case 32:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x35, 0x3, 0x11, 0x11);
-				break;
-			case 33:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xa3, 0x25, 0x3, 0x30, 0x90);
-				break;
-			case 34:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x53, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 35:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x63, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 36:
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x12, 0x3, 0x14, 0x50);
-				break;
-			case 40: // SoftAP only with no sta associated,BT disable ,TDMA mode for power saving
-				/* here softap mode screen off will cost 70-80mA for phone */
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x23, 0x18, 0x00, 0x10, 0x24);
-				break;	
-		}
-	}
-	else
-	{		
-
-		// disable PS tdma
-		switch(type)
-		{
-			case 8: //PTA Control
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-				break;
-			case 0:
-			default:  //Software control, Antenna at BT side
-				halbtc8812a1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				break;
-		}
-	}
-	rssiAdjustVal =0;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssiAdjustVal);
-
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-BOOLEAN
-halbtc8812a1ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected && 
-		BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n"));
-		
- 		//halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-
-		//halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT connected-idle!!\n"));
-
-		//halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-
-		//halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE != pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT Busy!!\n"));
-
-		//halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-		
-		bCommon = TRUE;
-	}
-	else
-	{
-		if (bWifiBusy)			
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-		}
-		
-		bCommon = FALSE;
-	}
-	
-	return bCommon;
-}
-
-
-VOID
-halbtc8812a1ant_TdmaDurationAdjustForAcl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0, btInfoExt;
-	static BOOLEAN	bPreWifiBusy=FALSE;
-	BOOLEAN			bWifiBusy = FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjustForAcl()\n"));
-
-	if(BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY == wifiStatus) 
-		bWifiBusy = TRUE;
-	else
-		bWifiBusy = FALSE;	 	
-
-	if( (BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN == wifiStatus) ||
-		(BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifiStatus) ||
-		(BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT == wifiStatus) )
-	{
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 3 &&
-			pCoexDm->curPsTdma != 9 )
-		{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-			pCoexDm->psTdmaDuAdjType = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n= 3;
-			result = 0;
-			WaitCount = 0;
-		}		
-		return;
-	}
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-		pCoexDm->psTdmaDuAdjType = 2;
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-		retryCount = pCoexSta->btRetryCnt;
-		btInfoExt = pCoexSta->btInfoExt;
-
-		if ( (pCoexSta->lowPriorityTx) > 1150 ||  (pCoexSta->lowPriorityRx) > 1250 )
-			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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		if(result == -1)
-		{
-			if( (BT_INFO_8812A_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 1)
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-				pCoexDm->psTdmaDuAdjType = 11;
-			}
-		}
-		else if(result == 1)
-		{
-			if( (BT_INFO_8812A_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 11)
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-				pCoexDm->psTdmaDuAdjType = 1;
-			}
-		}
-		else	  //no change
-		{
-			/* Bryant Modify	
-			if(bWifiBusy != bPreWifiBusy)  //if busy / idle change
-			{
-				bPreWifiBusy = bWifiBusy;
-				halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, pCoexDm->curPsTdma);
-			}
-			*/
-		
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-				pCoexDm->curPsTdma));
-		}
-
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 9 &&
-			pCoexDm->curPsTdma != 11 )
-		{
-			// recover to previous adjust type
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-	}
-}
-
-VOID
-halbtc8812a1ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8812a1ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8812a1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8812a1ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.			
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8812a1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8812a1ant_ActionWifiOnly(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-	halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-}
-
-VOID
-halbtc8812a1ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte		btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-			halbtc8812a1ant_ActionWifiOnly(pBtCoexist);
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		}
-	}
-}
-
-//=============================================
-//
-//	Software Coex Mechanism start
-//
-//=============================================
-
-// SCO only or SCO+PAN(HS)
-
-/*
-VOID
-halbtc8812a1ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-
-VOID
-halbtc8812a1ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8812a1ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8812a1ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8812a1ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(HS) only
-VOID
-halbtc8812a1ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8812a1ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8812a1ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8812a1ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-VOID
-halbtc8812a1ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-*/
-
-//=============================================
-//
-//	Non-Software Coex Mechanism start
-//
-//=============================================
-VOID
-halbtc8812a1ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8812a1ant_ActionHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-	halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8812a1ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bWifiConnected=FALSE, bApEnable=FALSE, bWifiBusy=FALSE, bBtBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	if((!bWifiConnected) && (!pCoexSta->bWiFiIsHighPriTask))
-	{
-		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	 	halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);		
-	}
-	else if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist) || (pBtLinkInfo->bA2dpExist))
-	{
-		// SCO/HID/A2DP  busy
-		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if ((pBtLinkInfo->bPanExist) || (bWifiBusy))
-	{
-		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);		
-		
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	else
-	{
-		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	}
-}
-
-VOID
-halbtc8812a1ant_ActionBtScoHidOnlyBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	// tdma and coex table
-
-	if(pBtLinkInfo->bScoExist)
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-	else //HID
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-}
-
-VOID
-halbtc8812a1ant_ActionWifiConnectedBtAclBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	u1Byte		btRssiState;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	btRssiState = halbtc8812a1ant_BtRssiState(2, 28, 0);	
-
-	if ( (pCoexSta->lowPriorityRx >= 950)  && (!pCoexSta->bUnderIps) )
-	{
-		pBtLinkInfo->bSlaveRole = TRUE;
-	}
-	else
-	{
-		pBtLinkInfo->bSlaveRole = FALSE;
-	}
-
-	if(pBtLinkInfo->bHidOnly)  //HID
-	{
-		halbtc8812a1ant_ActionBtScoHidOnlyBusy(pBtCoexist, wifiStatus);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		return;
-	}
-	else if(pBtLinkInfo->bA2dpOnly)  //A2DP		
-	{
-		if(BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifiStatus)
-		{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		else
-		{
-			halbtc8812a1ant_TdmaDurationAdjustForAcl(pBtCoexist, wifiStatus);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-			pCoexDm->bAutoTdmaAdjust = TRUE;
-		}
-	}
-	else if ( ((pBtLinkInfo->bA2dpExist) && (pBtLinkInfo->bPanExist)) ||
-		       (pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist&&pBtLinkInfo->bPanExist) ) //A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP)
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else if(pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist)  //HID+A2DP
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-	}
-	else if( (pBtLinkInfo->bPanOnly) || (pBtLinkInfo->bHidExist&&pBtLinkInfo->bPanExist) ) //PAN(OPP,FTP), HID+PAN(OPP,FTP)			
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{		
-		//BT no-profile busy (0x9)
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);	
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}	
-}
-
-VOID
-halbtc8812a1ant_ActionWifiNotConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// power save state
-	halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-	halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8812a1ant_ActionWifiNotConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8812A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-		{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	 	else
-	 	{
-		        halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-	}
-	else if( (BT_8812A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8812a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8812a1ant_ActionWifiNotConnectedAssoAuth(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if( (pBtLinkInfo->bScoExist)  || (pBtLinkInfo->bHidExist) ||  (pBtLinkInfo->bA2dpExist) )
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 4);		
-	}
-	else if (pBtLinkInfo->bPanExist)   			
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 4);		
-	}
-	else	
-	{		
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8812a1ant_ActionWifiConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8812A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-	 	{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	 	else
-	 	{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	}
-	else if( (BT_8812A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8812a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//Bryant Add
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8812a1ant_ActionWifiConnectedSpecialPacket(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-
-	halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist) || (pBtLinkInfo->bA2dpExist))
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if(pBtLinkInfo->bPanExist) 
-	{
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else	
-	{		
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8812a1ant_ActionWifiConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN 	bWifiBusy=FALSE;
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-	BOOLEAN		bUnder4way=FALSE, bApEnable=FALSE;
-	u4Byte		wifiBw;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect()===>\n"));
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-	if(bUnder4way)
-	{
-		halbtc8812a1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n"));
-		return;
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	if(bScan || bLink || bRoam)
-	{
-		if(bScan)	
-			halbtc8812a1ant_ActionWifiConnectedScan(pBtCoexist);
-		else
-			halbtc8812a1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	
-	// power save state
-	if(!bApEnable && BT_8812A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus && !pBtCoexist->btLinkInfo.bHidOnly)
-	{
-		if(pBtCoexist->btLinkInfo.bA2dpOnly)	//A2DP
-			{			
-			if(!bWifiBusy)
-		     		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);				
-			else //busy
-			{
-				if  (pCoexSta->nScanAPNum >= BT_8812A_1ANT_WIFI_NOISY_THRESH)  //no force LPS, no PS-TDMA, use pure TDMA
-				{
- 					halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);								
-				}
-				else
-				{
-					halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);					
-				}
-			}
-		}
-		else if ((pCoexSta->bPanExist == FALSE) && (pCoexSta->bA2dpExist == FALSE) && (pCoexSta->bHidExist == FALSE))
- 			halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-	else
-		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(!bWifiBusy)
-	{
-		if(BT_8812A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8812a1ant_ActionWifiConnectedBtAclBusy(pBtCoexist, 
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else if( (BT_8812A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8812a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else
-		{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);
-			if ( (pCoexSta->highPriorityTx) + (pCoexSta->highPriorityRx) <= 60 )
-				halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-			else
-				halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7); 		 
-		}
-	}
-	else
-	{
-		if(BT_8812A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8812a1ant_ActionWifiConnectedBtAclBusy(pBtCoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else if( (BT_8812A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8812a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else 
-		{
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, FALSE, FALSE);	
-			if ( (pCoexSta->highPriorityTx) + (pCoexSta->highPriorityRx) <= 60 )
-				halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-			else
-				halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7); 
-		}
-	}
-}
-
-VOID
-halbtc8812a1ant_RunSwCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte				algorithm=0;
-
-	algorithm = halbtc8812a1ant_ActionAlgorithm(pBtCoexist);
-	pCoexDm->curAlgorithm = algorithm;
-
-	if(halbtc8812a1ant_IsCommonAction(pBtCoexist))
-	{
-
-	}
-	else
-	{
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8812A_1ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = SCO.\n"));
-				//halbtc8812a1ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID.\n"));
-				//halbtc8812a1ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP.\n"));
-				//halbtc8812a1ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP+PAN(HS).\n"));
-				//halbtc8812a1ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR).\n"));
-				//halbtc8812a1ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HS mode.\n"));
-				//halbtc8812a1ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN+A2DP.\n"));
-				//halbtc8812a1ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR)+HID.\n"));
-				//halbtc8812a1ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP+PAN.\n"));
-				//halbtc8812a1ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8812A_1ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP.\n"));
-				//halbtc8812a1ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = coexist All Off!!\n"));
-				//halbtc8812a1ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8812a1ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bIncreaseScanDevNum=FALSE;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	BOOLEAN	bMiracastPlusBt=FALSE;
-	u1Byte	aggBufSize=5;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0, wifiBw;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pBtCoexist->bStopCoexDm)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	if( (BT_8812A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8812A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bIncreaseScanDevNum = TRUE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_INC_SCAN_DEV_NUM, &bIncreaseScanDevNum);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  Multi-Port numOfWifiLink = %d, wifiLinkStatus = 0x%x\n", numOfWifiLink,wifiLinkStatus) );
-
-		if(pBtLinkInfo->bBtLinkExist)
-		{
-			halbtc8812a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1);
-			bMiracastPlusBt = TRUE;
-		}
-		else
-		{
-			halbtc8812a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-			bMiracastPlusBt = FALSE;
-		}
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-		halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-
-		if ( (pBtLinkInfo->bA2dpExist) && (pCoexSta->bC2hBtInquiryPage) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );	
-			halbtc8812a1ant_ActionBtInquiry(pBtCoexist);
-		}
-		else
-			halbtc8812a1ant_ActionWifiMultiPort(pBtCoexist);
-		
-		return;
-	}
-	else
-	{
-		bMiracastPlusBt = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if ( (pBtLinkInfo->bBtLinkExist) && (bWifiConnected) )
-	{
-		halbtc8812a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 0, 1); 
-
-		if(pBtLinkInfo->bScoExist)
-			halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, TRUE, FALSE, 0x5);
-		else
-		{
-			if (BTC_WIFI_BW_HT40==wifiBw)
-			 halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x10);	
-			else
-			 halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);		
-		}
-
-		halbtc8812a1ant_SwMechanism(pBtCoexist, TRUE);
-		halbtc8812a1ant_RunSwCoexistMechanism(pBtCoexist);  //just print debug message
-	}
-	else
-	{
-		halbtc8812a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0); 
-
-		halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x5);
-
-		halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-		halbtc8812a1ant_RunSwCoexistMechanism(pBtCoexist); ////just print debug message
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  BT Is Inquirying \n") );		
-		halbtc8812a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8812a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	
-	if(!bWifiConnected)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is non connected-idle !!!\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-		if(bScan || bLink || bRoam)
-		{
-			 if (bScan)	
-		   		halbtc8812a1ant_ActionWifiNotConnectedScan(pBtCoexist);	
-			 else
-		    		halbtc8812a1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);	
-		}
-		else
-			halbtc8812a1ant_ActionWifiNotConnected(pBtCoexist);
-	}
-	else	// wifi LPS/Busy
-	{
-		halbtc8812a1ant_ActionWifiConnected(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8812a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-
-	// sw all off
-	halbtc8812a1ant_SwMechanism(pBtCoexist, FALSE);
-	
-	//halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	//halbtc8812a1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	pCoexSta->popEventCnt = 0;
-}
-
-VOID
-halbtc8812a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	u4Byte	u4Tmp=0;
-	u2Byte	u2Tmp=0;
-	u1Byte	u1Tmp=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 1Ant Init HW Config!!\n"));
-	
-	//ant sw control to BT
-	halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, TRUE, FALSE);
-
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	// PTA parameter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, 0x0);
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, 0xffff);
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, 0x55555555);
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, 0x55555555);
-
-	// coex parameters
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x1);
-
-	// enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-
-	// enable PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x20);
-
-	// bt clock related
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4);
-	u1Tmp |= BIT7;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4, u1Tmp);
-
-	// bt clock related
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x7);
-	u1Tmp |= BIT1;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x7, u1Tmp);
-}
-
-//============================================================
-// work around function start with wa_halbtc8812a1ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8812a1ant_
-//============================================================
-VOID
-EXhalbtc8812a1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8812a1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8812a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8812a1ant_InitHwConfig(pBtCoexist, TRUE, bWifiOnly);
-	pBtCoexist->bStopCoexDm = FALSE;
-}
-
-VOID
-EXhalbtc8812a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-
-	pBtCoexist->bStopCoexDm = FALSE;
-	
-	halbtc8812a1ant_InitCoexDm(pBtCoexist);
-
-	halbtc8812a1ant_QueryBtInfo(pBtCoexist);
-}
-
-VOID
-EXhalbtc8812a1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO 	pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte 			cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-	if(pBtCoexist->bStopCoexDm)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%d/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8812a1Ant, GLCoexVer8812a1Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-					
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist);
-	CL_PRINTF(cliBuf);	
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8812A_1ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8812a1Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	if(!pBtCoexist->bManualControl)
-	{
-		// Sw mechanism 
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %d ", "DelBA/ BtCtrlAgg/ AggSize", \
-			(pBtCoexist->btInfo.bRejectAggPkt? "Yes":"No"), (pBtCoexist->btInfo.bBtCtrlAggBufSize? "Yes":"No"),
-				pBtCoexist->btInfo.aggBufSize);
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Rate Mask", \
-				pBtCoexist->btInfo.raMask);
-		CL_PRINTF(cliBuf);
-
-		// Fw mechanism 	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-		CL_PRINTF(cliBuf);	
-
-		psTdmaCase = pCoexDm->curPsTdma;
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase);
-		CL_PRINTF(cliBuf);
-
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Latest error condition(should be 0)", \
-			pCoexDm->errorCondition);
-		CL_PRINTF(cliBuf);
-		
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IgnWlanAct", \
-			pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-	}
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x778", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-	
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb3);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb7);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x900);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0xcb3/0xcb7/0x900", \
-		u1Tmp[0], u1Tmp[1], u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x40", \
-		u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(hp rx[31:16]/tx[15:0])", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(lp rx[31:16]/tx[15:0])", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-	
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-
-VOID
-EXhalbtc8812a1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u4Byte	u4Tmp=0;
-
-	if(pBtCoexist->bManualControl ||	pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);	
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-
-		halbtc8812a1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8812a1ant_InitCoexDm(pBtCoexist);
-		halbtc8812a1ant_QueryBtInfo(pBtCoexist);
-
-		pCoexSta->bUnderIps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8812a1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(pBtCoexist->bManualControl || pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8812a1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN bWifiConnected=FALSE, bBtHsOn=FALSE;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	u1Byte u1Tmpa, u1Tmpb;
-	u4Byte u4Tmp;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm )
-		return;
-
-	if(BTC_SCAN_START == type)
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-
-		halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &pCoexSta->nScanAPNum);		
-	}	
-
-	if(pBtCoexist->btInfo.bBtDisabled)
-		return;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	halbtc8812a1ant_QueryBtInfo(pBtCoexist);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8812a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8812a1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-	
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8812a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8812a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_SCAN_START == type)
-	{	
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8812a1ant_ActionWifiNotConnectedScan(pBtCoexist);
-		}
-		else	// wifi is connected
-		{
-			halbtc8812a1ant_ActionWifiConnectedScan(pBtCoexist);
-		}
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8812a1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8812a1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8812a1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		 pCoexSta->bWiFiIsHighPriTask = TRUE;
-		 halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		 halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-		 RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));	
-		 pCoexDm->nArpCnt = 0;
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));	
-		//pCoexDm->nArpCnt = 0;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8812a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8812a1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8812a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8812a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));		
-		halbtc8812a1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-		
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-		if(!bWifiConnected) // non-connected scan
-		{
-			halbtc8812a1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8812a1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-//to check registers...
-VOID
-EXhalbtc8812a1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			dataLen=5;
-	u1Byte			buf[6] = {0};
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	BOOLEAN			bWifiUnderBMode = FALSE;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-		halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FORCE_EXEC, FALSE, FALSE);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-#if 0
-		//Set CCK Tx/Rx high Pri except 11b mode
-		if (bWifiUnderBMode)
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x00); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x00); //CCK Rx
-		}
-		else
-		{
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x10); //CCK Tx
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x10); //CCK Rx
-		}
-#endif	
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-		pCoexDm->nArpCnt = 0;
-
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cd, 0x0); //CCK Tx
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cf, 0x0); //CCK Rx
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		//H2C_Parameter[0] = 0x1;
-		H2C_Parameter[0] = 0x0;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-		
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-
-	buf[0] = dataLen;
-	buf[1] = 0x5;				// OP_Code
-	buf[2] = 0x3;				// OP_Code_Length
-	buf[3] = H2C_Parameter[0]; 	// OP_Code_Content
-	buf[4] = H2C_Parameter[1];
-	buf[5] = H2C_Parameter[2];
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);
-}
-
-VOID
-EXhalbtc8812a1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bBtHsOn=FALSE;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if( BTC_PACKET_DHCP == type || 
-		BTC_PACKET_EAPOL == type ||
-		BTC_PACKET_ARP == type )
-	{
-		if(BTC_PACKET_ARP == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet ARP notify\n"));		 
-
-			pCoexDm->nArpCnt++;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ARP Packet Count = %d\n", pCoexDm->nArpCnt));
-			
-			if(pCoexDm->nArpCnt >= 10) // if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecialPacket(pBtCoexist) 
-			{
-				pCoexSta->bWiFiIsHighPriTask = FALSE;					
-			}			
-			else
-			{
-				pCoexSta->bWiFiIsHighPriTask = TRUE;
-			}
-		}
-		else
-		{
-			pCoexSta->bWiFiIsHighPriTask = TRUE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet DHCP or EAPOL notify\n"));		 
-		}
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet [Type = %d] notify\n", type));
-	}
-
-	pCoexSta->specialPktPeriodCnt = 0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8812a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8812a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8812a1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8812a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8812a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if( BTC_PACKET_DHCP == type ||
-		BTC_PACKET_EAPOL == type || 
-		( (BTC_PACKET_ARP == type ) && (pCoexSta->bWiFiIsHighPriTask) ) )
-	{
-		halbtc8812a1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8812a1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte				btInfo=0;
-	u1Byte				i, rspSource=0;
-	BOOLEAN				bWifiConnected=FALSE;
-	BOOLEAN				bBtBusy=FALSE;
-	
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8812A_1ANT_MAX)
-		rspSource = BT_INFO_SRC_8812A_1ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(BT_INFO_SRC_8812A_1ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		if (pCoexSta->btRetryCnt >= 1)
-			pCoexSta->popEventCnt++;
-
-		if (pCoexSta->btInfoC2h[rspSource][2]&0x20)
-			pCoexSta->bC2hBtPage = TRUE;
-		else
-			pCoexSta->bC2hBtPage = FALSE;			
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2-90;
-			//pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-		if(!pCoexSta->bBtTxRxMask)
-		{
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */				
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n"));
-			pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15);
-		}
-		
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if(pCoexSta->btInfoExt & BIT1)
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				EXhalbtc8812a1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8812a1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-				
-		if(pCoexSta->btInfoExt & BIT3)
-		{
-			if(!pBtCoexist->bManualControl && !pBtCoexist->bStopCoexDm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-				halbtc8812a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-			}
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-#if(BT_AUTO_REPORT_ONLY_8812A_1ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8812a1ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-		
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8812A_1ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8812A_1ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8812A_1ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8812A_1ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8812A_1ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8812A_1ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-	}
-
-	halbtc8812a1ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	btInfo = btInfo & 0x1f;  //mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41)
-	
-	if(!(btInfo&BT_INFO_8812A_1ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8812A_1ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8812A_1ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8812A_1ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8812A_1ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8812A_1ANT_B_ACL_BUSY)
-	{
-		if(BT_8812A_1ANT_BT_STATUS_ACL_BUSY != pCoexDm->btStatus)
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->btStatus = BT_8812A_1ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8812A_1ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-
-	if( (BT_8812A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8812A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		bBtBusy = TRUE;
-	else
-		bBtBusy = FALSE;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	halbtc8812a1ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8812a1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	)
-{
-	u4Byte	u4Tmp;
-	u1Byte	u1Tmpa,u1Tmpb, u1Tmpc;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF Status notify\n"));
-
-	if(BTC_RF_ON == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned ON!!\n"));
-		pBtCoexist->bStopCoexDm = FALSE;
-	}
-	else if(BTC_RF_OFF == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RF is turned OFF!!\n"));
-		
-		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		
-		halbtc8812a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		pBtCoexist->bStopCoexDm = TRUE;
-	}
-}
-
-VOID
-EXhalbtc8812a1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u4Byte	u4Tmp;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8812a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-	halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-
-	halbtc8812a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-
-	EXhalbtc8812a1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-
-	pBtCoexist->bStopCoexDm = TRUE;	
-}
-
-VOID
-EXhalbtc8812a1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-
-		halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8812a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FORCE_EXEC, FALSE, TRUE);
-		halbtc8812a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-
-		pBtCoexist->bStopCoexDm = TRUE;
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		pBtCoexist->bStopCoexDm = FALSE;
-		halbtc8812a1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8812a1ant_InitCoexDm(pBtCoexist);
-		halbtc8812a1ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8812a1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], *****************Coex DM Reset*****************\n"));
-
-	halbtc8812a1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-	halbtc8812a1ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8812a1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8812a1Ant, GLCoexVer8812a1Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8812A_1ANT == 0)
-	halbtc8812a1ant_QueryBtInfo(pBtCoexist);
-	halbtc8812a1ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	halbtc8812a1ant_MonitorBtCtr(pBtCoexist);
-	halbtc8812a1ant_MonitorWiFiCtr(pBtCoexist);
-
-	if( halbtc8812a1ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust )
-	{
-		halbtc8812a1ant_RunCoexistMechanism(pBtCoexist);	
-	}
-
-	pCoexSta->specialPktPeriodCnt++;
-#endif
-}
-
-VOID
-EXhalbtc8812a1ant_DbgControl(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				opCode,
-	IN	u1Byte				opLen,
-	IN	pu1Byte				pData
-	)
-{
-	switch(opCode)
-	{
-		case BTC_DBG_SET_COEX_NORMAL:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set CoexMode to Normal\n"));
-			pBtCoexist->bManualControl = FALSE;
-			halbtc8812a1ant_InitCoexDm(pBtCoexist);
-			break;
-		case BTC_DBG_SET_COEX_WIFI_ONLY:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set CoexMode to Wifi Only\n"));
-			pBtCoexist->bManualControl = TRUE;
-			halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9);	
-			break;
-		case BTC_DBG_SET_COEX_BT_ONLY:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set CoexMode to BT only\n"));
-			pBtCoexist->bManualControl = TRUE;
-			halbtc8812a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);	
-			break;
-		case BTC_DBG_SET_COEX_DEC_BT_PWR:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set Dec BT power\n"));
-			{
-				u1Byte	dataLen=4;
-				u1Byte	buf[6] = {0};
-				u1Byte	decBtPwr=0, pwrLevel=0;
-				if(opLen == 2)
-				{
-					decBtPwr = pData[0];
-					pwrLevel = pData[1];
-				
-					buf[0] = dataLen;
-					buf[1] = 0x3;		// OP_Code
-					buf[2] = 0x2;		// OP_Code_Length
-					
-					buf[3] = decBtPwr;	// OP_Code_Content
-					buf[4] = pwrLevel;
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set Dec BT power=%d, pwrLevel=%d\n", decBtPwr, pwrLevel));
-					pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);	
-				}
-			}
-			break;
-
-		case BTC_DBG_SET_COEX_BT_AFH_MAP:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT AFH Map\n"));
-			{
-				u1Byte	dataLen=5;
-				u1Byte	buf[6] = {0};
-				if(opLen == 3)
-				{
-					buf[0] = dataLen;
-					buf[1] = 0x5;				// OP_Code
-					buf[2] = 0x3;				// OP_Code_Length
-
-					buf[3] = pData[0]; 			// OP_Code_Content
-					buf[4] = pData[1];
-					buf[5] = pData[2];
-
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT AFH Map = %02x %02x %02x\n", 
-						pData[0], pData[1], pData[2]));
-					pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);
-				}
-			}
-			break;
-		
-		case BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT Ignore Wlan Active\n"));
-			{
-				u1Byte	dataLen=3;
-				u1Byte	buf[6] = {0};
-				if(opLen == 1)
-				{
-					buf[0] = dataLen;
-					buf[1] = 0x1;			// OP_Code
-					buf[2] = 0x1;			// OP_Code_Length
-
-					buf[3] = pData[0];		// OP_Code_Content
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT Ignore Wlan Active = 0x%x\n", 
-						pData[0]));
-						
-					pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);
-				}
-			}
-			break;
-		default:
-			break;
-	}
-}
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a1Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a1Ant.h
deleted file mode 100644
index 44698240fd54..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a1Ant.h
+++ /dev/null
@@ -1,259 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8812A 1ANT BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8812A_1ANT				1
-
-#define	BT_INFO_8812A_1ANT_B_FTP						BIT7
-#define	BT_INFO_8812A_1ANT_B_A2DP					BIT6
-#define	BT_INFO_8812A_1ANT_B_HID						BIT5
-#define	BT_INFO_8812A_1ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8812A_1ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8812A_1ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8812A_1ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8812A_1ANT_B_CONNECTION				BIT0
-
-#define	BT_INFO_8812A_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT		2
-
-#define  BT_8812A_1ANT_WIFI_NOISY_THRESH								30   //max: 255
-
-typedef enum _BT_INFO_SRC_8812A_1ANT{
-	BT_INFO_SRC_8812A_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8812A_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8812A_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8812A_1ANT_MAX
-}BT_INFO_SRC_8812A_1ANT,*PBT_INFO_SRC_8812A_1ANT;
-
-typedef enum _BT_8812A_1ANT_BT_STATUS{
-	BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8812A_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8812A_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8812A_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8812A_1ANT_BT_STATUS_MAX
-}BT_8812A_1ANT_BT_STATUS,*PBT_8812A_1ANT_BT_STATUS;
-
-typedef enum _BT_8812A_1ANT_WIFI_STATUS{
-	BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT				= 0x3,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8812A_1ANT_WIFI_STATUS_MAX
-}BT_8812A_1ANT_WIFI_STATUS,*PBT_8812A_1ANT_WIFI_STATUS;
-
-typedef enum _BT_8812A_1ANT_COEX_ALGO{
-	BT_8812A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8812A_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8812A_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8812A_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8812A_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8812A_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8812A_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8812A_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8812A_1ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8812A_1ANT_COEX_ALGO,*PBT_8812A_1ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8812A_1ANT{
-	// hw setting
-	u1Byte		preAntPosType;
-	u1Byte		curAntPosType;
-	// fw mechanism
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	// sw mechanism
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	u4Byte		backupArfrCnt1;	// Auto Rate Fallback Retry cnt
-	u4Byte		backupArfrCnt2;	// Auto Rate Fallback Retry cnt
-	u2Byte		backupRetryLimit;
-	u1Byte		backupAmpduMaxTime;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-	u1Byte		preArfrType;
-	u1Byte		curArfrType;
-	u1Byte		preRetryLimitType;
-	u1Byte		curRetryLimitType;
-	u1Byte		preAmpduTimeType;
-	u1Byte		curAmpduTimeType;
-	u4Byte		nArpCnt;
-
-	u1Byte		errorCondition;
-} COEX_DM_8812A_1ANT, *PCOEX_DM_8812A_1ANT;
-
-typedef struct _COEX_STA_8812A_1ANT{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					specialPktPeriodCnt;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	s1Byte					btRssi;
-	BOOLEAN					bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8812A_1ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8812A_1ANT_MAX];
-	u4Byte					btInfoQueryCnt;
-	BOOLEAN					bC2hBtInquiryPage;
-	BOOLEAN					bC2hBtPage;				//Add for win8.1 page out issue
-	BOOLEAN					bWiFiIsHighPriTask;		//Add for win8.1 page out issue
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	u4Byte					popEventCnt;
-	u1Byte					nScanAPNum;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;	
-
-	BOOLEAN					bCCKLock;
-	BOOLEAN					bPreCCKLock;
-	u1Byte					nCoexTableType;
-
-	BOOLEAN					bForceLpsOn;
-}COEX_STA_8812A_1ANT, *PCOEX_STA_8812A_1ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8812a1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8812a1ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8812a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8812a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8812a1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8812a1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8812a1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8812a1ant_RfStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte					type
-	);
-VOID
-EXhalbtc8812a1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8812a1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8812a1ant_CoexDmReset(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8812a1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8812a1ant_DbgControl(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				opCode,
-	IN	u1Byte				opLen,
-	IN	pu1Byte				pData
-	);
-VOID
-EXhalbtc8812a1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a2Ant.c
deleted file mode 100644
index 8aab78d75da0..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a2Ant.c
+++ /dev/null
@@ -1,5435 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8812A Co-exist mechanism
-//
-// History
-// 2012/08/22 Cosa first check in.
-// 2012/11/14 Cosa Revise for 8812A 2Ant out sourcing.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8812a2Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8812A_2ANT	GLCoexDm8812a2Ant;
-static PCOEX_DM_8812A_2ANT 	pCoexDm=&GLCoexDm8812a2Ant;
-static COEX_STA_8812A_2ANT	GLCoexSta8812a2Ant;
-static PCOEX_STA_8812A_2ANT	pCoexSta=&GLCoexSta8812a2Ant;
-
-const char *const GLBtInfoSrc8812a2Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8812a2Ant=20150408;
-u4Byte	GLCoexVer8812a2Ant=0x39;
-//improve 8761ATV D-cut BT off/on fail issue
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8812a2ant_
-//============================================================
-u1Byte
-halbtc8812a2ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8812a2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8812a2ant_SetEnablePTA(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN 		bEnablePTA
-	)
-{
-	if(bEnablePTA)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PTA is enable!\n"));
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x20);
-
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PTA is disable!\n"));
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x00);
-
-	}
-}
-
-VOID
-halbtc8812a2ant_EnablePTA(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE (COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Enable PTA %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurEnablePTA = bEnable;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bPreEnablePTA = %d, bCurEnablePTA = %d!!\n", 
-			pCoexDm->bPreEnablePTA, pCoexDm->bCurEnablePTA));
-
-		if(pCoexDm->bPreEnablePTA == pCoexDm->bCurEnablePTA)
-			return;
-	}
-	halbtc8812a2ant_SetEnablePTA(pBtCoexist, bEnable);
-
-
-	pCoexDm->bPreEnablePTA = pCoexDm->bCurEnablePTA;
-}
-
-VOID
-halbtc8812a2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO	pStackInfo=&pBtCoexist->stackInfo;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	// only 8812a need to consider if core stack is installed.
-	if(!pStackInfo->hciVersion)
-	{
-		bBtActive = FALSE;
-	}
-/*
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-*/
-
-	if((pCoexSta->prebtInfoC2hCnt_BT_RSP == pCoexSta->btInfoC2hCnt[1]) &&
-		(pCoexSta->prebtInfoC2hCnt_BT_SEND == pCoexSta->btInfoC2hCnt[2]))
-	{
-		bBtActive = FALSE;
-	}
-	
-	pCoexSta->prebtInfoC2hCnt_BT_RSP = pCoexSta->btInfoC2hCnt[1];
-	pCoexSta->prebtInfoC2hCnt_BT_SEND = pCoexSta->btInfoC2hCnt[2];
-	
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt is detected as disabled %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(pCoexSta->preBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(pCoexSta->preBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		pCoexSta->preBtDisabled = bBtDisabled;
-
-		if(!bBtDisabled)
-		{
-			// enable PTA
-//			halbtc8812a2ant_EnablePTA(pBtCoexist,FORCE_EXEC, TRUE);
-		}
-		else
-		{
-			// disable PTA
-//			halbtc8812a2ant_EnablePTA(pBtCoexist,FORCE_EXEC, FALSE);
-		}
-	}
-}
-
-u4Byte
-halbtc8812a2ant_DecideRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte				raMaskType
-	)
-{
-	u4Byte	disRaMask=0x0;
-	
-	switch(raMaskType)
-	{
-		case 0: // normal mode
-			disRaMask = 0x0;
-			break;
-		case 1: // disable cck 1/2
-			disRaMask = 0x00000003;
-			break;
-		case 2: // disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4			
-			disRaMask = 0x0001f1f7;
-			break;
-		default:
-			break;
-	}
-
-	return disRaMask;
-}
-
-VOID
-halbtc8812a2ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-VOID
-halbtc8812a2ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-VOID
-halbtc8812a2ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-VOID
-halbtc8812a2ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8812a2ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType
-	)
-{
-	u4Byte	disRaMask=0x0;
-
-	pCoexDm->curRaMaskType = raMaskType;
-	disRaMask = halbtc8812a2ant_DecideRaMask(pBtCoexist, raMaskType);
-	halbtc8812a2ant_UpdateRaMask(pBtCoexist, bForceExec, disRaMask);
-
-	halbtc8812a2ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8812a2ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8812a2ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-}
-
-VOID
-halbtc8812a2ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-VOID
-halbtc8812a2ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8812a2ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	u1Byte	dataLen=3;
-	u1Byte	buf[5] = {0};
-//8812a watch btifo to check BT enable/disable
-//	if(!pBtCoexist->btInfo.bBtDisabled)
-	{
-		if(!pCoexSta->btInfoQueryCnt ||
-			(pCoexSta->btInfoC2hCnt[BT_INFO_SRC_8812A_2ANT_BT_RSP]-pCoexSta->btInfoQueryCnt)>2)
-		{
-			buf[0] = dataLen;
-			buf[1] = 0x1;	// polling enable, 1=enable, 0=disable
-			buf[2] = 0x2;	// polling time in seconds
-			buf[3] = 0x1;	// auto report enable, 1=enable, 0=disable
-				
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_INFO, (PVOID)&buf[0]);
-		}
-	}
-	pCoexSta->btInfoQueryCnt++;
-}
-
-BOOLEAN
-halbtc8812a2ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN	bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bWifiConnected=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8812a2ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO 	pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-#if 1//(BT_AUTO_REPORT_ONLY_8812A_2ANT == 1)	// profile from bt patch
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-	pBtLinkInfo->bAclBusy = pCoexSta->bAclBusy;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-#else	// profile from bt stack
-	pBtLinkInfo->bBtLinkExist = pStackInfo->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pStackInfo->bScoExist;
-	pBtLinkInfo->bA2dpExist = pStackInfo->bA2dpExist;
-	pBtLinkInfo->bPanExist = pStackInfo->bPanExist;
-	pBtLinkInfo->bHidExist = pStackInfo->bHidExist;
-
-	//for win-8 stack HID report error
-	if(!pStackInfo->bHidExist)
-		pStackInfo->bHidExist = pCoexSta->bHidExist;  //sync  BTInfo with BT firmware and stack
-	// when stack HID report error, here we use the info from bt fw.
-	if(!pStackInfo->bBtLinkExist)
-		pStackInfo->bBtLinkExist = pCoexSta->bBtLinkExist;	
-#endif
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8812a2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	PBTC_STACK_INFO 	pStackInfo=&pBtCoexist->stackInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8812A_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 0)
-	{
-		if(pBtLinkInfo->bAclBusy)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ACL Busy only\n"));
-			algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR;
-		}
-	}
-	else if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO only\n"));
-			algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8812A_2ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8812A_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(HS) only\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(EDR) only\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID\n"));
-				algorithm = BT_8812A_2ANT_COEX_ALGO_SCO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(HS)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(EDR)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(pStackInfo->numOfHid >= 2)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID*2 + A2DP\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-				else
-				{			
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(HS)\n"));
-					algorithm =  BT_8812A_2ANT_COEX_ALGO_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(EDR)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(HS)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(EDR)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8812a2ant_SetFwDacSwingLevel(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			dacSwingLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	// There are several type of dacswing
-	// 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6
-	H2C_Parameter[0] = dacSwingLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Set Dac Swing Level=0x%x\n", dacSwingLvl));
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x64=0x%x\n", H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x64, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8812a2ant_SetFwDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	u1Byte	dataLen=4;
-	u1Byte	buf[6] = {0};
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], decrease Bt Power level = %d\n", 
-		decBtPwrLvl));
-
-	buf[0] = dataLen;
-	buf[1] = 0x3;		// OP_Code
-	buf[2] = 0x2;		// OP_Code_Length
-	if(decBtPwrLvl)
-		buf[3] = 0x1;	// OP_Code_Content
-	else
-		buf[3] = 0x0;
-	buf[4] = decBtPwrLvl;// pwrLevel
-		
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);	
-}
-
-VOID
-halbtc8812a2ant_DecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			decBtPwrLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s Dec BT power level = %d\n",  
-		(bForceExec? "force to":""), decBtPwrLvl));
-	pCoexDm->curBtDecPwrLvl = decBtPwrLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preBtDecPwrLvl == pCoexDm->curBtDecPwrLvl) 
-			return;
-	}
-	halbtc8812a2ant_SetFwDecBtPwr(pBtCoexist, pCoexDm->curBtDecPwrLvl);
-
-	pCoexDm->preBtDecPwrLvl = pCoexDm->curBtDecPwrLvl;
-}
-
-VOID
-halbtc8812a2ant_FwDacSwingLvl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			fwDacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set FW Dac Swing level = %d\n",  
-		(bForceExec? "force to":""), fwDacSwingLvl));
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preFwDacSwingLvl == pCoexDm->curFwDacSwingLvl) 
-			return;
-	}
-
-	halbtc8812a2ant_SetFwDacSwingLevel(pBtCoexist, pCoexDm->curFwDacSwingLvl);
-
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-}
-
-VOID
-halbtc8812a2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xffffc);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8812a2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8812a2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8812a2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte	tmpU1;
-
-	tmpU1 = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4fd);
-	tmpU1 |= BIT0;
-	if(bLowPenaltyRa)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set low penalty!!\n"));
-		tmpU1 &= ~BIT2;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Tx rate adaptive, set normal!!\n"));
-		tmpU1 |= BIT2;
-	}
-
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4fd, tmpU1);
-}
-
-VOID
-halbtc8812a2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	return;
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8812a2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8812a2ant_SetDacSwingReg(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte			level
-	)
-{
-	u1Byte	val=(u1Byte)level;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Write SwDacSwing = 0x%x\n", level));
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc5b, 0x3e, val);
-}
-
-VOID
-halbtc8812a2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	if(bSwDacSwingOn)
-	{
-		halbtc8812a2ant_SetDacSwingReg(pBtCoexist, swDacSwingLvl);
-	}
-	else
-	{
-		halbtc8812a2ant_SetDacSwingReg(pBtCoexist, 0x18);
-	}
-}
-
-
-VOID
-halbtc8812a2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8812a2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8812a2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x8db, 0x60, 0x3);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x8db, 0x60, 0x1);
-	}
-}
-
-VOID
-halbtc8812a2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8812a2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8812a2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff,  0x28F4B);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff,  0x10AB2);
-		rssiAdjustVal = 8;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x2884B);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x104B2);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	// set rssiAdjustVal for wifi module.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-VOID
-halbtc8812a2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8812a2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8812a2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8812a2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8812a2ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8812a2ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	switch(type)
-	{
-		case 0:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5ffb5ffb, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0x5fdf5fdf, 0x5fdb5fdb, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0xdfffdfff, 0x5fdb5fdb, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0x5ddd5ddd, 0x5fdb5fdb, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 7:
-			if(pCoexSta->nScanAPNum <= 5)
-				halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0xffffffff, 0xfafafafa, 0xffffff, 0x3);
-			else
-				halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0xffffffff, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 8:
-			halbtc8812a2ant_CoexTable(pBtCoexist, bForceExec, 0x5f5f5f5f, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8812a2ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte	dataLen=3;
-	u1Byte	buf[5] = {0};
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Ignore Wlan_Act\n",
-		(bEnable? "Enable":"Disable")));
-
-	buf[0] = dataLen;
-	buf[1] = 0x1;			// OP_Code
-	buf[2] = 0x1;			// OP_Code_Length
-	if(bEnable)
-		buf[3] = 0x1; 		// OP_Code_Content
-	else
-		buf[3] = 0x0;
-		
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);	
-}
-
-VOID
-halbtc8812a2ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8812a2ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8812a2ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		if(byte1&BIT4 && !(byte1&BIT5))
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-			realByte1 &= ~BIT4;
-			realByte1 |= BIT5;
-
-			realByte5 |= BIT5;
-			realByte5 &= ~BIT6;
-		}
-	}
-
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-VOID
-halbtc8812a2ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8812a2ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8812a2ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8812a2ant_SwMechanism1(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bShrinkRxLPF,
-	IN	BOOLEAN 	bLowPenaltyRA,
-	IN	BOOLEAN		bLimitedDIG, 
-	IN	BOOLEAN		bBTLNAConstrain
-	) 
-{
-	/*
-	u4Byte	wifiBw;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	
-	if(BTC_WIFI_BW_HT40 != wifiBw)  //only shrink RF Rx LPF for HT40
-	{
-		if (bShrinkRxLPF)
-			bShrinkRxLPF = FALSE;
-	}
-	*/
-	 	
-	 halbtc8812a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, bShrinkRxLPF);
-	//halbtc8812a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8812a2ant_SwMechanism2(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bAGCTableShift,
-	IN	BOOLEAN 	bADCBackOff,
-	IN	BOOLEAN		bSWDACSwing,
-	IN	u4Byte		dacSwingLvl
-	) 
-{
-	//halbtc8812a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, bAGCTableShift);
-	halbtc8812a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, bADCBackOff);
-	halbtc8812a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, bSWDACSwing, dacSwingLvl);
-}
-
-VOID
-halbtc8812a2ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	u1Byte			u1Tmp=0;
-	
-	if(bInitHwCfg)
-	{
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x900, 0x00000400);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76d, 0x1);
-	}
-	else if(bWifiOff)
-	{
-
-	}
-	
-	// ext switch setting
-	switch(antPosType)
-	{
-		case BTC_ANT_WIFI_AT_CPL_MAIN:
-			break;
-		case BTC_ANT_WIFI_AT_CPL_AUX:
-			u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb7);
-			u1Tmp &= ~BIT3;
-			u1Tmp |= BIT2;
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb7, u1Tmp);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8812a2ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN			bTurnOnByCnt=FALSE;
-	u1Byte			psTdmaTypeByCnt=0;
-	s1Byte			nWiFiDurationAdjust = 0x0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-		(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if(!bForceExec)
-	{
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], bPrePsTdmaOn = %d, bCurPsTdmaOn = %d!!\n", 
-			pCoexDm->bPrePsTdmaOn, pCoexDm->bCurPsTdmaOn));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], prePsTdma = %d, curPsTdma = %d!!\n", 
-			pCoexDm->prePsTdma, pCoexDm->curPsTdma));
-
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-
-	if  (pCoexSta->nScanAPNum >= 40)
-	 	nWiFiDurationAdjust = -15;	
-	else if  (pCoexSta->nScanAPNum >= 20)
-	 	nWiFiDurationAdjust = -10;	
-
-/*	
-	if (!pCoexSta->bForceLpsOn)  //only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30
-	{
-		psTdmaByte0Val = 0x61;  //no null-pkt
-		psTdmaByte3Val = 0x11; // no tx-pause at BT-slot
-		psTdmaByte4Val = 0x10; // 0x778 = d/1 toggle
-	}
-
-	
-	if (  (type == 3) || (type == 13) || (type == 14) )
-	{
-		psTdmaByte4Val = psTdmaByte4Val & 0xbf;  //no dynamic slot for multi-profile
-	
-		if (!bWifiBusy)
-		 psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-	}
-	
-	if (pBtLinkInfo->bSlaveRole == TRUE)
-		psTdmaByte4Val = psTdmaByte4Val | 0x1;  //0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts)
-	
-*/
-	if(bTurnOn)
-	{
-		switch(type)
-		{
-			case 1:
-			default:	//d1,wb
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x11, 0x10);
-				break;
-			case 2:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x32, 0x03, 0x11, 0x10);
-				break;
-			case 3:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x28, 0x03, 0x11, 0x10);
-				break;
-			case 4:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1e, 0x03, 0x11, 0x10);
-				break;
-			case 5:		//d1,pb,TXpause
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x63, 0x3c, 0x03, 0x90, 0x10);
-				break;
-			case 6:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x63, 0x32, 0x03, 0x90, 0x10);
-				break;
-			case 7:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x63, 0x28, 0x03, 0x90, 0x10);
-				break;
-			case 8:	
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x63, 0x1e, 0x03, 0x90, 0x10);
-				break;
-			case 9:		//d1,bb
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x31, 0x10);
-				break;
-			case 10:	
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x32, 0x03, 0x31, 0x10);
-				break;
-			case 11:	
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x28, 0x03, 0x31, 0x10);
-				break;
-			case 12:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1e, 0x03, 0x31, 0x10);
-				break;
-			case 13:	//d1,bb,TXpause
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x30, 0x10);
-				break;
-			case 14:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x32, 0x03, 0x30, 0x10);
-				break;
-			case 15:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x28, 0x03, 0x30, 0x10);
-				break;
-			case 16:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1e, 0x03, 0x30, 0x10);
-				break;
-			case 17:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x61, 0x35, 0x3, 0x11, 0x11);
-				break;
-			case 18:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				break;			
-			case 19:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0xe1, 0x90);
-				break;
-			case 20:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0x60, 0x90);
-				break;
-			case 21:	
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x3, 0x70, 0x90);
-				break;
-			case 22:	
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x61, 0x1a, 0x1a, 0x21, 0x10);
-				break;
-			case 23:	
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x03, 0x31, 0x10);
-				break;
-
-			case 71:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				break;
-
-			// following cases is for wifi rssi low, started from 81
-			case 80:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x53, 0x3c, 0x3, 0x90, 0x50);
-				break;
-			case 81:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x53, 0x3a+nWiFiDurationAdjust, 0x3, 0x90, 0x50);
-				break;
-			case 82:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x53, 0x30+nWiFiDurationAdjust, 0x03, 0x90, 0x50);
-				break;
-			case 83:
-	   			halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x53, 0x21, 0x03, 0x90, 0x50);
-				break;
-			case 84:
-	   			halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x53, 0x15, 0x3, 0x90, 0x50);
-				break;
-			case 85:
-	   			halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x53, 0x1d, 0x1d, 0x80, 0x50);
-				break;
-			case 86:
-	   			halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x53, 0x15, 0x15, 0x80, 0x50);
-				break;
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(type)
-		{
-			case 0: //ANT2PTA, 0x778=0x1
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-				break;
-			case 1: //ANT2BT, 0x778=3
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x8, 0x0);				
-				delay_ms(5);
-				halbtc8812a2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_CPL_AUX, FALSE, FALSE);
-				break;
-			default:
-				halbtc8812a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				break;
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8812a2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-	halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8812a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-
-	halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, FORCE_EXEC, 0);
-
-	halbtc8812a2ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8812a2ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8812a2ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8812a2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8812a2ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8812a2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-BOOLEAN
-halbtc8812a2ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte				wifiRssiState=BTC_RSSI_STATE_HIGH;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-	BOOLEAN				bBtHsOn=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under inquiry/page scan !!\n"));
-		halbtc8812a2ant_ActionBtInquiry(pBtCoexist);
-		return TRUE;
-	}
-
-	if(pBtLinkInfo->bScoExist || pBtLinkInfo->bHidExist)
-	{
-		halbtc8812a2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 0, 0, 0);
-	}
-	else
-	{
-		halbtc8812a2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-	}
-
-	if(!bWifiConnected)
-	{
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-connected idle!!\n"));
-
-		if( (BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus) ||
-			(BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-		{
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-		else
-		{			
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-
-		halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-		
- 		halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		bCommon = TRUE;
-	}
-	else
-	{
-		if(BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);		
-			halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-			halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else if(BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			if(bBtHsOn)
-				return FALSE;
-
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); 
-			halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-			halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else
-		{
-			if(bWifiBusy)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-				bCommon = FALSE;
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-
-				halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-					
-				halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-				halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 17);
-
-				halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-				halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-				halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-				halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-				bCommon = TRUE;
-			}
-		}	
-	}
-
-	return bCommon;
-}
-
-VOID
-halbtc8812a2ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bScoHid,
-	IN	BOOLEAN			bTxPause,
-	IN	u1Byte			maxInterval
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-	pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;
-	
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-		{
-			if(bScoHid)
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;	
-					}
-					else
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-			else
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->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 = pCoexSta->btRetryCnt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-		if(maxInterval == 1)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-
-                                if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-					pCoexDm->psTdmaDuAdjType = 13;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				
-				if(result == -1)
-				{					
-					if(pCoexDm->curPsTdma == 5)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;
-					}
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-					pCoexDm->psTdmaDuAdjType = 1;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-					pCoexDm->psTdmaDuAdjType = 9;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 2)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 3)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-		if( !bScan && !bLink && !bRoam)
-		{
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-}
-
-//==================
-// pstdma for wifi rssi low
-//==================
-VOID
-halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(
-	IN	PBTC_COEXIST		pBtCoexist//,
-	//IN	u1Byte				wifiStatus
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0, btInfoExt;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow()\n"));
-#if 0
-	if( (BT_8812A_2ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN == wifiStatus) ||
-		(BT_8812A_2ANT_WIFI_STATUS_CONNECTED_SCAN == wifiStatus) ||
-		(BT_8812A_2ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT == wifiStatus) )
-	{
-		if( pCoexDm->curPsTdma != 81 &&
-			pCoexDm->curPsTdma != 82 &&
-			pCoexDm->curPsTdma != 83 &&
-			pCoexDm->curPsTdma != 84 )
-		{
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-			pCoexDm->psTdmaDuAdjType = 82;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n= 3;
-			result = 0;
-			WaitCount = 0;
-		}		
-		return;
-	}
-#endif
-	pCoexDm->bAutoTdmaAdjust = FALSE;
-
-	retryCount = pCoexSta->btRetryCnt;
-	btInfoExt = pCoexSta->btInfoExt;
-
-	if(!pCoexDm->bAutoTdmaAdjustLowRssi)
-	{
-		pCoexDm->bAutoTdmaAdjustLowRssi = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjustForWifiRssiLow()!!\n"));
-
-		if(BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(btInfoExt))
-		{
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-			pCoexDm->psTdmaDuAdjType = 83;
-		}
-		else
-		{
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-		pCoexDm->psTdmaDuAdjType = 82;
-		}
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-//		retryCount = pCoexSta->btRetryCnt;
-//		btInfoExt = pCoexSta->btInfoExt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		result = 0;
-		WaitCount++; 
-		  
-		if ( (pCoexSta->lowPriorityTx) > 1050 ||  (pCoexSta->lowPriorityRx) > 1250 )
-			retryCount++;	
-				
-		if(retryCount == 0)  // no retry in the last 2-second duration
-		{
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;				 
-
-			if(up >= n)	// if 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		if(result == -1)
-		{
-/*
-			if( (BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 81) ||(pCoexDm->curPsTdma == 82)) )
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 84);
-				pCoexDm->psTdmaDuAdjType = 84;
-			}
-*/
-			if(pCoexDm->curPsTdma == 80)
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-				pCoexDm->psTdmaDuAdjType = 82;
-			}
-			else if(pCoexDm->curPsTdma == 81)
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-				pCoexDm->psTdmaDuAdjType = 82;
-			}
-			else if(pCoexDm->curPsTdma == 82)
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-				pCoexDm->psTdmaDuAdjType = 83;
-			}
-			else if(pCoexDm->curPsTdma == 83)
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 84);
-				pCoexDm->psTdmaDuAdjType = 84;
-			}
-		}
-		else if(result == 1)
-		{
-/*
-			if( (BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 81) ||(pCoexDm->curPsTdma == 82)) )
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-				pCoexDm->psTdmaDuAdjType = 83;
-			}
-*/
-			if(pCoexDm->curPsTdma == 84)
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 83);
-				pCoexDm->psTdmaDuAdjType = 83;
-			}
-			else if(pCoexDm->curPsTdma == 83)
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 82);
-				pCoexDm->psTdmaDuAdjType = 82;
-			}
-			else if(pCoexDm->curPsTdma == 82)
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 81);
-				pCoexDm->psTdmaDuAdjType = 81;
-			}
-			else if((pCoexDm->curPsTdma == 81)&&((pCoexSta->nScanAPNum <= 5)))
-			{
-				halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 81);
-				pCoexDm->psTdmaDuAdjType = 81;
-		        }
-                }
-
-		if( pCoexDm->curPsTdma != 80 &&
-                        pCoexDm->curPsTdma != 81 &&
-			pCoexDm->curPsTdma != 82 &&
-			pCoexDm->curPsTdma != 83 &&
-			pCoexDm->curPsTdma != 84 )
-		{
-			// recover to previous adjust type
-			halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-	}
-}
-
-VOID
-halbtc8812a2ant_GetBtRssiThreshold(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte				pThres0,
-	IN	pu1Byte				pThres1
-	)
-{
-	u1Byte antType, btThreshold=0;
-	
-//	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_ANT_TYPE, &antType);
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-        antType = pBoardInfo->antType;
-
-
-	switch(antType)
-	{
-		case BTC_ANT_TYPE_0:
-			*pThres0 = 100;
-			*pThres1 = 100;
-			break;
-		case BTC_ANT_TYPE_1:
-			*pThres0 = 34;
-			*pThres1 = 42;
-			break;
-		case BTC_ANT_TYPE_2:
-			*pThres0 = 34;
-			*pThres1 = 42;
-			break;
-		case BTC_ANT_TYPE_3:
-			*pThres0 = 34;
-			*pThres1 = 42;
-			break;
-		case BTC_ANT_TYPE_4:
-			*pThres0 = 34;
-			*pThres1 = 42;
-			break;
-		default:
-			break;
-	}
-}
-
-
-
-VOID
-halbtc8812a2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// coex table
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-
-	// pstdma
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-	else
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x6);			
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x6);	
-		}		
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x6);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x6);
-		}		
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionScoHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// coex table
-	halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-
-	// pstdma
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-	else
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);		
-
-	// decrease BT power	
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-	
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x6);			
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x6);	
-		}		
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x6);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x6);
-		}		
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		anttype=0;
-	BOOLEAN 	bApEnable=FALSE;
-
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	
-    anttype = pBoardInfo->antType;
-
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-//	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-
-	if(anttype == 0)//ANTTYPE = 0   92E 2ant with SPDT
-	{
-		// power save state & pstdma & coex table
-       	pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else if(anttype == 1) //92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation
-	{		
-		// power save state & pstdma & coex table
-       	pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else if(anttype == 2)//ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 9);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);	
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 9);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 9);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-		}
-	}
-	else if(anttype == 3)	//ANTTYPE = 3,  92E 3ant with good ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-	}
-	else	//ANTTYPE = 4 for test
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-
-
-	// power save state
-	halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// coex table
-	halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}	
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8812a2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		anttype=0;
-	BOOLEAN			bApEnable=FALSE;
-
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	
-    anttype = pBoardInfo->antType;
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-//	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-	
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-//	anttype = 4;
-
-	if(anttype == 0)//ANTTYPE = 0   92E 2ant with SPDT
-	{
-
-		if((pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-		else
-		{
-			if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)))
-			{	//WIFI RSSI = high & BT RSSI = high & shielding room
-				halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-				halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-				halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-			}
-			else	//WIFI RSSI || BT RSSI == low
-			{
-				halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-				halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-				halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-			}
-		}
-
-		// power save state & pstdma & coex table
-/*
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-*/
-	}
-	else if(anttype == 1) //92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);	//shielding room
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-
-	}
-	else if(anttype == 2)//ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);	
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-	else if(anttype == 3)	//ANTTYPE = 3,  92E 3ant with good ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-	}
-	else	//ANTTYPE = 4 for test
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// decrease BT power
-/*
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A)  // BT HIGH RSSI & shielding room
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
- 			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// coex table	
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-
-	// pstdma	
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 2);		
-	else
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 2);
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-/*	
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
- 			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x6);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x6);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x6);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x6);
-		}		
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-	BOOLEAN		bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if((bApEnable == TRUE) || (BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-	else
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 85);
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-	
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-//PAN(HS) only
-VOID
-halbtc8812a2ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// coex table
-	halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-
-	// pstdma
-	halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8812a2ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state	
-	if((bApEnable == TRUE) || (BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);	
-	else if(BTC_RSSI_LOW(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	else if(BTC_RSSI_LOW(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-	else if(BTC_RSSI_LOW(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-	else
-	{
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 86);
-	}
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism	
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-//	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if((bApEnable == TRUE) || (BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);	
-	else if(BTC_RSSI_LOW(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);	
-	else if(BTC_RSSI_LOW(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);	
-	else if(BTC_RSSI_LOW(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-	else
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 85);
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	if(BTC_RSSI_HIGH(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	else if(BTC_RSSI_LOW(wifiRssiState) &&  (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	else
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8812a2ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-//	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	if((bApEnable == TRUE) || (BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState))))
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);	
-	else if(BTC_RSSI_LOW(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	else
-		halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-	else if(BTC_RSSI_LOW(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-	else if(BTC_RSSI_LOW(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-	else
-	{
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		halbtc8812a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 86);
-	}
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-/*	
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	else if(BTC_RSSI_LOW(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	else
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionHidA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0;
-
-	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-	
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-//	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	// power save state
-	halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// coex table
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 3);
-	else if(BTC_RSSI_LOW(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	// pstdma
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 2);	
-	else if(BTC_RSSI_LOW(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-	else
-		halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	if(BTC_RSSI_HIGH(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	else if(BTC_RSSI_LOW(wifiRssiState) && (!BTC_RSSI_LOW(btRssiState)))
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	else
-		halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8812a2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState=BTC_RSSI_STATE_HIGH, btRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte		wifiBw;
-	u1Byte		btThresh0=0, btThresh1=0, anttype=0;
-	BOOLEAN			bApEnable=FALSE;
-
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	
-    anttype = pBoardInfo->antType;
-
-
-//	halbtc8812a2ant_GetBtRssiThreshold(pBtCoexist, &btThresh0, &btThresh1);
-//	btRssiState = halbtc8812a2ant_BtRssiState(3, btThresh0, btThresh1);
-
-	wifiRssiState = halbtc8812a2ant_WifiRssiState(pBtCoexist, 0, 2, 34, 0);
-	btRssiState = halbtc8812a2ant_BtRssiState(3, 34, 42);
-
-	if(anttype == 0)//ANTTYPE = 0	92E 2ant with SPDT
-	{
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-		else
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-	}
-	else if(anttype == 1) //92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-		else
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-	}
-	else if(anttype == 2)//ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);	
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-        {	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-        }
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, TRUE, 83);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		}
-	}
-	else if(anttype == 3)	//ANTTYPE = 3,  92E 3ant with good ant. isolation
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-        	pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;   
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		}
-	}
-	else	//ANTTYPE = 4 for test
-	{		
-		// power save state & pstdma & coex table
-		if(BTC_RSSI_HIGH(wifiRssiState) &&	(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & shielding room
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifiRssiState)&&(!BTC_RSSI_LOW(btRssiState)) && (pCoexSta->nScanAPNum > NOISY_AP_NUM_THRESH_8812A))
-		{	//WIFI RSSI = high & BT RSSI = high & noisy enviroment
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-		else	//WIFI RSSI || BT RSSI == low
-		{
-			halbtc8812a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_TdmaDurationAdjustForWifiRssiLow(pBtCoexist);
-			halbtc8812a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		}
-	}
-
-	// decrease BT power
-	halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-/*
-	// decrease BT power
-	if(BTC_RSSI_LOW(btRssiState))
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(btRssiState)) 
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-        else if (pCoexSta->nScanAPNum < NOISY_AP_NUM_THRESH_8812A)  // BT HIGH RSSI & shielding room
-		halbtc8812a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-*/
-	// limited Rx
-	halbtc8812a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	// fw dac swing level
-	halbtc8812a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if(BTC_RSSI_HIGH(wifiRssiState))
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8812a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8812a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8812a2ant_CoexUnder5G(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8812a2ant_CoexAllOff(pBtCoexist);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Under 5G, force set BT to ignore Wlan active!!\n"));
-	halbtc8812a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, TRUE);
-}
-//====================================================
-VOID
-halbtc8812a2ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN				bWifiUnder5G=FALSE, bBtHsOn=FALSE;
-	u1Byte				btInfoOriginal=0, btRetryCnt=0;
-	u1Byte				algorithm=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-	if(bWifiUnder5G)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), run 5G coex setting!!<===\n"));
-		halbtc8812a2ant_CoexUnder5G(pBtCoexist);
-		return;
-	}
-
-
-	algorithm = halbtc8812a2ant_ActionAlgorithm(pBtCoexist);
-	if(pCoexSta->bC2hBtInquiryPage && (BT_8812A_2ANT_COEX_ALGO_PANHS!=algorithm))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under inquiry/page scan !!\n"));
-		halbtc8812a2ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-
-	pCoexDm->curAlgorithm = algorithm;
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Algorithm = %d \n", pCoexDm->curAlgorithm));
-
-	if(halbtc8812a2ant_IsCommonAction(pBtCoexist))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant common.\n"));
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;
-	}
-	else
-	{
-		if(pCoexDm->curAlgorithm != pCoexDm->preAlgorithm)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 
-				pCoexDm->preAlgorithm, pCoexDm->curAlgorithm));
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-			pCoexDm->bAutoTdmaAdjustLowRssi = FALSE;
-		}
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8812A_2ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO.\n"));
-				halbtc8812a2ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_SCO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO+HID.\n"));
-				halbtc8812a2ant_ActionScoHid(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID.\n"));
-				halbtc8812a2ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP.\n"));
-				halbtc8812a2ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n"));
-				halbtc8812a2ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n"));
-				halbtc8812a2ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HS mode.\n"));
-				halbtc8812a2ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n"));
-				halbtc8812a2ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-				halbtc8812a2ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-				halbtc8812a2ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN(HS).\n"));
-				halbtc8812a2ant_ActionHidA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8812A_2ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n"));
-				halbtc8812a2ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n"));
-				halbtc8812a2ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-	
-}
-
-VOID
-halbtc8812a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp
-	)
-{
-	u4Byte	u4Tmp=0;
-	u2Byte	u2Tmp=0;
-	u1Byte	u1Tmp=0;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	if(bBackUp)
-	{
-		// backup rf 0x1e value
-		pCoexDm->btRf0x1eBackup = 
-			pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);
-
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-	
-	//ant sw control to BT
-	halbtc8812a2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_CPL_AUX, TRUE, FALSE);
-
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	// PTA parameter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, 0x0);
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, 0xffff);
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, 0x55555555);
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, 0x55555555);
-
-	// coex parameters
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x1);
-
-	// enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-
-	// disable PTA to avoid BT insn't on
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x40, 0x00);
-
-	// bt clock related
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x4);
-	u1Tmp |= BIT7;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x4, u1Tmp);
-
-	// bt clock related
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x7);
-	u1Tmp |= BIT1;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x7, u1Tmp);
-}
-
-//============================================================
-// work around function start with wa_halbtc8812a2ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8812a2ant_
-//============================================================
-VOID
-EXhalbtc8812a2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}	
-
-VOID
-EXhalbtc8812a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8812a2ant_InitHwConfig(pBtCoexist, TRUE);
-}
-
-VOID
-EXhalbtc8812a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8812a2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8812a2ant_BTOffOnNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte			BTstatus 
-	)
-{
-	u1Byte u1Tmp=0;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BToff/on notify\n"));
-	DBG_871X("%s, BTstatus:%d", __func__, BTstatus);
-
-	if(BTC_BT_OFF == BTstatus)
-	{
-    		//PTA off
-		pBtCoexist->btInfo.bBtDisabled = TRUE;
-		halbtc8812a2ant_EnablePTA(pBtCoexist,FORCE_EXEC, FALSE);
-
-	}
-	else
-	{
-		//PTA on
-		pBtCoexist->btInfo.bBtDisabled = FALSE;
-		halbtc8812a2ant_EnablePTA(pBtCoexist,FORCE_EXEC, TRUE);
-	}
-
-}
-
-
-
-VOID
-EXhalbtc8812a2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u2Byte				u2Tmp[4];
-	u4Byte				u4Tmp[4];
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Antenna type:", \
-		pBoardInfo->antType);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%d/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8812a2Ant, GLCoexVer8812a2Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist);
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8812A_2ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8812a2Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Rate Mask", \
-			pBtCoexist->btInfo.raMask);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);	
-	
-	psTdmaCase = pCoexDm->curPsTdma;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d/%d)", "PS TDMA", \
-		pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-		pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-		pCoexDm->psTdmaPara[4], psTdmaCase, pCoexDm->bAutoTdmaAdjust, pCoexDm->bAutoTdmaAdjustLowRssi);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "DecBtPwr/ IgnWlanAct", \
-		pCoexDm->curBtDecPwrLvl, pCoexDm->bCurIgnoreWlanAct);
-	CL_PRINTF(cliBuf);
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "backup ARFR1/ARFR2/RL/AMaxTime", \
-		pCoexDm->backupArfrCnt1, pCoexDm->backupArfrCnt2, pCoexDm->backupRetryLimit, pCoexDm->backupAmpduMaxTime);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-	u2Tmp[0] = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "0x430/0x434/0x42a/0x456", \
-		u4Tmp[0], u4Tmp[1], u2Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x ", "0x778 (W_Act)/ 0x6cc (CoTab Sel)", \
-		u1Tmp[0], u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x8db);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xc5b);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x8db(ADC)/0xc5b[29:25](DAC)", \
-		((u1Tmp[0]&0x60)>>5), ((u1Tmp[1]&0x3e)>>1));
-	CL_PRINTF(cliBuf); 
-	
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb3);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xcb7);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xcb3/ 0xcb7", \
-		u1Tmp[0], u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x974);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x40/ 0x4c[24:23]/ 0x974", \
-		u1Tmp[0], ((u4Tmp[0]&0x01800000)>>23), u4Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa0a);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xc50(DIG)/0xa0a(CCK-TH)", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf48);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5b);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xf48/ 0xa5b (FA cnt-- OFDM : CCK)", \
-		u4Tmp[0], (u1Tmp[0]<<8) + u1Tmp[1]  );
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(high-pri rx/tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri rx/tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8812A_2ANT == 1)
-	halbtc8812a2ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8812a2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN	bWifiUnder5G=FALSE;
-	
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		halbtc8812a2ant_CoexAllOff(pBtCoexist);
-		halbtc8812a2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_CPL_AUX, FALSE, TRUE);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS notify, force set BT to ignore Wlan active!!\n"));
-		halbtc8812a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		EXhalbtc8812a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-		if(!bWifiUnder5G)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS notify, force set BT NOT to ignore Wlan active!!\n"));
-			halbtc8812a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-		}
-	}
-}
-
-VOID
-EXhalbtc8812a2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8812a2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &pCoexSta->nScanAPNum);
-	}
-}
-
-VOID
-EXhalbtc8812a2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8812a2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			dataLen=5;
-	u1Byte			buf[6] = {0};
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-		
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	buf[0] = dataLen;
-	buf[1] = 0x5;				// OP_Code
-	buf[2] = 0x3;				// OP_Code_Length
-	buf[3] = H2C_Parameter[0]; 	// OP_Code_Content
-	buf[4] = H2C_Parameter[1];
-	buf[5] = H2C_Parameter[2];
-		
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);		
-}
-
-VOID
-EXhalbtc8812a2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-
-}
-
-VOID
-EXhalbtc8812a2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtBusy=FALSE, bLimitedDig=FALSE;
-	BOOLEAN			bWifiConnected=FALSE, bBtHsOn=FALSE, bWifiUnder5G=FALSE;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-    
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8812A_2ANT_MAX)
-		rspSource = BT_INFO_SRC_8812A_2ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(BT_INFO_SRC_8812A_2ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if( (pCoexSta->btInfoExt & BIT1) )
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				EXhalbtc8812a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8812a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-	
-		if( (pCoexSta->btInfoExt&BIT3) && !bWifiUnder5G)
-		{
-			// BT already ignored WlanAct
-			if(!pBtCoexist->bManualControl && !pBtCoexist->bStopCoexDm)
-			{
-				if(!pCoexSta->bUnderIps)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-					halbtc8812a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-				}
-			}
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-
-			if(pCoexSta->bUnderIps)
-			{
-				// work around for 8812a combo hw bug => when IPS, wlanAct is always high.
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS, set BT to ignore Wlan active!!\n"));
-				halbtc8812a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-			}
-		}
-	}
-		
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8812A_2ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-	
-	// set link exist status
-	if(!(btInfo&BT_INFO_8812A_2ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-		pCoexSta->bAclBusy = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8812A_2ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8812A_2ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8812A_2ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8812A_2ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-		if(btInfo & BT_INFO_8812A_2ANT_B_ACL_BUSY)
-			pCoexSta->bAclBusy = TRUE;
-		else
-			pCoexSta->bAclBusy = FALSE;			
-		
-	}
-
-	halbtc8812a2ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	if(!(btInfo&BT_INFO_8812A_2ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8812A_2ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8812A_2ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8812A_2ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8812A_2ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8812A_2ANT_B_ACL_BUSY)
-	{
-		pCoexDm->btStatus = BT_8812A_2ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8812A_2ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-
-	if( (BT_8812A_2ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8812A_2ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8812A_2ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bBtBusy = TRUE;
-		if(!bWifiUnder5G)
-			bLimitedDig = TRUE;
-	}
-	else
-	{
-		bBtBusy = FALSE;
-		bLimitedDig = FALSE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	pCoexDm->bLimitedDig = bLimitedDig;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bLimitedDig);
-
-	halbtc8812a2ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8812a2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u1Byte u1Tmp=0;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8812a2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_CPL_AUX, FALSE, TRUE);
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify, force set BT to ignore Wlan active!!\n"));
-	halbtc8812a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	EXhalbtc8812a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-
-	// 0x522=0xff, pause tx
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x522, 0xff);
-	// 0x40[7:6]=2'b01, modify BT mode.
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0xc0, 0x2);
-	//PTA off.
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x0);
-
-}
-
-VOID
-EXhalbtc8812a2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8812a2Ant, GLCoexVer8812a2Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8812A_2ANT == 0)
-	halbtc8812a2ant_QueryBtInfo(pBtCoexist);
-	halbtc8812a2ant_MonitorBtCtr(pBtCoexist);
-//	halbtc8812a2ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	if( halbtc8812a2ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust ||
-		pCoexDm->bAutoTdmaAdjustLowRssi)
-	{
-		halbtc8812a2ant_RunCoexistMechanism(pBtCoexist);
-	}
-#endif
-}
-
-VOID
-EXhalbtc8812a2ant_DbgControl(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				opCode,
-	IN	u1Byte				opLen,
-	IN	pu1Byte				pData
-	)
-{
-	switch(opCode)
-	{
-		case BTC_DBG_SET_COEX_DEC_BT_PWR:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set Dec BT power\n"));
-			{
-				u1Byte	dataLen=4;
-				u1Byte	buf[6] = {0};
-				u1Byte	decBtPwr=0, pwrLevel=0;
-				if(opLen == 2)
-				{
-					decBtPwr = pData[0];
-					pwrLevel = pData[1];
-				
-					buf[0] = dataLen;
-					buf[1] = 0x3;		// OP_Code
-					buf[2] = 0x2;		// OP_Code_Length
-					
-					buf[3] = decBtPwr;	// OP_Code_Content
-					buf[4] = pwrLevel;
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set Dec BT power=%d, pwrLevel=%d\n", decBtPwr, pwrLevel));
-					pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);	
-				}
-			}
-			break;
-			
-		case BTC_DBG_SET_COEX_BT_AFH_MAP:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT AFH Map\n"));
-			{
-				u1Byte	dataLen=5;
-				u1Byte	buf[6] = {0};
-				if(opLen == 3)
-				{
-					buf[0] = dataLen;
-					buf[1] = 0x5;				// OP_Code
-					buf[2] = 0x3;				// OP_Code_Length
-		
-					buf[3] = pData[0];			// OP_Code_Content
-					buf[4] = pData[1];
-					buf[5] = pData[2];
-		
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT AFH Map = %02x %02x %02x\n", 
-						pData[0], pData[1], pData[2]));
-					pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);
-				}
-			}
-			break;
-		
-		case BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT:
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT Ignore Wlan Active\n"));
-			{
-				u1Byte	dataLen=3;
-				u1Byte	buf[6] = {0};
-				if(opLen == 1)
-				{
-					buf[0] = dataLen;
-					buf[1] = 0x1;			// OP_Code
-					buf[2] = 0x1;			// OP_Code_Length
-		
-					buf[3] = pData[0];		// OP_Code_Content
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set BT Ignore Wlan Active = 0x%x\n", 
-						pData[0]));
-						
-					pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_CTRL_BT_COEX, (PVOID)&buf[0]);
-				}
-			}
-			break;
-
-		default:
-			break;
-	}
-}
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a2Ant.h
deleted file mode 100644
index 53e52f3d2471..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8812a2Ant.h
+++ /dev/null
@@ -1,250 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8812A 2Ant BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8812A_2ANT				0
-
-#define	BT_INFO_8812A_2ANT_B_FTP						BIT7
-#define	BT_INFO_8812A_2ANT_B_A2DP					BIT6
-#define	BT_INFO_8812A_2ANT_B_HID						BIT5
-#define	BT_INFO_8812A_2ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8812A_2ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8812A_2ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8812A_2ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8812A_2ANT_B_CONNECTION				BIT0
-
-#define	BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT		2
-#define 	NOISY_AP_NUM_THRESH_8812A						50
-
-
-typedef enum _BT_INFO_SRC_8812A_2ANT{
-	BT_INFO_SRC_8812A_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8812A_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8812A_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8812A_2ANT_MAX
-}BT_INFO_SRC_8812A_2ANT,*PBT_INFO_SRC_8812A_2ANT;
-
-typedef enum _BT_8812A_2ANT_BT_STATUS{
-	BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8812A_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8812A_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8812A_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8812A_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8812A_2ANT_BT_STATUS_MAX
-}BT_8812A_2ANT_BT_STATUS,*PBT_8812A_2ANT_BT_STATUS;
-
-typedef enum _BT_8812A_2ANT_COEX_ALGO{
-	BT_8812A_2ANT_COEX_ALGO_UNDEFINED		= 0x0,
-	BT_8812A_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8812A_2ANT_COEX_ALGO_SCO_HID 		= 0x2,
-	BT_8812A_2ANT_COEX_ALGO_HID				= 0x3,
-	BT_8812A_2ANT_COEX_ALGO_A2DP			= 0x4,
-	BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS		= 0x5,
-	BT_8812A_2ANT_COEX_ALGO_PANEDR			= 0x6,
-	BT_8812A_2ANT_COEX_ALGO_PANHS			= 0x7,
-	BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x8,
-	BT_8812A_2ANT_COEX_ALGO_PANEDR_HID		= 0x9,
-	BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0xa,
-	BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS	= 0xb,
-	BT_8812A_2ANT_COEX_ALGO_HID_A2DP		= 0xc,
-	BT_8812A_2ANT_COEX_ALGO_MAX				= 0xd
-}BT_8812A_2ANT_COEX_ALGO,*PBT_8812A_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8812A_2ANT{
-	// fw mechanism
-	u1Byte		preBtDecPwrLvl;
-	u1Byte		curBtDecPwrLvl;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bAutoTdmaAdjustLowRssi;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-	BOOLEAN		bPreEnablePTA;
-	BOOLEAN		bCurEnablePTA;
-
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-	u4Byte		backupArfrCnt1;	// Auto Rate Fallback Retry cnt
-	u4Byte		backupArfrCnt2;	// Auto Rate Fallback Retry cnt
-	u2Byte		backupRetryLimit;
-	u1Byte		backupAmpduMaxTime;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-	u1Byte		curRaMaskType;
-	u1Byte		preArfrType;
-	u1Byte		curArfrType;
-	u1Byte		preRetryLimitType;
-	u1Byte		curRetryLimitType;
-	u1Byte		preAmpduTimeType;
-	u1Byte		curAmpduTimeType;
-} COEX_DM_8812A_2ANT, *PCOEX_DM_8812A_2ANT;
-
-typedef struct _COEX_STA_8812A_2ANT{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-	BOOLEAN					bAclBusy;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	u1Byte					preBtRssiState;
-	u1Byte					preBtDisabled;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8812A_2ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8812A_2ANT_MAX];
-	u4Byte					prebtInfoC2hCnt_BT_RSP;
-	u4Byte					prebtInfoC2hCnt_BT_SEND;
-	u4Byte					btInfoQueryCnt;
-	BOOLEAN					bC2hBtInquiryPage;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-	u1Byte					nScanAPNum;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;
-
-	u1Byte					nCoexTableType;
-	BOOLEAN					bForceLpsOn;
-
-	u1Byte					disVerInfoCnt;
-
-}COEX_STA_8812A_2ANT, *PCOEX_STA_8812A_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8812a2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8812a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8812a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8812a2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8812a2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8812a2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8812a2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8812a2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8812a2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8812a2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8812a2ant_DbgControl(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				opCode,
-	IN	u1Byte				opLen,
-	IN	pu1Byte 			pData
-	);
-VOID
-EXhalbtc8812a2ant_BTOffOnNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte			BTstatus 
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a1Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a1Ant.c
deleted file mode 100644
index 269edc27cb3f..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a1Ant.c
+++ /dev/null
@@ -1,3434 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for 8821A_1ANT Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8821a1Ant.tmh"
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8821A_1ANT		GLCoexDm8821a1Ant;
-static PCOEX_DM_8821A_1ANT 	pCoexDm=&GLCoexDm8821a1Ant;
-static COEX_STA_8821A_1ANT		GLCoexSta8821a1Ant;
-static PCOEX_STA_8821A_1ANT	pCoexSta=&GLCoexSta8821a1Ant;
-
-const char *const GLBtInfoSrc8821a1Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8821a1Ant=20140306;
-u4Byte	GLCoexVer8821a1Ant=0x4b;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8821a1ant_
-//============================================================
-u1Byte
-halbtc8821a1ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8821a1ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8821a1ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-VOID
-halbtc8821a1ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-VOID
-halbtc8821a1ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-VOID
-halbtc8821a1ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8821a1ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType
-	)
-{
-	switch(raMaskType)
-	{
-		case 0:	// normal mode
-			halbtc8821a1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0);
-			break;
-		case 1:	// disable cck 1/2
-			halbtc8821a1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x00000003);
-			break;
-		case 2:	// disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4
-			halbtc8821a1ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0001f1f7);
-			break;
-		default:
-			break;
-	}
-
-	halbtc8821a1ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8821a1ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8821a1ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-}
-
-VOID
-halbtc8821a1ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-VOID
-halbtc8821a1ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp, u4Tmp1;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp, u1Tmp1;
-	s4Byte			wifiRssi;
-#if 0
-       //to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS
-	if (! (pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e) & 0x8) ) 
-	{
-		pCoexSta->highPriorityTx = 65535;
-		pCoexSta->highPriorityRx = 65535;
-		pCoexSta->lowPriorityTx = 65535;
-		pCoexSta->lowPriorityRx = 65535;
-		return;
-	}
-#endif	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8821a1ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-BOOLEAN
-halbtc8821a1ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN bWifiConnected=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8821a1ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8821a1ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8821A_1ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO only\n"));
-			algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID only\n"));
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP only\n"));
-				algorithm = BT_8821A_1ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(HS) only\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = PAN(EDR) only\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID\n"));
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(HS)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + PAN(EDR)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP\n"));
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(HS)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + PAN(EDR)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = A2DP + PAN(EDR)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8821a1ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8821a1ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8821a1ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8821a1ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!") ));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8821a1ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8821a1ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8821a1ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8821a1ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8821a1ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8821a1ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** CoexTable(%d) **********\n", type));
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0x5a5a5a5a, 0xaaaa5a5a, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0xaaaa5a5a, 0xffffff, 0x3);
-			break;
-		case 7:
-			halbtc8821a1ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8821a1ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8821a1ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8821a1ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8821a1ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	u1Byte			realByte1=byte1, realByte5=byte5;
-	BOOLEAN			bApEnable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-
-	if(bApEnable)
-	{
-		if(byte1&BIT4 && !(byte1&BIT5))
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW for 1Ant AP mode\n"));
-			realByte1 &= ~BIT4;
-			realByte1 |= BIT5;
-
-			realByte5 |= BIT5;
-			realByte5 &= ~BIT6;
-		}
-	}
-
-	H2C_Parameter[0] = realByte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = realByte5;
-
-	pCoexDm->psTdmaPara[0] = realByte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = realByte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-VOID
-halbtc8821a1ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8821a1ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8821a1ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8821a1ant_SwMechanism(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN 	bLowPenaltyRA
-	) 
-{
-	halbtc8821a1ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8821a1ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	PBTC_BOARD_INFO pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte			fwVer=0, u4Tmp=0;
-	u1Byte			H2C_Parameter[2] ={0};
-	
-	if(bInitHwCfg)
-	{
-		// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp &=~BIT23;
-		u4Tmp |= BIT24;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-
-		//0x765 = 0x18
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x765, 0x18, 0x3); 	
-
-		if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT) 
-		{
-			//tell firmware "antenna inverse"  ==> WRONG firmware antenna control code.==>need fw to fix
-			H2C_Parameter[0] = 1;
-			H2C_Parameter[1] = 1;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-
-			//pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x64, 0x1, 0x1); //Main Ant to  BT for IPS case 0x4c[23]=1
-		}
-		else
-		{
-			//tell firmware "no antenna inverse" ==> WRONG firmware antenna control code.==>need fw to fix
-			H2C_Parameter[0] = 0;
-			H2C_Parameter[1] = 1;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-
-			//pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x64, 0x1, 0x0); //Aux Ant to  BT for IPS case 0x4c[23]=1
-		}
-	}
-	else if(bWifiOff)
-	{
-		// 0x4c[24:23]=00, Set Antenna control by BT_RFE_CTRL	BT Vendor 0xac=0xf002
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp &= ~BIT23;
-		u4Tmp &= ~BIT24;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-
-		//0x765 = 0x18
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x765, 0x18, 0x3); 
-	}
-	else
-	{
-		//0x765 = 0x0
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x765, 0x18, 0x0); 
-	}
-	
-	// ext switch setting
-	switch(antPosType)
-	{
-		case BTC_ANT_PATH_WIFI:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb4, 0x77);
-			if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x1);
-			else
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x2);
-			break;
-		case BTC_ANT_PATH_BT:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb4, 0x77);
-			if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x2);
-			else
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x1);
-			break;
-		default:
-		case BTC_ANT_PATH_PTA:
-			pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb4, 0x66);
-			if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT)
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x1);
-			else
-				pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x2);
-			break;
-	}
-}
-
-VOID
-halbtc8821a1ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	PBTC_BOARD_INFO	pBoardInfo=&pBtCoexist->boardInfo;
-	BOOLEAN			bTurnOnByCnt=FALSE;
-	u1Byte			psTdmaTypeByCnt=0, rssiAdjustVal=0;
-	//u4Byte			fwVer=0;
-
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if (pCoexDm->bCurPsTdmaOn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-			pCoexDm->curPsTdma));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(off, %d) **********\n", 
-			pCoexDm->curPsTdma));
-	}
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}
-	if(bTurnOn)
-	{
-		switch(type)
-		{
-			default:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1a, 0x1a, 0x0, 0x50);
-				break;
-			case 1:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x3a, 0x03, 0x10, 0x50);
-				rssiAdjustVal = 11;
-				break;
-			case 2:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x2b, 0x03, 0x10, 0x50);
-				rssiAdjustVal = 14;
-				break;
-			case 3:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x1d, 0x1d, 0x0, 0x52);
-				break;
-			case 4:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x14, 0x0);
-				rssiAdjustVal = 17;
-				break;
-			case 5:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x15, 0x3, 0x11, 0x10);
-				break;
-			case 6:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x20, 0x3, 0x11, 0x13);
-				break;
-			case 7:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x13, 0xc, 0x5, 0x0, 0x0);
-				break;
-			case 8:	
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				break;
-			case 9:	
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x21, 0x3, 0x10, 0x50);
-				rssiAdjustVal = 18;
-				break;
-			case 10:	
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0xa, 0x0, 0x40);
-				break;
-			case 11:	
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x15, 0x03, 0x10, 0x50);
-				rssiAdjustVal = 20;
-				break;
-			case 12:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x0a, 0x0a, 0x0, 0x50);
-				break;
-			case 13:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x12, 0x12, 0x0, 0x50);
-				break;
-			case 14:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x21, 0x3, 0x10, 0x52);
-				break;
-			case 15:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x13, 0xa, 0x3, 0x8, 0x0);
-				break;
-			case 16:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x15, 0x3, 0x10, 0x0);
-				rssiAdjustVal = 18;
-				break;
-			case 18:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x93, 0x25, 0x3, 0x10, 0x0);
-				rssiAdjustVal = 14;
-				break;			
-			case 20:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x35, 0x03, 0x11, 0x10);
-				break;
-			case 21:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x11);
-				break;
-			case 22:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x25, 0x03, 0x11, 0x10);
-				break;
-			case 23:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x18);
-				rssiAdjustVal = 22;
-				break;
-			case 24:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x3, 0x31, 0x18);
-				rssiAdjustVal = 22;
-				break;
-			case 25:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				rssiAdjustVal = 22;
-				break;
-			case 26:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0x3, 0x31, 0x18);
-				rssiAdjustVal = 22;
-				break;
-			case 27:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x3, 0x31, 0x98);
-				rssiAdjustVal = 22;
-				break;
-			case 28:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x69, 0x25, 0x3, 0x31, 0x0);
-				break;
-			case 29:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xab, 0x1a, 0x1a, 0x1, 0x10);
-				break;
-			case 30:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x51, 0x30, 0x3, 0x10, 0x10);
-				break;
-			case 31:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1a, 0x1a, 0, 0x58);
-				break;
-			case 32:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x61, 0x35, 0x3, 0x11, 0x11);
-				break;
-			case 33:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xa3, 0x25, 0x3, 0x30, 0x90);
-				break;
-			case 34:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x53, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 35:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x63, 0x1a, 0x1a, 0x0, 0x10);
-				break;
-			case 36:
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0xd3, 0x12, 0x3, 0x14, 0x50);
-				break;
-			case 40: // SoftAP only with no sta associated,BT disable ,TDMA mode for power saving
-				/* here softap mode screen off will cost 70-80mA for phone */
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x23, 0x18, 0x00, 0x10, 0x24);
-				break;	
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(type)
-		{
-			case 8: //PTA Control
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-				halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, FALSE, FALSE);
-				break;
-			case 0:
-			default:  //Software control, Antenna at BT side
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, FALSE);
-				break;
-			case 9:   //Software control, Antenna at WiFi side
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x0, 0x0);
-				halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_WIFI, FALSE, FALSE);
-				break;
-			case 10:	// under 5G
-				halbtc8821a1ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x8, 0x0);
-				halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, FALSE);
-				break;
-		}
-	}
-	rssiAdjustVal =0;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssiAdjustVal);
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8821a1ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// sw all off
-	halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-
-	// hw all off
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-BOOLEAN
-halbtc8821a1ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected && 
-		BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n"));
- 		halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-			(BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-		halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT connected-idle!!\n"));
-		halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-		halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE != pCoexDm->btStatus) )
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non connected-idle + BT Busy!!\n"));
-		halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-		
-		bCommon = TRUE;
-	}
-	else
-	{
-		if (bWifiBusy)			
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-		}
-		
-		bCommon = FALSE;
-	}
-	
-	return bCommon;
-}
-
-
-VOID
-halbtc8821a1ant_TdmaDurationAdjustForAcl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0, btInfoExt;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjustForAcl()\n"));
-
-	if( (BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN == wifiStatus) ||
-		(BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifiStatus) ||
-		(BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT == wifiStatus) )
-	{
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 3 &&
-			pCoexDm->curPsTdma != 9 )
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-			pCoexDm->psTdmaDuAdjType = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n= 3;
-			result = 0;
-			WaitCount = 0;
-		}		
-		return;
-	}
-	
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-		pCoexDm->psTdmaDuAdjType = 2;
-		//============
-		up = 0;
-		dn = 0;
-		m = 1;
-		n= 3;
-		result = 0;
-		WaitCount = 0;
-	}
-	else
-	{
-		//accquire the BT TRx retry count from BT_Info byte2
-		retryCount = pCoexSta->btRetryCnt;
-		btInfoExt = pCoexSta->btInfoExt;
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		if(result == -1)
-		{
-			if( (BT_INFO_8821A_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 1)
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-				pCoexDm->psTdmaDuAdjType = 11;
-			}
-		}
-		else if(result == 1)
-		{
-			if( (BT_INFO_8821A_1ANT_A2DP_BASIC_RATE(btInfoExt)) &&
-				((pCoexDm->curPsTdma == 1) ||(pCoexDm->curPsTdma == 2)) )
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 11)
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-				pCoexDm->psTdmaDuAdjType = 9;
-			}
-			else if(pCoexDm->curPsTdma == 9)
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-				pCoexDm->psTdmaDuAdjType = 2;
-			}
-			else if(pCoexDm->curPsTdma == 2)
-			{
-				halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-				pCoexDm->psTdmaDuAdjType = 1;
-			}
-		}
-		else	  //no change
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ********** TDMA(on, %d) **********\n", 
-				pCoexDm->curPsTdma));
-		}
-
-		if( pCoexDm->curPsTdma != 1 &&
-			pCoexDm->curPsTdma != 2 &&
-			pCoexDm->curPsTdma != 9 &&
-			pCoexDm->curPsTdma != 11 )
-		{
-			// recover to previous adjust type
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-	}
-}
-
-VOID
-halbtc8821a1ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8821a1ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8821a1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8821a1ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8821a1ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8821a1ant_CoexUnder5G(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	halbtc8821a1ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, TRUE);
-
-	halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 10);
-
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-	halbtc8821a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 5);
-}
-
-VOID
-halbtc8821a1ant_ActionWifiOnly(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 9);	
-}
-
-VOID
-halbtc8821a1ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte		btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-			halbtc8821a1ant_ActionWifiOnly(pBtCoexist);
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		}
-	}
-}
-
-//=============================================
-//
-//	Software Coex Mechanism start
-//
-//=============================================
-
-// SCO only or SCO+PAN(HS)
-VOID
-halbtc8821a1ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-VOID
-halbtc8821a1ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8821a1ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8821a1ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8821a1ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(HS) only
-VOID
-halbtc8821a1ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8821a1ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-}
-
-VOID
-halbtc8821a1ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8821a1ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-VOID
-halbtc8821a1ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_SwMechanism(pBtCoexist, TRUE);
-}
-
-//=============================================
-//
-//	Non-Software Coex Mechanism start
-//
-//=============================================
-VOID
-halbtc8821a1ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8821a1ant_ActionHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-}
-
-VOID
-halbtc8821a1ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN			bWifiConnected=FALSE, bApEnable=FALSE, bWifiBusy=FALSE, bBtBusy=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	if((!bWifiConnected) && (!pCoexSta->bWiFiIsHighPriTask))
-	{
-		halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-
-	 	halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);		
-	}
-	else if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist) || (pBtLinkInfo->bA2dpExist))
-	{
-		// SCO/HID/A2DP  busy
-		halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if ((pBtLinkInfo->bPanExist) || (bWifiBusy))
-	{
-		halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);		
-		
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	}
-	else
-	{
-		halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	}
-}
-
-VOID
-halbtc8821a1ant_ActionBtScoHidOnlyBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	// tdma and coex table
-
-	if(pBtLinkInfo->bScoExist)
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-	else //HID
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 5);
-	}
-}
-
-VOID
-halbtc8821a1ant_ActionWifiConnectedBtAclBusy(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				wifiStatus
-	)
-{
-	u1Byte		btRssiState;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	btRssiState = halbtc8821a1ant_BtRssiState(2, 28, 0);	
-
-	if(pBtLinkInfo->bHidOnly)  //HID
-	{
-		halbtc8821a1ant_ActionBtScoHidOnlyBusy(pBtCoexist, wifiStatus);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-		return;
-	}
-	else if(pBtLinkInfo->bA2dpOnly)  //A2DP		
-	{
-		if(BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifiStatus)
-		{
-			//halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			//halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		else if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )	
-		{
-			halbtc8821a1ant_TdmaDurationAdjustForAcl(pBtCoexist, wifiStatus);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-		}
-		else //for low BT RSSI
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-	}
-	else if(pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist)  //HID+A2DP
-	{
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )	
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		else //for low BT RSSI
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}		   	
-
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 6);
-	}
-	else if( (pBtLinkInfo->bPanOnly) || (pBtLinkInfo->bHidExist&&pBtLinkInfo->bPanExist) ) //PAN(OPP,FTP), HID+PAN(OPP,FTP)			
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 6);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else if ( ((pBtLinkInfo->bA2dpExist) && (pBtLinkInfo->bPanExist)) ||
-		       (pBtLinkInfo->bHidExist&&pBtLinkInfo->bA2dpExist&&pBtLinkInfo->bPanExist) ) //A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP)
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{		
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}	
-}
-
-VOID
-halbtc8821a1ant_ActionWifiNotConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// power save state
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table	
-	halbtc8821a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8821a1ant_ActionWifiNotConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	// tdma and coex table
-	if(BT_8821A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-	 {
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	 	else
-	 	{
-		        halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-	}
-	else if( (BT_8821A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8821a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		//halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-
-		//Bryant Add
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8821a1ant_ActionWifiNotConnectedAssoAuth(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if( (pBtLinkInfo->bScoExist)  || (pBtLinkInfo->bHidExist) )
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if( (pBtLinkInfo->bA2dpExist)  || (pBtLinkInfo->bPanExist) ) 			
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else	
-	{		
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8821a1ant_ActionWifiConnectedScan(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(BT_8821A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-	{
-		if (pBtLinkInfo->bA2dpExist)
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-		}
-		else if (pBtLinkInfo->bA2dpExist && pBtLinkInfo->bPanExist)
-	 	{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	 	else
-	 	{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);
-	 	}
-	}
-	else if( (BT_8821A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		halbtc8821a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-			BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	}
-	else
-	{
-		//halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		//halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 1);
-
-		//Bryant Add
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8821a1ant_ActionWifiConnectedSpecialPacket(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if((pBtLinkInfo->bScoExist) || (pBtLinkInfo->bHidExist) || (pBtLinkInfo->bA2dpExist))
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 32);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else if(pBtLinkInfo->bPanExist) 
-	{
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 20);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 4);		
-	}
-	else	
-	{		
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-}
-
-VOID
-halbtc8821a1ant_ActionWifiConnected(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN 	bWifiBusy=FALSE;
-	BOOLEAN 	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-	BOOLEAN		bUnder4way=FALSE, bApEnable=FALSE;
-	u4Byte		wifiBw;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect()===>\n"));
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-	if(bUnder4way)
-	{
-		halbtc8821a1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n"));
-		return;
-	}
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	if(bScan || bLink || bRoam)
-	{
-		if(bScan)	
-			halbtc8821a1ant_ActionWifiConnectedScan(pBtCoexist);
-		else
-			halbtc8821a1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	// power save state
-	if(!bApEnable && BT_8821A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus && !pBtCoexist->btLinkInfo.bHidOnly)
-	{
-		if(!bWifiBusy && pBtCoexist->btLinkInfo.bA2dpOnly)	//A2DP
-			halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-	else
-		halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-	// tdma and coex table
-	if(!bWifiBusy)
-	{
-		if(BT_8821A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8821a1ant_ActionWifiConnectedBtAclBusy(pBtCoexist, 
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else if( (BT_8821A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8821a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		}
-		else
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-		}
-	}
-	else
-	{
-		if(BT_8821A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus)
-		{
-			halbtc8821a1ant_ActionWifiConnectedBtAclBusy(pBtCoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else if( (BT_8821A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-			(BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		{
-			halbtc8821a1ant_ActionBtScoHidOnlyBusy(pBtCoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		}
-		else 
-		{
-			halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 8);
-			halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-		}
-	}
-}
-
-VOID
-halbtc8821a1ant_RunSwCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	algorithm=0;
-
-	algorithm = halbtc8821a1ant_ActionAlgorithm(pBtCoexist);
-	pCoexDm->curAlgorithm = algorithm;
-
-	if(halbtc8821a1ant_IsCommonAction(pBtCoexist))
-	{
-
-	}
-	else
-	{
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8821A_1ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = SCO.\n"));
-				halbtc8821a1ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID.\n"));
-				halbtc8821a1ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP.\n"));
-				halbtc8821a1ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = A2DP+PAN(HS).\n"));
-				halbtc8821a1ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR).\n"));
-				halbtc8821a1ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HS mode.\n"));
-				halbtc8821a1ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN+A2DP.\n"));
-				halbtc8821a1ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = PAN(EDR)+HID.\n"));
-				halbtc8821a1ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP+PAN.\n"));
-				halbtc8821a1ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8821A_1ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = HID+A2DP.\n"));
-				halbtc8821a1ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action algorithm = coexist All Off!!\n"));
-				//halbtc8821a1ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8821a1ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;
-	BOOLEAN	bIncreaseScanDevNum=FALSE;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-	u1Byte	wifiRssiState=BTC_RSSI_STATE_HIGH;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bWifiUnder5G=FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	if(pBtCoexist->bStopCoexDm)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n"));
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-	if(bWifiUnder5G)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for 5G <===\n"));
-		halbtc8821a1ant_CoexUnder5G(pBtCoexist);
-		return;
-	}
-
-	if( (BT_8821A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8821A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bIncreaseScanDevNum = TRUE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_INC_SCAN_DEV_NUM, &bIncreaseScanDevNum);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8821a1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	if(!pBtLinkInfo->bScoExist && !pBtLinkInfo->bHidExist)
-	{
-		halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-	}
-	else
-	{
-		if(bWifiConnected)
-		{
-			wifiRssiState = halbtc8821a1ant_WifiRssiState(pBtCoexist, 1, 2, 30, 0);
-			if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-				(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-				halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 1, 1);
-			}
-			else
-			{
-				halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 1, 1, 1, 1);
-			}
-		}
-		else
-		{
-			halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		}
-
-	}
-
-	if(pBtLinkInfo->bScoExist)
-	{
-		bBtCtrlAggBufSize = TRUE;
-		aggBufSize = 0x3;
-	}
-	else if(pBtLinkInfo->bHidExist)
-	{
-		bBtCtrlAggBufSize = TRUE;
-		aggBufSize = 0x5;
-	}
-	else if(pBtLinkInfo->bA2dpExist || pBtLinkInfo->bPanExist)
-	{
-		bBtCtrlAggBufSize = TRUE;
-		aggBufSize = 0x8;
-	}
-	halbtc8821a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-
-	halbtc8821a1ant_RunSwCoexistMechanism(pBtCoexist);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8821a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8821a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	
-	if(!bWifiConnected)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is non connected-idle !!!\n"));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-		if(bScan || bLink || bRoam)
-		{
-			 if (bScan)	
-		   		halbtc8821a1ant_ActionWifiNotConnectedScan(pBtCoexist);	
-			 else
-		    		halbtc8821a1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);	
-		}
-		else
-			halbtc8821a1ant_ActionWifiNotConnected(pBtCoexist);
-	}
-	else	// wifi LPS/Busy
-	{	
-		halbtc8821a1ant_ActionWifiConnected(pBtCoexist);
-	}
-}
-
-VOID
-halbtc8821a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// force to reset coex mechanism
-	// sw all off
-	halbtc8821a1ant_SwMechanism(pBtCoexist, FALSE);
-
-	//halbtc8821a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-}
-
-VOID
-halbtc8821a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte	u4Tmp=0;
-	u2Byte				u2Tmp=0;
-	u1Byte	u1Tmp=0;
-	u1Byte				H2C_Parameter[2] ={0};
-	BOOLEAN			bWifiUnder5G=FALSE;
-		
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 1Ant Init HW Config!!\n"));
-
-	if(bWifiOnly)
-		return;
-	
-	if(bBackUp)
-	{
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	}
-
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-
-	//Antenna config
-	if(bWifiUnder5G)
-		halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, TRUE, FALSE);
-	else
-		halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_PTA, TRUE, FALSE);
-
-	// PTA parameter
-	halbtc8821a1ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-
-	// Enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc); //0x76e[3] =1, WLAN_Act control by PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x3);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x1);
-}
-
-//============================================================
-// work around function start with wa_halbtc8821a1ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8821a1ant_
-//============================================================
-VOID
-EXhalbtc8821a1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8821a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8821a1ant_InitHwConfig(pBtCoexist, TRUE, bWifiOnly);
-}
-
-VOID
-EXhalbtc8821a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-
-	pBtCoexist->bStopCoexDm = FALSE;
-	
-	halbtc8821a1ant_InitCoexDm(pBtCoexist);
-
-	halbtc8821a1ant_QueryBtInfo(pBtCoexist);
-}
-
-VOID
-EXhalbtc8821a1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u2Byte				u2Tmp[4];
-	u4Byte				u4Tmp[4];
-	u4Byte				faOfdm, faCck;
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-	if(pBtCoexist->bStopCoexDm)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "Ant PG Num/ Ant Mech/ Ant Pos:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos);
-	CL_PRINTF(cliBuf);	
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8821a1Ant, GLCoexVer8821a1Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist);
-	CL_PRINTF(cliBuf);	
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8821A_1ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8821a1Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	if(!pBtCoexist->bManualControl)
-	{
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "SM[LowPenaltyRA]", \
-		pCoexDm->bCurLowPenaltyRa);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %d ", "DelBA/ BtCtrlAgg/ AggSize", \
-		(pBtCoexist->btInfo.bRejectAggPkt? "Yes":"No"), (pBtCoexist->btInfo.bBtCtrlAggBufSize? "Yes":"No"),
-			pBtCoexist->btInfo.aggBufSize);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Rate Mask", \
-			pBtCoexist->btInfo.raMask);
-	CL_PRINTF(cliBuf);	
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);	
-	
-		psTdmaCase = pCoexDm->curPsTdma;
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase, pCoexDm->bAutoTdmaAdjust);
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IgnWlanAct", \
-			pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Latest error condition(should be 0)", \
-			pCoexDm->errorCondition);
-		CL_PRINTF(cliBuf);
-	}
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "backup ARFR1/ARFR2/RL/AMaxTime", \
-		pCoexDm->backupArfrCnt1, pCoexDm->backupArfrCnt2, pCoexDm->backupRetryLimit, pCoexDm->backupAmpduMaxTime);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-	u2Tmp[0] = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x", "0x430/0x434/0x42a/0x456", \
-		u4Tmp[0], u4Tmp[1], u2Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc58);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x778/ 0xc58[29:25]", \
-		u1Tmp[0], (u4Tmp[0]&0x3e000000) >> 25);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x8db);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8db[6:5]", \
-		((u1Tmp[0]&0x60)>>5));
-	CL_PRINTF(cliBuf); 
-	
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x975);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcb4);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0xcb4[29:28]/0xcb4[7:0]/0x974[9:8]", \
-		(u4Tmp[0]&0x30000000)>>28, u4Tmp[0]&0xff, u1Tmp[0]& 0x3);
-	CL_PRINTF(cliBuf);
-
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x64);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x40/0x4c[24:23]/0x64[0]", \
-		u1Tmp[0], ((u4Tmp[0]&0x01800000)>>23), u1Tmp[1]&0x1);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-		u4Tmp[0]&0xff);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf48);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5d);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "OFDM-FA/ CCK-FA", \
-		u4Tmp[0], (u1Tmp[0]<<8) + u1Tmp[1]  );
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x6c0/0x6c4/0x6c8(coexTable)", \
-		u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(high-pri rx/tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri rx/tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8821A_1ANT == 1)
-	halbtc8821a1ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8821a1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u4Byte	u4Tmp=0;
-
-	if(pBtCoexist->bManualControl ||	pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);	
-		//halbtc8821a1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-
-		halbtc8821a1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8821a1ant_InitCoexDm(pBtCoexist);
-		halbtc8821a1ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8821a1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(pBtCoexist->bManualControl || pBtCoexist->bStopCoexDm)
-		return;
-
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8821a1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm )
-		return;
-
-	if(BTC_SCAN_START == type)
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-
-		halbtc8821a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 8);  //Force antenna setup for no scan result issue
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-	}	
-
-	if(pBtCoexist->btInfo.bBtDisabled)
-		return;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	halbtc8821a1ant_QueryBtInfo(pBtCoexist);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8821a1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-	
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8821a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8821a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_SCAN_START == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8821a1ant_ActionWifiNotConnectedScan(pBtCoexist);
-		}
-		else	// wifi is connected
-		{
-			halbtc8821a1ant_ActionWifiConnectedScan(pBtCoexist);
-		}
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-		if(!bWifiConnected)	// non-connected scan
-		{
-			halbtc8821a1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8821a1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8821a1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN	bWifiConnected=FALSE, bBtHsOn=FALSE;	
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-	 pCoexSta->bWiFiIsHighPriTask = TRUE;
-		 RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));	
-		 pCoexDm->nArpCnt = 0;
-	}
-	else
-	{
-	 pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		 RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));	
-		pCoexDm->nArpCnt = 0;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8821a1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8821a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8821a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if(BTC_ASSOCIATE_START == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));		
-		halbtc8821a1ant_ActionWifiNotConnectedAssoAuth(pBtCoexist);
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-		
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-		if(!bWifiConnected) // non-connected scan
-		{
-			halbtc8821a1ant_ActionWifiNotConnected(pBtCoexist);
-		}
-		else
-		{
-			halbtc8821a1ant_ActionWifiConnected(pBtCoexist);
-		}
-	}
-}
-
-VOID
-EXhalbtc8821a1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-		pCoexDm->nArpCnt = 0;
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		//H2C_Parameter[0] = 0x1;
-		H2C_Parameter[0] = 0x0;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-		
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);
-}
-
-VOID
-EXhalbtc8821a1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bBtHsOn=FALSE;
-	u4Byte	wifiLinkStatus=0;
-	u4Byte	numOfWifiLink=0;
-	BOOLEAN	bBtCtrlAggBufSize=FALSE;
-	u1Byte	aggBufSize=5;
-	
-	if(pBtCoexist->bManualControl ||
-		pBtCoexist->bStopCoexDm ||
-		pBtCoexist->btInfo.bBtDisabled )
-		return;
-
-	if( BTC_PACKET_DHCP == type || 
-		BTC_PACKET_EAPOL == type ||
-		BTC_PACKET_ARP == type )
-	{
-		pCoexSta->bWiFiIsHighPriTask = TRUE;
-
-		if(BTC_PACKET_ARP == type)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet ARP notify\n"));		 
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet DHCP or EAPOL notify\n"));		 
-		}
-	}
-	else
-	{
-		pCoexSta->bWiFiIsHighPriTask = FALSE;	
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet [Type = %d] notify\n", type));
-	}
-
-	pCoexSta->specialPktPeriodCnt = 0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	if(numOfWifiLink >= 2)
-	{
-		halbtc8821a1ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, bBtCtrlAggBufSize, aggBufSize);
-		halbtc8821a1ant_ActionWifiMultiPort(pBtCoexist);
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	if(pCoexSta->bC2hBtInquiryPage)
-	{
-		halbtc8821a1ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else if(bBtHsOn)
-	{
-		halbtc8821a1ant_ActionHs(pBtCoexist);
-		return;
-	}
-
-	if( BTC_PACKET_DHCP == type ||
-		BTC_PACKET_EAPOL == type || 
-		BTC_PACKET_ARP == type )
-	{
-		//RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], special Packet(%d) notify\n", type));
-		if(BTC_PACKET_ARP == type)
-		{
-			pCoexDm->nArpCnt++;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ARP Packet Count = %d\n", pCoexDm->nArpCnt));
-			if(pCoexDm->nArpCnt >= 10) // if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecialPacket(pBtCoexist) 
-				return;	
-		}
-		
-		halbtc8821a1ant_ActionWifiConnectedSpecialPacket(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8821a1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte				btInfo=0;
-	u1Byte				i, rspSource=0;
-	BOOLEAN				bWifiConnected=FALSE;
-	BOOLEAN				bBtBusy=FALSE;
-	BOOLEAN				bWifiUnder5G=FALSE;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8821A_1ANT_MAX)
-		rspSource = BT_INFO_SRC_8821A_1ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(BT_INFO_SRC_8821A_1ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		if (pCoexSta->btInfoC2h[rspSource][2]&0x20)
-			pCoexSta->bC2hBtPage = TRUE;
-		else
-			pCoexSta->bC2hBtPage = FALSE;			
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-		if(!pCoexSta->bBtTxRxMask)
-		{
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */				
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n"));
-			pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15);
-		}
-		
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if(pCoexSta->btInfoExt & BIT1)
-		{			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-			if(bWifiConnected)
-			{
-				EXhalbtc8821a1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8821a1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-
-		if( (pCoexSta->btInfoExt & BIT3) && !bWifiUnder5G)
-		{
-			if(!pBtCoexist->bManualControl && !pBtCoexist->bStopCoexDm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-				halbtc8821a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-			}
-		}
-		else
-		{
-			// BT already NOT ignore Wlan active, do nothing here.
-		}
-#if(BT_AUTO_REPORT_ONLY_8821A_1ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8821a1ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-		
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8821A_1ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8821A_1ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8821A_1ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8821A_1ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8821A_1ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8821A_1ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-	}
-
-	halbtc8821a1ant_UpdateBtLinkInfo(pBtCoexist);
-		
-	btInfo = btInfo & 0x1f;  //mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41)
-	
-	if(!(btInfo&BT_INFO_8821A_1ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8821A_1ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8821A_1ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8821A_1ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8821A_1ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8821A_1ANT_B_ACL_BUSY)
-	{
-		if(BT_8821A_1ANT_BT_STATUS_ACL_BUSY != pCoexDm->btStatus)
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		pCoexDm->btStatus = BT_8821A_1ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8821A_1ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-
-	if( (BT_8821A_1ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8821A_1ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-		bBtBusy = TRUE;
-	else
-		bBtBusy = FALSE;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	halbtc8821a1ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8821a1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	u4Byte	u4Tmp;
-	
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	halbtc8821a1ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 0);
-	halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);
-	//halbtc8821a1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF);
-
-	halbtc8821a1ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-
-	EXhalbtc8821a1ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-
-	pBtCoexist->bStopCoexDm = TRUE;	
-}
-
-VOID
-EXhalbtc8821a1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-
-		halbtc8821a1ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8821a1ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8821a1ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-		halbtc8821a1ant_SetAntPath(pBtCoexist, BTC_ANT_PATH_BT, FALSE, TRUE);
-	       //halbtc8821a1ant_SetAntPathDCut(pBtCoexist, FALSE, FALSE, FALSE, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF);
-
-		pBtCoexist->bStopCoexDm = TRUE;
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		pBtCoexist->bStopCoexDm = FALSE;
-		halbtc8821a1ant_InitHwConfig(pBtCoexist, FALSE, FALSE);
-		halbtc8821a1ant_InitCoexDm(pBtCoexist);
-		halbtc8821a1ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8821a1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8821a1Ant, GLCoexVer8821a1Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8821A_1ANT == 0)
-	halbtc8821a1ant_QueryBtInfo(pBtCoexist);
-	halbtc8821a1ant_MonitorBtCtr(pBtCoexist);
-	halbtc8821a1ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	if( halbtc8821a1ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust )
-	{
-		//if(pCoexSta->specialPktPeriodCnt > 2)
-		//{
-			halbtc8821a1ant_RunCoexistMechanism(pBtCoexist);	
-		//}
-	}
-
-	pCoexSta->specialPktPeriodCnt++;
-#endif
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a1Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a1Ant.h
deleted file mode 100644
index 684e9468ce18..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a1Ant.h
+++ /dev/null
@@ -1,214 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8821A 1ANT BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8821A_1ANT				1
-
-#define	BT_INFO_8821A_1ANT_B_FTP						BIT7
-#define	BT_INFO_8821A_1ANT_B_A2DP					BIT6
-#define	BT_INFO_8821A_1ANT_B_HID						BIT5
-#define	BT_INFO_8821A_1ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8821A_1ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8821A_1ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8821A_1ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8821A_1ANT_B_CONNECTION				BIT0
-
-#define	BT_INFO_8821A_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT0))? TRUE:FALSE)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT		2
-
-typedef enum _BT_INFO_SRC_8821A_1ANT{
-	BT_INFO_SRC_8821A_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8821A_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8821A_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8821A_1ANT_MAX
-}BT_INFO_SRC_8821A_1ANT,*PBT_INFO_SRC_8821A_1ANT;
-
-typedef enum _BT_8821A_1ANT_BT_STATUS{
-	BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8821A_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8821A_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8821A_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8821A_1ANT_BT_STATUS_MAX
-}BT_8821A_1ANT_BT_STATUS,*PBT_8821A_1ANT_BT_STATUS;
-
-typedef enum _BT_8821A_1ANT_WIFI_STATUS{
-	BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT				= 0x3,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8821A_1ANT_WIFI_STATUS_MAX
-}BT_8821A_1ANT_WIFI_STATUS,*PBT_8821A_1ANT_WIFI_STATUS;
-
-typedef enum _BT_8821A_1ANT_COEX_ALGO{
-	BT_8821A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8821A_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8821A_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8821A_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8821A_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8821A_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8821A_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8821A_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8821A_1ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8821A_1ANT_COEX_ALGO,*PBT_8821A_1ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8821A_1ANT{
-	// fw mechanism
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-
-	// sw mechanism
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-
-	u4Byte		backupArfrCnt1;	// Auto Rate Fallback Retry cnt
-	u4Byte		backupArfrCnt2;	// Auto Rate Fallback Retry cnt
-	u2Byte		backupRetryLimit;
-	u1Byte		backupAmpduMaxTime;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-	u1Byte		preArfrType;
-	u1Byte		curArfrType;
-	u1Byte		preRetryLimitType;
-	u1Byte		curRetryLimitType;
-	u1Byte		preAmpduTimeType;
-	u1Byte		curAmpduTimeType;
-	u4Byte		nArpCnt;
-
-	u1Byte		errorCondition;
-} COEX_DM_8821A_1ANT, *PCOEX_DM_8821A_1ANT;
-
-typedef struct _COEX_STA_8821A_1ANT{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					specialPktPeriodCnt;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	BOOLEAN					bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8821A_1ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8821A_1ANT_MAX];
-	BOOLEAN					bC2hBtInquiryPage;
-	BOOLEAN					bC2hBtPage;				//Add for win8.1 page out issue
-	BOOLEAN					bWiFiIsHighPriTask;		//Add for win8.1 page out issue
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-}COEX_STA_8821A_1ANT, *PCOEX_STA_8821A_1ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8821a1ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8821a1ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8821a1ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8821a1ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a1ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a1ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a1ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a1ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8821a1ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8821a1ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8821a1ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8821a1ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8821a1ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8821a1ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a2Ant.c
deleted file mode 100644
index 0943586975d3..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a2Ant.c
+++ /dev/null
@@ -1,4859 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8821A Co-exist mechanism
-//
-// History
-// 2012/11/15 Cosa first check in.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtc8821a2Ant.tmh"
-#endif
-
-#if (RTL8821A_SUPPORT == 1)
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8821A_2ANT		GLCoexDm8821a2Ant;
-static PCOEX_DM_8821A_2ANT 	pCoexDm=&GLCoexDm8821a2Ant;
-static COEX_STA_8821A_2ANT		GLCoexSta8821a2Ant;
-static PCOEX_STA_8821A_2ANT	pCoexSta=&GLCoexSta8821a2Ant;
-
-const char *const GLBtInfoSrc8821a2Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte	GLCoexVerDate8821a2Ant=20150921;
-u4Byte	GLCoexVer8821a2Ant=0x58;
-//modify 20140903v43 a2dpandhid tdmaonoff a2dp glitch _ tdma off 778=3(case1)->778=1(case0)
-//and to improve tp while a2dphid case23->case25 , case123->case125 for asus spec
-//and modify for asus bt WHQL test _ tdma off_ 778=3->1_
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8821a2ant_
-//============================================================
-u1Byte
-halbtc8821a2ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8821a2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8821a2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-		}
-	}
-}
-
-VOID
-halbtc8821a2ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-}
-
-VOID
-halbtc8821a2ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	if ( (pCoexSta->lowPriorityRx >= 950)  &&  (pCoexSta->lowPriorityRx >= pCoexSta->lowPriorityTx) && (!pCoexSta->bUnderIps) )
-	{
-		pBtLinkInfo->bSlaveRole = TRUE;
-	}
-	else
-	{
-		pBtLinkInfo->bSlaveRole = FALSE;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc);
-}
-
-VOID
-halbtc8821a2ant_MonitorWiFiCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 	u4Tmp;
-	u2Byte 	u2Tmp[3];
-	s4Byte	wifiRssi=0;
-	BOOLEAN bWifiBusy = FALSE, bWifiUnderBMode = FALSE;
-	static u1Byte nCCKLockCounter = 0;
-
-
-	if (pCoexSta->bUnderIps)
-	{
-		pCoexSta->nCRCOK_CCK = 0;
-		pCoexSta->nCRCOK_11g = 0;
-		pCoexSta->nCRCOK_11n = 0;
-		pCoexSta->nCRCOK_11nAgg = 0;
-
-		pCoexSta->nCRCErr_CCK = 0;
-		pCoexSta->nCRCErr_11g = 0;
-		pCoexSta->nCRCErr_11n = 0;
-		pCoexSta->nCRCErr_11nAgg = 0;	
-	}
-	else
-	{
-		pCoexSta->nCRCOK_CCK	= pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf88);
-		pCoexSta->nCRCOK_11g 	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf94);
-		pCoexSta->nCRCOK_11n	= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf90);
-		pCoexSta->nCRCOK_11nAgg= pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfb8);
-
-		pCoexSta->nCRCErr_CCK 	 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf84);
-		pCoexSta->nCRCErr_11g 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf96);
-		pCoexSta->nCRCErr_11n 	 = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xf92);
-		pCoexSta->nCRCErr_11nAgg = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0xfba);		
-	}
-
-	//reset counter
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x1);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xf16, 0x1, 0x0);
-}
-
-VOID
-halbtc8821a2ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-BOOLEAN
-halbtc8821a2ant_IsWifiStatusChanged(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreWifiBusy=FALSE, bPreUnder4way=FALSE, bPreBtHsOn=FALSE;
-	BOOLEAN			bWifiBusy=FALSE, bUnder4way=FALSE, bBtHsOn=FALSE;
-	BOOLEAN			bWifiConnected=FALSE;
-	u1Byte			wifiRssiState=BTC_RSSI_STATE_HIGH;
-	
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &bUnder4way);
-
-	if(bWifiConnected)
-	{
-		if(bWifiBusy != bPreWifiBusy)
-		{
-			bPreWifiBusy = bWifiBusy;
-			return TRUE;
-		}
-		if(bUnder4way != bPreUnder4way)
-		{
-			bPreUnder4way = bUnder4way;
-			return TRUE;
-		}
-		if(bBtHsOn != bPreBtHsOn)
-		{
-			bPreBtHsOn = bBtHsOn;
-			return TRUE;
-		}
-
-
-		wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist,3, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-
-		if ( (BTC_RSSI_STATE_HIGH ==wifiRssiState ) ||  (BTC_RSSI_STATE_LOW ==wifiRssiState ))
-		{
-			return TRUE;
-		}
-	
-	}
-
-	return FALSE;
-}
-
-VOID
-halbtc8821a2ant_UpdateBtLinkInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO 	pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-
-#if(BT_AUTO_REPORT_ONLY_8821A_2ANT == 1)	// profile from bt patch
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	pBtLinkInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pCoexSta->bScoExist;
-	pBtLinkInfo->bA2dpExist = pCoexSta->bA2dpExist;
-	pBtLinkInfo->bPanExist = pCoexSta->bPanExist;
-	pBtLinkInfo->bHidExist = pCoexSta->bHidExist;
-
-	// work around for HS mode.
-	if(bBtHsOn)
-	{
-		pBtLinkInfo->bPanExist = TRUE;
-		pBtLinkInfo->bBtLinkExist = TRUE;
-	}
-#else	// profile from bt stack
-	pBtLinkInfo->bBtLinkExist = pStackInfo->bBtLinkExist;
-	pBtLinkInfo->bScoExist = pStackInfo->bScoExist;
-	pBtLinkInfo->bA2dpExist = pStackInfo->bA2dpExist;
-	pBtLinkInfo->bPanExist = pStackInfo->bPanExist;
-	pBtLinkInfo->bHidExist = pStackInfo->bHidExist;
-
-	//for win-8 stack HID report error
-	if(!pStackInfo->bHidExist)
-		pStackInfo->bHidExist = pCoexSta->bHidExist;  //sync  BTInfo with BT firmware and stack
-	// when stack HID report error, here we use the info from bt fw.
-	if(!pStackInfo->bBtLinkExist)
-		pStackInfo->bBtLinkExist = pCoexSta->bBtLinkExist;	
-#endif
-	// check if Sco only
-	if( pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bScoOnly = TRUE;
-	else
-		pBtLinkInfo->bScoOnly = FALSE;
-
-	// check if A2dp only
-	if( !pBtLinkInfo->bScoExist &&
-		pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bA2dpOnly = TRUE;
-	else
-		pBtLinkInfo->bA2dpOnly = FALSE;
-
-	// check if Pan only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		pBtLinkInfo->bPanExist &&
-		!pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bPanOnly = TRUE;
-	else
-		pBtLinkInfo->bPanOnly = FALSE;
-	
-	// check if Hid only
-	if( !pBtLinkInfo->bScoExist &&
-		!pBtLinkInfo->bA2dpExist &&
-		!pBtLinkInfo->bPanExist &&
-		pBtLinkInfo->bHidExist )
-		pBtLinkInfo->bHidOnly = TRUE;
-	else
-		pBtLinkInfo->bHidOnly = FALSE;
-}
-
-u1Byte
-halbtc8821a2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8821A_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-		
-	if(!pBtLinkInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No BT link exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pBtLinkInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pBtLinkInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO only\n"));
-			algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8821A_2ANT_COEX_ALGO_HID;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8821A_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(HS) only\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(EDR) only\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if(pBtLinkInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID\n"));
-				algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-			}
-			else if(pBtLinkInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(HS)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(EDR)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-#if 0
-				if(pStackInfo->numOfHid >= 2)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID*2 + A2DP\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-				else
-#endif
-				{			
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(HS)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(EDR)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(EDR)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP ==> SCO\n"));
-				algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-			}
-			else if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(HS) ==> SCO\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(EDR) ==> SCO\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-			else if( pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		}
-		else
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pBtLinkInfo->bScoExist)
-		{
-			if( pBtLinkInfo->bHidExist &&
-				pBtLinkInfo->bPanExist &&
-				pBtLinkInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-VOID
-halbtc8821a2ant_SetFwDacSwingLevel(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			dacSwingLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	// There are several type of dacswing
-	// 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6
-	H2C_Parameter[0] = dacSwingLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Set Dac Swing Level=0x%x\n", dacSwingLvl));
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x64=0x%x\n", H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x64, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8821a2ant_SetFwDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = decBtPwrLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], decrease Bt Power level = %d, FW write 0x62=0x%x\n", 
-		decBtPwrLvl, H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x62, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8821a2ant_DecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				decBtPwrLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s Dec BT power level = %d\n",  
-		(bForceExec? "force to":""), decBtPwrLvl));
-	pCoexDm->curBtDecPwrLvl = decBtPwrLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preBtDecPwrLvl == pCoexDm->curBtDecPwrLvl) 
-			return;
-	}
-	halbtc8821a2ant_SetFwDecBtPwr(pBtCoexist, pCoexDm->curBtDecPwrLvl);
-
-	pCoexDm->preBtDecPwrLvl = pCoexDm->curBtDecPwrLvl;
-}
-
-VOID
-halbtc8821a2ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8821a2ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	halbtc8821a2ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8821a2ant_FwDacSwingLvl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			fwDacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set FW Dac Swing level = %d\n",  
-		(bForceExec? "force to":""), fwDacSwingLvl));
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preFwDacSwingLvl == pCoexDm->curFwDacSwingLvl) 
-			return;
-	}
-
-	halbtc8821a2ant_SetFwDacSwingLevel(pBtCoexist, pCoexDm->curFwDacSwingLvl);
-
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-}
-
-VOID
-halbtc8821a2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xffffc);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8821a2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8821a2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8821a2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-                H2C_Parameter[3] = 0xf5;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xa0;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xa0;	//MCS5 or OFDM36
-		//H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		//H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		//H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!")) );
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8821a2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	//return;
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8821a2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8821a2ant_SetDacSwingReg(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte			level
-	)
-{
-	u1Byte	val=(u1Byte)level;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Write SwDacSwing = 0x%x\n", level));
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc5b, 0x3e, val);
-}
-
-VOID
-halbtc8821a2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	if(bSwDacSwingOn)
-	{
-		halbtc8821a2ant_SetDacSwingReg(pBtCoexist, swDacSwingLvl);
-	}
-	else
-	{
-		halbtc8821a2ant_SetDacSwingReg(pBtCoexist, 0x18);
-	}
-}
-
-
-VOID
-halbtc8821a2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8821a2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8821a2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x8db, 0x60, 0x3);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x8db, 0x60, 0x1);
-	}
-}
-
-VOID
-halbtc8821a2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8821a2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8821a2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	//=================BB AGC Gain Table
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table On!\n"));
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6e1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6d1B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6c1C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6b1D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x6a1E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x691F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0x68200001);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB Agc Table Off!\n"));
-	 	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xaa1A0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa91B0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa81C0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa71D0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa61E0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa51F0001);
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0xc78, 0xa4200001);
-	}
-	
-	
-	//=================RF Gain
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x1);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38fff);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x38ffe);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x380c3);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x40, 0xfffff, 0x28ce6);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xed, 0xfffff, 0x0);
-
-	// set rssiAdjustVal for wifi module.
-	if(bAgcTableEn)
-	{
-		rssiAdjustVal = 8;
-	}
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-VOID
-halbtc8821a2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8821a2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8821a2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8821a2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{	
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8821a2ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8821a2ant_CoexTableWithType(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexSta->nCoexTableType = type;
-	
-	switch(type)
-	{
-		case 0:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x55555555, 0xffffff, 0x3);
-			break;
-		case 1:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55555555, 0x5afa5afa, 0xffffff, 0x3);
-			break;
-		case 2:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x5ada5ada, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 3:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 4:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0xffffffff, 0xffffffff, 0xffffff, 0x3);
-			break;
-		case 5:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5fff5fff, 0xffffff, 0x3);
-			break;
-		case 6:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55ff55ff, 0x5a5a5a5a, 0xffffff, 0x3);
-			break;
-		case 7:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 8:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 9:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 10:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 11:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 12:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 13:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 14:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x5fff5fff, 0x5ada5ada, 0xffffff, 0x3);
-			break;
-		case 15:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x55dd55dd, 0xaaaaaaaa, 0xffffff, 0x3);
-			break;
-		case 16:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0x5fdf5fdf, 0x5fdb5fdb, 0xffffff, 0x3);
-			break;
-		case 17:
-			halbtc8821a2ant_CoexTable(pBtCoexist, bForceExec, 0xfafafafa, 0xfafafafa, 0xffffff, 0x3);
-			break;
-		default:
-			break;
-	}
-}
-
-VOID
-halbtc8821a2ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8821a2ant_SetLpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	u1Byte	lps=lpsVal;
-	u1Byte	rpwm=rpwmVal;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_LPS_VAL, &lps);
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-VOID
-halbtc8821a2ant_LpsRpwm(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			lpsVal,
-	IN	u1Byte			rpwmVal
-	)
-{
-	BOOLEAN	bForceExecPwrCmd=FALSE;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set lps/rpwm=0x%x/0x%x \n", 
-		(bForceExec? "force to":""), lpsVal, rpwmVal));
-	pCoexDm->curLps = lpsVal;
-	pCoexDm->curRpwm = rpwmVal;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preLps == pCoexDm->curLps) &&
-			(pCoexDm->preRpwm == pCoexDm->curRpwm) )
-		{
-			return;
-		}
-	}
-	halbtc8821a2ant_SetLpsRpwm(pBtCoexist, lpsVal, rpwmVal);
-
-	pCoexDm->preLps = pCoexDm->curLps;
-	pCoexDm->preRpwm = pCoexDm->curRpwm;
-}
-
-VOID
-halbtc8821a2ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	halbtc8821a2ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8821a2ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[5] ={0};
-	 
-	H2C_Parameter[0] = byte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = byte5;
-
-	pCoexDm->psTdmaPara[0] = byte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = byte5;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x60(5bytes)=0x%x%08x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 5, H2C_Parameter);
-}
-
-VOID
-halbtc8821a2ant_SwMechanism1(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bShrinkRxLPF,
-	IN	BOOLEAN 	bLowPenaltyRA,
-	IN	BOOLEAN		bLimitedDIG, 
-	IN	BOOLEAN		bBTLNAConstrain
-	) 
-{
-	/*
-	u4Byte	wifiBw;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	
-	if(BTC_WIFI_BW_HT40 != wifiBw)  //only shrink RF Rx LPF for HT40
-	{
-		if (bShrinkRxLPF)
-			bShrinkRxLPF = FALSE;
-	}
-	*/
-	
-	//halbtc8821a2ant_RfShrink(pBtCoexist, NORMAL_EXEC, bShrinkRxLPF);
-	halbtc8821a2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-}
-
-VOID
-halbtc8821a2ant_SwMechanism2(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bAGCTableShift,
-	IN	BOOLEAN 	bADCBackOff,
-	IN	BOOLEAN		bSWDACSwing,
-	IN	u4Byte		dacSwingLvl
-	) 
-{
-	//halbtc8821a2ant_AgcTable(pBtCoexist, NORMAL_EXEC, bAGCTableShift);
-	//halbtc8821a2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, bADCBackOff);
-	halbtc8821a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, bSWDACSwing, dacSwingLvl);
-}
-
-VOID
-halbtc8821a2ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte				u4Tmp=0;
-	u1Byte				H2C_Parameter[2] ={0};
-	
-	if(bInitHwCfg)
-	{
-		// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp &=~BIT23;
-		u4Tmp |= BIT24;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x974, 0x3ff);
-		//pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb4, 0x77);
-
-		if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT) 
-		{
-			//tell firmware "antenna inverse"  ==> WRONG firmware antenna control code.==>need fw to fix
-			H2C_Parameter[0] = 1;
-			H2C_Parameter[1] = 1;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-		}
-		else
-		{
-			//tell firmware "no antenna inverse" ==> WRONG firmware antenna control code.==>need fw to fix
-			H2C_Parameter[0] = 0;
-			H2C_Parameter[1] = 1;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-		}
-	}
-	
-	// ext switch setting
-	switch(antPosType)
-	{
-		case BTC_ANT_WIFI_AT_MAIN:
-			pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x1);
-			break;
-		case BTC_ANT_WIFI_AT_AUX:
-			pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x2);
-			break;
-	}
-}
-
-VOID
-halbtc8821a2ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN			bTurnOnByCnt=FALSE;
-	u1Byte			psTdmaTypeByCnt=0;
-	u1Byte			wifiRssiState1, btRssiState;
-
-	
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	if (!(BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState)) && bTurnOn)
-	{
-		type = type +100;  //for WiFi RSSI low or BT RSSI low
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-		(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-	if(bTurnOn)
-	{
-		switch(type)
-		{
-			case 1:
-			default:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 2:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x03, 0xf1, 0x90);
-				break;
-			case 3:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0xf1, 0x90);
-				break;
-			case 4:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x03, 0xf1, 0x90);
-				break;
-			case 5:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x3, 0x70, 0x90);				
-				break;
-			case 6:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x3, 0x70, 0x90);
-				break;
-			case 7:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0x70, 0x90);
-				break;
-			case 8:	
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x10, 0x3, 0x70, 0x90);
-				break;
-			case 9:	
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 10:	
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x03, 0xf1, 0x90);
-				break;
-			case 11:	
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0xe1, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0xf1, 0x90);
-				break;
-			case 12:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x3, 0xf1, 0x90);
-				break;
-			case 13:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x3, 0x70, 0x90);		
-				break;
-			case 14:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x2d, 0x3, 0x70, 0x90);		
-				break;
-			case 15:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0x60, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0x70, 0x90);		
-				break;
-			case 16:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0x60, 0x90);
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x3, 0x70, 0x90);		
-				break;
-			case 17:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x2f, 0x2f, 0x60, 0x90);
-				break;
-			case 18:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				break;			
-			case 19:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0xe1, 0x90);
-				break;
-			case 20:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0x60, 0x90);
-				break;
-			case 21:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x03, 0x70, 0x90);
-				break;	
-			case 23:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1e, 0x03, 0xf0, 0x14);
-				break;
-			case 24:
-			case 124:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x3c, 0x03, 0x70, 0x50);
-				break;
-				//case25/case125 : for lenovo bt pan tp degrade<30% while wifi downlink
-			case 25:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x14, 0x03, 0xf1, 0x90);
-				break;
-                        case 26:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x30, 0x03, 0xf1, 0x90);
-				break;
-			case 71:
-				//halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 101:
-			case 105:
-			case 171:	
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x3a, 0x03, 0x70, 0x50);
-				break;
-			case 102:
-			case 106:
-			case 110:
-			case 114:	
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x2d, 0x03, 0x70, 0x50);
-				break;	
-			case 103:
-			case 107:
-			case 111:
-			case 115:	
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1c, 0x03, 0x70, 0x50);
-				break;		
-			case 104:
-			case 108:
-			case 112:
-			case 116:	
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x10, 0x03, 0x70, 0x50);
-				break;	
-			case 109:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0xf1, 0x90);
-				break;
-			case 113:	
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x3c, 0x03, 0x70, 0x90);
-				break;
-			case 121:	
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x03, 0x70, 0x90);
-				break;	
-			case 22:
-			case 122:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x35, 0x03, 0x71, 0x11);
-				break;
-			case 123:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x1c, 0x03, 0x70, 0x54);
-				break;
-				//case25/case125 : for lenovo bt pan tp degrade<30% while wifi downlink
-			case 125:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x14, 0x03, 0x70, 0x50);
-				break;
-                        case 126:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0xd3, 0x30, 0x03, 0x70, 0x50);
-				break;
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(type)
-		{
-			case 0:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-			case 1:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x48, 0x0);
-				break;
-			default:
-				halbtc8821a2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8821a2ant_PsTdmaCheckForPowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bNewPsState
-	)
-{
-	u1Byte	lpsMode=0x0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_LPS_MODE, &lpsMode);
-	
-	if(lpsMode)	// already under LPS state
-	{
-		if(bNewPsState)		
-		{
-			// keep state under LPS, do nothing.
-		}
-		else
-		{
-			// will leave LPS state, turn off psTdma first
-			halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-	}
-	else						// NO PS state
-	{
-		if(bNewPsState)
-		{
-			// will enter LPS state, turn off psTdma first
-			halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		else
-		{
-			// keep state under NO PS state, do nothing.
-		}
-	}
-}
-
-VOID
-halbtc8821a2ant_PowerSaveState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				psType,
-	IN	u1Byte				lpsVal,
-	IN	u1Byte				rpwmVal
-	)
-{
-	BOOLEAN		bLowPwrDisable=FALSE;
-	
-	switch(psType)
-	{
-		case BTC_PS_WIFI_NATIVE:
-			// recover to original 32k low power setting
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		case BTC_PS_LPS_ON:
-			halbtc8821a2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, TRUE);
-			halbtc8821a2ant_LpsRpwm(pBtCoexist, NORMAL_EXEC, lpsVal, rpwmVal);			
-			// when coex force to enter LPS, do not enter 32k low power.
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			// power save must executed before psTdma.			
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-			pCoexSta->bForceLpsOn = TRUE;
-			break;
-		case BTC_PS_LPS_OFF:
-			halbtc8821a2ant_PsTdmaCheckForPowerSaveState(pBtCoexist, FALSE);
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-			pCoexSta->bForceLpsOn = FALSE;
-			break;
-		default:
-			break;
-	}
-}
-
-
-VOID
-halbtc8821a2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8821a2ant_CoexUnder5G(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a2ant_CoexAllOff(pBtCoexist);
-
-	halbtc8821a2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, TRUE);
-}
-
-VOID
-halbtc8821a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-	halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-	
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8821a2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8821a2ant_DecBtPwr(pBtCoexist, FORCE_EXEC, 0);
-
-	halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8821a2ant_ActionBtInquiry(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	BOOLEAN	bWifiConnected=FALSE;
-	BOOLEAN	bLowPwrDisable=TRUE;
-	BOOLEAN		bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-	
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-
-	if(bScan || bLink || bRoam)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi link process + BT Inq/Page!!\n"));
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-	}
-	else if(bWifiConnected)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT Inq/Page!!\n"));
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi no-link + BT Inq/Page!!\n"));
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	}	
-	
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-	
-}
-
-
-VOID
-halbtc8821a2ant_ActionWiFiLinkProcess(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte 	u1Tmpa, u1Tmpb;
-	
-	halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 15);		
-	halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-
-	halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-
-
-	u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x765=0x%x, 0x76e=0x%x\n", u1Tmpa, u1Tmpb));
-}
-
-BOOLEAN
-halbtc8821a2ant_ActionWifiIdleProcess(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	//wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES-20, 0);
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-
-	// define the office environment
-	if(BTC_RSSI_HIGH(wifiRssiState1) && 
-			(pCoexSta->bHidExist == TRUE) && (pCoexSta->bA2dpExist == TRUE))
-	{
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi  idle process for BT HID+A2DP exist!!\n"));
-		
-		halbtc8821a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x6);
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-		// sw all off
-		halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	  	return TRUE;
-	}
-
-        //
-       else if (pCoexSta->bPanExist== TRUE)
-	{
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi  idle process for BT PAN exist!!\n"));
-		
-		halbtc8821a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x6);
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-		// sw all off
-		halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	  	return TRUE;
-	}
-	
-	else
-	{
-		halbtc8821a2ant_DacSwing(pBtCoexist, NORMAL_EXEC, TRUE, 0x18);
-		return FALSE;	
-	}
-	
-	
-}
-
-
-
-BOOLEAN
-halbtc8821a2ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			btRssiState=BTC_RSSI_STATE_HIGH;
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-	BOOLEAN			bBtHsOn=FALSE, bLowPwrDisable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected)
-	{
-		bLowPwrDisable = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-		halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-		
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi non-connected idle!!\n"));
-
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-		
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-		
- 		halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-		bCommon = TRUE;
-	}
-	else
-	{
-		if(BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			bLowPwrDisable = FALSE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-			halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-			
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT non connected-idle!!\n"));
-
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-			halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-			halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);		
-			halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0xb);
-			halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	      	halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else if(BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)
-		{
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bBtHsOn)
-				return FALSE;
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi connected + BT connected-idle!!\n"));
-			halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-			
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-			halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-			halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-			halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0xb);
-			halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-			bCommon = TRUE;
-		}
-		else
-		{
-			bLowPwrDisable = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-			if(bWifiBusy)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Busy + BT Busy!!\n"));
-				bCommon = FALSE;
-				//bCommon = halbtc8821a2ant_ActionWifiIdleProcess(pBtCoexist);	
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Connected-Idle + BT Busy!!\n"));
-				//bCommon = FALSE;	
-				bCommon = halbtc8821a2ant_ActionWifiIdleProcess(pBtCoexist);			
-			}
-		}	
-	}
-
-	return bCommon;
-}
-VOID
-halbtc8821a2ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bScoHid,
-	IN	BOOLEAN			bTxPause,
-	IN	u1Byte			maxInterval
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-	if(!pCoexDm->bAutoTdmaAdjust)
-	{
-		pCoexDm->bAutoTdmaAdjust = TRUE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-		{
-			if(bScoHid)
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;	
-					}
-					else
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-			else
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->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 = pCoexSta->btRetryCnt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-		if(maxInterval == 1)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-
-				if(pCoexDm->curPsTdma == 71)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-					pCoexDm->psTdmaDuAdjType = 13;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				
-				if(result == -1)
-				{					
-					if(pCoexDm->curPsTdma == 5)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;
-					}
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-					pCoexDm->psTdmaDuAdjType = 71;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-					pCoexDm->psTdmaDuAdjType = 9;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 71)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-						pCoexDm->psTdmaDuAdjType = 71;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 2)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 3)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-		if( !bScan && !bLink && !bRoam)
-		{
-			halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-}
-
-// SCO only or SCO+PAN(HS)
-VOID
-halbtc8821a2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte	wifiRssiState, btRssiState;
-	u4Byte	wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 4);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for SCO quality at 11b/g mode
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-	else  //for SCO quality & wifi performance balance at 11n mode
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 8);
-		else
-		{
-			if(pBtLinkInfo->bScoOnly)
-				halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 17);
-			else
-				halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 12);
-		}
-	}
-
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-	halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); //for voice quality
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x18);			
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x18);	
-		}		
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x18);
-		}		
-	}
-}
-
-
-VOID
-halbtc8821a2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, btRssiState;	
-	u4Byte	wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 2);
-	}
-
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-
-	halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 24);
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}	
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8821a2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-
-	// define the office environment
-	if( (apNum >= 10) && BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		//DbgPrint(" AP#>10(%d)\n", apNum);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);			
-		
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-		halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);			
-					
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-		//halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-
-		// sw mechanism
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x6);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,TRUE,0x6);		
-		}
-		return;
-		
-	}
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);	
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-		
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-	
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		//halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-	}
-	else
-	{
-		//halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-	}
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8821a2ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-	
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 2);
-
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8821a2ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState,wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 10);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-	
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 26);	
-	}
-	else
-	{
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 26);	
-	}
-	
-	// sw mechanism
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-
-//PAN(HS) only
-VOID
-halbtc8821a2ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	
-	halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-	
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8821a2ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))		
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	else
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 12);
-		
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-		else
-			halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 13);
-		halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-	}
-	
-	// sw mechanism	
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8821a2ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))	
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-		{
-			halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 3);
-			//halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 11);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780);
-		}
-		else
-		{
-			halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-			//halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		}
-		halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 2);
-	}
-	else
-	{
-		halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		//halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-		halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-	}
-	
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8821a2ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState,wifiRssiState1,  btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8821a2ant_BtRssiState(2, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, FALSE, 0x8);
-
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(BTC_RSSI_HIGH(btRssiState))
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-	else	
-		halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-		else
-			halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-	}
-	else
-	{
-		halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-	}
-
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8821a2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, wifiRssiState1, btRssiState;
-	u4Byte		wifiBw;
-	u1Byte		apNum=0;
-
-	wifiRssiState = halbtc8821a2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	//btRssiState = halbtc8821a2ant_BtRssiState(2, 29, 0);
-	wifiRssiState1 = halbtc8821a2ant_WifiRssiState(pBtCoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);	
-	btRssiState = halbtc8821a2ant_BtRssiState(3, BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 37);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	
-	halbtc8821a2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x5);
-
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	if(BTC_WIFI_BW_LEGACY == wifiBw)
-	{
-		if(BTC_RSSI_HIGH(btRssiState))
-			halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		else if(BTC_RSSI_MEDIUM(btRssiState))
-			halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		else	
-			halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-	else
-	{	// only 802.11N mode we have to dec bt power to 4 degree
-		if(BTC_RSSI_HIGH(btRssiState))
-		{
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-			// need to check ap Number of Not
-			if(apNum < 10)
-				halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 4);
-			else
-				halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		}
-		else if(BTC_RSSI_MEDIUM(btRssiState))
-			halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 2);
-		else	
-			halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-	}
-
-	if (BTC_RSSI_HIGH(wifiRssiState1) && BTC_RSSI_HIGH(btRssiState))
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 7);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	}
-	else
-	{
-		halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 14);
-		halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_LPS_ON, 0x50, 0x4);		
-	}
-
-	if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-		(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-	{
-		//halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-	}
-	else
-	{
-		//halbtc8821a2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-		halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-	}
-	
-	// sw mechanism
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8821a2ant_ActionBtWhckTest(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	
-	halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-}
-
-VOID
-halbtc8821a2ant_ActionWifiMultiPort(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{		
-	halbtc8821a2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8821a2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, 0);
-
-	// sw all off
-	halbtc8821a2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821a2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	//pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8821a2ant_CoexTableWithType(pBtCoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a2ant_PowerSaveState(pBtCoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);		
-	halbtc8821a2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-}
-
-VOID
-halbtc8821a2ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN				bWifiUnder5G=FALSE, bBtHsOn=FALSE;
-	u1Byte				btInfoOriginal=0, btRetryCnt=0;
-	u1Byte				algorithm=0;
-	u4Byte				numOfWifiLink=0;
-	u4Byte				wifiLinkStatus=0;
-	PBTC_BT_LINK_INFO pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	BOOLEAN				bMiracastPlusBt=FALSE;
-	BOOLEAN				bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism()===>\n"));
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-	if(bWifiUnder5G)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), run 5G coex setting!!<===\n"));
-		halbtc8821a2ant_CoexUnder5G(pBtCoexist);
-		return;
-	}
-
-	if(pCoexSta->bUnderIps)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi is under IPS !!!\n"));
-		return;
-	}
-
-	if(pCoexSta->bBtWhckTest)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under WHCK TEST!!!\n"));
-		halbtc8821a2ant_ActionBtWhckTest(pBtCoexist);
-		return;
-	}
-
-	algorithm = halbtc8821a2ant_ActionAlgorithm(pBtCoexist);
-	if(pCoexSta->bC2hBtInquiryPage && (BT_8821A_2ANT_COEX_ALGO_PANHS!=algorithm))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under inquiry/page scan !!\n"));
-		halbtc8821a2ant_ActionBtInquiry(pBtCoexist);
-		return;
-	}
-	else
-	{
-
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-
-	if(bScan || bLink || bRoam)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], WiFi is under Link Process !!\n"));
-		halbtc8821a2ant_ActionWiFiLinkProcess(pBtCoexist);
-		return;
-	}
-
-	//for P2P
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_LINK_STATUS, &wifiLinkStatus);
-	numOfWifiLink = wifiLinkStatus>>16;
-	
-	if((numOfWifiLink>=2) || (wifiLinkStatus&WIFI_P2P_GO_CONNECTED))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex],  Multi-Port numOfWifiLink = %d, wifiLinkStatus = 0x%x\n", numOfWifiLink,wifiLinkStatus) );
-
-		if(pBtLinkInfo->bBtLinkExist)
-		{
-			bMiracastPlusBt = TRUE;
-		}
-		else
-		{
-			bMiracastPlusBt = FALSE;
-		}
-		
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-		halbtc8821a2ant_ActionWifiMultiPort(pBtCoexist);
-		
-		return;
-	}
-	else
-	{
-		bMiracastPlusBt = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_MIRACAST_PLUS_BT, &bMiracastPlusBt);
-	}
-
-	pCoexDm->curAlgorithm = algorithm;
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Algorithm = %d \n", pCoexDm->curAlgorithm));
-
-	if(halbtc8821a2ant_IsCommonAction(pBtCoexist))
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant common.\n"));
-		pCoexDm->bAutoTdmaAdjust = FALSE;
-	}
-	else
-	{
-		if(pCoexDm->curAlgorithm != pCoexDm->preAlgorithm)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 
-				pCoexDm->preAlgorithm, pCoexDm->curAlgorithm));
-			pCoexDm->bAutoTdmaAdjust = FALSE;
-		}
-		switch(pCoexDm->curAlgorithm)
-		{
-			case BT_8821A_2ANT_COEX_ALGO_SCO:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO.\n"));
-				halbtc8821a2ant_ActionSco(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID.\n"));
-				halbtc8821a2ant_ActionHid(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP.\n"));
-				halbtc8821a2ant_ActionA2dp(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n"));
-				halbtc8821a2ant_ActionA2dpPanHs(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n"));
-				halbtc8821a2ant_ActionPanEdr(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_PANHS:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HS mode.\n"));
-				halbtc8821a2ant_ActionPanHs(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n"));
-				halbtc8821a2ant_ActionPanEdrA2dp(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_PANEDR_HID:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-				halbtc8821a2ant_ActionPanEdrHid(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-				halbtc8821a2ant_ActionHidA2dpPanEdr(pBtCoexist);
-				break;
-			case BT_8821A_2ANT_COEX_ALGO_HID_A2DP:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n"));
-				halbtc8821a2ant_ActionHidA2dp(pBtCoexist);
-				break;
-			default:
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n"));
-				halbtc8821a2ant_CoexAllOff(pBtCoexist);
-				break;
-		}
-		pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-	}
-}
-
-VOID
-halbtc8821a2ant_WifiOffHwCfg(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN	bIsInMpMode = FALSE;
-	u1Byte H2C_Parameter[2] ={0};
-	u4Byte fwVer=0;
-
-	// set wlan_act to low
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4);
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1, 0xfffff, 0x780); //WiFi goto standby while GNT_BT 0-->1
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	if(fwVer >= 0x180000)
-	{
-		/* Use H2C to set GNT_BT to HIGH */
-		H2C_Parameter[0] = 1;
-		pBtCoexist->fBtcFillH2c(pBtCoexist, 0x6E, 1, H2C_Parameter);
-	}
-	else
-	{
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x765, 0x18);
-	}
-}
-
-VOID
-halbtc8821a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bBackUp
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte	u4Tmp=0, fwVer;
-	u2Byte				u2Tmp=0;
-	u1Byte	u1Tmp=0;
-	u1Byte				H2C_Parameter[2] ={0};
-		
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	// backup rf 0x1e value
-	pCoexDm->btRf0x1eBackup = 
-		pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);	
-
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-
-	//Antenna config	
-	halbtc8821a2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_MAIN, TRUE, FALSE);
-	pCoexSta->disVerInfoCnt = 0;
-
-	// PTA parameter
-	halbtc8821a2ant_CoexTableWithType(pBtCoexist, FORCE_EXEC, 0);
-	
-	// Enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x4); //0x76e[3] =1, WLAN_Act control by PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x3);
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x1);
-}
-
-//============================================================
-// work around function start with wa_halbtc8821a2ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8821a2ant_
-//============================================================
-VOID
-EXhalbtc8821a2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-
-}
-
-VOID
-EXhalbtc8821a2ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u1Byte u1Tmp=0x4; /* Set BIT2 by default since it's 2ant case */
-
-	// 
-	// S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info)
-	// Local setting bit define
-	//	BIT0: "0" for no antenna inverse; "1" for antenna inverse 
-	//	BIT1: "0" for internal switch; "1" for external switch
-	//	BIT2: "0" for one antenna; "1" for two antenna
-	// NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0
-	if(pBtCoexist->chipInterface == BTC_INTF_USB)
-	{
-		// fixed at S0 for USB interface
-	 	u1Tmp |= 0x1;	// antenna inverse
-		pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0xfe08, u1Tmp);
-	}
-	else
-	{
-		// for PCIE and SDIO interface, we check efuse 0xc3[6]
-		if(pBoardInfo->singleAntPath == 0)
-		{
-		}
-		else if(pBoardInfo->singleAntPath == 1)
-		{
-			// set to S0
-			u1Tmp |= 0x1;	// antenna inverse
-		}
-
-		if(pBtCoexist->chipInterface == BTC_INTF_PCI)
-		{	
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x384, u1Tmp);
-		}
-		else if(pBtCoexist->chipInterface == BTC_INTF_SDIO)
-		{
-			pBtCoexist->fBtcWriteLocalReg1Byte(pBtCoexist, 0x60, u1Tmp);
-		}			
-	}
-}
-
-VOID
-EXhalbtc8821a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	halbtc8821a2ant_InitHwConfig(pBtCoexist, TRUE);
-}
-
-VOID
-EXhalbtc8821a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8821a2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8821a2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-	u4Byte				faOfdm, faCck;
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cliBuf);
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ==========================================");
-		CL_PRINTF(cliBuf);
-	}
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8821a2Ant, GLCoexVer8821a2Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-	
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %ddBm/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pBtCoexist->btInfo.bBtDisabled)? ("disabled"):	((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE == pCoexDm->btStatus)? "non-connected idle":
-		(  (BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy")))),
-		pCoexSta->btRssi-100, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-		pBtLinkInfo->bScoExist, pBtLinkInfo->bHidExist, pBtLinkInfo->bPanExist, pBtLinkInfo->bA2dpExist);
-	CL_PRINTF(cliBuf);
-
-	if (pStackInfo->bProfileNotified)
-	{
-		pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);	
-	}
-	else
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Role", \
-		(pBtLinkInfo->bSlaveRole )? "Slave":"Master");
-		CL_PRINTF(cliBuf);	
-	}	
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8821A_2ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8821a2Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);	
-
-	psTdmaCase = pCoexDm->curPsTdma;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)", "PS TDMA", \
-		pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-		pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-		pCoexDm->psTdmaPara[4], psTdmaCase, pCoexDm->bAutoTdmaAdjust);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Coex Table Type", \
-			pCoexSta->nCoexTableType);
-		CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "DecBtPwr/ IgnWlanAct", \
-		pCoexDm->curBtDecPwrLvl, pCoexDm->bCurIgnoreWlanAct);
-	CL_PRINTF(cliBuf);
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xc5b);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x880);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x778/0x880[29:25]/0xc58[29:25]", \
-		u1Tmp[0], (u4Tmp[0]&0x3e000000) >> 25, ((u1Tmp[1]&0x3e)>>1));
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x764);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x764/ 0x765/ 0x76e", \
-		(u4Tmp[0]&0xff), (u4Tmp[0]&0xff00)>>8, u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-	
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcb4);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xcb4[7:0](ctrl)/ 0xcb4[29:28](val)", \
-		u4Tmp[0]&0xff, ((u4Tmp[0]&0x30000000)>>28));
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x974);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x40/ 0x4c[24:23]/ 0x974", \
-		u1Tmp[0], ((u4Tmp[0]&0x01800000)>>23), u4Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x49c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xc50(dig)/0x49c(null-drop)", \
-		u4Tmp[0]&0xff, u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xda8);
-	u4Tmp[3] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcf0);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5b);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-
-	faOfdm = ((u4Tmp[0]&0xffff0000) >> 16) +  ((u4Tmp[1]&0xffff0000) >> 16) + (u4Tmp[1] & 0xffff) +  (u4Tmp[2] & 0xffff) + \
-		             ((u4Tmp[3]&0xffff0000) >> 16) + (u4Tmp[3] & 0xffff) ;
-	faCck = (u1Tmp[0] << 8) + u1Tmp[1];
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "OFDM-CCA/OFDM-FA/CCK-FA", \
-		u4Tmp[0]&0xffff, faOfdm, faCck);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_OK CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCOK_CCK, pCoexSta->nCRCOK_11g, pCoexSta->nCRCOK_11n, pCoexSta->nCRCOK_11nAgg);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "CRC_Err CCK/11g/11n/11n-Agg", \
-		pCoexSta->nCRCErr_CCK, pCoexSta->nCRCErr_11g, pCoexSta->nCRCErr_11n, pCoexSta->nCRCErr_11nAgg);
-	CL_PRINTF(cliBuf);	
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, 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[0]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770(high-pri rx/tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri rx/tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-#if(BT_AUTO_REPORT_ONLY_8821A_2ANT == 1)
-	//halbtc8821a2ant_MonitorBtCtr(pBtCoexist);
-#endif
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8821a2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		halbtc8821a2ant_WifiOffHwCfg(pBtCoexist);
-		halbtc8821a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-		halbtc8821a2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-		halbtc8821a2ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8821a2ant_InitCoexDm(pBtCoexist);
-		halbtc8821a2ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8821a2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8821a2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	u1Byte 	u1Tmpa, u1Tmpb;	
-	
-	u1Tmpa = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x765);
-	u1Tmpb = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x76e);
-	 
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-	}
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("############# [BTCoex], 0x765=0x%x, 0x76e=0x%x\n", u1Tmpa, u1Tmpb));
-}
-
-VOID
-EXhalbtc8821a2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8821a2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-	u1Byte			apNum=0;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-		{
-			pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &apNum);
-			if(apNum < 10)
-				H2C_Parameter[2] = 0x30;
-			else
-				H2C_Parameter[2] = 0x20;
-		}
-	}
-	
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);	
-}
-
-VOID
-EXhalbtc8821a2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8821a2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	PBTC_BT_LINK_INFO	pBtLinkInfo=&pBtCoexist->btLinkInfo;
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtBusy=FALSE, bLimitedDig=FALSE;
-	BOOLEAN			bWifiConnected=FALSE, bWifiUnder5G=FALSE;
-	static BOOLEAN		bPreScoExist=FALSE;
-	u4Byte				raMask=0x0;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8821A_2ANT_MAX)
-		rspSource = BT_INFO_SRC_8821A_2ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), return for Manual CTRL<===\n"));
-		return;
-	}
-
-	// if 0xff, it means BT is under WHCK test
-	if (btInfo == 0xff)
-		pCoexSta->bBtWhckTest = TRUE;
-	else
-		pCoexSta->bBtWhckTest = FALSE;
-
-	if(BT_INFO_SRC_8821A_2ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		pCoexSta->bBtTxRxMask = (pCoexSta->btInfoC2h[rspSource][2]&0x40);
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TX_RX_MASK, &pCoexSta->bBtTxRxMask);
-		if(pCoexSta->bBtTxRxMask)
-		{
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x01 => Need to switch BT TRx Mask */				
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x01\n"));
-			pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x01);
-		}
-
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if( (pCoexSta->btInfoExt & BIT1) )
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"));
-			if(bWifiConnected)
-			{
-				EXhalbtc8821a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8821a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-
-		
-		if(!pBtCoexist->bManualControl && !bWifiUnder5G)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info = 0x%x!!\n", pCoexSta->btInfoExt));
-			if( (pCoexSta->btInfoExt&BIT3) )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3=1, bWifiConnected=%d\n", bWifiConnected));
-				if(bWifiConnected)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-					halbtc8821a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3=0, bWifiConnected=%d\n", bWifiConnected));
-				// BT already NOT ignore Wlan active, do nothing here.
-				if(!bWifiConnected)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT to ignore Wlan active!!\n"));
-					halbtc8821a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-				}
-			}
-		}
-
-#if(BT_AUTO_REPORT_ONLY_8821A_2ANT == 0)
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8821a2ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-#endif
-	}
-
-	// check BIT2 first ==> check if bt is under inquiry or page scan
-	if(btInfo & BT_INFO_8821A_2ANT_B_INQ_PAGE)
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-	else
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-
-	// set link exist status
-	if(!(btInfo&BT_INFO_8821A_2ANT_B_CONNECTION))
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-	}
-	else	// connection exists
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		if(btInfo & BT_INFO_8821A_2ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-		if(btInfo & BT_INFO_8821A_2ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-		if(btInfo & BT_INFO_8821A_2ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-		if(btInfo & BT_INFO_8821A_2ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-	
-		if ( (pCoexSta->bHidExist == FALSE) && (pCoexSta->bC2hBtInquiryPage == FALSE) && (pCoexSta->bScoExist == FALSE))
-		{
-			if (pCoexSta->highPriorityTx  + pCoexSta->highPriorityRx >= 160) 
-				pCoexSta->bHidExist = TRUE;
-		}
-	}
-
-	halbtc8821a2ant_UpdateBtLinkInfo(pBtCoexist);
-	
-	if(!(btInfo&BT_INFO_8821A_2ANT_B_CONNECTION))
-	{
-		pCoexDm->btStatus = BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"));
-	}
-	else if(btInfo == BT_INFO_8821A_2ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexDm->btStatus = BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"));
-	}
-	else if((btInfo&BT_INFO_8821A_2ANT_B_SCO_ESCO) ||
-		(btInfo&BT_INFO_8821A_2ANT_B_SCO_BUSY))
-	{
-		pCoexDm->btStatus = BT_8821A_2ANT_BT_STATUS_SCO_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"));
-	}
-	else if(btInfo&BT_INFO_8821A_2ANT_B_ACL_BUSY)
-	{
-		pCoexDm->btStatus = BT_8821A_2ANT_BT_STATUS_ACL_BUSY;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"));
-	}
-	else
-	{
-		pCoexDm->btStatus = BT_8821A_2ANT_BT_STATUS_MAX;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"));
-	}
-	
-	if( (BT_8821A_2ANT_BT_STATUS_ACL_BUSY == pCoexDm->btStatus) ||
-		(BT_8821A_2ANT_BT_STATUS_SCO_BUSY == pCoexDm->btStatus) ||
-		(BT_8821A_2ANT_BT_STATUS_ACL_SCO_BUSY == pCoexDm->btStatus) )
-	{
-		bBtBusy = TRUE;
-		bLimitedDig = TRUE;
-	}
-	else
-	{
-		bBtBusy = FALSE;
-		bLimitedDig = FALSE;
-	}
-
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	pCoexDm->bLimitedDig = bLimitedDig;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bLimitedDig);
-
-	halbtc8821a2ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8821a2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8821a2ant_WifiOffHwCfg(pBtCoexist);
-	//remove due to interrupt is disabled that polling c2h will fail and delay 100ms.
-	//pBtCoexist->fBtcSetBtReg(pBtCoexist, BTC_BT_REG_RF, 0x3c, 0x15); //BT goto standby while GNT_BT 1-->0
-	halbtc8821a2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	
-	EXhalbtc8821a2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8821a2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-		halbtc8821a2ant_InitHwConfig(pBtCoexist, FALSE);
-		halbtc8821a2ant_InitCoexDm(pBtCoexist);
-		halbtc8821a2ant_QueryBtInfo(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8821a2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	//static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(pCoexSta->disVerInfoCnt <= 5)
-	{
-		pCoexSta->disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8821a2Ant, GLCoexVer8821a2Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-
-		if (pCoexSta->disVerInfoCnt == 3)
-		{
-			//Antenna config to set 0x765 = 0x0 (GNT_BT control by PTA) after initial 
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Set GNT_BT control by PTA\n"));
-			halbtc8821a2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_MAIN, FALSE, FALSE);
-		}
-	}
-
-#if(BT_AUTO_REPORT_ONLY_8821A_2ANT == 0)
-	halbtc8821a2ant_QueryBtInfo(pBtCoexist);	
-	halbtc8821a2ant_MonitorBtEnableDisable(pBtCoexist);
-#else
-	halbtc8821a2ant_MonitorBtCtr(pBtCoexist);
-	halbtc8821a2ant_MonitorWiFiCtr(pBtCoexist);
-	
-	if( halbtc8821a2ant_IsWifiStatusChanged(pBtCoexist) ||
-		pCoexDm->bAutoTdmaAdjust)
-	{
-		halbtc8821a2ant_RunCoexistMechanism(pBtCoexist);
-	}
-#endif
-}
-
-
-#endif
-
-#else	// #if (RTL8821A_SUPPORT == 1)
-VOID
-EXhalbtc8821a2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-VOID
-EXhalbtc8821a2ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-VOID
-EXhalbtc8821a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	){}
-VOID
-EXhalbtc8821a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-VOID
-EXhalbtc8821a2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8821a2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8821a2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8821a2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	){}
-VOID
-EXhalbtc8821a2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	){}
-VOID
-EXhalbtc8821a2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	){}
-VOID
-EXhalbtc8821a2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	){}
-VOID
-EXhalbtc8821a2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	){}
-VOID
-EXhalbtc8821a2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	){}
-VOID
-EXhalbtc8821a2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	){}
-VOID
-EXhalbtc8821a2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	){}
-#endif	// #if (RTL8821A_SUPPORT == 1)
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a2Ant.h
deleted file mode 100644
index 99cd0409036a..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821a2Ant.h
+++ /dev/null
@@ -1,227 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8821A 2Ant BT Co-exist definition
-//===========================================
-#define	BT_AUTO_REPORT_ONLY_8821A_2ANT				1
-
-
-#define	BT_INFO_8821A_2ANT_B_FTP						BIT7
-#define	BT_INFO_8821A_2ANT_B_A2DP					BIT6
-#define	BT_INFO_8821A_2ANT_B_HID						BIT5
-#define	BT_INFO_8821A_2ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8821A_2ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8821A_2ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8821A_2ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8821A_2ANT_B_CONNECTION				BIT0
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT		2
-
-
-#define	BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES				42  //WiFi RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation
-#define	BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES				46 //BT RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation
-
-typedef enum _BT_INFO_SRC_8821A_2ANT{
-	BT_INFO_SRC_8821A_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8821A_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8821A_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8821A_2ANT_MAX
-}BT_INFO_SRC_8821A_2ANT,*PBT_INFO_SRC_8821A_2ANT;
-
-typedef enum _BT_8821A_2ANT_BT_STATUS{
-	BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8821A_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8821A_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8821A_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8821A_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8821A_2ANT_BT_STATUS_MAX
-}BT_8821A_2ANT_BT_STATUS,*PBT_8821A_2ANT_BT_STATUS;
-
-typedef enum _BT_8821A_2ANT_COEX_ALGO{
-	BT_8821A_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8821A_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8821A_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8821A_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8821A_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8821A_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8821A_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8821A_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8821A_2ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8821A_2ANT_COEX_ALGO,*PBT_8821A_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8821A_2ANT{
-	// fw mechanism
-	u1Byte		preBtDecPwrLvl;
-	u1Byte		curBtDecPwrLvl;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[5];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bResetTdmaAdjust;
-	BOOLEAN		bAutoTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-
-	BOOLEAN		bNeedRecover0x948;
-	u4Byte		backup0x948;
-
-	u1Byte		preLps;
-	u1Byte		curLps;
-	u1Byte		preRpwm;
-	u1Byte		curRpwm;
-} COEX_DM_8821A_2ANT, *PCOEX_DM_8821A_2ANT;
-
-typedef struct _COEX_STA_8821A_2ANT{	
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	BOOLEAN					bBtTxRxMask;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8821A_2ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8821A_2ANT_MAX];
-	BOOLEAN 				bBtWhckTest;
-	BOOLEAN					bC2hBtInquiryPage;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-
-	u4Byte					nCRCOK_CCK;
-	u4Byte					nCRCOK_11g;
-	u4Byte					nCRCOK_11n;
-	u4Byte					nCRCOK_11nAgg;
-	
-	u4Byte					nCRCErr_CCK;
-	u4Byte					nCRCErr_11g;
-	u4Byte					nCRCErr_11n;
-	u4Byte					nCRCErr_11nAgg;
-
-	u1Byte					nCoexTableType;
-	BOOLEAN					bForceLpsOn;
-
-	u1Byte					disVerInfoCnt;
-}COEX_STA_8821A_2ANT, *PCOEX_STA_8821A_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8821a2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8821a2ant_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8821a2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8821a2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8821a2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821a2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8821a2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8821a2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8821a2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8821a2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8821a2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8821a2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821aCsr2Ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821aCsr2Ant.c
deleted file mode 100644
index a8111a2d22fb..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821aCsr2Ant.c
+++ /dev/null
@@ -1,4344 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for RTL8821A_CSR_CSR Co-exist mechanism
-//
-// History
-// 2012/08/22 Cosa first check in.
-// 2012/11/14 Cosa Revise for 8821A_CSR 2Ant out sourcing.
-//
-//============================================================
-
-//============================================================
-// include files
-//============================================================
-#include "Mp_Precomp.h"
-
-#if WPP_SOFTWARE_TRACE
-#include "HalBtcCsr8821a2Ant.tmh"
-#endif
-
-#define _BTCOEX_CSR 1
-
-#ifndef rtw_warn_on
-	#define rtw_warn_on(condition) do {} while (0)
-#endif
-
-#if(BT_30_SUPPORT == 1)
-//============================================================
-// Global variables, these are static variables
-//============================================================
-static COEX_DM_8821A_CSR_2ANT	GLCoexDm8821aCsr2Ant;
-static PCOEX_DM_8821A_CSR_2ANT 	pCoexDm=&GLCoexDm8821aCsr2Ant;
-static COEX_STA_8821A_CSR_2ANT	GLCoexSta8821aCsr2Ant;
-static PCOEX_STA_8821A_CSR_2ANT	pCoexSta=&GLCoexSta8821aCsr2Ant;
-
-const char *const GLBtInfoSrc8821aCsr2Ant[]={
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u4Byte GLCoexVerDate8821aCsr2Ant=20140901;
-u4Byte GLCoexVer8821aCsr2Ant=0x51;
-
-//============================================================
-// local function proto type if needed
-//============================================================
-//============================================================
-// local function start with halbtc8821aCsr2ant_
-//============================================================
-u1Byte
-halbtc8821aCsr2ant_BtRssiState(
-	u1Byte			levelNum,
-	u1Byte			rssiThresh,
-	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			btRssi=0;
-	u1Byte			btRssiState=pCoexSta->preBtRssiState;
-
-	btRssi = pCoexSta->btRssi;
-
-	if(levelNum == 2)
-	{			
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT Rssi thresh error!!\n"));
-			return pCoexSta->preBtRssiState;
-		}
-		
-		if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(btRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preBtRssiState == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preBtRssiState == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(btRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT))
-			{
-				btRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(btRssi < rssiThresh)
-			{
-				btRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(btRssi < rssiThresh1)
-			{
-				btRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				btRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preBtRssiState = btRssiState;
-
-	return btRssiState;
-}
-
-u1Byte
-halbtc8821aCsr2ant_WifiRssiState(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			index,
-	IN	u1Byte			levelNum,
-	IN	u1Byte			rssiThresh,
-	IN	u1Byte			rssiThresh1
-	)
-{
-	s4Byte			wifiRssi=0;
-	u1Byte			wifiRssiState=pCoexSta->preWifiRssiState[index];
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	
-	if(levelNum == 2)
-	{
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-	else if(levelNum == 3)
-	{
-		if(rssiThresh > rssiThresh1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], wifi RSSI thresh error!!\n"));
-			return pCoexSta->preWifiRssiState[index];
-		}
-		
-		if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_LOW) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_LOW))
-		{
-			if(wifiRssi >= (rssiThresh+BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_LOW;
-			}
-		}
-		else if( (pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_MEDIUM) ||
-			(pCoexSta->preWifiRssiState[index] == BTC_RSSI_STATE_STAY_MEDIUM))
-		{
-			if(wifiRssi >= (rssiThresh1+BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT))
-			{
-				wifiRssiState = BTC_RSSI_STATE_HIGH;
-			}
-			else if(wifiRssi < rssiThresh)
-			{
-				wifiRssiState = BTC_RSSI_STATE_LOW;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_MEDIUM;
-			}
-		}
-		else
-		{
-			if(wifiRssi < rssiThresh1)
-			{
-				wifiRssiState = BTC_RSSI_STATE_MEDIUM;
-			}
-			else
-			{
-				wifiRssiState = BTC_RSSI_STATE_STAY_HIGH;
-			}
-		}
-	}
-		
-	pCoexSta->preWifiRssiState[index] = wifiRssiState;
-
-	return wifiRssiState;
-}
-
-VOID
-halbtc8821aCsr2ant_MonitorBtEnableDisable(
-	IN 	PBTC_COEXIST		pBtCoexist
-	)
-{
-	static BOOLEAN	bPreBtDisabled=FALSE;
-	static u4Byte	btDisableCnt=0;
-	BOOLEAN			bBtActive=TRUE, bBtDisabled=FALSE;
-
-	// This function check if bt is disabled
-
-	if(	pCoexSta->highPriorityTx == 0 &&
-		pCoexSta->highPriorityRx == 0 &&
-		pCoexSta->lowPriorityTx == 0 &&
-		pCoexSta->lowPriorityRx == 0)
-	{
-		bBtActive = FALSE;
-	}
-	if(	pCoexSta->highPriorityTx == 0xffff &&
-		pCoexSta->highPriorityRx == 0xffff &&
-		pCoexSta->lowPriorityTx == 0xffff &&
-		pCoexSta->lowPriorityRx == 0xffff)
-	{
-		bBtActive = FALSE;
-	}
-	if(bBtActive)
-	{
-		btDisableCnt = 0;
-		bBtDisabled = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is enabled !!\n"));
-	}
-	else
-	{
-		btDisableCnt++;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], bt all counters=0, %d times!!\n", 
-				btDisableCnt));
-		if(btDisableCnt >= 2)
-		{
-			bBtDisabled = TRUE;
-			pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_DISABLE, &bBtDisabled);
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is disabled !!\n"));
-		}
-	}
-	if(bPreBtDisabled != bBtDisabled)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is from %s to %s!!\n", 
-			(bPreBtDisabled ? "disabled":"enabled"), 
-			(bBtDisabled ? "disabled":"enabled")));
-		bPreBtDisabled = bBtDisabled;
-		if(!bBtDisabled)
-		{
-		}
-		else
-		{
-		}
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_MonitorBtCtr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u4Byte 			regHPTxRx, regLPTxRx, u4Tmp;
-	u4Byte			regHPTx=0, regHPRx=0, regLPTx=0, regLPRx=0;
-	u1Byte			u1Tmp;
-	
-	regHPTxRx = 0x770;
-	regLPTxRx = 0x774;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regHPTxRx);
-	regHPTx = u4Tmp & bMaskLWord;
-	regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-	u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, regLPTxRx);
-	regLPTx = u4Tmp & bMaskLWord;
-	regLPRx = (u4Tmp & bMaskHWord)>>16;
-		
-	pCoexSta->highPriorityTx = regHPTx;
-	pCoexSta->highPriorityRx = regHPRx;
-	pCoexSta->lowPriorityTx = regLPTx;
-	pCoexSta->lowPriorityRx = regLPRx;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regHPTxRx, regHPTx, regHPTx, regHPRx, regHPRx));
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 
-		regLPTxRx, regLPTx, regLPTx, regLPRx, regLPRx));
-
-	// reset counter
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0x5d);
-}
-
-VOID
-halbtc8821aCsr2ant_UpdateRaMask(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u4Byte				disRateMask
-	)
-{
-	pCoexDm->curRaMask = disRateMask;
-	
-	if( bForceExec || (pCoexDm->preRaMask != pCoexDm->curRaMask))
-	{
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_UPDATE_RAMASK, &pCoexDm->curRaMask);
-	}
-	pCoexDm->preRaMask = pCoexDm->curRaMask;
-}
-
-VOID
-halbtc8821aCsr2ant_AutoRateFallbackRetry(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	BOOLEAN	bWifiUnderBMode=FALSE;
-	
-	pCoexDm->curArfrType = type;
-
-	if( bForceExec || (pCoexDm->preArfrType != pCoexDm->curArfrType))
-	{
-		switch(pCoexDm->curArfrType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, pCoexDm->backupArfrCnt1);
-				pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, pCoexDm->backupArfrCnt2);
-				break;
-			case 1:	
-				pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-				if(bWifiUnderBMode)
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x01010101);
-				}
-				else
-				{
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x430, 0x0);
-					pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x434, 0x04030201);
-				}
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preArfrType = pCoexDm->curArfrType;
-}
-
-VOID
-halbtc8821aCsr2ant_RetryLimit(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curRetryLimitType = type;
-
-	if( bForceExec || (pCoexDm->preRetryLimitType != pCoexDm->curRetryLimitType))
-	{
-		switch(pCoexDm->curRetryLimitType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, pCoexDm->backupRetryLimit);
-				break;
-			case 1:	// retry limit=8
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x42a, 0x0808);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preRetryLimitType = pCoexDm->curRetryLimitType;
-}
-
-VOID
-halbtc8821aCsr2ant_AmpduMaxTime(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduTimeType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduTimeType != pCoexDm->curAmpduTimeType))
-	{
-		switch(pCoexDm->curAmpduTimeType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, pCoexDm->backupAmpduMaxTime);
-				break;
-			case 1:	// AMPDU timw = 0x38 * 32us
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x38);
-				break;
-			case 2: 
-				pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x456, 0x17);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduTimeType = pCoexDm->curAmpduTimeType;
-}
-
-VOID
-halbtc8821aCsr2Ant_AmpduMaxNum(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				type
-	)
-{
-	pCoexDm->curAmpduNumType = type;
-
-	if( bForceExec || (pCoexDm->preAmpduNumType != pCoexDm->curAmpduNumType))
-	{
-		switch(pCoexDm->curAmpduNumType)
-		{
-			case 0:	// normal mode
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x4ca, pCoexDm->backupAmpduMaxNum);
-				break;
-			case 1:
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x4ca, 0x0808);
-				break;
-			case 2: 
-				pBtCoexist->fBtcWrite2Byte(pBtCoexist, 0x4ca, 0x1f1f);
-				break;
-			default:
-				break;
-		}
-	}
-
-	pCoexDm->preAmpduNumType = pCoexDm->curAmpduNumType;
-
-}
-
-VOID
-halbtc8821aCsr2ant_LimitedTx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	u1Byte				raMaskType,
-	IN	u1Byte				arfrType,
-	IN	u1Byte				retryLimitType,
-	IN	u1Byte				ampduTimeType,
-	IN	u1Byte				ampduNumType
-	)
-{
-	switch(raMaskType)
-	{
-		case 0:	// normal mode
-			halbtc8821aCsr2ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0);
-			break;
-		case 1:	// disable cck 1/2
-			halbtc8821aCsr2ant_UpdateRaMask(pBtCoexist, bForceExec, 0x00000003);
-			break;
-		case 2:	// disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4
-			halbtc8821aCsr2ant_UpdateRaMask(pBtCoexist, bForceExec, 0x0001f1f7);
-			break;
-		default:
-			break;
-	}
-
-	halbtc8821aCsr2ant_AutoRateFallbackRetry(pBtCoexist, bForceExec, arfrType);
-	halbtc8821aCsr2ant_RetryLimit(pBtCoexist, bForceExec, retryLimitType);
-	halbtc8821aCsr2ant_AmpduMaxTime(pBtCoexist, bForceExec, ampduTimeType);
-	halbtc8821aCsr2Ant_AmpduMaxNum(pBtCoexist, bForceExec, ampduNumType);
-}
-
-
-
-VOID
-halbtc8821aCsr2ant_LimitedRx(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bForceExec,
-	IN	BOOLEAN				bRejApAggPkt,
-	IN	BOOLEAN				bBtCtrlAggBufSize,
-	IN	u1Byte				aggBufSize
-	)
-{
-	BOOLEAN	bRejectRxAgg=bRejApAggPkt;
-	BOOLEAN	bBtCtrlRxAggSize=bBtCtrlAggBufSize;
-	u1Byte	rxAggSize=aggBufSize;
-
-	//============================================
-	//	Rx Aggregation related setting
-	//============================================
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &bRejectRxAgg);
-	// decide BT control aggregation buf size or not
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bBtCtrlRxAggSize);
-	// aggregation buf size, only work when BT control Rx aggregation size.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_AGG_BUF_SIZE, &rxAggSize);
-	// real update aggregation setting
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-}
-
-VOID
-halbtc8821aCsr2ant_QueryBtInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	pCoexSta->bC2hBtInfoReqSent = TRUE;
-
-	H2C_Parameter[0] |= BIT0;	// trigger
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Query Bt Info, FW write 0x61=0x%x\n", 
-		H2C_Parameter[0]));
-
-	rtw_warn_on(_BTCOEX_CSR);
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x61, 1, H2C_Parameter);
-}
-
-u1Byte
-halbtc8821aCsr2ant_ActionAlgorithm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	BOOLEAN				bBtHsOn=FALSE;
-	u1Byte				algorithm=BT_8821A_CSR_2ANT_COEX_ALGO_UNDEFINED;
-	u1Byte				numOfDiffProfile=0;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	//sync StackInfo with BT firmware and stack
-	pStackInfo->bHidExist = pCoexSta->bHidExist;
-	pStackInfo->bBtLinkExist = pCoexSta->bBtLinkExist;
-	pStackInfo->bScoExist = pCoexSta->bScoExist;
-	pStackInfo->bPanExist = pCoexSta->bPanExist;
-	pStackInfo->bA2dpExist = pCoexSta->bA2dpExist;
-
-	if(!pStackInfo->bBtLinkExist)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], No profile exists!!!\n"));
-		return algorithm;
-	}
-
-	if(pStackInfo->bScoExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bHidExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bPanExist)
-		numOfDiffProfile++;
-	if(pStackInfo->bA2dpExist)
-		numOfDiffProfile++;
-	
-	if(numOfDiffProfile == 1)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO only\n"));
-			algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_SCO;
-		}
-		else
-		{
-			if(pStackInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID only\n"));
-				algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_HID;
-			}
-			else if(pStackInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP only\n"));
-				algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_A2DP;
-			}
-			else if(pStackInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(HS) only\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PAN(EDR) only\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 2)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			if(pStackInfo->bHidExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID\n"));
-				algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pStackInfo->bA2dpExist)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP ==> SCO\n"));
-				algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if(pStackInfo->bPanExist)
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(HS)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_SCO;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + PAN(EDR)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(pStackInfo->numOfHid >= 2)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID*2 + A2DP\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-				else
-				{			
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			}
-			else if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(HS)\n"));
-					algorithm =  BT_8821A_CSR_2ANT_COEX_ALGO_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + PAN(EDR)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_A2DP_PANHS;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], A2DP + PAN(EDR)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile == 3)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bA2dpExist )
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP ==> HID\n"));
-				algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-			}
-			else if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(HS)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + PAN(EDR)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-			else if( pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-		else
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP;
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-	else if(numOfDiffProfile >= 3)
-	{
-		if(pStackInfo->bScoExist)
-		{
-			if( pStackInfo->bHidExist &&
-				pStackInfo->bPanExist &&
-				pStackInfo->bA2dpExist )
-			{
-				if(bBtHsOn)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-
-				}
-				else
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"));
-					algorithm = BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-BOOLEAN
-halbtc8821aCsr2ant_NeedToDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN		bRet=FALSE;
-	BOOLEAN		bBtHsOn=FALSE, bWifiConnected=FALSE;
-	s4Byte		btHsRssi=0;
-	u1Byte 		btRssiState;
-
-	if(!pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn))
-		return FALSE;
-	if(!pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected))
-		return FALSE;
-	if(!pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_HS_RSSI, &btHsRssi))
-		return FALSE;
-
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	if(bWifiConnected)
-	{
-		if(bBtHsOn)
-		{
-			if(btHsRssi > 37)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Need to decrease bt power for HS mode!!\n"));
-				bRet = TRUE;
-			}
-		}
-		else
-		{
-			if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-			{
-		
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Need to decrease bt power for Wifi is connected!!\n"));
-				bRet = TRUE;
-			}
-		}
-	}
-	
-	return bRet;
-}
-
-VOID
-halbtc8821aCsr2ant_SetFwDacSwingLevel(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			dacSwingLvl
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-
-	// There are several type of dacswing
-	// 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6
-	H2C_Parameter[0] = dacSwingLvl;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Set Dac Swing Level=0x%x\n", dacSwingLvl));
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x64=0x%x\n", H2C_Parameter[0]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x64, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8821aCsr2ant_SetFwDecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bDecBtPwr
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bDecBtPwr)
-	{
-		H2C_Parameter[0] |= BIT1;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], decrease Bt Power : %s, FW write 0x62=0x%x\n", 
-		(bDecBtPwr? "Yes!!":"No!!"), H2C_Parameter[0]));
-
-	rtw_warn_on(_BTCOEX_CSR);
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x62, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8821aCsr2ant_DecBtPwr(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDecBtPwr
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s Dec BT power = %s\n",  
-		(bForceExec? "force to":""), ((bDecBtPwr)? "ON":"OFF")));
-	pCoexDm->bCurDecBtPwr = bDecBtPwr;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreDecBtPwr == pCoexDm->bCurDecBtPwr) 
-			return;
-	}
-
-	/* TODO: may CSR consider to decrease BT power? */
-	//halbtc8821aCsr2ant_SetFwDecBtPwr(pBtCoexist, pCoexDm->bCurDecBtPwr);
-
-	pCoexDm->bPreDecBtPwr = pCoexDm->bCurDecBtPwr;
-}
-
-VOID
-halbtc8821aCsr2ant_SetBtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-	
-	H2C_Parameter[0] = 0;
-
-	if(bEnableAutoReport)
-	{
-		H2C_Parameter[0] |= BIT0;
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], BT FW auto report : %s, FW write 0x68=0x%x\n", 
-		(bEnableAutoReport? "Enabled!!":"Disabled!!"), H2C_Parameter[0]));
-
-	rtw_warn_on(_BTCOEX_CSR);
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x68, 1, H2C_Parameter);	
-}
-
-VOID
-halbtc8821aCsr2ant_BtAutoReport(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnableAutoReport
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s BT Auto report = %s\n",  
-		(bForceExec? "force to":""), ((bEnableAutoReport)? "Enabled":"Disabled")));
-	pCoexDm->bCurBtAutoReport = bEnableAutoReport;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreBtAutoReport == pCoexDm->bCurBtAutoReport) 
-			return;
-	}
-	//halbtc8821aCsr2ant_SetBtAutoReport(pBtCoexist, pCoexDm->bCurBtAutoReport);
-
-	pCoexDm->bPreBtAutoReport = pCoexDm->bCurBtAutoReport;
-}
-
-VOID
-halbtc8821aCsr2ant_FwDacSwingLvl(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u1Byte			fwDacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s set FW Dac Swing level = %d\n",  
-		(bForceExec? "force to":""), fwDacSwingLvl));
-	pCoexDm->curFwDacSwingLvl = fwDacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->preFwDacSwingLvl == pCoexDm->curFwDacSwingLvl) 
-			return;
-	}
-
-	halbtc8821aCsr2ant_SetFwDacSwingLevel(pBtCoexist, pCoexDm->curFwDacSwingLvl);
-
-	pCoexDm->preFwDacSwingLvl = pCoexDm->curFwDacSwingLvl;
-}
-
-VOID
-halbtc8821aCsr2ant_SetSwRfRxLpfCorner(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	if(bRxRfShrinkOn)
-	{
-		//Shrink RF Rx LPF corner
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Shrink RF Rx LPF corner!!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, 0xffffc);
-	}
-	else
-	{
-		//Resume RF Rx LPF corner
-		// After initialized, we can use pCoexDm->btRf0x1eBackup
-		if(pBtCoexist->bInitilized)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Resume RF Rx LPF corner!!\n"));
-			pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff, pCoexDm->btRf0x1eBackup);
-		}
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_RfShrink(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bRxRfShrinkOn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Rx RF Shrink = %s\n",  
-		(bForceExec? "force to":""), ((bRxRfShrinkOn)? "ON":"OFF")));
-	pCoexDm->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreRfRxLpfShrink == pCoexDm->bCurRfRxLpfShrink) 
-			return;
-	}
-	halbtc8821aCsr2ant_SetSwRfRxLpfCorner(pBtCoexist, pCoexDm->bCurRfRxLpfShrink);
-
-	pCoexDm->bPreRfRxLpfShrink = pCoexDm->bCurRfRxLpfShrink;
-}
-
-VOID
-halbtc8821aCsr2ant_SetSwPenaltyTxRateAdaptive(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-	
-	H2C_Parameter[0] = 0x6;	// opCode, 0x6= Retry_Penalty
-
-	if(bLowPenaltyRa)
-	{
-		H2C_Parameter[1] |= BIT0;
-		H2C_Parameter[2] = 0x00;  //normal rate except MCS7/6/5, OFDM54/48/36
-		H2C_Parameter[3] = 0xf7;  //MCS7 or OFDM54
-		H2C_Parameter[4] = 0xf8;  //MCS6 or OFDM48
-		H2C_Parameter[5] = 0xf9;	//MCS5 or OFDM36	
-	}
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set WiFi Low-Penalty Retry: %s", 
-		(bLowPenaltyRa? "ON!!":"OFF!!") ));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x69, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8821aCsr2ant_LowPenaltyRa(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bLowPenaltyRa
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn LowPenaltyRA = %s\n",  
-		(bForceExec? "force to":""), ((bLowPenaltyRa)? "ON":"OFF")));
-	pCoexDm->bCurLowPenaltyRa = bLowPenaltyRa;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreLowPenaltyRa == pCoexDm->bCurLowPenaltyRa) 
-			return;
-	}
-	halbtc8821aCsr2ant_SetSwPenaltyTxRateAdaptive(pBtCoexist, pCoexDm->bCurLowPenaltyRa);
-
-	pCoexDm->bPreLowPenaltyRa = pCoexDm->bCurLowPenaltyRa;
-}
-
-VOID
-halbtc8821aCsr2ant_SetDacSwingReg(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u4Byte			level
-	)
-{
-	u1Byte	val=(u1Byte)level;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Write SwDacSwing = 0x%x\n", level));
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xc5b, 0x3e, val);
-}
-
-VOID
-halbtc8821aCsr2ant_SetSwFullTimeDacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bSwDacSwingOn,
-	IN	u4Byte			swDacSwingLvl
-	)
-{
-	if(bSwDacSwingOn)
-	{
-		halbtc8821aCsr2ant_SetDacSwingReg(pBtCoexist, swDacSwingLvl);
-	}
-	else
-	{
-		halbtc8821aCsr2ant_SetDacSwingReg(pBtCoexist, 0x18);
-	}
-}
-
-
-VOID
-halbtc8821aCsr2ant_DacSwing(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bDacSwingOn,
-	IN	u4Byte			dacSwingLvl
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn DacSwing=%s, dacSwingLvl=0x%x\n",  
-		(bForceExec? "force to":""), ((bDacSwingOn)? "ON":"OFF"), dacSwingLvl));
-	pCoexDm->bCurDacSwingOn = bDacSwingOn;
-	pCoexDm->curDacSwingLvl = dacSwingLvl;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPreDacSwingOn == pCoexDm->bCurDacSwingOn) &&
-			(pCoexDm->preDacSwingLvl == pCoexDm->curDacSwingLvl) )
-			return;
-	}
-	delay_ms(30);
-	halbtc8821aCsr2ant_SetSwFullTimeDacSwing(pBtCoexist, bDacSwingOn, dacSwingLvl);
-
-	pCoexDm->bPreDacSwingOn = pCoexDm->bCurDacSwingOn;
-	pCoexDm->preDacSwingLvl = pCoexDm->curDacSwingLvl;
-}
-
-VOID
-halbtc8821aCsr2ant_SetAdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	if(bAdcBackOff)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level On!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x8db, 0x60, 0x3);
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BB BackOff Level Off!\n"));
-		pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x8db, 0x60, 0x1);
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_AdcBackOff(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAdcBackOff
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn AdcBackOff = %s\n",  
-		(bForceExec? "force to":""), ((bAdcBackOff)? "ON":"OFF")));
-	pCoexDm->bCurAdcBackOff = bAdcBackOff;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAdcBackOff == pCoexDm->bCurAdcBackOff) 
-			return;
-	}
-	halbtc8821aCsr2ant_SetAdcBackOff(pBtCoexist, pCoexDm->bCurAdcBackOff);
-
-	pCoexDm->bPreAdcBackOff = pCoexDm->bCurAdcBackOff;
-}
-
-VOID
-halbtc8821aCsr2ant_SetAgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	u1Byte		rssiAdjustVal=0;
-
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if(bAgcTableEn)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table On!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff,  0x28F4B);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff,  0x10AB2);
-		rssiAdjustVal = 8;
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Agc Table Off!\n"));
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x2884B);
-		pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0x3b, 0xfffff, 0x104B2);
-	}
-	pBtCoexist->fBtcSetRfReg(pBtCoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	// set rssiAdjustVal for wifi module.
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON, &rssiAdjustVal);
-}
-
-VOID
-halbtc8821aCsr2ant_AgcTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bAgcTableEn
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s %s Agc Table\n",  
-		(bForceExec? "force to":""), ((bAgcTableEn)? "Enable":"Disable")));
-	pCoexDm->bCurAgcTableEn = bAgcTableEn;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreAgcTableEn == pCoexDm->bCurAgcTableEn) 
-			return;
-	}
-	halbtc8821aCsr2ant_SetAgcTable(pBtCoexist, bAgcTableEn);
-
-	pCoexDm->bPreAgcTableEn = pCoexDm->bCurAgcTableEn;
-}
-
-VOID
-halbtc8821aCsr2ant_SetCoexTable(
-	IN	PBTC_COEXIST	pBtCoexist,
-	IN	u4Byte		val0x6c0,
-	IN	u4Byte		val0x6c4,
-	IN	u4Byte		val0x6c8,
-	IN	u1Byte		val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c0, val0x6c0);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c4, val0x6c4);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8));
-	pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x6c8, val0x6c8);
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc));
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x6cc, val0x6cc);
-}
-
-VOID
-halbtc8821aCsr2ant_CoexTable(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	u4Byte			val0x6c0,
-	IN	u4Byte			val0x6c4,
-	IN	u4Byte			val0x6c8,
-	IN	u1Byte			val0x6cc
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 
-		(bForceExec? "force to":""), val0x6c0, val0x6c4, val0x6c8, val0x6cc));
-	pCoexDm->curVal0x6c0 = val0x6c0;
-	pCoexDm->curVal0x6c4 = val0x6c4;
-	pCoexDm->curVal0x6c8 = val0x6c8;
-	pCoexDm->curVal0x6cc = val0x6cc;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->preVal0x6c0 == pCoexDm->curVal0x6c0) &&
-			(pCoexDm->preVal0x6c4 == pCoexDm->curVal0x6c4) &&
-			(pCoexDm->preVal0x6c8 == pCoexDm->curVal0x6c8) &&
-			(pCoexDm->preVal0x6cc == pCoexDm->curVal0x6cc) )
-			return;
-	}
-	halbtc8821aCsr2ant_SetCoexTable(pBtCoexist, val0x6c0, val0x6c4, val0x6c8, val0x6cc);
-
-	pCoexDm->preVal0x6c0 = pCoexDm->curVal0x6c0;
-	pCoexDm->preVal0x6c4 = pCoexDm->curVal0x6c4;
-	pCoexDm->preVal0x6c8 = pCoexDm->curVal0x6c8;
-	pCoexDm->preVal0x6cc = pCoexDm->curVal0x6cc;
-}
-
-VOID
-halbtc8821aCsr2ant_SetFwIgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bEnable
-	)
-{
-	u1Byte			H2C_Parameter[1] ={0};
-		
-	if(bEnable)
-	{
-		H2C_Parameter[0] |= BIT0;		// function enable
-	}
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 
-		H2C_Parameter[0]));
-
-	rtw_warn_on(_BTCOEX_CSR);
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x63, 1, H2C_Parameter);
-}
-
-VOID
-halbtc8821aCsr2ant_IgnoreWlanAct(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bEnable
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn Ignore WlanAct %s\n", 
-		(bForceExec? "force to":""), (bEnable? "ON":"OFF")));
-	pCoexDm->bCurIgnoreWlanAct = bEnable;
-
-	if(!bForceExec)
-	{
-		if(pCoexDm->bPreIgnoreWlanAct == pCoexDm->bCurIgnoreWlanAct)
-			return;
-	}
-	//halbtc8821aCsr2ant_SetFwIgnoreWlanAct(pBtCoexist, bEnable);
-
-	pCoexDm->bPreIgnoreWlanAct = pCoexDm->bCurIgnoreWlanAct;
-}
-
-VOID
-halbtc8821aCsr2ant_SetFwPstdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			byte1,
-	IN	u1Byte			byte2,
-	IN	u1Byte			byte3,
-	IN	u1Byte			byte4,
-	IN	u1Byte			byte5
-	)
-{
-	u1Byte			H2C_Parameter[6] ={0};
-
-	H2C_Parameter[0] = byte1;	
-	H2C_Parameter[1] = byte2;	
-	H2C_Parameter[2] = byte3;
-	H2C_Parameter[3] = byte4;
-	H2C_Parameter[4] = byte5;
-	H2C_Parameter[5] = 0x01;
-
-	pCoexDm->psTdmaPara[0] = byte1;
-	pCoexDm->psTdmaPara[1] = byte2;
-	pCoexDm->psTdmaPara[2] = byte3;
-	pCoexDm->psTdmaPara[3] = byte4;
-	pCoexDm->psTdmaPara[4] = byte5;
-	pCoexDm->psTdmaPara[5] = 0x01;
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x60(6bytes)=0x%x%08x%02x\n", 
-		H2C_Parameter[0], 
-		H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4], H2C_Parameter[5]));
-
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x60, 6, H2C_Parameter);
-}
-
-VOID
-halbtc8821aCsr2ant_SwMechanism1(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bShrinkRxLPF,
-	IN	BOOLEAN 	bLowPenaltyRA,
-	IN	BOOLEAN		bLimitedDIG, 
-	IN	BOOLEAN		bBTLNAConstrain
-	) 
-{
-	u4Byte	wifiBw;
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	
-	if(BTC_WIFI_BW_HT40 != wifiBw)  //only shrink RF Rx LPF for HT40
-	{
-		if (bShrinkRxLPF)
-			bShrinkRxLPF = FALSE;
-	}
-	 	
-	 halbtc8821aCsr2ant_RfShrink(pBtCoexist, NORMAL_EXEC, bShrinkRxLPF);
-	halbtc8821aCsr2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, bLowPenaltyRA);
-
-  	//no limited DIG
-	//halbtc8821aCsr2ant_SetBtLnaConstrain(pBtCoexist, NORMAL_EXEC, bBTLNAConstrain);
-}
-
-VOID
-halbtc8821aCsr2ant_SwMechanism2(
-	IN	PBTC_COEXIST	pBtCoexist,	
-	IN	BOOLEAN		bAGCTableShift,
-	IN	BOOLEAN 	bADCBackOff,
-	IN	BOOLEAN		bSWDACSwing,
-	IN	u4Byte		dacSwingLvl
-	) 
-{
-	//halbtc8821aCsr2ant_AgcTable(pBtCoexist, NORMAL_EXEC, bAGCTableShift);
-	halbtc8821aCsr2ant_AdcBackOff(pBtCoexist, NORMAL_EXEC, bADCBackOff);
-	halbtc8821aCsr2ant_DacSwing(pBtCoexist, NORMAL_EXEC, bSWDACSwing, dacSwingLvl);
-}
-
-VOID
-halbtc8821aCsr2ant_SetAntPath(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte				antPosType,
-	IN	BOOLEAN				bInitHwCfg,
-	IN	BOOLEAN				bWifiOff
-	)
-{
-	PBTC_BOARD_INFO 	pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte				u4Tmp=0;
-	u1Byte				H2C_Parameter[2] ={0};
-	
-	if(bInitHwCfg)
-	{
-		// 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT
-		u4Tmp = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-		u4Tmp &=~BIT23;
-		u4Tmp |= BIT24;
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x4c, u4Tmp);
-
-		pBtCoexist->fBtcWrite4Byte(pBtCoexist, 0x974, 0x3ff);
-		pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0xcb4, 0x77);
-
-		if(pBoardInfo->btdmAntPos == BTC_ANTENNA_AT_MAIN_PORT) 
-		{
-			//tell firmware "antenna inverse"  ==> WRONG firmware antenna control code.==>need fw to fix
-			H2C_Parameter[0] = 1;
-			H2C_Parameter[1] = 1;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-		}
-		else
-		{
-			//tell firmware "no antenna inverse" ==> WRONG firmware antenna control code.==>need fw to fix
-			H2C_Parameter[0] = 0;
-			H2C_Parameter[1] = 1;
-			pBtCoexist->fBtcFillH2c(pBtCoexist, 0x65, 2, H2C_Parameter);
-		}
-	}
-	
-	// ext switch setting
-	switch(antPosType)
-	{
-		case BTC_ANT_WIFI_AT_MAIN:
-			pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x1);
-			break;
-		case BTC_ANT_WIFI_AT_AUX:
-			pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0xcb7, 0x30, 0x2);
-			break;
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_PsTdma(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bForceExec,
-	IN	BOOLEAN			bTurnOn,
-	IN	u1Byte			type
-	)
-{
-	BOOLEAN			bTurnOnByCnt=FALSE;
-	u1Byte			psTdmaTypeByCnt=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], %s turn %s PS TDMA, type=%d\n", 
-		(bForceExec? "force to":""), (bTurnOn? "ON":"OFF"), type));
-	pCoexDm->bCurPsTdmaOn = bTurnOn;
-	pCoexDm->curPsTdma = type;
-
-	if(!bForceExec)
-	{
-		if( (pCoexDm->bPrePsTdmaOn == pCoexDm->bCurPsTdmaOn) &&
-			(pCoexDm->prePsTdma == pCoexDm->curPsTdma) )
-			return;
-	}	
-	if(bTurnOn)
-	{
-		switch(type)
-		{
-			case 1:
-			default:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				break;
-			case 2:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90);
-				break;
-			case 3:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0xf1, 0x90);
-				break;
-			case 4:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x10, 0x03, 0xf1, 0x90);
-				break;
-			case 5:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90);
-				break;
-			case 6:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x90);
-				break;
-			case 7:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1c, 0x3, 0x70, 0x90);
-				break;
-			case 8:	
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x10, 0x3, 0x70, 0x90);
-				break;
-			case 9:	
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				break;
-			case 10:	
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90);
-				break;
-			case 11:	
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0xe1, 0x90);
-				break;
-			case 12:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				break;
-			case 13:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90);
-				break;
-			case 14:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x12, 0x12, 0x60, 0x90);
-				break;
-			case 15:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0xa, 0xa, 0x60, 0x90);
-				break;
-			case 16:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0x60, 0x90);
-				break;
-			case 17:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xa3, 0x2f, 0x2f, 0x60, 0x90);
-				break;
-			case 18:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-				break;			
-			case 19:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0xe1, 0x90);
-				break;
-			case 20:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x25, 0x25, 0x60, 0x90);
-				break;
-			case 21:	
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x15, 0x03, 0x70, 0x90);
-				break;
-			case 22:	//ad2dp master
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xeb, 0x11, 0x11, 0x21, 0x10);
-				break;
-			case 23:	//a2dp slave
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xeb, 0x12, 0x12, 0x20, 0x10);
-				break;
-			case 71:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-				break;
-		}
-	}
-	else
-	{
-		// disable PS tdma
-		switch(type)
-		{
-			case 0:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-			case 1:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x48, 0x0);
-				break;
-			default:
-				halbtc8821aCsr2ant_SetFwPstdma(pBtCoexist, 0x0, 0x0, 0x0, 0x40, 0x0);
-				break;
-		}
-	}
-
-	// update pre state
-	pCoexDm->bPrePsTdmaOn = pCoexDm->bCurPsTdmaOn;
-	pCoexDm->prePsTdma = pCoexDm->curPsTdma;
-}
-
-VOID
-halbtc8821aCsr2ant_CoexAllOff(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	// fw all off
-	halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	// sw all off
-	halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-
-	// hw all off
-	halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x55555555, 0xffff, 0x3);
-}
-
-VOID
-halbtc8821aCsr2ant_CoexUnder5G(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	halbtc8821aCsr2ant_CoexAllOff(pBtCoexist);
-
-	halbtc8821aCsr2ant_IgnoreWlanAct(pBtCoexist, NORMAL_EXEC, TRUE);
-}
-
-VOID
-halbtc8821aCsr2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{	
-	// force to reset coex mechanism
-	halbtc8821aCsr2ant_CoexTable(pBtCoexist, FORCE_EXEC, 0x55555555, 0x55555555, 0xffff, 0x3);
-
-	halbtc8821aCsr2ant_PsTdma(pBtCoexist, FORCE_EXEC, FALSE, 1);
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, FORCE_EXEC, 6);
-	halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, FORCE_EXEC, FALSE);
-
-	halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-	halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-}
-
-VOID
-halbtc8821aCsr2ant_BtInquiryPage(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN	bLowPwrDisable=TRUE;
-	
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-	halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5afa5afa, 0xffff, 0x3);
-	halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-}
-BOOLEAN
-halbtc8821aCsr2ant_IsCommonAction(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	BOOLEAN			bCommon=FALSE, bWifiConnected=FALSE, bWifiBusy=FALSE;
-	BOOLEAN			bLowPwrDisable=FALSE;
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-
-	if(!bWifiConnected && 
-		BT_8821A_CSR_2ANT_BT_STATUS_IDLE == pCoexDm->btStatus)
-	{
-		bLowPwrDisable = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi IPS + BT IPS!!\n"));	
-
-		
-		halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-		
- 		halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0, 0);
-		halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, 0, 0, 0);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-			(BT_8821A_CSR_2ANT_BT_STATUS_IDLE == pCoexDm->btStatus) )
-	{		
-		bLowPwrDisable = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-		if(bWifiBusy)
-		{	
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Busy + BT IPS!!\n"));
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi LPS + BT IPS!!\n"));
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0, 0);
-		halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, 0, 0, 0);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-		(BT_8821A_CSR_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		bLowPwrDisable = TRUE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi IPS + BT LPS!!\n"));		
-
-		halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0, 0);
-		halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, 0, 0, 0);
-
-		bCommon = TRUE;
-	}
-	else if(bWifiConnected && 
-		(BT_8821A_CSR_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus) )
-	{
-		bLowPwrDisable = TRUE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-		
-		if(bWifiBusy)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Busy + BT LPS!!\n"));
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi LPS + BT LPS!!\n"));
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,TRUE,TRUE);
-		halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0, 0);
-		halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, 0, 0, 0);
-
-		bCommon = TRUE;
-	}
-	else if(!bWifiConnected && 
-			(BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE == pCoexDm->btStatus) )
-	{
-		bLowPwrDisable = FALSE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi IPS + BT Busy!!\n"));	
-
-		//halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-		halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0, 0);
-		halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, 0, 0, 0);
-		
-		bCommon = TRUE;
-	}
-	else
-	{
-		bLowPwrDisable = TRUE;
-		pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &bLowPwrDisable);
-
-		if(bWifiBusy)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi Busy + BT Busy!!\n"));
-	  		bCommon = FALSE;
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Wifi LPS + BT Busy!!\n"));
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 21);
-
-			if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-				halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-			else	
-				halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-			
-			bCommon = TRUE;
-		}
-
-		halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,TRUE,TRUE);
-	}
-
-	if (bCommon == TRUE)
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5afa5afa, 0xffff, 0x3);
-
-	return bCommon;
-}
-VOID
-halbtc8821aCsr2ant_TdmaDurationAdjust(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN			bScoHid,
-	IN	BOOLEAN			bTxPause,
-	IN	u1Byte			maxInterval
-	)
-{
-	static s4Byte		up,dn,m,n,WaitCount;
-	s4Byte			result;   //0: no change, +1: increase WiFi duration, -1: decrease WiFi duration
-	u1Byte			retryCount=0;
-
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-	if(pCoexDm->bResetTdmaAdjust)
-	{
-		pCoexDm->bResetTdmaAdjust = FALSE;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-		{
-			if(bScoHid)
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;	
-					}
-					else
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-			else
-			{
-				if(bTxPause)
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-				}
-				else
-				{
-					if(maxInterval == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;	
-					}
-					else if(maxInterval == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;	
-					}
-					else if(maxInterval == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->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 = pCoexSta->btRetryCnt;
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], up=%d, dn=%d, m=%d, n=%d, WaitCount=%d\n", 
-			up, dn, m, n, WaitCount));
-		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 連續 n 個2秒 retry count為0, 則調寬WiFi duration
-			{
-				WaitCount = 0; 
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1; 
-				RT_TRACE(COMP_COEX, DBG_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 連續 2 個2秒 retry count< 3, 則調窄WiFi duration
-			{
-				if (WaitCount <= 2)
-					m++; // 避免一直在兩個level中來回
-				else
-					m = 1;
-
-				if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-					m = 20;
-
-				n = 3*m;
-				up = 0;
-				dn = 0;
-				WaitCount = 0;
-				result = -1; 
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-			}
-		}
-		else  //retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration
-		{
-			if (WaitCount == 1)
-				m++; // 避免一直在兩個level中來回
-			else
-				m = 1;
-
-			if ( m >= 20) //m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration.
-				m = 20;
-
-			n = 3*m;
-			up = 0;
-			dn = 0;
-			WaitCount = 0; 
-			result = -1;
-			RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-		}
-
-		RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-		if(maxInterval == 1)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-
-				if(pCoexDm->curPsTdma == 71)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-					pCoexDm->psTdmaDuAdjType = 5;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-					pCoexDm->psTdmaDuAdjType = 13;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				
-				if(result == -1)
-				{					
-					if(pCoexDm->curPsTdma == 5)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-						pCoexDm->psTdmaDuAdjType = 5;
-					}
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-						pCoexDm->psTdmaDuAdjType = 13;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-					pCoexDm->psTdmaDuAdjType = 71;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-					pCoexDm->psTdmaDuAdjType = 9;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 71)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-						pCoexDm->psTdmaDuAdjType = 1;
-					}
-					else if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 71);
-						pCoexDm->psTdmaDuAdjType = 71;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-						pCoexDm->psTdmaDuAdjType = 9;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 2)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-					pCoexDm->psTdmaDuAdjType = 6;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-					pCoexDm->psTdmaDuAdjType = 14;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 6);
-						pCoexDm->psTdmaDuAdjType = 6;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-						pCoexDm->psTdmaDuAdjType = 14;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-					pCoexDm->psTdmaDuAdjType = 2;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-					pCoexDm->psTdmaDuAdjType = 10;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 2);
-						pCoexDm->psTdmaDuAdjType = 2;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-						pCoexDm->psTdmaDuAdjType = 10;
-					}
-				}
-			}
-		}
-		else if(maxInterval == 3)
-		{
-			if(bTxPause)
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 1\n"));
-				if(pCoexDm->curPsTdma == 1)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 2)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 3)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-					pCoexDm->psTdmaDuAdjType = 7;
-				}
-				else if(pCoexDm->curPsTdma == 4)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-					pCoexDm->psTdmaDuAdjType = 8;
-				}
-				if(pCoexDm->curPsTdma == 9)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 10)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 11)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-					pCoexDm->psTdmaDuAdjType = 15;
-				}
-				else if(pCoexDm->curPsTdma == 12)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-					pCoexDm->psTdmaDuAdjType = 16;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 5) 
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 8);
-						pCoexDm->psTdmaDuAdjType = 8;
-					}
-					else if(pCoexDm->curPsTdma == 13)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 16);
-						pCoexDm->psTdmaDuAdjType = 16;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 8)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 7)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}
-					else if(pCoexDm->curPsTdma == 6)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 7);
-						pCoexDm->psTdmaDuAdjType = 7;
-					}					
-					else if(pCoexDm->curPsTdma == 16)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 15)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-					else if(pCoexDm->curPsTdma == 14)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 15);
-						pCoexDm->psTdmaDuAdjType = 15;
-					}
-				}
-			}
-			else
-			{
-				RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], TxPause = 0\n"));
-				if(pCoexDm->curPsTdma == 5)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 6)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 7)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-					pCoexDm->psTdmaDuAdjType = 3;
-				}
-				else if(pCoexDm->curPsTdma == 8)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-					pCoexDm->psTdmaDuAdjType = 4;
-				}
-				if(pCoexDm->curPsTdma == 13)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 14)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 15)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-					pCoexDm->psTdmaDuAdjType = 11;
-				}
-				else if(pCoexDm->curPsTdma == 16)
-				{
-					halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-					pCoexDm->psTdmaDuAdjType = 12;
-				}
-				if(result == -1)
-				{
-					if(pCoexDm->curPsTdma == 1)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 4);
-						pCoexDm->psTdmaDuAdjType = 4;
-					}
-					else if(pCoexDm->curPsTdma == 9)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 12);
-						pCoexDm->psTdmaDuAdjType = 12;
-					}
-				} 
-				else if (result == 1)
-				{
-					if(pCoexDm->curPsTdma == 4)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 3)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 2)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 3);
-						pCoexDm->psTdmaDuAdjType = 3;
-					}
-					else if(pCoexDm->curPsTdma == 12)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 11)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-					else if(pCoexDm->curPsTdma == 10)
-					{
-						halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 11);
-						pCoexDm->psTdmaDuAdjType = 11;
-					}
-				}
-			}
-		}
-	}
-
-	// 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(pCoexDm->curPsTdma != pCoexDm->psTdmaDuAdjType)
-	{
-		BOOLEAN	bScan=FALSE, bLink=FALSE, bRoam=FALSE;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 
-			pCoexDm->curPsTdma, pCoexDm->psTdmaDuAdjType));
-
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-		
-		if( !bScan && !bLink && !bRoam)
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, pCoexDm->psTdmaDuAdjType);
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-		}
-	}
-
-	// when halbtc8821aCsr2ant_TdmaDurationAdjust() is called, fw dac swing is included in the function.
-	//if(pCoexDm->psTdmaDuAdjType == 71)
-	//	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0xc); //Skip because A2DP get worse at HT40
-	//else
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 0x6);
-}
-
-// SCO only or SCO+PAN(HS)
-VOID
-halbtc8821aCsr2ant_ActionSco(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState,btRssiState;
-	u4Byte	wifiBw;
-
-	halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55555555, 0x55555555, 0xffffff, 0x3);
-	halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0);
-
-	halbtc8821aCsr2ant_LowPenaltyRa(pBtCoexist, NORMAL_EXEC, TRUE);
-
-	halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 1, 0, 2, 0);
-
-	if(pCoexSta->bSlave == FALSE)
-		halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x4);
-	else
-		halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x2);
-
-/*
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 4);
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-	
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for SCO quality at 11b/g mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x5a5a5a5a, 0x5a5a5a5a, 0xffff, 0x3);
-	}
-	else  //for SCO quality & wifi performance balance at 11n mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x5aea5aea, 0x5aea5aea, 0xffff, 0x3);
-	}
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-	
-		// fw mechanism
-		//halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); //for voice quality
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); //for voice quality
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);			
-		}
-		else
-		{
-			halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);	
-		}		
-	}
-	else
-	{
-		// fw mechanism
-		//halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); //for voice quality
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 0); //for voice quality
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-*/
-}
-
-
-VOID
-halbtc8821aCsr2ant_ActionHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte	wifiRssiState, btRssiState;	
-	u4Byte	wifiBw;
-
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5a5a5a5a, 0xffff, 0x3);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5aea5aea, 0xffff, 0x3);
-	}
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}	
-	}
-	else
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 9);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 13);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
- 			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-//A2DP only / PAN(EDR) only/ A2DP+PAN(HS)
-VOID
-halbtc8821aCsr2ant_ActionA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState;
-	u4Byte		wifiBw;
-
-	halbtc8821aCsr2ant_LimitedRx(pBtCoexist, NORMAL_EXEC, FALSE, TRUE, 0x8);
-
-	if(pCoexSta->bSlave == FALSE)
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0xfdfdfdfd, 0xdfdadfda, 0xffffff, 0x3);
-		halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 22);
-		halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0, 1);
-		halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x0c);
-	}
-	else
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0xfdfdfdfd, 0xdfdadfda, 0xffffff, 0x3);
-		halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 23);
-		halbtc8821aCsr2ant_LimitedTx(pBtCoexist, NORMAL_EXEC, 0, 0, 0, 0, 2);
-		halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,TRUE,0x18);
-	}
-
-/*
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	//fw dac swing is called in halbtc8821aCsr2ant_TdmaDurationAdjust()
-	//halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-	
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 1);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-*/
-}
-
-VOID
-halbtc8821aCsr2ant_ActionA2dpPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2,35, 0);
-
-	//fw dac swing is called in halbtc8821aCsr2ant_TdmaDurationAdjust()
-	//halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if(btInfoExt&BIT0)	//a2dp basic rate
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 2);
-		}
-		else				//a2dp edr rate
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
- 			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		// fw mechanism
-		if(btInfoExt&BIT0)	//a2dp basic rate
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 2);
-		}
-		else				//a2dp edr rate
-		{
-			halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 1);
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}		
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_ActionPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5aff5aff, 0xffff, 0x3);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5aff5aff, 0xffff, 0x3);
-	}
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 1);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 5);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-
-//PAN(HS) only
-VOID
-halbtc8821aCsr2ant_ActionPanHs(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-		}
-		halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		// fw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-		}
-
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, FALSE, 1);
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-//PAN(EDR)+A2DP
-VOID
-halbtc8821aCsr2ant_ActionPanEdrA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5afa5afa, 0xffff, 0x3);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5afa5afa, 0xffff, 0x3);
-	}
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-			}
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		};
-	}
-	else
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, FALSE, 3);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, FALSE, TRUE, 3);
-			}
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,FALSE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_ActionPanEdrHid(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState;
-	u4Byte		wifiBw;
-
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5a5f5a5f, 0xffff, 0x3);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5a5f5a5f, 0xffff, 0x3);
-	}
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{ 
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 3);
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10); 
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14); 
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 10);
-		}
-		else
-		{
-			halbtc8821aCsr2ant_PsTdma(pBtCoexist, NORMAL_EXEC, TRUE, 14);
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-// HID+A2DP+PAN(EDR)
-VOID
-halbtc8821aCsr2ant_ActionHidA2dpPanEdr(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	halbtc8821aCsr2ant_FwDacSwingLvl(pBtCoexist, NORMAL_EXEC, 6);
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5a5a5a5a, 0xffff, 0x3);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5a5a5a5a, 0xffff, 0x3);
-	}
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 3);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 3);
-			}
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_ActionHidA2dp(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	u1Byte		wifiRssiState, btRssiState, btInfoExt;
-	u4Byte		wifiBw;
-
-	btInfoExt = pCoexSta->btInfoExt;
-	wifiRssiState = halbtc8821aCsr2ant_WifiRssiState(pBtCoexist, 0, 2, 15, 0);
-	btRssiState = halbtc8821aCsr2ant_BtRssiState(2, 35, 0);
-
-	if(halbtc8821aCsr2ant_NeedToDecBtPwr(pBtCoexist))
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, TRUE);
-	else	
-		halbtc8821aCsr2ant_DecBtPwr(pBtCoexist, NORMAL_EXEC, FALSE);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-
-	if (BTC_WIFI_BW_LEGACY == wifiBw) //for HID at 11b/g mode
-	{
-//Allen		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5a5a5a5a, 0xffff, 0x3);
-		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5f5b5f5b, 0xffffff, 0x3);
-	}
-	else  //for HID quality & wifi performance balance at 11n mode
-	{
-//Allen		halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5a5a5a5a, 0xffff, 0x3);
-			halbtc8821aCsr2ant_CoexTable(pBtCoexist, NORMAL_EXEC, 0x55ff55ff, 0x5f5b5f5b, 0xffffff, 0x3);
-
-	}
-
-	if(BTC_WIFI_BW_HT40 == wifiBw)
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			}
-		}
-		
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,TRUE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-	else
-	{
-		// fw mechanism
-		if( (btRssiState == BTC_RSSI_STATE_HIGH) ||
-			(btRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-//				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 2);
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-
-			}
-			else				//a2dp edr rate
-			{
-//Allen				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, FALSE, 2);
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			}
-		}
-		else
-		{
-			if(btInfoExt&BIT0)	//a2dp basic rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			}
-			else				//a2dp edr rate
-			{
-				halbtc8821aCsr2ant_TdmaDurationAdjust(pBtCoexist, TRUE, TRUE, 2);
-			}
-		}
-
-		// sw mechanism
-		if( (wifiRssiState == BTC_RSSI_STATE_HIGH) ||
-			(wifiRssiState == BTC_RSSI_STATE_STAY_HIGH) )
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,TRUE,FALSE,FALSE,0x18);
-		}
-		else
-		{
-			 halbtc8821aCsr2ant_SwMechanism1(pBtCoexist,FALSE,TRUE,FALSE,FALSE);
-			 halbtc8821aCsr2ant_SwMechanism2(pBtCoexist,FALSE,FALSE,FALSE,0x18);
-		}
-	}
-}
-
-VOID
-halbtc8821aCsr2ant_RunCoexistMechanism(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	BOOLEAN				bWifiUnder5G=FALSE;
-	u1Byte				btInfoOriginal=0, btRetryCnt=0;
-	u1Byte				algorithm=0;
-
-	if(pBtCoexist->bManualControl)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Manual control!!!\n"));
-		return;
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-
-	if(bWifiUnder5G)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], RunCoexistMechanism(), run 5G coex setting!!<===\n"));
-		halbtc8821aCsr2ant_CoexUnder5G(pBtCoexist);
-		return;
-	}
-
-	//if(pStackInfo->bProfileNotified)
-	{
-		algorithm = halbtc8821aCsr2ant_ActionAlgorithm(pBtCoexist);
-		if(pCoexSta->bC2hBtInquiryPage && (BT_8821A_CSR_2ANT_COEX_ALGO_PANHS!=algorithm))
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT is under inquiry/page scan !!\n"));
-			halbtc8821aCsr2ant_BtInquiryPage(pBtCoexist);
-			return;
-		}
-
-		pCoexDm->curAlgorithm = algorithm;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Algorithm = %d \n", pCoexDm->curAlgorithm));
-
-		if(halbtc8821aCsr2ant_IsCommonAction(pBtCoexist))
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant common.\n"));
-			pCoexDm->bResetTdmaAdjust = TRUE;
-		}
-		else
-		{
-			if(pCoexDm->curAlgorithm != pCoexDm->preAlgorithm)
-			{
-				RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 
-					pCoexDm->preAlgorithm, pCoexDm->curAlgorithm));
-				pCoexDm->bResetTdmaAdjust = TRUE;
-			}
-			switch(pCoexDm->curAlgorithm)
-			{
-				case BT_8821A_CSR_2ANT_COEX_ALGO_SCO:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = SCO.\n"));
-					halbtc8821aCsr2ant_ActionSco(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_HID:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID.\n"));
-					halbtc8821aCsr2ant_ActionHid(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_A2DP:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP.\n"));
-					halbtc8821aCsr2ant_ActionA2dp(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_A2DP_PANHS:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n"));
-					halbtc8821aCsr2ant_ActionA2dpPanHs(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n"));
-					halbtc8821aCsr2ant_ActionPanEdr(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_PANHS:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HS mode.\n"));
-					halbtc8821aCsr2ant_ActionPanHs(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_A2DP:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n"));
-					halbtc8821aCsr2ant_ActionPanEdrA2dp(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-					halbtc8821aCsr2ant_ActionPanEdrHid(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-					halbtc8821aCsr2ant_ActionHidA2dpPanEdr(pBtCoexist);
-					break;
-				case BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n"));
-					halbtc8821aCsr2ant_ActionHidA2dp(pBtCoexist);
-					break;
-				default:
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n"));
-					halbtc8821aCsr2ant_CoexAllOff(pBtCoexist);
-					break;
-			}
-			pCoexDm->preAlgorithm = pCoexDm->curAlgorithm;
-		}
-	}
-}
-
-
-
-//============================================================
-// work around function start with wa_halbtc8821aCsr2ant_
-//============================================================
-//============================================================
-// extern function start with EXhalbtc8821aCsr2ant_
-//============================================================
-VOID
-EXhalbtc8821aCsr2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-}
-
-VOID
-EXhalbtc8821aCsr2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	u4Byte	u4Tmp=0;
-	u2Byte				u2Tmp=0;
-	u1Byte	u1Tmp=0;
-	u1Byte				H2C_Parameter[2] ={0};
-		
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], 2Ant Init HW Config!!\n"));
-
-	if(bWifiOnly)
-		return;
-	
-	//if(bBackUp)
-	{
-		// backup rf 0x1e value
-		pCoexDm->btRf0x1eBackup = pBtCoexist->fBtcGetRfReg(pBtCoexist, BTC_RF_A, 0x1e, 0xfffff);
-		pCoexDm->backupArfrCnt1 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x430);
-		pCoexDm->backupArfrCnt2 = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x434);
-		pCoexDm->backupRetryLimit = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x42a);
-		pCoexDm->backupAmpduMaxTime = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x456);
-		pCoexDm->backupAmpduMaxNum = pBtCoexist->fBtcRead2Byte(pBtCoexist, 0x4ca);
-	}
-
-	#if 0 /* REMOVE */
-	// 0x790[5:0]=0x5
-	u1Tmp = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x790);
-	u1Tmp &= 0xc0;
-	u1Tmp |= 0x5;
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x790, u1Tmp);
-	#endif
-	
-	//Antenna config
-	halbtc8821aCsr2ant_SetAntPath(pBtCoexist, BTC_ANT_WIFI_AT_MAIN, TRUE, FALSE);
-
-	// PTA parameter
-	halbtc8821aCsr2ant_CoexTable(pBtCoexist, FORCE_EXEC, 0x55555555, 0x55555555, 0xffff, 0x3);
-	
-	// Enable counter statistics
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x76e, 0xc); //0x76e[3] =1, WLAN_Act control by PTA
-	pBtCoexist->fBtcWrite1Byte(pBtCoexist, 0x778, 0x3);
-
-	#if 0 /* REMOVE */
-	pBtCoexist->fBtcWrite1ByteBitMask(pBtCoexist, 0x40, 0x20, 0x1);
-	#endif
-}
-
-VOID
-EXhalbtc8821aCsr2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Coex Mechanism Init!!\n"));
-	
-	halbtc8821aCsr2ant_InitCoexDm(pBtCoexist);
-}
-
-VOID
-EXhalbtc8821aCsr2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	)
-{
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-	pu1Byte				cliBuf=pBtCoexist->cliBuf;
-	u1Byte				u1Tmp[4], i, btInfoExt, psTdmaCase=0;
-	u4Byte				u4Tmp[4];
-	u4Byte				fwVer=0, btPatchVer=0;
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "Ant PG number/ Ant mechanism:", \
-		pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum);
-	CL_PRINTF(cliBuf);	
-	
-	if(pBtCoexist->bManualControl)
-	{
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "[Action Manual control]!!");
-		CL_PRINTF(cliBuf);
-	}
-	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-		((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d_%d/ 0x%x/ 0x%x(%d)", "CoexVer/ FwVer/ PatchVer", \
-		GLCoexVerDate8821aCsr2Ant, GLCoexVer8821aCsr2Ant, fwVer, btPatchVer, btPatchVer);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ", "Wifi channel informed to BT", \
-		pCoexDm->wifiChnlInfo[0], pCoexDm->wifiChnlInfo[1],
-		pCoexDm->wifiChnlInfo[2]);
-	CL_PRINTF(cliBuf);
-
-	// wifi status
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Wifi Status]============");
-	CL_PRINTF(cliBuf);
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[BT Status]============");
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ", "BT [status/ rssi/ retryCnt]", \
-		((pCoexSta->bC2hBtInquiryPage)?("inquiry/page scan"):((BT_8821A_CSR_2ANT_BT_STATUS_IDLE == pCoexDm->btStatus)? "idle":(  (BT_8821A_CSR_2ANT_BT_STATUS_CONNECTED_IDLE == pCoexDm->btStatus)? "connected-idle":"busy"))),
-		pCoexSta->btRssi, pCoexSta->btRetryCnt);
-	CL_PRINTF(cliBuf);
-	
-	if(pStackInfo->bProfileNotified)
-	{			
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP", \
-			pStackInfo->bScoExist, pStackInfo->bHidExist, pStackInfo->bPanExist, pStackInfo->bA2dpExist);
-		CL_PRINTF(cliBuf);	
-
-		pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_BT_LINK_INFO);
-	}
-
-	btInfoExt = pCoexSta->btInfoExt;
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Info A2DP rate", \
-		(btInfoExt&BIT0)? "Basic rate":"EDR rate");
-	CL_PRINTF(cliBuf);	
-
-	for(i=0; i<BT_INFO_SRC_8821A_CSR_2ANT_MAX; i++)
-	{
-		if(pCoexSta->btInfoC2hCnt[i])
-		{				
-			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)", GLBtInfoSrc8821aCsr2Ant[i], \
-				pCoexSta->btInfoC2h[i][0], pCoexSta->btInfoC2h[i][1],
-				pCoexSta->btInfoC2h[i][2], pCoexSta->btInfoC2h[i][3],
-				pCoexSta->btInfoC2h[i][4], pCoexSta->btInfoC2h[i][5],
-				pCoexSta->btInfoC2h[i][6], pCoexSta->btInfoC2hCnt[i]);
-			CL_PRINTF(cliBuf);
-		}
-	}
-
-	// Sw mechanism	
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw mechanism]============");
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "SM1[ShRf/ LpRA/ LimDig]", \
-		pCoexDm->bCurRfRxLpfShrink, pCoexDm->bCurLowPenaltyRa, pCoexDm->bLimitedDig);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ", "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", \
-		pCoexDm->bCurAgcTableEn, pCoexDm->bCurAdcBackOff, pCoexDm->bCurDacSwingOn, pCoexDm->curDacSwingLvl);
-	CL_PRINTF(cliBuf);
-
-	// Fw mechanism		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw mechanism]============");
-	CL_PRINTF(cliBuf);	
-	
-	if(!pBtCoexist->bManualControl)
-	{
-		psTdmaCase = pCoexDm->curPsTdma;
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x case-%d", "PS TDMA", \
-			pCoexDm->psTdmaPara[0], pCoexDm->psTdmaPara[1],
-			pCoexDm->psTdmaPara[2], pCoexDm->psTdmaPara[3],
-			pCoexDm->psTdmaPara[4], psTdmaCase);
-		CL_PRINTF(cliBuf);
-	
-		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ", "DecBtPwr/ IgnWlanAct", \
-			pCoexDm->bCurDecBtPwr, pCoexDm->bCurIgnoreWlanAct);
-		CL_PRINTF(cliBuf);
-	}
-
-	// Hw setting		
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw setting]============");
-	CL_PRINTF(cliBuf);	
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "RF-A, 0x1e initVal", \
-		pCoexDm->btRf0x1eBackup);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x778);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x6cc);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x ", "0x778 (W_Act)/ 0x6cc (CoTab Sel)", \
-		u1Tmp[0], u1Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x8db);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xc5b);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x8db(ADC)/0xc5b[29:25](DAC)", \
-		((u1Tmp[0]&0x60)>>5), ((u1Tmp[1]&0x3e)>>1));
-	CL_PRINTF(cliBuf); 
-	
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xcb4);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xcb4[7:0](ctrl)/ 0xcb4[29:28](val)", \
-		u4Tmp[0]&0xff, ((u4Tmp[0]&0x30000000)>>28));
-	CL_PRINTF(cliBuf);
-
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x40);
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x4c);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x974);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x40/ 0x4c[24:23]/ 0x974", \
-		u1Tmp[0], ((u4Tmp[0]&0x01800000)>>23), u4Tmp[1]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x550);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0x522);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x550(bcn ctrl)/0x522", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xc50);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa0a);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0xc50(DIG)/0xa0a(CCK-TH)", \
-		u4Tmp[0], u1Tmp[0]);
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0xf48);
-	u1Tmp[0] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5b);
-	u1Tmp[1] = pBtCoexist->fBtcRead1Byte(pBtCoexist, 0xa5c);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "OFDM-FA/ CCK-FA", \
-		u4Tmp[0], (u1Tmp[0]<<8) + u1Tmp[1]  );
-	CL_PRINTF(cliBuf);
-
-	u4Tmp[0] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c0);
-	u4Tmp[1] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c4);
-	u4Tmp[2] = pBtCoexist->fBtcRead4Byte(pBtCoexist, 0x6c8);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x6c0/0x6c4/0x6c8", \
-		u4Tmp[0], u4Tmp[1], u4Tmp[2]);
-	CL_PRINTF(cliBuf);
-
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x770 (hi-pri Rx/Tx)", \
-		pCoexSta->highPriorityRx, pCoexSta->highPriorityTx);
-	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "0x774(low-pri Rx/Tx)", \
-		pCoexSta->lowPriorityRx, pCoexSta->lowPriorityTx);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcDispDbgMsg(pBtCoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-VOID
-EXhalbtc8821aCsr2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_IPS_ENTER == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS ENTER notify\n"));
-		pCoexSta->bUnderIps = TRUE;
-		halbtc8821aCsr2ant_CoexAllOff(pBtCoexist);
-	}
-	else if(BTC_IPS_LEAVE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], IPS LEAVE notify\n"));
-		pCoexSta->bUnderIps = FALSE;
-		//halbtc8821aCsr2ant_InitCoexDm(pBtCoexist);
-	}
-}
-
-VOID
-EXhalbtc8821aCsr2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_LPS_ENABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS ENABLE notify\n"));
-		pCoexSta->bUnderLps = TRUE;
-	}
-	else if(BTC_LPS_DISABLE == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], LPS DISABLE notify\n"));
-		pCoexSta->bUnderLps = FALSE;
-	}
-}
-
-VOID
-EXhalbtc8821aCsr2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_SCAN_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN START notify\n"));
-	}
-	else if(BTC_SCAN_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], SCAN FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8821aCsr2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	)
-{
-	if(BTC_ASSOCIATE_START == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT START notify\n"));
-	}
-	else if(BTC_ASSOCIATE_FINISH == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CONNECT FINISH notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8821aCsr2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	u1Byte			H2C_Parameter[3] ={0};
-	u4Byte			wifiBw;
-	u1Byte			wifiCentralChnl;
-
-	if(BTC_MEDIA_CONNECT == type)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA connect notify\n"));
-	}
-	else
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], MEDIA disconnect notify\n"));
-	}
-
-	// only 2.4G we need to inform bt the chnl mask
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifiCentralChnl);
-	if( (BTC_MEDIA_CONNECT == type) &&
-		(wifiCentralChnl <= 14) )
-	{
-		H2C_Parameter[0] = 0x1;
-		H2C_Parameter[1] = wifiCentralChnl;
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-		if(BTC_WIFI_BW_HT40 == wifiBw)
-			H2C_Parameter[2] = 0x30;
-		else
-			H2C_Parameter[2] = 0x20;
-	}
-
-	#if 0 /* REMOVE */	
-	pCoexDm->wifiChnlInfo[0] = H2C_Parameter[0];
-	pCoexDm->wifiChnlInfo[1] = H2C_Parameter[1];
-	pCoexDm->wifiChnlInfo[2] = H2C_Parameter[2];
-	
-	RT_TRACE(COMP_COEX, DBG_TRACE, ("[BTCoex], FW write 0x66=0x%x\n", 
-		H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-	rtw_warn_on(_BTCOEX_CSR);
-	pBtCoexist->fBtcFillH2c(pBtCoexist, 0x66, 3, H2C_Parameter);
-	#endif
-}
-
-VOID
-EXhalbtc8821aCsr2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	)
-{
-	if(type == BTC_PACKET_DHCP)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], DHCP Packet notify\n"));
-	}
-}
-
-VOID
-EXhalbtc8821aCsr2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	)
-{
-	u1Byte			btInfo=0;
-	u1Byte			i, rspSource=0;
-	BOOLEAN			bBtBusy=FALSE, bLimitedDig=FALSE;
-	BOOLEAN			bWifiConnected=FALSE, bBtHsOn=FALSE, bWifiUnder5G=FALSE;
-
-	pCoexSta->bC2hBtInfoReqSent = FALSE;
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &bWifiUnder5G);
-
-	rspSource = tmpBuf[0]&0xf;
-	if(rspSource >= BT_INFO_SRC_8821A_CSR_2ANT_MAX)
-		rspSource = BT_INFO_SRC_8821A_CSR_2ANT_WIFI_FW;
-	pCoexSta->btInfoC2hCnt[rspSource]++;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Bt info[%d], length=%d, hex data=[", rspSource, length));
-	for(i=0; i<length; i++)
-	{
-		pCoexSta->btInfoC2h[rspSource][i] = tmpBuf[i];
-		if(i == 1)
-			btInfo = tmpBuf[i];
-		if(i == length-1)
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x]\n", tmpBuf[i]));
-		}
-		else
-		{
-			RT_TRACE(COMP_COEX, DBG_LOUD, ("0x%02x, ", tmpBuf[i]));
-		}
-	}
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_CONNECTED, &bWifiConnected);
-	if(BT_INFO_SRC_8821A_CSR_2ANT_WIFI_FW != rspSource)
-	{
-		pCoexSta->btRetryCnt =	// [3:0]
-			pCoexSta->btInfoC2h[rspSource][2]&0xf;
-
-		pCoexSta->btRssi =
-			pCoexSta->btInfoC2h[rspSource][3]*2+10;
-
-		pCoexSta->btInfoExt = 
-			pCoexSta->btInfoC2h[rspSource][4];
-
-		#if 0 /* REMOVE */
-		// Here we need to resend some wifi info to BT
-		// because bt is reset and loss of the info.
-		if( (pCoexSta->btInfoExt & BIT1) )
-		{			
-			
-			if(bWifiConnected)
-			{
-				EXhalbtc8821aCsr2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_CONNECT);
-			}
-			else
-			{
-				EXhalbtc8821aCsr2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-			}
-		}
-		#endif
-
-		#if 0 /* REMOVE */
-		if(!pBtCoexist->bManualControl && !bWifiUnder5G)
-		{
-			if( (pCoexSta->btInfoExt&BIT3) )
-			{
-				if(bWifiConnected)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"));
-					halbtc8821aCsr2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, FALSE);
-				}
-			}
-			else
-			{
-				// BT already NOT ignore Wlan active, do nothing here.
-				if(!bWifiConnected)
-				{
-					RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT ext info bit3 check, set BT to ignore Wlan active!!\n"));
-					halbtc8821aCsr2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-				}
-			}
-		}
-		#endif
-
-		#if 0 /* REMOVE */
-		if( (pCoexSta->btInfoExt & BIT4) )
-		{
-			// BT auto report already enabled, do nothing
-		}
-		else
-		{
-			halbtc8821aCsr2ant_BtAutoReport(pBtCoexist, FORCE_EXEC, TRUE);
-		}
-		#endif
-	}
-		
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-
-	if(btInfo == BT_INFO_8821A_CSR_2ANT_B_CONNECTION)	// connection exists but no busy
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-		pCoexDm->btStatus = BT_8821A_CSR_2ANT_BT_STATUS_CONNECTED_IDLE;
-	}
-	else if(btInfo & BT_INFO_8821A_CSR_2ANT_B_CONNECTION)	// connection exists and some link is busy
-	{
-		pCoexSta->bBtLinkExist = TRUE;
-
-		if(btInfo & BT_INFO_8821A_CSR_2ANT_B_FTP)
-			pCoexSta->bPanExist = TRUE;
-		else
-			pCoexSta->bPanExist = FALSE;
-
-		if(btInfo & BT_INFO_8821A_CSR_2ANT_B_A2DP)
-			pCoexSta->bA2dpExist = TRUE;
-		else
-			pCoexSta->bA2dpExist = FALSE;
-
-		if(btInfo & BT_INFO_8821A_CSR_2ANT_B_HID)
-			pCoexSta->bHidExist = TRUE;
-		else
-			pCoexSta->bHidExist = FALSE;
-
-		if(btInfo & BT_INFO_8821A_CSR_2ANT_B_SCO_ESCO)
-			pCoexSta->bScoExist = TRUE;
-		else
-			pCoexSta->bScoExist = FALSE;
-
-		if (pCoexSta->btInfoExt & 0x80)
-			pCoexSta->bSlave = TRUE; //Slave
-		else
-			pCoexSta->bSlave = FALSE; //Master
-
-		pCoexDm->btStatus = BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE;
-	}
-	else
-	{
-		pCoexSta->bBtLinkExist = FALSE;
-		pCoexSta->bPanExist = FALSE;
-		pCoexSta->bA2dpExist = FALSE;
-		pCoexSta->bSlave = FALSE;
-		pCoexSta->bHidExist = FALSE;
-		pCoexSta->bScoExist = FALSE;
-		pCoexDm->btStatus = BT_8821A_CSR_2ANT_BT_STATUS_IDLE;
-	}
-
-	if(bBtHsOn)
-	{
-		pCoexDm->btStatus = BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE;
-	}
-
-	if(btInfo & BT_INFO_8821A_CSR_2ANT_B_INQ_PAGE)
-	{
-		pCoexSta->bC2hBtInquiryPage = TRUE;
-		pCoexDm->btStatus = BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE;
-	} 
-	else
-	{
-		pCoexSta->bC2hBtInquiryPage = FALSE;
-	}
-
-
-	if(BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE == pCoexDm->btStatus)
-	{
-		bBtBusy = TRUE;
-	}
-	else
-	{
-		bBtBusy = FALSE;
-	}
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bBtBusy);
-
-	if(BT_8821A_CSR_2ANT_BT_STATUS_IDLE != pCoexDm->btStatus)
-	{
-		bLimitedDig = TRUE;
-	}
-	else
-	{
-		bLimitedDig = FALSE;
-	}
-	pCoexDm->bLimitedDig = bLimitedDig;
-	pBtCoexist->fBtcSet(pBtCoexist, BTC_SET_BL_BT_LIMITED_DIG, &bLimitedDig);
-
-	halbtc8821aCsr2ant_RunCoexistMechanism(pBtCoexist);
-}
-
-VOID
-EXhalbtc8821aCsr2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Halt notify\n"));
-
-	halbtc8821aCsr2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	EXhalbtc8821aCsr2ant_MediaStatusNotify(pBtCoexist, BTC_MEDIA_DISCONNECT);
-}
-
-VOID
-EXhalbtc8821aCsr2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	)
-{
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify\n"));
-
-	if(BTC_WIFI_PNP_SLEEP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to SLEEP\n"));
-		halbtc8821aCsr2ant_IgnoreWlanAct(pBtCoexist, FORCE_EXEC, TRUE);
-	}
-	else if(BTC_WIFI_PNP_WAKE_UP == pnpState)
-	{
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Pnp notify to WAKE UP\n"));
-	}
-}
-
-VOID
-EXhalbtc8821aCsr2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	)
-{
-	static u1Byte		disVerInfoCnt=0;
-	u4Byte				fwVer=0, btPatchVer=0;
-	PBTC_BOARD_INFO		pBoardInfo=&pBtCoexist->boardInfo;
-	PBTC_STACK_INFO		pStackInfo=&pBtCoexist->stackInfo;
-
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ==========================Periodical===========================\n"));
-
-	if(disVerInfoCnt <= 5)
-	{
-		disVerInfoCnt += 1;
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			pBoardInfo->pgAntNum, pBoardInfo->btdmAntNum, pBoardInfo->btdmAntPos));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			((pStackInfo->bProfileNotified)? "Yes":"No"), pStackInfo->hciVersion));
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_BT_PATCH_VER, &btPatchVer);
-		pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_FW_VER, &fwVer);
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			GLCoexVerDate8821aCsr2Ant, GLCoexVer8821aCsr2Ant, fwVer, btPatchVer, btPatchVer));
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], ****************************************************************\n"));
-	}
-
-	//halbtc8821aCsr2ant_QueryBtInfo(pBtCoexist);
-	//halbtc8821aCsr2ant_RunCoexistMechanism(pBtCoexist);
-	halbtc8821aCsr2ant_MonitorBtCtr(pBtCoexist);
-	halbtc8821aCsr2ant_MonitorBtEnableDisable(pBtCoexist);
-}
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821aCsr2Ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821aCsr2Ant.h
deleted file mode 100644
index ef304b138c06..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtc8821aCsr2Ant.h
+++ /dev/null
@@ -1,208 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-//===========================================
-// The following is for 8821A_CSR 2Ant BT Co-exist definition
-//===========================================
-#define	BT_INFO_8821A_CSR_2ANT_B_FTP						BIT7
-#define	BT_INFO_8821A_CSR_2ANT_B_A2DP					BIT6
-#define	BT_INFO_8821A_CSR_2ANT_B_HID						BIT5
-#define	BT_INFO_8821A_CSR_2ANT_B_SCO_BUSY				BIT4
-#define	BT_INFO_8821A_CSR_2ANT_B_ACL_BUSY				BIT3
-#define	BT_INFO_8821A_CSR_2ANT_B_INQ_PAGE				BIT2
-#define	BT_INFO_8821A_CSR_2ANT_B_SCO_ESCO				BIT1
-#define	BT_INFO_8821A_CSR_2ANT_B_CONNECTION				BIT0
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT		2
-
-typedef enum _BT_INFO_SRC_8821A_CSR_2ANT{
-	BT_INFO_SRC_8821A_CSR_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8821A_CSR_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8821A_CSR_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8821A_CSR_2ANT_MAX
-}BT_INFO_SRC_8821A_CSR_2ANT,*PBT_INFO_SRC_8821A_CSR_2ANT;
-
-typedef enum _BT_8821A_CSR_2ANT_BT_STATUS{
-	BT_8821A_CSR_2ANT_BT_STATUS_IDLE				= 0x0,
-	BT_8821A_CSR_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,
-	BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE			= 0x2,
-	BT_8821A_CSR_2ANT_BT_STATUS_MAX
-}BT_8821A_CSR_2ANT_BT_STATUS,*PBT_8821A_CSR_2ANT_BT_STATUS;
-
-typedef enum _BT_8821A_CSR_2ANT_COEX_ALGO{
-	BT_8821A_CSR_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8821A_CSR_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8821A_CSR_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8821A_CSR_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8821A_CSR_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8821A_CSR_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8821A_CSR_2ANT_COEX_ALGO_MAX				= 0xb,
-}BT_8821A_CSR_2ANT_COEX_ALGO,*PBT_8821A_CSR_2ANT_COEX_ALGO;
-
-typedef struct _COEX_DM_8821A_CSR_2ANT{
-	// fw mechanism
-	BOOLEAN		bPreDecBtPwr;
-	BOOLEAN		bCurDecBtPwr;
-	u1Byte		preFwDacSwingLvl;
-	u1Byte		curFwDacSwingLvl;
-	BOOLEAN		bCurIgnoreWlanAct;
-	BOOLEAN		bPreIgnoreWlanAct;
-	u1Byte		prePsTdma;
-	u1Byte		curPsTdma;
-	u1Byte		psTdmaPara[6];
-	u1Byte		psTdmaDuAdjType;
-	BOOLEAN		bResetTdmaAdjust;
-	BOOLEAN		bPrePsTdmaOn;
-	BOOLEAN		bCurPsTdmaOn;
-	BOOLEAN		bPreBtAutoReport;
-	BOOLEAN		bCurBtAutoReport;
-
-	// sw mechanism
-	BOOLEAN		bPreRfRxLpfShrink;
-	BOOLEAN		bCurRfRxLpfShrink;
-	u4Byte		btRf0x1eBackup;
-	BOOLEAN 	bPreLowPenaltyRa;
-	BOOLEAN		bCurLowPenaltyRa;
-	BOOLEAN		bPreDacSwingOn;
-	u4Byte		preDacSwingLvl;
-	BOOLEAN		bCurDacSwingOn;
-	u4Byte		curDacSwingLvl;
-	BOOLEAN		bPreAdcBackOff;
-	BOOLEAN		bCurAdcBackOff;
-	BOOLEAN 	bPreAgcTableEn;
-	BOOLEAN		bCurAgcTableEn;
-	u4Byte		preVal0x6c0;
-	u4Byte		curVal0x6c0;
-	u4Byte		preVal0x6c4;
-	u4Byte		curVal0x6c4;
-	u4Byte		preVal0x6c8;
-	u4Byte		curVal0x6c8;
-	u1Byte		preVal0x6cc;
-	u1Byte		curVal0x6cc;
-	BOOLEAN		bLimitedDig;
-
-	u4Byte		preRaMask;
-	u4Byte		curRaMask;
-
-	u1Byte curAmpduNumType;
-	u1Byte preAmpduNumType;
-	u2Byte backupAmpduMaxNum;
-
-	u1Byte curAmpduTimeType;
-	u1Byte preAmpduTimeType;
-	u1Byte backupAmpduMaxTime;
-
-	u1Byte 		curArfrType;
-	u1Byte 		preArfrType;
-	u4Byte		backupArfrCnt1;
-	u4Byte		backupArfrCnt2;
-
-	u1Byte		curRetryLimitType;
-	u1Byte		preRetryLimitType;
-	u2Byte		backupRetryLimit;
-
-	// algorithm related
-	u1Byte		preAlgorithm;
-	u1Byte		curAlgorithm;
-	u1Byte		btStatus;
-	u1Byte		wifiChnlInfo[3];
-} COEX_DM_8821A_CSR_2ANT, *PCOEX_DM_8821A_CSR_2ANT;
-
-typedef struct _COEX_STA_8821A_CSR_2ANT{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bSlave;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bPanExist;
-
-	BOOLEAN					bUnderLps;
-	BOOLEAN					bUnderIps;
-	u4Byte					highPriorityTx;
-	u4Byte					highPriorityRx;
-	u4Byte					lowPriorityTx;
-	u4Byte					lowPriorityRx;
-	u1Byte					btRssi;
-	u1Byte					preBtRssiState;
-	u1Byte					preWifiRssiState[4];
-	BOOLEAN					bC2hBtInfoReqSent;
-	u1Byte					btInfoC2h[BT_INFO_SRC_8821A_CSR_2ANT_MAX][10];
-	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8821A_CSR_2ANT_MAX];
-	BOOLEAN					bC2hBtInquiryPage;
-	u1Byte					btRetryCnt;
-	u1Byte					btInfoExt;
-}COEX_STA_8821A_CSR_2ANT, *PCOEX_STA_8821A_CSR_2ANT;
-
-//===========================================
-// The following is interface which will notify coex module.
-//===========================================
-VOID
-EXhalbtc8821aCsr2ant_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8821aCsr2ant_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtc8821aCsr2ant_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtc8821aCsr2ant_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821aCsr2ant_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821aCsr2ant_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821aCsr2ant_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtc8821aCsr2ant_MediaStatusNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8821aCsr2ant_SpecialPacketNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				type
-	);
-VOID
-EXhalbtc8821aCsr2ant_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtc8821aCsr2ant_HaltNotify(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8821aCsr2ant_PnpNotify(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				pnpState
-	);
-VOID
-EXhalbtc8821aCsr2ant_Periodical(
-	IN	PBTC_COEXIST			pBtCoexist
-	);
-VOID
-EXhalbtc8821aCsr2ant_DisplayCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtcOutSrc.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtcOutSrc.h
deleted file mode 100644
index 13ea845260c2..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/HalBtcOutSrc.h
+++ /dev/null
@@ -1,748 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-#ifndef	__HALBTC_OUT_SRC_H__
-#define __HALBTC_OUT_SRC_H__
-
-#define		NORMAL_EXEC					FALSE
-#define		FORCE_EXEC						TRUE
-
-#define		BTC_RF_OFF					0x0
-#define		BTC_RF_ON					0x1
-
-#define		BTC_RF_A					0x0
-#define		BTC_RF_B					0x1
-#define		BTC_RF_C					0x2
-#define		BTC_RF_D					0x3
-
-#define		BTC_SMSP				SINGLEMAC_SINGLEPHY
-#define		BTC_DMDP				DUALMAC_DUALPHY
-#define		BTC_DMSP				DUALMAC_SINGLEPHY
-#define		BTC_MP_UNKNOWN		0xff
-
-#define		BT_COEX_ANT_TYPE_PG			0
-#define		BT_COEX_ANT_TYPE_ANTDIV		1
-#define		BT_COEX_ANT_TYPE_DETECTED	2
-
-#define		BTC_MIMO_PS_STATIC			0	// 1ss
-#define		BTC_MIMO_PS_DYNAMIC			1	// 2ss
-
-#define		BTC_RATE_DISABLE			0
-#define		BTC_RATE_ENABLE				1
-
-// single Antenna definition
-#define		BTC_ANT_PATH_WIFI			0
-#define		BTC_ANT_PATH_BT				1
-#define		BTC_ANT_PATH_PTA			2
-// dual Antenna definition
-#define		BTC_ANT_WIFI_AT_MAIN		0
-#define		BTC_ANT_WIFI_AT_AUX			1
-// coupler Antenna definition
-#define		BTC_ANT_WIFI_AT_CPL_MAIN	0
-#define		BTC_ANT_WIFI_AT_CPL_AUX		1
-
-typedef enum _BTC_POWERSAVE_TYPE{
-	BTC_PS_WIFI_NATIVE			= 0,	// wifi original power save behavior
-	BTC_PS_LPS_ON				= 1,
-	BTC_PS_LPS_OFF				= 2,
-	BTC_PS_MAX
-} BTC_POWERSAVE_TYPE, *PBTC_POWERSAVE_TYPE;
-
-typedef enum _BTC_BT_REG_TYPE{
-	BTC_BT_REG_RF						= 0,
-	BTC_BT_REG_MODEM					= 1,
-	BTC_BT_REG_BLUEWIZE					= 2,
-	BTC_BT_REG_VENDOR					= 3,
-	BTC_BT_REG_LE						= 4,
-	BTC_BT_REG_MAX
-} BTC_BT_REG_TYPE, *PBTC_BT_REG_TYPE;
-
-typedef enum _BTC_CHIP_INTERFACE{
-	BTC_INTF_UNKNOWN	= 0,
-	BTC_INTF_PCI			= 1,
-	BTC_INTF_USB			= 2,
-	BTC_INTF_SDIO		= 3,
-	BTC_INTF_MAX
-} BTC_CHIP_INTERFACE, *PBTC_CHIP_INTERFACE;
-
-typedef enum _BTC_CHIP_TYPE{
-	BTC_CHIP_UNDEF		= 0,
-	BTC_CHIP_CSR_BC4		= 1,
-	BTC_CHIP_CSR_BC8		= 2,
-	BTC_CHIP_RTL8723A 	= 3,
-	BTC_CHIP_RTL8821	= 4,
-	BTC_CHIP_RTL8723B 	= 5,
-	BTC_CHIP_MAX
-} BTC_CHIP_TYPE, *PBTC_CHIP_TYPE;
-
-// following is for wifi link status
-#define		WIFI_STA_CONNECTED				BIT0
-#define		WIFI_AP_CONNECTED				BIT1
-#define		WIFI_HS_CONNECTED				BIT2
-#define		WIFI_P2P_GO_CONNECTED			BIT3
-#define		WIFI_P2P_GC_CONNECTED			BIT4
-
-// following is for command line utility
-#define	CL_SPRINTF	rsprintf
-#define	CL_PRINTF	DCMD_Printf
-
-
-typedef struct _BTC_BOARD_INFO{
-	// The following is some board information
-	u1Byte				btChipType;
-	u1Byte				pgAntNum;	// pg ant number
-	u1Byte				btdmAntNum;	// ant number for btdm
-	u1Byte				btdmAntNumByAntDet;	// ant number for btdm after antenna detection
-	u1Byte				btdmAntPos;		//Bryant Add to indicate Antenna Position for (pgAntNum = 2) && (btdmAntNum =1)  (DPDT+1Ant case)
-	u1Byte				singleAntPath;	// current used for 8723b only, 1=>s0,  0=>s1
-	u1Byte				bTfbgaPackage;    //for Antenna detect threshold 
-	u1Byte				btdmAntDetFinish;
-	u1Byte				antType;
-} BTC_BOARD_INFO, *PBTC_BOARD_INFO;
-
-typedef enum _BTC_DBG_OPCODE{
-	BTC_DBG_SET_COEX_NORMAL				= 0x0,
-	BTC_DBG_SET_COEX_WIFI_ONLY				= 0x1,
-	BTC_DBG_SET_COEX_BT_ONLY				= 0x2,
-	BTC_DBG_SET_COEX_DEC_BT_PWR				= 0x3,
-	BTC_DBG_SET_COEX_BT_AFH_MAP				= 0x4,
-	BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT		= 0x5,
-	BTC_DBG_MAX
-}BTC_DBG_OPCODE,*PBTC_DBG_OPCODE;
-
-typedef enum _BTC_RSSI_STATE{
-	BTC_RSSI_STATE_HIGH						= 0x0,
-	BTC_RSSI_STATE_MEDIUM					= 0x1,
-	BTC_RSSI_STATE_LOW						= 0x2,
-	BTC_RSSI_STATE_STAY_HIGH					= 0x3,
-	BTC_RSSI_STATE_STAY_MEDIUM				= 0x4,
-	BTC_RSSI_STATE_STAY_LOW					= 0x5,
-	BTC_RSSI_MAX
-}BTC_RSSI_STATE,*PBTC_RSSI_STATE;
-#define	BTC_RSSI_HIGH(_rssi_)	((_rssi_==BTC_RSSI_STATE_HIGH||_rssi_==BTC_RSSI_STATE_STAY_HIGH)? TRUE:FALSE)
-#define	BTC_RSSI_MEDIUM(_rssi_)	((_rssi_==BTC_RSSI_STATE_MEDIUM||_rssi_==BTC_RSSI_STATE_STAY_MEDIUM)? TRUE:FALSE)
-#define	BTC_RSSI_LOW(_rssi_)	((_rssi_==BTC_RSSI_STATE_LOW||_rssi_==BTC_RSSI_STATE_STAY_LOW)? TRUE:FALSE)
-
-typedef enum _BTC_WIFI_ROLE{
-	BTC_ROLE_STATION						= 0x0,
-	BTC_ROLE_AP								= 0x1,
-	BTC_ROLE_IBSS							= 0x2,
-	BTC_ROLE_HS_MODE						= 0x3,
-	BTC_ROLE_MAX
-}BTC_WIFI_ROLE,*PBTC_WIFI_ROLE;
-
-typedef enum _BTC_WIRELESS_FREQ{
-	BTC_FREQ_2_4G					= 0x0,
-	BTC_FREQ_5G						= 0x1,
-	BTC_FREQ_MAX	
-}BTC_WIRELESS_FREQ,*PBTC_WIRELESS_FREQ;
-
-typedef enum _BTC_WIFI_BW_MODE{
-	BTC_WIFI_BW_LEGACY					= 0x0,
-	BTC_WIFI_BW_HT20					= 0x1,
-	BTC_WIFI_BW_HT40					= 0x2,
-	BTC_WIFI_BW_HT80					= 0x3,
-	BTC_WIFI_BW_HT160					= 0x4,
-	BTC_WIFI_BW_MAX	
-}BTC_WIFI_BW_MODE,*PBTC_WIFI_BW_MODE;
-
-typedef enum _BTC_WIFI_TRAFFIC_DIR{
-	BTC_WIFI_TRAFFIC_TX					= 0x0,
-	BTC_WIFI_TRAFFIC_RX					= 0x1,
-	BTC_WIFI_TRAFFIC_MAX	
-}BTC_WIFI_TRAFFIC_DIR,*PBTC_WIFI_TRAFFIC_DIR;
-
-typedef enum _BTC_WIFI_PNP{
-	BTC_WIFI_PNP_WAKE_UP					= 0x0,
-	BTC_WIFI_PNP_SLEEP						= 0x1,
-	BTC_WIFI_PNP_MAX
-}BTC_WIFI_PNP,*PBTC_WIFI_PNP;
-
-typedef enum _BTC_IOT_PEER
-{
-	BTC_IOT_PEER_UNKNOWN = 0,
-	BTC_IOT_PEER_REALTEK = 1,
-	BTC_IOT_PEER_REALTEK_92SE = 2,
-	BTC_IOT_PEER_BROADCOM = 3,
-	BTC_IOT_PEER_RALINK = 4,
-	BTC_IOT_PEER_ATHEROS = 5,
-	BTC_IOT_PEER_CISCO = 6,
-	BTC_IOT_PEER_MERU = 7,	
-	BTC_IOT_PEER_MARVELL = 8,
-	BTC_IOT_PEER_REALTEK_SOFTAP = 9,// peer is RealTek SOFT_AP, by Bohn, 2009.12.17
-	BTC_IOT_PEER_SELF_SOFTAP = 10, // Self is SoftAP
-	BTC_IOT_PEER_AIRGO = 11,
-	BTC_IOT_PEER_INTEL 				= 12, 
-	BTC_IOT_PEER_RTK_APCLIENT 		= 13, 
-	BTC_IOT_PEER_REALTEK_81XX 		= 14,	
-	BTC_IOT_PEER_REALTEK_WOW 		= 15,
-	BTC_IOT_PEER_REALTEK_JAGUAR_BCUTAP = 16,
-	BTC_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,
-	BTC_IOT_PEER_MAX,
-}BTC_IOT_PEER, *PBTC_IOT_PEER;
-
-//for 8723b-d cut large current issue
-typedef enum _BT_WIFI_COEX_STATE{
-	BTC_WIFI_STAT_INIT,
-	BTC_WIFI_STAT_IQK,
-	BTC_WIFI_STAT_NORMAL_OFF,
-	BTC_WIFI_STAT_MP_OFF,
-	BTC_WIFI_STAT_NORMAL,
-	BTC_WIFI_STAT_ANT_DIV,
-	BTC_WIFI_STAT_MAX
-}BT_WIFI_COEX_STATE,*PBT_WIFI_COEX_STATE;
-
-typedef enum _BT_ANT_TYPE{
-	BTC_ANT_TYPE_0,
-	BTC_ANT_TYPE_1,
-	BTC_ANT_TYPE_2,
-	BTC_ANT_TYPE_3,
-	BTC_ANT_TYPE_4,
-	BTC_ANT_TYPE_MAX
-}BT_ANT_TYPE,*PBT_ANT_TYPE;
-
-// defined for BFP_BTC_GET
-typedef enum _BTC_GET_TYPE{
-	// type BOOLEAN
-	BTC_GET_BL_HS_OPERATION,
-	BTC_GET_BL_HS_CONNECTING,
-	BTC_GET_BL_WIFI_CONNECTED,
-	BTC_GET_BL_WIFI_BUSY,
-	BTC_GET_BL_WIFI_SCAN,
-	BTC_GET_BL_WIFI_LINK,
-	BTC_GET_BL_WIFI_ROAM,
-	BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-	BTC_GET_BL_WIFI_UNDER_5G,
-	BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-	BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,
-	BTC_GET_BL_WIFI_UNDER_B_MODE,
-	BTC_GET_BL_EXT_SWITCH,
-	BTC_GET_BL_WIFI_IS_IN_MP_MODE,
-	BTC_GET_BL_IS_ASUS_8723B,
-
-	// type s4Byte
-	BTC_GET_S4_WIFI_RSSI,
-	BTC_GET_S4_HS_RSSI,
-	
-	// type u4Byte
-	BTC_GET_U4_WIFI_BW,
-	BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
-	BTC_GET_U4_WIFI_FW_VER,
-	BTC_GET_U4_WIFI_LINK_STATUS,
-	BTC_GET_U4_BT_PATCH_VER,
-
-	// type u1Byte
-	BTC_GET_U1_WIFI_DOT11_CHNL,
-	BTC_GET_U1_WIFI_CENTRAL_CHNL,
-	BTC_GET_U1_WIFI_HS_CHNL,
-	BTC_GET_U1_MAC_PHY_MODE,
-	BTC_GET_U1_AP_NUM,
-	BTC_GET_U1_ANT_TYPE,
-	BTC_GET_U1_IOT_PEER,
-
-	//===== for 1Ant ======
-	BTC_GET_U1_LPS_MODE,
-
-	BTC_GET_MAX
-}BTC_GET_TYPE,*PBTC_GET_TYPE;
-
-// defined for BFP_BTC_SET
-typedef enum _BTC_SET_TYPE{
-	// type BOOLEAN
-	BTC_SET_BL_BT_DISABLE,
-	BTC_SET_BL_BT_TRAFFIC_BUSY,
-	BTC_SET_BL_BT_LIMITED_DIG,
-	BTC_SET_BL_FORCE_TO_ROAM,
-	BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-	BTC_SET_BL_BT_CTRL_AGG_SIZE,
-	BTC_SET_BL_INC_SCAN_DEV_NUM,
-	BTC_SET_BL_BT_TX_RX_MASK,
-	BTC_SET_BL_MIRACAST_PLUS_BT,
-
-	// type u1Byte
-	BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
-	BTC_SET_U1_AGG_BUF_SIZE,
-
-	// type trigger some action
-	BTC_SET_ACT_GET_BT_RSSI,
-	BTC_SET_ACT_AGGREGATE_CTRL,
-	//===== for 1Ant ======
-	// type BOOLEAN
-
-	// type u1Byte
-	BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,
-	BTC_SET_U1_LPS_VAL,
-	BTC_SET_U1_RPWM_VAL,
-	// type trigger some action
-	BTC_SET_ACT_LEAVE_LPS,
-	BTC_SET_ACT_ENTER_LPS,
-	BTC_SET_ACT_NORMAL_LPS,
-	BTC_SET_ACT_DISABLE_LOW_POWER,
-	BTC_SET_ACT_UPDATE_RAMASK,
-	BTC_SET_ACT_SEND_MIMO_PS,
-	// BT Coex related
-	BTC_SET_ACT_CTRL_BT_INFO,
-	BTC_SET_ACT_CTRL_BT_COEX,
-	BTC_SET_ACT_CTRL_8723B_ANT,
-	//=================
-	BTC_SET_MAX
-}BTC_SET_TYPE,*PBTC_SET_TYPE;
-
-typedef enum _BTC_DBG_DISP_TYPE{
-	BTC_DBG_DISP_COEX_STATISTICS				= 0x0,
-	BTC_DBG_DISP_BT_LINK_INFO				= 0x1,
-	BTC_DBG_DISP_WIFI_STATUS				= 0x2,
-	BTC_DBG_DISP_MAX
-}BTC_DBG_DISP_TYPE,*PBTC_DBG_DISP_TYPE;
-
-typedef enum _BTC_NOTIFY_TYPE_IPS{
-	BTC_IPS_LEAVE							= 0x0,
-	BTC_IPS_ENTER							= 0x1,
-	BTC_IPS_MAX
-}BTC_NOTIFY_TYPE_IPS,*PBTC_NOTIFY_TYPE_IPS;
-typedef enum _BTC_NOTIFY_TYPE_LPS{
-	BTC_LPS_DISABLE							= 0x0,
-	BTC_LPS_ENABLE							= 0x1,
-	BTC_LPS_MAX
-}BTC_NOTIFY_TYPE_LPS,*PBTC_NOTIFY_TYPE_LPS;
-typedef enum _BTC_NOTIFY_TYPE_SCAN{
-	BTC_SCAN_FINISH							= 0x0,
-	BTC_SCAN_START							= 0x1,
-	BTC_SCAN_MAX
-}BTC_NOTIFY_TYPE_SCAN,*PBTC_NOTIFY_TYPE_SCAN;
-typedef enum _BTC_NOTIFY_TYPE_ASSOCIATE{
-	BTC_ASSOCIATE_FINISH						= 0x0,
-	BTC_ASSOCIATE_START						= 0x1,
-	BTC_ASSOCIATE_MAX
-}BTC_NOTIFY_TYPE_ASSOCIATE,*PBTC_NOTIFY_TYPE_ASSOCIATE;
-typedef enum _BTC_NOTIFY_TYPE_MEDIA_STATUS{
-	BTC_MEDIA_DISCONNECT					= 0x0,
-	BTC_MEDIA_CONNECT						= 0x1,
-	BTC_MEDIA_MAX
-}BTC_NOTIFY_TYPE_MEDIA_STATUS,*PBTC_NOTIFY_TYPE_MEDIA_STATUS;
-typedef enum _BTC_NOTIFY_TYPE_SPECIAL_PACKET{
-	BTC_PACKET_UNKNOWN					= 0x0,
-	BTC_PACKET_DHCP							= 0x1,
-	BTC_PACKET_ARP							= 0x2,
-	BTC_PACKET_EAPOL						= 0x3,
-	BTC_PACKET_MAX
-}BTC_NOTIFY_TYPE_SPECIAL_PACKET,*PBTC_NOTIFY_TYPE_SPECIAL_PACKET;
-typedef enum _BTC_NOTIFY_TYPE_STACK_OPERATION{
-	BTC_STACK_OP_NONE					= 0x0,
-	BTC_STACK_OP_INQ_PAGE_PAIR_START		= 0x1,
-	BTC_STACK_OP_INQ_PAGE_PAIR_FINISH	= 0x2,
-	BTC_STACK_OP_MAX
-}BTC_NOTIFY_TYPE_STACK_OPERATION,*PBTC_NOTIFY_TYPE_STACK_OPERATION;
-
-//Bryant Add
-typedef enum _BTC_ANTENNA_POS{
-	BTC_ANTENNA_AT_MAIN_PORT				= 0x1,
-	BTC_ANTENNA_AT_AUX_PORT				= 0x2,
-}BTC_ANTENNA_POS,*PBTC_ANTENNA_POS;
-
-//Bryant Add
-typedef enum _BTC_BT_OFFON{
-	BTC_BT_OFF				= 0x0,
-	BTC_BT_ON				= 0x1,
-}BTC_BTOFFON,*PBTC_BT_OFFON;
-
-typedef u1Byte
-(*BFP_BTC_R1)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr
-	);
-typedef u2Byte
-(*BFP_BTC_R2)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr
-	);
-typedef u4Byte
-(*BFP_BTC_R4)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr
-	);
-typedef VOID
-(*BFP_BTC_W1)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr,
-	IN	u1Byte			Data
-	);
-typedef VOID
-(*BFP_BTC_W1_BIT_MASK)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			regAddr,
-	IN	u1Byte			bitMask,
-	IN	u1Byte			data1b
-	);
-typedef VOID
-(*BFP_BTC_W2)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr,
-	IN	u2Byte			Data
-	);
-typedef VOID
-(*BFP_BTC_W4)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr,
-	IN	u4Byte			Data
-	);
-typedef VOID
-(*BFP_BTC_LOCAL_REG_W1)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr,
-	IN	u1Byte			Data
-	);
-typedef VOID
-(*BFP_BTC_SET_BB_REG)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr,
-	IN	u4Byte			BitMask,
-	IN	u4Byte			Data
-	);
-typedef u4Byte 
-(*BFP_BTC_GET_BB_REG)(
-	IN 	PVOID			pBtcContext,
-	IN	u4Byte			RegAddr,
-	IN	u4Byte			BitMask
-	);
-typedef VOID
-(*BFP_BTC_SET_RF_REG)(	
-	IN 	PVOID			pBtcContext,
-	IN	u1Byte			eRFPath,
-	IN	u4Byte			RegAddr,
-	IN	u4Byte			BitMask,
-	IN	u4Byte			Data
-	);
-typedef u4Byte 
-(*BFP_BTC_GET_RF_REG)(
-	IN 	PVOID			pBtcContext,
-	IN	u1Byte			eRFPath,
-	IN	u4Byte			RegAddr,
-	IN	u4Byte			BitMask
-	);
-typedef VOID
-(*BFP_BTC_FILL_H2C)(
-	IN 	PVOID			pBtcContext,
-	IN	u1Byte 			elementId,
-	IN	u4Byte 			cmdLen,
-	IN	pu1Byte			pCmdBuffer
-	);
-
-typedef	BOOLEAN
-(*BFP_BTC_GET)(
-	IN	PVOID			pBtCoexist,
-	IN	u1Byte			getType,
-	OUT	PVOID			pOutBuf
-	);
-
-typedef	BOOLEAN
-(*BFP_BTC_SET)(
-	IN	PVOID			pBtCoexist,
-	IN	u1Byte			setType,
-	OUT	PVOID			pInBuf
-	);
-typedef u2Byte
-(*BFP_BTC_SET_BT_REG)(
-	IN 	PVOID			pBtcContext,
-	IN	u1Byte			regType,
-	IN	u4Byte			offset,
-	IN	u4Byte			value
-	);
-typedef BOOLEAN
-(*BFP_BTC_SET_BT_ANT_DETECTION)(
-	IN 	PVOID			pBtcContext,
-	IN	u1Byte			txTime,
-	IN	u1Byte			btChnl
-	);
-typedef u2Byte 
-(*BFP_BTC_GET_BT_REG)(
-	IN 	PVOID			pBtcContext,
-	IN	u1Byte			regType,
-	IN	u4Byte			offset,
-	IN	pu4Byte			data
-	);
-typedef VOID
-(*BFP_BTC_DISP_DBG_MSG)(
-	IN	PVOID			pBtCoexist,
-	IN	u1Byte			dispType
-	);
-
-typedef struct _BTC_BT_INFO{
-	BOOLEAN					bBtDisabled;
-	u1Byte					rssiAdjustForAgcTableOn;
-	u1Byte					rssiAdjustFor1AntCoexType;
-	BOOLEAN					bPreBtCtrlAggBufSize;
-	BOOLEAN					bBtCtrlAggBufSize;
-	BOOLEAN					bPreRejectAggPkt;
-	BOOLEAN					bRejectAggPkt;
-	BOOLEAN					bIncreaseScanDevNum;
-	BOOLEAN					bBtTxRxMask;
-	u1Byte					preAggBufSize;
-	u1Byte					aggBufSize;
-	BOOLEAN					bBtBusy;
-	BOOLEAN					bLimitedDig;
-	u2Byte					btHciVer;
-	u2Byte					btRealFwVer;
-	u1Byte					btFwVer;
-	u4Byte					getBtFwVerCnt;
-	BOOLEAN					bMiracastPlusBt;
-
-	BOOLEAN					bBtDisableLowPwr;
-
-	BOOLEAN					bBtCtrlLps;
-	BOOLEAN					bBtLpsOn;
-	BOOLEAN					bForceToRoam;	// for 1Ant solution
-	u1Byte					lpsVal;
-	u1Byte					rpwmVal;
-	u4Byte					raMask;
-} BTC_BT_INFO, *PBTC_BT_INFO;
-
-typedef struct _BTC_STACK_INFO{
-	BOOLEAN					bProfileNotified;
-	u2Byte					hciVersion;	// stack hci version
-	u1Byte					numOfLink;
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bAclExist;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bHidExist;
-	u1Byte					numOfHid;
-	BOOLEAN					bPanExist;
-	BOOLEAN					bUnknownAclExist;
-	s1Byte					minBtRssi;
-} BTC_STACK_INFO, *PBTC_STACK_INFO;
-
-typedef struct _BTC_BT_LINK_INFO{
-	BOOLEAN					bBtLinkExist;
-	BOOLEAN					bBtHiPriLinkExist;
-	BOOLEAN					bScoExist;
-	BOOLEAN					bScoOnly;
-	BOOLEAN					bA2dpExist;
-	BOOLEAN					bA2dpOnly;
-	BOOLEAN					bHidExist;
-	BOOLEAN					bHidOnly;
-	BOOLEAN					bPanExist;
-	BOOLEAN					bPanOnly;
-	BOOLEAN					bSlaveRole;
-	BOOLEAN					bAclBusy;
-} BTC_BT_LINK_INFO, *PBTC_BT_LINK_INFO;
-
-typedef struct _BTC_STATISTICS{
-	u4Byte					cntBind;
-	u4Byte					cntPowerOn;
-	u4Byte					cntPreLoadFirmware;
-	u4Byte					cntInitHwConfig;
-	u4Byte					cntInitCoexDm;
-	u4Byte					cntIpsNotify;
-	u4Byte					cntLpsNotify;
-	u4Byte					cntScanNotify;
-	u4Byte					cntConnectNotify;
-	u4Byte					cntMediaStatusNotify;
-	u4Byte					cntSpecialPacketNotify;
-	u4Byte					cntBtInfoNotify;
-	u4Byte					cntRfStatusNotify;
-	u4Byte					cntPeriodical;
-	u4Byte					cntCoexDmSwitch;
-	u4Byte					cntStackOperationNotify;
-	u4Byte					cntDbgCtrl;
-} BTC_STATISTICS, *PBTC_STATISTICS;
-
-typedef struct _BTC_COEXIST{
-	BOOLEAN				bBinded;		// make sure only one adapter can bind the data context
-	PVOID				Adapter;		// default adapter
-	BTC_BOARD_INFO		boardInfo;
-	BTC_BT_INFO			btInfo;		// some bt info referenced by non-bt module
-	BTC_STACK_INFO		stackInfo;
-	BTC_BT_LINK_INFO	btLinkInfo;
-	BTC_CHIP_INTERFACE	chipInterface;
-
-	BOOLEAN				bInitilized;
-	BOOLEAN				bStopCoexDm;
-	BOOLEAN				bManualControl;
-	pu1Byte				cliBuf;
-	BTC_STATISTICS		statistics;
-	u1Byte				pwrModeVal[10];
-		
-	// function pointers
-	// io related
-	BFP_BTC_R1			fBtcRead1Byte;
-	BFP_BTC_W1			fBtcWrite1Byte;
-	BFP_BTC_W1_BIT_MASK	fBtcWrite1ByteBitMask;
-	BFP_BTC_R2			fBtcRead2Byte;
-	BFP_BTC_W2			fBtcWrite2Byte;
-	BFP_BTC_R4			fBtcRead4Byte;
-	BFP_BTC_W4			fBtcWrite4Byte;
-	BFP_BTC_LOCAL_REG_W1	fBtcWriteLocalReg1Byte;
-	// read/write bb related
-	BFP_BTC_SET_BB_REG	fBtcSetBbReg;
-	BFP_BTC_GET_BB_REG	fBtcGetBbReg;
-
-	// read/write rf related
-	BFP_BTC_SET_RF_REG	fBtcSetRfReg;
-	BFP_BTC_GET_RF_REG	fBtcGetRfReg;
-	
-	// fill h2c related
-	BFP_BTC_FILL_H2C		fBtcFillH2c;
-	// other
-	BFP_BTC_DISP_DBG_MSG	fBtcDispDbgMsg;
-	// normal get/set related
-	BFP_BTC_GET			fBtcGet;
-	BFP_BTC_SET			fBtcSet;
-
-	BFP_BTC_GET_BT_REG	fBtcGetBtReg;
-	BFP_BTC_SET_BT_REG	fBtcSetBtReg;
-
-	BFP_BTC_SET_BT_ANT_DETECTION	fBtcSetBtAntDetection;
-} BTC_COEXIST, *PBTC_COEXIST;
-
-extern BTC_COEXIST				GLBtCoexist;
-
-BOOLEAN
-EXhalbtcoutsrc_InitlizeVariables(
-	IN	PVOID		Adapter	
-	);
-VOID
-EXhalbtcoutsrc_PowerOnSetting(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtcoutsrc_PreLoadFirmware(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtcoutsrc_InitHwConfig(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	BOOLEAN				bWifiOnly
-	);
-VOID
-EXhalbtcoutsrc_InitCoexDm(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtcoutsrc_IpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtcoutsrc_LpsNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtcoutsrc_ScanNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtcoutsrc_ConnectNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			action
-	);
-VOID
-EXhalbtcoutsrc_MediaStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	RT_MEDIA_STATUS	mediaStatus
-	);
-VOID
-EXhalbtcoutsrc_SpecialPacketNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			pktType
-	);
-VOID
-EXhalbtcoutsrc_BtInfoNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtcoutsrc_RfStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte 				type
-	);
-VOID
-EXhalbtcoutsrc_StackOperationNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			type
-	);
-VOID
-EXhalbtcoutsrc_HaltNotify(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtcoutsrc_PnpNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte			pnpState
-	);
-VOID
-EXhalbtcoutsrc_ScoreBoardStatusNotify(
-	IN	PBTC_COEXIST		pBtCoexist,
-	IN	pu1Byte			tmpBuf,
-	IN	u1Byte			length
-	);
-VOID
-EXhalbtcoutsrc_CoexDmSwitch(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtcoutsrc_Periodical(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtcoutsrc_DbgControl(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u1Byte				opCode,
-	IN	u1Byte				opLen,
-	IN	pu1Byte				pData
-	);
-VOID
-EXhalbtcoutsrc_AntennaDetection(
-	IN	PBTC_COEXIST			pBtCoexist,
-	IN	u4Byte					centFreq,
-	IN	u4Byte					offset,
-	IN	u4Byte					span,
-	IN	u4Byte					seconds
-	);
-VOID
-EXhalbtcoutsrc_StackUpdateProfileInfo(
-	VOID
-	);
-VOID
-EXhalbtcoutsrc_SetHciVersion(
-	IN	u2Byte	hciVersion
-	);
-VOID
-EXhalbtcoutsrc_SetBtPatchVersion(
-	IN	u2Byte	btHciVersion,
-	IN	u2Byte	btPatchVersion
-	);
-VOID
-EXhalbtcoutsrc_UpdateMinBtRssi(
-	IN	s1Byte	btRssi
-	);
-#if 0
-VOID
-EXhalbtcoutsrc_SetBtExist(
-	IN	BOOLEAN		bBtExist
-	);
-#endif
-VOID
-EXhalbtcoutsrc_SetChipType(
-	IN	u1Byte		chipType
-	);
-VOID
-EXhalbtcoutsrc_SetAntNum(
-	IN	u1Byte		type,
-	IN	u1Byte		antNum
-	);
-VOID
-EXhalbtcoutsrc_SetSingleAntPath(
-	IN	u1Byte		singleAntPath
-	);
-VOID
-EXhalbtcoutsrc_DisplayBtCoexInfo(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-VOID
-EXhalbtcoutsrc_DisplayAntDetection(
-	IN	PBTC_COEXIST		pBtCoexist
-	);
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/Mp_Precomp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/Mp_Precomp.h
deleted file mode 100644
index 62abb5e285a3..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/btc/Mp_Precomp.h
+++ /dev/null
@@ -1,89 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __MP_PRECOMP_H__
-#define __MP_PRECOMP_H__
-
-#include <drv_types.h>
-#include <hal_data.h>
-
-#define BT_TMP_BUF_SIZE	100
-
-#ifdef PLATFORM_LINUX
-#define rsprintf snprintf
-#elif defined(PLATFORM_WINDOWS)
-#define rsprintf sprintf_s
-#endif
-
-#define DCMD_Printf			DBG_BT_INFO
-
-#define delay_ms(ms)		rtw_mdelay_os(ms)
-
-#ifdef bEnable
-#undef bEnable
-#endif
-
-#define WPP_SOFTWARE_TRACE 0
-
-typedef enum _BTC_MSG_COMP_TYPE{
-	COMP_COEX		= 0,
-	COMP_MAX
-}BTC_MSG_COMP_TYPE;
-extern u4Byte GLBtcDbgType[];
-
-#define DBG_OFF			0
-#define DBG_SEC			1
-#define DBG_SERIOUS		2
-#define DBG_WARNING		3
-#define DBG_LOUD		4
-#define DBG_TRACE		5
-
-#if DBG
-#ifdef RT_TRACE
-#undef RT_TRACE
-#define RT_TRACE(dbgtype, dbgflag, printstr)\
-do {\
-	if (GLBtcDbgType[dbgtype] & BIT(dbgflag))\
-	{\
-		DbgPrint printstr;\
-	}\
-} while (0)
-#endif
-#else
-#define RT_TRACE(dbgtype, dbgflag, printstr)
-#endif
-
-#include "HalBtcOutSrc.h"
-#include "HalBtc8188c2Ant.h"
-#include "HalBtc8192d2Ant.h"
-#include "HalBtc8192e1Ant.h"
-#include "HalBtc8192e2Ant.h"
-#include "HalBtc8723a1Ant.h"
-#include "HalBtc8723a2Ant.h"
-#include "HalBtc8723b1Ant.h"
-#include "HalBtc8723b2Ant.h"
-#include "HalBtc8812a1Ant.h"
-#include "HalBtc8812a2Ant.h"
-#include "HalBtc8821a1Ant.h"
-#include "HalBtc8821a2Ant.h"
-#include "HalBtc8821aCsr2Ant.h"
-#include "HalBtc8703b1Ant.h"
-#include "HalBtc8703b2Ant.h"
-
-#endif // __MP_PRECOMP_H__
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/efuse_mask.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/efuse_mask.h
index 866c605d8312..6a9b1454259b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/efuse_mask.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/efuse_mask.h
@@ -1,81 +1,147 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-
-	#if defined(CONFIG_RTL8188E)
-	#include "rtl8188e/HalEfuseMask8188E_USB.h"
-	#endif
-
-	#if defined(CONFIG_RTL8812A)
-	#include "rtl8812a/HalEfuseMask8812A_USB.h"
-	#endif
-
-	#if defined(CONFIG_RTL8821A)
-	#include "rtl8812a/HalEfuseMask8821A_USB.h"
-	#endif
-
-	#if defined(CONFIG_RTL8192E)
-	#include "rtl8192e/HalEfuseMask8192E_USB.h"
-	#endif
-
-	#if defined(CONFIG_RTL8723B)
-	#include "rtl8723b/HalEfuseMask8723B_USB.h"
-	#endif
-
-	#if defined(CONFIG_RTL8814A)
-	#include "rtl8814a/HalEfuseMask8814A_USB.h"
-	#endif
-
-	#if defined(CONFIG_RTL8703B)
-	#include "rtl8703b/HalEfuseMask8703B_USB.h"
-	#endif
-
-	#if defined(CONFIG_RTL8188F)
-	#include "rtl8188f/HalEfuseMask8188F_USB.h"
-	#endif
-
-#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
-
-	#if defined(CONFIG_RTL8188E)
-	#include "rtl8188e/HalEfuseMask8188E_PCIE.h"
-	#endif
-
-	#if defined(CONFIG_RTL8812A)
-	#include "rtl8812a/HalEfuseMask8812A_PCIE.h"
-	#endif
-
-	#if defined(CONFIG_RTL8821A)
-	#include "rtl8812a/HalEfuseMask8821A_PCIE.h"
-	#endif
-
-	#if defined(CONFIG_RTL8192E)
-	#include "rtl8192e/HalEfuseMask8192E_PCIE.h"
-	#endif
-
-	#if defined(CONFIG_RTL8723B)
-	#include "rtl8723b/HalEfuseMask8723B_PCIE.h"
-	#endif
-
-	#if defined(CONFIG_RTL8814A)
-	#include "rtl8814a/HalEfuseMask8814A_PCIE.h"
-	#endif
-
-	#if defined(CONFIG_RTL8703B)
-	#include "rtl8703b/HalEfuseMask8703B_PCIE.h"
-	#endif
-
-#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
-
-	#if defined(CONFIG_RTL8188E)
-	#include "rtl8188e/HalEfuseMask8188E_SDIO.h"
-	#endif
-
-	#if defined(CONFIG_RTL8703B)
-	#include "rtl8703b/HalEfuseMask8703B_SDIO.h"
-	#endif
-
-	#if defined(CONFIG_RTL8188F)
-	#include "rtl8188f/HalEfuseMask8188F_SDIO.h"
-	#endif
-
-#endif
\ No newline at end of file
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+
+	#if defined(CONFIG_RTL8188E)
+		#include "rtl8188e/HalEfuseMask8188E_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8812A)
+		#include "rtl8812a/HalEfuseMask8812A_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8821A)
+		#include "rtl8812a/HalEfuseMask8821A_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8192E)
+		#include "rtl8192e/HalEfuseMask8192E_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8723B)
+		#include "rtl8723b/HalEfuseMask8723B_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8814A)
+		#include "rtl8814a/HalEfuseMask8814A_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8703B)
+		#include "rtl8703b/HalEfuseMask8703B_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8723D)
+		#include "rtl8723d/HalEfuseMask8723D_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8188F)
+		#include "rtl8188f/HalEfuseMask8188F_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8188GTV)
+		#include "rtl8188gtv/HalEfuseMask8188GTV_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8822B)
+		#include "rtl8822b/HalEfuseMask8822B_USB.h"
+	#endif
+
+	#if defined(CONFIG_RTL8821C)
+		#include "rtl8821c/HalEfuseMask8821C_USB.h"
+	#endif
+
+#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+
+	#if defined(CONFIG_RTL8188E)
+		#include "rtl8188e/HalEfuseMask8188E_PCIE.h"
+	#endif
+
+	#if defined(CONFIG_RTL8812A)
+		#include "rtl8812a/HalEfuseMask8812A_PCIE.h"
+	#endif
+
+	#if defined(CONFIG_RTL8821A)
+		#include "rtl8812a/HalEfuseMask8821A_PCIE.h"
+	#endif
+
+	#if defined(CONFIG_RTL8192E)
+		#include "rtl8192e/HalEfuseMask8192E_PCIE.h"
+	#endif
+
+	#if defined(CONFIG_RTL8723B)
+		#include "rtl8723b/HalEfuseMask8723B_PCIE.h"
+	#endif
+
+	#if defined(CONFIG_RTL8814A)
+		#include "rtl8814a/HalEfuseMask8814A_PCIE.h"
+	#endif
+
+	#if defined(CONFIG_RTL8703B)
+		#include "rtl8703b/HalEfuseMask8703B_PCIE.h"
+	#endif
+
+	#if defined(CONFIG_RTL8822B)
+		#include "rtl8822b/HalEfuseMask8822B_PCIE.h"
+	#endif
+	#if defined(CONFIG_RTL8723D)
+		#include "rtl8723d/HalEfuseMask8723D_PCIE.h"
+	#endif
+	#if defined(CONFIG_RTL8821C)
+		#include "rtl8821c/HalEfuseMask8821C_PCIE.h"
+	#endif
+
+#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	#if defined(CONFIG_RTL8723B)
+		#include "rtl8723b/HalEfuseMask8723B_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8188E)
+		#include "rtl8188e/HalEfuseMask8188E_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8703B)
+		#include "rtl8703b/HalEfuseMask8703B_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8188F)
+		#include "rtl8188f/HalEfuseMask8188F_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8188GTV)
+		#include "rtl8188gtv/HalEfuseMask8188GTV_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8723D)
+		#include "rtl8723d/HalEfuseMask8723D_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8192E)
+		#include "rtl8192e/HalEfuseMask8192E_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8821A)
+		#include "rtl8812a/HalEfuseMask8821A_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8821C)
+		#include "rtl8821c/HalEfuseMask8821C_SDIO.h"
+	#endif
+
+	#if defined(CONFIG_RTL8822B)
+		#include "rtl8822b/HalEfuseMask8822B_SDIO.h"
+	#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.c
index 4840acb6a63f..5ea065bebb23 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.c
@@ -1,25 +1,21 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "Mp_Precomp.h"
-//#include "../odm_precomp.h"
+/* #include "Mp_Precomp.h" */
+/* #include "../odm_precomp.h" */
 
 #include <drv_types.h>
 
@@ -31,73 +27,71 @@
 *                           MSDIO.TXT
 ******************************************************************************/
 
-u1Byte Array_MP_8188F_MSDIO[] = { 
-0xFF,
-0xF3,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x0F,
-0xF1,
-0xFF,
-0xFF,
-0xFF,
-0xFF,
-0xFF,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
+u1Byte Array_MP_8188F_MSDIO[] = {
+	0xFF,
+	0xF3,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x0F,
+	0xF1,
+	0xFF,
+	0xFF,
+	0xFF,
+	0xFF,
+	0xFF,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
 
 };
 
 u2Byte
 EFUSE_GetArrayLen_MP_8188F_MSDIO(VOID)
 {
-	return sizeof(Array_MP_8188F_MSDIO)/sizeof(u1Byte);
+	return sizeof(Array_MP_8188F_MSDIO) / sizeof(u1Byte);
 }
 
 VOID
 EFUSE_GetMaskArray_MP_8188F_MSDIO(
-	IN 	OUT pu1Byte Array
-	)
+	IN	OUT pu1Byte Array
+)
 {
 	u2Byte len = EFUSE_GetArrayLen_MP_8188F_MSDIO(), i = 0;
 
 	for (i = 0; i < len; ++i)
-	   Array[i] = Array_MP_8188F_MSDIO[i];
+		Array[i] = Array_MP_8188F_MSDIO[i];
 }
 BOOLEAN
 EFUSE_IsAddressMasked_MP_8188F_MSDIO(
- 	IN   u2Byte  Offset
- 	)
+	IN   u2Byte  Offset
+)
 {
-	int r = Offset/16;
-	int c = (Offset%16) / 2;
+	int r = Offset / 16;
+	int c = (Offset % 16) / 2;
 	int result = 0;
 
-	if (c < 4) // Upper double word
-	    result = (Array_MP_8188F_MSDIO[r] & (0x10 << c));
+	if (c < 4) /* Upper double word */
+		result = (Array_MP_8188F_MSDIO[r] & (0x10 << c));
 	else
-	    result = (Array_MP_8188F_MSDIO[r] & (0x01 << (c-4)));
+		result = (Array_MP_8188F_MSDIO[r] & (0x01 << (c - 4)));
 
 	return (result > 0) ? 0 : 1;
 }
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.h
index 3fa4e3e7ec8c..9fef2db1dec0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_SDIO.h
@@ -1,22 +1,18 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
 
 
 
@@ -30,12 +26,10 @@ EFUSE_GetArrayLen_MP_8188F_MSDIO(VOID);
 
 VOID
 EFUSE_GetMaskArray_MP_8188F_MSDIO(
-	IN 	OUT pu1Byte Array
+	IN	OUT pu1Byte Array
 );
 
 BOOLEAN
-EFUSE_IsAddressMasked_MP_8188F_MSDIO( // TC: Test Chip, MP: MP Chip
+EFUSE_IsAddressMasked_MP_8188F_MSDIO(/* TC: Test Chip, MP: MP Chip */
 	IN   u2Byte  Offset
 );
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.c
index 9912f5d124ad..f9cbc439b5dc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.c
@@ -1,25 +1,21 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "Mp_Precomp.h"
-//#include "../odm_precomp.h"
+/* #include "Mp_Precomp.h" */
+/* #include "../odm_precomp.h" */
 
 #include <drv_types.h>
 
@@ -30,73 +26,70 @@
 *                           MUSB.TXT
 ******************************************************************************/
 
-u1Byte Array_MP_8188F_MUSB[] = { 
-0xFF,
-0xF3,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x0F,
-0xF1,
-0xFF,
-0xFF,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-0x00,
-
+u1Byte Array_MP_8188F_MUSB[] = {
+	0xFF,
+	0xF3,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x0F,
+	0xF1,
+	0xFF,
+	0xFF,
+	0xFF,
+	0xFF,
+	0x70,
+	0x00,
+	0x12,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
+	0x00,
 };
 
 u2Byte
 EFUSE_GetArrayLen_MP_8188F_MUSB(VOID)
 {
-	return sizeof(Array_MP_8188F_MUSB)/sizeof(u1Byte);
+	return sizeof(Array_MP_8188F_MUSB) / sizeof(u1Byte);
 }
 
 VOID
 EFUSE_GetMaskArray_MP_8188F_MUSB(
-	IN 	OUT pu1Byte Array
-	)
+	IN	OUT pu1Byte Array
+)
 {
 	u2Byte len = EFUSE_GetArrayLen_MP_8188F_MUSB(), i = 0;
 
 	for (i = 0; i < len; ++i)
-	   Array[i] = Array_MP_8188F_MUSB[i];
+		Array[i] = Array_MP_8188F_MUSB[i];
 }
 BOOLEAN
 EFUSE_IsAddressMasked_MP_8188F_MUSB(
- 	IN   u2Byte  Offset
- 	)
+	IN   u2Byte  Offset
+)
 {
-	int r = Offset/16;
-	int c = (Offset%16) / 2;
+	int r = Offset / 16;
+	int c = (Offset % 16) / 2;
 	int result = 0;
 
-	if (c < 4) // Upper double word
-	    result = (Array_MP_8188F_MUSB[r] & (0x10 << c));
+	if (c < 4) /* Upper double word */
+		result = (Array_MP_8188F_MUSB[r] & (0x10 << c));
 	else
-	    result = (Array_MP_8188F_MUSB[r] & (0x01 << (c-4)));
+		result = (Array_MP_8188F_MUSB[r] & (0x01 << (c - 4)));
 
 	return (result > 0) ? 0 : 1;
 }
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.h
index e4890cad0ad6..2bc01807e320 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/efuse/rtl8188f/HalEfuseMask8188F_USB.h
@@ -1,22 +1,18 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
 
 
 
@@ -30,13 +26,10 @@ EFUSE_GetArrayLen_MP_8188F_MUSB(VOID);
 
 VOID
 EFUSE_GetMaskArray_MP_8188F_MUSB(
-	IN 	OUT pu1Byte Array
+	IN	OUT pu1Byte Array
 );
 
 BOOLEAN
-EFUSE_IsAddressMasked_MP_8188F_MUSB( // TC: Test Chip, MP: MP Chip
+EFUSE_IsAddressMasked_MP_8188F_MUSB(/* TC: Test Chip, MP: MP Chip */
 	IN   u2Byte  Offset
 );
-
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_btcoex.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_btcoex.c
index 29a64c2d4527..4d0861ef128a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_btcoex.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_btcoex.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,25 +12,19 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define __HAL_BTCOEX_C__
 
 #ifdef CONFIG_BT_COEXIST
 
 #include <hal_data.h>
 #include <hal_btcoex.h>
-#include <Mp_Precomp.h>
+#include "btc/mp_precomp.h"
 
-//====================================
-//		Global variables
-//====================================
-const char *const BtProfileString[] =
-{
+/* ************************************
+ *		Global variables
+ * ************************************ */
+const char *const BtProfileString[] = {
 	"NONE",
 	"A2DP",
 	"PAN",
@@ -37,8 +32,7 @@ const char *const BtProfileString[] =
 	"SCO",
 };
 
-const char *const BtSpecString[] =
-{
+const char *const BtSpecString[] = {
 	"1.0b",
 	"1.1",
 	"1.2",
@@ -48,22 +42,19 @@ const char *const BtSpecString[] =
 	"4.0",
 };
 
-const char *const BtLinkRoleString[] =
-{
+const char *const BtLinkRoleString[] = {
 	"Master",
 	"Slave",
 };
 
-const char *const h2cStaString[] =
-{
+const char *const h2cStaString[] = {
 	"successful",
 	"h2c busy",
 	"rf off",
 	"fw not read",
 };
 
-const char *const ioStaString[] =
-{
+const char *const ioStaString[] = {
 	"success",
 	"can not IO",
 	"rf off",
@@ -77,7 +68,7 @@ const char *const ioStaString[] =
 	"h2c stopped",
 };
 
-const char *const GLBtcWifiBwString[]={
+const char *const GLBtcWifiBwString[] = {
 	"11bg",
 	"HT20",
 	"HT40",
@@ -85,7 +76,7 @@ const char *const GLBtcWifiBwString[]={
 	"HT160"
 };
 
-const char *const GLBtcWifiFreqString[]={
+const char *const GLBtcWifiFreqString[] = {
 	"2.4G",
 	"5G"
 };
@@ -98,22 +89,54 @@ const char *const GLBtcIotPeerString[] = {
 	"RALINK",
 	"ATHEROS",
 	"CISCO",
-	"MERU",	
+	"MERU",
 	"MARVELL",
 	"REALTEK_SOFTAP", /* peer is RealTek SOFT_AP, by Bohn, 2009.12.17 */
 	"SELF_SOFTAP", /* Self is SoftAP */
 	"AIRGO",
-	"INTEL", 
-	"RTK_APCLIENT", 
-	"REALTEK_81XX",	
+	"INTEL",
+	"RTK_APCLIENT",
+	"REALTEK_81XX",
 	"REALTEK_WOW",
 	"REALTEK_JAGUAR_BCUTAP",
 	"REALTEK_JAGUAR_CCUTAP"
 };
 
+const char *const coexOpcodeString[] = {
+	"Wifi status notify",
+	"Wifi progress",
+	"Wifi info",
+	"Power state",
+	"Set Control",
+	"Get Control"
+};
+
+const char *const coexIndTypeString[] = {
+	"bt info",
+	"pstdma",
+	"limited tx/rx",
+	"coex table",
+	"request"
+};
+
+const char *const coexH2cResultString[] = {
+	"ok",
+	"unknown",
+	"un opcode",
+	"opVer MM",
+	"par Err",
+	"par OoR",
+	"reqNum MM",
+	"halMac Fail",
+	"h2c TimeOut",
+	"Invalid c2h Len",
+	"data overflow"
+};
+
 #define HALBTCOUTSRC_AGG_CHK_WINDOW_IN_MS	8000
 
-BTC_COEXIST GLBtCoexist;
+struct btc_coexist GLBtCoexist;
+BTC_OFFLOAD gl_coex_offload;
 u8 GLBtcWiFiInScanState;
 u8 GLBtcWiFiInIQKState;
 u8 GLBtcWiFiInIPS;
@@ -139,10 +162,25 @@ typedef enum _bt_c2h_status {
 
 /* C2H BT OP CODES */
 typedef enum _bt_op_code {
-	BT_OP_GET_BT_VERSION	= 0,
-	BT_OP_WRITE_REG_ADDR	= 12,
-	BT_OP_WRITE_REG_VALUE,
-	BT_OP_READ_REG		= 17
+	BT_OP_GET_BT_VERSION					= 0x00,
+	BT_OP_WRITE_REG_ADDR					= 0x0c,
+	BT_OP_WRITE_REG_VALUE					= 0x0d,
+
+	BT_OP_READ_REG							= 0x11,
+
+	BT_LO_OP_GET_AFH_MAP_L					= 0x1e,
+	BT_LO_OP_GET_AFH_MAP_M					= 0x1f,
+	BT_LO_OP_GET_AFH_MAP_H					= 0x20,
+
+	BT_OP_GET_BT_COEX_SUPPORTED_FEATURE		= 0x2a,
+	BT_OP_GET_BT_COEX_SUPPORTED_VERSION		= 0x2b,
+	BT_OP_GET_BT_ANT_DET_VAL				= 0x2c,
+	BT_OP_GET_BT_BLE_SCAN_TYPE				= 0x2d,
+	BT_OP_GET_BT_BLE_SCAN_PARA				= 0x2e,
+	BT_OP_GET_BT_DEVICE_INFO				= 0x30,
+	BT_OP_GET_BT_FORBIDDEN_SLOT_VAL			= 0x31,
+	BT_OP_SET_BT_LANCONSTRAIN_LEVEL			= 0x32,
+	BT_OP_MAX
 } BT_OP_CODE;
 
 #define BTC_MPOPER_TIMEOUT	50	/* unit: ms */
@@ -165,12 +203,12 @@ u8 GLBtcBtMpRptBTOK;
  */
 u32 GLBtcDbgType[COMP_MAX];
 u8 GLBtcDbgBuf[BT_TMP_BUF_SIZE];
+u1Byte	gl_btc_trace_buf[BT_TMP_BUF_SIZE];
 
-typedef struct _btcoexdbginfo
-{
+typedef struct _btcoexdbginfo {
 	u8 *info;
-	u32 size; // buffer total size
-	u32 len; // now used length
+	u32 size; /* buffer total size */
+	u32 len; /* now used length */
 } BTCDBGINFO, *PBTCDBGINFO;
 
 BTCDBGINFO GLBtcDbgInfo;
@@ -179,7 +217,8 @@ BTCDBGINFO GLBtcDbgInfo;
 
 static void DBG_BT_INFO_INIT(PBTCDBGINFO pinfo, u8 *pbuf, u32 size)
 {
-	if (NULL == pinfo) return;
+	if (NULL == pinfo)
+		return;
 
 	_rtw_memset(pinfo, 0, sizeof(BTCDBGINFO));
 
@@ -210,16 +249,14 @@ void DBG_BT_INFO(u8 *dbgmsg)
 	pinfo->len += msglen;
 }
 
-//====================================
-//		Debug related function
-//====================================
+/* ************************************
+ *		Debug related function
+ * ************************************ */
 static u8 halbtcoutsrc_IsBtCoexistAvailable(PBTC_COEXIST pBtCoexist)
 {
 	if (!pBtCoexist->bBinded ||
-		NULL == pBtCoexist->Adapter)
-	{
+	    NULL == pBtCoexist->Adapter)
 		return _FALSE;
-	}
 	return _TRUE;
 }
 
@@ -233,40 +270,52 @@ static void halbtcoutsrc_DbgInit(void)
 
 static u8 halbtcoutsrc_IsCsrBtCoex(PBTC_COEXIST pBtCoexist)
 {
-	if (pBtCoexist->boardInfo.btChipType == BTC_CHIP_CSR_BC4
-		|| pBtCoexist->boardInfo.btChipType == BTC_CHIP_CSR_BC8
-	){
+	if (pBtCoexist->board_info.bt_chip_type == BTC_CHIP_CSR_BC4
+	    || pBtCoexist->board_info.bt_chip_type == BTC_CHIP_CSR_BC8
+	   )
 		return _TRUE;
-	}
 	return _FALSE;
 }
 
+static void halbtcoutsrc_EnterPwrLock(PBTC_COEXIST pBtCoexist)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj((PADAPTER)pBtCoexist->Adapter);
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+
+	_enter_pwrlock(&pwrpriv->lock);
+}
+
+static void halbtcoutsrc_ExitPwrLock(PBTC_COEXIST pBtCoexist)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj((PADAPTER)pBtCoexist->Adapter);
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+
+	_exit_pwrlock(&pwrpriv->lock);
+}
+
 static u8 halbtcoutsrc_IsHwMailboxExist(PBTC_COEXIST pBtCoexist)
 {
-	if (pBtCoexist->boardInfo.btChipType == BTC_CHIP_CSR_BC4
-		|| pBtCoexist->boardInfo.btChipType == BTC_CHIP_CSR_BC8
-	){
+	if (pBtCoexist->board_info.bt_chip_type == BTC_CHIP_CSR_BC4
+	    || pBtCoexist->board_info.bt_chip_type == BTC_CHIP_CSR_BC8
+	   )
 		return _FALSE;
-	}
 	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
 		return _FALSE;
-	}
 	else
 		return _TRUE;
 }
 
-static void halbtcoutsrc_LeaveLps(PBTC_COEXIST pBtCoexist)
+static u8 halbtcoutsrc_LeaveLps(PBTC_COEXIST pBtCoexist)
 {
 	PADAPTER padapter;
 
 
 	padapter = pBtCoexist->Adapter;
 
-	pBtCoexist->btInfo.bBtCtrlLps = _TRUE;
-	pBtCoexist->btInfo.bBtLpsOn = _FALSE;
+	pBtCoexist->bt_info.bt_ctrl_lps = _TRUE;
+	pBtCoexist->bt_info.bt_lps_on = _FALSE;
 
-	rtw_btcoex_LPS_Leave(padapter);
+	return rtw_btcoex_LPS_Leave(padapter);
 }
 
 void halbtcoutsrc_EnterLps(PBTC_COEXIST pBtCoexist)
@@ -276,10 +325,12 @@ void halbtcoutsrc_EnterLps(PBTC_COEXIST pBtCoexist)
 
 	padapter = pBtCoexist->Adapter;
 
-	pBtCoexist->btInfo.bBtCtrlLps = _TRUE;
-	pBtCoexist->btInfo.bBtLpsOn = _TRUE;
+	if (pBtCoexist->bdontenterLPS == _FALSE) {
+		pBtCoexist->bt_info.bt_ctrl_lps = _TRUE;
+		pBtCoexist->bt_info.bt_lps_on = _TRUE;
 
-	rtw_btcoex_LPS_Enter(padapter);
+		rtw_btcoex_LPS_Enter(padapter);
+	}
 }
 
 void halbtcoutsrc_NormalLps(PBTC_COEXIST pBtCoexist)
@@ -287,19 +338,17 @@ void halbtcoutsrc_NormalLps(PBTC_COEXIST pBtCoexist)
 	PADAPTER padapter;
 
 
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Normal LPS behavior!!!\n"));
 
 	padapter = pBtCoexist->Adapter;
 
-	if (pBtCoexist->btInfo.bBtCtrlLps)
-	{
-		pBtCoexist->btInfo.bBtLpsOn = _FALSE;
+	if (pBtCoexist->bt_info.bt_ctrl_lps) {
+		pBtCoexist->bt_info.bt_lps_on = _FALSE;
 		rtw_btcoex_LPS_Leave(padapter);
-		pBtCoexist->btInfo.bBtCtrlLps = _FALSE;
+		pBtCoexist->bt_info.bt_ctrl_lps = _FALSE;
 
-		// recover the LPS state to the original
+		/* recover the LPS state to the original */
 #if 0
-		padapter->HalFunc.UpdateLPSStatusHandler(
+		padapter->hal_func.UpdateLPSStatusHandler(
 			padapter,
 			pPSC->RegLeisurePsMode,
 			pPSC->RegPowerSaveMode);
@@ -307,6 +356,24 @@ void halbtcoutsrc_NormalLps(PBTC_COEXIST pBtCoexist)
 	}
 }
 
+void halbtcoutsrc_Pre_NormalLps(PBTC_COEXIST pBtCoexist)
+{
+	PADAPTER padapter;
+
+	padapter = pBtCoexist->Adapter;
+
+	if (pBtCoexist->bt_info.bt_ctrl_lps) {
+		pBtCoexist->bt_info.bt_lps_on = _FALSE;
+		rtw_btcoex_LPS_Leave(padapter);
+	}
+}
+
+void halbtcoutsrc_Post_NormalLps(PBTC_COEXIST pBtCoexist)
+{
+	if (pBtCoexist->bt_info.bt_ctrl_lps)
+		pBtCoexist->bt_info.bt_ctrl_lps = _FALSE;
+}
+
 /*
  *  Constraint:
  *	   1. this function will request pwrctrl->lock
@@ -318,9 +385,9 @@ void halbtcoutsrc_LeaveLowPower(PBTC_COEXIST pBtCoexist)
 	PHAL_DATA_TYPE pHalData;
 	struct pwrctrl_priv *pwrctrl;
 	s32 ready;
-	u32 stime;
+	systime stime;
 	s32 utime;
-	u32 timeout; // unit: ms
+	u32 timeout; /* unit: ms */
 
 
 	padapter = pBtCoexist->Adapter;
@@ -329,9 +396,9 @@ void halbtcoutsrc_LeaveLowPower(PBTC_COEXIST pBtCoexist)
 	ready = _FAIL;
 #ifdef LPS_RPWM_WAIT_MS
 	timeout = LPS_RPWM_WAIT_MS;
-#else // !LPS_RPWM_WAIT_MS
+#else /* !LPS_RPWM_WAIT_MS */
 	timeout = 30;
-#endif // !LPS_RPWM_WAIT_MS
+#endif /* !LPS_RPWM_WAIT_MS */
 
 	if (GLBtcBtCoexAliveRegistered == _TRUE)
 		return;
@@ -350,7 +417,7 @@ void halbtcoutsrc_LeaveLowPower(PBTC_COEXIST pBtCoexist)
 	} while (1);
 
 	GLBtcBtCoexAliveRegistered = _TRUE;
-#endif // CONFIG_LPS_LCLK
+#endif /* CONFIG_LPS_LCLK */
 }
 
 /*
@@ -369,16 +436,16 @@ void halbtcoutsrc_NormalLowPower(PBTC_COEXIST pBtCoexist)
 	rtw_unregister_task_alive(padapter, BTCOEX_ALIVE);
 
 	GLBtcBtCoexAliveRegistered = _FALSE;
-#endif // CONFIG_LPS_LCLK
+#endif /* CONFIG_LPS_LCLK */
 }
 
 void halbtcoutsrc_DisableLowPower(PBTC_COEXIST pBtCoexist, u8 bLowPwrDisable)
 {
-	pBtCoexist->btInfo.bBtDisableLowPwr = bLowPwrDisable;
+	pBtCoexist->bt_info.bt_disable_low_pwr = bLowPwrDisable;
 	if (bLowPwrDisable)
-		halbtcoutsrc_LeaveLowPower(pBtCoexist);		// leave 32k low power.
+		halbtcoutsrc_LeaveLowPower(pBtCoexist);		/* leave 32k low power. */
 	else
-		halbtcoutsrc_NormalLowPower(pBtCoexist);	// original 32k low power behavior.
+		halbtcoutsrc_NormalLowPower(pBtCoexist);	/* original 32k low power behavior. */
 }
 
 void halbtcoutsrc_AggregationCheck(PBTC_COEXIST pBtCoexist)
@@ -390,50 +457,38 @@ void halbtcoutsrc_AggregationCheck(PBTC_COEXIST pBtCoexist)
 
 	padapter = pBtCoexist->Adapter;
 
-	//=====================================
-	// To void continuous deleteBA=>addBA=>deleteBA=>addBA
-	// This function is not allowed to continuous called.
-	// It can only be called after 8 seconds.
-	//=====================================
+	/* ===================================== */
+	/* To void continuous deleteBA=>addBA=>deleteBA=>addBA */
+	/* This function is not allowed to continuous called. */
+	/* It can only be called after 8 seconds. */
+	/* ===================================== */
 
 	curTime = rtw_systime_to_ms(rtw_get_current_time());
-	if((curTime - preTime) < HALBTCOUTSRC_AGG_CHK_WINDOW_IN_MS)	// over 8 seconds you can execute this function again.
-	{
+	if ((curTime - preTime) < HALBTCOUTSRC_AGG_CHK_WINDOW_IN_MS)	/* over 8 seconds you can execute this function again. */
 		return;
-	}
 	else
-	{
 		preTime = curTime;
-	}
 
-	if (pBtCoexist->btInfo.bRejectAggPkt)
-	{
+	if (pBtCoexist->bt_info.reject_agg_pkt) {
 		bNeedToAct = _TRUE;
-		pBtCoexist->btInfo.bPreRejectAggPkt = pBtCoexist->btInfo.bRejectAggPkt;
-	}
-	else
-	{
-		if(pBtCoexist->btInfo.bPreRejectAggPkt)
-		{
+		pBtCoexist->bt_info.pre_reject_agg_pkt = pBtCoexist->bt_info.reject_agg_pkt;
+	} else {
+		if (pBtCoexist->bt_info.pre_reject_agg_pkt) {
 			bNeedToAct = _TRUE;
-			pBtCoexist->btInfo.bPreRejectAggPkt = pBtCoexist->btInfo.bRejectAggPkt;
+			pBtCoexist->bt_info.pre_reject_agg_pkt = pBtCoexist->bt_info.reject_agg_pkt;
 		}
-		
-		if (pBtCoexist->btInfo.bPreBtCtrlAggBufSize !=
-			pBtCoexist->btInfo.bBtCtrlAggBufSize)
-		{
+
+		if (pBtCoexist->bt_info.pre_bt_ctrl_agg_buf_size !=
+		    pBtCoexist->bt_info.bt_ctrl_agg_buf_size) {
 			bNeedToAct = _TRUE;
-			pBtCoexist->btInfo.bPreBtCtrlAggBufSize = pBtCoexist->btInfo.bBtCtrlAggBufSize;
+			pBtCoexist->bt_info.pre_bt_ctrl_agg_buf_size = pBtCoexist->bt_info.bt_ctrl_agg_buf_size;
 		}
 
-		if (pBtCoexist->btInfo.bBtCtrlAggBufSize)
-		{
-			if (pBtCoexist->btInfo.preAggBufSize !=
-				pBtCoexist->btInfo.aggBufSize)
-			{
+		if (pBtCoexist->bt_info.bt_ctrl_agg_buf_size) {
+			if (pBtCoexist->bt_info.pre_agg_buf_size !=
+			    pBtCoexist->bt_info.agg_buf_size)
 				bNeedToAct = _TRUE;
-			}
-			pBtCoexist->btInfo.preAggBufSize = pBtCoexist->btInfo.aggBufSize;
+			pBtCoexist->bt_info.pre_agg_buf_size = pBtCoexist->bt_info.agg_buf_size;
 		}
 	}
 
@@ -441,33 +496,54 @@ void halbtcoutsrc_AggregationCheck(PBTC_COEXIST pBtCoexist)
 		rtw_btcoex_rx_ampdu_apply(padapter);
 }
 
-u8 halbtcoutsrc_IsWifiBusy(PADAPTER padapter)
+u8 halbtcoutsrc_is_autoload_fail(PBTC_COEXIST pBtCoexist)
 {
-	struct mlme_priv *pmlmepriv;
+	PADAPTER padapter;
+	PHAL_DATA_TYPE pHalData;
+
+	padapter = pBtCoexist->Adapter;
+	pHalData = GET_HAL_DATA(padapter);
 
+	return pHalData->bautoload_fail_flag;
+}
 
-	pmlmepriv = &padapter->mlmepriv;
+u8 halbtcoutsrc_is_fw_ready(PBTC_COEXIST pBtCoexist)
+{
+	PADAPTER padapter;
 
-	if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _TRUE)
-	{
-		if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-			return _TRUE;
-		if (_TRUE == pmlmepriv->LinkDetectInfo.bBusyTraffic)
-			return _TRUE;
-	}
+	padapter = pBtCoexist->Adapter;
 
-#if defined(CONFIG_CONCURRENT_MODE)
-	pmlmepriv = &padapter->pbuddy_adapter->mlmepriv;
+	return GET_HAL_DATA(padapter)->bFWReady;
+}
 
-	if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _TRUE)
-	{
-		if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-			return _TRUE;
-		if (_TRUE == pmlmepriv->LinkDetectInfo.bBusyTraffic)
-			return _TRUE;
+u8 halbtcoutsrc_IsDualBandConnected(PADAPTER padapter)
+{
+	u8 ret = BTC_MULTIPORT_SCC;
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter) && (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+		struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+		u8 band0 = mccobjpriv->iface[0]->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
+		u8 band1 = mccobjpriv->iface[1]->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
+
+		if (band0 != band1)
+			ret = BTC_MULTIPORT_MCC_DUAL_BAND;
+		else
+			ret = BTC_MULTIPORT_MCC_DUAL_CHANNEL;
 	}
 #endif
 
+	return ret;
+}
+
+u8 halbtcoutsrc_IsWifiBusy(PADAPTER padapter)
+{
+	if (rtw_mi_check_status(padapter, MI_AP_ASSOC))
+		return _TRUE;
+	if (rtw_mi_busy_traffic_check(padapter, _FALSE))
+		return _TRUE;
+
 	return _FALSE;
 }
 
@@ -485,19 +561,15 @@ static u32 _halbtcoutsrc_GetWifiLinkStatus(PADAPTER padapter)
 #ifdef CONFIG_P2P
 	if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE))
 		bp2p = _TRUE;
-#endif // CONFIG_P2P
+#endif /* CONFIG_P2P */
 
-	if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _TRUE)
-	{
-		if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-		{
+	if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _TRUE) {
+		if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
 			if (_TRUE == bp2p)
 				portConnectedStatus |= WIFI_P2P_GO_CONNECTED;
 			else
 				portConnectedStatus |= WIFI_AP_CONNECTED;
-		}
-		else
-		{
+		} else {
 			if (_TRUE == bp2p)
 				portConnectedStatus |= WIFI_P2P_GC_CONNECTED;
 			else
@@ -510,62 +582,44 @@ static u32 _halbtcoutsrc_GetWifiLinkStatus(PADAPTER padapter)
 
 u32 halbtcoutsrc_GetWifiLinkStatus(PBTC_COEXIST pBtCoexist)
 {
-	//=================================
-	// return value:
-	// [31:16]=> connected port number
-	// [15:0]=> port connected bit define
-	//================================
+	/* ================================= */
+	/* return value: */
+	/* [31:16]=> connected port number */
+	/* [15:0]=> port connected bit define */
+	/* ================================ */
 
 	PADAPTER padapter;
 	u32 retVal;
 	u32 portConnectedStatus, numOfConnectedPort;
-
+	struct dvobj_priv *dvobj;
+	_adapter *iface;
+	int i;
 
 	padapter = pBtCoexist->Adapter;
 	retVal = 0;
 	portConnectedStatus = 0;
 	numOfConnectedPort = 0;
-
-	retVal = _halbtcoutsrc_GetWifiLinkStatus(padapter);
-	if (retVal)
-	{
-		portConnectedStatus |= retVal;
-		numOfConnectedPort++;
-	}
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->pbuddy_adapter)
-	{
-		retVal = _halbtcoutsrc_GetWifiLinkStatus(padapter->pbuddy_adapter);
-		if (retVal)
-		{
-			portConnectedStatus |= retVal;
-			numOfConnectedPort++;
+	dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			retVal = _halbtcoutsrc_GetWifiLinkStatus(iface);
+			if (retVal) {
+				portConnectedStatus |= retVal;
+				numOfConnectedPort++;
+			}
 		}
 	}
-#endif // CONFIG_CONCURRENT_MODE
-
 	retVal = (numOfConnectedPort << 16) | portConnectedStatus;
-	
-	return retVal;
-}
-
-static u8 _is_btfwver_valid(PBTC_COEXIST pBtCoexist, u16 btfwver)
-{
-	if (!btfwver)
-		return _FALSE;
-
-	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-		if (btfwver == 0x8723)
-			return _FALSE;
 
-	return _TRUE;
+	return retVal;
 }
 
 static void _btmpoper_timer_hdl(void *p)
 {
-	if (GLBtcBtMpRptWait) {
-		GLBtcBtMpRptWait = 0;
+	if (GLBtcBtMpRptWait == _TRUE) {
+		GLBtcBtMpRptWait = _FALSE;
 		_rtw_up_sema(&GLBtcBtMpRptSema);
 	}
 }
@@ -581,7 +635,6 @@ static u8 _btmpoper_cmd(PBTC_COEXIST pBtCoexist, u8 opcode, u8 opcodever, u8 *cm
 	u8 buf[H2C_BTMP_OPER_LEN] = {0};
 	u8 buflen;
 	u8 seq;
-	u8 timer_cancelled;
 	s32 ret;
 
 
@@ -597,36 +650,37 @@ static u8 _btmpoper_cmd(PBTC_COEXIST pBtCoexist, u8 opcode, u8 opcodever, u8 *cm
 	buf[0] = (opcodever & 0xF) | (seq << 4);
 	buf[1] = opcode;
 	if (cmd && size)
-		_rtw_memcpy(buf+2, cmd, size);
+		_rtw_memcpy(buf + 2, cmd, size);
 
-	GLBtcBtMpRptWait = 1;
-	GLBtcBtMpRptWiFiOK = 0;
-	GLBtcBtMpRptBTOK = 0;
+	GLBtcBtMpRptWait = _TRUE;
+	GLBtcBtMpRptWiFiOK = _FALSE;
+	GLBtcBtMpRptBTOK = _FALSE;
 	GLBtcBtMpRptStatus = 0;
 	padapter = pBtCoexist->Adapter;
 	_set_timer(&GLBtcBtMpOperTimer, BTC_MPOPER_TIMEOUT);
 	if (rtw_hal_fill_h2c_cmd(padapter, H2C_BT_MP_OPER, buflen, buf) == _FAIL) {
-		_cancel_timer(&GLBtcBtMpOperTimer, &timer_cancelled);
+		_cancel_timer_ex(&GLBtcBtMpOperTimer);
 		ret = BT_STATUS_H2C_FAIL;
 		goto exit;
 	}
 
 	_rtw_down_sema(&GLBtcBtMpRptSema);
-	/* GLBtcBtMpRptWait should be 0 here*/
+	/* GLBtcBtMpRptWait should be _FALSE here*/
 
-	if (!GLBtcBtMpRptWiFiOK) {
-		DBG_871X("%s: Didn't get H2C Rsp Event!\n", __FUNCTION__);
+	if (GLBtcBtMpRptWiFiOK == _FALSE) {
+		RTW_ERR("%s: Didn't get H2C Rsp Event!\n", __FUNCTION__);
 		ret = BT_STATUS_H2C_TIMTOUT;
 		goto exit;
 	}
-	if (!GLBtcBtMpRptBTOK) {
-		DBG_871X("%s: Didn't get BT response!\n", __FUNCTION__);
+	if (GLBtcBtMpRptBTOK == _FALSE) {
+		RTW_DBG("%s: Didn't get BT response!\n", __FUNCTION__);
 		ret = BT_STATUS_H2C_BT_NO_RSP;
 		goto exit;
 	}
+
 	if (seq != GLBtcBtMpRptSeq) {
-		DBG_871X("%s: Sequence number not match!(%d!=%d)!\n",
-			__FUNCTION__, seq, GLBtcBtMpRptSeq);
+		RTW_ERR("%s: Sequence number not match!(%d!=%d)!\n",
+			 __FUNCTION__, seq, GLBtcBtMpRptSeq);
 		ret = BT_STATUS_C2H_REQNUM_MISMATCH;
 		goto exit;
 	}
@@ -635,23 +689,23 @@ static u8 _btmpoper_cmd(PBTC_COEXIST pBtCoexist, u8 opcode, u8 opcodever, u8 *cm
 	/* Examine the status reported from C2H */
 	case BT_STATUS_OK:
 		ret = BT_STATUS_BT_OP_SUCCESS;
-		DBG_871X("%s: C2H status = BT_STATUS_BT_OP_SUCCESS\n", __FUNCTION__);
+		RTW_DBG("%s: C2H status = BT_STATUS_BT_OP_SUCCESS\n", __FUNCTION__);
 		break;
 	case BT_STATUS_VERSION_MISMATCH:
 		ret = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
-		DBG_871X("%s: C2H status = BT_STATUS_OPCODE_L_VERSION_MISMATCH\n", __FUNCTION__);
+		RTW_DBG("%s: C2H status = BT_STATUS_OPCODE_L_VERSION_MISMATCH\n", __FUNCTION__);
 		break;
 	case BT_STATUS_UNKNOWN_OPCODE:
 		ret = BT_STATUS_UNKNOWN_OPCODE_L;
-		DBG_871X("%s: C2H status = MP_BT_STATUS_UNKNOWN_OPCODE_L\n", __FUNCTION__);
+		RTW_DBG("%s: C2H status = MP_BT_STATUS_UNKNOWN_OPCODE_L\n", __FUNCTION__);
 		break;
 	case BT_STATUS_ERROR_PARAMETER:
 		ret = BT_STATUS_PARAMETER_FORMAT_ERROR_L;
-		DBG_871X("%s: C2H status = MP_BT_STATUS_PARAMETER_FORMAT_ERROR_L\n", __FUNCTION__);
+		RTW_DBG("%s: C2H status = MP_BT_STATUS_PARAMETER_FORMAT_ERROR_L\n", __FUNCTION__);
 		break;
 	default:
 		ret = BT_STATUS_UNKNOWN_STATUS_L;
-		DBG_871X("%s: C2H status = MP_BT_STATUS_UNKNOWN_STATUS_L\n", __FUNCTION__);
+		RTW_DBG("%s: C2H status = MP_BT_STATUS_UNKNOWN_STATUS_L\n", __FUNCTION__);
 		break;
 	}
 
@@ -661,49 +715,164 @@ exit:
 
 u32 halbtcoutsrc_GetBtPatchVer(PBTC_COEXIST pBtCoexist)
 {
-	if (_is_btfwver_valid(pBtCoexist, pBtCoexist->btInfo.btRealFwVer) == _TRUE)
-		goto exit;
+	if (pBtCoexist->bt_info.get_bt_fw_ver_cnt <= 5) {
+		if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+			_irqL irqL;
+			u8 ret;
+
+			_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+			ret = _btmpoper_cmd(pBtCoexist, BT_OP_GET_BT_VERSION, 0, NULL, 0);
+			if (BT_STATUS_BT_OP_SUCCESS == ret) {
+				pBtCoexist->bt_info.bt_real_fw_ver = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
+				pBtCoexist->bt_info.bt_fw_ver = *(GLBtcBtMpRptRsp + 2);
+				pBtCoexist->bt_info.get_bt_fw_ver_cnt++;
+			}
+
+			_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+		} else {
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+			u1Byte dataLen = 2;
+			u1Byte buf[4] = {0};
+
+			buf[0] = 0x0;	/* OP_Code */
+			buf[1] = 0x0;	/* OP_Code_Length */
+			BT_SendEventExtBtCoexControl(pBtCoexist->Adapter, _FALSE, dataLen, &buf[0]);
+#endif /* !CONFIG_BT_COEXIST_SOCKET_TRX */
+		}
+	}
+
+exit:
+	return pBtCoexist->bt_info.bt_real_fw_ver;
+}
+
+s32 halbtcoutsrc_GetWifiRssi(PADAPTER padapter)
+{
+	return rtw_phydm_get_min_rssi(padapter);
+}
+
+u32 halbtcoutsrc_GetBtCoexSupportedFeature(void *pBtcContext)
+{
+	PBTC_COEXIST pBtCoexist;
+	u32 ret = BT_STATUS_BT_OP_SUCCESS;
+	u32 data = 0;
+
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 
 	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		u8 buf[3] = {0};
 		_irqL irqL;
-		u8 ret;
+		u8 op_code;
+		u8 status;
+
+		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+		op_code = BT_OP_GET_BT_COEX_SUPPORTED_FEATURE;
+		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+		if (status == BT_STATUS_BT_OP_SUCCESS)
+			data = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
+		else
+			ret = SET_BT_MP_OPER_RET(op_code, status);
+
+		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+	} else
+		ret = BT_STATUS_NOT_IMPLEMENT;
+
+	return data;
+}
+
+u32 halbtcoutsrc_GetBtCoexSupportedVersion(void *pBtcContext)
+{
+	PBTC_COEXIST pBtCoexist;
+	u32 ret = BT_STATUS_BT_OP_SUCCESS;
+	u32 data = 0xFFFF;
+
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		u8 buf[3] = {0};
+		_irqL irqL;
+		u8 op_code;
+		u8 status;
 
 		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
 
-		ret = _btmpoper_cmd(pBtCoexist, BT_OP_GET_BT_VERSION, 0, NULL, 0);
-		if (BT_STATUS_BT_OP_SUCCESS == ret) {
-			pBtCoexist->btInfo.btRealFwVer = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
-			pBtCoexist->btInfo.btFwVer = *(GLBtcBtMpRptRsp+2);
-		}
-		pBtCoexist->btInfo.getBtFwVerCnt++;
+		op_code = BT_OP_GET_BT_COEX_SUPPORTED_VERSION;
+		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+		if (status == BT_STATUS_BT_OP_SUCCESS)
+			data = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
+		else
+			ret = SET_BT_MP_OPER_RET(op_code, status);
 
 		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
-	} else {
-#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-		u1Byte dataLen = 2;
-		u1Byte buf[4] = {0};
 
-		buf[0] = 0x0;	/* OP_Code */
-		buf[1] = 0x0;	/* OP_Code_Length */
-		BT_SendEventExtBtCoexControl(pBtCoexist->Adapter, _FALSE, dataLen, &buf[0]);
-#endif /* !CONFIG_BT_COEXIST_SOCKET_TRX */
-	}
+	} else
+		ret = BT_STATUS_NOT_IMPLEMENT;
 
-exit:
-	return pBtCoexist->btInfo.btRealFwVer;
+	return data;
 }
 
-s32 halbtcoutsrc_GetWifiRssi(PADAPTER padapter)
+u32 halbtcoutsrc_GetBtDeviceInfo(void *pBtcContext)
 {
-	PHAL_DATA_TYPE pHalData;
-	s32 UndecoratedSmoothedPWDB = 0;
+	PBTC_COEXIST pBtCoexist;
+	u32 ret = BT_STATUS_BT_OP_SUCCESS;
+	u32 btDeviceInfo = 0;
 
-	pHalData = GET_HAL_DATA(padapter);
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
+
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		u8 buf[3] = {0};
+		_irqL irqL;
+		u8 op_code;
+		u8 status;
+
+		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+		op_code = BT_OP_GET_BT_DEVICE_INFO;
+		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+		if (status == BT_STATUS_BT_OP_SUCCESS)
+			btDeviceInfo = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
+		else
+			ret = SET_BT_MP_OPER_RET(op_code, status);
+
+		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+	} else
+		ret = BT_STATUS_NOT_IMPLEMENT;
+
+	return btDeviceInfo;
+}
+
+u32 halbtcoutsrc_GetBtForbiddenSlotVal(void *pBtcContext)
+{
+	PBTC_COEXIST pBtCoexist;
+	u32 ret = BT_STATUS_BT_OP_SUCCESS;
+	u32 btForbiddenSlotVal = 0;
+
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
+
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		u8 buf[3] = {0};
+		_irqL irqL;
+		u8 op_code;
+		u8 status;
+
+		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
 
-	UndecoratedSmoothedPWDB = pHalData->EntryMinUndecoratedSmoothedPWDB;
+		op_code = BT_OP_GET_BT_FORBIDDEN_SLOT_VAL;
+		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+		if (status == BT_STATUS_BT_OP_SUCCESS)
+			btForbiddenSlotVal = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
+		else
+			ret = SET_BT_MP_OPER_RET(op_code, status);
+
+		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+	} else
+		ret = BT_STATUS_NOT_IMPLEMENT;
 
-	return UndecoratedSmoothedPWDB;
+	return btForbiddenSlotVal;
 }
 
 static u8 halbtcoutsrc_GetWifiScanAPNum(PADAPTER padapter)
@@ -737,6 +906,7 @@ u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
 	s32 *pS4Tmp;
 	u32 *pU4Tmp;
 	u8 *pU1Tmp;
+	u16 *pU2Tmp;
 	u8 ret;
 
 
@@ -749,227 +919,296 @@ u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
 	mlmeext = &padapter->mlmeextpriv;
 	bSoftApExist = _FALSE;
 	bVwifiExist = _FALSE;
-	pu8 = (u8*)pOutBuf;
-	pS4Tmp = (s32*)pOutBuf;
-	pU4Tmp = (u32*)pOutBuf;
-	pU1Tmp = (u8*)pOutBuf;
+	pu8 = (u8 *)pOutBuf;
+	pS4Tmp = (s32 *)pOutBuf;
+	pU4Tmp = (u32 *)pOutBuf;
+	pU1Tmp = (u8 *)pOutBuf;
+	pU2Tmp = (u16*)pOutBuf;
 	ret = _TRUE;
 
-	switch (getType)
-	{
-		case BTC_GET_BL_HS_OPERATION:
-			*pu8 = _FALSE;
-			ret = _FALSE;
-			break;
+	switch (getType) {
+	case BTC_GET_BL_HS_OPERATION:
+		*pu8 = _FALSE;
+		ret = _FALSE;
+		break;
 
-		case BTC_GET_BL_HS_CONNECTING:
-			*pu8 = _FALSE;
-			ret = _FALSE;
-			break;
+	case BTC_GET_BL_HS_CONNECTING:
+		*pu8 = _FALSE;
+		ret = _FALSE;
+		break;
 
-		case BTC_GET_BL_WIFI_CONNECTED:
-			*pu8 = check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE);
-#ifdef CONFIG_CONCURRENT_MODE
-			if ((_FALSE == *pu8) && padapter->pbuddy_adapter)
-			{
-				*pu8 = check_fwstate(&padapter->pbuddy_adapter->mlmepriv, WIFI_ASOC_STATE);
-			}
-#endif // CONFIG_CONCURRENT_MODE
-			break;
+	case BTC_GET_BL_WIFI_FW_READY:
+		*pu8 = halbtcoutsrc_is_fw_ready(pBtCoexist);
+		break;
 
-		case BTC_GET_BL_WIFI_BUSY:
-			*pu8 = halbtcoutsrc_IsWifiBusy(padapter);
-			break;
+	case BTC_GET_BL_WIFI_CONNECTED:
+		*pu8 = (rtw_mi_check_status(padapter, MI_LINKED)) ? _TRUE : _FALSE;
+		break;
 
-		case BTC_GET_BL_WIFI_SCAN:
-#if 0			
-			*pu8 = check_fwstate(&padapter->mlmepriv, WIFI_SITE_MONITOR);
-#ifdef CONFIG_CONCURRENT_MODE
-			if ((_FALSE == *pu8) && padapter->pbuddy_adapter)
-			{
-				*pu8 = check_fwstate(&padapter->pbuddy_adapter->mlmepriv, WIFI_SITE_MONITOR);
-			}
-#endif // CONFIG_CONCURRENT_MODE
-#else		
-			/* Use the value of the new variable GLBtcWiFiInScanState to judge whether WiFi is in scan state or not, since the originally used flag 
-				WIFI_SITE_MONITOR in fwstate may not be cleared in time */
-			*pu8 = GLBtcWiFiInScanState;
-#endif
-			break;
+	case BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED:
+		*pu8 = halbtcoutsrc_IsDualBandConnected(padapter);
+		break;
 
-		case BTC_GET_BL_WIFI_LINK:
-			*pu8 = check_fwstate(&padapter->mlmepriv, WIFI_UNDER_LINKING);
-#ifdef CONFIG_CONCURRENT_MODE
-			if ((_FALSE == *pu8) && padapter->pbuddy_adapter)
-			{
-				*pu8 = check_fwstate(&padapter->pbuddy_adapter->mlmepriv, WIFI_UNDER_LINKING);
-			}
-#endif // CONFIG_CONCURRENT_MODE
-			break;
+	case BTC_GET_BL_WIFI_BUSY:
+		*pu8 = halbtcoutsrc_IsWifiBusy(padapter);
+		break;
 
-		case BTC_GET_BL_WIFI_ROAM:
-			*pu8 = check_fwstate(&padapter->mlmepriv, WIFI_UNDER_LINKING);
-#ifdef CONFIG_CONCURRENT_MODE
-			if ((_FALSE == *pu8) && padapter->pbuddy_adapter)
-			{
-				*pu8 = check_fwstate(&padapter->pbuddy_adapter->mlmepriv, WIFI_UNDER_LINKING);
-			}
-#endif // CONFIG_CONCURRENT_MODE
-			break;
+	case BTC_GET_BL_WIFI_SCAN:
+#if 0
+		*pu8 = (rtw_mi_check_fwstate(padapter, WIFI_SITE_MONITOR)) ? _TRUE : _FALSE;
+#else
+		/* Use the value of the new variable GLBtcWiFiInScanState to judge whether WiFi is in scan state or not, since the originally used flag
+			WIFI_SITE_MONITOR in fwstate may not be cleared in time */
+		*pu8 = GLBtcWiFiInScanState;
+#endif
+		break;
 
-		case BTC_GET_BL_WIFI_4_WAY_PROGRESS:
-			*pu8 = _FALSE;
-			break;
+	case BTC_GET_BL_WIFI_LINK:
+		*pu8 = (rtw_mi_check_status(padapter, MI_STA_LINKING)) ? _TRUE : _FALSE;
+		break;
 
-		case BTC_GET_BL_WIFI_UNDER_5G:
-			*pu8 = (pHalData->CurrentBandType == 1)? _TRUE : _FALSE;
-			break;
+	case BTC_GET_BL_WIFI_ROAM:
+		*pu8 = (rtw_mi_check_status(padapter, MI_STA_LINKING)) ? _TRUE : _FALSE;
+		break;
 
-		case BTC_GET_BL_WIFI_AP_MODE_ENABLE:
-			*pu8 = check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE);
-#ifdef CONFIG_CONCURRENT_MODE
-			if ((_FALSE == *pu8) && padapter->pbuddy_adapter)
-			{
-				*pu8 = check_fwstate(&padapter->pbuddy_adapter->mlmepriv, WIFI_AP_STATE);
-			}
-#endif // CONFIG_CONCURRENT_MODE
-			break;
+	case BTC_GET_BL_WIFI_4_WAY_PROGRESS:
+		*pu8 = _FALSE;
+		break;
 
-		case BTC_GET_BL_WIFI_ENABLE_ENCRYPTION:
-			*pu8 = padapter->securitypriv.dot11PrivacyAlgrthm == 0? _FALSE: _TRUE;
-			break;
+	case BTC_GET_BL_WIFI_UNDER_5G:
+		*pu8 = (pHalData->current_band_type == BAND_ON_5G) ? _TRUE : _FALSE;
+		break;
 
-		case BTC_GET_BL_WIFI_UNDER_B_MODE:
-			if (mlmeext->cur_wireless_mode == WIRELESS_11B)
-				*pu8 = _TRUE;
-			else
-				*pu8 = _FALSE;
-			break;
+	case BTC_GET_BL_WIFI_AP_MODE_ENABLE:
+		*pu8 = (rtw_mi_check_status(padapter, MI_AP_MODE)) ? _TRUE : _FALSE;
+		break;
 
-		case BTC_GET_BL_WIFI_IS_IN_MP_MODE:
-			if (padapter->registrypriv.mp_mode == 0)
-			{
-				*pu8 = _FALSE;
-			}
-			else
-			{
-				*pu8 = _TRUE;
-			}
-			break;
+	case BTC_GET_BL_WIFI_ENABLE_ENCRYPTION:
+		*pu8 = padapter->securitypriv.dot11PrivacyAlgrthm == 0 ? _FALSE : _TRUE;
+		break;
 
-		case BTC_GET_BL_EXT_SWITCH:
+	case BTC_GET_BL_WIFI_UNDER_B_MODE:
+		if (mlmeext->cur_wireless_mode == WIRELESS_11B)
+			*pu8 = _TRUE;
+		else
 			*pu8 = _FALSE;
-			break;
-		case BTC_GET_BL_IS_ASUS_8723B:
-			/* Always return FALSE in linux driver since this case is added only for windows driver */
+		break;
+
+	case BTC_GET_BL_WIFI_IS_IN_MP_MODE:
+		if (padapter->registrypriv.mp_mode == 0)
 			*pu8 = _FALSE;
-			break;
+		else
+			*pu8 = _TRUE;
+		break;
 
-		case BTC_GET_S4_WIFI_RSSI:
-			*pS4Tmp = halbtcoutsrc_GetWifiRssi(padapter);
-			break;
+	case BTC_GET_BL_EXT_SWITCH:
+		*pu8 = _FALSE;
+		break;
+	case BTC_GET_BL_IS_ASUS_8723B:
+		/* Always return FALSE in linux driver since this case is added only for windows driver */
+		*pu8 = _FALSE;
+		break;
 
-		case BTC_GET_S4_HS_RSSI:
-			*pS4Tmp = 0;
-			ret = _FALSE;
-			break;
+	case BTC_GET_BL_RF4CE_CONNECTED:
+#ifdef CONFIG_RF4CE_COEXIST
+		if (hal_btcoex_get_rf4ce_link_state() == 0)
+			*pu8 = FALSE;
+		else
+			*pu8 = TRUE;
+#else
+		*pu8 = FALSE;
+#endif
+		break;
+
+	case BTC_GET_S4_WIFI_RSSI:
+		*pS4Tmp = halbtcoutsrc_GetWifiRssi(padapter);
+		break;
 
-		case BTC_GET_U4_WIFI_BW:
-			if (IsLegacyOnly(mlmeext->cur_wireless_mode))
-				*pU4Tmp = BTC_WIFI_BW_LEGACY;
-			else if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_20)
+	case BTC_GET_S4_HS_RSSI:
+		*pS4Tmp = 0;
+		ret = _FALSE;
+		break;
+
+	case BTC_GET_U4_WIFI_BW:
+		if (IsLegacyOnly(mlmeext->cur_wireless_mode))
+			*pU4Tmp = BTC_WIFI_BW_LEGACY;
+		else {
+			switch (pHalData->current_channel_bw) {
+			case CHANNEL_WIDTH_20:
 				*pU4Tmp = BTC_WIFI_BW_HT20;
-			else if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_40)
+				break;
+			case CHANNEL_WIDTH_40:
 				*pU4Tmp = BTC_WIFI_BW_HT40;
-			else
-				*pU4Tmp = BTC_WIFI_BW_HT40; /* todo */
-			break;
+				break;
+			case CHANNEL_WIDTH_80:
+				*pU4Tmp = BTC_WIFI_BW_HT80;
+				break;
+			case CHANNEL_WIDTH_160:
+				*pU4Tmp = BTC_WIFI_BW_HT160;
+				break;
+			default:
+				RTW_INFO("[BTCOEX] unknown bandwidth(%d)\n", pHalData->current_channel_bw);
+				*pU4Tmp = BTC_WIFI_BW_HT40;
+				break;
+			}
 
-		case BTC_GET_U4_WIFI_TRAFFIC_DIRECTION:
-			{
-				PRT_LINK_DETECT_T plinkinfo;
-				plinkinfo = &padapter->mlmepriv.LinkDetectInfo;
+		}
+		break;
 
-				if (plinkinfo->NumTxOkInPeriod > plinkinfo->NumRxOkInPeriod)
-					*pU4Tmp = BTC_WIFI_TRAFFIC_TX;
-				else
-					*pU4Tmp = BTC_WIFI_TRAFFIC_RX;
-			}
-			break;
+	case BTC_GET_U4_WIFI_TRAFFIC_DIRECTION: {
+		PRT_LINK_DETECT_T plinkinfo;
+		plinkinfo = &padapter->mlmepriv.LinkDetectInfo;
 
-		case BTC_GET_U4_WIFI_FW_VER:
-			*pU4Tmp = pHalData->FirmwareVersion << 16;
-			*pU4Tmp |= pHalData->FirmwareSubVersion;
-			break;
+		if (plinkinfo->NumTxOkInPeriod > plinkinfo->NumRxOkInPeriod)
+			*pU4Tmp = BTC_WIFI_TRAFFIC_TX;
+		else
+			*pU4Tmp = BTC_WIFI_TRAFFIC_RX;
+	}
+		break;
 
-		case BTC_GET_U4_WIFI_LINK_STATUS:
-			*pU4Tmp = halbtcoutsrc_GetWifiLinkStatus(pBtCoexist);
-			break;
+	case BTC_GET_U4_WIFI_FW_VER:
+		*pU4Tmp = pHalData->firmware_version << 16;
+		*pU4Tmp |= pHalData->firmware_sub_version;
+		break;
 
-		case BTC_GET_U4_BT_PATCH_VER:
-			*pU4Tmp = halbtcoutsrc_GetBtPatchVer(pBtCoexist);
-			break;
+	case BTC_GET_U4_WIFI_LINK_STATUS:
+		*pU4Tmp = halbtcoutsrc_GetWifiLinkStatus(pBtCoexist);
+		break;
 
-		case BTC_GET_U1_WIFI_DOT11_CHNL:
-			*pU1Tmp = padapter->mlmeextpriv.cur_channel;
-			break;
+	case BTC_GET_U4_BT_PATCH_VER:
+		*pU4Tmp = halbtcoutsrc_GetBtPatchVer(pBtCoexist);
+		break;
 
-		case BTC_GET_U1_WIFI_CENTRAL_CHNL:
-			*pU1Tmp = pHalData->CurrentChannel;
-			break;
+	case BTC_GET_U4_VENDOR:
+		*pU4Tmp = BTC_VENDOR_OTHER;
+		break;
 
-		case BTC_GET_U1_WIFI_HS_CHNL:
-			*pU1Tmp = 0;
-			ret = _FALSE;
-			break;
+	case BTC_GET_U4_SUPPORTED_VERSION:
+		*pU4Tmp = halbtcoutsrc_GetBtCoexSupportedVersion(pBtCoexist);
+		break;
+	case BTC_GET_U4_SUPPORTED_FEATURE:
+		*pU4Tmp = halbtcoutsrc_GetBtCoexSupportedFeature(pBtCoexist);
+		break;
 
-		case BTC_GET_U1_MAC_PHY_MODE:
-//			*pU1Tmp = BTC_SMSP;
-//			*pU1Tmp = BTC_DMSP;
-//			*pU1Tmp = BTC_DMDP;
-//			*pU1Tmp = BTC_MP_UNKNOWN;
-			break;
+	case BTC_GET_U4_BT_DEVICE_INFO:
+		*pU4Tmp = halbtcoutsrc_GetBtDeviceInfo(pBtCoexist);
+		break;
+
+	case BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL:
+		*pU4Tmp = halbtcoutsrc_GetBtForbiddenSlotVal(pBtCoexist);
+		break;
+
+	case BTC_GET_U4_WIFI_IQK_TOTAL:
+		*pU4Tmp = pHalData->odmpriv.n_iqk_cnt;
+		break;
+
+	case BTC_GET_U4_WIFI_IQK_OK:
+		*pU4Tmp = pHalData->odmpriv.n_iqk_ok_cnt;
+		break;
+
+	case BTC_GET_U4_WIFI_IQK_FAIL:
+		*pU4Tmp = pHalData->odmpriv.n_iqk_fail_cnt;
+		break;
+
+	case BTC_GET_U1_WIFI_DOT11_CHNL:
+		*pU1Tmp = padapter->mlmeextpriv.cur_channel;
+		break;
 
-		case BTC_GET_U1_AP_NUM:
-			*pU1Tmp = halbtcoutsrc_GetWifiScanAPNum(padapter);
+	case BTC_GET_U1_WIFI_CENTRAL_CHNL:
+		*pU1Tmp = pHalData->current_channel;
+		break;
+
+	case BTC_GET_U1_WIFI_HS_CHNL:
+		*pU1Tmp = 0;
+		ret = _FALSE;
+		break;
+
+	case BTC_GET_U1_WIFI_P2P_CHNL:
+#ifdef CONFIG_P2P
+		{
+			struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+			
+			*pU1Tmp = pwdinfo->operating_channel;
+		}
+#else
+		*pU1Tmp = 0;
+#endif
+		break;
+
+	case BTC_GET_U1_MAC_PHY_MODE:
+		/*			*pU1Tmp = BTC_SMSP;
+		 *			*pU1Tmp = BTC_DMSP;
+		 *			*pU1Tmp = BTC_DMDP;
+		 *			*pU1Tmp = BTC_MP_UNKNOWN; */
+		break;
+
+	case BTC_GET_U1_AP_NUM:
+		*pU1Tmp = halbtcoutsrc_GetWifiScanAPNum(padapter);
+		break;
+	case BTC_GET_U1_ANT_TYPE:
+		switch (pHalData->bt_coexist.btAntisolation) {
+		case 0:
+			*pU1Tmp = (u1Byte)BTC_ANT_TYPE_0;
+			pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_0;
 			break;
-		case BTC_GET_U1_ANT_TYPE:
-			switch(pHalData->bt_coexist.btAntisolation)
-			{
-				case 0:
-					*pU1Tmp = (u1Byte)BTC_ANT_TYPE_0;
-					pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_0;
-					break;
-				case 1:
-					*pU1Tmp = (u1Byte)BTC_ANT_TYPE_1;
-					pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_1;
-					break;
-				case 2:
-					*pU1Tmp = (u1Byte)BTC_ANT_TYPE_2;
-					pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_2;
-					break;
-				case 3:
-					*pU1Tmp = (u1Byte)BTC_ANT_TYPE_3;
-					pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_3;
-					break;
-				case 4:
-					*pU1Tmp = (u1Byte)BTC_ANT_TYPE_4;
-					pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_4;
-					break;
-			}
+		case 1:
+			*pU1Tmp = (u1Byte)BTC_ANT_TYPE_1;
+			pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_1;
 			break;
-		case BTC_GET_U1_IOT_PEER:
-			*pU1Tmp = mlmeext->mlmext_info.assoc_AP_vendor;
+		case 2:
+			*pU1Tmp = (u1Byte)BTC_ANT_TYPE_2;
+			pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_2;
 			break;
-
-		//=======1Ant===========
-		case BTC_GET_U1_LPS_MODE:
-			*pU1Tmp = padapter->dvobj->pwrctl_priv.pwr_mode;
+		case 3:
+			*pU1Tmp = (u1Byte)BTC_ANT_TYPE_3;
+			pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_3;
 			break;
-
-		default:
-			ret = _FALSE;
+		case 4:
+			*pU1Tmp = (u1Byte)BTC_ANT_TYPE_4;
+			pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_4;
 			break;
+		}
+		break;
+	case BTC_GET_U1_IOT_PEER:
+		*pU1Tmp = mlmeext->mlmext_info.assoc_AP_vendor;
+		break;
+
+	/* =======1Ant=========== */
+	case BTC_GET_U1_LPS_MODE:
+		*pU1Tmp = padapter->dvobj->pwrctl_priv.pwr_mode;
+		break;
+
+	case BTC_GET_U2_BEACON_PERIOD:
+		*pU2Tmp = mlmeext->mlmext_info.bcn_interval;
+		break;
+
+	default:
+		ret = _FALSE;
+		break;
+	}
+
+	return ret;
+}
+
+u16 halbtcoutsrc_LnaConstrainLvl(void *pBtcContext, u8 *lna_constrain_level)
+{
+	PBTC_COEXIST pBtCoexist;
+	u16 ret = BT_STATUS_BT_OP_SUCCESS;
+
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
+
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		_irqL irqL;
+		u8 op_code;
+
+		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+		ret = _btmpoper_cmd(pBtCoexist, BT_OP_SET_BT_LANCONSTRAIN_LEVEL, 0, lna_constrain_level, 1);
+
+		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+	} else { 
+		ret = BT_STATUS_NOT_IMPLEMENT;
+		RTW_INFO("%s halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == FALSE\n", __func__);
 	}
 
 	return ret;
@@ -984,198 +1223,207 @@ u8 halbtcoutsrc_Set(void *pBtcContext, u8 setType, void *pInBuf)
 	u8 *pU1Tmp;
 	u32	*pU4Tmp;
 	u8 ret;
+	u8 result = _TRUE;
 
 
 	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 	padapter = pBtCoexist->Adapter;
 	pHalData = GET_HAL_DATA(padapter);
-	pu8 = (u8*)pInBuf;
-	pU1Tmp = (u8*)pInBuf;
-	pU4Tmp = (u32*)pInBuf;
+	pu8 = (u8 *)pInBuf;
+	pU1Tmp = (u8 *)pInBuf;
+	pU4Tmp = (u32 *)pInBuf;
 	ret = _TRUE;
 
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return _FALSE;
 
-	switch (setType)
-	{
-		// set some u8 type variables.
-		case BTC_SET_BL_BT_DISABLE:
-			pBtCoexist->btInfo.bBtDisabled = *pu8;
-			break;
+	switch (setType) {
+	/* set some u8 type variables. */
+	case BTC_SET_BL_BT_DISABLE:
+		pBtCoexist->bt_info.bt_disabled = *pu8;
+		break;
 
-		case BTC_SET_BL_BT_TRAFFIC_BUSY:
-			pBtCoexist->btInfo.bBtBusy = *pu8;
-			break;
+	case BTC_SET_BL_BT_ENABLE_DISABLE_CHANGE:
+		pBtCoexist->bt_info.bt_enable_disable_change = *pu8;
+		break;
 
-		case BTC_SET_BL_BT_LIMITED_DIG:
-			pBtCoexist->btInfo.bLimitedDig = *pu8;
-			break;
+	case BTC_SET_BL_BT_TRAFFIC_BUSY:
+		pBtCoexist->bt_info.bt_busy = *pu8;
+		break;
 
-		case BTC_SET_BL_FORCE_TO_ROAM:
-			pBtCoexist->btInfo.bForceToRoam = *pu8;
-			break;
+	case BTC_SET_BL_BT_LIMITED_DIG:
+		pBtCoexist->bt_info.limited_dig = *pu8;
+		break;
 
-		case BTC_SET_BL_TO_REJ_AP_AGG_PKT:
-			pBtCoexist->btInfo.bRejectAggPkt = *pu8;
-			break;
+	case BTC_SET_BL_FORCE_TO_ROAM:
+		pBtCoexist->bt_info.force_to_roam = *pu8;
+		break;
 
-		case BTC_SET_BL_BT_CTRL_AGG_SIZE:
-			pBtCoexist->btInfo.bBtCtrlAggBufSize = *pu8;
-			break;
+	case BTC_SET_BL_TO_REJ_AP_AGG_PKT:
+		pBtCoexist->bt_info.reject_agg_pkt = *pu8;
+		break;
 
-		case BTC_SET_BL_INC_SCAN_DEV_NUM:
-			pBtCoexist->btInfo.bIncreaseScanDevNum = *pu8;
-			break;
+	case BTC_SET_BL_BT_CTRL_AGG_SIZE:
+		pBtCoexist->bt_info.bt_ctrl_agg_buf_size = *pu8;
+		break;
 
-		case BTC_SET_BL_BT_TX_RX_MASK:
-			pBtCoexist->btInfo.bBtTxRxMask = *pu8;
-			break;
+	case BTC_SET_BL_INC_SCAN_DEV_NUM:
+		pBtCoexist->bt_info.increase_scan_dev_num = *pu8;
+		break;
 
-		case BTC_SET_BL_MIRACAST_PLUS_BT:
-			pBtCoexist->btInfo.bMiracastPlusBt = *pu8;
-			break;
+	case BTC_SET_BL_BT_TX_RX_MASK:
+		pBtCoexist->bt_info.bt_tx_rx_mask = *pu8;
+		break;
 
-		// set some u8 type variables.
-		case BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON:
-			pBtCoexist->btInfo.rssiAdjustForAgcTableOn = *pU1Tmp;
-			break;
+	case BTC_SET_BL_MIRACAST_PLUS_BT:
+		pBtCoexist->bt_info.miracast_plus_bt = *pu8;
+		break;
 
-		case BTC_SET_U1_AGG_BUF_SIZE:
-			pBtCoexist->btInfo.aggBufSize = *pU1Tmp;
-			break;
+	/* set some u8 type variables. */
+	case BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON:
+		pBtCoexist->bt_info.rssi_adjust_for_agc_table_on = *pU1Tmp;
+		break;
+
+	case BTC_SET_U1_AGG_BUF_SIZE:
+		pBtCoexist->bt_info.agg_buf_size = *pU1Tmp;
+		break;
 
-		// the following are some action which will be triggered
-		case BTC_SET_ACT_GET_BT_RSSI:
+	/* the following are some action which will be triggered */
+	case BTC_SET_ACT_GET_BT_RSSI:
 #if 0
-			BT_SendGetBtRssiEvent(padapter);
+		BT_SendGetBtRssiEvent(padapter);
 #else
-			ret = _FALSE;
+		ret = _FALSE;
 #endif
-			break;
+		break;
 
-		case BTC_SET_ACT_AGGREGATE_CTRL:
-			halbtcoutsrc_AggregationCheck(pBtCoexist);
-			break;
+	case BTC_SET_ACT_AGGREGATE_CTRL:
+		halbtcoutsrc_AggregationCheck(pBtCoexist);
+		break;
 
-		//=======1Ant===========
-		// set some u8 type variables.
-		case BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE:
-			pBtCoexist->btInfo.rssiAdjustFor1AntCoexType = *pU1Tmp;
-			break;
+	/* =======1Ant=========== */
+	/* set some u8 type variables. */
+	case BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE:
+		pBtCoexist->bt_info.rssi_adjust_for_1ant_coex_type = *pU1Tmp;
+		break;
 
-		case BTC_SET_U1_LPS_VAL:
-			pBtCoexist->btInfo.lpsVal = *pU1Tmp;
-			break;
+	case BTC_SET_U1_LPS_VAL:
+		pBtCoexist->bt_info.lps_val = *pU1Tmp;
+		break;
 
-		case BTC_SET_U1_RPWM_VAL:
-			pBtCoexist->btInfo.rpwmVal = *pU1Tmp;
-			break;
+	case BTC_SET_U1_RPWM_VAL:
+		pBtCoexist->bt_info.rpwm_val = *pU1Tmp;
+		break;
 
-		// the following are some action which will be triggered
-		case BTC_SET_ACT_LEAVE_LPS:
-			halbtcoutsrc_LeaveLps(pBtCoexist);
-			break;
+	/* the following are some action which will be triggered */
+	case BTC_SET_ACT_LEAVE_LPS:
+		result = halbtcoutsrc_LeaveLps(pBtCoexist);
+		break;
 
-		case BTC_SET_ACT_ENTER_LPS:
-			halbtcoutsrc_EnterLps(pBtCoexist);
-			break;
+	case BTC_SET_ACT_ENTER_LPS:
+		halbtcoutsrc_EnterLps(pBtCoexist);
+		break;
 
-		case BTC_SET_ACT_NORMAL_LPS:
-			halbtcoutsrc_NormalLps(pBtCoexist);
-			break;
+	case BTC_SET_ACT_NORMAL_LPS:
+		halbtcoutsrc_NormalLps(pBtCoexist);
+		break;
 
-		case BTC_SET_ACT_DISABLE_LOW_POWER:
-			halbtcoutsrc_DisableLowPower(pBtCoexist, *pu8);
-			break;
+	case BTC_SET_ACT_PRE_NORMAL_LPS:
+		halbtcoutsrc_Pre_NormalLps(pBtCoexist);
+		break;
 
-		case BTC_SET_ACT_UPDATE_RAMASK:
-			pBtCoexist->btInfo.raMask = *pU4Tmp;
+	case BTC_SET_ACT_POST_NORMAL_LPS:
+		halbtcoutsrc_Post_NormalLps(pBtCoexist);
+		break;
 
-			if (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE) == _TRUE)
-			{
-				struct sta_info *psta;
-				PWLAN_BSSID_EX cur_network;
+	case BTC_SET_ACT_DISABLE_LOW_POWER:
+		halbtcoutsrc_DisableLowPower(pBtCoexist, *pu8);
+		break;
 
-				cur_network = &padapter->mlmeextpriv.mlmext_info.network;
-				psta = rtw_get_stainfo(&padapter->stapriv, cur_network->MacAddress);
-				rtw_hal_update_ra_mask(psta, 0);
-			}
-			break;
+	case BTC_SET_ACT_UPDATE_RAMASK:
+		/*
+		pBtCoexist->bt_info.ra_mask = *pU4Tmp;
 
-		case BTC_SET_ACT_SEND_MIMO_PS:
-			{
-				u8 newMimoPsMode = 3;
-				struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
-				struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
-
-				/* *pU1Tmp = 0 use SM_PS static type */
-				/* *pU1Tmp = 1 disable SM_PS */
-				if (*pU1Tmp == 0)
-					newMimoPsMode = WLAN_HT_CAP_SM_PS_STATIC;
-				else if (*pU1Tmp == 1)
-					newMimoPsMode = WLAN_HT_CAP_SM_PS_DISABLED;
-												  
-				if (check_fwstate(&padapter->mlmepriv , WIFI_ASOC_STATE) == _TRUE) {
-					/* issue_action_SM_PS(padapter, get_my_bssid(&(pmlmeinfo->network)), newMimoPsMode); */
-					issue_action_SM_PS_wait_ack(padapter , get_my_bssid(&(pmlmeinfo->network)) , newMimoPsMode, 3 , 1);
-				}
-			}
-			break;
+		if (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE) == _TRUE) {
+			struct sta_info *psta;
+			PWLAN_BSSID_EX cur_network;
 
-		case BTC_SET_ACT_CTRL_BT_INFO:
+			cur_network = &padapter->mlmeextpriv.mlmext_info.network;
+			psta = rtw_get_stainfo(&padapter->stapriv, cur_network->MacAddress);
+			rtw_hal_update_ra_mask(psta);
+		}
+		*/
+		break;
+
+	case BTC_SET_ACT_SEND_MIMO_PS: {
+		u8 newMimoPsMode = 3;
+		struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+		struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+
+		/* *pU1Tmp = 0 use SM_PS static type */
+		/* *pU1Tmp = 1 disable SM_PS */
+		if (*pU1Tmp == 0)
+			newMimoPsMode = WLAN_HT_CAP_SM_PS_STATIC;
+		else if (*pU1Tmp == 1)
+			newMimoPsMode = WLAN_HT_CAP_SM_PS_DISABLED;
+
+		if (check_fwstate(&padapter->mlmepriv , WIFI_ASOC_STATE) == _TRUE) {
+			/* issue_action_SM_PS(padapter, get_my_bssid(&(pmlmeinfo->network)), newMimoPsMode); */
+			issue_action_SM_PS_wait_ack(padapter , get_my_bssid(&(pmlmeinfo->network)) , newMimoPsMode, 3 , 1);
+		}
+	}
+	break;
+
+	case BTC_SET_ACT_CTRL_BT_INFO:
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-			{
-				u8 dataLen = *pU1Tmp;
-				u8 tmpBuf[20];
-				if (dataLen)
-				{
-					_rtw_memcpy(tmpBuf, pU1Tmp+1, dataLen);
-				}
-				BT_SendEventExtBtInfoControl(padapter, dataLen, &tmpBuf[0]);
-			}
-#else //!CONFIG_BT_COEXIST_SOCKET_TRX
-			ret = _FALSE;
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-			break;
+		{
+			u8 dataLen = *pU1Tmp;
+			u8 tmpBuf[BTC_TMP_BUF_SHORT];
+			if (dataLen)
+				_rtw_memcpy(tmpBuf, pU1Tmp + 1, dataLen);
+			BT_SendEventExtBtInfoControl(padapter, dataLen, &tmpBuf[0]);
+		}
+#else /* !CONFIG_BT_COEXIST_SOCKET_TRX */
+		ret = _FALSE;
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+		break;
 
-		case BTC_SET_ACT_CTRL_BT_COEX:
+	case BTC_SET_ACT_CTRL_BT_COEX:
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-			{
-				u8 dataLen = *pU1Tmp;
-				u8 tmpBuf[20];
-				if (dataLen)
-				{
-					_rtw_memcpy(tmpBuf, pU1Tmp+1, dataLen);
-				}
-				BT_SendEventExtBtCoexControl(padapter, _FALSE, dataLen, &tmpBuf[0]);
-			}
-#else //!CONFIG_BT_COEXIST_SOCKET_TRX
-			ret = _FALSE;
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-			break;
-		case BTC_SET_ACT_CTRL_8723B_ANT:
+		{
+			u8 dataLen = *pU1Tmp;
+			u8 tmpBuf[BTC_TMP_BUF_SHORT];
+			if (dataLen)
+				_rtw_memcpy(tmpBuf, pU1Tmp + 1, dataLen);
+			BT_SendEventExtBtCoexControl(padapter, _FALSE, dataLen, &tmpBuf[0]);
+		}
+#else /* !CONFIG_BT_COEXIST_SOCKET_TRX */
+		ret = _FALSE;
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+		break;
+	case BTC_SET_ACT_CTRL_8723B_ANT:
 #if 0
-			{
-				u1Byte	dataLen=*pU1Tmp;
-				u1Byte	tmpBuf[20];
-				if(dataLen)
-				{
-					PlatformMoveMemory(&tmpBuf[0], pU1Tmp+1, dataLen);
-				}
-				BT_Set8723bAnt(Adapter, dataLen, &tmpBuf[0]);
-			}
+		{
+			u1Byte	dataLen = *pU1Tmp;
+			u1Byte	tmpBuf[BTC_TMP_BUF_SHORT];
+			if (dataLen)
+				PlatformMoveMemory(&tmpBuf[0], pU1Tmp + 1, dataLen);
+			BT_Set8723bAnt(Adapter, dataLen, &tmpBuf[0]);
+		}
 #else
-			ret = _FALSE;
+		ret = _FALSE;
 #endif
-			break;
-		//=====================
-		default:
-			ret = _FALSE;
-			break;
+		break;
+	case BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL:
+		halbtcoutsrc_LnaConstrainLvl(pBtCoexist, pu8);
+		break;
+	/* ===================== */
+	default:
+		ret = _FALSE;
+		break;
 	}
 
-	return ret;
+	return result;
 }
 
 u8 halbtcoutsrc_UnderIps(PBTC_COEXIST pBtCoexist)
@@ -1189,22 +1437,16 @@ u8 halbtcoutsrc_UnderIps(PBTC_COEXIST pBtCoexist)
 	bMacPwrCtrlOn = _FALSE;
 
 	if ((_TRUE == pwrpriv->bips_processing)
-		&& (IPS_NONE != pwrpriv->ips_mode_req)
-		)
-	{
+	    && (IPS_NONE != pwrpriv->ips_mode_req)
+	   )
 		return _TRUE;
-	}
 
 	if (rf_off == pwrpriv->rf_pwrstate)
-	{
 		return _TRUE;
-	}
 
 	rtw_hal_get_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
 	if (_FALSE == bMacPwrCtrlOn)
-	{
 		return _TRUE;
-	}
 
 	return _FALSE;
 }
@@ -1227,47 +1469,132 @@ void halbtcoutsrc_DisplayCoexStatistics(PBTC_COEXIST pBtCoexist)
 	PBT_MGNT pBtMgnt = &padapter->MgntInfo.BtInfo.BtMgnt;
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 	u8 *cliBuf = pBtCoexist->cliBuf;
-	u8 i;
+	u1Byte			i, j;
+	u1Byte			tmpbuf[BTC_TMP_BUF_SHORT];
+
+
+	if (gl_coex_offload.cnt_h2c_sent) {
+		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Coex h2c notify]============");
+		CL_PRINTF(cliBuf);
+
+		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = H2c(%d)/Ack(%d)", "Coex h2c/c2h overall statistics",
+			gl_coex_offload.cnt_h2c_sent, gl_coex_offload.cnt_c2h_ack);
+		for (j = 0; j < COL_STATUS_MAX; j++) {
+			if (gl_coex_offload.status[j]) {
+				CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.status[j]);
+				CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
+			}
+		}
+		CL_PRINTF(cliBuf);
+	}
+	for (i = 0; i < COL_OP_WIFI_OPCODE_MAX; i++) {
+		if (gl_coex_offload.h2c_record[i].count) {
+			/*==========================================*/
+			/*	H2C result statistics*/
+			/*==========================================*/
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = total:%d", coexOpcodeString[i], gl_coex_offload.h2c_record[i].count);
+			for (j = 0; j < COL_STATUS_MAX; j++) {
+				if (gl_coex_offload.h2c_record[i].status[j]) {
+					CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.h2c_record[i].status[j]);
+					CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
+				}
+			}
+			CL_PRINTF(cliBuf);
+			/*==========================================*/
+			/*	H2C/C2H content*/
+			/*==========================================*/
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = ", "H2C / C2H content");
+			for (j = 0; j < gl_coex_offload.h2c_record[i].h2c_len; j++) {
+				CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, "%02x ", gl_coex_offload.h2c_record[i].h2c_buf[j]);
+				CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, 3);
+			}
+			if (gl_coex_offload.h2c_record[i].c2h_ack_len) {
+				CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, "/ ", 2);
+				for (j = 0; j < gl_coex_offload.h2c_record[i].c2h_ack_len; j++) {
+					CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, "%02x ", gl_coex_offload.h2c_record[i].c2h_ack_buf[j]);
+					CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, 3);
+				}
+			}
+			CL_PRINTF(cliBuf);
+			/*==========================================*/
+		}
+	}
+
+	if (gl_coex_offload.cnt_c2h_ind) {
+		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Coex c2h indication]============");
+		CL_PRINTF(cliBuf);
+
+		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = Ind(%d)", "C2H indication statistics",
+			   gl_coex_offload.cnt_c2h_ind);
+		for (j = 0; j < COL_STATUS_MAX; j++) {
+			if (gl_coex_offload.c2h_ind_status[j]) {
+				CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.c2h_ind_status[j]);
+				CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
+			}
+		}
+		CL_PRINTF(cliBuf);
+	}
+	for (i = 0; i < COL_IND_MAX; i++) {
+		if (gl_coex_offload.c2h_ind_record[i].count) {
+			/*==========================================*/
+			/*	H2C result statistics*/
+			/*==========================================*/
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = total:%d", coexIndTypeString[i], gl_coex_offload.c2h_ind_record[i].count);
+			for (j = 0; j < COL_STATUS_MAX; j++) {
+				if (gl_coex_offload.c2h_ind_record[i].status[j]) {
+					CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.c2h_ind_record[i].status[j]);
+					CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
+				}
+			}
+			CL_PRINTF(cliBuf);
+			/*==========================================*/
+			/*	content*/
+			/*==========================================*/
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = ", "C2H indication content");
+			for (j = 0; j < gl_coex_offload.c2h_ind_record[i].ind_len; j++) {
+				CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, "%02x ", gl_coex_offload.c2h_ind_record[i].ind_buf[j]);
+				CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, 3);
+			}
+			CL_PRINTF(cliBuf);
+			/*==========================================*/
+		}
+	}
 
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Statistics]============");
 	CL_PRINTF(cliBuf);
 
 #if (H2C_USE_IO_THREAD != 1)
-	for(i=0; i<H2C_STATUS_MAX; i++)
-	{
-		if (pHalData->h2cStatistics[i])
-		{
+	for (i = 0; i < H2C_STATUS_MAX; i++) {
+		if (pHalData->h2cStatistics[i]) {
 			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s] = %d", "H2C statistics", \
-				h2cStaString[i], pHalData->h2cStatistics[i]);
+				   h2cStaString[i], pHalData->h2cStatistics[i]);
 			CL_PRINTF(cliBuf);
 		}
 	}
 #else
-		for(i=0; i<IO_STATUS_MAX; i++)
-		{
-			if(Adapter->ioComStr.ioH2cStatistics[i])
-			{
-				CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s] = %d", "H2C statistics", \
-					ioStaString[i], Adapter->ioComStr.ioH2cStatistics[i]);
-				CL_PRINTF(cliBuf);
-			}
+	for (i = 0; i < IO_STATUS_MAX; i++) {
+		if (Adapter->ioComStr.ioH2cStatistics[i]) {
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s] = %d", "H2C statistics", \
+				ioStaString[i], Adapter->ioComStr.ioH2cStatistics[i]);
+			CL_PRINTF(cliBuf);
 		}
+	}
 #endif
 #if 0
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "lastHMEBoxNum", \
-		pHalData->LastHMEBoxNum);
+		   pHalData->LastHMEBoxNum);
 	CL_PRINTF(cliBuf);
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x / 0x%x", "LastOkH2c/FirstFailH2c(fwNotRead)", \
-		pHalData->lastSuccessH2cEid, pHalData->firstFailedH2cEid);
+		   pHalData->lastSuccessH2cEid, pHalData->firstFailedH2cEid);
 	CL_PRINTF(cliBuf);
 
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d", "c2hIsr/c2hIntr/clr1AF/noRdy/noBuf", \
 		pHalData->InterruptLog.nIMR_C2HCMD, DBG_Var.c2hInterruptCnt, DBG_Var.c2hClrReadC2hCnt,
-		DBG_Var.c2hNotReadyCnt, DBG_Var.c2hBufAlloFailCnt);
+		   DBG_Var.c2hNotReadyCnt, DBG_Var.c2hBufAlloFailCnt);
 	CL_PRINTF(cliBuf);
 
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "c2hPacket", \
-		DBG_Var.c2hPacketCnt);
+		   DBG_Var.c2hPacketCnt);
 	CL_PRINTF(cliBuf);
 #endif
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "Periodical/ DbgCtrl", \
@@ -1275,18 +1602,30 @@ void halbtcoutsrc_DisplayCoexStatistics(PBTC_COEXIST pBtCoexist)
 	CL_PRINTF(cliBuf);
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "PowerOn/InitHw/InitCoexDm/RfStatus", \
 		pBtCoexist->statistics.cntPowerOn, pBtCoexist->statistics.cntInitHwConfig, pBtCoexist->statistics.cntInitCoexDm,
-		pBtCoexist->statistics.cntRfStatusNotify);
+		   pBtCoexist->statistics.cntRfStatusNotify);
 	CL_PRINTF(cliBuf);
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d", "Ips/Lps/Scan/Connect/Mstatus", \
 		pBtCoexist->statistics.cntIpsNotify, pBtCoexist->statistics.cntLpsNotify,
 		pBtCoexist->statistics.cntScanNotify, pBtCoexist->statistics.cntConnectNotify,
-		pBtCoexist->statistics.cntMediaStatusNotify);
+		   pBtCoexist->statistics.cntMediaStatusNotify);
 	CL_PRINTF(cliBuf);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "Special pkt/Bt info/ bind", 
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "Special pkt/Bt info/ bind",
 		pBtCoexist->statistics.cntSpecialPacketNotify, pBtCoexist->statistics.cntBtInfoNotify,
-		pBtCoexist->statistics.cntBind);
+		   pBtCoexist->statistics.cntBind);
 	CL_PRINTF(cliBuf);
 #endif
+	PADAPTER		padapter = pBtCoexist->Adapter;
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	u8				*cliBuf = pBtCoexist->cli_buf;
+
+	if (pHalData->EEPROMBluetoothCoexist == 1) {
+		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Coex Status]============");
+		CL_PRINTF(cliBuf);
+		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IsBtDisabled", rtw_btcoex_IsBtDisabled(padapter));
+		CL_PRINTF(cliBuf);
+		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IsBtControlLps", rtw_btcoex_IsBtControlLps(padapter));
+		CL_PRINTF(cliBuf);
+	}
 }
 
 void halbtcoutsrc_DisplayBtLinkInfo(PBTC_COEXIST pBtCoexist)
@@ -1298,19 +1637,15 @@ void halbtcoutsrc_DisplayBtLinkInfo(PBTC_COEXIST pBtCoexist)
 	u8 i;
 
 
-	if (pBtCoexist->stackInfo.bProfileNotified)
-	{
-		for (i=0; i<pBtMgnt->ExtConfig.NumberOfACL; i++)
-		{
-			if (pBtMgnt->ExtConfig.HCIExtensionVer >= 1)
-			{
+	if (pBtCoexist->stack_info.profile_notified) {
+		for (i = 0; i < pBtMgnt->ExtConfig.NumberOfACL; i++) {
+			if (pBtMgnt->ExtConfig.HCIExtensionVer >= 1) {
 				CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s", "Bt link type/spec/role", \
 					BtProfileString[pBtMgnt->ExtConfig.aclLink[i].BTProfile],
 					BtSpecString[pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec],
 					BtLinkRoleString[pBtMgnt->ExtConfig.aclLink[i].linkRole]);
-				CL_PRINTF(cliBuf);				}
-			else
-			{
+				CL_PRINTF(cliBuf);
+			} else {
 				CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s", "Bt link type/spec", \
 					BtProfileString[pBtMgnt->ExtConfig.aclLink[i].BTProfile],
 					BtSpecString[pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec]);
@@ -1325,71 +1660,78 @@ void halbtcoutsrc_DisplayWifiStatus(PBTC_COEXIST pBtCoexist)
 {
 	PADAPTER	padapter = pBtCoexist->Adapter;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	u8* 			cliBuf=pBtCoexist->cliBuf;
-	s32			wifiRssi=0, btHsRssi=0;
-	BOOLEAN	bScan=_FALSE, bLink=_FALSE, bRoam=_FALSE, bWifiBusy=_FALSE, bWifiUnderBMode=_FALSE;
-	u32			wifiBw=BTC_WIFI_BW_HT20, wifiTrafficDir=BTC_WIFI_TRAFFIC_TX, wifiFreq=BTC_FREQ_2_4G;
-	u32			wifiLinkStatus=0x0;
-	BOOLEAN	bBtHsOn=_FALSE, bLowPower=_FALSE;
-	u8			wifiChnl=0, wifiHsChnl=0, nScanAPNum = 0, FwPSState;
+	u8			*cliBuf = pBtCoexist->cli_buf;
+	s32			wifiRssi = 0, btHsRssi = 0;
+	BOOLEAN	bScan = _FALSE, bLink = _FALSE, bRoam = _FALSE, bWifiBusy = _FALSE, bWifiUnderBMode = _FALSE;
+	u32			wifiBw = BTC_WIFI_BW_HT20, wifiTrafficDir = BTC_WIFI_TRAFFIC_TX, wifiFreq = BTC_FREQ_2_4G;
+	u32			wifiLinkStatus = 0x0;
+	BOOLEAN	bBtHsOn = _FALSE, bLowPower = _FALSE;
+	u8			wifiChnl = 0, wifiP2PChnl = 0, nScanAPNum = 0, FwPSState;
+	u32			iqk_cnt_total = 0, iqk_cnt_ok = 0, iqk_cnt_fail = 0;
+	u16			wifiBcnInterval = 0;
 
 	wifiLinkStatus = halbtcoutsrc_GetWifiLinkStatus(pBtCoexist);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d", "STA/vWifi/HS/p2pGo/p2pGc", \
-		((wifiLinkStatus&WIFI_STA_CONNECTED)? 1:0), ((wifiLinkStatus&WIFI_AP_CONNECTED)? 1:0), 
-		((wifiLinkStatus&WIFI_HS_CONNECTED)? 1:0), ((wifiLinkStatus&WIFI_P2P_GO_CONNECTED)? 1:0), 
-		((wifiLinkStatus&WIFI_P2P_GC_CONNECTED)? 1:0) );
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d (mcc+2band = %d)", "STA/vWifi/HS/p2pGo/p2pGc",
+		((wifiLinkStatus & WIFI_STA_CONNECTED) ? 1 : 0), ((wifiLinkStatus & WIFI_AP_CONNECTED) ? 1 : 0),
+		((wifiLinkStatus & WIFI_HS_CONNECTED) ? 1 : 0), ((wifiLinkStatus & WIFI_P2P_GO_CONNECTED) ? 1 : 0),
+		((wifiLinkStatus & WIFI_P2P_GC_CONNECTED) ? 1 : 0),
+		halbtcoutsrc_IsDualBandConnected(padapter) ? 1 : 0);
 	CL_PRINTF(cliBuf);
 
-	if (wifiLinkStatus&WIFI_STA_CONNECTED) {
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "Link/ Roam/ Scan",
+		bLink, bRoam, bScan);
+	CL_PRINTF(cliBuf);	
+
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_IQK_TOTAL, &iqk_cnt_total);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_IQK_OK, &iqk_cnt_ok);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_IQK_FAIL, &iqk_cnt_fail);
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d %s %s",
+		"IQK All/ OK/ Fail/AutoLoad/FWDL", iqk_cnt_total, iqk_cnt_ok, iqk_cnt_fail,
+		((halbtcoutsrc_is_autoload_fail(pBtCoexist) == _TRUE) ? "fail":"ok"), ((halbtcoutsrc_is_fw_ready(pBtCoexist) == _TRUE) ? "ok":"fail"));
+	CL_PRINTF(cliBuf);
+	
+	if (wifiLinkStatus & WIFI_STA_CONNECTED) {
 		CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "IOT Peer", GLBtcIotPeerString[padapter->mlmeextpriv.mlmext_info.assoc_AP_vendor]);
 		CL_PRINTF(cliBuf);
 	}
 
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_HS_OPERATION, &bBtHsOn);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_DOT11_CHNL, &wifiChnl);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_WIFI_HS_CHNL, &wifiHsChnl);	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d(%d)", "Dot11 channel / HsChnl(High Speed)", \
-		wifiChnl, wifiHsChnl, bBtHsOn);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U1_WIFI_DOT11_CHNL, &wifiChnl);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U2_BEACON_PERIOD, &wifiBcnInterval);
+	if ((wifiLinkStatus & WIFI_P2P_GO_CONNECTED) || (wifiLinkStatus & WIFI_P2P_GC_CONNECTED)) 
+		pBtCoexist->btc_get(pBtCoexist, BTC_GET_U1_WIFI_P2P_CHNL, &wifiP2PChnl);	
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dBm/ %d/ %d/ %d", "RSSI/ STA_Chnl/ P2P_Chnl/ BI",
+		wifiRssi-100, wifiChnl, wifiP2PChnl, wifiBcnInterval);
 	CL_PRINTF(cliBuf);
 
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_S4_HS_RSSI, &btHsRssi);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "Wifi rssi/ HS rssi", \
-		wifiRssi-100, btHsRssi-100);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifiFreq);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
+	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U1_AP_NUM, &nScanAPNum);
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %s/ %s/ %d ", "Band/ BW/ Traffic/ APCnt",
+		GLBtcWifiFreqString[wifiFreq], ((bWifiUnderBMode) ? "11b" : GLBtcWifiBwString[wifiBw]),
+		((!bWifiBusy) ? "idle" : ((BTC_WIFI_TRAFFIC_TX == wifiTrafficDir) ? "uplink" : "downlink")),
+		   nScanAPNum);
 	CL_PRINTF(cliBuf);
 
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "Wifi bLink/ bRoam/ bScan", \
-		bLink, bRoam, bScan);
-	CL_PRINTF(cliBuf);
-
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifiFreq);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
-	pBtCoexist->fBtcGet(pBtCoexist, BTC_GET_U1_AP_NUM, &nScanAPNum);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %s/ %s/ AP=%d ", "Wifi freq/ bw/ traffic", \
-		GLBtcWifiFreqString[wifiFreq], ((bWifiUnderBMode)? "11b": GLBtcWifiBwString[wifiBw]),
-		((!bWifiBusy)? "idle": ((BTC_WIFI_TRAFFIC_TX==wifiTrafficDir)? "uplink":"downlink")), 
-		nScanAPNum);
-	CL_PRINTF(cliBuf);
-
-	// power status
+	/* power status */
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s%s%s", "Power Status", \
-		((halbtcoutsrc_UnderIps(pBtCoexist) == _TRUE)? "IPS ON":"IPS OFF"),
-		((halbtcoutsrc_UnderLps(pBtCoexist) == _TRUE)? ", LPS ON":", LPS OFF"), 
-		((halbtcoutsrc_Under32K(pBtCoexist) == _TRUE)? ", 32k":""));
+		((halbtcoutsrc_UnderIps(pBtCoexist) == _TRUE) ? "IPS ON" : "IPS OFF"),
+		((halbtcoutsrc_UnderLps(pBtCoexist) == _TRUE) ? ", LPS ON" : ", LPS OFF"),
+		((halbtcoutsrc_Under32K(pBtCoexist) == _TRUE) ? ", 32k" : ""));
 	CL_PRINTF(cliBuf);
 
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x (0x%x/0x%x)", "Power mode cmd(lps/rpwm)", \
-		pBtCoexist->pwrModeVal[0], pBtCoexist->pwrModeVal[1],
-		pBtCoexist->pwrModeVal[2], pBtCoexist->pwrModeVal[3],
-		pBtCoexist->pwrModeVal[4], pBtCoexist->pwrModeVal[5],
-		pBtCoexist->btInfo.lpsVal, 
-		pBtCoexist->btInfo.rpwmVal);
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x (0x%x/0x%x)", "Power mode cmd(lps/rpwm)",
+		   pBtCoexist->pwrModeVal[0], pBtCoexist->pwrModeVal[1],
+		   pBtCoexist->pwrModeVal[2], pBtCoexist->pwrModeVal[3],
+		   pBtCoexist->pwrModeVal[4], pBtCoexist->pwrModeVal[5],
+		   pBtCoexist->bt_info.lps_val,
+		   pBtCoexist->bt_info.rpwm_val);
 	CL_PRINTF(cliBuf);
 }
 
@@ -1399,25 +1741,24 @@ void halbtcoutsrc_DisplayDbgMsg(void *pBtcContext, u8 dispType)
 
 
 	pBtCoexist = (PBTC_COEXIST)pBtcContext;
-	switch(dispType)
-	{
-		case BTC_DBG_DISP_COEX_STATISTICS:
-			halbtcoutsrc_DisplayCoexStatistics(pBtCoexist);
-			break;
-		case BTC_DBG_DISP_BT_LINK_INFO:
-			halbtcoutsrc_DisplayBtLinkInfo(pBtCoexist);
-			break;
-		case BTC_DBG_DISP_WIFI_STATUS:
-			halbtcoutsrc_DisplayWifiStatus(pBtCoexist);
-			break;
-		default:
-			break;
+	switch (dispType) {
+	case BTC_DBG_DISP_COEX_STATISTICS:
+		halbtcoutsrc_DisplayCoexStatistics(pBtCoexist);
+		break;
+	case BTC_DBG_DISP_BT_LINK_INFO:
+		halbtcoutsrc_DisplayBtLinkInfo(pBtCoexist);
+		break;
+	case BTC_DBG_DISP_WIFI_STATUS:
+		halbtcoutsrc_DisplayWifiStatus(pBtCoexist);
+		break;
+	default:
+		break;
 	}
 }
 
-//====================================
-//		IO related function
-//====================================
+/* ************************************
+ *		IO related function
+ * ************************************ */
 u8 halbtcoutsrc_Read1Byte(void *pBtcContext, u32 RegAddr)
 {
 	PBTC_COEXIST pBtCoexist;
@@ -1479,13 +1820,11 @@ void halbtcoutsrc_BitMaskWrite1Byte(void *pBtcContext, u32 regAddr, u8 bitMask,
 	originalValue = 0;
 	bitShift = 0;
 
-	if(bitMask != 0xff)
-	{
+	if (bitMask != 0xff) {
 		originalValue = rtw_read8(padapter, regAddr);
 
-		for (i=0; i<=7; i++)
-		{
-			if ((bitMask>>i)&0x1)
+		for (i = 0; i <= 7; i++) {
+			if ((bitMask >> i) & 0x1)
 				break;
 		}
 		bitShift = i;
@@ -1522,17 +1861,13 @@ void halbtcoutsrc_Write4Byte(void *pBtcContext, u32 RegAddr, u32 Data)
 
 void halbtcoutsrc_WriteLocalReg1Byte(void *pBtcContext, u32 RegAddr, u8 Data)
 {
-	PBTC_COEXIST		pBtCoexist=(PBTC_COEXIST)pBtcContext;
-	PADAPTER			Adapter=pBtCoexist->Adapter;
+	PBTC_COEXIST		pBtCoexist = (PBTC_COEXIST)pBtcContext;
+	PADAPTER			Adapter = pBtCoexist->Adapter;
 
-	if(BTC_INTF_SDIO == pBtCoexist->chipInterface)
-	{
+	if (BTC_INTF_SDIO == pBtCoexist->chip_interface)
 		rtw_write8(Adapter, SDIO_LOCAL_BASE | RegAddr, Data);
-	}
 	else
-	{
 		rtw_write8(Adapter, RegAddr, Data);
-	}
 }
 
 void halbtcoutsrc_SetBbReg(void *pBtcContext, u32 RegAddr, u32 BitMask, u32 Data)
@@ -1544,7 +1879,7 @@ void halbtcoutsrc_SetBbReg(void *pBtcContext, u32 RegAddr, u32 BitMask, u32 Data
 	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 	padapter = pBtCoexist->Adapter;
 
-	PHY_SetBBReg(padapter, RegAddr, BitMask, Data);
+	phy_set_bb_reg(padapter, RegAddr, BitMask, Data);
 }
 
 
@@ -1557,10 +1892,10 @@ u32 halbtcoutsrc_GetBbReg(void *pBtcContext, u32 RegAddr, u32 BitMask)
 	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 	padapter = pBtCoexist->Adapter;
 
-	return PHY_QueryBBReg(padapter, RegAddr, BitMask);
+	return phy_query_bb_reg(padapter, RegAddr, BitMask);
 }
 
-void halbtcoutsrc_SetRfReg(void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
+void halbtcoutsrc_SetRfReg(void *pBtcContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
 {
 	PBTC_COEXIST pBtCoexist;
 	PADAPTER padapter;
@@ -1569,10 +1904,10 @@ void halbtcoutsrc_SetRfReg(void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMa
 	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 	padapter = pBtCoexist->Adapter;
 
-	PHY_SetRFReg(padapter, eRFPath, RegAddr, BitMask, Data);
+	phy_set_rf_reg(padapter, eRFPath, RegAddr, BitMask, Data);
 }
 
-u32 halbtcoutsrc_GetRfReg(void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMask)
+u32 halbtcoutsrc_GetRfReg(void *pBtcContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask)
 {
 	PBTC_COEXIST pBtCoexist;
 	PADAPTER padapter;
@@ -1581,7 +1916,7 @@ u32 halbtcoutsrc_GetRfReg(void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMas
 	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 	padapter = pBtCoexist->Adapter;
 
-	return PHY_QueryRFReg(padapter, eRFPath, RegAddr, BitMask);
+	return phy_query_rf_reg(padapter, eRFPath, RegAddr, BitMask);
 }
 
 u16 halbtcoutsrc_SetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 Data)
@@ -1606,7 +1941,7 @@ u16 halbtcoutsrc_SetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 Data)
 			ret = SET_BT_MP_OPER_RET(op_code, status);
 		else {
 			buf[0] = RegType;
-			*(u16 *)(buf+1) = cpu_to_le16((u16)RegAddr);
+			*(u16 *)(buf + 1) = cpu_to_le16((u16)RegAddr);
 			op_code = BT_OP_WRITE_REG_ADDR;
 			status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 3);
 			if (status != BT_STATUS_BT_OP_SUCCESS)
@@ -1622,8 +1957,8 @@ u16 halbtcoutsrc_SetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 Data)
 
 u8 halbtcoutsrc_SetBtAntDetection(void *pBtcContext, u8 txTime, u8 btChnl)
 {
-/* Always return _FALSE since we don't implement this yet */	
-#if 0	
+	/* Always return _FALSE since we don't implement this yet */
+#if 0
 	PBTC_COEXIST		pBtCoexist = (PBTC_COEXIST)pBtcContext;
 	PADAPTER			Adapter = pBtCoexist->Adapter;
 	u1Byte				btCanTx = 0;
@@ -1639,7 +1974,39 @@ u8 halbtcoutsrc_SetBtAntDetection(void *pBtcContext, u8 txTime, u8 btChnl)
 #endif
 }
 
-u16 halbtcoutsrc_GetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 *data)
+BOOLEAN
+halbtcoutsrc_SetBtTRXMASK(
+	IN	PVOID			pBtcContext,
+	IN	u1Byte			bt_trx_mask
+	)
+{
+	/* Always return _FALSE since we don't implement this yet */
+#if 0
+	struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
+	PADAPTER			Adapter = pBtCoexist->Adapter;
+	BOOLEAN				bStatus = FALSE;
+	u1Byte				btCanTx = 0;
+
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter) || IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)
+			|| IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
+		bStatus = NDBG_SetBtTRXMASK(Adapter, 1, bt_trx_mask, &btCanTx);
+	else
+		bStatus = NDBG_SetBtTRXMASK(Adapter, 2, bt_trx_mask, &btCanTx);
+	}
+
+	
+	if (bStatus)
+		return TRUE;
+	else
+		return FALSE;
+#else
+	return _FALSE;
+#endif
+}
+
+u16 halbtcoutsrc_GetBtReg_with_status(void *pBtcContext, u8 RegType, u32 RegAddr, u32 *data)
 {
 	PBTC_COEXIST pBtCoexist;
 	u16 ret = BT_STATUS_BT_OP_SUCCESS;
@@ -1653,7 +2020,7 @@ u16 halbtcoutsrc_GetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 *data)
 		u8 status;
 
 		buf[0] = RegType;
-		*(u16 *)(buf+1) = cpu_to_le16((u16)RegAddr);
+		*(u16 *)(buf + 1) = cpu_to_le16((u16)RegAddr);
 
 		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
 
@@ -1672,6 +2039,13 @@ u16 halbtcoutsrc_GetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 *data)
 	return ret;
 }
 
+u32 halbtcoutsrc_GetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr)
+{
+	u32 regVal;
+	
+	return (BT_STATUS_BT_OP_SUCCESS == halbtcoutsrc_GetBtReg_with_status(pBtcContext, RegType, RegAddr, &regVal)) ? regVal : 0xffffffff;
+}
+
 void halbtcoutsrc_FillH2cCmd(void *pBtcContext, u8 elementId, u32 cmdLen, u8 *pCmdBuffer)
 {
 	PBTC_COEXIST pBtCoexist;
@@ -1684,527 +2058,1249 @@ void halbtcoutsrc_FillH2cCmd(void *pBtcContext, u8 elementId, u32 cmdLen, u8 *pC
 	rtw_hal_fill_h2c_cmd(padapter, elementId, cmdLen, pCmdBuffer);
 }
 
-//====================================
-//		Extern functions called by other module
-//====================================
-u8 EXhalbtcoutsrc_IsTfbgaPackageType(PADAPTER padapter)
+static void halbtcoutsrc_coex_offload_init(void)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	u1Byte	i;
 
-#ifdef CONFIG_RTL8723B
-	if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA80)
-		|| (pHalData->PackageType == PACKAGE_TFBGA90)) {
-		return _TRUE;
-	}		
+	gl_coex_offload.h2c_req_num = 0;
+	gl_coex_offload.cnt_h2c_sent = 0;
+	gl_coex_offload.cnt_c2h_ack = 0;
+	gl_coex_offload.cnt_c2h_ind = 0;
+
+	for (i = 0; i < COL_MAX_H2C_REQ_NUM; i++)
+		init_completion(&gl_coex_offload.c2h_event[i]);
+}
+
+static COL_H2C_STATUS halbtcoutsrc_send_h2c(PADAPTER Adapter, PCOL_H2C pcol_h2c, u16 h2c_cmd_len)
+{
+	COL_H2C_STATUS		h2c_status = COL_STATUS_C2H_OK;
+	u8				i;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0))
+	reinit_completion(&gl_coex_offload.c2h_event[pcol_h2c->req_num]);		/* set event to un signaled state */
+#else
+	INIT_COMPLETION(gl_coex_offload.c2h_event[pcol_h2c->req_num]);
 #endif
 
-	return _FALSE;
+	if (TRUE) {
+#if 0	/*(USE_HAL_MAC_API == 1) */
+		if (RT_STATUS_SUCCESS == HAL_MAC_Send_BT_COEX(&GET_HAL_MAC_INFO(Adapter), (pu1Byte)(pcol_h2c), (u4Byte)h2c_cmd_len, 1)) {
+			if (!wait_for_completion_timeout(&gl_coex_offload.c2h_event[pcol_h2c->req_num], 20)) {
+				h2c_status = COL_STATUS_H2C_TIMTOUT;
+			}
+		} else {
+			h2c_status = COL_STATUS_H2C_HALMAC_FAIL;
+		}
+#endif
+	}
+
+	return h2c_status;
 }
 
-u8 EXhalbtcoutsrc_BindBtCoexWithAdapter(void *padapter)
+static COL_H2C_STATUS halbtcoutsrc_check_c2h_ack(PADAPTER Adapter, PCOL_SINGLE_H2C_RECORD pH2cRecord)
 {
-	PBTC_COEXIST		pBtCoexist=&GLBtCoexist;
-	u1Byte	antNum=2, chipType;
-	
-	if(pBtCoexist->bBinded)
-		return _FALSE;
-	else
-		pBtCoexist->bBinded = _TRUE;
+	COL_H2C_STATUS	c2h_status = COL_STATUS_C2H_OK;
+	PCOL_H2C		p_h2c_cmd = (PCOL_H2C)&pH2cRecord->h2c_buf[0];
+	u8			req_num = p_h2c_cmd->req_num;
+	PCOL_C2H_ACK	p_c2h_ack = (PCOL_C2H_ACK)&gl_coex_offload.c2h_ack_buf[req_num];
 
-	pBtCoexist->statistics.cntBind++;
-	
-	pBtCoexist->Adapter = padapter;
-	
-	pBtCoexist->stackInfo.bProfileNotified = _FALSE;
 
-	pBtCoexist->btInfo.bBtCtrlAggBufSize = _FALSE;
-	pBtCoexist->btInfo.aggBufSize = 5;
+	if ((COL_C2H_ACK_HDR_LEN + p_c2h_ack->ret_len) > gl_coex_offload.c2h_ack_len[req_num]) {
+		c2h_status = COL_STATUS_COEX_DATA_OVERFLOW;
+		return c2h_status;
+	}
+	/* else */
+	{
+		_rtw_memmove(&pH2cRecord->c2h_ack_buf[0], &gl_coex_offload.c2h_ack_buf[req_num], gl_coex_offload.c2h_ack_len[req_num]);
+		pH2cRecord->c2h_ack_len = gl_coex_offload.c2h_ack_len[req_num];
+	}
 
-	pBtCoexist->btInfo.bIncreaseScanDevNum = _FALSE;
-	pBtCoexist->btInfo.bMiracastPlusBt = _FALSE;
 
-#if 0
-	chipType = HALBT_GetBtChipType(Adapter);
-	EXhalbtcoutsrc_SetChipType(chipType);
-	antNum = HALBT_GetPgAntNum(Adapter);
-	EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_PG, antNum);
-#endif
-	// set default antenna position to main  port
-	pBtCoexist->boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;	
+	if (p_c2h_ack->req_num != p_h2c_cmd->req_num) {
+		c2h_status = COL_STATUS_C2H_REQ_NUM_MISMATCH;
+	} else if (p_c2h_ack->opcode_ver != p_h2c_cmd->opcode_ver) {
+		c2h_status = COL_STATUS_C2H_OPCODE_VER_MISMATCH;
+	} else {
+		c2h_status = p_c2h_ack->status;
+	}
 
-	pBtCoexist->boardInfo.btdmAntDetFinish = _FALSE;
-	pBtCoexist->boardInfo.btdmAntNumByAntDet = 1;
+	return c2h_status;
+}
 
-	pBtCoexist->boardInfo.bTfbgaPackage = EXhalbtcoutsrc_IsTfbgaPackageType((PADAPTER)padapter);
+COL_H2C_STATUS halbtcoutsrc_CoexH2cProcess(void *pBtCoexist,
+		u8 opcode, u8 opcode_ver, u8 *ph2c_par, u8 h2c_par_len)
+{
+	PADAPTER			Adapter = ((struct btc_coexist *)pBtCoexist)->Adapter;
+	u8				H2C_Parameter[BTC_TMP_BUF_SHORT] = {0};
+	PCOL_H2C			pcol_h2c = (PCOL_H2C)&H2C_Parameter[0];
+	u16				paraLen = 0;
+	COL_H2C_STATUS		h2c_status = COL_STATUS_C2H_OK, c2h_status = COL_STATUS_C2H_OK;
+	COL_H2C_STATUS		ret_status = COL_STATUS_C2H_OK;
+	u16				i, col_h2c_len = 0;
 
-	if (pBtCoexist->boardInfo.bTfbgaPackage)
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Package Type = TFBGA\n"));
-	else
-		RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], Package Type = Non-TFBGA\n"));
-	
-	return _TRUE;
+	pcol_h2c->opcode = opcode;
+	pcol_h2c->opcode_ver = opcode_ver;
+	pcol_h2c->req_num = gl_coex_offload.h2c_req_num;
+	gl_coex_offload.h2c_req_num++;
+	gl_coex_offload.h2c_req_num %= 16;
+
+	_rtw_memmove(&pcol_h2c->buf[0], ph2c_par, h2c_par_len);
+
+
+	col_h2c_len = h2c_par_len + 2;	/* 2=sizeof(OPCode, OPCode_version and  Request number) */
+	BT_PrintData(Adapter, "[COL], H2C cmd: ", col_h2c_len, H2C_Parameter);
+
+	gl_coex_offload.cnt_h2c_sent++;
+
+	gl_coex_offload.h2c_record[opcode].count++;
+	gl_coex_offload.h2c_record[opcode].h2c_len = col_h2c_len;
+	_rtw_memmove((PVOID)&gl_coex_offload.h2c_record[opcode].h2c_buf[0], (PVOID)pcol_h2c, col_h2c_len);
+
+	h2c_status = halbtcoutsrc_send_h2c(Adapter, pcol_h2c, col_h2c_len);
+
+	gl_coex_offload.h2c_record[opcode].c2h_ack_len = 0;
+
+	if (COL_STATUS_C2H_OK == h2c_status) {
+		/* if reach here, it means H2C get the correct c2h response, */
+		c2h_status = halbtcoutsrc_check_c2h_ack(Adapter, &gl_coex_offload.h2c_record[opcode]);
+		ret_status = c2h_status;
+	} else {
+		/* check h2c status error, return error status code to upper layer. */
+		ret_status = h2c_status;
+	}
+	gl_coex_offload.h2c_record[opcode].status[ret_status]++;
+	gl_coex_offload.status[ret_status]++;
+
+	return ret_status;
 }
 
-u8 EXhalbtcoutsrc_InitlizeVariables(void *padapter)
+u8 halbtcoutsrc_GetAntDetValFromBt(void *pBtcContext)
 {
-	PBTC_COEXIST pBtCoexist = &GLBtCoexist;
+	/* Always return 0 since we don't implement this yet */
+#if 0
+	struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
+	PADAPTER			Adapter = pBtCoexist->Adapter;
+	u1Byte				AntDetVal = 0x0;
+	u1Byte				opcodeVer = 1;
+	BOOLEAN				status = false;
 
-	//pBtCoexist->statistics.cntBind++;
+	status = NDBG_GetAntDetValFromBt(Adapter, opcodeVer, &AntDetVal);
 
-	halbtcoutsrc_DbgInit();
+	RT_TRACE(COMP_DBG, DBG_LOUD, ("$$$ halbtcoutsrc_GetAntDetValFromBt(): status = %d, feature = %x\n", status, AntDetVal));
 
-#ifdef CONFIG_PCI_HCI
-	pBtCoexist->chipInterface = BTC_INTF_PCI;
-#elif defined(CONFIG_USB_HCI)
-	pBtCoexist->chipInterface = BTC_INTF_USB;
-#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	pBtCoexist->chipInterface = BTC_INTF_SDIO;
+	return AntDetVal;
 #else
-	pBtCoexist->chipInterface = BTC_INTF_UNKNOWN;
+	return 0;
 #endif
+}
 
-	EXhalbtcoutsrc_BindBtCoexWithAdapter(padapter);
+u8 halbtcoutsrc_GetBleScanTypeFromBt(void *pBtcContext)
+{
+	PBTC_COEXIST pBtCoexist;
+	u32 ret = BT_STATUS_BT_OP_SUCCESS;
+	u8 data = 0;
 
-	pBtCoexist->fBtcRead1Byte = halbtcoutsrc_Read1Byte;
-	pBtCoexist->fBtcWrite1Byte = halbtcoutsrc_Write1Byte;
-	pBtCoexist->fBtcWrite1ByteBitMask = halbtcoutsrc_BitMaskWrite1Byte;
-	pBtCoexist->fBtcRead2Byte = halbtcoutsrc_Read2Byte;
-	pBtCoexist->fBtcWrite2Byte = halbtcoutsrc_Write2Byte;
-	pBtCoexist->fBtcRead4Byte = halbtcoutsrc_Read4Byte;
-	pBtCoexist->fBtcWrite4Byte = halbtcoutsrc_Write4Byte;
-	pBtCoexist->fBtcWriteLocalReg1Byte = halbtcoutsrc_WriteLocalReg1Byte;
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 
-	pBtCoexist->fBtcSetBbReg = halbtcoutsrc_SetBbReg;
-	pBtCoexist->fBtcGetBbReg = halbtcoutsrc_GetBbReg;
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		u8 buf[3] = {0};
+		_irqL irqL;
+		u8 op_code;
+		u8 status;
 
-	pBtCoexist->fBtcSetRfReg = halbtcoutsrc_SetRfReg;
-	pBtCoexist->fBtcGetRfReg = halbtcoutsrc_GetRfReg;
 
-	pBtCoexist->fBtcFillH2c = halbtcoutsrc_FillH2cCmd;
-	pBtCoexist->fBtcDispDbgMsg = halbtcoutsrc_DisplayDbgMsg;
+		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
 
-	pBtCoexist->fBtcGet = halbtcoutsrc_Get;
-	pBtCoexist->fBtcSet = halbtcoutsrc_Set;
-	pBtCoexist->fBtcGetBtReg = halbtcoutsrc_GetBtReg;
-	pBtCoexist->fBtcSetBtReg = halbtcoutsrc_SetBtReg;
-	pBtCoexist->fBtcSetBtAntDetection = halbtcoutsrc_SetBtAntDetection;
+		op_code = BT_OP_GET_BT_BLE_SCAN_TYPE;
+		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+		if (status == BT_STATUS_BT_OP_SUCCESS)
+			data = *(u8 *)GLBtcBtMpRptRsp;
+		else
+			ret = SET_BT_MP_OPER_RET(op_code, status);
 
-	pBtCoexist->cliBuf = &GLBtcDbgBuf[0];
+		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
 
-	pBtCoexist->boardInfo.singleAntPath = 0;
-	
-	GLBtcWiFiInScanState = _FALSE;
+	} else
+		ret = BT_STATUS_NOT_IMPLEMENT;
 
-	GLBtcWiFiInIQKState = _FALSE;
+	return data;
+}
 
-	GLBtcWiFiInIPS = _FALSE;
+u32 halbtcoutsrc_GetBleScanParaFromBt(void *pBtcContext, u8 scanType)
+{
+	PBTC_COEXIST pBtCoexist;
+	u32 ret = BT_STATUS_BT_OP_SUCCESS;
+	u32 data = 0;
 
-	GLBtcWiFiInLPS = _FALSE;
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
 
-	GLBtcBtCoexAliveRegistered = _FALSE;
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		u8 buf[3] = {0};
+		_irqL irqL;
+		u8 op_code;
+		u8 status;
+		
+		buf[0] = scanType;
 
-	/* BT Control H2C/C2H*/
-	GLBtcBtMpOperSeq = 0;
-	_rtw_mutex_init(&GLBtcBtMpOperLock);
-	_init_timer(&GLBtcBtMpOperTimer, ((PADAPTER)padapter)->pnetdev, _btmpoper_timer_hdl, pBtCoexist);
-	_rtw_init_sema(&GLBtcBtMpRptSema, 0);
-	GLBtcBtMpRptSeq = 0;
-	GLBtcBtMpRptStatus = 0;
-	_rtw_memset(GLBtcBtMpRptRsp, 0, C2H_MAX_SIZE);
-	GLBtcBtMpRptRspSize = 0;
-	GLBtcBtMpRptWait = 0;
-	GLBtcBtMpRptWiFiOK = 0;
-	GLBtcBtMpRptBTOK = 0;
+		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
 
-	return _TRUE;
+		op_code = BT_OP_GET_BT_BLE_SCAN_PARA;
+		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 1);
+		if (status == BT_STATUS_BT_OP_SUCCESS)
+			data = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
+		else
+			ret = SET_BT_MP_OPER_RET(op_code, status);
+
+		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+	} else
+		ret = BT_STATUS_NOT_IMPLEMENT;
+
+	return data;
 }
 
-void EXhalbtcoutsrc_PowerOnSetting(PBTC_COEXIST pBtCoexist)
+u8 halbtcoutsrc_GetBtAFHMapFromBt(void *pBtcContext, u8 mapType, u8 *afhMap)
 {
-	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
-		return;
+	struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
+	u8 buf[2] = {0};
+	_irqL irqL;
+	u8 op_code;
+	u32 *AfhMapL = (u32 *)&(afhMap[0]);
+	u32 *AfhMapM = (u32 *)&(afhMap[4]);
+	u16 *AfhMapH = (u16 *)&(afhMap[8]);
+	u8 status;
+	u32 ret = BT_STATUS_BT_OP_SUCCESS;
 
-	/* Power on setting function is only added in 8723B currently */
-	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_PowerOnSetting(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_PowerOnSetting(pBtCoexist);
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _FALSE)
+		return _FALSE;
+
+	buf[0] = 0;
+	buf[1] = mapType;
+
+	_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+	op_code = BT_LO_OP_GET_AFH_MAP_L;
+	status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+	if (status == BT_STATUS_BT_OP_SUCCESS)
+		*AfhMapL = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
+	else {
+		ret = SET_BT_MP_OPER_RET(op_code, status);
+		goto exit;
 	}
-}
 
-void EXhalbtcoutsrc_PreLoadFirmware(PBTC_COEXIST pBtCoexist)
-{
-	if(!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
-		return;
-	
-	pBtCoexist->statistics.cntPreLoadFirmware++;
+	op_code = BT_LO_OP_GET_AFH_MAP_M;
+	status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+	if (status == BT_STATUS_BT_OP_SUCCESS)
+		*AfhMapM = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
+	else {
+		ret = SET_BT_MP_OPER_RET(op_code, status);
+		goto exit;
+	}
 
-	if(IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if(pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_PreLoadFirmware(pBtCoexist);
-		else if(pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_PreLoadFirmware(pBtCoexist);
+	op_code = BT_LO_OP_GET_AFH_MAP_H;
+	status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+	if (status == BT_STATUS_BT_OP_SUCCESS)
+		*AfhMapH = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
+	else {
+		ret = SET_BT_MP_OPER_RET(op_code, status);
+		goto exit;
 	}
+
+exit:
+
+	_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+	return (ret == BT_STATUS_BT_OP_SUCCESS) ? _TRUE : _FALSE;
 }
 
-void EXhalbtcoutsrc_InitHwConfig(PBTC_COEXIST pBtCoexist, u8 bWifiOnly)
+u32 halbtcoutsrc_GetPhydmVersion(void *pBtcContext)
 {
-	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
-		return;
+	struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
+	PADAPTER		Adapter = pBtCoexist->Adapter;
 
-	pBtCoexist->statistics.cntInitHwConfig++;
+#ifdef CONFIG_RTL8192E
+	return RELEASE_VERSION_8192E;
+#endif
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_InitHwConfig(pBtCoexist, bWifiOnly);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_InitHwConfig(pBtCoexist, bWifiOnly);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_InitHwConfig(pBtCoexist, bWifiOnly);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_InitHwConfig(pBtCoexist, bWifiOnly);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_InitHwConfig(pBtCoexist, bWifiOnly);
-	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_InitHwConfig(pBtCoexist, bWifiOnly);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_InitHwConfig(pBtCoexist, bWifiOnly);
-	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_InitHwConfig(pBtCoexist, bWifiOnly);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_InitHwConfig(pBtCoexist, bWifiOnly);
-	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_InitHwConfig(pBtCoexist, bWifiOnly);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_InitHwConfig(pBtCoexist, bWifiOnly);
-	}
+#ifdef CONFIG_RTL8821A
+	return RELEASE_VERSION_8821A;
+#endif
+
+#ifdef CONFIG_RTL8723B
+	return RELEASE_VERSION_8723B;
+#endif
+
+#ifdef CONFIG_RTL8812A
+	return RELEASE_VERSION_8812A;
+#endif
+
+#ifdef CONFIG_RTL8703B
+	return RELEASE_VERSION_8703B;
+#endif
+
+#ifdef CONFIG_RTL8822B
+	return RELEASE_VERSION_8822B;
+#endif
+
+#ifdef CONFIG_RTL8723D
+	return RELEASE_VERSION_8723D;
+#endif
+
+#ifdef CONFIG_RTL8821C
+	return RELEASE_VERSION_8821C;
+#endif
 }
 
-void EXhalbtcoutsrc_InitCoexDm(PBTC_COEXIST pBtCoexist)
+void halbtcoutsrc_phydm_modify_AntDiv_HwSw(void *pBtcContext, u8 is_hw)
 {
-	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
-		return;
+	/* empty function since we don't need it */
+}
+
+void halbtcoutsrc_phydm_modify_RA_PCR_threshold(void *pBtcContext, u8 RA_offset_direction, u8 RA_threshold_offset)
+{
+	struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
 
-	pBtCoexist->statistics.cntInitCoexDm++;
+/* switch to #if 0 in case the phydm version does not provide the function */
+#if 1
+	phydm_modify_RA_PCR_threshold(pBtCoexist->odm_priv, RA_offset_direction, RA_threshold_offset);
+#endif
+}
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_InitCoexDm(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_InitCoexDm(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_InitCoexDm(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_InitCoexDm(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_InitCoexDm(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_InitCoexDm(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_InitCoexDm(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_InitCoexDm(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_InitCoexDm(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_InitCoexDm(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_InitCoexDm(pBtCoexist);
-	}
+u32 halbtcoutsrc_phydm_query_PHY_counter(void *pBtcContext, u8 info_type)
+{
+	struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
 
-	pBtCoexist->bInitilized = _TRUE;
+/* switch to #if 0 in case the phydm version does not provide the function */
+#if 1
+	return phydm_cmn_info_query((struct dm_struct *)pBtCoexist->odm_priv, (enum phydm_info_query)info_type);
+#else
+	return 0;
+#endif
 }
 
-void EXhalbtcoutsrc_IpsNotify(PBTC_COEXIST pBtCoexist, u8 type)
+#if 0
+static void BT_CoexOffloadRecordErrC2hAck(PADAPTER	Adapter)
 {
-	u8	ipsType;
+	PADAPTER		pDefaultAdapter = GetDefaultAdapter(Adapter);
 
-	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+	if (pDefaultAdapter != Adapter)
 		return;
 
-	pBtCoexist->statistics.cntIpsNotify++;
-	if (pBtCoexist->bManualControl)
+	if (!hal_btcoex_IsBtExist(Adapter))
 		return;
 
-	if (IPS_NONE == type)
-	{
-		ipsType = BTC_IPS_LEAVE;
-		GLBtcWiFiInIPS = _FALSE;
-	}
-	else
-	{
-		ipsType = BTC_IPS_ENTER;
-		GLBtcWiFiInIPS = _TRUE;
-	}
-	
-	// All notify is called in cmd thread, don't need to leave low power again
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
-
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_IpsNotify(pBtCoexist, ipsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_IpsNotify(pBtCoexist, ipsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_IpsNotify(pBtCoexist, ipsType);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_IpsNotify(pBtCoexist, ipsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_IpsNotify(pBtCoexist, ipsType);
-	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_IpsNotify(pBtCoexist, ipsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_IpsNotify(pBtCoexist, ipsType);
-	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_IpsNotify(pBtCoexist, ipsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_IpsNotify(pBtCoexist, ipsType);
-	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_IpsNotify(pBtCoexist, ipsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_IpsNotify(pBtCoexist, ipsType);
-	}
+	gl_coex_offload.cnt_c2h_ack++;
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+	gl_coex_offload.status[COL_STATUS_INVALID_C2H_LEN]++;
 }
 
-void EXhalbtcoutsrc_LpsNotify(PBTC_COEXIST pBtCoexist, u8 type)
+static void BT_CoexOffloadC2hAckCheck(PADAPTER	Adapter, u8 *tmpBuf, u8 length)
 {
-	u8 lpsType;
-
+	PADAPTER		pDefaultAdapter = GetDefaultAdapter(Adapter);
+	PCOL_C2H_ACK	p_c2h_ack = NULL;
+	u8			req_num = 0xff;
 
-	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+	if (pDefaultAdapter != Adapter)
 		return;
 
-	pBtCoexist->statistics.cntLpsNotify++;
-	if (pBtCoexist->bManualControl)
+	if (!hal_btcoex_IsBtExist(Adapter))
 		return;
 
-	if (PS_MODE_ACTIVE == type)
-	{
-		lpsType = BTC_LPS_DISABLE;
-		GLBtcWiFiInLPS = _FALSE;
-	}
-	else
-	{
+	gl_coex_offload.cnt_c2h_ack++;
+
+	if (length < COL_C2H_ACK_HDR_LEN) {		/* c2h ack length must >= 3 (status, opcode_ver, req_num and ret_len) */
+		gl_coex_offload.status[COL_STATUS_INVALID_C2H_LEN]++;
+	} else {
+		BT_PrintData(Adapter, "[COL], c2h ack:", length, tmpBuf);
+
+		p_c2h_ack = (PCOL_C2H_ACK)tmpBuf;
+		req_num = p_c2h_ack->req_num;
+
+		_rtw_memmove(&gl_coex_offload.c2h_ack_buf[req_num][0], tmpBuf, length);
+		gl_coex_offload.c2h_ack_len[req_num] = length;
+
+		complete(&gl_coex_offload.c2h_event[req_num]);
+	}
+}
+
+static void BT_CoexOffloadC2hIndCheck(PADAPTER Adapter, u8 *tmpBuf, u8 length)
+{
+	PADAPTER		pDefaultAdapter = GetDefaultAdapter(Adapter);
+	PCOL_C2H_IND	p_c2h_ind = NULL;
+	u8			ind_type = 0, ind_version = 0, ind_length = 0;
+
+	if (pDefaultAdapter != Adapter)
+		return;
+
+	if (!hal_btcoex_IsBtExist(Adapter))
+		return;
+
+	gl_coex_offload.cnt_c2h_ind++;
+
+	if (length < COL_C2H_IND_HDR_LEN) {		/* c2h indication length must >= 3 (type, version and length) */
+		gl_coex_offload.c2h_ind_status[COL_STATUS_INVALID_C2H_LEN]++;
+	} else {
+		BT_PrintData(Adapter, "[COL], c2h indication:", length, tmpBuf);
+
+		p_c2h_ind = (PCOL_C2H_IND)tmpBuf;
+		ind_type = p_c2h_ind->type;
+		ind_version = p_c2h_ind->version;
+		ind_length = p_c2h_ind->length;
+
+		_rtw_memmove(&gl_coex_offload.c2h_ind_buf[0], tmpBuf, length);
+		gl_coex_offload.c2h_ind_len = length;
+
+		/* log */
+		gl_coex_offload.c2h_ind_record[ind_type].count++;
+		gl_coex_offload.c2h_ind_record[ind_type].status[COL_STATUS_C2H_OK]++;
+		_rtw_memmove(&gl_coex_offload.c2h_ind_record[ind_type].ind_buf[0], tmpBuf, length);
+		gl_coex_offload.c2h_ind_record[ind_type].ind_len = length;
+
+		gl_coex_offload.c2h_ind_status[COL_STATUS_C2H_OK]++;
+		/*TODO: need to check c2h indication length*/
+		/* TODO: Notification */
+	}
+}
+
+void BT_CoexOffloadC2hCheck(PADAPTER Adapter, u8 *Buffer, u8 Length)
+{
+#if 0 /*(USE_HAL_MAC_API == 1)*/
+	u8	c2hSubCmdId = 0, c2hAckLen = 0, h2cCmdId = 0, h2cSubCmdId = 0, c2hIndLen = 0;
+
+	BT_PrintData(Adapter, "[COL], c2h packet:", Length - 2, Buffer + 2);
+	c2hSubCmdId = (u1Byte)C2H_HDR_GET_C2H_SUB_CMD_ID(Buffer);
+
+	if (c2hSubCmdId == C2H_SUB_CMD_ID_H2C_ACK_HDR ||
+	    c2hSubCmdId == C2H_SUB_CMD_ID_BT_COEX_INFO) {
+		if (c2hSubCmdId == C2H_SUB_CMD_ID_H2C_ACK_HDR) {
+			/* coex c2h ack */
+			h2cCmdId = (u1Byte)H2C_ACK_HDR_GET_H2C_CMD_ID(Buffer);
+			h2cSubCmdId = (u1Byte)H2C_ACK_HDR_GET_H2C_SUB_CMD_ID(Buffer);
+			if (h2cCmdId == 0xff && h2cSubCmdId == 0x60) {
+				c2hAckLen = (u1Byte)C2H_HDR_GET_LEN(Buffer);
+				if (c2hAckLen >= 8)
+					BT_CoexOffloadC2hAckCheck(Adapter, &Buffer[12], (u1Byte)(c2hAckLen - 8));
+				else
+					BT_CoexOffloadRecordErrC2hAck(Adapter);
+			}
+		} else if (c2hSubCmdId == C2H_SUB_CMD_ID_BT_COEX_INFO) {
+			/* coex c2h indication */
+			c2hIndLen = (u1Byte)C2H_HDR_GET_LEN(Buffer);
+			BT_CoexOffloadC2hIndCheck(Adapter, &Buffer[4], (u1Byte)c2hIndLen);
+		}
+	}
+#endif
+}
+#endif
+
+/* ************************************
+ *		Extern functions called by other module
+ * ************************************ */
+u8 EXhalbtcoutsrc_BindBtCoexWithAdapter(void *padapter)
+{
+	PBTC_COEXIST		pBtCoexist = &GLBtCoexist;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA((PADAPTER)padapter);
+
+	if (pBtCoexist->bBinded)
+		return _FALSE;
+	else
+		pBtCoexist->bBinded = _TRUE;
+
+	pBtCoexist->statistics.cnt_bind++;
+
+	pBtCoexist->Adapter = padapter;
+	pBtCoexist->odm_priv = (PVOID)&(pHalData->odmpriv);
+
+	pBtCoexist->stack_info.profile_notified = _FALSE;
+
+	pBtCoexist->bt_info.bt_ctrl_agg_buf_size = _FALSE;
+	pBtCoexist->bt_info.agg_buf_size = 5;
+
+	pBtCoexist->bt_info.increase_scan_dev_num = _FALSE;
+	pBtCoexist->bt_info.miracast_plus_bt = _FALSE;
+
+	return _TRUE;
+}
+
+void EXhalbtcoutsrc_AntInfoSetting(void *padapter)
+{
+	PBTC_COEXIST		pBtCoexist = &GLBtCoexist;
+	u8	antNum = 1, singleAntPath = 0;
+
+	antNum = rtw_btcoex_get_pg_ant_num((PADAPTER)padapter);
+	EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_PG, antNum);
+
+	if (antNum == 1) {
+		singleAntPath = rtw_btcoex_get_pg_single_ant_path((PADAPTER)padapter);
+		EXhalbtcoutsrc_SetSingleAntPath(singleAntPath);
+	}
+
+	pBtCoexist->board_info.customerID = RT_CID_DEFAULT;
+
+	/* set default antenna position to main  port */
+	pBtCoexist->board_info.btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
+
+	pBtCoexist->board_info.btdm_ant_det_finish = _FALSE;
+	pBtCoexist->board_info.btdm_ant_num_by_ant_det = 1;
+
+	pBtCoexist->board_info.tfbga_package = rtw_btcoex_is_tfbga_package_type((PADAPTER)padapter);
+
+	pBtCoexist->board_info.rfe_type = rtw_btcoex_get_pg_rfe_type((PADAPTER)padapter);
+
+	pBtCoexist->board_info.ant_div_cfg = rtw_btcoex_get_ant_div_cfg((PADAPTER)padapter);
+
+}
+
+u8 EXhalbtcoutsrc_InitlizeVariables(void *padapter)
+{
+	PBTC_COEXIST pBtCoexist = &GLBtCoexist;
+
+	/* pBtCoexist->statistics.cntBind++; */
+
+	halbtcoutsrc_DbgInit();
+
+	halbtcoutsrc_coex_offload_init();
+
+#ifdef CONFIG_PCI_HCI
+	pBtCoexist->chip_interface = BTC_INTF_PCI;
+#elif defined(CONFIG_USB_HCI)
+	pBtCoexist->chip_interface = BTC_INTF_USB;
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	pBtCoexist->chip_interface = BTC_INTF_SDIO;
+#else
+	pBtCoexist->chip_interface = BTC_INTF_UNKNOWN;
+#endif
+
+	EXhalbtcoutsrc_BindBtCoexWithAdapter(padapter);
+
+	pBtCoexist->btc_read_1byte = halbtcoutsrc_Read1Byte;
+	pBtCoexist->btc_write_1byte = halbtcoutsrc_Write1Byte;
+	pBtCoexist->btc_write_1byte_bitmask = halbtcoutsrc_BitMaskWrite1Byte;
+	pBtCoexist->btc_read_2byte = halbtcoutsrc_Read2Byte;
+	pBtCoexist->btc_write_2byte = halbtcoutsrc_Write2Byte;
+	pBtCoexist->btc_read_4byte = halbtcoutsrc_Read4Byte;
+	pBtCoexist->btc_write_4byte = halbtcoutsrc_Write4Byte;
+	pBtCoexist->btc_write_local_reg_1byte = halbtcoutsrc_WriteLocalReg1Byte;
+
+	pBtCoexist->btc_set_bb_reg = halbtcoutsrc_SetBbReg;
+	pBtCoexist->btc_get_bb_reg = halbtcoutsrc_GetBbReg;
+
+	pBtCoexist->btc_set_rf_reg = halbtcoutsrc_SetRfReg;
+	pBtCoexist->btc_get_rf_reg = halbtcoutsrc_GetRfReg;
+
+	pBtCoexist->btc_fill_h2c = halbtcoutsrc_FillH2cCmd;
+	pBtCoexist->btc_disp_dbg_msg = halbtcoutsrc_DisplayDbgMsg;
+
+	pBtCoexist->btc_get = halbtcoutsrc_Get;
+	pBtCoexist->btc_set = halbtcoutsrc_Set;
+	pBtCoexist->btc_get_bt_reg = halbtcoutsrc_GetBtReg;
+	pBtCoexist->btc_set_bt_reg = halbtcoutsrc_SetBtReg;
+	pBtCoexist->btc_set_bt_ant_detection = halbtcoutsrc_SetBtAntDetection;
+	pBtCoexist->btc_set_bt_trx_mask = halbtcoutsrc_SetBtTRXMASK;
+	pBtCoexist->btc_coex_h2c_process = halbtcoutsrc_CoexH2cProcess;
+	pBtCoexist->btc_get_bt_coex_supported_feature = halbtcoutsrc_GetBtCoexSupportedFeature;
+	pBtCoexist->btc_get_bt_coex_supported_version= halbtcoutsrc_GetBtCoexSupportedVersion;
+	pBtCoexist->btc_get_ant_det_val_from_bt = halbtcoutsrc_GetAntDetValFromBt;
+	pBtCoexist->btc_get_ble_scan_type_from_bt = halbtcoutsrc_GetBleScanTypeFromBt;
+	pBtCoexist->btc_get_ble_scan_para_from_bt = halbtcoutsrc_GetBleScanParaFromBt;
+	pBtCoexist->btc_get_bt_afh_map_from_bt = halbtcoutsrc_GetBtAFHMapFromBt;
+	pBtCoexist->btc_get_bt_phydm_version = halbtcoutsrc_GetPhydmVersion;
+	pBtCoexist->btc_phydm_modify_RA_PCR_threshold = halbtcoutsrc_phydm_modify_RA_PCR_threshold;
+	pBtCoexist->btc_phydm_query_PHY_counter = halbtcoutsrc_phydm_query_PHY_counter;
+	pBtCoexist->btc_phydm_modify_ANTDIV_HwSw = halbtcoutsrc_phydm_modify_AntDiv_HwSw;
+
+	pBtCoexist->cli_buf = &GLBtcDbgBuf[0];
+
+	GLBtcWiFiInScanState = _FALSE;
+
+	GLBtcWiFiInIQKState = _FALSE;
+
+	GLBtcWiFiInIPS = _FALSE;
+
+	GLBtcWiFiInLPS = _FALSE;
+
+	GLBtcBtCoexAliveRegistered = _FALSE;
+
+	/* BT Control H2C/C2H*/
+	GLBtcBtMpOperSeq = 0;
+	_rtw_mutex_init(&GLBtcBtMpOperLock);
+	rtw_init_timer(&GLBtcBtMpOperTimer, padapter, _btmpoper_timer_hdl, pBtCoexist);
+	_rtw_init_sema(&GLBtcBtMpRptSema, 0);
+	GLBtcBtMpRptSeq = 0;
+	GLBtcBtMpRptStatus = 0;
+	_rtw_memset(GLBtcBtMpRptRsp, 0, C2H_MAX_SIZE);
+	GLBtcBtMpRptRspSize = 0;
+	GLBtcBtMpRptWait = _FALSE;
+	GLBtcBtMpRptWiFiOK = _FALSE;
+	GLBtcBtMpRptBTOK = _FALSE;
+
+	return _TRUE;
+}
+
+void EXhalbtcoutsrc_PowerOnSetting(PBTC_COEXIST pBtCoexist)
+{
+	HAL_DATA_TYPE	*pHalData = NULL;
+
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	pHalData = GET_HAL_DATA((PADAPTER)pBtCoexist->Adapter);
+
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_power_on_setting(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_power_on_setting(pBtCoexist);
+#endif
+	}
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_power_on_setting(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_power_on_setting(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_power_on_setting(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821A
+	else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_power_on_setting(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_power_on_setting(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if ((IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_power_on_setting(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_power_on_setting(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if ((IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_power_on_setting(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_power_on_setting(pBtCoexist);
+	}
+#endif
+}
+
+void EXhalbtcoutsrc_PreLoadFirmware(PBTC_COEXIST pBtCoexist)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	pBtCoexist->statistics.cnt_pre_load_firmware++;
+
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_pre_load_firmware(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_pre_load_firmware(pBtCoexist);
+#endif
+	}
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_pre_load_firmware(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_pre_load_firmware(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_pre_load_firmware(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_pre_load_firmware(pBtCoexist);
+	}
+#endif
+}
+
+void EXhalbtcoutsrc_init_hw_config(PBTC_COEXIST pBtCoexist, u8 bWifiOnly)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	pBtCoexist->statistics.cnt_init_hw_config++;
+
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_init_hw_config(pBtCoexist, bWifiOnly);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_init_hw_config(pBtCoexist, bWifiOnly);
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_init_hw_config(pBtCoexist, bWifiOnly);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_init_hw_config(pBtCoexist, bWifiOnly);
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_init_hw_config(pBtCoexist, bWifiOnly);
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_init_hw_config(pBtCoexist, bWifiOnly);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_init_hw_config(pBtCoexist, bWifiOnly);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_init_hw_config(pBtCoexist, bWifiOnly);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_init_hw_config(pBtCoexist, bWifiOnly);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_init_hw_config(pBtCoexist, bWifiOnly);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_init_hw_config(pBtCoexist, bWifiOnly);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_init_hw_config(pBtCoexist, bWifiOnly);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_init_hw_config(pBtCoexist, bWifiOnly);
+		#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+		rtw_hal_set_default_port_id_cmd(pBtCoexist->Adapter, 0);
+		rtw_hal_set_wifi_port_id_cmd(pBtCoexist->Adapter);
+		#endif
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_init_hw_config(pBtCoexist, bWifiOnly);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_init_hw_config(pBtCoexist, bWifiOnly);
+		#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+		rtw_hal_set_default_port_id_cmd(pBtCoexist->Adapter, 0);
+		rtw_hal_set_wifi_port_id_cmd(pBtCoexist->Adapter);
+		#endif
+	}
+#endif
+}
+
+void EXhalbtcoutsrc_init_coex_dm(PBTC_COEXIST pBtCoexist)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	pBtCoexist->statistics.cnt_init_coex_dm++;
+
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_init_coex_dm(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_init_coex_dm(pBtCoexist);
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_init_coex_dm(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_init_coex_dm(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_init_coex_dm(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_init_coex_dm(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_init_coex_dm(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_init_coex_dm(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_init_coex_dm(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_init_coex_dm(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_init_coex_dm(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_init_coex_dm(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_init_coex_dm(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_init_coex_dm(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_init_coex_dm(pBtCoexist);
+	}
+#endif
+
+	pBtCoexist->initilized = _TRUE;
+}
+
+void EXhalbtcoutsrc_ips_notify(PBTC_COEXIST pBtCoexist, u8 type)
+{
+	u8	ipsType;
+
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	pBtCoexist->statistics.cnt_ips_notify++;
+	if (pBtCoexist->manual_control)
+		return;
+
+	if (IPS_NONE == type) {
+		ipsType = BTC_IPS_LEAVE;
+		GLBtcWiFiInIPS = _FALSE;
+	} else {
+		ipsType = BTC_IPS_ENTER;
+		GLBtcWiFiInIPS = _TRUE;
+	}
+
+	/* All notify is called in cmd thread, don't need to leave low power again
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
+
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_ips_notify(pBtCoexist, ipsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_ips_notify(pBtCoexist, ipsType);
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_ips_notify(pBtCoexist, ipsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_ips_notify(pBtCoexist, ipsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_ips_notify(pBtCoexist, ipsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_ips_notify(pBtCoexist, ipsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_ips_notify(pBtCoexist, ipsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_ips_notify(pBtCoexist, ipsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_ips_notify(pBtCoexist, ipsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_ips_notify(pBtCoexist, ipsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_ips_notify(pBtCoexist, ipsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_ips_notify(pBtCoexist, ipsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_ips_notify(pBtCoexist, ipsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_ips_notify(pBtCoexist, ipsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_ips_notify(pBtCoexist, ipsType);
+	}
+#endif
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
+}
+
+void EXhalbtcoutsrc_lps_notify(PBTC_COEXIST pBtCoexist, u8 type)
+{
+	u8 lpsType;
+
+
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	pBtCoexist->statistics.cnt_lps_notify++;
+	if (pBtCoexist->manual_control)
+		return;
+
+	if (PS_MODE_ACTIVE == type) {
+		lpsType = BTC_LPS_DISABLE;
+		GLBtcWiFiInLPS = _FALSE;
+	} else {
 		lpsType = BTC_LPS_ENABLE;
 		GLBtcWiFiInLPS = _TRUE;
 	}
-	
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_LpsNotify(pBtCoexist, lpsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_LpsNotify(pBtCoexist, lpsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_LpsNotify(pBtCoexist, lpsType);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_LpsNotify(pBtCoexist, lpsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_LpsNotify(pBtCoexist, lpsType);
+
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_lps_notify(pBtCoexist, lpsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_lps_notify(pBtCoexist, lpsType);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_LpsNotify(pBtCoexist, lpsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_LpsNotify(pBtCoexist, lpsType);
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_lps_notify(pBtCoexist, lpsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_lps_notify(pBtCoexist, lpsType);
 	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_LpsNotify(pBtCoexist, lpsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_LpsNotify(pBtCoexist, lpsType);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_lps_notify(pBtCoexist, lpsType);
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_LpsNotify(pBtCoexist, lpsType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_LpsNotify(pBtCoexist, lpsType);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_lps_notify(pBtCoexist, lpsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_lps_notify(pBtCoexist, lpsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_lps_notify(pBtCoexist, lpsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_lps_notify(pBtCoexist, lpsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_lps_notify(pBtCoexist, lpsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_lps_notify(pBtCoexist, lpsType);
 	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_lps_notify(pBtCoexist, lpsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_lps_notify(pBtCoexist, lpsType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_lps_notify(pBtCoexist, lpsType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_lps_notify(pBtCoexist, lpsType);
+	}
+#endif
 }
 
-void EXhalbtcoutsrc_ScanNotify(PBTC_COEXIST pBtCoexist, u8 type)
+void EXhalbtcoutsrc_scan_notify(PBTC_COEXIST pBtCoexist, u8 type)
 {
 	u8	scanType;
 
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
-	pBtCoexist->statistics.cntScanNotify++;
-	if (pBtCoexist->bManualControl)
+	pBtCoexist->statistics.cnt_scan_notify++;
+	if (pBtCoexist->manual_control)
 		return;
 
-	if (type)
-	{
+	if (type) {
 		scanType = BTC_SCAN_START;
 		GLBtcWiFiInScanState = _TRUE;
-	}
-	else
-	{
+	} else {
 		scanType = BTC_SCAN_FINISH;
 		GLBtcWiFiInScanState = _FALSE;
 	}
 
-	// All notify is called in cmd thread, don't need to leave low power again
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+	/* All notify is called in cmd thread, don't need to leave low power again
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_ScanNotify(pBtCoexist, scanType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_ScanNotify(pBtCoexist, scanType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_ScanNotify(pBtCoexist, scanType);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_ScanNotify(pBtCoexist, scanType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_ScanNotify(pBtCoexist, scanType);
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_scan_notify(pBtCoexist, scanType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_scan_notify(pBtCoexist, scanType);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_ScanNotify(pBtCoexist, scanType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_ScanNotify(pBtCoexist, scanType);
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_scan_notify(pBtCoexist, scanType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_scan_notify(pBtCoexist, scanType);
 	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_ScanNotify(pBtCoexist, scanType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_ScanNotify(pBtCoexist, scanType);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_scan_notify(pBtCoexist, scanType);
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_ScanNotify(pBtCoexist, scanType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_ScanNotify(pBtCoexist, scanType);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_scan_notify(pBtCoexist, scanType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_scan_notify(pBtCoexist, scanType);
 	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_scan_notify(pBtCoexist, scanType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_scan_notify(pBtCoexist, scanType);
+	}
+#endif
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_scan_notify(pBtCoexist, scanType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_scan_notify(pBtCoexist, scanType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_scan_notify(pBtCoexist, scanType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_scan_notify(pBtCoexist, scanType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_scan_notify(pBtCoexist, scanType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_scan_notify(pBtCoexist, scanType);
+	}
+#endif
+
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
-void EXhalbtcoutsrc_ConnectNotify(PBTC_COEXIST pBtCoexist, u8 action)
+void EXhalbtcoutsrc_SetAntennaPathNotify(PBTC_COEXIST pBtCoexist, u8 type)
 {
-	u8	assoType;
+#if 0
+	u8	switchType;
 
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
-	pBtCoexist->statistics.cntConnectNotify++;
-	if (pBtCoexist->bManualControl)
+
+	if (pBtCoexist->manual_control)
 		return;
 
-	if (action)
-		assoType = BTC_ASSOCIATE_START;
-	else
-		assoType = BTC_ASSOCIATE_FINISH;
+	halbtcoutsrc_LeaveLowPower(pBtCoexist);
 
-	// All notify is called in cmd thread, don't need to leave low power again
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+	switchType = type;
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_ConnectNotify(pBtCoexist, assoType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_ConnectNotify(pBtCoexist, assoType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_ConnectNotify(pBtCoexist, assoType);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_ConnectNotify(pBtCoexist, assoType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_ConnectNotify(pBtCoexist, assoType);
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_set_antenna_notify(pBtCoexist, type);
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_ConnectNotify(pBtCoexist, assoType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_ConnectNotify(pBtCoexist, assoType);
+	if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_set_antenna_notify(pBtCoexist, type);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_set_antenna_notify(pBtCoexist, type);
 	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_ConnectNotify(pBtCoexist, assoType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_ConnectNotify(pBtCoexist, assoType);
+
+	halbtcoutsrc_NormalLowPower(pBtCoexist);
+#endif
+}
+
+void EXhalbtcoutsrc_connect_notify(PBTC_COEXIST pBtCoexist, u8 assoType)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+	pBtCoexist->statistics.cnt_connect_notify++;
+	if (pBtCoexist->manual_control)
+		return;
+	
+	/* All notify is called in cmd thread, don't need to leave low power again
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_connect_notify(pBtCoexist, assoType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_connect_notify(pBtCoexist, assoType);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_ConnectNotify(pBtCoexist, assoType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_ConnectNotify(pBtCoexist, assoType);
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_connect_notify(pBtCoexist, assoType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_connect_notify(pBtCoexist, assoType);
 	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_connect_notify(pBtCoexist, assoType);
+	}
+#endif
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_connect_notify(pBtCoexist, assoType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_connect_notify(pBtCoexist, assoType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_connect_notify(pBtCoexist, assoType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_connect_notify(pBtCoexist, assoType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_connect_notify(pBtCoexist, assoType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_connect_notify(pBtCoexist, assoType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_connect_notify(pBtCoexist, assoType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_connect_notify(pBtCoexist, assoType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_connect_notify(pBtCoexist, assoType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_connect_notify(pBtCoexist, assoType);
+	}
+#endif
+
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
-void EXhalbtcoutsrc_MediaStatusNotify(PBTC_COEXIST pBtCoexist, RT_MEDIA_STATUS mediaStatus)
+void EXhalbtcoutsrc_media_status_notify(PBTC_COEXIST pBtCoexist, RT_MEDIA_STATUS mediaStatus)
 {
 	u8 mStatus;
 
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	pBtCoexist->statistics.cntMediaStatusNotify++;
-	if (pBtCoexist->bManualControl)
+	pBtCoexist->statistics.cnt_media_status_notify++;
+	if (pBtCoexist->manual_control)
 		return;
 
 	if (RT_MEDIA_CONNECT == mediaStatus)
@@ -2212,58 +3308,89 @@ void EXhalbtcoutsrc_MediaStatusNotify(PBTC_COEXIST pBtCoexist, RT_MEDIA_STATUS m
 	else
 		mStatus = BTC_MEDIA_DISCONNECT;
 
-	// All notify is called in cmd thread, don't need to leave low power again
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+	/* All notify is called in cmd thread, don't need to leave low power again
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_media_status_notify(pBtCoexist, mStatus);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_media_status_notify(pBtCoexist, mStatus);
+#endif
+	}
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_MediaStatusNotify(pBtCoexist, mStatus);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_MediaStatusNotify(pBtCoexist, mStatus);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_MediaStatusNotify(pBtCoexist, mStatus);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_MediaStatusNotify(pBtCoexist, mStatus);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_MediaStatusNotify(pBtCoexist, mStatus);
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_media_status_notify(pBtCoexist, mStatus);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_media_status_notify(pBtCoexist, mStatus);
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_MediaStatusNotify(pBtCoexist, mStatus);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_MediaStatusNotify(pBtCoexist, mStatus);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_media_status_notify(pBtCoexist, mStatus);
 	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_MediaStatusNotify(pBtCoexist, mStatus);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_MediaStatusNotify(pBtCoexist, mStatus);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_media_status_notify(pBtCoexist, mStatus);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_media_status_notify(pBtCoexist, mStatus);
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_MediaStatusNotify(pBtCoexist, mStatus);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_MediaStatusNotify(pBtCoexist, mStatus);
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_media_status_notify(pBtCoexist, mStatus);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_media_status_notify(pBtCoexist, mStatus);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_media_status_notify(pBtCoexist, mStatus);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_media_status_notify(pBtCoexist, mStatus);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_media_status_notify(pBtCoexist, mStatus);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_media_status_notify(pBtCoexist, mStatus);
 	}
+#endif
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_media_status_notify(pBtCoexist, mStatus);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_media_status_notify(pBtCoexist, mStatus);
+	}
+#endif
+
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
-void EXhalbtcoutsrc_SpecialPacketNotify(PBTC_COEXIST pBtCoexist, u8 pktType)
+void EXhalbtcoutsrc_specific_packet_notify(PBTC_COEXIST pBtCoexist, u8 pktType)
 {
 	u8	packetType;
 
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
-	pBtCoexist->statistics.cntSpecialPacketNotify++;
-	if (pBtCoexist->bManualControl)
+	pBtCoexist->statistics.cnt_specific_packet_notify++;
+	if (pBtCoexist->manual_control)
 		return;
 
 	if (PACKET_DHCP == pktType)
@@ -2272,136 +3399,280 @@ void EXhalbtcoutsrc_SpecialPacketNotify(PBTC_COEXIST pBtCoexist, u8 pktType)
 		packetType = BTC_PACKET_EAPOL;
 	else if (PACKET_ARP == pktType)
 		packetType = BTC_PACKET_ARP;
-	else
-	{
+	else {
 		packetType = BTC_PACKET_UNKNOWN;
 		return;
 	}
 
-	// All notify is called in cmd thread, don't need to leave low power again
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+	/* All notify is called in cmd thread, don't need to leave low power again
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_specific_packet_notify(pBtCoexist, packetType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_specific_packet_notify(pBtCoexist, packetType);
+#endif
+	}
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_SpecialPacketNotify(pBtCoexist, packetType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_SpecialPacketNotify(pBtCoexist, packetType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_SpecialPacketNotify(pBtCoexist, packetType);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_SpecialPacketNotify(pBtCoexist, packetType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_SpecialPacketNotify(pBtCoexist, packetType);
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_specific_packet_notify(pBtCoexist, packetType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_specific_packet_notify(pBtCoexist, packetType);
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_SpecialPacketNotify(pBtCoexist, packetType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_SpecialPacketNotify(pBtCoexist, packetType);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_specific_packet_notify(pBtCoexist, packetType);
 	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_SpecialPacketNotify(pBtCoexist, packetType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_SpecialPacketNotify(pBtCoexist, packetType);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_specific_packet_notify(pBtCoexist, packetType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_specific_packet_notify(pBtCoexist, packetType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_specific_packet_notify(pBtCoexist, packetType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_specific_packet_notify(pBtCoexist, packetType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_specific_packet_notify(pBtCoexist, packetType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_specific_packet_notify(pBtCoexist, packetType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_specific_packet_notify(pBtCoexist, packetType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_specific_packet_notify(pBtCoexist, packetType);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_specific_packet_notify(pBtCoexist, packetType);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_specific_packet_notify(pBtCoexist, packetType);
+	}
+#endif
+
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
+}
+
+void EXhalbtcoutsrc_bt_info_notify(PBTC_COEXIST pBtCoexist, u8 *tmpBuf, u8 length)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	pBtCoexist->statistics.cnt_bt_info_notify++;
+
+	/* All notify is called in cmd thread, don't need to leave low power again
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
+
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
+}
+
+void EXhalbtcoutsrc_WlFwDbgInfoNotify(PBTC_COEXIST pBtCoexist, u8* tmpBuf, u8 length)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8703B
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_SpecialPacketNotify(pBtCoexist, packetType);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_SpecialPacketNotify(pBtCoexist, packetType);
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
 	}
+#endif
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
+	}
+#endif
 }
 
-void EXhalbtcoutsrc_BtInfoNotify(PBTC_COEXIST pBtCoexist, u8 *tmpBuf, u8 length)
+void EXhalbtcoutsrc_rx_rate_change_notify(PBTC_COEXIST pBtCoexist, u8 is_data_frame, u8 btc_rate_id)
 {
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	pBtCoexist->statistics.cntBtInfoNotify++;
+	pBtCoexist->statistics.cnt_rate_id_notify++;
 
-	// All notify is called in cmd thread, don't need to leave low power again
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
-
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
+	if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8703B
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_BtInfoNotify(pBtCoexist, tmpBuf, length);
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
 	}
+#endif
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
+	}
+#endif
 }
 
 VOID
 EXhalbtcoutsrc_RfStatusNotify(
 	IN	PBTC_COEXIST		pBtCoexist,
-	IN	u1Byte 				type
-	)
+	IN	u1Byte				type
+)
 {
-	if(!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
-	pBtCoexist->statistics.cntRfStatusNotify++;
-	
-	if(IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
+	pBtCoexist->statistics.cnt_rf_status_notify++;
+
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_rf_status_notify(pBtCoexist, type);
+#endif
 	}
-	else if(IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if(pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_RfStatusNotify(pBtCoexist, type);
-	}	
-	else if(IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if(pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_RfStatusNotify(pBtCoexist, type);
-	}	
-	else if(IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_rf_status_notify(pBtCoexist, type);
 	}
-	else if(IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_rf_status_notify(pBtCoexist, type);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_rf_status_notify(pBtCoexist, type);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_rf_status_notify(pBtCoexist, type);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_rf_status_notify(pBtCoexist, type);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_rf_status_notify(pBtCoexist, type);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_StackOperationNotify(PBTC_COEXIST pBtCoexist, u8 type)
@@ -2412,249 +3683,341 @@ void EXhalbtcoutsrc_StackOperationNotify(PBTC_COEXIST pBtCoexist, u8 type)
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 	pBtCoexist->statistics.cntStackOperationNotify++;
-	if (pBtCoexist->bManualControl)
+	if (pBtCoexist->manual_control)
 		return;
 
 	if ((HCI_BT_OP_INQUIRY_START == type) ||
-		(HCI_BT_OP_PAGING_START == type) ||
-		(HCI_BT_OP_PAIRING_START == type))
-	{
+	    (HCI_BT_OP_PAGING_START == type) ||
+	    (HCI_BT_OP_PAIRING_START == type))
 		stackOpType = BTC_STACK_OP_INQ_PAGE_PAIR_START;
-	}
 	else if ((HCI_BT_OP_INQUIRY_FINISH == type) ||
-		(HCI_BT_OP_PAGING_SUCCESS == type) ||
-		(HCI_BT_OP_PAGING_UNSUCCESS == type) ||
-		(HCI_BT_OP_PAIRING_FINISH == type) )
-	{
+		 (HCI_BT_OP_PAGING_SUCCESS == type) ||
+		 (HCI_BT_OP_PAGING_UNSUCCESS == type) ||
+		 (HCI_BT_OP_PAIRING_FINISH == type))
 		stackOpType = BTC_STACK_OP_INQ_PAGE_PAIR_FINISH;
-	}
 	else
-	{
 		stackOpType = BTC_STACK_OP_NONE;
-	}
 
 #endif
 }
 
-void EXhalbtcoutsrc_HaltNotify(PBTC_COEXIST pBtCoexist)
+void EXhalbtcoutsrc_halt_notify(PBTC_COEXIST pBtCoexist)
 {
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_HaltNotify(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_HaltNotify(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_HaltNotify(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_HaltNotify(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_HaltNotify(pBtCoexist);
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_halt_notify(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_halt_notify(pBtCoexist);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_HaltNotify(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_HaltNotify(pBtCoexist);
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_halt_notify(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_halt_notify(pBtCoexist);
 	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_HaltNotify(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_HaltNotify(pBtCoexist);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_halt_notify(pBtCoexist);
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_HaltNotify(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_HaltNotify(pBtCoexist);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_halt_notify(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_halt_notify(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_halt_notify(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_halt_notify(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_halt_notify(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_halt_notify(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_halt_notify(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_halt_notify(pBtCoexist);
 	}
+#endif
 
-	pBtCoexist->bBinded = FALSE;
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_halt_notify(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_halt_notify(pBtCoexist);
+	}
+#endif
 }
 
 void EXhalbtcoutsrc_SwitchBtTRxMask(PBTC_COEXIST pBtCoexist)
 {
-	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-		{
-			halbtcoutsrc_SetBtReg(pBtCoexist, 0, 0x3c, 0x01); //BT goto standby while GNT_BT 1-->0
-		}
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-		{
-			halbtcoutsrc_SetBtReg(pBtCoexist, 0, 0x3c, 0x15); //BT goto standby while GNT_BT 1-->0
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2) {
+			halbtcoutsrc_SetBtReg(pBtCoexist, 0, 0x3c, 0x01); /* BT goto standby while GNT_BT 1-->0 */
+		} else if (pBtCoexist->board_info.btdm_ant_num == 1) {
+			halbtcoutsrc_SetBtReg(pBtCoexist, 0, 0x3c, 0x15); /* BT goto standby while GNT_BT 1-->0 */
 		}
 	}
 }
 
-void EXhalbtcoutsrc_PnpNotify(PBTC_COEXIST pBtCoexist, u8 pnpState)
+void EXhalbtcoutsrc_pnp_notify(PBTC_COEXIST pBtCoexist, u8 pnpState)
 {
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	//
-	// currently only 1ant we have to do the notification,
-	// once pnp is notified to sleep state, we have to leave LPS that we can sleep normally.
-	//
+	/*  */
+	/* currently only 1ant we have to do the notification, */
+	/* once pnp is notified to sleep state, we have to leave LPS that we can sleep normally. */
+	/*  */
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_pnp_notify(pBtCoexist, pnpState);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_pnp_notify(pBtCoexist, pnpState);
+#endif
+	}
 
-	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_PnpNotify(pBtCoexist,pnpState);
-		else if(pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_PnpNotify(pBtCoexist,pnpState);
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_pnp_notify(pBtCoexist, pnpState);
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_PnpNotify(pBtCoexist,pnpState);
-		else if(pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_PnpNotify(pBtCoexist,pnpState);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_pnp_notify(pBtCoexist, pnpState);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_pnp_notify(pBtCoexist, pnpState);
 	}
-	else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_PnpNotify(pBtCoexist, pnpState);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_PnpNotify(pBtCoexist,pnpState);
-		else if(pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_PnpNotify(pBtCoexist,pnpState);
-	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_PnpNotify(pBtCoexist, pnpState);
+#endif
+
+#ifdef CONFIG_RTL8821A
+	else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_pnp_notify(pBtCoexist, pnpState);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_pnp_notify(pBtCoexist, pnpState);
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_PnpNotify(pBtCoexist, pnpState);
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_pnp_notify(pBtCoexist, pnpState);
 	}
-}
+#endif
 
-void EXhalbtcoutsrc_ScoreBoardStatusNotify(PBTC_COEXIST pBtCoexist, u8 *tmpBuf, u8 length)
-{
-	if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
-		if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_ScoreBoardStatusNotify(pBtCoexist, tmpBuf, length);
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_pnp_notify(pBtCoexist, pnpState);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_pnp_notify(pBtCoexist, pnpState);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_pnp_notify(pBtCoexist, pnpState);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_pnp_notify(pBtCoexist, pnpState);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_pnp_notify(pBtCoexist, pnpState);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_CoexDmSwitch(PBTC_COEXIST pBtCoexist)
 {
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
-	pBtCoexist->statistics.cntCoexDmSwitch++;
+	pBtCoexist->statistics.cnt_coex_dm_switch++;
 
 	halbtcoutsrc_LeaveLowPower(pBtCoexist);
 
-	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 1)
-		{
-			pBtCoexist->bStopCoexDm = TRUE;
-			EXhalbtc8723b1ant_CoexDmReset(pBtCoexist);
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
+		if (pBtCoexist->board_info.btdm_ant_num == 1) {
+			pBtCoexist->stop_coex_dm = TRUE;
+			ex_halbtc8723b1ant_coex_dm_reset(pBtCoexist);
+			EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_DETECTED, 2);
+			ex_halbtc8723b2ant_init_hw_config(pBtCoexist, FALSE);
+			ex_halbtc8723b2ant_init_coex_dm(pBtCoexist);
+			pBtCoexist->stop_coex_dm = FALSE;
+		}
+#endif
+	}
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1) {
+			pBtCoexist->stop_coex_dm = TRUE;
+			ex_halbtc8723d1ant_coex_dm_reset(pBtCoexist);
 			EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_DETECTED, 2);
-			EXhalbtc8723b2ant_InitHwConfig(pBtCoexist, FALSE);
-			EXhalbtc8723b2ant_InitCoexDm(pBtCoexist);
-			pBtCoexist->bStopCoexDm = FALSE;
+			ex_halbtc8723d2ant_init_hw_config(pBtCoexist, FALSE);
+			ex_halbtc8723d2ant_init_coex_dm(pBtCoexist);
+			pBtCoexist->stop_coex_dm = FALSE;
 		}
 	}
+#endif
 
 	halbtcoutsrc_NormalLowPower(pBtCoexist);
 }
 
-void EXhalbtcoutsrc_Periodical(PBTC_COEXIST pBtCoexist)
+void EXhalbtcoutsrc_periodical(PBTC_COEXIST pBtCoexist)
 {
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
-	pBtCoexist->statistics.cntPeriodical++;
-
-	// Periodical should be called in cmd thread,
-	// don't need to leave low power again
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
-
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_Periodical(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_Periodical(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-		{
+	pBtCoexist->statistics.cnt_periodical++;
+
+	/* Periodical should be called in cmd thread, */
+	/* don't need to leave low power again
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_periodical(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1) {
 			if (!halbtcoutsrc_UnderIps(pBtCoexist))
-			{
-				EXhalbtc8821a1ant_Periodical(pBtCoexist);
-			}
+				ex_halbtc8821a1ant_periodical(pBtCoexist);
 		}
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_Periodical(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_Periodical(pBtCoexist);
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_periodical(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_periodical(pBtCoexist);
 	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_Periodical(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_Periodical(pBtCoexist);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_periodical(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_periodical(pBtCoexist);
 	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_Periodical(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_Periodical(pBtCoexist);
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_periodical(pBtCoexist);
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_Periodical(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_Periodical(pBtCoexist);
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_periodical(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_periodical(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_periodical(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_periodical(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_periodical(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_periodical(pBtCoexist);
 	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_periodical(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_periodical(pBtCoexist);
+	}
+#endif
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
-void EXhalbtcoutsrc_DbgControl(PBTC_COEXIST pBtCoexist, u8 opCode, u8 opLen, u8 *pData)
+void EXhalbtcoutsrc_dbg_control(PBTC_COEXIST pBtCoexist, u8 opCode, u8 opLen, u8 *pData)
 {
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	pBtCoexist->statistics.cntDbgCtrl++;
+	pBtCoexist->statistics.cnt_dbg_ctrl++;
 
-	// This function doesn't be called yet,
-	// default no need to leave low power to avoid deadlock
-//	halbtcoutsrc_LeaveLowPower(pBtCoexist);
-
-	if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_DbgControl(pBtCoexist, opCode, opLen, pData);
+	/* This function doesn't be called yet, */
+	/* default no need to leave low power to avoid deadlock
+	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
+	if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8192E
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_DbgControl(pBtCoexist, opCode, opLen, pData);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_DbgControl(pBtCoexist, opCode, opLen, pData);
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_dbg_control(pBtCoexist, opCode, opLen, pData);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
 	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter))
+		if(pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
+#endif
 
-//	halbtcoutsrc_NormalLowPower(pBtCoexist);
+	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
 #if 0
@@ -2665,24 +4028,23 @@ EXhalbtcoutsrc_AntennaDetection(
 	IN	u4Byte					offset,
 	IN	u4Byte					span,
 	IN	u4Byte					seconds
-	)
+)
 {
-	if(!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	/* Need to refine the following power save operations to enable this function in the future */	
+	/* Need to refine the following power save operations to enable this function in the future */
 #if 0
 	IPSDisable(pBtCoexist->Adapter, FALSE, 0);
 	LeisurePSLeave(pBtCoexist->Adapter, LPS_DISABLE_BT_COEX);
 #endif
 
-	if(IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if(pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_AntennaDetection(pBtCoexist, centFreq, offset, span, seconds);
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_AntennaDetection(pBtCoexist, centFreq, offset, span, seconds);
 	}
 
-	//IPSReturn(pBtCoexist->Adapter, 0xff);
+	/* IPSReturn(pBtCoexist->Adapter, 0xff); */
 }
 #endif
 
@@ -2697,53 +4059,43 @@ void EXhalbtcoutsrc_StackUpdateProfileInfo(void)
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	pBtCoexist->stackInfo.bProfileNotified = _TRUE;
+	pBtCoexist->stack_info.profile_notified = _TRUE;
 
-	pBtCoexist->stackInfo.numOfLink =
-		pBtMgnt->ExtConfig.NumberOfACL+pBtMgnt->ExtConfig.NumberOfSCO;
+	pBtCoexist->stack_info.num_of_link =
+		pBtMgnt->ExtConfig.NumberOfACL + pBtMgnt->ExtConfig.NumberOfSCO;
 
-	// reset first
-	pBtCoexist->stackInfo.bBtLinkExist = _FALSE;
-	pBtCoexist->stackInfo.bScoExist = _FALSE;
-	pBtCoexist->stackInfo.bAclExist = _FALSE;
-	pBtCoexist->stackInfo.bA2dpExist = _FALSE;
-	pBtCoexist->stackInfo.bHidExist = _FALSE;
-	pBtCoexist->stackInfo.numOfHid = 0;
-	pBtCoexist->stackInfo.bPanExist = _FALSE;
+	/* reset first */
+	pBtCoexist->stack_info.bt_link_exist = _FALSE;
+	pBtCoexist->stack_info.sco_exist = _FALSE;
+	pBtCoexist->stack_info.acl_exist = _FALSE;
+	pBtCoexist->stack_info.a2dp_exist = _FALSE;
+	pBtCoexist->stack_info.hid_exist = _FALSE;
+	pBtCoexist->stack_info.num_of_hid = 0;
+	pBtCoexist->stack_info.pan_exist = _FALSE;
 
 	if (!pBtMgnt->ExtConfig.NumberOfACL)
-		pBtCoexist->stackInfo.minBtRssi = 0;
+		pBtCoexist->stack_info.min_bt_rssi = 0;
 
-	if (pBtCoexist->stackInfo.numOfLink)
-	{
-		pBtCoexist->stackInfo.bBtLinkExist = _TRUE;
+	if (pBtCoexist->stack_info.num_of_link) {
+		pBtCoexist->stack_info.bt_link_exist = _TRUE;
 		if (pBtMgnt->ExtConfig.NumberOfSCO)
-			pBtCoexist->stackInfo.bScoExist = _TRUE;
+			pBtCoexist->stack_info.sco_exist = _TRUE;
 		if (pBtMgnt->ExtConfig.NumberOfACL)
-			pBtCoexist->stackInfo.bAclExist = _TRUE;
+			pBtCoexist->stack_info.acl_exist = _TRUE;
 	}
 
-	for (i=0; i<pBtMgnt->ExtConfig.NumberOfACL; i++)
-	{
+	for (i = 0; i < pBtMgnt->ExtConfig.NumberOfACL; i++) {
 		if (BT_PROFILE_A2DP == pBtMgnt->ExtConfig.aclLink[i].BTProfile)
-		{
-			pBtCoexist->stackInfo.bA2dpExist = _TRUE;
-		}
+			pBtCoexist->stack_info.a2dp_exist = _TRUE;
 		else if (BT_PROFILE_PAN == pBtMgnt->ExtConfig.aclLink[i].BTProfile)
-		{
-			pBtCoexist->stackInfo.bPanExist = _TRUE;
-		}
-		else if (BT_PROFILE_HID == pBtMgnt->ExtConfig.aclLink[i].BTProfile)
-		{
-			pBtCoexist->stackInfo.bHidExist = _TRUE;
-			pBtCoexist->stackInfo.numOfHid++;
-		}
-		else
-		{
-			pBtCoexist->stackInfo.bUnknownAclExist = _TRUE;
-		}
+			pBtCoexist->stack_info.pan_exist = _TRUE;
+		else if (BT_PROFILE_HID == pBtMgnt->ExtConfig.aclLink[i].BTProfile) {
+			pBtCoexist->stack_info.hid_exist = _TRUE;
+			pBtCoexist->stack_info.num_of_hid++;
+		} else
+			pBtCoexist->stack_info.unknown_acl_exist = _TRUE;
 	}
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 }
 
 void EXhalbtcoutsrc_UpdateMinBtRssi(s8 btRssi)
@@ -2753,7 +4105,7 @@ void EXhalbtcoutsrc_UpdateMinBtRssi(s8 btRssi)
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	pBtCoexist->stackInfo.minBtRssi = btRssi;
+	pBtCoexist->stack_info.min_bt_rssi = btRssi;
 }
 
 void EXhalbtcoutsrc_SetHciVersion(u16 hciVersion)
@@ -2763,7 +4115,7 @@ void EXhalbtcoutsrc_SetHciVersion(u16 hciVersion)
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	pBtCoexist->stackInfo.hciVersion = hciVersion;
+	pBtCoexist->stack_info.hci_version = hciVersion;
 }
 
 void EXhalbtcoutsrc_SetBtPatchVersion(u16 btHciVersion, u16 btPatchVersion)
@@ -2773,8 +4125,8 @@ void EXhalbtcoutsrc_SetBtPatchVersion(u16 btHciVersion, u16 btPatchVersion)
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
-	pBtCoexist->btInfo.btRealFwVer = btPatchVersion;
-	pBtCoexist->btInfo.btHciVer = btHciVersion;
+	pBtCoexist->bt_info.bt_real_fw_ver = btPatchVersion;
+	pBtCoexist->bt_info.bt_hci_ver = btHciVersion;
 }
 
 #if 0
@@ -2785,156 +4137,515 @@ void EXhalbtcoutsrc_SetBtExist(u8 bBtExist)
 #endif
 void EXhalbtcoutsrc_SetChipType(u8 chipType)
 {
-	switch(chipType)
-	{
-		default:
-		case BT_2WIRE:
-		case BT_ISSC_3WIRE:
-		case BT_ACCEL:
-		case BT_RTL8756:
-			GLBtCoexist.boardInfo.btChipType = BTC_CHIP_UNDEF;
-			break;
-		case BT_CSR_BC4:
-			GLBtCoexist.boardInfo.btChipType = BTC_CHIP_CSR_BC4;
-			break;
-		case BT_CSR_BC8:
-			GLBtCoexist.boardInfo.btChipType = BTC_CHIP_CSR_BC8;
-			break;
-		case BT_RTL8723A:
-			GLBtCoexist.boardInfo.btChipType = BTC_CHIP_RTL8723A;
-			break;
-		case BT_RTL8821:
-			GLBtCoexist.boardInfo.btChipType = BTC_CHIP_RTL8821;
-			break;
-		case BT_RTL8723B:
-			GLBtCoexist.boardInfo.btChipType = BTC_CHIP_RTL8723B;
-			break;
+	switch (chipType) {
+	default:
+	case BT_2WIRE:
+	case BT_ISSC_3WIRE:
+	case BT_ACCEL:
+	case BT_RTL8756:
+		GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_UNDEF;
+		break;
+	case BT_CSR_BC4:
+		GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_CSR_BC4;
+		break;
+	case BT_CSR_BC8:
+		GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_CSR_BC8;
+		break;
+	case BT_RTL8723A:
+		GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_RTL8723A;
+		break;
+	case BT_RTL8821:
+		GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_RTL8821;
+		break;
+	case BT_RTL8723B:
+		GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_RTL8723B;
+		break;
 	}
 }
 
 void EXhalbtcoutsrc_SetAntNum(u8 type, u8 antNum)
 {
-	if (BT_COEX_ANT_TYPE_PG == type)
-	{
-		GLBtCoexist.boardInfo.pgAntNum = antNum;
-		GLBtCoexist.boardInfo.btdmAntNum = antNum;
+	if (BT_COEX_ANT_TYPE_PG == type) {
+		GLBtCoexist.board_info.pg_ant_num = antNum;
+		GLBtCoexist.board_info.btdm_ant_num = antNum;
 #if 0
-		//The antenna position: Main (default) or Aux for pgAntNum=2 && btdmAntNum =1
-		//The antenna position should be determined by auto-detect mechanism
-		// The following is assumed to main, and those must be modified if y auto-detect mechanism is ready
-		if ((GLBtCoexist.boardInfo.pgAntNum == 2) && (GLBtCoexist.boardInfo.btdmAntNum == 1) )
-			GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
+		/* The antenna position: Main (default) or Aux for pgAntNum=2 && btdmAntNum =1 */
+		/* The antenna position should be determined by auto-detect mechanism */
+		/* The following is assumed to main, and those must be modified if y auto-detect mechanism is ready */
+		if ((GLBtCoexist.board_info.pg_ant_num == 2) && (GLBtCoexist.board_info.btdm_ant_num == 1))
+			GLBtCoexist.board_info.btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
 		else
-			GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
+			GLBtCoexist.board_info.btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
 #endif
+	} else if (BT_COEX_ANT_TYPE_ANTDIV == type) {
+		GLBtCoexist.board_info.btdm_ant_num = antNum;
+		/* GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;	 */
+	} else if (BT_COEX_ANT_TYPE_DETECTED == type) {
+		GLBtCoexist.board_info.btdm_ant_num = antNum;
+		/* GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT; */
 	}
-	else if (BT_COEX_ANT_TYPE_ANTDIV == type)
-	{
-		GLBtCoexist.boardInfo.btdmAntNum = antNum;
-		//GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;	
+}
+
+/*
+ * Currently used by 8723b only, S0 or S1
+ *   */
+void EXhalbtcoutsrc_SetSingleAntPath(u8 singleAntPath)
+{
+	GLBtCoexist.board_info.single_ant_path = singleAntPath;
+}
+
+void EXhalbtcoutsrc_DisplayBtCoexInfo(PBTC_COEXIST pBtCoexist)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+
+	/* To prevent the racing with IPS enter */
+	halbtcoutsrc_EnterPwrLock(pBtCoexist);
+
+	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821a2ant_display_coex_info(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821a1ant_display_coex_info(pBtCoexist);
+#endif
 	}
-	else if (BT_COEX_ANT_TYPE_DETECTED == type)
-	{
-		GLBtCoexist.boardInfo.btdmAntNum = antNum;
-		//GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT;
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723b2ant_display_coex_info(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_display_coex_info(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8703b1ant_display_coex_info(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8723d2ant_display_coex_info(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723d1ant_display_coex_info(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8192e2ant_display_coex_info(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8192e1ant_display_coex_info(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_display_coex_info(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8812a1ant_display_coex_info(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_display_coex_info(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_display_coex_info(pBtCoexist);
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_display_coex_info(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_display_coex_info(pBtCoexist);
+	}
+#endif
+
+	halbtcoutsrc_ExitPwrLock(pBtCoexist);
+
+	halbtcoutsrc_NormalLowPower(pBtCoexist);
+}
+
+void EXhalbtcoutsrc_DisplayAntDetection(PBTC_COEXIST pBtCoexist)
+{
+	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+
+	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8723b1ant_display_ant_detection(pBtCoexist);
+#endif
+	}
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_display_ant_detection(pBtCoexist);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_display_ant_detection(pBtCoexist);
+	}
+#endif
+
+	halbtcoutsrc_NormalLowPower(pBtCoexist);
+}
+
+void ex_halbtcoutsrc_pta_off_on_notify(PBTC_COEXIST pBtCoexist, u8 bBTON)
+{
+#ifdef CONFIG_RTL8812A
+	if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8812a2ant_pta_off_on_notify(pBtCoexist, (bBTON == _TRUE) ? BTC_BT_ON : BTC_BT_OFF);
 	}
+#endif
+}
+
+void EXhalbtcoutsrc_set_rfe_type(u8 type)
+{
+	GLBtCoexist.board_info.rfe_type= type;
 }
 
-//
-// Currently used by 8723b only, S0 or S1
-//
-void EXhalbtcoutsrc_SetSingleAntPath(u8 singleAntPath)
+#ifdef CONFIG_RF4CE_COEXIST
+void EXhalbtcoutsrc_set_rf4ce_link_state(u8 state)
 {
-	GLBtCoexist.boardInfo.singleAntPath = singleAntPath;
+	GLBtCoexist.rf4ce_info.link_state = state;
 }
 
-void EXhalbtcoutsrc_DisplayBtCoexInfo(PBTC_COEXIST pBtCoexist)
+u8 EXhalbtcoutsrc_get_rf4ce_link_state(void)
 {
-	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+	return GLBtCoexist.rf4ce_info.link_state;
+}
+#endif
+
+void EXhalbtcoutsrc_switchband_notify(struct btc_coexist *pBtCoexist, u8 type)
+{
+	if(!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
+		return;
+	
+	if(pBtCoexist->manual_control)
 		return;
 
-	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+	/* Driver should guarantee that the HW status isn't in low power mode */
+	/* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter))
-	{
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			EXhalbtc8821aCsr2ant_DisplayCoexInfo(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8821a2ant_DisplayCoexInfo(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8821a1ant_DisplayCoexInfo(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8723b2ant_DisplayCoexInfo(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_DisplayCoexInfo(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8703b2ant_DisplayCoexInfo(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8703b1ant_DisplayCoexInfo(pBtCoexist);
-	}
-	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8192e2ant_DisplayCoexInfo(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8192e1ant_DisplayCoexInfo(pBtCoexist);
+	if(IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8822B
+		if(pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8822b1ant_switchband_notify(pBtCoexist, type);
+		else if(pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8822b2ant_switchband_notify(pBtCoexist, type);
+#endif
 	}
-	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
-	{
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_DisplayCoexInfo(pBtCoexist);
-		else if (pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8812a1ant_DisplayCoexInfo(pBtCoexist);
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+		if (pBtCoexist->board_info.btdm_ant_num == 2)
+			ex_halbtc8821c2ant_switchband_notify(pBtCoexist, type);
+		else if (pBtCoexist->board_info.btdm_ant_num == 1)
+			ex_halbtc8821c1ant_switchband_notify(pBtCoexist, type);
 	}
+#endif
 
-	halbtcoutsrc_NormalLowPower(pBtCoexist);
+	/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
-void EXhalbtcoutsrc_DisplayAntDetection(PBTC_COEXIST pBtCoexist)
+u8 EXhalbtcoutsrc_rate_id_to_btc_rate_id(u8 rate_id)
 {
-	if(!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
-		return;
+	u8 btc_rate_id = BTC_UNKNOWN;
 
-	halbtcoutsrc_LeaveLowPower(pBtCoexist);
+	switch (rate_id) {
+		/* CCK rates */
+		case DESC_RATE1M:
+			btc_rate_id = BTC_CCK_1;
+			break;
+		case DESC_RATE2M:
+			btc_rate_id = BTC_CCK_2;
+			break;
+		case DESC_RATE5_5M:
+			btc_rate_id = BTC_CCK_5_5;
+			break;
+		case DESC_RATE11M:
+			btc_rate_id = BTC_CCK_11;
+			break;
 
-	if(IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
-	{
-		if(pBtCoexist->boardInfo.btdmAntNum == 1)
-			EXhalbtc8723b1ant_DisplayAntDetection(pBtCoexist);
-	}
-	
-	halbtcoutsrc_NormalLowPower(pBtCoexist);
-}
+		/* OFDM rates */
+		case DESC_RATE6M:
+			btc_rate_id = BTC_OFDM_6;
+			break;
+		case DESC_RATE9M:
+			btc_rate_id = BTC_OFDM_9;
+			break;
+		case DESC_RATE12M:
+			btc_rate_id = BTC_OFDM_12;
+			break;
+		case DESC_RATE18M:
+			btc_rate_id = BTC_OFDM_18;
+			break;
+		case DESC_RATE24M:
+			btc_rate_id = BTC_OFDM_24;
+			break;
+		case DESC_RATE36M:
+			btc_rate_id = BTC_OFDM_36;
+			break;
+		case DESC_RATE48M:
+			btc_rate_id = BTC_OFDM_48;
+			break;
+		case DESC_RATE54M:
+			btc_rate_id = BTC_OFDM_54;
+			break;
 
-void EXhalbtcoutsrc_BTOffOnNotify(PBTC_COEXIST pBtCoexist, u8 bBTON)
-{
+		/* MCS rates */
+		case DESC_RATEMCS0:
+			btc_rate_id = BTC_MCS_0;
+			break;
+		case DESC_RATEMCS1:
+			btc_rate_id = BTC_MCS_1;
+			break;
+		case DESC_RATEMCS2:
+			btc_rate_id = BTC_MCS_2;
+			break;
+		case DESC_RATEMCS3:
+			btc_rate_id = BTC_MCS_3;
+			break;
+		case DESC_RATEMCS4:
+			btc_rate_id = BTC_MCS_4;
+			break;
+		case DESC_RATEMCS5:
+			btc_rate_id = BTC_MCS_5;
+			break;
+		case DESC_RATEMCS6:
+			btc_rate_id = BTC_MCS_6;
+			break;
+		case DESC_RATEMCS7:
+			btc_rate_id = BTC_MCS_7;
+			break;
+		case DESC_RATEMCS8:
+			btc_rate_id = BTC_MCS_8;
+			break;
+		case DESC_RATEMCS9:
+			btc_rate_id = BTC_MCS_9;
+			break;
+		case DESC_RATEMCS10:
+			btc_rate_id = BTC_MCS_10;
+			break;
+		case DESC_RATEMCS11:
+			btc_rate_id = BTC_MCS_11;
+			break;
+		case DESC_RATEMCS12:
+			btc_rate_id = BTC_MCS_12;
+			break;
+		case DESC_RATEMCS13:
+			btc_rate_id = BTC_MCS_13;
+			break;
+		case DESC_RATEMCS14:
+			btc_rate_id = BTC_MCS_14;
+			break;
+		case DESC_RATEMCS15:
+			btc_rate_id = BTC_MCS_15;
+			break;
+		case DESC_RATEMCS16:
+			btc_rate_id = BTC_MCS_16;
+			break;
+		case DESC_RATEMCS17:
+			btc_rate_id = BTC_MCS_17;
+			break;
+		case DESC_RATEMCS18:
+			btc_rate_id = BTC_MCS_18;
+			break;
+		case DESC_RATEMCS19:
+			btc_rate_id = BTC_MCS_19;
+			break;
+		case DESC_RATEMCS20:
+			btc_rate_id = BTC_MCS_20;
+			break;
+		case DESC_RATEMCS21:
+			btc_rate_id = BTC_MCS_21;
+			break;
+		case DESC_RATEMCS22:
+			btc_rate_id = BTC_MCS_22;
+			break;
+		case DESC_RATEMCS23:
+			btc_rate_id = BTC_MCS_23;
+			break;
+		case DESC_RATEMCS24:
+			btc_rate_id = BTC_MCS_24;
+			break;
+		case DESC_RATEMCS25:
+			btc_rate_id = BTC_MCS_25;
+			break;
+		case DESC_RATEMCS26:
+			btc_rate_id = BTC_MCS_26;
+			break;
+		case DESC_RATEMCS27:
+			btc_rate_id = BTC_MCS_27;
+			break;
+		case DESC_RATEMCS28:
+			btc_rate_id = BTC_MCS_28;
+			break;
+		case DESC_RATEMCS29:
+			btc_rate_id = BTC_MCS_29;
+			break;
+		case DESC_RATEMCS30:
+			btc_rate_id = BTC_MCS_30;
+			break;
+		case DESC_RATEMCS31:
+			btc_rate_id = BTC_MCS_31;
+			break;
+			
+		case DESC_RATEVHTSS1MCS0:
+			btc_rate_id = BTC_VHT_1SS_MCS_0;
+			break;
+		case DESC_RATEVHTSS1MCS1:
+			btc_rate_id = BTC_VHT_1SS_MCS_1;
+			break;
+		case DESC_RATEVHTSS1MCS2:
+			btc_rate_id = BTC_VHT_1SS_MCS_2;
+			break;
+		case DESC_RATEVHTSS1MCS3:
+			btc_rate_id = BTC_VHT_1SS_MCS_3;
+			break;
+		case DESC_RATEVHTSS1MCS4:
+			btc_rate_id = BTC_VHT_1SS_MCS_4;
+			break;
+		case DESC_RATEVHTSS1MCS5:
+			btc_rate_id = BTC_VHT_1SS_MCS_5;
+			break;
+		case DESC_RATEVHTSS1MCS6:
+			btc_rate_id = BTC_VHT_1SS_MCS_6;
+			break;
+		case DESC_RATEVHTSS1MCS7:
+			btc_rate_id = BTC_VHT_1SS_MCS_7;
+			break;
+		case DESC_RATEVHTSS1MCS8:
+			btc_rate_id = BTC_VHT_1SS_MCS_8;
+			break;
+		case DESC_RATEVHTSS1MCS9:
+			btc_rate_id = BTC_VHT_1SS_MCS_9;
+			break;
 
-	if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
-		if (pBtCoexist->boardInfo.btdmAntNum == 2)
-			EXhalbtc8812a2ant_BTOffOnNotify(pBtCoexist, (bBTON == _TRUE)?BTC_BT_ON:BTC_BT_OFF);
-	}
+		case DESC_RATEVHTSS2MCS0:
+			btc_rate_id = BTC_VHT_2SS_MCS_0;
+			break;
+		case DESC_RATEVHTSS2MCS1:
+			btc_rate_id = BTC_VHT_2SS_MCS_1;
+			break;
+		case DESC_RATEVHTSS2MCS2:
+			btc_rate_id = BTC_VHT_2SS_MCS_2;
+			break;
+		case DESC_RATEVHTSS2MCS3:
+			btc_rate_id = BTC_VHT_2SS_MCS_3;
+			break;
+		case DESC_RATEVHTSS2MCS4:
+			btc_rate_id = BTC_VHT_2SS_MCS_4;
+			break;
+		case DESC_RATEVHTSS2MCS5:
+			btc_rate_id = BTC_VHT_2SS_MCS_5;
+			break;
+		case DESC_RATEVHTSS2MCS6:
+			btc_rate_id = BTC_VHT_2SS_MCS_6;
+			break;
+		case DESC_RATEVHTSS2MCS7:
+			btc_rate_id = BTC_VHT_2SS_MCS_7;
+			break;
+		case DESC_RATEVHTSS2MCS8:
+			btc_rate_id = BTC_VHT_2SS_MCS_8;
+			break;
+		case DESC_RATEVHTSS2MCS9:
+			btc_rate_id = BTC_VHT_2SS_MCS_9;
+			break;
+
+		case DESC_RATEVHTSS3MCS0:
+			btc_rate_id = BTC_VHT_3SS_MCS_0;
+			break;
+		case DESC_RATEVHTSS3MCS1:
+			btc_rate_id = BTC_VHT_3SS_MCS_1;
+			break;
+		case DESC_RATEVHTSS3MCS2:
+			btc_rate_id = BTC_VHT_3SS_MCS_2;
+			break;
+		case DESC_RATEVHTSS3MCS3:
+			btc_rate_id = BTC_VHT_3SS_MCS_3;
+			break;
+		case DESC_RATEVHTSS3MCS4:
+			btc_rate_id = BTC_VHT_3SS_MCS_4;
+			break;
+		case DESC_RATEVHTSS3MCS5:
+			btc_rate_id = BTC_VHT_3SS_MCS_5;
+			break;
+		case DESC_RATEVHTSS3MCS6:
+			btc_rate_id = BTC_VHT_3SS_MCS_6;
+			break;
+		case DESC_RATEVHTSS3MCS7:
+			btc_rate_id = BTC_VHT_3SS_MCS_7;
+			break;
+		case DESC_RATEVHTSS3MCS8:
+			btc_rate_id = BTC_VHT_3SS_MCS_8;
+			break;
+		case DESC_RATEVHTSS3MCS9:
+			btc_rate_id = BTC_VHT_3SS_MCS_9;
+			break;
 
+		case DESC_RATEVHTSS4MCS0:
+			btc_rate_id = BTC_VHT_4SS_MCS_0;
+			break;
+		case DESC_RATEVHTSS4MCS1:
+			btc_rate_id = BTC_VHT_4SS_MCS_1;
+			break;
+		case DESC_RATEVHTSS4MCS2:
+			btc_rate_id = BTC_VHT_4SS_MCS_2;
+			break;
+		case DESC_RATEVHTSS4MCS3:
+			btc_rate_id = BTC_VHT_4SS_MCS_3;
+			break;
+		case DESC_RATEVHTSS4MCS4:
+			btc_rate_id = BTC_VHT_4SS_MCS_4;
+			break;
+		case DESC_RATEVHTSS4MCS5:
+			btc_rate_id = BTC_VHT_4SS_MCS_5;
+			break;
+		case DESC_RATEVHTSS4MCS6:
+			btc_rate_id = BTC_VHT_4SS_MCS_6;
+			break;
+		case DESC_RATEVHTSS4MCS7:
+			btc_rate_id = BTC_VHT_4SS_MCS_7;
+			break;
+		case DESC_RATEVHTSS4MCS8:
+			btc_rate_id = BTC_VHT_4SS_MCS_8;
+			break;
+		case DESC_RATEVHTSS4MCS9:
+			btc_rate_id = BTC_VHT_4SS_MCS_9;
+			break;
+	}
+	
+	return btc_rate_id;
 }
 
-static void halbt_InitHwConfig92C(PADAPTER padapter)
+static void halbt_init_hw_config92C(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
 	u8 u1Tmp;
 
 
 	pHalData = GET_HAL_DATA(padapter);
-	if( (pHalData->bt_coexist.btChipType == BT_CSR_BC4) ||
-		(pHalData->bt_coexist.btChipType == BT_CSR_BC8))
-	{
-		if (pHalData->rf_type == RF_1T1R)
-		{
-			// Config to 1T1R
+	if ((pHalData->bt_coexist.btChipType == BT_CSR_BC4) ||
+	    (pHalData->bt_coexist.btChipType == BT_CSR_BC8)) {
+		if (pHalData->rf_type == RF_1T1R) {
+			/* Config to 1T1R */
 			u1Tmp = rtw_read8(padapter, rOFDM0_TRxPathEnable);
 			u1Tmp &= ~BIT(1);
 			rtw_write8(padapter, rOFDM0_TRxPathEnable, u1Tmp);
@@ -2948,18 +4659,16 @@ static void halbt_InitHwConfig92C(PADAPTER padapter)
 	}
 }
 
-static void halbt_InitHwConfig92D(PADAPTER padapter)
+static void halbt_init_hw_config92D(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
 	u8 u1Tmp;
 
 	pHalData = GET_HAL_DATA(padapter);
 	if ((pHalData->bt_coexist.btChipType == BT_CSR_BC4) ||
-		(pHalData->bt_coexist.btChipType == BT_CSR_BC8))
-	{
-		if (pHalData->rf_type == RF_1T1R)
-		{
-			// Config to 1T1R
+	    (pHalData->bt_coexist.btChipType == BT_CSR_BC8)) {
+		if (pHalData->rf_type == RF_1T1R) {
+			/* Config to 1T1R */
 			u1Tmp = rtw_read8(padapter, rOFDM0_TRxPathEnable);
 			u1Tmp &= ~BIT(1);
 			rtw_write8(padapter, rOFDM0_TRxPathEnable, u1Tmp);
@@ -2985,8 +4694,6 @@ void hal_btcoex_SetBTCoexist(PADAPTER padapter, u8 bBtExist)
 
 	pHalData = GET_HAL_DATA(padapter);
 	pHalData->bt_coexist.bBtExist = bBtExist;
-
-	//EXhalbtcoutsrc_SetBtExist(bBtExist);
 }
 
 /*
@@ -3011,7 +4718,7 @@ u8 hal_btcoex_IsBtDisabled(PADAPTER padapter)
 	if (!hal_btcoex_IsBtExist(padapter))
 		return _TRUE;
 
-	if (GLBtCoexist.btInfo.bBtDisabled)
+	if (GLBtCoexist.bt_info.bt_disabled)
 		return _TRUE;
 	else
 		return _FALSE;
@@ -3021,64 +4728,51 @@ void hal_btcoex_SetChipType(PADAPTER padapter, u8 chipType)
 {
 	PHAL_DATA_TYPE	pHalData;
 
-
 	pHalData = GET_HAL_DATA(padapter);
 	pHalData->bt_coexist.btChipType = chipType;
-
-	EXhalbtcoutsrc_SetChipType(chipType);
-}
-
-u8 hal_btcoex_GetChipType(PADAPTER padapter)
-{
-	PHAL_DATA_TYPE	pHalData;
-
-
-	pHalData = GET_HAL_DATA(padapter);
-	return pHalData->bt_coexist.btChipType;
 }
 
 void hal_btcoex_SetPgAntNum(PADAPTER padapter, u8 antNum)
 {
 	PHAL_DATA_TYPE	pHalData;
 
-
 	pHalData = GET_HAL_DATA(padapter);
 
 	pHalData->bt_coexist.btTotalAntNum = antNum;
-	EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_PG, antNum);
 }
 
-u8 hal_btcoex_GetPgAntNum(PADAPTER padapter)
+u8 hal_btcoex_Initialize(PADAPTER padapter)
 {
-	PHAL_DATA_TYPE pHalData;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	u8 ret;
 
+	_rtw_memset(&GLBtCoexist, 0, sizeof(GLBtCoexist));
 
-	pHalData = GET_HAL_DATA(padapter);
+	ret = EXhalbtcoutsrc_InitlizeVariables((void *)padapter);
 
-	return pHalData->bt_coexist.btTotalAntNum;
+	return ret;
 }
 
-void hal_btcoex_SetSingleAntPath(PADAPTER padapter, u8 singleAntPath)
+void hal_btcoex_PowerOnSetting(PADAPTER padapter)
 {
-	EXhalbtcoutsrc_SetSingleAntPath(singleAntPath);
+	EXhalbtcoutsrc_PowerOnSetting(&GLBtCoexist);
 }
 
-u8 hal_btcoex_Initialize(PADAPTER padapter)
+void hal_btcoex_AntInfoSetting(PADAPTER padapter)
 {
-	u8 ret1;
-	u8 ret2;
-
-
-	_rtw_memset(&GLBtCoexist, 0, sizeof(GLBtCoexist));
-	ret1 = EXhalbtcoutsrc_InitlizeVariables((void*)padapter);
-	ret2 = (ret1==_TRUE) ? _TRUE : _FALSE;
+	hal_btcoex_SetBTCoexist(padapter, rtw_btcoex_get_bt_coexist(padapter));
+	hal_btcoex_SetChipType(padapter, rtw_btcoex_get_chip_type(padapter));
+	hal_btcoex_SetPgAntNum(padapter, rtw_btcoex_get_pg_ant_num(padapter));
 
-	return ret2;
+	EXhalbtcoutsrc_AntInfoSetting(padapter);
 }
 
-void hal_btcoex_PowerOnSetting(PADAPTER padapter)
+void hal_btcoex_PowerOffSetting(PADAPTER padapter)
 {
-	EXhalbtcoutsrc_PowerOnSetting(&GLBtCoexist);
+	/* Clear the WiFi on/off bit in scoreboard reg. if necessary */
+	if (IS_HARDWARE_TYPE_8703B(padapter) || IS_HARDWARE_TYPE_8723D(padapter)
+		|| IS_HARDWARE_TYPE_8821C(padapter) || IS_HARDWARE_TYPE_8822B(padapter))
+		rtw_write16(padapter, 0xaa, 0x8000);
 }
 
 void hal_btcoex_PreLoadFirmware(PADAPTER padapter)
@@ -3091,38 +4785,56 @@ void hal_btcoex_InitHwConfig(PADAPTER padapter, u8 bWifiOnly)
 	if (!hal_btcoex_IsBtExist(padapter))
 		return;
 
-	EXhalbtcoutsrc_InitHwConfig(&GLBtCoexist, bWifiOnly);
-	EXhalbtcoutsrc_InitCoexDm(&GLBtCoexist);
+	EXhalbtcoutsrc_init_hw_config(&GLBtCoexist, bWifiOnly);
+	EXhalbtcoutsrc_init_coex_dm(&GLBtCoexist);
 }
 
 void hal_btcoex_IpsNotify(PADAPTER padapter, u8 type)
 {
-	EXhalbtcoutsrc_IpsNotify(&GLBtCoexist, type);
+	EXhalbtcoutsrc_ips_notify(&GLBtCoexist, type);
 }
 
 void hal_btcoex_LpsNotify(PADAPTER padapter, u8 type)
 {
-	EXhalbtcoutsrc_LpsNotify(&GLBtCoexist, type);
+	EXhalbtcoutsrc_lps_notify(&GLBtCoexist, type);
 }
 
 void hal_btcoex_ScanNotify(PADAPTER padapter, u8 type)
 {
-	EXhalbtcoutsrc_ScanNotify(&GLBtCoexist, type);
+	EXhalbtcoutsrc_scan_notify(&GLBtCoexist, type);
 }
 
 void hal_btcoex_ConnectNotify(PADAPTER padapter, u8 action)
 {
-	EXhalbtcoutsrc_ConnectNotify(&GLBtCoexist, action);
+	u8 assoType = 0;
+	u8 is_5g_band = _FALSE;
+
+	is_5g_band = (padapter->mlmeextpriv.cur_channel > 14) ? _TRUE : _FALSE;
+
+	if (action == _TRUE) {
+		if (is_5g_band == _TRUE)
+			assoType = BTC_ASSOCIATE_5G_START;
+		else
+			assoType = BTC_ASSOCIATE_START;
+	}
+	else {
+		if (is_5g_band == _TRUE)
+			assoType = BTC_ASSOCIATE_5G_FINISH;
+		else
+			assoType = BTC_ASSOCIATE_FINISH;
+	}
+	
+	EXhalbtcoutsrc_connect_notify(&GLBtCoexist, assoType);
 }
 
 void hal_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus)
 {
-	EXhalbtcoutsrc_MediaStatusNotify(&GLBtCoexist, mediaStatus);
+	EXhalbtcoutsrc_media_status_notify(&GLBtCoexist, mediaStatus);
 }
 
 void hal_btcoex_SpecialPacketNotify(PADAPTER padapter, u8 pktType)
 {
-	EXhalbtcoutsrc_SpecialPacketNotify(&GLBtCoexist, pktType);
+	EXhalbtcoutsrc_specific_packet_notify(&GLBtCoexist, pktType);
 }
 
 void hal_btcoex_IQKNotify(PADAPTER padapter, u8 state)
@@ -3134,8 +4846,8 @@ void hal_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
 {
 	if (GLBtcWiFiInIQKState == _TRUE)
 		return;
-	
-	EXhalbtcoutsrc_BtInfoNotify(&GLBtCoexist, tmpBuf, length);
+
+	EXhalbtcoutsrc_bt_info_notify(&GLBtCoexist, tmpBuf, length);
 }
 
 void hal_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
@@ -3143,7 +4855,7 @@ void hal_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
 	u8 extid, status, len, seq;
 
 
-	if (!GLBtcBtMpRptWait)
+	if (GLBtcBtMpRptWait == _FALSE)
 		return;
 
 	if ((length < 3) || (!tmpBuf))
@@ -3153,48 +4865,66 @@ void hal_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
 	/* not response from BT FW then exit*/
 	switch (extid) {
 	case C2H_WIFI_FW_ACTIVE_RSP:
-		GLBtcBtMpRptWiFiOK = 1;
-		return;
+		GLBtcBtMpRptWiFiOK = _TRUE;
+		break;
 
 	case C2H_TRIG_BY_BT_FW:
-		_cancel_timer_ex(&GLBtcBtMpOperTimer);
-		GLBtcBtMpRptWait = 0;
-		GLBtcBtMpRptBTOK = 1;
+		GLBtcBtMpRptBTOK = _TRUE;
+
+		status = tmpBuf[1] & 0xF;
+		len = length - 3;
+		seq = tmpBuf[2] >> 4;
+
+		GLBtcBtMpRptSeq = seq;
+		GLBtcBtMpRptStatus = status;
+		_rtw_memcpy(GLBtcBtMpRptRsp, tmpBuf + 3, len);
+		GLBtcBtMpRptRspSize = len;
+
 		break;
 
 	default:
 		return;
 	}
 
-	status = tmpBuf[1] & 0xF;
-	len = tmpBuf[1] >> 4;
-	seq = tmpBuf[2] >> 4;
-
-	GLBtcBtMpRptSeq = seq;
-	GLBtcBtMpRptStatus = status;
-	_rtw_memcpy(GLBtcBtMpRptRsp, tmpBuf+3, len);
-	GLBtcBtMpRptRspSize = len;
-	_rtw_up_sema(&GLBtcBtMpRptSema);
+	if ((GLBtcBtMpRptWiFiOK == _TRUE) && (GLBtcBtMpRptBTOK == _TRUE)) {
+		GLBtcBtMpRptWait = _FALSE;
+		_cancel_timer_ex(&GLBtcBtMpOperTimer);
+		_rtw_up_sema(&GLBtcBtMpRptSema);
+	}
 }
 
 void hal_btcoex_SuspendNotify(PADAPTER padapter, u8 state)
 {
-	if (state == 1)
-		state = BTC_WIFI_PNP_SLEEP;
-	else
-		state = BTC_WIFI_PNP_WAKE_UP;
-
-	EXhalbtcoutsrc_PnpNotify(&GLBtCoexist, state);
+	switch (state) {
+	case BTCOEX_SUSPEND_STATE_SUSPEND:
+		EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP);
+		break;
+	case BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT:
+		/* should switch to "#if 1" once all ICs' coex. revision are upgraded to support the KEEP_ANT case */
+#if 0
+		EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP_KEEP_ANT);
+#else
+		EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP);
+		EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP_KEEP_ANT);
+#endif
+		break;
+	case BTCOEX_SUSPEND_STATE_RESUME:
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+		/* re-download FW after resume, inform WL FW port number */
+		rtw_hal_set_wifi_port_id_cmd(GLBtCoexist.Adapter);
+#endif
+		EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_WAKE_UP);
+		break;
+	}
 }
 
-void hal_btcoex_HaltNotify(PADAPTER padapter)
+void hal_btcoex_HaltNotify(PADAPTER padapter, u8 do_halt)
 {
-	EXhalbtcoutsrc_HaltNotify(&GLBtCoexist);
-}
+	if (do_halt == 1)
+		EXhalbtcoutsrc_halt_notify(&GLBtCoexist);
 
-void hal_btcoex_ScoreBoardStatusNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
-{
-	EXhalbtcoutsrc_ScoreBoardStatusNotify(&GLBtCoexist, tmpBuf, length);
+	GLBtCoexist.bBinded = _FALSE;
+	GLBtCoexist.Adapter = NULL;
 }
 
 void hal_btcoex_SwitchBtTRxMask(PADAPTER padapter)
@@ -3204,27 +4934,34 @@ void hal_btcoex_SwitchBtTRxMask(PADAPTER padapter)
 
 void hal_btcoex_Hanlder(PADAPTER padapter)
 {
-	EXhalbtcoutsrc_Periodical(&GLBtCoexist);
+	u32	bt_patch_ver;
+
+	EXhalbtcoutsrc_periodical(&GLBtCoexist);
+
+	if (GLBtCoexist.bt_info.bt_get_fw_ver == 0) {
+		GLBtCoexist.btc_get(&GLBtCoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
+		GLBtCoexist.bt_info.bt_get_fw_ver = bt_patch_ver;
+	}
 }
 
 s32 hal_btcoex_IsBTCoexRejectAMPDU(PADAPTER padapter)
 {
-	return (s32)GLBtCoexist.btInfo.bRejectAggPkt;
+	return (s32)GLBtCoexist.bt_info.reject_agg_pkt;
 }
 
 s32 hal_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER padapter)
 {
-	return (s32)GLBtCoexist.btInfo.bBtCtrlAggBufSize;
+	return (s32)GLBtCoexist.bt_info.bt_ctrl_agg_buf_size;
 }
 
 u32 hal_btcoex_GetAMPDUSize(PADAPTER padapter)
 {
-	return (u32)GLBtCoexist.btInfo.aggBufSize;
+	return (u32)GLBtCoexist.bt_info.agg_buf_size;
 }
 
 void hal_btcoex_SetManualControl(PADAPTER padapter, u8 bmanual)
 {
-	GLBtCoexist.bManualControl = bmanual;
+	GLBtCoexist.manual_control = bmanual;
 }
 
 u8 hal_btcoex_1Ant(PADAPTER padapter)
@@ -3232,7 +4969,7 @@ u8 hal_btcoex_1Ant(PADAPTER padapter)
 	if (hal_btcoex_IsBtExist(padapter) == _FALSE)
 		return _FALSE;
 
-	if (GLBtCoexist.boardInfo.btdmAntNum == 1)
+	if (GLBtCoexist.board_info.btdm_ant_num == 1)
 		return _TRUE;
 
 	return _FALSE;
@@ -3240,13 +4977,16 @@ u8 hal_btcoex_1Ant(PADAPTER padapter)
 
 u8 hal_btcoex_IsBtControlLps(PADAPTER padapter)
 {
+	if (GLBtCoexist.bdontenterLPS == _TRUE)
+		return _TRUE;
+	
 	if (hal_btcoex_IsBtExist(padapter) == _FALSE)
 		return _FALSE;
 
-	if (GLBtCoexist.btInfo.bBtDisabled)
+	if (GLBtCoexist.bt_info.bt_disabled)
 		return _FALSE;
 
-	if (GLBtCoexist.btInfo.bBtCtrlLps)
+	if (GLBtCoexist.bt_info.bt_ctrl_lps)
 		return _TRUE;
 
 	return _FALSE;
@@ -3254,13 +4994,16 @@ u8 hal_btcoex_IsBtControlLps(PADAPTER padapter)
 
 u8 hal_btcoex_IsLpsOn(PADAPTER padapter)
 {
+	if (GLBtCoexist.bdontenterLPS == _TRUE)
+		return _FALSE;
+	
 	if (hal_btcoex_IsBtExist(padapter) == _FALSE)
 		return _FALSE;
 
-	if (GLBtCoexist.btInfo.bBtDisabled)
+	if (GLBtCoexist.bt_info.bt_disabled)
 		return _FALSE;
 
-	if (GLBtCoexist.btInfo.bBtLpsOn)
+	if (GLBtCoexist.bt_info.bt_lps_on)
 		return _TRUE;
 
 	return _FALSE;
@@ -3268,12 +5011,12 @@ u8 hal_btcoex_IsLpsOn(PADAPTER padapter)
 
 u8 hal_btcoex_RpwmVal(PADAPTER padapter)
 {
-	return GLBtCoexist.btInfo.rpwmVal;
+	return GLBtCoexist.bt_info.rpwm_val;
 }
 
 u8 hal_btcoex_LpsVal(PADAPTER padapter)
 {
-	return GLBtCoexist.btInfo.lpsVal;
+	return GLBtCoexist.bt_info.lps_val;
 }
 
 u32 hal_btcoex_GetRaMask(PADAPTER padapter)
@@ -3281,23 +5024,20 @@ u32 hal_btcoex_GetRaMask(PADAPTER padapter)
 	if (!hal_btcoex_IsBtExist(padapter))
 		return 0;
 
-	if (GLBtCoexist.btInfo.bBtDisabled)
+	if (GLBtCoexist.bt_info.bt_disabled)
 		return 0;
 
-		/* Modify by YiWei , suggest by Cosa and Jenyu
-		 * Remove the limit antenna number , because 2 antenna case (ex: 8192eu)also want to get BT coex report rate mask.
-		 */
-	/*if (GLBtCoexist.boardInfo.btdmAntNum != 1)
+	/* Modify by YiWei , suggest by Cosa and Jenyu
+	 * Remove the limit antenna number , because 2 antenna case (ex: 8192eu)also want to get BT coex report rate mask.
+	 */
+	/*if (GLBtCoexist.board_info.btdm_ant_num != 1)
 		return 0;*/
 
-	return GLBtCoexist.btInfo.raMask;
+	return GLBtCoexist.bt_info.ra_mask;
 }
 
 void hal_btcoex_RecordPwrMode(PADAPTER padapter, u8 *pCmdBuf, u8 cmdLen)
 {
-	RT_TRACE(COMP_COEX, DBG_LOUD, ("[BTCoex], FW write pwrModeCmd=0x%04x%08x\n",
-		pCmdBuf[0]<<8|pCmdBuf[1],
-		pCmdBuf[2]<<24|pCmdBuf[3]<<16|pCmdBuf[4]<<8|pCmdBuf[5]));
 
 	_rtw_memcpy(GLBtCoexist.pwrModeVal, pCmdBuf, cmdLen);
 }
@@ -3338,7 +5078,7 @@ u32 hal_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)
 	count = 0;
 	pstr = pStrBuf;
 	leftSize = bufSize;
-//	DBG_871X(FUNC_ADPT_FMT ": bufsize=%d\n", FUNC_ADPT_ARG(padapter), bufSize);
+	/*	RTW_INFO(FUNC_ADPT_FMT ": bufsize=%d\n", FUNC_ADPT_ARG(padapter), bufSize); */
 
 	count = rtw_sprintf(pstr, leftSize, "#define DBG\t%d\n", DBG);
 	if ((count < 0) || (count >= leftSize))
@@ -3353,8 +5093,8 @@ u32 hal_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)
 	leftSize -= count;
 
 	count = rtw_sprintf(pstr, leftSize,
-		"COMP_COEX: 0x%08X\n\n",
-		GLBtcDbgType[COMP_COEX]);
+			    "COMP_COEX: 0x%08X\n\n",
+			    GLBtcDbgType[COMP_COEX]);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
@@ -3367,79 +5107,79 @@ u32 hal_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[0]=%d for INTF_INIT\n",
-		GLBtcDbgType[BTC_MSG_INTERFACE]&INTF_INIT?1:0);
+		    GLBtcDbgType[BTC_MSG_INTERFACE] & INTF_INIT ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[2]=%d for INTF_NOTIFY\n\n",
-		GLBtcDbgType[BTC_MSG_INTERFACE]&INTF_NOTIFY?1:0);
+		    GLBtcDbgType[BTC_MSG_INTERFACE] & INTF_NOTIFY ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
-	
+
 	count = rtw_sprintf(pstr, leftSize, "ALGORITHM Debug Setting Definition:\n");
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[0]=%d for BT_RSSI_STATE\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_BT_RSSI_STATE?1:0);
+		GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_BT_RSSI_STATE ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[1]=%d for WIFI_RSSI_STATE\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_WIFI_RSSI_STATE?1:0);
+		GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_WIFI_RSSI_STATE ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[2]=%d for BT_MONITOR\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_BT_MONITOR?1:0);
+		    GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_BT_MONITOR ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[3]=%d for TRACE\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_TRACE?1:0);
+		    GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[4]=%d for TRACE_FW\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_TRACE_FW?1:0);
+		    GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_FW ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[5]=%d for TRACE_FW_DETAIL\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_TRACE_FW_DETAIL?1:0);
+		GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_FW_DETAIL ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[6]=%d for TRACE_FW_EXEC\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_TRACE_FW_EXEC?1:0);
+		GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_FW_EXEC ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[7]=%d for TRACE_SW\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_TRACE_SW?1:0);
+		    GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_SW ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[8]=%d for TRACE_SW_DETAIL\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_TRACE_SW_DETAIL?1:0);
+		GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_SW_DETAIL ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
 	leftSize -= count;
 	count = rtw_sprintf(pstr, leftSize, "\tbit[9]=%d for TRACE_SW_EXEC\n",
-		GLBtcDbgType[BTC_MSG_ALGORITHM]&ALGO_TRACE_SW_EXEC?1:0);
+		GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_SW_EXEC ? 1 : 0);
 	if ((count < 0) || (count >= leftSize))
 		goto exit;
 	pstr += count;
@@ -3448,7 +5188,7 @@ u32 hal_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)
 
 exit:
 	count = pstr - pStrBuf;
-//	DBG_871X(FUNC_ADPT_FMT ": usedsize=%d\n", FUNC_ADPT_ARG(padapter), count);
+	/*	RTW_INFO(FUNC_ADPT_FMT ": usedsize=%d\n", FUNC_ADPT_ARG(padapter), count); */
 
 	return count;
 }
@@ -3458,7 +5198,7 @@ u8 hal_btcoex_IncreaseScanDeviceNum(PADAPTER padapter)
 	if (!hal_btcoex_IsBtExist(padapter))
 		return _FALSE;
 
-	if (GLBtCoexist.btInfo.bIncreaseScanDevNum)
+	if (GLBtCoexist.bt_info.increase_scan_dev_num)
 		return _TRUE;
 
 	return _FALSE;
@@ -3466,15 +5206,15 @@ u8 hal_btcoex_IncreaseScanDeviceNum(PADAPTER padapter)
 
 u8 hal_btcoex_IsBtLinkExist(PADAPTER padapter)
 {
-	if (GLBtCoexist.btLinkInfo.bBtLinkExist)
+	if (GLBtCoexist.bt_link_info.bt_link_exist)
 		return _TRUE;
 
 	return _FALSE;
 }
 
-void hal_btcoex_SetBtPatchVersion(PADAPTER padapter,u16 btHciVer,u16 btPatchVer)
+void hal_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer)
 {
-	EXhalbtcoutsrc_SetBtPatchVersion(btHciVer,btPatchVer);
+	EXhalbtcoutsrc_SetBtPatchVersion(btHciVer, btPatchVer);
 }
 
 void hal_btcoex_SetHciVersion(PADAPTER padapter, u16 hciVersion)
@@ -3487,9 +5227,9 @@ void hal_btcoex_StackUpdateProfileInfo(void)
 	EXhalbtcoutsrc_StackUpdateProfileInfo();
 }
 
-void hal_btcoex_BTOffOnNotify(PADAPTER padapter, u8 bBTON)
+void hal_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON)
 {
-	EXhalbtcoutsrc_BTOffOnNotify(&GLBtCoexist, bBTON);
+	ex_halbtcoutsrc_pta_off_on_notify(&GLBtCoexist, bBTON);
 }
 
 /*
@@ -3506,40 +5246,40 @@ void hal_btcoex_BTOffOnNotify(PADAPTER padapter, u8 bBTON)
  */
 void hal_btcoex_SetAntIsolationType(PADAPTER padapter, u8 anttype)
 {
-		PHAL_DATA_TYPE pHalData;
-		PBTC_COEXIST	pBtCoexist = &GLBtCoexist;
+	PHAL_DATA_TYPE pHalData;
+	PBTC_COEXIST	pBtCoexist = &GLBtCoexist;
 
-		/*DBG_871X("####%s , anttype = %d  , %d\n" , __func__ , anttype , __LINE__); */
-		pHalData = GET_HAL_DATA(padapter);
+	/*RTW_INFO("####%s , anttype = %d  , %d\n" , __func__ , anttype , __LINE__); */
+	pHalData = GET_HAL_DATA(padapter);
 
 
-		pHalData->bt_coexist.btAntisolation = anttype;
+	pHalData->bt_coexist.btAntisolation = anttype;
 
-		switch (pHalData->bt_coexist.btAntisolation) {
-		case 0:
-				pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_0;
-				break;
-		case 1:
-				pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_1;
-				break;
-		case 2:
-				pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_2;
-				break;
-		case 3:
-				pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_3;
-				break;
-		case 4:
-				pBtCoexist->boardInfo.antType = (u1Byte)BTC_ANT_TYPE_4;
-				break;
-		}
+	switch (pHalData->bt_coexist.btAntisolation) {
+	case 0:
+		pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_0;
+		break;
+	case 1:
+		pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_1;
+		break;
+	case 2:
+		pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_2;
+		break;
+	case 3:
+		pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_3;
+		break;
+	case 4:
+		pBtCoexist->board_info.ant_type = (u1Byte)BTC_ANT_TYPE_4;
+		break;
+	}
 
 }
 
 #ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
 int
 hal_btcoex_ParseAntIsolationConfigFile(
-  PADAPTER		Adapter,
-  char*			buffer
+	PADAPTER		Adapter,
+	char			*buffer
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
@@ -3549,32 +5289,32 @@ hal_btcoex_ParseAntIsolationConfigFile(
 	char param_value_string[10];
 	u8 param_value;
 	u8 anttype = 4;
-	
-	u8 ant_num = 3 , ant_distance = 50 , rfe_type = 1; 
-	
+
+	u8 ant_num = 3 , ant_distance = 50 , rfe_type = 1;
+
 	typedef struct ant_isolation {
-		char *param_name;  /* antenna isolation config parameter name */ 
+		char *param_name;  /* antenna isolation config parameter name */
 		u8 *value; /* antenna isolation config parameter value */
 	} ANT_ISOLATION;
 
 	ANT_ISOLATION ant_isolation_param[] = {
-												{"ANT_NUMBER" , &ant_num},
-												{"ANT_DISTANCE" , &ant_distance},
-												{"RFE_TYPE" , &rfe_type},												
-												{NULL , 0}
-										};
+		{"ANT_NUMBER" , &ant_num},
+		{"ANT_DISTANCE" , &ant_distance},
+		{"RFE_TYPE" , &rfe_type},
+		{NULL , 0}
+	};
 
 
-	
-	/* DBG_871X("===>Hal_ParseAntIsolationConfigFile()\n" ); */
-			
+
+	/* RTW_INFO("===>Hal_ParseAntIsolationConfigFile()\n" ); */
+
 	ptmp = buffer;
 	for (szLine = GetLineFromBuffer(ptmp) ; szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
-		/* skip comment */ 
+		/* skip comment */
 		if (IsCommentString(szLine))
-			continue;	 
+			continue;
 
-		/* DBG_871X("%s : szLine = %s , strlen(szLine) = %d\n" , __func__ , szLine , strlen(szLine));*/
+		/* RTW_INFO("%s : szLine = %s , strlen(szLine) = %d\n" , __func__ , szLine , strlen(szLine));*/
 		for (j = 0 ; ant_isolation_param[j].param_name != NULL ; j++) {
 			if (strstr(szLine , ant_isolation_param[j].param_name) != NULL) {
 				i = 0;
@@ -3584,26 +5324,26 @@ hal_btcoex_ParseAntIsolationConfigFile(
 					else {
 						/* skip only has one " */
 						if (strpbrk(szLine , "\"") == strrchr(szLine , '"')) {
-							DBG_871X("Fail to parse parameters , format error!\n");
+							RTW_INFO("Fail to parse parameters , format error!\n");
 							break;
 						}
 						_rtw_memset((PVOID)param_value_string , 0 , 10);
 						if (!ParseQualifiedString(szLine , &i , param_value_string , '"' , '"')) {
-							DBG_871X("Fail to parse parameters\n");
+							RTW_INFO("Fail to parse parameters\n");
 							return _FAIL;
-						} else if (!GetU1ByteIntegerFromStringInDecimal(param_value_string , ant_isolation_param[j].value)) 
-							DBG_871X("Fail to GetU1ByteIntegerFromStringInDecimal\n");
+						} else if (!GetU1ByteIntegerFromStringInDecimal(param_value_string , ant_isolation_param[j].value))
+							RTW_INFO("Fail to GetU1ByteIntegerFromStringInDecimal\n");
 
 						break;
 					}
 				}
 			}
 		}
-	} 
+	}
 
 	/* YiWei 20140716 , for BT coex antenna isolation control */
 	/* rfe_type = 0 was SPDT , rfe_type = 1 was coupler */
-	if (ant_num == 3 && ant_distance >= 50) 
+	if (ant_num == 3 && ant_distance >= 50)
 		anttype = 3;
 	else if (ant_num == 2 && ant_distance >= 50 && rfe_type == 1)
 		anttype = 2;
@@ -3615,23 +5355,23 @@ hal_btcoex_ParseAntIsolationConfigFile(
 		anttype = 1;
 	else if (ant_num == 2 && rfe_type == 0)
 		anttype = 0;
-	else 
+	else
 		anttype = 0;
 
-	hal_btcoex_SetAntIsolationType(Adapter, anttype); 
-						
-	DBG_871X("%s : ant_num = %d\n" , __func__ , ant_num);
-	DBG_871X("%s : ant_distance = %d\n" , __func__ , ant_distance);
-	DBG_871X("%s : rfe_type = %d\n" , __func__ , rfe_type);
-	/* DBG_871X("<===Hal_ParseAntIsolationConfigFile()\n"); */
-	return rtStatus;	
+	hal_btcoex_SetAntIsolationType(Adapter, anttype);
+
+	RTW_INFO("%s : ant_num = %d\n" , __func__ , ant_num);
+	RTW_INFO("%s : ant_distance = %d\n" , __func__ , ant_distance);
+	RTW_INFO("%s : rfe_type = %d\n" , __func__ , rfe_type);
+	/* RTW_INFO("<===Hal_ParseAntIsolationConfigFile()\n"); */
+	return rtStatus;
 }
 
 
 int
 hal_btcoex_AntIsolationConfig_ParaFile(
 	IN	PADAPTER	Adapter,
-	IN	char*	 	pFileName
+	IN	char		*pFileName
 )
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
@@ -3640,26 +5380,22 @@ hal_btcoex_AntIsolationConfig_ParaFile(
 	_rtw_memset(pHalData->para_file_buf , 0 , MAX_PARA_FILE_BUF_LEN);
 
 	rtw_get_phy_file_path(Adapter, pFileName);
-	if (rtw_is_file_readable(rtw_phy_para_file_path) == _TRUE)
-	{
+	if (rtw_is_file_readable(rtw_phy_para_file_path) == _TRUE) {
 		rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
 		if (rlen > 0)
-		{
 			rtStatus = _SUCCESS;
-		}
 	}
 
 
 	if (rtStatus == _SUCCESS) {
-		/*DBG_871X("%s(): read %s ok\n", __func__ , pFileName);*/
+		/*RTW_INFO("%s(): read %s ok\n", __func__ , pFileName);*/
 		rtStatus = hal_btcoex_ParseAntIsolationConfigFile(Adapter , pHalData->para_file_buf);
-	} else {
-		DBG_871X("%s(): No File %s, Load from *** Array!\n" , __func__ , pFileName);
-	}
+	} else
+		RTW_INFO("%s(): No File %s, Load from *** Array!\n" , __func__ , pFileName);
 
 	return rtStatus;
 }
-#endif // CONFIG_LOAD_PHY_PARA_FROM_FILE
+#endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
 
 u16 hal_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data)
 {
@@ -3667,7 +5403,7 @@ u16 hal_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data)
 
 	halbtcoutsrc_LeaveLowPower(&GLBtCoexist);
 
-	ret = halbtcoutsrc_GetBtReg(&GLBtCoexist, type, addr, data);
+	ret = halbtcoutsrc_GetBtReg_with_status(&GLBtCoexist, type, addr, data);
 
 	halbtcoutsrc_NormalLowPower(&GLBtCoexist);
 
@@ -3686,5 +5422,49 @@ u16 hal_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val)
 
 	return ret;
 }
-#endif // CONFIG_BT_COEXIST
 
+void hal_btcoex_set_rfe_type(u8 type)
+{
+	EXhalbtcoutsrc_set_rfe_type(type);
+}
+
+#ifdef CONFIG_RF4CE_COEXIST
+void hal_btcoex_set_rf4ce_link_state(u8 state)
+{
+	EXhalbtcoutsrc_set_rf4ce_link_state(state);
+}
+
+u8 hal_btcoex_get_rf4ce_link_state(void)
+{
+	return EXhalbtcoutsrc_get_rf4ce_link_state();
+}
+#endif /* CONFIG_RF4CE_COEXIST */
+
+void hal_btcoex_switchband_notify(u8 under_scan, u8 band_type)
+{
+	switch (band_type) {
+	case BAND_ON_2_4G:
+		if (under_scan)
+			EXhalbtcoutsrc_switchband_notify(&GLBtCoexist, BTC_SWITCH_TO_24G);
+		else
+			EXhalbtcoutsrc_switchband_notify(&GLBtCoexist, BTC_SWITCH_TO_24G_NOFORSCAN);
+		break;
+	case BAND_ON_5G:
+		EXhalbtcoutsrc_switchband_notify(&GLBtCoexist, BTC_SWITCH_TO_5G);
+		break;
+	default:
+		RTW_INFO("[BTCOEX] unkown switch band type\n");
+		break;
+	}
+}
+
+void hal_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length)
+{
+	EXhalbtcoutsrc_WlFwDbgInfoNotify(&GLBtCoexist, tmpBuf, length);
+}
+
+void hal_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id)
+{
+	EXhalbtcoutsrc_rx_rate_change_notify(&GLBtCoexist, is_data_frame, EXhalbtcoutsrc_rate_id_to_btc_rate_id(rate_id));
+}
+#endif /* CONFIG_BT_COEXIST */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_btcoex_wifionly.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_btcoex_wifionly.c
new file mode 100644
index 000000000000..3e9641e8c303
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_btcoex_wifionly.c
@@ -0,0 +1,205 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_btcoex_wifionly.h>
+
+#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
+
+#include "btc/mp_precomp.h"
+
+struct  wifi_only_cfg GLBtCoexistWifiOnly;
+
+void halwifionly_write1byte(PVOID pwifionlyContext, u32 RegAddr, u8 Data)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	rtw_write8(Adapter, RegAddr, Data);
+}
+
+void halwifionly_write2byte(PVOID pwifionlyContext, u32 RegAddr, u16 Data)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	rtw_write16(Adapter, RegAddr, Data);
+}
+
+void halwifionly_write4byte(PVOID pwifionlyContext, u32 RegAddr, u32 Data)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	rtw_write32(Adapter, RegAddr, Data);
+}
+
+u8 halwifionly_read1byte(PVOID pwifionlyContext, u32 RegAddr)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	return rtw_read8(Adapter, RegAddr);
+}
+
+u16 halwifionly_read2byte(PVOID pwifionlyContext, u32 RegAddr)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	return rtw_read16(Adapter, RegAddr);
+}
+
+u32 halwifionly_read4byte(PVOID pwifionlyContext, u32 RegAddr)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	return rtw_read32(Adapter, RegAddr);
+}
+
+void halwifionly_bitmaskwrite1byte(PVOID pwifionlyContext, u32 regAddr, u8 bitMask, u8 data)
+{
+	u8 originalValue, bitShift = 0;
+	u8 i;
+
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	if (bitMask != 0xff) {
+		originalValue = rtw_read8(Adapter, regAddr);
+		for (i = 0; i <= 7; i++) {
+			if ((bitMask >> i) & 0x1)
+				break;
+		}
+		bitShift = i;
+		data = ((originalValue) & (~bitMask)) | (((data << bitShift)) & bitMask);
+	}
+	rtw_write8(Adapter, regAddr, data);
+}
+
+void halwifionly_phy_set_rf_reg(PVOID pwifionlyContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	phy_set_rf_reg(Adapter, eRFPath, RegAddr, BitMask, Data);
+}
+
+void halwifionly_phy_set_bb_reg(PVOID pwifionlyContext, u32 RegAddr, u32 BitMask, u32 Data)
+{
+	struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
+	PADAPTER		Adapter = pwifionlycfg->Adapter;
+
+	phy_set_bb_reg(Adapter, RegAddr, BitMask, Data);
+}
+
+void hal_btcoex_wifionly_switchband_notify(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	u8 is_5g = _FALSE;
+
+	if (pHalData->current_band_type == BAND_ON_5G)
+		is_5g = _TRUE;
+
+	if (IS_HARDWARE_TYPE_8822B(padapter)) {
+#ifdef CONFIG_RTL8822B
+		ex_hal8822b_wifi_only_switchbandnotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+	}
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(padapter))
+		ex_hal8821c_wifi_only_switchbandnotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+}
+
+void hal_btcoex_wifionly_scan_notify(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	u8 is_5g = _FALSE;
+
+	if (pHalData->current_band_type == BAND_ON_5G)
+		is_5g = _TRUE;
+
+	if (IS_HARDWARE_TYPE_8822B(padapter)) {
+#ifdef CONFIG_RTL8822B
+		ex_hal8822b_wifi_only_scannotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+	}
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(padapter))
+		ex_hal8821c_wifi_only_scannotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+}
+
+void hal_btcoex_wifionly_hw_config(PADAPTER padapter)
+{
+	struct wifi_only_cfg *pwifionlycfg = &GLBtCoexistWifiOnly;
+
+	if (IS_HARDWARE_TYPE_8723B(padapter)) {
+#ifdef CONFIG_RTL8723B
+		ex_hal8723b_wifi_only_hw_config(pwifionlycfg);
+#endif
+	}
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(padapter))
+		ex_hal8822b_wifi_only_hw_config(pwifionlycfg);
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(padapter))
+		ex_hal8821c_wifi_only_hw_config(pwifionlycfg);
+#endif
+}
+
+void hal_btcoex_wifionly_initlizevariables(PADAPTER padapter)
+{
+	struct wifi_only_cfg		*pwifionlycfg = &GLBtCoexistWifiOnly;
+	struct wifi_only_haldata	*pwifionly_haldata = &pwifionlycfg->haldata_info;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	_rtw_memset(&GLBtCoexistWifiOnly, 0, sizeof(GLBtCoexistWifiOnly));
+
+	pwifionlycfg->Adapter = padapter;
+
+#ifdef CONFIG_PCI_HCI
+	pwifionlycfg->chip_interface = WIFIONLY_INTF_PCI;
+#elif defined(CONFIG_USB_HCI)
+	pwifionlycfg->chip_interface = WIFIONLY_INTF_USB;
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	pwifionlycfg->chip_interface = WIFIONLY_INTF_SDIO;
+#else
+	pwifionlycfg->chip_interface = WIFIONLY_INTF_UNKNOWN;
+#endif
+
+	pwifionly_haldata->customer_id = CUSTOMER_NORMAL;
+}
+
+void hal_btcoex_wifionly_AntInfoSetting(PADAPTER padapter)
+{
+	struct wifi_only_cfg		*pwifionlycfg = &GLBtCoexistWifiOnly;
+	struct wifi_only_haldata	*pwifionly_haldata = &pwifionlycfg->haldata_info;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	pwifionly_haldata->efuse_pg_antnum = pHalData->EEPROMBluetoothAntNum;
+	pwifionly_haldata->efuse_pg_antpath = pHalData->ant_path;
+	pwifionly_haldata->rfe_type = pHalData->rfe_type;
+	pwifionly_haldata->ant_div_cfg = pHalData->AntDivCfg;
+}
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com.c
index 59a907fbfd96..36a2a343360d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _HAL_COM_C_
 
 #include <drv_types.h>
@@ -24,115 +20,205 @@
 
 #include "hal_data.h"
 
-//#define CONFIG_GTK_OL_DBG
+#ifdef RTW_HALMAC
+#include "../../hal/hal_halmac.h"
+#endif
+
+void rtw_dump_fw_info(void *sel, _adapter *adapter)
+{
+	HAL_DATA_TYPE	*hal_data = NULL;
+
+	if (!adapter)
+		return;
+
+	hal_data = GET_HAL_DATA(adapter);
+	if (hal_data->bFWReady)
+		RTW_PRINT_SEL(sel, "FW VER -%d.%d\n", hal_data->firmware_version, hal_data->firmware_sub_version);
+	else
+		RTW_PRINT_SEL(sel, "FW not ready\n");
+}
+
+/* #define CONFIG_GTK_OL_DBG */
+
+/*#define DBG_SEC_CAM_MOVE*/
+#ifdef DBG_SEC_CAM_MOVE
+void rtw_hal_move_sta_gk_to_dk(_adapter *adapter)
+{
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	int cam_id, index = 0;
+	u8 *addr = NULL;
+
+	if (!MLME_IS_STA(adapter))
+		return;
+
+	addr = get_bssid(pmlmepriv);
+
+	if (addr == NULL) {
+		RTW_INFO("%s: get bssid MAC addr fail!!\n", __func__);
+		return;
+	}
+
+	rtw_clean_dk_section(adapter);
+
+	do {
+		cam_id = rtw_camid_search(adapter, addr, index, 1);
+
+		if (cam_id == -1)
+			RTW_INFO("%s: cam_id: %d, key_id:%d\n", __func__, cam_id, index);
+		else
+			rtw_sec_cam_swap(adapter, cam_id, index);
+
+		index++;
+	} while (index < 4);
+
+}
+
+void rtw_hal_read_sta_dk_key(_adapter *adapter, u8 key_id)
+{
+	struct security_priv *psecuritypriv = &adapter->securitypriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	_irqL irqL;
+	u8 get_key[16];
+
+	_rtw_memset(get_key, 0, sizeof(get_key));
+
+	if (key_id > 4) {
+		RTW_INFO("%s [ERROR] gtk_keyindex:%d invalid\n", __func__, key_id);
+		rtw_warn_on(1);
+		return;
+	}
+	rtw_sec_read_cam_ent(adapter, key_id, NULL, NULL, get_key);
+
+	/*update key into related sw variable*/
+	_enter_critical_bh(&cam_ctl->lock, &irqL);
+	if (_rtw_camid_is_gk(adapter, key_id)) {
+		RTW_INFO("[HW KEY] -Key-id:%d "KEY_FMT"\n", key_id, KEY_ARG(get_key));
+		RTW_INFO("[cam_cache KEY] - Key-id:%d "KEY_FMT"\n", key_id, KEY_ARG(&dvobj->cam_cache[key_id].key));
+	}
+	_exit_critical_bh(&cam_ctl->lock, &irqL);
+
+}
+#endif
+
 
 #ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
-char rtw_phy_para_file_path[PATH_LENGTH_MAX];
+	char	rtw_phy_para_file_path[PATH_LENGTH_MAX];
 #endif
 
 void dump_chip_info(HAL_VERSION	ChipVersion)
 {
 	int cnt = 0;
-	u8 buf[128]={0};
-	
+	u8 buf[128] = {0};
+
 	if (IS_8188E(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8188E_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188E_");
 	else if (IS_8188F(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8188F_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188F_");
+	else if (IS_8188GTV(ChipVersion))
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188GTV_");
 	else if (IS_8812_SERIES(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8812_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8812_");
 	else if (IS_8192E(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8192E_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8192E_");
 	else if (IS_8821_SERIES(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8821_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8821_");
 	else if (IS_8723B_SERIES(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8723B_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8723B_");
 	else if (IS_8703B_SERIES(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8703B_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8703B_");
+	else if (IS_8723D_SERIES(ChipVersion))
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8723D_");
 	else if (IS_8814A_SERIES(ChipVersion))
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_8814A_");
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8814A_");
+	else if (IS_8822B_SERIES(ChipVersion))
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8822B_");
+	else if (IS_8821C_SERIES(ChipVersion))
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8821C_");
 	else
-		cnt += sprintf((buf+cnt), "Chip Version Info: CHIP_UNKNOWN_");
-
-	cnt += sprintf((buf+cnt), "%s_", IS_NORMAL_CHIP(ChipVersion)?"Normal_Chip":"Test_Chip");
-	if(IS_CHIP_VENDOR_TSMC(ChipVersion))
-		cnt += sprintf((buf+cnt), "%s_","TSMC");
-	else if(IS_CHIP_VENDOR_UMC(ChipVersion))	
-		cnt += sprintf((buf+cnt), "%s_","UMC");
-	else if(IS_CHIP_VENDOR_SMIC(ChipVersion))
-		cnt += sprintf((buf+cnt), "%s_","SMIC");		
-	
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_UNKNOWN_");
+
+	cnt += sprintf((buf + cnt), "%s_", IS_NORMAL_CHIP(ChipVersion) ? "Normal_Chip" : "Test_Chip");
+	if (IS_CHIP_VENDOR_TSMC(ChipVersion))
+		cnt += sprintf((buf + cnt), "%s_", "TSMC");
+	else if (IS_CHIP_VENDOR_UMC(ChipVersion))
+		cnt += sprintf((buf + cnt), "%s_", "UMC");
+	else if (IS_CHIP_VENDOR_SMIC(ChipVersion))
+		cnt += sprintf((buf + cnt), "%s_", "SMIC");
+
 	if (IS_A_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "A_CUT_");
+		cnt += sprintf((buf + cnt), "A_CUT_");
 	else if (IS_B_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "B_CUT_");
+		cnt += sprintf((buf + cnt), "B_CUT_");
 	else if (IS_C_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "C_CUT_");
+		cnt += sprintf((buf + cnt), "C_CUT_");
 	else if (IS_D_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "D_CUT_");
+		cnt += sprintf((buf + cnt), "D_CUT_");
 	else if (IS_E_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "E_CUT_");
+		cnt += sprintf((buf + cnt), "E_CUT_");
 	else if (IS_F_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "F_CUT_");
+		cnt += sprintf((buf + cnt), "F_CUT_");
 	else if (IS_I_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "I_CUT_");
+		cnt += sprintf((buf + cnt), "I_CUT_");
 	else if (IS_J_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "J_CUT_");
+		cnt += sprintf((buf + cnt), "J_CUT_");
 	else if (IS_K_CUT(ChipVersion))
-		cnt += sprintf((buf+cnt), "K_CUT_");
+		cnt += sprintf((buf + cnt), "K_CUT_");
 	else
-		cnt += sprintf((buf+cnt), "UNKNOWN_CUT(%d)_", ChipVersion.CUTVersion);
-
-	if(IS_1T1R(ChipVersion)) cnt += sprintf((buf+cnt), "1T1R_");
-	else if(IS_1T2R(ChipVersion)) cnt += sprintf((buf+cnt), "1T2R_");
-	else if(IS_2T2R(ChipVersion)) cnt += sprintf((buf+cnt), "2T2R_");
-	else if(IS_3T3R(ChipVersion)) cnt += sprintf((buf+cnt), "3T3R_");
-	else if(IS_3T4R(ChipVersion)) cnt += sprintf((buf+cnt), "3T4R_");
-	else if(IS_4T4R(ChipVersion)) cnt += sprintf((buf+cnt), "4T4R_");
-	else cnt += sprintf((buf+cnt), "UNKNOWN_RFTYPE(%d)_", ChipVersion.RFType);
+		cnt += sprintf((buf + cnt), "UNKNOWN_CUT(%d)_", ChipVersion.CUTVersion);
+
+	if (IS_1T1R(ChipVersion))
+		cnt += sprintf((buf + cnt), "1T1R_");
+	else if (IS_1T2R(ChipVersion))
+		cnt += sprintf((buf + cnt), "1T2R_");
+	else if (IS_2T2R(ChipVersion))
+		cnt += sprintf((buf + cnt), "2T2R_");
+	else if (IS_3T3R(ChipVersion))
+		cnt += sprintf((buf + cnt), "3T3R_");
+	else if (IS_3T4R(ChipVersion))
+		cnt += sprintf((buf + cnt), "3T4R_");
+	else if (IS_4T4R(ChipVersion))
+		cnt += sprintf((buf + cnt), "4T4R_");
+	else
+		cnt += sprintf((buf + cnt), "UNKNOWN_RFTYPE(%d)_", ChipVersion.RFType);
 
-	cnt += sprintf((buf+cnt), "RomVer(%d)\n", ChipVersion.ROMVer);
+	cnt += sprintf((buf + cnt), "RomVer(%d)\n", ChipVersion.ROMVer);
 
-	DBG_871X("%s", buf);
+	RTW_INFO("%s", buf);
 }
 void rtw_hal_config_rftype(PADAPTER  padapter)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
-	
-	if (IS_1T1R(pHalData->VersionID)) {
+
+	if (IS_1T1R(pHalData->version_id)) {
 		pHalData->rf_type = RF_1T1R;
 		pHalData->NumTotalRFPath = 1;
-	}	
-	else if (IS_2T2R(pHalData->VersionID)) {
+	} else if (IS_2T2R(pHalData->version_id)) {
 		pHalData->rf_type = RF_2T2R;
 		pHalData->NumTotalRFPath = 2;
-	}
-	else if (IS_1T2R(pHalData->VersionID)) {
+	} else if (IS_1T2R(pHalData->version_id)) {
 		pHalData->rf_type = RF_1T2R;
 		pHalData->NumTotalRFPath = 2;
-	}
-	else if(IS_3T3R(pHalData->VersionID)) {
+	} else if (IS_3T3R(pHalData->version_id)) {
 		pHalData->rf_type = RF_3T3R;
 		pHalData->NumTotalRFPath = 3;
-	}	
-	else if(IS_4T4R(pHalData->VersionID)) {
+	} else if (IS_4T4R(pHalData->version_id)) {
 		pHalData->rf_type = RF_4T4R;
 		pHalData->NumTotalRFPath = 4;
-	}
-	else {
+	} else {
 		pHalData->rf_type = RF_1T1R;
 		pHalData->NumTotalRFPath = 1;
 	}
-	
-	DBG_871X("%s RF_Type is %d TotalTxPath is %d \n", __FUNCTION__, pHalData->rf_type, pHalData->NumTotalRFPath);
+
+	RTW_INFO("%s RF_Type is %d TotalTxPath is %d\n", __FUNCTION__, pHalData->rf_type, pHalData->NumTotalRFPath);
 }
 
 #define	EEPROM_CHANNEL_PLAN_BY_HW_MASK	0x80
 
 /*
  * Description:
- * 	Use hardware(efuse), driver parameter(registry) and default channel plan
- * 	to decide which one should be used.
+ *	Use hardware(efuse), driver parameter(registry) and default channel plan
+ *	to decide which one should be used.
  *
  * Parameters:
  *	padapter			pointer of adapter
@@ -145,11 +231,8 @@ void rtw_hal_config_rftype(PADAPTER  padapter)
  *	def_chplan		channel plan used when HW/SW both invalid
  *	AutoLoadFail		efuse autoload fail or not
  *
- * Return:
- *	Final channel plan decision
- *
  */
-u8 hal_com_config_channel_plan(
+void hal_com_config_channel_plan(
 	IN	PADAPTER padapter,
 	IN	char *hw_alpha2,
 	IN	u8 hw_chplan,
@@ -157,8 +240,9 @@ u8 hal_com_config_channel_plan(
 	IN	u8 sw_chplan,
 	IN	u8 def_chplan,
 	IN	BOOLEAN AutoLoadFail
-	)
+)
 {
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	PHAL_DATA_TYPE	pHalData;
 	u8 force_hw_chplan = _FALSE;
 	int chplan = -1;
@@ -173,10 +257,10 @@ u8 hal_com_config_channel_plan(
 	if (AutoLoadFail == _TRUE)
 		goto chk_sw_config;
 
-	#ifndef CONFIG_FORCE_SW_CHANNEL_PLAN
+#ifndef CONFIG_FORCE_SW_CHANNEL_PLAN
 	if (hw_chplan & EEPROM_CHANNEL_PLAN_BY_HW_MASK)
 		force_hw_chplan = _TRUE;
-	#endif
+#endif
 
 	hw_chplan &= (~EEPROM_CHANNEL_PLAN_BY_HW_MASK);
 
@@ -189,13 +273,13 @@ chk_hw_country_code:
 			chplan = ent->chplan;
 			goto chk_sw_config;
 		} else
-			DBG_871X_LEVEL(_drv_always_, "%s unsupported hw_alpha2:\"%c%c\"\n", __func__, hw_alpha2[0], hw_alpha2[1]);
+			RTW_PRINT("%s unsupported hw_alpha2:\"%c%c\"\n", __func__, hw_alpha2[0], hw_alpha2[1]);
 	}
 
 	if (rtw_is_channel_plan_valid(hw_chplan))
 		chplan = hw_chplan;
 	else if (force_hw_chplan == _TRUE) {
-		DBG_871X_LEVEL(_drv_always_, "%s unsupported hw_chplan:0x%02X\n", __func__, hw_chplan);
+		RTW_PRINT("%s unsupported hw_chplan:0x%02X\n", __func__, hw_chplan);
 		/* hw infomaton invalid, refer to sw information */
 		force_hw_chplan = _FALSE;
 	}
@@ -212,511 +296,944 @@ chk_sw_config:
 			chplan = ent->chplan;
 			goto done;
 		} else
-			DBG_871X_LEVEL(_drv_always_, "%s unsupported sw_alpha2:\"%c%c\"\n", __func__, sw_alpha2[0], sw_alpha2[1]);
+			RTW_PRINT("%s unsupported sw_alpha2:\"%c%c\"\n", __func__, sw_alpha2[0], sw_alpha2[1]);
 	}
 
 	if (rtw_is_channel_plan_valid(sw_chplan)) {
 		/* cancel hw_alpha2 because chplan is specified by sw_chplan*/
 		country_ent = NULL;
 		chplan = sw_chplan;
-	} else if (sw_chplan != RTW_CHPLAN_MAX)
-		DBG_871X_LEVEL(_drv_always_, "%s unsupported sw_chplan:0x%02X\n", __func__, sw_chplan);
+	} else if (sw_chplan != RTW_CHPLAN_UNSPECIFIED)
+		RTW_PRINT("%s unsupported sw_chplan:0x%02X\n", __func__, sw_chplan);
 
 done:
 	if (chplan == -1) {
-		DBG_871X_LEVEL(_drv_always_, "%s use def_chplan:0x%02X\n", __func__, def_chplan);
+		RTW_PRINT("%s use def_chplan:0x%02X\n", __func__, def_chplan);
 		chplan = def_chplan;
 	} else if (country_ent) {
-		DBG_871X_LEVEL(_drv_always_, "%s country code:\"%c%c\" with chplan:0x%02X\n", __func__
+		RTW_PRINT("%s country code:\"%c%c\" with chplan:0x%02X\n", __func__
 			, country_ent->alpha2[0], country_ent->alpha2[1], country_ent->chplan);
 	} else
-		DBG_871X_LEVEL(_drv_always_, "%s chplan:0x%02X\n", __func__, chplan);
+		RTW_PRINT("%s chplan:0x%02X\n", __func__, chplan);
 
-	padapter->mlmepriv.country_ent = country_ent;
+	rfctl->country_ent = country_ent;
+	rfctl->ChannelPlan = chplan;
 	pHalData->bDisableSWChannelPlan = force_hw_chplan;
-
-	return chplan;
 }
 
 BOOLEAN
 HAL_IsLegalChannel(
 	IN	PADAPTER	Adapter,
 	IN	u32			Channel
-	)
+)
 {
 	BOOLEAN bLegalChannel = _TRUE;
 
 	if (Channel > 14) {
-		if(IsSupported5G(Adapter->registrypriv.wireless_mode) == _FALSE) {
+		if (is_supported_5g(Adapter->registrypriv.wireless_mode) == _FALSE) {
 			bLegalChannel = _FALSE;
-			DBG_871X("Channel > 14 but wireless_mode do not support 5G\n");
+			RTW_INFO("Channel > 14 but wireless_mode do not support 5G\n");
 		}
-	} else if ((Channel <= 14) && (Channel >=1)){
-		if(IsSupported24G(Adapter->registrypriv.wireless_mode) == _FALSE) {
+	} else if ((Channel <= 14) && (Channel >= 1)) {
+		if (IsSupported24G(Adapter->registrypriv.wireless_mode) == _FALSE) {
 			bLegalChannel = _FALSE;
-			DBG_871X("(Channel <= 14) && (Channel >=1) but wireless_mode do not support 2.4G\n");
+			RTW_INFO("(Channel <= 14) && (Channel >=1) but wireless_mode do not support 2.4G\n");
 		}
 	} else {
 		bLegalChannel = _FALSE;
-		DBG_871X("Channel is Invalid !!!\n");
+		RTW_INFO("Channel is Invalid !!!\n");
 	}
 
 	return bLegalChannel;
-}	
+}
 
 u8	MRateToHwRate(u8 rate)
 {
 	u8	ret = DESC_RATE1M;
-		
-	switch(rate)
-	{
-		case MGN_1M:		    ret = DESC_RATE1M;	break;
-		case MGN_2M:		    ret = DESC_RATE2M;	break;
-		case MGN_5_5M:		    ret = DESC_RATE5_5M;	break;
-		case MGN_11M:		    ret = DESC_RATE11M;	break;
-		case MGN_6M:		    ret = DESC_RATE6M;	break;
-		case MGN_9M:		    ret = DESC_RATE9M;	break;
-		case MGN_12M:		    ret = DESC_RATE12M;	break;
-		case MGN_18M:		    ret = DESC_RATE18M;	break;
-		case MGN_24M:		    ret = DESC_RATE24M;	break;
-		case MGN_36M:		    ret = DESC_RATE36M;	break;
-		case MGN_48M:		    ret = DESC_RATE48M;	break;
-		case MGN_54M:		    ret = DESC_RATE54M;	break;
-
-		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;
-		case MGN_MCS8:		    ret = DESC_RATEMCS8;	break;
-		case MGN_MCS9:		    ret = DESC_RATEMCS9;	break;
-		case MGN_MCS10:	        ret = DESC_RATEMCS10;	break;
-		case MGN_MCS11:	        ret = DESC_RATEMCS11;	break;
-		case MGN_MCS12:	        ret = DESC_RATEMCS12;	break;
-		case MGN_MCS13:	        ret = DESC_RATEMCS13;	break;
-		case MGN_MCS14:	        ret = DESC_RATEMCS14;	break;
-		case MGN_MCS15:	        ret = DESC_RATEMCS15;	break;
-		case MGN_MCS16:		    ret = DESC_RATEMCS16;	break;
-		case MGN_MCS17:		    ret = DESC_RATEMCS17;	break;
-		case MGN_MCS18:		    ret = DESC_RATEMCS18;	break;
-		case MGN_MCS19:		    ret = DESC_RATEMCS19;	break;
-		case MGN_MCS20:	        ret = DESC_RATEMCS20;	break;
-		case MGN_MCS21:	        ret = DESC_RATEMCS21;	break;
-		case MGN_MCS22:	        ret = DESC_RATEMCS22;	break;
-		case MGN_MCS23:	        ret = DESC_RATEMCS23;	break;
-		case MGN_MCS24:	        ret = DESC_RATEMCS24;	break;
-		case MGN_MCS25:	        ret = DESC_RATEMCS25;	break;
-		case MGN_MCS26:		    ret = DESC_RATEMCS26;	break;
-		case MGN_MCS27:		    ret = DESC_RATEMCS27;	break;
-		case MGN_MCS28:		    ret = DESC_RATEMCS28;	break;
-		case MGN_MCS29:		    ret = DESC_RATEMCS29;	break;
-		case MGN_MCS30:	        ret = DESC_RATEMCS30;	break;
-		case MGN_MCS31:	        ret = DESC_RATEMCS31;	break;
-
-		case MGN_VHT1SS_MCS0:	ret = DESC_RATEVHTSS1MCS0;	break;
-		case MGN_VHT1SS_MCS1:	ret = DESC_RATEVHTSS1MCS1;	break;
-		case MGN_VHT1SS_MCS2:	ret = DESC_RATEVHTSS1MCS2;	break;
-		case MGN_VHT1SS_MCS3:	ret = DESC_RATEVHTSS1MCS3;	break;
-		case MGN_VHT1SS_MCS4:	ret = DESC_RATEVHTSS1MCS4;	break;
-		case MGN_VHT1SS_MCS5:	ret = DESC_RATEVHTSS1MCS5;	break;
-		case MGN_VHT1SS_MCS6:	ret = DESC_RATEVHTSS1MCS6;	break;
-		case MGN_VHT1SS_MCS7:	ret = DESC_RATEVHTSS1MCS7;	break;
-		case MGN_VHT1SS_MCS8:	ret = DESC_RATEVHTSS1MCS8;	break;
-		case MGN_VHT1SS_MCS9:	ret = DESC_RATEVHTSS1MCS9;	break;	
-		case MGN_VHT2SS_MCS0:	ret = DESC_RATEVHTSS2MCS0;	break;
-		case MGN_VHT2SS_MCS1:	ret = DESC_RATEVHTSS2MCS1;	break;
-		case MGN_VHT2SS_MCS2:	ret = DESC_RATEVHTSS2MCS2;	break;
-		case MGN_VHT2SS_MCS3:	ret = DESC_RATEVHTSS2MCS3;	break;
-		case MGN_VHT2SS_MCS4:	ret = DESC_RATEVHTSS2MCS4;	break;
-		case MGN_VHT2SS_MCS5:	ret = DESC_RATEVHTSS2MCS5;	break;
-		case MGN_VHT2SS_MCS6:	ret = DESC_RATEVHTSS2MCS6;	break;
-		case MGN_VHT2SS_MCS7:	ret = DESC_RATEVHTSS2MCS7;	break;
-		case MGN_VHT2SS_MCS8:	ret = DESC_RATEVHTSS2MCS8;	break;
-		case MGN_VHT2SS_MCS9:	ret = DESC_RATEVHTSS2MCS9;	break;	
-		case MGN_VHT3SS_MCS0:	ret = DESC_RATEVHTSS3MCS0;	break;
-		case MGN_VHT3SS_MCS1:	ret = DESC_RATEVHTSS3MCS1;	break;
-		case MGN_VHT3SS_MCS2:	ret = DESC_RATEVHTSS3MCS2;	break;
-		case MGN_VHT3SS_MCS3:	ret = DESC_RATEVHTSS3MCS3;	break;
-		case MGN_VHT3SS_MCS4:	ret = DESC_RATEVHTSS3MCS4;	break;
-		case MGN_VHT3SS_MCS5:	ret = DESC_RATEVHTSS3MCS5;	break;
-		case MGN_VHT3SS_MCS6:	ret = DESC_RATEVHTSS3MCS6;	break;
-		case MGN_VHT3SS_MCS7:	ret = DESC_RATEVHTSS3MCS7;	break;
-		case MGN_VHT3SS_MCS8:	ret = DESC_RATEVHTSS3MCS8;	break;
-		case MGN_VHT3SS_MCS9:	ret = DESC_RATEVHTSS3MCS9;	break;
-		case MGN_VHT4SS_MCS0:	ret = DESC_RATEVHTSS4MCS0;	break;
-		case MGN_VHT4SS_MCS1:	ret = DESC_RATEVHTSS4MCS1;	break;
-		case MGN_VHT4SS_MCS2:	ret = DESC_RATEVHTSS4MCS2;	break;
-		case MGN_VHT4SS_MCS3:	ret = DESC_RATEVHTSS4MCS3;	break;
-		case MGN_VHT4SS_MCS4:	ret = DESC_RATEVHTSS4MCS4;	break;
-		case MGN_VHT4SS_MCS5:	ret = DESC_RATEVHTSS4MCS5;	break;
-		case MGN_VHT4SS_MCS6:	ret = DESC_RATEVHTSS4MCS6;	break;
-		case MGN_VHT4SS_MCS7:	ret = DESC_RATEVHTSS4MCS7;	break;
-		case MGN_VHT4SS_MCS8:	ret = DESC_RATEVHTSS4MCS8;	break;
-		case MGN_VHT4SS_MCS9:	ret = DESC_RATEVHTSS4MCS9;	break;
-		default:		break;
-	}
-
-	return ret;
-}
-
-u8	HwRateToMRate(u8 rate)
-{
-	u8	ret_rate = MGN_1M;
-
-	switch(rate)
-	{
-	
-		case DESC_RATE1M:		    ret_rate = MGN_1M;		break;
-		case DESC_RATE2M:		    ret_rate = MGN_2M;		break;
-		case DESC_RATE5_5M:	        ret_rate = MGN_5_5M;	break;
-		case DESC_RATE11M:		    ret_rate = MGN_11M;		break;
-		case DESC_RATE6M:		    ret_rate = MGN_6M;		break;
-		case DESC_RATE9M:		    ret_rate = MGN_9M;		break;
-		case DESC_RATE12M:		    ret_rate = MGN_12M;		break;
-		case DESC_RATE18M:		    ret_rate = MGN_18M;		break;
-		case DESC_RATE24M:		    ret_rate = MGN_24M;		break;
-		case DESC_RATE36M:		    ret_rate = MGN_36M;		break;
-		case DESC_RATE48M:		    ret_rate = MGN_48M;		break;
-		case DESC_RATE54M:		    ret_rate = MGN_54M;		break;			
-		case DESC_RATEMCS0:	        ret_rate = MGN_MCS0;	break;
-		case DESC_RATEMCS1:	        ret_rate = MGN_MCS1;	break;
-		case DESC_RATEMCS2:	        ret_rate = MGN_MCS2;	break;
-		case DESC_RATEMCS3:	        ret_rate = MGN_MCS3;	break;
-		case DESC_RATEMCS4:	        ret_rate = MGN_MCS4;	break;
-		case DESC_RATEMCS5:	        ret_rate = MGN_MCS5;	break;
-		case DESC_RATEMCS6:	        ret_rate = MGN_MCS6;	break;
-		case DESC_RATEMCS7:	        ret_rate = MGN_MCS7;	break;
-		case DESC_RATEMCS8:	        ret_rate = MGN_MCS8;	break;
-		case DESC_RATEMCS9:	        ret_rate = MGN_MCS9;	break;
-		case DESC_RATEMCS10:	    ret_rate = MGN_MCS10;	break;
-		case DESC_RATEMCS11:	    ret_rate = MGN_MCS11;	break;
-		case DESC_RATEMCS12:	    ret_rate = MGN_MCS12;	break;
-		case DESC_RATEMCS13:	    ret_rate = MGN_MCS13;	break;
-		case DESC_RATEMCS14:	    ret_rate = MGN_MCS14;	break;
-		case DESC_RATEMCS15:	    ret_rate = MGN_MCS15;	break;
-		case DESC_RATEMCS16:	    ret_rate = MGN_MCS16;	break;
-		case DESC_RATEMCS17:	    ret_rate = MGN_MCS17;	break;
-		case DESC_RATEMCS18:	    ret_rate = MGN_MCS18;	break;
-		case DESC_RATEMCS19:	    ret_rate = MGN_MCS19;	break;
-		case DESC_RATEMCS20:	    ret_rate = MGN_MCS20;	break;
-		case DESC_RATEMCS21:	    ret_rate = MGN_MCS21;	break;
-		case DESC_RATEMCS22:	    ret_rate = MGN_MCS22;	break;
-		case DESC_RATEMCS23:	    ret_rate = MGN_MCS23;	break;
-		case DESC_RATEMCS24:	    ret_rate = MGN_MCS24;	break;
-		case DESC_RATEMCS25:	    ret_rate = MGN_MCS25;	break;
-		case DESC_RATEMCS26:	    ret_rate = MGN_MCS26;	break;
-		case DESC_RATEMCS27:	    ret_rate = MGN_MCS27;	break;
-		case DESC_RATEMCS28:	    ret_rate = MGN_MCS28;	break;
-		case DESC_RATEMCS29:	    ret_rate = MGN_MCS29;	break;
-		case DESC_RATEMCS30:	    ret_rate = MGN_MCS30;	break;
-		case DESC_RATEMCS31:	    ret_rate = MGN_MCS31;	break;
-		case DESC_RATEVHTSS1MCS0:	ret_rate = MGN_VHT1SS_MCS0;		break;
-		case DESC_RATEVHTSS1MCS1:	ret_rate = MGN_VHT1SS_MCS1;		break;
-		case DESC_RATEVHTSS1MCS2:	ret_rate = MGN_VHT1SS_MCS2;		break;
-		case DESC_RATEVHTSS1MCS3:	ret_rate = MGN_VHT1SS_MCS3;		break;
-		case DESC_RATEVHTSS1MCS4:	ret_rate = MGN_VHT1SS_MCS4;		break;
-		case DESC_RATEVHTSS1MCS5:	ret_rate = MGN_VHT1SS_MCS5;		break;
-		case DESC_RATEVHTSS1MCS6:	ret_rate = MGN_VHT1SS_MCS6;		break;
-		case DESC_RATEVHTSS1MCS7:	ret_rate = MGN_VHT1SS_MCS7;		break;
-		case DESC_RATEVHTSS1MCS8:	ret_rate = MGN_VHT1SS_MCS8;		break;
-		case DESC_RATEVHTSS1MCS9:	ret_rate = MGN_VHT1SS_MCS9;		break;
-		case DESC_RATEVHTSS2MCS0:	ret_rate = MGN_VHT2SS_MCS0;		break;
-		case DESC_RATEVHTSS2MCS1:	ret_rate = MGN_VHT2SS_MCS1;		break;
-		case DESC_RATEVHTSS2MCS2:	ret_rate = MGN_VHT2SS_MCS2;		break;
-		case DESC_RATEVHTSS2MCS3:	ret_rate = MGN_VHT2SS_MCS3;		break;
-		case DESC_RATEVHTSS2MCS4:	ret_rate = MGN_VHT2SS_MCS4;		break;
-		case DESC_RATEVHTSS2MCS5:	ret_rate = MGN_VHT2SS_MCS5;		break;
-		case DESC_RATEVHTSS2MCS6:	ret_rate = MGN_VHT2SS_MCS6;		break;
-		case DESC_RATEVHTSS2MCS7:	ret_rate = MGN_VHT2SS_MCS7;		break;
-		case DESC_RATEVHTSS2MCS8:	ret_rate = MGN_VHT2SS_MCS8;		break;
-		case DESC_RATEVHTSS2MCS9:	ret_rate = MGN_VHT2SS_MCS9;		break;				
-		case DESC_RATEVHTSS3MCS0:	ret_rate = MGN_VHT3SS_MCS0;		break;
-		case DESC_RATEVHTSS3MCS1:	ret_rate = MGN_VHT3SS_MCS1;		break;
-		case DESC_RATEVHTSS3MCS2:	ret_rate = MGN_VHT3SS_MCS2;		break;
-		case DESC_RATEVHTSS3MCS3:	ret_rate = MGN_VHT3SS_MCS3;		break;
-		case DESC_RATEVHTSS3MCS4:	ret_rate = MGN_VHT3SS_MCS4;		break;
-		case DESC_RATEVHTSS3MCS5:	ret_rate = MGN_VHT3SS_MCS5;		break;
-		case DESC_RATEVHTSS3MCS6:	ret_rate = MGN_VHT3SS_MCS6;		break;
-		case DESC_RATEVHTSS3MCS7:	ret_rate = MGN_VHT3SS_MCS7;		break;
-		case DESC_RATEVHTSS3MCS8:	ret_rate = MGN_VHT3SS_MCS8;		break;
-		case DESC_RATEVHTSS3MCS9:	ret_rate = MGN_VHT3SS_MCS9;		break;				
-		case DESC_RATEVHTSS4MCS0:	ret_rate = MGN_VHT4SS_MCS0;		break;
-		case DESC_RATEVHTSS4MCS1:	ret_rate = MGN_VHT4SS_MCS1;		break;
-		case DESC_RATEVHTSS4MCS2:	ret_rate = MGN_VHT4SS_MCS2;		break;
-		case DESC_RATEVHTSS4MCS3:	ret_rate = MGN_VHT4SS_MCS3;		break;
-		case DESC_RATEVHTSS4MCS4:	ret_rate = MGN_VHT4SS_MCS4;		break;
-		case DESC_RATEVHTSS4MCS5:	ret_rate = MGN_VHT4SS_MCS5;		break;
-		case DESC_RATEVHTSS4MCS6:	ret_rate = MGN_VHT4SS_MCS6;		break;
-		case DESC_RATEVHTSS4MCS7:	ret_rate = MGN_VHT4SS_MCS7;		break;
-		case DESC_RATEVHTSS4MCS8:	ret_rate = MGN_VHT4SS_MCS8;		break;
-		case DESC_RATEVHTSS4MCS9:	ret_rate = MGN_VHT4SS_MCS9;		break;				
-		
-		default:							
-			DBG_871X("HwRateToMRate(): Non supported Rate [%x]!!!\n",rate );
-			break;
-	}
-
-	return ret_rate;
-}
-
-void	HalSetBrateCfg(
-	IN PADAPTER		Adapter,
-	IN u8			*mBratesOS,
-	OUT u16			*pBrateCfg)
-{
-	u8	i, is_brate, brate;
-
-	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:	*pBrateCfg |= RATE_1M;	break;
-				case IEEE80211_CCK_RATE_2MB:	*pBrateCfg |= RATE_2M;	break;
-				case IEEE80211_CCK_RATE_5MB:	*pBrateCfg |= RATE_5_5M;break;
-				case IEEE80211_CCK_RATE_11MB:	*pBrateCfg |= RATE_11M;	break;
-				case IEEE80211_OFDM_RATE_6MB:	*pBrateCfg |= RATE_6M;	break;
-				case IEEE80211_OFDM_RATE_9MB:	*pBrateCfg |= RATE_9M;	break;
-				case IEEE80211_OFDM_RATE_12MB:	*pBrateCfg |= RATE_12M;	break;
-				case IEEE80211_OFDM_RATE_18MB:	*pBrateCfg |= RATE_18M;	break;
-				case IEEE80211_OFDM_RATE_24MB:	*pBrateCfg |= RATE_24M;	break;
-				case IEEE80211_OFDM_RATE_36MB:	*pBrateCfg |= RATE_36M;	break;
-				case IEEE80211_OFDM_RATE_48MB:	*pBrateCfg |= RATE_48M;	break;
-				case IEEE80211_OFDM_RATE_54MB:	*pBrateCfg |= RATE_54M;	break;
-			}
-		}
-	}
-}
 
-static VOID
-_OneOutPipeMapping(
-	IN	PADAPTER	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
-}
+	switch (rate) {
+	case MGN_1M:
+		ret = DESC_RATE1M;
+		break;
+	case MGN_2M:
+		ret = DESC_RATE2M;
+		break;
+	case MGN_5_5M:
+		ret = DESC_RATE5_5M;
+		break;
+	case MGN_11M:
+		ret = DESC_RATE11M;
+		break;
+	case MGN_6M:
+		ret = DESC_RATE6M;
+		break;
+	case MGN_9M:
+		ret = DESC_RATE9M;
+		break;
+	case MGN_12M:
+		ret = DESC_RATE12M;
+		break;
+	case MGN_18M:
+		ret = DESC_RATE18M;
+		break;
+	case MGN_24M:
+		ret = DESC_RATE24M;
+		break;
+	case MGN_36M:
+		ret = DESC_RATE36M;
+		break;
+	case MGN_48M:
+		ret = DESC_RATE48M;
+		break;
+	case MGN_54M:
+		ret = DESC_RATE54M;
+		break;
 
-static VOID
-_TwoOutPipeMapping(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN	 	bWIFICfg
-	)
-{
-	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(pAdapter);
+	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;
+	case MGN_MCS8:
+		ret = DESC_RATEMCS8;
+		break;
+	case MGN_MCS9:
+		ret = DESC_RATEMCS9;
+		break;
+	case MGN_MCS10:
+		ret = DESC_RATEMCS10;
+		break;
+	case MGN_MCS11:
+		ret = DESC_RATEMCS11;
+		break;
+	case MGN_MCS12:
+		ret = DESC_RATEMCS12;
+		break;
+	case MGN_MCS13:
+		ret = DESC_RATEMCS13;
+		break;
+	case MGN_MCS14:
+		ret = DESC_RATEMCS14;
+		break;
+	case MGN_MCS15:
+		ret = DESC_RATEMCS15;
+		break;
+	case MGN_MCS16:
+		ret = DESC_RATEMCS16;
+		break;
+	case MGN_MCS17:
+		ret = DESC_RATEMCS17;
+		break;
+	case MGN_MCS18:
+		ret = DESC_RATEMCS18;
+		break;
+	case MGN_MCS19:
+		ret = DESC_RATEMCS19;
+		break;
+	case MGN_MCS20:
+		ret = DESC_RATEMCS20;
+		break;
+	case MGN_MCS21:
+		ret = DESC_RATEMCS21;
+		break;
+	case MGN_MCS22:
+		ret = DESC_RATEMCS22;
+		break;
+	case MGN_MCS23:
+		ret = DESC_RATEMCS23;
+		break;
+	case MGN_MCS24:
+		ret = DESC_RATEMCS24;
+		break;
+	case MGN_MCS25:
+		ret = DESC_RATEMCS25;
+		break;
+	case MGN_MCS26:
+		ret = DESC_RATEMCS26;
+		break;
+	case MGN_MCS27:
+		ret = DESC_RATEMCS27;
+		break;
+	case MGN_MCS28:
+		ret = DESC_RATEMCS28;
+		break;
+	case MGN_MCS29:
+		ret = DESC_RATEMCS29;
+		break;
+	case MGN_MCS30:
+		ret = DESC_RATEMCS30;
+		break;
+	case MGN_MCS31:
+		ret = DESC_RATEMCS31;
+		break;
 
-	if(bWIFICfg){ //WMM
-		
-		//	BK, 	BE, 	VI, 	VO, 	BCN,	CMD,MGT,HIGH,HCCA 
-		//{  0, 	1, 	0, 	1, 	0, 	0, 	0, 	0, 		0	};
-		//0:ep_0 num, 1:ep_1 num 
-		
-		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
-		
+	case MGN_VHT1SS_MCS0:
+		ret = DESC_RATEVHTSS1MCS0;
+		break;
+	case MGN_VHT1SS_MCS1:
+		ret = DESC_RATEVHTSS1MCS1;
+		break;
+	case MGN_VHT1SS_MCS2:
+		ret = DESC_RATEVHTSS1MCS2;
+		break;
+	case MGN_VHT1SS_MCS3:
+		ret = DESC_RATEVHTSS1MCS3;
+		break;
+	case MGN_VHT1SS_MCS4:
+		ret = DESC_RATEVHTSS1MCS4;
+		break;
+	case MGN_VHT1SS_MCS5:
+		ret = DESC_RATEVHTSS1MCS5;
+		break;
+	case MGN_VHT1SS_MCS6:
+		ret = DESC_RATEVHTSS1MCS6;
+		break;
+	case MGN_VHT1SS_MCS7:
+		ret = DESC_RATEVHTSS1MCS7;
+		break;
+	case MGN_VHT1SS_MCS8:
+		ret = DESC_RATEVHTSS1MCS8;
+		break;
+	case MGN_VHT1SS_MCS9:
+		ret = DESC_RATEVHTSS1MCS9;
+		break;
+	case MGN_VHT2SS_MCS0:
+		ret = DESC_RATEVHTSS2MCS0;
+		break;
+	case MGN_VHT2SS_MCS1:
+		ret = DESC_RATEVHTSS2MCS1;
+		break;
+	case MGN_VHT2SS_MCS2:
+		ret = DESC_RATEVHTSS2MCS2;
+		break;
+	case MGN_VHT2SS_MCS3:
+		ret = DESC_RATEVHTSS2MCS3;
+		break;
+	case MGN_VHT2SS_MCS4:
+		ret = DESC_RATEVHTSS2MCS4;
+		break;
+	case MGN_VHT2SS_MCS5:
+		ret = DESC_RATEVHTSS2MCS5;
+		break;
+	case MGN_VHT2SS_MCS6:
+		ret = DESC_RATEVHTSS2MCS6;
+		break;
+	case MGN_VHT2SS_MCS7:
+		ret = DESC_RATEVHTSS2MCS7;
+		break;
+	case MGN_VHT2SS_MCS8:
+		ret = DESC_RATEVHTSS2MCS8;
+		break;
+	case MGN_VHT2SS_MCS9:
+		ret = DESC_RATEVHTSS2MCS9;
+		break;
+	case MGN_VHT3SS_MCS0:
+		ret = DESC_RATEVHTSS3MCS0;
+		break;
+	case MGN_VHT3SS_MCS1:
+		ret = DESC_RATEVHTSS3MCS1;
+		break;
+	case MGN_VHT3SS_MCS2:
+		ret = DESC_RATEVHTSS3MCS2;
+		break;
+	case MGN_VHT3SS_MCS3:
+		ret = DESC_RATEVHTSS3MCS3;
+		break;
+	case MGN_VHT3SS_MCS4:
+		ret = DESC_RATEVHTSS3MCS4;
+		break;
+	case MGN_VHT3SS_MCS5:
+		ret = DESC_RATEVHTSS3MCS5;
+		break;
+	case MGN_VHT3SS_MCS6:
+		ret = DESC_RATEVHTSS3MCS6;
+		break;
+	case MGN_VHT3SS_MCS7:
+		ret = DESC_RATEVHTSS3MCS7;
+		break;
+	case MGN_VHT3SS_MCS8:
+		ret = DESC_RATEVHTSS3MCS8;
+		break;
+	case MGN_VHT3SS_MCS9:
+		ret = DESC_RATEVHTSS3MCS9;
+		break;
+	case MGN_VHT4SS_MCS0:
+		ret = DESC_RATEVHTSS4MCS0;
+		break;
+	case MGN_VHT4SS_MCS1:
+		ret = DESC_RATEVHTSS4MCS1;
+		break;
+	case MGN_VHT4SS_MCS2:
+		ret = DESC_RATEVHTSS4MCS2;
+		break;
+	case MGN_VHT4SS_MCS3:
+		ret = DESC_RATEVHTSS4MCS3;
+		break;
+	case MGN_VHT4SS_MCS4:
+		ret = DESC_RATEVHTSS4MCS4;
+		break;
+	case MGN_VHT4SS_MCS5:
+		ret = DESC_RATEVHTSS4MCS5;
+		break;
+	case MGN_VHT4SS_MCS6:
+		ret = DESC_RATEVHTSS4MCS6;
+		break;
+	case MGN_VHT4SS_MCS7:
+		ret = DESC_RATEVHTSS4MCS7;
+		break;
+	case MGN_VHT4SS_MCS8:
+		ret = DESC_RATEVHTSS4MCS8;
+		break;
+	case MGN_VHT4SS_MCS9:
+		ret = DESC_RATEVHTSS4MCS9;
+		break;
+	default:
+		break;
 	}
-	else{//typical setting
 
-		
-		//BK, 	BE, 	VI, 	VO, 	BCN,	CMD,MGT,HIGH,HCCA 
-		//{  1, 	1, 	0, 	0, 	0, 	0, 	0, 	0, 		0	};			
-		//0:ep_0 num, 1:ep_1 num
-		
-		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	
-		
-	}
-	
+	return ret;
 }
 
-static VOID _ThreeOutPipeMapping(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN	 	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	
-	}
-
-}
-static VOID _FourOutPipeMapping(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN	 	bWIFICfg
-	)
+u8	hw_rate_to_m_rate(u8 rate)
 {
-	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(pAdapter);
+	u8	ret_rate = MGN_1M;
 
-	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 ,3:E
-		
-		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[3];//HIGH
-		pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];//TXCMD
-		
-	}
-	else{//typical setting
+	switch (rate) {
 
-		
-		//	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[3];//HIGH
-		pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];//TXCMD	
-	}
+	case DESC_RATE1M:
+		ret_rate = MGN_1M;
+		break;
+	case DESC_RATE2M:
+		ret_rate = MGN_2M;
+		break;
+	case DESC_RATE5_5M:
+		ret_rate = MGN_5_5M;
+		break;
+	case DESC_RATE11M:
+		ret_rate = MGN_11M;
+		break;
+	case DESC_RATE6M:
+		ret_rate = MGN_6M;
+		break;
+	case DESC_RATE9M:
+		ret_rate = MGN_9M;
+		break;
+	case DESC_RATE12M:
+		ret_rate = MGN_12M;
+		break;
+	case DESC_RATE18M:
+		ret_rate = MGN_18M;
+		break;
+	case DESC_RATE24M:
+		ret_rate = MGN_24M;
+		break;
+	case DESC_RATE36M:
+		ret_rate = MGN_36M;
+		break;
+	case DESC_RATE48M:
+		ret_rate = MGN_48M;
+		break;
+	case DESC_RATE54M:
+		ret_rate = MGN_54M;
+		break;
+	case DESC_RATEMCS0:
+		ret_rate = MGN_MCS0;
+		break;
+	case DESC_RATEMCS1:
+		ret_rate = MGN_MCS1;
+		break;
+	case DESC_RATEMCS2:
+		ret_rate = MGN_MCS2;
+		break;
+	case DESC_RATEMCS3:
+		ret_rate = MGN_MCS3;
+		break;
+	case DESC_RATEMCS4:
+		ret_rate = MGN_MCS4;
+		break;
+	case DESC_RATEMCS5:
+		ret_rate = MGN_MCS5;
+		break;
+	case DESC_RATEMCS6:
+		ret_rate = MGN_MCS6;
+		break;
+	case DESC_RATEMCS7:
+		ret_rate = MGN_MCS7;
+		break;
+	case DESC_RATEMCS8:
+		ret_rate = MGN_MCS8;
+		break;
+	case DESC_RATEMCS9:
+		ret_rate = MGN_MCS9;
+		break;
+	case DESC_RATEMCS10:
+		ret_rate = MGN_MCS10;
+		break;
+	case DESC_RATEMCS11:
+		ret_rate = MGN_MCS11;
+		break;
+	case DESC_RATEMCS12:
+		ret_rate = MGN_MCS12;
+		break;
+	case DESC_RATEMCS13:
+		ret_rate = MGN_MCS13;
+		break;
+	case DESC_RATEMCS14:
+		ret_rate = MGN_MCS14;
+		break;
+	case DESC_RATEMCS15:
+		ret_rate = MGN_MCS15;
+		break;
+	case DESC_RATEMCS16:
+		ret_rate = MGN_MCS16;
+		break;
+	case DESC_RATEMCS17:
+		ret_rate = MGN_MCS17;
+		break;
+	case DESC_RATEMCS18:
+		ret_rate = MGN_MCS18;
+		break;
+	case DESC_RATEMCS19:
+		ret_rate = MGN_MCS19;
+		break;
+	case DESC_RATEMCS20:
+		ret_rate = MGN_MCS20;
+		break;
+	case DESC_RATEMCS21:
+		ret_rate = MGN_MCS21;
+		break;
+	case DESC_RATEMCS22:
+		ret_rate = MGN_MCS22;
+		break;
+	case DESC_RATEMCS23:
+		ret_rate = MGN_MCS23;
+		break;
+	case DESC_RATEMCS24:
+		ret_rate = MGN_MCS24;
+		break;
+	case DESC_RATEMCS25:
+		ret_rate = MGN_MCS25;
+		break;
+	case DESC_RATEMCS26:
+		ret_rate = MGN_MCS26;
+		break;
+	case DESC_RATEMCS27:
+		ret_rate = MGN_MCS27;
+		break;
+	case DESC_RATEMCS28:
+		ret_rate = MGN_MCS28;
+		break;
+	case DESC_RATEMCS29:
+		ret_rate = MGN_MCS29;
+		break;
+	case DESC_RATEMCS30:
+		ret_rate = MGN_MCS30;
+		break;
+	case DESC_RATEMCS31:
+		ret_rate = MGN_MCS31;
+		break;
+	case DESC_RATEVHTSS1MCS0:
+		ret_rate = MGN_VHT1SS_MCS0;
+		break;
+	case DESC_RATEVHTSS1MCS1:
+		ret_rate = MGN_VHT1SS_MCS1;
+		break;
+	case DESC_RATEVHTSS1MCS2:
+		ret_rate = MGN_VHT1SS_MCS2;
+		break;
+	case DESC_RATEVHTSS1MCS3:
+		ret_rate = MGN_VHT1SS_MCS3;
+		break;
+	case DESC_RATEVHTSS1MCS4:
+		ret_rate = MGN_VHT1SS_MCS4;
+		break;
+	case DESC_RATEVHTSS1MCS5:
+		ret_rate = MGN_VHT1SS_MCS5;
+		break;
+	case DESC_RATEVHTSS1MCS6:
+		ret_rate = MGN_VHT1SS_MCS6;
+		break;
+	case DESC_RATEVHTSS1MCS7:
+		ret_rate = MGN_VHT1SS_MCS7;
+		break;
+	case DESC_RATEVHTSS1MCS8:
+		ret_rate = MGN_VHT1SS_MCS8;
+		break;
+	case DESC_RATEVHTSS1MCS9:
+		ret_rate = MGN_VHT1SS_MCS9;
+		break;
+	case DESC_RATEVHTSS2MCS0:
+		ret_rate = MGN_VHT2SS_MCS0;
+		break;
+	case DESC_RATEVHTSS2MCS1:
+		ret_rate = MGN_VHT2SS_MCS1;
+		break;
+	case DESC_RATEVHTSS2MCS2:
+		ret_rate = MGN_VHT2SS_MCS2;
+		break;
+	case DESC_RATEVHTSS2MCS3:
+		ret_rate = MGN_VHT2SS_MCS3;
+		break;
+	case DESC_RATEVHTSS2MCS4:
+		ret_rate = MGN_VHT2SS_MCS4;
+		break;
+	case DESC_RATEVHTSS2MCS5:
+		ret_rate = MGN_VHT2SS_MCS5;
+		break;
+	case DESC_RATEVHTSS2MCS6:
+		ret_rate = MGN_VHT2SS_MCS6;
+		break;
+	case DESC_RATEVHTSS2MCS7:
+		ret_rate = MGN_VHT2SS_MCS7;
+		break;
+	case DESC_RATEVHTSS2MCS8:
+		ret_rate = MGN_VHT2SS_MCS8;
+		break;
+	case DESC_RATEVHTSS2MCS9:
+		ret_rate = MGN_VHT2SS_MCS9;
+		break;
+	case DESC_RATEVHTSS3MCS0:
+		ret_rate = MGN_VHT3SS_MCS0;
+		break;
+	case DESC_RATEVHTSS3MCS1:
+		ret_rate = MGN_VHT3SS_MCS1;
+		break;
+	case DESC_RATEVHTSS3MCS2:
+		ret_rate = MGN_VHT3SS_MCS2;
+		break;
+	case DESC_RATEVHTSS3MCS3:
+		ret_rate = MGN_VHT3SS_MCS3;
+		break;
+	case DESC_RATEVHTSS3MCS4:
+		ret_rate = MGN_VHT3SS_MCS4;
+		break;
+	case DESC_RATEVHTSS3MCS5:
+		ret_rate = MGN_VHT3SS_MCS5;
+		break;
+	case DESC_RATEVHTSS3MCS6:
+		ret_rate = MGN_VHT3SS_MCS6;
+		break;
+	case DESC_RATEVHTSS3MCS7:
+		ret_rate = MGN_VHT3SS_MCS7;
+		break;
+	case DESC_RATEVHTSS3MCS8:
+		ret_rate = MGN_VHT3SS_MCS8;
+		break;
+	case DESC_RATEVHTSS3MCS9:
+		ret_rate = MGN_VHT3SS_MCS9;
+		break;
+	case DESC_RATEVHTSS4MCS0:
+		ret_rate = MGN_VHT4SS_MCS0;
+		break;
+	case DESC_RATEVHTSS4MCS1:
+		ret_rate = MGN_VHT4SS_MCS1;
+		break;
+	case DESC_RATEVHTSS4MCS2:
+		ret_rate = MGN_VHT4SS_MCS2;
+		break;
+	case DESC_RATEVHTSS4MCS3:
+		ret_rate = MGN_VHT4SS_MCS3;
+		break;
+	case DESC_RATEVHTSS4MCS4:
+		ret_rate = MGN_VHT4SS_MCS4;
+		break;
+	case DESC_RATEVHTSS4MCS5:
+		ret_rate = MGN_VHT4SS_MCS5;
+		break;
+	case DESC_RATEVHTSS4MCS6:
+		ret_rate = MGN_VHT4SS_MCS6;
+		break;
+	case DESC_RATEVHTSS4MCS7:
+		ret_rate = MGN_VHT4SS_MCS7;
+		break;
+	case DESC_RATEVHTSS4MCS8:
+		ret_rate = MGN_VHT4SS_MCS8;
+		break;
+	case DESC_RATEVHTSS4MCS9:
+		ret_rate = MGN_VHT4SS_MCS9;
+		break;
+
+	default:
+		RTW_INFO("hw_rate_to_m_rate(): Non supported Rate [%x]!!!\n", rate);
+		break;
+	}
+
+	return ret_rate;
+}
+
+void	HalSetBrateCfg(
+	IN PADAPTER		Adapter,
+	IN u8			*mBratesOS,
+	OUT u16			*pBrateCfg)
+{
+	u8	i, is_brate, brate;
+
+	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:
+				*pBrateCfg |= RATE_1M;
+				break;
+			case IEEE80211_CCK_RATE_2MB:
+				*pBrateCfg |= RATE_2M;
+				break;
+			case IEEE80211_CCK_RATE_5MB:
+				*pBrateCfg |= RATE_5_5M;
+				break;
+			case IEEE80211_CCK_RATE_11MB:
+				*pBrateCfg |= RATE_11M;
+				break;
+			case IEEE80211_OFDM_RATE_6MB:
+				*pBrateCfg |= RATE_6M;
+				break;
+			case IEEE80211_OFDM_RATE_9MB:
+				*pBrateCfg |= RATE_9M;
+				break;
+			case IEEE80211_OFDM_RATE_12MB:
+				*pBrateCfg |= RATE_12M;
+				break;
+			case IEEE80211_OFDM_RATE_18MB:
+				*pBrateCfg |= RATE_18M;
+				break;
+			case IEEE80211_OFDM_RATE_24MB:
+				*pBrateCfg |= RATE_24M;
+				break;
+			case IEEE80211_OFDM_RATE_36MB:
+				*pBrateCfg |= RATE_36M;
+				break;
+			case IEEE80211_OFDM_RATE_48MB:
+				*pBrateCfg |= RATE_48M;
+				break;
+			case IEEE80211_OFDM_RATE_54MB:
+				*pBrateCfg |= RATE_54M;
+				break;
+			}
+		}
+	}
+}
+
+static VOID
+_OneOutPipeMapping(
+	IN	PADAPTER	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(
+	IN	PADAPTER	pAdapter,
+	IN	BOOLEAN		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:ep_0 num, 1:ep_1 num */
+
+		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:ep_0 num, 1:ep_1 num */
+
+		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(
+	IN	PADAPTER	pAdapter,
+	IN	BOOLEAN		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	 */
+	}
+
+}
+static VOID _FourOutPipeMapping(
+	IN	PADAPTER	pAdapter,
+	IN	BOOLEAN		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 ,3:E */
+
+		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[3];/* 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[3];/* HIGH */
+		pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD	 */
+	}
 
 }
 BOOLEAN
 Hal_MappingOutPipe(
 	IN	PADAPTER	pAdapter,
 	IN	u8		NumOutPipe
-	)
+)
 {
 	struct registry_priv *pregistrypriv = &pAdapter->registrypriv;
 
-	BOOLEAN	 bWIFICfg = (pregistrypriv->wifi_spec) ?_TRUE:_FALSE;
-	
+	BOOLEAN	 bWIFICfg = (pregistrypriv->wifi_spec) ? _TRUE : _FALSE;
+
 	BOOLEAN result = _TRUE;
 
-	switch(NumOutPipe)
-	{
-		case 2:
-			_TwoOutPipeMapping(pAdapter, bWIFICfg);
-			break;
-		case 3:
-		case 4:
-			_ThreeOutPipeMapping(pAdapter, bWIFICfg);
-			break;			
-		case 1:
-			_OneOutPipeMapping(pAdapter);
-			break;
-		default:
-			result = _FALSE;
-			break;
+	switch (NumOutPipe) {
+	case 2:
+		_TwoOutPipeMapping(pAdapter, bWIFICfg);
+		break;
+	case 3:
+	case 4:
+		_ThreeOutPipeMapping(pAdapter, bWIFICfg);
+		break;
+	case 1:
+		_OneOutPipeMapping(pAdapter);
+		break;
+	default:
+		result = _FALSE;
+		break;
 	}
 
 	return result;
-	
+
+}
+
+void rtw_hal_reqtxrpt(_adapter *padapter, u8 macid)
+{
+	if (padapter->hal_func.reqtxrpt)
+		padapter->hal_func.reqtxrpt(padapter, macid);
+}
+
+void rtw_hal_dump_macaddr(void *sel, _adapter *adapter)
+{
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 mac_addr[ETH_ALEN];
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_mbid_cam_dump(sel, __func__, adapter);
+#else
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {
+			rtw_hal_get_hwreg(iface, HW_VAR_MAC_ADDR, mac_addr);
+			RTW_PRINT_SEL(sel, ADPT_FMT"- hw port(%d) mac_addr ="MAC_FMT"\n",
+				ADPT_ARG(iface), iface->hw_port, MAC_ARG(mac_addr));
+		}
+	}
+#endif
+}
+
+#ifdef RTW_HALMAC
+void rtw_hal_hw_port_enable(_adapter *adapter)
+{
+#if 1
+	u8 port_enable = _TRUE;
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_PORT_CFG, &port_enable);
+#else
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct rtw_halmac_bcn_ctrl bcn_ctrl;
+
+	_rtw_memset(&bcn_ctrl, 0, sizeof(struct rtw_halmac_bcn_ctrl));
+	bcn_ctrl.enable_bcn = 1;
+	bcn_ctrl.rx_bssid_fit = 1;
+	bcn_ctrl.rxbcn_rpt = 1;
+
+	/*rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
+				struct rtw_halmac_bcn_ctrl *bcn_ctrl)*/
+	if (rtw_halmac_set_bcn_ctrl(dvobj, get_hw_port(adapter), &bcn_ctrl) == -1) {
+		RTW_ERR(ADPT_FMT" - hw port(%d) enable fail!!\n", ADPT_ARG(adapter), get_hw_port(adapter));
+		rtw_warn_on(1);
+	}
+#endif
 }
+void rtw_hal_hw_port_disable(_adapter *adapter)
+{
+	u8 port_enable = _FALSE;
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_PORT_CFG, &port_enable);
+}
+
+void rtw_restore_hw_port_cfg(_adapter *adapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+
+#else
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface)
+			rtw_hal_hw_port_enable(iface);
+	}
+#endif
+}
+#endif
 
-void hal_init_macaddr(_adapter *adapter)
+void rtw_restore_mac_addr(_adapter *adapter)
 {
-	rtw_hal_set_hwreg(adapter, HW_VAR_MAC_ADDR, adapter_mac_addr(adapter));
-#ifdef  CONFIG_CONCURRENT_MODE
-	if (adapter->pbuddy_adapter)
-		rtw_hal_set_hwreg(adapter->pbuddy_adapter, HW_VAR_MAC_ADDR, adapter_mac_addr(adapter->pbuddy_adapter));
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_mbid_cam_restore(adapter);
+#else
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface)
+			rtw_hal_set_hwreg(iface, HW_VAR_MAC_ADDR, adapter_mac_addr(iface));
+	}
 #endif
+	if (1)
+		rtw_hal_dump_macaddr(RTW_DBGDUMP, adapter);
 }
 
 void rtw_init_hal_com_default_value(PADAPTER Adapter)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
+	struct registry_priv *regsty = adapter_to_regsty(Adapter);
 
 	pHalData->AntDetection = 1;
+	pHalData->antenna_test = _FALSE;
+	pHalData->RegIQKFWOffload = regsty->iqk_fw_offload;
+	pHalData->ch_switch_offload = regsty->ch_switch_offload;
 }
 
-/* 
-* C2H event format:
-* Field	 TRIGGER		CONTENT	   CMD_SEQ 	CMD_LEN		 CMD_ID
-* BITS	 [127:120]	[119:16]      [15:8]		  [7:4]	 	   [3:0]
-*/
-
+#ifdef CONFIG_FW_C2H_REG
 void c2h_evt_clear(_adapter *adapter)
 {
 	rtw_write8(adapter, REG_C2HEVT_CLEAR, C2H_EVT_HOST_CLOSE);
 }
 
-s32 c2h_evt_read(_adapter *adapter, u8 *buf)
+s32 c2h_evt_read_88xx(_adapter *adapter, u8 *buf)
 {
 	s32 ret = _FAIL;
-	struct c2h_evt_hdr *c2h_evt;
 	int i;
 	u8 trigger;
 
 	if (buf == NULL)
 		goto exit;
 
-#if defined (CONFIG_RTL8188E)
-
 	trigger = rtw_read8(adapter, REG_C2HEVT_CLEAR);
 
 	if (trigger == C2H_EVT_HOST_CLOSE) {
@@ -725,100 +1242,144 @@ s32 c2h_evt_read(_adapter *adapter, u8 *buf)
 		goto clear_evt; /* Not a valid value */
 	}
 
-	c2h_evt = (struct c2h_evt_hdr *)buf;
-
-	_rtw_memset(c2h_evt, 0, 16);
+	_rtw_memset(buf, 0, C2H_REG_LEN);
 
-	*buf = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL);
-	*(buf+1) = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL + 1);	
-
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_info_, "c2h_evt_read(): ",
-		&c2h_evt , sizeof(c2h_evt));
+	/* Read ID, LEN, SEQ */
+	SET_C2H_ID_88XX(buf, rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL));
+	SET_C2H_SEQ_88XX(buf, rtw_read8(adapter, REG_C2HEVT_CMD_SEQ_88XX));
+	SET_C2H_PLEN_88XX(buf, rtw_read8(adapter, REG_C2HEVT_CMD_LEN_88XX));
 
 	if (0) {
-		DBG_871X("%s id:%u, len:%u, seq:%u, trigger:0x%02x\n", __func__
-			, c2h_evt->id, c2h_evt->plen, c2h_evt->seq, trigger);
+		RTW_INFO("%s id=0x%02x, seq=%u, plen=%u, trigger=0x%02x\n", __func__
+			, C2H_ID_88XX(buf), C2H_SEQ_88XX(buf), C2H_PLEN_88XX(buf), trigger);
 	}
 
 	/* Read the content */
-	for (i = 0; i < c2h_evt->plen; i++)
-		c2h_evt->payload[i] = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL + 2 + i);
+	for (i = 0; i < C2H_PLEN_88XX(buf); i++)
+		*(C2H_PAYLOAD_88XX(buf) + i) = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL + 2 + i);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_info_, "c2h_evt_read(): Command Content:\n",
-		c2h_evt->payload, c2h_evt->plen);
+	RTW_DBG_DUMP("payload: ", C2H_PAYLOAD_88XX(buf), C2H_PLEN_88XX(buf));
 
 	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_clear(adapter);
-#endif
+
 exit:
 	return ret;
 }
+#endif /* CONFIG_FW_C2H_REG */
 
-/* 
-* C2H event format:
-* Field    TRIGGER    CMD_LEN    CONTENT    CMD_SEQ    CMD_ID
-* BITS    [127:120]   [119:112]    [111:16]	     [15:8]         [7:0]
-*/
-s32 c2h_evt_read_88xx(_adapter *adapter, u8 *buf)
+#ifdef CONFIG_FW_C2H_PKT
+#ifndef DBG_C2H_PKT_PRE_HDL
+#define DBG_C2H_PKT_PRE_HDL 0
+#endif
+#ifndef DBG_C2H_PKT_HDL
+#define DBG_C2H_PKT_HDL 0
+#endif
+void rtw_hal_c2h_pkt_pre_hdl(_adapter *adapter, u8 *buf, u16 len)
 {
+#ifdef RTW_HALMAC
+	/* TODO: extract hal_mac IC's code here*/
+#else
+	u8 parse_fail = 0;
+	u8 hdl_here = 0;
 	s32 ret = _FAIL;
-	struct c2h_evt_hdr_88xx *c2h_evt;
-	int i;
-	u8 trigger;
+	u8 id, seq, plen;
+	u8 *payload;
 
-	if (buf == NULL)
+	if (rtw_hal_c2h_pkt_hdr_parse(adapter, buf, len, &id, &seq, &plen, &payload) != _SUCCESS) {
+		parse_fail = 1;
 		goto exit;
+	}
 
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B)
-
-	trigger = rtw_read8(adapter, REG_C2HEVT_CLEAR);
+	hdl_here = rtw_hal_c2h_id_handle_directly(adapter, id, seq, plen, payload) == _TRUE ? 1 : 0;
+	if (hdl_here) 
+		ret = rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
+	else
+		ret = rtw_c2h_packet_wk_cmd(adapter, buf, len);
 
-	if (trigger == C2H_EVT_HOST_CLOSE) {
-		goto exit; /* Not ready */
-	} else if (trigger != C2H_EVT_FW_CLOSE) {
-		goto clear_evt; /* Not a valid value */
+exit:
+	if (parse_fail)
+		RTW_ERR("%s parse fail, buf=%p, len=:%u\n", __func__, buf, len);
+	else if (ret != _SUCCESS || DBG_C2H_PKT_PRE_HDL > 0) {
+		RTW_PRINT("%s: id=0x%02x, seq=%u, plen=%u, %s %s\n", __func__, id, seq, plen
+			, hdl_here ? "handle" : "enqueue"
+			, ret == _SUCCESS ? "ok" : "fail"
+		);
+		if (DBG_C2H_PKT_PRE_HDL >= 2)
+			RTW_PRINT_DUMP("dump: ", buf, len);
 	}
+#endif
+}
 
-	c2h_evt = (struct c2h_evt_hdr_88xx *)buf;
+void rtw_hal_c2h_pkt_hdl(_adapter *adapter, u8 *buf, u16 len)
+{
+#ifdef RTW_HALMAC
+	adapter->hal_func.hal_mac_c2h_handler(adapter, buf, len);
+#else
+	u8 parse_fail = 0;
+	u8 bypass = 0;
+	s32 ret = _FAIL;
+	u8 id, seq, plen;
+	u8 *payload;
 
-	_rtw_memset(c2h_evt, 0, 16);
+	if (rtw_hal_c2h_pkt_hdr_parse(adapter, buf, len, &id, &seq, &plen, &payload) != _SUCCESS) {
+		parse_fail = 1;
+		goto exit;
+	}
 
-	c2h_evt->id = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL);
-	c2h_evt->seq = rtw_read8(adapter, REG_C2HEVT_CMD_SEQ_88XX);
-	c2h_evt->plen = rtw_read8(adapter, REG_C2HEVT_CMD_LEN_88XX);
+#ifdef CONFIG_WOWLAN
+	if (adapter_to_pwrctl(adapter)->wowlan_mode == _TRUE) {
+		bypass = 1;
+		ret = _SUCCESS;
+		goto exit;
+	}
+#endif
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_info_, "c2h_evt_read(): ",
-		&c2h_evt , sizeof(c2h_evt));
+	ret = rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
 
-	if (0) {
-		DBG_871X("%s id:%u, len:%u, seq:%u, trigger:0x%02x\n", __func__
-			, c2h_evt->id, c2h_evt->plen, c2h_evt->seq, trigger);
+exit:
+	if (parse_fail)
+		RTW_ERR("%s parse fail, buf=%p, len=:%u\n", __func__, buf, len);
+	else if (ret != _SUCCESS || bypass || DBG_C2H_PKT_HDL > 0) {
+		RTW_PRINT("%s: id=0x%02x, seq=%u, plen=%u, %s %s\n", __func__, id, seq, plen
+			, !bypass ? "handle" : "bypass"
+			, ret == _SUCCESS ? "ok" : "fail"
+		);
+		if (DBG_C2H_PKT_HDL >= 2)
+			RTW_PRINT_DUMP("dump: ", buf, len);
 	}
+#endif
+}
+#endif /* CONFIG_FW_C2H_PKT */
 
-	/* Read the content */
-	for (i = 0; i < c2h_evt->plen; i++)
-		c2h_evt->payload[i] = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL + 2 + i);
+void c2h_iqk_offload(_adapter *adapter, u8 *data, u8 len)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct submit_ctx *iqk_sctx = &hal_data->iqk_sctx;
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_info_, "c2h_evt_read(): Command Content:\n",
-		c2h_evt->payload, c2h_evt->plen);
+	RTW_INFO("IQK offload finish in %dms\n", rtw_get_passing_time_ms(iqk_sctx->submit_time));
+	if (0)
+		RTW_INFO_DUMP("C2H_IQK_FINISH: ", data, len);
 
-	ret = _SUCCESS;
+	rtw_sctx_done(&iqk_sctx);
+}
 
-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_clear(adapter);
-#endif
-exit:
-	return ret;
+int c2h_iqk_offload_wait(_adapter *adapter, u32 timeout_ms)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct submit_ctx *iqk_sctx = &hal_data->iqk_sctx;
+
+	iqk_sctx->submit_time = rtw_get_current_time();
+	iqk_sctx->timeout_ms = timeout_ms;
+	iqk_sctx->status = RTW_SCTX_SUBMITTED;
+
+	return rtw_sctx_wait(iqk_sctx, __func__);
 }
 
 #define	GET_C2H_MAC_HIDDEN_RPT_UUID_X(_data)			LE_BITS_TO_1BYTE(((u8 *)(_data)) + 0, 0, 8)
@@ -831,7 +1392,6 @@ exit:
 #define	GET_C2H_MAC_HIDDEN_RPT_WL_FUNC(_data)			LE_BITS_TO_1BYTE(((u8 *)(_data)) + 5, 0, 4)
 #define	GET_C2H_MAC_HIDDEN_RPT_HW_STYPE(_data)			LE_BITS_TO_1BYTE(((u8 *)(_data)) + 5, 4, 4)
 #define	GET_C2H_MAC_HIDDEN_RPT_BW(_data)				LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 3)
-#define	GET_C2H_MAC_HIDDEN_RPT_FAB(_data)				LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 3, 2)
 #define	GET_C2H_MAC_HIDDEN_RPT_ANT_NUM(_data)			LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 5, 3)
 #define	GET_C2H_MAC_HIDDEN_RPT_80211_PROTOCOL(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 2, 2)
 #define	GET_C2H_MAC_HIDDEN_RPT_NIC_ROUTER(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 6, 2)
@@ -840,6 +1400,7 @@ exit:
 #define DBG_C2H_MAC_HIDDEN_RPT_HANDLE 0
 #endif
 
+#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
 int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 {
 	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
@@ -858,7 +1419,6 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 	u8 wl_func;
 	u8 hw_stype;
 	u8 bw;
-	u8 fab;
 	u8 ant_num;
 	u8 protocol;
 	u8 nic;
@@ -866,7 +1426,7 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 	int i;
 
 	if (len < MAC_HIDDEN_RPT_LEN) {
-		DBG_871X_LEVEL(_drv_warning_, "%s len(%u) < %d\n", __func__, len, MAC_HIDDEN_RPT_LEN);
+		RTW_WARN("%s len(%u) < %d\n", __func__, len, MAC_HIDDEN_RPT_LEN);
 		goto exit;
 	}
 
@@ -884,7 +1444,6 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 	hw_stype = GET_C2H_MAC_HIDDEN_RPT_HW_STYPE(data);
 
 	bw = GET_C2H_MAC_HIDDEN_RPT_BW(data);
-	fab = GET_C2H_MAC_HIDDEN_RPT_FAB(data);
 	ant_num = GET_C2H_MAC_HIDDEN_RPT_ANT_NUM(data);
 
 	protocol = GET_C2H_MAC_HIDDEN_RPT_80211_PROTOCOL(data);
@@ -892,19 +1451,18 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 
 	if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE) {
 		for (i = 0; i < len; i++)
-			DBG_871X("%s: 0x%02X\n", __func__, *(data + i));
+			RTW_PRINT("%s: 0x%02X\n", __func__, *(data + i));
 
-		DBG_871X("uuid x:0x%02x y:0x%02x z:0x%x crc:0x%x\n", uuid_x, uuid_y, uuid_z, uuid_crc);
-		DBG_871X("hci_type:0x%x\n", hci_type);
-		DBG_871X("package_type:0x%x\n", package_type);
-		DBG_871X("tr_switch:0x%x\n", tr_switch);
-		DBG_871X("wl_func:0x%x\n", wl_func);
-		DBG_871X("hw_stype:0x%x\n", hw_stype);
-		DBG_871X("bw:0x%x\n", bw);
-		DBG_871X("fab:0x%x\n", fab);
-		DBG_871X("ant_num:0x%x\n", ant_num);
-		DBG_871X("protocol:0x%x\n", protocol);
-		DBG_871X("nic:0x%x\n", nic);
+		RTW_PRINT("uuid x:0x%02x y:0x%02x z:0x%x crc:0x%x\n", uuid_x, uuid_y, uuid_z, uuid_crc);
+		RTW_PRINT("hci_type:0x%x\n", hci_type);
+		RTW_PRINT("package_type:0x%x\n", package_type);
+		RTW_PRINT("tr_switch:0x%x\n", tr_switch);
+		RTW_PRINT("wl_func:0x%x\n", wl_func);
+		RTW_PRINT("hw_stype:0x%x\n", hw_stype);
+		RTW_PRINT("bw:0x%x\n", bw);
+		RTW_PRINT("ant_num:0x%x\n", ant_num);
+		RTW_PRINT("protocol:0x%x\n", protocol);
+		RTW_PRINT("nic:0x%x\n", nic);
 	}
 
 	/*
@@ -916,11 +1474,12 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 	hal_data->PackageType = package_type;
 	hal_spec->wl_func &= mac_hidden_wl_func_to_hal_wl_func(wl_func);
 	hal_spec->bw_cap &= mac_hidden_max_bw_to_hal_bw_cap(bw);
-	hal_spec->nss_num = rtw_min(hal_spec->nss_num, ant_num);
+	hal_spec->tx_nss_num = rtw_min(hal_spec->tx_nss_num, ant_num);
+	hal_spec->rx_nss_num = rtw_min(hal_spec->rx_nss_num, ant_num);
 	hal_spec->proto_cap &= mac_hidden_proto_to_hal_proto_cap(protocol);
+	hal_spec->hci_type = hci_type;
 
 	/* TODO: tr_switch */
-	/* TODO: fab */
 
 	ret = _SUCCESS;
 
@@ -943,18 +1502,19 @@ int c2h_mac_hidden_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len)
 
 	if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE) {
 		for (i = 0; i < len; i++)
-			DBG_871X("%s: 0x%02X\n", __func__, *(data + i));
+			RTW_PRINT("%s: 0x%02X\n", __func__, *(data + i));
 	}
 
-	#ifdef CONFIG_RTL8188F
-	if (IS_8188F(hal_data->VersionID)) {
+	#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
+	if (IS_8188F(hal_data->version_id) || IS_8188GTV(hal_data->version_id)) {
 		#define GET_C2H_MAC_HIDDEN_RPT_IRV(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 0, 0, 4)
 		u8 irv = GET_C2H_MAC_HIDDEN_RPT_IRV(data);
 
 		if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE)
-			DBG_871X("irv:0x%x\n", irv);
+			RTW_PRINT("irv:0x%x\n", irv);
 
-		hal_data->VersionID.irv = irv;
+		if(irv != 0xf)
+			hal_data->version_id.CUTVersion = irv;
 	}
 	#endif
 
@@ -966,10 +1526,11 @@ exit:
 
 int hal_read_mac_hidden_rpt(_adapter *adapter)
 {
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(adapter);
 	int ret = _FAIL;
 	int ret_fwdl;
 	u8 mac_hidden_rpt[MAC_HIDDEN_RPT_LEN + MAC_HIDDEN_RPT_2_LEN] = {0};
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 	u32 cnt = 0;
 	u32 timeout_ms = 800;
 	u32 min_cnt = 10;
@@ -988,7 +1549,9 @@ int hal_read_mac_hidden_rpt(_adapter *adapter)
 	rtw_write8(adapter, REG_C2HEVT_MSG_NORMAL, C2H_DEFEATURE_RSVD);
 
 	/* download FW */
+	pHalData->not_xmitframe_fw_dl = 1;
 	ret_fwdl = rtw_hal_fw_dl(adapter, _FALSE);
+	pHalData->not_xmitframe_fw_dl = 0;
 	if (ret_fwdl != _SUCCESS)
 		goto mac_hidden_rpt_hdl;
 
@@ -1026,11 +1589,12 @@ exit:
 		rtw_hal_power_off(adapter);
 #endif
 
-	DBG_871X("%s %s! (%u, %dms), fwdl:%d, id:0x%02x\n", __func__
-		, (ret == _SUCCESS)?"OK":"Fail", cnt, rtw_get_passing_time_ms(start), ret_fwdl, id);
+	RTW_INFO("%s %s! (%u, %dms), fwdl:%d, id:0x%02x\n", __func__
+		, (ret == _SUCCESS) ? "OK" : "Fail", cnt, rtw_get_passing_time_ms(start), ret_fwdl, id);
 
 	return ret;
 }
+#endif /* CONFIG_RTW_MAC_HIDDEN_RPT */
 
 int c2h_defeature_dbg_hdl(_adapter *adapter, u8 *data, u8 len)
 {
@@ -1046,7 +1610,7 @@ int c2h_defeature_dbg_hdl(_adapter *adapter, u8 *data, u8 len)
 	}
 
 	for (i = 0; i < len; i++)
-		DBG_871X("%s: 0x%02X\n", __func__, *(data + i));
+		RTW_PRINT("%s: 0x%02X\n", __func__, *(data + i));
 
 	ret = _SUCCESS;
 	
@@ -1207,377 +1771,1401 @@ s32 rtw_hal_h2c_customer_str_write(_adapter *adapter, const u8 *cs)
 		goto exit;
 	}
 
-	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_CUSTOMER_STR_W3, H2C_CUSTOMER_STR_W3_LEN, h2c_data_w3);
-	if (ret != _SUCCESS) {
-		RTW_WARN("%s w3 fail\n", __func__);
+	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_CUSTOMER_STR_W3, H2C_CUSTOMER_STR_W3_LEN, h2c_data_w3);
+	if (ret != _SUCCESS) {
+		RTW_WARN("%s w3 fail\n", __func__);
+		goto exit;
+	}
+
+exit:
+	return ret;
+}
+
+/* write customer str and check if value reported is the same as requested */
+s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct submit_ctx sctx;
+	s32 ret = _SUCCESS;
+
+	_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
+	if (dvobj->customer_str_sctx != NULL)
+		ret = _FAIL;
+	else {
+		rtw_sctx_init(&sctx, 2 * 1000);
+		dvobj->customer_str_sctx = &sctx;
+	}
+	_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
+
+	if (ret == _FAIL) {
+		RTW_WARN("%s another handle ongoing\n", __func__);
+		goto exit;
+	}
+
+	ret = rtw_customer_str_write_cmd(adapter, cs);
+	if (ret != _SUCCESS) {
+		RTW_WARN("%s write cmd fail\n", __func__);
+		_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
+		dvobj->customer_str_sctx = NULL;
+		_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
+		goto exit;
+	}
+
+	ret = rtw_customer_str_req_cmd(adapter);
+	if (ret != _SUCCESS) {
+		RTW_WARN("%s read cmd fail\n", __func__);
+		_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
+		dvobj->customer_str_sctx = NULL;
+		_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
+		goto exit;
+	}
+
+	/* wait till rpt done or timeout */
+	rtw_sctx_wait(&sctx, __func__);
+
+	_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
+	dvobj->customer_str_sctx = NULL;
+	if (sctx.status == RTW_SCTX_DONE_SUCCESS) {
+		if (_rtw_memcmp(cs, dvobj->customer_str, RTW_CUSTOMER_STR_LEN) != _TRUE) {
+			RTW_WARN("%s read back check fail\n", __func__);
+			RTW_INFO_DUMP("write req: ", cs, RTW_CUSTOMER_STR_LEN);
+			RTW_INFO_DUMP("read back: ", dvobj->customer_str, RTW_CUSTOMER_STR_LEN);
+			ret = _FAIL;
+		}
+	} else
+		ret = _FAIL;
+	_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_RTW_CUSTOMER_STR */
+
+#ifdef RTW_PER_CMD_SUPPORT_FW
+#define H2C_REQ_PER_RPT_LEN 5
+#define SET_H2CCMD_REQ_PER_RPT_GROUP_MACID(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_REQ_PER_RPT_RPT_TYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_H2CCMD_REQ_PER_RPT_MACID_BMAP(__pH2CCmd, __Value)	SET_BITS_TO_LE_4BYTE(__pH2CCmd + 1, 0, 32, __Value)
+
+u8 rtw_hal_set_req_per_rpt_cmd(_adapter *adapter, u8 group_macid,
+				      u8 rpt_type, u32 macid_bitmap)
+{
+	u8 ret = _FAIL;
+	u8 cmd_buf[H2C_REQ_PER_RPT_LEN] = {0};
+
+	SET_H2CCMD_REQ_PER_RPT_GROUP_MACID(cmd_buf, group_macid);
+	SET_H2CCMD_REQ_PER_RPT_RPT_TYPE(cmd_buf, rpt_type);
+	SET_H2CCMD_REQ_PER_RPT_MACID_BMAP(cmd_buf, macid_bitmap);
+
+	ret = rtw_hal_fill_h2c_cmd(adapter, 
+				   H2C_REQ_PER_RPT, 
+				   H2C_REQ_PER_RPT_LEN, 
+				   cmd_buf);
+	return ret;
+}
+
+#define	GET_C2H_PER_RATE_RPT_TYPE0_MACID0(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)), 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_PER0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 1, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_RATE0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 2, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_BW0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 3, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT0(_data)	LE_BITS_TO_2BYTE(((u8 *)(_data)) + 4, 0, 16)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_MACID1(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_PER1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_RATE1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 8, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_BW1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 9, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT1(_data)	LE_BITS_TO_2BYTE(((u8 *)(_data)) + 10, 0, 16)
+
+#define	GET_C2H_PER_RATE_RPT_TYPE1_MACID0(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)), 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_PER0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 1, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_RATE0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 2, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_BW0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 3, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_MACID1(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 4, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_PER1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 5, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_RATE1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_BW1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_MACID2(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 8, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_PER2(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 9, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_RATE2(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 10, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_BW2(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 11, 0, 2)
+
+static void per_rate_rpt_update(_adapter *adapter, u8 mac_id,
+				u8 per, u8 rate,
+				u8 bw, u8 total_pkt)
+{
+#ifdef CONFIG_RTW_MESH
+	rtw_ieee80211s_update_metric(adapter, mac_id,
+				     per, rate,
+				     bw, total_pkt);
+#endif
+}
+
+int c2h_per_rate_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
+{
+	/* Now only consider type0, since it covers all params in type1
+	 * type0: mac_id, per, rate, bw, total_pkt
+	 * type1: mac_id, per, rate, bw
+	 */
+	u8 mac_id[2] = {0}, per[2] = {0}, rate[2] = {0}, bw[2] = {0};
+	u16 total_pkt[2] = {0};
+	int ret = _FAIL, i, macid_cnt = 0;
+
+	/* type0:
+	 * 1 macid includes   6 bytes info + 1 byte 0xff
+	 * 2 macid includes 2*6 bytes info
+	 */
+	if (!(len == 7 || len == 12)) {
+		RTW_WARN("%s len(%u) != 7 or 12\n", __FUNCTION__, len);
+		goto exit;
+	}
+
+	macid_cnt++;
+	mac_id[0] = GET_C2H_PER_RATE_RPT_TYPE0_MACID0(data);
+	per[0] = GET_C2H_PER_RATE_RPT_TYPE0_PER0(data);
+	rate[0] = GET_C2H_PER_RATE_RPT_TYPE0_RATE0(data);
+	bw[0] = GET_C2H_PER_RATE_RPT_TYPE0_BW0(data);
+	total_pkt[0] = GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT0(data);
+
+	mac_id[1] = GET_C2H_PER_RATE_RPT_TYPE0_MACID1(data);
+	/* 0xff means no report anymore */
+	if (mac_id[1] == 0xff)
+		goto update_per;
+	if (len != 12) {
+		RTW_WARN("%s incorrect format\n", __FUNCTION__);
+		goto exit;
+	}
+	macid_cnt++;
+	per[1] = GET_C2H_PER_RATE_RPT_TYPE0_PER1(data);
+	rate[1] = GET_C2H_PER_RATE_RPT_TYPE0_RATE1(data);
+	bw[1] = GET_C2H_PER_RATE_RPT_TYPE0_BW1(data);
+	total_pkt[1] = GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT1(data);
+
+update_per:
+	for (i = 0; i < macid_cnt; i++) {
+		RTW_DBG("[%s] type0 rpt[%d]: macid = %u, per = %u, "
+			"rate = %u, bw = %u, total_pkt = %u\n",
+			__FUNCTION__, i, mac_id[i], per[i],
+			rate[i], bw[i], total_pkt[i]);
+		per_rate_rpt_update(adapter, mac_id[i],
+				    per[i], rate[i],
+				    bw[i], total_pkt[i]);
+	}
+	ret = _SUCCESS;
+exit:
+	return ret;
+}
+#endif /* RTW_PER_CMD_SUPPORT_FW */
+
+void rtw_hal_update_sta_wset(_adapter *adapter, struct sta_info *psta)
+{
+	u8 w_set = 0;
+
+	if (psta->wireless_mode & WIRELESS_11B)
+		w_set |= WIRELESS_CCK;
+
+	if ((psta->wireless_mode & WIRELESS_11G) || (psta->wireless_mode & WIRELESS_11A))
+		w_set |= WIRELESS_OFDM;
+
+	if (psta->wireless_mode & WIRELESS_11_24N)
+		w_set |= WIRELESS_HT;
+
+	if ((psta->wireless_mode & WIRELESS_11AC) || (psta->wireless_mode & WIRELESS_11_5N))
+		w_set |= WIRELESS_VHT;
+
+	psta->cmn.support_wireless_set = w_set;
+}
+
+void rtw_hal_update_sta_mimo_type(_adapter *adapter, struct sta_info *psta)
+{
+	s8 tx_nss, rx_nss;
+
+	tx_nss = rtw_get_sta_tx_nss(adapter, psta);
+	rx_nss =  rtw_get_sta_rx_nss(adapter, psta);
+	if ((tx_nss == 1) && (rx_nss == 1))
+		psta->cmn.mimo_type = RF_1T1R;
+	else if ((tx_nss == 1) && (rx_nss == 2))
+		psta->cmn.mimo_type = RF_1T2R;
+	else if ((tx_nss == 2) && (rx_nss == 2))
+		psta->cmn.mimo_type = RF_2T2R;
+	else if ((tx_nss == 2) && (rx_nss == 3))
+		psta->cmn.mimo_type = RF_2T3R;
+	else if ((tx_nss == 2) && (rx_nss == 4))
+		psta->cmn.mimo_type = RF_2T4R;
+	else if ((tx_nss == 3) && (rx_nss == 3))
+		psta->cmn.mimo_type = RF_3T3R;
+	else if ((tx_nss == 3) && (rx_nss == 4))
+		psta->cmn.mimo_type = RF_3T4R;
+	else if ((tx_nss == 4) && (rx_nss == 4))
+		psta->cmn.mimo_type = RF_4T4R;
+	else
+		rtw_warn_on(1);
+
+	RTW_INFO("STA - MAC_ID:%d, Tx - %d SS, Rx - %d SS\n",
+			psta->cmn.mac_id, tx_nss, rx_nss);
+}
+
+void rtw_hal_update_sta_smps_cap(_adapter *adapter, struct sta_info *psta)
+{
+	/*Spatial Multiplexing Power Save*/
+#if 0
+	if (check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _TRUE) {
+		#ifdef CONFIG_80211N_HT
+		if (psta->htpriv.ht_option) {
+			if (psta->htpriv.smps_cap == 0)
+				psta->cmn.sm_ps = SM_PS_STATIC;
+			else if (psta->htpriv.smps_cap == 1)
+				psta->cmn.sm_ps = SM_PS_DYNAMIC;
+			else
+				psta->cmn.sm_ps = SM_PS_DISABLE;
+		}
+		#endif /* CONFIG_80211N_HT */
+	} else
+#endif
+		psta->cmn.sm_ps = SM_PS_DISABLE;
+
+	RTW_INFO("STA - MAC_ID:%d, SM_PS %d\n",
+			psta->cmn.mac_id, psta->cmn.sm_ps);
+}
+
+u8 rtw_get_mgntframe_raid(_adapter *adapter, unsigned char network_type)
+{
+
+	u8 raid;
+	if (IS_NEW_GENERATION_IC(adapter)) {
+
+		raid = (network_type & WIRELESS_11B)	? RATEID_IDX_B
+		       : RATEID_IDX_G;
+	} else {
+		raid = (network_type & WIRELESS_11B)	? RATR_INX_WIRELESS_B
+		       : RATR_INX_WIRELESS_G;
+	}
+	return raid;
+}
+
+void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	u8 i, rf_type, tx_nss;
+	u64 tx_ra_bitmap = 0;
+
+	if (psta == NULL)
+		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_value(psta->bssrateset[i] & 0x7f);
+	}
+
+#ifdef CONFIG_80211N_HT
+	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+	tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
+#ifdef CONFIG_80211AC_VHT
+	if (psta->vhtpriv.vht_option) {
+		/* AC mode ra_bitmap */
+		tx_ra_bitmap |= (rtw_vht_mcs_map_to_bitmap(psta->vhtpriv.vht_mcs_map, tx_nss) << 12);
+	} else
+#endif /* CONFIG_80211AC_VHT */
+	if (psta->htpriv.ht_option) {
+		/* n mode ra_bitmap */
+
+		/* Handling SMPS mode for AP MODE only*/
+		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE) {
+			/*0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
+			if (psta->htpriv.smps_cap == 0 || psta->htpriv.smps_cap == 1) {
+				/*operate with only one active receive chain // 11n-MCS rate <= MSC7*/
+				tx_nss = rtw_min(tx_nss, 1);
+			}
+		}
+
+		tx_ra_bitmap |= (rtw_ht_mcs_set_to_bitmap(psta->htpriv.ht_cap.supp_mcs_set, tx_nss) << 12);
+	}
+#endif /* CONFIG_80211N_HT */
+	psta->cmn.ra_info.ramask = tx_ra_bitmap;
+	psta->init_rate = get_highest_rate_idx(tx_ra_bitmap) & 0x3f;
+}
+
+void rtw_hal_update_sta_ra_info(PADAPTER padapter, struct sta_info *psta)
+{
+	rtw_hal_update_sta_mimo_type(padapter, psta);
+	rtw_hal_update_sta_smps_cap(padapter, psta);
+	rtw_hal_update_sta_rate_mask(padapter, psta);
+}
+
+#ifndef SEC_CAM_ACCESS_TIMEOUT_MS
+	#define SEC_CAM_ACCESS_TIMEOUT_MS 200
+#endif
+
+#ifndef DBG_SEC_CAM_ACCESS
+	#define DBG_SEC_CAM_ACCESS 0
+#endif
+
+u32 rtw_sec_read_cam(_adapter *adapter, u8 addr)
+{
+	_mutex *mutex = &adapter_to_dvobj(adapter)->cam_ctl.sec_cam_access_mutex;
+	u32 rdata;
+	u32 cnt = 0;
+	systime start = 0, end = 0;
+	u8 timeout = 0;
+	u8 sr = 0;
+
+	_enter_critical_mutex(mutex, NULL);
+
+	rtw_write32(adapter, REG_CAMCMD, CAM_POLLINIG | addr);
+
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(adapter)) {
+			sr = 1;
+			break;
+		}
+
+		cnt++;
+		if (0 == (rtw_read32(adapter, REG_CAMCMD) & CAM_POLLINIG))
+			break;
+
+		if (rtw_get_passing_time_ms(start) > SEC_CAM_ACCESS_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+	end = rtw_get_current_time();
+
+	rdata = rtw_read32(adapter, REG_CAMREAD);
+
+	_exit_critical_mutex(mutex, NULL);
+
+	if (DBG_SEC_CAM_ACCESS || timeout) {
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%02x, rdata:0x%08x, to:%u, polling:%u, %d ms\n"
+			, FUNC_ADPT_ARG(adapter), addr, rdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
+	}
+
+	return rdata;
+}
+
+void rtw_sec_write_cam(_adapter *adapter, u8 addr, u32 wdata)
+{
+	_mutex *mutex = &adapter_to_dvobj(adapter)->cam_ctl.sec_cam_access_mutex;
+	u32 cnt = 0;
+	systime start = 0, end = 0;
+	u8 timeout = 0;
+	u8 sr = 0;
+
+	_enter_critical_mutex(mutex, NULL);
+
+	rtw_write32(adapter, REG_CAMWRITE, wdata);
+	rtw_write32(adapter, REG_CAMCMD, CAM_POLLINIG | CAM_WRITE | addr);
+
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(adapter)) {
+			sr = 1;
+			break;
+		}
+
+		cnt++;
+		if (0 == (rtw_read32(adapter, REG_CAMCMD) & CAM_POLLINIG))
+			break;
+
+		if (rtw_get_passing_time_ms(start) > SEC_CAM_ACCESS_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+	end = rtw_get_current_time();
+
+	_exit_critical_mutex(mutex, NULL);
+
+	if (DBG_SEC_CAM_ACCESS || timeout) {
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%02x, wdata:0x%08x, to:%u, polling:%u, %d ms\n"
+			, FUNC_ADPT_ARG(adapter), addr, wdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
+	}
+}
+
+void rtw_sec_read_cam_ent(_adapter *adapter, u8 id, u8 *ctrl, u8 *mac, u8 *key)
+{
+	unsigned int val, addr;
+	u8 i;
+	u32 rdata;
+	u8 begin = 0;
+	u8 end = 5; /* TODO: consider other key length accordingly */
+
+	if (!ctrl && !mac && !key) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	/* TODO: check id range */
+
+	if (!ctrl && !mac)
+		begin = 2; /* read from key */
+
+	if (!key && !mac)
+		end = 0; /* read to ctrl */
+	else if (!key)
+		end = 2; /* read to mac */
+
+	for (i = begin; i <= end; i++) {
+		rdata = rtw_sec_read_cam(adapter, (id << 3) | i);
+
+		switch (i) {
+		case 0:
+			if (ctrl)
+				_rtw_memcpy(ctrl, (u8 *)(&rdata), 2);
+			if (mac)
+				_rtw_memcpy(mac, ((u8 *)(&rdata)) + 2, 2);
+			break;
+		case 1:
+			if (mac)
+				_rtw_memcpy(mac + 2, (u8 *)(&rdata), 4);
+			break;
+		default:
+			if (key)
+				_rtw_memcpy(key + (i - 2) * 4, (u8 *)(&rdata), 4);
+			break;
+		}
+	}
+
+exit:
+	return;
+}
+
+
+void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
+{
+	unsigned int i;
+	int j;
+	u8 addr;
+	u32 wdata;
+
+	/* TODO: consider other key length accordingly */
+#if 0
+	switch ((ctrl & 0x1c) >> 2) {
+	case _WEP40_:
+	case _TKIP_:
+	case _AES_:
+	case _WEP104_:
+
+	}
+#else
+	j = 7;
+#endif
+
+	for (; j >= 0; j--) {
+		switch (j) {
+		case 0:
+			wdata = (ctrl | (mac[0] << 16) | (mac[1] << 24));
+			break;
+		case 1:
+			wdata = (mac[2] | (mac[3] << 8) | (mac[4] << 16) | (mac[5] << 24));
+			break;
+		case 6:
+		case 7:
+			wdata = 0;
+			break;
+		default:
+			i = (j - 2) << 2;
+			wdata = (key[i] | (key[i + 1] << 8) | (key[i + 2] << 16) | (key[i + 3] << 24));
+			break;
+		}
+
+		addr = (id << 3) + j;
+
+		rtw_sec_write_cam(adapter, addr, wdata);
+	}
+}
+
+void rtw_sec_clr_cam_ent(_adapter *adapter, u8 id)
+{
+	u8 addr;
+
+	addr = (id << 3);
+	rtw_sec_write_cam(adapter, addr, 0);
+}
+
+bool rtw_sec_read_cam_is_gk(_adapter *adapter, u8 id)
+{
+	bool res;
+	u16 ctrl;
+
+	rtw_sec_read_cam_ent(adapter, id, (u8 *)&ctrl, NULL, NULL);
+
+	res = (ctrl & BIT6) ? _TRUE : _FALSE;
+	return res;
+}
+#ifdef CONFIG_MBSSID_CAM
+void rtw_mbid_cam_init(struct dvobj_priv *dvobj)
+{
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	_rtw_spinlock_init(&mbid_cam_ctl->lock);
+	mbid_cam_ctl->bitmap = 0;
+	ATOMIC_SET(&mbid_cam_ctl->mbid_entry_num, 0);
+	_rtw_memset(&dvobj->mbid_cam_cache, 0, sizeof(dvobj->mbid_cam_cache));
+}
+
+void rtw_mbid_cam_deinit(struct dvobj_priv *dvobj)
+{
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	_rtw_spinlock_free(&mbid_cam_ctl->lock);
+}
+
+void rtw_mbid_cam_reset(_adapter *adapter)
+{
+	_irqL irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	mbid_cam_ctl->bitmap = 0;
+	_rtw_memset(&dvobj->mbid_cam_cache, 0, sizeof(dvobj->mbid_cam_cache));
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
+
+	ATOMIC_SET(&mbid_cam_ctl->mbid_entry_num, 0);
+}
+static u8 _rtw_mbid_cam_search_by_macaddr(_adapter *adapter, u8 *mac_addr)
+{
+	u8 i;
+	u8 cam_id = INVALID_CAM_ID;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
+		if (mac_addr && _rtw_memcmp(dvobj->mbid_cam_cache[i].mac_addr, mac_addr, ETH_ALEN) == _TRUE) {
+			cam_id = i;
+			break;
+		}
+	}
+
+	RTW_INFO("%s mac:"MAC_FMT" - cam_id:%d\n", __func__, MAC_ARG(mac_addr), cam_id);
+	return cam_id;
+}
+
+u8 rtw_mbid_cam_search_by_macaddr(_adapter *adapter, u8 *mac_addr)
+{
+	_irqL irqL;
+
+	u8 cam_id = INVALID_CAM_ID;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	cam_id = _rtw_mbid_cam_search_by_macaddr(adapter, mac_addr);
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
+
+	return cam_id;
+}
+static u8 _rtw_mbid_cam_search_by_ifaceid(_adapter *adapter, u8 iface_id)
+{
+	u8 i;
+	u8 cam_id = INVALID_CAM_ID;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
+		if (iface_id == dvobj->mbid_cam_cache[i].iface_id) {
+			cam_id = i;
+			break;
+		}
+	}
+	if (cam_id != INVALID_CAM_ID)
+		RTW_INFO("%s iface_id:%d mac:"MAC_FMT" - cam_id:%d\n",
+			__func__, iface_id, MAC_ARG(dvobj->mbid_cam_cache[cam_id].mac_addr), cam_id);
+
+	return cam_id;
+}
+
+u8 rtw_mbid_cam_search_by_ifaceid(_adapter *adapter, u8 iface_id)
+{
+	_irqL irqL;
+	u8 cam_id = INVALID_CAM_ID;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	cam_id = _rtw_mbid_cam_search_by_ifaceid(adapter, iface_id);
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
+
+	return cam_id;
+}
+u8 rtw_get_max_mbid_cam_id(_adapter *adapter)
+{
+	_irqL irqL;
+	s8 i;
+	u8 cam_id = INVALID_CAM_ID;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	for (i = (TOTAL_MBID_CAM_NUM - 1); i >= 0; i--) {
+		if (mbid_cam_ctl->bitmap & BIT(i)) {
+			cam_id = i;
+			break;
+		}
+	}
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	/*RTW_INFO("%s max cam_id:%d\n", __func__, cam_id);*/
+	return cam_id;
+}
+
+inline u8 rtw_get_mbid_cam_entry_num(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	return ATOMIC_READ(&mbid_cam_ctl->mbid_entry_num);
+}
+
+static inline void mbid_cam_cache_init(_adapter *adapter, struct mbid_cam_cache *pmbid_cam, u8 *mac_addr)
+{
+	if (adapter && pmbid_cam && mac_addr) {
+		_rtw_memcpy(pmbid_cam->mac_addr, mac_addr, ETH_ALEN);
+		pmbid_cam->iface_id = adapter->iface_id;
+	}
+}
+static inline void mbid_cam_cache_clr(struct mbid_cam_cache *pmbid_cam)
+{
+	if (pmbid_cam) {
+		_rtw_memset(pmbid_cam->mac_addr, 0, ETH_ALEN);
+		pmbid_cam->iface_id = CONFIG_IFACE_NUMBER;
+	}
+}
+
+u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr)
+{
+	_irqL irqL;
+	u8 cam_id = INVALID_CAM_ID, i;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+	u8 entry_num = ATOMIC_READ(&mbid_cam_ctl->mbid_entry_num);
+
+	if (entry_num >= TOTAL_MBID_CAM_NUM) {
+		RTW_INFO(FUNC_ADPT_FMT" failed !! MBSSID number :%d over TOTAL_CAM_ENTRY(8)\n", FUNC_ADPT_ARG(adapter), entry_num);
+		rtw_warn_on(1);
+	}
+
+	if (INVALID_CAM_ID != rtw_mbid_cam_search_by_macaddr(adapter, mac_addr))
 		goto exit;
+
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
+		if (!(mbid_cam_ctl->bitmap & BIT(i))) {
+			mbid_cam_ctl->bitmap |= BIT(i);
+			cam_id = i;
+			break;
+		}
 	}
+	if ((cam_id != INVALID_CAM_ID) && (mac_addr))
+		mbid_cam_cache_init(adapter, &dvobj->mbid_cam_cache[cam_id], mac_addr);
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
 
+	if (cam_id != INVALID_CAM_ID) {
+		ATOMIC_INC(&mbid_cam_ctl->mbid_entry_num);
+		RTW_INFO("%s mac:"MAC_FMT" - cam_id:%d\n", __func__, MAC_ARG(mac_addr), cam_id);
+#ifdef DBG_MBID_CAM_DUMP
+		rtw_mbid_cam_cache_dump(RTW_DBGDUMP, __func__, adapter);
+#endif
+	} else
+		RTW_INFO("%s [WARN] "MAC_FMT" - invalid cam_id:%d\n", __func__, MAC_ARG(mac_addr), cam_id);
 exit:
-	return ret;
+	return cam_id;
 }
 
-/* write customer str and check if value reported is the same as requested */
-s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs)
+u8 rtw_mbid_cam_info_change(_adapter *adapter, u8 *mac_addr)
 {
+	_irqL irqL;
+	u8 entry_id = INVALID_CAM_ID;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct submit_ctx sctx;
-	s32 ret = _SUCCESS;
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
 
-	_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
-	if (dvobj->customer_str_sctx != NULL)
-		ret = _FAIL;
-	else {
-		rtw_sctx_init(&sctx, 2 * 1000);
-		dvobj->customer_str_sctx = &sctx;
-	}
-	_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	entry_id = _rtw_mbid_cam_search_by_ifaceid(adapter, adapter->iface_id);
+	if (entry_id != INVALID_CAM_ID)
+		mbid_cam_cache_init(adapter, &dvobj->mbid_cam_cache[entry_id], mac_addr);
 
-	if (ret == _FAIL) {
-		RTW_WARN("%s another handle ongoing\n", __func__);
-		goto exit;
-	}
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
 
-	ret = rtw_customer_str_write_cmd(adapter, cs);
-	if (ret != _SUCCESS) {
-		RTW_WARN("%s write cmd fail\n", __func__);
-		_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
-		dvobj->customer_str_sctx = NULL;
-		_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
-		goto exit;
-	}
+	return entry_id;
+}
 
-	ret = rtw_customer_str_req_cmd(adapter);
-	if (ret != _SUCCESS) {
-		RTW_WARN("%s read cmd fail\n", __func__);
-		_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
-		dvobj->customer_str_sctx = NULL;
-		_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
-		goto exit;
-	}
+u8 rtw_mbid_cam_assign(_adapter *adapter, u8 *mac_addr, u8 camid)
+{
+	_irqL irqL;
+	u8 ret = _FALSE;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
 
-	/* wait till rpt done or timeout */
-	rtw_sctx_wait(&sctx, __func__);
+	if ((camid >= TOTAL_MBID_CAM_NUM) || (camid == INVALID_CAM_ID)) {
+		RTW_INFO(FUNC_ADPT_FMT" failed !! invlaid mbid_canid :%d\n", FUNC_ADPT_ARG(adapter), camid);
+		rtw_warn_on(1);
+	}
+	if (INVALID_CAM_ID != rtw_mbid_cam_search_by_macaddr(adapter, mac_addr))
+		goto exit;
 
-	_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
-	dvobj->customer_str_sctx = NULL;
-	if (sctx.status == RTW_SCTX_DONE_SUCCESS) {
-		if (_rtw_memcmp(cs, dvobj->customer_str, RTW_CUSTOMER_STR_LEN) != _TRUE) {
-			RTW_WARN("%s read back check fail\n", __func__);
-			RTW_INFO_DUMP("write req: ", cs, RTW_CUSTOMER_STR_LEN);
-			RTW_INFO_DUMP("read back: ", dvobj->customer_str, RTW_CUSTOMER_STR_LEN);
-			ret = _FAIL;
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	if (!(mbid_cam_ctl->bitmap & BIT(camid))) {
+		if (mac_addr) {
+			mbid_cam_ctl->bitmap |= BIT(camid);
+			mbid_cam_cache_init(adapter, &dvobj->mbid_cam_cache[camid], mac_addr);
+			ret = _TRUE;
 		}
+	}
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
+
+	if (ret == _TRUE) {
+		ATOMIC_INC(&mbid_cam_ctl->mbid_entry_num);
+		RTW_INFO("%s mac:"MAC_FMT" - cam_id:%d\n", __func__, MAC_ARG(mac_addr), camid);
+#ifdef DBG_MBID_CAM_DUMP
+		rtw_mbid_cam_cache_dump(RTW_DBGDUMP, __func__, adapter);
+#endif
 	} else
-		ret = _FAIL;
-	_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
+		RTW_INFO("%s  [WARN] mac:"MAC_FMT" - cam_id:%d assigned failed\n", __func__, MAC_ARG(mac_addr), camid);
 
 exit:
 	return ret;
 }
-#endif /* CONFIG_RTW_CUSTOMER_STR */
 
-u8  rtw_hal_networktype_to_raid(_adapter *adapter, struct sta_info *psta)
+void rtw_mbid_camid_clean(_adapter *adapter, u8 mbss_canid)
 {
-	if(IS_NEW_GENERATION_IC(adapter)){
-		return networktype_to_raid_ex(adapter,psta);
-	}
-	else{
-		return networktype_to_raid(adapter,psta);
-	}
+	_irqL irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
 
+	if ((mbss_canid >= TOTAL_MBID_CAM_NUM) || (mbss_canid == INVALID_CAM_ID)) {
+		RTW_INFO(FUNC_ADPT_FMT" failed !! invlaid mbid_canid :%d\n", FUNC_ADPT_ARG(adapter), mbss_canid);
+		rtw_warn_on(1);
+	}
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	mbid_cam_cache_clr(&dvobj->mbid_cam_cache[mbss_canid]);
+	mbid_cam_ctl->bitmap &= (~BIT(mbss_canid));
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	ATOMIC_DEC(&mbid_cam_ctl->mbid_entry_num);
+	RTW_INFO("%s - cam_id:%d\n", __func__, mbss_canid);
 }
-u8 rtw_get_mgntframe_raid(_adapter *adapter,unsigned char network_type)
-{	
+int rtw_mbid_cam_cache_dump(void *sel, const char *fun_name, _adapter *adapter)
+{
+	_irqL irqL;
+	u8 i;
+	_adapter *iface;
+	u8 iface_id;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+	u8 entry_num = ATOMIC_READ(&mbid_cam_ctl->mbid_entry_num);
+	u8 max_cam_id = rtw_get_max_mbid_cam_id(adapter);
+
+	RTW_PRINT_SEL(sel, "== MBSSID CAM DUMP (%s)==\n", fun_name);
+
+	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	RTW_PRINT_SEL(sel, "Entry numbers:%d, max_camid:%d, bitmap:0x%08x\n", entry_num, max_cam_id, mbid_cam_ctl->bitmap);
+	for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
+		RTW_PRINT_SEL(sel, "CAM_ID = %d\t", i);
+
+		if (mbid_cam_ctl->bitmap & BIT(i)) {
+			iface_id = dvobj->mbid_cam_cache[i].iface_id;
+			RTW_PRINT_SEL(sel, "IF_ID:%d\t", iface_id);
+			RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\t", MAC_ARG(dvobj->mbid_cam_cache[i].mac_addr));
+
+			iface = dvobj->padapters[iface_id];
+			if (iface) {
+				if (MLME_IS_STA(iface))
+					RTW_PRINT_SEL(sel, "ROLE:%s\n", "STA");
+				else if (MLME_IS_AP(iface))
+					RTW_PRINT_SEL(sel, "ROLE:%s\n", "AP");
+				else if (MLME_IS_MESH(iface))
+					RTW_PRINT_SEL(sel, "ROLE:%s\n", "MESH");
+				else
+					RTW_PRINT_SEL(sel, "ROLE:%s\n", "NONE");
+			}
 
-	u8 raid;
-	if(IS_NEW_GENERATION_IC(adapter)){
-		
-		raid = (network_type & WIRELESS_11B)	?RATEID_IDX_B
-											:RATEID_IDX_G;		
+		} else
+			RTW_PRINT_SEL(sel, "N/A\n");
 	}
-	else{
-		raid = (network_type & WIRELESS_11B)	?RATR_INX_WIRELESS_B
-											:RATR_INX_WIRELESS_G;		
-	}	
-	return raid;
+	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
+	return 0;
 }
 
-void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta)
+static void read_mbssid_cam(_adapter *padapter, u8 cam_addr, u8 *mac)
 {
-	u8	i, rf_type, limit;
-	u64	tx_ra_bitmap;
+	u8 poll = 1;
+	u8 cam_ready = _FALSE;
+	u32 cam_data1 = 0;
+	u16 cam_data2 = 0;
 
-	if(psta == NULL)
-	{
+	if (RTW_CANNOT_RUN(padapter))
 		return;
-	}
 
-	tx_ra_bitmap = 0;
+	rtw_write32(padapter, REG_MBIDCAMCFG_2, BIT_MBIDCAM_POLL | ((cam_addr & MBIDCAM_ADDR_MASK) << MBIDCAM_ADDR_SHIFT));
 
-	//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_value(psta->bssrateset[i]&0x7f);
+	do {
+		if (0 == (rtw_read32(padapter, REG_MBIDCAMCFG_2) & BIT_MBIDCAM_POLL)) {
+			cam_ready = _TRUE;
+			break;
+		}
+		poll++;
+	} while ((poll % 10) != 0 && !RTW_CANNOT_RUN(padapter));
+
+	if (cam_ready) {
+		cam_data1 = rtw_read32(padapter, REG_MBIDCAMCFG_1);
+		mac[0] = cam_data1 & 0xFF;
+		mac[1] = (cam_data1 >> 8) & 0xFF;
+		mac[2] = (cam_data1 >> 16) & 0xFF;
+		mac[3] = (cam_data1 >> 24) & 0xFF;
+
+		cam_data2 = rtw_read16(padapter, REG_MBIDCAMCFG_2);
+		mac[4] = cam_data2 & 0xFF;
+		mac[5] = (cam_data2 >> 8) & 0xFF;
 	}
 
-#ifdef CONFIG_80211N_HT
-#ifdef CONFIG_80211AC_VHT
-	//AC mode ra_bitmap
-	if(psta->vhtpriv.vht_option) 
-	{
-		tx_ra_bitmap |= (rtw_vht_rate_to_bitmap(psta->vhtpriv.vht_mcs_map) << 12);
+}
+int rtw_mbid_cam_dump(void *sel, const char *fun_name, _adapter *adapter)
+{
+	/*_irqL irqL;*/
+	u8 i;
+	u8 mac_addr[ETH_ALEN];
+
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
+
+	RTW_PRINT_SEL(sel, "\n== MBSSID HW-CAM DUMP (%s)==\n", fun_name);
+
+	/*_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);*/
+	for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
+		RTW_PRINT_SEL(sel, "CAM_ID = %d\t", i);
+		_rtw_memset(mac_addr, 0, ETH_ALEN);
+		read_mbssid_cam(adapter, i, mac_addr);
+		RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\n", MAC_ARG(mac_addr));
 	}
-	else
-#endif //CONFIG_80211AC_VHT
-	{
-		//n mode ra_bitmap
-		if(psta->htpriv.ht_option)
-		{
-			rf_type = RF_1T1R;
-			rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-			if(rf_type == RF_2T2R)
-				limit=16;// 2R
-			else if(rf_type == RF_3T3R)
-				limit=24;// 3R
-			else
-				limit=8;//  1R
+	/*_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);*/
+	return 0;
+}
 
+static void write_mbssid_cam(_adapter *padapter, u8 cam_addr, u8 *mac)
+{
+	u32	cam_val[2] = {0};
 
-			/* Handling SMPS mode for AP MODE only*/
-			if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE) {
-				/*0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
-				if (psta->htpriv.smps_cap == 0 || psta->htpriv.smps_cap == 1) {
-					/*operate with only one active receive chain // 11n-MCS rate <= MSC7*/
-					limit = 8;/*  1R*/
-				}
-			}
+	cam_val[0] = (mac[3] << 24) | (mac[2] << 16) | (mac[1] << 8) | mac[0];
+	cam_val[1] = ((cam_addr & MBIDCAM_ADDR_MASK) << MBIDCAM_ADDR_SHIFT)  | (mac[5] << 8) | mac[4];
 
-			for (i=0; i<limit; i++) {
-				if (psta->htpriv.ht_cap.supp_mcs_set[i/8] & BIT(i%8))
-					tx_ra_bitmap |= BIT(i+12);
-			}
-		}
+	rtw_hal_set_hwreg(padapter, HW_VAR_MBSSID_CAM_WRITE, (u8 *)cam_val);
+}
+
+static void clear_mbssid_cam(_adapter *padapter, u8 cam_addr)
+{
+	rtw_hal_set_hwreg(padapter, HW_VAR_MBSSID_CAM_CLEAR, &cam_addr);
+}
+static void enable_mbssid_cam(_adapter *adapter)
+{
+	u8 max_cam_id = rtw_get_max_mbid_cam_id(adapter);
+	/*enable MBSSID*/
+	rtw_hal_rcr_add(adapter, RCR_ENMBID);
+	if (max_cam_id != INVALID_CAM_ID) {
+		rtw_write8(adapter, REG_MBID_NUM,
+			((rtw_read8(adapter, REG_MBID_NUM) & 0xF8) | ((max_cam_id -1) & 0x07)));
 	}
-#endif //CONFIG_80211N_HT
-	DBG_871X("supp_mcs_set = %02x, %02x, %02x, rf_type=%d, tx_ra_bitmap=%016llx\n"
-	, psta->htpriv.ht_cap.supp_mcs_set[0], psta->htpriv.ht_cap.supp_mcs_set[1], psta->htpriv.ht_cap.supp_mcs_set[2], rf_type, tx_ra_bitmap);
-	psta->ra_mask = tx_ra_bitmap;
-	psta->init_rate = get_highest_rate_idx(tx_ra_bitmap)&0x3f;
 }
+void rtw_mbid_cam_restore(_adapter *adapter)
+{
+	u8 i;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
 
-#ifndef SEC_CAM_ACCESS_TIMEOUT_MS
-	#define SEC_CAM_ACCESS_TIMEOUT_MS 200
+#ifdef DBG_MBID_CAM_DUMP
+	rtw_mbid_cam_cache_dump(RTW_DBGDUMP, __func__, adapter);
 #endif
 
-#ifndef DBG_SEC_CAM_ACCESS
-	#define DBG_SEC_CAM_ACCESS 0
-#endif
+	for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
+		if (mbid_cam_ctl->bitmap & BIT(i)) {
+			write_mbssid_cam(adapter, i, dvobj->mbid_cam_cache[i].mac_addr);
+			RTW_INFO("%s - cam_id:%d => mac:"MAC_FMT"\n", __func__, i, MAC_ARG(dvobj->mbid_cam_cache[i].mac_addr));
+		}
+	}
+	enable_mbssid_cam(adapter);
+}
+#endif /*CONFIG_MBSSID_CAM*/
 
-u32 rtw_sec_read_cam(_adapter *adapter, u8 addr)
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+void rtw_hal_set_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
 {
-	_mutex *mutex = &adapter_to_dvobj(adapter)->cam_ctl.sec_cam_access_mutex;
-	u32 rdata;
-	u32 cnt = 0;
-	u32 start = 0, end = 0;
-	u8 timeout = 0;
-	u8 sr = 0;
 
-	_enter_critical_mutex(mutex, NULL);
+#if 0 /*TODO - modify for more flexible*/
+	u8 idx = 0;
 
-	rtw_write32(adapter, REG_CAMCMD, CAM_POLLINIG | addr);
+	if ((check_fwstate(&adapter->mlmepriv, WIFI_STATION_STATE) == _TRUE) &&
+	    (DEV_STA_NUM(adapter_to_dvobj(adapter)) == 1)) {
+		for (idx = 0; idx < 6; idx++)
+			rtw_write8(GET_PRIMARY_ADAPTER(adapter), (REG_MACID + idx), val[idx]);
+	}  else {
+		/*MBID entry_id = 0~7 ,0 for root AP, 1~7 for VAP*/
+		u8 entry_id;
 
-	start = rtw_get_current_time();
-	while (1) {
-		if (rtw_is_surprise_removed(adapter)) {
-			sr = 1;
-			break;
+		if ((check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _TRUE) &&
+		    (DEV_AP_NUM(adapter_to_dvobj(adapter)) == 1)) {
+			entry_id = 0;
+			if (rtw_mbid_cam_assign(adapter, val, entry_id)) {
+				RTW_INFO(FUNC_ADPT_FMT" Root AP assigned success\n", FUNC_ADPT_ARG(adapter));
+				write_mbssid_cam(adapter, entry_id, val);
+			}
+		} else {
+			entry_id = rtw_mbid_camid_alloc(adapter, val);
+			if (entry_id != INVALID_CAM_ID)
+				write_mbssid_cam(adapter, entry_id, val);
 		}
+	}
+#else
+	{
+		/*
+			MBID entry_id = 0~7 ,for IFACE_ID0 ~ IFACE_IDx
+		*/
+		u8 entry_id = rtw_mbid_camid_alloc(adapter, mac_addr);
 
-		cnt++;
-		if (0 == (rtw_read32(adapter, REG_CAMCMD) & CAM_POLLINIG))
-			break;
 
-		if (rtw_get_passing_time_ms(start) > SEC_CAM_ACCESS_TIMEOUT_MS) {
-			timeout = 1;
-			break;
+		if (entry_id != INVALID_CAM_ID) {
+			write_mbssid_cam(adapter, entry_id, mac_addr);
+			enable_mbssid_cam(adapter);
 		}
 	}
-	end = rtw_get_current_time();
-
-	rdata = rtw_read32(adapter, REG_CAMREAD);
+#endif
+}
 
-	_exit_critical_mutex(mutex, NULL);
+void rtw_hal_change_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
+{
+	u8 idx = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 entry_id;
 
-	if (DBG_SEC_CAM_ACCESS || timeout) {
-		DBG_871X(FUNC_ADPT_FMT" addr:0x%02x, rdata:0x%08x, to:%u, polling:%u, %d ms\n"
-			, FUNC_ADPT_ARG(adapter), addr, rdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
+	if (!mac_addr) {
+		rtw_warn_on(1);
+		return;
 	}
 
-	return rdata;
+
+	entry_id = rtw_mbid_cam_info_change(adapter, mac_addr);
+
+	if (entry_id != INVALID_CAM_ID)
+		write_mbssid_cam(adapter, entry_id, mac_addr);
 }
 
-void rtw_sec_write_cam(_adapter *adapter, u8 addr, u32 wdata)
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+u16 rtw_hal_bcn_interval_adjust(_adapter *adapter, u16 bcn_interval)
 {
-	_mutex *mutex = &adapter_to_dvobj(adapter)->cam_ctl.sec_cam_access_mutex;
-	u32 cnt = 0;
-	u32 start = 0, end = 0;
-	u8 timeout = 0;
-	u8 sr = 0;
+	if (adapter_to_dvobj(adapter)->inter_bcn_space != bcn_interval)
+		return adapter_to_dvobj(adapter)->inter_bcn_space;
+	else
+		return bcn_interval;
+}
+#endif/*CONFIG_SWTIMER_BASED_TXBCN*/
 
-	_enter_critical_mutex(mutex, NULL);
+#endif/*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
 
-	rtw_write32(adapter, REG_CAMWRITE, wdata);
-	rtw_write32(adapter, REG_CAMCMD, CAM_POLLINIG | CAM_WRITE | addr);
+static void rtw_hal_set_macaddr_port(_adapter *adapter, u8 *val)
+{
+	u8 idx = 0;
+	u32 reg_macid = 0;
 
-	start = rtw_get_current_time();
-	while (1) {
-		if (rtw_is_surprise_removed(adapter)) {
-			sr = 1;
-			break;
-		}
+	if (val == NULL)
+		return;
 
-		cnt++;
-		if (0 == (rtw_read32(adapter, REG_CAMCMD) & CAM_POLLINIG))
-			break;
+	RTW_INFO("%s "ADPT_FMT"- hw port(%d) mac_addr ="MAC_FMT"\n",  __func__,
+		 ADPT_ARG(adapter), adapter->hw_port, MAC_ARG(val));
 
-		if (rtw_get_passing_time_ms(start) > SEC_CAM_ACCESS_TIMEOUT_MS) {
-			timeout = 1;
-			break;
-		}
+#ifdef RTW_HALMAC
+	rtw_halmac_set_mac_address(adapter_to_dvobj(adapter), adapter->hw_port, val);
+#else /* !RTW_HALMAC */
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+	default:
+		reg_macid = REG_MACID;
+		break;
+	case HW_PORT1:
+		reg_macid = REG_MACID1;
+		break;
+#if defined(CONFIG_RTL8814A)
+	case HW_PORT2:
+		reg_macid = REG_MACID2;
+		break;
+	case HW_PORT3:
+		reg_macid = REG_MACID3;
+		break;
+	case HW_PORT4:
+		reg_macid = REG_MACID4;
+		break;
+#endif/*defined(CONFIG_RTL8814A)*/
 	}
-	end = rtw_get_current_time();
 
-	_exit_critical_mutex(mutex, NULL);
+	for (idx = 0; idx < 6; idx++)
+		rtw_write8(GET_PRIMARY_ADAPTER(adapter), (reg_macid + idx), val[idx]);
+#endif /* !RTW_HALMAC */
+}
 
-	if (DBG_SEC_CAM_ACCESS || timeout) {
-		DBG_871X(FUNC_ADPT_FMT" addr:0x%02x, wdata:0x%08x, to:%u, polling:%u, %d ms\n"
-			, FUNC_ADPT_ARG(adapter), addr, wdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
+static void rtw_hal_get_macaddr_port(_adapter *adapter, u8 *mac_addr)
+{
+	u8 idx = 0;
+	u32 reg_macid = 0;
+
+	if (mac_addr == NULL)
+		return;
+
+	_rtw_memset(mac_addr, 0, ETH_ALEN);
+#ifdef RTW_HALMAC
+	rtw_halmac_get_mac_address(adapter_to_dvobj(adapter), adapter->hw_port, mac_addr);
+#else /* !RTW_HALMAC */
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+	default:
+		reg_macid = REG_MACID;
+		break;
+	case HW_PORT1:
+		reg_macid = REG_MACID1;
+		break;
+#if defined(CONFIG_RTL8814A)
+	case HW_PORT2:
+		reg_macid = REG_MACID2;
+		break;
+	case HW_PORT3:
+		reg_macid = REG_MACID3;
+		break;
+	case HW_PORT4:
+		reg_macid = REG_MACID4;
+		break;
+#endif /*defined(CONFIG_RTL8814A)*/
 	}
+
+	for (idx = 0; idx < 6; idx++)
+		mac_addr[idx] = rtw_read8(GET_PRIMARY_ADAPTER(adapter), (reg_macid + idx));
+#endif /* !RTW_HALMAC */
+
+	RTW_INFO("%s "ADPT_FMT"- hw port(%d) mac_addr ="MAC_FMT"\n",  __func__,
+		 ADPT_ARG(adapter), adapter->hw_port, MAC_ARG(mac_addr));
 }
 
-void rtw_sec_read_cam_ent(_adapter *adapter, u8 id, u8 *ctrl, u8 *mac, u8 *key)
+static void rtw_hal_set_bssid(_adapter *adapter, u8 *val)
 {
-	unsigned int val, addr;
-	u8 i;
-	u32 rdata;
-	u8 begin = 0;
-	u8 end = 5; /* TODO: consider other key length accordingly */
+#ifdef RTW_HALMAC
+	rtw_halmac_set_bssid(adapter_to_dvobj(adapter), adapter->hw_port, val);
+#else /* !RTW_HALMAC */
+	u8	idx = 0;
+	u32 reg_bssid = 0;
 
-	if (!ctrl && !mac && !key) {
-		rtw_warn_on(1);
-		goto exit;
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+	default:
+		reg_bssid = REG_BSSID;
+		break;
+	case HW_PORT1:
+		reg_bssid = REG_BSSID1;
+		break;
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)
+	case HW_PORT2:
+		reg_bssid = REG_BSSID2;
+		break;
+	case HW_PORT3:
+		reg_bssid = REG_BSSID3;
+		break;
+	case HW_PORT4:
+		reg_bssid = REG_BSSID4;
+		break;
+#endif/*defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)*/
 	}
 
-	/* TODO: check id range */
+	for (idx = 0 ; idx < 6; idx++)
+		rtw_write8(adapter, (reg_bssid + idx), val[idx]);
+#endif /* !RTW_HALMAC */
+
+	RTW_INFO("%s "ADPT_FMT"- hw port -%d BSSID: "MAC_FMT"\n", __func__, ADPT_ARG(adapter), adapter->hw_port, MAC_ARG(val));
+}
+
+static inline u8 hw_var_rcr_config(_adapter *adapter, u32 rcr)
+{
+	int err;
+
+	err = rtw_write32(adapter, REG_RCR, rcr);
+	if (err == _SUCCESS)
+		GET_HAL_DATA(adapter)->ReceiveConfig = rcr;
+	return err;
+}
+
+static inline u8 hw_var_rcr_get(_adapter *adapter, u32 *rcr)
+{
+	u32 v32;
+
+	v32 = rtw_read32(adapter, REG_RCR);
+	if (rcr)
+		*rcr = v32;
+	GET_HAL_DATA(adapter)->ReceiveConfig = v32;
+	return _SUCCESS;
+}
+
+/* only check SW RCR variable */
+inline u8 rtw_hal_rcr_check(_adapter *adapter, u32 check_bit)
+{
+	PHAL_DATA_TYPE hal;
+	u32 rcr;
+
+	hal = GET_HAL_DATA(adapter);
+
+	rcr = hal->ReceiveConfig;
+	if ((rcr & check_bit) == check_bit)
+		return 1;
+
+	return 0;
+}
+
+inline u8 rtw_hal_rcr_add(_adapter *adapter, u32 add)
+{
+	PHAL_DATA_TYPE hal;
+	u32 rcr;
+	u8 ret = _SUCCESS;
+
+	hal = GET_HAL_DATA(adapter);
 
-	if (!ctrl && !mac)
-		begin = 2; /* read from key */
+	rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
+	rcr |= add;
+	if (rcr != hal->ReceiveConfig)
+		ret = rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
 
-	if (!key && !mac)
-		end = 0; /* read to ctrl */
-	else if (!key)
-		end = 2; /* read to mac */
+	return ret;
+}
 
-	for (i = begin; i <= end; i++) {
-		rdata = rtw_sec_read_cam(adapter, (id << 3) | i);
+inline u8 rtw_hal_rcr_clear(_adapter *adapter, u32 clear)
+{
+	PHAL_DATA_TYPE hal;
+	u32 rcr;
+	u8 ret = _SUCCESS;
 
-		switch (i) {
-		case 0:
-			if (ctrl)
-				_rtw_memcpy(ctrl, (u8 *)(&rdata), 2);
-			if (mac)
-				_rtw_memcpy(mac, ((u8 *)(&rdata)) + 2, 2);
-			break;
-		case 1:
-			if (mac)
-				_rtw_memcpy(mac + 2, (u8 *)(&rdata), 4);
-			break;
-		default:
-			if (key)
-				_rtw_memcpy(key + (i - 2) * 4, (u8 *)(&rdata), 4);
-			break;
-		}
-	}
+	hal = GET_HAL_DATA(adapter);
 
-exit:
-	return;
-}
+	rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
+	rcr &= ~clear;
+	if (rcr != hal->ReceiveConfig)
+		ret = rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
 
+	return ret;
+}
 
-void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
+void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action)
 {
-	unsigned int i;
-	int j;
-	u8 addr;
-	u32 wdata;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u32 rcr, rcr_new;
+	struct mi_state mstate, mstate_s;
 
-	/* TODO: consider other key length accordingly */
-#if 0
-	switch ((ctrl & 0x1c) >> 2) {
-	case _WEP40_:
-	case _TKIP_
-	case _AES_
-	case _WEP104_
+	rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
+	rcr_new = rcr;
 
-	}
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rcr_new &= ~(RCR_CBSSID_BCN | RCR_CBSSID_DATA);
 #else
-	j = 7;
+	rtw_mi_status_no_self(adapter, &mstate);
+	rtw_mi_status_no_others(adapter, &mstate_s);
+
+	/* only adjust parameters interested */
+	switch (self_action) {
+	case MLME_SCAN_ENTER:
+		mstate_s.scan_num = 1;
+		mstate_s.scan_enter_num = 1;
+		break;
+	case MLME_SCAN_DONE:
+		mstate_s.scan_enter_num = 0;
+		break;
+#ifdef CONFIG_TDLS
+	case MLME_TDLS_LINKED:
+		mstate_s.ld_tdls_num = 1;
+		break;
+	case MLME_TDLS_NOLINK:
+		mstate_s.ld_tdls_num = 0;
+		break;
+#endif
+#ifdef CONFIG_AP_MODE
+	case MLME_AP_STARTED:
+		mstate_s.ap_num = 1;
+		break;
+	case MLME_AP_STOPPED:
+		mstate_s.ap_num = 0;
+		mstate_s.ld_ap_num = 0;
+		break;
+#endif
+#ifdef CONFIG_RTW_MESH
+	case MLME_MESH_STARTED:
+		mstate_s.mesh_num = 1;
+		break;
+	case MLME_MESH_STOPPED:
+		mstate_s.mesh_num = 0;
+		mstate_s.ld_mesh_num = 0;
+		break;
 #endif
+	case MLME_ACTION_NONE:
+	case MLME_STA_CONNECTING:
+	case MLME_ADHOC_STARTED:
+		/* caller without effect of decision */
+		break;
+	default:
+		rtw_warn_on(1);
+	};
 
-	for (; j >= 0; j--) {
-		switch (j) {
-		case 0:
-			wdata = (ctrl | (mac[0] << 16) | (mac[1] << 24));
-			break;
-		case 1:
-			wdata = (mac[2] | (mac[3] << 8) | (mac[4] << 16) | (mac[5] << 24));
-			break;
-		case 6:
-		case 7:
-			wdata = 0;
-			break;
-		default:
-			i = (j - 2) << 2;
-			wdata = (key[i] | (key[i + 1] << 8) | (key[i + 2] << 16) | (key[i + 3] << 24));
-			break;
-		}
+	rtw_mi_status_merge(&mstate, &mstate_s);
 
-		addr = (id << 3) + j;
+	if (MSTATE_AP_NUM(&mstate) || MSTATE_MESH_NUM(&mstate) || MSTATE_TDLS_LD_NUM(&mstate)
+		#ifdef CONFIG_FIND_BEST_CHANNEL
+		|| MSTATE_SCAN_ENTER_NUM(&mstate)
+		#endif
+		|| hal_data->in_cta_test
+	)
+		rcr_new &= ~RCR_CBSSID_DATA;
+	else
+		rcr_new |= RCR_CBSSID_DATA;
 
-		rtw_sec_write_cam(adapter, addr, wdata);
+	if ((MSTATE_AP_NUM(&mstate) && adapter->registrypriv.wifi_spec) /* for 11n Logo 4.2.31/4.2.32 */
+		|| MSTATE_MESH_NUM(&mstate)
+		|| MSTATE_SCAN_ENTER_NUM(&mstate)
+		|| hal_data->in_cta_test
+	)
+		rcr_new &= ~RCR_CBSSID_BCN;	
+	else
+		rcr_new |= RCR_CBSSID_BCN;
+#endif /* CONFIG_MI_WITH_MBSSID_CAM */
+
+	if (rcr != rcr_new)
+		rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr_new);
+}
+
+static void hw_var_set_rcr_am(_adapter *adapter, u8 enable)
+{
+	u32 rcr = RCR_AM;
+
+	if (enable)
+		rtw_hal_rcr_add(adapter, rcr);
+	else
+		rtw_hal_rcr_clear(adapter, rcr);
+}
+
+static void rtw_hal_get_msr(_adapter *adapter, u8 *net_type)
+{
+#ifdef RTW_HALMAC
+	rtw_halmac_get_network_type(adapter_to_dvobj(adapter),
+				adapter->hw_port, net_type);
+#else /* !RTW_HALMAC */
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+		/*REG_CR - BIT[17:16]-Network Type for port 1*/
+		*net_type = rtw_read8(adapter, MSR) & 0x03;
+		break;
+	case HW_PORT1:
+		/*REG_CR - BIT[19:18]-Network Type for port 1*/
+		*net_type = (rtw_read8(adapter, MSR) & 0x0C) >> 2;
+		break;
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)
+	case HW_PORT2:
+		/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
+		*net_type = rtw_read8(adapter, MSR1) & 0x03;
+		break;
+	case HW_PORT3:
+		/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
+		*net_type = (rtw_read8(adapter, MSR1) & 0x0C) >> 2;
+		break;
+	case HW_PORT4:
+		/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
+		*net_type = (rtw_read8(adapter, MSR1) & 0x30) >> 4;
+		break;
+#endif /*#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)*/
+	default:
+		RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
+			 ADPT_ARG(adapter), adapter->hw_port);
+		rtw_warn_on(1);
+		break;
 	}
+#endif /* !RTW_HALMAC */
 }
 
-bool rtw_sec_read_cam_is_gk(_adapter *adapter, u8 id)
+#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM) /*For 2 hw ports - 88E/92E/8812/8821/8723B*/
+static u8 rtw_hal_net_type_decision(_adapter *adapter, u8 net_type)
 {
-	bool res;
-	u16 ctrl;
+	if ((adapter->hw_port == HW_PORT0) && (rtw_get_mbid_cam_entry_num(adapter))) {
+		if (net_type != _HW_STATE_NOLINK_)
+			return _HW_STATE_AP_;
+	}
+	return net_type;
+}
+#endif
+static void rtw_hal_set_msr(_adapter *adapter, u8 net_type)
+{
+#ifdef RTW_HALMAC
+	#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
+	net_type = rtw_hal_net_type_decision(adapter, net_type);
+	#endif
+	rtw_halmac_set_network_type(adapter_to_dvobj(adapter),
+				adapter->hw_port, net_type);
+#else /* !RTW_HALMAC */
+	u8 val8 = 0;
 
-	rtw_sec_read_cam_ent(adapter, id, (u8 *)&ctrl, NULL, NULL);
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+		#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
+		net_type = rtw_hal_net_type_decision(adapter, net_type);
+		#endif
+		/*REG_CR - BIT[17:16]-Network Type for port 0*/
+		val8 = rtw_read8(adapter, MSR) & 0x0C;
+		val8 |= net_type;
+		rtw_write8(adapter, MSR, val8);
+		break;
+	case HW_PORT1:
+		/*REG_CR - BIT[19:18]-Network Type for port 1*/
+		val8 = rtw_read8(adapter, MSR) & 0x03;
+		val8 |= net_type << 2;
+		rtw_write8(adapter, MSR, val8);
+		break;
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	case HW_PORT2:
+		/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
+		val8 = rtw_read8(adapter, MSR1) & 0xFC;
+		val8 |= net_type;
+		rtw_write8(adapter, MSR1, val8);
+		break;
+	case HW_PORT3:
+		/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
+		val8 = rtw_read8(adapter, MSR1) & 0xF3;
+		val8 |= net_type << 2;
+		rtw_write8(adapter, MSR1, val8);
+		break;
+	case HW_PORT4:
+		/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
+		val8 = rtw_read8(adapter, MSR1) & 0xCF;
+		val8 |= net_type << 4;
+		rtw_write8(adapter, MSR1, val8);
+		break;
+#endif /* CONFIG_RTL8814A | CONFIG_RTL8822B */
+	default:
+		RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
+			 ADPT_ARG(adapter), adapter->hw_port);
+		rtw_warn_on(1);
+		break;
+	}
+#endif /* !RTW_HALMAC */
+}
 
-	res = (ctrl & BIT6) ? _TRUE : _FALSE;
-	return res;
+static void hw_var_set_bcn_interval(struct _ADAPTER *a, u16 interval)
+{
+#ifdef RTW_HALMAC
+	rtw_halmac_set_bcn_interval(adapter_to_dvobj(a), a->hw_port, interval);
+#else /* !RTW_HALMAC */
+	RTW_ERR(FUNC_ADPT_FMT ": Not implemented yet!!\n", FUNC_ADPT_ARG(a));
+	rtw_warn_on(1);
+#endif /* !RTW_HALMAC */
 }
 
 void hw_var_port_switch(_adapter *adapter)
 {
 #ifdef CONFIG_CONCURRENT_MODE
 #ifdef CONFIG_RUNTIME_PORT_SWITCH
-/*
-0x102: MSR
-0x550: REG_BCN_CTRL
-0x551: REG_BCN_CTRL_1
-0x55A: REG_ATIMWND
-0x560: REG_TSFTR
-0x568: REG_TSFTR1
-0x570: REG_ATIMWND_1
-0x610: REG_MACID
-0x618: REG_BSSID
-0x700: REG_MACID1
-0x708: REG_BSSID1
-*/
+	/*
+	0x102: MSR
+	0x550: REG_BCN_CTRL
+	0x551: REG_BCN_CTRL_1
+	0x55A: REG_ATIMWND
+	0x560: REG_TSFTR
+	0x568: REG_TSFTR1
+	0x570: REG_ATIMWND_1
+	0x610: REG_MACID
+	0x618: REG_BSSID
+	0x700: REG_MACID1
+	0x708: REG_BSSID1
+	*/
 
 	int i;
 	u8 msr;
@@ -1592,114 +3180,123 @@ void hw_var_port_switch(_adapter *adapter)
 	u8 macid_1[6];
 	u8 bssid_1[6];
 
-	u8 iface_type;
+	u8 hw_port;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface = NULL;
 
 	msr = rtw_read8(adapter, MSR);
 	bcn_ctrl = rtw_read8(adapter, REG_BCN_CTRL);
 	bcn_ctrl_1 = rtw_read8(adapter, REG_BCN_CTRL_1);
 
-	for (i=0; i<2; i++)
-		atimwnd[i] = rtw_read8(adapter, REG_ATIMWND+i);
-	for (i=0; i<2; i++)
-		atimwnd_1[i] = rtw_read8(adapter, REG_ATIMWND_1+i);
+	for (i = 0; i < 2; i++)
+		atimwnd[i] = rtw_read8(adapter, REG_ATIMWND + i);
+	for (i = 0; i < 2; i++)
+		atimwnd_1[i] = rtw_read8(adapter, REG_ATIMWND_1 + i);
 
-	for (i=0; i<8; i++)
-		tsftr[i] = rtw_read8(adapter, REG_TSFTR+i);
-	for (i=0; i<8; i++)
-		tsftr_1[i] = rtw_read8(adapter, REG_TSFTR1+i);
+	for (i = 0; i < 8; i++)
+		tsftr[i] = rtw_read8(adapter, REG_TSFTR + i);
+	for (i = 0; i < 8; i++)
+		tsftr_1[i] = rtw_read8(adapter, REG_TSFTR1 + i);
 
-	for (i=0; i<6; i++)
-		macid[i] = rtw_read8(adapter, REG_MACID+i);
+	for (i = 0; i < 6; i++)
+		macid[i] = rtw_read8(adapter, REG_MACID + i);
 
-	for (i=0; i<6; i++)
-		bssid[i] = rtw_read8(adapter, REG_BSSID+i);
+	for (i = 0; i < 6; i++)
+		bssid[i] = rtw_read8(adapter, REG_BSSID + i);
 
-	for (i=0; i<6; i++)
-		macid_1[i] = rtw_read8(adapter, REG_MACID1+i);
+	for (i = 0; i < 6; i++)
+		macid_1[i] = rtw_read8(adapter, REG_MACID1 + i);
 
-	for (i=0; i<6; i++)
-		bssid_1[i] = rtw_read8(adapter, REG_BSSID1+i);
+	for (i = 0; i < 6; i++)
+		bssid_1[i] = rtw_read8(adapter, REG_BSSID1 + i);
 
 #ifdef DBG_RUNTIME_PORT_SWITCH
-	DBG_871X(FUNC_ADPT_FMT" before switch\n"
-		"msr:0x%02x\n"
-		"bcn_ctrl:0x%02x\n"
-		"bcn_ctrl_1:0x%02x\n"
-		"atimwnd:0x%04x\n"
-		"atimwnd_1:0x%04x\n"
-		"tsftr:%llu\n"
-		"tsftr1:%llu\n"
-		"macid:"MAC_FMT"\n"
-		"bssid:"MAC_FMT"\n"
-		"macid_1:"MAC_FMT"\n"
-		"bssid_1:"MAC_FMT"\n"
-		, FUNC_ADPT_ARG(adapter)
-		, msr
-		, bcn_ctrl
-		, bcn_ctrl_1
-		, *((u16*)atimwnd)
-		, *((u16*)atimwnd_1)
-		, *((u64*)tsftr)
-		, *((u64*)tsftr_1)
-		, MAC_ARG(macid)
-		, MAC_ARG(bssid)
-		, MAC_ARG(macid_1)
-		, MAC_ARG(bssid_1)
-	);
+	RTW_INFO(FUNC_ADPT_FMT" before switch\n"
+		 "msr:0x%02x\n"
+		 "bcn_ctrl:0x%02x\n"
+		 "bcn_ctrl_1:0x%02x\n"
+		 "atimwnd:0x%04x\n"
+		 "atimwnd_1:0x%04x\n"
+		 "tsftr:%llu\n"
+		 "tsftr1:%llu\n"
+		 "macid:"MAC_FMT"\n"
+		 "bssid:"MAC_FMT"\n"
+		 "macid_1:"MAC_FMT"\n"
+		 "bssid_1:"MAC_FMT"\n"
+		 , FUNC_ADPT_ARG(adapter)
+		 , msr
+		 , bcn_ctrl
+		 , bcn_ctrl_1
+		 , *((u16 *)atimwnd)
+		 , *((u16 *)atimwnd_1)
+		 , *((u64 *)tsftr)
+		 , *((u64 *)tsftr_1)
+		 , MAC_ARG(macid)
+		 , MAC_ARG(bssid)
+		 , MAC_ARG(macid_1)
+		 , MAC_ARG(bssid_1)
+		);
 #endif /* DBG_RUNTIME_PORT_SWITCH */
 
-	/* disable bcn function, disable update TSF  */
+	/* disable bcn function, disable update TSF */
 	rtw_write8(adapter, REG_BCN_CTRL, (bcn_ctrl & (~EN_BCN_FUNCTION)) | DIS_TSF_UDT);
 	rtw_write8(adapter, REG_BCN_CTRL_1, (bcn_ctrl_1 & (~EN_BCN_FUNCTION)) | DIS_TSF_UDT);
 
 	/* switch msr */
-	msr = (msr&0xf0) |((msr&0x03) << 2) | ((msr&0x0c) >> 2);
+	msr = (msr & 0xf0) | ((msr & 0x03) << 2) | ((msr & 0x0c) >> 2);
 	rtw_write8(adapter, MSR, msr);
 
 	/* write port0 */
 	rtw_write8(adapter, REG_BCN_CTRL, bcn_ctrl_1 & ~EN_BCN_FUNCTION);
-	for (i=0; i<2; i++)
-		rtw_write8(adapter, REG_ATIMWND+i, atimwnd_1[i]);
-	for (i=0; i<8; i++)
-		rtw_write8(adapter, REG_TSFTR+i, tsftr_1[i]);
-	for (i=0; i<6; i++)
-		rtw_write8(adapter, REG_MACID+i, macid_1[i]);
-	for (i=0; i<6; i++)
-		rtw_write8(adapter, REG_BSSID+i, bssid_1[i]);
+	for (i = 0; i < 2; i++)
+		rtw_write8(adapter, REG_ATIMWND + i, atimwnd_1[i]);
+	for (i = 0; i < 8; i++)
+		rtw_write8(adapter, REG_TSFTR + i, tsftr_1[i]);
+	for (i = 0; i < 6; i++)
+		rtw_write8(adapter, REG_MACID + i, macid_1[i]);
+	for (i = 0; i < 6; i++)
+		rtw_write8(adapter, REG_BSSID + i, bssid_1[i]);
 
 	/* write port1 */
 	rtw_write8(adapter, REG_BCN_CTRL_1, bcn_ctrl & ~EN_BCN_FUNCTION);
-	for (i=0; i<2; i++)
+	for (i = 0; i < 2; i++)
 		rtw_write8(adapter, REG_ATIMWND_1 + i, atimwnd[i]);
-	for (i=0; i<8; i++)
-		rtw_write8(adapter, REG_TSFTR1+i, tsftr[i]);
-	for (i=0; i<6; i++)
-		rtw_write8(adapter, REG_MACID1+i, macid[i]);
-	for (i=0; i<6; i++)
-		rtw_write8(adapter, REG_BSSID1+i, bssid[i]);
+	for (i = 0; i < 8; i++)
+		rtw_write8(adapter, REG_TSFTR1 + i, tsftr[i]);
+	for (i = 0; i < 6; i++)
+		rtw_write8(adapter, REG_MACID1 + i, macid[i]);
+	for (i = 0; i < 6; i++)
+		rtw_write8(adapter, REG_BSSID1 + i, bssid[i]);
 
 	/* write bcn ctl */
 #ifdef CONFIG_BT_COEXIST
-#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B)
-	// always enable port0 beacon function for PSTDMA
-	bcn_ctrl_1 |= EN_BCN_FUNCTION;
-	// always disable port1 beacon function for PSTDMA
-	bcn_ctrl &= ~EN_BCN_FUNCTION;
-#endif
+	/* always enable port0 beacon function for PSTDMA */
+	if (IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8703B(adapter)
+	    || IS_HARDWARE_TYPE_8723D(adapter))
+		bcn_ctrl_1 |= EN_BCN_FUNCTION;
+	/* always disable port1 beacon function for PSTDMA */
+	if (IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8703B(adapter))
+		bcn_ctrl &= ~EN_BCN_FUNCTION;
 #endif
 	rtw_write8(adapter, REG_BCN_CTRL, bcn_ctrl_1);
 	rtw_write8(adapter, REG_BCN_CTRL_1, bcn_ctrl);
 
-	if (adapter->iface_type == IFACE_PORT0) {
-		adapter->iface_type = IFACE_PORT1;
-		adapter->pbuddy_adapter->iface_type = IFACE_PORT0;
-		DBG_871X_LEVEL(_drv_always_, "port switch - port0("ADPT_FMT"), port1("ADPT_FMT")\n",
-			ADPT_ARG(adapter->pbuddy_adapter), ADPT_ARG(adapter));
+	if (adapter->iface_id == IFACE_ID0)
+		iface = dvobj->padapters[IFACE_ID1];
+	else if (adapter->iface_id == IFACE_ID1)
+		iface = dvobj->padapters[IFACE_ID0];
+
+
+	if (adapter->hw_port == HW_PORT0) {
+		adapter->hw_port = HW_PORT1;
+		iface->hw_port = HW_PORT0;
+		RTW_PRINT("port switch - port0("ADPT_FMT"), port1("ADPT_FMT")\n",
+			  ADPT_ARG(iface), ADPT_ARG(adapter));
 	} else {
-		adapter->iface_type = IFACE_PORT0;
-		adapter->pbuddy_adapter->iface_type = IFACE_PORT1;
-		DBG_871X_LEVEL(_drv_always_, "port switch - port0("ADPT_FMT"), port1("ADPT_FMT")\n",
-			ADPT_ARG(adapter), ADPT_ARG(adapter->pbuddy_adapter));
+		adapter->hw_port = HW_PORT0;
+		iface->hw_port = HW_PORT1;
+		RTW_PRINT("port switch - port0("ADPT_FMT"), port1("ADPT_FMT")\n",
+			  ADPT_ARG(adapter), ADPT_ARG(iface));
 	}
 
 #ifdef DBG_RUNTIME_PORT_SWITCH
@@ -1707,60 +3304,60 @@ void hw_var_port_switch(_adapter *adapter)
 	bcn_ctrl = rtw_read8(adapter, REG_BCN_CTRL);
 	bcn_ctrl_1 = rtw_read8(adapter, REG_BCN_CTRL_1);
 
-	for (i=0; i<2; i++)
-		atimwnd[i] = rtw_read8(adapter, REG_ATIMWND+i);
-	for (i=0; i<2; i++)
-		atimwnd_1[i] = rtw_read8(adapter, REG_ATIMWND_1+i);
-
-	for (i=0; i<8; i++)
-		tsftr[i] = rtw_read8(adapter, REG_TSFTR+i);
-	for (i=0; i<8; i++)
-		tsftr_1[i] = rtw_read8(adapter, REG_TSFTR1+i);
-
-	for (i=0; i<6; i++)
-		macid[i] = rtw_read8(adapter, REG_MACID+i);
-
-	for (i=0; i<6; i++)
-		bssid[i] = rtw_read8(adapter, REG_BSSID+i);
-
-	for (i=0; i<6; i++)
-		macid_1[i] = rtw_read8(adapter, REG_MACID1+i);
-
-	for (i=0; i<6; i++)
-		bssid_1[i] = rtw_read8(adapter, REG_BSSID1+i);
-
-	DBG_871X(FUNC_ADPT_FMT" after switch\n"
-		"msr:0x%02x\n"
-		"bcn_ctrl:0x%02x\n"
-		"bcn_ctrl_1:0x%02x\n"
-		"atimwnd:%u\n"
-		"atimwnd_1:%u\n"
-		"tsftr:%llu\n"
-		"tsftr1:%llu\n"
-		"macid:"MAC_FMT"\n"
-		"bssid:"MAC_FMT"\n"
-		"macid_1:"MAC_FMT"\n"
-		"bssid_1:"MAC_FMT"\n"
-		, FUNC_ADPT_ARG(adapter)
-		, msr
-		, bcn_ctrl
-		, bcn_ctrl_1
-		, *((u16*)atimwnd)
-		, *((u16*)atimwnd_1)
-		, *((u64*)tsftr)
-		, *((u64*)tsftr_1)
-		, MAC_ARG(macid)
-		, MAC_ARG(bssid)
-		, MAC_ARG(macid_1)
-		, MAC_ARG(bssid_1)
-	);
+	for (i = 0; i < 2; i++)
+		atimwnd[i] = rtw_read8(adapter, REG_ATIMWND + i);
+	for (i = 0; i < 2; i++)
+		atimwnd_1[i] = rtw_read8(adapter, REG_ATIMWND_1 + i);
+
+	for (i = 0; i < 8; i++)
+		tsftr[i] = rtw_read8(adapter, REG_TSFTR + i);
+	for (i = 0; i < 8; i++)
+		tsftr_1[i] = rtw_read8(adapter, REG_TSFTR1 + i);
+
+	for (i = 0; i < 6; i++)
+		macid[i] = rtw_read8(adapter, REG_MACID + i);
+
+	for (i = 0; i < 6; i++)
+		bssid[i] = rtw_read8(adapter, REG_BSSID + i);
+
+	for (i = 0; i < 6; i++)
+		macid_1[i] = rtw_read8(adapter, REG_MACID1 + i);
+
+	for (i = 0; i < 6; i++)
+		bssid_1[i] = rtw_read8(adapter, REG_BSSID1 + i);
+
+	RTW_INFO(FUNC_ADPT_FMT" after switch\n"
+		 "msr:0x%02x\n"
+		 "bcn_ctrl:0x%02x\n"
+		 "bcn_ctrl_1:0x%02x\n"
+		 "atimwnd:%u\n"
+		 "atimwnd_1:%u\n"
+		 "tsftr:%llu\n"
+		 "tsftr1:%llu\n"
+		 "macid:"MAC_FMT"\n"
+		 "bssid:"MAC_FMT"\n"
+		 "macid_1:"MAC_FMT"\n"
+		 "bssid_1:"MAC_FMT"\n"
+		 , FUNC_ADPT_ARG(adapter)
+		 , msr
+		 , bcn_ctrl
+		 , bcn_ctrl_1
+		 , *((u16 *)atimwnd)
+		 , *((u16 *)atimwnd_1)
+		 , *((u64 *)tsftr)
+		 , *((u64 *)tsftr_1)
+		 , MAC_ARG(macid)
+		 , MAC_ARG(bssid)
+		 , MAC_ARG(macid_1)
+		 , MAC_ARG(bssid_1)
+		);
 #endif /* DBG_RUNTIME_PORT_SWITCH */
 
 #endif /* CONFIG_RUNTIME_PORT_SWITCH */
 #endif /* CONFIG_CONCURRENT_MODE */
 }
 
-const char * const _h2c_msr_role_str[] = {
+const char *const _h2c_msr_role_str[] = {
 	"RSVD",
 	"STA",
 	"AP",
@@ -1768,9 +3365,191 @@ const char * const _h2c_msr_role_str[] = {
 	"GO",
 	"TDLS",
 	"ADHOC",
+	"MESH",
 	"INVALID",
 };
 
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+s32 rtw_hal_set_default_port_id_cmd(_adapter *adapter, u8 mac_id)
+{
+	s32 ret = _SUCCESS;
+	u8 parm[H2C_DEFAULT_PORT_ID_LEN] = {0};
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	SET_H2CCMD_DFTPID_PORT_ID(parm, adapter->hw_port);
+	SET_H2CCMD_DFTPID_MAC_ID(parm, mac_id);
+
+	RTW_DBG_DUMP("DFT port id parm:", parm, H2C_DEFAULT_PORT_ID_LEN);
+	RTW_INFO("%s port_id :%d, mad_id:%d\n", __func__, adapter->hw_port, mac_id);
+
+	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_DEFAULT_PORT_ID, H2C_DEFAULT_PORT_ID_LEN, parm);
+	dvobj->default_port_id = adapter->hw_port;
+
+	return ret;
+}
+s32 rtw_set_default_port_id(_adapter *adapter)
+{
+	s32 ret = _SUCCESS;
+	struct sta_info		*psta;
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	if (adapter->hw_port == dvobj->default_port_id)
+		return ret;
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+		psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
+		if (psta)
+			ret = rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
+	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+
+	} else {
+	}
+
+	return ret;
+}
+s32 rtw_set_ps_rsvd_page(_adapter *adapter)
+{
+	s32 ret = _SUCCESS;
+	u16 media_status_rpt = RT_MEDIA_CONNECT;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	if (adapter->hw_port == dvobj->default_port_id)
+		return ret;
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
+			  (u8 *)&media_status_rpt);
+
+	return ret;
+}
+
+#endif
+
+#ifdef CONFIG_P2P_PS
+#ifdef RTW_HALMAC
+void rtw_set_p2p_ps_offload_cmd(_adapter *adapter, u8 p2p_ps_state)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct wifidirect_info *pwdinfo = &adapter->wdinfo;
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
+	struct sta_priv		*pstapriv = &adapter->stapriv;
+	struct sta_info		*psta;
+	HAL_P2P_PS_PARA p2p_ps_para;
+	int status = -1;
+	u8 i;
+
+	_rtw_memset(&p2p_ps_para, 0, sizeof(HAL_P2P_PS_PARA));
+	_rtw_memcpy((&p2p_ps_para) , &hal->p2p_ps_offload , sizeof(hal->p2p_ps_offload));
+
+	(&p2p_ps_para)->p2p_port_id = adapter->hw_port;
+	(&p2p_ps_para)->p2p_group = 0;
+	psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
+	if (psta) {
+		(&p2p_ps_para)->p2p_macid = psta->cmn.mac_id;
+	} else {
+		if (p2p_ps_state != P2P_PS_DISABLE) {
+			RTW_ERR("%s , psta was NULL\n", __func__);
+			return;
+		}
+	}
+
+
+	switch (p2p_ps_state) {
+	case P2P_PS_DISABLE:
+		RTW_INFO("P2P_PS_DISABLE\n");
+		_rtw_memset(&p2p_ps_para , 0, sizeof(HAL_P2P_PS_PARA));
+		break;
+
+	case P2P_PS_ENABLE:
+		RTW_INFO("P2P_PS_ENABLE\n");
+		/* update CTWindow value. */
+		if (pwdinfo->ctwindow > 0) {
+			(&p2p_ps_para)->ctwindow_en = 1;
+			(&p2p_ps_para)->ctwindow_length = pwdinfo->ctwindow;
+			/*RTW_INFO("%s , ctwindow_length = %d\n" , __func__ , (&p2p_ps_para)->ctwindow_length);*/
+		}
+
+
+		if ((pwdinfo->opp_ps == 1) || (pwdinfo->noa_num > 0)) {
+			(&p2p_ps_para)->offload_en = 1;
+			if (pwdinfo->role == P2P_ROLE_GO) {
+				(&p2p_ps_para)->role = 1;
+				(&p2p_ps_para)->all_sta_sleep = 0;
+			} else
+				(&p2p_ps_para)->role = 0;
+
+			(&p2p_ps_para)->discovery = 0;
+		}
+		/* hw only support 2 set of NoA */
+		for (i = 0; i < pwdinfo->noa_num; i++) {
+			/* To control the register setting for which NOA */
+			(&p2p_ps_para)->noa_sel = i;
+			(&p2p_ps_para)->noa_en = 1;
+			/* config P2P NoA Descriptor Register */
+			/* config NOA duration */
+			(&p2p_ps_para)->noa_duration_para = pwdinfo->noa_duration[i];
+			/* config NOA interval */
+			(&p2p_ps_para)->noa_interval_para = pwdinfo->noa_interval[i];
+			/* config NOA start time */
+			(&p2p_ps_para)->noa_start_time_para = pwdinfo->noa_start_time[i];
+			/* config NOA count */
+			(&p2p_ps_para)->noa_count_para = pwdinfo->noa_count[i];
+			/*RTW_INFO("%s , noa_duration_para = %d , noa_interval_para = %d , noa_start_time_para = %d , noa_count_para = %d\n" , __func__ ,
+				(&p2p_ps_para)->noa_duration_para , (&p2p_ps_para)->noa_interval_para ,
+				(&p2p_ps_para)->noa_start_time_para , (&p2p_ps_para)->noa_count_para);*/
+			status = rtw_halmac_p2pps(adapter_to_dvobj(adapter) , (&p2p_ps_para));
+			if (status == -1)
+				RTW_ERR("%s , rtw_halmac_p2pps fail\n", __func__);
+		}
+
+		break;
+
+	case P2P_PS_SCAN:
+		/*This feature FW not ready 20161116 YiWei*/
+		return;
+		RTW_INFO("P2P_PS_SCAN\n");
+		(&p2p_ps_para)->discovery = 1;
+		/*
+		(&p2p_ps_para)->ctwindow_length = pwdinfo->ctwindow;
+		(&p2p_ps_para)->noa_duration_para = pwdinfo->noa_duration[0];
+		(&p2p_ps_para)->noa_interval_para = pwdinfo->noa_interval[0];
+		(&p2p_ps_para)->noa_start_time_para = pwdinfo->noa_start_time[0];
+		(&p2p_ps_para)->noa_count_para = pwdinfo->noa_count[0];
+		*/
+		break;
+
+	case P2P_PS_SCAN_DONE:
+		/*This feature FW not ready 20161116 YiWei*/
+		return;
+		RTW_INFO("P2P_PS_SCAN_DONE\n");
+		(&p2p_ps_para)->discovery = 0;
+		/*
+		pwdinfo->p2p_ps_state = P2P_PS_ENABLE;
+		(&p2p_ps_para)->ctwindow_length = pwdinfo->ctwindow;
+		(&p2p_ps_para)->noa_duration_para = pwdinfo->noa_duration[0];
+		(&p2p_ps_para)->noa_interval_para = pwdinfo->noa_interval[0];
+		(&p2p_ps_para)->noa_start_time_para = pwdinfo->noa_start_time[0];
+		(&p2p_ps_para)->noa_count_para = pwdinfo->noa_count[0];
+		*/
+		break;
+
+	default:
+		break;
+	}
+
+	if (p2p_ps_state != P2P_PS_ENABLE || (&p2p_ps_para)->noa_en == 0) {
+		status = rtw_halmac_p2pps(adapter_to_dvobj(adapter) , (&p2p_ps_para));
+		if (status == -1)
+			RTW_ERR("%s , rtw_halmac_p2pps fail\n", __func__);
+	}
+	_rtw_memcpy(&hal->p2p_ps_offload , (&p2p_ps_para) , sizeof(hal->p2p_ps_offload));
+
+}
+#endif /* RTW_HALMAC */
+#endif /* CONFIG_P2P */
+
 /*
 * rtw_hal_set_FwMediaStatusRpt_cmd -
 *
@@ -1797,8 +3576,10 @@ s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miraca
 	SET_H2CCMD_MSRRPT_PARM_ROLE(parm, role);
 	SET_H2CCMD_MSRRPT_PARM_MACID(parm, macid);
 	SET_H2CCMD_MSRRPT_PARM_MACID_END(parm, macid_end);
-
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "MediaStatusRpt parm:", parm, H2C_MEDIA_STATUS_RPT_LEN);
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	SET_H2CCMD_MSRRPT_PARM_PORT_NUM(parm, adapter->hw_port);
+#endif
+	RTW_DBG_DUMP("MediaStatusRpt parm:", parm, H2C_MEDIA_STATUS_RPT_LEN);
 
 	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_MEDIA_STATUS_RPT, H2C_MEDIA_STATUS_RPT_LEN, parm);
 	if (ret != _SUCCESS)
@@ -1815,14 +3596,14 @@ s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miraca
 			rtw_hal_set_hwreg(adapter, HW_VAR_MACID_NOLINK, &macid);
 
 		/* for 8188E RA */
-		#if (RATE_ADAPTIVE_SUPPORT == 1)
+#if (RATE_ADAPTIVE_SUPPORT == 1)
 		if (hal_data->fw_ractrl == _FALSE) {
 			u8 max_macid;
 
 			max_macid = rtw_search_max_mac_id(adapter);
 			rtw_hal_set_hwreg(adapter, HW_VAR_TX_RPT_MAX_MACID, &max_macid);
 		}
-		#endif
+#endif
 	}
 #endif
 
@@ -1868,14 +3649,14 @@ inline s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode
 
 void rtw_hal_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
 {
-	struct	hal_ops *pHalFunc = &padapter->HalFunc;
-	u8	u1H2CRsvdPageParm[H2C_RSVDPAGE_LOC_LEN]={0};
+	struct	hal_ops *pHalFunc = &padapter->hal_func;
+	u8	u1H2CRsvdPageParm[H2C_RSVDPAGE_LOC_LEN] = {0};
 	u8	ret = 0;
 
-	DBG_871X("RsvdPageLoc: ProbeRsp=%d PsPoll=%d Null=%d QoSNull=%d BTNull=%d\n",
-		rsvdpageloc->LocProbeRsp, rsvdpageloc->LocPsPoll,
-		rsvdpageloc->LocNullData, rsvdpageloc->LocQosNull,
-		rsvdpageloc->LocBTQosNull);
+	RTW_INFO("RsvdPageLoc: ProbeRsp=%d PsPoll=%d Null=%d QoSNull=%d BTNull=%d\n",
+		 rsvdpageloc->LocProbeRsp, rsvdpageloc->LocPsPoll,
+		 rsvdpageloc->LocNullData, rsvdpageloc->LocQosNull,
+		 rsvdpageloc->LocBTQosNull);
 
 	SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(u1H2CRsvdPageParm, rsvdpageloc->LocProbeRsp);
 	SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(u1H2CRsvdPageParm, rsvdpageloc->LocPsPoll);
@@ -1884,47 +3665,101 @@ void rtw_hal_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
 	SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocBTQosNull);
 
 	ret = rtw_hal_fill_h2c_cmd(padapter,
-				H2C_RSVD_PAGE,
-				H2C_RSVDPAGE_LOC_LEN,
-				u1H2CRsvdPageParm);
+				   H2C_RSVD_PAGE,
+				   H2C_RSVDPAGE_LOC_LEN,
+				   u1H2CRsvdPageParm);
 
 }
 
 #ifdef CONFIG_GPIO_WAKEUP
 void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable)
 {
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+
+	if (IS_8723D_SERIES(pHalData->version_id) || IS_8822B_SERIES(pHalData->version_id) || IS_8821C_SERIES(pHalData->version_id))
+		rtw_hal_set_hwreg(padapter, HW_SET_GPIO_WL_CTRL, (u8 *)(&enable));
 	/*
 	* Switch GPIO_13, GPIO_14 to wlan control, or pull GPIO_13,14 MUST fail.
 	* It happended at 8723B/8192E/8821A. New IC will check multi function GPIO,
 	* and implement HAL function.
 	* TODO: GPIO_8 multi function?
 	*/
-	if (index == 13 || index == 14)
+
+	if ((index == 13 || index == 14)
+		#if defined(CONFIG_RTL8821A) && defined(CONFIG_SDIO_HCI)
+		/* 8821A's LED2 circuit(used by HW_LED strategy) needs enable WL GPIO control of GPIO[14:13], can't disable */
+		&& (!IS_HW_LED_STRATEGY(rtw_led_get_strategy(padapter)) || enable)
+		#endif
+	)
 		rtw_hal_set_hwreg(padapter, HW_SET_GPIO_WL_CTRL, (u8 *)(&enable));
 }
 
 void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval)
 {
-	if ( index <= 7 ) {
+	if (index <= 7) {
+		/* config GPIO mode */
+		rtw_write8(padapter, REG_GPIO_PIN_CTRL + 3,
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL + 3) & ~BIT(index));
+
+		/* config GPIO Sel */
+		/* 0: input */
+		/* 1: output */
+		rtw_write8(padapter, REG_GPIO_PIN_CTRL + 2,
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL + 2) | BIT(index));
+
+		/* set output value */
+		if (outputval) {
+			rtw_write8(padapter, REG_GPIO_PIN_CTRL + 1,
+				rtw_read8(padapter, REG_GPIO_PIN_CTRL + 1) | BIT(index));
+		} else {
+			rtw_write8(padapter, REG_GPIO_PIN_CTRL + 1,
+				rtw_read8(padapter, REG_GPIO_PIN_CTRL + 1) & ~BIT(index));
+		}
+	} else if (index <= 15) {
+		/* 88C Series: */
+		/* index: 11~8 transform to 3~0 */
+		/* 8723 Series: */
+		/* index: 12~8 transform to 4~0 */
+
+		index -= 8;
+
+		/* config GPIO mode */
+		rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 3,
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 3) & ~BIT(index));
+
+		/* config GPIO Sel */
+		/* 0: input */
+		/* 1: output */
+		rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 2,
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 2) | BIT(index));
+
+		/* set output value */
+		if (outputval) {
+			rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 1,
+				rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 1) | BIT(index));
+		} else {
+			rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 1,
+				rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 1) & ~BIT(index));
+		}
+	} else {
+		RTW_INFO("%s: invalid GPIO%d=%d\n",
+			 __FUNCTION__, index, outputval);
+	}
+}
+void rtw_hal_set_input_gpio(_adapter *padapter, u8 index)
+{
+	if (index <= 7) {
 		/* config GPIO mode */
 		rtw_write8(padapter, REG_GPIO_PIN_CTRL + 3,
-				rtw_read8(padapter, REG_GPIO_PIN_CTRL + 3) & ~BIT(index) );
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL + 3) & ~BIT(index));
 
 		/* config GPIO Sel */
 		/* 0: input */
 		/* 1: output */
 		rtw_write8(padapter, REG_GPIO_PIN_CTRL + 2,
-				rtw_read8(padapter, REG_GPIO_PIN_CTRL + 2) | BIT(index));
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL + 2) & ~BIT(index));
 
-		/* set output value */
-		if ( outputval ) {
-			rtw_write8(padapter, REG_GPIO_PIN_CTRL + 1,
-					rtw_read8(padapter, REG_GPIO_PIN_CTRL + 1) | BIT(index));
-		} else {
-			rtw_write8(padapter, REG_GPIO_PIN_CTRL + 1,
-					rtw_read8(padapter, REG_GPIO_PIN_CTRL + 1) & ~BIT(index));
-		}
-	} else if (index <= 15){
+	} else if (index <= 15) {
 		/* 88C Series: */
 		/* index: 11~8 transform to 3~0 */
 		/* 8723 Series: */
@@ -1934,103 +3769,247 @@ void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval)
 
 		/* config GPIO mode */
 		rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 3,
-				rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 3) & ~BIT(index) );
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 3) & ~BIT(index));
 
 		/* config GPIO Sel */
 		/* 0: input */
 		/* 1: output */
 		rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 2,
-				rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 2) | BIT(index));
+			rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 2) & ~BIT(index));
+	} else
+		RTW_INFO("%s: invalid GPIO%d\n", __func__, index);
 
-		/* set output value */
-		if ( outputval ) {
-			rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 1,
-					rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 1) | BIT(index));
-		} else {
-			rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 1,
-					rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 1) & ~BIT(index));
-		}
-	} else {
-		DBG_871X("%s: invalid GPIO%d=%d\n",
-				__FUNCTION__, index, outputval);
-	}
 }
+
 #endif
 
 void rtw_hal_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
 {
-	struct	hal_ops *pHalFunc = &padapter->HalFunc;
+	struct	hal_ops *pHalFunc = &padapter->hal_func;
 	struct	pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	u8	res = 0, count = 0, ret = 0;
-#ifdef CONFIG_WOWLAN	
-	u8 u1H2CAoacRsvdPageParm[H2C_AOAC_RSVDPAGE_LOC_LEN]={0};
+#ifdef CONFIG_WOWLAN
+	u8 u1H2CAoacRsvdPageParm[H2C_AOAC_RSVDPAGE_LOC_LEN] = {0};
 
-	DBG_871X("AOACRsvdPageLoc: RWC=%d ArpRsp=%d NbrAdv=%d GtkRsp=%d GtkInfo=%d ProbeReq=%d NetworkList=%d\n",
-			rsvdpageloc->LocRemoteCtrlInfo, rsvdpageloc->LocArpRsp,
-			rsvdpageloc->LocNbrAdv, rsvdpageloc->LocGTKRsp,
-			rsvdpageloc->LocGTKInfo, rsvdpageloc->LocProbeReq,
-			rsvdpageloc->LocNetList);
+	RTW_INFO("%s: RWC: %d ArpRsp: %d NbrAdv: %d LocNDPInfo: %d\n",
+		 __func__, rsvdpageloc->LocRemoteCtrlInfo,
+		 rsvdpageloc->LocArpRsp, rsvdpageloc->LocNbrAdv,
+		 rsvdpageloc->LocNDPInfo);
+	RTW_INFO("%s:GtkRsp: %d GtkInfo: %d ProbeReq: %d NetworkList: %d\n",
+		 __func__, rsvdpageloc->LocGTKRsp, rsvdpageloc->LocGTKInfo,
+		 rsvdpageloc->LocProbeReq, rsvdpageloc->LocNetList);
 
 	if (check_fwstate(pmlmepriv, _FW_LINKED)) {
 		SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocRemoteCtrlInfo);
 		SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(u1H2CAoacRsvdPageParm, rsvdpageloc->LocArpRsp);
-		//SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(u1H2CAoacRsvdPageParm, rsvdpageloc->LocNbrAdv);
+		SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(u1H2CAoacRsvdPageParm,
+							rsvdpageloc->LocNbrAdv);
+		SET_H2CCMD_AOAC_RSVDPAGE_LOC_NDP_INFO(u1H2CAoacRsvdPageParm,
+						      rsvdpageloc->LocNDPInfo);
+#ifdef CONFIG_GTK_OL
 		SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKRsp);
 		SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKInfo);
-#ifdef CONFIG_GTK_OL
 		SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKEXTMEM);
-#endif // CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
 		ret = rtw_hal_fill_h2c_cmd(padapter,
-					H2C_AOAC_RSVD_PAGE,
-					H2C_AOAC_RSVDPAGE_LOC_LEN,
-					u1H2CAoacRsvdPageParm);
+					   H2C_AOAC_RSVD_PAGE,
+					   H2C_AOAC_RSVDPAGE_LOC_LEN,
+					   u1H2CAoacRsvdPageParm);
+
+		RTW_INFO("AOAC Report=%d\n", rsvdpageloc->LocAOACReport);
+		_rtw_memset(&u1H2CAoacRsvdPageParm, 0, sizeof(u1H2CAoacRsvdPageParm));
+		SET_H2CCMD_AOAC_RSVDPAGE_LOC_AOAC_REPORT(u1H2CAoacRsvdPageParm,
+					 rsvdpageloc->LocAOACReport);
+		ret = rtw_hal_fill_h2c_cmd(padapter,
+				   H2C_AOAC_RSVDPAGE3,
+				   H2C_AOAC_RSVDPAGE_LOC_LEN,
+				   u1H2CAoacRsvdPageParm);
+		pwrpriv->wowlan_aoac_rpt_loc = rsvdpageloc->LocAOACReport;
 	}
 #ifdef CONFIG_PNO_SUPPORT
-	else
-	{
+	else {
 
-		if(!pwrpriv->pno_in_resume) {
-			DBG_871X("NLO_INFO=%d\n", rsvdpageloc->LocPNOInfo);
+		if (!pwrpriv->wowlan_in_resume) {
+			RTW_INFO("NLO_INFO=%d\n", rsvdpageloc->LocPNOInfo);
 			_rtw_memset(&u1H2CAoacRsvdPageParm, 0,
-					sizeof(u1H2CAoacRsvdPageParm));
+				    sizeof(u1H2CAoacRsvdPageParm));
 			SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(u1H2CAoacRsvdPageParm,
-					rsvdpageloc->LocPNOInfo);
+						      rsvdpageloc->LocPNOInfo);
 			ret = rtw_hal_fill_h2c_cmd(padapter,
-						H2C_AOAC_RSVDPAGE3,
-						H2C_AOAC_RSVDPAGE_LOC_LEN,
-						u1H2CAoacRsvdPageParm);
+						   H2C_AOAC_RSVDPAGE3,
+						   H2C_AOAC_RSVDPAGE_LOC_LEN,
+						   u1H2CAoacRsvdPageParm);
 		}
 	}
-#endif //CONFIG_PNO_SUPPORT
-#endif // CONFIG_WOWLAN
+#endif /* CONFIG_PNO_SUPPORT */
+#endif /* CONFIG_WOWLAN */
+}
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+void rtw_hal_set_fw_dbg_msg_pkt_rsvd_page_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
+{
+	struct	hal_ops *pHalFunc = &padapter->hal_func;
+	u8	u1H2C_fw_dbg_msg_pkt_parm[H2C_FW_DBG_MSG_PKT_LEN] = {0};
+	u8	ret = 0;
+
+
+	RTW_INFO("RsvdPageLoc: loc_fw_dbg_msg_pkt =%d\n", rsvdpageloc->loc_fw_dbg_msg_pkt);
+
+	SET_H2CCMD_FW_DBG_MSG_PKT_EN(u1H2C_fw_dbg_msg_pkt_parm, 1);
+	SET_H2CCMD_RSVDPAGE_LOC_FW_DBG_MSG_PKT(u1H2C_fw_dbg_msg_pkt_parm, rsvdpageloc->loc_fw_dbg_msg_pkt);
+	ret = rtw_hal_fill_h2c_cmd(padapter,
+				   H2C_FW_DBG_MSG_PKT,
+				   H2C_FW_DBG_MSG_PKT_LEN,
+				   u1H2C_fw_dbg_msg_pkt_parm);
+
+}
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+/*#define DBG_GET_RSVD_PAGE*/
+int rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset,
+	u32 page_num, u8 *buffer, u32 buffer_size)
+{
+	u32 addr = 0, size = 0, count = 0;
+	u32 page_size = 0, data_low = 0, data_high = 0;
+	u16 txbndy = 0, offset = 0;
+	u8 i = 0;
+	bool rst = _FALSE;
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
+
+	addr = page_offset * page_size;
+	size = page_num * page_size;
+
+	if (buffer_size < size) {
+		RTW_ERR("%s buffer_size(%d) < get page total size(%d)\n",
+			__func__, buffer_size, size);
+		return rst;
+	}
+#ifdef RTW_HALMAC
+	if (rtw_halmac_dump_fifo(adapter_to_dvobj(adapter), 2, addr, size, buffer) < 0)
+		rst = _FALSE;
+	else
+		rst = _TRUE;
+#else
+	txbndy = rtw_read8(adapter, REG_TDECTRL + 1);
+
+	offset = (txbndy + page_offset) * page_size / 8;
+	count = (buffer_size / 8) + 1;
+
+	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, 0x69);
+
+	for (i = 0 ; i < count ; i++) {
+		rtw_write32(adapter, REG_PKTBUF_DBG_CTRL, offset + i);
+		data_low = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_L);
+		data_high = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_H);
+		_rtw_memcpy(buffer + (i * 8),
+			&data_low, sizeof(data_low));
+		_rtw_memcpy(buffer + ((i * 8) + 4),
+			&data_high, sizeof(data_high));
+	}
+	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, 0x0);
+	rst = _TRUE;
+#endif /*RTW_HALMAC*/
+
+#ifdef DBG_GET_RSVD_PAGE
+	RTW_INFO("%s [page_offset:%d , page_num:%d][start_addr:0x%04x , size:%d]\n",
+		 __func__, page_offset, page_num, addr, size);
+	RTW_INFO_DUMP("\n", buffer, size);
+	RTW_INFO(" ==================================================\n");
+#endif
+	return rst;
+}
+
+void rtw_dump_rsvd_page(void *sel, _adapter *adapter, u8 page_offset, u8 page_num)
+{
+	u32 page_size = 0;
+	u8 *buffer = NULL;
+	u32 buf_size = 0;
+
+	if (page_num == 0)
+		return;
+
+	RTW_PRINT_SEL(sel, "======= RSVD PAGE DUMP =======\n");
+	RTW_PRINT_SEL(sel, "page_offset:%d, page_num:%d\n", page_offset, page_num);
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
+	if (page_size) {
+		buf_size = page_size * page_num;
+		buffer = rtw_zvmalloc(buf_size);
+
+		if (buffer) {
+			rtw_hal_get_rsvd_page(adapter, page_offset, page_num, buffer, buf_size);
+			RTW_DUMP_SEL(sel, buffer, buf_size);
+			rtw_vmfree(buffer, buf_size);
+		} else
+			RTW_PRINT_SEL(sel, "ERROR - rsvd_buf mem allocate failed\n");
+	} else
+			RTW_PRINT_SEL(sel, "ERROR - Tx page size is zero ??\n");
+
+	RTW_PRINT_SEL(sel, "==========================\n");
+}
+
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+void rtw_dump_fifo(void *sel, _adapter *adapter, u8 fifo_sel, u32 fifo_addr, u32 fifo_size)
+{
+	u8 *buffer = NULL;
+	u8 buff_size = 0;
+	static const char * const fifo_sel_str[] = {
+		"TX", "RX", "RSVD_PAGE", "REPORT", "LLT", "RXBUF_FW"
+	};
+
+	if (fifo_sel > 5) {
+		RTW_ERR("fifo_sel:%d invalid\n", fifo_sel);
+		return;
+	}
+
+	RTW_PRINT_SEL(sel, "========= FIFO DUMP =========\n");
+	RTW_PRINT_SEL(sel, "%s FIFO DUMP [start_addr:0x%04x , size:%d]\n", fifo_sel_str[fifo_sel], fifo_addr, fifo_size);
+
+	if (fifo_size) {
+		buff_size = RND4(fifo_size);
+		buffer = rtw_zvmalloc(buff_size);
+		if (buffer == NULL)
+			buff_size = 0;
+	}
+
+	rtw_halmac_dump_fifo(adapter_to_dvobj(adapter), fifo_sel, fifo_addr, buff_size, buffer);
+
+	if (buffer) {
+		RTW_DUMP_SEL(sel, buffer, fifo_size);
+		rtw_vmfree(buffer, buff_size);
+	}
+
+	RTW_PRINT_SEL(sel, "==========================\n");
 }
+#endif
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 static void rtw_hal_force_enable_rxdma(_adapter *adapter)
 {
-	DBG_871X("%s: Set 0x690=0x00\n", __func__);
+	RTW_INFO("%s: Set 0x690=0x00\n", __func__);
 	rtw_write8(adapter, REG_WOW_CTRL,
-			(rtw_read8(adapter, REG_WOW_CTRL)&0xf0));
-	DBG_871X_LEVEL(_drv_always_, "%s: Release RXDMA\n", __func__);
+		   (rtw_read8(adapter, REG_WOW_CTRL) & 0xf0));
+	RTW_PRINT("%s: Release RXDMA\n", __func__);
 	rtw_write32(adapter, REG_RXPKT_NUM,
-			(rtw_read32(adapter,REG_RXPKT_NUM)&(~RW_RELEASE_EN)));
+		    (rtw_read32(adapter, REG_RXPKT_NUM) & (~RW_RELEASE_EN)));
 }
-
+#if defined(CONFIG_RTL8188E)
 static void rtw_hal_disable_tx_report(_adapter *adapter)
 {
 	rtw_write8(adapter, REG_TX_RPT_CTRL,
-			((rtw_read8(adapter, REG_TX_RPT_CTRL)&~BIT(1)))&~BIT(5));
-	DBG_871X("disable TXRPT:0x%02x\n", rtw_read8(adapter, REG_TX_RPT_CTRL));
+		   ((rtw_read8(adapter, REG_TX_RPT_CTRL) & ~BIT(1))) & ~BIT(5));
+	RTW_INFO("disable TXRPT:0x%02x\n", rtw_read8(adapter, REG_TX_RPT_CTRL));
 }
 
 static void rtw_hal_enable_tx_report(_adapter *adapter)
 {
 	rtw_write8(adapter, REG_TX_RPT_CTRL,
-			((rtw_read8(adapter, REG_TX_RPT_CTRL)|BIT(1)))|BIT(5));
-	DBG_871X("enable TX_RPT:0x%02x\n", rtw_read8(adapter, REG_TX_RPT_CTRL));
+		   ((rtw_read8(adapter, REG_TX_RPT_CTRL) | BIT(1))) | BIT(5));
+	RTW_INFO("enable TX_RPT:0x%02x\n", rtw_read8(adapter, REG_TX_RPT_CTRL));
 }
-
+#endif
 static void rtw_hal_release_rx_dma(_adapter *adapter)
 {
 	u32 val32 = 0;
@@ -2039,72 +4018,65 @@ static void rtw_hal_release_rx_dma(_adapter *adapter)
 
 	rtw_write32(adapter, REG_RXPKT_NUM, (val32 & (~RW_RELEASE_EN)));
 
-	DBG_871X("%s, [0x%04x]: 0x%08lx\n",
+	RTW_INFO("%s, [0x%04x]: 0x%08x\n",
 		 __func__, REG_RXPKT_NUM, (val32 & (~RW_RELEASE_EN)));
 }
 
 static u8 rtw_hal_pause_rx_dma(_adapter *adapter)
 {
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
 	u8 ret = 0;
 	s8 trycnt = 100;
-	u16 len = 0;
 	u32 tmp = 0;
 	int res = 0;
-	//RX DMA stop
-	DBG_871X_LEVEL(_drv_always_, "Pause DMA\n");
+	/* RX DMA stop */
+	RTW_PRINT("Pause DMA\n");
 	rtw_write32(adapter, REG_RXPKT_NUM,
-			(rtw_read32(adapter,REG_RXPKT_NUM)|RW_RELEASE_EN));
-	do{
-		if((rtw_read32(adapter, REG_RXPKT_NUM)&RXDMA_IDLE)) {
-			DBG_871X_LEVEL(_drv_always_, "RX_DMA_IDLE is true\n");
+		    (rtw_read32(adapter, REG_RXPKT_NUM) | RW_RELEASE_EN));
+	do {
+		if ((rtw_read32(adapter, REG_RXPKT_NUM) & RXDMA_IDLE)) {
+#ifdef CONFIG_USB_HCI
+			/* stop interface before leave */
+			if (_TRUE == hal->usb_intf_start) {
+				rtw_intf_stop(adapter);
+				RTW_ENABLE_FUNC(adapter, DF_RX_BIT);
+				RTW_ENABLE_FUNC(adapter, DF_TX_BIT);
+			}
+#endif /* CONFIG_USB_HCI */
+
+			RTW_PRINT("RX_DMA_IDLE is true\n");
 			ret = _SUCCESS;
 			break;
 		}
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 		else {
-			// If RX_DMA is not idle, receive one pkt from DMA
-			res = sdio_local_read(adapter,
-					SDIO_REG_RX0_REQ_LEN, 4, (u8*)&tmp);
-			len = le16_to_cpu(tmp);
-			DBG_871X_LEVEL(_drv_always_, "RX len:%d\n", len);
-
-			if (len > 0)
-				res = RecvOnePkt(adapter, len);
-			else
-				DBG_871X_LEVEL(_drv_always_, "read length fail %d\n", len);
-
-			DBG_871X_LEVEL(_drv_always_,
-				       "RecvOnePkt Result: %d\n", res);
+			res = RecvOnePkt(adapter);
+			RTW_PRINT("RecvOnePkt Result: %d\n", res);
 		}
-#endif //CONFIG_SDIO_HCI || CONFIG_GSPI_HCI
+#endif /* CONFIG_SDIO_HCI || CONFIG_GSPI_HCI */
+
 #ifdef CONFIG_USB_HCI
 		else {
-			if (adapter->intf_start)
-				adapter->intf_start(adapter);
-			tmp = rtw_read32(adapter, REG_RXPKT_NUM) & RXDMA_IDLE;
-			if (tmp) {
-				if (adapter->intf_stop)
-					adapter->intf_stop(adapter);
-				RTW_ENABLE_FUNC(adapter, DF_RX_BIT);
-				RTW_ENABLE_FUNC(adapter, DF_TX_BIT);
-			}
+			/* to avoid interface start repeatedly  */
+			if (_FALSE == hal->usb_intf_start)
+				rtw_intf_start(adapter);
 		}
-#endif
-	}while(trycnt--);
+#endif /* CONFIG_USB_HCI */
+	} while (trycnt--);
 
 	if (trycnt < 0) {
-		tmp = rtw_read16(adapter, REG_RXPKT_NUM + 3);
-
-		DBG_871X_LEVEL(_drv_always_, "Stop RX DMA failed......\n");
-		DBG_871X_LEVEL(_drv_always_, "%s, RXPKT_NUM: 0x%04x\n",
-				__func__, tmp);
 		tmp = rtw_read16(adapter, REG_RXPKT_NUM + 2);
+
+		RTW_PRINT("Stop RX DMA failed......\n");
+		RTW_PRINT("%s, RXPKT_NUM: 0x%02x\n",
+			  __func__, ((tmp & 0xFF00) >> 8));
+
 		if (tmp & BIT(3))
-			DBG_871X_LEVEL(_drv_always_, "%s, RX DMA has req\n",
-				       __func__);
+			RTW_PRINT("%s, RX DMA has req\n",
+				  __func__);
 		else
-			DBG_871X_LEVEL(_drv_always_, "%s, RX DMA no req\n",
-				       __func__);
+			RTW_PRINT("%s, RX DMA no req\n",
+				  __func__);
 		ret = _FAIL;
 	}
 
@@ -2112,83 +4084,129 @@ static u8 rtw_hal_pause_rx_dma(_adapter *adapter)
 }
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-static u8 rtw_hal_enable_cpwm2(_adapter* adapter)
+#ifndef RTW_HALMAC
+static u8 rtw_hal_enable_cpwm2(_adapter *adapter)
 {
 	u8 ret = 0;
 	int res = 0;
 	u32 tmp = 0;
+#ifdef CONFIG_GPIO_WAKEUP
+	return _SUCCESS;
+#else
+	RTW_PRINT("%s\n", __func__);
 
-	DBG_871X_LEVEL(_drv_always_, "%s\n", __func__);
-
-	res = sdio_local_read(adapter, SDIO_REG_HIMR, 4, (u8*)&tmp);
+	res = sdio_local_read(adapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
 	if (!res)
-		DBG_871X_LEVEL(_drv_info_, "read SDIO_REG_HIMR: 0x%08x\n", tmp);
+		RTW_INFO("read SDIO_REG_HIMR: 0x%08x\n", tmp);
 	else
-		DBG_871X_LEVEL(_drv_info_, "sdio_local_read fail\n");
+		RTW_INFO("sdio_local_read fail\n");
 
 	tmp = SDIO_HIMR_CPWM2_MSK;
 
-	res = sdio_local_write(adapter, SDIO_REG_HIMR, 4, (u8*)&tmp);
+	res = sdio_local_write(adapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
 
-	if (!res){
-		res = sdio_local_read(adapter, SDIO_REG_HIMR, 4, (u8*)&tmp);
-		DBG_871X_LEVEL(_drv_info_, "read again SDIO_REG_HIMR: 0x%08x\n", tmp);
+	if (!res) {
+		res = sdio_local_read(adapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
+		RTW_INFO("read again SDIO_REG_HIMR: 0x%08x\n", tmp);
 		ret = _SUCCESS;
-	}else {
-		DBG_871X_LEVEL(_drv_info_, "sdio_local_write fail\n");
+	} else {
+		RTW_INFO("sdio_local_write fail\n");
 		ret = _FAIL;
 	}
-
 	return ret;
+#endif /* CONFIG_CPIO_WAKEUP */
 }
+#endif
 #endif /* CONFIG_SDIO_HCI, CONFIG_GSPI_HCI */
 #endif /* CONFIG_WOWLAN || CONFIG_AP_WOWLAN */
 
 #ifdef CONFIG_WOWLAN
-/* 
+/*
  * rtw_hal_check_wow_ctrl
- * chk_type: _TRUE means to check enable, if 0x690 & bit1, WOW enable successful
- *		     _FALSE means to check disable, if 0x690 & bit1, WOW disable fail
+ * chk_type: _TRUE means to check enable, if 0x690 & bit1 (for 8051), WOW enable successful.
+ *									If 0x1C7 == 0 (for 3081), WOW enable successful.
+ *		     _FALSE means to check disable, if 0x690 & bit1 (for 8051), WOW disable fail.
+ *									If 0x120 & bit16 || 0x284 & bit18 (for 3081), WOW disable fail.
  */
 static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)
 {
+	u32 fe1_imr = 0xFF, rxpkt_num = 0xFF;
 	u8 mstatus = 0;
+	u8 reason = 0xFF;
 	u8 trycnt = 25;
 	u8 res = _FALSE;
 
-	mstatus = rtw_read8(adapter, REG_WOW_CTRL);
-	DBG_871X_LEVEL(_drv_info_, "%s mstatus:0x%02x\n", __func__, mstatus);
-
-	if (chk_type) {
-		while (!(mstatus&BIT1) && trycnt > 1) {
-			mstatus = rtw_read8(adapter, REG_WOW_CTRL);
-			DBG_871X_LEVEL(_drv_always_,
-					"Loop index: %d :0x%02x\n",
-					trycnt, mstatus);
-			trycnt--;
-			rtw_msleep_os(20);
+	if (IS_HARDWARE_TYPE_JAGUAR2(adapter)) {
+		if (chk_type) {
+			reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
+			RTW_INFO("%s reason:0x%02x\n", __func__, reason);
+
+			while (reason && trycnt > 1) {
+				reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
+				RTW_PRINT("Loop index: %d :0x%02x\n",
+					  trycnt, reason);
+				trycnt--;
+				rtw_msleep_os(20);
+			}
+			if (!reason)
+				res = _TRUE;
+			else
+				res = _FALSE;
+		} else {
+			/* Wait FW to cleare 0x120 bit16, 0x284 bit18 to 0 */
+			fe1_imr = rtw_read32(adapter, REG_FE1IMR); /* RxDone IMR for 3081 */
+			rxpkt_num = rtw_read32(adapter, REG_RXPKT_NUM); /* Release RXDMA */
+			RTW_PRINT("%s REG_FE1IMR (reg120): 0x%x, REG_RXPKT_NUM(reg284): 0x%x\n", __func__, fe1_imr, rxpkt_num);
+
+			while (((fe1_imr & BIT_FS_RXDONE_INT_EN) || (rxpkt_num & BIT_RW_RELEASE_EN)) && trycnt > 1) {
+				rtw_msleep_os(20);
+				fe1_imr = rtw_read32(adapter, REG_FE1IMR);
+				rxpkt_num = rtw_read32(adapter, REG_RXPKT_NUM);
+				RTW_PRINT("Loop index: %d :0x%x, 0x%x\n",
+					  trycnt, fe1_imr, rxpkt_num);
+				trycnt--;
+			}
+
+			if ((fe1_imr & BIT_FS_RXDONE_INT_EN) || (rxpkt_num & BIT_RW_RELEASE_EN))
+				res = _FALSE;
+			else
+				res = _TRUE;
 		}
-		if (mstatus & BIT1)
-			res = _TRUE;
-		else
-			res = _FALSE;
 	} else {
-		while (mstatus&BIT1 && trycnt > 1) {
-			mstatus = rtw_read8(adapter, REG_WOW_CTRL);
-			DBG_871X_LEVEL(_drv_always_,
-					"Loop index: %d :0x%02x\n",
-					trycnt, mstatus);
-			trycnt--;
-			rtw_msleep_os(20);
-		}
+		mstatus = rtw_read8(adapter, REG_WOW_CTRL);
+		RTW_INFO("%s mstatus:0x%02x\n", __func__, mstatus);
 
-		if (mstatus & BIT1)
-			res = _FALSE;
-		else
-			res = _TRUE;
+
+		if (chk_type) {
+			while (!(mstatus & BIT1) && trycnt > 1) {
+				mstatus = rtw_read8(adapter, REG_WOW_CTRL);
+				RTW_PRINT("Loop index: %d :0x%02x\n",
+					  trycnt, mstatus);
+				trycnt--;
+				rtw_msleep_os(20);
+			}
+			if (mstatus & BIT1)
+				res = _TRUE;
+			else
+				res = _FALSE;
+		} else {
+			while (mstatus & BIT1 && trycnt > 1) {
+				mstatus = rtw_read8(adapter, REG_WOW_CTRL);
+				RTW_PRINT("Loop index: %d :0x%02x\n",
+					  trycnt, mstatus);
+				trycnt--;
+				rtw_msleep_os(20);
+			}
+
+			if (mstatus & BIT1)
+				res = _FALSE;
+			else
+				res = _TRUE;
+		}
 	}
-	DBG_871X_LEVEL(_drv_always_, "%s check_type: %d res: %d trycnt: %d\n",
-			__func__, chk_type, res, (25 - trycnt));
+
+	RTW_PRINT("%s check_type: %d res: %d trycnt: %d\n",
+		  __func__, chk_type, res, (25 - trycnt));
 	return res;
 }
 
@@ -2198,12 +4216,12 @@ static u8 rtw_hal_check_pno_enabled(_adapter *adapter)
 	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
 	u8 res = 0, count = 0;
 	u8 ret = _FALSE;
-	
-	if (ppwrpriv->wowlan_pno_enable && ppwrpriv->pno_in_resume == _FALSE) {
+
+	if (ppwrpriv->wowlan_pno_enable && ppwrpriv->wowlan_in_resume == _FALSE) {
 		res = rtw_read8(adapter, REG_PNO_STATUS);
-		while (!(res&BIT(7)) && count < 25) {
-			DBG_871X("[%d] cmd: 0x81 REG_PNO_STATUS: 0x%02x\n",
-					count, res);
+		while (!(res & BIT(7)) && count < 25) {
+			RTW_INFO("[%d] cmd: 0x81 REG_PNO_STATUS: 0x%02x\n",
+				 count, res);
 			res = rtw_read8(adapter, REG_PNO_STATUS);
 			count++;
 			rtw_msleep_os(2);
@@ -2212,7 +4230,7 @@ static u8 rtw_hal_check_pno_enabled(_adapter *adapter)
 			ret = _TRUE;
 		else
 			ret = _FALSE;
-		DBG_871X("cmd: 0x81 REG_PNO_STATUS: ret(%d)\n", ret);
+		RTW_INFO("cmd: 0x81 REG_PNO_STATUS: ret(%d)\n", ret);
 	}
 	return ret;
 }
@@ -2220,7 +4238,7 @@ static u8 rtw_hal_check_pno_enabled(_adapter *adapter)
 
 static void rtw_hal_backup_rate(_adapter *adapter)
 {
-	DBG_871X("%s\n", __func__);
+	RTW_INFO("%s\n", __func__);
 	/* backup data rate to register 0x8b for wowlan FW */
 	rtw_write8(adapter, 0x8d, 1);
 	rtw_write8(adapter, 0x8c, 0);
@@ -2231,208 +4249,350 @@ static void rtw_hal_backup_rate(_adapter *adapter)
 #ifdef CONFIG_GTK_OL
 static void rtw_hal_fw_sync_cam_id(_adapter *adapter)
 {
-	struct security_priv *psecuritypriv = &adapter->securitypriv;
-	u8 null_addr[] = {0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
-	int cam_id;
-	u32 algorithm = 0;
-	u16 ctrl = 0;
-	u8 *addr;
-	u8 index = 0;
-	u8 get_key[16];
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	int cam_id, index = 0;
+	u8 *addr = NULL;
+
+	if (!MLME_IS_STA(adapter))
+		return;
 
-	addr = get_bssid(&adapter->mlmepriv);
+	addr = get_bssid(pmlmepriv);
 
 	if (addr == NULL) {
-		DBG_871X("%s: get bssid MAC addr fail!!\n", __func__);
+		RTW_INFO("%s: get bssid MAC addr fail!!\n", __func__);
 		return;
 	}
 
-	do{
-		cam_id = rtw_camid_search(adapter, addr, index, -1);
-		if (cam_id == -1) {
-			DBG_871X("%s: cam_id: %d, key_id:%d\n",
-					__func__, cam_id, index);
-		} else if (rtw_camid_is_gk(adapter, cam_id) != _TRUE) {
-			DBG_871X("%s: cam_id: %d key_id(%d) is not GK\n",
-					__func__, cam_id, index);
-		} else {
-			rtw_sec_read_cam_ent(adapter, cam_id, NULL, NULL, get_key);
-			algorithm = psecuritypriv->dot11PrivacyAlgrthm;
-			ctrl = BIT(15) | BIT6 |(algorithm << 2) | index;
-			write_cam(adapter, index, ctrl, addr, get_key);
-			ctrl = 0;
-			write_cam(adapter, cam_id, ctrl, null_addr, get_key);
-		}
+	rtw_clean_dk_section(adapter);
+
+	do {
+		cam_id = rtw_camid_search(adapter, addr, index, 1);
+
+		if (cam_id == -1)
+			RTW_INFO("%s: cam_id: %d, key_id:%d\n", __func__, cam_id, index);
+		else
+			rtw_sec_cam_swap(adapter, cam_id, index);
+
 		index++;
-	}while(index < 4);
+	} while (index < 4);
 
 	rtw_write8(adapter, REG_SECCFG, 0xcc);
 }
 
 static void rtw_hal_update_gtk_offload_info(_adapter *adapter)
 {
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+	struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct security_priv *psecuritypriv = &adapter->securitypriv;
-	u8 default_cam_id = 0;
-	u8 cam_id=5;
-	u8 *addr;
-	u8 null_addr[] = {0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
-	u8 gtk_keyindex=0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	_irqL irqL;
 	u8 get_key[16];
-	u8 index = 1;
-	u16 ctrl = 0;
-	u32 algorithm = 0;
+	u8 gtk_id = 0, offset = 0, i = 0, sz = 0;
+	u64 replay_count = 0, tmp_iv_hdr = 0, pkt_pn = 0;
+
+	if (!MLME_IS_STA(adapter))
+		return;
 
-	addr = get_bssid(&adapter->mlmepriv);
+	_rtw_memset(get_key, 0, sizeof(get_key));
+	_rtw_memcpy(&replay_count,
+		paoac_rpt->replay_counter_eapol_key, 8);
+
+	/*read gtk key index*/
+	gtk_id = paoac_rpt->key_index;
+
+	if (gtk_id == 5 || gtk_id == 0) {
+		RTW_INFO("%s no rekey event happened.\n", __func__);
+	} else if (gtk_id > 0 && gtk_id < 4) {
+		RTW_INFO("%s update security key.\n", __func__);
+		/*read key from sec-cam,for DK ,keyindex is equal to cam-id*/
+		rtw_sec_read_cam_ent(adapter, gtk_id,
+				     NULL, NULL, get_key);
+		rtw_clean_hw_dk_cam(adapter);
+
+		if (_rtw_camid_is_gk(adapter, gtk_id)) {
+			_enter_critical_bh(&cam_ctl->lock, &irqL);
+			_rtw_memcpy(&dvobj->cam_cache[gtk_id].key,
+				    get_key, 16);
+			_exit_critical_bh(&cam_ctl->lock, &irqL);
+		} else {
+			struct setkey_parm parm_gtk;
 
-	if (addr == NULL) {
-		DBG_871X("%s: get bssid MAC addr fail!!\n", __func__);
+			parm_gtk.algorithm = paoac_rpt->security_type;
+			parm_gtk.keyid = gtk_id;
+			_rtw_memcpy(parm_gtk.key, get_key, 16);
+			setkey_hdl(adapter, (u8 *)&parm_gtk);
+		}
+
+		/*update key into related sw variable and sec-cam cache*/
+		psecuritypriv->dot118021XGrpKeyid = gtk_id;
+		_rtw_memcpy(&psecuritypriv->dot118021XGrpKey[gtk_id],
+				get_key, 16);
+		/* update SW TKIP TX/RX MIC value */
+		if (psecuritypriv->dot118021XGrpPrivacy == _TKIP_) {
+			offset = RTW_KEK_LEN + RTW_TKIP_MIC_LEN;
+			_rtw_memcpy(
+				&psecuritypriv->dot118021XGrptxmickey[gtk_id],
+				&(paoac_rpt->group_key[offset]),
+				RTW_TKIP_MIC_LEN);
+
+			offset = RTW_KEK_LEN;
+			_rtw_memcpy(
+				&psecuritypriv->dot118021XGrprxmickey[gtk_id],
+				&(paoac_rpt->group_key[offset]),
+				RTW_TKIP_MIC_LEN);
+		}
+		RTW_PRINT("GTK (%d) "KEY_FMT"\n", gtk_id,
+			KEY_ARG(psecuritypriv->dot118021XGrpKey[gtk_id].skey));
+	}
+
+	/* Update broadcast RX IV */
+	if (psecuritypriv->dot118021XGrpPrivacy == _AES_) {
+		sz = sizeof(psecuritypriv->iv_seq[0]);
+		for (i = 0 ; i < 4 ; i++) {
+			_rtw_memcpy(&tmp_iv_hdr, paoac_rpt->rxgtk_iv[i], sz);
+			tmp_iv_hdr = le64_to_cpu(tmp_iv_hdr);
+			pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
+			_rtw_memcpy(psecuritypriv->iv_seq[i], &pkt_pn, sz);
+		}
+	}
+
+	rtw_clean_dk_section(adapter);
+
+	rtw_write8(adapter, REG_SECCFG, 0x0c);
+
+	#ifdef CONFIG_GTK_OL_DBG
+	/* if (gtk_keyindex != 5) */
+	dump_sec_cam(RTW_DBGDUMP, adapter);
+	dump_sec_cam_cache(RTW_DBGDUMP, adapter);
+	#endif
+}
+#endif /*CONFIG_GTK_OL*/
+
+static void rtw_dump_aoac_rpt(_adapter *adapter)
+{
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+	struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
+	int i = 0;
+
+	RTW_INFO_DUMP("[AOAC-RPT] IV -", paoac_rpt->iv, 8);
+	RTW_INFO_DUMP("[AOAC-RPT] Replay counter of EAPOL key - ",
+		paoac_rpt->replay_counter_eapol_key, 8);
+	RTW_INFO_DUMP("[AOAC-RPT] Group key - ", paoac_rpt->group_key, 32);
+	RTW_INFO("[AOAC-RPT] Key Index - %d\n", paoac_rpt->key_index);
+	RTW_INFO("[AOAC-RPT] Security Type - %d\n", paoac_rpt->security_type);
+	RTW_INFO("[AOAC-RPT] wow_pattern_idx - %d\n",
+		 paoac_rpt->wow_pattern_idx);
+	RTW_INFO("[AOAC-RPT] version_info - %d\n", paoac_rpt->version_info);
+	RTW_INFO_DUMP("[AOAC-RPT] RX PTK IV-", paoac_rpt->rxptk_iv, 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[0] IV-", paoac_rpt->rxgtk_iv[0], 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[1] IV-", paoac_rpt->rxgtk_iv[1], 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[2] IV-", paoac_rpt->rxgtk_iv[2], 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[3] IV-", paoac_rpt->rxgtk_iv[3], 8);
+}
+
+static void rtw_hal_get_aoac_rpt(_adapter *adapter)
+{
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+	struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
+	u32 page_offset = 0, page_number = 0;
+	u32 page_size = 0, buf_size = 0;
+	u8 *buffer = NULL;
+	u8 i = 0, tmp = 0;
+	int ret = -1;
+
+	/* read aoac report from rsvd page */
+	page_offset = pwrctl->wowlan_aoac_rpt_loc;
+	page_number = 1;
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
+	buf_size = page_size * page_number;
+
+	buffer = rtw_zvmalloc(buf_size);
+
+	if (buffer == NULL) {
+		RTW_ERR("%s buffer allocate failed size(%d)\n",
+			__func__, buf_size);
 		return;
 	}
 
-	_rtw_memset(get_key, 0, sizeof(get_key));
+	RTW_INFO("Get AOAC Report from rsvd page_offset:%d\n", page_offset);
 
-	algorithm = psecuritypriv->dot11PrivacyAlgrthm;
-
-	if(psecuritypriv->binstallKCK_KEK == _TRUE) {
-
-		//read gtk key index
-		gtk_keyindex = rtw_read8(adapter, 0x48c);
-		do{
-			/* chech if GK */
-			if (rtw_sec_read_cam_is_gk(adapter, default_cam_id) == _TRUE) {
-				rtw_sec_read_cam_ent(adapter, default_cam_id, NULL, NULL, get_key);
-				algorithm = psecuritypriv->dot11PrivacyAlgrthm;
-				/* in default cam entry, cam id = key id */
-				ctrl = BIT(15) | BIT6 | (algorithm << 2) | default_cam_id;
-				write_cam(adapter, cam_id, ctrl, addr, get_key);
-				cam_id++;
-				ctrl = 0;
-				write_cam(adapter, default_cam_id, ctrl, null_addr, get_key);
-			}
+	ret = rtw_hal_get_rsvd_page(adapter, page_offset,
+		page_number, buffer, buf_size);
 
-			if (gtk_keyindex < 4 && (default_cam_id == gtk_keyindex)) {
-				psecuritypriv->dot118021XGrpKeyid = gtk_keyindex;
-				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey,
-						get_key, 16);
-
-				DBG_871X_LEVEL(_drv_always_, "GTK (%d) = 0x%08x, 0x%08x, 0x%08x, 0x%08x\n",
-						gtk_keyindex,
-				psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].lkey[0], 
-				psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].lkey[1],
-				psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].lkey[2],
-				psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].lkey[3]);
-			}
-			default_cam_id++;
-		} while (default_cam_id < 4);
+	if (ret == _FALSE) {
+		RTW_ERR("%s get aoac report failed\n", __func__);
+		rtw_warn_on(1);
+		goto _exit;
+	}
 
-		rtw_write8(adapter, REG_SECCFG, 0x0c);
-#ifdef CONFIG_GTK_OL_DBG
-		//if (gtk_keyindex != 5)
-		dump_sec_cam(RTW_DBGDUMP, adapter);
-#endif
+	_rtw_memset(paoac_rpt, 0, sizeof(struct aoac_report));
+	_rtw_memcpy(paoac_rpt, buffer, sizeof(struct aoac_report));
+
+	for (i = 0 ; i < 4 ; i++) {
+		tmp = paoac_rpt->replay_counter_eapol_key[i];
+		paoac_rpt->replay_counter_eapol_key[i] =
+			paoac_rpt->replay_counter_eapol_key[7 - i];
+		paoac_rpt->replay_counter_eapol_key[7 - i] = tmp;
 	}
+
+	rtw_dump_aoac_rpt(adapter);
+
+_exit:
+	if (buffer)
+		rtw_vmfree(buffer, buf_size);
 }
-#endif
 
 static void rtw_hal_update_tx_iv(_adapter *adapter)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
-	u64 iv_low = 0, iv_high = 0;
+	struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
+	struct sta_info	*psta;
+	struct mlme_ext_priv	*pmlmeext = &(adapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct security_priv	*psecpriv = &adapter->securitypriv;
+
+	u16 val16 = 0;
+	u32 val32 = 0;
+	u64 txiv = 0;
+	u8 *pval = NULL;
+
+	psta = rtw_get_stainfo(&adapter->stapriv,
+			       get_my_bssid(&pmlmeinfo->network));
+
+	/* Update TX iv data. */
+	pval = (u8 *)&paoac_rpt->iv;
+
+	if (psecpriv->dot11PrivacyAlgrthm == _TKIP_) {
+		val16 = ((u16)(paoac_rpt->iv[2]) << 0) +
+			((u16)(paoac_rpt->iv[0]) << 8);
+		val32 = ((u32)(paoac_rpt->iv[4]) << 0) +
+			((u32)(paoac_rpt->iv[5]) << 8) +
+			((u32)(paoac_rpt->iv[6]) << 16) +
+			((u32)(paoac_rpt->iv[7]) << 24);
+	} else if (psecpriv->dot11PrivacyAlgrthm == _AES_) {
+		val16 = ((u16)(paoac_rpt->iv[0]) << 0) +
+			((u16)(paoac_rpt->iv[1]) << 8);
+		val32 = ((u32)(paoac_rpt->iv[4]) << 0) +
+			((u32)(paoac_rpt->iv[5]) << 8) +
+			((u32)(paoac_rpt->iv[6]) << 16) +
+			((u32)(paoac_rpt->iv[7]) << 24);
+	}
 
-	// 3.1 read fw iv
-	iv_low = rtw_read32(adapter, REG_TXPKTBUF_IV_LOW);
-	//only low two bytes is PN, check AES_IV macro for detail
-	iv_low &= 0xffff;
-	iv_high = rtw_read32(adapter, REG_TXPKTBUF_IV_HIGH);
-	//get the real packet number
-	pwrctl->wowlan_fw_iv = iv_high << 16 | iv_low;
-	DBG_871X_LEVEL(_drv_always_,
-			"fw_iv: 0x%016llx\n", pwrctl->wowlan_fw_iv);
-	//Update TX iv data.
-	rtw_set_sec_pn(adapter);
+	if (psta) {
+		txiv = val16 + ((u64)val32 << 16);
+		if (txiv != 0)
+			psta->dot11txpn.val = txiv;
+	}
+}
+
+static void rtw_hal_update_sw_security_info(_adapter *adapter)
+{
+	struct security_priv *psecpriv = &adapter->securitypriv;
+	u8 sz = sizeof (psecpriv->iv_seq);
+
+	rtw_hal_update_tx_iv(adapter);
+#ifdef CONFIG_GTK_OL
+	if (psecpriv->binstallKCK_KEK == _TRUE &&
+	    psecpriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK)
+		rtw_hal_update_gtk_offload_info(adapter);
+#else
+	_rtw_memset(psecpriv->iv_seq, 0, sz);
+#endif
 }
 
 static u8 rtw_hal_set_keep_alive_cmd(_adapter *adapter, u8 enable, u8 pkt_type)
 {
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 
-	u8 u1H2CKeepAliveParm[H2C_KEEP_ALIVE_CTRL_LEN]={0};
+	u8 u1H2CKeepAliveParm[H2C_KEEP_ALIVE_CTRL_LEN] = {0};
 	u8 adopt = 1, check_period = 5;
 	u8 ret = _FAIL;
 
-	DBG_871X("%s(): enable = %d\n", __func__, enable);
 	SET_H2CCMD_KEEPALIVE_PARM_ENABLE(u1H2CKeepAliveParm, enable);
 	SET_H2CCMD_KEEPALIVE_PARM_ADOPT(u1H2CKeepAliveParm, adopt);
 	SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(u1H2CKeepAliveParm, pkt_type);
 	SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(u1H2CKeepAliveParm, check_period);
-
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(u1H2CKeepAliveParm, adapter->hw_port);
+	RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, adapter->hw_port);
+#else
+	RTW_INFO("%s(): enable = %d\n", __func__, enable);
+#endif
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_KEEP_ALIVE,
-				H2C_KEEP_ALIVE_CTRL_LEN,
-				u1H2CKeepAliveParm);
+				   H2C_KEEP_ALIVE,
+				   H2C_KEEP_ALIVE_CTRL_LEN,
+				   u1H2CKeepAliveParm);
 
 	return ret;
 }
 
 static u8 rtw_hal_set_disconnect_decision_cmd(_adapter *adapter, u8 enable)
 {
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
-	u8 u1H2CDisconDecisionParm[H2C_DISCON_DECISION_LEN]={0};
-	u8 adopt = 1, check_period = 10, trypkt_num = 0;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
+	u8 u1H2CDisconDecisionParm[H2C_DISCON_DECISION_LEN] = {0};
+	u8 adopt = 1, check_period = 30, trypkt_num = 5;
 	u8 ret = _FAIL;
 
-	DBG_871X("%s(): enable = %d\n", __func__, enable);
 	SET_H2CCMD_DISCONDECISION_PARM_ENABLE(u1H2CDisconDecisionParm, enable);
 	SET_H2CCMD_DISCONDECISION_PARM_ADOPT(u1H2CDisconDecisionParm, adopt);
 	SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(u1H2CDisconDecisionParm, check_period);
 	SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(u1H2CDisconDecisionParm, trypkt_num);
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	SET_H2CCMD_DISCONDECISION_PORT_NUM(u1H2CDisconDecisionParm, adapter->hw_port);
+	RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, adapter->hw_port);
+#else
+	RTW_INFO("%s(): enable = %d\n", __func__, enable);
+#endif
 
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_DISCON_DECISION,
-				H2C_DISCON_DECISION_LEN,
-				u1H2CDisconDecisionParm);
+				   H2C_DISCON_DECISION,
+				   H2C_DISCON_DECISION_LEN,
+				   u1H2CDisconDecisionParm);
 	return ret;
 }
 
 static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_unit)
 {
+	struct registry_priv  *registry_par = &adapter->registrypriv;
 	struct security_priv *psecpriv = &adapter->securitypriv;
 	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 
-	u8 u1H2CWoWlanCtrlParm[H2C_WOWLAN_LEN]={0};
-	u8 discont_wake = 1, gpionum = 0, gpio_dur = 0;
+	u8 u1H2CWoWlanCtrlParm[H2C_WOWLAN_LEN] = {0};
+	u8 discont_wake = 0, gpionum = 0, gpio_dur = 0;
 	u8 hw_unicast = 0, gpio_pulse_cnt = 0, gpio_pulse_en = 0;
 	u8 sdio_wakeup_enable = 1;
 	u8 gpio_high_active = 0;
-	u8 pattern_en = 0;
 	u8 magic_pkt = 0;
 	u8 gpio_unit = 0; /*0: 64ns, 1: 8ms*/
 	u8 ret = _FAIL;
+#ifdef CONFIG_DIS_UPHY
+	u8 dis_uphy = 0, dis_uphy_unit = 0, dis_uphy_time = 0;
+#endif /* CONFIG_DIS_UPHY */
 
 #ifdef CONFIG_GPIO_WAKEUP
 	gpio_high_active = ppwrpriv->is_high_active;
 	gpionum = WAKEUP_GPIO_IDX;
 	sdio_wakeup_enable = 0;
-#endif //CONFIG_GPIO_WAKEUP
+#endif /* CONFIG_GPIO_WAKEUP */
 
-	if (!ppwrpriv->wowlan_pno_enable)
+	if (!ppwrpriv->wowlan_pno_enable &&
+	    registry_par->wakeup_event & BIT(0))
 		magic_pkt = enable;
 
-	if (psecpriv->dot11PrivacyAlgrthm == _WEP40_ || psecpriv->dot11PrivacyAlgrthm == _WEP104_)
-		hw_unicast = 1;
-	else
-		hw_unicast = 0;
+	if ((registry_par->wakeup_event & BIT(1)) &&
+	    (psecpriv->dot11PrivacyAlgrthm == _WEP40_ ||
+	     psecpriv->dot11PrivacyAlgrthm == _WEP104_))
+			hw_unicast = 1;
 
-	if (ppwrpriv->wowlan_pattern) {
-		if (enable)
-			pattern_en = 1;
-		else
-			pattern_en = 0;
-	}
+	if (registry_par->wakeup_event & BIT(2))
+		discont_wake = enable;
 
-	DBG_871X("%s(): enable=%d change_unit=%d\n", __func__,
-			enable, change_unit);
+	RTW_INFO("%s(): enable=%d change_unit=%d\n", __func__,
+		 enable, change_unit);
 
 	/* time = (gpio_dur/2) * gpio_unit, default:256 ms */
 	if (enable && change_unit) {
@@ -2448,21 +4608,25 @@ static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_un
 	}
 #endif
 
+	if (enable) {
+		RTW_INFO("gpio_pulse_en\n");
+		gpio_pulse_en = 1;
+		gpio_pulse_cnt = 0x04;
+	}
+
 	SET_H2CCMD_WOWLAN_FUNC_ENABLE(u1H2CWoWlanCtrlParm, enable);
-	SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(u1H2CWoWlanCtrlParm, pattern_en);
+	SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(u1H2CWoWlanCtrlParm, enable);
 	SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(u1H2CWoWlanCtrlParm, magic_pkt);
 	SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(u1H2CWoWlanCtrlParm, hw_unicast);
 	SET_H2CCMD_WOWLAN_ALL_PKT_DROP(u1H2CWoWlanCtrlParm, 0);
 	SET_H2CCMD_WOWLAN_GPIO_ACTIVE(u1H2CWoWlanCtrlParm, gpio_high_active);
 
 #ifdef CONFIG_GTK_OL
-	if (enable == _TRUE) {
-		/* GTK rekey only for AES, if GTK rekey is TKIP, then wake up*/
-		if (psecpriv->dot118021XGrpPrivacy == _AES_)
-			SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, 0);
-		else if (psecpriv->dot118021XGrpPrivacy == _TKIP_)
-			SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, 1);
-	}
+	if (psecpriv->binstallKCK_KEK == _TRUE &&
+	    psecpriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK)
+		SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, 0);
+	else
+		SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, 1);
 #else
 	SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, enable);
 #endif
@@ -2476,59 +4640,100 @@ static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_un
 	SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(u1H2CWoWlanCtrlParm, gpio_pulse_en);
 	SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(u1H2CWoWlanCtrlParm, gpio_pulse_cnt);
 
+#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
+	if (enable)
+		SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(u1H2CWoWlanCtrlParm, 1);
+#endif
+
+#ifdef CONFIG_DIS_UPHY
+	if (enable) {
+		dis_uphy = 1;
+		/* time unit: 0 -> ms, 1 -> 256 ms*/
+		dis_uphy_unit = 1;
+		dis_uphy_time = 0x4;
+	}
+
+	SET_H2CCMD_WOWLAN_DIS_UPHY(u1H2CWoWlanCtrlParm, dis_uphy);
+	SET_H2CCMD_WOWLAN_HOST_2_DEV(u1H2CWoWlanCtrlParm, 1);
+	SET_H2CCMD_WOWLAN_DIS_UPHY_UNIT(u1H2CWoWlanCtrlParm, dis_uphy_unit);
+	SET_H2CCMD_WOWLAN_DIS_UPHY_TIME(u1H2CWoWlanCtrlParm, dis_uphy_time);
+#endif /* CONFIG_DIS_UPHY */
+
+
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_WOWLAN,
-				H2C_WOWLAN_LEN,
-				u1H2CWoWlanCtrlParm);
+				   H2C_WOWLAN,
+				   H2C_WOWLAN_LEN,
+				   u1H2CWoWlanCtrlParm);
 	return ret;
 }
 
 static u8 rtw_hal_set_remote_wake_ctrl_cmd(_adapter *adapter, u8 enable)
 {
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
-	struct security_priv* psecuritypriv=&(adapter->securitypriv);
+	struct hal_ops *pHalFunc = &adapter->hal_func;
+	struct security_priv *psecuritypriv = &(adapter->securitypriv);
 	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
-	u8 u1H2CRemoteWakeCtrlParm[H2C_REMOTE_WAKE_CTRL_LEN]={0};
+	struct registry_priv *pregistrypriv = &adapter->registrypriv;
+	u8 u1H2CRemoteWakeCtrlParm[H2C_REMOTE_WAKE_CTRL_LEN] = {0};
 	u8 ret = _FAIL, count = 0;
 
-	DBG_871X("%s(): enable=%d\n", __func__, enable);
+	RTW_INFO("%s(): enable=%d\n", __func__, enable);
 
 	if (!ppwrpriv->wowlan_pno_enable) {
 		SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
-				u1H2CRemoteWakeCtrlParm, enable);
+			u1H2CRemoteWakeCtrlParm, enable);
 		SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(
-				u1H2CRemoteWakeCtrlParm, 1);
+			u1H2CRemoteWakeCtrlParm, 1);
 #ifdef CONFIG_GTK_OL
 		if (psecuritypriv->binstallKCK_KEK == _TRUE &&
-				psecuritypriv->dot11PrivacyAlgrthm == _AES_) {
+		    psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
 			SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
-					u1H2CRemoteWakeCtrlParm, 1);
+				u1H2CRemoteWakeCtrlParm, 1);
 		} else {
-			DBG_871X("no kck or security is not AES\n");
+			RTW_INFO("no kck kek\n");
 			SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
-					u1H2CRemoteWakeCtrlParm, 0);
+				u1H2CRemoteWakeCtrlParm, 0);
 		}
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
 
-		SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(
-						u1H2CRemoteWakeCtrlParm,
-						!ppwrpriv->wowlan_pattern);
+#ifdef CONFIG_IPV6
+		if (ppwrpriv->wowlan_ns_offload_en == _TRUE) {
+			RTW_INFO("enable NS offload\n");
+			SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(
+				u1H2CRemoteWakeCtrlParm, enable);
+		}
 
 		/*
 		 * filter NetBios name service pkt to avoid being waked-up
-		 * by this kind of unicast pkt this exceptional modification 
+		 * by this kind of unicast pkt this exceptional modification
 		 * is used for match competitor's behavior
 		 */
+
 		SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(
-				u1H2CRemoteWakeCtrlParm, !ppwrpriv->wowlan_pattern);
-		
+			u1H2CRemoteWakeCtrlParm, enable);
+#endif /*CONFIG_IPV6*/
+
 		if ((psecuritypriv->dot11PrivacyAlgrthm == _AES_) ||
+			(psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) ||
 			(psecuritypriv->dot11PrivacyAlgrthm == _NO_PRIVACY_)) {
 			SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
-					u1H2CRemoteWakeCtrlParm, 0);
+				u1H2CRemoteWakeCtrlParm, 0);
 		} else {
 			SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
+				u1H2CRemoteWakeCtrlParm, 1);
+		}
+
+		if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_ &&
+		    psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
+			SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
+					u1H2CRemoteWakeCtrlParm, enable);
+
+			if (IS_HARDWARE_TYPE_8188E(adapter) ||
+			    IS_HARDWARE_TYPE_8812(adapter)) {
+				SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
+					u1H2CRemoteWakeCtrlParm, 0);
+				SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
 					u1H2CRemoteWakeCtrlParm, 1);
+			}
 		}
 
 		SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(
@@ -2537,122 +4742,122 @@ static u8 rtw_hal_set_remote_wake_ctrl_cmd(_adapter *adapter, u8 enable)
 #ifdef CONFIG_PNO_SUPPORT
 	else {
 		SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
-				u1H2CRemoteWakeCtrlParm, enable);
+			u1H2CRemoteWakeCtrlParm, enable);
 		SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(
-				u1H2CRemoteWakeCtrlParm, enable);
+			u1H2CRemoteWakeCtrlParm, enable);
 	}
 #endif
 
 #ifdef CONFIG_P2P_WOWLAN
-	if (_TRUE == ppwrpriv->wowlan_p2p_mode)
-	{
-		DBG_871X("P2P OFFLOAD ENABLE\n");
-		SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm,1);
-	}
-	else
-	{
-		DBG_871X("P2P OFFLOAD DISABLE\n");
-		SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm,0);
+	if (_TRUE == ppwrpriv->wowlan_p2p_mode) {
+		RTW_INFO("P2P OFFLOAD ENABLE\n");
+		SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 1);
+	} else {
+		RTW_INFO("P2P OFFLOAD DISABLE\n");
+		SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 0);
 	}
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
 
 
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_REMOTE_WAKE_CTRL,
-				H2C_REMOTE_WAKE_CTRL_LEN,
-				u1H2CRemoteWakeCtrlParm);
+				   H2C_REMOTE_WAKE_CTRL,
+				   H2C_REMOTE_WAKE_CTRL_LEN,
+				   u1H2CRemoteWakeCtrlParm);
 	return ret;
 }
 
-static u8 rtw_hal_set_global_info_cmd(_adapter* adapter, u8 group_alg, u8 pairwise_alg)
+static u8 rtw_hal_set_global_info_cmd(_adapter *adapter, u8 group_alg, u8 pairwise_alg)
 {
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	u8 ret = _FAIL;
-	u8 u1H2CAOACGlobalInfoParm[H2C_AOAC_GLOBAL_INFO_LEN]={0};
+	u8 u1H2CAOACGlobalInfoParm[H2C_AOAC_GLOBAL_INFO_LEN] = {0};
 
-	DBG_871X("%s(): group_alg=%d pairwise_alg=%d\n",
-			__func__, group_alg, pairwise_alg);
+	RTW_INFO("%s(): group_alg=%d pairwise_alg=%d\n",
+		 __func__, group_alg, pairwise_alg);
 	SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(u1H2CAOACGlobalInfoParm,
 			pairwise_alg);
 	SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(u1H2CAOACGlobalInfoParm,
 			group_alg);
 
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_AOAC_GLOBAL_INFO,
-				H2C_AOAC_GLOBAL_INFO_LEN,
-				u1H2CAOACGlobalInfoParm);
+				   H2C_AOAC_GLOBAL_INFO,
+				   H2C_AOAC_GLOBAL_INFO_LEN,
+				   u1H2CAOACGlobalInfoParm);
 
 	return ret;
 }
 
 #ifdef CONFIG_PNO_SUPPORT
-static u8 rtw_hal_set_scan_offload_info_cmd(_adapter* adapter,
+static u8 rtw_hal_set_scan_offload_info_cmd(_adapter *adapter,
 		PRSVDPAGE_LOC rsvdpageloc, u8 enable)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 
-	u8 u1H2CScanOffloadInfoParm[H2C_SCAN_OFFLOAD_CTRL_LEN]={0};
+	u8 u1H2CScanOffloadInfoParm[H2C_SCAN_OFFLOAD_CTRL_LEN] = {0};
 	u8 res = 0, count = 0, ret = _FAIL;
 
-	DBG_871X("%s: loc_probe_packet:%d, loc_scan_info: %d loc_ssid_info:%d\n",
-		__func__, rsvdpageloc->LocProbePacket,
-		rsvdpageloc->LocScanInfo, rsvdpageloc->LocSSIDInfo);
+	RTW_INFO("%s: loc_probe_packet:%d, loc_scan_info: %d loc_ssid_info:%d\n",
+		 __func__, rsvdpageloc->LocProbePacket,
+		 rsvdpageloc->LocScanInfo, rsvdpageloc->LocSSIDInfo);
 
 	SET_H2CCMD_AOAC_NLO_FUN_EN(u1H2CScanOffloadInfoParm, enable);
 	SET_H2CCMD_AOAC_NLO_IPS_EN(u1H2CScanOffloadInfoParm, enable);
 	SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(u1H2CScanOffloadInfoParm,
-			rsvdpageloc->LocScanInfo);
+					       rsvdpageloc->LocScanInfo);
 	SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(u1H2CScanOffloadInfoParm,
 			rsvdpageloc->LocProbePacket);
-	SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(u1H2CScanOffloadInfoParm,
-			rsvdpageloc->LocSSIDInfo);
-
+	/*
+		SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(u1H2CScanOffloadInfoParm,
+				rsvdpageloc->LocSSIDInfo);
+	*/
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_D0_SCAN_OFFLOAD_INFO,
-				H2C_SCAN_OFFLOAD_CTRL_LEN,
-				u1H2CScanOffloadInfoParm);
+				   H2C_D0_SCAN_OFFLOAD_INFO,
+				   H2C_SCAN_OFFLOAD_CTRL_LEN,
+				   u1H2CScanOffloadInfoParm);
 	return ret;
 }
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 
-void rtw_hal_set_fw_wow_related_cmd(_adapter* padapter, u8 enable)
+void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable)
 {
 	struct security_priv *psecpriv = &padapter->securitypriv;
 	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct registry_priv *pregistry = &padapter->registrypriv;
 	struct sta_info *psta = NULL;
 	u16 media_status_rpt;
 	u8	pkt_type = 0;
 	u8 ret = _SUCCESS;
 
-	DBG_871X_LEVEL(_drv_always_, "+%s()+: enable=%d\n", __func__, enable);
-_func_enter_;
+	RTW_PRINT("+%s()+: enable=%d\n", __func__, enable);
 
 	rtw_hal_set_wowlan_ctrl_cmd(padapter, enable, _FALSE);
 
 	if (enable) {
 		rtw_hal_set_global_info_cmd(padapter,
-				psecpriv->dot118021XGrpPrivacy,
-				psecpriv->dot11PrivacyAlgrthm);
+					    psecpriv->dot118021XGrpPrivacy,
+					    psecpriv->dot11PrivacyAlgrthm);
 
 		if (!(ppwrpriv->wowlan_pno_enable)) {
-			rtw_hal_set_disconnect_decision_cmd(padapter, enable);
+			if (pregistry->wakeup_event & BIT(2))
+				rtw_hal_set_disconnect_decision_cmd(padapter,
+								    enable);
 #ifdef CONFIG_ARP_KEEP_ALIVE
 			if ((psecpriv->dot11PrivacyAlgrthm == _WEP40_) ||
-				(psecpriv->dot11PrivacyAlgrthm == _WEP104_))
+			    (psecpriv->dot11PrivacyAlgrthm == _WEP104_))
 				pkt_type = 0;
 			else
 				pkt_type = 1;
 #else
 			pkt_type = 0;
-#endif //CONFIG_ARP_KEEP_ALIVE
+#endif /* CONFIG_ARP_KEEP_ALIVE */
 			rtw_hal_set_keep_alive_cmd(padapter, enable, pkt_type);
 		}
 		rtw_hal_set_remote_wake_ctrl_cmd(padapter, enable);
 #ifdef CONFIG_PNO_SUPPORT
 		rtw_hal_check_pno_enabled(padapter);
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 	} else {
 #if 0
 		{
@@ -2664,17 +4869,16 @@ _func_enter_;
 
 		rtw_hal_set_remote_wake_ctrl_cmd(padapter, enable);
 	}
-_func_exit_;
-	DBG_871X_LEVEL(_drv_always_, "-%s()-\n", __func__);
+	RTW_PRINT("-%s()-\n", __func__);
 }
-#endif //CONFIG_WOWLAN
+#endif /* CONFIG_WOWLAN */
 
 #ifdef CONFIG_AP_WOWLAN
 static u8 rtw_hal_set_ap_wowlan_ctrl_cmd(_adapter *adapter, u8 enable)
 {
 	struct security_priv *psecpriv = &adapter->securitypriv;
 	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 
 	u8 u1H2CAPWoWlanCtrlParm[H2C_AP_WOW_GPIO_CTRL_LEN] = {0};
 	u8 gpionum = 0, gpio_dur = 0;
@@ -2689,66 +4893,66 @@ static u8 rtw_hal_set_ap_wowlan_ctrl_cmd(_adapter *adapter, u8 enable)
 	sdio_wakeup_enable = 0;
 #endif /*CONFIG_GPIO_WAKEUP*/
 
-	DBG_871X("%s(): enable=%d\n", __func__, enable);
+	RTW_INFO("%s(): enable=%d\n", __func__, enable);
 
 	SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(u1H2CAPWoWlanCtrlParm,
-			gpionum);
+					  gpionum);
 	SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(u1H2CAPWoWlanCtrlParm,
-			gpio_pulse);
+					 gpio_pulse);
 	SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(u1H2CAPWoWlanCtrlParm,
-			gpio_high_active);
+						gpio_high_active);
 	SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(u1H2CAPWoWlanCtrlParm,
-			enable);
+				       enable);
 	SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(u1H2CAPWoWlanCtrlParm,
-			gpio_dur);
+					     gpio_dur);
 
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_AP_WOW_GPIO_CTRL,
-				H2C_AP_WOW_GPIO_CTRL_LEN,
-				u1H2CAPWoWlanCtrlParm);
+				   H2C_AP_WOW_GPIO_CTRL,
+				   H2C_AP_WOW_GPIO_CTRL_LEN,
+				   u1H2CAPWoWlanCtrlParm);
 
 	return ret;
 }
 
 static u8 rtw_hal_set_ap_offload_ctrl_cmd(_adapter *adapter, u8 enable)
 {
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	u8 u1H2CAPOffloadCtrlParm[H2C_WOWLAN_LEN] = {0};
 	u8 ret = _FAIL;
 
-	DBG_871X("%s(): bFuncEn=%d\n", __func__, enable);
+	RTW_INFO("%s(): bFuncEn=%d\n", __func__, enable);
 
 	SET_H2CCMD_AP_WOWLAN_EN(u1H2CAPOffloadCtrlParm, enable);
 
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_AP_OFFLOAD,
-				H2C_AP_OFFLOAD_LEN,
-				u1H2CAPOffloadCtrlParm);
+				   H2C_AP_OFFLOAD,
+				   H2C_AP_OFFLOAD_LEN,
+				   u1H2CAPOffloadCtrlParm);
 
 	return ret;
 }
 
 static u8 rtw_hal_set_ap_ps_cmd(_adapter *adapter, u8 enable)
 {
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	u8 ap_ps_parm[H2C_AP_PS_LEN] = {0};
 	u8 ret = _FAIL;
 
-	DBG_871X("%s(): enable=%d\n" , __func__ , enable);
-	
+	RTW_INFO("%s(): enable=%d\n" , __func__ , enable);
+
 	SET_H2CCMD_AP_WOW_PS_EN(ap_ps_parm, enable);
 #ifndef CONFIG_USB_HCI
 	SET_H2CCMD_AP_WOW_PS_32K_EN(ap_ps_parm, enable);
 #endif /*CONFIG_USB_HCI*/
 	SET_H2CCMD_AP_WOW_PS_RF(ap_ps_parm, enable);
-	
+
 	if (enable)
 		SET_H2CCMD_AP_WOW_PS_DURATION(ap_ps_parm, 0x32);
 	else
 		SET_H2CCMD_AP_WOW_PS_DURATION(ap_ps_parm, 0x0);
-		
+
 	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_SAP_PS_,
-			H2C_AP_PS_LEN, ap_ps_parm);
+				   H2C_AP_PS_LEN, ap_ps_parm);
 
 	return ret;
 }
@@ -2756,30 +4960,30 @@ static u8 rtw_hal_set_ap_ps_cmd(_adapter *adapter, u8 enable)
 static void rtw_hal_set_ap_rsvdpage_loc_cmd(PADAPTER padapter,
 		PRSVDPAGE_LOC rsvdpageloc)
 {
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 	u8 rsvdparm[H2C_AOAC_RSVDPAGE_LOC_LEN] = {0};
 	u8 ret = _FAIL, header = 0;
 
 	if (pHalFunc->fill_h2c_cmd == NULL) {
-		DBG_871X("%s: Please hook fill_h2c_cmd first!\n", __func__);
+		RTW_INFO("%s: Please hook fill_h2c_cmd first!\n", __func__);
 		return;
 	}
 
 	header = rtw_read8(padapter, REG_BCNQ_BDNY);
 
-	DBG_871X("%s: beacon: %d, probeRsp: %d, header:0x%02x\n", __func__,
-			rsvdpageloc->LocApOffloadBCN,
-			rsvdpageloc->LocProbeRsp,
-			header);
+	RTW_INFO("%s: beacon: %d, probeRsp: %d, header:0x%02x\n", __func__,
+		 rsvdpageloc->LocApOffloadBCN,
+		 rsvdpageloc->LocProbeRsp,
+		 header);
 
 	SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(rsvdparm,
-			rsvdpageloc->LocApOffloadBCN + header);
+				      rsvdpageloc->LocApOffloadBCN + header);
 
 	ret = rtw_hal_fill_h2c_cmd(padapter, H2C_BCN_RSVDPAGE,
-				H2C_BCN_RSVDPAGE_LEN, rsvdparm);
+				   H2C_BCN_RSVDPAGE_LEN, rsvdparm);
 
 	if (ret == _FAIL)
-		DBG_871X("%s: H2C_BCN_RSVDPAGE cmd fail\n", __func__);
+		RTW_INFO("%s: H2C_BCN_RSVDPAGE cmd fail\n", __func__);
 
 	rtw_msleep_os(10);
 
@@ -2789,10 +4993,10 @@ static void rtw_hal_set_ap_rsvdpage_loc_cmd(PADAPTER padapter,
 			rsvdpageloc->LocProbeRsp + header);
 
 	ret = rtw_hal_fill_h2c_cmd(padapter, H2C_PROBERSP_RSVDPAGE,
-				H2C_PROBERSP_RSVDPAGE_LEN, rsvdparm);
+				   H2C_PROBERSP_RSVDPAGE_LEN, rsvdparm);
 
 	if (ret == _FAIL)
-		DBG_871X("%s: H2C_PROBERSP_RSVDPAGE cmd fail\n", __func__);
+		RTW_INFO("%s: H2C_PROBERSP_RSVDPAGE cmd fail\n", __func__);
 
 	rtw_msleep_os(10);
 }
@@ -2809,8 +5013,9 @@ static void rtw_hal_ap_wow_enable(_adapter *padapter)
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 	struct sta_info *psta = NULL;
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 #ifdef DBG_CHECK_FW_PS_STATE
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
@@ -2818,11 +5023,11 @@ static void rtw_hal_ap_wow_enable(_adapter *padapter)
 	int res;
 	u16 media_status_rpt;
 
-	DBG_871X("%s, WOWLAN_AP_ENABLE\n", __func__);
+	RTW_INFO("%s, WOWLAN_AP_ENABLE\n", __func__);
 #ifdef DBG_CHECK_FW_PS_STATE
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
 		pdbgpriv->dbg_enwow_dload_fw_fail_cnt++;
-		DBG_871X_LEVEL(_drv_always_, "wowlan enable no leave 32k\n");
+		RTW_PRINT("wowlan enable no leave 32k\n");
 	}
 #endif /*DBG_CHECK_FW_PS_STATE*/
 
@@ -2831,52 +5036,51 @@ static void rtw_hal_ap_wow_enable(_adapter *padapter)
 
 	media_status_rpt = RT_MEDIA_CONNECT;
 	rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT,
-		(u8 *)&media_status_rpt);
+			  (u8 *)&media_status_rpt);
 
 	issue_beacon(padapter, 0);
 
 	rtw_msleep_os(2);
-
+	#if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(padapter))
 		rtw_hal_disable_tx_report(padapter);
-
+	#endif
 	/* RX DMA stop */
 	res = rtw_hal_pause_rx_dma(padapter);
 	if (res == _FAIL)
-		DBG_871X_LEVEL(_drv_always_, "[WARNING] pause RX DMA fail\n");
+		RTW_PRINT("[WARNING] pause RX DMA fail\n");
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 	/* Enable CPWM2 only. */
 	res = rtw_hal_enable_cpwm2(padapter);
 	if (res == _FAIL)
-		DBG_871X_LEVEL(_drv_always_, "[WARNING] enable cpwm2 fail\n");
+		RTW_PRINT("[WARNING] enable cpwm2 fail\n");
 #endif
 
 #ifdef CONFIG_GPIO_WAKEUP
 	rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
 #endif
 	/* 5. Set Enable WOWLAN H2C command. */
-	DBG_871X_LEVEL(_drv_always_, "Set Enable AP WOWLan cmd\n");
+	RTW_PRINT("Set Enable AP WOWLan cmd\n");
 	rtw_hal_set_fw_ap_wow_related_cmd(padapter, 1);
-		
+
 	rtw_write8(padapter, REG_MCUTST_WOWLAN, 0);
-#ifdef CONFIG_USB_HCI 
-	if (padapter->intf_stop)
-		padapter->intf_stop(padapter);
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter))/*free buddy adapter's resource*/
-		padapter->pbuddy_adapter->intf_stop(padapter->pbuddy_adapter);
-#endif /*CONFIG_CONCURRENT_MODE*/
-		/* Invoid SE0 reset signal during suspending*/
+#ifdef CONFIG_USB_HCI
+	rtw_mi_intf_stop(padapter);
+#endif
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
+	/* Invoid SE0 reset signal during suspending*/
 	rtw_write8(padapter, REG_RSV_CTRL, 0x20);
-	rtw_write8(padapter, REG_RSV_CTRL, 0x60);
-#endif /*CONFIG_USB_HCI*/
+	if (IS_8188F(pHalData->version_id) == FALSE
+		&& IS_8188GTV(pHalData->version_id) == FALSE)
+		rtw_write8(padapter, REG_RSV_CTRL, 0x60);
+#endif
 }
 
 static void rtw_hal_ap_wow_disable(_adapter *padapter)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 #ifdef DBG_CHECK_FW_PS_STATE
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
@@ -2884,12 +5088,12 @@ static void rtw_hal_ap_wow_disable(_adapter *padapter)
 	u16 media_status_rpt;
 	u8 val8;
 
-	DBG_871X("%s, WOWLAN_AP_DISABLE\n", __func__);
+	RTW_INFO("%s, WOWLAN_AP_DISABLE\n", __func__);
 	/* 1. Read wakeup reason*/
 	pwrctl->wowlan_wake_reason = rtw_read8(padapter, REG_MCUTST_WOWLAN);
 
-	DBG_871X_LEVEL(_drv_always_, "wakeup_reason: 0x%02x\n",
-		pwrctl->wowlan_wake_reason);
+	RTW_PRINT("wakeup_reason: 0x%02x\n",
+		  pwrctl->wowlan_wake_reason);
 
 	rtw_hal_set_fw_ap_wow_related_cmd(padapter, 0);
 
@@ -2897,26 +5101,37 @@ static void rtw_hal_ap_wow_disable(_adapter *padapter)
 #ifdef DBG_CHECK_FW_PS_STATE
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
 		pdbgpriv->dbg_diswow_dload_fw_fail_cnt++;
-		DBG_871X_LEVEL(_drv_always_, "wowlan enable no leave 32k\n");
+		RTW_PRINT("wowlan enable no leave 32k\n");
 	}
 #endif /*DBG_CHECK_FW_PS_STATE*/
 
+	#if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(padapter))
 		rtw_hal_enable_tx_report(padapter);
+	#endif
 
 	rtw_hal_force_enable_rxdma(padapter);
 
 	rtw_hal_fw_dl(padapter, _FALSE);
 
 #ifdef CONFIG_GPIO_WAKEUP
+	#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
+	if (pwrctl->is_high_active == 0)
+		rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
+	else
+		rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
+	#else
 	val8 = (pwrctl->is_high_active == 0) ? 1 : 0;
-	DBG_871X_LEVEL(_drv_always_, "Set Wake GPIO to default(%d).\n", val8);
+	RTW_PRINT("Set Wake GPIO to default(%d).\n", val8);
 	rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
+
+	rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _FALSE);
+	#endif/*CONFIG_WAKEUP_GPIO_INPUT_MODE*/
 #endif
 	media_status_rpt = RT_MEDIA_CONNECT;
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT,
-				(u8 *)&media_status_rpt);
+			  (u8 *)&media_status_rpt);
 
 	issue_beacon(padapter, 0);
 }
@@ -2928,33 +5143,30 @@ static int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
 	u8 *ssid_ie;
 	sint ssid_len_ori;
 	int len_diff = 0;
-	
+
 	ssid_ie = rtw_get_ie(ies,  WLAN_EID_SSID, &ssid_len_ori, ies_len);
 
-	//DBG_871X("%s hidden_ssid_mode:%u, ssid_ie:%p, ssid_len_ori:%d\n", __FUNCTION__, hidden_ssid_mode, ssid_ie, ssid_len_ori);
-	
-	if(ssid_ie && ssid_len_ori>0)
-	{
-		switch(hidden_ssid_mode)
-		{
-			case 1:
-			{
-				u8 *next_ie = ssid_ie + 2 + ssid_len_ori;
-				u32 remain_len = 0;
-				
-				remain_len = ies_len -(next_ie-ies);
-				
-				ssid_ie[1] = 0;				
-				_rtw_memcpy(ssid_ie+2, next_ie, remain_len);
-				len_diff -= ssid_len_ori;
-				
-				break;
-			}		
-			case 2:
-				_rtw_memset(&ssid_ie[2], 0, ssid_len_ori);
-				break;
-			default:
-				break;
+	/* RTW_INFO("%s hidden_ssid_mode:%u, ssid_ie:%p, ssid_len_ori:%d\n", __FUNCTION__, hidden_ssid_mode, ssid_ie, ssid_len_ori); */
+
+	if (ssid_ie && ssid_len_ori > 0) {
+		switch (hidden_ssid_mode) {
+		case 1: {
+			u8 *next_ie = ssid_ie + 2 + ssid_len_ori;
+			u32 remain_len = 0;
+
+			remain_len = ies_len - (next_ie - ies);
+
+			ssid_ie[1] = 0;
+			_rtw_memcpy(ssid_ie + 2, next_ie, remain_len);
+			len_diff -= ssid_len_ori;
+
+			break;
+		}
+		case 2:
+			_rtw_memset(&ssid_ie[2], 0, ssid_len_ori);
+			break;
+		default:
+			break;
 		}
 	}
 
@@ -2963,67 +5175,65 @@ static int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
 
 static void rtw_hal_construct_P2PBeacon(_adapter *padapter, u8 *pframe, u32 *pLength)
 {
-	//struct xmit_frame	*pmgntframe;
-	//struct pkt_attrib	*pattrib;
-	//unsigned char	*pframe;
+	/* struct xmit_frame	*pmgntframe; */
+	/* struct pkt_attrib	*pattrib; */
+	/* unsigned char	*pframe; */
 	struct rtw_ieee80211_hdr *pwlanhdr;
 	unsigned short *fctrl;
 	unsigned int	rate_len;
 	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
 	u32	pktlen;
-//#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-//	_irqL irqL;
-//	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-//#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	/* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
+	/*	_irqL irqL;
+	 *	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	 * #endif */ /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
 	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 #ifdef CONFIG_P2P
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
-	//for debug
+	/* for debug */
 	u8 *dbgbuf = pframe;
 	u8 dbgbufLen = 0, index = 0;
 
-	DBG_871X("%s\n", __FUNCTION__);
-//#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-//	_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
-//#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-		
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;	
-	
-	
+	RTW_INFO("%s\n", __FUNCTION__);
+	/* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
+	/*	_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
+	 * #endif */ /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
-	
+
 	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
-	//pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_BEACON);
-	
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);	
-	pktlen = sizeof (struct rtw_ieee80211_hdr_3addr);
-	
-	if( (pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
-		//DBG_871X("ie len=%d\n", cur_network->IELength);
+	/* pmlmeext->mgnt_seq++; */
+	set_frame_sub_type(pframe, WIFI_BEACON);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+		/* RTW_INFO("ie len=%d\n", cur_network->IELength); */
 #ifdef CONFIG_P2P
-		// for P2P : Primary Device Type & Device Name
-		u32 wpsielen=0, insert_len=0;
-		u8 *wpsie=NULL;		
-		wpsie = rtw_get_wps_ie(cur_network->IEs+_FIXED_IE_LENGTH_, cur_network->IELength-_FIXED_IE_LENGTH_, NULL, &wpsielen);
-		
-		if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && wpsie && wpsielen>0)
-		{
+		/* for P2P : Primary Device Type & Device Name */
+		u32 wpsielen = 0, insert_len = 0;
+		u8 *wpsie = NULL;
+		wpsie = rtw_get_wps_ie(cur_network->IEs + _FIXED_IE_LENGTH_, cur_network->IELength - _FIXED_IE_LENGTH_, NULL, &wpsielen);
+
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && wpsie && wpsielen > 0) {
 			uint wps_offset, remainder_ielen;
 			u8 *premainder_ie, *pframe_wscie;
-	
+
 			wps_offset = (uint)(wpsie - cur_network->IEs);
 
 			premainder_ie = wpsie + wpsielen;
@@ -3031,10 +5241,8 @@ static void rtw_hal_construct_P2PBeacon(_adapter *padapter, u8 *pframe, u32 *pLe
 			remainder_ielen = cur_network->IELength - wps_offset - wpsielen;
 
 #ifdef CONFIG_IOCTL_CFG80211
-			if(pwdinfo->driver_interface == DRIVER_CFG80211 )
-			{
-				if(pmlmepriv->wps_beacon_ie && pmlmepriv->wps_beacon_ie_len>0)
-				{
+			if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+				if (pmlmepriv->wps_beacon_ie && pmlmepriv->wps_beacon_ie_len > 0) {
 					_rtw_memcpy(pframe, cur_network->IEs, wps_offset);
 					pframe += wps_offset;
 					pktlen += wps_offset;
@@ -3043,119 +5251,111 @@ static void rtw_hal_construct_P2PBeacon(_adapter *padapter, u8 *pframe, u32 *pLe
 					pframe += pmlmepriv->wps_beacon_ie_len;
 					pktlen += pmlmepriv->wps_beacon_ie_len;
 
-					//copy remainder_ie to pframe
+					/* copy remainder_ie to pframe */
 					_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
-					pframe += remainder_ielen;		
+					pframe += remainder_ielen;
 					pktlen += remainder_ielen;
-				}
-				else
-				{
+				} else {
 					_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
 					pframe += cur_network->IELength;
 					pktlen += cur_network->IELength;
 				}
-			}
-			else
-#endif //CONFIG_IOCTL_CFG80211
+			} else
+#endif /* CONFIG_IOCTL_CFG80211 */
 			{
 				pframe_wscie = pframe + wps_offset;
-				_rtw_memcpy(pframe, cur_network->IEs, wps_offset+wpsielen);			
-				pframe += (wps_offset + wpsielen);		
+				_rtw_memcpy(pframe, cur_network->IEs, wps_offset + wpsielen);
+				pframe += (wps_offset + wpsielen);
 				pktlen += (wps_offset + wpsielen);
 
-				//now pframe is end of wsc ie, insert Primary Device Type & Device Name
-				//	Primary Device Type
-				//	Type:
-				*(u16*) ( pframe + insert_len) = cpu_to_be16( WPS_ATTR_PRIMARY_DEV_TYPE );
+				/* now pframe is end of wsc ie, insert Primary Device Type & Device Name */
+				/*	Primary Device Type */
+				/*	Type: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
 				insert_len += 2;
-				
-				//	Length:
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( 0x0008 );
+
+				/*	Length: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(0x0008);
 				insert_len += 2;
-				
-				//	Value:
-				//	Category ID
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+
+				/*	Value: */
+				/*	Category ID */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
 				insert_len += 2;
 
-				//	OUI
-				*(u32*) ( pframe + insert_len ) = cpu_to_be32( WPSOUI );
+				/*	OUI */
+				*(u32 *)(pframe + insert_len) = cpu_to_be32(WPSOUI);
 				insert_len += 4;
 
-				//	Sub Category ID
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+				/*	Sub Category ID */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
 				insert_len += 2;
 
 
-				//	Device Name
-				//	Type:
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+				/*	Device Name */
+				/*	Type: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 				insert_len += 2;
 
-				//	Length:
-				*(u16*) ( pframe + insert_len ) = cpu_to_be16( pwdinfo->device_name_len );
+				/*	Length: */
+				*(u16 *)(pframe + insert_len) = cpu_to_be16(pwdinfo->device_name_len);
 				insert_len += 2;
 
-				//	Value:
-				_rtw_memcpy( pframe + insert_len, pwdinfo->device_name, pwdinfo->device_name_len );
+				/*	Value: */
+				_rtw_memcpy(pframe + insert_len, pwdinfo->device_name, pwdinfo->device_name_len);
 				insert_len += pwdinfo->device_name_len;
 
 
-				//update wsc ie length
-				*(pframe_wscie+1) = (wpsielen -2) + insert_len;
+				/* update wsc ie length */
+				*(pframe_wscie + 1) = (wpsielen - 2) + insert_len;
 
-				//pframe move to end
-				pframe+=insert_len;
+				/* pframe move to end */
+				pframe += insert_len;
 				pktlen += insert_len;
 
-				//copy remainder_ie to pframe
+				/* copy remainder_ie to pframe */
 				_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
-				pframe += remainder_ielen;		
+				pframe += remainder_ielen;
 				pktlen += remainder_ielen;
 			}
-		}
-		else
-#endif //CONFIG_P2P
+		} else
+#endif /* CONFIG_P2P */
 		{
 			int len_diff;
 			_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
 			len_diff = update_hidden_ssid(
-				pframe+_BEACON_IE_OFFSET_
-				, cur_network->IELength-_BEACON_IE_OFFSET_
-				, pmlmeinfo->hidden_ssid_mode
-			);
-			pframe += (cur_network->IELength+len_diff);
-			pktlen += (cur_network->IELength+len_diff);
+					   pframe + _BEACON_IE_OFFSET_
+				   , cur_network->IELength - _BEACON_IE_OFFSET_
+					   , pmlmeinfo->hidden_ssid_mode
+				   );
+			pframe += (cur_network->IELength + len_diff);
+			pktlen += (cur_network->IELength + len_diff);
 		}
 #if 0
 		{
 			u8 *wps_ie;
 			uint wps_ielen;
 			u8 sr = 0;
-			wps_ie = rtw_get_wps_ie(pmgntframe->buf_addr+TXDESC_OFFSET+sizeof (struct rtw_ieee80211_hdr_3addr)+_BEACON_IE_OFFSET_,
-				pattrib->pktlen-sizeof (struct rtw_ieee80211_hdr_3addr)-_BEACON_IE_OFFSET_, NULL, &wps_ielen);
-			if (wps_ie && wps_ielen>0) {
-				rtw_get_wps_attr_content(wps_ie,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8*)(&sr), NULL);
-			}
+			wps_ie = rtw_get_wps_ie(pmgntframe->buf_addr + TXDESC_OFFSET + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_,
+				pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_, NULL, &wps_ielen);
+			if (wps_ie && wps_ielen > 0)
+				rtw_get_wps_attr_content(wps_ie,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
 			if (sr != 0)
 				set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
 			else
 				_clr_fwstate_(pmlmepriv, WIFI_UNDER_WPS);
 		}
-#endif 
+#endif
 #ifdef CONFIG_P2P
-		if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-		{
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
 			u32 len;
 #ifdef CONFIG_IOCTL_CFG80211
-			if(pwdinfo->driver_interface == DRIVER_CFG80211 )
-			{
+			if (pwdinfo->driver_interface == DRIVER_CFG80211) {
 				len = pmlmepriv->p2p_beacon_ie_len;
-				if(pmlmepriv->p2p_beacon_ie && len>0)				
+				if (pmlmepriv->p2p_beacon_ie && len > 0)
 					_rtw_memcpy(pframe, pmlmepriv->p2p_beacon_ie, len);
-			}
-			else
-#endif //CONFIG_IOCTL_CFG80211
+			} else
+#endif /* CONFIG_IOCTL_CFG80211 */
 			{
 				len = build_beacon_p2p_ie(pwdinfo, pframe);
 			}
@@ -3170,112 +5370,99 @@ static void rtw_hal_construct_P2PBeacon(_adapter *padapter, u8 *pframe, u32 *pLe
 			#endif
 
 		}
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 		goto _issue_bcn;
 
 	}
 
-	//below for ad-hoc mode
+	/* below for ad-hoc mode */
 
-	//timestamp will be inserted by hardware
+	/* timestamp will be inserted by hardware */
 	pframe += 8;
 	pktlen += 8;
 
-	// beacon interval: 2 bytes
+	/* beacon interval: 2 bytes */
 
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2); 
+	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
 
 	pframe += 2;
 	pktlen += 2;
 
-	// capability info: 2 bytes
+	/* capability info: 2 bytes */
 
 	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
 
 	pframe += 2;
 	pktlen += 2;
 
-	// SSID
+	/* SSID */
 	pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pktlen);
 
-	// supported rates...
+	/* supported rates... */
 	rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
-	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8)? 8: rate_len), cur_network->SupportedRates, &pktlen);
+	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pktlen);
 
-	// DS parameter set
+	/* DS parameter set */
 	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pktlen);
 
-	//if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)
+	/* if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) */
 	{
-		u8 erpinfo=0;
+		u8 erpinfo = 0;
 		u32 ATIMWindow;
-		// IBSS Parameter Set...
-		//ATIMWindow = cur->Configuration.ATIMWindow;
+		/* IBSS Parameter Set... */
+		/* ATIMWindow = cur->Configuration.ATIMWindow; */
 		ATIMWindow = 0;
 		pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pktlen);
 
-		//ERP IE
+		/* ERP IE */
 		pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pktlen);
-	}	
+	}
 
 
-	// EXTERNDED SUPPORTED RATE
+	/* EXTERNDED SUPPORTED RATE */
 	if (rate_len > 8)
-	{
 		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pktlen);
-	}
 
 
-	//todo:HT for adhoc
+	/* todo:HT for adhoc */
 
 _issue_bcn:
 
-//#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
-//	pmlmepriv->update_bcn = _FALSE;
-//	
-//	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);	
-//#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	/* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
+	/*	pmlmepriv->update_bcn = _FALSE;
+	 *
+	 *	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
+	 * #endif */ /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 
 	*pLength = pktlen;
 #if 0
-	// printf dbg msg
+	/* printf dbg msg */
 	dbgbufLen = pktlen;
-	DBG_871X("======> DBG MSG FOR CONSTRAUCT P2P BEACON\n");
+	RTW_INFO("======> DBG MSG FOR CONSTRAUCT P2P BEACON\n");
 
-	for(index=0;index<dbgbufLen;index++)
-		printk("%x ",*(dbgbuf+index));
+	for (index = 0; index < dbgbufLen; index++)
+		printk("%x ", *(dbgbuf + index));
 
 	printk("\n");
-	DBG_871X("<====== DBG MSG FOR CONSTRAUCT P2P BEACON\n");
-	
-#endif
-}
-
-static int get_reg_classes_full_count(struct p2p_channels channel_list) {
-	int cnt = 0;
-	int i;
-
-	for (i = 0; i < channel_list.reg_classes; i++) {
-		cnt += channel_list.reg_class[i].channels;
-	}
+	RTW_INFO("<====== DBG MSG FOR CONSTRAUCT P2P BEACON\n");
 
-	return cnt;
+#endif
 }
 
 static void rtw_hal_construct_P2PProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
 {
-	//struct xmit_frame			*pmgntframe;
-	//struct pkt_attrib			*pattrib;
-	//unsigned char					*pframe;
+	/* struct xmit_frame			*pmgntframe; */
+	/* struct pkt_attrib			*pattrib; */
+	/* unsigned char					*pframe; */
 	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short				*fctrl;	
+	unsigned short				*fctrl;
 	unsigned char					*mac;
 	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	//WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	/* WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network); */
 	u16					beacon_interval = 100;
 	u16					capInfo = 0;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
@@ -3287,283 +5474,277 @@ static void rtw_hal_construct_P2PProbeRsp(_adapter *padapter, u8 *pframe, u32 *p
 #endif
 #ifdef CONFIG_INTEL_WIDI
 	u8 zero_array_check[L2SDTA_SERVICE_VE_LEN] = { 0x00 };
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-	//for debug
+	/* for debug */
 	u8 *dbgbuf = pframe;
 	u8 dbgbufLen = 0, index = 0;
 
-	DBG_871X("%s\n", __FUNCTION__);
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;	
-	
+	RTW_INFO("%s\n", __FUNCTION__);
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
 	mac = adapter_mac_addr(padapter);
-	
+
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	//DA filled by FW
+	/* DA filled by FW */
 	_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
-	
-	//	Use the device address for BSSID field.	
+
+	/*	Use the device address for BSSID field.	 */
 	_rtw_memcpy(pwlanhdr->addr3, mac, ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0);
-	SetFrameSubType(fctrl, WIFI_PROBERSP);
+	set_frame_sub_type(fctrl, WIFI_PROBERSP);
 
- 	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
- 	pframe += pktlen;
+	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	pframe += pktlen;
 
 
-	//timestamp will be inserted by hardware
+	/* timestamp will be inserted by hardware */
 	pframe += 8;
 	pktlen += 8;
 
-	// beacon interval: 2 bytes
-	_rtw_memcpy(pframe, (unsigned char *) &beacon_interval, 2); 
+	/* beacon interval: 2 bytes */
+	_rtw_memcpy(pframe, (unsigned char *) &beacon_interval, 2);
 	pframe += 2;
 	pktlen += 2;
 
-	//	capability info: 2 bytes
-	//	ESS and IBSS bits must be 0 (defined in the 3.1.2.1.1 of WiFi Direct Spec)
+	/*	capability info: 2 bytes */
+	/*	ESS and IBSS bits must be 0 (defined in the 3.1.2.1.1 of WiFi Direct Spec) */
 	capInfo |= cap_ShortPremble;
 	capInfo |= cap_ShortSlot;
-	
+
 	_rtw_memcpy(pframe, (unsigned char *) &capInfo, 2);
 	pframe += 2;
 	pktlen += 2;
 
 
-	// SSID
+	/* SSID */
 	pframe = rtw_set_ie(pframe, _SSID_IE_, 7, pwdinfo->p2p_wildcard_ssid, &pktlen);
 
-	// supported rates...
-	//	Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 )
+	/* supported rates... */
+	/*	Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 ) */
 	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pwdinfo->support_rate, &pktlen);
 
-	// DS parameter set
+	/* DS parameter set */
 	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&pwdinfo->listen_channel, &pktlen);
 
 #ifdef CONFIG_IOCTL_CFG80211
-	if(pwdinfo->driver_interface == DRIVER_CFG80211 )
-	{
-		if( pmlmepriv->wps_probe_resp_ie != NULL && pmlmepriv->p2p_probe_resp_ie != NULL )
-		{
-			//WPS IE
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (pmlmepriv->wps_probe_resp_ie != NULL && pmlmepriv->p2p_probe_resp_ie != NULL) {
+			/* WPS IE */
 			_rtw_memcpy(pframe, pmlmepriv->wps_probe_resp_ie, pmlmepriv->wps_probe_resp_ie_len);
 			pktlen += pmlmepriv->wps_probe_resp_ie_len;
 			pframe += pmlmepriv->wps_probe_resp_ie_len;
 
-			//P2P IE
+			/* P2P IE */
 			_rtw_memcpy(pframe, pmlmepriv->p2p_probe_resp_ie, pmlmepriv->p2p_probe_resp_ie_len);
 			pktlen += pmlmepriv->p2p_probe_resp_ie_len;
 			pframe += pmlmepriv->p2p_probe_resp_ie_len;
 		}
-	}
-	else
-#endif //CONFIG_IOCTL_CFG80211		
+	} else
+#endif /* CONFIG_IOCTL_CFG80211		 */
 	{
 
-		//	Todo: WPS IE
-		//	Noted by Albert 20100907
-		//	According to the WPS specification, all the WPS attribute is presented by Big Endian.
+		/*	Todo: WPS IE */
+		/*	Noted by Albert 20100907 */
+		/*	According to the WPS specification, all the WPS attribute is presented by Big Endian. */
 
 		wpsielen = 0;
-		//	WPS OUI
-		*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+		/*	WPS OUI */
+		*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
 		wpsielen += 4;
 
-		//	WPS version
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+		/*	WPS version */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
-		wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+		/*	Value: */
+		wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 
 #ifdef CONFIG_INTEL_WIDI
-		//	Commented by Kurt
-		//	Appended WiDi info. only if we did issued_probereq_widi(), and then we saved ven. ext. in pmlmepriv->sa_ext.
-		if(  _rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE 
-			|| pmlmepriv->num_p2p_sdt != 0 )
-		{
-			//Sec dev type
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_SEC_DEV_TYPE_LIST );
+		/*	Commented by Kurt */
+		/*	Appended WiDi info. only if we did issued_probereq_widi(), and then we saved ven. ext. in pmlmepriv->sa_ext. */
+		if (_rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE
+		    || pmlmepriv->num_p2p_sdt != 0) {
+			/* Sec dev type */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SEC_DEV_TYPE_LIST);
 			wpsielen += 2;
 
-			//	Length:
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0008 );
+			/*	Length: */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
 			wpsielen += 2;
 
-			//	Value:
-			//	Category ID
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_CID_DISPLAYS );
+			/*	Value: */
+			/*	Category ID */
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_DISPLAYS);
 			wpsielen += 2;
 
-			//	OUI
-			*(u32*) ( wpsie + wpsielen ) = cpu_to_be32( INTEL_DEV_TYPE_OUI );
+			/*	OUI */
+			*(u32 *)(wpsie + wpsielen) = cpu_to_be32(INTEL_DEV_TYPE_OUI);
 			wpsielen += 4;
 
-			*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_SCID_WIDI_CONSUMER_SINK );
+			*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_WIDI_CONSUMER_SINK);
 			wpsielen += 2;
 
-			if(  _rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE )
-			{
-				//	Vendor Extension
-				_rtw_memcpy( wpsie + wpsielen, pmlmepriv->sa_ext, L2SDTA_SERVICE_VE_LEN );
+			if (_rtw_memcmp(pmlmepriv->sa_ext, zero_array_check, L2SDTA_SERVICE_VE_LEN) == _FALSE) {
+				/*	Vendor Extension */
+				_rtw_memcpy(wpsie + wpsielen, pmlmepriv->sa_ext, L2SDTA_SERVICE_VE_LEN);
 				wpsielen += L2SDTA_SERVICE_VE_LEN;
 			}
 		}
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-		//	WiFi Simple Config State
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_SIMPLE_CONF_STATE );
+		/*	WiFi Simple Config State */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SIMPLE_CONF_STATE);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
-		wpsie[wpsielen++] = WPS_WSC_STATE_NOT_CONFIG;	//	Not Configured.
+		/*	Value: */
+		wpsie[wpsielen++] = WPS_WSC_STATE_NOT_CONFIG;	/*	Not Configured. */
 
-		//	Response Type
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_RESP_TYPE );
+		/*	Response Type */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_RESP_TYPE);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
+		/*	Value: */
 		wpsie[wpsielen++] = WPS_RESPONSE_TYPE_8021X;
 
-		//	UUID-E
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_UUID_E );
+		/*	UUID-E */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_UUID_E);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0010 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0010);
 		wpsielen += 2;
 
-		//	Value:
+		/*	Value: */
 		if (pwdinfo->external_uuid == 0) {
-			_rtw_memset( wpsie + wpsielen, 0x0, 16 );
+			_rtw_memset(wpsie + wpsielen, 0x0, 16);
 			_rtw_memcpy(wpsie + wpsielen, mac, ETH_ALEN);
-		} else {
-			_rtw_memcpy( wpsie + wpsielen, pwdinfo->uuid, 0x10 );
-		}
+		} else
+			_rtw_memcpy(wpsie + wpsielen, pwdinfo->uuid, 0x10);
 		wpsielen += 0x10;
 
-		//	Manufacturer
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_MANUFACTURER );
+		/*	Manufacturer */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MANUFACTURER);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0007 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0007);
 		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, "Realtek", 7 );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, "Realtek", 7);
 		wpsielen += 7;
 
-		//	Model Name
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_MODEL_NAME );
+		/*	Model Name */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NAME);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0006 );
-		wpsielen += 2;	
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0006);
+		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, "8192CU", 6 );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, "8192CU", 6);
 		wpsielen += 6;
 
-		//	Model Number
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_MODEL_NUMBER );
+		/*	Model Number */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NUMBER);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 		wpsielen += 2;
 
-		//	Value:
-		wpsie[ wpsielen++ ] = 0x31;		//	character 1
+		/*	Value: */
+		wpsie[wpsielen++] = 0x31;		/*	character 1 */
 
-		//	Serial Number
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_SERIAL_NUMBER );
+		/*	Serial Number */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SERIAL_NUMBER);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( ETH_ALEN );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(ETH_ALEN);
 		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, "123456" , ETH_ALEN );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, "123456" , ETH_ALEN);
 		wpsielen += ETH_ALEN;
 
-		//	Primary Device Type
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_PRIMARY_DEV_TYPE );
+		/*	Primary Device Type */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0008 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
 		wpsielen += 2;
 
-		//	Value:
-		//	Category ID
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+		/*	Value: */
+		/*	Category ID */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
 		wpsielen += 2;
 
-		//	OUI
-		*(u32*) ( wpsie + wpsielen ) = cpu_to_be32( WPSOUI );
+		/*	OUI */
+		*(u32 *)(wpsie + wpsielen) = cpu_to_be32(WPSOUI);
 		wpsielen += 4;
 
-		//	Sub Category ID
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+		/*	Sub Category ID */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
 		wpsielen += 2;
 
-		//	Device Name
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+		/*	Device Name */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->device_name_len );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->device_name_len);
 		wpsielen += 2;
 
-		//	Value:
-		_rtw_memcpy( wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len );
+		/*	Value: */
+		_rtw_memcpy(wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len);
 		wpsielen += pwdinfo->device_name_len;
 
-		//	Config Method
-		//	Type:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD );
+		/*	Config Method */
+		/*	Type: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
 		wpsielen += 2;
 
-		//	Length:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+		/*	Length: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 		wpsielen += 2;
 
-		//	Value:
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->supported_wps_cm );
+		/*	Value: */
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
 		wpsielen += 2;
-		
 
-		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen );
-		
+
+		pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen);
+
 
 		p2pielen = build_probe_resp_p2p_ie(pwdinfo, pframe);
 		pframe += p2pielen;
@@ -3579,24 +5760,25 @@ static void rtw_hal_construct_P2PProbeRsp(_adapter *padapter, u8 *pframe, u32 *p
 	*pLength = pktlen;
 
 #if 0
-	// printf dbg msg
+	/* printf dbg msg */
 	dbgbufLen = pktlen;
-	DBG_871X("======> DBG MSG FOR CONSTRAUCT P2P Probe Rsp\n");
+	RTW_INFO("======> DBG MSG FOR CONSTRAUCT P2P Probe Rsp\n");
 
-	for(index=0;index<dbgbufLen;index++)
-		printk("%x ",*(dbgbuf+index));
+	for (index = 0; index < dbgbufLen; index++)
+		printk("%x ", *(dbgbuf + index));
 
 	printk("\n");
-	DBG_871X("<====== DBG MSG FOR CONSTRAUCT P2P Probe Rsp\n");
+	RTW_INFO("<====== DBG MSG FOR CONSTRAUCT P2P Probe Rsp\n");
 #endif
 }
 static void rtw_hal_construct_P2PNegoRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
 {
+	struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_GO_NEGO_RESP;
-	u8			wpsie[ 255 ] = { 0x00 }, p2pie[ 255 ] = { 0x00 };
+	u8			wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
 	u8			p2pielen = 0, i;
 	uint			wpsielen = 0;
 	u16			wps_devicepassword_id = 0x0000;
@@ -3605,39 +5787,39 @@ static void rtw_hal_construct_P2PNegoRsp(_adapter *padapter, u8 *pframe, u32 *pL
 	u16			len_channellist_attr = 0;
 	u32			pktlen;
 	u8			dialogToken = 0;
-	
-	//struct xmit_frame			*pmgntframe;
-	//struct pkt_attrib			*pattrib;
-	//unsigned char					*pframe;
+
+	/* struct xmit_frame			*pmgntframe; */
+	/* struct pkt_attrib			*pattrib; */
+	/* unsigned char					*pframe; */
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
-	//WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	/* WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network); */
 
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
 
-	//for debug
+	/* for debug */
 	u8 *dbgbuf = pframe;
 	u8 dbgbufLen = 0, index = 0;
 
-	DBG_871X( "%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	//RA, filled by FW
+	/* RA, filled by FW */
 	_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0);
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 	pframe += pktlen;
@@ -3645,459 +5827,400 @@ static void rtw_hal_construct_P2PNegoRsp(_adapter *padapter, u8 *pframe, u32 *pL
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));	
-	
-	//dialog token, filled by FW
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));
+
+	/* dialog token, filled by FW */
 	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pktlen));
 
-	_rtw_memset( wpsie, 0x00, 255 );
+	_rtw_memset(wpsie, 0x00, 255);
 	wpsielen = 0;
 
-	//	WPS Section
+	/*	WPS Section */
 	wpsielen = 0;
-	//	WPS OUI
-	*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+	/*	WPS OUI */
+	*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
 	wpsielen += 4;
 
-	//	WPS version
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 	wpsielen += 2;
 
-	//	Value:
-	wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 
-	//	Device Password ID
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_DEVICE_PWID );
+	/*	Device Password ID */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
 	wpsielen += 2;
 
-	//	Value:
-	if ( wps_devicepassword_id == WPS_DPID_USER_SPEC )
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_REGISTRAR_SPEC );
-	}
-	else if ( wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC )
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_USER_SPEC );
-	}
+	/*	Value: */
+	if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC);
+	else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_USER_SPEC);
 	else
-	{
-		*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_DPID_PBC );
-	}
+		*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_PBC);
 	wpsielen += 2;
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen );
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen);
 
 
-	//	P2P IE Section.
+	/*	P2P IE Section. */
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20100908
-	//	According to the P2P Specification, the group negoitation response frame should contain 9 P2P attributes
-	//	1. Status
-	//	2. P2P Capability
-	//	3. Group Owner Intent
-	//	4. Configuration Timeout
-	//	5. Operating Channel
-	//	6. Intended P2P Interface Address
-	//	7. Channel List
-	//	8. Device Info
-	//	9. Group ID	( Only GO )
-
-
-	//	ToDo:
-
-	//	P2P Status
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_STATUS;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20100908 */
+	/*	According to the P2P Specification, the group negoitation response frame should contain 9 P2P attributes */
+	/*	1. Status */
+	/*	2. P2P Capability */
+	/*	3. Group Owner Intent */
+	/*	4. Configuration Timeout */
+	/*	5. Operating Channel */
+	/*	6. Intended P2P Interface Address */
+	/*	7. Channel List */
+	/*	8. Device Info */
+	/*	9. Group ID	( Only GO ) */
+
+
+	/*	ToDo: */
+
+	/*	P2P Status */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_STATUS;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value, filled by FW
-	p2pie[ p2pielen++ ] = 1;
-	
-	//	P2P Capability
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
+	/*	Value, filled by FW */
+	p2pie[p2pielen++] = 1;
+
+	/*	P2P Capability */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
 
-	if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) )
-	{
-		//	Commented by Albert 2011/03/08
-		//	According to the P2P specification
-		//	if the sending device will be client, the P2P Capability should be reserved of group negotation response frame
-		p2pie[ p2pielen++ ] = 0;
-	}
-	else
-	{
-		//	Be group owner or meet the error case
-		p2pie[ p2pielen++ ] = DMP_P2P_DEVCAP_SUPPORT;
-	}
-	
-	//	Group Capability Bitmap, 1 byte
-	if ( pwdinfo->persistent_supported )
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
+		/*	Commented by Albert 2011/03/08 */
+		/*	According to the P2P specification */
+		/*	if the sending device will be client, the P2P Capability should be reserved of group negotation response frame */
+		p2pie[p2pielen++] = 0;
+	} else {
+		/*	Be group owner or meet the error case */
+		p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
 	}
+
+	/*	Group Capability Bitmap, 1 byte */
+	if (pwdinfo->persistent_supported)
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
 	else
-	{
-		p2pie[ p2pielen++ ] = P2P_GRPCAP_CROSS_CONN;
-	}
+		p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
 
-	//	Group Owner Intent
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_GO_INTENT;
+	/*	Group Owner Intent */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_GO_INTENT;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value:
-	if ( pwdinfo->peer_intent & 0x01 )
-	{
-		//	Peer's tie breaker bit is 1, our tie breaker bit should be 0
-		p2pie[ p2pielen++ ] = ( pwdinfo->intent << 1 );
-	}
-	else
-	{
-		//	Peer's tie breaker bit is 0, our tie breaker bit should be 1
-		p2pie[ p2pielen++ ] = ( ( pwdinfo->intent << 1 ) | BIT(0) );
+	/*	Value: */
+	if (pwdinfo->peer_intent & 0x01) {
+		/*	Peer's tie breaker bit is 1, our tie breaker bit should be 0 */
+		p2pie[p2pielen++] = (pwdinfo->intent << 1);
+	} else {
+		/*	Peer's tie breaker bit is 0, our tie breaker bit should be 1 */
+		p2pie[p2pielen++] = ((pwdinfo->intent << 1) | BIT(0));
 	}
 
 
-	//	Configuration Timeout
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CONF_TIMEOUT;
+	/*	Configuration Timeout */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P GO
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P Client
+	/*	Value: */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P GO */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P Client */
 
-	//	Operating Channel
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
+	/*	Operating Channel */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
-
-	//	Operating Class
-	if ( pwdinfo->operating_channel <= 14 )
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x51;
-	}
-	else if ( ( pwdinfo->operating_channel >= 36 ) && ( pwdinfo->operating_channel <= 48 ) )
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x73;
-	}
-	else
-	{
-		//	Operating Class
-		p2pie[ p2pielen++ ] = 0x7c;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
+
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Operating Class */
+	if (pwdinfo->operating_channel <= 14) {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x51;
+	} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x73;
+	} else {
+		/*	Operating Class */
+		p2pie[p2pielen++] = 0x7c;
 	}
-	
-	//	Channel Number
-	p2pie[ p2pielen++ ] = pwdinfo->operating_channel;	//	operating channel number
 
-	//	Intended P2P Interface Address	
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_INTENTED_IF_ADDR;
+	/*	Channel Number */
+	p2pie[p2pielen++] = pwdinfo->operating_channel;	/*	operating channel number */
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN );
+	/*	Intended P2P Interface Address	 */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_INTENDED_IF_ADDR;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
 	p2pielen += 2;
 
-	//	Value:
+	/*	Value: */
 	_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Channel List
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CH_LIST;
+	/*	Channel List */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
 
-	// Country String(3)
-	// + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?)
-	// + number of channels in all classes
+	/* Country String(3) */
+	/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
+	/* + number of channels in all classes */
 	len_channellist_attr = 3
-	   + (1 + 1) * (u16)pmlmeext->channel_list.reg_classes
-	   + get_reg_classes_full_count(pmlmeext->channel_list);
+		       + (1 + 1) * (u16)ch_list->reg_classes
+		       + get_reg_classes_full_count(ch_list);
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 5 + 1 );
-	}
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_LINKED))
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
 	else
-	{
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-	}
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
+
 #else
 
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 
- #endif
+#endif
 	p2pielen += 2;
 
-	//	Value:
-	//	Country String
-	p2pie[ p2pielen++ ] = 'X';
-	p2pie[ p2pielen++ ] = 'X';
-	
-	//	The third byte should be set to 0x04.
-	//	Described in the "Operating Channel Attribute" section.
-	p2pie[ p2pielen++ ] = 0x04;
+	/*	Value: */
+	/*	Country String */
+	p2pie[p2pielen++] = 'X';
+	p2pie[p2pielen++] = 'X';
 
-	//	Channel Entry List
+	/*	The third byte should be set to 0x04. */
+	/*	Described in the "Operating Channel Attribute" section. */
+	p2pie[p2pielen++] = 0x04;
+
+	/*	Channel Entry List */
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-	{
-		_adapter *pbuddy_adapter = padapter->pbuddy_adapter;	
-		struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		u8 union_ch = rtw_mi_get_union_chan(padapter);
 
-		//	Operating Class
-		if ( pbuddy_mlmeext->cur_channel > 14 )
-		{
-			if ( pbuddy_mlmeext->cur_channel >= 149 )
-			{
-				p2pie[ p2pielen++ ] = 0x7c;
-			}
+		/*	Operating Class */
+		if (union_ch > 14) {
+			if (union_ch >= 149)
+				p2pie[p2pielen++] = 0x7c;
 			else
-			{
-				p2pie[ p2pielen++ ] = 0x73;
-			}
-		}
-		else
-		{
-			p2pie[ p2pielen++ ] = 0x51;
-		}
-
-		//	Number of Channels
-		//	Just support 1 channel and this channel is AP's channel
-		p2pie[ p2pielen++ ] = 1;
+				p2pie[p2pielen++] = 0x73;
+		} else
+			p2pie[p2pielen++] = 0x51;
 
-		//	Channel List
-		p2pie[ p2pielen++ ] = pbuddy_mlmeext->cur_channel;
-	}
-	else
-	{
-		int i, j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+		/*	Number of Channels */
+		/*	Just support 1 channel and this channel is AP's channel */
+		p2pie[p2pielen++] = 1;
 
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
-		}
-	}
-#else // CONFIG_CONCURRENT_MODE
+		/*	Channel List */
+		p2pie[p2pielen++] = union_ch;
+	} else
+#endif /* CONFIG_CONCURRENT_MODE */
 	{
 		int i, j;
-		for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-			//	Operating Class
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
+		for (j = 0; j < ch_list->reg_classes; j++) {
+			/*	Operating Class */
+			p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
 
-			//	Number of Channels
-			p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+			/*	Number of Channels */
+			p2pie[p2pielen++] = ch_list->reg_class[j].channels;
 
-			//	Channel List
-			for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-			}
+			/*	Channel List */
+			for (i = 0; i < ch_list->reg_class[j].channels; i++)
+				p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
 		}
 	}
-#endif // CONFIG_CONCURRENT_MODE
 
-	
-	//	Device Info
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
-
-	//	Length:
-	//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-	//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
+	/*	Device Info */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
+
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	//	P2P Device Address
+	/*	Value: */
+	/*	P2P Device Address */
 	_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 	p2pielen += ETH_ALEN;
 
-	//	Config Method
-	//	This field should be big endian. Noted by P2P specification.
+	/*	Config Method */
+	/*	This field should be big endian. Noted by P2P specification. */
 
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->supported_wps_cm );
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
 
 	p2pielen += 2;
 
-	//	Primary Device Type
-	//	Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA );
+	/*	Primary Device Type */
+	/*	Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
 	p2pielen += 2;
 
-	//	OUI
-	*(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI );
+	/*	OUI */
+	*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
 	p2pielen += 4;
 
-	//	Sub Category ID
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER );
+	/*	Sub Category ID */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
 	p2pielen += 2;
 
-	//	Number of Secondary Device Types
-	p2pie[ p2pielen++ ] = 0x00;	//	No Secondary Device Type List
+	/*	Number of Secondary Device Types */
+	p2pie[p2pielen++] = 0x00;	/*	No Secondary Device Type List */
 
-	//	Device Name
-	//	Type:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME );
+	/*	Device Name */
+	/*	Type: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
 	p2pielen += 2;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
 	p2pielen += 2;
 
-	//	Value:
-	_rtw_memcpy( p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len );
-	p2pielen += pwdinfo->device_name_len;	
-	
-	if ( rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) )
-	{
-		//	Group ID Attribute
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_ID;
+	/*	Value: */
+	_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len);
+	p2pielen += pwdinfo->device_name_len;
+
+	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+		/*	Group ID Attribute */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
 
-		//	Length:
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN + pwdinfo->nego_ssidlen );
+		/*	Length: */
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + pwdinfo->nego_ssidlen);
 		p2pielen += 2;
 
-		//	Value:
-		//	p2P Device Address
-		_rtw_memcpy( p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN );
+		/*	Value: */
+		/*	p2P Device Address */
+		_rtw_memcpy(p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN);
 		p2pielen += ETH_ALEN;
 
-		//	SSID
-		_rtw_memcpy( p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen );
+		/*	SSID */
+		_rtw_memcpy(p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
 		p2pielen += pwdinfo->nego_ssidlen;
-		
+
 	}
-	
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pktlen );	
-	
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pktlen);
+
 #ifdef CONFIG_WFD
 	wfdielen = build_nego_resp_wfd_ie(pwdinfo, pframe);
 	pframe += wfdielen;
 	pktlen += wfdielen;
 #endif
-	
+
 	*pLength = pktlen;
 #if 0
-	// printf dbg msg
+	/* printf dbg msg */
 	dbgbufLen = pktlen;
-	DBG_871X("======> DBG MSG FOR CONSTRAUCT Nego Rsp\n");
+	RTW_INFO("======> DBG MSG FOR CONSTRAUCT Nego Rsp\n");
+
+	for (index = 0; index < dbgbufLen; index++)
+		printk("%x ", *(dbgbuf + index));
 
-	for(index=0;index<dbgbufLen;index++)
-		printk("%x ",*(dbgbuf+index));
-	
 	printk("\n");
-	DBG_871X("<====== DBG MSG FOR CONSTRAUCT Nego Rsp\n");
+	RTW_INFO("<====== DBG MSG FOR CONSTRAUCT Nego Rsp\n");
 #endif
 }
 
-static void rtw_hal_construct_P2PInviteRsp(_adapter * padapter, u8 * pframe, u32 * pLength)
+static void rtw_hal_construct_P2PInviteRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
 {
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_INVIT_RESP;
-	u8			p2pie[ 255 ] = { 0x00 };
+	u8			p2pie[255] = { 0x00 };
 	u8			p2pielen = 0, i;
 	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
 	u16			len_channellist_attr = 0;
 	u32			pktlen;
 	u8			dialogToken = 0;
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-	struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif	
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
-	
-	//struct xmit_frame			*pmgntframe;
-	//struct pkt_attrib			*pattrib;
-	//unsigned char					*pframe;
+
+	/* struct xmit_frame			*pmgntframe; */
+	/* struct pkt_attrib			*pattrib; */
+	/* unsigned char					*pframe; */
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-	//for debug
+	/* for debug */
 	u8 *dbgbuf = pframe;
 	u8 dbgbufLen = 0, index = 0;
 
 
-	DBG_871X( "%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	//RA fill by FW
+	/* RA fill by FW */
 	_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 
-	//BSSID fill by FW
+	/* BSSID fill by FW */
 	_rtw_memset(pwlanhdr->addr3, 0, ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0);
-	SetFrameSubType(pframe, WIFI_ACTION);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -4105,207 +6228,178 @@ static void rtw_hal_construct_P2PInviteRsp(_adapter * padapter, u8 * pframe, u32
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));	
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));
 
-	//dialog token, filled by FW
+	/* dialog token, filled by FW */
 	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pktlen));
 
-	//	P2P IE Section.
+	/*	P2P IE Section. */
 
-	//	P2P OUI
+	/*	P2P OUI */
 	p2pielen = 0;
-	p2pie[ p2pielen++ ] = 0x50;
-	p2pie[ p2pielen++ ] = 0x6F;
-	p2pie[ p2pielen++ ] = 0x9A;
-	p2pie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20101005
-	//	According to the P2P Specification, the P2P Invitation response frame should contain 5 P2P attributes
-	//	1. Status
-	//	2. Configuration Timeout
-	//	3. Operating Channel	( Only GO )
-	//	4. P2P Group BSSID	( Only GO )
-	//	5. Channel List
-
-	//	P2P Status
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_STATUS;
-
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0001 );
+	p2pie[p2pielen++] = 0x50;
+	p2pie[p2pielen++] = 0x6F;
+	p2pie[p2pielen++] = 0x9A;
+	p2pie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20101005 */
+	/*	According to the P2P Specification, the P2P Invitation response frame should contain 5 P2P attributes */
+	/*	1. Status */
+	/*	2. Configuration Timeout */
+	/*	3. Operating Channel	( Only GO ) */
+	/*	4. P2P Group BSSID	( Only GO ) */
+	/*	5. Channel List */
+
+	/*	P2P Status */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_STATUS;
+
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
 	p2pielen += 2;
 
-	//	Value: filled by FW, defult value is FAIL INFO UNAVAILABLE
-	p2pie[ p2pielen++ ] = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
-	
-	//	Configuration Timeout
-	//	Type:
-	p2pie[ p2pielen++ ] = P2P_ATTR_CONF_TIMEOUT;
+	/*	Value: filled by FW, defult value is FAIL INFO UNAVAILABLE */
+	p2pie[p2pielen++] = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
+
+	/*	Configuration Timeout */
+	/*	Type: */
+	p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
 
-	//	Length:
-	*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
+	/*	Length: */
+	*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
 	p2pielen += 2;
 
-	//	Value:
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P GO
-	p2pie[ p2pielen++ ] = 200;	//	2 seconds needed to be the P2P Client
+	/*	Value: */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P GO */
+	p2pie[p2pielen++] = 200;	/*	2 seconds needed to be the P2P Client */
 
-	// due to defult value is FAIL INFO UNAVAILABLE, so the following IE is not needed
-#if 0 
-	if( status_code == P2P_STATUS_SUCCESS )
-	{
-		if( rtw_p2p_chk_role( pwdinfo, P2P_ROLE_GO ) )
-		{
-			//	The P2P Invitation request frame asks this Wi-Fi device to be the P2P GO
-			//	In this case, the P2P Invitation response frame should carry the two more P2P attributes.
-			//	First one is operating channel attribute.
-			//	Second one is P2P Group BSSID attribute.
+	/* due to defult value is FAIL INFO UNAVAILABLE, so the following IE is not needed */
+#if 0
+	if (status_code == P2P_STATUS_SUCCESS) {
+		struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
+
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+			/*	The P2P Invitation request frame asks this Wi-Fi device to be the P2P GO */
+			/*	In this case, the P2P Invitation response frame should carry the two more P2P attributes. */
+			/*	First one is operating channel attribute. */
+			/*	Second one is P2P Group BSSID attribute. */
 
-			//	Operating Channel
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_OPERATING_CH;
+			/*	Operating Channel */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
 
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0005 );
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
 			p2pielen += 2;
 
-			//	Value:
-			//	Country String
-			p2pie[ p2pielen++ ] = 'X';
-			p2pie[ p2pielen++ ] = 'X';
-		
-			//	The third byte should be set to 0x04.
-			//	Described in the "Operating Channel Attribute" section.
-			p2pie[ p2pielen++ ] = 0x04;
+			/*	Value: */
+			/*	Country String */
+			p2pie[p2pielen++] = 'X';
+			p2pie[p2pielen++] = 'X';
 
-			//	Operating Class
-			p2pie[ p2pielen++ ] = 0x51;	//	Copy from SD7
-		
-			//	Channel Number
-			p2pie[ p2pielen++ ] = pwdinfo->operating_channel;	//	operating channel number
-			
+			/*	The third byte should be set to 0x04. */
+			/*	Described in the "Operating Channel Attribute" section. */
+			p2pie[p2pielen++] = 0x04;
 
-			//	P2P Group BSSID
-			//	Type:
-			p2pie[ p2pielen++ ] = P2P_ATTR_GROUP_BSSID;
+			/*	Operating Class */
+			p2pie[p2pielen++] = 0x51;	/*	Copy from SD7 */
 
-			//	Length:
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN );
+			/*	Channel Number */
+			p2pie[p2pielen++] = pwdinfo->operating_channel;	/*	operating channel number */
+
+
+			/*	P2P Group BSSID */
+			/*	Type: */
+			p2pie[p2pielen++] = P2P_ATTR_GROUP_BSSID;
+
+			/*	Length: */
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
 			p2pielen += 2;
 
-			//	Value:
-			//	P2P Device Address for GO
+			/*	Value: */
+			/*	P2P Device Address for GO */
 			_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
 			p2pielen += ETH_ALEN;
 
 		}
 
-		//	Channel List
-		//	Type:
-		p2pie[ p2pielen++ ] = P2P_ATTR_CH_LIST;
+		/*	Channel List */
+		/*	Type: */
+		p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
 
-		//	Length:
-		// Country String(3)
-		// + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?)
-		// + number of channels in all classes
+		/*	Length: */
+		/* Country String(3) */
+		/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
+		/* + number of channels in all classes */
 		len_channellist_attr = 3
-			+ (1 + 1) * (u16)pmlmeext->channel_list.reg_classes
-			+ get_reg_classes_full_count(pmlmeext->channel_list);
+			+ (1 + 1) * (u16)ch_list->reg_classes
+			+ get_reg_classes_full_count(ch_list);
 
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-		{
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 5 + 1 );
-		}
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
 		else
-		{
-			*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
-		}
+			*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
+
 #else
 
-		*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( len_channellist_attr );
+		*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
 
 #endif
 		p2pielen += 2;
 
-		//	Value:
-		//	Country String
-		p2pie[ p2pielen++ ] = 'X';
-		p2pie[ p2pielen++ ] = 'X';
+		/*	Value: */
+		/*	Country String */
+		p2pie[p2pielen++] = 'X';
+		p2pie[p2pielen++] = 'X';
 
-		//	The third byte should be set to 0x04.
-		//	Described in the "Operating Channel Attribute" section.
-		p2pie[ p2pielen++ ] = 0x04;
+		/*	The third byte should be set to 0x04. */
+		/*	Described in the "Operating Channel Attribute" section. */
+		p2pie[p2pielen++] = 0x04;
 
-		//	Channel Entry List
+		/*	Channel Entry List */
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_buddy_fwstate(padapter, _FW_LINKED ) )
-		{
-			_adapter *pbuddy_adapter = padapter->pbuddy_adapter;	
-			struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
 
-			//	Operating Class
-			if ( pbuddy_mlmeext->cur_channel > 14 )
-			{
-				if ( pbuddy_mlmeext->cur_channel >= 149 )
-				{
-					p2pie[ p2pielen++ ] = 0x7c;
-				}
+			/*	Operating Class */
+			if (union_ch > 14) {
+				if (union_ch >= 149)
+					p2pie[p2pielen++] = 0x7c;
 				else
-				{
-					p2pie[ p2pielen++ ] = 0x73;
-				}
-			}
-			else
-			{
-				p2pie[ p2pielen++ ] = 0x51;
-			}
+					p2pie[p2pielen++] = 0x73;
 
-			//	Number of Channels
-			//	Just support 1 channel and this channel is AP's channel
-			p2pie[ p2pielen++ ] = 1;
+			} else
+				p2pie[p2pielen++] = 0x51;
 
-			//	Channel List
-			p2pie[ p2pielen++ ] = pbuddy_mlmeext->cur_channel;
-		}
-		else
-		{
-			int i, j;
-			for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-				//	Operating Class
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
 
-				//	Number of Channels
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+			/*	Number of Channels */
+			/*	Just support 1 channel and this channel is AP's channel */
+			p2pie[p2pielen++] = 1;
 
-				//	Channel List
-				for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-					p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-				}
-			}
-		}
-#else // CONFIG_CONCURRENT_MODE
+			/*	Channel List */
+			p2pie[p2pielen++] = union_ch;
+		} else
+#endif /* CONFIG_CONCURRENT_MODE */
 		{
 			int i, j;
-			for (j = 0; j < pmlmeext->channel_list.reg_classes; j++) {
-				//	Operating Class
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].reg_class;
+			for (j = 0; j < ch_list->reg_classes; j++) {
+				/*	Operating Class */
+				p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
 
-				//	Number of Channels
-				p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channels;
+				/*	Number of Channels */
+				p2pie[p2pielen++] = ch_list->reg_class[j].channels;
 
-				//	Channel List
-				for (i = 0; i < pmlmeext->channel_list.reg_class[j].channels; i++) {
-					p2pie[p2pielen++] = pmlmeext->channel_list.reg_class[j].channel[i];
-				}
+				/*	Channel List */
+				for (i = 0; i < ch_list->reg_class[j].channels; i++)
+					p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
 			}
 		}
-#endif // CONFIG_CONCURRENT_MODE
 	}
 #endif
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pktlen );	
-	
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pktlen);
+
 #ifdef CONFIG_WFD
 	wfdielen = build_invitation_resp_wfd_ie(pwdinfo, pframe);
 	pframe += wfdielen;
@@ -4315,61 +6409,61 @@ static void rtw_hal_construct_P2PInviteRsp(_adapter * padapter, u8 * pframe, u32
 	*pLength = pktlen;
 
 #if 0
-	// printf dbg msg
+	/* printf dbg msg */
 	dbgbufLen = pktlen;
-	DBG_871X("======> DBG MSG FOR CONSTRAUCT Invite Rsp\n");
+	RTW_INFO("======> DBG MSG FOR CONSTRAUCT Invite Rsp\n");
+
+	for (index = 0; index < dbgbufLen; index++)
+		printk("%x ", *(dbgbuf + index));
 
-	for(index=0;index<dbgbufLen;index++)
-		printk("%x ",*(dbgbuf+index));
-	
 	printk("\n");
-	DBG_871X("<====== DBG MSG FOR CONSTRAUCT Invite Rsp\n");
+	RTW_INFO("<====== DBG MSG FOR CONSTRAUCT Invite Rsp\n");
 #endif
 }
 
 
-static void rtw_hal_construct_P2PProvisionDisRsp(_adapter * padapter, u8 * pframe, u32 * pLength)
+static void rtw_hal_construct_P2PProvisionDisRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
 {
 	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
 	u8			action = P2P_PUB_ACTION_ACTION;
-	u8			dialogToken = 0;	
+	u8			dialogToken = 0;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_PROVISION_DISC_RESP;
-	u8			wpsie[ 100 ] = { 0x00 };
+	u8			wpsie[100] = { 0x00 };
 	u8			wpsielen = 0;
 	u32			pktlen;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
 #endif
-	
-	//struct xmit_frame			*pmgntframe;
-	//struct pkt_attrib			*pattrib;
-	//unsigned char					*pframe;
+
+	/* struct xmit_frame			*pmgntframe; */
+	/* struct pkt_attrib			*pattrib; */
+	/* unsigned char					*pframe; */
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-	//for debug
+	/* for debug */
 	u8 *dbgbuf = pframe;
 	u8 dbgbufLen = 0, index = 0;
 
-	DBG_871X( "%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 
-	//RA filled by FW
+	/* RA filled by FW */
 	_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
 
-	SetSeqNum(pwlanhdr,0);
-	SetFrameSubType(pframe, WIFI_ACTION);
+	SetSeqNum(pwlanhdr, 0);
+	set_frame_sub_type(pframe, WIFI_ACTION);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -4377,47 +6471,47 @@ static void rtw_hal_construct_P2PProvisionDisRsp(_adapter * padapter, u8 * pfram
 	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pktlen));
 	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));	
-	//dialog token, filled by FW
-	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pktlen));		
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));
+	/* dialog token, filled by FW */
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pktlen));
 
 	wpsielen = 0;
-	//	WPS OUI
-	//*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
+	/*	WPS OUI */
+	/* *(u32*) ( wpsie ) = cpu_to_be32( WPSOUI ); */
 	RTW_PUT_BE32(wpsie, WPSOUI);
 	wpsielen += 4;
 
 #if 0
-	//	WPS version
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
 	wpsielen += 2;
 
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
 	wpsielen += 2;
 
-	//	Value:
-	wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
 #endif
 
-	//	Config Method
-	//	Type:
-	//*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD );
+	/*	Config Method */
+	/*	Type: */
+	/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD ); */
 	RTW_PUT_BE16(wpsie + wpsielen, WPS_ATTR_CONF_METHOD);
 	wpsielen += 2;
 
-	//	Length:
-	//*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
+	/*	Length: */
+	/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 ); */
 	RTW_PUT_BE16(wpsie + wpsielen, 0x0002);
 	wpsielen += 2;
 
-	//	Value: filled by FW, default value is PBC
-	//*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( config_method );
+	/*	Value: filled by FW, default value is PBC */
+	/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( config_method ); */
 	RTW_PUT_BE16(wpsie + wpsielen, WPS_CM_PUSH_BUTTON);
 	wpsielen += 2;
 
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen );	
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen);
 
 #ifdef CONFIG_WFD
 	wfdielen = build_provdisc_resp_wfd_ie(pwdinfo, pframe);
@@ -4427,91 +6521,90 @@ static void rtw_hal_construct_P2PProvisionDisRsp(_adapter * padapter, u8 * pfram
 
 	*pLength = pktlen;
 
-	// printf dbg msg
+	/* printf dbg msg */
 #if 0
 	dbgbufLen = pktlen;
-	DBG_871X("======> DBG MSG FOR CONSTRAUCT  ProvisionDis Rsp\n");
+	RTW_INFO("======> DBG MSG FOR CONSTRAUCT  ProvisionDis Rsp\n");
 
-	for(index=0;index<dbgbufLen;index++)
-		printk("%x ",*(dbgbuf+index));
+	for (index = 0; index < dbgbufLen; index++)
+		printk("%x ", *(dbgbuf + index));
 
 	printk("\n");
-	DBG_871X("<====== DBG MSG FOR CONSTRAUCT ProvisionDis Rsp\n");
+	RTW_INFO("<====== DBG MSG FOR CONSTRAUCT ProvisionDis Rsp\n");
 #endif
 }
 
-u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter* adapter, PRSVDPAGE_LOC rsvdpageloc)
+u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc)
 {
-	u8 u1H2CP2PRsvdPageParm[H2C_P2PRSVDPAGE_LOC_LEN]={0};
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	u8 u1H2CP2PRsvdPageParm[H2C_P2PRSVDPAGE_LOC_LEN] = {0};
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	u8 ret = _FAIL;
 
-	DBG_871X("P2PRsvdPageLoc: P2PBeacon=%d P2PProbeRsp=%d NegoRsp=%d InviteRsp=%d PDRsp=%d\n",  
-		rsvdpageloc->LocP2PBeacon, rsvdpageloc->LocP2PProbeRsp,
-		rsvdpageloc->LocNegoRsp, rsvdpageloc->LocInviteRsp,
-		rsvdpageloc->LocPDRsp);
+	RTW_INFO("P2PRsvdPageLoc: P2PBeacon=%d P2PProbeRsp=%d NegoRsp=%d InviteRsp=%d PDRsp=%d\n",
+		 rsvdpageloc->LocP2PBeacon, rsvdpageloc->LocP2PProbeRsp,
+		 rsvdpageloc->LocNegoRsp, rsvdpageloc->LocInviteRsp,
+		 rsvdpageloc->LocPDRsp);
 
 	SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(u1H2CP2PRsvdPageParm, rsvdpageloc->LocProbeRsp);
 	SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocPsPoll);
 	SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocNullData);
 	SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocQosNull);
 	SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocBTQosNull);
-	
-	//FillH2CCmd8723B(padapter, H2C_8723B_P2P_OFFLOAD_RSVD_PAGE, H2C_P2PRSVDPAGE_LOC_LEN, u1H2CP2PRsvdPageParm);
+
+	/* FillH2CCmd8723B(padapter, H2C_8723B_P2P_OFFLOAD_RSVD_PAGE, H2C_P2PRSVDPAGE_LOC_LEN, u1H2CP2PRsvdPageParm); */
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_P2P_OFFLOAD_RSVD_PAGE,
-				H2C_P2PRSVDPAGE_LOC_LEN,
-				u1H2CP2PRsvdPageParm);
+				   H2C_P2P_OFFLOAD_RSVD_PAGE,
+				   H2C_P2PRSVDPAGE_LOC_LEN,
+				   u1H2CP2PRsvdPageParm);
 
 	return ret;
 }
 
-u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter* adapter)
+u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter)
 {
 
 	u8 offload_cmd[H2C_P2P_OFFLOAD_LEN] = {0};
 	struct wifidirect_info	*pwdinfo = &(adapter->wdinfo);
 	struct P2P_WoWlan_Offload_t *p2p_wowlan_offload = (struct P2P_WoWlan_Offload_t *)offload_cmd;
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	u8 ret = _FAIL;
 
-	_rtw_memset(p2p_wowlan_offload,0 ,sizeof(struct P2P_WoWlan_Offload_t)); 
-	DBG_871X("%s\n",__func__);	
-	switch(pwdinfo->role)
-	{
-		case P2P_ROLE_DEVICE:
-			DBG_871X("P2P_ROLE_DEVICE\n");
-			p2p_wowlan_offload->role = 0;
-			break;
-		case P2P_ROLE_CLIENT:
-			DBG_871X("P2P_ROLE_CLIENT\n");
-			p2p_wowlan_offload->role = 1;
-			break;
-		case P2P_ROLE_GO:
-			DBG_871X("P2P_ROLE_GO\n");
-			p2p_wowlan_offload->role = 2;
-			break;
-		default: 
-			DBG_871X("P2P_ROLE_DISABLE\n");
-			break;
-		}
-	p2p_wowlan_offload->Wps_Config[0] = pwdinfo->supported_wps_cm>>8;
+	_rtw_memset(p2p_wowlan_offload, 0 , sizeof(struct P2P_WoWlan_Offload_t));
+	RTW_INFO("%s\n", __func__);
+	switch (pwdinfo->role) {
+	case P2P_ROLE_DEVICE:
+		RTW_INFO("P2P_ROLE_DEVICE\n");
+		p2p_wowlan_offload->role = 0;
+		break;
+	case P2P_ROLE_CLIENT:
+		RTW_INFO("P2P_ROLE_CLIENT\n");
+		p2p_wowlan_offload->role = 1;
+		break;
+	case P2P_ROLE_GO:
+		RTW_INFO("P2P_ROLE_GO\n");
+		p2p_wowlan_offload->role = 2;
+		break;
+	default:
+		RTW_INFO("P2P_ROLE_DISABLE\n");
+		break;
+	}
+	p2p_wowlan_offload->Wps_Config[0] = pwdinfo->supported_wps_cm >> 8;
 	p2p_wowlan_offload->Wps_Config[1] = pwdinfo->supported_wps_cm;
-	offload_cmd = (u8*)p2p_wowlan_offload;
-	DBG_871X("p2p_wowlan_offload: %x:%x:%x\n",offload_cmd[0],offload_cmd[1],offload_cmd[2]);	
+	offload_cmd = (u8 *)p2p_wowlan_offload;
+	RTW_INFO("p2p_wowlan_offload: %x:%x:%x\n", offload_cmd[0], offload_cmd[1], offload_cmd[2]);
 
 	ret = rtw_hal_fill_h2c_cmd(adapter,
-				H2C_P2P_OFFLOAD,
-				H2C_P2P_OFFLOAD_LEN,
-				offload_cmd);
+				   H2C_P2P_OFFLOAD,
+				   H2C_P2P_OFFLOAD_LEN,
+				   offload_cmd);
 	return ret;
 
-	//FillH2CCmd8723B(adapter, H2C_8723B_P2P_OFFLOAD, sizeof(struct P2P_WoWlan_Offload_t), (u8 *)p2p_wowlan_offload);
+	/* FillH2CCmd8723B(adapter, H2C_8723B_P2P_OFFLOAD, sizeof(struct P2P_WoWlan_Offload_t), (u8 *)p2p_wowlan_offload); */
 }
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
 
-static void rtw_hal_construct_beacon(_adapter *padapter,
-		u8 *pframe, u32 *pLength)
+void rtw_hal_construct_beacon(_adapter *padapter,
+				     u8 *pframe, u32 *pLength)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u16					*fctrl;
@@ -4522,7 +6615,7 @@ static void rtw_hal_construct_beacon(_adapter *padapter,
 	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 
 
-	//DBG_871X("%s\n", __FUNCTION__);
+	/* RTW_INFO("%s\n", __FUNCTION__); */
 
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
@@ -4534,87 +6627,82 @@ static void rtw_hal_construct_beacon(_adapter *padapter,
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
-	//pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_BEACON);
+	/* pmlmeext->mgnt_seq++; */
+	set_frame_sub_type(pframe, WIFI_BEACON);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pktlen = sizeof (struct rtw_ieee80211_hdr_3addr);
+	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	//timestamp will be inserted by hardware
+	/* timestamp will be inserted by hardware */
 	pframe += 8;
 	pktlen += 8;
 
-	// beacon interval: 2 bytes
+	/* beacon interval: 2 bytes */
 	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
 
 	pframe += 2;
 	pktlen += 2;
 
-	// capability info: 2 bytes
+	/* capability info: 2 bytes */
 	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
 
 	pframe += 2;
 	pktlen += 2;
 
-	if( (pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE)
-	{
-		//DBG_871X("ie len=%d\n", cur_network->IELength);
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+		/* RTW_INFO("ie len=%d\n", cur_network->IELength); */
 		pktlen += cur_network->IELength - sizeof(NDIS_802_11_FIXED_IEs);
-		_rtw_memcpy(pframe, cur_network->IEs+sizeof(NDIS_802_11_FIXED_IEs), pktlen);
+		_rtw_memcpy(pframe, cur_network->IEs + sizeof(NDIS_802_11_FIXED_IEs), pktlen);
 
 		goto _ConstructBeacon;
 	}
 
-	//below for ad-hoc mode
+	/* below for ad-hoc mode */
 
-	// SSID
+	/* SSID */
 	pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pktlen);
 
-	// supported rates...
+	/* supported rates... */
 	rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
-	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8)? 8: rate_len), cur_network->SupportedRates, &pktlen);
+	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pktlen);
 
-	// DS parameter set
+	/* DS parameter set */
 	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pktlen);
 
-	if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)
-	{
+	if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
 		u32 ATIMWindow;
-		// IBSS Parameter Set...
-		//ATIMWindow = cur->Configuration.ATIMWindow;
+		/* IBSS Parameter Set... */
+		/* ATIMWindow = cur->Configuration.ATIMWindow; */
 		ATIMWindow = 0;
 		pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pktlen);
 	}
 
 
-	//todo: ERP IE
+	/* todo: ERP IE */
 
 
-	// EXTERNDED SUPPORTED RATE
+	/* EXTERNDED SUPPORTED RATE */
 	if (rate_len > 8)
-	{
 		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pktlen);
-	}
 
 
-	//todo:HT for adhoc
+	/* todo:HT for adhoc */
 
 _ConstructBeacon:
 
-	if ((pktlen + TXDESC_SIZE) > 512)
-	{
-		DBG_871X("beacon frame too large\n");
+	if ((pktlen + TXDESC_SIZE) > 512) {
+		RTW_INFO("beacon frame too large\n");
 		return;
 	}
 
 	*pLength = pktlen;
 
-	//DBG_871X("%s bcn_sz=%d\n", __FUNCTION__, pktlen);
+	/* RTW_INFO("%s bcn_sz=%d\n", __FUNCTION__, pktlen); */
 
 }
 
 static void rtw_hal_construct_PSPoll(_adapter *padapter,
-		u8 *pframe, u32 *pLength)
+				     u8 *pframe, u32 *pLength)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u16					*fctrl;
@@ -4622,29 +6710,67 @@ static void rtw_hal_construct_PSPoll(_adapter *padapter,
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-	//DBG_871X("%s\n", __FUNCTION__);
+	/* RTW_INFO("%s\n", __FUNCTION__); */
 
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
-	// Frame control.
+	/* Frame control. */
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
 	SetPwrMgt(fctrl);
-	SetFrameSubType(pframe, WIFI_PSPOLL);
+	set_frame_sub_type(pframe, WIFI_PSPOLL);
 
-	// AID.
-	SetDuration(pframe, (pmlmeinfo->aid | 0xc000));
+	/* AID. */
+	set_duration(pframe, (pmlmeinfo->aid | 0xc000));
 
-	// BSSID.
+	/* BSSID. */
 	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
-	// TA.
+	/* TA. */
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 
 	*pLength = 16;
 }
 
-static void rtw_hal_construct_NullFunctionData(
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+void rtw_hal_construct_fw_dbg_msg_pkt(
+	PADAPTER padapter,
+	u8		*pframe,
+	u32		*plength)
+{
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	u16						*fctrl;
+	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);
+	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+
+	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, 0);
+
+	set_frame_sub_type(pframe, WIFI_DATA);
+
+	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	*plength = pktlen;
+}
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+void rtw_hal_construct_NullFunctionData(
 	PADAPTER padapter,
 	u8		*pframe,
 	u32		*pLength,
@@ -4661,55 +6787,58 @@ static void rtw_hal_construct_NullFunctionData(
 	struct wlan_network		*cur_network = &pmlmepriv->cur_network;
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8 bssid[ETH_ALEN];
 
+	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
 
-	//DBG_871X("%s:%d\n", __FUNCTION__, bForcePowerSave);
-
-	pwlanhdr = (struct rtw_ieee80211_hdr*)pframe;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
 	fctrl = &pwlanhdr->frame_ctl;
 	*(fctrl) = 0;
 	if (bForcePowerSave)
-	{
 		SetPwrMgt(fctrl);
+
+	if (NULL == StaAddr) {
+		_rtw_memcpy(bssid, adapter_mac_addr(padapter), ETH_ALEN);
+		StaAddr = bssid;
 	}
 
-	switch(cur_network->network.InfrastructureMode)
-	{
-		case Ndis802_11Infrastructure:
-			SetToDs(fctrl);
-			_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr3, StaAddr, ETH_ALEN);
-			break;
-		case Ndis802_11APMode:
-			SetFrDs(fctrl);
-			_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr2, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
-			break;
-		case Ndis802_11IBSS:
-		default:
-			_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-			_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-			break;
+	switch (cur_network->network.InfrastructureMode) {
+	case Ndis802_11Infrastructure:
+		SetToDs(fctrl);
+		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, StaAddr, ETH_ALEN);
+		break;
+	case Ndis802_11APMode:
+		SetFrDs(fctrl);
+		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
+		break;
+	case Ndis802_11IBSS:
+	default:
+		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		break;
 	}
 
 	SetSeqNum(pwlanhdr, 0);
+	set_duration(pwlanhdr, 0);
 
 	if (bQoS == _TRUE) {
 		struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
 
-		SetFrameSubType(pframe, WIFI_QOS_DATA_NULL);
+		set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
 
-		pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos*)pframe;
+		pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos *)pframe;
 		SetPriority(&pwlanqoshdr->qc, AC);
 		SetEOSP(&pwlanqoshdr->qc, bEosp);
 
 		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
 	} else {
-		SetFrameSubType(pframe, WIFI_DATA_NULL);
+		set_frame_sub_type(pframe, WIFI_DATA_NULL);
 
 		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 	}
@@ -4718,7 +6847,7 @@ static void rtw_hal_construct_NullFunctionData(
 }
 
 void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,
-		u8 *StaAddr, BOOLEAN bHideSSID)
+				u8 *StaAddr, BOOLEAN bHideSSID)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u16					*fctrl;
@@ -4728,7 +6857,7 @@ void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX  *cur_network = &(pmlmeinfo->network);
 
-	/*DBG_871X("%s\n", __FUNCTION__);*/
+	/*RTW_INFO("%s\n", __FUNCTION__);*/
 
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
@@ -4742,7 +6871,7 @@ void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,
 	_rtw_memcpy(pwlanhdr->addr3, bssid, ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0);
-	SetFrameSubType(fctrl, WIFI_PROBERSP);
+	set_frame_sub_type(fctrl, WIFI_PROBERSP);
 
 	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 	pframe += pktlen;
@@ -4757,17 +6886,63 @@ void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,
 	*pLength = pktlen;
 }
 
-#ifdef CONFIG_WOWLAN	
-//
-// Description:
-//	Construct the ARP response packet to support ARP offload.
-//
+#ifdef CONFIG_WOWLAN
+static void rtw_hal_append_tkip_mic(PADAPTER padapter,
+				    u8 *pframe, u32 offset)
+{
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct mic_data	micdata;
+	struct sta_info	*psta = NULL;
+	int res = 0;
+
+	u8	*payload = (u8 *)(pframe + offset);
+
+	u8	mic[8];
+	u8	priority[4] = {0x0};
+	u8	null_key[16] = {0x0};
+
+	RTW_INFO("%s(): Add MIC, offset: %d\n", __func__, offset);
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	psta = rtw_get_stainfo(&padapter->stapriv,
+			get_my_bssid(&(pmlmeinfo->network)));
+	if (psta != NULL) {
+		res = _rtw_memcmp(&psta->dot11tkiptxmickey.skey[0],
+				  null_key, 16);
+		if (res == _TRUE)
+			RTW_INFO("%s(): STA dot11tkiptxmickey==0\n", __func__);
+		rtw_secmicsetkey(&micdata, &psta->dot11tkiptxmickey.skey[0]);
+	}
+
+	rtw_secmicappend(&micdata, pwlanhdr->addr3, 6);  /* DA */
+
+	rtw_secmicappend(&micdata, pwlanhdr->addr2, 6); /* SA */
+
+	priority[0] = 0;
+
+	rtw_secmicappend(&micdata, &priority[0], 4);
+
+	rtw_secmicappend(&micdata, payload, 36); /* payload length = 8 + 28 */
+
+	rtw_secgetmic(&micdata, &(mic[0]));
+
+	payload += 36;
+
+	_rtw_memcpy(payload, &(mic[0]), 8);
+}
+/*
+ * Description:
+ *	Construct the ARP response packet to support ARP offload.
+ *   */
 static void rtw_hal_construct_ARPRsp(
 	PADAPTER padapter,
 	u8			*pframe,
 	u32			*pLength,
 	u8			*pIPAddress
-	)
+)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u16	*fctrl;
@@ -4779,151 +6954,299 @@ static void rtw_hal_construct_ARPRsp(
 	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 	static u8	ARPLLCHeader[8] = {0xAA, 0xAA, 0x03, 0x00, 0x00, 0x00, 0x08, 0x06};
 	u8	*pARPRspPkt = pframe;
-	//for TKIP Cal MIC
+	/* for TKIP Cal MIC */
 	u8	*payload = pframe;
-	u8	EncryptionHeadOverhead = 0;
-	//DBG_871X("%s:%d\n", __FUNCTION__, bForcePowerSave);
+	u8	EncryptionHeadOverhead = 0, arp_offset = 0;
+	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
 
-	pwlanhdr = (struct rtw_ieee80211_hdr*)pframe;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
 	fctrl = &pwlanhdr->frame_ctl;
 	*(fctrl) = 0;
 
-	//-------------------------------------------------------------------------
-	// MAC Header.
-	//-------------------------------------------------------------------------
+	/* ------------------------------------------------------------------------- */
+	/* MAC Header. */
+	/* ------------------------------------------------------------------------- */
 	SetFrameType(fctrl, WIFI_DATA);
-	//SetFrameSubType(fctrl, 0);
+	/* set_frame_sub_type(fctrl, 0); */
 	SetToDs(fctrl);
 	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0);
-	SetDuration(pwlanhdr, 0);
-	//SET_80211_HDR_FRAME_CONTROL(pARPRspPkt, 0);
-	//SET_80211_HDR_TYPE_AND_SUBTYPE(pARPRspPkt, Type_Data);
-	//SET_80211_HDR_TO_DS(pARPRspPkt, 1);
-	//SET_80211_HDR_ADDRESS1(pARPRspPkt, pMgntInfo->Bssid);
-	//SET_80211_HDR_ADDRESS2(pARPRspPkt, Adapter->CurrentAddress);
-	//SET_80211_HDR_ADDRESS3(pARPRspPkt, pMgntInfo->Bssid);
-
-	//SET_80211_HDR_DURATION(pARPRspPkt, 0);
-	//SET_80211_HDR_FRAGMENT_SEQUENCE(pARPRspPkt, 0);
+	set_duration(pwlanhdr, 0);
+	/* SET_80211_HDR_FRAME_CONTROL(pARPRspPkt, 0); */
+	/* SET_80211_HDR_TYPE_AND_SUBTYPE(pARPRspPkt, Type_Data); */
+	/* SET_80211_HDR_TO_DS(pARPRspPkt, 1); */
+	/* SET_80211_HDR_ADDRESS1(pARPRspPkt, pMgntInfo->Bssid); */
+	/* SET_80211_HDR_ADDRESS2(pARPRspPkt, Adapter->CurrentAddress); */
+	/* SET_80211_HDR_ADDRESS3(pARPRspPkt, pMgntInfo->Bssid); */
+
+	/* SET_80211_HDR_DURATION(pARPRspPkt, 0); */
+	/* SET_80211_HDR_FRAGMENT_SEQUENCE(pARPRspPkt, 0); */
 #ifdef CONFIG_WAPI_SUPPORT
 	*pLength = sMacHdrLng;
 #else
 	*pLength = 24;
 #endif
 	switch (psecuritypriv->dot11PrivacyAlgrthm) {
-		case _WEP40_:
-		case _WEP104_:
-			EncryptionHeadOverhead = 4;
-			break;
-		case _TKIP_:
-			EncryptionHeadOverhead = 8;
-			break;
-		case _AES_:
-			EncryptionHeadOverhead = 8;
-			break;
+	case _WEP40_:
+	case _WEP104_:
+		EncryptionHeadOverhead = 4;
+		break;
+	case _TKIP_:
+		EncryptionHeadOverhead = 8;
+		break;
+	case _AES_:
+		EncryptionHeadOverhead = 8;
+		break;
 #ifdef CONFIG_WAPI_SUPPORT
-		case _SMS4_:
-			EncryptionHeadOverhead = 18;
-			break;
+	case _SMS4_:
+		EncryptionHeadOverhead = 18;
+		break;
 #endif
-		default:
-			EncryptionHeadOverhead = 0;
+	default:
+		EncryptionHeadOverhead = 0;
 	}
 
-	if(EncryptionHeadOverhead > 0) {
-		_rtw_memset(&(pframe[*pLength]), 0,EncryptionHeadOverhead);
+	if (EncryptionHeadOverhead > 0) {
+		_rtw_memset(&(pframe[*pLength]), 0, EncryptionHeadOverhead);
 		*pLength += EncryptionHeadOverhead;
-		//SET_80211_HDR_WEP(pARPRspPkt, 1);  //Suggested by CCW.
+		/* SET_80211_HDR_WEP(pARPRspPkt, 1);  */ /* Suggested by CCW. */
 		SetPrivacy(fctrl);
 	}
 
-	//-------------------------------------------------------------------------
-	// Frame Body.
-	//-------------------------------------------------------------------------
-	pARPRspPkt =  (u8*)(pframe+ *pLength);
-	payload = pARPRspPkt; //Get Payload pointer
-	// LLC header
+	/* ------------------------------------------------------------------------- */
+	/* Frame Body. */
+	/* ------------------------------------------------------------------------- */
+	arp_offset = *pLength;
+	pARPRspPkt = (u8 *)(pframe + arp_offset);
+	payload = pARPRspPkt; /* Get Payload pointer */
+	/* LLC header */
 	_rtw_memcpy(pARPRspPkt, ARPLLCHeader, 8);
 	*pLength += 8;
 
-	// ARP element
+	/* ARP element */
 	pARPRspPkt += 8;
 	SET_ARP_PKT_HW(pARPRspPkt, 0x0100);
-	SET_ARP_PKT_PROTOCOL(pARPRspPkt, 0x0008);	// IP protocol
+	SET_ARP_PKT_PROTOCOL(pARPRspPkt, 0x0008);	/* IP protocol */
 	SET_ARP_PKT_HW_ADDR_LEN(pARPRspPkt, 6);
 	SET_ARP_PKT_PROTOCOL_ADDR_LEN(pARPRspPkt, 4);
-	SET_ARP_PKT_OPERATION(pARPRspPkt, 0x0200);	// ARP response
+	SET_ARP_PKT_OPERATION(pARPRspPkt, 0x0200);	/* ARP response */
 	SET_ARP_PKT_SENDER_MAC_ADDR(pARPRspPkt, adapter_mac_addr(padapter));
 	SET_ARP_PKT_SENDER_IP_ADDR(pARPRspPkt, pIPAddress);
 #ifdef CONFIG_ARP_KEEP_ALIVE
 	if (!is_zero_mac_addr(pmlmepriv->gw_mac_addr)) {
 		SET_ARP_PKT_TARGET_MAC_ADDR(pARPRspPkt, pmlmepriv->gw_mac_addr);
 		SET_ARP_PKT_TARGET_IP_ADDR(pARPRspPkt, pmlmepriv->gw_ip);
-	}    
-	else
+	} else
 #endif
 	{
 		SET_ARP_PKT_TARGET_MAC_ADDR(pARPRspPkt,
-				get_my_bssid(&(pmlmeinfo->network)));
+				    get_my_bssid(&(pmlmeinfo->network)));
 		SET_ARP_PKT_TARGET_IP_ADDR(pARPRspPkt,
-				pIPAddress);
-		DBG_871X("%s Target Mac Addr:" MAC_FMT "\n", __FUNCTION__,
-				MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
-		DBG_871X("%s Target IP Addr" IP_FMT "\n", __FUNCTION__,
-				IP_ARG(pIPAddress));
+					   pIPAddress);
+		RTW_INFO("%s Target Mac Addr:" MAC_FMT "\n", __FUNCTION__,
+			 MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
+		RTW_INFO("%s Target IP Addr" IP_FMT "\n", __FUNCTION__,
+			 IP_ARG(pIPAddress));
 	}
 
 	*pLength += 28;
 
 	if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) {
-		u8	mic[8];
-		struct mic_data	micdata;
-		struct sta_info	*psta = NULL;
-		u8	priority[4]={0x0,0x0,0x0,0x0};
-		u8	null_key[16]={0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0};
+		if (IS_HARDWARE_TYPE_8188E(padapter) ||
+		    IS_HARDWARE_TYPE_8812(padapter)) {
+			rtw_hal_append_tkip_mic(padapter, pframe, arp_offset);
+		}
+		*pLength += 8;
+	}
+}
 
-		DBG_871X("%s(): Add MIC\n",__FUNCTION__);
+#ifdef CONFIG_IPV6
+/*
+ * Description: Neighbor Discovery Offload.
+ */
+static void rtw_hal_construct_na_message(_adapter *padapter,
+				     u8 *pframe, u32 *pLength)
+{
+	struct rtw_ieee80211_hdr *pwlanhdr = NULL;
+	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;
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 
-		psta = rtw_get_stainfo(&padapter->stapriv,
-				get_my_bssid(&(pmlmeinfo->network)));
-		if (psta != NULL) {
-			if(_rtw_memcmp(&psta->dot11tkiptxmickey.skey[0],
-						null_key, 16)==_TRUE) {
-				DBG_871X("%s(): STA dot11tkiptxmickey==0\n",
-						__func__);
-			}
-			//start to calculate the mic code
-			rtw_secmicsetkey(&micdata,
-					&psta->dot11tkiptxmickey.skey[0]);
-		}
+	u32 pktlen = 0;
+	u16 *fctrl = NULL;
+
+	u8 ns_hdr[8] = {0xAA, 0xAA, 0x03, 0x00, 0x00, 0x00, 0x86, 0xDD};
+	u8 ipv6_info[4] = {0x60, 0x00, 0x00, 0x00};
+	u8 ipv6_contx[4] = {0x00, 0x20, 0x3a, 0xff};
+	u8 icmpv6_hdr[8] = {0x88, 0x00, 0x00, 0x00, 0x60, 0x00, 0x00, 0x00};
+	u8 val8 = 0;
+
+	u8 *p_na_msg = pframe;
+	/* for TKIP Cal MIC */
+	u8 *payload = pframe;
+	u8 EncryptionHeadOverhead = 0, na_msg_offset = 0;
+	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
 
-		rtw_secmicappend(&micdata, pwlanhdr->addr3, 6);  //DA
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
-		rtw_secmicappend(&micdata, pwlanhdr->addr2, 6); //SA
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
 
-		priority[0]=0;
+	/* ------------------------------------------------------------------------- */
+	/* MAC Header. */
+	/* ------------------------------------------------------------------------- */
+	SetFrameType(fctrl, WIFI_DATA);
+	SetToDs(fctrl);
+	_rtw_memcpy(pwlanhdr->addr1,
+		    get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2,
+		    adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3,
+		    get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
-		rtw_secmicappend(&micdata, &priority[0], 4);
+	SetSeqNum(pwlanhdr, 0);
+	set_duration(pwlanhdr, 0);
 
-		rtw_secmicappend(&micdata, payload, 36); //payload length = 8 + 28
+#ifdef CONFIG_WAPI_SUPPORT
+	*pLength = sMacHdrLng;
+#else
+	*pLength = 24;
+#endif
+	switch (psecuritypriv->dot11PrivacyAlgrthm) {
+	case _WEP40_:
+	case _WEP104_:
+		EncryptionHeadOverhead = 4;
+		break;
+	case _TKIP_:
+		EncryptionHeadOverhead = 8;
+		break;
+	case _AES_:
+		EncryptionHeadOverhead = 8;
+		break;
+#ifdef CONFIG_WAPI_SUPPORT
+	case _SMS4_:
+		EncryptionHeadOverhead = 18;
+		break;
+#endif
+	default:
+		EncryptionHeadOverhead = 0;
+	}
 
-		rtw_secgetmic(&micdata,&(mic[0]));
+	if (EncryptionHeadOverhead > 0) {
+		_rtw_memset(&(pframe[*pLength]), 0, EncryptionHeadOverhead);
+		*pLength += EncryptionHeadOverhead;
+		/* SET_80211_HDR_WEP(pARPRspPkt, 1);  */ /* Suggested by CCW. */
+		SetPrivacy(fctrl);
+	}
 
-		pARPRspPkt += 28;
-		_rtw_memcpy(pARPRspPkt, &(mic[0]),8);
+	/* ------------------------------------------------------------------------- */
+	/* Frame Body. */
+	/* ------------------------------------------------------------------------- */
+	na_msg_offset = *pLength;
+	p_na_msg = (u8 *)(pframe + na_msg_offset);
+	payload = p_na_msg; /* Get Payload pointer */
+
+	/* LLC header */
+	val8 = sizeof(ns_hdr);
+	_rtw_memcpy(p_na_msg, ns_hdr, val8);
+	*pLength += val8;
+	p_na_msg += val8;
+
+	/* IPv6 Header */
+	/* 1 . Information (4 bytes): 0x60 0x00 0x00 0x00 */
+	val8 = sizeof(ipv6_info);
+	_rtw_memcpy(p_na_msg, ipv6_info, val8);
+	*pLength += val8;
+	p_na_msg += val8;
+
+	/* 2 . playload : 0x00 0x20 , NextProt : 0x3a (ICMPv6) HopLim : 0xff */
+	val8 = sizeof(ipv6_contx);
+	_rtw_memcpy(p_na_msg, ipv6_contx, val8);
+	*pLength += val8;
+	p_na_msg += val8;
+
+	/* 3 . SA : 16 bytes , DA : 16 bytes ( Fw will filled ) */
+	_rtw_memset(&(p_na_msg[*pLength]), 0, 32);
+	*pLength += 32;
+	p_na_msg += 32;
+
+	/* ICMPv6 */
+	/* 1. Type : 0x88 (NA)
+	 * 2. Code : 0x00
+	 * 3. ChechSum : 0x00 0x00 (RSvd)
+	 * 4. NAFlag: 0x60 0x00 0x00 0x00 ( Solicited , Override)
+	 */
+	val8 = sizeof(icmpv6_hdr);
+	_rtw_memcpy(p_na_msg, icmpv6_hdr, val8);
+	*pLength += val8;
+	p_na_msg += val8;
+
+	/* TA: 16 bytes*/
+	_rtw_memset(&(p_na_msg[*pLength]), 0, 16);
+	*pLength += 16;
+	p_na_msg += 16;
+
+	/* ICMPv6 Target Link Layer Address */
+	p_na_msg[0] = 0x02; /* type */
+	p_na_msg[1] = 0x01; /* len 1 unit of 8 octes */
+	*pLength += 2;
+	p_na_msg += 2;
+
+	_rtw_memset(&(p_na_msg[*pLength]), 0, 6);
+	*pLength += 6;
+	p_na_msg += 6;
 
+	if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) {
+		if (IS_HARDWARE_TYPE_8188E(padapter) ||
+		    IS_HARDWARE_TYPE_8812(padapter)) {
+			rtw_hal_append_tkip_mic(padapter, pframe,
+						na_msg_offset);
+		}
 		*pLength += 8;
 	}
 }
+/*
+ * Description: Neighbor Discovery Protocol Information.
+ */
+static void rtw_hal_construct_ndp_info(_adapter *padapter,
+				     u8 *pframe, u32 *pLength)
+{
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	struct rtw_ndp_info ndp_info;
+	u8	*pndp_info = pframe;
+	u8	len = sizeof(struct rtw_ndp_info);
+
+	RTW_INFO("%s: len: %d\n", __func__, len);
+
+	pmlmeext =  &padapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+
+	_rtw_memset(pframe, 0, len);
+	_rtw_memset(&ndp_info, 0, len);
+
+	ndp_info.enable = 1;
+	ndp_info.check_remote_ip = 0;
+	ndp_info.num_of_target_ip = 1;
+
+	_rtw_memcpy(&ndp_info.target_link_addr, adapter_mac_addr(padapter),
+		    ETH_ALEN);
+	_rtw_memcpy(&ndp_info.target_ipv6_addr, pmlmeinfo->ip6_addr,
+		    RTW_IPv6_ADDR_LEN);
+
+	_rtw_memcpy(pndp_info, &ndp_info, len);
+}
+#endif /* CONFIG_IPV6 */
 
 #ifdef CONFIG_PNO_SUPPORT
 static void rtw_hal_construct_ProbeReq(_adapter *padapter, u8 *pframe,
-		u32 *pLength, pno_ssid_t *ssid)
+				       u32 *pLength, pno_ssid_t *ssid)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u16				*fctrl;
@@ -4949,94 +7272,92 @@ static void rtw_hal_construct_ProbeReq(_adapter *padapter, u8 *pframe,
 	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0);
-	SetFrameSubType(pframe, WIFI_PROBEREQ);
+	set_frame_sub_type(pframe, WIFI_PROBEREQ);
 
 	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 	pframe += pktlen;
 
-	if (ssid == NULL) {
+	if (ssid == NULL)
 		pframe = rtw_set_ie(pframe, _SSID_IE_, 0, NULL, &pktlen);
-	} else {
-		//DBG_871X("%s len:%d\n", ssid->SSID, ssid->SSID_len);
+	else {
+		/* RTW_INFO("%s len:%d\n", ssid->SSID, ssid->SSID_len); */
 		pframe = rtw_set_ie(pframe, _SSID_IE_, ssid->SSID_len, ssid->SSID, &pktlen);
 	}
 
 	get_rate_set(padapter, bssrate, &bssrate_len);
 
-	if (bssrate_len > 8)
-	{
+	if (bssrate_len > 8) {
 		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &pktlen);
 		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &pktlen);
-	}
-	else
-	{
+	} else
 		pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &pktlen);
-	}
 
 	*pLength = pktlen;
 }
 
 static void rtw_hal_construct_PNO_info(_adapter *padapter,
-		u8 *pframe, u32*pLength)
+				       u8 *pframe, u32 *pLength)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
+	int i;
 
 	u8	*pPnoInfoPkt = pframe;
-	pPnoInfoPkt =  (u8*)(pframe+ *pLength);
+	pPnoInfoPkt = (u8 *)(pframe + *pLength);
 	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_num, 1);
 
-	*pLength+=1;
 	pPnoInfoPkt += 1;
 	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->hidden_ssid_num, 1);
 
-	*pLength+=3;
 	pPnoInfoPkt += 3;
 	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->fast_scan_period, 1);
 
-	*pLength+=4;
 	pPnoInfoPkt += 4;
 	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->fast_scan_iterations, 4);
 
-	*pLength+=4;
 	pPnoInfoPkt += 4;
 	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->slow_scan_period, 4);
 
-	*pLength+=4;
 	pPnoInfoPkt += 4;
-	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_length,
-			MAX_PNO_LIST_COUNT);
+	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_length, MAX_PNO_LIST_COUNT);
 
-	*pLength+=MAX_PNO_LIST_COUNT;
 	pPnoInfoPkt += MAX_PNO_LIST_COUNT;
-	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_cipher_info,
-			MAX_PNO_LIST_COUNT);
+	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_cipher_info, MAX_PNO_LIST_COUNT);
 
-	*pLength+=MAX_PNO_LIST_COUNT;
 	pPnoInfoPkt += MAX_PNO_LIST_COUNT;
-	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_channel_info,
-			MAX_PNO_LIST_COUNT);
+	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_channel_info, MAX_PNO_LIST_COUNT);
 
-	*pLength+=MAX_PNO_LIST_COUNT;
 	pPnoInfoPkt += MAX_PNO_LIST_COUNT;
-	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->loc_probe_req,
-			MAX_HIDDEN_AP);
+	_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->loc_probe_req, MAX_HIDDEN_AP);
 
-	*pLength+=MAX_HIDDEN_AP;
 	pPnoInfoPkt += MAX_HIDDEN_AP;
+
+	/*
+	SSID is located at 128th Byte in NLO info Page
+	*/
+
+	*pLength += 128;
+	pPnoInfoPkt = pframe + 128;
+
+	for (i = 0; i < pwrctl->pnlo_info->ssid_num ; i++) {
+		_rtw_memcpy(pPnoInfoPkt, &pwrctl->pno_ssid_list->node[i].SSID,
+			    pwrctl->pnlo_info->ssid_length[i]);
+		*pLength += WLAN_SSID_MAXLEN;
+		pPnoInfoPkt += WLAN_SSID_MAXLEN;
+	}
 }
 
 static void rtw_hal_construct_ssid_list(_adapter *padapter,
-	u8 *pframe, u32 *pLength)
+					u8 *pframe, u32 *pLength)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	u8 *pSSIDListPkt = pframe;
 	int i;
 
-	pSSIDListPkt =  (u8*)(pframe+ *pLength);
+	pSSIDListPkt = (u8 *)(pframe + *pLength);
 
-	for(i = 0; i < pwrctl->pnlo_info->ssid_num ; i++) {
+	for (i = 0; i < pwrctl->pnlo_info->ssid_num ; i++) {
 		_rtw_memcpy(pSSIDListPkt, &pwrctl->pno_ssid_list->node[i].SSID,
-			pwrctl->pnlo_info->ssid_length[i]);
+			    pwrctl->pnlo_info->ssid_length[i]);
 
 		*pLength += WLAN_SSID_MAXLEN;
 		pSSIDListPkt += WLAN_SSID_MAXLEN;
@@ -5044,68 +7365,68 @@ static void rtw_hal_construct_ssid_list(_adapter *padapter,
 }
 
 static void rtw_hal_construct_scan_info(_adapter *padapter,
-	u8 *pframe, u32 *pLength)
+					u8 *pframe, u32 *pLength)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	u8 *pScanInfoPkt = pframe;
 	int i;
 
-	pScanInfoPkt =  (u8*)(pframe+ *pLength);
+	pScanInfoPkt = (u8 *)(pframe + *pLength);
 
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->channel_num, 1);
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_ch, 1);
 
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_bw, 1);
 
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_40_offset, 1);
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_80_offset, 1);
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->periodScan, 1);
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->period_scan_time, 1);
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->enableRFE, 1);
 
-	*pLength+=1;
+	*pLength += 1;
 	pScanInfoPkt += 1;
 	_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->rfe_type, 8);
 
-	*pLength+=8;
+	*pLength += 8;
 	pScanInfoPkt += 8;
 
-	for(i = 0 ; i < MAX_SCAN_LIST_COUNT ; i ++) {
+	for (i = 0 ; i < MAX_SCAN_LIST_COUNT ; i++) {
 		_rtw_memcpy(pScanInfoPkt,
-			&pwrctl->pscan_info->ssid_channel_info[i], 4);
-		*pLength+=4;
+			    &pwrctl->pscan_info->ssid_channel_info[i], 4);
+		*pLength += 4;
 		pScanInfoPkt += 4;
 	}
 }
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 
 #ifdef CONFIG_GTK_OL
 static void rtw_hal_construct_GTKRsp(
 	PADAPTER	padapter,
 	u8		*pframe,
 	u32		*pLength
-	)
+)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u16	*fctrl;
@@ -5116,274 +7437,419 @@ static void rtw_hal_construct_GTKRsp(
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 	static u8	LLCHeader[8] = {0xAA, 0xAA, 0x03, 0x00, 0x00, 0x00, 0x88, 0x8E};
-	static u8	GTKbody_a[11] ={0x01, 0x03, 0x00, 0x5F, 0x02, 0x03, 0x12, 0x00, 0x10, 0x42, 0x0B};
+	static u8	GTKbody_a[11] = {0x01, 0x03, 0x00, 0x5F, 0x02, 0x03, 0x12, 0x00, 0x10, 0x42, 0x0B};
 	u8	*pGTKRspPkt = pframe;
 	u8	EncryptionHeadOverhead = 0;
-	//DBG_871X("%s:%d\n", __FUNCTION__, bForcePowerSave);
+	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
 
-	pwlanhdr = (struct rtw_ieee80211_hdr*)pframe;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
 	fctrl = &pwlanhdr->frame_ctl;
 	*(fctrl) = 0;
 
-	//-------------------------------------------------------------------------
-	// MAC Header.
-	//-------------------------------------------------------------------------
+	/* ------------------------------------------------------------------------- */
+	/* MAC Header. */
+	/* ------------------------------------------------------------------------- */
 	SetFrameType(fctrl, WIFI_DATA);
-	//SetFrameSubType(fctrl, 0);
+	/* set_frame_sub_type(fctrl, 0); */
 	SetToDs(fctrl);
 
 	_rtw_memcpy(pwlanhdr->addr1,
-			get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		    get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	_rtw_memcpy(pwlanhdr->addr2,
-			adapter_mac_addr(padapter), ETH_ALEN);
+		    adapter_mac_addr(padapter), ETH_ALEN);
 
 	_rtw_memcpy(pwlanhdr->addr3,
-			get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		    get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	SetSeqNum(pwlanhdr, 0);
-	SetDuration(pwlanhdr, 0);
+	set_duration(pwlanhdr, 0);
 
 #ifdef CONFIG_WAPI_SUPPORT
 	*pLength = sMacHdrLng;
 #else
 	*pLength = 24;
-#endif //CONFIG_WAPI_SUPPORT
+#endif /* CONFIG_WAPI_SUPPORT */
 
-	//-------------------------------------------------------------------------
-	// Security Header: leave space for it if necessary.
-	//-------------------------------------------------------------------------
+	/* ------------------------------------------------------------------------- */
+	/* Security Header: leave space for it if necessary. */
+	/* ------------------------------------------------------------------------- */
 	switch (psecuritypriv->dot11PrivacyAlgrthm) {
-		case _WEP40_:
-		case _WEP104_:
-			EncryptionHeadOverhead = 4;
-			break;
-		case _TKIP_:
-			EncryptionHeadOverhead = 8;
-			break;
-		case _AES_:
-			EncryptionHeadOverhead = 8;
-			break;
+	case _WEP40_:
+	case _WEP104_:
+		EncryptionHeadOverhead = 4;
+		break;
+	case _TKIP_:
+		EncryptionHeadOverhead = 8;
+		break;
+	case _AES_:
+		EncryptionHeadOverhead = 8;
+		break;
 #ifdef CONFIG_WAPI_SUPPORT
-		case _SMS4_:
-			EncryptionHeadOverhead = 18;
-			break;
-#endif //CONFIG_WAPI_SUPPORT
-		default:
-			EncryptionHeadOverhead = 0;
+	case _SMS4_:
+		EncryptionHeadOverhead = 18;
+		break;
+#endif /* CONFIG_WAPI_SUPPORT */
+	default:
+		EncryptionHeadOverhead = 0;
 	}
 
 	if (EncryptionHeadOverhead > 0) {
-		_rtw_memset(&(pframe[*pLength]), 0,EncryptionHeadOverhead);
+		_rtw_memset(&(pframe[*pLength]), 0, EncryptionHeadOverhead);
 		*pLength += EncryptionHeadOverhead;
-		//SET_80211_HDR_WEP(pGTKRspPkt, 1);  //Suggested by CCW.
-		//GTK's privacy bit is done by FW
-		//SetPrivacy(fctrl);
-	}
-	//-------------------------------------------------------------------------
-	// Frame Body.
-	//-------------------------------------------------------------------------
-	pGTKRspPkt =  (u8*)(pframe+ *pLength);
-	// LLC header
+		/* SET_80211_HDR_WEP(pGTKRspPkt, 1);  */ /* Suggested by CCW. */
+		/* GTK's privacy bit is done by FW */
+		/* SetPrivacy(fctrl); */
+	}
+	/* ------------------------------------------------------------------------- */
+	/* Frame Body. */
+	/* ------------------------------------------------------------------------- */
+	pGTKRspPkt = (u8 *)(pframe + *pLength);
+	/* LLC header */
 	_rtw_memcpy(pGTKRspPkt, LLCHeader, 8);
 	*pLength += 8;
 
-	// GTK element
+	/* GTK element */
 	pGTKRspPkt += 8;
 
-	//GTK frame body after LLC, part 1
+	/* GTK frame body after LLC, part 1 */
+	/* TKIP key_length = 32, AES key_length = 16 */
+	if (psecuritypriv->dot118021XGrpPrivacy == _TKIP_)
+		GTKbody_a[8] = 0x20;
+
+	/* GTK frame body after LLC, part 1 */
 	_rtw_memcpy(pGTKRspPkt, GTKbody_a, 11);
 	*pLength += 11;
 	pGTKRspPkt += 11;
-	//GTK frame body after LLC, part 2
+	/* GTK frame body after LLC, part 2 */
 	_rtw_memset(&(pframe[*pLength]), 0, 88);
 	*pLength += 88;
 	pGTKRspPkt += 88;
 
+	if (psecuritypriv->dot118021XGrpPrivacy == _TKIP_)
+		*pLength += 8;
+}
+#endif /* CONFIG_GTK_OL */
+
+#define PN_2_CCMPH(ch,key_id)	((ch) & 0x000000000000ffff) \
+				| (((ch) & 0x0000ffffffff0000) << 16) \
+				| (((key_id) << 30)) \
+				| BIT(29)
+static void rtw_hal_construct_remote_control_info(_adapter *adapter,
+						  u8 *pframe, u32 *pLength)
+{
+	struct mlme_priv   *pmlmepriv = &adapter->mlmepriv;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct security_priv *psecuritypriv = &adapter->securitypriv;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct sta_info *psta;
+	struct stainfo_rxcache *prxcache;
+	u8 cur_dot11rxiv[8], id = 0, tid_id = 0, i = 0;
+	size_t sz = 0, total = 0;
+	u64 ccmp_hdr = 0, tmp_key = 0;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+
+	if (psta == NULL) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	prxcache = &psta->sta_recvpriv.rxcache;
+	sz = sizeof(cur_dot11rxiv);
+
+	/* 3 SEC IV * 1 page */
+	rtw_get_sec_iv(adapter, cur_dot11rxiv,
+		       get_my_bssid(&pmlmeinfo->network));
+
+	_rtw_memcpy(pframe, cur_dot11rxiv, sz);
+	*pLength += sz;
+	pframe += sz;
+
+	_rtw_memset(&cur_dot11rxiv, 0, sz);
+
+	if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
+		id = psecuritypriv->dot118021XGrpKeyid;
+		tid_id = prxcache->last_tid;
+		REMOTE_INFO_CTRL_SET_VALD_EN(cur_dot11rxiv, 0xdd);
+		REMOTE_INFO_CTRL_SET_PTK_EN(cur_dot11rxiv, 1);
+		REMOTE_INFO_CTRL_SET_GTK_EN(cur_dot11rxiv, 1);
+		REMOTE_INFO_CTRL_SET_GTK_IDX(cur_dot11rxiv, id);
+		_rtw_memcpy(pframe, cur_dot11rxiv, sz);
+		*pLength += sz;
+		pframe += sz;
+
+		_rtw_memcpy(pframe, prxcache->iv[tid_id], sz);
+		*pLength += sz;
+		pframe += sz;
+
+		total = sizeof(psecuritypriv->iv_seq);
+		total /= sizeof(psecuritypriv->iv_seq[0]);
+
+		for (i = 0 ; i < total ; i ++) {
+			ccmp_hdr =
+				le64_to_cpu(*(u64*)psecuritypriv->iv_seq[i]);
+			_rtw_memset(&cur_dot11rxiv, 0, sz);
+			if (ccmp_hdr != 0) {
+				tmp_key = i;
+				ccmp_hdr = PN_2_CCMPH(ccmp_hdr, tmp_key);
+				*(u64*)cur_dot11rxiv = cpu_to_le64(ccmp_hdr);
+				_rtw_memcpy(pframe, cur_dot11rxiv, sz);
+			}
+			*pLength += sz;
+			pframe += sz;
+		}
+	}
 }
-#endif //CONFIG_GTK_OL
 
+/*#define DBG_RSVD_PAGE_CFG*/
+#ifdef DBG_RSVD_PAGE_CFG
+#define RSVD_PAGE_CFG(ops, v1, v2, v3)	\
+	RTW_INFO("=== [RSVD][%s]-NeedPage:%d, TotalPageNum:%d TotalPacketLen:%d ===\n",	\
+		ops, v1, v2, v3)
+#endif
 void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
-		u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
-		RSVDPAGE_LOC *rsvd_page_loc)
+		  u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
+				  RSVDPAGE_LOC *rsvd_page_loc)
 {
 	struct security_priv *psecuritypriv = &adapter->securitypriv;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 	struct mlme_ext_priv	*pmlmeext;
 	struct mlme_ext_info	*pmlmeinfo;
-	u32	ARPLegnth = 0, GTKLegnth = 0, PNOLength = 0, ScanInfoLength = 0;
-	u32	SSIDLegnth = 0, ProbeReqLength = 0;
+	u32	ARPLength = 0, GTKLength = 0, PNOLength = 0, ScanInfoLength = 0;
+	u32     SSIDLegnth = 0, ProbeReqLength = 0, ns_len = 0, rc_len = 0;
 	u8 CurtPktPageNum = 0;
-	u8 currentip[4];
-	u8 cur_dot11txpn[8];
 
 #ifdef CONFIG_GTK_OL
 	struct sta_priv *pstapriv = &adapter->stapriv;
-	struct sta_info * psta;
+	struct sta_info *psta;
+	struct security_priv *psecpriv = &adapter->securitypriv;
 	u8 kek[RTW_KEK_LEN];
 	u8 kck[RTW_KCK_LEN];
-#endif //CONFIG_GTK_OL
-#ifdef	CONFIG_PNO_SUPPORT 
+#endif /* CONFIG_GTK_OL */
+#ifdef CONFIG_PNO_SUPPORT
 	int pno_index;
 	u8 ssid_num;
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 
 	pmlmeext = &adapter->mlmeextpriv;
 	pmlmeinfo = &pmlmeext->mlmext_info;
 
 	if (pwrctl->wowlan_pno_enable == _FALSE) {
-		//ARP RSP * 1 page
-		rtw_get_current_ip_address(adapter, currentip);
+		/* ARP RSP * 1 page */
 
 		rsvd_page_loc->LocArpRsp = *page_num;
 
-		DBG_871X("LocArpRsp: %d\n", rsvd_page_loc->LocArpRsp);
+		RTW_INFO("LocArpRsp: %d\n", rsvd_page_loc->LocArpRsp);
 
-		rtw_hal_construct_ARPRsp( adapter, &pframe[index],
-				&ARPLegnth, currentip);
+		rtw_hal_construct_ARPRsp(adapter, &pframe[index],
+					 &ARPLength, pmlmeinfo->ip_addr);
 
 		rtw_hal_fill_fake_txdesc(adapter,
-				&pframe[index-tx_desc],
-				ARPLegnth, _FALSE, _FALSE, _TRUE);
+					 &pframe[index - tx_desc],
+					 ARPLength, _FALSE, _FALSE, _TRUE);
 
-		CurtPktPageNum = (u8)PageNum(tx_desc + ARPLegnth, page_size);
+		CurtPktPageNum = (u8)PageNum(tx_desc + ARPLength, page_size);
 
 		*page_num += CurtPktPageNum;
 
 		index += (CurtPktPageNum * page_size);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-ARPRsp", CurtPktPageNum, *page_num, 0);
+		#endif
 
-		//3 SEC IV * 1 page
-		rtw_get_sec_iv(adapter, cur_dot11txpn,
-				get_my_bssid(&pmlmeinfo->network));
-
-		rsvd_page_loc->LocRemoteCtrlInfo = *page_num;
-
-		DBG_871X("LocRemoteCtrlInfo: %d\n", rsvd_page_loc->LocRemoteCtrlInfo);
+#ifdef CONFIG_IPV6
+		/* 2 NS offload and NDP Info*/
+		if (pwrctl->wowlan_ns_offload_en == _TRUE) {
+			rsvd_page_loc->LocNbrAdv = *page_num;
+			RTW_INFO("LocNbrAdv: %d\n", rsvd_page_loc->LocNbrAdv);
+			rtw_hal_construct_na_message(adapter,
+						     &pframe[index], &ns_len);
+			rtw_hal_fill_fake_txdesc(adapter,
+						 &pframe[index - tx_desc],
+						 ns_len, _FALSE,
+						 _FALSE, _TRUE);
+			CurtPktPageNum = (u8)PageNum(tx_desc + ns_len,
+						      page_size);
+			*page_num += CurtPktPageNum;
+			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-NbrAdv", CurtPktPageNum, *page_num, 0);
+			#endif
 
-		_rtw_memcpy(pframe+index-tx_desc, cur_dot11txpn, _AES_IV_LEN_);
+			rsvd_page_loc->LocNDPInfo = *page_num;
+			RTW_INFO("LocNDPInfo: %d\n",
+				 rsvd_page_loc->LocNDPInfo);
 
-		CurtPktPageNum = (u8)PageNum(_AES_IV_LEN_, page_size);
+			rtw_hal_construct_ndp_info(adapter,
+						   &pframe[index - tx_desc],
+						   &ns_len);
+			CurtPktPageNum =
+				(u8)PageNum(tx_desc + ns_len, page_size);
+			*page_num += CurtPktPageNum;
+			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-NDPInfo", CurtPktPageNum, *page_num, 0);
+			#endif
 
+		}
+#endif /*CONFIG_IPV6*/
+		/* 3 Remote Control Info. * 1 page */
+		rsvd_page_loc->LocRemoteCtrlInfo = *page_num;
+		RTW_INFO("LocRemoteCtrlInfo: %d\n", rsvd_page_loc->LocRemoteCtrlInfo);
+		rtw_hal_construct_remote_control_info(adapter,
+						      &pframe[index - tx_desc],
+						      &rc_len);
+		CurtPktPageNum = (u8)PageNum(rc_len, page_size);
 		*page_num += CurtPktPageNum;
-
-		*total_pkt_len = index + _AES_IV_LEN_;
+		*total_pkt_len = index + rc_len;
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-RCI", CurtPktPageNum, *page_num, *total_pkt_len);
+		#endif
 #ifdef CONFIG_GTK_OL
 		index += (CurtPktPageNum * page_size);
 
-		//if the ap staion info. exists, get the kek, kck from staion info.
+		/* if the ap staion info. exists, get the kek, kck from staion info. */
 		psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
 		if (psta == NULL) {
 			_rtw_memset(kek, 0, RTW_KEK_LEN);
 			_rtw_memset(kck, 0, RTW_KCK_LEN);
-			DBG_8192C("%s, KEK, KCK download rsvd page all zero \n",
-					__func__);
+			RTW_INFO("%s, KEK, KCK download rsvd page all zero\n",
+				 __func__);
 		} else {
 			_rtw_memcpy(kek, psta->kek, RTW_KEK_LEN);
 			_rtw_memcpy(kck, psta->kck, RTW_KCK_LEN);
 		}
 
-		//3 KEK, KCK
+		/* 3 KEK, KCK */
 		rsvd_page_loc->LocGTKInfo = *page_num;
-		DBG_871X("LocGTKInfo: %d\n", rsvd_page_loc->LocGTKInfo);
+		RTW_INFO("LocGTKInfo: %d\n", rsvd_page_loc->LocGTKInfo);
 
 		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_8812(adapter)) {
 			struct security_priv *psecpriv = NULL;
-			
+
 			psecpriv = &adapter->securitypriv;
-			_rtw_memcpy(pframe+index-tx_desc,
-					&psecpriv->dot11PrivacyAlgrthm, 1);
-			_rtw_memcpy(pframe+index-tx_desc+1,
-					&psecpriv->dot118021XGrpPrivacy, 1);
-			_rtw_memcpy(pframe+index-tx_desc+2,
-					kck, RTW_KCK_LEN);
-			_rtw_memcpy(pframe+index-tx_desc+2+RTW_KCK_LEN,
-					kek, RTW_KEK_LEN);
+			_rtw_memcpy(pframe + index - tx_desc,
+				    &psecpriv->dot11PrivacyAlgrthm, 1);
+			_rtw_memcpy(pframe + index - tx_desc + 1,
+				    &psecpriv->dot118021XGrpPrivacy, 1);
+			_rtw_memcpy(pframe + index - tx_desc + 2,
+				    kck, RTW_KCK_LEN);
+			_rtw_memcpy(pframe + index - tx_desc + 2 + RTW_KCK_LEN,
+				    kek, RTW_KEK_LEN);
 			CurtPktPageNum = (u8)PageNum(tx_desc + 2 + RTW_KCK_LEN + RTW_KEK_LEN, page_size);
 		} else {
-			_rtw_memcpy(pframe+index-tx_desc, kck, RTW_KCK_LEN);
-			_rtw_memcpy(pframe+index-tx_desc+RTW_KCK_LEN, kek, RTW_KEK_LEN);
-			CurtPktPageNum = (u8)PageNum(tx_desc + RTW_KCK_LEN + RTW_KEK_LEN, page_size);
-		}
-		
-		
 
+			_rtw_memcpy(pframe + index - tx_desc, kck, RTW_KCK_LEN);
+			_rtw_memcpy(pframe + index - tx_desc + RTW_KCK_LEN,
+				    kek, RTW_KEK_LEN);
+			GTKLength = tx_desc + RTW_KCK_LEN + RTW_KEK_LEN;
+
+			if (psta != NULL &&
+				psecuritypriv->dot118021XGrpPrivacy == _TKIP_) {
+				_rtw_memcpy(pframe + index - tx_desc + 56,
+					&psta->dot11tkiptxmickey, RTW_TKIP_MIC_LEN);
+				GTKLength += RTW_TKIP_MIC_LEN;
+			}
+			CurtPktPageNum = (u8)PageNum(GTKLength, page_size);
+		}
 #if 0
 		{
 			int i;
 			printk("\ntoFW KCK: ");
-			for(i=0;i<16; i++)
+			for (i = 0; i < 16; i++)
 				printk(" %02x ", kck[i]);
 			printk("\ntoFW KEK: ");
-			for(i=0;i<16; i++)
+			for (i = 0; i < 16; i++)
 				printk(" %02x ", kek[i]);
 			printk("\n");
 		}
 
-		DBG_871X("%s(): HW_VAR_SET_TX_CMD: KEK KCK %p %d\n", 
-			__FUNCTION__, &pframe[index-tx_desc],
-			(tx_desc + RTW_KCK_LEN + RTW_KEK_LEN));
+		RTW_INFO("%s(): HW_VAR_SET_TX_CMD: KEK KCK %p %d\n",
+			 __FUNCTION__, &pframe[index - tx_desc],
+			 (tx_desc + RTW_KCK_LEN + RTW_KEK_LEN));
 #endif
 
 		*page_num += CurtPktPageNum;
 
 		index += (CurtPktPageNum * page_size);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-GTKInfo", CurtPktPageNum, *page_num, 0);
+		#endif
 
-		//3 GTK Response
-		rsvd_page_loc->LocGTKRsp= *page_num;
-		DBG_871X("LocGTKRsp: %d\n", rsvd_page_loc->LocGTKRsp);
-		rtw_hal_construct_GTKRsp(adapter, &pframe[index], &GTKLegnth);
+		/* 3 GTK Response */
+		rsvd_page_loc->LocGTKRsp = *page_num;
+		RTW_INFO("LocGTKRsp: %d\n", rsvd_page_loc->LocGTKRsp);
+		rtw_hal_construct_GTKRsp(adapter, &pframe[index], &GTKLength);
 
-		rtw_hal_fill_fake_txdesc(adapter, &pframe[index-tx_desc],
-				GTKLegnth, _FALSE, _FALSE, _TRUE);
+		rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
+					 GTKLength, _FALSE, _FALSE, _TRUE);
 #if 0
 		{
 			int gj;
-			printk("123GTK pkt=> \n");
-			for(gj=0; gj < GTKLegnth+tx_desc; gj++) {
-				printk(" %02x ", pframe[index-tx_desc+gj]);
-				if ((gj + 1)%16==0)
+			printk("123GTK pkt=>\n");
+			for (gj = 0; gj < GTKLength + tx_desc; gj++) {
+				printk(" %02x ", pframe[index - tx_desc + gj]);
+				if ((gj + 1) % 16 == 0)
 					printk("\n");
 			}
 			printk(" <=end\n");
 		}
 
-		DBG_871X("%s(): HW_VAR_SET_TX_CMD: GTK RSP %p %d\n",
-			__FUNCTION__, &pframe[index-tx_desc],
-			(tx_desc + GTKLegnth));
+		RTW_INFO("%s(): HW_VAR_SET_TX_CMD: GTK RSP %p %d\n",
+			 __FUNCTION__, &pframe[index - tx_desc],
+			 (tx_desc + GTKLength));
 #endif
 
-		CurtPktPageNum = (u8)PageNum(tx_desc + GTKLegnth, page_size);
+		CurtPktPageNum = (u8)PageNum(tx_desc + GTKLength, page_size);
 
 		*page_num += CurtPktPageNum;
 
 		index += (CurtPktPageNum * page_size);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-GTKRsp", CurtPktPageNum, *page_num, 0);
+		#endif
 
-		//below page is empty for GTK extension memory
-		//3(11) GTK EXT MEM
+		/* below page is empty for GTK extension memory */
+		/* 3(11) GTK EXT MEM */
 		rsvd_page_loc->LocGTKEXTMEM = *page_num;
-
+		RTW_INFO("LocGTKEXTMEM: %d\n", rsvd_page_loc->LocGTKEXTMEM);
 		CurtPktPageNum = 2;
 
 		if (page_size >= 256)
 			CurtPktPageNum = 1;
 
 		*page_num += CurtPktPageNum;
-		//extension memory for FW
+		/* extension memory for FW */
 		*total_pkt_len = index + (page_size * CurtPktPageNum);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-GTKEXTMEM", CurtPktPageNum, *page_num, *total_pkt_len);
+		#endif
+#endif /* CONFIG_GTK_OL */
+
+		index += (CurtPktPageNum * page_size);
 
-#endif //CONFIG_GTK_OL
+		/*Reserve 1 page for AOAC report*/
+		rsvd_page_loc->LocAOACReport = *page_num;
+		RTW_INFO("LocAOACReport: %d\n", rsvd_page_loc->LocAOACReport);
+		*page_num += 1;
+		*total_pkt_len = index + (page_size * 1);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-AOAC", 1, *page_num, *total_pkt_len);
+		#endif
 	} else {
 #ifdef CONFIG_PNO_SUPPORT
-		if (pwrctl->pno_in_resume == _FALSE &&
-				pwrctl->pno_inited == _TRUE) {
+		if (pwrctl->wowlan_in_resume == _FALSE &&
+		    pwrctl->pno_inited == _TRUE) {
 
-			//Broadcast Probe Request
+			/* Broadcast Probe Request */
 			rsvd_page_loc->LocProbePacket = *page_num;
 
-			DBG_871X("loc_probe_req: %d\n",
-					rsvd_page_loc->LocProbePacket);
+			RTW_INFO("loc_probe_req: %d\n",
+				 rsvd_page_loc->LocProbePacket);
 
 			rtw_hal_construct_ProbeReq(
 				adapter,
@@ -5392,8 +7858,8 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 				NULL);
 
 			rtw_hal_fill_fake_txdesc(adapter,
-				&pframe[index-tx_desc],
-				ProbeReqLength, _FALSE, _FALSE, _FALSE);
+						 &pframe[index - tx_desc],
+				 ProbeReqLength, _FALSE, _FALSE, _FALSE);
 
 			CurtPktPageNum =
 				(u8)PageNum(tx_desc + ProbeReqLength, page_size);
@@ -5401,8 +7867,11 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 			*page_num += CurtPktPageNum;
 
 			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-ProbeReq", CurtPktPageNum, *page_num, 0);
+			#endif
 
-			//Hidden SSID Probe Request
+			/* Hidden SSID Probe Request */
 			ssid_num = pwrctl->pnlo_info->hidden_ssid_num;
 
 			for (pno_index = 0 ; pno_index < ssid_num ; pno_index++) {
@@ -5416,7 +7885,7 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 					&pwrctl->pno_ssid_list->node[pno_index]);
 
 				rtw_hal_fill_fake_txdesc(adapter,
-					&pframe[index - tx_desc],
+						 &pframe[index - tx_desc],
 					ProbeReqLength, _FALSE, _FALSE, _FALSE);
 
 				CurtPktPageNum =
@@ -5425,71 +7894,83 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 				*page_num += CurtPktPageNum;
 
 				index += (CurtPktPageNum * page_size);
+				#ifdef DBG_RSVD_PAGE_CFG
+				RSVD_PAGE_CFG("WOW-ProbeReq", CurtPktPageNum, *page_num, 0);
+				#endif
 			}
 
-			//PNO INFO Page
+			/* PNO INFO Page */
 			rsvd_page_loc->LocPNOInfo = *page_num;
-			DBG_871X("LocPNOInfo: %d\n", rsvd_page_loc->LocPNOInfo);
+			RTW_INFO("LocPNOInfo: %d\n", rsvd_page_loc->LocPNOInfo);
 			rtw_hal_construct_PNO_info(adapter,
-					&pframe[index - tx_desc],
-					&PNOLength);
+						   &pframe[index - tx_desc],
+						   &PNOLength);
 
 			CurtPktPageNum = (u8)PageNum(PNOLength, page_size);
 			*page_num += CurtPktPageNum;
 			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-PNOInfo", CurtPktPageNum, *page_num, 0);
+			#endif
 
-			//SSID List Page
-			rsvd_page_loc->LocSSIDInfo = *page_num;
-			DBG_871X("LocSSIDInfo: %d\n", rsvd_page_loc->LocSSIDInfo);
-			rtw_hal_construct_ssid_list(adapter,
-					&pframe[index - tx_desc],
-					&SSIDLegnth);
-
-			CurtPktPageNum = (u8)PageNum(SSIDLegnth, page_size);
-			*page_num += CurtPktPageNum;
-			index += (CurtPktPageNum * page_size);
-
-			//Scan Info Page
+			/* Scan Info Page */
 			rsvd_page_loc->LocScanInfo = *page_num;
-			DBG_871X("LocScanInfo: %d\n", rsvd_page_loc->LocScanInfo);
+			RTW_INFO("LocScanInfo: %d\n", rsvd_page_loc->LocScanInfo);
 			rtw_hal_construct_scan_info(adapter,
-					&pframe[index - tx_desc],
-					&ScanInfoLength);
+						    &pframe[index - tx_desc],
+						    &ScanInfoLength);
 
 			CurtPktPageNum = (u8)PageNum(ScanInfoLength, page_size);
 			*page_num += CurtPktPageNum;
 			*total_pkt_len = index + ScanInfoLength;
 			index += (CurtPktPageNum * page_size);
-
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-ScanInfo", CurtPktPageNum, *page_num, *total_pkt_len);
+			#endif
 		}
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 	}
 }
 
 static void rtw_hal_gate_bb(_adapter *adapter, bool stop)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
-	u8 val8 = 0;
+	u8 i = 0, val8 = 0, empty = _FAIL;
 	u16 val16 = 0;
 
-	if (stop) {
+	if (stop) {
+		/* checking TX queue status */
+		for (i = 0 ; i < 5 ; i++) {
+			rtw_hal_get_hwreg(adapter, HW_VAR_CHK_MGQ_CPU_EMPTY, &empty);
+			if (empty) {
+				break;
+			} else {
+				RTW_WARN("%s: MGQ_CPU is busy(%d)!\n",
+					 __func__, i);
+				rtw_mdelay_os(10);
+			}
+		}
+
+		if (val8 == 5)
+			RTW_ERR("%s: Polling MGQ_CPU empty fail!\n", __func__);
+
 		/* Pause TX*/
 		pwrpriv->wowlan_txpause_status = rtw_read8(adapter, REG_TXPAUSE);
 		rtw_write8(adapter, REG_TXPAUSE, 0xff);
 		val8 = rtw_read8(adapter, REG_SYS_FUNC_EN);
 		val8 &= ~BIT(0);
 		rtw_write8(adapter, REG_SYS_FUNC_EN, val8);
-		DBG_871X("%s: BB gated: 0x%02x, store TXPAUSE: %02x\n",
-				__func__,
-				rtw_read8(adapter, REG_SYS_FUNC_EN),
-				pwrpriv->wowlan_txpause_status);
+		RTW_INFO("%s: BB gated: 0x%02x, store TXPAUSE: %02x\n",
+			 __func__,
+			 rtw_read8(adapter, REG_SYS_FUNC_EN),
+			 pwrpriv->wowlan_txpause_status);
 	} else {
 		val8 = rtw_read8(adapter, REG_SYS_FUNC_EN);
 		val8 |= BIT(0);
 		rtw_write8(adapter, REG_SYS_FUNC_EN, val8);
-		DBG_871X("%s: BB release: 0x%02x, recover TXPAUSE:%02x\n",
-				__func__, rtw_read8(adapter, REG_SYS_FUNC_EN),
-				pwrpriv->wowlan_txpause_status);
+		RTW_INFO("%s: BB release: 0x%02x, recover TXPAUSE:%02x\n",
+			 __func__, rtw_read8(adapter, REG_SYS_FUNC_EN),
+			 pwrpriv->wowlan_txpause_status);
 		/* release TX*/
 		rtw_write8(adapter, REG_TXPAUSE, pwrpriv->wowlan_txpause_status);
 	}
@@ -5506,9 +7987,114 @@ static void rtw_hal_reset_mac_rx(_adapter *adapter)
 	/* Set REG_CR bit1, bit3, bit7 to 1*/
 	val8 |= 0x8a;
 	rtw_write8(adapter, REG_CR, val8);
-	DBG_871X("0x%04x: %02x\n", REG_CR, rtw_read8(adapter, REG_CR));
+	RTW_INFO("0x%04x: %02x\n", REG_CR, rtw_read8(adapter, REG_CR));
+}
+
+static u8 rtw_hal_wow_pattern_generate(_adapter *adapter, u8 idx, struct rtl_wow_pattern *pwow_pattern)
+{
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+	 u8 *pattern;
+	 u8 len = 0;
+	 u8 *mask;
+
+	u8 mask_hw[MAX_WKFM_SIZE] = {0};
+	u8 content[MAX_WKFM_PATTERN_SIZE] = {0};
+	u8 broadcast_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 multicast_addr1[2] = {0x33, 0x33};
+	u8 multicast_addr2[3] = {0x01, 0x00, 0x5e};
+	u8 mask_len = 0;
+	u8 mac_addr[ETH_ALEN] = {0};
+	u16 count = 0;
+	int i, j;
+
+	if (pwrctl->wowlan_pattern_idx > MAX_WKFM_CAM_NUM) {
+		RTW_INFO("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
+			 __func__, MAX_WKFM_CAM_NUM);
+		return _FAIL;
+	}
+
+	pattern = pwrctl->patterns[idx].content;
+	len = pwrctl->patterns[idx].len;
+	mask = pwrctl->patterns[idx].mask;
+
+	_rtw_memcpy(mac_addr, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memset(pwow_pattern, 0, sizeof(struct rtl_wow_pattern));
+
+	mask_len = DIV_ROUND_UP(len, 8);
+
+	/* 1. setup A1 table */
+	if (memcmp(pattern, broadcast_addr, ETH_ALEN) == 0)
+		pwow_pattern->type = PATTERN_BROADCAST;
+	else if (memcmp(pattern, multicast_addr1, 2) == 0)
+		pwow_pattern->type = PATTERN_MULTICAST;
+	else if (memcmp(pattern, multicast_addr2, 3) == 0)
+		pwow_pattern->type = PATTERN_MULTICAST;
+	else if (memcmp(pattern, mac_addr, ETH_ALEN) == 0)
+		pwow_pattern->type = PATTERN_UNICAST;
+	else
+		pwow_pattern->type = PATTERN_INVALID;
+
+	/* translate mask from os to mask for hw */
+
+	/******************************************************************************
+	 * pattern from OS uses 'ethenet frame', like this:
+
+		|    6   |    6   |   2  |     20    |  Variable  |  4  |
+		|--------+--------+------+-----------+------------+-----|
+		|    802.3 Mac Header    | IP Header | TCP Packet | FCS |
+		|   DA   |   SA   | Type |
+
+	 * BUT, packet catched by our HW is in '802.11 frame', begin from LLC,
+
+		|     24 or 30      |    6   |   2  |     20    |  Variable  |  4  |
+		|-------------------+--------+------+-----------+------------+-----|
+		| 802.11 MAC Header |       LLC     | IP Header | TCP Packet | FCS |
+				    | Others | Tpye |
+
+	 * Therefore, we need translate mask_from_OS to mask_to_hw.
+	 * We should left-shift mask by 6 bits, then set the new bit[0~5] = 0,
+	 * because new mask[0~5] means 'SA', but our HW packet begins from LLC,
+	 * bit[0~5] corresponds to first 6 Bytes in LLC, they just don't match.
+	 ******************************************************************************/
+	/* Shift 6 bits */
+	for (i = 0; i < mask_len - 1; i++) {
+		mask_hw[i] = mask[i] >> 6;
+		mask_hw[i] |= (mask[i + 1] & 0x3F) << 2;
+	}
+
+	mask_hw[i] = (mask[i] >> 6) & 0x3F;
+	/* Set bit 0-5 to zero */
+	mask_hw[0] &= 0xC0;
+
+	for (i = 0; i < (MAX_WKFM_SIZE / 4); i++) {
+		pwow_pattern->mask[i] = mask_hw[i * 4];
+		pwow_pattern->mask[i] |= (mask_hw[i * 4 + 1] << 8);
+		pwow_pattern->mask[i] |= (mask_hw[i * 4 + 2] << 16);
+		pwow_pattern->mask[i] |= (mask_hw[i * 4 + 3] << 24);
+	}
+
+	/* To get the wake up pattern from the mask.
+	 * We do not count first 12 bits which means
+	 * DA[6] and SA[6] in the pattern to match HW design. */
+	count = 0;
+	for (i = 12; i < len; i++) {
+		if ((mask[i / 8] >> (i % 8)) & 0x01) {
+			content[count] = pattern[i];
+			count++;
+		}
+	}
+
+	pwow_pattern->crc = rtw_calc_crc(content, count);
+
+	if (pwow_pattern->crc != 0) {
+		if (pwow_pattern->type == PATTERN_INVALID)
+			pwow_pattern->type = PATTERN_VALID;
+	}
+
+	return _SUCCESS;
 }
 
+#ifndef CONFIG_WOW_PATTERN_HW_CAM
 static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)
 {
 	u8 val8 = 0;
@@ -5517,7 +8103,7 @@ static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)
 
 	val8 = rtw_read8(adapter, REG_FIFOPAGE + 3);
 	if (val8 != 0)
-		DBG_871X("%s:[%04x]some PKTs in TXPKTBUF\n",
+		RTW_INFO("%s:[%04x]some PKTs in TXPKTBUF\n",
 			 __func__, (REG_FIFOPAGE + 3));
 
 	rtw_hal_reset_mac_rx(adapter);
@@ -5528,22 +8114,229 @@ static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)
 		rxff_bndy = rx_dma_buff_sz - 1;
 
 		rtw_write16(adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
-		DBG_871X("%s: wow mode, 0x%04x: 0x%04x\n", __func__,
+		RTW_INFO("%s: wow mode, 0x%04x: 0x%04x\n", __func__,
 			 REG_TRXFF_BNDY + 2,
-			 rtw_read16(adapter, (REG_TRXFF_BNDY+2)));
+			 rtw_read16(adapter, (REG_TRXFF_BNDY + 2)));
 	} else {
 		rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ,
 				    (u8 *)&rx_dma_buff_sz);
 		rxff_bndy = rx_dma_buff_sz - 1;
 		rtw_write16(adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
-		DBG_871X("%s: normal mode, 0x%04x: 0x%04x\n", __func__,
+		RTW_INFO("%s: normal mode, 0x%04x: 0x%04x\n", __func__,
 			 REG_TRXFF_BNDY + 2,
-			 rtw_read16(adapter, (REG_TRXFF_BNDY+2)));
+			 rtw_read16(adapter, (REG_TRXFF_BNDY + 2)));
 	}
 }
 
+bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)
+{
+	u32 data_l = 0, data_h = 0, rx_dma_buff_sz = 0, page_sz = 0;
+	u16 offset, rx_buf_ptr = 0;
+	u16 cam_start_offset = 0;
+	u16 ctrl_l = 0, ctrl_h = 0;
+	u8 count = 0, tmp = 0;
+	int i = 0;
+	bool res = _TRUE;
+
+	if (idx > MAX_WKFM_CAM_NUM) {
+		RTW_INFO("[Error]: %s, pattern index is out of range\n",
+			 __func__);
+		return _FALSE;
+	}
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ_WOW,
+			    (u8 *)&rx_dma_buff_sz);
+
+	if (rx_dma_buff_sz == 0) {
+		RTW_INFO("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
+		return _FALSE;
+	}
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
+
+	if (page_sz == 0) {
+		RTW_INFO("[Error]: %s, page_sz is 0!!\n", __func__);
+		return _FALSE;
+	}
+
+	offset = (u16)PageNum(rx_dma_buff_sz, page_sz);
+	cam_start_offset = offset * page_sz;
+
+	ctrl_l = 0x0;
+	ctrl_h = 0x0;
+
+	/* Enable RX packet buffer access */
+	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, RXPKT_BUF_SELECT);
+
+	/* Read the WKFM CAM */
+	for (i = 0; i < (WKFMCAM_ADDR_NUM / 2); i++) {
+		/*
+		 * Set Rx packet buffer offset.
+		 * RxBufer pointer increases 1, we can access 8 bytes in Rx packet buffer.
+		 * CAM start offset (unit: 1 byte) =  Index*WKFMCAM_SIZE
+		 * RxBufer pointer addr = (CAM start offset + per entry offset of a WKFMCAM)/8
+		 * * Index: The index of the wake up frame mask
+		 * * WKFMCAM_SIZE: the total size of one WKFM CAM
+		 * * per entry offset of a WKFM CAM: Addr i * 4 bytes
+		 */
+		rx_buf_ptr =
+			(cam_start_offset + idx * WKFMCAM_SIZE + i * 8) >> 3;
+		rtw_write16(adapter, REG_PKTBUF_DBG_CTRL, rx_buf_ptr);
+
+		rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
+		data_l = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_L);
+		data_h = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_H);
+
+		RTW_INFO("[%d]: %08x %08x\n", i, data_h, data_l);
+
+		count = 0;
+
+		do {
+			tmp = rtw_read8(adapter, REG_RXPKTBUF_CTRL);
+			rtw_udelay_os(2);
+			count++;
+		} while (!tmp && count < 100);
+
+		if (count >= 100) {
+			RTW_INFO("%s count:%d\n", __func__, count);
+			res = _FALSE;
+		}
+	}
+
+	/* Disable RX packet buffer access */
+	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL,
+		   DISABLE_TRXPKT_BUF_ACCESS);
+	return res;
+}
+
+bool rtw_write_to_frame_mask(_adapter *adapter, u8 idx,
+			     struct  rtl_wow_pattern *context)
+{
+	u32 data = 0, rx_dma_buff_sz = 0, page_sz = 0;
+	u16 offset, rx_buf_ptr = 0;
+	u16 cam_start_offset = 0;
+	u16 ctrl_l = 0, ctrl_h = 0;
+	u8 count = 0, tmp = 0;
+	int res = 0, i = 0;
+
+	if (idx > MAX_WKFM_CAM_NUM) {
+		RTW_INFO("[Error]: %s, pattern index is out of range\n",
+			 __func__);
+		return _FALSE;
+	}
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ_WOW,
+			    (u8 *)&rx_dma_buff_sz);
+
+	if (rx_dma_buff_sz == 0) {
+		RTW_INFO("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
+		return _FALSE;
+	}
+
+	rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
+
+	if (page_sz == 0) {
+		RTW_INFO("[Error]: %s, page_sz is 0!!\n", __func__);
+		return _FALSE;
+	}
+
+	offset = (u16)PageNum(rx_dma_buff_sz, page_sz);
+
+	cam_start_offset = offset * page_sz;
+
+	if (IS_HARDWARE_TYPE_8188E(adapter)) {
+		ctrl_l = 0x0001;
+		ctrl_h = 0x0001;
+	} else {
+		ctrl_l = 0x0f01;
+		ctrl_h = 0xf001;
+	}
+
+	/* Enable RX packet buffer access */
+	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, RXPKT_BUF_SELECT);
+
+	/* Write the WKFM CAM */
+	for (i = 0; i < WKFMCAM_ADDR_NUM; i++) {
+		/*
+		 * Set Rx packet buffer offset.
+		 * RxBufer pointer increases 1, we can access 8 bytes in Rx packet buffer.
+		 * CAM start offset (unit: 1 byte) =  Index*WKFMCAM_SIZE
+		 * RxBufer pointer addr = (CAM start offset + per entry offset of a WKFMCAM)/8
+		 * * Index: The index of the wake up frame mask
+		 * * WKFMCAM_SIZE: the total size of one WKFM CAM
+		 * * per entry offset of a WKFM CAM: Addr i * 4 bytes
+		 */
+		rx_buf_ptr =
+			(cam_start_offset + idx * WKFMCAM_SIZE + i * 4) >> 3;
+		rtw_write16(adapter, REG_PKTBUF_DBG_CTRL, rx_buf_ptr);
+
+		if (i == 0) {
+			if (context->type == PATTERN_VALID)
+				data = BIT(31);
+			else if (context->type == PATTERN_BROADCAST)
+				data = BIT(31) | BIT(26);
+			else if (context->type == PATTERN_MULTICAST)
+				data = BIT(31) | BIT(25);
+			else if (context->type == PATTERN_UNICAST)
+				data = BIT(31) | BIT(24);
+
+			if (context->crc != 0)
+				data |= context->crc;
+
+			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_L, data);
+			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
+		} else if (i == 1) {
+			data = 0;
+			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_H, data);
+			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_h);
+		} else if (i == 2 || i == 4) {
+			data = context->mask[i - 2];
+			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_L, data);
+			/* write to RX packet buffer*/
+			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
+		} else if (i == 3 || i == 5) {
+			data = context->mask[i - 2];
+			rtw_write32(adapter, REG_PKTBUF_DBG_DATA_H, data);
+			/* write to RX packet buffer*/
+			rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_h);
+		}
+
+		count = 0;
+		do {
+			tmp = rtw_read8(adapter, REG_RXPKTBUF_CTRL);
+			rtw_udelay_os(2);
+			count++;
+		} while (tmp && count < 100);
+
+		if (count >= 100)
+			res = _FALSE;
+		else
+			res = _TRUE;
+	}
+
+	/* Disable RX packet buffer access */
+	rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL,
+		   DISABLE_TRXPKT_BUF_ACCESS);
+
+	return res;
+}
+void rtw_clean_pattern(_adapter *adapter)
+{
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+	struct rtl_wow_pattern zero_pattern;
+	int i = 0;
+
+	_rtw_memset(&zero_pattern, 0, sizeof(struct rtl_wow_pattern));
+
+	zero_pattern.type = PATTERN_INVALID;
+
+	for (i = 0; i < MAX_WKFM_CAM_NUM; i++)
+		rtw_write_to_frame_mask(adapter, i, &zero_pattern);
+
+	rtw_write8(adapter, REG_WKFMCAM_NUM, 0);
+}
 static int rtw_hal_set_pattern(_adapter *adapter, u8 *pattern,
-			       u8 len, u8 *mask)
+			       u8 len, u8 *mask, u8 idx)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 	struct mlme_ext_priv *pmlmeext = NULL;
@@ -5559,9 +8352,9 @@ static int rtw_hal_set_pattern(_adapter *adapter, u8 *pattern,
 	u16 count = 0;
 	int i, j;
 
-	if (pwrctl->wowlan_pattern_idx > MAX_WKFM_NUM) {
-		DBG_871X("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
-			 __func__, MAX_WKFM_NUM);
+	if (pwrctl->wowlan_pattern_idx > MAX_WKFM_CAM_NUM) {
+		RTW_INFO("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
+			 __func__, MAX_WKFM_CAM_NUM);
 		return _FALSE;
 	}
 
@@ -5612,81 +8405,342 @@ static int rtw_hal_set_pattern(_adapter *adapter, u8 *pattern,
 		mask_hw[i] |= (mask[i + 1] & 0x3F) << 2;
 	}
 
-	mask_hw[i] = (mask[i] >> 6) & 0x3F;
-	/* Set bit 0-5 to zero */
-	mask_hw[0] &= 0xC0;
-	
-	for (i = 0; i < (MAX_WKFM_SIZE/4); i++) {
-		wow_pattern.mask[i] = mask_hw[i * 4];
-		wow_pattern.mask[i] |= (mask_hw[i * 4 + 1] << 8);
-		wow_pattern.mask[i] |= (mask_hw[i * 4 + 2] << 16);
-		wow_pattern.mask[i] |= (mask_hw[i * 4 + 3] << 24);
+	mask_hw[i] = (mask[i] >> 6) & 0x3F;
+	/* Set bit 0-5 to zero */
+	mask_hw[0] &= 0xC0;
+
+	for (i = 0; i < (MAX_WKFM_SIZE / 4); i++) {
+		wow_pattern.mask[i] = mask_hw[i * 4];
+		wow_pattern.mask[i] |= (mask_hw[i * 4 + 1] << 8);
+		wow_pattern.mask[i] |= (mask_hw[i * 4 + 2] << 16);
+		wow_pattern.mask[i] |= (mask_hw[i * 4 + 3] << 24);
+	}
+
+	/* To get the wake up pattern from the mask.
+	 * We do not count first 12 bits which means
+	 * DA[6] and SA[6] in the pattern to match HW design. */
+	count = 0;
+	for (i = 12; i < len; i++) {
+		if ((mask[i / 8] >> (i % 8)) & 0x01) {
+			content[count] = pattern[i];
+			count++;
+		}
+	}
+
+	wow_pattern.crc = rtw_calc_crc(content, count);
+
+	if (wow_pattern.crc != 0) {
+		if (wow_pattern.type == PATTERN_INVALID)
+			wow_pattern.type = PATTERN_VALID;
+	}
+
+	index = idx;
+
+	if (!pwrctl->bInSuspend)
+		index += 2;
+
+	/* write pattern */
+	res = rtw_write_to_frame_mask(adapter, index, &wow_pattern);
+
+	if (res == _FALSE)
+		RTW_INFO("%s: ERROR!! idx: %d write_to_frame_mask_cam fail\n",
+			 __func__, idx);
+
+	return res;
+}
+void rtw_fill_pattern(_adapter *adapter)
+{
+	int i = 0, total = 0, index;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct rtl_wow_pattern wow_pattern;
+
+	total = pwrpriv->wowlan_pattern_idx;
+
+	if (total > MAX_WKFM_CAM_NUM)
+		total = MAX_WKFM_CAM_NUM;
+
+	for (i = 0 ; i < total ; i++) {
+		if (_SUCCESS == rtw_hal_wow_pattern_generate(adapter, i, &wow_pattern)) {
+
+			index = i;
+			if (!pwrpriv->bInSuspend)
+				index += 2;
+
+			if (rtw_write_to_frame_mask(adapter, index, &wow_pattern) == _FALSE)
+				RTW_INFO("%s: ERROR!! idx: %d write_to_frame_mask_cam fail\n", __func__, i);
+		}
+
+	}
+	rtw_write8(adapter, REG_WKFMCAM_NUM, total);
+
+}
+
+#else /*CONFIG_WOW_PATTERN_HW_CAM*/
+
+#define WOW_CAM_ACCESS_TIMEOUT_MS	200
+#define WOW_VALID_BIT	BIT31
+#define WOW_BC_BIT		BIT26
+#define WOW_MC_BIT		BIT25
+#define WOW_UC_BIT		BIT24
+
+static u32 _rtw_wow_pattern_read_cam(_adapter *adapter, u8 addr)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	_mutex *mutex = &pwrpriv->wowlan_pattern_cam_mutex;
+
+	u32 rdata = 0;
+	u32 cnt = 0;
+	systime start = 0;
+	u8 timeout = 0;
+	u8 rst = _FALSE;
+
+	_enter_critical_mutex(mutex, NULL);
+
+	rtw_write32(adapter, REG_WKFMCAM_CMD, BIT_WKFCAM_POLLING_V1 | BIT_WKFCAM_ADDR_V2(addr));
+
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(adapter))
+			break;
+
+		cnt++;
+		if (0 == (rtw_read32(adapter, REG_WKFMCAM_CMD) & BIT_WKFCAM_POLLING_V1)) {
+			rst = _SUCCESS;
+			break;
+		}
+		if (rtw_get_passing_time_ms(start) > WOW_CAM_ACCESS_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+
+	rdata = rtw_read32(adapter, REG_WKFMCAM_RWD);
+
+	_exit_critical_mutex(mutex, NULL);
+
+	/*RTW_INFO("%s ==> addr:0x%02x , rdata:0x%08x\n", __func__, addr, rdata);*/
+
+	if (timeout)
+		RTW_ERR(FUNC_ADPT_FMT" failed due to polling timeout\n", FUNC_ADPT_ARG(adapter));
+
+	return rdata;
+}
+void rtw_wow_pattern_read_cam_ent(_adapter *adapter, u8 id, struct  rtl_wow_pattern *context)
+{
+	int i;
+	u32 rdata;
+
+	_rtw_memset(context, 0, sizeof(struct  rtl_wow_pattern));
+
+	for (i = 4; i >= 0; i--) {
+		rdata = _rtw_wow_pattern_read_cam(adapter, (id << 3) | i);
+
+		switch (i) {
+		case 4:
+			if (rdata & WOW_BC_BIT)
+				context->type = PATTERN_BROADCAST;
+			else if (rdata & WOW_MC_BIT)
+				context->type = PATTERN_MULTICAST;
+			else if (rdata & WOW_UC_BIT)
+				context->type = PATTERN_UNICAST;
+			else
+				context->type = PATTERN_INVALID;
+
+			context->crc = rdata & 0xFFFF;
+			break;
+		default:
+			_rtw_memcpy(&context->mask[i], (u8 *)(&rdata), 4);
+			break;
+		}
+	}
+}
+
+static void _rtw_wow_pattern_write_cam(_adapter *adapter, u8 addr, u32 wdata)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	_mutex *mutex = &pwrpriv->wowlan_pattern_cam_mutex;
+	u32 cnt = 0;
+	systime start = 0, end = 0;
+	u8 timeout = 0;
+
+	/*RTW_INFO("%s ==> addr:0x%02x , wdata:0x%08x\n", __func__, addr, wdata);*/
+	_enter_critical_mutex(mutex, NULL);
+
+	rtw_write32(adapter, REG_WKFMCAM_RWD, wdata);
+	rtw_write32(adapter, REG_WKFMCAM_CMD, BIT_WKFCAM_POLLING_V1 | BIT_WKFCAM_WE | BIT_WKFCAM_ADDR_V2(addr));
+
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(adapter))
+			break;
+
+		cnt++;
+		if (0 == (rtw_read32(adapter, REG_WKFMCAM_CMD) & BIT_WKFCAM_POLLING_V1))
+			break;
+
+		if (rtw_get_passing_time_ms(start) > WOW_CAM_ACCESS_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+	end = rtw_get_current_time();
+
+	_exit_critical_mutex(mutex, NULL);
+
+	if (timeout) {
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%02x, wdata:0x%08x, to:%u, polling:%u, %d ms\n"
+			, FUNC_ADPT_ARG(adapter), addr, wdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
 	}
+}
 
-	/* To get the wake up pattern from the mask.
-	 * We do not count first 12 bits which means
-	 * DA[6] and SA[6] in the pattern to match HW design. */
-	count = 0;
-	for (i = 12; i < len; i++) {
-		if ((mask[i / 8] >> (i % 8)) & 0x01) {
-			content[count] = pattern[i];
-			count++;
+void rtw_wow_pattern_write_cam_ent(_adapter *adapter, u8 id, struct  rtl_wow_pattern *context)
+{
+	int j;
+	u8 addr;
+	u32 wdata = 0;
+
+	for (j = 4; j >= 0; j--) {
+		switch (j) {
+		case 4:
+			wdata = context->crc;
+
+			if (PATTERN_BROADCAST == context->type)
+				wdata |= WOW_BC_BIT;
+			if (PATTERN_MULTICAST == context->type)
+				wdata |= WOW_MC_BIT;
+			if (PATTERN_UNICAST == context->type)
+				wdata |= WOW_UC_BIT;
+			if (PATTERN_INVALID != context->type)
+				wdata |= WOW_VALID_BIT;
+			break;
+		default:
+			wdata = context->mask[j];
+			break;
 		}
-	}
 
-	wow_pattern.crc = rtw_calc_crc(content, count);
+		addr = (id << 3) + j;
 
-	if (wow_pattern.crc != 0) {
-		if (wow_pattern.type == PATTERN_INVALID)
-			wow_pattern.type = PATTERN_VALID;
+		_rtw_wow_pattern_write_cam(adapter, addr, wdata);
 	}
+}
 
-	index = rtw_read8(adapter, REG_WKFMCAM_NUM);
+static u8 _rtw_wow_pattern_clean_cam(_adapter *adapter)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	_mutex *mutex = &pwrpriv->wowlan_pattern_cam_mutex;
+	u32 cnt = 0;
+	systime start = 0;
+	u8 timeout = 0;
+	u8 rst = _FAIL;
 
-	if (!pwrctl->bInSuspend)
-		index += 2;
+	_enter_critical_mutex(mutex, NULL);
+	rtw_write32(adapter, REG_WKFMCAM_CMD, BIT_WKFCAM_POLLING_V1 | BIT_WKFCAM_CLR_V1);
 
-	/* write pattern */
-	res = rtw_write_to_frame_mask(adapter, index, &wow_pattern);
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(adapter))
+			break;
 
-	if (res == _TRUE) {
-		pwrctl->wowlan_pattern_idx++;
-		rtw_write8(adapter,
-			   REG_WKFMCAM_NUM,
-			   pwrctl->wowlan_pattern_idx);
-	} else {
-		DBG_871X("%s: ERROR write_to_frame_mask_cam fail\n", __func__);
+		cnt++;
+		if (0 == (rtw_read32(adapter, REG_WKFMCAM_CMD) & BIT_WKFCAM_POLLING_V1)) {
+			rst = _SUCCESS;
+			break;
+		}
+		if (rtw_get_passing_time_ms(start) > WOW_CAM_ACCESS_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
 	}
+	_exit_critical_mutex(mutex, NULL);
 
-	return res;
+	if (timeout)
+		RTW_ERR(FUNC_ADPT_FMT" falied ,polling timeout\n", FUNC_ADPT_ARG(adapter));
+
+	return rst;
 }
 
-static void rtw_hal_dl_pattern(_adapter *adapter, u8 clean_all)
+void rtw_clean_pattern(_adapter *adapter)
+{
+	if (_FAIL == _rtw_wow_pattern_clean_cam(adapter))
+		RTW_ERR("rtw_clean_pattern failed\n");
+}
+
+void rtw_dump_wow_pattern(void *sel, struct rtl_wow_pattern *pwow_pattern, u8 idx)
+{
+	int j;
+
+	RTW_PRINT_SEL(sel, "=======WOW CAM-ID[%d]=======\n", idx);
+	RTW_PRINT_SEL(sel, "[WOW CAM] type:%d\n", pwow_pattern->type);
+	RTW_PRINT_SEL(sel, "[WOW CAM] crc:0x%04x\n", pwow_pattern->crc);
+	for (j = 0; j < 4; j++)
+		RTW_PRINT_SEL(sel, "[WOW CAM] Mask:0x%08x\n", pwow_pattern->mask[j]);
+}
+
+void rtw_fill_pattern(_adapter *adapter)
 {
-	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
 	int i = 0, total = 0;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct rtl_wow_pattern wow_pattern;
 
 	total = pwrpriv->wowlan_pattern_idx;
 
-	rtw_clean_pattern(adapter);
+	if (total > MAX_WKFM_CAM_NUM)
+		total = MAX_WKFM_CAM_NUM;
 
-	if (!clean_all) {
-		for (i = 0 ; i < total ; i++) {
-			rtw_hal_set_pattern(adapter,
-					pwrpriv->patterns[i].content,
-					pwrpriv->patterns[i].len,
-					pwrpriv->patterns[i].mask);
+	for (i = 0 ; i < total ; i++) {
+		if (_SUCCESS == rtw_hal_wow_pattern_generate(adapter, i, &wow_pattern)) {
+			rtw_dump_wow_pattern(RTW_DBGDUMP, &wow_pattern, i);
+			rtw_wow_pattern_write_cam_ent(adapter, i, &wow_pattern);
 		}
-		DBG_871X("pattern downloaded\n");
-	} else {
-		for (i = 0 ; i < MAX_WKFM_NUM ; i++) {
-			_rtw_memset(pwrpriv->patterns[i].content, '\0',
-					sizeof(pwrpriv->patterns[i].content));
-			_rtw_memset(pwrpriv->patterns[i].mask, '\0',
-					sizeof(pwrpriv->patterns[i].mask));
-			pwrpriv->patterns[i].len = 0;
-		}
-		DBG_871X("clean all pattern\n");
+	}
+}
+
+#endif
+void rtw_wow_pattern_cam_dump(_adapter *adapter)
+{
+
+#ifndef CONFIG_WOW_PATTERN_HW_CAM
+	int i;
+
+	for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++) {
+		RTW_INFO("=======[%d]=======\n", i);
+		rtw_read_from_frame_mask(adapter, i);
+	}
+#else
+	struct  rtl_wow_pattern context;
+	int i;
+
+	for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++) {
+		rtw_wow_pattern_read_cam_ent(adapter, i, &context);
+		rtw_dump_wow_pattern(RTW_DBGDUMP, &context, i);
+	}
+
+#endif
+}
+
+
+static void rtw_hal_dl_pattern(_adapter *adapter, u8 mode)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+
+	switch (mode) {
+	case 0:
+		rtw_clean_pattern(adapter);
+		RTW_INFO("%s: total patterns: %d\n", __func__, pwrpriv->wowlan_pattern_idx);
+		break;
+	case 1:
+		rtw_set_default_pattern(adapter);
+		rtw_fill_pattern(adapter);
+		RTW_INFO("%s: pattern total: %d downloaded\n", __func__, pwrpriv->wowlan_pattern_idx);
+		break;
+	case 2:
+		rtw_clean_pattern(adapter);
+		rtw_wow_pattern_sw_reset(adapter);
+		RTW_INFO("%s: clean patterns\n", __func__);
+		break;
+	default:
+		RTW_INFO("%s: unknown mode\n", __func__);
+		break;
 	}
 }
 
@@ -5695,126 +8749,193 @@ static void rtw_hal_wow_enable(_adapter *adapter)
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 	struct security_priv *psecuritypriv = &adapter->securitypriv;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	struct sta_info *psta = NULL;
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
 	int res;
 	u16 media_status_rpt;
-	
 
-	DBG_871X_LEVEL(_drv_always_, "%s, WOWLAN_ENABLE\n", __func__);
+
+	RTW_PRINT("%s, WOWLAN_ENABLE\n", __func__);
 	rtw_hal_gate_bb(adapter, _TRUE);
 #ifdef CONFIG_GTK_OL
-	if (psecuritypriv->dot11PrivacyAlgrthm == _AES_)
+	if (psecuritypriv->binstallKCK_KEK == _TRUE)
 		rtw_hal_fw_sync_cam_id(adapter);
 #endif
 	if (IS_HARDWARE_TYPE_8723B(adapter))
 		rtw_hal_backup_rate(adapter);
 
+	rtw_hal_fw_dl(adapter, _TRUE);
+	media_status_rpt = RT_MEDIA_CONNECT;
+	rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
+			  (u8 *)&media_status_rpt);
+
 	/* RX DMA stop */
+	#if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(adapter))
 		rtw_hal_disable_tx_report(adapter);
+	#endif
 
 	res = rtw_hal_pause_rx_dma(adapter);
 	if (res == _FAIL)
-		DBG_871X_LEVEL(_drv_always_, "[WARNING] pause RX DMA fail\n");
+		RTW_PRINT("[WARNING] pause RX DMA fail\n");
 
+	#ifndef CONFIG_WOW_PATTERN_HW_CAM
 	/* Reconfig RX_FF Boundary */
 	rtw_hal_set_wow_rxff_boundary(adapter, _TRUE);
+	#endif
 
-	/* redownload pattern match */
-	if (pwrctl->wowlan_pattern)
-		rtw_hal_dl_pattern(adapter, _FALSE);
+	/* redownload wow pattern */
+	rtw_hal_dl_pattern(adapter, 1);
 
-	rtw_hal_fw_dl(adapter, _TRUE);
-	media_status_rpt = RT_MEDIA_CONNECT;
-	rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
-		(u8 *)&media_status_rpt);
-		
 	if (!pwrctl->wowlan_pno_enable) {
 		psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
-		if (psta != NULL)
+
+		if (psta != NULL) {
+			#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+			rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
+			#endif
+
 			rtw_sta_media_status_rpt(adapter, psta, 1);
+		}
 	}
-		
+
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 	/* Enable CPWM2 only. */
 	res = rtw_hal_enable_cpwm2(adapter);
 	if (res == _FAIL)
-		DBG_871X_LEVEL(_drv_always_, "[WARNING] enable cpwm2 fail\n");
+		RTW_PRINT("[WARNING] enable cpwm2 fail\n");
 #endif
 #ifdef CONFIG_GPIO_WAKEUP
 	rtw_hal_switch_gpio_wl_ctrl(adapter, WAKEUP_GPIO_IDX, _TRUE);
 #endif
 	/* Set WOWLAN H2C command. */
-	DBG_871X_LEVEL(_drv_always_, "Set WOWLan cmd\n");
+	RTW_PRINT("Set WOWLan cmd\n");
 	rtw_hal_set_fw_wow_related_cmd(adapter, 1);
-		
+
 	res = rtw_hal_check_wow_ctrl(adapter, _TRUE);
 
 	if (res == _FALSE)
-		DBG_871X("[Error]%s: set wowlan CMD fail!!\n", __func__);
+		RTW_INFO("[Error]%s: set wowlan CMD fail!!\n", __func__);
 
 	pwrctl->wowlan_wake_reason =
 		rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
 
-	DBG_871X_LEVEL(_drv_always_, "wowlan_wake_reason: 0x%02x\n",
-				pwrctl->wowlan_wake_reason);
+	RTW_PRINT("wowlan_wake_reason: 0x%02x\n",
+		  pwrctl->wowlan_wake_reason);
 #ifdef CONFIG_GTK_OL_DBG
 	dump_sec_cam(RTW_DBGDUMP, adapter);
+	dump_sec_cam_cache(RTW_DBGDUMP, adapter);
 #endif
 #ifdef CONFIG_USB_HCI
-	if (adapter->intf_stop)	    /* free adapter's resource */
-		adapter->intf_stop(adapter);
+	/* free adapter's resource */
+	rtw_mi_intf_stop(adapter);
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(adapter)) /*free buddy adapter's resource*/
-		adapter->pbuddy_adapter->intf_stop(adapter->pbuddy_adapter);
-#endif /*CONFIG_CONCURRENT_MODE*/
+#endif
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
 	/* Invoid SE0 reset signal during suspending*/
 	rtw_write8(adapter, REG_RSV_CTRL, 0x20);
-	rtw_write8(adapter, REG_RSV_CTRL, 0x60);
-#endif /*CONFIG_USB_HCI*/
+	if (IS_8188F(pHalData->version_id) == FALSE
+		&& IS_8188GTV(pHalData->version_id) == FALSE)
+		rtw_write8(adapter, REG_RSV_CTRL, 0x60);
+#endif
 
 	rtw_hal_gate_bb(adapter, _FALSE);
 }
 
+#define DBG_WAKEUP_REASON
+#ifdef DBG_WAKEUP_REASON
+void _dbg_wake_up_reason_string(_adapter *adapter, const char *srt_res)
+{
+	RTW_INFO(ADPT_FMT "- wake up reason - %s\n", ADPT_ARG(adapter), srt_res);
+}
+void _dbg_rtw_wake_up_reason(_adapter *adapter, u8 reason)
+{
+	if (RX_PAIRWISEKEY == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx pairwise key");
+	else if (RX_GTK == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx GTK");
+	else if (RX_FOURWAY_HANDSHAKE == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx four way handshake");
+	else if (RX_DISASSOC == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx disassoc");
+	else if (RX_DEAUTH == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx deauth");
+	else if (RX_ARP_REQUEST == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx ARP request");
+	else if (FW_DECISION_DISCONNECT == reason)
+		_dbg_wake_up_reason_string(adapter, "FW detect disconnect");
+	else if (RX_MAGIC_PKT == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx magic packet");
+	else if (RX_UNICAST_PKT == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx unicast packet");
+	else if (RX_PATTERN_PKT == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx pattern packet");
+	else if (RTD3_SSID_MATCH == reason)
+		_dbg_wake_up_reason_string(adapter, "RTD3 SSID match");
+	else if (RX_REALWOW_V2_WAKEUP_PKT == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx real WOW V2 wakeup packet");
+	else if (RX_REALWOW_V2_ACK_LOST == reason)
+		_dbg_wake_up_reason_string(adapter, "Rx real WOW V2 ack lost");
+	else if (ENABLE_FAIL_DMA_IDLE == reason)
+		_dbg_wake_up_reason_string(adapter, "enable fail DMA idle");
+	else if (ENABLE_FAIL_DMA_PAUSE == reason)
+		_dbg_wake_up_reason_string(adapter, "enable fail DMA pause");
+	else if (AP_OFFLOAD_WAKEUP == reason)
+		_dbg_wake_up_reason_string(adapter, "AP offload wakeup");
+	else if (CLK_32K_UNLOCK == reason)
+		_dbg_wake_up_reason_string(adapter, "clk 32k unlock");
+	else if (RTIME_FAIL_DMA_IDLE == reason)
+		_dbg_wake_up_reason_string(adapter, "RTIME fail DMA idle");
+	else if (CLK_32K_LOCK == reason)
+		_dbg_wake_up_reason_string(adapter, "clk 32k lock");
+	else
+		_dbg_wake_up_reason_string(adapter, "unknown reasoen");
+}
+#endif
+
 static void rtw_hal_wow_disable(_adapter *adapter)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 	struct security_priv *psecuritypriv = &adapter->securitypriv;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	struct sta_info *psta = NULL;
 	int res;
 	u16 media_status_rpt;
 	u8 val8;
 
-	DBG_871X_LEVEL(_drv_always_, "%s, WOWLAN_DISABLE\n", __func__);
+	RTW_PRINT("%s, WOWLAN_DISABLE\n", __func__);
 
 	if (!pwrctl->wowlan_pno_enable) {
 		psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
 		if (psta != NULL)
 			rtw_sta_media_status_rpt(adapter, psta, 0);
 		else
-			DBG_871X("%s: psta is null\n", __func__);
+			RTW_INFO("%s: psta is null\n", __func__);
 	}
-		
+
 	if (0) {
-		DBG_871X("0x630:0x%02x\n", rtw_read8(adapter, 0x630));
-		DBG_871X("0x631:0x%02x\n", rtw_read8(adapter, 0x631));
+		RTW_INFO("0x630:0x%02x\n", rtw_read8(adapter, 0x630));
+		RTW_INFO("0x631:0x%02x\n", rtw_read8(adapter, 0x631));
+		RTW_INFO("0x634:0x%02x\n", rtw_read8(adapter, 0x634));
+		RTW_INFO("0x1c7:0x%02x\n", rtw_read8(adapter, 0x1c7));
 	}
 
 	pwrctl->wowlan_wake_reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
 
-	DBG_871X_LEVEL(_drv_always_, "wakeup_reason: 0x%02x\n",
-		pwrctl->wowlan_wake_reason);
+	RTW_PRINT("wakeup_reason: 0x%02x\n",
+		  pwrctl->wowlan_wake_reason);
+	#ifdef DBG_WAKEUP_REASON
+	_dbg_rtw_wake_up_reason(adapter, pwrctl->wowlan_wake_reason);
+	#endif
 
 	rtw_hal_set_fw_wow_related_cmd(adapter, 0);
 
 	res = rtw_hal_check_wow_ctrl(adapter, _FALSE);
 
 	if (res == _FALSE) {
-		DBG_871X("[Error]%s: disable WOW cmd fail\n!!", __func__);
+		RTW_INFO("[Error]%s: disable WOW cmd fail\n!!", __func__);
 		rtw_hal_force_enable_rxdma(adapter);
 	}
 
@@ -5822,55 +8943,71 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 
 	res = rtw_hal_pause_rx_dma(adapter);
 	if (res == _FAIL)
-		DBG_871X_LEVEL(_drv_always_, "[WARNING] pause RX DMA fail\n");
+		RTW_PRINT("[WARNING] pause RX DMA fail\n");
 
-	/* clean pattern match */
-	if (pwrctl->wowlan_pattern)
-		rtw_hal_dl_pattern(adapter, _TRUE);
+	/* clean HW pattern match */
+	rtw_hal_dl_pattern(adapter, 0);
 
+	#ifndef CONFIG_WOW_PATTERN_HW_CAM
 	/* config RXFF boundary to original */
 	rtw_hal_set_wow_rxff_boundary(adapter, _FALSE);
-
+	#endif
 	rtw_hal_release_rx_dma(adapter);
 
+	#if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(adapter))
 		rtw_hal_enable_tx_report(adapter);
-		
-	rtw_hal_update_tx_iv(adapter);
+	#endif
 
-#ifdef CONFIG_GTK_OL
-	if (psecuritypriv->dot11PrivacyAlgrthm == _AES_)
-		rtw_hal_update_gtk_offload_info(adapter);
-#endif /*CONFIG_GTK_OL*/
+	if ((pwrctl->wowlan_wake_reason != RX_DISASSOC) ||
+		(pwrctl->wowlan_wake_reason != RX_DEAUTH) ||
+		(pwrctl->wowlan_wake_reason != FW_DECISION_DISCONNECT)) {
+		rtw_hal_get_aoac_rpt(adapter);
+		rtw_hal_update_sw_security_info(adapter);
+	}
 
 	rtw_hal_fw_dl(adapter, _FALSE);
 
 #ifdef CONFIG_GPIO_WAKEUP
+
+#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
+	if (pwrctl->is_high_active == 0)
+		rtw_hal_set_input_gpio(adapter, WAKEUP_GPIO_IDX);
+	else
+		rtw_hal_set_output_gpio(adapter, WAKEUP_GPIO_IDX, 0);
+#else
 	val8 = (pwrctl->is_high_active == 0) ? 1 : 0;
-	DBG_871X_LEVEL(_drv_always_, "Set Wake GPIO to default(%d).\n", val8);
+	RTW_PRINT("Set Wake GPIO to default(%d).\n", val8);
+
 	rtw_hal_set_output_gpio(adapter, WAKEUP_GPIO_IDX, val8);
+	rtw_hal_switch_gpio_wl_ctrl(adapter, WAKEUP_GPIO_IDX, _FALSE);
 #endif
 
-	if ((pwrctl->wowlan_wake_reason != FWDecisionDisconnect) &&
-		(pwrctl->wowlan_wake_reason != Rx_Pairwisekey) &&
-		(pwrctl->wowlan_wake_reason != Rx_DisAssoc) &&
-		(pwrctl->wowlan_wake_reason != Rx_DeAuth)) {
+#endif
+	if ((pwrctl->wowlan_wake_reason != FW_DECISION_DISCONNECT) &&
+	    (pwrctl->wowlan_wake_reason != RX_PAIRWISEKEY) &&
+	    (pwrctl->wowlan_wake_reason != RX_DISASSOC) &&
+	    (pwrctl->wowlan_wake_reason != RX_DEAUTH)) {
 
 		media_status_rpt = RT_MEDIA_CONNECT;
 		rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
-			(u8 *)&media_status_rpt);
+				  (u8 *)&media_status_rpt);
 
-		if (psta != NULL)
+		if (psta != NULL) {
+			#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+			rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
+			#endif
 			rtw_sta_media_status_rpt(adapter, psta, 1);
+		}
 	}
 	rtw_hal_gate_bb(adapter, _FALSE);
 }
 #endif /*CONFIG_WOWLAN*/
 
 #ifdef CONFIG_P2P_WOWLAN
-void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter* adapter, u8 *pframe, u16 index,
-		u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
-		RSVDPAGE_LOC* rsvd_page_loc)
+void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
+	      u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
+				      RSVDPAGE_LOC *rsvd_page_loc)
 {
 	u32 P2PNegoRspLength = 0, P2PInviteRspLength = 0;
 	u32 P2PPDRspLength = 0, P2PProbeRspLength = 0, P2PBCNLength = 0;
@@ -5879,12 +9016,12 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter* adapter, u8 *pframe, u16 index,
 	/* P2P Beacon */
 	rsvd_page_loc->LocP2PBeacon = *page_num;
 	rtw_hal_construct_P2PBeacon(adapter, &pframe[index], &P2PBCNLength);
-	rtw_hal_fill_fake_txdesc(adapter, &pframe[index-tx_desc],
-			P2PBCNLength, _FALSE, _FALSE, _FALSE);
+	rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
+				 P2PBCNLength, _FALSE, _FALSE, _FALSE);
 
 #if 0
-	DBG_871X("%s(): HW_VAR_SET_TX_CMD: PROBE RSP %p %d\n", 
-		__FUNCTION__, &pframe[index-tx_desc], (P2PBCNLength+tx_desc));
+	RTW_INFO("%s(): HW_VAR_SET_TX_CMD: PROBE RSP %p %d\n",
+		__FUNCTION__, &pframe[index - tx_desc], (P2PBCNLength + tx_desc));
 #endif
 
 	CurtPktPageNum = (u8)PageNum(tx_desc + P2PBCNLength, page_size);
@@ -5892,77 +9029,318 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter* adapter, u8 *pframe, u16 index,
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-Beacon", CurtPktPageNum, *page_num, 0);
+	#endif
 
-	// P2P Probe rsp
+	/* P2P Probe rsp */
 	rsvd_page_loc->LocP2PProbeRsp = *page_num;
 	rtw_hal_construct_P2PProbeRsp(adapter, &pframe[index],
-			&P2PProbeRspLength);
-	rtw_hal_fill_fake_txdesc(adapter, &pframe[index-tx_desc],
-			P2PProbeRspLength, _FALSE, _FALSE, _FALSE);
+				      &P2PProbeRspLength);
+	rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
+				 P2PProbeRspLength, _FALSE, _FALSE, _FALSE);
 
-	//DBG_871X("%s(): HW_VAR_SET_TX_CMD: PROBE RSP %p %d\n", 
-	//	__FUNCTION__, &pframe[index-tx_desc], (P2PProbeRspLength+tx_desc));
+	/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: PROBE RSP %p %d\n",  */
+	/*	__FUNCTION__, &pframe[index-tx_desc], (P2PProbeRspLength+tx_desc)); */
 
 	CurtPktPageNum = (u8)PageNum(tx_desc + P2PProbeRspLength, page_size);
 
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-ProbeRsp", CurtPktPageNum, *page_num, 0);
+	#endif
 
-	//P2P nego rsp
+	/* P2P nego rsp */
 	rsvd_page_loc->LocNegoRsp = *page_num;
 	rtw_hal_construct_P2PNegoRsp(adapter, &pframe[index],
-			&P2PNegoRspLength);
-	rtw_hal_fill_fake_txdesc(adapter, &pframe[index-tx_desc],
-			P2PNegoRspLength, _FALSE, _FALSE, _FALSE);
+				     &P2PNegoRspLength);
+	rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
+				 P2PNegoRspLength, _FALSE, _FALSE, _FALSE);
 
-	//DBG_871X("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n", 
-	//	__FUNCTION__, &pframe[index-tx_desc], (NegoRspLength+tx_desc));
+	/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n",  */
+	/*	__FUNCTION__, &pframe[index-tx_desc], (NegoRspLength+tx_desc)); */
 
 	CurtPktPageNum = (u8)PageNum(tx_desc + P2PNegoRspLength, page_size);
 
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
-		
-	//P2P invite rsp
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-NegoRsp", CurtPktPageNum, *page_num, 0);
+	#endif
+
+	/* P2P invite rsp */
 	rsvd_page_loc->LocInviteRsp = *page_num;
 	rtw_hal_construct_P2PInviteRsp(adapter, &pframe[index],
-			&P2PInviteRspLength);
-	rtw_hal_fill_fake_txdesc(adapter, &pframe[index-tx_desc],
-			P2PInviteRspLength, _FALSE, _FALSE, _FALSE);
+				       &P2PInviteRspLength);
+	rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
+				 P2PInviteRspLength, _FALSE, _FALSE, _FALSE);
 
-	//DBG_871X("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n", 
-	//__FUNCTION__, &pframe[index-tx_desc], (InviteRspLength+tx_desc));
+	/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n",  */
+	/* __FUNCTION__, &pframe[index-tx_desc], (InviteRspLength+tx_desc)); */
 
 	CurtPktPageNum = (u8)PageNum(tx_desc + P2PInviteRspLength, page_size);
 
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
-	
-	//P2P provision discovery rsp
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-InviteRsp", CurtPktPageNum, *page_num, 0);
+	#endif
+
+	/* P2P provision discovery rsp */
 	rsvd_page_loc->LocPDRsp = *page_num;
-	rtw_hal_construct_P2PProvisionDisRsp( adapter,
-			&pframe[index], &P2PPDRspLength);
+	rtw_hal_construct_P2PProvisionDisRsp(adapter,
+					     &pframe[index], &P2PPDRspLength);
 
-	rtw_hal_fill_fake_txdesc(adapter, &pframe[index-tx_desc],
-			P2PPDRspLength, _FALSE, _FALSE, _FALSE);
+	rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
+				 P2PPDRspLength, _FALSE, _FALSE, _FALSE);
 
-	//DBG_871X("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n", 
-	//	__FUNCTION__, &pframe[index-tx_desc], (PDRspLength+tx_desc));
+	/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n",  */
+	/*	__FUNCTION__, &pframe[index-tx_desc], (PDRspLength+tx_desc)); */
 
 	CurtPktPageNum = (u8)PageNum(tx_desc + P2PPDRspLength, page_size);
 
-       *page_num += CurtPktPageNum;
+	*page_num += CurtPktPageNum;
 
 	*total_pkt_len = index + P2PPDRspLength;
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-PDR", CurtPktPageNum, *page_num, *total_pkt_len);
+	#endif
 
 	index += (CurtPktPageNum * page_size);
 
 
 }
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
+
+#ifdef CONFIG_LPS_PG
+#include "hal_halmac.h"
+
+#define DBG_LPSPG_SEC_DUMP
+#define LPS_PG_INFO_RSVD_LEN	16
+#define LPS_PG_INFO_RSVD_PAGE_NUM	1
+
+#define DBG_LPSPG_INFO_DUMP
+static void rtw_hal_set_lps_pg_info_rsvd_page(_adapter *adapter)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct sta_info	*psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(&adapter->mlmepriv));
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	PHAL_DATA_TYPE phal_data = GET_HAL_DATA(adapter);
+	u8 lps_pg_info[LPS_PG_INFO_RSVD_LEN] = {0};
+#ifdef CONFIG_MBSSID_CAM
+	u8 cam_id = INVALID_CAM_ID;
+#endif
+	u8 *psec_cam_id = lps_pg_info + 8;
+	u8 sec_cam_num = 0;
+	u8 drv_rsvdpage_num = 0;
+
+	if (!psta) {
+		RTW_ERR("%s [ERROR] sta is NULL\n", __func__);
+		rtw_warn_on(1);
+		return;
+	}
+
+	/*Byte 0 - used macid*/
+	LPSPG_RSVD_PAGE_SET_MACID(lps_pg_info, psta->cmn.mac_id);
+	RTW_INFO("[LPSPG-INFO] mac_id:%d\n", psta->cmn.mac_id);
+
+#ifdef CONFIG_MBSSID_CAM
+	/*Byte 1 - used BSSID CAM entry*/
+	cam_id = rtw_mbid_cam_search_by_ifaceid(adapter, adapter->iface_id);
+	if (cam_id != INVALID_CAM_ID)
+		LPSPG_RSVD_PAGE_SET_MBSSCAMID(lps_pg_info, cam_id);
+	RTW_INFO("[LPSPG-INFO] mbss_cam_id:%d\n", cam_id);
+#endif
+
+#ifdef CONFIG_WOWLAN /*&& pattern match cam used*/
+	/*Btye 2 - Max used Pattern Match CAM entry*/
+	if (pwrpriv->wowlan_mode == _TRUE &&
+	    check_fwstate(&adapter->mlmepriv, _FW_LINKED) == _TRUE) {
+		LPSPG_RSVD_PAGE_SET_PMC_NUM(lps_pg_info, pwrpriv->wowlan_pattern_idx);
+		RTW_INFO("[LPSPG-INFO] Max Pattern Match CAM entry :%d\n", pwrpriv->wowlan_pattern_idx);
+	}
+#endif
+#ifdef CONFIG_BEAMFORMING  /*&& MU BF*/
+	/*Btye 3 - Max MU rate table Group ID*/
+	LPSPG_RSVD_PAGE_SET_MU_RAID_GID(lps_pg_info, 0);
+	RTW_INFO("[LPSPG-INFO] Max MU rate table Group ID :%d\n", 0);
+#endif
+
+	/*Btye 8 ~15 - used Security CAM entry */
+	sec_cam_num = rtw_get_sec_camid(adapter, 8, psec_cam_id);
+
+	/*Btye 4 - used Security CAM entry number*/
+	if (sec_cam_num < 8)
+		LPSPG_RSVD_PAGE_SET_SEC_CAM_NUM(lps_pg_info, sec_cam_num);
+	RTW_INFO("[LPSPG-INFO] Security CAM entry number :%d\n", sec_cam_num);
+
+	/*Btye 5 - Txbuf used page number for fw offload*/
+	if (pwrpriv->wowlan_mode == _TRUE || pwrpriv->wowlan_ap_mode == _TRUE)
+		drv_rsvdpage_num = rtw_hal_get_txbuff_rsvd_page_num(adapter, _TRUE);
+	else
+		drv_rsvdpage_num = rtw_hal_get_txbuff_rsvd_page_num(adapter, _FALSE);
+	LPSPG_RSVD_PAGE_SET_DRV_RSVDPAGE_NUM(lps_pg_info, drv_rsvdpage_num);
+	RTW_INFO("[LPSPG-INFO] DRV's rsvd page numbers :%d\n", drv_rsvdpage_num);
+
+#ifdef DBG_LPSPG_SEC_DUMP
+	{
+		int i;
+
+		for (i = 0; i < sec_cam_num; i++)
+			RTW_INFO("%d = sec_cam_id:%d\n", i, psec_cam_id[i]);
+	}
+#endif
+
+#ifdef DBG_LPSPG_INFO_DUMP
+	RTW_INFO("==== DBG_LPSPG_INFO_RSVD_PAGE_DUMP====\n");
+	RTW_INFO("  %02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X\n",
+		*(lps_pg_info), *(lps_pg_info + 1), *(lps_pg_info + 2), *(lps_pg_info + 3),
+		*(lps_pg_info + 4), *(lps_pg_info + 5), *(lps_pg_info + 6), *(lps_pg_info + 7));
+	RTW_INFO("  %02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X\n",
+		*(lps_pg_info + 8), *(lps_pg_info + 9), *(lps_pg_info + 10), *(lps_pg_info + 11),
+		*(lps_pg_info + 12), *(lps_pg_info + 13), *(lps_pg_info + 14), *(lps_pg_info + 15));
+	RTW_INFO("==== DBG_LPSPG_INFO_RSVD_PAGE_DUMP====\n");
+#endif
+
+	rtw_halmac_download_rsvd_page(dvobj, pwrpriv->lpspg_rsvd_page_locate, lps_pg_info, LPS_PG_INFO_RSVD_LEN);
+
+#ifdef DBG_LPSPG_INFO_DUMP
+	RTW_INFO("Get LPS-PG INFO from rsvd page_offset:%d\n", pwrpriv->lpspg_rsvd_page_locate);
+	rtw_dump_rsvd_page(RTW_DBGDUMP, adapter, pwrpriv->lpspg_rsvd_page_locate, 1);
+#endif
+}
+
+
+static u8 rtw_hal_set_lps_pg_info_cmd(_adapter *adapter)
+{
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+
+	u8 lpspg_info[H2C_LPS_PG_INFO_LEN] = {0};
+	u8 ret = _FAIL;
+
+	RTW_INFO("%s: loc_lpspg_info:%d\n", __func__, pwrpriv->lpspg_rsvd_page_locate);
+
+	if (_NO_PRIVACY_ != adapter->securitypriv.dot11PrivacyAlgrthm)
+		SET_H2CCMD_LPSPG_SEC_CAM_EN(lpspg_info, 1);	/*SecurityCAM_En*/
+#ifdef CONFIG_MBSSID_CAM
+	SET_H2CCMD_LPSPG_MBID_CAM_EN(lpspg_info, 1);		/*BSSIDCAM_En*/
+#endif
+
+#if defined(CONFIG_WOWLAN) && defined(CONFIG_WOW_PATTERN_HW_CAM)
+	if (pwrpriv->wowlan_mode == _TRUE &&
+	    check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+
+		SET_H2CCMD_LPSPG_PMC_CAM_EN(lpspg_info, 1);	/*PatternMatchCAM_En*/
+	}
+#endif
+
+#ifdef CONFIG_MACID_SEARCH
+	SET_H2CCMD_LPSPG_MACID_SEARCH_EN(lpspg_info, 1);	/*MACIDSearch_En*/
+#endif
+
+#ifdef CONFIG_TX_SC
+	SET_H2CCMD_LPSPG_TXSC_EN(lpspg_info, 1);	/*TXSC_En*/
+#endif
+
+#ifdef CONFIG_BEAMFORMING  /*&& MU BF*/
+	SET_H2CCMD_LPSPG_MU_RATE_TB_EN(lpspg_info, 1);	/*MURateTable_En*/
+#endif
+
+	SET_H2CCMD_LPSPG_LOC(lpspg_info, pwrpriv->lpspg_rsvd_page_locate);
+
+#ifdef DBG_LPSPG_INFO_DUMP
+	RTW_INFO("==== DBG_LPSPG_INFO_CMD_DUMP====\n");
+	RTW_INFO("  H2C_CMD: 0x%02x, H2C_LEN: %d\n", H2C_LPS_PG_INFO, H2C_LPS_PG_INFO_LEN);
+	RTW_INFO("  %02X:%02X\n", *(lpspg_info), *(lpspg_info + 1));
+	RTW_INFO("==== DBG_LPSPG_INFO_CMD_DUMP====\n");
+#endif
+
+	ret = rtw_hal_fill_h2c_cmd(adapter,
+				   H2C_LPS_PG_INFO,
+				   H2C_LPS_PG_INFO_LEN,
+				   lpspg_info);
+	return ret;
+}
+u8 rtw_hal_set_lps_pg_info(_adapter *adapter)
+{
+	u8 ret = _FAIL;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+
+	if (pwrpriv->lpspg_rsvd_page_locate == 0) {
+		RTW_ERR("%s [ERROR] lpspg_rsvd_page_locate = 0\n", __func__);
+		rtw_warn_on(1);
+		return ret;
+	}
+
+	rtw_hal_set_lps_pg_info_rsvd_page(adapter);
+	ret = rtw_hal_set_lps_pg_info_cmd(adapter);
+	if (_SUCCESS == ret)
+		pwrpriv->blpspg_info_up = _FALSE;
+
+	return ret;
+}
+
+void rtw_hal_lps_pg_rssi_lv_decide(_adapter *adapter, struct sta_info *sta)
+{
+#if 0
+	if (sta->cmn.ra_info.rssi_level >= 4)
+		sta->lps_pg_rssi_lv = 3;	/*RSSI High - 1SS_VHT_MCS7*/
+	else if (sta->cmn.ra_info.rssi_level >=  2)
+		sta->lps_pg_rssi_lv = 2;	/*RSSI Middle - 1SS_VHT_MCS3*/
+	else
+		sta->lps_pg_rssi_lv = 1;	/*RSSI Lower - Lowest_rate*/
+#else
+	sta->lps_pg_rssi_lv = 0;
+#endif
+	RTW_INFO("%s mac-id:%d, rssi:%d, rssi_level:%d, lps_pg_rssi_lv:%d\n",
+		__func__, sta->cmn.mac_id, sta->cmn.rssi_stat.rssi, sta->cmn.ra_info.rssi_level, sta->lps_pg_rssi_lv);
+}
+
+void rtw_hal_lps_pg_handler(_adapter *adapter, enum lps_pg_hdl_id hdl_id)
+{
+	switch (hdl_id) {
+	case LPS_PG_INFO_CFG:
+		rtw_hal_set_lps_pg_info(adapter);
+		break;
+	case LPS_PG_REDLEMEM:
+		{
+			/*set xmit_block*/
+			rtw_set_xmit_block(adapter, XMIT_BLOCK_REDLMEM);
+			if (_FAIL == rtw_hal_fw_mem_dl(adapter, FW_EMEM))
+				rtw_warn_on(1);
+			/*clearn xmit_block*/
+			rtw_clr_xmit_block(adapter, XMIT_BLOCK_REDLMEM);
+		}
+		break;
+
+	case LPS_PG_RESEND_H2C:
+		{
+			struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
+			struct sta_info *sta;
+			int i;
+
+			for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
+				sta = macid_ctl->sta[i];
+				if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr)) {
+					rtw_hal_lps_pg_rssi_lv_decide(adapter, sta);
+					set_sta_rate(adapter, sta);
+					sta->lps_pg_rssi_lv = 0;
+				}
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+}
+
+#endif /*CONFIG_LPS_PG*/
 
 /*
  * Description: Fill the reserved packets that FW will use to RSVD page.
@@ -5973,24 +9351,30 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter* adapter, u8 *pframe, u16 index,
  *		    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.
+ * page_num - The amount of reserved page which driver need.
+ *	      If this is not NULL, this function doesn't real download reserved
+ *	      page, but just count the number of reserved page.
+ *
  * 2009.10.15 by tynli.
+ * 2017.06.20 modified by Lucas.
  *
- * Page Size = 128: 8188e, 8723a/b, 8192c/d,  
+ * Page Size = 128: 8188e, 8723a/b, 8192c/d,
  * Page Size = 256: 8192e, 8821a
  * Page Size = 512: 8812a
  */
 
-void rtw_hal_set_fw_rsvd_page(_adapter* adapter, bool finished)
+/*#define DBG_DUMP_SET_RSVD_PAGE*/
+static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page_num)
 {
 	PHAL_DATA_TYPE pHalData;
-	struct xmit_frame	*pcmdframe;
+	struct xmit_frame	*pcmdframe = NULL;
 	struct pkt_attrib	*pattrib;
 	struct xmit_priv	*pxmitpriv;
 	struct mlme_ext_priv	*pmlmeext;
 	struct mlme_ext_info	*pmlmeinfo;
 	struct pwrctrl_priv *pwrctl;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct hal_ops *pHalFunc = &adapter->HalFunc;
+	struct hal_ops *pHalFunc = &adapter->hal_func;
 	u32	BeaconLength = 0, ProbeRspLength = 0, PSPollLength = 0;
 	u32	NullDataLength = 0, QosNullLength = 0, BTQosNullLength = 0;
 	u32	ProbeReqLength = 0, NullFunctionDataLength = 0;
@@ -6001,10 +9385,17 @@ void rtw_hal_set_fw_rsvd_page(_adapter* adapter, bool finished)
 	u32	TotalPacketLen = 0, MaxRsvdPageBufSize = 0, PageSize = 0;
 	RSVDPAGE_LOC	RsvdPageLoc;
 
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	u32	fw_dbg_msg_pkt_len = 0;
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
 #ifdef DBG_CONFIG_ERROR_DETECT
 	struct sreset_priv *psrtpriv;
 #endif /* DBG_CONFIG_ERROR_DETECT */
 
+#ifdef CONFIG_MCC_MODE
+	u8 dl_mcc_page = _FAIL;
+#endif /* CONFIG_MCC_MODE */
 
 	pHalData = GET_HAL_DATA(adapter);
 #ifdef DBG_CONFIG_ERROR_DETECT
@@ -6016,55 +9407,65 @@ void rtw_hal_set_fw_rsvd_page(_adapter* adapter, bool finished)
 	pwrctl = adapter_to_pwrctl(adapter);
 
 	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&PageSize);
-	
+
 	if (PageSize == 0) {
-		DBG_871X("[Error]: %s, PageSize is zero!!\n", __func__);
+		RTW_INFO("[Error]: %s, PageSize is zero!!\n", __func__);
 		return;
 	}
 
-	if (pwrctl->wowlan_mode == _TRUE || pwrctl->wowlan_ap_mode == _TRUE)
-		RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _TRUE);
-	else
-		RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _FALSE);
-	
-	DBG_871X("%s PageSize: %d, RsvdPageNUm: %d\n",__func__, PageSize, RsvdPageNum);
-	
-	MaxRsvdPageBufSize = RsvdPageNum*PageSize;
+	/* Prepare ReservedPagePacket */
+	if (page_num) {
+		ReservedPagePacket = rtw_zmalloc(MAX_CMDBUF_SZ);
+		if (!ReservedPagePacket) {
+			RTW_WARN("%s: alloc ReservedPagePacket fail!\n", __FUNCTION__);
+			*page_num = 0xFF;
+			return;
+		}
+	} else {
+		if (pwrctl->wowlan_mode == _TRUE || pwrctl->wowlan_ap_mode == _TRUE)
+			RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _TRUE);
+		else
+			RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _FALSE);
 
-	if (MaxRsvdPageBufSize > MAX_CMDBUF_SZ) {
-		DBG_871X("%s MaxRsvdPageBufSize(%d) is larger than MAX_CMDBUF_SZ(%d)",
-			__func__, MaxRsvdPageBufSize, MAX_CMDBUF_SZ);
-		rtw_warn_on(1);
-		return;
-	}
-	
-	pcmdframe = rtw_alloc_cmdxmitframe(pxmitpriv);
-	
-	if (pcmdframe == NULL) {
-		DBG_871X("%s: alloc ReservedPagePacket fail!\n", __FUNCTION__);
-		return;
+		RTW_INFO("%s PageSize: %d, RsvdPageNUm: %d\n", __func__, PageSize, RsvdPageNum);
+
+		MaxRsvdPageBufSize = RsvdPageNum * PageSize;
+		if (MaxRsvdPageBufSize > MAX_CMDBUF_SZ) {
+			RTW_ERR("%s MaxRsvdPageBufSize(%d) is larger than MAX_CMDBUF_SZ(%d)",
+				 __func__, MaxRsvdPageBufSize, MAX_CMDBUF_SZ);
+			rtw_warn_on(1);
+			return;
+		}
+
+		pcmdframe = rtw_alloc_cmdxmitframe(pxmitpriv);
+		if (pcmdframe == NULL) {
+			RTW_ERR("%s: alloc ReservedPagePacket fail!\n", __FUNCTION__);
+			return;
+		}
+
+		ReservedPagePacket = pcmdframe->buf_addr;
 	}
 
-	ReservedPagePacket = pcmdframe->buf_addr;
 	_rtw_memset(&RsvdPageLoc, 0, sizeof(RSVDPAGE_LOC));
 
-	/* beacon * 2 pages */
+	/* beacon * 1 pages */
 	BufIndex = TxDescOffset;
 	rtw_hal_construct_beacon(adapter,
-			&ReservedPagePacket[BufIndex], &BeaconLength);
+				 &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.
 	*/
 	CurtPktPageNum = (u8)PageNum((TxDescLen + BeaconLength), PageSize);
-	/* If we don't add 1 more page, ARP offload function will fail at 8723bs.*/
-	if (CurtPktPageNum == 1) 
-		CurtPktPageNum += 1;
 
 	TotalPageNum += CurtPktPageNum;
 
-	BufIndex += (CurtPktPageNum*PageSize);
+	BufIndex += (CurtPktPageNum * PageSize);
+
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("Beacon", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+	#endif
 
 	if (pwrctl->wowlan_ap_mode == _TRUE) {
 		/* (4) probe response*/
@@ -6074,117 +9475,214 @@ void rtw_hal_set_fw_rsvd_page(_adapter* adapter, bool finished)
 			&ProbeRspLength,
 			get_my_bssid(&pmlmeinfo->network), _FALSE);
 		rtw_hal_fill_fake_txdesc(adapter,
-			&ReservedPagePacket[BufIndex-TxDescLen],
-			ProbeRspLength, _FALSE, _FALSE, _FALSE);
+				 &ReservedPagePacket[BufIndex - TxDescLen],
+				 ProbeRspLength, _FALSE, _FALSE, _FALSE);
 
 		CurtPktPageNum = (u8)PageNum(TxDescLen + ProbeRspLength, PageSize);
 		TotalPageNum += CurtPktPageNum;
 		TotalPacketLen = BufIndex + ProbeRspLength;
-		BufIndex += (CurtPktPageNum*PageSize);
+		BufIndex += (CurtPktPageNum * PageSize);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("ProbeRsp", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+		#endif
 		goto download_page;
 	}
 
 	/* ps-poll * 1 page */
 	RsvdPageLoc.LocPsPoll = TotalPageNum;
-	DBG_871X("LocPsPoll: %d\n", RsvdPageLoc.LocPsPoll);
+	RTW_INFO("LocPsPoll: %d\n", RsvdPageLoc.LocPsPoll);
 	rtw_hal_construct_PSPoll(adapter,
-			&ReservedPagePacket[BufIndex], &PSPollLength);
+				 &ReservedPagePacket[BufIndex], &PSPollLength);
 	rtw_hal_fill_fake_txdesc(adapter,
-			&ReservedPagePacket[BufIndex-TxDescLen],
-			PSPollLength, _TRUE, _FALSE, _FALSE);
+				 &ReservedPagePacket[BufIndex - TxDescLen],
+				 PSPollLength, _TRUE, _FALSE, _FALSE);
 
 	CurtPktPageNum = (u8)PageNum((TxDescLen + PSPollLength), PageSize);
 
 	TotalPageNum += CurtPktPageNum;
 
-	BufIndex += (CurtPktPageNum*PageSize);
+	BufIndex += (CurtPktPageNum * PageSize);
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("PSPoll", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+	#endif
 
 #ifdef CONFIG_BT_COEXIST
-	/* BT Qos null data * 1 page */
-	RsvdPageLoc.LocBTQosNull = TotalPageNum;
-	DBG_871X("LocBTQosNull: %d\n", RsvdPageLoc.LocBTQosNull);
-	rtw_hal_construct_NullFunctionData(
-			adapter,
-			&ReservedPagePacket[BufIndex],
-			&BTQosNullLength,
-			get_my_bssid(&pmlmeinfo->network),
-			_TRUE, 0, 0, _FALSE);
-	rtw_hal_fill_fake_txdesc(adapter,
-			&ReservedPagePacket[BufIndex-TxDescLen],
-			BTQosNullLength, _FALSE, _TRUE, _FALSE);
+	if (pwrctl->wowlan_mode == _FALSE ||
+		pwrctl->wowlan_in_resume == _TRUE) {
+		/* BT Qos null data * 1 page */
+		RsvdPageLoc.LocBTQosNull = TotalPageNum;
 
-	CurtPktPageNum = (u8)PageNum(TxDescLen + BTQosNullLength, PageSize);
+		RTW_INFO("LocBTQosNull: %d\n", RsvdPageLoc.LocBTQosNull);
 
-	TotalPageNum += CurtPktPageNum;
+		rtw_hal_construct_NullFunctionData(adapter,
+					&ReservedPagePacket[BufIndex],
+					&BTQosNullLength,
+					get_my_bssid(&pmlmeinfo->network),
+					_TRUE, 0, 0, _FALSE);
+
+		rtw_hal_fill_fake_txdesc(adapter,
+				&ReservedPagePacket[BufIndex - TxDescLen],
+				BTQosNullLength, _FALSE, _TRUE, _FALSE);
+
+		CurtPktPageNum = (u8)PageNum(TxDescLen + BTQosNullLength,
+					     PageSize);
+
+		TotalPageNum += CurtPktPageNum;
+		BufIndex += (CurtPktPageNum * PageSize);
 
-	BufIndex += (CurtPktPageNum*PageSize);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("BTQosNull", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+		#endif
+	}
 #endif /* CONFIG_BT_COEXIT */
 
-	/* null data * 1 page */
-	RsvdPageLoc.LocNullData = TotalPageNum;
-	DBG_871X("LocNullData: %d\n", RsvdPageLoc.LocNullData);
-	rtw_hal_construct_NullFunctionData(
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(adapter)) {
+		dl_mcc_page = rtw_hal_dl_mcc_fw_rsvd_page(adapter, ReservedPagePacket,
+				&BufIndex, TxDescLen, PageSize, &TotalPageNum, &RsvdPageLoc, page_num);
+	} else {
+		dl_mcc_page = _FAIL;
+	}
+
+	if (dl_mcc_page == _FAIL)
+#endif /* CONFIG_MCC_MODE */
+	{
+		/* null data * 1 page */
+		RsvdPageLoc.LocNullData = TotalPageNum;
+		RTW_INFO("LocNullData: %d\n", RsvdPageLoc.LocNullData);
+		rtw_hal_construct_NullFunctionData(
 			adapter,
 			&ReservedPagePacket[BufIndex],
 			&NullDataLength,
 			get_my_bssid(&pmlmeinfo->network),
 			_FALSE, 0, 0, _FALSE);
-	rtw_hal_fill_fake_txdesc(adapter,
-			&ReservedPagePacket[BufIndex-TxDescLen],
-			NullDataLength, _FALSE, _FALSE, _FALSE);
+		rtw_hal_fill_fake_txdesc(adapter,
+				 &ReservedPagePacket[BufIndex - TxDescLen],
+				 NullDataLength, _FALSE, _FALSE, _FALSE);
 
-	CurtPktPageNum = (u8)PageNum(TxDescLen + NullDataLength, PageSize);
+		CurtPktPageNum = (u8)PageNum(TxDescLen + NullDataLength, PageSize);
 
-	TotalPageNum += CurtPktPageNum;
+		TotalPageNum += CurtPktPageNum;
+
+		BufIndex += (CurtPktPageNum * PageSize);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("NullData", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+		#endif
+	}
+
+	if (pwrctl->wowlan_mode == _FALSE ||
+		pwrctl->wowlan_in_resume == _TRUE) {
+		/* Qos null data * 1 page */
+		RsvdPageLoc.LocQosNull = TotalPageNum;
+		RTW_INFO("LocQosNull: %d\n", RsvdPageLoc.LocQosNull);
+		rtw_hal_construct_NullFunctionData(adapter,
+					&ReservedPagePacket[BufIndex],
+					&QosNullLength,
+					get_my_bssid(&pmlmeinfo->network),
+					_TRUE, 0, 0, _FALSE);
+		rtw_hal_fill_fake_txdesc(adapter,
+				 &ReservedPagePacket[BufIndex - TxDescLen],
+				 QosNullLength, _FALSE, _FALSE, _FALSE);
+
+		CurtPktPageNum = (u8)PageNum(TxDescLen + QosNullLength,
+					     PageSize);
 
-	BufIndex += (CurtPktPageNum*PageSize);
+		TotalPageNum += CurtPktPageNum;
+
+		BufIndex += (CurtPktPageNum * PageSize);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("QosNull", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+		#endif
+	}
 
-	//Qos null data * 1 page
-	RsvdPageLoc.LocQosNull = TotalPageNum;
-	DBG_871X("LocQosNull: %d\n", RsvdPageLoc.LocQosNull);
-	rtw_hal_construct_NullFunctionData(
+	TotalPacketLen = BufIndex;
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+		RsvdPageLoc.loc_fw_dbg_msg_pkt = TotalPageNum;
+		RTW_INFO("loc_fw_dbg_msg_pkt: %d\n", RsvdPageLoc.loc_fw_dbg_msg_pkt);
+		rtw_hal_construct_fw_dbg_msg_pkt(
 			adapter,
 			&ReservedPagePacket[BufIndex],
-			&QosNullLength,
-			get_my_bssid(&pmlmeinfo->network),
-			_TRUE, 0, 0, _FALSE);
-	rtw_hal_fill_fake_txdesc(adapter,
-			&ReservedPagePacket[BufIndex-TxDescLen],
-			QosNullLength, _FALSE, _FALSE, _FALSE);
+			&fw_dbg_msg_pkt_len);
+
+		rtw_hal_fill_fake_txdesc(adapter,
+				 &ReservedPagePacket[BufIndex - TxDescLen],
+				 fw_dbg_msg_pkt_len, _FALSE, _FALSE, _FALSE);
 
-	CurtPktPageNum = (u8)PageNum(TxDescLen + QosNullLength, PageSize);
+		CurtPktPageNum = (u8)PageNum(TxDescLen + fw_dbg_msg_pkt_len, PageSize);
 
-	TotalPageNum += CurtPktPageNum;
+		TotalPageNum += CurtPktPageNum;
 
-	TotalPacketLen = BufIndex + QosNullLength;
+		TotalPacketLen = BufIndex + fw_dbg_msg_pkt_len;
+		BufIndex += (CurtPktPageNum * PageSize);
 
-	BufIndex += (CurtPktPageNum*PageSize);
+		
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 
 #ifdef CONFIG_WOWLAN
 	if (pwrctl->wowlan_mode == _TRUE &&
-			check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		pwrctl->wowlan_in_resume == _FALSE) {
 		rtw_hal_set_wow_fw_rsvd_page(adapter, ReservedPagePacket,
-				BufIndex, TxDescLen, PageSize,
-				&TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
+					     BufIndex, TxDescLen, PageSize,
+			     &TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
 	}
 #endif /* CONFIG_WOWLAN */
 
 #ifdef CONFIG_P2P_WOWLAN
-	if(_TRUE == pwrctl->wowlan_p2p_mode) {
+	if (_TRUE == pwrctl->wowlan_p2p_mode) {
 		rtw_hal_set_p2p_wow_fw_rsvd_page(adapter, ReservedPagePacket,
-				BufIndex, TxDescLen, PageSize,
-				&TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
+						 BufIndex, TxDescLen, PageSize,
+				 &TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
 	}
 #endif /* CONFIG_P2P_WOWLAN */
 
+#ifdef CONFIG_LPS_PG
+	/* must reserved last 1 x page for LPS PG Info*/
+	pwrctl->lpspg_rsvd_page_locate = TotalPageNum;
+	pwrctl->blpspg_info_up = _TRUE;
+	if (page_num)
+		TotalPageNum += LPS_PG_INFO_RSVD_PAGE_NUM;
+
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("LPS_PG", LPS_PG_INFO_RSVD_PAGE_NUM,
+		(page_num) ? TotalPageNum : (TotalPageNum + LPS_PG_INFO_RSVD_PAGE_NUM),
+		TotalPacketLen);
+	#endif
+
+#endif
+
+	/*Note:  BufIndex already add a TxDescOffset offset in first Beacon page
+	* The "TotalPacketLen" is calculate by BufIndex.
+	* We need to decrease TxDescOffset before doing length check. by yiwei
+	*/
+	TotalPacketLen = TotalPacketLen - TxDescOffset;
+
 download_page:
-	/* DBG_871X("%s BufIndex(%d), TxDescLen(%d), PageSize(%d)\n",__func__, BufIndex, TxDescLen, PageSize);*/
-	DBG_871X("%s PageNum(%d), pktlen(%d)\n",
-				__func__, TotalPageNum, TotalPacketLen);
+	if (page_num) {
+		*page_num = TotalPageNum;
+		rtw_mfree(ReservedPagePacket, MAX_CMDBUF_SZ);
+		ReservedPagePacket = NULL;
+		return;
+	}
+
+	/* RTW_INFO("%s BufIndex(%d), TxDescLen(%d), PageSize(%d)\n",__func__, BufIndex, TxDescLen, PageSize);*/
+	RTW_INFO("%s PageNum(%d), pktlen(%d)\n",
+		 __func__, TotalPageNum, TotalPacketLen);
+
+#ifdef CONFIG_LPS_PG
+	if ((TotalPageNum + LPS_PG_INFO_RSVD_PAGE_NUM) > RsvdPageNum) {
+		pwrctl->lpspg_rsvd_page_locate = 0;
+		pwrctl->blpspg_info_up = _FALSE;
+
+		RTW_ERR("%s [LPS_PG] rsvd page %d  is not enough! need %d pages\n",
+			__func__, RsvdPageNum, (TotalPageNum + LPS_PG_INFO_RSVD_PAGE_NUM));
+		rtw_warn_on(1);
+	}
+#endif
 
 	if (TotalPacketLen > MaxRsvdPageBufSize) {
-		DBG_871X("%s(ERROR): rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
-				__FUNCTION__, TotalPacketLen,MaxRsvdPageBufSize);
+		RTW_ERR("%s : rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
+			 __FUNCTION__, TotalPacketLen, MaxRsvdPageBufSize);
 		rtw_warn_on(1);
 		goto error;
 	} else {
@@ -6192,8 +9690,8 @@ download_page:
 		pattrib = &pcmdframe->attrib;
 		update_mgntframe_attrib(adapter, pattrib);
 		pattrib->qsel = QSLT_BEACON;
-		pattrib->pktlen = TotalPacketLen - TxDescOffset;
-		pattrib->last_txcmdsz = TotalPacketLen - TxDescOffset;
+		pattrib->pktlen = TotalPacketLen;
+		pattrib->last_txcmdsz = TotalPacketLen;
 #ifdef CONFIG_PCI_HCI
 		dump_mgntframe(adapter, pcmdframe);
 #else
@@ -6201,13 +9699,23 @@ download_page:
 #endif
 	}
 
-	DBG_871X("%s: Set RSVD page location to Fw ,TotalPacketLen(%d), TotalPageNum(%d)\n",
-			__func__,TotalPacketLen,TotalPageNum);
-
-	if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+	RTW_INFO("%s: Set RSVD page location to Fw ,TotalPacketLen(%d), TotalPageNum(%d)\n",
+		 __func__, TotalPacketLen, TotalPageNum);
+#ifdef DBG_DUMP_SET_RSVD_PAGE
+	RTW_INFO(" ==================================================\n");
+	RTW_INFO_DUMP("\n", ReservedPagePacket, TotalPacketLen);
+	RTW_INFO(" ==================================================\n");
+#endif
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
 		rtw_hal_set_FwRsvdPage_cmd(adapter, &RsvdPageLoc);
-		if (pwrctl->wowlan_mode == _TRUE)
+#ifdef DBG_FW_DEBUG_MSG_PKT
+		rtw_hal_set_fw_dbg_msg_pkt_rsvd_page_cmd(adapter, &RsvdPageLoc);
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+#ifdef CONFIG_WOWLAN
+		if (pwrctl->wowlan_mode == _TRUE &&
+			pwrctl->wowlan_in_resume == _FALSE)
 			rtw_hal_set_FwAoacRsvdPage_cmd(adapter, &RsvdPageLoc);
+#endif /* CONFIG_WOWLAN */
 #ifdef CONFIG_AP_WOWLAN
 		if (pwrctl->wowlan_ap_mode == _TRUE)
 			rtw_hal_set_ap_rsvdpage_loc_cmd(adapter, &RsvdPageLoc);
@@ -6215,197 +9723,694 @@ download_page:
 	} else if (pwrctl->wowlan_pno_enable) {
 #ifdef CONFIG_PNO_SUPPORT
 		rtw_hal_set_FwAoacRsvdPage_cmd(adapter, &RsvdPageLoc);
-		if(pwrctl->pno_in_resume)
+		if (pwrctl->wowlan_in_resume)
 			rtw_hal_set_scan_offload_info_cmd(adapter,
-					&RsvdPageLoc, 0);
+							  &RsvdPageLoc, 0);
 		else
 			rtw_hal_set_scan_offload_info_cmd(adapter,
-					&RsvdPageLoc, 1);
+							  &RsvdPageLoc, 1);
 #endif /* CONFIG_PNO_SUPPORT */
 	}
+
 #ifdef CONFIG_P2P_WOWLAN
-	if(_TRUE == pwrctl->wowlan_p2p_mode)
+	if (_TRUE == pwrctl->wowlan_p2p_mode)
 		rtw_hal_set_FwP2PRsvdPage_cmd(adapter, &RsvdPageLoc);
 #endif /* CONFIG_P2P_WOWLAN */
+
 	return;
 error:
 	rtw_free_xmitframe(pxmitpriv, pcmdframe);
 }
 
-void SetHwReg(_adapter *adapter, u8 variable, u8 *val)
+void rtw_hal_set_fw_rsvd_page(struct _ADAPTER *adapter, bool finished)
+{
+	_rtw_hal_set_fw_rsvd_page(adapter, finished, NULL);
+}
+
+/**
+ * rtw_hal_get_rsvd_page_num() - Get needed reserved page number
+ * @adapter:	struct _ADAPTER*
+ *
+ * Caculate needed reserved page number.
+ * In different state would get different number, for example normal mode and
+ * WOW mode would need different reserved page size.
+ *
+ * Return the number of reserved page which driver need.
+ */
+u8 rtw_hal_get_rsvd_page_num(struct _ADAPTER *adapter)
+{
+	u8 num = 0;
+
+
+	_rtw_hal_set_fw_rsvd_page(adapter, _FALSE, &num);
+
+	return num;
+}
+
+static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 variable, u8 *val)
 {
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-_func_enter_;
+	u16 value_rxfltmap2;
+	int i;
+	_adapter *iface;
 
-	switch (variable) {
-		case HW_VAR_PORT_SWITCH:
-			hw_var_port_switch(adapter);
-			break;
-		case HW_VAR_INIT_RTS_RATE:
-		{
-			u16 brate_cfg = *((u16*)val);
-			u8 rate_index = 0;
-			HAL_VERSION *hal_ver = &hal_data->VersionID;
+#ifdef DBG_IFACE_STATUS
+	DBG_IFACE_STATUS_DUMP(adapter);
+#endif
 
-			if (IS_8188E(*hal_ver)) {
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	/* Receive all data frames */
+	value_rxfltmap2 = 0xFFFF;
+#else
+	/* not to receive data frame */
+	value_rxfltmap2 = 0;
+#endif
 
-				while (brate_cfg > 0x1) {
-					brate_cfg = (brate_cfg >> 1);
-					rate_index++;
-				}
-				rtw_write8(adapter, REG_INIRTS_RATE_SEL, rate_index);
-			} else {
-				rtw_warn_on(1);
+	if (*((u8 *)val)) { /* under sitesurvey */
+		/*
+		* 1. configure REG_RXFLTMAP2
+		* 2. disable TSF update &  buddy TSF update to avoid updating wrong TSF due to clear RCR_CBSSID_BCN
+		* 3. config RCR to receive different BSSID BCN or probe rsp
+		*/
+		rtw_write16(adapter, REG_RXFLTMAP2, value_rxfltmap2);
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		/*do nothing~~*/
+#else
+
+		/* disable update TSF */
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface)
+				continue;
+
+			if (rtw_linked_check(iface)
+				&& !MLME_IS_AP(iface) && !MLME_IS_MESH(iface)
+			) {
+				if (iface->hw_port == HW_PORT1)
+					rtw_write8(iface, REG_BCN_CTRL_1, rtw_read8(iface, REG_BCN_CTRL_1) | DIS_TSF_UDT);
+				else
+					rtw_write8(iface, REG_BCN_CTRL, rtw_read8(iface, REG_BCN_CTRL) | DIS_TSF_UDT);
+
+				iface->mlmeextpriv.en_hw_update_tsf = _FALSE;
 			}
 		}
-			break;
-		case HW_VAR_SEC_CFG:
-		{
-			#if defined(CONFIG_CONCURRENT_MODE) && !defined(DYNAMIC_CAMID_ALLOC)
-			// enable tx enc and rx dec engine, and no key search for MC/BC
-			rtw_write8(adapter, REG_SECCFG, SCR_NoSKMC|SCR_RxDecEnable|SCR_TxEncEnable);
-			#elif defined(DYNAMIC_CAMID_ALLOC)
-			u16 reg_scr_ori;
-			u16 reg_scr;
-
-			reg_scr = reg_scr_ori = rtw_read16(adapter, REG_SECCFG);
-			reg_scr |= (SCR_CHK_KEYID|SCR_RxDecEnable|SCR_TxEncEnable);
-
-			if (_rtw_camctl_chk_cap(adapter, SEC_CAP_CHK_BMC))
-				reg_scr |= SCR_CHK_BMC;
-
-			if (_rtw_camctl_chk_flags(adapter, SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH))
-				reg_scr |= SCR_NoSKMC;
-
-			if (reg_scr != reg_scr_ori)
-				rtw_write16(adapter, REG_SECCFG, reg_scr);
-			#else
-			rtw_write8(adapter, REG_SECCFG, *((u8*)val));
-			#endif
+#endif /* CONFIG_MI_WITH_MBSSID_CAM */
+
+		rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_ENTER);
+
+		/* Save orignal RRSR setting. needed? */
+		hal_data->RegRRSR = rtw_read16(adapter, REG_RRSR);
+
+		#if defined(CONFIG_BEAMFORMING) && (defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A))
+		if (IS_8812_SERIES(hal_data->version_id) || IS_8821_SERIES(hal_data->version_id)) {
+			/* set 718[1:0]=2'b00 to avoid BF scan hang */
+			hal_data->backup_snd_ptcl_ctrl = rtw_read8(adapter, REG_SND_PTCL_CTRL_8812A);
+			rtw_write8(adapter, REG_SND_PTCL_CTRL_8812A, (hal_data->backup_snd_ptcl_ctrl & 0xfc));
 		}
-			break;
-		case HW_VAR_SEC_DK_CFG:
-		{
-			struct security_priv *sec = &adapter->securitypriv;
-			u8 reg_scr = rtw_read8(adapter, REG_SECCFG);
+		#endif
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
+			StopTxBeacon(adapter);
+	} else { /* sitesurvey done */
+		/*
+		* 1. enable rx data frame
+		* 2. config RCR not to receive different BSSID BCN or probe rsp
+		* 3. doesn't enable TSF update &  buddy TSF right now to avoid HW conflict
+		*	 so, we enable TSF update when rx first BCN after sitesurvey done
+		*/
+		if (rtw_mi_check_fwstate(adapter, _FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE)) {
+			/* enable to rx data frame */
+			rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
+		}
+
+		rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_DONE);
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		/*if ((rtw_mi_get_assoced_sta_num(adapter) == 1) && (!rtw_mi_check_status(adapter, MI_AP_MODE)))
+			rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL)&(~DIS_TSF_UDT));*/
+#else
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface)
+				continue;
+			if (rtw_linked_check(iface)
+				&& !MLME_IS_AP(iface) && !MLME_IS_MESH(iface)
+			) {
+				/* enable HW TSF update when recive beacon*/
+				/*if (iface->hw_port == HW_PORT1)
+					rtw_write8(iface, REG_BCN_CTRL_1, rtw_read8(iface, REG_BCN_CTRL_1)&(~(DIS_TSF_UDT)));
+				else
+					rtw_write8(iface, REG_BCN_CTRL, rtw_read8(iface, REG_BCN_CTRL)&(~(DIS_TSF_UDT)));
+				*/
+				iface->mlmeextpriv.en_hw_update_tsf = _TRUE;
+			}
+		}
+#endif /* CONFIG_MI_WITH_MBSSID_CAM */
+
+		/* Restore orignal RRSR setting. needed? */
+		rtw_write16(adapter, REG_RRSR, hal_data->RegRRSR);
+
+		#if defined(CONFIG_BEAMFORMING) && (defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A))
+		if (IS_8812_SERIES(hal_data->version_id) || IS_8821_SERIES(hal_data->version_id)) {
+			/* Restore orignal 0x718 setting*/
+			rtw_write8(adapter, REG_SND_PTCL_CTRL_8812A, hal_data->backup_snd_ptcl_ctrl);
+		}
+		#endif
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
+			ResumeTxBeacon(adapter);
+			rtw_mi_tx_beacon_hdl(adapter);
+		}
+	}
+}
+
+#ifdef CONFIG_TSF_RESET_OFFLOAD
+static int rtw_hal_h2c_reset_tsf(_adapter *adapter, u8 reset_port)
+{
+	u8 buf[2];
+	int ret;
+
+	if (reset_port == HW_PORT0) {
+		buf[0] = 0x1;
+		buf[1] = 0;
+	} else {
+		buf[0] = 0x0;
+		buf[1] = 0x1;
+	}
+
+	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_RESET_TSF, 2, buf);
+
+	return ret;
+}
+
+int rtw_hal_reset_tsf(_adapter *adapter, u8 reset_port)
+{
+	u8 reset_cnt_before = 0, reset_cnt_after = 0, loop_cnt = 0;
+	u32 reg_reset_tsf_cnt = (reset_port == HW_PORT0) ?
+				REG_FW_RESET_TSF_CNT_0 : REG_FW_RESET_TSF_CNT_1;
+	int ret;
+
+	/* site survey will cause reset tsf fail */
+	rtw_mi_buddy_scan_abort(adapter, _FALSE);
+	reset_cnt_after = reset_cnt_before = rtw_read8(adapter, reg_reset_tsf_cnt);
+	ret = rtw_hal_h2c_reset_tsf(adapter, reset_port);
+	if (ret != _SUCCESS)
+		return ret;
+
+	while ((reset_cnt_after == reset_cnt_before) && (loop_cnt < 10)) {
+		rtw_msleep_os(100);
+		loop_cnt++;
+		reset_cnt_after = rtw_read8(adapter, reg_reset_tsf_cnt);
+	}
+
+	return (loop_cnt >= 10) ? _FAIL : _SUCCESS;
+}
+#endif /* CONFIG_TSF_RESET_OFFLOAD */
+
+static void rtw_hal_set_hw_update_tsf(PADAPTER padapter)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_MI_WITH_MBSSID_CAM)
+	RTW_INFO("[Warn] %s "ADPT_FMT" enter func\n", __func__, ADPT_ARG(padapter));
+	rtw_warn_on(1);
+	return;
+#endif
+
+	if (!pmlmeext->en_hw_update_tsf)
+		return;
+
+	/* check RCR */
+	if (!rtw_hal_rcr_check(padapter, RCR_CBSSID_BCN))
+		return;
+
+	/* enable hw update tsf function for non-AP and non-Mesh */
+	if (rtw_linked_check(padapter)
+		&& !MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter)
+	) {
+#ifdef CONFIG_CONCURRENT_MODE
+		if (padapter->hw_port == HW_PORT1)
+			rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) & (~DIS_TSF_UDT));
+		else
+#endif
+			rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) & (~DIS_TSF_UDT));
+	}
+	pmlmeext->en_hw_update_tsf = _FALSE;
+}
+
+static void hw_var_set_correct_tsf(_adapter *adapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	/*do nothing*/
+#else
+	u64 tsf;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
+
+	tsf = mlmeext->TSFValue - rtw_modular64(mlmeext->TSFValue, (mlmeinfo->bcn_interval * 1024)) - 1024; /*us*/
+
+	if ((mlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE
+		|| (mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)
+		StopTxBeacon(adapter);
+
+	rtw_hal_correct_tsf(adapter, adapter->hw_port, tsf);
+
+#ifdef CONFIG_CONCURRENT_MODE
+	/* Update buddy port's TSF if it is SoftAP/Mesh for beacon TX issue! */
+	if ((mlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE
+		&& (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
+	) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+		int i;
+		_adapter *iface;
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface)
+				continue;
+			if (iface == adapter)
+				continue;
+
+			if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
+				&& check_fwstate(&iface->mlmepriv, WIFI_ASOC_STATE) == _TRUE
+			) {
+				rtw_hal_correct_tsf(iface, iface->hw_port, tsf);
+				#ifdef CONFIG_TSF_RESET_OFFLOAD
+				if (rtw_hal_reset_tsf(iface, iface->hw_port) == _FAIL)
+					RTW_INFO("%s-[ERROR] "ADPT_FMT" Reset port%d TSF fail\n"
+						, __func__, ADPT_ARG(iface), iface->hw_port);
+				#endif	/* CONFIG_TSF_RESET_OFFLOAD*/
+			}
+		}
+	}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+	if ((mlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE
+		|| (mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)
+		ResumeTxBeacon(adapter);
+
+#endif /*CONFIG_MI_WITH_MBSSID_CAM*/
+}
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+s32 rtw_hal_ch_sw_oper_offload(_adapter *padapter, u8 channel, u8 channel_offset, u16 bwmode)
+{
+	PHAL_DATA_TYPE	pHalData =  GET_HAL_DATA(padapter);
+	u8 ch_sw_h2c_buf[4] = {0x00, 0x00, 0x00, 0x00};
+
+
+	SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(ch_sw_h2c_buf, channel);
+	SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(ch_sw_h2c_buf, bwmode);
+	switch (bwmode) {
+	case CHANNEL_WIDTH_40:
+		SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(ch_sw_h2c_buf, channel_offset);
+		break;
+	case CHANNEL_WIDTH_80:
+		SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(ch_sw_h2c_buf, channel_offset);
+		break;
+	case CHANNEL_WIDTH_20:
+	default:
+		break;
+	}
+	SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(ch_sw_h2c_buf, pHalData->rfe_type);
+
+	return rtw_hal_fill_h2c_cmd(padapter, H2C_CHNL_SWITCH_OPER_OFFLOAD, sizeof(ch_sw_h2c_buf), ch_sw_h2c_buf);
+}
+#endif
+#endif
+
+#ifdef CONFIG_WMMPS_STA
+void rtw_hal_update_uapsd_tid(_adapter *adapter)
+{
+	struct mlme_priv		*pmlmepriv = &adapter->mlmepriv;
+	struct qos_priv		*pqospriv = &pmlmepriv->qospriv;
+
+	/* write complement of pqospriv->uapsd_tid to mac register 0x693 because 
+	    it's designed  for "0" represents "enable" and "1" represents "disable" */
+	rtw_write8(adapter, REG_WMMPS_UAPSD_TID, (u8)(~pqospriv->uapsd_tid));
+}
+#endif /* CONFIG_WMMPS_STA */
+
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+/* For multi-port support, driver needs to inform the port ID to FW for btc operations */
+s32 rtw_hal_set_wifi_port_id_cmd(_adapter *adapter)
+{
+	u8 port_id = 0;
+	u8 h2c_buf[H2C_BTC_WL_PORT_ID_LEN] = {0};
+
+	SET_H2CCMD_BTC_WL_PORT_ID(h2c_buf, adapter->hw_port);
+	return rtw_hal_fill_h2c_cmd(adapter, H2C_BTC_WL_PORT_ID, H2C_BTC_WL_PORT_ID_LEN, h2c_buf);
+}
+#endif
+
+u8 SetHwReg(_adapter *adapter, u8 variable, u8 *val)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u8 ret = _SUCCESS;
+
+	switch (variable) {
+	case HW_VAR_MEDIA_STATUS: {
+		u8 net_type = *((u8 *)val);
+
+		rtw_hal_set_msr(adapter, net_type);
+	}
+	break;
+	case HW_VAR_DO_IQK:
+		if (*val)
+			hal_data->bNeedIQK = _TRUE;
+		else
+			hal_data->bNeedIQK = _FALSE;
+		break;
+	case HW_VAR_MAC_ADDR:
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_hal_set_macaddr_mbid(adapter, val);
+#else
+		rtw_hal_set_macaddr_port(adapter, val);
+#endif
+		break;
+	case HW_VAR_BSSID:
+		rtw_hal_set_bssid(adapter, val);
+		break;
+	case HW_VAR_RCR:
+		ret = hw_var_rcr_config(adapter, *((u32 *)val));
+		break;
+	case HW_VAR_ON_RCR_AM:
+		hw_var_set_rcr_am(adapter, 1);
+		break;
+	case HW_VAR_OFF_RCR_AM:
+		hw_var_set_rcr_am(adapter, 0);
+		break;
+	case HW_VAR_BEACON_INTERVAL:
+		hw_var_set_bcn_interval(adapter, *(u16 *)val);
+		break;
+#ifdef CONFIG_MBSSID_CAM
+	case HW_VAR_MBSSID_CAM_WRITE: {
+		u32	cmd = 0;
+		u32	*cam_val = (u32 *)val;
+
+		rtw_write32(adapter, REG_MBIDCAMCFG_1, cam_val[0]);
+		cmd = BIT_MBIDCAM_POLL | BIT_MBIDCAM_WT_EN | BIT_MBIDCAM_VALID | cam_val[1];
+		rtw_write32(adapter, REG_MBIDCAMCFG_2, cmd);
+	}
+		break;
+	case HW_VAR_MBSSID_CAM_CLEAR: {
+		u32 cmd;
+		u8 entry_id = *(u8 *)val;
+
+		rtw_write32(adapter, REG_MBIDCAMCFG_1, 0);
+
+		cmd = BIT_MBIDCAM_POLL | BIT_MBIDCAM_WT_EN | ((entry_id & MBIDCAM_ADDR_MASK) << MBIDCAM_ADDR_SHIFT);
+		rtw_write32(adapter, REG_MBIDCAMCFG_2, cmd);
+	}
+		break;
+	case HW_VAR_RCR_MBSSID_EN:
+		if (*((u8 *)val))
+			rtw_hal_rcr_add(adapter, RCR_ENMBID);
+		else
+			rtw_hal_rcr_clear(adapter, RCR_ENMBID);
+		break;
+#endif
+	case HW_VAR_PORT_SWITCH:
+		hw_var_port_switch(adapter);
+		break;
+	case HW_VAR_INIT_RTS_RATE: {
+		u16 brate_cfg = *((u16 *)val);
+		u8 rate_index = 0;
+		HAL_VERSION *hal_ver = &hal_data->version_id;
+
+		if (IS_8188E(*hal_ver)) {
+
+			while (brate_cfg > 0x1) {
+				brate_cfg = (brate_cfg >> 1);
+				rate_index++;
+			}
+			rtw_write8(adapter, REG_INIRTS_RATE_SEL, rate_index);
+		} else
+			rtw_warn_on(1);
+	}
+		break;
+	case HW_VAR_SEC_CFG: {
+		u16 reg_scr_ori;
+		u16 reg_scr;
+
+		reg_scr = reg_scr_ori = rtw_read16(adapter, REG_SECCFG);
+		reg_scr |= (SCR_CHK_KEYID | SCR_RxDecEnable | SCR_TxEncEnable);
+
+		if (_rtw_camctl_chk_cap(adapter, SEC_CAP_CHK_BMC))
+			reg_scr |= SCR_CHK_BMC;
+
+		if (_rtw_camctl_chk_flags(adapter, SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH))
+			reg_scr |= SCR_NoSKMC;
+
+		if (reg_scr != reg_scr_ori)
+			rtw_write16(adapter, REG_SECCFG, reg_scr);
+	}
+		break;
+	case HW_VAR_SEC_DK_CFG: {
+		struct security_priv *sec = &adapter->securitypriv;
+		u8 reg_scr = rtw_read8(adapter, REG_SECCFG);
 
-			if (val) /* Enable default key related setting */
-			{
-				reg_scr |= SCR_TXBCUSEDK;
-				if (sec->dot11AuthAlgrthm != dot11AuthAlgrthm_8021X)
-					reg_scr |= (SCR_RxUseDK|SCR_TxUseDK);
-			}
-			else /* Disable default key related setting */
-			{
-				reg_scr &= ~(SCR_RXBCUSEDK|SCR_TXBCUSEDK|SCR_RxUseDK|SCR_TxUseDK);
-			}
+		if (val) { /* Enable default key related setting */
+			reg_scr |= SCR_TXBCUSEDK;
+			if (sec->dot11AuthAlgrthm != dot11AuthAlgrthm_8021X)
+				reg_scr |= (SCR_RxUseDK | SCR_TxUseDK);
+		} else /* Disable default key related setting */
+			reg_scr &= ~(SCR_RXBCUSEDK | SCR_TXBCUSEDK | SCR_RxUseDK | SCR_TxUseDK);
 
-			rtw_write8(adapter, REG_SECCFG, reg_scr);
-		}
-			break;
+		rtw_write8(adapter, REG_SECCFG, reg_scr);
+	}
+		break;
 
-		case HW_VAR_ASIX_IOT:
-			// enable  ASIX IOT function
-			if (*((u8*)val) == _TRUE) {
-				// 0xa2e[0]=0 (disable rake receiver)
-				rtw_write8(adapter, rCCK0_FalseAlarmReport+2, 
-						rtw_read8(adapter, rCCK0_FalseAlarmReport+2) & ~(BIT0));
-				//  0xa1c=0xa0 (reset channel estimation if signal quality is bad)
-				rtw_write8(adapter, rCCK0_DSPParameter2, 0xa0);
-			} else {
-			// restore reg:0xa2e,   reg:0xa1c
-				rtw_write8(adapter, rCCK0_FalseAlarmReport+2, 
-						rtw_read8(adapter, rCCK0_FalseAlarmReport+2)|(BIT0));
-				rtw_write8(adapter, rCCK0_DSPParameter2, 0x00);
-			}
-			break;
+	case HW_VAR_ASIX_IOT:
+		/* enable  ASIX IOT function */
+		if (*((u8 *)val) == _TRUE) {
+			/* 0xa2e[0]=0 (disable rake receiver) */
+			rtw_write8(adapter, rCCK0_FalseAlarmReport + 2,
+				rtw_read8(adapter, rCCK0_FalseAlarmReport + 2) & ~(BIT0));
+			/* 0xa1c=0xa0 (reset channel estimation if signal quality is bad) */
+			rtw_write8(adapter, rCCK0_DSPParameter2, 0xa0);
+		} else {
+			/* restore reg:0xa2e,   reg:0xa1c */
+			rtw_write8(adapter, rCCK0_FalseAlarmReport + 2,
+				rtw_read8(adapter, rCCK0_FalseAlarmReport + 2) | (BIT0));
+			rtw_write8(adapter, rCCK0_DSPParameter2, 0x00);
+		}
+		break;
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-		case HW_VAR_WOWLAN:
-		{
-			struct wowlan_ioctl_param *poidparam;
-			
-			poidparam = (struct wowlan_ioctl_param *)val;
-			switch (poidparam->subcode) {
+	case HW_VAR_WOWLAN: {
+		struct wowlan_ioctl_param *poidparam;
+
+		poidparam = (struct wowlan_ioctl_param *)val;
+		switch (poidparam->subcode) {
 #ifdef CONFIG_WOWLAN
-			case WOWLAN_PATTERN_CLEAN:
-				rtw_hal_dl_pattern(adapter, _TRUE);
-				break;
-			case WOWLAN_ENABLE:
-				rtw_hal_wow_enable(adapter);
-				break;
-			case WOWLAN_DISABLE:
-				rtw_hal_wow_disable(adapter);
-				break;
+		case WOWLAN_PATTERN_CLEAN:
+			rtw_hal_dl_pattern(adapter, 2);
+			break;
+		case WOWLAN_ENABLE:
+			rtw_hal_wow_enable(adapter);
+			break;
+		case WOWLAN_DISABLE:
+			rtw_hal_wow_disable(adapter);
+			break;
 #endif /*CONFIG_WOWLAN*/
 #ifdef CONFIG_AP_WOWLAN
-			case WOWLAN_AP_ENABLE:
-				rtw_hal_ap_wow_enable(adapter);
-				break;
-			case WOWLAN_AP_DISABLE:
-				rtw_hal_ap_wow_disable(adapter);
-				break;
+		case WOWLAN_AP_ENABLE:
+			rtw_hal_ap_wow_enable(adapter);
+			break;
+		case WOWLAN_AP_DISABLE:
+			rtw_hal_ap_wow_disable(adapter);
+			break;
 #endif /*CONFIG_AP_WOWLAN*/
-			default:
-				break;
-			}
+		default:
+			break;
 		}
+	}
 		break;
 #endif /*defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)*/
-		default:
-			if (0)
-				DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" variable(%d) not defined!\n",
-					FUNC_ADPT_ARG(adapter), variable);
-			break;
+
+	case HW_VAR_MLME_SITESURVEY:
+		hw_var_set_mlme_sitesurvey(adapter, variable, val);
+		#ifdef CONFIG_BT_COEXIST
+		if (hal_data->EEPROMBluetoothCoexist == 1)
+			rtw_btcoex_ScanNotify(adapter, *val ? _TRUE : _FALSE);
+		#endif
+		break;
+
+	case HW_VAR_EN_HW_UPDATE_TSF:
+		rtw_hal_set_hw_update_tsf(adapter);
+		break;
+
+	case HW_VAR_CORRECT_TSF:
+		hw_var_set_correct_tsf(adapter);
+		break;
+
+	case HW_VAR_APFM_ON_MAC:
+		hal_data->bMacPwrCtrlOn = *val;
+		RTW_INFO("%s: bMacPwrCtrlOn=%d\n", __func__, hal_data->bMacPwrCtrlOn);
+		break;
+#ifdef CONFIG_WMMPS_STA
+	case  HW_VAR_UAPSD_TID:
+		rtw_hal_update_uapsd_tid(adapter);
+		break;
+#endif /* CONFIG_WMMPS_STA */
+#ifdef CONFIG_LPS_PG
+	case HW_VAR_LPS_PG_HANDLE:
+		rtw_hal_lps_pg_handler(adapter, *val);
+		break;
+#endif
+#ifdef CONFIG_LPS_LCLK_WD_TIMER
+	case HW_VAR_DM_IN_LPS_LCLK:
+		rtw_phydm_wd_lps_lclk_hdl(adapter);
+		break;
+#endif
+	case HW_VAR_ENABLE_RX_BAR:
+		if (*val == _TRUE) {
+			/* enable RX BAR */
+			u16 val16 = rtw_read16(adapter, REG_RXFLTMAP1);
+
+			val16 |= BIT(8);
+			rtw_write16(adapter, REG_RXFLTMAP1, val16);
+		} else {
+			/* disable RX BAR */
+			u16 val16 = rtw_read16(adapter, REG_RXFLTMAP1);
+
+			val16 &= (~BIT(8));
+			rtw_write16(adapter, REG_RXFLTMAP1, val16);
+		}
+		RTW_INFO("[HW_VAR_ENABLE_RX_BAR] 0x%02X=0x%02X\n",
+			REG_RXFLTMAP1, rtw_read16(adapter, REG_RXFLTMAP1));
+		break;
+	default:
+		if (0)
+			RTW_PRINT(FUNC_ADPT_FMT" variable(%d) not defined!\n",
+				  FUNC_ADPT_ARG(adapter), variable);
+		ret = _FAIL;
+		break;
 	}
 
-_func_exit_;
+	return ret;
 }
 
 void GetHwReg(_adapter *adapter, u8 variable, u8 *val)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u64 val64;
 
-_func_enter_;
 
 	switch (variable) {
+	case HW_VAR_MAC_ADDR:
+		rtw_hal_get_macaddr_port(adapter, val);
+		break;
 	case HW_VAR_BASIC_RATE:
-		*((u16*)val) = hal_data->BasicRateSet;
+		*((u16 *)val) = hal_data->BasicRateSet;
 		break;
 	case HW_VAR_RF_TYPE:
-		*((u8*)val) = hal_data->rf_type;
+		*((u8 *)val) = hal_data->rf_type;
+		break;
+	case HW_VAR_MEDIA_STATUS:
+		rtw_hal_get_msr(adapter, val);
+		break;
+	case HW_VAR_DO_IQK:
+		*val = hal_data->bNeedIQK;
+		break;
+	case HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO:
+		if (hal_is_band_support(adapter, BAND_ON_5G))
+			*val = _TRUE;
+		else
+			*val = _FALSE;
 		break;
+	case HW_VAR_APFM_ON_MAC:
+		*val = hal_data->bMacPwrCtrlOn;
+		break;
+	case HW_VAR_RCR:
+		hw_var_rcr_get(adapter, (u32 *)val);
+		break;
+	case HW_VAR_FWLPS_RF_ON:
+		/* When we halt NIC, we should check if FW LPS is leave. */
+		if (rtw_is_surprise_removed(adapter)
+			|| (adapter_to_pwrctl(adapter)->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.
+			 */
+			*val = _TRUE;
+		} else {
+			u32 rcr = 0;
+
+			rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
+			if (rcr & (RCR_UC_MD_EN | RCR_BC_MD_EN | RCR_TIM_PARSER_EN))
+				*val = _FALSE;
+			else
+				*val = _TRUE;
+		}
+		break;
+
+	case HW_VAR_TSF:
+		/* read and save HIGH 32bits TSF value */
+		val64 = rtw_read32(adapter, REG_TSFTR+4);
+		val64 = val64 << 32;
+
+		/* read and save LOW 32bits TSF value */
+		val64 |= rtw_read32(adapter, REG_TSFTR);
+		*((u64*)val) = val64;
+		break;
+
 	default:
 		if (0)
-			DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" variable(%d) not defined!\n",
-				FUNC_ADPT_ARG(adapter), variable);
+			RTW_PRINT(FUNC_ADPT_FMT" variable(%d) not defined!\n",
+				  FUNC_ADPT_ARG(adapter), variable);
 		break;
 	}
 
-_func_exit_;
+}
+
+static u32 _get_page_size(struct _ADAPTER *a)
+{
+#ifdef RTW_HALMAC
+	struct dvobj_priv *d;
+	u32 size = 0;
+	int err = 0;
+
+
+	d = adapter_to_dvobj(a);
+
+	err = rtw_halmac_get_page_size(d, &size);
+	if (!err)
+		return size;
+
+	RTW_WARN(FUNC_ADPT_FMT ": Fail to get Page size!!(err=%d)\n",
+		 FUNC_ADPT_ARG(a), err);
+#endif /* RTW_HALMAC */
+
+	return PAGE_SIZE_128;
 }
 
 u8
 SetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)
-{	
+{
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	u8 bResult = _SUCCESS;
 
-	switch(variable) {
+	switch (variable) {
 
 	case HAL_DEF_DBG_DUMP_RXPKT:
-		hal_data->bDumpRxPkt = *((u8*)value);
+		hal_data->bDumpRxPkt = *((u8 *)value);
 		break;
 	case HAL_DEF_DBG_DUMP_TXPKT:
-		hal_data->bDumpTxPkt = *((u8*)value);
+		hal_data->bDumpTxPkt = *((u8 *)value);
 		break;
 	case HAL_DEF_ANT_DETECT:
 		hal_data->AntDetection = *((u8 *)value);
 		break;
-	case HAL_DEF_DBG_DIS_PWT:
-		hal_data->bDisableTXPowerTraining = *((u8*)value);
-		break;	
 	default:
-		DBG_871X_LEVEL(_drv_always_, "%s: [WARNING] HAL_DEF_VARIABLE(%d) not defined!\n", __FUNCTION__, variable);
+		RTW_PRINT("%s: [WARNING] HAL_DEF_VARIABLE(%d) not defined!\n", __FUNCTION__, variable);
 		bResult = _FAIL;
 		break;
 	}
@@ -6418,47 +10423,76 @@ u8 rtw_hal_query_txbfer_rf_num(_adapter *adapter)
 {
 	struct registry_priv	*pregistrypriv = &adapter->registrypriv;
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	
-	if ((pregistrypriv->beamformer_rf_num) && (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter) || IS_HARDWARE_TYPE_8822BU(adapter)))
+
+	if ((pregistrypriv->beamformer_rf_num) && (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter) || IS_HARDWARE_TYPE_8822BU(adapter) || IS_HARDWARE_TYPE_8821C(adapter)))
 		return pregistrypriv->beamformer_rf_num;
 	else if (IS_HARDWARE_TYPE_8814AE(adapter)
-/*
-#if defined(CONFIG_USB_HCI) 
-	||  (IS_HARDWARE_TYPE_8814AU(adapter) && (pUsbModeMech->CurUsbMode == 2 || pUsbModeMech->HubUsbMode == 2)) //for USB3.0
+#if 0
+#if defined(CONFIG_USB_HCI)
+		|| (IS_HARDWARE_TYPE_8814AU(adapter) && (pUsbModeMech->CurUsbMode == 2 || pUsbModeMech->HubUsbMode == 2))  /* for USB3.0 */
 #endif
-*/
-	) {	
+#endif
+		) {
 		/*BF cap provided by Yu Chen, Sean, 2015, 01 */
-		if (hal_data->rf_type == RF_3T3R) 
+		if (hal_data->rf_type == RF_3T3R)
 			return 2;
 		else if (hal_data->rf_type == RF_4T4R)
 			return 3;
-		else 
+		else
 			return 1;
 	} else
 		return 1;
-	
+
 }
 u8 rtw_hal_query_txbfee_rf_num(_adapter *adapter)
 {
 	struct registry_priv		*pregistrypriv = &adapter->registrypriv;
 	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	
+
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	
-	if ((pregistrypriv->beamformee_rf_num) && (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter) || IS_HARDWARE_TYPE_8822BU(adapter)))
+
+	if ((pregistrypriv->beamformee_rf_num) && (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter) || IS_HARDWARE_TYPE_8822BU(adapter) || IS_HARDWARE_TYPE_8821C(adapter)))
 		return pregistrypriv->beamformee_rf_num;
 	else if (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter)) {
-		if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM)		
-			return 2;		
+		if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM)
+			return 2;
 		else
 			return 2;/*TODO: May be 3 in the future, by ChenYu. */
 	} else
 		return 1;
-		
+
+}
+#ifdef RTW_BEAMFORMING_VERSION_2
+void rtw_hal_beamforming_config_csirate(PADAPTER adapter)
+{
+	struct dm_struct *p_dm_odm;
+	struct beamforming_info *bf_info;
+	u8 fix_rate_enable = 0;
+	u8 new_csi_rate_idx;
+
+	/* Acting as BFee */
+	if (IS_BEAMFORMEE(adapter)) {
+	#if 0
+		/* Do not enable now because it will affect MU performance and CTS/BA rate. 2016.07.19. by tynli. [PCIE-1660] */
+		if (IS_HARDWARE_TYPE_8821C(Adapter))
+			FixRateEnable = 1;	/* Support after 8821C */
+	#endif
+
+		p_dm_odm = adapter_to_phydm(adapter);
+		bf_info = GET_BEAMFORM_INFO(adapter);
+
+		rtw_halmac_bf_cfg_csi_rate(adapter_to_dvobj(adapter),
+				p_dm_odm->rssi_min,
+				bf_info->cur_csi_rpt_rate,
+				fix_rate_enable, &new_csi_rate_idx);
+
+		if (new_csi_rate_idx != bf_info->cur_csi_rpt_rate)
+			bf_info->cur_csi_rpt_rate = new_csi_rate_idx;
+	}
 }
 #endif
+#endif
 
 u8
 GetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)
@@ -6466,424 +10500,180 @@ GetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	u8 bResult = _SUCCESS;
 
-	switch(variable) {
-		case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB:
-			{
-				struct mlme_priv *pmlmepriv;
-				struct sta_priv *pstapriv;
-				struct sta_info *psta;
-
-				pmlmepriv = &adapter->mlmepriv;
-				pstapriv = &adapter->stapriv;
-				psta = rtw_get_stainfo(pstapriv, pmlmepriv->cur_network.network.MacAddress);
-				if (psta)
-				{
-					*((int*)value) = psta->rssi_stat.UndecoratedSmoothedPWDB;     
-				}
-			}
-			break;
-		case HAL_DEF_DBG_DUMP_RXPKT:
-			*((u8*)value) = hal_data->bDumpRxPkt;
-			break;
-		case HAL_DEF_DBG_DUMP_TXPKT:
-			*((u8*)value) = hal_data->bDumpTxPkt;
-			break;
-		case HAL_DEF_ANT_DETECT:
-			*((u8 *)value) = hal_data->AntDetection;
-			break;
-		case HAL_DEF_MACID_SLEEP:
-			*(u8*)value = _FALSE;
-			break;
-		case HAL_DEF_TX_PAGE_SIZE:
-			*(( u32*)value) = PAGE_SIZE_128;
-			break;
-		case HAL_DEF_DBG_DIS_PWT:
-			*(u8*)value = hal_data->bDisableTXPowerTraining;
-			break;
-#ifdef CONFIG_BEAMFORMING
-		case HAL_DEF_BEAMFORMER_CAP:
-			*(u8 *)value = rtw_hal_query_txbfer_rf_num(adapter);
-			break;
-		case HAL_DEF_BEAMFORMEE_CAP:
-			*(u8 *)value = rtw_hal_query_txbfee_rf_num(adapter);
-			break;
-#endif
-		default:
-			DBG_871X_LEVEL(_drv_always_, "%s: [WARNING] HAL_DEF_VARIABLE(%d) not defined!\n", __FUNCTION__, variable);
-			bResult = _FAIL;
-			break;
-	}
-
-	return bResult;
-}
-
-void SetHalODMVar(
-	PADAPTER				Adapter,
-	HAL_ODM_VARIABLE		eVariable,
-	PVOID					pValue1,
-	BOOLEAN					bSet)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T podmpriv = &pHalData->odmpriv;
-	//_irqL irqL;
-	switch(eVariable){
-		case HAL_ODM_STA_INFO:
-			{	
-				struct sta_info *psta = (struct sta_info *)pValue1;				
-				if(bSet){
-					DBG_8192C("### Set STA_(%d) info ###\n",psta->mac_id);
-					ODM_CmnInfoPtrArrayHook(podmpriv, ODM_CMNINFO_STA_STATUS,psta->mac_id,psta);
-				}
-				else{
-					DBG_8192C("### Clean STA_(%d) info ###\n",psta->mac_id);
-					//_enter_critical_bh(&pHalData->odm_stainfo_lock, &irqL);
-					ODM_CmnInfoPtrArrayHook(podmpriv, ODM_CMNINFO_STA_STATUS,psta->mac_id,NULL);
-					
-					//_exit_critical_bh(&pHalData->odm_stainfo_lock, &irqL);
-			            }
-			}
-			break;
-		case HAL_ODM_P2P_STATE:		
-				ODM_CmnInfoUpdate(podmpriv,ODM_CMNINFO_WIFI_DIRECT,bSet);
-			break;
-		case HAL_ODM_WIFI_DISPLAY_STATE:
-				ODM_CmnInfoUpdate(podmpriv,ODM_CMNINFO_WIFI_DISPLAY,bSet);
-			break;
-		case HAL_ODM_REGULATION:
-				ODM_CmnInfoInit(podmpriv, ODM_CMNINFO_DOMAIN_CODE_2G, pHalData->Regulation2_4G);
-				ODM_CmnInfoInit(podmpriv, ODM_CMNINFO_DOMAIN_CODE_5G, pHalData->Regulation5G);
-			break;
-#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)		
-		case HAL_ODM_NOISE_MONITOR:
-			{
-				struct noise_info *pinfo = (struct noise_info *)pValue1;
-
-				#ifdef DBG_NOISE_MONITOR
-				DBG_8192C("### Noise monitor chan(%d)-bPauseDIG:%d,IGIValue:0x%02x,max_time:%d (ms) ###\n",
-					pinfo->chan,pinfo->bPauseDIG,pinfo->IGIValue,pinfo->max_time);
-				#endif
-				
-				pHalData->noise[pinfo->chan] = ODM_InbandNoise_Monitor(podmpriv,pinfo->bPauseDIG,pinfo->IGIValue,pinfo->max_time);				
-				DBG_871X("chan_%d, noise = %d (dBm)\n",pinfo->chan,pHalData->noise[pinfo->chan]);
-				#ifdef DBG_NOISE_MONITOR
-				DBG_871X("noise_a = %d, noise_b = %d  noise_all:%d \n", 
-					podmpriv->noise_level.noise[ODM_RF_PATH_A], 
-					podmpriv->noise_level.noise[ODM_RF_PATH_B],
-					podmpriv->noise_level.noise_all);						
-				#endif
-			}
-			break;
-#endif/*#ifdef CONFIG_BACKGROUND_NOISE_MONITOR*/
+	switch (variable) {
+	case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB: {
+		struct mlme_priv *pmlmepriv;
+		struct sta_priv *pstapriv;
+		struct sta_info *psta;
 
-		case HAL_ODM_INITIAL_GAIN:
-			{
-				u8 rx_gain = *((u8 *)(pValue1));
-				/*printk("rx_gain:%x\n",rx_gain);*/
-				if (rx_gain == 0xff) {/*restore rx gain*/
-					/*ODM_Write_DIG(podmpriv,pDigTable->BackupIGValue);*/
-					odm_PauseDIG(podmpriv, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_0, rx_gain);
-				} else {
-					/*pDigTable->BackupIGValue = pDigTable->CurIGValue;*/
-					/*ODM_Write_DIG(podmpriv,rx_gain);*/
-					odm_PauseDIG(podmpriv, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_0, rx_gain);
-				}
-			}
-			break;		
-		case HAL_ODM_FA_CNT_DUMP:
-			if (*((u8 *)pValue1))
-				podmpriv->DebugComponents |= (ODM_COMP_DIG | ODM_COMP_FA_CNT);
-			else
-				podmpriv->DebugComponents &= ~(ODM_COMP_DIG | ODM_COMP_FA_CNT);
-			break;
-		case HAL_ODM_DBG_FLAG:
-			ODM_CmnInfoUpdate(podmpriv, ODM_CMNINFO_DBG_COMP, *((u8Byte *)pValue1));
-			break;
-		case HAL_ODM_DBG_LEVEL:
-			ODM_CmnInfoUpdate(podmpriv, ODM_CMNINFO_DBG_LEVEL, *((u4Byte *)pValue1));
-			break;
-		case HAL_ODM_RX_INFO_DUMP:
-		{
-			PFALSE_ALARM_STATISTICS FalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure(podmpriv , PHYDM_FALSEALMCNT);
-			pDIG_T	pDM_DigTable = &podmpriv->DM_DigTable;
-
-			DBG_871X("============ Rx Info dump ===================\n");
-			DBG_871X("bLinked = %d, RSSI_Min = %d(%%), CurrentIGI = 0x%x\n",
-				podmpriv->bLinked, podmpriv->RSSI_Min, pDM_DigTable->CurIGValue);			
-			if (FalseAlmCnt)
-				DBG_871X("Cnt_Cck_fail = %d, Cnt_Ofdm_fail = %d, Total False Alarm = %d\n",
-					FalseAlmCnt->Cnt_Cck_fail, FalseAlmCnt->Cnt_Ofdm_fail, FalseAlmCnt->Cnt_all);
-
-			if (podmpriv->bLinked) {
-				DBG_871X("RxRate = %s, RSSI_A = %d(%%), RSSI_B = %d(%%)\n", 
-					HDATA_RATE(podmpriv->RxRate), podmpriv->RSSI_A, podmpriv->RSSI_B);	
-
-				#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
-				rtw_dump_raw_rssi_info(Adapter);
-				#endif
-			}
-		}		
+		pmlmepriv = &adapter->mlmepriv;
+		pstapriv = &adapter->stapriv;
+		psta = rtw_get_stainfo(pstapriv, pmlmepriv->cur_network.network.MacAddress);
+		if (psta)
+			*((int *)value) = psta->cmn.rssi_stat.rssi;
+	}
+	break;
+	case HAL_DEF_DBG_DUMP_RXPKT:
+		*((u8 *)value) = hal_data->bDumpRxPkt;
 		break;
-
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-		case HAL_ODM_AUTO_CHNL_SEL:
-		{
-			ACS_OP	acs_op = *(ACS_OP *)pValue1;
-
-			rtw_phydm_func_set(Adapter, ODM_BB_NHM_CNT);
-
-			if (ACS_INIT == acs_op) {
-				#ifdef DBG_AUTO_CHNL_SEL_NHM
-				DBG_871X("[ACS-"ADPT_FMT"] HAL_ODM_AUTO_CHNL_SEL: ACS_INIT\n", ADPT_ARG(Adapter));
-				#endif
-				odm_AutoChannelSelectInit(podmpriv); 
-			} else if (ACS_RESET == acs_op) {
-				/* Reset statistics for auto channel selection mechanism.*/
-				#ifdef DBG_AUTO_CHNL_SEL_NHM
-				DBG_871X("[ACS-"ADPT_FMT"] HAL_ODM_AUTO_CHNL_SEL: ACS_RESET\n", ADPT_ARG(Adapter));
-				#endif
-				odm_AutoChannelSelectReset(podmpriv);
-				
-			} else if (ACS_SELECT == acs_op) {
-				/* Collect NHM measurement result after current channel */
-				#ifdef DBG_AUTO_CHNL_SEL_NHM
-				DBG_871X("[ACS-"ADPT_FMT"] HAL_ODM_AUTO_CHNL_SEL: ACS_SELECT, CH(%d)\n", ADPT_ARG(Adapter), rtw_get_acs_channel(Adapter));
-				#endif
-				odm_AutoChannelSelect(podmpriv, rtw_get_acs_channel(Adapter));
-			} else 
-				DBG_871X("[ACS-"ADPT_FMT"] HAL_ODM_AUTO_CHNL_SEL: Unexpected OP\n", ADPT_ARG(Adapter));
-
-		}
+	case HAL_DEF_DBG_DUMP_TXPKT:
+		*((u8 *)value) = hal_data->bDumpTxPkt;
 		break;
-#endif
-
-		default:
-			break;
-	}
-}	
-
-void GetHalODMVar(	
-	PADAPTER				Adapter,
-	HAL_ODM_VARIABLE		eVariable,
-	PVOID					pValue1,
-	PVOID					pValue2)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T podmpriv = &pHalData->odmpriv;
-	
-	switch (eVariable) {
-#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-	case HAL_ODM_NOISE_MONITOR:
-		{
-			u8 chan = *(u8 *)pValue1;
-			*(s16 *)pValue2 = pHalData->noise[chan];
-			#ifdef DBG_NOISE_MONITOR
-			DBG_8192C("### Noise monitor chan(%d)-noise:%d (dBm) ###\n",
-				chan, pHalData->noise[chan]);
-			#endif
-		}
+	case HAL_DEF_ANT_DETECT:
+		*((u8 *)value) = hal_data->AntDetection;
 		break;
-#endif/*#ifdef CONFIG_BACKGROUND_NOISE_MONITOR*/
-	case HAL_ODM_DBG_FLAG:
-		*((u8Byte *)pValue1) = podmpriv->DebugComponents;
+	case HAL_DEF_TX_PAGE_SIZE:
+		*((u32 *)value) = _get_page_size(adapter);
 		break;
-	case HAL_ODM_DBG_LEVEL:
-		*((u4Byte *)pValue1) = podmpriv->DebugLevel;
+	case HAL_DEF_EXPLICIT_BEAMFORMER:
+	case HAL_DEF_EXPLICIT_BEAMFORMEE:
+	case HAL_DEF_VHT_MU_BEAMFORMER:
+	case HAL_DEF_VHT_MU_BEAMFORMEE:
+		*(u8 *)value = _FALSE;
 		break;
-
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-	case HAL_ODM_AUTO_CHNL_SEL:
-		{
-			#ifdef DBG_AUTO_CHNL_SEL_NHM
-			DBG_871X("[ACS-"ADPT_FMT"] HAL_ODM_AUTO_CHNL_SEL: GET_BEST_CHAN\n", ADPT_ARG(Adapter));
-			#endif	
-			/* Retrieve better channel from NHM mechanism	*/
-			if (IsSupported24G(Adapter->registrypriv.wireless_mode)) 
-				*((u8 *)(pValue1)) = ODM_GetAutoChannelSelectResult(podmpriv, BAND_ON_2_4G);
-			if (IsSupported5G(Adapter->registrypriv.wireless_mode)) 
-				*((u8 *)(pValue2)) = ODM_GetAutoChannelSelectResult(podmpriv, BAND_ON_5G);
-		}
+#ifdef CONFIG_BEAMFORMING
+	case HAL_DEF_BEAMFORMER_CAP:
+		*(u8 *)value = rtw_hal_query_txbfer_rf_num(adapter);
 		break;
-#endif
-	case HAL_ODM_INITIAL_GAIN:
-		{
-			pDIG_T pDM_DigTable = &podmpriv->DM_DigTable;
-			*((u8 *)pValue1) = pDM_DigTable->CurIGValue;
-		}
+	case HAL_DEF_BEAMFORMEE_CAP:
+		*(u8 *)value = rtw_hal_query_txbfee_rf_num(adapter);
 		break;
+#endif
 	default:
+		RTW_PRINT("%s: [WARNING] HAL_DEF_VARIABLE(%d) not defined!\n", __FUNCTION__, variable);
+		bResult = _FAIL;
 		break;
 	}
-}
 
-
-u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
-	PDM_ODM_T podmpriv = &pHalData->odmpriv;
-	u32 result = 0;
-	
-	switch (ops) {
-	case HAL_PHYDM_DIS_ALL_FUNC:
-		podmpriv->SupportAbility = DYNAMIC_FUNC_DISABLE;
-		break;
-	case HAL_PHYDM_FUNC_SET:
-		podmpriv->SupportAbility |= ability;
-		break;
-	case HAL_PHYDM_FUNC_CLR:
-		podmpriv->SupportAbility &= ~(ability);
-		break;			
-	case HAL_PHYDM_ABILITY_BK:
-		/* dm flag backup*/
-		podmpriv->BK_SupportAbility = podmpriv->SupportAbility;
-		break;
-	case HAL_PHYDM_ABILITY_RESTORE:
-		/* restore dm flag */
-		podmpriv->SupportAbility = podmpriv->BK_SupportAbility;
-		break;
-	case HAL_PHYDM_ABILITY_SET:
-		podmpriv->SupportAbility = ability;
-		break;
-	case HAL_PHYDM_ABILITY_GET:
-		result = podmpriv->SupportAbility;
-		break;
-	}
-	return result;
+	return bResult;
 }
 
 
-BOOLEAN 
+BOOLEAN
 eqNByte(
-	u8*	str1,
-	u8*	str2,
+	u8	*str1,
+	u8	*str2,
 	u32	num
-	)
+)
 {
-	if(num==0)
+	if (num == 0)
 		return _FALSE;
-	while(num>0)
-	{
+	while (num > 0) {
 		num--;
-		if(str1[num]!=str2[num])
+		if (str1[num] != str2[num])
 			return _FALSE;
 	}
 	return _TRUE;
 }
 
-//
-//	Description:
-//		Translate a character to hex digit.
-//
+/*
+ *	Description:
+ *		Translate a character to hex digit.
+ *   */
 u32
 MapCharToHexDigit(
 	IN		char		chTmp
 )
 {
-	if(chTmp >= '0' && chTmp <= '9')
-		return (chTmp - '0');
-	else if(chTmp >= 'a' && chTmp <= 'f')
-		return (10 + (chTmp - 'a'));
-	else if(chTmp >= 'A' && chTmp <= 'F') 
-		return (10 + (chTmp - 'A'));
+	if (chTmp >= '0' && chTmp <= '9')
+		return chTmp - '0';
+	else if (chTmp >= 'a' && chTmp <= 'f')
+		return 10 + (chTmp - 'a');
+	else if (chTmp >= 'A' && chTmp <= 'F')
+		return 10 + (chTmp - 'A');
 	else
-		return 0;	
+		return 0;
 }
 
 
 
-//
-//	Description:
-//		Parse hex number from the string pucStr.
-//
-BOOLEAN 
+/*
+ *	Description:
+ *		Parse hex number from the string pucStr.
+ *   */
+BOOLEAN
 GetHexValueFromString(
-	IN		char*			szStr,
-	IN OUT	u32*			pu4bVal,
-	IN OUT	u32*			pu4bMove
+	IN		char			*szStr,
+	IN OUT	u32			*pu4bVal,
+	IN OUT	u32			*pu4bMove
 )
 {
-	char*		szScan = szStr;
+	char		*szScan = szStr;
 
-	// Check input parameter.
-	if(szStr == NULL || pu4bVal == NULL || pu4bMove == NULL)
-	{
-		DBG_871X("GetHexValueFromString(): Invalid inpur argumetns! szStr: %p, pu4bVal: %p, pu4bMove: %p\n", szStr, pu4bVal, pu4bMove);
+	/* Check input parameter. */
+	if (szStr == NULL || pu4bVal == NULL || pu4bMove == NULL) {
+		RTW_INFO("GetHexValueFromString(): Invalid inpur argumetns! szStr: %p, pu4bVal: %p, pu4bMove: %p\n", szStr, pu4bVal, pu4bMove);
 		return _FALSE;
 	}
 
-	// Initialize output.
+	/* Initialize output. */
 	*pu4bMove = 0;
 	*pu4bVal = 0;
 
-	// Skip leading space.
-	while(	*szScan != '\0' && 
-			(*szScan == ' ' || *szScan == '\t') )
-	{
+	/* Skip leading space. */
+	while (*szScan != '\0' &&
+	       (*szScan == ' ' || *szScan == '\t')) {
 		szScan++;
 		(*pu4bMove)++;
 	}
 
-	// Skip leading '0x' or '0X'.
-	if(*szScan == '0' && (*(szScan+1) == 'x' || *(szScan+1) == 'X'))
-	{
+	/* Skip leading '0x' or '0X'. */
+	if (*szScan == '0' && (*(szScan + 1) == 'x' || *(szScan + 1) == 'X')) {
 		szScan += 2;
 		(*pu4bMove) += 2;
-	}	
+	}
 
-	// Check if szScan is now pointer to a character for hex digit, 
-	// if not, it means this is not a valid hex number.
-	if(!IsHexDigit(*szScan))
-	{
+	/* Check if szScan is now pointer to a character for hex digit, */
+	/* if not, it means this is not a valid hex number. */
+	if (!IsHexDigit(*szScan))
 		return _FALSE;
-	}
 
-	// Parse each digit.
-	do
-	{
+	/* Parse each digit. */
+	do {
 		(*pu4bVal) <<= 4;
 		*pu4bVal += MapCharToHexDigit(*szScan);
 
 		szScan++;
 		(*pu4bMove)++;
-	} while(IsHexDigit(*szScan));
+	} while (IsHexDigit(*szScan));
 
 	return _TRUE;
 }
 
-BOOLEAN 
+BOOLEAN
 GetFractionValueFromString(
-	IN		char*			szStr,
-	IN OUT	u8*				pInteger,
-	IN OUT	u8*				pFraction,
-	IN OUT	u32*			pu4bMove
+	IN		char			*szStr,
+	IN OUT	u8				*pInteger,
+	IN OUT	u8				*pFraction,
+	IN OUT	u32			*pu4bMove
 )
 {
 	char	*szScan = szStr;
 
-	// Initialize output.
+	/* Initialize output. */
 	*pu4bMove = 0;
 	*pInteger = 0;
 	*pFraction = 0;
 
-	// Skip leading space.
-	while (	*szScan != '\0' && 	(*szScan == ' ' || *szScan == '\t') ) {
+	/* Skip leading space. */
+	while (*szScan != '\0' &&	(*szScan == ' ' || *szScan == '\t')) {
 		++szScan;
 		++(*pu4bMove);
 	}
 
-	// Parse each digit.
+	/* Parse each digit. */
 	do {
 		(*pInteger) *= 10;
-		*pInteger += ( *szScan - '0' );
+		*pInteger += (*szScan - '0');
 
 		++szScan;
 		++(*pu4bMove);
 
-		if ( *szScan == '.' ) 
-		{
+		if (*szScan == '.') {
 			++szScan;
 			++(*pu4bMove);
-			
-			if ( *szScan < '0' || *szScan > '9' )
+
+			if (*szScan < '0' || *szScan > '9')
 				return _FALSE;
 			else {
 				*pFraction = *szScan - '0';
@@ -6892,67 +10682,58 @@ GetFractionValueFromString(
 				return _TRUE;
 			}
 		}
-	} while(*szScan >= '0' && *szScan <= '9');
+	} while (*szScan >= '0' && *szScan <= '9');
 
 	return _TRUE;
 }
 
-//
-//	Description:
-//		Return TRUE if szStr is comment out with leading "//".
-//
+/*
+ *	Description:
+ * Return TRUE if szStr is comment out with leading " */ /* ".
+ *   */
 BOOLEAN
 IsCommentString(
 	IN		char			*szStr
 )
 {
-	if(*szStr == '/' && *(szStr+1) == '/')
-	{
+	if (*szStr == '/' && *(szStr + 1) == '/')
 		return _TRUE;
-	}
 	else
-	{
 		return _FALSE;
-	}
 }
 
 BOOLEAN
 GetU1ByteIntegerFromStringInDecimal(
-	IN		char*	Str,
-	IN OUT	u8*		pInt
-	)
+	IN		char	*Str,
+	IN OUT	u8		*pInt
+)
 {
 	u16 i = 0;
 	*pInt = 0;
 
-	while ( Str[i] != '\0' )
-	{
-		if ( Str[i] >= '0' && Str[i] <= '9' )
-		{
+	while (Str[i] != '\0') {
+		if (Str[i] >= '0' && Str[i] <= '9') {
 			*pInt *= 10;
-			*pInt += ( Str[i] - '0' );
-		}
-		else
-		{
+			*pInt += (Str[i] - '0');
+		} else
 			return _FALSE;
-		}
 		++i;
 	}
 
 	return _TRUE;
 }
 
-// <20121004, Kordan> For example, 
-// ParseQualifiedString(inString, 0, outString, '[', ']') gets "Kordan" from a string "Hello [Kordan]".
-// If RightQualifier does not exist, it will hang on in the while loop
-BOOLEAN 
+/* <20121004, Kordan> For example,
+ * ParseQualifiedString(inString, 0, outString, '[', ']') gets "Kordan" from a string "Hello [Kordan]".
+ * If RightQualifier does not exist, it will hang on in the while loop */
+BOOLEAN
 ParseQualifiedString(
-    IN		char*	In, 
-    IN OUT	u32*	Start, 
-    OUT		char*	Out, 
-    IN		char		LeftQualifier, 
-    IN		char		RightQualifier
-    )
+	IN		char	*In,
+	IN OUT	u32	*Start,
+	OUT		char	*Out,
+	IN		char		LeftQualifier,
+	IN		char		RightQualifier
+)
 {
 	u32	i = 0, j = 0;
 	char	c = In[(*Start)++];
@@ -6961,25 +10742,29 @@ ParseQualifiedString(
 		return _FALSE;
 
 	i = (*Start);
-	while ((c = In[(*Start)++]) != RightQualifier) 
-		; // find ']'
+	c = In[(*Start)++];
+	while (c != RightQualifier && c != '\0')
+		c = In[(*Start)++];
+
+	if (c == '\0')
+		return _FALSE;
+
 	j = (*Start) - 2;
-	strncpy((char *)Out, (const char*)(In+i), j-i+1);
+	strncpy((char *)Out, (const char *)(In + i), j - i + 1);
 
 	return _TRUE;
 }
 
 BOOLEAN
 isAllSpaceOrTab(
-	u8*	data,
+	u8	*data,
 	u8	size
-	)
+)
 {
 	u8	cnt = 0, NumOfSpaceAndTab = 0;
 
-	while( size > cnt )
-	{
-		if ( data[cnt] == ' ' || data[cnt] == '\t' || data[cnt] == '\0' )
+	while (size > cnt) {
+		if (data[cnt] == ' ' || data[cnt] == '\t' || data[cnt] == '\0')
 			++NumOfSpaceAndTab;
 
 		++cnt;
@@ -6993,190 +10778,259 @@ void rtw_hal_check_rxfifo_full(_adapter *adapter)
 {
 	struct dvobj_priv *psdpriv = adapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(adapter);
-	int save_cnt=_FALSE;
-	
-	//switch counter to RX fifo
-	if (IS_8188E(pHalData->VersionID) || IS_8188F(pHalData->VersionID)
-		|| IS_8812_SERIES(pHalData->VersionID) || IS_8821_SERIES(pHalData->VersionID)
-		|| IS_8723B_SERIES(pHalData->VersionID) || IS_8192E(pHalData->VersionID) || IS_8703B_SERIES(pHalData->VersionID))
-	{
-		rtw_write8(adapter, REG_RXERR_RPT+3, rtw_read8(adapter, REG_RXERR_RPT+3)|0xa0);
-		save_cnt = _TRUE;
-	}
-	else 
-	{
-		//todo: other chips 
-	}
-	
-		
-	if (save_cnt) {
-		pdbgpriv->dbg_rx_fifo_last_overflow = pdbgpriv->dbg_rx_fifo_curr_overflow;
-		pdbgpriv->dbg_rx_fifo_curr_overflow = rtw_read16(adapter, REG_RXERR_RPT);
-		pdbgpriv->dbg_rx_fifo_diff_overflow = pdbgpriv->dbg_rx_fifo_curr_overflow-pdbgpriv->dbg_rx_fifo_last_overflow;
-	} else {
-		/* special value to indicate no implementation */
-		pdbgpriv->dbg_rx_fifo_last_overflow = 1;
-		pdbgpriv->dbg_rx_fifo_curr_overflow = 1;
-		pdbgpriv->dbg_rx_fifo_diff_overflow = 1;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
+	struct registry_priv *regsty = &adapter->registrypriv;
+	int save_cnt = _FALSE;
+
+	if (regsty->check_hw_status == 1) {
+		/* switch counter to RX fifo */
+		if (IS_8188E(pHalData->version_id) ||
+		    IS_8188F(pHalData->version_id) ||
+		    IS_8188GTV(pHalData->version_id) ||
+		    IS_8812_SERIES(pHalData->version_id) ||
+		    IS_8821_SERIES(pHalData->version_id) ||
+		    IS_8723B_SERIES(pHalData->version_id) ||
+		    IS_8192E(pHalData->version_id) ||
+		    IS_8703B_SERIES(pHalData->version_id) ||
+		    IS_8723D_SERIES(pHalData->version_id)) {
+			rtw_write8(adapter, REG_RXERR_RPT + 3, rtw_read8(adapter, REG_RXERR_RPT + 3) | 0xa0);
+			save_cnt = _TRUE;
+		} else {
+			/* todo: other chips */
+		}
+
+
+		if (save_cnt) {
+			pdbgpriv->dbg_rx_fifo_last_overflow = pdbgpriv->dbg_rx_fifo_curr_overflow;
+			pdbgpriv->dbg_rx_fifo_curr_overflow = rtw_read16(adapter, REG_RXERR_RPT);
+			pdbgpriv->dbg_rx_fifo_diff_overflow = pdbgpriv->dbg_rx_fifo_curr_overflow - pdbgpriv->dbg_rx_fifo_last_overflow;
+		} else {
+			/* special value to indicate no implementation */
+			pdbgpriv->dbg_rx_fifo_last_overflow = 1;
+			pdbgpriv->dbg_rx_fifo_curr_overflow = 1;
+			pdbgpriv->dbg_rx_fifo_diff_overflow = 1;
+		}
 	}
 }
 
-void linked_info_dump(_adapter *padapter,u8 benable)
-{			
+void linked_info_dump(_adapter *padapter, u8 benable)
+{
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 
-	if(padapter->bLinkInfoDump == benable)
+	if (padapter->bLinkInfoDump == benable)
 		return;
-	
-	DBG_871X("%s %s \n",__FUNCTION__,(benable)?"enable":"disable");
-										
-	if(benable){
-		#ifdef CONFIG_LPS
-		pwrctrlpriv->org_power_mgnt = pwrctrlpriv->power_mgnt;//keep org value
-		rtw_pm_set_lps(padapter,PS_MODE_ACTIVE);
-		#endif	
-								
-		#ifdef CONFIG_IPS	
-		pwrctrlpriv->ips_org_mode = pwrctrlpriv->ips_mode;//keep org value
-		rtw_pm_set_ips(padapter,IPS_NONE);
-		#endif	
-	}
-	else{
-		#ifdef CONFIG_IPS		
+
+	RTW_INFO("%s %s\n", __FUNCTION__, (benable) ? "enable" : "disable");
+
+	if (benable) {
+#ifdef CONFIG_LPS
+		pwrctrlpriv->org_power_mgnt = pwrctrlpriv->power_mgnt;/* keep org value */
+		rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
+#endif
+
+#ifdef CONFIG_IPS
+		pwrctrlpriv->ips_org_mode = pwrctrlpriv->ips_mode;/* keep org value */
+		rtw_pm_set_ips(padapter, IPS_NONE);
+#endif
+	} else {
+#ifdef CONFIG_IPS
 		rtw_pm_set_ips(padapter, pwrctrlpriv->ips_org_mode);
-		#endif // CONFIG_IPS
+#endif /* CONFIG_IPS */
 
-		#ifdef CONFIG_LPS	
-		rtw_pm_set_lps(padapter, pwrctrlpriv->org_power_mgnt );
-		#endif // CONFIG_LPS
+#ifdef CONFIG_LPS
+		rtw_pm_set_lps(padapter, pwrctrlpriv->org_power_mgnt);
+#endif /* CONFIG_LPS */
 	}
-	padapter->bLinkInfoDump = benable ;	
+	padapter->bLinkInfoDump = benable ;
 }
 
 #ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
 void rtw_get_raw_rssi_info(void *sel, _adapter *padapter)
 {
-	u8 isCCKrate,rf_path;
+	u8 isCCKrate, rf_path;
 	PHAL_DATA_TYPE	pHalData =  GET_HAL_DATA(padapter);
 	struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
-	
-	DBG_871X_SEL_NL(sel,"RxRate = %s, PWDBALL = %d(%%), rx_pwr_all = %d(dBm)\n", 
-			HDATA_RATE(psample_pkt_rssi->data_rate), psample_pkt_rssi->pwdball, psample_pkt_rssi->pwr_all);
-	isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M)?TRUE :FALSE;
+	RTW_PRINT_SEL(sel, "RxRate = %s, PWDBALL = %d(%%), rx_pwr_all = %d(dBm)\n",
+		HDATA_RATE(psample_pkt_rssi->data_rate), psample_pkt_rssi->pwdball, psample_pkt_rssi->pwr_all);
+	isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
 
-	if(isCCKrate)
+	if (isCCKrate)
 		psample_pkt_rssi->mimo_signal_strength[0] = psample_pkt_rssi->pwdball;
-		
-	for(rf_path = 0;rf_path<pHalData->NumTotalRFPath;rf_path++)
-	{
-		DBG_871X_SEL_NL(sel, "RF_PATH_%d=>signal_strength:%d(%%),signal_quality:%d(%%)\n"
+
+	for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
+		RTW_PRINT_SEL(sel, "RF_PATH_%d=>signal_strength:%d(%%),signal_quality:%d(%%)\n"
 			, rf_path, psample_pkt_rssi->mimo_signal_strength[rf_path], psample_pkt_rssi->mimo_signal_quality[rf_path]);
-		
-		if(!isCCKrate){
-			DBG_871X_SEL_NL(sel,"\trx_ofdm_pwr:%d(dBm),rx_ofdm_snr:%d(dB)\n",
-			psample_pkt_rssi->ofdm_pwr[rf_path],psample_pkt_rssi->ofdm_snr[rf_path]);
+
+		if (!isCCKrate) {
+			RTW_PRINT_SEL(sel, "\trx_ofdm_pwr:%d(dBm),rx_ofdm_snr:%d(dB)\n",
+				psample_pkt_rssi->ofdm_pwr[rf_path], psample_pkt_rssi->ofdm_snr[rf_path]);
 		}
-	}	
+	}
 }
 
-void rtw_dump_raw_rssi_info(_adapter *padapter)
+void rtw_dump_raw_rssi_info(_adapter *padapter, void *sel)
 {
-	u8 isCCKrate,rf_path;
+	u8 isCCKrate, rf_path;
 	PHAL_DATA_TYPE	pHalData =  GET_HAL_DATA(padapter);
 	struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
-	DBG_871X("============ RAW Rx Info dump ===================\n");
-	DBG_871X("RxRate = %s, PWDBALL = %d(%%), rx_pwr_all = %d(dBm)\n", 
-			HDATA_RATE(psample_pkt_rssi->data_rate), psample_pkt_rssi->pwdball, psample_pkt_rssi->pwr_all);	
+	_RTW_PRINT_SEL(sel, "============ RAW Rx Info dump ===================\n");
+	_RTW_PRINT_SEL(sel, "RxRate = %s, PWDBALL = %d(%%), rx_pwr_all = %d(dBm)\n", HDATA_RATE(psample_pkt_rssi->data_rate), psample_pkt_rssi->pwdball, psample_pkt_rssi->pwr_all);
 
-	isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M)?TRUE :FALSE;
+	isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
 
-	if(isCCKrate)
+	if (isCCKrate)
 		psample_pkt_rssi->mimo_signal_strength[0] = psample_pkt_rssi->pwdball;
-		
-	for(rf_path = 0;rf_path<pHalData->NumTotalRFPath;rf_path++)
-	{
-		DBG_871X("RF_PATH_%d=>signal_strength:%d(%%),signal_quality:%d(%%)"
+
+	for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
+		_RTW_PRINT_SEL(sel , "RF_PATH_%d=>signal_strength:%d(%%),signal_quality:%d(%%)"
 			, rf_path, psample_pkt_rssi->mimo_signal_strength[rf_path], psample_pkt_rssi->mimo_signal_quality[rf_path]);
-		
-		if(!isCCKrate){
-			printk(",rx_ofdm_pwr:%d(dBm),rx_ofdm_snr:%d(dB)\n",
-			psample_pkt_rssi->ofdm_pwr[rf_path],psample_pkt_rssi->ofdm_snr[rf_path]);
-		}else{
-			printk("\n");	
-		}
-	}	
+
+		if (!isCCKrate)
+			_RTW_PRINT_SEL(sel , ",rx_ofdm_pwr:%d(dBm),rx_ofdm_snr:%d(dB)\n", psample_pkt_rssi->ofdm_pwr[rf_path], psample_pkt_rssi->ofdm_snr[rf_path]);
+		else
+			_RTW_PRINT_SEL(sel , "\n");
+
+	}
 }
+#endif
 
-void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe)	
+#ifdef DBG_RX_DFRAME_RAW_DATA
+void rtw_dump_rx_dframe_info(_adapter *padapter, void *sel)
 {
-	u8 isCCKrate,rf_path;
+#define DBG_RX_DFRAME_RAW_DATA_UC		0
+#define DBG_RX_DFRAME_RAW_DATA_BMC		1
+#define DBG_RX_DFRAME_RAW_DATA_TYPES	2
+
+	_irqL irqL;
+	u8 isCCKrate, rf_path;
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
 	PHAL_DATA_TYPE	pHalData =  GET_HAL_DATA(padapter);
-	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta;
+	struct sta_recv_dframe_info *psta_dframe_info;
+	int i, j;
+	_list	*plist, *phead;
+	u8 bc_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
 
-	PODM_PHY_INFO_T pPhyInfo  = (PODM_PHY_INFO_T)(&pattrib->phy_info);
-	struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
-	
-	psample_pkt_rssi->data_rate = pattrib->data_rate;
-	isCCKrate = (pattrib->data_rate <= DESC_RATE11M)?TRUE :FALSE;
-	
-	psample_pkt_rssi->pwdball = pPhyInfo->RxPWDBAll;
-	psample_pkt_rssi->pwr_all = pPhyInfo->RecvSignalPower;
-
-	for(rf_path = 0;rf_path<pHalData->NumTotalRFPath;rf_path++)
-	{		
-		psample_pkt_rssi->mimo_signal_strength[rf_path] = pPhyInfo->RxMIMOSignalStrength[rf_path];
-		psample_pkt_rssi->mimo_signal_quality[rf_path] = pPhyInfo->RxMIMOSignalQuality[rf_path];
-		if(!isCCKrate){
-			psample_pkt_rssi->ofdm_pwr[rf_path] = pPhyInfo->RxPwr[rf_path];
-			psample_pkt_rssi->ofdm_snr[rf_path] = pPhyInfo->RxSNR[rf_path];		
+	if (precvpriv->store_law_data_flag) {
+
+		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+		for (i = 0; i < NUM_STA; i++) {
+			phead = &(pstapriv->sta_hash[i]);
+			plist = get_next(phead);
+
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+
+				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+				plist = get_next(plist);
+
+				if (psta) {
+					if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6)  !=   _TRUE)
+					    && (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6)  !=  _TRUE)
+					    && (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), 6)  !=  _TRUE)) {
+
+						RTW_PRINT_SEL(sel, "==============================\n");
+						RTW_PRINT_SEL(sel, "macaddr =" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+
+						for (j = 0; j < DBG_RX_DFRAME_RAW_DATA_TYPES; j++) {
+							if (j == DBG_RX_DFRAME_RAW_DATA_UC) {
+								psta_dframe_info = &psta->sta_dframe_info;
+								RTW_PRINT_SEL(sel, "\n");
+								RTW_PRINT_SEL(sel, "Unicast:\n");
+							} else if (j == DBG_RX_DFRAME_RAW_DATA_BMC) {
+								psta_dframe_info = &psta->sta_dframe_info_bmc;
+								RTW_PRINT_SEL(sel, "\n");
+								RTW_PRINT_SEL(sel, "Broadcast/Multicast:\n");
+							}
+
+							isCCKrate = (psta_dframe_info->sta_data_rate <= DESC_RATE11M) ? TRUE : FALSE;
+
+							RTW_PRINT_SEL(sel, "BW=%s, sgi =%d\n", ch_width_str(psta_dframe_info->sta_bw_mode), psta_dframe_info->sta_sgi);
+							RTW_PRINT_SEL(sel, "Rx_Data_Rate = %s\n", HDATA_RATE(psta_dframe_info->sta_data_rate));
+
+							for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
+								if (!isCCKrate) {
+									RTW_PRINT_SEL(sel , "RF_PATH_%d RSSI:%d(dBm)", rf_path, psta_dframe_info->sta_RxPwr[rf_path]);
+									_RTW_PRINT_SEL(sel , ",rx_ofdm_snr:%d(dB)\n", psta_dframe_info->sta_ofdm_snr[rf_path]);
+								} else
+									RTW_PRINT_SEL(sel , "RF_PATH_%d RSSI:%d(dBm)\n", rf_path, (psta_dframe_info->sta_mimo_signal_strength[rf_path]) - 100);
+							}
+						}
+
+					}
+				}
+			}
 		}
+		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 	}
 }
 #endif
+void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe)
+{
+	u8 isCCKrate, rf_path , dframe_type;
+	u8 *ptr;
+	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+#ifdef DBG_RX_DFRAME_RAW_DATA
+	struct sta_recv_dframe_info *psta_dframe_info;
+#endif
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	PHAL_DATA_TYPE	pHalData =  GET_HAL_DATA(padapter);
+	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
+	struct sta_info *psta = prframe->u.hdr.psta;
+	struct phydm_phyinfo_struct *p_phy_info = &pattrib->phy_info;
+	struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
+	psample_pkt_rssi->data_rate = pattrib->data_rate;
+	ptr = prframe->u.hdr.rx_data;
+	dframe_type = GetFrameType(ptr);
+	/*RTW_INFO("=>%s\n", __FUNCTION__);*/
 
-int check_phy_efuse_tx_power_info_valid(PADAPTER padapter) {
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
-	u8* pContent = pHalData->efuse_eeprom_data;
-	int index = 0;
-	u16 tx_index_offset = 0x0000;
 
-	switch (rtw_get_chip_type(padapter)) {
-		case RTL8723B:
-			tx_index_offset = EEPROM_TX_PWR_INX_8723B;
-		break;
-		case RTL8703B:
-			tx_index_offset = EEPROM_TX_PWR_INX_8703B;
-		break;
-		case RTL8188E:
-			tx_index_offset = EEPROM_TX_PWR_INX_88E;
-		break;
-		case RTL8188F:
-			tx_index_offset = EEPROM_TX_PWR_INX_8188F;
-		break;
-		case RTL8192E:
-			tx_index_offset = EEPROM_TX_PWR_INX_8192E;
-		break;
-		case RTL8821:
-			tx_index_offset = EEPROM_TX_PWR_INX_8821;
-		break;
-		case RTL8812:
-			tx_index_offset = EEPROM_TX_PWR_INX_8812;
-		break;
-		case RTL8814A:
-			tx_index_offset = EEPROM_TX_PWR_INX_8814;
-		break;
-		default:
-			tx_index_offset = 0x0010;
-		break;
-	}
+	if (precvpriv->store_law_data_flag) {
+		isCCKrate = (pattrib->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
 
-	/* TODO: chacking length by ICs */
-	for (index = 0 ; index < 11 ; index++) {
-		if (pContent[tx_index_offset + index] == 0xFF)
-			return _FALSE;
+		psample_pkt_rssi->pwdball = p_phy_info->rx_pwdb_all;
+		psample_pkt_rssi->pwr_all = p_phy_info->recv_signal_power;
+
+		for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
+			psample_pkt_rssi->mimo_signal_strength[rf_path] = p_phy_info->rx_mimo_signal_strength[rf_path];
+			psample_pkt_rssi->mimo_signal_quality[rf_path] = p_phy_info->rx_mimo_signal_quality[rf_path];
+			if (!isCCKrate) {
+				psample_pkt_rssi->ofdm_pwr[rf_path] = p_phy_info->rx_pwr[rf_path];
+				psample_pkt_rssi->ofdm_snr[rf_path] = p_phy_info->rx_snr[rf_path];
+			}
+		}
+#ifdef DBG_RX_DFRAME_RAW_DATA
+		if ((dframe_type == WIFI_DATA_TYPE) || (dframe_type == WIFI_QOS_DATA_TYPE) || (padapter->registrypriv.mp_mode == 1)) {
+
+			/*RTW_INFO("=>%s WIFI_DATA_TYPE or WIFI_QOS_DATA_TYPE\n", __FUNCTION__);*/
+			if (psta) {
+				if (IS_MCAST(get_ra(get_recvframe_data(prframe))))
+					psta_dframe_info = &psta->sta_dframe_info_bmc;
+				else
+					psta_dframe_info = &psta->sta_dframe_info;
+				/*RTW_INFO("=>%s psta->cmn.mac_addr="MAC_FMT" !\n",
+					__FUNCTION__, MAC_ARG(psta->cmn.mac_addr));*/
+				if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) != _TRUE) || (padapter->registrypriv.mp_mode == 1)) {
+					psta_dframe_info->sta_data_rate = pattrib->data_rate;
+					psta_dframe_info->sta_sgi = pattrib->sgi;
+					psta_dframe_info->sta_bw_mode = pattrib->bw;
+					for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
+
+						psta_dframe_info->sta_mimo_signal_strength[rf_path] = (p_phy_info->rx_mimo_signal_strength[rf_path]);/*Percentage to dbm*/
+
+						if (!isCCKrate) {
+							psta_dframe_info->sta_ofdm_snr[rf_path] = p_phy_info->rx_snr[rf_path];
+							psta_dframe_info->sta_RxPwr[rf_path] = p_phy_info->rx_pwr[rf_path];
+						}
+					}
+				}
+			}
+		}
+#endif
 	}
-	return _TRUE;
+
 }
 
 int hal_efuse_macaddr_offset(_adapter *adapter)
@@ -7203,8 +11057,19 @@ int hal_efuse_macaddr_offset(_adapter *adapter)
 			addr_offset = EEPROM_MAC_ADDR_8703BU;
 		else if (interface_type == RTW_SDIO)
 			addr_offset = EEPROM_MAC_ADDR_8703BS;
-	break;
+		break;
+#endif
+#ifdef CONFIG_RTL8723D
+	case RTL8723D:
+		if (interface_type == RTW_USB)
+			addr_offset = EEPROM_MAC_ADDR_8723DU;
+		else if (interface_type == RTW_SDIO)
+			addr_offset = EEPROM_MAC_ADDR_8723DS;
+		else if (interface_type == RTW_PCIE)
+			addr_offset = EEPROM_MAC_ADDR_8723DE;
+		break;
 #endif
+
 #ifdef CONFIG_RTL8188E
 	case RTL8188E:
 		if (interface_type == RTW_USB)
@@ -7223,6 +11088,14 @@ int hal_efuse_macaddr_offset(_adapter *adapter)
 			addr_offset = EEPROM_MAC_ADDR_8188FS;
 		break;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		if (interface_type == RTW_USB)
+			addr_offset = EEPROM_MAC_ADDR_8188GTVU;
+		else if (interface_type == RTW_SDIO)
+			addr_offset = EEPROM_MAC_ADDR_8188GTVS;
+		break;
+#endif
 #ifdef CONFIG_RTL8812A
 	case RTL8812:
 		if (interface_type == RTW_USB)
@@ -7259,10 +11132,32 @@ int hal_efuse_macaddr_offset(_adapter *adapter)
 			addr_offset = EEPROM_MAC_ADDR_8814AE;
 		break;
 #endif
+
+#ifdef CONFIG_RTL8822B
+	case RTL8822B:
+		if (interface_type == RTW_USB)
+			addr_offset = EEPROM_MAC_ADDR_8822BU;
+		else if (interface_type == RTW_SDIO)
+			addr_offset = EEPROM_MAC_ADDR_8822BS;
+		else if (interface_type == RTW_PCIE)
+			addr_offset = EEPROM_MAC_ADDR_8822BE;
+		break;
+#endif /* CONFIG_RTL8822B */
+
+#ifdef CONFIG_RTL8821C
+	case RTL8821C:
+		if (interface_type == RTW_USB)
+			addr_offset = EEPROM_MAC_ADDR_8821CU;
+		else if (interface_type == RTW_SDIO)
+			addr_offset = EEPROM_MAC_ADDR_8821CS;
+		else if (interface_type == RTW_PCIE)
+			addr_offset = EEPROM_MAC_ADDR_8821CE;
+		break;
+#endif /* CONFIG_RTL8821C */
 	}
 
 	if (addr_offset == -1) {
-		DBG_871X_LEVEL(_drv_err_, "%s: unknown combination - chip_type:%u, interface:%u\n"
+		RTW_ERR("%s: unknown combination - chip_type:%u, interface:%u\n"
 			, __func__, rtw_get_chip_type(adapter), rtw_get_intf_type(adapter));
 	}
 
@@ -7293,29 +11188,19 @@ void rtw_dump_cur_efuse(PADAPTER padapter)
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&mapsize, _FALSE);
 
 	if (mapsize <= 0 || mapsize > EEPROM_MAX_SIZE) {
-		DBG_871X_LEVEL(_drv_err_, "wrong map size %d\n", mapsize);
+		RTW_ERR("wrong map size %d\n", mapsize);
 		return;
 	}
 
+#ifdef CONFIG_RTW_DEBUG
 	if (hal_data->efuse_file_status == EFUSE_FILE_LOADED)
-		DBG_871X_LEVEL(_drv_always_, "EFUSE FILE\n");
+		RTW_MAP_DUMP_SEL(RTW_DBGDUMP, "EFUSE FILE", hal_data->efuse_eeprom_data, mapsize);
 	else
-		DBG_871X_LEVEL(_drv_always_, "HW EFUSE\n");
-
-#ifdef CONFIG_DEBUG
-	for (i = 0; i < mapsize; i++) {
-		if (i % 16 == 0)
-			DBG_871X_SEL_NL(RTW_DBGDUMP, "0x%03x: ", i);
-
-		DBG_871X_SEL(RTW_DBGDUMP, "%02X%s"
-			, hal_data->efuse_eeprom_data[i]
-			, ((i + 1) % 16 == 0) ? "\n" : (((i + 1) % 8 == 0) ? "    " : " ")
-		);
-	}
-	DBG_871X_SEL(RTW_DBGDUMP, "\n");
+		RTW_MAP_DUMP_SEL(RTW_DBGDUMP, "HW EFUSE", hal_data->efuse_eeprom_data, mapsize);
 #endif
 }
 
+
 #ifdef CONFIG_EFUSE_CONFIG_FILE
 u32 Hal_readPGDataFromConfigFile(PADAPTER padapter)
 {
@@ -7326,9 +11211,9 @@ u32 Hal_readPGDataFromConfigFile(PADAPTER padapter)
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&maplen, _FALSE);
 
 	if (maplen < 256 || maplen > EEPROM_MAX_SIZE) {
-		DBG_871X_LEVEL(_drv_err_, "eFuse length error :%d\n", maplen);
+		RTW_ERR("eFuse length error :%d\n", maplen);
 		return _FALSE;
-	}
+	}	
 
 	ret = rtw_read_efuse_from_file(EFUSE_MAP_PATH, hal_data->efuse_eeprom_data, maplen);
 
@@ -7350,9 +11235,8 @@ u32 Hal_ReadMACAddrFromFile(PADAPTER padapter, u8 *mac_addr)
 	) {
 		hal_data->macaddr_file_status = MACADDR_FILE_LOADED;
 		ret = _SUCCESS;
-	} else {
+	} else
 		hal_data->macaddr_file_status = MACADDR_FILE_FAILED;
-	}
 
 	return ret;
 }
@@ -7365,6 +11249,9 @@ int hal_config_macaddr(_adapter *adapter, bool autoload_fail)
 	int addr_offset = hal_efuse_macaddr_offset(adapter);
 	u8 *hw_addr = NULL;
 	int ret = _SUCCESS;
+#if defined(CONFIG_RTL8822B) && defined(CONFIG_USB_HCI)
+	u8 ft_mac_addr[ETH_ALEN] = {0x00, 0xff, 0xff, 0xff, 0xff, 0xff}; /* FT USB2 for 8822B */
+#endif
 
 	if (autoload_fail)
 		goto bypass_hw_pg;
@@ -7384,12 +11271,17 @@ int hal_config_macaddr(_adapter *adapter, bool autoload_fail)
 			hw_addr = addr;
 	}
 
+#if defined(CONFIG_RTL8822B) && defined(CONFIG_USB_HCI)
+	if (_rtw_memcmp(hw_addr, ft_mac_addr, ETH_ALEN))
+		hw_addr[0] = 0xff;
+#endif
+
 	/* check hw pg data */
 	if (hw_addr && rtw_check_invalid_mac_address(hw_addr, _TRUE) == _FALSE) {
 		_rtw_memcpy(hal_data->EEPROMMACAddr, hw_addr, ETH_ALEN);
 		goto exit;
 	}
-	
+
 bypass_hw_pg:
 
 #ifdef CONFIG_EFUSE_CONFIG_FILE
@@ -7407,18 +11299,18 @@ exit:
 	return ret;
 }
 
-#ifdef CONFIG_RF_GAIN_OFFSET
-u32 Array_kfreemap[] = { 
-0x08,0xe,
-0x06,0xc,
-0x04,0xa,
-0x02,0x8,
-0x00,0x6,
-0x03,0x4,
-0x05,0x2,
-0x07,0x0,
-0x09,0x0,
-0x0c,0x0,
+#ifdef CONFIG_RF_POWER_TRIM
+u32 Array_kfreemap[] = {
+	0x08, 0xe,
+	0x06, 0xc,
+	0x04, 0xa,
+	0x02, 0x8,
+	0x00, 0x6,
+	0x03, 0x4,
+	0x05, 0x2,
+	0x07, 0x0,
+	0x09, 0x0,
+	0x0c, 0x0,
 };
 
 void rtw_bb_rf_gain_offset(_adapter *padapter)
@@ -7429,96 +11321,91 @@ void rtw_bb_rf_gain_offset(_adapter *padapter)
 	u8		value = pHalData->EEPROMRFGainOffset;
 	u8		tmp = 0x3e;
 	u32		res, i = 0;
-	u4Byte		ArrayLen	= sizeof(Array_kfreemap)/sizeof(u32);
+	u4Byte		ArrayLen	= sizeof(Array_kfreemap) / sizeof(u32);
 	pu4Byte		Array	= Array_kfreemap;
 	u4Byte		v1 = 0, v2 = 0, GainValue = 0, target = 0;
 
-	if (registry_par->RegRfKFreeEnable == 2) {
-		DBG_871X("Registry kfree default force disable.\n");
+	if (registry_par->RegPwrTrimEnable == 2) {
+		RTW_INFO("Registry kfree default force disable.\n");
 		return;
 	}
 
 #if defined(CONFIG_RTL8723B)
-	if (value & BIT4 || (registry_par->RegRfKFreeEnable == 1)) {
-		DBG_871X("Offset RF Gain.\n");
-		DBG_871X("Offset RF Gain.  pHalData->EEPROMRFGainVal=0x%x\n",pHalData->EEPROMRFGainVal);
-		
-		if(pHalData->EEPROMRFGainVal != 0xff){
+	if (value & BIT4 && (registry_par->RegPwrTrimEnable == 1)) {
+		RTW_INFO("Offset RF Gain.\n");
+		RTW_INFO("Offset RF Gain.  pHalData->EEPROMRFGainVal=0x%x\n", pHalData->EEPROMRFGainVal);
 
-			if(pHalData->ant_path == ODM_RF_PATH_A) {
-				GainValue=(pHalData->EEPROMRFGainVal & 0x0f);
-				
-			} else {
-				GainValue=(pHalData->EEPROMRFGainVal & 0xf0)>>4;
-			}
-			DBG_871X("Ant PATH_%d GainValue Offset = 0x%x\n",(pHalData->ant_path == ODM_RF_PATH_A) ? (ODM_RF_PATH_A) : (ODM_RF_PATH_B),GainValue);
-			
-			for (i = 0; i < ArrayLen; i += 2 )
-			{
-				//DBG_871X("ArrayLen in =%d ,Array 1 =0x%x ,Array2 =0x%x \n",i,Array[i],Array[i]+1);
+		if (pHalData->EEPROMRFGainVal != 0xff) {
+
+			if (pHalData->ant_path == RF_PATH_A)
+				GainValue = (pHalData->EEPROMRFGainVal & 0x0f);
+
+			else
+				GainValue = (pHalData->EEPROMRFGainVal & 0xf0) >> 4;
+			RTW_INFO("Ant PATH_%d GainValue Offset = 0x%x\n", (pHalData->ant_path == RF_PATH_A) ? (RF_PATH_A) : (RF_PATH_B), GainValue);
+
+			for (i = 0; i < ArrayLen; i += 2) {
+				/* RTW_INFO("ArrayLen in =%d ,Array 1 =0x%x ,Array2 =0x%x\n",i,Array[i],Array[i]+1); */
 				v1 = Array[i];
-				v2 = Array[i+1];
-				 if ( v1 == GainValue ) {
-						DBG_871X("Offset RF Gain. got v1 =0x%x ,v2 =0x%x \n",v1,v2);
-						target=v2;
-						break;
-				 }
-			}	 
-			DBG_871X("pHalData->EEPROMRFGainVal=0x%x ,Gain offset Target Value=0x%x\n",pHalData->EEPROMRFGainVal,target);
+				v2 = Array[i + 1];
+				if (v1 == GainValue) {
+					RTW_INFO("Offset RF Gain. got v1 =0x%x ,v2 =0x%x\n", v1, v2);
+					target = v2;
+					break;
+				}
+			}
+			RTW_INFO("pHalData->EEPROMRFGainVal=0x%x ,Gain offset Target Value=0x%x\n", pHalData->EEPROMRFGainVal, target);
 
 			res = rtw_hal_read_rfreg(padapter, RF_PATH_A, 0x7f, 0xffffffff);
-			DBG_871X("Offset RF Gain. before reg 0x7f=0x%08x\n",res);
-			PHY_SetRFReg(padapter, RF_PATH_A, REG_RF_BB_GAIN_OFFSET, BIT18|BIT17|BIT16|BIT15, target);
+			RTW_INFO("Offset RF Gain. before reg 0x7f=0x%08x\n", res);
+			phy_set_rf_reg(padapter, RF_PATH_A, REG_RF_BB_GAIN_OFFSET, BIT18 | BIT17 | BIT16 | BIT15, target);
 			res = rtw_hal_read_rfreg(padapter, RF_PATH_A, 0x7f, 0xffffffff);
 
-			DBG_871X("Offset RF Gain. After reg 0x7f=0x%08x\n",res);
-			
-		}else {
+			RTW_INFO("Offset RF Gain. After reg 0x7f=0x%08x\n", res);
 
-			DBG_871X("Offset RF Gain.  pHalData->EEPROMRFGainVal=0x%x	!= 0xff, didn't run Kfree\n",pHalData->EEPROMRFGainVal);
-		}
-	} else {
-		DBG_871X("Using the default RF gain.\n");
-	}
+		} else
+
+			RTW_INFO("Offset RF Gain.  pHalData->EEPROMRFGainVal=0x%x	!= 0xff, didn't run Kfree\n", pHalData->EEPROMRFGainVal);
+	} else
+		RTW_INFO("Using the default RF gain.\n");
 
 #elif defined(CONFIG_RTL8188E)
-	if (value & BIT4 || (registry_par->RegRfKFreeEnable == 1)) {
-		DBG_871X("8188ES Offset RF Gain.\n");
-		DBG_871X("8188ES Offset RF Gain. EEPROMRFGainVal=0x%x\n",
-				pHalData->EEPROMRFGainVal);
+	if (value & BIT4 && (registry_par->RegPwrTrimEnable == 1)) {
+		RTW_INFO("8188ES Offset RF Gain.\n");
+		RTW_INFO("8188ES Offset RF Gain. EEPROMRFGainVal=0x%x\n",
+			 pHalData->EEPROMRFGainVal);
 
 		if (pHalData->EEPROMRFGainVal != 0xff) {
 			res = rtw_hal_read_rfreg(padapter, RF_PATH_A,
-					REG_RF_BB_GAIN_OFFSET, 0xffffffff);
+					 REG_RF_BB_GAIN_OFFSET, 0xffffffff);
 
-			DBG_871X("Offset RF Gain. reg 0x55=0x%x\n",res);
+			RTW_INFO("Offset RF Gain. reg 0x55=0x%x\n", res);
 			res &= 0xfff87fff;
 
 			res |= (pHalData->EEPROMRFGainVal & 0x0f) << 15;
-			DBG_871X("Offset RF Gain. res=0x%x\n",res);
+			RTW_INFO("Offset RF Gain. res=0x%x\n", res);
 
 			rtw_hal_write_rfreg(padapter, RF_PATH_A,
-					REG_RF_BB_GAIN_OFFSET,
-					RF_GAIN_OFFSET_MASK, res);
+					    REG_RF_BB_GAIN_OFFSET,
+					    RF_GAIN_OFFSET_MASK, res);
 		} else {
-			DBG_871X("Offset RF Gain. EEPROMRFGainVal=0x%x == 0xff, didn't run Kfree\n",
-					pHalData->EEPROMRFGainVal);
+			RTW_INFO("Offset RF Gain. EEPROMRFGainVal=0x%x == 0xff, didn't run Kfree\n",
+				 pHalData->EEPROMRFGainVal);
 		}
-	} else {
-		DBG_871X("Using the default RF gain.\n");
-	}
+	} else
+		RTW_INFO("Using the default RF gain.\n");
 #else
 	/* TODO: call this when channel switch */
 	if (kfree_data->flag & KFREE_FLAG_ON)
 		rtw_rf_apply_tx_gain_offset(padapter, 6); /* input ch6 to select BB_GAIN_2G */
 #endif
-	
+
 }
-#endif //CONFIG_RF_GAIN_OFFSET
+#endif /*CONFIG_RF_POWER_TRIM */
 
 bool kfree_data_is_bb_gain_empty(struct kfree_data_t *data)
 {
-#ifdef CONFIG_RF_GAIN_OFFSET
+#ifdef CONFIG_RF_POWER_TRIM
 	int i, j;
 
 	for (i = 0; i < BB_GAIN_NUM; i++)
@@ -7533,75 +11420,68 @@ bool kfree_data_is_bb_gain_empty(struct kfree_data_t *data)
 void rtw_set_usb_agg_by_mode_normal(_adapter *padapter, u8 cur_wireless_mode)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	if(cur_wireless_mode < WIRELESS_11_24N 
-		&& cur_wireless_mode > 0) //ABG mode
-	{
+	if (cur_wireless_mode < WIRELESS_11_24N
+	    && cur_wireless_mode > 0) { /* ABG mode */
 #ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
 		u32 remainder = 0;
 		u8 quotient = 0;
 
-		remainder = MAX_RECVBUF_SZ % (4*1024); 
-		quotient = (u8)(MAX_RECVBUF_SZ >> 12); 
-		
+		remainder = MAX_RECVBUF_SZ % (4 * 1024);
+		quotient = (u8)(MAX_RECVBUF_SZ >> 12);
+
 		if (quotient > 5) {
-			pHalData->RegAcUsbDmaSize = 0x6;
-			pHalData->RegAcUsbDmaTime = 0x10;
+			pHalData->rxagg_usb_size = 0x6;
+			pHalData->rxagg_usb_timeout = 0x10;
 		} else {
 			if (remainder >= 2048) {
-				pHalData->RegAcUsbDmaSize = quotient;
-				pHalData->RegAcUsbDmaTime = 0x10;
+				pHalData->rxagg_usb_size = quotient;
+				pHalData->rxagg_usb_timeout = 0x10;
 			} else {
-				pHalData->RegAcUsbDmaSize = (quotient-1);
-				pHalData->RegAcUsbDmaTime = 0x10;
+				pHalData->rxagg_usb_size = (quotient - 1);
+				pHalData->rxagg_usb_timeout = 0x10;
 			}
 		}
 #else /* !CONFIG_PREALLOC_RX_SKB_BUFFER */
-		if(0x6 != pHalData->RegAcUsbDmaSize || 0x10 !=pHalData->RegAcUsbDmaTime)
-		{
-			pHalData->RegAcUsbDmaSize = 0x6;
-			pHalData->RegAcUsbDmaTime = 0x10;
+		if (0x6 != pHalData->rxagg_usb_size || 0x10 != pHalData->rxagg_usb_timeout) {
+			pHalData->rxagg_usb_size = 0x6;
+			pHalData->rxagg_usb_timeout = 0x10;
 			rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
-				pHalData->RegAcUsbDmaSize | (pHalData->RegAcUsbDmaTime<<8));
+				pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
 		}
 #endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
-					
-	}
-	else if(cur_wireless_mode >= WIRELESS_11_24N
-			&& cur_wireless_mode <= WIRELESS_MODE_MAX)//N AC mode
-	{
+
+	} else if (cur_wireless_mode >= WIRELESS_11_24N
+		   && cur_wireless_mode <= WIRELESS_MODE_MAX) { /* N AC mode */
 #ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
 		u32 remainder = 0;
 		u8 quotient = 0;
 
-		remainder = MAX_RECVBUF_SZ % (4*1024); 
-		quotient = (u8)(MAX_RECVBUF_SZ >> 12); 
-		
+		remainder = MAX_RECVBUF_SZ % (4 * 1024);
+		quotient = (u8)(MAX_RECVBUF_SZ >> 12);
+
 		if (quotient > 5) {
-			pHalData->RegAcUsbDmaSize = 0x5;
-			pHalData->RegAcUsbDmaTime = 0x20;
+			pHalData->rxagg_usb_size = 0x5;
+			pHalData->rxagg_usb_timeout = 0x20;
 		} else {
 			if (remainder >= 2048) {
-				pHalData->RegAcUsbDmaSize = quotient;
-				pHalData->RegAcUsbDmaTime = 0x10;
+				pHalData->rxagg_usb_size = quotient;
+				pHalData->rxagg_usb_timeout = 0x10;
 			} else {
-				pHalData->RegAcUsbDmaSize = (quotient-1);
-				pHalData->RegAcUsbDmaTime = 0x10;
+				pHalData->rxagg_usb_size = (quotient - 1);
+				pHalData->rxagg_usb_timeout = 0x10;
 			}
 		}
 #else /* !CONFIG_PREALLOC_RX_SKB_BUFFER */
-		if(0x5 != pHalData->RegAcUsbDmaSize || 0x20 !=pHalData->RegAcUsbDmaTime)
-		{
-			pHalData->RegAcUsbDmaSize = 0x5;
-			pHalData->RegAcUsbDmaTime = 0x20;
+		if ((0x5 != pHalData->rxagg_usb_size) || (0x20 != pHalData->rxagg_usb_timeout)) {
+			pHalData->rxagg_usb_size = 0x5;
+			pHalData->rxagg_usb_timeout = 0x20;
 			rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
-				pHalData->RegAcUsbDmaSize | (pHalData->RegAcUsbDmaTime<<8));
+				pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
 		}
 #endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
 
-	}
-	else
-	{
-		/* DBG_871X("%s: Unknow wireless mode(0x%x)\n",__func__,padapter->mlmeextpriv.cur_wireless_mode); */
+	} else {
+		/* RTW_INFO("%s: Unknow wireless mode(0x%x)\n",__func__,padapter->mlmeextpriv.cur_wireless_mode); */
 	}
 }
 
@@ -7610,25 +11490,25 @@ void rtw_set_usb_agg_by_mode_customer(_adapter *padapter, u8 cur_wireless_mode,
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
 	if (cur_wireless_mode < WIRELESS_11_24N
-		&& cur_wireless_mode > 0) { /* ABG mode */
-		if (Legacy_UsbDmaSize != pHalData->RegAcUsbDmaSize
-			|| 0x10 != pHalData->RegAcUsbDmaTime) {
-			pHalData->RegAcUsbDmaSize = Legacy_UsbDmaSize;
-			pHalData->RegAcUsbDmaTime = 0x10;
+	    && cur_wireless_mode > 0) { /* ABG mode */
+		if (Legacy_UsbDmaSize != pHalData->rxagg_usb_size
+		    || 0x10 != pHalData->rxagg_usb_timeout) {
+			pHalData->rxagg_usb_size = Legacy_UsbDmaSize;
+			pHalData->rxagg_usb_timeout = 0x10;
 			rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
-				pHalData->RegAcUsbDmaSize | (pHalData->RegAcUsbDmaTime<<8));
+				pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
 		}
 	} else if (cur_wireless_mode >= WIRELESS_11_24N
-				&& cur_wireless_mode <= WIRELESS_MODE_MAX) { /* N AC mode */
-		if (UsbDmaSize != pHalData->RegAcUsbDmaSize
-			|| 0x20 != pHalData->RegAcUsbDmaTime) {
-			pHalData->RegAcUsbDmaSize = UsbDmaSize;
-			pHalData->RegAcUsbDmaTime = 0x20;
+		   && cur_wireless_mode <= WIRELESS_MODE_MAX) { /* N AC mode */
+		if (UsbDmaSize != pHalData->rxagg_usb_size
+		    || 0x20 != pHalData->rxagg_usb_timeout) {
+			pHalData->rxagg_usb_size = UsbDmaSize;
+			pHalData->rxagg_usb_timeout = 0x20;
 			rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
-				pHalData->RegAcUsbDmaSize | (pHalData->RegAcUsbDmaTime<<8));
+				pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
 		}
 	} else {
-		/* DBG_871X("%s: Unknown wireless mode(0x%x)\n",__func__,padapter->mlmeextpriv.cur_wireless_mode); */
+		/* RTW_INFO("%s: Unknown wireless mode(0x%x)\n",__func__,padapter->mlmeextpriv.cur_wireless_mode); */
 	}
 }
 
@@ -7641,77 +11521,84 @@ void rtw_set_usb_agg_by_mode(_adapter *padapter, u8 cur_wireless_mode)
 
 	rtw_set_usb_agg_by_mode_normal(padapter, cur_wireless_mode);
 }
-#endif //CONFIG_USB_RX_AGGREGATION
+#endif /* CONFIG_USB_RX_AGGREGATION */
 
-//To avoid RX affect TX throughput
+/* To avoid RX affect TX throughput */
 void dm_DynamicUsbTxAgg(_adapter *padapter, u8 from_timer)
 {
 	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
 	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeextpriv = &(padapter->mlmeextpriv);
+	struct registry_priv *registry_par = &padapter->registrypriv;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	u8 cur_wireless_mode = pmlmeextpriv->cur_wireless_mode;
-#ifdef CONFIG_CONCURRENT_MODE
-	struct mlme_ext_priv	*pbuddymlmeextpriv = &(padapter->pbuddy_adapter->mlmeextpriv);
-#endif //CONFIG_CONCURRENT_MODE
+	u8 cur_wireless_mode = WIRELESS_INVALID;
 
-#ifdef CONFIG_USB_RX_AGGREGATION	
-	if(IS_HARDWARE_TYPE_8821U(padapter) )//|| IS_HARDWARE_TYPE_8192EU(padapter))
-	{
-		//This AGG_PH_TH only for UsbRxAggMode == USB_RX_AGG_USB
-		if((pHalData->UsbRxAggMode == USB_RX_AGG_USB) && (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE))
-		{
-			if(pdvobjpriv->traffic_stat.cur_tx_tp > 2 && pdvobjpriv->traffic_stat.cur_rx_tp < 30)
+#ifdef CONFIG_USB_RX_AGGREGATION
+	if (!registry_par->dynamic_agg_enable)
+		return;
+
+#ifdef RTW_HALMAC
+	if (IS_HARDWARE_TYPE_8822BU(padapter) || IS_HARDWARE_TYPE_8821CU(padapter))
+		rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, NULL);
+#else /* !RTW_HALMAC */
+	if (IS_HARDWARE_TYPE_8821U(padapter)) { /* || IS_HARDWARE_TYPE_8192EU(padapter)) */
+		/* This AGG_PH_TH only for UsbRxAggMode == USB_RX_AGG_USB */
+		if ((pHalData->rxagg_mode == RX_AGG_USB) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+			if (pdvobjpriv->traffic_stat.cur_tx_tp > 2 && pdvobjpriv->traffic_stat.cur_rx_tp < 30)
 				rtw_write16(padapter , REG_RXDMA_AGG_PG_TH , 0x1010);
 			else if (pdvobjpriv->traffic_stat.last_tx_bytes > 220000 && pdvobjpriv->traffic_stat.cur_rx_tp < 30)
-				rtw_write16(padapter , REG_RXDMA_AGG_PG_TH , 0x1006);			
-			else
-				rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,0x2005); //dmc agg th 20K
-			
-			//DBG_871X("TX_TP=%u, RX_TP=%u \n", pdvobjpriv->traffic_stat.cur_tx_tp, pdvobjpriv->traffic_stat.cur_rx_tp);
-		}
-	}
-	else if(IS_HARDWARE_TYPE_8812(padapter))
-	{
-#ifdef CONFIG_CONCURRENT_MODE
-		if(rtw_linked_check(padapter) == _TRUE && rtw_linked_check(padapter->pbuddy_adapter) == _TRUE)
-		{
-			if(pbuddymlmeextpriv->cur_wireless_mode >= pmlmeextpriv->cur_wireless_mode)
-				cur_wireless_mode = pbuddymlmeextpriv->cur_wireless_mode;
+				rtw_write16(padapter , REG_RXDMA_AGG_PG_TH , 0x1006);
 			else
-				cur_wireless_mode = pmlmeextpriv->cur_wireless_mode;
+				rtw_write16(padapter, REG_RXDMA_AGG_PG_TH, 0x2005); /* dmc agg th 20K */
 
-			rtw_set_usb_agg_by_mode(padapter,cur_wireless_mode);
+			/* RTW_INFO("TX_TP=%u, RX_TP=%u\n", pdvobjpriv->traffic_stat.cur_tx_tp, pdvobjpriv->traffic_stat.cur_rx_tp); */
 		}
-		else if (rtw_linked_check(padapter) == _TRUE && rtw_linked_check(padapter->pbuddy_adapter) == _FALSE)
-		{
-			rtw_set_usb_agg_by_mode(padapter,cur_wireless_mode);
+	} else if (IS_HARDWARE_TYPE_8812(padapter)) {
+#ifdef CONFIG_CONCURRENT_MODE
+		u8 i;
+		_adapter *iface;
+		u8 bassocaed = _FALSE;
+		struct mlme_ext_priv *mlmeext;
+
+		for (i = 0; i < pdvobjpriv->iface_nums; i++) {
+			iface = pdvobjpriv->padapters[i];
+			mlmeext = &iface->mlmeextpriv;
+			if (rtw_linked_check(iface) == _TRUE) {
+				if (mlmeext->cur_wireless_mode >= cur_wireless_mode)
+					cur_wireless_mode = mlmeext->cur_wireless_mode;
+				bassocaed = _TRUE;
+			}
 		}
-#else //!CONFIG_CONCURRENT_MODE
-		rtw_set_usb_agg_by_mode(padapter,cur_wireless_mode);
-#endif //CONFIG_CONCURRENT_MODE
-	}
+		if (bassocaed)
 #endif
+			rtw_set_usb_agg_by_mode(padapter, cur_wireless_mode);
+#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+	} else {
+		rtw_set_usb_agg_by_mode(padapter, cur_wireless_mode);
+#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
+	}
+#endif /* RTW_HALMAC */
+#endif /* CONFIG_USB_RX_AGGREGATION */
+
 }
 
-//bus-agg check for SoftAP mode
-inline u8 rtw_hal_busagg_qsel_check(_adapter *padapter,u8 pre_qsel,u8 next_qsel)
+/* bus-agg check for SoftAP mode */
+inline u8 rtw_hal_busagg_qsel_check(_adapter *padapter, u8 pre_qsel, u8 next_qsel)
 {
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	u8 chk_rst = _SUCCESS;
-	
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+
+	if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
 		return chk_rst;
 
-	//if((pre_qsel == 0xFF)||(next_qsel== 0xFF)) 
-	//	return chk_rst;
-	
-	if(	((pre_qsel == QSLT_HIGH)||((next_qsel== QSLT_HIGH))) 
-			&& (pre_qsel != next_qsel )){
-			//DBG_871X("### bus-agg break cause of qsel misatch, pre_qsel=0x%02x,next_qsel=0x%02x ###\n",
-			//	pre_qsel,next_qsel);
-			chk_rst = _FAIL;
-		}
+	/* if((pre_qsel == 0xFF)||(next_qsel== 0xFF)) */
+	/*	return chk_rst; */
+
+	if (((pre_qsel == QSLT_HIGH) || ((next_qsel == QSLT_HIGH)))
+	    && (pre_qsel != next_qsel)) {
+		/* RTW_INFO("### bus-agg break cause of qsel misatch, pre_qsel=0x%02x,next_qsel=0x%02x ###\n", */
+		/*	pre_qsel,next_qsel); */
+		chk_rst = _FAIL;
+	}
 	return chk_rst;
 }
 
@@ -7722,10 +11609,11 @@ inline u8 rtw_hal_busagg_qsel_check(_adapter *padapter,u8 pre_qsel,u8 next_qsel)
  *
  * Input:
  * adapter: adapter pointer.
- * page_num: The max. page number that user want to dump. 
+ * page_num: The max. page number that user want to dump.
  * page_size: page size of each page. eg. 128 bytes, 256 bytes, 512byte.
  */
-void dump_TX_FIFO(_adapter* padapter, u8 page_num, u16 page_size){
+void dump_TX_FIFO(_adapter *padapter, u8 page_num, u16 page_size)
+{
 
 	int i;
 	u8 val = 0;
@@ -7734,92 +11622,107 @@ void dump_TX_FIFO(_adapter* padapter, u8 page_num, u16 page_size){
 	u32 count = (page_size / 8);
 
 	if (page_num <= 0) {
-		DBG_871X("!!%s: incorrect input page_num paramter!\n", __func__);
+		RTW_INFO("!!%s: incorrect input page_num paramter!\n", __func__);
 		return;
 	}
 
 	if (page_size < 128 || page_size > 512) {
-		DBG_871X("!!%s: incorrect input page_size paramter!\n", __func__);
+		RTW_INFO("!!%s: incorrect input page_size paramter!\n", __func__);
 		return;
 	}
 
-	DBG_871X("+%s+\n", __func__);
+	RTW_INFO("+%s+\n", __func__);
 	val = rtw_read8(padapter, 0x106);
 	rtw_write8(padapter, 0x106, 0x69);
-	DBG_871X("0x106: 0x%02x\n", val);
+	RTW_INFO("0x106: 0x%02x\n", val);
 	base = rtw_read8(padapter, 0x209);
-	DBG_871X("0x209: 0x%02x\n", base);
+	RTW_INFO("0x209: 0x%02x\n", base);
 
-	addr = ((base) * page_size)/8;
-	for (i = 0 ; i < page_num * count ; i+=2) {
+	addr = ((base)*page_size) / 8;
+	for (i = 0 ; i < page_num * count ; i += 2) {
 		rtw_write32(padapter, 0x140, addr + i);
 		printk(" %08x %08x ", rtw_read32(padapter, 0x144), rtw_read32(padapter, 0x148));
 		rtw_write32(padapter, 0x140, addr + i + 1);
-		printk(" %08x %08x \n", rtw_read32(padapter, 0x144), rtw_read32(padapter, 0x148));
+		printk(" %08x %08x\n", rtw_read32(padapter, 0x144), rtw_read32(padapter, 0x148));
 	}
 }
 
 #ifdef CONFIG_GPIO_API
-u8 rtw_hal_get_gpio(_adapter* adapter, u8 gpio_num)
+u8 rtw_hal_get_gpio(_adapter *adapter, u8 gpio_num)
 {
-	u8 value;
-	u8 direction;	
+	u8 value = 0;
+	u8 direction = 0;
+	u32 gpio_pin_input_val = REG_GPIO_PIN_CTRL;
+	u32 gpio_pin_output_val = REG_GPIO_PIN_CTRL + 1;
+	u32 gpio_pin_output_en = REG_GPIO_PIN_CTRL + 2;
+	u8 gpio_num_to_set = gpio_num;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
 
+	if (rtw_hal_gpio_func_check(adapter, gpio_num) == _FAIL)
+		return value;
+
 	rtw_ps_deny(adapter, PS_DENY_IOCTL);
 
-	DBG_871X("rf_pwrstate=0x%02x\n", pwrpriv->rf_pwrstate);
+	RTW_INFO("rf_pwrstate=0x%02x\n", pwrpriv->rf_pwrstate);
 	LeaveAllPowerSaveModeDirect(adapter);
 
+	if (gpio_num > 7) {
+		gpio_pin_input_val = REG_GPIO_PIN_CTRL_2;
+		gpio_pin_output_val = REG_GPIO_PIN_CTRL_2 + 1;
+		gpio_pin_output_en = REG_GPIO_PIN_CTRL_2 + 2;
+		gpio_num_to_set = gpio_num - 8;
+	}
+
 	/* Read GPIO Direction */
-	direction = (rtw_read8(adapter,REG_GPIO_PIN_CTRL + 2) & BIT(gpio_num)) >> gpio_num;
+	direction = (rtw_read8(adapter, gpio_pin_output_en) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
 
 	/* According the direction to read register value */
-	if( direction )
-		value =  (rtw_read8(adapter, REG_GPIO_PIN_CTRL + 1)& BIT(gpio_num)) >> gpio_num;
+	if (direction)
+		value =  (rtw_read8(adapter, gpio_pin_output_val) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
 	else
-		value =  (rtw_read8(adapter, REG_GPIO_PIN_CTRL)& BIT(gpio_num)) >> gpio_num;
+		value =  (rtw_read8(adapter, gpio_pin_input_val) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
 
 	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
-	DBG_871X("%s direction=%d value=%d\n",__FUNCTION__,direction,value);
+	RTW_INFO("%s direction=%d value=%d\n", __FUNCTION__, direction, value);
 
 	return value;
 }
 
-int  rtw_hal_set_gpio_output_value(_adapter* adapter, u8 gpio_num, bool isHigh)
+int  rtw_hal_set_gpio_output_value(_adapter *adapter, u8 gpio_num, bool isHigh)
 {
 	u8 direction = 0;
 	u8 res = -1;
-	if (IS_HARDWARE_TYPE_8188E(adapter)){
-		/* Check GPIO is 4~7 */
-		if( gpio_num > 7 || gpio_num < 4)
-		{
-			DBG_871X("%s The gpio number does not included 4~7.\n",__FUNCTION__);
-			return -1;
-		}
-	}	
-	
+	u32 gpio_pin_output_val = REG_GPIO_PIN_CTRL + 1;
+	u32 gpio_pin_output_en = REG_GPIO_PIN_CTRL + 2;
+	u8 gpio_num_to_set = gpio_num;
+
+	if (rtw_hal_gpio_func_check(adapter, gpio_num) == _FAIL)
+		return -1;
+
 	rtw_ps_deny(adapter, PS_DENY_IOCTL);
 
 	LeaveAllPowerSaveModeDirect(adapter);
 
+	if (gpio_num > 7) {
+		gpio_pin_output_val = REG_GPIO_PIN_CTRL_2 + 1;
+		gpio_pin_output_en = REG_GPIO_PIN_CTRL_2 + 2;
+		gpio_num_to_set = gpio_num - 8;
+	}
+
 	/* Read GPIO direction */
-	direction = (rtw_read8(adapter,REG_GPIO_PIN_CTRL + 2) & BIT(gpio_num)) >> gpio_num;
+	direction = (rtw_read8(adapter, gpio_pin_output_en) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
 
 	/* If GPIO is output direction, setting value. */
-	if( direction )
-	{
-		if(isHigh)
-			rtw_write8(adapter, REG_GPIO_PIN_CTRL + 1, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 1) | BIT(gpio_num));
+	if (direction) {
+		if (isHigh)
+			rtw_write8(adapter, gpio_pin_output_val, rtw_read8(adapter, gpio_pin_output_val) | BIT(gpio_num_to_set));
 		else
-			rtw_write8(adapter, REG_GPIO_PIN_CTRL + 1, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 1) & ~BIT(gpio_num));
+			rtw_write8(adapter, gpio_pin_output_val, rtw_read8(adapter, gpio_pin_output_val) & ~BIT(gpio_num_to_set));
 
-		DBG_871X("%s Set gpio %x[%d]=%d\n",__FUNCTION__,REG_GPIO_PIN_CTRL+1,gpio_num,isHigh );
+		RTW_INFO("%s Set gpio %x[%d]=%d\n", __FUNCTION__, REG_GPIO_PIN_CTRL + 1, gpio_num, isHigh);
 		res = 0;
-	}
-	else
-	{
-		DBG_871X("%s The gpio is input,not be set!\n",__FUNCTION__);
+	} else {
+		RTW_INFO("%s The gpio is input,not be set!\n", __FUNCTION__);
 		res = -1;
 	}
 
@@ -7827,45 +11730,45 @@ int  rtw_hal_set_gpio_output_value(_adapter* adapter, u8 gpio_num, bool isHigh)
 	return res;
 }
 
-int rtw_hal_config_gpio(_adapter* adapter, u8 gpio_num, bool isOutput)
+int rtw_hal_config_gpio(_adapter *adapter, u8 gpio_num, bool isOutput)
 {
-	if (IS_HARDWARE_TYPE_8188E(adapter)){
-		if( gpio_num > 7 || gpio_num < 4)
-		{
-			DBG_871X("%s The gpio number does not included 4~7.\n",__FUNCTION__);
-			return -1;
-		}
-	}	
+	u32 gpio_ctrl_reg_to_set = REG_GPIO_PIN_CTRL + 2;
+	u8 gpio_num_to_set = gpio_num;
+
+	if (rtw_hal_gpio_func_check(adapter, gpio_num) == _FAIL)
+		return -1;
 
-	DBG_871X("%s gpio_num =%d direction=%d\n",__FUNCTION__,gpio_num,isOutput);
+	RTW_INFO("%s gpio_num =%d direction=%d\n", __FUNCTION__, gpio_num, isOutput);
 
 	rtw_ps_deny(adapter, PS_DENY_IOCTL);
 
 	LeaveAllPowerSaveModeDirect(adapter);
 
-	if( isOutput )
-	{
-		rtw_write8(adapter, REG_GPIO_PIN_CTRL + 2, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 2) | BIT(gpio_num));
+	rtw_hal_gpio_multi_func_reset(adapter, gpio_num);
+
+	if (gpio_num > 7) {
+		gpio_ctrl_reg_to_set = REG_GPIO_PIN_CTRL_2 + 2;
+		gpio_num_to_set = gpio_num - 8;
 	}
+
+	if (isOutput)
+		rtw_write8(adapter, gpio_ctrl_reg_to_set, rtw_read8(adapter, gpio_ctrl_reg_to_set) | BIT(gpio_num_to_set));
 	else
-	{
-		rtw_write8(adapter, REG_GPIO_PIN_CTRL + 2, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 2) & ~BIT(gpio_num));
-	}
+		rtw_write8(adapter, gpio_ctrl_reg_to_set, rtw_read8(adapter, gpio_ctrl_reg_to_set) & ~BIT(gpio_num_to_set));
 
 	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
 
 	return 0;
 }
-int rtw_hal_register_gpio_interrupt(_adapter* adapter, int gpio_num, void(*callback)(u8 level))
+int rtw_hal_register_gpio_interrupt(_adapter *adapter, int gpio_num, void(*callback)(u8 level))
 {
 	u8 value;
 	u8 direction;
 	PHAL_DATA_TYPE phal = GET_HAL_DATA(adapter);
 
-	if (IS_HARDWARE_TYPE_8188E(adapter)){	
-		if(gpio_num > 7 || gpio_num < 4)
-		{
-			DBG_871X_LEVEL(_drv_always_, "%s The gpio number does not included 4~7.\n",__FUNCTION__);
+	if (IS_HARDWARE_TYPE_8188E(adapter)) {
+		if (gpio_num > 7 || gpio_num < 4) {
+			RTW_PRINT("%s The gpio number does not included 4~7.\n", __FUNCTION__);
 			return -1;
 		}
 	}
@@ -7875,43 +11778,42 @@ int rtw_hal_register_gpio_interrupt(_adapter* adapter, int gpio_num, void(*callb
 	LeaveAllPowerSaveModeDirect(adapter);
 
 	/* Read GPIO direction */
-	direction = (rtw_read8(adapter,REG_GPIO_PIN_CTRL + 2) & BIT(gpio_num)) >> gpio_num;
-	if(direction){
-		DBG_871X_LEVEL(_drv_always_, "%s Can't register output gpio as interrupt.\n",__FUNCTION__);
+	direction = (rtw_read8(adapter, REG_GPIO_PIN_CTRL + 2) & BIT(gpio_num)) >> gpio_num;
+	if (direction) {
+		RTW_PRINT("%s Can't register output gpio as interrupt.\n", __FUNCTION__);
 		return -1;
 	}
 
 	/* Config GPIO Mode */
-	rtw_write8(adapter, REG_GPIO_PIN_CTRL + 3, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 3) | BIT(gpio_num));	
+	rtw_write8(adapter, REG_GPIO_PIN_CTRL + 3, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 3) | BIT(gpio_num));
 
 	/* Register GPIO interrupt handler*/
 	adapter->gpiointpriv.callback[gpio_num] = callback;
-	
+
 	/* Set GPIO interrupt mode, 0:positive edge, 1:negative edge */
 	value = rtw_read8(adapter, REG_GPIO_PIN_CTRL) & BIT(gpio_num);
-	adapter->gpiointpriv.interrupt_mode = rtw_read8(adapter, REG_HSIMR + 2)^value;
+	adapter->gpiointpriv.interrupt_mode = rtw_read8(adapter, REG_HSIMR + 2) ^ value;
 	rtw_write8(adapter, REG_GPIO_INTM, adapter->gpiointpriv.interrupt_mode);
-	
+
 	/* Enable GPIO interrupt */
 	adapter->gpiointpriv.interrupt_enable_mask = rtw_read8(adapter, REG_HSIMR + 2) | BIT(gpio_num);
 	rtw_write8(adapter, REG_HSIMR + 2, adapter->gpiointpriv.interrupt_enable_mask);
 
 	rtw_hal_update_hisr_hsisr_ind(adapter, 1);
-	
+
 	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
 
 	return 0;
 }
-int rtw_hal_disable_gpio_interrupt(_adapter* adapter, int gpio_num)
+int rtw_hal_disable_gpio_interrupt(_adapter *adapter, int gpio_num)
 {
 	u8 value;
 	u8 direction;
 	PHAL_DATA_TYPE phal = GET_HAL_DATA(adapter);
 
-	if (IS_HARDWARE_TYPE_8188E(adapter)){
-		if(gpio_num > 7 || gpio_num < 4)
-		{
-			DBG_871X("%s The gpio number does not included 4~7.\n",__FUNCTION__);
+	if (IS_HARDWARE_TYPE_8188E(adapter)) {
+		if (gpio_num > 7 || gpio_num < 4) {
+			RTW_INFO("%s The gpio number does not included 4~7.\n", __FUNCTION__);
 			return -1;
 		}
 	}
@@ -7921,393 +11823,359 @@ int rtw_hal_disable_gpio_interrupt(_adapter* adapter, int gpio_num)
 	LeaveAllPowerSaveModeDirect(adapter);
 
 	/* Config GPIO Mode */
-	rtw_write8(adapter, REG_GPIO_PIN_CTRL + 3, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 3) &~ BIT(gpio_num));	
+	rtw_write8(adapter, REG_GPIO_PIN_CTRL + 3, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 3) & ~BIT(gpio_num));
+
+	/* Unregister GPIO interrupt handler*/
+	adapter->gpiointpriv.callback[gpio_num] = NULL;
+
+	/* Reset GPIO interrupt mode, 0:positive edge, 1:negative edge */
+	adapter->gpiointpriv.interrupt_mode = rtw_read8(adapter, REG_GPIO_INTM) & ~BIT(gpio_num);
+	rtw_write8(adapter, REG_GPIO_INTM, 0x00);
+
+	/* Disable GPIO interrupt */
+	adapter->gpiointpriv.interrupt_enable_mask = rtw_read8(adapter, REG_HSIMR + 2) & ~BIT(gpio_num);
+	rtw_write8(adapter, REG_HSIMR + 2, adapter->gpiointpriv.interrupt_enable_mask);
+
+	if (!adapter->gpiointpriv.interrupt_enable_mask)
+		rtw_hal_update_hisr_hsisr_ind(adapter, 0);
+
+	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+
+	return 0;
+}
+#endif
+
+s8 rtw_hal_ch_sw_iqk_info_search(_adapter *padapter, u8 central_chnl, u8 bw_mode)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 i;
+
+	for (i = 0; i < MAX_IQK_INFO_BACKUP_CHNL_NUM; i++) {
+		if ((pHalData->iqk_reg_backup[i].central_chnl != 0)) {
+			if ((pHalData->iqk_reg_backup[i].central_chnl == central_chnl)
+			    && (pHalData->iqk_reg_backup[i].bw_mode == bw_mode))
+				return i;
+		}
+	}
+
+	return -1;
+}
+
+void rtw_hal_ch_sw_iqk_info_backup(_adapter *padapter)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	s8 res;
+	u8 i;
+
+	/* If it's an existed record, overwrite it */
+	res = rtw_hal_ch_sw_iqk_info_search(padapter, pHalData->current_channel, pHalData->current_channel_bw);
+	if ((res >= 0) && (res < MAX_IQK_INFO_BACKUP_CHNL_NUM)) {
+		rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_BACKUP, (u8 *)&(pHalData->iqk_reg_backup[res]));
+		return;
+	}
 
-	/* Unregister GPIO interrupt handler*/
-	adapter->gpiointpriv.callback[gpio_num] = NULL;
+	/* Search for the empty record to use */
+	for (i = 0; i < MAX_IQK_INFO_BACKUP_CHNL_NUM; i++) {
+		if (pHalData->iqk_reg_backup[i].central_chnl == 0) {
+			rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_BACKUP, (u8 *)&(pHalData->iqk_reg_backup[i]));
+			return;
+		}
+	}
 
-	/* Reset GPIO interrupt mode, 0:positive edge, 1:negative edge */
-	adapter->gpiointpriv.interrupt_mode = rtw_read8(adapter, REG_GPIO_INTM) &~ BIT(gpio_num);
-	rtw_write8(adapter, REG_GPIO_INTM, 0x00);
-	
-	/* Disable GPIO interrupt */
-	adapter->gpiointpriv.interrupt_enable_mask = rtw_read8(adapter, REG_HSIMR + 2) &~ BIT(gpio_num);
-	rtw_write8(adapter, REG_HSIMR + 2, adapter->gpiointpriv.interrupt_enable_mask);
+	/* Else, overwrite the oldest record */
+	for (i = 1; i < MAX_IQK_INFO_BACKUP_CHNL_NUM; i++)
+		_rtw_memcpy(&(pHalData->iqk_reg_backup[i - 1]), &(pHalData->iqk_reg_backup[i]), sizeof(struct hal_iqk_reg_backup));
 
-	if(!adapter->gpiointpriv.interrupt_enable_mask)
-		rtw_hal_update_hisr_hsisr_ind(adapter, 0);
-	
-	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+	rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_BACKUP, (u8 *)&(pHalData->iqk_reg_backup[MAX_IQK_INFO_BACKUP_CHNL_NUM - 1]));
+}
 
-	return 0;
+void rtw_hal_ch_sw_iqk_info_restore(_adapter *padapter, u8 ch_sw_use_case)
+{
+	rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_RESTORE, &ch_sw_use_case);
 }
-#endif
 
-void rtw_dump_mac_rx_counters(_adapter* padapter,struct dbg_rx_counter *rx_counter)
+void rtw_dump_mac_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)
 {
-	u32	mac_cck_ok=0, mac_ofdm_ok=0, mac_ht_ok=0, mac_vht_ok=0;
-	u32	mac_cck_err=0, mac_ofdm_err=0, mac_ht_err=0, mac_vht_err=0;
-	u32	mac_cck_fa=0, mac_ofdm_fa=0, mac_ht_fa=0;
-	u32	DropPacket=0;
-	
-	if(!rx_counter){
+	u32	mac_cck_ok = 0, mac_ofdm_ok = 0, mac_ht_ok = 0, mac_vht_ok = 0;
+	u32	mac_cck_err = 0, mac_ofdm_err = 0, mac_ht_err = 0, mac_vht_err = 0;
+	u32	mac_cck_fa = 0, mac_ofdm_fa = 0, mac_ht_fa = 0;
+	u32	DropPacket = 0;
+
+	if (!rx_counter) {
 		rtw_warn_on(1);
 		return;
 	}
-
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x3);
-	mac_cck_ok	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	  
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x0);
-	mac_ofdm_ok	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	 
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x6);
-	mac_ht_ok	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	
-	mac_vht_ok	= 0;	
+	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter))
+		phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x0);/*clear bit-26*/
+
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x3);
+	mac_cck_ok	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]	  */
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x0);
+	mac_ofdm_ok	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]	 */
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x6);
+	mac_ht_ok	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]	 */
+	mac_vht_ok	= 0;
 	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
-		PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x0);
-		PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT26, 0x1);
-		mac_vht_ok	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	 
-	}	
-		
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x4);
-	mac_cck_err	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x1);
-	mac_ofdm_err	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x7);
-	mac_ht_err	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]		
+		phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x0);
+		phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x1);
+		mac_vht_ok	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]*/
+		phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x0);/*clear bit-26*/
+	}
+
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x4);
+	mac_cck_err	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]	 */
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x1);
+	mac_ofdm_err	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]	 */
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x7);
+	mac_ht_err	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]		 */
 	mac_vht_err	= 0;
 	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
-		PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x1);
-		PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT26, 0x1);
-		mac_vht_err	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	 
+		phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x1);
+		phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x1);
+		mac_vht_err	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]*/
+		phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x0);/*clear bit-26*/
 	}
 
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x5);
-	mac_cck_fa	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x2);
-	mac_ofdm_fa	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]	
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT28|BIT29|BIT30|BIT31, 0x9);
-	mac_ht_fa	= PHY_QueryMacReg(padapter, REG_RXERR_RPT, bMaskLWord);// [15:0]		
-	
-	//Mac_DropPacket
-	rtw_write32(padapter, REG_RXERR_RPT, (rtw_read32(padapter, REG_RXERR_RPT)& 0x0FFFFFFF)| Mac_DropPacket);
-	DropPacket = rtw_read32(padapter, REG_RXERR_RPT)& 0x0000FFFF;
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x5);
+	mac_cck_fa	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]	 */
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x2);
+	mac_ofdm_fa	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]	 */
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x9);
+	mac_ht_fa	= phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]		 */
 
-	rx_counter->rx_pkt_ok = mac_cck_ok+mac_ofdm_ok+mac_ht_ok+mac_vht_ok;
-	rx_counter->rx_pkt_crc_error = mac_cck_err+mac_ofdm_err+mac_ht_err+mac_vht_err;
+	/* Mac_DropPacket */
+	rtw_write32(padapter, REG_RXERR_RPT, (rtw_read32(padapter, REG_RXERR_RPT) & 0x0FFFFFFF) | Mac_DropPacket);
+	DropPacket = rtw_read32(padapter, REG_RXERR_RPT) & 0x0000FFFF;
+
+	rx_counter->rx_pkt_ok = mac_cck_ok + mac_ofdm_ok + mac_ht_ok + mac_vht_ok;
+	rx_counter->rx_pkt_crc_error = mac_cck_err + mac_ofdm_err + mac_ht_err + mac_vht_err;
 	rx_counter->rx_cck_fa = mac_cck_fa;
 	rx_counter->rx_ofdm_fa = mac_ofdm_fa;
 	rx_counter->rx_ht_fa = mac_ht_fa;
 	rx_counter->rx_pkt_drop = DropPacket;
 }
-void rtw_reset_mac_rx_counters(_adapter* padapter)
+void rtw_reset_mac_rx_counters(_adapter *padapter)
 {
 
-	if (IS_HARDWARE_TYPE_8703B(padapter) || IS_HARDWARE_TYPE_8188F(padapter))
-		PHY_SetMacReg(padapter, 0x608, BIT19, 0x1); /* If no packet rx, MaxRx clock be gating ,BIT_DISGCLK bit19 set 1 for fix*/	
+	/* If no packet rx, MaxRx clock be gating ,BIT_DISGCLK bit19 set 1 for fix*/
+	if (IS_HARDWARE_TYPE_8703B(padapter) ||
+	    IS_HARDWARE_TYPE_8723D(padapter) ||
+	    IS_HARDWARE_TYPE_8188F(padapter) ||
+	    IS_HARDWARE_TYPE_8188GTV(padapter))
+		phy_set_mac_reg(padapter, REG_RCR, BIT19, 0x1);
 
-	//reset mac counter
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT27, 0x1); 
-	PHY_SetMacReg(padapter, REG_RXERR_RPT, BIT27, 0x0);
+	/* reset mac counter */
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT27, 0x1);
+	phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT27, 0x0);
 }
 
-void rtw_dump_phy_rx_counters(_adapter* padapter,struct dbg_rx_counter *rx_counter)
+void rtw_dump_phy_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)
 {
-	u32 cckok=0,cckcrc=0,ofdmok=0,ofdmcrc=0,htok=0,htcrc=0,OFDM_FA=0,CCK_FA=0,vht_ok=0,vht_err=0;
-	if(!rx_counter){
+	u32 cckok = 0, cckcrc = 0, ofdmok = 0, ofdmcrc = 0, htok = 0, htcrc = 0, OFDM_FA = 0, CCK_FA = 0, vht_ok = 0, vht_err = 0;
+	if (!rx_counter) {
 		rtw_warn_on(1);
 		return;
 	}
-	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)){
-		cckok	= PHY_QueryBBReg(padapter, 0xF04, 0x3FFF);	     // [13:0] 
-		ofdmok	= PHY_QueryBBReg(padapter, 0xF14, 0x3FFF);	     // [13:0] 
-		htok		= PHY_QueryBBReg(padapter, 0xF10, 0x3FFF);     // [13:0]
-		vht_ok	= PHY_QueryBBReg(padapter, 0xF0C, 0x3FFF);     // [13:0]
-		cckcrc	= PHY_QueryBBReg(padapter, 0xF04, 0x3FFF0000); // [29:16]	
-		ofdmcrc	= PHY_QueryBBReg(padapter, 0xF14, 0x3FFF0000); // [29:16]
-		htcrc	= PHY_QueryBBReg(padapter, 0xF10, 0x3FFF0000); // [29:16]
-		vht_err	= PHY_QueryBBReg(padapter, 0xF0C, 0x3FFF0000); // [29:16]
-		CCK_FA	= PHY_QueryBBReg(padapter, 0xA5C, bMaskLWord);
-		OFDM_FA	= PHY_QueryBBReg(padapter, 0xF48, bMaskLWord);
-	} 
-	else
-	{
-		cckok	= PHY_QueryBBReg(padapter, 0xF88, bMaskDWord);
-		ofdmok	= PHY_QueryBBReg(padapter, 0xF94, bMaskLWord);
-		htok		= PHY_QueryBBReg(padapter, 0xF90, bMaskLWord);
+	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
+		cckok	= phy_query_bb_reg(padapter, 0xF04, 0x3FFF);	     /* [13:0] */
+		ofdmok	= phy_query_bb_reg(padapter, 0xF14, 0x3FFF);	     /* [13:0] */
+		htok		= phy_query_bb_reg(padapter, 0xF10, 0x3FFF);     /* [13:0] */
+		vht_ok	= phy_query_bb_reg(padapter, 0xF0C, 0x3FFF);     /* [13:0] */
+		cckcrc	= phy_query_bb_reg(padapter, 0xF04, 0x3FFF0000); /* [29:16]	 */
+		ofdmcrc	= phy_query_bb_reg(padapter, 0xF14, 0x3FFF0000); /* [29:16] */
+		htcrc	= phy_query_bb_reg(padapter, 0xF10, 0x3FFF0000); /* [29:16] */
+		vht_err	= phy_query_bb_reg(padapter, 0xF0C, 0x3FFF0000); /* [29:16] */
+		CCK_FA	= phy_query_bb_reg(padapter, 0xA5C, bMaskLWord);
+		OFDM_FA	= phy_query_bb_reg(padapter, 0xF48, bMaskLWord);
+	} else {
+		cckok	= phy_query_bb_reg(padapter, 0xF88, bMaskDWord);
+		ofdmok	= phy_query_bb_reg(padapter, 0xF94, bMaskLWord);
+		htok		= phy_query_bb_reg(padapter, 0xF90, bMaskLWord);
 		vht_ok	= 0;
-		cckcrc	= PHY_QueryBBReg(padapter, 0xF84, bMaskDWord);
-		ofdmcrc	= PHY_QueryBBReg(padapter, 0xF94, bMaskHWord);
-		htcrc	= PHY_QueryBBReg(padapter, 0xF90, bMaskHWord);
+		cckcrc	= phy_query_bb_reg(padapter, 0xF84, bMaskDWord);
+		ofdmcrc	= phy_query_bb_reg(padapter, 0xF94, bMaskHWord);
+		htcrc	= phy_query_bb_reg(padapter, 0xF90, bMaskHWord);
 		vht_err	= 0;
-		OFDM_FA = PHY_QueryBBReg(padapter, 0xCF0, bMaskLWord) + PHY_QueryBBReg(padapter, 0xCF2, bMaskLWord) +
-			PHY_QueryBBReg(padapter, 0xDA2, bMaskLWord) + PHY_QueryBBReg(padapter, 0xDA4, bMaskLWord) +
-			PHY_QueryBBReg(padapter, 0xDA6, bMaskLWord) + PHY_QueryBBReg(padapter, 0xDA8, bMaskLWord);
-	
-		CCK_FA=(rtw_read8(padapter, 0xA5B )<<8 ) | (rtw_read8(padapter, 0xA5C));
+		OFDM_FA = phy_query_bb_reg(padapter, 0xCF0, bMaskLWord) + phy_query_bb_reg(padapter, 0xCF2, bMaskLWord) +
+			phy_query_bb_reg(padapter, 0xDA2, bMaskLWord) + phy_query_bb_reg(padapter, 0xDA4, bMaskLWord) +
+			phy_query_bb_reg(padapter, 0xDA6, bMaskLWord) + phy_query_bb_reg(padapter, 0xDA8, bMaskLWord);
+
+		CCK_FA = (rtw_read8(padapter, 0xA5B) << 8) | (rtw_read8(padapter, 0xA5C));
 	}
-	
-	rx_counter->rx_pkt_ok = cckok+ofdmok+htok+vht_ok;
-	rx_counter->rx_pkt_crc_error = cckcrc+ofdmcrc+htcrc+vht_err;
+
+	rx_counter->rx_pkt_ok = cckok + ofdmok + htok + vht_ok;
+	rx_counter->rx_pkt_crc_error = cckcrc + ofdmcrc + htcrc + vht_err;
 	rx_counter->rx_ofdm_fa = OFDM_FA;
 	rx_counter->rx_cck_fa = CCK_FA;
-	
+
 }
 
-void rtw_reset_phy_rx_counters(_adapter* padapter)
+void rtw_reset_phy_trx_ok_counters(_adapter *padapter)
 {
-	//reset phy counter
-	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter))
-	{
-		PHY_SetBBReg(padapter, 0xB58, BIT0, 0x1);
-		PHY_SetBBReg(padapter, 0xB58, BIT0, 0x0);
-
-		PHY_SetBBReg(padapter, 0x9A4, BIT17, 0x1);//reset  OFDA FA counter
-		PHY_SetBBReg(padapter, 0x9A4, BIT17, 0x0);
-			
-		PHY_SetBBReg(padapter, 0xA2C, BIT15, 0x0);//reset  CCK FA counter
-		PHY_SetBBReg(padapter, 0xA2C, BIT15, 0x1);
+	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
+		phy_set_bb_reg(padapter, 0xB58, BIT0, 0x1);
+		phy_set_bb_reg(padapter, 0xB58, BIT0, 0x0);
 	}
-	else
-	{
-		PHY_SetBBReg(padapter, 0xF14, BIT16, 0x1);
+}
+void rtw_reset_phy_rx_counters(_adapter *padapter)
+{
+	/* reset phy counter */
+	if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
+		rtw_reset_phy_trx_ok_counters(padapter);
+
+		phy_set_bb_reg(padapter, 0x9A4, BIT17, 0x1);/* reset  OFDA FA counter */
+		phy_set_bb_reg(padapter, 0x9A4, BIT17, 0x0);
+
+		phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x0);/* reset  CCK FA counter */
+		phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x1);
+	} else {
+		phy_set_bb_reg(padapter, 0xF14, BIT16, 0x1);
 		rtw_msleep_os(10);
-		PHY_SetBBReg(padapter, 0xF14, BIT16, 0x0);
-		
-		PHY_SetBBReg(padapter, 0xD00, BIT27, 0x1);//reset  OFDA FA counter
-		PHY_SetBBReg(padapter, 0xC0C, BIT31, 0x1);//reset  OFDA FA counter
-		PHY_SetBBReg(padapter, 0xD00, BIT27, 0x0);
-		PHY_SetBBReg(padapter, 0xC0C, BIT31, 0x0);
-			
-		PHY_SetBBReg(padapter, 0xA2C, BIT15, 0x0);//reset  CCK FA counter
-		PHY_SetBBReg(padapter, 0xA2C, BIT15, 0x1);
+		phy_set_bb_reg(padapter, 0xF14, BIT16, 0x0);
+
+		phy_set_bb_reg(padapter, 0xD00, BIT27, 0x1);/* reset  OFDA FA counter */
+		phy_set_bb_reg(padapter, 0xC0C, BIT31, 0x1);/* reset  OFDA FA counter */
+		phy_set_bb_reg(padapter, 0xD00, BIT27, 0x0);
+		phy_set_bb_reg(padapter, 0xC0C, BIT31, 0x0);
+
+		phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x0);/* reset  CCK FA counter */
+		phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x1);
 	}
 }
 #ifdef DBG_RX_COUNTER_DUMP
-void rtw_dump_drv_rx_counters(_adapter* padapter,struct dbg_rx_counter *rx_counter)
+void rtw_dump_drv_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)
 {
 	struct recv_priv *precvpriv = &padapter->recvpriv;
-	if(!rx_counter){
+	if (!rx_counter) {
 		rtw_warn_on(1);
 		return;
 	}
 	rx_counter->rx_pkt_ok = padapter->drv_rx_cnt_ok;
 	rx_counter->rx_pkt_crc_error = padapter->drv_rx_cnt_crcerror;
-	rx_counter->rx_pkt_drop = precvpriv->rx_drop - padapter->drv_rx_cnt_drop;	
+	rx_counter->rx_pkt_drop = precvpriv->rx_drop - padapter->drv_rx_cnt_drop;
 }
-void rtw_reset_drv_rx_counters(_adapter* padapter)
+void rtw_reset_drv_rx_counters(_adapter *padapter)
 {
 	struct recv_priv *precvpriv = &padapter->recvpriv;
 	padapter->drv_rx_cnt_ok = 0;
 	padapter->drv_rx_cnt_crcerror = 0;
 	padapter->drv_rx_cnt_drop = precvpriv->rx_drop;
 }
-void rtw_dump_phy_rxcnts_preprocess(_adapter* padapter,u8 rx_cnt_mode)
+void rtw_dump_phy_rxcnts_preprocess(_adapter *padapter, u8 rx_cnt_mode)
 {
 	u8 initialgain;
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
-	
-	if((!(padapter->dump_rx_cnt_mode& DUMP_PHY_RX_COUNTER)) && (rx_cnt_mode & DUMP_PHY_RX_COUNTER))
-	{
-		/*initialgain = pDigTable->CurIGValue;*/
+
+	if ((!(padapter->dump_rx_cnt_mode & DUMP_PHY_RX_COUNTER)) && (rx_cnt_mode & DUMP_PHY_RX_COUNTER)) {
 		rtw_hal_get_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, NULL);
-		DBG_871X("%s CurIGValue:0x%02x\n",__FUNCTION__,initialgain);
+		RTW_INFO("%s CurIGValue:0x%02x\n", __FUNCTION__, initialgain);
 		rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);
 		/*disable dynamic functions, such as high power, DIG*/
 		rtw_phydm_ability_backup(padapter);
-		rtw_phydm_func_clr(padapter, (ODM_BB_DIG|ODM_BB_FA_CNT));
-	}
-	else if((padapter->dump_rx_cnt_mode& DUMP_PHY_RX_COUNTER) &&(!(rx_cnt_mode & DUMP_PHY_RX_COUNTER )))
-	{
-		//turn on phy-dynamic functions
+		rtw_phydm_func_clr(padapter, (ODM_BB_DIG | ODM_BB_FA_CNT));
+	} else if ((padapter->dump_rx_cnt_mode & DUMP_PHY_RX_COUNTER) && (!(rx_cnt_mode & DUMP_PHY_RX_COUNTER))) {
+		/* turn on phy-dynamic functions */
 		rtw_phydm_ability_restore(padapter);
-		initialgain = 0xff; //restore RX GAIN
+		initialgain = 0xff; /* restore RX GAIN */
 		rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);
-		
+
 	}
 }
-	
-void rtw_dump_rx_counters(_adapter* padapter)
+
+void rtw_dump_rx_counters(_adapter *padapter)
 {
 	struct dbg_rx_counter rx_counter;
 
-	if( padapter->dump_rx_cnt_mode & DUMP_DRV_RX_COUNTER ){
-		_rtw_memset(&rx_counter,0,sizeof(struct dbg_rx_counter));
-		rtw_dump_drv_rx_counters(padapter,&rx_counter);
-		DBG_871X( "Drv Received packet OK:%d CRC error:%d Drop Packets: %d\n",
-					rx_counter.rx_pkt_ok,rx_counter.rx_pkt_crc_error,rx_counter.rx_pkt_drop);		
-		rtw_reset_drv_rx_counters(padapter);		
-	}
-		
-	if( padapter->dump_rx_cnt_mode & DUMP_MAC_RX_COUNTER ){
-		_rtw_memset(&rx_counter,0,sizeof(struct dbg_rx_counter));
-		rtw_dump_mac_rx_counters(padapter,&rx_counter);
-		DBG_871X( "Mac Received packet OK:%d CRC error:%d FA Counter: %d Drop Packets: %d\n",
-					rx_counter.rx_pkt_ok,rx_counter.rx_pkt_crc_error,
-					rx_counter.rx_cck_fa+rx_counter.rx_ofdm_fa+rx_counter.rx_ht_fa,
-					rx_counter.rx_pkt_drop);			
+	if (padapter->dump_rx_cnt_mode & DUMP_DRV_RX_COUNTER) {
+		_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
+		rtw_dump_drv_rx_counters(padapter, &rx_counter);
+		RTW_INFO("Drv Received packet OK:%d CRC error:%d Drop Packets: %d\n",
+			rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error, rx_counter.rx_pkt_drop);
+		rtw_reset_drv_rx_counters(padapter);
+	}
+
+	if (padapter->dump_rx_cnt_mode & DUMP_MAC_RX_COUNTER) {
+		_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
+		rtw_dump_mac_rx_counters(padapter, &rx_counter);
+		RTW_INFO("Mac Received packet OK:%d CRC error:%d FA Counter: %d Drop Packets: %d\n",
+			 rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error,
+			rx_counter.rx_cck_fa + rx_counter.rx_ofdm_fa + rx_counter.rx_ht_fa,
+			 rx_counter.rx_pkt_drop);
 		rtw_reset_mac_rx_counters(padapter);
 	}
 
-	if(padapter->dump_rx_cnt_mode & DUMP_PHY_RX_COUNTER ){		
-		_rtw_memset(&rx_counter,0,sizeof(struct dbg_rx_counter));		
-		rtw_dump_phy_rx_counters(padapter,&rx_counter);
-		//DBG_871X("%s: OFDM_FA =%d\n", __FUNCTION__, rx_counter.rx_ofdm_fa);
-		//DBG_871X("%s: CCK_FA =%d\n", __FUNCTION__, rx_counter.rx_cck_fa);
-		DBG_871X("Phy Received packet OK:%d CRC error:%d FA Counter: %d\n",rx_counter.rx_pkt_ok,rx_counter.rx_pkt_crc_error,
-		rx_counter.rx_ofdm_fa+rx_counter.rx_cck_fa);
-		rtw_reset_phy_rx_counters(padapter);	
+	if (padapter->dump_rx_cnt_mode & DUMP_PHY_RX_COUNTER) {
+		_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
+		rtw_dump_phy_rx_counters(padapter, &rx_counter);
+		/* RTW_INFO("%s: OFDM_FA =%d\n", __FUNCTION__, rx_counter.rx_ofdm_fa); */
+		/* RTW_INFO("%s: CCK_FA =%d\n", __FUNCTION__, rx_counter.rx_cck_fa); */
+		RTW_INFO("Phy Received packet OK:%d CRC error:%d FA Counter: %d\n", rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error,
+			 rx_counter.rx_ofdm_fa + rx_counter.rx_cck_fa);
+		rtw_reset_phy_rx_counters(padapter);
 	}
 }
 #endif
-void rtw_get_noise(_adapter* padapter)
+u8 rtw_get_current_tx_sgi(_adapter *padapter, struct sta_info *psta)
 {
-#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct noise_info info;
-	if(rtw_linked_check(padapter)){
-		info.bPauseDIG = _TRUE;
-		info.IGIValue = 0x1e;
-		info.max_time = 100;//ms
-		info.chan = pmlmeext->cur_channel ;//rtw_get_oper_ch(padapter);
-		rtw_ps_deny(padapter, PS_DENY_IOCTL);
-		LeaveAllPowerSaveModeDirect(padapter);
-
-		rtw_hal_set_odm_var(padapter, HAL_ODM_NOISE_MONITOR,&info, _FALSE);	
-		//ODM_InbandNoise_Monitor(podmpriv,_TRUE,0x20,100);
-		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
-		rtw_hal_get_odm_var(padapter, HAL_ODM_NOISE_MONITOR,&(info.chan), &(padapter->recvpriv.noise));	
-		#ifdef DBG_NOISE_MONITOR
-		DBG_871X("chan:%d,noise_level:%d\n",info.chan,padapter->recvpriv.noise);
-		#endif
+	u8 curr_tx_sgi = 0;
+	struct ra_sta_info *ra_info;
+
+	if (!psta)
+		return curr_tx_sgi;
+
+	if (padapter->fix_rate == 0xff) {
+		ra_info = &psta->cmn.ra_info;
+		curr_tx_sgi = ((ra_info->curr_tx_rate) & 0x80) >> 7;
+	} else {
+		curr_tx_sgi = ((padapter->fix_rate) & 0x80) >> 7;
 	}
-#endif		
 
+	return curr_tx_sgi;
 }
-
-u8 rtw_get_current_tx_rate(_adapter *padapter, u8 macid)
+u8 rtw_get_current_tx_rate(_adapter *padapter, struct sta_info *psta)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
 	u8 rate_id = 0;
+	struct ra_sta_info *ra_info;
 
-#if (RATE_ADAPTIVE_SUPPORT == 1)
-	rate_id = ODM_RA_GetDecisionRate_8188E(pDM_Odm, macid);
-#else
-	rate_id = (pRA_Table->link_tx_rate[macid]) & 0x7f;
-#endif
+	if (!psta)
+		return rate_id;
 
-	return rate_id;
+	if (padapter->fix_rate == 0xff) {
+		ra_info = &psta->cmn.ra_info;
+		rate_id = ra_info->curr_tx_rate & 0x7f;
+	} else {
+		rate_id = padapter->fix_rate & 0x7f;
+	}
 
+	return rate_id;
 }
 
-#ifdef CONFIG_FW_C2H_DEBUG
-
-/*	C2H RX package original is 128.
-if enable CONFIG_FW_C2H_DEBUG, it should increase to 256.
- C2H FW debug message:
- without aggregate:
- {C2H_CmdID,Seq,SubID,Len,Content[0~n]}
- Content[0~n]={'a','b','c',...,'z','\n'}
- with aggregate:
- {C2H_CmdID,Seq,SubID,Len,Content[0~n]}
- Content[0~n]={'a','b','c',...,'z','\n',Extend C2H pkt 2...}
- Extend C2H pkt 2={C2H CmdID,Seq,SubID,Len,Content = {'a','b','c',...,'z','\n'}}
- Author: Isaac	*/
-
-void Debug_FwC2H(PADAPTER padapter, u8 *pdata, u8 len)
-{
-	int i = 0;
-	int cnt = 0, total_length = 0;
-	u8 buf[128] = {0};
-	u8 more_data = _FALSE;
-	u8 *nextdata = NULL;
-	u8 test = 0;
-
-	u8 data_len;
-	u8 seq_no;
-
-	nextdata = pdata;
-	do {
-		data_len = *(nextdata + 1);
-		seq_no = *(nextdata + 2);
-
-		for (i = 0 ; i < data_len - 2 ; i++) {
-			cnt += sprintf((buf+cnt), "%c", nextdata[3 + i]);
-
-			if (nextdata[3 + i] == 0x0a && nextdata[4 + i] == 0xff)
-				more_data = _TRUE;
-			else if (nextdata[3 + i] == 0x0a && nextdata[4 + i] != 0xff)
-				more_data = _FALSE;
-		}
-
-		DBG_871X("[RTKFW, SEQ=%d]: %s", seq_no, buf);
-		data_len += 3;
-		total_length += data_len;
-
-		if (more_data == _TRUE) {
-			_rtw_memset(buf, '\0', 128);
-			cnt = 0;
-			nextdata = (pdata + total_length);
-		}
-	} while (more_data == _TRUE);
-}
-#endif /*CONFIG_FW_C2H_DEBUG*/
 void update_IOT_info(_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			
-			rtw_phydm_func_clr(padapter, ODM_BB_DYNAMIC_TXPWR);
-			break;
-		case HT_IOT_PEER_REALTEK:
-			//rtw_write16(padapter, 0x4cc, 0xffff);
-			//rtw_write16(padapter, 0x546, 0x01c0);
-			//disable high power			
-			rtw_phydm_func_clr(padapter, ODM_BB_DYNAMIC_TXPWR);
-			break;
-		default:
-			pmlmeinfo->turboMode_cts2self = 0;
-			pmlmeinfo->turboMode_rtsen = 1;
-			break;	
-	}
-	
-}
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-void rtw_acs_start(_adapter *padapter, bool bStart)
-{	
-	if (_TRUE == bStart) {
-		ACS_OP acs_op = ACS_INIT;
-		
-		rtw_hal_set_odm_var(padapter, HAL_ODM_AUTO_CHNL_SEL, &acs_op, _TRUE);
-		rtw_set_acs_channel(padapter, 0);
-		SET_ACS_STATE(padapter, ACS_ENABLE);		
-	} else {		
-		SET_ACS_STATE(padapter, ACS_DISABLE);
-		#ifdef DBG_AUTO_CHNL_SEL_NHM
-		if (1) {
-			u8 best_24g_ch = 0;
-			u8 best_5g_ch = 0;
-			
-			rtw_hal_get_odm_var(padapter, HAL_ODM_AUTO_CHNL_SEL, &(best_24g_ch), &(best_5g_ch));
-			DBG_871X("[ACS-"ADPT_FMT"] Best 2.4G CH:%u\n", ADPT_ARG(padapter), best_24g_ch);
-			DBG_871X("[ACS-"ADPT_FMT"] Best 5G CH:%u\n", ADPT_ARG(padapter), best_5g_ch);
-		}
-		#endif
+
+	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;
+		break;
+	case HT_IOT_PEER_REALTEK:
+		/* rtw_write16(padapter, 0x4cc, 0xffff); */
+		/* rtw_write16(padapter, 0x546, 0x01c0); */
+		break;
+	default:
+		pmlmeinfo->turboMode_cts2self = 0;
+		pmlmeinfo->turboMode_rtsen = 1;
+		break;
 	}
+
 }
-#endif
 
 /* TODO: merge with phydm, see odm_SetCrystalCap() */
 void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap)
@@ -8315,41 +12183,46 @@ void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap)
 	crystal_cap = crystal_cap & 0x3F;
 
 	switch (rtw_get_chip_type(adapter)) {
-#if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F)
+#if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
 	case RTL8188E:
 	case RTL8188F:
+	case RTL8188GTV:
 		/* write 0x24[16:11] = 0x24[22:17] = CrystalCap */
-		PHY_SetBBReg(adapter, REG_AFE_XTAL_CTRL, 0x007FF800, (crystal_cap | (crystal_cap << 6)));
+		phy_set_bb_reg(adapter, REG_AFE_XTAL_CTRL, 0x007FF800, (crystal_cap | (crystal_cap << 6)));
 		break;
 #endif
 #if defined(CONFIG_RTL8812A)
 	case RTL8812:
 		/* write 0x2C[30:25] = 0x2C[24:19] = CrystalCap */
-		PHY_SetBBReg(adapter, REG_MAC_PHY_CTRL, 0x7FF80000, (crystal_cap | (crystal_cap << 6)));
+		phy_set_bb_reg(adapter, REG_MAC_PHY_CTRL, 0x7FF80000, (crystal_cap | (crystal_cap << 6)));
 		break;
 #endif
-#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8192E)
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || \
+		defined(CONFIG_RTL8723D) || defined(CONFIG_RTL8821A) || \
+		defined(CONFIG_RTL8192E)
 	case RTL8723B:
 	case RTL8703B:
+	case RTL8723D:
 	case RTL8821:
 	case RTL8192E:
 		/* write 0x2C[23:18] = 0x2C[17:12] = CrystalCap */
-		PHY_SetBBReg(adapter, REG_MAC_PHY_CTRL, 0x00FFF000, (crystal_cap | (crystal_cap << 6)));
+		phy_set_bb_reg(adapter, REG_MAC_PHY_CTRL, 0x00FFF000, (crystal_cap | (crystal_cap << 6)));
 		break;
 #endif
 #if defined(CONFIG_RTL8814A)
 	case RTL8814A:
 		/* write 0x2C[26:21] = 0x2C[20:15] = CrystalCap*/
-		PHY_SetBBReg(adapter, REG_MAC_PHY_CTRL, 0x07FF8000, (crystal_cap | (crystal_cap << 6)));
+		phy_set_bb_reg(adapter, REG_MAC_PHY_CTRL, 0x07FF8000, (crystal_cap | (crystal_cap << 6)));
 		break;
 #endif
-#if defined(CONFIG_RTL8821B) || defined(CONFIG_RTL8822B)
-	case RTL8821B:
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+
 	case RTL8822B:
+	case RTL8821C:
 		/* write 0x28[6:1] = 0x24[30:25] = CrystalCap */
 		crystal_cap = crystal_cap & 0x3F;
-		PHY_SetBBReg(adapter, REG_AFE_XTAL_CTRL, 0x7E000000, crystal_cap);
-		PHY_SetBBReg(adapter, REG_AFE_PLL_CTRL, 0x7E, crystal_cap);
+		phy_set_bb_reg(adapter, REG_AFE_XTAL_CTRL, 0x7E000000, crystal_cap);
+		phy_set_bb_reg(adapter, REG_AFE_PLL_CTRL, 0x7E, crystal_cap);
 		break;
 #endif
 	default:
@@ -8375,6 +12248,11 @@ int hal_spec_init(_adapter *adapter)
 		init_hal_spec_8703b(adapter);
 		break;
 #endif
+#ifdef CONFIG_RTL8723D
+	case RTL8723D:
+		init_hal_spec_8723d(adapter);
+		break;
+#endif
 #ifdef CONFIG_RTL8188E
 	case RTL8188E:
 		init_hal_spec_8188e(adapter);
@@ -8385,6 +12263,11 @@ int hal_spec_init(_adapter *adapter)
 		init_hal_spec_8188f(adapter);
 		break;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		init_hal_spec_8188gtv(adapter);
+		break;
+#endif
 #ifdef CONFIG_RTL8812A
 	case RTL8812:
 		init_hal_spec_8812a(adapter);
@@ -8404,9 +12287,19 @@ int hal_spec_init(_adapter *adapter)
 	case RTL8814A:
 		init_hal_spec_8814a(adapter);
 		break;
+#endif
+#ifdef CONFIG_RTL8822B
+	case RTL8822B:
+		rtl8822b_init_hal_spec(adapter);
+		break;
+#endif
+#ifdef CONFIG_RTL8821C
+	case RTL8821C:
+		init_hal_spec_rtl8821c(adapter);
+		break;
 #endif
 	default:
-		DBG_871X_LEVEL(_drv_err_, "%s: unknown chip_type:%u\n"
+		RTW_ERR("%s: unknown chip_type:%u\n"
 			, __func__, rtw_get_chip_type(adapter));
 		ret = _FAIL;
 		break;
@@ -8415,12 +12308,12 @@ int hal_spec_init(_adapter *adapter)
 	return ret;
 }
 
-static const char * const _band_cap_str[] = {
+static const char *const _band_cap_str[] = {
 	/* BIT0 */"2G",
 	/* BIT1 */"5G",
 };
 
-static const char * const _bw_cap_str[] = {
+static const char *const _bw_cap_str[] = {
 	/* BIT0 */"5M",
 	/* BIT1 */"10M",
 	/* BIT2 */"20M",
@@ -8430,14 +12323,14 @@ static const char * const _bw_cap_str[] = {
 	/* BIT6 */"80_80M",
 };
 
-static const char * const _proto_cap_str[] = {
+static const char *const _proto_cap_str[] = {
 	/* BIT0 */"b",
 	/* BIT1 */"g",
 	/* BIT2 */"n",
 	/* BIT3 */"ac",
 };
 
-static const char * const _wl_func_str[] = {
+static const char *const _wl_func_str[] = {
 	/* BIT0 */"P2P",
 	/* BIT1 */"MIRACAST",
 	/* BIT2 */"TDLS",
@@ -8449,68 +12342,74 @@ void dump_hal_spec(void *sel, _adapter *adapter)
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	int i;
 
-	DBG_871X_SEL_NL(sel, "macid_num:%u\n", hal_spec->macid_num);
-	DBG_871X_SEL_NL(sel, "sec_cap:0x%02x\n", hal_spec->sec_cap);
-	DBG_871X_SEL_NL(sel, "sec_cam_ent_num:%u\n", hal_spec->sec_cam_ent_num);
-	DBG_871X_SEL_NL(sel, "nss_num:%u\n", hal_spec->nss_num);
+	RTW_PRINT_SEL(sel, "macid_num:%u\n", hal_spec->macid_num);
+	RTW_PRINT_SEL(sel, "sec_cap:0x%02x\n", hal_spec->sec_cap);
+	RTW_PRINT_SEL(sel, "sec_cam_ent_num:%u\n", hal_spec->sec_cam_ent_num);
+	RTW_PRINT_SEL(sel, "rfpath_num_2g:%u\n", hal_spec->rfpath_num_2g);
+	RTW_PRINT_SEL(sel, "rfpath_num_5g:%u\n", hal_spec->rfpath_num_5g);
+	RTW_PRINT_SEL(sel, "max_tx_cnt:%u\n", hal_spec->max_tx_cnt);
+	RTW_PRINT_SEL(sel, "tx_nss_num:%u\n", hal_spec->tx_nss_num);
+	RTW_PRINT_SEL(sel, "rx_nss_num:%u\n", hal_spec->rx_nss_num);
 
-	DBG_871X_SEL_NL(sel, "band_cap:");
+	RTW_PRINT_SEL(sel, "band_cap:");
 	for (i = 0; i < BAND_CAP_BIT_NUM; i++) {
 		if (((hal_spec->band_cap) >> i) & BIT0 && _band_cap_str[i])
-			DBG_871X_SEL(sel, "%s ", _band_cap_str[i]);
+			_RTW_PRINT_SEL(sel, "%s ", _band_cap_str[i]);
 	}
-	DBG_871X_SEL(sel, "\n");
+	_RTW_PRINT_SEL(sel, "\n");
 
-	DBG_871X_SEL_NL(sel, "bw_cap:");
+	RTW_PRINT_SEL(sel, "bw_cap:");
 	for (i = 0; i < BW_CAP_BIT_NUM; i++) {
 		if (((hal_spec->bw_cap) >> i) & BIT0 && _bw_cap_str[i])
-			DBG_871X_SEL(sel, "%s ", _bw_cap_str[i]);
+			_RTW_PRINT_SEL(sel, "%s ", _bw_cap_str[i]);
 	}
-	DBG_871X_SEL(sel, "\n");
+	_RTW_PRINT_SEL(sel, "\n");
 
-	DBG_871X_SEL_NL(sel, "proto_cap:");
+	RTW_PRINT_SEL(sel, "proto_cap:");
 	for (i = 0; i < PROTO_CAP_BIT_NUM; i++) {
 		if (((hal_spec->proto_cap) >> i) & BIT0 && _proto_cap_str[i])
-			DBG_871X_SEL(sel, "%s ", _proto_cap_str[i]);
+			_RTW_PRINT_SEL(sel, "%s ", _proto_cap_str[i]);
 	}
-	DBG_871X_SEL(sel, "\n");
+	_RTW_PRINT_SEL(sel, "\n");
 
-	DBG_871X_SEL_NL(sel, "wl_func:");
+	RTW_PRINT_SEL(sel, "wl_func:");
 	for (i = 0; i < WL_FUNC_BIT_NUM; i++) {
 		if (((hal_spec->wl_func) >> i) & BIT0 && _wl_func_str[i])
-			DBG_871X_SEL(sel, "%s ", _wl_func_str[i]);
+			_RTW_PRINT_SEL(sel, "%s ", _wl_func_str[i]);
 	}
-	DBG_871X_SEL(sel, "\n");
+	_RTW_PRINT_SEL(sel, "\n");
+
+	RTW_PRINT_SEL(sel, "pg_txpwr_saddr:0x%X\n", hal_spec->pg_txpwr_saddr);
 }
 
 inline bool hal_chk_band_cap(_adapter *adapter, u8 cap)
 {
-	return (GET_HAL_SPEC(adapter)->band_cap & cap);
+	return GET_HAL_SPEC(adapter)->band_cap & cap;
 }
 
 inline bool hal_chk_bw_cap(_adapter *adapter, u8 cap)
 {
-	return (GET_HAL_SPEC(adapter)->bw_cap & cap);
+	return GET_HAL_SPEC(adapter)->bw_cap & cap;
 }
 
 inline bool hal_chk_proto_cap(_adapter *adapter, u8 cap)
 {
-	return (GET_HAL_SPEC(adapter)->proto_cap & cap);
+	return GET_HAL_SPEC(adapter)->proto_cap & cap;
 }
 
 inline bool hal_chk_wl_func(_adapter *adapter, u8 func)
 {
-	return (GET_HAL_SPEC(adapter)->wl_func & func);
+	return GET_HAL_SPEC(adapter)->wl_func & func;
 }
 
 inline bool hal_is_band_support(_adapter *adapter, u8 band)
 {
-	return (GET_HAL_SPEC(adapter)->band_cap & band_to_band_cap(band));
+	return GET_HAL_SPEC(adapter)->band_cap & band_to_band_cap(band);
 }
 
 inline bool hal_is_bw_support(_adapter *adapter, u8 bw)
 {
-	return (GET_HAL_SPEC(adapter)->bw_cap & ch_width_to_bw_cap(bw));
+	return GET_HAL_SPEC(adapter)->bw_cap & ch_width_to_bw_cap(bw);
 }
 
 inline bool hal_is_wireless_mode_support(_adapter *adapter, u8 mode)
@@ -8547,9 +12446,9 @@ inline bool hal_is_wireless_mode_support(_adapter *adapter, u8 mode)
 /*
 * hal_largest_bw - starting from in_bw, get largest bw supported by HAL
 * @adapter:
-* @in_bw: starting bw, value of CHANNEL_WIDTH
+* @in_bw: starting bw, value of enum channel_width
 *
-* Returns: value of CHANNEL_WIDTH
+* Returns: value of enum channel_width
 */
 u8 hal_largest_bw(_adapter *adapter, u8 in_bw)
 {
@@ -8564,3 +12463,399 @@ u8 hal_largest_bw(_adapter *adapter, u8 in_bw)
 	return in_bw;
 }
 
+void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf)
+{
+	if (hw_port == HW_PORT0) {
+		/*disable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) & (~EN_BCN_FUNCTION));
+
+		rtw_write32(padapter, REG_TSFTR, tsf);
+		rtw_write32(padapter, REG_TSFTR + 4, tsf >> 32);
+
+		/*enable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) | EN_BCN_FUNCTION);
+	} else if (hw_port == HW_PORT1) {
+		/*disable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) & (~EN_BCN_FUNCTION));
+
+		rtw_write32(padapter, REG_TSFTR1, tsf);
+		rtw_write32(padapter, REG_TSFTR1 + 4, tsf >> 32);
+
+		/*enable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) | EN_BCN_FUNCTION);
+	} else
+		RTW_INFO("%s-[WARN] "ADPT_FMT" invalid hw_port:%d\n", __func__, ADPT_ARG(padapter), hw_port);
+}
+
+void ResumeTxBeacon(_adapter *padapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+#else
+	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
+		rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2) | BIT(6));
+
+#ifdef RTW_HALMAC
+	/* Add this for driver using HALMAC because driver doesn't have setup time init by self */
+	/* TBTT setup time */
+	rtw_write8(padapter, REG_TBTT_PROHIBIT, TBTT_PROHIBIT_SETUP_TIME);
+#endif
+
+	/* TBTT hold time: 0x540[19:8] */
+	rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME & 0xFF);
+	rtw_write8(padapter, REG_TBTT_PROHIBIT + 2,
+		(rtw_read8(padapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME >> 8));
+#endif
+}
+
+void StopTxBeacon(_adapter *padapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+#else
+	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
+		rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2) & (~BIT6));
+
+	/* TBTT hold time: 0x540[19:8] */
+	rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME_STOP_BCN & 0xFF);
+	rtw_write8(padapter, REG_TBTT_PROHIBIT + 2,
+		(rtw_read8(padapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME_STOP_BCN >> 8));
+#endif
+}
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM /*HW port0 - MBSS*/
+void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode)
+{
+	RTW_INFO("%s()-"ADPT_FMT" mode = %d\n", __func__, ADPT_ARG(Adapter), mode);
+
+	rtw_hal_rcr_set_chk_bssid(Adapter, MLME_ACTION_NONE);
+
+	/* disable Port0 TSF update*/
+	rtw_write8(Adapter, REG_BCN_CTRL, rtw_read8(Adapter, REG_BCN_CTRL) | DIS_TSF_UDT);
+
+	/* set net_type */
+	Set_MSR(Adapter, mode);
+
+	if ((mode == _HW_STATE_STATION_) || (mode == _HW_STATE_NOLINK_)) {
+		if (!rtw_mi_get_ap_num(Adapter) && !rtw_mi_get_mesh_num(Adapter))
+			StopTxBeacon(Adapter);
+
+		rtw_write8(Adapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_ATIM);/*disable atim wnd*/
+	} else if (mode == _HW_STATE_ADHOC_) {
+		ResumeTxBeacon(Adapter);
+		rtw_write8(Adapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_BCNQ_SUB);
+
+	} else if (mode == _HW_STATE_AP_) {
+		ResumeTxBeacon(Adapter);
+
+		rtw_write8(Adapter, REG_BCN_CTRL, DIS_TSF_UDT | DIS_BCNQ_SUB);
+
+		/*enable to rx data frame*/
+		rtw_write16(Adapter, REG_RXFLTMAP2, 0xFFFF);
+
+		/*Beacon Control related register for first time*/
+		rtw_write8(Adapter, REG_BCNDMATIM, 0x02); /* 2ms */
+
+		/*rtw_write8(Adapter, REG_BCN_MAX_ERR, 0xFF);*/
+		rtw_write8(Adapter, REG_ATIMWND, 0x0c); /* 12ms */
+		rtw_write16(Adapter, REG_BCNTCFG, 0x00);
+
+		rtw_write16(Adapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
+
+		/*reset TSF*/
+		rtw_write8(Adapter, REG_DUAL_TSF_RST, BIT(0));
+
+		/*enable BCN0 Function for if1*/
+		/*don't enable update TSF0 for if1 (due to TSF update when beacon,probe rsp are received)*/
+		rtw_write8(Adapter, REG_BCN_CTRL, (DIS_TSF_UDT | EN_BCN_FUNCTION | EN_TXBCN_RPT | DIS_BCNQ_SUB));
+		#ifdef CONFIG_BCN_XMIT_PROTECT
+		rtw_write8(Adapter, REG_CCK_CHECK, rtw_read8(Adapter, REG_CCK_CHECK) | BIT_EN_BCN_PKT_REL);
+		#endif
+
+		if (IS_HARDWARE_TYPE_8821(Adapter) || IS_HARDWARE_TYPE_8192E(Adapter))/* select BCN on port 0 for DualBeacon*/
+			rtw_write8(Adapter, REG_CCK_CHECK, rtw_read8(Adapter, REG_CCK_CHECK) & (~BIT_BCN_PORT_SEL));
+
+	}
+
+}
+#endif
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
+u8	rtw_hal_antdiv_before_linked(_adapter *padapter)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 cur_ant, change_ant;
+
+	if (!pHalData->AntDivCfg)
+		return _FALSE;
+
+	if (pHalData->sw_antdiv_bl_state == 0) {
+		pHalData->sw_antdiv_bl_state = 1;
+
+		rtw_hal_get_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &cur_ant, NULL);
+		change_ant = (cur_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+
+		return rtw_antenna_select_cmd(padapter, change_ant, _FALSE);
+	}
+
+	pHalData->sw_antdiv_bl_state = 0;
+	return _FALSE;
+}
+
+void	rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+
+	if (pHalData->AntDivCfg) {
+		/*RTW_INFO("update_network=> org-RSSI(%d), new-RSSI(%d)\n", dst->Rssi, src->Rssi);*/
+		/*select optimum_antenna for before linked =>For antenna diversity*/
+		if (dst->Rssi >=  src->Rssi) {/*keep org parameter*/
+			src->Rssi = dst->Rssi;
+			src->PhyInfo.Optimum_antenna = dst->PhyInfo.Optimum_antenna;
+		}
+	}
+}
+#endif
+
+#ifdef CONFIG_PHY_CAPABILITY_QUERY
+void rtw_dump_phy_cap_by_phydmapi(void *sel, _adapter *adapter)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
+	struct phy_spec_t *phy_spec = &pHalData->phy_spec;
+
+	RTW_PRINT_SEL(sel, "[PHY SPEC] TRx Capability : 0x%08x\n", phy_spec->trx_cap);
+	RTW_PRINT_SEL(sel, "[PHY SPEC] Tx Stream Num Index : %d\n", (phy_spec->trx_cap >> 24) & 0xFF); /*Tx Stream Num Index [31:24]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] Rx Stream Num Index : %d\n", (phy_spec->trx_cap >> 16) & 0xFF); /*Rx Stream Num Index [23:16]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] Tx Path Num Index : %d\n", (phy_spec->trx_cap >> 8) & 0xFF);/*Tx Path Num Index	[15:8]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] Rx Path Num Index : %d\n\n", (phy_spec->trx_cap & 0xFF));/*Rx Path Num Index	[7:0]*/
+
+	RTW_PRINT_SEL(sel, "[PHY SPEC] STBC Capability : 0x%08x\n", phy_spec->stbc_cap);
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT STBC Tx : %s\n", ((phy_spec->stbc_cap >> 24) & 0xFF) ? "Supported" : "N/A"); /*VHT STBC Tx [31:24]*/
+	/*VHT STBC Rx [23:16]
+	0 = not support
+	1 = support for 1 spatial stream
+	2 = support for 1 or 2 spatial streams
+	3 = support for 1 or 2 or 3 spatial streams
+	4 = support for 1 or 2 or 3 or 4 spatial streams*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT STBC Rx :%d\n", ((phy_spec->stbc_cap >> 16) & 0xFF));
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT STBC Tx : %s\n", ((phy_spec->stbc_cap >> 8) & 0xFF) ? "Supported" : "N/A"); /*HT STBC Tx [15:8]*/
+	/*HT STBC Rx [7:0]
+	0 = not support
+	1 = support for 1 spatial stream
+	2 = support for 1 or 2 spatial streams
+	3 = support for 1 or 2 or 3 spatial streams*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT STBC Rx : %d\n\n", (phy_spec->stbc_cap & 0xFF));
+
+	RTW_PRINT_SEL(sel, "[PHY SPEC] LDPC Capability : 0x%08x\n", phy_spec->ldpc_cap);
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT LDPC Tx : %s\n", ((phy_spec->ldpc_cap >> 24) & 0xFF) ? "Supported" : "N/A"); /*VHT LDPC Tx [31:24]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT LDPC Rx : %s\n", ((phy_spec->ldpc_cap >> 16) & 0xFF) ? "Supported" : "N/A"); /*VHT LDPC Rx [23:16]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT LDPC Tx : %s\n", ((phy_spec->ldpc_cap >> 8) & 0xFF) ? "Supported" : "N/A"); /*HT LDPC Tx [15:8]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT LDPC Rx : %s\n\n", (phy_spec->ldpc_cap & 0xFF) ? "Supported" : "N/A"); /*HT LDPC Rx [7:0]*/
+	#ifdef CONFIG_BEAMFORMING
+	RTW_PRINT_SEL(sel, "[PHY SPEC] TxBF Capability : 0x%08x\n", phy_spec->txbf_cap);
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT MU Bfer : %s\n", ((phy_spec->txbf_cap >> 28) & 0xF) ? "Supported" : "N/A"); /*VHT MU Bfer [31:28]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT MU Bfee : %s\n", ((phy_spec->txbf_cap >> 24) & 0xF) ? "Supported" : "N/A"); /*VHT MU Bfee [27:24]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT SU Bfer : %s\n", ((phy_spec->txbf_cap >> 20) & 0xF) ? "Supported" : "N/A"); /*VHT SU Bfer [23:20]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT SU Bfee : %s\n", ((phy_spec->txbf_cap >> 16) & 0xF) ? "Supported" : "N/A"); /*VHT SU Bfee [19:16]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT Bfer : %s\n", ((phy_spec->txbf_cap >> 4) & 0xF)  ? "Supported" : "N/A"); /*HT Bfer [7:4]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT Bfee : %s\n\n", (phy_spec->txbf_cap & 0xF) ? "Supported" : "N/A"); /*HT Bfee [3:0]*/
+
+	RTW_PRINT_SEL(sel, "[PHY SPEC] TxBF parameter : 0x%08x\n", phy_spec->txbf_param);
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT Sounding Dim : %d\n", (phy_spec->txbf_param >> 24) & 0xFF); /*VHT Sounding Dim [31:24]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] VHT Steering Ant : %d\n", (phy_spec->txbf_param >> 16) & 0xFF); /*VHT Steering Ant [23:16]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT Sounding Dim : %d\n", (phy_spec->txbf_param >> 8) & 0xFF); /*HT Sounding Dim [15:8]*/
+	RTW_PRINT_SEL(sel, "[PHY SPEC] HT Steering Ant : %d\n", phy_spec->txbf_param & 0xFF); /*HT Steering Ant [7:0]*/
+	#endif
+}
+#else
+void rtw_dump_phy_cap_by_hal(void *sel, _adapter *adapter)
+{
+	u8 phy_cap = _FALSE;
+
+	/* STBC */
+	rtw_hal_get_def_var(adapter, HAL_DEF_TX_STBC, (u8 *)&phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] STBC Tx : %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+
+	phy_cap = _FALSE;
+	rtw_hal_get_def_var(adapter, HAL_DEF_RX_STBC, (u8 *)&phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] STBC Rx : %s\n\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+
+	/* LDPC support */
+	phy_cap = _FALSE;
+	rtw_hal_get_def_var(adapter, HAL_DEF_TX_LDPC, (u8 *)&phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] LDPC Tx : %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+
+	phy_cap = _FALSE;
+	rtw_hal_get_def_var(adapter, HAL_DEF_RX_LDPC, (u8 *)&phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] LDPC Rx : %s\n\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+	
+	#ifdef CONFIG_BEAMFORMING
+	phy_cap = _FALSE;
+	rtw_hal_get_def_var(adapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] Beamformer: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+
+	phy_cap = _FALSE;
+	rtw_hal_get_def_var(adapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] Beamformee: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+
+	phy_cap = _FALSE;
+	rtw_hal_get_def_var(adapter, HAL_DEF_VHT_MU_BEAMFORMER, &phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] VHT MU Beamformer: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+
+	phy_cap = _FALSE;
+	rtw_hal_get_def_var(adapter, HAL_DEF_VHT_MU_BEAMFORMEE, &phy_cap);
+	RTW_PRINT_SEL(sel, "[HAL] VHT MU Beamformee: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
+	#endif
+}
+#endif
+void rtw_dump_phy_cap(void *sel, _adapter *adapter)
+{
+	RTW_PRINT_SEL(sel, "\n ======== PHY Capability ========\n");
+#ifdef CONFIG_PHY_CAPABILITY_QUERY
+	rtw_dump_phy_cap_by_phydmapi(sel, adapter);
+#else
+	rtw_dump_phy_cap_by_hal(sel, adapter);
+#endif
+}
+
+inline s16 translate_dbm_to_percentage(s16 signal)
+{
+	if ((signal <= -100) || (signal >= 20))
+		return	0;
+	else if (signal >= 0)
+		return	100;
+	else
+		return 100 + signal;
+}
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+#ifdef CONFIG_BCN_RECOVERY
+#define REG_CPU_MGQ_INFO	0x041C
+#define BIT_BCN_POLL			BIT(28)
+u8 rtw_ap_bcn_recovery(_adapter *padapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
+
+	if (hal_data->issue_bcn_fail >= 2) {
+		RTW_ERR("%s ISSUE BCN Fail\n", __func__);
+		rtw_write8(padapter, REG_CPU_MGQ_INFO + 3, 0x10);
+		hal_data->issue_bcn_fail = 0;
+	}
+	return _SUCCESS;
+}
+#endif /*CONFIG_BCN_RECOVERY*/
+
+#ifdef CONFIG_BCN_XMIT_PROTECT
+u8 rtw_ap_bcn_queue_empty_check(_adapter *padapter, u32 txbcn_timer_ms)
+{
+	u32 start_time = rtw_get_current_time();
+	u8 bcn_queue_empty = _FALSE;
+
+	do {
+		if (rtw_read16(padapter, REG_TXPKT_EMPTY) & BIT(11)) {
+			bcn_queue_empty = _TRUE;
+			break;
+		}
+	} while (rtw_get_passing_time_ms(start_time) <= (txbcn_timer_ms + 10));
+
+	if (bcn_queue_empty == _FALSE)
+		RTW_ERR("%s BCN queue not empty\n", __func__);
+
+	return bcn_queue_empty;
+}
+#endif /*CONFIG_BCN_XMIT_PROTECT*/
+#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
+
+static void _rf_type_to_ant_path(enum rf_type rf, enum bb_path *tx,
+				 enum bb_path *rx)
+{
+	if (tx) {
+		switch (rf) {
+		case RF_1T1R:
+		case RF_1T2R:
+			*tx = BB_PATH_A;
+			break;
+		case RF_2T2R:
+		case RF_2T3R:
+		case RF_2T4R:
+			*tx = BB_PATH_AB;
+			break;
+		case RF_3T3R:
+		case RF_3T4R:
+			*tx = BB_PATH_ABC;
+			break;
+		case RF_4T4R:
+		default:
+			*tx = BB_PATH_ABCD;
+			break;
+		}
+	}
+
+	if (rx) {
+		switch (rf) {
+		case RF_1T1R:
+			*rx = BB_PATH_A;
+			break;
+		case RF_1T2R:
+		case RF_2T2R:
+			*rx = BB_PATH_AB;
+			break;
+		case RF_2T3R:
+		case RF_3T3R:
+			*rx = BB_PATH_ABC;
+			break;
+		case RF_2T4R:
+		case RF_3T4R:
+		case RF_4T4R:
+		default:
+			*rx = BB_PATH_ABCD;
+			break;
+		}
+	}
+}
+
+/**
+ * rtw_hal_get_rf_path() - Get RF path related information
+ * @d:		struct dvobj_priv*
+ * @type:	RF type, nTnR
+ * @tx:		Tx path
+ * @rx:		Rx path
+ *
+ * Get RF type, TX path and RX path information.
+ */
+void rtw_hal_get_rf_path(struct dvobj_priv *d, enum rf_type *type,
+			 enum bb_path *tx, enum bb_path *rx)
+{
+	struct _ADAPTER *a;
+	u8 val8 = RF_1T1R;
+	enum rf_type rf;
+
+
+	a = dvobj_get_primary_adapter(d);
+
+	rtw_hal_get_hwreg(a, HW_VAR_RF_TYPE, &val8);
+	rf = (enum rf_type)val8;
+	if (type)
+		*type = rf;
+
+	if (tx || rx)
+		_rf_type_to_ant_path(rf, tx, rx);
+}
+
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+void rtw_hal_switch_chnl_and_set_bw_offload(_adapter *adapter, u8 central_ch, u8 pri_ch_idx, u8 bw)
+{
+	u8 h2c[H2C_SINGLE_CHANNELSWITCH_V2_LEN] = {0};
+	PHAL_DATA_TYPE hal;
+	struct submit_ctx *chsw_sctx;
+
+	hal = GET_HAL_DATA(adapter);
+	chsw_sctx = &hal->chsw_sctx;
+
+	SET_H2CCMD_SINGLE_CH_SWITCH_V2_CENTRAL_CH_NUM(h2c, central_ch);
+	SET_H2CCMD_SINGLE_CH_SWITCH_V2_PRIMARY_CH_IDX(h2c, pri_ch_idx);
+	SET_H2CCMD_SINGLE_CH_SWITCH_V2_BW(h2c, bw);
+
+	rtw_sctx_init(chsw_sctx, 10);
+	rtw_hal_fill_h2c_cmd(adapter, H2C_SINGLE_CHANNELSWITCH_V2, H2C_SINGLE_CHANNELSWITCH_V2_LEN, h2c);
+	rtw_sctx_wait(chsw_sctx, __func__);
+}
+#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_c2h.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_c2h.h
index 8097623dbb56..a12317778da2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_c2h.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_c2h.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,34 +12,69 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __COMMON_C2H_H__
 #define __COMMON_C2H_H__
 
+#define C2H_TYPE_REG 0
+#define C2H_TYPE_PKT 1
+
+/* 
+* C2H event format:
+* Fields    TRIGGER    PAYLOAD    SEQ    PLEN    ID
+* BITS     [127:120]    [119:16]   [15:8]  [7:4]  [3:0]
+*/
+#define C2H_ID(_c2h)		LE_BITS_TO_1BYTE(((u8*)(_c2h)), 0, 4)
+#define C2H_PLEN(_c2h)		LE_BITS_TO_1BYTE(((u8*)(_c2h)), 4, 4)
+#define C2H_SEQ(_c2h)		LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 1, 0, 8)
+#define C2H_PAYLOAD(_c2h)	(((u8*)(_c2h)) + 2)
+
+#define SET_C2H_ID(_c2h, _val)		SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)), 0, 4, _val)
+#define SET_C2H_PLEN(_c2h, _val)	SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)), 4, 4, _val)
+#define SET_C2H_SEQ(_c2h, _val)		SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)) + 1 , 0, 8, _val)
+
+/* 
+* C2H event format:
+* Fields    TRIGGER     PLEN      PAYLOAD    SEQ      ID
+* BITS    [127:120]  [119:112]  [111:16]   [15:8]   [7:0]
+*/
+#define C2H_ID_88XX(_c2h)		LE_BITS_TO_1BYTE(((u8*)(_c2h)), 0, 8)
+#define C2H_SEQ_88XX(_c2h)		LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 1, 0, 8)
+#define C2H_PAYLOAD_88XX(_c2h)	(((u8*)(_c2h)) + 2)
+#define C2H_PLEN_88XX(_c2h)		LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 14, 0, 8)
+#define C2H_TRIGGER_88XX(_c2h)	LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 15, 0, 8)
+
+#define SET_C2H_ID_88XX(_c2h, _val)		SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)), 0, 8, _val)
+#define SET_C2H_SEQ_88XX(_c2h, _val)	SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)) + 1, 0, 8, _val)
+#define SET_C2H_PLEN_88XX(_c2h, _val)	SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)) + 14, 0, 8, _val)
+
 typedef enum _C2H_EVT {
 	C2H_DBG = 0x00,
 	C2H_LB = 0x01,
 	C2H_TXBF = 0x02,
 	C2H_CCX_TX_RPT = 0x03,
+	C2H_AP_REQ_TXRPT = 0x04,
+	C2H_FW_SCAN_COMPLETE = 0x7,
 	C2H_BT_INFO = 0x09,
 	C2H_BT_MP_INFO = 0x0B,
 	C2H_RA_RPT = 0x0C,
+	C2H_SPC_STAT = 0x0D,
 	C2H_RA_PARA_RPT = 0x0E,
-	C2H_FW_SWCHNL = 0x10,
+	C2H_FW_CHNL_SWITCH_COMPLETE = 0x10,
 	C2H_IQK_FINISH = 0x11,
 	C2H_MAILBOX_STATUS = 0x15,
 	C2H_P2P_RPORT = 0x16,
+	C2H_MCC = 0x17,
 	C2H_MAC_HIDDEN_RPT = 0x19,
 	C2H_MAC_HIDDEN_RPT_2 = 0x1A,
-	C2H_BT_SCOREBOARD_STATUS = 0x20,
+	C2H_BCN_EARLY_RPT = 0x1E,
 	C2H_DEFEATURE_DBG = 0x22,
 	C2H_CUSTOMER_STR_RPT = 0x24,
 	C2H_CUSTOMER_STR_RPT_2 = 0x25,
+	C2H_WLAN_INFO = 0x27,
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	C2H_PER_RATE_RPT = 0x2c,
+#endif
 	C2H_DEFEATURE_RSVD = 0xFD,
 	C2H_EXTEND = 0xff,
 } C2H_EVT;
@@ -47,6 +83,15 @@ typedef enum _EXTEND_C2H_EVT {
 	EXTEND_C2H_DBG_PRINT = 0
 } EXTEND_C2H_EVT;
 
+#define C2H_REG_LEN 16
+
+/* C2H_IQK_FINISH, 0x11 */
+#define IQK_OFFLOAD_LEN 1
+void c2h_iqk_offload(_adapter *adapter, u8 *data, u8 len);
+int	c2h_iqk_offload_wait(_adapter *adapter, u32 timeout_ms);
+#define rtl8812_iqk_wait c2h_iqk_offload_wait /* TODO: remove this after phydm call c2h_iqk_offload_wait instead */
+
+#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
 /* C2H_MAC_HIDDEN_RPT, 0x19 */
 #define MAC_HIDDEN_RPT_LEN 8
 int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
@@ -55,6 +100,7 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
 #define MAC_HIDDEN_RPT_2_LEN 5
 int c2h_mac_hidden_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len);
 int hal_read_mac_hidden_rpt(_adapter *adapter);
+#endif /* CONFIG_RTW_MAC_HIDDEN_RPT */
 
 /* C2H_DEFEATURE_DBG, 0x22 */
 #define DEFEATURE_DBG_LEN 1
@@ -70,5 +116,9 @@ int c2h_customer_str_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
 int c2h_customer_str_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len);
 #endif /* CONFIG_RTW_CUSTOMER_STR */
 
-#endif /* __COMMON_C2H_H__ */
+#ifdef RTW_PER_CMD_SUPPORT_FW
+/* C2H_PER_RATE_RPT, 0x2c */
+int c2h_per_rate_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
+#endif
 
+#endif /* __COMMON_C2H_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_phycfg.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_phycfg.c
index 0443f5cbbf1f..efce16587329 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_phycfg.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_com_phycfg.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,17 +12,18 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _HAL_COM_PHYCFG_C_
 
 #include <drv_types.h>
 #include <hal_data.h>
 
+#define PG_TXPWR_1PATH_BYTE_NUM_2G 18
+#define PG_TXPWR_BASE_BYTE_NUM_2G 11
+
+#define PG_TXPWR_1PATH_BYTE_NUM_5G 24
+#define PG_TXPWR_BASE_BYTE_NUM_5G 14
+
 #define PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) (((_pg_v) & 0xf0) >> 4)
 #define PG_TXPWR_LSB_DIFF_S4BIT(_pg_v) ((_pg_v) & 0x0f)
 #define PG_TXPWR_MSB_DIFF_TO_S8BIT(_pg_v) ((PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) & BIT3) ? (PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) | 0xF0) : PG_TXPWR_MSB_DIFF_S4BIT(_pg_v))
@@ -57,7 +59,8 @@ const char *const _pg_txpwr_src_str[] = {
 #define DBG_PG_TXPWR_READ 0
 #endif
 
-void dump_pg_txpwr_info_2g(void *sel, TxPowerInfo24G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)
+#if DBG_PG_TXPWR_READ
+static void dump_pg_txpwr_info_2g(void *sel, TxPowerInfo24G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)
 {
 	int path, group, tx_idx;
 
@@ -141,7 +144,7 @@ void dump_pg_txpwr_info_2g(void *sel, TxPowerInfo24G *txpwr_info, u8 rfpath_num,
 	RTW_PRINT_SEL(sel, "\n");
 }
 
-void dump_pg_txpwr_info_5g(void *sel, TxPowerInfo5G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)
+static void dump_pg_txpwr_info_5g(void *sel, TxPowerInfo5G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)
 {
 	int path, group, tx_idx;
 
@@ -224,6 +227,7 @@ void dump_pg_txpwr_info_5g(void *sel, TxPowerInfo5G *txpwr_info, u8 rfpath_num,
 	}
 	RTW_PRINT_SEL(sel, "\n");
 }
+#endif /* DBG_PG_TXPWR_READ */
 
 const struct map_t pg_txpwr_def_info =
 	MAP_ENT(0xB8, 1, 0xFF
@@ -257,6 +261,14 @@ static const struct map_t rtl8188f_pg_txpwr_def_info =
 	);
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+static const struct map_t rtl8188gtv_pg_txpwr_def_info =
+	MAP_ENT(0xB8, 1, 0xFF
+		, MAPSEG_ARRAY_ENT(0x10, 12,
+			0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x27, 0x27, 0x27, 0x27, 0x27, 0x24)
+	);
+#endif
+
 #ifdef CONFIG_RTL8723B
 static const struct map_t rtl8723b_pg_txpwr_def_info =
 	MAP_ENT(0xB8, 2, 0xFF
@@ -393,6 +405,11 @@ const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter)
 		map = &rtl8188f_pg_txpwr_def_info;
 		break;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		map = &rtl8188gtv_pg_txpwr_def_info;
+		break;
+#endif
 #ifdef CONFIG_RTL8812A
 	case RTL8812:
 		map = &rtl8812a_pg_txpwr_def_info;
@@ -443,7 +460,7 @@ static u8 hal_chk_pg_txpwr_info_2g(_adapter *adapter, TxPowerInfo24G *pwr_info)
 		return _SUCCESS;
 
 	for (path = 0; path < MAX_RF_PATH; path++) {
-		if (!HAL_SPEC_CHK_RF_PATH(hal_spec, path))
+		if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path))
 			continue;
 		for (group = 0; group < MAX_CHNL_GROUP_24G; group++) {
 			if (IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexCCK_Base[path][group])
@@ -474,7 +491,7 @@ static u8 hal_chk_pg_txpwr_info_5g(_adapter *adapter, TxPowerInfo5G *pwr_info)
 		return _SUCCESS;
 
 	for (path = 0; path < MAX_RF_PATH; path++) {
-		if (!HAL_SPEC_CHK_RF_PATH(hal_spec, path))
+		if (!HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
 			continue;
 		for (group = 0; group < MAX_CHNL_GROUP_5G; group++)
 			if (IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexBW40_Base[path][group]))
@@ -520,7 +537,7 @@ static inline void hal_init_pg_txpwr_info_2g(_adapter *adapter, TxPowerInfo24G *
 
 	/* init for dummy base and diff */
 	for (path = 0; path < MAX_RF_PATH; path++) {
-		if (!HAL_SPEC_CHK_RF_PATH(hal_spec, path))
+		if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path))
 			break;
 		/* 2.4G BW40 base has 1 less group than CCK base*/
 		pwr_info->IndexBW40_Base[path][MAX_CHNL_GROUP_24G - 1] = 0;
@@ -556,7 +573,7 @@ static inline void hal_init_pg_txpwr_info_5g(_adapter *adapter, TxPowerInfo5G *p
 	}
 
 	for (path = 0; path < MAX_RF_PATH; path++) {
-		if (!HAL_SPEC_CHK_RF_PATH(hal_spec, path))
+		if (!HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
 			break;
 		/* dummy diff */
 		pwr_info->BW40_Diff[path][0] = 0; /* 5G BW40-1S */
@@ -578,8 +595,6 @@ u16 hal_load_pg_txpwr_info_path_2g(
 	const struct map_t *txpwr_map,
 	u16 pg_offset)
 {
-#define PG_TXPWR_1PATH_BYTE_NUM_2G 18
-
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	u16 offset = pg_offset;
 	u8 group, tx_idx;
@@ -596,7 +611,7 @@ u16 hal_load_pg_txpwr_info_path_2g(
 		RTW_INFO("%s [%c] offset:0x%03x\n", __func__, rf_path_char(path), offset);
 
 	for (group = 0; group < MAX_CHNL_GROUP_24G; group++) {
-		if (HAL_SPEC_CHK_RF_PATH(hal_spec, path)) {
+		if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
 			tmp_base = map_read8(txpwr_map, offset);
 			if (!IS_PG_TXPWR_BASE_INVALID(tmp_base)
 				&& IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexCCK_Base[path][group])
@@ -610,7 +625,7 @@ u16 hal_load_pg_txpwr_info_path_2g(
 	}
 
 	for (group = 0; group < MAX_CHNL_GROUP_24G - 1; group++) {
-		if (HAL_SPEC_CHK_RF_PATH(hal_spec, path)) {
+		if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
 			tmp_base = map_read8(txpwr_map, offset);
 			if (!IS_PG_TXPWR_BASE_INVALID(tmp_base)
 				&& IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexBW40_Base[path][group])
@@ -625,7 +640,7 @@ u16 hal_load_pg_txpwr_info_path_2g(
 
 	for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
 		if (tx_idx == 0) {
-			if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
+			if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
 				val = map_read8(txpwr_map, offset);
 				tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
 				if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -646,7 +661,7 @@ u16 hal_load_pg_txpwr_info_path_2g(
 			}
 			offset++;
 		} else {
-			if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
+			if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
 				val = map_read8(txpwr_map, offset);
 				tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
 				if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -668,7 +683,7 @@ u16 hal_load_pg_txpwr_info_path_2g(
 			}
 			offset++;
 
-			if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
+			if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
 				val = map_read8(txpwr_map, offset);
 				tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
 				if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -708,8 +723,6 @@ u16 hal_load_pg_txpwr_info_path_5g(
 	const struct map_t *txpwr_map,
 	u16 pg_offset)
 {
-#define PG_TXPWR_1PATH_BYTE_NUM_5G 24
-
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	u16 offset = pg_offset;
 	u8 group, tx_idx;
@@ -730,7 +743,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 		RTW_INFO("%s[%c] eaddr:0x%03x\n", __func__, rf_path_char(path), offset);
 
 	for (group = 0; group < MAX_CHNL_GROUP_5G; group++) {
-		if (HAL_SPEC_CHK_RF_PATH(hal_spec, path)) {
+		if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path)) {
 			tmp_base = map_read8(txpwr_map, offset);
 			if (!IS_PG_TXPWR_BASE_INVALID(tmp_base)
 				&& IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexBW40_Base[path][group])
@@ -745,7 +758,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 
 	for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
 		if (tx_idx == 0) {
-			if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
+			if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
 				val = map_read8(txpwr_map, offset);
 				tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
 				if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -766,7 +779,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 			}
 			offset++;
 		} else {
-			if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
+			if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
 				val = map_read8(txpwr_map, offset);
 				tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
 				if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -790,7 +803,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 	}	
 
 	/* OFDM diff 2T ~ 3T */
-	if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, 1)) {
+	if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, 1)) {
 		val = map_read8(txpwr_map, offset);
 		tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
 		if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -814,7 +827,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 	offset++;
 
 	/* OFDM diff 4T */
-	if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, 3)) {
+	if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, 3)) {
 		val = map_read8(txpwr_map, offset);
 		tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
 		if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -828,7 +841,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 	offset++;
 
 	for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
-		if (HAL_SPEC_CHK_RF_PATH(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
+		if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
 			val = map_read8(txpwr_map, offset);
 			tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
 			if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
@@ -881,7 +894,7 @@ void hal_load_pg_txpwr_info(
 	hal_init_pg_txpwr_info_5g(adapter, pwr_info_5g);
 
 select_src:
-	pg_offset = 0x10;
+	pg_offset = hal_spec->pg_txpwr_saddr;
 
 	switch (txpwr_src) {
 	case PG_TXPWR_SRC_PG_DATA:
@@ -900,7 +913,7 @@ select_src:
 		goto end_parse;
 
 	for (path = 0; path < MAX_RF_PATH ; path++) {
-		if (!HAL_SPEC_CHK_RF_PATH(hal_spec, path))
+		if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && !HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
 			break;
 		pg_offset = hal_load_pg_txpwr_info_path_2g(adapter, pwr_info_2g, path, txpwr_src, txpwr_map, pg_offset);
 		pg_offset = hal_load_pg_txpwr_info_path_5g(adapter, pwr_info_5g, path, txpwr_src, txpwr_map, pg_offset);
@@ -920,16 +933,89 @@ end_parse:
 		rtw_warn_on(1);
 
 exit:
-	if (DBG_PG_TXPWR_READ) {
-		if (pwr_info_2g)
-			dump_pg_txpwr_info_2g(RTW_DBGDUMP, pwr_info_2g, 4, 4);
-		if (pwr_info_5g)
-			dump_pg_txpwr_info_5g(RTW_DBGDUMP, pwr_info_5g, 4, 4);
-	}
+	#if DBG_PG_TXPWR_READ
+	if (pwr_info_2g)
+		dump_pg_txpwr_info_2g(RTW_DBGDUMP, pwr_info_2g, 4, 4);
+	if (pwr_info_5g)
+		dump_pg_txpwr_info_5g(RTW_DBGDUMP, pwr_info_5g, 4, 4);
+	#endif
 
 	return;
 }
 
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+
+#define EFUSE_POWER_INDEX_INVALID 0xFF
+
+static u8 _check_phy_efuse_tx_power_info_valid(u8 *pg_data, int base_len, u16 pg_offset)
+{
+	int ff_cnt = 0;
+	int i;
+
+	for (i = 0; i < base_len; i++) {
+		if (*(pg_data + pg_offset + i) == 0xFF)
+			ff_cnt++;
+	}
+
+	if (ff_cnt == 0)
+		return _TRUE;
+	else if (ff_cnt == base_len)
+		return _FALSE;
+	else
+		return EFUSE_POWER_INDEX_INVALID;
+}
+
+int check_phy_efuse_tx_power_info_valid(_adapter *adapter)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u8 *pg_data = hal_data->efuse_eeprom_data;
+	u16 pg_offset = hal_spec->pg_txpwr_saddr;
+	u8 path;
+	u8 valid_2g_path_bmp = 0;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	u8 valid_5g_path_bmp = 0;
+#endif
+	int result = _FALSE;
+
+	for (path = 0; path < MAX_RF_PATH; path++) {
+		u8 ret = _FALSE;
+
+		if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && !HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
+			break;
+
+		if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
+			ret = _check_phy_efuse_tx_power_info_valid(pg_data, PG_TXPWR_BASE_BYTE_NUM_2G, pg_offset);
+			if (ret == _TRUE)
+				valid_2g_path_bmp |= BIT(path);
+			else if (ret == EFUSE_POWER_INDEX_INVALID)
+				return _FALSE;
+		}
+		pg_offset += PG_TXPWR_1PATH_BYTE_NUM_2G;
+
+		#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path)) {
+			ret = _check_phy_efuse_tx_power_info_valid(pg_data, PG_TXPWR_BASE_BYTE_NUM_5G, pg_offset);
+			if (ret == _TRUE)
+				valid_5g_path_bmp |= BIT(path);
+			else if (ret == EFUSE_POWER_INDEX_INVALID)
+				return _FALSE;
+		}
+		#endif
+		pg_offset += PG_TXPWR_1PATH_BYTE_NUM_5G;
+	}
+
+	if ((hal_chk_band_cap(adapter, BAND_CAP_2G) && valid_2g_path_bmp)
+		#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		|| (hal_chk_band_cap(adapter, BAND_CAP_5G) && valid_5g_path_bmp)
+		#endif
+	)
+		return _TRUE;
+
+	return _FALSE;
+}
+#endif /* CONFIG_EFUSE_CONFIG_FILE */
+
 void hal_load_txpwr_info(
 	_adapter *adapter,
 	TxPowerInfo24G *pwr_info_2g,
@@ -939,7 +1025,6 @@ void hal_load_txpwr_info(
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
-	u8 rfpath_num = hal_spec->rfpath_num;
 	u8 max_tx_cnt = hal_spec->max_tx_cnt;
 	u8 rfpath, ch_idx, group, tx_idx;
 
@@ -948,11 +1033,9 @@ void hal_load_txpwr_info(
 
 	/* transform to hal_data */
 	for (rfpath = 0; rfpath < MAX_RF_PATH; rfpath++) {
-		if (rfpath >= rfpath_num)
-			break;
 
-		if (!pwr_info_2g)
-			continue;
+		if (!pwr_info_2g || !HAL_SPEC_CHK_RF_PATH_2G(hal_spec, rfpath))
+			goto bypass_2g;
 
 		/* 2.4G base */
 		for (ch_idx = 0; ch_idx < CENTER_CH_2G_NUM; ch_idx++) {
@@ -975,10 +1058,12 @@ void hal_load_txpwr_info(
 			hal_data->BW20_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW20_Diff[rfpath][tx_idx];
 			hal_data->BW40_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW40_Diff[rfpath][tx_idx];
 		}
+bypass_2g:
+		;
 
 #ifdef CONFIG_IEEE80211_BAND_5GHZ
-		if (!pwr_info_5g)
-			continue;
+		if (!pwr_info_5g || !HAL_SPEC_CHK_RF_PATH_5G(hal_spec, rfpath))
+			goto bypass_5g;
 
 		/* 5G base */
 		for (ch_idx = 0; ch_idx < CENTER_CH_5G_ALL_NUM; ch_idx++) {
@@ -1008,6 +1093,8 @@ void hal_load_txpwr_info(
 			hal_data->BW40_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW40_Diff[rfpath][tx_idx];
 			hal_data->BW80_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW80_Diff[rfpath][tx_idx];
 		}
+bypass_5g:
+		;
 #endif /* CONFIG_IEEE80211_BAND_5GHZ */
 	}
 }
@@ -1212,13 +1299,13 @@ s8 rtw_regsty_get_target_tx_power(
 	IN	u8				Band,
 	IN	u8				RfPath,
 	IN	RATE_SECTION	RateSection
-	)
+)
 {
 	struct registry_priv *regsty = adapter_to_regsty(Adapter);
 	s8 value = 0;
 
 	if (RfPath > RF_PATH_D) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid RfPath:%d\n", __func__, RfPath);
+		RTW_PRINT("%s invalid RfPath:%d\n", __func__, RfPath);
 		return -1;
 	}
 
@@ -1227,7 +1314,7 @@ s8 rtw_regsty_get_target_tx_power(
 		&& Band != BAND_ON_5G
 		#endif
 	) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid Band:%d\n", __func__, Band);
+		RTW_PRINT("%s invalid Band:%d\n", __func__, Band);
 		return -1;
 	}
 
@@ -1236,8 +1323,8 @@ s8 rtw_regsty_get_target_tx_power(
 		|| (Band == BAND_ON_5G && RateSection == CCK)
 		#endif
 	) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid RateSection:%d in %sG, RfPath:%d\n", __func__
-			, RateSection, (Band == BAND_ON_2_4G) ? "2.4" : "5", RfPath);
+		RTW_PRINT("%s invalid RateSection:%d in Band:%d, RfPath:%d\n", __func__
+			, RateSection, Band, RfPath);
 		return -1;
 	}
 
@@ -1263,12 +1350,12 @@ bool rtw_regsty_chk_target_tx_power_valid(_adapter *adapter)
 			continue;
 
 		for (path = 0; path < RF_PATH_MAX; path++) {
-			if (path >= hal_data->NumTotalRFPath)
+			if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
 				break;
 
 			for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
 				tx_num = rate_section_to_tx_num(rs);
-				if (tx_num >= hal_spec->nss_num)
+				if (tx_num >= hal_spec->tx_nss_num)
 					continue;
 
 				if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
@@ -1279,7 +1366,7 @@ bool rtw_regsty_chk_target_tx_power_valid(_adapter *adapter)
 
 				target = rtw_regsty_get_target_tx_power(adapter, band, path, rs);
 				if (target == -1) {
-					DBG_871X_LEVEL(_drv_always_, "%s return _FALSE for band:%d, path:%d, rs:%d, t:%d\n", __func__, band, path, rs, target);
+					RTW_PRINT("%s return _FALSE for band:%d, path:%d, rs:%d, t:%d\n", __func__, band, path, rs, target);
 					return _FALSE;
 				}
 			}
@@ -1299,35 +1386,34 @@ PHY_GetTxPowerByRateBase(
 	IN	PADAPTER		Adapter,
 	IN	u8				Band,
 	IN	u8				RfPath,
-	IN	u8				TxNum,
 	IN	RATE_SECTION	RateSection
-	)
+)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
 	u8 value = 0;
 
 	if (RfPath > RF_PATH_D) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid RfPath:%d\n", __func__, RfPath);
+		RTW_PRINT("%s invalid RfPath:%d\n", __func__, RfPath);
 		return 0;
 	}
 
 	if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid Band:%d\n", __func__, Band);
+		RTW_PRINT("%s invalid Band:%d\n", __func__, Band);
 		return 0;
 	}
 
 	if (RateSection >= RATE_SECTION_NUM
 		|| (Band == BAND_ON_5G && RateSection == CCK)
 	) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid RateSection:%d in %sG, RfPath:%d, TxNum:%d\n", __func__
-			, RateSection, (Band == BAND_ON_2_4G) ? "2.4" : "5", RfPath, TxNum);
+		RTW_PRINT("%s invalid RateSection:%d in Band:%d, RfPath:%d\n", __func__
+			, RateSection, Band, RfPath);
 		return 0;
 	}
 
 	if (Band == BAND_ON_2_4G)
-		value = pHalData->TxPwrByRateBase2_4G[RfPath][TxNum][RateSection];
+		value = pHalData->TxPwrByRateBase2_4G[RfPath][RateSection];
 	else /* BAND_ON_5G */
-		value = pHalData->TxPwrByRateBase5G[RfPath][TxNum][RateSection - 1];
+		value = pHalData->TxPwrByRateBase5G[RfPath][RateSection - 1];
 
 	return value;
 }
@@ -1338,85 +1424,121 @@ phy_SetTxPowerByRateBase(
 	IN	u8				Band,
 	IN	u8				RfPath,
 	IN	RATE_SECTION	RateSection,
-	IN	u8				TxNum,
 	IN	u8				Value
-	)
+)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
-	
+
 	if (RfPath > RF_PATH_D) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid RfPath:%d\n", __func__, RfPath);
+		RTW_PRINT("%s invalid RfPath:%d\n", __func__, RfPath);
 		return;
 	}
 
 	if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid Band:%d\n", __func__, Band);
+		RTW_PRINT("%s invalid Band:%d\n", __func__, Band);
 		return;
 	}
 
 	if (RateSection >= RATE_SECTION_NUM
 		|| (Band == BAND_ON_5G && RateSection == CCK)
 	) {
-		DBG_871X_LEVEL(_drv_always_, "%s invalid RateSection:%d in %sG, RfPath:%d, TxNum:%d\n", __func__
-			, RateSection, (Band == BAND_ON_2_4G) ? "2.4" : "5", RfPath, TxNum);
+		RTW_PRINT("%s invalid RateSection:%d in %sG, RfPath:%d\n", __func__
+			, RateSection, (Band == BAND_ON_2_4G) ? "2.4" : "5", RfPath);
 		return;
 	}
 
 	if (Band == BAND_ON_2_4G)
-		pHalData->TxPwrByRateBase2_4G[RfPath][TxNum][RateSection] = Value;
+		pHalData->TxPwrByRateBase2_4G[RfPath][RateSection] = Value;
 	else /* BAND_ON_5G */
-		pHalData->TxPwrByRateBase5G[RfPath][TxNum][RateSection - 1] = Value;
+		pHalData->TxPwrByRateBase5G[RfPath][RateSection - 1] = Value;
 }
 
-#ifdef TX_POWER_BY_RATE_OLD
-VOID
-phy_StoreTxPowerByRateBaseOld(	
-	IN	PADAPTER	pAdapter
-	)
+static inline BOOLEAN phy_is_txpwr_by_rate_undefined_of_band_path(_adapter *adapter, u8 band, u8 path)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u8 rate_idx = 0;
+
+	for (rate_idx = 0; rate_idx < TX_PWR_BY_RATE_NUM_RATE; rate_idx++) {
+		if (hal_data->TxPwrByRateOffset[band][path][rate_idx] != 0)
+			goto exit;
+	}
+
+exit:
+	return rate_idx >= TX_PWR_BY_RATE_NUM_RATE ? _TRUE : _FALSE;
+}
+
+static inline void phy_txpwr_by_rate_duplicate_band_path(_adapter *adapter, u8 band, u8 s_path, u8 t_path)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u8 rate_idx = 0;
+
+	for (rate_idx = 0; rate_idx < TX_PWR_BY_RATE_NUM_RATE; rate_idx++)
+		hal_data->TxPwrByRateOffset[band][t_path][rate_idx] = hal_data->TxPwrByRateOffset[band][s_path][rate_idx];
+}
+
+static void phy_txpwr_by_rate_chk_for_path_dup(_adapter *adapter)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA( pAdapter );
-	u16			rawValue = 0;
-	u8			base = 0;
-	u8			path = 0;
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][7] >> 8 ) & 0xFF; 
-	base = ( rawValue >> 4 ) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, CCK, RF_1TX, base );
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][1] >> 24 ) & 0xFF; 
-	base = ( rawValue >> 4 ) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, OFDM, RF_1TX, base );
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][3] >> 24 ) & 0xFF; 
-	base = ( rawValue >> 4 ) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, HT_MCS0_MCS7, RF_1TX, base );
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][5] >> 24 ) & 0xFF; 
-	base = ( rawValue >> 4) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, HT_MCS8_MCS15, RF_2TX, base );
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][7] & 0xFF ); 
-	base = ( rawValue >> 4 ) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, CCK, RF_1TX, base );
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][9] >> 24 ) & 0xFF; 
-	base = ( rawValue >> 4 ) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, OFDM, RF_1TX, base );
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][11] >> 24 ) & 0xFF; 
-	base = ( rawValue >> 4 ) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, HT_MCS0_MCS7, RF_1TX, base );
-
-	rawValue = ( u16 ) ( pHalData->MCSTxPowerLevelOriginalOffset[0][13] >> 24 ) & 0xFF; 
-	base = ( rawValue >> 4 ) * 10 + ( rawValue & 0xF );
-	phy_SetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, HT_MCS8_MCS15, RF_2TX, base );
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u8 band, path;
+	s8 src_path;
+
+	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++)
+		for (path = RF_PATH_A; path < RF_PATH_MAX; path++)
+			hal_data->txpwr_by_rate_undefined_band_path[band][path] = 0;
+
+	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
+		if (!hal_is_band_support(adapter, band))
+			continue;
+
+		for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
+			if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
+				continue;
+
+			if (phy_is_txpwr_by_rate_undefined_of_band_path(adapter, band, path))
+				hal_data->txpwr_by_rate_undefined_band_path[band][path] = 1;
+		}
+	}
+
+	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
+		if (!hal_is_band_support(adapter, band))
+			continue;
+
+		src_path = -1;
+		for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
+			if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
+				continue;
+
+			/* find src */
+			if (src_path == -1 && hal_data->txpwr_by_rate_undefined_band_path[band][path] == 0)
+				src_path = path;
+		}
+
+		if (src_path == -1) {
+			RTW_ERR("%s all power by rate undefined\n", __func__);
+			continue;
+		}
+
+		for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
+			if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
+				continue;
+
+			/* duplicate src to undefined one */
+			if (hal_data->txpwr_by_rate_undefined_band_path[band][path] == 1) {
+				RTW_INFO("%s duplicate %s [%c] to [%c]\n", __func__
+					, band_str(band), rf_path_char(src_path), rf_path_char(path));
+				phy_txpwr_by_rate_duplicate_band_path(adapter, band, src_path, path);
+			}
+		}
+	}
 }
-#endif /* TX_POWER_BY_RATE_OLD */
 
 VOID
-phy_StoreTxPowerByRateBase(	
+phy_StoreTxPowerByRateBase(
 	IN	PADAPTER	pAdapter
-	)
+)
 {
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(pAdapter);
 	struct registry_priv *regsty = adapter_to_regsty(pAdapter);
@@ -1441,14 +1563,12 @@ phy_StoreTxPowerByRateBase(
 			continue;
 
 		for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
-			/* TODO: 8814A's NumTotalRFPath differs at probe(3) and up(4), need fixed
-			if (path >= hal_data->NumTotalRFPath)
+			if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
 				break;
-			*/
 
 			for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
 				tx_num = rate_section_to_tx_num(rs);
-				if (tx_num >= hal_spec->nss_num)
+				if (tx_num >= hal_spec->tx_nss_num)
 					continue;
 
 				if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
@@ -1460,60 +1580,13 @@ phy_StoreTxPowerByRateBase(
 				if (regsty->target_tx_pwr_valid == _TRUE)
 					base = 2 * rtw_regsty_get_target_tx_power(pAdapter, band, path, rs);
 				else
-					base = _PHY_GetTxPowerByRate(pAdapter, band, path, tx_num, rate_sec_base[rs]);
-				phy_SetTxPowerByRateBase(pAdapter, band, path, rs, tx_num, base);
+					base = _PHY_GetTxPowerByRate(pAdapter, band, path, rate_sec_base[rs]);
+				phy_SetTxPowerByRateBase(pAdapter, band, path, rs, base);
 			}
 		}
 	}
 }
 
-#ifdef TX_POWER_BY_RATE_OLD
-u8
-PHY_GetRateSectionIndexOfTxPowerByRate(
-	IN	PADAPTER	pAdapter,
-	IN	u32			RegAddr,
-	IN	u32			BitMask
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA( pAdapter );
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	u8 			index = 0;
-	
-	if ( pDM_Odm->PhyRegPgVersion == 0 )
-	{
-		switch ( RegAddr )
-		{
-			case rTxAGC_A_Rate18_06:	 index = 0;		break;
-			case rTxAGC_A_Rate54_24:	 index = 1;		break;
-			case rTxAGC_A_CCK1_Mcs32:	 index = 6;		break;
-			case rTxAGC_B_CCK11_A_CCK2_11:
-				if ( BitMask == bMaskH3Bytes )
-					index = 7;
-				else if ( BitMask == 0x000000ff )
-					index = 15;
-				break;
-				
-			case rTxAGC_A_Mcs03_Mcs00:	 index = 2;		break;
-			case rTxAGC_A_Mcs07_Mcs04:	 index = 3;		break;
-			case rTxAGC_A_Mcs11_Mcs08:	 index = 4;		break;
-			case rTxAGC_A_Mcs15_Mcs12:	 index = 5;		break;
-			case rTxAGC_B_Rate18_06:	 index = 8;		break;
-			case rTxAGC_B_Rate54_24:	 index = 9;		break;
-			case rTxAGC_B_CCK1_55_Mcs32: index = 14;	break;
-			case rTxAGC_B_Mcs03_Mcs00:	 index = 10;	break;
-			case rTxAGC_B_Mcs07_Mcs04:	 index = 11;	break;
-			case rTxAGC_B_Mcs11_Mcs08:	 index = 12;	break;
-			case rTxAGC_B_Mcs15_Mcs12:	 index = 13;	break;
-			default:
-				DBG_871X("Invalid RegAddr 0x3%x in PHY_GetRateSectionIndexOfTxPowerByRate()", RegAddr );
-				break;
-		};
-	}
-	
-	return index;
-}
-#endif /* TX_POWER_BY_RATE_OLD */
-
 VOID
 PHY_GetRateValuesOfTxPowerByRate(
 	IN	PADAPTER pAdapter,
@@ -1523,508 +1596,436 @@ PHY_GetRateValuesOfTxPowerByRate(
 	OUT	u8 *Rate,
 	OUT	s8 *PwrByRateVal,
 	OUT	u8 *RateNum
-	)
+)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA( pAdapter );
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	u8	 			index = 0, i = 0;
-	
-	switch ( RegAddr )
-	{
-		case rTxAGC_A_Rate18_06:
-		case rTxAGC_B_Rate18_06:
-			Rate[0] = MGN_6M;
-			Rate[1] = MGN_9M;
-			Rate[2] = MGN_12M;
-			Rate[3] = MGN_18M;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
-			
-		case rTxAGC_A_Rate54_24:
-		case rTxAGC_B_Rate54_24:
-			Rate[0] = MGN_24M;
-			Rate[1] = MGN_36M;
-			Rate[2] = MGN_48M;
-			Rate[3] = MGN_54M;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
-			
-		case rTxAGC_A_CCK1_Mcs32:
-			Rate[0] = MGN_1M;
-			PwrByRateVal[0] = ( s8 ) ( ( ( ( Value >> (8 + 4) ) & 0xF ) ) * 10 + 
-											( ( Value >> 8 ) & 0xF ) );
-			*RateNum = 1;
-			break;
-			
-		case rTxAGC_B_CCK11_A_CCK2_11:
-			if ( BitMask == 0xffffff00 )
-			{
-				Rate[0] = MGN_2M;
-				Rate[1] = MGN_5_5M;
-				Rate[2] = MGN_11M;
-				for ( i = 1; i < 4; ++ i )
-				{
-					PwrByRateVal[i - 1] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-													( ( Value >> (i * 8) ) & 0xF ) );
-				}
-				*RateNum = 3;
-			}
-			else if ( BitMask == 0x000000ff )
-			{
-				Rate[0] = MGN_11M;
-				PwrByRateVal[0] = ( s8 ) ( ( ( ( Value >> 4 ) & 0xF ) ) * 10 + 
-											        ( Value & 0xF ) );
-				*RateNum = 1;
-			}
-			break;
-			
-		case rTxAGC_A_Mcs03_Mcs00:
-		case rTxAGC_B_Mcs03_Mcs00:
-			Rate[0] = MGN_MCS0;
-			Rate[1] = MGN_MCS1;
-			Rate[2] = MGN_MCS2;
-			Rate[3] = MGN_MCS3;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
-			
-		case rTxAGC_A_Mcs07_Mcs04:
-		case rTxAGC_B_Mcs07_Mcs04:
-			Rate[0] = MGN_MCS4;
-			Rate[1] = MGN_MCS5;
-			Rate[2] = MGN_MCS6;
-			Rate[3] = MGN_MCS7;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
-			
-		case rTxAGC_A_Mcs11_Mcs08:
-		case rTxAGC_B_Mcs11_Mcs08:
-			Rate[0] = MGN_MCS8;
-			Rate[1] = MGN_MCS9;
-			Rate[2] = MGN_MCS10;
-			Rate[3] = MGN_MCS11;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
-			
-		case rTxAGC_A_Mcs15_Mcs12:
-		case rTxAGC_B_Mcs15_Mcs12:
-			Rate[0] = MGN_MCS12;
-			Rate[1] = MGN_MCS13;
-			Rate[2] = MGN_MCS14;
-			Rate[3] = MGN_MCS15;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			
-			break;
-			
-		case rTxAGC_B_CCK1_55_Mcs32:
-			Rate[0] = MGN_1M;
-			Rate[1] = MGN_2M;
-			Rate[2] = MGN_5_5M;
-			for ( i = 1; i < 4; ++ i )
-			{
-				PwrByRateVal[i - 1] = ( s8 ) ( ( ( ( Value >> ( i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> ( i * 8) ) & 0xF ) );
-			}
-			*RateNum = 3;
-			break;
-			
-		case 0xC20:
-		case 0xE20:
-		case 0x1820:
-		case 0x1a20:
-			Rate[0] = MGN_1M;
-			Rate[1] = MGN_2M;
-			Rate[2] = MGN_5_5M;
-			Rate[3] = MGN_11M;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
-			
-		case 0xC24:
-		case 0xE24:
-		case 0x1824:
-		case 0x1a24:
-			Rate[0] = MGN_6M;
-			Rate[1] = MGN_9M;
-			Rate[2] = MGN_12M;
-			Rate[3] = MGN_18M;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
-
-		case 0xC28:
-		case 0xE28:
-		case 0x1828:
-		case 0x1a28:
-			Rate[0] = MGN_24M;
-			Rate[1] = MGN_36M;
-			Rate[2] = MGN_48M;
-			Rate[3] = MGN_54M;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+	u8				index = 0, i = 0;
+
+	switch (RegAddr) {
+	case rTxAGC_A_Rate18_06:
+	case rTxAGC_B_Rate18_06:
+		Rate[0] = MGN_6M;
+		Rate[1] = MGN_9M;
+		Rate[2] = MGN_12M;
+		Rate[3] = MGN_18M;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xC2C:
-		case 0xE2C:
-		case 0x182C:
-		case 0x1a2C:
-			Rate[0] = MGN_MCS0;
-			Rate[1] = MGN_MCS1;
-			Rate[2] = MGN_MCS2;
-			Rate[3] = MGN_MCS3;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case rTxAGC_A_Rate54_24:
+	case rTxAGC_B_Rate54_24:
+		Rate[0] = MGN_24M;
+		Rate[1] = MGN_36M;
+		Rate[2] = MGN_48M;
+		Rate[3] = MGN_54M;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xC30:
-		case 0xE30:
-		case 0x1830:
-		case 0x1a30:
-			Rate[0] = MGN_MCS4;
-			Rate[1] = MGN_MCS5;
-			Rate[2] = MGN_MCS6;
-			Rate[3] = MGN_MCS7;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case rTxAGC_A_CCK1_Mcs32:
+		Rate[0] = MGN_1M;
+		PwrByRateVal[0] = (s8)((((Value >> (8 + 4)) & 0xF)) * 10 +
+				       ((Value >> 8) & 0xF));
+		*RateNum = 1;
+		break;
 
-		case 0xC34:
-		case 0xE34:
-		case 0x1834:
-		case 0x1a34:
-			Rate[0] = MGN_MCS8;
-			Rate[1] = MGN_MCS9;
-			Rate[2] = MGN_MCS10;
-			Rate[3] = MGN_MCS11;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
+	case rTxAGC_B_CCK11_A_CCK2_11:
+		if (BitMask == 0xffffff00) {
+			Rate[0] = MGN_2M;
+			Rate[1] = MGN_5_5M;
+			Rate[2] = MGN_11M;
+			for (i = 1; i < 4; ++i) {
+				PwrByRateVal[i - 1] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+						   ((Value >> (i * 8)) & 0xF));
 			}
-			*RateNum = 4;
-			break;
+			*RateNum = 3;
+		} else if (BitMask == 0x000000ff) {
+			Rate[0] = MGN_11M;
+			PwrByRateVal[0] = (s8)((((Value >> 4) & 0xF)) * 10 +
+					       (Value & 0xF));
+			*RateNum = 1;
+		}
+		break;
 
-		case 0xC38:
-		case 0xE38:
-		case 0x1838:
-		case 0x1a38:
-			Rate[0] = MGN_MCS12;
-			Rate[1] = MGN_MCS13;
-			Rate[2] = MGN_MCS14;
-			Rate[3] = MGN_MCS15;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case rTxAGC_A_Mcs03_Mcs00:
+	case rTxAGC_B_Mcs03_Mcs00:
+		Rate[0] = MGN_MCS0;
+		Rate[1] = MGN_MCS1;
+		Rate[2] = MGN_MCS2;
+		Rate[3] = MGN_MCS3;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xC3C:
-		case 0xE3C:
-		case 0x183C:
-		case 0x1a3C:
-			Rate[0] = MGN_VHT1SS_MCS0;
-			Rate[1] = MGN_VHT1SS_MCS1;
-			Rate[2] = MGN_VHT1SS_MCS2;
-			Rate[3] = MGN_VHT1SS_MCS3;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case rTxAGC_A_Mcs07_Mcs04:
+	case rTxAGC_B_Mcs07_Mcs04:
+		Rate[0] = MGN_MCS4;
+		Rate[1] = MGN_MCS5;
+		Rate[2] = MGN_MCS6;
+		Rate[3] = MGN_MCS7;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xC40:
-		case 0xE40:
-		case 0x1840:
-		case 0x1a40:
-			Rate[0] = MGN_VHT1SS_MCS4;
-			Rate[1] = MGN_VHT1SS_MCS5;
-			Rate[2] = MGN_VHT1SS_MCS6;
-			Rate[3] = MGN_VHT1SS_MCS7;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case rTxAGC_A_Mcs11_Mcs08:
+	case rTxAGC_B_Mcs11_Mcs08:
+		Rate[0] = MGN_MCS8;
+		Rate[1] = MGN_MCS9;
+		Rate[2] = MGN_MCS10;
+		Rate[3] = MGN_MCS11;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xC44:
-		case 0xE44:
-		case 0x1844:
-		case 0x1a44:
-			Rate[0] = MGN_VHT1SS_MCS8;
-			Rate[1] = MGN_VHT1SS_MCS9;
-			Rate[2] = MGN_VHT2SS_MCS0;
-			Rate[3] = MGN_VHT2SS_MCS1;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case rTxAGC_A_Mcs15_Mcs12:
+	case rTxAGC_B_Mcs15_Mcs12:
+		Rate[0] = MGN_MCS12;
+		Rate[1] = MGN_MCS13;
+		Rate[2] = MGN_MCS14;
+		Rate[3] = MGN_MCS15;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
 
-		case 0xC48:
-		case 0xE48:
-		case 0x1848:
-		case 0x1a48:
-			Rate[0] = MGN_VHT2SS_MCS2;
-			Rate[1] = MGN_VHT2SS_MCS3;
-			Rate[2] = MGN_VHT2SS_MCS4;
-			Rate[3] = MGN_VHT2SS_MCS5;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+		break;
 
-		case 0xC4C:
-		case 0xE4C:
-		case 0x184C:
-		case 0x1a4C:
-			Rate[0] = MGN_VHT2SS_MCS6;
-			Rate[1] = MGN_VHT2SS_MCS7;
-			Rate[2] = MGN_VHT2SS_MCS8;
-			Rate[3] = MGN_VHT2SS_MCS9;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case rTxAGC_B_CCK1_55_Mcs32:
+		Rate[0] = MGN_1M;
+		Rate[1] = MGN_2M;
+		Rate[2] = MGN_5_5M;
+		for (i = 1; i < 4; ++i) {
+			PwrByRateVal[i - 1] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+						   ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 3;
+		break;
 
-		case 0xCD8:
-		case 0xED8:
-		case 0x18D8:
-		case 0x1aD8:
-			Rate[0] = MGN_MCS16;
-			Rate[1] = MGN_MCS17;
-			Rate[2] = MGN_MCS18;
-			Rate[3] = MGN_MCS19;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case 0xC20:
+	case 0xE20:
+	case 0x1820:
+	case 0x1a20:
+		Rate[0] = MGN_1M;
+		Rate[1] = MGN_2M;
+		Rate[2] = MGN_5_5M;
+		Rate[3] = MGN_11M;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xCDC:
-		case 0xEDC:
-		case 0x18DC:
-		case 0x1aDC:
-			Rate[0] = MGN_MCS20;
-			Rate[1] = MGN_MCS21;
-			Rate[2] = MGN_MCS22;
-			Rate[3] = MGN_MCS23;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case 0xC24:
+	case 0xE24:
+	case 0x1824:
+	case 0x1a24:
+		Rate[0] = MGN_6M;
+		Rate[1] = MGN_9M;
+		Rate[2] = MGN_12M;
+		Rate[3] = MGN_18M;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xCE0:
-		case 0xEE0:
-		case 0x18E0:
-		case 0x1aE0:
-			Rate[0] = MGN_VHT3SS_MCS0;
-			Rate[1] = MGN_VHT3SS_MCS1;
-			Rate[2] = MGN_VHT3SS_MCS2;
-			Rate[3] = MGN_VHT3SS_MCS3;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case 0xC28:
+	case 0xE28:
+	case 0x1828:
+	case 0x1a28:
+		Rate[0] = MGN_24M;
+		Rate[1] = MGN_36M;
+		Rate[2] = MGN_48M;
+		Rate[3] = MGN_54M;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xCE4:
-		case 0xEE4:
-		case 0x18E4:
-		case 0x1aE4:
-			Rate[0] = MGN_VHT3SS_MCS4;
-			Rate[1] = MGN_VHT3SS_MCS5;
-			Rate[2] = MGN_VHT3SS_MCS6;
-			Rate[3] = MGN_VHT3SS_MCS7;
-			for ( i = 0; i < 4; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 4;
-			break;
+	case 0xC2C:
+	case 0xE2C:
+	case 0x182C:
+	case 0x1a2C:
+		Rate[0] = MGN_MCS0;
+		Rate[1] = MGN_MCS1;
+		Rate[2] = MGN_MCS2;
+		Rate[3] = MGN_MCS3;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-		case 0xCE8:
-		case 0xEE8:
-		case 0x18E8:
-		case 0x1aE8:
-			Rate[0] = MGN_VHT3SS_MCS8;
-			Rate[1] = MGN_VHT3SS_MCS9;
-			for ( i = 0; i < 2; ++ i )
-			{
-				PwrByRateVal[i] = ( s8 ) ( ( ( ( Value >> (i * 8 + 4) ) & 0xF ) ) * 10 + 
-												( ( Value >> (i * 8) ) & 0xF ) );
-			}
-			*RateNum = 2;
-			break;
-			
-		default:
-			DBG_871X_LEVEL(_drv_always_, "Invalid RegAddr 0x%x in %s()\n", RegAddr, __func__);
-			break;
-	};
-}
+	case 0xC30:
+	case 0xE30:
+	case 0x1830:
+	case 0x1a30:
+		Rate[0] = MGN_MCS4;
+		Rate[1] = MGN_MCS5;
+		Rate[2] = MGN_MCS6;
+		Rate[3] = MGN_MCS7;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-void
-PHY_StoreTxPowerByRateNew(
-	IN	PADAPTER	pAdapter,
-	IN	u32			Band,
-	IN	u32			RfPath,
-	IN	u32			TxNum,
-	IN	u32			RegAddr,
-	IN	u32			BitMask,
-	IN	u32			Data
-	)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-	u8	i = 0, rates[4] = {0}, rateNum = 0;
-	s8	PwrByRateVal[4] = {0};
+	case 0xC34:
+	case 0xE34:
+	case 0x1834:
+	case 0x1a34:
+		Rate[0] = MGN_MCS8;
+		Rate[1] = MGN_MCS9;
+		Rate[2] = MGN_MCS10;
+		Rate[3] = MGN_MCS11;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-	PHY_GetRateValuesOfTxPowerByRate(pAdapter, RegAddr, BitMask, Data, rates, PwrByRateVal, &rateNum);
+	case 0xC38:
+	case 0xE38:
+	case 0x1838:
+	case 0x1a38:
+		Rate[0] = MGN_MCS12;
+		Rate[1] = MGN_MCS13;
+		Rate[2] = MGN_MCS14;
+		Rate[3] = MGN_MCS15;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-	if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
-		DBG_871X_LEVEL(_drv_always_, "Invalid Band %d\n", Band);
-		return;
-	}
+	case 0xC3C:
+	case 0xE3C:
+	case 0x183C:
+	case 0x1a3C:
+		Rate[0] = MGN_VHT1SS_MCS0;
+		Rate[1] = MGN_VHT1SS_MCS1;
+		Rate[2] = MGN_VHT1SS_MCS2;
+		Rate[3] = MGN_VHT1SS_MCS3;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-	if (RfPath > ODM_RF_PATH_D) {
-		DBG_871X_LEVEL(_drv_always_, "Invalid RfPath %d\n", RfPath);
-		return;
-	}
+	case 0xC40:
+	case 0xE40:
+	case 0x1840:
+	case 0x1a40:
+		Rate[0] = MGN_VHT1SS_MCS4;
+		Rate[1] = MGN_VHT1SS_MCS5;
+		Rate[2] = MGN_VHT1SS_MCS6;
+		Rate[3] = MGN_VHT1SS_MCS7;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
 
-	if (TxNum > ODM_RF_PATH_D) {
-		DBG_871X_LEVEL(_drv_always_, "Invalid TxNum %d\n", TxNum);
+	case 0xC44:
+	case 0xE44:
+	case 0x1844:
+	case 0x1a44:
+		Rate[0] = MGN_VHT1SS_MCS8;
+		Rate[1] = MGN_VHT1SS_MCS9;
+		Rate[2] = MGN_VHT2SS_MCS0;
+		Rate[3] = MGN_VHT2SS_MCS1;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
+
+	case 0xC48:
+	case 0xE48:
+	case 0x1848:
+	case 0x1a48:
+		Rate[0] = MGN_VHT2SS_MCS2;
+		Rate[1] = MGN_VHT2SS_MCS3;
+		Rate[2] = MGN_VHT2SS_MCS4;
+		Rate[3] = MGN_VHT2SS_MCS5;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
+
+	case 0xC4C:
+	case 0xE4C:
+	case 0x184C:
+	case 0x1a4C:
+		Rate[0] = MGN_VHT2SS_MCS6;
+		Rate[1] = MGN_VHT2SS_MCS7;
+		Rate[2] = MGN_VHT2SS_MCS8;
+		Rate[3] = MGN_VHT2SS_MCS9;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
+
+	case 0xCD8:
+	case 0xED8:
+	case 0x18D8:
+	case 0x1aD8:
+		Rate[0] = MGN_MCS16;
+		Rate[1] = MGN_MCS17;
+		Rate[2] = MGN_MCS18;
+		Rate[3] = MGN_MCS19;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
+
+	case 0xCDC:
+	case 0xEDC:
+	case 0x18DC:
+	case 0x1aDC:
+		Rate[0] = MGN_MCS20;
+		Rate[1] = MGN_MCS21;
+		Rate[2] = MGN_MCS22;
+		Rate[3] = MGN_MCS23;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
+
+	case 0xCE0:
+	case 0xEE0:
+	case 0x18E0:
+	case 0x1aE0:
+		Rate[0] = MGN_VHT3SS_MCS0;
+		Rate[1] = MGN_VHT3SS_MCS1;
+		Rate[2] = MGN_VHT3SS_MCS2;
+		Rate[3] = MGN_VHT3SS_MCS3;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
+
+	case 0xCE4:
+	case 0xEE4:
+	case 0x18E4:
+	case 0x1aE4:
+		Rate[0] = MGN_VHT3SS_MCS4;
+		Rate[1] = MGN_VHT3SS_MCS5;
+		Rate[2] = MGN_VHT3SS_MCS6;
+		Rate[3] = MGN_VHT3SS_MCS7;
+		for (i = 0; i < 4; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 4;
+		break;
+
+	case 0xCE8:
+	case 0xEE8:
+	case 0x18E8:
+	case 0x1aE8:
+		Rate[0] = MGN_VHT3SS_MCS8;
+		Rate[1] = MGN_VHT3SS_MCS9;
+		for (i = 0; i < 2; ++i) {
+			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
+					       ((Value >> (i * 8)) & 0xF));
+		}
+		*RateNum = 2;
+		break;
+
+	default:
+		RTW_PRINT("Invalid RegAddr 0x%x in %s()\n", RegAddr, __func__);
+		break;
+	};
+}
+
+void
+PHY_StoreTxPowerByRateNew(
+	IN	PADAPTER	pAdapter,
+	IN	u32			Band,
+	IN	u32			RfPath,
+	IN	u32			RegAddr,
+	IN	u32			BitMask,
+	IN	u32			Data
+)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
+	u8	i = 0, rates[4] = {0}, rateNum = 0;
+	s8	PwrByRateVal[4] = {0};
+
+	PHY_GetRateValuesOfTxPowerByRate(pAdapter, RegAddr, BitMask, Data, rates, PwrByRateVal, &rateNum);
+
+	if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
+		RTW_PRINT("Invalid Band %d\n", Band);
+		return;
+	}
+
+	if (RfPath > RF_PATH_D) {
+		RTW_PRINT("Invalid RfPath %d\n", RfPath);
 		return;
 	}
 
 	for (i = 0; i < rateNum; ++i) {
 		u8 rate_idx = PHY_GetRateIndexOfTxPowerByRate(rates[i]);
 
-		if (IS_1T_RATE(rates[i]))
-			pHalData->TxPwrByRateOffset[Band][RfPath][RF_1TX][rate_idx] = PwrByRateVal[i];
-		else if (IS_2T_RATE(rates[i]))
-			pHalData->TxPwrByRateOffset[Band][RfPath][RF_2TX][rate_idx] = PwrByRateVal[i];
-		else if (IS_3T_RATE(rates[i]))
-			pHalData->TxPwrByRateOffset[Band][RfPath][RF_3TX][rate_idx] = PwrByRateVal[i];
-		else if (IS_4T_RATE(rates[i]))
-			pHalData->TxPwrByRateOffset[Band][RfPath][RF_4TX][rate_idx] = PwrByRateVal[i];
-		else
-			rtw_warn_on(1);
+		pHalData->TxPwrByRateOffset[Band][RfPath][rate_idx] = PwrByRateVal[i];
 	}
 }
 
-#ifdef TX_POWER_BY_RATE_OLD
-void 
-PHY_StoreTxPowerByRateOld(
-	IN	PADAPTER		pAdapter,
-	IN	u32				RegAddr,
-	IN	u32				BitMask,
-	IN	u32				Data
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u8			index = PHY_GetRateSectionIndexOfTxPowerByRate( pAdapter, RegAddr, BitMask );
-
-	pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][index] = Data;
-	//DBG_871X("MCSTxPowerLevelOriginalOffset[%d][0] = 0x%x\n", pHalData->pwrGroupCnt,
-	//	pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][0]);
-}
-#endif /* TX_POWER_BY_RATE_OLD */
-
 VOID
 PHY_InitTxPowerByRate(
 	IN	PADAPTER	pAdapter
-	)
+)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u8	band = 0, rfPath = 0, TxNum = 0, rate = 0, i = 0, j = 0;
+	u8	band = 0, rfPath = 0, rate = 0, i = 0, j = 0;
 
-	if ( IS_HARDWARE_TYPE_8188E( pAdapter ) )
-	{
-		for ( i = 0; i < MAX_PG_GROUP; ++i )
-			for ( j = 0; j < 16; ++j )
-				pHalData->MCSTxPowerLevelOriginalOffset[i][j] = 0;
-	}
-	else
-	{
-		for ( band = BAND_ON_2_4G; band <= BAND_ON_5G; ++band )
-				for ( rfPath = 0; rfPath < TX_PWR_BY_RATE_NUM_RF; ++rfPath )
-					for ( TxNum = 0; TxNum < TX_PWR_BY_RATE_NUM_RF; ++TxNum )
-						for ( rate = 0; rate < TX_PWR_BY_RATE_NUM_RATE; ++rate )
-							pHalData->TxPwrByRateOffset[band][rfPath][TxNum][rate] = 0;
-	}
+	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; ++band)
+		for (rfPath = 0; rfPath < TX_PWR_BY_RATE_NUM_RF; ++rfPath)
+				for (rate = 0; rate < TX_PWR_BY_RATE_NUM_RATE; ++rate)
+					pHalData->TxPwrByRateOffset[band][rfPath][rate] = 0;
 }
 
 VOID
-PHY_StoreTxPowerByRate(
+phy_store_tx_power_by_rate(
 	IN	PADAPTER	pAdapter,
 	IN	u32			Band,
 	IN	u32			RfPath,
@@ -2032,226 +2033,104 @@ PHY_StoreTxPowerByRate(
 	IN	u32			RegAddr,
 	IN	u32			BitMask,
 	IN	u32			Data
-	)
+)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T  		pDM_Odm = &pHalData->odmpriv;
-	
-	if ( pDM_Odm->PhyRegPgVersion > 0 )
-	{
-		PHY_StoreTxPowerByRateNew( pAdapter, Band, RfPath, TxNum, RegAddr, BitMask, Data );
-	}
-#ifdef TX_POWER_BY_RATE_OLD
-	else if ( pDM_Odm->PhyRegPgVersion == 0 )
-	{
-		PHY_StoreTxPowerByRateOld( pAdapter, RegAddr, BitMask, Data );
-	
-		if ( RegAddr == rTxAGC_A_Mcs15_Mcs12 && pHalData->rf_type == RF_1T1R )
-			pHalData->pwrGroupCnt++;
-		else if ( RegAddr == rTxAGC_B_Mcs15_Mcs12 && pHalData->rf_type != RF_1T1R )
-			pHalData->pwrGroupCnt++;
-	}
-#endif
-	else
-		DBG_871X("Invalid PHY_REG_PG.txt version %d\n",  pDM_Odm->PhyRegPgVersion );
-	
-}
-
-#ifdef TX_POWER_BY_RATE_OLD
-VOID 
-phy_ConvertTxPowerByRateByBase(
-	IN	u32*		pData,
-	IN	u8			Start,
-	IN	u8			End,
-	IN	u8			BaseValue
-	)
-{
-	s8	i = 0;
-	u8	TempValue = 0;
-	u32	TempData = 0;
-	
-	for ( i = 3; i >= 0; --i )
-	{
-		if ( i >= Start && i <= End )
-		{
-			// Get the exact value
-			TempValue = ( u8 ) ( *pData >> ( i * 8 ) ) & 0xF; 
-			TempValue += ( ( u8 ) ( ( *pData >> ( i * 8 + 4 ) ) & 0xF ) ) * 10; 
-			
-			// Change the value to a relative value
-			TempValue = ( TempValue > BaseValue ) ? TempValue - BaseValue : BaseValue - TempValue;
-		}
-		else
-		{
-			TempValue = ( u8 ) ( *pData >> ( i * 8 ) ) & 0xFF;
-		}
-		
-		TempData <<= 8;
-		TempData |= TempValue;
-	}
-
-	*pData = TempData;
-}
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 
+	if (pDM_Odm->phy_reg_pg_version > 0)
+		PHY_StoreTxPowerByRateNew(pAdapter, Band, RfPath, RegAddr, BitMask, Data);
+	else
+		RTW_INFO("Invalid PHY_REG_PG.txt version %d\n",  pDM_Odm->phy_reg_pg_version);
 
-VOID
-PHY_ConvertTxPowerByRateInDbmToRelativeValuesOld(
-	IN	PADAPTER	pAdapter
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA( pAdapter );
-	u8			base = 0;
-	
-	//DBG_871X("===>PHY_ConvertTxPowerByRateInDbmToRelativeValuesOld()\n" );
-	
-	// CCK
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, RF_1TX, CCK );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][6] ), 1, 1, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][7] ), 1, 3, base );
-
-	// OFDM
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, RF_1TX, OFDM );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][0] ), 0, 3, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][1] ),	0, 3, base );
-
-	// HT MCS0~7
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, RF_1TX, HT_MCS0_MCS7 );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][2] ),	0, 3, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][3] ),	0, 3, base );
-
-	// HT MCS8~15
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, RF_2TX, HT_MCS8_MCS15 );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][4] ), 0, 3, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][5] ), 0, 3, base );
-
-	// CCK
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, RF_1TX, CCK );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][14] ), 1, 3, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][15] ), 0, 0, base );
-
-	// OFDM
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, RF_1TX, OFDM );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][8] ), 0, 3, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][9] ),	0, 3, base );
-
-	// HT MCS0~7
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, RF_1TX, HT_MCS0_MCS7 );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][10] ), 0, 3, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][11] ), 0, 3, base );
-
-	// HT MCS8~15
-	base = PHY_GetTxPowerByRateBase( pAdapter, BAND_ON_2_4G, ODM_RF_PATH_B, RF_2TX, HT_MCS8_MCS15 );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][12] ), 0, 3, base );
-	phy_ConvertTxPowerByRateByBase( 
-			&( pHalData->MCSTxPowerLevelOriginalOffset[0][13] ), 0, 3, base );
-
-	//DBG_871X("<===PHY_ConvertTxPowerByRateInDbmToRelativeValuesOld()\n" );
 }
-#endif /* TX_POWER_BY_RATE_OLD */
 
 VOID
 phy_ConvertTxPowerByRateInDbmToRelativeValues(
 	IN	PADAPTER	pAdapter
-	)
+)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA( pAdapter );
-	u8 			base = 0, i = 0, value = 0,
-				band = 0, path = 0, txNum = 0, index = 0, 
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	u8			base = 0, i = 0, value = 0,
+				band = 0, path = 0, index = 0,
 				startIndex = 0, endIndex = 0;
-	u8			cckRates[4] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M},
-				ofdmRates[8] = {MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M},
-				mcs0_7Rates[8] = {MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7},
-				mcs8_15Rates[8] = {MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15},
-				mcs16_23Rates[8] = {MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19, MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23},
-				vht1ssRates[10] = {MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4, 
-							   MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9},
-				vht2ssRates[10] = {MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4, 
-							   MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9},
-				vht3ssRates[10] = {MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4, 
-								   MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9};
-
-	//DBG_871X("===>PHY_ConvertTxPowerByRateInDbmToRelativeValues()\n" );
+	u8	cckRates[4] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M},
+		ofdmRates[8] = {MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M},
+		mcs0_7Rates[8] = {MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7},
+		mcs8_15Rates[8] = {MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15},
+		mcs16_23Rates[8] = {MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19, MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23},
+		vht1ssRates[10] = {MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4,
+			MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9},
+		vht2ssRates[10] = {MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4,
+			MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9},
+		vht3ssRates[10] = {MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4,
+			MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9};
+
+	/* RTW_INFO("===>PHY_ConvertTxPowerByRateInDbmToRelativeValues()\n" ); */
 
 	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; ++band) {
-		for (path = ODM_RF_PATH_A; path <= ODM_RF_PATH_D; ++path) {
-			for (txNum = RF_1TX; txNum < RF_MAX_TX_NUM; ++txNum) {
-				/* CCK */
-				if (band == BAND_ON_2_4G) {
-					base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, CCK);
-					for (i = 0; i < sizeof(cckRates); ++i) {
-						value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, cckRates[i]);
-						PHY_SetTxPowerByRate(pAdapter, band, path, txNum, cckRates[i], value - base);
-					}
+		for (path = RF_PATH_A; path <= RF_PATH_D; ++path) {
+			/* CCK */
+			if (band == BAND_ON_2_4G) {
+				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, CCK);
+				for (i = 0; i < sizeof(cckRates); ++i) {
+					value = PHY_GetTxPowerByRate(pAdapter, band, path, cckRates[i]);
+					PHY_SetTxPowerByRate(pAdapter, band, path, cckRates[i], value - base);
 				}
+			}
 
-				/* OFDM */
-				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, OFDM);
-				for (i = 0; i < sizeof(ofdmRates); ++i) {
-					value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, ofdmRates[i]);
-					PHY_SetTxPowerByRate(pAdapter, band, path, txNum, ofdmRates[i], value - base);
-				}
+			/* OFDM */
+			base = PHY_GetTxPowerByRateBase(pAdapter, band, path, OFDM);
+			for (i = 0; i < sizeof(ofdmRates); ++i) {
+				value = PHY_GetTxPowerByRate(pAdapter, band, path, ofdmRates[i]);
+				PHY_SetTxPowerByRate(pAdapter, band, path, ofdmRates[i], value - base);
+			}
 
-				/* HT MCS0~7 */
-				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, HT_1SS);
-				for (i = 0; i < sizeof(mcs0_7Rates); ++i) {
-					value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, mcs0_7Rates[i]);
-					PHY_SetTxPowerByRate(pAdapter, band, path, txNum, mcs0_7Rates[i], value - base);
-				}
+			/* HT MCS0~7 */
+			base = PHY_GetTxPowerByRateBase(pAdapter, band, path, HT_1SS);
+			for (i = 0; i < sizeof(mcs0_7Rates); ++i) {
+				value = PHY_GetTxPowerByRate(pAdapter, band, path, mcs0_7Rates[i]);
+				PHY_SetTxPowerByRate(pAdapter, band, path, mcs0_7Rates[i], value - base);
+			}
 
-				/* HT MCS8~15 */
-				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, HT_2SS);
-				for (i = 0; i < sizeof(mcs8_15Rates); ++i) {
-					value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, mcs8_15Rates[i]);
-					PHY_SetTxPowerByRate(pAdapter, band, path, txNum, mcs8_15Rates[i], value - base);
-				}
+			/* HT MCS8~15 */
+			base = PHY_GetTxPowerByRateBase(pAdapter, band, path, HT_2SS);
+			for (i = 0; i < sizeof(mcs8_15Rates); ++i) {
+				value = PHY_GetTxPowerByRate(pAdapter, band, path, mcs8_15Rates[i]);
+				PHY_SetTxPowerByRate(pAdapter, band, path, mcs8_15Rates[i], value - base);
+			}
 
-				/* HT MCS16~23 */
-				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, HT_3SS);
-				for (i = 0; i < sizeof(mcs16_23Rates); ++i) {
-					value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, mcs16_23Rates[i]);
-					PHY_SetTxPowerByRate(pAdapter, band, path, txNum, mcs16_23Rates[i], value - base);
-				}
+			/* HT MCS16~23 */
+			base = PHY_GetTxPowerByRateBase(pAdapter, band, path, HT_3SS);
+			for (i = 0; i < sizeof(mcs16_23Rates); ++i) {
+				value = PHY_GetTxPowerByRate(pAdapter, band, path, mcs16_23Rates[i]);
+				PHY_SetTxPowerByRate(pAdapter, band, path, mcs16_23Rates[i], value - base);
+			}
 
-				/* VHT 1SS */
-				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, VHT_1SS);
-				for (i = 0; i < sizeof(vht1ssRates); ++i) {
-					value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, vht1ssRates[i]);
-					PHY_SetTxPowerByRate(pAdapter, band, path, txNum, vht1ssRates[i], value - base);
-				}
+			/* VHT 1SS */
+			base = PHY_GetTxPowerByRateBase(pAdapter, band, path, VHT_1SS);
+			for (i = 0; i < sizeof(vht1ssRates); ++i) {
+				value = PHY_GetTxPowerByRate(pAdapter, band, path, vht1ssRates[i]);
+				PHY_SetTxPowerByRate(pAdapter, band, path, vht1ssRates[i], value - base);
+			}
 
-				/* VHT 2SS */
-				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, VHT_2SS);
-				for (i = 0; i < sizeof(vht2ssRates); ++i) {
-					value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, vht2ssRates[i]);
-					PHY_SetTxPowerByRate(pAdapter, band, path, txNum, vht2ssRates[i], value - base);
-				}
+			/* VHT 2SS */
+			base = PHY_GetTxPowerByRateBase(pAdapter, band, path, VHT_2SS);
+			for (i = 0; i < sizeof(vht2ssRates); ++i) {
+				value = PHY_GetTxPowerByRate(pAdapter, band, path, vht2ssRates[i]);
+				PHY_SetTxPowerByRate(pAdapter, band, path, vht2ssRates[i], value - base);
+			}
 
-				/* VHT 3SS */
-				base = PHY_GetTxPowerByRateBase(pAdapter, band, path, txNum, VHT_3SS);
-				for (i = 0; i < sizeof(vht3ssRates); ++i) {
-					value = PHY_GetTxPowerByRate(pAdapter, band, path, txNum, vht3ssRates[i]);
-					PHY_SetTxPowerByRate(pAdapter, band, path, txNum, vht3ssRates[i], value - base);
-				}
+			/* VHT 3SS */
+			base = PHY_GetTxPowerByRateBase(pAdapter, band, path, VHT_3SS);
+			for (i = 0; i < sizeof(vht3ssRates); ++i) {
+				value = PHY_GetTxPowerByRate(pAdapter, band, path, vht3ssRates[i]);
+				PHY_SetTxPowerByRate(pAdapter, band, path, vht3ssRates[i], value - base);
 			}
 		}
 	}
 
-	//DBG_871X("<===PHY_ConvertTxPowerByRateInDbmToRelativeValues()\n" );
+	/* RTW_INFO("<===PHY_ConvertTxPowerByRateInDbmToRelativeValues()\n" ); */
 }
 
 /*
@@ -2261,18 +2140,19 @@ phy_ConvertTxPowerByRateInDbmToRelativeValues(
 VOID
 PHY_TxPowerByRateConfiguration(
 	IN  PADAPTER			pAdapter
-	)
+)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA( pAdapter);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 
-	phy_StoreTxPowerByRateBase( pAdapter );
-	phy_ConvertTxPowerByRateInDbmToRelativeValues( pAdapter );
+	phy_txpwr_by_rate_chk_for_path_dup(pAdapter);
+	phy_StoreTxPowerByRateBase(pAdapter);
+	phy_ConvertTxPowerByRateInDbmToRelativeValues(pAdapter);
 }
 
 VOID
-PHY_SetTxPowerIndexByRateSection(
+phy_set_tx_power_index_by_rate_section(
 	IN	PADAPTER		pAdapter,
-	IN	u8				RFPath,
+	IN	enum rf_path		RFPath,
 	IN	u8				Channel,
 	IN	u8				RateSection
 )
@@ -2285,30 +2165,30 @@ PHY_SetTxPowerIndexByRateSection(
 		goto exit;
 	}
 
-	if (RateSection == CCK && pHalData->CurrentBandType != BAND_ON_2_4G)
+	if (RateSection == CCK && pHalData->current_band_type != BAND_ON_2_4G)
 		goto exit;
 
-	PHY_SetTxPowerIndexByRateArray(pAdapter, RFPath, pHalData->CurrentChannelBW, Channel,
+	PHY_SetTxPowerIndexByRateArray(pAdapter, RFPath, pHalData->current_channel_bw, Channel,
 		rates_by_sections[RateSection].rates, rates_by_sections[RateSection].rate_num);
 
 exit:
 	return;
 }
 
-BOOLEAN 
+BOOLEAN
 phy_GetChnlIndex(
-	IN	u8 	Channel,
-	OUT u8*	ChannelIdx
-	)
+	IN	u8	Channel,
+	OUT u8	*ChannelIdx
+)
 {
 	u8  i = 0;
-	BOOLEAN bIn24G=_TRUE;
+	BOOLEAN bIn24G = _TRUE;
 
 	if (Channel <= 14) {
 		bIn24G = _TRUE;
 		*ChannelIdx = Channel - 1;
 	} else {
-		bIn24G = _FALSE;	
+		bIn24G = _FALSE;
 
 		for (i = 0; i < CENTER_CH_5G_ALL_NUM; ++i) {
 			if (center_ch_5g_all[i] == Channel) {
@@ -2324,308 +2204,470 @@ phy_GetChnlIndex(
 u8
 PHY_GetTxPowerIndexBase(
 	IN	PADAPTER		pAdapter,
-	IN	u8				RFPath,
-	IN	u8				Rate,	
-	IN	CHANNEL_WIDTH	BandWidth,	
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	u8 ntx_idx,
+	IN	enum channel_width	BandWidth,
 	IN	u8				Channel,
 	OUT PBOOLEAN		bIn24G
-	)
+)
 {
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T			pDM_Odm = &pHalData->odmpriv;
-	u8					i = 0;	//default set to 1S
+	struct dm_struct			*pDM_Odm = &pHalData->odmpriv;
+	u8					i = 0;	/* default set to 1S */
 	u8					txPower = 0;
-	u8					chnlIdx = (Channel-1);
-	
-	if (HAL_IsLegalChannel(pAdapter, Channel) == _FALSE)
-	{
+	u8					chnlIdx = (Channel - 1);
+
+	if (HAL_IsLegalChannel(pAdapter, Channel) == _FALSE) {
 		chnlIdx = 0;
-		DBG_871X("Illegal channel!!\n");
+		RTW_INFO("Illegal channel!!\n");
 	}
 
 	*bIn24G = phy_GetChnlIndex(Channel, &chnlIdx);
 
-	//DBG_871X("[%s] Channel Index: %d\n", (*bIn24G?"2.4G":"5G"), chnlIdx);
-
-	if (*bIn24G) //3 ============================== 2.4 G ==============================
-	{
-		if ( IS_CCK_RATE(Rate) )
-		{
-			txPower = pHalData->Index24G_CCK_Base[RFPath][chnlIdx];	
-		}
-		else if ( MGN_6M <= Rate )
-		{				
-			txPower = pHalData->Index24G_BW40_Base[RFPath][chnlIdx];
-		}
-		else
-		{
-			DBG_871X("PHY_GetTxPowerIndexBase: INVALID Rate.\n");
+	if (0)
+		RTW_INFO("[%s] Channel Index: %d\n", (*bIn24G ? "2.4G" : "5G"), chnlIdx);
+
+	if (*bIn24G) {
+		if (IS_CCK_RATE(Rate)) {
+			/* CCK-nTX */
+			txPower = pHalData->Index24G_CCK_Base[RFPath][chnlIdx];
+			txPower += pHalData->CCK_24G_Diff[RFPath][RF_1TX];
+			if (ntx_idx >= RF_2TX)
+				txPower += pHalData->CCK_24G_Diff[RFPath][RF_2TX];
+			if (ntx_idx >= RF_3TX)
+				txPower += pHalData->CCK_24G_Diff[RFPath][RF_3TX];
+			if (ntx_idx >= RF_4TX)
+				txPower += pHalData->CCK_24G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
 
-		//DBG_871X("Base Tx power(RF-%c, Rate #%d, Channel Index %d) = 0x%X\n", 
-		//		((RFPath==0)?'A':'B'), Rate, chnlIdx, txPower);
-		
-		// OFDM-1T
-		if ( (MGN_6M <= Rate && Rate <= MGN_54M) && ! IS_CCK_RATE(Rate) )
-		{
-			txPower += pHalData->OFDM_24G_Diff[RFPath][TX_1S];
-			//DBG_871X("+PowerDiff 2.4G (RF-%c): (OFDM-1T) = (%d)\n", ((RFPath==0)?'A':'B'), pHalData->OFDM_24G_Diff[RFPath][TX_1S]);
+		txPower = pHalData->Index24G_BW40_Base[RFPath][chnlIdx];
+
+		/* OFDM-nTX */
+		if ((MGN_6M <= Rate && Rate <= MGN_54M) && !IS_CCK_RATE(Rate)) {
+			txPower += pHalData->OFDM_24G_Diff[RFPath][RF_1TX];
+			if (ntx_idx >= RF_2TX)
+				txPower += pHalData->OFDM_24G_Diff[RFPath][RF_2TX];
+			if (ntx_idx >= RF_3TX)
+				txPower += pHalData->OFDM_24G_Diff[RFPath][RF_3TX];
+			if (ntx_idx >= RF_4TX)
+				txPower += pHalData->OFDM_24G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
-		// BW20-1S, BW20-2S
-		if (BandWidth == CHANNEL_WIDTH_20)
-		{
-			if ( (MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_24G_Diff[RFPath][TX_1S];
-			if ( (MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_24G_Diff[RFPath][TX_2S];
-			if ( (MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_24G_Diff[RFPath][TX_3S];
-			if ( (MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_24G_Diff[RFPath][TX_4S];
-
-			//DBG_871X("+PowerDiff 2.4G (RF-%c): (BW20-1S, BW20-2S, BW20-3S, BW20-4S) = (%d, %d, %d, %d)\n", ((RFPath==0)?'A':(RFPath==1)?'B':(RFPath==2)?'C':'D'), 
-			//	pHalData->BW20_24G_Diff[RFPath][TX_1S], pHalData->BW20_24G_Diff[RFPath][TX_2S], 
-			//	pHalData->BW20_24G_Diff[RFPath][TX_3S], pHalData->BW20_24G_Diff[RFPath][TX_4S]);
+
+		/* BW20-nS */
+		if (BandWidth == CHANNEL_WIDTH_20) {
+			if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_24G_Diff[RFPath][RF_1TX];
+			if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_24G_Diff[RFPath][RF_2TX];
+			if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_24G_Diff[RFPath][RF_3TX];
+			if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_24G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
-		// BW40-1S, BW40-2S
-		else if (BandWidth == CHANNEL_WIDTH_40)
-		{
-			if ( (MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_1S];
-			if ( (MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_2S];
-			if ( (MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_3S];
-			if ( (MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_4S];			 
-
-			//DBG_871X("+PowerDiff 2.4G (RF-%c): (BW40-1S, BW40-2S, BW40-3S, BW40-4S) = (%d, %d, %d, %d)\n", ((RFPath==0)?'A':(RFPath==1)?'B':(RFPath==2)?'C':'D'), 
-			//	pHalData->BW40_24G_Diff[RFPath][TX_1S], pHalData->BW40_24G_Diff[RFPath][TX_2S],
-			//	pHalData->BW40_24G_Diff[RFPath][TX_3S], pHalData->BW40_24G_Diff[RFPath][TX_4S]);
+
+		/* BW40-nS */
+		if (BandWidth == CHANNEL_WIDTH_40) {
+			if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_1TX];
+			if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_2TX];
+			if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_3TX];
+			if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
-		// Willis suggest adopt BW 40M power index while in BW 80 mode
-		else if ( BandWidth == CHANNEL_WIDTH_80 )
-		{
-			if ( (MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_1S];
-			if ( (MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_2S];
-			if ( (MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_3S];
-			if ( (MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_24G_Diff[RFPath][TX_4S];
-
-			//DBG_871X("+PowerDiff 2.4G (RF-%c): (BW40-1S, BW40-2S, BW40-3S, BW40-4T) = (%d, %d, %d, %d) P.S. Current is in BW 80MHz\n", ((RFPath==0)?'A':(RFPath==1)?'B':(RFPath==2)?'C':'D'), 
-			//	pHalData->BW40_24G_Diff[RFPath][TX_1S], pHalData->BW40_24G_Diff[RFPath][TX_2S],
-			//	pHalData->BW40_24G_Diff[RFPath][TX_3S], pHalData->BW40_24G_Diff[RFPath][TX_4S]);
+
+		/* Willis suggest adopt BW 40M power index while in BW 80 mode */
+		if (BandWidth == CHANNEL_WIDTH_80) {
+			if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_1TX];
+			if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_2TX];
+			if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_3TX];
+			if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_24G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
 	}
 #ifdef CONFIG_IEEE80211_BAND_5GHZ
-	else { /* 3 ============================== 5 G ============================== */
-		if (MGN_6M <= Rate)
-		{
+	else {
+		if (Rate >= MGN_6M)
 			txPower = pHalData->Index5G_BW40_Base[RFPath][chnlIdx];
-		}
-		else
-		{
-			DBG_871X("===> mpt_ProQueryCalTxPower_Jaguar: INVALID Rate.\n");
+		else {
+			RTW_INFO("===>PHY_GetTxPowerIndexBase: INVALID Rate(0x%02x).\n", Rate);
+			goto exit;
 		}
 
-		//DBG_871X("Base Tx power(RF-%c, Rate #%d, Channel Index %d) = 0x%X\n", 
-		//	((RFPath==0)?'A':'B'), Rate, chnlIdx, txPower);
-
-		// OFDM-1T
-		if ( (MGN_6M <= Rate && Rate <= MGN_54M) && ! IS_CCK_RATE(Rate))
-		{
-			txPower += pHalData->OFDM_5G_Diff[RFPath][TX_1S];
-			//DBG_871X("+PowerDiff 5G (RF-%c): (OFDM-1T) = (%d)\n", ((RFPath==0)?'A':'B'), pHalData->OFDM_5G_Diff[RFPath][TX_1S]);
+		/* OFDM-nTX */
+		if ((MGN_6M <= Rate && Rate <= MGN_54M) && !IS_CCK_RATE(Rate)) {
+			txPower += pHalData->OFDM_5G_Diff[RFPath][RF_1TX];
+			if (ntx_idx >= RF_2TX)
+				txPower += pHalData->OFDM_5G_Diff[RFPath][RF_2TX];
+			if (ntx_idx >= RF_3TX)
+				txPower += pHalData->OFDM_5G_Diff[RFPath][RF_3TX];
+			if (ntx_idx >= RF_4TX)
+				txPower += pHalData->OFDM_5G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
-		
-		// BW20-1S, BW20-2S
-		if (BandWidth == CHANNEL_WIDTH_20)
-		{
-			if ( (MGN_MCS0 <= Rate && Rate <= MGN_MCS31)  || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_5G_Diff[RFPath][TX_1S];
-			if ( (MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_5G_Diff[RFPath][TX_2S];
-			if ( (MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_5G_Diff[RFPath][TX_3S];
-			if ( (MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW20_5G_Diff[RFPath][TX_4S];
-
-			//DBG_871X("+PowerDiff 5G (RF-%c): (BW20-1S, BW20-2S, BW20-3S, BW20-4S) = (%d, %d, %d, %d)\n", ((RFPath==0)?'A':(RFPath==1)?'B':(RFPath==2)?'C':'D'), 
-			//	pHalData->BW20_5G_Diff[RFPath][TX_1S], pHalData->BW20_5G_Diff[RFPath][TX_2S],
-			//	pHalData->BW20_5G_Diff[RFPath][TX_3S], pHalData->BW20_5G_Diff[RFPath][TX_4S]);
+
+		/* BW20-nS */
+		if (BandWidth == CHANNEL_WIDTH_20) {
+			if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31)  || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_5G_Diff[RFPath][RF_1TX];
+			if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_5G_Diff[RFPath][RF_2TX];
+			if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_5G_Diff[RFPath][RF_3TX];
+			if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW20_5G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
-		// BW40-1S, BW40-2S
-		else if (BandWidth == CHANNEL_WIDTH_40)
-		{
-			if ( (MGN_MCS0 <= Rate && Rate <= MGN_MCS31)  || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_5G_Diff[RFPath][TX_1S];
-			if ( (MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_5G_Diff[RFPath][TX_2S];
-			if ( (MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_5G_Diff[RFPath][TX_3S];
-			if ( (MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW40_5G_Diff[RFPath][TX_4S];
-
-			//DBG_871X("+PowerDiff 5G(RF-%c): (BW40-1S, BW40-2S) = (%d, %d, %d, %d)\n", ((RFPath==0)?'A':(RFPath==1)?'B':(RFPath==2)?'C':'D'), 
-			//	pHalData->BW40_5G_Diff[RFPath][TX_1S], pHalData->BW40_5G_Diff[RFPath][TX_2S],
-			//	pHalData->BW40_5G_Diff[RFPath][TX_3S], pHalData->BW40_5G_Diff[RFPath][TX_4S]);
+
+		/* BW40-nS */
+		if (BandWidth == CHANNEL_WIDTH_40) {
+			if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31)  || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_5G_Diff[RFPath][RF_1TX];
+			if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_5G_Diff[RFPath][RF_2TX];
+			if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_5G_Diff[RFPath][RF_3TX];
+			if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW40_5G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
-		// BW80-1S, BW80-2S
-		else if (BandWidth== CHANNEL_WIDTH_80)
-		{
-			// <20121220, Kordan> Get the index of array "Index5G_BW80_Base".
-			for (i = 0; i < CENTER_CH_5G_80M_NUM; ++i)
-				if (center_ch_5g_80m[i] == Channel)
+
+		/* BW80-nS */
+		if (BandWidth == CHANNEL_WIDTH_80) {
+			/* get 80MHz cch index */
+			for (i = 0; i < CENTER_CH_5G_80M_NUM; ++i) {
+				if (center_ch_5g_80m[i] == Channel) {
 					chnlIdx = i;
+					break;
+				}
+			}
+			if (i >= CENTER_CH_5G_80M_NUM) {
+				rtw_warn_on(1);
+				txPower = 0;
+				goto exit;
+			}
 
 			txPower = pHalData->Index5G_BW80_Base[RFPath][chnlIdx];
 
-			if ( (MGN_MCS0 <= Rate && Rate <= MGN_MCS31)  || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += + pHalData->BW80_5G_Diff[RFPath][TX_1S];
-			if ( (MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW80_5G_Diff[RFPath][TX_2S];
-			if ( (MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW80_5G_Diff[RFPath][TX_3S];
-			if ( (MGN_MCS23 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
-				txPower += pHalData->BW80_5G_Diff[RFPath][TX_4S];
-
-			//DBG_871X("+PowerDiff 5G(RF-%c): (BW80-1S, BW80-2S, BW80-3S, BW80-4S) = (%d, %d, %d, %d)\n",((RFPath==0)?'A':(RFPath==1)?'B':(RFPath==2)?'C':'D'), 
-			//	pHalData->BW80_5G_Diff[RFPath][TX_1S], pHalData->BW80_5G_Diff[RFPath][TX_2S],
-			//	pHalData->BW80_5G_Diff[RFPath][TX_3S], pHalData->BW80_5G_Diff[RFPath][TX_4S]);
+			if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31)  || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += + pHalData->BW80_5G_Diff[RFPath][RF_1TX];
+			if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW80_5G_Diff[RFPath][RF_2TX];
+			if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW80_5G_Diff[RFPath][RF_3TX];
+			if ((MGN_MCS23 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
+				txPower += pHalData->BW80_5G_Diff[RFPath][RF_4TX];
+			goto exit;
 		}
+
+		/* TODO: BW160-nS */
+		rtw_warn_on(1);
 	}
 #endif /* CONFIG_IEEE80211_BAND_5GHZ */
 
-	return txPower;	
+exit:
+	return txPower;
 }
 
 s8
-PHY_GetTxPowerTrackingOffset( 
+PHY_GetTxPowerTrackingOffset(
 	PADAPTER	pAdapter,
-	u8			RFPath,
+	enum rf_path	RFPath,
 	u8			Rate
-	)
+)
 {
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T			pDM_Odm = &pHalData->odmpriv;	
+	struct dm_struct			*pDM_Odm = &pHalData->odmpriv;
 	s8	offset = 0;
-	
-	if( pDM_Odm->RFCalibrateInfo.TxPowerTrackControl  == _FALSE)
+
+	if (pDM_Odm->rf_calibrate_info.txpowertrack_control  == _FALSE)
 		return offset;
-	
-	if ((Rate == MGN_1M) ||(Rate == MGN_2M)||(Rate == MGN_5_5M)||(Rate == MGN_11M))
-	{ 
-		offset = pDM_Odm->RFCalibrateInfo.Remnant_CCKSwingIdx;
-		/*DBG_871X("+Remnant_CCKSwingIdx = 0x%x\n", RFPath, Rate, pRFCalibrateInfo->Remnant_CCKSwingIdx);*/
-	}
-	else
-	{
-		offset = pDM_Odm->RFCalibrateInfo.Remnant_OFDMSwingIdx[RFPath]; 
-		/*DBG_871X("+Remanant_OFDMSwingIdx[RFPath %u][Rate 0x%x] = 0x%x\n", RFPath, Rate, pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath]);	*/	
-		
+
+	if ((Rate == MGN_1M) || (Rate == MGN_2M) || (Rate == MGN_5_5M) || (Rate == MGN_11M)) {
+		offset = pDM_Odm->rf_calibrate_info.remnant_cck_swing_idx;
+		/*RTW_INFO("+Remnant_CCKSwingIdx = 0x%x\n", RFPath, Rate, pRFCalibrateInfo->Remnant_CCKSwingIdx);*/
+	} else {
+		offset = pDM_Odm->rf_calibrate_info.remnant_ofdm_swing_idx[RFPath];
+		/*RTW_INFO("+Remanant_OFDMSwingIdx[RFPath %u][Rate 0x%x] = 0x%x\n", RFPath, Rate, pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath]);	*/
+
 	}
 
 	return offset;
 }
 
+/*The same as MRateToHwRate in hal_com.c*/
 u8
 PHY_GetRateIndexOfTxPowerByRate(
 	IN	u8		Rate
-	)
+)
 {
 	u8	index = 0;
-	switch ( Rate )
-	{
-		case MGN_1M: index = 0; break;
-		case MGN_2M: index = 1; break;
-		case MGN_5_5M: index = 2; break;
-		case MGN_11M: index = 3; break;
-		case MGN_6M: index = 4; break;
-		case MGN_9M: index = 5; break;
-		case MGN_12M: index = 6; break;
-		case MGN_18M: index = 7; break;
-		case MGN_24M: index = 8; break;
-		case MGN_36M: index = 9; break;
-		case MGN_48M: index = 10; break;
-		case MGN_54M: index = 11; break;
-		case MGN_MCS0: index = 12; break;
-		case MGN_MCS1: index = 13; break;
-		case MGN_MCS2: index = 14; break;
-		case MGN_MCS3: index = 15; break;
-		case MGN_MCS4: index = 16; break;
-		case MGN_MCS5: index = 17; break;
-		case MGN_MCS6: index = 18; break;
-		case MGN_MCS7: index = 19; break;
-		case MGN_MCS8: index = 20; break;
-		case MGN_MCS9: index = 21; break;
-		case MGN_MCS10: index = 22; break;
-		case MGN_MCS11: index = 23; break;
-		case MGN_MCS12: index = 24; break;
-		case MGN_MCS13: index = 25; break;
-		case MGN_MCS14: index = 26; break;
-		case MGN_MCS15: index = 27; break;
-		case MGN_MCS16: index = 28; break;
-		case MGN_MCS17: index = 29; break;
-		case MGN_MCS18: index = 30; break;
-		case MGN_MCS19: index = 31; break;
-		case MGN_MCS20: index = 32; break;
-		case MGN_MCS21: index = 33; break;
-		case MGN_MCS22: index = 34; break;
-		case MGN_MCS23: index = 35; break;
-		case MGN_MCS24: index = 36; break;
-		case MGN_MCS25: index = 37; break;
-		case MGN_MCS26: index = 38; break;
-		case MGN_MCS27: index = 39; break;
-		case MGN_MCS28: index = 40; break;
-		case MGN_MCS29: index = 41; break;
-		case MGN_MCS30: index = 42; break;
-		case MGN_MCS31: index = 43; break;
-		case MGN_VHT1SS_MCS0: index = 44; break;
-		case MGN_VHT1SS_MCS1: index = 45; break;
-		case MGN_VHT1SS_MCS2: index = 46; break;
-		case MGN_VHT1SS_MCS3: index = 47; break;
-		case MGN_VHT1SS_MCS4: index = 48; break;
-		case MGN_VHT1SS_MCS5: index = 49; break;
-		case MGN_VHT1SS_MCS6: index = 50; break;
-		case MGN_VHT1SS_MCS7: index = 51; break;
-		case MGN_VHT1SS_MCS8: index = 52; break;
-		case MGN_VHT1SS_MCS9: index = 53; break;
-		case MGN_VHT2SS_MCS0: index = 54; break;
-		case MGN_VHT2SS_MCS1: index = 55; break;
-		case MGN_VHT2SS_MCS2: index = 56; break;
-		case MGN_VHT2SS_MCS3: index = 57; break;
-		case MGN_VHT2SS_MCS4: index = 58; break;
-		case MGN_VHT2SS_MCS5: index = 59; break;
-		case MGN_VHT2SS_MCS6: index = 60; break;
-		case MGN_VHT2SS_MCS7: index = 61; break;
-		case MGN_VHT2SS_MCS8: index = 62; break;
-		case MGN_VHT2SS_MCS9: index = 63; break;
-		case MGN_VHT3SS_MCS0: index = 64; break;
-		case MGN_VHT3SS_MCS1: index = 65; break;
-		case MGN_VHT3SS_MCS2: index = 66; break;
-		case MGN_VHT3SS_MCS3: index = 67; break;
-		case MGN_VHT3SS_MCS4: index = 68; break;
-		case MGN_VHT3SS_MCS5: index = 69; break;
-		case MGN_VHT3SS_MCS6: index = 70; break;
-		case MGN_VHT3SS_MCS7: index = 71; break;
-		case MGN_VHT3SS_MCS8: index = 72; break;
-		case MGN_VHT3SS_MCS9: index = 73; break;
-		case MGN_VHT4SS_MCS0: index = 74; break;
-		case MGN_VHT4SS_MCS1: index = 75; break;
-		case MGN_VHT4SS_MCS2: index = 76; break;
-		case MGN_VHT4SS_MCS3: index = 77; break;
-		case MGN_VHT4SS_MCS4: index = 78; break;
-		case MGN_VHT4SS_MCS5: index = 79; break;
-		case MGN_VHT4SS_MCS6: index = 80; break;
-		case MGN_VHT4SS_MCS7: index = 81; break;
-		case MGN_VHT4SS_MCS8: index = 82; break;
-		case MGN_VHT4SS_MCS9: index = 83; break;
-		default:
-			DBG_871X("Invalid rate 0x%x in %s\n", Rate, __FUNCTION__ );
-			break;
+	switch (Rate) {
+	case MGN_1M:
+		index = 0;
+		break;
+	case MGN_2M:
+		index = 1;
+		break;
+	case MGN_5_5M:
+		index = 2;
+		break;
+	case MGN_11M:
+		index = 3;
+		break;
+	case MGN_6M:
+		index = 4;
+		break;
+	case MGN_9M:
+		index = 5;
+		break;
+	case MGN_12M:
+		index = 6;
+		break;
+	case MGN_18M:
+		index = 7;
+		break;
+	case MGN_24M:
+		index = 8;
+		break;
+	case MGN_36M:
+		index = 9;
+		break;
+	case MGN_48M:
+		index = 10;
+		break;
+	case MGN_54M:
+		index = 11;
+		break;
+	case MGN_MCS0:
+		index = 12;
+		break;
+	case MGN_MCS1:
+		index = 13;
+		break;
+	case MGN_MCS2:
+		index = 14;
+		break;
+	case MGN_MCS3:
+		index = 15;
+		break;
+	case MGN_MCS4:
+		index = 16;
+		break;
+	case MGN_MCS5:
+		index = 17;
+		break;
+	case MGN_MCS6:
+		index = 18;
+		break;
+	case MGN_MCS7:
+		index = 19;
+		break;
+	case MGN_MCS8:
+		index = 20;
+		break;
+	case MGN_MCS9:
+		index = 21;
+		break;
+	case MGN_MCS10:
+		index = 22;
+		break;
+	case MGN_MCS11:
+		index = 23;
+		break;
+	case MGN_MCS12:
+		index = 24;
+		break;
+	case MGN_MCS13:
+		index = 25;
+		break;
+	case MGN_MCS14:
+		index = 26;
+		break;
+	case MGN_MCS15:
+		index = 27;
+		break;
+	case MGN_MCS16:
+		index = 28;
+		break;
+	case MGN_MCS17:
+		index = 29;
+		break;
+	case MGN_MCS18:
+		index = 30;
+		break;
+	case MGN_MCS19:
+		index = 31;
+		break;
+	case MGN_MCS20:
+		index = 32;
+		break;
+	case MGN_MCS21:
+		index = 33;
+		break;
+	case MGN_MCS22:
+		index = 34;
+		break;
+	case MGN_MCS23:
+		index = 35;
+		break;
+	case MGN_MCS24:
+		index = 36;
+		break;
+	case MGN_MCS25:
+		index = 37;
+		break;
+	case MGN_MCS26:
+		index = 38;
+		break;
+	case MGN_MCS27:
+		index = 39;
+		break;
+	case MGN_MCS28:
+		index = 40;
+		break;
+	case MGN_MCS29:
+		index = 41;
+		break;
+	case MGN_MCS30:
+		index = 42;
+		break;
+	case MGN_MCS31:
+		index = 43;
+		break;
+	case MGN_VHT1SS_MCS0:
+		index = 44;
+		break;
+	case MGN_VHT1SS_MCS1:
+		index = 45;
+		break;
+	case MGN_VHT1SS_MCS2:
+		index = 46;
+		break;
+	case MGN_VHT1SS_MCS3:
+		index = 47;
+		break;
+	case MGN_VHT1SS_MCS4:
+		index = 48;
+		break;
+	case MGN_VHT1SS_MCS5:
+		index = 49;
+		break;
+	case MGN_VHT1SS_MCS6:
+		index = 50;
+		break;
+	case MGN_VHT1SS_MCS7:
+		index = 51;
+		break;
+	case MGN_VHT1SS_MCS8:
+		index = 52;
+		break;
+	case MGN_VHT1SS_MCS9:
+		index = 53;
+		break;
+	case MGN_VHT2SS_MCS0:
+		index = 54;
+		break;
+	case MGN_VHT2SS_MCS1:
+		index = 55;
+		break;
+	case MGN_VHT2SS_MCS2:
+		index = 56;
+		break;
+	case MGN_VHT2SS_MCS3:
+		index = 57;
+		break;
+	case MGN_VHT2SS_MCS4:
+		index = 58;
+		break;
+	case MGN_VHT2SS_MCS5:
+		index = 59;
+		break;
+	case MGN_VHT2SS_MCS6:
+		index = 60;
+		break;
+	case MGN_VHT2SS_MCS7:
+		index = 61;
+		break;
+	case MGN_VHT2SS_MCS8:
+		index = 62;
+		break;
+	case MGN_VHT2SS_MCS9:
+		index = 63;
+		break;
+	case MGN_VHT3SS_MCS0:
+		index = 64;
+		break;
+	case MGN_VHT3SS_MCS1:
+		index = 65;
+		break;
+	case MGN_VHT3SS_MCS2:
+		index = 66;
+		break;
+	case MGN_VHT3SS_MCS3:
+		index = 67;
+		break;
+	case MGN_VHT3SS_MCS4:
+		index = 68;
+		break;
+	case MGN_VHT3SS_MCS5:
+		index = 69;
+		break;
+	case MGN_VHT3SS_MCS6:
+		index = 70;
+		break;
+	case MGN_VHT3SS_MCS7:
+		index = 71;
+		break;
+	case MGN_VHT3SS_MCS8:
+		index = 72;
+		break;
+	case MGN_VHT3SS_MCS9:
+		index = 73;
+		break;
+	case MGN_VHT4SS_MCS0:
+		index = 74;
+		break;
+	case MGN_VHT4SS_MCS1:
+		index = 75;
+		break;
+	case MGN_VHT4SS_MCS2:
+		index = 76;
+		break;
+	case MGN_VHT4SS_MCS3:
+		index = 77;
+		break;
+	case MGN_VHT4SS_MCS4:
+		index = 78;
+		break;
+	case MGN_VHT4SS_MCS5:
+		index = 79;
+		break;
+	case MGN_VHT4SS_MCS6:
+		index = 80;
+		break;
+	case MGN_VHT4SS_MCS7:
+		index = 81;
+		break;
+	case MGN_VHT4SS_MCS8:
+		index = 82;
+		break;
+	case MGN_VHT4SS_MCS9:
+		index = 83;
+		break;
+	default:
+		RTW_INFO("Invalid rate 0x%x in %s\n", Rate, __FUNCTION__);
+		break;
 	};
 
 	return index;
@@ -2633,35 +2675,30 @@ PHY_GetRateIndexOfTxPowerByRate(
 
 s8
 _PHY_GetTxPowerByRate(
-	IN	PADAPTER	pAdapter, 
-	IN	u8			Band, 
-	IN	u8			RFPath, 
-	IN	u8			TxNum, 
+	IN	PADAPTER	pAdapter,
+	IN	u8			Band,
+	IN	enum rf_path	RFPath,
 	IN	u8			Rate
-	)
+)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
 	s8 value = 0;
 	u8 rateIndex = PHY_GetRateIndexOfTxPowerByRate(Rate);
 
 	if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
-		DBG_871X("Invalid band %d in %s\n", Band, __func__);
-		goto exit;
-	}
-	if (RFPath > ODM_RF_PATH_D) {
-		DBG_871X("Invalid RfPath %d in %s\n", RFPath, __func__);
+		RTW_INFO("Invalid band %d in %s\n", Band, __func__);
 		goto exit;
 	}
-	if (TxNum >= RF_MAX_TX_NUM) {
-		DBG_871X("Invalid TxNum %d in %s\n", TxNum, __func__);
+	if (RFPath > RF_PATH_D) {
+		RTW_INFO("Invalid RfPath %d in %s\n", RFPath, __func__);
 		goto exit;
 	}
 	if (rateIndex >= TX_PWR_BY_RATE_NUM_RATE) {
-		DBG_871X("Invalid RateIndex %d in %s\n", rateIndex, __func__);
+		RTW_INFO("Invalid RateIndex %d in %s\n", rateIndex, __func__);
 		goto exit;
 	}
 
-	value = pHalData->TxPwrByRateOffset[Band][RFPath][TxNum][rateIndex];
+	value = pHalData->TxPwrByRateOffset[Band][RFPath][rateIndex];
 
 exit:
 	return value;
@@ -2672,86 +2709,74 @@ s8
 PHY_GetTxPowerByRate(
 	IN	PADAPTER	pAdapter,
 	IN	u8			Band,
-	IN	u8			RFPath,
-	IN	u8			TxNum,
+	IN	enum rf_path	RFPath,
 	IN	u8			Rate
-	)
+)
 {
 	if (!phy_is_tx_power_by_rate_needed(pAdapter))
 		return 0;
 
-	return _PHY_GetTxPowerByRate(pAdapter, Band, RFPath, TxNum, Rate);
+	return _PHY_GetTxPowerByRate(pAdapter, Band, RFPath, Rate);
 }
 
 VOID
-PHY_SetTxPowerByRate( 
-	IN	PADAPTER	pAdapter, 
-	IN	u8			Band, 
-	IN	u8			RFPath, 
-	IN	u8			TxNum, 
+PHY_SetTxPowerByRate(
+	IN	PADAPTER	pAdapter,
+	IN	u8			Band,
+	IN	enum rf_path	RFPath,
 	IN	u8			Rate,
 	IN	s8			Value
-	)
+)
 {
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA( pAdapter );
-	u8	rateIndex = PHY_GetRateIndexOfTxPowerByRate( Rate );
-	
-	if ( Band != BAND_ON_2_4G && Band != BAND_ON_5G )
-	{
-		DBG_871X("Invalid band %d in %s\n", Band, __FUNCTION__ );
-		return;
-	}
-	if ( RFPath > ODM_RF_PATH_D )
-	{
-		DBG_871X("Invalid RfPath %d in %s\n", RFPath, __FUNCTION__ );
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	u8	rateIndex = PHY_GetRateIndexOfTxPowerByRate(Rate);
+
+	if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
+		RTW_INFO("Invalid band %d in %s\n", Band, __FUNCTION__);
 		return;
 	}
-	if ( TxNum >= RF_MAX_TX_NUM )
-	{
-		DBG_871X( "Invalid TxNum %d in %s\n", TxNum, __FUNCTION__ );
+	if (RFPath > RF_PATH_D) {
+		RTW_INFO("Invalid RfPath %d in %s\n", RFPath, __FUNCTION__);
 		return;
 	}
-	if ( rateIndex >= TX_PWR_BY_RATE_NUM_RATE )
-	{
-		DBG_871X("Invalid RateIndex %d in %s\n", rateIndex, __FUNCTION__ );
+	if (rateIndex >= TX_PWR_BY_RATE_NUM_RATE) {
+		RTW_INFO("Invalid RateIndex %d in %s\n", rateIndex, __FUNCTION__);
 		return;
 	}
 
-	pHalData->TxPwrByRateOffset[Band][RFPath][TxNum][rateIndex] = Value;
+	pHalData->TxPwrByRateOffset[Band][RFPath][rateIndex] = Value;
 }
 
 VOID
-PHY_SetTxPowerLevelByPath(
+phy_set_tx_power_level_by_path(
 	IN	PADAPTER	Adapter,
 	IN	u8			channel,
 	IN	u8			path
-	)
+)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	BOOLEAN bIsIn24G = (pHalData->CurrentBandType == BAND_ON_2_4G );
+	BOOLEAN bIsIn24G = (pHalData->current_band_type == BAND_ON_2_4G);
 
-	//if ( pMgntInfo->RegNByteAccess == 0 )
+	/* if ( pMgntInfo->RegNByteAccess == 0 ) */
 	{
-		if ( bIsIn24G )
-			PHY_SetTxPowerIndexByRateSection( Adapter, path, channel, CCK );
-		
-		PHY_SetTxPowerIndexByRateSection( Adapter, path, channel, OFDM );
-		PHY_SetTxPowerIndexByRateSection( Adapter, path, channel, HT_MCS0_MCS7 );
+		if (bIsIn24G)
+			phy_set_tx_power_index_by_rate_section(Adapter, path, channel, CCK);
+
+		phy_set_tx_power_index_by_rate_section(Adapter, path, channel, OFDM);
+		phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS0_MCS7);
 
 		if (IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter))
-			PHY_SetTxPowerIndexByRateSection(Adapter, path, channel, VHT_1SSMCS0_1SSMCS9);
+			phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_1SSMCS0_1SSMCS9);
 
-		if (pHalData->NumTotalRFPath >= 2)
-		{
-			PHY_SetTxPowerIndexByRateSection( Adapter, path, channel, HT_MCS8_MCS15 );
+		if (pHalData->NumTotalRFPath >= 2) {
+			phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS8_MCS15);
 
 			if (IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter))
-				PHY_SetTxPowerIndexByRateSection(Adapter, path, channel, VHT_2SSMCS0_2SSMCS9);
+				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_2SSMCS0_2SSMCS9);
 
-			if (IS_HARDWARE_TYPE_8814A(Adapter))
-			{
-				PHY_SetTxPowerIndexByRateSection( Adapter, path, channel, HT_MCS16_MCS23 );
-				PHY_SetTxPowerIndexByRateSection( Adapter, path, channel, VHT_3SSMCS0_3SSMCS9 );
+			if (IS_HARDWARE_TYPE_8814A(Adapter)) {
+				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS16_MCS23);
+				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_3SSMCS0_3SSMCS9);
 			}
 		}
 	}
@@ -2764,172 +2789,278 @@ PHY_SetTxPowerLevelByPath(
 VOID
 PHY_SetTxPowerIndexByRateArray(
 	IN	PADAPTER			pAdapter,
-	IN 	u8					RFPath,
-	IN	CHANNEL_WIDTH		BandWidth,	
+	IN	enum rf_path			RFPath,
+	IN	enum channel_width	BandWidth,
 	IN	u8					Channel,
-	IN	u8*					Rates,
+	IN	u8					*Rates,
 	IN	u8					RateArraySize
-	)
+)
 {
 	u32	powerIndex = 0;
 	int	i = 0;
 
-	for (i = 0; i < RateArraySize; ++i) 
-	{
+	for (i = 0; i < RateArraySize; ++i) {
 #if DBG_TX_POWER_IDX
 		struct txpwr_idx_comp tic;
 
 		powerIndex = rtw_hal_get_tx_power_index(pAdapter, RFPath, Rates[i], BandWidth, Channel, &tic);
-		RTW_INFO("TXPWR: [%c][%s]ch:%u, %s, pwr_idx:%u = %u + (%d=%d:%d) + (%d) + (%d)\n"
-			, rf_path_char(RFPath), ch_width_str(BandWidth), Channel, MGN_RATE_STR(Rates[i])
+		RTW_INFO("TXPWR: [%c][%s]ch:%u, %s %uT, pwr_idx:%u = %u + (%d=%d:%d) + (%d) + (%d)\n"
+			, rf_path_char(RFPath), ch_width_str(BandWidth), Channel, MGN_RATE_STR(Rates[i]), tic.ntx_idx + 1
 			, powerIndex, tic.base, (tic.by_rate > tic.limit ? tic.limit : tic.by_rate), tic.by_rate, tic.limit, tic.tpt, tic.ebias);
 #else
-		powerIndex = PHY_GetTxPowerIndex(pAdapter, RFPath, Rates[i], BandWidth, Channel);
+		powerIndex = phy_get_tx_power_index(pAdapter, RFPath, Rates[i], BandWidth, Channel);
 #endif
 		PHY_SetTxPowerIndex(pAdapter, powerIndex, RFPath, Rates[i]);
 	}
 }
 
-s8
-phy_GetWorldWideLimit(
-	s8* LimitTable
-)
-{
-	s8	min = LimitTable[0];
-	u8	i = 0;
-	
-	for (i = 0; i < MAX_REGULATION_NUM; ++i) {
-		if (LimitTable[i] < min)
-			min = LimitTable[i];
-	}
-
-	return min;
-}
+#ifdef CONFIG_TXPWR_LIMIT
+const char *const _txpwr_lmt_rs_str[] = {
+	"CCK",
+	"OFDM",
+	"HT",
+	"VHT",
+	"UNKNOWN",
+};
 
-s8
+static s8
 phy_GetChannelIndexOfTxPowerLimit(
 	IN	u8			Band,
 	IN	u8			Channel
-	)
+)
 {
 	s8	channelIndex = -1;
 	u8	i = 0;
 
-	if (Band == BAND_ON_2_4G) {
+	if (Band == BAND_ON_2_4G)
 		channelIndex = Channel - 1;
-	} else if (Band == BAND_ON_5G) {
+	else if (Band == BAND_ON_5G) {
 		for (i = 0; i < CENTER_CH_5G_ALL_NUM; ++i) {
 			if (center_ch_5g_all[i] == Channel)
 				channelIndex = i;
 		}
-	} else {
-		DBG_871X_LEVEL(_drv_always_, "Invalid Band %d in %s\n", Band, __func__);
-	}
+	} else
+		RTW_PRINT("Invalid Band %d in %s\n", Band, __func__);
 
 	if (channelIndex == -1)
-		DBG_871X_LEVEL(_drv_always_, "Invalid Channel %d of Band %d in %s\n", Channel, Band, __func__);
+		RTW_PRINT("Invalid Channel %d of Band %d in %s\n", Channel, Band, __func__);
 
 	return channelIndex;
 }
 
-static s8 _phy_get_txpwr_lmt(
+/*
+* return txpwr limit absolute value
+* MAX_POWER_INDEX is returned when NO limit
+*/
+s8 phy_get_txpwr_lmt_abs(
 	IN	PADAPTER			Adapter,
-	IN	u32					RegPwrTblSel,
+	IN	const char			*regd_name,
 	IN	BAND_TYPE			Band,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					RfPath,
-	IN	u8					DataRate,
-	IN	u8					Channel,
-	BOOLEAN no_sc
+	IN	enum channel_width		bw,
+	u8 tlrs,
+	u8 ntx_idx,
+	u8 cch,
+	u8 lock
 )
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(Adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(Adapter);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(Adapter);
-	s8 regulation = -1, bw = -1, rs = -1;
-	u8 cch = 0;
-	u8 bw_bmp = 0;
-	s8 min_lmt = MAX_POWER_INDEX;
-	s8 tmp_lmt;
-	u8 final_bw = Bandwidth, final_cch = Channel;
+	struct txpwr_lmt_ent *ent = NULL;
+	_irqL irqL;
+	_list *cur, *head;
+	s8 ch_idx;
+	u8 is_ww_regd = 0;
+	s8 lmt = MAX_POWER_INDEX;
 
 	if ((Adapter->registrypriv.RegEnableTxPowerLimit == 2 && hal_data->EEPROMRegulatory != 1) ||
 		Adapter->registrypriv.RegEnableTxPowerLimit == 0)
 		goto exit;
 
-	switch (RegPwrTblSel) {
-	case 1:
-		regulation = TXPWR_LMT_ETSI;
-		break;
-	case 2:
-		regulation = TXPWR_LMT_MKK;
-		break;
-	case 3:
-		regulation = TXPWR_LMT_FCC;
-		break;
-	case 4:
-		regulation = TXPWR_LMT_WW;
-		break;
-	default:
-		regulation = (Band == BAND_ON_2_4G) ? hal_data->Regulation2_4G : hal_data->Regulation5G;
-		break;
-	}
-
 	if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
 		RTW_ERR("%s invalid band:%u\n", __func__, Band);
 		rtw_warn_on(1);
 		goto exit;
 	}
 
-	if (IS_CCK_RATE(DataRate))
-		rs = CCK;
-	else if (IS_OFDM_RATE(DataRate))
-		rs = OFDM;
-	else if (IS_HT1SS_RATE(DataRate))
-		rs = HT_1SS;
-	else if (IS_HT2SS_RATE(DataRate))
-		rs = HT_2SS;
-	else if (IS_HT3SS_RATE(DataRate))
-		rs = HT_3SS;
-	else if (IS_HT4SS_RATE(DataRate))
-		rs = HT_4SS;
-	else if (IS_VHT1SS_RATE(DataRate))
-		rs = VHT_1SS;
-	else if (IS_VHT2SS_RATE(DataRate))
-		rs = VHT_2SS;
-	else if (IS_VHT3SS_RATE(DataRate))
-		rs = VHT_3SS;
-	else if (IS_VHT4SS_RATE(DataRate))
-		rs = VHT_4SS;
+	if (Band == BAND_ON_5G  && tlrs == TXPWR_LMT_RS_CCK) {
+		RTW_ERR("5G has no CCK\n");
+		goto exit;
+	}
+
+	if (lock)
+		_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+	if (!regd_name) /* no regd_name specified, use currnet */
+		regd_name = rfctl->regd_name;
+
+	if (rfctl->txpwr_regd_num == 0
+		|| strcmp(regd_name, regd_str(TXPWR_LMT_NONE)) == 0)
+		goto release_lock;
+
+	if (strcmp(regd_name, regd_str(TXPWR_LMT_WW)) == 0)
+		is_ww_regd = 1;
+
+	if (!is_ww_regd) {
+		ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_name);
+		if (!ent)
+			goto release_lock;
+	}
+
+	ch_idx = phy_GetChannelIndexOfTxPowerLimit(Band, cch);
+	if (ch_idx == -1)
+		goto release_lock;
+
+	if (Band == BAND_ON_2_4G) {
+		if (!is_ww_regd) {
+			lmt = ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx];
+			if (lmt != -MAX_POWER_INDEX)
+				goto release_lock;
+		}
+
+		/* search for min value for WW regd or WW limit */
+		lmt = MAX_POWER_INDEX;
+		head = &rfctl->txpwr_lmt_list;
+		cur = get_next(head);
+		while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+			ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+			cur = get_next(cur);
+			if (ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx] != -MAX_POWER_INDEX)
+				lmt = rtw_min(lmt, ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx]);
+		}
+	}
+	#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	else if (Band == BAND_ON_5G) {
+		if (!is_ww_regd) {
+			lmt = ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx];
+			if (lmt != -MAX_POWER_INDEX)
+				goto release_lock;
+		}
+
+		/* search for min value for WW regd or WW limit */
+		lmt = MAX_POWER_INDEX;
+		head = &rfctl->txpwr_lmt_list;
+		cur = get_next(head);
+		while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+			ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+			cur = get_next(cur);
+			if (ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx] != -MAX_POWER_INDEX)
+				lmt = rtw_min(lmt, ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx]);
+		}
+	}
+	#endif
+
+release_lock:
+	if (lock)
+		_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
+
+exit:
+	return lmt;
+}
+
+/*
+* return txpwr limit diff value
+* MAX_POWER_INDEX is returned when NO limit
+*/
+inline s8 phy_get_txpwr_lmt(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 rfpath, u8 rs, u8 ntx_idx, u8 cch, u8 lock
+)
+{
+	u8 tlrs;
+	s8 lmt = MAX_POWER_INDEX;
+
+	if (IS_CCK_RATE_SECTION(rs))
+		tlrs = TXPWR_LMT_RS_CCK;
+	else if (IS_OFDM_RATE_SECTION(rs))
+		tlrs = TXPWR_LMT_RS_OFDM;
+	else if (IS_HT_RATE_SECTION(rs))
+		tlrs = TXPWR_LMT_RS_HT;
+	else if (IS_VHT_RATE_SECTION(rs))
+		tlrs = TXPWR_LMT_RS_VHT;
 	else {
-		RTW_ERR("%s invalid rate 0x%x\n", __func__, DataRate);
+		RTW_ERR("%s invalid rs %u\n", __func__, rs);
 		rtw_warn_on(1);
 		goto exit;
 	}
 
-	if (Band == BAND_ON_5G  && rs == CCK) {
-		RTW_ERR("Wrong rate No CCK(0x%x) in 5G Band\n", DataRate);
+	lmt = phy_get_txpwr_lmt_abs(adapter, regd_name, band, bw, tlrs, ntx_idx, cch, lock);
+
+	if (lmt != MAX_POWER_INDEX) {
+		/* return diff value */
+		lmt = lmt - PHY_GetTxPowerByRateBase(adapter, band, rfpath, rs);
+	}
+
+exit:
+	return lmt;
+}
+
+/*
+* May search for secondary channels for min limit
+* return txpwr limit diff value
+*/
+s8
+PHY_GetTxPowerLimit(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 rfpath, u8 rate, u8 ntx_idx, u8 cch)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	BOOLEAN no_sc = _FALSE;
+	s8 tlrs = -1, rs = -1;
+	s8 lmt = MAX_POWER_INDEX;
+	u8 tmp_cch = 0;
+	u8 tmp_bw;
+	u8 bw_bmp = 0;
+	s8 min_lmt = MAX_POWER_INDEX;
+	u8 final_bw = bw, final_cch = cch;
+	_irqL irqL;
+
+#ifdef CONFIG_MP_INCLUDED
+	/* MP mode channel don't use secondary channel */
+	if (rtw_mp_mode_check(adapter) == _TRUE)
+		no_sc = _TRUE;
+#endif
+	if (IS_CCK_RATE(rate)) {
+		tlrs = TXPWR_LMT_RS_CCK;
+		rs = CCK;
+	} else if (IS_OFDM_RATE(rate)) {
+		tlrs = TXPWR_LMT_RS_OFDM;
+		rs = OFDM;
+	} else if (IS_HT_RATE(rate)) {
+		tlrs = TXPWR_LMT_RS_HT;
+		rs = HT_1SS + (IS_HT1SS_RATE(rate) ? 0 : IS_HT2SS_RATE(rate) ? 1 : IS_HT3SS_RATE(rate) ? 2 : IS_HT4SS_RATE(rate) ? 3 : 0);
+	} else if (IS_VHT_RATE(rate)) {
+		tlrs = TXPWR_LMT_RS_VHT;
+		rs = VHT_1SS + (IS_VHT1SS_RATE(rate) ? 0 : IS_VHT2SS_RATE(rate) ? 1 : IS_VHT3SS_RATE(rate) ? 2 : IS_VHT4SS_RATE(rate) ? 3 : 0);
+	} else {
+		RTW_ERR("%s invalid rate 0x%x\n", __func__, rate);
+		rtw_warn_on(1);
 		goto exit;
 	}
 
 	if (no_sc == _TRUE) {
 		/* use the input center channel and bandwidth directly */
-		cch = Channel;
-		bw_bmp = ch_width_to_bw_cap(Bandwidth);
+		tmp_cch = cch;
+		bw_bmp = ch_width_to_bw_cap(bw);
 	} else {
 		/*
 		* find the possible tx bandwidth bmp for this rate, and then will get center channel for each bandwidth
 		* if no possible tx bandwidth bmp, select valid bandwidth up to current RF bandwidth into bmp
 		*/
-		if (rs == CCK || rs == OFDM)
+		if (tlrs == TXPWR_LMT_RS_CCK || tlrs == TXPWR_LMT_RS_OFDM)
 			bw_bmp = BW_CAP_20M; /* CCK, OFDM only BW 20M */
-		else if (IS_HT_RATE_SECTION(rs)) {
-			bw_bmp = rtw_get_tx_bw_bmp_of_ht_rate(dvobj, DataRate, Bandwidth);
+		else if (tlrs == TXPWR_LMT_RS_HT) {
+			bw_bmp = rtw_get_tx_bw_bmp_of_ht_rate(dvobj, rate, bw);
 			if (bw_bmp == 0)
-				bw_bmp = ch_width_to_bw_cap(Bandwidth > CHANNEL_WIDTH_40 ? CHANNEL_WIDTH_40 : Bandwidth);
-		} else if (IS_VHT_RATE_SECTION(rs)) {
-			bw_bmp = rtw_get_tx_bw_bmp_of_vht_rate(dvobj, DataRate, Bandwidth);
+				bw_bmp = ch_width_to_bw_cap(bw > CHANNEL_WIDTH_40 ? CHANNEL_WIDTH_40 : bw);
+		} else if (tlrs == TXPWR_LMT_RS_VHT) {
+			bw_bmp = rtw_get_tx_bw_bmp_of_vht_rate(dvobj, rate, bw);
 			if (bw_bmp == 0)
-				bw_bmp = ch_width_to_bw_cap(Bandwidth > CHANNEL_WIDTH_160 ? CHANNEL_WIDTH_160 : Bandwidth);
+				bw_bmp = ch_width_to_bw_cap(bw > CHANNEL_WIDTH_160 ? CHANNEL_WIDTH_160 : bw);
 		} else
 			rtw_warn_on(1);
 	}
@@ -2937,165 +3068,189 @@ static s8 _phy_get_txpwr_lmt(
 	if (bw_bmp == 0)
 		goto exit;
 
-	/* loop for each possible tx bandwidth to find minimum limit */
-	for (bw = CHANNEL_WIDTH_20; bw <= Bandwidth; bw++) {
-		s8 ch_idx;
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
 
-		if (!(ch_width_to_bw_cap(bw) & bw_bmp))
+	/* loop for each possible tx bandwidth to find minimum limit */
+	for (tmp_bw = CHANNEL_WIDTH_20; tmp_bw <= bw; tmp_bw++) {
+		if (!(ch_width_to_bw_cap(tmp_bw) & bw_bmp))
 			continue;
 
 		if (no_sc == _FALSE) {
-			if (bw == CHANNEL_WIDTH_20)
-				cch = hal_data->cch_20;
-			else if (bw == CHANNEL_WIDTH_40)
-				cch = hal_data->cch_40;
-			else if (bw == CHANNEL_WIDTH_80)
-				cch = hal_data->cch_80;
+			if (tmp_bw == CHANNEL_WIDTH_20)
+				tmp_cch = hal_data->cch_20;
+			else if (tmp_bw == CHANNEL_WIDTH_40)
+				tmp_cch = hal_data->cch_40;
+			else if (tmp_bw == CHANNEL_WIDTH_80)
+				tmp_cch = hal_data->cch_80;
 			else {
-				cch = 0;
+				tmp_cch = 0;
 				rtw_warn_on(1);
 			}
 		}
 
-		ch_idx = phy_GetChannelIndexOfTxPowerLimit(Band, cch);
-		if (ch_idx == -1)
-			continue;
-
-		if (Band == BAND_ON_2_4G) {
-			s8 limits[MAX_REGULATION_NUM] = {0};
-			u8 i = 0;
+		lmt = phy_get_txpwr_lmt_abs(adapter, regd_name, band, tmp_bw, tlrs, ntx_idx, tmp_cch, 0);
 
-			for (i = 0; i < MAX_REGULATION_NUM; ++i)
-				limits[i] = hal_data->TxPwrLimit_2_4G[i][bw][rs][ch_idx][RfPath];
+		if (min_lmt >= lmt) {
+			min_lmt = lmt;
+			final_cch = tmp_cch;
+			final_bw = tmp_bw;
+		}
 
-			tmp_lmt = (regulation == TXPWR_LMT_WW) ? phy_GetWorldWideLimit(limits) :
-				hal_data->TxPwrLimit_2_4G[regulation][bw][rs][ch_idx][RfPath];
+	}
 
-		} else if (Band == BAND_ON_5G) {
-			s8 limits[MAX_REGULATION_NUM] = {0};
-			u8 i = 0;
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
 
-			for (i = 0; i < MAX_REGULATION_NUM; ++i)
-				limits[i] = hal_data->TxPwrLimit_5G[i][bw][rs][ch_idx][RfPath];
+	if (min_lmt != MAX_POWER_INDEX) {
+		/* return diff value */
+		min_lmt = min_lmt - PHY_GetTxPowerByRateBase(adapter, band, rfpath, rs);
+	}
 
-			tmp_lmt = (regulation == TXPWR_LMT_WW) ? phy_GetWorldWideLimit(limits) :
-				hal_data->TxPwrLimit_5G[regulation][bw][rs][ch_idx][RfPath];
-		} else
-			continue;
+exit:
 
-		if (min_lmt >= tmp_lmt) {
-			min_lmt = tmp_lmt;
-			final_cch = cch;
-			final_bw = bw;
-		}
+	if (0) {
+		if (final_bw != bw && (IS_HT_RATE(rate) || IS_VHT_RATE(rate)))
+			RTW_INFO("%s min_lmt: %s ch%u -> %s ch%u\n"
+				, MGN_RATE_STR(rate)
+				, ch_width_str(bw), cch
+				, ch_width_str(final_bw), final_cch);
 	}
 
-exit:
 	return min_lmt;
 }
 
-inline s8
-PHY_GetTxPowerLimit(
-	IN	PADAPTER			Adapter,
-	IN	u32					RegPwrTblSel,
-	IN	BAND_TYPE			Band,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					RfPath,
-	IN	u8					DataRate,
-	IN	u8					Channel
-)
+static void phy_txpwr_lmt_cck_ofdm_mt_chk(_adapter *adapter)
 {
-	BOOLEAN no_sc = _FALSE;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct txpwr_lmt_ent *ent;
+	_list *cur, *head;
+	u8 channel, tlrs, ntx_idx;
 
-	/* MP mode channel don't use secondary channel */
-	if (rtw_mp_mode_check(Adapter) == _TRUE)
-		no_sc = _TRUE;
+	rfctl->txpwr_lmt_2g_cck_ofdm_state = 0;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	rfctl->txpwr_lmt_5g_cck_ofdm_state = 0;
+#endif
 
-	return _phy_get_txpwr_lmt(Adapter, RegPwrTblSel, Band, Bandwidth, RfPath, DataRate, Channel, no_sc);
-}
+	head = &rfctl->txpwr_lmt_list;
+	cur = get_next(head);
 
-inline s8
-PHY_GetTxPowerLimit_no_sc(
-	IN	PADAPTER			Adapter,
-	IN	u32					RegPwrTblSel,
-	IN	BAND_TYPE			Band,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					RfPath,
-	IN	u8					DataRate,
-	IN	u8					Channel
-)
-{
-	return _phy_get_txpwr_lmt(Adapter, RegPwrTblSel, Band, Bandwidth, RfPath, DataRate, Channel, _TRUE);
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+		cur = get_next(cur);
+
+		/* check 2G CCK, OFDM state*/
+		for (tlrs = TXPWR_LMT_RS_CCK; tlrs <= TXPWR_LMT_RS_OFDM; tlrs++) {
+			for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
+				for (channel = 0; channel < CENTER_CH_2G_NUM; ++channel) {
+					if (ent->lmt_2g[CHANNEL_WIDTH_20][tlrs][channel][ntx_idx] != MAX_POWER_INDEX) {
+						if (tlrs == TXPWR_LMT_RS_CCK)
+							rfctl->txpwr_lmt_2g_cck_ofdm_state |= TXPWR_LMT_HAS_CCK_1T << ntx_idx;
+						else
+							rfctl->txpwr_lmt_2g_cck_ofdm_state |= TXPWR_LMT_HAS_OFDM_1T << ntx_idx;
+						break;
+					}
+				}
+			}
+		}
+
+		/* if 2G OFDM multi-TX is not defined, reference HT20 */
+		for (channel = 0; channel < CENTER_CH_2G_NUM; ++channel) {
+			for (ntx_idx = RF_2TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
+				if (rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx))
+					continue;
+				ent->lmt_2g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM][channel][ntx_idx] =
+					ent->lmt_2g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_HT][channel][ntx_idx];
+			}
+		}
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		/* check 5G OFDM state*/
+		for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
+			for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
+				if (ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM - 1][channel][ntx_idx] != MAX_POWER_INDEX) {
+					rfctl->txpwr_lmt_5g_cck_ofdm_state |= TXPWR_LMT_HAS_OFDM_1T << ntx_idx;
+					break;
+				}
+			}
+		}
+
+		for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
+			for (ntx_idx = RF_2TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
+				if (rfctl->txpwr_lmt_5g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx))
+					continue;
+				/* if 5G OFDM multi-TX is not defined, reference HT20 */
+				ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM - 1][channel][ntx_idx] =
+					ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_HT - 1][channel][ntx_idx];
+			}
+		}
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
+	}
 }
 
-VOID
-phy_CrossReferenceHTAndVHTTxPowerLimit(
-	IN	PADAPTER			pAdapter
-	)
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+static void phy_txpwr_lmt_cross_ref_ht_vht(_adapter *adapter)
 {
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-	u8 regulation, bw, channel, rs, ref_rs;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct txpwr_lmt_ent *ent;
+	_list *cur, *head;
+	u8 bw, channel, tlrs, ref_tlrs, ntx_idx;
 	int ht_ref_vht_5g_20_40 = 0;
 	int vht_ref_ht_5g_20_40 = 0;
 	int ht_has_ref_5g_20_40 = 0;
 	int vht_has_ref_5g_20_40 = 0;
 
-	pHalData->tx_pwr_lmt_5g_20_40_ref = 0;
+	rfctl->txpwr_lmt_5g_20_40_ref = 0;
 
-	for (regulation = 0; regulation < MAX_REGULATION_NUM; ++regulation) {
+	head = &rfctl->txpwr_lmt_list;
+	cur = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+		ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+		cur = get_next(cur);
 
 		for (bw = 0; bw < MAX_5G_BANDWIDTH_NUM; ++bw) {
 
 			for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
 
-				for (rs = 0; rs < MAX_RATE_SECTION_NUM; ++rs) {
+				for (tlrs = TXPWR_LMT_RS_HT; tlrs < TXPWR_LMT_RS_NUM; ++tlrs) {
 
 					/* 5G 20M 40M VHT and HT can cross reference */
 					if (bw == CHANNEL_WIDTH_20 || bw == CHANNEL_WIDTH_40) {
-						if (rs == HT_1SS)
-							ref_rs = VHT_1SS;
-						else if (rs == HT_2SS)
-							ref_rs = VHT_2SS;
-						else if (rs == HT_3SS)
-							ref_rs = VHT_3SS;
-						else if (rs == HT_4SS)
-							ref_rs = VHT_4SS;
-						else if (rs == VHT_1SS)
-							ref_rs = HT_1SS;
-						else if (rs == VHT_2SS)
-							ref_rs = HT_2SS;
-						else if (rs == VHT_3SS)
-							ref_rs = HT_3SS;
-						else if (rs == VHT_4SS)
-							ref_rs = HT_4SS;
+						if (tlrs == TXPWR_LMT_RS_HT)
+							ref_tlrs = TXPWR_LMT_RS_VHT;
+						else if (tlrs == TXPWR_LMT_RS_VHT)
+							ref_tlrs = TXPWR_LMT_RS_HT;
 						else
 							continue;
 
-						if (pHalData->TxPwrLimit_5G[regulation][bw][ref_rs][channel][RF_PATH_A] == MAX_POWER_INDEX)
-							continue;
+						for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
 
-						if (IS_HT_RATE_SECTION(rs))
-							ht_has_ref_5g_20_40++;
-						else if (IS_VHT_RATE_SECTION(rs))
-							vht_has_ref_5g_20_40++;
-						else
-							continue;
+							if (ent->lmt_5g[bw][ref_tlrs - 1][channel][ntx_idx] == MAX_POWER_INDEX)
+								continue;
 
-						if (pHalData->TxPwrLimit_5G[regulation][bw][rs][channel][RF_PATH_A] != MAX_POWER_INDEX)
-							continue;
+							if (tlrs == TXPWR_LMT_RS_HT)
+								ht_has_ref_5g_20_40++;
+							else if (tlrs == TXPWR_LMT_RS_VHT)
+								vht_has_ref_5g_20_40++;
+							else
+								continue;
+
+							if (ent->lmt_5g[bw][tlrs - 1][channel][ntx_idx] != MAX_POWER_INDEX)
+								continue;
 
-						if (IS_HT_RATE_SECTION(rs) && IS_VHT_RATE_SECTION(ref_rs))
-							ht_ref_vht_5g_20_40++;
-						else if (IS_VHT_RATE_SECTION(rs) && IS_HT_RATE_SECTION(ref_rs))
-							vht_ref_ht_5g_20_40++;
+							if (tlrs == TXPWR_LMT_RS_HT && ref_tlrs == TXPWR_LMT_RS_VHT)
+								ht_ref_vht_5g_20_40++;
+							else if (tlrs == TXPWR_LMT_RS_VHT && ref_tlrs == TXPWR_LMT_RS_HT)
+								vht_ref_ht_5g_20_40++;
 
-						if (0)
-							DBG_871X("reg:%u, bw:%u, ch:%u, %s ref %s\n"
-								, regulation, bw, channel
-								, rate_section_str(rs), rate_section_str(ref_rs));
+							if (0)
+								RTW_INFO("reg:%s, bw:%u, ch:%u, %s-%uT ref %s-%uT\n"
+									, ent->regd_name, bw, channel
+									, txpwr_lmt_rs_str(tlrs), ntx_idx + 1
+									, txpwr_lmt_rs_str(ref_tlrs), ntx_idx + 1);
 
-						pHalData->TxPwrLimit_5G[regulation][bw][rs][channel][RF_PATH_A] =
-							pHalData->TxPwrLimit_5G[regulation][bw][ref_rs][channel][RF_PATH_A];
+							ent->lmt_5g[bw][tlrs - 1][channel][ntx_idx] =
+								ent->lmt_5g[bw][ref_tlrs - 1][channel][ntx_idx];
+						}
 					}
 
 				}
@@ -3104,179 +3259,313 @@ phy_CrossReferenceHTAndVHTTxPowerLimit(
 	}
 
 	if (0) {
-		DBG_871X("ht_ref_vht_5g_20_40:%d, ht_has_ref_5g_20_40:%d\n", ht_ref_vht_5g_20_40, ht_has_ref_5g_20_40);
-		DBG_871X("vht_ref_hht_5g_20_40:%d, vht_has_ref_5g_20_40:%d\n", vht_ref_ht_5g_20_40, vht_has_ref_5g_20_40);
+		RTW_INFO("ht_ref_vht_5g_20_40:%d, ht_has_ref_5g_20_40:%d\n", ht_ref_vht_5g_20_40, ht_has_ref_5g_20_40);
+		RTW_INFO("vht_ref_hht_5g_20_40:%d, vht_has_ref_5g_20_40:%d\n", vht_ref_ht_5g_20_40, vht_has_ref_5g_20_40);
 	}
 
 	/* 5G 20M&40M HT all come from VHT*/
 	if (ht_ref_vht_5g_20_40 && ht_has_ref_5g_20_40 == ht_ref_vht_5g_20_40)
-		pHalData->tx_pwr_lmt_5g_20_40_ref |= TX_PWR_LMT_REF_HT_FROM_VHT;
+		rfctl->txpwr_lmt_5g_20_40_ref |= TXPWR_LMT_REF_HT_FROM_VHT;
 
 	/* 5G 20M&40M VHT all come from HT*/
 	if (vht_ref_ht_5g_20_40 && vht_has_ref_5g_20_40 == vht_ref_ht_5g_20_40)
-		pHalData->tx_pwr_lmt_5g_20_40_ref |= TX_PWR_LMT_REF_VHT_FROM_HT;
+		rfctl->txpwr_lmt_5g_20_40_ref |= TXPWR_LMT_REF_VHT_FROM_HT;
 }
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
 
-VOID 
-PHY_ConvertTxPowerLimitToPowerIndex(
-	IN	PADAPTER			Adapter
-	)
+#ifndef DBG_TXPWR_LMT_BAND_CHK
+#define DBG_TXPWR_LMT_BAND_CHK 0
+#endif
+
+#if DBG_TXPWR_LMT_BAND_CHK
+/* check if larger bandwidth limit is less than smaller bandwidth for HT & VHT rate */
+void phy_txpwr_limit_bandwidth_chk(_adapter *adapter)
 {
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
-	u8 base;
-	u8 regulation, bw, channel, rateSection;
-	s8 tempValue = 0, tempPwrLmt = 0;
-	u8 rfPath = 0;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	u8 band, bw, path, tlrs, ntx_idx, cch, offset, scch;
+	u8 ch_num, n, i;
 
-	if (pHalData->odmpriv.PhyRegPgValueType != PHY_REG_PG_EXACT_VALUE) {
-		rtw_warn_on(1);
-		return;
-	}
+	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
+		if (!hal_is_band_support(adapter, band))
+			continue;
+
+		for (bw = CHANNEL_WIDTH_40; bw <= CHANNEL_WIDTH_80; bw++) {
+			if (bw >= CHANNEL_WIDTH_160)
+				continue;
+			if (band == BAND_ON_2_4G && bw >= CHANNEL_WIDTH_80)
+				continue;
+
+			if (band == BAND_ON_2_4G)
+				ch_num = center_chs_2g_num(bw);
+			else
+				ch_num = center_chs_5g_num(bw);
+
+			if (ch_num == 0) {
+				rtw_warn_on(1);
+				break;
+			}
+
+			for (tlrs = TXPWR_LMT_RS_HT; tlrs < TXPWR_LMT_RS_NUM; tlrs++) {
+
+				if (band == BAND_ON_2_4G && tlrs == TXPWR_LMT_RS_VHT)
+					continue;
+				if (band == BAND_ON_5G && tlrs == TXPWR_LMT_RS_CCK)
+					continue;
+				if (bw > CHANNEL_WIDTH_20 && (tlrs == TXPWR_LMT_RS_CCK || tlrs == TXPWR_LMT_RS_OFDM))
+					continue;
+				if (bw > CHANNEL_WIDTH_40 && tlrs == TXPWR_LMT_RS_HT)
+					continue;
+				if (tlrs == TXPWR_LMT_RS_VHT && !IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
+					continue;
 
-	phy_CrossReferenceHTAndVHTTxPowerLimit(Adapter);
+				for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
+					struct txpwr_lmt_ent *ent;
+					_list *cur, *head;
 
-	for (regulation = 0; regulation < MAX_REGULATION_NUM; ++regulation) {
+					if (ntx_idx >= hal_spec->tx_nss_num)
+						continue;
 
-		for (bw = 0; bw < MAX_2_4G_BANDWIDTH_NUM; ++bw) {
+					/* bypass CCK multi-TX is not defined */
+					if (tlrs == TXPWR_LMT_RS_CCK && ntx_idx > RF_1TX) {
+						if (band == BAND_ON_2_4G
+							&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_CCK_1T << ntx_idx)))
+							continue;
+					}
+
+					/* bypass OFDM multi-TX is not defined */
+					if (tlrs == TXPWR_LMT_RS_OFDM && ntx_idx > RF_1TX) {
+						if (band == BAND_ON_2_4G
+							&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
+							continue;
+						#ifdef CONFIG_IEEE80211_BAND_5GHZ
+						if (band == BAND_ON_5G
+							&& !(rfctl->txpwr_lmt_5g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
+							continue;
+						#endif
+					}
 
-			for (channel = 0; channel < CENTER_CH_2G_NUM; ++channel) {
+					/* bypass 5G 20M, 40M pure reference */
+					#ifdef CONFIG_IEEE80211_BAND_5GHZ
+					if (band == BAND_ON_5G && (bw == CHANNEL_WIDTH_20 || bw == CHANNEL_WIDTH_40)) {
+						if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_HT_FROM_VHT) {
+							if (tlrs == TXPWR_LMT_RS_HT)
+								continue;
+						} else if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_VHT_FROM_HT) {
+							if (tlrs == TXPWR_LMT_RS_VHT && bw <= CHANNEL_WIDTH_40)
+								continue;
+						}
+					}
+					#endif
 
-				for (rateSection = CCK; rateSection <= HT_4SS; ++rateSection) {
-					tempPwrLmt = pHalData->TxPwrLimit_2_4G[regulation][bw][rateSection][channel][RF_PATH_A];
+					for (n = 0; n < ch_num; n++) {
+						u8 cch_by_bw[3];
+						u8 offset_by_bw; /* bitmap, 0 for lower, 1 for upper */
+						u8 bw_pos;
+						s8 lmt[3];
 
-					if (tempPwrLmt != MAX_POWER_INDEX) {
+						if (band == BAND_ON_2_4G)
+							cch = center_chs_2g(bw, n);
+						else
+							cch = center_chs_5g(bw, n);
 
-						for (rfPath = RF_PATH_A; rfPath < MAX_RF_PATH; ++rfPath) {
-							base = PHY_GetTxPowerByRateBase(Adapter, BAND_ON_2_4G, rfPath, rate_section_to_tx_num(rateSection), rateSection);
-							tempValue = tempPwrLmt - base;
-							pHalData->TxPwrLimit_2_4G[regulation][bw][rateSection][channel][rfPath] = tempValue;
+						if (cch == 0) {
+							rtw_warn_on(1);
+							break;
 						}
-					}
-				}
-			}
-		}
-	}
-	
-	if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(Adapter)) {
 
-		for (regulation = 0; regulation < MAX_REGULATION_NUM; ++regulation) {
+						_rtw_memset(cch_by_bw, 0, 3);
+						cch_by_bw[bw] = cch;
+						offset_by_bw = 0x01;
+
+						do {
+							for (bw_pos = bw; bw_pos >= CHANNEL_WIDTH_40; bw_pos--)
+								cch_by_bw[bw_pos - 1] = rtw_get_scch_by_cch_offset(cch_by_bw[bw_pos], bw_pos, offset_by_bw & BIT(bw_pos) ? HAL_PRIME_CHNL_OFFSET_UPPER : HAL_PRIME_CHNL_OFFSET_LOWER);
+
+							head = &rfctl->txpwr_lmt_list;
+							cur = get_next(head);
+							while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+								ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+								cur = get_next(cur);
+
+								for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
+									lmt[bw_pos] = phy_get_txpwr_lmt_abs(adapter, ent->regd_name, band, bw_pos, tlrs, ntx_idx, cch_by_bw[bw_pos], 0);
+
+								for (bw_pos = bw; bw_pos > CHANNEL_WIDTH_20; bw_pos--)
+									if (lmt[bw_pos] > lmt[bw_pos - 1])
+										break;
+								if (bw_pos == CHANNEL_WIDTH_20)
+									continue;
+
+								RTW_PRINT_SEL(RTW_DBGDUMP, "[%s][%s][%s][%uT][%-4s] cch:"
+									, band_str(band)
+									, ch_width_str(bw)
+									, txpwr_lmt_rs_str(tlrs)
+									, ntx_idx + 1
+									, ent->regd_name
+								);
+								for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
+									_RTW_PRINT_SEL(RTW_DBGDUMP, "%03u ", cch_by_bw[bw_pos]);
+								_RTW_PRINT_SEL(RTW_DBGDUMP, "limit:");
+								for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--) {
+									if (lmt[bw_pos] == MAX_POWER_INDEX)
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "N/A ");
+									else
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2u%s ", lmt[bw_pos] / 2, lmt[bw_pos] % 2 ? ".5" : "");
+								}
+								_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
+							}
+							for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
+								lmt[bw_pos] = phy_get_txpwr_lmt_abs(adapter, regd_str(TXPWR_LMT_WW), band, bw_pos, tlrs, ntx_idx, cch_by_bw[bw_pos], 0);
 
-			for (bw = 0; bw < MAX_5G_BANDWIDTH_NUM; ++bw) {
+							for (bw_pos = bw; bw_pos > CHANNEL_WIDTH_20; bw_pos--)
+								if (lmt[bw_pos] > lmt[bw_pos - 1])
+									break;
+							if (bw_pos != CHANNEL_WIDTH_20) {
+								RTW_PRINT_SEL(RTW_DBGDUMP, "[%s][%s][%s][%uT][%-4s] cch:"
+									, band_str(band)
+									, ch_width_str(bw)
+									, txpwr_lmt_rs_str(tlrs)
+									, ntx_idx + 1
+									, regd_str(TXPWR_LMT_WW)
+								);
+								for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
+									_RTW_PRINT_SEL(RTW_DBGDUMP, "%03u ", cch_by_bw[bw_pos]);
+								_RTW_PRINT_SEL(RTW_DBGDUMP, "limit:");
+								for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--) {
+									if (lmt[bw_pos] == MAX_POWER_INDEX)
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "N/A ");
+									else
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2u%s ", lmt[bw_pos] / 2, lmt[bw_pos] % 2 ? ".5" : "");
+								}
+								_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
+							}
 
-				for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
+							offset_by_bw += 2;
+							if (offset_by_bw & BIT(bw + 1))
+								break;
+						} while (1); /* loop for all ch combinations */
+					} /* loop for center channels */
+				} /* loop fo each ntx_idx */
+			} /* loop for tlrs */
+		} /* loop for bandwidth */
+	} /* loop for band */
+}
+#endif /* DBG_TXPWR_LMT_BAND_CHK */
 
-					for (rateSection = OFDM; rateSection <= VHT_4SS; ++rateSection) {
-						tempPwrLmt = pHalData->TxPwrLimit_5G[regulation][bw][rateSection][channel][RF_PATH_A];
+static void phy_txpwr_lmt_post_hdl(_adapter *adapter)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	_irqL irqL;
 
-						if (tempPwrLmt != MAX_POWER_INDEX) {
+	_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
 
-							for (rfPath = RF_PATH_A; rfPath < MAX_RF_PATH; ++rfPath) {
-								base = PHY_GetTxPowerByRateBase(Adapter, BAND_ON_5G, rfPath, rate_section_to_tx_num(rateSection), rateSection);
-								tempValue = tempPwrLmt - base;
-								pHalData->TxPwrLimit_5G[regulation][bw][rateSection][channel][rfPath] = tempValue;
-							}
-						}
-					}
-				}
-			}
-		}
-	}
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
+		phy_txpwr_lmt_cross_ref_ht_vht(adapter);
+#endif
+	phy_txpwr_lmt_cck_ofdm_mt_chk(adapter);
+
+#if DBG_TXPWR_LMT_BAND_CHK
+	phy_txpwr_limit_bandwidth_chk(adapter);
+#endif
+
+	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
 }
 
-/*
-* PHY_InitTxPowerLimit - Set all hal_data.TxPwrLimit_2_4G, TxPwrLimit_5G array to MAX_POWER_INDEX
-*/
-VOID
-PHY_InitTxPowerLimit(
-	IN	PADAPTER		Adapter
-	)
+BOOLEAN
+GetS1ByteIntegerFromStringInDecimal(
+	IN		char	*str,
+	IN OUT	s8		*val
+)
 {
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
-	u8 i, j, k, l, m;
-
-	for (i = 0; i < MAX_REGULATION_NUM; ++i)
-		for (j = 0; j < MAX_2_4G_BANDWIDTH_NUM; ++j)
-			for (k = 0; k < MAX_RATE_SECTION_NUM; ++k)
-				for (m = 0; m < CENTER_CH_2G_NUM; ++m)
-					for (l = 0; l < MAX_RF_PATH; ++l)
-						pHalData->TxPwrLimit_2_4G[i][j][k][m][l] = MAX_POWER_INDEX;
-
-	for (i = 0; i < MAX_REGULATION_NUM; ++i)
-		for (j = 0; j < MAX_5G_BANDWIDTH_NUM; ++j)
-			for (k = 0; k < MAX_RATE_SECTION_NUM; ++k)
-				for (m = 0; m < CENTER_CH_5G_ALL_NUM; ++m)
-					for (l = 0; l < MAX_RF_PATH; ++l)
-						pHalData->TxPwrLimit_5G[i][j][k][m][l] = MAX_POWER_INDEX;
+	u8 negative = 0;
+	u16 i = 0;
+
+	*val = 0;
+
+	while (str[i] != '\0') {
+		if (i == 0 && (str[i] == '+' || str[i] == '-')) {
+			if (str[i] == '-')
+				negative = 1;
+		} else if (str[i] >= '0' && str[i] <= '9') {
+			*val *= 10;
+			*val += (str[i] - '0');
+		} else
+			return _FALSE;
+		++i;
+	}
+
+	if (negative)
+		*val = -*val;
+
+	return _TRUE;
 }
+#endif /* CONFIG_TXPWR_LIMIT */
 
 /*
-* PHY_SetTxPowerLimit - Parsing TX power limit from phydm array, called by odm_ConfigBB_TXPWR_LMT_XXX in phydm
+* phy_set_tx_power_limit - Parsing TX power limit from phydm array, called by odm_ConfigBB_TXPWR_LMT_XXX in phydm
 */
 VOID
-PHY_SetTxPowerLimit(
-	IN	PDM_ODM_T		pDM_Odm,
+phy_set_tx_power_limit(
+	IN	struct dm_struct		*pDM_Odm,
 	IN	u8				*Regulation,
 	IN	u8				*Band,
 	IN	u8				*Bandwidth,
 	IN	u8				*RateSection,
-	IN	u8				*RfPath,
+	IN	u8				*ntx,
 	IN	u8				*Channel,
 	IN	u8				*PowerLimit
-	)
+)
 {
-	PADAPTER Adapter = pDM_Odm->Adapter;
+#ifdef CONFIG_TXPWR_LIMIT
+	PADAPTER Adapter = pDM_Odm->adapter;
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
-	u8 regulation = 0, bandwidth = 0, rateSection = 0, channel;
+	u8 band = 0, bandwidth = 0, tlrs = 0, channel;
+	u8 ntx_idx;
 	s8 powerLimit = 0, prevPowerLimit, channelIndex;
 
 	if (0)
-		DBG_871X("Index of power limit table [band %s][regulation %s][bw %s][rate section %s][rf path %s][chnl %s][val %s]\n"
-			, Band, Regulation, Bandwidth, RateSection, RfPath, Channel, PowerLimit);
+		RTW_INFO("Index of power limit table [regulation %s][band %s][bw %s][rate section %s][ntx %s][chnl %s][val %s]\n"
+			, Regulation, Band, Bandwidth, RateSection, ntx, Channel, PowerLimit);
 
-	if (GetU1ByteIntegerFromStringInDecimal((s8 *)Channel, &channel) == _FALSE
-		|| GetU1ByteIntegerFromStringInDecimal((s8 *)PowerLimit, &powerLimit) == _FALSE
-	){
-		DBG_871X_LEVEL(_drv_always_, "Illegal index of power limit table [ch %s][val %s]\n", Channel, PowerLimit);
+	if (GetU1ByteIntegerFromStringInDecimal((char *)Channel, &channel) == _FALSE
+		|| GetS1ByteIntegerFromStringInDecimal((char *)PowerLimit, &powerLimit) == _FALSE
+	) {
+		RTW_PRINT("Illegal index of power limit table [ch %s][val %s]\n", Channel, PowerLimit);
 		return;
 	}
 
-	powerLimit = powerLimit > MAX_POWER_INDEX ? MAX_POWER_INDEX : powerLimit;
+	if (powerLimit < -MAX_POWER_INDEX || powerLimit > MAX_POWER_INDEX)
+		RTW_PRINT("Illegal power limit value [ch %s][val %s]\n", Channel, PowerLimit);
 
-	if (eqNByte(Regulation, (u8 *)("FCC"), 3))
-		regulation = TXPWR_LMT_FCC;
-	else if (eqNByte(Regulation, (u8 *)("MKK"), 3))
-		regulation = TXPWR_LMT_MKK;
-	else if (eqNByte(Regulation, (u8 *)("ETSI"), 4))
-		regulation = TXPWR_LMT_ETSI;
-	else if (eqNByte(Regulation, (u8 *)("WW13"), 4))
-		regulation = TXPWR_LMT_WW;
+	powerLimit = powerLimit > MAX_POWER_INDEX ? MAX_POWER_INDEX : powerLimit;
+	powerLimit = powerLimit < -MAX_POWER_INDEX ? -MAX_POWER_INDEX + 1 : powerLimit;
+
+	if (eqNByte(RateSection, (u8 *)("CCK"), 3))
+		tlrs = TXPWR_LMT_RS_CCK;
+	else if (eqNByte(RateSection, (u8 *)("OFDM"), 4))
+		tlrs = TXPWR_LMT_RS_OFDM;
+	else if (eqNByte(RateSection, (u8 *)("HT"), 2))
+		tlrs = TXPWR_LMT_RS_HT;
+	else if (eqNByte(RateSection, (u8 *)("VHT"), 3))
+		tlrs = TXPWR_LMT_RS_VHT;
 	else {
-		DBG_871X_LEVEL(_drv_always_, "unknown regulation:%s", Regulation);
+		RTW_PRINT("Wrong rate section:%s\n", RateSection);
 		return;
 	}
 
-	if (eqNByte(RateSection, (u8 *)("CCK"), 3) && eqNByte(RfPath, (u8 *)("1T"), 2))
-		rateSection = CCK;
-	else if (eqNByte(RateSection, (u8 *)("OFDM"), 4) && eqNByte(RfPath, (u8 *)("1T"), 2))
-		rateSection = OFDM;
-	else if (eqNByte(RateSection, (u8 *)("HT"), 2) && eqNByte(RfPath, (u8 *)("1T"), 2))
-		rateSection = HT_1SS;
-	else if (eqNByte(RateSection, (u8 *)("HT"), 2) && eqNByte(RfPath, (u8 *)("2T"), 2))
-		rateSection = HT_2SS;
-	else if (eqNByte(RateSection, (u8 *)("HT"), 2) && eqNByte(RfPath, (u8 *)("3T"), 2))
-		rateSection = HT_3SS;
-	else if (eqNByte(RateSection, (u8 *)("HT"), 2) && eqNByte(RfPath, (u8 *)("4T"), 2))
-		rateSection = HT_4SS;
-	else if (eqNByte(RateSection, (u8 *)("VHT"), 3) && eqNByte(RfPath, (u8 *)("1T"), 2))
-		rateSection = VHT_1SS;
-	else if (eqNByte(RateSection, (u8 *)("VHT"), 3) && eqNByte(RfPath, (u8 *)("2T"), 2))
-		rateSection = VHT_2SS;
-	else if (eqNByte(RateSection, (u8 *)("VHT"), 3) && eqNByte(RfPath, (u8 *)("3T"), 2))
-		rateSection = VHT_3SS;
-	else if (eqNByte(RateSection, (u8 *)("VHT"), 3) && eqNByte(RfPath, (u8 *)("4T"), 2))
-		rateSection = VHT_4SS;
+	if (eqNByte(ntx, (u8 *)("1T"), 2))
+		ntx_idx = RF_1TX;
+	else if (eqNByte(ntx, (u8 *)("2T"), 2))
+		ntx_idx = RF_2TX;
+	else if (eqNByte(ntx, (u8 *)("3T"), 2))
+		ntx_idx = RF_3TX;
+	else if (eqNByte(ntx, (u8 *)("4T"), 2))
+		ntx_idx = RF_4TX;
 	else {
-		DBG_871X_LEVEL(_drv_always_, "Wrong rate section: (%s,%s)\n", RateSection, RfPath);
+		RTW_PRINT("Wrong tx num:%s\n", ntx);
 		return;
 	}
 
@@ -3286,71 +3575,57 @@ PHY_SetTxPowerLimit(
 		bandwidth = CHANNEL_WIDTH_40;
 	else if (eqNByte(Bandwidth, (u8 *)("80M"), 3))
 		bandwidth = CHANNEL_WIDTH_80;
+	else if (eqNByte(Bandwidth, (u8 *)("160M"), 4))
+		bandwidth = CHANNEL_WIDTH_160;
 	else {
-		DBG_871X_LEVEL(_drv_always_, "unknown bandwidth: %s\n", Bandwidth);
+		RTW_PRINT("unknown bandwidth: %s\n", Bandwidth);
 		return;
 	}
 
 	if (eqNByte(Band, (u8 *)("2.4G"), 4)) {
+		band = BAND_ON_2_4G;
 		channelIndex = phy_GetChannelIndexOfTxPowerLimit(BAND_ON_2_4G, channel);
 
 		if (channelIndex == -1) {
-			DBG_871X_LEVEL(_drv_always_, "unsupported channel: %d at 2.4G\n", channel);
+			RTW_PRINT("unsupported channel: %d at 2.4G\n", channel);
 			return;
 		}
 
 		if (bandwidth >= MAX_2_4G_BANDWIDTH_NUM) {
-			DBG_871X_LEVEL(_drv_always_, "unsupported bandwidth: %s at 2.4G\n", Bandwidth);
+			RTW_PRINT("unsupported bandwidth: %s at 2.4G\n", Bandwidth);
 			return;
 		}
 
-		prevPowerLimit = pHalData->TxPwrLimit_2_4G[regulation][bandwidth][rateSection][channelIndex][RF_PATH_A];
-
-		if (prevPowerLimit != MAX_POWER_INDEX)
-			DBG_871X_LEVEL(_drv_always_, "duplicate tx power limit combination [band %s][regulation %s][bw %s][rate section %s][rf path %s][chnl %s]\n"
-				, Band, Regulation, Bandwidth, RateSection, RfPath, Channel);
-
-		if (powerLimit < prevPowerLimit)
-			pHalData->TxPwrLimit_2_4G[regulation][bandwidth][rateSection][channelIndex][RF_PATH_A] = powerLimit;
-
-		if (0)
-			DBG_871X("2.4G Band value : [regulation %d][bw %d][rate_section %d][chnl %d][val %d]\n"
-				, regulation, bandwidth, rateSection, channelIndex, pHalData->TxPwrLimit_2_4G[regulation][bandwidth][rateSection][channelIndex][ODM_RF_PATH_A]);
-	} else if (eqNByte(Band, (u8 *)("5G"), 2)) {
-
+		rtw_txpwr_lmt_add(adapter_to_rfctl(Adapter), Regulation, band, bandwidth, tlrs, ntx_idx, channelIndex, powerLimit);
+	}
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	else if (eqNByte(Band, (u8 *)("5G"), 2)) {
+		band = BAND_ON_5G;
 		channelIndex = phy_GetChannelIndexOfTxPowerLimit(BAND_ON_5G, channel);
 
 		if (channelIndex == -1) {
-			DBG_871X_LEVEL(_drv_always_, "unsupported channel: %d at 5G\n", channel);
+			RTW_PRINT("unsupported channel: %d at 5G\n", channel);
 			return;
 		}
 
-		prevPowerLimit = pHalData->TxPwrLimit_5G[regulation][bandwidth][rateSection][channelIndex][RF_PATH_A];
-
-		if (prevPowerLimit != MAX_POWER_INDEX)
-			DBG_871X_LEVEL(_drv_always_, "duplicate tx power limit combination [band %s][regulation %s][bw %s][rate section %s][rf path %s][chnl %s]\n"
-				, Band, Regulation, Bandwidth, RateSection, RfPath, Channel);
-
-		if (powerLimit < prevPowerLimit)
-			pHalData->TxPwrLimit_5G[regulation][bandwidth][rateSection][channelIndex][RF_PATH_A] = powerLimit;
-
-		if (0)
-			DBG_871X("5G Band value : [regulation %d][bw %d][rate_section %d][chnl %d][val %d]\n"
-				, regulation, bandwidth, rateSection, channel, pHalData->TxPwrLimit_5G[regulation][bandwidth][rateSection][channelIndex][RF_PATH_A]);
-	} else {
-		DBG_871X_LEVEL(_drv_always_, "Cannot recognize the band info in %s\n", Band);
+		rtw_txpwr_lmt_add(adapter_to_rfctl(Adapter), Regulation, band, bandwidth, tlrs, ntx_idx, channelIndex, powerLimit);
+	}
+#endif
+	else {
+		RTW_PRINT("unknown/unsupported band:%s\n", Band);
 		return;
 	}
+#endif
 }
 
 u8
-PHY_GetTxPowerIndex(
+phy_get_tx_power_index(
 	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
-	IN	u8					Rate,	
-	IN	CHANNEL_WIDTH		BandWidth,	
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	enum channel_width	BandWidth,
 	IN	u8					Channel
-	)
+)
 {
 	return rtw_hal_get_tx_power_index(pAdapter, RFPath, Rate, BandWidth, Channel, NULL);
 }
@@ -3359,50 +3634,17 @@ VOID
 PHY_SetTxPowerIndex(
 	IN	PADAPTER		pAdapter,
 	IN	u32				PowerIndex,
-	IN	u8				RFPath,	
+	IN	enum rf_path		RFPath,
 	IN	u8				Rate
-	)
+)
 {
-	if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
-#if (RTL8814A_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8814A(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	}
-	else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
-#if ((RTL8812A_SUPPORT==1) || (RTL8821A_SUPPORT == 1))
-		PHY_SetTxPowerIndex_8812A( pAdapter, PowerIndex, RFPath, Rate );
-#endif
-	}
-	else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
-#if (RTL8723B_SUPPORT==1)
-		PHY_SetTxPowerIndex_8723B( pAdapter, PowerIndex, RFPath, Rate );
-#endif
-	}
-	else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
-#if (RTL8703B_SUPPORT==1)
-		PHY_SetTxPowerIndex_8703B( pAdapter, PowerIndex, RFPath, Rate );
-#endif
-	}
-	else if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
-#if (RTL8192E_SUPPORT==1)
-		PHY_SetTxPowerIndex_8192E( pAdapter, PowerIndex, RFPath, Rate );
-#endif
-	}
-	else if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
-#if (RTL8188E_SUPPORT==1)
-		PHY_SetTxPowerIndex_8188E( pAdapter, PowerIndex, RFPath, Rate );
-#endif
-	} else if (IS_HARDWARE_TYPE_8188F(pAdapter)) {
-#if (RTL8188F_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8188F(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	}
+	rtw_hal_set_tx_power_index(pAdapter, PowerIndex, RFPath, Rate);
 }
 
 void dump_tx_power_idx_title(void *sel, _adapter *adapter)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	u8 bw = hal_data->CurrentChannelBW;
+	u8 bw = hal_data->current_channel_bw;
 
 	RTW_PRINT_SEL(sel, "%s", ch_width_str(bw));
 	if (bw >= CHANNEL_WIDTH_80)
@@ -3411,8 +3653,8 @@ void dump_tx_power_idx_title(void *sel, _adapter *adapter)
 		_RTW_PRINT_SEL(sel, ", cch40:%u", hal_data->cch_40);
 	_RTW_PRINT_SEL(sel, ", cch20:%u\n", hal_data->cch_20);
 
-	RTW_PRINT_SEL(sel, "%-4s %-9s %-3s %-4s %-3s %-4s %-4s %-3s %-5s\n"
-		, "path", "rate", "pwr", "base", "", "(byr", "lmt)", "tpt", "ebias");
+	RTW_PRINT_SEL(sel, "%-4s %-9s %2s %-3s %-4s %-3s %-4s %-4s %-3s %-5s\n"
+		, "path", "rate", "", "pwr", "base", "", "(byr", "lmt)", "tpt", "ebias");
 }
 
 void dump_tx_power_idx_by_path_rs(void *sel, _adapter *adapter, u8 rfpath, u8 rs)
@@ -3422,18 +3664,18 @@ void dump_tx_power_idx_by_path_rs(void *sel, _adapter *adapter, u8 rfpath, u8 rs
 	u8 power_idx;
 	struct txpwr_idx_comp tic;
 	u8 tx_num, i;
-	u8 band = hal_data->CurrentBandType;
-	u8 cch = hal_data->CurrentChannel;
-	u8 bw = hal_data->CurrentChannelBW;
+	u8 band = hal_data->current_band_type;
+	u8 cch = hal_data->current_channel;
+	u8 bw = hal_data->current_channel_bw;
 
-	if (!HAL_SPEC_CHK_RF_PATH(hal_spec, rfpath))
+	if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, rfpath))
 		return;
 
 	if (rs >= RATE_SECTION_NUM)
 		return;
 
 	tx_num = rate_section_to_tx_num(rs);
-	if (tx_num >= hal_spec->nss_num || tx_num >= hal_spec->max_tx_cnt)
+	if (tx_num >= hal_spec->tx_nss_num || tx_num >= hal_spec->max_tx_cnt)
 		return;
 
 	if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
@@ -3445,8 +3687,8 @@ void dump_tx_power_idx_by_path_rs(void *sel, _adapter *adapter, u8 rfpath, u8 rs
 	for (i = 0; i < rates_by_sections[rs].rate_num; i++) {
 		power_idx = rtw_hal_get_tx_power_index(adapter, rfpath, rates_by_sections[rs].rates[i], bw, cch, &tic);
 
-		RTW_PRINT_SEL(sel, "%4c %9s %3u %4u %3d (%3d %3d) %3d %5d\n"
-			, rf_path_char(rfpath), MGN_RATE_STR(rates_by_sections[rs].rates[i])
+		RTW_PRINT_SEL(sel, "%4c %9s %uT %3u %4u %3d (%3d %3d) %3d %5d\n"
+			, rf_path_char(rfpath), MGN_RATE_STR(rates_by_sections[rs].rates[i]), tic.ntx_idx + 1
 			, power_idx, tic.base, (tic.by_rate > tic.limit ? tic.limit : tic.by_rate), tic.by_rate, tic.limit, tic.tpt, tic.ebias);
 	}
 }
@@ -3466,9 +3708,12 @@ bool phy_is_tx_power_limit_needed(_adapter *adapter)
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
 
+#ifdef CONFIG_TXPWR_LIMIT
 	if (regsty->RegEnableTxPowerLimit == 1
 		|| (regsty->RegEnableTxPowerLimit == 2 && hal_data->EEPROMRegulatory == 1))
 		return _TRUE;
+#endif
+
 	return _FALSE;
 }
 
@@ -3505,7 +3750,7 @@ int phy_load_tx_power_by_rate(_adapter *adapter, u8 chk_file)
 #endif
 
 #ifdef CONFIG_EMBEDDED_FWIMG
-	if (HAL_STATUS_SUCCESS == ODM_ConfigBBWithHeaderFile(&hal_data->odmpriv, CONFIG_BB_PHY_REG_PG)) {
+	if (HAL_STATUS_SUCCESS == odm_config_bb_with_header_file(&hal_data->odmpriv, CONFIG_BB_PHY_REG_PG)) {
 		RTW_INFO("default power by rate loaded\n");
 		hal_data->txpwr_by_rate_from_file = 0;
 		goto post_hdl;
@@ -3516,7 +3761,7 @@ int phy_load_tx_power_by_rate(_adapter *adapter, u8 chk_file)
 	goto exit;
 
 post_hdl:
-	if (hal_data->odmpriv.PhyRegPgValueType != PHY_REG_PG_EXACT_VALUE) {
+	if (hal_data->odmpriv.phy_reg_pg_value_type != PHY_REG_PG_EXACT_VALUE) {
 		rtw_warn_on(1);
 		goto exit;
 	}
@@ -3530,14 +3775,17 @@ exit:
 	return ret;
 }
 
+#ifdef CONFIG_TXPWR_LIMIT
 int phy_load_tx_power_limit(_adapter *adapter, u8 chk_file)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	int ret = _FAIL;
 
 	hal_data->txpwr_limit_loaded = 0;
-	PHY_InitTxPowerLimit(adapter);
+	rtw_regd_exc_list_free(rfctl);
+	rtw_txpwr_lmt_list_free(rfctl);
 
 	if (!hal_data->txpwr_by_rate_loaded && regsty->target_tx_pwr_valid != _TRUE) {
 		RTW_ERR("%s():Read Tx power limit before target tx power is specify\n", __func__);
@@ -3554,7 +3802,7 @@ int phy_load_tx_power_limit(_adapter *adapter, u8 chk_file)
 #endif
 
 #ifdef CONFIG_EMBEDDED_FWIMG
-	if (HAL_STATUS_SUCCESS == ODM_ConfigRFWithHeaderFile(&hal_data->odmpriv, CONFIG_RF_TXPWR_LMT, (ODM_RF_RADIO_PATH_E)0)) {
+	if (odm_config_rf_with_header_file(&hal_data->odmpriv, CONFIG_RF_TXPWR_LMT, RF_PATH_A) == HAL_STATUS_SUCCESS) {
 		RTW_INFO("default power limit loaded\n");
 		hal_data->txpwr_limit_from_file = 0;
 		goto post_hdl;
@@ -3565,13 +3813,15 @@ int phy_load_tx_power_limit(_adapter *adapter, u8 chk_file)
 	goto exit;
 
 post_hdl:
-	PHY_ConvertTxPowerLimitToPowerIndex(adapter);
+	phy_txpwr_lmt_post_hdl(adapter);
+	rtw_txpwr_init_regd(rfctl);
 	hal_data->txpwr_limit_loaded = 1;
 	ret = _SUCCESS;
 
 exit:
 	return ret;
 }
+#endif /* CONFIG_TXPWR_LIMIT */
 
 void phy_load_tx_power_ext_info(_adapter *adapter, u8 chk_file)
 {
@@ -3586,8 +3836,10 @@ void phy_load_tx_power_ext_info(_adapter *adapter, u8 chk_file)
 	)
 		phy_load_tx_power_by_rate(adapter, chk_file);
 
+#ifdef CONFIG_TXPWR_LIMIT
 	if (phy_is_tx_power_limit_needed(adapter))
 		phy_load_tx_power_limit(adapter, chk_file);
+#endif
 }
 
 inline void phy_reload_tx_power_ext_info(_adapter *adapter)
@@ -3606,19 +3858,19 @@ void dump_tx_power_ext_info(void *sel, _adapter *adapter)
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 
 	if (regsty->target_tx_pwr_valid == _TRUE)
-		DBG_871X_SEL_NL(sel, "target_tx_power: from registry\n");
+		RTW_PRINT_SEL(sel, "target_tx_power: from registry\n");
 	else if (phy_is_tx_power_by_rate_needed(adapter))
-		DBG_871X_SEL_NL(sel, "target_tx_power: from power by rate\n"); 
+		RTW_PRINT_SEL(sel, "target_tx_power: from power by rate\n"); 
 	else
-		DBG_871X_SEL_NL(sel, "target_tx_power: unavailable\n");
+		RTW_PRINT_SEL(sel, "target_tx_power: unavailable\n");
 
-	DBG_871X_SEL_NL(sel, "tx_power_by_rate: %s, %s, %s\n"
+	RTW_PRINT_SEL(sel, "tx_power_by_rate: %s, %s, %s\n"
 		, phy_is_tx_power_by_rate_needed(adapter) ? "enabled" : "disabled"
 		, hal_data->txpwr_by_rate_loaded ? "loaded" : "unloaded"
 		, hal_data->txpwr_by_rate_from_file ? "file" : "default"
 	);
 
-	DBG_871X_SEL_NL(sel, "tx_power_limit: %s, %s, %s\n"
+	RTW_PRINT_SEL(sel, "tx_power_limit: %s, %s, %s\n"
 		, phy_is_tx_power_limit_needed(adapter) ? "enabled" : "disabled"
 		, hal_data->txpwr_limit_loaded ? "loaded" : "unloaded"
 		, hal_data->txpwr_limit_from_file ? "file" : "default"
@@ -3638,14 +3890,15 @@ void dump_target_tx_power(void *sel, _adapter *adapter)
 			continue;
 
 		for (path = 0; path < RF_PATH_MAX; path++) {
-			if (path >= hal_data->NumTotalRFPath)
+			if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
 				break;
 
-			DBG_871X_SEL_NL(sel, "[%s][%c]\n", band_str(band), rf_path_char(path));
+			RTW_PRINT_SEL(sel, "[%s][%c]%s\n", band_str(band), rf_path_char(path)
+				, (regsty->target_tx_pwr_valid == _FALSE && hal_data->txpwr_by_rate_undefined_band_path[band][path]) ? "(dup)" : "");
 
 			for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
 				tx_num = rate_section_to_tx_num(rs);
-				if (tx_num >= hal_spec->nss_num)
+				if (tx_num >= hal_spec->tx_nss_num)
 					continue;
 
 				if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
@@ -3654,12 +3907,12 @@ void dump_target_tx_power(void *sel, _adapter *adapter)
 				if (IS_VHT_RATE_SECTION(rs) && !IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
 					continue;
 
-				target = PHY_GetTxPowerByRateBase(adapter, band, path, rate_section_to_tx_num(rs), rs);
+				target = PHY_GetTxPowerByRateBase(adapter, band, path, rs);
 
 				if (target % 2)
-					DBG_871X_SEL(sel, "%7s: %2d.5\n", rate_section_str(rs), target / 2);
+					_RTW_PRINT_SEL(sel, "%7s: %2d.5\n", rate_section_str(rs), target / 2);
 				else
-					DBG_871X_SEL(sel, "%7s: %4d\n", rate_section_str(rs), target / 2);
+					_RTW_PRINT_SEL(sel, "%7s: %4d\n", rate_section_str(rs), target / 2);
 			}
 		}
 	}
@@ -3681,14 +3934,15 @@ void dump_tx_power_by_rate(void *sel, _adapter *adapter)
 			continue;
 
 		for (path = 0; path < RF_PATH_MAX; path++) {
-			if (path >= hal_data->NumTotalRFPath)
+			if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
 				break;
 
-			DBG_871X_SEL_NL(sel, "[%s][%c]\n", band_str(band), rf_path_char(path));
+			RTW_PRINT_SEL(sel, "[%s][%c]%s\n", band_str(band), rf_path_char(path)
+				, hal_data->txpwr_by_rate_undefined_band_path[band][path] ? "(dup)" : "");
 
 			for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
 				tx_num = rate_section_to_tx_num(rs);
-				if (tx_num >= hal_spec->nss_num)
+				if (tx_num >= hal_spec->tx_nss_num)
 					continue;
 
 				if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
@@ -3702,205 +3956,31 @@ void dump_tx_power_by_rate(void *sel, _adapter *adapter)
 				else
 					max_rate_num = 8;
 				rate_num = rate_section_rate_num(rs);
-				base = PHY_GetTxPowerByRateBase(adapter, band, path, tx_num, rs);
+				base = PHY_GetTxPowerByRateBase(adapter, band, path, rs);
 
-				DBG_871X_SEL_NL(sel, "%7s: ", rate_section_str(rs));
+				RTW_PRINT_SEL(sel, "%7s: ", rate_section_str(rs));
 
 				/* dump power by rate in db */
 				for (n = rate_num - 1; n >= 0; n--) {
-					by_rate_offset = PHY_GetTxPowerByRate(adapter, band, path, tx_num, rates_by_sections[rs].rates[n]);
+					by_rate_offset = PHY_GetTxPowerByRate(adapter, band, path, rates_by_sections[rs].rates[n]);
 
 					if ((base + by_rate_offset) % 2)
-						DBG_871X_SEL(sel, "%2d.5 ", (base + by_rate_offset) / 2);
+						_RTW_PRINT_SEL(sel, "%2d.5 ", (base + by_rate_offset) / 2);
 					else
-						DBG_871X_SEL(sel, "%4d ", (base + by_rate_offset) / 2);
+						_RTW_PRINT_SEL(sel, "%4d ", (base + by_rate_offset) / 2);
 				}
 				for (n = 0; n < max_rate_num - rate_num; n++)
-					DBG_871X_SEL(sel, "%4s ", "");
+					_RTW_PRINT_SEL(sel, "%4s ", "");
 
-				DBG_871X_SEL(sel, "|");
+				_RTW_PRINT_SEL(sel, "|");
 
 				/* dump power by rate in offset */
 				for (n = rate_num - 1; n >= 0; n--) {
-					by_rate_offset = PHY_GetTxPowerByRate(adapter, band, path, tx_num, rates_by_sections[rs].rates[n]);
-					DBG_871X_SEL(sel, "%3d ", by_rate_offset);
-				}
-				DBG_871X_SEL_NL(sel, "\n");
-
-			}
-		}
-	}
-}
-
-void dump_tx_power_limit(void *sel, _adapter *adapter)
-{
-	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
-
-	int bw, band, ch_num, rs, i, path;
-	u8 ch, n, rd;
-
-	if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
-		DBG_871X_SEL_NL(sel, "tx_pwr_lmt_5g_20_40_ref:0x%02x\n", hal_data->tx_pwr_lmt_5g_20_40_ref);
-
-	for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
-		if (!hal_is_band_support(adapter, band))
-			continue;
-
-		rd = (band == BAND_ON_2_4G ? hal_data->Regulation2_4G : hal_data->Regulation5G);
-
-		for (bw = 0; bw < MAX_5G_BANDWIDTH_NUM; bw++) {
-
-			if (bw >= CHANNEL_WIDTH_160)
-				break;
-			if (band == BAND_ON_2_4G && bw >= CHANNEL_WIDTH_80)
-				break;
-
-			if (band == BAND_ON_2_4G)
-				ch_num = CENTER_CH_2G_NUM;
-			else
-				ch_num = center_chs_5g_num(bw);
-
-			if (ch_num == 0) {
-				rtw_warn_on(1);
-				break;
-			}
-
-			for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
-				if (band == BAND_ON_2_4G && IS_VHT_RATE_SECTION(rs))
-					continue;
-				if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
-					continue;
-				if (bw > CHANNEL_WIDTH_20 && (IS_CCK_RATE_SECTION(rs) || IS_OFDM_RATE_SECTION(rs)))
-					continue;
-				if (bw > CHANNEL_WIDTH_40 && IS_HT_RATE_SECTION(rs))
-					continue;
-
-				if (rate_section_to_tx_num(rs) >= hal_spec->nss_num)
-					continue;
-
-				if (IS_VHT_RATE_SECTION(rs) && !IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
-					continue;
-
-				/* by pass 5G 20M, 40M pure reference */
-				if (band == BAND_ON_5G && (bw == CHANNEL_WIDTH_20 || bw == CHANNEL_WIDTH_40)) {
-					if (hal_data->tx_pwr_lmt_5g_20_40_ref == TX_PWR_LMT_REF_HT_FROM_VHT) {
-						if (IS_HT_RATE_SECTION(rs))
-							continue;
-					} else if (hal_data->tx_pwr_lmt_5g_20_40_ref == TX_PWR_LMT_REF_VHT_FROM_HT) {
-						if (IS_VHT_RATE_SECTION(rs) && bw <= CHANNEL_WIDTH_40)
-							continue;
-					}
-				}
-
-				DBG_871X_SEL_NL(sel, "[%s][%s][%s]\n"
-					, band_str(band)
-					, ch_width_str(bw)
-					, rate_section_str(rs)
-				);
-
-				/* header for limit in db */
-				DBG_871X_SEL_NL(sel, "%3s %5s %5s %5s %5s "
-					, "ch"
-					, (rd == TXPWR_LMT_FCC ? "*FCC" : "FCC")
-					, (rd == TXPWR_LMT_ETSI ? "*ETSI" : "ETSI")
-					, (rd == TXPWR_LMT_MKK ? "*MKK" : "MKK")
-					, (rd == TXPWR_LMT_WW ? "*WW" : "WW")
-				);
-
-				/* header for limit offset */
-				for (path = 0; path < RF_PATH_MAX; path++) {
-					if (path >= hal_data->NumTotalRFPath)
-						break;
-					DBG_871X_SEL(sel, "|%3c %3c %3c %3c "
-						, (rd == TXPWR_LMT_FCC ? rf_path_char(path) : ' ')
-						, (rd == TXPWR_LMT_ETSI ? rf_path_char(path) : ' ')
-						, (rd == TXPWR_LMT_MKK ? rf_path_char(path) : ' ')
-						, (rd == TXPWR_LMT_WW ? rf_path_char(path) : ' ')
-					);
+					by_rate_offset = PHY_GetTxPowerByRate(adapter, band, path, rates_by_sections[rs].rates[n]);
+					_RTW_PRINT_SEL(sel, "%3d ", by_rate_offset);
 				}
-				DBG_871X_SEL(sel, "\n");
-
-				for (n = 0; n < ch_num; n++) {
-					s8 limit_idx[RF_PATH_MAX][MAX_REGULATION_NUM];
-					s8 limit_offset[MAX_REGULATION_NUM];
-					u8 base;
-
-					if (band == BAND_ON_2_4G)
-						ch = n + 1;
-					else
-						ch = center_chs_5g(bw, n);
-
-					if (ch == 0) {
-						rtw_warn_on(1);
-						break;
-					}
-
-					/* dump limit in db (calculate from path A) */
-					limit_offset[0] = PHY_GetTxPowerLimit_no_sc(adapter, 3, band, bw, RF_PATH_A, rates_by_sections[rs].rates[0], ch); /* FCC */
-					limit_offset[1] = PHY_GetTxPowerLimit_no_sc(adapter, 1, band, bw, RF_PATH_A, rates_by_sections[rs].rates[0], ch); /* ETSI */
-					limit_offset[2] = PHY_GetTxPowerLimit_no_sc(adapter, 2, band, bw, RF_PATH_A, rates_by_sections[rs].rates[0], ch); /* MKK */
-					limit_offset[3] = PHY_GetTxPowerLimit_no_sc(adapter, 4, band, bw, RF_PATH_A, rates_by_sections[rs].rates[0], ch); /* WW */
-
-					base = PHY_GetTxPowerByRateBase(adapter, band, RF_PATH_A, rate_section_to_tx_num(rs), rs);
-
-					DBG_871X_SEL_NL(sel, "%3u ", ch);
-					for (i = 0; i < MAX_REGULATION_NUM; i++) {
-						if (limit_offset[i] == MAX_POWER_INDEX) {
-							limit_idx[0][i] = MAX_POWER_INDEX;
-							DBG_871X_SEL(sel, "%5s ", "NA");
-						} else {
-							limit_idx[0][i] = limit_offset[i] + base;
-							if ((limit_offset[i] + base) % 2)
-								DBG_871X_SEL(sel, "%3d.5 ", (limit_offset[i] + base) / 2);
-							else
-								DBG_871X_SEL(sel, "%5d ", (limit_offset[i] + base) / 2);
-						}
-					}
-
-					/* dump limit offset of each path */
-					for (path = 0; path < RF_PATH_MAX; path++) {
-						if (path >= hal_data->NumTotalRFPath)
-							break;
-						limit_offset[0] = PHY_GetTxPowerLimit_no_sc(adapter, 3, band, bw, path, rates_by_sections[rs].rates[0], ch); /* FCC */
-						limit_offset[1] = PHY_GetTxPowerLimit_no_sc(adapter, 1, band, bw, path, rates_by_sections[rs].rates[0], ch); /* ETSI */
-						limit_offset[2] = PHY_GetTxPowerLimit_no_sc(adapter, 2, band, bw, path, rates_by_sections[rs].rates[0], ch); /* MKK */
-						limit_offset[3] = PHY_GetTxPowerLimit_no_sc(adapter, 4, band, bw, path, rates_by_sections[rs].rates[0], ch); /* WW */
-
-						base = PHY_GetTxPowerByRateBase(adapter, band, path, rate_section_to_tx_num(rs), rs);
-
-						DBG_871X_SEL(sel, "|");
-						for (i = 0; i < MAX_REGULATION_NUM; i++) {
-							if (limit_offset[i] == MAX_POWER_INDEX) {
-								limit_idx[path][i] = MAX_POWER_INDEX;
-								DBG_871X_SEL(sel, "%3s ", "NA");
-							} else {
-								limit_idx[path][i] = limit_offset[i] + base;
-								DBG_871X_SEL(sel, "%3d ", limit_offset[i]);
-							}
-						}
-					}
-
-					/* compare limit_idx of each path, print 'x' when mismatch */
-					if (hal_data->NumTotalRFPath > 1) {
-						for (i = 0; i < MAX_REGULATION_NUM; i++) {
-							for (path = 0; path < RF_PATH_MAX; path++) {
-								if (path >= hal_data->NumTotalRFPath)
-									break;
-								if (limit_idx[path][i] != limit_idx[(path + 1) % hal_data->NumTotalRFPath][i])
-									break;
-							}
-							if (path >= hal_data->NumTotalRFPath)
-								DBG_871X_SEL(sel, " ");
-							else
-								DBG_871X_SEL(sel, "x");
-						}
-					}
-					DBG_871X_SEL(sel, "\n");
+				RTW_PRINT_SEL(sel, "\n");
 
-				}
-				DBG_871X_SEL_NL(sel, "\n");
 			}
 		}
 	}
@@ -3933,7 +4013,7 @@ int rtw_get_phy_file_path(_adapter *adapter, const char *file_name)
 int
 phy_ConfigMACWithParaFile(
 	IN	PADAPTER	Adapter,
-	IN	char* 		pFileName
+	IN	char		*pFileName
 )
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
@@ -3941,7 +4021,7 @@ phy_ConfigMACWithParaFile(
 	char	*szLine, *ptmp;
 	u32	u4bRegOffset, u4bRegValue, u4bMove;
 
-	if(!(Adapter->registrypriv.load_phy_file & LOAD_MAC_PARA_FILE))
+	if (!(Adapter->registrypriv.load_phy_file & LOAD_MAC_PARA_FILE))
 		return rtStatus;
 
 	_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
@@ -3953,56 +4033,41 @@ phy_ConfigMACWithParaFile(
 			if (rlen > 0) {
 				rtStatus = _SUCCESS;
 				pHalData->mac_reg = rtw_zvmalloc(rlen);
-				if(pHalData->mac_reg) {
+				if (pHalData->mac_reg) {
 					_rtw_memcpy(pHalData->mac_reg, pHalData->para_file_buf, rlen);
 					pHalData->mac_reg_len = rlen;
-				}
-				else {
-					DBG_871X("%s mac_reg alloc fail !\n",__FUNCTION__);
-				}
+				} else
+					RTW_INFO("%s mac_reg alloc fail !\n", __FUNCTION__);
 			}
 		}
-	}
-	else
-	{
+	} else {
 		if ((pHalData->mac_reg_len != 0) && (pHalData->mac_reg != NULL)) {
 			_rtw_memcpy(pHalData->para_file_buf, pHalData->mac_reg, pHalData->mac_reg_len);
 			rtStatus = _SUCCESS;
-		}
-		else {
-			DBG_871X("%s(): Critical Error !!!\n",__FUNCTION__);
-		}
+		} else
+			RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
 	}
 
-	if (rtStatus == _SUCCESS)
-	{
+	if (rtStatus == _SUCCESS) {
 		ptmp = pHalData->para_file_buf;
-		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp))
-		{
-			if(!IsCommentString(szLine))
-			{
-				// Get 1st hex value as register offset
-				if(GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
-				{
-					if(u4bRegOffset == 0xffff)
-					{ // Ending.
+		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
+			if (!IsCommentString(szLine)) {
+				/* Get 1st hex value as register offset */
+				if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
+					if (u4bRegOffset == 0xffff) {
+						/* Ending. */
 						break;
 					}
 
-					// Get 2nd hex value as register value.
+					/* Get 2nd hex value as register value. */
 					szLine += u4bMove;
-					if(GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
-					{
+					if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
 						rtw_write8(Adapter, u4bRegOffset, (u8)u4bRegValue);
-					}
 				}
 			}
 		}
-	}
-	else
-	{
-		DBG_871X("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
-	}
+	} else
+		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 
 	return rtStatus;
 }
@@ -4010,7 +4075,7 @@ phy_ConfigMACWithParaFile(
 int
 phy_ConfigBBWithParaFile(
 	IN	PADAPTER	Adapter,
-	IN	char*		pFileName,
+	IN	char		*pFileName,
 	IN	u32			ConfigType
 )
 {
@@ -4021,22 +4086,21 @@ phy_ConfigBBWithParaFile(
 	char	*pBuf = NULL;
 	u32	*pBufLen = NULL;
 
-	if(!(Adapter->registrypriv.load_phy_file & LOAD_BB_PARA_FILE))
+	if (!(Adapter->registrypriv.load_phy_file & LOAD_BB_PARA_FILE))
 		return rtStatus;
 
-	switch(ConfigType)
-	{
-		case CONFIG_BB_PHY_REG:
-			pBuf = pHalData->bb_phy_reg;
-			pBufLen = &pHalData->bb_phy_reg_len;
-			break;
-		case CONFIG_BB_AGC_TAB:
-			pBuf = pHalData->bb_agc_tab;
-			pBufLen = &pHalData->bb_agc_tab_len;
-			break;
-		default:
-			DBG_871X("Unknown ConfigType!! %d\r\n", ConfigType);
-			break;
+	switch (ConfigType) {
+	case CONFIG_BB_PHY_REG:
+		pBuf = pHalData->bb_phy_reg;
+		pBufLen = &pHalData->bb_phy_reg_len;
+		break;
+	case CONFIG_BB_AGC_TAB:
+		pBuf = pHalData->bb_agc_tab;
+		pBufLen = &pHalData->bb_agc_tab_len;
+		break;
+	default:
+		RTW_INFO("Unknown ConfigType!! %d\r\n", ConfigType);
+		break;
 	}
 
 	_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
@@ -4048,101 +4112,73 @@ phy_ConfigBBWithParaFile(
 			if (rlen > 0) {
 				rtStatus = _SUCCESS;
 				pBuf = rtw_zvmalloc(rlen);
-				if(pBuf) {
+				if (pBuf) {
 					_rtw_memcpy(pBuf, pHalData->para_file_buf, rlen);
 					*pBufLen = rlen;
 
-					switch(ConfigType)
-					{
-						case CONFIG_BB_PHY_REG:
-							pHalData->bb_phy_reg = pBuf;
-							break;
-						case CONFIG_BB_AGC_TAB:
-							pHalData->bb_agc_tab = pBuf;
-							break;
+					switch (ConfigType) {
+					case CONFIG_BB_PHY_REG:
+						pHalData->bb_phy_reg = pBuf;
+						break;
+					case CONFIG_BB_AGC_TAB:
+						pHalData->bb_agc_tab = pBuf;
+						break;
 					}
-				}
-				else {
-					DBG_871X("%s(): ConfigType %d  alloc fail !\n",__FUNCTION__,ConfigType);
-				}
+				} else
+					RTW_INFO("%s(): ConfigType %d  alloc fail !\n", __FUNCTION__, ConfigType);
 			}
 		}
-	}
-	else
-	{
-		if ((pBufLen != NULL) && (*pBufLen == 0) && (pBuf == NULL)) {
+	} else {
+		if ((pBufLen != NULL) && (*pBufLen != 0) && (pBuf != NULL)) {
 			_rtw_memcpy(pHalData->para_file_buf, pBuf, *pBufLen);
 			rtStatus = _SUCCESS;
-		}
-		else {
-			DBG_871X("%s(): Critical Error !!!\n",__FUNCTION__);
-		}
+		} else
+			RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
 	}
 
-	if (rtStatus == _SUCCESS)
-	{
+	if (rtStatus == _SUCCESS) {
 		ptmp = pHalData->para_file_buf;
-		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp))
-		{
-			if(!IsCommentString(szLine))
-			{
-				// Get 1st hex value as register offset.
-				if(GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
-				{
-					if(u4bRegOffset == 0xffff)
-					{ // Ending.
+		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
+			if (!IsCommentString(szLine)) {
+				/* Get 1st hex value as register offset. */
+				if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
+					if (u4bRegOffset == 0xffff) {
+						/* Ending. */
 						break;
-					}
-					else if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe)
-					{
-						#ifdef CONFIG_LONG_DELAY_ISSUE
+					} else if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe) {
+#ifdef CONFIG_LONG_DELAY_ISSUE
 						rtw_msleep_os(50);
-						#else
+#else
 						rtw_mdelay_os(50);
-						#endif
-					}
-					else if (u4bRegOffset == 0xfd)
-					{
+#endif
+					} else if (u4bRegOffset == 0xfd)
 						rtw_mdelay_os(5);
-					}
 					else if (u4bRegOffset == 0xfc)
-					{
 						rtw_mdelay_os(1);
-					}
 					else if (u4bRegOffset == 0xfb)
-					{
 						rtw_udelay_os(50);
-					}
 					else if (u4bRegOffset == 0xfa)
-					{
 						rtw_udelay_os(5);
-					}
 					else if (u4bRegOffset == 0xf9)
-					{
 						rtw_udelay_os(1);
-					}
-					
-					// Get 2nd hex value as register value.
+
+					/* Get 2nd hex value as register value. */
 					szLine += u4bMove;
-					if(GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
-					{
-						//DBG_871X("[BB-ADDR]%03lX=%08lX\n", u4bRegOffset, u4bRegValue);
-						PHY_SetBBReg(Adapter, u4bRegOffset, bMaskDWord, u4bRegValue);
+					if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
+						/* RTW_INFO("[BB-ADDR]%03lX=%08lX\n", u4bRegOffset, u4bRegValue); */
+						phy_set_bb_reg(Adapter, u4bRegOffset, bMaskDWord, u4bRegValue);
 
 						if (u4bRegOffset == 0xa24)
-							pHalData->odmpriv.RFCalibrateInfo.RegA24 = u4bRegValue;
+							pHalData->odmpriv.rf_calibrate_info.rega24 = u4bRegValue;
 
-						// Add 1us delay between BB/RF register setting.
+						/* Add 1us delay between BB/RF register setting. */
 						rtw_udelay_os(1);
 					}
 				}
 			}
 		}
-	}
-	else
-	{
-		DBG_871X("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
-	}
+	} else
+		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 
 	return rtStatus;
 }
@@ -4150,37 +4186,35 @@ phy_ConfigBBWithParaFile(
 VOID
 phy_DecryptBBPgParaFile(
 	PADAPTER		Adapter,
-	char*			buffer
-	)
+	char			*buffer
+)
 {
 	u32	i = 0, j = 0;
 	u8	map[95] = {0};
 	u8	currentChar;
 	char	*BufOfLines, *ptmp;
 
-	//DBG_871X("=====>phy_DecryptBBPgParaFile()\n");
-	// 32 the ascii code of the first visable char, 126 the last one
-	for ( i = 0; i < 95; ++i )
-		map[i] = ( u8 ) ( 94 - i );
+	/* RTW_INFO("=====>phy_DecryptBBPgParaFile()\n"); */
+	/* 32 the ascii code of the first visable char, 126 the last one */
+	for (i = 0; i < 95; ++i)
+		map[i] = (u8)(94 - i);
 
 	ptmp = buffer;
 	i = 0;
-	for (BufOfLines = GetLineFromBuffer(ptmp); BufOfLines != NULL; BufOfLines = GetLineFromBuffer(ptmp))
-	{
-		//DBG_871X("Encrypted Line: %s\n", BufOfLines);
+	for (BufOfLines = GetLineFromBuffer(ptmp); BufOfLines != NULL; BufOfLines = GetLineFromBuffer(ptmp)) {
+		/* RTW_INFO("Encrypted Line: %s\n", BufOfLines); */
 
-		for ( j = 0; j < strlen(BufOfLines); ++j )
-		{
+		for (j = 0; j < strlen(BufOfLines); ++j) {
 			currentChar = BufOfLines[j];
 
-			if ( currentChar == '\0' )
+			if (currentChar == '\0')
 				break;
 
-			currentChar -=  (u8) ( ( ( ( i + j ) * 3 ) % 128 ) );
-			
+			currentChar -= (u8)((((i + j) * 3) % 128));
+
 			BufOfLines[j] = map[currentChar - 32] + 32;
 		}
-		//DBG_871X("Decrypted Line: %s\n", BufOfLines );
+		/* RTW_INFO("Decrypted Line: %s\n", BufOfLines ); */
 		if (strlen(BufOfLines) != 0)
 			i++;
 		BufOfLines[strlen(BufOfLines)] = '\n';
@@ -4190,8 +4224,8 @@ phy_DecryptBBPgParaFile(
 int
 phy_ParseBBPgParaFile(
 	PADAPTER		Adapter,
-	char*			buffer
-	)
+	char			*buffer
+)
 {
 	int	rtStatus = _SUCCESS;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
@@ -4202,278 +4236,245 @@ phy_ParseBBPgParaFile(
 	u8	tx_num = 0;
 	u8	band = 0, rf_path = 0;
 
-	//DBG_871X("=====>phy_ParseBBPgParaFile()\n");
-	
-	if ( Adapter->registrypriv.RegDecryptCustomFile == 1 )
-		phy_DecryptBBPgParaFile( Adapter, buffer);
+	/* RTW_INFO("=====>phy_ParseBBPgParaFile()\n"); */
+
+	if (Adapter->registrypriv.RegDecryptCustomFile == 1)
+		phy_DecryptBBPgParaFile(Adapter, buffer);
 
 	ptmp = buffer;
-	for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp))
-	{
+	for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
 		if (isAllSpaceOrTab(szLine, sizeof(*szLine)))
 			continue;
 
-		if(!IsCommentString(szLine))
-		{
-			// Get header info (relative value or exact value)
-			if ( firstLine )
-			{
-				if ( eqNByte( szLine, (u8 *)("#[v1]"), 5 ) )
-				{
-					
-					pHalData->odmpriv.PhyRegPgVersion = szLine[3] - '0';
-					//DBG_871X("This is a new format PHY_REG_PG.txt \n");
-				}
-				else if ( eqNByte( szLine, (u8 *)("#[v0]"), 5 ))
-				{
-					pHalData->odmpriv.PhyRegPgVersion = szLine[3] - '0';
-					//DBG_871X("This is a old format PHY_REG_PG.txt ok\n");
-				}
-				else
-				{
-					DBG_871X("The format in PHY_REG_PG are invalid %s\n", szLine);
+		if (!IsCommentString(szLine)) {
+			/* Get header info (relative value or exact value) */
+			if (firstLine) {
+				if (eqNByte(szLine, (u8 *)("#[v1]"), 5)) {
+
+					pHalData->odmpriv.phy_reg_pg_version = szLine[3] - '0';
+					/* RTW_INFO("This is a new format PHY_REG_PG.txt\n"); */
+				} else if (eqNByte(szLine, (u8 *)("#[v0]"), 5)) {
+					pHalData->odmpriv.phy_reg_pg_version = szLine[3] - '0';
+					/* RTW_INFO("This is a old format PHY_REG_PG.txt ok\n"); */
+				} else {
+					RTW_INFO("The format in PHY_REG_PG are invalid %s\n", szLine);
 					return _FAIL;
 				}
-					
-				if ( eqNByte( szLine + 5, (u8 *)("[Exact]#"), 8 ) )
-				{
-					pHalData->odmpriv.PhyRegPgValueType = PHY_REG_PG_EXACT_VALUE;
-					//DBG_871X("The values in PHY_REG_PG are exact values ok\n");
+
+				if (eqNByte(szLine + 5, (u8 *)("[Exact]#"), 8)) {
+					pHalData->odmpriv.phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+					/* RTW_INFO("The values in PHY_REG_PG are exact values ok\n"); */
 					firstLine = _FALSE;
 					continue;
-				}
-				else if ( eqNByte( szLine + 5, (pu1Byte)("[Relative]#"), 11 ) )
-				{
-					pHalData->odmpriv.PhyRegPgValueType = PHY_REG_PG_RELATIVE_VALUE;
-					//DBG_871X("The values in PHY_REG_PG are relative values ok\n");
+				} else if (eqNByte(szLine + 5, (pu1Byte)("[Relative]#"), 11)) {
+					pHalData->odmpriv.phy_reg_pg_value_type = PHY_REG_PG_RELATIVE_VALUE;
+					/* RTW_INFO("The values in PHY_REG_PG are relative values ok\n"); */
 					firstLine = _FALSE;
 					continue;
-				}
-				else
-				{
-					DBG_871X("The values in PHY_REG_PG are invalid %s\n", szLine);
+				} else {
+					RTW_INFO("The values in PHY_REG_PG are invalid %s\n", szLine);
 					return _FAIL;
 				}
 			}
 
-			if ( pHalData->odmpriv.PhyRegPgVersion == 0 )
-			{
-				// Get 1st hex value as register offset.
-				if(GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
-				{
+			if (pHalData->odmpriv.phy_reg_pg_version == 0) {
+				/* Get 1st hex value as register offset. */
+				if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
 					szLine += u4bMove;
-					if(u4bRegOffset == 0xffff)
-					{ // Ending.
+					if (u4bRegOffset == 0xffff) {
+						/* Ending. */
 						break;
 					}
 
-					// Get 2nd hex value as register mask.
-					if ( GetHexValueFromString(szLine, &u4bRegMask, &u4bMove) )
+					/* Get 2nd hex value as register mask. */
+					if (GetHexValueFromString(szLine, &u4bRegMask, &u4bMove))
 						szLine += u4bMove;
 					else
 						return _FAIL;
 
-					if ( pHalData->odmpriv.PhyRegPgValueType == PHY_REG_PG_RELATIVE_VALUE ) 
-					{
-						// Get 3rd hex value as register value.
-						if(GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
-						{
-							PHY_StoreTxPowerByRate(Adapter, 0, 0, 1, u4bRegOffset, u4bRegMask, u4bRegValue);
-							//DBG_871X("[ADDR] %03X=%08X Mask=%08x\n", u4bRegOffset, u4bRegValue, u4bRegMask);
-						}
-						else
-						{
+					if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_RELATIVE_VALUE) {
+						/* Get 3rd hex value as register value. */
+						if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
+							phy_store_tx_power_by_rate(Adapter, 0, 0, 1, u4bRegOffset, u4bRegMask, u4bRegValue);
+							/* RTW_INFO("[ADDR] %03X=%08X Mask=%08x\n", u4bRegOffset, u4bRegValue, u4bRegMask); */
+						} else
 							return _FAIL;
-						}
-					}
-					else if ( pHalData->odmpriv.PhyRegPgValueType == PHY_REG_PG_EXACT_VALUE ) 
-					{
+					} else if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_EXACT_VALUE) {
 						u32	combineValue = 0;
 						u8	integer = 0, fraction = 0;
-						
-						if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+
+						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 							szLine += u4bMove;
-						else 
+						else
 							return _FAIL;
-						
+
 						integer *= 2;
-						if ( fraction == 5 ) integer += 1;
-						combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-						//DBG_871X(" %d", integer );
+						if (fraction == 5)
+							integer += 1;
+						combineValue |= (((integer / 10) << 4) + (integer % 10));
+						/* RTW_INFO(" %d", integer ); */
 
-						if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 							szLine += u4bMove;
-						else 
+						else
 							return _FAIL;
 
 						integer *= 2;
-						if ( fraction == 5 ) integer += 1;
+						if (fraction == 5)
+							integer += 1;
 						combineValue <<= 8;
-						combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-						//DBG_871X(" %d", integer );
+						combineValue |= (((integer / 10) << 4) + (integer % 10));
+						/* RTW_INFO(" %d", integer ); */
 
-						if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 							szLine += u4bMove;
 						else
 							return _FAIL;
-						
+
 						integer *= 2;
-						if ( fraction == 5 ) integer += 1;
+						if (fraction == 5)
+							integer += 1;
 						combineValue <<= 8;
-						combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-						//DBG_871X(" %d", integer );
+						combineValue |= (((integer / 10) << 4) + (integer % 10));
+						/* RTW_INFO(" %d", integer ); */
 
-						if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 							szLine += u4bMove;
-						else 
+						else
 							return _FAIL;
 
 						integer *= 2;
-						if ( fraction == 5 ) integer += 1;
+						if (fraction == 5)
+							integer += 1;
 						combineValue <<= 8;
-						combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-						//DBG_871X(" %d", integer );
-						PHY_StoreTxPowerByRate(Adapter, 0, 0, 1, u4bRegOffset, u4bRegMask, combineValue);
+						combineValue |= (((integer / 10) << 4) + (integer % 10));
+						/* RTW_INFO(" %d", integer ); */
+						phy_store_tx_power_by_rate(Adapter, 0, 0, 1, u4bRegOffset, u4bRegMask, combineValue);
 
-						//DBG_871X("[ADDR] 0x%3x = 0x%4x\n", u4bRegOffset, combineValue );
+						/* RTW_INFO("[ADDR] 0x%3x = 0x%4x\n", u4bRegOffset, combineValue ); */
 					}
 				}
-			}
-			else if ( pHalData->odmpriv.PhyRegPgVersion > 0 )
-			{
+			} else if (pHalData->odmpriv.phy_reg_pg_version > 0) {
 				u32	index = 0, cnt = 0;
 
-				if ( eqNByte( szLine, "0xffff", 6 ) )
+				if (eqNByte(szLine, "0xffff", 6))
 					break;
 
-				if( !eqNByte( "#[END]#", szLine, 7 ) )
-				{
-					// load the table label info
-					if ( szLine[0] == '#' )
-					{
+				if (!eqNByte("#[END]#", szLine, 7)) {
+					/* load the table label info */
+					if (szLine[0] == '#') {
 						index = 0;
-						if ( eqNByte( szLine, "#[2.4G]" , 7 ) )
-						{
+						if (eqNByte(szLine, "#[2.4G]" , 7)) {
 							band = BAND_ON_2_4G;
 							index += 8;
-						}
-						else if ( eqNByte( szLine, "#[5G]", 5) )
-						{
+						} else if (eqNByte(szLine, "#[5G]", 5)) {
 							band = BAND_ON_5G;
 							index += 6;
-						}
-						else
-						{
-							DBG_871X("Invalid band %s in PHY_REG_PG.txt \n", szLine );
+						} else {
+							RTW_INFO("Invalid band %s in PHY_REG_PG.txt\n", szLine);
 							return _FAIL;
 						}
 
-						rf_path= szLine[index] - 'A';
-						//DBG_871X(" Table label Band %d, RfPath %d\n", band, rf_path );
-					}
-					else // load rows of tables
-					{
-						if ( szLine[1] == '1' )
+						rf_path = szLine[index] - 'A';
+						/* RTW_INFO(" Table label Band %d, RfPath %d\n", band, rf_path ); */
+					} else { /* load rows of tables */
+						if (szLine[1] == '1')
 							tx_num = RF_1TX;
-						else if ( szLine[1] == '2' )
+						else if (szLine[1] == '2')
 							tx_num = RF_2TX;
-						else if ( szLine[1] == '3' )
+						else if (szLine[1] == '3')
 							tx_num = RF_3TX;
-						else if ( szLine[1] == '4' )
+						else if (szLine[1] == '4')
 							tx_num = RF_4TX;
-						else
-						{
-							DBG_871X("Invalid row in PHY_REG_PG.txt '%c'(%d)\n", szLine[1], szLine[1]);
+						else {
+							RTW_INFO("Invalid row in PHY_REG_PG.txt '%c'(%d)\n", szLine[1], szLine[1]);
 							return _FAIL;
 						}
 
-						while ( szLine[index] != ']' )
+						while (szLine[index] != ']')
 							++index;
-						++index;// skip ]
+						++index;/* skip ] */
 
-						// Get 2nd hex value as register offset.
+						/* Get 2nd hex value as register offset. */
 						szLine += index;
-						if ( GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove) )
+						if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
 							szLine += u4bMove;
 						else
 							return _FAIL;
 
-						// Get 2nd hex value as register mask.
-						if ( GetHexValueFromString(szLine, &u4bRegMask, &u4bMove) )
+						/* Get 2nd hex value as register mask. */
+						if (GetHexValueFromString(szLine, &u4bRegMask, &u4bMove))
 							szLine += u4bMove;
 						else
 							return _FAIL;
 
-						if ( pHalData->odmpriv.PhyRegPgValueType == PHY_REG_PG_RELATIVE_VALUE ) 
-						{
-							// Get 3rd hex value as register value.
-							if(GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
-							{
-								PHY_StoreTxPowerByRate(Adapter, band, rf_path, tx_num, u4bRegOffset, u4bRegMask, u4bRegValue);
-								//DBG_871X("[ADDR] %03X (tx_num %d) =%08X Mask=%08x\n", u4bRegOffset, tx_num, u4bRegValue, u4bRegMask);
-							}
-							else
-							{
+						if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_RELATIVE_VALUE) {
+							/* Get 3rd hex value as register value. */
+							if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
+								phy_store_tx_power_by_rate(Adapter, band, rf_path, tx_num, u4bRegOffset, u4bRegMask, u4bRegValue);
+								/* RTW_INFO("[ADDR] %03X (tx_num %d) =%08X Mask=%08x\n", u4bRegOffset, tx_num, u4bRegValue, u4bRegMask); */
+							} else
 								return _FAIL;
-							}
-						}
-						else if ( pHalData->odmpriv.PhyRegPgValueType == PHY_REG_PG_EXACT_VALUE ) 
-						{
+						} else if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_EXACT_VALUE) {
 							u32	combineValue = 0;
 							u8	integer = 0, fraction = 0;
 
-							if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
 								return _FAIL;
 
 							integer *= 2;
-							if ( fraction == 5 ) integer += 1;
-							combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-							//DBG_871X(" %d", integer );
+							if (fraction == 5)
+								integer += 1;
+							combineValue |= (((integer / 10) << 4) + (integer % 10));
+							/* RTW_INFO(" %d", integer ); */
 
-							if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
 								return _FAIL;
 
 							integer *= 2;
-							if ( fraction == 5 ) integer += 1;
+							if (fraction == 5)
+								integer += 1;
 							combineValue <<= 8;
-							combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-							//DBG_871X(" %d", integer );
+							combineValue |= (((integer / 10) << 4) + (integer % 10));
+							/* RTW_INFO(" %d", integer ); */
 
-							if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
 								return _FAIL;
 
 							integer *= 2;
-							if ( fraction == 5 ) integer += 1;
+							if (fraction == 5)
+								integer += 1;
 							combineValue <<= 8;
-							combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-							//DBG_871X(" %d", integer );
+							combineValue |= (((integer / 10) << 4) + (integer % 10));
+							/* RTW_INFO(" %d", integer ); */
 
-							if ( GetFractionValueFromString( szLine, &integer, &fraction, &u4bMove ) )
+							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
 								return _FAIL;
 
 							integer *= 2;
-							if ( fraction == 5 ) integer += 1;
+							if (fraction == 5)
+								integer += 1;
 							combineValue <<= 8;
-							combineValue |= ( ( ( integer / 10 ) << 4 ) + ( integer % 10 ) );
-							//DBG_871X(" %d", integer );
-							PHY_StoreTxPowerByRate(Adapter, band, rf_path, tx_num, u4bRegOffset, u4bRegMask, combineValue);
+							combineValue |= (((integer / 10) << 4) + (integer % 10));
+							/* RTW_INFO(" %d", integer ); */
+							phy_store_tx_power_by_rate(Adapter, band, rf_path, tx_num, u4bRegOffset, u4bRegMask, combineValue);
 
-							//DBG_871X("[ADDR] 0x%3x (tx_num %d) = 0x%4x\n", u4bRegOffset, tx_num, combineValue );
+							/* RTW_INFO("[ADDR] 0x%3x (tx_num %d) = 0x%4x\n", u4bRegOffset, tx_num, combineValue ); */
 						}
 					}
 				}
 			}
 		}
 	}
-	//DBG_871X("<=====phy_ParseBBPgParaFile()\n");
+	/* RTW_INFO("<=====phy_ParseBBPgParaFile()\n"); */
 	return rtStatus;
 }
 
@@ -4485,7 +4486,7 @@ phy_ConfigBBWithPgParaFile(
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
 	int	rlen = 0, rtStatus = _FAIL;
 
-	if(!(Adapter->registrypriv.load_phy_file & LOAD_BB_PG_PARA_FILE))
+	if (!(Adapter->registrypriv.load_phy_file & LOAD_BB_PG_PARA_FILE))
 		return rtStatus;
 
 	_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
@@ -4497,44 +4498,36 @@ phy_ConfigBBWithPgParaFile(
 			if (rlen > 0) {
 				rtStatus = _SUCCESS;
 				pHalData->bb_phy_reg_pg = rtw_zvmalloc(rlen);
-				if(pHalData->bb_phy_reg_pg) {
+				if (pHalData->bb_phy_reg_pg) {
 					_rtw_memcpy(pHalData->bb_phy_reg_pg, pHalData->para_file_buf, rlen);
 					pHalData->bb_phy_reg_pg_len = rlen;
-				}
-				else {
-					DBG_871X("%s bb_phy_reg_pg alloc fail !\n",__FUNCTION__);
-				}
+				} else
+					RTW_INFO("%s bb_phy_reg_pg alloc fail !\n", __FUNCTION__);
 			}
 		}
 	} else {
 		if ((pHalData->bb_phy_reg_pg_len != 0) && (pHalData->bb_phy_reg_pg != NULL)) {
 			_rtw_memcpy(pHalData->para_file_buf, pHalData->bb_phy_reg_pg, pHalData->bb_phy_reg_pg_len);
 			rtStatus = _SUCCESS;
-		}
-		else {
-			DBG_871X("%s(): Critical Error !!!\n",__FUNCTION__);
-		}
+		} else
+			RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
 	}
 
-	if(rtStatus == _SUCCESS)
-	{
-		//DBG_871X("phy_ConfigBBWithPgParaFile(): read %s ok\n", pFileName);
+	if (rtStatus == _SUCCESS) {
+		/* RTW_INFO("phy_ConfigBBWithPgParaFile(): read %s ok\n", pFileName); */
 		phy_ParseBBPgParaFile(Adapter, pHalData->para_file_buf);
-	}
-	else
-	{
-		DBG_871X("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
-	}
+	} else
+		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 
 	return rtStatus;
 }
 
-#if (MP_DRIVER == 1 )
+#if (MP_DRIVER == 1)
 
 int
 phy_ConfigBBWithMpParaFile(
 	IN	PADAPTER	Adapter,
-	IN	char* 		pFileName
+	IN	char		*pFileName
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
@@ -4542,7 +4535,7 @@ phy_ConfigBBWithMpParaFile(
 	char	*szLine, *ptmp;
 	u32	u4bRegOffset, u4bRegValue, u4bMove;
 
-	if(!(Adapter->registrypriv.load_phy_file & LOAD_BB_MP_PARA_FILE))
+	if (!(Adapter->registrypriv.load_phy_file & LOAD_BB_MP_PARA_FILE))
 		return rtStatus;
 
 	_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
@@ -4554,90 +4547,63 @@ phy_ConfigBBWithMpParaFile(
 			if (rlen > 0) {
 				rtStatus = _SUCCESS;
 				pHalData->bb_phy_reg_mp = rtw_zvmalloc(rlen);
-				if(pHalData->bb_phy_reg_mp) {
+				if (pHalData->bb_phy_reg_mp) {
 					_rtw_memcpy(pHalData->bb_phy_reg_mp, pHalData->para_file_buf, rlen);
 					pHalData->bb_phy_reg_mp_len = rlen;
-				}
-				else {
-					DBG_871X("%s bb_phy_reg_mp alloc fail !\n",__FUNCTION__);
-				}
+				} else
+					RTW_INFO("%s bb_phy_reg_mp alloc fail !\n", __FUNCTION__);
 			}
 		}
-	}
-	else
-	{
+	} else {
 		if ((pHalData->bb_phy_reg_mp_len != 0) && (pHalData->bb_phy_reg_mp != NULL)) {
 			_rtw_memcpy(pHalData->para_file_buf, pHalData->bb_phy_reg_mp, pHalData->bb_phy_reg_mp_len);
 			rtStatus = _SUCCESS;
-		}
-		else {
-			DBG_871X("%s(): Critical Error !!!\n",__FUNCTION__);
-		}
+		} else
+			RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
 	}
 
-	if(rtStatus == _SUCCESS)
-	{
-		//DBG_871X("phy_ConfigBBWithMpParaFile(): read %s ok\n", pFileName);
+	if (rtStatus == _SUCCESS) {
+		/* RTW_INFO("phy_ConfigBBWithMpParaFile(): read %s ok\n", pFileName); */
 
 		ptmp = pHalData->para_file_buf;
-		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp))
-		{
-			if(!IsCommentString(szLine))
-			{
-				// Get 1st hex value as register offset.
-				if(GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
-				{
-					if(u4bRegOffset == 0xffff)
-					{ // Ending.
+		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
+			if (!IsCommentString(szLine)) {
+				/* Get 1st hex value as register offset. */
+				if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
+					if (u4bRegOffset == 0xffff) {
+						/* Ending. */
 						break;
-					}
-					else if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe)
-					{
-						#ifdef CONFIG_LONG_DELAY_ISSUE
+					} else if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe) {
+#ifdef CONFIG_LONG_DELAY_ISSUE
 						rtw_msleep_os(50);
-						#else
+#else
 						rtw_mdelay_os(50);
-						#endif
-					}
-					else if (u4bRegOffset == 0xfd)
-					{
+#endif
+					} else if (u4bRegOffset == 0xfd)
 						rtw_mdelay_os(5);
-					}
 					else if (u4bRegOffset == 0xfc)
-					{
 						rtw_mdelay_os(1);
-					}
 					else if (u4bRegOffset == 0xfb)
-					{
 						rtw_udelay_os(50);
-					}
 					else if (u4bRegOffset == 0xfa)
-					{
 						rtw_udelay_os(5);
-					}
 					else if (u4bRegOffset == 0xf9)
-					{
 						rtw_udelay_os(1);
-					}
 
-					// Get 2nd hex value as register value.
+					/* Get 2nd hex value as register value. */
 					szLine += u4bMove;
-					if(GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
-					{
-						//DBG_871X("[ADDR]%03lX=%08lX\n", u4bRegOffset, u4bRegValue);
-						PHY_SetBBReg(Adapter, u4bRegOffset, bMaskDWord, u4bRegValue);
+					if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
+						/* RTW_INFO("[ADDR]%03lX=%08lX\n", u4bRegOffset, u4bRegValue); */
+						phy_set_bb_reg(Adapter, u4bRegOffset, bMaskDWord, u4bRegValue);
 
-						// Add 1us delay between BB/RF register setting.
+						/* Add 1us delay between BB/RF register setting. */
 						rtw_udelay_os(1);
 					}
 				}
 			}
 		}
-	}
-	else
-	{
-		DBG_871X("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
-	}
+	} else
+		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 
 	return rtStatus;
 }
@@ -4647,8 +4613,8 @@ phy_ConfigBBWithMpParaFile(
 int
 PHY_ConfigRFWithParaFile(
 	IN	PADAPTER	Adapter,
-	IN	char* 		pFileName,
-	IN	u8			eRFPath
+	IN	char		*pFileName,
+	IN	enum rf_path		eRFPath
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
@@ -4659,298 +4625,220 @@ PHY_ConfigRFWithParaFile(
 	char	*pBuf = NULL;
 	u32	*pBufLen = NULL;
 
-	if(!(Adapter->registrypriv.load_phy_file & LOAD_RF_PARA_FILE))
+	if (!(Adapter->registrypriv.load_phy_file & LOAD_RF_PARA_FILE))
 		return rtStatus;
 
-	switch(eRFPath)
-	{
-		case ODM_RF_PATH_A:
-			pBuf = pHalData->rf_radio_a;
-			pBufLen = &pHalData->rf_radio_a_len;
-			break;
-		case ODM_RF_PATH_B:
-			pBuf = pHalData->rf_radio_b;
-			pBufLen = &pHalData->rf_radio_b_len;
-			break;
-		default:
-			DBG_871X("Unknown RF path!! %d\r\n", eRFPath);
-			break;			
+	switch (eRFPath) {
+	case RF_PATH_A:
+		pBuf = pHalData->rf_radio_a;
+		pBufLen = &pHalData->rf_radio_a_len;
+		break;
+	case RF_PATH_B:
+		pBuf = pHalData->rf_radio_b;
+		pBufLen = &pHalData->rf_radio_b_len;
+		break;
+	default:
+		RTW_INFO("Unknown RF path!! %d\r\n", eRFPath);
+		break;
 	}
 
 	_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
 
 	if ((pBufLen != NULL) && (*pBufLen == 0) && (pBuf == NULL)) {
 		rtw_get_phy_file_path(Adapter, pFileName);
-		if (rtw_is_file_readable(rtw_phy_para_file_path) == _TRUE)
-		{
+		if (rtw_is_file_readable(rtw_phy_para_file_path) == _TRUE) {
 			rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
-			if (rlen > 0)
-			{
+			if (rlen > 0) {
 				rtStatus = _SUCCESS;
 				pBuf = rtw_zvmalloc(rlen);
-				if(pBuf) {
+				if (pBuf) {
 					_rtw_memcpy(pBuf, pHalData->para_file_buf, rlen);
 					*pBufLen = rlen;
 
-					switch(eRFPath)
-					{
-						case ODM_RF_PATH_A:
-							pHalData->rf_radio_a = pBuf;
-							break;
-						case ODM_RF_PATH_B:
-							pHalData->rf_radio_b = pBuf;
-							break;
+					switch (eRFPath) {
+					case RF_PATH_A:
+						pHalData->rf_radio_a = pBuf;
+						break;
+					case RF_PATH_B:
+						pHalData->rf_radio_b = pBuf;
+						break;
+					default:
+						RTW_INFO("Unknown RF path!! %d\r\n", eRFPath);
+						break;
 					}
-				}
-				else {
-					DBG_871X("%s(): eRFPath=%d  alloc fail !\n",__FUNCTION__,eRFPath);
-				}
+				} else
+					RTW_INFO("%s(): eRFPath=%d  alloc fail !\n", __FUNCTION__, eRFPath);
 			}
 		}
-	}
-	else
-	{
-		if ((pBufLen != NULL) && (*pBufLen == 0) && (pBuf == NULL)) {
+	} else {
+		if ((pBufLen != NULL) && (*pBufLen != 0) && (pBuf != NULL)) {
 			_rtw_memcpy(pHalData->para_file_buf, pBuf, *pBufLen);
 			rtStatus = _SUCCESS;
-		}
-		else {
-			DBG_871X("%s(): Critical Error !!!\n",__FUNCTION__);
-		}
+		} else
+			RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
 	}
 
-	if(rtStatus == _SUCCESS)
-	{
-		//DBG_871X("%s(): read %s successfully\n", __FUNCTION__, pFileName);
-	
+	if (rtStatus == _SUCCESS) {
+		/* RTW_INFO("%s(): read %s successfully\n", __FUNCTION__, pFileName); */
+
 		ptmp = pHalData->para_file_buf;
-		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp))
-		{
-			if(!IsCommentString(szLine))
-			{
-				// Get 1st hex value as register offset.
-				if(GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
-				{
-			 		if(u4bRegOffset == 0xfe || u4bRegOffset == 0xffe)
-					{ // Deay specific ms. Only RF configuration require delay.												
-						#ifdef CONFIG_LONG_DELAY_ISSUE
+		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
+			if (!IsCommentString(szLine)) {
+				/* Get 1st hex value as register offset. */
+				if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
+					if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe) {
+						/* Deay specific ms. Only RF configuration require delay.												 */
+#ifdef CONFIG_LONG_DELAY_ISSUE
 						rtw_msleep_os(50);
-						#else
+#else
 						rtw_mdelay_os(50);
-						#endif
-					}
-					else if (u4bRegOffset == 0xfd)
-					{
-						//delay_ms(5);
-						for(i=0;i<100;i++)
+#endif
+					} else if (u4bRegOffset == 0xfd) {
+						/* delay_ms(5); */
+						for (i = 0; i < 100; i++)
 							rtw_udelay_os(MAX_STALL_TIME);
-					}
-					else if (u4bRegOffset == 0xfc)
-					{
-						//delay_ms(1);
-						for(i=0;i<20;i++)
+					} else if (u4bRegOffset == 0xfc) {
+						/* delay_ms(1); */
+						for (i = 0; i < 20; i++)
 							rtw_udelay_os(MAX_STALL_TIME);
-					}
-					else if (u4bRegOffset == 0xfb)
-					{
+					} else if (u4bRegOffset == 0xfb)
 						rtw_udelay_os(50);
-					}
 					else if (u4bRegOffset == 0xfa)
-					{
 						rtw_udelay_os(5);
-					}
 					else if (u4bRegOffset == 0xf9)
-					{
 						rtw_udelay_os(1);
-					}
-					else if(u4bRegOffset == 0xffff)
-					{
-						break;					
-					}
-					
-					// Get 2nd hex value as register value.
+					else if (u4bRegOffset == 0xffff)
+						break;
+
+					/* Get 2nd hex value as register value. */
 					szLine += u4bMove;
-					if(GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
-					{
-						PHY_SetRFReg(Adapter, eRFPath, u4bRegOffset, bRFRegOffsetMask, u4bRegValue);
-						
-						// Temp add, for frequency lock, if no delay, that may cause
-						// frequency shift, ex: 2412MHz => 2417MHz
-						// If frequency shift, the following action may works.
-						// Fractional-N table in radio_a.txt 
-						//0x2a 0x00001		// channel 1
-						//0x2b 0x00808		frequency divider.
-						//0x2b 0x53333
-						//0x2c 0x0000c
+					if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
+						phy_set_rf_reg(Adapter, eRFPath, u4bRegOffset, bRFRegOffsetMask, u4bRegValue);
+
+						/* Temp add, for frequency lock, if no delay, that may cause */
+						/* frequency shift, ex: 2412MHz => 2417MHz */
+						/* If frequency shift, the following action may works. */
+						/* Fractional-N table in radio_a.txt */
+						/* 0x2a 0x00001		 */ /* channel 1 */
+						/* 0x2b 0x00808		frequency divider. */
+						/* 0x2b 0x53333 */
+						/* 0x2c 0x0000c */
 						rtw_udelay_os(1);
 					}
 				}
 			}
 		}
-	}
-	else
-	{
-		DBG_871X("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
-	}
+	} else
+		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 
 	return rtStatus;
 }
 
 VOID
 initDeltaSwingIndexTables(
-	PADAPTER	Adapter, 
-	char*		Band, 
-	char*		Path,
-	char*		Sign,
-	char*		Channel, 
-	char*		Rate,
-	char*		Data
+	PADAPTER	Adapter,
+	char		*Band,
+	char		*Path,
+	char		*Sign,
+	char		*Channel,
+	char		*Rate,
+	char		*Data
 )
 {
-	#define STR_EQUAL_5G(_band, _path, _sign, _rate, _chnl) \
-		((strcmp(Band, _band) == 0) && (strcmp(Path, _path) == 0) && (strcmp(Sign, _sign) == 0) &&\
-		(strcmp(Rate, _rate) == 0) && (strcmp(Channel, _chnl) == 0)\
+#define STR_EQUAL_5G(_band, _path, _sign, _rate, _chnl) \
+	((strcmp(Band, _band) == 0) && (strcmp(Path, _path) == 0) && (strcmp(Sign, _sign) == 0) &&\
+	 (strcmp(Rate, _rate) == 0) && (strcmp(Channel, _chnl) == 0)\
 	)
-	#define STR_EQUAL_2G(_band, _path, _sign, _rate) \
-		((strcmp(Band, _band) == 0) && (strcmp(Path, _path) == 0) && (strcmp(Sign, _sign) == 0) &&\
-		(strcmp(Rate, _rate) == 0)\
+#define STR_EQUAL_2G(_band, _path, _sign, _rate) \
+	((strcmp(Band, _band) == 0) && (strcmp(Path, _path) == 0) && (strcmp(Sign, _sign) == 0) &&\
+	 (strcmp(Rate, _rate) == 0)\
 	)
-	
-	#define STORE_SWING_TABLE(_array, _iteratedIdx) \
-		for(token = strsep(&Data, delim); token != NULL; token = strsep(&Data, delim))\
-		{\
-			sscanf(token, "%d", &idx);\
-			_array[_iteratedIdx++] = (u8)idx;\
-		}\
+
+#define STORE_SWING_TABLE(_array, _iteratedIdx) \
+	do {	\
+	for (token = strsep(&Data, delim); token != NULL; token = strsep(&Data, delim)) {\
+		sscanf(token, "%d", &idx);\
+		_array[_iteratedIdx++] = (u8)idx;\
+	} } while (0)\
 
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	PODM_RF_CAL_T  	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
 	u32	j = 0;
 	char	*token;
 	char	delim[] = ",";
 	u32	idx = 0;
-	
-	//DBG_871X("===>initDeltaSwingIndexTables(): Band: %s;\nPath: %s;\nSign: %s;\nChannel: %s;\nRate: %s;\n, Data: %s;\n", 
-	//	Band, Path, Sign, Channel, Rate, Data);
-	
-	if ( STR_EQUAL_2G("2G", "A", "+", "CCK") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P, j);
-	}
-	else if ( STR_EQUAL_2G("2G", "A", "-", "CCK") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N, j);
-	}
-	else if ( STR_EQUAL_2G("2G", "B", "+", "CCK") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P, j);
-	}
-	else if ( STR_EQUAL_2G("2G", "B", "-", "CCK") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N, j);
-	}
-	else if ( STR_EQUAL_2G("2G", "A", "+", "ALL") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P, j);
-	}
-	else if ( STR_EQUAL_2G("2G", "A", "-", "ALL") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N, j);
-	}
-	else if ( STR_EQUAL_2G("2G", "B", "+", "ALL") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P, j);
-	}
-	else if ( STR_EQUAL_2G("2G", "B", "-", "ALL") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N, j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "+", "ALL", "0") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[0], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "-", "ALL", "0") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[0], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "+", "ALL", "0") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[0], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "-", "ALL", "0") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[0], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "+", "ALL", "1") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[1], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "-", "ALL", "1") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[1], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "+", "ALL", "1") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[1], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "-", "ALL", "1") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[1], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "+", "ALL", "2") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[2], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "-", "ALL", "2") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[2], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "+", "ALL", "2") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[2], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "-", "ALL", "2") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[2], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "+", "ALL", "3") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[3], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "A", "-", "ALL", "3") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[3], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "+", "ALL", "3") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[3], j);
-	}
-	else if ( STR_EQUAL_5G("5G", "B", "-", "ALL", "3") )
-	{
-		STORE_SWING_TABLE(pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[3], j);
-	}
+
+	/* RTW_INFO("===>initDeltaSwingIndexTables(): Band: %s;\nPath: %s;\nSign: %s;\nChannel: %s;\nRate: %s;\n, Data: %s;\n",  */
+	/*	Band, Path, Sign, Channel, Rate, Data); */
+
+	if (STR_EQUAL_2G("2G", "A", "+", "CCK"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_p, j);
+	else if (STR_EQUAL_2G("2G", "A", "-", "CCK"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_n, j);
+	else if (STR_EQUAL_2G("2G", "B", "+", "CCK"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_p, j);
+	else if (STR_EQUAL_2G("2G", "B", "-", "CCK"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_n, j);
+	else if (STR_EQUAL_2G("2G", "A", "+", "ALL"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2ga_p, j);
+	else if (STR_EQUAL_2G("2G", "A", "-", "ALL"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2ga_n, j);
+	else if (STR_EQUAL_2G("2G", "B", "+", "ALL"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2gb_p, j);
+	else if (STR_EQUAL_2G("2G", "B", "-", "ALL"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2gb_n, j);
+	else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "0"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[0], j);
+	else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "0"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[0], j);
+	else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "0"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[0], j);
+	else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "0"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[0], j);
+	else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "1"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[1], j);
+	else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "1"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[1], j);
+	else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "1"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[1], j);
+	else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "1"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[1], j);
+	else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "2"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[2], j);
+	else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "2"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[2], j);
+	else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "2"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[2], j);
+	else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "2"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[2], j);
+	else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "3"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[3], j);
+	else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "3"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[3], j);
+	else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "3"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[3], j);
+	else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "3"))
+		STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[3], j);
 	else
-	{
- 		DBG_871X("===>initDeltaSwingIndexTables(): The input is invalid!!\n");
-	}
+		RTW_INFO("===>initDeltaSwingIndexTables(): The input is invalid!!\n");
 }
 
 int
 PHY_ConfigRFWithTxPwrTrackParaFile(
 	IN	PADAPTER		Adapter,
-	IN	char*	 		pFileName
+	IN	char			*pFileName
 )
 {
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T			pDM_Odm = &pHalData->odmpriv;
-	PODM_RF_CAL_T  		pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
+	struct dm_struct			*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct		*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
 	int	rlen = 0, rtStatus = _FAIL;
 	char	*szLine, *ptmp;
 	u32	i = 0, j = 0;
 	char	c = 0;
 
-	if(!(Adapter->registrypriv.load_phy_file & LOAD_RF_TXPWR_TRACK_PARA_FILE))
+	if (!(Adapter->registrypriv.load_phy_file & LOAD_RF_TXPWR_TRACK_PARA_FILE))
 		return rtStatus;
 
 	_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
@@ -4962,282 +4850,434 @@ PHY_ConfigRFWithTxPwrTrackParaFile(
 			if (rlen > 0) {
 				rtStatus = _SUCCESS;
 				pHalData->rf_tx_pwr_track = rtw_zvmalloc(rlen);
-				if(pHalData->rf_tx_pwr_track) {
+				if (pHalData->rf_tx_pwr_track) {
 					_rtw_memcpy(pHalData->rf_tx_pwr_track, pHalData->para_file_buf, rlen);
 					pHalData->rf_tx_pwr_track_len = rlen;
-				}
-				else {
-					DBG_871X("%s rf_tx_pwr_track alloc fail !\n",__FUNCTION__);
-				}
+				} else
+					RTW_INFO("%s rf_tx_pwr_track alloc fail !\n", __FUNCTION__);
 			}
 		}
-	}
-	else
-	{
+	} else {
 		if ((pHalData->rf_tx_pwr_track_len != 0) && (pHalData->rf_tx_pwr_track != NULL)) {
 			_rtw_memcpy(pHalData->para_file_buf, pHalData->rf_tx_pwr_track, pHalData->rf_tx_pwr_track_len);
 			rtStatus = _SUCCESS;
-		}
-		else {
-			DBG_871X("%s(): Critical Error !!!\n",__FUNCTION__);
-		}
+		} else
+			RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
 	}
 
-	if(rtStatus == _SUCCESS)
-	{
-		//DBG_871X("%s(): read %s successfully\n", __FUNCTION__, pFileName);
+	if (rtStatus == _SUCCESS) {
+		/* RTW_INFO("%s(): read %s successfully\n", __FUNCTION__, pFileName); */
 
 		ptmp = pHalData->para_file_buf;
-		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp))
-		{
-			if ( ! IsCommentString(szLine) )
-			{
-				char	band[5]="", path[5]="", sign[5]  = "";
-				char	chnl[5]="", rate[10]="";
-				char	data[300]=""; // 100 is too small
+		for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
+			if (!IsCommentString(szLine)) {
+				char	band[5] = "", path[5] = "", sign[5]  = "";
+				char	chnl[5] = "", rate[10] = "";
+				char	data[300] = ""; /* 100 is too small */
 
 				if (strlen(szLine) < 10 || szLine[0] != '[')
 					continue;
 
-				strncpy(band, szLine+1, 2); 
-				strncpy(path, szLine+5, 1); 
-				strncpy(sign, szLine+8, 1);
+				strncpy(band, szLine + 1, 2);
+				strncpy(path, szLine + 5, 1);
+				strncpy(sign, szLine + 8, 1);
 
-				i = 10; // szLine+10
-				if ( ! ParseQualifiedString(szLine, &i, rate, '[', ']') ) {
-					//DBG_871X("Fail to parse rate!\n");
+				i = 10; /* szLine+10 */
+				if (!ParseQualifiedString(szLine, &i, rate, '[', ']')) {
+					/* RTW_INFO("Fail to parse rate!\n"); */
 				}
-				if ( ! ParseQualifiedString(szLine, &i, chnl, '[', ']') ) {
-					//DBG_871X("Fail to parse channel group!\n");
+				if (!ParseQualifiedString(szLine, &i, chnl, '[', ']')) {
+					/* RTW_INFO("Fail to parse channel group!\n"); */
 				}
-				while ( szLine[i] != '{' && i < strlen(szLine))
+				while (szLine[i] != '{' && i < strlen(szLine))
 					i++;
-				if ( ! ParseQualifiedString(szLine, &i, data, '{', '}') ) {
-					//DBG_871X("Fail to parse data!\n");
+				if (!ParseQualifiedString(szLine, &i, data, '{', '}')) {
+					/* RTW_INFO("Fail to parse data!\n"); */
 				}
 
 				initDeltaSwingIndexTables(Adapter, band, path, sign, chnl, rate, data);
 			}
 		}
-	}
-	else
-	{
-		DBG_871X("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
-	}
+	} else
+		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 #if 0
-	for (i = 0; i < DELTA_SWINGIDX_SIZE; ++i)
-	{
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P[i]);
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N[i]);
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P[i]);
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N[i]);
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P[i]);
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N[i]);
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P[i]);
-		DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N[%d] = %d\n", i, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N[i]);
-
-		for (j = 0; j < 3; ++j)
-		{
-		    DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[%d][%d] = %d\n", j, i, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P[j][i]);
-		    DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[%d][%d] = %d\n", j, i, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N[j][i]);
-		    DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[%d][%d] = %d\n", j, i, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P[j][i]);
-		    DBG_871X("pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[%d][%d] = %d\n", j, i, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N[j][i]);
+	for (i = 0; i < DELTA_SWINGIDX_SIZE; ++i) {
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2ga_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2ga_p[i]);
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2ga_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2ga_n[i]);
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2gb_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2gb_p[i]);
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2gb_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2gb_n[i]);
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_p[i]);
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_n[i]);
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_p[i]);
+		RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_n[i]);
+
+		for (j = 0; j < 3; ++j) {
+			RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5ga_p[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5ga_p[j][i]);
+			RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5ga_n[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5ga_n[j][i]);
+			RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5gb_p[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5gb_p[j][i]);
+			RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5gb_n[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5gb_n[j][i]);
 		}
 	}
 #endif
 	return rtStatus;
 }
 
-int
+#ifdef CONFIG_TXPWR_LIMIT
+
+#ifndef DBG_TXPWR_LMT_FILE_PARSE
+#define DBG_TXPWR_LMT_FILE_PARSE 0
+#endif
+
+#define PARSE_RET_NO_HDL	0
+#define PARSE_RET_SUCCESS	1
+#define PARSE_RET_FAIL		2
+
+/*
+* @@Ver=2.0
+* or
+* @@DomainCode=0x28, Regulation=C6
+* or
+* @@CountryCode=GB, Regulation=C7
+*/
+static u8 parse_reg_exc_config(_adapter *adapter, char *szLine)
+{
+#define VER_PREFIX "Ver="
+#define DOMAIN_PREFIX "DomainCode=0x"
+#define COUNTRY_PREFIX "CountryCode="
+#define REG_PREFIX "Regulation="
+
+	const u8 ver_prefix_len = strlen(VER_PREFIX);
+	const u8 domain_prefix_len = strlen(DOMAIN_PREFIX);
+	const u8 country_prefix_len = strlen(COUNTRY_PREFIX);
+	const u8 reg_prefix_len = strlen(REG_PREFIX);
+	u32 i, i_val_s, i_val_e;
+	u32 j;
+	u8 domain = 0xFF;
+	char *country = NULL;
+	u8 parse_reg = 0;
+
+	if (szLine[0] != '@' || szLine[1] != '@')
+		return PARSE_RET_NO_HDL;
+
+	i = 2;
+	if (strncmp(szLine + i, VER_PREFIX, ver_prefix_len) == 0)
+		; /* nothing to do */
+	else if (strncmp(szLine + i, DOMAIN_PREFIX, domain_prefix_len) == 0) {
+		/* get string after domain prefix to ',' */
+		i += domain_prefix_len;
+		i_val_s = i;
+		while (szLine[i] != ',') {
+			if (szLine[i] == '\0')
+				return PARSE_RET_FAIL;
+			i++;
+		}
+		i_val_e = i;
+
+		/* check if all hex */
+		for (j = i_val_s; j < i_val_e; j++)
+			if (IsHexDigit(szLine[j]) == _FALSE)
+				return PARSE_RET_FAIL;
+
+		/* get value from hex string */
+		if (sscanf(szLine + i_val_s, "%hhx", &domain) != 1)
+			return PARSE_RET_FAIL;
+
+		parse_reg = 1;
+	} else if (strncmp(szLine + i, COUNTRY_PREFIX, country_prefix_len) == 0) {
+		/* get string after country prefix to ',' */
+		i += country_prefix_len;
+		i_val_s = i;
+		while (szLine[i] != ',') {
+			if (szLine[i] == '\0')
+				return PARSE_RET_FAIL;
+			i++;
+		}
+		i_val_e = i;
+
+		if (i_val_e - i_val_s != 2)
+			return PARSE_RET_FAIL;
+
+		/* check if all alpha */
+		for (j = i_val_s; j < i_val_e; j++)
+			if (is_alpha(szLine[j]) == _FALSE)
+				return PARSE_RET_FAIL;
+
+		country = szLine + i_val_s;
+
+		parse_reg = 1;
+
+	} else
+		return PARSE_RET_FAIL;
+
+	if (parse_reg) {
+		/* move to 'R' */
+		while (szLine[i] != 'R') {
+			if (szLine[i] == '\0')
+				return PARSE_RET_FAIL;
+			i++;
+		}
+
+		/* check if matching regulation prefix */
+		if (strncmp(szLine + i, REG_PREFIX, reg_prefix_len) != 0)
+			return PARSE_RET_FAIL;
+
+		/* get string after regulation prefix ending with space */
+		i += reg_prefix_len;
+		i_val_s = i;
+		while (szLine[i] != ' ' && szLine[i] != '\t' && szLine[i] != '\0')
+			i++;
+
+		if (i == i_val_s)
+			return PARSE_RET_FAIL;
+
+		rtw_regd_exc_add_with_nlen(adapter_to_rfctl(adapter), country, domain, szLine + i_val_s, i - i_val_s);
+	}
+
+	return PARSE_RET_SUCCESS;
+}
+
+static int
 phy_ParsePowerLimitTableFile(
-  PADAPTER		Adapter,
-  char*			buffer
+	PADAPTER		Adapter,
+	char			*buffer
 )
 {
+#define LD_STAGE_EXC_MAPPING	0
+#define LD_STAGE_TAB_DEFINE		1
+#define LD_STAGE_TAB_START		2
+#define LD_STAGE_COLUMN_DEFINE	3
+#define LD_STAGE_CH_ROW			4
+
+	int	rtStatus = _FAIL;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T	pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct	*pDM_Odm = &(pHalData->odmpriv);
+	u8	loadingStage = LD_STAGE_EXC_MAPPING;
 	u32	i = 0, forCnt = 0;
-	u8	loadingStage = 0, limitValue = 0, fraction = 0;
+	u8 limitValue = 0, fraction = 0, negative = 0;
 	char	*szLine, *ptmp;
-	int	rtStatus = _SUCCESS;
-	char band[10], bandwidth[10], rateSection[10],
-		regulation[TXPWR_LMT_MAX_REGULATION_NUM][10], rfPath[10],colNumBuf[10];
-	u8 	colNum = 0;
+	char band[10], bandwidth[10], rateSection[10], ntx[10], colNumBuf[10];
+	char **regulation = NULL;
+	u8	colNum = 0;
 
-	DBG_871X("===>phy_ParsePowerLimitTableFile()\n" );
+	RTW_INFO("%s enter\n", __func__);
 
-	if ( Adapter->registrypriv.RegDecryptCustomFile == 1 )
-		phy_DecryptBBPgParaFile( Adapter, buffer);
+	if (Adapter->registrypriv.RegDecryptCustomFile == 1)
+		phy_DecryptBBPgParaFile(Adapter, buffer);
 
 	ptmp = buffer;
-	for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp))
-	{
+	for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
 		if (isAllSpaceOrTab(szLine, sizeof(*szLine)))
 			continue;
-
-		// skip comment 
-		if ( IsCommentString( szLine ) ) {
+		if (IsCommentString(szLine))
 			continue;
-		}
 
-		if( loadingStage == 0 ) {
-			for ( forCnt = 0; forCnt < TXPWR_LMT_MAX_REGULATION_NUM; ++forCnt )
-				_rtw_memset( ( PVOID ) regulation[forCnt], 0, 10 );
-			_rtw_memset( ( PVOID ) band, 0, 10 );
-			_rtw_memset( ( PVOID ) bandwidth, 0, 10 );
-			_rtw_memset( ( PVOID ) rateSection, 0, 10 );
-			_rtw_memset( ( PVOID ) rfPath, 0, 10 );
-			_rtw_memset( ( PVOID ) colNumBuf, 0, 10 );
+		if (loadingStage == LD_STAGE_EXC_MAPPING) {
+			if (szLine[0] == '#' || szLine[1] == '#') {
+				loadingStage = LD_STAGE_TAB_DEFINE;
+				if (DBG_TXPWR_LMT_FILE_PARSE)
+					dump_regd_exc_list(RTW_DBGDUMP, adapter_to_rfctl(Adapter));
+			} else {
+				if (parse_reg_exc_config(Adapter, szLine) == PARSE_RET_FAIL) {
+					RTW_ERR("Fail to parse regulation exception ruls!\n");
+					goto exit;
+				}
+				continue;
+			}
+		}
 
-			if ( szLine[0] != '#' || szLine[1] != '#' )
+		if (loadingStage == LD_STAGE_TAB_DEFINE) {
+			/* read "##	2.4G, 20M, 1T, CCK" */
+			if (szLine[0] != '#' || szLine[1] != '#')
 				continue;
 
-			// skip the space
+			/* skip the space */
 			i = 2;
-			while ( szLine[i] == ' ' || szLine[i] == '\t' )
+			while (szLine[i] == ' ' || szLine[i] == '\t')
 				++i;
 
-			szLine[--i] = ' '; // return the space in front of the regulation info
+			szLine[--i] = ' '; /* return the space in front of the regulation info */
 
-			// Parse the label of the table
-			if ( ! ParseQualifiedString( szLine, &i, band, ' ', ',' ) ) {
-				DBG_871X( "Fail to parse band!\n");
-				return _FAIL;
+			/* Parse the label of the table */
+			_rtw_memset((PVOID) band, 0, 10);
+			_rtw_memset((PVOID) bandwidth, 0, 10);
+			_rtw_memset((PVOID) ntx, 0, 10);
+			_rtw_memset((PVOID) rateSection, 0, 10);
+			if (!ParseQualifiedString(szLine, &i, band, ' ', ',')) {
+				RTW_ERR("Fail to parse band!\n");
+				goto exit;
 			}
-			if ( ! ParseQualifiedString( szLine, &i, bandwidth, ' ', ',' ) ) {
-				DBG_871X("Fail to parse bandwidth!\n");
-				return _FAIL;
+			if (!ParseQualifiedString(szLine, &i, bandwidth, ' ', ',')) {
+				RTW_ERR("Fail to parse bandwidth!\n");
+				goto exit;
 			}
-			if ( ! ParseQualifiedString( szLine, &i, rfPath, ' ', ',' ) ) {
-				DBG_871X("Fail to parse rf path!\n");
-				return _FAIL;
+			if (!ParseQualifiedString(szLine, &i, ntx, ' ', ',')) {
+				RTW_ERR("Fail to parse ntx!\n");
+				goto exit;
 			}
-			if ( ! ParseQualifiedString( szLine, &i, rateSection, ' ', ',' ) ) {
-				DBG_871X("Fail to parse rate!\n");
-				return _FAIL;
+			if (!ParseQualifiedString(szLine, &i, rateSection, ' ', ',')) {
+				RTW_ERR("Fail to parse rate!\n");
+				goto exit;
 			}
 
-			loadingStage = 1;
-		}
-		else if ( loadingStage == 1 )
-		{
-			if ( szLine[0] != '#' || szLine[1] != '#' )
+			loadingStage = LD_STAGE_TAB_START;
+		} else if (loadingStage == LD_STAGE_TAB_START) {
+			/* read "##	START" */
+			if (szLine[0] != '#' || szLine[1] != '#')
 				continue;
 
-			// skip the space
+			/* skip the space */
 			i = 2;
-			while ( szLine[i] == ' ' || szLine[i] == '\t' )
+			while (szLine[i] == ' ' || szLine[i] == '\t')
 				++i;
 
-			if ( !eqNByte( (u8 *)(szLine + i), (u8 *)("START"), 5 ) ) {
-				DBG_871X("Lost \"##   START\" label\n");
-				return _FAIL;
+			if (!eqNByte((u8 *)(szLine + i), (u8 *)("START"), 5)) {
+				RTW_ERR("Missing \"##   START\" label\n");
+				goto exit;
 			}
 
-			loadingStage = 2;
-		}
-		else if ( loadingStage == 2 )
-		{
-			if ( szLine[0] != '#' || szLine[1] != '#' )
+			loadingStage = LD_STAGE_COLUMN_DEFINE;
+		} else if (loadingStage == LD_STAGE_COLUMN_DEFINE) {
+			/* read "##	#5#	FCC	ETSI	MKK	IC	KCC" */
+			if (szLine[0] != '#' || szLine[1] != '#')
 				continue;
 
-			// skip the space
+			/* skip the space */
 			i = 2;
-			while ( szLine[i] == ' ' || szLine[i] == '\t' )
+			while (szLine[i] == ' ' || szLine[i] == '\t')
 				++i;
 
-			if ( ! ParseQualifiedString( szLine, &i, colNumBuf, '#', '#' ) ) {
-				DBG_871X("Fail to parse column number!\n");
-				return _FAIL;
+			_rtw_memset((PVOID) colNumBuf, 0, 10);
+			if (!ParseQualifiedString(szLine, &i, colNumBuf, '#', '#')) {
+				RTW_ERR("Fail to parse column number!\n");
+				goto exit;
+			}
+			if (!GetU1ByteIntegerFromStringInDecimal(colNumBuf, &colNum)) {
+				RTW_ERR("Column number \"%s\" is not unsigned decimal\n", colNumBuf);
+				goto exit;
+			}
+			if (colNum == 0) {
+				RTW_ERR("Column number is 0\n");
+				goto exit;
 			}
 
-			if ( !GetU1ByteIntegerFromStringInDecimal( colNumBuf, &colNum ) )
-				return _FAIL;
+			if (DBG_TXPWR_LMT_FILE_PARSE)
+				RTW_PRINT("[%s][%s][%s][%s] column num:%d\n", band, bandwidth, rateSection, ntx, colNum);
 
-			if ( colNum > TXPWR_LMT_MAX_REGULATION_NUM ) {
-				DBG_871X("unvalid col number %d (greater than max %d)\n", 
-				          colNum, TXPWR_LMT_MAX_REGULATION_NUM );
-				return _FAIL;
+			regulation = (char **)rtw_zmalloc(sizeof(char *) * colNum);
+			if (!regulation) {
+				RTW_ERR("Regulation alloc fail\n");
+				goto exit;
 			}
 
-			for ( forCnt = 0; forCnt < colNum; ++forCnt )
-			{
-				u8	regulation_name_cnt = 0;
+			for (forCnt = 0; forCnt < colNum; ++forCnt) {
+				u32 i_ns;
 
-				// skip the space
-				while ( szLine[i] == ' ' || szLine[i] == '\t' )
-					++i;
+				/* skip the space */
+				while (szLine[i] == ' ' || szLine[i] == '\t')
+					i++;
+				i_ns = i;
 
-				while ( szLine[i] != ' ' && szLine[i] != '\t' && szLine[i] != '\0' )
-					regulation[forCnt][regulation_name_cnt++] = szLine[i++];
-				//DBG_871X("regulation %s!\n", regulation[forCnt]);
+				while (szLine[i] != ' ' && szLine[i] != '\t' && szLine[i] != '\0')
+					i++;
 
-				if ( regulation_name_cnt == 0 ) {
-					DBG_871X("unvalid number of regulation!\n");
-					return _FAIL;
+				regulation[forCnt] = (char *)rtw_malloc(i - i_ns + 1);
+				if (!regulation[forCnt]) {
+					RTW_ERR("Regulation alloc fail\n");
+					goto exit;
 				}
+
+				_rtw_memcpy(regulation[forCnt], szLine + i_ns, i - i_ns);
+				regulation[forCnt][i - i_ns] = '\0';
 			}
 
-			loadingStage = 3;
-		}
-		else if ( loadingStage == 3 )
-		{
+			if (DBG_TXPWR_LMT_FILE_PARSE) {
+				RTW_PRINT("column name:");
+				for (forCnt = 0; forCnt < colNum; ++forCnt)
+					_RTW_PRINT(" %s", regulation[forCnt]);
+				_RTW_PRINT("\n");
+			}
+
+			loadingStage = LD_STAGE_CH_ROW;
+		} else if (loadingStage == LD_STAGE_CH_ROW) {
 			char	channel[10] = {0}, powerLimit[10] = {0};
 			u8	cnt = 0;
-			
-			// the table ends
-			if ( szLine[0] == '#' && szLine[1] == '#' ) {
+
+			/* the table ends */
+			if (szLine[0] == '#' && szLine[1] == '#') {
 				i = 2;
-				while ( szLine[i] == ' ' || szLine[i] == '\t' )
+				while (szLine[i] == ' ' || szLine[i] == '\t')
 					++i;
 
-				if ( eqNByte( (u8 *)(szLine + i), (u8 *)("END"), 3 ) ) {
-					loadingStage = 0;
+				if (eqNByte((u8 *)(szLine + i), (u8 *)("END"), 3)) {
+					loadingStage = LD_STAGE_TAB_DEFINE;
+					if (regulation) {
+						for (forCnt = 0; forCnt < colNum; ++forCnt) {
+							if (regulation[forCnt]) {
+								rtw_mfree(regulation[forCnt], strlen(regulation[forCnt]) + 1);
+								regulation[forCnt] = NULL;
+							}
+						}
+						rtw_mfree((u8 *)regulation, sizeof(char *) * colNum);
+						regulation = NULL;
+					}
+					colNum = 0;
 					continue;
-				}
-				else {
-					DBG_871X("Wrong format\n");
-					DBG_871X("<===== phy_ParsePowerLimitTableFile()\n");
-					return _FAIL;
+				} else {
+					RTW_ERR("Missing \"##   END\" label\n");
+					goto exit;
 				}
 			}
 
-			if ( ( szLine[0] != 'c' && szLine[0] != 'C' ) || 
-				 ( szLine[1] != 'h' && szLine[1] != 'H' ) ) {
-				DBG_871X("Meet wrong channel => power limt pair '%c','%c'(%d,%d)\n", szLine[0], szLine[1], szLine[0], szLine[1]);
+			if ((szLine[0] != 'c' && szLine[0] != 'C') ||
+				(szLine[1] != 'h' && szLine[1] != 'H')
+			) {
+				RTW_WARN("Wrong channel prefix: '%c','%c'(%d,%d)\n", szLine[0], szLine[1], szLine[0], szLine[1]);
 				continue;
 			}
-			i = 2;// move to the  location behind 'h'
+			i = 2;/* move to the  location behind 'h' */
 
-			// load the channel number
+			/* load the channel number */
 			cnt = 0;
-			while ( szLine[i] >= '0' && szLine[i] <= '9' ) {
+			while (szLine[i] >= '0' && szLine[i] <= '9') {
 				channel[cnt] = szLine[i];
 				++cnt;
 				++i;
 			}
-			//DBG_871X("chnl %s!\n", channel);
-			
-			for ( forCnt = 0; forCnt < colNum; ++forCnt )
-			{
-				// skip the space between channel number and the power limit value
-				while ( szLine[i] == ' ' || szLine[i] == '\t' )
+			/* RTW_INFO("chnl %s!\n", channel); */
+
+			for (forCnt = 0; forCnt < colNum; ++forCnt) {
+				/* skip the space between channel number and the power limit value */
+				while (szLine[i] == ' ' || szLine[i] == '\t')
 					++i;
 
-				// load the power limit value
+				/* load the power limit value */
 				cnt = 0;
 				fraction = 0;
-				_rtw_memset( ( PVOID ) powerLimit, 0, 10 );
-				while ( ( szLine[i] >= '0' && szLine[i] <= '9' ) || szLine[i] == '.' )
-				{
-					if ( szLine[i] == '.' ){
-						if ( ( szLine[i+1] >= '0' && szLine[i+1] <= '9' ) ) {
-							fraction = szLine[i+1];
-							i += 2;
+				negative = 0;
+				_rtw_memset((PVOID) powerLimit, 0, 10);
+
+				while ((szLine[i] >= '0' && szLine[i] <= '9') || szLine[i] == '.'
+					|| szLine[i] == '+' || szLine[i] == '-'
+				) {
+					/* try to get valid decimal number */
+					if (szLine[i] == '+' || szLine[i] == '-') {
+						if (cnt != 0) {
+							RTW_ERR("Wrong position for sign '%c'\n", szLine[i]);
+							goto exit;
 						}
-						else {
-							DBG_871X("Wrong fraction in TXPWR_LMT.txt\n");
-							return _FAIL;
+						if (szLine[i] == '-') {
+							negative = 1;
+							++i;
+							continue;
+						}
+
+					} else if (szLine[i] == '.') {
+						if ((szLine[i + 1] >= '0' && szLine[i + 1] <= '9')) {
+							fraction = szLine[i + 1];
+							i += 2;
+						} else {
+							RTW_ERR("Wrong fraction '%c'(%d)\n", szLine[i + 1], szLine[i + 1]);
+							goto exit;
 						}
 
 						break;
@@ -5248,65 +5288,96 @@ phy_ParsePowerLimitTableFile(
 					++i;
 				}
 
-				if ( powerLimit[0] == '\0' ) {
-					powerLimit[0] = '6';
-					powerLimit[1] = '3';
-					i += 2;
-				}
-				else {
-					if ( !GetU1ByteIntegerFromStringInDecimal( powerLimit, &limitValue ) )
-						return _FAIL;
+				if (powerLimit[0] == '\0') {
+					if (szLine[i] == 'W' && szLine[i + 1] == 'W') {
+						/*
+						* case "WW" assign special value -63
+						* means to get minimal limit in other regulations at same channel
+						*/
+						powerLimit[0] = '-';
+						powerLimit[1] = '6';
+						powerLimit[2] = '3';
+						i += 2;
+					} else if (szLine[i] == 'N' && szLine[i + 1] == 'A') {
+						/*
+						* case "NA" assign special value 63
+						* means no limitation
+						*/
+						powerLimit[0] = '6';
+						powerLimit[1] = '3';
+						i += 2;
+					} else {
+						RTW_ERR("Wrong limit expression \"%c%c\"(%d, %d)\n"
+							, szLine[i], szLine[i + 1], szLine[i], szLine[i + 1]);
+						goto exit;
+					}
+				} else {
+					/* transform dicimal value to power index */
+					if (!GetU1ByteIntegerFromStringInDecimal(powerLimit, &limitValue)) {
+						RTW_ERR("Limit \"%s\" is not valid decimal\n", powerLimit);
+						goto exit;
+					}
 
 					limitValue *= 2;
 					cnt = 0;
-					if ( fraction == '5' )
+
+					if (negative)
+						powerLimit[cnt++] = '-';
+
+					if (fraction == '5')
 						++limitValue;
 
-					// the value is greater or equal to 100
-					if ( limitValue >= 100 ) {
-						powerLimit[cnt++] = limitValue/100 + '0';
+					/* the value is greater or equal to 100 */
+					if (limitValue >= 100) {
+						powerLimit[cnt++] = limitValue / 100 + '0';
 						limitValue %= 100;
 
-						if ( limitValue >= 10 ) {
-							powerLimit[cnt++] = limitValue/10 + '0';
+						if (limitValue >= 10) {
+							powerLimit[cnt++] = limitValue / 10 + '0';
 							limitValue %= 10;
-						}
-						else {
+						} else
 							powerLimit[cnt++] = '0';
-						}
 
 						powerLimit[cnt++] = limitValue + '0';
 					}
-					// the value is greater or equal to 10
-					else if ( limitValue >= 10 ) {
-						powerLimit[cnt++] = limitValue/10 + '0';
+					/* the value is greater or equal to 10 */
+					else if (limitValue >= 10) {
+						powerLimit[cnt++] = limitValue / 10 + '0';
 						limitValue %= 10;
 						powerLimit[cnt++] = limitValue + '0';
 					}
-					// the value is less than 10 
+					/* the value is less than 10 */
 					else
 						powerLimit[cnt++] = limitValue + '0';
 
 					powerLimit[cnt] = '\0';
 				}
 
-				//DBG_871X("ch%s => %s\n", channel, powerLimit);
+				/* RTW_INFO("ch%s => %s\n", channel, powerLimit); */
 
-				// store the power limit value
-				PHY_SetTxPowerLimit(pDM_Odm, (u8 *)regulation[forCnt], (u8 *)band,
-					(u8 *)bandwidth, (u8 *)rateSection, (u8 *)rfPath, (u8 *)channel, (u8 *)powerLimit );
+				/* store the power limit value */
+				phy_set_tx_power_limit(pDM_Odm, (u8 *)regulation[forCnt], (u8 *)band,
+					(u8 *)bandwidth, (u8 *)rateSection, (u8 *)ntx, (u8 *)channel, (u8 *)powerLimit);
 
 			}
 		}
-		else 
-		{
-			DBG_871X("Abnormal loading stage in phy_ParsePowerLimitTableFile()!\n");
-			rtStatus = _FAIL;
-			break;
+	}
+
+	rtStatus = _SUCCESS;
+
+exit:
+	if (regulation) {
+		for (forCnt = 0; forCnt < colNum; ++forCnt) {
+			if (regulation[forCnt]) {
+				rtw_mfree(regulation[forCnt], strlen(regulation[forCnt]) + 1);
+				regulation[forCnt] = NULL;
+			}
 		}
+		rtw_mfree((u8 *)regulation, sizeof(char *) * colNum);
+		regulation = NULL;
 	}
 
-	DBG_871X("<===phy_ParsePowerLimitTableFile()\n");
+	RTW_INFO("%s return %d\n", __func__, rtStatus);
 	return rtStatus;
 }
 
@@ -5319,7 +5390,7 @@ PHY_ConfigRFWithPowerLimitTableParaFile(
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
 	int	rlen = 0, rtStatus = _FAIL;
 
-	if(!(Adapter->registrypriv.load_phy_file & LOAD_RF_TXPWR_LMT_PARA_FILE))
+	if (!(Adapter->registrypriv.load_phy_file & LOAD_RF_TXPWR_LMT_PARA_FILE))
 		return rtStatus;
 
 	_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
@@ -5331,37 +5402,30 @@ PHY_ConfigRFWithPowerLimitTableParaFile(
 			if (rlen > 0) {
 				rtStatus = _SUCCESS;
 				pHalData->rf_tx_pwr_lmt = rtw_zvmalloc(rlen);
-				if(pHalData->rf_tx_pwr_lmt) {
+				if (pHalData->rf_tx_pwr_lmt) {
 					_rtw_memcpy(pHalData->rf_tx_pwr_lmt, pHalData->para_file_buf, rlen);
 					pHalData->rf_tx_pwr_lmt_len = rlen;
-				}
-				else {
-					DBG_871X("%s rf_tx_pwr_lmt alloc fail !\n",__FUNCTION__);
-				}
+				} else
+					RTW_INFO("%s rf_tx_pwr_lmt alloc fail !\n", __FUNCTION__);
 			}
 		}
 	} else {
 		if ((pHalData->rf_tx_pwr_lmt_len != 0) && (pHalData->rf_tx_pwr_lmt != NULL)) {
 			_rtw_memcpy(pHalData->para_file_buf, pHalData->rf_tx_pwr_lmt, pHalData->rf_tx_pwr_lmt_len);
 			rtStatus = _SUCCESS;
-		}
-		else {
-			DBG_871X("%s(): Critical Error !!!\n",__FUNCTION__);
-		}
+		} else
+			RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
 	}
 
-	if(rtStatus == _SUCCESS)
-	{
-		//DBG_871X("%s(): read %s ok\n", __FUNCTION__, pFileName);
-		rtStatus = phy_ParsePowerLimitTableFile( Adapter, pHalData->para_file_buf );
-	}
-	else
-	{
-		DBG_871X("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
-	}
+	if (rtStatus == _SUCCESS) {
+		/* RTW_INFO("%s(): read %s ok\n", __FUNCTION__, pFileName); */
+		rtStatus = phy_ParsePowerLimitTableFile(Adapter, pHalData->para_file_buf);
+	} else
+		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 
 	return rtStatus;
 }
+#endif /* CONFIG_TXPWR_LIMIT */
 
 void phy_free_filebuf_mask(_adapter *padapter, u8 mask)
 {
@@ -5415,4 +5479,3 @@ inline void phy_free_filebuf(_adapter *padapter)
 }
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.c
index 5135692e9fe5..759644c8d014 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.c
@@ -1,195 +1,1266 @@
-/******************************************************************************
- *
- * Copyright(c) 2014 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#include <drv_types.h>
-#include <hal_data.h>
-
-// A mapping from HalData to ODM.
-ODM_BOARD_TYPE_E boardType(u8 InterfaceSel)
-{
-    ODM_BOARD_TYPE_E        board	= ODM_BOARD_DEFAULT;
-
-#ifdef CONFIG_PCI_HCI
-	INTERFACE_SELECT_PCIE   pcie 	= (INTERFACE_SELECT_PCIE)InterfaceSel;
-	switch (pcie) 
-	{
-        case INTF_SEL0_SOLO_MINICARD:       
-            board |= ODM_BOARD_MINICARD;
-            break;
-        case INTF_SEL1_BT_COMBO_MINICARD:   
-            board |= ODM_BOARD_BT;
-			board |= ODM_BOARD_MINICARD;
-            break;
-        default:
-            board = ODM_BOARD_DEFAULT;
-            break;
-	}                                
-
-#elif defined(CONFIG_USB_HCI)
-	INTERFACE_SELECT_USB    usb 	= (INTERFACE_SELECT_USB)InterfaceSel;
-	switch (usb) 
-	{
-	    case INTF_SEL1_USB_High_Power:      
-	        board |= ODM_BOARD_EXT_LNA;
-	        board |= ODM_BOARD_EXT_PA;			
-	        break;
-	    case INTF_SEL2_MINICARD:            
-	        board |= ODM_BOARD_MINICARD;
-	        break;
-	    case INTF_SEL4_USB_Combo:           
-	        board |= ODM_BOARD_BT;
-	        break;
-	    case INTF_SEL5_USB_Combo_MF:        
-	        board |= ODM_BOARD_BT;
-	        break;
-	    case INTF_SEL0_USB: 			
-	    case INTF_SEL3_USB_Solo:            			
-	    default:
-	        board = ODM_BOARD_DEFAULT;
-	        break;
-	}
-	
-#endif	
-	//DBG_871X("===> boardType(): (pHalData->InterfaceSel, pDM_Odm->BoardType) = (%d, %d)\n", InterfaceSel, board);
-
-	return board;
-}
-
-void Init_ODM_ComInfo(_adapter *adapter)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
-	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
-	int i;
-
-	_rtw_memset(pDM_Odm,0,sizeof(*pDM_Odm));
-
-	pDM_Odm->Adapter = adapter;
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_PLATFORM, ODM_CE);
-
-	rtw_odm_init_ic_type(adapter);
-
-	if (rtw_get_intf_type(adapter) == RTW_GSPI)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_INTERFACE, ODM_ITRF_SDIO);
-	else
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_INTERFACE, rtw_get_intf_type(adapter));
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_MP_TEST_CHIP, IS_NORMAL_CHIP(pHalData->VersionID));
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_PATCH_ID, pHalData->CustomerID);
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_BWIFI_TEST, adapter->registrypriv.wifi_spec);
-
-
-	if (pHalData->rf_type == RF_1T1R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_1T1R);
-	else if (pHalData->rf_type == RF_1T2R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_1T2R);
-	else if (pHalData->rf_type == RF_2T2R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T2R);
-	else if (pHalData->rf_type == RF_2T2R_GREEN)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T2R_GREEN);
-	else if (pHalData->rf_type == RF_2T3R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T3R);
-	else if (pHalData->rf_type == RF_2T4R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T4R);
-	else if (pHalData->rf_type == RF_3T3R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_3T3R);
-	else if (pHalData->rf_type == RF_3T4R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_3T4R);
-	else if (pHalData->rf_type == RF_4T4R)
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_4T4R);
-	else
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_XTXR);
-	
-
-{
-	//1 ======= BoardType: ODM_CMNINFO_BOARD_TYPE =======
-	u8 odm_board_type = ODM_BOARD_DEFAULT;
-
-	if (pHalData->ExternalLNA_2G != 0) {
-		odm_board_type |= ODM_BOARD_EXT_LNA;
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_EXT_LNA, 1);
-	}
-	if (pHalData->ExternalLNA_5G != 0) {
-		odm_board_type |= ODM_BOARD_EXT_LNA_5G;
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_5G_EXT_LNA, 1);
-	}
-	if (pHalData->ExternalPA_2G != 0) {
-		odm_board_type |= ODM_BOARD_EXT_PA;
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_EXT_PA, 1);
-	}
-	if (pHalData->ExternalPA_5G != 0) {
-		odm_board_type |= ODM_BOARD_EXT_PA_5G;
-		ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_5G_EXT_PA, 1);
-	}
-	if (pHalData->EEPROMBluetoothCoexist)
-		odm_board_type |= ODM_BOARD_BT;	
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_BOARD_TYPE, odm_board_type);
-	//1 ============== End of BoardType ==============
-}
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_DOMAIN_CODE_2G, pHalData->Regulation2_4G);
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_DOMAIN_CODE_5G, pHalData->Regulation5G);
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_GPA, pHalData->TypeGPA);
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_APA, pHalData->TypeAPA);
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_GLNA, pHalData->TypeGLNA);
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_ALNA, pHalData->TypeALNA);
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_RFE_TYPE, pHalData->RFEType);
-
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_EXT_TRSW, 0);
-
-	/* Pointer reference */
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_TX_UNI, &(dvobj->traffic_stat.tx_bytes));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_RX_UNI, &(dvobj->traffic_stat.rx_bytes));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_WM_MODE, &(pmlmeext->cur_wireless_mode));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_BAND, &(pHalData->CurrentBandType));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_FORCED_RATE, &(pHalData->ForcedDataRate));
-
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_SEC_CHNL_OFFSET, &(pHalData->nCur40MhzPrimeSC));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_SEC_MODE, &(adapter->securitypriv.dot11PrivacyAlgrthm));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_BW, &(pHalData->CurrentChannelBW));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_CHNL, &( pHalData->CurrentChannel));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_NET_CLOSED, &(adapter->net_closed));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_FORCED_IGI_LB, &(pHalData->u1ForcedIgiLb));
-
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_SCAN, &(pmlmepriv->bScanInProcess));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_POWER_SAVING, &(pwrctl->bpower_saving));
-	/*Add by Yuchen for phydm beamforming*/
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_TX_TP, &(dvobj->traffic_stat.cur_tx_tp));
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_RX_TP, &(dvobj->traffic_stat.cur_rx_tp));
-#ifdef CONFIG_USB_HCI
-	ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_HUBUSBMODE, &(dvobj->usb_speed));
-#endif
-	for(i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-		ODM_CmnInfoPtrArrayHook(pDM_Odm, ODM_CMNINFO_STA_STATUS, i, NULL);
-
-	/* TODO */
-	//ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_BT_OPERATION, _FALSE);
-	//ODM_CmnInfoHook(pDM_Odm, ODM_CMNINFO_BT_DISABLE_EDCA, _FALSE);
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2014 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+
+/* A mapping from HalData to ODM. */
+enum odm_board_type boardType(u8 InterfaceSel)
+{
+	enum odm_board_type        board	= ODM_BOARD_DEFAULT;
+
+#ifdef CONFIG_PCI_HCI
+	INTERFACE_SELECT_PCIE   pcie	= (INTERFACE_SELECT_PCIE)InterfaceSel;
+	switch (pcie) {
+	case INTF_SEL0_SOLO_MINICARD:
+		board |= ODM_BOARD_MINICARD;
+		break;
+	case INTF_SEL1_BT_COMBO_MINICARD:
+		board |= ODM_BOARD_BT;
+		board |= ODM_BOARD_MINICARD;
+		break;
+	default:
+		board = ODM_BOARD_DEFAULT;
+		break;
+	}
+
+#elif defined(CONFIG_USB_HCI)
+	INTERFACE_SELECT_USB    usb	= (INTERFACE_SELECT_USB)InterfaceSel;
+	switch (usb) {
+	case INTF_SEL1_USB_High_Power:
+		board |= ODM_BOARD_EXT_LNA;
+		board |= ODM_BOARD_EXT_PA;
+		break;
+	case INTF_SEL2_MINICARD:
+		board |= ODM_BOARD_MINICARD;
+		break;
+	case INTF_SEL4_USB_Combo:
+		board |= ODM_BOARD_BT;
+		break;
+	case INTF_SEL5_USB_Combo_MF:
+		board |= ODM_BOARD_BT;
+		break;
+	case INTF_SEL0_USB:
+	case INTF_SEL3_USB_Solo:
+	default:
+		board = ODM_BOARD_DEFAULT;
+		break;
+	}
+
+#endif
+	/* RTW_INFO("===> boardType(): (pHalData->InterfaceSel, pDM_Odm->BoardType) = (%d, %d)\n", InterfaceSel, board); */
+
+	return board;
+}
+
+void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+
+	if (hal->RegIQKFWOffload) {
+		rtw_sctx_init(&hal->iqk_sctx, 0);
+		phydm_fwoffload_ability_init(p_dm_odm, PHYDM_RF_IQK_OFFLOAD);
+	} else
+		phydm_fwoffload_ability_clear(p_dm_odm, PHYDM_RF_IQK_OFFLOAD);
+
+	RTW_INFO("IQK FW offload:%s\n", hal->RegIQKFWOffload ? "enable" : "disable");
+}
+
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+void rtw_phydm_iqk_trigger(_adapter *adapter)
+{
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+	u8 clear = _TRUE;
+	u8 segment = _FALSE;
+	u8 rfk_forbidden = _FALSE;
+
+	/*segment = _rtw_phydm_iqk_segment_chk(adapter);*/
+	halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
+	halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_IQK_SEGMENT, segment);
+	halrf_segment_iqk_trigger(p_dm_odm, clear, segment);
+}
+#endif
+
+void rtw_phydm_iqk_trigger_dbg(_adapter *adapter, bool recovery, bool clear, bool segment)
+{
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+		halrf_segment_iqk_trigger(p_dm_odm, clear, segment);
+#else
+		halrf_iqk_trigger(p_dm_odm, recovery);
+#endif
+}
+void rtw_phydm_lck_trigger(_adapter *adapter)
+{
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+
+	halrf_lck_trigger(p_dm_odm);
+}
+#ifdef CONFIG_DBG_RF_CAL
+void rtw_hal_iqk_test(_adapter *adapter, bool recovery, bool clear, bool segment)
+{
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+
+	rtw_ps_deny(adapter, PS_DENY_IOCTL);
+	LeaveAllPowerSaveModeDirect(adapter);
+
+	rtw_phydm_ability_backup(adapter);
+	rtw_phydm_func_disable_all(adapter);
+
+	halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_ABILITY, HAL_RF_IQK);
+
+	rtw_phydm_iqk_trigger_dbg(adapter, recovery, clear, segment);
+	rtw_phydm_ability_restore(adapter);
+
+	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+}
+
+void rtw_hal_lck_test(_adapter *adapter)
+{
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+
+	rtw_ps_deny(adapter, PS_DENY_IOCTL);
+	LeaveAllPowerSaveModeDirect(adapter);
+
+	rtw_phydm_ability_backup(adapter);
+	rtw_phydm_func_disable_all(adapter);
+
+	halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_ABILITY, HAL_RF_LCK);
+
+	rtw_phydm_lck_trigger(adapter);
+
+	rtw_phydm_ability_restore(adapter);
+	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+}
+#endif
+
+#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+void rtw_hal_update_param_init_fw_offload_cap(_adapter *adapter)
+{
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+
+	if (adapter->registrypriv.fw_param_init)
+		phydm_fwoffload_ability_init(p_dm_odm, PHYDM_PHY_PARAM_OFFLOAD);
+	else
+		phydm_fwoffload_ability_clear(p_dm_odm, PHYDM_PHY_PARAM_OFFLOAD);
+
+	RTW_INFO("Init-Parameter FW offload:%s\n", adapter->registrypriv.fw_param_init ? "enable" : "disable");
+}
+#endif
+
+void record_ra_info(void *p_dm_void, u8 macid, struct cmn_sta_info *p_sta, u64 ra_mask)
+{
+	struct dm_struct *p_dm = (struct dm_struct *)p_dm_void;
+	_adapter *adapter = p_dm->adapter;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+
+	if (p_sta) {
+		rtw_macid_ctl_set_bw(macid_ctl, macid, p_sta->ra_info.ra_bw_mode);
+		rtw_macid_ctl_set_vht_en(macid_ctl, macid, p_sta->ra_info.is_vht_enable);
+		rtw_macid_ctl_set_rate_bmp0(macid_ctl, macid, ra_mask);
+		rtw_macid_ctl_set_rate_bmp1(macid_ctl, macid, ra_mask >> 32);
+
+		rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
+	}
+}
+
+void rtw_phydm_ops_func_init(struct dm_struct *p_phydm)
+{
+	struct ra_table *p_ra_t = &p_phydm->dm_ra_table;
+
+	p_ra_t->record_ra_info = record_ra_info;
+}
+
+void Init_ODM_ComInfo(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+	int i;
+
+	_rtw_memset(pDM_Odm, 0, sizeof(*pDM_Odm));
+
+	pDM_Odm->adapter = adapter;
+
+	/*phydm_op_mode could be change for different scenarios: ex: SoftAP - PHYDM_BALANCE_MODE*/
+	pHalData->phydm_op_mode = PHYDM_PERFORMANCE_MODE;/*Service one device*/
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_PLATFORM, ODM_CE);
+
+	rtw_odm_init_ic_type(adapter);
+
+	if (rtw_get_intf_type(adapter) == RTW_GSPI)
+		odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_INTERFACE, ODM_ITRF_SDIO);
+	else
+		odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_INTERFACE, rtw_get_intf_type(adapter));
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_MP_TEST_CHIP, IS_NORMAL_CHIP(pHalData->version_id));
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_PATCH_ID, pHalData->CustomerID);
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BWIFI_TEST, adapter->registrypriv.wifi_spec);
+
+#ifdef CONFIG_ADVANCE_OTA
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_ADVANCE_OTA, adapter->registrypriv.adv_ota);
+#endif
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, pHalData->rf_type);
+
+	{
+		/* 1 ======= BoardType: ODM_CMNINFO_BOARD_TYPE ======= */
+		u8 odm_board_type = ODM_BOARD_DEFAULT;
+
+		if (pHalData->ExternalLNA_2G != 0) {
+			odm_board_type |= ODM_BOARD_EXT_LNA;
+			odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_LNA, 1);
+		}
+		if (pHalData->external_lna_5g != 0) {
+			odm_board_type |= ODM_BOARD_EXT_LNA_5G;
+			odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_5G_EXT_LNA, 1);
+		}
+		if (pHalData->ExternalPA_2G != 0) {
+			odm_board_type |= ODM_BOARD_EXT_PA;
+			odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_PA, 1);
+		}
+		if (pHalData->external_pa_5g != 0) {
+			odm_board_type |= ODM_BOARD_EXT_PA_5G;
+			odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_5G_EXT_PA, 1);
+		}
+		if (pHalData->EEPROMBluetoothCoexist)
+			odm_board_type |= ODM_BOARD_BT;
+
+		odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BOARD_TYPE, odm_board_type);
+		/* 1 ============== End of BoardType ============== */
+	}
+
+	rtw_hal_set_odm_var(adapter, HAL_ODM_REGULATION, NULL, _TRUE);
+
+#ifdef CONFIG_DFS_MASTER
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_DFS_REGION_DOMAIN, adapter->registrypriv.dfs_region_domain);
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_DFS_MASTER_ENABLE, &(adapter_to_rfctl(adapter)->dfs_master_enabled));
+#endif
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_GPA, pHalData->TypeGPA);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_APA, pHalData->TypeAPA);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_GLNA, pHalData->TypeGLNA);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_ALNA, pHalData->TypeALNA);
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RFE_TYPE, pHalData->rfe_type);
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_TRSW, 0);
+
+	/*Add by YuChen for kfree init*/
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_REGRFKFREEENABLE, adapter->registrypriv.RegPwrTrimEnable);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RFKFREEENABLE, pHalData->RfKFreeEnable);
+
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_ANTENNA_TYPE, pHalData->TRxAntDivType);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BE_FIX_TX_ANT, pHalData->b_fix_tx_ant);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH, pHalData->with_extenal_ant_switch);
+
+	/* (8822B) efuse 0x3D7 & 0x3D8 for TX PA bias */
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EFUSE0X3D7, pHalData->efuse0x3d7);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EFUSE0X3D8, pHalData->efuse0x3d8);
+
+	/*Add by YuChen for adaptivity init*/
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ADAPTIVITY, &(adapter->registrypriv.adaptivity_en));
+	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE, (adapter->registrypriv.adaptivity_mode != 0) ? TRUE : FALSE);
+	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_DCBACKOFF, adapter->registrypriv.adaptivity_dc_backoff);
+	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY, (adapter->registrypriv.adaptivity_dml != 0) ? TRUE : FALSE);
+	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_L2H_INI, adapter->registrypriv.adaptivity_th_l2h_ini);
+	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF, adapter->registrypriv.adaptivity_th_edcca_hl_diff);
+
+	/*halrf info init*/
+	halrf_cmn_info_init(pDM_Odm, HALRF_CMNINFO_EEPROM_THERMAL_VALUE, pHalData->eeprom_thermal_meter);
+
+	if (rtw_odm_adaptivity_needed(adapter) == _TRUE)
+		rtw_odm_adaptivity_config_msg(RTW_DBGDUMP, adapter);
+
+#ifdef CONFIG_IQK_PA_OFF
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_IQKPAOFF, 1);
+#endif
+	rtw_hal_update_iqk_fw_offload_cap(adapter);
+	#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+	rtw_hal_update_param_init_fw_offload_cap(adapter);
+	#endif
+
+	/* Pointer reference */
+	/*Antenna diversity relative parameters*/
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ANT_DIV, &(pHalData->AntDivCfg));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_MP_MODE, &(adapter->registrypriv.mp_mode));
+
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BB_OPERATION_MODE, &(pHalData->phydm_op_mode));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_TX_UNI, &(dvobj->traffic_stat.tx_bytes));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RX_UNI, &(dvobj->traffic_stat.rx_bytes));
+
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BAND, &(pHalData->current_band_type));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_FORCED_RATE, &(pHalData->ForcedDataRate));
+
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SEC_CHNL_OFFSET, &(pHalData->nCur40MhzPrimeSC));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SEC_MODE, &(adapter->securitypriv.dot11PrivacyAlgrthm));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BW, &(pHalData->current_channel_bw));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_CHNL, &(pHalData->current_channel));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_NET_CLOSED, &(adapter->net_closed));
+
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SCAN, &(pHalData->bScanInProcess));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_POWER_SAVING, &(pwrctl->bpower_saving));
+	/*Add by Yuchen for phydm beamforming*/
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_TX_TP, &(dvobj->traffic_stat.cur_tx_tp));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RX_TP, &(dvobj->traffic_stat.cur_rx_tp));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ANT_TEST, &(pHalData->antenna_test));
+#ifdef CONFIG_RTL8723B
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_IS1ANTENNA, &pHalData->EEPROMBluetoothAntNum);
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RFDEFAULTPATH, &pHalData->ant_path);
+#endif /*CONFIG_RTL8723B*/
+#ifdef CONFIG_USB_HCI
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_HUBUSBMODE, &(dvobj->usb_speed));
+#endif
+
+#ifdef CONFIG_DYNAMIC_SOML
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ADAPTIVE_SOML, &(adapter->registrypriv.dyn_soml_en));
+#endif
+
+	/*halrf info hook*/
+#ifdef CONFIG_MP_INCLUDED
+	halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_CON_TX, &(adapter->mppriv.mpt_ctx.is_start_cont_tx));
+	halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_SINGLE_TONE, &(adapter->mppriv.mpt_ctx.is_single_tone));
+	halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_CARRIER_SUPPRESSION, &(adapter->mppriv.mpt_ctx.is_carrier_suppression));
+	halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_MP_RATE_INDEX, &(adapter->mppriv.mpt_ctx.mpt_rate_index));
+#endif/*CONFIG_MP_INCLUDED*/
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
+		odm_cmn_info_ptr_array_hook(pDM_Odm, ODM_CMNINFO_STA_STATUS, i, NULL);
+
+	phydm_init_debug_setting(pDM_Odm);
+	rtw_phydm_ops_func_init(pDM_Odm);
+	/* TODO */
+	/* odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BT_OPERATION, _FALSE); */
+	/* odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BT_DISABLE_EDCA, _FALSE); */
+}
+
+
+static u32 edca_setting_UL[HT_IOT_PEER_MAX] =
+/*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM,*/
+/*RALINK, ATHEROS, CISCO, MERU, MARVELL, 92U_AP, SELF_AP(DownLink/Tx) */
+{ 0x5e4322, 0xa44f, 0x5e4322, 0x5ea32b, 0x5ea422, 0x5ea322, 0x3ea430, 0x5ea42b, 0x5ea44f, 0x5e4322, 0x5e4322};
+
+static u32 edca_setting_DL[HT_IOT_PEER_MAX] =
+/*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM,*/
+/*RALINK, ATHEROS, CISCO, MERU, MARVELL, 92U_AP, SELF_AP(UpLink/Rx)*/
+{ 0xa44f, 0x5ea44f,	 0x5e4322, 0x5ea42b, 0xa44f, 0xa630, 0x5ea630, 0x5ea42b, 0xa44f, 0xa42b, 0xa42b};
+
+static u32 edca_setting_dl_g_mode[HT_IOT_PEER_MAX] =
+/*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM,*/
+/*RALINK, ATHEROS, CISCO, MERU, MARVELL, 92U_AP, SELF_AP */
+{ 0x4322, 0xa44f, 0x5e4322, 0xa42b, 0x5e4322, 0x4322,	 0xa42b, 0x5ea42b, 0xa44f, 0x5e4322, 0x5ea42b};
+
+void rtw_hal_turbo_edca(_adapter *adapter)
+{
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA(adapter);
+	struct dvobj_priv		*dvobj = adapter_to_dvobj(adapter);
+	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);
+
+	/* Parameter suggested by Scott  */
+#if 0
+	u32	EDCA_BE_UL = edca_setting_UL[p_mgnt_info->iot_peer];
+	u32	EDCA_BE_DL = edca_setting_DL[p_mgnt_info->iot_peer];
+#endif
+	u32	EDCA_BE_UL = 0x5ea42b;
+	u32	EDCA_BE_DL = 0x00a42b;
+	u8	ic_type = rtw_get_chip_type(adapter);
+
+	u8	iot_peer = 0;
+	u8	wireless_mode = 0xFF;                 /* invalid value */
+	u8	traffic_index;
+	u32	edca_param;
+	u64	cur_tx_bytes = 0;
+	u64	cur_rx_bytes = 0;
+	u8	bbtchange = _TRUE;
+	u8	is_bias_on_rx = _FALSE;
+	u8	is_linked = _FALSE;
+	u8	interface_type;
+
+	if (hal_data->dis_turboedca)
+		return;
+
+	if (rtw_mi_check_status(adapter, MI_ASSOC))
+		is_linked = _TRUE;
+
+	if (is_linked != _TRUE) {
+		precvpriv->is_any_non_be_pkts = _FALSE;
+		return;
+	}
+
+	if ((pregpriv->wifi_spec == 1)) { /* || (pmlmeinfo->HT_enable == 0)) */
+		precvpriv->is_any_non_be_pkts = _FALSE;
+		return;
+	}
+
+	interface_type = rtw_get_intf_type(adapter);
+	wireless_mode = pmlmeext->cur_wireless_mode;
+
+	iot_peer = pmlmeinfo->assoc_AP_vendor;
+
+	if (iot_peer >=  HT_IOT_PEER_MAX) {
+		precvpriv->is_any_non_be_pkts = _FALSE;
+		return;
+	}
+
+	if (ic_type == RTL8188E) {
+		if ((iot_peer == HT_IOT_PEER_RALINK) || (iot_peer == HT_IOT_PEER_ATHEROS))
+			is_bias_on_rx = _TRUE;
+	}
+
+	/* Check if the status needs to be changed. */
+	if ((bbtchange) || (!precvpriv->is_any_non_be_pkts)) {
+		cur_tx_bytes = dvobj->traffic_stat.cur_tx_bytes;
+		cur_rx_bytes = dvobj->traffic_stat.cur_rx_bytes;
+
+		/* traffic, TX or RX */
+		if (is_bias_on_rx) {
+			if (cur_tx_bytes > (cur_rx_bytes << 2)) {
+				/* Uplink TP is present. */
+				traffic_index = UP_LINK;
+			} else {
+				/* Balance TP is present. */
+				traffic_index = DOWN_LINK;
+			}
+		} else {
+			if (cur_rx_bytes > (cur_tx_bytes << 2)) {
+				/* Downlink TP is present. */
+				traffic_index = DOWN_LINK;
+			} else {
+				/* Balance TP is present. */
+				traffic_index = UP_LINK;
+			}
+		}
+#if 0
+		if ((p_dm_odm->dm_edca_table.prv_traffic_idx != traffic_index)
+			|| (!p_dm_odm->dm_edca_table.is_current_turbo_edca))
+#endif
+		{
+			if (interface_type == RTW_PCIE) {
+				EDCA_BE_UL = 0x6ea42b;
+				EDCA_BE_DL = 0x6ea42b;
+			}
+
+			/* 92D txop can't be set to 0x3e for cisco1250 */
+			if ((iot_peer == HT_IOT_PEER_CISCO) && (wireless_mode == ODM_WM_N24G)) {
+				EDCA_BE_DL = edca_setting_DL[iot_peer];
+				EDCA_BE_UL = edca_setting_UL[iot_peer];
+			}
+			/* merge from 92s_92c_merge temp*/
+			else if ((iot_peer == HT_IOT_PEER_CISCO) && ((wireless_mode == ODM_WM_G) || (wireless_mode == (ODM_WM_B | ODM_WM_G)) || (wireless_mode == ODM_WM_A) || (wireless_mode == ODM_WM_B)))
+				EDCA_BE_DL = edca_setting_dl_g_mode[iot_peer];
+			else if ((iot_peer == HT_IOT_PEER_AIRGO) && ((wireless_mode == ODM_WM_G) || (wireless_mode == ODM_WM_A)))
+				EDCA_BE_DL = 0xa630;
+			else if (iot_peer == HT_IOT_PEER_MARVELL) {
+				EDCA_BE_DL = edca_setting_DL[iot_peer];
+				EDCA_BE_UL = edca_setting_UL[iot_peer];
+			} else if (iot_peer == HT_IOT_PEER_ATHEROS) {
+				/* Set DL EDCA for Atheros peer to 0x3ea42b.*/
+				/* Suggested by SD3 Wilson for ASUS TP issue.*/
+				EDCA_BE_DL = edca_setting_DL[iot_peer];
+			}
+
+			if ((ic_type == RTL8812) || (ic_type == RTL8821) || (ic_type == RTL8192E)) { /* add 8812AU/8812AE */
+				EDCA_BE_UL = 0x5ea42b;
+				EDCA_BE_DL = 0x5ea42b;
+
+				RTW_DBG("8812A: EDCA_BE_UL=0x%x EDCA_BE_DL =0x%x\n", EDCA_BE_UL, EDCA_BE_DL);
+			}
+
+			if (interface_type == RTW_PCIE &&
+				((ic_type == RTL8822B)
+				|| (ic_type == RTL8814A))) {
+				EDCA_BE_UL = 0x6ea42b;
+				EDCA_BE_DL = 0x6ea42b;
+			}
+
+			if (traffic_index == DOWN_LINK)
+				edca_param = EDCA_BE_DL;
+			else
+				edca_param = EDCA_BE_UL;
+#ifdef 	CONFIG_RTW_CUSTOMIZE_BEEDCA
+			edca_param = CONFIG_RTW_CUSTOMIZE_BEEDCA;
+#endif
+			rtw_hal_set_hwreg(adapter, HW_VAR_AC_PARAM_BE, (u8 *)(&edca_param));
+
+			RTW_DBG("Turbo EDCA =0x%x\n", edca_param);
+
+			hal_data->prv_traffic_idx = traffic_index;
+		}
+
+		hal_data->is_turbo_edca = _TRUE;
+	} else {
+		/*  */
+		/* Turn Off EDCA turbo here. */
+		/* Restore original EDCA according to the declaration of AP. */
+		/*  */
+		if (hal_data->is_turbo_edca) {
+			edca_param = hal_data->ac_param_be;
+			rtw_hal_set_hwreg(adapter, HW_VAR_AC_PARAM_BE, (u8 *)(&edca_param));
+			hal_data->is_turbo_edca = _FALSE;
+		}
+	}
+
+}
+
+s8 rtw_phydm_get_min_rssi(_adapter *adapter)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	s8 rssi_min = 0;
+
+	rssi_min = phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_RSSI_MIN);
+	return rssi_min;
+}
+
+u8 rtw_phydm_get_cur_igi(_adapter *adapter)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	u8 cur_igi = 0;
+
+	cur_igi = phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CURR_IGI);
+	return cur_igi;
+}
+
+u32 rtw_phydm_get_phy_cnt(_adapter *adapter, enum phy_cnt cnt)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+
+	if (cnt == FA_OFDM)
+		return  phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_OFDM);
+	else if (cnt == FA_CCK)
+		return  phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_CCK);
+	else if (cnt == FA_TOTAL)
+		return  phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_TOTAL);
+	else if (cnt == CCA_OFDM)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_OFDM);
+	else if (cnt == CCA_CCK)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_CCK);
+	else if (cnt == CCA_ALL)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_ALL);
+	else if (cnt == CRC32_OK_VHT)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_VHT);
+	else if (cnt == CRC32_OK_HT)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_HT);
+	else if (cnt == CRC32_OK_LEGACY)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_LEGACY);
+	else if (cnt == CRC32_OK_CCK)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_CCK);
+	else if (cnt == CRC32_ERROR_VHT)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_VHT);
+	else if (cnt == CRC32_ERROR_HT)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_HT);
+	else if (cnt == CRC32_ERROR_LEGACY)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_LEGACY);
+	else if (cnt == CRC32_ERROR_CCK)
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_CCK);
+	else
+		return 0;
+}
+
+u8 rtw_phydm_is_iqk_in_progress(_adapter *adapter)
+{
+	u8 rts = _FALSE;
+	struct dm_struct *podmpriv = adapter_to_phydm(adapter);
+
+	odm_acquire_spin_lock(podmpriv, RT_IQK_SPINLOCK);
+	if (podmpriv->rf_calibrate_info.is_iqk_in_progress == _TRUE) {
+		RTW_ERR("IQK InProgress\n");
+		rts = _TRUE;
+	}
+	odm_release_spin_lock(podmpriv, RT_IQK_SPINLOCK);
+
+	return rts;
+}
+
+void SetHalODMVar(
+	PADAPTER				Adapter,
+	HAL_ODM_VARIABLE		eVariable,
+	PVOID					pValue1,
+	BOOLEAN					bSet)
+{
+	struct dm_struct *podmpriv = adapter_to_phydm(Adapter);
+	/* _irqL irqL; */
+	switch (eVariable) {
+	case HAL_ODM_STA_INFO: {
+		struct sta_info *psta = (struct sta_info *)pValue1;
+
+		if (bSet) {
+			RTW_INFO("### Set STA_(%d) info ###\n", psta->cmn.mac_id);
+			odm_cmn_info_ptr_array_hook(podmpriv, ODM_CMNINFO_STA_STATUS, psta->cmn.mac_id, psta);
+			psta->cmn.dm_ctrl = STA_DM_CTRL_ACTIVE;
+			phydm_cmn_sta_info_hook(podmpriv, psta->cmn.mac_id, &(psta->cmn));
+		} else {
+			RTW_INFO("### Clean STA_(%d) info ###\n", psta->cmn.mac_id);
+			/* _enter_critical_bh(&pHalData->odm_stainfo_lock, &irqL); */
+			psta->cmn.dm_ctrl = 0;
+			odm_cmn_info_ptr_array_hook(podmpriv, ODM_CMNINFO_STA_STATUS, psta->cmn.mac_id, NULL);
+			phydm_cmn_sta_info_hook(podmpriv, psta->cmn.mac_id, NULL);
+
+			/* _exit_critical_bh(&pHalData->odm_stainfo_lock, &irqL); */
+		}
+	}
+		break;
+	case HAL_ODM_P2P_STATE:
+		odm_cmn_info_update(podmpriv, ODM_CMNINFO_WIFI_DIRECT, bSet);
+		break;
+	case HAL_ODM_WIFI_DISPLAY_STATE:
+		odm_cmn_info_update(podmpriv, ODM_CMNINFO_WIFI_DISPLAY, bSet);
+		break;
+	case HAL_ODM_REGULATION:
+		/* used to auto enable/disable adaptivity by SD7 */
+		odm_cmn_info_init(podmpriv, ODM_CMNINFO_DOMAIN_CODE_2G, 0);
+		odm_cmn_info_init(podmpriv, ODM_CMNINFO_DOMAIN_CODE_5G, 0);
+		break;
+	case HAL_ODM_INITIAL_GAIN: {
+		u8 rx_gain = *((u8 *)(pValue1));
+		/*printk("rx_gain:%x\n",rx_gain);*/
+		if (rx_gain == 0xff) {/*restore rx gain*/
+			/*odm_write_dig(podmpriv,pDigTable->backup_ig_value);*/
+			odm_pause_dig(podmpriv, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_0, rx_gain);
+		} else {
+			/*pDigTable->backup_ig_value = pDigTable->cur_ig_value;*/
+			/*odm_write_dig(podmpriv,rx_gain);*/
+			odm_pause_dig(podmpriv, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_0, rx_gain);
+		}
+	}
+	break;
+	case HAL_ODM_RX_INFO_DUMP: {
+		u8 cur_igi = 0;
+		s8 rssi_min;
+		void *sel;
+
+		sel = pValue1;
+		cur_igi = rtw_phydm_get_cur_igi(Adapter);
+		rssi_min = rtw_phydm_get_min_rssi(Adapter);
+
+		_RTW_PRINT_SEL(sel, "============ Rx Info dump ===================\n");
+		_RTW_PRINT_SEL(sel, "is_linked = %d, rssi_min = %d(%%), current_igi = 0x%x\n", podmpriv->is_linked, rssi_min, cur_igi);
+		_RTW_PRINT_SEL(sel, "cnt_cck_fail = %d, cnt_ofdm_fail = %d, Total False Alarm = %d\n",
+			rtw_phydm_get_phy_cnt(Adapter, FA_CCK),
+			rtw_phydm_get_phy_cnt(Adapter, FA_OFDM),
+			rtw_phydm_get_phy_cnt(Adapter, FA_TOTAL));
+
+		if (podmpriv->is_linked) {
+			_RTW_PRINT_SEL(sel, "rx_rate = %s", HDATA_RATE(podmpriv->rx_rate));
+			if (IS_HARDWARE_TYPE_8814A(Adapter))
+				_RTW_PRINT_SEL(sel, " rssi_a = %d(%%), rssi_b = %d(%%), rssi_c = %d(%%), rssi_d = %d(%%)\n",
+					podmpriv->rssi_a, podmpriv->rssi_b, podmpriv->rssi_c, podmpriv->rssi_d);
+			else
+				_RTW_PRINT_SEL(sel, " rssi_a = %d(%%), rssi_b = %d(%%)\n", podmpriv->rssi_a, podmpriv->rssi_b);
+#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
+			rtw_dump_raw_rssi_info(Adapter, sel);
+#endif
+		}
+	}
+		break;
+	case HAL_ODM_RX_Dframe_INFO: {
+		void *sel;
+
+		sel = pValue1;
+
+		/*_RTW_PRINT_SEL(sel , "HAL_ODM_RX_Dframe_INFO\n");*/
+#ifdef DBG_RX_DFRAME_RAW_DATA
+		rtw_dump_rx_dframe_info(Adapter, sel);
+#endif
+	}
+		break;
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	case HAL_ODM_ANTDIV_SELECT: {
+		u8	antenna = (*(u8 *)pValue1);
+		HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
+		/*switch antenna*/
+		odm_update_rx_idle_ant(&pHalData->odmpriv, antenna);
+		/*RTW_INFO("==> HAL_ODM_ANTDIV_SELECT, Ant_(%s)\n", (antenna == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");*/
+
+	}
+		break;
+#endif
+
+	default:
+		break;
+	}
+}
+
+void GetHalODMVar(
+	PADAPTER				Adapter,
+	HAL_ODM_VARIABLE		eVariable,
+	PVOID					pValue1,
+	PVOID					pValue2)
+{
+	struct dm_struct *podmpriv = adapter_to_phydm(Adapter);
+
+	switch (eVariable) {
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	case HAL_ODM_ANTDIV_SELECT: {
+		struct phydm_fat_struct	*pDM_FatTable = &podmpriv->dm_fat_table;
+		*((u8 *)pValue1) = pDM_FatTable->rx_idle_ant;
+	}
+		break;
+#endif
+	case HAL_ODM_INITIAL_GAIN:
+		*((u8 *)pValue1) = rtw_phydm_get_cur_igi(Adapter);
+		break;
+	default:
+		break;
+	}
+}
+
+#ifdef RTW_HALMAC
+#include "../hal_halmac.h"
+#endif
+
+enum hal_status
+rtw_phydm_fw_iqk(
+	struct dm_struct	*p_dm_odm,
+	u8 clear,
+	u8 segment
+)
+{
+	#ifdef RTW_HALMAC
+	struct _ADAPTER *adapter = p_dm_odm->adapter;
+
+	if (rtw_halmac_iqk(adapter_to_dvobj(adapter), clear, segment) == 0)
+		return HAL_STATUS_SUCCESS;
+	#endif
+	return HAL_STATUS_FAILURE;
+}
+
+enum hal_status
+rtw_phydm_cfg_phy_para(
+	struct dm_struct	*p_dm_odm,
+	enum phydm_halmac_param config_type,
+	u32 offset,
+	u32 data,
+	u32 mask,
+	enum rf_path e_rf_path,
+	u32 delay_time)
+{
+	#ifdef RTW_HALMAC
+	struct _ADAPTER *adapter = p_dm_odm->adapter;
+	struct rtw_phy_parameter para;
+
+	switch (config_type) {
+	case PHYDM_HALMAC_CMD_MAC_W8:
+		para.cmd = 0; /* MAC register */
+		para.data.mac.offset = offset;
+		para.data.mac.value = data;
+		para.data.mac.msk = mask;
+		para.data.mac.msk_en = (mask) ? 1 : 0;
+		para.data.mac.size = 1;
+	break;
+	case PHYDM_HALMAC_CMD_MAC_W16:
+		para.cmd = 0; /* MAC register */
+		para.data.mac.offset = offset;
+		para.data.mac.value = data;
+		para.data.mac.msk = mask;
+		para.data.mac.msk_en = (mask) ? 1 : 0;
+		para.data.mac.size = 2;
+	break;
+	case PHYDM_HALMAC_CMD_MAC_W32:
+		para.cmd = 0; /* MAC register */
+		para.data.mac.offset = offset;
+		para.data.mac.value = data;
+		para.data.mac.msk = mask;
+		para.data.mac.msk_en = (mask) ? 1 : 0;
+		para.data.mac.size = 4;
+	break;
+	case PHYDM_HALMAC_CMD_BB_W8:
+		para.cmd = 1; /* BB register */
+		para.data.bb.offset = offset;
+		para.data.bb.value = data;
+		para.data.bb.msk = mask;
+		para.data.bb.msk_en = (mask) ? 1 : 0;
+		para.data.bb.size = 1;
+	break;
+	case PHYDM_HALMAC_CMD_BB_W16:
+		para.cmd = 1; /* BB register */
+		para.data.bb.offset = offset;
+		para.data.bb.value = data;
+		para.data.bb.msk = mask;
+		para.data.bb.msk_en = (mask) ? 1 : 0;
+		para.data.bb.size = 2;
+	break;
+	case PHYDM_HALMAC_CMD_BB_W32:
+		para.cmd = 1; /* BB register */
+		para.data.bb.offset = offset;
+		para.data.bb.value = data;
+		para.data.bb.msk = mask;
+		para.data.bb.msk_en = (mask) ? 1 : 0;
+		para.data.bb.size = 4;
+	break;
+	case PHYDM_HALMAC_CMD_RF_W:
+		para.cmd = 2; /* RF register */
+		para.data.rf.offset = offset;
+		para.data.rf.value = data;
+		para.data.rf.msk = mask;
+		para.data.rf.msk_en = (mask) ? 1 : 0;
+		if (e_rf_path == RF_PATH_A)
+			para.data.rf.path = 0;
+		else if (e_rf_path == RF_PATH_B)
+			para.data.rf.path = 1;
+		else if (e_rf_path == RF_PATH_C)
+			para.data.rf.path = 2;
+		else if (e_rf_path == RF_PATH_D)
+			para.data.rf.path = 3;
+		else
+			para.data.rf.path = 0;
+	break;
+	case PHYDM_HALMAC_CMD_DELAY_US:
+		para.cmd = 3; /* Delay */
+		para.data.delay.unit = 0; /* microsecond */
+		para.data.delay.value = delay_time;
+	break;
+	case PHYDM_HALMAC_CMD_DELAY_MS:
+		para.cmd = 3; /* Delay */
+		para.data.delay.unit = 1; /* millisecond */
+		para.data.delay.value = delay_time;
+	break;
+	case PHYDM_HALMAC_CMD_END:
+		para.cmd = 0xFF; /* End command */
+	break;
+	default:
+		return HAL_STATUS_FAILURE;
+	}
+
+	if (rtw_halmac_cfg_phy_para(adapter_to_dvobj(adapter), &para))
+		return HAL_STATUS_FAILURE;
+	#endif /*RTW_HALMAC*/
+	return HAL_STATUS_SUCCESS;
+}
+
+
+#ifdef CONFIG_LPS_LCLK_WD_TIMER
+void rtw_phydm_wd_lps_lclk_hdl(_adapter *adapter)
+{
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
+	struct dm_struct	*podmpriv = &(pHalData->odmpriv);
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *psta = NULL;
+	u8 rssi_min = 0;
+	u32	rssi_rpt = 0;
+	bool is_linked = _FALSE;
+
+	if (!rtw_is_hw_init_completed(adapter))
+		return;
+
+	if (rtw_mi_check_status(adapter, MI_ASSOC))
+		is_linked = _TRUE;
+
+	if (is_linked == _FALSE)
+		return;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL)
+		return;
+
+	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_LINK, is_linked);
+
+	phydm_watchdog_lps_32k(&pHalData->odmpriv);
+}
+
+void rtw_phydm_watchdog_in_lps_lclk(_adapter *adapter)
+{
+	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *psta = NULL;
+	u8 cur_igi = 0;
+	s8 min_rssi = 0;
+
+	if (!rtw_is_hw_init_completed(adapter))
+		return;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL)
+		return;
+
+	cur_igi = rtw_phydm_get_cur_igi(adapter);
+	min_rssi = rtw_phydm_get_min_rssi(adapter);
+	if (min_rssi <= 0)
+		min_rssi = psta->cmn.rssi_stat.rssi;
+	/*RTW_INFO("%s "ADPT_FMT" cur_ig_value=%d, min_rssi = %d\n", __func__,  ADPT_ARG(adapter), cur_igi, min_rssi);*/
+
+	if (min_rssi <= 0)
+		return;
+
+	if ((cur_igi > min_rssi + 5) ||
+		(cur_igi < min_rssi - 5)) {
+#ifdef CONFIG_LPS
+		rtw_dm_in_lps_wk_cmd(adapter);
+#endif
+	}
+}
+#endif /*CONFIG_LPS_LCLK_WD_TIMER*/
+
+void dump_sta_traffic(void *sel, _adapter *adapter, struct sta_info *psta)
+{
+	struct ra_sta_info *ra_info;
+	u8 curr_sgi = _FALSE;
+
+	if (!psta)
+		return;
+	RTW_PRINT_SEL(sel, "====== mac_id : %d ======\n", psta->cmn.mac_id);
+
+	ra_info = &psta->cmn.ra_info;
+	curr_sgi = (ra_info->curr_tx_rate & 0x80) ? _TRUE : _FALSE;
+	RTW_PRINT_SEL(sel, "tx_rate : %s(%s)  rx_rate : %s, rx_rate_bmc : %s, rssi : %d %%\n"
+		, HDATA_RATE((ra_info->curr_tx_rate & 0x7F)), (curr_sgi) ? "S" : "L"
+		, HDATA_RATE((psta->curr_rx_rate & 0x7F)), HDATA_RATE((psta->curr_rx_rate_bmc & 0x7F)), psta->cmn.rssi_stat.rssi
+	);
+
+	if (0) {
+		RTW_PRINT_SEL(sel, "tx_bytes:%llu(%llu - %llu)\n"
+			, psta->sta_stats.tx_bytes - psta->sta_stats.last_tx_bytes
+			, psta->sta_stats.tx_bytes, psta->sta_stats.last_tx_bytes
+		);
+		RTW_PRINT_SEL(sel, "rx_uc_bytes:%llu(%llu - %llu)\n"
+			, sta_rx_uc_bytes(psta) - sta_last_rx_uc_bytes(psta)
+			, sta_rx_uc_bytes(psta), sta_last_rx_uc_bytes(psta)
+		);
+		RTW_PRINT_SEL(sel, "rx_mc_bytes:%llu(%llu - %llu)\n"
+			, psta->sta_stats.rx_mc_bytes - psta->sta_stats.last_rx_mc_bytes
+			, psta->sta_stats.rx_mc_bytes, psta->sta_stats.last_rx_mc_bytes
+		);
+		RTW_PRINT_SEL(sel, "rx_bc_bytes:%llu(%llu - %llu)\n"
+			, psta->sta_stats.rx_bc_bytes - psta->sta_stats.last_rx_bc_bytes
+			, psta->sta_stats.rx_bc_bytes, psta->sta_stats.last_rx_bc_bytes
+		);
+	}
+
+	RTW_PRINT_SEL(sel, "TP {Tx,Rx,Total} = { %d , %d , %d } Mbps\n",
+		(psta->sta_stats.tx_tp_mbytes << 3), (psta->sta_stats.rx_tp_mbytes << 3),
+		(psta->sta_stats.tx_tp_mbytes + psta->sta_stats.rx_tp_mbytes) << 3);
+
+	RTW_PRINT_SEL(sel, "Moving-AVG TP {Tx,Rx,Total} = { %d , %d , %d } Mbps\n\n",
+		(psta->cmn.tx_moving_average_tp << 3), (psta->cmn.rx_moving_average_tp << 3),
+		(psta->cmn.tx_moving_average_tp + psta->cmn.rx_moving_average_tp) << 3);
+
+}
+
+void dump_sta_info(void *sel, struct sta_info *psta)
+{
+	struct ra_sta_info *ra_info;
+	u8 curr_tx_sgi = _FALSE;
+	u8 curr_tx_rate = 0;
+
+	if (!psta)
+		return;
+
+	ra_info = &psta->cmn.ra_info;
+
+	RTW_PRINT_SEL(sel, "============ STA [" MAC_FMT "]  ===================\n",
+		MAC_ARG(psta->cmn.mac_addr));
+	RTW_PRINT_SEL(sel, "mac_id : %d\n", psta->cmn.mac_id);
+	RTW_PRINT_SEL(sel, "wireless_mode : 0x%02x\n", psta->wireless_mode);
+	RTW_PRINT_SEL(sel, "mimo_type : %d\n", psta->cmn.mimo_type);
+	RTW_PRINT_SEL(sel, "bw_mode : %s, ra_bw_mode : %s\n",
+			ch_width_str(psta->cmn.bw_mode), ch_width_str(ra_info->ra_bw_mode));
+	RTW_PRINT_SEL(sel, "rate_id : %d\n", ra_info->rate_id);
+	RTW_PRINT_SEL(sel, "rssi : %d (%%), rssi_level : %d\n", psta->cmn.rssi_stat.rssi, ra_info->rssi_level);
+	RTW_PRINT_SEL(sel, "is_support_sgi : %s, is_vht_enable : %s\n",
+			(ra_info->is_support_sgi) ? "Y" : "N", (ra_info->is_vht_enable) ? "Y" : "N");
+	RTW_PRINT_SEL(sel, "disable_ra : %s, disable_pt : %s\n",
+				(ra_info->disable_ra) ? "Y" : "N", (ra_info->disable_pt) ? "Y" : "N");
+	RTW_PRINT_SEL(sel, "is_noisy : %s\n", (ra_info->is_noisy) ? "Y" : "N");
+	RTW_PRINT_SEL(sel, "txrx_state : %d\n", ra_info->txrx_state);/*0: uplink, 1:downlink, 2:bi-direction*/
+
+	curr_tx_sgi = (ra_info->curr_tx_rate & 0x80) ? _TRUE : _FALSE;
+	curr_tx_rate = ra_info->curr_tx_rate & 0x7F;
+	RTW_PRINT_SEL(sel, "curr_tx_rate : %s (%s)\n",
+			HDATA_RATE(curr_tx_rate), (curr_tx_sgi) ? "S" : "L");
+	RTW_PRINT_SEL(sel, "curr_tx_bw : %s\n", ch_width_str(ra_info->curr_tx_bw));
+	RTW_PRINT_SEL(sel, "curr_retry_ratio : %d\n", ra_info->curr_retry_ratio);
+	RTW_PRINT_SEL(sel, "ra_mask : 0x%016llx\n\n", ra_info->ramask);
+}
+
+void rtw_phydm_ra_registed(_adapter *adapter, struct sta_info *psta)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+
+	if (psta == NULL) {
+		RTW_ERR(FUNC_ADPT_FMT" sta is NULL\n", FUNC_ADPT_ARG(adapter));
+		rtw_warn_on(1);
+		return;
+	}
+
+	phydm_ra_registed(&hal_data->odmpriv, psta->cmn.mac_id, psta->cmn.rssi_stat.rssi);
+	dump_sta_info(RTW_DBGDUMP, psta);
+}
+
+static void init_phydm_info(_adapter *adapter)
+{
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm = &(hal_data->odmpriv);
+
+	halrf_cmn_info_init(phydm, HALRF_CMNINFO_FW_VER,
+		((hal_data->firmware_version << 16) | hal_data->firmware_sub_version));
+
+	#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+	/*PHYDM API - thermal trim*/
+	phydm_get_thermal_trim_offset(phydm);
+	/*PHYDM API - power trim*/
+	phydm_get_power_trim_offset(phydm);
+	#endif
+}
+void rtw_phydm_init(_adapter *adapter)
+{
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct	*phydm = &(hal_data->odmpriv);
+
+	init_phydm_info(adapter);
+	odm_dm_init(phydm);
+}
+
+#ifdef CONFIG_LPS_PG
+static void _lps_pg_state_update(_adapter *adapter)
+{
+	u8	is_in_lpspg = _FALSE;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *psta = NULL;
+
+	if ((pwrpriv->lps_level == LPS_PG) && (pwrpriv->pwr_mode != PS_MODE_ACTIVE) && (pwrpriv->rpwm <= PS_STATE_S2))
+		is_in_lpspg = _TRUE;
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+
+	if (psta)
+		psta->cmn.ra_info.disable_ra = (is_in_lpspg) ? _TRUE : _FALSE;
+}
+#endif
+
+/*#define DBG_PHYDM_STATE_CHK*/
+
+
+static u8 _rtw_phydm_rfk_condition_check(_adapter *adapter, u8 is_scaning, u8 ifs_linked)
+{
+	u8 rfk_allowed = _TRUE;
+
+	#ifdef CONFIG_SKIP_RFK_IN_DM
+	rfk_allowed = _FALSE;
+	if (0)
+		RTW_ERR("[RFK-CHK] RF-K not allowed due to CONFIG_SKIP_RFK_IN_DM\n");
+	return rfk_allowed;
+	#endif
+
+	if (ifs_linked) {
+		if (is_scaning) {
+			rfk_allowed = _FALSE;
+			RTW_ERR("[RFK-CHK] RF-K not allowed due to ifaces under site-survey\n");
+		}
+		else {
+			rfk_allowed = rtw_mi_stayin_union_ch_chk(adapter) ? _TRUE : _FALSE;
+			if (rfk_allowed == _FALSE)
+				RTW_ERR("[RFK-CHK] RF-K not allowed due to ld_iface not stayin union ch\n");
+		}
+	}
+
+	#ifdef CONFIG_MCC_MODE
+	/*not in MCC State*/
+	if (MCC_EN(adapter)) {
+		if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
+			rfk_allowed = _FALSE;
+			if (0)
+				RTW_ERR("[RFK-CHK] RF-K not allowed due to doing MCC\n");
+		}
+	}
+	#endif
+
+	#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
+
+	#endif
+
+	return rfk_allowed;
+}
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+static u8 _rtw_phydm_iqk_segment_chk(_adapter *adapter, u8 ifs_linked)
+{
+	u8 iqk_sgt = _FALSE;
+
+#if 0
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	if (is_linked && (dvobj->traffic_stat.cur_tx_tp > 2 || dvobj->traffic_stat.cur_rx_tp > 2))
+		rst = _TRUE;
+#else
+	if (ifs_linked)
+		iqk_sgt = _TRUE;
+#endif
+	return iqk_sgt;
+}
+#endif
+
+/*check the tx low rate while unlinked to any AP;for pwr tracking */
+static u8 _rtw_phydm_pwr_tracking_rate_check(_adapter *adapter)
+{
+	int i;
+	_adapter *iface;
+	u8		if_tx_rate = 0xFF;
+	u8		tx_rate = 0xFF;
+	struct mlme_ext_priv	*pmlmeext = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		pmlmeext = &(iface->mlmeextpriv);
+		if ((iface) && rtw_is_adapter_up(iface)) {
+#ifdef CONFIG_P2P
+			if (!rtw_p2p_chk_role(&(iface)->wdinfo, P2P_ROLE_DISABLE))
+				if_tx_rate = IEEE80211_OFDM_RATE_6MB;
+			else
+#endif
+				if_tx_rate = pmlmeext->tx_rate;
+			if(if_tx_rate < tx_rate)
+				tx_rate = if_tx_rate;
+
+			RTW_DBG("%s i=%d tx_rate =0x%x\n", __func__, i, if_tx_rate);
+		}
+	}
+	RTW_DBG("%s tx_low_rate (unlinked to any AP)=0x%x\n", __func__, tx_rate);
+	return tx_rate;
+}
+
+#ifdef CONFIG_DYNAMIC_SOML
+void rtw_dyn_soml_byte_update(_adapter *adapter, u8 data_rate, u32 size)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+
+	phydm_soml_bytes_acq(phydm, data_rate, size);
+}
+
+void rtw_dyn_soml_para_set(_adapter *adapter, u8 train_num, u8 intvl,
+			u8 period, u8 delay)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+
+	phydm_adaptive_soml_para_set(phydm, train_num, intvl, period, delay);
+	RTW_INFO("%s.\n", __func__);
+}
+
+void rtw_dyn_soml_config(_adapter *adapter)
+{
+	RTW_INFO("%s.\n", __func__);
+
+	if (adapter->registrypriv.dyn_soml_en == 1) {
+		/* Must after phydm_adaptive_soml_init() */
+		rtw_hal_set_hwreg(adapter , HW_VAR_SET_SOML_PARAM , NULL);
+		RTW_INFO("dyn_soml_en = 1\n");
+	} else {
+		if (adapter->registrypriv.dyn_soml_en == 2) {
+			rtw_dyn_soml_para_set(adapter, 
+				adapter->registrypriv.dyn_soml_train_num, 
+				adapter->registrypriv.dyn_soml_interval, 
+				adapter->registrypriv.dyn_soml_period,
+				adapter->registrypriv.dyn_soml_delay);
+			RTW_INFO("dyn_soml_en = 2\n");
+			RTW_INFO("dyn_soml_en, param = %d, %d, %d, %d\n",
+				adapter->registrypriv.dyn_soml_train_num,
+				adapter->registrypriv.dyn_soml_interval, 
+				adapter->registrypriv.dyn_soml_period,
+				adapter->registrypriv.dyn_soml_delay);
+		} else if (adapter->registrypriv.dyn_soml_en == 0) {
+			RTW_INFO("dyn_soml_en = 0\n");
+		} else
+			RTW_ERR("%s, wrong setting: dyn_soml_en = %d\n", __func__,
+				adapter->registrypriv.dyn_soml_en);
+	}
+}
+#endif
+
+void rtw_phydm_watchdog(_adapter *adapter)
+{
+	u8	bLinked = _FALSE;
+	u8	bsta_state = _FALSE;
+	u8	bBtDisabled = _TRUE;
+	u8	rfk_forbidden = _FALSE;
+	#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+	u8	segment_iqk = _FALSE;
+	#endif
+	u8	tx_unlinked_low_rate = 0xFF;
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
+
+	if (!rtw_is_hw_init_completed(adapter)) {
+		RTW_DBG("%s skip due to hw_init_completed == FALSE\n", __func__);
+		return;
+	}
+	if (rtw_mi_check_fwstate(adapter, _FW_UNDER_SURVEY))
+		pHalData->bScanInProcess = _TRUE;
+	else
+		pHalData->bScanInProcess = _FALSE;
+
+	if (rtw_mi_check_status(adapter, MI_ASSOC)) {
+		bLinked = _TRUE;
+		if (rtw_mi_check_status(adapter, MI_STA_LINKED))
+		bsta_state = _TRUE;
+	}
+
+	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_LINK, bLinked);
+	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_STATION_STATE, bsta_state);
+
+	#ifdef CONFIG_BT_COEXIST
+	bBtDisabled = rtw_btcoex_IsBtDisabled(adapter);
+	#endif /* CONFIG_BT_COEXIST */
+	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_BT_ENABLED,
+							(bBtDisabled == _TRUE) ? _FALSE : _TRUE);
+#ifdef CONFIG_LPS_PG
+	_lps_pg_state_update(adapter);
+#endif
+
+	rfk_forbidden = (_rtw_phydm_rfk_condition_check(adapter, pHalData->bScanInProcess, bLinked) == _TRUE) ? _FALSE : _TRUE;
+	halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
+
+	#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+	segment_iqk = _rtw_phydm_iqk_segment_chk(adapter, bLinked);
+	halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_IQK_SEGMENT, segment_iqk);
+	#endif
+	#ifdef DBG_PHYDM_STATE_CHK
+	RTW_INFO("%s rfk_forbidden = %s, segment_iqk = %s\n",
+			__func__, (rfk_forbidden) ? "Y" : "N", (segment_iqk) ? "Y" : "N");
+	#endif
+
+	if (bLinked == _FALSE) {
+		tx_unlinked_low_rate = _rtw_phydm_pwr_tracking_rate_check(adapter);
+		halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_RATE_INDEX, tx_unlinked_low_rate);
+	}
+
+	/*if (!rtw_mi_stayin_union_band_chk(adapter)) {
+		#ifdef DBG_PHYDM_STATE_CHK
+		RTW_ERR("Not stay in union band, skip phydm\n");
+		#endif
+		goto _exit;
+	}*/
+	if (pwrctl->bpower_saving)
+		phydm_watchdog_lps(&pHalData->odmpriv);
+	else
+		phydm_watchdog(&pHalData->odmpriv);
+
+	#ifdef CONFIG_RTW_ACS
+	rtw_acs_update_current_info(adapter);
+	#endif
+
+_exit:
+	return;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.h
index 2dd95f021600..440dde0fbf18 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm.h
@@ -1,26 +1,89 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __HAL_DM_H__
-#define __HAL_DM_H__
-
-void Init_ODM_ComInfo(_adapter *adapter);
-
-#endif /* __HAL_DM_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_DM_H__
+#define __HAL_DM_H__
+
+#define adapter_to_phydm(adapter) (&(GET_HAL_DATA(adapter)->odmpriv))
+
+void Init_ODM_ComInfo(_adapter *adapter);
+void rtw_phydm_init(_adapter *adapter);
+
+void rtw_hal_turbo_edca(_adapter *adapter);
+u8 rtw_phydm_is_iqk_in_progress(_adapter *adapter);
+
+void GetHalODMVar(
+	PADAPTER				Adapter,
+	HAL_ODM_VARIABLE		eVariable,
+	PVOID					pValue1,
+	PVOID					pValue2);
+void SetHalODMVar(
+	PADAPTER				Adapter,
+	HAL_ODM_VARIABLE		eVariable,
+	PVOID					pValue1,
+	BOOLEAN					bSet);
+
+void rtw_phydm_ra_registed(_adapter *adapter, struct sta_info *psta);
+
+#ifdef CONFIG_DYNAMIC_SOML
+void rtw_dyn_soml_byte_update(_adapter *adapter, u8 data_rate, u32 size);
+void rtw_dyn_soml_para_set(_adapter *adapter, u8 train_num, u8 intvl,
+			u8 period, u8 delay);
+void rtw_dyn_soml_config(_adapter *adapter);
+#endif
+void rtw_phydm_watchdog(_adapter *adapter);
+
+void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter);
+void dump_sta_info(void *sel, struct sta_info *psta);
+void dump_sta_traffic(void *sel, _adapter *adapter, struct sta_info *psta);
+
+#ifdef CONFIG_DBG_RF_CAL
+void rtw_hal_iqk_test(_adapter *adapter, bool recovery, bool clear, bool segment);
+void rtw_hal_lck_test(_adapter *adapter);
+#endif
+
+s8 rtw_phydm_get_min_rssi(_adapter *adapter);
+u8 rtw_phydm_get_cur_igi(_adapter *adapter);
+
+
+#ifdef CONFIG_LPS_LCLK_WD_TIMER
+extern void phydm_rssi_monitor_check(void *p_dm_void);
+
+void rtw_phydm_wd_lps_lclk_hdl(_adapter *adapter);
+void rtw_phydm_watchdog_in_lps_lclk(_adapter *adapter);
+#endif
+
+enum phy_cnt {
+	FA_OFDM,
+	FA_CCK,
+	FA_TOTAL,
+	CCA_OFDM,
+	CCA_CCK,
+	CCA_ALL,
+	CRC32_OK_VHT,
+	CRC32_OK_HT,
+	CRC32_OK_LEGACY,
+	CRC32_OK_CCK,
+	CRC32_ERROR_VHT,
+	CRC32_ERROR_HT,
+	CRC32_ERROR_LEGACY,
+	CRC32_ERROR_CCK,
+};
+u32 rtw_phydm_get_phy_cnt(_adapter *adapter, enum phy_cnt cnt);
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+void rtw_phydm_iqk_trigger(_adapter *adapter);
+#endif
+
+#endif /* __HAL_DM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm_acs.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm_acs.c
new file mode 100644
index 000000000000..9b581a6059c6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm_acs.c
@@ -0,0 +1,555 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2014 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+
+
+#if defined(CONFIG_RTW_ACS) || defined(CONFIG_BACKGROUND_NOISE_MONITOR)
+static void _rtw_bss_nums_count(_adapter *adapter, u8 *pbss_nums)
+{
+	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
+	_queue *queue = &(pmlmepriv->scanned_queue);
+	struct wlan_network *pnetwork = NULL;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+
+	_list	*plist, *phead;
+	_irqL irqL;
+	int chan_idx = -1;
+
+	if (pbss_nums == NULL) {
+		RTW_ERR("%s pbss_nums is null pointer\n", __func__);
+		return;
+	}
+	_rtw_memset(pbss_nums, 0, MAX_CHANNEL_NUM);
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		if (!pnetwork)
+			break;
+		chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), pnetwork->network.Configuration.DSConfig);
+		if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
+			RTW_ERR("%s can't get chan_idx(CH:%d)\n",
+				__func__, pnetwork->network.Configuration.DSConfig);
+			chan_idx = 0;
+		}
+		/*if (pnetwork->network.Reserved[0] != BSS_TYPE_PROB_REQ)*/
+
+		pbss_nums[chan_idx]++;
+
+		plist = get_next(plist);
+	}
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+}
+
+u8 rtw_get_ch_num_by_idx(_adapter *adapter, u8 idx)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	RT_CHANNEL_INFO *pch_set = rfctl->channel_set;
+	u8 max_chan_nums = rfctl->max_chan_nums;
+
+	if (idx >= max_chan_nums)
+		return 0;
+	return pch_set[idx].ChannelNum;
+}
+#endif /*defined(CONFIG_RTW_ACS) || defined(CONFIG_BACKGROUND_NOISE_MONITOR)*/
+
+
+#ifdef CONFIG_RTW_ACS
+void rtw_acs_version_dump(void *sel, _adapter *adapter)
+{
+	_RTW_PRINT_SEL(sel, "RTK_ACS VER_%d\n", RTK_ACS_VERSION);
+}
+u8 rtw_phydm_clm_ratio(_adapter *adapter)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+
+	return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CLM_RATIO);
+}
+u8 rtw_phydm_nhm_ratio(_adapter *adapter)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+
+	return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_NHM_RATIO);
+}
+void rtw_acs_reset(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct auto_chan_sel *pacs = &hal_data->acs;
+
+	_rtw_memset(pacs, 0, sizeof(struct auto_chan_sel));
+	#ifdef CONFIG_RTW_ACS_DBG
+	rtw_acs_adv_reset(adapter);
+	#endif /*CONFIG_RTW_ACS_DBG*/
+}
+
+#ifdef CONFIG_RTW_ACS_DBG
+u8 rtw_is_acs_igi_valid(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct auto_chan_sel *pacs = &hal_data->acs;
+
+	if ((pacs->igi) && ((pacs->igi >= 0x1E) || (pacs->igi < 0x60)))
+		return _TRUE;
+
+	return _FALSE;
+}
+void rtw_acs_adv_setting(_adapter *adapter, RT_SCAN_TYPE scan_type, u16 scan_time, u8 igi, u8 bw)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct auto_chan_sel *pacs = &hal_data->acs;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+
+	pacs->scan_type = scan_type;
+	pacs->scan_time = scan_time;
+	pacs->igi = igi;
+	pacs->bw = bw;
+	RTW_INFO("[ACS] ADV setting - scan_type:%c, ch_ms:%d(ms), igi:0x%02x, bw:%d\n",
+		pacs->scan_type ? 'A' : 'P', pacs->scan_time, pacs->igi, pacs->bw);
+}
+void rtw_acs_adv_reset(_adapter *adapter)
+{
+	rtw_acs_adv_setting(adapter, SCAN_ACTIVE, 0, 0, 0);
+}
+#endif /*CONFIG_RTW_ACS_DBG*/
+
+void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan, enum NHM_PID pid)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+#if (RTK_ACS_VERSION == 3)
+	struct clm_para_info clm_para;
+	struct nhm_para_info nhm_para;
+	struct env_trig_rpt trig_rpt;
+
+	scan_time_ms -= 10;
+
+	init_acs_clm(clm_para, scan_time_ms);
+
+	if (pid == NHM_PID_IEEE_11K_HIGH)
+		init_11K_high_nhm(nhm_para, scan_time_ms);
+	else if (pid == NHM_PID_IEEE_11K_LOW)
+		init_11K_low_nhm(nhm_para, scan_time_ms);
+	else
+		init_acs_nhm(nhm_para, scan_time_ms);
+
+	hal_data->acs.trig_rst = phydm_env_mntr_trigger(phydm, &nhm_para, &clm_para, &trig_rpt);
+	if (hal_data->acs.trig_rst == (NHM_SUCCESS | CLM_SUCCESS)) {
+		hal_data->acs.trig_rpt.clm_rpt_stamp = trig_rpt.clm_rpt_stamp;
+		hal_data->acs.trig_rpt.nhm_rpt_stamp = trig_rpt.nhm_rpt_stamp;
+		/*RTW_INFO("[ACS] trigger success (rst = 0x%02x, clm_stamp:%d, nhm_stamp:%d)\n",
+			hal_data->acs.trig_rst, hal_data->acs.trig_rpt.clm_rpt_stamp, hal_data->acs.trig_rpt.nhm_rpt_stamp);*/
+	} else
+		RTW_ERR("[ACS] trigger failed (rst = 0x%02x)\n", hal_data->acs.trig_rst);
+#else
+	phydm_ccx_monitor_trigger(phydm, scan_time_ms);
+#endif
+
+	hal_data->acs.trigger_ch = scan_chan;
+	hal_data->acs.triggered = _TRUE;
+
+	#ifdef CONFIG_RTW_ACS_DBG
+	RTW_INFO("[ACS] Trigger CH:%d, Times:%d\n", hal_data->acs.trigger_ch, scan_time_ms);
+	#endif
+}
+void rtw_acs_get_rst(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	int chan_idx = -1;
+	u8 cur_chan = hal_data->acs.trigger_ch;
+
+	if (cur_chan == 0)
+		return;
+
+	if (!hal_data->acs.triggered)
+		return;
+
+	chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), cur_chan);
+	if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
+		RTW_ERR("[ACS] %s can't get chan_idx(CH:%d)\n", __func__, cur_chan);
+		return;
+	}
+#if (RTK_ACS_VERSION == 3)
+	if (!(hal_data->acs.trig_rst == (NHM_SUCCESS | CLM_SUCCESS))) {
+		RTW_ERR("[ACS] get_rst return, due to acs trigger failed\n");
+		return;
+	}
+
+	{
+		struct env_mntr_rpt rpt = {0};
+		u8 rst;
+
+		rst = phydm_env_mntr_result(phydm, &rpt);
+		if ((rst == (NHM_SUCCESS | CLM_SUCCESS)) &&
+			(rpt.clm_rpt_stamp == hal_data->acs.trig_rpt.clm_rpt_stamp) &&
+			(rpt.nhm_rpt_stamp == hal_data->acs.trig_rpt.nhm_rpt_stamp)){
+			hal_data->acs.clm_ratio[chan_idx] = rpt.clm_ratio;
+			hal_data->acs.nhm_ratio[chan_idx] = rpt.nhm_ratio;
+			_rtw_memcpy(&hal_data->acs.nhm[chan_idx][0], rpt.nhm_result, NHM_RPT_NUM);
+
+			/*RTW_INFO("[ACS] get_rst success (rst = 0x%02x, clm_stamp:%d:%d, nhm_stamp:%d:%d)\n",
+			rst,
+			hal_data->acs.trig_rpt.clm_rpt_stamp, rpt.clm_rpt_stamp,
+			hal_data->acs.trig_rpt.nhm_rpt_stamp, rpt.nhm_rpt_stamp);*/
+		} else {
+			RTW_ERR("[ACS] get_rst failed (rst = 0x%02x, clm_stamp:%d:%d, nhm_stamp:%d:%d)\n",
+			rst,
+			hal_data->acs.trig_rpt.clm_rpt_stamp, rpt.clm_rpt_stamp,
+			hal_data->acs.trig_rpt.nhm_rpt_stamp, rpt.nhm_rpt_stamp);
+		}
+	}
+
+#else
+	phydm_ccx_monitor_result(phydm);
+
+	hal_data->acs.clm_ratio[chan_idx] = rtw_phydm_clm_ratio(adapter);
+	hal_data->acs.nhm_ratio[chan_idx] = rtw_phydm_nhm_ratio(adapter);
+#endif
+	hal_data->acs.triggered = _FALSE;
+	#ifdef CONFIG_RTW_ACS_DBG
+	RTW_INFO("[ACS] Result CH:%d, CLM:%d NHM:%d\n",
+		cur_chan, hal_data->acs.clm_ratio[chan_idx], hal_data->acs.nhm_ratio[chan_idx]);
+	#endif
+}
+
+void _rtw_phydm_acs_select_best_chan(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u8 ch_idx;
+	u8 ch_idx_24g = 0xFF, ch_idx_5g = 0xFF;
+	u8 min_itf_24g = 0xFF,  min_itf_5g = 0xFF;
+	u8 *pbss_nums = hal_data->acs.bss_nums;
+	u8 *pclm_ratio = hal_data->acs.clm_ratio;
+	u8 *pnhm_ratio = hal_data->acs.nhm_ratio;
+	u8 *pinterference_time = hal_data->acs.interference_time;
+	u8 max_chan_nums = rfctl->max_chan_nums;
+
+	for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
+		if (pbss_nums[ch_idx])
+			pinterference_time[ch_idx] = (pclm_ratio[ch_idx] / 2) + pnhm_ratio[ch_idx];
+		else
+			pinterference_time[ch_idx] = pclm_ratio[ch_idx] + pnhm_ratio[ch_idx];
+
+		if (rtw_get_ch_num_by_idx(adapter, ch_idx) < 14) {
+			if (pinterference_time[ch_idx] < min_itf_24g) {
+				min_itf_24g = pinterference_time[ch_idx];
+				ch_idx_24g = ch_idx;
+			}
+		} else {
+			if (pinterference_time[ch_idx] < min_itf_5g) {
+				min_itf_5g = pinterference_time[ch_idx];
+				ch_idx_5g = ch_idx;
+			}
+		}
+	}
+	if (ch_idx_24g != 0xFF)
+		hal_data->acs.best_chan_24g = rtw_get_ch_num_by_idx(adapter, ch_idx_24g);
+
+	if (ch_idx_5g != 0xFF)
+		hal_data->acs.best_chan_5g = rtw_get_ch_num_by_idx(adapter, ch_idx_5g);
+
+	hal_data->acs.trigger_ch = 0;
+}
+
+void rtw_acs_info_dump(void *sel, _adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u8 max_chan_nums = rfctl->max_chan_nums;
+	u8 ch_idx, ch_num;
+
+	_RTW_PRINT_SEL(sel, "========== ACS (VER-%d) ==========\n", RTK_ACS_VERSION);
+	_RTW_PRINT_SEL(sel, "Best 24G Channel:%d\n", hal_data->acs.best_chan_24g);
+	_RTW_PRINT_SEL(sel, "Best 5G Channel:%d\n\n", hal_data->acs.best_chan_5g);
+
+	#ifdef CONFIG_RTW_ACS_DBG
+	_RTW_PRINT_SEL(sel, "Advanced setting - scan_type:%c, ch_ms:%d(ms), igi:0x%02x, bw:%d\n",
+		hal_data->acs.scan_type ? 'A' : 'P', hal_data->acs.scan_time, hal_data->acs.igi, hal_data->acs.bw);
+
+	_RTW_PRINT_SEL(sel, "BW  20MHz\n");
+	_RTW_PRINT_SEL(sel, "%5s  %3s  %3s  %3s(%%)  %3s(%%)  %3s\n",
+						"Index", "CH", "BSS", "CLM", "NHM", "ITF");
+
+	for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
+		ch_num = rtw_get_ch_num_by_idx(adapter, ch_idx);
+		_RTW_PRINT_SEL(sel, "%5d  %3d  %3d  %6d  %6d  %3d\n",
+						ch_idx, ch_num, hal_data->acs.bss_nums[ch_idx],
+						hal_data->acs.clm_ratio[ch_idx],
+						hal_data->acs.nhm_ratio[ch_idx],
+						hal_data->acs.interference_time[ch_idx]);
+	}
+	#endif
+}
+void rtw_acs_select_best_chan(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+
+	_rtw_bss_nums_count(adapter, hal_data->acs.bss_nums);
+	_rtw_phydm_acs_select_best_chan(adapter);
+	rtw_acs_info_dump(RTW_DBGDUMP, adapter);
+}
+
+void rtw_acs_start(_adapter *adapter)
+{
+	rtw_acs_reset(adapter);
+	if (GET_ACS_STATE(adapter) != ACS_ENABLE)
+		SET_ACS_STATE(adapter, ACS_ENABLE);
+}
+void rtw_acs_stop(_adapter *adapter)
+{
+	SET_ACS_STATE(adapter, ACS_DISABLE);
+}
+
+
+u8 rtw_acs_get_clm_ratio_by_ch_num(_adapter *adapter, u8 chan)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	int chan_idx = -1;
+
+	chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
+	if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
+		RTW_ERR("[ACS] Get CLM fail, can't get chan_idx(CH:%d)\n", chan);
+		return 0;
+	}
+
+	return hal_data->acs.clm_ratio[chan_idx];
+}
+u8 rtw_acs_get_clm_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+
+	if (ch_idx >= MAX_CHANNEL_NUM) {
+		RTW_ERR("%s [ACS] ch_idx(%d) is invalid\n", __func__, ch_idx);
+		return 0;
+	}
+
+	return hal_data->acs.clm_ratio[ch_idx];
+}
+u8 rtw_acs_get_nhm_ratio_by_ch_num(_adapter *adapter, u8 chan)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	int chan_idx = -1;
+
+	chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
+	if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
+		RTW_ERR("[ACS] Get NHM fail, can't get chan_idx(CH:%d)\n", chan);
+		return 0;
+	}
+
+	return hal_data->acs.nhm_ratio[chan_idx];
+}
+u8 rtw_acs_get_num_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+
+	if (ch_idx >= MAX_CHANNEL_NUM) {
+		RTW_ERR("%s [ACS] ch_idx(%d) is invalid\n", __func__, ch_idx);
+		return 0;
+	}
+
+	return hal_data->acs.nhm_ratio[ch_idx];
+}
+void rtw_acs_chan_info_dump(void *sel, _adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u8 max_chan_nums = rfctl->max_chan_nums;
+	u8 ch_idx, ch_num;
+	u8 utilization;
+
+	_RTW_PRINT_SEL(sel, "BW  20MHz\n");
+	_RTW_PRINT_SEL(sel, "%5s  %3s  %7s(%%)  %12s(%%)  %11s(%%)  %9s(%%)  %8s(%%)\n",
+						"Index", "CH", "Quality", "Availability", "Utilization",
+						"WIFI Util", "Interference Util");
+
+	for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
+		ch_num = rtw_get_ch_num_by_idx(adapter, ch_idx);
+		utilization = hal_data->acs.clm_ratio[ch_idx] + hal_data->acs.nhm_ratio[ch_idx];
+		_RTW_PRINT_SEL(sel, "%5d  %3d  %7d   %12d   %12d   %12d   %12d\n",
+						ch_idx, ch_num,
+						(100-hal_data->acs.interference_time[ch_idx]),
+						(100-utilization),
+						utilization,
+						hal_data->acs.clm_ratio[ch_idx],
+						hal_data->acs.nhm_ratio[ch_idx]);
+	}
+}
+void rtw_acs_current_info_dump(void *sel, _adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u8 ch, cen_ch, bw, offset;
+
+	_RTW_PRINT_SEL(sel, "========== ACS (VER-%d) ==========\n", RTK_ACS_VERSION);
+
+	ch = rtw_get_oper_ch(adapter);
+	bw = rtw_get_oper_bw(adapter);
+	offset = rtw_get_oper_choffset(adapter);
+
+	_RTW_PRINT_SEL(sel, "Current Channel:%d\n", ch);
+	if ((bw == CHANNEL_WIDTH_80) ||(bw == CHANNEL_WIDTH_40)) {
+		cen_ch = rtw_get_center_ch(ch, bw, offset);
+		_RTW_PRINT_SEL(sel, "Center Channel:%d\n", cen_ch);
+	}
+
+	_RTW_PRINT_SEL(sel, "Current BW %s\n", ch_width_str(bw));
+	if (0)
+		_RTW_PRINT_SEL(sel, "Current IGI 0x%02x\n", rtw_phydm_get_cur_igi(adapter));
+	_RTW_PRINT_SEL(sel, "CLM:%d, NHM:%d\n\n",
+		hal_data->acs.cur_ch_clm_ratio, hal_data->acs.cur_ch_nhm_ratio);
+}
+
+void rtw_acs_update_current_info(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+
+	hal_data->acs.cur_ch_clm_ratio = rtw_phydm_clm_ratio(adapter);
+	hal_data->acs.cur_ch_nhm_ratio = rtw_phydm_nhm_ratio(adapter);
+
+	#ifdef CONFIG_RTW_ACS_DBG
+	rtw_acs_current_info_dump(RTW_DBGDUMP, adapter);
+	#endif
+}
+#endif /*CONFIG_RTW_ACS*/
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+void rtw_noise_monitor_version_dump(void *sel, _adapter *adapter)
+{
+	_RTW_PRINT_SEL(sel, "RTK_NOISE_MONITOR VER_%d\n", RTK_NOISE_MONITOR_VERSION);
+}
+void rtw_nm_enable(_adapter *adapter)
+{
+	SET_NM_STATE(adapter, NM_ENABLE);
+}
+void rtw_nm_disable(_adapter *adapter)
+{
+	SET_NM_STATE(adapter, NM_DISABLE);
+}
+void rtw_noise_info_dump(void *sel, _adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	u8 max_chan_nums = rfctl->max_chan_nums;
+	u8 ch_idx, ch_num;
+
+	_RTW_PRINT_SEL(sel, "========== NM (VER-%d) ==========\n", RTK_NOISE_MONITOR_VERSION);
+
+	_RTW_PRINT_SEL(sel, "%5s  %3s  %3s  %10s", "Index", "CH", "BSS", "Noise(dBm)\n");
+
+	_rtw_bss_nums_count(adapter, hal_data->nm.bss_nums);
+
+	for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
+		ch_num = rtw_get_ch_num_by_idx(adapter, ch_idx);
+		_RTW_PRINT_SEL(sel, "%5d  %3d  %3d  %10d\n",
+						ch_idx, ch_num, hal_data->nm.bss_nums[ch_idx],
+						hal_data->nm.noise[ch_idx]);
+	}
+}
+
+void rtw_noise_measure(_adapter *adapter, u8 chan, u8 is_pause_dig, u8 igi_value, u32 max_time)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm = &hal_data->odmpriv;
+	int chan_idx = -1;
+	s16 noise = 0;
+
+	#ifdef DBG_NOISE_MONITOR
+	RTW_INFO("[NM] chan(%d)-PauseDIG:%s,  IGIValue:0x%02x, max_time:%d (ms)\n",
+		chan, (is_pause_dig) ? "Y" : "N", igi_value, max_time);
+	#endif
+
+	chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
+	if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
+		RTW_ERR("[NM] Get noise fail, can't get chan_idx(CH:%d)\n", chan);
+		return;
+	}
+	noise = odm_inband_noise_monitor(phydm, is_pause_dig, igi_value, max_time); /*dBm*/
+
+	hal_data->nm.noise[chan_idx] = noise;
+
+	#ifdef DBG_NOISE_MONITOR
+	RTW_INFO("[NM] %s chan_%d, noise = %d (dBm)\n", __func__, chan, hal_data->nm.noise[chan_idx]);
+
+	RTW_INFO("[NM] noise_a = %d, noise_b = %d  noise_all:%d\n",
+			 phydm->noise_level.noise[RF_PATH_A],
+			 phydm->noise_level.noise[RF_PATH_B],
+			 phydm->noise_level.noise_all);
+	#endif /*DBG_NOISE_MONITOR*/
+}
+
+s16 rtw_noise_query_by_chan_num(_adapter *adapter, u8 chan)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	s16 noise = 0;
+	int chan_idx = -1;
+
+	chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
+	if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
+		RTW_ERR("[NM] Get noise fail, can't get chan_idx(CH:%d)\n", chan);
+		return noise;
+	}
+	noise = hal_data->nm.noise[chan_idx];
+
+	#ifdef DBG_NOISE_MONITOR
+	RTW_INFO("[NM] %s chan_%d, noise = %d (dBm)\n", __func__, chan, noise);
+	#endif/*DBG_NOISE_MONITOR*/
+	return noise;
+}
+s16 rtw_noise_query_by_chan_idx(_adapter *adapter, u8 ch_idx)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	s16 noise = 0;
+
+	if (ch_idx >= MAX_CHANNEL_NUM) {
+		RTW_ERR("[NM] %s ch_idx(%d) is invalid\n", __func__, ch_idx);
+		return noise;
+	}
+	noise = hal_data->nm.noise[ch_idx];
+
+	#ifdef DBG_NOISE_MONITOR
+	RTW_INFO("[NM] %s ch_idx %d, noise = %d (dBm)\n", __func__, ch_idx, noise);
+	#endif/*DBG_NOISE_MONITOR*/
+	return noise;
+}
+
+s16 rtw_noise_measure_curchan(_adapter *padapter)
+{
+	s16 noise = 0;
+	u8 igi_value = 0x1E;
+	u32 max_time = 100;/* ms */
+	u8 is_pause_dig = _TRUE;
+	u8 cur_chan = rtw_get_oper_ch(padapter);
+
+	if (rtw_linked_check(padapter) == _FALSE)
+		return noise;
+
+	rtw_ps_deny(padapter, PS_DENY_IOCTL);
+	LeaveAllPowerSaveModeDirect(padapter);
+	rtw_noise_measure(padapter, cur_chan, is_pause_dig, igi_value, max_time);
+	noise = rtw_noise_query_by_chan_num(padapter, cur_chan);
+	rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+
+	return noise;
+}
+#endif /*CONFIG_BACKGROUND_NOISE_MONITOR*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm_acs.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm_acs.h
new file mode 100644
index 000000000000..c515deed624e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_dm_acs.h
@@ -0,0 +1,168 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_DM_ACS_H__
+#define __HAL_DM_ACS_H__
+#ifdef CONFIG_RTW_ACS
+#define RTK_ACS_VERSION	3
+
+#if (RTK_ACS_VERSION == 3)
+enum NHM_PID {
+	NHM_PID_ACS,
+	NHM_PID_IEEE_11K_HIGH,
+	NHM_PID_IEEE_11K_LOW,
+};
+
+#define init_clm_param(clm, app, lv, time) \
+	do {\
+		clm.clm_app = app;\
+		clm.clm_lv = lv;\
+		clm.mntr_time = time;\
+	} while (0)
+
+#define init_nhm_param(nhm, txon, cca, cnt_opt, app, lv, time) \
+	do {\
+		nhm.incld_txon = txon;\
+		nhm.incld_cca = cca;\
+		nhm.div_opt = cnt_opt;\
+		nhm.nhm_app = app;\
+		nhm.nhm_lv = lv;\
+		nhm.mntr_time = time;\
+	} while (0)
+
+	
+#define init_acs_clm(clm, time) \
+	init_clm_param(clm, CLM_ACS, CLM_LV_2, time)
+
+#define init_acs_nhm(nhm, time) \
+	init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, NHM_ACS, NHM_LV_2, time)
+
+#define init_11K_high_nhm(nhm, time) \
+	init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, IEEE_11K_HIGH, NHM_LV_2, time)
+	
+#define init_11K_low_nhm(nhm, time) \
+		init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, IEEE_11K_LOW, NHM_LV_2, time)
+
+
+#endif /*(RTK_ACS_VERSION == 3)*/
+void rtw_acs_version_dump(void *sel, _adapter *adapter);
+extern void phydm_ccx_monitor_trigger(void *p_dm_void, u16 monitor_time);
+extern void phydm_ccx_monitor_result(void *p_dm_void);
+
+#define GET_ACS_STATE(padapter)					(ATOMIC_READ(&GET_HAL_DATA(padapter)->acs.state))
+#define SET_ACS_STATE(padapter, set_state)			(ATOMIC_SET(&GET_HAL_DATA(padapter)->acs.state, set_state))
+#define IS_ACS_ENABLE(padapter)					((GET_ACS_STATE(padapter) == ACS_ENABLE) ? _TRUE : _FALSE)
+
+enum ACS_STATE {
+	ACS_DISABLE,
+	ACS_ENABLE,
+};
+
+#define ACS_BW_20M	BIT(0)
+#define ACS_BW_40M	BIT(1)
+#define ACS_BW_80M	BIT(2)
+#define ACS_BW_160M	BIT(3)
+
+struct auto_chan_sel {
+	ATOMIC_T state;
+	u8 trigger_ch;
+	bool triggered;
+	u8 clm_ratio[MAX_CHANNEL_NUM];
+	u8 nhm_ratio[MAX_CHANNEL_NUM];
+	#if (RTK_ACS_VERSION == 3)
+	u8 nhm[MAX_CHANNEL_NUM][NHM_RPT_NUM];
+	#endif
+	u8 bss_nums[MAX_CHANNEL_NUM];
+	u8 interference_time[MAX_CHANNEL_NUM];
+	u8 cur_ch_clm_ratio;
+	u8 cur_ch_nhm_ratio;
+	u8 best_chan_5g;
+	u8 best_chan_24g;
+
+	#if (RTK_ACS_VERSION == 3)
+	u8 trig_rst;
+	struct env_trig_rpt	trig_rpt;
+	#endif
+
+	#ifdef CONFIG_RTW_ACS_DBG
+	RT_SCAN_TYPE scan_type;
+	u16 scan_time;
+	u8 igi;
+	u8 bw;
+	#endif
+};
+
+#define rtw_acs_get_best_chan_24g(adapter)		(GET_HAL_DATA(adapter)->acs.best_chan_24g)
+#define rtw_acs_get_best_chan_5g(adapter)		(GET_HAL_DATA(adapter)->acs.best_chan_5g)
+
+#ifdef CONFIG_RTW_ACS_DBG
+#define rtw_is_acs_passiv_scan(adapter)	(((GET_HAL_DATA(adapter)->acs.scan_type) == SCAN_PASSIVE) ? _TRUE : _FALSE)
+
+#define rtw_acs_get_adv_st(adapter)	(GET_HAL_DATA(adapter)->acs.scan_time)
+#define rtw_is_acs_st_valid(adapter)	((GET_HAL_DATA(adapter)->acs.scan_time) ? _TRUE : _FALSE)
+
+#define rtw_acs_get_adv_igi(adapter)	(GET_HAL_DATA(adapter)->acs.igi)
+u8 rtw_is_acs_igi_valid(_adapter *adapter);
+
+#define rtw_acs_get_adv_bw(adapter)	(GET_HAL_DATA(adapter)->acs.bw)
+
+void rtw_acs_adv_setting(_adapter *adapter, RT_SCAN_TYPE scan_type, u16 scan_time, u8 igi, u8 bw);
+void rtw_acs_adv_reset(_adapter *adapter);
+#endif
+
+u8 rtw_acs_get_clm_ratio_by_ch_num(_adapter *adapter, u8 chan);
+u8 rtw_acs_get_clm_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx);
+u8 rtw_acs_get_nhm_ratio_by_ch_num(_adapter *adapter, u8 chan);
+u8 rtw_acs_get_num_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx);
+
+void rtw_acs_reset(_adapter *adapter);
+void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan, enum NHM_PID pid);
+void rtw_acs_get_rst(_adapter *adapter);
+void rtw_acs_select_best_chan(_adapter *adapter);
+void rtw_acs_info_dump(void *sel, _adapter *adapter);
+void rtw_acs_update_current_info(_adapter *adapter);
+void rtw_acs_chan_info_dump(void *sel, _adapter *adapter);
+void rtw_acs_current_info_dump(void *sel, _adapter *adapter);
+
+void rtw_acs_start(_adapter *adapter);
+void rtw_acs_stop(_adapter *adapter);
+
+#endif /*CONFIG_RTW_ACS*/
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+#define RTK_NOISE_MONITOR_VERSION	3
+#define GET_NM_STATE(padapter)					(ATOMIC_READ(&GET_HAL_DATA(padapter)->nm.state))
+#define SET_NM_STATE(padapter, set_state)			(ATOMIC_SET(&GET_HAL_DATA(padapter)->nm.state, set_state))
+#define IS_NM_ENABLE(padapter)					((GET_NM_STATE(padapter) == NM_ENABLE) ? _TRUE : _FALSE)
+
+enum NM_STATE {
+	NM_DISABLE,
+	NM_ENABLE,
+};
+
+struct noise_monitor {
+	ATOMIC_T state;
+	s16 noise[MAX_CHANNEL_NUM];
+	u8 bss_nums[MAX_CHANNEL_NUM];
+};
+void rtw_nm_enable(_adapter *adapter);
+void rtw_nm_disable(_adapter *adapter);
+void rtw_noise_measure(_adapter *adapter, u8 chan, u8 is_pause_dig, u8 igi_value, u32 max_time);
+s16 rtw_noise_query_by_chan_num(_adapter *adapter, u8 chan);
+s16 rtw_noise_query_by_chan_idx(_adapter *adapter, u8 ch_idx);
+s16 rtw_noise_measure_curchan(_adapter *padapter);
+void rtw_noise_info_dump(void *sel, _adapter *adapter);
+#endif
+#endif /* __HAL_DM_ACS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_halmac.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_halmac.c
new file mode 100644
index 000000000000..383ee901c603
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_halmac.c
@@ -0,0 +1,5033 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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_HALMAC_C_
+
+#include <drv_types.h>		/* PADAPTER, struct dvobj_priv, SDIO_ERR_VAL8 and etc. */
+#include <hal_data.h>		/* efuse, PHAL_DATA_TYPE and etc. */
+#include "hal_halmac.h"		/* dvobj_to_halmac() and ect. */
+
+#define DEFAULT_INDICATOR_TIMELMT	1000	/* ms */
+#define MSG_PREFIX			"[HALMAC]"
+
+#define RTW_HALMAC_DLFW_MEM_NO_STOP_TX
+
+/*
+ * Driver API for HALMAC operations
+ */
+
+#ifdef CONFIG_SDIO_HCI
+#include <rtw_sdio.h>
+
+static u8 _halmac_mac_reg_page0_chk(const char *func, struct dvobj_priv *dvobj, u32 offset)
+{
+#if defined(CONFIG_IO_CHECK_IN_ANA_LOW_CLK) && defined(CONFIG_LPS_LCLK)
+	struct pwrctrl_priv *pwrpriv = &dvobj->pwrctl_priv;
+	u32 mac_reg_offset = 0;
+
+	if (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
+		return _TRUE;
+
+	if (pwrpriv->lps_level == LPS_NORMAL)
+		return _TRUE;
+
+	if (pwrpriv->rpwm >= PS_STATE_S2)
+		return _TRUE;
+
+	if (offset & (WLAN_IOREG_DEVICE_ID << 13))  { /*WLAN_IOREG_OFFSET*/
+		mac_reg_offset = offset & HALMAC_WLAN_MAC_REG_MSK;
+		if (mac_reg_offset < 0x100) {
+			RTW_ERR(FUNC_ADPT_FMT
+				"access MAC REG -0x%04x in PS-mode:0x%02x (rpwm:0x%02x, lps_level:0x%02x)\n",
+				FUNC_ADPT_ARG(dvobj_get_primary_adapter(dvobj)), mac_reg_offset,
+				pwrpriv->pwr_mode, pwrpriv->rpwm, pwrpriv->lps_level);
+			rtw_warn_on(1);
+			return _FALSE;
+		}
+	}
+#endif
+	return _TRUE;
+}
+
+static u8 _halmac_sdio_cmd52_read(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	u8 val;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	ret = rtw_sdio_read_cmd52(d, offset, &val, 1);
+	if (_FAIL == ret) {
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+		return SDIO_ERR_VAL8;
+	}
+
+	return val;
+}
+
+static void _halmac_sdio_cmd52_write(void *p, u32 offset, u8 val)
+{
+	struct dvobj_priv *d;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	ret = rtw_sdio_write_cmd52(d, offset, &val, 1);
+	if (_FAIL == ret)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+}
+
+static u8 _halmac_sdio_reg_read_8(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	u8 *pbuf;
+	u8 val;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	val = SDIO_ERR_VAL8;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	pbuf = rtw_zmalloc(1);
+	if (!pbuf)
+		return val;
+
+	ret = rtw_sdio_read_cmd53(d, offset, pbuf, 1);
+	if (ret == _FAIL) {
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	val = *pbuf;
+
+exit:
+	rtw_mfree(pbuf, 1);
+
+	return val;
+}
+
+static u16 _halmac_sdio_reg_read_16(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	u8 *pbuf;
+	u16 val;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	val = SDIO_ERR_VAL16;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	pbuf = rtw_zmalloc(2);
+	if (!pbuf)
+		return val;
+
+	ret = rtw_sdio_read_cmd53(d, offset, pbuf, 2);
+	if (ret == _FAIL) {
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	val = le16_to_cpu(*(u16 *)pbuf);
+
+exit:
+	rtw_mfree(pbuf, 2);
+
+	return val;
+}
+
+static u32 _halmac_sdio_reg_read_32(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	u8 *pbuf;
+	u32 val;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	val = SDIO_ERR_VAL32;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	pbuf = rtw_zmalloc(4);
+	if (!pbuf)
+		return val;
+
+	ret = rtw_sdio_read_cmd53(d, offset, pbuf, 4);
+	if (ret == _FAIL) {
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	val = le32_to_cpu(*(u32 *)pbuf);
+
+exit:
+	rtw_mfree(pbuf, 4);
+
+	return val;
+}
+
+static u8 _halmac_sdio_reg_read_n(void *p, u32 offset, u32 size, u8 *data)
+{
+	struct dvobj_priv *d = (struct dvobj_priv *)p;
+	u8 *pbuf;
+	u8 ret;
+	u8 rst = _FALSE;
+	u32 sdio_read_size;
+
+
+	sdio_read_size = RND4(size);
+	sdio_read_size = rtw_sdio_cmd53_align_size(d, sdio_read_size);
+
+	pbuf = rtw_zmalloc(sdio_read_size);
+	if ((!pbuf) || (!data))
+		return rst;
+
+	ret = rtw_sdio_read_cmd53(d, offset, pbuf, sdio_read_size);
+	if (ret == _FAIL) {
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	_rtw_memcpy(data, pbuf, size);
+	rst = _TRUE;
+exit:
+	rtw_mfree(pbuf, sdio_read_size);
+
+	return rst;
+}
+
+static void _halmac_sdio_reg_write_8(void *p, u32 offset, u8 val)
+{
+	struct dvobj_priv *d;
+	u8 *pbuf;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	pbuf = rtw_zmalloc(1);
+	if (!pbuf)
+		return;
+	_rtw_memcpy(pbuf, &val, 1);
+
+	ret = rtw_sdio_write_cmd53(d, offset, pbuf, 1);
+	if (ret == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+
+	rtw_mfree(pbuf, 1);
+}
+
+static void _halmac_sdio_reg_write_16(void *p, u32 offset, u16 val)
+{
+	struct dvobj_priv *d;
+	u8 *pbuf;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	val = cpu_to_le16(val);
+	pbuf = rtw_zmalloc(2);
+	if (!pbuf)
+		return;
+	_rtw_memcpy(pbuf, &val, 2);
+
+	ret = rtw_sdio_write_cmd53(d, offset, pbuf, 2);
+	if (ret == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+
+	rtw_mfree(pbuf, 2);
+}
+
+static void _halmac_sdio_reg_write_32(void *p, u32 offset, u32 val)
+{
+	struct dvobj_priv *d;
+	u8 *pbuf;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	_halmac_mac_reg_page0_chk(__func__, d, offset);
+	val = cpu_to_le32(val);
+	pbuf = rtw_zmalloc(4);
+	if (!pbuf)
+		return;
+	_rtw_memcpy(pbuf, &val, 4);
+
+	ret = rtw_sdio_write_cmd53(d, offset, pbuf, 4);
+	if (ret == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+
+	rtw_mfree(pbuf, 4);
+}
+
+static u8 _halmac_sdio_read_cia(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	u8 data = 0;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+
+	ret = rtw_sdio_f0_read(d, offset, &data, 1);
+	if (ret == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+
+	return data;
+}
+
+#else /* !CONFIG_SDIO_HCI */
+
+static u8 _halmac_reg_read_8(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	PADAPTER adapter;
+
+
+	d = (struct dvobj_priv *)p;
+	adapter = dvobj_get_primary_adapter(d);
+
+	return rtw_read8(adapter, offset);
+}
+
+static u16 _halmac_reg_read_16(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	PADAPTER adapter;
+
+
+	d = (struct dvobj_priv *)p;
+	adapter = dvobj_get_primary_adapter(d);
+
+	return rtw_read16(adapter, offset);
+}
+
+static u32 _halmac_reg_read_32(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	PADAPTER adapter;
+
+
+	d = (struct dvobj_priv *)p;
+	adapter = dvobj_get_primary_adapter(d);
+
+	return rtw_read32(adapter, offset);
+}
+
+static void _halmac_reg_write_8(void *p, u32 offset, u8 val)
+{
+	struct dvobj_priv *d;
+	PADAPTER adapter;
+	int err;
+
+
+	d = (struct dvobj_priv *)p;
+	adapter = dvobj_get_primary_adapter(d);
+
+	err = rtw_write8(adapter, offset, val);
+	if (err == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+}
+
+static void _halmac_reg_write_16(void *p, u32 offset, u16 val)
+{
+	struct dvobj_priv *d;
+	PADAPTER adapter;
+	int err;
+
+
+	d = (struct dvobj_priv *)p;
+	adapter = dvobj_get_primary_adapter(d);
+
+	err = rtw_write16(adapter, offset, val);
+	if (err == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+}
+
+static void _halmac_reg_write_32(void *p, u32 offset, u32 val)
+{
+	struct dvobj_priv *d;
+	PADAPTER adapter;
+	int err;
+
+
+	d = (struct dvobj_priv *)p;
+	adapter = dvobj_get_primary_adapter(d);
+
+	err = rtw_write32(adapter, offset, val);
+	if (err == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+}
+#endif /* !CONFIG_SDIO_HCI */
+
+static u8 _halmac_mfree(void *p, void *buffer, u32 size)
+{
+	rtw_mfree(buffer, size);
+	return _TRUE;
+}
+
+static void *_halmac_malloc(void *p, u32 size)
+{
+	return rtw_zmalloc(size);
+}
+
+static u8 _halmac_memcpy(void *p, void *dest, void *src, u32 size)
+{
+	_rtw_memcpy(dest, src, size);
+	return _TRUE;
+}
+
+static u8 _halmac_memset(void *p, void *addr, u8 value, u32 size)
+{
+	_rtw_memset(addr, value, size);
+	return _TRUE;
+}
+
+static void _halmac_udelay(void *p, u32 us)
+{
+	/* Most hardware polling wait time < 50us) */
+	if (us <= 50)
+		rtw_udelay_os(us);
+	else if (us <= 1000)
+		rtw_usleep_os(us);
+	else
+		rtw_msleep_os(RTW_DIV_ROUND_UP(us, 1000));
+}
+
+static u8 _halmac_mutex_init(void *p, HALMAC_MUTEX *pMutex)
+{
+	_rtw_mutex_init(pMutex);
+	return _TRUE;
+}
+
+static u8 _halmac_mutex_deinit(void *p, HALMAC_MUTEX *pMutex)
+{
+	_rtw_mutex_free(pMutex);
+	return _TRUE;
+}
+
+static u8 _halmac_mutex_lock(void *p, HALMAC_MUTEX *pMutex)
+{
+	int err;
+
+	err = _enter_critical_mutex(pMutex, NULL);
+	if (err)
+		return _FALSE;
+
+	return _TRUE;
+}
+
+static u8 _halmac_mutex_unlock(void *p, HALMAC_MUTEX *pMutex)
+{
+	_exit_critical_mutex(pMutex, NULL);
+	return _TRUE;
+}
+
+static u8 _halmac_msg_print(void *p, u32 msg_type, u8 msg_level, s8 *fmt, ...)
+{
+#define MSG_LEN		100
+	va_list args;
+	u8 str[MSG_LEN] = {0};
+	int err;
+	u8 ret = _TRUE;
+
+
+	str[0] = '\n';
+	va_start(args, fmt);
+	err = vsnprintf(str, MSG_LEN, fmt, args);
+	va_end(args);
+
+	/* An output error is encountered */
+	if (err < 0)
+		return _FALSE;
+	/* Output may be truncated due to size limit */
+	if ((err == (MSG_LEN - 1)) && (str[MSG_LEN - 2] != '\n'))
+		ret = _FALSE;
+
+	if (msg_level == HALMAC_DBG_ALWAYS)
+		RTW_PRINT(MSG_PREFIX "%s", str);
+	else if (msg_level <= HALMAC_DBG_ERR)
+		RTW_ERR(MSG_PREFIX "%s", str);
+	else if (msg_level <= HALMAC_DBG_WARN)
+		RTW_WARN(MSG_PREFIX "%s", str);
+	else
+		RTW_DBG(MSG_PREFIX "%s", str);
+
+	return ret;
+}
+
+static u8 _halmac_buff_print(void *p, u32 msg_type, u8 msg_level, s8 *buf, u32 size)
+{
+	if (msg_level <= HALMAC_DBG_WARN)
+		RTW_INFO_DUMP(MSG_PREFIX, buf, size);
+	else
+		RTW_DBG_DUMP(MSG_PREFIX, buf, size);
+
+	return _TRUE;
+}
+
+
+const char *const RTW_HALMAC_FEATURE_NAME[] = {
+	"HALMAC_FEATURE_CFG_PARA",
+	"HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE",
+	"HALMAC_FEATURE_DUMP_LOGICAL_EFUSE",
+	"HALMAC_FEATURE_UPDATE_PACKET",
+	"HALMAC_FEATURE_UPDATE_DATAPACK",
+	"HALMAC_FEATURE_RUN_DATAPACK",
+	"HALMAC_FEATURE_CHANNEL_SWITCH",
+	"HALMAC_FEATURE_IQK",
+	"HALMAC_FEATURE_POWER_TRACKING",
+	"HALMAC_FEATURE_PSD",
+	"HALMAC_FEATURE_FW_SNDING",
+	"HALMAC_FEATURE_ALL"
+};
+
+static inline u8 is_valid_id_status(enum halmac_feature_id id, enum halmac_cmd_process_status status)
+{
+	switch (id) {
+	case HALMAC_FEATURE_CFG_PARA:
+		RTW_DBG("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		if (HALMAC_CMD_PROCESS_DONE != status)
+			RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
+				 __FUNCTION__, id, status);
+		break;
+	case HALMAC_FEATURE_DUMP_LOGICAL_EFUSE:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		if (HALMAC_CMD_PROCESS_DONE != status)
+			RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
+				 __FUNCTION__, id, status);
+		break;
+	case HALMAC_FEATURE_UPDATE_PACKET:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_UPDATE_DATAPACK:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_RUN_DATAPACK:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_CHANNEL_SWITCH:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_IQK:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_POWER_TRACKING:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_PSD:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_FW_SNDING:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	case HALMAC_FEATURE_ALL:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
+	default:
+		RTW_ERR("%s: unknown feature id(%d)\n", __FUNCTION__, id);
+		return _FALSE;
+	}
+
+	return _TRUE;
+}
+
+static int init_halmac_event_with_waittime(struct dvobj_priv *d, enum halmac_feature_id id, u8 *buf, u32 size, u32 time)
+{
+	struct submit_ctx *sctx;
+
+
+	if (!d->hmpriv.indicator[id].sctx) {
+		sctx = (struct submit_ctx *)rtw_zmalloc(sizeof(*sctx));
+		if (!sctx)
+			return -1;
+	} else {
+		RTW_WARN("%s: id(%d) sctx is not NULL!!\n", __FUNCTION__, id);
+		sctx = d->hmpriv.indicator[id].sctx;
+		d->hmpriv.indicator[id].sctx = NULL;
+	}
+
+	rtw_sctx_init(sctx, time);
+	d->hmpriv.indicator[id].buffer = buf;
+	d->hmpriv.indicator[id].buf_size = size;
+	d->hmpriv.indicator[id].ret_size = 0;
+	d->hmpriv.indicator[id].status = 0;
+	/* fill sctx at least to sure other variables are all ready! */
+	d->hmpriv.indicator[id].sctx = sctx;
+
+	return 0;
+}
+
+static inline int init_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id, u8 *buf, u32 size)
+{
+	return init_halmac_event_with_waittime(d, id, buf, size, DEFAULT_INDICATOR_TIMELMT);
+}
+
+static void free_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id)
+{
+	struct submit_ctx *sctx;
+
+
+	if (!d->hmpriv.indicator[id].sctx)
+		return;
+
+	sctx = d->hmpriv.indicator[id].sctx;
+	d->hmpriv.indicator[id].sctx = NULL;
+	rtw_mfree((u8 *)sctx, sizeof(*sctx));
+}
+
+static int wait_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	struct submit_ctx *sctx;
+	int ret;
+
+
+	sctx = d->hmpriv.indicator[id].sctx;
+	if (!sctx)
+		return -1;
+
+	ret = rtw_sctx_wait(sctx, RTW_HALMAC_FEATURE_NAME[id]);
+	free_halmac_event(d, id);
+	if (_SUCCESS == ret)
+		return 0;
+
+	/* timeout! We have to reset halmac state */
+	RTW_ERR("%s: Wait id(%d, %s) TIMEOUT! Reset HALMAC state!\n",
+		__FUNCTION__, id, RTW_HALMAC_FEATURE_NAME[id]);
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+	api->halmac_reset_feature(mac, id);
+
+	return -1;
+}
+
+/*
+ * Return:
+ *	Always return _TRUE, HALMAC don't care the return value.
+ */
+static u8 _halmac_event_indication(void *p, enum halmac_feature_id feature_id, enum halmac_cmd_process_status process_status, u8 *buf, u32 size)
+{
+	struct dvobj_priv *d;
+	PADAPTER adapter;
+	PHAL_DATA_TYPE hal;
+	struct halmac_indicator *tbl, *indicator;
+	struct submit_ctx *sctx;
+	u32 cpsz;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+	adapter = dvobj_get_primary_adapter(d);
+	hal = GET_HAL_DATA(adapter);
+	tbl = d->hmpriv.indicator;
+
+	/* Filter(Skip) middle status indication */
+	ret = is_valid_id_status(feature_id, process_status);
+	if (_FALSE == ret)
+		goto exit;
+
+	indicator = &tbl[feature_id];
+	indicator->status = process_status;
+	indicator->ret_size = size;
+	if (!indicator->sctx) {
+		RTW_WARN("%s: No feature id(%d, %s) waiting!!\n", __FUNCTION__, feature_id, RTW_HALMAC_FEATURE_NAME[feature_id]);
+		goto exit;
+	}
+	sctx = indicator->sctx;
+
+	if (HALMAC_CMD_PROCESS_ERROR == process_status) {
+		RTW_ERR("%s: Something wrong id(%d, %s)!!\n", __FUNCTION__, feature_id, RTW_HALMAC_FEATURE_NAME[feature_id]);
+		rtw_sctx_done_err(&sctx, RTW_SCTX_DONE_UNKNOWN);
+		goto exit;
+	}
+
+	if (size > indicator->buf_size) {
+		RTW_WARN("%s: id(%d, %s) buffer is not enough(%d<%d), data will be truncated!\n",
+			 __FUNCTION__, feature_id, RTW_HALMAC_FEATURE_NAME[feature_id], indicator->buf_size, size);
+		cpsz = indicator->buf_size;
+	} else {
+		cpsz = size;
+	}
+	if (cpsz && indicator->buffer)
+		_rtw_memcpy(indicator->buffer, buf, cpsz);
+
+	rtw_sctx_done(&sctx);
+
+exit:
+	return _TRUE;
+}
+
+struct halmac_platform_api rtw_halmac_platform_api = {
+	/* R/W register */
+#ifdef CONFIG_SDIO_HCI
+	.SDIO_CMD52_READ = _halmac_sdio_cmd52_read,
+	.SDIO_CMD53_READ_8 = _halmac_sdio_reg_read_8,
+	.SDIO_CMD53_READ_16 = _halmac_sdio_reg_read_16,
+	.SDIO_CMD53_READ_32 = _halmac_sdio_reg_read_32,
+	.SDIO_CMD53_READ_N = _halmac_sdio_reg_read_n,
+	.SDIO_CMD52_WRITE = _halmac_sdio_cmd52_write,
+	.SDIO_CMD53_WRITE_8 = _halmac_sdio_reg_write_8,
+	.SDIO_CMD53_WRITE_16 = _halmac_sdio_reg_write_16,
+	.SDIO_CMD53_WRITE_32 = _halmac_sdio_reg_write_32,
+	.SDIO_CMD52_CIA_READ = _halmac_sdio_read_cia,
+#endif /* CONFIG_SDIO_HCI */
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCIE_HCI)
+	.REG_READ_8 = _halmac_reg_read_8,
+	.REG_READ_16 = _halmac_reg_read_16,
+	.REG_READ_32 = _halmac_reg_read_32,
+	.REG_WRITE_8 = _halmac_reg_write_8,
+	.REG_WRITE_16 = _halmac_reg_write_16,
+	.REG_WRITE_32 = _halmac_reg_write_32,
+#endif /* CONFIG_USB_HCI || CONFIG_PCIE_HCI */
+
+	/* Write data */
+#if 0
+	/* impletement in HAL-IC level */
+	.SEND_RSVD_PAGE = sdio_write_data_rsvd_page,
+	.SEND_H2C_PKT = sdio_write_data_h2c,
+#endif
+	/* Memory allocate */
+	.RTL_FREE = _halmac_mfree,
+	.RTL_MALLOC = _halmac_malloc,
+	.RTL_MEMCPY = _halmac_memcpy,
+	.RTL_MEMSET = _halmac_memset,
+
+	/* Sleep */
+	.RTL_DELAY_US = _halmac_udelay,
+
+	/* Process Synchronization */
+	.MUTEX_INIT = _halmac_mutex_init,
+	.MUTEX_DEINIT = _halmac_mutex_deinit,
+	.MUTEX_LOCK = _halmac_mutex_lock,
+	.MUTEX_UNLOCK = _halmac_mutex_unlock,
+
+	.MSG_PRINT = _halmac_msg_print,
+	.BUFF_PRINT = _halmac_buff_print,
+	.EVENT_INDICATION = _halmac_event_indication,
+};
+
+u8 rtw_halmac_read8(struct intf_hdl *pintfhdl, u32 addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	return api->halmac_reg_read_8(mac, addr);
+}
+
+u16 rtw_halmac_read16(struct intf_hdl *pintfhdl, u32 addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	return api->halmac_reg_read_16(mac, addr);
+}
+
+u32 rtw_halmac_read32(struct intf_hdl *pintfhdl, u32 addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	return api->halmac_reg_read_32(mac, addr);
+}
+
+static void _read_register(struct dvobj_priv *d, u32 addr, u32 cnt, u8 *buf)
+{
+#if 1
+	struct _ADAPTER *a;
+	u32 i, n;
+	u16 val16;
+	u32 val32;
+
+
+	a = dvobj_get_primary_adapter(d);
+
+	i = addr & 0x3;
+	/* Handle address not start from 4 bytes alignment case */
+	if (i) {
+		val32 = cpu_to_le32(rtw_read32(a, addr & ~0x3));
+		n = 4 - i;
+		_rtw_memcpy(buf, ((u8 *)&val32) + i, n);
+		i = n;
+		cnt -= n;
+	}
+
+	while (cnt) {
+		if (cnt >= 4)
+			n = 4;
+		else if (cnt >= 2)
+			n = 2;
+		else
+			n = 1;
+		cnt -= n;
+
+		switch (n) {
+		case 1:
+			buf[i] = rtw_read8(a, addr+i);
+			i++;
+			break;
+		case 2:
+			val16 = cpu_to_le16(rtw_read16(a, addr+i));
+			_rtw_memcpy(&buf[i], &val16, 2);
+			i += 2;
+			break;
+		case 4:
+			val32 = cpu_to_le32(rtw_read32(a, addr+i));
+			_rtw_memcpy(&buf[i], &val32, 4);
+			i += 4;
+			break;
+		}
+	}
+#else
+	struct _ADAPTER *a;
+	u32 i;
+
+
+	a = dvobj_get_primary_adapter(d);
+	for (i = 0; i < cnt; i++)
+		buf[i] = rtw_read8(a, addr + i);
+#endif
+}
+
+#ifdef CONFIG_SDIO_HCI
+static int _sdio_read_local(struct dvobj_priv *d, u32 addr, u32 cnt, u8 *buf)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	if (buf == NULL)
+		return -1;
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_reg_sdio_cmd53_read_n(mac, addr, cnt, buf);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_ERR("%s: addr=0x%08x cnt=%d err=%d\n",
+			__FUNCTION__, addr, cnt, status);
+		return -1;
+	}
+
+	return 0;
+}
+#endif /* CONFIG_SDIO_HCI */
+
+void rtw_halmac_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem)
+{
+	struct dvobj_priv *d;
+
+
+	if (pmem == NULL) {
+		RTW_ERR("pmem is NULL\n");
+		return;
+	}
+
+	d = pintfhdl->pintf_dev;
+
+#ifdef CONFIG_SDIO_HCI
+	if (addr & 0xFFFF0000) {
+		int err = 0;
+
+		err = _sdio_read_local(d, addr, cnt, pmem);
+		if (!err)
+			return;
+	}
+#endif /* CONFIG_SDIO_HCI */
+
+	_read_register(d, addr, cnt, pmem);
+}
+
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+u8 rtw_halmac_iread8(struct intf_hdl *pintfhdl, u32 addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	/*return api->halmac_reg_read_indirect_8(mac, addr);*/
+	return api->halmac_reg_read_8(mac, addr);
+}
+
+u16 rtw_halmac_iread16(struct intf_hdl *pintfhdl, u32 addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	u16 val16 = 0;
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	/*return api->halmac_reg_read_indirect_16(mac, addr);*/
+	return api->halmac_reg_read_16(mac, addr);
+}
+
+u32 rtw_halmac_iread32(struct intf_hdl *pintfhdl, u32 addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	return api->halmac_reg_read_indirect_32(mac, addr);
+}
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+
+int rtw_halmac_write8(struct intf_hdl *pintfhdl, u32 addr, u8 value)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_reg_write_8(mac, addr, value);
+
+	if (status == HALMAC_RET_SUCCESS)
+		return 0;
+
+	return -1;
+}
+
+int rtw_halmac_write16(struct intf_hdl *pintfhdl, u32 addr, u16 value)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_reg_write_16(mac, addr, value);
+
+	if (status == HALMAC_RET_SUCCESS)
+		return 0;
+
+	return -1;
+}
+
+int rtw_halmac_write32(struct intf_hdl *pintfhdl, u32 addr, u32 value)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	/* WARNING: pintf_dev should not be null! */
+	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_reg_write_32(mac, addr, value);
+
+	if (status == HALMAC_RET_SUCCESS)
+		return 0;
+
+	return -1;
+}
+
+static int init_write_rsvd_page_size(struct dvobj_priv *d)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	u32 size = 0;
+	struct halmac_ofld_func_info ofld_info;
+	enum halmac_ret_status status;
+	int err = 0;
+
+
+#ifdef CONFIG_USB_HCI
+	/* for USB do not exceed MAX_CMDBUF_SZ */
+	size = 0x1000;
+#elif defined(CONFIG_PCIE_HCI)
+	size = MAX_CMDBUF_SZ - TXDESC_OFFSET;
+#elif defined(CONFIG_SDIO_HCI)
+	size = 0x7000; /* 28KB */
+#endif
+
+	/* If size==0, use HALMAC default setting and don't call any function */
+	if (!size)
+		return 0;
+
+	err = rtw_halmac_set_max_dl_fw_size(d, size);
+	if (err) {
+		RTW_ERR("%s: Fail to set max download fw size!\n", __FUNCTION__);
+		return -1;
+	}
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	_rtw_memset(&ofld_info, 0, sizeof(ofld_info));
+	ofld_info.halmac_malloc_max_sz = 0xFFFFFFFF;
+	ofld_info.rsvd_pg_drv_buf_max_sz = size;
+	status = api->halmac_ofld_func_cfg(mac, &ofld_info);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_ERR("%s: Fail to config offload parameters!\n", __FUNCTION__);
+		return -1;
+	}
+
+	return 0;
+}
+
+static int init_priv(struct halmacpriv *priv)
+{
+	struct halmac_indicator *indicator;
+	u32 count, size;
+
+
+	if (priv->indicator)
+		RTW_WARN("%s: HALMAC private data is not CLEAR!\n", __FUNCTION__);
+	count = HALMAC_FEATURE_ALL + 1;
+	size = sizeof(*indicator) * count;
+	indicator = (struct halmac_indicator *)rtw_zmalloc(size);
+	if (!indicator)
+		return -1;
+	priv->indicator = indicator;
+
+	return 0;
+}
+
+static void deinit_priv(struct halmacpriv *priv)
+{
+	struct halmac_indicator *indicator;
+
+
+	indicator = priv->indicator;
+	priv->indicator = NULL;
+	if (indicator) {
+		u32 count, size;
+
+		count = HALMAC_FEATURE_ALL + 1;
+#ifdef CONFIG_RTW_DEBUG
+		{
+			struct submit_ctx *sctx;
+			u32 i;
+
+			for (i = 0; i < count; i++) {
+				if (!indicator[i].sctx)
+					continue;
+
+				RTW_WARN("%s: %s id(%d) sctx still exist!!\n",
+					__FUNCTION__, RTW_HALMAC_FEATURE_NAME[i], i);
+				sctx = indicator[i].sctx;
+				indicator[i].sctx = NULL;
+				rtw_mfree((u8 *)sctx, sizeof(*sctx));
+			}
+		}
+#endif /* !CONFIG_RTW_DEBUG */
+		size = sizeof(*indicator) * count;
+		rtw_mfree((u8 *)indicator, size);
+	}
+}
+
+#ifdef CONFIG_SDIO_HCI
+static enum halmac_sdio_spec_ver _sdio_ver_drv2halmac(struct dvobj_priv *d)
+{
+	bool v3;
+	enum halmac_sdio_spec_ver ver;
+
+
+	v3 = rtw_is_sdio30(dvobj_get_primary_adapter(d));
+	if (v3)
+		ver = HALMAC_SDIO_SPEC_VER_3_00;
+	else
+		ver = HALMAC_SDIO_SPEC_VER_2_00;
+
+	return ver;
+}
+#endif /* CONFIG_SDIO_HCI */
+
+void rtw_halmac_get_version(char *str, u32 len)
+{
+	enum halmac_ret_status status;
+	struct halmac_ver ver;
+
+
+	status = halmac_get_version(&ver);
+	if (status != HALMAC_RET_SUCCESS)
+		return;
+
+	rtw_sprintf(str, len, "V%d_%02d_%02d",
+		    ver.major_ver, ver.prototype_ver, ver.minor_ver);
+}
+
+int rtw_halmac_init_adapter(struct dvobj_priv *d, struct halmac_platform_api *pf_api)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_interface intf;
+	enum halmac_ret_status status;
+	int err = 0;
+#ifdef CONFIG_SDIO_HCI
+	struct halmac_sdio_hw_info info;
+#endif /* CONFIG_SDIO_HCI */
+
+
+	halmac = dvobj_to_halmac(d);
+	if (halmac) {
+		RTW_WARN("%s: initialize already completed!\n", __FUNCTION__);
+		goto error;
+	}
+
+	err = init_priv(&d->hmpriv);
+	if (err)
+		goto error;
+
+#ifdef CONFIG_SDIO_HCI
+	intf = HALMAC_INTERFACE_SDIO;
+#elif defined(CONFIG_USB_HCI)
+	intf = HALMAC_INTERFACE_USB;
+#elif defined(CONFIG_PCIE_HCI)
+	intf = HALMAC_INTERFACE_PCIE;
+#else
+#warning "INTERFACE(CONFIG_XXX_HCI) not be defined!!"
+	intf = HALMAC_INTERFACE_UNDEFINE;
+#endif
+	status = halmac_init_adapter(d, pf_api, intf, &halmac, &api);
+	if (HALMAC_RET_SUCCESS != status) {
+		RTW_ERR("%s: halmac_init_adapter fail!(status=%d)\n", __FUNCTION__, status);
+		err = -1;
+		if (halmac)
+			goto deinit;
+		goto free;
+	}
+
+	dvobj_set_halmac(d, halmac);
+
+	status = api->halmac_interface_integration_tuning(halmac);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_ERR("%s: halmac_interface_integration_tuning fail!(status=%d)\n", __FUNCTION__, status);
+		err = -1;
+		goto deinit;
+	}
+
+	status = api->halmac_phy_cfg(halmac, HALMAC_INTF_PHY_PLATFORM_ALL);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_ERR("%s: halmac_phy_cfg fail!(status=%d)\n", __FUNCTION__, status);
+		err = -1;
+		goto deinit;
+	}
+
+	init_write_rsvd_page_size(d);
+
+#ifdef CONFIG_SDIO_HCI
+	_rtw_memset(&info, 0, sizeof(info));
+	info.spec_ver = _sdio_ver_drv2halmac(d);
+	/* Convert clock speed unit to MHz from Hz */
+	info.clock_speed = RTW_DIV_ROUND_UP(rtw_sdio_get_clock(d), 1000000);
+	info.block_size = rtw_sdio_get_block_size(d);
+	RTW_DBG("%s: SDIO ver=%u clock=%uMHz blk_size=%u bytes\n",
+		__FUNCTION__, info.spec_ver+2, info.clock_speed,
+		info.block_size);
+	status = api->halmac_sdio_hw_info(halmac, &info);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_ERR("%s: halmac_sdio_hw_info fail!(status=%d)\n",
+			__FUNCTION__, status);
+		err = -1;
+		goto deinit;
+	}
+#endif /* CONFIG_SDIO_HCI */
+
+	return 0;
+
+deinit:
+	status = halmac_deinit_adapter(halmac);
+	dvobj_set_halmac(d, NULL);
+	if (status != HALMAC_RET_SUCCESS)
+		RTW_ERR("%s: halmac_deinit_adapter fail!(status=%d)\n",
+			__FUNCTION__, status);
+
+free:
+	deinit_priv(&d->hmpriv);
+
+error:
+	return err;
+}
+
+int rtw_halmac_deinit_adapter(struct dvobj_priv *d)
+{
+	struct halmac_adapter *halmac;
+	enum halmac_ret_status status;
+	int err = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	if (halmac) {
+		status = halmac_deinit_adapter(halmac);
+		dvobj_set_halmac(d, NULL);
+		if (status != HALMAC_RET_SUCCESS)
+			err = -1;
+	}
+
+	deinit_priv(&d->hmpriv);
+
+	return err;
+}
+
+static inline enum halmac_portid _hw_port_drv2halmac(enum _hw_port hwport)
+{
+	enum halmac_portid port = HALMAC_PORTID_NUM;
+
+
+	switch (hwport) {
+	case HW_PORT0:
+		port = HALMAC_PORTID0;
+		break;
+	case HW_PORT1:
+		port = HALMAC_PORTID1;
+		break;
+	case HW_PORT2:
+		port = HALMAC_PORTID2;
+		break;
+	case HW_PORT3:
+		port = HALMAC_PORTID3;
+		break;
+	case HW_PORT4:
+		port = HALMAC_PORTID4;
+		break;
+	default:
+		break;
+	}
+
+	return port;
+}
+
+static enum halmac_network_type_select _network_type_drv2halmac(u8 type)
+{
+	enum halmac_network_type_select network = HALMAC_NETWORK_UNDEFINE;
+
+
+	switch (type) {
+	case _HW_STATE_NOLINK_:
+	case _HW_STATE_MONITOR_:
+		network = HALMAC_NETWORK_NO_LINK;
+		break;
+
+	case _HW_STATE_ADHOC_:
+		network = HALMAC_NETWORK_ADHOC;
+		break;
+
+	case _HW_STATE_STATION_:
+		network = HALMAC_NETWORK_INFRASTRUCTURE;
+		break;
+
+	case _HW_STATE_AP_:
+		network = HALMAC_NETWORK_AP;
+		break;
+	}
+
+	return network;
+}
+
+static u8 _network_type_halmac2drv(enum halmac_network_type_select network)
+{
+	u8 type = _HW_STATE_NOLINK_;
+
+
+	switch (network) {
+	case HALMAC_NETWORK_NO_LINK:
+	case HALMAC_NETWORK_UNDEFINE:
+		type = _HW_STATE_NOLINK_;
+		break;
+
+	case HALMAC_NETWORK_ADHOC:
+		type = _HW_STATE_ADHOC_;
+		break;
+
+	case HALMAC_NETWORK_INFRASTRUCTURE:
+		type = _HW_STATE_STATION_;
+		break;
+
+	case HALMAC_NETWORK_AP:
+		type = _HW_STATE_AP_;
+		break;
+	}
+
+	return type;
+}
+
+static void _beacon_ctrl_halmac2drv(struct halmac_bcn_ctrl *ctrl,
+				struct rtw_halmac_bcn_ctrl *drv_ctrl)
+{
+	drv_ctrl->rx_bssid_fit = ctrl->dis_rx_bssid_fit ? 0 : 1;
+	drv_ctrl->txbcn_rpt = ctrl->en_txbcn_rpt ? 1 : 0;
+	drv_ctrl->tsf_update = ctrl->dis_tsf_udt ? 0 : 1;
+	drv_ctrl->enable_bcn = ctrl->en_bcn ? 1 : 0;
+	drv_ctrl->rxbcn_rpt = ctrl->en_rxbcn_rpt ? 1 : 0;
+	drv_ctrl->p2p_ctwin = ctrl->en_p2p_ctwin ? 1 : 0;
+	drv_ctrl->p2p_bcn_area = ctrl->en_p2p_bcn_area ? 1 : 0;
+}
+
+static void _beacon_ctrl_drv2halmac(struct rtw_halmac_bcn_ctrl *drv_ctrl,
+				struct halmac_bcn_ctrl *ctrl)
+{
+	ctrl->dis_rx_bssid_fit = drv_ctrl->rx_bssid_fit ? 0 : 1;
+	ctrl->en_txbcn_rpt = drv_ctrl->txbcn_rpt ? 1 : 0;
+	ctrl->dis_tsf_udt = drv_ctrl->tsf_update ? 0 : 1;
+	ctrl->en_bcn = drv_ctrl->enable_bcn ? 1 : 0;
+	ctrl->en_rxbcn_rpt = drv_ctrl->rxbcn_rpt ? 1 : 0;
+	ctrl->en_p2p_ctwin = drv_ctrl->p2p_ctwin ? 1 : 0;
+	ctrl->en_p2p_bcn_area = drv_ctrl->p2p_bcn_area ? 1 : 0;
+}
+
+int rtw_halmac_get_hw_value(struct dvobj_priv *d, enum halmac_hw_id hw_id, void *pvalue)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_get_hw_value(mac, hw_id, pvalue);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_tx_fifo_size() - TX FIFO size
+ * @d:		struct dvobj_priv*
+ * @size:	TX FIFO size, unit is byte.
+ *
+ * Get TX FIFO size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_tx_fifo_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_TXFIFO_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_rx_fifo_size() - RX FIFO size
+ * @d:		struct dvobj_priv*
+ * @size:	RX FIFO size, unit is byte
+ *
+ * Get RX FIFO size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_rx_fifo_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_RXFIFO_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_rsvd_drv_pg_bndy() - Reserve page boundary of driver
+ * @d:		struct dvobj_priv*
+ * @size:	Page size, unit is byte
+ *
+ * Get reserve page boundary of driver from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *d, u16 *bndy)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u16 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_RSVD_PG_BNDY, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*bndy = val;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_page_size() - Page size
+ * @d:		struct dvobj_priv*
+ * @size:	Page size, unit is byte
+ *
+ * Get TX/RX page size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_page_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_PAGE_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_tx_agg_align_size() - TX aggregation align size
+ * @d:		struct dvobj_priv*
+ * @size:	TX aggregation align size, unit is byte
+ *
+ * Get TX aggregation align size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_tx_agg_align_size(struct dvobj_priv *d, u16 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u16 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_TX_AGG_ALIGN_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_rx_agg_align_size() - RX aggregation align size
+ * @d:		struct dvobj_priv*
+ * @size:	RX aggregation align size, unit is byte
+ *
+ * Get RX aggregation align size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_rx_agg_align_size(struct dvobj_priv *d, u8 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u8 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_RX_AGG_ALIGN_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+/*
+ * Description:
+ *	Get RX driver info size. RX driver info is a small memory space between
+ *	scriptor and RX payload.
+ *
+ *	+-------------------------+
+ *	| RX descriptor           |
+ *	| usually 24 bytes        |
+ *	+-------------------------+
+ *	| RX driver info          |
+ *	| depends on driver cfg   |
+ *	+-------------------------+
+ *	| RX paylad               |
+ *	|                         |
+ *	+-------------------------+
+ *
+ * Parameter:
+ *	d	pointer to struct dvobj_priv of driver
+ *	sz	rx driver info size in bytes.
+ *
+ * Rteurn:
+ *	0	Success
+ *	other	Fail
+ */
+int rtw_halmac_get_rx_drv_info_sz(struct dvobj_priv *d, u8 *sz)
+{
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac = dvobj_to_halmac(d);
+	struct halmac_api *api = HALMAC_GET_API(halmac);
+	u8 dw = 0;
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_DRV_INFO_SIZE, &dw);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*sz = dw * 8;
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_tx_desc_size() - TX descriptor size
+ * @d:		struct dvobj_priv*
+ * @size:	TX descriptor size, unit is byte.
+ *
+ * Get TX descriptor size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_tx_desc_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_TX_DESC_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_rx_desc_size() - RX descriptor size
+ * @d:		struct dvobj_priv*
+ * @size:	RX descriptor size, unit is byte.
+ *
+ * Get RX descriptor size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_rx_desc_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_RX_DESC_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+
+/**
+ * rtw_halmac_get_fw_max_size() - Firmware MAX size
+ * @d:		struct dvobj_priv*
+ * @size:	MAX Firmware size, unit is byte.
+ *
+ * Get Firmware MAX size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+static int rtw_halmac_get_fw_max_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_FW_MAX_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_ori_h2c_size() - Original H2C MAX size
+ * @d:		struct dvobj_priv*
+ * @size:	H2C MAX size, unit is byte.
+ *
+ * Get original H2C MAX size(byte) from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_ori_h2c_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_ORI_H2C_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+
+	return 0;
+}
+
+int rtw_halmac_get_oqt_size(struct dvobj_priv *d, u8 *size)
+{
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	u8 val;
+
+
+	if (!size)
+		return -1;
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_AC_OQT_SIZE, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*size = val;
+	return 0;
+}
+
+int rtw_halmac_get_ac_queue_number(struct dvobj_priv *d, u8 *num)
+{
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	u8 val;
+
+
+	if (!num)
+		return -1;
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_AC_QUEUE_NUM, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*num = val;
+	return 0;
+}
+
+/**
+ * rtw_halmac_get_mac_address() - Get MAC address of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @addr:	buffer for storing MAC address
+ *
+ * Get MAC address of specific port from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	if (!addr)
+		goto out;
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+	_rtw_memset(&hwa, 0, sizeof(hwa));
+
+	status = api->halmac_get_mac_addr(halmac, port, &hwa);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	_rtw_memcpy(addr, hwa.addr, 6);
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_get_network_type() - Get network type of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @type:	buffer to put network type (_HW_STATE_*)
+ *
+ * Get network type of specific port from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 *type)
+{
+#if 0
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_network_type_select network;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+	network = HALMAC_NETWORK_UNDEFINE;
+
+	status = api->halmac_get_net_type(halmac, port, &network);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	*type = _network_type_halmac2drv(network);
+
+	err = 0;
+out:
+	return err;
+#else
+	struct _ADAPTER *a;
+	enum halmac_portid port;
+	enum halmac_network_type_select network;
+	u32 val;
+	int err = -1;
+
+
+	a = dvobj_get_primary_adapter(d);
+	port = _hw_port_drv2halmac(hwport);
+	network = HALMAC_NETWORK_UNDEFINE;
+
+	switch (port) {
+	case HALMAC_PORTID0:
+		val = rtw_read32(a, REG_CR);
+		network = BIT_GET_NETYPE0(val);
+		break;
+
+	case HALMAC_PORTID1:
+		val = rtw_read32(a, REG_CR);
+		network = BIT_GET_NETYPE1(val);
+		break;
+
+	case HALMAC_PORTID2:
+		val = rtw_read32(a, REG_CR_EXT);
+		network = BIT_GET_NETYPE2(val);
+		break;
+
+	case HALMAC_PORTID3:
+		val = rtw_read32(a, REG_CR_EXT);
+		network = BIT_GET_NETYPE3(val);
+		break;
+
+	case HALMAC_PORTID4:
+		val = rtw_read32(a, REG_CR_EXT);
+		network = BIT_GET_NETYPE4(val);
+		break;
+
+	default:
+		goto out;
+	}
+
+	*type = _network_type_halmac2drv(network);
+
+	err = 0;
+out:
+	return err;
+#endif
+}
+
+/**
+ * rtw_halmac_get_bcn_ctrl() - Get beacon control setting of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @bcn_ctrl:	setting of beacon control
+ *
+ * Get beacon control setting of specific port from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
+			struct rtw_halmac_bcn_ctrl *bcn_ctrl)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	struct halmac_bcn_ctrl ctrl;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+	_rtw_memset(&ctrl, 0, sizeof(ctrl));
+
+	status = api->halmac_rw_bcn_ctrl(halmac, port, 0, &ctrl);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+	_beacon_ctrl_halmac2drv(&ctrl, bcn_ctrl);
+
+	err = 0;
+out:
+	return err;
+}
+
+/*
+ * Note:
+ *	When this function return, the register REG_RCR may be changed.
+ */
+int rtw_halmac_config_rx_info(struct dvobj_priv *d, enum halmac_drv_info info)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_cfg_drv_info(halmac, info);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_set_max_dl_fw_size() - Set the MAX download firmware size
+ * @d:		struct dvobj_priv*
+ * @size:	the max download firmware size in one I/O
+ *
+ * Set the max download firmware size in one I/O.
+ * Please also consider the max size of the callback function "SEND_RSVD_PAGE"
+ * could accept, because download firmware would call "SEND_RSVD_PAGE" to send
+ * firmware to IC.
+ *
+ * If the value of "size" is not even, it would be rounded down to nearest
+ * even, and 0 and 1 are both invalid value.
+ *
+ * Return 0 for setting OK, otherwise fail.
+ */
+int rtw_halmac_set_max_dl_fw_size(struct dvobj_priv *d, u32 size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	if (!size || (size == 1))
+		return -1;
+
+	mac = dvobj_to_halmac(d);
+	if (!mac) {
+		RTW_ERR("%s: HALMAC is not ready!!\n", __FUNCTION__);
+		return -1;
+	}
+	api = HALMAC_GET_API(mac);
+
+	size &= ~1; /* round down to even */
+	status = api->halmac_cfg_max_dl_size(mac, size);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_WARN("%s: Fail to cfg_max_dl_size(%d), err=%d!!\n",
+			 __FUNCTION__, size, status);
+		return -1;
+	}
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_set_mac_address() - Set mac address of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @addr:	mac address
+ *
+ * Set self mac address of specific port to HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	port = _hw_port_drv2halmac(hwport);
+	_rtw_memset(&hwa, 0, sizeof(hwa));
+	_rtw_memcpy(hwa.addr, addr, 6);
+
+	status = api->halmac_cfg_mac_addr(halmac, port, &hwa);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_set_bssid() - Set BSSID of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @addr:	BSSID, mac address of AP
+ *
+ * Set BSSID of specific port to HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_set_bssid(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+
+	_rtw_memset(&hwa, 0, sizeof(hwa));
+	_rtw_memcpy(hwa.addr, addr, 6);
+	status = api->halmac_cfg_bssid(halmac, port, &hwa);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_set_tx_address() - Set transmitter address of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @addr:	transmitter address
+ *
+ * Set transmitter address of specific port to HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_set_tx_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+	_rtw_memset(&hwa, 0, sizeof(hwa));
+	_rtw_memcpy(hwa.addr, addr, 6);
+
+	status = api->halmac_cfg_transmitter_addr(halmac, port, &hwa);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_set_network_type() - Set network type of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @type:	network type (_HW_STATE_*)
+ *
+ * Set network type of specific port to HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_set_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 type)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_network_type_select network;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+	network = _network_type_drv2halmac(type);
+
+	status = api->halmac_cfg_net_type(halmac, port, network);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_reset_tsf() - Reset TSF timer of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ *
+ * Notice HALMAC to reset timing synchronization function(TSF) timer of
+ * specific port.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_reset_tsf(struct dvobj_priv *d, enum _hw_port hwport)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+
+	status = api->halmac_cfg_tsf_rst(halmac, port);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_set_bcn_interval() - Set beacon interval of each port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @space:	beacon interval, unit is ms
+ *
+ * Set beacon interval of specific port to HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_set_bcn_interval(struct dvobj_priv *d, enum _hw_port hwport,
+				u32 interval)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+
+	status = api->halmac_cfg_bcn_space(halmac, port, interval);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_set_bcn_ctrl() - Set beacon control setting of each port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @bcn_ctrl:	setting of beacon control
+ *
+ * Set beacon control setting of specific port to HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_set_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
+			struct rtw_halmac_bcn_ctrl *bcn_ctrl)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	struct halmac_bcn_ctrl ctrl;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+	_rtw_memset(&ctrl, 0, sizeof(ctrl));
+	_beacon_ctrl_drv2halmac(bcn_ctrl, &ctrl);
+
+	status = api->halmac_rw_bcn_ctrl(halmac, port, 1, &ctrl);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/**
+ * rtw_halmac_set_aid() - Set association identifier(AID) of specific port
+ * @d:		struct dvobj_priv*
+ * @hwport:	port
+ * @aid:	Association identifier
+ *
+ * Set association identifier(AID) of specific port to HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_set_aid(struct dvobj_priv *d, enum _hw_port hwport, u16 aid)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	port = _hw_port_drv2halmac(hwport);
+
+#if 0
+	status = api->halmac_cfg_aid(halmac, port, aid);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+#else
+{
+	struct _ADAPTER *a;
+	u32 addr;
+	u16 val;
+
+	a = dvobj_get_primary_adapter(d);
+
+	switch (port) {
+	case 0:
+		addr = REG_BCN_PSR_RPT;
+		val = rtw_read16(a, addr);
+		val = BIT_SET_PS_AID_0(val, aid);
+		rtw_write16(a, addr, val);
+		break;
+
+	case 1:
+		addr = REG_BCN_PSR_RPT1;
+		val = rtw_read16(a, addr);
+		val = BIT_SET_PS_AID_1(val, aid);
+		rtw_write16(a, addr, val);
+		break;
+
+	case 2:
+		addr = REG_BCN_PSR_RPT2;
+		val = rtw_read16(a, addr);
+		val = BIT_SET_PS_AID_2(val, aid);
+		rtw_write16(a, addr, val);
+		break;
+
+	case 3:
+		addr = REG_BCN_PSR_RPT3;
+		val = rtw_read16(a, addr);
+		val = BIT_SET_PS_AID_3(val, aid);
+		rtw_write16(a, addr, val);
+		break;
+
+	case 4:
+		addr = REG_BCN_PSR_RPT4;
+		val = rtw_read16(a, addr);
+		val = BIT_SET_PS_AID_4(val, aid);
+		rtw_write16(a, addr, val);
+		break;
+
+	default:
+		goto out;
+	}
+}
+#endif
+
+	err = 0;
+out:
+	return err;
+}
+
+int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8 bw)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_cfg_ch_bw(mac, channel, pri_ch_idx, bw);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_set_edca() - config edca parameter
+ * @d:		struct dvobj_priv*
+ * @queue:	XMIT_[VO/VI/BE/BK]_QUEUE
+ * @aifs:	Arbitration inter-frame space(AIFS)
+ * @cw:		Contention window(CW)
+ * @txop:	MAX Transmit Opportunity(TXOP)
+ *
+ * Return: 0 if process OK, otherwise -1.
+ */
+int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_acq_id ac;
+	struct halmac_edca_para edca;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	switch (queue) {
+	case XMIT_VO_QUEUE:
+		ac = HALMAC_ACQ_ID_VO;
+		break;
+	case XMIT_VI_QUEUE:
+		ac = HALMAC_ACQ_ID_VI;
+		break;
+	case XMIT_BE_QUEUE:
+		ac = HALMAC_ACQ_ID_BE;
+		break;
+	case XMIT_BK_QUEUE:
+		ac = HALMAC_ACQ_ID_BK;
+		break;
+	default:
+		return -1;
+	}
+
+	edca.aifs = aifs;
+	edca.cw = cw;
+	edca.txop_limit = txop;
+
+	status = api->halmac_cfg_edca_para(mac, ac, &edca);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+/*
+ * Description:
+ *	Power on device hardware.
+ *	[Notice!] If device's power state is on before,
+ *	it would be power off first and turn on power again.
+ *
+ * Return:
+ *	0	power on success
+ *	-1	power on fail
+ *	-2	power state unchange
+ */
+int rtw_halmac_poweron(struct dvobj_priv *d)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	if (!halmac)
+		goto out;
+
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_pre_init_system_cfg(halmac);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+#ifdef CONFIG_SDIO_HCI
+	status = api->halmac_sdio_cmd53_4byte(halmac, HALMAC_SDIO_CMD53_4BYTE_MODE_RW);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+#endif /* CONFIG_SDIO_HCI */
+
+	status = api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_ON);
+	if (HALMAC_RET_PWR_UNCHANGE == status) {
+		/*
+		 * Work around for warm reboot but device not power off,
+		 * but it would also fall into this case when auto power on is enabled.
+		 */
+		api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_OFF);
+		status = api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_ON);
+		RTW_WARN("%s: Power state abnormal, try to recover...%s\n",
+			 __FUNCTION__, (HALMAC_RET_SUCCESS == status)?"OK":"FAIL!");
+	}
+	if (HALMAC_RET_SUCCESS != status) {
+		if (HALMAC_RET_PWR_UNCHANGE == status)
+			err = -2;
+		goto out;
+	}
+
+	status = api->halmac_init_system_cfg(halmac);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+/*
+ * Description:
+ *	Power off device hardware.
+ *
+ * Return:
+ *	0	Power off success
+ *	-1	Power off fail
+ */
+int rtw_halmac_poweroff(struct dvobj_priv *d)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	halmac = dvobj_to_halmac(d);
+	if (!halmac)
+		goto out;
+
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_OFF);
+	if ((HALMAC_RET_SUCCESS != status)
+	    && (HALMAC_RET_PWR_UNCHANGE != status))
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+static inline enum halmac_rx_fifo_expanding_mode _trx_share_mode_drv2halmac(u8 trx_share_mode)
+{
+	if (0 == trx_share_mode)
+		return HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE;
+	else if (1 == trx_share_mode)
+		return HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK;
+	else if (2 == trx_share_mode)
+		return HALMAC_RX_FIFO_EXPANDING_MODE_2_BLOCK;
+	else if (3 == trx_share_mode)
+		return HALMAC_RX_FIFO_EXPANDING_MODE_3_BLOCK;
+	else
+		return HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE;
+}
+
+static enum halmac_rx_fifo_expanding_mode _rtw_get_trx_share_mode(struct _ADAPTER *adapter)
+{
+	struct registry_priv *registry_par = &adapter->registrypriv;
+
+	return _trx_share_mode_drv2halmac(registry_par->trx_share_mode);
+}
+
+void dump_trx_share_mode(void *sel, struct _ADAPTER *adapter)
+{
+	struct registry_priv  *registry_par = &adapter->registrypriv;
+	u8 mode = _trx_share_mode_drv2halmac(registry_par->trx_share_mode);
+
+	if (HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK == mode)
+		RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "RX_FIFO_EXPANDING_MODE_1");
+	else if (HALMAC_RX_FIFO_EXPANDING_MODE_2_BLOCK == mode)
+		RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "RX_FIFO_EXPANDING_MODE_2");
+	else if (HALMAC_RX_FIFO_EXPANDING_MODE_3_BLOCK == mode)
+		RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "RX_FIFO_EXPANDING_MODE_3");
+	else
+		RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "DISABLE");
+}
+#endif
+
+static enum halmac_drv_rsvd_pg_num _rsvd_page_num_drv2halmac(u8 num)
+{
+	if (num <= 8)
+		return HALMAC_RSVD_PG_NUM8;
+	if (num <= 16)
+		return HALMAC_RSVD_PG_NUM16;
+	if (num <= 24)
+		return HALMAC_RSVD_PG_NUM24;
+	if (num <= 32)
+		return HALMAC_RSVD_PG_NUM32;
+	if (num <= 64)
+		return HALMAC_RSVD_PG_NUM64;
+
+	if (num > 128)
+		RTW_WARN("%s: Fail to allocate RSVD page(%d)!!"
+			 " The MAX RSVD page number is 128...\n",
+			 __FUNCTION__, num);
+
+	return HALMAC_RSVD_PG_NUM128;
+}
+
+static u8 _rsvd_page_num_halmac2drv(enum halmac_drv_rsvd_pg_num rsvd_page_number)
+{
+	u8 num = 0;
+
+
+	switch (rsvd_page_number) {
+	case HALMAC_RSVD_PG_NUM8:
+		num = 8;
+		break;
+
+	case HALMAC_RSVD_PG_NUM16:
+		num = 16;
+		break;
+
+	case HALMAC_RSVD_PG_NUM24:
+		num = 24;
+		break;
+
+	case HALMAC_RSVD_PG_NUM32:
+		num = 32;
+		break;
+
+	case HALMAC_RSVD_PG_NUM64:
+		num = 64;
+		break;
+
+	case HALMAC_RSVD_PG_NUM128:
+		num = 128;
+		break;
+	}
+
+	return num;
+}
+
+static enum halmac_trx_mode _choose_trx_mode(struct dvobj_priv *d)
+{
+	PADAPTER p;
+
+
+	p = dvobj_get_primary_adapter(d);
+
+	if (p->registrypriv.wifi_spec)
+		return HALMAC_TRX_MODE_WMM;
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	if (_rtw_get_trx_share_mode(p))
+		return HALMAC_TRX_MODE_TRXSHARE;
+#endif
+
+	return HALMAC_TRX_MODE_NORMAL;
+}
+
+static inline enum halmac_rf_type _rf_type_drv2halmac(enum rf_type rf_drv)
+{
+	enum halmac_rf_type rf_mac;
+
+
+	switch (rf_drv) {
+	case RF_1T1R:
+		rf_mac = HALMAC_RF_1T1R;
+		break;
+	case RF_1T2R:
+		rf_mac = HALMAC_RF_1T2R;
+		break;
+	case RF_2T2R:
+		rf_mac = HALMAC_RF_2T2R;
+		break;
+	case RF_2T3R:
+		rf_mac = HALMAC_RF_2T3R;
+		break;
+	case RF_2T4R:
+		rf_mac = HALMAC_RF_2T4R;
+		break;
+	case RF_3T3R:
+		rf_mac = HALMAC_RF_3T3R;
+		break;
+	case RF_3T4R:
+		rf_mac = HALMAC_RF_3T4R;
+		break;
+	case RF_4T4R:
+		rf_mac = HALMAC_RF_4T4R;
+		break;
+	default:
+		rf_mac = HALMAC_RF_MAX_TYPE;
+		RTW_ERR("%s: Invalid RF type(0x%x)!\n", __FUNCTION__, rf_drv);
+		break;
+	}
+
+	return rf_mac;
+}
+
+static inline enum rf_type _rf_type_halmac2drv(enum halmac_rf_type rf_mac)
+{
+	enum rf_type rf_drv;
+
+
+	switch (rf_mac) {
+	case HALMAC_RF_1T2R:
+		rf_drv = RF_1T2R;
+		break;
+	case HALMAC_RF_2T4R:
+		rf_drv = RF_2T4R;
+		break;
+	case HALMAC_RF_2T2R:
+	case HALMAC_RF_2T2R_GREEN:
+		rf_drv = RF_2T2R;
+		break;
+	case HALMAC_RF_2T3R:
+		rf_drv = RF_2T3R;
+		break;
+	case HALMAC_RF_1T1R:
+		rf_drv = RF_1T1R;
+		break;
+	case HALMAC_RF_3T3R:
+		rf_drv = RF_3T3R;
+		break;
+	case HALMAC_RF_3T4R:
+		rf_drv = RF_3T4R;
+		break;
+	case HALMAC_RF_4T4R:
+		rf_drv = RF_4T4R;
+		break;
+	default:
+		rf_drv = RF_TYPE_MAX;
+		RTW_ERR("%s: Invalid RF type(0x%x)!\n", __FUNCTION__, rf_mac);
+		break;
+	}
+
+	return rf_drv;
+}
+
+static enum odm_cut_version _cut_version_drv2phydm(
+				enum tag_HAL_Cut_Version_Definition cut_drv)
+{
+	enum odm_cut_version cut_phydm = ODM_CUT_A;
+	u32 diff;
+
+
+	if (cut_drv > K_CUT_VERSION)
+		RTW_WARN("%s: unknown cut_ver=%d !!\n", __FUNCTION__, cut_drv);
+
+	diff = cut_drv - A_CUT_VERSION;
+	cut_phydm += diff;
+
+	return cut_phydm;
+}
+
+static int _send_general_info_by_reg(struct dvobj_priv *d,
+				     struct halmac_general_info *info)
+{
+	struct _ADAPTER *a;
+	struct hal_com_data *hal;
+	enum tag_HAL_Cut_Version_Definition cut_drv;
+	enum rf_type rftype;
+	enum odm_cut_version cut_phydm;
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+
+
+	a = dvobj_get_primary_adapter(d);
+	hal = GET_HAL_DATA(a);
+	rftype = _rf_type_halmac2drv(info->rf_type);
+	cut_drv = GET_CVID_CUT_VERSION(hal->version_id);
+	cut_phydm = _cut_version_drv2phydm(cut_drv);
+
+#define CLASS_GENERAL_INFO_REG				0x02
+#define CMD_ID_GENERAL_INFO_REG				0x0C
+#define GENERAL_INFO_REG_SET_CMD_ID(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 0, 5, v)
+#define GENERAL_INFO_REG_SET_CLASS(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 5, 3, v)
+#define GENERAL_INFO_REG_SET_RFE_TYPE(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 8, 8, v)
+#define GENERAL_INFO_REG_SET_RF_TYPE(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 16, 8, v)
+#define GENERAL_INFO_REG_SET_CUT_VERSION(buf, v)	SET_BITS_TO_LE_4BYTE(buf, 24, 8, v)
+#define GENERAL_INFO_REG_SET_RX_ANT_STATUS(buf, v)	SET_BITS_TO_LE_1BYTE(buf+4, 0, 4, v)
+#define GENERAL_INFO_REG_SET_TX_ANT_STATUS(buf, v)	SET_BITS_TO_LE_1BYTE(buf+4, 4, 4, v)
+
+	GENERAL_INFO_REG_SET_CMD_ID(h2c, CMD_ID_GENERAL_INFO_REG);
+	GENERAL_INFO_REG_SET_CLASS(h2c, CLASS_GENERAL_INFO_REG);
+	GENERAL_INFO_REG_SET_RFE_TYPE(h2c, info->rfe_type);
+	GENERAL_INFO_REG_SET_RF_TYPE(h2c, rftype);
+	GENERAL_INFO_REG_SET_CUT_VERSION(h2c, cut_phydm);
+	GENERAL_INFO_REG_SET_RX_ANT_STATUS(h2c, info->rx_ant_status);
+	GENERAL_INFO_REG_SET_TX_ANT_STATUS(h2c, info->tx_ant_status);
+
+	return rtw_halmac_send_h2c(d, h2c);
+}
+
+static int _send_general_info(struct dvobj_priv *d)
+{
+	struct _ADAPTER *adapter;
+	struct hal_com_data *hal;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	struct halmac_general_info info;
+	enum halmac_ret_status status;
+	enum rf_type rf = RF_1T1R;
+	enum bb_path txpath = BB_PATH_A;
+	enum bb_path rxpath = BB_PATH_A;
+	int err;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	hal = GET_HAL_DATA(adapter);
+	halmac = dvobj_to_halmac(d);
+	if (!halmac)
+		return -1;
+	api = HALMAC_GET_API(halmac);
+
+	_rtw_memset(&info, 0, sizeof(info));
+	info.rfe_type = (u8)hal->rfe_type;
+	rtw_hal_get_rf_path(d, &rf, &txpath, &rxpath);
+	info.rf_type = _rf_type_drv2halmac(rf);
+	info.tx_ant_status = (u8)txpath;
+	info.rx_ant_status = (u8)rxpath;
+
+	status = api->halmac_send_general_info(halmac, &info);
+	switch (status) {
+	case HALMAC_RET_SUCCESS:
+		break;
+	case HALMAC_RET_NO_DLFW:
+		RTW_WARN("%s: halmac_send_general_info() fail because fw not dl!\n",
+			 __FUNCTION__);
+		/* go through */
+	default:
+		return -1;
+	}
+
+	err = _send_general_info_by_reg(d, &info);
+	if (err) {
+		RTW_ERR("%s: Fail to send general info by register!\n",
+			 __FUNCTION__);
+		return -1;
+	}
+
+	return 0;
+}
+
+static int _cfg_drv_rsvd_pg_num(struct dvobj_priv *d)
+{
+	struct _ADAPTER *a;
+	struct hal_com_data *hal;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_drv_rsvd_pg_num rsvd_page_number;
+	enum halmac_ret_status status;
+	u8 drv_rsvd_num;
+
+
+	a = dvobj_get_primary_adapter(d);
+	hal = GET_HAL_DATA(a);
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	drv_rsvd_num = rtw_hal_get_rsvd_page_num(a);
+	rsvd_page_number = _rsvd_page_num_drv2halmac(drv_rsvd_num);
+	status = api->halmac_cfg_drv_rsvd_pg_num(halmac, rsvd_page_number);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+	hal->drv_rsvd_page_number = _rsvd_page_num_halmac2drv(rsvd_page_number);
+
+	if (drv_rsvd_num != hal->drv_rsvd_page_number)
+		RTW_INFO("%s: request %d pages, but allocate %d pages\n",
+			 __FUNCTION__, drv_rsvd_num, hal->drv_rsvd_page_number);
+
+	return 0;
+}
+
+static void _debug_dlfw_fail(struct dvobj_priv *d)
+{
+	struct _ADAPTER *a;
+	u32 addr;
+	u32 v32, i, n;
+	u8 data[0x100] = {0};
+
+
+	a = dvobj_get_primary_adapter(d);
+
+	/* read 0x80[15:0], 0x10F8[31:0] once */
+	addr = 0x80;
+	v32 = rtw_read16(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%04x\n", __FUNCTION__, addr, v32);
+
+	addr = 0x10F8;
+	v32 = rtw_read32(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%08x\n", __FUNCTION__, addr, v32);
+
+	/* read 0x10FC[31:0], 5 times */
+	addr = 0x10FC;
+	n = 5;
+	for (i = 0; i < n; i++) {
+		v32 = rtw_read32(a, addr);
+		RTW_PRINT("%s: 0x%X = 0x%08x (%u/%u)\n",
+			  __FUNCTION__, addr, v32, i, n);
+	}
+
+	/*
+	 * write 0x3A[7:0]=0x28 and 0xF6[7:0]=0x01
+	 * and then read 0xC0[31:0] 5 times
+	 */
+	addr = 0x3A;
+	v32 = 0x28;
+	rtw_write8(a, addr, (u8)v32);
+	v32 = rtw_read8(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v32);
+
+	addr = 0xF6;
+	v32 = 0x1;
+	rtw_write8(a, addr, (u8)v32);
+	v32 = rtw_read8(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v32);
+
+	addr = 0xC0;
+	n = 5;
+	for (i = 0; i < n; i++) {
+		v32 = rtw_read32(a, addr);
+		RTW_PRINT("%s: 0x%X = 0x%08x (%u/%u)\n",
+			  __FUNCTION__, addr, v32, i, n);
+	}
+
+	/* 0x00~0xFF, 0x1000~0x10FF */
+	addr = 0;
+	n = 0x100;
+	for (i = 0; i < n; i+=4)
+		*(u32*)&data[i] = cpu_to_le32(rtw_read32(a, addr+i));
+	for (i = 0; i < n; i++) {
+		if (i % 16 == 0)
+			RTW_PRINT("0x%04x\t", addr+i);
+		_RTW_PRINT("0x%02x", data[i]);
+		if (i % 16 == 15)
+			_RTW_PRINT("\n");
+		else
+			_RTW_PRINT(" ");
+	}
+
+	addr = 0x1000;
+	n = 0x100;
+	for (i = 0; i < n; i+=4)
+		*(u32*)&data[i] = cpu_to_le32(rtw_read32(a, addr+i));
+	for (i = 0; i < n; i++) {
+		if (i % 16 == 0)
+			RTW_PRINT("0x%04x\t", addr+i);
+		_RTW_PRINT("0x%02x", data[i]);
+		if (i % 16 == 15)
+			_RTW_PRINT("\n");
+		else
+			_RTW_PRINT(" ");
+	}
+
+	/* read 0x80 after 10 secs */
+	rtw_msleep_os(10000);
+	addr = 0x80;
+	v32 = rtw_read16(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%04x (after 10 secs)\n",
+		  __FUNCTION__, addr, v32);
+}
+
+static enum halmac_ret_status _enter_cpu_sleep_mode(struct dvobj_priv *d)
+{
+	struct hal_com_data *hal;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+
+
+	hal = GET_HAL_DATA(dvobj_get_primary_adapter(d));
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+#ifdef CONFIG_RTL8822B
+	/* Support after firmware version 21 */
+	if (hal->firmware_version < 21)
+		return HALMAC_RET_NOT_SUPPORT;
+#elif defined(CONFIG_RTL8821C)
+	/* Support after firmware version 13.6 or 16 */
+	if (hal->firmware_version == 13) {
+		if (hal->firmware_sub_version < 6)
+			return HALMAC_RET_NOT_SUPPORT;
+	} else if (hal->firmware_version < 16) {
+		return HALMAC_RET_NOT_SUPPORT;
+	}
+#endif
+
+	return api->halmac_enter_cpu_sleep_mode(mac);
+}
+
+/*
+ * _cpu_sleep() - Let IC CPU enter sleep mode
+ * @d:		struct dvobj_priv*
+ * @timeout:	time limit of wait, unit is ms
+ *		0 for no limit
+ *
+ * Rteurn 0 for CPU in sleep mode, otherwise fail to enter sleep mode.
+ * Error codes definition are as follow:
+ * 	-1	HALMAC enter sleep return fail
+ *	-2	HALMAC get CPU mode return fail
+ *	-110	timeout
+ */
+static int _cpu_sleep(struct dvobj_priv *d, u32 timeout)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_wlcpu_mode mode = HALMAC_WLCPU_UNDEFINE;
+	systime start_t;
+	s32 period = 0;
+	u32 cnt = 0;
+	int err = 0;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	start_t = rtw_get_current_time();
+
+	status = _enter_cpu_sleep_mode(d);
+	if (status != HALMAC_RET_SUCCESS) {
+		if (status != HALMAC_RET_NOT_SUPPORT)
+			err = -1;
+		goto exit;
+	}
+
+	do {
+		cnt++;
+
+		mode = HALMAC_WLCPU_UNDEFINE;
+		status = api->halmac_get_cpu_mode(mac, &mode);
+
+		period = rtw_get_passing_time_ms(start_t);
+
+		if (status != HALMAC_RET_SUCCESS) {
+			err = -2;
+			break;
+		}
+		if (mode == HALMAC_WLCPU_SLEEP)
+			break;
+		if (period > timeout) {
+			err = -110;
+			break;
+		}
+
+		rtw_msleep_os(1);
+	} while (1);
+
+exit:
+	if (err)
+		RTW_ERR("%s: Fail to enter sleep mode! (%d, %d)\n",
+			__FUNCTION__, status, mode);
+
+	RTW_INFO("%s: Cost %dms to polling %u times. (err=%d)\n",
+		__FUNCTION__, period, cnt, err);
+
+	return err;
+}
+
+/*
+ * Description:
+ *	Downlaod Firmware Flow
+ *
+ * Parameters:
+ *	d	pointer of struct dvobj_priv
+ *	fw	firmware array
+ *	fwsize	firmware size
+ *	re_dl	re-download firmware or not
+ *		0: run in init hal flow, not re-download
+ *		1: it is a stand alone operation, not in init hal flow
+ *
+ * Return:
+ *	0	Success
+ *	others	Fail
+ */
+static int download_fw(struct dvobj_priv *d, u8 *fw, u32 fwsize, u8 re_dl)
+{
+	PHAL_DATA_TYPE hal;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	struct halmac_fw_version fw_vesion;
+	enum halmac_ret_status status;
+	int err = 0;
+
+
+	hal = GET_HAL_DATA(dvobj_get_primary_adapter(d));
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	if ((!fw) || (!fwsize))
+		return -1;
+
+	/* 1. Driver Stop Tx */
+	/* ToDo */
+
+	/* 2. Driver Check Tx FIFO is empty */
+	err = rtw_halmac_txfifo_wait_empty(d, 2000); /* wait 2s */
+	if (err) {
+		err = -1;
+		goto resume_tx;
+	}
+
+	/* 3. Config MAX download size */
+	/*
+	 * Already done in rtw_halmac_init_adapter() or
+	 * somewhere calling rtw_halmac_set_max_dl_fw_size().
+	 */
+
+	if (re_dl) {
+		/* 4. Enter IC CPU sleep mode */
+		err = _cpu_sleep(d, 2000);
+		if (err) {
+			RTW_ERR("%s: IC CPU fail to enter sleep mode!(%d)\n",
+				__FUNCTION__, err);
+			/* skip this error */
+			err = 0;
+		}
+	}
+
+	/* 5. Download Firmware */
+	status = api->halmac_download_firmware(mac, fw, fwsize);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_ERR("%s: download firmware FAIL! status=0x%02x\n",
+			__FUNCTION__, status);
+		_debug_dlfw_fail(d);
+		err = -1;
+		goto resume_tx;
+	}
+
+	/* 5.1. (Driver) Reset driver variables if needed */
+	hal->LastHMEBoxNum = 0;
+
+	/* 5.2. (Driver) Get FW version */
+	status = api->halmac_get_fw_version(mac, &fw_vesion);
+	if (status == HALMAC_RET_SUCCESS) {
+		hal->firmware_version = fw_vesion.version;
+		hal->firmware_sub_version = fw_vesion.sub_version;
+		hal->firmware_size = fwsize;
+	}
+
+resume_tx:
+	/* 6. Driver resume TX if needed */
+	/* ToDo */
+
+	if (err)
+		goto exit;
+
+	if (re_dl) {
+		enum halmac_trx_mode mode;
+
+		/* 7. Change reserved page size */
+		err = _cfg_drv_rsvd_pg_num(d);
+		if (err)
+			return -1;
+
+		/* 8. Init TRX Configuration */
+		mode = _choose_trx_mode(d);
+		status = api->halmac_init_trx_cfg(mac, mode);
+		if (HALMAC_RET_SUCCESS != status)
+			return -1;
+
+		/* 9. Config RX Aggregation */
+		err = rtw_halmac_rx_agg_switch(d, _TRUE);
+		if (err)
+			return -1;
+
+		/* 10. Send General Info */
+		err = _send_general_info(d);
+		if (err)
+			return -1;
+	}
+
+exit:
+	return err;
+}
+
+static int init_mac_flow(struct dvobj_priv *d)
+{
+	PADAPTER p;
+	struct hal_com_data *hal;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_drv_rsvd_pg_num rsvd_page_number;
+	union halmac_wlan_addr hwa;
+	enum halmac_trx_mode trx_mode;
+	enum halmac_ret_status status;
+	u8 drv_rsvd_num;
+	u8 nettype;
+	int err, err_ret = -1;
+
+
+	p = dvobj_get_primary_adapter(d);
+	hal = GET_HAL_DATA(p);
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	status = api->halmac_cfg_rxff_expand_mode(halmac,
+						  _rtw_get_trx_share_mode(p));
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+#endif
+
+#if 0 /* It is not necessary to call this in normal driver */
+	status = api->halmac_cfg_la_mode(halmac, HALMAC_LA_MODE_DISABLE);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+#endif
+
+	err = _cfg_drv_rsvd_pg_num(d);
+	if (err)
+		goto out;
+
+#ifdef CONFIG_USB_HCI
+	status = api->halmac_set_bulkout_num(halmac, d->RtNumOutPipes);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+#endif /* CONFIG_USB_HCI */
+
+	trx_mode = _choose_trx_mode(d);
+	status = api->halmac_init_mac_cfg(halmac, trx_mode);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = rtw_halmac_rx_agg_switch(d, _TRUE);
+	if (err)
+		goto out;
+
+	nettype = dvobj_to_regsty(d)->wireless_mode;
+	if (is_supported_vht(nettype) == _TRUE)
+		status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_AC);
+	else if (is_supported_ht(nettype) == _TRUE)
+		status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_N);
+	else if (IsSupportedTxOFDM(nettype) == _TRUE)
+		status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_G);
+	else
+		status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_B);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err_ret = 0;
+out:
+	return err_ret;
+}
+
+static int _drv_enable_trx(struct dvobj_priv *d)
+{
+	struct _ADAPTER *adapter;
+	u32 status;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	if (adapter->bup == _FALSE) {
+		status = rtw_start_drv_threads(adapter);
+		if (status == _FAIL) {
+			RTW_ERR("%s: Start threads Failed!\n", __FUNCTION__);
+			return -1;
+		}
+	}
+
+	rtw_intf_start(adapter);
+
+	return 0;
+}
+
+/*
+ * Notices:
+ *	Make sure
+ *	1. rtw_hal_get_hwreg(HW_VAR_RF_TYPE)
+ *	2. HAL_DATA_TYPE.rfe_type
+ *	already ready for use before calling this function.
+ */
+static int _halmac_init_hal(struct dvobj_priv *d, u8 *fw, u32 fwsize)
+{
+	PADAPTER adapter;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 ok;
+	u8 fw_ok = _FALSE;
+	int err, err_ret = -1;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	halmac = dvobj_to_halmac(d);
+	if (!halmac)
+		goto out;
+	api = HALMAC_GET_API(halmac);
+
+	/* StatePowerOff */
+
+	/* SKIP: halmac_init_adapter (Already done before) */
+
+	/* halmac_pre_Init_system_cfg */
+	/* halmac_mac_power_switch(on) */
+	/* halmac_Init_system_cfg */
+	ok = rtw_hal_power_on(adapter);
+	if (_FAIL == ok)
+		goto out;
+
+	/* StatePowerOn */
+
+	/* DownloadFW */
+	if (fw && fwsize) {
+		err = download_fw(d, fw, fwsize, 0);
+		if (err)
+			goto out;
+		fw_ok = _TRUE;
+	}
+
+	/* InitMACFlow */
+	err = init_mac_flow(d);
+	if (err)
+		goto out;
+
+	/* Driver insert flow: Enable TR/RX */
+	err = _drv_enable_trx(d);
+	if (err)
+		goto out;
+
+	/* halmac_send_general_info */
+	if (_TRUE == fw_ok) {
+		err = _send_general_info(d);
+		if (err)
+			goto out;
+	}
+
+	/* Init Phy parameter-MAC */
+	ok = rtw_hal_init_mac_register(adapter);
+	if (_FALSE == ok)
+		goto out;
+
+	/* StateMacInitialized */
+
+	/* halmac_cfg_drv_info */
+	err = rtw_halmac_config_rx_info(d, HALMAC_DRV_INFO_PHY_STATUS);
+	if (err)
+		goto out;
+
+	/* halmac_set_hw_value(HALMAC_HW_EN_BB_RF) */
+	/* Init BB, RF */
+	ok = rtw_hal_init_phy(adapter);
+	if (_FALSE == ok)
+		goto out;
+
+	status = api->halmac_init_interface_cfg(halmac);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	/* SKIP: halmac_verify_platform_api */
+	/* SKIP: halmac_h2c_lb */
+
+	/* StateRxIdle */
+
+	err_ret = 0;
+out:
+	return err_ret;
+}
+
+int rtw_halmac_init_hal(struct dvobj_priv *d)
+{
+	return _halmac_init_hal(d, NULL, 0);
+}
+
+/*
+ * Notices:
+ *	Make sure
+ *	1. rtw_hal_get_hwreg(HW_VAR_RF_TYPE)
+ *	2. HAL_DATA_TYPE.rfe_type
+ *	already ready for use before calling this function.
+ */
+int rtw_halmac_init_hal_fw(struct dvobj_priv *d, u8 *fw, u32 fwsize)
+{
+	return _halmac_init_hal(d, fw, fwsize);
+}
+
+/*
+ * Notices:
+ *	Make sure
+ *	1. rtw_hal_get_hwreg(HW_VAR_RF_TYPE)
+ *	2. HAL_DATA_TYPE.rfe_type
+ *	already ready for use before calling this function.
+ */
+int rtw_halmac_init_hal_fw_file(struct dvobj_priv *d, u8 *fwpath)
+{
+	u8 *fw = NULL;
+	u32 fwmaxsize = 0, size = 0;
+	int err = 0;
+
+
+	err = rtw_halmac_get_fw_max_size(d, &fwmaxsize);
+	if (err) {
+		RTW_ERR("%s: Fail to get Firmware MAX size(err=%d)\n", __FUNCTION__, err);
+		return -1;
+	}
+
+	fw = rtw_zmalloc(fwmaxsize);
+	if (!fw)
+		return -1;
+
+	size = rtw_retrieve_from_file(fwpath, fw, fwmaxsize);
+	if (!size) {
+		err = -1;
+		goto exit;
+	}
+
+	err = _halmac_init_hal(d, fw, size);
+
+exit:
+	rtw_mfree(fw, fwmaxsize);
+	/*fw = NULL;*/
+
+	return err;
+}
+
+int rtw_halmac_deinit_hal(struct dvobj_priv *d)
+{
+	PADAPTER adapter;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	halmac = dvobj_to_halmac(d);
+	if (!halmac)
+		goto out;
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_deinit_interface_cfg(halmac);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	rtw_hal_power_off(adapter);
+
+	err = 0;
+out:
+	return err;
+}
+
+int rtw_halmac_self_verify(struct dvobj_priv *d)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	int err = -1;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_verify_platform_api(mac);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	status = api->halmac_h2c_lb(mac);
+	if (status != HALMAC_RET_SUCCESS)
+		goto out;
+
+	err = 0;
+out:
+	return err;
+}
+
+static u8 rtw_halmac_txfifo_is_empty(struct dvobj_priv *d)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 chk_num = 10;
+	u8 rst = _FALSE;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_txfifo_is_empty(mac, chk_num);
+	if (status == HALMAC_RET_SUCCESS)
+		rst = _TRUE;
+
+	return rst;
+}
+
+/**
+ * rtw_halmac_txfifo_wait_empty() - Wait TX FIFO to be emtpy
+ * @d:		struct dvobj_priv*
+ * @timeout:	time limit of wait, unit is ms
+ *		0 for no limit
+ *
+ * Wait TX FIFO to be emtpy.
+ *
+ * Rteurn 0 for TX FIFO is empty, otherwise not empty.
+ */
+int rtw_halmac_txfifo_wait_empty(struct dvobj_priv *d, u32 timeout)
+{
+	struct _ADAPTER *a;
+	u8 empty = _FALSE;
+	u32 cnt = 0;
+	systime start_time = 0;
+	u32 pass_time; /* ms */
+
+
+	a = dvobj_get_primary_adapter(d);
+	start_time = rtw_get_current_time();
+
+	do {
+		cnt++;
+		empty = rtw_halmac_txfifo_is_empty(d);
+		if (empty == _TRUE)
+			break;
+
+		if (timeout) {
+			pass_time = rtw_get_passing_time_ms(start_time);
+			if (pass_time > timeout)
+				break;
+		}
+		if (RTW_CANNOT_IO(a)) {
+			RTW_WARN("%s: Interrupted by I/O forbiden!\n", __FUNCTION__);
+			break;
+		}
+
+		rtw_msleep_os(2);
+	} while (1);
+
+	if (empty == _FALSE) {
+#ifdef CONFIG_RTW_DEBUG
+		u16 dbg_reg[] = {0x210, 0x230, 0x234, 0x238, 0x23C, 0x240,
+				 0x41A, 0x10FC, 0x10F8, 0x11F4, 0x11F8};
+		u8 i;
+		u32 val;
+
+		if (!RTW_CANNOT_IO(a)) {
+			for (i = 0; i < ARRAY_SIZE(dbg_reg); i++) {
+				val = rtw_read32(a, dbg_reg[i]);
+				RTW_ERR("REG_%X:0x%08x\n", dbg_reg[i], val);
+			}
+		}
+#endif /* CONFIG_RTW_DEBUG */
+
+		RTW_ERR("%s: Fail to wait txfifo empty!(cnt=%d)\n",
+			__FUNCTION__, cnt);
+		return -1;
+	}
+
+	return 0;
+}
+
+static enum halmac_dlfw_mem _fw_mem_drv2halmac(enum fw_mem mem, u8 tx_stop)
+{
+	enum halmac_dlfw_mem mem_halmac = HALMAC_DLFW_MEM_UNDEFINE;
+
+
+	switch (mem) {
+	case FW_EMEM:
+		if (tx_stop == _FALSE)
+			mem_halmac = HALMAC_DLFW_MEM_EMEM_RSVD_PG;
+		else
+			mem_halmac = HALMAC_DLFW_MEM_EMEM;
+		break;
+
+	case FW_IMEM:
+	case FW_DMEM:
+		mem_halmac = HALMAC_DLFW_MEM_UNDEFINE;
+		break;
+	}
+
+	return mem_halmac;
+}
+
+int rtw_halmac_dlfw_mem(struct dvobj_priv *d, u8 *fw, u32 fwsize, enum fw_mem mem)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_dlfw_mem dlfw_mem;
+	u8 tx_stop = _FALSE;
+	u32 chk_timeout = 2000; /* unit: ms */
+	int err = 0;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	if ((!fw) || (!fwsize))
+		return -1;
+
+#ifndef RTW_HALMAC_DLFW_MEM_NO_STOP_TX
+	/* 1. Driver Stop Tx */
+	/* ToDo */
+
+	/* 2. Driver Check Tx FIFO is empty */
+	err = rtw_halmac_txfifo_wait_empty(d, chk_timeout);
+	if (err)
+		tx_stop = _FALSE;
+	else
+		tx_stop = _TRUE;
+#endif /* !RTW_HALMAC_DLFW_MEM_NO_STOP_TX */
+
+	/* 3. Download Firmware MEM */
+	dlfw_mem = _fw_mem_drv2halmac(mem, tx_stop);
+	if (dlfw_mem == HALMAC_DLFW_MEM_UNDEFINE) {
+		err = -1;
+		goto resume_tx;
+	}
+	status = api->halmac_free_download_firmware(mac, dlfw_mem, fw, fwsize);
+	if (status != HALMAC_RET_SUCCESS) {
+		RTW_ERR("%s: halmac_free_download_firmware fail(err=0x%x)\n",
+			__FUNCTION__, status);
+		err = -1;
+		goto resume_tx;
+	}
+
+resume_tx:
+#ifndef RTW_HALMAC_DLFW_MEM_NO_STOP_TX
+	/* 4. Driver resume TX if needed */
+	/* ToDo */
+#endif /* !RTW_HALMAC_DLFW_MEM_NO_STOP_TX */
+
+	return err;
+}
+
+int rtw_halmac_dlfw_mem_from_file(struct dvobj_priv *d, u8 *fwpath, enum fw_mem mem)
+{
+	u8 *fw = NULL;
+	u32 fwmaxsize = 0, size = 0;
+	int err = 0;
+
+
+	err = rtw_halmac_get_fw_max_size(d, &fwmaxsize);
+	if (err) {
+		RTW_ERR("%s: Fail to get Firmware MAX size(err=%d)\n", __FUNCTION__, err);
+		return -1;
+	}
+
+	fw = rtw_zmalloc(fwmaxsize);
+	if (!fw)
+		return -1;
+
+	size = rtw_retrieve_from_file(fwpath, fw, fwmaxsize);
+	if (size)
+		err = rtw_halmac_dlfw_mem(d, fw, size, mem);
+	else
+		err = -1;
+
+	rtw_mfree(fw, fwmaxsize);
+	/*fw = NULL;*/
+
+	return err;
+}
+
+/*
+ * Return:
+ *	0	Success
+ *	-22	Invalid arguemnt
+ */
+int rtw_halmac_dlfw(struct dvobj_priv *d, u8 *fw, u32 fwsize)
+{
+	PADAPTER adapter;
+	enum halmac_ret_status status;
+	u32 ok;
+	int err, err_ret = -1;
+
+
+	if (!fw || !fwsize)
+		return -22;
+
+	adapter = dvobj_get_primary_adapter(d);
+
+	/* re-download firmware */
+	if (rtw_is_hw_init_completed(adapter))
+		return download_fw(d, fw, fwsize, 1);
+
+	/* Download firmware before hal init */
+	/* Power on, download firmware and init mac */
+	ok = rtw_hal_power_on(adapter);
+	if (_FAIL == ok)
+		goto out;
+
+	err = download_fw(d, fw, fwsize, 0);
+	if (err) {
+		err_ret = err;
+		goto out;
+	}
+
+	err = init_mac_flow(d);
+	if (err)
+		goto out;
+
+	err = _send_general_info(d);
+	if (err)
+		goto out;
+
+	err_ret = 0;
+
+out:
+	return err_ret;
+}
+
+int rtw_halmac_dlfw_from_file(struct dvobj_priv *d, u8 *fwpath)
+{
+	u8 *fw = NULL;
+	u32 fwmaxsize = 0, size = 0;
+	int err = 0;
+
+
+	err = rtw_halmac_get_fw_max_size(d, &fwmaxsize);
+	if (err) {
+		RTW_ERR("%s: Fail to get Firmware MAX size(err=%d)\n", __FUNCTION__, err);
+		return -1;
+	}
+
+	fw = rtw_zmalloc(fwmaxsize);
+	if (!fw)
+		return -1;
+
+	size = rtw_retrieve_from_file(fwpath, fw, fwmaxsize);
+	if (size)
+		err = rtw_halmac_dlfw(d, fw, size);
+	else
+		err = -1;
+
+	rtw_mfree(fw, fwmaxsize);
+	/*fw = NULL;*/
+
+	return err;
+}
+
+/*
+ * Description:
+ *	Power on/off BB/RF domain.
+ *
+ * Parameters:
+ *	enable	_TRUE/_FALSE for power on/off
+ *
+ * Return:
+ *	0	Success
+ *	others	Fail
+ */
+int rtw_halmac_phy_power_switch(struct dvobj_priv *d, u8 enable)
+{
+	PADAPTER adapter;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	halmac = dvobj_to_halmac(d);
+	if (!halmac)
+		return -1;
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_set_hw_value(halmac, HALMAC_HW_EN_BB_RF, &enable);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+static u8 _is_fw_read_cmd_down(PADAPTER adapter, u8 msgbox_num)
+{
+	u8 read_down = _FALSE;
+	int retry_cnts = 100;
+	u8 valid;
+
+	do {
+		valid = rtw_read8(adapter, REG_HMETFR) & BIT(msgbox_num);
+		if (0 == valid)
+			read_down = _TRUE;
+		else
+			rtw_msleep_os(1);
+	} while ((!read_down) && (retry_cnts--));
+
+	if (_FALSE == read_down)
+		RTW_WARN("%s, reg_1cc(%x), msg_box(%d)...\n", __func__, rtw_read8(adapter, REG_HMETFR), msgbox_num);
+
+	return read_down;
+}
+
+/**
+ * rtw_halmac_send_h2c() - Send H2C to firmware
+ * @d:		struct dvobj_priv*
+ * @h2c:	H2C data buffer, suppose to be 8 bytes
+ *
+ * Send H2C to firmware by message box register(0x1D0~0x1D3 & 0x1F0~0x1F3).
+ *
+ * Assume firmware be ready to accept H2C here, please check
+ * (hal->bFWReady == _TRUE) before call this function or make sure firmware is
+ * ready.
+ *
+ * Return: 0 if process OK, otherwise fail to send this H2C.
+ */
+int rtw_halmac_send_h2c(struct dvobj_priv *d, u8 *h2c)
+{
+	PADAPTER adapter = dvobj_get_primary_adapter(d);
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	u8 h2c_box_num = 0;
+	u32 msgbox_addr = 0;
+	u32 msgbox_ex_addr = 0;
+	u32 h2c_cmd = 0;
+	u32 h2c_cmd_ex = 0;
+	int err = -1;
+
+
+	if (!h2c) {
+		RTW_WARN("%s: pbuf is NULL\n", __FUNCTION__);
+		return err;
+	}
+
+	if (rtw_is_surprise_removed(adapter)) {
+		RTW_WARN("%s: surprise removed\n", __FUNCTION__);
+		return err;
+	}
+
+	_enter_critical_mutex(&d->h2c_fwcmd_mutex, NULL);
+
+	/* pay attention to if race condition happened in H2C cmd setting */
+	h2c_box_num = hal->LastHMEBoxNum;
+
+	if (!_is_fw_read_cmd_down(adapter, h2c_box_num)) {
+		RTW_WARN(" fw read cmd failed...\n");
+#ifdef DBG_CONFIG_ERROR_DETECT
+		hal->srestpriv.self_dect_fw = _TRUE;
+		hal->srestpriv.self_dect_fw_cnt++;
+#endif /* DBG_CONFIG_ERROR_DETECT */
+		goto exit;
+	}
+
+	/* Write Ext command (byte 4~7) */
+	msgbox_ex_addr = REG_HMEBOX_E0 + (h2c_box_num * EX_MESSAGE_BOX_SIZE);
+	_rtw_memcpy((u8 *)(&h2c_cmd_ex), h2c + 4, EX_MESSAGE_BOX_SIZE);
+	h2c_cmd_ex = le32_to_cpu(h2c_cmd_ex);
+	rtw_write32(adapter, msgbox_ex_addr, h2c_cmd_ex);
+
+	/* Write command (byte 0~3) */
+	msgbox_addr = REG_HMEBOX0 + (h2c_box_num * MESSAGE_BOX_SIZE);
+	_rtw_memcpy((u8 *)(&h2c_cmd), h2c, 4);
+	h2c_cmd = le32_to_cpu(h2c_cmd);
+	rtw_write32(adapter, msgbox_addr, h2c_cmd);
+
+	/* update last msg box number */
+	hal->LastHMEBoxNum = (h2c_box_num + 1) % MAX_H2C_BOX_NUMS;
+	err = 0;
+
+#ifdef DBG_H2C_CONTENT
+	RTW_INFO_DUMP("[H2C] - ", h2c, RTW_HALMAC_H2C_MAX_SIZE);
+#endif
+exit:
+	_exit_critical_mutex(&d->h2c_fwcmd_mutex, NULL);
+	return err;
+}
+
+/**
+ * rtw_halmac_c2h_handle() - Handle C2H for HALMAC
+ * @d:		struct dvobj_priv*
+ * @c2h:	Full C2H packet, including RX description and payload
+ * @size:	Size(byte) of c2h
+ *
+ * Send C2H packet to HALMAC to process C2H packets, and the expected C2H ID is
+ * 0xFF. This function won't have any I/O, so caller doesn't have to call it in
+ * I/O safe place(ex. command thread).
+ *
+ * Please sure doesn't call this function in the same thread as someone is
+ * waiting HALMAC C2H ack, otherwise there is a deadlock happen.
+ *
+ * Return: 0 if process OK, otherwise no action for this C2H.
+ */
+int rtw_halmac_c2h_handle(struct dvobj_priv *d, u8 *c2h, u32 size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_get_c2h_info(mac, c2h, size);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_get_available_efuse_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_get_efuse_available_size(mac, &val);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	*size = val;
+	return 0;
+}
+
+int rtw_halmac_get_physical_efuse_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_get_efuse_size(mac, &val);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	*size = val;
+	return 0;
+}
+
+int rtw_halmac_read_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
+	int ret;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+	id = HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE;
+
+	ret = init_halmac_event(d, id, map, size);
+	if (ret)
+		return -1;
+
+	status = api->halmac_dump_efuse_map(mac, HALMAC_EFUSE_R_DRV);
+	if (HALMAC_RET_SUCCESS != status) {
+		free_halmac_event(d, id);
+		return -1;
+	}
+
+	ret = wait_halmac_event(d, id);
+	if (ret)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_read_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u8 v;
+	u32 i;
+	u8 *efuse = NULL;
+	u32 size = 0;
+	int err = 0;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	if (api->halmac_read_efuse) {
+		for (i = 0; i < cnt; i++) {
+			status = api->halmac_read_efuse(mac, offset + i, &v);
+			if (HALMAC_RET_SUCCESS != status)
+				return -1;
+			data[i] = v;
+		}
+	} else {
+		err = rtw_halmac_get_physical_efuse_size(d, &size);
+		if (err)
+			return -1;
+
+		efuse = rtw_zmalloc(size);
+		if (!efuse)
+			return -1;
+
+		err = rtw_halmac_read_physical_efuse_map(d, efuse, size);
+		if (err)
+			err = -1;
+		else
+			_rtw_memcpy(data, efuse + offset, cnt);
+
+		rtw_mfree(efuse, size);
+	}
+
+	return err;
+}
+
+int rtw_halmac_write_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 i;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	if (api->halmac_write_efuse == NULL)
+		return -1;
+
+	for (i = 0; i < cnt; i++) {
+		status = api->halmac_write_efuse(mac, offset + i, data[i]);
+		if (HALMAC_RET_SUCCESS != status)
+			return -1;
+	}
+
+	return 0;
+}
+
+int rtw_halmac_get_logical_efuse_size(struct dvobj_priv *d, u32 *size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 val;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_get_logical_efuse_size(mac, &val);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	*size = val;
+	return 0;
+}
+
+int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u8 *maskmap, u32 masksize)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
+	int ret;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+	id = HALMAC_FEATURE_DUMP_LOGICAL_EFUSE;
+
+	ret = init_halmac_event(d, id, map, size);
+	if (ret)
+		return -1;
+
+	status = api->halmac_dump_logical_efuse_map(mac, HALMAC_EFUSE_R_DRV);
+	if (HALMAC_RET_SUCCESS != status) {
+		free_halmac_event(d, id);
+		return -1;
+	}
+
+	ret = wait_halmac_event(d, id);
+	if (ret)
+		return -1;
+
+	if (maskmap && masksize) {
+		struct halmac_pg_efuse_info pginfo;
+
+		pginfo.efuse_map = map;
+		pginfo.efuse_map_size = size;
+		pginfo.efuse_mask = maskmap;
+		pginfo.efuse_mask_size = masksize;
+
+		status = api->halmac_mask_logical_efuse(mac, &pginfo);
+		if (status != HALMAC_RET_SUCCESS)
+			RTW_WARN("%s: mask logical efuse FAIL!\n", __FUNCTION__);
+	}
+
+	return 0;
+}
+
+int rtw_halmac_write_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u8 *maskmap, u32 masksize)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	struct halmac_pg_efuse_info pginfo;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	pginfo.efuse_map = map;
+	pginfo.efuse_map_size = size;
+	pginfo.efuse_mask = maskmap;
+	pginfo.efuse_mask_size = masksize;
+
+	status = api->halmac_pg_efuse_by_map(mac, &pginfo, HALMAC_EFUSE_R_AUTO);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_read_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u8 v;
+	u32 i;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	for (i = 0; i < cnt; i++) {
+		status = api->halmac_read_logical_efuse(mac, offset + i, &v);
+		if (HALMAC_RET_SUCCESS != status)
+			return -1;
+		data[i] = v;
+	}
+
+	return 0;
+}
+
+int rtw_halmac_write_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 i;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	for (i = 0; i < cnt; i++) {
+		status = api->halmac_write_logical_efuse(mac, offset + i, data[i]);
+		if (HALMAC_RET_SUCCESS != status)
+			return -1;
+	}
+
+	return 0;
+}
+
+int rtw_halmac_write_bt_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 i;
+	u8 bank = 1;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	for (i = 0; i < cnt; i++) {
+		status = api->halmac_write_efuse_bt(mac, offset + i, data[i], bank);
+		if (HALMAC_RET_SUCCESS != status) {
+			printk("%s: halmac_write_efuse_bt status = %d\n", __FUNCTION__, status);
+			return -1;
+		}
+	}
+	printk("%s: halmac_write_efuse_bt status = HALMAC_RET_SUCCESS %d\n", __FUNCTION__, status);
+	return 0;
+}
+
+
+int rtw_halmac_read_bt_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	int bank = 1;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_dump_efuse_map_bt(mac, bank, size, map);
+	if (HALMAC_RET_SUCCESS != status) {
+		printk("%s: halmac_dump_efuse_map_bt fail!\n", __FUNCTION__);
+		return -1;
+	}
+
+	printk("%s: OK!\n", __FUNCTION__);
+
+	return 0;
+}
+
+static enum hal_fifo_sel _fifo_sel_drv2halmac(u8 fifo_sel)
+{
+	switch (fifo_sel) {
+	case 0:
+		return HAL_FIFO_SEL_TX;
+	case 1:
+		return HAL_FIFO_SEL_RX;
+	case 2:
+		return HAL_FIFO_SEL_RSVD_PAGE;
+	case 3:
+		return HAL_FIFO_SEL_REPORT;
+	case 4:
+		return HAL_FIFO_SEL_LLT;
+	case 5:
+		return HAL_FIFO_SEL_RXBUF_FW;
+	}
+
+	return HAL_FIFO_SEL_RSVD_PAGE;
+}
+
+/*#define CONFIG_HALMAC_FIFO_DUMP*/
+int rtw_halmac_dump_fifo(struct dvobj_priv *d, u8 fifo_sel, u32 addr, u32 size, u8 *buffer)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum hal_fifo_sel halmac_fifo_sel;
+	enum halmac_ret_status status;
+	u8 *pfifo_map = NULL;
+	u32 fifo_size = 0;
+	s8 ret = 0;/* 0:success, -1:error */
+	u8 mem_created = _FALSE;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	if ((size != 0) && (buffer == NULL))
+		return -1;
+
+	halmac_fifo_sel = _fifo_sel_drv2halmac(fifo_sel);
+
+	if ((size) && (buffer)) {
+		pfifo_map = buffer;
+		fifo_size = size;
+	} else {
+		fifo_size = api->halmac_get_fifo_size(mac, halmac_fifo_sel);
+
+		if (fifo_size)
+			pfifo_map = rtw_zvmalloc(fifo_size);
+		if (pfifo_map == NULL)
+			return -1;
+		mem_created = _TRUE;
+	}
+
+	status = api->halmac_dump_fifo(mac, halmac_fifo_sel, addr, fifo_size, pfifo_map);
+	if (HALMAC_RET_SUCCESS != status) {
+		ret = -1;
+		goto _exit;
+	}
+
+#ifdef CONFIG_HALMAC_FIFO_DUMP
+	{
+		static const char * const fifo_sel_str[] = {
+			"TX", "RX", "RSVD_PAGE", "REPORT", "LLT", "RXBUF_FW"
+		};
+
+		RTW_INFO("%s FIFO DUMP [start_addr:0x%04x , size:%d]\n", fifo_sel_str[halmac_fifo_sel], addr, fifo_size);
+		RTW_INFO_DUMP("\n", pfifo_map, fifo_size);
+		RTW_INFO(" ==================================================\n");
+	}
+#endif /* CONFIG_HALMAC_FIFO_DUMP */
+
+_exit:
+	if ((mem_created == _TRUE) && pfifo_map)
+		rtw_vmfree(pfifo_map, fifo_size);
+
+	return ret;
+}
+
+/*
+ * rtw_halmac_rx_agg_switch() - Switch RX aggregation function and setting
+ * @d		struct dvobj_priv *
+ * @enable	0/1 for disable/enable RX aggregation function
+ *
+ * This function could help to on/off bus RX aggregation function, and is only
+ * useful for SDIO and USB interface. Although only "enable" flag is brough in,
+ * some setting would be taken from other places, and they are from:
+ * [DMA aggregation]
+ *	struct hal_com_data.rxagg_dma_size
+ *	struct hal_com_data.rxagg_dma_timeout
+ * [USB aggregation] (only use for USB interface)
+ *	struct hal_com_data.rxagg_usb_size
+ *	struct hal_com_data.rxagg_usb_timeout
+ * If above values of size and timeout are both 0 means driver would not
+ * control the threshold setting and leave it to HALMAC handle.
+ *
+ * From HALMAC V1_04_04, driver force the size threshold be hard limit, and the
+ * rx size can not exceed the setting.
+ *
+ * Return 0 for success, otherwise fail.
+ */
+int rtw_halmac_rx_agg_switch(struct dvobj_priv *d, u8 enable)
+{
+	struct _ADAPTER *adapter;
+	struct hal_com_data *hal;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	struct halmac_rxagg_cfg rxaggcfg;
+	enum halmac_ret_status status;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	hal = GET_HAL_DATA(adapter);
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	_rtw_memset((void *)&rxaggcfg, 0, sizeof(rxaggcfg));
+	rxaggcfg.mode = HALMAC_RX_AGG_MODE_NONE;
+	/*
+	 * Always enable size limit to avoid rx size exceed
+	 * driver defined size.
+	 */
+	rxaggcfg.threshold.size_limit_en = 1;
+
+#ifdef RTW_RX_AGGREGATION
+	if (_TRUE == enable) {
+#ifdef CONFIG_SDIO_HCI
+		rxaggcfg.mode = HALMAC_RX_AGG_MODE_DMA;
+		rxaggcfg.threshold.drv_define = 0;
+		if (hal->rxagg_dma_size || hal->rxagg_dma_timeout) {
+			rxaggcfg.threshold.drv_define = 1;
+			rxaggcfg.threshold.timeout = hal->rxagg_dma_timeout;
+			rxaggcfg.threshold.size = hal->rxagg_dma_size;
+			RTW_INFO("%s: RX aggregation threshold: "
+				 "timeout=%u size=%u\n",
+				 __FUNCTION__,
+				 hal->rxagg_dma_timeout,
+				 hal->rxagg_dma_size);
+		}
+#elif defined(CONFIG_USB_HCI)
+		switch (hal->rxagg_mode) {
+		case RX_AGG_DISABLE:
+			rxaggcfg.mode = HALMAC_RX_AGG_MODE_NONE;
+			break;
+
+		case RX_AGG_DMA:
+			rxaggcfg.mode = HALMAC_RX_AGG_MODE_DMA;
+			if (hal->rxagg_dma_size || hal->rxagg_dma_timeout) {
+				rxaggcfg.threshold.drv_define = 1;
+				rxaggcfg.threshold.timeout = hal->rxagg_dma_timeout;
+				rxaggcfg.threshold.size = hal->rxagg_dma_size;
+			}
+			break;
+
+		case RX_AGG_USB:
+		case RX_AGG_MIX:
+			rxaggcfg.mode = HALMAC_RX_AGG_MODE_USB;
+			if (hal->rxagg_usb_size || hal->rxagg_usb_timeout) {
+				rxaggcfg.threshold.drv_define = 1;
+				rxaggcfg.threshold.timeout = hal->rxagg_usb_timeout;
+				rxaggcfg.threshold.size = hal->rxagg_usb_size;
+			}
+			break;
+		}
+#endif /* CONFIG_USB_HCI */
+	}
+#endif /* RTW_RX_AGGREGATION */
+
+	status = api->halmac_cfg_rx_aggregation(halmac, &rxaggcfg);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_download_rsvd_page(struct dvobj_priv *dvobj, u8 pg_offset, u8 *pbuf, u32 size)
+{
+	enum halmac_ret_status status = HALMAC_RET_SUCCESS;
+	struct halmac_adapter *halmac = dvobj_to_halmac(dvobj);
+	struct halmac_api *api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_dl_drv_rsvd_page(halmac, pg_offset, pbuf, size);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+/*
+ * Description
+ *	Fill following spec info from HALMAC API:
+ *	sec_cam_ent_num
+ *
+ * Return
+ *	0	Success
+ *	others	Fail
+ */
+int rtw_halmac_fill_hal_spec(struct dvobj_priv *dvobj, struct hal_spec_t *spec)
+{
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	u8 cam = 0;	/* Security Cam Entry Number */
+
+
+	halmac = dvobj_to_halmac(dvobj);
+	api = HALMAC_GET_API(halmac);
+
+	/* Prepare data from HALMAC */
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_CAM_ENTRY_NUM, &cam);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	/* Fill data to hal_spec_t */
+	spec->sec_cam_ent_num = cam;
+
+	return 0;
+}
+
+int rtw_halmac_p2pps(struct dvobj_priv *dvobj, struct hal_p2p_ps_para *pp2p_ps_para)
+{
+	enum halmac_ret_status status = HALMAC_RET_SUCCESS;
+	struct halmac_adapter *halmac = dvobj_to_halmac(dvobj);
+	struct halmac_api *api = HALMAC_GET_API(halmac);
+	struct halmac_p2pps halmac_p2p_ps;
+
+	(&halmac_p2p_ps)->offload_en = pp2p_ps_para->offload_en;
+	(&halmac_p2p_ps)->role = pp2p_ps_para->role;
+	(&halmac_p2p_ps)->ctwindow_en = pp2p_ps_para->ctwindow_en;
+	(&halmac_p2p_ps)->noa_en = pp2p_ps_para->noa_en;
+	(&halmac_p2p_ps)->noa_sel = pp2p_ps_para->noa_sel;
+	(&halmac_p2p_ps)->all_sta_sleep = pp2p_ps_para->all_sta_sleep;
+	(&halmac_p2p_ps)->discovery = pp2p_ps_para->discovery;
+	(&halmac_p2p_ps)->p2p_port_id = _hw_port_drv2halmac(pp2p_ps_para->p2p_port_id);
+	(&halmac_p2p_ps)->p2p_group = pp2p_ps_para->p2p_group;
+	(&halmac_p2p_ps)->p2p_macid = pp2p_ps_para->p2p_macid;
+	(&halmac_p2p_ps)->ctwindow_length = pp2p_ps_para->ctwindow_length;
+	(&halmac_p2p_ps)->noa_duration_para = pp2p_ps_para->noa_duration_para;
+	(&halmac_p2p_ps)->noa_interval_para = pp2p_ps_para->noa_interval_para;
+	(&halmac_p2p_ps)->noa_start_time_para = pp2p_ps_para->noa_start_time_para;
+	(&halmac_p2p_ps)->noa_count_para = pp2p_ps_para->noa_count_para;
+
+	status = api->halmac_p2pps(halmac, (&halmac_p2p_ps));
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+
+}
+
+/**
+ * rtw_halmac_iqk() - Run IQ Calibration
+ * @d:		struct dvobj_priv*
+ * @clear:	IQK parameters
+ * @segment:	IQK parameters
+ *
+ * Process IQ Calibration(IQK).
+ *
+ * Rteurn: 0 for OK, otherwise fail.
+ */
+int rtw_halmac_iqk(struct dvobj_priv *d, u8 clear, u8 segment)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
+	struct halmac_iqk_para para;
+	int ret;
+	u8 retry = 3;
+	u8 delay = 1; /* ms */
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+	id = HALMAC_FEATURE_IQK;
+
+	ret = init_halmac_event(d, id, NULL, 0);
+	if (ret)
+		return -1;
+
+	para.clear = clear;
+	para.segment_iqk = segment;
+
+	do {
+		status = api->halmac_start_iqk(mac, &para);
+		if (status != HALMAC_RET_BUSY_STATE)
+			break;
+		RTW_WARN("%s: Fail to start IQK, status is BUSY! retry=%d\n", __FUNCTION__, retry);
+		if (!retry)
+			break;
+		retry--;
+		rtw_msleep_os(delay);
+	} while (1);
+	if (status != HALMAC_RET_SUCCESS) {
+		free_halmac_event(d, id);
+		return -1;
+	}
+
+	ret = wait_halmac_event(d, id);
+	if (ret)
+		return -1;
+
+	return 0;
+}
+
+static inline u32 _phy_parameter_val_drv2halmac(u32 val, u8 msk_en, u32 msk)
+{
+	if (!msk_en)
+		return val;
+
+	return (val << bitshift(msk));
+}
+
+static int _phy_parameter_drv2halmac(struct rtw_phy_parameter *para, struct halmac_phy_parameter_info *info)
+{
+	if (!para || !info)
+		return -1;
+
+	_rtw_memset(info, 0, sizeof(*info));
+
+	switch (para->cmd) {
+	case 0:
+		/* MAC register */
+		switch (para->data.mac.size) {
+		case 1:
+			info->cmd_id = HALMAC_PARAMETER_CMD_MAC_W8;
+			break;
+		case 2:
+			info->cmd_id = HALMAC_PARAMETER_CMD_MAC_W16;
+			break;
+		default:
+			info->cmd_id = HALMAC_PARAMETER_CMD_MAC_W32;
+			break;
+		}
+		info->content.MAC_REG_W.value = _phy_parameter_val_drv2halmac(
+							para->data.mac.value,
+							para->data.mac.msk_en,
+							para->data.mac.msk);
+		info->content.MAC_REG_W.msk = para->data.mac.msk;
+		info->content.MAC_REG_W.offset = para->data.mac.offset;
+		info->content.MAC_REG_W.msk_en = para->data.mac.msk_en;
+		break;
+
+	case 1:
+		/* BB register */
+		switch (para->data.bb.size) {
+		case 1:
+			info->cmd_id = HALMAC_PARAMETER_CMD_BB_W8;
+			break;
+		case 2:
+			info->cmd_id = HALMAC_PARAMETER_CMD_BB_W16;
+			break;
+		default:
+			info->cmd_id = HALMAC_PARAMETER_CMD_BB_W32;
+			break;
+		}
+		info->content.BB_REG_W.value = _phy_parameter_val_drv2halmac(
+							para->data.bb.value,
+							para->data.bb.msk_en,
+							para->data.bb.msk);
+		info->content.BB_REG_W.msk = para->data.bb.msk;
+		info->content.BB_REG_W.offset = para->data.bb.offset;
+		info->content.BB_REG_W.msk_en = para->data.bb.msk_en;
+		break;
+
+	case 2:
+		/* RF register */
+		info->cmd_id = HALMAC_PARAMETER_CMD_RF_W;
+		info->content.RF_REG_W.value = _phy_parameter_val_drv2halmac(
+							para->data.rf.value,
+							para->data.rf.msk_en,
+							para->data.rf.msk);
+		info->content.RF_REG_W.msk = para->data.rf.msk;
+		info->content.RF_REG_W.offset = para->data.rf.offset;
+		info->content.RF_REG_W.msk_en = para->data.rf.msk_en;
+		info->content.RF_REG_W.rf_path = para->data.rf.path;
+		break;
+
+	case 3:
+		/* Delay register */
+		if (para->data.delay.unit == 0)
+			info->cmd_id = HALMAC_PARAMETER_CMD_DELAY_US;
+		else
+			info->cmd_id = HALMAC_PARAMETER_CMD_DELAY_MS;
+		info->content.DELAY_TIME.delay_time = para->data.delay.value;
+		break;
+
+	case 0xFF:
+		/* Latest(End) command */
+		info->cmd_id = HALMAC_PARAMETER_CMD_END;
+		break;
+
+	default:
+		return -1;
+	}
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_cfg_phy_para() - Register(Phy parameter) configuration
+ * @d:		struct dvobj_priv*
+ * @para:	phy parameter
+ *
+ * Configure registers by firmware using H2C/C2H mechanism.
+ * The latest command should be para->cmd==0xFF(End command) to finish all
+ * processes.
+ *
+ * Return: 0 for OK, otherwise fail.
+ */
+int rtw_halmac_cfg_phy_para(struct dvobj_priv *d, struct rtw_phy_parameter *para)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
+	struct halmac_phy_parameter_info info;
+	u8 full_fifo;
+	int err, ret;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+	id = HALMAC_FEATURE_CFG_PARA;
+	full_fifo = 1; /* ToDo: How to deciede? */
+	ret = 0;
+
+	err = _phy_parameter_drv2halmac(para, &info);
+	if (err)
+		return -1;
+
+	err = init_halmac_event(d, id, NULL, 0);
+	if (err)
+		return -1;
+
+	status = api->halmac_cfg_parameter(mac, &info, full_fifo);
+	if (info.cmd_id == HALMAC_PARAMETER_CMD_END) {
+		if (status == HALMAC_RET_SUCCESS) {
+			err = wait_halmac_event(d, id);
+			if (err)
+				ret = -1;
+		} else {
+			free_halmac_event(d, id);
+			ret = -1;
+			RTW_ERR("%s: Fail to send END of cfg parameter, status is 0x%x!\n", __FUNCTION__, status);
+		}
+	} else {
+		if (status == HALMAC_RET_PARA_SENDING) {
+			err = wait_halmac_event(d, id);
+			if (err)
+				ret = -1;
+		} else {
+			free_halmac_event(d, id);
+			if (status != HALMAC_RET_SUCCESS) {
+				ret = -1;
+				RTW_ERR("%s: Fail to cfg parameter, status is 0x%x!\n", __FUNCTION__, status);
+			}
+		}
+	}
+
+	return ret;
+}
+
+static enum halmac_wlled_mode _led_mode_drv2halmac(u8 drv_mode)
+{
+	enum halmac_wlled_mode halmac_mode;
+
+
+	switch (drv_mode) {
+	case 1:
+		halmac_mode = HALMAC_WLLED_MODE_TX;
+		break;
+	case 2:
+		halmac_mode = HALMAC_WLLED_MODE_RX;
+		break;
+	case 3:
+		halmac_mode = HALMAC_WLLED_MODE_SW_CTRL;
+		break;
+	case 0:
+	default:
+		halmac_mode = HALMAC_WLLED_MODE_TRX;
+		break;
+	}
+
+	return halmac_mode;
+}
+
+/**
+ * rtw_halmac_led_cfg() - Configure Hardware LED Mode
+ * @d:		struct dvobj_priv*
+ * @enable:	enable or disable LED function
+ *		0: disable
+ *		1: enable
+ * @mode:	WLan LED mode (valid when enable==1)
+ *		0: Blink when TX(transmit packet) and RX(receive packet)
+ *		1: Blink when TX only
+ *		2: Blink when RX only
+ *		3: Software control
+ *
+ * Configure hardware WLan LED mode.
+ * If want to change LED mode after enabled, need to disable LED first and
+ * enable again to set new mode.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_led_cfg(struct dvobj_priv *d, u8 enable, u8 mode)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_wlled_mode led_mode;
+	enum halmac_ret_status status;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	if (enable) {
+		status = api->halmac_pinmux_set_func(halmac,
+						     HALMAC_GPIO_FUNC_WL_LED);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: pinmux set fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+
+		led_mode = _led_mode_drv2halmac(mode);
+		status = api->halmac_pinmux_wl_led_mode(halmac, led_mode);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: mode set fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+	} else {
+		/* Change LED to software control and turn off */
+		api->halmac_pinmux_wl_led_mode(halmac,
+					       HALMAC_WLLED_MODE_SW_CTRL);
+		api->halmac_pinmux_wl_led_sw_ctrl(halmac, 0);
+
+		status = api->halmac_pinmux_free_func(halmac,
+						      HALMAC_GPIO_FUNC_WL_LED);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: pinmux free fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+	}
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_led_switch() - Turn Hardware LED on/off
+ * @d:		struct dvobj_priv*
+ * @on:		LED light or not
+ *		0: Off
+ *		1: On(Light)
+ *
+ * Turn Hardware WLan LED On/Off.
+ * Before use this function, user should call rtw_halmac_led_ctrl() to switch
+ * mode to "software control(3)" first, otherwise control would fail.
+ * The interval between on and off must be longer than 1 ms, or the LED would
+ * keep light or dark only.
+ * Ex. Turn off LED at first, turn on after 0.5ms and turn off again after
+ * 0.5ms. The LED during this flow will only keep dark, and miss the turn on
+ * operation between two turn off operations.
+ */
+void rtw_halmac_led_switch(struct dvobj_priv *d, u8 on)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	api->halmac_pinmux_wl_led_sw_ctrl(halmac, on);
+}
+
+#ifdef CONFIG_SDIO_HCI
+
+/*
+ * Description:
+ *	Update queue allocated page number to driver
+ *
+ * Parameter:
+ *	d	pointer to struct dvobj_priv of driver
+ *
+ * Rteurn:
+ *	0	Success, "page" is valid.
+ *	others	Fail, "page" is invalid.
+ */
+int rtw_halmac_query_tx_page_num(struct dvobj_priv *d)
+{
+	PADAPTER adapter;
+	struct halmacpriv *hmpriv;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	struct halmac_rqpn_map rqpn;
+	enum halmac_dma_mapping dmaqueue;
+	struct halmac_txff_allocation fifosize;
+	enum halmac_ret_status status;
+	u8 i;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	hmpriv = &d->hmpriv;
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+	_rtw_memset((void *)&rqpn, 0, sizeof(rqpn));
+	_rtw_memset((void *)&fifosize, 0, sizeof(fifosize));
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_RQPN_MAPPING, &rqpn);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_TXFF_ALLOCATION, &fifosize);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	for (i = 0; i < HW_QUEUE_ENTRY; i++) {
+		hmpriv->txpage[i] = 0;
+
+		/* Driver index mapping to HALMAC DMA queue */
+		dmaqueue = HALMAC_DMA_MAPPING_UNDEFINE;
+		switch (i) {
+		case VO_QUEUE_INX:
+			dmaqueue = rqpn.dma_map_vo;
+			break;
+		case VI_QUEUE_INX:
+			dmaqueue = rqpn.dma_map_vi;
+			break;
+		case BE_QUEUE_INX:
+			dmaqueue = rqpn.dma_map_be;
+			break;
+		case BK_QUEUE_INX:
+			dmaqueue = rqpn.dma_map_bk;
+			break;
+		case MGT_QUEUE_INX:
+			dmaqueue = rqpn.dma_map_mg;
+			break;
+		case HIGH_QUEUE_INX:
+			dmaqueue = rqpn.dma_map_hi;
+			break;
+		case BCN_QUEUE_INX:
+		case TXCMD_QUEUE_INX:
+			/* Unlimited */
+			hmpriv->txpage[i] = 0xFFFF;
+			continue;
+		}
+
+		switch (dmaqueue) {
+		case HALMAC_DMA_MAPPING_EXTRA:
+			hmpriv->txpage[i] = fifosize.extra_queue_pg_num;
+			break;
+		case HALMAC_DMA_MAPPING_LOW:
+			hmpriv->txpage[i] = fifosize.low_queue_pg_num;
+			break;
+		case HALMAC_DMA_MAPPING_NORMAL:
+			hmpriv->txpage[i] = fifosize.normal_queue_pg_num;
+			break;
+		case HALMAC_DMA_MAPPING_HIGH:
+			hmpriv->txpage[i] = fifosize.high_queue_pg_num;
+			break;
+		case HALMAC_DMA_MAPPING_UNDEFINE:
+			break;
+		}
+		hmpriv->txpage[i] += fifosize.pub_queue_pg_num;
+	}
+
+	return 0;
+}
+
+/*
+ * Description:
+ *	Get specific queue allocated page number
+ *
+ * Parameter:
+ *	d	pointer to struct dvobj_priv of driver
+ *	queue	target queue to query, VO/VI/BE/BK/.../TXCMD_QUEUE_INX
+ *	page	return allocated page number
+ *
+ * Rteurn:
+ *	0	Success, "page" is valid.
+ *	others	Fail, "page" is invalid.
+ */
+int rtw_halmac_get_tx_queue_page_num(struct dvobj_priv *d, u8 queue, u32 *page)
+{
+	*page = 0;
+	if (queue < HW_QUEUE_ENTRY)
+		*page = d->hmpriv.txpage[queue];
+
+	return 0;
+}
+
+/*
+ * Return:
+ *	address for SDIO command
+ */
+u32 rtw_halmac_sdio_get_tx_addr(struct dvobj_priv *d, u8 *desc, u32 size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 addr;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_get_sdio_tx_addr(mac, desc, size, &addr);
+	if (HALMAC_RET_SUCCESS != status)
+		return 0;
+
+	return addr;
+}
+
+int rtw_halmac_sdio_tx_allowed(struct dvobj_priv *d, u8 *buf, u32 size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_tx_allowed_sdio(mac, buf, size);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	return 0;
+}
+
+u32 rtw_halmac_sdio_get_rx_addr(struct dvobj_priv *d, u8 *seq)
+{
+	u8 id;
+
+#define RTW_SDIO_ADDR_RX_RX0FF_PRFIX	0x0E000
+#define RTW_SDIO_ADDR_RX_RX0FF_GEN(a)	(RTW_SDIO_ADDR_RX_RX0FF_PRFIX|(a&0x3))
+
+	id = *seq;
+	(*seq)++;
+	return RTW_SDIO_ADDR_RX_RX0FF_GEN(id);
+}
+#endif /* CONFIG_SDIO_HCI */
+
+#ifdef CONFIG_USB_HCI
+u8 rtw_halmac_usb_get_bulkout_id(struct dvobj_priv *d, u8 *buf, u32 size)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u8 bulkout_id;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_get_usb_bulkout_id(mac, buf, size, &bulkout_id);
+	if (HALMAC_RET_SUCCESS != status)
+		return 0;
+
+	return bulkout_id;
+}
+
+/**
+ * rtw_halmac_usb_get_txagg_desc_num() - MAX descriptor number in one bulk for TX
+ * @d:		struct dvobj_priv*
+ * @size:	TX FIFO size, unit is byte.
+ *
+ * Get MAX descriptor number in one bulk out from HALMAC.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_usb_get_txagg_desc_num(struct dvobj_priv *d, u8 *num)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u8 val = 0;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	status = api->halmac_get_hw_value(halmac, HALMAC_HW_USB_TXAGG_DESC_NUM, &val);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	*num = val;
+
+	return 0;
+}
+
+static inline enum halmac_usb_mode _usb_mode_drv2halmac(enum RTW_USB_SPEED usb_mode)
+{
+	enum halmac_usb_mode halmac_usb_mode = HALMAC_USB_MODE_U2;
+
+	switch (usb_mode) {
+	case RTW_USB_SPEED_2:
+		halmac_usb_mode = HALMAC_USB_MODE_U2;
+		break;
+	case RTW_USB_SPEED_3:
+		halmac_usb_mode = HALMAC_USB_MODE_U3;
+		break;
+	default:
+		halmac_usb_mode = HALMAC_USB_MODE_U2;
+		break;
+	}
+
+	return halmac_usb_mode;
+}
+
+u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode)
+{
+	PADAPTER adapter;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_usb_mode halmac_usb_mode;
+
+	adapter = dvobj_get_primary_adapter(d);
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+	halmac_usb_mode = _usb_mode_drv2halmac(usb_mode);
+	status = api->halmac_set_hw_value(mac, HALMAC_HW_USB_MODE, (void *)&halmac_usb_mode);
+
+	if (HALMAC_RET_SUCCESS != status)
+		return _FAIL;
+
+	return _SUCCESS;
+}
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+int rtw_halmac_bf_add_mu_bfer(struct dvobj_priv *d, u16 paid, u16 csi_para,
+		u16 my_aid, enum halmac_csi_seg_len sel, u8 *addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	struct halmac_mu_bfer_init_para param;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	_rtw_memset(&param, 0, sizeof(param));
+	param.paid = paid;
+	param.csi_para = csi_para;
+	param.my_aid = my_aid;
+	param.csi_length_sel = sel;
+	_rtw_memcpy(param.bfer_address.addr, addr, 6);
+
+	status = api->halmac_mu_bfer_entry_init(mac, &param);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_del_mu_bfer(struct dvobj_priv *d)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_mu_bfer_entry_del(mac);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+
+int rtw_halmac_bf_cfg_sounding(struct dvobj_priv *d,
+		enum halmac_snd_role role, enum halmac_data_rate rate)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_cfg_sounding(mac, role, rate);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_del_sounding(struct dvobj_priv *d,
+		enum halmac_snd_role role)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_del_sounding(mac, role);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_cfg_csi_rate(struct dvobj_priv *d,
+		u8 rssi, u8 current_rate, u8 fixrate_en,
+		u8 *new_rate)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_cfg_csi_rate(mac,
+			rssi, current_rate, fixrate_en, new_rate);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_cfg_mu_mimo(struct dvobj_priv *d, enum halmac_snd_role role,
+		u8 *sounding_sts, u16 grouping_bitmap, u8 mu_tx_en,
+		u32 *given_gid_tab, u32 *given_user_pos)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	struct halmac_cfg_mumimo_para param;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	_rtw_memset(&param, 0, sizeof(param));
+
+	param.role = role;
+	param.grouping_bitmap = grouping_bitmap;
+	param.mu_tx_en = mu_tx_en;
+
+	if (sounding_sts)
+		_rtw_memcpy(param.sounding_sts, sounding_sts, 6);
+
+	if (given_gid_tab)
+		_rtw_memcpy(param.given_gid_tab, given_gid_tab, 8);
+
+	if (given_user_pos)
+		_rtw_memcpy(param.given_user_pos, given_user_pos, 16);
+
+	status = api->halmac_cfg_mumimo(mac, &param);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_halmac.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_halmac.h
new file mode 100644
index 000000000000..c1ed93c99883
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_halmac.h
@@ -0,0 +1,241 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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_HALMAC_H_
+#define _HAL_HALMAC_H_
+
+#include <drv_types.h>		/* adapter_to_dvobj(), struct intf_hdl and etc. */
+#include <hal_data.h>		/* struct hal_spec_t */
+#include "halmac/halmac_api.h"	/* struct halmac_adapter* and etc. */
+
+/* HALMAC Definition for Driver */
+#define RTW_HALMAC_H2C_MAX_SIZE		8
+#define RTW_HALMAC_BA_SSN_RPT_SIZE	4
+
+#define dvobj_set_halmac(d, mac)	((d)->halmac = (mac))
+#define dvobj_to_halmac(d)		((struct halmac_adapter *)((d)->halmac))
+#define adapter_to_halmac(p)		dvobj_to_halmac(adapter_to_dvobj(p))
+
+/* for H2C cmd */
+#define MAX_H2C_BOX_NUMS 4
+#define MESSAGE_BOX_SIZE 4
+#define EX_MESSAGE_BOX_SIZE 4
+
+typedef enum _RTW_HALMAC_MODE {
+	RTW_HALMAC_MODE_NORMAL,
+	RTW_HALMAC_MODE_WIFI_TEST,
+} RTW_HALMAC_MODE;
+
+union rtw_phy_para_data {
+	struct _mac {
+		u32	value;	/* value to be set in bit mask(msk) */
+		u32	msk;	/* bit mask */
+		u16	offset; /* address */
+		u8	msk_en;	/* 0/1 for msk invalid/valid */
+		u8	size;	/* Unit is bytes, and value should be 1/2/4 */
+	} mac;
+	struct _bb {
+		u32	value;
+		u32	msk;
+		u16	offset;
+		u8	msk_en;
+		u8	size;
+	} bb;
+	struct _rf {
+		u32	value;
+		u32	msk;
+		u8	offset;
+		u8	msk_en;
+		/*
+		 * 0: path A
+		 * 1: path B
+		 * 2: path C
+		 * 3: path D
+		 */
+		u8	path;
+	} rf;
+	struct _delay {
+		/*
+		 * 0: microsecond (us)
+		 * 1: millisecond (ms)
+		 */
+		u8	unit;
+		u16	value;
+	} delay;
+};
+
+struct rtw_phy_parameter {
+	/*
+	 * 0: MAC register
+	 * 1: BB register
+	 * 2: RF register
+	 * 3: Delay
+	 * 0xFF: Latest(End) command
+	 */
+	u8 cmd;
+	union rtw_phy_para_data data;
+};
+
+struct rtw_halmac_bcn_ctrl {
+	u8 rx_bssid_fit:1;	/* 0:HW handle beacon, 1:ignore */
+	u8 txbcn_rpt:1;		/* Enable TXBCN report in ad hoc and AP mode */
+	u8 tsf_update:1;	/* Update TSF when beacon or probe response */
+	u8 enable_bcn:1;	/* Enable beacon related functions */
+	u8 rxbcn_rpt:1;		/* Enable RXBCNOK report */
+	u8 p2p_ctwin:1;		/* Enable P2P CTN WINDOWS function */
+	u8 p2p_bcn_area:1;	/* Enable P2P BCN area on function */
+};
+
+extern struct halmac_platform_api rtw_halmac_platform_api;
+
+/* HALMAC API for Driver(HAL) */
+u8 rtw_halmac_read8(struct intf_hdl *, u32 addr);
+u16 rtw_halmac_read16(struct intf_hdl *, u32 addr);
+u32 rtw_halmac_read32(struct intf_hdl *, u32 addr);
+void rtw_halmac_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+u8 rtw_halmac_iread8(struct intf_hdl *pintfhdl, u32 addr);
+u16 rtw_halmac_iread16(struct intf_hdl *pintfhdl, u32 addr);
+u32 rtw_halmac_iread32(struct intf_hdl *pintfhdl, u32 addr);
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+int rtw_halmac_write8(struct intf_hdl *, u32 addr, u8 value);
+int rtw_halmac_write16(struct intf_hdl *, u32 addr, u16 value);
+int rtw_halmac_write32(struct intf_hdl *, u32 addr, u32 value);
+
+/* Software Information */
+void rtw_halmac_get_version(char *str, u32 len);
+
+/* Software Initialization */
+int rtw_halmac_init_adapter(struct dvobj_priv *d, struct halmac_platform_api *pf_api);
+int rtw_halmac_deinit_adapter(struct dvobj_priv *);
+
+/* Get operations */
+int rtw_halmac_get_hw_value(struct dvobj_priv *d, enum halmac_hw_id hw_id, void *pvalue);
+int rtw_halmac_get_tx_fifo_size(struct dvobj_priv *d, u32 *size);
+int rtw_halmac_get_rx_fifo_size(struct dvobj_priv *d, u32 *size);
+int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *d, u16 *bndy);
+int rtw_halmac_get_page_size(struct dvobj_priv *d, u32 *size);
+int rtw_halmac_get_tx_agg_align_size(struct dvobj_priv *d, u16 *size);
+int rtw_halmac_get_rx_agg_align_size(struct dvobj_priv *d, u8 *size);
+int rtw_halmac_get_rx_drv_info_sz(struct dvobj_priv *, u8 *sz);
+int rtw_halmac_get_tx_desc_size(struct dvobj_priv *d, u32 *size);
+int rtw_halmac_get_rx_desc_size(struct dvobj_priv *d, u32 *size);
+int rtw_halmac_get_ori_h2c_size(struct dvobj_priv *d, u32 *size);
+int rtw_halmac_get_oqt_size(struct dvobj_priv *d, u8 *size);
+int rtw_halmac_get_ac_queue_number(struct dvobj_priv *d, u8 *num);
+int rtw_halmac_get_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
+int rtw_halmac_get_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 *type);
+int rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport, struct rtw_halmac_bcn_ctrl *bcn_ctrl);
+/*int rtw_halmac_get_wow_reason(struct dvobj_priv *, u8 *reason);*/
+
+/* Set operations */
+int rtw_halmac_config_rx_info(struct dvobj_priv *d, enum halmac_drv_info info);
+int rtw_halmac_set_max_dl_fw_size(struct dvobj_priv *d, u32 size);
+int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
+int rtw_halmac_set_bssid(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
+int rtw_halmac_set_tx_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
+int rtw_halmac_set_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 type);
+int rtw_halmac_reset_tsf(struct dvobj_priv *d, enum _hw_port hwport);
+int rtw_halmac_set_bcn_interval(struct dvobj_priv *d, enum _hw_port hwport, u32 space);
+int rtw_halmac_set_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport, struct rtw_halmac_bcn_ctrl *bcn_ctrl);
+int rtw_halmac_set_aid(struct dvobj_priv *d, enum _hw_port hwport, u16 aid);
+int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8 bw);
+int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop);
+
+/* Functions */
+int rtw_halmac_poweron(struct dvobj_priv *);
+int rtw_halmac_poweroff(struct dvobj_priv *);
+int rtw_halmac_init_hal(struct dvobj_priv *);
+int rtw_halmac_init_hal_fw(struct dvobj_priv *, u8 *fw, u32 fwsize);
+int rtw_halmac_init_hal_fw_file(struct dvobj_priv *, u8 *fwpath);
+int rtw_halmac_deinit_hal(struct dvobj_priv *);
+int rtw_halmac_self_verify(struct dvobj_priv *);
+int rtw_halmac_txfifo_wait_empty(struct dvobj_priv *d, u32 timeout);
+int rtw_halmac_dlfw(struct dvobj_priv *, u8 *fw, u32 fwsize);
+int rtw_halmac_dlfw_from_file(struct dvobj_priv *, u8 *fwpath);
+int rtw_halmac_dlfw_mem(struct dvobj_priv *d, u8 *fw, u32 fwsize, enum fw_mem mem);
+int rtw_halmac_dlfw_mem_from_file(struct dvobj_priv *d, u8 *fwpath, enum fw_mem mem);
+int rtw_halmac_phy_power_switch(struct dvobj_priv *, u8 enable);
+int rtw_halmac_send_h2c(struct dvobj_priv *, u8 *h2c);
+int rtw_halmac_c2h_handle(struct dvobj_priv *, u8 *c2h, u32 size);
+
+/* eFuse */
+int rtw_halmac_get_available_efuse_size(struct dvobj_priv *d, u32 *size);
+int rtw_halmac_get_physical_efuse_size(struct dvobj_priv *, u32 *size);
+int rtw_halmac_read_physical_efuse_map(struct dvobj_priv *, u8 *map, u32 size);
+int rtw_halmac_read_physical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
+int rtw_halmac_write_physical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
+int rtw_halmac_get_logical_efuse_size(struct dvobj_priv *, u32 *size);
+int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *, u8 *map, u32 size, u8 *maskmap, u32 masksize);
+int rtw_halmac_write_logical_efuse_map(struct dvobj_priv *, u8 *map, u32 size, u8 *maskmap, u32 masksize);
+int rtw_halmac_read_logical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
+int rtw_halmac_write_logical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
+
+int rtw_halmac_write_bt_physical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
+int rtw_halmac_read_bt_physical_efuse_map(struct dvobj_priv *, u8 *map, u32 size);
+
+int rtw_halmac_dump_fifo(struct dvobj_priv *d, u8 fifo_sel, u32 addr, u32 size, u8 *buffer);
+int rtw_halmac_rx_agg_switch(struct dvobj_priv *, u8 enable);
+
+/* Specific function APIs*/
+int rtw_halmac_download_rsvd_page(struct dvobj_priv *dvobj, u8 pg_offset, u8 *pbuf, u32 size);
+int rtw_halmac_fill_hal_spec(struct dvobj_priv *, struct hal_spec_t *);
+int rtw_halmac_p2pps(struct dvobj_priv *dvobj, PHAL_P2P_PS_PARA pp2p_ps_para);
+int rtw_halmac_iqk(struct dvobj_priv *d, u8 clear, u8 segment);
+int rtw_halmac_cfg_phy_para(struct dvobj_priv *d, struct rtw_phy_parameter *para);
+int rtw_halmac_led_cfg(struct dvobj_priv *d, u8 enable, u8 mode);
+void rtw_halmac_led_switch(struct dvobj_priv *d, u8 on);
+
+#ifdef CONFIG_SDIO_HCI
+int rtw_halmac_query_tx_page_num(struct dvobj_priv *);
+int rtw_halmac_get_tx_queue_page_num(struct dvobj_priv *, u8 queue, u32 *page);
+u32 rtw_halmac_sdio_get_tx_addr(struct dvobj_priv *, u8 *desc, u32 size);
+int rtw_halmac_sdio_tx_allowed(struct dvobj_priv *, u8 *buf, u32 size);
+u32 rtw_halmac_sdio_get_rx_addr(struct dvobj_priv *, u8 *seq);
+#endif /* CONFIG_SDIO_HCI */
+
+#ifdef CONFIG_USB_HCI
+u8 rtw_halmac_usb_get_bulkout_id(struct dvobj_priv *, u8 *buf, u32 size);
+int rtw_halmac_usb_get_txagg_desc_num(struct dvobj_priv *d, u8 *num);
+u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+void dump_trx_share_mode(void *sel, _adapter *adapter);
+#endif
+
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+int rtw_halmac_bf_add_mu_bfer(struct dvobj_priv *d, u16 paid, u16 csi_para,
+		u16 my_aid, enum halmac_csi_seg_len sel, u8 *addr);
+int rtw_halmac_bf_del_mu_bfer(struct dvobj_priv *d);
+
+int rtw_halmac_bf_cfg_sounding(struct dvobj_priv *d, enum halmac_snd_role role,
+		enum halmac_data_rate rate);
+int rtw_halmac_bf_del_sounding(struct dvobj_priv *d, enum halmac_snd_role role);
+
+int rtw_halmac_bf_cfg_csi_rate(struct dvobj_priv *d, u8 rssi, u8 current_rate,
+		u8 fixrate_en, u8 *new_rate);
+
+int rtw_halmac_bf_cfg_mu_mimo(struct dvobj_priv *d, enum halmac_snd_role role,
+		u8 *sounding_sts, u16 grouping_bitmap, u8 mu_tx_en,
+		u32 *given_gid_tab, u32 *given_user_pos);
+#define rtw_halmac_bf_cfg_mu_bfee(d, gid_tab, user_pos) \
+	rtw_halmac_bf_cfg_mu_mimo(d, HAL_BFEE, NULL, 0, 0, gid_tab, user_pos)
+
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+
+#endif /* _HAL_HALMAC_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_hci/hal_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_hci/hal_sdio.c
index 1ee0a9ddd0a0..e6fa762df36e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_hci/hal_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_hci/hal_sdio.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,32 +12,127 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _HAL_SDIO_C_
 
 #include <drv_types.h>
 #include <hal_data.h>
 
+#ifndef RTW_HALMAC
+static void dump_mac_page0(PADAPTER padapter)
+{
+	char str_out[128];
+	char str_val[8];
+	char *p = NULL;
+	int index = 0, i = 0;
+	u8 val8 = 0, len = 0;
+
+	RTW_ERR("Dump MAC Page0 register:\n");
+	for (index = 0 ; index < 0x100 ; index += 16) {
+		p = &str_out[0];
+		len = snprintf(str_val, sizeof(str_val),
+			       "0x%02x: ", index);
+		strncpy(str_out, str_val, len);
+		p += len;
+
+		for (i = 0 ; i < 16 ; i++) {
+			len = snprintf(str_val, sizeof(str_val), "%02x ",
+				       rtw_read8(padapter, index + i));
+			strncpy(p, str_val, len);
+			p += len;
+		}
+		RTW_INFO("%s\n", str_out);
+		_rtw_memset(&str_out, '\0', sizeof(str_out));
+	}
+}
+
+/*
+ * Description:
+ *	Call this function to make sure power on successfully
+ *
+ * Return:
+ *	_SUCCESS	enable success
+ *	_FAIL	enable fail
+ */
+bool sdio_power_on_check(PADAPTER padapter) {
+	u32 val_offset0, val_offset1, val_offset2, val_offset3;
+	u32 val_mix = 0;
+	u32 res = 0;
+	bool ret = _FAIL;
+	int index = 0;
+
+	val_offset0 = rtw_read8(padapter, REG_CR);
+	val_offset1 = rtw_read8(padapter, REG_CR + 1);
+	val_offset2 = rtw_read8(padapter, REG_CR + 2);
+	val_offset3 = rtw_read8(padapter, REG_CR + 3);
+
+	if (val_offset0 == 0xEA || val_offset1 == 0xEA ||
+	    val_offset2 == 0xEA || val_offset3 == 0xEA) {
+		RTW_INFO("%s: power on fail, do Power on again\n", __func__);
+		return ret;
+	}
+
+	val_mix = val_offset3 << 24 | val_mix;
+	val_mix = val_offset2 << 16 | val_mix;
+	val_mix = val_offset1 << 8 | val_mix;
+	val_mix = val_offset0 | val_mix;
+
+	res = rtw_read32(padapter, REG_CR);
+
+	RTW_INFO("%s: val_mix:0x%08x, res:0x%08x\n", __func__, val_mix, res);
+
+	while (index < 100) {
+		if (res == val_mix) {
+			RTW_INFO("%s: 0x100 the result of cmd52 and cmd53 is the same.\n", __func__);
+			ret = _SUCCESS;
+			break;
+		} else {
+			RTW_INFO("%s: 0x100 cmd52 and cmd53 is not the same(index:%d).\n", __func__, index);
+			res = rtw_read32(padapter, REG_CR);
+			index++;
+			ret = _FAIL;
+		}
+	}
+
+	if (ret) {
+		index = 0;
+		while (index < 100) {
+			rtw_write32(padapter, 0x1B8, 0x12345678);
+			res = rtw_read32(padapter, 0x1B8);
+			if (res == 0x12345678) {
+				RTW_INFO("%s: 0x1B8 test Pass.\n", __func__);
+				ret = _SUCCESS;
+				break;
+			} else {
+				index++;
+				RTW_INFO("%s: 0x1B8 test Fail(index: %d).\n", __func__, index);
+				ret = _FAIL;
+			}
+		}
+	} else
+		RTW_INFO("%s: fail at cmd52, cmd53.\n", __func__);
+
+	if (ret == _FAIL)
+		dump_mac_page0(padapter);
+
+	return ret;
+}
+
 u8 rtw_hal_sdio_max_txoqt_free_space(_adapter *padapter)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
-	if(pHalData->SdioTxOQTMaxFreeSpace < 8 )
+	if (pHalData->SdioTxOQTMaxFreeSpace < 8)
 		pHalData->SdioTxOQTMaxFreeSpace = 8;
 
-	return pHalData->SdioTxOQTMaxFreeSpace;	
+	return pHalData->SdioTxOQTMaxFreeSpace;
 }
 
 u8 rtw_hal_sdio_query_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
-	if ((pHalData->SdioTxFIFOFreePage[PageIdx]+pHalData->SdioTxFIFOFreePage[PUBLIC_QUEUE_IDX]) >= (RequiredPageNum))
+	if ((pHalData->SdioTxFIFOFreePage[PageIdx] + pHalData->SdioTxFIFOFreePage[PUBLIC_QUEUE_IDX]) >= (RequiredPageNum))
 		return _TRUE;
 	else
 		return _FALSE;
@@ -47,20 +143,20 @@ void rtw_hal_sdio_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 Required
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	u8	DedicatedPgNum = 0;
 	u8	RequiredPublicFreePgNum = 0;
-	//_irqL irql;
+	/* _irqL irql; */
 
-	//_enter_critical_bh(&pHalData->SdioTxFIFOFreePageLock, &irql);
+	/* _enter_critical_bh(&pHalData->SdioTxFIFOFreePageLock, &irql); */
 
 	DedicatedPgNum = pHalData->SdioTxFIFOFreePage[PageIdx];
-	if (RequiredPageNum <= DedicatedPgNum) {
+	if (RequiredPageNum <= DedicatedPgNum)
 		pHalData->SdioTxFIFOFreePage[PageIdx] -= RequiredPageNum;
-	} else {
+	else {
 		pHalData->SdioTxFIFOFreePage[PageIdx] = 0;
 		RequiredPublicFreePgNum = RequiredPageNum - DedicatedPgNum;
 		pHalData->SdioTxFIFOFreePage[PUBLIC_QUEUE_IDX] -= RequiredPublicFreePgNum;
 	}
 
-	//_exit_critical_bh(&pHalData->SdioTxFIFOFreePageLock, &irql);
+	/* _exit_critical_bh(&pHalData->SdioTxFIFOFreePageLock, &irql); */
 }
 
 void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ)
@@ -69,15 +165,15 @@ void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 nu
 	u32	page_size;
 	u32	lenHQ, lenNQ, lenLQ;
 
-	rtw_hal_get_def_var(padapter, HAL_DEF_TX_PAGE_SIZE,&page_size);
+	rtw_hal_get_def_var(padapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
 
 	lenHQ = ((numHQ + numPubQ) >> 1) * page_size;
 	lenNQ = ((numNQ + numPubQ) >> 1) * page_size;
 	lenLQ = ((numLQ + numPubQ) >> 1) * page_size;
 
-	pHalData->sdio_tx_max_len[HI_QUEUE_IDX] = (lenHQ > MAX_XMITBUF_SZ)? MAX_XMITBUF_SZ:lenHQ;
-	pHalData->sdio_tx_max_len[MID_QUEUE_IDX] = (lenNQ > MAX_XMITBUF_SZ)? MAX_XMITBUF_SZ:lenNQ;
-	pHalData->sdio_tx_max_len[LOW_QUEUE_IDX] = (lenLQ > MAX_XMITBUF_SZ)? MAX_XMITBUF_SZ:lenLQ;
+	pHalData->sdio_tx_max_len[HI_QUEUE_IDX] = (lenHQ > MAX_XMITBUF_SZ) ? MAX_XMITBUF_SZ : lenHQ;
+	pHalData->sdio_tx_max_len[MID_QUEUE_IDX] = (lenNQ > MAX_XMITBUF_SZ) ? MAX_XMITBUF_SZ : lenNQ;
+	pHalData->sdio_tx_max_len[LOW_QUEUE_IDX] = (lenLQ > MAX_XMITBUF_SZ) ? MAX_XMITBUF_SZ : lenLQ;
 }
 
 u32 rtw_hal_get_sdio_tx_max_length(PADAPTER padapter, u8 queue_idx)
@@ -85,28 +181,55 @@ u32 rtw_hal_get_sdio_tx_max_length(PADAPTER padapter, u8 queue_idx)
 	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	u32	deviceId, max_len;
-	
+
 
 	deviceId = ffaddr2deviceId(pdvobjpriv, queue_idx);
 	switch (deviceId) {
-		case WLAN_TX_HIQ_DEVICE_ID:
-			max_len = pHalData->sdio_tx_max_len[HI_QUEUE_IDX];
-			break;
+	case WLAN_TX_HIQ_DEVICE_ID:
+		max_len = pHalData->sdio_tx_max_len[HI_QUEUE_IDX];
+		break;
 
-		case WLAN_TX_MIQ_DEVICE_ID:
-			max_len = pHalData->sdio_tx_max_len[MID_QUEUE_IDX];
-			break;
+	case WLAN_TX_MIQ_DEVICE_ID:
+		max_len = pHalData->sdio_tx_max_len[MID_QUEUE_IDX];
+		break;
 
-		case WLAN_TX_LOQ_DEVICE_ID:
-			max_len = pHalData->sdio_tx_max_len[LOW_QUEUE_IDX];
-			break;
+	case WLAN_TX_LOQ_DEVICE_ID:
+		max_len = pHalData->sdio_tx_max_len[LOW_QUEUE_IDX];
+		break;
 
-		default:
-			max_len = pHalData->sdio_tx_max_len[MID_QUEUE_IDX];
-			break;
+	default:
+		max_len = pHalData->sdio_tx_max_len[MID_QUEUE_IDX];
+		break;
 	}
 
 	return max_len;
 }
 
+#ifdef CONFIG_FW_C2H_REG
+void sd_c2h_hisr_hdl(_adapter *adapter)
+{
+	u8 c2h_evt[C2H_REG_LEN] = {0};
+	u8 id, seq, plen;
+	u8 *payload;
+
+	if (rtw_hal_c2h_evt_read(adapter, c2h_evt) != _SUCCESS)
+		goto exit;
+
+	if (rtw_hal_c2h_reg_hdr_parse(adapter, c2h_evt, &id, &seq, &plen, &payload) != _SUCCESS)
+		goto exit;
+		
+	if (rtw_hal_c2h_id_handle_directly(adapter, id, seq, plen, payload)) {
+		/* Handle directly */
+		rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
+		goto exit;
+	}
+
+	if (rtw_c2h_reg_wk_cmd(adapter, c2h_evt) != _SUCCESS)
+		RTW_ERR("%s rtw_c2h_reg_wk_cmd fail\n", __func__);
+
+exit:
+	return;
+}
+#endif
 
+#endif /* !RTW_HALMAC */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_intf.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_intf.c
index a232bbda8575..0bf02db93b6d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_intf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_intf.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #define _HAL_INTF_C_
 
@@ -33,43 +29,58 @@ const u32 _chip_type_to_odm_ic_type[] = {
 	ODM_RTL8814A,
 	ODM_RTL8703B,
 	ODM_RTL8188F,
+	ODM_RTL8188F,
+	ODM_RTL8822B,
+	ODM_RTL8723D,
+	ODM_RTL8821C,
 	0,
 };
 
 void rtw_hal_chip_configure(_adapter *padapter)
 {
-	padapter->HalFunc.intf_chip_configure(padapter);
+	padapter->hal_func.intf_chip_configure(padapter);
 }
 
-void rtw_hal_read_chip_info(_adapter *padapter)
+/*
+ * Description:
+ *	Read chip internal ROM data
+ *
+ * Return:
+ *	_SUCCESS success
+ *	_FAIL	 fail
+ */
+u8 rtw_hal_read_chip_info(_adapter *padapter)
 {
+	u8 rtn = _SUCCESS;
 	u8 hci_type = rtw_get_intf_type(padapter);
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 
 	/*  before access eFuse, make sure card enable has been called */
 	if ((hci_type == RTW_SDIO || hci_type == RTW_GSPI)
-		&& !rtw_is_hw_init_completed(padapter))
+	    && !rtw_is_hw_init_completed(padapter))
 		rtw_hal_power_on(padapter);
 
-	padapter->HalFunc.read_adapter_info(padapter);
+	rtn = padapter->hal_func.read_adapter_info(padapter);
 
 	if ((hci_type == RTW_SDIO || hci_type == RTW_GSPI)
-		&& !rtw_is_hw_init_completed(padapter))
+	    && !rtw_is_hw_init_completed(padapter))
 		rtw_hal_power_off(padapter);
 
-	DBG_871X("%s in %d ms\n", __func__, rtw_get_passing_time_ms(start));
+	RTW_INFO("%s in %d ms\n", __func__, rtw_get_passing_time_ms(start));
+
+	return rtn;
 }
 
 void rtw_hal_read_chip_version(_adapter *padapter)
 {
-	padapter->HalFunc.read_chip_version(padapter);
+	padapter->hal_func.read_chip_version(padapter);
 	rtw_odm_init_ic_type(padapter);
 }
 
 void rtw_hal_def_value_init(_adapter *padapter)
 {
 	if (is_primary_adapter(padapter)) {
-		padapter->HalFunc.init_default_value(padapter);
+		padapter->hal_func.init_default_value(padapter);
 
 		rtw_init_hal_com_default_value(padapter);
 
@@ -91,8 +102,8 @@ u8 rtw_hal_data_init(_adapter *padapter)
 	if (is_primary_adapter(padapter)) {
 		padapter->hal_data_sz = sizeof(HAL_DATA_TYPE);
 		padapter->HalData = rtw_zvmalloc(padapter->hal_data_sz);
-		if(padapter->HalData == NULL){
-			DBG_8192C("cant not alloc memory for HAL DATA \n");
+		if (padapter->HalData == NULL) {
+			RTW_INFO("cant not alloc memory for HAL DATA\n");
 			return _FAIL;
 		}
 	}
@@ -100,31 +111,30 @@ u8 rtw_hal_data_init(_adapter *padapter)
 }
 
 void rtw_hal_data_deinit(_adapter *padapter)
-{	
+{
 	if (is_primary_adapter(padapter)) {
-		if (padapter->HalData) 
-		{
-			#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
-			phy_free_filebuf(padapter);				
-			#endif
+		if (padapter->HalData) {
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+			phy_free_filebuf(padapter);
+#endif
 			rtw_vmfree(padapter->HalData, padapter->hal_data_sz);
 			padapter->HalData = NULL;
 			padapter->hal_data_sz = 0;
-		}	
+		}
 	}
 }
 
 void	rtw_hal_free_data(_adapter *padapter)
 {
-	//free HAL Data 	
-	rtw_hal_data_deinit(padapter);	
+	/* free HAL Data	 */
+	rtw_hal_data_deinit(padapter);
 }
 void rtw_hal_dm_init(_adapter *padapter)
 {
 	if (is_primary_adapter(padapter)) {
 		PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-		
-		padapter->HalFunc.dm_init(padapter);
+
+		padapter->hal_func.dm_init(padapter);
 
 		_rtw_spinlock_init(&pHalData->IQKSpinLock);
 
@@ -134,28 +144,60 @@ void rtw_hal_dm_init(_adapter *padapter)
 void rtw_hal_dm_deinit(_adapter *padapter)
 {
 	if (is_primary_adapter(padapter)) {
-		PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);		
+		PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 
-		padapter->HalFunc.dm_deinit(padapter);
+		padapter->hal_func.dm_deinit(padapter);
 
 		_rtw_spinlock_free(&pHalData->IQKSpinLock);
 	}
 }
-void	rtw_hal_sw_led_init(_adapter *padapter)
+
+#ifdef CONFIG_RTW_SW_LED
+void rtw_hal_sw_led_init(_adapter *padapter)
 {
-	if(padapter->HalFunc.InitSwLeds)
-		padapter->HalFunc.InitSwLeds(padapter);
+	struct led_priv *ledpriv = adapter_to_led(padapter);
+
+	if (ledpriv->bRegUseLed == _FALSE)
+		return;
+
+	if (!is_primary_adapter(padapter))
+		return;
+
+	if (padapter->hal_func.InitSwLeds) {
+		padapter->hal_func.InitSwLeds(padapter);
+		rtw_led_set_ctl_en_mask_primary(padapter);
+		rtw_led_set_iface_en(padapter, 1);
+	}
 }
 
 void rtw_hal_sw_led_deinit(_adapter *padapter)
 {
-	if(padapter->HalFunc.DeInitSwLeds)
-		padapter->HalFunc.DeInitSwLeds(padapter);
+	struct led_priv *ledpriv = adapter_to_led(padapter);
+
+	if (ledpriv->bRegUseLed == _FALSE)
+		return;
+
+	if (!is_primary_adapter(padapter))
+		return;
+
+	if (padapter->hal_func.DeInitSwLeds)
+		padapter->hal_func.DeInitSwLeds(padapter);
 }
+#endif
 
 u32 rtw_hal_power_on(_adapter *padapter)
-{	
-	return padapter->HalFunc.hal_power_on(padapter);
+{
+	u32 ret = 0;
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+
+	ret = padapter->hal_func.hal_power_on(padapter);
+
+#ifdef CONFIG_BT_COEXIST
+	if ((ret == _SUCCESS) && (pHalData->EEPROMBluetoothCoexist == _TRUE))
+		rtw_btcoex_PowerOnSetting(padapter);
+#endif
+
+	return ret;
 }
 void rtw_hal_power_off(_adapter *padapter)
 {
@@ -163,11 +205,15 @@ void rtw_hal_power_off(_adapter *padapter)
 
 	_rtw_memset(macid_ctl->h2c_msr, 0, MACID_NUM_SW_LIMIT);
 
-	padapter->HalFunc.hal_power_off(padapter);
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_PowerOffSetting(padapter);
+#endif
+
+	padapter->hal_func.hal_power_off(padapter);
 }
 
 
-void rtw_hal_init_opmode(_adapter *padapter) 
+void rtw_hal_init_opmode(_adapter *padapter)
 {
 	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType = Ndis802_11InfrastructureMax;
 	struct  mlme_priv *pmlmepriv = &(padapter->mlmepriv);
@@ -175,199 +221,269 @@ void rtw_hal_init_opmode(_adapter *padapter)
 
 	fw_state = get_fwstate(pmlmepriv);
 
-	if (fw_state & WIFI_ADHOC_STATE) 
+	if (fw_state & WIFI_ADHOC_STATE)
 		networkType = Ndis802_11IBSS;
 	else if (fw_state & WIFI_STATION_STATE)
 		networkType = Ndis802_11Infrastructure;
+#ifdef CONFIG_AP_MODE
 	else if (fw_state & WIFI_AP_STATE)
 		networkType = Ndis802_11APMode;
+#endif
+#ifdef CONFIG_RTW_MESH
+	else if (fw_state & WIFI_MESH_STATE)
+		networkType = Ndis802_11_mesh;
+#endif
 	else
 		return;
 
-	rtw_setopmode_cmd(padapter, networkType, _FALSE); 
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_DIRECTLY);
 }
 
-uint	 rtw_hal_init(_adapter *padapter) 
+uint	 rtw_hal_init(_adapter *padapter)
 {
 	uint	status = _SUCCESS;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 	int i;
 
-	status = padapter->HalFunc.hal_init(padapter);
-	
+	status = padapter->hal_func.hal_init(padapter);
+
 	if (status == _SUCCESS) {
-		pHalData->hw_init_completed = _TRUE;
-			
+		rtw_set_hw_init_completed(padapter, _TRUE);
+		rtw_restore_mac_addr(padapter);
+		#ifdef RTW_HALMAC
+		rtw_restore_hw_port_cfg(padapter);
+		#endif
 		if (padapter->registrypriv.notch_filter == 1)
 			rtw_hal_notch_filter(padapter, 1);
 
-		for (i = 0; i<dvobj->iface_nums; i++)
+		for (i = 0; i < dvobj->iface_nums; i++)
 			rtw_sec_restore_wep_key(dvobj->padapters[i]);
 
 		rtw_led_control(padapter, LED_CTL_POWER_ON);
 
 		init_hw_mlme_ext(padapter);
 
-                rtw_hal_init_opmode(padapter);
-		
-#ifdef CONFIG_RF_GAIN_OFFSET
+		rtw_hal_init_opmode(padapter);
+
+#ifdef CONFIG_RF_POWER_TRIM
 		rtw_bb_rf_gain_offset(padapter);
-#endif //CONFIG_RF_GAIN_OFFSET
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+#if (RTL8822B_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)
+#ifdef CONFIG_DYNAMIC_SOML
+		rtw_dyn_soml_config(padapter);
+#endif
+#endif
 
 	} else {
-		pHalData->hw_init_completed = _FALSE;
-		DBG_871X("rtw_hal_init: hal__init fail\n");
+		rtw_set_hw_init_completed(padapter, _FALSE);
+		RTW_ERR("%s: fail\n", __func__);
 	}
 
-	RT_TRACE(_module_hal_init_c_,_drv_err_,("-rtl871x_hal_init:status=0x%x\n",status));
 
 	return status;
 
-}	
+}
 
 uint rtw_hal_deinit(_adapter *padapter)
 {
 	uint	status = _SUCCESS;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 	int i;
-_func_enter_;
 
-	status = padapter->HalFunc.hal_deinit(padapter);
+	status = padapter->hal_func.hal_deinit(padapter);
 
-	if(status == _SUCCESS){
+	if (status == _SUCCESS) {
 		rtw_led_control(padapter, LED_CTL_POWER_OFF);
-		pHalData->hw_init_completed = _FALSE;
-	}
-	else
-	{
-		DBG_871X("\n rtw_hal_deinit: hal_init fail\n");
-	}
+		rtw_set_hw_init_completed(padapter, _FALSE);
+	} else
+		RTW_INFO("\n rtw_hal_deinit: hal_init fail\n");
+
 
-_func_exit_;
-	
 	return status;
 }
 
-void rtw_hal_set_hwreg(_adapter *padapter, u8 variable, u8 *val)
+u8 rtw_hal_set_hwreg(_adapter *padapter, u8 variable, u8 *val)
 {
-	padapter->HalFunc.SetHwRegHandler(padapter, variable, val);
+	return padapter->hal_func.set_hw_reg_handler(padapter, variable, val);
 }
 
 void rtw_hal_get_hwreg(_adapter *padapter, u8 variable, u8 *val)
 {
-	padapter->HalFunc.GetHwRegHandler(padapter, variable, val);
-}
-
-#ifdef CONFIG_C2H_PACKET_EN
-void rtw_hal_set_hwreg_with_buf(_adapter *padapter, u8 variable, u8 *pbuf, int len)
-{
-	if (padapter->HalFunc.SetHwRegHandlerWithBuf)
-		padapter->HalFunc.SetHwRegHandlerWithBuf(padapter, variable, pbuf, len);
+	padapter->hal_func.GetHwRegHandler(padapter, variable, val);
 }
-#endif
 
 u8 rtw_hal_set_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue)
-{	
-	return padapter->HalFunc.SetHalDefVarHandler(padapter,eVariable,pValue);
+{
+	return padapter->hal_func.SetHalDefVarHandler(padapter, eVariable, pValue);
 }
 u8 rtw_hal_get_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue)
-{	
-	return padapter->HalFunc.GetHalDefVarHandler(padapter,eVariable,pValue);		
-}	
+{
+	return padapter->hal_func.get_hal_def_var_handler(padapter, eVariable, pValue);
+}
 
-void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,BOOLEAN bSet)
+void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, BOOLEAN bSet)
 {
-	padapter->HalFunc.SetHalODMVarHandler(padapter,eVariable,pValue1,bSet);
+	padapter->hal_func.SetHalODMVarHandler(padapter, eVariable, pValue1, bSet);
 }
-void	rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,PVOID pValue2)
+void	rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, PVOID pValue2)
 {
-	padapter->HalFunc.GetHalODMVarHandler(padapter,eVariable,pValue1,pValue2);
+	padapter->hal_func.GetHalODMVarHandler(padapter, eVariable, pValue1, pValue2);
 }
 
 /* FOR SDIO & PCIE */
 void rtw_hal_enable_interrupt(_adapter *padapter)
 {
-#if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
-	padapter->HalFunc.enable_interrupt(padapter);	
-#endif //#if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
+#if defined(CONFIG_PCI_HCI) || defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
+	padapter->hal_func.enable_interrupt(padapter);
+#endif /* #if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI) */
 }
 
 /* FOR SDIO & PCIE */
 void rtw_hal_disable_interrupt(_adapter *padapter)
 {
-#if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
-	padapter->HalFunc.disable_interrupt(padapter);
-#endif //#if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
+#if defined(CONFIG_PCI_HCI) || defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
+	padapter->hal_func.disable_interrupt(padapter);
+#endif /* #if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI) */
 }
 
 
 u8 rtw_hal_check_ips_status(_adapter *padapter)
 {
 	u8 val = _FALSE;
-	if (padapter->HalFunc.check_ips_status)
-		val = padapter->HalFunc.check_ips_status(padapter);
-	else 
-		DBG_871X("%s: HalFunc.check_ips_status is NULL!\n", __FUNCTION__);
-	
+	if (padapter->hal_func.check_ips_status)
+		val = padapter->hal_func.check_ips_status(padapter);
+	else
+		RTW_INFO("%s: hal_func.check_ips_status is NULL!\n", __FUNCTION__);
+
 	return val;
 }
 
 s32 rtw_hal_fw_dl(_adapter *padapter, u8 wowlan)
 {
-	return padapter->HalFunc.fw_dl(padapter, wowlan);
+	return padapter->hal_func.fw_dl(padapter, wowlan);
 }
 
+#ifdef RTW_HALMAC
+s32 rtw_hal_fw_mem_dl(_adapter *padapter, enum fw_mem mem)
+{
+	systime dlfw_start_time = rtw_get_current_time();
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
+	s32 rst = _FALSE;
+
+	rst = padapter->hal_func.fw_mem_dl(padapter, mem);
+	RTW_INFO("%s in %dms\n", __func__, rtw_get_passing_time_ms(dlfw_start_time));
+
+	if (rst == _FALSE)
+		pdbgpriv->dbg_fw_mem_dl_error_cnt++;
+	if (1)
+		RTW_INFO("%s dbg_fw_mem_dl_error_cnt:%d\n", __func__, pdbgpriv->dbg_fw_mem_dl_error_cnt);
+	return rst;
+}
+#endif
+
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 void rtw_hal_clear_interrupt(_adapter *padapter)
-{  
+{
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	padapter->HalFunc.clear_interrupt(padapter);
+	padapter->hal_func.clear_interrupt(padapter);
 #endif
 }
 #endif
 
-#if defined(CONFIG_USB_HCI) || defined (CONFIG_PCI_HCI)
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
 u32	rtw_hal_inirp_init(_adapter *padapter)
 {
-	if (is_primary_adapter(padapter)) 		
-		return padapter->HalFunc.inirp_init(padapter);	
-	 return _SUCCESS;
+	if (is_primary_adapter(padapter))
+		return padapter->hal_func.inirp_init(padapter);
+	return _SUCCESS;
 }
 u32	rtw_hal_inirp_deinit(_adapter *padapter)
 {
 
-	if (is_primary_adapter(padapter)) 	
-		return padapter->HalFunc.inirp_deinit(padapter);
+	if (is_primary_adapter(padapter))
+		return padapter->hal_func.inirp_deinit(padapter);
 
 	return _SUCCESS;
 }
-#endif //#if defined(CONFIG_USB_HCI) || defined (CONFIG_PCI_HCI)
+#endif /* #if defined(CONFIG_USB_HCI) || defined (CONFIG_PCI_HCI) */
 
 #if defined(CONFIG_PCI_HCI)
 void	rtw_hal_irp_reset(_adapter *padapter)
 {
-	padapter->HalFunc.irp_reset(padapter);
+	padapter->hal_func.irp_reset(GET_PRIMARY_ADAPTER(padapter));
+}
+
+void rtw_hal_pci_dbi_write(_adapter *padapter, u16 addr, u8 data)
+{
+	u16 cmd[2];
+
+	cmd[0] = addr;
+	cmd[1] = data;
+
+	padapter->hal_func.set_hw_reg_handler(padapter, HW_VAR_DBI, (u8 *) cmd);
+}
+
+u8 rtw_hal_pci_dbi_read(_adapter *padapter, u16 addr)
+{
+	padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_DBI, (u8 *)(&addr));
+
+	return (u8)addr;
+}
+
+void rtw_hal_pci_mdio_write(_adapter *padapter, u8 addr, u16 data)
+{
+	u16 cmd[2];
+
+	cmd[0] = (u16)addr;
+	cmd[1] = data;
+
+	padapter->hal_func.set_hw_reg_handler(padapter, HW_VAR_MDIO, (u8 *) cmd);
+}
+
+u16 rtw_hal_pci_mdio_read(_adapter *padapter, u8 addr)
+{
+	padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_MDIO, &addr);
+
+	return (u8)addr;
+}
+
+u8 rtw_hal_pci_l1off_nic_support(_adapter *padapter)
+{
+	u8 l1off;
+
+	padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_L1OFF_NIC_SUPPORT, &l1off);
+	return l1off;
+}
+
+u8 rtw_hal_pci_l1off_capability(_adapter *padapter)
+{
+	u8 l1off;
+
+	padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_L1OFF_CAPABILITY, &l1off);
+	return l1off;
 }
-#endif //#if defined(CONFIG_PCI_HCI)
+
+
+#endif /* #if defined(CONFIG_PCI_HCI) */
 
 /* for USB Auto-suspend */
-u8	rtw_hal_intf_ps_func(_adapter *padapter,HAL_INTF_PS_FUNC efunc_id, u8* val)
-{	
-	if(padapter->HalFunc.interface_ps_func)	
-		return padapter->HalFunc.interface_ps_func(padapter,efunc_id,val);
+u8	rtw_hal_intf_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val)
+{
+	if (padapter->hal_func.interface_ps_func)
+		return padapter->hal_func.interface_ps_func(padapter, efunc_id, val);
 	return _FAIL;
 }
 
 s32	rtw_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
-	return padapter->HalFunc.hal_xmitframe_enqueue(padapter, pxmitframe);
+	return padapter->hal_func.hal_xmitframe_enqueue(padapter, pxmitframe);
 }
 
 s32	rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
-	return padapter->HalFunc.hal_xmit(padapter, pxmitframe);
+	return padapter->hal_func.hal_xmit(padapter, pxmitframe);
 }
 
 /*
@@ -376,132 +492,124 @@ s32	rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe)
 s32	rtw_hal_mgnt_xmit(_adapter *padapter, struct xmit_frame *pmgntframe)
 {
 	s32 ret = _FAIL;
-	u8	*pframe, subtype;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct sta_info	*psta;
-	struct sta_priv		*pstapriv = &padapter->stapriv;
-	
+
 	update_mgntframe_attrib_addr(padapter, pmgntframe);
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	subtype = GetFrameSubType(pframe); /* bit(7)~bit(2) */
-	
-	//pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-	//_rtw_memcpy(pmgntframe->attrib.ra, pwlanhdr->addr1, ETH_ALEN);
-
-#ifdef CONFIG_IEEE80211W
-	if (padapter->securitypriv.binstallBIPkey == _TRUE && (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC ||
-			subtype == WIFI_ACTION))
-	{
-		if (IS_MCAST(pmgntframe->attrib.ra) && pmgntframe->attrib.key_type != IEEE80211W_NO_KEY) {
-			pmgntframe->attrib.encrypt = _BIP_;
-			/* pmgntframe->attrib.bswenc = _TRUE; */
-		} else if (pmgntframe->attrib.key_type != IEEE80211W_NO_KEY) {
-			psta = rtw_get_stainfo(pstapriv, pmgntframe->attrib.ra);
-			if (psta && psta->bpairwise_key_installed == _TRUE) {
-				pmgntframe->attrib.encrypt = _AES_;
-				pmgntframe->attrib.bswenc = _TRUE;
-			} else {
-				DBG_871X("%s, %d, bpairwise_key_installed is FALSE\n", __func__, __LINE__);
-				goto no_mgmt_coalesce;
-			}
-		}
-		DBG_871X("encrypt=%d, bswenc=%d\n", pmgntframe->attrib.encrypt, pmgntframe->attrib.bswenc);
+
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+	if ((!MLME_IS_MESH(padapter) && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE)
+		#ifdef CONFIG_RTW_MESH
+		|| (MLME_IS_MESH(padapter) && padapter->mesh_info.mesh_auth_id)
+		#endif
+	)
 		rtw_mgmt_xmitframe_coalesce(padapter, pmgntframe->pkt, pmgntframe);
-	}
-#endif //CONFIG_IEEE80211W
+#endif
+
 no_mgmt_coalesce:
-	ret = padapter->HalFunc.mgnt_xmit(padapter, pmgntframe);
+	ret = padapter->hal_func.mgnt_xmit(padapter, pmgntframe);
 	return ret;
 }
 
 s32	rtw_hal_init_xmit_priv(_adapter *padapter)
-{	
-	return padapter->HalFunc.init_xmit_priv(padapter);	
+{
+	return padapter->hal_func.init_xmit_priv(padapter);
 }
 void	rtw_hal_free_xmit_priv(_adapter *padapter)
 {
-	padapter->HalFunc.free_xmit_priv(padapter);
+	padapter->hal_func.free_xmit_priv(padapter);
 }
 
 s32	rtw_hal_init_recv_priv(_adapter *padapter)
-{	
-	return padapter->HalFunc.init_recv_priv(padapter);
+{
+	return padapter->hal_func.init_recv_priv(padapter);
 }
 void	rtw_hal_free_recv_priv(_adapter *padapter)
 {
-	padapter->HalFunc.free_recv_priv(padapter);
+	padapter->hal_func.free_recv_priv(padapter);
 }
 
-void rtw_hal_update_ra_mask(struct sta_info *psta, u8 rssi_level)
+void rtw_sta_ra_registed(_adapter *padapter, struct sta_info *psta)
 {
-	_adapter *padapter;
-	struct mlme_priv *pmlmepriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 
-	if(!psta)
+	if (psta == NULL) {
+		RTW_ERR(FUNC_ADPT_FMT" sta is NULL\n", FUNC_ADPT_ARG(padapter));
+		rtw_warn_on(1);
 		return;
-
-	padapter = psta->padapter;
-
-	pmlmepriv = &(padapter->mlmepriv);
-	
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
-		add_RATid(padapter, psta, rssi_level);
 	}
-	else
-	{
-		padapter->HalFunc.UpdateRAMaskHandler(padapter, psta->mac_id, rssi_level);
+
+#ifdef CONFIG_AP_MODE
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+		if (psta->cmn.aid > padapter->stapriv.max_aid) {
+			RTW_ERR("station aid %d exceed the max number\n", psta->cmn.aid);
+			rtw_warn_on(1);
+			return;
+		}
+		rtw_ap_update_sta_ra_info(padapter, psta);
 	}
+#endif
+
+	psta->cmn.ra_info.ra_bw_mode = rtw_get_tx_bw_mode(padapter, psta);
+	/*set correct initial date rate for each mac_id */
+	hal_data->INIDATA_RATE[psta->cmn.mac_id] = psta->init_rate;
+
+	rtw_phydm_ra_registed(padapter, psta);
 }
 
-void	rtw_hal_add_ra_tid(_adapter *padapter, u64 bitmap, u8 *arg, u8 rssi_level)
+void rtw_hal_update_ra_mask(struct sta_info *psta)
 {
-	padapter->HalFunc.Add_RateATid(padapter, bitmap, arg, rssi_level);
+	_adapter *padapter;
+
+	if (!psta)
+		return;
+
+	padapter = psta->padapter;
+	rtw_sta_ra_registed(padapter, psta);
 }
 
 /*	Start specifical interface thread		*/
 void	rtw_hal_start_thread(_adapter *padapter)
 {
-#if defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
-#ifndef CONFIG_SDIO_TX_TASKLET	
-	padapter->HalFunc.run_thread(padapter);	
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#ifndef CONFIG_SDIO_TX_TASKLET
+	padapter->hal_func.run_thread(padapter);
 #endif
 #endif
 }
 /*	Start specifical interface thread		*/
 void	rtw_hal_stop_thread(_adapter *padapter)
 {
-#if defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 #ifndef CONFIG_SDIO_TX_TASKLET
-	
-	padapter->HalFunc.cancel_thread(padapter);
-	
+
+	padapter->hal_func.cancel_thread(padapter);
+
+#endif
 #endif
-#endif	
 }
 
 u32	rtw_hal_read_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask)
 {
 	u32 data = 0;
-	if(padapter->HalFunc.read_bbreg)
-		 data = padapter->HalFunc.read_bbreg(padapter, RegAddr, BitMask);
+	if (padapter->hal_func.read_bbreg)
+		data = padapter->hal_func.read_bbreg(padapter, RegAddr, BitMask);
 	return data;
 }
 void	rtw_hal_write_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data)
 {
-	if(padapter->HalFunc.write_bbreg)
-		padapter->HalFunc.write_bbreg(padapter, RegAddr, BitMask, Data);
+	if (padapter->hal_func.write_bbreg)
+		padapter->hal_func.write_bbreg(padapter, RegAddr, BitMask, Data);
 }
 
-u32 rtw_hal_read_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask)
+u32 rtw_hal_read_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask)
 {
 	u32 data = 0;
 
-	if (padapter->HalFunc.read_rfreg) {
-		data = padapter->HalFunc.read_rfreg(padapter, eRFPath, RegAddr, BitMask);
+	if (padapter->hal_func.read_rfreg) {
+		data = padapter->hal_func.read_rfreg(padapter, eRFPath, RegAddr, BitMask);
 
 		if (match_rf_read_sniff_ranges(eRFPath, RegAddr, BitMask)) {
-			DBG_871X("DBG_IO rtw_hal_read_rfreg(%u, 0x%04x, 0x%08x) read:0x%08x(0x%08x)\n"
+			RTW_INFO("DBG_IO rtw_hal_read_rfreg(%u, 0x%04x, 0x%08x) read:0x%08x(0x%08x)\n"
 				, eRFPath, RegAddr, BitMask, (data << PHY_CalculateBitShift(BitMask)), data);
 		}
 	}
@@ -509,16 +617,16 @@ u32 rtw_hal_read_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask
 	return data;
 }
 
-void rtw_hal_write_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
+void rtw_hal_write_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
 {
-	if (padapter->HalFunc.write_rfreg) {
+	if (padapter->hal_func.write_rfreg) {
 
 		if (match_rf_write_sniff_ranges(eRFPath, RegAddr, BitMask)) {
-			DBG_871X("DBG_IO rtw_hal_write_rfreg(%u, 0x%04x, 0x%08x) write:0x%08x(0x%08x)\n"
+			RTW_INFO("DBG_IO rtw_hal_write_rfreg(%u, 0x%04x, 0x%08x) write:0x%08x(0x%08x)\n"
 				, eRFPath, RegAddr, BitMask, (Data << PHY_CalculateBitShift(BitMask)), Data);
 		}
 
-		padapter->HalFunc.write_rfreg(padapter, eRFPath, RegAddr, BitMask, Data);
+		padapter->hal_func.write_rfreg(padapter, eRFPath, RegAddr, BitMask, Data);
 
 #ifdef CONFIG_PCI_HCI
 		if (!IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(padapter)) /*For N-Series IC, suggest by Jenyu*/
@@ -531,33 +639,33 @@ void rtw_hal_write_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMa
 s32	rtw_hal_interrupt_handler(_adapter *padapter)
 {
 	s32 ret = _FAIL;
-	ret = padapter->HalFunc.interrupt_handler(padapter);
+	ret = padapter->hal_func.interrupt_handler(padapter);
 	return ret;
 }
 #endif
 #if defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
 void	rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf)
 {
-	padapter->HalFunc.interrupt_handler(padapter, pkt_len, pbuf);
+	padapter->hal_func.interrupt_handler(padapter, pkt_len, pbuf);
 }
 #endif
 
-void	rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth, u8 Offset40, u8 Offset80)
+void	rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
 	u8 cch_160 = Bandwidth == CHANNEL_WIDTH_160 ? channel : 0;
 	u8 cch_80 = Bandwidth == CHANNEL_WIDTH_80 ? channel : 0;
 	u8 cch_40 = Bandwidth == CHANNEL_WIDTH_40 ? channel : 0;
 	u8 cch_20 = Bandwidth == CHANNEL_WIDTH_20 ? channel : 0;
 
-	ODM_AcquireSpinLock(pDM_Odm, RT_IQK_SPINLOCK);
-	if (pDM_Odm->RFCalibrateInfo.bIQKInProgress == _TRUE)
+	if (rtw_phydm_is_iqk_in_progress(padapter))
 		RTW_ERR("%s, %d, IQK may race condition\n", __func__, __LINE__);
-	ODM_ReleaseSpinLock(pDM_Odm, RT_IQK_SPINLOCK);
 
+#ifdef CONFIG_MP_INCLUDED
 	/* MP mode channel don't use secondary channel */
-	if (rtw_mp_mode_check(padapter) == _FALSE) {
+	if (rtw_mp_mode_check(padapter) == _FALSE)
+#endif
+	{
 		#if 0
 		if (cch_160 != 0)
 			cch_80 = rtw_get_scch_by_cch_offset(cch_160, CHANNEL_WIDTH_160, Offset80);
@@ -577,571 +685,889 @@ void	rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth
 			, channel, ch_width_str(Bandwidth), Offset40, Offset80
 			, pHalData->cch_80, pHalData->cch_40, pHalData->cch_20);
 
-	padapter->HalFunc.set_chnl_bw_handler(padapter, channel, Bandwidth, Offset40, Offset80);
+	padapter->hal_func.set_chnl_bw_handler(padapter, channel, Bandwidth, Offset40, Offset80);
 }
 
 void	rtw_hal_set_tx_power_level(_adapter *padapter, u8 channel)
 {
-	if(padapter->HalFunc.set_tx_power_level_handler)
-		padapter->HalFunc.set_tx_power_level_handler(padapter, channel);
+	if (padapter->hal_func.set_tx_power_level_handler)
+		padapter->hal_func.set_tx_power_level_handler(padapter, channel);
 }
 
 void	rtw_hal_get_tx_power_level(_adapter *padapter, s32 *powerlevel)
 {
-	if(padapter->HalFunc.get_tx_power_level_handler)
-		padapter->HalFunc.get_tx_power_level_handler(padapter, powerlevel);
+	if (padapter->hal_func.get_tx_power_level_handler)
+		padapter->hal_func.get_tx_power_level_handler(padapter, powerlevel);
 }
 
 void	rtw_hal_dm_watchdog(_adapter *padapter)
 {
-	if (!is_primary_adapter(padapter))
-		return;
 
-	padapter->HalFunc.hal_dm_watchdog(padapter);
-	
+	rtw_hal_turbo_edca(padapter);
+	padapter->hal_func.hal_dm_watchdog(padapter);
+
+#ifdef CONFIG_PCI_DYNAMIC_ASPM
+	rtw_pci_aspm_config_dynamic_l1_ilde_time(padapter);
+#endif
 }
 
 #ifdef CONFIG_LPS_LCLK_WD_TIMER
 void	rtw_hal_dm_watchdog_in_lps(_adapter *padapter)
 {
 #if defined(CONFIG_CONCURRENT_MODE)
-	if (padapter->iface_type != IFACE_PORT0)
+#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
+	if (padapter->hw_port != HW_PORT0)
 		return;
-#endif	
-
-	if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode ==_TRUE ) {
-		padapter->HalFunc.hal_dm_watchdog_in_lps(padapter);//this fuction caller is in interrupt context				 	
-	}
-}
+#endif
 #endif
 
-void rtw_hal_bcn_related_reg_setting(_adapter *padapter)
-{	
-	padapter->HalFunc.SetBeaconRelatedRegistersHandler(padapter);	
+	if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
+		rtw_phydm_watchdog_in_lps_lclk(padapter);/* this function caller is in interrupt context */
 }
+#endif /*CONFIG_LPS_LCLK_WD_TIMER*/
 
-
-#ifdef CONFIG_ANTENNA_DIVERSITY
-u8	rtw_hal_antdiv_before_linked(_adapter *padapter)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	int i;
-
-	if (!padapter->HalFunc.AntDivBeforeLinkHandler)
-		return _FALSE;
-
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		if (rtw_linked_check(dvobj->padapters[i]))
-			return _FALSE;
-	}
-
-	return padapter->HalFunc.AntDivBeforeLinkHandler(padapter);
-}
-void	rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src)
+void rtw_hal_bcn_related_reg_setting(_adapter *padapter)
 {
-	if(padapter->HalFunc.AntDivCompareHandler)
-		padapter->HalFunc.AntDivCompareHandler(padapter, dst, src);
+	padapter->hal_func.SetBeaconRelatedRegistersHandler(padapter);
 }
-#endif
 
 #ifdef CONFIG_HOSTAPD_MLME
 s32	rtw_hal_hostap_mgnt_xmit_entry(_adapter *padapter, _pkt *pkt)
 {
-	if(padapter->HalFunc.hostap_mgnt_xmit_entry)
-		return padapter->HalFunc.hostap_mgnt_xmit_entry(padapter, pkt);
+	if (padapter->hal_func.hostap_mgnt_xmit_entry)
+		return padapter->hal_func.hostap_mgnt_xmit_entry(padapter, pkt);
 	return _FAIL;
 }
-#endif //CONFIG_HOSTAPD_MLME
+#endif /* CONFIG_HOSTAPD_MLME */
 
 #ifdef DBG_CONFIG_ERROR_DETECT
 void	rtw_hal_sreset_init(_adapter *padapter)
 {
-	padapter->HalFunc.sreset_init_value(padapter); 
+	padapter->hal_func.sreset_init_value(padapter);
 }
 void rtw_hal_sreset_reset(_adapter *padapter)
 {
 	padapter = GET_PRIMARY_ADAPTER(padapter);
-	padapter->HalFunc.silentreset(padapter);
+	padapter->hal_func.silentreset(padapter);
 }
 
 void rtw_hal_sreset_reset_value(_adapter *padapter)
 {
-	padapter->HalFunc.sreset_reset_value(padapter);
+	padapter->hal_func.sreset_reset_value(padapter);
 }
 
 void rtw_hal_sreset_xmit_status_check(_adapter *padapter)
 {
-	if (!is_primary_adapter(padapter))
-		return;
-
-	padapter->HalFunc.sreset_xmit_status_check(padapter);		
+	padapter->hal_func.sreset_xmit_status_check(padapter);
 }
 void rtw_hal_sreset_linked_status_check(_adapter *padapter)
 {
-	if (!is_primary_adapter(padapter))
-		return;
-	padapter->HalFunc.sreset_linked_status_check(padapter);	
+	padapter->hal_func.sreset_linked_status_check(padapter);
 }
 u8   rtw_hal_sreset_get_wifi_status(_adapter *padapter)
-{	
-	return padapter->HalFunc.sreset_get_wifi_status(padapter);
+{
+	return padapter->hal_func.sreset_get_wifi_status(padapter);
 }
 
 bool rtw_hal_sreset_inprogress(_adapter *padapter)
 {
 	padapter = GET_PRIMARY_ADAPTER(padapter);
-	return padapter->HalFunc.sreset_inprogress(padapter);
+	return padapter->hal_func.sreset_inprogress(padapter);
 }
-#endif	//DBG_CONFIG_ERROR_DETECT
+#endif /* DBG_CONFIG_ERROR_DETECT */
 
 #ifdef CONFIG_IOL
-int rtw_hal_iol_cmd(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt)
+int rtw_hal_iol_cmd(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_waiting_ms, u32 bndy_cnt)
 {
-	if(adapter->HalFunc.IOL_exec_cmds_sync)
-		return adapter->HalFunc.IOL_exec_cmds_sync(adapter, xmit_frame, max_wating_ms,bndy_cnt);
+	if (adapter->hal_func.IOL_exec_cmds_sync)
+		return adapter->hal_func.IOL_exec_cmds_sync(adapter, xmit_frame, max_waiting_ms, bndy_cnt);
 	return _FAIL;
 }
 #endif
 
 #ifdef CONFIG_XMIT_THREAD_MODE
 s32 rtw_hal_xmit_thread_handler(_adapter *padapter)
-{	
-	return padapter->HalFunc.xmit_thread_handler(padapter);
+{
+	return padapter->hal_func.xmit_thread_handler(padapter);
 }
 #endif
 
 #ifdef CONFIG_RECV_THREAD_MODE
 s32 rtw_hal_recv_hdl(_adapter *adapter)
 {
-	return adapter->HalFunc.recv_hdl(adapter);
+	return adapter->hal_func.recv_hdl(adapter);
 }
 #endif
 
 void rtw_hal_notch_filter(_adapter *adapter, bool enable)
 {
-	if(adapter->HalFunc.hal_notch_filter)
-		adapter->HalFunc.hal_notch_filter(adapter,enable);		
+	if (adapter->hal_func.hal_notch_filter)
+		adapter->hal_func.hal_notch_filter(adapter, enable);
 }
 
-bool rtw_hal_c2h_valid(_adapter *adapter, u8 *buf)
+#ifdef CONFIG_FW_C2H_REG
+inline bool rtw_hal_c2h_valid(_adapter *adapter, u8 *buf)
 {
 	HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
-	HAL_VERSION *hal_ver = &HalData->VersionID;
+	HAL_VERSION *hal_ver = &HalData->version_id;
 	bool ret = _FAIL;
 
-	if (IS_8188E(*hal_ver)) {
-		ret = c2h_evt_valid((struct c2h_evt_hdr *)buf);
-	} else if(IS_8192E(*hal_ver) || IS_8812_SERIES(*hal_ver) || IS_8821_SERIES(*hal_ver) || IS_8723B_SERIES(*hal_ver)) {
-		ret = c2h_evt_valid((struct c2h_evt_hdr_88xx*)buf);
-	} else {
-		rtw_warn_on(1);
-	}
+	ret = C2H_ID_88XX(buf) || C2H_PLEN_88XX(buf);
 
 	return ret;
 }
 
-s32 rtw_hal_c2h_evt_read(_adapter *adapter, u8 *buf)
+inline s32 rtw_hal_c2h_evt_read(_adapter *adapter, u8 *buf)
 {
 	HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
-	HAL_VERSION *hal_ver = &HalData->VersionID;
+	HAL_VERSION *hal_ver = &HalData->version_id;
 	s32 ret = _FAIL;
 
-	if (IS_8188E(*hal_ver)) {
-		ret = c2h_evt_read(adapter, buf);
-	} else if(IS_8192E(*hal_ver) || IS_8812_SERIES(*hal_ver) || IS_8821_SERIES(*hal_ver) || IS_8723B_SERIES(*hal_ver)) {
-		ret = c2h_evt_read_88xx(adapter, buf);
-	} else {
-		rtw_warn_on(1);
+	ret = c2h_evt_read_88xx(adapter, buf);
+
+	return ret;
+}
+
+bool rtw_hal_c2h_reg_hdr_parse(_adapter *adapter, u8 *buf, u8 *id, u8 *seq, u8 *plen, u8 **payload)
+{
+	HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
+	HAL_VERSION *hal_ver = &HalData->version_id;
+	bool ret = _FAIL;
+
+	*id = C2H_ID_88XX(buf);
+	*seq = C2H_SEQ_88XX(buf);
+	*plen = C2H_PLEN_88XX(buf);
+	*payload = C2H_PAYLOAD_88XX(buf);
+	ret = _SUCCESS;
+
+	return ret;
+}
+#endif /* CONFIG_FW_C2H_REG */
+
+#ifdef CONFIG_FW_C2H_PKT
+bool rtw_hal_c2h_pkt_hdr_parse(_adapter *adapter, u8 *buf, u16 len, u8 *id, u8 *seq, u8 *plen, u8 **payload)
+{
+	HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
+	HAL_VERSION *hal_ver = &HalData->version_id;
+	bool ret = _FAIL;
+
+	if (!buf || len > 256 || len < 3)
+		goto exit;
+
+	*id = C2H_ID_88XX(buf);
+	*seq = C2H_SEQ_88XX(buf);
+	*plen = len - 2;
+	*payload = C2H_PAYLOAD_88XX(buf);
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_FW_C2H_PKT */
+
+#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTL8723B)
+#include <rtw_bt_mp.h> /* for MPTBT_FwC2hBtMpCtrl */
+#endif
+s32 c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
+{
+	u8 sub_id = 0;
+	s32 ret = _SUCCESS;
+
+	switch (id) {
+	case C2H_FW_SCAN_COMPLETE:
+		RTW_INFO("[C2H], FW Scan Complete\n");
+		break;
+
+#ifdef CONFIG_BT_COEXIST
+	case C2H_BT_INFO:
+		rtw_btcoex_BtInfoNotify(adapter, plen, payload);
+		break;
+	case C2H_BT_MP_INFO:
+		#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTL8723B)
+		MPTBT_FwC2hBtMpCtrl(adapter, payload, plen);
+		#endif
+		rtw_btcoex_BtMpRptNotify(adapter, plen, payload);
+		break;
+	case C2H_MAILBOX_STATUS:
+		RTW_DBG_DUMP("C2H_MAILBOX_STATUS: ", payload, plen);
+		break;
+	case C2H_WLAN_INFO:
+		rtw_btcoex_WlFwDbgInfoNotify(adapter, payload, plen);
+		break;
+#endif /* CONFIG_BT_COEXIST */
+
+	case C2H_IQK_FINISH:
+		c2h_iqk_offload(adapter, payload, plen);
+		break;
+
+#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
+	case C2H_FW_CHNL_SWITCH_COMPLETE:
+		rtw_tdls_chsw_oper_done(adapter);
+		break;
+	case C2H_BCN_EARLY_RPT:
+		rtw_tdls_ch_sw_back_to_base_chnl(adapter);
+		break;
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	case C2H_MCC:
+		rtw_hal_mcc_c2h_handler(adapter, plen, payload);
+		break;
+#endif
+
+#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
+	case C2H_MAC_HIDDEN_RPT:
+		c2h_mac_hidden_rpt_hdl(adapter, payload, plen);
+		break;
+	case C2H_MAC_HIDDEN_RPT_2:
+		c2h_mac_hidden_rpt_2_hdl(adapter, payload, plen);
+		break;
+#endif
+
+	case C2H_DEFEATURE_DBG:
+		c2h_defeature_dbg_hdl(adapter, payload, plen);
+		break;
+
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	case C2H_CUSTOMER_STR_RPT:
+		c2h_customer_str_rpt_hdl(adapter, payload, plen);
+		break;
+	case C2H_CUSTOMER_STR_RPT_2:
+		c2h_customer_str_rpt_2_hdl(adapter, payload, plen);
+		break;
+#endif
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	case C2H_PER_RATE_RPT:
+		c2h_per_rate_rpt_hdl(adapter, payload, plen);
+		break;
+#endif
+	case C2H_EXTEND:
+		sub_id = payload[0];
+		/* no handle, goto default */
+
+	default:
+		if (phydm_c2H_content_parsing(adapter_to_phydm(adapter), id, plen, payload) != TRUE)
+			ret = _FAIL;
+		break;
+	}
+
+exit:
+	if (ret != _SUCCESS) {
+		if (id == C2H_EXTEND)
+			RTW_WARN("%s: unknown C2H(0x%02x, 0x%02x)\n", __func__, id, sub_id);
+		else
+			RTW_WARN("%s: unknown C2H(0x%02x)\n", __func__, id);
 	}
 
 	return ret;
 }
 
-s32 rtw_hal_c2h_handler(_adapter *adapter, u8 *c2h_evt)
+#ifndef RTW_HALMAC
+s32 rtw_hal_c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
 {
 	s32 ret = _FAIL;
-	if (adapter->HalFunc.c2h_handler)
-		ret = adapter->HalFunc.c2h_handler(adapter, c2h_evt);
+
+	ret = adapter->hal_func.c2h_handler(adapter, id, seq, plen, payload);
+	if (ret != _SUCCESS)
+		ret = c2h_handler(adapter, id, seq, plen, payload);
+
 	return ret;
 }
 
-c2h_id_filter rtw_hal_c2h_id_filter_ccx(_adapter *adapter)
-{	
-	return adapter->HalFunc.c2h_id_filter_ccx;
+s32 rtw_hal_c2h_id_handle_directly(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
+{
+	switch (id) {
+	case C2H_CCX_TX_RPT:
+	case C2H_BT_MP_INFO:
+	case C2H_FW_CHNL_SWITCH_COMPLETE:
+	case C2H_IQK_FINISH:
+	case C2H_MCC:
+	case C2H_BCN_EARLY_RPT:
+	case C2H_AP_REQ_TXRPT:
+	case C2H_SPC_STAT:
+		return _TRUE;
+	default:
+		return _FALSE;
+	}
 }
+#endif /* !RTW_HALMAC */
 
 s32 rtw_hal_is_disable_sw_channel_plan(PADAPTER padapter)
 {
 	return GET_HAL_DATA(padapter)->bDisableSWChannelPlan;
 }
 
-s32 rtw_hal_macid_sleep(PADAPTER padapter, u8 macid)
+static s32 _rtw_hal_macid_sleep(_adapter *adapter, u8 macid, u8 sleep)
 {
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	u8 support;
-
-	support = _FALSE;
-	rtw_hal_get_def_var(padapter, HAL_DEF_MACID_SLEEP, &support);
-	if (_FALSE == support)
-		return _FAIL;
+	struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
+	u16 reg_sleep;
+	u8 bit_shift;
+	u32 val32;
+	s32 ret = _FAIL;
 
 	if (macid >= macid_ctl->num) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT": Invalid macid(%u)\n",
-			FUNC_ADPT_ARG(padapter), macid);
-		return _FAIL;
+		RTW_ERR(ADPT_FMT" %s invalid macid(%u)\n"
+			, ADPT_ARG(adapter), sleep ? "sleep" : "wakeup" , macid);
+		goto exit;
+	}
+
+	if (macid < 32) {
+		reg_sleep = macid_ctl->reg_sleep_m0;
+		bit_shift = macid;
+	#if (MACID_NUM_SW_LIMIT > 32)
+	} else if (macid < 64) {
+		reg_sleep = macid_ctl->reg_sleep_m1;
+		bit_shift = macid - 32;
+	#endif
+	#if (MACID_NUM_SW_LIMIT > 64)
+	} else if (macid < 96) {
+		reg_sleep = macid_ctl->reg_sleep_m2;
+		bit_shift = macid - 64;
+	#endif
+	#if (MACID_NUM_SW_LIMIT > 96)
+	} else if (macid < 128) {
+		reg_sleep = macid_ctl->reg_sleep_m3;
+		bit_shift = macid - 96;
+	#endif
+	} else {
+		rtw_warn_on(1);
+		goto exit;
 	}
 
-	rtw_hal_set_hwreg(padapter, HW_VAR_MACID_SLEEP, &macid);
+	if (!reg_sleep) {
+		rtw_warn_on(1);
+		goto exit;
+	}
 
-	return _SUCCESS;
+	val32 = rtw_read32(adapter, reg_sleep);
+	RTW_INFO(ADPT_FMT" %s macid=%d, ori reg_0x%03x=0x%08x\n"
+		, ADPT_ARG(adapter), sleep ? "sleep" : "wakeup"
+		, macid, reg_sleep, val32);
+
+	ret = _SUCCESS;
+
+	if (sleep) {
+		if (val32 & BIT(bit_shift))
+			goto exit;
+		val32 |= BIT(bit_shift);
+	} else {
+		if (!(val32 & BIT(bit_shift)))
+			goto exit;
+		val32 &= ~BIT(bit_shift);
+	}
+
+	rtw_write32(adapter, reg_sleep, val32);
+
+exit:
+	return ret;
 }
 
-s32 rtw_hal_macid_wakeup(PADAPTER padapter, u8 macid)
+inline s32 rtw_hal_macid_sleep(_adapter *adapter, u8 macid)
 {
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	u8 support;
+	return _rtw_hal_macid_sleep(adapter, macid, 1);
+}
 
-	support = _FALSE;
-	rtw_hal_get_def_var(padapter, HAL_DEF_MACID_SLEEP, &support);
-	if (_FALSE == support)
-		return _FAIL;
+inline s32 rtw_hal_macid_wakeup(_adapter *adapter, u8 macid)
+{
+	return _rtw_hal_macid_sleep(adapter, macid, 0);
+}
 
-	if (macid >= macid_ctl->num) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT": Invalid macid(%u)\n",
-			FUNC_ADPT_ARG(padapter), macid);
-		return _FAIL;
-	}
+static s32 _rtw_hal_macid_bmp_sleep(_adapter *adapter, struct macid_bmp *bmp, u8 sleep)
+{
+	struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
+	u16 reg_sleep;
+	u32 *m = &bmp->m0;
+	u8 mid = 0;
+	u32 val32;
 
-	rtw_hal_set_hwreg(padapter, HW_VAR_MACID_WAKEUP, &macid);
+	do {
+		if (*m == 0)
+			goto move_next;
+
+		if (mid == 0)
+			reg_sleep = macid_ctl->reg_sleep_m0;
+		#if (MACID_NUM_SW_LIMIT > 32)
+		else if (mid == 1)
+			reg_sleep = macid_ctl->reg_sleep_m1;
+		#endif
+		#if (MACID_NUM_SW_LIMIT > 64)
+		else if (mid == 2)
+			reg_sleep = macid_ctl->reg_sleep_m2;
+		#endif
+		#if (MACID_NUM_SW_LIMIT > 96)
+		else if (mid == 3)
+			reg_sleep = macid_ctl->reg_sleep_m3;
+		#endif
+		else {
+			rtw_warn_on(1);
+			break;
+		}
+
+		if (!reg_sleep) {
+			rtw_warn_on(1);
+			break;
+		}
+
+		val32 = rtw_read32(adapter, reg_sleep);
+		RTW_INFO(ADPT_FMT" %s m%u=0x%08x, ori reg_0x%03x=0x%08x\n"
+			, ADPT_ARG(adapter), sleep ? "sleep" : "wakeup"
+			, mid, *m, reg_sleep, val32);
+
+		if (sleep) {
+			if ((val32 & *m) == *m)
+				goto move_next;
+			val32 |= *m;
+		} else {
+			if ((val32 & *m) == 0)
+				goto move_next;
+			val32 &= ~(*m);
+		}
+
+		rtw_write32(adapter, reg_sleep, val32);
+
+move_next:
+		m++;
+		mid++;
+	} while (mid * 32 < MACID_NUM_SW_LIMIT);
 
 	return _SUCCESS;
 }
 
+inline s32 rtw_hal_macid_sleep_all_used(_adapter *adapter)
+{
+	struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
+
+	return _rtw_hal_macid_bmp_sleep(adapter, &macid_ctl->used, 1);
+}
+
+inline s32 rtw_hal_macid_wakeup_all_used(_adapter *adapter)
+{
+	struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
+
+	return _rtw_hal_macid_bmp_sleep(adapter, &macid_ctl->used, 0);
+}
+
 s32 rtw_hal_fill_h2c_cmd(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)
 {
 	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(padapter);
 
-	if (pri_adapter->bFWReady == _TRUE)
-		return padapter->HalFunc.fill_h2c_cmd(padapter, ElementID, CmdLen, pCmdBuffer);
+	if (GET_HAL_DATA(pri_adapter)->bFWReady == _TRUE)
+		return padapter->hal_func.fill_h2c_cmd(padapter, ElementID, CmdLen, pCmdBuffer);
 	else if (padapter->registrypriv.mp_mode == 0)
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" FW doesn't exit when no MP mode, by pass H2C id:0x%02x\n"
-			, FUNC_ADPT_ARG(padapter), ElementID);
+		RTW_PRINT(FUNC_ADPT_FMT" FW doesn't exit when no MP mode, by pass H2C id:0x%02x\n"
+			  , FUNC_ADPT_ARG(padapter), ElementID);
 	return _FAIL;
 }
 
-void rtw_hal_fill_fake_txdesc(_adapter* padapter, u8* pDesc, u32 BufferLen,
-		u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame)
+void rtw_hal_fill_fake_txdesc(_adapter *padapter, u8 *pDesc, u32 BufferLen,
+			      u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame)
 {
-	padapter->HalFunc.fill_fake_txdesc(padapter, pDesc, BufferLen,IsPsPoll, IsBTQosNull, bDataFrame);
+	padapter->hal_func.fill_fake_txdesc(padapter, pDesc, BufferLen, IsPsPoll, IsBTQosNull, bDataFrame);
 
 }
+
 u8 rtw_hal_get_txbuff_rsvd_page_num(_adapter *adapter, bool wowlan)
 {
-	return adapter->HalFunc.hal_get_tx_buff_rsvd_page_num(adapter, wowlan);
+	u8 num = 0;
+
+
+	if (adapter->hal_func.hal_get_tx_buff_rsvd_page_num) {
+		num = adapter->hal_func.hal_get_tx_buff_rsvd_page_num(adapter, wowlan);
+	} else {
+#ifdef RTW_HALMAC
+		num = GET_HAL_DATA(adapter)->drv_rsvd_page_number;
+#endif /* RTW_HALMAC */
+	}
+
+	return num;
 }
 
 #ifdef CONFIG_GPIO_API
 void rtw_hal_update_hisr_hsisr_ind(_adapter *padapter, u32 flag)
 {
-	if (padapter->HalFunc.update_hisr_hsisr_ind)
-		padapter->HalFunc.update_hisr_hsisr_ind(padapter, flag);
+	if (padapter->hal_func.update_hisr_hsisr_ind)
+		padapter->hal_func.update_hisr_hsisr_ind(padapter, flag);
+}
+
+int rtw_hal_gpio_func_check(_adapter *padapter, u8 gpio_num)
+{
+	int ret = _SUCCESS;
+
+	if (padapter->hal_func.hal_gpio_func_check)
+		ret = padapter->hal_func.hal_gpio_func_check(padapter, gpio_num);
+
+	return ret;
+}
+
+void rtw_hal_gpio_multi_func_reset(_adapter *padapter, u8 gpio_num)
+{
+	if (padapter->hal_func.hal_gpio_multi_func_reset)
+		padapter->hal_func.hal_gpio_multi_func_reset(padapter, gpio_num);
 }
 #endif
 
 void rtw_hal_fw_correct_bcn(_adapter *padapter)
 {
-	if (padapter->HalFunc.fw_correct_bcn)
-		padapter->HalFunc.fw_correct_bcn(padapter);
+	if (padapter->hal_func.fw_correct_bcn)
+		padapter->hal_func.fw_correct_bcn(padapter);
+}
+
+void rtw_hal_set_tx_power_index(PADAPTER padapter, u32 powerindex, enum rf_path rfpath, u8 rate)
+{
+	return padapter->hal_func.set_tx_power_index_handler(padapter, powerindex, rfpath, rate);
+}
+
+u8 rtw_hal_get_tx_power_index(PADAPTER padapter, enum rf_path rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic)
+{
+	return padapter->hal_func.get_tx_power_index_handler(padapter, rfpath, rate, bandwidth, channel, tic);
 }
 
-void rtw_hal_set_tx_power_index(PADAPTER padapter, u32 powerindex, u8 rfpath, u8 rate)
+#ifdef RTW_HALMAC
+/*
+ * Description:
+ *	Initialize MAC registers
+ *
+ * Return:
+ *	_TRUE	success
+ *	_FALSE	fail
+ */
+u8 rtw_hal_init_mac_register(PADAPTER adapter)
 {
-	return padapter->HalFunc.set_tx_power_index_handler(padapter, powerindex, rfpath, rate);
+	return adapter->hal_func.init_mac_register(adapter);
 }
 
-u8 rtw_hal_get_tx_power_index(PADAPTER padapter, u8 rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic)
+/*
+ * Description:
+ *	Initialize PHY(BB/RF) related functions
+ *
+ * Return:
+ *	_TRUE	success
+ *	_FALSE	fail
+ */
+u8 rtw_hal_init_phy(PADAPTER adapter)
 {
-	return padapter->HalFunc.get_tx_power_index_handler(padapter, rfpath, rate, bandwidth, channel, tic);
+	return adapter->hal_func.init_phy(adapter);
 }
+#endif /* RTW_HALMAC */
+
+#ifdef CONFIG_RFKILL_POLL
+bool rtw_hal_rfkill_poll(_adapter *adapter, u8 *valid)
+{
+	bool ret;
+
+	if (adapter->hal_func.hal_radio_onoff_check)
+		ret = adapter->hal_func.hal_radio_onoff_check(adapter, valid);
+	else {
+		*valid = 0;
+		ret = _FALSE;
+	}
+	return ret;
+}
+#endif
 
 #define rtw_hal_error_msg(ops_fun)		\
-	DBG_871X_LEVEL(_drv_always_, "### %s - Error : Please hook HalFunc.%s ###\n",__FUNCTION__,ops_fun)
+	RTW_PRINT("### %s - Error : Please hook hal_func.%s ###\n", __FUNCTION__, ops_fun)
 
 u8 rtw_hal_ops_check(_adapter *padapter)
-{	
+{
 	u8 ret = _SUCCESS;
 #if 1
 	/*** initialize section ***/
-	if (NULL == padapter->HalFunc.read_chip_version) {
+	if (NULL == padapter->hal_func.read_chip_version) {
 		rtw_hal_error_msg("read_chip_version");
 		ret = _FAIL;
-	}	
-	if (NULL == padapter->HalFunc.init_default_value) {
+	}
+	if (NULL == padapter->hal_func.init_default_value) {
 		rtw_hal_error_msg("init_default_value");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.intf_chip_configure) {
+	if (NULL == padapter->hal_func.intf_chip_configure) {
 		rtw_hal_error_msg("intf_chip_configure");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.read_adapter_info) {
+	if (NULL == padapter->hal_func.read_adapter_info) {
 		rtw_hal_error_msg("read_adapter_info");
 		ret = _FAIL;
 	}
 
-	if (NULL == padapter->HalFunc.hal_power_on) {		
+	if (NULL == padapter->hal_func.hal_power_on) {
 		rtw_hal_error_msg("hal_power_on");
 		ret = _FAIL;
-	}	
-	if (NULL == padapter->HalFunc.hal_power_off) {
+	}
+	if (NULL == padapter->hal_func.hal_power_off) {
 		rtw_hal_error_msg("hal_power_off");
 		ret = _FAIL;
 	}
-	
-	if (NULL == padapter->HalFunc.hal_init) {
+
+	if (NULL == padapter->hal_func.hal_init) {
 		rtw_hal_error_msg("hal_init");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.hal_deinit) {
+	if (NULL == padapter->hal_func.hal_deinit) {
 		rtw_hal_error_msg("hal_deinit");
 		ret = _FAIL;
 	}
-	
+
 	/*** xmit section ***/
-	if (NULL == padapter->HalFunc.init_xmit_priv) {
+	if (NULL == padapter->hal_func.init_xmit_priv) {
 		rtw_hal_error_msg("init_xmit_priv");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.free_xmit_priv) {
+	if (NULL == padapter->hal_func.free_xmit_priv) {
 		rtw_hal_error_msg("free_xmit_priv");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.hal_xmit) {
+	if (NULL == padapter->hal_func.hal_xmit) {
 		rtw_hal_error_msg("hal_xmit");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.mgnt_xmit) {
+	if (NULL == padapter->hal_func.mgnt_xmit) {
 		rtw_hal_error_msg("mgnt_xmit");
 		ret = _FAIL;
 	}
-	#ifdef CONFIG_XMIT_THREAD_MODE
-	if (NULL == padapter->HalFunc.xmit_thread_handler) {
+#ifdef CONFIG_XMIT_THREAD_MODE
+	if (NULL == padapter->hal_func.xmit_thread_handler) {
 		rtw_hal_error_msg("xmit_thread_handler");
 		ret = _FAIL;
 	}
-	#endif
-	if (NULL == padapter->HalFunc.hal_xmitframe_enqueue) {
+#endif
+	if (NULL == padapter->hal_func.hal_xmitframe_enqueue) {
 		rtw_hal_error_msg("hal_xmitframe_enqueue");
 		ret = _FAIL;
 	}
-	#if defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
-	#ifndef CONFIG_SDIO_TX_TASKLET
-	if (NULL == padapter->HalFunc.run_thread) {
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#ifndef CONFIG_SDIO_TX_TASKLET
+	if (NULL == padapter->hal_func.run_thread) {
 		rtw_hal_error_msg("run_thread");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.cancel_thread) {
+	if (NULL == padapter->hal_func.cancel_thread) {
 		rtw_hal_error_msg("cancel_thread");
 		ret = _FAIL;
 	}
-	#endif
-	#endif
-	
+#endif
+#endif
+
 	/*** recv section ***/
-	if (NULL == padapter->HalFunc.init_recv_priv) {
+	if (NULL == padapter->hal_func.init_recv_priv) {
 		rtw_hal_error_msg("init_recv_priv");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.free_recv_priv) {
+	if (NULL == padapter->hal_func.free_recv_priv) {
 		rtw_hal_error_msg("free_recv_priv");
 		ret = _FAIL;
 	}
 #ifdef CONFIG_RECV_THREAD_MODE
-	if (NULL == padapter->HalFunc.recv_hdl) {
+	if (NULL == padapter->hal_func.recv_hdl) {
 		rtw_hal_error_msg("recv_hdl");
 		ret = _FAIL;
 	}
 #endif
-	#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
-	if (NULL == padapter->HalFunc.inirp_init) {
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
+	if (NULL == padapter->hal_func.inirp_init) {
 		rtw_hal_error_msg("inirp_init");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.inirp_deinit) {
+	if (NULL == padapter->hal_func.inirp_deinit) {
 		rtw_hal_error_msg("inirp_deinit");
 		ret = _FAIL;
 	}
-	#endif //#if defined(CONFIG_USB_HCI) || defined (CONFIG_PCI_HCI)
-	
-	
+#endif /* #if defined(CONFIG_USB_HCI) || defined (CONFIG_PCI_HCI) */
+
+
 	/*** interrupt hdl section ***/
-	#if defined(CONFIG_PCI_HCI)
-	if (NULL == padapter->HalFunc.irp_reset) {
+#if defined(CONFIG_PCI_HCI)
+	if (NULL == padapter->hal_func.irp_reset) {
 		rtw_hal_error_msg("irp_reset");
 		ret = _FAIL;
 	}
-	#endif/*#if defined(CONFIG_PCI_HCI)*/
-	#if (defined(CONFIG_PCI_HCI)) || (defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT))
-	if (NULL == padapter->HalFunc.interrupt_handler) {
+#endif/*#if defined(CONFIG_PCI_HCI)*/
+#if (defined(CONFIG_PCI_HCI)) || (defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT))
+	if (NULL == padapter->hal_func.interrupt_handler) {
 		rtw_hal_error_msg("interrupt_handler");
 		ret = _FAIL;
 	}
-	#endif /*#if (defined(CONFIG_PCI_HCI)) || (defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT))*/
+#endif /*#if (defined(CONFIG_PCI_HCI)) || (defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT))*/
 
-	#if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)	
-	if (NULL == padapter->HalFunc.enable_interrupt) {
+#if defined(CONFIG_PCI_HCI) || defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
+	if (NULL == padapter->hal_func.enable_interrupt) {
 		rtw_hal_error_msg("enable_interrupt");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.disable_interrupt) {
+	if (NULL == padapter->hal_func.disable_interrupt) {
 		rtw_hal_error_msg("disable_interrupt");
 		ret = _FAIL;
 	}
-	#endif //defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
-		
-	
+#endif /* defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI) */
+
+
 	/*** DM section ***/
-	if (NULL == padapter->HalFunc.dm_init) {
+	if (NULL == padapter->hal_func.dm_init) {
 		rtw_hal_error_msg("dm_init");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.dm_deinit) {
+	if (NULL == padapter->hal_func.dm_deinit) {
 		rtw_hal_error_msg("dm_deinit");
 		ret = _FAIL;
-	}	
-	if (NULL == padapter->HalFunc.hal_dm_watchdog) {
-		rtw_hal_error_msg("hal_dm_watchdog");
-		ret = _FAIL;
 	}
-	#ifdef CONFIG_LPS_LCLK_WD_TIMER
-	if (NULL == padapter->HalFunc.hal_dm_watchdog_in_lps) {
-		rtw_hal_error_msg("hal_dm_watchdog_in_lps");
+	if (NULL == padapter->hal_func.hal_dm_watchdog) {
+		rtw_hal_error_msg("hal_dm_watchdog");
 		ret = _FAIL;
 	}
-	#endif
 
 	/*** xxx section ***/
-	if (NULL == padapter->HalFunc.set_chnl_bw_handler) {
+	if (NULL == padapter->hal_func.set_chnl_bw_handler) {
 		rtw_hal_error_msg("set_chnl_bw_handler");
 		ret = _FAIL;
-	}	
-	
-	if (NULL == padapter->HalFunc.SetHwRegHandler) {
-		rtw_hal_error_msg("SetHwRegHandler");
+	}
+
+	if (NULL == padapter->hal_func.set_hw_reg_handler) {
+		rtw_hal_error_msg("set_hw_reg_handler");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.GetHwRegHandler) {
+	if (NULL == padapter->hal_func.GetHwRegHandler) {
 		rtw_hal_error_msg("GetHwRegHandler");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.GetHalDefVarHandler) {
-		rtw_hal_error_msg("GetHalDefVarHandler");
+	if (NULL == padapter->hal_func.get_hal_def_var_handler) {
+		rtw_hal_error_msg("get_hal_def_var_handler");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.SetHalDefVarHandler) {
+	if (NULL == padapter->hal_func.SetHalDefVarHandler) {
 		rtw_hal_error_msg("SetHalDefVarHandler");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.GetHalODMVarHandler) {
+	if (NULL == padapter->hal_func.GetHalODMVarHandler) {
 		rtw_hal_error_msg("GetHalODMVarHandler");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.SetHalODMVarHandler) {
+	if (NULL == padapter->hal_func.SetHalODMVarHandler) {
 		rtw_hal_error_msg("SetHalODMVarHandler");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.UpdateRAMaskHandler) {
-		rtw_hal_error_msg("UpdateRAMaskHandler");
-		ret = _FAIL;
-	}
-	
-	if (NULL == padapter->HalFunc.SetBeaconRelatedRegistersHandler) {
+
+	if (NULL == padapter->hal_func.SetBeaconRelatedRegistersHandler) {
 		rtw_hal_error_msg("SetBeaconRelatedRegistersHandler");
 		ret = _FAIL;
 	}
 
-	if (NULL == padapter->HalFunc.Add_RateATid) {
-		rtw_hal_error_msg("Add_RateATid");
+	if (NULL == padapter->hal_func.fill_h2c_cmd) {
+		rtw_hal_error_msg("fill_h2c_cmd");
 		ret = _FAIL;
-	}	
+	}
 
-	if (NULL == padapter->HalFunc.fill_h2c_cmd) {
-		rtw_hal_error_msg("fill_h2c_cmd");
+#ifdef RTW_HALMAC
+	if (NULL == padapter->hal_func.hal_mac_c2h_handler) {
+		rtw_hal_error_msg("hal_mac_c2h_handler");
+		ret = _FAIL;
+	}
+#elif !defined(CONFIG_RTL8188E)
+	if (NULL == padapter->hal_func.c2h_handler) {
+		rtw_hal_error_msg("c2h_handler");
 		ret = _FAIL;
 	}
-	#if defined(CONFIG_LPS) || defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-	if (NULL == padapter->HalFunc.fill_fake_txdesc) {
+#endif
+
+#if defined(CONFIG_LPS) || defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	if (NULL == padapter->hal_func.fill_fake_txdesc) {
 		rtw_hal_error_msg("fill_fake_txdesc");
 		ret = _FAIL;
 	}
-	#endif
-	if (NULL == padapter->HalFunc.hal_get_tx_buff_rsvd_page_num) {
+#endif
+
+#ifndef RTW_HALMAC
+	if (NULL == padapter->hal_func.hal_get_tx_buff_rsvd_page_num) {
 		rtw_hal_error_msg("hal_get_tx_buff_rsvd_page_num");
 		ret = _FAIL;
 	}
+#endif /* !RTW_HALMAC */
 
-	#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-	#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	if (NULL == padapter->HalFunc.clear_interrupt) {
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	if (NULL == padapter->hal_func.clear_interrupt) {
 		rtw_hal_error_msg("clear_interrupt");
 		ret = _FAIL;
 	}
-	#endif
-	#endif /* CONFIG_WOWLAN */
+#endif
+#endif /* CONFIG_WOWLAN */
 
-	if (NULL == padapter->HalFunc.fw_dl) {
+	if (NULL == padapter->hal_func.fw_dl) {
 		rtw_hal_error_msg("fw_dl");
 		ret = _FAIL;
 	}
 
+#if defined(RTW_HALMAC) && defined(CONFIG_LPS_PG)
+	if (NULL == padapter->hal_func.fw_mem_dl) {
+		rtw_hal_error_msg("fw_mem_dl");
+		ret = _FAIL;
+	}
+#endif
+
 	if ((IS_HARDWARE_TYPE_8814A(padapter)
-		|| IS_HARDWARE_TYPE_8822BU(padapter) || IS_HARDWARE_TYPE_8822BS(padapter))
-		&& NULL == padapter->HalFunc.fw_correct_bcn) {
+	     || IS_HARDWARE_TYPE_8822BU(padapter) || IS_HARDWARE_TYPE_8822BS(padapter))
+	    && NULL == padapter->hal_func.fw_correct_bcn) {
 		rtw_hal_error_msg("fw_correct_bcn");
 		ret = _FAIL;
 	}
-	
-	
-	if (!padapter->HalFunc.get_tx_power_index_handler) {
+
+	if (!padapter->hal_func.set_tx_power_index_handler) {
+		rtw_hal_error_msg("set_tx_power_index_handler");
+		ret = _FAIL;
+	}
+	if (!padapter->hal_func.get_tx_power_index_handler) {
 		rtw_hal_error_msg("get_tx_power_index_handler");
 		ret = _FAIL;
 	}
 
 	/*** SReset section ***/
-	#ifdef DBG_CONFIG_ERROR_DETECT		
-	if (NULL == padapter->HalFunc.sreset_init_value) {
+#ifdef DBG_CONFIG_ERROR_DETECT
+	if (NULL == padapter->hal_func.sreset_init_value) {
 		rtw_hal_error_msg("sreset_init_value");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.sreset_reset_value) {
+	if (NULL == padapter->hal_func.sreset_reset_value) {
 		rtw_hal_error_msg("sreset_reset_value");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.silentreset) {
+	if (NULL == padapter->hal_func.silentreset) {
 		rtw_hal_error_msg("silentreset");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.sreset_xmit_status_check) {
+	if (NULL == padapter->hal_func.sreset_xmit_status_check) {
 		rtw_hal_error_msg("sreset_xmit_status_check");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.sreset_linked_status_check) {
+	if (NULL == padapter->hal_func.sreset_linked_status_check) {
 		rtw_hal_error_msg("sreset_linked_status_check");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.sreset_get_wifi_status) {
+	if (NULL == padapter->hal_func.sreset_get_wifi_status) {
 		rtw_hal_error_msg("sreset_get_wifi_status");
 		ret = _FAIL;
 	}
-	if (NULL == padapter->HalFunc.sreset_inprogress) {
+	if (NULL == padapter->hal_func.sreset_inprogress) {
 		rtw_hal_error_msg("sreset_inprogress");
 		ret = _FAIL;
 	}
-	#endif  //#ifdef DBG_CONFIG_ERROR_DETECT
+#endif  /* #ifdef DBG_CONFIG_ERROR_DETECT */
+
+#ifdef RTW_HALMAC
+	if (NULL == padapter->hal_func.init_mac_register) {
+		rtw_hal_error_msg("init_mac_register");
+		ret = _FAIL;
+	}
+	if (NULL == padapter->hal_func.init_phy) {
+		rtw_hal_error_msg("init_phy");
+		ret = _FAIL;
+	}
+#endif /* RTW_HALMAC */
 
+#ifdef CONFIG_RFKILL_POLL
+	if (padapter->hal_func.hal_radio_onoff_check == NULL) {
+		rtw_hal_error_msg("hal_radio_onoff_check");
+		ret = _FAIL;
+	}
+#endif
 #endif
 	return  ret;
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_mcc.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_mcc.c
new file mode 100644
index 000000000000..b770c08c02f3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_mcc.c
@@ -0,0 +1,3310 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#ifdef CONFIG_MCC_MODE
+#define _HAL_MCC_C_
+
+#include <drv_types.h> /* PADAPTER */
+#include <rtw_mcc.h> /* mcc structure */
+#include <hal_data.h> /* HAL_DATA */
+#include <rtw_pwrctrl.h> /* power control */
+
+/*  use for AP/GO + STA/GC case */
+#define MCC_DURATION_IDX 0 /* druration for station side */
+#define MCC_TSF_SYNC_OFFSET_IDX 1
+#define MCC_START_TIME_OFFSET_IDX 2
+#define MCC_INTERVAL_IDX 3
+#define MCC_GUARD_OFFSET0_IDX 4
+#define MCC_GUARD_OFFSET1_IDX 5
+#define MCC_STOP_THRESHOLD 6
+#define TU 1024 /* 1 TU equals 1024 microseconds */
+/* druration, TSF sync offset, start time offset, interval (unit:TU (1024 microseconds))*/
+u8 mcc_switch_channel_policy_table[][7]={
+	{20, 50, 40, 100, 0, 0, 30},
+	{80, 50, 10, 100, 0, 0, 30},
+	{36, 50, 32, 100, 0, 0, 30},
+	{30, 50, 35, 100, 0, 0, 30},
+};
+
+const int mcc_max_policy_num = sizeof(mcc_switch_channel_policy_table) /sizeof(u8) /7;
+struct mi_state mcc_mstate;
+
+static void dump_iqk_val_table(PADAPTER padapter)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct hal_iqk_reg_backup *iqk_reg_backup = pHalData->iqk_reg_backup;
+	u8 total_rf_path = pHalData->NumTotalRFPath;
+	u8 rf_path_idx = 0;
+	u8 backup_chan_idx = 0;
+	u8 backup_reg_idx = 0;
+
+#ifdef CONFIG_MCC_MODE_V2
+#else
+
+	RTW_INFO("=============dump IQK backup table================\n");
+	for (backup_chan_idx = 0; backup_chan_idx < MAX_IQK_INFO_BACKUP_CHNL_NUM; backup_chan_idx++) {
+		for (rf_path_idx = 0; rf_path_idx < total_rf_path; rf_path_idx++) {
+			for(backup_reg_idx = 0; backup_reg_idx < MAX_IQK_INFO_BACKUP_REG_NUM; backup_reg_idx++) {
+				RTW_INFO("ch:%d. bw:%d. rf path:%d. reg[%d] = 0x%02x \n"
+						, iqk_reg_backup[backup_chan_idx].central_chnl
+						, iqk_reg_backup[backup_chan_idx].bw_mode
+						, rf_path_idx
+						, backup_reg_idx
+						, iqk_reg_backup[backup_chan_idx].reg_backup[rf_path_idx][backup_reg_idx]
+						);
+			}
+		}
+	}	
+	RTW_INFO("=============================================\n");
+
+#endif
+}
+
+static void rtw_hal_mcc_build_p2p_noa_attr(PADAPTER padapter, u8 *ie, u32 *ie_len)
+{
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	u8 p2p_noa_attr_ie[MAX_P2P_IE_LEN] = {0x00};
+	u32 p2p_noa_attr_len = 0;
+	u8 noa_desc_num = 1;
+	u8 opp_ps = 0; /* Disable OppPS */
+	u8 noa_count = 255;
+	u32 noa_duration;
+	u32 noa_interval;
+	u8 noa_index = 0;
+	u8 mcc_policy_idx = 0;
+
+	mcc_policy_idx = pmccobjpriv->policy_index;
+	noa_duration = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_DURATION_IDX] * TU;
+	noa_interval = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_INTERVAL_IDX] * TU;
+
+	/* P2P OUI(4 bytes) */
+	_rtw_memcpy(p2p_noa_attr_ie, P2P_OUI, 4);
+	p2p_noa_attr_len = p2p_noa_attr_len + 4;
+
+	/* attrute ID(1 byte) */
+	p2p_noa_attr_ie[p2p_noa_attr_len] = P2P_ATTR_NOA;
+	p2p_noa_attr_len = p2p_noa_attr_len + 1;
+	
+	/* attrute length(2 bytes) length = noa_desc_num*13 + 2 */
+	RTW_PUT_LE16(p2p_noa_attr_ie + p2p_noa_attr_len, (noa_desc_num * 13 + 2));
+	p2p_noa_attr_len = p2p_noa_attr_len + 2;
+
+	/* Index (1 byte) */
+	p2p_noa_attr_ie[p2p_noa_attr_len] = noa_index;
+	p2p_noa_attr_len = p2p_noa_attr_len + 1;
+
+	/* CTWindow and OppPS Parameters (1 byte) */
+	p2p_noa_attr_ie[p2p_noa_attr_len] = opp_ps;
+	p2p_noa_attr_len = p2p_noa_attr_len+ 1;
+
+	/* NoA Count (1 byte) */
+	p2p_noa_attr_ie[p2p_noa_attr_len] = noa_count;
+	p2p_noa_attr_len = p2p_noa_attr_len + 1;
+
+	/* NoA Duration (4 bytes) unit: microseconds */
+	RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, noa_duration);
+	p2p_noa_attr_len = p2p_noa_attr_len + 4;
+
+	/* NoA Interval (4 bytes) unit: microseconds */
+	RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, noa_interval);
+	p2p_noa_attr_len = p2p_noa_attr_len + 4;
+
+	/* NoA Start Time (4 bytes) unit: microseconds */
+	RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, pmccadapriv->noa_start_time);
+	if (0)
+		RTW_INFO("indxe:%d, start_time=0x%02x:0x%02x:0x%02x:0x%02x\n"
+		, noa_index
+		, p2p_noa_attr_ie[p2p_noa_attr_len]
+		, p2p_noa_attr_ie[p2p_noa_attr_len + 1]
+		, p2p_noa_attr_ie[p2p_noa_attr_len + 2]
+		, p2p_noa_attr_ie[p2p_noa_attr_len + 3]);
+
+	p2p_noa_attr_len = p2p_noa_attr_len + 4;
+	rtw_set_ie(ie, _VENDOR_SPECIFIC_IE_, p2p_noa_attr_len, (u8 *)p2p_noa_attr_ie, ie_len);
+}
+
+
+/**
+ * rtw_hal_mcc_update_go_p2p_ie - update go p2p ie(add NoA attribute)
+ * @padapter: the adapter to be update go p2p ie
+ */
+static void rtw_hal_mcc_update_go_p2p_ie(PADAPTER padapter)
+{
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	u8 *pos = NULL;
+
+
+	/* no noa attribute, build it */
+	if (pmccadapriv->p2p_go_noa_ie_len == 0)
+		rtw_hal_mcc_build_p2p_noa_attr(padapter, pmccadapriv->p2p_go_noa_ie, &pmccadapriv->p2p_go_noa_ie_len);
+	else {
+		/* has noa attribut, modify it */
+		u32 noa_duration = 0;
+		
+		/* update index */
+		pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 15;
+		/* 0~255 */
+		(*pos) = ((*pos) + 1) % 256;
+		if (0)
+			RTW_INFO("indxe:%d\n", (*pos));
+
+
+		/* update duration */
+		noa_duration = mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_DURATION_IDX] * TU;
+		pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 12;
+		RTW_PUT_LE32(pos, noa_duration);
+
+		/* update start time */
+		pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 4;
+		RTW_PUT_LE32(pos, pmccadapriv->noa_start_time);
+		if (0)
+			RTW_INFO("start_time=0x%02x:0x%02x:0x%02x:0x%02x\n"
+			, ((u8*)(pos))[0]
+			, ((u8*)(pos))[1]
+			, ((u8*)(pos))[2]
+			, ((u8*)(pos))[3]);
+
+	}
+
+	if (0) {
+		RTW_INFO("p2p_go_noa_ie_len:%d\n", pmccadapriv->p2p_go_noa_ie_len);
+		RTW_INFO_DUMP("\n", pmccadapriv->p2p_go_noa_ie, pmccadapriv->p2p_go_noa_ie_len);
+	}
+	update_beacon(padapter, _VENDOR_SPECIFIC_IE_, P2P_OUI, _TRUE);
+}
+
+/**
+ * rtw_hal_mcc_remove_go_p2p_ie - remove go p2p ie(add NoA attribute)
+ * @padapter: the adapter to be update go p2p ie
+ */
+static void rtw_hal_mcc_remove_go_p2p_ie(PADAPTER padapter)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+	/* chech has noa ie or not */
+	if (pmccadapriv->p2p_go_noa_ie_len == 0)
+		return;
+
+	pmccadapriv->p2p_go_noa_ie_len = 0;
+	update_beacon(padapter, _VENDOR_SPECIFIC_IE_, P2P_OUI, _TRUE);
+}
+
+/* restore IQK value for all interface */
+void rtw_hal_mcc_restore_iqk_val(PADAPTER padapter)
+{
+	u8 take_care_iqk = _FALSE;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	_adapter *iface = NULL;
+	u8 i = 0;
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
+	if (take_care_iqk == _TRUE && MCC_EN(padapter)) {
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface == NULL)
+				continue;
+
+			rtw_hal_ch_sw_iqk_info_restore(iface, CH_SW_USE_CASE_MCC);
+		}
+	}
+
+	if (0)
+		dump_iqk_val_table(padapter);
+}
+
+u8 rtw_hal_check_mcc_status(PADAPTER padapter, u8 mcc_status)
+{
+	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+
+	if (pmccobjpriv->mcc_status & (mcc_status))
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+void rtw_hal_set_mcc_status(PADAPTER padapter, u8 mcc_status)
+{
+	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+
+	pmccobjpriv->mcc_status |= (mcc_status);
+}
+
+void rtw_hal_clear_mcc_status(PADAPTER padapter, u8 mcc_status)
+{
+	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+
+	pmccobjpriv->mcc_status &= (~mcc_status);
+}
+
+static void rtw_hal_mcc_update_policy_table(PADAPTER adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	u8 mcc_duration = mccobjpriv->duration;
+	s8 mcc_policy_idx = mccobjpriv->policy_index;
+	u8 interval = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_INTERVAL_IDX];
+	u8 new_mcc_duration_time = 0;
+	u8 new_starttime_offset = 0;
+
+	/* convert % to ms */
+	new_mcc_duration_time = mcc_duration * interval / 100;
+
+	/* start time offset = (interval - duration time)/2 */
+	new_starttime_offset = (interval - new_mcc_duration_time) >> 1;
+
+	/* update modified parameters */
+	mcc_switch_channel_policy_table[mcc_policy_idx][MCC_DURATION_IDX]
+		= new_mcc_duration_time;
+
+	mcc_switch_channel_policy_table[mcc_policy_idx][MCC_START_TIME_OFFSET_IDX]
+		= new_starttime_offset;
+	
+
+}
+
+static void rtw_hal_config_mcc_switch_channel_setting(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	struct registry_priv *registry_par = &padapter->registrypriv;
+	u8 mcc_duration = 0;
+	s8 mcc_policy_idx = 0;
+
+	mcc_policy_idx = registry_par->rtw_mcc_policy_table_idx;
+	mcc_duration = mccobjpriv->duration;
+
+	if (mcc_policy_idx < 0 || mcc_policy_idx >= mcc_max_policy_num) {
+		mccobjpriv->policy_index = 0;
+		RTW_INFO("[MCC] can't find table(%d), use default policy(%d)\n",
+			mcc_policy_idx, mccobjpriv->policy_index);
+	} else
+		mccobjpriv->policy_index = mcc_policy_idx;
+
+	/* convert % to time */
+	if (mcc_duration != 0)
+		rtw_hal_mcc_update_policy_table(padapter);
+
+	RTW_INFO("[MCC] policy(%d): %d,%d,%d,%d,%d,%d\n"
+		, mccobjpriv->policy_index
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_DURATION_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_TSF_SYNC_OFFSET_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_START_TIME_OFFSET_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_INTERVAL_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX]);
+
+}
+
+static void rtw_hal_mcc_assign_tx_threshold(PADAPTER padapter) 
+{
+	struct registry_priv *preg = &padapter->registrypriv;
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+
+	switch (pmccadapriv->role) {
+	case MCC_ROLE_STA:
+	case MCC_ROLE_GC:
+		switch (pmlmeext->cur_bwmode) {
+		case CHANNEL_WIDTH_20:
+			/*
+			* target tx byte(bytes) = target tx tp(Mbits/sec) * 1024 * 1024 / 8 * (duration(ms) / 1024)
+			*					= target tx tp(Mbits/sec) * 128 * duration(ms)
+			* note:
+			* target tx tp(Mbits/sec) * 1024 * 1024 / 8 ==> Mbits to bytes
+			* duration(ms) / 1024 ==> msec to sec
+			*/
+			pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_sta_bw20_target_tx_tp * 128 * pmccadapriv->mcc_duration;
+			break;
+		case CHANNEL_WIDTH_40:
+			pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_sta_bw40_target_tx_tp * 128 * pmccadapriv->mcc_duration;
+			break;
+		case CHANNEL_WIDTH_80:
+			pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_sta_bw80_target_tx_tp * 128 * pmccadapriv->mcc_duration;
+			break;
+		case CHANNEL_WIDTH_160:
+		case CHANNEL_WIDTH_80_80:
+			RTW_INFO(FUNC_ADPT_FMT": not support bwmode = %d\n"
+				, FUNC_ADPT_ARG(padapter), pmlmeext->cur_bwmode);
+			break;
+		}
+		break;
+	case MCC_ROLE_AP:
+	case MCC_ROLE_GO:
+		switch (pmlmeext->cur_bwmode) {
+		case CHANNEL_WIDTH_20:
+			pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_ap_bw20_target_tx_tp * 128 * pmccadapriv->mcc_duration;
+			break;
+		case CHANNEL_WIDTH_40:
+			pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_ap_bw40_target_tx_tp * 128 * pmccadapriv->mcc_duration;
+			break;
+		case CHANNEL_WIDTH_80:
+			pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_ap_bw80_target_tx_tp * 128 * pmccadapriv->mcc_duration;
+			break;
+		case CHANNEL_WIDTH_160:
+		case CHANNEL_WIDTH_80_80:
+			RTW_INFO(FUNC_ADPT_FMT": not support bwmode = %d\n"
+				, FUNC_ADPT_ARG(padapter), pmlmeext->cur_bwmode);
+			break;
+		}
+		break;
+	}
+}
+
+static void rtw_hal_config_mcc_role_setting(PADAPTER padapter, u8 order)
+{
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta = NULL;
+	struct registry_priv *preg = &padapter->registrypriv;
+	_irqL irqL;
+	_list	*phead =NULL, *plist = NULL;
+	u8 policy_index = 0;
+	u8 mcc_duration = 0;
+	u8 mcc_interval = 0;
+
+	policy_index = pmccobjpriv->policy_index;
+	mcc_duration = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_DURATION_IDX]
+		- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
+			- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX];
+	mcc_interval = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_INTERVAL_IDX];
+
+	if (MSTATE_AP_STARTING_NUM(&mcc_mstate) == 0
+		&& MSTATE_AP_NUM(&mcc_mstate) == 0) {
+		pmccadapriv->order = order;
+
+		if (pmccadapriv->order == 0) {
+			/* setting is smiliar to GO/AP */
+			/* pmccadapriv->mcc_duration = mcc_interval - mcc_duration;*/
+			pmccadapriv->mgmt_queue_macid = MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID;
+		} else if (pmccadapriv->order == 1) {
+			/* pmccadapriv->mcc_duration = mcc_duration; */
+			pmccadapriv->mgmt_queue_macid = MCC_ROLE_STA_GC_MGMT_QUEUE_MACID;
+		} else {
+			RTW_INFO("[MCC] not support >= 3 interface\n");
+			rtw_warn_on(1);
+		}
+
+		rtw_hal_mcc_assign_tx_threshold(padapter);
+
+		psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
+		if (psta) {
+			/* combine AP/GO macid and mgmt queue macid to bitmap */
+			pmccadapriv->mcc_macid_bitmap = BIT(psta->cmn.mac_id) | BIT(pmccadapriv->mgmt_queue_macid);
+		} else {
+			RTW_INFO(FUNC_ADPT_FMT":AP/GO station info is NULL\n", FUNC_ADPT_ARG(padapter));
+			rtw_warn_on(1);
+		}
+	} else {
+		/* GO/AP is 1nd order  GC/STA is 2nd order */
+		switch (pmccadapriv->role) {
+		case MCC_ROLE_STA:
+		case MCC_ROLE_GC:
+			pmccadapriv->order = 1;
+			pmccadapriv->mcc_duration = mcc_duration;
+
+			rtw_hal_mcc_assign_tx_threshold(padapter);
+			/* assign used mac to avoid affecting RA */
+			pmccadapriv->mgmt_queue_macid = MCC_ROLE_STA_GC_MGMT_QUEUE_MACID;
+
+			psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
+			if (psta) {
+				/* combine AP/GO macid and mgmt queue macid to bitmap */
+				pmccadapriv->mcc_macid_bitmap = BIT(psta->cmn.mac_id) | BIT(pmccadapriv->mgmt_queue_macid);
+			} else {
+				RTW_INFO(FUNC_ADPT_FMT":AP/GO station info is NULL\n", FUNC_ADPT_ARG(padapter));
+				rtw_warn_on(1);
+			}
+			break;
+		case MCC_ROLE_AP:
+		case MCC_ROLE_GO:
+			pmccadapriv->order = 0;
+			/* total druation value equals interval */
+			pmccadapriv->mcc_duration = mcc_interval - mcc_duration;
+			pmccadapriv->p2p_go_noa_ie_len = 0; /* not NoA attribute at init time */
+
+			rtw_hal_mcc_assign_tx_threshold(padapter);
+
+			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+			phead = &pstapriv->asoc_list;
+			plist = get_next(phead);
+			pmccadapriv->mcc_macid_bitmap = 0;
+	
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+				plist = get_next(plist);
+				pmccadapriv->mcc_macid_bitmap |= BIT(psta->cmn.mac_id);
+			}
+
+			_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+			psta = rtw_get_bcmc_stainfo(padapter);
+
+			if (psta != NULL)
+				pmccadapriv->mgmt_queue_macid = psta->cmn.mac_id;
+			else {
+				pmccadapriv->mgmt_queue_macid = MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID;
+				RTW_INFO(FUNC_ADPT_FMT":bcmc station is NULL, use macid %d\n"
+					, FUNC_ADPT_ARG(padapter), pmccadapriv->mgmt_queue_macid);
+			}
+
+			/* combine client macid and mgmt queue macid to bitmap */
+			pmccadapriv->mcc_macid_bitmap |= BIT(pmccadapriv->mgmt_queue_macid);
+			break;
+		default:
+			RTW_INFO("Unknown role\n");
+			rtw_warn_on(1);
+			break;
+		}
+
+	}
+
+	/* setting Null data parameters */
+	if (pmccadapriv->role == MCC_ROLE_STA) {
+			pmccadapriv->null_early = 3;
+			pmccadapriv->null_rty_num= 5;
+	} else if (pmccadapriv->role == MCC_ROLE_GC) {
+			pmccadapriv->null_early = 2;
+			pmccadapriv->null_rty_num= 5;
+	} else {
+			pmccadapriv->null_early = 0;
+			pmccadapriv->null_rty_num= 0;
+	}
+
+	RTW_INFO("********* "FUNC_ADPT_FMT" *********\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO("order:%d\n", pmccadapriv->order);
+	RTW_INFO("role:%d\n", pmccadapriv->role);
+	RTW_INFO("mcc duration:%d\n", pmccadapriv->mcc_duration);
+	RTW_INFO("null_early:%d\n", pmccadapriv->null_early);
+	RTW_INFO("null_rty_num:%d\n", pmccadapriv->null_rty_num);
+	RTW_INFO("mgmt queue macid:%d\n", pmccadapriv->mgmt_queue_macid);
+	RTW_INFO("bitmap:0x%02x\n", pmccadapriv->mcc_macid_bitmap);
+	RTW_INFO("target tx bytes:%d\n", pmccadapriv->mcc_target_tx_bytes_to_port);
+	RTW_INFO("**********************************\n");
+
+	pmccobjpriv->iface[pmccadapriv->order] = padapter;
+
+}
+
+static void rtw_hal_clear_mcc_macid(PADAPTER padapter)
+{
+	u16 media_status_rpt;
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+	switch (pmccadapriv->role) {
+	case MCC_ROLE_STA:
+	case MCC_ROLE_GC:
+		break;
+	case MCC_ROLE_AP:
+	case MCC_ROLE_GO:
+	/* nothing to do */
+		break;
+	default:
+		RTW_INFO("Unknown role\n");
+		rtw_warn_on(1);
+		break;
+	}
+}
+
+static void rtw_hal_mcc_rqt_tsf(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	u8 cmd[H2C_MCC_RQT_TSF_LEN] = {0};
+
+	rtw_sctx_init(&pmccobjpriv->mcc_tsf_req_sctx, MCC_EXPIRE_TIME);
+
+	SET_H2CCMD_MCC_RQT_TSFX(cmd, pmccobjpriv->iface[0]->hw_port);
+	SET_H2CCMD_MCC_RQT_TSFY(cmd, pmccobjpriv->iface[1]->hw_port);
+
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_RQT_TSF, H2C_MCC_RQT_TSF_LEN, cmd);
+
+	if (!rtw_sctx_wait(&pmccobjpriv->mcc_tsf_req_sctx, __func__))
+		RTW_INFO(FUNC_ADPT_FMT": wait for mcc tsf req C2H time out\n", FUNC_ADPT_ARG(padapter));
+
+}
+
+static u8 rtw_hal_mcc_check_start_time_is_valid(PADAPTER padapter, u8 case_num,
+	u32 tsfdiff, s8 *upper_bound_0, s8 *lower_bound_0, s8 *upper_bound_1, s8 *lower_bound_1)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	u8 duration_0 = 0, duration_1 = 0;
+	s8 final_upper_bound = 0, final_lower_bound = 0;
+	u8 intersection =  _FALSE;
+	u8 min_start_time = 5;
+	u8 max_start_time = 95;
+	
+	duration_0 = mccobjpriv->iface[0]->mcc_adapterpriv.mcc_duration;
+	duration_1 = mccobjpriv->iface[1]->mcc_adapterpriv.mcc_duration;
+
+	switch(case_num) {
+	case 1:
+		*upper_bound_0 = tsfdiff;
+		*lower_bound_0 = tsfdiff - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 2:
+		*upper_bound_0 = tsfdiff + 100;
+		*lower_bound_0 = tsfdiff + 100 - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 3:
+		*upper_bound_0 = tsfdiff + 50;
+		*lower_bound_0 = tsfdiff + 50 - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 4:
+		*upper_bound_0 = tsfdiff;
+		*lower_bound_0 = tsfdiff - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 5:
+		*upper_bound_0 = 200 - tsfdiff;
+		*lower_bound_0 = 200 - tsfdiff - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 6:
+		*upper_bound_0 = tsfdiff - 50;
+		*lower_bound_0 = tsfdiff - 50 - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	default:
+		RTW_ERR("[MCC] %s: error case number(%d\n)", __func__, case_num);
+	}
+
+
+	/* check Intersection or not */
+	if ((*lower_bound_1 >= *upper_bound_0) ||
+		(*lower_bound_0 >= *upper_bound_1))
+		intersection = _FALSE;
+	else
+		intersection = _TRUE;
+
+	if (intersection) {
+		if (*upper_bound_0 > *upper_bound_1)
+			final_upper_bound = *upper_bound_1;
+		else
+			final_upper_bound = *upper_bound_0;
+
+		if (*lower_bound_0 > *lower_bound_1)
+			final_lower_bound = *lower_bound_0;
+		else
+			final_lower_bound = *lower_bound_1;
+
+		mccobjpriv->start_time = (final_lower_bound + final_upper_bound) / 2;
+
+		/* check start time less than 5ms, request by Pablo@SD1 */
+		if (mccobjpriv->start_time <= min_start_time) {
+			mccobjpriv->start_time = 6;
+			if (mccobjpriv->start_time < final_lower_bound && mccobjpriv->start_time > final_upper_bound) {
+				intersection = _FALSE;
+				goto exit;
+			}
+		}
+
+		/* check start time less than 95ms */
+		if (mccobjpriv->start_time >= max_start_time) {
+			mccobjpriv->start_time = 90;
+			if (mccobjpriv->start_time < final_lower_bound && mccobjpriv->start_time > final_upper_bound) {
+				intersection = _FALSE;
+				goto exit;
+			}
+		}
+	}
+
+exit:
+	return intersection;
+}
+
+static void rtw_hal_mcc_decide_duration(PADAPTER padapter)
+{
+	struct registry_priv *registry_par = &padapter->registrypriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_adapter_priv *mccadapriv = NULL, *mccadapriv_order0 = NULL, *mccadapriv_order1 = NULL;
+	_adapter *iface = NULL, *iface_order0 = NULL,  *iface_order1 = NULL;
+	u8 duration = 0, i = 0, duration_time;
+	u8 mcc_interval = 150;
+
+	iface_order0 = mccobjpriv->iface[0];
+	iface_order1 = mccobjpriv->iface[1];
+	mccadapriv_order0 = &iface_order0->mcc_adapterpriv;
+	mccadapriv_order1 = &iface_order1->mcc_adapterpriv;
+	
+	if (mccobjpriv->duration == 0) {
+		/* default */
+		duration = 30;/*(%)*/
+		RTW_INFO("%s: mccobjpriv->duration=0, use default value(%d)\n",
+			__FUNCTION__, duration);
+	} else {
+		duration = mccobjpriv->duration;/*(%)*/
+		RTW_INFO("%s: mccobjpriv->duration=%d\n",
+			__FUNCTION__, duration);
+	}
+
+	mccobjpriv->interval = mcc_interval;
+	mccobjpriv->mcc_stop_threshold = 2000 * 4 / 300 - 6;
+	/* convert % to ms, for primary adapter */
+	duration_time = mccobjpriv->interval * duration / 100;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+
+		if (!iface)
+			continue;
+
+		mccadapriv = &iface->mcc_adapterpriv;
+
+		if (is_primary_adapter(iface))
+			mccadapriv->mcc_duration = duration_time;
+		else
+			mccadapriv->mcc_duration = mccobjpriv->interval - duration_time;
+	}
+
+	RTW_INFO("[MCC]"  FUNC_ADPT_FMT " order 0 duration=%d\n", FUNC_ADPT_ARG(iface_order0), mccadapriv_order0->mcc_duration);
+	RTW_INFO("[MCC]"  FUNC_ADPT_FMT " order 1 duration=%d\n", FUNC_ADPT_ARG(iface_order1), mccadapriv_order1->mcc_duration);
+}
+
+static u8 rtw_hal_mcc_update_timing_parameters(PADAPTER padapter, u8 force_update)
+{
+	u8 need_update = _FALSE;
+
+	/* for STA+STA, modify policy table */
+	if (MSTATE_AP_STARTING_NUM(&mcc_mstate) == 0
+		&& MSTATE_AP_NUM(&mcc_mstate) == 0) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+		struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+		struct mcc_adapter_priv *pmccadapriv = NULL;
+		_adapter *iface = NULL;
+		u64 tsf0 = 0, tsf1 = 0;
+		u32 beaconperiod_0 = 0, beaconperiod_1 = 0, tsfdiff = 0;
+		s8 upper_bound_0 = 0, lower_bound_0 = 0;
+		s8 upper_bound_1 = 0, lower_bound_1 = 0;
+		u8 valid = _FALSE;
+		u8 case_num = 1;
+		u8 i = 0;
+		
+		/* query TSF */
+		rtw_hal_mcc_rqt_tsf(padapter);
+
+		/* selecet policy table according TSF diff */
+		tsf0 = pmccobjpriv->iface[0]->mcc_adapterpriv.tsf;
+		beaconperiod_0 = pmccobjpriv->iface[0]->mlmepriv.cur_network.network.Configuration.BeaconPeriod;
+		tsf0 = rtw_modular64(tsf0, (beaconperiod_0 * TU));
+
+		tsf1 = pmccobjpriv->iface[1]->mcc_adapterpriv.tsf;
+		beaconperiod_1 = pmccobjpriv->iface[1]->mlmepriv.cur_network.network.Configuration.BeaconPeriod;
+		tsf1 = rtw_modular64(tsf1, (beaconperiod_1 * TU));
+
+		if (tsf0 > tsf1)
+			tsfdiff = tsf0- tsf1;
+		else
+			tsfdiff = (tsf0 +  beaconperiod_0 * TU) - tsf1;
+
+		/* convert to ms */
+		tsfdiff = (tsfdiff / TU);
+
+		/* force update*/
+		if (force_update) {
+			RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
+				pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
+			RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
+			RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
+				__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
+			pmccobjpriv->last_tsfdiff = tsfdiff;
+			need_update = _TRUE;
+		} else {
+			if (pmccobjpriv->last_tsfdiff > tsfdiff) {
+				/* last tsfdiff - current tsfdiff > THRESHOLD, update parameters */
+				if (pmccobjpriv->last_tsfdiff > (tsfdiff + MCC_UPDATE_PARAMETER_THRESHOLD)) {
+					RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
+						pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
+					RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
+					RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
+						__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
+
+					pmccobjpriv->last_tsfdiff = tsfdiff;
+					need_update = _TRUE;
+				} else {
+					need_update = _FALSE;
+				}
+			} else if (tsfdiff > pmccobjpriv->last_tsfdiff){
+				/* current tsfdiff - last tsfdiff > THRESHOLD, update parameters */
+				if (tsfdiff > (pmccobjpriv->last_tsfdiff + MCC_UPDATE_PARAMETER_THRESHOLD)) {
+					RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
+						pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
+					RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
+					RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
+						__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
+
+					pmccobjpriv->last_tsfdiff = tsfdiff;
+					need_update = _TRUE;
+				} else {
+					need_update = _FALSE;
+				}
+			} else {
+				need_update = _FALSE;
+			}
+		}
+
+		if (need_update == _FALSE)
+			goto exit;
+
+		rtw_hal_mcc_decide_duration(padapter);
+
+		if (tsfdiff <= 50) {
+	
+			/* RX TBTT 0 */
+			case_num = 1;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+	
+			/* RX TBTT 1 */
+			case_num = 2;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+			
+			/* RX TBTT 2 */
+			case_num = 3;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+
+			if (valid == _FALSE) {
+				RTW_INFO("[MCC] do not find fit start time\n");
+				RTW_INFO("[MCC] tsfdiff:%d, duration:%d(%c), interval:%d\n",
+					tsfdiff, pmccobjpriv->duration, 37, pmccobjpriv->interval);
+
+			}
+
+		} else {
+
+			/* RX TBTT 0 */
+			case_num = 4;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+			
+			
+			/* RX TBTT 1 */
+			case_num = 5;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+
+			
+			/* RX TBTT 2 */
+			case_num = 6;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+
+			if (valid == _FALSE) {
+				RTW_INFO("[MCC] do not find fit start time\n");
+				RTW_INFO("[MCC] tsfdiff:%d, duration:%d(%c), interval:%d\n",
+					tsfdiff, pmccobjpriv->duration, 37, pmccobjpriv->interval);
+			}
+		}
+
+		
+
+	valid_result:
+		RTW_INFO("********************\n");
+		RTW_INFO("%s: case_num:%d, start time:%d\n",
+				__func__, case_num, pmccobjpriv->start_time);
+		RTW_INFO("%s: upper_bound_0:%d, lower_bound_0:%d\n",
+				__func__, upper_bound_0, lower_bound_0);
+		RTW_INFO("%s: upper_bound_1:%d, lower_bound_1:%d\n",
+				__func__, upper_bound_1, lower_bound_1);
+		
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface == NULL)
+				continue;
+
+			pmccadapriv = &iface->mcc_adapterpriv;
+#if 0
+			if (pmccadapriv->order == 0) {
+				pmccadapriv->mcc_duration = mcc_duration;
+			} else if (pmccadapriv->order == 1) {
+				pmccadapriv->mcc_duration = mcc_interval - mcc_duration;
+			} else {
+				RTW_INFO("[MCC] not support >= 3 interface\n");
+				rtw_warn_on(1);
+			}
+#endif
+			RTW_INFO("********************\n");
+			RTW_INFO(FUNC_ADPT_FMT": order:%d, role:%d\n",
+				FUNC_ADPT_ARG(iface), pmccadapriv->order, pmccadapriv->role);
+			RTW_INFO(FUNC_ADPT_FMT": mcc duration:%d, target tx bytes:%d\n",
+				FUNC_ADPT_ARG(iface), pmccadapriv->mcc_duration, pmccadapriv->mcc_target_tx_bytes_to_port);
+			RTW_INFO(FUNC_ADPT_FMT": mgmt queue macid:%d, bitmap:0x%02x\n",
+				FUNC_ADPT_ARG(iface), pmccadapriv->mgmt_queue_macid, pmccadapriv->mcc_macid_bitmap);
+			RTW_INFO("********************\n");
+		}
+		
+	}
+exit:
+	return need_update;
+}
+
+static u8 rtw_hal_decide_mcc_role(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	_adapter *iface = NULL;
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	struct wifidirect_info *pwdinfo = NULL;
+	struct mlme_priv *pmlmepriv = NULL;
+	u8 ret = _SUCCESS, i = 0;
+	u8 order = 1;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+
+		pmccadapriv = &iface->mcc_adapterpriv;
+
+		if (MLME_IS_GO(iface))
+			pmccadapriv->role = MCC_ROLE_GO;
+		else if (MLME_IS_AP(iface))
+			pmccadapriv->role = MCC_ROLE_AP;
+		else if (MLME_IS_GC(iface))
+			pmccadapriv->role = MCC_ROLE_GC;
+		else if (MLME_IS_STA(iface))
+			pmccadapriv->role = MCC_ROLE_STA;
+		else {
+			pwdinfo = &iface->wdinfo;
+			pmlmepriv = &iface->mlmepriv;
+
+			RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(iface));
+			RTW_INFO("Unknown:P2P state:%d, mlme state:0x%2x, mlmext info state:0x%02x\n",
+				pwdinfo->role, pmlmepriv->fw_state, iface->mlmeextpriv.mlmext_info.state);
+			rtw_warn_on(1);
+			ret =  _FAIL;
+			goto exit;
+		}
+
+		if (ret == _SUCCESS) {
+			if (padapter == iface) {
+				/* current adapter is order 0 */
+				rtw_hal_config_mcc_role_setting(iface, 0);
+			} else {
+				rtw_hal_config_mcc_role_setting(iface, order);
+				order ++;
+			}
+		}
+	}
+
+	rtw_hal_mcc_update_timing_parameters(padapter, _TRUE);
+exit:
+	return ret;
+}
+
+static void rtw_hal_construct_CTS(PADAPTER padapter, u8 *pframe, u32 *pLength)
+{
+	u8 broadcast_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+	/* frame type, length = 1*/
+	set_frame_sub_type(pframe, WIFI_RTS);
+
+	/* frame control flag, length = 1 */
+	*(pframe + 1) = 0;
+
+	/* frame duration, length = 2 */
+	*(pframe + 2) = 0x00;
+	*(pframe + 3) = 0x78;
+
+	/* frame recvaddr, length = 6 */
+	_rtw_memcpy((pframe + 4), broadcast_addr, ETH_ALEN);
+	_rtw_memcpy((pframe + 4 + ETH_ALEN), adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy((pframe + 4 + ETH_ALEN*2), adapter_mac_addr(padapter), ETH_ALEN);
+	*pLength = 22;
+}
+
+/* avoid wrong information for power limit */
+void rtw_hal_mcc_upadate_chnl_bw(_adapter *padapter, u8 ch, u8 ch_offset, u8 bw, u8 print)
+{
+
+	u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	PHAL_DATA_TYPE	hal = GET_HAL_DATA(padapter);
+	u8 cch_160, cch_80, cch_40, cch_20;
+
+	center_ch = rtw_get_center_ch(ch, bw, ch_offset);
+
+	if (bw == CHANNEL_WIDTH_80) {
+		if (center_ch > ch)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
+		else if (center_ch < ch)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
+		else
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	}
+
+	/* set Channel */
+	/* saved channel/bw info */
+	rtw_set_oper_ch(padapter, ch);
+	rtw_set_oper_bw(padapter, bw);
+	rtw_set_oper_choffset(padapter, ch_offset);
+
+	cch_80 = bw == CHANNEL_WIDTH_80 ? center_ch : 0;
+	cch_40 = bw == CHANNEL_WIDTH_40 ? center_ch : 0;
+	cch_20 = bw == CHANNEL_WIDTH_20 ? center_ch : 0;
+
+	if (cch_80 != 0)
+		cch_40 = rtw_get_scch_by_cch_offset(cch_80, CHANNEL_WIDTH_80, chnl_offset80);
+	if (cch_40 != 0)
+		cch_20 = rtw_get_scch_by_cch_offset(cch_40, CHANNEL_WIDTH_40, ch_offset);
+
+
+	hal->cch_80 = cch_80;
+	hal->cch_40 = cch_40;
+	hal->cch_20 = cch_20;
+	hal->current_channel = center_ch;
+	hal->CurrentCenterFrequencyIndex1 = center_ch;
+	hal->current_channel_bw = bw;
+	hal->nCur40MhzPrimeSC = ch_offset;
+	hal->nCur80MhzPrimeSC = chnl_offset80;
+	hal->current_band_type = ch > 14 ? BAND_ON_5G:BAND_ON_2_4G;
+
+	if (print) {
+		RTW_INFO(FUNC_ADPT_FMT" cch:%u, %s, offset40:%u, offset80:%u (%u, %u, %u), band:%s\n"
+			, FUNC_ADPT_ARG(padapter), center_ch, ch_width_str(bw)
+			, ch_offset, chnl_offset80
+			, hal->cch_80, hal->cch_40, hal->cch_20
+			, band_str(hal->current_band_type));
+	}
+}
+
+#ifdef DBG_RSVD_PAGE_CFG
+#define RSVD_PAGE_CFG(ops, v1, v2, v3)	\
+	RTW_INFO("=== [RSVD][%s]-NeedPage:%d, TotalPageNum:%d TotalPacketLen:%d ===\n",	\
+		ops, v1, v2, v3)
+#endif
+
+u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index,
+	u8 tx_desc, u32 page_size, u8 *total_page_num, RSVDPAGE_LOC *rsvd_page_loc, u8 *page_num)
+{
+	u32 len = 0;
+	_adapter *iface = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct hal_com_data *hal = GET_HAL_DATA(adapter);
+	u8 ret = _SUCCESS, i = 0, j  =0, order = 0, CurtPktPageNum = 0;
+	u8 bssid[ETH_ALEN] = {0};
+	u8 *start = NULL;
+	u8 path = RF_PATH_A;
+
+	if (page_num) {
+#ifdef CONFIG_MCC_MODE_V2
+		if (!hal->RegIQKFWOffload)
+			RTW_WARN("[MCC] must enable FW IQK for New IC\n");
+#endif /* CONFIG_MCC_MODE_V2 */
+		/* Null data(interface number) + power index(interface number) + 1  */
+		*total_page_num += (2 * dvobj->iface_nums + 3);
+		goto exit;
+	}
+
+	/* check proccess mcc start setting */
+	if (!rtw_hal_check_mcc_status(adapter, MCC_STATUS_PROCESS_MCC_START_SETTING)) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+
+		order = iface->mcc_adapterpriv.order;
+		dvobj->mcc_objpriv.mcc_loc_rsvd_paga[order] = *total_page_num;
+
+		switch (iface->mcc_adapterpriv.role) {
+		case MCC_ROLE_STA:
+		case MCC_ROLE_GC:
+			/* Build NULL DATA */
+			RTW_INFO("LocNull(order:%d): %d\n"
+				, order, dvobj->mcc_objpriv.mcc_loc_rsvd_paga[order]);
+			len = 0;
+			pmlmeext = &iface->mlmeextpriv;
+			pmlmeinfo = &pmlmeext->mlmext_info;
+
+			_rtw_memcpy(bssid, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
+
+			rtw_hal_construct_NullFunctionData(iface
+				, &pframe[*index], &len, bssid, _FALSE, 0, 0, _FALSE);
+			rtw_hal_fill_fake_txdesc(iface, &pframe[*index-tx_desc],
+				len, _FALSE, _FALSE, _FALSE);
+
+			CurtPktPageNum = (u8)PageNum(tx_desc + len, page_size);
+			*total_page_num += CurtPktPageNum;
+			*index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("LocNull", CurtPktPageNum, *total_page_num, *index);
+			#endif
+			break;
+		case MCC_ROLE_AP:
+			/* Bulid CTS */
+			RTW_INFO("LocCTS(order:%d): %d\n"
+				, order, dvobj->mcc_objpriv.mcc_loc_rsvd_paga[order]);
+
+			len = 0;
+			rtw_hal_construct_CTS(iface, &pframe[*index], &len);
+			rtw_hal_fill_fake_txdesc(iface, &pframe[*index-tx_desc],
+				len, _FALSE, _FALSE, _FALSE);
+
+			CurtPktPageNum = (u8)PageNum(tx_desc + len, page_size);
+			*total_page_num += CurtPktPageNum;
+			*index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("LocCTS", CurtPktPageNum, *total_page_num, *index);
+			#endif
+			break;
+		case MCC_ROLE_GO:
+		/* To DO */
+			break;
+		}
+	}
+
+	for (i = 0; i < MAX_MCC_NUM; i++) {
+		u8 center_ch = 0, ch = 0, bw = 0, bw_offset = 0;
+		u8 power_index = 0;
+		u8 rate_array_sz = 0;
+		u8 *rates = NULL;
+		u8 rate = 0;
+		u8 shift = 0;
+		u32 power_index_4bytes = 0;
+		u8 total_rate = 0;
+		u8 *total_rate_offset = NULL;
+
+		iface = pmccobjpriv->iface[i];
+		pmlmeext = &iface->mlmeextpriv;
+		ch = pmlmeext->cur_channel;
+		bw = pmlmeext->cur_bwmode;
+		bw_offset = pmlmeext->cur_ch_offset;
+		center_ch = rtw_get_center_ch(ch, bw, bw_offset);
+		rtw_hal_mcc_upadate_chnl_bw(iface, ch, bw_offset, bw, _TRUE);
+
+		start = &pframe[*index - tx_desc];
+		_rtw_memset(start, 0, page_size);
+		pmccobjpriv->mcc_pwr_idx_rsvd_page[i] = *total_page_num;
+		RTW_INFO(ADPT_FMT" order:%d, pwr_idx_rsvd_page location[%d]: %d\n",
+			ADPT_ARG(iface), iface->mcc_adapterpriv.order,
+			i, pmccobjpriv->mcc_pwr_idx_rsvd_page[i]);
+
+		total_rate_offset = start;
+			
+		for (path = RF_PATH_A; path < hal->NumTotalRFPath; ++path) {
+			total_rate = 0;
+			/* PATH A for 0~63 byte, PATH B for 64~127 byte*/
+			if (path == RF_PATH_A)
+				start = total_rate_offset + 1;
+			else if (path == RF_PATH_B)
+				start = total_rate_offset + 64;
+			else {
+				RTW_INFO("[MCC] %s: unknow RF PATH(%d)\n", __func__, path);
+				break;
+			}
+
+			/* CCK */
+			if (ch <= 14) {
+				rate_array_sz = rates_by_sections[CCK].rate_num;
+				rates = rates_by_sections[CCK].rates;
+				for (j = 0; j < rate_array_sz; ++j) {
+					power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+					rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+					shift = rate % 4;
+					if (shift == 0) {
+						*start = rate;
+						start++;
+						total_rate++;
+
+						#ifdef DBG_PWR_IDX_RSVD_PAGE
+						RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+							ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+							center_ch, MGN_RATE_STR(rates[j]), power_index);
+						#endif
+					}
+
+					*start = power_index;
+					start++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+					
+					shift = rate % 4;
+					power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+					if (shift == 3) {
+						rate = rate - 3;
+						RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+						power_index_4bytes = 0;
+						total_rate++;
+					}
+					#endif
+						
+				}
+			}
+
+			/* OFDM */
+			rate_array_sz = rates_by_sections[OFDM].rate_num;
+			rates = rates_by_sections[OFDM].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+
+				}
+
+				*start = power_index;
+				start++;
+
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* HT_MCS0_MCS7 */
+			rate_array_sz = rates_by_sections[HT_MCS0_MCS7].rate_num;
+			rates = rates_by_sections[HT_MCS0_MCS7].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+
+				}
+
+				*start = power_index;
+				start++;
+
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* HT_MCS8_MCS15 */
+			rate_array_sz = rates_by_sections[HT_MCS8_MCS15].rate_num;
+			rates = rates_by_sections[HT_MCS8_MCS15].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+				}
+
+				*start = power_index;
+				start++;
+
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+				
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* VHT_1SSMCS0_1SSMCS9 */
+			rate_array_sz = rates_by_sections[VHT_1SSMCS0_1SSMCS9].rate_num;
+			rates = rates_by_sections[VHT_1SSMCS0_1SSMCS9].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:0x%02x\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+				}
+				*start = power_index;
+				start++;
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* VHT_2SSMCS0_2SSMCS9 */
+			rate_array_sz = rates_by_sections[VHT_2SSMCS0_2SSMCS9].rate_num;
+			rates = rates_by_sections[VHT_2SSMCS0_2SSMCS9].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+				}
+				*start = power_index;
+				start++;
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+						total_rate++;
+				}
+				#endif
+			}
+				
+		}
+		/*  total rate store in offset 0 */
+		*total_rate_offset = total_rate;
+
+#ifdef DBG_PWR_IDX_RSVD_PAGE
+			RTW_INFO("total_rate=%d\n", total_rate);
+			RTW_INFO(" ======================="ADPT_FMT"===========================\n", ADPT_ARG(iface));
+			RTW_INFO_DUMP("\n", total_rate_offset, 128);
+			RTW_INFO(" ==================================================\n");
+#endif
+
+			CurtPktPageNum = 1;
+			*total_page_num += CurtPktPageNum;
+			*index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("mcc_pwr_idx_rsvd_page", CurtPktPageNum, *total_page_num, *index);
+			#endif
+		}
+
+exit:
+	return ret;
+}
+
+/*
+* 1. Download MCC rsvd page
+* 2. Re-Download beacon after download rsvd page
+*/
+static void rtw_hal_set_fw_mcc_rsvd_page(PADAPTER padapter)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	PADAPTER port0_iface = dvobj_get_port0_adapter(dvobj);
+	PADAPTER iface = NULL;
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	u8 mstatus = RT_MEDIA_CONNECT, i = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	rtw_hal_set_hwreg(port0_iface, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
+
+	/* Re-Download beacon */
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = pmccobjpriv->iface[i];
+		pmccadapriv = &iface->mcc_adapterpriv;
+		if (pmccadapriv->role == MCC_ROLE_AP
+			|| pmccadapriv->role == MCC_ROLE_GO)
+			tx_beacon_hdl(iface, NULL);
+	}
+}
+
+static void rtw_hal_set_mcc_rsvdpage_cmd(_adapter *padapter)
+{
+	u8 cmd[H2C_MCC_LOCATION_LEN] = {0}, i = 0, order = 0;
+	_adapter *iface = NULL;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+
+	SET_H2CCMD_MCC_PWRIDX_OFFLOAD_EN(cmd, _TRUE);
+	SET_H2CCMD_MCC_PWRIDX_OFFLOAD_RFNUM(cmd, hal->NumTotalRFPath);
+	for (order = 0; order < MAX_MCC_NUM; order++) {
+		iface = pmccobjpriv->iface[i];
+
+		SET_H2CCMD_MCC_RSVDPAGE_LOC((cmd + order), pmccobjpriv->mcc_loc_rsvd_paga[order]);
+		SET_H2CCMD_MCC_PWRIDX_RSVDPAGE_LOC ((cmd + order), pmccobjpriv->mcc_pwr_idx_rsvd_page[order]);
+	}
+
+#ifdef CONFIG_MCC_MODE_DEBUG
+	RTW_INFO("=========================\n");
+	RTW_INFO("MCC RSVD PAGE LOC:\n");
+	for (i = 0; i < H2C_MCC_LOCATION_LEN; i++)
+		pr_dbg("0x%x ", cmd[i]);
+	pr_dbg("\n");
+	RTW_INFO("=========================\n");
+#endif /* CONFIG_MCC_MODE_DEBUG */
+
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_LOCATION, H2C_MCC_LOCATION_LEN, cmd);
+}
+
+static void rtw_hal_set_mcc_time_setting_cmd(PADAPTER padapter)
+{
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	u8 cmd[H2C_MCC_TIME_SETTING_LEN] = {0};
+	u8 fw_eable = 1;
+	u8 swchannel_early_time = MCC_SWCH_FW_EARLY_TIME;
+	
+
+	if (MSTATE_AP_STARTING_NUM(&mcc_mstate) == 0
+		&& MSTATE_AP_NUM(&mcc_mstate) == 0)
+		/* For STA+GC/STA+STA, TSF of GC/STA does not need to sync from TSF of other STA/GC */
+		fw_eable = 0;
+	else
+		/* Only for STA+GO/STA+AP, TSF of AP/GO need to sync from TSF of STA */
+		fw_eable = 1;
+
+	if (fw_eable == 1) {
+		u8 policy_idx = pmccobjpriv->policy_index;
+		u8 tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
+		u8 start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
+		u8 interval = mcc_switch_channel_policy_table[policy_idx][MCC_INTERVAL_IDX];
+		u8 guard_offset0 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET0_IDX];
+		u8 guard_offset1 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET1_IDX];
+		/* FW set enable */
+		SET_H2CCMD_MCC_TIME_SETTING_FW_EN(cmd, fw_eable);
+		/* TSF Sync offset */
+		SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(cmd, tsf_sync_offset);
+		/* start time offset */
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, (start_time_offset + guard_offset0));
+		/* interval */
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
+		/* Early time to inform driver by C2H before switch channel */
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+		/* Port0 sync from Port1, not support multi-port */
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(cmd, HW_PORT1);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(cmd, HW_PORT0);
+	} else {
+		/* start time offset */
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, pmccobjpriv->start_time);
+		/* interval */
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, pmccobjpriv->interval);
+		/* Early time to inform driver by C2H before switch channel */
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+	}
+
+#ifdef CONFIG_MCC_MODE_DEBUG
+	{
+		u8 i = 0;
+
+		RTW_INFO("=========================\n");
+		RTW_INFO("NoA:\n");
+		for (i = 0; i < H2C_MCC_TIME_SETTING_LEN; i++)
+			pr_dbg("0x%x ", cmd[i]);
+		pr_dbg("\n");
+		RTW_INFO("=========================\n");
+	}
+#endif /* CONFIG_MCC_MODE_DEBUG */
+
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_TIME_SETTING, H2C_MCC_TIME_SETTING_LEN, cmd);
+}
+
+static void rtw_hal_set_mcc_IQK_offload_cmd(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	_adapter *iface = NULL;
+	u8 cmd[H2C_MCC_IQK_PARAM_LEN] = {0}, bready = 0, i = 0, order = 0;
+	u16 TX_X = 0, TX_Y = 0, RX_X = 0, RX_Y = 0;
+	u8 total_rf_path = GET_HAL_DATA(padapter)->NumTotalRFPath;
+	u8 rf_path_idx = 0, last_order = MAX_MCC_NUM - 1, last_rf_path_index = total_rf_path - 1;
+
+	/* by order, last order & last_rf_path_index must set ready bit = 1 */
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = pmccobjpriv->iface[i];
+		if (iface == NULL)
+			continue;
+
+		pmccadapriv = &iface->mcc_adapterpriv;
+		order = pmccadapriv->order;
+
+		for (rf_path_idx = 0; rf_path_idx < total_rf_path; rf_path_idx ++) {
+
+			_rtw_memset(cmd, 0, H2C_MCC_IQK_PARAM_LEN);
+			TX_X = pmccadapriv->mcc_iqk_arr[rf_path_idx].TX_X & 0x7ff;/* [10:0]  */
+			TX_Y = pmccadapriv->mcc_iqk_arr[rf_path_idx].TX_Y & 0x7ff;/* [10:0]  */
+			RX_X = pmccadapriv->mcc_iqk_arr[rf_path_idx].RX_X & 0x3ff;/* [9:0]  */
+			RX_Y = pmccadapriv->mcc_iqk_arr[rf_path_idx].RX_Y & 0x3ff;/* [9:0]  */
+
+			/* ready or not */
+			if (order == last_order && rf_path_idx == last_rf_path_index)
+				bready = 1;
+			else
+				bready = 0;
+
+			SET_H2CCMD_MCC_IQK_READY(cmd, bready);
+			SET_H2CCMD_MCC_IQK_ORDER(cmd, order);
+			SET_H2CCMD_MCC_IQK_PATH(cmd, rf_path_idx);
+
+			/* fill RX_X[7:0] to (cmd+1)[7:0] bitlen=8 */
+			SET_H2CCMD_MCC_IQK_RX_L(cmd, (u8)(RX_X & 0xff));
+			/* fill RX_X[9:8] to (cmd+2)[1:0] bitlen=2 */
+			SET_H2CCMD_MCC_IQK_RX_M1(cmd, (u8)((RX_X >> 8) & 0x03));
+			/* fill RX_Y[5:0] to (cmd+2)[7:2] bitlen=6 */
+			SET_H2CCMD_MCC_IQK_RX_M2(cmd, (u8)(RX_Y & 0x3f));
+			/* fill RX_Y[9:6] to (cmd+3)[3:0] bitlen=4 */
+			SET_H2CCMD_MCC_IQK_RX_H(cmd, (u8)((RX_Y >> 6) & 0x0f));
+
+
+			/* fill TX_X[7:0] to (cmd+4)[7:0] bitlen=8 */
+			SET_H2CCMD_MCC_IQK_TX_L(cmd, (u8)(TX_X & 0xff));
+			/* fill TX_X[10:8] to (cmd+5)[2:0] bitlen=3 */
+			SET_H2CCMD_MCC_IQK_TX_M1(cmd, (u8)((TX_X >> 8) & 0x07));
+			/* fill TX_Y[4:0] to (cmd+5)[7:3] bitlen=5 */
+			SET_H2CCMD_MCC_IQK_TX_M2(cmd, (u8)(TX_Y & 0x1f));
+			/* fill TX_Y[10:5] to (cmd+6)[5:0] bitlen=6 */
+			SET_H2CCMD_MCC_IQK_TX_H(cmd, (u8)((TX_Y >> 5) & 0x3f));
+
+#ifdef CONFIG_MCC_MODE_DEBUG
+			RTW_INFO("=========================\n");
+			RTW_INFO(FUNC_ADPT_FMT" IQK:\n", FUNC_ADPT_ARG(iface));
+			RTW_INFO("TX_X: 0x%02x\n", TX_X);
+			RTW_INFO("TX_Y: 0x%02x\n", TX_Y);
+			RTW_INFO("RX_X: 0x%02x\n", RX_X);
+			RTW_INFO("RX_Y: 0x%02x\n", RX_Y);
+			RTW_INFO("cmd[0]:0x%02x\n", cmd[0]);
+			RTW_INFO("cmd[1]:0x%02x\n", cmd[1]);
+			RTW_INFO("cmd[2]:0x%02x\n", cmd[2]);
+			RTW_INFO("cmd[3]:0x%02x\n", cmd[3]);
+			RTW_INFO("cmd[4]:0x%02x\n", cmd[4]);
+			RTW_INFO("cmd[5]:0x%02x\n", cmd[5]);
+			RTW_INFO("cmd[6]:0x%02x\n", cmd[6]);
+			RTW_INFO("=========================\n");
+#endif /* CONFIG_MCC_MODE_DEBUG */
+
+			rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_IQK_PARAM, H2C_MCC_IQK_PARAM_LEN, cmd);
+		}
+	}
+}
+
+
+static void rtw_hal_set_mcc_macid_cmd(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	_adapter *iface = NULL;
+	u8 cmd[H2C_MCC_MACID_BITMAP_LEN] = {0}, i = 0, order = 0;
+	u16 bitmap = 0;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+
+		pmccadapriv = &iface->mcc_adapterpriv;
+		order = pmccadapriv->order;
+		bitmap = pmccadapriv->mcc_macid_bitmap;
+
+		if (order >= (H2C_MCC_MACID_BITMAP_LEN/2)) {
+			RTW_INFO(FUNC_ADPT_FMT" only support 3 interface at most(%d)\n"
+				, FUNC_ADPT_ARG(padapter), order);
+			continue;
+		}
+		SET_H2CCMD_MCC_MACID_BITMAP_L((cmd + order * 2), (u8)(bitmap & 0xff));
+		SET_H2CCMD_MCC_MACID_BITMAP_H((cmd + order * 2), (u8)((bitmap >> 8) & 0xff));
+	}
+
+#ifdef CONFIG_MCC_MODE_DEBUG
+	RTW_INFO("=========================\n");
+	RTW_INFO("MACID BITMAP: ");
+	for (i = 0; i < H2C_MCC_MACID_BITMAP_LEN; i++)
+		printk("0x%x ", cmd[i]);
+	printk("\n");
+	RTW_INFO("=========================\n");
+#endif /* CONFIG_MCC_MODE_DEBUG */
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_MACID_BITMAP, H2C_MCC_MACID_BITMAP_LEN, cmd);
+}
+
+#ifdef CONFIG_MCC_MODE_V2
+static u8 get_pri_ch_idx_by_adapter(u8 center_ch, u8 channel, u8 bw, u8 ch_offset40)
+{
+	u8 pri_ch_idx = 0, chnl_offset80 = 0;
+
+	if (bw == CHANNEL_WIDTH_80) {
+		if (center_ch > channel)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
+		else if (center_ch < channel)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
+		else
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	}
+
+	if (bw == CHANNEL_WIDTH_80) {
+		/* primary channel is at lower subband of 80MHz & 40MHz */
+		if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER))
+			pri_ch_idx = VHT_DATA_SC_20_LOWEST_OF_80MHZ;
+		/* primary channel is at lower subband of 80MHz & upper subband of 40MHz */
+		else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_UPPER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER))
+			pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+		/* primary channel is at upper subband of 80MHz & lower subband of 40MHz */
+		else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER))
+			pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+		/* primary channel is at upper subband of 80MHz & upper subband of 40MHz */
+		else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_UPPER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER))
+			pri_ch_idx = VHT_DATA_SC_20_UPPERST_OF_80MHZ;
+		else {
+			if (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER)
+				pri_ch_idx = VHT_DATA_SC_40_LOWER_OF_80MHZ;
+			else if (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER)
+				pri_ch_idx = VHT_DATA_SC_40_UPPER_OF_80MHZ;
+			else
+				RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+		}
+	} else if (bw == CHANNEL_WIDTH_40) {
+		/* primary channel is at upper subband of 40MHz */
+		if (ch_offset40== HAL_PRIME_CHNL_OFFSET_UPPER)
+			pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+		/* primary channel is at lower subband of 40MHz */
+		else if (ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER)
+			pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+		else
+			RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+	}
+
+	return  pri_ch_idx;
+}
+
+static void rtw_hal_set_mcc_ctrl_cmd_v2(PADAPTER padapter, u8 stop)
+{
+	u8 cmd[H2C_MCC_CTRL_LEN] = {0}, i = 0;
+	u8 order = 0, totalnum = 0;
+	u8 center_ch = 0, pri_ch_idx = 0, bw = 0;
+	u8 duration = 0, role = 0, incurch = 0, rfetype = 0, distxnull = 0, c2hrpt = 0;
+	u8 dis_sw_retry = 0, null_early_time=2, tsfx = 0, update_parm = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	_adapter *iface = NULL;
+
+	RTW_INFO(FUNC_ADPT_FMT": stop=%d\n", FUNC_ADPT_ARG(padapter), stop);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = pmccobjpriv->iface[i];
+		if (iface == NULL)
+			continue;
+
+		if (stop) {
+			if (iface != padapter)
+				continue;
+		}
+
+
+		order = iface->mcc_adapterpriv.order;
+		if (!stop)
+			totalnum = dvobj->iface_nums;
+		else
+			totalnum = 0xff; /* 0xff means stop */
+
+		pmlmeext = &iface->mlmeextpriv;
+		center_ch = rtw_get_center_ch(pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
+		pri_ch_idx = get_pri_ch_idx_by_adapter(center_ch, pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
+		bw = pmlmeext->cur_bwmode;
+		duration = iface->mcc_adapterpriv.mcc_duration;
+		role = iface->mcc_adapterpriv.role;
+
+		incurch = _FALSE;
+		dis_sw_retry = _TRUE;
+
+		/* STA/GC TX NULL data to inform AP/GC for ps mode */
+		switch (role) {
+		case MCC_ROLE_GO:
+		case MCC_ROLE_AP:
+			distxnull = MCC_DISABLE_TX_NULL;
+			break;
+		case MCC_ROLE_GC:
+			set_channel_bwmode(iface, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
+			distxnull = MCC_ENABLE_TX_NULL;
+			break;
+		case MCC_ROLE_STA:
+			distxnull = MCC_ENABLE_TX_NULL;
+			break;
+		}
+
+		null_early_time = iface->mcc_adapterpriv.null_early;
+
+		c2hrpt = MCC_C2H_REPORT_ALL_STATUS;
+		tsfx = iface->hw_port;
+		update_parm = 0;
+
+		SET_H2CCMD_MCC_CTRL_V2_ORDER(cmd, order);
+		SET_H2CCMD_MCC_CTRL_V2_TOTALNUM(cmd, totalnum);
+		SET_H2CCMD_MCC_CTRL_V2_CENTRAL_CH(cmd, center_ch);
+		SET_H2CCMD_MCC_CTRL_V2_PRIMARY_CH(cmd, pri_ch_idx);
+		SET_H2CCMD_MCC_CTRL_V2_BW(cmd, bw);
+		SET_H2CCMD_MCC_CTRL_V2_DURATION(cmd, duration);
+		SET_H2CCMD_MCC_CTRL_V2_ROLE(cmd, role);
+		SET_H2CCMD_MCC_CTRL_V2_INCURCH(cmd, incurch);
+		SET_H2CCMD_MCC_CTRL_V2_DIS_SW_RETRY(cmd, dis_sw_retry);
+		SET_H2CCMD_MCC_CTRL_V2_DISTXNULL(cmd, distxnull);
+		SET_H2CCMD_MCC_CTRL_V2_C2HRPT(cmd, c2hrpt);
+		SET_H2CCMD_MCC_CTRL_V2_TSFX(cmd, tsfx);
+		SET_H2CCMD_MCC_CTRL_V2_NULL_EARLY(cmd, null_early_time);
+		SET_H2CCMD_MCC_CTRL_V2_UPDATE_PARM(cmd, update_parm);
+
+#ifdef CONFIG_MCC_MODE_DEBUG
+		RTW_INFO("=========================\n");
+		RTW_INFO(FUNC_ADPT_FMT" MCC INFO:\n", FUNC_ADPT_ARG(iface));
+		RTW_INFO("cmd[0]:0x%02x\n", cmd[0]);
+		RTW_INFO("cmd[1]:0x%02x\n", cmd[1]);
+		RTW_INFO("cmd[2]:0x%02x\n", cmd[2]);
+		RTW_INFO("cmd[3]:0x%02x\n", cmd[3]);
+		RTW_INFO("cmd[4]:0x%02x\n", cmd[4]);
+		RTW_INFO("cmd[5]:0x%02x\n", cmd[5]);
+		RTW_INFO("cmd[6]:0x%02x\n", cmd[6]);
+		RTW_INFO("=========================\n");
+#endif /* CONFIG_MCC_MODE_DEBUG */
+
+		rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_CTRL_V2, H2C_MCC_CTRL_LEN, cmd);
+	}
+}
+
+#else
+static void rtw_hal_set_mcc_ctrl_cmd_v1(PADAPTER padapter, u8 stop)
+{
+	u8 cmd[H2C_MCC_CTRL_LEN] = {0}, i = 0;
+	u8 order = 0, totalnum = 0, chidx = 0, bw = 0, bw40sc = 0, bw80sc = 0;
+	u8 duration = 0, role = 0, incurch = 0, rfetype = 0, distxnull = 0, c2hrpt = 0, chscan = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	_adapter *iface = NULL;
+
+	RTW_INFO(FUNC_ADPT_FMT": stop=%d\n", FUNC_ADPT_ARG(padapter), stop);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = pmccobjpriv->iface[i];
+		if (iface == NULL)
+			continue;
+
+		if (stop) {
+			if (iface != padapter)
+				continue;
+		}
+
+
+		order = iface->mcc_adapterpriv.order;
+		if (!stop)
+			totalnum = dvobj->iface_nums;
+		else
+			totalnum = 0xff; /* 0xff means stop */
+
+		pmlmeext = &iface->mlmeextpriv;
+		chidx = pmlmeext->cur_channel;
+		bw = pmlmeext->cur_bwmode;
+		bw40sc = pmlmeext->cur_ch_offset;
+
+		/* decide 80 band width offset */
+		if (bw == CHANNEL_WIDTH_80) {
+			u8 center_ch = rtw_get_center_ch(chidx, bw, bw40sc);
+
+			if (center_ch > chidx)
+				bw80sc = HAL_PRIME_CHNL_OFFSET_LOWER;
+			else if (center_ch < chidx)
+				bw80sc = HAL_PRIME_CHNL_OFFSET_UPPER;
+			else
+				bw80sc = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		} else
+			bw80sc = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+
+		duration = iface->mcc_adapterpriv.mcc_duration;
+		role = iface->mcc_adapterpriv.role;
+
+		incurch = _FALSE;
+
+		if (IS_HARDWARE_TYPE_8812(padapter))
+			rfetype = pHalData->rfe_type; /* RFETYPE (only for 8812)*/
+		else
+			rfetype = 0;
+
+		/* STA/GC TX NULL data to inform AP/GC for ps mode */
+		switch (role) {
+		case MCC_ROLE_GO:
+		case MCC_ROLE_AP:
+			distxnull = MCC_DISABLE_TX_NULL;
+			break;
+		case MCC_ROLE_GC:
+		case MCC_ROLE_STA:
+			distxnull = MCC_ENABLE_TX_NULL;
+			break;
+		}
+
+		c2hrpt = MCC_C2H_REPORT_ALL_STATUS;
+		chscan = MCC_CHIDX;
+
+		SET_H2CCMD_MCC_CTRL_ORDER(cmd, order);
+		SET_H2CCMD_MCC_CTRL_TOTALNUM(cmd, totalnum);
+		SET_H2CCMD_MCC_CTRL_CHIDX(cmd, chidx);
+		SET_H2CCMD_MCC_CTRL_BW(cmd, bw);
+		SET_H2CCMD_MCC_CTRL_BW40SC(cmd, bw40sc);
+		SET_H2CCMD_MCC_CTRL_BW80SC(cmd, bw80sc);
+		SET_H2CCMD_MCC_CTRL_DURATION(cmd, duration);
+		SET_H2CCMD_MCC_CTRL_ROLE(cmd, role);
+		SET_H2CCMD_MCC_CTRL_INCURCH(cmd, incurch);
+		SET_H2CCMD_MCC_CTRL_RFETYPE(cmd, rfetype);
+		SET_H2CCMD_MCC_CTRL_DISTXNULL(cmd, distxnull);
+		SET_H2CCMD_MCC_CTRL_C2HRPT(cmd, c2hrpt);
+		SET_H2CCMD_MCC_CTRL_CHSCAN(cmd, chscan);
+
+#ifdef CONFIG_MCC_MODE_DEBUG
+		RTW_INFO("=========================\n");
+		RTW_INFO(FUNC_ADPT_FMT" MCC INFO:\n", FUNC_ADPT_ARG(iface));
+		RTW_INFO("cmd[0]:0x%02x\n", cmd[0]);
+		RTW_INFO("cmd[1]:0x%02x\n", cmd[1]);
+		RTW_INFO("cmd[2]:0x%02x\n", cmd[2]);
+		RTW_INFO("cmd[3]:0x%02x\n", cmd[3]);
+		RTW_INFO("cmd[4]:0x%02x\n", cmd[4]);
+		RTW_INFO("cmd[5]:0x%02x\n", cmd[5]);
+		RTW_INFO("cmd[6]:0x%02x\n", cmd[6]);
+		RTW_INFO("=========================\n");
+#endif /* CONFIG_MCC_MODE_DEBUG */
+
+		rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_CTRL, H2C_MCC_CTRL_LEN, cmd);
+	}
+}
+#endif
+
+static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
+{
+	#ifdef CONFIG_MCC_MODE_V2
+		/* new cmd 0x17 */
+		rtw_hal_set_mcc_ctrl_cmd_v2(padapter, stop);
+	#else
+		/* old cmd 0x18 */
+		rtw_hal_set_mcc_ctrl_cmd_v1(padapter, stop);
+	#endif
+}
+
+static u8 rtw_hal_set_mcc_start_setting(PADAPTER padapter, u8 status)
+{
+	u8 ret = _SUCCESS, enable_tsf_auto_sync = _FALSE;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+
+	if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
+		rtw_warn_on(1);
+		RTW_INFO("PS mode is not active before start mcc, force exit ps mode\n");
+		LeaveAllPowerSaveModeDirect(padapter);
+	}
+
+	if (dvobj->iface_nums > MAX_MCC_NUM) {
+		RTW_INFO("%s: current iface num(%d) > MAX_MCC_NUM(%d)\n", __func__, dvobj->iface_nums, MAX_MCC_NUM);
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* update mi_state to decide STA+STA or AP+STA */
+	rtw_mi_status(padapter, &mcc_mstate);
+
+	/* configure mcc switch channel setting */
+	rtw_hal_config_mcc_switch_channel_setting(padapter);
+
+	if (rtw_hal_decide_mcc_role(padapter) == _FAIL) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* set mcc status to indicate process mcc start setting */
+	rtw_hal_set_mcc_status(padapter, MCC_STATUS_PROCESS_MCC_START_SETTING);
+
+	/* only download rsvd page for connect */
+	if (status == MCC_SETCMD_STATUS_START_CONNECT) {
+		/* download mcc rsvd page */
+		rtw_hal_set_fw_mcc_rsvd_page(padapter);
+		rtw_hal_set_mcc_rsvdpage_cmd(padapter);
+	}
+
+	/* configure time setting */
+	rtw_hal_set_mcc_time_setting_cmd(padapter);
+
+#ifndef CONFIG_MCC_MODE_V2
+	/* IQK value offload */
+	rtw_hal_set_mcc_IQK_offload_cmd(padapter);
+#endif
+
+	/* set mac id to fw */
+	rtw_hal_set_mcc_macid_cmd(padapter);
+
+	/* disable tsf auto sync */
+	rtw_hal_set_hwreg(padapter, HW_VAR_TSF_AUTO_SYNC, &enable_tsf_auto_sync);
+
+	/* set mcc parameter  */
+	rtw_hal_set_mcc_ctrl_cmd(padapter, _FALSE);
+
+exit:
+	return ret;
+}
+
+static void rtw_hal_set_mcc_stop_setting(PADAPTER padapter, u8 status)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	_adapter *iface = NULL;
+	u8 i = 0;
+	/*
+	 * when adapter disconnect, stop mcc mod
+	 * total=0xf means stop mcc mode
+	 */
+
+	switch (status) {
+	default:
+		/* let fw switch to other interface channel */
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface == NULL)
+				continue;
+			/* use other interface to set cmd */
+			if (iface != padapter) {
+				rtw_hal_set_mcc_ctrl_cmd(iface, _TRUE);
+				break;
+			}
+		}
+		break;
+	}
+}
+
+static void rtw_hal_mcc_status_hdl(PADAPTER padapter, u8 status)
+{
+	switch (status) {
+	case MCC_SETCMD_STATUS_STOP_DISCONNECT:
+		rtw_hal_clear_mcc_status(padapter, MCC_STATUS_NEED_MCC | MCC_STATUS_DOING_MCC);
+		break;
+	case MCC_SETCMD_STATUS_STOP_SCAN_START:
+		rtw_hal_set_mcc_status(padapter, MCC_STATUS_NEED_MCC);
+		rtw_hal_clear_mcc_status(padapter, MCC_STATUS_DOING_MCC);
+		break;
+
+	case MCC_SETCMD_STATUS_START_CONNECT:
+	case MCC_SETCMD_STATUS_START_SCAN_DONE:
+		rtw_hal_set_mcc_status(padapter, MCC_STATUS_NEED_MCC | MCC_STATUS_DOING_MCC);
+		break;
+	default:
+		RTW_INFO(FUNC_ADPT_FMT" error status(%d)\n", FUNC_ADPT_ARG(padapter), status);
+		break;
+	}
+}
+
+static void rtw_hal_mcc_stop_posthdl(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	_adapter *iface = NULL;
+	PHAL_DATA_TYPE hal;
+	struct dm_struct *p_dm_odm;
+	u8 i = 0;
+	u8 enable_rx_bar = _FALSE;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+		/* release network queue */
+		rtw_netif_wake_queue(iface->pnetdev);
+		iface->mcc_adapterpriv.mcc_tx_bytes_from_kernel = 0;
+		iface->mcc_adapterpriv.mcc_last_tx_bytes_from_kernel = 0;
+		iface->mcc_adapterpriv.mcc_tx_bytes_to_port = 0;
+
+		if (iface->mcc_adapterpriv.role == MCC_ROLE_GO)
+			rtw_hal_mcc_remove_go_p2p_ie(iface);
+
+#ifdef CONFIG_TDLS
+		if (MLME_IS_STA(iface)) {
+			if (iface->mcc_adapterpriv.backup_tdls_en) {
+				rtw_enable_tdls_func(iface);
+				RTW_INFO("%s: Disable MCC, Enable TDLS\n", __func__);
+				iface->mcc_adapterpriv.backup_tdls_en = _FALSE;
+			}
+		}
+#endif /* CONFIG_TDLS */
+	}
+
+	hal = GET_HAL_DATA(padapter);
+	p_dm_odm = &hal->odmpriv;
+	phydm_dm_early_init(p_dm_odm);
+
+	/* force switch channel */
+	hal->current_channel = 0;
+	hal->current_channel_bw = CHANNEL_WIDTH_MAX;
+}
+
+static void rtw_hal_mcc_start_posthdl(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	_adapter *iface = NULL;
+	PHAL_DATA_TYPE hal;
+	struct dm_struct *p_dm_odm;
+	struct _hal_rf_ *p_rf;
+	u32 support_ability = 0;
+	u8 i = 0;
+	u8 enable_rx_bar = _TRUE;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+		iface->mcc_adapterpriv.mcc_tx_bytes_from_kernel = 0;
+		iface->mcc_adapterpriv.mcc_last_tx_bytes_from_kernel = 0;
+		iface->mcc_adapterpriv.mcc_tx_bytes_to_port = 0;
+
+#ifdef CONFIG_TDLS
+		if (MLME_IS_STA(iface)) {
+			if (rtw_is_tdls_enabled(iface)) {
+				iface->mcc_adapterpriv.backup_tdls_en = _TRUE;
+				rtw_disable_tdls_func(iface, _TRUE);
+				RTW_INFO("%s: Enable MCC, Disable TDLS\n", __func__);
+			}
+		}
+#endif /* CONFIG_TDLS */
+	}
+
+	hal = GET_HAL_DATA(padapter);
+	p_dm_odm = &hal->odmpriv;
+	p_rf = &(p_dm_odm->rf_table);
+	mccobjpriv->backup_phydm_ability = p_rf->rf_supportability;
+	p_rf->rf_supportability = p_rf->rf_supportability & (~HAL_RF_TX_PWR_TRACK) & (~HAL_RF_IQK);
+}
+
+/*
+ * rtw_hal_set_mcc_setting - set mcc setting
+ * @padapter: currnet padapter to stop/start MCC
+ * @stop: stop mcc or not
+ * @return val: 1 for SUCCESS, 0 for fail
+ */
+static u8 rtw_hal_set_mcc_setting(PADAPTER padapter, u8 status)
+{
+	u8 ret = _FAIL;
+	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	u8 stop = (status < MCC_SETCMD_STATUS_START_CONNECT) ? _TRUE : _FALSE;
+	u32 start_time = rtw_get_current_time();
+
+	RTW_INFO("===> "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	rtw_sctx_init(&pmccobjpriv->mcc_sctx, MCC_EXPIRE_TIME);
+	pmccobjpriv->mcc_c2h_status = MCC_RPT_MAX;
+
+	if (stop == _FALSE) {
+		/* handle mcc start */
+		if (rtw_hal_set_mcc_start_setting(padapter, status) == _FAIL)
+			goto exit;
+
+		/* wait for C2H */
+		if (!rtw_sctx_wait(&pmccobjpriv->mcc_sctx, __func__))
+			RTW_INFO(FUNC_ADPT_FMT": wait for mcc start C2H time out\n", FUNC_ADPT_ARG(padapter));
+		else
+			ret = _SUCCESS;
+
+		if (ret == _SUCCESS) {
+			RTW_INFO(FUNC_ADPT_FMT": mcc start sucecssfully\n", FUNC_ADPT_ARG(padapter));
+			rtw_hal_mcc_status_hdl(padapter, status);
+			rtw_hal_mcc_start_posthdl(padapter);
+		}
+	} else {
+
+		/* set mcc status to indicate process mcc start setting */
+		rtw_hal_set_mcc_status(padapter, MCC_STATUS_PROCESS_MCC_STOP_SETTING);
+
+		/* handle mcc stop */
+		rtw_hal_set_mcc_stop_setting(padapter, status);
+
+		/* wait for C2H */
+		if (!rtw_sctx_wait(&pmccobjpriv->mcc_sctx, __func__))
+			RTW_INFO(FUNC_ADPT_FMT": wait for mcc stop C2H time out\n", FUNC_ADPT_ARG(padapter));
+		else {
+			ret = _SUCCESS;
+			rtw_hal_mcc_status_hdl(padapter, status);
+			rtw_hal_mcc_stop_posthdl(padapter);
+		}
+	}
+
+exit:
+	/* clear mcc status */
+	rtw_hal_clear_mcc_status(padapter
+		, MCC_STATUS_PROCESS_MCC_START_SETTING | MCC_STATUS_PROCESS_MCC_STOP_SETTING);
+
+	RTW_INFO(FUNC_ADPT_FMT" in %dms <===\n"
+		, FUNC_ADPT_ARG(padapter), rtw_get_passing_time_ms(start_time));
+	return ret;
+}
+
+/**
+ * rtw_hal_mcc_check_case_not_limit_traffic - handler flow ctrl for special case
+ * @cur_iface: fw stay channel setting of this iface
+ * @next_iface: fw will swich channel setting of this iface
+ */
+static void rtw_hal_mcc_check_case_not_limit_traffic(PADAPTER cur_iface, PADAPTER next_iface)
+{
+	u8 cur_bw = cur_iface->mlmeextpriv.cur_bwmode;
+	u8 next_bw = next_iface->mlmeextpriv.cur_bwmode;
+
+	/* for both interface are VHT80, doesn't limit_traffic according to iperf results */
+	if (cur_bw == CHANNEL_WIDTH_80 && next_bw == CHANNEL_WIDTH_80) {
+		cur_iface->mcc_adapterpriv.mcc_tp_limit = _FALSE;
+		next_iface->mcc_adapterpriv.mcc_tp_limit = _FALSE;
+	}
+}
+
+
+/**
+ * rtw_hal_mcc_sw_ch_fw_notify_hdl - handler flow ctrl
+ */
+static void rtw_hal_mcc_sw_ch_fw_notify_hdl(PADAPTER padapter)
+{
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
+	struct mcc_adapter_priv *cur_mccadapriv = NULL, *next_mccadapriv = NULL;
+	_adapter *iface = NULL, *cur_iface = NULL, *next_iface = NULL;
+	struct registry_priv *preg = &padapter->registrypriv;
+	u8 cur_op_ch = pdvobjpriv->oper_channel;
+	u8 i = 0, iface_num = pdvobjpriv->iface_nums, cur_order = 0, next_order = 0;
+	static u8 cnt = 1;
+	u32 single_tx_cri = preg->rtw_mcc_single_tx_cri;
+
+	for (i = 0; i < iface_num; i++) {
+		iface = pdvobjpriv->padapters[i];
+		if (cur_op_ch == iface->mlmeextpriv.cur_channel) {
+			cur_iface = iface;
+			cur_mccadapriv = &cur_iface->mcc_adapterpriv;
+			cur_order = cur_mccadapriv->order;
+			next_order = (cur_order + 1) % iface_num;
+			next_iface = pmccobjpriv->iface[next_order];
+			next_mccadapriv = &next_iface->mcc_adapterpriv;
+			break;
+		}
+	}
+
+	if (cur_iface == NULL || next_iface == NULL) {
+		RTW_ERR("cur_iface=%p,next_iface=%p\n", cur_iface, next_iface);
+		rtw_warn_on(1);
+		return;
+	}
+
+	/* check other interface tx busy traffic or not under every 2 switch channel notify(Mbits/100ms) */
+	if (cnt == 2) {
+		cur_mccadapriv->mcc_tp = (cur_mccadapriv->mcc_tx_bytes_from_kernel
+			- cur_mccadapriv->mcc_last_tx_bytes_from_kernel) * 10 * 8 / 1024 / 1024;
+		cur_mccadapriv->mcc_last_tx_bytes_from_kernel = cur_mccadapriv->mcc_tx_bytes_from_kernel;
+
+		next_mccadapriv->mcc_tp = (next_mccadapriv->mcc_tx_bytes_from_kernel
+			- next_mccadapriv->mcc_last_tx_bytes_from_kernel) * 10 * 8 / 1024 / 1024;
+		next_mccadapriv->mcc_last_tx_bytes_from_kernel = next_mccadapriv->mcc_tx_bytes_from_kernel;
+
+		cnt = 1;
+	} else
+		cnt = 2;
+
+	/* check single TX or cuncurrnet TX */
+	if (next_mccadapriv->mcc_tp < single_tx_cri) {
+		/* single TX, does not stop */
+		cur_mccadapriv->mcc_tx_stop = _FALSE;
+		cur_mccadapriv->mcc_tp_limit = _FALSE;
+	} else {
+		/* concurrent TX, stop */
+		cur_mccadapriv->mcc_tx_stop = _TRUE;
+		cur_mccadapriv->mcc_tp_limit = _TRUE;
+	}
+
+	if (cur_mccadapriv->mcc_tp < single_tx_cri) {
+		next_mccadapriv->mcc_tx_stop  = _FALSE;
+		next_mccadapriv->mcc_tp_limit = _FALSE;
+	} else {
+		next_mccadapriv->mcc_tx_stop = _FALSE;
+		next_mccadapriv->mcc_tp_limit = _TRUE;
+		next_mccadapriv->mcc_tx_bytes_to_port = 0;
+	}
+
+	/* stop current iface kernel queue or not */
+	if (cur_mccadapriv->mcc_tx_stop)
+		rtw_netif_stop_queue(cur_iface->pnetdev);
+	else
+		rtw_netif_wake_queue(cur_iface->pnetdev);
+
+	/* stop next iface kernel queue or not */
+	if (next_mccadapriv->mcc_tx_stop)
+		rtw_netif_stop_queue(next_iface->pnetdev);
+	else
+		rtw_netif_wake_queue(next_iface->pnetdev);
+
+	/* start xmit tasklet */
+	rtw_os_xmit_schedule(next_iface);
+
+	rtw_hal_mcc_check_case_not_limit_traffic(cur_iface, next_iface);
+
+	if (0) {
+		RTW_INFO("order:%d, mcc_tx_stop:%d, mcc_tp:%d\n",
+			cur_mccadapriv->order, cur_mccadapriv->mcc_tx_stop, cur_mccadapriv->mcc_tp);
+		dump_os_queue(0, cur_iface);
+		RTW_INFO("order:%d, mcc_tx_stop:%d, mcc_tp:%d\n",
+			next_mccadapriv->order, next_mccadapriv->mcc_tx_stop, next_mccadapriv->mcc_tp);
+		dump_os_queue(0, next_iface);
+	}
+}
+
+static void rtw_hal_mcc_update_noa_start_time_hdl(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
+{
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	PADAPTER iface = NULL;
+	u8 i = 0;
+	u8 policy_idx = pmccobjpriv->policy_index;
+	u8 noa_tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
+	u8 noa_start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
+	
+	for (i = 0; i < pdvobjpriv->iface_nums; i++) {
+		iface = pdvobjpriv->padapters[i];
+		if (iface == NULL)
+			continue;
+		
+		pmccadapriv = &iface->mcc_adapterpriv;
+		/* GO & channel match */
+		if (pmccadapriv->role == MCC_ROLE_GO) {
+			/* convert GO TBTT from FW to noa_start_time(TU convert to mircosecond) */
+			pmccadapriv->noa_start_time = RTW_GET_LE32(tmpBuf + 2) + noa_start_time_offset * TU;
+
+			if (0) {
+				RTW_INFO("TBTT:0x%02x\n", RTW_GET_LE32(tmpBuf + 2));
+				RTW_INFO("noa_tsf_sync_offset:%d, noa_start_time_offset:%d\n", noa_tsf_sync_offset, noa_start_time_offset);
+				RTW_INFO(FUNC_ADPT_FMT"buf=0x%02x:0x%02x:0x%02x:0x%02x, noa_start_time=0x%02x\n"
+					, FUNC_ADPT_ARG(iface)
+					, tmpBuf[2]
+					, tmpBuf[3]
+					, tmpBuf[4]
+					, tmpBuf[5]
+					,pmccadapriv->noa_start_time);
+				}
+
+			rtw_hal_mcc_update_go_p2p_ie(iface);
+
+			break;
+		}
+	}
+
+}
+
+static void rtw_hal_mcc_rpt_tsf_hdl(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
+{
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	struct submit_ctx *mcc_tsf_req_sctx = &pmccobjpriv->mcc_tsf_req_sctx;
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	u8 iface_num = pdvobjpriv->iface_nums;
+	static u8 order = 0;
+
+	pmccadapriv = &pmccobjpriv->iface[order]->mcc_adapterpriv;
+	pmccadapriv->tsf = RTW_GET_LE64(tmpBuf + 2);
+
+
+	if (0) {
+		RTW_INFO("TSF(order:%d):%llu\n", pmccadapriv->order, pmccadapriv->tsf);
+	}
+
+	if (pmccadapriv->order == (iface_num - 1)) {
+		rtw_sctx_done(&mcc_tsf_req_sctx);
+		order = 0;
+	} else
+		order ++;
+		
+}
+
+/**
+ * rtw_hal_mcc_c2h_handler - mcc c2h handler
+ */
+void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
+{
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct submit_ctx *mcc_sctx = &pmccobjpriv->mcc_sctx;
+	_adapter *cur_adapter = NULL;
+	u8 cur_ch = 0, cur_bw = 0, cur_ch_offset = 0;
+	_irqL irqL;
+
+	/* RTW_INFO("[length]=%d, [C2H data]="MAC_FMT"\n", buflen, MAC_ARG(tmpBuf)); */
+	/* To avoid reg is set, but driver recive c2h to set wrong oper_channel */
+	if (MCC_RPT_STOPMCC == pmccobjpriv->mcc_c2h_status) {
+		RTW_INFO(FUNC_ADPT_FMT" MCC alread stops return\n", FUNC_ADPT_ARG(padapter));
+		return;
+	}
+
+	pmccobjpriv->mcc_c2h_status = tmpBuf[0];
+	pmccobjpriv->current_order = tmpBuf[1];
+	cur_adapter = pmccobjpriv->iface[pmccobjpriv->current_order];
+	cur_ch = cur_adapter->mlmeextpriv.cur_channel;
+	cur_bw = cur_adapter->mlmeextpriv.cur_bwmode;
+	cur_ch_offset = cur_adapter->mlmeextpriv.cur_ch_offset;
+	rtw_set_oper_ch(cur_adapter, cur_ch);
+	rtw_set_oper_bw(cur_adapter, cur_bw);
+	rtw_set_oper_choffset(cur_adapter, cur_ch_offset);
+
+	if (0)
+		RTW_INFO("%d,order:%d,TSF:0x%llx\n", tmpBuf[0], tmpBuf[1], RTW_GET_LE64(tmpBuf + 2));
+	
+	switch (pmccobjpriv->mcc_c2h_status) {
+	case MCC_RPT_SUCCESS:
+		_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		pmccobjpriv->cur_mcc_success_cnt++;
+		rtw_hal_mcc_upadate_chnl_bw(cur_adapter, cur_ch, cur_ch_offset, cur_bw, _FALSE);
+		_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		break;
+	case MCC_RPT_TXNULL_FAIL:
+		RTW_INFO("[MCC] TXNULL FAIL\n");
+		break;
+	case MCC_RPT_STOPMCC:
+		RTW_INFO("[MCC] MCC stop\n");
+		pmccobjpriv->mcc_c2h_status = MCC_RPT_STOPMCC;
+		rtw_hal_mcc_upadate_chnl_bw(cur_adapter, cur_ch, cur_ch_offset, cur_bw, _TRUE);
+		rtw_sctx_done(&mcc_sctx);
+		break;
+	case MCC_RPT_READY:
+		_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		/* initialize counter & time */
+		pmccobjpriv->mcc_launch_time = rtw_get_current_time();
+		pmccobjpriv->mcc_c2h_status = MCC_RPT_READY;
+		pmccobjpriv->cur_mcc_success_cnt = 0;
+		pmccobjpriv->prev_mcc_success_cnt = 0;
+		pmccobjpriv->mcc_tolerance_time = MCC_TOLERANCE_TIME;
+		_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+
+		RTW_INFO("[MCC] MCC ready (time:%d)\n", pmccobjpriv->mcc_launch_time);
+		rtw_sctx_done(&mcc_sctx);
+		break;
+	case MCC_RPT_SWICH_CHANNEL_NOTIFY:
+		rtw_hal_mcc_sw_ch_fw_notify_hdl(padapter);
+		break;
+	case MCC_RPT_UPDATE_NOA_START_TIME:
+		rtw_hal_mcc_update_noa_start_time_hdl(padapter, buflen, tmpBuf);
+		break;
+	case MCC_RPT_TSF:
+		_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		rtw_hal_mcc_rpt_tsf_hdl(padapter, buflen, tmpBuf);
+		_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		break;
+	default:
+		/* RTW_INFO("[MCC] Other MCC status(%d)\n", pmccobjpriv->mcc_c2h_status); */
+		break;
+	}
+}
+
+void rtw_hal_mcc_update_parameter(PADAPTER padapter, u8 force_update)
+{	
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	u8 cmd[H2C_MCC_TIME_SETTING_LEN] = {0};
+	u8 swchannel_early_time = MCC_SWCH_FW_EARLY_TIME;
+
+	rtw_mi_status(padapter, &mcc_mstate);
+
+	if (MSTATE_AP_NUM(&mcc_mstate) == 0) {
+		u8 need_update = _FALSE;
+		u8 start_time_offset = 0, interval = 0, duration = 0;
+
+		need_update = rtw_hal_mcc_update_timing_parameters(padapter, force_update);
+
+		if (need_update == _FALSE)
+			return;
+		
+		start_time_offset = pmccobjpriv->start_time;
+		interval = pmccobjpriv->interval;
+		duration = pmccobjpriv->iface[0]->mcc_adapterpriv.mcc_duration;
+
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, start_time_offset);
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+		SET_H2CCMD_MCC_TIME_SETTING_UPDATE(cmd, _TRUE);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(cmd, duration);
+	} else {
+		u8 policy_idx = pmccobjpriv->policy_index;
+		u8 duration = mcc_switch_channel_policy_table[policy_idx][MCC_DURATION_IDX];
+		u8 tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
+		u8 start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
+		u8 interval = mcc_switch_channel_policy_table[policy_idx][MCC_INTERVAL_IDX];
+		u8 guard_offset0 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET0_IDX];
+		u8 guard_offset1 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET1_IDX];
+		u8 order0_duration = 0;
+		u8 i = 0;
+
+		RTW_INFO("%s: policy_idx=%d\n", __func__, policy_idx);
+
+		/* GO/AP is order 0, GC/STA is order 1 */
+		order0_duration = pmccobjpriv->iface[0]->mcc_adapterpriv.mcc_duration = interval - duration;
+		pmccobjpriv->iface[1]->mcc_adapterpriv.mcc_duration = duration;
+
+		/* update IE */
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			PADAPTER iface = NULL;
+			struct mcc_adapter_priv *mccadapriv = NULL;
+
+			iface = dvobj->padapters[i];
+			if (iface == NULL)
+				continue;
+		
+			mccadapriv = &iface->mcc_adapterpriv;
+			if (mccadapriv == NULL)
+				continue;
+			
+			if (mccadapriv->role == MCC_ROLE_GO)
+				rtw_hal_mcc_update_go_p2p_ie(iface);
+		}
+
+		/* update H2C cmd */
+		/* FW set enable */
+		SET_H2CCMD_MCC_TIME_SETTING_FW_EN(cmd, _TRUE);
+		/* TSF Sync offset */
+		SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(cmd, tsf_sync_offset);
+		/* start time offset */
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, (start_time_offset + guard_offset0));
+		/* interval */
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
+		/* Early time to inform driver by C2H before switch channel */
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+		/* Port0 sync from Port1, not support multi-port */
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(cmd, HW_PORT1);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(cmd, HW_PORT0);
+		SET_H2CCMD_MCC_TIME_SETTING_UPDATE(cmd, _TRUE);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(cmd, order0_duration);
+	}
+
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_TIME_SETTING, H2C_MCC_TIME_SETTING_LEN, cmd);
+}
+
+/**
+ * rtw_hal_mcc_sw_status_check - check mcc swich channel status
+ * @padapter: primary adapter
+ */
+void rtw_hal_mcc_sw_status_check(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct pwrctrl_priv	*pwrpriv = dvobj_to_pwrctl(dvobj);
+	_adapter *iface = NULL;
+	u8 cur_cnt = 0, prev_cnt = 0, diff_cnt = 0, check_ret = _FAIL, threshold = 0;
+	u8 policy_idx = pmccobjpriv->policy_index;
+	u8 noa_enable = _FALSE;
+	u8 i = 0;
+	_irqL irqL;
+
+/* #define MCC_RESTART 1 */
+
+	if (!MCC_EN(padapter))
+		return;
+
+	rtw_mi_status(padapter, &mcc_mstate);
+
+	_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+
+	if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+
+		/* check noa enable or not */
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
+				noa_enable = _TRUE;
+				break;
+			}
+		}		
+
+		if (!noa_enable && MSTATE_AP_NUM(&mcc_mstate) == 0)
+			rtw_hal_mcc_update_parameter(padapter, _FALSE);
+
+		threshold = pmccobjpriv->mcc_stop_threshold;
+
+		if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
+			rtw_warn_on(1);
+			RTW_INFO("PS mode is not active under mcc, force exit ps mode\n");
+			LeaveAllPowerSaveModeDirect(padapter);
+		}
+
+		if (rtw_get_passing_time_ms(pmccobjpriv->mcc_launch_time) > 2000) {
+			_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+
+			cur_cnt = pmccobjpriv->cur_mcc_success_cnt;
+			prev_cnt = pmccobjpriv->prev_mcc_success_cnt;
+			if (cur_cnt < prev_cnt)
+				diff_cnt = (cur_cnt + 255) - prev_cnt;
+			else
+				diff_cnt = cur_cnt - prev_cnt;
+
+			if (diff_cnt < threshold) {
+				pmccobjpriv->mcc_tolerance_time--;
+				RTW_INFO("%s: diff_cnt:%d, tolerance_time:%d\n",
+					__func__, diff_cnt, pmccobjpriv->mcc_tolerance_time);
+			} else
+				pmccobjpriv->mcc_tolerance_time = MCC_TOLERANCE_TIME;
+
+			pmccobjpriv->prev_mcc_success_cnt = pmccobjpriv->cur_mcc_success_cnt;
+
+			if (pmccobjpriv->mcc_tolerance_time != 0)
+				check_ret = _SUCCESS;
+
+			_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+
+			if (check_ret != _SUCCESS) {
+				RTW_INFO("============ MCC swich channel check fail (%d)=============\n", diff_cnt);
+				/* restart MCC */
+				#ifdef MCC_RESTART
+					rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_STOP_DISCONNECT);
+					rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_CONNECT);
+				#endif /* MCC_RESTART */
+			}
+		} else {
+			_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+			pmccobjpriv->prev_mcc_success_cnt = pmccobjpriv->cur_mcc_success_cnt;
+			_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		}
+
+	}
+	_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+}
+
+/**
+ * rtw_hal_mcc_change_scan_flag - change scan flag under mcc
+ *
+ * MCC mode under sitesurvey goto AP channel to tx bcn & data
+ * MCC mode under sitesurvey doesn't support TX data for station mode (FW not support)
+ *
+ * @padapter: the adapter to be change scan flag
+ * @ch: pointer to rerurn ch
+ * @bw: pointer to rerurn bw
+ * @offset: pointer to rerurn offset
+ */
+u8 rtw_hal_mcc_change_scan_flag(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset)
+{
+	u8 need_ch_setting_union = _TRUE, i = 0, flags = 0, role = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	struct mlme_ext_priv *pmlmeext = NULL;
+
+	if (!MCC_EN(padapter))
+		goto exit;
+
+	if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC))
+		goto exit;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (!dvobj->padapters[i])
+				continue;
+
+		pmlmeext = &dvobj->padapters[i]->mlmeextpriv;
+		pmccadapriv = &dvobj->padapters[i]->mcc_adapterpriv;
+		role = pmccadapriv->role;
+
+		switch (role) {
+		case MCC_ROLE_AP:
+		case MCC_ROLE_GO:
+			*ch = pmlmeext->cur_channel;
+			*bw = pmlmeext->cur_bwmode;
+			*offset = pmlmeext->cur_ch_offset;
+			need_ch_setting_union = _FALSE;
+			break;
+		case MCC_ROLE_STA:
+		case MCC_ROLE_GC:
+			if (dvobj->padapters[i] != padapter) {
+				*ch = pmlmeext->cur_channel;
+				*bw = pmlmeext->cur_bwmode;
+				*offset = pmlmeext->cur_ch_offset;
+				need_ch_setting_union = _FALSE;
+			}
+			break;
+		default:
+			RTW_INFO("unknown role\n");
+			rtw_warn_on(1);
+			break;
+		}
+
+		/* check other scan flag */
+		flags = mlmeext_scan_backop_flags(pmlmeext);
+		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC))
+			flags &= ~SS_BACKOP_PS_ANNC;
+
+		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_TX_RESUME))
+			flags &= ~SS_BACKOP_TX_RESUME;
+
+		mlmeext_assign_scan_backop_flags(pmlmeext, flags);
+
+	}
+exit:
+	return need_ch_setting_union;
+}
+
+/**
+ * rtw_hal_mcc_calc_tx_bytes_from_kernel - calculte tx bytes from kernel to check concurrent tx or not
+ * @padapter: the adapter to be record tx bytes
+ * @len: data len
+ */
+inline void rtw_hal_mcc_calc_tx_bytes_from_kernel(PADAPTER padapter, u32 len)
+{
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+	if (MCC_EN(padapter)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+			pmccadapriv->mcc_tx_bytes_from_kernel += len;
+			if (0)
+				RTW_INFO("%s(order:%d): mcc tx bytes from kernel:%lld\n"
+					, __func__, pmccadapriv->order, pmccadapriv->mcc_tx_bytes_from_kernel);
+		}
+	}
+}
+
+/**
+ * rtw_hal_mcc_calc_tx_bytes_to_port - calculte tx bytes to write port in order to flow crtl
+ * @padapter: the adapter to be record tx bytes
+ * @len: data len
+ */
+inline void rtw_hal_mcc_calc_tx_bytes_to_port(PADAPTER padapter, u32 len)
+{
+	if (MCC_EN(padapter)) {
+		struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+		struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+			pmccadapriv->mcc_tx_bytes_to_port += len;
+			if (0)
+				RTW_INFO("%s(order:%d): mcc tx bytes to port:%d, mcc target tx bytes to port:%d\n"
+					, __func__, pmccadapriv->order, pmccadapriv->mcc_tx_bytes_to_port
+					, pmccadapriv->mcc_target_tx_bytes_to_port);
+		}
+	}
+}
+
+/**
+ * rtw_hal_mcc_stop_tx_bytes_to_port - stop write port to hw or not
+ * @padapter: the adapter to be stopped
+ */
+inline u8 rtw_hal_mcc_stop_tx_bytes_to_port(PADAPTER padapter)
+{
+	if (MCC_EN(padapter)) {
+		struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+		struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+			if (pmccadapriv->mcc_tp_limit) {
+				if (pmccadapriv->mcc_tx_bytes_to_port >= pmccadapriv->mcc_target_tx_bytes_to_port) {
+					pmccadapriv->mcc_tx_stop = _TRUE;
+					rtw_netif_stop_queue(padapter->pnetdev);
+					return _TRUE;
+				}
+			}
+		}
+	}
+
+	return _FALSE;
+}
+
+static void rtw_hal_mcc_assign_scan_flag(PADAPTER padapter, u8 scan_done)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	_adapter *iface = NULL;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	u8 i = 0, flags;
+
+	if (!MCC_EN(padapter))
+		return;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		pmlmeext = &iface->mlmeextpriv;
+		if (is_client_associated_to_ap(iface)) {
+			flags = mlmeext_scan_backop_flags_sta(pmlmeext);
+			if (scan_done) {
+				if (mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN)) {
+					flags &= ~SS_BACKOP_EN;
+					mlmeext_assign_scan_backop_flags_sta(pmlmeext, flags);
+				}
+			} else {
+				if (!mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN)) {
+					flags |= SS_BACKOP_EN;
+					mlmeext_assign_scan_backop_flags_sta(pmlmeext, flags);
+				}
+			}
+
+		}
+	}
+}
+
+/**
+ * rtw_hal_set_mcc_setting_scan_start - setting mcc under scan start
+ * @padapter: the adapter to be setted
+ * @ch_setting_changed: softap channel setting to be changed or not
+ */
+u8 rtw_hal_set_mcc_setting_scan_start(PADAPTER padapter)
+{
+	u8 ret = _FAIL;
+
+	if (MCC_EN(padapter)) {
+		struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+
+		_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
+			if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+				ret = rtw_hal_set_mcc_setting(padapter,  MCC_SETCMD_STATUS_STOP_SCAN_START);
+				rtw_hal_mcc_assign_scan_flag(padapter, 0);
+			}
+		}
+		_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+	}
+
+	return ret;
+}
+
+/**
+ * rtw_hal_set_mcc_setting_scan_complete - setting mcc after scan commplete
+ * @padapter: the adapter to be setted
+ * @ch_setting_changed: softap channel setting to be changed or not
+ */
+u8 rtw_hal_set_mcc_setting_scan_complete(PADAPTER padapter)
+{
+	u8 ret = _FAIL;
+
+	if (MCC_EN(padapter)) {
+		struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+
+		_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
+				rtw_hal_mcc_assign_scan_flag(padapter, 1);
+				ret = rtw_hal_set_mcc_setting(padapter,  MCC_SETCMD_STATUS_START_SCAN_DONE);	
+		}
+		_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+	}
+
+	return ret;
+}
+
+
+/**
+ * rtw_hal_set_mcc_setting_start_bss_network - setting mcc under softap start
+ * @padapter: the adapter to be setted
+ * @chbw_grouped: channel bw offset can not be allowed or not
+ */
+u8 rtw_hal_set_mcc_setting_start_bss_network(PADAPTER padapter, u8 chbw_allow)
+{
+	u8 ret = _FAIL;
+
+	if (MCC_EN(padapter)) {
+		/* channel bw offset can not be allowed, start MCC */
+		if (chbw_allow == _FALSE) {
+				struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+
+				rtw_hal_mcc_restore_iqk_val(padapter);
+				_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+				ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_CONNECT);
+				_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+			}
+		}
+
+	return ret;
+}
+
+/**
+ * rtw_hal_set_mcc_setting_disconnect - setting mcc under mlme disconnect(stop softap/disconnect from AP)
+ * @padapter: the adapter to be setted
+ */
+u8 rtw_hal_set_mcc_setting_disconnect(PADAPTER padapter)
+{
+	u8 ret = _FAIL;
+
+	if (MCC_EN(padapter)) {
+		struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+
+		_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
+			if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+				ret = rtw_hal_set_mcc_setting(padapter,  MCC_SETCMD_STATUS_STOP_DISCONNECT);
+		}
+		_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+	}
+
+	return ret;
+}
+
+/**
+ * rtw_hal_set_mcc_setting_join_done_chk_ch - setting mcc under join done
+ * @padapter: the adapter to be checked
+ */
+u8 rtw_hal_set_mcc_setting_join_done_chk_ch(PADAPTER padapter)
+{
+	u8 ret = _FAIL;
+
+	if (MCC_EN(padapter)) {
+		struct mi_state mstate;
+
+		rtw_mi_status_no_self(padapter, &mstate);
+
+		if (MSTATE_STA_LD_NUM(&mstate) || MSTATE_STA_LG_NUM(&mstate) || MSTATE_AP_NUM(&mstate)) {
+			bool chbw_allow = _TRUE;
+			u8 u_ch, u_offset, u_bw;
+			struct mlme_ext_priv *cur_mlmeext = &padapter->mlmeextpriv;
+			struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+			if (rtw_mi_get_ch_setting_union_no_self(padapter, &u_ch, &u_bw, &u_offset) <= 0) {
+				dump_adapters_status(RTW_DBGDUMP , dvobj);
+				rtw_warn_on(1);
+			}
+
+			RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n"
+				, FUNC_ADPT_ARG(padapter), u_ch, u_bw, u_offset);
+
+			/* chbw_allow? */
+			chbw_allow = rtw_is_chbw_grouped(cur_mlmeext->cur_channel
+				, cur_mlmeext->cur_bwmode, cur_mlmeext->cur_ch_offset
+					, u_ch, u_bw, u_offset);
+
+			RTW_INFO(FUNC_ADPT_FMT" chbw_allow:%d\n"
+				, FUNC_ADPT_ARG(padapter), chbw_allow);
+
+			/* if chbw_allow = false, start MCC setting */
+			if (chbw_allow == _FALSE) {
+				struct mcc_obj_priv *pmccobjpriv = &dvobj->mcc_objpriv;
+
+				rtw_hal_mcc_restore_iqk_val(padapter);
+				_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+				ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_CONNECT);
+				_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
+		}
+	}
+	}
+
+	return ret;
+}
+
+/**
+ * rtw_hal_set_mcc_setting_chk_start_clnt_join - check change channel under start clnt join
+ * @padapter: the adapter to be checked
+ * @ch: pointer to rerurn ch
+ * @bw: pointer to rerurn bw
+ * @offset: pointer to rerurn offset
+ * @chbw_allow: allow to use adapter's channel setting
+ */
+u8 rtw_hal_set_mcc_setting_chk_start_clnt_join(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset, u8 chbw_allow)
+{
+	u8 ret = _FAIL;
+
+	/* if chbw_allow = false under en_mcc = TRUE, we do not change channel related setting  */
+	if (MCC_EN(padapter)) {
+		/* restore union channel related setting to current channel related setting */
+		if (chbw_allow == _FALSE) {
+			struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+
+			/* issue null data to other interface connected to AP */
+			rtw_hal_mcc_issue_null_data(padapter, chbw_allow, _TRUE);
+
+			*ch = pmlmeext->cur_channel;
+			*bw = pmlmeext->cur_bwmode;
+			*offset = pmlmeext->cur_ch_offset;
+
+			RTW_INFO(FUNC_ADPT_FMT" en_mcc:%d(%d,%d,%d,)\n"
+				, FUNC_ADPT_ARG(padapter), MCC_EN(padapter)
+				, *ch, *bw, *offset);
+			ret = _SUCCESS;
+		}
+	}
+
+	return ret;
+}
+
+static void rtw_hal_mcc_dump_noa_content(void *sel, PADAPTER padapter)
+{
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	u8 *pos = NULL;
+	pmccadapriv = &padapter->mcc_adapterpriv;
+	/* last position for NoA attribute */
+	pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len;
+
+
+	RTW_PRINT_SEL(sel, "\nStart to dump NoA Content\n");
+	RTW_PRINT_SEL(sel, "NoA Counts:%d\n", *(pos - 13));
+	RTW_PRINT_SEL(sel, "NoA Duration(TU):%d\n", (RTW_GET_LE32(pos - 12))/TU);
+	RTW_PRINT_SEL(sel, "NoA Interval(TU):%d\n", (RTW_GET_LE32(pos - 8))/TU);
+	RTW_PRINT_SEL(sel, "NoA Start time(microseconds):0x%02x\n", RTW_GET_LE32(pos - 4));
+	RTW_PRINT_SEL(sel, "End to dump NoA Content\n");
+}
+
+void rtw_hal_dump_mcc_info(void *sel, struct dvobj_priv *dvobj)
+{
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_adapter_priv *pmccadapriv = NULL;
+	_adapter *iface = NULL, *adapter = NULL;
+	struct registry_priv *regpriv = NULL;
+	u8 i = 0;
+
+	/* regpriv is common for all adapter */
+	adapter = dvobj_get_primary_adapter(dvobj);
+
+	RTW_PRINT_SEL(sel, "**********************************************\n");
+	RTW_PRINT_SEL(sel, "en_mcc:%d\n", MCC_EN(adapter));
+	RTW_PRINT_SEL(sel, "primary adapter("ADPT_FMT") duration:%d%c\n",
+		ADPT_ARG(dvobj_get_primary_adapter(dvobj)), pmccobjpriv->duration, 37);
+	RTW_PRINT_SEL(sel, "runtime duration:%s\n", pmccobjpriv->enable_runtime_duration ? "enable":"disable");
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		regpriv = &iface->registrypriv;
+		pmccadapriv = &iface->mcc_adapterpriv;
+		if (pmccadapriv) {
+			u8 p2p_ps_mode = iface->wdinfo.p2p_ps_mode;
+
+			RTW_PRINT_SEL(sel, "adapter mcc info:\n");
+			RTW_PRINT_SEL(sel, "ifname:%s\n", ADPT_ARG(iface));
+			RTW_PRINT_SEL(sel, "order:%d\n", pmccadapriv->order);
+			RTW_PRINT_SEL(sel, "duration:%d\n", pmccadapriv->mcc_duration);
+			RTW_PRINT_SEL(sel, "target tx bytes:%d\n", pmccadapriv->mcc_target_tx_bytes_to_port);
+			RTW_PRINT_SEL(sel, "current TP:%d\n", pmccadapriv->mcc_tp);
+			RTW_PRINT_SEL(sel, "mgmt queue macid:%d\n", pmccadapriv->mgmt_queue_macid);
+			RTW_PRINT_SEL(sel, "macid bitmap:0x%02x\n", pmccadapriv->mcc_macid_bitmap);
+			RTW_PRINT_SEL(sel, "P2P NoA:%s\n\n", p2p_ps_mode == P2P_PS_NOA ? "enable":"disable");
+			RTW_PRINT_SEL(sel, "registry data:\n");
+			RTW_PRINT_SEL(sel, "ap target tx TP(BW:20M):%d Mbps\n", regpriv->rtw_mcc_ap_bw20_target_tx_tp);
+			RTW_PRINT_SEL(sel, "ap target tx TP(BW:40M):%d Mbps\n", regpriv->rtw_mcc_ap_bw40_target_tx_tp);
+			RTW_PRINT_SEL(sel, "ap target tx TP(BW:80M):%d Mbps\n", regpriv->rtw_mcc_ap_bw80_target_tx_tp);
+			RTW_PRINT_SEL(sel, "sta target tx TP(BW:20M):%d Mbps\n", regpriv->rtw_mcc_sta_bw20_target_tx_tp);
+			RTW_PRINT_SEL(sel, "sta target tx TP(BW:40M ):%d Mbps\n", regpriv->rtw_mcc_sta_bw40_target_tx_tp);
+			RTW_PRINT_SEL(sel, "sta target tx TP(BW:80M):%d Mbps\n", regpriv->rtw_mcc_sta_bw80_target_tx_tp);
+			RTW_PRINT_SEL(sel, "single tx criteria:%d Mbps\n", regpriv->rtw_mcc_single_tx_cri);
+			if (MLME_IS_GO(iface))
+				rtw_hal_mcc_dump_noa_content(sel, iface);
+			RTW_PRINT_SEL(sel, "**********************************************\n");
+		}
+	}
+	RTW_PRINT_SEL(sel, "------------------------------------------\n");
+	RTW_PRINT_SEL(sel, "policy index:%d\n", pmccobjpriv->policy_index);
+	RTW_PRINT_SEL(sel, "------------------------------------------\n");
+	RTW_PRINT_SEL(sel, "define data:\n");
+	RTW_PRINT_SEL(sel, "ap target tx TP(BW:20M):%d Mbps\n", MCC_AP_BW20_TARGET_TX_TP);
+	RTW_PRINT_SEL(sel, "ap target tx TP(BW:40M):%d Mbps\n", MCC_AP_BW40_TARGET_TX_TP);
+	RTW_PRINT_SEL(sel, "ap target tx TP(BW:80M):%d Mbps\n", MCC_AP_BW80_TARGET_TX_TP);
+	RTW_PRINT_SEL(sel, "sta target tx TP(BW:20M):%d Mbps\n", MCC_STA_BW20_TARGET_TX_TP);
+	RTW_PRINT_SEL(sel, "sta target tx TP(BW:40M):%d Mbps\n", MCC_STA_BW40_TARGET_TX_TP);
+	RTW_PRINT_SEL(sel, "sta target tx TP(BW:80M):%d Mbps\n", MCC_STA_BW80_TARGET_TX_TP);
+	RTW_PRINT_SEL(sel, "single tx criteria:%d Mbps\n", MCC_SINGLE_TX_CRITERIA);
+	RTW_PRINT_SEL(sel, "------------------------------------------\n");
+}
+
+inline void update_mcc_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
+{
+	if (MCC_EN(padapter)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+			/* use QSLT_MGNT to check mgnt queue or bcn queue */
+			if (pattrib->qsel == QSLT_MGNT) {
+				pattrib->mac_id = padapter->mcc_adapterpriv.mgmt_queue_macid;
+				pattrib->qsel = QSLT_VO;
+			}
+		}
+	}
+}
+
+inline u8 rtw_hal_mcc_link_status_chk(_adapter *padapter, const char *msg)
+{
+	u8 ret = _TRUE, i = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	_adapter *iface;
+	struct mlme_ext_priv *mlmeext;
+
+	if (MCC_EN(padapter)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
+			for (i = 0; i < dvobj->iface_nums; i++) {
+				iface = dvobj->padapters[i];
+				mlmeext = &iface->mlmeextpriv;
+				if (mlmeext_scan_state(mlmeext) != SCAN_DISABLE) {
+					#ifdef DBG_EXPIRATION_CHK
+						RTW_INFO(FUNC_ADPT_FMT" don't enter %s under scan for MCC mode\n", FUNC_ADPT_ARG(padapter), msg);
+					#endif
+					ret = _FALSE;
+					goto exit;
+				}
+			}
+		}
+	}
+
+exit:
+	return ret;
+}
+
+void rtw_hal_mcc_issue_null_data(_adapter *padapter, u8 chbw_allow, u8 ps_mode)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	_adapter *iface = NULL;
+	systime start = rtw_get_current_time();
+	u8 i = 0;
+
+	if (!MCC_EN(padapter))
+		return;
+
+	if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+		return;
+
+	if (chbw_allow == _TRUE)
+		return;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		/* issue null data to inform ap station will leave */
+		if (is_client_associated_to_ap(iface)) {
+			struct mlme_ext_priv *mlmeext = &iface->mlmeextpriv;
+			struct mlme_ext_info *mlmeextinfo = &mlmeext->mlmext_info;
+			u8 ch = mlmeext->cur_channel;
+			u8 bw = mlmeext->cur_bwmode;
+			u8 offset = mlmeext->cur_ch_offset;
+			struct sta_info *sta = rtw_get_stainfo(&iface->stapriv, get_my_bssid(&(mlmeextinfo->network)));
+
+			if (!sta)
+				continue;
+
+			set_channel_bwmode(iface, ch, offset, bw);
+
+			if (ps_mode)
+				rtw_hal_macid_sleep(iface, sta->cmn.mac_id);
+			else
+				rtw_hal_macid_wakeup(iface, sta->cmn.mac_id);
+
+			issue_nulldata(iface, NULL, ps_mode, 3, 50);
+		}
+	}
+	RTW_INFO("%s(%d ms)\n", __func__, rtw_get_passing_time_ms(start));
+}
+
+u8 *rtw_hal_mcc_append_go_p2p_ie(PADAPTER padapter, u8 *pframe, u32 *len)
+{
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+	if (!MCC_EN(padapter))
+		return pframe;
+	
+	if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+		return pframe;
+
+	if (pmccadapriv->p2p_go_noa_ie_len == 0)
+		return pframe;
+
+	_rtw_memcpy(pframe, pmccadapriv->p2p_go_noa_ie, pmccadapriv->p2p_go_noa_ie_len);
+	*len = *len + pmccadapriv->p2p_go_noa_ie_len;
+
+	return pframe + pmccadapriv->p2p_go_noa_ie_len;
+}
+
+void rtw_hal_dump_mcc_policy_table(void *sel)
+{
+	u8 idx = 0;
+	RTW_PRINT_SEL(sel, "duration\t,tsf sync offset\t,start time offset\t,interval\t,guard offset0\t,guard offset1\n");
+
+	for (idx = 0; idx < mcc_max_policy_num; idx ++) {
+		RTW_PRINT_SEL(sel, "%d\t\t,%d\t\t\t,%d\t\t\t,%d\t\t,%d\t\t,%d\n"
+			, mcc_switch_channel_policy_table[idx][MCC_DURATION_IDX]
+			, mcc_switch_channel_policy_table[idx][MCC_TSF_SYNC_OFFSET_IDX]
+			, mcc_switch_channel_policy_table[idx][MCC_START_TIME_OFFSET_IDX]
+			, mcc_switch_channel_policy_table[idx][MCC_INTERVAL_IDX]
+			, mcc_switch_channel_policy_table[idx][MCC_GUARD_OFFSET0_IDX]
+			, mcc_switch_channel_policy_table[idx][MCC_GUARD_OFFSET1_IDX]);
+	}
+}
+
+void rtw_hal_mcc_update_macid_bitmap(PADAPTER padapter, int mac_id, u8 add)
+{
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+	if (!MCC_EN(padapter))
+		return;
+
+	if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+		return;
+
+	if (pmccadapriv->role == MCC_ROLE_GC || pmccadapriv->role == MCC_ROLE_STA)
+		return;
+
+	if (mac_id < 0) {
+		RTW_WARN("%s: mac_id < 0(%d)\n", __func__, mac_id);
+		return;
+	}
+
+	RTW_INFO(ADPT_FMT" %s macid=%d, ori mcc_macid_bitmap=0x%08x\n"
+		, ADPT_ARG(padapter), add ? "add" : "clear"
+		, mac_id, pmccadapriv->mcc_macid_bitmap);
+
+	if (add)
+		pmccadapriv->mcc_macid_bitmap |= BIT(mac_id);
+	else
+		pmccadapriv->mcc_macid_bitmap &= ~(BIT(mac_id));
+
+	rtw_hal_set_mcc_macid_cmd(padapter);
+}
+
+void rtw_hal_mcc_process_noa(PADAPTER padapter)
+{
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+
+	if (!MCC_EN(padapter))
+		return;
+
+	if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+		return;
+
+	if (!MLME_IS_GC(padapter))
+		return;
+
+	switch(pwdinfo->p2p_ps_mode) {
+	case P2P_PS_NONE:
+		RTW_INFO("[MCC] Disable NoA under MCC\n");
+		rtw_hal_mcc_update_parameter(padapter, _TRUE);
+		break;
+	case P2P_PS_NOA:
+		RTW_INFO("[MCC] Enable NoA under MCC\n");
+		break;
+	default:
+		break;
+
+	}
+}
+
+void rtw_hal_mcc_parameter_init(PADAPTER padapter)
+{
+	if (!padapter->registrypriv.en_mcc)
+		return;
+
+	if (is_primary_adapter(padapter)) {
+		SET_MCC_EN_FLAG(padapter, padapter->registrypriv.en_mcc);
+		SET_MCC_DURATION(padapter, padapter->registrypriv.rtw_mcc_duration);
+		SET_MCC_RUNTIME_DURATION(padapter, padapter->registrypriv.rtw_mcc_enable_runtime_duration);
+	}
+}
+
+
+u8 rtw_set_mcc_duration_hdl(PADAPTER adapter, u8 type, const u8 *val)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	_adapter *iface = NULL;
+	u8 duration = 50;
+	u8 ret = _SUCCESS, noa_enable = _FALSE, i = 0;
+
+	if (!mccobjpriv->enable_runtime_duration)
+		goto exit;
+
+#ifdef CONFIG_P2P_PS
+	/* check noa enable or not */
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
+			noa_enable = _TRUE;
+			break;
+		}
+	}
+#endif /* CONFIG_P2P_PS */
+
+
+
+	if (type == MCC_DURATION_MAPPING) {
+		switch (*val) {
+			/* 0 = fair scheduling */
+			case 0:
+				mccobjpriv->duration= 40;
+				mccobjpriv->policy_index = 2;
+				mccobjpriv->mchan_sched_mode = MCC_FAIR_SCHEDULE;
+				break;
+			/* 1 = favor STA */
+			case 1:
+				mccobjpriv->duration= 70;
+				mccobjpriv->policy_index = 1;
+				mccobjpriv->mchan_sched_mode = MCC_FAVOE_STA;
+				break;
+			/* 2 = favor P2P*/
+			case 2:
+			default:
+				mccobjpriv->duration= 30;
+				mccobjpriv->policy_index = 0;
+				mccobjpriv->mchan_sched_mode = MCC_FAVOE_P2P;
+				break;
+		}
+	} else {
+		mccobjpriv->duration = *val;
+		rtw_hal_mcc_update_policy_table(adapter);
+	}
+
+	/* only update sw parameter under MCC 
+	    it will be force update during */
+	if (noa_enable)
+		goto exit;
+
+	if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
+		rtw_hal_mcc_update_parameter(adapter, _TRUE);
+exit:
+	return ret;
+}
+
+u8 rtw_set_mcc_duration_cmd(_adapter *adapter, u8 type, u8 val)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *pdrvextra_cmd_parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	u8 *mcc_duration = NULL;
+	u8 res = _FAIL;
+
+	
+	cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (cmdobj == NULL)
+		goto exit;
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
+		goto exit;
+	}
+
+	mcc_duration = rtw_zmalloc(sizeof(u8));
+	if (mcc_duration == NULL) {
+		rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm->ec_id = MCC_SET_DURATION_WK_CID;
+	pdrvextra_cmd_parm->type = type;
+	pdrvextra_cmd_parm->size = 1;
+	pdrvextra_cmd_parm->pbuf = mcc_duration;
+
+	_rtw_memcpy(mcc_duration, &val, 1);
+
+	init_h2fwcmd_w_parm_no_rsp(cmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+	res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+
+exit:
+	return res;
+}
+
+#endif /* CONFIG_MCC_MODE */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_mp.c
index cc05e76d44c8..b9003c18dd57 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_mp.c
@@ -1,2187 +1,2279 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#define _HAL_MP_C_
-#ifdef CONFIG_MP_INCLUDED
-
-#ifdef CONFIG_RTL8188E
-#include <rtl8188e_hal.h>
-#endif
-#ifdef CONFIG_RTL8723B
-#include <rtl8723b_hal.h>
-#endif
-#ifdef CONFIG_RTL8192E
-#include <rtl8192e_hal.h>
-#endif
-#ifdef CONFIG_RTL8814A
-#include <rtl8814a_hal.h>
-#endif
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-#include <rtl8812a_hal.h>
-#endif
-#ifdef CONFIG_RTL8703B
-#include <rtl8703b_hal.h>
-#endif
-#ifdef CONFIG_RTL8188F
-#include <rtl8188f_hal.h>
-#endif
-
-
-u8 MgntQuery_NssTxRate(u16 Rate)
-{
-	u8	NssNum = RF_TX_NUM_NONIMPLEMENT;
-	
-	if ((Rate >= MGN_MCS8 && Rate <= MGN_MCS15) || 
-		 (Rate >= MGN_VHT2SS_MCS0 && Rate <= MGN_VHT2SS_MCS9))
-		NssNum = RF_2TX;
-	else if ((Rate >= MGN_MCS16 && Rate <= MGN_MCS23) || 
-		 (Rate >= MGN_VHT3SS_MCS0 && Rate <= MGN_VHT3SS_MCS9))
-		NssNum = RF_3TX;
-	else if ((Rate >= MGN_MCS24 && Rate <= MGN_MCS31) || 
-		 (Rate >= MGN_VHT4SS_MCS0 && Rate <= MGN_VHT4SS_MCS9))
-		NssNum = RF_4TX;
-	else
-		NssNum = RF_1TX;
-		
-	return NssNum;
-}
-
-void hal_mpt_SwitchRfSetting(PADAPTER	pAdapter)
-{
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u8				ChannelToSw = pMptCtx->MptChannelToSw;
-	ULONG				ulRateIdx = pMptCtx->MptRateIndex;
-	ULONG				ulbandwidth = pMptCtx->MptBandWidth;
-	
-	/* <20120525, Kordan> Dynamic mechanism for APK, asked by Dennis.*/
-	if (IS_HARDWARE_TYPE_8188ES(pAdapter) && (1 <= ChannelToSw && ChannelToSw <= 11) &&
-		(ulRateIdx == MPT_RATE_MCS0 || ulRateIdx == MPT_RATE_1M || ulRateIdx == MPT_RATE_6M)) {
-		pMptCtx->backup0x52_RF_A = (u1Byte)PHY_QueryRFReg(pAdapter, ODM_RF_PATH_A, RF_0x52, 0x000F0);
-		pMptCtx->backup0x52_RF_B = (u1Byte)PHY_QueryRFReg(pAdapter, ODM_RF_PATH_B, RF_0x52, 0x000F0);
-		
-		if ((PlatformEFIORead4Byte(pAdapter, 0xF4)&BIT29) == BIT29) {
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_0x52, 0x000F0, 0xB);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_0x52, 0x000F0, 0xB);
-		} else {
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_0x52, 0x000F0, 0xD);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_0x52, 0x000F0, 0xD);
-		}
-	} else if (IS_HARDWARE_TYPE_8188EE(pAdapter)) { /* <20140903, VincentL> Asked by RF Eason and Edlu*/
-	
-		if (ChannelToSw == 3 && ulbandwidth == MPT_BW_40MHZ) {
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
-		} else {
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
-		}
-		
-	} else if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
-		PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_A);
-		PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_B);
-	}
-}
-
-s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-
-
-	if (!netif_running(padapter->pnetdev)) {
-		RT_TRACE(_module_mp_, _drv_warning_, ("SetPowerTracking! Fail: interface not opened!\n"));
-		return _FAIL;
-	}
-
-	if (check_fwstate(&padapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
-		RT_TRACE(_module_mp_, _drv_warning_, ("SetPowerTracking! Fail: not in MP mode!\n"));
-		return _FAIL;
-	}
-	if (enable)
-		pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = _TRUE;	
-	else
-		pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = _FALSE;
-
-	return _SUCCESS;
-}
-
-void hal_mpt_GetPowerTracking(PADAPTER padapter, u8 *enable)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-
-
-	*enable = pDM_Odm->RFCalibrateInfo.TxPowerTrackControl;
-}
-
-
-void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
-{
-	u32		TempVal = 0, TempVal2 = 0, TempVal3 = 0;
-	u32		CurrCCKSwingVal = 0, CCKSwingIndex = 12;
-	u8		i;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PMPT_CONTEXT		pMptCtx = &(Adapter->mppriv.MptCtx);
-	u1Byte				u1Channel = pHalData->CurrentChannel;
-	ULONG				ulRateIdx = pMptCtx->MptRateIndex;
-	u1Byte				DataRate = 0xFF;
-
-
-	DataRate = MptToMgntRate(ulRateIdx);
-
-	if (u1Channel == 14 && IS_CCK_RATE(DataRate))
-		pHalData->bCCKinCH14 = TRUE;
-	else
-		pHalData->bCCKinCH14 = FALSE;
-
-	if (IS_HARDWARE_TYPE_8703B(Adapter)) {
-		if ((u1Channel == 14) && IS_CCK_RATE(DataRate)) {
-			/* Channel 14 in CCK, need to set 0xA26~0xA29 to 0 for 8703B */
-			PHY_SetBBReg(Adapter, rCCK0_TxFilter2, bMaskHWord, 0);
-			PHY_SetBBReg(Adapter, rCCK0_DebugPort, bMaskLWord, 0);
-
-		} else {
-			/* Normal setting for 8703B, just recover to the default setting. */
-			/* This hardcore values reference from the parameter which BB team gave. */
-			for (i = 0 ; i < 2 ; ++i)
-				PHY_SetBBReg(Adapter, pHalData->RegForRecover[i].offset, bMaskDWord, pHalData->RegForRecover[i].value);
-
-		}
-	} else if (IS_HARDWARE_TYPE_8188F(Adapter)) {
-		/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
-		CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
-		CCKSwingIndex = 20; /* default index */
-
-		if (!pHalData->bCCKinCH14) {
-			/* Readback the current bb cck swing value and compare with the table to */
-			/* get the current swing index */
-			for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
-				if (((CurrCCKSwingVal & 0xff) == (u32)CCKSwingTable_Ch1_Ch13_88F[i][0]) &&
-				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)CCKSwingTable_Ch1_Ch13_88F[i][1])) {
-					CCKSwingIndex = i;
-					break;
-				}
-			}
-			write_bbreg(Adapter, 0xa22, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][0]);
-			write_bbreg(Adapter, 0xa23, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][1]);
-			write_bbreg(Adapter, 0xa24, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][2]);
-			write_bbreg(Adapter, 0xa25, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][3]);
-			write_bbreg(Adapter, 0xa26, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][4]);
-			write_bbreg(Adapter, 0xa27, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][5]);
-			write_bbreg(Adapter, 0xa28, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][6]);
-			write_bbreg(Adapter, 0xa29, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][7]);
-			write_bbreg(Adapter, 0xa9a, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][8]);
-			write_bbreg(Adapter, 0xa9b, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][9]);
-			write_bbreg(Adapter, 0xa9c, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][10]);
-			write_bbreg(Adapter, 0xa9d, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][11]);
-			write_bbreg(Adapter, 0xaa0, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][12]);
-			write_bbreg(Adapter, 0xaa1, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][13]);
-			write_bbreg(Adapter, 0xaa2, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][14]);
-			write_bbreg(Adapter, 0xaa3, bMaskByte0, CCKSwingTable_Ch1_Ch13_88F[CCKSwingIndex][15]);
-			DBG_871X("%s , CCKSwingTable_Ch1_Ch13_88F[%d]\n", __func__, CCKSwingIndex);
-		}  else {
-			for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
-				if (((CurrCCKSwingVal & 0xff) == (u32)CCKSwingTable_Ch14_88F[i][0]) &&
-				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)CCKSwingTable_Ch14_88F[i][1])) {
-					CCKSwingIndex = i;
-					break;
-				}
-			}
-			write_bbreg(Adapter, 0xa22, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][0]);
-			write_bbreg(Adapter, 0xa23, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][1]);
-			write_bbreg(Adapter, 0xa24, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][2]);
-			write_bbreg(Adapter, 0xa25, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][3]);
-			write_bbreg(Adapter, 0xa26, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][4]);
-			write_bbreg(Adapter, 0xa27, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][5]);
-			write_bbreg(Adapter, 0xa28, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][6]);
-			write_bbreg(Adapter, 0xa29, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][7]);
-			write_bbreg(Adapter, 0xa9a, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][8]);
-			write_bbreg(Adapter, 0xa9b, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][9]);
-			write_bbreg(Adapter, 0xa9c, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][10]);
-			write_bbreg(Adapter, 0xa9d, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][11]);
-			write_bbreg(Adapter, 0xaa0, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][12]);
-			write_bbreg(Adapter, 0xaa1, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][13]);
-			write_bbreg(Adapter, 0xaa2, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][14]);
-			write_bbreg(Adapter, 0xaa3, bMaskByte0, CCKSwingTable_Ch14_88F[CCKSwingIndex][15]);
-			DBG_871X("%s , CCKSwingTable_Ch14_88F[%d]\n", __func__, CCKSwingIndex);
-		}
-	} else {
-
-		/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
-		CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
-
-		if (!pHalData->bCCKinCH14) {
-			/* Readback the current bb cck swing value and compare with the table to */
-			/* get the current swing index */
-			for (i = 0; i < CCK_TABLE_SIZE; i++) {
-				if (((CurrCCKSwingVal & 0xff) == (u32)CCKSwingTable_Ch1_Ch13[i][0]) &&
-				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)CCKSwingTable_Ch1_Ch13[i][1])) {
-					CCKSwingIndex = i;
-					break;
-				}
-			}
-
-			/*Write 0xa22 0xa23*/
-			TempVal = CCKSwingTable_Ch1_Ch13[CCKSwingIndex][0] +
-				(CCKSwingTable_Ch1_Ch13[CCKSwingIndex][1] << 8);
-
-
-			/*Write 0xa24 ~ 0xa27*/
-			TempVal2 = 0;
-			TempVal2 = CCKSwingTable_Ch1_Ch13[CCKSwingIndex][2] +
-				(CCKSwingTable_Ch1_Ch13[CCKSwingIndex][3] << 8) +
-				(CCKSwingTable_Ch1_Ch13[CCKSwingIndex][4] << 16) +
-				(CCKSwingTable_Ch1_Ch13[CCKSwingIndex][5] << 24);
-
-			/*Write 0xa28  0xa29*/
-			TempVal3 = 0;
-			TempVal3 = CCKSwingTable_Ch1_Ch13[CCKSwingIndex][6] +
-				(CCKSwingTable_Ch1_Ch13[CCKSwingIndex][7] << 8);
-		}  else {
-			for (i = 0; i < CCK_TABLE_SIZE; i++) {
-				if (((CurrCCKSwingVal & 0xff) == (u32)CCKSwingTable_Ch14[i][0]) &&
-				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)CCKSwingTable_Ch14[i][1])) {
-					CCKSwingIndex = i;
-					break;
-				}
-			}
-
-			/*Write 0xa22 0xa23*/
-			TempVal = CCKSwingTable_Ch14[CCKSwingIndex][0] +
-				  (CCKSwingTable_Ch14[CCKSwingIndex][1] << 8);
-
-			/*Write 0xa24 ~ 0xa27*/
-			TempVal2 = 0;
-			TempVal2 = CCKSwingTable_Ch14[CCKSwingIndex][2] +
-				   (CCKSwingTable_Ch14[CCKSwingIndex][3] << 8) +
-				(CCKSwingTable_Ch14[CCKSwingIndex][4] << 16) +
-				   (CCKSwingTable_Ch14[CCKSwingIndex][5] << 24);
-
-			/*Write 0xa28  0xa29*/
-			TempVal3 = 0;
-			TempVal3 = CCKSwingTable_Ch14[CCKSwingIndex][6] +
-				   (CCKSwingTable_Ch14[CCKSwingIndex][7] << 8);
-		}
-
-		write_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord, TempVal);
-		write_bbreg(Adapter, rCCK0_TxFilter2, bMaskDWord, TempVal2);
-		write_bbreg(Adapter, rCCK0_DebugPort, bMaskLWord, TempVal3);
-	}
-
-}
-
-void hal_mpt_SetChannel(PADAPTER pAdapter)
-{
-	u8 eRFPath;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-	struct mp_priv	*pmp = &pAdapter->mppriv;
-	u8		channel = pmp->channel;
-	u8		bandwidth = pmp->bandwidth;
-
-	hal_mpt_SwitchRfSetting(pAdapter);
-
-	pHalData->bSwChnl = _TRUE;
-	pHalData->bSetChnlBW = _TRUE;
-	rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, 0, 0);
-
-	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
-
-}
-
-/*
- * Notice
- *	Switch bandwitdth may change center frequency(channel)
- */
-void hal_mpt_SetBandwidth(PADAPTER pAdapter)
-{
-	struct mp_priv *pmp = &pAdapter->mppriv;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	
-	u8		channel = pmp->channel;
-	u8		bandwidth = pmp->bandwidth;
-
-	pHalData->bSwChnl = _TRUE;
-	pHalData->bSetChnlBW = _TRUE;
-	rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, 0, 0);
-	
-	hal_mpt_SwitchRfSetting(pAdapter);
-}
-
-void mpt_SetTxPower_Old(PADAPTER pAdapter, MPT_TXPWR_DEF Rate, u8 *pTxPower)
-{
-	RT_TRACE(_module_mp_, DBG_LOUD, ("===>mpt_SetTxPower_Old(): Case = %d\n", Rate));
-	switch (Rate) {
-	case MPT_CCK:
-			{
-			u4Byte	TxAGC = 0, pwr = 0;
-			u1Byte	rf;
-
-			pwr = pTxPower[ODM_RF_PATH_A];
-			if (pwr < 0x3f) {
-				TxAGC = (pwr<<16)|(pwr<<8)|(pwr);
-				PHY_SetBBReg(pAdapter, rTxAGC_A_CCK1_Mcs32, bMaskByte1, pTxPower[ODM_RF_PATH_A]);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, 0xffffff00, TxAGC);
-			}
-			pwr = pTxPower[ODM_RF_PATH_B];
-			if (pwr < 0x3f) {
-				TxAGC = (pwr<<16)|(pwr<<8)|(pwr);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte0, pTxPower[ODM_RF_PATH_B]);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_CCK1_55_Mcs32, 0xffffff00, TxAGC);
-			}
-		    
-			} break;
-
-	case MPT_OFDM_AND_HT:
-			{
-			u4Byte	TxAGC = 0;
-			u1Byte	pwr = 0, rf;
-			
-			pwr = pTxPower[0];
-			if (pwr < 0x3f) {
-				TxAGC |= ((pwr<<24)|(pwr<<16)|(pwr<<8)|pwr);
-				DBG_871X("HT Tx-rf(A) Power = 0x%x\n", TxAGC);
-				
-				PHY_SetBBReg(pAdapter, rTxAGC_A_Rate18_06, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_A_Rate54_24, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_A_Mcs03_Mcs00, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_A_Mcs07_Mcs04, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_A_Mcs11_Mcs08, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_A_Mcs15_Mcs12, bMaskDWord, TxAGC);
-			}
-			TxAGC = 0;
-			pwr = pTxPower[1];
-			if (pwr < 0x3f) {
-				TxAGC |= ((pwr<<24)|(pwr<<16)|(pwr<<8)|pwr);
-				DBG_871X("HT Tx-rf(B) Power = 0x%x\n", TxAGC);
-				
-				PHY_SetBBReg(pAdapter, rTxAGC_B_Rate18_06, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_Rate54_24, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_Mcs03_Mcs00, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_Mcs07_Mcs04, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_Mcs11_Mcs08, bMaskDWord, TxAGC);
-				PHY_SetBBReg(pAdapter, rTxAGC_B_Mcs15_Mcs12, bMaskDWord, TxAGC);
-			}
-			} break;
-
-	default:
-		break;
-	}	
-		DBG_871X("<===mpt_SetTxPower_Old()\n");
-}
-
-
-
-void 
-mpt_SetTxPower(
-		PADAPTER		pAdapter,
-		MPT_TXPWR_DEF	Rate,
-		pu1Byte	pTxPower
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-
-	u1Byte path = 0 , i = 0, MaxRate = MGN_6M;
-	u1Byte StartPath = ODM_RF_PATH_A, EndPath = ODM_RF_PATH_B;
-	
-	if (IS_HARDWARE_TYPE_8814A(pAdapter))
-		EndPath = ODM_RF_PATH_D;
-	else if (IS_HARDWARE_TYPE_8188F(pAdapter))
-		EndPath = ODM_RF_PATH_A;
-
-	switch (Rate) {
-	case MPT_CCK:
-			{
-			u1Byte rate[] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M};
-
-			for (path = StartPath; path <= EndPath; path++)
-				for (i = 0; i < sizeof(rate); ++i)
-					PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);	
-			}
-			break;
-		
-	case MPT_OFDM:
-			{
-			u1Byte rate[] = {
-				MGN_6M, MGN_9M, MGN_12M, MGN_18M,
-				MGN_24M, MGN_36M, MGN_48M, MGN_54M,
-				};
-
-			for (path = StartPath; path <= EndPath; path++)
-				for (i = 0; i < sizeof(rate); ++i)
-					PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);	
-			} break;
-		
-	case MPT_HT:
-			{
-			u1Byte rate[] = {
-			MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4,
-			MGN_MCS5, MGN_MCS6, MGN_MCS7, MGN_MCS8, MGN_MCS9,
-			MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14,
-			MGN_MCS15, MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19,
-			MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23, MGN_MCS24,
-			MGN_MCS25, MGN_MCS26, MGN_MCS27, MGN_MCS28, MGN_MCS29,
-			MGN_MCS30, MGN_MCS31,
-			};
-			if (pHalData->rf_type == RF_3T3R)
-				MaxRate = MGN_MCS23;
-			else if (pHalData->rf_type == RF_2T2R)
-				MaxRate = MGN_MCS15;
-			else
-				MaxRate = MGN_MCS7;
-			
-			for (path = StartPath; path <= EndPath; path++) {
-				for (i = 0; i < sizeof(rate); ++i) {
-					if (rate[i] > MaxRate)
-						break;					
-				    PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
-				}
-			}
-			} break;
-		
-	case MPT_VHT:
-			{
-			u1Byte rate[] = {
-			MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4,
-			MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9,
-			MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4,
-			MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9,
-			MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4,
-			MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9,
-			MGN_VHT4SS_MCS0, MGN_VHT4SS_MCS1, MGN_VHT4SS_MCS2, MGN_VHT4SS_MCS3, MGN_VHT4SS_MCS4,
-			MGN_VHT4SS_MCS5, MGN_VHT4SS_MCS6, MGN_VHT4SS_MCS7, MGN_VHT4SS_MCS8, MGN_VHT4SS_MCS9,
-			};
-					
-			if (pHalData->rf_type == RF_3T3R)
-				MaxRate = MGN_VHT3SS_MCS9;
-			else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
-				MaxRate = MGN_VHT2SS_MCS9;
-			else
-				MaxRate = MGN_VHT1SS_MCS9;
-
-			for (path = StartPath; path <= EndPath; path++) {
-				for (i = 0; i < sizeof(rate); ++i) {
-					if (rate[i] > MaxRate)
-						break;	
-					PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
-				}
-			}
-			} break;
-			
-	default:
-			DBG_871X("<===mpt_SetTxPower: Illegal channel!!\n");
-			break;
-	}
-
-}
-
-
-void hal_mpt_SetTxPower(PADAPTER pAdapter)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-
-	if (pHalData->rf_chip < RF_TYPE_MAX) {
-		if (IS_HARDWARE_TYPE_8188E(pAdapter) || 
-			IS_HARDWARE_TYPE_8723B(pAdapter) || 
-			IS_HARDWARE_TYPE_8192E(pAdapter) || 
-			IS_HARDWARE_TYPE_8703B(pAdapter) ||
-			IS_HARDWARE_TYPE_8188F(pAdapter)) {
-			u8 path = (pHalData->AntennaTxPath == ANTENNA_A) ? (ODM_RF_PATH_A) : (ODM_RF_PATH_B);
-
-			DBG_8192C("===> MPT_ProSetTxPower: Old\n");
-
-			RT_TRACE(_module_mp_, DBG_LOUD, ("===> MPT_ProSetTxPower[Old]:\n"));
-			mpt_SetTxPower_Old(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);		
-			mpt_SetTxPower_Old(pAdapter, MPT_OFDM_AND_HT, pMptCtx->TxPwrLevel);
-
-		} else {
-			DBG_871X("===> MPT_ProSetTxPower: Jaguar\n");
-			mpt_SetTxPower(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
-			mpt_SetTxPower(pAdapter, MPT_OFDM, pMptCtx->TxPwrLevel);
-			mpt_SetTxPower(pAdapter, MPT_HT, pMptCtx->TxPwrLevel);
-			mpt_SetTxPower(pAdapter, MPT_VHT, pMptCtx->TxPwrLevel);
-
-			}
-	} else
-		DBG_8192C("RFChipID < RF_TYPE_MAX, the RF chip is not supported - %d\n", pHalData->rf_chip);
-
-	ODM_ClearTxPowerTrackingState(pDM_Odm);
-
-}
-
-
-void hal_mpt_SetDataRate(PADAPTER pAdapter)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u32 DataRate;
-
-	DataRate = MptToMgntRate(pMptCtx->MptRateIndex);
-	
-	hal_mpt_SwitchRfSetting(pAdapter);
-
-	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
-#ifdef CONFIG_RTL8723B
-	if (IS_HARDWARE_TYPE_8723B(pAdapter) || IS_HARDWARE_TYPE_8188F(pAdapter)) {
-		if (IS_CCK_RATE(DataRate)) {
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_A)
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, 0xF, 0x6);	
-			else
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x71, 0xF, 0x6);
-		} else {
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_A)
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, 0xF, 0xE);	
-			else
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x71, 0xF, 0xE);		
-		}
-	}
-	
-	if ((IS_HARDWARE_TYPE_8723BS(pAdapter) && 
-		  ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90)))) {
-		if (pMptCtx->MptRfPath == ODM_RF_PATH_A)
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, 0xF, 0xE);	
-		else
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x71, 0xF, 0xE);			
-	}
-#endif	
-}
-
-
-#define RF_PATH_AB	22
-
-#ifdef CONFIG_RTL8814A
-VOID mpt_ToggleIG_8814A(PADAPTER	pAdapter)
-{
-	u1Byte Path = 0;
-	u4Byte IGReg = rA_IGI_Jaguar, IGvalue = 0;
-
-	for (Path; Path <= ODM_RF_PATH_D; Path++) {
-		switch (Path) {
-		case ODM_RF_PATH_B:
-			IGReg = rB_IGI_Jaguar;
-			break;
-		case ODM_RF_PATH_C:
-			IGReg = rC_IGI_Jaguar2;
-			break;
-		case ODM_RF_PATH_D:
-			IGReg = rD_IGI_Jaguar2;
-			break;
-		default:
-			IGReg = rA_IGI_Jaguar;
-			break;
-		}
-
-		IGvalue = PHY_QueryBBReg(pAdapter, IGReg, bMaskByte0);
-		PHY_SetBBReg(pAdapter, IGReg, bMaskByte0, IGvalue+2);	   
-		PHY_SetBBReg(pAdapter, IGReg, bMaskByte0, IGvalue);
-	}
-}
-
-VOID mpt_SetRFPath_8814A(PADAPTER	pAdapter)
-{
-
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.MptCtx;
-	R_ANTENNA_SELECT_OFDM	*p_ofdm_tx;	/* OFDM Tx register */
-	R_ANTENNA_SELECT_CCK	*p_cck_txrx;
-	u8	ForcedDataRate = MptToMgntRate(pMptCtx->MptRateIndex);
-	u8	HtStbcCap = pAdapter->registrypriv.stbc_cap;
-	/*/PRT_HIGH_THROUGHPUT		pHTInfo = GET_HT_INFO(pMgntInfo);*/
-	/*/PRT_VERY_HIGH_THROUGHPUT	pVHTInfo = GET_VHT_INFO(pMgntInfo);*/
-
-	u32	ulAntennaTx = pHalData->AntennaTxPath;
-	u32	ulAntennaRx = pHalData->AntennaRxPath;
-	u8	NssforRate = MgntQuery_NssTxRate(ForcedDataRate);
-
-	if (NssforRate == RF_2TX) {	
-		DBG_871X("===> SetAntenna 2T ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
-
-		switch (ulAntennaTx) {
-		case ANTENNA_BC:
-				pMptCtx->MptRfPath = ODM_RF_PATH_BC;
-				/*pHalData->ValidTxPath = 0x06; linux no use */
-				PHY_SetBBReg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0000fff0, 0x106);	/*/ 0x940[15:4]=12'b0000_0100_0011*/
-				break;
-
-		case ANTENNA_CD:
-				pMptCtx->MptRfPath = ODM_RF_PATH_CD;
-				/*pHalData->ValidTxPath = 0x0C;*/
-				PHY_SetBBReg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0000fff0, 0x40c);	/*/ 0x940[15:4]=12'b0000_0100_0011*/
-				break;
-		case ANTENNA_AB: default:
-				pMptCtx->MptRfPath = ODM_RF_PATH_AB;
-				/*pHalData->ValidTxPath = 0x03;*/
-				PHY_SetBBReg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0000fff0, 0x043);	/*/ 0x940[15:4]=12'b0000_0100_0011*/
-				break;
-		}
-
-	} else if (NssforRate == RF_3TX) {
-				DBG_871X("===> SetAntenna 3T ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
-
-		switch (ulAntennaTx) {
-		case ANTENNA_BCD:
-				pMptCtx->MptRfPath = ODM_RF_PATH_BCD;
-				/*pHalData->ValidTxPath = 0x0e;*/
-				PHY_SetBBReg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x90e);	/*/ 0x940[27:16]=12'b0010_0100_0111*/
-				break;
-
-		case ANTENNA_ABC: default:
-				pMptCtx->MptRfPath = ODM_RF_PATH_ABC;
-				/*pHalData->ValidTxPath = 0x0d;*/
-				PHY_SetBBReg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x247);	/*/ 0x940[27:16]=12'b0010_0100_0111*/
-				break;
-		}
-
-	} else { /*/if(NssforRate == RF_1TX)*/
-		DBG_871X("===> SetAntenna 1T ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
-		switch (ulAntennaTx) {
-		case ANTENNA_B:
-				pMptCtx->MptRfPath = ODM_RF_PATH_B;
-				/*pHalData->ValidTxPath = 0x02;*/
-				PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x4);			/*/ 0xa07[7:4] = 4'b0100*/
-				PHY_SetBBReg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x002);	/*/ 0x93C[31:20]=12'b0000_0000_0010*/
-				PHY_SetBBReg(pAdapter, rTxPath_Jaguar, 0xf0, 0x2);					/* 0x80C[7:4] = 4'b0010*/
-				break;
-
-		case ANTENNA_C:
-				pMptCtx->MptRfPath = ODM_RF_PATH_C;
-				/*pHalData->ValidTxPath = 0x04;*/
-				PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x2);			/*/ 0xa07[7:4] = 4'b0010*/
-				PHY_SetBBReg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x004);	/*/ 0x93C[31:20]=12'b0000_0000_0100*/
-				PHY_SetBBReg(pAdapter, rTxPath_Jaguar, 0xf0, 0x4);					/*/ 0x80C[7:4] = 4'b0100*/
-				break;
-
-		case ANTENNA_D:
-				pMptCtx->MptRfPath = ODM_RF_PATH_D;
-				/*pHalData->ValidTxPath = 0x08;*/
-				PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x1);			/*/ 0xa07[7:4] = 4'b0001*/
-				PHY_SetBBReg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x008);	/*/ 0x93C[31:20]=12'b0000_0000_1000*/
-				PHY_SetBBReg(pAdapter, rTxPath_Jaguar, 0xf0, 0x8);					/*/ 0x80C[7:4] = 4'b1000*/
-				break;
-
-		case ANTENNA_A: default:
-				pMptCtx->MptRfPath = ODM_RF_PATH_A;
-				/*pHalData->ValidTxPath = 0x01;*/
-				PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x8);			/*/ 0xa07[7:4] = 4'b1000*/
-				PHY_SetBBReg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x001);	/*/ 0x93C[31:20]=12'b0000_0000_0001*/
-				PHY_SetBBReg(pAdapter, rTxPath_Jaguar, 0xf0, 0x1);					/*/ 0x80C[7:4] = 4'b0001*/
-				break;
-		}
-	}
-
-	switch (ulAntennaRx) {
-	case ANTENNA_A:
-			/*pHalData->ValidRxPath = 0x01;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x0);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
-			break;
-
-	case ANTENNA_B:
-			/*pHalData->ValidRxPath = 0x02;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);	
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x1);	
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
-			break;
-
-	case ANTENNA_C:
-			/*pHalData->ValidRxPath = 0x04;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x44);	
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x2);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
-			break;
-
-	case ANTENNA_D:
-			/*pHalData->ValidRxPath = 0x08;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x88);	
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x3);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
-			break;
-
-	case ANTENNA_BC: 
-			/*pHalData->ValidRxPath = 0x06;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x66);
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
-			break;
-
-	case ANTENNA_CD: 
-			/*pHalData->ValidRxPath = 0x0C;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xcc);
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0xB);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
-			break;
-
-	case ANTENNA_BCD: 
-			/*pHalData->ValidRxPath = 0x0e;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xee);
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, Rx mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
-			break;
-
-	case ANTENNA_ABCD: 
-			/*pHalData->ValidRxPath = 0x0f;*/
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x2);
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xff);
-			PHY_SetBBReg(pAdapter, 0x1000, bMaskByte2, 0x3);
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x1);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
-			/*/ CCA related PD_delay_th*/
-			PHY_SetBBReg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
-			PHY_SetBBReg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
-			break;
-
-	default:
-			RT_TRACE(_module_mp_, _drv_warning_, ("Unknown Rx antenna.\n"));
-			break;
-	}
-
-	PHY_Set_SecCCATH_by_RXANT_8814A(pAdapter, ulAntennaRx);
-
-	mpt_ToggleIG_8814A(pAdapter);
-	RT_TRACE(_module_mp_, _drv_notice_, ("-SwitchAntenna: finished\n"));
-}
-
-VOID
-mpt_SetSingleTone_8814A(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN	bSingleTone,
-	IN	BOOLEAN	bEnPMacTx)
-{
-
-	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u1Byte StartPath = ODM_RF_PATH_A,  EndPath = ODM_RF_PATH_A;
-	static u4Byte		regIG0 = 0, regIG1 = 0, regIG2 = 0, regIG3 = 0;
-
-	if (bSingleTone) {		
-		regIG0 = PHY_QueryBBReg(pAdapter, rA_TxScale_Jaguar, bMaskDWord);		/*/ 0xC1C[31:21]*/
-		regIG1 = PHY_QueryBBReg(pAdapter, rB_TxScale_Jaguar, bMaskDWord);		/*/ 0xE1C[31:21]*/
-		regIG2 = PHY_QueryBBReg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord);	/*/ 0x181C[31:21]*/
-		regIG3 = PHY_QueryBBReg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord);	/*/ 0x1A1C[31:21]*/
-
-		switch (pMptCtx->MptRfPath) {
-		case ODM_RF_PATH_A: case ODM_RF_PATH_B:
-		case ODM_RF_PATH_C: case ODM_RF_PATH_D:
-			StartPath = pMptCtx->MptRfPath;
-			EndPath = pMptCtx->MptRfPath;
-			break;
-		case ODM_RF_PATH_AB:
-			EndPath = ODM_RF_PATH_B;
-			break;
-		case ODM_RF_PATH_BC:
-			StartPath = ODM_RF_PATH_B;
-			EndPath = ODM_RF_PATH_C;
-			break;
-		case ODM_RF_PATH_ABC:
-			EndPath = ODM_RF_PATH_C;
-			break;
-		case ODM_RF_PATH_BCD:
-			StartPath = ODM_RF_PATH_B;
-			EndPath = ODM_RF_PATH_D;
-			break;
-		case ODM_RF_PATH_ABCD:
-			EndPath = ODM_RF_PATH_D;
-			break;
-		}
-
-		if (bEnPMacTx == FALSE) {
-			hal_mpt_SetOFDMContinuousTx(pAdapter, _TRUE);
-			issue_nulldata(pAdapter, NULL, 1, 3, 500);
-		}
-
-		PHY_SetBBReg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1); /*/ Disable CCA*/
-
-		for (StartPath; StartPath <= EndPath; StartPath++) {
-			PHY_SetRFReg(pAdapter, StartPath, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
-			PHY_SetRFReg(pAdapter, StartPath, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
-
-			PHY_SetRFReg(pAdapter, StartPath, LNA_Low_Gain_3, BIT1, 0x1); /*/ RF LO enabled*/
-		}
-
-		PHY_SetBBReg(pAdapter, rA_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xC1C[31:21]*/
-		PHY_SetBBReg(pAdapter, rB_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xE1C[31:21]*/
-		PHY_SetBBReg(pAdapter, rC_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x181C[31:21]*/
-		PHY_SetBBReg(pAdapter, rD_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x1A1C[31:21]*/
-		
-	} else {
-	
-		switch (pMptCtx->MptRfPath) {
-		case ODM_RF_PATH_A: case ODM_RF_PATH_B:
-		case ODM_RF_PATH_C: case ODM_RF_PATH_D:
-				StartPath = pMptCtx->MptRfPath;
-				EndPath = pMptCtx->MptRfPath;
-				break;
-		case ODM_RF_PATH_AB:
-				EndPath = ODM_RF_PATH_B;
-				break;
-		case ODM_RF_PATH_BC:
-				StartPath = ODM_RF_PATH_B;
-				EndPath = ODM_RF_PATH_C;
-				break;
-		case ODM_RF_PATH_ABC:
-				EndPath = ODM_RF_PATH_C;
-				break;
-		case ODM_RF_PATH_BCD:
-				StartPath = ODM_RF_PATH_B;
-				EndPath = ODM_RF_PATH_D;
-				break;
-		case ODM_RF_PATH_ABCD:
-				EndPath = ODM_RF_PATH_D;
-				break;
-		}
-		
-		for (StartPath; StartPath <= EndPath; StartPath++)
-			PHY_SetRFReg(pAdapter, StartPath, LNA_Low_Gain_3, BIT1, 0x0); /*// RF LO disabled*/
-
-		
-		PHY_SetBBReg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0); /* Enable CCA*/
-
-		if (bEnPMacTx == FALSE)
-			hal_mpt_SetOFDMContinuousTx(pAdapter, _FALSE);
-
-		PHY_SetBBReg(pAdapter, rA_TxScale_Jaguar, bMaskDWord, regIG0); /* 0xC1C[31:21]*/
-		PHY_SetBBReg(pAdapter, rB_TxScale_Jaguar, bMaskDWord, regIG1); /* 0xE1C[31:21]*/
-		PHY_SetBBReg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord, regIG2); /* 0x181C[31:21]*/
-		PHY_SetBBReg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord, regIG3); /* 0x1A1C[31:21]*/
-	}
-}
-
-#endif
-
-#if	defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-void mpt_SetRFPath_8812A(PADAPTER pAdapter)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.MptCtx;
-	u32		ulAntennaTx, ulAntennaRx;
-
-	ulAntennaTx = pHalData->AntennaTxPath;
-	ulAntennaRx = pHalData->AntennaRxPath;
-
-	switch (ulAntennaTx) {
-	case ANTENNA_A:
-			pMptCtx->MptRfPath = ODM_RF_PATH_A;
-			PHY_SetBBReg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x1111);
-			if (pHalData->RFEType == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
-				PHY_SetBBReg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);	 
-			break;
-	case ANTENNA_B:
-			pMptCtx->MptRfPath = ODM_RF_PATH_B;
-			PHY_SetBBReg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x2222);
-			if (pHalData->RFEType == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
-				PHY_SetBBReg(pAdapter,	r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x1);
-			break;
-	case ANTENNA_AB:
-			pMptCtx->MptRfPath = ODM_RF_PATH_AB;
-			PHY_SetBBReg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x3333);
-			if (pHalData->RFEType == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
-				PHY_SetBBReg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);
-			break;
-	default:
-			pMptCtx->MptRfPath = ODM_RF_PATH_AB;
-			DBG_871X("Unknown Tx antenna.\n");
-			break;
-	}
-
-	switch (ulAntennaRx) {
-			u32 reg0xC50 = 0;
-	case ANTENNA_A:
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);	
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);	   
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, BIT19|BIT18|BIT17|BIT16, 0x3); 
-
-			/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
-			reg0xC50 = PHY_QueryBBReg(pAdapter, rA_IGI_Jaguar, bMaskByte0);
-			PHY_SetBBReg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50+2);	   
-			PHY_SetBBReg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50);			
-			break;
-	case ANTENNA_B:
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1);/*/ RF_A_0x0[19:16] = 1, Standby mode */
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x1);
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, BIT19|BIT18|BIT17|BIT16, 0x3); 
-
-			/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
-			reg0xC50 = PHY_QueryBBReg(pAdapter, rB_IGI_Jaguar, bMaskByte0);
-			PHY_SetBBReg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50+2);	   
-			PHY_SetBBReg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50);						
-			break;
-	case ANTENNA_AB:
-			PHY_SetBBReg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x33);	
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, Rx mode*/
-			PHY_SetBBReg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);	
-			break;
-	default:
-			DBG_871X("Unknown Rx antenna.\n");
-			break;
-	}
-	RT_TRACE(_module_mp_, _drv_notice_, ("-SwitchAntenna: finished\n"));
-}
-#endif
-
-
-#ifdef CONFIG_RTL8723B
-void mpt_SetRFPath_8723B(PADAPTER pAdapter)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u32		ulAntennaTx, ulAntennaRx;
-	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.MptCtx);
-	PDM_ODM_T	pDM_Odm = &pHalData->odmpriv;
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	ulAntennaTx = pHalData->AntennaTxPath;
-	ulAntennaRx = pHalData->AntennaRxPath;
-
-	if (pHalData->rf_chip >= RF_TYPE_MAX) {
-		DBG_8192C("This RF chip ID is not supported\n");
-		return;
-	}
-
-	switch (pAdapter->mppriv.antenna_tx) {
-		u8 p = 0, i = 0;
-	case ANTENNA_A: /*/ Actually path S1  (Wi-Fi)*/
-			{
-			pMptCtx->MptRfPath = ODM_RF_PATH_A;			
-			PHY_SetBBReg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7, 0x0);
-			PHY_SetBBReg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
-
-			/*/<20130522, Kordan> 0x51 and 0x71 should be set immediately after path switched, or they might be overwritten.*/
-			if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90))
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B10E);
-			else
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
-
-
-			for (i = 0; i < 3; ++i) {
-				u4Byte offset = pRFCalibrateInfo->TxIQC_8723B[ODM_RF_PATH_A][i][0];
-				u4Byte data = pRFCalibrateInfo->TxIQC_8723B[ODM_RF_PATH_A][i][1];
-				
-				if (offset != 0) {
-					PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);
-					DBG_8192C("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
-				}
-
-			}
-			for (i = 0; i < 2; ++i) {
-				u4Byte offset = pRFCalibrateInfo->RxIQC_8723B[ODM_RF_PATH_A][i][0];
-				u4Byte data = pRFCalibrateInfo->RxIQC_8723B[ODM_RF_PATH_A][i][1];
-				
-				if (offset != 0) {
-					PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);					
-					DBG_8192C("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
-				}
-			}
-			}
-			break;
-	case ANTENNA_B: /*/ Actually path S0 (BT)*/
-			{
-			u4Byte offset;
-			u4Byte data;
-			
-			pMptCtx->MptRfPath = ODM_RF_PATH_B;
-			PHY_SetBBReg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7, 0x5);
-			PHY_SetBBReg(pAdapter, 0xB2C, BIT31, 0x1); /*/ AGC Table Sel.*/
-				
-			/* <20130522, Kordan> 0x51 and 0x71 should be set immediately after path switched, or they might be overwritten.*/
-			if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90))
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B10E);
-			else
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
-
-			for (i = 0; i < 3; ++i) {
-				/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC  to S1 instead of S0.*/
-				offset = pRFCalibrateInfo->TxIQC_8723B[ODM_RF_PATH_A][i][0];
-				data = pRFCalibrateInfo->TxIQC_8723B[ODM_RF_PATH_B][i][1];
-				if (pRFCalibrateInfo->TxIQC_8723B[ODM_RF_PATH_B][i][0] != 0) {
-					PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);
-					DBG_8192C("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
-				}
-			}
-			/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC to S1 instead of S0.*/
-			for (i = 0; i < 2; ++i) {
-				offset = pRFCalibrateInfo->RxIQC_8723B[ODM_RF_PATH_A][i][0];
-				data = pRFCalibrateInfo->RxIQC_8723B[ODM_RF_PATH_B][i][1];
-				
-				if (pRFCalibrateInfo->RxIQC_8723B[ODM_RF_PATH_B][i][0] != 0) {
-					PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);
-					DBG_8192C("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
-				}
-			}
-			}
-			break;
-	default:
-		pMptCtx->MptRfPath = RF_PATH_AB;
-		RT_TRACE(_module_mp_, _drv_notice_, ("Unknown Tx antenna.\n"));
-		break;
-	}
-	RT_TRACE(_module_mp_, _drv_notice_, ("-SwitchAntenna: finished\n"));
-}
-#endif
-
-#ifdef CONFIG_RTL8703B
-void mpt_SetRFPath_8703B(PADAPTER pAdapter)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u4Byte					ulAntennaTx, ulAntennaRx;
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	PODM_RF_CAL_T			pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	ulAntennaTx = pHalData->AntennaTxPath;
-	ulAntennaRx = pHalData->AntennaRxPath;
-
-	if (pHalData->rf_chip >= RF_TYPE_MAX) {
-		DBG_871X("This RF chip ID is not supported\n");
-		return;
-	}
-
-	switch (pAdapter->mppriv.antenna_tx) {
-		u1Byte p = 0, i = 0;
-
-	case ANTENNA_A: /* Actually path S1  (Wi-Fi) */
-				{
-				pMptCtx->MptRfPath = ODM_RF_PATH_A;			
-				PHY_SetBBReg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7, 0x0);
-				PHY_SetBBReg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
-
-				for (i = 0; i < 3; ++i) {
-					u4Byte offset = pRFCalibrateInfo->TxIQC_8703B[i][0];
-					u4Byte data = pRFCalibrateInfo->TxIQC_8703B[i][1];
-
-					if (offset != 0) {
-						PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);
-						DBG_871X("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
-					}
-
-				}
-				for (i = 0; i < 2; ++i) {
-					u4Byte offset = pRFCalibrateInfo->RxIQC_8703B[i][0];
-					u4Byte data = pRFCalibrateInfo->RxIQC_8703B[i][1];
-
-					if (offset != 0) {
-						PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);					
-						DBG_871X("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
-					}
-				}
-				}
-	break;
-	case ANTENNA_B: /* Actually path S0 (BT)*/
-				{
-				pMptCtx->MptRfPath = ODM_RF_PATH_B;
-				PHY_SetBBReg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7, 0x5);
-				PHY_SetBBReg(pAdapter, 0xB2C, BIT31, 0x1); /* AGC Table Sel */
-
-				for (i = 0; i < 3; ++i) {
-					u4Byte offset = pRFCalibrateInfo->TxIQC_8703B[i][0];
-					u4Byte data = pRFCalibrateInfo->TxIQC_8703B[i][1];
-
-					if (pRFCalibrateInfo->TxIQC_8703B[i][0] != 0) {
-						PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);
-						DBG_871X("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
-					}
-				}
-				for (i = 0; i < 2; ++i) {
-					u4Byte offset = pRFCalibrateInfo->RxIQC_8703B[i][0];
-					u4Byte data = pRFCalibrateInfo->RxIQC_8703B[i][1];
-
-					if (pRFCalibrateInfo->RxIQC_8703B[i][0] != 0) {
-						PHY_SetBBReg(pAdapter, offset, bMaskDWord, data);
-						DBG_871X("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
-					}
-				}
-				}
-	break;
-	default:
-			pMptCtx->MptRfPath = RF_PATH_AB; 
-			RT_TRACE(_module_mp_, _drv_notice_, ("Unknown Tx antenna.\n"));
-	break;
-	}
-
-	RT_TRACE(_module_mp_, _drv_notice_, ("-SwitchAntenna: finished\n"));
-}
-#endif
-
-
-VOID mpt_SetRFPath_819X(PADAPTER	pAdapter)
-{
-	HAL_DATA_TYPE			*pHalData	= GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u4Byte			ulAntennaTx, ulAntennaRx;
-	R_ANTENNA_SELECT_OFDM	*p_ofdm_tx;	/* OFDM Tx register */
-	R_ANTENNA_SELECT_CCK	*p_cck_txrx;
-	u1Byte		r_rx_antenna_ofdm = 0, r_ant_select_cck_val = 0;
-	u1Byte		chgTx = 0, chgRx = 0;
-	u4Byte		r_ant_sel_cck_val = 0, r_ant_select_ofdm_val = 0, r_ofdm_tx_en_val = 0;
-
-	ulAntennaTx = pHalData->AntennaTxPath;
-	ulAntennaRx = pHalData->AntennaRxPath;
-	
-	p_ofdm_tx = (R_ANTENNA_SELECT_OFDM *)&r_ant_select_ofdm_val;
-	p_cck_txrx = (R_ANTENNA_SELECT_CCK *)&r_ant_select_cck_val;
-
-	p_ofdm_tx->r_ant_ht1			= 0x1;
-	p_ofdm_tx->r_ant_ht2			= 0x2;/*Second TX RF path is A*/
-	p_ofdm_tx->r_ant_non_ht			= 0x3;/*/ 0x1+0x2=0x3 */
-
-	switch (ulAntennaTx) {
-	case ANTENNA_A:
-			p_ofdm_tx->r_tx_antenna		= 0x1;
-			r_ofdm_tx_en_val		= 0x1;
-			p_ofdm_tx->r_ant_l		= 0x1;
-			p_ofdm_tx->r_ant_ht_s1		= 0x1;
-			p_ofdm_tx->r_ant_non_ht_s1	= 0x1;
-			p_cck_txrx->r_ccktx_enable	= 0x8;
-			chgTx = 1;
-			/*/ From SD3 Willis suggestion !!! Set RF A=TX and B as standby*/
-			/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
-			{
-				PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
-				PHY_SetBBReg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 1);
-				r_ofdm_tx_en_val			= 0x3;
-				/*/ Power save*/
-				/*/cosa r_ant_select_ofdm_val = 0x11111111;*/
-				/*/ We need to close RFB by SW control*/
-			if (pHalData->rf_type == RF_2T2R) {
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 1);
-				PHY_SetBBReg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 0);
-			}
-			}
-			pMptCtx->MptRfPath = ODM_RF_PATH_A;
-			break;
-	case ANTENNA_B:
-			p_ofdm_tx->r_tx_antenna		= 0x2;
-			r_ofdm_tx_en_val		= 0x2;
-			p_ofdm_tx->r_ant_l		= 0x2;
-			p_ofdm_tx->r_ant_ht_s1		= 0x2;
-			p_ofdm_tx->r_ant_non_ht_s1	= 0x2;
-			p_cck_txrx->r_ccktx_enable	= 0x4;
-			chgTx = 1;
-			/*/ From SD3 Willis suggestion !!! Set RF A as standby*/
-			/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
-			{
-				PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 1);
-				PHY_SetBBReg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
-
-				/*/ 2008/10/31 MH From SD3 Willi's suggestion. We must read RF 1T table.*/
-				/*/ 2009/01/08 MH From Sd3 Willis. We need to close RFA by SW control*/
-			if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_1T2R) {
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 1);
-				PHY_SetBBReg(pAdapter, rFPGA0_XA_RFInterfaceOE, BIT10, 0);
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
-				/*/PHY_SetBBReg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 0);
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
-			}
-			}
-			pMptCtx->MptRfPath = ODM_RF_PATH_B;		
-			break;
-	case ANTENNA_AB:/*/ For 8192S*/
-			p_ofdm_tx->r_tx_antenna		= 0x3;
-			r_ofdm_tx_en_val		= 0x3;
-			p_ofdm_tx->r_ant_l		= 0x3;
-			p_ofdm_tx->r_ant_ht_s1		= 0x3;
-			p_ofdm_tx->r_ant_non_ht_s1	= 0x3;
-			p_cck_txrx->r_ccktx_enable	= 0xC;
-			chgTx = 1;
-			/*/ From SD3Willis suggestion !!! Set RF B as standby*/
-			/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
-			{
-			PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
-			PHY_SetBBReg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
-			/* Disable Power save*/			
-			/*cosa r_ant_select_ofdm_val = 0x3321333;*/
-			/* 2009/01/08 MH From Sd3 Willis. We need to enable RFA/B by SW control*/
-			if (pHalData->rf_type == RF_2T2R) {
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
-
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
-				/*/PHY_SetBBReg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
-				PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
-			}
-			}			
-			pMptCtx->MptRfPath = ODM_RF_PATH_AB;
-			break;
-	default:
-				break;
-	}
-
-	
-	
-/*// r_rx_antenna_ofdm, bit0=A, bit1=B, bit2=C, bit3=D
-// r_cckrx_enable : CCK default, 0=A, 1=B, 2=C, 3=D
-// r_cckrx_enable_2 : CCK option, 0=A, 1=B, 2=C, 3=D	*/
-	switch (ulAntennaRx) {
-	case ANTENNA_A:
-		r_rx_antenna_ofdm		= 0x1;	/* A*/
-		p_cck_txrx->r_cckrx_enable	= 0x0;	/* default: A*/
-		p_cck_txrx->r_cckrx_enable_2	= 0x0;	/* option: A*/
-		chgRx = 1;
-		break;
-	case ANTENNA_B:
-		r_rx_antenna_ofdm			= 0x2;	/*/ B*/
-		p_cck_txrx->r_cckrx_enable	= 0x1;	/*/ default: B*/
-		p_cck_txrx->r_cckrx_enable_2	= 0x1;	/*/ option: B*/
-		chgRx = 1;
-		break;
-	case ANTENNA_AB:/*/ For 8192S and 8192E/U...*/
-		r_rx_antenna_ofdm		= 0x3;/*/ AB*/
-		p_cck_txrx->r_cckrx_enable	= 0x0;/*/ default:A*/
-		p_cck_txrx->r_cckrx_enable_2	= 0x1;/*/ option:B*/
-		chgRx = 1;
-		break;
-	default:
-		break;
-	}
-
-
-	if (chgTx && chgRx) {
-		switch (pHalData->rf_chip) {
-		case RF_8225:
-		case RF_8256:
-		case RF_6052:
-				/*/r_ant_sel_cck_val = r_ant_select_cck_val;*/
-				PHY_SetBBReg(pAdapter, rFPGA1_TxInfo, 0x7fffffff, r_ant_select_ofdm_val);		/*/OFDM Tx*/
-				PHY_SetBBReg(pAdapter, rFPGA0_TxInfo, 0x0000000f, r_ofdm_tx_en_val);		/*/OFDM Tx*/
-				PHY_SetBBReg(pAdapter, rOFDM0_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm);	/*/OFDM Rx*/
-				PHY_SetBBReg(pAdapter, rOFDM1_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm);	/*/OFDM Rx*/
-				if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
-					PHY_SetBBReg(pAdapter, rOFDM0_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm);	/*/OFDM Rx*/
-					PHY_SetBBReg(pAdapter, rOFDM1_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm);	/*/OFDM Rx*/
-				}
-				PHY_SetBBReg(pAdapter, rCCK0_AFESetting, bMaskByte3, r_ant_select_cck_val);/*/r_ant_sel_cck_val); /CCK TxRx*/
-				break;
-
-		default:
-				DBG_871X("Unsupported RFChipID for switching antenna.\n");
-				break;
-		}
-	}
-}	/* MPT_ProSetRFPath */
-
-
-void hal_mpt_SetAntenna(PADAPTER	pAdapter)
-
-{
-	DBG_871X("Do %s\n", __func__);
-#ifdef	CONFIG_RTL8814A
-	if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
-		mpt_SetRFPath_8814A(pAdapter);
-		return;
-	}
-#endif
-#if	defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-	if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
-		mpt_SetRFPath_8812A(pAdapter);
-		return;
-	}
-#endif
-#ifdef	CONFIG_RTL8723B
-	if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
-		mpt_SetRFPath_8723B(pAdapter);
-		return;
-	}	
-#endif	
-#ifdef	CONFIG_RTL8703B
-	if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
-		mpt_SetRFPath_8703B(pAdapter);
-		return;
-	}	
-#endif	
-
-/*	else if (IS_HARDWARE_TYPE_8821B(pAdapter))
-		mpt_SetRFPath_8821B(pAdapter);
-	Prepare for 8822B
-	else if (IS_HARDWARE_TYPE_8822B(Context))
-		mpt_SetRFPath_8822B(Context);
-*/	
-	mpt_SetRFPath_819X(pAdapter);
-	DBG_871X("mpt_SetRFPath_819X Do %s\n", __func__);
-
-}
-
-
-s32 hal_mpt_SetThermalMeter(PADAPTER pAdapter, u8 target_ther)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-
-	if (!netif_running(pAdapter->pnetdev)) {
-		RT_TRACE(_module_mp_, _drv_warning_, ("SetThermalMeter! Fail: interface not opened!\n"));
-		return _FAIL;
-	}
-
-
-	if (check_fwstate(&pAdapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
-		RT_TRACE(_module_mp_, _drv_warning_, ("SetThermalMeter: Fail! not in MP mode!\n"));
-		return _FAIL;
-	}
-
-
-	target_ther &= 0xff;
-	if (target_ther < 0x07)
-		target_ther = 0x07;
-	else if (target_ther > 0x1d)
-		target_ther = 0x1d;
-
-	pHalData->EEPROMThermalMeter = target_ther;
-
-	return _SUCCESS;
-}
-
-
-void hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter)
-{
-	PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x42, BIT17 | BIT16, 0x03);
-
-}
-
-
-u8 hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter)
-
-{
-	u32 ThermalValue = 0;
-
-	ThermalValue = (u1Byte)PHY_QueryRFReg(pAdapter, ODM_RF_PATH_A, 0x42, 0xfc00);	/*0x42: RF Reg[15:10]*/
-	return (u8)ThermalValue;
-
-}
-
-
-void hal_mpt_GetThermalMeter(PADAPTER pAdapter, u8 *value)
-{
-#if 0
-	fw_cmd(pAdapter, IOCMD_GET_THERMAL_METER);
-	rtw_msleep_os(1000);
-	fw_cmd_data(pAdapter, value, 1);
-	*value &= 0xFF;
-#else
-	hal_mpt_TriggerRFThermalMeter(pAdapter);
-	rtw_msleep_os(1000);
-	*value = hal_mpt_ReadRFThermalMeter(pAdapter);
-#endif
-
-}
-
-
-void hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-	
-	pAdapter->mppriv.MptCtx.bSingleCarrier = bStart;
-	
-	if (bStart) {/*/ Start Single Carrier.*/
-		RT_TRACE(_module_mp_, _drv_alert_, ("SetSingleCarrierTx: test start\n"));
-		/*/ Start Single Carrier.*/
-		/*/ 1. if OFDM block on?*/
-		if (!PHY_QueryBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
-			PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1); /*set OFDM block on*/
-
-		/*/ 2. set CCK test mode off, set to CCK normal mode*/
-		PHY_SetBBReg(pAdapter, rCCK0_System, bCCKBBMode, 0);
-
-		/*/ 3. turn on scramble setting*/
-		PHY_SetBBReg(pAdapter, rCCK0_System, bCCKScramble, 1);
-
-		/*/ 4. Turn On Continue Tx and turn off the other test modes.*/
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) ||  defined(CONFIG_RTL8814A)
-		if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8814A(pAdapter) /*|| IS_HARDWARE_TYPE_8822B(pAdapter)*/)
-			PHY_SetBBReg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18|BIT17|BIT16, OFDM_SingleCarrier);
-		else
-#endif		
-			PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_SingleCarrier);
-
-	} else {
-		/*/ Stop Single Carrier.*/
-		/*/ Stop Single Carrier.*/
-		/*/ Turn off all test modes.*/
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) ||  defined(CONFIG_RTL8814A)		
-		if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8814A(pAdapter) /*|| IS_HARDWARE_TYPE_8822B(pAdapter)*/)
-			PHY_SetBBReg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18|BIT17|BIT16, OFDM_ALL_OFF);
-		else
-#endif
-		
-			PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ALL_OFF);
-
-		rtw_msleep_os(10);
-		/*/BB Reset*/
-	    PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
-	    PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
-	}
-}
-
-
-void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u4Byte			ulAntennaTx = pHalData->AntennaTxPath;
-	static u4Byte		regRF = 0, regBB0 = 0, regBB1 = 0, regBB2 = 0, regBB3 = 0;
-	u8 rfPath;
-
-	switch (ulAntennaTx) {
-	case ANTENNA_B:
-			rfPath = ODM_RF_PATH_B;
-			break;
-	case ANTENNA_C:
-			rfPath = ODM_RF_PATH_C;
-			break;
-	case ANTENNA_D:
-			rfPath = ODM_RF_PATH_D;
-			break;
-	case ANTENNA_A:
-	default:	
-			rfPath = ODM_RF_PATH_A;
-			break;
-	}
-
-	pAdapter->mppriv.MptCtx.bSingleTone = bStart;
-	if (bStart) {
-		/*/ Start Single Tone.*/
-		/*/ <20120326, Kordan> To amplify the power of tone for Xtal calibration. (asked by Edlu)*/
-		if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
-			regRF = PHY_QueryRFReg(pAdapter, rfPath, LNA_Low_Gain_3, bRFRegOffsetMask);
-			
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, LNA_Low_Gain_3, BIT1, 0x1); /*/ RF LO enabled*/	
-			PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x0);
-			PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x0);
-		} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) { /*/ USB need to do RF LO disable first, PCIE isn't required to follow this order.*/
-						/*/Set MAC REG 88C: Prevent SingleTone Fail*/
-			PHY_SetMacReg(pAdapter, 0x88C, 0xF00000, 0xF);
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, LNA_Low_Gain_3, BIT1, 0x1); /*/ RF LO disabled*/
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
-		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_A) {
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x56, 0xF, 0x1); /*/ RF LO enabled*/
-			} else { 
-				/*/ S0/S1 both use PATH A to configure*/
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x76, 0xF, 0x1); /*/ RF LO enabled*/
-			}
-		} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_A) {
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC, 0xF0000, 0x2); /* Tx mode */
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x53, 0xF000, 0x1); /* RF LO enabled */
-			}
-		} else if (IS_HARDWARE_TYPE_8188F(pAdapter)) {
-			/*Set BB REG 88C: Prevent SingleTone Fail*/
-			PHY_SetBBReg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xF);
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, LNA_Low_Gain_3, BIT1, 0x1);
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, RF_AC, 0xF0000, 0x2);
-
-		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-			u1Byte p = ODM_RF_PATH_A;
-			
-			regRF = PHY_QueryRFReg(pAdapter, ODM_RF_PATH_A, RF_AC_Jaguar, bRFRegOffsetMask);
-			regBB0 = PHY_QueryBBReg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord);
-			regBB1 = PHY_QueryBBReg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord);
-			regBB2 = PHY_QueryBBReg(pAdapter, rA_RFE_Pinmux_Jaguar+4, bMaskDWord);
-			regBB3 = PHY_QueryBBReg(pAdapter, rB_RFE_Pinmux_Jaguar+4, bMaskDWord);
-			
-			PHY_SetBBReg(pAdapter, rOFDMCCKEN_Jaguar, BIT29|BIT28, 0x0); /*/ Disable CCK and OFDM*/
-			
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_AB) {
-				for (p = ODM_RF_PATH_A; p <= ODM_RF_PATH_B; ++p) {					
-					PHY_SetRFReg(pAdapter, p, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
-					PHY_SetRFReg(pAdapter, p, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
-					PHY_SetRFReg(pAdapter, p, LNA_Low_Gain_3, BIT1, 0x1); /*/ RF LO enabled*/
-				}
-			} else {
-				PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
-				PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
-				PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, LNA_Low_Gain_3, BIT1, 0x1); /*/ RF LO enabled*/
-			}			
-			
-			PHY_SetBBReg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
-			PHY_SetBBReg(pAdapter, rB_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
-			
-			if (pHalData->ExternalPA_5G) {
-				PHY_SetBBReg(pAdapter, rA_RFE_Pinmux_Jaguar+4, 0xFF00000, 0x12); /*/ 0xCB4[23:16] = 0x12*/
-				PHY_SetBBReg(pAdapter, rB_RFE_Pinmux_Jaguar+4, 0xFF00000, 0x12); /*/ 0xEB4[23:16] = 0x12*/
-			} else if (pHalData->ExternalPA_2G) {
-				PHY_SetBBReg(pAdapter, rA_RFE_Pinmux_Jaguar+4, 0xFF00000, 0x11); /*/ 0xCB4[23:16] = 0x11*/
-				PHY_SetBBReg(pAdapter, rB_RFE_Pinmux_Jaguar+4, 0xFF00000, 0x11); /*/ 0xEB4[23:16] = 0x11*/
-			}
-#endif
-		}
-#ifdef CONFIG_RTL8814A 
-		else if (IS_HARDWARE_TYPE_8814A(pAdapter))
-			mpt_SetSingleTone_8814A(pAdapter, TRUE, FALSE);
-#endif
-		else	/*/ Turn On SingleTone and turn off the other test modes.*/
-			PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_SingleTone);			
-
-		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
-		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
-
-	} else {/*/ Stop Single Ton e.*/
-
-		if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
-			PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, LNA_Low_Gain_3, bRFRegOffsetMask, regRF);
-			PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x1);
-			PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
-		} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, RF_AC, 0xF0000, 0x3);/*/ Tx mode*/
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, LNA_Low_Gain_3, BIT1, 0x0);/*/ RF LO disabled */
-			/*/ RESTORE MAC REG 88C: Enable RF Functions*/
-			PHY_SetMacReg(pAdapter, 0x88C, 0xF00000, 0x0);
-		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_A) {
-			
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x56, 0xF, 0x0); /*/ RF LO disabled*/
-			} else {
-				/*/ S0/S1 both use PATH A to configure*/
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x76, 0xF, 0x0); /*/ RF LO disabled*/
-				}
-		} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
-		
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_A) {
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_AC, 0xF0000, 0x3); /* Rx mode */
-				PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, 0x53, 0xF000, 0x0); /* RF LO disabled */
-			}
-		} else if (IS_HARDWARE_TYPE_8188F(pAdapter)) {
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, RF_AC, 0xF0000, 0x3); /*Tx mode*/
-			PHY_SetRFReg(pAdapter, pMptCtx->MptRfPath, LNA_Low_Gain_3, BIT1, 0x0); /*RF LO disabled*/
-			/*Set BB REG 88C: Prevent SingleTone Fail*/
-			PHY_SetBBReg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xc);	
-		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-			u1Byte p = ODM_RF_PATH_A;
-			
-			PHY_SetBBReg(pAdapter, rOFDMCCKEN_Jaguar, BIT29|BIT28, 0x3); /*/ Disable CCK and OFDM*/
-
-			if (pMptCtx->MptRfPath == ODM_RF_PATH_AB) {
-				for (p = ODM_RF_PATH_A; p <= ODM_RF_PATH_B; ++p) {					
-					PHY_SetRFReg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
-					PHY_SetRFReg(pAdapter, p, LNA_Low_Gain_3, BIT1, 0x0); /*/ RF LO disabled*/
-				}
-			} else {
-				PHY_SetRFReg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
-				PHY_SetRFReg(pAdapter, p, LNA_Low_Gain_3, BIT1, 0x0); /*/ RF LO disabled*/
-			}
-			
-			PHY_SetBBReg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, regBB0); 
-			PHY_SetBBReg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, regBB1); 
-			PHY_SetBBReg(pAdapter, rA_RFE_Pinmux_Jaguar+4, bMaskDWord, regBB2);
-			PHY_SetBBReg(pAdapter, rB_RFE_Pinmux_Jaguar+4, bMaskDWord, regBB3);
-#endif
-		}
-#ifdef CONFIG_RTL8814A		
-		else if (IS_HARDWARE_TYPE_8814A(pAdapter))
-			mpt_SetSingleTone_8814A(pAdapter, FALSE, FALSE);
-
-		 else/*/ Turn off all test modes.*/			
-			PHY_SetBBReg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18|BIT17|BIT16, OFDM_ALL_OFF);				   
-#endif
-		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
-		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
-
-	}
-}
-
-
-void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)
-{
-	u8 Rate;
-	pAdapter->mppriv.MptCtx.bCarrierSuppression = bStart;
-
-	Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
-	if (bStart) {/* Start Carrier Suppression.*/
-		RT_TRACE(_module_mp_, _drv_alert_, ("SetCarrierSuppressionTx: test start\n"));
-		if (Rate <= MPT_RATE_11M) {
-			/*/ 1. if CCK block on?*/
-			if (!read_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn))
-				write_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn, bEnable);/*set CCK block on*/
-
-			/*/Turn Off All Test Mode*/
-			if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8814A(pAdapter) /*|| IS_HARDWARE_TYPE_8822B(pAdapter)*/)
-				PHY_SetBBReg(pAdapter, 0x914, BIT18|BIT17|BIT16, OFDM_ALL_OFF);/* rSingleTone_ContTx_Jaguar*/
-			else
-				PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ALL_OFF);
-
-			write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x2);    /*/transmit mode*/
-			write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x0);  /*/turn off scramble setting*/
-
-			/*/Set CCK Tx Test Rate*/
-			write_bbreg(pAdapter, rCCK0_System, bCCKTxRate, 0x0);    /*/Set FTxRate to 1Mbps*/
-		}
-
-		 /*Set for dynamic set Power index*/
-		 write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
-		 write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
-
-	} else {/* Stop Carrier Suppression.*/	
-		RT_TRACE(_module_mp_, _drv_alert_, ("SetCarrierSuppressionTx: test stop\n"));
-
-		if (Rate <= MPT_RATE_11M) {
-			write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x0);    /*normal mode*/
-			write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x1);  /*turn on scramble setting*/
-
-			/*BB Reset*/
-			write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
-			write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
-		}
-		/*Stop for dynamic set Power index*/
-		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
-		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
-	}
-	DBG_871X("\n MPT_ProSetCarrierSupp() is finished.\n");
-}
-
-void hal_mpt_SetCCKContinuousTx(PADAPTER pAdapter, u8 bStart)
-{
-	u32 cckrate;
-
-	if (bStart) {
-		RT_TRACE(_module_mp_, _drv_alert_,
-			 ("SetCCKContinuousTx: test start\n"));
-
-		/*/ 1. if CCK block on?*/
-		if (!read_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn))
-			write_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn, bEnable);/*set CCK block on*/
-
-		/*/Turn Off All Test Mode*/
-		if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter))
-			PHY_SetBBReg(pAdapter, 0x914, BIT18|BIT17|BIT16, OFDM_ALL_OFF);/*rSingleTone_ContTx_Jaguar*/
-		else
-			PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ALL_OFF);
-
-		/*/Set CCK Tx Test Rate*/
-
-		cckrate  = pAdapter->mppriv.rateidx;
-
-		write_bbreg(pAdapter, rCCK0_System, bCCKTxRate, cckrate);
-		write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x2);	/*/transmit mode*/
-		write_bbreg(pAdapter, rCCK0_System, bCCKScramble, bEnable);	/*/turn on scramble setting*/
-
-		if (!IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter)) {
-			PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x3);  /* rCCK0_RxHP 0xa15[1:0] = 11 force cck rxiq = 0*/
-			PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/*/ 0xc08[16] = 1 force ofdm rxiq = ofdm txiq*/
-			PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 1);
-			PHY_SetBBReg(pAdapter, 0x0B34, BIT14, 1);
-		}
-
-		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
-		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
-
-	} else {
-		RT_TRACE(_module_mp_, _drv_info_,
-			 ("SetCCKContinuousTx: test stop\n"));
-
-		write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x0);	/*/normal mode*/
-		write_bbreg(pAdapter, rCCK0_System, bCCKScramble, bEnable);	/*/turn on scramble setting*/
-
-		if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter)  && !IS_HARDWARE_TYPE_8814A(pAdapter) /* && !IS_HARDWARE_TYPE_8822B(pAdapter) */) {
-			PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x0);/* rCCK0_RxHP 0xa15[1:0] = 2b00*/
-			PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);		/*/ 0xc08[16] = 0*/
-			
-			PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 0);
-			PHY_SetBBReg(pAdapter, 0x0B34, BIT14, 0);
-		}
-		
-		/*/BB Reset*/
-		write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
-		write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
-
-		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
-		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
-	}
-
-	pAdapter->mppriv.MptCtx.bCckContTx = bStart;
-	pAdapter->mppriv.MptCtx.bOfdmContTx = _FALSE;
-}
-
-void hal_mpt_SetOFDMContinuousTx(PADAPTER pAdapter, u8 bStart)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-
-	if (bStart) {
-		RT_TRACE(_module_mp_, _drv_info_, ("SetOFDMContinuousTx: test start\n"));/*/ 1. if OFDM block on?*/
-		if (!PHY_QueryBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
-			PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1);/*/set OFDM block on*/
-
-		/*/ 2. set CCK test mode off, set to CCK normal mode*/
-		PHY_SetBBReg(pAdapter, rCCK0_System, bCCKBBMode, 0);
-
-		/*/ 3. turn on scramble setting*/
-		PHY_SetBBReg(pAdapter, rCCK0_System, bCCKScramble, 1);
-
-		if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter) && !IS_HARDWARE_TYPE_8814A(pAdapter) /*&& !IS_HARDWARE_TYPE_8822B(pAdapter)*/) {
-			PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x3);			/* rCCK0_RxHP 0xa15[1:0] = 2b'11*/
-			PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/* 0xc08[16] = 1*/
-		}
-
-		/*/ 4. Turn On Continue Tx and turn off the other test modes.*/
-		if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8814A(pAdapter) /*|| IS_HARDWARE_TYPE_8822B(pAdapter)*/)
-			PHY_SetBBReg(pAdapter, 0x914, BIT18|BIT17|BIT16, OFDM_ContinuousTx);/*rSingleTone_ContTx_Jaguar*/
-		else
-			PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ContinuousTx);
-
-		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
-		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
-
-	} else {
-		RT_TRACE(_module_mp_, _drv_info_, ("SetOFDMContinuousTx: test stop\n"));
-		if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8814A(pAdapter) /*|| IS_HARDWARE_TYPE_8822B(pAdapter)*/)
-			PHY_SetBBReg(pAdapter, 0x914, BIT18|BIT17|BIT16, OFDM_ALL_OFF);
-		else
-			PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ALL_OFF);
-		/*/Delay 10 ms*/
-		rtw_msleep_os(10);
-		
-		if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter) && !IS_HARDWARE_TYPE_8814A(pAdapter) /*&&! IS_HARDWARE_TYPE_8822B(pAdapter)*/) {
-			PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x0);/*/ 0xa15[1:0] = 0*/
-			PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);/*/ 0xc08[16] = 0*/
-		}
-		
-		/*/BB Reset*/
-		PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
-		PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
-
-		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
-		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
-	}
-
-	pAdapter->mppriv.MptCtx.bCckContTx = _FALSE;
-	pAdapter->mppriv.MptCtx.bOfdmContTx = bStart;
-}
-
-void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart)
-{
-	u8 Rate;
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("SetContinuousTx: rate:%d\n", pAdapter->mppriv.rateidx));
-
-	Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
-	pAdapter->mppriv.MptCtx.bStartContTx = bStart;
-
-	if (Rate <= MPT_RATE_11M)
-		hal_mpt_SetCCKContinuousTx(pAdapter, bStart);
-	else if (Rate >= MPT_RATE_6M) 
-		hal_mpt_SetOFDMContinuousTx(pAdapter, bStart);
-}
-
-#ifdef CONFIG_MP_VHT_HW_TX_MODE
-static	VOID mpt_StopCckContTx(
-	PADAPTER	pAdapter
-	)
-{
-	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u1Byte			u1bReg;
-
-	pMptCtx->bCckContTx = FALSE;
-	pMptCtx->bOfdmContTx = FALSE;
-
-	PHY_SetBBReg(pAdapter, rCCK0_System, bCCKBBMode, 0x0);	/*normal mode*/
-	PHY_SetBBReg(pAdapter, rCCK0_System, bCCKScramble, 0x1);	/*turn on scramble setting*/
-
-	if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter) && !IS_HARDWARE_TYPE_JAGUAR2(pAdapter)) {
-		PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x0);			/* 0xa15[1:0] = 2b00*/
-		PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);		/* 0xc08[16] = 0*/
-		
-		PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 0);
-		PHY_SetBBReg(pAdapter, 0x0B34, BIT14, 0);
-	}
-
-	/*BB Reset*/
-	PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
-	PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
-
-	PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
-	PHY_SetBBReg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
-
-}	/* mpt_StopCckContTx */
-
-
-static	VOID mpt_StopOfdmContTx(
-	PADAPTER	pAdapter
-	)
-{
-	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u1Byte			u1bReg;
-	u4Byte			data;
-
-	pMptCtx->bCckContTx = FALSE;
-	pMptCtx->bOfdmContTx = FALSE;
-
-	if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_JAGUAR2(pAdapter))
-		PHY_SetBBReg(pAdapter, 0x914, BIT18|BIT17|BIT16, OFDM_ALL_OFF);
-	else
-		PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ALL_OFF);
-
-	rtw_mdelay_os(10);
-
-	if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter) && !IS_HARDWARE_TYPE_JAGUAR2(pAdapter)) {
-		PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x0);			/* 0xa15[1:0] = 0*/
-		PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);		/* 0xc08[16] = 0*/
-	}
-
-	/*BB Reset*/
-	PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
-	PHY_SetBBReg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
-
-	PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
-	PHY_SetBBReg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
-}	/* mpt_StopOfdmContTx */
-
-
-static	VOID mpt_StartCckContTx(
-	PADAPTER		pAdapter
-	)
-{
-	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.MptCtx);
-	u4Byte			cckrate;
-
-	/* 1. if CCK block on */
-	if (!PHY_QueryBBReg(pAdapter, rFPGA0_RFMOD, bCCKEn))
-		PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bCCKEn, 1);/*set CCK block on*/
-
-	/*Turn Off All Test Mode*/
-	if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter))
-		PHY_SetBBReg(pAdapter, 0x914, BIT18|BIT17|BIT16, OFDM_ALL_OFF);
-	else
-		PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ALL_OFF);
-
-	cckrate  = pAdapter->mppriv.rateidx;
-
-	PHY_SetBBReg(pAdapter, rCCK0_System, bCCKTxRate, cckrate);
-
-	PHY_SetBBReg(pAdapter, rCCK0_System, bCCKBBMode, 0x2);	/*transmit mode*/
-	PHY_SetBBReg(pAdapter, rCCK0_System, bCCKScramble, 0x1);	/*turn on scramble setting*/
-
-	if (!IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter)) {
-		PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x3);			/* 0xa15[1:0] = 11 force cck rxiq = 0*/
-		PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/* 0xc08[16] = 1 force ofdm rxiq = ofdm txiq*/
-		PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 1);
-		PHY_SetBBReg(pAdapter, 0x0B34, BIT14, 1);
-	}
-
-	PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
-	PHY_SetBBReg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
-
-	pMptCtx->bCckContTx = TRUE;
-	pMptCtx->bOfdmContTx = FALSE;
-	
-}	/* mpt_StartCckContTx */
-
-
-static	VOID mpt_StartOfdmContTx(
-	PADAPTER		pAdapter
-	)
-{
-	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
-	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.MptCtx);
-
-	/* 1. if OFDM block on?*/
-	if (!PHY_QueryBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
-		PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1);/*set OFDM block on*/
-
-	/* 2. set CCK test mode off, set to CCK normal mode*/
-	PHY_SetBBReg(pAdapter, rCCK0_System, bCCKBBMode, 0);
-
-	/* 3. turn on scramble setting*/
-	PHY_SetBBReg(pAdapter, rCCK0_System, bCCKScramble, 1);
-
-	if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter) && !IS_HARDWARE_TYPE_JAGUAR2(pAdapter)) {
-		PHY_SetBBReg(pAdapter, 0xa14, 0x300, 0x3);			/* 0xa15[1:0] = 2b'11*/
-		PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/* 0xc08[16] = 1*/
-	}
-
-	/* 4. Turn On Continue Tx and turn off the other test modes.*/
-	if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_JAGUAR2(pAdapter))
-		PHY_SetBBReg(pAdapter, 0x914, BIT18|BIT17|BIT16, OFDM_ContinuousTx);
-	else
-		PHY_SetBBReg(pAdapter, rOFDM1_LSTF, BIT30|BIT29|BIT28, OFDM_ContinuousTx);
-	
-	PHY_SetBBReg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
-	PHY_SetBBReg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
-
-	pMptCtx->bCckContTx = FALSE;
-	pMptCtx->bOfdmContTx = TRUE;
-}	/* mpt_StartOfdmContTx */
-
-
-VOID mpt_ProSetPMacTx(PADAPTER	Adapter)
-{
-	PMPT_CONTEXT	pMptCtx		=	&(Adapter->mppriv.MptCtx);
-	RT_PMAC_TX_INFO	PMacTxInfo	=	pMptCtx->PMacTxInfo;
-	u32			u4bTmp;
-
-	DbgPrint("SGI %d bSPreamble %d bSTBC %d bLDPC %d NDP_sound %d\n", PMacTxInfo.bSGI, PMacTxInfo.bSPreamble, PMacTxInfo.bSTBC, PMacTxInfo.bLDPC, PMacTxInfo.NDP_sound);
-	DbgPrint("TXSC %d BandWidth %d PacketPeriod %d PacketCount %d PacketLength %d PacketPattern %d\n", PMacTxInfo.TX_SC, PMacTxInfo.BandWidth, PMacTxInfo.PacketPeriod, PMacTxInfo.PacketCount, PMacTxInfo.PacketLength, PMacTxInfo.PacketPattern);
-#if 0
-	PRINT_DATA("LSIG ", PMacTxInfo.LSIG, 3);
-	PRINT_DATA("HT_SIG", PMacTxInfo.HT_SIG, 6);
-	PRINT_DATA("VHT_SIG_A", PMacTxInfo.VHT_SIG_A, 6);
-	PRINT_DATA("VHT_SIG_B", PMacTxInfo.VHT_SIG_B, 4);
-	DbgPrint("VHT_SIG_B_CRC %x\n", PMacTxInfo.VHT_SIG_B_CRC);
-	PRINT_DATA("VHT_Delimiter", PMacTxInfo.VHT_Delimiter, 4);
-
-	PRINT_DATA("Src Address", Adapter->mac_addr, 6);
-	PRINT_DATA("Dest Address", PMacTxInfo.MacAddress, 6);
-#endif
-
-	if (PMacTxInfo.bEnPMacTx == FALSE) {
-		if (PMacTxInfo.Mode == CONTINUOUS_TX) {
-			PHY_SetBBReg(Adapter, 0xb04, 0xf, 2);			/*	TX Stop*/
-			if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
-				mpt_StopCckContTx(Adapter);
-			else
-				mpt_StopOfdmContTx(Adapter);
-		} else if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
-			u4bTmp = PHY_QueryBBReg(Adapter, 0xf50, bMaskLWord);
-			PHY_SetBBReg(Adapter, 0xb1c, bMaskLWord, u4bTmp+50);
-			PHY_SetBBReg(Adapter, 0xb04, 0xf, 2);		/*TX Stop*/
-		} else
-			PHY_SetBBReg(Adapter, 0xb04, 0xf, 2);		/*	TX Stop*/
-
-		if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
-			/* Stop HW TX -> Stop Continuous TX -> Stop RF Setting*/
-			if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
-				mpt_StopCckContTx(Adapter);
-			else
-				mpt_StopOfdmContTx(Adapter);
-
-			mpt_SetSingleTone_8814A(Adapter, FALSE, TRUE);
-		}
-
-		return;
-	}
-
-	if (PMacTxInfo.Mode == CONTINUOUS_TX) {
-		PMacTxInfo.PacketCount = 1;
-
-		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
-			mpt_StartCckContTx(Adapter);
-		else
-			mpt_StartOfdmContTx(Adapter);
-	} else if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
-		/* Continuous TX -> HW TX -> RF Setting */
-		PMacTxInfo.PacketCount = 1;
-
-		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
-			mpt_StartCckContTx(Adapter);
-		else
-			mpt_StartOfdmContTx(Adapter);
-	} else if (PMacTxInfo.Mode == PACKETS_TX) {
-		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE) && PMacTxInfo.PacketCount == 0)
-			PMacTxInfo.PacketCount = 0xffff;
-	}
-
-	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
-		/* 0xb1c[0:15] TX packet count 0xb1C[31:16]	SFD*/
-		u4bTmp = PMacTxInfo.PacketCount|(PMacTxInfo.SFD << 16);
-		PHY_SetBBReg(Adapter, 0xb1c, bMaskDWord, u4bTmp);
-		/* 0xb40 7:0 SIGNAL	15:8 SERVICE	31:16 LENGTH*/
-		u4bTmp = PMacTxInfo.SignalField|(PMacTxInfo.ServiceField << 8)|(PMacTxInfo.LENGTH << 16);
-		PHY_SetBBReg(Adapter, 0xb40, bMaskDWord, u4bTmp);
-		u4bTmp = PMacTxInfo.CRC16[0] | (PMacTxInfo.CRC16[1] << 8);
-		PHY_SetBBReg(Adapter, 0xb44, bMaskLWord, u4bTmp);
-
-		if (PMacTxInfo.bSPreamble)
-			PHY_SetBBReg(Adapter, 0xb0c, BIT27, 0);	
-		else
-			PHY_SetBBReg(Adapter, 0xb0c, BIT27, 1);	
-	} else {
-		PHY_SetBBReg(Adapter, 0xb18, 0xfffff, PMacTxInfo.PacketCount);
-
-		u4bTmp = PMacTxInfo.LSIG[0]|((PMacTxInfo.LSIG[1]) << 8)|((PMacTxInfo.LSIG[2]) << 16)|((PMacTxInfo.PacketPattern) << 24);
-		PHY_SetBBReg(Adapter, 0xb08, bMaskDWord, u4bTmp);	/*	Set 0xb08[23:0] = LSIG, 0xb08[31:24] =  Data init octet*/
-
-		if (PMacTxInfo.PacketPattern == 0x12)
-			u4bTmp = 0x3000000;
-		else
-			u4bTmp = 0;
-	}
-
-	if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE)) {
-		u4bTmp |= PMacTxInfo.HT_SIG[0]|((PMacTxInfo.HT_SIG[1]) << 8)|((PMacTxInfo.HT_SIG[2]) << 16);
-		PHY_SetBBReg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
-		u4bTmp = PMacTxInfo.HT_SIG[3]|((PMacTxInfo.HT_SIG[4]) << 8)|((PMacTxInfo.HT_SIG[5]) << 16);
-		PHY_SetBBReg(Adapter, 0xb10, 0xffffff, u4bTmp);
-	} else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
-		u4bTmp |= PMacTxInfo.VHT_SIG_A[0]|((PMacTxInfo.VHT_SIG_A[1]) << 8)|((PMacTxInfo.VHT_SIG_A[2]) << 16);
-		PHY_SetBBReg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
-		u4bTmp = PMacTxInfo.VHT_SIG_A[3]|((PMacTxInfo.VHT_SIG_A[4]) << 8)|((PMacTxInfo.VHT_SIG_A[5]) << 16);
-		PHY_SetBBReg(Adapter, 0xb10, 0xffffff, u4bTmp);
-
-		_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_SIG_B, 4);
-		PHY_SetBBReg(Adapter, 0xb14, bMaskDWord, u4bTmp);
-	}
-
-	if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
-		u4bTmp = (PMacTxInfo.VHT_SIG_B_CRC << 24)|PMacTxInfo.PacketPeriod;	/* for TX interval */
-		PHY_SetBBReg(Adapter, 0xb20, bMaskDWord, u4bTmp);
-
-		_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_Delimiter, 4);
-		PHY_SetBBReg(Adapter, 0xb24, bMaskDWord, u4bTmp);
-
-		/* 0xb28 - 0xb34 24 byte Probe Request MAC Header*/
-		/*& Duration & Frame control*/
-		PHY_SetBBReg(Adapter, 0xb28, bMaskDWord, 0x00000040);
-
-		/* Address1 [0:3]*/
-		u4bTmp = PMacTxInfo.MacAddress[0]|(PMacTxInfo.MacAddress[1] << 8)|(PMacTxInfo.MacAddress[2] << 16)|(PMacTxInfo.MacAddress[3] << 24);
-		PHY_SetBBReg(Adapter, 0xb2C, bMaskDWord, u4bTmp);
-
-		/* Address3 [3:0]*/
-		PHY_SetBBReg(Adapter, 0xb38, bMaskDWord, u4bTmp);
-
-		/* Address2[0:1] & Address1 [5:4]*/
-		u4bTmp = PMacTxInfo.MacAddress[4]|(PMacTxInfo.MacAddress[5] << 8)|(Adapter->mac_addr[0] << 16)|(Adapter->mac_addr[1] << 24);
-		PHY_SetBBReg(Adapter, 0xb30, bMaskDWord, u4bTmp);
-
-		/* Address2 [5:2]*/
-		u4bTmp = Adapter->mac_addr[2]|(Adapter->mac_addr[3] << 8)|(Adapter->mac_addr[4] << 16)|(Adapter->mac_addr[5] << 24);
-		PHY_SetBBReg(Adapter, 0xb34, bMaskDWord, u4bTmp);
-
-		/* Sequence Control & Address3 [5:4]*/
-		/*u4bTmp = PMacTxInfo.MacAddress[4]|(PMacTxInfo.MacAddress[5] << 8) ;*/
-		/*PHY_SetBBReg(Adapter, 0xb38, bMaskDWord, u4bTmp);*/
-	} else {
-		PHY_SetBBReg(Adapter, 0xb20, bMaskDWord, PMacTxInfo.PacketPeriod);	/* for TX interval*/
-		/* & Duration & Frame control */
-		PHY_SetBBReg(Adapter, 0xb24, bMaskDWord, 0x00000040);
-
-		/* 0xb24 - 0xb38 24 byte Probe Request MAC Header*/
-		/* Address1 [0:3]*/
-		u4bTmp = PMacTxInfo.MacAddress[0]|(PMacTxInfo.MacAddress[1] << 8)|(PMacTxInfo.MacAddress[2] << 16)|(PMacTxInfo.MacAddress[3] << 24);
-		PHY_SetBBReg(Adapter, 0xb28, bMaskDWord, u4bTmp);
-
-		/* Address3 [3:0]*/
-		PHY_SetBBReg(Adapter, 0xb34, bMaskDWord, u4bTmp);
-
-		/* Address2[0:1] & Address1 [5:4]*/
-		u4bTmp = PMacTxInfo.MacAddress[4]|(PMacTxInfo.MacAddress[5] << 8)|(Adapter->mac_addr[0] << 16)|(Adapter->mac_addr[1] << 24);
-		PHY_SetBBReg(Adapter, 0xb2c, bMaskDWord, u4bTmp);
-
-		/* Address2 [5:2] */
-		u4bTmp = Adapter->mac_addr[2]|(Adapter->mac_addr[3] << 8)|(Adapter->mac_addr[4] << 16)|(Adapter->mac_addr[5] << 24);
-		PHY_SetBBReg(Adapter, 0xb30, bMaskDWord, u4bTmp);
-
-		/* Sequence Control & Address3 [5:4]*/
-		u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8);
-		PHY_SetBBReg(Adapter, 0xb38, bMaskDWord, u4bTmp);
-	}
-
-	PHY_SetBBReg(Adapter, 0xb48, bMaskByte3, PMacTxInfo.TX_RATE_HEX);
-
-	/* 0xb4c 3:0 TXSC	5:4	BW	7:6 m_STBC	8 NDP_Sound*/
-	u4bTmp = (PMacTxInfo.TX_SC)|((PMacTxInfo.BandWidth) << 4)|((PMacTxInfo.m_STBC - 1) << 6)|((PMacTxInfo.NDP_sound) << 8);
-	PHY_SetBBReg(Adapter, 0xb4c, 0x1ff, u4bTmp);
-
-	if (IS_HARDWARE_TYPE_8814A(Adapter) || IS_HARDWARE_TYPE_8822B(Adapter)) {
-		u4Byte offset = 0xb44;
-
-		if (IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
-			PHY_SetBBReg(Adapter, offset, 0xc0000000, 0);
-		else if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE))
-			PHY_SetBBReg(Adapter, offset, 0xc0000000, 1);
-		else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
-			PHY_SetBBReg(Adapter, offset, 0xc0000000, 2);
-	}
-
-	PHY_SetBBReg(Adapter, 0xb00, BIT8, 1);		/*	Turn on PMAC*/
-/*	//PHY_SetBBReg(Adapter, 0xb04, 0xf, 2);				//TX Stop*/
-	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
-		PHY_SetBBReg(Adapter, 0xb04, 0xf, 8);		/*TX CCK ON*/	
-		PHY_SetBBReg(Adapter, 0xA84, BIT31, 0);
-	} else
-		PHY_SetBBReg(Adapter, 0xb04, 0xf, 4);		/*	TX Ofdm ON	*/
-
-	if (PMacTxInfo.Mode == OFDM_Single_Tone_TX)
-		mpt_SetSingleTone_8814A(Adapter, TRUE, TRUE);
-
-}
-#endif /* CONFIG_MP_VHT_HW_TX_MODE */
-
-#endif /* CONFIG_MP_INCLUDE*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MP_C_
+
+#include <drv_types.h>
+
+#ifdef CONFIG_MP_INCLUDED
+
+#ifdef RTW_HALMAC
+	#include <hal_data.h>		/* struct HAL_DATA_TYPE, RF register definition and etc. */
+#else /* !RTW_HALMAC */
+	#ifdef CONFIG_RTL8188E
+		#include <rtl8188e_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8723B
+		#include <rtl8723b_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8192E
+		#include <rtl8192e_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8814A
+		#include <rtl8814a_hal.h>
+	#endif
+	#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+		#include <rtl8812a_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8703B
+		#include <rtl8703b_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8723D
+		#include <rtl8723d_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8188F
+		#include <rtl8188f_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8188GTV
+		#include <rtl8188gtv_hal.h>
+	#endif
+#endif /* !RTW_HALMAC */
+
+
+u8 MgntQuery_NssTxRate(u16 Rate)
+{
+	u8	NssNum = RF_TX_NUM_NONIMPLEMENT;
+
+	if ((Rate >= MGN_MCS8 && Rate <= MGN_MCS15) ||
+	    (Rate >= MGN_VHT2SS_MCS0 && Rate <= MGN_VHT2SS_MCS9))
+		NssNum = RF_2TX;
+	else if ((Rate >= MGN_MCS16 && Rate <= MGN_MCS23) ||
+		 (Rate >= MGN_VHT3SS_MCS0 && Rate <= MGN_VHT3SS_MCS9))
+		NssNum = RF_3TX;
+	else if ((Rate >= MGN_MCS24 && Rate <= MGN_MCS31) ||
+		 (Rate >= MGN_VHT4SS_MCS0 && Rate <= MGN_VHT4SS_MCS9))
+		NssNum = RF_4TX;
+	else
+		NssNum = RF_1TX;
+
+	return NssNum;
+}
+
+void hal_mpt_SwitchRfSetting(PADAPTER	pAdapter)
+{
+	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	u8				ChannelToSw = pMptCtx->MptChannelToSw;
+	ULONG				ulRateIdx = pMptCtx->mpt_rate_index;
+	ULONG				ulbandwidth = pMptCtx->MptBandWidth;
+
+	/* <20120525, Kordan> Dynamic mechanism for APK, asked by Dennis.*/
+	if (IS_HARDWARE_TYPE_8188ES(pAdapter) && (1 <= ChannelToSw && ChannelToSw <= 11) &&
+	    (ulRateIdx == MPT_RATE_MCS0 || ulRateIdx == MPT_RATE_1M || ulRateIdx == MPT_RATE_6M)) {
+		pMptCtx->backup0x52_RF_A = (u1Byte)phy_query_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0);
+		pMptCtx->backup0x52_RF_B = (u1Byte)phy_query_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0);
+
+		if ((PlatformEFIORead4Byte(pAdapter, 0xF4) & BIT29) == BIT29) {
+			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xB);
+			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xB);
+		} else {
+			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xD);
+			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xD);
+		}
+	} else if (IS_HARDWARE_TYPE_8188EE(pAdapter)) { /* <20140903, VincentL> Asked by RF Eason and Edlu*/
+		if (ChannelToSw == 3 && ulbandwidth == MPT_BW_40MHZ) {
+			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
+			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
+		} else {
+			phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
+			phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
+		}
+	} else if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_A);
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_B);
+	}
+}
+
+s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+
+
+	if (!netif_running(padapter->pnetdev)) {
+		return _FAIL;
+	}
+
+	if (check_fwstate(&padapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
+		return _FAIL;
+	}
+	if (enable)
+		pDM_Odm->rf_calibrate_info.txpowertrack_control = _TRUE;
+	else
+		pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
+
+	return _SUCCESS;
+}
+
+void hal_mpt_GetPowerTracking(PADAPTER padapter, u8 *enable)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+
+
+	*enable = pDM_Odm->rf_calibrate_info.txpowertrack_control;
+}
+
+
+void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
+{
+	u32		TempVal = 0, TempVal2 = 0, TempVal3 = 0;
+	u32		CurrCCKSwingVal = 0, CCKSwingIndex = 12;
+	u8		i;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
+	PMPT_CONTEXT		pMptCtx = &(Adapter->mppriv.mpt_ctx);
+	u1Byte				u1Channel = pHalData->current_channel;
+	ULONG				ulRateIdx = pMptCtx->mpt_rate_index;
+	u1Byte				DataRate = 0xFF;
+
+	/* Do not modify CCK TX filter parameters for 8822B*/
+	if(IS_HARDWARE_TYPE_8822B(Adapter) || IS_HARDWARE_TYPE_8821C(Adapter) || IS_HARDWARE_TYPE_8723D(Adapter))
+		return;
+
+	DataRate = mpt_to_mgnt_rate(ulRateIdx);
+
+	if (u1Channel == 14 && IS_CCK_RATE(DataRate))
+		pHalData->bCCKinCH14 = TRUE;
+	else
+		pHalData->bCCKinCH14 = FALSE;
+
+	if (IS_HARDWARE_TYPE_8703B(Adapter)) {
+		if ((u1Channel == 14) && IS_CCK_RATE(DataRate)) {
+			/* Channel 14 in CCK, need to set 0xA26~0xA29 to 0 for 8703B */
+			phy_set_bb_reg(Adapter, rCCK0_TxFilter2, bMaskHWord, 0);
+			phy_set_bb_reg(Adapter, rCCK0_DebugPort, bMaskLWord, 0);
+
+		} else {
+			/* Normal setting for 8703B, just recover to the default setting. */
+			/* This hardcore values reference from the parameter which BB team gave. */
+			for (i = 0 ; i < 2 ; ++i)
+				phy_set_bb_reg(Adapter, pHalData->RegForRecover[i].offset, bMaskDWord, pHalData->RegForRecover[i].value);
+
+		}
+	} else if (IS_HARDWARE_TYPE_8723D(Adapter)) {
+		/* 2.4G CCK TX DFIR */
+		/* 2016.01.20 Suggest from RS BB mingzhi*/
+		if ((u1Channel == 14)) {
+			phy_set_bb_reg(Adapter, rCCK0_TxFilter2, bMaskDWord, 0x0000B81C);
+			phy_set_bb_reg(Adapter, rCCK0_DebugPort, bMaskDWord, 0x00000000);
+			phy_set_bb_reg(Adapter, 0xAAC, bMaskDWord, 0x00003667);
+		} else {
+			for (i = 0 ; i < 3 ; ++i) {
+				phy_set_bb_reg(Adapter,
+					     pHalData->RegForRecover[i].offset,
+					     bMaskDWord,
+					     pHalData->RegForRecover[i].value);
+			}
+		}
+	} else if (IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8188GTV(Adapter)) {
+		/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
+		CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
+		CCKSwingIndex = 20; /* default index */
+
+		if (!pHalData->bCCKinCH14) {
+			/* Readback the current bb cck swing value and compare with the table to */
+			/* get the current swing index */
+			for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
+				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch1_ch13_88f[i][0]) &&
+				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch1_ch13_88f[i][1])) {
+					CCKSwingIndex = i;
+					break;
+				}
+			}
+			write_bbreg(Adapter, 0xa22, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][0]);
+			write_bbreg(Adapter, 0xa23, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][1]);
+			write_bbreg(Adapter, 0xa24, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][2]);
+			write_bbreg(Adapter, 0xa25, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][3]);
+			write_bbreg(Adapter, 0xa26, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][4]);
+			write_bbreg(Adapter, 0xa27, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][5]);
+			write_bbreg(Adapter, 0xa28, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][6]);
+			write_bbreg(Adapter, 0xa29, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][7]);
+			write_bbreg(Adapter, 0xa9a, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][8]);
+			write_bbreg(Adapter, 0xa9b, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][9]);
+			write_bbreg(Adapter, 0xa9c, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][10]);
+			write_bbreg(Adapter, 0xa9d, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][11]);
+			write_bbreg(Adapter, 0xaa0, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][12]);
+			write_bbreg(Adapter, 0xaa1, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][13]);
+			write_bbreg(Adapter, 0xaa2, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][14]);
+			write_bbreg(Adapter, 0xaa3, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][15]);
+			RTW_INFO("%s , cck_swing_table_ch1_ch13_88f[%d]\n", __func__, CCKSwingIndex);
+		}  else {
+			for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
+				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch14_88f[i][0]) &&
+				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch14_88f[i][1])) {
+					CCKSwingIndex = i;
+					break;
+				}
+			}
+			write_bbreg(Adapter, 0xa22, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][0]);
+			write_bbreg(Adapter, 0xa23, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][1]);
+			write_bbreg(Adapter, 0xa24, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][2]);
+			write_bbreg(Adapter, 0xa25, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][3]);
+			write_bbreg(Adapter, 0xa26, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][4]);
+			write_bbreg(Adapter, 0xa27, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][5]);
+			write_bbreg(Adapter, 0xa28, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][6]);
+			write_bbreg(Adapter, 0xa29, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][7]);
+			write_bbreg(Adapter, 0xa9a, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][8]);
+			write_bbreg(Adapter, 0xa9b, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][9]);
+			write_bbreg(Adapter, 0xa9c, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][10]);
+			write_bbreg(Adapter, 0xa9d, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][11]);
+			write_bbreg(Adapter, 0xaa0, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][12]);
+			write_bbreg(Adapter, 0xaa1, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][13]);
+			write_bbreg(Adapter, 0xaa2, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][14]);
+			write_bbreg(Adapter, 0xaa3, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][15]);
+			RTW_INFO("%s , cck_swing_table_ch14_88f[%d]\n", __func__, CCKSwingIndex);
+		}
+	} else {
+
+		/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
+		CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
+
+		if (!pHalData->bCCKinCH14) {
+			/* Readback the current bb cck swing value and compare with the table to */
+			/* get the current swing index */
+			for (i = 0; i < CCK_TABLE_SIZE; i++) {
+				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch1_ch13[i][0]) &&
+				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch1_ch13[i][1])) {
+					CCKSwingIndex = i;
+					break;
+				}
+			}
+
+			/*Write 0xa22 0xa23*/
+			TempVal = cck_swing_table_ch1_ch13[CCKSwingIndex][0] +
+				(cck_swing_table_ch1_ch13[CCKSwingIndex][1] << 8);
+
+
+			/*Write 0xa24 ~ 0xa27*/
+			TempVal2 = 0;
+			TempVal2 = cck_swing_table_ch1_ch13[CCKSwingIndex][2] +
+				(cck_swing_table_ch1_ch13[CCKSwingIndex][3] << 8) +
+				(cck_swing_table_ch1_ch13[CCKSwingIndex][4] << 16) +
+				(cck_swing_table_ch1_ch13[CCKSwingIndex][5] << 24);
+
+			/*Write 0xa28  0xa29*/
+			TempVal3 = 0;
+			TempVal3 = cck_swing_table_ch1_ch13[CCKSwingIndex][6] +
+				(cck_swing_table_ch1_ch13[CCKSwingIndex][7] << 8);
+		}  else {
+			for (i = 0; i < CCK_TABLE_SIZE; i++) {
+				if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch14[i][0]) &&
+				    (((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch14[i][1])) {
+					CCKSwingIndex = i;
+					break;
+				}
+			}
+
+			/*Write 0xa22 0xa23*/
+			TempVal = cck_swing_table_ch14[CCKSwingIndex][0] +
+				  (cck_swing_table_ch14[CCKSwingIndex][1] << 8);
+
+			/*Write 0xa24 ~ 0xa27*/
+			TempVal2 = 0;
+			TempVal2 = cck_swing_table_ch14[CCKSwingIndex][2] +
+				   (cck_swing_table_ch14[CCKSwingIndex][3] << 8) +
+				(cck_swing_table_ch14[CCKSwingIndex][4] << 16) +
+				   (cck_swing_table_ch14[CCKSwingIndex][5] << 24);
+
+			/*Write 0xa28  0xa29*/
+			TempVal3 = 0;
+			TempVal3 = cck_swing_table_ch14[CCKSwingIndex][6] +
+				   (cck_swing_table_ch14[CCKSwingIndex][7] << 8);
+		}
+
+		write_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord, TempVal);
+		write_bbreg(Adapter, rCCK0_TxFilter2, bMaskDWord, TempVal2);
+		write_bbreg(Adapter, rCCK0_DebugPort, bMaskLWord, TempVal3);
+	}
+
+}
+
+void hal_mpt_SetChannel(PADAPTER pAdapter)
+{
+	enum rf_path eRFPath;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+	struct mp_priv	*pmp = &pAdapter->mppriv;
+	u8		channel = pmp->channel;
+	u8		bandwidth = pmp->bandwidth;
+
+	hal_mpt_SwitchRfSetting(pAdapter);
+
+	pHalData->bSwChnl = _TRUE;
+	pHalData->bSetChnlBW = _TRUE;
+
+#ifdef CONFIG_RTL8822B
+	if (bandwidth == 2) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
+	} else if (bandwidth == 1) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
+	} else
+#endif
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, pmp->prime_channel_offset, 0);
+
+	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
+
+}
+
+/*
+ * Notice
+ *	Switch bandwitdth may change center frequency(channel)
+ */
+void hal_mpt_SetBandwidth(PADAPTER pAdapter)
+{
+	struct mp_priv *pmp = &pAdapter->mppriv;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+
+	u8		channel = pmp->channel;
+	u8		bandwidth = pmp->bandwidth;
+
+	pHalData->bSwChnl = _TRUE;
+	pHalData->bSetChnlBW = _TRUE;
+
+#ifdef CONFIG_RTL8822B
+	if (bandwidth == 2) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
+	} else if (bandwidth == 1) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
+	} else
+#endif
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, 0, 0);
+
+	hal_mpt_SwitchRfSetting(pAdapter);
+}
+
+void mpt_SetTxPower_Old(PADAPTER pAdapter, MPT_TXPWR_DEF Rate, u8 *pTxPower)
+{
+	switch (Rate) {
+	case MPT_CCK: {
+		u4Byte	TxAGC = 0, pwr = 0;
+		u1Byte	rf;
+
+		pwr = pTxPower[RF_PATH_A];
+		if (pwr < 0x3f) {
+			TxAGC = (pwr << 16) | (pwr << 8) | (pwr);
+			phy_set_bb_reg(pAdapter, rTxAGC_A_CCK1_Mcs32, bMaskByte1, pTxPower[RF_PATH_A]);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, 0xffffff00, TxAGC);
+		}
+		pwr = pTxPower[RF_PATH_B];
+		if (pwr < 0x3f) {
+			TxAGC = (pwr << 16) | (pwr << 8) | (pwr);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte0, pTxPower[RF_PATH_B]);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_CCK1_55_Mcs32, 0xffffff00, TxAGC);
+		}
+	}
+	break;
+
+	case MPT_OFDM_AND_HT: {
+		u4Byte	TxAGC = 0;
+		u1Byte	pwr = 0, rf;
+
+		pwr = pTxPower[0];
+		if (pwr < 0x3f) {
+			TxAGC |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
+			RTW_INFO("HT Tx-rf(A) Power = 0x%x\n", TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_A_Rate18_06, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_A_Rate54_24, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs03_Mcs00, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs07_Mcs04, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs11_Mcs08, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs15_Mcs12, bMaskDWord, TxAGC);
+		}
+		TxAGC = 0;
+		pwr = pTxPower[1];
+		if (pwr < 0x3f) {
+			TxAGC |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
+			RTW_INFO("HT Tx-rf(B) Power = 0x%x\n", TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_Rate18_06, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_Rate54_24, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs03_Mcs00, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs07_Mcs04, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs11_Mcs08, bMaskDWord, TxAGC);
+			phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs15_Mcs12, bMaskDWord, TxAGC);
+		}
+	}
+	break;
+
+	default:
+		break;
+	}
+	RTW_INFO("<===mpt_SetTxPower_Old()\n");
+}
+
+void
+mpt_SetTxPower(
+	PADAPTER		pAdapter,
+	MPT_TXPWR_DEF	Rate,
+	pu1Byte	pTxPower
+)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+
+	u1Byte path = 0 , i = 0, MaxRate = MGN_6M;
+	u1Byte StartPath = RF_PATH_A, EndPath = RF_PATH_B;
+
+	if (IS_HARDWARE_TYPE_8814A(pAdapter))
+		EndPath = RF_PATH_D;
+	else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)
+		|| IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter))
+		EndPath = RF_PATH_A;
+
+	switch (Rate) {
+	case MPT_CCK: {
+		u1Byte rate[] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M};
+
+		for (path = StartPath; path <= EndPath; path++)
+			for (i = 0; i < sizeof(rate); ++i)
+				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
+	}
+	break;
+	case MPT_OFDM: {
+		u1Byte rate[] = {
+			MGN_6M, MGN_9M, MGN_12M, MGN_18M,
+			MGN_24M, MGN_36M, MGN_48M, MGN_54M,
+		};
+
+		for (path = StartPath; path <= EndPath; path++)
+			for (i = 0; i < sizeof(rate); ++i)
+				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
+	}
+	break;
+	case MPT_HT: {
+		u1Byte rate[] = {
+			MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4,
+			MGN_MCS5, MGN_MCS6, MGN_MCS7, MGN_MCS8, MGN_MCS9,
+			MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14,
+			MGN_MCS15, MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19,
+			MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23, MGN_MCS24,
+			MGN_MCS25, MGN_MCS26, MGN_MCS27, MGN_MCS28, MGN_MCS29,
+			MGN_MCS30, MGN_MCS31,
+		};
+		if (pHalData->rf_type == RF_3T3R)
+			MaxRate = MGN_MCS23;
+		else if (pHalData->rf_type == RF_2T2R)
+			MaxRate = MGN_MCS15;
+		else
+			MaxRate = MGN_MCS7;
+		for (path = StartPath; path <= EndPath; path++) {
+			for (i = 0; i < sizeof(rate); ++i) {
+				if (rate[i] > MaxRate)
+					break;
+				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
+			}
+		}
+	}
+	break;
+	case MPT_VHT: {
+		u1Byte rate[] = {
+			MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4,
+			MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9,
+			MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4,
+			MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9,
+			MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4,
+			MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9,
+			MGN_VHT4SS_MCS0, MGN_VHT4SS_MCS1, MGN_VHT4SS_MCS2, MGN_VHT4SS_MCS3, MGN_VHT4SS_MCS4,
+			MGN_VHT4SS_MCS5, MGN_VHT4SS_MCS6, MGN_VHT4SS_MCS7, MGN_VHT4SS_MCS8, MGN_VHT4SS_MCS9,
+		};
+		if (pHalData->rf_type == RF_3T3R)
+			MaxRate = MGN_VHT3SS_MCS9;
+		else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
+			MaxRate = MGN_VHT2SS_MCS9;
+		else
+			MaxRate = MGN_VHT1SS_MCS9;
+
+		for (path = StartPath; path <= EndPath; path++) {
+			for (i = 0; i < sizeof(rate); ++i) {
+				if (rate[i] > MaxRate)
+					break;
+				PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
+			}
+		}
+	}
+	break;
+	default:
+		RTW_INFO("<===mpt_SetTxPower: Illegal channel!!\n");
+		break;
+	}
+}
+
+void hal_mpt_SetTxPower(PADAPTER pAdapter)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+
+	if (pHalData->rf_chip < RF_CHIP_MAX) {
+		if (IS_HARDWARE_TYPE_8188E(pAdapter) ||
+		    IS_HARDWARE_TYPE_8723B(pAdapter) ||
+		    IS_HARDWARE_TYPE_8192E(pAdapter) ||
+		    IS_HARDWARE_TYPE_8703B(pAdapter) ||
+		    IS_HARDWARE_TYPE_8188F(pAdapter) ||
+		    IS_HARDWARE_TYPE_8188GTV(pAdapter)
+		) {
+			u8 path = (pHalData->antenna_tx_path == ANTENNA_A) ? (RF_PATH_A) : (RF_PATH_B);
+
+			RTW_INFO("===> MPT_ProSetTxPower: Old\n");
+
+			mpt_SetTxPower_Old(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
+			mpt_SetTxPower_Old(pAdapter, MPT_OFDM_AND_HT, pMptCtx->TxPwrLevel);
+
+		} else {
+			RTW_INFO("===> MPT_ProSetTxPower: Jaguar/Jaguar2\n");
+			mpt_SetTxPower(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
+			mpt_SetTxPower(pAdapter, MPT_OFDM, pMptCtx->TxPwrLevel);
+			mpt_SetTxPower(pAdapter, MPT_HT, pMptCtx->TxPwrLevel);
+			mpt_SetTxPower(pAdapter, MPT_VHT, pMptCtx->TxPwrLevel);
+
+		}
+	} else
+		RTW_INFO("RFChipID < RF_CHIP_MAX, the RF chip is not supported - %d\n", pHalData->rf_chip);
+
+	odm_clear_txpowertracking_state(pDM_Odm);
+}
+
+void hal_mpt_SetDataRate(PADAPTER pAdapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	u32 DataRate;
+
+	DataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
+
+	hal_mpt_SwitchRfSetting(pAdapter);
+
+	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
+#ifdef CONFIG_RTL8723B
+	if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
+		if (IS_CCK_RATE(DataRate)) {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A)
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0x6);
+			else
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0x6);
+		} else {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A)
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0xE);
+			else
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0xE);
+		}
+	}
+
+	if ((IS_HARDWARE_TYPE_8723BS(pAdapter) &&
+	     ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90)))) {
+		if (pMptCtx->mpt_rf_path == RF_PATH_A)
+			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0xE);
+		else
+			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0xE);
+	}
+#endif
+}
+
+#define RF_PATH_AB	22
+
+#ifdef CONFIG_RTL8814A
+VOID mpt_ToggleIG_8814A(PADAPTER	pAdapter)
+{
+	u1Byte Path = 0;
+	u4Byte IGReg = rA_IGI_Jaguar, IGvalue = 0;
+
+	for (Path; Path <= RF_PATH_D; Path++) {
+		switch (Path) {
+		case RF_PATH_B:
+			IGReg = rB_IGI_Jaguar;
+			break;
+		case RF_PATH_C:
+			IGReg = rC_IGI_Jaguar2;
+			break;
+		case RF_PATH_D:
+			IGReg = rD_IGI_Jaguar2;
+			break;
+		default:
+			IGReg = rA_IGI_Jaguar;
+			break;
+		}
+
+		IGvalue = phy_query_bb_reg(pAdapter, IGReg, bMaskByte0);
+		phy_set_bb_reg(pAdapter, IGReg, bMaskByte0, IGvalue + 2);
+		phy_set_bb_reg(pAdapter, IGReg, bMaskByte0, IGvalue);
+	}
+}
+
+VOID mpt_SetRFPath_8814A(PADAPTER	pAdapter)
+{
+
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.mpt_ctx;
+	R_ANTENNA_SELECT_OFDM	*p_ofdm_tx;	/* OFDM Tx register */
+	R_ANTENNA_SELECT_CCK	*p_cck_txrx;
+	u8	ForcedDataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
+	u8	HtStbcCap = pAdapter->registrypriv.stbc_cap;
+	/*/PRT_HIGH_THROUGHPUT		pHTInfo = GET_HT_INFO(pMgntInfo);*/
+	/*/PRT_VERY_HIGH_THROUGHPUT	pVHTInfo = GET_VHT_INFO(pMgntInfo);*/
+
+	u32	ulAntennaTx = pHalData->antenna_tx_path;
+	u32	ulAntennaRx = pHalData->AntennaRxPath;
+	u8	NssforRate = MgntQuery_NssTxRate(ForcedDataRate);
+
+	if (NssforRate == RF_3TX) {
+		RTW_INFO("===> SetAntenna 3T Rate ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
+
+		switch (ulAntennaTx) {
+		case ANTENNA_BCD:
+			pMptCtx->mpt_rf_path = RF_PATH_BCD;
+			/*pHalData->ValidTxPath = 0x0e;*/
+			phy_set_bb_reg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x90e);	/*/ 0x940[27:16]=12'b0010_0100_0111*/
+			break;
+
+		case ANTENNA_ABC:
+		default:
+			pMptCtx->mpt_rf_path = RF_PATH_ABC;
+			/*pHalData->ValidTxPath = 0x0d;*/
+			phy_set_bb_reg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x247);	/*/ 0x940[27:16]=12'b0010_0100_0111*/
+			break;
+		}
+
+	} else { /*/if(NssforRate == RF_1TX)*/
+		RTW_INFO("===> SetAntenna for 1T/2T Rate, ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
+		switch (ulAntennaTx) {
+		case ANTENNA_BCD:
+			pMptCtx->mpt_rf_path = RF_PATH_BCD;
+			/*pHalData->ValidTxPath = 0x0e;*/
+			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x7);
+			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0x000f00000, 0xe);
+			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0xe);
+			break;
+
+		case ANTENNA_BC:
+			pMptCtx->mpt_rf_path = RF_PATH_BC;
+			/*pHalData->ValidTxPath = 0x06;*/
+			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x6);
+			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0x000f00000, 0x6);
+			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x6);
+			break;
+		case ANTENNA_B:
+			pMptCtx->mpt_rf_path = RF_PATH_B;
+			/*pHalData->ValidTxPath = 0x02;*/
+			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x4);			/*/ 0xa07[7:4] = 4'b0100*/
+			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x002);	/*/ 0x93C[31:20]=12'b0000_0000_0010*/
+			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x2);					/* 0x80C[7:4] = 4'b0010*/
+			break;
+
+		case ANTENNA_C:
+			pMptCtx->mpt_rf_path = RF_PATH_C;
+			/*pHalData->ValidTxPath = 0x04;*/
+			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x2);			/*/ 0xa07[7:4] = 4'b0010*/
+			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x004);	/*/ 0x93C[31:20]=12'b0000_0000_0100*/
+			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x4);					/*/ 0x80C[7:4] = 4'b0100*/
+			break;
+
+		case ANTENNA_D:
+			pMptCtx->mpt_rf_path = RF_PATH_D;
+			/*pHalData->ValidTxPath = 0x08;*/
+			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x1);			/*/ 0xa07[7:4] = 4'b0001*/
+			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x008);	/*/ 0x93C[31:20]=12'b0000_0000_1000*/
+			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x8);					/*/ 0x80C[7:4] = 4'b1000*/
+			break;
+
+		case ANTENNA_A:
+		default:
+			pMptCtx->mpt_rf_path = RF_PATH_A;
+			/*pHalData->ValidTxPath = 0x01;*/
+			phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x8);			/*/ 0xa07[7:4] = 4'b1000*/
+			phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x001);	/*/ 0x93C[31:20]=12'b0000_0000_0001*/
+			phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x1);					/*/ 0x80C[7:4] = 4'b0001*/
+			break;
+		}
+	}
+
+	switch (ulAntennaRx) {
+	case ANTENNA_A:
+		/*pHalData->ValidRxPath = 0x01;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x0);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
+		break;
+
+	case ANTENNA_B:
+		/*pHalData->ValidRxPath = 0x02;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x1);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
+		break;
+
+	case ANTENNA_C:
+		/*pHalData->ValidRxPath = 0x04;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x44);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x2);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
+		break;
+
+	case ANTENNA_D:
+		/*pHalData->ValidRxPath = 0x08;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x88);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x3);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
+		break;
+
+	case ANTENNA_BC:
+		/*pHalData->ValidRxPath = 0x06;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x66);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
+		break;
+
+	case ANTENNA_CD:
+		/*pHalData->ValidRxPath = 0x0C;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xcc);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0xB);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
+		break;
+
+	case ANTENNA_BCD:
+		/*pHalData->ValidRxPath = 0x0e;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xee);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, Rx mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
+		break;
+
+	case ANTENNA_ABCD:
+		/*pHalData->ValidRxPath = 0x0f;*/
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xff);
+		phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x1);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
+		phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
+		/*/ CCA related PD_delay_th*/
+		phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
+		break;
+
+	default:
+		break;
+	}
+
+	PHY_Set_SecCCATH_by_RXANT_8814A(pAdapter, ulAntennaRx);
+
+	mpt_ToggleIG_8814A(pAdapter);
+}
+#endif /* CONFIG_RTL8814A */
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+VOID
+mpt_SetSingleTone_8814A(
+	IN	PADAPTER	pAdapter,
+	IN	BOOLEAN	bSingleTone,
+	IN	BOOLEAN	bEnPMacTx)
+{
+
+	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	u1Byte StartPath = RF_PATH_A,  EndPath = RF_PATH_A;
+	static u4Byte		regIG0 = 0, regIG1 = 0, regIG2 = 0, regIG3 = 0;
+
+	if (bSingleTone) {
+		regIG0 = phy_query_bb_reg(pAdapter, rA_TxScale_Jaguar, bMaskDWord);		/*/ 0xC1C[31:21]*/
+		regIG1 = phy_query_bb_reg(pAdapter, rB_TxScale_Jaguar, bMaskDWord);		/*/ 0xE1C[31:21]*/
+		regIG2 = phy_query_bb_reg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord);	/*/ 0x181C[31:21]*/
+		regIG3 = phy_query_bb_reg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord);	/*/ 0x1A1C[31:21]*/
+
+		switch (pMptCtx->mpt_rf_path) {
+		case RF_PATH_A:
+		case RF_PATH_B:
+		case RF_PATH_C:
+		case RF_PATH_D:
+			StartPath = pMptCtx->mpt_rf_path;
+			EndPath = pMptCtx->mpt_rf_path;
+			break;
+		case RF_PATH_AB:
+			EndPath = RF_PATH_B;
+			break;
+		case RF_PATH_BC:
+			StartPath = RF_PATH_B;
+			EndPath = RF_PATH_C;
+			break;
+		case RF_PATH_ABC:
+			EndPath = RF_PATH_C;
+			break;
+		case RF_PATH_BCD:
+			StartPath = RF_PATH_B;
+			EndPath = RF_PATH_D;
+			break;
+		case RF_PATH_ABCD:
+			EndPath = RF_PATH_D;
+			break;
+		}
+
+		if (bEnPMacTx == FALSE) {
+			hal_mpt_SetContinuousTx(pAdapter, _TRUE);
+			issue_nulldata(pAdapter, NULL, 1, 3, 500);
+		}
+
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1); /*/ Disable CCA*/
+
+		for (StartPath; StartPath <= EndPath; StartPath++) {
+			phy_set_rf_reg(pAdapter, StartPath, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
+			phy_set_rf_reg(pAdapter, StartPath, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
+
+			phy_set_rf_reg(pAdapter, StartPath, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
+		}
+
+		phy_set_bb_reg(pAdapter, rA_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xC1C[31:21]*/
+		phy_set_bb_reg(pAdapter, rB_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xE1C[31:21]*/
+		phy_set_bb_reg(pAdapter, rC_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x181C[31:21]*/
+		phy_set_bb_reg(pAdapter, rD_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x1A1C[31:21]*/
+	} else {
+		switch (pMptCtx->mpt_rf_path) {
+		case RF_PATH_A:
+		case RF_PATH_B:
+		case RF_PATH_C:
+		case RF_PATH_D:
+			StartPath = pMptCtx->mpt_rf_path;
+			EndPath = pMptCtx->mpt_rf_path;
+			break;
+		case RF_PATH_AB:
+			EndPath = RF_PATH_B;
+			break;
+		case RF_PATH_BC:
+			StartPath = RF_PATH_B;
+			EndPath = RF_PATH_C;
+			break;
+		case RF_PATH_ABC:
+			EndPath = RF_PATH_C;
+			break;
+		case RF_PATH_BCD:
+			StartPath = RF_PATH_B;
+			EndPath = RF_PATH_D;
+			break;
+		case RF_PATH_ABCD:
+			EndPath = RF_PATH_D;
+			break;
+		}
+		for (StartPath; StartPath <= EndPath; StartPath++)
+			phy_set_rf_reg(pAdapter, StartPath, lna_low_gain_3, BIT1, 0x0); /* RF LO disabled */
+
+		phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0); /* Enable CCA*/
+
+		if (bEnPMacTx == FALSE)
+			hal_mpt_SetContinuousTx(pAdapter, _FALSE);
+
+		phy_set_bb_reg(pAdapter, rA_TxScale_Jaguar, bMaskDWord, regIG0); /* 0xC1C[31:21]*/
+		phy_set_bb_reg(pAdapter, rB_TxScale_Jaguar, bMaskDWord, regIG1); /* 0xE1C[31:21]*/
+		phy_set_bb_reg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord, regIG2); /* 0x181C[31:21]*/
+		phy_set_bb_reg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord, regIG3); /* 0x1A1C[31:21]*/
+	}
+}
+
+#endif
+
+#if	defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+void mpt_SetRFPath_8812A(PADAPTER pAdapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.mpt_ctx;
+	struct mp_priv *pmp = &pAdapter->mppriv;
+	u8		channel = pmp->channel;
+	u8		bandwidth = pmp->bandwidth;
+	u8		eLNA_2g = pHalData->ExternalLNA_2G;
+	u32		ulAntennaTx, ulAntennaRx;
+
+	ulAntennaTx = pHalData->antenna_tx_path;
+	ulAntennaRx = pHalData->AntennaRxPath;
+
+	switch (ulAntennaTx) {
+	case ANTENNA_A:
+		pMptCtx->mpt_rf_path = RF_PATH_A;
+		phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x1111);
+		if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
+			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);
+		break;
+	case ANTENNA_B:
+		pMptCtx->mpt_rf_path = RF_PATH_B;
+		phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x2222);
+		if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
+			phy_set_bb_reg(pAdapter,	r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x1);
+		break;
+	case ANTENNA_AB:
+		pMptCtx->mpt_rf_path = RF_PATH_AB;
+		phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x3333);
+		if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
+			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);
+		break;
+	default:
+		pMptCtx->mpt_rf_path = RF_PATH_AB;
+		RTW_INFO("Unknown Tx antenna.\n");
+		break;
+	}
+
+	switch (ulAntennaRx) {
+		u32 reg0xC50 = 0;
+	case ANTENNA_A:
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, BIT19 | BIT18 | BIT17 | BIT16, 0x3);
+
+		/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
+		reg0xC50 = phy_query_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0);
+		phy_set_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50 + 2);
+		phy_set_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50);
+
+		/* set PWED_TH for BB Yn user guide R29 */
+		if (IS_HARDWARE_TYPE_8812(pAdapter)) {
+			if (channel <= 14) { /* 2.4G */
+				if (bandwidth == CHANNEL_WIDTH_20
+				    && eLNA_2g == 0) {
+					/* 0x830[3:1]=3'b010 */
+					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x02);
+				} else
+					/* 0x830[3:1]=3'b100 */
+					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
+			} else
+				/* 0x830[3:1]=3'b100 for 5G */
+				phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
+		}
+		break;
+	case ANTENNA_B:
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);
+		phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1);/*/ RF_A_0x0[19:16] = 1, Standby mode */
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x1);
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, BIT19 | BIT18 | BIT17 | BIT16, 0x3);
+
+		/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
+		reg0xC50 = phy_query_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0);
+		phy_set_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50 + 2);
+		phy_set_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50);
+
+		/* set PWED_TH for BB Yn user guide R29 */
+		if (IS_HARDWARE_TYPE_8812(pAdapter)) {
+			if (channel <= 14) {
+				if (bandwidth == CHANNEL_WIDTH_20
+				    && eLNA_2g == 0) {
+					/* 0x830[3:1]=3'b010 */
+					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x02);
+				} else
+					/* 0x830[3:1]=3'b100 */
+					phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
+			} else
+				/* 0x830[3:1]=3'b100 for 5G */
+				phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
+		}
+		break;
+	case ANTENNA_AB:
+		phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x33);
+		phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, Rx mode*/
+		phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
+		/* set PWED_TH for BB Yn user guide R29 */
+		phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
+		break;
+	default:
+		RTW_INFO("Unknown Rx antenna.\n");
+		break;
+	}
+
+	if (pHalData->rfe_type == 5 || pHalData->rfe_type == 1) {
+		if (ulAntennaTx == ANTENNA_A || ulAntennaTx == ANTENNA_AB) {
+			/* WiFi */
+			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(1) | BIT(0), 0x2);
+			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(9) | BIT(8), 0x3);
+		} else {
+			/* BT */
+			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(1) | BIT(0), 0x1);
+			phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(9) | BIT(8), 0x3);
+		}
+	}
+}
+#endif
+
+#ifdef CONFIG_RTL8723B
+void mpt_SetRFPath_8723B(PADAPTER pAdapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	u32		ulAntennaTx, ulAntennaRx;
+	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	struct dm_struct	*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+
+	ulAntennaTx = pHalData->antenna_tx_path;
+	ulAntennaRx = pHalData->AntennaRxPath;
+
+	if (pHalData->rf_chip >= RF_CHIP_MAX) {
+		RTW_INFO("This RF chip ID is not supported\n");
+		return;
+	}
+
+	switch (pAdapter->mppriv.antenna_tx) {
+		u8 p = 0, i = 0;
+	case ANTENNA_A: { /*/ Actually path S1  (Wi-Fi)*/
+		pMptCtx->mpt_rf_path = RF_PATH_A;
+		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x0);
+		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
+
+		for (i = 0; i < 3; ++i) {
+			u4Byte offset = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][0];
+			u4Byte data = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][1];
+
+			if (offset != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+		}
+		for (i = 0; i < 2; ++i) {
+			u4Byte offset = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][0];
+			u4Byte data = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][1];
+
+			if (offset != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+		}
+	}
+	break;
+	case ANTENNA_B: { /*/ Actually path S0 (BT)*/
+		u4Byte offset;
+		u4Byte data;
+
+		pMptCtx->mpt_rf_path = RF_PATH_B;
+		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x5);
+		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x1); /*/ AGC Table Sel.*/
+
+		for (i = 0; i < 3; ++i) {
+			/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC  to S1 instead of S0.*/
+			offset = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][0];
+			data = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_B][i][1];
+			if (pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_B][i][0] != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+		}
+		/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC to S1 instead of S0.*/
+		for (i = 0; i < 2; ++i) {
+			offset = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][0];
+			data = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_B][i][1];
+			if (pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_B][i][0] != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+		}
+	}
+	break;
+	default:
+		pMptCtx->mpt_rf_path = RF_PATH_AB;
+		break;
+	}
+}
+#endif
+
+#ifdef CONFIG_RTL8703B
+void mpt_SetRFPath_8703B(PADAPTER pAdapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	u4Byte					ulAntennaTx, ulAntennaRx;
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct			*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+
+	ulAntennaTx = pHalData->antenna_tx_path;
+	ulAntennaRx = pHalData->AntennaRxPath;
+
+	if (pHalData->rf_chip >= RF_CHIP_MAX) {
+		RTW_INFO("This RF chip ID is not supported\n");
+		return;
+	}
+
+	switch (pAdapter->mppriv.antenna_tx) {
+		u1Byte p = 0, i = 0;
+
+	case ANTENNA_A: { /* Actually path S1  (Wi-Fi) */
+		pMptCtx->mpt_rf_path = RF_PATH_A;
+		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x0);
+		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
+
+		for (i = 0; i < 3; ++i) {
+			u4Byte offset = pRFCalibrateInfo->tx_iqc_8703b[i][0];
+			u4Byte data = pRFCalibrateInfo->tx_iqc_8703b[i][1];
+
+			if (offset != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+
+		}
+		for (i = 0; i < 2; ++i) {
+			u4Byte offset = pRFCalibrateInfo->rx_iqc_8703b[i][0];
+			u4Byte data = pRFCalibrateInfo->rx_iqc_8703b[i][1];
+
+			if (offset != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+		}
+	}
+	break;
+	case ANTENNA_B: { /* Actually path S0 (BT)*/
+		pMptCtx->mpt_rf_path = RF_PATH_B;
+		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x5);
+		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x1); /* AGC Table Sel */
+
+		for (i = 0; i < 3; ++i) {
+			u4Byte offset = pRFCalibrateInfo->tx_iqc_8703b[i][0];
+			u4Byte data = pRFCalibrateInfo->tx_iqc_8703b[i][1];
+
+			if (pRFCalibrateInfo->tx_iqc_8703b[i][0] != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+		}
+		for (i = 0; i < 2; ++i) {
+			u4Byte offset = pRFCalibrateInfo->rx_iqc_8703b[i][0];
+			u4Byte data = pRFCalibrateInfo->rx_iqc_8703b[i][1];
+
+			if (pRFCalibrateInfo->rx_iqc_8703b[i][0] != 0) {
+				phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
+				RTW_INFO("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
+			}
+		}
+	}
+	break;
+	default:
+		pMptCtx->mpt_rf_path = RF_PATH_AB;
+		break;
+	}
+
+}
+#endif
+
+#ifdef CONFIG_RTL8723D
+void mpt_SetRFPath_8723D(PADAPTER pAdapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	u1Byte	p = 0, i = 0;
+	u4Byte	ulAntennaTx, ulAntennaRx, offset = 0, data = 0, val32 = 0;
+	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	struct dm_struct	*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+
+	ulAntennaTx = pHalData->antenna_tx_path;
+	ulAntennaRx = pHalData->AntennaRxPath;
+
+	if (pHalData->rf_chip >= RF_CHIP_MAX) {
+		RTW_INFO("This RF chip ID is not supported\n");
+		return;
+	}
+
+	switch (pAdapter->mppriv.antenna_tx) {
+	/* Actually path S1  (Wi-Fi) */
+	case ANTENNA_A: {
+		pMptCtx->mpt_rf_path = RF_PATH_A;
+		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7|BIT6, 0);
+	}
+	break;
+	/* Actually path S0 (BT) */
+	case ANTENNA_B: {
+		pMptCtx->mpt_rf_path = RF_PATH_B;
+		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7|BIT6, 0xA);
+
+	}
+	break;
+	default:
+		pMptCtx->mpt_rf_path = RF_PATH_AB;
+		break;
+	}
+}
+#endif
+
+VOID mpt_SetRFPath_819X(PADAPTER	pAdapter)
+{
+	HAL_DATA_TYPE			*pHalData	= GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	u4Byte			ulAntennaTx, ulAntennaRx;
+	R_ANTENNA_SELECT_OFDM	*p_ofdm_tx;	/* OFDM Tx register */
+	R_ANTENNA_SELECT_CCK	*p_cck_txrx;
+	u1Byte		r_rx_antenna_ofdm = 0, r_ant_select_cck_val = 0;
+	u1Byte		chgTx = 0, chgRx = 0;
+	u4Byte		r_ant_sel_cck_val = 0, r_ant_select_ofdm_val = 0, r_ofdm_tx_en_val = 0;
+
+	ulAntennaTx = pHalData->antenna_tx_path;
+	ulAntennaRx = pHalData->AntennaRxPath;
+
+	p_ofdm_tx = (R_ANTENNA_SELECT_OFDM *)&r_ant_select_ofdm_val;
+	p_cck_txrx = (R_ANTENNA_SELECT_CCK *)&r_ant_select_cck_val;
+
+	p_ofdm_tx->r_ant_ht1			= 0x1;
+	p_ofdm_tx->r_ant_ht2			= 0x2;/*Second TX RF path is A*/
+	p_ofdm_tx->r_ant_non_ht			= 0x3;/*/ 0x1+0x2=0x3 */
+
+	switch (ulAntennaTx) {
+	case ANTENNA_A:
+		p_ofdm_tx->r_tx_antenna		= 0x1;
+		r_ofdm_tx_en_val		= 0x1;
+		p_ofdm_tx->r_ant_l		= 0x1;
+		p_ofdm_tx->r_ant_ht_s1		= 0x1;
+		p_ofdm_tx->r_ant_non_ht_s1	= 0x1;
+		p_cck_txrx->r_ccktx_enable	= 0x8;
+		chgTx = 1;
+		/*/ From SD3 Willis suggestion !!! Set RF A=TX and B as standby*/
+		/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
+		{
+			phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
+			phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 1);
+			r_ofdm_tx_en_val			= 0x3;
+			/*/ Power save*/
+			/*/cosa r_ant_select_ofdm_val = 0x11111111;*/
+			/*/ We need to close RFB by SW control*/
+			if (pHalData->rf_type == RF_2T2R) {
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 1);
+				phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 0);
+			}
+		}
+		pMptCtx->mpt_rf_path = RF_PATH_A;
+		break;
+	case ANTENNA_B:
+		p_ofdm_tx->r_tx_antenna		= 0x2;
+		r_ofdm_tx_en_val		= 0x2;
+		p_ofdm_tx->r_ant_l		= 0x2;
+		p_ofdm_tx->r_ant_ht_s1		= 0x2;
+		p_ofdm_tx->r_ant_non_ht_s1	= 0x2;
+		p_cck_txrx->r_ccktx_enable	= 0x4;
+		chgTx = 1;
+		/*/ From SD3 Willis suggestion !!! Set RF A as standby*/
+		/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
+		{
+			phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 1);
+			phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
+
+			/*/ 2008/10/31 MH From SD3 Willi's suggestion. We must read RF 1T table.*/
+			/*/ 2009/01/08 MH From Sd3 Willis. We need to close RFA by SW control*/
+			if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_1T2R) {
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 1);
+				phy_set_bb_reg(pAdapter, rFPGA0_XA_RFInterfaceOE, BIT10, 0);
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
+				/*/phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 0);
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
+			}
+		}
+		pMptCtx->mpt_rf_path = RF_PATH_B;
+		break;
+	case ANTENNA_AB:/*/ For 8192S*/
+		p_ofdm_tx->r_tx_antenna		= 0x3;
+		r_ofdm_tx_en_val		= 0x3;
+		p_ofdm_tx->r_ant_l		= 0x3;
+		p_ofdm_tx->r_ant_ht_s1		= 0x3;
+		p_ofdm_tx->r_ant_non_ht_s1	= 0x3;
+		p_cck_txrx->r_ccktx_enable	= 0xC;
+		chgTx = 1;
+		/*/ From SD3Willis suggestion !!! Set RF B as standby*/
+		/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
+		{
+			phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
+			phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
+			/* Disable Power save*/
+			/*cosa r_ant_select_ofdm_val = 0x3321333;*/
+			/* 2009/01/08 MH From Sd3 Willis. We need to enable RFA/B by SW control*/
+			if (pHalData->rf_type == RF_2T2R) {
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
+
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
+				/*/phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
+				phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
+			}
+		}
+		pMptCtx->mpt_rf_path = RF_PATH_AB;
+		break;
+	default:
+		break;
+	}
+#if 0
+	/*  r_rx_antenna_ofdm, bit0=A, bit1=B, bit2=C, bit3=D */
+	/*  r_cckrx_enable : CCK default, 0=A, 1=B, 2=C, 3=D */
+	/* r_cckrx_enable_2 : CCK option, 0=A, 1=B, 2=C, 3=D	 */
+#endif
+	switch (ulAntennaRx) {
+	case ANTENNA_A:
+		r_rx_antenna_ofdm		= 0x1;	/* A*/
+		p_cck_txrx->r_cckrx_enable	= 0x0;	/* default: A*/
+		p_cck_txrx->r_cckrx_enable_2	= 0x0;	/* option: A*/
+		chgRx = 1;
+		break;
+	case ANTENNA_B:
+		r_rx_antenna_ofdm			= 0x2;	/*/ B*/
+		p_cck_txrx->r_cckrx_enable	= 0x1;	/*/ default: B*/
+		p_cck_txrx->r_cckrx_enable_2	= 0x1;	/*/ option: B*/
+		chgRx = 1;
+		break;
+	case ANTENNA_AB:/*/ For 8192S and 8192E/U...*/
+		r_rx_antenna_ofdm		= 0x3;/*/ AB*/
+		p_cck_txrx->r_cckrx_enable	= 0x0;/*/ default:A*/
+		p_cck_txrx->r_cckrx_enable_2	= 0x1;/*/ option:B*/
+		chgRx = 1;
+		break;
+	default:
+		break;
+	}
+
+
+	if (chgTx && chgRx) {
+		switch (pHalData->rf_chip) {
+		case RF_8225:
+		case RF_8256:
+		case RF_6052:
+			/*/r_ant_sel_cck_val = r_ant_select_cck_val;*/
+			phy_set_bb_reg(pAdapter, rFPGA1_TxInfo, 0x7fffffff, r_ant_select_ofdm_val);		/*/OFDM Tx*/
+			phy_set_bb_reg(pAdapter, rFPGA0_TxInfo, 0x0000000f, r_ofdm_tx_en_val);		/*/OFDM Tx*/
+			phy_set_bb_reg(pAdapter, rOFDM0_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm);	/*/OFDM Rx*/
+			phy_set_bb_reg(pAdapter, rOFDM1_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm);	/*/OFDM Rx*/
+			if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
+				phy_set_bb_reg(pAdapter, rOFDM0_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm);	/*/OFDM Rx*/
+				phy_set_bb_reg(pAdapter, rOFDM1_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm);	/*/OFDM Rx*/
+			}
+			phy_set_bb_reg(pAdapter, rCCK0_AFESetting, bMaskByte3, r_ant_select_cck_val);/*/r_ant_sel_cck_val); /CCK TxRx*/
+			break;
+
+		default:
+			RTW_INFO("Unsupported RFChipID for switching antenna.\n");
+			break;
+		}
+	}
+}	/* MPT_ProSetRFPath */
+
+
+void hal_mpt_SetAntenna(PADAPTER	pAdapter)
+
+{
+	RTW_INFO("Do %s\n", __func__);
+#ifdef CONFIG_RTL8814A
+	if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
+		mpt_SetRFPath_8814A(pAdapter);
+		return;
+	}
+#endif
+#ifdef CONFIG_RTL8822B
+	if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
+		rtl8822b_mp_config_rfpath(pAdapter);
+		return;
+	}
+#endif
+#ifdef CONFIG_RTL8821C
+	if (IS_HARDWARE_TYPE_8821C(pAdapter)) {
+		rtl8821c_mp_config_rfpath(pAdapter);
+		return;
+	}
+#endif
+#if	defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
+	if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
+		mpt_SetRFPath_8812A(pAdapter);
+		return;
+	}
+#endif
+#ifdef CONFIG_RTL8723B
+	if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
+		mpt_SetRFPath_8723B(pAdapter);
+		return;
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
+		mpt_SetRFPath_8703B(pAdapter);
+		return;
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
+		mpt_SetRFPath_8723D(pAdapter);
+		return;
+	}
+#endif
+	/*	else if (IS_HARDWARE_TYPE_8821B(pAdapter))
+			mpt_SetRFPath_8821B(pAdapter);
+		Prepare for 8822B
+		else if (IS_HARDWARE_TYPE_8822B(Context))
+			mpt_SetRFPath_8822B(Context);
+	*/
+	mpt_SetRFPath_819X(pAdapter);
+	RTW_INFO("mpt_SetRFPath_819X Do %s\n", __func__);
+}
+
+s32 hal_mpt_SetThermalMeter(PADAPTER pAdapter, u8 target_ther)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
+
+	if (!netif_running(pAdapter->pnetdev)) {
+		return _FAIL;
+	}
+
+
+	if (check_fwstate(&pAdapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
+		return _FAIL;
+	}
+
+
+	target_ther &= 0xff;
+	if (target_ther < 0x07)
+		target_ther = 0x07;
+	else if (target_ther > 0x1d)
+		target_ther = 0x1d;
+
+	pHalData->eeprom_thermal_meter = target_ther;
+
+	return _SUCCESS;
+}
+
+
+void hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter)
+{
+	phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT17 | BIT16, 0x03);
+
+}
+
+
+u8 hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter)
+
+{
+	struct dm_struct *p_dm_odm = adapter_to_phydm(pAdapter);
+	u32 ThermalValue = 0;
+	s32 thermal_value_temp = 0;
+	s8 thermal_offset = 0;
+
+	ThermalValue = (u1Byte)phy_query_rf_reg(pAdapter, RF_PATH_A, 0x42, 0xfc00);	/*0x42: RF Reg[15:10]*/
+	thermal_offset = phydm_get_thermal_offset(p_dm_odm);
+
+	thermal_value_temp = ThermalValue + thermal_offset;
+
+	if (thermal_value_temp > 63)
+		ThermalValue = 63;
+	else if (thermal_value_temp < 0)
+		ThermalValue = 0;
+	else
+		ThermalValue = thermal_value_temp;
+
+	return (u8)ThermalValue;
+}
+
+
+void hal_mpt_GetThermalMeter(PADAPTER pAdapter, u8 *value)
+{
+#if 0
+	fw_cmd(pAdapter, IOCMD_GET_THERMAL_METER);
+	rtw_msleep_os(1000);
+	fw_cmd_data(pAdapter, value, 1);
+	*value &= 0xFF;
+#else
+	hal_mpt_TriggerRFThermalMeter(pAdapter);
+	rtw_msleep_os(1000);
+	*value = hal_mpt_ReadRFThermalMeter(pAdapter);
+#endif
+
+}
+
+
+void hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart)
+{
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
+
+	pAdapter->mppriv.mpt_ctx.bSingleCarrier = bStart;
+
+	if (bStart) {/*/ Start Single Carrier.*/
+		/*/ Start Single Carrier.*/
+		/*/ 1. if OFDM block on?*/
+		if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
+			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1); /*set OFDM block on*/
+
+		/*/ 2. set CCK test mode off, set to CCK normal mode*/
+		phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0);
+
+		/*/ 3. turn on scramble setting*/
+		phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 1);
+
+		/*/ 4. Turn On Continue Tx and turn off the other test modes.*/
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+		if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter))
+			phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_SingleCarrier);
+		else
+#endif /* CONFIG_RTL8812A || CONFIG_RTL8821A || CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
+			phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_SingleCarrier);
+
+	} else {
+		/*/ Stop Single Carrier.*/
+		/*/ Stop Single Carrier.*/
+		/*/ Turn off all test modes.*/
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+		if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter))
+			phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
+		else
+#endif /* CONFIG_RTL8812A || CONFIG_RTL8821A || CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
+			phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
+
+		rtw_msleep_os(10);
+		/*/BB Reset*/
+		phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
+		phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
+	}
+}
+
+
+void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+	u4Byte			ulAntennaTx = pHalData->antenna_tx_path;
+	static u4Byte		regRF = 0, regBB0 = 0, regBB1 = 0, regBB2 = 0, regBB3 = 0;
+	u8 rfPath;
+
+	switch (ulAntennaTx) {
+	case ANTENNA_B:
+		rfPath = RF_PATH_B;
+		break;
+	case ANTENNA_C:
+		rfPath = RF_PATH_C;
+		break;
+	case ANTENNA_D:
+		rfPath = RF_PATH_D;
+		break;
+	case ANTENNA_A:
+	default:
+		rfPath = RF_PATH_A;
+		break;
+	}
+
+	pAdapter->mppriv.mpt_ctx.is_single_tone = bStart;
+	if (bStart) {
+		/*/ Start Single Tone.*/
+		/*/ <20120326, Kordan> To amplify the power of tone for Xtal calibration. (asked by Edlu)*/
+		if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
+			regRF = phy_query_rf_reg(pAdapter, rfPath, lna_low_gain_3, bRFRegOffsetMask);
+			phy_set_rf_reg(pAdapter, RF_PATH_A, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
+			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x0);
+			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x0);
+		} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) { /*/ USB need to do RF LO disable first, PCIE isn't required to follow this order.*/
+			/*/Set MAC REG 88C: Prevent SingleTone Fail*/
+			phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0xF);
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO disabled*/
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
+		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x56, 0xF, 0x1); /*/ RF LO enabled*/
+			} else {
+				/*/ S0/S1 both use PATH A to configure*/
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x76, 0xF, 0x1); /*/ RF LO enabled*/
+			}
+		} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /* Tx mode */
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x1); /* RF LO enabled */
+			}
+		} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
+			/*Set BB REG 88C: Prevent SingleTone Fail*/
+			phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xF);
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1);
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2);
+
+		} else if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
+				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x0);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, BIT0, 0x1);
+			} else {/* S0/S1 both use PATH A to configure */
+				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x0);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x1);
+			}
+		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+			u1Byte p = RF_PATH_A;
+
+			regRF = phy_query_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, bRFRegOffsetMask);
+			regBB0 = phy_query_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord);
+			regBB1 = phy_query_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord);
+			regBB2 = phy_query_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskDWord);
+			regBB3 = phy_query_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskDWord);
+
+			phy_set_bb_reg(pAdapter, rOFDMCCKEN_Jaguar, BIT29 | BIT28, 0x0); /*/ Disable CCK and OFDM*/
+
+			if (pMptCtx->mpt_rf_path == RF_PATH_AB) {
+				for (p = RF_PATH_A; p <= RF_PATH_B; ++p) {
+					phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
+					phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
+					phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
+				}
+			} else {
+				phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
+				phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
+#ifdef CONFIG_RTL8821C
+				if (IS_HARDWARE_TYPE_8821C(pAdapter) && pDM_Odm->current_rf_set_8821c == SWITCH_TO_BTG)
+					phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x75, BIT16, 0x1); /* RF LO (for BTG) enabled */
+				else
+#endif
+					phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
+			}
+			if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777);  /* 0xCB0=0x77777777*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777);  /* 0xEB0=0x77777777*/
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777);  /* 0xCB4[15:0] = 0x7777*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777);  /* 0xEB4[15:0] = 0x7777*/
+					phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xFFF, 0xb); /* 0xCBC[23:16] = 0x12*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xFFF, 0x830); /* 0xEBC[23:16] = 0x12*/
+			} else if (IS_HARDWARE_TYPE_8821C(pAdapter)) {
+				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xF0F0, 0x707);  /* 0xCB0[[15:12, 7:4] = 0x707*/
+
+				if (pHalData->external_pa_5g) 
+				{
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
+				}
+				else if (pHalData->ExternalPA_2G) 
+				{
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
+				}
+			} else {
+				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
+				phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
+
+				if (pHalData->external_pa_5g) {
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xCB4[23:16] = 0x12*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xEB4[23:16] = 0x12*/
+				} else if (pHalData->ExternalPA_2G) {
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xCB4[23:16] = 0x11*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xEB4[23:16] = 0x11*/
+				}
+			}
+#endif
+		}
+#if defined(CONFIG_RTL8814A)
+				else if (IS_HARDWARE_TYPE_8814A(pAdapter))
+						mpt_SetSingleTone_8814A(pAdapter, TRUE, FALSE);
+#endif
+		else	/*/ Turn On SingleTone and turn off the other test modes.*/
+			phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_SingleTone);
+
+		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
+		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
+
+	} else {/*/ Stop Single Ton e.*/
+
+		if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
+			phy_set_rf_reg(pAdapter, RF_PATH_A, lna_low_gain_3, bRFRegOffsetMask, regRF);
+			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x1);
+			phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
+		} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3);/*/ Tx mode*/
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0);/*/ RF LO disabled */
+			/*/ RESTORE MAC REG 88C: Enable RF Functions*/
+			phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0x0);
+		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x56, 0xF, 0x0); /*/ RF LO disabled*/
+			} else {
+				/*/ S0/S1 both use PATH A to configure*/
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x76, 0xF, 0x0); /*/ RF LO disabled*/
+			}
+		} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /* Rx mode */
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x0); /* RF LO disabled */
+			}
+		} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3); /*Tx mode*/
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0); /*RF LO disabled*/
+			/*Set BB REG 88C: Prevent SingleTone Fail*/
+			phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xc);
+		} else if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
+			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
+				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0x3);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x1);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, BIT0, 0x0);
+			} else {	/* S0/S1 both use PATH A to configure */
+				phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0x3);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x1);
+				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x0);
+			}
+		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+			u1Byte p = RF_PATH_A;
+
+			phy_set_bb_reg(pAdapter, rOFDMCCKEN_Jaguar, BIT29 | BIT28, 0x3); /*/ Disable CCK and OFDM*/
+
+			if (pMptCtx->mpt_rf_path == RF_PATH_AB) {
+				for (p = RF_PATH_A; p <= RF_PATH_B; ++p) {
+					phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
+					phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
+				}
+			} else {
+				p = pMptCtx->mpt_rf_path;
+				phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
+
+				if (IS_HARDWARE_TYPE_8821C(pAdapter))
+					phy_set_rf_reg(pAdapter, p, 0x75, BIT16, 0x0); /* RF LO (for BTG) disabled */
+
+				phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
+			}
+
+			phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, regBB0);
+			phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, regBB1);
+			phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB2);
+			phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB3);
+
+			if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
+				RTW_INFO("Restore RFE control Pin cbc\n");
+				phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xfff, 0x0);
+				phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xfff, 0x0);
+			}
+#endif
+		}
+#if defined(CONFIG_RTL8814A)
+		else if (IS_HARDWARE_TYPE_8814A(pAdapter))
+			mpt_SetSingleTone_8814A(pAdapter, FALSE, FALSE);
+
+		else/*/ Turn off all test modes.*/
+			phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
+#endif
+		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
+		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
+
+	}
+}
+
+void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)
+{
+	u8 Rate;
+
+	pAdapter->mppriv.mpt_ctx.is_carrier_suppression = bStart;
+
+	Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
+	if (bStart) {/* Start Carrier Suppression.*/
+		if (Rate <= MPT_RATE_11M) {
+			/*/ 1. if CCK block on?*/
+			if (!read_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn))
+				write_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn, bEnable);/*set CCK block on*/
+
+			/*/Turn Off All Test Mode*/
+			if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8814A(pAdapter) /*|| IS_HARDWARE_TYPE_8822B(pAdapter)*/)
+				phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF); /* rSingleTone_ContTx_Jaguar*/
+			else
+				phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
+
+			write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x2);    /*/transmit mode*/
+			write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x0);  /*/turn off scramble setting*/
+
+			/*/Set CCK Tx Test Rate*/
+			write_bbreg(pAdapter, rCCK0_System, bCCKTxRate, 0x0);    /*/Set FTxRate to 1Mbps*/
+		}
+
+		/*Set for dynamic set Power index*/
+		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
+		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
+
+	} else {/* Stop Carrier Suppression.*/
+
+		if (Rate <= MPT_RATE_11M) {
+			write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x0);    /*normal mode*/
+			write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x1);  /*turn on scramble setting*/
+
+			/*BB Reset*/
+			write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
+			write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
+		}
+		/*Stop for dynamic set Power index*/
+		write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
+		write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
+	}
+	RTW_INFO("\n MPT_ProSetCarrierSupp() is finished.\n");
+}
+
+u32 hal_mpt_query_phytxok(PADAPTER	pAdapter)
+{
+	PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	RT_PMAC_TX_INFO PMacTxInfo = pMptCtx->PMacTxInfo;
+	u16 count = 0;
+
+	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
+		count = phy_query_bb_reg(pAdapter, 0xF50, bMaskLWord); /* [15:0]*/
+	else
+		count = phy_query_bb_reg(pAdapter, 0xF50, bMaskHWord); /* [31:16]*/
+
+	if (count > 50000) {
+		rtw_reset_phy_trx_ok_counters(pAdapter);
+		pAdapter->mppriv.tx.sended += count;
+		count = 0;
+	}
+
+	return pAdapter->mppriv.tx.sended + count;
+
+}
+
+static	VOID mpt_StopCckContTx(
+	PADAPTER	pAdapter
+)
+{
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	u1Byte			u1bReg;
+
+	pMptCtx->bCckContTx = FALSE;
+	pMptCtx->bOfdmContTx = FALSE;
+
+	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0x0);	/*normal mode*/
+	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 0x1);	/*turn on scramble setting*/
+
+	if (!IS_HARDWARE_TYPE_JAGUAR2(pAdapter)) {
+		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x0);			/* 0xa15[1:0] = 2b00*/
+		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);		/* 0xc08[16] = 0*/
+
+		phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 0);
+		phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, BIT14, 0);
+		phy_set_bb_reg(pAdapter, 0x0B34, BIT14, 0);
+	}
+
+	/*BB Reset*/
+	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
+	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
+
+	phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
+	phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
+
+}	/* mpt_StopCckContTx */
+
+
+static	VOID mpt_StopOfdmContTx(
+	PADAPTER	pAdapter
+)
+{
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	u1Byte			u1bReg;
+	u4Byte			data;
+
+	pMptCtx->bCckContTx = FALSE;
+	pMptCtx->bOfdmContTx = FALSE;
+
+	if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_JAGUAR2(pAdapter))
+		phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
+	else
+		phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
+
+	rtw_mdelay_os(10);
+
+	if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter) && !IS_HARDWARE_TYPE_JAGUAR2(pAdapter)) {
+		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x0);			/* 0xa15[1:0] = 0*/
+		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0);		/* 0xc08[16] = 0*/
+	}
+
+	/*BB Reset*/
+	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
+	phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
+
+	phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
+	phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
+}	/* mpt_StopOfdmContTx */
+
+
+static	VOID mpt_StartCckContTx(
+	PADAPTER		pAdapter
+)
+{
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	u4Byte			cckrate;
+
+	/* 1. if CCK block on */
+	if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn))
+		phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 1);/*set CCK block on*/
+
+	/*Turn Off All Test Mode*/
+	if (IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter))
+		phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
+	else
+		phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
+
+	cckrate  = pAdapter->mppriv.rateidx;
+
+	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKTxRate, cckrate);
+
+	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0x2);	/*transmit mode*/
+	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 0x1);	/*turn on scramble setting*/
+
+	if (!IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(pAdapter)) {
+		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x3);			/* 0xa15[1:0] = 11 force cck rxiq = 0*/
+		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/* 0xc08[16] = 1 force ofdm rxiq = ofdm txiq*/
+		phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 1);
+		phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, BIT14, 1);
+		phy_set_bb_reg(pAdapter, 0x0B34, BIT14, 1);
+	}
+
+	phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
+	phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
+
+	pMptCtx->bCckContTx = TRUE;
+	pMptCtx->bOfdmContTx = FALSE;
+
+}	/* mpt_StartCckContTx */
+
+
+static	VOID mpt_StartOfdmContTx(
+	PADAPTER		pAdapter
+)
+{
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+
+	/* 1. if OFDM block on?*/
+	if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
+		phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1);/*set OFDM block on*/
+
+	/* 2. set CCK test mode off, set to CCK normal mode*/
+	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0);
+
+	/* 3. turn on scramble setting*/
+	phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 1);
+
+	if (!IS_HARDWARE_TYPE_JAGUAR(pAdapter) && !IS_HARDWARE_TYPE_JAGUAR2(pAdapter)) {
+		phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x3);			/* 0xa15[1:0] = 2b'11*/
+		phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1);		/* 0xc08[16] = 1*/
+	}
+
+	/* 4. Turn On Continue Tx and turn off the other test modes.*/
+	if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_JAGUAR2(pAdapter))
+		phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ContinuousTx);
+	else
+		phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ContinuousTx);
+
+	phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
+	phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
+
+	pMptCtx->bCckContTx = FALSE;
+	pMptCtx->bOfdmContTx = TRUE;
+}	/* mpt_StartOfdmContTx */
+
+
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8821B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+/* for HW TX mode */
+void mpt_ProSetPMacTx(PADAPTER	Adapter)
+{
+	PMPT_CONTEXT	pMptCtx		=	&(Adapter->mppriv.mpt_ctx);
+	struct mp_priv *pmppriv = &Adapter->mppriv;
+	RT_PMAC_TX_INFO	PMacTxInfo	=	pMptCtx->PMacTxInfo;
+	u32			u4bTmp;
+
+#if 0
+	PRINT_DATA("LSIG ", PMacTxInfo.LSIG, 3);
+	PRINT_DATA("HT_SIG", PMacTxInfo.HT_SIG, 6);
+	PRINT_DATA("VHT_SIG_A", PMacTxInfo.VHT_SIG_A, 6);
+	PRINT_DATA("VHT_SIG_B", PMacTxInfo.VHT_SIG_B, 4);
+	dbg_print("VHT_SIG_B_CRC %x\n", PMacTxInfo.VHT_SIG_B_CRC);
+	PRINT_DATA("VHT_Delimiter", PMacTxInfo.VHT_Delimiter, 4);
+
+	PRINT_DATA("Src Address", Adapter->mac_addr, 6);
+	PRINT_DATA("Dest Address", PMacTxInfo.MacAddress, 6);
+#endif
+	if (Adapter->mppriv.pktInterval != 0)
+		PMacTxInfo.PacketPeriod = Adapter->mppriv.pktInterval;
+
+	RTW_INFO("SGI %d bSPreamble %d bSTBC %d bLDPC %d NDP_sound %d\n", PMacTxInfo.bSGI, PMacTxInfo.bSPreamble, PMacTxInfo.bSTBC, PMacTxInfo.bLDPC, PMacTxInfo.NDP_sound);
+	RTW_INFO("TXSC %d BandWidth %d PacketPeriod %d PacketCount %d PacketLength %d PacketPattern %d\n", PMacTxInfo.TX_SC, PMacTxInfo.BandWidth, PMacTxInfo.PacketPeriod, PMacTxInfo.PacketCount,
+		 PMacTxInfo.PacketLength, PMacTxInfo.PacketPattern);
+
+	if (PMacTxInfo.bEnPMacTx == FALSE) {
+			pmppriv->mode = MP_ON;
+		if (PMacTxInfo.Mode == CONTINUOUS_TX) {
+			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);			/*	TX Stop*/
+			if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
+				mpt_StopCckContTx(Adapter);
+			else
+				mpt_StopOfdmContTx(Adapter);
+		} else if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
+			u4bTmp = phy_query_bb_reg(Adapter, 0xf50, bMaskLWord);
+			phy_set_bb_reg(Adapter, 0xb1c, bMaskLWord, u4bTmp + 50);
+			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);		/*TX Stop*/
+		} else
+			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);		/*	TX Stop*/
+
+		if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
+			/* Stop HW TX -> Stop Continuous TX -> Stop RF Setting*/
+			if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
+				mpt_StopCckContTx(Adapter);
+			else
+				mpt_StopOfdmContTx(Adapter);
+
+			mpt_SetSingleTone_8814A(Adapter, FALSE, TRUE);
+		}
+
+		return;
+	}
+
+	if (PMacTxInfo.Mode == CONTINUOUS_TX) {
+		pmppriv->mode = MP_CONTINUOUS_TX;
+		PMacTxInfo.PacketCount = 1;
+
+		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
+			mpt_StartCckContTx(Adapter);
+		else
+			mpt_StartOfdmContTx(Adapter);
+	} else if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
+		pmppriv->mode = MP_SINGLE_TONE_TX;
+		/* Continuous TX -> HW TX -> RF Setting */
+		PMacTxInfo.PacketCount = 1;
+
+		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
+			mpt_StartCckContTx(Adapter);
+		else
+			mpt_StartOfdmContTx(Adapter);
+	} else if (PMacTxInfo.Mode == PACKETS_TX) {
+		pmppriv->mode = MP_PACKET_TX;
+		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE) && PMacTxInfo.PacketCount == 0)
+			PMacTxInfo.PacketCount = 0xffff;
+	}
+
+	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
+		/* 0xb1c[0:15] TX packet count 0xb1C[31:16]	SFD*/
+		u4bTmp = PMacTxInfo.PacketCount | (PMacTxInfo.SFD << 16);
+		phy_set_bb_reg(Adapter, 0xb1c, bMaskDWord, u4bTmp);
+		/* 0xb40 7:0 SIGNAL	15:8 SERVICE	31:16 LENGTH*/
+		u4bTmp = PMacTxInfo.SignalField | (PMacTxInfo.ServiceField << 8) | (PMacTxInfo.LENGTH << 16);
+		phy_set_bb_reg(Adapter, 0xb40, bMaskDWord, u4bTmp);
+		u4bTmp = PMacTxInfo.CRC16[0] | (PMacTxInfo.CRC16[1] << 8);
+		phy_set_bb_reg(Adapter, 0xb44, bMaskLWord, u4bTmp);
+
+		if (PMacTxInfo.bSPreamble)
+			phy_set_bb_reg(Adapter, 0xb0c, BIT27, 0);
+		else
+			phy_set_bb_reg(Adapter, 0xb0c, BIT27, 1);
+	} else {
+		phy_set_bb_reg(Adapter, 0xb18, 0xfffff, PMacTxInfo.PacketCount);
+
+		u4bTmp = PMacTxInfo.LSIG[0] | ((PMacTxInfo.LSIG[1]) << 8) | ((PMacTxInfo.LSIG[2]) << 16) | ((PMacTxInfo.PacketPattern) << 24);
+		phy_set_bb_reg(Adapter, 0xb08, bMaskDWord, u4bTmp);	/*	Set 0xb08[23:0] = LSIG, 0xb08[31:24] =  Data init octet*/
+
+		if (PMacTxInfo.PacketPattern == 0x12)
+			u4bTmp = 0x3000000;
+		else
+			u4bTmp = 0;
+	}
+
+	if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE)) {
+		u4bTmp |= PMacTxInfo.HT_SIG[0] | ((PMacTxInfo.HT_SIG[1]) << 8) | ((PMacTxInfo.HT_SIG[2]) << 16);
+		phy_set_bb_reg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
+		u4bTmp = PMacTxInfo.HT_SIG[3] | ((PMacTxInfo.HT_SIG[4]) << 8) | ((PMacTxInfo.HT_SIG[5]) << 16);
+		phy_set_bb_reg(Adapter, 0xb10, 0xffffff, u4bTmp);
+	} else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
+		u4bTmp |= PMacTxInfo.VHT_SIG_A[0] | ((PMacTxInfo.VHT_SIG_A[1]) << 8) | ((PMacTxInfo.VHT_SIG_A[2]) << 16);
+		phy_set_bb_reg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
+		u4bTmp = PMacTxInfo.VHT_SIG_A[3] | ((PMacTxInfo.VHT_SIG_A[4]) << 8) | ((PMacTxInfo.VHT_SIG_A[5]) << 16);
+		phy_set_bb_reg(Adapter, 0xb10, 0xffffff, u4bTmp);
+
+		_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_SIG_B, 4);
+		phy_set_bb_reg(Adapter, 0xb14, bMaskDWord, u4bTmp);
+	}
+
+	if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
+		u4bTmp = (PMacTxInfo.VHT_SIG_B_CRC << 24) | PMacTxInfo.PacketPeriod;	/* for TX interval */
+		phy_set_bb_reg(Adapter, 0xb20, bMaskDWord, u4bTmp);
+
+		_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_Delimiter, 4);
+		phy_set_bb_reg(Adapter, 0xb24, bMaskDWord, u4bTmp);
+
+		/* 0xb28 - 0xb34 24 byte Probe Request MAC Header*/
+		/*& Duration & Frame control*/
+		phy_set_bb_reg(Adapter, 0xb28, bMaskDWord, 0x00000040);
+
+		/* Address1 [0:3]*/
+		u4bTmp = PMacTxInfo.MacAddress[0] | (PMacTxInfo.MacAddress[1] << 8) | (PMacTxInfo.MacAddress[2] << 16) | (PMacTxInfo.MacAddress[3] << 24);
+		phy_set_bb_reg(Adapter, 0xb2C, bMaskDWord, u4bTmp);
+
+		/* Address3 [3:0]*/
+		phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);
+
+		/* Address2[0:1] & Address1 [5:4]*/
+		u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8) | (Adapter->mac_addr[0] << 16) | (Adapter->mac_addr[1] << 24);
+		phy_set_bb_reg(Adapter, 0xb30, bMaskDWord, u4bTmp);
+
+		/* Address2 [5:2]*/
+		u4bTmp = Adapter->mac_addr[2] | (Adapter->mac_addr[3] << 8) | (Adapter->mac_addr[4] << 16) | (Adapter->mac_addr[5] << 24);
+		phy_set_bb_reg(Adapter, 0xb34, bMaskDWord, u4bTmp);
+
+		/* Sequence Control & Address3 [5:4]*/
+		/*u4bTmp = PMacTxInfo.MacAddress[4]|(PMacTxInfo.MacAddress[5] << 8) ;*/
+		/*phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);*/
+	} else {
+		phy_set_bb_reg(Adapter, 0xb20, bMaskDWord, PMacTxInfo.PacketPeriod);	/* for TX interval*/
+		/* & Duration & Frame control */
+		phy_set_bb_reg(Adapter, 0xb24, bMaskDWord, 0x00000040);
+
+		/* 0xb24 - 0xb38 24 byte Probe Request MAC Header*/
+		/* Address1 [0:3]*/
+		u4bTmp = PMacTxInfo.MacAddress[0] | (PMacTxInfo.MacAddress[1] << 8) | (PMacTxInfo.MacAddress[2] << 16) | (PMacTxInfo.MacAddress[3] << 24);
+		phy_set_bb_reg(Adapter, 0xb28, bMaskDWord, u4bTmp);
+
+		/* Address3 [3:0]*/
+		phy_set_bb_reg(Adapter, 0xb34, bMaskDWord, u4bTmp);
+
+		/* Address2[0:1] & Address1 [5:4]*/
+		u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8) | (Adapter->mac_addr[0] << 16) | (Adapter->mac_addr[1] << 24);
+		phy_set_bb_reg(Adapter, 0xb2c, bMaskDWord, u4bTmp);
+
+		/* Address2 [5:2] */
+		u4bTmp = Adapter->mac_addr[2] | (Adapter->mac_addr[3] << 8) | (Adapter->mac_addr[4] << 16) | (Adapter->mac_addr[5] << 24);
+		phy_set_bb_reg(Adapter, 0xb30, bMaskDWord, u4bTmp);
+
+		/* Sequence Control & Address3 [5:4]*/
+		u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8);
+		phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);
+	}
+
+	phy_set_bb_reg(Adapter, 0xb48, bMaskByte3, PMacTxInfo.TX_RATE_HEX);
+
+	/* 0xb4c 3:0 TXSC	5:4	BW	7:6 m_STBC	8 NDP_Sound*/
+	u4bTmp = (PMacTxInfo.TX_SC) | ((PMacTxInfo.BandWidth) << 4) | ((PMacTxInfo.m_STBC - 1) << 6) | ((PMacTxInfo.NDP_sound) << 8);
+	phy_set_bb_reg(Adapter, 0xb4c, 0x1ff, u4bTmp);
+
+	if (IS_HARDWARE_TYPE_JAGUAR2(Adapter)) {
+		u4Byte offset = 0xb44;
+
+		if (IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
+			phy_set_bb_reg(Adapter, offset, 0xc0000000, 0);
+		else if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE))
+			phy_set_bb_reg(Adapter, offset, 0xc0000000, 1);
+		else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
+			phy_set_bb_reg(Adapter, offset, 0xc0000000, 2);
+	}
+
+	phy_set_bb_reg(Adapter, 0xb00, BIT8, 1);		/*	Turn on PMAC*/
+	/* phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);				 */ /* TX Stop */
+	if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
+		phy_set_bb_reg(Adapter, 0xb04, 0xf, 8);		/*TX CCK ON*/
+		phy_set_bb_reg(Adapter, 0xA84, BIT31, 0);
+	} else
+		phy_set_bb_reg(Adapter, 0xb04, 0xf, 4);		/*	TX Ofdm ON	*/
+
+	if (PMacTxInfo.Mode == OFDM_Single_Tone_TX)
+		mpt_SetSingleTone_8814A(Adapter, TRUE, TRUE);
+
+}
+
+#endif
+
+void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart)
+{
+	u8 Rate;
+
+	RTW_INFO("SetContinuousTx: rate:%d\n", pAdapter->mppriv.rateidx);
+	Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
+	pAdapter->mppriv.mpt_ctx.is_start_cont_tx = bStart;
+
+	if (Rate <= MPT_RATE_11M) {
+		if (bStart)
+			mpt_StartCckContTx(pAdapter);
+		else
+			mpt_StopCckContTx(pAdapter);
+
+	} else if (Rate >= MPT_RATE_6M) {
+		if (bStart)
+			mpt_StartOfdmContTx(pAdapter);
+		else
+			mpt_StopOfdmContTx(pAdapter);
+	}
+}
+
+#endif /* CONFIG_MP_INCLUDE*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_phy.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_phy.c
index feb619edb659..59b3673f6f26 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_phy.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/hal_phy.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,29 +12,18 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _HAL_PHY_C_
 
 #include <drv_types.h>
 
-//================================================================================
-//	Constant.
-//================================================================================
-// 2008/11/20 MH For Debug only, RF
-static RF_SHADOW_T RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
-
 /**
 * Function:	PHY_CalculateBitShift
 *
 * OverView:	Get shifted position of the BitMask
 *
 * Input:
-*			u4Byte		BitMask,	
+*			u4Byte		BitMask,
 *
 * Output:	none
 * Return:		u4Byte		Return the shift bit bit position of the mask
@@ -41,24 +31,30 @@ static RF_SHADOW_T RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
 u32
 PHY_CalculateBitShift(
 	u32 BitMask
-	)
+)
 {
 	u32 i;
 
-	for(i=0; i<=31; i++)
-	{
-		if ( ((BitMask>>i) &  0x1 ) == 1)
+	for (i = 0; i <= 31; i++) {
+		if (((BitMask >> i) &  0x1) == 1)
 			break;
 	}
 
-	return (i);
+	return i;
 }
 
 
-//
-// ==> RF shadow Operation API Code Section!!!
-//
-/*-----------------------------------------------------------------------------
+#ifdef CONFIG_RF_SHADOW_RW
+/* ********************************************************************************
+ *	Constant.
+ * ********************************************************************************
+ * 2008/11/20 MH For Debug only, RF */
+static RF_SHADOW_T RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
+
+/*
+ * ==> RF shadow Operation API Code Section!!!
+ *
+ *-----------------------------------------------------------------------------
  * Function:	PHY_RFShadowRead
  *				PHY_RFShadowWrite
  *				PHY_RFShadowCompare
@@ -80,13 +76,13 @@ PHY_CalculateBitShift(
  *
  * Revised History:
  * When			Who		Remark
- * 11/20/2008 	MHC		Create Version 0.
+ * 11/20/2008	MHC		Create Version 0.
  *
  *---------------------------------------------------------------------------*/
 u32
 PHY_RFShadowRead(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset)
 {
 	return	RF_Shadow[eRFPath][Offset].Value;
@@ -97,7 +93,7 @@ PHY_RFShadowRead(
 VOID
 PHY_RFShadowWrite(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset,
 	IN	u32				Data)
 {
@@ -110,22 +106,17 @@ PHY_RFShadowWrite(
 BOOLEAN
 PHY_RFShadowCompare(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset)
 {
 	u32	reg;
-	// Check if we need to check the register
-	if (RF_Shadow[eRFPath][Offset].Compare == _TRUE)
-	{
+	/* Check if we need to check the register */
+	if (RF_Shadow[eRFPath][Offset].Compare == _TRUE) {
 		reg = rtw_hal_read_rfreg(Adapter, eRFPath, Offset, bRFRegOffsetMask);
-		// Compare shadow and real rf register for 20bits!!
-		if (RF_Shadow[eRFPath][Offset].Value != reg)
-		{
-			// Locate error position.
+		/* Compare shadow and real rf register for 20bits!! */
+		if (RF_Shadow[eRFPath][Offset].Value != reg) {
+			/* Locate error position. */
 			RF_Shadow[eRFPath][Offset].ErrorOrNot = _TRUE;
-			//RT_TRACE(COMP_INIT, DBG_LOUD,
-			//("PHY_RFShadowCompare RF-%d Addr%02lx Err = %05lx\n",
-			//eRFPath, Offset, reg));
 		}
 		return RF_Shadow[eRFPath][Offset].ErrorOrNot ;
 	}
@@ -136,20 +127,15 @@ PHY_RFShadowCompare(
 VOID
 PHY_RFShadowRecorver(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset)
 {
-	// Check if the address is error
-	if (RF_Shadow[eRFPath][Offset].ErrorOrNot == _TRUE)
-	{
-		// Check if we need to recorver the register.
-		if (RF_Shadow[eRFPath][Offset].Recorver == _TRUE)
-		{
+	/* Check if the address is error */
+	if (RF_Shadow[eRFPath][Offset].ErrorOrNot == _TRUE) {
+		/* Check if we need to recorver the register. */
+		if (RF_Shadow[eRFPath][Offset].Recorver == _TRUE) {
 			rtw_hal_write_rfreg(Adapter, eRFPath, Offset, bRFRegOffsetMask,
-							RF_Shadow[eRFPath][Offset].Value);
-			//RT_TRACE(COMP_INIT, DBG_LOUD,
-			//("PHY_RFShadowRecorver RF-%d Addr%02lx=%05lx",
-			//eRFPath, Offset, RF_Shadow[eRFPath][Offset].Value));
+					    RF_Shadow[eRFPath][Offset].Value);
 		}
 	}
 
@@ -160,15 +146,12 @@ VOID
 PHY_RFShadowCompareAll(
 	IN	PADAPTER			Adapter)
 {
-	u8		eRFPath = 0 ;
-	u32		Offset = 0, maxReg= GET_RF6052_REAL_MAX_REG(Adapter);
+	enum rf_path	eRFPath = RF_PATH_A;
+	u32		Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
 
-	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++)
-	{
+	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
 		for (Offset = 0; Offset < maxReg; Offset++)
-		{
 			PHY_RFShadowCompare(Adapter, eRFPath, Offset);
-		}
 	}
 
 }	/* PHY_RFShadowCompareAll */
@@ -178,15 +161,12 @@ VOID
 PHY_RFShadowRecorverAll(
 	IN	PADAPTER			Adapter)
 {
-	u8		eRFPath =0;
-	u32		Offset = 0, maxReg= GET_RF6052_REAL_MAX_REG(Adapter);
+	enum rf_path		eRFPath = RF_PATH_A;
+	u32		Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
 
-	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++)
-	{
+	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
 		for (Offset = 0; Offset < maxReg; Offset++)
-		{
 			PHY_RFShadowRecorver(Adapter, eRFPath, Offset);
-		}
 	}
 
 }	/* PHY_RFShadowRecorverAll */
@@ -195,11 +175,11 @@ PHY_RFShadowRecorverAll(
 VOID
 PHY_RFShadowCompareFlagSet(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset,
 	IN	u8				Type)
 {
-	// Set True or False!!!
+	/* Set True or False!!! */
 	RF_Shadow[eRFPath][Offset].Compare = Type;
 
 }	/* PHY_RFShadowCompareFlagSet */
@@ -208,12 +188,12 @@ PHY_RFShadowCompareFlagSet(
 VOID
 PHY_RFShadowRecorverFlagSet(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset,
 	IN	u8				Type)
 {
-	// Set True or False!!!
-	RF_Shadow[eRFPath][Offset].Recorver= Type;
+	/* Set True or False!!! */
+	RF_Shadow[eRFPath][Offset].Recorver = Type;
 
 }	/* PHY_RFShadowRecorverFlagSet */
 
@@ -222,14 +202,12 @@ VOID
 PHY_RFShadowCompareFlagSetAll(
 	IN	PADAPTER			Adapter)
 {
-	u8		eRFPath = 0;
-	u32		Offset = 0, maxReg= GET_RF6052_REAL_MAX_REG(Adapter);
+	enum rf_path	eRFPath = RF_PATH_A;
+	u32		Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
 
-	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++)
-	{
-		for (Offset = 0; Offset < maxReg; Offset++)
-		{
-			// 2008/11/20 MH For S3S4 test, we only check reg 26/27 now!!!!
+	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
+		for (Offset = 0; Offset < maxReg; Offset++) {
+			/* 2008/11/20 MH For S3S4 test, we only check reg 26/27 now!!!! */
 			if (Offset != 0x26 && Offset != 0x27)
 				PHY_RFShadowCompareFlagSet(Adapter, eRFPath, Offset, _FALSE);
 			else
@@ -244,14 +222,12 @@ VOID
 PHY_RFShadowRecorverFlagSetAll(
 	IN	PADAPTER			Adapter)
 {
-	u8		eRFPath = 0;
-	u32		Offset = 0, maxReg= GET_RF6052_REAL_MAX_REG(Adapter);
+	enum rf_path		eRFPath = RF_PATH_A;
+	u32		Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
 
-	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++)
-	{
-		for (Offset = 0; Offset < maxReg; Offset++)
-		{
-			// 2008/11/20 MH For S3S4 test, we only check reg 26/27 now!!!!
+	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
+		for (Offset = 0; Offset < maxReg; Offset++) {
+			/* 2008/11/20 MH For S3S4 test, we only check reg 26/27 now!!!! */
 			if (Offset != 0x26 && Offset != 0x27)
 				PHY_RFShadowRecorverFlagSet(Adapter, eRFPath, Offset, _FALSE);
 			else
@@ -265,13 +241,11 @@ VOID
 PHY_RFShadowRefresh(
 	IN	PADAPTER			Adapter)
 {
-	u8		eRFPath = 0;
-	u32		Offset = 0, maxReg= GET_RF6052_REAL_MAX_REG(Adapter);
+	enum rf_path		eRFPath = RF_PATH_A;
+	u32		Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
 
-	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++)
-	{
-		for (Offset = 0; Offset < maxReg; Offset++)
-		{
+	for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
+		for (Offset = 0; Offset < maxReg; Offset++) {
 			RF_Shadow[eRFPath][Offset].Value = 0;
 			RF_Shadow[eRFPath][Offset].Compare = _FALSE;
 			RF_Shadow[eRFPath][Offset].Recorver  = _FALSE;
@@ -281,5 +255,4 @@ PHY_RFShadowRefresh(
 	}
 
 }	/* PHY_RFShadowRead */
-
-
+#endif /*CONFIG_RF_SHADOW_RW*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/led/hal_led.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/led/hal_led.c
new file mode 100644
index 000000000000..7a68107c67f8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/led/hal_led.c
@@ -0,0 +1,255 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+
+#ifdef CONFIG_RTW_LED
+void dump_led_config(void *sel, _adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+	int i;
+
+	RTW_PRINT_SEL(sel, "strategy:%u\n", ledpriv->LedStrategy);
+#ifdef CONFIG_RTW_SW_LED
+	RTW_PRINT_SEL(sel, "bRegUseLed:%u\n", ledpriv->bRegUseLed);
+	RTW_PRINT_SEL(sel, "iface_en_mask:0x%02X\n", ledpriv->iface_en_mask);
+	for (i = 0; i < dvobj->iface_nums; i++)
+		RTW_PRINT_SEL(sel, "ctl_en_mask[%d]:0x%08X\n", i, ledpriv->ctl_en_mask[i]);
+#endif
+}
+
+void rtw_led_set_strategy(_adapter *adapter, u8 strategy)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
+
+#ifndef CONFIG_RTW_SW_LED
+	if (IS_SW_LED_STRATEGY(strategy)) {
+		RTW_WARN("CONFIG_RTW_SW_LED is not defined\n");
+		return;
+	}
+#endif
+
+#ifdef CONFIG_RTW_SW_LED
+	if (!ledpriv->bRegUseLed)
+		return;
+#endif
+
+	if (ledpriv->LedStrategy == strategy)
+		return;
+
+	if (IS_HW_LED_STRATEGY(strategy) || IS_HW_LED_STRATEGY(ledpriv->LedStrategy)) {
+		RTW_WARN("switching on/off HW_LED strategy is not supported\n");
+		return;
+	}
+
+	ledpriv->LedStrategy = strategy;
+
+#ifdef CONFIG_RTW_SW_LED
+	rtw_hal_sw_led_deinit(pri_adapter);
+#endif
+
+	rtw_led_control(pri_adapter, RTW_LED_OFF);
+}
+
+#ifdef CONFIG_RTW_SW_LED
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+void rtw_sw_led_blink_uc_trx_only(LED_DATA *led)
+{
+	_adapter *adapter = led->padapter;
+	BOOLEAN bStopBlinking = _FALSE;
+
+	if (led->BlinkingLedState == RTW_LED_ON)
+		SwLedOn(adapter, led);
+	else
+		SwLedOff(adapter, led);
+
+	switch (led->CurrLedState) {
+	case RTW_LED_ON:
+		SwLedOn(adapter, led);
+		break;
+
+	case RTW_LED_OFF:
+		SwLedOff(adapter, led);
+		break;
+
+	case LED_BLINK_TXRX:
+		led->BlinkTimes--;
+		if (led->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (adapter_to_pwrctl(adapter)->rf_pwrstate != rf_on
+			&& adapter_to_pwrctl(adapter)->rfoff_reason > RF_CHANGE_BY_PS
+		) {
+			SwLedOff(adapter, led);
+			led->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (led->bLedOn)
+				led->BlinkingLedState = RTW_LED_OFF;
+			else
+				led->BlinkingLedState = RTW_LED_ON;
+			
+			if (bStopBlinking) {
+				led->CurrLedState = RTW_LED_OFF;
+				led->bLedBlinkInProgress = _FALSE;
+			}
+			_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	default:
+		break;
+	}
+}
+
+void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl)
+{
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+	LED_DATA *led = &(ledpriv->SwLed0);
+	LED_DATA *led1 = &(ledpriv->SwLed1);
+	LED_DATA *led2 = &(ledpriv->SwLed2);
+
+	switch (ctl) {
+	case LED_CTL_UC_TX:
+	case LED_CTL_UC_RX:
+		if (led->bLedBlinkInProgress == _FALSE) {
+			led->bLedBlinkInProgress = _TRUE;
+			led->CurrLedState = LED_BLINK_TXRX;
+			led->BlinkTimes = 2;
+			if (led->bLedOn)
+				led->BlinkingLedState = RTW_LED_OFF;
+			else
+				led->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		led->CurrLedState = RTW_LED_OFF;
+		led->BlinkingLedState = RTW_LED_OFF;
+
+		if (led->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(led->BlinkTimer));
+			led->bLedBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(adapter, led);
+		SwLedOff(adapter, led1);
+		SwLedOff(adapter, led2);
+		break;
+
+	default:
+		break;
+	}
+}
+#endif /* CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY */
+
+void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl)
+{
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+
+	if (ledpriv->LedControlHandler) {
+		#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+		if (ledpriv->LedStrategy != SW_LED_MODE_UC_TRX_ONLY) {
+			if (ctl == LED_CTL_UC_TX || ctl == LED_CTL_BMC_TX) {
+				if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_TX))
+					ctl = LED_CTL_TX; /* transform specific TX ctl to general TX ctl */
+			} else if (ctl == LED_CTL_UC_RX || ctl == LED_CTL_BMC_RX) {
+				if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_RX))
+					ctl = LED_CTL_RX; /* transform specific RX ctl to general RX ctl */
+			}
+		}
+		#endif
+
+		if ((ledpriv->iface_en_mask & BIT(adapter->iface_id))
+			&& (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(ctl)))
+			ledpriv->LedControlHandler(adapter, ctl);
+	}
+}
+
+void rtw_led_tx_control(_adapter *adapter, const u8 *da)
+{
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (IS_MCAST(da))
+		rtw_led_control(adapter, LED_CTL_BMC_TX);
+	else
+		rtw_led_control(adapter, LED_CTL_UC_TX);
+#else
+	rtw_led_control(adapter, LED_CTL_TX);
+#endif
+}
+
+void rtw_led_rx_control(_adapter *adapter, const u8 *da)
+{
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (IS_MCAST(da))
+		rtw_led_control(adapter, LED_CTL_BMC_RX);
+	else
+		rtw_led_control(adapter, LED_CTL_UC_RX);
+#else
+	rtw_led_control(adapter, LED_CTL_RX);
+#endif
+}
+
+void rtw_led_set_iface_en(_adapter *adapter, u8 en)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+	if (en)
+		ledpriv->iface_en_mask |= BIT(adapter->iface_id);
+	else
+		ledpriv->iface_en_mask &= ~BIT(adapter->iface_id);
+}
+
+void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+	ledpriv->iface_en_mask = mask;
+}
+
+void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+	
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (ctl_mask & BIT(LED_CTL_TX))
+		ctl_mask |= BIT(LED_CTL_UC_TX) | BIT(LED_CTL_BMC_TX);
+	if (ctl_mask & BIT(LED_CTL_RX))
+		ctl_mask |= BIT(LED_CTL_UC_RX) | BIT(LED_CTL_BMC_RX);
+#endif
+
+	ledpriv->ctl_en_mask[adapter->iface_id] = ctl_mask;
+}
+
+void rtw_led_set_ctl_en_mask_primary(_adapter *adapter)
+{
+	rtw_led_set_ctl_en_mask(adapter, 0xFFFFFFFF);
+}
+
+void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter)
+{
+	rtw_led_set_ctl_en_mask(adapter
+		, BIT(LED_CTL_POWER_ON) | BIT(LED_CTL_POWER_OFF)
+		| BIT(LED_CTL_TX) | BIT(LED_CTL_RX)
+	);
+}
+#endif /* CONFIG_RTW_SW_LED */
+
+#endif /* CONFIG_RTW_LED */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/led/hal_sdio_led.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/led/hal_sdio_led.c
index 2f6d49c076ec..d60325f5a284 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/led/hal_sdio_led.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/led/hal_sdio_led.c
@@ -1,2418 +1,2019 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#include <drv_types.h>
-#include <hal_data.h>
-
-//
-//	Description:
-//		Implementation of LED blinking behavior.
-//		It toggle off LED and schedule corresponding timer if necessary.
-//
-void
-SwLedBlink(
-	PLED_SDIO			pLed
-	)
-{
-	_adapter			*padapter = pLed->padapter;
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	u8				bStopBlinking = _FALSE;
-
-	// Change LED according to BlinkingLedState specified.
-	if( pLed->BlinkingLedState == RTW_LED_ON )
-	{
-		SwLedOn(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn on\n", pLed->BlinkTimes));
-	}
-	else
-	{
-		SwLedOff(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,( "Blinktimes (%d): turn off\n", pLed->BlinkTimes));
-	}
-
-	// Determine if we shall change LED state again.
-	pLed->BlinkTimes--;
-	switch(pLed->CurrLedState)
-	{
-
-	case LED_BLINK_NORMAL:
-		if(pLed->BlinkTimes == 0)
-		{
-			bStopBlinking = _TRUE;
-		}
-		break;
-
-	case LED_BLINK_StartToBlink:
-		if( check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE) )
-		{
-			bStopBlinking = _TRUE;
-		}
-		if( check_fwstate(pmlmepriv, _FW_LINKED) &&
-			(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) )
-		{
-			bStopBlinking = _TRUE;
-		}
-		else if(pLed->BlinkTimes == 0)
-		{
-			bStopBlinking = _TRUE;
-		}
-		break;
-
-	case LED_BLINK_WPS:
-		if( pLed->BlinkTimes == 0 )
-		{
-			bStopBlinking = _TRUE;
-		}
-		break;
-
-
-	default:
-		bStopBlinking = _TRUE;
-		break;
-
-	}
-
-	if(bStopBlinking)
-	{
-		if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-		{
-			SwLedOff(padapter, pLed);
-		}
-		else if( (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE) && (pLed->bLedOn == _FALSE))
-		{
-			SwLedOn(padapter, pLed);
-		}
-		else if( (check_fwstate(pmlmepriv, _FW_LINKED)== _FALSE) &&  pLed->bLedOn == _TRUE)
-		{
-			SwLedOff(padapter, pLed);
-		}
-
-		pLed->BlinkTimes = 0;
-		pLed->bLedBlinkInProgress = _FALSE;
-	}
-	else
-	{
-		// Assign LED state to toggle.
-		if( pLed->BlinkingLedState == RTW_LED_ON )
-			pLed->BlinkingLedState = RTW_LED_OFF;
-		else
-			pLed->BlinkingLedState = RTW_LED_ON;
-
-		// Schedule a timer to toggle LED state.
-		switch( pLed->CurrLedState )
-		{
-		case LED_BLINK_NORMAL:
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-			break;
-
-		case LED_BLINK_SLOWLY:
-		case LED_BLINK_StartToBlink:
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
-			break;
-
-		case LED_BLINK_WPS:
-			{
-				if( pLed->BlinkingLedState == RTW_LED_ON )
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
-				else
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
-			}
-			break;
-
-		default:
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
-			break;
-		}
-	}
-}
-
-void
-SwLedBlink1(
-	PLED_SDIO			pLed
-	)
-{
-	_adapter				*padapter = pLed->padapter;
-	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);	
-	struct led_priv		*ledpriv = &(padapter->ledpriv);
-	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
-	PLED_SDIO 			pLed1 = &(ledpriv->SwLed1);
-	u8					bStopBlinking = _FALSE;
-	
-	if(pHalData->CustomerID == RT_CID_819x_CAMEO)
-		pLed = &(ledpriv->SwLed1);
-
-	// Change LED according to BlinkingLedState specified.
-	if( pLed->BlinkingLedState == RTW_LED_ON )
-	{
-		SwLedOn(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,( "Blinktimes (%d): turn on\n", pLed->BlinkTimes));
-	}
-	else
-	{
-		SwLedOff(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn off\n", pLed->BlinkTimes));
-	}
-
-
-	if(pHalData->CustomerID == RT_CID_DEFAULT)
-	{
-		if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE)
-		{
-			if(!pLed1->bSWLedCtrl)
-			{
-				SwLedOn(padapter, pLed1);
-				pLed1->bSWLedCtrl = _TRUE;
-			}
-			else if(!pLed1->bLedOn)
-				SwLedOn(padapter, pLed1);
-			RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (): turn on pLed1\n"));
-		}
-		else
-		{
-			if(!pLed1->bSWLedCtrl)
-			{
-				SwLedOff(padapter, pLed1);
-				pLed1->bSWLedCtrl = _TRUE;
-			}
-			else if(pLed1->bLedOn)
-				SwLedOff(padapter, pLed1);
-			RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (): turn off pLed1\n"));
-		}
-	}
-
-	switch(pLed->CurrLedState)
-	{
-		case LED_BLINK_SLOWLY:
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-			break;
-
-		case LED_BLINK_NORMAL:
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
-			break;
-
-		case LED_BLINK_SCAN:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE)
-				{
-					pLed->bLedLinkBlinkInProgress = _TRUE;
-					pLed->CurrLedState = LED_BLINK_NORMAL;
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _FALSE)
-				{
-					pLed->bLedNoLinkBlinkInProgress = _TRUE;
-					pLed->CurrLedState = LED_BLINK_SLOWLY;
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		case LED_BLINK_TXRX:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE)
-				{
-					pLed->bLedLinkBlinkInProgress = _TRUE;
-					pLed->CurrLedState = LED_BLINK_NORMAL;
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _FALSE)
-				{
-					pLed->bLedNoLinkBlinkInProgress = _TRUE;
-					pLed->CurrLedState = LED_BLINK_SLOWLY;
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->BlinkTimes = 0;
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		case LED_BLINK_WPS:
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			break;
-
-		case LED_BLINK_WPS_STOP:	//WPS success
-			if(pLed->BlinkingLedState == RTW_LED_ON)
-			{
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
-				bStopBlinking = _FALSE;
-			}
-			else
-			{
-				bStopBlinking = _TRUE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					pLed->bLedLinkBlinkInProgress = _TRUE;
-					pLed->CurrLedState = LED_BLINK_NORMAL;
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-			break;
-
-		default:
-			break;
-	}
-
-}
-
-void
-SwLedBlink2(
-	PLED_SDIO			pLed
-	)
-{
-	_adapter				*padapter = pLed->padapter;
-	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
-	u8					bStopBlinking = _FALSE;
-
-	// Change LED according to BlinkingLedState specified.
-	if( pLed->BlinkingLedState == RTW_LED_ON)
-	{
-		SwLedOn(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn on\n", pLed->BlinkTimes));
-	}
-	else
-	{
-		SwLedOff(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn off\n", pLed->BlinkTimes));
-	}
-
-	switch(pLed->CurrLedState)
-	{
-		case LED_BLINK_SCAN:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE)
-				{
-					pLed->CurrLedState = RTW_LED_ON;
-					pLed->BlinkingLedState = RTW_LED_ON;
-					SwLedOn(padapter, pLed);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("stop scan blink CurrLedState %d\n", pLed->CurrLedState));
-
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _FALSE)
-				{
-					pLed->CurrLedState = RTW_LED_OFF;
-					pLed->BlinkingLedState = RTW_LED_OFF;
-					SwLedOff(padapter, pLed);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("stop scan blink CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					 if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		case LED_BLINK_TXRX:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE)
-				{
-					pLed->CurrLedState = RTW_LED_ON;
-					pLed->BlinkingLedState = RTW_LED_ON;
-					SwLedOn(padapter, pLed);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("stop CurrLedState %d\n", pLed->CurrLedState));
-
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _FALSE)
-				{
-					pLed->CurrLedState = RTW_LED_OFF;
-					pLed->BlinkingLedState = RTW_LED_OFF;
-					SwLedOff(padapter, pLed);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("stop CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					 if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		default:
-			break;
-	}
-
-}
-
-void
-SwLedBlink3(
-	PLED_SDIO			pLed
-	)
-{
-	_adapter			*padapter = pLed->padapter;
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	u8				bStopBlinking = _FALSE;
-
-	// Change LED according to BlinkingLedState specified.
-	if( pLed->BlinkingLedState == RTW_LED_ON )
-	{
-		SwLedOn(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn on\n", pLed->BlinkTimes));
-	}
-	else
-	{
-		if(pLed->CurrLedState != LED_BLINK_WPS_STOP)
-			SwLedOff(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn off\n", pLed->BlinkTimes));
-	}
-
-	switch(pLed->CurrLedState)
-	{
-		case LED_BLINK_SCAN:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE)
-				{
-					pLed->CurrLedState = RTW_LED_ON;
-					pLed->BlinkingLedState = RTW_LED_ON;
-					if( !pLed->bLedOn )
-						SwLedOn(padapter, pLed);
-
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _FALSE)
-				{
-					pLed->CurrLedState = RTW_LED_OFF;
-					pLed->BlinkingLedState = RTW_LED_OFF;
-					if( pLed->bLedOn )
-						SwLedOff(padapter, pLed);
-
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-				 	if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		case LED_BLINK_TXRX:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE)
-				{
-					pLed->CurrLedState = RTW_LED_ON;
-					pLed->BlinkingLedState = RTW_LED_ON;
-
-					if( !pLed->bLedOn )
-						SwLedOn(padapter, pLed);
-
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				else if(check_fwstate(pmlmepriv, _FW_LINKED)== _FALSE)
-				{
-					pLed->CurrLedState = RTW_LED_OFF;
-					pLed->BlinkingLedState = RTW_LED_OFF;
-
-					if( pLed->bLedOn )
-						SwLedOff(padapter, pLed);
-
-
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		case LED_BLINK_WPS:
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			break;
-
-		case LED_BLINK_WPS_STOP:	//WPS success
-			if(pLed->BlinkingLedState == RTW_LED_ON)
-			{
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
-				bStopBlinking = _FALSE;
-			}
-			else
-			{
-				bStopBlinking = _TRUE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on )
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					pLed->CurrLedState = RTW_LED_ON;
-					pLed->BlinkingLedState = RTW_LED_ON;
-					SwLedOn(padapter, pLed);
-					RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-				}
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-			break;
-
-
-		default:
-			break;
-	}
-
-}
-
-
-void
-SwLedBlink4(
-	PLED_SDIO			pLed
-	)
-{
-	_adapter			*padapter = pLed->padapter;
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	PLED_SDIO 		pLed1 = &(ledpriv->SwLed1);
-	u8				bStopBlinking = _FALSE;
-
-	// Change LED according to BlinkingLedState specified.
-	if( pLed->BlinkingLedState == RTW_LED_ON )
-	{
-		SwLedOn(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn on\n", pLed->BlinkTimes));
-	}
-	else
-	{
-		SwLedOff(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn off\n", pLed->BlinkTimes));
-	}
-
-	if(!pLed1->bLedWPSBlinkInProgress && pLed1->BlinkingLedState == LED_UNKNOWN)
-	{
-		pLed1->BlinkingLedState = RTW_LED_OFF;
-		pLed1->CurrLedState = RTW_LED_OFF;
-		SwLedOff(padapter, pLed1);
-	}
-
-	switch(pLed->CurrLedState)
-	{
-		case LED_BLINK_SLOWLY:
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-			break;
-
-		case LED_BLINK_StartToBlink:
-			if( pLed->bLedOn )
-			{
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
-			}
-			else
-			{
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-			}
-			break;
-
-		case LED_BLINK_SCAN:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _FALSE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-					pLed->CurrLedState = LED_BLINK_SLOWLY;
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-				}
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					 if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		case LED_BLINK_TXRX:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					pLed->bLedNoLinkBlinkInProgress = _TRUE;
-					pLed->CurrLedState = LED_BLINK_SLOWLY;
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-				}
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		case LED_BLINK_WPS:
-			if( pLed->bLedOn )
-			{
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
-			}
-			else
-			{
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-			}
-			break;
-
-		case LED_BLINK_WPS_STOP:	//WPS authentication fail
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-			break;
-
-		case LED_BLINK_WPS_STOP_OVERLAP:	//WPS session overlap
-			pLed->BlinkTimes--;
-			if(pLed->BlinkTimes == 0)
-			{
-				if(pLed->bLedOn)
-				{
-					pLed->BlinkTimes = 1;
-				}
-				else
-				{
-					bStopBlinking = _TRUE;
-				}
-			}
-
-			if(bStopBlinking)
-			{
-				pLed->BlinkTimes = 10;
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
-			}
-			else
-			{
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-			}
-			break;
-
-		default:
-			break;
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("SwLedBlink4 CurrLedState %d\n", pLed->CurrLedState));
-
-
-}
-
-void
-SwLedBlink5(
-	PLED_SDIO			pLed
-	)
-{
-	_adapter			*padapter = pLed->padapter;
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	u8				bStopBlinking = _FALSE;
-
-	// Change LED according to BlinkingLedState specified.
-	if( pLed->BlinkingLedState == RTW_LED_ON )
-	{
-		SwLedOn(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn on\n", pLed->BlinkTimes));
-	}
-	else
-	{
-		SwLedOff(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn off\n", pLed->BlinkTimes));
-	}
-
-	switch(pLed->CurrLedState)
-	{
-		case LED_BLINK_SCAN:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					pLed->CurrLedState = RTW_LED_OFF;
-					pLed->BlinkingLedState = RTW_LED_OFF;
-					if(pLed->bLedOn)
-						SwLedOff(padapter, pLed);
-				}
-				else
-				{		pLed->CurrLedState = RTW_LED_ON;
-						pLed->BlinkingLedState = RTW_LED_ON;
-						if(!pLed->bLedOn)
-							_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-				}
-
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-
-		case LED_BLINK_TXRX:
-			pLed->BlinkTimes--;
-			if( pLed->BlinkTimes == 0 )
-			{
-				bStopBlinking = _TRUE;
-			}
-
-			if(bStopBlinking)
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					pLed->CurrLedState = RTW_LED_OFF;
-					pLed->BlinkingLedState = RTW_LED_OFF;
-					if(pLed->bLedOn)
-						SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					pLed->CurrLedState = RTW_LED_ON;
-					pLed->BlinkingLedState = RTW_LED_ON;
-					if(!pLed->bLedOn)
-						_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-				}
-
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				if( adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
-				{
-					SwLedOff(padapter, pLed);
-				}
-				else
-				{
-					 if( pLed->bLedOn )
-						pLed->BlinkingLedState = RTW_LED_OFF;
-					else
-						pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-				}
-			}
-			break;
-
-		default:
-			break;
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("SwLedBlink5 CurrLedState %d\n", pLed->CurrLedState));
-
-
-}
-
-void
-SwLedBlink6(
-	PLED_SDIO			pLed
-	)
-{
-	_adapter			*padapter = pLed->padapter;
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	u8				bStopBlinking = _FALSE;
-
-	// Change LED according to BlinkingLedState specified.
-	if( pLed->BlinkingLedState == RTW_LED_ON )
-	{
-		SwLedOn(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn on\n", pLed->BlinkTimes));
-	}
-	else
-	{
-		SwLedOff(padapter, pLed);
-		RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Blinktimes (%d): turn off\n", pLed->BlinkTimes));
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("<==== blink6\n"));
-}
-
-//
-//	Description:
-//		Handler function of LED Blinking.
-//		We dispatch acture LED blink action according to LedStrategy.
-//
-void BlinkHandler(PLED_SDIO	pLed)
-{
-	_adapter		*padapter = pLed->padapter;
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-
-	//DBG_871X("%s (%s:%d)\n",__FUNCTION__, current->comm, current->pid);
-	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
-		DBG_871X("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
-		, __func__
-		, rtw_is_drv_stopped(padapter)?"True":"False"
-		, rtw_is_surprise_removed(padapter)?"True":"False");
-		
-		return;
-	}
-
-	switch(ledpriv->LedStrategy)
-	{
-		case SW_LED_MODE0:
-			SwLedBlink(pLed);
-			break;
-		
-		case SW_LED_MODE1:
-			SwLedBlink1(pLed);
-			break;
-		
-		case SW_LED_MODE2:
-			SwLedBlink2(pLed);
-			break;
-			
-		case SW_LED_MODE3:
-			SwLedBlink3(pLed);
-			break;
-
-		case SW_LED_MODE4:
-			SwLedBlink4(pLed);
-			break;			
-
-		case SW_LED_MODE5:
-			SwLedBlink5(pLed);
-			break;
-
-		case SW_LED_MODE6:
-			SwLedBlink6(pLed);
-			break;
-
-		default:
-			//RT_TRACE(COMP_LED, DBG_LOUD, ("BlinkWorkItemCallback 0x%x \n", pHalData->LedStrategy));
-			//SwLedBlink(pLed);
-			break;
-	}
-}
-
-//
-//	Description:
-//		Callback function of LED BlinkTimer, 
-//		it just schedules to corresponding BlinkWorkItem/led_blink_hdl
-//
-void BlinkTimerCallback(void *data)
-{
-	PLED_SDIO	 pLed = (PLED_SDIO)data;
-	_adapter		*padapter = pLed->padapter;
-
-	//DBG_871X("%s\n", __FUNCTION__);
-
-	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
-		/*DBG_871X("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
-			, __func__
-			, rtw_is_drv_stopped(padapter)?"True":"False"
-			, rtw_is_surprise_removed(padapter)?"True":"False" );*/
-		return;
-	}
-
-	#ifdef CONFIG_LED_HANDLED_BY_CMD_THREAD
-	rtw_led_blink_cmd(padapter, pLed);
-	#else
-	_set_workitem(&(pLed->BlinkWorkItem));
-	#endif
-}
-
-//
-//	Description:
-//		Callback function of LED BlinkWorkItem.
-//		We dispatch acture LED blink action according to LedStrategy.
-//
-void BlinkWorkItemCallback(_workitem *work)
-{
-	PLED_SDIO	 pLed = container_of(work, LED_SDIO, BlinkWorkItem);
-	BlinkHandler(pLed);
-}
-
-static void
-SwLedControlMode0(
-	_adapter		*padapter,
-	LED_CTL_MODE		LedAction
-)
-{
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-	PLED_SDIO	pLed = &(ledpriv->SwLed1);
-
-	// Decide led state
-	switch(LedAction)
-	{
-	case LED_CTL_TX:
-	case LED_CTL_RX:
-		if( pLed->bLedBlinkInProgress == _FALSE )
-		{
-			pLed->bLedBlinkInProgress = _TRUE;
-
-			pLed->CurrLedState = LED_BLINK_NORMAL;
-			pLed->BlinkTimes = 2;
-
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-		}
-		break;
-
-	case LED_CTL_START_TO_LINK:
-		if( pLed->bLedBlinkInProgress == _FALSE )
-		{
-			pLed->bLedBlinkInProgress = _TRUE;
-
-			pLed->CurrLedState = LED_BLINK_StartToBlink;
-			pLed->BlinkTimes = 24;
-
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
-		}
-		else
-		{
-			pLed->CurrLedState = LED_BLINK_StartToBlink;
-		}
-		break;
-
-	case LED_CTL_LINK:
-		pLed->CurrLedState = RTW_LED_ON;
-		if( pLed->bLedBlinkInProgress == _FALSE )
-		{
-			pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), 0);
-		}
-		break;
-
-	case LED_CTL_NO_LINK:
-		pLed->CurrLedState = RTW_LED_OFF;
-		if( pLed->bLedBlinkInProgress == _FALSE )
-		{
-			pLed->BlinkingLedState = RTW_LED_OFF;
-			_set_timer(&(pLed->BlinkTimer), 0);
-		}
-		break;
-
-	case LED_CTL_POWER_OFF:
-		pLed->CurrLedState = RTW_LED_OFF;
-		if(pLed->bLedBlinkInProgress)
-		{
-			_cancel_timer_ex(&(pLed->BlinkTimer));
-			pLed->bLedBlinkInProgress = _FALSE;
-		}
-		SwLedOff(padapter, pLed);
-		break;
-
-	case LED_CTL_START_WPS:
-		if( pLed->bLedBlinkInProgress == _FALSE || pLed->CurrLedState == RTW_LED_ON)
-		{
-			pLed->bLedBlinkInProgress = _TRUE;
-
-			pLed->CurrLedState = LED_BLINK_WPS;
-			pLed->BlinkTimes = 20;
-
-			if( pLed->bLedOn )
-			{
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
-			}
-			else
-			{
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
-			}
-		}
-		break;
-
-	case LED_CTL_STOP_WPS:
-		if(pLed->bLedBlinkInProgress)
-		{
-			pLed->CurrLedState = RTW_LED_OFF;
-			_cancel_timer_ex(&(pLed->BlinkTimer));
-			pLed->bLedBlinkInProgress = _FALSE;
-		}
-		break;
-
-
-	default:
-		break;
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Led %d\n", pLed->CurrLedState));
-
-}
-
- //ALPHA, added by chiyoko, 20090106
-static void
-SwLedControlMode1(
-	_adapter		*padapter,
-	LED_CTL_MODE		LedAction
-)
-{
-	struct led_priv		*ledpriv = &(padapter->ledpriv);
-	PLED_SDIO			pLed = &(ledpriv->SwLed0);
-	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
-	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);
-	
-	if(pHalData->CustomerID == RT_CID_819x_CAMEO)
-		pLed = &(ledpriv->SwLed1);
-
-	switch(LedAction)
-	{
-		case LED_CTL_POWER_ON:
-		case LED_CTL_START_TO_LINK:
-		case LED_CTL_NO_LINK:
-			if( pLed->bLedNoLinkBlinkInProgress == _FALSE )
-			{
-				if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-				if( pLed->bLedLinkBlinkInProgress == _TRUE )
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedLinkBlinkInProgress = _FALSE;
-				}
-	 			if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-	 			}
-
-				pLed->bLedNoLinkBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_SLOWLY;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_LINK:
-			if( pLed->bLedLinkBlinkInProgress == _FALSE )
-			{
-				if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-				if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-	 			}
-				pLed->bLedLinkBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_NORMAL;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_SITE_SURVEY:
-			 if((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE))
-			 	;
-			 else if(pLed->bLedScanBlinkInProgress ==_FALSE)
-			 {
-			 	if(IS_LED_WPS_BLINKING(pLed))
-					return;
-
-	  			if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-				}
-				if( pLed->bLedLinkBlinkInProgress == _TRUE )
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					 pLed->bLedLinkBlinkInProgress = _FALSE;
-				}
-	 			if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				pLed->bLedScanBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_SCAN;
-				pLed->BlinkTimes = 24;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-
-			 }
-			break;
-
-		case LED_CTL_TX:
-		case LED_CTL_RX:
-			if(pLed->bLedBlinkInProgress ==_FALSE)
-			{
-				if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-				if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-				}
-				if( pLed->bLedLinkBlinkInProgress == _TRUE )
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedLinkBlinkInProgress = _FALSE;
-				}
-				pLed->bLedBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_TXRX;
-				pLed->BlinkTimes = 2;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_START_WPS: //wait until xinpin finish
-		case LED_CTL_START_WPS_BOTTON:
-			 if(pLed->bLedWPSBlinkInProgress ==_FALSE)
-			 {
-				if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-				}
-				if( pLed->bLedLinkBlinkInProgress == _TRUE )
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					 pLed->bLedLinkBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedScanBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedScanBlinkInProgress = _FALSE;
-				}
-				pLed->bLedWPSBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_WPS;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			 }
-			break;
-
-
-		case LED_CTL_STOP_WPS:
-			if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedNoLinkBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedLinkBlinkInProgress == _TRUE )
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				 pLed->bLedLinkBlinkInProgress = _FALSE;
-			}
-			if(pLed->bLedBlinkInProgress ==_TRUE)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			if(pLed->bLedScanBlinkInProgress ==_TRUE)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			if(pLed->bLedWPSBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-			}
-			else
-			{
-				pLed->bLedWPSBlinkInProgress = _TRUE;
-			}
-
-			pLed->CurrLedState = LED_BLINK_WPS_STOP;
-			if(pLed->bLedOn)
-			{
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
-			}
-			else
-			{
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), 0);
-			}
-			break;
-
-		case LED_CTL_STOP_WPS_FAIL:
-			if(pLed->bLedWPSBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			pLed->bLedNoLinkBlinkInProgress = _TRUE;
-			pLed->CurrLedState = LED_BLINK_SLOWLY;
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-			break;
-
-		case LED_CTL_POWER_OFF:
-			pLed->CurrLedState = RTW_LED_OFF;
-			pLed->BlinkingLedState = RTW_LED_OFF;
-			if( pLed->bLedNoLinkBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedNoLinkBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedLinkBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedLinkBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedWPSBlinkInProgress )
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedScanBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-
-			SwLedOff(padapter, pLed);
-			break;
-
-		default:
-			break;
-
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Led %d\n", pLed->CurrLedState));
-}
-
- //Arcadyan/Sitecom , added by chiyoko, 20090216
-static void
-SwLedControlMode2(
-	_adapter				*padapter,
-	LED_CTL_MODE		LedAction
-)
-{
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	PLED_SDIO 		pLed = &(ledpriv->SwLed0);
-
-	switch(LedAction)
-	{
-		case LED_CTL_SITE_SURVEY:
-			 if(pmlmepriv->LinkDetectInfo.bBusyTraffic)
-			 	;
-			 else if(pLed->bLedScanBlinkInProgress ==_FALSE)
-			 {
-			 	if(IS_LED_WPS_BLINKING(pLed))
-					return;
-
-	 			if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				pLed->bLedScanBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_SCAN;
-				pLed->BlinkTimes = 24;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			 }
-			break;
-
-		case LED_CTL_TX:
-		case LED_CTL_RX:
-	 		if((pLed->bLedBlinkInProgress ==_FALSE) && (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE))
-	  		{
-	  		  	if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-
-				pLed->bLedBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_TXRX;
-				pLed->BlinkTimes = 2;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_LINK:
-			pLed->CurrLedState = RTW_LED_ON;
-			pLed->BlinkingLedState = RTW_LED_ON;
-			if( pLed->bLedBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedScanBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-
-			_set_timer(&(pLed->BlinkTimer), 0);
-			break;
-
-		case LED_CTL_START_WPS: //wait until xinpin finish
-		case LED_CTL_START_WPS_BOTTON:
-			if(pLed->bLedWPSBlinkInProgress ==_FALSE)
-			{
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedScanBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedScanBlinkInProgress = _FALSE;
-				}
-				pLed->bLedWPSBlinkInProgress = _TRUE;
-				pLed->CurrLedState = RTW_LED_ON;
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), 0);
-			 }
-			break;
-
-		case LED_CTL_STOP_WPS:
-			pLed->bLedWPSBlinkInProgress = _FALSE;
-			if(adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
-			{
-				pLed->CurrLedState = RTW_LED_OFF;
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), 0);
-			}
-			else
-			{
-				pLed->CurrLedState = RTW_LED_ON;
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), 0);
-				RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-			}
-			break;
-
-		case LED_CTL_STOP_WPS_FAIL:
-			pLed->bLedWPSBlinkInProgress = _FALSE;
-			pLed->CurrLedState = RTW_LED_OFF;
-			pLed->BlinkingLedState = RTW_LED_OFF;
-			_set_timer(&(pLed->BlinkTimer), 0);
-			RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-			break;
-
-		case LED_CTL_START_TO_LINK:
-		case LED_CTL_NO_LINK:
-			if(!IS_LED_BLINKING(pLed))
-			{
-				pLed->CurrLedState = RTW_LED_OFF;
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), 0);
-			}
-			break;
-
-		case LED_CTL_POWER_OFF:
-			pLed->CurrLedState = RTW_LED_OFF;
-			pLed->BlinkingLedState = RTW_LED_OFF;
-			if( pLed->bLedBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedScanBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedWPSBlinkInProgress )
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			SwLedOff(padapter, pLed);
-			break;
-
-		default:
-			break;
-
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-}
-
-  //COREGA, added by chiyoko, 20090316
- static void
- SwLedControlMode3(
-	_adapter				*padapter,
-	LED_CTL_MODE		LedAction
-)
-{
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	PLED_SDIO		pLed = &(ledpriv->SwLed0);
-
-	switch(LedAction)
-	{
-		case LED_CTL_SITE_SURVEY:
-			if(pmlmepriv->LinkDetectInfo.bBusyTraffic)
-				;
-			else if(pLed->bLedScanBlinkInProgress ==_FALSE)
-			{
-				if(IS_LED_WPS_BLINKING(pLed))
-					return;
-
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				pLed->bLedScanBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_SCAN;
-				pLed->BlinkTimes = 24;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_TX:
-		case LED_CTL_RX:
-	 		if((pLed->bLedBlinkInProgress ==_FALSE) && (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE))
-	  		{
-	  		  	if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-
-				pLed->bLedBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_TXRX;
-				pLed->BlinkTimes = 2;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_LINK:
-			if(IS_LED_WPS_BLINKING(pLed))
-				return;
-
-			pLed->CurrLedState = RTW_LED_ON;
-			pLed->BlinkingLedState = RTW_LED_ON;
-			if( pLed->bLedBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedScanBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-
-			_set_timer(&(pLed->BlinkTimer), 0);
-			break;
-
-		case LED_CTL_START_WPS: //wait until xinpin finish
-		case LED_CTL_START_WPS_BOTTON:
-			if(pLed->bLedWPSBlinkInProgress ==_FALSE)
-			{
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedScanBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedScanBlinkInProgress = _FALSE;
-				}
-				pLed->bLedWPSBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_WPS;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_STOP_WPS:
-			if(pLed->bLedWPSBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-			else
-			{
-				pLed->bLedWPSBlinkInProgress = _TRUE;
-			}
-
-			pLed->CurrLedState = LED_BLINK_WPS_STOP;
-			if(pLed->bLedOn)
-			{
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
-			}
-			else
-			{
-				pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), 0);
-			}
-
-			break;
-
-		case LED_CTL_STOP_WPS_FAIL:
-			if(pLed->bLedWPSBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			pLed->CurrLedState = RTW_LED_OFF;
-			pLed->BlinkingLedState = RTW_LED_OFF;
-			_set_timer(&(pLed->BlinkTimer), 0);
-			break;
-
-		case LED_CTL_START_TO_LINK:
-		case LED_CTL_NO_LINK:
-			if(!IS_LED_BLINKING(pLed))
-			{
-				pLed->CurrLedState = RTW_LED_OFF;
-				pLed->BlinkingLedState = RTW_LED_OFF;
-				_set_timer(&(pLed->BlinkTimer), 0);
-			}
-			break;
-
-		case LED_CTL_POWER_OFF:
-			pLed->CurrLedState = RTW_LED_OFF;
-			pLed->BlinkingLedState = RTW_LED_OFF;
-			if( pLed->bLedBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedScanBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedWPSBlinkInProgress )
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			SwLedOff(padapter, pLed);
-			break;
-
-		default:
-			break;
-
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("CurrLedState %d\n", pLed->CurrLedState));
-}
-
-
- //Edimax-Belkin, added by chiyoko, 20090413
-static void
-SwLedControlMode4(
-	_adapter				*padapter,
-	LED_CTL_MODE		LedAction
-)
-{
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	PLED_SDIO		pLed = &(ledpriv->SwLed0);
-	PLED_SDIO		pLed1 = &(ledpriv->SwLed1);
-
-	switch(LedAction)
-	{
-		case LED_CTL_START_TO_LINK:
-			if(pLed1->bLedWPSBlinkInProgress)
-			{
-				pLed1->bLedWPSBlinkInProgress = _FALSE;
-				_cancel_timer_ex(&(pLed1->BlinkTimer));
-
-				pLed1->BlinkingLedState = RTW_LED_OFF;
-				pLed1->CurrLedState = RTW_LED_OFF;
-
-				if(pLed1->bLedOn)
-					_set_timer(&(pLed->BlinkTimer), 0);
-			}
-
-			if( pLed->bLedStartToLinkBlinkInProgress == _FALSE )
-			{
-				if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-	 			if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-	 			}
-	 			if(pLed->bLedNoLinkBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-	 			}
-
-				pLed->bLedStartToLinkBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_StartToBlink;
-				if( pLed->bLedOn )
-				{
-					pLed->BlinkingLedState = RTW_LED_OFF;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
-				}
-				else
-				{
-					pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-				}
-			}
-			break;
-
-		case LED_CTL_LINK:
-		case LED_CTL_NO_LINK:
-			//LED1 settings
-			if(LedAction == LED_CTL_LINK)
-			{
-				if(pLed1->bLedWPSBlinkInProgress)
-				{
-					pLed1->bLedWPSBlinkInProgress = _FALSE;
-					_cancel_timer_ex(&(pLed1->BlinkTimer));
-
-					pLed1->BlinkingLedState = RTW_LED_OFF;
-					pLed1->CurrLedState = RTW_LED_OFF;
-
-					if(pLed1->bLedOn)
-						_set_timer(&(pLed->BlinkTimer), 0);
-				}
-			}
-
-			if( pLed->bLedNoLinkBlinkInProgress == _FALSE )
-			{
-				if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-	 			if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-	 			}
-
-				pLed->bLedNoLinkBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_SLOWLY;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_SITE_SURVEY:
-			if((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE))
-				;
-			else if(pLed->bLedScanBlinkInProgress ==_FALSE)
-			{
-				if(IS_LED_WPS_BLINKING(pLed))
-					return;
-
-				if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				pLed->bLedScanBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_SCAN;
-				pLed->BlinkTimes = 24;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_TX:
-		case LED_CTL_RX:
-	 		if(pLed->bLedBlinkInProgress ==_FALSE)
-	  		{
-	  		  	if(pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
-				{
-					return;
-				}
-	  		  	if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-				}
-				pLed->bLedBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_TXRX;
-				pLed->BlinkTimes = 2;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_START_WPS: //wait until xinpin finish
-		case LED_CTL_START_WPS_BOTTON:
-			if(pLed1->bLedWPSBlinkInProgress)
-			{
-				pLed1->bLedWPSBlinkInProgress = _FALSE;
-				_cancel_timer_ex(&(pLed1->BlinkTimer));
-
-				pLed1->BlinkingLedState = RTW_LED_OFF;
-				pLed1->CurrLedState = RTW_LED_OFF;
-
-				if(pLed1->bLedOn)
-					_set_timer(&(pLed->BlinkTimer), 0);
-			}
-
-			if(pLed->bLedWPSBlinkInProgress ==_FALSE)
-			{
-				if(pLed->bLedNoLinkBlinkInProgress == _TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedNoLinkBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				if(pLed->bLedScanBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedScanBlinkInProgress = _FALSE;
-				}
-				pLed->bLedWPSBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_WPS;
-				if( pLed->bLedOn )
-				{
-					pLed->BlinkingLedState = RTW_LED_OFF;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
-				}
-				else
-				{
-					pLed->BlinkingLedState = RTW_LED_ON;
-					_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-				}
-			}
-			break;
-
-		case LED_CTL_STOP_WPS:	//WPS connect success
-			if(pLed->bLedWPSBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			pLed->bLedNoLinkBlinkInProgress = _TRUE;
-			pLed->CurrLedState = LED_BLINK_SLOWLY;
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-
-			break;
-
-		case LED_CTL_STOP_WPS_FAIL:		//WPS authentication fail
-			if(pLed->bLedWPSBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			pLed->bLedNoLinkBlinkInProgress = _TRUE;
-			pLed->CurrLedState = LED_BLINK_SLOWLY;
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-
-			//LED1 settings
-			if(pLed1->bLedWPSBlinkInProgress)
-				_cancel_timer_ex(&(pLed1->BlinkTimer));
-			else
-				pLed1->bLedWPSBlinkInProgress = _TRUE;
-
-			pLed1->CurrLedState = LED_BLINK_WPS_STOP;
-			if( pLed1->bLedOn )
-				pLed1->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed1->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-
-			break;
-
-		case LED_CTL_STOP_WPS_FAIL_OVERLAP:	//WPS session overlap
-			if(pLed->bLedWPSBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			pLed->bLedNoLinkBlinkInProgress = _TRUE;
-			pLed->CurrLedState = LED_BLINK_SLOWLY;
-			if( pLed->bLedOn )
-				pLed->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
-
-			//LED1 settings
-			if(pLed1->bLedWPSBlinkInProgress)
-				_cancel_timer_ex(&(pLed1->BlinkTimer));
-			else
-				pLed1->bLedWPSBlinkInProgress = _TRUE;
-
-			pLed1->CurrLedState = LED_BLINK_WPS_STOP_OVERLAP;
-			pLed1->BlinkTimes = 10;
-			if( pLed1->bLedOn )
-				pLed1->BlinkingLedState = RTW_LED_OFF;
-			else
-				pLed1->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
-
-			break;
-
-		case LED_CTL_POWER_OFF:
-			pLed->CurrLedState = RTW_LED_OFF;
-			pLed->BlinkingLedState = RTW_LED_OFF;
-
-			if( pLed->bLedNoLinkBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedNoLinkBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedLinkBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedLinkBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedWPSBlinkInProgress )
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedWPSBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedScanBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedScanBlinkInProgress = _FALSE;
-			}
-			if( pLed->bLedStartToLinkBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedStartToLinkBlinkInProgress = _FALSE;
-			}
-
-			if( pLed1->bLedWPSBlinkInProgress )
-			{
-				_cancel_timer_ex(&(pLed1->BlinkTimer));
-				pLed1->bLedWPSBlinkInProgress = _FALSE;
-			}
-
-			pLed1->BlinkingLedState = LED_UNKNOWN;
-			SwLedOff(padapter, pLed);
-			SwLedOff(padapter, pLed1);
-			break;
-
-		default:
-			break;
-
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Led %d\n", pLed->CurrLedState));
-}
-
-
-
- //Sercomm-Belkin, added by chiyoko, 20090415
-static void
-SwLedControlMode5(
-	_adapter				*padapter,
-	LED_CTL_MODE		LedAction
-)
-{
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-	PLED_SDIO		pLed = &(ledpriv->SwLed0);
-
-	if(pHalData->CustomerID == RT_CID_819x_CAMEO)
-		pLed = &(ledpriv->SwLed1);
-
-	switch(LedAction)
-	{
-		case LED_CTL_POWER_ON:
-		case LED_CTL_NO_LINK:
-		case LED_CTL_LINK: 	//solid blue
-			pLed->CurrLedState = RTW_LED_ON;
-			pLed->BlinkingLedState = RTW_LED_ON;
-
-			_set_timer(&(pLed->BlinkTimer), 0);
-			break;
-
-		case LED_CTL_SITE_SURVEY:
-			if((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE))
-				;
-			else if(pLed->bLedScanBlinkInProgress ==_FALSE)
-			{
-				if(pLed->bLedBlinkInProgress ==_TRUE)
-				{
-					_cancel_timer_ex(&(pLed->BlinkTimer));
-					pLed->bLedBlinkInProgress = _FALSE;
-				}
-				pLed->bLedScanBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_SCAN;
-				pLed->BlinkTimes = 24;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_TX:
-		case LED_CTL_RX:
-	 		if(pLed->bLedBlinkInProgress ==_FALSE)
-	  		{
-	  		  	if(pLed->CurrLedState == LED_BLINK_SCAN)
-				{
-					return;
-				}
-				pLed->bLedBlinkInProgress = _TRUE;
-				pLed->CurrLedState = LED_BLINK_TXRX;
-				pLed->BlinkTimes = 2;
-				if( pLed->bLedOn )
-					pLed->BlinkingLedState = RTW_LED_OFF;
-				else
-					pLed->BlinkingLedState = RTW_LED_ON;
-				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
-			}
-			break;
-
-		case LED_CTL_POWER_OFF:
-			pLed->CurrLedState = RTW_LED_OFF;
-			pLed->BlinkingLedState = RTW_LED_OFF;
-
-			if( pLed->bLedBlinkInProgress)
-			{
-				_cancel_timer_ex(&(pLed->BlinkTimer));
-				pLed->bLedBlinkInProgress = _FALSE;
-			}
-
-			SwLedOff(padapter, pLed);
-			break;
-
-		default:
-			break;
-
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("Led %d\n", pLed->CurrLedState));
-}
-
- //WNC-Corega, added by chiyoko, 20090902
-static void
-SwLedControlMode6(
-	_adapter				*padapter,
-	LED_CTL_MODE		LedAction
-)
-{
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	PLED_SDIO pLed0 = &(ledpriv->SwLed0);
-
-	switch(LedAction)
-	{
-		case LED_CTL_POWER_ON:
-		case LED_CTL_LINK:
-		case LED_CTL_NO_LINK:
-			_cancel_timer_ex(&(pLed0->BlinkTimer));
-			pLed0->CurrLedState = RTW_LED_ON;
-			pLed0->BlinkingLedState = RTW_LED_ON;
-			_set_timer(&(pLed0->BlinkTimer), 0);
-			break;
-
-		case LED_CTL_POWER_OFF:
-			SwLedOff(padapter, pLed0);
-			break;
-
-		default:
-			break;
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("ledcontrol 6 Led %d\n", pLed0->CurrLedState));
-}
-
-void
-LedControlSDIO(
-	_adapter				*padapter,
-	LED_CTL_MODE		LedAction
-	)
-{
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-
- #if(MP_DRIVER == 1)
-	if (padapter->registrypriv.mp_mode == 1)
-		return;
-#endif
-
-	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
-		/*DBG_871X("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
-		, __func__
-		, rtw_is_drv_stopped(padapter)?"True":"False"
-		, rtw_is_surprise_removed(padapter)?"True":"False");*/
-		return;
-	}
-
-	if( ledpriv->bRegUseLed == _FALSE)
-		return;
-
-	//if(priv->bInHctTest)
-	//	return;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	// Only do led action for PRIMARY_ADAPTER
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
-		return;
-#endif
-
-	if( (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on &&
-		adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) &&
-		(LedAction == LED_CTL_TX || LedAction == LED_CTL_RX ||
-		 LedAction == LED_CTL_SITE_SURVEY ||
-		 LedAction == LED_CTL_LINK ||
-		 LedAction == LED_CTL_NO_LINK ||
-		 LedAction == LED_CTL_POWER_ON) )
-	{
-		return;
-	}
-
-	switch(ledpriv->LedStrategy)
-	{
-		case SW_LED_MODE0:
-			SwLedControlMode0(padapter, LedAction);
-			break;
-
-		case SW_LED_MODE1:
-			SwLedControlMode1(padapter, LedAction);
-			break;
-		case SW_LED_MODE2:
-			SwLedControlMode2(padapter, LedAction);
-                	break;
-
-		case SW_LED_MODE3:
-			SwLedControlMode3(padapter, LedAction);
-			break;
-
-		case SW_LED_MODE4:
-			SwLedControlMode4(padapter, LedAction);
-			break;
-
-		case SW_LED_MODE5:
-			SwLedControlMode5(padapter, LedAction);
-			break;
-
-		case SW_LED_MODE6:
-			SwLedControlMode6(padapter, LedAction);
-			break;
-
-		default:
-			break;
-	}
-
-	RT_TRACE(_module_rtl8712_led_c_,_drv_info_,("LedStrategy:%d, LedAction %d\n", ledpriv->LedStrategy,LedAction));
-}
-
-//
-//	Description:
-//		Reset status of LED_871x object.
-//
-void ResetLedStatus(PLED_SDIO pLed) {
-
-	pLed->CurrLedState = RTW_LED_OFF; // Current LED state.
-	pLed->bLedOn = _FALSE; // true if LED is ON, false if LED is OFF.
-
-	pLed->bLedBlinkInProgress = _FALSE; // true if it is blinking, false o.w..
-	pLed->bLedWPSBlinkInProgress = _FALSE;
-	
-	pLed->BlinkTimes = 0; // Number of times to toggle led state for blinking.
-	pLed->BlinkingLedState = LED_UNKNOWN; // Next state for blinking, either RTW_LED_ON or RTW_LED_OFF are.
-
-	pLed->bLedNoLinkBlinkInProgress = _FALSE;
-	pLed->bLedLinkBlinkInProgress = _FALSE;
-	pLed->bLedStartToLinkBlinkInProgress = _FALSE;
-	pLed->bLedScanBlinkInProgress = _FALSE;
-}
-
- //
-//	Description:
-//		Initialize an LED_871x object.
-//
-void
-InitLed(
-	_adapter			*padapter,
-	PLED_SDIO		pLed,
-	LED_PIN			LedPin
-	)
-{
-	pLed->padapter = padapter;
-	pLed->LedPin = LedPin;
-
-	ResetLedStatus(pLed);
-
-	_init_timer(&(pLed->BlinkTimer), padapter->pnetdev, BlinkTimerCallback, pLed);
-
-	_init_workitem(&(pLed->BlinkWorkItem), BlinkWorkItemCallback, pLed);
-}
-
-
-//
-//	Description:
-//		DeInitialize an LED_871x object.
-//
-void
-DeInitLed(
-	PLED_SDIO		pLed
-	)
-{
-	_cancel_workitem_sync(&(pLed->BlinkWorkItem));
-	_cancel_timer_ex(&(pLed->BlinkTimer));
-	ResetLedStatus(pLed);
-}
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+#ifdef CONFIG_RTW_SW_LED
+
+/*
+ *	Description:
+ *		Implementation of LED blinking behavior.
+ *		It toggle off LED and schedule corresponding timer if necessary.
+ *   */
+void
+SwLedBlink(
+	PLED_SDIO			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	/* Determine if we shall change LED state again. */
+	pLed->BlinkTimes--;
+	switch (pLed->CurrLedState) {
+
+	case LED_BLINK_NORMAL:
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		break;
+
+	case LED_BLINK_StartToBlink:
+		if (check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE))
+			bStopBlinking = _TRUE;
+		if (check_fwstate(pmlmepriv, _FW_LINKED) &&
+		    (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)))
+			bStopBlinking = _TRUE;
+		else if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		break;
+
+
+	default:
+		bStopBlinking = _TRUE;
+		break;
+
+	}
+
+	if (bStopBlinking) {
+		if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+			SwLedOff(padapter, pLed);
+		else if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && (pLed->bLedOn == _FALSE))
+			SwLedOn(padapter, pLed);
+		else if ((check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) &&  pLed->bLedOn == _TRUE)
+			SwLedOff(padapter, pLed);
+
+		pLed->BlinkTimes = 0;
+		pLed->bLedBlinkInProgress = _FALSE;
+	} else {
+		/* Assign LED state to toggle. */
+		if (pLed->BlinkingLedState == RTW_LED_ON)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+		/* Schedule a timer to toggle LED state. */
+		switch (pLed->CurrLedState) {
+		case LED_BLINK_NORMAL:
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			break;
+
+		case LED_BLINK_SLOWLY:
+		case LED_BLINK_StartToBlink:
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			break;
+
+		case LED_BLINK_WPS: {
+			if (pLed->BlinkingLedState == RTW_LED_ON)
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+			else
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+		}
+		break;
+
+		default:
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			break;
+		}
+	}
+}
+
+void
+SwLedBlink1(
+	PLED_SDIO			pLed
+)
+{
+	_adapter				*padapter = pLed->padapter;
+	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);
+	struct led_priv		*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
+	PLED_SDIO			pLed1 = &(ledpriv->SwLed1);
+	u8					bStopBlinking = _FALSE;
+
+	if (pHalData->CustomerID == RT_CID_819x_CAMEO)
+		pLed = &(ledpriv->SwLed1);
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+
+	if (pHalData->CustomerID == RT_CID_DEFAULT) {
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+			if (!pLed1->bSWLedCtrl) {
+				SwLedOn(padapter, pLed1);
+				pLed1->bSWLedCtrl = _TRUE;
+			} else if (!pLed1->bLedOn)
+				SwLedOn(padapter, pLed1);
+		} else {
+			if (!pLed1->bSWLedCtrl) {
+				SwLedOff(padapter, pLed1);
+				pLed1->bSWLedCtrl = _TRUE;
+			} else if (pLed1->bLedOn)
+				SwLedOff(padapter, pLed1);
+		}
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SLOWLY:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_NORMAL:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->bLedLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_NORMAL;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->bLedLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_NORMAL;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->BlinkTimes = 0;
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS success */
+		if (pLed->BlinkingLedState == RTW_LED_ON) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+			bStopBlinking = _FALSE;
+		} else
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->bLedLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_NORMAL;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+SwLedBlink2(
+	PLED_SDIO			pLed
+)
+{
+	_adapter				*padapter = pLed->padapter;
+	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
+	u8					bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				SwLedOff(padapter, pLed);
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				SwLedOff(padapter, pLed);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+SwLedBlink3(
+	PLED_SDIO			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		if (pLed->CurrLedState != LED_BLINK_WPS_STOP)
+			SwLedOff(padapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (!pLed->bLedOn)
+					SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+
+				if (!pLed->bLedOn)
+					SwLedOn(padapter, pLed);
+
+			} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+
+
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS success */
+		if (pLed->BlinkingLedState == RTW_LED_ON) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+			bStopBlinking = _FALSE;
+		} else
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				SwLedOn(padapter, pLed);
+			}
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		break;
+
+
+	default:
+		break;
+	}
+
+}
+
+
+void
+SwLedBlink4(
+	PLED_SDIO			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	PLED_SDIO		pLed1 = &(ledpriv->SwLed1);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	if (!pLed1->bLedWPSBlinkInProgress && pLed1->BlinkingLedState == LED_UNKNOWN) {
+		pLed1->BlinkingLedState = RTW_LED_OFF;
+		pLed1->CurrLedState = RTW_LED_OFF;
+		SwLedOff(padapter, pLed1);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SLOWLY:
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_BLINK_StartToBlink:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _FALSE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				pLed->bLedNoLinkBlinkInProgress = _TRUE;
+				pLed->CurrLedState = LED_BLINK_SLOWLY;
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+			}
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	case LED_BLINK_WPS:
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_BLINK_WPS_STOP:	/* WPS authentication fail */
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		break;
+
+	case LED_BLINK_WPS_STOP_OVERLAP:	/* WPS session overlap */
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0) {
+			if (pLed->bLedOn)
+				pLed->BlinkTimes = 1;
+			else
+				bStopBlinking = _TRUE;
+		}
+
+		if (bStopBlinking) {
+			pLed->BlinkTimes = 10;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+		} else {
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	default:
+		break;
+	}
+
+
+
+}
+
+void
+SwLedBlink5(
+	PLED_SDIO			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+	switch (pLed->CurrLedState) {
+	case LED_BLINK_SCAN:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+			} else {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (!pLed->bLedOn)
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+
+	case LED_BLINK_TXRX:
+		pLed->BlinkTimes--;
+		if (pLed->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (bStopBlinking) {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) {
+				pLed->CurrLedState = RTW_LED_OFF;
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				if (pLed->bLedOn)
+					SwLedOff(padapter, pLed);
+			} else {
+				pLed->CurrLedState = RTW_LED_ON;
+				pLed->BlinkingLedState = RTW_LED_ON;
+				if (!pLed->bLedOn)
+					_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+
+			pLed->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS)
+				SwLedOff(padapter, pLed);
+			else {
+				if (pLed->bLedOn)
+					pLed->BlinkingLedState = RTW_LED_OFF;
+				else
+					pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+			}
+		}
+		break;
+
+	default:
+		break;
+	}
+
+
+
+}
+
+void
+SwLedBlink6(
+	PLED_SDIO			pLed
+)
+{
+	_adapter			*padapter = pLed->padapter;
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	u8				bStopBlinking = _FALSE;
+
+	/* Change LED according to BlinkingLedState specified. */
+	if (pLed->BlinkingLedState == RTW_LED_ON) {
+		SwLedOn(padapter, pLed);
+	} else {
+		SwLedOff(padapter, pLed);
+	}
+
+}
+
+/*
+ *	Description:
+ *		Handler function of LED Blinking.
+ *		We dispatch acture LED blink action according to LedStrategy.
+ *   */
+void BlinkHandler(PLED_SDIO	pLed)
+{
+	_adapter		*padapter = pLed->padapter;
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+
+	/* RTW_INFO("%s (%s:%d)\n",__FUNCTION__, current->comm, current->pid); */
+	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
+		RTW_INFO("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
+			 , __func__
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
+
+		return;
+	}
+
+	switch (ledpriv->LedStrategy) {
+	#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	case SW_LED_MODE_UC_TRX_ONLY:
+		rtw_sw_led_blink_uc_trx_only(pLed);
+		break;
+	#endif
+
+	case SW_LED_MODE0:
+		SwLedBlink(pLed);
+		break;
+
+	case SW_LED_MODE1:
+		SwLedBlink1(pLed);
+		break;
+
+	case SW_LED_MODE2:
+		SwLedBlink2(pLed);
+		break;
+
+	case SW_LED_MODE3:
+		SwLedBlink3(pLed);
+		break;
+
+	case SW_LED_MODE4:
+		SwLedBlink4(pLed);
+		break;
+
+	case SW_LED_MODE5:
+		SwLedBlink5(pLed);
+		break;
+
+	case SW_LED_MODE6:
+		SwLedBlink6(pLed);
+		break;
+
+	default:
+		/* SwLedBlink(pLed); */
+		break;
+	}
+}
+
+/*
+ *	Description:
+ *		Callback function of LED BlinkTimer,
+ *		it just schedules to corresponding BlinkWorkItem/led_blink_hdl
+ *   */
+void BlinkTimerCallback(void *data)
+{
+	PLED_SDIO	 pLed = (PLED_SDIO)data;
+	_adapter		*padapter = pLed->padapter;
+
+	/* RTW_INFO("%s\n", __FUNCTION__); */
+
+	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
+		/*RTW_INFO("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
+			, __func__
+			, rtw_is_drv_stopped(padapter)?"True":"False"
+			, rtw_is_surprise_removed(padapter)?"True":"False" );*/
+		return;
+	}
+
+#ifdef CONFIG_RTW_LED_HANDLED_BY_CMD_THREAD
+	rtw_led_blink_cmd(padapter, pLed);
+#else
+	_set_workitem(&(pLed->BlinkWorkItem));
+#endif
+}
+
+/*
+ *	Description:
+ *		Callback function of LED BlinkWorkItem.
+ *		We dispatch acture LED blink action according to LedStrategy.
+ *   */
+void BlinkWorkItemCallback(_workitem *work)
+{
+	PLED_SDIO	 pLed = container_of(work, LED_SDIO, BlinkWorkItem);
+	BlinkHandler(pLed);
+}
+
+static void
+SwLedControlMode0(
+	_adapter		*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	PLED_SDIO	pLed = &(ledpriv->SwLed1);
+
+	/* Decide led state */
+	switch (LedAction) {
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_NORMAL;
+			pLed->BlinkTimes = 2;
+
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+		}
+		break;
+
+	case LED_CTL_START_TO_LINK:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_StartToBlink;
+			pLed->BlinkTimes = 24;
+
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+		} else
+			pLed->CurrLedState = LED_BLINK_StartToBlink;
+		break;
+
+	case LED_CTL_LINK:
+		pLed->CurrLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_NO_LINK:
+		pLed->CurrLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		SwLedOff(padapter, pLed);
+		break;
+
+	case LED_CTL_START_WPS:
+		if (pLed->bLedBlinkInProgress == _FALSE || pLed->CurrLedState == RTW_LED_ON) {
+			pLed->bLedBlinkInProgress = _TRUE;
+
+			pLed->CurrLedState = LED_BLINK_WPS;
+			pLed->BlinkTimes = 20;
+
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_LONG_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedBlinkInProgress) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		break;
+
+
+	default:
+		break;
+	}
+
+
+}
+
+/* ALPHA, added by chiyoko, 20090106 */
+static void
+SwLedControlMode1(
+	_adapter		*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv		*ledpriv = adapter_to_led(padapter);
+	PLED_SDIO			pLed = &(ledpriv->SwLed0);
+	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
+	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);
+
+	if (pHalData->CustomerID == RT_CID_819x_CAMEO)
+		pLed = &(ledpriv->SwLed1);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		if (pLed->bLedNoLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedNoLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SLOWLY;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_LINK:
+		if (pLed->bLedLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_NORMAL;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if ((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE))
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress == _TRUE) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress)
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+		else
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedNoLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* Arcadyan/Sitecom , added by chiyoko, 20090216 */
+static void
+SwLedControlMode2(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_SDIO		pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_SITE_SURVEY:
+		if (pmlmepriv->LinkDetectInfo.bBusyTraffic)
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if ((pLed->bLedBlinkInProgress == _FALSE) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_LINK:
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = RTW_LED_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		pLed->bLedWPSBlinkInProgress = _FALSE;
+		if (adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		} else {
+			pLed->CurrLedState = RTW_LED_ON;
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:
+		pLed->bLedWPSBlinkInProgress = _FALSE;
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		if (!IS_LED_BLINKING(pLed)) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* COREGA, added by chiyoko, 20090316 */
+static void
+SwLedControlMode3(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_SDIO		pLed = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_SITE_SURVEY:
+		if (pmlmepriv->LinkDetectInfo.bBusyTraffic)
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if ((pLed->bLedBlinkInProgress == _FALSE) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_LINK:
+		if (IS_LED_WPS_BLINKING(pLed))
+			return;
+
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		} else
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed->bLedOn) {
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA);
+		} else {
+			pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_START_TO_LINK:
+	case LED_CTL_NO_LINK:
+		if (!IS_LED_BLINKING(pLed)) {
+			pLed->CurrLedState = RTW_LED_OFF;
+			pLed->BlinkingLedState = RTW_LED_OFF;
+			_set_timer(&(pLed->BlinkTimer), 0);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+
+/* Edimax-Belkin, added by chiyoko, 20090413 */
+static void
+SwLedControlMode4(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_SDIO		pLed = &(ledpriv->SwLed0);
+	PLED_SDIO		pLed1 = &(ledpriv->SwLed1);
+
+	switch (LedAction) {
+	case LED_CTL_START_TO_LINK:
+		if (pLed1->bLedWPSBlinkInProgress) {
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+			pLed1->CurrLedState = RTW_LED_OFF;
+
+			if (pLed1->bLedOn)
+				_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		if (pLed->bLedStartToLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedStartToLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_StartToBlink;
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_CTL_LINK:
+	case LED_CTL_NO_LINK:
+		/* LED1 settings */
+		if (LedAction == LED_CTL_LINK) {
+			if (pLed1->bLedWPSBlinkInProgress) {
+				pLed1->bLedWPSBlinkInProgress = _FALSE;
+				_cancel_timer_ex(&(pLed1->BlinkTimer));
+
+				pLed1->BlinkingLedState = RTW_LED_OFF;
+				pLed1->CurrLedState = RTW_LED_OFF;
+
+				if (pLed1->bLedOn)
+					_set_timer(&(pLed->BlinkTimer), 0);
+			}
+		}
+
+		if (pLed->bLedNoLinkBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+
+			pLed->bLedNoLinkBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SLOWLY;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if ((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE))
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (IS_LED_WPS_BLINKING(pLed))
+				return;
+
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN || IS_LED_WPS_BLINKING(pLed))
+				return;
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_START_WPS: /* wait until xinpin finish */
+	case LED_CTL_START_WPS_BOTTON:
+		if (pLed1->bLedWPSBlinkInProgress) {
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+			pLed1->CurrLedState = RTW_LED_OFF;
+
+			if (pLed1->bLedOn)
+				_set_timer(&(pLed->BlinkTimer), 0);
+		}
+
+		if (pLed->bLedWPSBlinkInProgress == _FALSE) {
+			if (pLed->bLedNoLinkBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedNoLinkBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			if (pLed->bLedScanBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedScanBlinkInProgress = _FALSE;
+			}
+			pLed->bLedWPSBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_WPS;
+			if (pLed->bLedOn) {
+				pLed->BlinkingLedState = RTW_LED_OFF;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
+			} else {
+				pLed->BlinkingLedState = RTW_LED_ON;
+				_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+			}
+		}
+		break;
+
+	case LED_CTL_STOP_WPS:	/* WPS connect success */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL:		/* WPS authentication fail */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+
+		/* LED1 settings */
+		if (pLed1->bLedWPSBlinkInProgress)
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+		else
+			pLed1->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed1->CurrLedState = LED_BLINK_WPS_STOP;
+		if (pLed1->bLedOn)
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed1->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+
+		break;
+
+	case LED_CTL_STOP_WPS_FAIL_OVERLAP:	/* WPS session overlap */
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed->bLedNoLinkBlinkInProgress = _TRUE;
+		pLed->CurrLedState = LED_BLINK_SLOWLY;
+		if (pLed->bLedOn)
+			pLed->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NO_LINK_INTERVAL_ALPHA);
+
+		/* LED1 settings */
+		if (pLed1->bLedWPSBlinkInProgress)
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+		else
+			pLed1->bLedWPSBlinkInProgress = _TRUE;
+
+		pLed1->CurrLedState = LED_BLINK_WPS_STOP_OVERLAP;
+		pLed1->BlinkTimes = 10;
+		if (pLed1->bLedOn)
+			pLed1->BlinkingLedState = RTW_LED_OFF;
+		else
+			pLed1->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
+
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		if (pLed->bLedNoLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedNoLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedLinkBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedWPSBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedScanBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedScanBlinkInProgress = _FALSE;
+		}
+		if (pLed->bLedStartToLinkBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedStartToLinkBlinkInProgress = _FALSE;
+		}
+
+		if (pLed1->bLedWPSBlinkInProgress) {
+			_cancel_timer_ex(&(pLed1->BlinkTimer));
+			pLed1->bLedWPSBlinkInProgress = _FALSE;
+		}
+
+		pLed1->BlinkingLedState = LED_UNKNOWN;
+		SwLedOff(padapter, pLed);
+		SwLedOff(padapter, pLed1);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+
+
+/* Sercomm-Belkin, added by chiyoko, 20090415 */
+static void
+SwLedControlMode5(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	PLED_SDIO		pLed = &(ledpriv->SwLed0);
+
+	if (pHalData->CustomerID == RT_CID_819x_CAMEO)
+		pLed = &(ledpriv->SwLed1);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_NO_LINK:
+	case LED_CTL_LINK:	/* solid blue */
+		pLed->CurrLedState = RTW_LED_ON;
+		pLed->BlinkingLedState = RTW_LED_ON;
+
+		_set_timer(&(pLed->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_SITE_SURVEY:
+		if ((pmlmepriv->LinkDetectInfo.bBusyTraffic) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE))
+			;
+		else if (pLed->bLedScanBlinkInProgress == _FALSE) {
+			if (pLed->bLedBlinkInProgress == _TRUE) {
+				_cancel_timer_ex(&(pLed->BlinkTimer));
+				pLed->bLedBlinkInProgress = _FALSE;
+			}
+			pLed->bLedScanBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_SCAN;
+			pLed->BlinkTimes = 24;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_SCAN_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_TX:
+	case LED_CTL_RX:
+		if (pLed->bLedBlinkInProgress == _FALSE) {
+			if (pLed->CurrLedState == LED_BLINK_SCAN)
+				return;
+			pLed->bLedBlinkInProgress = _TRUE;
+			pLed->CurrLedState = LED_BLINK_TXRX;
+			pLed->BlinkTimes = 2;
+			if (pLed->bLedOn)
+				pLed->BlinkingLedState = RTW_LED_OFF;
+			else
+				pLed->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(pLed->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		pLed->CurrLedState = RTW_LED_OFF;
+		pLed->BlinkingLedState = RTW_LED_OFF;
+
+		if (pLed->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(pLed->BlinkTimer));
+			pLed->bLedBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(padapter, pLed);
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+/* WNC-Corega, added by chiyoko, 20090902 */
+static void
+SwLedControlMode6(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PLED_SDIO pLed0 = &(ledpriv->SwLed0);
+
+	switch (LedAction) {
+	case LED_CTL_POWER_ON:
+	case LED_CTL_LINK:
+	case LED_CTL_NO_LINK:
+		_cancel_timer_ex(&(pLed0->BlinkTimer));
+		pLed0->CurrLedState = RTW_LED_ON;
+		pLed0->BlinkingLedState = RTW_LED_ON;
+		_set_timer(&(pLed0->BlinkTimer), 0);
+		break;
+
+	case LED_CTL_POWER_OFF:
+		SwLedOff(padapter, pLed0);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+LedControlSDIO(
+	_adapter				*padapter,
+	LED_CTL_MODE		LedAction
+)
+{
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+
+#if (MP_DRIVER == 1)
+	if (padapter->registrypriv.mp_mode == 1)
+		return;
+#endif
+
+	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
+		/*RTW_INFO("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
+		, __func__
+		, rtw_is_drv_stopped(padapter)?"True":"False"
+		, rtw_is_surprise_removed(padapter)?"True":"False");*/
+		return;
+	}
+
+	if (ledpriv->bRegUseLed == _FALSE)
+		return;
+
+	/* if(priv->bInHctTest) */
+	/*	return; */
+
+	if ((adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on &&
+	     adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) &&
+	    (LedAction == LED_CTL_TX || LedAction == LED_CTL_RX ||
+	     LedAction == LED_CTL_SITE_SURVEY ||
+	     LedAction == LED_CTL_LINK ||
+	     LedAction == LED_CTL_NO_LINK ||
+	     LedAction == LED_CTL_POWER_ON))
+		return;
+
+	switch (ledpriv->LedStrategy) {
+	#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	case SW_LED_MODE_UC_TRX_ONLY:
+		rtw_sw_led_ctl_mode_uc_trx_only(padapter, LedAction);
+		break;
+	#endif
+
+	case SW_LED_MODE0:
+		SwLedControlMode0(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE1:
+		SwLedControlMode1(padapter, LedAction);
+		break;
+	case SW_LED_MODE2:
+		SwLedControlMode2(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE3:
+		SwLedControlMode3(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE4:
+		SwLedControlMode4(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE5:
+		SwLedControlMode5(padapter, LedAction);
+		break;
+
+	case SW_LED_MODE6:
+		SwLedControlMode6(padapter, LedAction);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+/*
+ *	Description:
+ *		Reset status of LED_871x object.
+ *   */
+void ResetLedStatus(PLED_SDIO pLed)
+{
+
+	pLed->CurrLedState = RTW_LED_OFF; /* Current LED state. */
+	pLed->bLedOn = _FALSE; /* true if LED is ON, false if LED is OFF. */
+
+	pLed->bLedBlinkInProgress = _FALSE; /* true if it is blinking, false o.w.. */
+	pLed->bLedWPSBlinkInProgress = _FALSE;
+
+	pLed->BlinkTimes = 0; /* Number of times to toggle led state for blinking. */
+	pLed->BlinkingLedState = LED_UNKNOWN; /* Next state for blinking, either RTW_LED_ON or RTW_LED_OFF are. */
+
+	pLed->bLedNoLinkBlinkInProgress = _FALSE;
+	pLed->bLedLinkBlinkInProgress = _FALSE;
+	pLed->bLedStartToLinkBlinkInProgress = _FALSE;
+	pLed->bLedScanBlinkInProgress = _FALSE;
+}
+
+/*
+*	Description:
+*		Initialize an LED_871x object.
+*   */
+void
+InitLed(
+	_adapter			*padapter,
+	PLED_SDIO		pLed,
+	LED_PIN			LedPin
+)
+{
+	pLed->padapter = padapter;
+	pLed->LedPin = LedPin;
+
+	ResetLedStatus(pLed);
+
+	rtw_init_timer(&(pLed->BlinkTimer), padapter, BlinkTimerCallback, pLed);
+
+	_init_workitem(&(pLed->BlinkWorkItem), BlinkWorkItemCallback, pLed);
+}
+
+
+/*
+ *	Description:
+ *		DeInitialize an LED_871x object.
+ *   */
+void
+DeInitLed(
+	PLED_SDIO		pLed
+)
+{
+	_cancel_workitem_sync(&(pLed->BlinkWorkItem));
+	_cancel_timer_ex(&(pLed->BlinkTimer));
+	ResetLedStatus(pLed);
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/ap_makefile.mk b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/ap_makefile.mk
new file mode 100644
index 000000000000..b0c32b97d8de
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/ap_makefile.mk
@@ -0,0 +1,119 @@
+# SPDX-License-Identifier: GPL-2.0
+
+_PHYDM_FILES :=\
+	phydm/phydm.o \
+	phydm/phydm_dig.o\
+	phydm/phydm_antdiv.o\
+	phydm/phydm_soml.o\
+	phydm/phydm_smt_ant.o\
+	phydm/phydm_pathdiv.o\
+	phydm/phydm_rainfo.o\
+	phydm/phydm_dynamictxpower.o\
+	phydm/phydm_adaptivity.o\
+	phydm/phydm_debug.o\
+	phydm/phydm_interface.o\
+	phydm/phydm_phystatus.o\
+	phydm/phydm_hwconfig.o\
+	phydm/phydm_dfs.o\
+	phydm/phydm_cfotracking.o\
+	phydm/phydm_adc_sampling.o\
+	phydm/phydm_ccx.o\
+	phydm/phydm_primary_cca.o\
+	phydm/phydm_cck_pd.o\
+	phydm/phydm_rssi_monitor.o\
+	phydm/phydm_auto_dbg.o\
+	phydm/phydm_math_lib.o\
+	phydm/phydm_noisemonitor.o\
+	phydm/phydm_api.o\
+	phydm/phydm_pow_train.o\
+	phydm/txbf/phydm_hal_txbf_api.o\
+	EdcaTurboCheck.o\
+	phydm/halrf/halrf.o\
+	phydm/halrf/halphyrf_ap.o\
+	phydm/halrf/halrf_powertracking_ap.o\
+	phydm/halrf/halrf_powertracking.o\
+	phydm/halrf/halrf_kfree.o
+
+ifeq ($(CONFIG_RTL_88E_SUPPORT),y)
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8188e/halhwimg8188e_bb.o\
+		phydm/rtl8188e/halhwimg8188e_mac.o\
+		phydm/rtl8188e/halhwimg8188e_rf.o\
+		phydm/rtl8188e/phydm_regconfig8188e.o\
+		phydm/rtl8188e/hal8188erateadaptive.o\
+		phydm/rtl8188e/phydm_rtl8188e.o\
+		phydm/halrf/rtl8188e/halrf_8188e_ap.o
+	endif
+endif
+	
+ifeq ($(CONFIG_RTL_8812_SUPPORT),y)
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += ./phydm/halrf/rtl8812a/halrf_8812a_ap.o
+	endif
+endif
+	
+ifeq ($(CONFIG_WLAN_HAL_8881A),y)
+	_PHYDM_FILES += phydm/halrf/rtl8821a/halrf_iqk_8821a_ap.o
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8192EE),y)
+	_PHYDM_FILES += \
+	phydm/halrf/rtl8192e/halrf_8192e_ap.o\
+	phydm/rtl8192e/phydm_rtl8192e.o
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8814AE),y)
+	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_8814a_ap.o
+	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_iqk_8814a.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		rtl8192cd-objs += \
+		phydm/rtl8814a/halhwimg8814a_bb.o\
+		phydm/rtl8814a/halhwimg8814a_mac.o\
+		phydm/rtl8814a/halhwimg8814a_rf.o\
+		phydm/rtl8814a/phydm_regconfig8814a.o\
+		phydm/rtl8814a/phydm_rtl8814a.o			
+	endif
+endif
+	
+ifeq ($(CONFIG_WLAN_HAL_8822BE),y)
+	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_8822b.o
+	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_iqk_8822b.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8822b/halhwimg8822b_bb.o\
+		phydm/rtl8822b/halhwimg8822b_mac.o\
+		phydm/rtl8822b/halhwimg8822b_rf.o\
+		phydm/rtl8822b/phydm_regconfig8822b.o\
+		phydm/rtl8822b/phydm_hal_api8822b.o\
+		phydm/rtl8822b/phydm_rtl8822b.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8821CE),y)
+	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_8821c.o
+	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_iqk_8821c.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8821c/halhwimg8821c_bb.o\
+		phydm/rtl8821c/halhwimg8821c_mac.o\
+		phydm/rtl8821c/halhwimg8821c_rf.o\
+		phydm/rtl8821c/phydm_regconfig8821c.o\
+		phydm/rtl8821c/phydm_hal_api8821c.o
+	endif
+endif
+	
+ifeq ($(CONFIG_WLAN_HAL_8197F),y)
+		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_8197f.o
+		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_iqk_8197f.o
+		_PHYDM_FILES += efuse_97f/efuse.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8197f/halhwimg8197f_bb.o\
+		phydm/rtl8197f/halhwimg8197f_mac.o\
+		phydm/rtl8197f/halhwimg8197f_rf.o\
+		phydm/rtl8197f/phydm_hal_api8197f.o\
+		phydm/rtl8197f/phydm_regconfig8197f.o\
+		phydm/rtl8197f/phydm_rtl8197f.o
+	endif
+endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halhwimg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halhwimg.h
index a7155cbb85cc..27c5f486d4cb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halhwimg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halhwimg.h
@@ -1,124 +1,138 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#pragma once
-#ifndef __INC_HW_IMG_H
-#define __INC_HW_IMG_H
-
-//
-// 2011/03/15 MH Add for different IC HW image file selection. code size consideration.
-//
-#if RT_PLATFORM == PLATFORM_LINUX
-
-	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-	// For 92C
-	#define		RTL8192CE_HWIMG_SUPPORT					1
-	#define		RTL8192CE_TEST_HWIMG_SUPPORT			0
-	#define		RTL8192CU_HWIMG_SUPPORT					0
-	#define		RTL8192CU_TEST_HWIMG_SUPPORT			0
-
-	// For 92D
-	#define		RTL8192DE_HWIMG_SUPPORT					1
-	#define		RTL8192DE_TEST_HWIMG_SUPPORT			0
-	#define		RTL8192DU_HWIMG_SUPPORT					0
-	#define		RTL8192DU_TEST_HWIMG_SUPPORT			0
-
-	// For 8723
-	#define		RTL8723E_HWIMG_SUPPORT					1
-	#define		RTL8723U_HWIMG_SUPPORT					0
-	#define		RTL8723S_HWIMG_SUPPORT					0
-
-	//For 88E
-	#define		RTL8188EE_HWIMG_SUPPORT					0
-	#define		RTL8188EU_HWIMG_SUPPORT					0
-	#define		RTL8188ES_HWIMG_SUPPORT					0
-	
-	#elif (DEV_BUS_TYPE == RT_USB_INTERFACE)
-	// For 92C
-	#define 	RTL8192CE_HWIMG_SUPPORT 				0
-	#define 	RTL8192CE_TEST_HWIMG_SUPPORT			0
-	#define 	RTL8192CU_HWIMG_SUPPORT 				1
-	#define 	RTL8192CU_TEST_HWIMG_SUPPORT			0
-
-	//For 92D
-	#define 	RTL8192DE_HWIMG_SUPPORT 				0
-	#define 	RTL8192DE_TEST_HWIMG_SUPPORT			0
-	#define 	RTL8192DU_HWIMG_SUPPORT 				1
-	#define 	RTL8192DU_TEST_HWIMG_SUPPORT			0
-
-	// For 8723
-	#define 	RTL8723E_HWIMG_SUPPORT					0
-	#define 	RTL8723U_HWIMG_SUPPORT					1
-	#define 	RTL8723S_HWIMG_SUPPORT					0
-
-	//For 88E
-	#define		RTL8188EE_HWIMG_SUPPORT					0
-	#define		RTL8188EU_HWIMG_SUPPORT					0
-	#define		RTL8188ES_HWIMG_SUPPORT					0
-	
-	#elif (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
-	// For 92C
-	#define 	RTL8192CE_HWIMG_SUPPORT 				0
-	#define 	RTL8192CE_TEST_HWIMG_SUPPORT			0
-	#define 	RTL8192CU_HWIMG_SUPPORT 				1
-	#define 	RTL8192CU_TEST_HWIMG_SUPPORT			0
-
-	//For 92D
-	#define 	RTL8192DE_HWIMG_SUPPORT 				0
-	#define 	RTL8192DE_TEST_HWIMG_SUPPORT			0
-	#define 	RTL8192DU_HWIMG_SUPPORT 				1
-	#define 	RTL8192DU_TEST_HWIMG_SUPPORT			0
-
-	// For 8723
-	#define 	RTL8723E_HWIMG_SUPPORT					0
-	#define 	RTL8723U_HWIMG_SUPPORT					0
-	#define 	RTL8723S_HWIMG_SUPPORT					1
-
-	//For 88E
-	#define		RTL8188EE_HWIMG_SUPPORT					0
-	#define		RTL8188EU_HWIMG_SUPPORT					0
-	#define		RTL8188ES_HWIMG_SUPPORT					0
-	#endif
-
-#else	// PLATFORM_WINDOWS & MacOSX
-
-//For 92C
-#define		RTL8192CE_HWIMG_SUPPORT						1
-#define		RTL8192CE_TEST_HWIMG_SUPPORT				1
-#define		RTL8192CU_HWIMG_SUPPORT						1
-#define		RTL8192CU_TEST_HWIMG_SUPPORT				1
-
-// For 92D
-#define		RTL8192DE_HWIMG_SUPPORT					1
-#define		RTL8192DE_TEST_HWIMG_SUPPORT				1
-#define		RTL8192DU_HWIMG_SUPPORT					1
-#define		RTL8192DU_TEST_HWIMG_SUPPORT				1
-
-	#if defined(UNDER_CE)
-	// For 8723
-	#define		RTL8723E_HWIMG_SUPPORT					0
-	#define		RTL8723U_HWIMG_SUPPORT					0
-	#define		RTL8723S_HWIMG_SUPPORT					1
-
-	// For 88E
-	#define		RTL8188EE_HWIMG_SUPPORT					0
-	#define		RTL8188EU_HWIMG_SUPPORT					0
-	#define		RTL8188ES_HWIMG_SUPPORT					0
-
-	#else 
-
-	// For 8723
-	#define		RTL8723E_HWIMG_SUPPORT					1
-	//#define		RTL_8723E_TEST_HWIMG_SUPPORT			1
-	#define		RTL8723U_HWIMG_SUPPORT					1
-	//#define		RTL_8723U_TEST_HWIMG_SUPPORT			1
-	#define		RTL8723S_HWIMG_SUPPORT					1
-	//#define		RTL_8723S_TEST_HWIMG_SUPPORT			1
-
-	//For 88E
-	#define		RTL8188EE_HWIMG_SUPPORT					1
-	#define		RTL8188EU_HWIMG_SUPPORT					1
-	#define		RTL8188ES_HWIMG_SUPPORT					1
-	#endif
-
-#endif
-
-#endif //__INC_HW_IMG_H
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#pragma once
+#ifndef __INC_HW_IMG_H
+#define __INC_HW_IMG_H
+
+/*
+ * 2011/03/15 MH Add for different IC HW image file selection. code size consideration.
+ *   */
+#if RT_PLATFORM == PLATFORM_LINUX
+
+	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		/* For 92C */
+		#define		RTL8192CE_HWIMG_SUPPORT					1
+		#define		RTL8192CE_TEST_HWIMG_SUPPORT			0
+		#define		RTL8192CU_HWIMG_SUPPORT					0
+		#define		RTL8192CU_TEST_HWIMG_SUPPORT			0
+
+		/* For 92D */
+		#define		RTL8192DE_HWIMG_SUPPORT					1
+		#define		RTL8192DE_TEST_HWIMG_SUPPORT			0
+		#define		RTL8192DU_HWIMG_SUPPORT					0
+		#define		RTL8192DU_TEST_HWIMG_SUPPORT			0
+
+		/* For 8723 */
+		#define		RTL8723E_HWIMG_SUPPORT					1
+		#define		RTL8723U_HWIMG_SUPPORT					0
+		#define		RTL8723S_HWIMG_SUPPORT					0
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+
+	#elif (DEV_BUS_TYPE == RT_USB_INTERFACE)
+		/* For 92C */
+		#define	RTL8192CE_HWIMG_SUPPORT				0
+		#define	RTL8192CE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192CU_HWIMG_SUPPORT				1
+		#define	RTL8192CU_TEST_HWIMG_SUPPORT			0
+
+		/* For 92D */
+		#define	RTL8192DE_HWIMG_SUPPORT				0
+		#define	RTL8192DE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192DU_HWIMG_SUPPORT				1
+		#define	RTL8192DU_TEST_HWIMG_SUPPORT			0
+
+		/* For 8723 */
+		#define	RTL8723E_HWIMG_SUPPORT					0
+		#define	RTL8723U_HWIMG_SUPPORT					1
+		#define	RTL8723S_HWIMG_SUPPORT					0
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+
+	#elif (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+		/* For 92C */
+		#define	RTL8192CE_HWIMG_SUPPORT				0
+		#define	RTL8192CE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192CU_HWIMG_SUPPORT				1
+		#define	RTL8192CU_TEST_HWIMG_SUPPORT			0
+
+		/* For 92D */
+		#define	RTL8192DE_HWIMG_SUPPORT				0
+		#define	RTL8192DE_TEST_HWIMG_SUPPORT			0
+		#define	RTL8192DU_HWIMG_SUPPORT				1
+		#define	RTL8192DU_TEST_HWIMG_SUPPORT			0
+
+		/* For 8723 */
+		#define	RTL8723E_HWIMG_SUPPORT					0
+		#define	RTL8723U_HWIMG_SUPPORT					0
+		#define	RTL8723S_HWIMG_SUPPORT					1
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+	#endif
+
+#else	/* PLATFORM_WINDOWS & MacOSX */
+
+	/* For 92C */
+	#define		RTL8192CE_HWIMG_SUPPORT						1
+	#define		RTL8192CE_TEST_HWIMG_SUPPORT				1
+	#define		RTL8192CU_HWIMG_SUPPORT						1
+	#define		RTL8192CU_TEST_HWIMG_SUPPORT				1
+
+	/* For 92D */
+	#define		RTL8192DE_HWIMG_SUPPORT					1
+	#define		RTL8192DE_TEST_HWIMG_SUPPORT				1
+	#define		RTL8192DU_HWIMG_SUPPORT					1
+	#define		RTL8192DU_TEST_HWIMG_SUPPORT				1
+
+	#if defined(UNDER_CE)
+		/* For 8723 */
+		#define		RTL8723E_HWIMG_SUPPORT					0
+		#define		RTL8723U_HWIMG_SUPPORT					0
+		#define		RTL8723S_HWIMG_SUPPORT					1
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					0
+		#define		RTL8188EU_HWIMG_SUPPORT					0
+		#define		RTL8188ES_HWIMG_SUPPORT					0
+
+	#else
+
+		/* For 8723 */
+		#define		RTL8723E_HWIMG_SUPPORT					1
+		/* #define		RTL_8723E_TEST_HWIMG_SUPPORT			1 */
+		#define		RTL8723U_HWIMG_SUPPORT					1
+		/* #define		RTL_8723U_TEST_HWIMG_SUPPORT			1 */
+		#define		RTL8723S_HWIMG_SUPPORT					1
+		/* #define		RTL_8723S_TEST_HWIMG_SUPPORT			1 */
+
+		/* For 88E */
+		#define		RTL8188EE_HWIMG_SUPPORT					1
+		#define		RTL8188EU_HWIMG_SUPPORT					1
+		#define		RTL8188ES_HWIMG_SUPPORT					1
+	#endif
+
+#endif
+
+#endif /* __INC_HW_IMG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ap.c
deleted file mode 100644
index f9d60710d9fe..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ap.c
+++ /dev/null
@@ -1,2504 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
- #include "mp_precomp.h"
- #include "phydm_precomp.h"
-
-#ifndef index_mapping_NUM_88E
- #define	index_mapping_NUM_88E	15
-#endif
-
-//#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
-#define 	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _deltaThermal) \
-					do {\
-						for(_offset = 0; _offset < _size; _offset++)\
-						{\
-							if(_deltaThermal < thermalThreshold[_direction][_offset])\
-							{\
-								if(_offset != 0)\
-									_offset--;\
-								break;\
-							}\
-						}			\
-						if(_offset >= _size)\
-							_offset = _size-1;\
-					} while(0)
-
-
-void ConfigureTxpowerTrack(
-	IN	PVOID		pDM_VOID,
-	OUT	PTXPWRTRACK_CFG	pConfig
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if RTL8812A_SUPPORT
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	//if (IS_HARDWARE_TYPE_8812(pDM_Odm->Adapter))
-	if(pDM_Odm->SupportICType==ODM_RTL8812)
-		ConfigureTxpowerTrack_8812A(pConfig);
-	//else
-#endif
-#endif
-
-#if RTL8814A_SUPPORT
-	if(pDM_Odm->SupportICType== ODM_RTL8814A)
-		ConfigureTxpowerTrack_8814A(pConfig);
-#endif
-
-
-#if RTL8188E_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8188E)
-		ConfigureTxpowerTrack_8188E(pConfig);
-#endif 
-}
-
-#if (RTL8192E_SUPPORT==1) 
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter_92E(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	ThermalValue = 0, delta, delta_IQK, delta_LCK, channel, is_decrease, rf_mimo_mode;
-	u1Byte	ThermalValue_AVG_count = 0;
-    	u1Byte     OFDM_min_index = 10; //OFDM BB Swing should be less than +2.5dB, which is required by Arthur
-	s1Byte	OFDM_index[2], index ;
-    	u4Byte	ThermalValue_AVG = 0, Reg0x18;
-	u4Byte	i = 0, j = 0, rf;
-	s4Byte	value32, CCK_index = 0, ele_A, ele_D, ele_C, X, Y;
-	prtl8192cd_priv 	priv = pDM_Odm->priv;
-
-	rf_mimo_mode = pDM_Odm->RFType;
-	//ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("%s:%d rf_mimo_mode:%d\n", __FUNCTION__, __LINE__, rf_mimo_mode));
-
-#ifdef MP_TEST
-	if ((OPMODE & WIFI_MP_STATE) || priv->pshare->rf_ft_var.mp_specific) {
-		channel = priv->pshare->working_channel;
-		if (priv->pshare->mp_txpwr_tracking == FALSE)
-			return;
-	} else
-#endif
-	{
-		channel = (priv->pmib->dot11RFEntry.dot11channel);
-	}
-
-	ThermalValue = (unsigned char)ODM_GetRFReg(pDM_Odm, RF_PATH_A, ODM_RF_T_METER_92E, 0xfc00);	//0x42: RF Reg[15:10] 88E
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", ThermalValue, priv->pshare->ThermalValue, priv->pmib->dot11RFEntry.ther));
-
-
-	switch (rf_mimo_mode) {
-		case MIMO_1T1R:
-			rf = 1;      
-			break;
-		case MIMO_2T2R:
-			rf = 2;
-			break;
-		default:
-			rf = 2;
-			break;
-	}
-
-	//Query OFDM path A default setting 	Bit[31:21]
-	ele_D = PHY_QueryBBReg(priv, rOFDM0_XATxIQImbalance, bMaskOFDM_D);
-	for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
-		if (ele_D == (OFDMSwingTable_92E[i] >> 22)) {
-			OFDM_index[0] = (unsigned char)i;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("PathA 0xC80[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[0]));
-			break;
-		}
-	}
-
-	//Query OFDM path B default setting
-	if (rf_mimo_mode == MIMO_2T2R) {
-		ele_D = PHY_QueryBBReg(priv, rOFDM0_XBTxIQImbalance, bMaskOFDM_D);
-		for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
-			if (ele_D == (OFDMSwingTable_92E[i] >> 22)) {
-				OFDM_index[1] = (unsigned char)i;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("PathB 0xC88[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[1]));
-				break;
-			}
-		}
-	}
-
-	/* calculate average thermal meter */
-	{
-		priv->pshare->ThermalValue_AVG_88XX[priv->pshare->ThermalValue_AVG_index_88XX] = ThermalValue;
-		priv->pshare->ThermalValue_AVG_index_88XX++;
-		if (priv->pshare->ThermalValue_AVG_index_88XX == AVG_THERMAL_NUM_88XX)
-			priv->pshare->ThermalValue_AVG_index_88XX = 0;
-
-		for (i = 0; i < AVG_THERMAL_NUM_88XX; i++) {
-			if (priv->pshare->ThermalValue_AVG_88XX[i]) {
-				ThermalValue_AVG += priv->pshare->ThermalValue_AVG_88XX[i];
-				ThermalValue_AVG_count++;
-			}
-		}
-
-		if (ThermalValue_AVG_count) {
-			ThermalValue = (unsigned char)(ThermalValue_AVG / ThermalValue_AVG_count);
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("AVG Thermal Meter = 0x%x \n", ThermalValue));
-		}
-	}
-
-	/* Initialize */
-	if (!priv->pshare->ThermalValue) {
-		priv->pshare->ThermalValue = priv->pmib->dot11RFEntry.ther;
-		priv->pshare->ThermalValue_IQK = ThermalValue;
-		priv->pshare->ThermalValue_LCK = ThermalValue;
-	}
-
-	if (ThermalValue != priv->pshare->ThermalValue) {
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\n******** START POWER TRACKING ********\n")); 					
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", ThermalValue, priv->pshare->ThermalValue, priv->pmib->dot11RFEntry.ther)); 			
-
-		delta = RTL_ABS(ThermalValue, priv->pmib->dot11RFEntry.ther);
-		delta_IQK = RTL_ABS(ThermalValue, priv->pshare->ThermalValue_IQK);
-		delta_LCK = RTL_ABS(ThermalValue, priv->pshare->ThermalValue_LCK);
-		is_decrease = ((ThermalValue < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
-		
-#ifdef _TRACKING_TABLE_FILE
-		if (priv->pshare->rf_ft_var.pwr_track_file) {				
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("Diff: (%s)%d ==> get index from table : %d)\n", (is_decrease?"-":"+"), delta, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0)));
-        
-            	if (is_decrease) {					
-                	for (i = 0; i < rf; i++) {
-				OFDM_index[i] = priv->pshare->OFDM_index0[i] + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
-				OFDM_index[i] = ((OFDM_index[i] > (OFDM_TABLE_SIZE_92E- 1)) ? (OFDM_TABLE_SIZE_92E - 1) : OFDM_index[i]);
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0)));
-	                        CCK_index = priv->pshare->CCK_index0 + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);                        
-				CCK_index = ((CCK_index > (CCK_TABLE_SIZE_92E - 1)) ? (CCK_TABLE_SIZE_92E - 1) : CCK_index);				
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> Decrese power ---> new CCK_INDEX:%d (%d + %d)\n",  CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1)));
-			}
-		} else {
-			for (i = 0; i < rf; i++) {
-				OFDM_index[i] = priv->pshare->OFDM_index0[i] - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
-				OFDM_index[i] = ((OFDM_index[i] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[i]);
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> Increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0)));
-				CCK_index = priv->pshare->CCK_index0 - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);						  
-	                        CCK_index = ((CCK_index < 0 )? 0 : CCK_index);  
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> Increse power ---> new CCK_INDEX:%d (%d - %d)\n", CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1)));
-			}
-		}
-		}
-#endif //CFG_TRACKING_TABLE_FILE
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("OFDMSwingTable_92E[(unsigned int)OFDM_index[0]] = %x \n",OFDMSwingTable_92E[(unsigned int)OFDM_index[0]]));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("OFDMSwingTable_92E[(unsigned int)OFDM_index[1]] = %x \n",OFDMSwingTable_92E[(unsigned int)OFDM_index[1]]));
-
-		//Adujst OFDM Ant_A according to IQK result
-		ele_D = (OFDMSwingTable_92E[(unsigned int)OFDM_index[0]] & 0xFFC00000) >> 22;
-		X = priv->pshare->RegE94;
-		Y = priv->pshare->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;
-
-			//wirte new elements A, C, D to regC80 and regC94, element B is always 0
-			value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
-			PHY_SetBBReg(priv, rOFDM0_XATxIQImbalance, bMaskDWord, value32);
-
-			value32 = (ele_C&0x000003C0)>>6;
-			PHY_SetBBReg(priv, rOFDM0_XCTxAFE, bMaskH4Bits, value32);
-			
-			value32 = ((X * ele_D)>>7)&0x01;
-			PHY_SetBBReg(priv, rOFDM0_ECCAThreshold, BIT(24), value32);
-		} else {
-			PHY_SetBBReg(priv, rOFDM0_XATxIQImbalance, bMaskDWord, OFDMSwingTable_92E[(unsigned int)OFDM_index[0]]);
-			PHY_SetBBReg(priv, rOFDM0_XCTxAFE, bMaskH4Bits, 0x00);
-			PHY_SetBBReg(priv, rOFDM0_ECCAThreshold, BIT(24), 0x00);
-		}
-
-		set_CCK_swing_index(priv, CCK_index);
-
-		if (rf == 2) {
-			ele_D = (OFDMSwingTable_92E[(unsigned int)OFDM_index[1]] & 0xFFC00000) >> 22;
-			X = priv->pshare->RegEB4;
-			Y = priv->pshare->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;
-
-				//wirte new elements A, C, D to regC88 and regC9C, element B is always 0
-				value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
-				PHY_SetBBReg(priv, rOFDM0_XBTxIQImbalance, bMaskDWord, value32);
-				
-				value32 = (ele_C & 0x000003C0) >> 6;
-				PHY_SetBBReg(priv, rOFDM0_XDTxAFE, bMaskH4Bits, value32);
-
-				value32 = ((X * ele_D) >> 7) & 0x01;
-				PHY_SetBBReg(priv, rOFDM0_ECCAThreshold, BIT(28), value32);
-			} else {
-				PHY_SetBBReg(priv, rOFDM0_XBTxIQImbalance, bMaskDWord, OFDMSwingTable_92E[(unsigned int)OFDM_index[1]]);
-				PHY_SetBBReg(priv, rOFDM0_XDTxAFE, bMaskH4Bits, 0x00);
-				PHY_SetBBReg(priv, rOFDM0_ECCAThreshold, BIT(28), 0x00);
-			}
-
-		}
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("0xc80 = 0x%x \n", PHY_QueryBBReg(priv, rOFDM0_XATxIQImbalance, bMaskDWord)));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("0xc88 = 0x%x \n", PHY_QueryBBReg(priv, rOFDM0_XBTxIQImbalance, bMaskDWord)));
-
-		if (delta_IQK > 3) {
-			priv->pshare->ThermalValue_IQK = ThermalValue;
-#ifdef MP_TEST
-			if (!(priv->pshare->rf_ft_var.mp_specific && (OPMODE & (WIFI_MP_CTX_BACKGROUND | WIFI_MP_CTX_PACKET))))
-#endif	
-				PHY_IQCalibrate_8192E(pDM_Odm,false);
-		}
-
-		if (delta_LCK > 8) {
-			RTL_W8(0x522, 0xff);
-			Reg0x18 = PHY_QueryRFReg(priv, RF_PATH_A, 0x18, bMask20Bits, 1);
-			PHY_SetRFReg(priv, RF_PATH_A, 0xB4, BIT(14), 1);			
-			PHY_SetRFReg(priv, RF_PATH_A, 0x18, BIT(15), 1);
-			delay_ms(1);
-			PHY_SetRFReg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
-			PHY_SetRFReg(priv, RF_PATH_A, 0x18, bMask20Bits, Reg0x18);		
-			RTL_W8(0x522, 0x0);
-			priv->pshare->ThermalValue_LCK = ThermalValue;
-		}	
-	}
-
-	//update thermal meter value
-	priv->pshare->ThermalValue = ThermalValue;
-	for (i = 0 ; i < rf ; i++)
-		priv->pshare->OFDM_index[i] = OFDM_index[i];
-	priv->pshare->CCK_index = CCK_index;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,  ("\n******** END:%s() ********\n", __FUNCTION__));	
-}
-#endif
-
-#if (RTL8814A_SUPPORT ==1)					
-		
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries2(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			ThermalValue = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
-	u1Byte			ThermalValue_AVG_count = 0, p = 0, i = 0;
-	u4Byte			ThermalValue_AVG = 0, Reg0x18;
-	u4Byte 			BBSwingReg[4] = {rA_TxScale_Jaguar,rB_TxScale_Jaguar,rC_TxScale_Jaguar2,rD_TxScale_Jaguar2};
-	s4Byte			ele_D;
-	u4Byte			BBswingIdx;
-	prtl8192cd_priv	priv = pDM_Odm->priv;
-	TXPWRTRACK_CFG 	c;
-	BOOLEAN			bTSSIenable = FALSE;
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	//4 1. The following TWO tables decide the final index of OFDM/CCK swing table.
-	pu1Byte			deltaSwingTableIdx_TUP_A = NULL, deltaSwingTableIdx_TDOWN_A = NULL;
-	pu1Byte			deltaSwingTableIdx_TUP_B = NULL, deltaSwingTableIdx_TDOWN_B = NULL;
-	//for 8814 add by Yu Chen
-	pu1Byte			deltaSwingTableIdx_TUP_C = NULL, deltaSwingTableIdx_TDOWN_C = NULL;
-	pu1Byte			deltaSwingTableIdx_TUP_D = NULL, deltaSwingTableIdx_TDOWN_D = NULL;
-
-#ifdef MP_TEST
-	if ((OPMODE & WIFI_MP_STATE) || priv->pshare->rf_ft_var.mp_specific) {
-		channel = priv->pshare->working_channel;
-		if (priv->pshare->mp_txpwr_tracking == FALSE)
-			return;
-	} else
-#endif
-	{
-		channel = (priv->pmib->dot11RFEntry.dot11channel);
-	}
-
-	ConfigureTxpowerTrack(pDM_Odm, &c);
-	pRFCalibrateInfo->DefaultOfdmIndex = priv->pshare->OFDM_index0[ODM_RF_PATH_A];
-
-	(*c.GetDeltaSwingTable)(pDM_Odm, (pu1Byte*)&deltaSwingTableIdx_TUP_A, (pu1Byte*)&deltaSwingTableIdx_TDOWN_A,
-									  (pu1Byte*)&deltaSwingTableIdx_TUP_B, (pu1Byte*)&deltaSwingTableIdx_TDOWN_B);
-
-	if(pDM_Odm->SupportICType & ODM_RTL8814A)	// for 8814 path C & D
-	(*c.GetDeltaSwingTable8814only)(pDM_Odm, (pu1Byte*)&deltaSwingTableIdx_TUP_C, (pu1Byte*)&deltaSwingTableIdx_TDOWN_C,
-									  (pu1Byte*)&deltaSwingTableIdx_TUP_D, (pu1Byte*)&deltaSwingTableIdx_TDOWN_D);
-	
-	ThermalValue = (u1Byte)ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, c.ThermalRegAddr, 0xfc00); //0x42: RF Reg[15:10] 88E
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("\nReadback Thermal Meter = 0x%x, pre thermal meter 0x%x, EEPROMthermalmeter 0x%x\n", ThermalValue, pDM_Odm->RFCalibrateInfo.ThermalValue, priv->pmib->dot11RFEntry.ther));
-
-	/* Initialize */
-	if (!pDM_Odm->RFCalibrateInfo.ThermalValue) {
-		pDM_Odm->RFCalibrateInfo.ThermalValue = priv->pmib->dot11RFEntry.ther;
-	}
-	
-	if (!pDM_Odm->RFCalibrateInfo.ThermalValue_LCK) {
-		pDM_Odm->RFCalibrateInfo.ThermalValue_LCK = priv->pmib->dot11RFEntry.ther;
-	}
-
-	if (!pDM_Odm->RFCalibrateInfo.ThermalValue_IQK) {
-		pDM_Odm->RFCalibrateInfo.ThermalValue_IQK = priv->pmib->dot11RFEntry.ther;
-	}
-	
-	bTSSIenable = (BOOLEAN)ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, rRF_TxGainOffset, BIT7);	// check TSSI enable
-	
-	//4 Query OFDM BB swing default setting 	Bit[31:21]	
-	for(p = ODM_RF_PATH_A ; p < c.RfPathCount ; p++)
-	{
-		ele_D = ODM_GetBBReg(pDM_Odm, BBSwingReg[p], 0xffe00000);	
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("0x%x:0x%x ([31:21] = 0x%x)\n", BBSwingReg[p], ODM_GetBBReg(pDM_Odm, BBSwingReg[p], bMaskDWord), ele_D));
-		
-		for (BBswingIdx = 0; BBswingIdx < TXSCALE_TABLE_SIZE; BBswingIdx++) {//4 
-			if (ele_D == TxScalingTable_Jaguar[BBswingIdx]) {
-				pDM_Odm->RFCalibrateInfo.OFDM_index[p] = (u1Byte)BBswingIdx;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("OFDM_index[%d]=%d\n",p, pDM_Odm->RFCalibrateInfo.OFDM_index[p]));				
-				break;
-			}
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("KfreeOffset[%d]=%d\n",p, pRFCalibrateInfo->KfreeOffset[p]));
-		
-	}
-
-	/* calculate average thermal meter */
-	pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index] = ThermalValue;
-	pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index++;
-	if(pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index == c.AverageThermalNum)   //Average times =  c.AverageThermalNum
-		pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index = 0;
-
-	for(i = 0; i < c.AverageThermalNum; i++)
-	{
-		if(pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[i])
-		{
-			ThermalValue_AVG += pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[i];
-			ThermalValue_AVG_count++;
-		}
-	}
-
-	if(ThermalValue_AVG_count)               //Calculate Average ThermalValue after average enough times
-	{
-		ThermalValue = (u1Byte)(ThermalValue_AVG / ThermalValue_AVG_count);
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X, EEPROMthermalmeter = 0x%X\n", ThermalValue, priv->pmib->dot11RFEntry.ther));					
-	}
-
-	//4 Calculate delta, delta_LCK, delta_IQK.
-	delta = RTL_ABS(ThermalValue, priv->pmib->dot11RFEntry.ther);	
-	delta_LCK = RTL_ABS(ThermalValue, pDM_Odm->RFCalibrateInfo.ThermalValue_LCK);
-	delta_IQK = RTL_ABS(ThermalValue, pDM_Odm->RFCalibrateInfo.ThermalValue_IQK);
-	is_increase = ((ThermalValue < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
-
-	//4 if necessary, do LCK.
-	if (!(pDM_Odm->SupportICType & ODM_RTL8821)) {
-		if (delta_LCK > c.Threshold_IQK) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_LCK(%d) >= Threshold_IQK(%d)\n", delta_LCK, c.Threshold_IQK));
-			pDM_Odm->RFCalibrateInfo.ThermalValue_LCK = ThermalValue;
-			if (c.PHY_LCCalibrate)
-				(*c.PHY_LCCalibrate)(pDM_Odm);
-		}
-	}
-
-	if (delta_IQK > c.Threshold_IQK) 
-	{
-		panic_printk("%s(%d)\n", __FUNCTION__, __LINE__);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_IQK(%d) >= Threshold_IQK(%d)\n", delta_IQK, c.Threshold_IQK));
-		pDM_Odm->RFCalibrateInfo.ThermalValue_IQK = ThermalValue;
-		if(c.DoIQK)
-			(*c.DoIQK)(pDM_Odm, TRUE, 0, 0);
-	} 
-
-	if(!priv->pmib->dot11RFEntry.ther)	/*Don't do power tracking since no calibrated thermal value*/
-		return;
-	
-	 //4 Do Power Tracking
-
-	 if(bTSSIenable == TRUE)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("**********Enter PURE TSSI MODE**********\n"));
-		for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-			(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, TSSI_MODE, p, 0);
-	}
-	else if (ThermalValue != pDM_Odm->RFCalibrateInfo.ThermalValue)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("\n******** START POWER TRACKING ********\n")); 					
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", ThermalValue, pDM_Odm->RFCalibrateInfo.ThermalValue, priv->pmib->dot11RFEntry.ther)); 			
-				
-#ifdef _TRACKING_TABLE_FILE
-		if (priv->pshare->rf_ft_var.pwr_track_file)
-		{				
-			if (is_increase)			// thermal is higher than base
-			{
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 
-				{
-					switch(p)
-					{
-					case ODM_RF_PATH_B:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("deltaSwingTableIdx_TUP_B[%d] = %d\n", delta, deltaSwingTableIdx_TUP_B[delta])); 						
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = deltaSwingTableIdx_TUP_B[delta];       // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_B] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					case ODM_RF_PATH_C:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("deltaSwingTableIdx_TUP_C[%d] = %d\n", delta, deltaSwingTableIdx_TUP_C[delta]));								
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = deltaSwingTableIdx_TUP_C[delta];       // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_C] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					case ODM_RF_PATH_D:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("deltaSwingTableIdx_TUP_D[%d] = %d\n", delta, deltaSwingTableIdx_TUP_D[delta]));							
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = deltaSwingTableIdx_TUP_D[delta];       // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_D] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					default:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, 
-							("deltaSwingTableIdx_TUP_A[%d] = %d\n", delta, deltaSwingTableIdx_TUP_A[delta]));						
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = deltaSwingTableIdx_TUP_A[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_A] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-					}		
-				}
-			}
-			else					// thermal is lower than base
-			{
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 
-				{
-					switch(p)
-					{
-					case ODM_RF_PATH_B:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("deltaSwingTableIdx_TDOWN_B[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_B[delta]));  
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = -1 * deltaSwingTableIdx_TDOWN_B[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_B] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p])); 
-					break;
-
-					case ODM_RF_PATH_C:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("deltaSwingTableIdx_TDOWN_C[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_C[delta]));  
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = -1 * deltaSwingTableIdx_TDOWN_C[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_C] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));   
-					break;
-
-					case ODM_RF_PATH_D:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("deltaSwingTableIdx_TDOWN_D[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_D[delta]));  
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = -1 * deltaSwingTableIdx_TDOWN_D[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_D] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					default:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("deltaSwingTableIdx_TDOWN_A[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_A[delta]));  
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = -1 * deltaSwingTableIdx_TDOWN_A[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_A] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-					}		
-				}
-			}
-				
-			if (is_increase)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> increse power ---> \n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 
-				(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, MIX_MODE, p, 0);
-			} 
-			else
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> decrese power --->\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 
-				(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, MIX_MODE, p, 0);
-			}
-		}
-#endif		
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\n******** END:%s() ********\n", __FUNCTION__));
-	//update thermal meter value
-	pDM_Odm->RFCalibrateInfo.ThermalValue =  ThermalValue;
-
-	}
-}
-
-#elif(ODM_IC_11AC_SERIES_SUPPORT)
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	unsigned char			ThermalValue = 0, delta, delta_LCK, channel, is_decrease;
-	unsigned char			ThermalValue_AVG_count = 0;
-	unsigned int			ThermalValue_AVG = 0, Reg0x18;
-	unsigned int 			BBSwingReg[4]={0xc1c,0xe1c,0x181c,0x1a1c};
-	int 					ele_D, value32;
-	char					OFDM_index[2], index;
-	unsigned int			i = 0, j = 0, rf_path, max_rf_path =2 ,rf;
-	prtl8192cd_priv		priv = pDM_Odm->priv;
-	unsigned char			OFDM_min_index = 7; //OFDM BB Swing should be less than +2.5dB, which is required by Arthur and Mimic
-
-#ifdef MP_TEST
-	if ((OPMODE & WIFI_MP_STATE) || priv->pshare->rf_ft_var.mp_specific) {
-		channel = priv->pshare->working_channel;
-		if (priv->pshare->mp_txpwr_tracking == FALSE)
-			return;
-	} else
-#endif
-	{
-		channel = (priv->pmib->dot11RFEntry.dot11channel);
-	}
-
-#if RTL8881A_SUPPORT
-	if (pDM_Odm->SupportICType == ODM_RTL8881A) {
-		max_rf_path = 1;
-		if ((get_bonding_type_8881A() == BOND_8881AM ||get_bonding_type_8881A() == BOND_8881AN) 			
-			&& priv->pshare->rf_ft_var.use_intpa8881A && (priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_2G))			
-			OFDM_min_index = 6;		// intPA - upper bond set to +3 dB (base: -2 dB)ot11RFEntry.phyBandSelect == PHY_BAND_2G))
-		else
-			OFDM_min_index = 10;		//OFDM BB Swing should be less than +1dB, which is required by Arthur and Mimic
-	}
-#endif
-
-
-	ThermalValue = (unsigned char)PHY_QueryRFReg(priv, RF_PATH_A, 0x42, 0xfc00, 1); //0x42: RF Reg[15:10] 88E
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", ThermalValue, priv->pshare->ThermalValue, priv->pmib->dot11RFEntry.ther));
-
-
-	//4 Query OFDM BB swing default setting 	Bit[31:21]
-	for(rf_path = 0 ; rf_path < max_rf_path ; rf_path++){
-		ele_D = PHY_QueryBBReg(priv, BBSwingReg[rf_path], 0xffe00000);	
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("0x%x:0x%x ([31:21] = 0x%x)\n",BBSwingReg[rf_path], PHY_QueryBBReg(priv, BBSwingReg[rf_path], bMaskDWord),ele_D)); 			
-		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {//4 
-			if (ele_D == OFDMSwingTable_8812[i]) {
-				OFDM_index[rf_path] = (unsigned char)i;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("OFDM_index[%d]=%d\n",rf_path, OFDM_index[rf_path]));				
-				break;
-			}
-		}
-	}
-#if 0	
-	//Query OFDM path A default setting 	Bit[31:21]
-	ele_D = PHY_QueryBBReg(priv, 0xc1c, 0xffe00000);	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("0xc1c:0x%x ([31:21] = 0x%x)\n", PHY_QueryBBReg(priv, 0xc1c, bMaskDWord),ele_D)); 			
-	for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {//4 
-		if (ele_D == OFDMSwingTable_8812[i]) {
-			OFDM_index[0] = (unsigned char)i;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("OFDM_index[0]=%d\n", OFDM_index[0]));				
-			break;
-		}
-	}
-	//Query OFDM path B default setting
-	if (rf == 2) {
-		ele_D = PHY_QueryBBReg(priv, 0xe1c, 0xffe00000);		
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("0xe1c:0x%x ([32:21] = 0x%x)\n", PHY_QueryBBReg(priv, 0xe1c, bMaskDWord),ele_D)); 			
-		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {
-			if (ele_D == OFDMSwingTable_8812[i]) {
-				OFDM_index[1] = (unsigned char)i;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("OFDM_index[1]=%d\n", OFDM_index[1])); 			
-				break;
-			}
-		}
-	}
-#endif
-	/* Initialize */
-	if (!priv->pshare->ThermalValue) {
-		priv->pshare->ThermalValue = priv->pmib->dot11RFEntry.ther;
-		priv->pshare->ThermalValue_LCK = ThermalValue;
-	}
-
-	/* calculate average thermal meter */
-	{
-		priv->pshare->ThermalValue_AVG_8812[priv->pshare->ThermalValue_AVG_index_8812] = ThermalValue;
-		priv->pshare->ThermalValue_AVG_index_8812++;
-		if (priv->pshare->ThermalValue_AVG_index_8812 == AVG_THERMAL_NUM_8812)
-			priv->pshare->ThermalValue_AVG_index_8812 = 0;
-
-		for (i = 0; i < AVG_THERMAL_NUM_8812; i++) {
-			if (priv->pshare->ThermalValue_AVG_8812[i]) {
-				ThermalValue_AVG += priv->pshare->ThermalValue_AVG_8812[i];
-				ThermalValue_AVG_count++;
-			}
-		}
-
-		if (ThermalValue_AVG_count) {
-			ThermalValue = (unsigned char)(ThermalValue_AVG / ThermalValue_AVG_count);
-			//printk("AVG Thermal Meter = 0x%x \n", ThermalValue);
-		}
-	}
-	
-
-	//4 If necessary,  do power tracking
-
-	if(!priv->pmib->dot11RFEntry.ther) /*Don't do power tracking since no calibrated thermal value*/
-		return;  
-
-	if (ThermalValue != priv->pshare->ThermalValue) {
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\n******** START POWER TRACKING ********\n")); 					
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", ThermalValue, priv->pshare->ThermalValue, priv->pmib->dot11RFEntry.ther)); 			
-		delta = RTL_ABS(ThermalValue, priv->pmib->dot11RFEntry.ther);
-		delta_LCK = RTL_ABS(ThermalValue, priv->pshare->ThermalValue_LCK);
-		is_decrease = ((ThermalValue < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
-		//if (priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_5G) 
-		{
-#ifdef _TRACKING_TABLE_FILE
-			if (priv->pshare->rf_ft_var.pwr_track_file) {				
-				for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("Diff: (%s)%d ==> get index from table : %d)\n", (is_decrease?"-":"+"), delta, get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0)));
-					if (is_decrease) {
-						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] + get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
-						OFDM_index[rf_path] = ((OFDM_index[rf_path] > (OFDM_TABLE_SIZE_8812 - 1)) ? (OFDM_TABLE_SIZE_8812 - 1) : OFDM_index[rf_path]);
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0)));
-#if 0// RTL8881A_SUPPORT
-						if (pDM_Odm->SupportICType == ODM_RTL8881A){
-							if(priv->pshare->rf_ft_var.pwrtrk_TxAGC_enable){
-								if(priv->pshare->AddTxAGC){//TxAGC has been added
-									AddTxPower88XX_AC(priv,0); 
-									priv->pshare->AddTxAGC = 0;
-									priv->pshare->AddTxAGC_index = 0;
-								}
-							}
-						}
-#endif				
-					} else {
-
-						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] - get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
-#if 0// RTL8881A_SUPPORT
-						if(pDM_Odm->SupportICType == ODM_RTL8881A){ 
-							if(priv->pshare->rf_ft_var.pwrtrk_TxAGC_enable){
-								if(OFDM_index[i] < OFDM_min_index){
-									priv->pshare->AddTxAGC_index = (OFDM_min_index - OFDM_index[i])/2;  // Calculate Remnant TxAGC Value,  2 index for 1 TxAGC 
-									AddTxPower88XX_AC(priv,priv->pshare->AddTxAGC_index);
-									priv->pshare->AddTxAGC = 1;     //AddTxAGC Flag = 1
-									OFDM_index[i] = OFDM_min_index;
-								}
-								else{
-									if(priv->pshare->AddTxAGC){// TxAGC been added
-										priv->pshare->AddTxAGC = 0;
-										priv->pshare->AddTxAGC_index = 0;
-										AddTxPower88XX_AC(priv,0); //minus the added TPI
-									}
-								}
-							}
-						}
-#else
-						OFDM_index[rf_path] = ((OFDM_index[rf_path] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[rf_path]);
-#endif
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,(">>> increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0)));
-					}
-				}
-			}
-#endif
-			//4 Set new BB swing index
-			for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
-				PHY_SetBBReg(priv, BBSwingReg[rf_path], 0xffe00000, OFDMSwingTable_8812[(unsigned int)OFDM_index[rf_path]]);
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("Readback 0x%x[31:21] = 0x%x, OFDM_index:%d\n",BBSwingReg[rf_path], PHY_QueryBBReg(priv, BBSwingReg[rf_path], 0xffe00000), OFDM_index[rf_path]));				
-			}
-
-		}
-		if (delta_LCK > 8) {
-			RTL_W8(0x522, 0xff);
-			Reg0x18 = PHY_QueryRFReg(priv, RF_PATH_A, 0x18, bMask20Bits, 1);
-			PHY_SetRFReg(priv, RF_PATH_A, 0xB4, BIT(14), 1);			
-			PHY_SetRFReg(priv, RF_PATH_A, 0x18, BIT(15), 1);
-            delay_ms(200); // frequency deviation
-			PHY_SetRFReg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
-			PHY_SetRFReg(priv, RF_PATH_A, 0x18, bMask20Bits, Reg0x18);
-			#ifdef CONFIG_RTL_8812_SUPPORT
-			if (GET_CHIP_VER(priv)== VERSION_8812E)			
-				UpdateBBRFVal8812(priv, priv->pmib->dot11RFEntry.dot11channel);	
-			#endif
-			RTL_W8(0x522, 0x0);
-			priv->pshare->ThermalValue_LCK = ThermalValue;
-		}	
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("\n******** END:%s() ********\n", __FUNCTION__));
-
-		//update thermal meter value
-		priv->pshare->ThermalValue = ThermalValue;
-		for (rf_path = 0; rf_path < max_rf_path; rf_path++)
-			priv->pshare->OFDM_index[rf_path] = OFDM_index[rf_path];
-	}
-}
-
-#endif
-
-
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-#if (RTL8814A_SUPPORT == 1)		//use this function to do power tracking after 8814 by YuChen
-	if (pDM_Odm->SupportICType & ODM_RTL8814A) {
-		ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries2(pDM_Odm);
-		return;
-		}
-#elif ODM_IC_11AC_SERIES_SUPPORT
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) {
-		ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries(pDM_Odm);
-		return;
-	}
-#endif
-
-#if (RTL8192E_SUPPORT == 1)
-	if (pDM_Odm->SupportICType==ODM_RTL8192E) {
-		ODM_TXPowerTrackingCallback_ThermalMeter_92E(pDM_Odm);
-		return;
-	}
-#endif
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	//PMGNT_INFO      		pMgntInfo = &Adapter->MgntInfo;
-#endif
-	
-	u1Byte			ThermalValue = 0, delta, delta_LCK, delta_IQK, offset;
-	u1Byte			ThermalValue_AVG_count = 0;
-	u4Byte			ThermalValue_AVG = 0;	
-//	s4Byte			ele_A=0, ele_D, TempCCk, X, value32;
-//	s4Byte			Y, ele_C=0;
-//	s1Byte			OFDM_index[2], CCK_index=0, OFDM_index_old[2]={0,0}, CCK_index_old=0, index;
-//	s1Byte			deltaPowerIndex = 0;
-	u4Byte			i = 0;//, j = 0;
-	BOOLEAN 		is2T = FALSE;
-//	BOOLEAN 		bInteralPA = FALSE;
-
-	u1Byte			OFDM_max_index = 34, rf = (is2T) ? 2 : 1; //OFDM BB Swing should be less than +3.0dB, which is required by Arthur
-	u1Byte			Indexforchannel = 0;/*GetRightChnlPlaceforIQK(pHalData->CurrentChannel)*/
-    enum            _POWER_DEC_INC { POWER_DEC, POWER_INC };
-	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	#endif
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	#endif
-
-	TXPWRTRACK_CFG 	c;
-
-
-	//4 1. The following TWO tables decide the final index of OFDM/CCK swing table.
-	s1Byte			deltaSwingTableIdx[2][index_mapping_NUM_88E] = { 
-                        // {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}}
-                        {0,0,2,3,4,4,5,6,7,7,8,9,10,10,11}, {0,0,1,2,3,4,4,4,4,5,7,8,9,9,10}
-                    };	
-	u1Byte			thermalThreshold[2][index_mapping_NUM_88E]={
-                        // {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}}
-					    {0,2,4,6,8,10,12,14,16,18,20,22,24,26,27}, {0,2,4,6,8,10,12,14,16,18,20,22,25,25,25}
-                    };		
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	prtl8192cd_priv	priv = pDM_Odm->priv;
-#endif	
-
-	//4 2. Initilization ( 7 steps in total )
-
-	ConfigureTxpowerTrack(pDM_Odm, &c);
-	
-	pDM_Odm->RFCalibrateInfo.TXPowerTrackingCallbackCnt++; //cosa add for debug
-	pDM_Odm->RFCalibrateInfo.bTXPowerTrackingInit = TRUE;
-    
-#if (MP_DRIVER == 1)      
-    pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = pHalData->TxPowerTrackControl; // <Kordan> We should keep updating the control variable according to HalData.
-    // <Kordan> RFCalibrateInfo.RegA24 will be initialized when ODM HW configuring, but MP configures with para files.
-    pDM_Odm->RFCalibrateInfo.RegA24 = 0x090e1317; 
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP) && defined(MP_TEST)
-	if ((OPMODE & WIFI_MP_STATE) || pDM_Odm->priv->pshare->rf_ft_var.mp_specific) {
-		if(pDM_Odm->priv->pshare->mp_txpwr_tracking == FALSE)
-			return;
-	}
-#endif
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("===>odm_TXPowerTrackingCallback_ThermalMeter_8188E, pDM_Odm->BbSwingIdxCckBase: %d, pDM_Odm->BbSwingIdxOfdmBase: %d \n", pRFCalibrateInfo->BbSwingIdxCckBase, pRFCalibrateInfo->BbSwingIdxOfdmBase));
-/*
-	if (!pDM_Odm->RFCalibrateInfo.TM_Trigger) {
-		ODM_SetRFReg(pDM_Odm, RF_PATH_A, c.ThermalRegAddr, BIT17 | BIT16, 0x3);
-		pDM_Odm->RFCalibrateInfo.TM_Trigger = 1;
-		return;
-	}
-*/	
-	ThermalValue = (u1Byte)ODM_GetRFReg(pDM_Odm, RF_PATH_A, c.ThermalRegAddr, 0xfc00);	//0x42: RF Reg[15:10] 88E
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	if( ! ThermalValue || ! pDM_Odm->RFCalibrateInfo.TxPowerTrackControl)
-#else
-	if( ! pDM_Odm->RFCalibrateInfo.TxPowerTrackControl)
-#endif		
-        return;
-
-	//4 3. Initialize ThermalValues of RFCalibrateInfo
-	
-	if( ! pDM_Odm->RFCalibrateInfo.ThermalValue)
-	{
-		pDM_Odm->RFCalibrateInfo.ThermalValue_LCK = ThermalValue;				
-		pDM_Odm->RFCalibrateInfo.ThermalValue_IQK = ThermalValue;										
-	}			
-
-	if(pDM_Odm->RFCalibrateInfo.bReloadtxpowerindex)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("reload ofdm index for band switch\n"));				
-	}
-
-	//4 4. Calculate average thermal meter
-	
-	pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index] = ThermalValue;
-	pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index++;
-	if(pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index == c.AverageThermalNum)
-		pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index = 0;
-
-	for(i = 0; i < c.AverageThermalNum; i++)
-	{
-		if(pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[i])
-		{
-			ThermalValue_AVG += pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[i];
-			ThermalValue_AVG_count++;
-		}
-	}
-
-	if(ThermalValue_AVG_count)
-	{
-		// Give the new thermo value a weighting
-		ThermalValue_AVG += (ThermalValue*4);
-		
-		ThermalValue = (u1Byte)(ThermalValue_AVG / (ThermalValue_AVG_count+4));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("AVG Thermal Meter = 0x%x \n", ThermalValue));					
-	}
-			
-	//4 5. Calculate delta, delta_LCK, delta_IQK.
-	
-	delta 	  = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue):(pDM_Odm->RFCalibrateInfo.ThermalValue - ThermalValue);
-	delta_LCK = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue_LCK)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue_LCK):(pDM_Odm->RFCalibrateInfo.ThermalValue_LCK - ThermalValue);
-	delta_IQK = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue_IQK)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue_IQK):(pDM_Odm->RFCalibrateInfo.ThermalValue_IQK - ThermalValue);
-		
-	//4 6. If necessary, do LCK.	
-	if (!(pDM_Odm->SupportICType & ODM_RTL8821)) {
-	/*if((delta_LCK > pHalData->Delta_LCK) && (pHalData->Delta_LCK != 0))*/
-		if (delta_LCK >= c.Threshold_IQK) { 
-			/*Delta temperature is equal to or larger than 20 centigrade.*/
-			pDM_Odm->RFCalibrateInfo.ThermalValue_LCK = ThermalValue;
-			(*c.PHY_LCCalibrate)(pDM_Odm);
-		}
-	}
-
-	//3 7. If necessary, move the index of swing table to adjust Tx power.	
-	
-	if (delta > 0 && pDM_Odm->RFCalibrateInfo.TxPowerTrackControl)
-	{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))			
-	    delta = ThermalValue > pHalData->EEPROMThermalMeter?(ThermalValue - pHalData->EEPROMThermalMeter):(pHalData->EEPROMThermalMeter - ThermalValue);		
-#else
-	    delta = (ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther)?(ThermalValue - pDM_Odm->priv->pmib->dot11RFEntry.ther):(pDM_Odm->priv->pmib->dot11RFEntry.ther - ThermalValue);		
-#endif
-
-
-		//4 7.1 The Final Power Index = BaseIndex + PowerIndexOffset
-		
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))				
-		if(ThermalValue > pHalData->EEPROMThermalMeter) {
-#else
-		if(ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther) {
-#endif
-			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_INC, index_mapping_NUM_88E, delta);
-			pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast = pDM_Odm->RFCalibrateInfo.DeltaPowerIndex;
-			pDM_Odm->RFCalibrateInfo.DeltaPowerIndex =  deltaSwingTableIdx[POWER_INC][offset];
-
-        } else {
-        
-			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_DEC, index_mapping_NUM_88E, delta);
-			pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast = pDM_Odm->RFCalibrateInfo.DeltaPowerIndex;
-			pDM_Odm->RFCalibrateInfo.DeltaPowerIndex = (-1)*deltaSwingTableIdx[POWER_DEC][offset];
-        }
-		
-		if (pDM_Odm->RFCalibrateInfo.DeltaPowerIndex == pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast)
-			pDM_Odm->RFCalibrateInfo.PowerIndexOffset = 0;
-		else
-			pDM_Odm->RFCalibrateInfo.PowerIndexOffset = pDM_Odm->RFCalibrateInfo.DeltaPowerIndex - pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast;
-		
-	    for(i = 0; i < rf; i++) 		
-	    	pDM_Odm->RFCalibrateInfo.OFDM_index[i] = pRFCalibrateInfo->BbSwingIdxOfdmBase + pDM_Odm->RFCalibrateInfo.PowerIndexOffset;
-		pDM_Odm->RFCalibrateInfo.CCK_index = pRFCalibrateInfo->BbSwingIdxCckBase + pDM_Odm->RFCalibrateInfo.PowerIndexOffset;
-
-		pRFCalibrateInfo->BbSwingIdxCck = pDM_Odm->RFCalibrateInfo.CCK_index;	
-		pRFCalibrateInfo->BbSwingIdxOfdm[RF_PATH_A] = pDM_Odm->RFCalibrateInfo.OFDM_index[RF_PATH_A];	
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("The 'CCK' final index(%d) = BaseIndex(%d) + PowerIndexOffset(%d)\n", pRFCalibrateInfo->BbSwingIdxCck, pRFCalibrateInfo->BbSwingIdxCckBase, pDM_Odm->RFCalibrateInfo.PowerIndexOffset));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("The 'OFDM' final index(%d) = BaseIndex(%d) + PowerIndexOffset(%d)\n", pRFCalibrateInfo->BbSwingIdxOfdm[RF_PATH_A], pRFCalibrateInfo->BbSwingIdxOfdmBase, pDM_Odm->RFCalibrateInfo.PowerIndexOffset));
-
-		//4 7.1 Handle boundary conditions of index.
-		
-		
-		for(i = 0; i < rf; i++)
-		{
-			if(pDM_Odm->RFCalibrateInfo.OFDM_index[i] > OFDM_max_index)
-			{
-				pDM_Odm->RFCalibrateInfo.OFDM_index[i] = OFDM_max_index;
-			}
-			else if (pDM_Odm->RFCalibrateInfo.OFDM_index[i] < 0)
-			{
-				pDM_Odm->RFCalibrateInfo.OFDM_index[i] = 0;
-			}
-		}
-
-		if(pDM_Odm->RFCalibrateInfo.CCK_index > c.SwingTableSize_CCK-1)
-			pDM_Odm->RFCalibrateInfo.CCK_index = c.SwingTableSize_CCK-1;
-		else if (pDM_Odm->RFCalibrateInfo.CCK_index < 0)
-			pDM_Odm->RFCalibrateInfo.CCK_index = 0;
-	}
-	else
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("The thermal meter is unchanged or TxPowerTracking OFF: ThermalValue: %d , pDM_Odm->RFCalibrateInfo.ThermalValue: %d)\n", ThermalValue, pDM_Odm->RFCalibrateInfo.ThermalValue));
-		pDM_Odm->RFCalibrateInfo.PowerIndexOffset = 0;
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("TxPowerTracking: [CCK] Swing Current Index: %d, Swing Base Index: %d\n", pDM_Odm->RFCalibrateInfo.CCK_index, pRFCalibrateInfo->BbSwingIdxCckBase));
-				
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("TxPowerTracking: [OFDM] Swing Current Index: %d, Swing Base Index: %d\n", pDM_Odm->RFCalibrateInfo.OFDM_index[RF_PATH_A], pRFCalibrateInfo->BbSwingIdxOfdmBase));
-	
-	if (pDM_Odm->RFCalibrateInfo.PowerIndexOffset != 0 && pDM_Odm->RFCalibrateInfo.TxPowerTrackControl)
-	{
-		//4 7.2 Configure the Swing Table to adjust Tx Power.
-		
-			pDM_Odm->RFCalibrateInfo.bTxPowerChanged = TRUE; // Always TRUE after Tx Power is adjusted by power tracking.			
-			//
-			// 2012/04/23 MH According to Luke's suggestion, we can not write BB digital
-			// to increase TX power. Otherwise, EVM will be bad.
-			//
-			// 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E.
-			if (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue)
-			{
-				//ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				//	("Temperature Increasing: delta_pi: %d , delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", 
-				//	pDM_Odm->RFCalibrateInfo.PowerIndexOffset, delta, ThermalValue, pHalData->EEPROMThermalMeter, pDM_Odm->RFCalibrateInfo.ThermalValue));	
-			}
-			else if (ThermalValue < pDM_Odm->RFCalibrateInfo.ThermalValue)// Low temperature
-			{
-				//ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				//	("Temperature Decreasing: delta_pi: %d , delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-				//		pDM_Odm->RFCalibrateInfo.PowerIndexOffset, delta, ThermalValue, pHalData->EEPROMThermalMeter, pDM_Odm->RFCalibrateInfo.ThermalValue));				
-			}
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			if (ThermalValue > pHalData->EEPROMThermalMeter)
-#else
-			if (ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther)
-#endif
-			{
-//				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("Temperature(%d) hugher than PG value(%d), increases the power by TxAGC\n", ThermalValue, pHalData->EEPROMThermalMeter));
-				(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, TXAGC, 0, 0);							
-			}
-			else
-			{
-	//			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("Temperature(%d) lower than PG value(%d), increases the power by TxAGC\n", ThermalValue, pHalData->EEPROMThermalMeter));
-				(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, RF_PATH_A, Indexforchannel);	
-				if(is2T)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, RF_PATH_B, Indexforchannel);				
-			}
-			
-			pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->BbSwingIdxCck;
-			pRFCalibrateInfo->BbSwingIdxOfdmBase = pRFCalibrateInfo->BbSwingIdxOfdm[RF_PATH_A];
-			pDM_Odm->RFCalibrateInfo.ThermalValue = ThermalValue;
-
-	}
-		
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	// if((delta_IQK > pHalData->Delta_IQK) && (pHalData->Delta_IQK != 0))
-	if ((delta_IQK >= 8)) // Delta temperature is equal to or larger than 20 centigrade.
-		(*c.DoIQK)(pDM_Odm, delta_IQK, ThermalValue, 8);
-#endif		
-			
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("<===dm_TXPowerTrackingCallback_ThermalMeter_8188E\n"));
-	
-	pDM_Odm->RFCalibrateInfo.TXPowercount = 0;
-}
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
-
-VOID
-phy_PathAStandBy(
-	IN	PADAPTER	pAdapter
-	)
-{
-	RTPRINT(FINIT, INIT_IQK, ("Path-A standby mode!\n"));
-
-	PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0x0);
-	PHY_SetBBReg(pAdapter, 0x840, bMaskDWord, 0x00010000);
-	PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0x808000);
-}
-
-//1 7.	IQK
-//#define MAX_TOLERANCE		5
-//#define IQK_DELAY_TIME		1		//ms
-
-u1Byte			//bit0 = 1 => Tx OK, bit1 = 1 => Rx OK
-phy_PathA_IQK_8192C(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN		configPathB
-	)
-{
-
-	u4Byte regEAC, regE94, regE9C, regEA4;
-	u1Byte result = 0x00;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-
-	RTPRINT(FINIT, INIT_IQK, ("Path A IQK!\n"));
-
-	//path-A IQK setting
-	RTPRINT(FINIT, INIT_IQK, ("Path-A IQK setting!\n"));
-	if(pAdapter->interfaceIndex == 0)
-	{
-		PHY_SetBBReg(pAdapter, rTx_IQK_Tone_A, bMaskDWord, 0x10008c1f);
-		PHY_SetBBReg(pAdapter, rRx_IQK_Tone_A, bMaskDWord, 0x10008c1f);
-	}
-	else
-	{
-		PHY_SetBBReg(pAdapter, rTx_IQK_Tone_A, bMaskDWord, 0x10008c22);
-		PHY_SetBBReg(pAdapter, rRx_IQK_Tone_A, bMaskDWord, 0x10008c22);	
-	}
-
-	PHY_SetBBReg(pAdapter, rTx_IQK_PI_A, bMaskDWord, 0x82140102);
-
-	PHY_SetBBReg(pAdapter, rRx_IQK_PI_A, bMaskDWord, configPathB ? 0x28160202 : 
-		IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID)?0x28160202:0x28160502);
-
-	//path-B IQK setting
-	if(configPathB)
-	{
-		PHY_SetBBReg(pAdapter, rTx_IQK_Tone_B, bMaskDWord, 0x10008c22);
-		PHY_SetBBReg(pAdapter, rRx_IQK_Tone_B, bMaskDWord, 0x10008c22);
-		PHY_SetBBReg(pAdapter, rTx_IQK_PI_B, bMaskDWord, 0x82140102);
-		PHY_SetBBReg(pAdapter, rRx_IQK_PI_B, bMaskDWord, 0x28160202);
-	}
-
-	//LO calibration setting
-	RTPRINT(FINIT, INIT_IQK, ("LO calibration setting!\n"));
-	PHY_SetBBReg(pAdapter, rIQK_AGC_Rsp, bMaskDWord, 0x001028d1);
-
-	//One shot, path A LOK & IQK
-	RTPRINT(FINIT, INIT_IQK, ("One shot, path A LOK & IQK!\n"));
-	PHY_SetBBReg(pAdapter, rIQK_AGC_Pts, bMaskDWord, 0xf9000000);
-	PHY_SetBBReg(pAdapter, rIQK_AGC_Pts, bMaskDWord, 0xf8000000);
-	
-	// delay x ms
-	RTPRINT(FINIT, INIT_IQK, ("Delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME));
-	PlatformStallExecution(IQK_DELAY_TIME*1000);
-
-	// Check failed
-	regEAC = PHY_QueryBBReg(pAdapter, rRx_Power_After_IQK_A_2, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xeac = 0x%x\n", regEAC));
-	regE94 = PHY_QueryBBReg(pAdapter, rTx_Power_Before_IQK_A, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xe94 = 0x%x\n", regE94));
-	regE9C= PHY_QueryBBReg(pAdapter, rTx_Power_After_IQK_A, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xe9c = 0x%x\n", regE9C));
-	regEA4= PHY_QueryBBReg(pAdapter, rRx_Power_Before_IQK_A_2, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xea4 = 0x%x\n", regEA4));
-
-	if(!(regEAC & BIT28) &&		
-		(((regE94 & 0x03FF0000)>>16) != 0x142) &&
-		(((regE9C & 0x03FF0000)>>16) != 0x42) )
-		result |= 0x01;
-	else							//if Tx not OK, ignore Rx
-		return result;
-
-	if(!(regEAC & BIT27) &&		//if Tx is OK, check whether Rx is OK
-		(((regEA4 & 0x03FF0000)>>16) != 0x132) &&
-		(((regEAC & 0x03FF0000)>>16) != 0x36))
-		result |= 0x02;
-	else
-		RTPRINT(FINIT, INIT_IQK, ("Path A Rx IQK fail!!\n"));
-	
-	return result;
-
-
-}
-
-u1Byte				//bit0 = 1 => Tx OK, bit1 = 1 => Rx OK
-phy_PathB_IQK_8192C(
-	IN	PADAPTER	pAdapter
-	)
-{
-	u4Byte regEAC, regEB4, regEBC, regEC4, regECC;
-	u1Byte	result = 0x00;
-	RTPRINT(FINIT, INIT_IQK, ("Path B IQK!\n"));
-
-	//One shot, path B LOK & IQK
-	RTPRINT(FINIT, INIT_IQK, ("One shot, path A LOK & IQK!\n"));
-	PHY_SetBBReg(pAdapter, rIQK_AGC_Cont, bMaskDWord, 0x00000002);
-	PHY_SetBBReg(pAdapter, rIQK_AGC_Cont, bMaskDWord, 0x00000000);
-
-	// delay x ms
-	RTPRINT(FINIT, INIT_IQK, ("Delay %d ms for One shot, path B LOK & IQK.\n", IQK_DELAY_TIME));
-	PlatformStallExecution(IQK_DELAY_TIME*1000);
-
-	// Check failed
-	regEAC = PHY_QueryBBReg(pAdapter, rRx_Power_After_IQK_A_2, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xeac = 0x%x\n", regEAC));
-	regEB4 = PHY_QueryBBReg(pAdapter, rTx_Power_Before_IQK_B, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xeb4 = 0x%x\n", regEB4));
-	regEBC= PHY_QueryBBReg(pAdapter, rTx_Power_After_IQK_B, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xebc = 0x%x\n", regEBC));
-	regEC4= PHY_QueryBBReg(pAdapter, rRx_Power_Before_IQK_B_2, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xec4 = 0x%x\n", regEC4));
-	regECC= PHY_QueryBBReg(pAdapter, rRx_Power_After_IQK_B_2, bMaskDWord);
-	RTPRINT(FINIT, INIT_IQK, ("0xecc = 0x%x\n", regECC));
-
-	if(!(regEAC & BIT31) &&
-		(((regEB4 & 0x03FF0000)>>16) != 0x142) &&
-		(((regEBC & 0x03FF0000)>>16) != 0x42))
-		result |= 0x01;
-	else
-		return result;
-
-	if(!(regEAC & BIT30) &&
-		(((regEC4 & 0x03FF0000)>>16) != 0x132) &&
-		(((regECC & 0x03FF0000)>>16) != 0x36))
-		result |= 0x02;
-	else
-		RTPRINT(FINIT, INIT_IQK, ("Path B Rx IQK fail!!\n"));
-	
-
-	return result;
-
-}
-
-VOID
-phy_PathAFillIQKMatrix(
-	IN	PADAPTER	pAdapter,
-	IN  BOOLEAN    	bIQKOK,
-	IN	s4Byte		result[][8],
-	IN	u1Byte		final_candidate,
-	IN  BOOLEAN		bTxOnly
-	)
-{
-	u4Byte	Oldval_0, X, TX0_A, reg;
-	s4Byte	Y, TX0_C;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);	
-	
-	RTPRINT(FINIT, INIT_IQK, ("Path A IQ Calibration %s !\n",(bIQKOK)?"Success":"Failed"));
-
-	if(final_candidate == 0xFF)
-		return;
-
-	else if(bIQKOK)
-	{
-		Oldval_0 = (PHY_QueryBBReg(pAdapter, rOFDM0_XATxIQImbalance, bMaskDWord) >> 22) & 0x3FF;
-
-		X = result[final_candidate][0];
-		if ((X & 0x00000200) != 0)
-			X = X | 0xFFFFFC00;				
-		TX0_A = (X * Oldval_0) >> 8;
-		RTPRINT(FINIT, INIT_IQK, ("X = 0x%x, TX0_A = 0x%x, Oldval_0 0x%x\n", X, TX0_A, Oldval_0));
-		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;		
-
-		//path B IQK result + 3
-		if(pAdapter->interfaceIndex == 1 && pHalData->CurrentBandType == BAND_ON_5G)
-			Y += 3;
-		
-		TX0_C = (Y * Oldval_0) >> 8;
-		RTPRINT(FINIT, INIT_IQK, ("Y = 0x%x, TX = 0x%x\n", Y, TX0_C));
-		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)
-		{
-			RTPRINT(FINIT, INIT_IQK, ("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);
-	}
-}
-
-VOID
-phy_PathBFillIQKMatrix(
-	IN	PADAPTER	pAdapter,
-	IN  BOOLEAN   	bIQKOK,
-	IN	s4Byte		result[][8],
-	IN	u1Byte		final_candidate,
-	IN	BOOLEAN		bTxOnly			//do Tx only
-	)
-{
-	u4Byte	Oldval_1, X, TX1_A, reg;
-	s4Byte	Y, TX1_C;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);	
-	
-	RTPRINT(FINIT, INIT_IQK, ("Path B IQ Calibration %s !\n",(bIQKOK)?"Success":"Failed"));
-
-	if(final_candidate == 0xFF)
-		return;
-
-	else if(bIQKOK)
-	{
-		Oldval_1 = (PHY_QueryBBReg(pAdapter, rOFDM0_XBTxIQImbalance, bMaskDWord) >> 22) & 0x3FF;
-
-		X = result[final_candidate][4];
-		if ((X & 0x00000200) != 0)
-			X = X | 0xFFFFFC00;		
-		TX1_A = (X * Oldval_1) >> 8;
-		RTPRINT(FINIT, INIT_IQK, ("X = 0x%x, TX1_A = 0x%x\n", X, TX1_A));
-		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;		
-		if(pHalData->CurrentBandType == BAND_ON_5G)		
-			Y += 3;		//temp modify for preformance
-		TX1_C = (Y * Oldval_1) >> 8;
-		RTPRINT(FINIT, INIT_IQK, ("Y = 0x%x, TX1_C = 0x%x\n", Y, TX1_C));
-		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);
-	}
-}
-
-
-BOOLEAN							
-phy_SimularityCompare_92C(
-	IN	PADAPTER	pAdapter,
-	IN	s4Byte 		result[][8],
-	IN	u1Byte		 c1,
-	IN	u1Byte		 c2
-	)
-{
-	u4Byte		i, j, diff, SimularityBitMap, bound = 0;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);	
-	u1Byte		final_candidate[2] = {0xFF, 0xFF};	//for path A and path B
-	BOOLEAN		bResult = TRUE, is2T = IS_92C_SERIAL( pHalData->VersionID);
-	
-	if(is2T)
-		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) && is2T)	//path B OK
-	{
-		for(i = 4; i < 8; i++)
-			result[3][i] = result[c1][i];
-		return FALSE;
-	}	
-	else		
-		return FALSE;
-	
-}
-
-/*
-return FALSE => do IQK again
-*/
-BOOLEAN							
-phy_SimularityCompare(
-	IN	PADAPTER	pAdapter,
-	IN	s4Byte 		result[][8],
-	IN	u1Byte		 c1,
-	IN	u1Byte		 c2
-	)
-{	
-	return phy_SimularityCompare_92C(pAdapter, result, c1, c2);	
-
-}
-
-VOID	
-phy_IQCalibrate_8192C(
-	IN	PADAPTER	pAdapter,
-	IN	s4Byte 		result[][8],
-	IN	u1Byte		t,
-	IN	BOOLEAN		is2T
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u4Byte			i;
-	u1Byte			PathAOK, PathBOK;
-	u4Byte			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 };
-	u4Byte			IQK_MAC_REG[IQK_MAC_REG_NUM] = {
-						REG_TXPAUSE, 		REG_BCN_CTRL,	
-						REG_BCN_CTRL_1,	REG_GPIO_MUXCFG};
-					
-	//since 92C & 92D have the different define in IQK_BB_REG	
-	u4Byte	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*/ rCCK0_AFESetting	
-							};	
-
-	u4Byte	IQK_BB_REG_92D[IQK_BB_REG_NUM_92D] = {	//for normal
-							rFPGA0_XAB_RFInterfaceSW,	rFPGA0_XA_RFInterfaceOE,	
-							rFPGA0_XB_RFInterfaceOE,	rOFDM0_TRMuxPar,
-							rFPGA0_XCD_RFInterfaceSW,	rOFDM0_TRxPathEnable,	
-							/*rFPGA0_RFMOD*/ rCCK0_AFESetting,			rFPGA0_AnalogParameter4,
-							rOFDM0_XAAGCCore1,		rOFDM0_XBAGCCore1						
-						};		
-#if MP_DRIVER
-	const u4Byte	retryCount = 9;
-#else
-	const u4Byte	retryCount = 2;
-#endif
-	//Neil Chen--2011--05--19--
-       //3 Path Div	
-	u1Byte                 rfPathSwitch=0x0;
-
-	// Note: IQ calibration must be performed after loading 
-	// 		PHY_REG.txt , and radio_a, radio_b.txt	
-	
-	u4Byte bbvalue;
-
-	if(t==0)
-	{
-	 	 //bbvalue = PHY_QueryBBReg(pAdapter, rFPGA0_RFMOD, bMaskDWord);
-		//	RTPRINT(FINIT, INIT_IQK, ("phy_IQCalibrate_8192C()==>0x%08x\n",bbvalue));
-
-			RTPRINT(FINIT, INIT_IQK, ("IQ Calibration for %s\n", (is2T ? "2T2R" : "1T1R")));
-	
-	 	// Save ADDA parameters, turn Path A ADDA on
-	 	phy_SaveADDARegisters(pAdapter, ADDA_REG, pHalData->ADDA_backup, IQK_ADDA_REG_NUM);
-		phy_SaveMACRegisters(pAdapter, IQK_MAC_REG, pHalData->IQK_MAC_backup);
-		phy_SaveADDARegisters(pAdapter, IQK_BB_REG_92C, pHalData->IQK_BB_backup, IQK_BB_REG_NUM);
-	}
-	
- 	phy_PathADDAOn(pAdapter, ADDA_REG, TRUE, is2T);
-	
-	if(t==0)
-	{
-		pHalData->bRfPiEnable = (u1Byte)PHY_QueryBBReg(pAdapter, rFPGA0_XA_HSSIParameter1, BIT(8));
-	}
-	
-	if(!pHalData->bRfPiEnable){
-		// Switch BB to PI mode to do IQ Calibration.
-		phy_PIModeSwitch(pAdapter, TRUE);
-	}
-	
-	//MAC settings
-	phy_MACSettingCalibration(pAdapter, IQK_MAC_REG, pHalData->IQK_MAC_backup);
-	
-	//PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, BIT24, 0x00);		
-	PHY_SetBBReg(pAdapter, rCCK0_AFESetting, bMaskDWord, (0x0f000000 | (PHY_QueryBBReg(pAdapter, rCCK0_AFESetting, bMaskDWord))) );
-	PHY_SetBBReg(pAdapter, rOFDM0_TRxPathEnable, bMaskDWord, 0x03a05600);
-	PHY_SetBBReg(pAdapter, rOFDM0_TRMuxPar, bMaskDWord, 0x000800e4);
-	PHY_SetBBReg(pAdapter, rFPGA0_XCD_RFInterfaceSW, bMaskDWord, 0x22204000);
-	{
-		PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0x01);
-		PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0x01);	
-		PHY_SetBBReg(pAdapter, rFPGA0_XA_RFInterfaceOE, BIT10, 0x00);
-		PHY_SetBBReg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0x00);	
-	}
-
-	if(is2T)
-	{
-		PHY_SetBBReg(pAdapter, rFPGA0_XA_LSSIParameter, bMaskDWord, 0x00010000);
-		PHY_SetBBReg(pAdapter, rFPGA0_XB_LSSIParameter, bMaskDWord, 0x00010000);
-	}
-
-	{
-		//Page B init
-		PHY_SetBBReg(pAdapter, rConfig_AntA, bMaskDWord, 0x00080000);
-		
-		if(is2T)
-		{
-			PHY_SetBBReg(pAdapter, rConfig_AntB, bMaskDWord, 0x00080000);
-		}
-	}
-	// IQ calibration setting
-	RTPRINT(FINIT, INIT_IQK, ("IQK setting!\n"));		
-	PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0x808000);
-	PHY_SetBBReg(pAdapter, rTx_IQK, bMaskDWord, 0x01007c00);
-	PHY_SetBBReg(pAdapter, rRx_IQK, bMaskDWord, 0x01004800);
-
-	for(i = 0 ; i < retryCount ; i++){
-		PathAOK = phy_PathA_IQK_8192C(pAdapter, is2T);
-		if(PathAOK == 0x03){
-			RTPRINT(FINIT, INIT_IQK, ("Path A IQK Success!!\n"));
-				result[t][0] = (PHY_QueryBBReg(pAdapter, rTx_Power_Before_IQK_A, bMaskDWord)&0x3FF0000)>>16;
-				result[t][1] = (PHY_QueryBBReg(pAdapter, rTx_Power_After_IQK_A, bMaskDWord)&0x3FF0000)>>16;
-				result[t][2] = (PHY_QueryBBReg(pAdapter, rRx_Power_Before_IQK_A_2, bMaskDWord)&0x3FF0000)>>16;
-				result[t][3] = (PHY_QueryBBReg(pAdapter, rRx_Power_After_IQK_A_2, bMaskDWord)&0x3FF0000)>>16;
-			break;
-		}
-		else if (i == (retryCount-1) && PathAOK == 0x01)	//Tx IQK OK
-		{
-			RTPRINT(FINIT, INIT_IQK, ("Path A IQK Only  Tx Success!!\n"));
-			
-			result[t][0] = (PHY_QueryBBReg(pAdapter, rTx_Power_Before_IQK_A, bMaskDWord)&0x3FF0000)>>16;
-			result[t][1] = (PHY_QueryBBReg(pAdapter, rTx_Power_After_IQK_A, bMaskDWord)&0x3FF0000)>>16;			
-		}
-	}
-
-	if(0x00 == PathAOK){		
-		RTPRINT(FINIT, INIT_IQK, ("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_8192C(pAdapter);
-			if(PathBOK == 0x03){
-				RTPRINT(FINIT, INIT_IQK, ("Path B IQK Success!!\n"));
-				result[t][4] = (PHY_QueryBBReg(pAdapter, rTx_Power_Before_IQK_B, bMaskDWord)&0x3FF0000)>>16;
-				result[t][5] = (PHY_QueryBBReg(pAdapter, rTx_Power_After_IQK_B, bMaskDWord)&0x3FF0000)>>16;
-				result[t][6] = (PHY_QueryBBReg(pAdapter, rRx_Power_Before_IQK_B_2, bMaskDWord)&0x3FF0000)>>16;
-				result[t][7] = (PHY_QueryBBReg(pAdapter, rRx_Power_After_IQK_B_2, bMaskDWord)&0x3FF0000)>>16;
-				break;
-			}
-			else if (i == (retryCount - 1) && PathBOK == 0x01)	//Tx IQK OK
-			{
-				RTPRINT(FINIT, INIT_IQK, ("Path B Only Tx IQK Success!!\n"));
-				result[t][4] = (PHY_QueryBBReg(pAdapter, rTx_Power_Before_IQK_B, bMaskDWord)&0x3FF0000)>>16;
-				result[t][5] = (PHY_QueryBBReg(pAdapter, rTx_Power_After_IQK_B, bMaskDWord)&0x3FF0000)>>16;				
-			}
-		}
-
-		if(0x00 == PathBOK){		
-			RTPRINT(FINIT, INIT_IQK, ("Path B IQK failed!!\n"));		
-		}
-	}
-
-	//Back to BB mode, load original value
-	RTPRINT(FINIT, INIT_IQK, ("IQK:Back to BB mode, load original value!\n"));
-	PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0);
-
-	if(t!=0)
-	{
-		if(!pHalData->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, pHalData->ADDA_backup, IQK_ADDA_REG_NUM);
-
-		// Reload MAC parameters
-		phy_ReloadMACRegisters(pAdapter, IQK_MAC_REG, pHalData->IQK_MAC_backup);
-		
-	 	// Reload BB parameters
-		phy_ReloadADDARegisters(pAdapter, IQK_BB_REG_92C, pHalData->IQK_BB_backup, IQK_BB_REG_NUM);
-		
-		/*Restore RX initial gain*/
-		PHY_SetBBReg(pAdapter, rFPGA0_XA_LSSIParameter, bMaskDWord, 0x00032ed3);
-		if (is2T)
-			PHY_SetBBReg(pAdapter, rFPGA0_XB_LSSIParameter, bMaskDWord, 0x00032ed3);
-		//load 0xe30 IQC default value
-		PHY_SetBBReg(pAdapter, rTx_IQK_Tone_A, bMaskDWord, 0x01008c00);		
-		PHY_SetBBReg(pAdapter, rRx_IQK_Tone_A, bMaskDWord, 0x01008c00);				
-		
-	}
-	RTPRINT(FINIT, INIT_IQK, ("phy_IQCalibrate_8192C() <==\n"));
-	
-}
-
-
-VOID	
-phy_LCCalibrate92C(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN		is2T
-	)
-{
-	u1Byte	tmpReg;
-	u4Byte	RF_Amode=0, RF_Bmode=0, LC_Cal;
-//	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-
-	//Check continuous TX and Packet TX
-	tmpReg = PlatformEFIORead1Byte(pAdapter, 0xd03);
-
-	if((tmpReg&0x70) != 0)			//Deal with contisuous TX case
-		PlatformEFIOWrite1Byte(pAdapter, 0xd03, tmpReg&0x8F);	//disable all continuous TX
-	else							// Deal with Packet TX case
-		PlatformEFIOWrite1Byte(pAdapter, REG_TXPAUSE, 0xFF);			// block all queues
-
-	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	bit15
-	PHY_SetRFReg(pAdapter, RF_PATH_A, RF_CHNLBW, bMask12Bits, LC_Cal|0x08000);
-
-	delay_ms(100);		
-
-
-	//Restore original situation
-	if((tmpReg&0x70) != 0)	//Deal with contisuous TX case 
-	{  
-		//Path-A
-		PlatformEFIOWrite1Byte(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
-	{
-		PlatformEFIOWrite1Byte(pAdapter, REG_TXPAUSE, 0x00);	
-	}
-}
-
-
-VOID	
-phy_LCCalibrate(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN		is2T
-	)
-{
-	phy_LCCalibrate92C(pAdapter, is2T);
-}
-
-
-
-//Analog Pre-distortion calibration
-#define		APK_BB_REG_NUM	8
-#define		APK_CURVE_REG_NUM 4
-#define		PATH_NUM		2
-
-VOID	
-phy_APCalibrate_8192C(
-	IN	PADAPTER	pAdapter,
-	IN	s1Byte 		delta,
-	IN	BOOLEAN		is2T
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-
-	u4Byte 			regD[PATH_NUM];
-	u4Byte			tmpReg, index, offset, i, apkbound;
-	u1Byte			path, pathbound = PATH_NUM;
-	u4Byte			BB_backup[APK_BB_REG_NUM];
-	u4Byte			BB_REG[APK_BB_REG_NUM] = {	
-						rFPGA1_TxBlock, 	rOFDM0_TRxPathEnable, 
-						rFPGA0_RFMOD, 	rOFDM0_TRMuxPar, 
-						rFPGA0_XCD_RFInterfaceSW,	rFPGA0_XAB_RFInterfaceSW, 
-						rFPGA0_XA_RFInterfaceOE, 	rFPGA0_XB_RFInterfaceOE	};
-	u4Byte			BB_AP_MODE[APK_BB_REG_NUM] = {	
-						0x00000020, 0x00a05430, 0x02040000, 
-						0x000800e4, 0x00204000 };
-	u4Byte			BB_normal_AP_MODE[APK_BB_REG_NUM] = {	
-						0x00000020, 0x00a05430, 0x02040000, 
-						0x000800e4, 0x22204000 };						
-
-	u4Byte			AFE_backup[IQK_ADDA_REG_NUM];
-	u4Byte			AFE_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 };
-
-	u4Byte			MAC_backup[IQK_MAC_REG_NUM];
-	u4Byte			MAC_REG[IQK_MAC_REG_NUM] = {
-						REG_TXPAUSE, 		REG_BCN_CTRL,	
-						REG_BCN_CTRL_1,	REG_GPIO_MUXCFG};
-
-	u4Byte			APK_RF_init_value[PATH_NUM][APK_BB_REG_NUM] = {
-					{0x0852c, 0x1852c, 0x5852c, 0x1852c, 0x5852c},
-					{0x2852e, 0x0852e, 0x3852e, 0x0852e, 0x0852e}
-					};	
-
-	u4Byte			APK_normal_RF_init_value[PATH_NUM][APK_BB_REG_NUM] = {
-					{0x0852c, 0x0a52c, 0x3a52c, 0x5a52c, 0x5a52c},	//path settings equal to path b settings
-					{0x0852c, 0x0a52c, 0x5a52c, 0x5a52c, 0x5a52c}
-					};
-	
-	u4Byte			APK_RF_value_0[PATH_NUM][APK_BB_REG_NUM] = {
-					{0x52019, 0x52014, 0x52013, 0x5200f, 0x5208d},
-					{0x5201a, 0x52019, 0x52016, 0x52033, 0x52050}
-					};
-
-	u4Byte			APK_normal_RF_value_0[PATH_NUM][APK_BB_REG_NUM] = {
-					{0x52019, 0x52017, 0x52010, 0x5200d, 0x5206a},	//path settings equal to path b settings
-					{0x52019, 0x52017, 0x52010, 0x5200d, 0x5206a}
-					};
-#if 0	
-	u4Byte			APK_RF_value_A[PATH_NUM][APK_BB_REG_NUM] = {
-					{0x1adb0, 0x1adb0, 0x1ada0, 0x1ad90, 0x1ad80},		
-					{0x00fb0, 0x00fb0, 0x00fa0, 0x00f90, 0x00f80}						
-					};
-#endif
-	u4Byte			AFE_on_off[PATH_NUM] = {
-					0x04db25a4, 0x0b1b25a4};	//path A on path B off / path A off path B on
-
-	u4Byte			APK_offset[PATH_NUM] = {
-					rConfig_AntA, rConfig_AntB};
-
-	u4Byte			APK_normal_offset[PATH_NUM] = {
-					rConfig_Pmpd_AntA, rConfig_Pmpd_AntB};
-					
-	u4Byte			APK_value[PATH_NUM] = {
-					0x92fc0000, 0x12fc0000};					
-
-	u4Byte			APK_normal_value[PATH_NUM] = {
-					0x92680000, 0x12680000};					
-
-	s1Byte			APK_delta_mapping[APK_BB_REG_NUM][13] = {
-					{-4, -3, -2, -2, -1, -1, 0, 1, 2, 3, 4, 5, 6},
-					{-4, -3, -2, -2, -1, -1, 0, 1, 2, 3, 4, 5, 6},											
-					{-6, -4, -2, -2, -1, -1, 0, 1, 2, 3, 4, 5, 6},
-					{-1, -1, -1, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6},
-					{-11, -9, -7, -5, -3, -1, 0, 0, 0, 0, 0, 0, 0}
-					};
-	
-	u4Byte			APK_normal_setting_value_1[13] = {
-					0x01017018, 0xf7ed8f84, 0x1b1a1816, 0x2522201e, 0x322e2b28,
-					0x433f3a36, 0x5b544e49, 0x7b726a62, 0xa69a8f84, 0xdfcfc0b3,
-					0x12680000, 0x00880000, 0x00880000
-					};
-
-	u4Byte			APK_normal_setting_value_2[16] = {
-					0x01c7021d, 0x01670183, 0x01000123, 0x00bf00e2, 0x008d00a3,
-					0x0068007b, 0x004d0059, 0x003a0042, 0x002b0031, 0x001f0025,
-					0x0017001b, 0x00110014, 0x000c000f, 0x0009000b, 0x00070008,
-					0x00050006
-					};
-	
-	u4Byte			APK_result[PATH_NUM][APK_BB_REG_NUM];	//val_1_1a, val_1_2a, val_2a, val_3a, val_4a
-//	u4Byte			AP_curve[PATH_NUM][APK_CURVE_REG_NUM];
-
-	s4Byte			BB_offset, delta_V, delta_offset;
-
-#if MP_DRIVER == 1
-	PMPT_CONTEXT	pMptCtx = &(pAdapter->MptCtx);	
-
-	pMptCtx->APK_bound[0] = 45;
-	pMptCtx->APK_bound[1] = 52;		
-#endif
-
-	RTPRINT(FINIT, INIT_IQK, ("==>phy_APCalibrate_8192C() delta %d\n", delta));
-	RTPRINT(FINIT, INIT_IQK, ("AP Calibration for %s\n", (is2T ? "2T2R" : "1T1R")));
-	if(!is2T)
-		pathbound = 1;
-
-	//2 FOR NORMAL CHIP SETTINGS
-
-// Temporarily do not allow normal driver to do the following settings because these offset
-// and value will cause RF internal PA to be unpredictably disabled by HW, such that RF Tx signal
-// will disappear after disable/enable card many times on 88CU. RF SD and DD have not find the
-// root cause, so we remove these actions temporarily. Added by tynli and SD3 Allen. 2010.05.31.
-#if MP_DRIVER != 1
-	return;
-#endif
-	//settings adjust for normal chip
-	for(index = 0; index < PATH_NUM; index ++)
-	{
-		APK_offset[index] = APK_normal_offset[index];
-		APK_value[index] = APK_normal_value[index];
-		AFE_on_off[index] = 0x6fdb25a4;
-	}
-
-	for(index = 0; index < APK_BB_REG_NUM; index ++)
-	{
-		for(path = 0; path < pathbound; path++)
-		{
-			APK_RF_init_value[path][index] = APK_normal_RF_init_value[path][index];
-			APK_RF_value_0[path][index] = APK_normal_RF_value_0[path][index];
-		}
-		BB_AP_MODE[index] = BB_normal_AP_MODE[index];
-	}			
-
-	apkbound = 6;
-	
-	//save BB default value
-	for(index = 0; index < APK_BB_REG_NUM ; index++)
-	{
-		if(index == 0)		//skip 
-			continue;				
-		BB_backup[index] = PHY_QueryBBReg(pAdapter, BB_REG[index], bMaskDWord);
-	}
-	
-	//save MAC default value													
-	phy_SaveMACRegisters(pAdapter, MAC_REG, MAC_backup);
-	
-	//save AFE default value
-	phy_SaveADDARegisters(pAdapter, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-
-	for(path = 0; path < pathbound; path++)
-	{
-
-
-		if(path == RF_PATH_A)
-		{
-			//path A APK
-			//load APK setting
-			//path-A		
-			offset = rPdp_AntA;
-			for(index = 0; index < 11; index ++)			
-			{
-				PHY_SetBBReg(pAdapter, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", offset, PHY_QueryBBReg(pAdapter, offset, bMaskDWord))); 	
-				
-				offset += 0x04;
-			}
-			
-			PHY_SetBBReg(pAdapter, rConfig_Pmpd_AntB, bMaskDWord, 0x12680000);
-			
-			offset = rConfig_AntA;
-			for(; index < 13; index ++) 		
-			{
-				PHY_SetBBReg(pAdapter, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", offset, PHY_QueryBBReg(pAdapter, offset, bMaskDWord))); 	
-				
-				offset += 0x04;
-			}	
-			
-			//page-B1
-			PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0x400000);
-		
-			//path A
-			offset = rPdp_AntA;
-			for(index = 0; index < 16; index++)
-			{
-				PHY_SetBBReg(pAdapter, offset, bMaskDWord, APK_normal_setting_value_2[index]);		
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", offset, PHY_QueryBBReg(pAdapter, offset, bMaskDWord))); 	
-				
-				offset += 0x04;
-			}				
-			PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0);							
-		}
-		else if(path == RF_PATH_B)
-		{
-			//path B APK
-			//load APK setting
-			//path-B		
-			offset = rPdp_AntB;
-			for(index = 0; index < 10; index ++)			
-			{
-				PHY_SetBBReg(pAdapter, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", offset, PHY_QueryBBReg(pAdapter, offset, bMaskDWord))); 	
-				
-				offset += 0x04;
-			}
-			PHY_SetBBReg(pAdapter, rConfig_Pmpd_AntA, bMaskDWord, 0x12680000);
-			
-			PHY_SetBBReg(pAdapter, rConfig_Pmpd_AntB, bMaskDWord, 0x12680000);
-			
-			offset = rConfig_AntA;
-			index = 11;
-			for(; index < 13; index ++) //offset 0xb68, 0xb6c		
-			{
-				PHY_SetBBReg(pAdapter, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", offset, PHY_QueryBBReg(pAdapter, offset, bMaskDWord))); 	
-				
-				offset += 0x04;
-			}	
-			
-			//page-B1
-			PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0x400000);
-			
-			//path B
-			offset = 0xb60;
-			for(index = 0; index < 16; index++)
-			{
-				PHY_SetBBReg(pAdapter, offset, bMaskDWord, APK_normal_setting_value_2[index]);		
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", offset, PHY_QueryBBReg(pAdapter, offset, bMaskDWord))); 	
-				
-				offset += 0x04;
-			}				
-			PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0);							
-		}
-	
-		//save RF default value
-		regD[path] = PHY_QueryRFReg(pAdapter, path, RF_TXBIAS_A, bRFRegOffsetMask);
-		
-		//Path A AFE all on, path B AFE All off or vise versa
-		for(index = 0; index < IQK_ADDA_REG_NUM ; index++)
-			PHY_SetBBReg(pAdapter, AFE_REG[index], bMaskDWord, AFE_on_off[path]);
-		RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0xe70 %x\n", PHY_QueryBBReg(pAdapter, rRx_Wait_CCA, bMaskDWord)));		
-
-		//BB to AP mode
-		if(path == 0)
-		{				
-			for(index = 0; index < APK_BB_REG_NUM ; index++)
-			{
-
-				if(index == 0)		//skip 
-					continue;			
-				else if (index < 5)
-				PHY_SetBBReg(pAdapter, BB_REG[index], bMaskDWord, BB_AP_MODE[index]);
-				else if (BB_REG[index] == 0x870)
-					PHY_SetBBReg(pAdapter, BB_REG[index], bMaskDWord, BB_backup[index]|BIT10|BIT26);
-				else
-					PHY_SetBBReg(pAdapter, BB_REG[index], BIT10, 0x0);					
-			}
-
-			PHY_SetBBReg(pAdapter, rTx_IQK_Tone_A, bMaskDWord, 0x01008c00);			
-			PHY_SetBBReg(pAdapter, rRx_IQK_Tone_A, bMaskDWord, 0x01008c00);					
-		}
-		else		//path B
-		{
-			PHY_SetBBReg(pAdapter, rTx_IQK_Tone_B, bMaskDWord, 0x01008c00);			
-			PHY_SetBBReg(pAdapter, rRx_IQK_Tone_B, bMaskDWord, 0x01008c00);					
-		
-		}
-
-		RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x800 %x\n", PHY_QueryBBReg(pAdapter, 0x800, bMaskDWord)));				
-
-		//MAC settings
-		phy_MACSettingCalibration(pAdapter, MAC_REG, MAC_backup);
-		
-		if(path == RF_PATH_A)	//Path B to standby mode
-		{
-			PHY_SetRFReg(pAdapter, RF_PATH_B, RF_AC, bRFRegOffsetMask, 0x10000);			
-		}
-		else			//Path A to standby mode
-		{
-			PHY_SetRFReg(pAdapter, RF_PATH_A, RF_AC, bRFRegOffsetMask, 0x10000);			
-			PHY_SetRFReg(pAdapter, RF_PATH_A, RF_MODE1, bRFRegOffsetMask, 0x1000f);			
-			PHY_SetRFReg(pAdapter, RF_PATH_A, RF_MODE2, bRFRegOffsetMask, 0x20103);						
-		}
-
-		delta_offset = ((delta+14)/2);
-		if(delta_offset < 0)
-			delta_offset = 0;
-		else if (delta_offset > 12)
-			delta_offset = 12;
-			
-		//AP calibration
-		for(index = 0; index < APK_BB_REG_NUM; index++)
-		{
-			if(index != 1)	//only DO PA11+PAD01001, AP RF setting
-				continue;
-					
-			tmpReg = APK_RF_init_value[path][index];
-#if 1			
-			if(!pHalData->bAPKThermalMeterIgnore)
-			{
-				BB_offset = (tmpReg & 0xF0000) >> 16;
-
-				if(!(tmpReg & BIT15)) //sign bit 0
-				{
-					BB_offset = -BB_offset;
-				}
-
-				delta_V = APK_delta_mapping[index][delta_offset];
-				
-				BB_offset += delta_V;
-
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() APK index %d tmpReg 0x%x delta_V %d delta_offset %d\n", index, tmpReg, delta_V, delta_offset));		
-				
-				if(BB_offset < 0)
-				{
-					tmpReg = tmpReg & (~BIT15);
-					BB_offset = -BB_offset;
-				}
-				else
-				{
-					tmpReg = tmpReg | BIT15;
-				}
-				tmpReg = (tmpReg & 0xFFF0FFFF) | (BB_offset << 16);
-			}
-#endif
-
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-			if(IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID))
-				PHY_SetRFReg(pAdapter, path, RF_IPA_A, bRFRegOffsetMask, 0x894ae);
-			else
-#endif	
-				PHY_SetRFReg(pAdapter, path, RF_IPA_A, bRFRegOffsetMask, 0x8992e);
-			RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0xc %x\n", PHY_QueryRFReg(pAdapter, path, RF_IPA_A, bRFRegOffsetMask)));		
-			PHY_SetRFReg(pAdapter, path, RF_AC, bRFRegOffsetMask, APK_RF_value_0[path][index]);
-			RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x0 %x\n", PHY_QueryRFReg(pAdapter, path, RF_AC, bRFRegOffsetMask)));		
-			PHY_SetRFReg(pAdapter, path, RF_TXBIAS_A, bRFRegOffsetMask, tmpReg);
-			RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0xd %x\n", PHY_QueryRFReg(pAdapter, path, RF_TXBIAS_A, bRFRegOffsetMask)));					
-			
-			// PA11+PAD01111, one shot	
-			i = 0;
-			do
-			{
-				PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0x800000);
-				{
-					PHY_SetBBReg(pAdapter, APK_offset[path], bMaskDWord, APK_value[0]);		
-					RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", APK_offset[path], PHY_QueryBBReg(pAdapter, APK_offset[path], bMaskDWord)));
-					delay_ms(3);				
-					PHY_SetBBReg(pAdapter, APK_offset[path], bMaskDWord, APK_value[1]);
-					RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0x%x value 0x%x\n", APK_offset[path], PHY_QueryBBReg(pAdapter, APK_offset[path], bMaskDWord)));
-
-					delay_ms(20);
-				}
-				PHY_SetBBReg(pAdapter, rFPGA0_IQK, 0xffffff00, 0);
-
-				if(path == RF_PATH_A)
-					tmpReg = PHY_QueryBBReg(pAdapter, rAPK, 0x03E00000);
-				else
-					tmpReg = PHY_QueryBBReg(pAdapter, rAPK, 0xF8000000);
-				RTPRINT(FINIT, INIT_IQK, ("phy_APCalibrate_8192C() offset 0xbd8[25:21] %x\n", tmpReg));		
-				
-
-				i++;
-			}
-			while(tmpReg > apkbound && i < 4);
-
-			APK_result[path][index] = tmpReg;
-		}
-	}
-
-	//reload MAC default value	
-	phy_ReloadMACRegisters(pAdapter, MAC_REG, MAC_backup);
-	
-	//reload BB default value	
-	for(index = 0; index < APK_BB_REG_NUM ; index++)
-	{
-
-		if(index == 0)		//skip 
-			continue;					
-		PHY_SetBBReg(pAdapter, BB_REG[index], bMaskDWord, BB_backup[index]);
-	}
-
-	//reload AFE default value
-	phy_ReloadADDARegisters(pAdapter, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-
-	//reload RF path default value
-	for(path = 0; path < pathbound; path++)
-	{
-		PHY_SetRFReg(pAdapter, path, RF_TXBIAS_A, bRFRegOffsetMask, regD[path]);
-		if(path == RF_PATH_B)
-		{
-			PHY_SetRFReg(pAdapter, RF_PATH_A, RF_MODE1, bRFRegOffsetMask, 0x1000f);			
-			PHY_SetRFReg(pAdapter, RF_PATH_A, RF_MODE2, bRFRegOffsetMask, 0x20101);						
-		}
-
-		//note no index == 0
-		if (APK_result[path][1] > 6)
-			APK_result[path][1] = 6;
-		RTPRINT(FINIT, INIT_IQK, ("apk path %d result %d 0x%x \t", path, 1, APK_result[path][1]));					
-	}
-
-	RTPRINT(FINIT, INIT_IQK, ("\n"));
-	
-
-	for(path = 0; path < pathbound; path++)
-	{
-		PHY_SetRFReg(pAdapter, path, RF_BS_PA_APSET_G1_G4, bRFRegOffsetMask, 
-		((APK_result[path][1] << 15) | (APK_result[path][1] << 10) | (APK_result[path][1] << 5) | APK_result[path][1]));
-		if(path == RF_PATH_A)
-			PHY_SetRFReg(pAdapter, path, RF_BS_PA_APSET_G5_G8, bRFRegOffsetMask, 
-			((APK_result[path][1] << 15) | (APK_result[path][1] << 10) | (0x00 << 5) | 0x05));		
-		else
-		PHY_SetRFReg(pAdapter, path, RF_BS_PA_APSET_G5_G8, bRFRegOffsetMask, 
-			((APK_result[path][1] << 15) | (APK_result[path][1] << 10) | (0x02 << 5) | 0x05));						
-			
-		PHY_SetRFReg(pAdapter, path, RF_BS_PA_APSET_G9_G11, bRFRegOffsetMask, ((0x08 << 15) | (0x08 << 10) | (0x08 << 5) | 0x08));			
-	}
-
-	pHalData->bAPKdone = TRUE;
-
-	RTPRINT(FINIT, INIT_IQK, ("<==phy_APCalibrate_8192C()\n"));
-}
-
-
-VOID
-PHY_IQCalibrate_8192C(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN 	bReCovery
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	s4Byte			result[4][8];	//last is final result
-	u1Byte			i, final_candidate, Indexforchannel;
-	BOOLEAN			bPathAOK, bPathBOK;
-	s4Byte			RegE94, RegE9C, RegEA4, RegEAC, RegEB4, RegEBC, RegEC4, RegECC, RegTmp = 0;
-	BOOLEAN			is12simular, is13simular, is23simular;	
-	BOOLEAN 		bStartContTx = FALSE, bSingleTone = FALSE, bCarrierSuppression = FALSE;
-	u4Byte			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};
-
-	if (ODM_CheckPowerStatus(pAdapter) == FALSE)
-		return;
-	
-#if MP_DRIVER == 1	
-	bStartContTx = pAdapter->MptCtx.bStartContTx;
-	bSingleTone = pAdapter->MptCtx.bSingleTone;
-	bCarrierSuppression = pAdapter->MptCtx.bCarrierSuppression;	
-#endif
-	
-	//ignore IQK when continuous Tx
-	if(bStartContTx || bSingleTone || bCarrierSuppression)
-		return;
-
-#ifdef DISABLE_BB_RF
-	return;
-#endif
-	if(pAdapter->bSlaveOfDMSP)
-		return;
-
-	if (bReCovery)
-		{
-			phy_ReloadADDARegisters(pAdapter, IQK_BB_REG_92C, pHalData->IQK_BB_backup_recover, 9);
-			return;		
-
-		}
-
-	RTPRINT(FINIT, INIT_IQK, ("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;
-
-	AcquireCCKAndRWPageAControl(pAdapter);
-	/*RT_TRACE(COMP_INIT,DBG_LOUD,("Acquire Mutex in IQCalibrate\n"));*/
-	for (i=0; i<3; i++)
-	{
-		/*For 88C 1T1R*/
-		phy_IQCalibrate_8192C(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;
-			}
-		}
-	}
-//	RT_TRACE(COMP_INIT,DBG_LOUD,("Release Mutex in IQCalibrate \n"));
-	ReleaseCCKAndRWPageAControl(pAdapter);
-
-	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];
-		RTPRINT(FINIT, INIT_IQK, ("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));
-	}
-	
-	if(final_candidate != 0xff)
-	{
-		pHalData->RegE94 = RegE94 = result[final_candidate][0];
-		pHalData->RegE9C = RegE9C = result[final_candidate][1];
-		RegEA4 = result[final_candidate][2];
-		RegEAC = result[final_candidate][3];
-		pHalData->RegEB4 = RegEB4 = result[final_candidate][4];
-		pHalData->RegEBC = RegEBC = result[final_candidate][5];
-		RegEC4 = result[final_candidate][6];
-		RegECC = result[final_candidate][7];
-		RTPRINT(FINIT, INIT_IQK, ("IQK: final_candidate is %x\n",final_candidate));
-		RTPRINT(FINIT, INIT_IQK, ("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 = pHalData->RegE94 = pHalData->RegEB4 = 0x100;	//X default value
-		RegE9C = RegEBC = pHalData->RegE9C = pHalData->RegEBC = 0x0;		//Y default value
-	}
-	
-	if((RegE94 != 0)/*&&(RegEA4 != 0)*/)
-	{
-		if(pHalData->CurrentBandType == BAND_ON_5G)
-			phy_PathAFillIQKMatrix_5G_Normal(pAdapter, bPathAOK, result, final_candidate, (RegEA4 == 0));			
-		else		
-			phy_PathAFillIQKMatrix(pAdapter, bPathAOK, result, final_candidate, (RegEA4 == 0));
-
-	}
-	
-	if (IS_92C_SERIAL(pHalData->VersionID) || IS_92D_SINGLEPHY(pHalData->VersionID))
-	{
-		if((RegEB4 != 0)/*&&(RegEC4 != 0)*/)
-		{
-			if(pHalData->CurrentBandType == BAND_ON_5G)		
-				phy_PathBFillIQKMatrix_5G_Normal(pAdapter, bPathBOK, result, final_candidate, (RegEC4 == 0));
-			else
-				phy_PathBFillIQKMatrix(pAdapter, bPathBOK, result, final_candidate, (RegEC4 == 0));
-		}
-	}
-	
-	phy_SaveADDARegisters(pAdapter, IQK_BB_REG_92C, pHalData->IQK_BB_backup_recover, 9);
-
-}
-
-
-VOID
-PHY_LCCalibrate_8192C(
-	IN	PADAPTER	pAdapter
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	BOOLEAN 		bStartContTx = FALSE, bSingleTone = FALSE, bCarrierSuppression = FALSE;
-	PMGNT_INFO		pMgntInfo=&pAdapter->MgntInfo;
-	PMGNT_INFO		pMgntInfoBuddyAdapter;
-	u4Byte			timeout = 2000, timecount = 0;
-	PADAPTER	BuddyAdapter = pAdapter->BuddyAdapter;
-
-#if MP_DRIVER == 1	
-	bStartContTx = pAdapter->MptCtx.bStartContTx;
-	bSingleTone = pAdapter->MptCtx.bSingleTone;
-	bCarrierSuppression = pAdapter->MptCtx.bCarrierSuppression;		
-#endif
-
-#ifdef DISABLE_BB_RF
-	return;
-#endif
-
-	//ignore LCK when continuous Tx
-	if(bStartContTx || bSingleTone || bCarrierSuppression)
-		return;
-
-	if(BuddyAdapter != NULL &&
-		((pAdapter->interfaceIndex == 0 && pHalData->CurrentBandType == BAND_ON_2_4G) ||
-		(pAdapter->interfaceIndex == 1 && pHalData->CurrentBandType == BAND_ON_5G)))
-	{
-		pMgntInfoBuddyAdapter=&BuddyAdapter->MgntInfo;
-		while(pMgntInfoBuddyAdapter->bScanInProgress && timecount < timeout)
-		{
-			delay_ms(50);
-			timecount += 50;
-		}
-	}
-
-	while(pMgntInfo->bScanInProgress && timecount < timeout)
-	{
-		delay_ms(50);
-		timecount += 50;
-	}	
-	
-	pHalData->bLCKInProgress = TRUE;
-
-	RTPRINT(FINIT, INIT_IQK, ("LCK:Start!!!interface %d currentband %x delay %d ms\n", pAdapter->interfaceIndex, pHalData->CurrentBandType, timecount));
-	
-	//if(IS_92C_SERIAL(pHalData->VersionID) || IS_92D_SINGLEPHY(pHalData->VersionID))
-	if(IS_2T2R(pHalData->VersionID))
-	{
-		phy_LCCalibrate(pAdapter, TRUE);
-	}
-	else{
-		// For 88C 1T1R
-		phy_LCCalibrate(pAdapter, FALSE);
-	}
-
-	pHalData->bLCKInProgress = FALSE;
-
-	RTPRINT(FINIT, INIT_IQK, ("LCK:Finish!!!interface %d\n", pAdapter->interfaceIndex));
-	
-
-}
-
-VOID
-PHY_APCalibrate_8192C(
-	IN	PADAPTER	pAdapter,
-	IN	s1Byte 		delta	
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-
-	//default disable APK, because Tx NG issue, suggest by Jenyu, 2011.11.25
-	return;
-
-#ifdef DISABLE_BB_RF
-	return;
-#endif
-
-#if FOR_BRAZIL_PRETEST != 1
-	if(pHalData->bAPKdone)
-#endif		
-		return;
-
-	if(IS_92C_SERIAL( pHalData->VersionID)){
-		phy_APCalibrate_8192C(pAdapter, delta, TRUE);
-	}
-	else{
-		// For 88C 1T1R
-		phy_APCalibrate_8192C(pAdapter, delta, FALSE);
-	}
-}
-
-
-#endif
-
-
-//3============================================================
-//3 IQ Calibration
-//3============================================================
-
-VOID
-ODM_ResetIQKResult(
-	IN	PVOID		pDM_VOID 
-)
-{
-	return;
-}
-#if 1//!(DM_ODM_SUPPORT_TYPE & ODM_AP)
-u1Byte ODM_GetRightChnlPlaceforIQK(u1Byte chnl)
-{
-	u1Byte	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = 
-	{1,2,3,4,5,6,7,8,9,10,11,12,13,14,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};
-	u1Byte	place = chnl;
-
-	
-	if(chnl > 14)
-	{
-		for(place = 14; place<sizeof(channel_all); place++)
-		{
-			if(channel_all[place] == chnl)
-			{
-				return place-13;
-			}
-		}
-	}	
-	return 0;
-
-}
-#endif
-
-VOID
-odm_IQCalibrate(
-		IN	PDM_ODM_T	pDM_Odm 
-		)
-{
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	if (*pDM_Odm->pIsFcsModeEnable)
-		return;
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))		
-	if (!IS_HARDWARE_TYPE_JAGUAR(Adapter))
-		return;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	else if (IS_HARDWARE_TYPE_8812AU(Adapter))
-		return;
-#endif
-#endif
-	
-#if (RTL8821A_SUPPORT == 1)
-	if (pDM_Odm->bLinked) {
-		if ((*pDM_Odm->pChannel != pDM_Odm->preChannel) && (!*pDM_Odm->pbScanInProcess)) {
-			pDM_Odm->preChannel = *pDM_Odm->pChannel;
-			pDM_Odm->LinkedInterval = 0;
-		}
-
-		if (pDM_Odm->LinkedInterval < 3)
-			pDM_Odm->LinkedInterval++;
-		
-		if (pDM_Odm->LinkedInterval == 2) {
-			/*Mark out IQK flow to prevent tx stuck. by Maddest 20130306*/
-			/*Open it verified by James 20130715*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-			PHY_IQCalibrate_8821A(pDM_Odm, FALSE);
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			PHY_IQCalibrate(Adapter, FALSE);
-#else
-			PHY_IQCalibrate_8821A(Adapter, FALSE);
-#endif
-		}
-	} else
-		pDM_Odm->LinkedInterval = 0;
-#endif
-}
-
-void phydm_rf_init(IN	PVOID		pDM_VOID)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	odm_TXPowerTrackingInit(pDM_Odm);
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	ODM_ClearTxPowerTrackingState(pDM_Odm);	
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#if (RTL8814A_SUPPORT == 1)		
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		PHY_IQCalibrate_8814A_Init(pDM_Odm);
-#endif	
-#endif
-
-}
-
-void phydm_rf_watchdog(IN	PVOID		pDM_VOID)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	ODM_TXPowerTrackingCheck(pDM_Odm);
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		odm_IQCalibrate(pDM_Odm);
-#endif
-}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ap.h
deleted file mode 100644
index 3fdbc72e4afe..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ap.h
+++ /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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
- #ifndef __HAL_PHY_RF_H__
- #define __HAL_PHY_RF_H__
- 
-#include "phydm_powertracking_ap.h"
-#if (RTL8814A_SUPPORT == 1)
-#include "rtl8814a/phydm_iqk_8814a.h"
-#endif
-
-#if (RTL8822B_SUPPORT == 1)
-#include "rtl8822b/phydm_iqk_8822b.h"
-#endif
-
-
-typedef enum _PWRTRACK_CONTROL_METHOD {
-	BBSWING,
-	TXAGC,
-	MIX_MODE,
-	TSSI_MODE
-} PWRTRACK_METHOD;
-
-typedef VOID 	(*FuncSetPwr)(PVOID, PWRTRACK_METHOD, u1Byte, u1Byte);
-typedef VOID(*FuncIQK)(PVOID, u1Byte, u1Byte, u1Byte);
-typedef VOID 	(*FuncLCK)(PVOID);
-				//refine by YuChen for 8814A
-typedef VOID  	(*FuncSwing)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);
-typedef VOID	(*FuncSwing8814only)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);
-
-typedef struct _TXPWRTRACK_CFG {
-	u1Byte 		SwingTableSize_CCK;	
-	u1Byte 		SwingTableSize_OFDM;
-	u1Byte 		Threshold_IQK;
-	u1Byte 		Threshold_DPK;	
-	u1Byte 		AverageThermalNum;
-	u1Byte 		RfPathCount;
-	u4Byte 		ThermalRegAddr;	
-	FuncSetPwr 	ODM_TxPwrTrackSetPwr;
-	FuncIQK 	DoIQK;
-	FuncLCK		PHY_LCCalibrate;
-	FuncSwing	GetDeltaSwingTable;
-	FuncSwing8814only	GetDeltaSwingTable8814only;
-} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;
-
-VOID 
-ConfigureTxpowerTrack(
-	IN	PVOID		pDM_VOID,
-	OUT	PTXPWRTRACK_CFG	pConfig
-	);
-
-
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	);
-
-#if (RTL8192E_SUPPORT==1) 
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter_92E(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	);
-#endif
-
-#if (RTL8814A_SUPPORT == 1)
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries2(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	);
-
-#elif ODM_IC_11AC_SERIES_SUPPORT
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN	PVOID		pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	);
-#endif
-
-#define IS_CCK_RATE(_rate) 				(ODM_MGN_1M == _rate || _rate == ODM_MGN_2M || _rate == ODM_MGN_5_5M || _rate == ODM_MGN_11M )
-
-
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-#define MAX_TOLERANCE          5
-#define IQK_DELAY_TIME         1               //ms
-
- //
-// BB/MAC/RF other monitor API
-//
-
-void	PHY_SetMonitorMode8192C(IN	PADAPTER	pAdapter,
-										IN	BOOLEAN		bEnableMonitorMode	);
-										
-//
-// IQ calibrate
-//
-void	
-PHY_IQCalibrate_8192C(		IN	PADAPTER	pAdapter,	
-							IN	BOOLEAN 	bReCovery);
-							
-//
-// LC calibrate
-//
-void	
-PHY_LCCalibrate_8192C(		IN	PADAPTER	pAdapter);
-
-//
-// AP calibrate
-//
-void	
-PHY_APCalibrate_8192C(		IN	PADAPTER	pAdapter,
-								IN 	s1Byte		delta);
-#endif
-
-#define ODM_TARGET_CHNL_NUM_2G_5G	59
-
-
-VOID
-ODM_ResetIQKResult(
-	IN	PVOID		pDM_VOID
-);
-u1Byte 
-ODM_GetRightChnlPlaceforIQK(
-    IN u1Byte chnl
-);
-
-void phydm_rf_init(IN	PVOID		pDM_VOID);
-void phydm_rf_watchdog(IN	PVOID		pDM_VOID);
-								
-#endif	// #ifndef __HAL_PHY_RF_H__
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ce.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ce.c
deleted file mode 100644
index adad98ed4716..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ce.c
+++ /dev/null
@@ -1,711 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-
-#define 	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _deltaThermal) \
-					do {\
-						for(_offset = 0; _offset < _size; _offset++)\
-						{\
-							if(_deltaThermal < thermalThreshold[_direction][_offset])\
-							{\
-								if(_offset != 0)\
-									_offset--;\
-								break;\
-							}\
-						}			\
-						if(_offset >= _size)\
-							_offset = _size-1;\
-					} while(0)
-
-void ConfigureTxpowerTrack(
-	IN		PVOID					pDM_VOID,
-	OUT	PTXPWRTRACK_CFG	pConfig
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-#if RTL8192E_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8192E)
-		ConfigureTxpowerTrack_8192E(pConfig);
-#endif	
-#if RTL8821A_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8821)
-		ConfigureTxpowerTrack_8821A(pConfig);
-#endif
-#if RTL8812A_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8812)
-		ConfigureTxpowerTrack_8812A(pConfig);
-#endif
-#if RTL8188E_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8188E)
-		ConfigureTxpowerTrack_8188E(pConfig);
-#endif 
-
-#if RTL8723B_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8723B)
-		ConfigureTxpowerTrack_8723B(pConfig);
-#endif
-
-#if RTL8814A_SUPPORT
-	if (pDM_Odm->SupportICType == ODM_RTL8814A)
-		ConfigureTxpowerTrack_8814A(pConfig);
-#endif
-
-#if RTL8703B_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8703B)
-		ConfigureTxpowerTrack_8703B(pConfig);
-#endif
-
-#if RTL8188F_SUPPORT
-	if (pDM_Odm->SupportICType == ODM_RTL8188F)
-		ConfigureTxpowerTrack_8188F(pConfig);
-#endif 
-}
-
-//======================================================================
-// <20121113, Kordan> This function should be called when TxAGC changed.
-// Otherwise the previous compensation is gone, because we record the 
-// delta of temperature between two TxPowerTracking watch dogs.
-//
-// NOTE: If Tx BB swing or Tx scaling is varified during run-time, still 
-//       need to call this function.
-//======================================================================
-VOID
-ODM_ClearTxPowerTrackingState(
-	IN		PVOID					pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(pDM_Odm->Adapter);
-	u1Byte 			p = 0;
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-	
-	pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->DefaultCckIndex;
-	pRFCalibrateInfo->BbSwingIdxCck = pRFCalibrateInfo->DefaultCckIndex;
-	pDM_Odm->RFCalibrateInfo.CCK_index = 0;
-	
-	for (p = ODM_RF_PATH_A; p < MAX_RF_PATH; ++p)
-	{
-		pRFCalibrateInfo->BbSwingIdxOfdmBase[p] = pRFCalibrateInfo->DefaultOfdmIndex;
-		pRFCalibrateInfo->BbSwingIdxOfdm[p] = pRFCalibrateInfo->DefaultOfdmIndex;
-		pRFCalibrateInfo->OFDM_index[p] = pRFCalibrateInfo->DefaultOfdmIndex;
-
-		pRFCalibrateInfo->PowerIndexOffset[p] = 0;
-		pRFCalibrateInfo->DeltaPowerIndex[p] = 0;
-		pRFCalibrateInfo->DeltaPowerIndexLast[p] = 0;
-		pRFCalibrateInfo->PowerIndexOffset[p] = 0;
-
-		pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = 0;    /* Initial Mix mode power tracking*/
-		pRFCalibrateInfo->Remnant_OFDMSwingIdx[p] = 0;			  
-		pRFCalibrateInfo->KfreeOffset[p] = 0;
-	}
-	
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathA = FALSE;       /*Initial at Modify Tx Scaling Mode*/
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathB = FALSE;       /*Initial at Modify Tx Scaling Mode*/
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathC = FALSE;       /*Initial at Modify Tx Scaling Mode*/
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathD = FALSE;       /*Initial at Modify Tx Scaling Mode*/
-	pRFCalibrateInfo->Remnant_CCKSwingIdx = 0;
-	pRFCalibrateInfo->ThermalValue = pHalData->EEPROMThermalMeter;
-	
-	pRFCalibrateInfo->Modify_TxAGC_Value_CCK=0;			//modify by Mingzhi.Guo
-	pRFCalibrateInfo->Modify_TxAGC_Value_OFDM=0;		//modify by Mingzhi.Guo
-}
-
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm
-#else
-	IN PADAPTER	Adapter
-#endif
-	)
-{
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	#endif
-#endif
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	u1Byte			ThermalValue = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
-	s1Byte			diff_DPK[4] = {0};
-	u1Byte			ThermalValue_AVG_count = 0;
-	u4Byte			ThermalValue_AVG = 0;	
-
-	u1Byte			OFDM_min_index = 0;  // OFDM BB Swing should be less than +3.0dB, which is required by Arthur
-	u1Byte			Indexforchannel = 0; // GetRightChnlPlaceforIQK(pHalData->CurrentChannel)
-	BOOLEAN			bTSSIenable = FALSE;
-
-	TXPWRTRACK_CFG 	c;
-
-	//4 1. The following TWO tables decide the final index of OFDM/CCK swing table.
-	pu1Byte			deltaSwingTableIdx_TUP_A;
-	pu1Byte			deltaSwingTableIdx_TDOWN_A;
-	pu1Byte			deltaSwingTableIdx_TUP_B;
-	pu1Byte			deltaSwingTableIdx_TDOWN_B;
-	/*for 8814 add by Yu Chen*/
-	pu1Byte			deltaSwingTableIdx_TUP_C;
-	pu1Byte			deltaSwingTableIdx_TDOWN_C;
-	pu1Byte			deltaSwingTableIdx_TUP_D;
-	pu1Byte			deltaSwingTableIdx_TDOWN_D;
-	
-	//4 2. Initilization ( 7 steps in total )
-
-	ConfigureTxpowerTrack(pDM_Odm, &c);
-
-	(*c.GetDeltaSwingTable)(pDM_Odm, (pu1Byte*)&deltaSwingTableIdx_TUP_A, (pu1Byte*)&deltaSwingTableIdx_TDOWN_A,
-									  (pu1Byte*)&deltaSwingTableIdx_TUP_B, (pu1Byte*)&deltaSwingTableIdx_TDOWN_B);	
-	
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)	/*for 8814 path C & D*/
-		(*c.GetDeltaSwingTable8814only)(pDM_Odm, (pu1Byte *)&deltaSwingTableIdx_TUP_C, (pu1Byte *)&deltaSwingTableIdx_TDOWN_C,
-			(pu1Byte *)&deltaSwingTableIdx_TUP_D, (pu1Byte *)&deltaSwingTableIdx_TDOWN_D);
-	
-	
-	pDM_Odm->RFCalibrateInfo.TXPowerTrackingCallbackCnt++; //cosa add for debug
-	pDM_Odm->RFCalibrateInfo.bTXPowerTrackingInit = TRUE;
-    
-#if (MP_DRIVER == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = pHalData->TxPowerTrackControl; // <Kordan> We should keep updating the control variable according to HalData.
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (pDM_Odm->mp_mode == TRUE)
-#endif
-		// <Kordan> RFCalibrateInfo.RegA24 will be initialized when ODM HW configuring, but MP configures with para files.
-		pDM_Odm->RFCalibrateInfo.RegA24 = 0x090e1317;
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, 
-		("===>ODM_TXPowerTrackingCallback_ThermalMeter Start\n pRFCalibrateInfo->BbSwingIdxCckBase: %d, pRFCalibrateInfo->BbSwingIdxOfdmBase[A]: %d, pRFCalibrateInfo->DefaultOfdmIndex: %d\n", 
-		pRFCalibrateInfo->BbSwingIdxCckBase, pRFCalibrateInfo->BbSwingIdxOfdmBase[ODM_RF_PATH_A], pRFCalibrateInfo->DefaultOfdmIndex));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, 
-		("pDM_Odm->RFCalibrateInfo.TxPowerTrackControl %d,  pHalData->EEPROMThermalMeter %d\n", pDM_Odm->RFCalibrateInfo.TxPowerTrackControl,  pHalData->EEPROMThermalMeter));
-	ThermalValue = (u1Byte)ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, c.ThermalRegAddr, 0xfc00);	//0x42: RF Reg[15:10] 88E
-	if( ! pDM_Odm->RFCalibrateInfo.TxPowerTrackControl || pHalData->EEPROMThermalMeter == 0 || 
-		pHalData->EEPROMThermalMeter == 0xFF)
-		return;
-
-
-	//4 3. Initialize ThermalValues of RFCalibrateInfo
-
-	if(pDM_Odm->RFCalibrateInfo.bReloadtxpowerindex)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("reload ofdm index for band switch\n"));				
-	}
-
-	//4 4. Calculate average thermal meter
-	
-	pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index] = ThermalValue;
-	pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index++;
-	if(pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index == c.AverageThermalNum)   //Average times =  c.AverageThermalNum
-		pDM_Odm->RFCalibrateInfo.ThermalValue_AVG_index = 0;
-
-	for(i = 0; i < c.AverageThermalNum; i++)
-	{
-		if(pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[i])
-		{
-			ThermalValue_AVG += pDM_Odm->RFCalibrateInfo.ThermalValue_AVG[i];
-			ThermalValue_AVG_count++;
-		}
-	}
-
-	if(ThermalValue_AVG_count)               //Calculate Average ThermalValue after average enough times
-	{
-		ThermalValue = (u1Byte)(ThermalValue_AVG / ThermalValue_AVG_count);
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X, EFUSE Thermal Base = 0x%X\n", ThermalValue, pHalData->EEPROMThermalMeter));					
-	}
-			
-	//4 5. Calculate delta, delta_LCK, delta_IQK.
-
-	//"delta" here is used to determine whether thermal value changes or not.
-	delta 	  = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue):(pDM_Odm->RFCalibrateInfo.ThermalValue - ThermalValue);
-	delta_LCK = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue_LCK)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue_LCK):(pDM_Odm->RFCalibrateInfo.ThermalValue_LCK - ThermalValue);
-	delta_IQK = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue_IQK)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue_IQK):(pDM_Odm->RFCalibrateInfo.ThermalValue_IQK - ThermalValue);
-
-	if (pDM_Odm->RFCalibrateInfo.ThermalValue_IQK == 0xff) {	/*no PG, use thermal value for IQK*/
-		pDM_Odm->RFCalibrateInfo.ThermalValue_IQK = ThermalValue;
-		delta_IQK = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue_IQK)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue_IQK):(pDM_Odm->RFCalibrateInfo.ThermalValue_IQK - ThermalValue);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, use ThermalValue for IQK\n"));
-	}
-	
-	for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-		diff_DPK[p] = (s1Byte)ThermalValue - (s1Byte)pDM_Odm->RFCalibrateInfo.DpkThermal[p];
-
-	/*4 6. If necessary, do LCK.*/	
-	if (!(pDM_Odm->SupportICType & ODM_RTL8821)) {
-
-		if (pDM_Odm->RFCalibrateInfo.ThermalValue_LCK == 0xff) {
-			/*no PG , do LCK at initial status*/
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, do LCK\n"));
-			pDM_Odm->RFCalibrateInfo.ThermalValue_LCK = ThermalValue;
-			if (c.PHY_LCCalibrate)
-				(*c.PHY_LCCalibrate)(pDM_Odm);
-			delta_LCK = (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue_LCK)?(ThermalValue - pDM_Odm->RFCalibrateInfo.ThermalValue_LCK):(pDM_Odm->RFCalibrateInfo.ThermalValue_LCK - ThermalValue);
-		}
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK));
-		/*DBG_871X("(delta, delta_LCK, delta_IQK) = (%d, %d, %d), %d\n", delta, delta_LCK, delta_IQK, c.Threshold_IQK);*/
-		
-		/* 4 6. If necessary, do LCK.*/
-		
-		if (delta_LCK >= c.Threshold_IQK) {
-			/* Delta temperature is equal to or larger than 20 centigrade.*/
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_LCK(%d) >= Threshold_IQK(%d)\n", delta_LCK, c.Threshold_IQK));
-			pDM_Odm->RFCalibrateInfo.ThermalValue_LCK = ThermalValue;
-			if (c.PHY_LCCalibrate)
-				(*c.PHY_LCCalibrate)(pDM_Odm);
-		}
-	}
-	//3 7. If necessary, move the index of swing table to adjust Tx power.	
-	
-	if (delta > 0 && pDM_Odm->RFCalibrateInfo.TxPowerTrackControl)
-	{
-		//"delta" here is used to record the absolute value of differrence.
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))			
-	    delta = ThermalValue > pHalData->EEPROMThermalMeter?(ThermalValue - pHalData->EEPROMThermalMeter):(pHalData->EEPROMThermalMeter - ThermalValue);		
-#else
-	    delta = (ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther)?(ThermalValue - pDM_Odm->priv->pmib->dot11RFEntry.ther):(pDM_Odm->priv->pmib->dot11RFEntry.ther - ThermalValue);		
-#endif
-		if (delta >= TXPWR_TRACK_TABLE_SIZE)
-			delta = TXPWR_TRACK_TABLE_SIZE - 1;
-
-		//4 7.1 The Final Power Index = BaseIndex + PowerIndexOffset
-		
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))				
-		if(ThermalValue > pHalData->EEPROMThermalMeter) {
-#else
-		if(ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther) {
-#endif
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)  {
-				pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast[p] = pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p];	/* recording power index offset */
-				switch (p) {
-				case ODM_RF_PATH_B:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("deltaSwingTableIdx_TUP_B[%d] = %d\n", delta, deltaSwingTableIdx_TUP_B[delta])); 
-
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_B[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = deltaSwingTableIdx_TUP_B[delta];       /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_B] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Temp is higher and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_A] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_A]));  
-
-
-				break;
-
-				case ODM_RF_PATH_C:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("deltaSwingTableIdx_TUP_C[%d] = %d\n", delta, deltaSwingTableIdx_TUP_C[delta]));
-			
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_C[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  deltaSwingTableIdx_TUP_C[delta];       /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_C] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-				break;
-
-				case ODM_RF_PATH_D:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("deltaSwingTableIdx_TUP_D[%d] = %d\n", delta, deltaSwingTableIdx_TUP_D[delta]));
-
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_D[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  deltaSwingTableIdx_TUP_D[delta];       /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_D] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-				break;
-
-				default:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, 
-						("deltaSwingTableIdx_TUP_A[%d] = %d\n", delta, deltaSwingTableIdx_TUP_A[delta]));
-
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_A[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = deltaSwingTableIdx_TUP_A[delta];        /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_A] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));
-				break;
-				}		
-			}
-		} else {
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) {
-				pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast[p] = pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p];	/* recording poer index offset */
-				switch (p) {
-				case ODM_RF_PATH_B:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("deltaSwingTableIdx_TDOWN_B[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_B[delta]));  
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_B[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = -1 * deltaSwingTableIdx_TDOWN_B[delta];        /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_B] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p])); 
-				break;
-					
-				case ODM_RF_PATH_C:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("deltaSwingTableIdx_TDOWN_C[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_C[delta]));  
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_C[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = -1 * deltaSwingTableIdx_TDOWN_C[delta];        /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_C] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));   
-				break;
-
-				case ODM_RF_PATH_D:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("deltaSwingTableIdx_TDOWN_D[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_D[delta]));  
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_D[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  -1 * deltaSwingTableIdx_TDOWN_D[delta];        /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_D] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-				break;
-
-				default:
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("deltaSwingTableIdx_TDOWN_A[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_A[delta]));  
-					pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_A[delta];
-					pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  -1 * deltaSwingTableIdx_TDOWN_A[delta];        /* Record delta swing for mix mode power tracking */
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and pDM_Odm->Absolute_OFDMSwingIdx[ODM_RF_PATH_A] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-				break;
-				}	
-			}
-		}
-		
-		for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("\n\n=========================== [Path-%d] Calculating PowerIndexOffset===========================\n", p));  
-			if (pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] == pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast[p])         /* If Thermal value changes but lookup table value still the same */
-				pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p] = 0;
-			else
-				pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p] = pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p] - pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast[p];      /* Power Index Diff between 2 times Power Tracking */
-
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("[Path-%d] PowerIndexOffset(%d) = DeltaPowerIndex(%d) - DeltaPowerIndexLast(%d)\n", p, pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p], pDM_Odm->RFCalibrateInfo.DeltaPowerIndex[p], pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast[p]));		
-		
-			pDM_Odm->RFCalibrateInfo.OFDM_index[p] = pRFCalibrateInfo->BbSwingIdxOfdmBase[p] + pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p];
-			pDM_Odm->RFCalibrateInfo.CCK_index = pRFCalibrateInfo->BbSwingIdxCckBase + pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p];
-
-			pRFCalibrateInfo->BbSwingIdxCck = pDM_Odm->RFCalibrateInfo.CCK_index;	
-			pRFCalibrateInfo->BbSwingIdxOfdm[p] = pDM_Odm->RFCalibrateInfo.OFDM_index[p];
-
-
-
-			/* *************Print BB Swing Base and Index Offset************* */
-
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'CCK' final index(%d) = BaseIndex(%d) + PowerIndexOffset(%d)\n", pRFCalibrateInfo->BbSwingIdxCck, pRFCalibrateInfo->BbSwingIdxCckBase, pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p]));
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'OFDM' final index(%d) = BaseIndex[%d](%d) + PowerIndexOffset(%d)\n", pRFCalibrateInfo->BbSwingIdxOfdm[p], p, pRFCalibrateInfo->BbSwingIdxOfdmBase[p], pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p]));
-
-		    //4 7.1 Handle boundary conditions of index.
-		
-			if(pDM_Odm->RFCalibrateInfo.OFDM_index[p] > c.SwingTableSize_OFDM-1)
-			{
-				pDM_Odm->RFCalibrateInfo.OFDM_index[p] = c.SwingTableSize_OFDM-1;
-			}
-			else if (pDM_Odm->RFCalibrateInfo.OFDM_index[p] < OFDM_min_index)
-			{
-				pDM_Odm->RFCalibrateInfo.OFDM_index[p] = OFDM_min_index;
-			}
-		}
-		
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("\n\n========================================================================================================\n"));  
-		if(pDM_Odm->RFCalibrateInfo.CCK_index > c.SwingTableSize_CCK-1)
-			pDM_Odm->RFCalibrateInfo.CCK_index = c.SwingTableSize_CCK-1;
-		else if (pDM_Odm->RFCalibrateInfo.CCK_index <= 0)
-			pDM_Odm->RFCalibrateInfo.CCK_index = 0;
-	} else {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("The thermal meter is unchanged or TxPowerTracking OFF(%d): ThermalValue: %d , pDM_Odm->RFCalibrateInfo.ThermalValue: %d\n", 
-			pDM_Odm->RFCalibrateInfo.TxPowerTrackControl, ThermalValue, pDM_Odm->RFCalibrateInfo.ThermalValue));
-		
-	    for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 		
-		    pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p] = 0;
-	}
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("TxPowerTracking: [CCK] Swing Current Index: %d, Swing Base Index: %d\n", 
-		pDM_Odm->RFCalibrateInfo.CCK_index, pRFCalibrateInfo->BbSwingIdxCckBase));       /*Print Swing base & current*/
-			
-	for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("TxPowerTracking: [OFDM] Swing Current Index: %d, Swing Base Index[%d]: %d\n",
-			pDM_Odm->RFCalibrateInfo.OFDM_index[p], p, pRFCalibrateInfo->BbSwingIdxOfdmBase[p]));
-	}
-	
-	if ((pDM_Odm->RFCalibrateInfo.PowerIndexOffset[ODM_RF_PATH_A] != 0 ||
-		pDM_Odm->RFCalibrateInfo.PowerIndexOffset[ODM_RF_PATH_B] != 0 ||
-		pDM_Odm->RFCalibrateInfo.PowerIndexOffset[ODM_RF_PATH_C] != 0 ||
-		pDM_Odm->RFCalibrateInfo.PowerIndexOffset[ODM_RF_PATH_D] != 0) && 
-		pDM_Odm->RFCalibrateInfo.TxPowerTrackControl && (pHalData->EEPROMThermalMeter != 0xff))
-	{
-		//4 7.2 Configure the Swing Table to adjust Tx Power.
-		
-		pDM_Odm->RFCalibrateInfo.bTxPowerChanged = TRUE; // Always TRUE after Tx Power is adjusted by power tracking.			
-		//
-		// 2012/04/23 MH According to Luke's suggestion, we can not write BB digital
-		// to increase TX power. Otherwise, EVM will be bad.
-		//
-		// 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E.
-		if (ThermalValue > pDM_Odm->RFCalibrateInfo.ThermalValue)
-		{
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Increasing(%d): delta_pi: %d , delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", 
-					p, pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p], delta, ThermalValue, pHalData->EEPROMThermalMeter, pDM_Odm->RFCalibrateInfo.ThermalValue));	
-			}
-		}
-		else if (ThermalValue < pDM_Odm->RFCalibrateInfo.ThermalValue)// Low temperature
-		{
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Decreasing(%d): delta_pi: %d , delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, pDM_Odm->RFCalibrateInfo.PowerIndexOffset[p], delta, ThermalValue, pHalData->EEPROMThermalMeter, pDM_Odm->RFCalibrateInfo.ThermalValue));				
-			}
-		}
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		if (ThermalValue > pHalData->EEPROMThermalMeter)
-#else
-		if (ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther)
-#endif
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) higher than PG value(%d)\n", ThermalValue, pHalData->EEPROMThermalMeter));			
-
-			if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8821 ||
-				pDM_Odm->SupportICType == ODM_RTL8812 || pDM_Odm->SupportICType == ODM_RTL8723B || pDM_Odm->SupportICType == ODM_RTL8814A ||
-				pDM_Odm->SupportICType == ODM_RTL8822B || pDM_Odm->SupportICType == ODM_RTL8188F || pDM_Odm->SupportICType == ODM_RTL8703B) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-						(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, MIX_MODE, p, 0);
-			}
-			else 
-			{
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking BBSWING_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-						(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, p, Indexforchannel);
-			}
-		}
-		else
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) lower than PG value(%d)\n", ThermalValue, pHalData->EEPROMThermalMeter));
-
-			if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8821 ||
-				pDM_Odm->SupportICType == ODM_RTL8812 || pDM_Odm->SupportICType == ODM_RTL8723B || pDM_Odm->SupportICType == ODM_RTL8814A ||
-				pDM_Odm->SupportICType == ODM_RTL8822B || pDM_Odm->SupportICType == ODM_RTL8188F || pDM_Odm->SupportICType == ODM_RTL8703B) {
-			
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, MIX_MODE, p, Indexforchannel);
-			}
-			else
-			{
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking BBSWING_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, p, Indexforchannel);
-			}
-			
-		}
-
-		pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->BbSwingIdxCck;    /*Record last time Power Tracking result as base.*/
-		for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-				pRFCalibrateInfo->BbSwingIdxOfdmBase[p] = pRFCalibrateInfo->BbSwingIdxOfdm[p];
-
-	 	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("pDM_Odm->RFCalibrateInfo.ThermalValue = %d ThermalValue= %d\n", pDM_Odm->RFCalibrateInfo.ThermalValue, ThermalValue));
-		
-		pDM_Odm->RFCalibrateInfo.ThermalValue = ThermalValue;         /*Record last Power Tracking Thermal Value*/
-
-	}
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		
-	if (!IS_HARDWARE_TYPE_8723B(Adapter) && !IS_HARDWARE_TYPE_8192E(Adapter) && !IS_HARDWARE_TYPE_8703B(Adapter)) {
-		/* Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
-		if (delta_IQK >= c.Threshold_IQK) {
-			if (!pDM_Odm->RFCalibrateInfo.bIQKInProgress) 
-				(*c.DoIQK)(pDM_Odm, delta_IQK, ThermalValue, 8);
-		}
-	}	
-	if (!(pDM_Odm->SupportICType & ODM_RTL8814A)) {
-		if (pDM_Odm->RFCalibrateInfo.DpkThermal[ODM_RF_PATH_A] != 0) {
-			if (diff_DPK[ODM_RF_PATH_A] >= c.Threshold_DPK) { 
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-				ODM_SetBBReg(pDM_Odm, 0xcc4, BIT14|BIT13|BIT12|BIT11|BIT10, (diff_DPK[ODM_RF_PATH_A] / c.Threshold_DPK));
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-			} else if ((diff_DPK[ODM_RF_PATH_A] <= -1 * c.Threshold_DPK)) {
-				s4Byte value = 0x20 + (diff_DPK[ODM_RF_PATH_A] / c.Threshold_DPK);
-
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-				ODM_SetBBReg(pDM_Odm, 0xcc4, BIT14|BIT13|BIT12|BIT11|BIT10, value);
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-			} else {
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-				ODM_SetBBReg(pDM_Odm, 0xcc4, BIT14|BIT13|BIT12|BIT11|BIT10, 0);
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);	
-			}
-		}
-		if (pDM_Odm->RFCalibrateInfo.DpkThermal[ODM_RF_PATH_B] != 0) {
-			if (diff_DPK[ODM_RF_PATH_B] >= c.Threshold_DPK) { 
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-				ODM_SetBBReg(pDM_Odm, 0xec4, BIT14|BIT13|BIT12|BIT11|BIT10, (diff_DPK[ODM_RF_PATH_B] / c.Threshold_DPK));
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-			} else if ((diff_DPK[ODM_RF_PATH_B] <= -1 * c.Threshold_DPK)) {
-				s4Byte value = 0x20 + (diff_DPK[ODM_RF_PATH_B] / c.Threshold_DPK);	
-				
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-				ODM_SetBBReg(pDM_Odm, 0xec4, BIT14|BIT13|BIT12|BIT11|BIT10, value);
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-			} else {
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-				ODM_SetBBReg(pDM_Odm, 0xec4, BIT14|BIT13|BIT12|BIT11|BIT10, 0);
-				ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);	
-			}
-		}
-	}
-
-#endif		
-			
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("<===ODM_TXPowerTrackingCallback_ThermalMeter End\n"));
-	
-	pDM_Odm->RFCalibrateInfo.TXPowercount = 0;
-}
-
-
-//3============================================================
-//3 IQ Calibration
-//3============================================================
-
-VOID
-ODM_ResetIQKResult(
-	IN		PVOID					pDM_VOID
-)
-{
-	return;
-
-}
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-u1Byte ODM_GetRightChnlPlaceforIQK(u1Byte chnl)
-{
-	u1Byte	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = 
-	{1,2,3,4,5,6,7,8,9,10,11,12,13,14,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};
-	u1Byte	place = chnl;
-
-	
-	if(chnl > 14)
-	{
-		for(place = 14; place<sizeof(channel_all); place++)
-		{
-			if(channel_all[place] == chnl)
-			{
-				return place-13;
-			}
-		}
-	}	
-	return 0;
-
-}
-#endif
-
-VOID
-odm_IQCalibrate(
-		IN	PDM_ODM_T	pDM_Odm 
-		)
-{
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	if (*pDM_Odm->pIsFcsModeEnable)
-		return;
-#endif
-	
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))		
-	if (!IS_HARDWARE_TYPE_JAGUAR(Adapter))
-		return;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	else if (IS_HARDWARE_TYPE_8812AU(Adapter))
-		return;
-#endif
-#endif
-	
-#if (RTL8821A_SUPPORT == 1)
-	if (pDM_Odm->bLinked) {
-		if ((*pDM_Odm->pChannel != pDM_Odm->preChannel) && (!*pDM_Odm->pbScanInProcess)) {
-			pDM_Odm->preChannel = *pDM_Odm->pChannel;
-			pDM_Odm->LinkedInterval = 0;
-		}
-
-		if (pDM_Odm->LinkedInterval < 3)
-			pDM_Odm->LinkedInterval++;
-		
-		if (pDM_Odm->LinkedInterval == 2) {
-			/*Mark out IQK flow to prevent tx stuck. by Maddest 20130306*/
-			/*Open it verified by James 20130715*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-			/*Change channel will do IQK , cancel duplicate doIQK by YiWei*/
-			/*PHY_IQCalibrate_8821A(pDM_Odm, FALSE);*/
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			PHY_IQCalibrate(Adapter, FALSE);
-#else
-			PHY_IQCalibrate_8821A(Adapter, FALSE);
-#endif
-		}
-	} else
-		pDM_Odm->LinkedInterval = 0;
-#endif
-}
-
-void phydm_rf_init(IN	PVOID		pDM_VOID)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	odm_TXPowerTrackingInit(pDM_Odm);
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	ODM_ClearTxPowerTrackingState(pDM_Odm);	
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#if (RTL8814A_SUPPORT == 1)		
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		PHY_IQCalibrate_8814A_Init(pDM_Odm);
-#endif	
-#endif
-
-}
-
-void phydm_rf_watchdog(IN	PVOID		pDM_VOID)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	ODM_TXPowerTrackingCheck(pDM_Odm);
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		odm_IQCalibrate(pDM_Odm);
-#endif
-}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ce.h
deleted file mode 100644
index 78333d634c70..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_ce.h
+++ /dev/null
@@ -1,106 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
- #ifndef __HAL_PHY_RF_H__
- #define __HAL_PHY_RF_H__
- 
-/*#include "phydm_kfree.h"*/
-#if (RTL8814A_SUPPORT == 1)
-#include "rtl8814a/phydm_iqk_8814a.h"
-#endif
-
-#if (RTL8822B_SUPPORT == 1)
-#include "rtl8822b/phydm_iqk_8822b.h"
-#endif
-#include "phydm_powertracking_ce.h"
-
-
-typedef enum _SPUR_CAL_METHOD {
-	PLL_RESET,
-	AFE_PHASE_SEL
-} SPUR_CAL_METHOD;
-
-typedef enum _PWRTRACK_CONTROL_METHOD {
-	BBSWING,
-	TXAGC,
-	MIX_MODE,
-	TSSI_MODE
-} PWRTRACK_METHOD;
-
-typedef VOID 	(*FuncSetPwr)(PVOID, PWRTRACK_METHOD, u1Byte, u1Byte);
-typedef VOID(*FuncIQK)(PVOID, u1Byte, u1Byte, u1Byte);
-typedef VOID 	(*FuncLCK)(PVOID);
-typedef VOID  	(*FuncSwing)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);
-typedef VOID	(*FuncSwing8814only)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);
-
-typedef struct _TXPWRTRACK_CFG {
-	u1Byte 		SwingTableSize_CCK;	
-	u1Byte 		SwingTableSize_OFDM;
-	u1Byte 		Threshold_IQK;	
-	u1Byte		Threshold_DPK;
-	u1Byte 		AverageThermalNum;
-	u1Byte 		RfPathCount;
-	u4Byte 		ThermalRegAddr;	
-	FuncSetPwr 	ODM_TxPwrTrackSetPwr;
-	FuncIQK 	DoIQK;
-	FuncLCK		PHY_LCCalibrate;
-	FuncSwing	GetDeltaSwingTable;
-	FuncSwing8814only	GetDeltaSwingTable8814only;
-} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;
-
-void ConfigureTxpowerTrack(
-	IN		PVOID					pDM_VOID,
-	OUT	PTXPWRTRACK_CFG	pConfig
-	);
-
-
-VOID
-ODM_ClearTxPowerTrackingState(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN		PVOID					pDM_VOID
-#else
-	IN PADAPTER	Adapter
-#endif
-	);
-
-
-
-#define ODM_TARGET_CHNL_NUM_2G_5G	59
-
-
-VOID
-ODM_ResetIQKResult(
-	IN		PVOID					pDM_VOID
-);
-u1Byte 
-ODM_GetRightChnlPlaceforIQK(
-    IN u1Byte chnl
-);
-
-void phydm_rf_init(	IN		PVOID					pDM_VOID);
-void phydm_rf_watchdog(	IN		PVOID					pDM_VOID);
-								
-#endif	// #ifndef __HAL_PHY_RF_H__
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_win.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_win.c
deleted file mode 100644
index 32f39858b624..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_win.c
+++ /dev/null
@@ -1,716 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
- #include "mp_precomp.h"
- #include "phydm_precomp.h"
-
-//#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
-#define 	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _deltaThermal) \
-					do {\
-						for(_offset = 0; _offset < _size; _offset++)\
-						{\
-							if(_deltaThermal < thermalThreshold[_direction][_offset])\
-							{\
-								if(_offset != 0)\
-									_offset--;\
-								break;\
-							}\
-						}			\
-						if(_offset >= _size)\
-							_offset = _size-1;\
-					} while(0)
-
-
-void ConfigureTxpowerTrack(
-	IN 	PDM_ODM_T		pDM_Odm,
-	OUT	PTXPWRTRACK_CFG	pConfig
-	)
-{
-#if RTL8192E_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8192E)
-		ConfigureTxpowerTrack_8192E(pConfig);
-#endif	
-#if RTL8821A_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8821)
-		ConfigureTxpowerTrack_8821A(pConfig);
-#endif
-#if RTL8812A_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8812)
-		ConfigureTxpowerTrack_8812A(pConfig);
-#endif
-#if RTL8188E_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8188E)
-		ConfigureTxpowerTrack_8188E(pConfig);
-#endif 
-
-#if RTL8188F_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8188F)
-		ConfigureTxpowerTrack_8188F(pConfig);
-#endif 
-
-#if RTL8723B_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8723B)
-		ConfigureTxpowerTrack_8723B(pConfig);
-#endif
-
-#if RTL8814A_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8814A)
-		ConfigureTxpowerTrack_8814A(pConfig);
-#endif
-
-#if RTL8821B_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8821B)
-		ConfigureTxpowerTrack_8821B(pConfig);
-#endif
-
-#if RTL8703B_SUPPORT
-	if(pDM_Odm->SupportICType==ODM_RTL8703B)
-		ConfigureTxpowerTrack_8703B(pConfig);
-#endif
-
-}
-
-//======================================================================
-// <20121113, Kordan> This function should be called when TxAGC changed.
-// Otherwise the previous compensation is gone, because we record the 
-// delta of temperature between two TxPowerTracking watch dogs.
-//
-// NOTE: If Tx BB swing or Tx scaling is varified during run-time, still 
-//       need to call this function.
-//======================================================================
-VOID
-ODM_ClearTxPowerTrackingState(
-	IN PDM_ODM_T		pDM_Odm
-	)
-{
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(pDM_Odm->Adapter);
-	u1Byte 			p = 0;
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-	
-	pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->DefaultCckIndex;
-	pRFCalibrateInfo->BbSwingIdxCck = pRFCalibrateInfo->DefaultCckIndex;
-	pRFCalibrateInfo->CCK_index = 0;
-	
-	for (p = ODM_RF_PATH_A; p < MAX_RF_PATH; ++p)
-	{
-		pRFCalibrateInfo->BbSwingIdxOfdmBase[p] = pRFCalibrateInfo->DefaultOfdmIndex;
-		pRFCalibrateInfo->BbSwingIdxOfdm[p] = pRFCalibrateInfo->DefaultOfdmIndex;
-	   	pRFCalibrateInfo->OFDM_index[p] = pRFCalibrateInfo->DefaultOfdmIndex;
-
-		pRFCalibrateInfo->PowerIndexOffset[p] = 0;
-		pRFCalibrateInfo->DeltaPowerIndex[p] = 0;
-		pRFCalibrateInfo->DeltaPowerIndexLast[p] = 0;
-
-		pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] = 0;    // Initial Mix mode power tracking
-		pRFCalibrateInfo->Remnant_OFDMSwingIdx[p] = 0;			  
-		pRFCalibrateInfo->KfreeOffset[p] = 0;			  
-	}
-	
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathA= FALSE;       //Initial at Modify Tx Scaling Mode
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathB= FALSE;       //Initial at Modify Tx Scaling Mode
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathC= FALSE;       //Initial at Modify Tx Scaling Mode
-	pRFCalibrateInfo->Modify_TxAGC_Flag_PathD= FALSE;       //Initial at Modify Tx Scaling Mode
-	pRFCalibrateInfo->Remnant_CCKSwingIdx= 0;
-	pRFCalibrateInfo->ThermalValue = pHalData->EEPROMThermalMeter;
-
-	pRFCalibrateInfo->Modify_TxAGC_Value_CCK=0;			//modify by Mingzhi.Guo
-	pRFCalibrateInfo->Modify_TxAGC_Value_OFDM=0;		//modify by Mingzhi.Guo
-
-}
-
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm
-#else
-	IN PADAPTER	Adapter
-#endif
-	)
-{
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm	  = &pHalData->DM_OutSrc;
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-#endif
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-	
-	u1Byte			ThermalValue = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0, pathName = 0;
-	s1Byte			diff_DPK[4] = {0};
-	u1Byte			ThermalValue_AVG_count = 0;
-	u4Byte			ThermalValue_AVG = 0;	
-
-	u1Byte			OFDM_min_index = 0;  // OFDM BB Swing should be less than +3.0dB, which is required by Arthur
-	u1Byte			Indexforchannel = 0; // GetRightChnlPlaceforIQK(pHalData->CurrentChannel)
-	BOOLEAN			bTSSIenable = FALSE;
-
-	TXPWRTRACK_CFG 	c;
-	
-	//4 1. The following TWO tables decide the final index of OFDM/CCK swing table.
-	pu1Byte			deltaSwingTableIdx_TUP_A, deltaSwingTableIdx_TDOWN_A;
-	pu1Byte			deltaSwingTableIdx_TUP_B, deltaSwingTableIdx_TDOWN_B;
-	//for 8814 add by Yu Chen
-	pu1Byte			deltaSwingTableIdx_TUP_C = NULL, deltaSwingTableIdx_TDOWN_C = NULL;
-	pu1Byte			deltaSwingTableIdx_TUP_D= NULL, deltaSwingTableIdx_TDOWN_D = NULL;
-		
-	//4 2. Initilization ( 7 steps in total )
-
-	ConfigureTxpowerTrack(pDM_Odm, &c);
-	
-	(*c.GetDeltaSwingTable)(pDM_Odm, (pu1Byte*)&deltaSwingTableIdx_TUP_A, (pu1Byte*)&deltaSwingTableIdx_TDOWN_A,
-									  (pu1Byte*)&deltaSwingTableIdx_TUP_B, (pu1Byte*)&deltaSwingTableIdx_TDOWN_B);
-
-	if(pDM_Odm->SupportICType & ODM_RTL8814A)	// for 8814 path C & D
-	(*c.GetDeltaSwingTable8814only)(pDM_Odm, (pu1Byte*)&deltaSwingTableIdx_TUP_C, (pu1Byte*)&deltaSwingTableIdx_TDOWN_C,
-									  (pu1Byte*)&deltaSwingTableIdx_TUP_D, (pu1Byte*)&deltaSwingTableIdx_TDOWN_D);
-	
-	
-	pRFCalibrateInfo->TXPowerTrackingCallbackCnt++; //cosa add for debug
-	pRFCalibrateInfo->bTXPowerTrackingInit = TRUE;
-   
-#if (MP_DRIVER == 1)      
-    /*pRFCalibrateInfo->TxPowerTrackControl = pHalData->TxPowerTrackControl;
-    <Kordan> We should keep updating the control variable according to HalData. 
-    <Kordan> RFCalibrateInfo.RegA24 will be initialized when ODM HW configuring, but MP configures with para files. */
-    pRFCalibrateInfo->RegA24 = 0x090e1317; 
-#endif
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("===>ODM_TXPowerTrackingCallback_ThermalMeter, \
-		 \n pRFCalibrateInfo->BbSwingIdxCckBase: %d, pRFCalibrateInfo->BbSwingIdxOfdmBase[A]: %d, pRFCalibrateInfo->DefaultOfdmIndex: %d\n", 
-		pRFCalibrateInfo->BbSwingIdxCckBase, pRFCalibrateInfo->BbSwingIdxOfdmBase[ODM_RF_PATH_A], pRFCalibrateInfo->DefaultOfdmIndex));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, 
-		("pRFCalibrateInfo->TxPowerTrackControl %d,  pHalData->EEPROMThermalMeter %d\n", pRFCalibrateInfo->TxPowerTrackControl,  pHalData->EEPROMThermalMeter));
-	ThermalValue = (u1Byte)ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, c.ThermalRegAddr, 0xfc00);	//0x42: RF Reg[15:10] 88E
-
-
-	if( ! pRFCalibrateInfo->TxPowerTrackControl )
-        	return;
-
-
-	//4 3. Initialize ThermalValues of RFCalibrateInfo
-
-	if(pRFCalibrateInfo->bReloadtxpowerindex)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("reload ofdm index for band switch\n"));				
-	}
-
-	//4 4. Calculate average thermal meter
-	
-	pRFCalibrateInfo->ThermalValue_AVG[pRFCalibrateInfo->ThermalValue_AVG_index] = ThermalValue;
-	pRFCalibrateInfo->ThermalValue_AVG_index++;
-	if(pRFCalibrateInfo->ThermalValue_AVG_index == c.AverageThermalNum)   //Average times =  c.AverageThermalNum
-		pRFCalibrateInfo->ThermalValue_AVG_index = 0;
-
-	for(i = 0; i < c.AverageThermalNum; i++)
-	{
-		if(pRFCalibrateInfo->ThermalValue_AVG[i])
-		{
-			ThermalValue_AVG += pRFCalibrateInfo->ThermalValue_AVG[i];
-			ThermalValue_AVG_count++;
-		}
-	}
-
-	if(ThermalValue_AVG_count)               //Calculate Average ThermalValue after average enough times
-	{
-		ThermalValue = (u1Byte)(ThermalValue_AVG / ThermalValue_AVG_count);
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X, EFUSE Thermal Base = 0x%X\n", ThermalValue, pHalData->EEPROMThermalMeter));					
-	}
-			
-	//4 5. Calculate delta, delta_LCK, delta_IQK.
-
-	//"delta" here is used to determine whether thermal value changes or not.
-	delta 	  = (ThermalValue > pRFCalibrateInfo->ThermalValue)?(ThermalValue - pRFCalibrateInfo->ThermalValue):(pRFCalibrateInfo->ThermalValue - ThermalValue);
-	delta_LCK = (ThermalValue > pRFCalibrateInfo->ThermalValue_LCK)?(ThermalValue - pRFCalibrateInfo->ThermalValue_LCK):(pRFCalibrateInfo->ThermalValue_LCK - ThermalValue);
-	delta_IQK = (ThermalValue > pRFCalibrateInfo->ThermalValue_IQK)?(ThermalValue - pRFCalibrateInfo->ThermalValue_IQK):(pRFCalibrateInfo->ThermalValue_IQK - ThermalValue);
-
-	if(pRFCalibrateInfo->ThermalValue_IQK == 0xff)	//no PG, use thermal value for IQK
-	{
-		pRFCalibrateInfo->ThermalValue_IQK = ThermalValue;
-		delta_IQK = (ThermalValue > pRFCalibrateInfo->ThermalValue_IQK)?(ThermalValue - pRFCalibrateInfo->ThermalValue_IQK):(pRFCalibrateInfo->ThermalValue_IQK - ThermalValue);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, use ThermalValue for IQK\n"));
-	}
-	
-	for(p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-		{
-		diff_DPK[p] = (s1Byte)ThermalValue - (s1Byte)pRFCalibrateInfo->DpkThermal[p];
-		}
-
-	//4 6. If necessary, do LCK.	
-
-	if (!(pDM_Odm->SupportICType & ODM_RTL8821)) {
-		/*no PG , do LCK at initial status*/
-		if (pRFCalibrateInfo->ThermalValue_LCK == 0xff) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, do LCK\n"));
-		pRFCalibrateInfo->ThermalValue_LCK = ThermalValue;
-		if(c.PHY_LCCalibrate)
-			(*c.PHY_LCCalibrate)(pDM_Odm);
-		delta_LCK = (ThermalValue > pRFCalibrateInfo->ThermalValue_LCK)?(ThermalValue - pRFCalibrateInfo->ThermalValue_LCK):(pRFCalibrateInfo->ThermalValue_LCK - ThermalValue);
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK));
-	
-		 /* Delta temperature is equal to or larger than 20 centigrade.*/
-		if (delta_LCK >= c.Threshold_IQK) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_LCK(%d) >= Threshold_IQK(%d)\n", delta_LCK, c.Threshold_IQK));
-		pRFCalibrateInfo->ThermalValue_LCK = ThermalValue;
-		if(c.PHY_LCCalibrate)
-			(*c.PHY_LCCalibrate)(pDM_Odm);
-	}
-	}
-
-	//3 7. If necessary, move the index of swing table to adjust Tx power.	
-	
-	if (delta > 0 && pRFCalibrateInfo->TxPowerTrackControl)
-	{
-		//"delta" here is used to record the absolute value of differrence.
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))			
-	    delta = ThermalValue > pHalData->EEPROMThermalMeter?(ThermalValue - pHalData->EEPROMThermalMeter):(pHalData->EEPROMThermalMeter - ThermalValue);		
-#else
-	    delta = (ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther)?(ThermalValue - pDM_Odm->priv->pmib->dot11RFEntry.ther):(pDM_Odm->priv->pmib->dot11RFEntry.ther - ThermalValue);		
-#endif
-		if (delta >= TXPWR_TRACK_TABLE_SIZE)
-			delta = TXPWR_TRACK_TABLE_SIZE - 1;
-
-		//4 7.1 The Final Power Index = BaseIndex + PowerIndexOffset
-		
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))				
-		if(ThermalValue > pHalData->EEPROMThermalMeter) {
-#else
-		if(ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther) {
-#endif
-
-		for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 
-			{
-			pRFCalibrateInfo->DeltaPowerIndexLast[p] = pRFCalibrateInfo->DeltaPowerIndex[p];	//recording poer index offset
-			switch(p)
-				{
-					case ODM_RF_PATH_B:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-	                                    	("deltaSwingTableIdx_TUP_B[%d] = %d\n", delta, deltaSwingTableIdx_TUP_B[delta])); 
-						
-						pRFCalibrateInfo->DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_B[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  deltaSwingTableIdx_TUP_B[delta];       // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_B] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					case ODM_RF_PATH_C:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-	                                    	("deltaSwingTableIdx_TUP_C[%d] = %d\n", delta, deltaSwingTableIdx_TUP_C[delta]));
-						
-						pRFCalibrateInfo->DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_C[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  deltaSwingTableIdx_TUP_C[delta];       // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_C] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					case ODM_RF_PATH_D:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-	                                   	 ("deltaSwingTableIdx_TUP_D[%d] = %d\n", delta, deltaSwingTableIdx_TUP_D[delta]));
-						
-						pRFCalibrateInfo->DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_D[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  deltaSwingTableIdx_TUP_D[delta];       // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_D] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					default:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, 
-	                                 	   	("deltaSwingTableIdx_TUP_A[%d] = %d\n", delta, deltaSwingTableIdx_TUP_A[delta]));
-						
-						pRFCalibrateInfo->DeltaPowerIndex[p] = deltaSwingTableIdx_TUP_A[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  deltaSwingTableIdx_TUP_A[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_A] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-				}	
-				
-			}
-			
-        } 
-		else {
-
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 
-			{
-			pRFCalibrateInfo->DeltaPowerIndexLast[p] = pRFCalibrateInfo->DeltaPowerIndex[p];	//recording poer index offset
-			switch(p)
-				{
-					case ODM_RF_PATH_B:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-               	 				("deltaSwingTableIdx_TDOWN_B[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_B[delta]));  
-						pRFCalibrateInfo->DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_B[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  -1 * deltaSwingTableIdx_TDOWN_B[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_B] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p])); 
-					break;
-
-					case ODM_RF_PATH_C:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-               	 				("deltaSwingTableIdx_TDOWN_C[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_C[delta]));  
-						pRFCalibrateInfo->DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_C[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  -1 * deltaSwingTableIdx_TDOWN_C[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_C] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));   
-					break;
-
-					case ODM_RF_PATH_D:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-               	 				("deltaSwingTableIdx_TDOWN_D[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_D[delta]));  
-						pRFCalibrateInfo->DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_D[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  -1 * deltaSwingTableIdx_TDOWN_D[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_D] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-
-					default:
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-               	 				("deltaSwingTableIdx_TDOWN_A[%d] = %d\n", delta, deltaSwingTableIdx_TDOWN_A[delta]));  
-						pRFCalibrateInfo->DeltaPowerIndex[p] = -1 * deltaSwingTableIdx_TDOWN_A[delta];
-						pRFCalibrateInfo->Absolute_OFDMSwingIdx[p] =  -1 * deltaSwingTableIdx_TDOWN_A[delta];        // Record delta swing for mix mode power tracking
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRFCalibrateInfo->Absolute_OFDMSwingIdx[ODM_RF_PATH_A] = %d\n", pRFCalibrateInfo->Absolute_OFDMSwingIdx[p]));  
-					break;
-				}	
-				
-			}
-			
-        }
-		
-	   for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 		
-        	{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("\n\n=========================== [Path-%d] Calculating PowerIndexOffset===========================\n", p));  
-			
-		    if(pRFCalibrateInfo->DeltaPowerIndex[p] == pRFCalibrateInfo->DeltaPowerIndexLast[p])         // If Thermal value changes but lookup table value still the same
-		    	pRFCalibrateInfo->PowerIndexOffset[p] = 0;
-		    else
-		    	pRFCalibrateInfo->PowerIndexOffset[p] = pRFCalibrateInfo->DeltaPowerIndex[p] - pRFCalibrateInfo->DeltaPowerIndexLast[p];      // Power Index Diff between 2 times Power Tracking
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("[Path-%d] PowerIndexOffset(%d) = DeltaPowerIndex(%d) - DeltaPowerIndexLast(%d)\n", p, pRFCalibrateInfo->PowerIndexOffset[p], pRFCalibrateInfo->DeltaPowerIndex[p], pRFCalibrateInfo->DeltaPowerIndexLast[p]));		
-		
-			pRFCalibrateInfo->OFDM_index[p] = pRFCalibrateInfo->BbSwingIdxOfdmBase[p] + pRFCalibrateInfo->PowerIndexOffset[p];
-			pRFCalibrateInfo->CCK_index = pRFCalibrateInfo->BbSwingIdxCckBase + pRFCalibrateInfo->PowerIndexOffset[p];
-
-			pRFCalibrateInfo->BbSwingIdxCck = pRFCalibrateInfo->CCK_index;	
-			pRFCalibrateInfo->BbSwingIdxOfdm[p] = pRFCalibrateInfo->OFDM_index[p];	
-
-	           // *************Print BB Swing Base and Index Offset*************
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'CCK' final index(%d) = BaseIndex(%d) + PowerIndexOffset(%d)\n", pRFCalibrateInfo->BbSwingIdxCck, pRFCalibrateInfo->BbSwingIdxCckBase, pRFCalibrateInfo->PowerIndexOffset[p]));
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'OFDM' final index(%d) = BaseIndex[%d](%d) + PowerIndexOffset(%d)\n", pRFCalibrateInfo->BbSwingIdxOfdm[p], p, pRFCalibrateInfo->BbSwingIdxOfdmBase[p], pRFCalibrateInfo->PowerIndexOffset[p]));
-
-		    //4 7.1 Handle boundary conditions of index.
-		
-			if(pRFCalibrateInfo->OFDM_index[p] > c.SwingTableSize_OFDM-1)
-			{
-				pRFCalibrateInfo->OFDM_index[p] = c.SwingTableSize_OFDM-1;
-			}
-			else if (pRFCalibrateInfo->OFDM_index[p] <= OFDM_min_index)
-			{
-				pRFCalibrateInfo->OFDM_index[p] = OFDM_min_index;
-			}
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-            ("\n\n========================================================================================================\n"));  
-		if(pRFCalibrateInfo->CCK_index > c.SwingTableSize_CCK-1)
-			pRFCalibrateInfo->CCK_index = c.SwingTableSize_CCK-1;
-		else if (pRFCalibrateInfo->CCK_index <= 0)
-			pRFCalibrateInfo->CCK_index = 0;
-	}
-	else
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("The thermal meter is unchanged or TxPowerTracking OFF(%d): ThermalValue: %d , pRFCalibrateInfo->ThermalValue: %d\n", 
-			pRFCalibrateInfo->TxPowerTrackControl, ThermalValue, pRFCalibrateInfo->ThermalValue));
-
-		for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++) 		
-		    pRFCalibrateInfo->PowerIndexOffset[p] = 0;
-	}
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("TxPowerTracking: [CCK] Swing Current Index: %d, Swing Base Index: %d\n", 
-			pRFCalibrateInfo->CCK_index, pRFCalibrateInfo->BbSwingIdxCckBase));       //Print Swing base & current
-		
-	for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("TxPowerTracking: [OFDM] Swing Current Index: %d, Swing Base Index[%d]: %d\n",
-			pRFCalibrateInfo->OFDM_index[p], p, pRFCalibrateInfo->BbSwingIdxOfdmBase[p]));
-	}
-	
-	if ((pRFCalibrateInfo->PowerIndexOffset[ODM_RF_PATH_A] != 0 ||
-		pRFCalibrateInfo->PowerIndexOffset[ODM_RF_PATH_B] != 0 ||
-		pRFCalibrateInfo->PowerIndexOffset[ODM_RF_PATH_C] != 0 ||
-		pRFCalibrateInfo->PowerIndexOffset[ODM_RF_PATH_D] != 0) && 
-     	 	pRFCalibrateInfo->TxPowerTrackControl && (pHalData->EEPROMThermalMeter != 0xff))
-	{
-		//4 7.2 Configure the Swing Table to adjust Tx Power.
-		
-		pRFCalibrateInfo->bTxPowerChanged = TRUE; // Always TRUE after Tx Power is adjusted by power tracking.			
-		//
-		// 2012/04/23 MH According to Luke's suggestion, we can not write BB digital
-		// to increase TX power. Otherwise, EVM will be bad.
-		//
-		// 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E.
-		if (ThermalValue > pRFCalibrateInfo->ThermalValue)
-		{
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-			{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Increasing(%d): delta_pi: %d , delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", 
-					p, pRFCalibrateInfo->PowerIndexOffset[p], delta, ThermalValue, pHalData->EEPROMThermalMeter, pRFCalibrateInfo->ThermalValue));	
-			}
-		}
-		
-		else if (ThermalValue < pRFCalibrateInfo->ThermalValue)// Low temperature
-		{
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-			{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Decreasing(%d): delta_pi: %d , delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, pRFCalibrateInfo->PowerIndexOffset[p], delta, ThermalValue, pHalData->EEPROMThermalMeter, pRFCalibrateInfo->ThermalValue));				
-			}
-		}				
-		
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		if (ThermalValue > pHalData->EEPROMThermalMeter)
-#else
-		if (ThermalValue > pDM_Odm->priv->pmib->dot11RFEntry.ther)
-#endif
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) higher than PG value(%d)\n", ThermalValue, pHalData->EEPROMThermalMeter));			
-
-			if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8192E ||pDM_Odm->SupportICType == ODM_RTL8821 ||
-				pDM_Odm->SupportICType == ODM_RTL8812  || pDM_Odm->SupportICType == ODM_RTL8723B || pDM_Odm->SupportICType == ODM_RTL8814A || pDM_Odm->SupportICType == ODM_RTL8703B || pDM_Odm->SupportICType == ODM_RTL8188F)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("**********Enter POWER Tracking MIX_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, MIX_MODE, p, 0);
-			}
-			else 
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("**********Enter POWER Tracking BBSWING_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, p, Indexforchannel);
-			}
-		}
-		else
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) lower than PG value(%d)\n", ThermalValue, pHalData->EEPROMThermalMeter));
-
-			if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8821 ||
-				pDM_Odm->SupportICType == ODM_RTL8812  || pDM_Odm->SupportICType == ODM_RTL8723B || pDM_Odm->SupportICType == ODM_RTL8814A || pDM_Odm->SupportICType == ODM_RTL8703B || pDM_Odm->SupportICType == ODM_RTL8188F)
-			{
-	            		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("**********Enter POWER Tracking MIX_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, MIX_MODE, p, Indexforchannel);
-			}
-			else
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("**********Enter POWER Tracking BBSWING_MODE**********\n"));
-				for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-					(*c.ODM_TxPwrTrackSetPwr)(pDM_Odm, BBSWING, p, Indexforchannel);
-			}
-			
-		}
-
-			pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->BbSwingIdxCck;   // Record last time Power Tracking result as base.
-			for (p = ODM_RF_PATH_A; p < c.RfPathCount; p++)
-				pRFCalibrateInfo->BbSwingIdxOfdmBase[p] = pRFCalibrateInfo->BbSwingIdxOfdm[p];
-
-	 		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("pRFCalibrateInfo->ThermalValue = %d ThermalValue= %d\n", pRFCalibrateInfo->ThermalValue, ThermalValue));
-		
-			pRFCalibrateInfo->ThermalValue = ThermalValue;         //Record last Power Tracking Thermal Value
-			
-	}
-	
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	
-	if(!IS_HARDWARE_TYPE_8723B(Adapter))
-	{
-		// Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).
-		if ((delta_IQK >= c.Threshold_IQK)) {
-			if ( ! pRFCalibrateInfo->bIQKInProgress) 
-				(*c.DoIQK)(pDM_Odm, delta_IQK, ThermalValue, 8);
-		}
-	}
-	if (pRFCalibrateInfo->DpkThermal[ODM_RF_PATH_A] != 0) {
-		if ((diff_DPK[ODM_RF_PATH_A] >= c.Threshold_DPK)) { 
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-			ODM_SetBBReg(pDM_Odm, 0xcc4, BIT14|BIT13|BIT12|BIT11|BIT10, (diff_DPK[ODM_RF_PATH_A] / c.Threshold_DPK));
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-		} else if ((diff_DPK[ODM_RF_PATH_A] <= -1 * c.Threshold_DPK)) {
-			s4Byte value = 0x20 + (diff_DPK[ODM_RF_PATH_A] / c.Threshold_DPK);	
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-			ODM_SetBBReg(pDM_Odm, 0xcc4, BIT14|BIT13|BIT12|BIT11|BIT10, value);
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-		} else {
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-			ODM_SetBBReg(pDM_Odm, 0xcc4, BIT14|BIT13|BIT12|BIT11|BIT10, 0);
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);	
-		}
-	}
-	if (pRFCalibrateInfo->DpkThermal[ODM_RF_PATH_B] != 0) {
-		if ((diff_DPK[ODM_RF_PATH_B] >= c.Threshold_DPK)) { 
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-			ODM_SetBBReg(pDM_Odm, 0xec4, BIT14|BIT13|BIT12|BIT11|BIT10, (diff_DPK[ODM_RF_PATH_B] / c.Threshold_DPK));
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-		} else if ((diff_DPK[ODM_RF_PATH_B] <= -1 * c.Threshold_DPK)) {
-			s4Byte value = 0x20 + (diff_DPK[ODM_RF_PATH_B] / c.Threshold_DPK);	
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-			ODM_SetBBReg(pDM_Odm, 0xec4, BIT14|BIT13|BIT12|BIT11|BIT10, value);
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);
-		} else {
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x1);
-			ODM_SetBBReg(pDM_Odm, 0xec4, BIT14|BIT13|BIT12|BIT11|BIT10, 0);
-			ODM_SetBBReg(pDM_Odm, 0x82c, BIT(31), 0x0);	
-		}
-	}
-
-#endif		
-			
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("<===ODM_TXPowerTrackingCallback_ThermalMeter\n"));
-	
-	pRFCalibrateInfo->TXPowercount = 0;
-}
-
-
-
-//3============================================================
-//3 IQ Calibration
-//3============================================================
-
-VOID
-ODM_ResetIQKResult(
-	IN PDM_ODM_T	pDM_Odm 
-)
-{
-	return;
-}
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-u1Byte ODM_GetRightChnlPlaceforIQK(u1Byte chnl)
-{
-	u1Byte	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = 
-	{1,2,3,4,5,6,7,8,9,10,11,12,13,14,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};
-	u1Byte	place = chnl;
-
-	
-	if(chnl > 14)
-	{
-		for(place = 14; place<sizeof(channel_all); place++)
-		{
-			if(channel_all[place] == chnl)
-			{
-				return place-13;
-			}
-		}
-	}	
-	return 0;
-
-}
-#endif
-
-VOID
-odm_IQCalibrate(
-		IN	PDM_ODM_T	pDM_Odm 
-		)
-{
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	if (*pDM_Odm->pIsFcsModeEnable)
-		return;
-#endif
-	
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))		
-	if (!IS_HARDWARE_TYPE_JAGUAR(Adapter))
-		return;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	else if (IS_HARDWARE_TYPE_8812AU(Adapter))
-		return;
-#endif
-#endif
-	
-#if (RTL8821A_SUPPORT == 1)
-	if (pDM_Odm->bLinked) {
-		if ((*pDM_Odm->pChannel != pDM_Odm->preChannel) && (!*pDM_Odm->pbScanInProcess)) {
-			pDM_Odm->preChannel = *pDM_Odm->pChannel;
-			pDM_Odm->LinkedInterval = 0;
-		}
-
-		if (pDM_Odm->LinkedInterval < 3)
-			pDM_Odm->LinkedInterval++;
-		
-		if (pDM_Odm->LinkedInterval == 2) {
-			/*Mark out IQK flow to prevent tx stuck. by Maddest 20130306*/
-			/*Open it verified by James 20130715*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-			PHY_IQCalibrate_8821A(pDM_Odm, FALSE);
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			PHY_IQCalibrate(Adapter, FALSE);
-#else
-			PHY_IQCalibrate_8821A(Adapter, FALSE);
-#endif
-		}
-	} else
-		pDM_Odm->LinkedInterval = 0;
-#endif
-}
-
-void phydm_rf_init(IN		PDM_ODM_T		pDM_Odm)
-{
-
-	odm_TXPowerTrackingInit(pDM_Odm);
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	ODM_ClearTxPowerTrackingState(pDM_Odm);	
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#if (RTL8814A_SUPPORT == 1)		
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		PHY_IQCalibrate_8814A_Init(pDM_Odm);
-#endif	
-#endif
-
-}
-
-void phydm_rf_watchdog(IN		PDM_ODM_T		pDM_Odm)
-{
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	ODM_TXPowerTrackingCheck(pDM_Odm);
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		odm_IQCalibrate(pDM_Odm);
-#endif
-}
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_win.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_win.h
deleted file mode 100644
index 40104217c103..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halphyrf_win.h
+++ /dev/null
@@ -1,108 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
- #ifndef __HAL_PHY_RF_H__
- #define __HAL_PHY_RF_H__
- 
-#include "phydm_kfree.h"
-#if (RTL8814A_SUPPORT == 1)
-#include "rtl8814a/phydm_iqk_8814a.h"
-#endif
-
-#if (RTL8822B_SUPPORT == 1)
-#include "rtl8822b/phydm_iqk_8822b.h"
-#endif
-#include "phydm_powertracking_win.h"
-
-typedef enum _SPUR_CAL_METHOD {
-	PLL_RESET,
-	AFE_PHASE_SEL
-} SPUR_CAL_METHOD;
-
-typedef enum _PWRTRACK_CONTROL_METHOD {
-	BBSWING,
-	TXAGC,
-	MIX_MODE,
-	TSSI_MODE
-} PWRTRACK_METHOD;
-
-typedef VOID 	(*FuncSetPwr)(PDM_ODM_T, PWRTRACK_METHOD, u1Byte, u1Byte);
-typedef VOID(*FuncIQK)(PVOID, u1Byte, u1Byte, u1Byte);
-typedef VOID 	(*FuncLCK)(PDM_ODM_T);
-				//refine by YuChen for 8814A
-typedef VOID  	(*FuncSwing)(PDM_ODM_T, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);
-typedef VOID	(*FuncSwing8814only)(PDM_ODM_T, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);
-
-typedef struct _TXPWRTRACK_CFG {
-	u1Byte 		SwingTableSize_CCK;	
-	u1Byte 		SwingTableSize_OFDM;
-	u1Byte 		Threshold_IQK;
-	u1Byte 		Threshold_DPK;	
-	u1Byte 		AverageThermalNum;
-	u1Byte 		RfPathCount;
-	u4Byte 		ThermalRegAddr;	
-	FuncSetPwr 	ODM_TxPwrTrackSetPwr;
-	FuncIQK 	DoIQK;
-	FuncLCK		PHY_LCCalibrate;
-	FuncSwing	GetDeltaSwingTable;
-	FuncSwing8814only	GetDeltaSwingTable8814only;
-} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;
-
-VOID 
-ConfigureTxpowerTrack(
-	IN 	PDM_ODM_T		pDM_Odm,
-	OUT	PTXPWRTRACK_CFG	pConfig
-	);
-
-
-VOID
-ODM_ClearTxPowerTrackingState(
-	IN PDM_ODM_T		pDM_Odm
-	);
-
-VOID
-ODM_TXPowerTrackingCallback_ThermalMeter(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm
-#else
-	IN PADAPTER	Adapter
-#endif
-	);
-
-
-
-#define ODM_TARGET_CHNL_NUM_2G_5G	59
-
-
-VOID
-ODM_ResetIQKResult(
-	IN PDM_ODM_T	pDM_Odm 
-);
-u1Byte 
-ODM_GetRightChnlPlaceforIQK(
-    IN u1Byte chnl
-);
-
-VOID odm_IQCalibrate(IN	PDM_ODM_T	pDM_Odm);
-VOID phydm_rf_init(	IN		PDM_ODM_T		pDM_Odm);
-VOID phydm_rf_watchdog(	IN		PDM_ODM_T		pDM_Odm);
-								
-#endif	// #ifndef __HAL_PHY_RF_H__
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ap.c
new file mode 100644
index 000000000000..dba2deee01a4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ap.c
@@ -0,0 +1,1306 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifndef index_mapping_NUM_88E
+	#define	index_mapping_NUM_88E	15
+#endif
+
+/* #if(DM_ODM_SUPPORT_TYPE & ODM_WIN) */
+
+#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
+	do {\
+		for (_offset = 0; _offset < _size; _offset++) { \
+			\
+			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
+				\
+				if (_offset != 0)\
+					_offset--;\
+				break;\
+			} \
+		}			\
+		if (_offset >= _size)\
+			_offset = _size-1;\
+	} while (0)
+
+
+void configure_txpower_track(
+	void		*dm_void,
+	struct txpwrtrack_cfg	*config
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if RTL8812A_SUPPORT
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	/* if (IS_HARDWARE_TYPE_8812(dm->adapter)) */
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
+	/* else */
+#endif
+#endif
+
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
+#endif
+
+
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
+#endif
+
+#if RTL8197F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8197F)
+		configure_txpower_track_8197f(config);
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
+#endif
+
+
+}
+
+#if (RTL8192E_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8	thermal_value = 0, delta, delta_IQK, delta_LCK, channel, is_decrease, rf_mimo_mode;
+	u8	thermal_value_avg_count = 0;
+	u8     OFDM_min_index = 10; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur */
+	s8	OFDM_index[2], index ;
+	u32	thermal_value_avg = 0, reg0x18;
+	u32	i = 0, j = 0, rf;
+	s32	value32, CCK_index = 0, ele_A, ele_D, ele_C, X, Y;
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	rf_mimo_mode = dm->rf_type;
+	/* PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK,"%s:%d rf_mimo_mode:%d\n", __FUNCTION__, __LINE__, rf_mimo_mode); */
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+	thermal_value = (unsigned char)odm_get_rf_reg(dm, RF_PATH_A, ODM_RF_T_METER_92E, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+
+
+	switch (rf_mimo_mode) {
+	case RF_1T1R:
+		rf = 1;
+		break;
+	case RF_2T2R:
+		rf = 2;
+		break;
+	default:
+		rf = 2;
+		break;
+	}
+
+	/* Query OFDM path A default setting 	Bit[31:21] */
+	ele_D = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
+	for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
+		if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
+			OFDM_index[0] = (unsigned char)i;
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "PathA 0xC80[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[0]);
+			break;
+		}
+	}
+
+	/* Query OFDM path B default setting */
+	if (rf_mimo_mode == RF_2T2R) {
+		ele_D = phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKOFDM_D);
+		for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
+			if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
+				OFDM_index[1] = (unsigned char)i;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "PathB 0xC88[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[1]);
+				break;
+			}
+		}
+	}
+
+	/* calculate average thermal meter */
+	{
+		priv->pshare->thermal_value_avg_88xx[priv->pshare->thermal_value_avg_index_88xx] = thermal_value;
+		priv->pshare->thermal_value_avg_index_88xx++;
+		if (priv->pshare->thermal_value_avg_index_88xx == AVG_THERMAL_NUM_88XX)
+			priv->pshare->thermal_value_avg_index_88xx = 0;
+
+		for (i = 0; i < AVG_THERMAL_NUM_88XX; i++) {
+			if (priv->pshare->thermal_value_avg_88xx[i]) {
+				thermal_value_avg += priv->pshare->thermal_value_avg_88xx[i];
+				thermal_value_avg_count++;
+			}
+		}
+
+		if (thermal_value_avg_count) {
+			thermal_value = (unsigned char)(thermal_value_avg / thermal_value_avg_count);
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
+		}
+	}
+
+	/* Initialize */
+	if (!priv->pshare->thermal_value) {
+		priv->pshare->thermal_value = priv->pmib->dot11RFEntry.ther;
+		priv->pshare->thermal_value_iqk = thermal_value;
+		priv->pshare->thermal_value_lck = thermal_value;
+	}
+
+	if (thermal_value != priv->pshare->thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+
+		delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+		delta_IQK = RTL_ABS(thermal_value, priv->pshare->thermal_value_iqk);
+		delta_LCK = RTL_ABS(thermal_value, priv->pshare->thermal_value_lck);
+		is_decrease = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
+
+#ifdef _TRACKING_TABLE_FILE
+		if (priv->pshare->rf_ft_var.pwr_track_file) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
+
+			if (is_decrease) {
+				for (i = 0; i < rf; i++) {
+					OFDM_index[i] = priv->pshare->OFDM_index0[i] + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
+					OFDM_index[i] = ((OFDM_index[i] > (OFDM_TABLE_SIZE_92E- 1)) ? (OFDM_TABLE_SIZE_92E - 1) : OFDM_index[i]);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
+					CCK_index = priv->pshare->CCK_index0 + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
+					CCK_index = ((CCK_index > (CCK_TABLE_SIZE_92E - 1)) ? (CCK_TABLE_SIZE_92E - 1) : CCK_index);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> Decrese power ---> new CCK_INDEX:%d (%d + %d)\n",  CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
+				}
+			} else {
+				for (i = 0; i < rf; i++) {
+					OFDM_index[i] = priv->pshare->OFDM_index0[i] - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
+					OFDM_index[i] = ((OFDM_index[i] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[i]);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> Increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
+					CCK_index = priv->pshare->CCK_index0 - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
+					CCK_index = ((CCK_index < 0) ? 0 : CCK_index);
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> Increse power ---> new CCK_INDEX:%d (%d - %d)\n", CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
+				}
+			}
+		}
+#endif /* CFG_TRACKING_TABLE_FILE */
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]);
+
+		/* Adujst OFDM Ant_A according to IQK result */
+		ele_D = (ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] & 0xFFC00000) >> 22;
+		X = priv->pshare->rege94;
+		Y = priv->pshare->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;
+
+			/* wirte new elements A, C, D to regC80 and regC94, element B is always 0 */
+			value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
+			phy_set_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, value32);
+
+			value32 = (ele_C & 0x000003C0) >> 6;
+			phy_set_bb_reg(priv, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, value32);
+
+			value32 = ((X * ele_D) >> 7) & 0x01;
+			phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), value32);
+		} else {
+			phy_set_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]);
+			phy_set_bb_reg(priv, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, 0x00);
+			phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), 0x00);
+		}
+
+		set_CCK_swing_index(priv, CCK_index);
+
+		if (rf == 2) {
+			ele_D = (ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] & 0xFFC00000) >> 22;
+			X = priv->pshare->regeb4;
+			Y = priv->pshare->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;
+
+				/* wirte new elements A, C, D to regC88 and regC9C, element B is always 0 */
+				value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
+				phy_set_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, value32);
+
+				value32 = (ele_C & 0x000003C0) >> 6;
+				phy_set_bb_reg(priv, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, value32);
+
+				value32 = ((X * ele_D) >> 7) & 0x01;
+				phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), value32);
+			} else {
+				phy_set_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]);
+				phy_set_bb_reg(priv, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, 0x00);
+				phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), 0x00);
+			}
+
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xc80 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD));
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xc88 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD));
+
+		if ((delta_IQK > 3) && (!iqk_info->rfk_forbidden)) {
+			priv->pshare->thermal_value_iqk = thermal_value;
+#ifdef MP_TEST
+#endif			if (!(*(dm->mp_mode) && (OPMODE & (WIFI_MP_CTX_BACKGROUND | WIFI_MP_CTX_PACKET))))
+
+				halrf_iqk_trigger(dm, false);
+		}
+
+		if ((delta_LCK > 8)  && (!iqk_info->rfk_forbidden)) {
+			RTL_W8(0x522, 0xff);
+			reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, BIT(15), 1);
+			delay_ms(1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, reg0x18);
+			RTL_W8(0x522, 0x0);
+			priv->pshare->thermal_value_lck = thermal_value;
+		}
+	}
+
+	/* update thermal meter value */
+	priv->pshare->thermal_value = thermal_value;
+	for (i = 0 ; i < rf ; i++)
+		priv->pshare->OFDM_index[i] = OFDM_index[i];
+	priv->pshare->CCK_index = CCK_index;
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
+}
+#endif
+
+
+
+#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series3(
+	void		*dm_void
+)
+{
+#if 1
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
+	u8			thermal_value_avg_count = 0, p = 0, i = 0;
+	u32			thermal_value_avg = 0;
+	struct rtl8192cd_priv		*priv = dm->priv;
+	struct txpwrtrack_cfg	c;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	/*4 1. The following TWO tables decide the final index of OFDM/CCK swing table.*/
+	u8			*delta_swing_table_idx_tup_a = NULL, *delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL, *delta_swing_table_idx_tdown_b = NULL;
+	u8			*delta_swing_table_idx_tup_cck_a = NULL, *delta_swing_table_idx_tdown_cck_a = NULL;
+	u8			*delta_swing_table_idx_tup_cck_b = NULL, *delta_swing_table_idx_tdown_cck_b = NULL;
+	/*for 8814 add by Yu Chen*/
+	u8			*delta_swing_table_idx_tup_c = NULL, *delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL, *delta_swing_table_idx_tdown_d = NULL;
+	u8			*delta_swing_table_idx_tup_cck_c = NULL, *delta_swing_table_idx_tdown_cck_c = NULL;
+	u8			*delta_swing_table_idx_tup_cck_d = NULL, *delta_swing_table_idx_tdown_cck_d = NULL;
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_all_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b,
+		(u8 **)&delta_swing_table_idx_tup_cck_a, (u8 **)&delta_swing_table_idx_tdown_cck_a,
+		(u8 **)&delta_swing_table_idx_tup_cck_b, (u8 **)&delta_swing_table_idx_tdown_cck_b);
+
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /*0x42: RF Reg[15:10] 88E*/
+#ifdef THER_TRIM
+	if (GET_CHIP_VER(priv) == VERSION_8197F) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"orig thermal_value=%d, ther_trim_val=%d\n", thermal_value, priv->pshare->rf_ft_var.ther_trim_val);
+
+		thermal_value += priv->pshare->rf_ft_var.ther_trim_val;
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"after thermal trim, thermal_value=%d\n", thermal_value);
+	}
+#endif
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"Readback Thermal Meter = 0x%x(%d) EEPROMthermalmeter 0x%x(%d)\n"
+		, thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
+
+	/* Initialize */
+	if (!dm->rf_calibrate_info.thermal_value)
+		dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_lck)
+		dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_iqk)
+		dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
+
+	/* calculate average thermal meter */
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {/*Calculate Average thermal_value after average enough times*/
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"thermal_value_avg=0x%x(%d)  thermal_value_avg_count = %d\n"
+			, thermal_value_avg, thermal_value_avg, thermal_value_avg_count);
+
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X(%d), EEPROMthermalmeter = 0x%X(%d)\n", thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
+	}
+
+	/*4 Calculate delta, delta_LCK, delta_IQK.*/
+	delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+	delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
+	delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
+	is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
+
+	if (delta > 29) { /* power track table index(thermal diff.) upper bound*/
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta(%d) > 29, set delta to 29\n", delta);
+		delta = 29;
+	}
+
+
+	/*4 if necessary, do LCK.*/
+	if ((delta_LCK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+#if (RTL8822B_SUPPORT != 1)
+		if (!(dm->support_ic_type & ODM_RTL8822B)) {
+		if (c.phy_lc_calibrate)
+			(*c.phy_lc_calibrate)(dm);
+	}
+#endif
+	}
+
+	if ((delta_IQK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+		if (c.do_iqk)
+			(*c.do_iqk)(dm, true, 0, 0);
+	}
+
+	if (!priv->pmib->dot11RFEntry.ther)	/*Don't do power tracking since no calibrated thermal value*/
+		return;
+
+	/*4 Do Power Tracking*/
+
+	if (thermal_value != dm->rf_calibrate_info.thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\n\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"Readback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n",
+			thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
+
+#ifdef _TRACKING_TABLE_FILE
+		if (priv->pshare->rf_ft_var.pwr_track_file) {
+			if (is_increase) {			/*thermal is higher than base*/
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_b[%d] = %d delta_swing_table_idx_tup_cck_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta], delta, delta_swing_table_idx_tup_cck_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_b[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_c[%d] = %d delta_swing_table_idx_tup_cck_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta], delta, delta_swing_table_idx_tup_cck_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_c[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_d[%d] = %d delta_swing_table_idx_tup_cck_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta], delta, delta_swing_table_idx_tup_cck_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_d[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_a[%d] = %d delta_swing_table_idx_tup_cck_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta], delta, delta_swing_table_idx_tup_cck_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta];
+						cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_a[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+					}
+				}
+			} else {			/* thermal is lower than base*/
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_b[%d] = %d   delta_swing_table_idx_tdown_cck_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta], delta, delta_swing_table_idx_tdown_cck_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_b[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d   pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_c[%d] = %d   delta_swing_table_idx_tdown_cck_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta], delta, delta_swing_table_idx_tdown_cck_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_c[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d   pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_d[%d] = %d   delta_swing_table_idx_tdown_cck_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta], delta, delta_swing_table_idx_tdown_cck_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_d[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d   pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_a[%d] = %d   delta_swing_table_idx_tdown_cck_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta], delta, delta_swing_table_idx_tdown_cck_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_a[delta];
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d   pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
+						break;
+					}
+				}
+			}
+
+			if (is_increase) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> increse power --->\n");
+				if (GET_CHIP_VER(priv) == VERSION_8197F) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				}
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power --->\n");
+				if (GET_CHIP_VER(priv) == VERSION_8197F) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				}
+			}
+		}
+#endif
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n\n", __func__);
+		/*update thermal meter value*/
+		dm->rf_calibrate_info.thermal_value =  thermal_value;
+
+	}
+
+#endif
+}
+#endif
+
+/*#if (RTL8814A_SUPPORT == 1)*/
+#if (RTL8814A_SUPPORT == 1)
+
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series2(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
+	u8			thermal_value_avg_count = 0, p = 0, i = 0;
+	u32			thermal_value_avg = 0, reg0x18;
+	u32			bb_swing_reg[4] = {REG_A_TX_SCALE_JAGUAR, REG_B_TX_SCALE_JAGUAR, REG_C_TX_SCALE_JAGUAR2, REG_D_TX_SCALE_JAGUAR2};
+	s32			ele_D;
+	u32			bb_swing_idx;
+	struct rtl8192cd_priv	*priv = dm->priv;
+	struct txpwrtrack_cfg	c;
+	boolean			is_tssi_enable = false;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	u8			*delta_swing_table_idx_tup_a = NULL, *delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL, *delta_swing_table_idx_tdown_b = NULL;
+	/* for 8814 add by Yu Chen */
+	u8			*delta_swing_table_idx_tup_c = NULL, *delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL, *delta_swing_table_idx_tdown_d = NULL;
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+	configure_txpower_track(dm, &c);
+	cali_info->default_ofdm_index = priv->pshare->OFDM_index0[RF_PATH_A];
+
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+
+	if (dm->support_ic_type & ODM_RTL8814A)	/* for 8814 path C & D */
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
+
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x, pre thermal meter 0x%x, EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
+
+	/* Initialize */
+	if (!dm->rf_calibrate_info.thermal_value)
+		dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_lck)
+		dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
+
+	if (!dm->rf_calibrate_info.thermal_value_iqk)
+		dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
+
+	is_tssi_enable = (boolean)odm_get_rf_reg(dm, RF_PATH_A, REG_RF_TX_GAIN_OFFSET, BIT(7));	/* check TSSI enable */
+
+	/* 4 Query OFDM BB swing default setting 	Bit[31:21] */
+	for (p = RF_PATH_A ; p < c.rf_path_count ; p++) {
+		ele_D = odm_get_bb_reg(dm, bb_swing_reg[p], 0xffe00000);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[p], odm_get_bb_reg(dm, bb_swing_reg[p], MASKDWORD), ele_D);
+
+		for (bb_swing_idx = 0; bb_swing_idx < TXSCALE_TABLE_SIZE; bb_swing_idx++) {/* 4 */
+			if (ele_D == tx_scaling_table_jaguar[bb_swing_idx]) {
+				dm->rf_calibrate_info.OFDM_index[p] = (u8)bb_swing_idx;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"OFDM_index[%d]=%d\n", p, dm->rf_calibrate_info.OFDM_index[p]);
+				break;
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "kfree_offset[%d]=%d\n", p, cali_info->kfree_offset[p]);
+
+	}
+
+	/* calculate average thermal meter */
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)  /* Average times =  c.average_thermal_num */
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X, EEPROMthermalmeter = 0x%X\n", thermal_value, priv->pmib->dot11RFEntry.ther);
+	}
+
+	/* 4 Calculate delta, delta_LCK, delta_IQK. */
+	delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+	delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
+	delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
+	is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
+
+	/* 4 if necessary, do LCK. */
+	if (!(dm->support_ic_type & ODM_RTL8821)) {
+		if ((delta_LCK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+			dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, so close power tracking driver LCK*/
+#if (RTL8814A_SUPPORT != 1)
+			if (!(dm->support_ic_type & ODM_RTL8814A)) {
+				if (c.phy_lc_calibrate)
+					(*c.phy_lc_calibrate)(dm);
+			}
+#endif
+		}
+	}
+
+	if ((delta_IQK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+		panic_printk("%s(%d)\n", __FUNCTION__, __LINE__);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+		if (c.do_iqk)
+			(*c.do_iqk)(dm, true, 0, 0);
+	}
+
+	if (!priv->pmib->dot11RFEntry.ther)	/*Don't do power tracking since no calibrated thermal value*/
+		return;
+
+	/* 4 Do Power Tracking */
+
+	if (is_tssi_enable == true) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter PURE TSSI MODE**********\n");
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
+	} else if (thermal_value != dm->rf_calibrate_info.thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
+
+#ifdef _TRACKING_TABLE_FILE
+		if (priv->pshare->rf_ft_var.pwr_track_file) {
+			if (is_increase) {		/* thermal is higher than base */
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta];       /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta];       /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta];       /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+					}
+				}
+			} else {				/* thermal is lower than base */
+				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+					switch (p) {
+					case RF_PATH_B:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_C:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					case RF_PATH_D:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+
+					default:
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta];        /* Record delta swing for mix mode power tracking */
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+						break;
+					}
+				}
+			}
+
+			if (is_increase) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> increse power --->\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power --->\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			}
+		}
+#endif
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
+		/* update thermal meter value */
+		dm->rf_calibrate_info.thermal_value =  thermal_value;
+
+	}
+}
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8881A_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	unsigned char			thermal_value = 0, delta, delta_LCK, channel, is_decrease;
+	unsigned char			thermal_value_avg_count = 0;
+	unsigned int			thermal_value_avg = 0, reg0x18;
+	unsigned int			bb_swing_reg[4] = {0xc1c, 0xe1c, 0x181c, 0x1a1c};
+	int					ele_D, value32;
+	char					OFDM_index[2], index;
+	unsigned int			i = 0, j = 0, rf_path, max_rf_path = 2, rf;
+	struct rtl8192cd_priv		*priv = dm->priv;
+	unsigned char			OFDM_min_index = 7; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur and Mimic */
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+
+#ifdef MP_TEST
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		channel = priv->pshare->working_channel;
+		if (priv->pshare->mp_txpwr_tracking == false)
+			return;
+	} else
+#endif
+	{
+		channel = (priv->pmib->dot11RFEntry.dot11channel);
+	}
+
+#if RTL8881A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8881A) {
+		max_rf_path = 1;
+		if ((get_bonding_type_8881A() == BOND_8881AM || get_bonding_type_8881A() == BOND_8881AN)
+		    && priv->pshare->rf_ft_var.use_intpa8881A && (*dm->band_type == ODM_BAND_2_4G))
+			OFDM_min_index = 6;		/* intPA - upper bond set to +3 dB (base: -2 dB)ot11RFEntry.phy_band_select == PHY_BAND_2G)) */
+		else
+			OFDM_min_index = 10;		/* OFDM BB Swing should be less than +1dB, which is required by Arthur and Mimic */
+	}
+#endif
+
+
+	thermal_value = (unsigned char)phy_query_rf_reg(priv, RF_PATH_A, 0x42, 0xfc00, 1); /* 0x42: RF Reg[15:10] 88E */
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+
+
+	/* 4 Query OFDM BB swing default setting 	Bit[31:21] */
+	for (rf_path = 0 ; rf_path < max_rf_path ; rf_path++) {
+		ele_D = phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], MASKDWORD), ele_D);
+		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
+			if (ele_D == ofdm_swing_table_8812[i]) {
+				OFDM_index[rf_path] = (unsigned char)i;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "OFDM_index[%d]=%d\n", rf_path, OFDM_index[rf_path]);
+				break;
+			}
+		}
+	}
+#if 0
+	/* Query OFDM path A default setting 	Bit[31:21] */
+	ele_D = phy_query_bb_reg(priv, 0xc1c, 0xffe00000);
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xc1c:0x%x ([31:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xc1c, MASKDWORD), ele_D);
+	for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
+		if (ele_D == ofdm_swing_table_8812[i]) {
+			OFDM_index[0] = (unsigned char)i;
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "OFDM_index[0]=%d\n", OFDM_index[0]);
+			break;
+		}
+	}
+	/* Query OFDM path B default setting */
+	if (rf == 2) {
+		ele_D = phy_query_bb_reg(priv, 0xe1c, 0xffe00000);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "0xe1c:0x%x ([32:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xe1c, MASKDWORD), ele_D);
+		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {
+			if (ele_D == ofdm_swing_table_8812[i]) {
+				OFDM_index[1] = (unsigned char)i;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "OFDM_index[1]=%d\n", OFDM_index[1]);
+				break;
+			}
+		}
+	}
+#endif
+	/* Initialize */
+	if (!priv->pshare->thermal_value) {
+		priv->pshare->thermal_value = priv->pmib->dot11RFEntry.ther;
+		priv->pshare->thermal_value_lck = thermal_value;
+	}
+
+	/* calculate average thermal meter */
+	{
+		priv->pshare->thermal_value_avg_8812[priv->pshare->thermal_value_avg_index_8812] = thermal_value;
+		priv->pshare->thermal_value_avg_index_8812++;
+		if (priv->pshare->thermal_value_avg_index_8812 == AVG_THERMAL_NUM_8812)
+			priv->pshare->thermal_value_avg_index_8812 = 0;
+
+		for (i = 0; i < AVG_THERMAL_NUM_8812; i++) {
+			if (priv->pshare->thermal_value_avg_8812[i]) {
+				thermal_value_avg += priv->pshare->thermal_value_avg_8812[i];
+				thermal_value_avg_count++;
+			}
+		}
+
+		if (thermal_value_avg_count) {
+			thermal_value = (unsigned char)(thermal_value_avg / thermal_value_avg_count);
+			/* printk("AVG Thermal Meter = 0x%x\n", thermal_value); */
+		}
+	}
+
+
+	/* 4 If necessary,  do power tracking */
+
+	if (!priv->pmib->dot11RFEntry.ther) /*Don't do power tracking since no calibrated thermal value*/
+		return;
+
+	if (thermal_value != priv->pshare->thermal_value) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
+		delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
+		delta_LCK = RTL_ABS(thermal_value, priv->pshare->thermal_value_lck);
+		is_decrease = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
+		/* if (*dm->band_type == ODM_BAND_5G) */
+		{
+#ifdef _TRACKING_TABLE_FILE
+			if (priv->pshare->rf_ft_var.pwr_track_file) {
+				for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
+					if (is_decrease) {
+						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] + get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
+						OFDM_index[rf_path] = ((OFDM_index[rf_path] > (OFDM_TABLE_SIZE_8812 - 1)) ? (OFDM_TABLE_SIZE_8812 - 1) : OFDM_index[rf_path]);
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
+#if 0/* RTL8881A_SUPPORT */
+						if (dm->support_ic_type == ODM_RTL8881A) {
+							if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
+								if (priv->pshare->add_tx_agc) { /* tx_agc has been added */
+									add_tx_power88xx_ac(priv, 0);
+									priv->pshare->add_tx_agc = 0;
+									priv->pshare->add_tx_agc_index = 0;
+								}
+							}
+						}
+#endif
+					} else {
+
+						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] - get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
+#if 0/* RTL8881A_SUPPORT */
+						if (dm->support_ic_type == ODM_RTL8881A) {
+							if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
+								if (OFDM_index[i] < OFDM_min_index) {
+									priv->pshare->add_tx_agc_index = (OFDM_min_index - OFDM_index[i]) / 2; /* Calculate Remnant tx_agc value,  2 index for 1 tx_agc */
+									add_tx_power88xx_ac(priv, priv->pshare->add_tx_agc_index);
+									priv->pshare->add_tx_agc = 1;     /* add_tx_agc Flag = 1 */
+									OFDM_index[i] = OFDM_min_index;
+								} else {
+									if (priv->pshare->add_tx_agc) { /* tx_agc been added */
+										priv->pshare->add_tx_agc = 0;
+										priv->pshare->add_tx_agc_index = 0;
+										add_tx_power88xx_ac(priv, 0); /* minus the added TPI */
+									}
+								}
+							}
+						}
+#else
+						OFDM_index[rf_path] = ((OFDM_index[rf_path] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[rf_path]);
+#endif
+						PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, ">>> increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
+					}
+				}
+			}
+#endif
+			/* 4 Set new BB swing index */
+			for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
+				phy_set_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000, ofdm_swing_table_8812[(unsigned int)OFDM_index[rf_path]]);
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Readback 0x%x[31:21] = 0x%x, OFDM_index:%d\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000), OFDM_index[rf_path]);
+			}
+
+		}
+		if ((delta_LCK > 8) && (!iqk_info->rfk_forbidden)) {
+			RTL_W8(0x522, 0xff);
+			reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, BIT(15), 1);
+			delay_ms(200); /* frequency deviation */
+			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
+			phy_set_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, reg0x18);
+#ifdef CONFIG_RTL_8812_SUPPORT
+			if (GET_CHIP_VER(priv) == VERSION_8812E)
+				update_bbrf_val8812(priv, priv->pmib->dot11RFEntry.dot11channel);
+#endif
+			RTL_W8(0x522, 0x0);
+			priv->pshare->thermal_value_lck = thermal_value;
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
+
+		/* update thermal meter value */
+		priv->pshare->thermal_value = thermal_value;
+		for (rf_path = 0; rf_path < max_rf_path; rf_path++)
+			priv->pshare->OFDM_index[rf_path] = OFDM_index[rf_path];
+	}
+}
+
+#endif
+
+
+void
+odm_txpowertracking_callback_thermal_meter(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F || dm->support_ic_type == ODM_RTL8822B
+		|| dm->support_ic_type == ODM_RTL8821C) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series3(dm);
+		return;
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)		/*use this function to do power tracking after 8814 by YuChen*/
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series2(dm);
+		return;
+	}
+#endif
+#if (RTL8881A_SUPPORT || RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8812 || dm->support_ic_type & ODM_RTL8881A) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series(dm);
+		return;
+	}
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_txpowertracking_callback_thermal_meter_92e(dm);
+		return;
+	}
+#endif
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	/* PMGNT_INFO      		mgnt_info = &adapter->mgnt_info; */
+#endif
+
+
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, offset;
+	u8			thermal_value_avg_count = 0;
+	u32			thermal_value_avg = 0;
+	/*	s32			ele_A=0, ele_D, TempCCk, X, value32;
+	 *	s32			Y, ele_C=0;
+	 *	s8			OFDM_index[2], CCK_index=0, OFDM_index_old[2]={0,0}, CCK_index_old=0, index;
+	 *	s8			deltaPowerIndex = 0; */
+	u32			i = 0;/* , j = 0; */
+	boolean		is2T = false;
+	/*	bool 		bInteralPA = false; */
+
+	u8			OFDM_max_index = 34, rf = (is2T) ? 2 : 1; /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
+	u8			indexforchannel = 0;/*get_right_chnl_place_for_iqk(hal_data->current_channel)*/
+	enum            _POWER_DEC_INC { POWER_DEC, POWER_INC };
+
+	struct txpwrtrack_cfg	c;
+
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	s8			delta_swing_table_idx[2][index_mapping_NUM_88E] = {
+		/* {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}} */
+		{0, 0, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 10, 11}, {0, 0, 1, 2, 3, 4, 4, 4, 4, 5, 7, 8, 9, 9, 10}
+	};
+	u8			thermal_threshold[2][index_mapping_NUM_88E] = {
+		/* {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}} */
+		{0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 27}, {0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 25, 25, 25}
+	};
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct rtl8192cd_priv	*priv = dm->priv;
+#endif
+
+	/* 4 2. Initilization ( 7 steps in total ) */
+
+	configure_txpower_track(dm, &c);
+
+	dm->rf_calibrate_info.txpowertracking_callback_cnt++; /* cosa add for debug */
+	dm->rf_calibrate_info.is_txpowertracking_init = true;
+
+#if (MP_DRIVER == 1)
+	dm->rf_calibrate_info.txpowertrack_control = hal_data->txpowertrack_control; /* <Kordan> We should keep updating the control variable according to HalData.
+     * <Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
+	dm->rf_calibrate_info.rega24 = 0x090e1317;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP) && defined(MP_TEST)
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		if (dm->priv->pshare->mp_txpwr_tracking == false)
+			return;
+	}
+#endif
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "===>odm_txpowertracking_callback_thermal_meter_8188e, dm->bb_swing_idx_cck_base: %d, dm->bb_swing_idx_ofdm_base: %d\n", cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base);
+	/*
+		if (!dm->rf_calibrate_info.tm_trigger) {
+			odm_set_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, BIT(17) | BIT(16), 0x3);
+			dm->rf_calibrate_info.tm_trigger = 1;
+			return;
+		}
+	*/
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	if (!thermal_value || !dm->rf_calibrate_info.txpowertrack_control)
+#else
+	if (!dm->rf_calibrate_info.txpowertrack_control)
+#endif
+		return;
+
+	/* 4 3. Initialize ThermalValues of rf_calibrate_info */
+
+	if (!dm->rf_calibrate_info.thermal_value) {
+		dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+	}
+
+	if (dm->rf_calibrate_info.is_reloadtxpowerindex)
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "reload ofdm index for band switch\n");
+
+	/* 4 4. Calculate average thermal meter */
+
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {
+		/* Give the new thermo value a weighting */
+		thermal_value_avg += (thermal_value * 4);
+
+		thermal_value = (u8)(thermal_value_avg / (thermal_value_avg_count + 4));
+		cali_info->thermal_value_delta = thermal_value - priv->pmib->dot11RFEntry.ther;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
+	}
+
+	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
+
+	delta	  = (thermal_value > dm->rf_calibrate_info.thermal_value) ? (thermal_value - dm->rf_calibrate_info.thermal_value) : (dm->rf_calibrate_info.thermal_value - thermal_value);
+	delta_LCK = (thermal_value > dm->rf_calibrate_info.thermal_value_lck) ? (thermal_value - dm->rf_calibrate_info.thermal_value_lck) : (dm->rf_calibrate_info.thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > dm->rf_calibrate_info.thermal_value_iqk) ? (thermal_value - dm->rf_calibrate_info.thermal_value_iqk) : (dm->rf_calibrate_info.thermal_value_iqk - thermal_value);
+
+	/* 4 6. If necessary, do LCK. */
+	if (!(dm->support_ic_type & ODM_RTL8821)) {
+		/*if((delta_LCK > hal_data->delta_lck) && (hal_data->delta_lck != 0))*/
+		if ((delta_LCK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+			/*Delta temperature is equal to or larger than 20 centigrade.*/
+			dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+			(*c.phy_lc_calibrate)(dm);
+		}
+	}
+
+	/* 3 7. If necessary, move the index of swing table to adjust Tx power. */
+
+	if (delta > 0 && dm->rf_calibrate_info.txpowertrack_control) {
+
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+
+		/* 4 7.1 The Final Power index = BaseIndex + power_index_offset */
+
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_INC, index_mapping_NUM_88E, delta);
+			dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
+			dm->rf_calibrate_info.delta_power_index =  delta_swing_table_idx[POWER_INC][offset];
+
+		} else {
+
+			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_DEC, index_mapping_NUM_88E, delta);
+			dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
+			dm->rf_calibrate_info.delta_power_index = (-1) * delta_swing_table_idx[POWER_DEC][offset];
+		}
+
+		if (dm->rf_calibrate_info.delta_power_index == dm->rf_calibrate_info.delta_power_index_last)
+			dm->rf_calibrate_info.power_index_offset = 0;
+		else
+			dm->rf_calibrate_info.power_index_offset = dm->rf_calibrate_info.delta_power_index - dm->rf_calibrate_info.delta_power_index_last;
+
+		for (i = 0; i < rf; i++)
+			dm->rf_calibrate_info.OFDM_index[i] = cali_info->bb_swing_idx_ofdm_base + dm->rf_calibrate_info.power_index_offset;
+		dm->rf_calibrate_info.CCK_index = cali_info->bb_swing_idx_cck_base + dm->rf_calibrate_info.power_index_offset;
+
+		cali_info->bb_swing_idx_cck = dm->rf_calibrate_info.CCK_index;
+		cali_info->bb_swing_idx_ofdm[RF_PATH_A] = dm->rf_calibrate_info.OFDM_index[RF_PATH_A];
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, dm->rf_calibrate_info.power_index_offset);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "The 'OFDM' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base, dm->rf_calibrate_info.power_index_offset);
+
+		/* 4 7.1 Handle boundary conditions of index. */
+
+
+		for (i = 0; i < rf; i++) {
+			if (dm->rf_calibrate_info.OFDM_index[i] > OFDM_max_index)
+				dm->rf_calibrate_info.OFDM_index[i] = OFDM_max_index;
+			else if (dm->rf_calibrate_info.OFDM_index[i] < 0)
+				dm->rf_calibrate_info.OFDM_index[i] = 0;
+		}
+
+		if (dm->rf_calibrate_info.CCK_index > c.swing_table_size_cck - 1)
+			dm->rf_calibrate_info.CCK_index = c.swing_table_size_cck - 1;
+		else if (dm->rf_calibrate_info.CCK_index < 0)
+			dm->rf_calibrate_info.CCK_index = 0;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"The thermal meter is unchanged or TxPowerTracking OFF: thermal_value: %d, dm->rf_calibrate_info.thermal_value: %d)\n", thermal_value, dm->rf_calibrate_info.thermal_value);
+		dm->rf_calibrate_info.power_index_offset = 0;
+	}
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.CCK_index, cali_info->bb_swing_idx_cck_base);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.OFDM_index[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base);
+
+	if (dm->rf_calibrate_info.power_index_offset != 0 && dm->rf_calibrate_info.txpowertrack_control) {
+		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
+
+		dm->rf_calibrate_info.is_tx_power_changed = true; /* Always true after Tx Power is adjusted by power tracking. */
+		/*  */
+		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
+		/* to increase TX power. Otherwise, EVM will be bad. */
+		/*  */
+		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
+		if (thermal_value > dm->rf_calibrate_info.thermal_value) {
+			/* PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK, */
+			/*	"Temperature Increasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
+			/*	dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
+		} else if (thermal_value < dm->rf_calibrate_info.thermal_value) { /* Low temperature */
+			/* PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK, */
+			/*	"Temperature Decreasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
+			/*		dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
+		}
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
+		{
+			/*				PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK,"Temperature(%d) hugher than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
+			(*c.odm_tx_pwr_track_set_pwr)(dm, TXAGC, 0, 0);
+		} else {
+			/*			PHYDM_DBG(dm,ODM_COMP_TX_PWR_TRACK,"Temperature(%d) lower than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
+			(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_A, indexforchannel);
+			if (is2T)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_B, indexforchannel);
+		}
+
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;
+		cali_info->bb_swing_idx_ofdm_base = cali_info->bb_swing_idx_ofdm[RF_PATH_A];
+		dm->rf_calibrate_info.thermal_value = thermal_value;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "<===dm_TXPowerTrackingCallback_ThermalMeter_8188E\n");
+
+	dm->rf_calibrate_info.tx_powercount = 0;
+}
+
+/* 3============================================================
+ * 3 IQ Calibration
+ * 3============================================================ */
+
+void
+odm_reset_iqk_result(
+	void		*dm_void
+)
+{
+	return;
+}
+#if 1/* !(DM_ODM_SUPPORT_TYPE & ODM_AP) */
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
+{
+	u8	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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
+	};
+	u8	place = chnl;
+
+
+	if (chnl > 14) {
+		for (place = 14; place < sizeof(channel_all); place++) {
+			if (channel_all[place] == chnl)
+				return place - 13;
+		}
+	}
+	return 0;
+
+}
+#endif
+
+void
+odm_iq_calibrate(
+	struct dm_struct	*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		if ((*dm->channel != dm->pre_channel) && (!*dm->is_scan_in_process)) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
+		}
+
+		if (dm->linked_interval < 3)
+			dm->linked_interval++;
+
+		if (dm->linked_interval == 2)
+			halrf_iqk_trigger(dm, false);
+	} else
+		dm->linked_interval = 0;
+
+}
+
+void phydm_rf_init(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	odm_txpowertracking_init(dm);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
+#endif
+#endif
+
+}
+
+void phydm_rf_watchdog(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_txpowertracking_check(dm);
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_iq_calibrate(dm);
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ap.h
new file mode 100644
index 000000000000..b3264086d685
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ap.h
@@ -0,0 +1,123 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PHY_RF_H__
+#define __HAL_PHY_RF_H__
+
+#include "halrf/halrf_powertracking_ap.h"
+#include "halrf/halrf_kfree.h"
+
+#if (RTL8814A_SUPPORT == 1)
+	#include "halrf/rtl8814a/halrf_iqk_8814a.h"
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#include "halrf/rtl8822b/halrf_iqk_8822b.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
+#endif
+
+enum pwrtrack_method {
+	BBSWING,
+	TXAGC,
+	MIX_MODE,
+	TSSI_MODE
+};
+
+typedef void	(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void(*func_iqk)(void *, u8, u8, u8);
+typedef void	(*func_lck)(void *);
+/* refine by YuChen for 8814A */
+typedef void	(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
+
+
+struct txpwrtrack_cfg {
+	u8		swing_table_size_cck;
+	u8		swing_table_size_ofdm;
+	u8		threshold_iqk;
+	u8		threshold_dpk;
+	u8		average_thermal_num;
+	u8		rf_path_count;
+	u32		thermal_reg_addr;
+	func_set_pwr	odm_tx_pwr_track_set_pwr;
+	func_iqk	do_iqk;
+	func_lck		phy_lc_calibrate;
+	func_swing	get_delta_swing_table;
+	func_swing8814only	get_delta_swing_table8814only;
+	func_all_swing	get_delta_all_swing_table;
+};
+
+void
+configure_txpower_track(
+	void		*dm_void,
+	struct txpwrtrack_cfg	*config
+);
+
+
+void
+odm_txpowertracking_callback_thermal_meter(
+	void		*dm_void
+);
+
+#if (RTL8192E_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_92e(
+	void		*dm_void
+);
+#endif
+
+#if (RTL8814A_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series2(
+	void		*dm_void
+);
+
+#elif ODM_IC_11AC_SERIES_SUPPORT
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series(
+	void		*dm_void
+);
+
+#elif (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+void
+odm_txpowertracking_callback_thermal_meter_jaguar_series3(
+	void		*dm_void
+);
+
+#endif
+
+#define IS_CCK_RATE(_rate)				(ODM_MGN_1M == _rate || _rate == ODM_MGN_2M || _rate == ODM_MGN_5_5M || _rate == ODM_MGN_11M)
+
+#define ODM_TARGET_CHNL_NUM_2G_5G	59
+
+
+void
+odm_reset_iqk_result(
+	void		*dm_void
+);
+u8
+odm_get_right_chnl_place_for_iqk(
+	u8 chnl
+);
+
+void phydm_rf_init(void		*dm_void);
+void phydm_rf_watchdog(void		*dm_void);
+
+#endif	/*  #ifndef __HAL_PHY_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ce.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ce.c
new file mode 100644
index 000000000000..db5447caee3b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ce.c
@@ -0,0 +1,908 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
+	do {\
+		for (_offset = 0; _offset < _size; _offset++) { \
+			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
+				if (_offset != 0)\
+					_offset--;\
+				break;\
+			} \
+		}			\
+		if (_offset >= _size)\
+			_offset = _size-1;\
+	} while (0)
+
+void configure_txpower_track(
+	void					*dm_void,
+	struct txpwrtrack_cfg	*config
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if RTL8192E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192E)
+		configure_txpower_track_8192e(config);
+#endif
+#if RTL8821A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821)
+		configure_txpower_track_8821a(config);
+#endif
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
+#endif
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
+#endif
+
+#if RTL8723B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723B)
+		configure_txpower_track_8723b(config);
+#endif
+
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
+#endif
+
+#if RTL8703B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8703B)
+		configure_txpower_track_8703b(config);
+#endif
+
+#if RTL8188F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188F)
+		configure_txpower_track_8188f(config);
+#endif
+#if RTL8723D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723D)
+		configure_txpower_track_8723d(config);
+#endif
+/* JJ ADD 20161014 */
+#if RTL8710B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8710B)
+		configure_txpower_track_8710b(config);
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
+#endif
+#if RTL8821C_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821C)
+		configure_txpower_track_8821c(config);
+#endif
+
+}
+
+/* **********************************************************************
+ * <20121113, Kordan> This function should be called when tx_agc changed.
+ * Otherwise the previous compensation is gone, because we record the
+ * delta of temperature between two TxPowerTracking watch dogs.
+ *
+ * NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
+ * need to call this function.
+ * ********************************************************************** */
+void
+odm_clear_txpowertracking_state(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
+#else
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(dm->adapter);
+#endif
+	u8			p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+	dm->rf_calibrate_info.CCK_index = 0;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+
+		cali_info->power_index_offset[p] = 0;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+
+		cali_info->absolute_ofdm_swing_idx[p] = 0;    /* Initial Mix mode power tracking*/
+		cali_info->remnant_ofdm_swing_idx[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+
+	cali_info->modify_tx_agc_flag_path_a = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_b = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_c = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_d = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->remnant_cck_swing_idx = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	cali_info->thermal_value = rtlefu->eeprom_thermalmeter;
+#else
+	cali_info->thermal_value = hal_data->eeprom_thermal_meter;
+#endif
+
+	cali_info->modify_tx_agc_value_cck = 0;			/* modify by Mingzhi.Guo */
+	cali_info->modify_tx_agc_value_ofdm = 0;		/* modify by Mingzhi.Guo */
+
+}
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct		*dm
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*dm_void
+#else
+	void	*adapter
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
+	void *adapter = dm->adapter;
+#elif !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#endif
+#endif
+
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct	dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
+	s8			diff_DPK[4] = {0};
+	u8			thermal_value_avg_count = 0;
+	u32			thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
+
+	u8			OFDM_min_index = 0;  /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
+	u8			indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	u8			power_tracking_type = 0;	/* no specify type */
+#else
+	u8			power_tracking_type = hal_data->rf_power_tracking_type;
+#endif
+	u8			xtal_offset_eanble = 0;
+	s8			thermal_value_temp = 0;
+
+	struct txpwrtrack_cfg	c = {0};
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	u8			*delta_swing_table_idx_tup_a = NULL;
+	u8			*delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL;
+	u8			*delta_swing_table_idx_tdown_b = NULL;
+	/*for 8814 add by Yu Chen*/
+	u8			*delta_swing_table_idx_tup_c = NULL;
+	u8			*delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL;
+	u8			*delta_swing_table_idx_tdown_d = NULL;
+	/*for Xtal Offset by James.Tung*/
+	s8			*delta_swing_table_xtal_up = NULL;
+	s8			*delta_swing_table_xtal_down = NULL;
+
+	/* 4 2. Initilization ( 7 steps in total ) */
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+
+	if (dm->support_ic_type & ODM_RTL8814A)	/*for 8814 path C & D*/
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B))	/*for Xtal Offset*/
+		(*c.get_delta_swing_xtal_table)(dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
+
+	cali_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
+	cali_info->is_txpowertracking_init = true;
+
+	/*cali_info->txpowertrack_control = hal_data->txpowertrack_control;
+	<Kordan> We should keep updating the control variable according to HalData.
+	<Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+	cali_info->rega24 = 0x090e1317;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	if (*(dm->mp_mode) == true)
+		cali_info->rega24 = 0x090e1317;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
+		cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"cali_info->txpowertrack_control=%d,  rtlefu->eeprom_thermalmeter %d\n", cali_info->txpowertrack_control,  rtlefu->eeprom_thermalmeter);
+#else
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"cali_info->txpowertrack_control=%d,  hal_data->eeprom_thermal_meter %d\n", cali_info->txpowertrack_control,  hal_data->eeprom_thermal_meter);
+#endif
+
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+
+	thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"thermal_value_temp(%d) = thermal_value(%d) + power_trim_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
+
+	if (thermal_value_temp > 63)
+		thermal_value = 63;
+	else if (thermal_value_temp < 0)
+		thermal_value = 0;
+	else
+		thermal_value = thermal_value_temp;
+
+	/*add log by zhao he, check c80/c94/c14/ca0 value*/
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+
+	if (!cali_info->txpowertrack_control)
+		return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	if (rtlefu->eeprom_thermalmeter == 0xff) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", rtlefu->eeprom_thermalmeter);
+		return;
+	}
+#else
+	if (hal_data->eeprom_thermal_meter == 0xff) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", hal_data->eeprom_thermal_meter);
+		return;
+	}
+#endif
+
+	/*4 3. Initialize ThermalValues of rf_calibrate_info*/
+
+	if (cali_info->is_reloadtxpowerindex)
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "reload ofdm index for band switch\n");
+
+	/*4 4. Calculate average thermal meter*/
+
+	cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
+	cali_info->thermal_value_avg_index++;
+	if (cali_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		cali_info->thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (cali_info->thermal_value_avg[i]) {
+			thermal_value_avg += cali_info->thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		cali_info->thermal_value_delta = thermal_value - rtlefu->eeprom_thermalmeter;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+		cali_info->thermal_value_delta = thermal_value - hal_data->eeprom_thermal_meter;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+	}
+
+	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
+
+	/* "delta" here is used to determine whether thermal value changes or not. */
+	delta	= (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
+	delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+
+	if (cali_info->thermal_value_iqk == 0xff) {	/*no PG, use thermal value for IQK*/
+		cali_info->thermal_value_iqk = thermal_value;
+		delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, use thermal_value for IQK\n");
+	}
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++)
+		diff_DPK[p] = (s8)thermal_value - (s8)cali_info->dpk_thermal[p];
+
+	/*4 6. If necessary, do LCK.*/
+
+	if (!(dm->support_ic_type & ODM_RTL8821)) {	/*no PG, do LCK at initial status*/
+		if (cali_info->thermal_value_lck == 0xff) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, do LCK\n");
+			cali_info->thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, so close power tracking driver LCK*/
+			if (!(dm->support_ic_type & ODM_RTL8814A) && !(dm->support_ic_type & ODM_RTL8822B) && c.phy_lc_calibrate)
+				(*c.phy_lc_calibrate)(dm);
+
+			delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
+
+		/* Wait sacn to do LCK by RF Jenyu*/
+		if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
+			/* Delta temperature is equal to or larger than 20 centigrade.*/
+			if (delta_LCK >= c.threshold_iqk) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+				cali_info->thermal_value_lck = thermal_value;
+
+				/*Use RTLCK, so close power tracking driver LCK*/
+				if (!(dm->support_ic_type & ODM_RTL8814A) && !(dm->support_ic_type & ODM_RTL8822B) && c.phy_lc_calibrate)
+					(*c.phy_lc_calibrate)(dm);
+			}
+		}
+	}
+
+	/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
+
+	if (delta > 0 && cali_info->txpowertrack_control) {
+		/* "delta" here is used to record the absolute value of differrence. */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		delta = thermal_value > rtlefu->eeprom_thermalmeter ? (thermal_value - rtlefu->eeprom_thermalmeter) : (rtlefu->eeprom_thermalmeter - thermal_value);
+#else
+		delta = thermal_value > hal_data->eeprom_thermal_meter ? (thermal_value - hal_data->eeprom_thermal_meter) : (hal_data->eeprom_thermal_meter - thermal_value);
+#endif
+#else
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+#endif
+		if (delta >= TXPWR_TRACK_TABLE_SIZE)
+			delta = TXPWR_TRACK_TABLE_SIZE - 1;
+
+		/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		if (thermal_value > rtlefu->eeprom_thermalmeter) {
+#else
+		if (thermal_value > hal_data->eeprom_thermal_meter) {
+#endif
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_b[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_c[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_d[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
+				xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
+			}
+
+		} else {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_b[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_c[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_d[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
+				xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
+			}
+
+		}
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
+
+			if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p])         /*If Thermal value changes but lookup table value still the same*/
+				cali_info->power_index_offset[p] = 0;
+			else
+				cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p];      /*Power index diff between 2 times Power Tracking*/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
+
+			cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
+			cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
+
+			cali_info->bb_swing_idx_cck = cali_info->CCK_index;
+			cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
+
+			/*************Print BB Swing base and index Offset*************/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
+
+			/*4 7.1 Handle boundary conditions of index.*/
+
+			if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
+				cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
+			else if (cali_info->OFDM_index[p] <= OFDM_min_index)
+				cali_info->OFDM_index[p] = OFDM_min_index;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"\n\n========================================================================================================\n");
+
+		if (cali_info->CCK_index > c.swing_table_size_cck - 1)
+			cali_info->CCK_index = c.swing_table_size_cck - 1;
+		else if (cali_info->CCK_index <= 0)
+			cali_info->CCK_index = 0;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
+			cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->power_index_offset[p] = 0;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
+		cali_info->CCK_index, cali_info->bb_swing_idx_cck_base);       /*Print Swing base & current*/
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
+			cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
+	}
+
+	if ((dm->support_ic_type & ODM_RTL8814A)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "power_tracking_type=%d\n", power_tracking_type);
+
+		if (power_tracking_type == 0) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+		} else if (power_tracking_type == 1) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_2G_TSSI_5G_MODE, p, 0);
+		} else if (power_tracking_type == 2) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_5G_TSSI_2G_MODE, p, 0);
+		} else if (power_tracking_type == 3) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
+		}
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
+		cali_info->power_index_offset[RF_PATH_B] != 0 ||
+		cali_info->power_index_offset[RF_PATH_C] != 0 ||
+		cali_info->power_index_offset[RF_PATH_D] != 0) &&
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		cali_info->txpowertrack_control && (rtlefu->eeprom_thermalmeter != 0xff)) {
+#else
+		cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+#endif
+		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
+
+		cali_info->is_tx_power_changed = true;	/*Always true after Tx Power is adjusted by power tracking.*/
+		/*  */
+		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
+		/* to increase TX power. Otherwise, EVM will be bad. */
+		/*  */
+		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
+		if (thermal_value > cali_info->thermal_value) {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, rtlefu->eeprom_thermalmeter, cali_info->thermal_value);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+#endif
+			}
+		} else if (thermal_value < cali_info->thermal_value) {	/*Low temperature*/
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, rtlefu->eeprom_thermalmeter, cali_info->thermal_value);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+#endif
+			}
+		}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		if (thermal_value > rtlefu->eeprom_thermalmeter)
+#else
+		if (thermal_value > hal_data->eeprom_thermal_meter)
+#endif
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
+#endif
+		{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) higher than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+		} else {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) lower than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+
+		}
+
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
+
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	}
+
+
+	if (dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (rtlefu->eeprom_thermalmeter != 0xff)) {
+#else
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+#endif
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			if (thermal_value > rtlefu->eeprom_thermalmeter) {
+#else
+			if (thermal_value > hal_data->eeprom_thermal_meter) {
+#endif
+#else
+			if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) higher than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			} else {
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) lower than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter);
+#else
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+#endif
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
+	}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	/* Wait sacn to do IQK by RF Jenyu*/
+	if ((*dm->is_scan_in_process == false)  && (!iqk_info->rfk_forbidden)) {
+		if (!IS_HARDWARE_TYPE_8723B(adapter)) {
+			/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
+			if (delta_IQK >= c.threshold_iqk) {
+				cali_info->thermal_value_iqk = thermal_value;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+				if (!cali_info->is_iqk_in_progress)
+					(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
+			}
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
+		if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
+		if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
+
+	cali_info->tx_powercount = 0;
+}
+
+
+
+/* 3============================================================
+ * 3 IQ Calibration
+ * 3============================================================ */
+
+void
+odm_reset_iqk_result(
+	void					*dm_void
+)
+{
+	return;
+}
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
+{
+	u8	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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
+	};
+	u8	place = chnl;
+
+
+	if (chnl > 14) {
+		for (place = 14; place < sizeof(channel_all); place++) {
+			if (channel_all[place] == chnl)
+				return place - 13;
+		}
+	}
+	return 0;
+
+}
+#endif
+
+void
+odm_iq_calibrate(
+	struct dm_struct	*dm
+)
+{
+	void	*adapter = dm->adapter;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (*dm->is_fcs_mode_enable)
+		return;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	if (IS_HARDWARE_TYPE_8812AU(adapter))
+		return;
+#endif
+
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		if ((*dm->channel != dm->pre_channel) && (!*dm->is_scan_in_process)) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
+		}
+
+		if (dm->linked_interval < 3)
+			dm->linked_interval++;
+
+		if (dm->linked_interval == 2)
+			halrf_iqk_trigger(dm, false);
+	} else
+		dm->linked_interval = 0;
+}
+
+void phydm_rf_init(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	odm_txpowertracking_init(dm);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_clear_txpowertracking_state(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
+#endif
+#endif
+
+}
+
+void phydm_rf_watchdog(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_txpowertracking_check(dm);
+	/*if (dm->support_ic_type & ODM_IC_11AC_SERIES)*/
+		/*odm_iq_calibrate(dm);*/
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ce.h
new file mode 100644
index 000000000000..6db641f0c7b0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_ce.h
@@ -0,0 +1,125 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HAL_PHY_RF_H__
+#define __HAL_PHY_RF_H__
+
+#include "halrf/halrf_kfree.h"
+#if (RTL8814A_SUPPORT == 1)
+	#include "halrf/rtl8814a/halrf_iqk_8814a.h"
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#include "halrf/rtl8822b/halrf_iqk_8822b.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
+#endif
+
+#include "halrf/halrf_powertracking_ce.h"
+
+
+enum spur_cal_method {
+	PLL_RESET,
+	AFE_PHASE_SEL
+};
+
+enum pwrtrack_method {
+	BBSWING,
+	TXAGC,
+	MIX_MODE,
+	TSSI_MODE,
+	MIX_2G_TSSI_5G_MODE,
+	MIX_5G_TSSI_2G_MODE
+};
+
+typedef void	(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void(*func_iqk)(void *, u8, u8, u8);
+typedef void	(*func_lck)(void *);
+typedef void	(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void(*func_swing_xtal)(void *, s8 **, s8 **);
+typedef void(*func_set_xtal)(void *);
+
+struct txpwrtrack_cfg {
+	u8		swing_table_size_cck;
+	u8		swing_table_size_ofdm;
+	u8		threshold_iqk;
+	u8		threshold_dpk;
+	u8		average_thermal_num;
+	u8		rf_path_count;
+	u32		thermal_reg_addr;
+	func_set_pwr	odm_tx_pwr_track_set_pwr;
+	func_iqk	do_iqk;
+	func_lck		phy_lc_calibrate;
+	func_swing	get_delta_swing_table;
+	func_swing8814only	get_delta_swing_table8814only;
+	func_swing_xtal			get_delta_swing_xtal_table;
+	func_set_xtal			odm_txxtaltrack_set_xtal;
+};
+
+void
+configure_txpower_track(
+	void					*dm_void,
+	struct txpwrtrack_cfg	*config
+);
+
+
+void
+odm_clear_txpowertracking_state(
+	void					*dm_void
+);
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	void					*dm_void
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void	*dm
+#else
+	void	*adapter
+#endif
+);
+
+
+
+#define ODM_TARGET_CHNL_NUM_2G_5G	59
+
+
+void
+odm_reset_iqk_result(
+	void					*dm_void
+);
+u8
+odm_get_right_chnl_place_for_iqk(
+	u8 chnl
+);
+
+void phydm_rf_init(void					*dm_void);
+void phydm_rf_watchdog(void					*dm_void);
+
+#endif	/*  #ifndef __HAL_PHY_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_win.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_win.c
new file mode 100644
index 000000000000..588c41519137
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_win.c
@@ -0,0 +1,818 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
+	do {\
+		for (_offset = 0; _offset < _size; _offset++) { \
+			\
+			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
+				\
+				if (_offset != 0)\
+					_offset--;\
+				break;\
+			} \
+		}			\
+		if (_offset >= _size)\
+			_offset = _size-1;\
+	} while (0)
+
+void configure_txpower_track(
+	struct dm_struct		*dm,
+	struct txpwrtrack_cfg	*config
+)
+{
+#if RTL8192E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192E)
+		configure_txpower_track_8192e(config);
+#endif
+#if RTL8821A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821)
+		configure_txpower_track_8821a(config);
+#endif
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
+#endif
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
+#endif
+
+#if RTL8188F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188F)
+		configure_txpower_track_8188f(config);
+#endif
+
+#if RTL8723B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723B)
+		configure_txpower_track_8723b(config);
+#endif
+
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
+#endif
+
+#if RTL8703B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8703B)
+		configure_txpower_track_8703b(config);
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
+#endif
+
+#if RTL8723D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723D)
+		configure_txpower_track_8723d(config);
+#endif
+
+/* JJ ADD 20161014 */
+#if RTL8710B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8710B)
+		configure_txpower_track_8710b(config);
+#endif
+
+#if RTL8821C_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821C)
+		configure_txpower_track_8821c(config);
+#endif
+
+}
+
+/* **********************************************************************
+ * <20121113, Kordan> This function should be called when tx_agc changed.
+ * Otherwise the previous compensation is gone, because we record the
+ * delta of temperature between two TxPowerTracking watch dogs.
+ *
+ * NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
+ * need to call this function.
+ * ********************************************************************** */
+void
+odm_clear_txpowertracking_state(
+	struct dm_struct		*dm
+)
+{
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA((PADAPTER)(dm->adapter));
+	u8			p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+	cali_info->CCK_index = 0;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+
+		cali_info->power_index_offset[p] = 0;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+
+		cali_info->absolute_ofdm_swing_idx[p] = 0;    /* Initial Mix mode power tracking*/
+		cali_info->remnant_ofdm_swing_idx[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+
+	cali_info->modify_tx_agc_flag_path_a = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_b = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_c = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_d = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->remnant_cck_swing_idx = 0;
+	cali_info->thermal_value = hal_data->eeprom_thermal_meter;
+
+	cali_info->modify_tx_agc_value_cck = 0;			/* modify by Mingzhi.Guo */
+	cali_info->modify_tx_agc_value_ofdm = 0;		/* modify by Mingzhi.Guo */
+
+}
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct		*dm
+#else
+	void	*adapter
+#endif
+)
+{
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct		*dm = &hal_data->odmpriv;
+#endif
+#endif
+
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+ 	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
+	s8			diff_DPK[4] = {0};
+	u8			thermal_value_avg_count = 0;
+	u32			thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
+
+	u8			OFDM_min_index = 0;  /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
+	u8			indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
+	u8			power_tracking_type = hal_data->RfPowerTrackingType;
+	u8			xtal_offset_eanble = 0;
+	s8			thermal_value_temp = 0;
+
+	struct txpwrtrack_cfg	c;
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	u8			*delta_swing_table_idx_tup_a = NULL;
+	u8			*delta_swing_table_idx_tdown_a = NULL;
+	u8			*delta_swing_table_idx_tup_b = NULL;
+	u8			*delta_swing_table_idx_tdown_b = NULL;
+	/*for 8814 add by Yu Chen*/
+	u8			*delta_swing_table_idx_tup_c = NULL;
+	u8			*delta_swing_table_idx_tdown_c = NULL;
+	u8			*delta_swing_table_idx_tup_d = NULL;
+	u8			*delta_swing_table_idx_tdown_d = NULL;
+	/*for Xtal Offset by James.Tung*/
+	s8			*delta_swing_table_xtal_up = NULL;
+	s8			*delta_swing_table_xtal_down = NULL;
+
+	/* 4 2. Initilization ( 7 steps in total ) */
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+
+	if (dm->support_ic_type & ODM_RTL8814A)	/*for 8814 path C & D*/
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B))	/*for Xtal Offset*/
+		(*c.get_delta_swing_xtal_table)(dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
+
+
+	cali_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
+	cali_info->is_txpowertracking_init = true;
+
+	/*cali_info->txpowertrack_control = hal_data->txpowertrack_control;
+	<Kordan> We should keep updating the control variable according to HalData.
+	<Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+	cali_info->rega24 = 0x090e1317;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	if (*(dm->mp_mode) == true)
+		cali_info->rega24 = 0x090e1317;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
+		cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"cali_info->txpowertrack_control=%d,  hal_data->eeprom_thermal_meter %d\n", cali_info->txpowertrack_control,  hal_data->eeprom_thermal_meter);
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+
+	thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"thermal_value_temp(%d) = thermal_value(%d) + power_time_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
+
+	if (thermal_value_temp > 63)
+		thermal_value = 63;
+	else if (thermal_value_temp < 0)
+		thermal_value = 0;
+	else
+		thermal_value = thermal_value_temp;
+
+	/*add log by zhao he, check c80/c94/c14/ca0 value*/
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		regc80 = odm_get_bb_reg(dm, 0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, 0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, 0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, 0xab4, 0x000007FF);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+
+	if (!cali_info->txpowertrack_control)
+		return;
+
+	if (hal_data->eeprom_thermal_meter == 0xff) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", hal_data->eeprom_thermal_meter);
+		return;
+	}
+
+	/*4 3. Initialize ThermalValues of rf_calibrate_info*/
+
+	if (cali_info->is_reloadtxpowerindex)
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "reload ofdm index for band switch\n");
+
+	/*4 4. Calculate average thermal meter*/
+
+	cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
+	cali_info->thermal_value_avg_index++;
+	if (cali_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		cali_info->thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (cali_info->thermal_value_avg[i]) {
+			thermal_value_avg += cali_info->thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+		cali_info->thermal_value_delta = thermal_value - hal_data->eeprom_thermal_meter;
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, hal_data->eeprom_thermal_meter);
+	}
+
+	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
+
+	/* "delta" here is used to determine whether thermal value changes or not. */
+	delta	= (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
+	delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+
+	if (cali_info->thermal_value_iqk == 0xff) {	/*no PG, use thermal value for IQK*/
+		cali_info->thermal_value_iqk = thermal_value;
+		delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, use thermal_value for IQK\n");
+	}
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++)
+		diff_DPK[p] = (s8)thermal_value - (s8)cali_info->dpk_thermal[p];
+
+	/*4 6. If necessary, do LCK.*/
+
+	if (!(dm->support_ic_type & ODM_RTL8821)) {	/*no PG, do LCK at initial status*/
+		if (cali_info->thermal_value_lck == 0xff) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "no PG, do LCK\n");
+			cali_info->thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, so close power tracking driver LCK*/
+			if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
+				if (c.phy_lc_calibrate)
+					(*c.phy_lc_calibrate)(dm);
+			}
+
+			delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
+
+		/* Wait sacn to do LCK by RF Jenyu*/
+		if( (*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
+			/* Delta temperature is equal to or larger than 20 centigrade.*/
+			if (delta_LCK >= c.threshold_iqk) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+				cali_info->thermal_value_lck = thermal_value;
+
+				/*Use RTLCK, so close power tracking driver LCK*/
+				if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
+					if (c.phy_lc_calibrate)
+						(*c.phy_lc_calibrate)(dm);
+				}
+			}
+		}
+	}
+
+	/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
+
+	if (delta > 0 && cali_info->txpowertrack_control) {
+		/* "delta" here is used to record the absolute value of differrence. */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		delta = thermal_value > hal_data->eeprom_thermal_meter ? (thermal_value - hal_data->eeprom_thermal_meter) : (hal_data->eeprom_thermal_meter - thermal_value);
+#else
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+#endif
+		if (delta >= TXPWR_TRACK_TABLE_SIZE)
+			delta = TXPWR_TRACK_TABLE_SIZE - 1;
+
+		/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		if (thermal_value > hal_data->eeprom_thermal_meter) {
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_b[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_c[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_d[delta];       /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
+
+				if (cali_info->xtal_offset_last == cali_info->xtal_offset)
+					xtal_offset_eanble = 0;
+				else
+					xtal_offset_eanble = 1;
+			}
+
+		} else {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
+
+				switch (p) {
+				case RF_PATH_B:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_b[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_C:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_c[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				case RF_PATH_D:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_d[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_a[delta];        /*Record delta swing for mix mode power tracking*/
+					PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
+
+				if (cali_info->xtal_offset_last == cali_info->xtal_offset)
+					xtal_offset_eanble = 0;
+				else
+					xtal_offset_eanble = 1;
+			}
+
+		}
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
+
+			if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p])         /*If Thermal value changes but lookup table value still the same*/
+				cali_info->power_index_offset[p] = 0;
+			else
+				cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p];      /*Power index diff between 2 times Power Tracking*/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
+
+			cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
+			cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
+
+			cali_info->bb_swing_idx_cck = cali_info->CCK_index;
+			cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
+
+			/*************Print BB Swing base and index Offset*************/
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
+
+			/*4 7.1 Handle boundary conditions of index.*/
+
+			if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
+				cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
+			else if (cali_info->OFDM_index[p] <= OFDM_min_index)
+				cali_info->OFDM_index[p] = OFDM_min_index;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"\n\n========================================================================================================\n");
+
+		if (cali_info->CCK_index > c.swing_table_size_cck - 1)
+			cali_info->CCK_index = c.swing_table_size_cck - 1;
+		else if (cali_info->CCK_index <= 0)
+			cali_info->CCK_index = 0;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
+			cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->power_index_offset[p] = 0;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+		"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
+		cali_info->CCK_index, cali_info->bb_swing_idx_cck_base);       /*Print Swing base & current*/
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
+			cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
+	}
+
+	if ((dm->support_ic_type & ODM_RTL8814A)) {
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "power_tracking_type=%d\n", power_tracking_type);
+
+		if (power_tracking_type == 0) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+		} else if (power_tracking_type == 1) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_2G_TSSI_5G_MODE, p, 0);
+		} else if (power_tracking_type == 2) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_5G_TSSI_2G_MODE, p, 0);
+		} else if (power_tracking_type == 3) {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
+		}
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
+		cali_info->power_index_offset[RF_PATH_B] != 0 ||
+		cali_info->power_index_offset[RF_PATH_C] != 0 ||
+		cali_info->power_index_offset[RF_PATH_D] != 0) &&
+		cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
+
+		cali_info->is_tx_power_changed = true;	/*Always true after Tx Power is adjusted by power tracking.*/
+		/*  */
+		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
+		/* to increase TX power. Otherwise, EVM will be bad. */
+		/*  */
+		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
+		if (thermal_value > cali_info->thermal_value) {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+			}
+		} else if (thermal_value < cali_info->thermal_value) {	/*Low temperature*/
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
+			}
+		}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+		if (thermal_value > hal_data->eeprom_thermal_meter)
+#else
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
+#endif
+		{
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+		} else {
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+				"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+				for (p = RF_PATH_A; p < c.rf_path_count; p++)
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+			}
+
+		}
+
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
+
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+			"cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
+
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+
+	}
+
+
+	if (dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
+
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+			if (thermal_value > hal_data->eeprom_thermal_meter) {
+#else
+			if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
+#endif
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			} else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
+	}
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	/* Wait sacn to do IQK by RF Jenyu*/
+	if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
+		if (!IS_HARDWARE_TYPE_8723B(adapter)) {
+			/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
+			if (delta_IQK >= c.threshold_iqk) {
+				cali_info->thermal_value_iqk = thermal_value;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+				if (!cali_info->is_iqk_in_progress)
+					(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
+			}
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
+		if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+	if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
+		if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
+			s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
+
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x82c, BIT(31), 0x0);
+		}
+	}
+
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
+
+	cali_info->tx_powercount = 0;
+}
+
+
+
+/* 3============================================================
+ * 3 IQ Calibration
+ * 3============================================================ */
+
+void
+odm_reset_iqk_result(
+	struct dm_struct	*dm
+)
+{
+	return;
+}
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
+{
+	u8	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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
+	};
+	u8	place = chnl;
+
+
+	if (chnl > 14) {
+		for (place = 14; place < sizeof(channel_all); place++) {
+			if (channel_all[place] == chnl)
+				return place - 13;
+		}
+	}
+	return 0;
+
+}
+#endif
+
+void
+odm_iq_calibrate(
+	struct dm_struct	*dm
+)
+{
+	void	*adapter = dm->adapter;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	
+	RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("=>%s\n" , __FUNCTION__));
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (*dm->is_fcs_mode_enable)
+		return;
+#endif
+
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("interval=%d ch=%d prech=%d scan=%s\n", dm->linked_interval,
+			*dm->channel,  dm->pre_channel, *dm->is_scan_in_process == TRUE ? "TRUE":"FALSE"));
+
+		if (*dm->channel != dm->pre_channel) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
+		}
+
+		if ((dm->linked_interval < 3) && (!*dm->is_scan_in_process))
+			dm->linked_interval++;
+
+		if (dm->linked_interval == 2)
+			PHY_IQCalibrate((PADAPTER)adapter, false);
+	} else
+		dm->linked_interval = 0;
+
+		RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("<=%s interval=%d ch=%d prech=%d scan=%s\n", __FUNCTION__, dm->linked_interval,
+			*dm->channel,  dm->pre_channel, *dm->is_scan_in_process == TRUE?"TRUE":"FALSE"));
+}
+
+void phydm_rf_init(struct dm_struct		*dm)
+{
+
+	odm_txpowertracking_init(dm);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_clear_txpowertracking_state(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
+#endif
+#endif
+
+}
+
+void phydm_rf_watchdog(struct dm_struct		*dm)
+{
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	odm_txpowertracking_check(dm);
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_iq_calibrate(dm);
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_win.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_win.h
new file mode 100644
index 000000000000..a844bd85576c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halphyrf_win.h
@@ -0,0 +1,136 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PHY_RF_H__
+#define __HAL_PHY_RF_H__
+
+#if (RTL8814A_SUPPORT == 1)
+    #if RT_PLATFORM == PLATFORM_MACOSX
+        #include "rtl8814a/halrf_iqk_8814a.h"
+    #else
+        #include "halrf/rtl8814a/halrf_iqk_8814a.h"
+    #endif
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+    #if RT_PLATFORM == PLATFORM_MACOSX
+        #include "rtl8822b/halrf_iqk_8822b.h"
+        #include "../../MAC/Halmac_type.h"
+    #else
+        #include "halrf/rtl8822b/halrf_iqk_8822b.h"
+        #include "../mac/Halmac_type.h"
+    #endif
+#endif
+
+#if RT_PLATFORM == PLATFORM_MACOSX
+    #include "halrf_powertracking_win.h"
+    #include "halrf_kfree.h"
+    #include "halrf_txgapcal.h"
+#else
+    #include "halrf/halrf_powertracking_win.h"
+    #include "halrf/halrf_kfree.h"
+    #include "halrf/halrf_txgapcal.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+    #if RT_PLATFORM == PLATFORM_MACOSX
+        #include "rtl8821c/halrf_iqk_8821c.h"
+    #else
+        #include "halrf/rtl8821c/halrf_iqk_8821c.h"
+    #endif
+#endif
+
+enum spur_cal_method {
+	PLL_RESET,
+	AFE_PHASE_SEL
+};
+
+enum pwrtrack_method {
+	BBSWING,
+	TXAGC,
+	MIX_MODE,
+	TSSI_MODE,
+	MIX_2G_TSSI_5G_MODE,
+	MIX_5G_TSSI_2G_MODE
+};
+
+typedef void(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void(*func_iqk)(void *, u8, u8, u8);
+typedef void(*func_lck)(void *);
+typedef void(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void (*func_swing_xtal)(void *, s8 **, s8 **);
+typedef void (*func_set_xtal)(void *);
+typedef void(*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
+
+struct txpwrtrack_cfg {
+	u8		swing_table_size_cck;
+	u8		swing_table_size_ofdm;
+	u8		threshold_iqk;
+	u8		threshold_dpk;
+	u8		average_thermal_num;
+	u8		rf_path_count;
+	u32		thermal_reg_addr;
+	func_set_pwr	odm_tx_pwr_track_set_pwr;
+	func_iqk	do_iqk;
+	func_lck		phy_lc_calibrate;
+	func_swing	get_delta_swing_table;
+	func_swing8814only	get_delta_swing_table8814only;
+	func_swing_xtal			get_delta_swing_xtal_table;
+	func_set_xtal			odm_txxtaltrack_set_xtal;
+	func_all_swing	get_delta_all_swing_table;
+};
+
+void
+configure_txpower_track(
+	struct dm_struct		*dm,
+	struct txpwrtrack_cfg	*config
+);
+
+
+void
+odm_clear_txpowertracking_state(
+	struct dm_struct		*dm
+);
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct		*dm
+#else
+	void	*adapter
+#endif
+);
+
+
+
+#define ODM_TARGET_CHNL_NUM_2G_5G	59
+
+
+void
+odm_reset_iqk_result(
+	struct dm_struct	*dm
+);
+u8
+odm_get_right_chnl_place_for_iqk(
+	u8 chnl
+);
+
+void odm_iq_calibrate(struct dm_struct	*dm);
+void phydm_rf_init(struct dm_struct		*dm);
+void phydm_rf_watchdog(struct dm_struct		*dm);
+
+#endif	/*  #ifndef __HAL_PHY_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf.c
new file mode 100644
index 000000000000..d146fbc9f663
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf.c
@@ -0,0 +1,1576 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void halrf_basic_profile(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/* HAL RF version List */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "% HAL RF version %");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Power Tracking",
+		       HALRF_POWRTRACKING_VER);
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s %s\n", "IQK",
+					(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD)? "FW" : HALRF_IQK_VER,
+					(halrf_match_iqk_version(dm_void))? "(match)" : "(mismatch)");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "LCK", HALRF_LCK_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "DPK", HALRF_DPK_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "KFREE", HALRF_KFREE_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "TX 2G Current Calibration",
+		       HALRF_PABIASK_VER);
+
+	*_used = used;
+	*_out_len = out_len;
+#endif
+}
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void
+_iqk_page_switch(
+		void			*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (dm->support_ic_type == ODM_RTL8821C)	
+		odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	else	
+		odm_write_4byte(dm, 0x1b00, 0xf800000a);
+}
+
+u32 halrf_psd_log2base(u32 val)
+{
+	u8	j;
+	u32	tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
+	u32	result, val_fractiond_b = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
+				   174, 151, 132, 115, 100, 86, 74, 62, 51, 42,
+							   32, 23, 15, 7, 0
+							      };
+
+	if (val == 0)
+		return 0;
+
+	tmp = val;
+
+	while (1) {
+		if (tmp == 1)
+			break;
+
+		tmp = (tmp >> 1);
+		shiftcount++;
+	}
+
+
+	val_integerd_b = shiftcount + 1;
+
+	tmp2 = 1;
+	for (j = 1; j <= val_integerd_b; j++)
+		tmp2 = tmp2 * 2;
+
+	tmp = (val * 100) / tmp2;
+	tindex = tmp / 5;
+
+	if (tindex > 20)
+		tindex = 20;
+
+	val_fractiond_b = table_fraction[tindex];
+
+	result = val_integerd_b * 100 - val_fractiond_b;
+	
+	return result;
+
+
+}
+
+void phydm_get_iqk_cfir(
+	void *dm_void,
+	u8 idx,
+	u8 path,
+	boolean debug
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	
+	u8 i, ch;
+	u32 tmp;
+
+	if (debug)
+		ch = 2;
+	else
+		ch = 0;
+	odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+	if (idx == 0)
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+	else
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
+	odm_set_bb_reg(dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+	for (i = 0; i < 8; i++) {
+		odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0xe0000001 + (i * 4));
+		tmp = odm_get_bb_reg(dm, 0x1bfc, MASKDWORD);
+		iqk_info->iqk_cfir_real[ch][path][idx][i] = (tmp & 0x0fff0000) >> 16;
+		iqk_info->iqk_cfir_imag[ch][path][idx][i] = tmp & 0xfff;
+	}
+	odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0x0);
+	odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+}
+
+void
+halrf_iqk_xym_enable(
+	struct dm_struct *dm,
+	u8 xym_enable
+	)
+{
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+
+	if (xym_enable == 0)
+		iqk_info->xym_read = false;
+	else
+		iqk_info->xym_read = true;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %s\n", "xym_read = ", (iqk_info->xym_read ? "true": "false"));	
+}
+
+void
+halrf_iqk_xym_read(
+	void *dm_void,
+	u8 path,
+	u8 xym_type /*0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
+ )
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;	
+	u8 i, start, num;
+	u32 tmp1, tmp2;
+
+	if (!iqk_info->xym_read)
+		return;
+
+	if (*dm->band_width == 0) {
+		start = 3;
+		num = 4;
+	}else if (*dm->band_width == 1) { 
+		start = 2;
+		num = 6;
+	}else {
+		start = 0;
+  		num = 10;
+ 	}
+	
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+ 	tmp1 =  odm_read_4byte(dm, 0x1b1c);
+	odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
+
+ 	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+ 	tmp2 =  odm_read_4byte(dm, 0x1b1c);
+	odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
+
+	for (path = 0; path < 2; path ++) {
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		switch(xym_type){
+ 			case 0:
+				for (i = 0; i < num ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe6+start+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->rx_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+				}
+			break;
+			case 1:		
+				for (i = 0; i < num ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe6+start+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->tx_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+				}
+			break;
+			case 2:		
+				for (i = 0; i < 6 ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe0+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->gs1_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+				}
+			break;
+			case 3:		
+				for (i = 0; i < 6 ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe0+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->gs2_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+	  		}
+			break;			
+			case 4:		
+				for (i = 0; i < 6 ;i++) {
+	   				odm_write_4byte(dm, 0x1b14, 0xe0+i);
+	   				odm_write_4byte(dm, 0x1b14, 0x0);
+	   				iqk_info->rxk1_xym[path][i] = odm_read_4byte(dm, 0x1b38);
+	  		}
+			break;
+
+		}
+		odm_write_4byte(dm, 0x1b38, 0x20000000);
+		odm_write_4byte(dm, 0x1b00, 0xf8000008);
+		odm_write_4byte(dm, 0x1b1c, tmp1);
+		odm_write_4byte(dm, 0x1b00, 0xf800000a);
+		odm_write_4byte(dm, 0x1b1c, tmp2);
+		_iqk_page_switch(dm);
+	}
+}
+
+void halrf_iqk_xym_show(
+	struct dm_struct *dm,
+	u8 xym_type /*0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
+ )
+{
+	u8 num, path, path_num, i;		
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;	
+
+	if (dm->rf_type ==RF_1T1R)
+		path_num = 0x1;
+	else if (dm->rf_type ==RF_2T2R)
+		path_num = 0x2;
+	else
+		path_num = 0x4;
+
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		num = 4;
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		num = 6;
+	else
+		num = 10;
+		
+	for (path = 0; path < path_num; path ++) {
+		switch (xym_type){
+		case 0:
+			for (i = 0 ; i < num; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A RX-XYM ": "PATH B RX-XYM", i, iqk_info->rx_xym[path][i]);
+			break;
+		case 1:
+			for (i = 0 ; i < num; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A TX-XYM ": "PATH B TX-XYM", i, iqk_info->tx_xym[path][i]);
+			break;
+		case 2:
+			for (i = 0 ; i < 6; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A GS1-XYM ": "PATH B GS1-XYM", i, iqk_info->gs1_xym[path][i]);
+			break;
+		case 3:
+			for (i = 0 ; i < 6; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A GS2-XYM ": "PATH B GS2-XYM", i, iqk_info->gs2_xym[path][i]);
+			break;
+		case 4:			
+			for (i = 0 ; i < 6; i ++)
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s %-2d: 0x%x\n",
+					(path == 0) ? "PATH A RXK1-XYM ": "PATH B RXK1-XYM", i, iqk_info->rxk1_xym[path][i]);
+			break;
+		}
+	}
+}
+
+
+void
+halrf_iqk_xym_dump(
+	void *dm_void
+ )
+{
+	u32 tmp1, tmp2;
+ 	struct dm_struct	 *dm = (struct dm_struct *)dm_void;
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+ 	tmp1 =  odm_read_4byte(dm, 0x1b1c);
+ 	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+ 	tmp2 =  odm_read_4byte(dm, 0x1b1c);
+ 	/*halrf_iqk_xym_read(dm, xym_type);*/
+ 	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+ 	odm_write_4byte(dm, 0x1b1c, tmp1);
+ 	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+ 	odm_write_4byte(dm, 0x1b1c, tmp2);
+ 	_iqk_page_switch(dm);
+}
+
+void halrf_iqk_info_dump(
+	void *dm_void,
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;	
+	u8 path, num, i;
+
+	u8 rf_path, j, reload_iqk = 0;
+	u32 tmp;
+	boolean iqk_result[2][NUM][2];	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+	/* IQK INFO */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s\n", "% IQK Info %");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s\n",
+		       (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" : "Driver-IQK");	
+
+	reload_iqk = (u8)odm_get_bb_reg(dm, 0x1bf0, BIT(16));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s: %s\n",
+		       "reload", (reload_iqk) ? "True" : "False");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s: %s\n",
+			"rfk_forbidden", (iqk_info->rfk_forbidden) ? "True" : "False");
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s: %s\n",
+			"segment_iqk", (iqk_info->segment_iqk) ? "True" : "False");
+#endif
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s:%d %d\n",
+			"iqk count / fail count", dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"%-20s: %d\n",
+			"channel", *dm->channel);
+
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_20");
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_40");
+	else if (*dm->band_width == CHANNEL_WIDTH_80)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_80");
+	else if (*dm->band_width == CHANNEL_WIDTH_160)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_160");
+	else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"bandwidth", "BW_UNKNOW");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
+		
+	tmp = odm_read_4byte(dm, 0x1bf0);
+	for(rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
+		for(j = 0; j < 2; j++)
+			iqk_result[0][rf_path][j] = (boolean)(tmp & BIT(rf_path + (j * 4)) >> (rf_path + (j * 4)));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-20s: 0x%08x\n","Reg0x1bf0", tmp);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_A-Tx result", (iqk_result[0][RF_PATH_A][0]) ?  "Fail" : "Pass");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_A-Rx result", (iqk_result[0][RF_PATH_A][1]) ?  "Fail" : "Pass");
+#if (RTL8822B_SUPPORT == 1) 
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_B-Tx result", (iqk_result[0][RF_PATH_B][0]) ?  "Fail" : "Pass");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+				"%-20s: %s\n",
+				"PATH_B-Rx result", (iqk_result[0][RF_PATH_B][1]) ?  "Fail" : "Pass");
+#endif
+	*_used = used;
+	*_out_len = out_len;
+
+}
+
+void halrf_get_fw_version(void	*dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	{
+		void		*adapter = dm->adapter;
+
+		rf->fw_ver = (((PADAPTER)adapter)->MgntInfo.FirmwareVersion << 16) | ((PADAPTER)adapter)->MgntInfo.FirmwareSubVersion;
+	}
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	{
+		struct rtl8192cd_priv *priv = dm->priv;
+
+		rf->fw_ver = (priv->pshare->fw_version << 16) | priv->pshare->fw_sub_version;
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	{
+		struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+		struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
+
+		rf->fw_ver = (rtlhal->fw_version << 16) | rtlhal->fw_subversion;
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE		*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+		rf->fw_ver = (hal_data->firmware_version << 16) | hal_data->firmware_sub_version;
+	}
+#endif
+}
+
+
+
+void halrf_iqk_dbg(void	*dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rf_path, j, reload_iqk = 0;
+	u8 path, num, i;
+	u32 tmp;
+	boolean iqk_result[2][NUM][2];	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	/* IQK INFO */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n", "====== IQK Info ======");
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n",
+		(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" : "Driver-IQK");
+
+	if (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) {
+		halrf_get_fw_version(dm);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: 0x%x\n",
+			"FW_VER", rf->fw_ver);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+			"IQK_VER", HALRF_IQK_VER);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"%-20s: %s\n",
+		"reload", (iqk_info->is_reload) ? "True" : "False");
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %d %d\n",
+			"iqk count / fail count", dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %d\n",
+			"channel", *dm->channel);
+
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_20");
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_40");
+	else if (*dm->band_width == CHANNEL_WIDTH_80)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_80");
+	else if (*dm->band_width == CHANNEL_WIDTH_160)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_160");
+	else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"bandwidth", "BW_UNKNOW");
+/*
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
+*/
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"rfk_forbidden", (iqk_info->rfk_forbidden) ? "True" : "False");
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"segment_iqk", (iqk_info->segment_iqk) ? "True" : "False");
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.iqk_progressing_time, "(ms)");
+
+	
+
+
+	tmp = odm_read_4byte(dm, 0x1bf0);
+	for(rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
+		for(j = 0; j < 2; j++)
+			iqk_result[0][rf_path][j] = (boolean)(tmp & BIT(rf_path + (j * 4)) >> (rf_path + (j * 4)));
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: 0x%08x\n", "Reg0x1bf0", tmp);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: 0x%08x\n", "Reg0x1be8", odm_read_4byte(dm, 0x1be8));
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"PATH_A-Tx result", (iqk_result[0][RF_PATH_A][0]) ?  "Fail" : "Pass");
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"PATH_A-Rx result", (iqk_result[0][RF_PATH_A][1]) ?  "Fail" : "Pass");
+#if (RTL8822B_SUPPORT == 1) 
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",		
+				"PATH_B-Tx result", (iqk_result[0][RF_PATH_B][0]) ?  "Fail" : "Pass");
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %s\n",
+				"PATH_B-Rx result", (iqk_result[0][RF_PATH_B][1]) ?  "Fail" : "Pass");
+#endif
+
+
+}
+void halrf_lck_dbg(struct dm_struct *dm)
+{
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n", "====== LCK Info ======");
+	/*PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s\n",
+		(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "LCK" : "RTK"));*/
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "%-20s: %llu %s\n",
+				"progressing_time", dm->rf_calibrate_info.lck_progressing_time, "(ms)");
+}
+
+void
+halrf_iqk_dbg_cfir_backup(struct dm_struct *dm)
+{
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	u8	path, idx, i;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "backup TX/RX CFIR");	
+
+	for (path = 0; path < 2; path ++) {
+		for (idx = 0; idx < 2; idx++) {
+			phydm_get_iqk_cfir(dm, idx, path, true);
+		}
+	}
+
+	for (path = 0; path < 2; path ++) {
+		for (idx = 0; idx < 2; idx++) {
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-7s %-3s CFIR_real: %-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_real[2][path][idx][i]);
+			}
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-7s %-3s CFIR_img:%-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_imag[2][path][idx][i]);
+			}
+		}
+	}
+}
+
+
+void
+halrf_iqk_dbg_cfir_backup_update(
+	struct dm_struct			*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8 i, path, idx;
+
+	if(iqk_info->iqk_cfir_real[2][0][0][0] == 0) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "CFIR is invalid");
+		return;
+	}
+	for (path = 0; path < 2; path++) {
+		for (idx = 0; idx < 2; idx++) {
+			odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+			odm_set_bb_reg(dm, 0x1b2c, MASKDWORD, 0x7);
+			odm_set_bb_reg(dm, 0x1b38, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1b3c, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1bcc, MASKDWORD, 0x00000000);
+			if (idx == 0)
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+			else
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
+			odm_set_bb_reg(dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+			for (i = 0; i < 8; i++) {
+				odm_write_4byte(dm, 0x1bd8,	((0xc0000000 >> idx) + 0x3) + (i * 4) + (iqk_info->iqk_cfir_real[2][path][idx][i] << 9));
+				odm_write_4byte(dm, 0x1bd8, ((0xc0000000 >> idx) + 0x1) + (i * 4) + (iqk_info->iqk_cfir_imag[2][path][idx][i] << 9));
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_real[2][path][idx][i]);*/
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_imag[2][path][idx][i]);*/
+			}
+		}
+		odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0x0);
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "update new CFIR");
+}
+
+
+void
+halrf_iqk_dbg_cfir_reload(
+	struct dm_struct			*dm
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u8 i, path, idx;
+
+	if(iqk_info->iqk_cfir_real[0][0][0][0] == 0) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "CFIR is invalid");
+		return;
+	}
+	for (path = 0; path < 2; path++) {
+		for (idx = 0; idx < 2; idx++) {
+			odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+			odm_set_bb_reg(dm, 0x1b2c, MASKDWORD, 0x7);
+			odm_set_bb_reg(dm, 0x1b38, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1b3c, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, 0x1bcc, MASKDWORD, 0x00000000);
+			if (idx == 0)
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+			else
+				odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
+			odm_set_bb_reg(dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+			for (i = 0; i < 8; i++) {
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_real[0][path][idx][i]);*/
+				/*odm_write_4byte(dm, 0x1bd8, iqk_info->iqk_cfir_imag[0][path][idx][i]);*/
+				odm_write_4byte(dm, 0x1bd8,	((0xc0000000 >> idx) + 0x3) + (i * 4) + (iqk_info->iqk_cfir_real[0][path][idx][i] << 9));
+				odm_write_4byte(dm, 0x1bd8, ((0xc0000000 >> idx) + 0x1) + (i * 4) + (iqk_info->iqk_cfir_imag[0][path][idx][i] << 9));
+			}
+		}
+		odm_set_bb_reg(dm, 0x1bd8, MASKDWORD, 0x0);
+		odm_set_bb_reg(dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "write CFIR with default value");
+}
+
+void
+halrf_iqk_dbg_cfir_write(
+	struct dm_struct			*dm,
+	u8	type,
+	u32 path,
+	u32 idx,
+	u32 i,
+	u32 data
+)
+{
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	if (type == 0)
+		iqk_info->iqk_cfir_real[2][path][idx][i] = data;
+	else
+		iqk_info->iqk_cfir_imag[2][path][idx][i] = data;
+}
+
+void
+halrf_iqk_dbg_cfir_backup_show(struct dm_struct *dm)
+{
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	u8	path, idx, i;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-20s\n", "backup TX/RX CFIR");	
+
+	for (path = 0; path < 2; path ++) {
+		for (idx = 0; idx < 2; idx++) {
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-10s %-3s CFIR_real: %-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_real[2][path][idx][i]);
+			}
+			for(i = 0; i < 8; i++) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]%-10s %-3s CFIR_img:%-2d: 0x%x\n",
+					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, iqk_info->iqk_cfir_imag[2][path][idx][i]);
+			}
+		}
+	}
+}
+
+void
+halrf_do_imr_test(
+	void	*dm_void,
+	u8  flag_imr_test
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (flag_imr_test != 0x0)
+		switch (dm->support_ic_type) {
+#if (RTL8822B_SUPPORT == 1)
+		case ODM_RTL8822B:
+			do_imr_test_8822b(dm);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
+		case ODM_RTL8821C:
+			do_imr_test_8821c(dm);
+			break;
+#endif
+		default:
+		break;
+		}
+}
+
+void halrf_iqk_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	
+	/*dm_value[0]=0x0: backup from SRAM & show*/
+	/*dm_value[0]=0x1: write backup CFIR to SRAM*/
+	/*dm_value[0]=0x2: reload default CFIR to SRAM*/
+	/*dm_value[0]=0x3: show backup*/
+	/*dm_value[0]=0x10: write backup CFIR real part*/
+	/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/
+	/*dm_value[0]=0x11: write backup CFIR imag*/
+	/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/	
+	/*dm_value[0]=0x20 :xym_read enable*/
+	/*--> dm_value[1]:0:disable, 1:enable*/ 
+	/*if dm_value[0]=0x20 = enable, */
+	/*0x1:show rx_sym; 0x2: tx_xym; 0x3:gs1_xym; 0x4:gs2_sym; 0x5:rxk1_xym*/
+
+	if (dm_value[0] == 0x0)
+		halrf_iqk_dbg_cfir_backup(dm);
+	else if (dm_value[0] == 0x1)
+		halrf_iqk_dbg_cfir_backup_update(dm);
+	else if (dm_value[0] == 0x2)
+		halrf_iqk_dbg_cfir_reload(dm);
+	else if (dm_value[0] == 0x3)
+		halrf_iqk_dbg_cfir_backup_show(dm);
+	else if (dm_value[0] == 0x10)
+		halrf_iqk_dbg_cfir_write(dm, 0, dm_value[1], dm_value[2], dm_value[3], dm_value[4]);
+	else if (dm_value[0] == 0x11)
+		halrf_iqk_dbg_cfir_write(dm, 1, dm_value[1], dm_value[2], dm_value[3], dm_value[4]);
+	else if (dm_value[0] == 0x20)
+		halrf_iqk_xym_enable(dm, (u8)dm_value[1]);
+	else if (dm_value[0] == 0x21)
+		halrf_iqk_xym_show(dm,(u8)dm_value[1]);
+	else if (dm_value[0] == 0x30)
+		halrf_do_imr_test(dm, (u8)dm_value[1]);
+}
+
+void
+halrf_iqk_hwtx_check(
+	void *dm_void,
+	boolean		is_check
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+	u32 tmp_b04;
+
+	if (is_check)
+		iqk_info->is_hwtx = (boolean)odm_get_bb_reg(dm, 0xb00, BIT(8));
+	else {
+		if (iqk_info->is_hwtx) {
+			tmp_b04 = odm_read_4byte(dm, 0xb04);
+			odm_set_bb_reg(dm, 0xb04, BIT(3) | BIT (2), 0x0);
+			odm_write_4byte(dm, 0xb04, tmp_b04);
+		}
+	}
+}
+
+void
+halrf_segment_iqk_trigger(
+	void			*dm_void,
+	boolean		clear,
+	boolean		segment_iqk
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info		*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64 start_time;
+	
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if (odm_check_power_status(dm) == false)
+		return;
+#endif
+
+	if ((dm->mp_mode != NULL) && (rf->is_con_tx != NULL) && (rf->is_single_tone != NULL) && (rf->is_carrier_suppresion != NULL))
+		if (*dm->mp_mode && ((*rf->is_con_tx || *rf->is_single_tone || *rf->is_carrier_suppresion)))
+			return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (!(rf->rf_supportability & HAL_RF_IQK))
+		return;
+#endif
+
+#if DISABLE_BB_RF
+	return;
+#endif
+	if (iqk_info->rfk_forbidden)
+		return;
+
+	if (!dm->rf_calibrate_info.is_iqk_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		dm->IQK_info.segment_iqk = segment_iqk;
+
+		switch (dm->support_ic_type) {
+#if (RTL8822B_SUPPORT == 1)
+		case ODM_RTL8822B:
+			phy_iq_calibrate_8822b(dm, clear, segment_iqk);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
+		case ODM_RTL8821C:
+			phy_iq_calibrate_8821c(dm, clear, segment_iqk);
+			break;
+#endif
+#if (RTL8814B_SUPPORT == 1)
+		case ODM_RTL8814B:
+			break;
+#endif
+		default:
+			break;
+		}
+		dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(dm, start_time);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]IQK progressing_time = %lld ms\n", dm->rf_calibrate_info.iqk_progressing_time);
+
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "== Return the IQK CMD, because RFKs in Progress ==\n");
+}
+
+
+
+#endif
+
+
+
+u8 halrf_match_iqk_version(void	*dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	u32 iqk_version = 0;
+	char temp[10] = {0};
+
+	odm_move_memory(dm, temp, (PVOID)(HALRF_IQK_VER), sizeof(temp));
+	PHYDM_SSCANF(temp + 2, DCMD_HEX, &iqk_version);
+	
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if ((iqk_version >= 0x24) && (odm_get_hw_img_version(dm) >= 72))
+			return 1;
+		else if ((iqk_version <= 0x23) && (odm_get_hw_img_version(dm) <= 71))
+			return 1;
+		else
+			return 0;
+	}
+
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if ((iqk_version >= 0x18) && (odm_get_hw_img_version(dm) >= 37))
+			return 1;
+		else
+			return 0;
+	}
+
+	return 1;
+}
+
+
+
+void
+halrf_rf_lna_setting(
+	void	*dm_void,
+	enum phydm_lna_set type
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_	 *rf = &dm->rf_table;
+
+		switch (dm->support_ic_type) {
+#if (RTL8188E_SUPPORT == 1)
+		case ODM_RTL8188E:
+			halrf_rf_lna_setting_8188e(dm, type);
+			break;
+#endif
+#if (RTL8192E_SUPPORT == 1)
+		case ODM_RTL8192E:
+			halrf_rf_lna_setting_8192e(dm, type);
+			break;
+#endif
+#if (RTL8723B_SUPPORT == 1)
+		case ODM_RTL8723B:
+			halrf_rf_lna_setting_8723b(dm, type);
+			break;
+#endif
+#if (RTL8812A_SUPPORT == 1)
+		case ODM_RTL8812:
+			halrf_rf_lna_setting_8812a(dm, type);
+			break;
+#endif
+#if ((RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1))
+		case ODM_RTL8881A:
+		case ODM_RTL8821:
+			halrf_rf_lna_setting_8821a(dm, type);
+			break;
+#endif
+#if (RTL8822B_SUPPORT == 1)
+		case ODM_RTL8822B:
+			halrf_rf_lna_setting_8822b(dm, type);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
+		case ODM_RTL8821C:
+			halrf_rf_lna_setting_8821c(dm, type);
+			break;
+#endif
+		default:
+			break;
+		}
+
+	}
+
+
+void
+halrf_support_ability_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u32	dm_value[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8	i;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+		}
+	}
+	
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%s\n",
+		       "================================");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[RF Supportability]\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))Power Tracking\n",
+			       ((rf->rf_supportability & HAL_RF_TX_PWR_TRACK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "01. (( %s ))IQK\n",
+			       ((rf->rf_supportability & HAL_RF_IQK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "02. (( %s ))LCK\n",
+			       ((rf->rf_supportability & HAL_RF_LCK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "03. (( %s ))DPK\n",
+			       ((rf->rf_supportability & HAL_RF_DPK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "04. (( %s ))HAL_RF_TXGAPK\n",
+			       ((rf->rf_supportability & HAL_RF_TXGAPK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");		
+	}
+	else {
+		if (dm_value[1] == 1) { /* enable */
+			rf->rf_supportability |= BIT(dm_value[0]) ;
+		} else if (dm_value[1] == 2) /* disable */
+			rf->rf_supportability &= ~(BIT(dm_value[0])) ;
+		else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "%s\n",
+				       "[Warning!!!]  1:enable,  2:disable");
+		}
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Curr-RF_supportability =  0x%x\n",
+		       rf->rf_supportability);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%s\n",
+		       "================================");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+halrf_cmn_info_init(
+	void		*dm_void,
+enum halrf_cmninfo_init	cmn_info,
+	u32			value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	switch	(cmn_info) {
+	case	HALRF_CMNINFO_EEPROM_THERMAL_VALUE:
+		rf->eeprom_thermal = (u8)value;
+		break;
+	case	HALRF_CMNINFO_FW_VER:
+		rf->fw_ver = (u32)value;
+		break;
+	default:
+		break;
+	}
+}
+
+
+void
+halrf_cmn_info_hook(
+	void		*dm_void,
+enum halrf_cmninfo_hook cmn_info,
+	void		*value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	
+	switch	(cmn_info) {
+	case	HALRF_CMNINFO_CON_TX:
+		rf->is_con_tx = (boolean *)value;
+		break;
+	case	HALRF_CMNINFO_SINGLE_TONE:
+		rf->is_single_tone = (boolean *)value;		
+		break;
+	case	HALRF_CMNINFO_CARRIER_SUPPRESSION:
+		rf->is_carrier_suppresion = (boolean *)value;		
+		break;
+	case	HALRF_CMNINFO_MP_RATE_INDEX:
+		rf->mp_rate_index = (u8 *)value;
+		break;
+	default:
+		/*do nothing*/
+		break;
+	}
+}
+
+void
+halrf_cmn_info_set(
+	void		*dm_void,
+	u32			cmn_info,
+	u64			value
+)
+{
+	/*  */
+	/* This init variable may be changed in run time. */
+	/*  */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	
+	switch	(cmn_info) {
+		case	HALRF_CMNINFO_ABILITY:
+			rf->rf_supportability = (u32)value;
+			break;
+
+		case	HALRF_CMNINFO_DPK_EN:
+			rf->dpk_en = (u8)value;
+			break;
+		case HALRF_CMNINFO_RFK_FORBIDDEN :
+			dm->IQK_info.rfk_forbidden = (boolean)value;
+			break;
+		#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		case HALRF_CMNINFO_IQK_SEGMENT:
+			dm->IQK_info.segment_iqk = (boolean)value;
+			break;
+		#endif
+		case HALRF_CMNINFO_RATE_INDEX:
+			rf->p_rate_index = (u32)value;
+			break;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		case	HALRF_CMNINFO_MP_PSD_POINT:
+			rf->halrf_psd_data.point = (u32)value;
+			break;
+		case	HALRF_CMNINFO_MP_PSD_START_POINT:
+			rf->halrf_psd_data.start_point = (u32)value;
+			break;
+		case	HALRF_CMNINFO_MP_PSD_STOP_POINT:
+			rf->halrf_psd_data.stop_point = (u32)value;
+			break;
+		case	HALRF_CMNINFO_MP_PSD_AVERAGE:
+			rf->halrf_psd_data.average = (u32)value;
+			break;
+#endif
+		default:
+			/* do nothing */
+			break;
+	}
+}
+
+u64
+halrf_cmn_info_get(
+	void		*dm_void,
+	u32			cmn_info
+)
+{
+	/*  */
+	/* This init variable may be changed in run time. */
+	/*  */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64	return_value = 0;
+	
+	switch	(cmn_info) {
+		case	HALRF_CMNINFO_ABILITY:
+			return_value = (u32)rf->rf_supportability;
+			break;
+		case HALRF_CMNINFO_RFK_FORBIDDEN :
+			return_value = dm->IQK_info.rfk_forbidden;
+			break;
+		#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		case HALRF_CMNINFO_IQK_SEGMENT:
+			return_value = dm->IQK_info.segment_iqk;
+			break;
+		#endif
+		default:
+			/* do nothing */
+			break;
+	}
+
+	return	return_value;
+}
+
+void
+halrf_supportability_init_mp(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	switch (dm->support_ic_type) {
+	case ODM_RTL8814B:
+		#if (RTL8814B_SUPPORT == 1) 
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		#endif
+		break;
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			/*HAL_RF_TXGAPK			|*/
+			0;
+		break;
+	#endif
+
+	default:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			/*HAL_RF_TXGAPK			|*/
+			0;
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "IC = ((0x%x)), RF_Supportability Init MP = ((0x%x))\n", dm->support_ic_type, rf->rf_supportability);
+}
+
+void
+halrf_supportability_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+
+	switch (dm->support_ic_type) {
+	case ODM_RTL8814B:
+		#if (RTL8814B_SUPPORT == 1) 
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		#endif
+		break;
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/		
+			/*HAL_RF_TXGAPK				|*/
+			0;
+		break;
+	#endif
+
+	default:
+		rf->rf_supportability = 
+			HAL_RF_TX_PWR_TRACK	|
+			HAL_RF_IQK				|
+			HAL_RF_LCK				|
+			/*HAL_RF_DPK				|*/
+			0;
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "IC = ((0x%x)), RF_Supportability Init = ((0x%x))\n", dm->support_ic_type, rf->rf_supportability);
+}
+
+void
+halrf_watchdog(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	phydm_rf_watchdog(dm);
+}
+#if 0
+void
+halrf_iqk_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+
+	switch (dm->support_ic_type) {
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		break;
+	#endif
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		_iq_calibrate_8822b_init(dm);
+		break;
+	#endif
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		break;
+	#endif
+
+	default:
+		break;
+	}
+}
+#endif
+
+
+void
+halrf_iqk_trigger(
+	void			*dm_void,
+	boolean		is_recovery
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info		*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64 start_time;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if (odm_check_power_status(dm) == false)
+		return;
+#endif
+
+	if ((dm->mp_mode != NULL) && (rf->is_con_tx != NULL) && (rf->is_single_tone != NULL) && (rf->is_carrier_suppresion != NULL))
+		if (*dm->mp_mode && ((*rf->is_con_tx || *rf->is_single_tone || *rf->is_carrier_suppresion)))
+			return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (!(rf->rf_supportability & HAL_RF_IQK))
+		return;
+#endif
+
+#if DISABLE_BB_RF
+	return;
+#endif
+
+	if (iqk_info->rfk_forbidden)
+		return;
+
+	if (!dm->rf_calibrate_info.is_iqk_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		switch (dm->support_ic_type) {
+#if (RTL8188E_SUPPORT == 1) 
+		case ODM_RTL8188E:
+			phy_iq_calibrate_8188e(dm, is_recovery);
+			break;
+#endif
+#if (RTL8188F_SUPPORT == 1) 
+		case ODM_RTL8188F:
+			phy_iq_calibrate_8188f(dm, is_recovery);
+			break;
+#endif
+#if (RTL8192E_SUPPORT == 1) 
+		case ODM_RTL8192E:
+			phy_iq_calibrate_8192e(dm, is_recovery);
+			break;
+#endif
+#if (RTL8197F_SUPPORT == 1) 
+		case ODM_RTL8197F:
+			phy_iq_calibrate_8197f(dm, is_recovery);
+			break;
+#endif
+#if (RTL8703B_SUPPORT == 1) 
+		case ODM_RTL8703B:
+			phy_iq_calibrate_8703b(dm, is_recovery);
+			break;
+#endif
+#if (RTL8710B_SUPPORT == 1) 
+		case ODM_RTL8710B:
+			phy_iq_calibrate_8710b(dm, is_recovery);
+			break;
+#endif
+#if (RTL8723B_SUPPORT == 1) 
+		case ODM_RTL8723B:
+			phy_iq_calibrate_8723b(dm, is_recovery);
+			break;
+#endif
+#if (RTL8723D_SUPPORT == 1) 
+		case ODM_RTL8723D:
+			phy_iq_calibrate_8723d(dm, is_recovery);
+			break;
+#endif
+#if (RTL8812A_SUPPORT == 1) 
+		case ODM_RTL8812:
+			phy_iq_calibrate_8812a(dm, is_recovery);
+			break;
+#endif
+#if (RTL8821A_SUPPORT == 1) 
+		case ODM_RTL8821:
+			phy_iq_calibrate_8821a(dm, is_recovery);
+			break;
+#endif
+#if (RTL8814A_SUPPORT == 1) 
+		case ODM_RTL8814A:
+			phy_iq_calibrate_8814a(dm, is_recovery);
+			break;
+#endif
+#if (RTL8822B_SUPPORT == 1) 
+		case ODM_RTL8822B:
+			phy_iq_calibrate_8822b(dm, false, false);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1) 
+		case ODM_RTL8821C:
+			phy_iq_calibrate_8821c(dm, false, false);
+			break;
+#endif
+#if (RTL8814B_SUPPORT == 1) 
+		case ODM_RTL8814B:
+			break;
+#endif
+		default:
+			break;
+		}
+		dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(dm, start_time);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]IQK progressing_time = %lld ms\n", dm->rf_calibrate_info.iqk_progressing_time);
+
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "== Return the IQK CMD, because RFKs in Progress ==\n");
+}
+
+
+
+void
+halrf_lck_trigger(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info		*iqk_info = &dm->IQK_info;
+	struct _hal_rf_				*rf = &dm->rf_table;
+	u64 start_time;
+	
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if (odm_check_power_status(dm) == false)
+		return;
+#endif
+
+	if ((dm->mp_mode != NULL) && (rf->is_con_tx != NULL) && (rf->is_single_tone != NULL) && (rf->is_carrier_suppresion != NULL))
+		if (*dm->mp_mode && ((*rf->is_con_tx || *rf->is_single_tone || *rf->is_carrier_suppresion)))
+			return;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (!(rf->rf_supportability & HAL_RF_LCK))
+		return;
+#endif
+
+#if DISABLE_BB_RF
+		return;
+#endif
+	if (iqk_info->rfk_forbidden)
+		return;
+	while (*dm->is_scan_in_process) {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[LCK]scan is in process, bypass LCK\n");
+		return;
+	}
+
+	if (!dm->rf_calibrate_info.is_lck_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_lck_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		switch (dm->support_ic_type) {
+#if (RTL8188E_SUPPORT == 1)
+		case ODM_RTL8188E:
+			phy_lc_calibrate_8188e(dm);
+			break;
+#endif
+#if (RTL8188F_SUPPORT == 1)
+		case ODM_RTL8188F:
+			phy_lc_calibrate_8188f(dm);
+			break;
+#endif
+#if (RTL8192E_SUPPORT == 1)
+		case ODM_RTL8192E:
+			phy_lc_calibrate_8192e(dm);
+			break;
+#endif
+#if (RTL8197F_SUPPORT == 1)
+		case ODM_RTL8197F:
+			phy_lc_calibrate_8197f(dm);
+			break;
+#endif
+#if (RTL8703B_SUPPORT == 1)
+		case ODM_RTL8703B:
+			phy_lc_calibrate_8703b(dm);
+			break;
+#endif
+#if (RTL8710B_SUPPORT == 1)
+		case ODM_RTL8710B:
+			phy_lc_calibrate_8710b(dm);
+			break;
+#endif
+#if (RTL8723B_SUPPORT == 1) 
+		case ODM_RTL8723B:
+			phy_lc_calibrate_8723b(dm);
+			break;
+#endif
+#if (RTL8723D_SUPPORT == 1)
+		case ODM_RTL8723D:
+			phy_lc_calibrate_8723d(dm);
+			break;
+#endif
+#if (RTL8812A_SUPPORT == 1)
+		case ODM_RTL8812:
+			phy_lc_calibrate_8812a(dm);
+			break;
+#endif
+#if (RTL8821A_SUPPORT == 1) 
+		case ODM_RTL8821:
+			phy_lc_calibrate_8821a(dm);
+			break;
+#endif
+#if (RTL8814A_SUPPORT == 1) 
+		case ODM_RTL8814A:
+			phy_lc_calibrate_8814a(dm);
+			break;
+#endif
+#if (RTL8822B_SUPPORT == 1) 
+		case ODM_RTL8822B:
+			phy_lc_calibrate_8822b(dm);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1) 
+		case ODM_RTL8821C:
+			phy_lc_calibrate_8821c(dm);
+			break;
+#endif
+#if (RTL8814B_SUPPORT == 1) 
+		case ODM_RTL8814B:
+			break;
+#endif
+		default:
+			break;
+		}
+		dm->rf_calibrate_info.lck_progressing_time = odm_get_progressing_time(dm, start_time);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[IQK]LCK progressing_time = %lld ms\n", dm->rf_calibrate_info.lck_progressing_time);
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		halrf_lck_dbg(dm);
+#endif
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_lck_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);		
+	}else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "== Return the LCK CMD, because RFK is in Progress ==\n");
+}
+
+void
+halrf_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	PHYDM_DBG(dm, ODM_COMP_INIT, "HALRF_Init\n");
+
+	if (*dm->mp_mode == true)
+		halrf_supportability_init_mp(dm);
+	else
+		halrf_supportability_init(dm);
+
+	/*Init all RF funciton*/
+	/*iqk_init();*/
+	/*dpk_init();*/
+}
+
+
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf.h
new file mode 100644
index 000000000000..f9c57a922293
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf.h
@@ -0,0 +1,456 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	_HALRF_H__
+#define _HALRF_H__
+
+/*============================================================*/
+/*include files*/
+/*============================================================*/
+#include "halrf/halrf_psd.h"
+
+
+/*============================================================*/
+/*Definition */
+/*============================================================*/
+/*IQK version*/
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+#define IQK_VERSION_8188E	"0x14"
+#define IQK_VERSION_8192E	"0x01"
+#define IQK_VERSION_8723B	"0x1e"
+#define IQK_VERSION_8812A	"0x01"
+#define IQK_VERSION_8821A	"0x01"
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+#define IQK_VERSION_8188E	"0x01"
+#define IQK_VERSION_8192E	"0x01"
+#define IQK_VERSION_8723B	"0x1e"
+#define IQK_VERSION_8812A	"0x01"
+#define IQK_VERSION_8821A	"0x01"
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#define IQK_VERSION_8188E	"0x01"
+#define IQK_VERSION_8192E	"0x01"
+#define IQK_VERSION_8723B	"0x1e"
+#define IQK_VERSION_8812A	"0x01"
+#define IQK_VERSION_8821A	"0x01"
+#endif
+#define IQK_VERSION_8814A	"0x0f"
+#define IQK_VERSION_8188F	"0x01"
+#define IQK_VERSION_8197F	"0x01"
+#define IQK_VERSION_8703B	"0x05"
+#define IQK_VERSION_8710B	"0x01"
+#define IQK_VERSION_8723D	"0x02"
+#define IQK_VERSION_8822B	"0x2f"
+#define IQK_VERSION_8821C	"0x23"
+
+/*LCK version*/
+#define LCK_VERSION_8188E	"0x01"
+#define LCK_VERSION_8192E	"0x01"
+#define LCK_VERSION_8723B	"0x01"
+#define LCK_VERSION_8812A	"0x01"
+#define LCK_VERSION_8821A	"0x01"
+#define LCK_VERSION_8814A	"0x01"
+#define LCK_VERSION_8188F	"0x01"
+#define LCK_VERSION_8197F	"0x01"
+#define LCK_VERSION_8703B	"0x01"
+#define LCK_VERSION_8710B	"0x01"
+#define LCK_VERSION_8723D	"0x01"
+#define LCK_VERSION_8822B	"0x01"
+#define LCK_VERSION_8821C	"0x02"
+
+/*power tracking version*/
+#define POWERTRACKING_VERSION_8188E	"0x01"
+#define POWERTRACKING_VERSION_8192E	"0x01"
+#define POWERTRACKING_VERSION_8723B	"0x01"
+#define POWERTRACKING_VERSION_8812A	"0x01"
+#define POWERTRACKING_VERSION_8821A	"0x01"
+#define POWERTRACKING_VERSION_8814A	"0x01"
+#define POWERTRACKING_VERSION_8188F	"0x01"
+#define POWERTRACKING_VERSION_8197F	"0x01"
+#define POWERTRACKING_VERSION_8703B	"0x01"
+#define POWERTRACKING_VERSION_8710B	"0x01"
+#define POWERTRACKING_VERSION_8723D	"0x01"
+#define POWERTRACKING_VERSION_8822B	"0x01"
+#define POWERTRACKING_VERSION_8821C	"0x01"
+
+/*DPK tracking version*/
+#define DPK_VERSION_8188E	"NONE"
+#define DPK_VERSION_8192E	"NONE"
+#define DPK_VERSION_8723B	"NONE"
+#define DPK_VERSION_8812A	"NONE"
+#define DPK_VERSION_8821A	"NONE"
+#define DPK_VERSION_8814A	"NONE"
+#define DPK_VERSION_8188F	"NONE"
+#define DPK_VERSION_8197F	"NONE"
+#define DPK_VERSION_8703B	"NONE"
+#define DPK_VERSION_8710B	"NONE"
+#define DPK_VERSION_8723D	"NONE"
+#define DPK_VERSION_8822B	"NONE"
+#define DPK_VERSION_8821C	"NONE"
+
+/*Kfree tracking version*/
+#define KFREE_VERSION_8188E	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8192E	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8723B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8812A	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8821A	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8814A	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8188F	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8197F	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8703B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8710B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8723D	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8822B	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+#define KFREE_VERSION_8821C	(dm->power_trim_data.flag & KFREE_FLAG_ON)? "0x01" : "NONE"
+
+/*PA Bias Calibration version*/
+#define PABIASK_VERSION_8188E	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8192E	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8723B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8812A	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8821A	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8814A	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8188F	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8197F	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8703B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8710B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8723D	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8822B	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+#define PABIASK_VERSION_8821C	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON)? "0x01" : "NONE"
+
+
+
+#define HALRF_IQK_VER	(dm->support_ic_type == ODM_RTL8188E)? IQK_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? IQK_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? IQK_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? IQK_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? IQK_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? IQK_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? IQK_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? IQK_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? IQK_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? IQK_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? IQK_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? IQK_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? IQK_VERSION_8821C :"unknown"
+
+
+#define HALRF_LCK_VER	(dm->support_ic_type == ODM_RTL8188E)? LCK_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? LCK_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? LCK_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? LCK_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? LCK_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? LCK_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? LCK_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? LCK_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? LCK_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? LCK_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? LCK_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? LCK_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? LCK_VERSION_8821C :"unknown"
+
+
+#define HALRF_POWRTRACKING_VER	(dm->support_ic_type == ODM_RTL8188E)? POWERTRACKING_VERSION_8188E :\
+								(dm->support_ic_type == ODM_RTL8192E)? POWERTRACKING_VERSION_8192E :\
+								(dm->support_ic_type == ODM_RTL8723B)? POWERTRACKING_VERSION_8723B :\
+								(dm->support_ic_type == ODM_RTL8812)? POWERTRACKING_VERSION_8812A :\
+								(dm->support_ic_type == ODM_RTL8821)? POWERTRACKING_VERSION_8821A :\
+								(dm->support_ic_type == ODM_RTL8814A)? POWERTRACKING_VERSION_8814A :\
+								(dm->support_ic_type == ODM_RTL8188F)? POWERTRACKING_VERSION_8188F :\
+								(dm->support_ic_type == ODM_RTL8197F)? POWERTRACKING_VERSION_8197F :\
+								(dm->support_ic_type == ODM_RTL8703B)? POWERTRACKING_VERSION_8703B :\
+								(dm->support_ic_type == ODM_RTL8710B)? POWERTRACKING_VERSION_8710B :\
+								(dm->support_ic_type == ODM_RTL8723D)? POWERTRACKING_VERSION_8723D :\
+								(dm->support_ic_type == ODM_RTL8822B)? POWERTRACKING_VERSION_8822B :\
+								(dm->support_ic_type == ODM_RTL8821C)? POWERTRACKING_VERSION_8821C :"unknown"
+
+#define HALRF_DPK_VER	(dm->support_ic_type == ODM_RTL8188E)? DPK_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? DPK_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? DPK_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? DPK_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? DPK_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? DPK_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? DPK_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? DPK_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? DPK_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? DPK_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? DPK_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? DPK_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? DPK_VERSION_8821C :"unknown"
+
+#define HALRF_KFREE_VER (dm->support_ic_type == ODM_RTL8188E)? KFREE_VERSION_8188E :\
+						(dm->support_ic_type == ODM_RTL8192E)? KFREE_VERSION_8192E :\
+						(dm->support_ic_type == ODM_RTL8723B)? KFREE_VERSION_8723B :\
+						(dm->support_ic_type == ODM_RTL8812)? KFREE_VERSION_8812A :\
+						(dm->support_ic_type == ODM_RTL8821)? KFREE_VERSION_8821A :\
+						(dm->support_ic_type == ODM_RTL8814A)? KFREE_VERSION_8814A :\
+						(dm->support_ic_type == ODM_RTL8188F)? KFREE_VERSION_8188F :\
+						(dm->support_ic_type == ODM_RTL8197F)? KFREE_VERSION_8197F :\
+						(dm->support_ic_type == ODM_RTL8703B)? KFREE_VERSION_8703B :\
+						(dm->support_ic_type == ODM_RTL8710B)? KFREE_VERSION_8710B :\
+						(dm->support_ic_type == ODM_RTL8723D)? KFREE_VERSION_8723D :\
+						(dm->support_ic_type == ODM_RTL8822B)? KFREE_VERSION_8822B :\
+						(dm->support_ic_type == ODM_RTL8821C)? KFREE_VERSION_8821C :"unknown"
+
+#define HALRF_PABIASK_VER	(dm->support_ic_type == ODM_RTL8188E)? PABIASK_VERSION_8188E :\
+								(dm->support_ic_type == ODM_RTL8192E)? PABIASK_VERSION_8192E :\
+								(dm->support_ic_type == ODM_RTL8723B)? PABIASK_VERSION_8723B :\
+								(dm->support_ic_type == ODM_RTL8812)? PABIASK_VERSION_8812A :\
+								(dm->support_ic_type == ODM_RTL8821)? PABIASK_VERSION_8821A :\
+								(dm->support_ic_type == ODM_RTL8814A)? PABIASK_VERSION_8814A :\
+								(dm->support_ic_type == ODM_RTL8188F)? PABIASK_VERSION_8188F :\
+								(dm->support_ic_type == ODM_RTL8197F)? PABIASK_VERSION_8197F :\
+								(dm->support_ic_type == ODM_RTL8703B)? PABIASK_VERSION_8703B :\
+								(dm->support_ic_type == ODM_RTL8710B)? PABIASK_VERSION_8710B :\
+								(dm->support_ic_type == ODM_RTL8723D)? PABIASK_VERSION_8723D :\
+								(dm->support_ic_type == ODM_RTL8822B)? PABIASK_VERSION_8822B :\
+								(dm->support_ic_type == ODM_RTL8821C)? PABIASK_VERSION_8821C :"unknown"
+
+
+
+#define IQK_THRESHOLD			8
+#define DPK_THRESHOLD			4
+
+/*===========================================================*/
+/*AGC RX High Power mode*/
+/*===========================================================*/
+#define	lna_low_gain_1		0x64
+#define	lna_low_gain_2		0x5A
+#define	lna_low_gain_3		0x58
+
+/*============================================================*/
+/* enumeration */
+/*============================================================*/
+enum halrf_ability {
+	HAL_RF_TX_PWR_TRACK	= BIT(0),
+	HAL_RF_IQK				= BIT(1),
+	HAL_RF_LCK				= BIT(2),
+	HAL_RF_DPK				= BIT(3),
+	HAL_RF_TXGAPK			= BIT(4)
+};
+
+enum halrf_cmninfo_init {
+	HALRF_CMNINFO_ABILITY = 0,
+	HALRF_CMNINFO_DPK_EN = 1,
+	HALRF_CMNINFO_EEPROM_THERMAL_VALUE,
+	HALRF_CMNINFO_FW_VER,
+	HALRF_CMNINFO_RFK_FORBIDDEN,
+	HALRF_CMNINFO_IQK_SEGMENT,
+	HALRF_CMNINFO_RATE_INDEX,
+	HALRF_CMNINFO_MP_PSD_POINT,
+	HALRF_CMNINFO_MP_PSD_START_POINT,
+	HALRF_CMNINFO_MP_PSD_STOP_POINT,
+	HALRF_CMNINFO_MP_PSD_AVERAGE
+};
+
+enum halrf_cmninfo_hook {
+	HALRF_CMNINFO_CON_TX,
+	HALRF_CMNINFO_SINGLE_TONE,
+	HALRF_CMNINFO_CARRIER_SUPPRESSION,	
+	HALRF_CMNINFO_MP_RATE_INDEX
+};
+
+enum phydm_lna_set {
+	phydm_lna_disable		= 0,
+	phydm_lna_enable		= 1,
+};
+
+
+/*============================================================*/
+/* structure */
+/*============================================================*/
+
+struct _hal_rf_ {
+	/*hook*/
+	u8		*test1;
+
+	/*update*/
+	u32		rf_supportability;
+
+	u8		eeprom_thermal;
+	u8		dpk_en;			/*Enable Function DPK OFF/ON = 0/1*/
+	boolean	dpk_done;
+	u32		fw_ver;
+
+	boolean	*is_con_tx;
+	boolean	*is_single_tone;
+	boolean	*is_carrier_suppresion;
+
+	u8		*mp_rate_index;
+	u32		p_rate_index;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct	_halrf_psd_data	halrf_psd_data;
+#endif
+};
+
+/*============================================================*/
+/* function prototype */
+/*============================================================*/
+
+void halrf_basic_profile(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+);
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void halrf_iqk_info_dump(
+	void *dm_void,
+	u32 *_used,
+	char *output,
+	u32 *_out_len
+);
+
+void
+halrf_iqk_hwtx_check(
+	void *dm_void,
+	boolean		is_check
+);
+#endif
+
+u8
+halrf_match_iqk_version(
+	void	*dm_void
+);
+
+void
+halrf_support_ability_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+halrf_cmn_info_init(
+	void		*dm_void,
+	enum halrf_cmninfo_init	cmn_info,
+	u32		value
+);
+
+void
+halrf_cmn_info_hook(
+	void		*dm_void,
+	u32		cmn_info,
+	void		*value
+);
+
+void
+halrf_cmn_info_set(
+	void		*dm_void,
+	u32			cmn_info,
+	u64			value
+);
+
+u64
+halrf_cmn_info_get(
+	void		*dm_void,
+	u32			cmn_info
+);
+
+void
+halrf_watchdog(
+	void			*dm_void
+);
+
+void
+halrf_supportability_init(
+	void		*dm_void
+);
+
+void
+halrf_init(
+	void			*dm_void
+);
+
+void
+halrf_iqk_trigger(
+	void			*dm_void,
+	boolean		is_recovery
+);
+
+void
+halrf_segment_iqk_trigger(
+	void			*dm_void,
+	boolean		clear,
+	boolean		segment_iqk
+);
+
+void
+halrf_lck_trigger(
+	void			*dm_void
+);
+
+void
+halrf_iqk_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_get_iqk_cfir(
+	void		*dm_void,
+	u8 idx,
+	u8 path,
+	boolean debug
+);
+
+void 
+halrf_iqk_xym_read(
+	void *dm_void,
+	u8 path,
+	u8 xym_type
+ );
+
+void
+halrf_rf_lna_setting(
+	void	*dm_void,
+	enum phydm_lna_set type
+);
+
+
+void
+halrf_do_imr_test(
+	void	*dm_void,
+	u8 data
+);
+
+u32
+halrf_psd_log2base(
+	u32 val
+);
+
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+void halrf_iqk_dbg(void	*dm_void);
+#endif
+#endif
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_features.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_features.h
new file mode 100644
index 000000000000..df5700955af7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_features.h
@@ -0,0 +1,44 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__HALRF_FEATURES_H__
+#define __HALRF_FEATURES
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+	#define	CONFIG_HALRF_POWERTRACKING	1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	#define	CONFIG_HALRF_POWERTRACKING	1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+	#define	CONFIG_HALRF_POWERTRACKING	1
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_iqk.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_iqk.h
new file mode 100644
index 000000000000..6d5c1b8f0633
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_iqk.h
@@ -0,0 +1,86 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMIQK_H__
+#define __PHYDMIQK_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define	LOK_delay 1
+#define	WBIQK_delay 10
+#define	TX_IQK 0
+#define	RX_IQK 1
+#define	TXIQK 0
+#define	RXIQK1 1
+#define	RXIQK2 2
+#define kcount_limit_80m 2
+#define kcount_limit_others 4
+#define rxiqk_gs_limit 10
+
+#define	NUM 4
+/*---------------------------End Define Parameters-------------------------------*/
+
+struct dm_iqk_info {
+	boolean		lok_fail[NUM];
+	boolean		iqk_fail[2][NUM];
+	u32		iqc_matrix[2][NUM];
+	u8      iqk_times;
+	u32		rf_reg18;
+	u32		lna_idx;
+	u8		rxiqk_step;
+	u8		tmp1bcc;
+	u8		kcount;
+	u8		rfk_ing; /*bit0:IQKing, bit1:LCKing, bit2:DPKing*/
+	boolean rfk_forbidden;	
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	u32		iqk_channel[2];
+	boolean		iqk_fail_report[2][4][2]; /*channel/path/TRX(TX:0, RX:1) */
+	u32		iqk_cfir_real[3][4][2][8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_real*/ /*channel index = 2 is just for debug*/
+	u32		iqk_cfir_imag[3][4][2][8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_imag*/ /*channel index = 2 is just for debug*/
+	u8		retry_count[2][4][3]; /* channel / path / (TXK:0, RXK1:1, RXK2:2) */
+	u8		gs_retry_count[2][4][2]; /* channel / path / (GSRXK1:0, GSRXK2:1) */
+	u8		rxiqk_fail_code[2][4]; /* channel / path 0:SRXK1 fail, 1:RXK1 fail 2:RXK2 fail */
+	u32		lok_idac[2][4];		/*channel / path*/
+	u16		rxiqk_agc[2][4];	 /*channel / path*/
+	u32		bypass_iqk[2][4];	/*channel / 0xc94/0xe94*/
+	u32		txgap_result[8]; /*txagpK result  */
+	u32		tmp_gntwl;
+	boolean		is_btg;
+	boolean		isbnd;
+	boolean is_reload;
+	boolean segment_iqk;
+	boolean is_hwtx;
+	
+	boolean	xym_read;
+	boolean trximr_enable;
+	u32		rx_xym[2][10];
+	u32		tx_xym[2][10];
+	u32		gs1_xym[2][6];
+	u32		gs2_xym[2][6];
+	u32		rxk1_xym[2][6];
+#endif
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_kfree.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_kfree.c
new file mode 100644
index 000000000000..8735cc3554f5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_kfree.c
@@ -0,0 +1,884 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*============================================================*/
+/*include files*/
+/*============================================================*/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+/*<YuChen, 150720> Add for KFree Feature Requested by RF David.*/
+/*This is a phydm API*/
+
+void
+phydm_set_kfree_to_rf_8814a(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	boolean is_odd;
+
+	if ((data % 2) != 0) {	/*odd->positive*/
+		data = data - 1;
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(19), 1);
+		is_odd = true;
+	} else {		/*even->negative*/
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(19), 0);
+		is_odd = false;
+	}
+	PHYDM_DBG(dm, ODM_COMP_MP, "phy_ConfigKFree8814A(): RF_0x55[19]= %d\n", is_odd);
+	switch (data) {
+	case 0:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 0);
+		cali_info->kfree_offset[e_rf_path] = 0;
+		break;
+	case 2:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 0);
+		cali_info->kfree_offset[e_rf_path] = 0;
+		break;
+	case 4:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 1);
+		cali_info->kfree_offset[e_rf_path] = 1;
+		break;
+	case 6:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 1);
+		cali_info->kfree_offset[e_rf_path] = 1;
+		break;
+	case 8:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 2);
+		cali_info->kfree_offset[e_rf_path] = 2;
+		break;
+	case 10:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 2);
+		cali_info->kfree_offset[e_rf_path] = 2;
+		break;
+	case 12:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 3);
+		cali_info->kfree_offset[e_rf_path] = 3;
+		break;
+	case 14:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 3);
+		cali_info->kfree_offset[e_rf_path] = 3;
+		break;
+	case 16:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 4);
+		cali_info->kfree_offset[e_rf_path] = 4;
+		break;
+	case 18:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 4);
+		cali_info->kfree_offset[e_rf_path] = 4;
+		break;
+	case 20:
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 5);
+		cali_info->kfree_offset[e_rf_path] = 5;
+		break;
+
+	default:
+		break;
+	}
+
+	if (is_odd == false) {
+		/*that means Kfree offset is negative, we need to record it.*/
+		cali_info->kfree_offset[e_rf_path] = (-1) * cali_info->kfree_offset[e_rf_path];
+		PHYDM_DBG(dm, ODM_COMP_MP, "phy_ConfigKFree8814A(): kfree_offset = %d\n", cali_info->kfree_offset[e_rf_path]);
+	} else
+		PHYDM_DBG(dm, ODM_COMP_MP, "phy_ConfigKFree8814A(): kfree_offset = %d\n", cali_info->kfree_offset[e_rf_path]);
+
+}
+
+
+
+//
+//
+//
+void
+phydm_get_thermal_trim_offset_8821c(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_therm = 0xff;
+
+	odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_8821C, &pg_therm, false);
+
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
+
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c thermal trim flag:0x%02x\n", power_trim_info->flag);
+
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c thermal:%d\n", power_trim_info->thermal);
+}
+
+
+
+void
+phydm_get_power_trim_offset_8821c(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_power = 0xff, i;
+
+	odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET_8821C, &pg_power, false);
+
+	if (pg_power != 0xff) {
+		power_trim_info->bb_gain[0][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[1][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL2_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[2][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM1_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[3][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM2_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[4][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GH1_TXA_OFFSET_8821C, &pg_power, false);
+		power_trim_info->bb_gain[5][0] = pg_power;
+		power_trim_info->flag = power_trim_info->flag | KFREE_FLAG_ON | KFREE_FLAG_ON_2G | KFREE_FLAG_ON_5G;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c power trim flag:0x%02x\n", power_trim_info->flag);
+
+	if (power_trim_info->flag & KFREE_FLAG_ON) {
+		for (i = 0; i < KFREE_BAND_NUM; i++)
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8821c power_trim_data->bb_gain[%d][0]=0x%X\n", i, power_trim_info->bb_gain[i][0]);
+	}
+}
+
+
+
+void
+phydm_set_kfree_to_rf_8821c(
+	void		*dm_void,
+	u8		e_rf_path,
+	boolean		wlg_btg,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	u8	wlg, btg;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(5), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(6), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(6), 1);
+
+	if (wlg_btg == true) {
+		wlg = data & 0xf;
+		btg = (data & 0xf0) >> 4;
+
+		odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (wlg & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (wlg >> 1));
+
+		odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(19), (btg & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, 0x65, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (btg >> 1));
+	} else {
+		odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		odm_get_rf_reg(dm, e_rf_path, 0x65, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)))
+		);
+}
+
+
+
+void
+phydm_clear_kfree_to_rf_8821c(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(5), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(6), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(6), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (data >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x65, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (data >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(5), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(6), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, BIT(6), 0);
+
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		odm_get_rf_reg(dm, e_rf_path, 0x65, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)))
+		);
+}
+
+
+
+void
+phydm_get_thermal_trim_offset_8822b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_therm = 0xff;
+
+#if 0
+	u32	thermal_trim_enable = 0xff;
+
+	odm_efuse_logical_map_read(dm, 1, 0xc8, &thermal_trim_enable);
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 0xc8:0x%2x\n", thermal_trim_enable);
+
+	thermal_trim_enable = (thermal_trim_enable & BIT(5)) >> 5;
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b thermal trim Enable:%d\n", thermal_trim_enable);
+
+	if ((cali_info->reg_rf_kfree_enable == 0 && thermal_trim_enable == 1) ||
+		cali_info->reg_rf_kfree_enable == 1) {
+#endif
+
+		odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET, &pg_therm, false);
+
+		if (pg_therm != 0xff) {
+			pg_therm = pg_therm & 0x1f;
+			if ((pg_therm & BIT(0)) == 0)
+				power_trim_info->thermal = (-1 * (pg_therm >> 1));
+			else
+				power_trim_info->thermal = (pg_therm >> 1);
+
+			power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b thermal trim flag:0x%02x\n", power_trim_info->flag);
+
+		if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b thermal:%d\n", power_trim_info->thermal);
+#if 0
+	} else
+		return;
+#endif
+
+}
+
+
+
+void
+phydm_get_power_trim_offset_8822b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	u8 pg_power = 0xff, i, j;
+
+#if 0
+	u32	power_trim_enable = 0xff;
+
+	odm_efuse_logical_map_read(dm, 1, 0xc8, &power_trim_enable);
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 0xc8:0x%2x\n", power_trim_enable);
+
+	power_trim_enable = (power_trim_enable & BIT(4)) >> 4;
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b power trim Enable:%d\n", power_trim_enable);
+
+	if ((cali_info->reg_rf_kfree_enable == 0 && power_trim_enable == 1) ||
+		cali_info->reg_rf_kfree_enable == 1) {
+#endif
+
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
+
+		if (pg_power != 0xff) {
+			/*Path A*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
+
+			/*Path B*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[0][1] = ((pg_power & 0xf0) >> 4);
+
+			power_trim_info->flag |= KFREE_FLAG_ON_2G;
+			power_trim_info->flag |= KFREE_FLAG_ON;
+		}
+
+		odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXA_OFFSET, &pg_power, false);
+		
+		if (pg_power != 0xff) {
+			/*Path A*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[1][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL2_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[2][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM1_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[3][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM2_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[4][0] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GH1_TXA_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[5][0] = pg_power;
+
+			/*Path B*/
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL1_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[1][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GL2_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[2][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM1_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[3][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GM2_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[4][1] = pg_power;
+			odm_efuse_one_byte_read(dm, PPG_BB_GAIN_5GH1_TXB_OFFSET, &pg_power, false);
+			power_trim_info->bb_gain[5][1] = pg_power;
+			
+			power_trim_info->flag |= KFREE_FLAG_ON_5G;
+			power_trim_info->flag |= KFREE_FLAG_ON;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b power trim flag:0x%02x\n", power_trim_info->flag);
+
+		if (!(power_trim_info->flag & KFREE_FLAG_ON))
+			return;
+
+		for (i = 0; i < KFREE_BAND_NUM; i++) {
+			for (j = 0; j < 2; j++)
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b power_trim_data->bb_gain[%d][%d]=0x%X\n", i, j, power_trim_info->bb_gain[i][j]);
+		}
+#if 0
+	} else
+		return;
+#endif
+}
+
+
+
+void
+phydm_set_pa_bias_to_rf_8822b(
+	void		*dm_void,
+	u8		e_rf_path,
+	s8		tx_pa_bias
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	u32	rf_reg_51 = 0, rf_reg_52 = 0, rf_reg_3f = 0;
+
+	rf_reg_51 = odm_get_rf_reg(dm, e_rf_path, 0x51, RFREGOFFSETMASK);
+	rf_reg_52 = odm_get_rf_reg(dm, e_rf_path, 0x52, RFREGOFFSETMASK);
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 2g rf(0x51)=0x%X rf(0x52)=0x%X path=%d\n",
+ 		rf_reg_51, rf_reg_52, e_rf_path);
+
+	/*rf3f => rf52[19:17] = rf3f[2:0] rf52[16:15] = rf3f[4:3] rf52[3:0] = rf3f[8:5]*/
+	/*rf3f => rf51[6:3] = rf3f[12:9] rf52[13] = rf3f[13]*/
+	rf_reg_3f = ((rf_reg_52 & 0xe0000) >> 17) |
+					(((rf_reg_52 & 0x18000) >> 15) << 3) |
+					((rf_reg_52 & 0xf) << 5) |
+					(((rf_reg_51 & 0x78) >> 3) << 9) |
+					(((rf_reg_52 & 0x2000) >> 13) << 13);
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 2g original tx_pa_bias=%d rf_reg_3f=0x%X path=%d\n",
+			tx_pa_bias, rf_reg_3f, e_rf_path);
+
+	tx_pa_bias = (s8)((rf_reg_3f & (BIT(12) | BIT(11) | BIT(10) | BIT(9))) >> 9) + tx_pa_bias;
+
+	if (tx_pa_bias < 0)
+		tx_pa_bias = 0;
+	else if (tx_pa_bias > 7)
+		tx_pa_bias = 7;
+
+	rf_reg_3f = ((rf_reg_3f & 0xfe1ff) | (tx_pa_bias << 9));
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 2g offset efuse 0x3d5 0x3d6 tx_pa_bias=%d rf_reg_3f=0x%X path=%d\n",
+			tx_pa_bias, rf_reg_3f, e_rf_path);
+
+	odm_set_rf_reg(dm, e_rf_path, 0xef, BIT(10), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, RFREGOFFSETMASK, 0x0);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, BIT(0), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, BIT(1), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0x33, (BIT(1) | BIT(0)), 0x3);
+	odm_set_rf_reg(dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, 0xef, BIT(10), 0x0);
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 2g tx pa bias rf_0x3f(0x%X) path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x3f, (BIT(12) | BIT(11) | BIT(10) | BIT(9))), e_rf_path);
+}
+
+
+
+void
+phydm_get_pa_bias_offset_8822b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8 pg_pa_bias = 0xff, e_rf_path = 0;
+	s8 tx_pa_bias[2] = {0};
+
+	odm_efuse_one_byte_read(dm, PPG_PA_BIAS_2G_TXA_OFFSET, &pg_pa_bias, false);
+
+	if (pg_pa_bias != 0xff) {
+		/*paht a*/
+		odm_efuse_one_byte_read(dm, PPG_PA_BIAS_2G_TXA_OFFSET, &pg_pa_bias, false);
+		pg_pa_bias = pg_pa_bias & 0xf;
+		
+		if ((pg_pa_bias & BIT(0)) == 0)
+			tx_pa_bias[0] = (-1 * (pg_pa_bias >> 1));
+		else
+			tx_pa_bias[0] = (pg_pa_bias >> 1);
+
+		/*paht b*/
+		odm_efuse_one_byte_read(dm, PPG_PA_BIAS_2G_TXB_OFFSET, &pg_pa_bias, false);
+		pg_pa_bias = pg_pa_bias & 0xf;
+		
+		if ((pg_pa_bias & BIT(0)) == 0)
+			tx_pa_bias[1] = (-1 * (pg_pa_bias >> 1));
+		else
+			tx_pa_bias[1] = (pg_pa_bias >> 1);
+
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 2g tx_patha_pa_bias:%d   tx_pathb_pa_bias:%d\n", tx_pa_bias[0], tx_pa_bias[1]);
+
+		for (e_rf_path = RF_PATH_A;  e_rf_path < 2; e_rf_path++)
+			phydm_set_pa_bias_to_rf_8822b(dm, e_rf_path, tx_pa_bias[e_rf_path]);
+
+		power_trim_info->pa_bias_flag |= PA_BIAS_FLAG_ON;
+	}
+	else
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] 8822b 2g tx pa bias no pg\n");
+}
+
+
+
+void
+phydm_set_kfree_to_rf_8822b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(5), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		);
+}
+
+
+
+void
+phydm_clear_kfree_to_rf_8822b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(5), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(0), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(5), 0);
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(7), 0);
+
+	PHYDM_DBG(dm, ODM_COMP_MP,"[kfree] 8822b clear power trim 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		);
+}
+
+void
+phydm_get_thermal_trim_offset_8710b(
+void	*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &(dm->power_trim_data);
+
+	u8 pg_therm = 0xff;
+	
+	odm_efuse_one_byte_read(dm, 0x0EF, &pg_therm, false);
+	
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
+	
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
+	
+	ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b thermal trim flag:0x%02x\n", power_trim_info->flag));
+	
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b thermal:%d\n", power_trim_info->thermal));
+
+}
+
+void
+phydm_get_power_trim_offset_8710b(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &(dm->power_trim_data);
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	u8 pg_power = 0xff;
+
+	odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
+
+		if (pg_power != 0xff) {
+			/*Path A*/
+			odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
+			power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
+
+			power_trim_info->flag |= KFREE_FLAG_ON_2G;
+			power_trim_info->flag |= KFREE_FLAG_ON;
+		}
+
+
+		ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b power trim flag:0x%02x\n", power_trim_info->flag));
+
+		if (power_trim_info->flag & KFREE_FLAG_ON) 
+
+		ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8710b power_trim_data->bb_gain[0][0]=0x%X\n",  power_trim_info->bb_gain[0][0]));
+
+}
+void
+phydm_set_kfree_to_rf_8710b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15)), ((data & 0xf) >> 1));
+
+	ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD,
+		("[kfree] 8710b 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		));
+}
+
+void
+phydm_clear_kfree_to_rf_8710b(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	odm_set_rf_reg(dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+
+	ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD,
+		("[kfree] 8710b clear power trim 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		));
+}
+
+
+void
+phydm_set_kfree_to_rf(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phydm_set_kfree_to_rf_8814a(dm, e_rf_path, data);
+
+	if ((dm->support_ic_type & ODM_RTL8821C) && (*dm->band_type == ODM_BAND_2_4G))
+		phydm_set_kfree_to_rf_8821c(dm, e_rf_path, true, data);
+	else if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_set_kfree_to_rf_8821c(dm, e_rf_path, false, data);
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_set_kfree_to_rf_8822b(dm, e_rf_path, data);
+	if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_set_kfree_to_rf_8710b(dm, e_rf_path, data);
+}
+
+
+
+void
+phydm_clear_kfree_to_rf(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_clear_kfree_to_rf_8822b(dm, e_rf_path, 1);
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_clear_kfree_to_rf_8821c(dm, e_rf_path, 1);
+
+	if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_set_kfree_to_rf_8710b(dm, e_rf_path, data);
+}
+
+
+
+
+void
+phydm_get_thermal_trim_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL		pEfuseHal = &hal_data->EfuseHal;
+	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] dump efuse fail !!!\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_get_thermal_trim_offset_8821c(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_thermal_trim_offset_8822b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_get_thermal_trim_offset_8710b(dm_void);
+}
+
+
+
+void
+phydm_get_power_trim_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if 0 //(DM_ODM_SUPPORT_TYPE & ODM_WIN)	// 2017 MH DM Should use the same code.s
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL		pEfuseHal = &hal_data->EfuseHal;
+	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO(adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] dump efuse fail !!!\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_get_power_trim_offset_8821c(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_power_trim_offset_8822b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_get_power_trim_offset_8710b(dm_void);
+
+}
+
+
+
+void
+phydm_get_pa_bias_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL		pEfuseHal = &hal_data->EfuseHal;
+	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] dump efuse fail !!!\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_pa_bias_offset_8822b(dm_void);
+}
+
+
+
+s8
+phydm_get_thermal_offset(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		return power_trim_info->thermal;
+	else
+		return 0;
+}
+
+
+
+void
+phydm_config_kfree(
+	void	*dm_void,
+	u8	channel_to_sw
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	struct odm_power_trim_data	*power_trim_info = &dm->power_trim_data;
+
+	u8			rfpath = 0, max_rf_path = 0;
+	u8			channel_idx = 0, i, j;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		max_rf_path = 4;	/*0~3*/
+	else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E | ODM_RTL8822B))
+		max_rf_path = 2;	/*0~1*/
+	else if (dm->support_ic_type & (ODM_RTL8821C| ODM_RTL8710B))
+		max_rf_path = 1;
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "===>[kfree] phy_ConfigKFree()\n");
+
+	if (cali_info->reg_rf_kfree_enable == 2) {
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phy_ConfigKFree(): reg_rf_kfree_enable == 2, Disable\n");
+		return;
+	} else if (cali_info->reg_rf_kfree_enable == 1 || cali_info->reg_rf_kfree_enable == 0) {
+		PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phy_ConfigKFree(): reg_rf_kfree_enable == true\n");
+		/*Make sure the targetval is defined*/
+		if (!(power_trim_info->flag & KFREE_FLAG_ON)) {
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phy_ConfigKFree(): targetval not defined, Don't execute KFree Process.\n");
+			return;
+		}
+		/*if kfree_table[0] == 0xff, means no Kfree*/
+		if (dm->support_ic_type &ODM_RTL8710B)
+		  ODM_RT_TRACE(dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] power_trim_data->bb_gain[0][0]=0x%X\n", power_trim_info->bb_gain[0][0]));
+		else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E | ODM_RTL8822B |ODM_RTL8821C | ODM_RTL8814A)){
+		for (i = 0; i < KFREE_BAND_NUM; i++) {
+			for (j = 0; j < max_rf_path; j++)
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] power_trim_data->bb_gain[%d][%d]=0x%X\n", i, j, power_trim_info->bb_gain[i][j]);
+		}
+			}
+		if (*dm->band_type == ODM_BAND_2_4G && power_trim_info->flag & KFREE_FLAG_ON_2G) {
+			if (channel_to_sw >= 1 && channel_to_sw <= 14)
+				channel_idx = PHYDM_2G;
+
+			for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++) {
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phydm_kfree(): channel_to_sw=%d PATH_%d bb_gain:0x%X\n", channel_to_sw, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+				phydm_set_kfree_to_rf(dm, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+			}
+
+		} else if (*dm->band_type == ODM_BAND_5G && power_trim_info->flag & KFREE_FLAG_ON_5G) {
+			if (channel_to_sw >= 36 && channel_to_sw <= 48)
+				channel_idx = PHYDM_5GLB1;
+			if (channel_to_sw >= 52 && channel_to_sw <= 64)
+				channel_idx = PHYDM_5GLB2;
+			if (channel_to_sw >= 100 && channel_to_sw <= 120)
+				channel_idx = PHYDM_5GMB1;
+			if (channel_to_sw >= 122 && channel_to_sw <= 144)
+				channel_idx = PHYDM_5GMB2;
+			if (channel_to_sw >= 149 && channel_to_sw <= 177)
+				channel_idx = PHYDM_5GHB;
+
+			for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++) {
+				PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] phydm_kfree(): channel_to_sw=%d PATH_%d bb_gain:0x%X\n", channel_to_sw, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+				phydm_set_kfree_to_rf(dm, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+			}
+		} else {
+			PHYDM_DBG(dm, ODM_COMP_MP, "[kfree] Set default Register\n");
+			for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++)
+				phydm_clear_kfree_to_rf(dm, rfpath, power_trim_info->bb_gain[channel_idx][rfpath]);
+		}
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_MP, "<===[kfree] phy_ConfigKFree()\n");
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_kfree.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_kfree.h
new file mode 100644
index 000000000000..02e2e87381fb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_kfree.h
@@ -0,0 +1,143 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDMKFREE_H__
+#define    __PHYDKFREE_H__
+
+#define KFREE_VERSION	"1.0"
+
+#define	KFREE_BAND_NUM		6
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_AP))
+
+#define	BB_GAIN_NUM		6
+
+#endif
+
+#define KFREE_FLAG_ON				BIT(0)
+#define KFREE_FLAG_THERMAL_K_ON		BIT(1)
+
+#define KFREE_FLAG_ON_2G				BIT(2)
+#define KFREE_FLAG_ON_5G				BIT(3)
+
+#define PA_BIAS_FLAG_ON				BIT(4)
+
+#define PPG_THERMAL_OFFSET_8821C				0x1EF
+#define PPG_BB_GAIN_2G_TXAB_OFFSET_8821C		0x1EE
+#define PPG_BB_GAIN_5GL1_TXA_OFFSET_8821C		0x1EC
+#define PPG_BB_GAIN_5GL2_TXA_OFFSET_8821C		0x1E8
+#define PPG_BB_GAIN_5GM1_TXA_OFFSET_8821C		0x1E4
+#define PPG_BB_GAIN_5GM2_TXA_OFFSET_8821C		0x1E0
+#define PPG_BB_GAIN_5GH1_TXA_OFFSET_8821C		0x1DC
+
+
+
+#define PPG_THERMAL_OFFSET				0x3EF
+#define PPG_BB_GAIN_2G_TXAB_OFFSET		0x3EE
+#define PPG_BB_GAIN_2G_TXCD_OFFSET		0x3ED
+#define PPG_BB_GAIN_5GL1_TXA_OFFSET		0x3EC
+#define PPG_BB_GAIN_5GL1_TXB_OFFSET		0x3EB
+#define PPG_BB_GAIN_5GL1_TXC_OFFSET		0x3EA
+#define PPG_BB_GAIN_5GL1_TXD_OFFSET		0x3E9
+#define PPG_BB_GAIN_5GL2_TXA_OFFSET		0x3E8
+#define PPG_BB_GAIN_5GL2_TXB_OFFSET		0x3E7
+#define PPG_BB_GAIN_5GL2_TXC_OFFSET		0x3E6
+#define PPG_BB_GAIN_5GL2_TXD_OFFSET		0x3E5
+#define PPG_BB_GAIN_5GM1_TXA_OFFSET		0x3E4
+#define PPG_BB_GAIN_5GM1_TXB_OFFSET		0x3E3
+#define PPG_BB_GAIN_5GM1_TXC_OFFSET		0x3E2
+#define PPG_BB_GAIN_5GM1_TXD_OFFSET		0x3E1
+#define PPG_BB_GAIN_5GM2_TXA_OFFSET		0x3E0
+#define PPG_BB_GAIN_5GM2_TXB_OFFSET		0x3DF
+#define PPG_BB_GAIN_5GM2_TXC_OFFSET		0x3DE
+#define PPG_BB_GAIN_5GM2_TXD_OFFSET		0x3DD
+#define PPG_BB_GAIN_5GH1_TXA_OFFSET		0x3DC
+#define PPG_BB_GAIN_5GH1_TXB_OFFSET		0x3DB
+#define PPG_BB_GAIN_5GH1_TXC_OFFSET		0x3DA
+#define PPG_BB_GAIN_5GH1_TXD_OFFSET		0x3D9
+
+#define PPG_PA_BIAS_2G_TXA_OFFSET		0x3D5
+#define PPG_PA_BIAS_2G_TXB_OFFSET		0x3D6
+
+
+
+struct odm_power_trim_data {
+	u8 flag;
+	u8 pa_bias_flag;
+	s8 bb_gain[KFREE_BAND_NUM][MAX_RF_PATH];
+	s8 thermal;
+};
+
+
+
+enum phydm_kfree_channeltosw {
+	PHYDM_2G = 0,
+	PHYDM_5GLB1 = 1,
+	PHYDM_5GLB2 = 2,
+	PHYDM_5GMB1 = 3,
+	PHYDM_5GMB2 = 4,
+	PHYDM_5GHB = 5,
+};
+
+
+
+void
+phydm_get_thermal_trim_offset(
+	void	*dm_void
+);
+
+void
+phydm_get_power_trim_offset(
+	void	*dm_void
+);
+
+void
+phydm_get_pa_bias_offset(
+	void	*dm_void
+);
+
+s8
+phydm_get_thermal_offset(
+	void	*dm_void
+);
+
+void
+phydm_clear_kfree_to_rf(
+	void		*dm_void,
+	u8		e_rf_path,
+	u8		data
+);
+
+
+void
+phydm_config_kfree(
+	void	*dm_void,
+	u8	channel_to_sw
+);
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking.c
new file mode 100644
index 000000000000..49bfc7711ba3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking.c
@@ -0,0 +1,160 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+boolean
+odm_check_power_status(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	PADAPTER	adapter = (PADAPTER)dm->adapter;
+
+	RT_RF_POWER_STATE	rt_state;
+	MGNT_INFO	*mgnt_info	= &adapter->MgntInfo;
+
+	/* 2011/07/27 MH We are not testing ready~~!! We may fail to get correct value when init sequence. */
+	if (mgnt_info->init_adpt_in_progress == true) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "check_pow_status Return true, due to initadapter\n");
+		return	true;
+	}
+
+	/*  */
+	/*	2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK. */
+	/*  */
+	adapter->HalFunc.GetHwRegHandler(adapter, HW_VAR_RF_STATE, (u8 *)(&rt_state));
+	if (adapter->bDriverStopped || adapter->bDriverIsGoingToPnpSetPowerSleep || rt_state == eRfOff) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "check_pow_status Return false, due to %d/%d/%d\n",
+			adapter->bDriverStopped, adapter->bDriverIsGoingToPnpSetPowerSleep, rt_state);
+		return	false;
+	}
+#endif
+	return	true;
+	
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+halrf_update_pwr_track(
+	void		*dm_void,
+	u8		rate
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	u8			path_idx = 0;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Pwr Track Get rate=0x%x\n", rate);
+
+	dm->tx_rate = rate;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm->ra_rpt_workitem);
+#else
+	if (dm->support_ic_type == ODM_RTL8821) {
+#if (RTL8821A_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8812A; path_idx++) {
+#if (RTL8812A_SUPPORT == 1)
+			odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, path_idx, 0);
+#endif
+		}
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
+#if (RTL8723B_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8192E; path_idx++) {
+#if (RTL8192E_SUPPORT == 1)
+			odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, path_idx, 0);
+#endif
+		}
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	}
+#endif
+#else
+	odm_schedule_work_item(&dm->ra_rpt_workitem);
+#endif
+#endif
+
+}
+
+#endif
+
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+halrf_update_init_rate_work_item_callback(
+	void	*context
+)
+{
+	void	*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	u8		p = 0;
+
+	if (dm->support_ic_type == ODM_RTL8821) {
+		odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
+		/**/
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		for (p = RF_PATH_A; p < MAX_PATH_NUM_8812A; p++) {    /*DOn't know how to include &c*/
+
+			odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, p, 0);
+			/**/
+		}
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
+		odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
+		/**/
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		for (p = RF_PATH_A; p < MAX_PATH_NUM_8192E; p++) {   /*DOn't know how to include &c*/
+			odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, p, 0);
+			/**/
+		}
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+		odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
+		/**/
+	}
+}
+#endif
+
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking.h
new file mode 100644
index 000000000000..1c1b69be3299
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking.h
@@ -0,0 +1,51 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__HALRF_POWER_TRACKING_H__
+#define    __HALRF_POWER_TRACKING_H__
+
+
+boolean
+odm_check_power_status(
+	void		*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+halrf_update_pwr_track(
+	void		*dm_void,
+	u8		rate
+);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+halrf_update_init_rate_work_item_callback(
+	void	*context
+);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ap.c
new file mode 100644
index 000000000000..022798efd108
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ap.c
@@ -0,0 +1,1159 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if !defined(_OUTSRC_COEXIST)
+/* ************************************************************
+ * Global var
+ * ************************************************************ */
+
+
+u32 ofdm_swing_table_new[OFDM_TABLE_SIZE_92D] = {
+	0x0b40002d, /* 0,  -15.0dB */
+	0x0c000030, /* 1,  -14.5dB */
+	0x0cc00033, /* 2,  -14.0dB */
+	0x0d800036, /* 3,  -13.5dB */
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB */
+	0x10000040, /* 6,  -12.0dB */
+	0x11000044, /* 7,  -11.5dB */
+	0x12000048, /* 8,  -11.0dB */
+	0x1300004c, /* 9,  -10.5dB */
+	0x14400051, /* 10, -10.0dB */
+	0x15800056, /* 11, -9.5dB */
+	0x16c0005b, /* 12, -9.0dB */
+	0x18000060, /* 13, -8.5dB */
+	0x19800066, /* 14, -8.0dB */
+	0x1b00006c, /* 15, -7.5dB */
+	0x1c800072, /* 16, -7.0dB */
+	0x1e400079, /* 17, -6.5dB */
+	0x20000080, /* 18, -6.0dB */
+	0x22000088, /* 19, -5.5dB */
+	0x24000090, /* 20, -5.0dB */
+	0x26000098, /* 21, -4.5dB */
+	0x288000a2, /* 22, -4.0dB */
+	0x2ac000ab, /* 23, -3.5dB */
+	0x2d4000b5, /* 24, -3.0dB */
+	0x300000c0, /* 25, -2.5dB */
+	0x32c000cb, /* 26, -2.0dB */
+	0x35c000d7, /* 27, -1.5dB */
+	0x390000e4, /* 28, -1.0dB */
+	0x3c8000f2, /* 29, -0.5dB */
+	0x40000100, /* 30, +0dB */
+	0x43c0010f, /* 31, +0.5dB */
+	0x47c0011f, /* 32, +1.0dB */
+	0x4c000130, /* 33, +1.5dB */
+	0x50800142, /* 34, +2.0dB */
+	0x55400155, /* 35, +2.5dB */
+	0x5a400169, /* 36, +3.0dB */
+	0x5fc0017f, /* 37, +3.5dB */
+	0x65400195, /* 38, +4.0dB */
+	0x6b8001ae, /* 39, +4.5dB */
+	0x71c001c7, /* 40, +5.0dB */
+	0x788001e2, /* 41, +5.5dB */
+	0x7f8001fe  /* 42, +6.0dB */
+};
+
+u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/* 32, +0dB */
+};
+
+
+u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB */
+};
+
+u32 ofdm_swing_table[OFDM_TABLE_SIZE_92D] = {
+	0x0b40002d, /* 0,  -15.0dB */
+	0x0c000030, /* 1,  -14.5dB */
+	0x0cc00033, /* 2,  -14.0dB */
+	0x0d800036, /* 3,  -13.5dB */
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB */
+	0x10000040, /* 6,  -12.0dB */
+	0x11000044, /* 7,  -11.5dB */
+	0x12000048, /* 8,  -11.0dB */
+	0x1300004c, /* 9,  -10.5dB */
+	0x14400051, /* 10, -10.0dB */
+	0x15800056, /* 11, -9.5dB */
+	0x16c0005b, /* 12, -9.0dB */
+	0x18000060, /* 13, -8.5dB */
+	0x19800066, /* 14, -8.0dB */
+	0x1b00006c, /* 15, -7.5dB */
+	0x1c800072, /* 16, -7.0dB */
+	0x1e400079, /* 17, -6.5dB */
+	0x20000080, /* 18, -6.0dB */
+	0x22000088, /* 19, -5.5dB */
+	0x24000090, /* 20, -5.0dB */
+	0x26000098, /* 21, -4.5dB */
+	0x288000a2, /* 22, -4.0dB */
+	0x2ac000ab, /* 23, -3.5dB */
+	0x2d4000b5, /* 24, -3.0dB */
+	0x300000c0, /* 25, -2.5dB */
+	0x32c000cb, /* 26, -2.0dB */
+	0x35c000d7, /* 27, -1.5dB */
+	0x390000e4, /* 28, -1.0dB */
+	0x3c8000f2, /* 29, -0.5dB */
+	0x40000100, /* 30, +0dB */
+	0x43c0010f, /* 31, +0.5dB */
+	0x47c0011f, /* 32, +1.0dB */
+	0x4c000130, /* 33, +1.5dB */
+	0x50800142, /* 34, +2.0dB */
+	0x55400155, /* 35, +2.5dB */
+	0x5a400169, /* 36, +3.0dB */
+	0x5fc0017f, /* 37, +3.5dB */
+	0x65400195, /* 38, +4.0dB */
+	0x6b8001ae, /* 39, +4.5dB */
+	0x71c001c7, /* 40, +5.0dB */
+	0x788001e2, /* 41, +5.5dB */
+	0x7f8001fe  /* 42, +6.0dB */
+};
+
+
+u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/* 32, +0dB */
+};
+
+
+u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB */
+};
+
+u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x16, 0x15, 0x13, 0x10, 0xD, 0x9, 0x6, 0x3, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 0  -16dB */
+	{0x18, 0x17, 0x15, 0x12, 0xE, 0xA, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 1  -15.5dB */
+	{0x1B, 0x1A, 0x18, 0x14, 0x10, 0xB, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 2  -15dB */
+	{0x1F, 0x1E, 0x1B, 0x17, 0x12, 0xD, 0x8, 0x5, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 3  -14.5dB */
+	{0x22, 0x21, 0x1E, 0x19, 0x14, 0xE, 0x9, 0x5, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 4  -14dB */
+	{0x26, 0x25, 0x22, 0x1C, 0x16, 0x10, 0xA, 0x6, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 5  -13.5dB */
+	{0x2B, 0x2A, 0x26, 0x20, 0x19, 0x12, 0xC, 0x7, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 6  -13dB */
+	{0x30, 0x2F, 0x2A, 0x24, 0x1C, 0x14, 0xD, 0x8, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 7  -12.5dB */
+	{0x36, 0x34, 0x2F, 0x28, 0x1F, 0x17, 0xF, 0x9, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 8  -12dB */
+	{0x3D, 0x3B, 0x35, 0x2D, 0x23, 0x19, 0x11, 0xA, 0x5, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 9  -11.5dB */
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0xB, 0x5, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 10  -11dB */
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0xC, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 11  -10.5dB */
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0xE, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 12  -10dB */
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0xF, 0x7, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 13  -9.5dB */
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x8, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 14  -9dB */
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x9, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 15  -8.5dB */
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0xA, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 16  -8dB */
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0xB, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 17  -7.5dB */
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0xD, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 18  -7dB */
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0xE, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 19  -6.5dB */
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x5, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}      /* 20  -6dB */
+};
+
+
+u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x16, 0x15, 0x13, 0x10, 0xD, 0x9, 0x6, 0x3, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 0  -16dB */
+	{0x18, 0x17, 0x15, 0x12, 0xE, 0xA, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 1  -15.5dB */
+	{0x1B, 0x1A, 0x18, 0x14, 0x10, 0xB, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 2  -15dB */
+	{0x1F, 0x1E, 0x1B, 0x17, 0x12, 0xD, 0x8, 0x5, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 3  -14.5dB */
+	{0x22, 0x21, 0x1E, 0x19, 0x14, 0xE, 0x9, 0x5, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 4  -14dB */
+	{0x26, 0x25, 0x22, 0x1C, 0x16, 0x10, 0xA, 0x6, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 5  -13.5dB */
+	{0x2B, 0x2A, 0x26, 0x20, 0x19, 0x12, 0xC, 0x7, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 6  -13dB */
+	{0x30, 0x2F, 0x2A, 0x24, 0x1C, 0x14, 0xD, 0x8, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 7  -12.5dB */
+	{0x36, 0x34, 0x2F, 0x28, 0x1F, 0x17, 0xF, 0x9, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 8  -12dB */
+	{0x3D, 0x3B, 0x35, 0x2D, 0x23, 0x19, 0x11, 0xA, 0x5, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 9  -11.5dB */
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0xB, 0x5, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 10  -11dB */
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0xC, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 11  -10.5dB */
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0xE, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 12  -10dB */
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0xF, 0x7, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 13  -9.5dB */
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x8, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 14  -9dB */
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x9, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 15  -8.5dB */
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0xA, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 16  -8dB */
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0xB, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 17  -7.5dB */
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0xD, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 18  -7dB */
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0xE, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 19  -6.5dB */
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x5, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}      /* 20  -6dB */
+};
+
+
+u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+
+#if 0
+u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E] = {
+	/* Index0   6  dB */ 0x7fc001ff,
+	/* Index1   5.7dB */ 0x7b4001ed,
+	/* Index2   5.4dB */ 0x774001dd,
+	/* Index3   5.1dB */ 0x734001cd,
+	/* Index4   4.8dB */ 0x6f4001bd,
+	/* Index5   4.5dB */ 0x6b8001ae,
+	/* Index6   4.2dB */ 0x67c0019f,
+	/* Index7   3.9dB */ 0x64400191,
+	/* Index8   3.6dB */ 0x60c00183,
+	/* Index9   3.3dB */ 0x5d800176,
+	/* Index10  3  dB */ 0x5a80016a,
+	/* Index11  2.7dB */ 0x5740015d,
+	/* Index12  2.4dB */ 0x54400151,
+	/* Index13  2.1dB */ 0x51800146,
+	/* Index14  1.8dB */ 0x4ec0013b,
+	/* Index15  1.5dB */ 0x4c000130,
+	/* Index16  1.2dB */ 0x49800126,
+	/* Index17  0.9dB */ 0x4700011c,
+	/* Index18  0.6dB */ 0x44800112,
+	/* Index19  0.3dB */ 0x42000108,
+	/* Index20  0  dB */ 0x40000100, /* 20 This is OFDM base index */
+	/* Index21 -0.3dB */ 0x3dc000f7,
+	/* Index22 -0.6dB */ 0x3bc000ef,
+	/* Index23 -0.9dB */ 0x39c000e7,
+	/* Index24 -1.2dB */ 0x37c000df,
+	/* Index25 -1.5dB */ 0x35c000d7,
+	/* Index26 -1.8dB */ 0x340000d0,
+	/* Index27 -2.1dB */ 0x324000c9,
+	/* Index28 -2.4dB */ 0x308000c2,
+	/* Index29 -2.7dB */ 0x2f0000bc,
+	/* Index30 -3  dB */ 0x2d4000b5,
+	/* Index31 -3.3dB */ 0x2bc000af,
+	/* Index32 -3.6dB */ 0x2a4000a9,
+	/* Index33 -3.9dB */ 0x28c000a3,
+	/* Index34 -4.2dB */ 0x2780009e,
+	/* Index35 -4.5dB */ 0x26000098,
+	/* Index36 -4.8dB */ 0x24c00093,
+	/* Index37 -5.1dB */ 0x2380008e,
+	/* Index38 -5.4dB */ 0x22400089,
+	/* Index39 -5.7dB */ 0x21400085,
+	/* Index40 -6  dB */ 0x20000080,
+	/* Index41 -6.3dB */ 0x1f00007c,
+	/* Index42 -6.6dB */ 0x1e000078,
+	/* Index43 -6.9dB */ 0x1d000074,
+	/* Index44 -7.2dB */ 0x1c000070,
+	/* Index45 -7.5dB */ 0x1b00006c,
+	/* Index46 -7.8dB */ 0x1a000068,
+	/* Index47 -8.1dB */ 0x19400065,
+	/* Index48 -8.4dB */ 0x18400061,
+	/* Index49 -8.7dB */ 0x1780005e,
+	/* Index50 -9  dB */ 0x16c0005b,
+	/* Index51 -9.3dB */ 0x16000058,
+	/* Index52 -9.6dB */ 0x15400055,
+	/* Index53 -9.9dB */ 0x14800052
+};
+u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x1C, 0x12, 0x08, 0x04},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x1B, 0x11, 0x08, 0x04},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x1A, 0x11, 0x07, 0x04},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x19, 0x10, 0x07, 0x04},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x18, 0x10, 0x07, 0x03},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x18, 0x0F, 0x07, 0x03},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x17, 0x0F, 0x06, 0x03},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x16, 0x0E, 0x06, 0x03},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x15, 0x0E, 0x06, 0x03},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x14, 0x0D, 0x06, 0x03},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x14, 0x0D, 0x06, 0x03},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x13, 0x0C, 0x05, 0x03},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x12, 0x0C, 0x05, 0x03},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x12, 0x0B, 0x05, 0x03},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x10, 0x0A, 0x05, 0x02},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x10, 0x0A, 0x04, 0x02},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x0F, 0x0A, 0x04, 0x02},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x0E, 0x09, 0x04, 0x02},
+	/* Index20  -6.0dB */    {0x1B, 0x1A, 0x17, 0x13, 0x0E, 0x09, 0x04, 0x02}, /* 20 This is CCK base index */
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x0E, 0x09, 0x04, 0x02},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x0D, 0x08, 0x04, 0x02},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x0D, 0x08, 0x04, 0x02},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x0C, 0x08, 0x03, 0x02},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x0C, 0x08, 0x03, 0x02},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x0B, 0x07, 0x03, 0x02},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x0A, 0x07, 0x03, 0x01},
+	/* Index30  -9.0dB */    {0x13, 0x12, 0x10, 0x0D, 0x0A, 0x06, 0x03, 0x01}, /* 30 This is hp CCK base index */
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x0A, 0x06, 0x03, 0x01},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x09, 0x06, 0x03, 0x01},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x09, 0x06, 0x03, 0x01},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x09, 0x06, 0x02, 0x01},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x08, 0x05, 0x02, 0x01},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x06, 0x04, 0x02, 0x01},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x06, 0x04, 0x02, 0x01},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}
+};
+u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x00, 0x00, 0x00, 0x00},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x00, 0x00, 0x00, 0x00},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x00, 0x00, 0x00, 0x00},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x00, 0x00, 0x00, 0x00},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x00, 0x00, 0x00, 0x00},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x00, 0x00, 0x00, 0x00},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x00, 0x00, 0x00, 0x00},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x00, 0x00, 0x00, 0x00},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x00, 0x00, 0x00, 0x00},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x00, 0x00, 0x00, 0x00},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x00, 0x00, 0x00, 0x00},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x00, 0x00, 0x00, 0x00},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x00, 0x00, 0x00, 0x00},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x00, 0x00, 0x00, 0x00},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x00, 0x00, 0x00, 0x00},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x00, 0x00, 0x00, 0x00},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index20  -6  dB */     {0x1B, 0x1A, 0x17, 0x13, 0x00, 0x00, 0x00, 0x00},
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x00, 0x00, 0x00, 0x00},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index30  -9  dB */    {0x13, 0x12, 0x10, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x00, 0x00, 0x00, 0x00}
+};
+#endif
+#endif
+
+
+u8 delta_swing_table_idx_2ga_p_default[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3
+	, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9
+							      };
+u8 delta_swing_table_idx_2ga_n_default[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4
+	, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11
+							      };
+
+
+#ifdef CONFIG_WLAN_HAL_8192EE
+u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E] = {
+	/* Index0   6  dB */ 0x7fc001ff,
+	/* Index1   5.7dB */ 0x7b4001ed,
+	/* Index2   5.4dB */ 0x774001dd,
+	/* Index3   5.1dB */ 0x734001cd,
+	/* Index4   4.8dB */ 0x6f4001bd,
+	/* Index5   4.5dB */ 0x6b8001ae,
+	/* Index6   4.2dB */ 0x67c0019f,
+	/* Index7   3.9dB */ 0x64400191,
+	/* Index8   3.6dB */ 0x60c00183,
+	/* Index9   3.3dB */ 0x5d800176,
+	/* Index10  3  dB */ 0x5a80016a,
+	/* Index11  2.7dB */ 0x5740015d,
+	/* Index12  2.4dB */ 0x54400151,
+	/* Index13  2.1dB */ 0x51800146,
+	/* Index14  1.8dB */ 0x4ec0013b,
+	/* Index15  1.5dB */ 0x4c000130,
+	/* Index16  1.2dB */ 0x49800126,
+	/* Index17  0.9dB */ 0x4700011c,
+	/* Index18  0.6dB */ 0x44800112,
+	/* Index19  0.3dB */ 0x42000108,
+	/* Index20  0  dB */ 0x40000100, /* 20 This is OFDM base index */
+	/* Index21 -0.3dB */ 0x3dc000f7,
+	/* Index22 -0.6dB */ 0x3bc000ef,
+	/* Index23 -0.9dB */ 0x39c000e7,
+	/* Index24 -1.2dB */ 0x37c000df,
+	/* Index25 -1.5dB */ 0x35c000d7,
+	/* Index26 -1.8dB */ 0x340000d0,
+	/* Index27 -2.1dB */ 0x324000c9,
+	/* Index28 -2.4dB */ 0x308000c2,
+	/* Index29 -2.7dB */ 0x2f0000bc,
+	/* Index30 -3  dB */ 0x2d4000b5,
+	/* Index31 -3.3dB */ 0x2bc000af,
+	/* Index32 -3.6dB */ 0x2a4000a9,
+	/* Index33 -3.9dB */ 0x28c000a3,
+	/* Index34 -4.2dB */ 0x2780009e,
+	/* Index35 -4.5dB */ 0x26000098,
+	/* Index36 -4.8dB */ 0x24c00093,
+	/* Index37 -5.1dB */ 0x2380008e,
+	/* Index38 -5.4dB */ 0x22400089,
+	/* Index39 -5.7dB */ 0x21400085,
+	/* Index40 -6  dB */ 0x20000080,
+	/* Index41 -6.3dB */ 0x1f00007c,
+	/* Index42 -6.6dB */ 0x1e000078,
+	/* Index43 -6.9dB */ 0x1d000074,
+	/* Index44 -7.2dB */ 0x1c000070,
+	/* Index45 -7.5dB */ 0x1b00006c,
+	/* Index46 -7.8dB */ 0x1a000068,
+	/* Index47 -8.1dB */ 0x19400065,
+	/* Index48 -8.4dB */ 0x18400061,
+	/* Index49 -8.7dB */ 0x1780005e,
+	/* Index50 -9  dB */ 0x16c0005b,
+	/* Index51 -9.3dB */ 0x16000058,
+	/* Index52 -9.6dB */ 0x15400055,
+	/* Index53 -9.9dB */ 0x14800052
+};
+u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x1C, 0x12, 0x08, 0x04},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x1B, 0x11, 0x08, 0x04},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x1A, 0x11, 0x07, 0x04},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x19, 0x10, 0x07, 0x04},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x18, 0x10, 0x07, 0x03},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x18, 0x0F, 0x07, 0x03},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x17, 0x0F, 0x06, 0x03},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x16, 0x0E, 0x06, 0x03},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x15, 0x0E, 0x06, 0x03},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x14, 0x0D, 0x06, 0x03},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x14, 0x0D, 0x06, 0x03},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x13, 0x0C, 0x05, 0x03},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x12, 0x0C, 0x05, 0x03},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x12, 0x0B, 0x05, 0x03},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x11, 0x0B, 0x05, 0x02},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x10, 0x0A, 0x05, 0x02},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x10, 0x0A, 0x04, 0x02},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x0F, 0x0A, 0x04, 0x02},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x0E, 0x09, 0x04, 0x02},
+	/* Index20  -6.0dB */    {0x1B, 0x1A, 0x17, 0x13, 0x0E, 0x09, 0x04, 0x02}, /* 20 This is CCK base index */
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x0E, 0x09, 0x04, 0x02},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x0D, 0x08, 0x04, 0x02},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x0D, 0x08, 0x04, 0x02},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x0C, 0x08, 0x03, 0x02},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x0C, 0x08, 0x03, 0x02},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x0B, 0x07, 0x03, 0x02},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x0B, 0x07, 0x03, 0x02},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x0A, 0x07, 0x03, 0x01},
+	/* Index30  -9.0dB */    {0x13, 0x12, 0x10, 0x0D, 0x0A, 0x06, 0x03, 0x01}, /* 30 This is hp CCK base index */
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x0A, 0x06, 0x03, 0x01},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x09, 0x06, 0x03, 0x01},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x09, 0x06, 0x03, 0x01},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x09, 0x06, 0x02, 0x01},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x08, 0x05, 0x02, 0x01},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x08, 0x05, 0x02, 0x01},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x06, 0x04, 0x02, 0x01},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x06, 0x04, 0x02, 0x01},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}
+};
+u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8] = {
+	/* Index0    0  dB */    {0x36, 0x34, 0x2E, 0x26, 0x00, 0x00, 0x00, 0x00},
+	/* Index1   -0.3dB */    {0x34, 0x32, 0x2C, 0x25, 0x00, 0x00, 0x00, 0x00},
+	/* Index2   -0.6dB */    {0x32, 0x30, 0x2B, 0x23, 0x00, 0x00, 0x00, 0x00},
+	/* Index3   -0.9dB */    {0x31, 0x2F, 0x29, 0x22, 0x00, 0x00, 0x00, 0x00},
+	/* Index4   -1.2dB */    {0x2F, 0x2D, 0x28, 0x21, 0x00, 0x00, 0x00, 0x00},
+	/* Index5   -1.5dB */    {0x2D, 0x2C, 0x27, 0x20, 0x00, 0x00, 0x00, 0x00},
+	/* Index6   -1.8dB */    {0x2C, 0x2A, 0x25, 0x1F, 0x00, 0x00, 0x00, 0x00},
+	/* Index7   -2.1dB */    {0x2A, 0x29, 0x24, 0x1E, 0x00, 0x00, 0x00, 0x00},
+	/* Index8   -2.4dB */    {0x29, 0x27, 0x23, 0x1D, 0x00, 0x00, 0x00, 0x00},
+	/* Index9   -2.7dB */    {0x27, 0x26, 0x22, 0x1C, 0x00, 0x00, 0x00, 0x00},
+	/* Index10  -3  dB */    {0x26, 0x25, 0x20, 0x1B, 0x00, 0x00, 0x00, 0x00},
+	/* Index11  -3.3dB */    {0x25, 0x23, 0x1F, 0x1A, 0x00, 0x00, 0x00, 0x00},
+	/* Index12  -3.6dB */    {0x24, 0x22, 0x1E, 0x19, 0x00, 0x00, 0x00, 0x00},
+	/* Index13  -3.9dB */    {0x22, 0x21, 0x1D, 0x18, 0x00, 0x00, 0x00, 0x00},
+	/* Index14  -4.2dB */    {0x21, 0x20, 0x1C, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index15  -4.5dB */    {0x20, 0x1F, 0x1B, 0x17, 0x00, 0x00, 0x00, 0x00},
+	/* Index16  -4.8dB */    {0x1F, 0x1E, 0x1A, 0x16, 0x00, 0x00, 0x00, 0x00},
+	/* Index17  -5.1dB */    {0x1E, 0x1D, 0x1A, 0x15, 0x00, 0x00, 0x00, 0x00},
+	/* Index18  -5.4dB */    {0x1D, 0x1C, 0x19, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index19  -5.7dB */    {0x1C, 0x1B, 0x18, 0x14, 0x00, 0x00, 0x00, 0x00},
+	/* Index20  -6  dB */     {0x1B, 0x1A, 0x17, 0x13, 0x00, 0x00, 0x00, 0x00},
+	/* Index21  -6.3dB */    {0x1A, 0x19, 0x16, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index22  -6.6dB */    {0x19, 0x18, 0x15, 0x12, 0x00, 0x00, 0x00, 0x00},
+	/* Index23  -6.9dB */    {0x18, 0x17, 0x15, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index24  -7.2dB */    {0x18, 0x17, 0x14, 0x11, 0x00, 0x00, 0x00, 0x00},
+	/* Index25  -7.5dB */    {0x17, 0x16, 0x13, 0x10, 0x00, 0x00, 0x00, 0x00},
+	/* Index26  -7.8dB */    {0x16, 0x15, 0x13, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index27  -8.1dB */    {0x15, 0x14, 0x12, 0x0F, 0x00, 0x00, 0x00, 0x00},
+	/* Index28  -8.4dB */    {0x14, 0x14, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index29  -8.7dB */    {0x14, 0x13, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
+	/* Index30  -9  dB */    {0x13, 0x12, 0x10, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index31  -9.3dB */    {0x12, 0x12, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index32  -9.6dB */    {0x12, 0x11, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
+	/* Index33  -9.9dB */    {0x11, 0x11, 0x0F, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index34 -10.2dB */    {0x11, 0x11, 0x0E, 0x0C, 0x00, 0x00, 0x00, 0x00},
+	/* Index35 -10.5dB */    {0x10, 0x0F, 0x0E, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index36 -10.8dB */    {0x10, 0x0F, 0x0D, 0x0B, 0x00, 0x00, 0x00, 0x00},
+	/* Index37 -11.1dB */    {0x0F, 0x0E, 0x0D, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index38 -11.4dB */    {0x0E, 0x0E, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index39 -11.7dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index40 -12  dB */    {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
+	/* Index41 -12.3dB */    {0x0D, 0x0D, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index42 -12.6dB */    {0x0D, 0x0C, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index43 -12.9dB */    {0x0C, 0x0C, 0x0A, 0x09, 0x00, 0x00, 0x00, 0x00},
+	/* Index44 -13.2dB */    {0x0C, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index45 -13.5dB */    {0x0B, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index46 -13.8dB */    {0x0B, 0x0B, 0x09, 0x08, 0x00, 0x00, 0x00, 0x00},
+	/* Index47 -14.1dB */    {0x0B, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index48 -14.4dB */    {0x0A, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index49 -14.7dB */    {0x0A, 0x0A, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index50 -15  dB */    {0x0A, 0x09, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
+	/* Index51 -15.3dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index52 -15.6dB */    {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
+	/* Index53 -15.9dB */    {0x09, 0x08, 0x07, 0x06, 0x00, 0x00, 0x00, 0x00}
+};
+#endif
+
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
+	0x081, /* 0,  -12.0dB */
+	0x088, /* 1,  -11.5dB */
+	0x090, /* 2,  -11.0dB */
+	0x099, /* 3,  -10.5dB */
+	0x0A2, /* 4,  -10.0dB */
+	0x0AC, /* 5,  -9.5dB */
+	0x0B6, /* 6,  -9.0dB */
+	0x0C0, /* 7,  -8.5dB */
+	0x0CC, /* 8,  -8.0dB */
+	0x0D8, /* 9,  -7.5dB */
+	0x0E5, /* 10, -7.0dB */
+	0x0F2, /* 11, -6.5dB */
+	0x101, /* 12, -6.0dB */
+	0x110, /* 13, -5.5dB */
+	0x120, /* 14, -5.0dB */
+	0x131, /* 15, -4.5dB */
+	0x143, /* 16, -4.0dB */
+	0x156, /* 17, -3.5dB */
+	0x16A, /* 18, -3.0dB */
+	0x180, /* 19, -2.5dB */
+	0x197, /* 20, -2.0dB */
+	0x1AF, /* 21, -1.5dB */
+	0x1C8, /* 22, -1.0dB */
+	0x1E3, /* 23, -0.5dB */
+	0x200, /* 24, +0  dB */
+	0x21E, /* 25, +0.5dB */
+	0x23E, /* 26, +1.0dB */
+	0x261, /* 27, +1.5dB */
+	0x285, /* 28, +2.0dB */
+	0x2AB, /* 29, +2.5dB */
+	0x2D3, /* 30, +3.0dB */
+	0x2FE, /* 31, +3.5dB */
+	0x32B, /* 32, +4.0dB */
+	0x35C, /* 33, +4.5dB */
+	0x38E, /* 34, +5.0dB */
+	0x3C4, /* 35, +5.5dB */
+	0x3FE  /* 36, +6.0dB */
+};
+#elif(ODM_IC_11AC_SERIES_SUPPORT)
+u32 ofdm_swing_table_8812[OFDM_TABLE_SIZE_8812] = {
+	0x3FE, /* 0,  (6dB) */
+	0x3C4, /* 1,  (5.5dB) */
+	0x38E, /* 2,  (5dB) */
+	0x35C, /* 3,  (4.5dB) */
+	0x32B, /* 4,  (4dB) */
+	0x2FE, /* 5,  (3.5dB) */
+	0x2D3, /* 6,  (3dB) */
+	0x2AB, /* 7,  (2.5dB) */
+	0x285, /* 8,  (2dB) */
+	0x261, /* 9,  (1.5dB */
+	0x23E, /* 10, (1dB) */
+	0x21E, /* 11, (0.5dB) */
+	0x200, /* 12, (0dB)		8814 int PA 2G default */
+	0x1E3, /* 13, (-0.5dB) */
+	0x1C8, /* 14, (-1dB) */
+	0x1AF, /* 15, (-1.5dB) */
+	0x197, /* 16, (-2dB) */
+	0x180, /* 17, (-2.5dB) */
+	0x16A, /* 18, (-3dB)		8812 / 8814 int PA 5G / 8814 ext PA 2G5G default */
+	0x156, /* 19, (-3.5dB) */
+	0x143, /* 20, (-4dB)		8812 HP default */
+	0x131, /* 21, (-4.5dB) */
+	0x120, /* 22, (-5dB) */
+	0x110, /* 23, (-5.5dB) */
+	0x101, /* 24, (-6dB) */
+	0x0F2, /* 25, (-6.5dB) */
+	0x0E5, /* 26, (-7dB) */
+	0x0D8, /* 27, (-7.5dB) */
+	0x0CC, /* 28, (-8dB) */
+	0x0C0, /* 29, (-8.5dB) */
+	0x0B6, /* 30, (-9dB) */
+	0x0AC, /* 31, (-9.5dB) */
+	0x0A2, /* 32, (-10dB) */
+	0x099, /* 33, (-10.5dB) */
+	0x090, /* 34, (-11dB) */
+	0x088, /* 35, (-11.5dB) */
+	0x081, /* 36, (-12dB) */
+	0x079, /* 37, (-12.5dB) */
+	0x072, /* 38, (-13dB) */
+	0x06c, /* 39, (-13.5dB) */
+	0x066, /* 40, (-14dB) */
+	0x060, /* 41, (-14.5dB) */
+	0x05B  /* 42, (-15dB) */
+};
+#endif
+
+u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
+	0x0CD,
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+/* JJ ADD 20161014 */
+u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
+	0x0CD,
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+
+/* #endif */
+/* 3============================================================
+ * 3 Tx Power Tracking
+ * 3============================================================ */
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_IC_11N_SERIES)))
+		return;
+#endif
+
+	odm_txpowertracking_thermal_meter_init(dm);
+}
+
+
+u8
+get_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			i = 0, bb_swing_mask = 0;
+	u32			bb_swing = 0;
+	u32			swing_table_size = 0;
+	u32			*swing_table = 0;
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+#if (RTL8197F_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8197F) {
+		bb_swing = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
+		swing_table = ofdm_swing_table_new;
+		swing_table_size = OFDM_TABLE_SIZE_92D;
+		bb_swing_mask = 22;
+	}
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8822B) {
+		bb_swing = phy_query_bb_reg(priv, REG_A_TX_SCALE_JAGUAR, 0xFFE00000);
+		swing_table = tx_scaling_table_jaguar;
+		swing_table_size = TXSCALE_TABLE_SIZE;
+		bb_swing_mask = 0;
+	}
+#endif
+
+	for (i = 0; i < swing_table_size - 1; i++) {
+		u32 table_value = swing_table[i] >> bb_swing_mask;
+
+		if (bb_swing == table_value)
+			break;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "bb_swing=0x%x bbswing_index=%d\n", bb_swing, i);
+
+
+	return i;
+}
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct rtl8192cd_priv		*priv = dm->priv;
+	u8 p;
+	u8 default_swing_index;
+#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	if ((GET_CHIP_VER(priv) == VERSION_8197F) || (GET_CHIP_VER(priv) == VERSION_8822B))
+		default_swing_index = get_swing_index(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	PMGNT_INFO	mgnt_info = &adapter->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	mgnt_info->is_txpowertracking = true;
+	hal_data->tx_powercount       = 0;
+	hal_data->is_txpowertracking_init = false;
+
+	if (*(dm->mp_mode) == false)
+		hal_data->txpowertrack_control = true;
+	PHYDM_DBG(dm, COMP_POWER_TRACKING, "mgnt_info->is_txpowertracking = %d\n", mgnt_info->is_txpowertracking);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#ifdef CONFIG_RTL8188E
+	{
+		dm->rf_calibrate_info.is_txpowertracking = true;
+		dm->rf_calibrate_info.tx_powercount = 0;
+		dm->rf_calibrate_info.is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)
+			dm->rf_calibrate_info.txpowertrack_control = true;
+
+		MSG_8192C("dm txpowertrack_control = %d\n", dm->rf_calibrate_info.txpowertrack_control);
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+		struct dm_priv	*pdmpriv = &hal_data->dmpriv;
+		
+		pdmpriv->is_txpowertracking = true;
+		pdmpriv->tx_powercount = 0;
+		pdmpriv->is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)		/* for mp driver, turn off txpwrtracking as default */
+			pdmpriv->txpowertrack_control = true;
+
+		MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
+
+	}
+#endif/* endif (CONFIG_RTL8188E==1) */
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#ifdef RTL8188E_SUPPORT
+	{
+		dm->rf_calibrate_info.is_txpowertracking = true;
+		dm->rf_calibrate_info.tx_powercount = 0;
+		dm->rf_calibrate_info.is_txpowertracking_init = false;
+		dm->rf_calibrate_info.txpowertrack_control = true;
+		dm->rf_calibrate_info.tm_trigger = 0;
+	}
+#endif
+#endif
+
+	dm->rf_calibrate_info.txpowertrack_control = true;
+	dm->rf_calibrate_info.delta_power_index = 0;
+	dm->rf_calibrate_info.delta_power_index_last = 0;
+	dm->rf_calibrate_info.power_index_offset = 0;
+	dm->rf_calibrate_info.thermal_value = 0;
+	cali_info->default_ofdm_index = 28;
+
+#if (RTL8197F_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8197F) {
+		cali_info->default_ofdm_index = (default_swing_index >= (OFDM_TABLE_SIZE_92D - 1)) ? 30 : default_swing_index;
+		cali_info->default_cck_index = 28;
+	}
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8822B) {
+		cali_info->default_ofdm_index = (default_swing_index >= (TXSCALE_TABLE_SIZE - 1)) ? 24 : default_swing_index;
+		cali_info->default_cck_index = 20;
+	}
+#endif
+
+
+#if RTL8188E_SUPPORT
+	cali_info->default_cck_index = 20;	/* -6 dB */
+#elif RTL8192E_SUPPORT
+	cali_info->default_cck_index = 8;	/* -12 dB */
+#endif
+	cali_info->bb_swing_idx_ofdm_base = cali_info->default_ofdm_index;
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	dm->rf_calibrate_info.CCK_index = cali_info->default_cck_index;
+
+	for (p = 0; p < MAX_RF_PATH; p++) {
+		dm->rf_calibrate_info.OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->kfree_offset[p] = 0;	/* for 8814 kfree*/
+	}
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "cali_info->default_ofdm_index=%d cali_info->default_cck_index=%d\n", cali_info->default_ofdm_index, cali_info->default_cck_index);
+
+	cali_info->tm_trigger = 0;
+}
+
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+)
+{
+	/*  */
+	/* For AP/ADSL use struct rtl8192cd_priv* */
+	/* For CE/NIC use struct void* */
+	/*  */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	/*  */
+	/* 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. */
+	/*  */
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_txpowertracking_check_mp(dm);
+		break;
+
+	case	ODM_CE:
+		odm_txpowertracking_check_ce(dm);
+		break;
+
+	case	ODM_AP:
+		odm_txpowertracking_check_ap(dm);
+		break;
+	}
+
+}
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+
+#if (RTL8188E_SUPPORT == 1)
+
+	/* if(!mgnt_info->is_txpowertracking || (!pdmpriv->txpowertrack_control && pdmpriv->is_ap_kdone)) */
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	if (!dm->rf_calibrate_info.tm_trigger) {	/* at least delay 1 sec */
+		/* hal_data->TxPowerCheckCnt++;	 */ /* cosa add for debug */
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+		/* DBG_8192C("Trigger 92C Thermal Meter!!\n"); */
+
+		dm->rf_calibrate_info.tm_trigger = 1;
+		return;
+
+	} else {
+		/* DBG_8192C("Schedule TxPowerTracking direct call!!\n"); */
+		odm_txpowertracking_callback_thermal_meter_8188e(adapter);
+		dm->rf_calibrate_info.tm_trigger = 0;
+	}
+#endif
+
+#endif
+}
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+
+	if (odm_check_power_status(adapter) == false)
+		return;
+
+	if (!adapter->is_slave_of_dmsp || adapter->dual_mac_smart_concurrent == false)
+		odm_txpowertracking_thermal_meter_check(adapter);
+#endif
+
+}
+
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct rtl8192cd_priv	*priv		= dm->priv;
+
+#if ((RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8881A | ODM_RTL8814A | ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8821C))
+		odm_txpowertracking_callback_thermal_meter(dm);
+	else
+#endif
+	{
+	}
+#endif
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ap.h
new file mode 100644
index 000000000000..983d7ea19379
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ap.h
@@ -0,0 +1,346 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDMPOWERTRACKING_H__
+#define    __PHYDMPOWERTRACKING_H__
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#ifdef RTK_AC_SUPPORT
+		#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#else
+		#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#endif
+#else
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+#endif
+
+#define		DPK_DELTA_MAPPING_NUM	13
+#define		index_mapping_HP_NUM	15
+#define		DELTA_SWINGIDX_SIZE     30
+#define		DELTA_SWINTSSI_SIZE     61
+#define		BAND_NUM				3
+#define		MAX_RF_PATH	4
+#define		TXSCALE_TABLE_SIZE		37
+#define		CCK_TABLE_SIZE_8723D		41
+/* JJ ADD 20161014 */
+#define		CCK_TABLE_SIZE_8710B		41
+
+#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 AVG_THERMAL_NUM		8
+#define iqk_matrix_reg_num	8
+/* #define IQK_MATRIX_SETTINGS_NUM	1+24+21 */
+#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+
+#if !defined(_OUTSRC_COEXIST)
+	#define	OFDM_TABLE_SIZE_92D	43
+	#define	OFDM_TABLE_SIZE	37
+	#define	CCK_TABLE_SIZE		33
+	#define	CCK_TABLE_SIZE_88F	21
+
+
+
+	/* #define	OFDM_TABLE_SIZE_92E	54 */
+	/* #define	CCK_TABLE_SIZE_92E	54 */
+	extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE_92D];
+	extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+	extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+
+	extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE_92D];
+	extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+	extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+	extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+	extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+	extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+
+#endif
+
+#define	ODM_OFDM_TABLE_SIZE	37
+#define	ODM_CCK_TABLE_SIZE		33
+/* <20140613, YuChen> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+extern u8 delta_swing_table_idx_2ga_p_default[DELTA_SWINGIDX_SIZE];
+extern u8 delta_swing_table_idx_2ga_n_default[DELTA_SWINGIDX_SIZE];
+
+static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+
+/* extern	u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E];
+ * extern	u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8];
+ * extern	u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8]; */
+
+#ifdef CONFIG_WLAN_HAL_8192EE
+	#define	OFDM_TABLE_SIZE_92E	54
+	#define	CCK_TABLE_SIZE_92E	54
+	extern	u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E];
+	extern	u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8];
+	extern	u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8];
+#endif
+
+#define	OFDM_TABLE_SIZE_8812	43
+#define	AVG_THERMAL_NUM_8812	4
+
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+	#elif(ODM_IC_11AC_SERIES_SUPPORT)
+	extern unsigned int ofdm_swing_table_8812[OFDM_TABLE_SIZE_8812];
+#endif
+
+extern u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/* JJ ADD 20161014 */
+extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+
+#define dm_check_txpowertracking	odm_txpowertracking_check
+
+struct iqk_matrix_regs_setting {
+	boolean	is_iqk_done;
+	s32		value[1][iqk_matrix_reg_num];
+};
+
+struct dm_rf_calibration_struct {
+	/* for tx power tracking */
+
+	u32	rega24; /* for TempCCK */
+	s32	rege94;
+	s32	rege9c;
+	s32	regeb4;
+	s32	regebc;
+
+	/* u8 is_txpowertracking; */
+	u8	tx_powercount;
+	boolean is_txpowertracking_init;
+	boolean is_txpowertracking;
+	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
+	u8	tm_trigger;
+	u8  	internal_pa_5g[2];	/* pathA / pathB */
+
+	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8	thermal_value;
+	u8	thermal_value_lck;
+	u8	thermal_value_iqk;
+	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8	thermal_value_dpk;
+	u8	thermal_value_avg[AVG_THERMAL_NUM];
+	u8	thermal_value_avg_index;
+	u8	thermal_value_rx_gain;
+	u8	thermal_value_crystal;
+	u8	thermal_value_dpk_store;
+	u8	thermal_value_dpk_track;
+	boolean	txpowertracking_in_progress;
+	boolean	is_dpk_enable;
+
+	boolean	is_reloadtxpowerindex;
+	u8	is_rf_pi_enable;
+	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
+
+	u8	is_cck_in_ch14;
+	u8	CCK_index;
+	u8	OFDM_index[MAX_RF_PATH];
+	s8	power_index_offset;
+	s8	delta_power_index;
+	s8	delta_power_index_last;
+	boolean is_tx_power_changed;
+
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8	delta_lck;
+	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8			bb_swing_idx_ofdm_current;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+#else
+	u8			bb_swing_idx_ofdm_base;
+#endif
+	boolean			bb_swing_flag_ofdm;
+	u8			bb_swing_idx_cck;
+	u8			bb_swing_idx_cck_current;
+	u8			bb_swing_idx_cck_base;
+	u8			default_ofdm_index;
+	u8			default_cck_index;
+	boolean			bb_swing_flag_cck;
+
+	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8			absolute_cck_swing_idx[MAX_RF_PATH];
+	s8			remnant_cck_swing_idx;
+	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
+	boolean			modify_tx_agc_flag_path_a;
+	boolean			modify_tx_agc_flag_path_b;
+	boolean			modify_tx_agc_flag_path_c;
+	boolean			modify_tx_agc_flag_path_d;
+	boolean			modify_tx_agc_flag_path_a_cck;
+
+	s8			kfree_offset[MAX_RF_PATH];
+
+	/* -------------------------------------------------------------------- */
+
+	/* for IQK */
+	u32	regc04;
+	u32	reg874;
+	u32	regc08;
+	u32	regb68;
+	u32	regb6c;
+	u32	reg870;
+	u32	reg860;
+	u32	reg864;
+
+	boolean	is_iqk_initialized;
+	boolean is_lck_in_progress;
+	boolean	is_antenna_detected;
+	boolean	is_need_iqk;
+	boolean	is_iqk_in_progress;
+	boolean	is_iqk_pa_off;
+	u8	delta_iqk;
+	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];
+	u32	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
+	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+
+	u64	iqk_start_time;
+	u64	iqk_total_progressing_time;
+	u64	iqk_progressing_time;
+	u64	lck_progressing_time;
+	u32  lok_result;
+	u8	iqk_step;
+	u8	kcount;
+	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean	is_mp_mode;
+
+	/* for APK */
+	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8	is_ap_kdone;
+	u8	is_apk_thermal_meter_ignore;
+	u8	is_dp_done;
+	u8	is_dp_path_aok;
+	u8	is_dp_path_bok;
+
+	/*Add by Yuchen for Kfree Phydm*/
+	u8			reg_rf_kfree_enable;	/*for registry*/
+	u8			rf_kfree_enable;		/*for efuse enable check*/
+	u32	tx_lok[2];
+};
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+);
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+void
+odm_txpowertracking_callback_thermal_meter92c(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_rx_gain_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_direct_call92c(
+	void		*adapter
+);
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+);
+
+#endif
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ce.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ce.c
new file mode 100644
index 000000000000..eb906e9a0053
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ce.c
@@ -0,0 +1,762 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*============================================================	*/
+/* include files												*/
+/*============================================================	*/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ************************************************************
+ * Global var
+ * ************************************************************ */
+
+u32	ofdm_swing_table[OFDM_TABLE_SIZE] = {
+	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*/
+};
+
+u8	cck_swing_table_ch1_ch13[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 <== default */
+	{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	cck_swing_table_ch14[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  <== default*/
+	{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*/
+};
+
+
+u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
+	0x0b40002d, /* 0,  -15.0dB	*/
+	0x0c000030, /* 1,  -14.5dB*/
+	0x0cc00033, /* 2,  -14.0dB*/
+	0x0d800036, /* 3,  -13.5dB*/
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB*/
+	0x10000040, /* 6,  -12.0dB*/
+	0x11000044, /* 7,  -11.5dB*/
+	0x12000048, /* 8,  -11.0dB*/
+	0x1300004c, /* 9,  -10.5dB*/
+	0x14400051, /* 10, -10.0dB*/
+	0x15800056, /* 11, -9.5dB*/
+	0x16c0005b, /* 12, -9.0dB*/
+	0x18000060, /* 13, -8.5dB*/
+	0x19800066, /* 14, -8.0dB*/
+	0x1b00006c, /* 15, -7.5dB*/
+	0x1c800072, /* 16, -7.0dB*/
+	0x1e400079, /* 17, -6.5dB*/
+	0x20000080, /* 18, -6.0dB*/
+	0x22000088, /* 19, -5.5dB*/
+	0x24000090, /* 20, -5.0dB*/
+	0x26000098, /* 21, -4.5dB*/
+	0x288000a2, /* 22, -4.0dB*/
+	0x2ac000ab, /* 23, -3.5dB*/
+	0x2d4000b5, /* 24, -3.0dB*/
+	0x300000c0, /* 25, -2.5dB*/
+	0x32c000cb, /* 26, -2.0dB*/
+	0x35c000d7, /* 27, -1.5dB*/
+	0x390000e4, /* 28, -1.0dB*/
+	0x3c8000f2, /* 29, -0.5dB*/
+	0x40000100, /* 30, +0dB*/
+	0x43c0010f, /* 31, +0.5dB*/
+	0x47c0011f, /* 32, +1.0dB*/
+	0x4c000130, /* 33, +1.5dB*/
+	0x50800142, /* 34, +2.0dB*/
+	0x55400155, /* 35, +2.5dB*/
+	0x5a400169, /* 36, +3.0dB*/
+	0x5fc0017f, /* 37, +3.5dB*/
+	0x65400195, /* 38, +4.0dB*/
+	0x6b8001ae, /* 39, +4.5dB*/
+	0x71c001c7, /* 40, +5.0dB*/
+	0x788001e2, /* 41, +5.5dB*/
+	0x7f8001fe  /* 42, +6.0dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/*  0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/*   1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/*  2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/*   3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/*   6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/*   7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/*  8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/*   9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/*  14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/*  15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/*  16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/*  17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/*  18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/*  19, -6.5dB*/
+	{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	/*20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/*  21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/*  23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/*  24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/*  25, -3.5dB*/
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/*  26, -3.0dB*/
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/*  27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/*  28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/*  29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/*  30, -1.0dB*/
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/*  31, -0.5dB*/
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/*  32, +0dB*/
+};
+
+
+u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/*  0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/*5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/*  7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/*11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/*14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/*23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/*27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/*29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB	*/
+};
+u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
+	0x0CD,          /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+/* JJ ADD 20161014 */
+u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
+	0x0CD,          /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+
+u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
+	0x081, /* 0,  -12.0dB*/
+	0x088, /* 1,  -11.5dB*/
+	0x090, /* 2,  -11.0dB*/
+	0x099, /* 3,  -10.5dB*/
+	0x0A2, /* 4,  -10.0dB*/
+	0x0AC, /* 5,  -9.5dB*/
+	0x0B6, /* 6,  -9.0dB*/
+	0x0C0, /*7,  -8.5dB*/
+	0x0CC, /* 8,  -8.0dB*/
+	0x0D8, /* 9,  -7.5dB*/
+	0x0E5, /* 10, -7.0dB*/
+	0x0F2, /* 11, -6.5dB*/
+	0x101, /* 12, -6.0dB*/
+	0x110, /* 13, -5.5dB*/
+	0x120, /* 14, -5.0dB*/
+	0x131, /* 15, -4.5dB*/
+	0x143, /* 16, -4.0dB*/
+	0x156, /* 17, -3.5dB*/
+	0x16A, /* 18, -3.0dB*/
+	0x180, /* 19, -2.5dB*/
+	0x197, /* 20, -2.0dB*/
+	0x1AF, /* 21, -1.5dB*/
+	0x1C8, /* 22, -1.0dB*/
+	0x1E3, /* 23, -0.5dB*/
+	0x200, /* 24, +0  dB*/
+	0x21E, /* 25, +0.5dB*/
+	0x23E, /* 26, +1.0dB*/
+	0x261, /* 27, +1.5dB*/
+	0x285,/* 28, +2.0dB*/
+	0x2AB, /* 29, +2.5dB*/
+	0x2D3, /*30, +3.0dB*/
+	0x2FE, /* 31, +3.5dB*/
+	0x32B, /* 32, +4.0dB*/
+	0x35C, /* 33, +4.5dB*/
+	0x38E, /* 34, +5.0dB*/
+	0x3C4, /* 35, +5.5dB*/
+	0x3FE  /* 36, +6.0dB	*/
+};
+
+void
+odm_txpowertracking_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
+		return;
+#endif
+
+	odm_txpowertracking_thermal_meter_init(dm);
+}
+
+u8
+get_swing_index(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+#endif
+	u8			i = 0;
+	u32			bb_swing;
+	u32			swing_table_size;
+	u32			*swing_table;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B
+	    || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B
+	   ) {
+		bb_swing = odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
+
+		swing_table = ofdm_swing_table_new;
+		swing_table_size = OFDM_TABLE_SIZE;
+	} else {
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8821) {
+			bb_swing = phy_get_tx_bb_swing_8812a(adapter, hal_data->current_band_type, RF_PATH_A);
+			swing_table = tx_scaling_table_jaguar;
+			swing_table_size = TXSCALE_TABLE_SIZE;
+		} else
+#endif
+		{
+			bb_swing = 0;
+			swing_table = ofdm_swing_table;
+			swing_table_size = OFDM_TABLE_SIZE;
+		}
+	}
+
+	for (i = 0; i < swing_table_size; ++i) {
+		u32 table_value = swing_table[i];
+
+		if (table_value >= 0x100000)
+			table_value >>= 22;
+		if (bb_swing == table_value)
+			break;
+	}
+	return i;
+}
+
+u8
+get_cck_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	u8			i = 0;
+	u32			bb_cck_swing;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
+				break;
+		}
+	} else if (dm->support_ic_type == ODM_RTL8703B) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
+				break;
+		}
+	}
+
+	return i;
+}
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8 default_swing_index = get_swing_index(dm);
+	u8 default_cck_swing_index = get_cck_swing_index(dm);
+	u8			p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+
+	if (*dm->mp_mode == false)
+		hal_data->txpowertrack_control = true;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#ifdef DM_ODM_CE_MAC80211
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
+#else
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+#endif
+
+	cali_info->is_txpowertracking = true;
+	cali_info->tx_powercount = 0;
+	cali_info->is_txpowertracking_init = false;
+
+	if (*dm->mp_mode == false)
+		cali_info->txpowertrack_control = true;
+	else
+		cali_info->txpowertrack_control = false;
+
+	if (*dm->mp_mode == false)
+		cali_info->txpowertrack_control = true;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
+
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#ifdef RTL8188E_SUPPORT
+	{
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
+		cali_info->txpowertrack_control = true;
+	}
+#endif
+#endif
+
+	/* dm->rf_calibrate_info.txpowertrack_control = true; */
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	cali_info->thermal_value = rtlefu->eeprom_thermalmeter;
+	cali_info->thermal_value_iqk = rtlefu->eeprom_thermalmeter;
+	cali_info->thermal_value_lck = rtlefu->eeprom_thermalmeter;
+#else
+	cali_info->thermal_value = hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_iqk = hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_lck = hal_data->eeprom_thermal_meter;
+#endif
+
+	if (cali_info->default_bb_swing_index_flag != true) {
+		/*The index of "0 dB" in SwingTable.*/
+		if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+		    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8703B) {
+			cali_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
+			cali_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
+		} else if (dm->support_ic_type == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
+			cali_info->default_ofdm_index = 28;							/*OFDM: -1dB*/
+			cali_info->default_cck_index = 20;							/*CCK:-6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8723D) {			 /*add by zhaohe  2015-10-27*/
+			cali_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;							/*CCK:   -6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8710B) {		/* JJ ADD 20161014 */
+			cali_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;							   /*CCK:   -6dB*/
+		} else {
+			cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
+			cali_info->default_cck_index = 24;
+		}
+		cali_info->default_bb_swing_index_flag = true;
+	}
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->CCK_index = cali_info->default_cck_index;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
+	}
+	cali_info->modify_tx_agc_value_ofdm = 0;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->tm_trigger = 0;
+}
+
+
+void
+odm_txpowertracking_check(
+	void	*dm_void
+)
+{
+	/* 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. */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_txpowertracking_check_mp(dm);
+		break;
+
+	case	ODM_CE:
+		odm_txpowertracking_check_ce(dm);
+		break;
+
+	case	ODM_AP:
+		odm_txpowertracking_check_ap(dm);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+odm_txpowertracking_check_ce(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &dm->rf_table;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*adapter = dm->adapter;
+
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	if (!dm->rf_calibrate_info.tm_trigger) {
+		if (dm->support_ic_type &
+				(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8192E |
+				 ODM_RTL8723B | ODM_RTL8812 | ODM_RTL8821 |
+				 ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8723D |
+				 ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8710B))
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW, (BIT(17) | BIT(16)), 0x03);
+		else
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_OLD, RFREGOFFSETMASK, 0x60);
+
+
+
+		dm->rf_calibrate_info.tm_trigger = 1;
+		return;
+	} else {
+		odm_txpowertracking_callback_thermal_meter(dm);
+		dm->rf_calibrate_info.tm_trigger = 0;
+	}
+
+#endif
+}
+
+void
+odm_txpowertracking_check_mp(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+
+	if (odm_check_power_status(adapter) == false) {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status, return false\n"));
+		return;
+	}
+
+	odm_txpowertracking_thermal_meter_check(adapter);
+#endif
+
+}
+
+
+void
+odm_txpowertracking_check_ap(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv	*priv		= dm->priv;
+
+	return;
+
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ce.h
new file mode 100644
index 000000000000..0306d9e29588
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_ce.h
@@ -0,0 +1,349 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMPOWERTRACKING_H__
+#define    __PHYDMPOWERTRACKING_H__
+
+#define		DPK_DELTA_MAPPING_NUM	13
+#define		index_mapping_HP_NUM	15
+#define	OFDM_TABLE_SIZE	43
+#define	CCK_TABLE_SIZE			33
+#define	CCK_TABLE_SIZE_88F	21
+#define TXSCALE_TABLE_SIZE		37
+#define CCK_TABLE_SIZE_8723D	41
+/* JJ ADD 20161014 */
+#define CCK_TABLE_SIZE_8710B	41
+
+#define TXPWR_TRACK_TABLE_SIZE	30
+#define DELTA_SWINGIDX_SIZE     30
+#define DELTA_SWINTSSI_SIZE     61
+#define BAND_NUM				4
+
+#define AVG_THERMAL_NUM		8
+#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 iqk_matrix_reg_num	8
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#else
+#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+#endif
+
+extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/* JJ ADD 20161014 */
+extern	u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+
+extern  u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+
+/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#else
+static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+#endif
+
+#define dm_check_txpowertracking	odm_txpowertracking_check
+
+struct iqk_matrix_regs_setting {
+	boolean	is_iqk_done;
+	s32		value[3][iqk_matrix_reg_num];
+	boolean	is_bw_iqk_result_saved[3];
+};
+
+struct dm_rf_calibration_struct {
+	/* for tx power tracking */
+
+	u32	rega24; /* for TempCCK */
+	s32	rege94;
+	s32	rege9c;
+	s32	regeb4;
+	s32	regebc;
+
+	u8	tx_powercount;
+	boolean is_txpowertracking_init;
+	boolean is_txpowertracking;
+	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
+	u8	tm_trigger;
+	u8  	internal_pa_5g[2];	/* pathA / pathB */
+
+	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8	thermal_value;
+	u8	thermal_value_lck;
+	u8	thermal_value_iqk;
+	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8	thermal_value_dpk;
+	u8	thermal_value_avg[AVG_THERMAL_NUM];
+	u8	thermal_value_avg_index;
+	u8	thermal_value_rx_gain;
+	u8	thermal_value_crystal;
+	u8	thermal_value_dpk_store;
+	u8	thermal_value_dpk_track;
+	boolean	txpowertracking_in_progress;
+
+	boolean	is_reloadtxpowerindex;
+	u8	is_rf_pi_enable;
+	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
+
+
+	/* ------------------------- Tx power Tracking ------------------------- */
+	u8	is_cck_in_ch14;
+	u8	CCK_index;
+	u8	OFDM_index[MAX_RF_PATH];
+	s8	power_index_offset[MAX_RF_PATH];
+	s8	delta_power_index[MAX_RF_PATH];
+	s8	delta_power_index_last[MAX_RF_PATH];
+	boolean is_tx_power_changed;
+	s8	xtal_offset;
+	s8	xtal_offset_last;
+
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8	delta_lck;
+	s8  bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
+	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	s8  delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
+	s8  delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8			bb_swing_idx_ofdm_current;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+#else
+	u8			bb_swing_idx_ofdm_base;
+#endif
+	boolean		default_bb_swing_index_flag;
+	boolean			bb_swing_flag_ofdm;
+	u8			bb_swing_idx_cck;
+	u8			bb_swing_idx_cck_current;
+	u8			bb_swing_idx_cck_base;
+	u8			default_ofdm_index;
+	u8			default_cck_index;
+	boolean			bb_swing_flag_cck;
+
+	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8			absolute_cck_swing_idx[MAX_RF_PATH];
+	s8			remnant_cck_swing_idx;
+	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
+	boolean			modify_tx_agc_flag_path_a;
+	boolean			modify_tx_agc_flag_path_b;
+	boolean			modify_tx_agc_flag_path_c;
+	boolean			modify_tx_agc_flag_path_d;
+	boolean			modify_tx_agc_flag_path_a_cck;
+
+	s8			kfree_offset[MAX_RF_PATH];
+
+	/* -------------------------------------------------------------------- */
+
+	/* for IQK */
+	u32	regc04;
+	u32	reg874;
+	u32	regc08;
+	u32	regb68;
+	u32	regb6c;
+	u32	reg870;
+	u32	reg860;
+	u32	reg864;
+
+	boolean	is_iqk_initialized;
+	boolean is_lck_in_progress;
+	boolean	is_antenna_detected;
+	boolean	is_need_iqk;
+	boolean	is_iqk_in_progress;
+	boolean is_iqk_pa_off;
+	u8	delta_iqk;
+	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];
+	u32 	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32 	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
+	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	u32	tx_iqc_8723d[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8723d[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	/* JJ ADD 20161014 */
+	u32	tx_iqc_8710b[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8710b[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+
+	u8	iqk_step;
+	u8	kcount;
+	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean	is_mp_mode;
+
+
+
+	/* <James> IQK time measurement */
+	u64	iqk_start_time;
+	u64	iqk_progressing_time;
+	u64	iqk_total_progressing_time;
+	u64 lck_progressing_time;
+
+	u32  lok_result;
+
+	/* for APK */
+	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8	is_ap_kdone;
+	u8	is_apk_thermal_meter_ignore;
+
+	/* DPK */
+	boolean is_dpk_fail;
+	u8	is_dp_done;
+	u8	is_dp_path_aok;
+	u8	is_dp_path_bok;
+
+	u32	tx_lok[2];
+	u32  dpk_tx_agc;
+	s32  dpk_gain;
+	u32  dpk_thermal[4];
+	s8 modify_tx_agc_value_ofdm;
+	s8 modify_tx_agc_value_cck;
+
+	/*Add by Yuchen for Kfree Phydm*/
+	u8			reg_rf_kfree_enable;	/*for registry*/
+	u8			rf_kfree_enable;		/*for efuse enable check*/
+
+};
+
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+void
+odm_txpowertracking_callback_thermal_meter92c(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_rx_gain_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_direct_call92c(
+	void		*adapter
+);
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+);
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_win.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_win.c
new file mode 100644
index 000000000000..66a377215424
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_win.c
@@ -0,0 +1,807 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ************************************************************
+ * Global var
+ * ************************************************************ */
+
+u32	ofdm_swing_table[OFDM_TABLE_SIZE] = {
+	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 */
+};
+
+u8	cck_swing_table_ch1_ch13[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 <== default */
+	{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	cck_swing_table_ch14[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  <== default */
+	{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 */
+};
+
+
+u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
+	0x0b40002d, /* 0,  -15.0dB */
+	0x0c000030, /* 1,  -14.5dB */
+	0x0cc00033, /* 2,  -14.0dB */
+	0x0d800036, /* 3,  -13.5dB */
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB */
+	0x10000040, /* 6,  -12.0dB */
+	0x11000044, /* 7,  -11.5dB */
+	0x12000048, /* 8,  -11.0dB */
+	0x1300004c, /* 9,  -10.5dB */
+	0x14400051, /* 10, -10.0dB */
+	0x15800056, /* 11, -9.5dB */
+	0x16c0005b, /* 12, -9.0dB */
+	0x18000060, /* 13, -8.5dB */
+	0x19800066, /* 14, -8.0dB */
+	0x1b00006c, /* 15, -7.5dB */
+	0x1c800072, /* 16, -7.0dB */
+	0x1e400079, /* 17, -6.5dB */
+	0x20000080, /* 18, -6.0dB */
+	0x22000088, /* 19, -5.5dB */
+	0x24000090, /* 20, -5.0dB */
+	0x26000098, /* 21, -4.5dB */
+	0x288000a2, /* 22, -4.0dB */
+	0x2ac000ab, /* 23, -3.5dB */
+	0x2d4000b5, /* 24, -3.0dB */
+	0x300000c0, /* 25, -2.5dB */
+	0x32c000cb, /* 26, -2.0dB */
+	0x35c000d7, /* 27, -1.5dB */
+	0x390000e4, /* 28, -1.0dB */
+	0x3c8000f2, /* 29, -0.5dB */
+	0x40000100, /* 30, +0dB */
+	0x43c0010f, /* 31, +0.5dB */
+	0x47c0011f, /* 32, +1.0dB */
+	0x4c000130, /* 33, +1.5dB */
+	0x50800142, /* 34, +2.0dB */
+	0x55400155, /* 35, +2.5dB */
+	0x5a400169, /* 36, +3.0dB */
+	0x5fc0017f, /* 37, +3.5dB */
+	0x65400195, /* 38, +4.0dB */
+	0x6b8001ae, /* 39, +4.5dB */
+	0x71c001c7, /* 40, +5.0dB */
+	0x788001e2, /* 41, +5.5dB */
+	0x7f8001fe  /* 42, +6.0dB */
+};
+
+
+u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+
+u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/* 32, +0dB */
+};
+
+
+u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/* 0, -16.0dB */
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB */
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 2, -15.0dB */
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB */
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 4, -14.0dB */
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 5, -13.5dB */
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB */
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 7, -12.5dB */
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB */
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB */
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB */
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 11, -10.5dB */
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB */
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB */
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB */
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB */
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB */
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/* 23, -4.5dB */
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/* 27, -2.5dB */
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/* 29, -1.5dB */
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB */
+};
+u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
+	0x0CD,
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+/* JJ ADD 20161014 */
+u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
+	0x0CD,			 /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,		/*19*/
+	0x287,		/*20*/
+	0x2AE,		/*21*/
+	0x2D6,		/*22*/
+	0x301,		/*23*/
+	0x32F,		/*24*/
+	0x35F,		/*25*/
+	0x392,		/*26*/
+	0x3C9,		/*27*/
+	0x402,		/*28*/
+	0x43F,		/*29*/
+	0x47F,		/*30*/
+	0x4C3,		/*31*/
+	0x50C,		/*32*/
+	0x558,		/*33*/
+	0x5A9,		/*34*/
+	0x5FF,		/*35*/
+	0x65A,		/*36*/
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+
+u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
+	0x081, /* 0,  -12.0dB */
+	0x088, /* 1,  -11.5dB */
+	0x090, /* 2,  -11.0dB */
+	0x099, /* 3,  -10.5dB */
+	0x0A2, /* 4,  -10.0dB */
+	0x0AC, /* 5,  -9.5dB */
+	0x0B6, /* 6,  -9.0dB */
+	0x0C0, /* 7,  -8.5dB */
+	0x0CC, /* 8,  -8.0dB */
+	0x0D8, /* 9,  -7.5dB */
+	0x0E5, /* 10, -7.0dB */
+	0x0F2, /* 11, -6.5dB */
+	0x101, /* 12, -6.0dB */
+	0x110, /* 13, -5.5dB */
+	0x120, /* 14, -5.0dB */
+	0x131, /* 15, -4.5dB */
+	0x143, /* 16, -4.0dB */
+	0x156, /* 17, -3.5dB */
+	0x16A, /* 18, -3.0dB */
+	0x180, /* 19, -2.5dB */
+	0x197, /* 20, -2.0dB */
+	0x1AF, /* 21, -1.5dB */
+	0x1C8, /* 22, -1.0dB */
+	0x1E3, /* 23, -0.5dB */
+	0x200, /* 24, +0  dB */
+	0x21E, /* 25, +0.5dB */
+	0x23E, /* 26, +1.0dB */
+	0x261, /* 27, +1.5dB */
+	0x285, /* 28, +2.0dB */
+	0x2AB, /* 29, +2.5dB */
+	0x2D3, /* 30, +3.0dB */
+	0x2FE, /* 31, +3.5dB */
+	0x32B, /* 32, +4.0dB */
+	0x35C, /* 33, +4.5dB */
+	0x38E, /* 34, +5.0dB */
+	0x3C4, /* 35, +5.5dB */
+	0x3FE  /* 36, +6.0dB */
+};
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
+		return;
+#endif
+
+	odm_txpowertracking_thermal_meter_init(dm);
+}
+
+u8
+get_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	u8			i = 0;
+	u32			bb_swing;
+	u32			swing_table_size;
+	u32			*swing_table;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8710B) {
+		bb_swing = odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
+
+		swing_table = ofdm_swing_table_new;
+		swing_table_size = OFDM_TABLE_SIZE;
+	} else {
+		bb_swing = PHY_GetTxBBSwing_8812A((PADAPTER)adapter, hal_data->CurrentBandType, RF_PATH_A);
+		swing_table = tx_scaling_table_jaguar;
+		swing_table_size = TXSCALE_TABLE_SIZE;
+	}
+
+	for (i = 0; i < swing_table_size; ++i) {
+		u32 table_value = swing_table[i];
+
+		if (table_value >= 0x100000)
+			table_value >>= 22;
+		if (bb_swing == table_value)
+			break;
+	}
+	return i;
+}
+
+u8
+get_cck_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	u8			i = 0;
+	u32			bb_cck_swing;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
+				break;
+		}
+	} else if (dm->support_ic_type == ODM_RTL8703B) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
+				break;
+		}
+	}
+
+	return i;
+}
+
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8 default_swing_index = get_swing_index(dm);
+	u8 default_cck_swing_index = get_cck_swing_index(dm);
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	u8			p = 0;
+
+	if (*(dm->mp_mode) == false)
+		cali_info->txpowertrack_control = true;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#ifdef CONFIG_RTL8188E
+	{
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)
+			cali_info->txpowertrack_control = true;
+
+		MSG_8192C("dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+		struct dm_priv	*pdmpriv = &hal_data->dmpriv;
+
+		pdmpriv->is_txpowertracking = true;
+		pdmpriv->tx_powercount = 0;
+		pdmpriv->is_txpowertracking_init = false;
+
+		if (*(dm->mp_mode) == false)
+			pdmpriv->txpowertrack_control = true;
+
+		MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
+
+	}
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#ifdef RTL8188E_SUPPORT
+	{
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
+		cali_info->txpowertrack_control = true;
+	}
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if (MP_DRIVER == 1)
+	cali_info->txpowertrack_control = false;
+#else
+	cali_info->txpowertrack_control = true;
+#endif
+#else
+	cali_info->txpowertrack_control = true;
+#endif
+
+	cali_info->thermal_value		= hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_iqk	= hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_lck	= hal_data->eeprom_thermal_meter;
+
+	if (cali_info->default_bb_swing_index_flag != true) {
+		/*The index of "0 dB" in SwingTable.*/
+		if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+		    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8703B) {
+			cali_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
+			cali_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
+		} else if (dm->support_ic_type == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
+			cali_info->default_ofdm_index = 28;							/*OFDM: -1dB*/
+			cali_info->default_cck_index = 20;							/*CCK:-6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8723D) {			 /*add by zhaohe  2015-10-27*/
+			cali_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;							/*CCK:   -6dB*/
+			/* JJ ADD 20161014 */
+		} else if (dm->support_ic_type == ODM_RTL8710B) {			
+			cali_info->default_ofdm_index = 28;					/*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;					/*CCK:   -6dB*/
+		} else {
+			cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
+			cali_info->default_cck_index = 24;
+		}
+		cali_info->default_bb_swing_index_flag = true;
+	}
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->CCK_index = cali_info->default_cck_index;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+	cali_info->modify_tx_agc_value_ofdm = 0;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->tm_trigger = 0;
+}
+
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+)
+{
+
+#if 0
+	/* 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. */
+#endif
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_txpowertracking_check_mp(dm);
+		break;
+
+	case	ODM_CE:
+		odm_txpowertracking_check_ce(dm);
+		break;
+
+	case	ODM_AP:
+		odm_txpowertracking_check_ap(dm);
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*adapter = dm->adapter;
+#if ((RTL8188F_SUPPORT == 1))
+	rtl8192c_odm_check_txpowertracking(adapter);
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	if (!cali_info->tm_trigger) {
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+		/*DBG_8192C("Trigger 92C Thermal Meter!!\n");*/
+
+		cali_info->tm_trigger = 1;
+		return;
+
+	} else {
+		/*DBG_8192C("Schedule TxPowerTracking direct call!!\n");*/
+		odm_txpowertracking_callback_thermal_meter_8188e(adapter);
+		cali_info->tm_trigger = 0;
+	}
+#endif
+#endif
+}
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+
+	if (*dm->is_fcs_mode_enable)
+		return;
+
+	if (odm_check_power_status(dm) == false) {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status return false\n"));
+		return;
+	}
+
+	if (IS_HARDWARE_TYPE_8821B(adapter)) /* TODO: Don't Do PowerTracking*/
+		return;
+
+	odm_txpowertracking_thermal_meter_check(adapter);
+
+
+#endif
+
+}
+
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+)
+{
+	return;
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_txpowertracking_direct_call(
+	void		*adapter
+)
+{
+	HAL_DATA_TYPE		*hal_data	= GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct			*dm = &hal_data->DM_OutSrc;
+
+	odm_txpowertracking_callback_thermal_meter(adapter);
+}
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+)
+{
+	static u8			tm_trigger = 0;
+	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct	*dm = &(pHalData->DM_OutSrc);
+	struct _hal_rf_			*rf = &(dm->rf_table);
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK)) {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
+			("===>odm_txpowertracking_thermal_meter_check(),mgnt_info->is_txpowertracking is false, return!!\n"));
+		return;
+	}
+
+	if (!tm_trigger) {
+		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_8192E(adapter) ||
+		    IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8814A(adapter) || IS_HARDWARE_TYPE_8188F(adapter) || IS_HARDWARE_TYPE_8703B(adapter)
+		    || IS_HARDWARE_TYPE_8822B(adapter) || IS_HARDWARE_TYPE_8723D(adapter) || IS_HARDWARE_TYPE_8821C(adapter) || IS_HARDWARE_TYPE_8710B(adapter))/* JJ ADD 20161014 */
+			PHY_SetRFReg((PADAPTER)adapter, RF_PATH_A, RF_T_METER_88E, BIT(17) | BIT(16), 0x03);
+		else
+			PHY_SetRFReg((PADAPTER)adapter, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("Trigger Thermal Meter!!\n"));
+
+		tm_trigger = 1;
+		return;
+	} else {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("Schedule TxPowerTracking direct call!!\n"));
+		odm_txpowertracking_direct_call(adapter);
+		tm_trigger = 0;
+	}
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_win.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_win.h
new file mode 100644
index 000000000000..c3851d9db660
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_powertracking_win.h
@@ -0,0 +1,300 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDMPOWERTRACKING_H__
+#define    __PHYDMPOWERTRACKING_H__
+
+#define	DPK_DELTA_MAPPING_NUM	13
+#define	index_mapping_HP_NUM	15
+#define	TXSCALE_TABLE_SIZE		37
+#define	OFDM_TABLE_SIZE			43
+#define	CCK_TABLE_SIZE			33
+#define	CCK_TABLE_SIZE_8723D    41
+#define	TXPWR_TRACK_TABLE_SIZE	30
+#define	DELTA_SWINGIDX_SIZE     30
+#define	DELTA_SWINTSSI_SIZE     61
+#define	BAND_NUM				3
+#define	MAX_RF_PATH	4
+#define	CCK_TABLE_SIZE_88F	21
+/* JJ ADD 20161014 */
+#define	CCK_TABLE_SIZE_8710B   41
+
+
+#define	dm_check_txpowertracking	odm_txpowertracking_check
+
+#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+#define	AVG_THERMAL_NUM		8
+#define	iqk_matrix_reg_num	8
+#define	IQK_MAC_REG_NUM		4
+#define	IQK_ADDA_REG_NUM		16
+
+#define	IQK_BB_REG_NUM		9
+
+
+extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/* JJ ADD 20161014 */
+extern	u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+
+extern  u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+
+/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_ce(
+	void		*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+);
+
+#endif
+
+struct iqk_matrix_regs_setting {
+	boolean	is_iqk_done;
+	s32		value[3][iqk_matrix_reg_num];
+	boolean	is_bw_iqk_result_saved[3];
+};
+
+struct dm_rf_calibration_struct {
+	/* for tx power tracking */
+
+	u32	rega24; /* for TempCCK */
+	s32	rege94;
+	s32	rege9c;
+	s32	regeb4;
+	s32	regebc;
+	/* u8 is_txpowertracking; */
+	u8	tx_powercount;
+	boolean is_txpowertracking_init;
+	boolean is_txpowertracking;
+	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
+	u8	tm_trigger;
+	u8  	internal_pa_5g[2];	/* pathA / pathB */
+
+	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8	thermal_value;
+	u8	thermal_value_lck;
+	u8	thermal_value_iqk;
+	u8  thermal_value_dpk;
+	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8	thermal_value_avg[AVG_THERMAL_NUM];
+	u8	thermal_value_avg_index;
+	u8	thermal_value_rx_gain;
+
+
+	boolean	is_reloadtxpowerindex;
+	u8	is_rf_pi_enable;
+	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
+
+
+	/* ------------------------- Tx power Tracking ------------------------- */
+	u8	is_cck_in_ch14;
+	u8	CCK_index;
+	u8	OFDM_index[MAX_RF_PATH];
+	s8	power_index_offset[MAX_RF_PATH];
+	s8	delta_power_index[MAX_RF_PATH];
+	s8	delta_power_index_last[MAX_RF_PATH];
+	boolean is_tx_power_changed;
+	s8	xtal_offset;
+	s8	xtal_offset_last;
+
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8	delta_lck;
+	s8  bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
+	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	s8  delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
+	s8  delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8			bb_swing_idx_ofdm_current;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+#else
+	u8			bb_swing_idx_ofdm_base;
+#endif
+	boolean		default_bb_swing_index_flag;
+	boolean			bb_swing_flag_ofdm;
+	u8			bb_swing_idx_cck;
+	u8			bb_swing_idx_cck_current;
+	u8			bb_swing_idx_cck_base;
+	u8			default_ofdm_index;
+	u8			default_cck_index;
+	boolean			bb_swing_flag_cck;
+
+	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8			absolute_cck_swing_idx[MAX_RF_PATH];
+	s8			remnant_cck_swing_idx;
+	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
+	boolean			modify_tx_agc_flag_path_a;
+	boolean			modify_tx_agc_flag_path_b;
+	boolean			modify_tx_agc_flag_path_c;
+	boolean			modify_tx_agc_flag_path_d;
+	boolean			modify_tx_agc_flag_path_a_cck;
+
+	s8			kfree_offset[MAX_RF_PATH];
+
+	/* -------------------------------------------------------------------- */
+
+	/* for IQK */
+	u32	regc04;
+	u32	reg874;
+	u32	regc08;
+	u32	regb68;
+	u32	regb6c;
+	u32	reg870;
+	u32	reg860;
+	u32	reg864;
+
+	boolean	is_iqk_initialized;
+	boolean is_lck_in_progress;
+	boolean	is_antenna_detected;
+	boolean	is_need_iqk;
+	boolean	is_iqk_in_progress;
+	boolean	is_iqk_pa_off;
+	u8	delta_iqk;
+	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];
+	u32	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
+	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	u32	tx_iqc_8723d[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8723d[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	/* JJ ADD 20161014 */
+	u32	tx_iqc_8710b[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8710b[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+
+	u64	iqk_start_time;
+	u64	iqk_total_progressing_time;
+	u64	iqk_progressing_time;
+	u64	lck_progressing_time;
+	u32  lok_result;
+	u8	iqk_step;
+	u8	kcount;
+	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean	is_mp_mode;
+
+	/* for APK */
+	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8	is_ap_kdone;
+	u8	is_apk_thermal_meter_ignore;
+
+	/* DPK */
+	boolean is_dpk_fail;
+	u8	is_dp_done;
+	u8	is_dp_path_aok;
+	u8	is_dp_path_bok;
+
+	u32	tx_lok[2];
+	u32  dpk_tx_agc;
+	s32  dpk_gain;
+	u32  dpk_thermal[4];
+
+	s8 modify_tx_agc_value_ofdm;
+	s8 modify_tx_agc_value_cck;
+
+	/*Add by Yuchen for Kfree Phydm*/
+	u8			reg_rf_kfree_enable;	/*for registry*/
+	u8			rf_kfree_enable;		/*for efuse enable check*/
+};
+
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_psd.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_psd.c
new file mode 100644
index 000000000000..286892a1c2b8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_psd.c
@@ -0,0 +1,322 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#if 0
+u32 _sqrt(u64 n)
+{
+	u64	ans = 0, q = 0; 
+	s64	i;
+
+	/*for (i = sizeof(n) * 8 - 2; i > -1; i = i - 2) {*/
+	for (i = 8 * 8 - 2; i > -1; i = i - 2) {
+		q = (q << 2) | ((n & (3 << i)) >> i); 
+		if (q >= ((ans << 2) | 1)) 
+		{ 
+			q = q - ((ans << 2) | 1); 
+			ans = (ans << 1) | 1; 
+		} 
+		else 
+			ans = ans << 1; 
+	}
+	DbgPrint("ans=0x%x\n", ans);
+
+	return (u32)ans; 
+}
+#endif
+
+
+
+u64 _sqrt(u64 x)
+{
+	u64 i = 0;
+	u64 j = x / 2 + 1;
+
+	while (i <= j) {
+		u64 mid = (i + j) / 2;
+
+		u64 sq = mid * mid;
+
+		if (sq == x)
+			return mid;
+		else if (sq < x)
+			i = mid + 1;
+		else
+			j = mid - 1;
+	}
+
+	return j;
+}
+
+
+
+u32
+halrf_get_psd_data(
+	struct	dm_struct	*dm,
+	u32	point
+	)
+{
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+	u32 psd_val = 0, psd_reg, psd_report, psd_point, psd_start, i, delay_time;
+
+#if (DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+	if (psd->average == 0)
+		delay_time = 100;
+	else
+		delay_time = 0;
+#else
+	if (psd->average == 0)
+		delay_time = 1000;
+	else
+		delay_time = 100;
+#endif
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
+		psd_reg = 0x910;
+		psd_report = 0xf44;
+	} else {
+		psd_reg = 0x808;
+		psd_report = 0x8b4;
+	}
+
+	if (dm->support_ic_type & ODM_RTL8710B) {
+		psd_point = 0xeffffc00;
+		psd_start = 0x10000000;
+	} else {
+		psd_point = 0xffbffc00;
+		psd_start = 0x00400000;
+	}
+
+	psd_val = odm_get_bb_reg(dm, psd_reg, MASKDWORD);
+		
+	psd_val &= psd_point;
+	psd_val |= point;
+
+	odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
+	
+	psd_val |= psd_start;
+
+	odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
+
+	for (i = 0; i < delay_time; i++)
+		ODM_delay_us(1);
+
+	psd_val = odm_get_bb_reg(dm, psd_report, MASKDWORD);
+
+	if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8710B)) {
+		psd_val &= MASKL3BYTES;
+		psd_val = psd_val / 32;
+	} else
+		psd_val &= MASKLWORD;
+
+	return psd_val;
+}
+
+
+
+void
+halrf_psd(
+	struct	dm_struct	*dm,
+	u32	point,
+	u32	start_point,
+	u32	stop_point,
+	u32	average
+	)
+{
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+	
+	u32 i = 0, j = 0, k = 0;
+	u32 psd_reg, avg_org, point_temp, average_tmp;
+	u64 data_tatal = 0, data_temp[64] = {0};
+
+	psd->buf_size = 256;
+
+	if (average == 0)
+		average_tmp = 1;
+	else
+		average_tmp = average;
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+		psd_reg = 0x910;
+	else
+		psd_reg = 0x808;
+
+#if 0
+	dbg_print("[PSD]point=%d, start_point=%d, stop_point=%d, average=%d, average_tmp=%d, buf_size=%d\n",
+		point, start_point, stop_point, average, average_tmp, psd->buf_size);
+#endif
+
+	for (i = 0; i < psd->buf_size; i++)
+		psd->psd_data[i] = 0;
+	
+	if (dm->support_ic_type & ODM_RTL8710B)
+		avg_org = odm_get_bb_reg(dm, psd_reg, 0x30000);
+	else
+		avg_org = odm_get_bb_reg(dm, psd_reg, 0x3000);
+
+	if (average != 0)
+	{
+		if (dm->support_ic_type & ODM_RTL8710B)
+			odm_set_bb_reg(dm, psd_reg, 0x30000, 0x1);
+		else
+			odm_set_bb_reg(dm, psd_reg, 0x3000, 0x1);
+	}
+
+#if 0
+	if (avg_temp == 0)
+		avg = 1;
+	else if (avg_temp == 1)
+		avg = 8;
+	else if (avg_temp == 2)
+		avg = 16;
+	else if (avg_temp == 3)
+		avg = 32;
+#endif
+
+	i = start_point;
+	while (i < stop_point) {
+		data_tatal = 0;
+	
+		if (i >= point)
+			point_temp = i - point;
+		else
+			point_temp = i;
+		
+		for (k = 0; k < average_tmp; k++) {
+			data_temp[k] = halrf_get_psd_data(dm, point_temp);
+			data_tatal = data_tatal + (data_temp[k] * data_temp[k]);
+
+#if 0
+			if ((k % 20) == 0)
+				dbg_print("\n ");
+			
+			dbg_print("0x%x ", data_temp[k]);
+#endif
+		}
+		/*dbg_print("\n");*/
+
+		data_tatal = ((data_tatal * 100) / average_tmp);
+		psd->psd_data[j] = (u32)_sqrt(data_tatal);
+
+		i++;
+		j++;
+	}
+
+#if 0
+	for (i = 0; i < psd->buf_size; i++) {
+		if ((i % 20) == 0)
+			dbg_print("\n ");
+			
+		dbg_print("0x%x ", psd->psd_data[i]);
+	}
+	dbg_print("\n\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8710B)
+		odm_set_bb_reg(dm, psd_reg, 0x30000, avg_org);
+	else
+		odm_set_bb_reg(dm, psd_reg, 0x3000, avg_org);
+}
+
+
+
+enum rt_status
+halrf_psd_init(
+	struct	dm_struct	*dm
+	)
+{
+	enum rt_status	ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+
+	if (psd->psd_progress)
+		ret_status = RT_STATUS_PENDING;
+	else {
+		psd->psd_progress = 1;
+		halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
+		psd->psd_progress = 0;
+	}
+
+	return ret_status;
+}
+
+
+
+enum rt_status
+halrf_psd_query(
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		buf_size
+	)
+{
+	enum rt_status	ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+
+	if (psd->psd_progress)
+		ret_status = RT_STATUS_PENDING;
+	else
+		PlatformMoveMemory(outbuf, psd->psd_data, 0x400);
+
+	return ret_status;
+}
+
+
+
+enum rt_status
+halrf_psd_init_query(
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		point,
+	u32		start_point,
+	u32		stop_point,
+	u32		average,
+	u32		buf_size
+	)
+{
+	enum rt_status	ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_			*rf = &(dm->rf_table);
+	struct _halrf_psd_data	*psd = &(rf->halrf_psd_data);
+
+	psd->point = point;
+	psd->start_point = start_point;
+	psd->stop_point = stop_point;
+	psd->average = average;
+
+	if (psd->psd_progress)
+		ret_status = RT_STATUS_PENDING;
+	else {
+		psd->psd_progress = 1;
+		halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
+		PlatformMoveMemory(outbuf, psd->psd_data, 0x400);
+		psd->psd_progress = 0;
+	}
+
+	return ret_status;
+}
+
+#endif	/*#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_psd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_psd.h
new file mode 100644
index 000000000000..2903da3c9ee3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_psd.h
@@ -0,0 +1,61 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HALRF_PSD_H__
+#define __HALRF_PSD_H__
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+struct _halrf_psd_data {
+	u32		point;
+	u32		start_point;
+	u32		stop_point;
+	u32		average;
+	u32		buf_size;
+	u32		psd_data[256];
+	u32		psd_progress;
+};
+
+
+
+enum rt_status
+halrf_psd_init (
+	struct	dm_struct	*dm
+	);
+
+
+
+enum rt_status
+halrf_psd_query (
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		buf_size
+);
+
+enum rt_status
+halrf_psd_init_query(
+	struct	dm_struct	*dm,
+	u32		*outbuf,
+	u32		point,
+	u32		start_point,
+	u32		stop_point,
+	u32		average,
+	u32		buf_size
+);
+
+#endif	/*#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)*/
+#endif	/*#ifndef __HALRF_PSD_H__*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_txgapcal.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_txgapcal.c
new file mode 100644
index 000000000000..6fa4ef0be1dc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_txgapcal.c
@@ -0,0 +1,304 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+
+void odm_bub_sort(pu4Byte data, u4Byte n)
+{
+	int i, j, temp, sp;
+	
+	for (i = n - 1;i >= 0;i--) {
+		sp = 1;
+		for (j = 0;j < i;j++) {
+			if (data[j] < data[j + 1]) {
+				temp = data[j];
+				data[j] = data[j + 1];
+				data[j + 1] = temp;
+				sp = 0;
+			}
+		}
+		if (sp == 1)
+			break;          
+	}
+}
+
+
+#if (RTL8197F_SUPPORT == 1)
+
+u4Byte
+odm_tx_gain_gap_psd_8197f(
+	void	*dm_void,
+	u1Byte	rf_path,
+	u4Byte	rf56
+)
+{
+	PDM_ODM_T	dm = (PDM_ODM_T)dm_void;
+	
+	u1Byte i, j;
+	u4Byte psd_vaule[5], psd_avg_time = 5, psd_vaule_temp;
+	
+	u4Byte iqk_ctl_addr[2][6] = {{0xe30, 0xe34, 0xe50, 0xe54, 0xe38, 0xe3c},
+								{0xe50, 0xe54, 0xe30, 0xe34, 0xe58, 0xe5c}};
+	
+	u4Byte psd_finish_bit[2] = {0x04000000, 0x20000000};
+	u4Byte psd_fail_bit[2] = {0x08000000, 0x40000000};
+	
+	u4Byte psd_cntl_value[2][2] = {{0x38008c1c, 0x10008c1c},
+								   {0x38008c2c, 0x10008c2c}};
+	
+	u4Byte psd_report_addr[2] = {0xea0, 0xec0};
+	
+	odm_set_rf_reg(dm, rf_path, 0xdf, bRFRegOffsetMask, 0x00e02);
+
+	ODM_delay_us(100);
+
+	odm_set_bb_reg(dm, 0xe28, 0xffffffff, 0x0);
+	
+	odm_set_rf_reg(dm, rf_path, 0x56, 0xfff, rf56);
+	while(rf56 != (odm_get_rf_reg(dm, rf_path, 0x56, 0xfff)))
+		odm_set_rf_reg(dm, rf_path, 0x56, 0xfff, rf56);
+
+	odm_set_bb_reg(dm, 0xd94, 0xffffffff, 0x44FFBB44);
+	odm_set_bb_reg(dm, 0xe70, 0xffffffff, 0x00400040);
+	odm_set_bb_reg(dm, 0xc04, 0xffffffff, 0x6f005403);
+	odm_set_bb_reg(dm, 0xc08, 0xffffffff, 0x000804e4);
+	odm_set_bb_reg(dm, 0x874, 0xffffffff, 0x04203400);
+	odm_set_bb_reg(dm, 0xe28, 0xffffffff, 0x80800000);
+
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][0], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][1], 0xffffffff, psd_cntl_value[rf_path][1]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][2], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][3], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][4], 0xffffffff, 0x8215001F);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][5], 0xffffffff, 0x2805001F);
+	
+	odm_set_bb_reg(dm, 0xe40, 0xffffffff, 0x81007C00);
+	odm_set_bb_reg(dm, 0xe44, 0xffffffff, 0x81004800);
+	odm_set_bb_reg(dm, 0xe4c, 0xffffffff, 0x0046a8d0);
+	
+
+	for (i = 0; i < psd_avg_time; i++) {
+			
+		for(j = 0; j < 1000 ; j++) {
+			odm_set_bb_reg(dm, 0xe48, 0xffffffff, 0xfa005800);
+			odm_set_bb_reg(dm, 0xe48, 0xffffffff, 0xf8005800);
+
+			while(!odm_get_bb_reg(dm, 0xeac, psd_finish_bit[rf_path]));	/*wait finish bit*/
+
+			if (!odm_get_bb_reg(dm, 0xeac, psd_fail_bit[rf_path])) {	/*check fail bit*/
+				
+				psd_vaule[i] = odm_get_bb_reg(dm, psd_report_addr[rf_path], 0xffffffff);
+				
+				if (psd_vaule[i] > 0xffff)
+					break;
+			}
+		}
+			
+		
+
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x time=%d psd_vaule=0x%x\n",
+			odm_get_rf_reg(dm, rf_path, 0x0, 0xff),
+			rf56, odm_get_rf_reg(dm, rf_path, 0x56, 0xfff), j, psd_vaule[i]);
+	}
+
+	odm_bub_sort(psd_vaule, psd_avg_time);
+
+	psd_vaule_temp = psd_vaule[(UINT)(psd_avg_time / 2)];
+
+	odm_set_bb_reg(dm, 0xd94, 0xffffffff, 0x44BBBB44);
+	odm_set_bb_reg(dm, 0xe70, 0xffffffff, 0x80408040);
+	odm_set_bb_reg(dm, 0xc04, 0xffffffff, 0x6f005433);
+	odm_set_bb_reg(dm, 0xc08, 0xffffffff, 0x000004e4);
+	odm_set_bb_reg(dm, 0x874, 0xffffffff, 0x04003400);
+	odm_set_bb_reg(dm, 0xe28, 0xffffffff, 0x00000000);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x psd_vaule_temp=0x%x\n",
+		odm_get_rf_reg(dm, rf_path, 0x0, 0xff),
+		rf56, odm_get_rf_reg(dm, rf_path, 0x56, 0xfff), psd_vaule_temp);
+	
+	odm_set_rf_reg(dm, rf_path, 0xdf, bRFRegOffsetMask, 0x00602);
+
+	return psd_vaule_temp;
+
+}
+
+
+
+void
+odm_tx_gain_gap_calibration_8197f(
+	void	*dm_void
+)
+{
+	PDM_ODM_T	dm = (PDM_ODM_T)dm_void;
+
+	u1Byte rf_path, rf0_idx, rf0_idx_current, rf0_idx_next, i, delta_gain_retry = 3;
+	
+	s1Byte delta_gain_gap_pre, delta_gain_gap[2][11];
+	u4Byte rf56_current, rf56_next, psd_value_current, psd_value_next;
+	u4Byte psd_gap, rf56_current_temp[2][11];
+	s4Byte rf33[2][11];
+
+	memset(rf33, 0x0, sizeof(rf33));
+
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
+
+		if (rf_path == RF_PATH_A)
+			odm_set_bb_reg(dm, 0x88c, (BIT(21) | BIT(20)), 0x3);	/*disable 3-wire*/
+		else if (rf_path == RF_PATH_B)
+			odm_set_bb_reg(dm, 0x88c, (BIT(23) | BIT(22)), 0x3);	/*disable 3-wire*/
+		
+		ODM_delay_us(100);
+
+		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
+			
+			rf0_idx_current = 3 * (rf0_idx - 1) + 1;
+			odm_set_rf_reg(dm, rf_path, 0x0, 0xff, rf0_idx_current);
+			ODM_delay_us(100);
+			rf56_current_temp[rf_path][rf0_idx] = odm_get_rf_reg(dm, rf_path, 0x56, 0xfff);
+			rf56_current = rf56_current_temp[rf_path][rf0_idx];
+			
+			rf0_idx_next = 3 * rf0_idx + 1;
+			odm_set_rf_reg(dm, rf_path, 0x0, 0xff, rf0_idx_next);
+			ODM_delay_us(100);
+			rf56_next= odm_get_rf_reg(dm, rf_path, 0x56, 0xfff);
+
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56_current[%d][%d]=0x%x rf56_next[%d][%d]=0x%x\n",
+				rf_path, rf0_idx, rf56_current,  rf_path, rf0_idx, rf56_next);
+
+			if ((rf56_current >> 5) == (rf56_next >> 5)) {
+				delta_gain_gap[rf_path][rf0_idx] = 0;
+				
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56_current[11:5] == rf56_next[%d][%d][11:5]=0x%x delta_gain_gap[%d][%d]=%d\n",
+					rf_path, rf0_idx, (rf56_next >> 5), rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx]);
+
+				continue;
+			}
+
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56_current[%d][%d][11:5]=0x%x != rf56_next[%d][%d][11:5]=0x%x\n",
+					 rf_path, rf0_idx, (rf56_current >> 5), rf_path, rf0_idx, (rf56_next >> 5));
+
+			for (i = 0; i < delta_gain_retry; i++) {
+				psd_value_current = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_current);
+
+				psd_value_next = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_next - 2);
+
+				psd_gap = psd_value_next / (psd_value_current / 1000);
+
+#if 0
+				if (psd_gap > 1413)
+					delta_gain_gap[rf_path][rf0_idx] = 1;
+				else if (psd_gap > 1122)
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+				else
+					delta_gain_gap[rf_path][rf0_idx] = -1;
+#endif
+
+				if (psd_gap > 1445)
+					delta_gain_gap[rf_path][rf0_idx] = 1;
+				else if (psd_gap > 1096)
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+				else
+					delta_gain_gap[rf_path][rf0_idx] = -1;
+
+				if (i == 0)
+					delta_gain_gap_pre = delta_gain_gap[rf_path][rf0_idx];
+
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] psd_value_current=0x%x psd_value_next=0x%x psd_value_next/psd_value_current=%d delta_gain_gap[%d][%d]=%d\n",
+						 psd_value_current, psd_value_next, psd_gap, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx]);
+
+				if ((i == 0) && (delta_gain_gap[rf_path][rf0_idx] == 0))
+					break;
+
+				if (delta_gain_gap_pre != delta_gain_gap[rf_path][rf0_idx]) {
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] delta_gain_gap_pre(%d) != delta_gain_gap[%d][%d](%d) time=%d\n",
+							 delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i);
+
+					break;
+				} else {
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] delta_gain_gap_pre(%d) == delta_gain_gap[%d][%d](%d) time=%d\n",
+							 delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i);
+				}
+			}
+		}
+
+		if (rf_path == RF_PATH_A)
+			odm_set_bb_reg(dm, 0x88c, (BIT(21) | BIT(20)), 0x0);	/*enable 3-wire*/
+		else if (rf_path == RF_PATH_B)
+			odm_set_bb_reg(dm, 0x88c, (BIT(23) | BIT(22)), 0x0);	/*enable 3-wire*/
+
+		ODM_delay_us(100);
+
+	}
+
+	/*odm_set_bb_reg(dm, 0x88c, (BIT(23) | BIT(22) | BIT(21) | BIT(20)), 0x0);*/	/*enable 3-wire*/
+
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
+
+		odm_set_rf_reg(dm, rf_path, 0xef, bRFRegOffsetMask, 0x00100);
+
+		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
+			
+			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + (rf56_current_temp[rf_path][rf0_idx] & 0x1f); 
+			
+			for (i = rf0_idx; i <= 10; i++)
+				rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + delta_gain_gap[rf_path][i];
+
+			if (rf33[rf_path][rf0_idx] >= 0x1d)
+				rf33[rf_path][rf0_idx] = 0x1d;
+			else if (rf33[rf_path][rf0_idx] <= 0x2)
+				rf33[rf_path][rf0_idx] = 0x2;
+
+			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + ((rf0_idx - 1) * 0x4000) + (rf56_current_temp[rf_path][rf0_idx] & 0xfffe0);
+
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION,"[TGGC] rf56[%d][%d]=0x%05x rf33[%d][%d]=0x%05x\n", rf_path, rf0_idx, rf56_current_temp[rf_path][rf0_idx], rf_path, rf0_idx, rf33[rf_path][rf0_idx]);
+
+			odm_set_rf_reg(dm, rf_path, 0x33, bRFRegOffsetMask, rf33[rf_path][rf0_idx]);
+		}
+		
+		odm_set_rf_reg(dm, rf_path, 0xef, bRFRegOffsetMask, 0x00000);
+	}
+
+}
+#endif
+
+
+void
+odm_tx_gain_gap_calibration(
+	void	*dm_void
+)
+{
+	PDM_ODM_T	dm = (PDM_ODM_T)dm_void;
+
+	#if (RTL8197F_SUPPORT == 1)
+		if (dm->SupportICType & ODM_RTL8197F)
+			odm_tx_gain_gap_calibration_8197f(dm_void);
+	#endif
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_txgapcal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_txgapcal.h
new file mode 100644
index 000000000000..51ab93a189e6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/halrf_txgapcal.h
@@ -0,0 +1,30 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+void
+odm_tx_gain_gap_calibration(
+	void	*dm_void
+);
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/rtl8188f/halrf_8188f.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/rtl8188f/halrf_8188f.c
new file mode 100644
index 000000000000..9c7a4e2f3f48
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/rtl8188f/halrf_8188f.c
@@ -0,0 +1,2445 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+#if (DM_ODM_SUPPORT_TYPE == 0x08) /*[PHYDM-262] workaround for SD4 compile warning*/
+	#if RT_PLATFORM==PLATFORM_MACOSX
+	#include "phydm_precomp.h"
+	#else
+	#include "../phydm_precomp.h"
+	#endif
+#else
+#include "../../phydm_precomp.h"
+#endif
+
+#define		MASKH3BYTES				0xffffff00
+
+/* #define SUCCESS 0 */
+/* #define FAIL -1 */
+
+
+/*---------------------------Define Local Constant---------------------------*/
+/* 2010/04/25 MH Define the max tx power tracking tx agc power. */
+#define	ODM_TXPWRTRACK_MAX_IDX8188F		6
+
+/* MACRO definition for cali_info->TxIQC_8188F[0] */
+#define 	PATH_S0                         1 /* RF_PATH_B */
+#define     idx_0xc94                       0
+#define     idx_0xc80                       1
+#define     idx_0xc4c                       2
+#define     idx_0xc14                       0
+#define     idx_0xca0                       1
+#define     KEY                             0
+#define     VAL                             1
+
+/* MACRO definition for cali_info->TxIQC_8188F[1] */
+#define 	PATH_S1                         0 /* RF_PATH_A */
+#define     idx_0xc9c                       0
+#define     idx_0xc88                       1
+#define     idx_0xc4c                       2
+#define     idx_0xc1c                       0
+#define     idx_0xc78                       1
+
+
+
+/*---------------------------Define Local Constant---------------------------*/
+
+
+/* 3============================================================
+ * 3 Tx Power Tracking
+ * 3============================================================ */
+
+
+void set_iqk_matrix_8188f(
+	struct dm_struct *dm,
+	s8 OFDM_index,
+	u8 rf_path,
+	s32 iqk_result_x,
+	s32 iqk_result_y
+)
+{
+	s32 ele_A = 0, ele_D, ele_C = 0, value32;
+
+	if (OFDM_index >= OFDM_TABLE_SIZE)
+		OFDM_index = OFDM_TABLE_SIZE - 1;
+	else if (OFDM_index < 0)
+		OFDM_index = 0;
+
+	ele_D = (ofdm_swing_table_new[OFDM_index] & 0xFFC00000) >> 22;
+
+	/* new element A = element D x X */
+	if ((iqk_result_x != 0) && (*(dm->band_type) == ODM_BAND_2_4G)) {
+		if ((iqk_result_x & 0x00000200) != 0)    /* consider minus */
+			iqk_result_x = iqk_result_x | 0xFFFFFC00;
+		ele_A = ((iqk_result_x * ele_D) >> 8) & 0x000003FF;
+
+		/* new element C = element D x Y */
+		if ((iqk_result_y & 0x00000200) != 0)
+			iqk_result_y = iqk_result_y | 0xFFFFFC00;
+		ele_C = ((iqk_result_y * ele_D) >> 8) & 0x000003FF;
+
+		if (rf_path == RF_PATH_A)
+			switch (rf_path) {
+			case RF_PATH_A:
+				/* wirte new elements A, C, D to regC80 and regC94, element B is always 0 */
+				value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
+				odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, value32);
+
+				value32 = (ele_C & 0x000003C0) >> 6;
+				odm_set_bb_reg(dm, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, value32);
+
+				value32 = ((iqk_result_x * ele_D) >> 7) & 0x01;
+				odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), value32);
+				break;
+			case RF_PATH_B:
+				/* wirte new elements A, C, D to regC88 and regC9C, element B is always 0 */
+				value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
+				odm_set_bb_reg(dm, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, value32);
+
+				value32 = (ele_C & 0x000003C0) >> 6;
+				odm_set_bb_reg(dm, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, value32);
+
+				value32 = ((iqk_result_x * ele_D) >> 7) & 0x01;
+				odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), value32);
+
+				break;
+			default:
+				break;
+			}
+	} else {
+		switch (rf_path) {
+		case RF_PATH_A:
+			odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_new[OFDM_index]);
+			odm_set_bb_reg(dm, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, 0x00);
+			odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), 0x00);
+			break;
+
+		case RF_PATH_B:
+			odm_set_bb_reg(dm, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_new[OFDM_index]);
+			odm_set_bb_reg(dm, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, 0x00);
+			odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), 0x00);
+			break;
+
+		default:
+			break;
+		}
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "TxPwrTracking path B: X = 0x%x, Y = 0x%x ele_A = 0x%x ele_C = 0x%x ele_D = 0x%x 0xeb4 = 0x%x 0xebc = 0x%x\n",
+		(u32)iqk_result_x, (u32)iqk_result_y, (u32)ele_A, (u32)ele_C, (u32)ele_D, (u32)iqk_result_x, (u32)iqk_result_y);
+}
+
+void do_iqk_8188f(
+	void *dm_void,
+	u8 delta_thermal_index,
+	u8 thermal_value,
+	u8 threshold
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_reset_iqk_result(dm);
+	dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+	halrf_iqk_trigger(dm, false);
+}
+
+/*-----------------------------------------------------------------------------
+ * Function:	odm_TxPwrTrackSetPwr88E()
+ *
+ * Overview:	88E change all channel tx power accordign to flag.
+ *				OFDM & CCK are all different.
+ *
+ * Input:		NONE
+ *
+ * Output:		NONE
+ *
+ * Return:		NONE
+ *
+ * Revised History:
+ *	When		Who		Remark
+ *	04/23/2012	MHC		Create version 0.
+ *
+ *---------------------------------------------------------------------------*/
+void
+odm_tx_pwr_track_set_pwr_8188f(
+	void *dm_void,
+	enum pwrtrack_method method,
+	u8 rf_path,
+	u8 channel_mapped_index
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	PADAPTER   adapter = (PADAPTER)dm->adapter;
+	//PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	u8 pwr_tracking_limit_ofdm = 32;
+	u8 pwr_tracking_limit_cck = CCK_TABLE_SIZE_88F - 1; /* -2dB */
+	u8 tx_rate = 0xFF;
+	s8 final_ofdm_swing_index = 0;
+	s8 final_cck_swing_index = 0;
+	/*	u8	i = 0; */
+	struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
+
+#if 0
+	struct _hal_rf_	*rf = &(dm->rf_table);
+
+	if (*(dm->mp_mode) == true) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+		PMPT_CONTEXT p_mpt_ctx = &(adapter->mpt_ctx);
+
+		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#ifdef CONFIG_MP_INCLUDED
+		PMPT_CONTEXT p_mpt_ctx = &(adapter->mppriv.mpt_ctx);
+
+		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
+#endif
+#endif
+#endif
+	} else {
+		u16 rate	 = *(dm->forced_data_rate);
+
+		if (!rate) { /*auto rate*/
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			tx_rate = adapter->HalFunc.GetHwRateFromMRateHandler(dm->tx_rate);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+			if (dm->number_linked_client != 0)
+				tx_rate = hw_rate_to_m_rate(dm->tx_rate);
+			else
+				tx_rate = rf->p_rate_index;
+#endif
+		} else	 /*force rate*/
+			tx_rate = (u8)rate;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Power Tracking tx_rate=0x%X\n", tx_rate);
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "===>ODM_TxPwrTrackSetPwr8188F\n");
+
+	if (tx_rate != 0xFF) {
+		/* 2 CCK */
+		if (((tx_rate >= MGN_1M) && (tx_rate <= MGN_5_5M)) || (tx_rate == MGN_11M))
+			pwr_tracking_limit_cck = CCK_TABLE_SIZE_88F - 1; /* -2dB */
+		/* 2 OFDM */
+		else if ((tx_rate >= MGN_6M) && (tx_rate <= MGN_48M))
+			pwr_tracking_limit_ofdm = 36; /* +3dB */
+		else if (tx_rate == MGN_54M)
+			pwr_tracking_limit_ofdm = 34; /* +2dB */
+
+		/* 2 HT */
+		else if ((tx_rate >= MGN_MCS0) && (tx_rate <= MGN_MCS2)) /* QPSK/BPSK */
+			pwr_tracking_limit_ofdm = 38; /* +4dB */
+		else if ((tx_rate >= MGN_MCS3) && (tx_rate <= MGN_MCS4)) /* 16QAM */
+			pwr_tracking_limit_ofdm = 36; /* +3dB */
+		else if ((tx_rate >= MGN_MCS5) && (tx_rate <= MGN_MCS7)) /* 64QAM */
+			pwr_tracking_limit_ofdm = 34; /* +2dB */
+
+		else
+			pwr_tracking_limit_ofdm = cali_info->default_ofdm_index;   /* Default OFDM index = 30 */
+	}
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "tx_rate=0x%x, pwr_tracking_limit=%d\n", tx_rate, pwr_tracking_limit_ofdm);
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "method=%d\n", method);
+
+	if (method == TXAGC) {
+		/* u8	rf = 0; */
+#if (MP_DRIVER == 1)
+		u32 pwr = 0, tx_agc = 0;
+#endif
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "odm_TxPwrTrackSetPwr8188F CH=%d\n", *(dm->channel));
+
+		cali_info->remnant_ofdm_swing_idx[rf_path] = cali_info->absolute_ofdm_swing_idx[rf_path];
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+#if (MP_DRIVER == 1)
+		if ((*(dm->mp_mode)) == 1) {
+			pwr = odm_get_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, MASKBYTE1);
+			pwr += dm->rf_calibrate_info.power_index_offset[RF_PATH_A];
+			odm_set_bb_reg(dm, REG_TX_AGC_A_CCK_1_MCS32, MASKBYTE1, pwr);              /* CCK 1M */
+
+			if (pwr > 0x3F)
+				pwr = 0x3F;            /* add by Mingzhi.Guo 2015-04-10 */
+			else if (pwr <= 0)
+				pwr = 0;
+
+			tx_agc = (pwr << 16) | (pwr << 8) | (pwr);
+
+			odm_set_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0xffffff00, tx_agc);              /* CCK 2~11M */
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ODM_TxPwrTrackSetPwr8188F: CCK Tx-rf(A) Power = 0x%x\n", tx_agc);
+
+			pwr = odm_get_bb_reg(dm, REG_TX_AGC_A_RATE18_06, 0xFF);
+			pwr += (cali_info->bb_swing_idx_ofdm[RF_PATH_A] - cali_info->bb_swing_idx_ofdm_base[RF_PATH_A]);
+			tx_agc |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
+			/*	odm_set_bb_reg(adapter, REG_TX_AGC_A_MCS11_MCS08, MASKDWORD, tx_agc); */
+			/*	odm_set_bb_reg(adapter, REG_TX_AGC_A_MCS15_MCS12, MASKDWORD, tx_agc); */
+			PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ODM_TxPwrTrackSetPwr8188F: OFDM Tx-rf(A) Power = 0x%x\n", tx_agc);
+		} else
+#endif
+		{
+			/* PHY_SetTxPowerLevelByPath8188F(adapter, hal_data->current_channel, RF_PATH_A); */
+			/* PHY_SetTxPowerLevel8188F(dm->adapter, *dm->channel); */
+			cali_info->modify_tx_agc_flag_path_a = true;
+			cali_info->modify_tx_agc_flag_path_a_cck = true;
+
+			if (rf_path == RF_PATH_A) {
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, CCK);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, OFDM);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, HT_MCS0_MCS7);
+			}
+		}
+
+#endif
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+		/* phy_rf6052_set_cck_tx_power(dm->priv, *(dm->channel)); */
+		/* phy_rf6052_set_ofdm_tx_power(dm->priv, *(dm->channel)); */
+#endif
+
+	} else if (method == BBSWING) {
+		final_ofdm_swing_index = cali_info->default_ofdm_index + cali_info->absolute_ofdm_swing_idx[rf_path];
+		final_cck_swing_index = cali_info->default_cck_index + cali_info->absolute_ofdm_swing_idx[rf_path];
+
+		/* Adjust BB swing by OFDM IQ matrix */
+		if (final_ofdm_swing_index >= pwr_tracking_limit_ofdm)
+			final_ofdm_swing_index = pwr_tracking_limit_ofdm;
+		else if (final_ofdm_swing_index <= 0)
+			final_ofdm_swing_index = 0;
+
+		if (final_cck_swing_index >= CCK_TABLE_SIZE_88F)
+			final_cck_swing_index = CCK_TABLE_SIZE_88F - 1;
+		else if ((s8)cali_info->bb_swing_idx_cck < 0)
+			final_cck_swing_index = 0;
+
+		if (rf_path == RF_PATH_A) {
+
+			set_iqk_matrix_8188f(dm, final_ofdm_swing_index, RF_PATH_A,
+				dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+				dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+			if (*dm->channel != 14) {
+				odm_write_1byte(dm, 0xa22, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][0]);
+				odm_write_1byte(dm, 0xa23, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][1]);
+				odm_write_1byte(dm, 0xa24, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][2]);
+				odm_write_1byte(dm, 0xa25, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][3]);
+				odm_write_1byte(dm, 0xa26, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][4]);
+				odm_write_1byte(dm, 0xa27, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][5]);
+				odm_write_1byte(dm, 0xa28, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][6]);
+				odm_write_1byte(dm, 0xa29, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][7]);
+				odm_write_1byte(dm, 0xa9a, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][8]);
+				odm_write_1byte(dm, 0xa9b, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][9]);
+				odm_write_1byte(dm, 0xa9c, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][10]);
+				odm_write_1byte(dm, 0xa9d, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][11]);
+				odm_write_1byte(dm, 0xaa0, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][12]);
+				odm_write_1byte(dm, 0xaa1, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][13]);
+				odm_write_1byte(dm, 0xaa2, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][14]);
+				odm_write_1byte(dm, 0xaa3, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][15]);
+			} else {
+				odm_write_1byte(dm, 0xa22, cck_swing_table_ch14_88f[final_cck_swing_index][0]);
+				odm_write_1byte(dm, 0xa23, cck_swing_table_ch14_88f[final_cck_swing_index][1]);
+				odm_write_1byte(dm, 0xa24, cck_swing_table_ch14_88f[final_cck_swing_index][2]);
+				odm_write_1byte(dm, 0xa25, cck_swing_table_ch14_88f[final_cck_swing_index][3]);
+				odm_write_1byte(dm, 0xa26, cck_swing_table_ch14_88f[final_cck_swing_index][4]);
+				odm_write_1byte(dm, 0xa27, cck_swing_table_ch14_88f[final_cck_swing_index][5]);
+				odm_write_1byte(dm, 0xa28, cck_swing_table_ch14_88f[final_cck_swing_index][6]);
+				odm_write_1byte(dm, 0xa29, cck_swing_table_ch14_88f[final_cck_swing_index][7]);
+				odm_write_1byte(dm, 0xa9a, cck_swing_table_ch14_88f[final_cck_swing_index][8]);
+				odm_write_1byte(dm, 0xa9b, cck_swing_table_ch14_88f[final_cck_swing_index][9]);
+				odm_write_1byte(dm, 0xa9c, cck_swing_table_ch14_88f[final_cck_swing_index][10]);
+				odm_write_1byte(dm, 0xa9d, cck_swing_table_ch14_88f[final_cck_swing_index][11]);
+				odm_write_1byte(dm, 0xaa0, cck_swing_table_ch14_88f[final_cck_swing_index][12]);
+				odm_write_1byte(dm, 0xaa1, cck_swing_table_ch14_88f[final_cck_swing_index][13]);
+				odm_write_1byte(dm, 0xaa2, cck_swing_table_ch14_88f[final_cck_swing_index][14]);
+				odm_write_1byte(dm, 0xaa3, cck_swing_table_ch14_88f[final_cck_swing_index][15]);
+			}
+		}
+
+	} else if (method == MIX_MODE) {
+#if (MP_DRIVER == 1)
+		/* u32 	pwr = 0, tx_agc = 0; */
+		u32	tx_agc = 0;            /* add by Mingzhi.Guo 2015-04-10 */
+		s32    pwr = 0;
+		/* s32	pwr_down_up = 0; */
+#endif
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "method is MIX_MODE ====>\n");
+		PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "cali_info->default_ofdm_index=%d,  cali_info->DefaultCCKIndex=%d, cali_info->absolute_ofdm_swing_idx[rf_path]=%d, rf_path = %d\n",
+			cali_info->default_ofdm_index, cali_info->default_cck_index, cali_info->absolute_ofdm_swing_idx[rf_path], rf_path);
+
+		final_ofdm_swing_index = cali_info->default_ofdm_index + cali_info->absolute_ofdm_swing_idx[rf_path];
+		final_cck_swing_index = cali_info->default_cck_index + cali_info->absolute_ofdm_swing_idx[rf_path];
+		if (rf_path == RF_PATH_A) {
+			if (final_ofdm_swing_index > pwr_tracking_limit_ofdm) {     /* BBSwing higher then Limit */
+				cali_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index - pwr_tracking_limit_ofdm;
+
+				set_iqk_matrix_8188f(dm, pwr_tracking_limit_ofdm, rf_path,
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+
+				cali_info->modify_tx_agc_flag_path_a = true;
+
+				/* Set tx_agc Page C{}; */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Path_A Over BBSwing Limit, pwr_tracking_limit = %d, Remnant tx_agc value = %d\n",
+					pwr_tracking_limit_ofdm, cali_info->remnant_ofdm_swing_idx[rf_path]);
+			} else if (final_ofdm_swing_index < cali_info->default_ofdm_index) {
+				cali_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index - cali_info->default_ofdm_index;
+				set_iqk_matrix_8188f(dm, cali_info->default_ofdm_index, RF_PATH_A,
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+
+				cali_info->modify_tx_agc_flag_path_a = true;
+				/* Set tx_agc Page C{}; */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Path_A Lower then BBSwing lower bound  28, Remnant tx_agc value = %d\n",
+					cali_info->remnant_ofdm_swing_idx[rf_path]);
+			}
+
+#if 0
+			else if (final_ofdm_swing_index < 0) {
+				cali_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index ;
+				set_iqk_matrix_8188f(dm, 0, RF_PATH_A,
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+
+				cali_info->modify_tx_agc_flag_path_a = true;
+				/* Set tx_agc Page C{}; */
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,
+					"******Path_A Lower then BBSwing lower bound  0, Remnant tx_agc value = %d\n",
+					cali_info->remnant_ofdm_swing_idx[rf_path]);
+			}
+#endif
+			else {
+				set_iqk_matrix_8188f(dm, final_ofdm_swing_index, RF_PATH_A,
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+					dm->rf_calibrate_info.iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK,"******Path_A Compensate with BBSwing, final_ofdm_swing_index = %d\n", final_ofdm_swing_index);
+
+				if (cali_info->modify_tx_agc_flag_path_a)    /* If tx_agc has changed, reset tx_agc again */
+					cali_info->remnant_ofdm_swing_idx[rf_path] = 0;
+			}
+#if (MP_DRIVER == 1) && (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+			if ((*(dm->mp_mode)) == 1) {
+				pwr = odm_get_bb_reg(dm, REG_TX_AGC_A_RATE18_06, 0xFF);
+				/* pwr_down_up = (cali_info->remnant_ofdm_swing_idx[RF_PATH_A] - cali_info->modify_tx_agc_value_ofdm); */
+				pwr += (cali_info->remnant_ofdm_swing_idx[RF_PATH_A] - cali_info->modify_tx_agc_value_ofdm);
+
+				if (pwr > 0x3F)
+					pwr = 0x3F;             /* add by Mingzhi.Guo 2015-04-10 */
+				else if (pwr < 0)
+					pwr = 0;
+				
+				#if 0
+				if (pwr == 0x32 || pwr == 0x33) {	/*8188F TXAGC skip index 32&33 to avoid bad TX EVM, suggested  by RF_Jayden*/
+					if (pwr_down_up >= 0)
+						pwr = 0x34; 
+					else
+						pwr = 0x31;
+				}
+				#endif
+				
+				tx_agc |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
+				/* odm_set_bb_reg(dm, REG_TX_AGC_A_MCS11_MCS08, MASKDWORD, tx_agc); */
+				/* odm_set_bb_reg(dm, REG_TX_AGC_A_MCS15_MCS12, MASKDWORD, tx_agc); */
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ODM_TxPwrTrackSetPwr8188F: OFDM Tx-rf(A) Power = 0x%x\n", tx_agc);
+
+
+			} else
+#endif
+			{
+				/* Set tx_agc Page C{}; */
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, OFDM);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, HT_MCS0_MCS7);
+			}
+			cali_info->modify_tx_agc_value_ofdm = cali_info->remnant_ofdm_swing_idx[RF_PATH_A] ;      /* add by Mingzhi.Guo */
+
+
+			/* MIX mode: CCK */
+			if (final_cck_swing_index > pwr_tracking_limit_cck) {
+				cali_info->remnant_cck_swing_idx = final_cck_swing_index - pwr_tracking_limit_cck;
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "******Path_A CCK Over Limit, pwr_tracking_limit_cck = %d, cali_info->remnant_cck_swing_idx  = %d\n", pwr_tracking_limit_cck, cali_info->remnant_cck_swing_idx);
+				if (*dm->channel != 14) {
+					odm_write_1byte(dm, 0xa22, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][0]);
+					odm_write_1byte(dm, 0xa23, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][1]);
+					odm_write_1byte(dm, 0xa24, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][2]);
+					odm_write_1byte(dm, 0xa25, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][3]);
+					odm_write_1byte(dm, 0xa26, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][4]);
+					odm_write_1byte(dm, 0xa27, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][5]);
+					odm_write_1byte(dm, 0xa28, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][6]);
+					odm_write_1byte(dm, 0xa29, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][7]);
+					odm_write_1byte(dm, 0xa9a, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][8]);
+					odm_write_1byte(dm, 0xa9b, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][9]);
+					odm_write_1byte(dm, 0xa9c, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][10]);
+					odm_write_1byte(dm, 0xa9d, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][11]);
+					odm_write_1byte(dm, 0xaa0, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][12]);
+					odm_write_1byte(dm, 0xaa1, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][13]);
+					odm_write_1byte(dm, 0xaa2, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][14]);
+					odm_write_1byte(dm, 0xaa3, cck_swing_table_ch1_ch13_88f[pwr_tracking_limit_cck][15]);
+				} else {
+					odm_write_1byte(dm, 0xa22, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][0]);
+					odm_write_1byte(dm, 0xa23, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][1]);
+					odm_write_1byte(dm, 0xa24, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][2]);
+					odm_write_1byte(dm, 0xa25, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][3]);
+					odm_write_1byte(dm, 0xa26, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][4]);
+					odm_write_1byte(dm, 0xa27, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][5]);
+					odm_write_1byte(dm, 0xa28, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][6]);
+					odm_write_1byte(dm, 0xa29, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][7]);
+					odm_write_1byte(dm, 0xa9a, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][8]);
+					odm_write_1byte(dm, 0xa9b, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][9]);
+					odm_write_1byte(dm, 0xa9c, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][10]);
+					odm_write_1byte(dm, 0xa9d, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][11]);
+					odm_write_1byte(dm, 0xaa0, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][12]);
+					odm_write_1byte(dm, 0xaa1, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][13]);
+					odm_write_1byte(dm, 0xaa2, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][14]);
+					odm_write_1byte(dm, 0xaa3, cck_swing_table_ch14_88f[pwr_tracking_limit_cck][15]);
+				}
+
+				cali_info->modify_tx_agc_flag_path_a_cck = true;
+
+			} else if (final_cck_swing_index < 0) { /* Lowest CCK index = 0 */
+				cali_info->remnant_cck_swing_idx = final_cck_swing_index;
+
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "******Path_A CCK Under Limit, pwr_tracking_limit_cck = %d, cali_info->remnant_cck_swing_idx  = %d\n", 0, cali_info->remnant_cck_swing_idx);
+				if (*dm->channel != 14) {
+					odm_write_1byte(dm, 0xa22, cck_swing_table_ch1_ch13_88f[0][0]);
+					odm_write_1byte(dm, 0xa23, cck_swing_table_ch1_ch13_88f[0][1]);
+					odm_write_1byte(dm, 0xa24, cck_swing_table_ch1_ch13_88f[0][2]);
+					odm_write_1byte(dm, 0xa25, cck_swing_table_ch1_ch13_88f[0][3]);
+					odm_write_1byte(dm, 0xa26, cck_swing_table_ch1_ch13_88f[0][4]);
+					odm_write_1byte(dm, 0xa27, cck_swing_table_ch1_ch13_88f[0][5]);
+					odm_write_1byte(dm, 0xa28, cck_swing_table_ch1_ch13_88f[0][6]);
+					odm_write_1byte(dm, 0xa29, cck_swing_table_ch1_ch13_88f[0][7]);
+					odm_write_1byte(dm, 0xa9a, cck_swing_table_ch1_ch13_88f[0][8]);
+					odm_write_1byte(dm, 0xa9b, cck_swing_table_ch1_ch13_88f[0][9]);
+					odm_write_1byte(dm, 0xa9c, cck_swing_table_ch1_ch13_88f[0][10]);
+					odm_write_1byte(dm, 0xa9d, cck_swing_table_ch1_ch13_88f[0][11]);
+					odm_write_1byte(dm, 0xaa0, cck_swing_table_ch1_ch13_88f[0][12]);
+					odm_write_1byte(dm, 0xaa1, cck_swing_table_ch1_ch13_88f[0][13]);
+					odm_write_1byte(dm, 0xaa2, cck_swing_table_ch1_ch13_88f[0][14]);
+					odm_write_1byte(dm, 0xaa3, cck_swing_table_ch1_ch13_88f[0][15]);
+				} else {
+					odm_write_1byte(dm, 0xa22, cck_swing_table_ch14_88f[0][0]);
+					odm_write_1byte(dm, 0xa23, cck_swing_table_ch14_88f[0][1]);
+					odm_write_1byte(dm, 0xa24, cck_swing_table_ch14_88f[0][2]);
+					odm_write_1byte(dm, 0xa25, cck_swing_table_ch14_88f[0][3]);
+					odm_write_1byte(dm, 0xa26, cck_swing_table_ch14_88f[0][4]);
+					odm_write_1byte(dm, 0xa27, cck_swing_table_ch14_88f[0][5]);
+					odm_write_1byte(dm, 0xa28, cck_swing_table_ch14_88f[0][6]);
+					odm_write_1byte(dm, 0xa29, cck_swing_table_ch14_88f[0][7]);
+					odm_write_1byte(dm, 0xa9a, cck_swing_table_ch14_88f[0][8]);
+					odm_write_1byte(dm, 0xa9b, cck_swing_table_ch14_88f[0][9]);
+					odm_write_1byte(dm, 0xa9c, cck_swing_table_ch14_88f[0][10]);
+					odm_write_1byte(dm, 0xa9d, cck_swing_table_ch14_88f[0][11]);
+					odm_write_1byte(dm, 0xaa0, cck_swing_table_ch14_88f[0][12]);
+					odm_write_1byte(dm, 0xaa1, cck_swing_table_ch14_88f[0][13]);
+					odm_write_1byte(dm, 0xaa2, cck_swing_table_ch14_88f[0][14]);
+					odm_write_1byte(dm, 0xaa3, cck_swing_table_ch14_88f[0][15]);
+				}
+				cali_info->modify_tx_agc_flag_path_a_cck = true;
+
+			}
+
+			else {
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "******Path_A CCK Compensate with BBSwing, final_cck_swing_index = %d\n", final_cck_swing_index);
+				if (*dm->channel != 14) {
+					odm_write_1byte(dm, 0xa22, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][0]);
+					odm_write_1byte(dm, 0xa23, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][1]);
+					odm_write_1byte(dm, 0xa24, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][2]);
+					odm_write_1byte(dm, 0xa25, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][3]);
+					odm_write_1byte(dm, 0xa26, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][4]);
+					odm_write_1byte(dm, 0xa27, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][5]);
+					odm_write_1byte(dm, 0xa28, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][6]);
+					odm_write_1byte(dm, 0xa29, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][7]);
+					odm_write_1byte(dm, 0xa9a, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][8]);
+					odm_write_1byte(dm, 0xa9b, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][9]);
+					odm_write_1byte(dm, 0xa9c, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][10]);
+					odm_write_1byte(dm, 0xa9d, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][11]);
+					odm_write_1byte(dm, 0xaa0, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][12]);
+					odm_write_1byte(dm, 0xaa1, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][13]);
+					odm_write_1byte(dm, 0xaa2, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][14]);
+					odm_write_1byte(dm, 0xaa3, cck_swing_table_ch1_ch13_88f[final_cck_swing_index][15]);
+				} else {
+					odm_write_1byte(dm, 0xa22, cck_swing_table_ch14_88f[final_cck_swing_index][0]);
+					odm_write_1byte(dm, 0xa23, cck_swing_table_ch14_88f[final_cck_swing_index][1]);
+					odm_write_1byte(dm, 0xa24, cck_swing_table_ch14_88f[final_cck_swing_index][2]);
+					odm_write_1byte(dm, 0xa25, cck_swing_table_ch14_88f[final_cck_swing_index][3]);
+					odm_write_1byte(dm, 0xa26, cck_swing_table_ch14_88f[final_cck_swing_index][4]);
+					odm_write_1byte(dm, 0xa27, cck_swing_table_ch14_88f[final_cck_swing_index][5]);
+					odm_write_1byte(dm, 0xa28, cck_swing_table_ch14_88f[final_cck_swing_index][6]);
+					odm_write_1byte(dm, 0xa29, cck_swing_table_ch14_88f[final_cck_swing_index][7]);
+					odm_write_1byte(dm, 0xa9a, cck_swing_table_ch14_88f[final_cck_swing_index][8]);
+					odm_write_1byte(dm, 0xa9b, cck_swing_table_ch14_88f[final_cck_swing_index][9]);
+					odm_write_1byte(dm, 0xa9c, cck_swing_table_ch14_88f[final_cck_swing_index][10]);
+					odm_write_1byte(dm, 0xa9d, cck_swing_table_ch14_88f[final_cck_swing_index][11]);
+					odm_write_1byte(dm, 0xaa0, cck_swing_table_ch14_88f[final_cck_swing_index][12]);
+					odm_write_1byte(dm, 0xaa1, cck_swing_table_ch14_88f[final_cck_swing_index][13]);
+					odm_write_1byte(dm, 0xaa2, cck_swing_table_ch14_88f[final_cck_swing_index][14]);
+					odm_write_1byte(dm, 0xaa3, cck_swing_table_ch14_88f[final_cck_swing_index][15]);
+				}
+
+				cali_info->modify_tx_agc_flag_path_a_cck = false;
+				cali_info->remnant_cck_swing_idx = 0;
+
+			}
+#if (MP_DRIVER == 1) && (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+			if ((*(dm->mp_mode)) == 1) {
+				pwr = odm_get_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, MASKBYTE1);
+				pwr += cali_info->remnant_cck_swing_idx - cali_info->modify_tx_agc_value_cck;
+
+				if (pwr > 0x3F)
+					pwr = 0x3F;             /* add by Mingzhi.Guo 2015-04-10 */
+				else if (pwr < 0)
+					pwr = 0;
+
+				odm_set_bb_reg(dm, REG_TX_AGC_A_CCK_1_MCS32, MASKBYTE1, pwr);              /* CCK 1M */
+				tx_agc = (pwr << 16) | (pwr << 8) | (pwr);
+				odm_set_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0xffffff00, tx_agc);              /* CCK 2~11M */
+				PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "ODM_TxPwrTrackSetPwr8188F: CCK Tx-rf(A) Power = 0x%x\n", tx_agc);
+			} else
+#endif
+			{
+				/* Set tx_agc Page C{}; */
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, CCK);
+			}
+			cali_info->modify_tx_agc_value_cck = cali_info->remnant_cck_swing_idx;
+
+		}
+	} else
+		return;
+} /* odm_TxPwrTrackSetPwr8188F */
+
+
+void
+get_delta_swing_table_8188f(
+	void *dm_void,
+	u8 **temperature_up_a,
+	u8 **temperature_down_a,
+	u8 **temperature_up_b,
+	u8 **temperature_down_b
+)
+{
+	struct dm_struct			*dm	= (struct dm_struct *)dm_void;
+	struct _ADAPTER *adapter		= (PADAPTER)dm->adapter;
+	struct dm_rf_calibration_struct		*cali_info = &(dm->rf_calibrate_info);
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	u8				tx_rate			= 0xFF;
+	u8				channel			= *dm->channel;
+
+	if (*(dm->mp_mode) == true) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+		PMPT_CONTEXT p_mpt_ctx = &(adapter->MptCtx);
+
+		tx_rate = MptToMgntRate(p_mpt_ctx->MptRateIndex);
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#ifdef CONFIG_MP_INCLUDED
+		PMPT_CONTEXT p_mpt_ctx = &(adapter->mppriv.mpt_ctx);
+
+		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
+#endif
+#endif
+#endif
+	} else {
+		u16	rate	 = *(dm->forced_data_rate);
+
+		if (!rate) { /*auto rate*/
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			tx_rate = adapter->HalFunc.GetHwRateFromMRateHandler(dm->tx_rate);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+			if (dm->number_linked_client != 0)
+				tx_rate = hw_rate_to_m_rate(dm->tx_rate);
+			else
+				tx_rate = rf->p_rate_index;
+#endif
+		} else   /*force rate*/
+			tx_rate = (u8)rate;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "Power Tracking tx_rate=0x%X\n", tx_rate);
+
+
+	PHYDM_DBG(dm, ODM_COMP_TX_PWR_TRACK, "get_delta_swing_table_8188f ====> channel is %d\n", channel);
+
+	if (1 <= channel && channel <= 14) {
+		if (IS_CCK_RATE(tx_rate)) {
+			*temperature_up_a = cali_info->delta_swing_table_idx_2g_cck_a_p;
+			*temperature_down_a = cali_info->delta_swing_table_idx_2g_cck_a_n;
+			*temperature_up_b = cali_info->delta_swing_table_idx_2g_cck_b_p;
+			*temperature_down_b = cali_info->delta_swing_table_idx_2g_cck_b_n;
+		} else {
+			*temperature_up_a = cali_info->delta_swing_table_idx_2ga_p;
+			*temperature_down_a = cali_info->delta_swing_table_idx_2ga_n;
+			*temperature_up_b = cali_info->delta_swing_table_idx_2gb_p;
+			*temperature_down_b = cali_info->delta_swing_table_idx_2gb_n;
+		}
+	} else {
+		*temperature_up_a = (u8 *)delta_swing_table_idx_2ga_p_8188e;
+		*temperature_down_a = (u8 *)delta_swing_table_idx_2ga_n_8188e;
+		*temperature_up_b = (u8 *)delta_swing_table_idx_2ga_p_8188e;
+		*temperature_down_b = (u8 *)delta_swing_table_idx_2ga_n_8188e;
+	}
+
+	return;
+}
+
+
+void configure_txpower_track_8188f(
+	struct txpwrtrack_cfg *config
+)
+{
+	config->swing_table_size_cck = CCK_TABLE_SIZE_88F;
+	config->swing_table_size_ofdm = OFDM_TABLE_SIZE;
+	config->threshold_iqk = IQK_THRESHOLD;
+	config->average_thermal_num = AVG_THERMAL_NUM_8188F;
+	config->rf_path_count = MAX_PATH_NUM_8188F;
+	config->thermal_reg_addr = RF_T_METER_8188F;
+
+	config->odm_tx_pwr_track_set_pwr = odm_tx_pwr_track_set_pwr_8188f;
+	config->do_iqk = do_iqk_8188f;
+	config->phy_lc_calibrate = halrf_lck_trigger;
+	config->get_delta_swing_table = get_delta_swing_table_8188f;
+}
+
+/* 1 7.	IQK */
+#define MAX_TOLERANCE		5
+#define IQK_DELAY_TIME		1		/* ms */
+
+u8          /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
+phy_path_a_iqk_8188f(
+	struct dm_struct *dm,
+	boolean config_path_b
+)
+{
+	u32 reg_eac, reg_e94, reg_e9c/*, reg_ea4*/;
+	u8 result = 0x00;
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A IQK!\n");
+
+	/* enable path A PA in TXIQK mode */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x20000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0000f);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0x07ff7);   /* 0x07f77 */
+	/* PA,PAD gain adjust */
+	odm_set_rf_reg(dm, RF_PATH_A, 0xdf, RFREGOFFSETMASK, 0x980);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x56, RFREGOFFSETMASK, 0x5102a); /* 0x5111e0 */
+
+
+	/* enter IQK mode */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
+
+
+	/* 1 Tx IQK */
+	/* path-A IQK setting
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "path-A IQK setting!\n"); */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x18008c1c);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x821403ff);    /* 0x821403e0 */
+	odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28160000);
+
+	/* LO calibration setting
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "LO calibration setting!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x00462911);
+
+	/* One shot, path A LOK & IQK
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "One shot, path A LOK & IQK!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+
+	/* delay x ms
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F);
+	* platform_stall_execution(IQK_DELAY_TIME_8188F*1000); */
+	ODM_delay_ms(IQK_DELAY_TIME_8188F);
+
+	/* reload RF 0xdf */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, 0xdf, RFREGOFFSETMASK, 0x180);
+
+	/* save LOK result */
+	dm->rf_calibrate_info.lok_result = odm_get_rf_reg(dm, RF_PATH_A, 0x8, RFREGOFFSETMASK);
+
+	/* Check failed */
+	reg_eac = odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
+	reg_e94 = odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD);
+	reg_e9c = odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeac = 0x%x\n", reg_eac);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe94 = 0x%x, 0xe9c = 0x%x\n", reg_e94, reg_e9c);
+	/* monitor image power before & after IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
+		odm_get_bb_reg(dm, 0xe90, MASKDWORD), odm_get_bb_reg(dm, 0xe98, MASKDWORD));
+
+	if (!(reg_eac & BIT(28)) &&
+	    (((reg_e94 & 0x03FF0000) >> 16) != 0x142) &&
+	    (((reg_e9c & 0x03FF0000) >> 16) != 0x42))
+		result |= 0x01;
+
+	return result;
+}
+
+u8          /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
+phy_path_a_rx_iqk_8188f(
+	struct dm_struct *dm,
+	boolean config_path_b
+)
+{
+	u32 reg_eac, reg_e94, reg_e9c, reg_ea4, u4tmp;
+	u8 result = 0x00;
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A Rx IQK!\n");
+
+	/* 1 Get TXIMR setting */
+	/* modify RXIQK mode table
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "path-A Rx IQK modify RXIQK mode table!\n"); */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x30000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0000f);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0xf1173);   /* 0xf117b */
+
+	/* PA,PAD gain adjust */
+	odm_set_rf_reg(dm, RF_PATH_A, 0xdf, RFREGOFFSETMASK, 0x980);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x56, RFREGOFFSETMASK, 0x5102a); /* 0x510f0 */
+
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
+
+	/* IQK setting */
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+
+	/* path-A IQK setting */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x10008c1c);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x30008c1c);
+	odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82160fff);    /* 0x821603e0 */
+	odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28160000);
+
+	/* LO calibration setting
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "LO calibration setting!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x00462911);
+
+	/* One shot, path A LOK & IQK
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "One shot, path A LOK & IQK!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+
+	/* delay x ms
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F);
+	* platform_stall_execution(IQK_DELAY_TIME_8188F*1000); */
+	ODM_delay_ms(IQK_DELAY_TIME_8188F);
+
+
+	/* reload RF 0xdf */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, 0xdf, RFREGOFFSETMASK, 0x180);
+
+
+
+	/* Check failed */
+	reg_eac = odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
+	reg_e94 = odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD);
+	reg_e9c = odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeac = 0x%x\n", reg_eac);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe94 = 0x%x, 0xe9c = 0x%x\n", reg_e94, reg_e9c);
+	/* monitor image power before & after IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
+		odm_get_bb_reg(dm, 0xe90, MASKDWORD), odm_get_bb_reg(dm, 0xe98, MASKDWORD));
+
+	if (!(reg_eac & BIT(28)) &&
+	    (((reg_e94 & 0x03FF0000) >> 16) != 0x142) &&
+	    (((reg_e9c & 0x03FF0000) >> 16) != 0x42))
+		result |= 0x01;
+	else                            /* if Tx not OK, ignore Rx */
+		return result;
+
+	u4tmp = 0x80007C00 | (reg_e94 & 0x3FF0000) | ((reg_e9c & 0x3FF0000) >> 16);
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, u4tmp);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe40 = 0x%x u4tmp = 0x%x\n", odm_get_bb_reg(dm, REG_TX_IQK, MASKDWORD), u4tmp);
+
+
+	/* 1 RX IQK */
+	/* modify RXIQK mode table
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "path-A Rx IQK modify RXIQK mode table 2!\n"); */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);                 /* 0xEF[19]   = 0x1 */
+	odm_set_rf_reg(dm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x30000);  /* 0x30[19:0] = 0x18000 */
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0000f); /* 0x31[19:0] = 0x0000f */
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0xf7ff2); /* 0x32[19:0] = 0xf7ffa */
+
+	/* PA,PAD gain adjust */
+	odm_set_rf_reg(dm, RF_PATH_A, 0xdf, RFREGOFFSETMASK, 0x980);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x56, RFREGOFFSETMASK, 0x51000); /* 0x51000 */
+
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
+
+	/* IQK setting */
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+
+	/* path-A IQK setting */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x30008c1c);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x10008c1c);
+	odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82160000);
+	odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x281613ff);    /* 0x281603e0 */
+
+
+	/* LO calibration setting
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "LO calibration setting!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a911);
+
+	/* One shot, path A LOK & IQK
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "One shot, path A LOK & IQK!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+
+	/* delay x ms
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F);
+	* platform_stall_execution(IQK_DELAY_TIME_8188F*1000); */
+	ODM_delay_ms(IQK_DELAY_TIME_8188F);
+
+	/* reload RF 0xdf */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, 0xdf, RFREGOFFSETMASK, 0x180);
+
+	/* reload LOK value */
+	odm_set_rf_reg(dm, RF_PATH_A, 0x8, RFREGOFFSETMASK, dm->rf_calibrate_info.lok_result);
+
+	/* Check failed */
+	reg_eac = odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
+	reg_ea4 = odm_get_bb_reg(dm, REG_RX_POWER_BEFORE_IQK_A_2, MASKDWORD);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeac = 0x%x\n", reg_eac);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xea4 = 0x%x, 0xeac = 0x%x\n", reg_ea4, reg_eac);
+	/* monitor image power before & after IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xea0(before IQK)= 0x%x, 0xea8(afer IQK) = 0x%x\n",
+		odm_get_bb_reg(dm, 0xea0, MASKDWORD), odm_get_bb_reg(dm, 0xea8, MASKDWORD));
+
+
+	if (!(reg_eac & BIT(27)) &&     /* if Tx is OK, check whether Rx is OK */
+	    (((reg_ea4 & 0x03FF0000) >> 16) != 0x132) &&
+	    (((reg_eac & 0x03FF0000) >> 16) != 0x36))
+		result |= 0x02;
+	else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A Rx IQK fail!!\n");
+
+	return result;
+
+
+}
+
+
+#if 0
+u8              /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
+phy_path_b_iqk_8188f(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct *dm
+#else
+	void *adapter
+#endif
+)
+{
+	u32 reg_eac, reg_e94, reg_e9c/*, reg_ec4, reg_ecc*/;
+	u8 result = 0x00;
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct *dm = &hal_data->odmpriv;
+#endif
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+#endif
+#endif
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B IQK!\n");
+
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	/* switch to path B */
+	odm_set_bb_reg(dm, 0x948, MASKDWORD, 0x00000080);
+	odm_set_rf_reg(dm, RF_PATH_A, 0xb0, RFREGOFFSETMASK, 0xefff0);
+	/* in TXIQK mode
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, RFREGOFFSETMASK, 0x800a0 );
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x20000 );
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0003f );
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0xc7f87 );
+	* enable path B PA in TXIQK mode
+	*	odm_set_rf_reg(dm, RF_PATH_A, 0xed, RFREGOFFSETMASK, 0x00020 );
+	*	odm_set_rf_reg(dm, RF_PATH_A, 0x43, RFREGOFFSETMASK, 0x40fc1 ); */
+
+
+	/* 1 Tx IQK */
+	/* path-A IQK setting
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "path-B IQK setting!\n"); */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x18008c1c);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82140102);
+	odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28160000);
+
+	/* LO calibration setting
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "LO calibration setting!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x00462911);
+
+
+	/* enter IQK mode */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
+
+	/* One shot, path B LOK & IQK
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "One shot, path B LOK & IQK!\n"); */
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+
+	/* delay x ms
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "delay %d ms for One shot, path B LOK & IQK.\n", IQK_DELAY_TIME_8188F);
+	* platform_stall_execution(IQK_DELAY_TIME_8188F*1000); */
+	ODM_delay_ms(IQK_DELAY_TIME_8188F);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0x948 = 0x%x\n", odm_get_bb_reg(dm, 0x948, MASKDWORD));
+
+
+	/* Check failed */
+	reg_eac = odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
+	reg_e94 = odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD);
+	reg_e9c = odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeac = 0x%x\n", reg_eac);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe94 = 0x%x, 0xe9c = 0x%x\n", reg_e94, reg_e9c);
+	/* monitor image power before & after IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
+		odm_get_bb_reg(dm, 0xe90, MASKDWORD), odm_get_bb_reg(dm, 0xe98, MASKDWORD));
+
+
+	if (!(reg_eac & BIT(28)) &&
+	    (((reg_e94 & 0x03FF0000) >> 16) != 0x142) &&
+	    (((reg_e9c & 0x03FF0000) >> 16) != 0x42))
+		result |= 0x01;
+	else
+		return result;
+#if 0
+	if (!(reg_eac & BIT(30)) &&
+	    (((reg_ec4 & 0x03FF0000) >> 16) != 0x132) &&
+	    (((reg_ecc & 0x03FF0000) >> 16) != 0x36))
+		result |= 0x02;
+	else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B Rx IQK fail!!\n");
+
+#endif
+	return result;
+}
+
+
+
+u8          /* bit0 = 1 => Tx OK, bit1 = 1 => Rx OK */
+phy_path_b_rx_iqk_8188f(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct *dm,
+#else
+	void *adapter,
+#endif
+	boolean config_path_b
+)
+{
+	u32 reg_eac, reg_eb4, reg_ebc, reg_ecc, reg_ec4, u4tmp;
+	u8 result = 0x00;
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct *dm = &hal_data->odmpriv;
+#endif
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+#endif
+#endif
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B Rx IQK!\n");
+
+	/* 1 Get TXIMR setting */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "Get RXIQK TXIMR!\n");
+	/* modify RXIQK mode table
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "path-A Rx IQK modify RXIQK mode table!\n");
+	*	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, RFREGOFFSETMASK, 0x800a0 );
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x30000 );
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0000f );
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0xf117B );
+	*	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000); */
+
+	/* IQK setting */
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x81004800);
+
+	/* path-B IQK setting */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_B, MASKDWORD, 0x10008c1c);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_B, MASKDWORD, 0x30008c1c);
+	odm_set_bb_reg(dm, REG_TX_IQK_PI_B, MASKDWORD, 0x82130804);
+	odm_set_bb_reg(dm, REG_RX_IQK_PI_B, MASKDWORD, 0x68130000);
+
+	/* LO calibration setting */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "LO calibration setting!\n");
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a911);
+
+	/* One shot, path B LOK & IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "One shot, path B LOK & IQK!\n");
+	odm_set_bb_reg(dm, REG_IQK_AGC_CONT, MASKDWORD, 0x00000002);
+	odm_set_bb_reg(dm, REG_IQK_AGC_CONT, MASKDWORD, 0x00000000);
+
+	/* delay x ms */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F);
+	/* platform_stall_execution(IQK_DELAY_TIME_8188F*1000); */
+	ODM_delay_ms(IQK_DELAY_TIME_8188F);
+
+
+	/* Check failed */
+	reg_eac = odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
+	reg_eb4 = odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_B, MASKDWORD);
+	reg_ebc = odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_B, MASKDWORD);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeac = 0x%x\n", reg_eac);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeb4 = 0x%x, 0xebc = 0x%x\n", reg_eb4, reg_ebc);
+	/* monitor image power before & after IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeb0(before IQK)= 0x%x, 0xeb8(afer IQK) = 0x%x\n",
+		odm_get_bb_reg(dm, 0xeb0, MASKDWORD), odm_get_bb_reg(dm, 0xeb8, MASKDWORD));
+
+
+	if (!(reg_eac & BIT(31)) &&
+	    (((reg_eb4 & 0x03FF0000) >> 16) != 0x142) &&
+	    (((reg_ebc & 0x03FF0000) >> 16) != 0x42))
+		result |= 0x01;
+	else                            /* if Tx not OK, ignore Rx */
+		return result;
+
+	u4tmp = 0x80007C00 | (reg_eb4 & 0x3FF0000) | ((reg_ebc & 0x3FF0000) >> 16);
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, u4tmp);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xe40 = 0x%x u4tmp = 0x%x\n", odm_get_bb_reg(dm, REG_TX_IQK, MASKDWORD), u4tmp);
+
+
+	/* 1 RX IQK */
+	/* modify RXIQK mode table
+	* 	PHYDM_DBG(dm,ODM_COMP_CALIBRATION, "path-A Rx IQK modify RXIQK mode table 2!\n");
+	*	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	*	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, RFREGOFFSETMASK, 0x800a0 ); */
+
+	/* <20121009, Kordan> RF mode = 3
+	* odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);	                */ /* 0xEF[19]   = 0x1
+* odm_set_rf_reg(dm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x18000 );   */ /* 0x30[19:0] = 0x18000
+* odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0000f );  */ /* 0x31[19:0] = 0x0000f
+* odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0xf7ffa );  */ /* 0x32[19:0] = 0xf7ffa
+* odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);	                */ /* 0xEF[19]   = 0x0
+*	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000); */
+
+	/* IQK setting */
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+
+	/* path-B IQK setting */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_B, MASKDWORD, 0x30008c1c);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_B, MASKDWORD, 0x10008c1c);
+	odm_set_bb_reg(dm, REG_TX_IQK_PI_B, MASKDWORD, 0x82130c05);
+	odm_set_bb_reg(dm, REG_RX_IQK_PI_B, MASKDWORD, 0x68130c05);
+
+	/* LO calibration setting */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "LO calibration setting!\n");
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a911);
+
+	/* One shot, path B LOK & IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "One shot, path B LOK & IQK!\n");
+	odm_set_bb_reg(dm, REG_IQK_AGC_CONT, MASKDWORD, 0x00000002);
+	odm_set_bb_reg(dm, REG_IQK_AGC_CONT, MASKDWORD, 0x00000000);
+
+	/* delay x ms */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F);
+	/* platform_stall_execution(IQK_DELAY_TIME_8188F*1000); */
+	ODM_delay_ms(IQK_DELAY_TIME_8188F);
+
+	/* Check failed */
+	reg_eac = odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
+	reg_ec4 = odm_get_bb_reg(dm, REG_RX_POWER_BEFORE_IQK_B_2, MASKDWORD);;
+	reg_ecc = odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_B_2, MASKDWORD);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xeac = 0x%x\n", reg_eac);
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xec4 = 0x%x, 0xecc = 0x%x\n", reg_ec4, reg_ecc);
+	/* monitor image power before & after IQK */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "0xec0(before IQK)= 0x%x, 0xec8(afer IQK) = 0x%x\n",
+		odm_get_bb_reg(dm, 0xec0, MASKDWORD), odm_get_bb_reg(dm, 0xec8, MASKDWORD));
+
+	/*	PA/PAD controlled by 0x0 */
+	/* leave IQK mode
+	*	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	*	odm_set_rf_reg(dm, RF_PATH_B, 0xdf, RFREGOFFSETMASK, 0x180 ); */
+
+
+
+#if 0
+	if (!(reg_eac & BIT(31)) &&
+	    (((reg_eb4 & 0x03FF0000) >> 16) != 0x142) &&
+	    (((reg_ebc & 0x03FF0000) >> 16) != 0x42))
+		result |= 0x01;
+	else                            /* if Tx not OK, ignore Rx */
+		return result;
+#endif
+
+	if (!(reg_eac & BIT(30)) &&     /* if Tx is OK, check whether Rx is OK */
+	    (((reg_ec4 & 0x03FF0000) >> 16) != 0x132) &&
+	    (((reg_ecc & 0x03FF0000) >> 16) != 0x36))
+		result |= 0x02;
+	else
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B Rx IQK fail!!\n");
+
+	return result;
+}
+#endif
+
+
+void
+_phy_path_a_fill_iqk_matrix8188f(
+	struct dm_struct *dm,
+	boolean is_iqk_ok,
+	s32 result[][8],
+	u8 final_candidate,
+	boolean is_tx_only
+)
+{
+	u32 oldval_0, X, TX0_A, reg;
+	s32 Y, TX0_C;
+	struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A IQ Calibration %s !\n", (is_iqk_ok) ? "Success" : "Failed");
+
+	if (final_candidate == 0xFF)
+		return;
+
+	else if (is_iqk_ok) {
+		oldval_0 = (odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD) >> 22) & 0x3FF;
+
+		X = result[final_candidate][0];
+		if ((X & 0x00000200) != 0)
+			X = X | 0xFFFFFC00;
+		TX0_A = (X * oldval_0) >> 8;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "X = 0x%x, TX0_A = 0x%x, oldval_0 0x%x\n", X, TX0_A, oldval_0);
+		odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0x3FF, TX0_A);
+
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(31), ((X * oldval_0 >> 7) & 0x1));
+
+		Y = result[final_candidate][1];
+		if ((Y & 0x00000200) != 0)
+			Y = Y | 0xFFFFFC00;
+
+		/* 2 Tx IQC */
+		TX0_C = (Y * oldval_0) >> 8;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "Y = 0x%x, TX = 0x%x\n", Y, TX0_C);
+		odm_set_bb_reg(dm, REG_OFDM_0_XC_TX_AFE, 0xF0000000, ((TX0_C & 0x3C0) >> 6));
+		cali_info->tx_iqc_8723b[PATH_S1][idx_0xc94][KEY] = REG_OFDM_0_XC_TX_AFE;
+		cali_info->tx_iqc_8723b[PATH_S1][idx_0xc94][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XC_TX_AFE, MASKDWORD);
+
+		odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0x003F0000, (TX0_C & 0x3F));
+		cali_info->tx_iqc_8723b[PATH_S1][idx_0xc80][KEY] = REG_OFDM_0_XA_TX_IQ_IMBALANCE;
+		cali_info->tx_iqc_8723b[PATH_S1][idx_0xc80][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD);
+
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(29), ((Y * oldval_0 >> 7) & 0x1));
+		cali_info->tx_iqc_8723b[PATH_S1][idx_0xc4c][KEY] = REG_OFDM_0_ECCA_THRESHOLD;
+		cali_info->tx_iqc_8723b[PATH_S1][idx_0xc4c][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD);
+
+		if (is_tx_only) {
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "_phy_path_a_fill_iqk_matrix8188f only Tx OK\n");
+
+			/* <20130226, Kordan> Saving RxIQC, otherwise not initialized. */
+			cali_info->rx_iqc_8723b[PATH_S1][idx_0xca0][KEY] = REG_OFDM_0_RX_IQ_EXT_ANTA;
+			cali_info->rx_iqc_8723b[PATH_S1][idx_0xca0][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_RX_IQ_EXT_ANTA, MASKDWORD);
+			cali_info->rx_iqc_8723b[PATH_S1][idx_0xc14][KEY] = REG_OFDM_0_XA_RX_IQ_IMBALANCE;
+			cali_info->rx_iqc_8723b[PATH_S1][idx_0xc14][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XA_RX_IQ_IMBALANCE, MASKDWORD);
+			return;
+		}
+
+		reg = result[final_candidate][2];
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		if (RTL_ABS(reg, 0x100) >= 16)
+			reg = 0x100;
+#endif
+
+		/* 2 Rx IQC */
+		odm_set_bb_reg(dm, REG_OFDM_0_XA_RX_IQ_IMBALANCE, 0x3FF, reg);
+		reg = result[final_candidate][3] & 0x3F;
+		odm_set_bb_reg(dm, REG_OFDM_0_XA_RX_IQ_IMBALANCE, 0xFC00, reg);
+		cali_info->rx_iqc_8723b[PATH_S1][idx_0xc14][KEY] = REG_OFDM_0_XA_RX_IQ_IMBALANCE;
+		cali_info->rx_iqc_8723b[PATH_S1][idx_0xc14][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XA_RX_IQ_IMBALANCE, MASKDWORD);
+
+		reg = (result[final_candidate][3] >> 6) & 0xF;
+		odm_set_bb_reg(dm, REG_OFDM_0_RX_IQ_EXT_ANTA, 0xF0000000, reg);
+		cali_info->rx_iqc_8723b[PATH_S1][idx_0xca0][KEY] = REG_OFDM_0_RX_IQ_EXT_ANTA;
+		cali_info->rx_iqc_8723b[PATH_S1][idx_0xca0][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_RX_IQ_EXT_ANTA, MASKDWORD);
+
+	}
+}
+
+#if 0
+void
+_phy_path_b_fill_iqk_matrix8188f(
+	struct dm_struct *dm,
+	boolean is_iqk_ok,
+	s32 result[][8],
+	u8 final_candidate,
+	boolean is_tx_only         /* do Tx only */
+)
+{
+	u32 oldval_1, X, TX1_A, reg;
+	s32 Y, TX1_C;
+	struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B IQ Calibration %s !\n", (is_iqk_ok) ? "Success" : "Failed");
+
+	if (final_candidate == 0xFF)
+		return;
+
+	else if (is_iqk_ok) {
+		oldval_1 = (odm_get_bb_reg(dm, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD) >> 22) & 0x3FF;
+
+		X = result[final_candidate][4];
+		if ((X & 0x00000200) != 0)
+			X = X | 0xFFFFFC00;
+		TX1_A = (X * oldval_1) >> 8;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "X = 0x%x, TX1_A = 0x%x\n", X, TX1_A);
+
+		odm_set_bb_reg(dm, REG_OFDM_0_XB_TX_IQ_IMBALANCE, 0x3FF, TX1_A);
+
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, 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;
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "Y = 0x%x, TX1_C = 0x%x\n", Y, TX1_C);
+
+		/* 2 Tx IQC */
+		odm_set_bb_reg(dm, REG_OFDM_0_XD_TX_AFE, 0xF0000000, ((TX1_C & 0x3C0) >> 6));
+		cali_info->tx_iqc_8723b[PATH_S0][idx_0xc9c][KEY] = REG_OFDM_0_XD_TX_AFE;
+		cali_info->tx_iqc_8723b[PATH_S0][idx_0xc9c][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XD_TX_AFE, MASKDWORD);
+
+		odm_set_bb_reg(dm, REG_OFDM_0_XB_TX_IQ_IMBALANCE, 0x003F0000, (TX1_C & 0x3F));
+		cali_info->tx_iqc_8723b[PATH_S0][idx_0xc88][KEY] = REG_OFDM_0_XB_TX_IQ_IMBALANCE;
+		cali_info->tx_iqc_8723b[PATH_S0][idx_0xc88][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD);
+
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(25), ((Y * oldval_1 >> 7) & 0x1));
+		cali_info->tx_iqc_8723b[PATH_S0][idx_0xc4c][KEY] = REG_OFDM_0_ECCA_THRESHOLD;
+		cali_info->tx_iqc_8723b[PATH_S0][idx_0xc4c][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD);
+
+		if (is_tx_only) {
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "_phy_path_b_fill_iqk_matrix8188f only Tx OK\n");
+
+			cali_info->rx_iqc_8723b[PATH_S0][idx_0xc1c][KEY] = REG_OFDM_0_XB_RX_IQ_IMBALANCE;
+			cali_info->rx_iqc_8723b[PATH_S0][idx_0xc1c][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XB_RX_IQ_IMBALANCE, MASKDWORD);
+			cali_info->rx_iqc_8723b[PATH_S0][idx_0xc78][KEY] = REG_OFDM_0_AGC_RSSI_TABLE;
+			cali_info->rx_iqc_8723b[PATH_S0][idx_0xc78][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_AGC_RSSI_TABLE, MASKDWORD);
+			return;
+		}
+
+		/* 2 Rx IQC */
+		reg = result[final_candidate][6];
+		odm_set_bb_reg(dm, REG_OFDM_0_XB_RX_IQ_IMBALANCE, 0x3FF, reg);
+		reg = result[final_candidate][7] & 0x3F;
+		odm_set_bb_reg(dm, REG_OFDM_0_XB_RX_IQ_IMBALANCE, 0xFC00, reg);
+		cali_info->rx_iqc_8723b[PATH_S0][idx_0xc1c][KEY] = REG_OFDM_0_XB_RX_IQ_IMBALANCE;
+		cali_info->rx_iqc_8723b[PATH_S0][idx_0xc1c][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_XB_RX_IQ_IMBALANCE, MASKDWORD);
+
+		reg = (result[final_candidate][7] >> 6) & 0xF;
+		odm_set_bb_reg(dm, REG_OFDM_0_AGC_RSSI_TABLE, 0x0000F000, reg);
+		cali_info->rx_iqc_8723b[PATH_S0][idx_0xc78][KEY] = REG_OFDM_0_AGC_RSSI_TABLE;
+		cali_info->rx_iqc_8723b[PATH_S0][idx_0xc78][VAL] = odm_get_bb_reg(dm, REG_OFDM_0_AGC_RSSI_TABLE, MASKDWORD);
+	}
+}
+#endif
+
+void
+_phy_save_adda_registers8188f(
+	struct dm_struct *dm,
+	u32 *adda_reg,
+	u32 *adda_backup,
+	u32 register_num
+)
+{
+	u32 i;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if (odm_check_power_status(dm) == false)
+		return;
+#endif
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "Save ADDA parameters.\n");
+	for (i = 0; i < register_num; i++)
+		adda_backup[i] = odm_get_bb_reg(dm, adda_reg[i], MASKDWORD);
+}
+
+
+void
+_phy_save_mac_registers8188f(
+	struct dm_struct *dm,
+	u32 *mac_reg,
+	u32 *mac_backup
+)
+{
+	u32 i;
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "Save MAC parameters.\n");
+	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
+		mac_backup[i] = odm_read_1byte(dm, mac_reg[i]);
+	mac_backup[i] = odm_read_4byte(dm, mac_reg[i]);
+}
+
+
+void
+_phy_reload_adda_registers8188f(
+	struct dm_struct *dm,
+	u32 *adda_reg,
+	u32 *adda_backup,
+	u32 regiester_num
+)
+{
+	u32 i;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "Reload ADDA power saving parameters !\n");
+	for (i = 0; i < regiester_num; i++)
+		odm_set_bb_reg(dm, adda_reg[i], MASKDWORD, adda_backup[i]);
+}
+
+void
+_phy_reload_mac_registers8188f(
+	struct dm_struct *dm,
+	u32 *mac_reg,
+	u32 *mac_backup
+)
+{
+	u32 i;
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "Reload MAC parameters !\n");
+	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
+		odm_write_1byte(dm, mac_reg[i], (u8)mac_backup[i]);
+	odm_write_4byte(dm, mac_reg[i], mac_backup[i]);
+}
+
+
+void
+_phy_path_adda_on8188f(
+	struct dm_struct *dm,
+	u32 *adda_reg,
+	boolean is_path_a_on,
+	boolean is2T
+)
+{
+	u32 path_on;
+	u32 i;
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "ADDA ON.\n");
+
+	path_on = is_path_a_on ? 0x03c00014 : 0x03c00014;
+	if (false == is2T) {
+		path_on = 0x03c00014;
+		odm_set_bb_reg(dm, adda_reg[0], MASKDWORD, 0x03c00014);
+	} else
+		odm_set_bb_reg(dm, adda_reg[0], MASKDWORD, path_on);
+
+	for (i = 1; i < IQK_ADDA_REG_NUM; i++)
+		odm_set_bb_reg(dm, adda_reg[i], MASKDWORD, path_on);
+
+}
+
+void
+_phy_mac_setting_calibration8188f(
+	struct dm_struct *dm,
+	u32 *mac_reg,
+	u32 *mac_backup
+)
+{
+	//u32 i = 0;
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "MAC settings for Calibration.\n");
+
+#if 0
+	odm_write_1byte(dm, mac_reg[i], 0x3F);
+
+	for (i = 1; i < (IQK_MAC_REG_NUM - 1); i++)
+		odm_write_1byte(dm, mac_reg[i], (u8)(mac_backup[i] & (~BIT(3))));
+	odm_write_1byte(dm, mac_reg[i], (u8)(mac_backup[i] & (~BIT(5))));
+#else
+
+	odm_set_bb_reg(dm, 0x520, 0x00ff0000, 0xff);
+#endif
+}
+
+void
+_phy_path_a_stand_by8188f(
+	struct dm_struct *dm
+)
+{
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path-A standby mode!\n");
+
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+	/* Allen */
+	odm_set_rf_reg(dm, RF_PATH_A, RF_AC, MASKDWORD, 0x10000);
+	/* odm_set_bb_reg(dm, 0x840, MASKDWORD, 0x00010000);
+	*   */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
+}
+
+void
+_phy_pi_mode_switch8188f(
+	struct dm_struct *dm,
+	boolean pi_mode
+)
+{
+	u32 mode;
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "BB Switch to %s mode!\n", (pi_mode ? "PI" : "SI"));
+
+	mode = pi_mode ? 0x01000100 : 0x01000000;
+	odm_set_bb_reg(dm, REG_FPGA0_XA_HSSI_PARAMETER1, MASKDWORD, mode);
+	odm_set_bb_reg(dm, REG_FPGA0_XB_HSSI_PARAMETER1, MASKDWORD, mode);
+}
+
+boolean
+phy_simularity_compare_8188f(
+	struct dm_struct *dm,
+	s32 result[][8],
+	u8 c1,
+	u8 c2
+)
+{
+	u32 i, j, diff, simularity_bit_map, bound = 0;
+	u8 final_candidate[2] = { 0xFF, 0xFF };  /* for path A and path B */
+	boolean is_result = true;
+	/* #if !(DM_ODM_SUPPORT_TYPE & ODM_AP) */
+	/*	bool		is2T = IS_92C_SERIAL( hal_data->version_id);
+	 * #else */
+	boolean is2T = true;
+	/* #endif */
+
+	s32 tmp1 = 0, tmp2 = 0;
+
+	if (is2T)
+		bound = 8;
+	else
+		bound = 4;
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "===> IQK:phy_simularity_compare_8192e c1 %d c2 %d!!!\n", c1, c2);
+
+
+	simularity_bit_map = 0;
+
+	for (i = 0; i < bound; i++) {
+
+		if ((i == 1) || (i == 3) || (i == 5) || (i == 7)) {
+			if ((result[c1][i] & 0x00000200) != 0)
+				tmp1 = result[c1][i] | 0xFFFFFC00;
+			else
+				tmp1 = result[c1][i];
+
+			if ((result[c2][i] & 0x00000200) != 0)
+				tmp2 = result[c2][i] | 0xFFFFFC00;
+			else
+				tmp2 = result[c2][i];
+		} else {
+			tmp1 = result[c1][i];
+			tmp2 = result[c2][i];
+		}
+
+		diff = (tmp1 > tmp2) ? (tmp1 - tmp2) : (tmp2 - tmp1);
+
+		if (diff > MAX_TOLERANCE) {
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK:differnece overflow %d index %d compare1 0x%x compare2 0x%x!!!\n", diff, i, result[c1][i], result[c2][i]);
+
+			if ((i == 2 || i == 6) && !simularity_bit_map) {
+				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
+					simularity_bit_map = simularity_bit_map | (1 << i);
+			} else
+				simularity_bit_map = simularity_bit_map | (1 << i);
+		}
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK:phy_simularity_compare_8192e simularity_bit_map   %x !!!\n", simularity_bit_map);
+
+	if (simularity_bit_map == 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];
+				is_result = false;
+			}
+		}
+		return is_result;
+	} else {
+
+		if (!(simularity_bit_map & 0x03)) {       /* path A TX OK */
+			for (i = 0; i < 2; i++)
+				result[3][i] = result[c1][i];
+		}
+
+		if (!(simularity_bit_map & 0x0c)) {       /* path A RX OK */
+			for (i = 2; i < 4; i++)
+				result[3][i] = result[c1][i];
+		}
+
+		if (!(simularity_bit_map & 0x30)) { /* path B TX OK */
+			for (i = 4; i < 6; i++)
+				result[3][i] = result[c1][i];
+
+		}
+
+		if (!(simularity_bit_map & 0xc0)) { /* path B RX OK */
+			for (i = 6; i < 8; i++)
+				result[3][i] = result[c1][i];
+		}
+		return false;
+	}
+}
+
+
+
+void
+_phy_iq_calibrate_8188f(
+	struct dm_struct *dm,
+	s32 result[][8],
+	u8 t,
+	boolean is2T
+)
+{
+	u32 i;
+	u8 path_aok = 0x0;//, path_bok = 0x0;
+	u8 tmp0xc50 = (u8)odm_get_bb_reg(dm, 0xC50, MASKBYTE0);
+	u8 tmp0xc58 = (u8)odm_get_bb_reg(dm, 0xC58, MASKBYTE0);
+	u32 ADDA_REG[IQK_ADDA_REG_NUM] = {
+		REG_FPGA0_XCD_SWITCH_CONTROL, REG_BLUE_TOOTH,
+		REG_RX_WAIT_CCA, REG_TX_CCK_RFON,
+		REG_TX_CCK_BBON, REG_TX_OFDM_RFON,
+		REG_TX_OFDM_BBON, REG_TX_TO_RX,
+		REG_TX_TO_TX, REG_RX_CCK,
+		REG_RX_OFDM, REG_RX_WAIT_RIFS,
+		REG_RX_TO_RX, REG_STANDBY,
+		REG_SLEEP, REG_PMPD_ANAEN
+	};
+	u32 IQK_MAC_REG[IQK_MAC_REG_NUM] = {
+		REG_TXPAUSE, REG_BCN_CTRL,
+		REG_BCN_CTRL_1, REG_GPIO_MUXCFG
+	};
+
+	/* since 92C & 92D have the different define in IQK_BB_REG */
+	u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
+		REG_OFDM_0_TRX_PATH_ENABLE, REG_OFDM_0_TR_MUX_PAR,
+		REG_FPGA0_XCD_RF_INTERFACE_SW, REG_CONFIG_ANT_A, REG_CONFIG_ANT_B,
+		REG_FPGA0_XAB_RF_INTERFACE_SW, REG_FPGA0_XA_RF_INTERFACE_OE,
+		REG_FPGA0_XB_RF_INTERFACE_OE, REG_FPGA0_RFMOD
+	};
+
+	//u32 path_sel_bb; 
+	u32 path_sel_rf;
+	u32 retry_count;
+	
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	retry_count = 2;
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+#if MP_DRIVER
+	retry_count = 9;
+#else
+	retry_count = 2;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	if (*(dm->mp_mode))
+		retry_count = 9;
+	else
+		retry_count = 2;
+#endif
+
+	/* Note: IQ calibration must be performed after loading */
+	/*		PHY_REG.txt , and radio_a, radio_b.txt */
+
+	/* u32 bbvalue; */
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#ifdef MP_TEST
+	if (*(dm->mp_mode))
+		retry_count = 9;
+#endif
+#endif
+
+
+	if (t == 0) {
+		/*	 	 bbvalue = odm_get_bb_reg(dm, REG_FPGA0_RFMOD, MASKDWORD);
+		 * 			RT_DISP(FINIT, INIT_IQK, ("_phy_iq_calibrate_8188f()==>0x%08x\n",bbvalue)); */
+
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQ Calibration for %s for %d times\n", (is2T ? "2T2R" : "1T1R"), t);
+
+		/* Save ADDA parameters, turn path A ADDA on */
+		_phy_save_adda_registers8188f(dm, ADDA_REG, dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
+		_phy_save_mac_registers8188f(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
+		_phy_save_adda_registers8188f(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQ Calibration for %s for %d times\n", (is2T ? "2T2R" : "1T1R"), t);
+	_phy_path_adda_on8188f(dm, ADDA_REG, true, is2T);
+
+	if (t == 0)
+		dm->rf_calibrate_info.is_rf_pi_enable = (u8)odm_get_bb_reg(dm, REG_FPGA0_XA_HSSI_PARAMETER1, BIT(8));
+
+#if 0
+	if (!dm->rf_calibrate_info.is_rf_pi_enable) {
+		/* Switch BB to PI mode to do IQ Calibration. */
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+		_phy_pi_mode_switch8188f(adapter, true);
+#else
+		_phy_pi_mode_switch8188f(dm, true);
+#endif
+	}
+#endif
+
+	/* save RF path */
+//	path_sel_bb = odm_get_bb_reg(dm, 0x948, MASKDWORD);
+//	path_sel_rf = odm_get_rf_reg(dm, RF_PATH_A, 0xb0, 0xfffff);
+
+
+	/* BB setting */
+	/*odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT24, 0x00);*/
+	odm_set_bb_reg(dm, REG_OFDM_0_TRX_PATH_ENABLE, MASKDWORD, 0x03a05600);
+	odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800e4);
+	odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x25204000);
+
+	/* external switch control
+	*	odm_set_bb_reg(dm, REG_FPGA0_XAB_RF_INTERFACE_SW, BIT(10), 0x01);
+	*	odm_set_bb_reg(dm, REG_FPGA0_XAB_RF_INTERFACE_SW, BIT(26), 0x01);
+	*	odm_set_bb_reg(dm, REG_FPGA0_XA_RF_INTERFACE_OE, BIT(10), 0x00);
+	*	odm_set_bb_reg(dm, REG_FPGA0_XB_RF_INTERFACE_OE, BIT(10), 0x00); */
+
+
+	if (is2T) {
+		/* Allen */
+		/*	odm_set_bb_reg(dm, REG_FPGA0_XA_LSSI_PARAMETER, MASKDWORD, 0x00010000); */
+		/*	odm_set_bb_reg(dm, REG_FPGA0_XB_LSSI_PARAMETER, MASKDWORD, 0x00010000); */
+		odm_set_rf_reg(dm, RF_PATH_B, RF_AC, MASKDWORD, 0x10000);
+	}
+
+	/* MAC settings */
+	_phy_mac_setting_calibration8188f(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
+
+	/* Page B init */
+	/* AP or IQK
+	*	odm_set_bb_reg(dm, REG_CONFIG_ANT_A, MASKDWORD, 0x0f600000); */
+
+	if (is2T) {
+		/*		odm_set_bb_reg(dm, REG_CONFIG_ANT_B, MASKDWORD, 0x0f600000); */
+	}
+
+	/* IQ calibration setting */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK setting!\n");
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+
+	for (i = 0; i < retry_count; i++) {
+		path_aok = phy_path_a_iqk_8188f(dm, is2T);
+		/*		if(path_aok == 0x03){ */
+		if (path_aok == 0x01) { /* path A Tx IQK Success */
+			odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+			dm->rf_calibrate_info.tx_lok[RF_PATH_A] = odm_get_rf_reg(dm, RF_PATH_A, 0x8, RFREGOFFSETMASK);
+
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A Tx IQK Success!!\n");
+			result[t][0] = (odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+			result[t][1] = (odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+			break;
+		}
+#if 0
+		else if (i == (retry_count - 1) && path_aok == 0x01) { /* Tx IQK OK */
+			RT_DISP(FINIT, INIT_IQK, ("path A IQK Only  Tx Success!!\n"));
+
+			result[t][0] = (odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+			result[t][1] = (odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+		}
+#endif
+	}
+
+	/* bypass RXQIK */
+#if 1
+
+	for (i = 0; i < retry_count; i++) {
+		path_aok = phy_path_a_rx_iqk_8188f(dm, is2T);
+		if (path_aok == 0x03) {
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A Rx IQK Success!!\n");
+			/*				result[t][0] = (odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD)&0x3FF0000)>>16;
+			 *				result[t][1] = (odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD)&0x3FF0000)>>16; */
+			result[t][2] = (odm_get_bb_reg(dm, REG_RX_POWER_BEFORE_IQK_A_2, MASKDWORD) & 0x3FF0000) >> 16;
+			result[t][3] = (odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD) & 0x3FF0000) >> 16;
+			break;
+		} else
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A Rx IQK Fail!!\n");
+	}
+#endif
+
+
+	if (path_aok == 0x0)
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path A IQK failed!!\n");
+#if 0
+	if (is2T) {
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+		_phy_path_a_stand_by8188f(adapter);
+
+		/* Turn path B ADDA on */
+		_phy_path_adda_on8188f(adapter, ADDA_REG, false, is2T);
+#else
+		_phy_path_a_stand_by8188f(dm);
+
+		/* Turn path B ADDA on */
+		_phy_path_adda_on8188f(dm, ADDA_REG, false, is2T);
+#endif
+		/* Allen */
+		for (i = 0; i < retry_count; i++) {
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+			path_bok = phy_path_b_iqk_8188f(adapter);
+#else
+			path_bok = phy_path_b_iqk_8188f(dm);
+#endif
+			/*		if(path_bok == 0x03){ */
+			if (path_bok == 0x01) { /* path B Tx IQK Success */
+				odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+				dm->rf_calibrate_info.tx_lok[RF_PATH_B] = odm_get_rf_reg(dm, RF_PATH_B, 0x8, RFREGOFFSETMASK);
+
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B Tx IQK Success!!\n");
+				result[t][4] = (odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+				result[t][5] = (odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+				break;
+			}
+#if 0
+			else if (i == (retry_count - 1) && path_aok == 0x01) { /* Tx IQK OK */
+				RT_DISP(FINIT, INIT_IQK, ("path B IQK Only  Tx Success!!\n"));
+
+				result[t][0] = (odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_B, MASKDWORD) & 0x3FF0000) >> 16;
+				result[t][1] = (odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_B, MASKDWORD) & 0x3FF0000) >> 16;
+			}
+#endif
+		}
+
+		/* bypass RXQIK */
+#if 0
+
+		for (i = 0; i < retry_count; i++) {
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+			path_bok = phy_path_b_rx_iqk_8188f(adapter, is2T);
+#else
+			path_bok = phy_path_b_rx_iqk_8188f(dm, is2T);
+#endif
+			if (path_bok == 0x03) {
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B Rx IQK Success!!\n");
+				/*				result[t][0] = (odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD)&0x3FF0000)>>16;
+				 *				result[t][1] = (odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD)&0x3FF0000)>>16; */
+				result[t][6] = (odm_get_bb_reg(dm, REG_RX_POWER_BEFORE_IQK_B_2, MASKDWORD) & 0x3FF0000) >> 16;
+				result[t][7] = (odm_get_bb_reg(dm, REG_RX_POWER_AFTER_IQK_B_2, MASKDWORD) & 0x3FF0000) >> 16;
+				break;
+			} else
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B Rx IQK Fail!!\n");
+		}
+#endif
+
+		/* ======Allen end ========= */
+		if (0x00 == path_bok)
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "path B IQK failed!!\n");
+	}
+#endif
+	/* Back to BB mode, load original value */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK:Back to BB mode, load original value!\n");
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0);
+
+	if (t != 0) {
+		if (!dm->rf_calibrate_info.is_rf_pi_enable) {
+			/* Switch back BB to SI mode after finish IQ Calibration. */
+			_phy_pi_mode_switch8188f(dm, false);
+		}
+		/* Reload ADDA power saving parameters */
+		_phy_reload_adda_registers8188f(dm, ADDA_REG, dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
+		/* Reload MAC parameters */
+		_phy_reload_mac_registers8188f(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
+		_phy_reload_adda_registers8188f(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
+		/* Reload RF path */
+//		odm_set_bb_reg(dm, 0x948, MASKDWORD, path_sel_bb);
+//		odm_set_rf_reg(dm, RF_PATH_A, 0xb0, 0xfffff, path_sel_rf);
+
+		/* Allen initial gain 0xc50 */
+		/* Restore RX initial gain */
+		odm_set_bb_reg(dm, 0xc50, MASKBYTE0, 0x50);
+		odm_set_bb_reg(dm, 0xc50, MASKBYTE0, tmp0xc50);
+		if (is2T) {
+			odm_set_bb_reg(dm, 0xc58, MASKBYTE0, 0x50);
+			odm_set_bb_reg(dm, 0xc58, MASKBYTE0, tmp0xc58);
+		}
+
+		/* load 0xe30 IQC default value */
+		odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x01008c00);
+		odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x01008c00);
+
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "_phy_iq_calibrate_8188f() <==\n");
+
+}
+
+
+void
+_phy_lc_calibrate_8188f(
+	struct dm_struct *dm,
+	boolean is2T
+)
+{
+	u8 tmp_reg;
+	u32 rf_bmode = 0, lc_cal, cnt;
+
+	/*Check continuous TX and Packet TX*/
+	tmp_reg = odm_read_1byte(dm, 0xd03);
+
+	if ((tmp_reg & 0x70) != 0)			/*Deal with contisuous TX case*/
+		odm_write_1byte(dm, 0xd03, tmp_reg & 0x8F);	/*disable all continuous TX*/
+	else							/* Deal with Packet TX case*/
+		odm_write_1byte(dm, REG_TXPAUSE, 0xFF);			/* block all queues*/
+
+
+	/*backup RF0x18*/
+	lc_cal = odm_get_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK);
+
+	/*Start LCK*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal | 0x08000);
+
+	for (cnt = 0; cnt < 100; cnt++) {
+		if (odm_get_rf_reg(dm, RF_PATH_A, RF_CHNLBW, 0x8000) != 0x1)
+			break;
+		ODM_delay_ms(10);
+	}
+
+	/*Recover channel number*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal);
+
+
+	/*Restore original situation*/
+	if ((tmp_reg & 0x70) != 0) {
+		/*Deal with contisuous TX case*/
+		odm_write_1byte(dm, 0xd03, tmp_reg);
+	} else {
+		/* Deal with Packet TX case*/
+		odm_write_1byte(dm, REG_TXPAUSE, 0x00);
+	}
+
+}
+
+void
+phy_iq_calibrate_8188f(
+	void		*dm_void,
+	boolean is_recovery
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	s32 result[4][8];   /* last is final result */
+	u8 i, final_candidate, indexforchannel;
+	boolean is_patha_ok, is_pathb_ok;
+#if 1 //DBG
+	s32 rege94, rege9c, regea4, regeac, regeb4 = 0, regebc = 0, regec4 = 0, regecc = 0, reg_tmp = 0;
+#else
+	s32 rege94, regea4, regeb4, regec4, reg_tmp = 0;
+#endif
+	boolean is12simular, is13simular, is23simular;
+	u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
+		REG_OFDM_0_XA_RX_IQ_IMBALANCE, REG_OFDM_0_XB_RX_IQ_IMBALANCE,
+		REG_OFDM_0_ECCA_THRESHOLD, REG_OFDM_0_AGC_RSSI_TABLE,
+		REG_OFDM_0_XA_TX_IQ_IMBALANCE, REG_OFDM_0_XB_TX_IQ_IMBALANCE,
+		REG_OFDM_0_XC_TX_AFE, REG_OFDM_0_XD_TX_AFE,
+		REG_OFDM_0_RX_IQ_EXT_ANTA
+	};
+	//u32 path_sel_bb = 0;
+	u32 path_sel_rf = 0;
+
+#if 0
+	if (is_restore) {
+		u32 offset, data;
+		u8 path, is_result = SUCCESS;
+		struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
+
+		/* #define 	PATH_S0                         1 */ /* RF_PATH_B */
+		/* #define 	PATH_S1                         0 */ /* RF_PATH_A */
+
+		path = (odm_get_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKBYTE0) == 0x00) ? RF_PATH_A : RF_PATH_B;
+		/* Restore TX IQK */
+		for (i = 0; i < 3; ++i) {
+			offset = cali_info->tx_iqc_8723b[path][i][0];
+			data = cali_info->tx_iqc_8723b[path][i][1];
+			if ((offset == 0) || (data == 0)) {
+				is_result = FAIL;
+				break;
+			}
+			RT_TRACE(COMP_MP, DBG_TRACE, ("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data));
+			odm_set_bb_reg(dm, offset, MASKDWORD, data);
+		}
+		/* Restore RX IQK */
+		for (i = 0; i < 2; ++i) {
+			offset = cali_info->rx_iqc_8723b[path][i][0];
+			data = cali_info->rx_iqc_8723b[path][i][1];
+			if ((offset == 0) || (data == 0)) {
+				is_result = FAIL;
+				break;
+			}
+			RT_TRACE(COMP_MP, DBG_TRACE, ("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data));
+			odm_set_bb_reg(dm, offset, MASKDWORD, data);
+		}
+
+		if (dm->rf_calibrate_info.tx_lok[RF_PATH_A] == 0)
+			is_result = FAIL;
+		else {
+			odm_set_rf_reg(dm, RF_PATH_A, RF_TXM_IDAC, RFREGOFFSETMASK, dm->rf_calibrate_info.tx_lok[RF_PATH_A]);
+			odm_set_rf_reg(dm, RF_PATH_B, RF_TXM_IDAC, RFREGOFFSETMASK, dm->rf_calibrate_info.tx_lok[RF_PATH_B]);
+		}
+
+		if (is_result == SUCCESS)
+			return;
+
+	}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+	if (is_recovery)
+#else/* for ODM_WIN */
+	if (is_recovery && (!dm->is_in_hct_test))  /* YJ,add for PowerTest,120405 */
+#endif
+	{
+		PHYDM_DBG(dm, ODM_COMP_INIT, "phy_iq_calibrate_8188f: Return due to is_recovery!\n");
+		_phy_reload_adda_registers8188f(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup_recover, 9);
+		return;
+	}
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK:Start!!!\n");
+
+
+	/* Save RF path */
+//	path_sel_bb = odm_get_bb_reg(dm, 0x948, MASKDWORD);
+//	path_sel_rf = odm_get_rf_reg(dm, RF_PATH_A, 0xb0, 0xfffff);
+
+
+	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;
+	is_patha_ok = false;
+	is_pathb_ok = false;
+	is12simular = false;
+	is23simular = false;
+	is13simular = false;
+
+
+	for (i = 0; i < 3; i++) {
+		_phy_iq_calibrate_8188f(dm, result, i, false);
+
+		if (i == 1) {
+			is12simular = phy_simularity_compare_8188f(dm, result, 0, 1);
+			if (is12simular) {
+				final_candidate = 0;
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK: is12simular final_candidate is %x\n", final_candidate);
+				break;
+			}
+		}
+
+		if (i == 2) {
+			is13simular = phy_simularity_compare_8188f(dm, result, 0, 2);
+			if (is13simular) {
+				final_candidate = 0;
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK: is13simular final_candidate is %x\n", final_candidate);
+
+				break;
+			}
+
+			is23simular = phy_simularity_compare_8188f(dm, result, 1, 2);
+
+			if (is23simular) {
+				final_candidate = 1;
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK: is23simular final_candidate is %x\n", final_candidate);
+			} else {
+				for (i = 0; i < 8; i++)
+					reg_tmp += result[3][i];
+
+				if (reg_tmp != 0)
+					final_candidate = 3;
+				else
+					final_candidate = 0xFF;
+			}
+		}
+	}
+	/*	RT_TRACE(COMP_INIT,DBG_LOUD,("Release Mutex in IQCalibrate\n")); */
+
+	for (i = 0; i < 4; i++) {
+		rege94 = result[i][0];
+		regea4 = result[i][2];
+		regeb4 = result[i][4];
+		regec4 = result[i][6];
+#if DBG
+		rege9c = result[i][1];
+		regeac = result[i][3];
+		regebc = result[i][5];
+		regecc = result[i][7];
+#endif
+		//PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK: rege94=%04x rege9c=%04x regea4=%04x regeac=%04x regeb4=%04x regebc=%04x regec4=%04x regecc=%04x\n",
+		//	rege94, rege9c, regea4, regeac, regeb4, regebc, regec4, regecc);
+	}
+
+	if (final_candidate != 0xff) {
+		dm->rf_calibrate_info.rege94 = result[final_candidate][0];
+		dm->rf_calibrate_info.rege9c = result[final_candidate][1];
+		dm->rf_calibrate_info.regeb4 = result[final_candidate][4];
+		dm->rf_calibrate_info.regebc = result[final_candidate][5];
+
+		rege94 = result[final_candidate][0];
+		regea4 = result[final_candidate][2];
+		regeb4 = result[final_candidate][4];
+		regec4 = result[final_candidate][6];
+#if DBG
+		rege9c = result[final_candidate][1];
+		regeac = result[final_candidate][3];
+		regebc = result[final_candidate][5];
+		regecc = result[final_candidate][7];
+#endif
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK: final_candidate is %x\n", final_candidate);
+		//PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK: rege94=%04x rege9c=%04x regea4=%04x regeac=%04x regeb4=%04x regebc=%04x regec4=%04x regecc=%04x\n",
+		//	rege94, rege9c, regea4, regeac, regeb4, regebc, regec4, regecc);
+		is_patha_ok = is_pathb_ok = true;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK: FAIL use default value\n");
+
+		dm->rf_calibrate_info.rege94 = dm->rf_calibrate_info.regeb4 = 0x100;  /* X default value */
+		dm->rf_calibrate_info.rege9c = dm->rf_calibrate_info.regebc = 0x0;        /* Y default value */
+	}
+
+
+	if (rege94 != 0)
+		_phy_path_a_fill_iqk_matrix8188f(dm, is_patha_ok, result, final_candidate, (regea4 == 0));
+
+#if 0
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if MP_DRIVER == 1
+	if ((rf_path == RF_PATH_A) || ((*(dm->mp_mode)) == 0))
+#endif
+	{
+		if (regeb4 != 0)
+			_phy_path_b_fill_iqk_matrix8188f(dm, is_pathb_ok, result, final_candidate, (regec4 == 0));
+	}
+#endif
+#endif
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	indexforchannel = odm_get_right_chnl_place_for_iqk(*dm->channel);
+#else
+	indexforchannel = 0;
+#endif
+
+	/* To Fix BSOD when final_candidate is 0xff
+	 * by sherry 20120321 */
+	if (final_candidate < 4) {
+		for (i = 0; i < iqk_matrix_reg_num; i++)
+			dm->rf_calibrate_info.iqk_matrix_reg_setting[indexforchannel].value[0][i] = result[final_candidate][i];
+		dm->rf_calibrate_info.iqk_matrix_reg_setting[indexforchannel].is_iqk_done = true;
+	}
+	/* RT_DISP(FINIT, INIT_IQK, ("\nIQK OK indexforchannel %d.\n", indexforchannel)); */
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "\nIQK OK indexforchannel %d.\n", indexforchannel);
+	_phy_save_adda_registers8188f(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup_recover, IQK_BB_REG_NUM);
+
+	/* Restore RF path */
+//	odm_set_bb_reg(dm, 0x948, MASKDWORD, path_sel_bb);
+//	odm_set_rf_reg(dm, RF_PATH_A, 0xb0, 0xfffff, path_sel_rf);
+
+	PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "IQK finished 8188F\n");
+}
+
+
+void
+phy_lc_calibrate_8188f(
+	void *dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	_phy_lc_calibrate_8188f(dm, false);
+}
+
+void _phy_set_rf_path_switch_8188f(
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	struct dm_struct *dm,
+#else
+	void *adapter,
+#endif
+	boolean is_main,
+	boolean is2T
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+#endif
+
+	if (is_main)   /* Left antenna */
+		odm_set_bb_reg(dm, 0x92C, MASKDWORD, 0x1);
+	else
+		odm_set_bb_reg(dm, 0x92C, MASKDWORD, 0x2);
+}
+
+void phy_set_rf_path_switch_8188f(
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	struct dm_struct *dm,
+#else
+	void *adapter,
+#endif
+	boolean is_main
+)
+{
+#if DISABLE_BB_RF
+	return;
+#endif
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	_phy_set_rf_path_switch_8188f(dm, is_main, true);
+#else
+	_phy_set_rf_path_switch_8188f(adapter, is_main, true);
+#endif
+#endif
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+/* return value true => Main; false => Aux */
+
+boolean _phy_query_rf_path_switch_8188f(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct *dm,
+#else
+	void *adapter,
+#endif
+	boolean is2T
+)
+{
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct *dm = &hal_data->odmpriv;
+#endif
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+#endif
+#endif
+
+
+	if (odm_get_bb_reg(dm, 0x92C, MASKDWORD) == 0x01)
+		return true;
+	else
+		return false;
+
+}
+
+
+
+/* return value true => Main; false => Aux */
+boolean phy_query_rf_path_switch_8188f(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct dm_struct *dm
+#else
+	void *adapter
+#endif
+)
+{
+#if DISABLE_BB_RF
+	return true;
+#endif
+
+#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
+	return _phy_query_rf_path_switch_8188f(adapter, false);
+#else
+	return _phy_query_rf_path_switch_8188f(dm, false);
+#endif
+}
+#endif
+
+u32 phy_psd_log2base(u32 val)
+{
+	u8	i, j;
+	u32	tmp, tmp2, val_integerdb = 0, tindex, shiftcount = 0;
+	u32	result, val_fractiondb = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
+									174, 151, 132, 115, 100, 86,
+									74, 62, 51, 42, 32, 23, 15, 7, 0};
+
+	if (val == 0)
+		return 0;
+
+	tmp = val;
+	while (1) {
+		if (tmp == 1)
+			break;
+
+		else {
+			tmp = (tmp >> 1);
+			shiftcount++;
+		}
+	}
+
+	val_integerdb = shiftcount+1;
+	tmp2 = 1;
+
+	for (j = 1; j <= val_integerdb; j++)
+		tmp2 = tmp2 * 2;
+
+	tmp = (val * 100) / tmp2;
+	tindex = tmp / 5;
+
+	if (tindex > 20)
+		tindex = 20;
+
+	val_fractiondb = table_fraction[tindex];
+
+	result = val_integerdb * 100 - val_fractiondb;
+
+	return result;
+
+
+}
+
+
+void phy_active_large_power_detection_8188f(
+	struct dm_struct *dm
+)
+{
+	u8	i = 1, j = 0, retrycnt = 2;
+	u32	threshold_psd = 56, tmp_psd = 0, tmp_psd_db = 0, rf_mode;
+
+	u32 ADDA_REG[IQK_ADDA_REG_NUM] = {
+		REG_FPGA0_XCD_SWITCH_CONTROL, REG_BLUE_TOOTH,
+		REG_RX_WAIT_CCA, REG_TX_CCK_RFON,
+		REG_TX_CCK_BBON, REG_TX_OFDM_RFON,
+		REG_TX_OFDM_BBON, REG_TX_TO_RX,
+		REG_TX_TO_TX, REG_RX_CCK,
+		REG_RX_OFDM, REG_RX_WAIT_RIFS,
+		REG_RX_TO_RX, REG_STANDBY,
+		REG_SLEEP, REG_PMPD_ANAEN
+	};
+	u32 IQK_MAC_REG[IQK_MAC_REG_NUM] = {
+		REG_TXPAUSE, REG_BCN_CTRL,
+		REG_BCN_CTRL_1, REG_GPIO_MUXCFG
+	};
+
+	/* since 92C & 92D have the different define in IQK_BB_REG */
+	u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
+		REG_OFDM_0_TRX_PATH_ENABLE, REG_OFDM_0_TR_MUX_PAR,
+		REG_FPGA0_XCD_RF_INTERFACE_SW, REG_CONFIG_ANT_A, REG_CONFIG_ANT_B,
+		REG_FPGA0_XAB_RF_INTERFACE_SW, REG_FPGA0_XA_RF_INTERFACE_OE,
+		REG_FPGA0_XB_RF_INTERFACE_OE, REG_FPGA0_RFMOD
+	};
+
+	BOOLEAN goout = FALSE;
+
+	_phy_save_adda_registers8188f(dm, ADDA_REG, dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
+	_phy_save_mac_registers8188f(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
+	_phy_save_adda_registers8188f(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
+
+	_phy_path_adda_on8188f(dm, ADDA_REG, TRUE, FALSE);
+
+	rf_mode = odm_get_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK);
+	/*PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]Original RF mode = 0x%x\n", odm_get_rf_reg(dm, ODM_RF_PATH_A, 0x0, RFREGOFFSETMASK));*/
+
+	do {
+		switch (i) {
+		case 1: /*initial setting*/
+			PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]Loopback test Start!!\n");
+			odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+			odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x28000);
+			odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0000f);
+			odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0x3fffe);
+			odm_set_rf_reg(dm, RF_PATH_A, RF_DBG_LP_RX2, 0x00800, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x56, 0x00fff, 0x67);
+
+			odm_set_bb_reg(dm, REG_OFDM_0_TRX_PATH_ENABLE, MASKDWORD, 0x03a05600);
+			odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800e4);
+			odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x25204000);
+
+			odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
+			odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x80007C00);	/*set two tone*/
+			odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+			odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x30008c1c);
+			odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x10009c1c);
+			odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82160000);
+			odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x2815200f);
+			odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a910);
+
+			odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+			odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+			ODM_delay_ms(IQK_DELAY_TIME_8188F);
+
+			if (odm_get_bb_reg(dm, 0xea0, MASKDWORD) <= 0xa) {
+
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]Skip Activation due to abnormal 0xea0 value (0x%x)\n", odm_get_bb_reg(dm, 0xea0, MASKDWORD));
+				goout = TRUE;
+				break;
+
+			} else {
+				tmp_psd = 3 * (phy_psd_log2base(odm_get_bb_reg(dm, 0xea0, MASKDWORD)));
+				tmp_psd_db = tmp_psd / 100;
+
+				PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]0xea0 = 0x%x, tmp_PSD_dB = %d, (criterion = %d)\n", odm_get_bb_reg(dm, 0xea0, MASKDWORD), tmp_psd_db, threshold_psd);
+
+				i = 2;
+				break;
+			}
+
+		case 2: /*check PSD*/
+			if (tmp_psd_db < threshold_psd) {
+
+				if (j < retrycnt) {
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]Activation Start!!\n");
+					odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+					odm_set_bb_reg(dm, 0x88c, BIT(20)|BIT(21), 0x3);
+					odm_set_rf_reg(dm, RF_PATH_A, 0x58, 0x2, 0x1);
+					/*PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]RF mode before set = %x\n", odm_get_rf_reg(dm, ODM_RF_PATH_A, 0x0, RFREGOFFSETMASK));*/
+					odm_set_rf_reg(dm, RF_PATH_A, 0x0, 0xf001f, 0x2001f);
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]set RF 0x0 = %x\n", odm_get_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK));
+					ODM_delay_ms(200);
+					odm_set_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK, rf_mode);
+					odm_set_rf_reg(dm, RF_PATH_A, 0x58, 0x2, 0x0);
+					odm_set_bb_reg(dm, 0x88c, BIT(20)|BIT(21), 0x0);
+					ODM_delay_ms(100);
+					i = 1;
+					j++;
+					break;
+
+					} else {
+						PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]Activation fail!!!\n");
+						goout = TRUE;
+						break;
+					}
+				} else {
+					PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]No need Activation!!!\n");
+					goout = TRUE;
+					break;
+				}
+
+		}
+	} while (!goout);
+
+		odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x01007C00);
+		odm_set_bb_reg(dm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_DBG_LP_RX2, 0x00800, 0x0);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);
+		odm_set_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK, rf_mode);
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]Reload RF mode = 0x%x\n", odm_get_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK));
+
+		_phy_reload_adda_registers8188f(dm, ADDA_REG, dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
+		_phy_reload_mac_registers8188f(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
+		_phy_reload_adda_registers8188f(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
+
+		PHYDM_DBG(dm, ODM_COMP_CALIBRATION, "[Act_Large_PWR]Activation process finish!!!\n");
+
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/rtl8188f/halrf_8188f.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/rtl8188f/halrf_8188f.h
new file mode 100644
index 000000000000..890ed3ce15dd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/halrf/rtl8188f/halrf_8188f.h
@@ -0,0 +1,107 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PHY_RF_8188F_H__
+#define __HAL_PHY_RF_8188F_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define	IQK_DELAY_TIME_8188F		25		/* ms */
+#define	IQK_DEFERRED_TIME_8188F		4
+#define	index_mapping_NUM_8188F		15
+#define	AVG_THERMAL_NUM_8188F		4
+#define	RF_T_METER_8188F			0x42
+
+
+void configure_txpower_track_8188f(
+	struct txpwrtrack_cfg	*config
+);
+
+void do_iqk_8188f(
+	void		*dm_void,
+	u8		delta_thermal_index,
+	u8		thermal_value,
+	u8		threshold
+);
+
+void
+odm_tx_pwr_track_set_pwr_8188f(
+	void		*dm_void,
+	enum pwrtrack_method	method,
+	u8				rf_path,
+	u8				channel_mapped_index
+);
+
+/* 1 7.	IQK */
+
+void
+phy_iq_calibrate_8188f(
+	void		*dm_void,
+	boolean	is_recovery);
+
+
+/*
+ * LC calibrate
+ *   */
+void
+phy_lc_calibrate_8188f(
+	void		*dm_void
+);
+
+
+void
+_phy_save_adda_registers_8188f(
+	struct dm_struct		*dm,
+	u32		*adda_reg,
+	u32		*adda_backup,
+	u32		register_num
+);
+
+void
+_phy_path_adda_on_8188f(
+	struct dm_struct		*dm,
+	u32		*adda_reg,
+	boolean		is_path_a_on,
+	boolean		is2T
+);
+
+void
+_phy_mac_setting_calibration_8188f(
+	struct dm_struct		*dm,
+	u32		*mac_reg,
+	u32		*mac_backup
+);
+
+
+void
+_phy_path_a_stand_by_8188f(
+	struct dm_struct		*dm
+);
+
+void phy_set_rf_path_switch_8188f(
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+	struct dm_struct *dm,
+#else
+	void *adapter,
+#endif
+	boolean is_main
+);
+
+void phy_active_large_power_detection_8188f(
+	struct dm_struct		*dm
+);
+
+
+#endif	/*  #ifndef __HAL_PHY_RF_8188E_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/mp_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/mp_precomp.h
index 2ae81105aaa6..34208ac03b43 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/mp_precomp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/mp_precomp.h
@@ -1,20 +1,25 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.c
index 1f3774b2d8f4..65baba9a39b8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.c
@@ -1,2162 +1,3093 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-const u2Byte dB_Invert_Table[12][8] = {
-	{	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}
-};
-
-
-//============================================================
-// Local Function predefine.
-//============================================================
-
-/* START------------COMMON INFO RELATED--------------- */
-
-VOID
-odm_GlobalAdapterCheck(
-	IN		VOID
-	);
-
-//move to odm_PowerTacking.h by YuChen
-
-
-
-VOID
-odm_UpdatePowerTrainingState(
-	IN	PDM_ODM_T	pDM_Odm
-);
-
-//============================================================
-//3 Export Interface
-//============================================================
-
-/*Y = 10*log(X)*/
-s4Byte
-ODM_PWdB_Conversion(
-	IN  s4Byte X,
-	IN  u4Byte TotalBit,
-	IN  u4Byte DecimalBit
-	)
-{
-	s4Byte Y, integer = 0, decimal = 0;
-	u4Byte i;
-
-	if(X == 0)
-		X = 1; // log2(x), x can't be 0
-
-	for(i = (TotalBit-1); i > 0; i--)
-	{
-		if(X & BIT(i))
-		{
-			integer = i;
-			if(i > 0)
-				decimal = (X & BIT(i-1))?2:0; //decimal is 0.5dB*3=1.5dB~=2dB 
-			break;
-		}
-	}
-	
-	Y = 3*(integer-DecimalBit)+decimal; //10*log(x)=3*log2(x), 
-
-	return Y;
-}
-
-s4Byte
-ODM_SignConversion(
-    IN  s4Byte value,
-    IN  u4Byte TotalBit
-    )
-{
-	if(value&BIT(TotalBit-1))
-		value -= BIT(TotalBit);
-	return value;
-}
-
-VOID
-ODM_InitMpDriverStatus(
-	IN		PDM_ODM_T		pDM_Odm
-)
-{
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
-	// Decide when compile time
-	#if(MP_DRIVER == 1)
-	pDM_Odm->mp_mode = TRUE;
-	#else
-	pDM_Odm->mp_mode = FALSE;
-	#endif
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-	PADAPTER	Adapter =  pDM_Odm->Adapter;
-
-	// Update information every period
-	pDM_Odm->mp_mode = (BOOLEAN)Adapter->registrypriv.mp_mode;
-
-#else
-
-	// MP mode is always false at AP side
-	pDM_Odm->mp_mode = FALSE;
-
-#endif
-}
-
-VOID
-ODM_UpdateMpDriverStatus(
-	IN		PDM_ODM_T		pDM_Odm
-)
-{
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
-	// Do nothing.
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER	Adapter =  pDM_Odm->Adapter;
-
-	// Update information erery period
-	pDM_Odm->mp_mode = (BOOLEAN)Adapter->registrypriv.mp_mode;
-
-#else
-
-	// Do nothing.
-
-#endif
-}
-
-VOID
-PHYDM_InitTRXAntennaSetting(
-	IN		PDM_ODM_T		pDM_Odm
-)
-{
-#if (RTL8814A_SUPPORT == 1)
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8814A)) {
-		u1Byte	RxAnt = 0, TxAnt = 0;
-
-		RxAnt = (u1Byte)ODM_GetBBReg(pDM_Odm, ODM_REG(BB_RX_PATH, pDM_Odm), ODM_BIT(BB_RX_PATH, pDM_Odm));
-		TxAnt = (u1Byte)ODM_GetBBReg(pDM_Odm, ODM_REG(BB_TX_PATH, pDM_Odm), ODM_BIT(BB_TX_PATH, pDM_Odm));
-		pDM_Odm->TXAntStatus =  (TxAnt & 0xf);
-		pDM_Odm->RXAntStatus =  (RxAnt & 0xf);
-	}
-#endif
-}
-
-VOID
-phydm_Init_cck_setting(
-	IN		PDM_ODM_T		pDM_Odm
-)
-{
-	u4Byte value_824,value_82c;
-
-	pDM_Odm->bCckHighPower = (BOOLEAN) ODM_GetBBReg(pDM_Odm, ODM_REG(CCK_RPT_FORMAT,pDM_Odm), ODM_BIT(CCK_RPT_FORMAT,pDM_Odm));
-
-	#if (RTL8192E_SUPPORT == 1)
-	if(pDM_Odm->SupportICType & (ODM_RTL8192E))
-	{
-		/* 0x824[9] = 0x82C[9] = 0xA80[7]  these regiaters settinh should be equal or CCK RSSI report may inaccurate */
-		value_824 = ODM_GetBBReg(pDM_Odm, 0x824, BIT9);
-		value_82c = ODM_GetBBReg(pDM_Odm, 0x82c, BIT9);
-		
-		if(value_824 != value_82c)
-		{
-			ODM_SetBBReg(pDM_Odm, 0x82c , BIT9, value_824);
-		}
-		ODM_SetBBReg(pDM_Odm, 0xa80 , BIT7, value_824);
-		pDM_Odm->cck_agc_report_type = (BOOLEAN)value_824;
-	}
-	#endif
-	
-	#if (RTL8703B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType & (ODM_RTL8703B)) {
-
-		pDM_Odm->cck_agc_report_type = ODM_GetBBReg(pDM_Odm, 0x950, BIT11) ? 1 : 0; /*1: 4bit LNA , 0: 3bit LNA */
-		
-		if (pDM_Odm->cck_agc_report_type != 1) {
-			DbgPrint("[Warning] 8703B CCK should be 4bit LNA, ie. 0x950[11] = 1\n");
-			/**/
-		}
-	}
-	#endif
-	
-}
-
-u1Byte DummyHubUsbMode = 1;/* USB 2.0 */
-void	phydm_hook_dummy_member(
-	IN	PDM_ODM_T		pDM_Odm
-	)
-{
-	if (pDM_Odm->HubUsbMode == NULL)
-		pDM_Odm->HubUsbMode = &DummyHubUsbMode;
-}
-
-
-VOID
-odm_CommonInfoSelfInit(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-	phydm_Init_cck_setting(pDM_Odm);
-	pDM_Odm->RFPathRxEnable = (u1Byte) ODM_GetBBReg(pDM_Odm, ODM_REG(BB_RX_PATH,pDM_Odm), ODM_BIT(BB_RX_PATH,pDM_Odm));
-#if (DM_ODM_SUPPORT_TYPE != ODM_CE)	
-	pDM_Odm->pbNet_closed = &pDM_Odm->BOOLEAN_temp;
-#endif
-
-	PHYDM_InitDebugSetting(pDM_Odm);
-	ODM_InitMpDriverStatus(pDM_Odm);
-	PHYDM_InitTRXAntennaSetting(pDM_Odm);
-
-	pDM_Odm->TxRate = 0xFF;
-
-	pDM_Odm->number_linked_client = 0;
-	pDM_Odm->pre_number_linked_client = 0;
-	pDM_Odm->number_active_client = 0;
-	pDM_Odm->pre_number_active_client = 0;
-	phydm_hook_dummy_member(pDM_Odm);
-	
-}
-
-VOID
-odm_CommonInfoSelfUpdate(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-	u1Byte	EntryCnt = 0, num_active_client = 0;
-	u4Byte	i, OneEntry_MACID = 0, ma_rx_tp = 0;
-	PSTA_INFO_T   	pEntry;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-	PADAPTER	Adapter =  pDM_Odm->Adapter;
-	PMGNT_INFO	pMgntInfo = &Adapter->MgntInfo;
-
-	pEntry = pDM_Odm->pODM_StaInfo[0];
-	if(pMgntInfo->mAssoc)
-	{
-		pEntry->bUsed=TRUE;
-		for (i=0; i<6; i++)
-			pEntry->MacAddr[i] = pMgntInfo->Bssid[i];
-	}
-	else
-	{
-		pEntry->bUsed=FALSE;
-		for (i=0; i<6; i++)
-			pEntry->MacAddr[i] = 0;
-	}
-
-	//STA mode is linked to AP
-	if(IS_STA_VALID(pDM_Odm->pODM_StaInfo[0]) && !ACTING_AS_AP(Adapter))
-		pDM_Odm->bsta_state = TRUE;
-	else
-		pDM_Odm->bsta_state = FALSE;
-#endif
-
-/* THis variable cannot be used because it is wrong*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if (*(pDM_Odm->pBandWidth) == ODM_BW40M)
-	{
-		if (*(pDM_Odm->pSecChOffset) == 1)
-			pDM_Odm->ControlChannel = *(pDM_Odm->pChannel) + 2;
-		else if (*(pDM_Odm->pSecChOffset) == 2)
-			pDM_Odm->ControlChannel = *(pDM_Odm->pChannel) - 2;
-	} else if (*(pDM_Odm->pBandWidth) == ODM_BW80M)	{
-		if (*(pDM_Odm->pSecChOffset) == 1)
-			pDM_Odm->ControlChannel = *(pDM_Odm->pChannel) + 6;
-		else if (*(pDM_Odm->pSecChOffset) == 2)
-			pDM_Odm->ControlChannel = *(pDM_Odm->pChannel) - 6;
-	} else
-		pDM_Odm->ControlChannel = *(pDM_Odm->pChannel);
-#else
-	if (*(pDM_Odm->pBandWidth) == ODM_BW40M) {
-		if (*(pDM_Odm->pSecChOffset) == 1)
-			pDM_Odm->ControlChannel = *(pDM_Odm->pChannel) - 2;
-		else if (*(pDM_Odm->pSecChOffset) == 2)
-			pDM_Odm->ControlChannel = *(pDM_Odm->pChannel) + 2;
-	} else
-		pDM_Odm->ControlChannel = *(pDM_Odm->pChannel);
-#endif
-
-	for (i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-	{
-		pEntry = pDM_Odm->pODM_StaInfo[i];
-		if(IS_STA_VALID(pEntry))
-		{
-			EntryCnt++;
-			if(EntryCnt==1)
-			{
-				OneEntry_MACID=i;
-			}
-
-			#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-				ma_rx_tp =  (pEntry->rx_byte_cnt_LowMAW)<<3; /*  low moving average RX  TP   ( bit /sec)*/
-
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("ClientTP[%d]: ((%d )) bit/sec\n", i, ma_rx_tp));
-				
-				if (ma_rx_tp > ACTIVE_TP_THRESHOLD)
-					num_active_client++;
-			#endif
-                }
-	}
-	
-	if(EntryCnt == 1)
-	{
-		pDM_Odm->bOneEntryOnly = TRUE;
-		pDM_Odm->OneEntry_MACID=OneEntry_MACID;
-	}
-	else
-		pDM_Odm->bOneEntryOnly = FALSE;
-
-	pDM_Odm->pre_number_linked_client = pDM_Odm->number_linked_client;
-	pDM_Odm->pre_number_active_client = pDM_Odm->number_active_client;
-	
-	pDM_Odm->number_linked_client = EntryCnt;
-	pDM_Odm->number_active_client = num_active_client;	
-
-	/* Update MP driver status*/
-	ODM_UpdateMpDriverStatus(pDM_Odm);
-}
-
-VOID
-odm_CommonInfoSelfReset(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	pDM_Odm->PhyDbgInfo.NumQryBeaconPkt = 0;
-#endif
-}
-
-PVOID
-PhyDM_Get_Structure(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		u1Byte			Structure_Type
-)
-
-{
-	PVOID	pStruct = NULL;
-#if RTL8195A_SUPPORT
-	switch (Structure_Type){
-		case	PHYDM_FALSEALMCNT:
-			pStruct = &FalseAlmCnt;
-		break;
-		
-		case	PHYDM_CFOTRACK:
-			pStruct = &DM_CfoTrack;
-		break;
-
-		case	PHYDM_ADAPTIVITY:
-			pStruct = &(pDM_Odm->Adaptivity);
-		break;
-		
-		default:
-		break;
-	}
-
-#else
-	switch (Structure_Type){
-		case	PHYDM_FALSEALMCNT:
-			pStruct = &(pDM_Odm->FalseAlmCnt);
-		break;
-		
-		case	PHYDM_CFOTRACK:
-			pStruct = &(pDM_Odm->DM_CfoTrack);
-		break;
-
-		case	PHYDM_ADAPTIVITY:
-			pStruct = &(pDM_Odm->Adaptivity);
-		break;
-		
-		default:
-		break;
-	}
-
-#endif
-	return	pStruct;
-}
-
-VOID
-odm_HWSetting(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-#if (RTL8821A_SUPPORT == 1)
-	if(pDM_Odm->SupportICType & ODM_RTL8821)
-		odm_HWSetting_8821A(pDM_Odm);
-#endif
-
-}
-
-//
-// 2011/09/21 MH Add to describe different team necessary resource allocate??
-//
-VOID
-ODM_DMInit(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-	odm_CommonInfoSelfInit(pDM_Odm);
-	odm_DIGInit(pDM_Odm);
-	Phydm_NHMCounterStatisticsInit(pDM_Odm);
-	Phydm_AdaptivityInit(pDM_Odm);
-	phydm_ra_info_init(pDM_Odm);
-	odm_RateAdaptiveMaskInit(pDM_Odm);
-	odm_RA_ParaAdjust_init(pDM_Odm);
-	ODM_CfoTrackingInit(pDM_Odm);
-	ODM_EdcaTurboInit(pDM_Odm);
-	odm_RSSIMonitorInit(pDM_Odm);
-	phydm_rf_init(pDM_Odm);
-	odm_TXPowerTrackingInit(pDM_Odm);
-	odm_AntennaDiversityInit(pDM_Odm);
-	odm_AutoChannelSelectInit(pDM_Odm);
-	odm_PathDiversityInit(pDM_Odm);
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	phydm_Beamforming_Init(pDM_Odm);
-#endif	
-
-	if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-	{
-		odm_DynamicBBPowerSavingInit(pDM_Odm);
-		odm_DynamicTxPowerInit(pDM_Odm);
-
-#if (RTL8188E_SUPPORT == 1)
-		if(pDM_Odm->SupportICType==ODM_RTL8188E)
-		{
-			odm_PrimaryCCA_Init(pDM_Odm);
-			ODM_RAInfo_Init_all(pDM_Odm);
-		}
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	
-	#if (RTL8723B_SUPPORT == 1)
-		if(pDM_Odm->SupportICType == ODM_RTL8723B)
-			odm_SwAntDetectInit(pDM_Odm);
-	#endif
-
-	#if (RTL8192E_SUPPORT == 1)
-		if(pDM_Odm->SupportICType==ODM_RTL8192E)
-			odm_PrimaryCCA_Check_Init(pDM_Odm);
-	#endif
-
-#endif
-
-	}
-
-}
-
-VOID
-ODM_DMReset(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-	pDIG_T pDM_DigTable = &pDM_Odm->DM_DigTable;
-	
-	ODM_AntDivReset(pDM_Odm);	
-	phydm_setEDCCAThresholdAPI(pDM_Odm, pDM_DigTable->CurIGValue);
-}
-
-
-VOID
-phydm_support_ablity_debug(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value,
-	IN		u4Byte			*_used,
-	OUT		char			*output,
-	IN		u4Byte			*_out_len
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			pre_support_ability;
-	u4Byte used = *_used;
-	u4Byte out_len = *_out_len;
-
-	pre_support_ability = pDM_Odm->SupportAbility ;	
-	PHYDM_SNPRINTF((output+used, out_len-used,"\n%s\n", "================================"));
-	if(dm_value[0] == 100)
-	{
-		PHYDM_SNPRINTF((output+used, out_len-used, "[Supportablity] PhyDM Selection\n"));
-		PHYDM_SNPRINTF((output+used, out_len-used,"%s\n", "================================"));
-		PHYDM_SNPRINTF((output+used, out_len-used, "00. (( %s ))DIG  \n", ((pDM_Odm->SupportAbility & ODM_BB_DIG)?("V"):(".")) ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "01. (( %s ))RA_MASK  \n", ((pDM_Odm->SupportAbility & ODM_BB_RA_MASK)?("V"):(".")) ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "02. (( %s ))DYNAMIC_TXPWR  \n", ((pDM_Odm->SupportAbility & ODM_BB_DYNAMIC_TXPWR)?("V"):("."))   ));		
-		PHYDM_SNPRINTF((output+used, out_len-used, "03. (( %s ))FA_CNT  \n", ((pDM_Odm->SupportAbility & ODM_BB_FA_CNT)?("V"):("."))  ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "04. (( %s ))RSSI_MONITOR  \n", ((pDM_Odm->SupportAbility & ODM_BB_RSSI_MONITOR)?("V"):("."))   ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "05. (( %s ))CCK_PD  \n", ((pDM_Odm->SupportAbility & ODM_BB_CCK_PD)?("V"):("."))   ));	
-		PHYDM_SNPRINTF((output+used, out_len-used, "06. (( %s ))ANT_DIV  \n", ((pDM_Odm->SupportAbility & ODM_BB_ANT_DIV)?("V"):("."))  ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "07. (( %s ))PWR_SAVE  \n", ((pDM_Odm->SupportAbility & ODM_BB_PWR_SAVE)?("V"):("."))  ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "08. (( %s ))PWR_TRAIN  \n", ((pDM_Odm->SupportAbility & ODM_BB_PWR_TRAIN)?("V"):("."))   ));	
-		PHYDM_SNPRINTF((output+used, out_len-used, "09. (( %s ))RATE_ADAPTIVE  \n", ((pDM_Odm->SupportAbility & ODM_BB_RATE_ADAPTIVE)?("V"):("."))   ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "10. (( %s ))PATH_DIV  \n", ((pDM_Odm->SupportAbility & ODM_BB_PATH_DIV)?("V"):("."))));
-		PHYDM_SNPRINTF((output+used, out_len-used, "11. (( %s ))PSD  \n", ((pDM_Odm->SupportAbility & ODM_BB_PSD)?("V"):(".")) ));	
-		PHYDM_SNPRINTF((output+used, out_len-used, "12. (( %s ))RXHP  \n", ((pDM_Odm->SupportAbility & ODM_BB_RXHP)?("V"):("."))   ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "13. (( %s ))ADAPTIVITY  \n", ((pDM_Odm->SupportAbility & ODM_BB_ADAPTIVITY)?("V"):(".")) ));	
-		PHYDM_SNPRINTF((output+used, out_len-used, "14. (( %s ))CFO_TRACKING  \n", ((pDM_Odm->SupportAbility & ODM_BB_CFO_TRACKING)?("V"):(".")) ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "15. (( %s ))NHM_CNT  \n", ((pDM_Odm->SupportAbility & ODM_BB_NHM_CNT)?("V"):("."))  ));	
-		PHYDM_SNPRINTF((output+used, out_len-used, "16. (( %s ))PRIMARY_CCA  \n", ((pDM_Odm->SupportAbility & ODM_BB_PRIMARY_CCA)?("V"):(".")) ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "20. (( %s ))EDCA_TURBO  \n", ((pDM_Odm->SupportAbility & ODM_MAC_EDCA_TURBO)?("V"):("."))  ));	
-		PHYDM_SNPRINTF((output+used, out_len-used, "21. (( %s ))EARLY_MODE  \n", ((pDM_Odm->SupportAbility & ODM_MAC_EARLY_MODE)?("V"):(".")) ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "24. (( %s ))TX_PWR_TRACK  \n", ((pDM_Odm->SupportAbility & ODM_RF_TX_PWR_TRACK)?("V"):("."))  ));	
-		PHYDM_SNPRINTF((output+used, out_len-used, "25. (( %s ))RX_GAIN_TRACK  \n", ((pDM_Odm->SupportAbility & ODM_RF_RX_GAIN_TRACK)?("V"):("."))  ));
-		PHYDM_SNPRINTF((output+used, out_len-used, "26. (( %s ))RF_CALIBRATION  \n", ((pDM_Odm->SupportAbility & ODM_RF_CALIBRATION)?("V"):("."))   ));
-		PHYDM_SNPRINTF((output+used, out_len-used,"%s\n", "================================"));
-	}
-	/*
-	else if(dm_value[0] == 101)
-	{
-		pDM_Odm->SupportAbility = 0 ;
-		DbgPrint("Disable all SupportAbility components \n");
-		PHYDM_SNPRINTF((output+used, out_len-used,"%s\n", "Disable all SupportAbility components"));	
-	}
-	*/
-	else
-	{
-
-		if(dm_value[1] == 1) //enable
-		{
-			pDM_Odm->SupportAbility |= BIT(dm_value[0]) ;
-			if(BIT(dm_value[0]) & ODM_BB_PATH_DIV)
-			{
-				odm_PathDiversityInit(pDM_Odm);
-			}
-		}
-		else if(dm_value[1] == 2) //disable
-		{
-			pDM_Odm->SupportAbility &= ~(BIT(dm_value[0])) ;
-		}
-		else
-		{
-			//DbgPrint("\n[Warning!!!]  1:enable,  2:disable \n\n");
-			PHYDM_SNPRINTF((output+used, out_len-used,"%s\n", "[Warning!!!]  1:enable,  2:disable"));
-		}
-	}
-	PHYDM_SNPRINTF((output+used, out_len-used,"pre-SupportAbility  =  0x%x\n",  pre_support_ability ));	
-	PHYDM_SNPRINTF((output+used, out_len-used,"Curr-SupportAbility =  0x%x\n", pDM_Odm->SupportAbility ));
-	PHYDM_SNPRINTF((output+used, out_len-used,"%s\n", "================================"));
-}
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-//
-//tmp modify for LC Only
-//
-VOID
-ODM_DMWatchdog_LPS(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{	
-	odm_CommonInfoSelfUpdate(pDM_Odm);
-	odm_FalseAlarmCounterStatistics(pDM_Odm);
-	odm_RSSIMonitorCheck(pDM_Odm);
-	odm_DIGbyRSSI_LPS(pDM_Odm);	
-	odm_CCKPacketDetectionThresh(pDM_Odm);
-	odm_CommonInfoSelfReset(pDM_Odm);
-
-	if(*(pDM_Odm->pbPowerSaving)==TRUE)
-		return;
-}
-#endif
-//
-// 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_DMWatchdog(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-	odm_CommonInfoSelfUpdate(pDM_Odm);
-	phydm_BasicDbgMessage(pDM_Odm);
-	odm_HWSetting(pDM_Odm);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	{
-	prtl8192cd_priv priv		= pDM_Odm->priv;
-	if( (priv->auto_channel != 0) && (priv->auto_channel != 2) )//if ACS running, do not do FA/CCA counter read
-		return;
-	}
-#endif	
-	odm_FalseAlarmCounterStatistics(pDM_Odm);
-	phydm_NoisyDetection(pDM_Odm);
-	
-	odm_RSSIMonitorCheck(pDM_Odm);
-
-	if(*(pDM_Odm->pbPowerSaving) == TRUE)
-	{
-		odm_DIGbyRSSI_LPS(pDM_Odm);
-		{
-			pDIG_T	pDM_DigTable = &pDM_Odm->DM_DigTable;
-			Phydm_Adaptivity(pDM_Odm, pDM_DigTable->CurIGValue);
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD, ("DMWatchdog in power saving mode\n"));
-		return;
-	}
-	
-	Phydm_CheckAdaptivity(pDM_Odm);
-	odm_UpdatePowerTrainingState(pDM_Odm);
-	odm_DIG(pDM_Odm);
-	{
-		pDIG_T	pDM_DigTable = &pDM_Odm->DM_DigTable;
-		Phydm_Adaptivity(pDM_Odm, pDM_DigTable->CurIGValue);
-	}
-	odm_CCKPacketDetectionThresh(pDM_Odm);
-	phydm_ra_dynamic_retry_limit(pDM_Odm);
-	phydm_ra_dynamic_retry_count(pDM_Odm);
-	odm_RefreshRateAdaptiveMask(pDM_Odm);
-	odm_RefreshBasicRateMask(pDM_Odm);
-	odm_DynamicBBPowerSaving(pDM_Odm);
-	odm_EdcaTurboCheck(pDM_Odm);
-	odm_PathDiversity(pDM_Odm);
-	ODM_CfoTracking(pDM_Odm);
-	odm_DynamicTxPower(pDM_Odm);
-	odm_AntennaDiversity(pDM_Odm);
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	phydm_Beamforming_Watchdog(pDM_Odm);
-#endif
-
-	phydm_rf_watchdog(pDM_Odm);
-
-	if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-	{
-	        
-#if (RTL8188E_SUPPORT == 1)
-	        if(pDM_Odm->SupportICType==ODM_RTL8188E)
-	                odm_DynamicPrimaryCCA(pDM_Odm);	
-#endif
-
-#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-
-	#if (RTL8192E_SUPPORT == 1)
-		if(pDM_Odm->SupportICType==ODM_RTL8192E)
-			odm_DynamicPrimaryCCA_Check(pDM_Odm); 
-	#endif
-#endif
-	}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	odm_dtc(pDM_Odm);
-#endif
-
-	odm_CommonInfoSelfReset(pDM_Odm);
-	
-}
-
-
-//
-// Init /.. Fixed HW value. Only init time.
-//
-VOID
-ODM_CmnInfoInit(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		ODM_CMNINFO_E	CmnInfo,
-	IN		u4Byte			Value	
-	)
-{
-	//
-	// This section is used for init value
-	//
-	switch	(CmnInfo)
-	{
-		//
-		// Fixed ODM value.
-		//
-		case	ODM_CMNINFO_ABILITY:
-			pDM_Odm->SupportAbility = (u4Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_RF_TYPE:
-			pDM_Odm->RFType = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_PLATFORM:
-			pDM_Odm->SupportPlatform = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_INTERFACE:
-			pDM_Odm->SupportInterface = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_MP_TEST_CHIP:
-			pDM_Odm->bIsMPChip= (u1Byte)Value;
-			break;
-            
-		case	ODM_CMNINFO_IC_TYPE:
-			pDM_Odm->SupportICType = Value;
-			break;
-
-		case	ODM_CMNINFO_CUT_VER:
-			pDM_Odm->CutVersion = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_FAB_VER:
-			pDM_Odm->FabVersion = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_RFE_TYPE:
-			pDM_Odm->RFEType = (u1Byte)Value;
-			break;
-
-		case    ODM_CMNINFO_RF_ANTENNA_TYPE:
-			pDM_Odm->AntDivType= (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_BOARD_TYPE:
-			pDM_Odm->BoardType = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_PACKAGE_TYPE:
-			pDM_Odm->PackageType = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_EXT_LNA:
-			pDM_Odm->ExtLNA = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_5G_EXT_LNA:
-			pDM_Odm->ExtLNA5G = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_EXT_PA:
-			pDM_Odm->ExtPA = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_5G_EXT_PA:
-			pDM_Odm->ExtPA5G = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_GPA:
-			pDM_Odm->TypeGPA = (u2Byte)Value;
-			break;
-		case	ODM_CMNINFO_APA:
-			pDM_Odm->TypeAPA = (u2Byte)Value;
-			break;
-		case	ODM_CMNINFO_GLNA:
-			pDM_Odm->TypeGLNA = (u2Byte)Value;
-			break;
-		case	ODM_CMNINFO_ALNA:
-			pDM_Odm->TypeALNA = (u2Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_EXT_TRSW:
-			pDM_Odm->ExtTRSW = (u1Byte)Value;
-			break;
-		case	ODM_CMNINFO_EXT_LNA_GAIN:
-			pDM_Odm->ExtLNAGain = (u1Byte)Value;
-			break;
-		case 	ODM_CMNINFO_PATCH_ID:
-			pDM_Odm->PatchID = (u1Byte)Value;
-			break;
-		case 	ODM_CMNINFO_BINHCT_TEST:
-			pDM_Odm->bInHctTest = (BOOLEAN)Value;
-			break;
-		case 	ODM_CMNINFO_BWIFI_TEST:
-			pDM_Odm->bWIFITest = (BOOLEAN)Value;
-			break;	
-		case	ODM_CMNINFO_SMART_CONCURRENT:
-			pDM_Odm->bDualMacSmartConcurrent = (BOOLEAN )Value;
-			break;
-		case	ODM_CMNINFO_DOMAIN_CODE_2G:
-			pDM_Odm->odm_Regulation2_4G = (u1Byte)Value;
-			break;
-		case	ODM_CMNINFO_DOMAIN_CODE_5G:
-			pDM_Odm->odm_Regulation5G = (u1Byte)Value;
-			break;
-		case	ODM_CMNINFO_CONFIG_BB_RF:
-			pDM_Odm->ConfigBBRF = (BOOLEAN)Value;
-			break;
-		case	ODM_CMNINFO_IQKFWOFFLOAD:
-			pDM_Odm->IQKFWOffload = (u1Byte)Value;
-			break;
-		//To remove the compiler warning, must add an empty default statement to handle the other values.	
-		default:
-			//do nothing
-			break;	
-		
-	}
-
-}
-
-
-VOID
-ODM_CmnInfoHook(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		ODM_CMNINFO_E	CmnInfo,
-	IN		PVOID			pValue	
-	)
-{
-	//
-	// Hook call by reference pointer.
-	//
-	switch	(CmnInfo)
-	{
-		//
-		// Dynamic call by reference pointer.
-		//
-		case	ODM_CMNINFO_MAC_PHY_MODE:
-			pDM_Odm->pMacPhyMode = (u1Byte *)pValue;
-			break;
-		
-		case	ODM_CMNINFO_TX_UNI:
-			pDM_Odm->pNumTxBytesUnicast = (u8Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_RX_UNI:
-			pDM_Odm->pNumRxBytesUnicast = (u8Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_WM_MODE:
-			pDM_Odm->pWirelessMode = (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_BAND:
-			pDM_Odm->pBandType = (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_SEC_CHNL_OFFSET:
-			pDM_Odm->pSecChOffset = (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_SEC_MODE:
-			pDM_Odm->pSecurity = (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_BW:
-			pDM_Odm->pBandWidth = (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_CHNL:
-			pDM_Odm->pChannel = (u1Byte *)pValue;
-			break;
-		
-		case	ODM_CMNINFO_DMSP_GET_VALUE:
-			pDM_Odm->pbGetValueFromOtherMac = (BOOLEAN *)pValue;
-			break;
-
-		case	ODM_CMNINFO_BUDDY_ADAPTOR:
-			pDM_Odm->pBuddyAdapter = (PADAPTER *)pValue;
-			break;
-
-		case	ODM_CMNINFO_DMSP_IS_MASTER:
-			pDM_Odm->pbMasterOfDMSP = (BOOLEAN *)pValue;
-			break;
-
-		case	ODM_CMNINFO_SCAN:
-			pDM_Odm->pbScanInProcess = (BOOLEAN *)pValue;
-			break;
-
-		case	ODM_CMNINFO_POWER_SAVING:
-			pDM_Odm->pbPowerSaving = (BOOLEAN *)pValue;
-			break;
-
-		case	ODM_CMNINFO_ONE_PATH_CCA:
-			pDM_Odm->pOnePathCCA = (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_DRV_STOP:
-			pDM_Odm->pbDriverStopped =  (BOOLEAN *)pValue;
-			break;
-
-		case	ODM_CMNINFO_PNP_IN:
-			pDM_Odm->pbDriverIsGoingToPnpSetPowerSleep =  (BOOLEAN *)pValue;
-			break;
-
-		case	ODM_CMNINFO_INIT_ON:
-			pDM_Odm->pinit_adpt_in_progress =  (BOOLEAN *)pValue;
-			break;
-
-		case	ODM_CMNINFO_ANT_TEST:
-			pDM_Odm->pAntennaTest =  (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_NET_CLOSED:
-			pDM_Odm->pbNet_closed = (BOOLEAN *)pValue;
-			break;
-
-		case 	ODM_CMNINFO_FORCED_RATE:
-			pDM_Odm->pForcedDataRate = (pu2Byte)pValue;
-			break;
-
-		case  ODM_CMNINFO_FORCED_IGI_LB:
-			pDM_Odm->pu1ForcedIgiLb = (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_P2P_LINK:
-			pDM_Odm->DM_DigTable.bP2PInProcess = (u1Byte *)pValue;
-			break;
-
-		case 	ODM_CMNINFO_IS1ANTENNA:
-			pDM_Odm->pIs1Antenna = (BOOLEAN *)pValue;
-			break;
-			
-		case 	ODM_CMNINFO_RFDEFAULTPATH:
-			pDM_Odm->pRFDefaultPath= (u1Byte *)pValue;
-			break;
-
-		case	ODM_CMNINFO_FCS_MODE:
-			pDM_Odm->pIsFcsModeEnable = (BOOLEAN *)pValue;
-			break;
-		/*add by YuChen for beamforming PhyDM*/
-		case	ODM_CMNINFO_HUBUSBMODE:
-			pDM_Odm->HubUsbMode = (u1Byte *)pValue;
-			break;
-		case	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS:
-			pDM_Odm->pbFwDwRsvdPageInProgress = (BOOLEAN *)pValue;
-			break;
-		case	ODM_CMNINFO_TX_TP:
-			pDM_Odm->pCurrentTxTP = (u4Byte *)pValue;
-			break;
-		case	ODM_CMNINFO_RX_TP:
-			pDM_Odm->pCurrentRxTP = (u4Byte *)pValue;
-			break;
-		case	ODM_CMNINFO_SOUNDING_SEQ:
-			pDM_Odm->pSoundingSeq = (u1Byte *)pValue;
-			break;
-		//case	ODM_CMNINFO_RTSTA_AID:
-		//	pDM_Odm->pAidMap =  (u1Byte *)pValue;
-		//	break;
-
-		//case	ODM_CMNINFO_BT_COEXIST:
-		//	pDM_Odm->BTCoexist = (BOOLEAN *)pValue;		
-
-		//case	ODM_CMNINFO_STA_STATUS:
-			//pDM_Odm->pODM_StaInfo[] = (PSTA_INFO_T)pValue;
-			//break;
-
-		//case	ODM_CMNINFO_PHY_STATUS:
-		//	pDM_Odm->pPhyInfo = (ODM_PHY_INFO *)pValue;
-		//	break;
-
-		//case	ODM_CMNINFO_MAC_STATUS:
-		//	pDM_Odm->pMacInfo = (ODM_MAC_INFO *)pValue;
-		//	break;
-		//To remove the compiler warning, must add an empty default statement to handle the other values.				
-		default:
-			//do nothing
-			break;
-
-	}
-
-}
-
-
-VOID
-ODM_CmnInfoPtrArrayHook(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		ODM_CMNINFO_E	CmnInfo,
-	IN		u2Byte			Index,
-	IN		PVOID			pValue	
-	)
-{
-	//
-	// Hook call by reference pointer.
-	//
-	switch	(CmnInfo)
-	{
-		//
-		// Dynamic call by reference pointer.
-		//		
-		case	ODM_CMNINFO_STA_STATUS:
-			pDM_Odm->pODM_StaInfo[Index] = (PSTA_INFO_T)pValue;
-			
-			if (IS_STA_VALID(pDM_Odm->pODM_StaInfo[Index]))
-			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-				pDM_Odm->platform2phydm_macid_table[((PSTA_INFO_T)pValue)->AssociatedMacId] = Index; /*AssociatedMacId are unique bttween different Adapter*/
-			#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-				pDM_Odm->platform2phydm_macid_table[((PSTA_INFO_T)pValue)->aid] = Index;
-			#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-				pDM_Odm->platform2phydm_macid_table[((PSTA_INFO_T)pValue)->mac_id] = Index;
-			#endif
-			
-			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_CmnInfoUpdate(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		u4Byte			CmnInfo,
-	IN		u8Byte			Value	
-	)
-{
-	//
-	// This init variable may be changed in run time.
-	//
-	switch	(CmnInfo)
-	{
-		case ODM_CMNINFO_LINK_IN_PROGRESS:
-			pDM_Odm->bLinkInProcess = (BOOLEAN)Value;
-			break;
-		
-		case	ODM_CMNINFO_ABILITY:
-			pDM_Odm->SupportAbility = (u4Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_RF_TYPE:
-			pDM_Odm->RFType = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_WIFI_DIRECT:
-			pDM_Odm->bWIFI_Direct = (BOOLEAN)Value;
-			break;
-
-		case	ODM_CMNINFO_WIFI_DISPLAY:
-			pDM_Odm->bWIFI_Display = (BOOLEAN)Value;
-			break;
-
-		case	ODM_CMNINFO_LINK:
-			pDM_Odm->bLinked = (BOOLEAN)Value;
-			break;
-
-		case	ODM_CMNINFO_STATION_STATE:
-			pDM_Odm->bsta_state = (BOOLEAN)Value;
-			break;
-			
-		case	ODM_CMNINFO_RSSI_MIN:
-			pDM_Odm->RSSI_Min= (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_DBG_COMP:
-			pDM_Odm->DebugComponents = Value;
-			break;
-
-		case	ODM_CMNINFO_DBG_LEVEL:
-			pDM_Odm->DebugLevel = (u4Byte)Value;
-			break;
-		case	ODM_CMNINFO_RA_THRESHOLD_HIGH:
-			pDM_Odm->RateAdaptive.HighRSSIThresh = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_RA_THRESHOLD_LOW:
-			pDM_Odm->RateAdaptive.LowRSSIThresh = (u1Byte)Value;
-			break;
-#if defined(BT_30_SUPPORT) && (BT_30_SUPPORT == 1)
-		// The following is for BT HS mode and BT coexist mechanism.
-		case ODM_CMNINFO_BT_ENABLED:
-			pDM_Odm->bBtEnabled = (BOOLEAN)Value;
-			break;
-			
-		case ODM_CMNINFO_BT_HS_CONNECT_PROCESS:
-			pDM_Odm->bBtConnectProcess = (BOOLEAN)Value;
-			break;
-		
-		case ODM_CMNINFO_BT_HS_RSSI:
-			pDM_Odm->btHsRssi = (u1Byte)Value;
-			break;
-			
-		case	ODM_CMNINFO_BT_OPERATION:
-			pDM_Odm->bBtHsOperation = (BOOLEAN)Value;
-			break;
-
-		case	ODM_CMNINFO_BT_LIMITED_DIG:
-			pDM_Odm->bBtLimitedDig = (BOOLEAN)Value;
-			break;	
-
-		case ODM_CMNINFO_BT_DIG:
-			pDM_Odm->btHsDigVal = (u1Byte)Value;
-			break;
-			
-		case	ODM_CMNINFO_BT_BUSY:
-			pDM_Odm->bBtBusy = (BOOLEAN)Value;
-			break;	
-
-		case	ODM_CMNINFO_BT_DISABLE_EDCA:
-			pDM_Odm->bBtDisableEdcaTurbo = (BOOLEAN)Value;
-			break;
-#endif
-
-#if(DM_ODM_SUPPORT_TYPE & ODM_AP)		// for repeater mode add by YuChen 2014.06.23
-#ifdef UNIVERSAL_REPEATER
-		case	ODM_CMNINFO_VXD_LINK:
-			pDM_Odm->VXD_bLinked= (BOOLEAN)Value;
-			break;
-#endif
-#endif
-
-		case	ODM_CMNINFO_AP_TOTAL_NUM:
-			pDM_Odm->APTotalNum = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_POWER_TRAINING:
-			pDM_Odm->bDisablePowerTraining = (BOOLEAN)Value;
-			break;
-
-/*
-		case	ODM_CMNINFO_OP_MODE:
-			pDM_Odm->OPMode = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_WM_MODE:
-			pDM_Odm->WirelessMode = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_BAND:
-			pDM_Odm->BandType = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_SEC_CHNL_OFFSET:
-			pDM_Odm->SecChOffset = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_SEC_MODE:
-			pDM_Odm->Security = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_BW:
-			pDM_Odm->BandWidth = (u1Byte)Value;
-			break;
-
-		case	ODM_CMNINFO_CHNL:
-			pDM_Odm->Channel = (u1Byte)Value;
-			break;			
-*/	
-                default:
-			//do nothing
-			break;
-	}
-
-	
-}
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-ODM_InitAllWorkItems(IN PDM_ODM_T	pDM_Odm )
-{
-
-	PADAPTER		pAdapter = pDM_Odm->Adapter;
-#if USE_WORKITEM
-	#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-	ODM_InitializeWorkItem(	pDM_Odm, 
-							&pDM_Odm->DM_SWAT_Table.phydm_SwAntennaSwitchWorkitem, 
-							(RT_WORKITEM_CALL_BACK)ODM_SW_AntDiv_WorkitemCallback,
-							(PVOID)pAdapter,
-							"AntennaSwitchWorkitem");
-	#endif
-	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-	ODM_InitializeWorkItem(pDM_Odm, 
-						&pDM_Odm->dm_sat_table.hl_smart_antenna_workitem, 
-						(RT_WORKITEM_CALL_BACK)phydm_beam_switch_workitem_callback,
-						(PVOID)pAdapter,
-						"hl_smart_ant_workitem");
-
-	ODM_InitializeWorkItem(pDM_Odm, 
-						&pDM_Odm->dm_sat_table.hl_smart_antenna_decision_workitem, 
-						(RT_WORKITEM_CALL_BACK)phydm_beam_decision_workitem_callback,
-						(PVOID)pAdapter,
-						"hl_smart_ant_decision_workitem");
-	#endif
-	
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->PathDivSwitchWorkitem), 
-		(RT_WORKITEM_CALL_BACK)odm_PathDivChkAntSwitchWorkitemCallback, 
-		(PVOID)pAdapter,
-		"SWAS_WorkItem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->CCKPathDiversityWorkitem), 
-		(RT_WORKITEM_CALL_BACK)odm_CCKTXPathDiversityWorkItemCallback, 
-		(PVOID)pAdapter,
-		"CCKTXPathDiversityWorkItem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->MPT_DIGWorkitem), 
-		(RT_WORKITEM_CALL_BACK)odm_MPT_DIGWorkItemCallback, 
-		(PVOID)pAdapter,
-		"MPT_DIGWorkitem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->RaRptWorkitem), 
-		(RT_WORKITEM_CALL_BACK)ODM_UpdateInitRateWorkItemCallback, 
-		(PVOID)pAdapter,
-		"RaRptWorkitem");
-
-#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->FastAntTrainingWorkitem), 
-		(RT_WORKITEM_CALL_BACK)odm_FastAntTrainingWorkItemCallback, 
-		(PVOID)pAdapter,
-		"FastAntTrainingWorkitem");
-#endif
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->DM_RXHP_Table.PSDTimeWorkitem), 
-		(RT_WORKITEM_CALL_BACK)odm_PSD_RXHPWorkitemCallback, 
-		(PVOID)pAdapter,
-		"PSDRXHP_WorkItem");
-
-#endif /*#if USE_WORKITEM*/
-
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_EnterWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_EnterWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_EnterWorkItem");
-	
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_LeaveWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_LeaveWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_LeaveWorkItem");
-	
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_FwNdpaWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_FwNdpaWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_FwNdpaWorkItem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_ClkWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_ClkWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_ClkWorkItem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_RateWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_RateWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_RateWorkItem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_StatusWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_StatusWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_StatusWorkItem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_ResetTxPathWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_ResetTxPathWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_ResetTxPathWorkItem");
-
-	ODM_InitializeWorkItem(
-		pDM_Odm,
-		&(pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_GetTxRateWorkItem),
-		(RT_WORKITEM_CALL_BACK)halComTxbf_GetTxRateWorkItemCallback,
-		(PVOID)pAdapter,
-		"Txbf_GetTxRateWorkItem");
-#endif
-}
-
-VOID
-ODM_FreeAllWorkItems(IN PDM_ODM_T	pDM_Odm )
-{
-#if USE_WORKITEM
-
-#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-	ODM_FreeWorkItem(&(pDM_Odm->DM_SWAT_Table.phydm_SwAntennaSwitchWorkitem));
-#endif
-
-#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-	ODM_FreeWorkItem(&(pDM_Odm->dm_sat_table.hl_smart_antenna_workitem));
-	ODM_FreeWorkItem(&(pDM_Odm->dm_sat_table.hl_smart_antenna_decision_workitem));
-#endif
-
-	ODM_FreeWorkItem(&(pDM_Odm->PathDivSwitchWorkitem));      
-	ODM_FreeWorkItem(&(pDM_Odm->CCKPathDiversityWorkitem));
-#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-	ODM_FreeWorkItem(&(pDM_Odm->FastAntTrainingWorkitem));
-#endif
-	ODM_FreeWorkItem(&(pDM_Odm->MPT_DIGWorkitem));
-	ODM_FreeWorkItem(&(pDM_Odm->RaRptWorkitem));
-	ODM_FreeWorkItem((&pDM_Odm->DM_RXHP_Table.PSDTimeWorkitem));
-	/*ODM_FreeWorkItem((&pDM_Odm->sbdcnt_workitem));*/
-#endif
-
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_EnterWorkItem));
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_LeaveWorkItem));
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_FwNdpaWorkItem));
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_ClkWorkItem));
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_RateWorkItem));
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_StatusWorkItem));
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_ResetTxPathWorkItem));
-	ODM_FreeWorkItem((&pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_GetTxRateWorkItem));
-#endif
-
-}
-#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
-
-/*
-VOID
-odm_FindMinimumRSSI(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-	u4Byte	i;
-	u1Byte	RSSI_Min = 0xFF;
-
-	for(i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-	{
-//		if(pDM_Odm->pODM_StaInfo[i] != NULL)
-		if(IS_STA_VALID(pDM_Odm->pODM_StaInfo[i]) )
-		{
-			if(pDM_Odm->pODM_StaInfo[i]->RSSI_Ave < RSSI_Min)
-			{
-				RSSI_Min = pDM_Odm->pODM_StaInfo[i]->RSSI_Ave;
-			}
-		}
-	}
-
-	pDM_Odm->RSSI_Min = RSSI_Min;
-
-}
-
-VOID
-odm_IsLinked(
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-	u4Byte i;
-	BOOLEAN Linked = FALSE;
-	
-	for(i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-	{
-			if(IS_STA_VALID(pDM_Odm->pODM_StaInfo[i]) )
-			{			
-				Linked = TRUE;
-				break;
-			}
-		
-	}
-
-	pDM_Odm->bLinked = Linked;
-}
-*/
-
-VOID
-ODM_InitAllTimers(
-	IN PDM_ODM_T	pDM_Odm 
-	)
-{
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	ODM_AntDivTimers(pDM_Odm,INIT_ANTDIV_TIMMER);
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-#ifdef MP_TEST
-	if (pDM_Odm->priv->pshare->rf_ft_var.mp_specific) 
-		ODM_InitializeTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer, 
-			(RT_TIMER_CALL_BACK)odm_MPT_DIGCallback, NULL, "MPT_DIGTimer");	
-#endif
-#elif(DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer, 
-		(RT_TIMER_CALL_BACK)odm_MPT_DIGCallback, NULL, "MPT_DIGTimer");
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->PSDTimer, 
-		(RT_TIMER_CALL_BACK)dm_PSDMonitorCallback, NULL, "PSDTimer");
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 
-		(RT_TIMER_CALL_BACK)odm_PathDivChkAntSwitchCallback, NULL, "PathDivTimer");
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->CCKPathDiversityTimer, 
-		(RT_TIMER_CALL_BACK)odm_CCKTXPathDiversityCallback, NULL, "CCKPathDiversityTimer");
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->DM_RXHP_Table.PSDTimer,
-		(RT_TIMER_CALL_BACK)odm_PSD_RXHPCallback, NULL, "PSDRXHPTimer"); 
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->sbdcnt_timer,
-		(RT_TIMER_CALL_BACK)phydm_sbd_callback, NULL, "SbdTimer"); 
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_FwNdpaTimer,
-		(RT_TIMER_CALL_BACK)halComTxbf_FwNdpaTimerCallback, NULL, "Txbf_FwNdpaTimer");
-#endif
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_InitializeTimer(pDM_Odm, &pDM_Odm->BeamformingInfo.BeamformingTimer,
-		(RT_TIMER_CALL_BACK)Beamforming_SWTimerCallback, NULL, "BeamformingTimer");
-#endif
-#endif
-}
-
-VOID
-ODM_CancelAllTimers(
-	IN PDM_ODM_T	pDM_Odm 
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	//
-	// 2012/01/12 MH Temp BSOD fix. We need to find NIC allocate mem fail reason in 
-	// win7 platform.
-	//
-	HAL_ADAPTER_STS_CHK(pDM_Odm)
-#endif	
-
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	ODM_AntDivTimers(pDM_Odm,CANCEL_ANTDIV_TIMMER);
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-#ifdef MP_TEST
-	if (pDM_Odm->priv->pshare->rf_ft_var.mp_specific)
-		ODM_CancelTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer);
-#endif
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer);
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->PSDTimer);	
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->PathDivSwitchTimer);
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->CCKPathDiversityTimer);
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer);
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->DM_RXHP_Table.PSDTimer);
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->sbdcnt_timer);
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_FwNdpaTimer);
-#endif
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_CancelTimer(pDM_Odm, &pDM_Odm->BeamformingInfo.BeamformingTimer);
-#endif
-#endif
-
-}
-
-
-VOID
-ODM_ReleaseAllTimers(
-	IN PDM_ODM_T	pDM_Odm 
-	)
-{
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	ODM_AntDivTimers(pDM_Odm,RELEASE_ANTDIV_TIMMER);
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-    #ifdef MP_TEST
-	if (pDM_Odm->priv->pshare->rf_ft_var.mp_specific)
-		ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer);
-    #endif
-#elif(DM_ODM_SUPPORT_TYPE == ODM_WIN)
-ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer);
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->PSDTimer);
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->PathDivSwitchTimer);
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->CCKPathDiversityTimer);
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer);
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->DM_RXHP_Table.PSDTimer);
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->sbdcnt_timer);
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->BeamformingInfo.TxbfInfo.Txbf_FwNdpaTimer);
-#endif
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	ODM_ReleaseTimer(pDM_Odm, &pDM_Odm->BeamformingInfo.BeamformingTimer);
-#endif
-#endif
-}
-
-
-//3============================================================
-//3 Tx Power Tracking
-//3============================================================
-
-
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-VOID
-ODM_InitAllThreads(
-	IN PDM_ODM_T	pDM_Odm 
-	)
-{
-	#ifdef TPT_THREAD
-	kTPT_task_init(pDM_Odm->priv);
-	#endif
-}
-
-VOID
-ODM_StopAllThreads(
-	IN PDM_ODM_T	pDM_Odm 
-	)
-{
-	#ifdef TPT_THREAD
-	kTPT_task_stop(pDM_Odm->priv);
-	#endif
-}
-#endif	
-
-
-#if( DM_ODM_SUPPORT_TYPE == ODM_WIN) 
-//
-// 2011/07/26 MH Add an API for testing IQK fail case.
-//
-BOOLEAN
-ODM_CheckPowerStatus(
-	IN	PADAPTER		Adapter)
-{
-
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T			pDM_Odm = &pHalData->DM_OutSrc;
-	RT_RF_POWER_STATE 	rtState;
-	PMGNT_INFO			pMgntInfo	= &(Adapter->MgntInfo);
-
-	// 2011/07/27 MH We are not testing ready~~!! We may fail to get correct value when init sequence.
-	if (pMgntInfo->init_adpt_in_progress == TRUE)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ODM_CheckPowerStatus Return TRUE, due to initadapter\n"));
-		return	TRUE;
-	}
-	
-	//
-	//	2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK.
-	//
-	Adapter->HalFunc.GetHwRegHandler(Adapter, HW_VAR_RF_STATE, (pu1Byte)(&rtState));	
-	if(Adapter->bDriverStopped || Adapter->bDriverIsGoingToPnpSetPowerSleep || rtState == eRfOff)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ODM_CheckPowerStatus Return FALSE, due to %d/%d/%d\n", 
-		Adapter->bDriverStopped, Adapter->bDriverIsGoingToPnpSetPowerSleep, rtState));
-		return	FALSE;
-	}
-	return	TRUE;
-}
-#elif( DM_ODM_SUPPORT_TYPE == ODM_AP)
-BOOLEAN
-ODM_CheckPowerStatus(
-		IN	PADAPTER		Adapter)
-{
-	/*
-	   HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	   PDM_ODM_T			pDM_Odm = &pHalData->DM_OutSrc;
-	   RT_RF_POWER_STATE 	rtState;
-	   PMGNT_INFO			pMgntInfo	= &(Adapter->MgntInfo);
-
-	// 2011/07/27 MH We are not testing ready~~!! We may fail to get correct value when init sequence.
-	if (pMgntInfo->init_adpt_in_progress == TRUE)
-	{
-	ODM_RT_TRACE(pDM_Odm,COMP_INIT, DBG_LOUD, ("ODM_CheckPowerStatus Return TRUE, due to initadapter"));
-	return	TRUE;
-	}
-
-	//
-	//	2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK.
-	//
-	Adapter->HalFunc.GetHwRegHandler(Adapter, HW_VAR_RF_STATE, (pu1Byte)(&rtState));	
-	if(Adapter->bDriverStopped || Adapter->bDriverIsGoingToPnpSetPowerSleep || rtState == eRfOff)
-	{
-	ODM_RT_TRACE(pDM_Odm,COMP_INIT, DBG_LOUD, ("ODM_CheckPowerStatus Return FALSE, due to %d/%d/%d\n", 
-	Adapter->bDriverStopped, Adapter->bDriverIsGoingToPnpSetPowerSleep, rtState));
-	return	FALSE;
-	}
-	 */
-	return	TRUE;
-}
-#endif
-
-// need to ODM CE Platform
-//move to here for ANT detection mechanism using
-
-#if ((DM_ODM_SUPPORT_TYPE == ODM_WIN)||(DM_ODM_SUPPORT_TYPE == ODM_CE))
-u4Byte
-GetPSDData(
-	IN PDM_ODM_T	pDM_Odm,
-	unsigned int 	point,
-	u1Byte initial_gain_psd)
-{
-	//unsigned int	val, rfval;
-	//int	psd_report;
-	u4Byte	psd_report;
-	
-	//HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	//Debug Message
-	//val = PHY_QueryBBReg(Adapter,0x908, bMaskDWord);
-	//DbgPrint("Reg908 = 0x%x\n",val);
-	//val = PHY_QueryBBReg(Adapter,0xDF4, bMaskDWord);
-	//rfval = PHY_QueryRFReg(Adapter, ODM_RF_PATH_A, 0x00, bRFRegOffsetMask);
-	//DbgPrint("RegDF4 = 0x%x, RFReg00 = 0x%x\n",val, rfval);
-	//DbgPrint("PHYTXON = %x, OFDMCCA_PP = %x, CCKCCA_PP = %x, RFReg00 = %x\n",
-		//(val&BIT25)>>25, (val&BIT14)>>14, (val&BIT15)>>15, rfval);
-
-	//Set DCO frequency index, offset=(40MHz/SamplePts)*point
-	ODM_SetBBReg(pDM_Odm, 0x808, 0x3FF, point);
-
-	//Start PSD calculation, Reg808[22]=0->1
-	ODM_SetBBReg(pDM_Odm, 0x808, BIT22, 1);
-	//Need to wait for HW PSD report
-	ODM_StallExecution(1000);
-	ODM_SetBBReg(pDM_Odm, 0x808, BIT22, 0);
-	//Read PSD report, Reg8B4[15:0]
-	psd_report = ODM_GetBBReg(pDM_Odm,0x8B4, bMaskDWord) & 0x0000FFFF;
-	
-#if 1//(DEV_BUS_TYPE == RT_PCI_INTERFACE) && ( (RT_PLATFORM == PLATFORM_LINUX) || (RT_PLATFORM == PLATFORM_MACOSX))
-	psd_report = (u4Byte) (odm_ConvertTo_dB(psd_report))+(u4Byte)(initial_gain_psd-0x1c);
-#else
-	psd_report = (int) (20*log10((double)psd_report))+(int)(initial_gain_psd-0x1c);
-#endif
-
-	return psd_report;
-	
-}
-#endif
-
-u4Byte 
-odm_ConvertTo_dB(
-	u4Byte 	Value)
-{
-	u1Byte i;
-	u1Byte j;
-	u4Byte dB;
-
-	Value = Value & 0xFFFF;
-
-	for (i = 0; i < 12; i++)
-	{
-		if (Value <= dB_Invert_Table[i][7])
-		{
-			break;
-		}
-	}
-
-	if (i >= 12)
-	{
-		return (96);	// maximum 96 dB
-	}
-
-	for (j = 0; j < 8; j++)
-	{
-		if (Value <= dB_Invert_Table[i][j])
-		{
-			break;
-		}
-	}
-
-	dB = (i << 3) + j + 1;
-
-	return (dB);
-}
-
-u4Byte 
-odm_ConvertTo_linear(
-	u4Byte 	Value)
-{
-	u1Byte i;
-	u1Byte j;
-	u4Byte linear;
-	
-	/* 1dB~96dB */
-	
-	Value = Value & 0xFF;
-
-	i = (u1Byte)((Value - 1) >> 3);
-	j = (u1Byte)(Value - 1) - (i << 3);
-
-	linear = dB_Invert_Table[i][j];
-
-	return (linear);
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-ODM_UpdateInitRateWorkItemCallback(
-    IN PVOID            pContext
-    )
-{
-	PADAPTER	Adapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	u1Byte			p = 0;	
-
-	if(pDM_Odm->SupportICType == ODM_RTL8821)
-	{
-		ODM_TxPwrTrackSetPwr8821A(pDM_Odm, MIX_MODE, ODM_RF_PATH_A, 0);
-	}
-	else if(pDM_Odm->SupportICType == ODM_RTL8812)
-	{
-		for (p = ODM_RF_PATH_A; p < MAX_PATH_NUM_8812A; p++)    //DOn't know how to include &c
-		{
-			ODM_TxPwrTrackSetPwr8812A(pDM_Odm, MIX_MODE, p, 0);
-		}
-	}
-	else if(pDM_Odm->SupportICType == ODM_RTL8723B)
-	{
-			ODM_TxPwrTrackSetPwr_8723B(pDM_Odm, MIX_MODE, ODM_RF_PATH_A, 0);
-	}
-	else if(pDM_Odm->SupportICType == ODM_RTL8192E)
-	{
-		for (p = ODM_RF_PATH_A; p < MAX_PATH_NUM_8192E; p++)    //DOn't know how to include &c
-		{
-			ODM_TxPwrTrackSetPwr92E(pDM_Odm, MIX_MODE, p, 0);
-		}
-	}
-	else if(pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-			ODM_TxPwrTrackSetPwr88E(pDM_Odm, MIX_MODE, ODM_RF_PATH_A, 0);
-	}
-}
-#endif
-
-//
-// ODM multi-port consideration, added by Roger, 2013.10.01.
-//
-VOID
-ODM_AsocEntry_Init(
-	IN	PDM_ODM_T	pDM_Odm
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER pLoopAdapter = GetDefaultAdapter(pDM_Odm->Adapter);
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pLoopAdapter);
-	PDM_ODM_T		 pDM_OutSrc = &pHalData->DM_OutSrc;
-	u1Byte	TotalAssocEntryNum = 0;
-	u1Byte	index = 0;
-
-
-	ODM_CmnInfoPtrArrayHook(pDM_OutSrc, ODM_CMNINFO_STA_STATUS, 0, &pLoopAdapter->MgntInfo.DefaultPort[0]);
-	pLoopAdapter->MgntInfo.DefaultPort[0].MultiPortStationIdx = TotalAssocEntryNum;
-		
-	pLoopAdapter = GetNextExtAdapter(pLoopAdapter);
-	TotalAssocEntryNum +=1;
-
-	while(pLoopAdapter)
-	{
-		for (index = 0; index <ASSOCIATE_ENTRY_NUM; index++)
-		{
-			ODM_CmnInfoPtrArrayHook(pDM_OutSrc, ODM_CMNINFO_STA_STATUS, TotalAssocEntryNum+index, &pLoopAdapter->MgntInfo.AsocEntry[index]);
-			pLoopAdapter->MgntInfo.AsocEntry[index].MultiPortStationIdx = TotalAssocEntryNum+index;				
-		}
-		
-		TotalAssocEntryNum+= index;
-		if(IS_HARDWARE_TYPE_8188E((pDM_Odm->Adapter)))
-			pLoopAdapter->RASupport = TRUE;
-		pLoopAdapter = GetNextExtAdapter(pLoopAdapter);
-	}
-#endif
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-/* Justin: According to the current RRSI to adjust Response Frame TX power, 2012/11/05 */
-void odm_dtc(PDM_ODM_T pDM_Odm)
-{
-#ifdef CONFIG_DM_RESP_TXAGC
-	#define DTC_BASE            35	/* RSSI higher than this value, start to decade TX power */
-	#define DTC_DWN_BASE       (DTC_BASE-5)	/* RSSI lower than this value, start to increase TX power */
-
-	/* RSSI vs TX power step mapping: decade TX power */
-	static const u8 dtc_table_down[]={
-		DTC_BASE,
-		(DTC_BASE+5),
-		(DTC_BASE+10),
-		(DTC_BASE+15),
-		(DTC_BASE+20),
-		(DTC_BASE+25)
-	};
-
-	/* RSSI vs TX power step mapping: increase TX power */
-	static const u8 dtc_table_up[]={
-		DTC_DWN_BASE,
-		(DTC_DWN_BASE-5),
-		(DTC_DWN_BASE-10),
-		(DTC_DWN_BASE-15),
-		(DTC_DWN_BASE-15),
-		(DTC_DWN_BASE-20),
-		(DTC_DWN_BASE-20),
-		(DTC_DWN_BASE-25),
-		(DTC_DWN_BASE-25),
-		(DTC_DWN_BASE-30),
-		(DTC_DWN_BASE-35)
-	};
-
-	u8 i;
-	u8 dtc_steps=0;
-	u8 sign;
-	u8 resp_txagc=0;
-
-	#if 0
-	/* As DIG is disabled, DTC is also disable */
-	if(!(pDM_Odm->SupportAbility & ODM_XXXXXX))
-		return;
-	#endif
-
-	if (DTC_BASE < pDM_Odm->RSSI_Min) {
-		/* need to decade the CTS TX power */
-		sign = 1;
-		for (i=0;i<ARRAY_SIZE(dtc_table_down);i++)
-		{
-			if ((dtc_table_down[i] >= pDM_Odm->RSSI_Min) || (dtc_steps >= 6))
-				break;
-			else
-				dtc_steps++;
-		}
-	}
-#if 0
-	else if (DTC_DWN_BASE > pDM_Odm->RSSI_Min)
-	{
-		/* needs to increase the CTS TX power */
-		sign = 0;
-		dtc_steps = 1;
-		for (i=0;i<ARRAY_SIZE(dtc_table_up);i++)
-		{
-			if ((dtc_table_up[i] <= pDM_Odm->RSSI_Min) || (dtc_steps>=10))
-				break;
-			else
-				dtc_steps++;
-		}
-	}
-#endif
-	else
-	{
-		sign = 0;
-		dtc_steps = 0;
-	}
-
-	resp_txagc = dtc_steps | (sign << 4);
-	resp_txagc = resp_txagc | (resp_txagc << 5);
-	ODM_Write1Byte(pDM_Odm, 0x06d9, resp_txagc);
-
-	DBG_871X("%s RSSI_Min:%u, set RESP_TXAGC to %s %u\n", 
-		__func__, pDM_Odm->RSSI_Min, sign?"minus":"plus", dtc_steps);
-#endif /* CONFIG_RESP_TXAGC_ADJUST */
-}
-
-#endif /* #if (DM_ODM_SUPPORT_TYPE == ODM_CE) */
-
-VOID
-odm_UpdatePowerTrainingState(
-	IN	PDM_ODM_T	pDM_Odm
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PFALSE_ALARM_STATISTICS 	FalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm , PHYDM_FALSEALMCNT);
-	pDIG_T						pDM_DigTable = &pDM_Odm->DM_DigTable;
-	u4Byte						score = 0;
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_PWR_TRAIN))
-		return;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState()============>\n"));
-	pDM_Odm->bChangeState = FALSE;
-
-	// Debug command
-	if(pDM_Odm->ForcePowerTrainingState)
-	{
-		if(pDM_Odm->ForcePowerTrainingState == 1 && !pDM_Odm->bDisablePowerTraining)
-		{
-			pDM_Odm->bChangeState = TRUE;
-			pDM_Odm->bDisablePowerTraining = TRUE;
-		}
-		else if(pDM_Odm->ForcePowerTrainingState == 2 && pDM_Odm->bDisablePowerTraining)
-		{
-			pDM_Odm->bChangeState = TRUE;
-			pDM_Odm->bDisablePowerTraining = FALSE;
-		}
-
-		pDM_Odm->PT_score = 0;
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM = 0;
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK = 0;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): ForcePowerTrainingState = %d\n", 
-			pDM_Odm->ForcePowerTrainingState));
-		return;
-	}
-	
-	if(!pDM_Odm->bLinked)
-		return;
-	
-	// First connect
-	if((pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == FALSE))
-	{
-		pDM_Odm->PT_score = 0;
-		pDM_Odm->bChangeState = TRUE;
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM = 0;
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK = 0;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): First Connect\n"));
-		return;
-	}
-
-	// Compute score
-	if(pDM_Odm->NHM_cnt_0 >= 215)
-		score = 2;
-	else if(pDM_Odm->NHM_cnt_0 >= 190) 
-		score = 1;							// unknow state
-	else
-	{
-		u4Byte	RX_Pkt_Cnt;
-		
-		RX_Pkt_Cnt = (u4Byte)(pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM) + (u4Byte)(pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK);
-		
-		if((FalseAlmCnt->Cnt_CCA_all > 31 && RX_Pkt_Cnt > 31) && (FalseAlmCnt->Cnt_CCA_all >= RX_Pkt_Cnt))
-		{
-			if((RX_Pkt_Cnt + (RX_Pkt_Cnt >> 1)) <= FalseAlmCnt->Cnt_CCA_all)
-				score = 0;
-			else if((RX_Pkt_Cnt + (RX_Pkt_Cnt >> 2)) <= FalseAlmCnt->Cnt_CCA_all)
-				score = 1;
-			else
-				score = 2;
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): RX_Pkt_Cnt = %d, Cnt_CCA_all = %d\n", 
-			RX_Pkt_Cnt, FalseAlmCnt->Cnt_CCA_all));
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): NumQryPhyStatusOFDM = %d, NumQryPhyStatusCCK = %d\n",
-			(u4Byte)(pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM), (u4Byte)(pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK)));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): NHM_cnt_0 = %d, score = %d\n", 
-		pDM_Odm->NHM_cnt_0, score));
-
-	// smoothing
-	pDM_Odm->PT_score = (score << 4) + (pDM_Odm->PT_score>>1) + (pDM_Odm->PT_score>>2);
-	score = (pDM_Odm->PT_score + 32) >> 6;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): PT_score = %d, score after smoothing = %d\n", 
-		pDM_Odm->PT_score, score));
-
-	// Mode decision
-	if(score == 2)
-	{
-		if(pDM_Odm->bDisablePowerTraining)
-		{
-			pDM_Odm->bChangeState = TRUE;
-			pDM_Odm->bDisablePowerTraining = FALSE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): Change state\n"));
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): Enable Power Training\n"));
-	}
-	else if(score == 0)
-	{
-		if(!pDM_Odm->bDisablePowerTraining)
-		{
-			pDM_Odm->bChangeState = TRUE;
-			pDM_Odm->bDisablePowerTraining = TRUE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): Change state\n"));
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_RA_MASK, ODM_DBG_LOUD,("odm_UpdatePowerTrainingState(): Disable Power Training\n"));
-	}
-
-	pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM = 0;
-	pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK = 0;
-#endif
-}
-
-
-
-/*===========================================================*/
-/* The following is for compile only*/
-/*===========================================================*/
-/*#define TARGET_CHNL_NUM_2G_5G	59*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-u1Byte GetRightChnlPlaceforIQK(u1Byte chnl)
-{
-	u1Byte	channel_all[TARGET_CHNL_NUM_2G_5G] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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};
-	u1Byte	place = chnl;
-
-	
-	if (chnl > 14) {
-		for (place = 14; place < sizeof(channel_all); place++) {
-			if (channel_all[place] == chnl)
-				return place-13;
-		}
-	}
-	
-	return 0;
-}
-
-VOID
-FillH2CCmd92C(	
-	IN	PADAPTER		Adapter,
-	IN	u1Byte	ElementID,
-	IN	u4Byte	CmdLen,
-	IN	pu1Byte	pCmdBuffer
-)
-{}
-VOID
-PHY_SetTxPowerLevel8192C(
-	IN	PADAPTER		Adapter,
-	IN	u1Byte			channel
-	)
-{
-}
-#endif
-/*===========================================================*/
-
-VOID
-phydm_NoisyDetection(
-	IN	PDM_ODM_T	pDM_Odm
-	)
-{
-	u4Byte  Total_FA_Cnt, Total_CCA_Cnt;
-	u4Byte  Score = 0, i, Score_Smooth;
-    
-	Total_CCA_Cnt = pDM_Odm->FalseAlmCnt.Cnt_CCA_all;
-	Total_FA_Cnt  = pDM_Odm->FalseAlmCnt.Cnt_all;    
-
-/*
-    if( Total_FA_Cnt*16>=Total_CCA_Cnt*14 )         // 87.5
-    
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*12 )    // 75
-    
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*10 )    // 56.25
-    
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*8 )     // 50
-
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*7 )     // 43.75
-
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*6 )     // 37.5
-
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*5 )     // 31.25%
-        
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*4 )     // 25%
-
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*3 )     // 18.75%
-
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*2 )     // 12.5%
-
-    else if( Total_FA_Cnt*16>=Total_CCA_Cnt*1 )     // 6.25%
-*/
-    for(i=0;i<=16;i++)
-    {
-        if( Total_FA_Cnt*16>=Total_CCA_Cnt*(16-i) )
-        {
-            Score = 16-i;
-            break;
-        }
-    }
-
-    // NoisyDecision_Smooth = NoisyDecision_Smooth>>1 + (Score<<3)>>1;
-    pDM_Odm->NoisyDecision_Smooth = (pDM_Odm->NoisyDecision_Smooth>>1) + (Score<<2);
-
-    // Round the NoisyDecision_Smooth: +"3" comes from (2^3)/2-1
-    Score_Smooth = (Total_CCA_Cnt>=300)?((pDM_Odm->NoisyDecision_Smooth+3)>>3):0;
-
-    pDM_Odm->NoisyDecision = (Score_Smooth>=3)?1:0;
-/*
-    switch(Score_Smooth)
-    {
-        case 0:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=0%%\n"));
-            break;
-        case 1:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=6.25%%\n"));
-            break;
-        case 2:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=12.5%%\n"));
-            break;
-        case 3:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=18.75%%\n"));
-            break;
-        case 4:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=25%%\n"));
-            break;
-        case 5:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=31.25%%\n"));
-            break;
-        case 6:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=37.5%%\n"));
-            break;
-        case 7:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=43.75%%\n"));
-            break;
-        case 8:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=50%%\n"));
-            break;
-        case 9:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=56.25%%\n"));
-            break;
-        case 10:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=62.5%%\n"));
-            break;
-        case 11:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=68.75%%\n"));
-            break;
-        case 12:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=75%%\n"));
-            break;
-        case 13:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=81.25%%\n"));
-            break;
-        case 14:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=87.5%%\n"));
-            break;
-        case 15:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=93.75%%\n"));            
-            break;
-        case 16:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Total_FA_Cnt/Total_CCA_Cnt=100%%\n"));
-            break;
-        default:
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("[NoisyDetection] Unknown Value!! Need Check!!\n"));            
-    }
-*/        
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_NOISY_DETECT, ODM_DBG_LOUD,
-	("[NoisyDetection] Total_CCA_Cnt=%d, Total_FA_Cnt=%d, NoisyDecision_Smooth=%d, Score=%d, Score_Smooth=%d, pDM_Odm->NoisyDecision=%d\n",
-	Total_CCA_Cnt, Total_FA_Cnt, pDM_Odm->NoisyDecision_Smooth, Score, Score_Smooth, pDM_Odm->NoisyDecision));
-	
-}
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+const u16 phy_rate_table[] = {	/*20M*/
+	1, 2, 5, 11,
+	6, 9, 12, 18, 24, 36, 48, 54,
+	6, 13, 19, 26, 39, 52, 58, 65,		/*MCS0~7*/
+	13, 26, 39, 52, 78, 104, 117, 130		/*MCS8~15*/
+};
+
+void
+phydm_traffic_load_decision(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		bit_shift_num = 0;
+
+	/*---TP & Trafic-load calculation---*/
+
+	if (dm->last_tx_ok_cnt > *dm->num_tx_bytes_unicast)
+		dm->last_tx_ok_cnt = *dm->num_tx_bytes_unicast;
+
+	if (dm->last_rx_ok_cnt > *dm->num_rx_bytes_unicast)
+		dm->last_rx_ok_cnt = *dm->num_rx_bytes_unicast;
+
+	dm->cur_tx_ok_cnt = *dm->num_tx_bytes_unicast - dm->last_tx_ok_cnt;
+	dm->cur_rx_ok_cnt = *dm->num_rx_bytes_unicast - dm->last_rx_ok_cnt;
+	dm->last_tx_ok_cnt = *dm->num_tx_bytes_unicast;
+	dm->last_rx_ok_cnt = *dm->num_rx_bytes_unicast;
+
+	bit_shift_num = 17 + (PHYDM_WATCH_DOG_PERIOD - 1); /*AP:  <<3(8bit), >>20(10^6,M), >>0(1sec)*/
+													/*WIN&CE:  <<3(8bit), >>20(10^6,M), >>1(2sec)*/
+
+	dm->tx_tp = ((dm->tx_tp) >> 1) + (u32)(((dm->cur_tx_ok_cnt) >> bit_shift_num) >> 1);
+	dm->rx_tp = ((dm->rx_tp) >> 1) + (u32)(((dm->cur_rx_ok_cnt) >> bit_shift_num) >> 1);
+
+	dm->total_tp = dm->tx_tp + dm->rx_tp;
+
+	/*[Calculate TX/RX state]*/
+	if (dm->tx_tp > (dm->rx_tp << 1))
+		dm->txrx_state_all = TX_STATE;
+	else if (dm->rx_tp > (dm->tx_tp << 1))
+		dm->txrx_state_all = RX_STATE;
+	else
+		dm->txrx_state_all = BI_DIRECTION_STATE;
+
+	/*[Calculate consecutive idlel time]*/
+	if (dm->total_tp == 0)
+		dm->consecutive_idlel_time += PHYDM_WATCH_DOG_PERIOD;
+	else
+		dm->consecutive_idlel_time = 0;
+
+	/*[Traffic load decision]*/
+	dm->pre_traffic_load = dm->traffic_load;
+
+	if (dm->cur_tx_ok_cnt > 1875000 || dm->cur_rx_ok_cnt > 1875000) {		/* ( 1.875M * 8bit ) / 2sec= 7.5M bits /sec )*/
+
+		dm->traffic_load = TRAFFIC_HIGH;
+		/**/
+	} else if (dm->cur_tx_ok_cnt > 500000 || dm->cur_rx_ok_cnt > 500000) { /*( 0.5M * 8bit ) / 2sec =  2M bits /sec )*/
+
+		dm->traffic_load = TRAFFIC_MID;
+		/**/
+	} else if (dm->cur_tx_ok_cnt > 100000 || dm->cur_rx_ok_cnt > 100000)  { /*( 0.1M * 8bit ) / 2sec =  0.4M bits /sec )*/
+
+		dm->traffic_load = TRAFFIC_LOW;
+		/**/
+	} else {
+		dm->traffic_load = TRAFFIC_ULTRA_LOW;
+		/**/
+	}
+
+	/*
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "cur_tx_ok_cnt = %d, cur_rx_ok_cnt = %d, last_tx_ok_cnt = %d, last_rx_ok_cnt = %d\n",
+		dm->cur_tx_ok_cnt, dm->cur_rx_ok_cnt, dm->last_tx_ok_cnt, dm->last_rx_ok_cnt);
+
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "tx_tp = %d, rx_tp = %d\n",
+		dm->tx_tp, dm->rx_tp);
+	*/
+		
+}
+
+void
+phydm_init_cck_setting(
+	struct dm_struct		*dm
+)
+{
+#if (RTL8192E_SUPPORT == 1)
+	u32 value_824, value_82c;
+#endif
+
+	dm->is_cck_high_power = (boolean) odm_get_bb_reg(dm, ODM_REG(CCK_RPT_FORMAT, dm), ODM_BIT(CCK_RPT_FORMAT, dm));
+
+	phydm_config_cck_rx_antenna_init(dm);
+	phydm_config_cck_rx_path(dm, BB_PATH_A);
+
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+		/* 0x824[9] = 0x82C[9] = 0xA80[7]  those registers setting should be equal or CCK RSSI report may be incorrect */
+		value_824 = odm_get_bb_reg(dm, 0x824, BIT(9));
+		value_82c = odm_get_bb_reg(dm, 0x82c, BIT(9));
+
+		if (value_824 != value_82c)
+			odm_set_bb_reg(dm, 0x82c, BIT(9), value_824);
+		odm_set_bb_reg(dm, 0xa80, BIT(7), value_824);
+		dm->cck_agc_report_type = (boolean)value_824;
+
+		PHYDM_DBG(dm, ODM_COMP_INIT, "cck_agc_report_type = (( %d )), ext_lna_gain = (( %d ))\n", dm->cck_agc_report_type, dm->ext_lna_gain);
+	}
+#endif
+
+#if ((RTL8703B_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+		dm->cck_agc_report_type = odm_get_bb_reg(dm, 0x950, BIT(11)) ? 1 : 0; /*1: 4bit LNA, 0: 3bit LNA */
+
+		if (dm->cck_agc_report_type != 1) {
+			pr_debug("[Warning] 8703B/8723D/8710B CCK should be 4bit LNA, ie. 0x950[11] = 1\n");
+			/**/
+		}
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) {
+		dm->cck_new_agc = odm_get_bb_reg(dm, 0xa9c, BIT(17)) ? true : false;          /*1: new agc  0: old agc*/
+		if (dm->cck_new_agc == 0 && dm->default_rf_set_8821c == SWITCH_TO_BTG)
+			dm->cck_agc_report_type = 1;
+	}
+#endif
+
+#if ((RTL8723D_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8723D | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8710B))
+		dm->cck_new_agc = odm_get_bb_reg(dm, 0xa9c, BIT(17)) ? true : false;          /*1: new agc  0: old agc*/
+	else
+#endif
+	{
+		dm->cck_new_agc = false;
+		/**/
+	}
+
+	phydm_get_cck_rssi_table_from_reg(dm);
+
+}
+
+void
+phydm_init_hw_info_by_rfe(
+	struct dm_struct		*dm
+)
+{
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_init_hw_info_by_rfe_type_8822b(dm);
+#endif
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_init_hw_info_by_rfe_type_8821c(dm);
+#endif
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_init_hw_info_by_rfe_type_8197f(dm);
+#endif
+}
+
+void
+phydm_common_info_self_init(
+	struct dm_struct		*dm
+)
+{
+	phydm_init_cck_setting(dm);
+	dm->rf_path_rx_enable = (u8) odm_get_bb_reg(dm, ODM_REG(BB_RX_PATH, dm), ODM_BIT(BB_RX_PATH, dm));
+#if (DM_ODM_SUPPORT_TYPE != ODM_CE)
+	dm->is_net_closed = &dm->BOOLEAN_temp;
+
+	phydm_init_debug_setting(dm);
+#endif
+	phydm_init_trx_antenna_setting(dm);
+	phydm_init_soft_ml_setting(dm);
+
+	dm->phydm_sys_up_time = 0;
+
+	if (dm->support_ic_type & ODM_IC_1SS)
+		dm->num_rf_path = 1;
+	else if (dm->support_ic_type & ODM_IC_2SS)
+		dm->num_rf_path = 2;
+	else if (dm->support_ic_type & ODM_IC_3SS)
+		dm->num_rf_path = 3;
+	else if (dm->support_ic_type & ODM_IC_4SS)
+		dm->num_rf_path = 4;
+	else
+		dm->num_rf_path = 1;
+
+	dm->tx_rate = 0xFF;
+	dm->rssi_min_by_path = 0xFF;
+
+	dm->number_linked_client = 0;
+	dm->pre_number_linked_client = 0;
+	dm->number_active_client = 0;
+	dm->pre_number_active_client = 0;
+
+	dm->last_tx_ok_cnt = 0;
+	dm->last_rx_ok_cnt = 0;
+	dm->tx_tp = 0;
+	dm->rx_tp = 0;
+	dm->total_tp = 0;
+	dm->traffic_load = TRAFFIC_LOW;
+
+	dm->nbi_set_result = 0;
+	dm->is_init_hw_info_by_rfe = false;
+	dm->pre_dbg_priority = BB_DBGPORT_RELEASE;
+	dm->tp_active_th = 5;
+	dm->disable_phydm_watchdog = 0;
+
+	dm->u8_dummy = 0xf;
+	dm->u16_dummy = 0xffff;
+	dm->u32_dummy = 0xffffffff;
+	
+	/*odm_memory_set(dm, &(dm->pause_lv_table.lv_dig), 0, sizeof(struct phydm_pause_lv));*/
+	dm->pause_lv_table.lv_cckpd = PHYDM_PAUSE_RELEASE;
+	dm->pause_lv_table.lv_dig = PHYDM_PAUSE_RELEASE;
+
+}
+
+void
+phydm_cmn_sta_info_update(
+	void	*dm_void,
+	u8	macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA_MASK, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA_MASK, "MACID=%d\n", sta->mac_id);
+
+	/*[Calculate TX/RX state]*/
+	if (sta->tx_moving_average_tp > (sta->rx_moving_average_tp << 1))
+		ra->txrx_state= TX_STATE;
+	else if (sta->rx_moving_average_tp > (sta->tx_moving_average_tp << 1))
+		ra->txrx_state = RX_STATE;
+	else
+		ra->txrx_state = BI_DIRECTION_STATE;
+
+	 ra->is_noisy = dm->noisy_decision;
+
+}
+
+void
+phydm_common_info_self_update(
+	struct dm_struct		*dm
+)
+{
+	u8	sta_cnt = 0, num_active_client = 0;
+	u32	i, one_entry_macid = 0;
+	u32	ma_rx_tp = 0;
+	struct cmn_sta_info	*sta;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+	PADAPTER	adapter =  (PADAPTER)dm->adapter;
+
+	PMGNT_INFO	mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+
+	sta = dm->phydm_sta_info[0];
+	if (mgnt_info->mAssoc) {
+		sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
+		for (i = 0; i < 6; i++)
+			sta->mac_addr[i] = mgnt_info->Bssid[i];
+	} else if (GetFirstClientPort(adapter)) {
+		//void	*client_adapter = GetFirstClientPort(adapter);
+		struct _ADAPTER	*client_adapter = GetFirstClientPort(adapter);
+
+		sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
+		for (i = 0; i < 6; i++)
+			sta->mac_addr[i] = client_adapter->MgntInfo.Bssid[i];
+	} else {
+		sta->dm_ctrl = sta->dm_ctrl & (~STA_DM_CTRL_ACTIVE);
+		for (i = 0; i < 6; i++)
+			sta->mac_addr[i] = 0;
+	}
+
+	/* STA mode is linked to AP */
+	if (is_sta_active(sta) && !ACTING_AS_AP(adapter))
+		dm->bsta_state = true;
+	else
+		dm->bsta_state = false;
+#endif
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
+			sta_cnt++;
+			
+			if (sta_cnt == 1)
+				one_entry_macid = i;
+
+			phydm_cmn_sta_info_update(dm, (u8)i);
+			#if (BEAMFORMING_SUPPORT == 1)
+			//phydm_get_txbf_device_num(dm, (u8)i);
+			#endif
+
+			ma_rx_tp = sta->rx_moving_average_tp + sta->tx_moving_average_tp;
+			PHYDM_DBG(dm, DBG_COMMON_FLOW, "TP[%d]: ((%d )) bit/sec\n", i, ma_rx_tp);
+
+			if (ma_rx_tp > ACTIVE_TP_THRESHOLD)
+				num_active_client++;
+		}
+	}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	dm->is_linked = (sta_cnt != 0) ? true : false;
+#endif
+
+	if (sta_cnt == 1) {
+		dm->is_one_entry_only = true;
+		dm->one_entry_macid = one_entry_macid;
+		dm->one_entry_tp = ma_rx_tp;
+
+		dm->tp_active_occur = 0;
+
+		PHYDM_DBG(dm, DBG_COMMON_FLOW, "one_entry_tp=((%d)), pre_one_entry_tp=((%d))\n",
+			dm->one_entry_tp, dm->pre_one_entry_tp);
+
+		if ((dm->one_entry_tp > dm->pre_one_entry_tp) && (dm->pre_one_entry_tp <= 2)) {
+			if ((dm->one_entry_tp - dm->pre_one_entry_tp) > dm->tp_active_th)
+				dm->tp_active_occur = 1;
+		}
+		dm->pre_one_entry_tp = dm->one_entry_tp;
+	} else
+		dm->is_one_entry_only = false;
+
+	dm->pre_number_linked_client = dm->number_linked_client;
+	dm->pre_number_active_client = dm->number_active_client;
+
+	dm->number_linked_client = sta_cnt;
+	dm->number_active_client = num_active_client;
+
+	/*Traffic load information update*/
+	phydm_traffic_load_decision(dm);
+
+	dm->phydm_sys_up_time += PHYDM_WATCH_DOG_PERIOD;
+
+	dm->is_dfs_band = phydm_is_dfs_band(dm);
+	dm->phy_dbg_info.show_phy_sts_cnt = 0;
+
+}
+
+void
+phydm_common_info_self_reset(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	dm->phy_dbg_info.num_qry_beacon_pkt = 0;
+#endif
+}
+
+void *
+phydm_get_structure(
+	struct dm_struct		*dm,
+	u8			structure_type
+)
+
+{
+	void	*structure = NULL;
+#if RTL8195A_SUPPORT
+	switch (structure_type) {
+	case	PHYDM_FALSEALMCNT:
+		structure = &false_alm_cnt;
+		break;
+
+	case	PHYDM_CFOTRACK:
+		structure = &dm_cfo_track;
+		break;
+
+	case	PHYDM_ADAPTIVITY:
+		structure = &dm->adaptivity;
+		break;
+
+	default:
+		break;
+	}
+
+#else
+	switch (structure_type) {
+	case	PHYDM_FALSEALMCNT:
+		structure = &dm->false_alm_cnt;
+		break;
+
+	case	PHYDM_CFOTRACK:
+		structure = &dm->dm_cfo_track;
+		break;
+
+	case	PHYDM_ADAPTIVITY:
+		structure = &dm->adaptivity;
+		break;
+
+	case	PHYDM_DFS:
+		structure = &dm->dfs;
+		break;
+
+	default:
+		break;
+	}
+
+#endif
+	return	structure;
+}
+
+void
+phydm_hw_setting(
+	struct dm_struct		*dm
+)
+{
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821)
+		odm_hw_setting_8821a(dm);
+#endif
+
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phydm_hwsetting_8814a(dm);
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_hwsetting_8822b(dm);
+#endif
+
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8812)
+		phydm_hwsetting_8812a(dm);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_hwsetting_8197f(dm);
+#endif
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+u64
+phydm_supportability_init_win(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	/*---------------N Series--------------------*/
+	#if (RTL8188E_SUPPORT == 1)	
+	case	ODM_RTL8188E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8192E_SUPPORT == 1)
+	case	ODM_RTL8192E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8723B_SUPPORT == 1)
+	case	ODM_RTL8723B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR		|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8703B_SUPPORT == 1)
+	case	ODM_RTL8703B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8723D_SUPPORT == 1)
+	case	ODM_RTL8723D:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/* ODM_BB_PWR_TRAIN	| */
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8710B_SUPPORT == 1)
+	case	ODM_RTL8710B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8188F_SUPPORT == 1)
+	case	ODM_RTL8188F:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	/*---------------AC Series-------------------*/
+
+	#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+	case	ODM_RTL8812:
+	case	ODM_RTL8821:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_DYNAMIC_TXPWR	|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8814A_SUPPORT == 1) 
+	case ODM_RTL8814A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_DYNAMIC_TXPWR	|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_ADAPTIVE_SOML;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	return support_ability;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+u64
+phydm_supportability_init_ce(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	/*---------------N Series--------------------*/
+	#if (RTL8188E_SUPPORT == 1)	
+	case	ODM_RTL8188E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8192E_SUPPORT == 1)
+	case	ODM_RTL8192E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8723B_SUPPORT == 1)
+	case	ODM_RTL8723B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8703B_SUPPORT == 1)
+	case	ODM_RTL8703B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8723D_SUPPORT == 1)
+	case	ODM_RTL8723D:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/* ODM_BB_PWR_TRAIN	| */	
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8710B_SUPPORT == 1)
+	case	ODM_RTL8710B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8188F_SUPPORT == 1)
+	case	ODM_RTL8188F:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+		
+	/*---------------AC Series-------------------*/
+
+	#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+	case	ODM_RTL8812:
+	case	ODM_RTL8821:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8814A_SUPPORT == 1) 
+	case ODM_RTL8814A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	return support_ability;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+u64
+phydm_supportability_init_ap(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	/*---------------N Series--------------------*/
+	#if (RTL8188E_SUPPORT == 1)	
+	case	ODM_RTL8188E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8192E_SUPPORT == 1)
+	case	ODM_RTL8192E:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR			|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+
+	#if (RTL8723B_SUPPORT == 1)
+	case	ODM_RTL8723B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+		
+	#if ((RTL8198F_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+	case	ODM_RTL8198F:
+	case	ODM_RTL8197F:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ADAPTIVE_SOML	|
+			ODM_BB_ENV_MONITOR		|
+			ODM_BB_LNA_SAT_CHK		|
+			ODM_BB_PRIMARY_CCA;
+		break;
+	#endif
+	
+	/*---------------AC Series-------------------*/
+
+	#if (RTL8881A_SUPPORT == 1)
+	case	ODM_RTL8881A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8814A_SUPPORT == 1) 
+	case ODM_RTL8814A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	#if (RTL8814B_SUPPORT == 1) 
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1) 
+	case ODM_RTL8822B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			/*ODM_BB_ADAPTIVE_SOML	|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR	;
+		break;
+	#endif
+
+	#if (RTL8821C_SUPPORT == 1) 
+	case ODM_RTL8821C:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+		break;
+	#endif
+
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	#if 0
+	/*[Config Antenna Diveristy]*/
+	if (*(dm->enable_antdiv))
+		support_ability |= ODM_BB_ANT_DIV;
+	
+	/*[Config Adaptivity]*/
+	if (*(dm->enable_adaptivity))
+		support_ability |= ODM_BB_ADAPTIVITY;
+	#endif
+
+	return support_ability;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+u64
+phydm_supportability_init_iot(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			support_ability = 0;
+
+	switch (dm->support_ic_type) {
+	#if (RTL8710B_SUPPORT == 1)
+	case	ODM_RTL8710B:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+
+	#if (RTL8195A_SUPPORT == 1)
+	case	ODM_RTL8195A:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+		break;
+	#endif
+	
+	default:
+		support_ability |=
+			ODM_BB_DIG				|
+			ODM_BB_RA_MASK			|
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT			|
+			ODM_BB_RSSI_MONITOR		|
+			ODM_BB_CCK_PD			|
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE	|
+			ODM_BB_CFO_TRACKING		|
+			ODM_BB_ENV_MONITOR;
+
+			pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
+
+	}
+
+	return support_ability;
+}
+#endif
+
+void
+phydm_fwoffload_ability_init(
+	struct dm_struct		*dm,
+	enum phydm_offload_ability	offload_ability
+)
+{
+	switch (offload_ability) {
+	case	PHYDM_PHY_PARAM_OFFLOAD:
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+			dm->fw_offload_ability |= PHYDM_PHY_PARAM_OFFLOAD;
+		break;
+
+	case	PHYDM_RF_IQK_OFFLOAD:
+		dm->fw_offload_ability |= PHYDM_RF_IQK_OFFLOAD;
+		break;
+
+	default:
+		PHYDM_DBG(dm, ODM_COMP_INIT, "fwofflad, wrong init type!!\n");
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"fw_offload_ability = %x\n", dm->fw_offload_ability);
+
+}
+void
+phydm_fwoffload_ability_clear(
+	struct dm_struct		*dm,
+	enum phydm_offload_ability	offload_ability
+)
+{
+	switch (offload_ability) {
+	case	PHYDM_PHY_PARAM_OFFLOAD:
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+			dm->fw_offload_ability &= (~PHYDM_PHY_PARAM_OFFLOAD);
+		break;
+
+	case	PHYDM_RF_IQK_OFFLOAD:
+		dm->fw_offload_ability &= (~PHYDM_RF_IQK_OFFLOAD);
+		break;
+
+	default:
+		PHYDM_DBG(dm, ODM_COMP_INIT, "fwofflad, wrong init type!!\n");
+		break;
+
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"fw_offload_ability = %x\n", dm->fw_offload_ability);
+
+}
+
+void
+phydm_supportability_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64	support_ability;
+	
+	if (*dm->mp_mode == true) {
+		support_ability = 0;
+
+		/**/
+	} else {
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+		support_ability = phydm_supportability_init_win(dm);
+		#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+		support_ability = phydm_supportability_init_ap(dm);
+		#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE))
+		support_ability = phydm_supportability_init_ce(dm);
+		#elif(DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+		support_ability = phydm_supportability_init_iot(dm);
+		#endif
+
+		/*[Config Antenna Diveristy]*/
+		if (IS_FUNC_EN(dm->enable_antdiv))
+			support_ability |= ODM_BB_ANT_DIV;
+
+		/*[Config Adaptive SOML]*/
+		if (IS_FUNC_EN(dm->en_adap_soml))
+			support_ability |= ODM_BB_ADAPTIVE_SOML;
+
+		/*[Config Adaptivity]*/
+		if (IS_FUNC_EN(dm->enable_adaptivity))
+			support_ability |= ODM_BB_ADAPTIVITY;
+	}
+	odm_cmn_info_init(dm, ODM_CMNINFO_ABILITY, support_ability);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "IC = ((0x%x)), Supportability Init = ((0x%llx))\n", dm->support_ic_type, dm->support_ability);
+}
+
+void
+phydm_rfe_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	PHYDM_DBG(dm, ODM_COMP_INIT, "RFE_Init\n");
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		phydm_rfe_8822b_init(dm);
+		/**/
+	}
+#endif
+}
+
+void
+phydm_dm_early_init(
+	struct dm_struct	*dm
+)
+{
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	halrf_init(dm);
+	#endif
+}
+
+void
+odm_dm_init(
+	struct dm_struct		*dm
+)
+{
+	halrf_init(dm);
+	phydm_supportability_init(dm);
+	phydm_rfe_init(dm);
+	phydm_common_info_self_init(dm);
+	phydm_rx_phy_status_init(dm);
+	phydm_auto_dbg_engine_init(dm);
+	phydm_dig_init(dm);
+	phydm_cck_pd_init(dm);
+	phydm_env_monitor_init(dm);
+	phydm_adaptivity_init(dm);
+	phydm_ra_info_init(dm);
+	phydm_rssi_monitor_init(dm);
+	phydm_cfo_tracking_init(dm);
+	phydm_rf_init(dm);
+	phydm_dc_cancellation(dm);
+#ifdef PHYDM_TXA_CALIBRATION
+	phydm_txcurrentcalibration(dm);
+	phydm_get_pa_bias_offset(dm);
+#endif
+	odm_antenna_diversity_init(dm);
+	phydm_adaptive_soml_init(dm);
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_init(dm);
+#endif
+	phydm_path_diversity_init(dm);
+	phydm_pow_train_init(dm);
+	phydm_dynamic_tx_power_init(dm);
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	adc_smp_init(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_beamforming_init(dm);
+#endif
+#if (RTL8188E_SUPPORT == 1)
+	odm_ra_info_init_all(dm);
+#endif
+
+	phydm_primary_cca_init(dm);
+
+	#ifdef CONFIG_PSD_TOOL
+	phydm_psd_init(dm);
+	#endif
+	
+	#ifdef CONFIG_SMART_ANTENNA
+	phydm_smt_ant_init(dm);
+	#endif
+
+}
+
+void
+odm_dm_reset(
+	struct dm_struct		*dm
+)
+{
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	odm_ant_div_reset(dm);
+	phydm_set_edcca_threshold_api(dm, dig_t->cur_ig_value);
+}
+
+void
+phydm_support_ability_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			pre_support_ability, one = 1;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	pre_support_ability = dm->support_ability;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%s\n",
+		       "================================");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[Supportability] PhyDM Selection\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))DIG\n",
+			       ((dm->support_ability & ODM_BB_DIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "01. (( %s ))RA_MASK\n",
+			       ((dm->support_ability & ODM_BB_RA_MASK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "02. (( %s ))DYN_TXPWR\n",
+			       ((dm->support_ability & ODM_BB_DYNAMIC_TXPWR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "03. (( %s ))FA_CNT\n",
+			       ((dm->support_ability & ODM_BB_FA_CNT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "04. (( %s ))RSSI_MNTR\n",
+			       ((dm->support_ability & ODM_BB_RSSI_MONITOR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "05. (( %s ))CCK_PD\n",
+			       ((dm->support_ability & ODM_BB_CCK_PD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "06. (( %s ))ANT_DIV\n",
+			       ((dm->support_ability & ODM_BB_ANT_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "07. (( %s ))SMT_ANT\n",
+			       ((dm->support_ability & ODM_BB_SMT_ANT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "08. (( %s ))PWR_TRAIN\n",
+			       ((dm->support_ability & ODM_BB_PWR_TRAIN) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "09. (( %s ))RA\n",
+			       ((dm->support_ability & ODM_BB_RATE_ADAPTIVE) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "10. (( %s ))PATH_DIV\n",
+			       ((dm->support_ability & ODM_BB_PATH_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "11. (( %s ))DFS\n",
+			       ((dm->support_ability & ODM_BB_DFS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "12. (( %s ))DYN_ARFR\n",
+			       ((dm->support_ability & ODM_BB_DYNAMIC_ARFR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "13. (( %s ))ADAPTIVITY\n",
+			       ((dm->support_ability & ODM_BB_ADAPTIVITY) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "14. (( %s ))CFO_TRACK\n",
+			       ((dm->support_ability & ODM_BB_CFO_TRACKING) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "15. (( %s ))ENV_MONITOR\n",
+			       ((dm->support_ability & ODM_BB_ENV_MONITOR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "16. (( %s ))PRI_CCA\n",
+			       ((dm->support_ability & ODM_BB_PRIMARY_CCA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "17. (( %s ))ADPTV_SOML\n",
+			       ((dm->support_ability & ODM_BB_ADAPTIVE_SOML) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "18. (( %s ))NA_SAT_CHK\n",
+			       ((dm->support_ability & ODM_BB_LNA_SAT_CHK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "19. (( %s ))DYN_RX_PATH\n",
+			       ((dm->support_ability & ODM_BB_DYNAMIC_RX_PATH) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[Supportability] PhyDM offload ability\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))PHY PARAM OFFLOAD\n",
+			       ((dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "01. (( %s ))RF IQK OFFLOAD\n",
+			       ((dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+
+	}
+	/*
+	else if(dm_value[0] == 101)
+	{
+		dm->support_ability = 0 ;
+		dbg_print("Disable all support_ability components\n");
+		PDM_SNPF((output+used, out_len-used,"%s\n", "Disable all support_ability components"));
+	}
+	*/
+	else {
+		if (dm_value[1] == 1) { /* enable */
+			dm->support_ability |= (one << dm_value[0]);
+			if (BIT(dm_value[0]) & ODM_BB_PATH_DIV)
+				phydm_path_diversity_init(dm);
+		} else if (dm_value[1] == 2)	/* disable */
+			dm->support_ability &= ~(one << dm_value[0]);
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "%s\n",
+				       "[Warning!!!]  1:enable,  2:disable");
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "pre-support_ability  =  0x%llx\n",
+		         pre_support_ability);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Curr-support_ability =  0x%llx\n",
+		       dm->support_ability);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%s\n",
+		       "================================");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_watchdog_lps_32k(
+	struct dm_struct		*dm
+)
+{
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
+
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_dig_lps_32k(dm);
+	phydm_common_info_self_reset(dm);
+}
+
+void
+phydm_watchdog_lps(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
+
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_basic_dbg_message(dm);
+	phydm_receiver_blocking(dm);
+	odm_false_alarm_counter_statistics(dm);
+	phydm_dig_by_rssi_lps(dm);
+	phydm_cck_pd_th(dm);
+	phydm_adaptivity(dm);
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	odm_antenna_diversity(dm); /*enable AntDiv in PS mode, request from SD4 Jeff*/
+	#endif
+	phydm_common_info_self_reset(dm);
+#endif
+}
+
+void
+phydm_watchdog_mp(
+	struct dm_struct		*dm
+)
+{
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_caller(dm);
+#endif
+}
+
+void
+phydm_pause_dm_watchdog(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+
+	if (pause_type == PHYDM_PAUSE) {
+		dm->disable_phydm_watchdog = 1;
+		PHYDM_DBG(dm, ODM_COMP_API, "PHYDM Stop\n");
+	} else {
+		dm->disable_phydm_watchdog = 0;
+		PHYDM_DBG(dm, ODM_COMP_API, "PHYDM Start\n");
+	}
+}
+
+u8
+phydm_pause_func(
+	void						*dm_void,
+	enum phydm_func_idx	pause_func,
+	enum phydm_pause_type	pause_type,
+	enum phydm_pause_level	pause_lv,
+	u8						val_lehgth,
+	u32						*val_buf
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	s8	*pause_lv_pre = &dm->s8_dummy;
+	u32	*bkp_val = &dm->u32_dummy;
+	u32	ori_val[5] = {0};
+	u64	pause_func_bitmap = (u64)BIT(pause_func);
+	u8	i;
+
+
+
+	PHYDM_DBG(dm, ODM_COMP_API, "[%s][%s] LV=%d, Len=%d\n", __func__, 
+		((pause_type == PHYDM_PAUSE) ? "Pause" : "Resume"),  pause_lv, val_lehgth);
+
+	if (pause_lv >= PHYDM_PAUSE_MAX_NUM) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] Wrong LV=%d\n", pause_lv);
+		return PAUSE_FAIL;
+	}
+
+	if (pause_func == F00_DIG) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[DIG]\n");
+
+		if (val_lehgth != 1) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 1\n");
+			return PAUSE_FAIL;
+		}
+		
+		ori_val[0] = (u32)(dm->dm_dig_table.cur_ig_value); /*0xc50*/
+		pause_lv_pre = &dm->pause_lv_table.lv_dig;
+		bkp_val = (u32*)(&dm->dm_dig_table.rvrt_val);
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_dig_val; /*function pointer hook*/
+	
+	} else
+	
+#ifdef PHYDM_SUPPORT_CCKPD
+	if (pause_func == F05_CCK_PD) {
+		
+		PHYDM_DBG(dm, ODM_COMP_API, "[CCK_PD]\n");
+
+		if (val_lehgth != 2) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 2\n");
+			return PAUSE_FAIL;
+		}
+		
+		ori_val[0] = dm->dm_cckpd_table.cur_cck_cca_thres; /*0xa0a*/
+		ori_val[1] = dm->dm_cckpd_table.cck_cca_th_aaa;	/*0xaaa*/
+		pause_lv_pre = &dm->pause_lv_table.lv_cckpd;
+		bkp_val = &dm->dm_cckpd_table.rvrt_val[0];
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_cckpd_val; /*function pointer hook*/
+		
+	} else 
+#endif
+
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	if (pause_func == F06_ANT_DIV) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[AntDiv]\n");
+
+		if (val_lehgth != 1) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 1\n");
+			return PAUSE_FAIL;
+		}
+		
+		ori_val[0] = (u32)(dm->dm_fat_table.rx_idle_ant); /*default antenna*/
+		pause_lv_pre = &dm->pause_lv_table.lv_antdiv;
+		bkp_val = (u32*)(&dm->dm_fat_table.rvrt_val);
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_antdiv_val; /*function pointer hook*/
+	
+	} else
+#endif
+
+	if (pause_func == F13_ADPTVTY) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Adaptivity]\n");
+
+		if (val_lehgth != 2) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] val_length != 2\n");
+			return PAUSE_FAIL;
+		}
+
+		ori_val[0] = (u32)(dm->adaptivity.th_l2h);	/*th_l2h*/
+		ori_val[1] = (u32)(dm->adaptivity.th_h2l);	/*th_h2l*/
+		pause_lv_pre = &dm->pause_lv_table.lv_adapt;
+		bkp_val = (u32 *)(&dm->adaptivity.rvrt_val);
+		dm->phydm_func_handler.pause_phydm_handler = phydm_set_edcca_val; /*function pointer hook*/
+
+	} else
+
+	{
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] error func idx\n");
+		return PAUSE_FAIL;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_API, "Pause_LV{new , pre} = {%d ,%d}\n", pause_lv, *pause_lv_pre);
+
+	if ((pause_type == PHYDM_PAUSE) || (pause_type == PHYDM_PAUSE_NO_SET)) {
+		if (pause_lv <= *pause_lv_pre) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[PAUSE FAIL] Pre_LV >= Curr_LV\n");
+			return PAUSE_FAIL;
+		}
+
+		if (!(dm->pause_ability & pause_func_bitmap)) {
+			for (i = 0; i < val_lehgth; i ++)
+				bkp_val[i] = ori_val[i];
+		}
+
+		dm->pause_ability |= pause_func_bitmap;
+		PHYDM_DBG(dm, ODM_COMP_API, "pause_ability=0x%llx\n", dm->pause_ability);
+
+		if (pause_type == PHYDM_PAUSE) {
+			for (i = 0; i < val_lehgth; i ++) {
+				PHYDM_DBG(dm, ODM_COMP_API, "[PAUSE SUCCESS] val_idx[%d]{New, Ori}={0x%x, 0x%x}\n",i, val_buf[i], bkp_val[i]);
+				/**/
+			}
+			dm->phydm_func_handler.pause_phydm_handler(dm, val_buf, val_lehgth);
+		} else {
+			for (i = 0; i < val_lehgth; i ++) {
+				PHYDM_DBG(dm, ODM_COMP_API, "[PAUSE NO Set: SUCCESS] val_idx[%d]{Ori}={0x%x}\n",i, bkp_val[i]);
+				/**/
+			}
+		}
+
+		*pause_lv_pre = pause_lv;
+		return PAUSE_SUCCESS;
+
+	} else if (pause_type == PHYDM_RESUME) {
+		dm->pause_ability &= ~pause_func_bitmap;
+		PHYDM_DBG(dm, ODM_COMP_API, "pause_ability=0x%llx\n", dm->pause_ability);
+		
+		*pause_lv_pre = PHYDM_PAUSE_RELEASE;
+		
+		for (i = 0; i < val_lehgth; i ++) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[RESUME] val_idx[%d]={0x%x}\n", i, bkp_val[i]);
+		}
+		
+		dm->phydm_func_handler.pause_phydm_handler(dm, bkp_val, val_lehgth);
+		
+		return PAUSE_SUCCESS;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] error pause_type\n");
+		return PAUSE_FAIL;
+	}
+	
+}
+
+void
+phydm_pause_func_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i;
+	u8		val_length = 0;
+	u32		val_buf[5] = {0};
+	u8		set_result = 0;
+	enum phydm_func_idx	func = (enum phydm_func_idx)0;
+	enum phydm_pause_type	pause_type = (enum phydm_pause_type)0;
+	enum phydm_pause_level	pause_lv = (enum phydm_pause_level)0;
+	
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "{Func} {1:pause, 2:Resume} {lv} Val[5:0]\n");
+		
+	} else {
+		for (i = 0; i < 10; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+			}
+		}
+
+		func = (enum phydm_func_idx)var1[0];
+		pause_type = (enum phydm_pause_type)var1[1];
+		pause_lv = (enum phydm_pause_level)var1[2];
+	
+
+		for (i = 0; i < 5; i++) {
+			val_buf[i] = var1[3 + i];
+		}
+
+		if (func == F00_DIG) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[DIG]\n");
+			val_length = 1;
+			
+		} else if (func == F05_CCK_PD) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[CCK_PD]\n");
+			val_length = 2;
+		} else if (func == F06_ANT_DIV) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Ant_Div]\n");
+			val_length = 1;
+		} else if (func == F13_ADPTVTY) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Adaptivity]\n");
+			val_length = 2;
+		} else {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Set Function Error]\n");
+			val_length = 0;
+		}
+
+		if (val_length != 0) {
+			
+			PDM_SNPF(out_len, used, output + used, out_len - used, "{%s, lv=%d} val = %d, %d}\n", 
+				       ((pause_type == PHYDM_PAUSE) ? "Pause" : "Resume"),
+				       pause_lv, var1[3], var1[4]);
+			
+			set_result= phydm_pause_func(dm, func, pause_type, pause_lv, val_length, val_buf);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "set_result = %d\n", 
+			set_result);
+	}
+
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+u8
+phydm_stop_dm_watchdog_check(
+	void					*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+
+	if (dm->disable_phydm_watchdog == 1) {
+		PHYDM_DBG(dm, DBG_COMMON_FLOW, "Disable phydm\n");
+		return true;
+	} else
+		return false;
+	
+}
+
+/*
+ * 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
+phydm_watchdog(
+	struct dm_struct		*dm
+)
+{
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
+
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_basic_dbg_message(dm);
+	phydm_auto_dbg_engine(dm);
+	phydm_receiver_blocking(dm);
+	
+	if (phydm_stop_dm_watchdog_check(dm) == true)
+		return;
+
+	phydm_hw_setting(dm);
+	
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0)
+		phydm_tdma_dig_timer_check(dm);
+	else 
+	#endif
+	{
+		odm_false_alarm_counter_statistics(dm);
+		phydm_noisy_detection(dm);
+		phydm_dig(dm);
+		phydm_cck_pd_th(dm);
+	}
+
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+	phydm_update_power_training_state(dm);
+#endif
+	phydm_adaptivity(dm);
+	phydm_ra_info_watchdog(dm);
+	odm_path_diversity(dm);
+	phydm_cfo_tracking(dm);
+	/* odm_dynamic_tx_power(dm); */
+	phydm_dynamic_tx_power(dm);
+	odm_antenna_diversity(dm);
+	phydm_adaptive_soml(dm);
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path(dm);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_beamforming_watchdog(dm);
+#endif
+
+	halrf_watchdog(dm);
+	phydm_primary_cca(dm);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	odm_dtc(dm);
+#endif
+
+	phydm_env_mntr_watchdog(dm);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_watchdog(dm);
+#endif
+
+	phydm_common_info_self_reset(dm);
+
+}
+
+
+/*
+ * Init /.. Fixed HW value. Only init time.
+ *   */
+void
+odm_cmn_info_init(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	u64			value
+)
+{
+	/*  */
+	/* This section is used for init value */
+	/*  */
+	switch	(cmn_info) {
+	/*  */
+	/* Fixed ODM value. */
+	/*  */
+	case	ODM_CMNINFO_ABILITY:
+		dm->support_ability = (u64)value;
+		break;
+
+	case	ODM_CMNINFO_RF_TYPE:
+		dm->rf_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_PLATFORM:
+		dm->support_platform = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_INTERFACE:
+		dm->support_interface = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_MP_TEST_CHIP:
+		dm->is_mp_chip = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_IC_TYPE:
+		dm->support_ic_type = (u32)value;
+		break;
+
+	case	ODM_CMNINFO_CUT_VER:
+		dm->cut_version = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_FAB_VER:
+		dm->fab_version = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_RFE_TYPE:
+		#if (RTL8821C_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8821C)
+			dm->rfe_type_expand = (u8)value; /**/
+		else
+		#endif
+			dm->rfe_type = (u8)value;
+		phydm_init_hw_info_by_rfe(dm);
+		break;
+
+	case    ODM_CMNINFO_RF_ANTENNA_TYPE:
+		dm->ant_div_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH:
+		dm->with_extenal_ant_switch = (u8)value;
+		break;
+
+	case    ODM_CMNINFO_BE_FIX_TX_ANT:
+		dm->dm_fat_table.b_fix_tx_ant = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BOARD_TYPE:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->board_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_PACKAGE_TYPE:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->package_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_EXT_LNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_lna = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_5G_EXT_LNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_lna_5g = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_EXT_PA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_pa = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_5G_EXT_PA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_pa_5g = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_GPA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_gpa = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_APA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_apa = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_GLNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_glna = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_ALNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_alna = (u16)value;
+		break;
+
+	case	ODM_CMNINFO_EXT_TRSW:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_trsw = (u8)value;
+		break;
+	case	ODM_CMNINFO_EXT_LNA_GAIN:
+		dm->ext_lna_gain = (u8)value;
+		break;
+	case	ODM_CMNINFO_PATCH_ID:
+		dm->iot_table.win_patch_id = (u8)value;
+		break;
+	case	ODM_CMNINFO_BINHCT_TEST:
+		dm->is_in_hct_test = (boolean)value;
+		break;
+	case	ODM_CMNINFO_BWIFI_TEST:
+		dm->wifi_test = (u8)value;
+		break;
+	case	ODM_CMNINFO_SMART_CONCURRENT:
+		dm->is_dual_mac_smart_concurrent = (boolean)value;
+		break;
+	case	ODM_CMNINFO_DOMAIN_CODE_2G:
+		dm->odm_regulation_2_4g = (u8)value;
+		break;
+	case	ODM_CMNINFO_DOMAIN_CODE_5G:
+		dm->odm_regulation_5g = (u8)value;
+		break;
+#if (DM_ODM_SUPPORT_TYPE &  (ODM_AP))
+	case	ODM_CMNINFO_CONFIG_BB_RF:
+		dm->config_bbrf = (boolean)value;
+		break;
+#endif
+	case	ODM_CMNINFO_IQKPAOFF:
+		dm->rf_calibrate_info.is_iqk_pa_off = (boolean)value;
+		break;
+	case	ODM_CMNINFO_REGRFKFREEENABLE:
+		dm->rf_calibrate_info.reg_rf_kfree_enable = (u8)value;
+		break;
+	case	ODM_CMNINFO_RFKFREEENABLE:
+		dm->rf_calibrate_info.rf_kfree_enable = (u8)value;
+		break;
+	case	ODM_CMNINFO_NORMAL_RX_PATH_CHANGE:
+		dm->normal_rx_path = (u8)value;
+		break;
+	case	ODM_CMNINFO_EFUSE0X3D8:
+		dm->efuse0x3d8 = (u8)value;
+		break;
+	case	ODM_CMNINFO_EFUSE0X3D7:
+		dm->efuse0x3d7 = (u8)value;
+		break;
+	case	ODM_CMNINFO_ADVANCE_OTA:
+		dm->p_advance_ota = (u8)value;
+		break;
+		
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	case	ODM_CMNINFO_DFS_REGION_DOMAIN:
+		dm->dfs_region_domain = (u8)value;
+		break;
+#endif
+	case	ODM_CMNINFO_SOFT_AP_SPECIAL_SETTING:
+		dm->soft_ap_special_setting = (u32)value;
+		break;
+
+	case	ODM_CMNINFO_DPK_EN:
+		/*dm->dpk_en = (u1Byte)value;*/
+		halrf_cmn_info_set(dm, HALRF_CMNINFO_DPK_EN, (u64)value);
+		break;
+
+	case	ODM_CMNINFO_HP_HWID:
+		dm->hp_hw_id = (boolean)value;
+		break;
+	/* To remove the compiler warning, must add an empty default statement to handle the other values. */
+	default:
+		/* do nothing */
+		break;
+
+	}
+
+}
+
+
+void
+odm_cmn_info_hook(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	void			*value
+)
+{
+	/*  */
+	/* Hook call by reference pointer. */
+	/*  */
+	switch	(cmn_info) {
+	/*  */
+	/* Dynamic call by reference pointer. */
+	/*  */
+	case	ODM_CMNINFO_TX_UNI:
+		dm->num_tx_bytes_unicast = (u64 *)value;
+		break;
+
+	case	ODM_CMNINFO_RX_UNI:
+		dm->num_rx_bytes_unicast = (u64 *)value;
+		break;
+
+	case	ODM_CMNINFO_BAND:
+		dm->band_type = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_CHNL_OFFSET:
+		dm->sec_ch_offset = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_MODE:
+		dm->security = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_BW:
+		dm->band_width = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_CHNL:
+		dm->channel = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_SCAN:
+		dm->is_scan_in_process = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_POWER_SAVING:
+		dm->is_power_saving = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_ONE_PATH_CCA:
+		dm->one_path_cca = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_DRV_STOP:
+		dm->is_driver_stopped = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_PNP_IN:
+		dm->is_driver_is_going_to_pnp_set_power_sleep = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_INIT_ON:
+		dm->pinit_adpt_in_progress = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_ANT_TEST:
+		dm->antenna_test = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_NET_CLOSED:
+		dm->is_net_closed = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_FORCED_RATE:
+		dm->forced_data_rate = (u16 *)value;
+		break;
+	case ODM_CMNINFO_ANT_DIV:
+		dm->enable_antdiv = (u8 *)value;
+		break;
+
+	case ODM_CMNINFO_ADAPTIVE_SOML:
+		dm->en_adap_soml = (u8 *)value;
+		break;
+
+	case ODM_CMNINFO_ADAPTIVITY:
+		dm->enable_adaptivity = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_P2P_LINK:
+		dm->dm_dig_table.is_p2p_in_process = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_IS1ANTENNA:
+		dm->is_1_antenna = (boolean *)value;
+		break;
+
+	case	ODM_CMNINFO_RFDEFAULTPATH:
+		dm->rf_default_path = (u8 *)value;
+		break;
+
+	case	ODM_CMNINFO_FCS_MODE:
+		dm->is_fcs_mode_enable = (boolean *)value;
+		break;
+	/*add by YuChen for beamforming PhyDM*/
+	case	ODM_CMNINFO_HUBUSBMODE:
+		dm->hub_usb_mode = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS:
+		dm->is_fw_dw_rsvd_page_in_progress = (boolean *)value;
+		break;
+	case	ODM_CMNINFO_TX_TP:
+		dm->current_tx_tp = (u32 *)value;
+		break;
+	case	ODM_CMNINFO_RX_TP:
+		dm->current_rx_tp = (u32 *)value;
+		break;
+	case	ODM_CMNINFO_SOUNDING_SEQ:
+		dm->sounding_seq = (u8 *)value;
+		break;
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	case	ODM_CMNINFO_DFS_MASTER_ENABLE:
+		dm->dfs_master_enabled = (u8 *)value;
+		break;
+#endif
+	case	ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC:
+		dm->dm_fat_table.p_force_tx_ant_by_desc = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA:
+		dm->dm_fat_table.p_default_s0_s1 = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_SOFT_AP_MODE:
+		dm->soft_ap_mode = (u32 *)value;
+		break;
+	case ODM_CMNINFO_MP_MODE:
+		dm->mp_mode = (u8 *)value;
+		break;
+	case	ODM_CMNINFO_INTERRUPT_MASK:
+		dm->interrupt_mask = (u32 *)value;
+		break;
+	case ODM_CMNINFO_BB_OPERATION_MODE:
+		dm->bb_op_mode = (u8 *)value;
+		break;
+	case ODM_CMNINFO_BF_ANTDIV_DECISION:
+		dm->dm_fat_table.is_no_csi_feedback = (boolean *)value;
+		break;
+
+	default:
+		/*do nothing*/
+		break;
+
+	}
+
+}
+/*
+ * Update band/CHannel/.. The values are dynamic but non-per-packet.
+ *   */
+void
+odm_cmn_info_update(
+	struct dm_struct		*dm,
+	u32			cmn_info,
+	u64			value
+)
+{
+	/*  */
+	/* This init variable may be changed in run time. */
+	/*  */
+	switch	(cmn_info) {
+	case ODM_CMNINFO_LINK_IN_PROGRESS:
+		dm->is_link_in_process = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_ABILITY:
+		dm->support_ability = (u64)value;
+		break;
+
+	case	ODM_CMNINFO_RF_TYPE:
+		dm->rf_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_WIFI_DIRECT:
+		dm->is_wifi_direct = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_WIFI_DISPLAY:
+		dm->is_wifi_display = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_LINK:
+		dm->is_linked = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_CMW500LINK:
+		dm->iot_table.is_linked_cmw500 = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_STATION_STATE:
+		dm->bsta_state = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_RSSI_MIN:
+		dm->rssi_min = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_RSSI_MIN_BY_PATH:
+		dm->rssi_min_by_path = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_DBG_COMP:
+		dm->debug_components = (u64)value;
+		break;
+
+	case	ODM_CMNINFO_DBG_LEVEL:
+		dm->debug_level = (u32)value;
+		break;
+
+#ifdef ODM_CONFIG_BT_COEXIST
+	/* The following is for BT HS mode and BT coexist mechanism. */
+	case ODM_CMNINFO_BT_ENABLED:
+		dm->bt_info_table.is_bt_enabled = (boolean)value;
+		break;
+
+	case ODM_CMNINFO_BT_HS_CONNECT_PROCESS:
+		dm->bt_info_table.is_bt_connect_process = (boolean)value;
+		break;
+
+	case ODM_CMNINFO_BT_HS_RSSI:
+		dm->bt_info_table.bt_hs_rssi = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BT_OPERATION:
+		dm->bt_info_table.is_bt_hs_operation = (boolean)value;
+		break;
+
+	case	ODM_CMNINFO_BT_LIMITED_DIG:
+		dm->bt_info_table.is_bt_limited_dig = (boolean)value;
+		break;
+#endif
+
+	case	ODM_CMNINFO_AP_TOTAL_NUM:
+		dm->ap_total_num = (u8)value;
+		break;
+
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	case	ODM_CMNINFO_DFS_REGION_DOMAIN:
+		dm->dfs_region_domain = (u8)value;
+		break;
+#endif
+
+	case	ODM_CMNINFO_BT_CONTINUOUS_TURN:
+		dm->is_bt_continuous_turn = (boolean)value;
+		break;
+
+#if 0
+	case	ODM_CMNINFO_OP_MODE:
+		dm->op_mode = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BAND:
+		dm->band_type = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_CHNL_OFFSET:
+		dm->sec_ch_offset = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_SEC_MODE:
+		dm->security = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_BW:
+		dm->band_width = (u8)value;
+		break;
+
+	case	ODM_CMNINFO_CHNL:
+		dm->channel = (u8)value;
+		break;
+#endif
+	default:
+		/* do nothing */
+		break;
+	}
+
+
+}
+
+u32
+phydm_cmn_info_query(
+	struct dm_struct		*dm,
+	enum phydm_info_query		info_type
+)
+{
+	struct phydm_fa_struct		*fa_t = &dm->false_alm_cnt;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+
+	switch (info_type) {
+	/*=== [FA Relative] ===========================================*/
+	case PHYDM_INFO_FA_OFDM:
+		return fa_t->cnt_ofdm_fail;
+
+	case PHYDM_INFO_FA_CCK:
+		return fa_t->cnt_cck_fail;
+
+	case PHYDM_INFO_FA_TOTAL:
+		return fa_t->cnt_all;
+
+	case PHYDM_INFO_CCA_OFDM:
+		return fa_t->cnt_ofdm_cca;
+
+	case PHYDM_INFO_CCA_CCK:
+		return fa_t->cnt_cck_cca;
+
+	case PHYDM_INFO_CCA_ALL:
+		return fa_t->cnt_cca_all;
+
+	case PHYDM_INFO_CRC32_OK_VHT:
+		return fa_t->cnt_vht_crc32_ok;
+
+	case PHYDM_INFO_CRC32_OK_HT:
+		return fa_t->cnt_ht_crc32_ok;
+
+	case PHYDM_INFO_CRC32_OK_LEGACY:
+		return fa_t->cnt_ofdm_crc32_ok;
+
+	case PHYDM_INFO_CRC32_OK_CCK:
+		return fa_t->cnt_cck_crc32_ok;
+
+	case PHYDM_INFO_CRC32_ERROR_VHT:
+		return fa_t->cnt_vht_crc32_error;
+
+	case PHYDM_INFO_CRC32_ERROR_HT:
+		return fa_t->cnt_ht_crc32_error;
+
+	case PHYDM_INFO_CRC32_ERROR_LEGACY:
+		return fa_t->cnt_ofdm_crc32_error;
+
+	case PHYDM_INFO_CRC32_ERROR_CCK:
+		return fa_t->cnt_cck_crc32_error;
+
+	case PHYDM_INFO_EDCCA_FLAG:
+		return fa_t->edcca_flag;
+
+	case PHYDM_INFO_OFDM_ENABLE:
+		return fa_t->ofdm_block_enable;
+
+	case PHYDM_INFO_CCK_ENABLE:
+		return fa_t->cck_block_enable;
+
+	case PHYDM_INFO_DBG_PORT_0:
+		return fa_t->dbg_port0;
+				
+	case PHYDM_INFO_CRC32_OK_HT_AGG:
+		return fa_t->cnt_ht_crc32_ok_agg;
+		
+	case PHYDM_INFO_CRC32_ERROR_HT_AGG:
+		return fa_t->cnt_ht_crc32_error_agg;
+		
+	/*=== [DIG] ================================================*/	
+	
+	case PHYDM_INFO_CURR_IGI:
+		return dig_t->cur_ig_value;
+
+	/*=== [RSSI] ===============================================*/
+	case PHYDM_INFO_RSSI_MIN:
+		return (u32)dm->rssi_min;
+		
+	case PHYDM_INFO_RSSI_MAX:
+		return (u32)dm->rssi_max;
+
+	case PHYDM_INFO_CLM_RATIO :
+		return (u32)ccx_info->clm_ratio;
+	case PHYDM_INFO_NHM_RATIO :
+		return (u32)ccx_info->nhm_ratio;
+	default:
+		return 0xffffffff;
+
+	}
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_init_all_work_items(struct dm_struct	*dm)
+{
+	void		*adapter = dm->adapter;
+#if USE_WORKITEM
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	odm_initialize_work_item(dm,
+			 &dm->dm_drp_table.phydm_dynamic_rx_path_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_dynamic_rx_path_workitem_callback,
+				 (void *)adapter,
+				 "DynamicRxPathWorkitem");
+
+#endif
+
+#ifdef CONFIG_ADAPTIVE_SOML
+	odm_initialize_work_item(dm,
+			 &dm->dm_soml_table.phydm_adaptive_soml_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_adaptive_soml_workitem_callback,
+				 (void *)adapter,
+				 "AdaptiveSOMLWorkitem");
+#endif
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	odm_initialize_work_item(dm,
+		 &dm->dm_swat_table.phydm_sw_antenna_switch_workitem,
+			 (RT_WORKITEM_CALL_BACK)odm_sw_antdiv_workitem_callback,
+				 (void *)adapter,
+				 "AntennaSwitchWorkitem");
+#endif
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	odm_initialize_work_item(dm,
+			 &dm->dm_sat_table.hl_smart_antenna_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_beam_switch_workitem_callback,
+				 (void *)adapter,
+				 "hl_smart_ant_workitem");
+
+	odm_initialize_work_item(dm,
+		 &dm->dm_sat_table.hl_smart_antenna_decision_workitem,
+		 (RT_WORKITEM_CALL_BACK)phydm_beam_decision_workitem_callback,
+				 (void *)adapter,
+				 "hl_smart_ant_decision_workitem");
+#endif
+
+	odm_initialize_work_item(
+		dm,
+		&dm->path_div_switch_workitem,
+		(RT_WORKITEM_CALL_BACK)odm_path_div_chk_ant_switch_workitem_callback,
+		(void *)adapter,
+		"SWAS_WorkItem");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->cck_path_diversity_workitem,
+		(RT_WORKITEM_CALL_BACK)odm_cck_tx_path_diversity_work_item_callback,
+		(void *)adapter,
+		"CCKTXPathDiversityWorkItem");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->ra_rpt_workitem,
+		(RT_WORKITEM_CALL_BACK)halrf_update_init_rate_work_item_callback,
+		(void *)adapter,
+		"ra_rpt_workitem");
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+	odm_initialize_work_item(
+		dm,
+		&dm->fast_ant_training_workitem,
+		(RT_WORKITEM_CALL_BACK)odm_fast_ant_training_work_item_callback,
+		(void *)adapter,
+		"fast_ant_training_workitem");
+#endif
+
+#endif /*#if USE_WORKITEM*/
+
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_enter_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_enter_work_item_callback,
+		(void *)adapter,
+		"txbf_enter_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_leave_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_leave_work_item_callback,
+		(void *)adapter,
+		"txbf_leave_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_fw_ndpa_work_item_callback,
+		(void *)adapter,
+		"txbf_fw_ndpa_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_clk_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_clk_work_item_callback,
+		(void *)adapter,
+		"txbf_clk_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_rate_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_rate_work_item_callback,
+		(void *)adapter,
+		"txbf_rate_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_status_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_status_work_item_callback,
+		(void *)adapter,
+		"txbf_status_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_reset_tx_path_work_item_callback,
+		(void *)adapter,
+		"txbf_reset_tx_path_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item,
+		(RT_WORKITEM_CALL_BACK)hal_com_txbf_get_tx_rate_work_item_callback,
+		(void *)adapter,
+		"txbf_get_tx_rate_work_item");
+#endif
+
+	odm_initialize_work_item(
+		dm,
+		&dm->adaptivity.phydm_pause_edcca_work_item,
+		(RT_WORKITEM_CALL_BACK)phydm_pause_edcca_work_item_callback,
+		(void *)adapter,
+		"phydm_pause_edcca_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->adaptivity.phydm_resume_edcca_work_item,
+		(RT_WORKITEM_CALL_BACK)phydm_resume_edcca_work_item_callback,
+		(void *)adapter,
+		"phydm_resume_edcca_work_item");
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	odm_initialize_work_item(
+		dm,
+		&dm->adcsmp.adc_smp_work_item,
+		(RT_WORKITEM_CALL_BACK)adc_smp_work_item_callback,
+		(void *)adapter,
+		"adc_smp_work_item");
+
+	odm_initialize_work_item(
+		dm,
+		&dm->adcsmp.adc_smp_work_item_1,
+		(RT_WORKITEM_CALL_BACK)adc_smp_work_item_callback,
+		(void *)adapter,
+		"adc_smp_work_item_1");
+#endif
+
+}
+
+void
+odm_free_all_work_items(struct dm_struct	*dm)
+{
+#if USE_WORKITEM
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	odm_free_work_item(&dm->dm_swat_table.phydm_sw_antenna_switch_workitem);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	odm_free_work_item(&dm->dm_drp_table.phydm_dynamic_rx_path_workitem);
+#endif
+
+#ifdef CONFIG_ADAPTIVE_SOML
+	odm_free_work_item(&dm->dm_soml_table.phydm_adaptive_soml_workitem);
+#endif
+
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	odm_free_work_item(&dm->dm_sat_table.hl_smart_antenna_workitem);
+	odm_free_work_item(&dm->dm_sat_table.hl_smart_antenna_decision_workitem);
+#endif
+
+	odm_free_work_item(&dm->path_div_switch_workitem);
+	odm_free_work_item(&dm->cck_path_diversity_workitem);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+	odm_free_work_item(&dm->fast_ant_training_workitem);
+#endif
+	odm_free_work_item(&dm->ra_rpt_workitem);
+	/*odm_free_work_item((&dm->sbdcnt_workitem));*/
+#endif
+
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_enter_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_leave_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_clk_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_rate_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_status_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item));
+#endif
+
+	odm_free_work_item((&dm->adaptivity.phydm_pause_edcca_work_item));
+	odm_free_work_item((&dm->adaptivity.phydm_resume_edcca_work_item));
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	odm_free_work_item((&dm->adcsmp.adc_smp_work_item));
+	odm_free_work_item((&dm->adcsmp.adc_smp_work_item_1));
+#endif
+
+}
+#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+void
+odm_init_all_timers(
+	struct dm_struct	*dm
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	odm_ant_div_timers(dm, INIT_ANTDIV_TIMMER);
+#endif
+
+	phydm_adaptive_soml_timers(dm, INIT_SOML_TIMMER);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_timers(dm, INIT_LNA_SAT_CHK_TIMMER);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_timers(dm, INIT_DRP_TIMMER);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_initialize_timer(dm, &dm->path_div_switch_timer,
+		(void *)odm_path_div_chk_ant_switch_callback, NULL, "PathDivTimer");
+	odm_initialize_timer(dm, &dm->cck_path_diversity_timer,
+		(void *)odm_cck_tx_path_diversity_callback, NULL, "cck_path_diversity_timer");
+	odm_initialize_timer(dm, &dm->sbdcnt_timer,
+			     (void *)phydm_sbd_callback, NULL, "SbdTimer");
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_initialize_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer,
+		(void *)hal_com_txbf_fw_ndpa_timer_callback, NULL, "txbf_fw_ndpa_timer");
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_initialize_timer(dm, &dm->beamforming_info.beamforming_timer,
+		(void *)beamforming_sw_timer_callback, NULL, "beamforming_timer");
+#endif
+#endif
+}
+
+void
+odm_cancel_all_timers(
+	struct dm_struct	*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	/* 2012/01/12 MH Temp BSOD fix. We need to find NIC allocate mem fail reason in win7*/
+	if (dm->adapter == NULL)
+		return;	
+#endif
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	odm_ant_div_timers(dm, CANCEL_ANTDIV_TIMMER);
+#endif
+
+	phydm_adaptive_soml_timers(dm, CANCEL_SOML_TIMMER);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_timers(dm, CANCEL_LNA_SAT_CHK_TIMMER);
+#endif
+
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_timers(dm, CANCEL_DRP_TIMMER);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_cancel_timer(dm, &dm->path_div_switch_timer);
+	odm_cancel_timer(dm, &dm->cck_path_diversity_timer);
+	odm_cancel_timer(dm, &dm->sbdcnt_timer);
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_cancel_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_cancel_timer(dm, &dm->beamforming_info.beamforming_timer);
+#endif
+#endif
+
+}
+
+
+void
+odm_release_all_timers(
+	struct dm_struct	*dm
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	odm_ant_div_timers(dm, RELEASE_ANTDIV_TIMMER);
+#endif
+	phydm_adaptive_soml_timers(dm, RELEASE_SOML_TIMMER);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_chk_timers(dm, RELEASE_LNA_SAT_CHK_TIMMER);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_dynamic_rx_path_timers(dm, RELEASE_DRP_TIMMER);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_release_timer(dm, &dm->path_div_switch_timer);
+	odm_release_timer(dm, &dm->cck_path_diversity_timer);
+	odm_release_timer(dm, &dm->sbdcnt_timer);
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_release_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
+#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	odm_release_timer(dm, &dm->beamforming_info.beamforming_timer);
+#endif
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+void
+odm_init_all_threads(
+	struct dm_struct	*dm
+)
+{
+#ifdef TPT_THREAD
+	k_tpt_task_init(dm->priv);
+#endif
+}
+
+void
+odm_stop_all_threads(
+	struct dm_struct	*dm
+)
+{
+#ifdef TPT_THREAD
+	k_tpt_task_stop(dm->priv);
+#endif
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+/* Justin: According to the current RRSI to adjust Response Frame TX power, 2012/11/05 */
+void odm_dtc(struct dm_struct *dm)
+{
+#ifdef CONFIG_DM_RESP_TXAGC
+#define DTC_BASE            35	/* RSSI higher than this value, start to decade TX power */
+#define DTC_DWN_BASE       (DTC_BASE-5)	/* RSSI lower than this value, start to increase TX power */
+
+	/* RSSI vs TX power step mapping: decade TX power */
+	static const u8 dtc_table_down[] = {
+		DTC_BASE,
+		(DTC_BASE + 5),
+		(DTC_BASE + 10),
+		(DTC_BASE + 15),
+		(DTC_BASE + 20),
+		(DTC_BASE + 25)
+	};
+
+	/* RSSI vs TX power step mapping: increase TX power */
+	static const u8 dtc_table_up[] = {
+		DTC_DWN_BASE,
+		(DTC_DWN_BASE - 5),
+		(DTC_DWN_BASE - 10),
+		(DTC_DWN_BASE - 15),
+		(DTC_DWN_BASE - 15),
+		(DTC_DWN_BASE - 20),
+		(DTC_DWN_BASE - 20),
+		(DTC_DWN_BASE - 25),
+		(DTC_DWN_BASE - 25),
+		(DTC_DWN_BASE - 30),
+		(DTC_DWN_BASE - 35)
+	};
+
+	u8 i;
+	u8 dtc_steps = 0;
+	u8 sign;
+	u8 resp_txagc = 0;
+
+#if 0
+	/* As DIG is disabled, DTC is also disable */
+	if (!(dm->support_ability & ODM_XXXXXX))
+		return;
+#endif
+
+	if (dm->rssi_min > DTC_BASE) {
+		/* need to decade the CTS TX power */
+		sign = 1;
+		for (i = 0; i < ARRAY_SIZE(dtc_table_down); i++) {
+			if ((dtc_table_down[i] >= dm->rssi_min) || (dtc_steps >= 6))
+				break;
+			else
+				dtc_steps++;
+		}
+	}
+#if 0
+	else if (dm->rssi_min > DTC_DWN_BASE) {
+		/* needs to increase the CTS TX power */
+		sign = 0;
+		dtc_steps = 1;
+		for (i = 0; i < ARRAY_SIZE(dtc_table_up); i++) {
+			if ((dtc_table_up[i] <= dm->rssi_min) || (dtc_steps >= 10))
+				break;
+			else
+				dtc_steps++;
+		}
+	}
+#endif
+	else {
+		sign = 0;
+		dtc_steps = 0;
+	}
+
+	resp_txagc = dtc_steps | (sign << 4);
+	resp_txagc = resp_txagc | (resp_txagc << 5);
+	odm_write_1byte(dm, 0x06d9, resp_txagc);
+
+	PHYDM_DBG(dm, ODM_COMP_PWR_TRAIN, "%s rssi_min:%u, set RESP_TXAGC to %s %u\n",
+		__func__, dm->rssi_min, sign ? "minus" : "plus", dtc_steps);
+#endif /* CONFIG_RESP_TXAGC_ADJUST */
+}
+
+#endif /* #if (DM_ODM_SUPPORT_TYPE == ODM_CE) */
+
+
+/*<20170126, BB-Kevin>8188F D-CUT DC cancellation and 8821C*/
+void
+phydm_dc_cancellation(
+	struct dm_struct	*dm
+
+)
+{	
+#ifdef PHYDM_DC_CANCELLATION
+	u32		offset_i_hex[PHYDM_MAX_RF_PATH] = {0};
+	u32		offset_q_hex[PHYDM_MAX_RF_PATH] = {0};
+	u32		reg_value32[PHYDM_MAX_RF_PATH] = {0};
+	u8		path = RF_PATH_A;
+
+	if (!(dm->support_ic_type & ODM_DC_CANCELLATION_SUPPORT))
+		return;
+
+	if ((dm->support_ic_type & ODM_RTL8188F) && (dm->cut_version < ODM_CUT_D))
+		return;
+
+	/*DC_Estimation (only for 2x2 ic now) */
+
+	for (path = RF_PATH_A; path < PHYDM_MAX_RF_PATH; path++) {
+		if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
+			if (!phydm_set_bb_dbg_port(dm,
+				BB_DBGPORT_PRIORITY_2, 0x235)) {/*set debug port to 0x235*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					"[DC Cancellation] Set Debug port Fail");
+				return;
+			}
+		} else if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B)) {
+			if (!phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_2, 0x200)) {
+				/*set debug port to 0x200*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					"[DC Cancellation] Set Debug port Fail");
+				return;
+			}
+			phydm_bb_dbg_port_header_sel(dm, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				if (!phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_2, 0x202)) {
+					/*set debug port to 0x200*/
+					PHYDM_DBG(dm, ODM_COMP_API,
+						"[DC Cancellation] Set Debug port Fail");
+					return;
+				}
+				phydm_bb_dbg_port_header_sel(dm, 0x0);
+			}
+		}
+	
+		odm_write_dig(dm, 0x7E);
+	
+		if (dm->support_ic_type & ODM_IC_11N_SERIES)
+			odm_set_bb_reg(dm, 0x88c, BIT(21)|BIT(20), 0x3);
+		else {
+			odm_set_bb_reg(dm, 0xc00, BIT(1)|BIT(0), 0x0);
+			if (dm->rf_type > RF_1T1R)
+				odm_set_bb_reg(dm, 0xe00, BIT(1)|BIT(0), 0x0);
+		}
+		odm_set_bb_reg(dm, 0xa78, MASKBYTE1, 0x0); /*disable CCK DCNF*/
+	
+		PHYDM_DBG(dm, ODM_COMP_API, "DC cancellation Begin!!!");
+	
+		phydm_stop_ck320(dm, true);	/*stop ck320*/
+
+		/* the same debug port both for path-a and path-b*/
+		reg_value32[path] = phydm_get_bb_dbg_port_value(dm);
+
+		phydm_stop_ck320(dm, false);	/*start ck320*/
+
+		if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			odm_set_bb_reg(dm, 0x88c, BIT(21)|BIT(20), 0x0);
+		} else {
+			odm_set_bb_reg(dm, 0xc00, BIT(1)|BIT(0), 0x3);
+			odm_set_bb_reg(dm, 0xe00, BIT(1)|BIT(0), 0x3);
+		}
+		odm_write_dig(dm, 0x20);
+		phydm_release_bb_dbg_port(dm);
+
+		PHYDM_DBG(dm, ODM_COMP_API, "DC cancellation OK!!!");
+	}
+		
+	/*DC_Cancellation*/
+	odm_set_bb_reg(dm, 0xa9c, BIT(20), 0x1); /*DC compensation to CCK data path*/
+	if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
+		offset_i_hex[0] = (reg_value32[0] & 0xffc0000) >> 18;
+		offset_q_hex[0] = (reg_value32[0] & 0x3ff00) >> 8;
+
+		/*Before filling into registers, offset should be multiplexed (-1)*/
+		offset_i_hex[0] = (offset_i_hex[0] >= 0x200) ? (0x400 - offset_i_hex[0]) : (0x1ff - offset_i_hex[0]);
+		offset_q_hex[0] = (offset_q_hex[0] >= 0x200) ? (0x400 - offset_q_hex[0]) : (0x1ff - offset_q_hex[0]);
+
+		odm_set_bb_reg(dm, 0x950, 0x1ff, offset_i_hex[0]);
+		odm_set_bb_reg(dm, 0x950, 0x1ff0000, offset_q_hex[0]);
+	} else if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B)) {
+	
+		/* Path-a */
+		offset_i_hex[0] = (reg_value32[0] & 0xffc00) >> 10;
+		offset_q_hex[0] = reg_value32[0] & 0x3ff;
+
+		/*Before filling into registers, offset should be multiplexed (-1)*/
+		offset_i_hex[0] = 0x400 - offset_i_hex[0];
+		offset_q_hex[0] = 0x400 - offset_q_hex[0];
+
+		odm_set_bb_reg(dm, 0xc10, 0x3c000000, ((0x3c0 & offset_i_hex[0]) >> 6));
+		odm_set_bb_reg(dm, 0xc10, 0xfc00, (0x3f & offset_i_hex[0]));
+		odm_set_bb_reg(dm, 0xc14, 0x3c000000, ((0x3c0 & offset_q_hex[0]) >> 6));
+		odm_set_bb_reg(dm, 0xc14, 0xfc00, (0x3f & offset_q_hex[0]));
+
+		/* Path-b */
+		if (dm->rf_type > RF_1T1R) {
+			
+			offset_i_hex[1] = (reg_value32[1] & 0xffc00) >> 10;
+			offset_q_hex[1] = reg_value32[1] & 0x3ff;
+
+		/*Before filling into registers, offset should be multiplexed (-1)*/
+			offset_i_hex[1] = 0x400 - offset_i_hex[1];
+			offset_q_hex[1] = 0x400 - offset_q_hex[1];
+
+			odm_set_bb_reg(dm, 0xe10, 0x3c000000, ((0x3c0 & offset_i_hex[1]) >> 6));
+			odm_set_bb_reg(dm, 0xe10, 0xfc00, (0x3f & offset_i_hex[1]));
+			odm_set_bb_reg(dm, 0xe14, 0x3c000000, ((0x3c0 & offset_q_hex[1]) >> 6));
+			odm_set_bb_reg(dm, 0xe14, 0xfc00, (0x3f & offset_q_hex[1]));
+		}
+	}
+#endif
+}
+
+void
+phydm_receiver_blocking(
+	void *dm_void
+)
+{
+#ifdef CONFIG_RECEIVER_BLOCKING
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	channel = *dm->channel;
+	u8	bw = *dm->band_width;
+	u32	bb_regf0 = odm_get_bb_reg(dm, 0xf0, MASKDWORD);
+
+	if (!(dm->support_ic_type & ODM_RECEIVER_BLOCKING_SUPPORT))
+		return;
+
+	if ((dm->support_ic_type & ODM_RTL8188E && ((bb_regf0 & 0xf000) >> 12) < 8) ||
+		dm->support_ic_type & ODM_RTL8192E) { /*8188E_T version*/
+		if (dm->consecutive_idlel_time > 10 && *dm->mp_mode == false && dm->adaptivity_enable == true) {
+			if ((bw == CHANNEL_WIDTH_20) && (channel == 1)) {
+				phydm_nbi_setting(dm, FUNC_ENABLE, channel, 20, 2410, PHYDM_DONT_CARE);
+				dm->is_receiver_blocking_en = true;
+			} else if ((bw == CHANNEL_WIDTH_20) && (channel == 13)) {
+				phydm_nbi_setting(dm, FUNC_ENABLE, channel, 20, 2473, PHYDM_DONT_CARE);
+				dm->is_receiver_blocking_en = true;
+			} else if (dm->is_receiver_blocking_en && channel != 1 && channel != 13) {
+				phydm_nbi_enable(dm, FUNC_DISABLE);
+				odm_set_bb_reg(dm, 0xc40, 0x1f000000, 0x1f);
+				dm->is_receiver_blocking_en = false;
+			}
+			return;
+		}
+	} else if ((dm->support_ic_type & ODM_RTL8188E && ((bb_regf0 & 0xf000) >> 12) >= 8)) { /*8188E_S version*/
+		if (dm->consecutive_idlel_time > 10 && *dm->mp_mode == false && dm->adaptivity_enable == true) {
+			if ((bw == CHANNEL_WIDTH_20) && (channel == 13)) {
+				phydm_nbi_setting(dm, FUNC_ENABLE, channel, 20, 2473, PHYDM_DONT_CARE);
+				dm->is_receiver_blocking_en = true;
+			} else if (dm->is_receiver_blocking_en && channel != 13) {
+				phydm_nbi_enable(dm, FUNC_DISABLE);
+				odm_set_bb_reg(dm, 0xc40, 0x1f000000, 0x1f);
+				dm->is_receiver_blocking_en = false;
+			}
+			return;
+		}
+	}
+
+	if (dm->is_receiver_blocking_en) {
+		phydm_nbi_enable(dm, FUNC_DISABLE);
+		odm_set_bb_reg(dm, 0xc40, 0x1f000000, 0x1f);
+		dm->is_receiver_blocking_en = false;
+	}
+
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.h
index 0e8b88e24da7..4c229aa518d5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.h
@@ -1,1448 +1,1238 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-
-#ifndef	__HALDMOUTSRC_H__
-#define __HALDMOUTSRC_H__
-
-//============================================================
-// include files
-//============================================================
-#include "phydm_pre_define.h"
-#include "phydm_dig.h"
-#include "phydm_edcaturbocheck.h"
-#include "phydm_pathdiv.h"
-#include "phydm_antdiv.h"
-#include "phydm_antdect.h"
-#include "phydm_dynamicbbpowersaving.h"
-#include "phydm_rainfo.h"
-#include "phydm_dynamictxpower.h"
-#include "phydm_cfotracking.h"
-#include "phydm_acs.h"
-#include "phydm_adaptivity.h"
-
-
-#if (RTL8814A_SUPPORT == 1)
-#include "rtl8814a/phydm_iqk_8814a.h"
-#endif
-
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#include "halphyrf_ap.h"
-#include "phydm_powertracking_ap.h"
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-#include "phydm_beamforming.h"
-#include "phydm_noisemonitor.h"
-#include "halphyrf_ce.h"
-#include "phydm_powertracking_ce.h"
-#endif
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-#include "phydm_beamforming.h"
-#include "phydm_rxhp.h"
-#include "halphyrf_win.h"
-#include "phydm_powertracking_win.h"
-#endif
-
-//============================================================
-// 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
-
-//
-// 2011/09/28 MH Define ODM SW team support flag.
-//
-
-//For SW AntDiv, PathDiv, 8192C AntDiv joint use
-#define	TP_MODE		0
-#define	RSSI_MODE		1
-
-#define	TRAFFIC_LOW	0
-#define	TRAFFIC_HIGH	1
-#define	TRAFFIC_ULTRA_LOW	2
-#define	TRAFFIC_MID	3
-
-
-#define	NONE			0
-
-
-
-
-//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
-#define		DM_DIG_LOW_PWR_THRESHOLD	0x14
-
-
-//============================================================
-// structure and define
-//============================================================
-
-//
-// 2011/09/20 MH Add for AP/ADSLpseudo DM structuer requirement.
-// We need to remove to other position???
-//
-#if(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-typedef		struct rtl8192cd_priv {
-	u1Byte		temp;
-
-}rtl8192cd_priv, *prtl8192cd_priv;
-#endif
-
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-typedef		struct _ADAPTER{
-	u1Byte		temp;
-	#ifdef AP_BUILD_WORKAROUND
-	HAL_DATA_TYPE*		temp2;
-	prtl8192cd_priv		priv;
-	#endif
-}ADAPTER, *PADAPTER;
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-typedef		struct _WLAN_STA{
-	u1Byte		temp;
-} WLAN_STA, *PRT_WLAN_STA;
-
-#endif
-
-typedef struct _Dynamic_Primary_CCA{
-	u1Byte		PriCCA_flag;
-	u1Byte		intf_flag;
-	u1Byte		intf_type;  
-	u1Byte		DupRTS_flag;
-	u1Byte		Monitor_flag;
-	u1Byte		CH_offset;
-	u1Byte  	MF_state;
-}Pri_CCA_T, *pPri_CCA_T;
-
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-
-#ifdef ADSL_AP_BUILD_WORKAROUND
-#define MAX_TOLERANCE			5
-#define IQK_DELAY_TIME			1		//ms
-#endif
-#if 0//defined in 8192cd.h
-//
-// Indicate different AP vendor for IOT issue.
-//
-typedef enum _HT_IOT_PEER
-{
-	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_MAX 				= 16
-}HT_IOT_PEER_E, *PHTIOT_PEER_E;
-#endif
-#endif//#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-
-#define		DM_Type_ByFW			0
-#define		DM_Type_ByDriver		1
-
-//
-// Declare for common info
-//
-
-#define IQK_THRESHOLD			8
-#define DPK_THRESHOLD			4
-
-
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_AP))
-__PACK typedef struct _ODM_Phy_Status_Info_
-{
-	u1Byte		RxPWDBAll;
-	u1Byte		SignalQuality;					/* in 0-100 index. */
-	u1Byte		RxMIMOSignalStrength[4];		/* in 0~100 index */
-	s1Byte		RxMIMOSignalQuality[4];		/* EVM */
-	s1Byte		RxSNR[4];					/* per-path's SNR */
-#if (RTL8822B_SUPPORT == 1)
-	u1Byte		RxCount;						/* RX path counter---*/
-#endif
-	u1Byte		BandWidth;
-
-} __WLAN_ATTRIB_PACK__ ODM_PHY_INFO_T, *PODM_PHY_INFO_T;
-
-typedef struct _ODM_Phy_Status_Info_Append_
-{
-	u1Byte		MAC_CRC32;	
-
-}ODM_PHY_INFO_Append_T,*PODM_PHY_INFO_Append_T;
-
-#else
-
-typedef struct _ODM_Phy_Status_Info_
-{
-	//
-	// Be care, if you want to add any element please insert between 
-	// RxPWDBAll & SignalStrength.
-	//
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN))
-	u4Byte		RxPWDBAll;	
-#else
-	u1Byte		RxPWDBAll;	
-#endif
-	u1Byte		SignalQuality;				/* in 0-100 index. */
-	s1Byte		RxMIMOSignalQuality[4];		/* per-path's EVM */
-	u1Byte		RxMIMOEVMdbm[4];			/* per-path's EVM dbm */
-	u1Byte		RxMIMOSignalStrength[4];	/* in 0~100 index */
-	s2Byte		Cfo_short[4];				/* per-path's Cfo_short */
-	s2Byte		Cfo_tail[4];					/* per-path's Cfo_tail */
-	s1Byte		RxPower;					/* in dBm Translate from PWdB */
-	s1Byte		RecvSignalPower;			/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. */
-	u1Byte		BTRxRSSIPercentage;
-	u1Byte		SignalStrength;				/* in 0-100 index. */
-	s1Byte		RxPwr[4];					/* per-path's pwdb */
-	s1Byte		RxSNR[4];					/* per-path's SNR	*/
-#if (RTL8822B_SUPPORT == 1)
-	u1Byte		RxCount:2;					/* RX path counter---*/
-	u1Byte		BandWidth:2;
-	u1Byte		rxsc:4;						/* sub-channel---*/
-#else
-	u1Byte		BandWidth;
-#endif
-	u1Byte		btCoexPwrAdjust;
-#if (RTL8822B_SUPPORT == 1)
-	u1Byte		channel;						/* channel number---*/
-	BOOLEAN		bMuPacket;					/* is MU packet or not---*/
-	BOOLEAN		bBeamformed;				/* BF packet---*/
-#endif
-}ODM_PHY_INFO_T,*PODM_PHY_INFO_T;
-#endif
-
-typedef struct _ODM_Per_Pkt_Info_
-{
-	//u1Byte		Rate;	
-	u1Byte		DataRate;
-	u1Byte		StationID;
-	BOOLEAN		bPacketMatchBSSID;
-	BOOLEAN		bPacketToSelf;
-	BOOLEAN		bPacketBeacon;
-	BOOLEAN		bToSelf;
-}ODM_PACKET_INFO_T,*PODM_PACKET_INFO_T;
-
-
-typedef struct _ODM_Phy_Dbg_Info_
-{
-	//ODM Write,debug info
-	s1Byte		RxSNRdB[4];
-	u4Byte		NumQryPhyStatus;
-	u4Byte		NumQryPhyStatusCCK;
-	u4Byte		NumQryPhyStatusOFDM;
-#if (RTL8822B_SUPPORT == 1)
-	u4Byte		NumQryMuPkt;
-	u4Byte		NumQryBfPkt;
-#endif
-	u1Byte		NumQryBeaconPkt;
-	//Others
-	s4Byte		RxEVM[4];	
-	
-}ODM_PHY_DBG_INFO_T;
-
-
-typedef struct _ODM_Mac_Status_Info_
-{
-	u1Byte	test;
-	
-}ODM_MAC_INFO;
-
-//
-// 2011/20/20 MH For MP driver RT_WLAN_STA =  STA_INFO_T
-// Please declare below ODM relative info in your STA info structure.
-//
-#if 1
-typedef		struct _ODM_STA_INFO{
-	// Driver Write
-	BOOLEAN		bUsed;				// record the sta status link or not?
-	//u1Byte		WirelessMode;		// 
-	u1Byte		IOTPeer;			// Enum value.	HT_IOT_PEER_E
-
-	// ODM Write
-	//1 PHY_STATUS_INFO
-	u1Byte		RSSI_Path[4];		// 
-	u1Byte		RSSI_Ave;
-	u1Byte		RXEVM[4];
-	u1Byte		RXSNR[4];
-
-	// ODM Write
-	//1 TX_INFO (may changed by IC)
-	//TX_INFO_T		pTxInfo;				// Define in IC folder. Move lower layer.
-#if 0
-	u1Byte		ANTSEL_A;			//in Jagar: 4bit; others: 2bit
-	u1Byte		ANTSEL_B;			//in Jagar: 4bit; others: 2bit
-	u1Byte		ANTSEL_C;			//only in Jagar: 4bit
-	u1Byte		ANTSEL_D;			//only in Jagar: 4bit
-	u1Byte		TX_ANTL;			//not in Jagar: 2bit
-	u1Byte		TX_ANT_HT;			//not in Jagar: 2bit
-	u1Byte		TX_ANT_CCK;			//not in Jagar: 2bit
-	u1Byte		TXAGC_A;			//not in Jagar: 4bit
-	u1Byte		TXAGC_B;			//not in Jagar: 4bit
-	u1Byte		TXPWR_OFFSET;		//only in Jagar: 3bit
-	u1Byte		TX_ANT;				//only in Jagar: 4bit for TX_ANTL/TX_ANTHT/TX_ANT_CCK
-#endif
-
-	//
-	// 	Please use compile flag to disabe the strcutrue for other IC except 88E.
-	//	Move To lower layer.
-	//
-	// ODM Write Wilson will handle this part(said by Luke.Lee)
-	//TX_RPT_T		pTxRpt;				// Define in IC folder. Move lower layer.
-#if 0	
-	//1 For 88E RA (don't redefine the naming)
-	u1Byte		rate_id;
-	u1Byte		rate_SGI;
-	u1Byte		rssi_sta_ra;
-	u1Byte		SGI_enable;
-	u1Byte		Decision_rate;
-	u1Byte		Pre_rate;
-	u1Byte		Active;
-
-	// Driver write Wilson handle.
-	//1 TX_RPT (don't redefine the naming)
-	u2Byte		RTY[4];				// ???
-	u2Byte		TOTAL;				// ???
-	u2Byte		DROP;				// ???
-	//
-	// Please use compile flag to disabe the strcutrue for other IC except 88E.
-	//
-#endif
-
-}ODM_STA_INFO_T, *PODM_STA_INFO_T;
-#endif
-
-//
-// 2011/10/20 MH Define Common info enum for all team.
-//
-typedef enum _ODM_Common_Info_Definition
-{
-//-------------REMOVED CASE-----------//
-	//ODM_CMNINFO_CCK_HP,
-	//ODM_CMNINFO_RFPATH_ENABLE,		// Define as ODM write???	
-	//ODM_CMNINFO_BT_COEXIST,				// ODM_BT_COEXIST_E
-	//ODM_CMNINFO_OP_MODE,				// ODM_OPERATION_MODE_E
-//-------------REMOVED CASE-----------//
-
-	//
-	// Fixed value:
-	//
-
-	//-----------HOOK BEFORE REG INIT-----------//
-	ODM_CMNINFO_PLATFORM = 0,
-	ODM_CMNINFO_ABILITY,					// ODM_ABILITY_E
-	ODM_CMNINFO_INTERFACE,				// ODM_INTERFACE_E
-	ODM_CMNINFO_MP_TEST_CHIP,
-	ODM_CMNINFO_IC_TYPE,					// ODM_IC_TYPE_E
-	ODM_CMNINFO_CUT_VER,					// ODM_CUT_VERSION_E
-	ODM_CMNINFO_FAB_VER,					// ODM_FAB_E
-	ODM_CMNINFO_RF_TYPE,					// ODM_RF_PATH_E or ODM_RF_TYPE_E?
-	ODM_CMNINFO_RFE_TYPE, 
-	ODM_CMNINFO_BOARD_TYPE,				// ODM_BOARD_TYPE_E
-	ODM_CMNINFO_PACKAGE_TYPE,
-	ODM_CMNINFO_EXT_LNA,					// TRUE
-	ODM_CMNINFO_5G_EXT_LNA,	
-	ODM_CMNINFO_EXT_PA,
-	ODM_CMNINFO_5G_EXT_PA,
-	ODM_CMNINFO_GPA,
-	ODM_CMNINFO_APA,
-	ODM_CMNINFO_GLNA,
-	ODM_CMNINFO_ALNA,
-	ODM_CMNINFO_EXT_TRSW,
-	ODM_CMNINFO_EXT_LNA_GAIN,
-	ODM_CMNINFO_PATCH_ID,				//CUSTOMER ID
-	ODM_CMNINFO_BINHCT_TEST,
-	ODM_CMNINFO_BWIFI_TEST,
-	ODM_CMNINFO_SMART_CONCURRENT,
-	ODM_CMNINFO_CONFIG_BB_RF,
-	ODM_CMNINFO_DOMAIN_CODE_2G,
-	ODM_CMNINFO_DOMAIN_CODE_5G,
-	ODM_CMNINFO_IQKFWOFFLOAD,
-	ODM_CMNINFO_HUBUSBMODE,
-	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS,
-	ODM_CMNINFO_TX_TP,
-	ODM_CMNINFO_RX_TP,
-	ODM_CMNINFO_SOUNDING_SEQ,
-	//-----------HOOK BEFORE REG INIT-----------//	
-
-
-	//
-	// Dynamic value:
-	//
-//--------- POINTER REFERENCE-----------//
-	ODM_CMNINFO_MAC_PHY_MODE,			// ODM_MAC_PHY_MODE_E
-	ODM_CMNINFO_TX_UNI,
-	ODM_CMNINFO_RX_UNI,
-	ODM_CMNINFO_WM_MODE,				// ODM_WIRELESS_MODE_E
-	ODM_CMNINFO_BAND,					// ODM_BAND_TYPE_E
-	ODM_CMNINFO_SEC_CHNL_OFFSET,		// ODM_SEC_CHNL_OFFSET_E
-	ODM_CMNINFO_SEC_MODE,				// ODM_SECURITY_E
-	ODM_CMNINFO_BW,						// ODM_BW_E
-	ODM_CMNINFO_CHNL,
-	ODM_CMNINFO_FORCED_RATE,
-	
-	ODM_CMNINFO_DMSP_GET_VALUE,
-	ODM_CMNINFO_BUDDY_ADAPTOR,
-	ODM_CMNINFO_DMSP_IS_MASTER,
-	ODM_CMNINFO_SCAN,
-	ODM_CMNINFO_POWER_SAVING,
-	ODM_CMNINFO_ONE_PATH_CCA,			// ODM_CCA_PATH_E
-	ODM_CMNINFO_DRV_STOP,
-	ODM_CMNINFO_PNP_IN,
-	ODM_CMNINFO_INIT_ON,
-	ODM_CMNINFO_ANT_TEST,
-	ODM_CMNINFO_NET_CLOSED,
-	//ODM_CMNINFO_RTSTA_AID,				// For win driver only?
-	ODM_CMNINFO_FORCED_IGI_LB,
-	ODM_CMNINFO_P2P_LINK,
-	ODM_CMNINFO_FCS_MODE,
-	ODM_CMNINFO_IS1ANTENNA,
-	ODM_CMNINFO_RFDEFAULTPATH,
-//--------- POINTER REFERENCE-----------//
-
-//------------CALL BY VALUE-------------//
-	ODM_CMNINFO_WIFI_DIRECT,
-	ODM_CMNINFO_WIFI_DISPLAY,
-	ODM_CMNINFO_LINK_IN_PROGRESS,			
-	ODM_CMNINFO_LINK,
-	ODM_CMNINFO_STATION_STATE,
-	ODM_CMNINFO_RSSI_MIN,
-	ODM_CMNINFO_DBG_COMP,				// u8Byte
-	ODM_CMNINFO_DBG_LEVEL,				// u4Byte
-	ODM_CMNINFO_RA_THRESHOLD_HIGH,		// u1Byte
-	ODM_CMNINFO_RA_THRESHOLD_LOW,		// u1Byte
-	ODM_CMNINFO_RF_ANTENNA_TYPE,		// u1Byte
-	ODM_CMNINFO_BT_ENABLED,
-	ODM_CMNINFO_BT_HS_CONNECT_PROCESS,
-	ODM_CMNINFO_BT_HS_RSSI,
-	ODM_CMNINFO_BT_OPERATION,
-	ODM_CMNINFO_BT_LIMITED_DIG,					//Need to Limited Dig or not
-	ODM_CMNINFO_BT_DIG,
-	ODM_CMNINFO_BT_BUSY,					//Check Bt is using or not//neil	
-	ODM_CMNINFO_BT_DISABLE_EDCA,
-#if(DM_ODM_SUPPORT_TYPE & ODM_AP)		// for repeater mode add by YuChen 2014.06.23
-#ifdef UNIVERSAL_REPEATER
-	ODM_CMNINFO_VXD_LINK,
-#endif
-#endif
-	ODM_CMNINFO_AP_TOTAL_NUM,
-	ODM_CMNINFO_POWER_TRAINING,
-//------------CALL BY VALUE-------------//
-
-	//
-	// Dynamic ptr array hook itms.
-	//
-	ODM_CMNINFO_STA_STATUS,
-	ODM_CMNINFO_PHY_STATUS,
-	ODM_CMNINFO_MAC_STATUS,
-	
-	ODM_CMNINFO_MAX,
-
-
-}ODM_CMNINFO_E;
-
-//
-// 2011/10/20 MH Define ODM support ability.  ODM_CMNINFO_ABILITY
-//
-typedef enum _ODM_Support_Ability_Definition
-{
-	//
-	// BB ODM section BIT 0-19
-	//
-	ODM_BB_DIG					= BIT0,
-	ODM_BB_RA_MASK				= BIT1,
-	ODM_BB_DYNAMIC_TXPWR		= BIT2,
-	ODM_BB_FA_CNT					= BIT3,
-	ODM_BB_RSSI_MONITOR			= BIT4,
-	ODM_BB_CCK_PD				= BIT5,
-	ODM_BB_ANT_DIV				= BIT6,
-	ODM_BB_PWR_SAVE				= BIT7,
-	ODM_BB_PWR_TRAIN				= BIT8,
-	ODM_BB_RATE_ADAPTIVE			= BIT9,
-	ODM_BB_PATH_DIV				= BIT10,
-	ODM_BB_PSD					= BIT11,
-	ODM_BB_RXHP					= BIT12,
-	ODM_BB_ADAPTIVITY				= BIT13,
-	ODM_BB_CFO_TRACKING			= BIT14,
-	ODM_BB_NHM_CNT				= BIT15,
-	ODM_BB_PRIMARY_CCA			= BIT16,
-	ODM_BB_TXBF				= BIT17,
-	
-	//
-	// MAC DM section BIT 20-23
-	//
-	ODM_MAC_EDCA_TURBO			= BIT20,
-	ODM_MAC_EARLY_MODE			= BIT21,
-	
-	//
-	// RF ODM section BIT 24-31
-	//
-	ODM_RF_TX_PWR_TRACK			= BIT24,
-	ODM_RF_RX_GAIN_TRACK			= BIT25,
-	ODM_RF_CALIBRATION			= BIT26,
-	
-}ODM_ABILITY_E;
-
-//Move some non-DM enum,define, struc. form phydm.h to phydm_types.h by Dino
-
-// ODM_CMNINFO_ONE_PATH_CCA
-typedef enum tag_CCA_Path
-{
-	ODM_CCA_2R			= 0,
-	ODM_CCA_1R_A		= 1,
-	ODM_CCA_1R_B		= 2,
-}ODM_CCA_PATH_E;
-
-//move RAInfo to Phydm_RaInfo.h
-
-//Remove struct  PATHDIV_PARA to odm_PathDiv.h 
-
-//Remove struct to odm_PowerTracking.h by YuChen
-//
-// ODM Dynamic common info value definition
-//
-//Move AntDiv form phydm.h to Phydm_AntDiv.h by Dino
-
-//move PathDiv to Phydm_PathDiv.h
-
-typedef enum _BASEBAND_CONFIG_PHY_REG_PG_VALUE_TYPE{
-	PHY_REG_PG_RELATIVE_VALUE = 0,
-	PHY_REG_PG_EXACT_VALUE = 1
-} PHY_REG_PG_TYPE;
-
-//
-// 2011/09/22 MH Copy from SD4 defined structure. We use to support PHY DM integration.
-//
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-#if (RT_PLATFORM != PLATFORM_LINUX)
-typedef 
-#endif
-	
-struct DM_Out_Source_Dynamic_Mechanism_Structure
-#else// for AP,ADSL,CE Team
-typedef  struct DM_Out_Source_Dynamic_Mechanism_Structure
-#endif
-{
-	//RT_TIMER 	FastAntTrainingTimer;
-	//
-	//	Add for different team use temporarily
-	//
-	PADAPTER		Adapter;		// For CE/NIC team
-	prtl8192cd_priv	priv;			// For AP/ADSL team
-	// WHen you use Adapter or priv pointer, you must make sure the pointer is ready.
-	BOOLEAN			odm_ready;
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-	rtl8192cd_priv		fake_priv;
-#endif
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	// ADSL_AP_BUILD_WORKAROUND
-	ADAPTER			fake_adapter;
-#endif
-	
-	PHY_REG_PG_TYPE		PhyRegPgValueType;
-	u1Byte				PhyRegPgVersion;
-
-	u8Byte			DebugComponents;
-	u4Byte			DebugLevel;
-	
-	u4Byte			NumQryPhyStatusAll; 	//CCK + OFDM
-	u4Byte			LastNumQryPhyStatusAll; 
-	u4Byte			RxPWDBAve;
-	BOOLEAN			MPDIG_2G; 		//off MPDIG
-	u1Byte			Times_2G;
-	
-//------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------//
-	BOOLEAN			bCckHighPower; 
-	u1Byte			RFPathRxEnable;		// ODM_CMNINFO_RFPATH_ENABLE
-	u1Byte			ControlChannel;
-//------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------//
-
-//--------REMOVED COMMON INFO----------//
-	//u1Byte				PseudoMacPhyMode;
-	//BOOLEAN			*BTCoexist;
-	//BOOLEAN			PseudoBtCoexist;
-	//u1Byte				OPMode;
-	//BOOLEAN			bAPMode;
-	//BOOLEAN			bClientMode;
-	//BOOLEAN			bAdHocMode;
-	//BOOLEAN			bSlaveOfDMSP;
-//--------REMOVED COMMON INFO----------//
-
-
-//1  COMMON INFORMATION
-
-	//
-	// Init Value
-	//
-//-----------HOOK BEFORE REG INIT-----------//	
-	// ODM Platform info AP/ADSL/CE/MP = 1/2/3/4
-	u1Byte			SupportPlatform;		
-	// ODM Support Ability DIG/RATR/TX_PWR_TRACK/ …… = 1/2/3/…
-	u4Byte			SupportAbility;
-	// ODM PCIE/USB/SDIO = 1/2/3
-	u1Byte			SupportInterface;			
-	// ODM composite or independent. Bit oriented/ 92C+92D+ .... or any other type = 1/2/3/...
-	u4Byte			SupportICType;	
-	// Cut Version TestChip/A-cut/B-cut... = 0/1/2/3/...
-	u1Byte			CutVersion;
-	// Fab Version TSMC/UMC = 0/1
-	u1Byte			FabVersion;
-	// RF Type 4T4R/3T3R/2T2R/1T2R/1T1R/...
-	u1Byte			RFType;
-	u1Byte			RFEType;	
-	// Board Type Normal/HighPower/MiniCard/SLIM/Combo/... = 0/1/2/3/4/...
-	u1Byte			BoardType;
-	u1Byte			PackageType;
-	u2Byte			TypeGLNA;
-	u2Byte			TypeGPA;
-	u2Byte			TypeALNA;
-	u2Byte			TypeAPA;
-	// with external LNA  NO/Yes = 0/1
-	u1Byte			ExtLNA; // 2G
-	u1Byte			ExtLNA5G; //5G
-	// with external PA  NO/Yes = 0/1
-	u1Byte			ExtPA; // 2G
-	u1Byte			ExtPA5G; //5G
-	// with external TRSW  NO/Yes = 0/1
-	u1Byte			ExtTRSW;
-	u1Byte			ExtLNAGain; // 2G
-	u1Byte			PatchID; //Customer ID
-	BOOLEAN			bInHctTest;
-	BOOLEAN			bWIFITest;
-
-	BOOLEAN			bDualMacSmartConcurrent;
-	u4Byte			BK_SupportAbility;
-	u1Byte			AntDivType;
-	BOOLEAN			ConfigBBRF;
-	u1Byte			odm_Regulation2_4G;
-	u1Byte			odm_Regulation5G;
-	u1Byte			IQKFWOffload;
-//-----------HOOK BEFORE REG INIT-----------//	
-
-	//
-	// Dynamic Value
-	//	
-//--------- POINTER REFERENCE-----------//
-
-	u1Byte			u1Byte_temp;
-	BOOLEAN			BOOLEAN_temp;
-	PADAPTER		PADAPTER_temp;
-	
-	// MAC PHY Mode SMSP/DMSP/DMDP = 0/1/2
-	u1Byte			*pMacPhyMode;
-	//TX Unicast byte count
-	u8Byte			*pNumTxBytesUnicast;
-	//RX Unicast byte count
-	u8Byte			*pNumRxBytesUnicast;
-	// Wireless mode B/G/A/N = BIT0/BIT1/BIT2/BIT3
-	u1Byte			*pWirelessMode; //ODM_WIRELESS_MODE_E
-	// Frequence band 2.4G/5G = 0/1
-	u1Byte			*pBandType;
-	// Secondary channel offset don't_care/below/above = 0/1/2
-	u1Byte			*pSecChOffset;
-	// Security mode Open/WEP/AES/TKIP = 0/1/2/3
-	u1Byte			*pSecurity;
-	// BW info 20M/40M/80M = 0/1/2
-	u1Byte			*pBandWidth;
- 	// Central channel location Ch1/Ch2/....
-	u1Byte			*pChannel;	//central channel number
-	BOOLEAN			DPK_Done;
-	// Common info for 92D DMSP
-	
-	BOOLEAN			*pbGetValueFromOtherMac;
-	PADAPTER		*pBuddyAdapter;
-	BOOLEAN			*pbMasterOfDMSP; //MAC0: master, MAC1: slave
-	// Common info for Status
-	BOOLEAN			*pbScanInProcess;
-	BOOLEAN			*pbPowerSaving;
-	// CCA Path 2-path/path-A/path-B = 0/1/2; using ODM_CCA_PATH_E.
-	u1Byte			*pOnePathCCA;
-	//pMgntInfo->AntennaTest
-	u1Byte			*pAntennaTest;
-	BOOLEAN			*pbNet_closed;
-	//u1Byte			*pAidMap;
-	u1Byte			*pu1ForcedIgiLb;
-	BOOLEAN			*pIsFcsModeEnable;
-/*--------- For 8723B IQK-----------*/
-	BOOLEAN			*pIs1Antenna;
-	u1Byte			*pRFDefaultPath;
-	// 0:S1, 1:S0
-	
-//--------- POINTER REFERENCE-----------//
-	pu2Byte			pForcedDataRate;
-	pu1Byte			HubUsbMode;
-	BOOLEAN			*pbFwDwRsvdPageInProgress;
-	u4Byte			*pCurrentTxTP;
-	u4Byte			*pCurrentRxTP;
-	u1Byte			*pSoundingSeq;
-//------------CALL BY VALUE-------------//
-	BOOLEAN			bLinkInProcess;
-	BOOLEAN			bWIFI_Direct;
-	BOOLEAN			bWIFI_Display;
-	BOOLEAN			bLinked;
-	BOOLEAN			bsta_state;
-#if(DM_ODM_SUPPORT_TYPE & ODM_AP)		// for repeater mode add by YuChen 2014.06.23
-#ifdef UNIVERSAL_REPEATER
-	BOOLEAN			VXD_bLinked;
-#endif
-#endif									// for repeater mode add by YuChen 2014.06.23	
-	u1Byte			RSSI_Min;	
-	u1Byte			InterfaceIndex; /*Add for 92D  dual MAC: 0--Mac0 1--Mac1*/
-	BOOLEAN			bIsMPChip;
-	BOOLEAN			bOneEntryOnly;
-	BOOLEAN			mp_mode;
-	u4Byte			OneEntry_MACID;
-	u1Byte			pre_number_linked_client;	
-	u1Byte			number_linked_client;
-	u1Byte			pre_number_active_client;	
-	u1Byte			number_active_client;
-	// Common info for BTDM
-	BOOLEAN			bBtEnabled;			// BT is enabled
-	BOOLEAN			bBtConnectProcess;	// BT HS is under connection progress.
-	u1Byte			btHsRssi;				// BT HS mode wifi rssi value.
-	BOOLEAN			bBtHsOperation;		// BT HS mode is under progress
-	u1Byte			btHsDigVal;			// use BT rssi to decide the DIG value
-	BOOLEAN			bBtDisableEdcaTurbo;	// Under some condition, don't enable the EDCA Turbo
-	BOOLEAN			bBtBusy;   			// BT is busy.
-	BOOLEAN			bBtLimitedDig;   		// BT is busy.
-	BOOLEAN			bDisablePhyApi;
-//------------CALL BY VALUE-------------//
-	u1Byte			RSSI_A;
-	u1Byte			RSSI_B;
-	u1Byte			RSSI_C;
-	u1Byte			RSSI_D;
-	u8Byte			RSSI_TRSW;	
-	u8Byte			RSSI_TRSW_H;
-	u8Byte			RSSI_TRSW_L;	
-	u8Byte			RSSI_TRSW_iso;
-	u1Byte			TXAntStatus;
-	u1Byte			RXAntStatus;
-	u1Byte			cck_lna_idx;
-	u1Byte			cck_vga_idx;
-	u1Byte			ofdm_agc_idx[4];
-
-	u1Byte			RxRate;
-	BOOLEAN			bNoisyState;
-	u1Byte			TxRate;
-	u1Byte			LinkedInterval;
-	u1Byte			preChannel;
-	u4Byte			TxagcOffsetValueA;
-	BOOLEAN			IsTxagcOffsetPositiveA;
-	u4Byte			TxagcOffsetValueB;
-	BOOLEAN			IsTxagcOffsetPositiveB;
-	u4Byte			tx_tp;
-	u4Byte			rx_tp;
-	u4Byte			total_tp;
-	u8Byte			curTxOkCnt;
-	u8Byte			curRxOkCnt;	
-	u8Byte			lastTxOkCnt;
-	u8Byte			lastRxOkCnt;
-	u4Byte			BbSwingOffsetA;
-	BOOLEAN			IsBbSwingOffsetPositiveA;
-	u4Byte			BbSwingOffsetB;
-	BOOLEAN			IsBbSwingOffsetPositiveB;
-	u1Byte			antdiv_rssi;
-	u1Byte			fat_comb_a;
-	u1Byte			fat_comb_b;
-	u1Byte			antdiv_intvl;
-	u1Byte			AntType;
-	u1Byte			pre_AntType;
-	u1Byte			antdiv_period;
-	u1Byte			antdiv_select;
-	u1Byte			path_select;	
-	u1Byte			antdiv_evm_en;
-	u1Byte			bdc_holdstate;
-	u1Byte			NdpaPeriod;
-	BOOLEAN			H2C_RARpt_connect;
-	BOOLEAN			cck_agc_report_type;
-	
-	u1Byte			dm_dig_max_TH;
-	u1Byte 			dm_dig_min_TH;
-	u1Byte 			print_agc;
-	u1Byte			TrafficLoad;
-	u1Byte			pre_TrafficLoad;
-
-
-	//For Adaptivtiy
-	u2Byte			NHM_cnt_0;
-	u2Byte			NHM_cnt_1;
-	s1Byte			TH_L2H_default;
-	s1Byte			TH_EDCCA_HL_diff_default;
-	s1Byte			TH_L2H_ini;
-	s1Byte			TH_EDCCA_HL_diff;
-	s1Byte			TH_L2H_ini_mode2;
-	s1Byte			TH_EDCCA_HL_diff_mode2;
-	BOOLEAN			Carrier_Sense_enable;
-	u1Byte			Adaptivity_IGI_upper;
-	BOOLEAN			adaptivity_flag;
-	u1Byte			DCbackoff;
-	BOOLEAN			Adaptivity_enable;
-	u1Byte			APTotalNum;
-	BOOLEAN			EDCCA_enable;
-	ADAPTIVITY_STATISTICS	Adaptivity;
-	//For Adaptivtiy
-	u1Byte			LastUSBHub;
-	u1Byte			TxBfDataRate;
-	
-	u1Byte			c2h_cmd_start;
-	u1Byte			fw_debug_trace[60]; 
-	u1Byte			pre_c2h_seq;
-	BOOLEAN			fw_buff_is_enpty;
-	u4Byte			data_frame_num;
-
-	/*for noise detection*/
-	BOOLEAN			NoisyDecision; /*b_noisy*/
-	BOOLEAN			pre_b_noisy;	
-	u4Byte			NoisyDecision_Smooth;
-
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_CE))
-	ODM_NOISE_MONITOR noise_level;//[ODM_MAX_CHANNEL_NUM];
-#endif
-	//
-	//2 Define STA info.
-	// _ODM_STA_INFO
-	// 2012/01/12 MH For MP, we need to reduce one array pointer for default port.??
-	PSTA_INFO_T		pODM_StaInfo[ODM_ASSOCIATE_ENTRY_NUM];
-	u2Byte			platform2phydm_macid_table[ODM_ASSOCIATE_ENTRY_NUM];		/* platform_macid_table[platform_macid] = phydm_macid */
-
-#if (RATE_ADAPTIVE_SUPPORT == 1)
-	u2Byte 			CurrminRptTime;
-	ODM_RA_INFO_T   RAInfo[ODM_ASSOCIATE_ENTRY_NUM]; //Use MacID as array index. STA MacID=0, VWiFi Client MacID={1, ODM_ASSOCIATE_ENTRY_NUM-1} //YJ,add,120119
-#endif
-	//
-	// 2012/02/14 MH Add to share 88E ra with other SW team.
-	// We need to colelct all support abilit to a proper area.
-	//
-	BOOLEAN				RaSupport88E;
-
-	// Define ...........
-
-	// Latest packet phy info (ODM write)
-	ODM_PHY_DBG_INFO_T	 PhyDbgInfo;
-	//PHY_INFO_88E		PhyInfo;
-
-	// Latest packet phy info (ODM write)
-	ODM_MAC_INFO		*pMacInfo;
-	//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
-	//
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	BDC_T					DM_BdcTable;
-	#endif
-	
-	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-	SAT_T						dm_sat_table;
-	#endif
-	
-#endif
-	FAT_T						DM_FatTable;
-	DIG_T						DM_DigTable;
-
-	PS_T						DM_PSTable;
-	Pri_CCA_T					DM_PriCCA;
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	RXHP_T						DM_RXHP_Table;
-#endif
-	RA_T						DM_RA_Table;  
-	FALSE_ALARM_STATISTICS		FalseAlmCnt;
-	FALSE_ALARM_STATISTICS		FlaseAlmCntBuddyAdapter;
-	SWAT_T						DM_SWAT_Table;
-	CFO_TRACKING    				DM_CfoTrack;
-	ACS							DM_ACS;
-
-
-#if (RTL8814A_SUPPORT == 1)
-	IQK_INFO	IQK_info;
-#endif /* (RTL8814A_SUPPORT==1) */
-
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	//Path Div Struct
-	PATHDIV_PARA	pathIQK;
-#endif
-#if(defined(CONFIG_PATH_DIVERSITY))
-	PATHDIV_T	DM_PathDiv;
-#endif	
-
-	EDCA_T		DM_EDCA_Table;
-	u4Byte		WMMEDCA_BE;
-
-	// Copy from SD4 structure
-	//
-	// ==================================================
-	//
-
-	//common
-	//u1Byte		DM_Type;	
-	//u1Byte    PSD_Report_RXHP[80];   // Add By Gary
-	//u1Byte    PSD_func_flag;               // Add By Gary
-	//for DIG
-	//u1Byte		bDMInitialGainEnable;
-	//u1Byte		binitialized; // for dm_initial_gain_Multi_STA use.
-
-	BOOLEAN			*pbDriverStopped;
-	BOOLEAN			*pbDriverIsGoingToPnpSetPowerSleep;
-	BOOLEAN			*pinit_adpt_in_progress;
-
-	//PSD
-	BOOLEAN			bUserAssignLevel;
-	RT_TIMER 		PSDTimer;
-	u1Byte			RSSI_BT;			//come from BT
-	BOOLEAN			bPSDinProcess;
-	BOOLEAN			bPSDactive;
-	BOOLEAN			bDMInitialGainEnable;
-
-	//MPT DIG
-	RT_TIMER 		MPT_DIGTimer;
-	
-	//for rate adaptive, in fact,  88c/92c fw will handle this
-	u1Byte			bUseRAMask;
-
-	ODM_RATE_ADAPTIVE	RateAdaptive;
-//#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if(defined(CONFIG_ANT_DETECTION))
-	ANT_DETECTED_INFO	AntDetectedInfo; // Antenna detected information for RSSI tool
-#endif
-	ODM_RF_CAL_T	RFCalibrateInfo;
-
-	
-	//
-	// Dynamic ATC switch
-	//
-
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))	
-	//
-	// Power Training
-	//
-	u1Byte			ForcePowerTrainingState;
-	BOOLEAN			bChangeState;
-	u4Byte			PT_score;
-	u8Byte			OFDM_RX_Cnt;
-	u8Byte			CCK_RX_Cnt;
-#endif
-	BOOLEAN			bDisablePowerTraining;
-
-	//
-	// ODM system resource.
-	//
-
-	// ODM relative time.
-	RT_TIMER 				PathDivSwitchTimer;
-	//2011.09.27 add for Path Diversity
-	RT_TIMER				CCKPathDiversityTimer;
-	RT_TIMER 	FastAntTrainingTimer;
-#ifdef ODM_EVM_ENHANCE_ANTDIV
-	RT_TIMER 			EVM_FastAntTrainingTimer;
-#endif
-	RT_TIMER		sbdcnt_timer;
-
-	// ODM relative workitem.
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#if USE_WORKITEM
-	RT_WORK_ITEM			PathDivSwitchWorkitem;
-	RT_WORK_ITEM			CCKPathDiversityWorkitem;
-	RT_WORK_ITEM			FastAntTrainingWorkitem;
-	RT_WORK_ITEM			MPT_DIGWorkitem;
-	RT_WORK_ITEM			RaRptWorkitem;
-	RT_WORK_ITEM			sbdcnt_workitem;
-#endif
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	RT_BEAMFORMING_INFO BeamformingInfo;
-#endif 
-#endif
-
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	
-#if (RT_PLATFORM != PLATFORM_LINUX)
-} DM_ODM_T, *PDM_ODM_T;		// DM_Dynamic_Mechanism_Structure
-#else
-};
-#endif	
-
-#else// for AP,ADSL,CE Team
-} DM_ODM_T, *PDM_ODM_T;		// DM_Dynamic_Mechanism_Structure
-#endif
-
-
-typedef enum _PHYDM_STRUCTURE_TYPE{
-	PHYDM_FALSEALMCNT,
-	PHYDM_CFOTRACK,
-	PHYDM_ADAPTIVITY,
-	PHYDM_ROMINFO,
-	
-}PHYDM_STRUCTURE_TYPE;
-
-
-
- typedef enum _ODM_RF_CONTENT{
-	odm_radioa_txt = 0x1000,
-	odm_radiob_txt = 0x1001,
-	odm_radioc_txt = 0x1002,
-	odm_radiod_txt = 0x1003
-} ODM_RF_CONTENT;
-
-typedef enum _ODM_BB_Config_Type{
-	CONFIG_BB_PHY_REG,   
-	CONFIG_BB_AGC_TAB,   
-	CONFIG_BB_AGC_TAB_2G,
-	CONFIG_BB_AGC_TAB_5G, 
-	CONFIG_BB_PHY_REG_PG,
-	CONFIG_BB_PHY_REG_MP,
-	CONFIG_BB_AGC_TAB_DIFF,
-} ODM_BB_Config_Type, *PODM_BB_Config_Type;
-
-typedef enum _ODM_RF_Config_Type{ 
-	CONFIG_RF_RADIO,
-    CONFIG_RF_TXPWR_LMT,
-} ODM_RF_Config_Type, *PODM_RF_Config_Type;
-
-typedef enum _ODM_FW_Config_Type{
-    CONFIG_FW_NIC,
-    CONFIG_FW_NIC_2,
-    CONFIG_FW_AP,
-    CONFIG_FW_AP_2,
-    CONFIG_FW_MP,
-    CONFIG_FW_WoWLAN,
-    CONFIG_FW_WoWLAN_2,
-    CONFIG_FW_AP_WoWLAN,
-    CONFIG_FW_BT,
-} ODM_FW_Config_Type;
-
-// Status code
-#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
-typedef 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,
-}RT_STATUS,*PRT_STATUS;
-#endif // end of RT_STATUS definition
-
-#ifdef REMOVE_PACK
-#pragma pack()
-#endif
-
-//#include "odm_function.h"
-
-//3===========================================================
-//3 DIG
-//3===========================================================
-
-//Remove DIG by Yuchen
-
-//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
-
-//Remove By YuChen
-
-//3===========================================================
-//3 Tx Power Tracking
-//3===========================================================
-
-
-
-//3===========================================================
-//3 Rate Adaptive
-//3===========================================================
-//Remove to odm_RaInfo.h by RS_James
-
-//3===========================================================
-//3 BB Power Save
-//3===========================================================
-
-typedef enum tag_1R_CCA_Type_Definition
-{
-	CCA_1R =0,
-	CCA_2R = 1,
-	CCA_MAX = 2,
-}DM_1R_CCA_E;
-
-typedef enum tag_RF_Type_Definition
-{
-	RF_Save =0,
-	RF_Normal = 1,
-	RF_MAX = 2,
-}DM_RF_E;
-
-
-//
-// Extern Global Variables.
-//
-//PowerTracking move to odm_powerTrakcing.h by YuChen
-//
-// check Sta pointer valid or not
-//
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-#define IS_STA_VALID(pSta)		(pSta && pSta->expire_to)
-#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-#define IS_STA_VALID(pSta)		(pSta && pSta->bUsed)
-#else
-#define IS_STA_VALID(pSta)		(pSta)
-#endif
-
-//Remove DIG by yuchen
-
-//Remove BB power saving by Yuchen
-
-//remove PT by yuchen
-
-//ODM_RAStateCheck() Remove by RS_James
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_AP|ODM_ADSL))
-//============================================================
-// function prototype
-//============================================================
-//#define DM_ChangeDynamicInitGainThresh		ODM_ChangeDynamicInitGainThresh
-//void	ODM_ChangeDynamicInitGainThresh(IN	PADAPTER	pAdapter,
-//											IN	INT32		DM_Type,
-//											IN	INT32		DM_Value);
-
-//Remove DIG by yuchen
-
-
-BOOLEAN
-ODM_CheckPowerStatus(
-	IN	PADAPTER		Adapter
-	);
-
-
-//Remove ODM_RateAdaptiveStateApInit() by RS_James
-
-//Remove Edca by YuChen
-
-#endif
-
-
-
-u4Byte odm_ConvertTo_dB(u4Byte Value);
-
-u4Byte odm_ConvertTo_linear(u4Byte Value);
-
-#if((DM_ODM_SUPPORT_TYPE==ODM_WIN)||(DM_ODM_SUPPORT_TYPE==ODM_CE))
-
-u4Byte
-GetPSDData(
-	PDM_ODM_T	pDM_Odm,
-	unsigned int 	point,
-	u1Byte initial_gain_psd);
-
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)	
-VOID
-ODM_DMWatchdog_LPS(
-	IN		PDM_ODM_T		pDM_Odm
-);
-#endif
-
-
-s4Byte
-ODM_PWdB_Conversion(
-    IN  s4Byte X,
-    IN  u4Byte TotalBit,
-    IN  u4Byte DecimalBit
-    );
-
-s4Byte
-ODM_SignConversion(
-    IN  s4Byte value,
-    IN  u4Byte TotalBit
-    );
-
-VOID 
-ODM_DMInit(
- IN	PDM_ODM_T	pDM_Odm
-);
-
-VOID
-ODM_DMReset(
-	IN	PDM_ODM_T	pDM_Odm
-	);
-
-VOID
-phydm_support_ablity_debug(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value,
-	IN		u4Byte			*_used,
-	OUT		char				*output,
-	IN		u4Byte			*_out_len
-	);
-
-VOID
-ODM_DMWatchdog(
-	IN		PDM_ODM_T			pDM_Odm			// For common use in the future
-	);
-
-VOID
-ODM_CmnInfoInit(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		ODM_CMNINFO_E	CmnInfo,
-	IN		u4Byte			Value	
-	);
-
-VOID
-ODM_CmnInfoHook(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		ODM_CMNINFO_E	CmnInfo,
-	IN		PVOID			pValue	
-	);
-
-VOID
-ODM_CmnInfoPtrArrayHook(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		ODM_CMNINFO_E	CmnInfo,
-	IN		u2Byte			Index,
-	IN		PVOID			pValue	
-	);
-
-VOID
-ODM_CmnInfoUpdate(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		u4Byte			CmnInfo,
-	IN		u8Byte			Value	
-	);
-
-#if(DM_ODM_SUPPORT_TYPE==ODM_AP)
-VOID 
-ODM_InitAllThreads(
-    IN PDM_ODM_T	pDM_Odm 
-    );
-
-VOID
-ODM_StopAllThreads(
-	IN PDM_ODM_T	pDM_Odm 
-	);
-#endif
-
-VOID 
-ODM_InitAllTimers(
-    IN PDM_ODM_T	pDM_Odm 
-    );
-
-VOID 
-ODM_CancelAllTimers(
-    IN PDM_ODM_T    pDM_Odm 
-    );
-
-VOID
-ODM_ReleaseAllTimers(
-    IN PDM_ODM_T	pDM_Odm 
-    );
-
-
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID ODM_InitAllWorkItems(IN PDM_ODM_T	pDM_Odm );
-VOID ODM_FreeAllWorkItems(IN PDM_ODM_T	pDM_Odm );
-
-
-
-u8Byte
-PlatformDivision64(
-	IN u8Byte	x,
-	IN u8Byte	y
-);
-
-//====================================================
-//3 PathDiV End
-//====================================================
-
-
-#define DM_ChangeDynamicInitGainThresh		ODM_ChangeDynamicInitGainThresh
-//void	ODM_ChangeDynamicInitGainThresh(IN	PADAPTER	pAdapter,
-//											IN	INT32		DM_Type,
-//											IN	INT32		DM_Value);
-//
-// PathDiveristy Remove by RS_James
-
-typedef enum tag_DIG_Connect_Definition
-{
-	DIG_STA_DISCONNECT = 0,	
-	DIG_STA_CONNECT = 1,
-	DIG_STA_BEFORE_CONNECT = 2,
-	DIG_MultiSTA_DISCONNECT = 3,
-	DIG_MultiSTA_CONNECT = 4,
-	DIG_CONNECT_MAX
-}DM_DIG_CONNECT_E;
-
-
-//
-// 2012/01/12 MH Check afapter status. Temp fix BSOD.
-//
-#define	HAL_ADAPTER_STS_CHK(pDM_Odm)\
-	if (pDM_Odm->Adapter == NULL)\
-	{\
-		return;\
-	}\
-
-
-//
-// For new definition in MP temporarily fro power tracking,
-//
-/*
-#define odm_TXPowerTrackingDirectCall(_Adapter)	\
-	IS_HARDWARE_TYPE_8192D(_Adapter) ? odm_TXPowerTrackingCallback_ThermalMeter_92D(_Adapter) : \
-	IS_HARDWARE_TYPE_8192C(_Adapter) ? odm_TXPowerTrackingCallback_ThermalMeter_92C(_Adapter) : \
-	IS_HARDWARE_TYPE_8723A(_Adapter) ? odm_TXPowerTrackingCallback_ThermalMeter_8723A(_Adapter) :\
-	ODM_TXPowerTrackingCallback_ThermalMeter(_Adapter)
-*/
-
-
-#endif	// #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-ODM_AsocEntry_Init(
-	IN		PDM_ODM_T		pDM_Odm
-	);
-
-//Remove ODM_DynamicARFBSelect() by RS_James
-
-PVOID
-PhyDM_Get_Structure(
-	IN		PDM_ODM_T		pDM_Odm,
-	IN		u1Byte			Structure_Type
-);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) ||(DM_ODM_SUPPORT_TYPE == ODM_CE)
-/*===========================================================*/
-/* The following is for compile only*/
-/*===========================================================*/
-
-#define	IS_HARDWARE_TYPE_8723A(_Adapter)			FALSE
-#define IS_HARDWARE_TYPE_8723AE(_Adapter)			FALSE
-#define	IS_HARDWARE_TYPE_8192C(_Adapter)			FALSE
-#define	IS_HARDWARE_TYPE_8192D(_Adapter)			FALSE
-#define	RF_T_METER_92D					0x42
-
-
-#define SET_TX_DESC_ANTSEL_A_92C(__pTxDesc, __Value) SET_BITS_TO_LE_1BYTE(__pTxDesc+8+3, 0, 1, __Value)
-#define SET_TX_DESC_TX_ANTL_92C(__pTxDesc, __Value) SET_BITS_TO_LE_1BYTE(__pTxDesc+8+3, 4, 2, __Value)
-#define SET_TX_DESC_TX_ANT_HT_92C(__pTxDesc, __Value) SET_BITS_TO_LE_1BYTE(__pTxDesc+8+3, 6, 2, __Value)
-#define SET_TX_DESC_TX_ANT_CCK_92C(__pTxDesc, __Value) SET_BITS_TO_LE_1BYTE(__pTxDesc+8+3, 2, 2, __Value)
-
-#define GET_RX_STATUS_DESC_RX_MCS(__pRxStatusDesc)				LE_BITS_TO_1BYTE( __pRxStatusDesc+12, 0, 6)
-
-#define		RX_HAL_IS_CCK_RATE_92C(pDesc)\
-			(GET_RX_STATUS_DESC_RX_MCS(pDesc) == DESC_RATE1M ||\
-			GET_RX_STATUS_DESC_RX_MCS(pDesc) == DESC_RATE2M ||\
-			GET_RX_STATUS_DESC_RX_MCS(pDesc) == DESC_RATE5_5M ||\
-			GET_RX_STATUS_DESC_RX_MCS(pDesc) == DESC_RATE11M)
-
-#define		H2C_92C_PSD_RESULT				16
-
-#define		rConfig_ram64x16				0xb2c
-
-#define TARGET_CHNL_NUM_2G_5G	59
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-FillH2CCmd92C(	
-	IN	PADAPTER		Adapter,
-	IN	u1Byte 	ElementID,
-	IN	u4Byte 	CmdLen,
-	IN	pu1Byte	pCmdBuffer
-);
-VOID
-PHY_SetTxPowerLevel8192C(
-	IN	PADAPTER		Adapter,
-	IN	u1Byte			channel
-	);
-u1Byte GetRightChnlPlaceforIQK(u1Byte chnl);
-
-#endif
-
-//===========================================================
-#endif //#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-void odm_dtc(PDM_ODM_T pDM_Odm);
-#endif /* #if (DM_ODM_SUPPORT_TYPE == ODM_CE) */
-
-
-VOID phydm_NoisyDetection(IN	PDM_ODM_T	pDM_Odm	);
-
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__HALDMOUTSRC_H__
+#define __HALDMOUTSRC_H__
+
+/*============================================================*/
+/*include files*/
+/*============================================================*/
+/*PHYDM header*/
+#include "phydm_pre_define.h"
+#include "phydm_dig.h"
+#include "phydm_pathdiv.h"
+#include "phydm_antdiv.h"
+#include "phydm_soml.h"
+#include "phydm_smt_ant.h"
+#include "phydm_antdect.h"
+#include "phydm_rainfo.h"
+#include "phydm_dynamictxpower.h"
+#include "phydm_cfotracking.h"
+#include "phydm_adaptivity.h"
+#include "phydm_dfs.h"
+#include "phydm_ccx.h"
+#include "txbf/phydm_hal_txbf_api.h"
+#include "phydm_adc_sampling.h"
+#include "phydm_dynamic_rx_path.h"
+#include "phydm_psd.h"
+#include "phydm_primary_cca.h"
+#include "phydm_cck_pd.h"
+#include "phydm_rssi_monitor.h"
+#include "phydm_auto_dbg.h"
+#include "phydm_math_lib.h"
+#include "phydm_noisemonitor.h"
+#include "phydm_api.h"
+#include "phydm_pow_train.h"
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
+	#include "phydm_beamforming.h"
+#endif
+
+/* reg naming transfer */
+#include "phydm_regtable.h"
+
+/*HALRF header*/
+#include "halrf/halrf_iqk.h"
+#include "halrf/halrf.h"
+#include "halrf/halrf_powertracking.h"
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	#include "halrf/halphyrf_ap.h"
+#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	#include "halrf/halphyrf_ce.h"
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	#include "halrf/halphyrf_win.h"
+#endif
+
+extern const u16 phy_rate_table[28];
+
+/*============================================================*/
+/*Definition */
+/*============================================================*/
+
+/* Traffic load decision */
+#define	TRAFFIC_ULTRA_LOW	1
+#define	TRAFFIC_LOW			2
+#define	TRAFFIC_MID			3
+#define	TRAFFIC_HIGH			4
+
+#define	NONE			0
+
+#define MAX_2(_x_, _y_)	(((_x_)>(_y_))? (_x_) : (_y_))
+#define MIN_2(_x_, _y_)	(((_x_)<(_y_))? (_x_) : (_y_))
+#define DIFF_2(_x_,_y_)	((_x_ >= _y_) ? (_x_ - _y_) : (_y_ - _x_))
+
+#define BYTE_2_DWORD(B3, B2, B1, B0)	((B3 << 24) | (B2 << 16) | (B1 << 8) | B0)
+#define BIT_2_BYTE(B3, B2, B1, B0)	((B3 << 3) | (B2 << 2) | (B1 << 1) | B0)
+
+/*For cmn sta info*/
+#define is_sta_active(sta)	((sta) && (sta->dm_ctrl & STA_DM_CTRL_ACTIVE))
+
+#define IS_FUNC_EN(name)	((name) && (*name))
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define PHYDM_WATCH_DOG_PERIOD	1 /*second*/
+#else
+	#define PHYDM_WATCH_DOG_PERIOD	2 /*second*/
+#endif
+
+/*============================================================*/
+/*structure and define*/
+/*============================================================*/
+
+#define		dm_type_by_fw			0
+#define		dm_type_by_driver		1
+
+struct phydm_phystatus_statistic {
+	
+	/*[CCK]*/
+	u32		rssi_cck_sum;
+	u32		rssi_cck_cnt;
+	/*[OFDM]*/	
+	u32		rssi_ofdm_sum;
+	u32		rssi_ofdm_cnt;
+	u32		evm_ofdm_sum;
+	u32		snr_ofdm_sum;
+	/*[1SS]*/
+	u32		rssi_1ss_cnt;
+	u32		rssi_1ss_sum;
+	u32		evm_1ss_sum;
+	u32		snr_1ss_sum;
+	/*[2SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	u32		rssi_2ss_cnt;
+	u32		rssi_2ss_sum[2];
+	u32		evm_2ss_sum[2];
+	u32		snr_2ss_sum[2];
+	#endif
+	/*[3SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	u32		rssi_3ss_cnt;
+	u32		rssi_3ss_sum[3];
+	u32		evm_3ss_sum[3];
+	u32		snr_3ss_sum[3];
+	#endif
+	/*[4SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	u32		rssi_4ss_cnt;
+	u32		rssi_4ss_sum[4];
+	u32		evm_4ss_sum[4];	
+	u32		snr_4ss_sum[4];
+	#endif
+};
+
+struct phydm_phystatus_avg {
+	
+	/*[CCK]*/
+	u8		rssi_cck_avg;
+	/*[OFDM]*/
+	u8		rssi_ofdm_avg;
+	u8		evm_ofdm_avg;
+	u8		snr_ofdm_avg;
+	/*[1SS]*/
+	u8		rssi_1ss_avg;
+	u8		evm_1ss_avg;
+	u8		snr_1ss_avg;
+	/*[2SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	u8		rssi_2ss_avg[2];
+	u8		evm_2ss_avg[2];
+	u8		snr_2ss_avg[2];
+	#endif
+	/*[3SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	u8		rssi_3ss_avg[3];
+	u8		evm_3ss_avg[3];
+	u8		snr_3ss_avg[3];
+	#endif
+	/*[4SS]*/
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	u8		rssi_4ss_avg[4];
+	u8		evm_4ss_avg[4];	
+	u8		snr_4ss_avg[4];
+	#endif
+};
+
+struct odm_phy_dbg_info {
+	/*ODM Write,debug info*/
+	
+	u32		num_qry_phy_status_cck;
+	u32		num_qry_phy_status_ofdm;
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+	u32		num_qry_mu_pkt;
+	u32		num_qry_bf_pkt;
+	u32		num_qry_mu_vht_pkt[VHT_RATE_NUM];
+	boolean	is_ldpc_pkt;
+	boolean	is_stbc_pkt;
+	u8		num_of_ppdu[4];
+	u8		gid_num[4];
+#endif
+	u8		num_qry_beacon_pkt;
+	u8		show_phy_sts_all_pkt;	/*Show phy status witch not match BSSID*/
+	u16		show_phy_sts_max_cnt;	/*show number of phy-status row data per PHYDM watchdog*/
+	u16		show_phy_sts_cnt;
+	/* Others */
+	/*s32		rx_evm[4];*/
+	/*s8		rx_snr_db[4];*/
+
+	u16		num_qry_legacy_pkt[LEGACY_RATE_NUM];
+	u16		num_qry_ht_pkt[HT_RATE_NUM];
+	u16		num_qry_pkt_sc_20m[LOW_BW_RATE_NUM];	/*for 20M SC*/
+	boolean	ht_pkt_not_zero;
+	boolean	low_bw_20_occur;
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+	u16		num_qry_vht_pkt[VHT_RATE_NUM];
+	u16		num_qry_pkt_sc_40m[LOW_BW_RATE_NUM];	/*for 40M SC*/
+	boolean	vht_pkt_not_zero;
+	boolean	low_bw_40_occur;
+	#endif
+	struct phydm_phystatus_statistic	phystatus_statistic_info;
+	struct phydm_phystatus_avg	phystatus_statistic_avg;
+};
+
+enum odm_cmninfo {
+	/*Fixed value*/
+	/*-----------HOOK BEFORE REG INIT-----------*/
+	ODM_CMNINFO_PLATFORM = 0,
+	ODM_CMNINFO_ABILITY,
+	ODM_CMNINFO_INTERFACE,
+	ODM_CMNINFO_MP_TEST_CHIP,
+	ODM_CMNINFO_IC_TYPE,
+	ODM_CMNINFO_CUT_VER,
+	ODM_CMNINFO_FAB_VER,
+	ODM_CMNINFO_RF_TYPE,
+	ODM_CMNINFO_RFE_TYPE,
+	ODM_CMNINFO_DPK_EN,
+	ODM_CMNINFO_BOARD_TYPE,
+	ODM_CMNINFO_PACKAGE_TYPE,
+	ODM_CMNINFO_EXT_LNA,
+	ODM_CMNINFO_5G_EXT_LNA,
+	ODM_CMNINFO_EXT_PA,
+	ODM_CMNINFO_5G_EXT_PA,
+	ODM_CMNINFO_GPA,
+	ODM_CMNINFO_APA,
+	ODM_CMNINFO_GLNA,
+	ODM_CMNINFO_ALNA,
+	ODM_CMNINFO_EXT_TRSW,
+	ODM_CMNINFO_EXT_LNA_GAIN,
+	ODM_CMNINFO_PATCH_ID,
+	ODM_CMNINFO_BINHCT_TEST,
+	ODM_CMNINFO_BWIFI_TEST,
+	ODM_CMNINFO_SMART_CONCURRENT,
+	ODM_CMNINFO_CONFIG_BB_RF,
+	ODM_CMNINFO_DOMAIN_CODE_2G,
+	ODM_CMNINFO_DOMAIN_CODE_5G,
+	ODM_CMNINFO_IQKPAOFF,
+	ODM_CMNINFO_HUBUSBMODE,
+	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS,
+	ODM_CMNINFO_TX_TP,
+	ODM_CMNINFO_RX_TP,
+	ODM_CMNINFO_SOUNDING_SEQ,
+	ODM_CMNINFO_REGRFKFREEENABLE,
+	ODM_CMNINFO_RFKFREEENABLE,
+	ODM_CMNINFO_NORMAL_RX_PATH_CHANGE,
+	ODM_CMNINFO_EFUSE0X3D8,
+	ODM_CMNINFO_EFUSE0X3D7,
+	ODM_CMNINFO_SOFT_AP_SPECIAL_SETTING,
+	ODM_CMNINFO_ADVANCE_OTA,
+	ODM_CMNINFO_HP_HWID,
+	/*-----------HOOK BEFORE REG INIT-----------*/
+
+	/*Dynamic value:*/
+
+	/*--------- POINTER REFERENCE-----------*/
+	ODM_CMNINFO_TX_UNI,
+	ODM_CMNINFO_RX_UNI,
+	ODM_CMNINFO_BAND,
+	ODM_CMNINFO_SEC_CHNL_OFFSET,
+	ODM_CMNINFO_SEC_MODE,
+	ODM_CMNINFO_BW,
+	ODM_CMNINFO_CHNL,
+	ODM_CMNINFO_FORCED_RATE,
+	ODM_CMNINFO_ANT_DIV,
+	ODM_CMNINFO_ADAPTIVE_SOML,
+	ODM_CMNINFO_ADAPTIVITY,
+	ODM_CMNINFO_SCAN,
+	ODM_CMNINFO_POWER_SAVING,
+	ODM_CMNINFO_ONE_PATH_CCA,
+	ODM_CMNINFO_DRV_STOP,
+	ODM_CMNINFO_PNP_IN,
+	ODM_CMNINFO_INIT_ON,
+	ODM_CMNINFO_ANT_TEST,
+	ODM_CMNINFO_NET_CLOSED,
+	ODM_CMNINFO_P2P_LINK,
+	ODM_CMNINFO_FCS_MODE,
+	ODM_CMNINFO_IS1ANTENNA,
+	ODM_CMNINFO_RFDEFAULTPATH,
+	ODM_CMNINFO_DFS_MASTER_ENABLE,
+	ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC,
+	ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA,
+	ODM_CMNINFO_SOFT_AP_MODE,
+	ODM_CMNINFO_MP_MODE,
+	ODM_CMNINFO_INTERRUPT_MASK,
+	ODM_CMNINFO_BB_OPERATION_MODE,
+	ODM_CMNINFO_BF_ANTDIV_DECISION,
+	/*--------- POINTER REFERENCE-----------*/
+
+	/*------------CALL BY VALUE-------------*/
+	ODM_CMNINFO_WIFI_DIRECT,
+	ODM_CMNINFO_WIFI_DISPLAY,
+	ODM_CMNINFO_LINK_IN_PROGRESS,
+	ODM_CMNINFO_LINK,
+	ODM_CMNINFO_CMW500LINK,
+	ODM_CMNINFO_STATION_STATE,
+	ODM_CMNINFO_RSSI_MIN,
+	ODM_CMNINFO_RSSI_MIN_BY_PATH,
+	ODM_CMNINFO_DBG_COMP,
+	ODM_CMNINFO_DBG_LEVEL,
+	ODM_CMNINFO_RA_THRESHOLD_HIGH,	/*to be removed*/
+	ODM_CMNINFO_RA_THRESHOLD_LOW,	/*to be removed*/
+	ODM_CMNINFO_RF_ANTENNA_TYPE,
+	ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH,
+	ODM_CMNINFO_BE_FIX_TX_ANT,
+	ODM_CMNINFO_BT_ENABLED,
+	ODM_CMNINFO_BT_HS_CONNECT_PROCESS,
+	ODM_CMNINFO_BT_HS_RSSI,
+	ODM_CMNINFO_BT_OPERATION,
+	ODM_CMNINFO_BT_LIMITED_DIG,
+	ODM_CMNINFO_AP_TOTAL_NUM,
+	ODM_CMNINFO_POWER_TRAINING,
+	ODM_CMNINFO_DFS_REGION_DOMAIN,
+	ODM_CMNINFO_BT_CONTINUOUS_TURN,
+	/*------------CALL BY VALUE-------------*/
+
+	/*Dynamic ptr array hook itms.*/
+	ODM_CMNINFO_STA_STATUS,
+	ODM_CMNINFO_MAX,
+
+};
+
+enum phydm_rfe_bb_source_sel {
+	PAPE_2G	= 0,
+	PAPE_5G	= 1,
+	LNA0N_2G	= 2,
+	LNAON_5G	= 3,
+	TRSW		= 4,
+	TRSW_B		= 5,
+	GNT_BT		= 6,
+	ZERO		= 7,
+	ANTSEL_0	= 8,
+	ANTSEL_1	= 9,
+	ANTSEL_2	= 0xa,
+	ANTSEL_3	= 0xb,
+	ANTSEL_4	= 0xc,
+	ANTSEL_5	= 0xd,
+	ANTSEL_6	= 0xe,
+	ANTSEL_7	= 0xf
+};
+
+enum phydm_info_query {
+	PHYDM_INFO_FA_OFDM,
+	PHYDM_INFO_FA_CCK,
+	PHYDM_INFO_FA_TOTAL,
+	PHYDM_INFO_CCA_OFDM,
+	PHYDM_INFO_CCA_CCK,
+	PHYDM_INFO_CCA_ALL,
+	PHYDM_INFO_CRC32_OK_VHT,
+	PHYDM_INFO_CRC32_OK_HT,
+	PHYDM_INFO_CRC32_OK_LEGACY,
+	PHYDM_INFO_CRC32_OK_CCK,
+	PHYDM_INFO_CRC32_ERROR_VHT,
+	PHYDM_INFO_CRC32_ERROR_HT,
+	PHYDM_INFO_CRC32_ERROR_LEGACY,
+	PHYDM_INFO_CRC32_ERROR_CCK,
+	PHYDM_INFO_EDCCA_FLAG,
+	PHYDM_INFO_OFDM_ENABLE,
+	PHYDM_INFO_CCK_ENABLE,
+	PHYDM_INFO_CRC32_OK_HT_AGG,
+	PHYDM_INFO_CRC32_ERROR_HT_AGG,
+	PHYDM_INFO_DBG_PORT_0,
+	PHYDM_INFO_CURR_IGI,
+	PHYDM_INFO_RSSI_MIN,
+	PHYDM_INFO_RSSI_MAX,
+	PHYDM_INFO_CLM_RATIO,
+	PHYDM_INFO_NHM_RATIO,
+};
+
+enum phydm_api {
+	PHYDM_API_NBI			= 1,
+	PHYDM_API_CSI_MASK,
+
+};
+
+enum phydm_func_idx { /*F_XXX = PHYDM XXX function*/
+
+	F00_DIG			= 0,
+	F01_RA_MASK		= 1,
+	F02_DYN_TXPWR		= 2,
+	F03_FA_CNT			= 3,
+	F04_RSSI_MNTR		= 4,
+	F05_CCK_PD			= 5,
+	F06_ANT_DIV		= 6,
+	F07_SMT_ANT		= 7,
+	F08_PWR_TRAIN		= 8,
+	F09_RA				= 9,
+	F10_PATH_DIV		= 10,
+	F11_DFS			= 11,
+	F12_DYN_ARFR		= 12,
+	F13_ADPTVTY		= 13,
+	F14_CFO_TRK		= 14,
+	F15_ENV_MNTR		= 15,
+	F16_PRI_CCA		= 16,
+	F17_ADPTV_SOML	= 17,
+	F18_LNA_SAT_CHK	= 18,
+	F19_DYN_RX_PATH	= 19
+};
+
+/*=[PHYDM supportability]==========================================*/
+enum odm_ability {
+	ODM_BB_DIG				= BIT(F00_DIG),
+	ODM_BB_RA_MASK			= BIT(F01_RA_MASK),
+	ODM_BB_DYNAMIC_TXPWR	= BIT(F02_DYN_TXPWR),
+	ODM_BB_FA_CNT				= BIT(F03_FA_CNT),
+	ODM_BB_RSSI_MONITOR		= BIT(F04_RSSI_MNTR),
+	ODM_BB_CCK_PD				= BIT(F05_CCK_PD),
+	ODM_BB_ANT_DIV			= BIT(F06_ANT_DIV),
+	ODM_BB_SMT_ANT			= BIT(F07_SMT_ANT),
+	ODM_BB_PWR_TRAIN			= BIT(F08_PWR_TRAIN),
+	ODM_BB_RATE_ADAPTIVE		= BIT(F09_RA),
+	ODM_BB_PATH_DIV			= BIT(F10_PATH_DIV),
+	ODM_BB_DFS				= BIT(F11_DFS),
+	ODM_BB_DYNAMIC_ARFR		= BIT(F12_DYN_ARFR),
+	ODM_BB_ADAPTIVITY			= BIT(F13_ADPTVTY),
+	ODM_BB_CFO_TRACKING		= BIT(F14_CFO_TRK),
+	ODM_BB_ENV_MONITOR		= BIT(F15_ENV_MNTR),
+	ODM_BB_PRIMARY_CCA		= BIT(F16_PRI_CCA),
+	ODM_BB_ADAPTIVE_SOML		= BIT(F17_ADPTV_SOML),
+	ODM_BB_LNA_SAT_CHK		= BIT(F18_LNA_SAT_CHK),
+	ODM_BB_DYNAMIC_RX_PATH	= BIT(F19_DYN_RX_PATH)
+};
+
+/*=[PHYDM Debug Component]=====================================*/
+enum phydm_dbg_comp {
+	/*BB Driver Functions*/
+	DBG_DIG			= BIT(F00_DIG),
+	DBG_RA_MASK		= BIT(F01_RA_MASK),
+	DBG_DYN_TXPWR	= BIT(F02_DYN_TXPWR),
+	DBG_FA_CNT		= BIT(F03_FA_CNT),
+	DBG_RSSI_MNTR		= BIT(F04_RSSI_MNTR),
+	DBG_CCKPD			= BIT(F05_CCK_PD),
+	DBG_ANT_DIV		= BIT(F06_ANT_DIV),
+	DBG_SMT_ANT		= BIT(F07_SMT_ANT),
+	DBG_PWR_TRAIN		= BIT(F08_PWR_TRAIN),
+	DBG_RA				= BIT(F09_RA),
+	DBG_PATH_DIV		= BIT(F10_PATH_DIV),
+	DBG_DFS			= BIT(F11_DFS),
+	DBG_DYN_ARFR		= BIT(F12_DYN_ARFR),
+	DBG_ADPTVTY		= BIT(F13_ADPTVTY),
+	DBG_CFO_TRK		= BIT(F14_CFO_TRK), 
+	DBG_ENV_MNTR		= BIT(F15_ENV_MNTR),
+	DBG_PRI_CCA		= BIT(F16_PRI_CCA),
+	DBG_ADPTV_SOML	= BIT(F17_ADPTV_SOML),
+	DBG_LNA_SAT_CHK	= BIT(F18_LNA_SAT_CHK),
+	DBG_DYN_RX_PATH	= BIT(F19_DYN_RX_PATH),
+	/*Neet to re-arrange*/
+	DBG_PHY_STATUS	= BIT(20),
+	DBG_TMP			= BIT(21),
+	DBG_FW_TRACE		= BIT(22),
+	DBG_TXBF			= BIT(23),
+	DBG_COMMON_FLOW	= BIT(24),
+	ODM_COMP_TX_PWR_TRACK	= BIT(25),
+	ODM_COMP_CALIBRATION		= BIT(26),
+	ODM_COMP_MP		= BIT(27),
+	ODM_PHY_CONFIG	= BIT(28),
+	ODM_COMP_INIT		= BIT(29),
+	ODM_COMP_COMMON	= BIT(30),
+	ODM_COMP_API		= BIT(31)
+};
+
+/*=========================================================*/
+
+/*ODM_CMNINFO_ONE_PATH_CCA*/
+enum odm_cca_path {
+	ODM_CCA_2R		= 0,
+	ODM_CCA_1R_A		= 1,
+	ODM_CCA_1R_B		= 2,
+};
+
+enum phy_reg_pg_type {
+	PHY_REG_PG_RELATIVE_VALUE	= 0,
+	PHY_REG_PG_EXACT_VALUE		= 1
+};
+
+enum phydm_offload_ability {
+	PHYDM_PHY_PARAM_OFFLOAD = BIT(0),
+	PHYDM_RF_IQK_OFFLOAD = BIT(1),
+};
+
+struct phydm_pause_lv {
+	s8	lv_dig;
+	s8	lv_cckpd;
+	s8	lv_antdiv;
+	s8	lv_adapt;
+};
+
+struct phydm_func_poiner {
+	void	(*pause_phydm_handler)(void	 *dm_void, u32 *val_buf, u8 val_len);
+};
+
+struct pkt_process_info {
+	u8	phystatus_smp_mode_en; /*send phystatus every sampling time*/
+	u8	pre_ppdu_cnt;
+	u8	lna_idx;
+	u8	vga_idx;
+};
+
+#ifdef ODM_CONFIG_BT_COEXIST
+struct	phydm_bt_info {
+	boolean		is_bt_enabled;			/*BT is enabled*/
+	boolean		is_bt_connect_process;	/*BT HS is under connection progress.*/
+	u8			bt_hs_rssi;				/*BT HS mode wifi rssi value.*/
+	boolean		is_bt_hs_operation;		/*BT HS mode is under progress*/
+	boolean		is_bt_limited_dig;		/*BT is busy.*/
+};
+#endif
+
+struct	phydm_iot_center {
+	boolean		is_linked_cmw500;
+	u8			win_patch_id;		/*Customer ID*/
+	u32			phydm_patch_id;
+
+};
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	#if (RT_PLATFORM != PLATFORM_LINUX)
+		typedef
+	#endif
+
+	struct dm_struct
+#else/*for AP, CE Team*/
+	struct dm_struct
+#endif
+{
+	/*Add for different team use temporarily*/
+	void		*adapter;		/*For CE/NIC team*/
+	struct rtl8192cd_priv	*priv;			/*For AP team*/
+	/*WHen you use adapter or priv pointer, you must make sure the pointer is ready.*/
+	boolean		odm_ready;
+	enum phy_reg_pg_type	phy_reg_pg_value_type;
+	u8			phy_reg_pg_version;
+	u64			support_ability;	/*PHYDM function Supportability*/
+	u64			pause_ability;	/*PHYDM function pause Supportability*/
+	u64			debug_components;
+	u8			cmn_dbg_msg_period;
+	u8			cmn_dbg_msg_cnt;
+	u32			fw_debug_components;
+	u32			debug_level;
+	u32			num_qry_phy_status_all;		/*CCK + OFDM*/
+	u32			last_num_qry_phy_status_all;
+	u32			rx_pwdb_ave;
+	boolean		is_init_hw_info_by_rfe;
+
+	/*------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
+	boolean		is_cck_high_power;
+	u8			rf_path_rx_enable;
+	/*------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
+
+	/* COMMON INFORMATION */
+
+	/*Init value*/
+	/*-----------HOOK BEFORE REG INIT-----------*/
+
+	u8			support_platform;/*PHYDM Platform info WIN/AP/CE = 1/2/3 */
+	u8			normal_rx_path;	
+	boolean		brxagcswitch; /* for rx AGC table switch in Microsoft case */
+	u8			support_interface;/*PHYDM PCIE/USB/SDIO = 1/2/3*/
+	u32			support_ic_type;	/*PHYDM supported IC*/
+	u8			cut_version;		/*cut version TestChip/A-cut/B-cut... = 0/1/2/3/...*/
+	u8			fab_version;		/*Fab version TSMC/UMC = 0/1*/
+	u8			rf_type;			/*RF type 4T4R/3T3R/2T2R/1T2R/1T1R/...*/
+	u8			rfe_type;
+	u8			board_type;
+	u8			package_type;
+	u16			type_glna;
+	u16			type_gpa;
+	u16			type_alna;
+	u16			type_apa;
+	u8			ext_lna;			/*with 2G external LNA  NO/Yes = 0/1*/
+	u8			ext_lna_5g;		/*with 5G external LNA  NO/Yes = 0/1*/
+	u8			ext_pa;			/*with 2G external PNA  NO/Yes = 0/1*/
+	u8			ext_pa_5g;		/*with 5G external PNA  NO/Yes = 0/1*/
+	u8 			efuse0x3d7;		/*with Efuse number*/
+	u8 			efuse0x3d8;
+	u8			ext_trsw;		/*with external TRSW  NO/Yes = 0/1*/
+	u8			ext_lna_gain;	/*gain of external lna*/
+	boolean		is_in_hct_test;
+	u8			wifi_test;
+	boolean		is_dual_mac_smart_concurrent;
+	u32			bk_support_ability; /*SD4 only*/
+	u8			with_extenal_ant_switch;
+	/*cck agc relative*/
+	boolean		cck_new_agc;
+	s8			cck_lna_gain_table[8];
+	/*-------------------------------------*/
+	u32			phydm_sys_up_time;
+	u8			num_rf_path; /*ex: 8821C=1, 8192E=2, 8814B=4*/
+	u32			soft_ap_special_setting;
+	s8			s8_dummy;
+	u8			u8_dummy;
+	u16			u16_dummy;
+	u32			u32_dummy;
+	u8			rfe_hwsetting_band;
+	u8			p_advance_ota;
+	boolean		hp_hw_id;
+	boolean		BOOLEAN_temp;
+	boolean		is_dfs_band;
+	u8			is_receiver_blocking_en;
+	u16			fw_offload_ability;
+/*-----------HOOK BEFORE REG INIT-----------*/
+/*===========================================================*/	
+/*====[ CALL BY Reference ]=========================================*/
+/*===========================================================*/	
+
+	u64			*num_tx_bytes_unicast;	/*TX Unicast byte count*/
+	u64			*num_rx_bytes_unicast;	/*RX Unicast byte count*/
+	u8			*band_type;				/*Frequence band 2.4G/5G = 0/1*/
+	u8			*sec_ch_offset;			/*Secondary channel offset don't_care/below/above = 0/1/2*/
+	u8			*security;					/*security mode Open/WEP/AES/TKIP = 0/1/2/3*/
+	u8			*band_width;				/*BW info 20M/40M/80M = 0/1/2*/
+	u8			*channel;					/*central channel number*/
+	boolean		*is_scan_in_process;		/*Common info for status*/
+	boolean		*is_power_saving;
+	u8			*one_path_cca;			/*CCA path 2-path/path-A/path-B = 0/1/2; using enum odm_cca_path.*/
+	u8			*antenna_test;
+	boolean		*is_net_closed;
+	boolean		*is_fcs_mode_enable;
+	/*--------- For 8723B IQK-------------------------------------*/
+	boolean		*is_1_antenna;
+	u8			*rf_default_path;	/* 0:S1, 1:S0 */
+	/*-----------------------------------------------------------*/
+
+	u16			*forced_data_rate;
+	u8			*enable_antdiv;
+	u8			*en_adap_soml;
+	u8			*enable_adaptivity;
+	u8			*hub_usb_mode;		/*1: USB 2.0, 2: USB 3.0*/
+	boolean			*is_fw_dw_rsvd_page_in_progress;
+	u32			*current_tx_tp;
+	u32			*current_rx_tp;
+	u8			*sounding_seq;
+	u32			*soft_ap_mode;
+	u8			*mp_mode;
+	u32			*interrupt_mask;
+	u8			*bb_op_mode;
+/*===========================================================*/	
+/*====[ CALL BY VALUE ]===========================================*/
+/*===========================================================*/	
+
+	u8			disable_phydm_watchdog;
+	boolean		is_link_in_process;
+	boolean		is_wifi_direct;
+	boolean		is_wifi_display;
+	boolean		is_linked;
+	boolean		bsta_state;
+	u8			rssi_min;
+	u8			pre_rssi_min;
+	u8			rssi_max;
+	u8			rssi_min_by_path;
+	boolean		is_mp_chip;
+	boolean		is_one_entry_only;
+	u32			one_entry_macid;
+	u32			one_entry_tp;
+	u32			pre_one_entry_tp;
+	u8			pre_number_linked_client;
+	u8			number_linked_client;
+	u8			pre_number_active_client;
+	u8			number_active_client;
+	boolean		is_disable_phy_api;
+	u8			rssi_a;
+	u8			rssi_b;
+	u8			rssi_c;
+	u8			rssi_d;
+	u64			rssi_trsw;
+	u64			rssi_trsw_h;
+	u64			rssi_trsw_l;
+	u64			rssi_trsw_iso;
+	u8			tx_ant_status;
+	u8			rx_ant_status;
+	u8			cck_lna_idx;
+	u8			cck_vga_idx;
+	u8			curr_station_id;
+	u8			ofdm_agc_idx[4];
+	u8			rx_rate;
+	u8			rate_ss;
+	u8			tx_rate;
+	u8			linked_interval;
+	u8			pre_channel;
+	u32			txagc_offset_value_a;
+	boolean		is_txagc_offset_positive_a;
+	u32			txagc_offset_value_b;
+	boolean		is_txagc_offset_positive_b;
+	/*[traffic]*/
+	u8			traffic_load;
+	u8			pre_traffic_load;
+	u32			tx_tp;	/*Mbps*/
+	u32			rx_tp;	/*Mbps*/
+	u32			total_tp;/*Mbps*/
+	u8			txrx_state_all;	/*0: tx, 1:rx, 2:bi-direction*/
+	u64			cur_tx_ok_cnt;
+	u64			cur_rx_ok_cnt;
+	u64			last_tx_ok_cnt;
+	u64			last_rx_ok_cnt;
+	u16			consecutive_idlel_time;	/*unit: second*/
+	/*---------------------------*/
+	boolean		is_bb_swing_offset_positive_a;
+	boolean		is_bb_swing_offset_positive_b;
+
+	/*[DIG]*/
+	boolean		MPDIG_2G;				/*off MPDIG*/
+	u8			times_2g;	/*for MP DIG*/
+
+	/*[TDMA-DIG]*/
+	u8			tdma_dig_timer_ms;
+	u8			tdma_dig_state_number;
+	u8			tdma_dig_low_upper_bond;
+	u8			fix_expire_to_zero;
+	boolean		original_dig_restore;
+	/*---------------------------*/
+
+	/*[AntDiv]*/
+	u8			ant_div_type;
+	u8			antdiv_rssi;
+	u8			fat_comb_a;
+	u8			fat_comb_b;
+	u8			antdiv_intvl;
+	u8			ant_type;
+	u8			pre_ant_type;
+	u8			antdiv_period;
+	u8			evm_antdiv_period;
+	u8			antdiv_select;
+	u8			antdiv_train_num;/*training time for each antenna in EVM method*/
+	u8			stop_antdiv_rssi_th;
+	u16			stop_antdiv_tp_diff_th;
+	u16			stop_antdiv_tp_th;
+	u8			antdiv_tp_period;
+	u16			tp_active_th;
+	u8			tp_active_occur;
+	u8			path_select;
+	u8			antdiv_evm_en;
+	u8			bdc_holdstate;
+	/*---------------------------*/
+	
+	u8			ndpa_period;
+	boolean		h2c_rarpt_connect;
+	boolean		cck_agc_report_type;
+	u8			print_agc;
+	u8			la_mode;
+	/*---8821C Antenna and RF Set BTG/WLG/WLA Select---------------*/
+	u8			current_rf_set_8821c;
+	u8			default_rf_set_8821c;
+	u8			current_ant_num_8821c;
+	u8			default_ant_num_8821c;
+	u8			rfe_type_expand;
+	/*-----------------------------------------------------------*/
+	/*---For Adaptivtiy---------------------------------------------*/
+	s8			TH_L2H_default;
+	s8			th_edcca_hl_diff_default;
+	s8			th_l2h_ini;
+	s8			th_edcca_hl_diff;
+	s8			th_l2h_ini_mode2;
+	s8			th_edcca_hl_diff_mode2;
+	boolean		carrier_sense_enable;
+	boolean		adaptivity_flag;	/*Limit IGI upper bound for Adaptivity*/
+	u8			dc_backoff;
+	boolean		adaptivity_enable;
+	u8			ap_total_num;
+	boolean		edcca_enable;
+	u8			odm_regulation_2_4g;
+	u8			odm_regulation_5g;
+	/*-----------------------------------------------------------*/
+	
+	u8			pre_dbg_priority;
+	u8			nbi_set_result;
+	u8			c2h_cmd_start;
+	u8			fw_debug_trace[60];
+	u8			pre_c2h_seq;
+	boolean		fw_buff_is_enpty;
+	u32			data_frame_num;
+
+	/*--- for noise detection ---------------------------------------*/
+	boolean		is_noisy_state;
+	boolean		noisy_decision; /*b_noisy*/
+	boolean		pre_b_noisy;
+	u32			noisy_decision_smooth;
+	u8			lna_sat_chk_cnt;
+	u8			lna_sat_chk_duty_cycle;
+	u32			lna_sat_chk_period_ms;
+	boolean		is_disable_lna_sat_chk;
+	boolean		is_disable_gain_table_switch;
+	/*-----------------------------------------------------------*/
+	
+	boolean		is_disable_dym_ecs;
+	boolean		is_disable_dym_ant_weighting;
+	struct sta_info	*odm_sta_info[ODM_ASSOCIATE_ENTRY_NUM];/*odm_sta_info, 2012/01/12 MH For MP, we need to reduce one array pointer for default port.??*/
+	struct cmn_sta_info	*phydm_sta_info[ODM_ASSOCIATE_ENTRY_NUM];
+	u8			phydm_macid_table[ODM_ASSOCIATE_ENTRY_NUM];
+
+#if (RATE_ADAPTIVE_SUPPORT == 1)
+	u16			currmin_rpt_time;
+	struct _odm_ra_info_   ra_info[ODM_ASSOCIATE_ENTRY_NUM];
+	/*Use mac_id as array index. STA mac_id=0, VWiFi Client mac_id={1, ODM_ASSOCIATE_ENTRY_NUM-1} //YJ,add,120119*/
+#endif
+	boolean		ra_support88e;	/*2012/02/14 MH Add to share 88E ra with other SW team.We need to colelct all support abilit to a proper area.*/
+	boolean		*is_driver_stopped;
+	boolean		*is_driver_is_going_to_pnp_set_power_sleep;
+	boolean		*pinit_adpt_in_progress;
+	boolean		is_user_assign_level;
+	u8			RSSI_BT;			/*come from BT*/
+
+	/*---PSD Relative ---------------------------------------------*/
+	boolean		is_psd_in_process;
+	boolean		is_psd_active;
+	/*-----------------------------------------------------------*/
+	
+	boolean		bsomlenabled;		/* for dynamic SoML control */
+	boolean		bhtstfdisabled;		/* for dynamic HTSTF gain control	*/
+	boolean		disrxhpsoml;			/* for dynamic RxHP control with SoML on/off */
+	u32			n_iqk_cnt;
+	u32			n_iqk_ok_cnt;
+	u32			n_iqk_fail_cnt;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	boolean		config_bbrf;
+#endif
+	boolean		is_disable_power_training;
+	boolean		is_bt_continuous_turn;
+	u8			dynamic_tx_high_power_lvl;
+	u8			last_dtp_lvl;
+	u8			min_power_index;
+	u32			tx_agc_ofdm_18_6;
+	u8			rx_pkt_type;
+
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	u8			dfs_region_domain;
+	u8			*dfs_master_enabled;
+	/*---phydm_radar_detect_with_dbg_parm start --------------------*/
+	u8			radar_detect_dbg_parm_en;
+	u32			radar_detect_reg_918;
+	u32			radar_detect_reg_91c;
+	u32			radar_detect_reg_920;
+	u32			radar_detect_reg_924;
+	/*-----------------------------------------------------------*/
+#endif
+
+/*=== PHYDM Timer ========================================== (start)*/
+
+	struct phydm_timer_list	mpt_dig_timer;	/*MPT DIG timer*/
+	struct phydm_timer_list	path_div_switch_timer;
+	struct phydm_timer_list	cck_path_diversity_timer;	/*2011.09.27 add for path Diversity*/
+	struct phydm_timer_list	fast_ant_training_timer;
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	struct phydm_timer_list	evm_fast_ant_training_timer;
+#endif
+	struct phydm_timer_list	sbdcnt_timer;
+
+
+/*=== PHYDM Workitem ======================================= (start)*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	path_div_switch_workitem;
+	RT_WORK_ITEM	cck_path_diversity_workitem;
+	RT_WORK_ITEM	fast_ant_training_workitem;
+	RT_WORK_ITEM	ra_rpt_workitem;
+	RT_WORK_ITEM	sbdcnt_workitem;
+#endif
+#endif
+
+
+/*=== PHYDM Structure ======================================== (start)*/
+	struct	phydm_func_poiner			phydm_func_handler;
+	struct	phydm_iot_center				iot_table;
+
+#ifdef ODM_CONFIG_BT_COEXIST
+	struct	phydm_bt_info				bt_info_table;
+#endif
+
+	struct	pkt_process_info				pkt_proc_struct;
+	struct phydm_adaptivity_struct			adaptivity;
+	struct _DFS_STATISTICS				dfs;
+
+	struct odm_noise_monitor			noise_level;
+
+	struct odm_phy_dbg_info				phy_dbg_info;
+
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct adaptive_soml					dm_soml_table;
+#endif
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct _BF_DIV_COEX_					dm_bdc_table;
+	#endif
+
+	#if (defined(CONFIG_HL_SMART_ANTENNA))
+	struct smt_ant_honbo					dm_sat_table;
+	#endif
+#endif
+
+#if (defined(CONFIG_SMART_ANTENNA))
+	struct smt_ant						smtant_table;
+#endif
+
+	struct phydm_fat_struct				dm_fat_table;
+	struct phydm_dig_struct				dm_dig_table;
+	struct phydm_lna_sat_info_struct		dm_lna_sat_info;
+
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct phydm_cckpd_struct				dm_cckpd_table;
+#endif
+	
+#ifdef PHYDM_PRIMARY_CCA
+	struct phydm_pricca_struct				dm_pri_cca;
+#endif
+
+	struct ra_table			dm_ra_table;
+	struct phydm_fa_struct					false_alm_cnt;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct				false_alm_cnt_acc;
+#endif
+	struct sw_antenna_switch				dm_swat_table;
+	struct phydm_cfo_track_struct			dm_cfo_track;
+	struct ccx_info						dm_ccx_info;
+	struct _hal_rf_						rf_table; 		/*for HALRF function*/
+	struct dm_rf_calibration_struct		rf_calibrate_info;
+	struct odm_power_trim_data			power_trim_data;	
+#if (RTL8822B_SUPPORT == 1)
+	struct drp_rtl8822b_struct				phydm_rtl8822b;
+#endif
+
+#ifdef CONFIG_PSD_TOOL
+	struct psd_info					dm_psd_table;
+#endif
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+	struct rt_adcsmp					adcsmp;
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	struct _DYNAMIC_RX_PATH_			dm_drp_table;
+#endif
+
+	struct dm_iqk_info				IQK_info;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct _path_div_parameter_define_		path_iqk;
+#endif
+
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct _ODM_PATH_DIVERSITY_			dm_path_div;
+#endif
+
+#if (defined(CONFIG_ANT_DETECTION))
+	struct _ANT_DETECTED_INFO			ant_detected_info;	/* Antenna detected information for RSSI tool*/
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+	struct _RT_BEAMFORMING_INFO 		beamforming_info;
+#endif
+#endif
+#ifdef PHYDM_AUTO_DEGBUG
+	struct	phydm_auto_dbg_struc			auto_dbg_table;
+#endif
+
+	struct	phydm_pause_lv				pause_lv_table;	
+	struct	phydm_api_stuc 				api_table;
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+	struct	phydm_pow_train_stuc			pow_train_table;
+#endif
+/*==========================================================*/
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#if (RT_PLATFORM != PLATFORM_LINUX)
+}dm_struct;		/*DM_Dynamic_Mechanism_Structure*/
+#else
+};
+#endif
+
+#else	/*for AP,CE Team*/
+};
+#endif
+
+enum phydm_adv_ota {
+	PHYDM_PATHB_1RCCA = BIT(0),
+	PHYDM_HP_OTA_SETTING_A = BIT(1),
+	PHYDM_HP_OTA_SETTING_B = BIT(2),
+	PHYDM_ASUS_OTA_SETTING = BIT(3),
+	PHYDM_ASUS_OTA_SETTING_CCK_PATH = BIT(4),
+	PHYDM_HP_OTA_SETTING_CCK_PATH = BIT(5),
+	PHYDM_LENOVO_OTA_SETTING_NBI_CSI = BIT(6),
+
+};
+
+enum phydm_bb_op_mode {
+	PHYDM_PERFORMANCE_MODE = 0,	/*Service one device*/
+	PHYDM_BALANCE_MODE = 1,		/*Service more than one device*/
+};
+
+enum phydm_structure_type {
+	PHYDM_FALSEALMCNT,
+	PHYDM_CFOTRACK,
+	PHYDM_ADAPTIVITY,
+	PHYDM_DFS,
+	PHYDM_ROMINFO,
+
+};
+
+enum odm_bb_config_type {
+	CONFIG_BB_PHY_REG,
+	CONFIG_BB_AGC_TAB,
+	CONFIG_BB_AGC_TAB_2G,
+	CONFIG_BB_AGC_TAB_5G,
+	CONFIG_BB_PHY_REG_PG,
+	CONFIG_BB_PHY_REG_MP,
+	CONFIG_BB_AGC_TAB_DIFF,
+};
+
+enum odm_rf_config_type {
+	CONFIG_RF_RADIO,
+	CONFIG_RF_TXPWR_LMT,
+};
+
+enum odm_fw_config_type {
+	CONFIG_FW_NIC,
+	CONFIG_FW_NIC_2,
+	CONFIG_FW_AP,
+	CONFIG_FW_AP_2,
+	CONFIG_FW_MP,
+	CONFIG_FW_WOWLAN,
+	CONFIG_FW_WOWLAN_2,
+	CONFIG_FW_AP_WOWLAN,
+	CONFIG_FW_BT,
+};
+
+/*status code*/
+#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
+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,
+};
+#endif	/*end of enum rt_status definition*/
+
+void
+phydm_watchdog_lps(
+	struct dm_struct	*dm
+);
+
+void
+phydm_watchdog_lps_32k(
+	struct dm_struct	*dm
+);
+
+void
+phydm_txcurrentcalibration(
+	struct dm_struct	*dm
+);	
+
+void
+phydm_dm_early_init(
+	struct dm_struct	*dm
+);
+
+void
+odm_dm_init(
+	struct dm_struct	*dm
+);
+
+void
+odm_dm_reset(
+	struct dm_struct	*dm
+);
+
+void
+phydm_fwoffload_ability_init(
+	struct dm_struct	*dm,
+	enum phydm_offload_ability	offload_ability
+);
+
+void
+phydm_fwoffload_ability_clear(
+	struct dm_struct	*dm,
+	enum phydm_offload_ability	offload_ability
+);
+
+void
+phydm_support_ability_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_pause_dm_watchdog(
+	void					*dm_void,
+	enum phydm_pause_type	pause_type
+);
+
+void
+phydm_watchdog(
+	struct dm_struct	*dm
+);
+
+void
+phydm_watchdog_mp(
+	struct dm_struct	*dm
+);
+
+u8
+phydm_pause_func(
+	void					*dm_void,
+	enum phydm_func_idx	pause_func,	
+	enum phydm_pause_type	pause_type,
+	enum phydm_pause_level	pause_lv,
+	u8						val_lehgth,
+	u32						*val_buf
+	
+);
+
+void
+phydm_pause_func_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+void
+odm_cmn_info_init(
+	struct dm_struct	*dm,
+	enum odm_cmninfo		cmn_info,
+	u64						value
+);
+
+void
+odm_cmn_info_hook(
+	struct dm_struct	*dm,
+	enum odm_cmninfo		cmn_info,
+	void						*value
+);
+
+void
+odm_cmn_info_update(
+	struct dm_struct	*dm,
+	u32						cmn_info,
+	u64						value
+);
+
+u32
+phydm_cmn_info_query(
+	struct dm_struct	*dm,
+	enum phydm_info_query	info_type
+);
+
+void
+odm_init_all_timers(
+	struct dm_struct	*dm
+);
+
+void
+odm_cancel_all_timers(
+	struct dm_struct	*dm
+);
+
+void
+odm_release_all_timers(
+	struct dm_struct	*dm
+);
+
+void *
+phydm_get_structure(
+	struct dm_struct	*dm,
+	u8			structure_type
+);
+
+void
+phydm_dc_cancellation(
+	struct	dm_struct	*dm
+);
+
+void
+phydm_receiver_blocking(
+	void *dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void 
+odm_init_all_work_items(
+	struct dm_struct	*dm
+);
+void 
+odm_free_all_work_items(
+	struct dm_struct	*dm
+);
+#endif	/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void 
+odm_dtc(
+	struct dm_struct	*dm
+);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+void
+odm_init_all_threads(
+	struct dm_struct	*dm
+);
+
+void
+odm_stop_all_threads(
+	struct dm_struct	*dm
+);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.mk b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.mk
new file mode 100644
index 000000000000..94f180dd5530
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm.mk
@@ -0,0 +1,167 @@
+# SPDX-License-Identifier: GPL-2.0
+EXTRA_CFLAGS += -I$(src)/hal/phydm
+
+_PHYDM_FILES := hal/phydm/phydm_debug.o	\
+								hal/phydm/phydm_antdiv.o\
+								hal/phydm/phydm_soml.o\
+								hal/phydm/phydm_smt_ant.o\
+								hal/phydm/phydm_antdect.o\
+								hal/phydm/phydm_interface.o\
+								hal/phydm/phydm_phystatus.o\
+								hal/phydm/phydm_hwconfig.o\
+								hal/phydm/phydm.o\
+								hal/phydm/phydm_dig.o\
+								hal/phydm/phydm_pathdiv.o\
+								hal/phydm/phydm_rainfo.o\
+								hal/phydm/phydm_dynamictxpower.o\
+								hal/phydm/phydm_adaptivity.o\
+								hal/phydm/phydm_cfotracking.o\
+								hal/phydm/phydm_noisemonitor.o\
+								hal/phydm/phydm_beamforming.o\
+								hal/phydm/phydm_dfs.o\
+								hal/phydm/txbf/halcomtxbf.o\
+								hal/phydm/txbf/haltxbfinterface.o\
+								hal/phydm/txbf/phydm_hal_txbf_api.o\
+								hal/phydm/phydm_adc_sampling.o\
+								hal/phydm/phydm_ccx.o\
+								hal/phydm/phydm_psd.o\
+								hal/phydm/phydm_primary_cca.o\
+								hal/phydm/phydm_cck_pd.o\
+								hal/phydm/phydm_rssi_monitor.o\
+								hal/phydm/phydm_auto_dbg.o\
+								hal/phydm/phydm_math_lib.o\
+								hal/phydm/phydm_api.o\
+								hal/phydm/phydm_pow_train.o\
+								hal/phydm/halrf/halrf.o\
+								hal/phydm/halrf/halphyrf_ce.o\
+								hal/phydm/halrf/halrf_powertracking_ce.o\
+								hal/phydm/halrf/halrf_powertracking.o\
+								hal/phydm/halrf/halrf_kfree.o
+		
+ifeq ($(CONFIG_RTL8188E), y)
+RTL871X = rtl8188e
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8188e_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8188e_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8188e_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8188e_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8188e.o\
+								hal/phydm/$(RTL871X)/hal8188erateadaptive.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8188e.o
+endif
+
+ifeq ($(CONFIG_RTL8192E), y)
+RTL871X = rtl8192e
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8192e_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8192e_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8192e_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8192e_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8192e.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8192e.o
+endif
+
+
+ifeq ($(CONFIG_RTL8812A), y)
+RTL871X = rtl8812a
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8812a_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8812a_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8812a_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8812a_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8812a.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8812a.o\
+								hal/phydm/txbf/haltxbfjaguar.o
+endif
+
+ifeq ($(CONFIG_RTL8821A), y)
+RTL871X = rtl8821a
+_PHYDM_FILES += hal/phydm/rtl8821a/halhwimg8821a_mac.o\
+								hal/phydm/rtl8821a/halhwimg8821a_bb.o\
+								hal/phydm/rtl8821a/halhwimg8821a_rf.o\
+								hal/phydm/halrf/rtl8812a/halrf_8812a_ce.o\
+								hal/phydm/halrf/rtl8821a/halrf_8821a_ce.o\
+								hal/phydm/rtl8821a/phydm_regconfig8821a.o\
+								hal/phydm/rtl8821a/phydm_rtl8821a.o\
+								hal/phydm/halrf/rtl8821a/halrf_iqk_8821a_ce.o\
+								hal/phydm/txbf/haltxbfjaguar.o
+endif
+
+
+ifeq ($(CONFIG_RTL8723B), y)
+RTL871X = rtl8723b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8723b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_rf.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_mp.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8723b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8723b_ce.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8723b.o
+endif
+
+
+ifeq ($(CONFIG_RTL8814A), y)
+RTL871X = rtl8814a
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8814a_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8814a_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8814a_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8814a.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8814a.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8814a_ce.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8814a.o\
+								hal/phydm/txbf/haltxbf8814a.o
+endif
+
+
+ifeq ($(CONFIG_RTL8723C), y)
+RTL871X = rtl8703b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8703b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8703b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8703b_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8703b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8703b.o
+endif
+
+ifeq ($(CONFIG_RTL8723D), y)
+RTL871X = rtl8723d
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8723d_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8723d_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8723d_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8723d.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8723d.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8723d.o
+endif
+
+
+ifeq ($(CONFIG_RTL8188F), y)
+RTL871X = rtl8188f
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8188f_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8188f_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8188f_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8188f.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8188f.o \
+								hal/phydm/$(RTL871X)/phydm_rtl8188f.o
+endif
+
+ifeq ($(CONFIG_RTL8822B), y)
+RTL871X = rtl8822b
+_PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8822b_bb.o \
+								hal/phydm/$(RTL871X)/halhwimg8822b_mac.o \
+								hal/phydm/$(RTL871X)/halhwimg8822b_rf.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_8822b.o \
+								hal/phydm/$(RTL871X)/phydm_hal_api8822b.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8822b.o \
+								hal/phydm/$(RTL871X)/phydm_regconfig8822b.o \
+								hal/phydm/$(RTL871X)/phydm_rtl8822b.o
+
+_PHYDM_FILES +=	hal/phydm/txbf/haltxbf8822b.o
+endif
+
+
+ifeq ($(CONFIG_RTL8821C), y)
+RTL871X = rtl8821c
+_PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8821c_bb.o \
+								hal/phydm/$(RTL871X)/halhwimg8821c_mac.o \
+								hal/phydm/$(RTL871X)/halhwimg8821c_rf.o \
+								hal/phydm/$(RTL871X)/phydm_hal_api8821c.o \
+								hal/phydm/$(RTL871X)/phydm_regconfig8821c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8821c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8821c.o
+endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.c
index 4b607ce0463b..a78d6cb7aedb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.c
@@ -1,1306 +1,1153 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-
-u1Byte
-ODM_GetAutoChannelSelectResult(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Band
-)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PACS					pACS = &pDM_Odm->DM_ACS;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	if(Band == ODM_BAND_2_4G)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("[ACS] ODM_GetAutoChannelSelectResult(): CleanChannel_2G(%d)\n", pACS->CleanChannel_2G));
-		return (u1Byte)pACS->CleanChannel_2G;	
-	}
-	else
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("[ACS] ODM_GetAutoChannelSelectResult(): CleanChannel_5G(%d)\n", pACS->CleanChannel_5G));
-		return (u1Byte)pACS->CleanChannel_5G;	
-	}
-#else
-	return (u1Byte)pACS->CleanChannel_2G;
-#endif
-
-}
-
-VOID
-odm_AutoChannelSelectSetting(
-	IN		PVOID			pDM_VOID,
-	IN		BOOLEAN			IsEnable
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte						period = 0x2710;// 40ms in default
-	u2Byte						NHMType = 0x7;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("odm_AutoChannelSelectSetting()=========> \n"));
-
-	if(IsEnable)
-	{//20 ms
-		period = 0x1388;
-		NHMType = 0x1;
-	}
-
-	if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-	{
-		//PHY parameters initialize for ac series
-		ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TIMER_11AC+2, period);	//0x990[31:16]=0x2710	Time duration for NHM unit: 4us, 0x2710=40ms
-		//ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC, BIT8|BIT9|BIT10, NHMType);	//0x994[9:8]=3			enable CCX
-	}
-	else if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-	{
-		//PHY parameters initialize for n series
-		ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TIMER_11N+2, period);	//0x894[31:16]=0x2710	Time duration for NHM unit: 4us, 0x2710=40ms
-		//ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N, BIT10|BIT9|BIT8, NHMType);	//0x890[9:8]=3			enable CCX		
-	}
-#endif
-}
-
-VOID
-odm_AutoChannelSelectInit(
-	IN		PVOID			pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PACS						pACS = &pDM_Odm->DM_ACS;
-	u1Byte						i;
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_NHM_CNT))
-		return;
-
-	if(pACS->bForceACSResult)
-		return;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("odm_AutoChannelSelectInit()=========> \n"));
-
-	pACS->CleanChannel_2G = 1;
-	pACS->CleanChannel_5G = 36;
-
-	for (i = 0; i < ODM_MAX_CHANNEL_2G; ++i)
-	{
-		pACS->Channel_Info_2G[0][i] = 0;
-		pACS->Channel_Info_2G[1][i] = 0;
-	}
-
-	if(pDM_Odm->SupportICType & (ODM_IC_11AC_SERIES|ODM_RTL8192D))
-	{
-		for (i = 0; i < ODM_MAX_CHANNEL_5G; ++i)
-		{
-			pACS->Channel_Info_5G[0][i] = 0;
-			pACS->Channel_Info_5G[1][i] = 0;
-		}
-	}
-#endif
-}
-
-VOID
-odm_AutoChannelSelectReset(
-	IN		PVOID			pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PACS						pACS = &pDM_Odm->DM_ACS;
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_NHM_CNT))
-		return;
-
-	if(pACS->bForceACSResult)
-		return;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("odm_AutoChannelSelectReset()=========> \n"));
-
-	odm_AutoChannelSelectSetting(pDM_Odm,TRUE);// for 20ms measurement
-	Phydm_NHMCounterStatisticsReset(pDM_Odm);
-#endif
-}
-
-VOID
-odm_AutoChannelSelect(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Channel
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PACS						pACS = &pDM_Odm->DM_ACS;
-	u1Byte						ChannelIDX = 0, SearchIDX = 0;
-	u2Byte						MaxScore=0;
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_NHM_CNT))
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_AutoChannelSelect(): Return: SupportAbility ODM_BB_NHM_CNT is disabled\n"));
-		return;
-	}
-
-	if(pACS->bForceACSResult)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_AutoChannelSelect(): Force 2G clean channel = %d, 5G clean channel = %d\n",
-			pACS->CleanChannel_2G, pACS->CleanChannel_5G));
-		return;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("odm_AutoChannelSelect(): Channel = %d=========> \n", Channel));
-
-	Phydm_GetNHMCounterStatistics(pDM_Odm);
-	odm_AutoChannelSelectSetting(pDM_Odm,FALSE);
-
-	if(Channel >=1 && Channel <=14)
-	{
-		ChannelIDX = Channel - 1;
-		pACS->Channel_Info_2G[1][ChannelIDX]++;
-		
-		if(pACS->Channel_Info_2G[1][ChannelIDX] >= 2)
-			pACS->Channel_Info_2G[0][ChannelIDX] = (pACS->Channel_Info_2G[0][ChannelIDX] >> 1) + 
-			(pACS->Channel_Info_2G[0][ChannelIDX] >> 2) + (pDM_Odm->NHM_cnt_0>>2);
-		else
-			pACS->Channel_Info_2G[0][ChannelIDX] = pDM_Odm->NHM_cnt_0;
-	
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("odm_AutoChannelSelect(): NHM_cnt_0 = %d \n", pDM_Odm->NHM_cnt_0));
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("odm_AutoChannelSelect(): Channel_Info[0][%d] = %d, Channel_Info[1][%d] = %d\n", ChannelIDX, pACS->Channel_Info_2G[0][ChannelIDX], ChannelIDX, pACS->Channel_Info_2G[1][ChannelIDX]));
-
-		for(SearchIDX = 0; SearchIDX < ODM_MAX_CHANNEL_2G; SearchIDX++)
-		{
-			if(pACS->Channel_Info_2G[1][SearchIDX] != 0)
-			{
-				if(pACS->Channel_Info_2G[0][SearchIDX] >= MaxScore)
-				{
-					MaxScore = pACS->Channel_Info_2G[0][SearchIDX];
-					pACS->CleanChannel_2G = SearchIDX+1;
-				}
-			}
-		}
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("(1)odm_AutoChannelSelect(): 2G: CleanChannel_2G = %d, MaxScore = %d \n", 
-			pACS->CleanChannel_2G, MaxScore));
-
-	}
-	else if(Channel >= 36)
-	{
-		// Need to do
-		pACS->CleanChannel_5G = Channel;
-	}
-#endif
-}
-
-#if ( DM_ODM_SUPPORT_TYPE & ODM_AP )
-
-VOID
-phydm_AutoChannelSelectSettingAP(
-    IN  PVOID   pDM_VOID,
-    IN  u4Byte  setting,             // 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING
-    IN  u4Byte  acs_step
-)
-{
-    PDM_ODM_T           pDM_Odm = (PDM_ODM_T)pDM_VOID;
-    prtl8192cd_priv       priv           = pDM_Odm->priv;
-    PACS                    pACS         = &pDM_Odm->DM_ACS;
-
-    ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("odm_AutoChannelSelectSettingAP()=========> \n"));
-
-    //3 Store Default Setting
-    if(setting == STORE_DEFAULT_NHM_SETTING)
-    {
-        ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("STORE_DEFAULT_NHM_SETTING\n"));
-    
-        if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)     // store Reg0x990, Reg0x994, Reg0x998, Reg0x99C, Reg0x9a0
-        {
-            pACS->Reg0x990 = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TIMER_11AC);                // Reg0x990
-            pACS->Reg0x994 = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC);           // Reg0x994
-            pACS->Reg0x998 = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11AC);       // Reg0x998
-            pACS->Reg0x99C = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11AC);       // Reg0x99c
-            pACS->Reg0x9A0 = ODM_Read1Byte(pDM_Odm, ODM_REG_NHM_TH8_11AC);                   // Reg0x9a0, u1Byte            
-        }
-        else if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-        {
-            pACS->Reg0x890 = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N);             // Reg0x890
-            pACS->Reg0x894 = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TIMER_11N);                  // Reg0x894
-            pACS->Reg0x898 = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11N);         // Reg0x898
-            pACS->Reg0x89C = ODM_Read4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11N);         // Reg0x89c
-            pACS->Reg0xE28 = ODM_Read1Byte(pDM_Odm, ODM_REG_NHM_TH8_11N);                     // Reg0xe28, u1Byte    
-        }
-    }
-
-    //3 Restore Default Setting
-    else if(setting == RESTORE_DEFAULT_NHM_SETTING)
-    {
-        ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("RESTORE_DEFAULT_NHM_SETTING\n"));
-        
-        if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)     // store Reg0x990, Reg0x994, Reg0x998, Reg0x99C, Reg0x9a0
-        {
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TIMER_11AC,          pACS->Reg0x990);
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC,     pACS->Reg0x994);
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11AC, pACS->Reg0x998);
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11AC, pACS->Reg0x99C);
-            ODM_Write1Byte(pDM_Odm, ODM_REG_NHM_TH8_11AC,             pACS->Reg0x9A0);   
-        }
-        else if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-        {
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N,     pACS->Reg0x890);
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TIMER_11N,          pACS->Reg0x894);
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11N, pACS->Reg0x898);
-            ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11N, pACS->Reg0x89C);
-            ODM_Write1Byte(pDM_Odm, ODM_REG_NHM_TH8_11N,             pACS->Reg0xE28); 
-        }        
-    }
-
-    //3 ACS Setting
-    else if(setting == ACS_NHM_SETTING)
-    {        
-        ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("ACS_NHM_SETTING\n"));
-        u2Byte  period;
-        period = 0x61a8;
-        pACS->ACS_Step = acs_step;
-            
-        if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-        {   
-            //4 Set NHM period, 0x990[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms
-            ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TIMER_11AC+2, period);
-            //4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0
-            ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC,BIT8|BIT9|BIT10, 3);
-            
-            if(pACS->ACS_Step == 0)
-            {
-                //4 Set IGI
-                ODM_SetBBReg(pDM_Odm,0xc50,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x3E);
-                if (get_rf_mimo_mode(priv) != MIMO_1T1R)
-					ODM_SetBBReg(pDM_Odm,0xe50,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x3E);
-                    
-                //4 Set ACS NHM threshold
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x82786e64);
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff8c);
-                ODM_Write1Byte(pDM_Odm, ODM_REG_NHM_TH8_11AC, 0xff);
-                ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC+2, 0xffff);
-                
-            }
-            else if(pACS->ACS_Step == 1)
-            {
-                //4 Set IGI
-                ODM_SetBBReg(pDM_Odm,0xc50,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x2A);
-                if (get_rf_mimo_mode(priv) != MIMO_1T1R)
-					ODM_SetBBReg(pDM_Odm,0xe50,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x2A);
-
-                //4 Set ACS NHM threshold
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x5a50463c);
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff64);
-                
-            }
-
-        }
-        else if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-        {
-            //4 Set NHM period, 0x894[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms
-            ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TIMER_11N+2, period);
-            //4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0
-            ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N,BIT8|BIT9|BIT10, 3);
-            
-            if(pACS->ACS_Step == 0)
-            {
-                //4 Set IGI
-                ODM_SetBBReg(pDM_Odm,0xc50,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x3E);
-                if (get_rf_mimo_mode(priv) != MIMO_1T1R)
-					ODM_SetBBReg(pDM_Odm,0xc58,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x3E);
-            
-                //4 Set ACS NHM threshold
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x82786e64);
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff8c);
-                ODM_Write1Byte(pDM_Odm, ODM_REG_NHM_TH8_11N, 0xff);
-                ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N+2, 0xffff);
-                
-            }
-            else if(pACS->ACS_Step == 1)
-            {
-                //4 Set IGI
-                ODM_SetBBReg(pDM_Odm,0xc50,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x2A);
-                if (get_rf_mimo_mode(priv) != MIMO_1T1R)
-					ODM_SetBBReg(pDM_Odm,0xc58,BIT0|BIT1|BIT2|BIT3|BIT4|BIT5|BIT6,0x2A);
-            
-                //4 Set ACS NHM threshold
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x5a50463c);
-                ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff64);
-
-            }            
-        }
-    }	
-	
-}
-
-VOID
-phydm_GetNHMStatisticsAP(
-    IN  PVOID       pDM_VOID,
-    IN  u4Byte      idx,                // @ 2G, Real channel number = idx+1
-    IN  u4Byte      acs_step
-)
-{
-    PDM_ODM_T	    pDM_Odm = (PDM_ODM_T)pDM_VOID;
-    prtl8192cd_priv     priv    = pDM_Odm->priv;
-    PACS                  pACS    = &pDM_Odm->DM_ACS;
-    u4Byte                value32 = 0;
-    u1Byte                i;
-
-    pACS->ACS_Step = acs_step;
-
-    if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-    {
-        //4 Check if NHM result is ready        
-        for (i=0; i<20; i++) {
-            
-            ODM_delay_ms(1);
-            if ( ODM_GetBBReg(pDM_Odm,rFPGA0_PSDReport,BIT17) )
-                break;
-        }
-        
-        //4 Get NHM Statistics        
-        if ( pACS->ACS_Step==1 ) {
-            
-            value32 = ODM_Read4Byte(pDM_Odm,ODM_REG_NHM_CNT7_TO_CNT4_11N);
-            
-            pACS->NHM_Cnt[idx][9] = (value32 & bMaskByte1) >> 8;
-            pACS->NHM_Cnt[idx][8] = (value32 & bMaskByte0);
-
-            value32 = ODM_Read4Byte(pDM_Odm,ODM_REG_NHM_CNT_11N);    // ODM_REG_NHM_CNT3_TO_CNT0_11N
-
-            pACS->NHM_Cnt[idx][7] = (value32 & bMaskByte3) >> 24;
-            pACS->NHM_Cnt[idx][6] = (value32 & bMaskByte2) >> 16;
-            pACS->NHM_Cnt[idx][5] = (value32 & bMaskByte1) >> 8;
-
-        } else if (pACS->ACS_Step==2) {
-        
-            value32 = ODM_Read4Byte(pDM_Odm,ODM_REG_NHM_CNT_11N);   // ODM_REG_NHM_CNT3_TO_CNT0_11N
-
-            pACS->NHM_Cnt[idx][4] = ODM_Read1Byte(pDM_Odm, ODM_REG_NHM_CNT7_TO_CNT4_11N);            
-            pACS->NHM_Cnt[idx][3] = (value32 & bMaskByte3) >> 24;
-            pACS->NHM_Cnt[idx][2] = (value32 & bMaskByte2) >> 16;
-            pACS->NHM_Cnt[idx][1] = (value32 & bMaskByte1) >> 8;
-            pACS->NHM_Cnt[idx][0] = (value32 & bMaskByte0);
-        }
-    }
-    else if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-    {
-        //4 Check if NHM result is ready        
-        for (i=0; i<20; i++) {
-            
-            ODM_delay_ms(1);
-            if (ODM_GetBBReg(pDM_Odm,ODM_REG_NHM_DUR_READY_11AC,BIT17))
-                break;
-        }
-    
-        if ( pACS->ACS_Step==1 ) {
-            
-            value32 = ODM_Read4Byte(pDM_Odm,ODM_REG_NHM_CNT7_TO_CNT4_11AC);
-            
-            pACS->NHM_Cnt[idx][9] = (value32 & bMaskByte1) >> 8;
-            pACS->NHM_Cnt[idx][8] = (value32 & bMaskByte0);
-
-            value32 = ODM_Read4Byte(pDM_Odm,ODM_REG_NHM_CNT_11AC);     // ODM_REG_NHM_CNT3_TO_CNT0_11AC
-
-            pACS->NHM_Cnt[idx][7] = (value32 & bMaskByte3) >> 24;
-            pACS->NHM_Cnt[idx][6] = (value32 & bMaskByte2) >> 16;
-            pACS->NHM_Cnt[idx][5] = (value32 & bMaskByte1) >> 8;
-
-        } else if (pACS->ACS_Step==2) {
-        
-            value32 = ODM_Read4Byte(pDM_Odm,ODM_REG_NHM_CNT_11AC);      // ODM_REG_NHM_CNT3_TO_CNT0_11AC
-
-            pACS->NHM_Cnt[idx][4] = ODM_Read1Byte(pDM_Odm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);            
-            pACS->NHM_Cnt[idx][3] = (value32 & bMaskByte3) >> 24;
-            pACS->NHM_Cnt[idx][2] = (value32 & bMaskByte2) >> 16;
-            pACS->NHM_Cnt[idx][1] = (value32 & bMaskByte1) >> 8;
-            pACS->NHM_Cnt[idx][0] = (value32 & bMaskByte0);
-        }            
-    }
-
-}
-
-
-//#define ACS_DEBUG_INFO //acs debug default off
-/*
-int phydm_AutoChannelSelectAP( 
-    IN   PVOID   pDM_VOID,
-    IN   u4Byte  ACS_Type,                      // 0: RXCount_Type, 1:NHM_Type
-    IN   u4Byte  available_chnl_num        // amount of all channels
-    )
-{
-    PDM_ODM_T               pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PACS                    pACS    = &pDM_Odm->DM_ACS;
-    prtl8192cd_priv			priv    = pDM_Odm->priv;
-    
-    static u4Byte           score2G[MAX_2G_CHANNEL_NUM], score5G[MAX_5G_CHANNEL_NUM];
-    u4Byte                  score[MAX_BSS_NUM], use_nhm = 0;
-    u4Byte                  minScore=0xffffffff;
-    u4Byte                  tmpScore, tmpIdx=0;
-    u4Byte                  traffic_check = 0;
-    u4Byte                  fa_count_weighting = 1;
-    int                     i, j, idx=0, idx_2G_end=-1, idx_5G_begin=-1, minChan=0;
-	struct bss_desc *pBss=NULL;
-
-#ifdef _DEBUG_RTL8192CD_
-	char tmpbuf[400];
-	int len=0;
-#endif
-
-	memset(score2G, '\0', sizeof(score2G));
-	memset(score5G, '\0', sizeof(score5G));
-
-	for (i=0; i<priv->available_chnl_num; i++) {
-		if (priv->available_chnl[i] <= 14)
-			idx_2G_end = i;
-		else
-			break;
-	}
-
-	for (i=0; i<priv->available_chnl_num; i++) {
-		if (priv->available_chnl[i] > 14) {
-			idx_5G_begin = i;
-			break;
-		}
-	}
-
-// DELETE
-#ifndef CONFIG_RTL_NEW_AUTOCH
-	for (i=0; i<priv->site_survey->count; i++) {
-		pBss = &priv->site_survey->bss[i];
-		for (idx=0; idx<priv->available_chnl_num; idx++) {
-			if (pBss->channel == priv->available_chnl[idx]) {
-				if (pBss->channel <= 14)
-					setChannelScore(idx, score2G, 0, MAX_2G_CHANNEL_NUM-1);
-				else
-					score5G[idx - idx_5G_begin] += 5;
-				break;
-			}
-		}
-	}
-#endif
-
-	if (idx_2G_end >= 0)
-		for (i=0; i<=idx_2G_end; i++)
-			score[i] = score2G[i];
-	if (idx_5G_begin >= 0)
-		for (i=idx_5G_begin; i<priv->available_chnl_num; i++)
-			score[i] = score5G[i - idx_5G_begin];
-		
-#ifdef CONFIG_RTL_NEW_AUTOCH
-	{
-		u4Byte y, ch_begin=0, ch_end= priv->available_chnl_num;
-
-		u4Byte do_ap_check = 1, ap_ratio = 0;
-		
-		if (idx_2G_end >= 0) 
-			ch_end = idx_2G_end+1;
-		if (idx_5G_begin >= 0)  
-			ch_begin = idx_5G_begin;
-
-#ifdef ACS_DEBUG_INFO//for debug
-		printk("\n");
-		for (y=ch_begin; y<ch_end; y++)
-			printk("1. init: chnl[%d] 20M_rx[%d] 40M_rx[%d] fa_cnt[%d] score[%d]\n",
-				priv->available_chnl[y], 
-				priv->chnl_ss_mac_rx_count[y], 
-				priv->chnl_ss_mac_rx_count_40M[y],
-				priv->chnl_ss_fa_count[y],
-				score[y]);
-		printk("\n");
-#endif
-
-#if defined(CONFIG_RTL_88E_SUPPORT) || defined(CONFIG_WLAN_HAL_8192EE)
-        if( pDM_Odm->SupportICType&(ODM_RTL8188E|ODM_RTL8192E)&& priv->pmib->dot11RFEntry.acs_type )
-		{
-			u4Byte tmp_score[MAX_BSS_NUM];
-			memcpy(tmp_score, score, sizeof(score));
-			if (find_clean_channel(priv, ch_begin, ch_end, tmp_score)) {
-				//memcpy(score, tmp_score, sizeof(score));
-#ifdef _DEBUG_RTL8192CD_
-				printk("!! Found clean channel, select minimum FA channel\n");
-#endif
-				goto USE_CLN_CH;
-			}
-#ifdef _DEBUG_RTL8192CD_
-			printk("!! Not found clean channel, use NHM algorithm\n");
-#endif
-			use_nhm = 1;
-USE_CLN_CH:
-			for (y=ch_begin; y<ch_end; y++) {
-				for (i=0; i<=9; i++) {
-					u4Byte val32 = priv->nhm_cnt[y][i];
-					for (j=0; j<i; j++)
-						val32 *= 3;
-					score[y] += val32;
-				}
-
-#ifdef _DEBUG_RTL8192CD_				
-				printk("nhm_cnt_%d: H<-[ %3d %3d %3d %3d %3d %3d %3d %3d %3d %3d]->L, score: %d\n", 
-					y+1, priv->nhm_cnt[y][9], priv->nhm_cnt[y][8], priv->nhm_cnt[y][7], 
-					priv->nhm_cnt[y][6], priv->nhm_cnt[y][5], priv->nhm_cnt[y][4],
-					priv->nhm_cnt[y][3], priv->nhm_cnt[y][2], priv->nhm_cnt[y][1],
-					priv->nhm_cnt[y][0], score[y]);
-#endif
-			}
-
-			if (!use_nhm)
-				memcpy(score, tmp_score, sizeof(score));
-			
-			goto choose_ch;
-		}
-#endif
-
-            // For each channel, weighting behind channels with MAC RX counter
-            //For each channel, weighting the channel with FA counter
-
-		for (y=ch_begin; y<ch_end; y++) {
-			score[y] += 8 * priv->chnl_ss_mac_rx_count[y];
-			if (priv->chnl_ss_mac_rx_count[y] > 30)
-				do_ap_check = 0;
-			if( priv->chnl_ss_mac_rx_count[y] > MAC_RX_COUNT_THRESHOLD )
-				traffic_check = 1;
-			
-#ifdef RTK_5G_SUPPORT
-			if (priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_2G)
-#endif
-			{
-				if ((int)(y-4) >= (int)ch_begin)
-					score[y-4] += 2 * priv->chnl_ss_mac_rx_count[y];				
-				if ((int)(y-3) >= (int)ch_begin)
-					score[y-3] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y-2) >= (int)ch_begin)
-					score[y-2] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y-1) >= (int)ch_begin)
-					score[y-1] += 10 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y+1) < (int)ch_end)
-					score[y+1] += 10 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y+2) < (int)ch_end)
-					score[y+2] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y+3) < (int)ch_end)
-					score[y+3] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y+4) < (int)ch_end)
-					score[y+4] += 2 * priv->chnl_ss_mac_rx_count[y];
-			}
-
-			//this is for CH_LOAD caculation
-			if( priv->chnl_ss_cca_count[y] > priv->chnl_ss_fa_count[y])
-				priv->chnl_ss_cca_count[y]-= priv->chnl_ss_fa_count[y];
-			else
-				priv->chnl_ss_cca_count[y] = 0;
-		}
-
-#ifdef ACS_DEBUG_INFO//for debug
-		printk("\n");
-		for (y=ch_begin; y<ch_end; y++)
-			printk("2. after 20M check: chnl[%d] score[%d]\n",priv->available_chnl[y], score[y]);
-		printk("\n");
-#endif	
-
-		for (y=ch_begin; y<ch_end; y++) {
-			if (priv->chnl_ss_mac_rx_count_40M[y]) {
-				score[y] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-				if (priv->chnl_ss_mac_rx_count_40M[y] > 30)
-					do_ap_check = 0;
-				if( priv->chnl_ss_mac_rx_count_40M[y] > MAC_RX_COUNT_THRESHOLD )
-					traffic_check = 1;
-				
-#ifdef RTK_5G_SUPPORT
-				if (priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_2G)
-#endif
-				{
-					if ((int)(y-6) >= (int)ch_begin)
-						score[y-6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y-5) >= (int)ch_begin)
-						score[y-5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y-4) >= (int)ch_begin)
-						score[y-4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y-3) >= (int)ch_begin)
-						score[y-3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y-2) >= (int)ch_begin)
-						score[y-2] += (5 * priv->chnl_ss_mac_rx_count_40M[y])/2;
-					if ((int)(y-1) >= (int)ch_begin)
-						score[y-1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y+1) < (int)ch_end)
-						score[y+1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y+2) < (int)ch_end)
-						score[y+2] += (5 * priv->chnl_ss_mac_rx_count_40M[y])/2;
-					if ((int)(y+3) < (int)ch_end)
-						score[y+3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y+4) < (int)ch_end)
-						score[y+4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y+5) < (int)ch_end)
-						score[y+5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y+6) < (int)ch_end)
-						score[y+6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
-				}
-			}
-		}
-
-#ifdef ACS_DEBUG_INFO//for debug
-		printk("\n");
-		for (y=ch_begin; y<ch_end; y++)
-			printk("3. after 40M check: chnl[%d] score[%d]\n",priv->available_chnl[y], score[y]);
-		printk("\n");
-		printk("4. do_ap_check=%d traffic_check=%d\n", do_ap_check, traffic_check);
-		printk("\n");
-#endif
-
-		if( traffic_check == 0)
-			fa_count_weighting = 5;
-		else
-			fa_count_weighting = 1;
-
-		for (y=ch_begin; y<ch_end; y++) {
-			score[y] += fa_count_weighting * priv->chnl_ss_fa_count[y];
-		}
-
-#ifdef ACS_DEBUG_INFO//for debug
-		printk("\n");
-		for (y=ch_begin; y<ch_end; y++)
-			printk("5. after fa check: chnl[%d] score[%d]\n",priv->available_chnl[y], score[y]);
-		printk("\n");
-#endif			
-
-		if (do_ap_check) {
-			for (i=0; i<priv->site_survey->count; i++) {				
-				pBss = &priv->site_survey->bss[i];
-				for (y=ch_begin; y<ch_end; y++) {
-					if (pBss->channel == priv->available_chnl[y]) {
-						if (pBss->channel <= 14) {
-#ifdef ACS_DEBUG_INFO//for debug
-						printk("\n");
-						printk("chnl[%d] has ap rssi=%d bw[0x%02x]\n",
-							pBss->channel, pBss->rssi, pBss->t_stamp[1]);
-						printk("\n");
-#endif
-							if (pBss->rssi > 60)
-								ap_ratio = 4;
-							else if (pBss->rssi > 35)
-								ap_ratio = 2;
-							else
-								ap_ratio = 1;
-							
-							if ((pBss->t_stamp[1] & 0x6) == 0) {
-								score[y] += 50 * ap_ratio;
-								if ((int)(y-4) >= (int)ch_begin)
-									score[y-4] += 10 * ap_ratio;
-								if ((int)(y-3) >= (int)ch_begin)
-									score[y-3] += 20 * ap_ratio;
-								if ((int)(y-2) >= (int)ch_begin)
-									score[y-2] += 30 * ap_ratio;
-								if ((int)(y-1) >= (int)ch_begin)
-									score[y-1] += 40 * ap_ratio;
-								if ((int)(y+1) < (int)ch_end)
-									score[y+1] += 40 * ap_ratio;
-								if ((int)(y+2) < (int)ch_end)
-									score[y+2] += 30 * ap_ratio;
-								if ((int)(y+3) < (int)ch_end)
-									score[y+3] += 20 * ap_ratio;
-								if ((int)(y+4) < (int)ch_end)
-									score[y+4] += 10 * ap_ratio;
-							}	
-							else if ((pBss->t_stamp[1] & 0x4) == 0) {
-								score[y] += 50 * ap_ratio;
-								if ((int)(y-3) >= (int)ch_begin)
-									score[y-3] += 20 * ap_ratio;
-								if ((int)(y-2) >= (int)ch_begin)
-									score[y-2] += 30 * ap_ratio;
-								if ((int)(y-1) >= (int)ch_begin)
-									score[y-1] += 40 * ap_ratio;
-								if ((int)(y+1) < (int)ch_end)
-									score[y+1] += 50 * ap_ratio;
-								if ((int)(y+2) < (int)ch_end)
-									score[y+2] += 50 * ap_ratio;
-								if ((int)(y+3) < (int)ch_end)
-									score[y+3] += 50 * ap_ratio;
-								if ((int)(y+4) < (int)ch_end)
-									score[y+4] += 50 * ap_ratio;
-								if ((int)(y+5) < (int)ch_end)
-									score[y+5] += 40 * ap_ratio;
-								if ((int)(y+6) < (int)ch_end)
-									score[y+6] += 30 * ap_ratio;
-								if ((int)(y+7) < (int)ch_end)
-									score[y+7] += 20 * ap_ratio;	
-							}	
-							else {
-								score[y] += 50 * ap_ratio;
-								if ((int)(y-7) >= (int)ch_begin)
-									score[y-7] += 20 * ap_ratio;
-								if ((int)(y-6) >= (int)ch_begin)
-									score[y-6] += 30 * ap_ratio;
-								if ((int)(y-5) >= (int)ch_begin)
-									score[y-5] += 40 * ap_ratio;
-								if ((int)(y-4) >= (int)ch_begin)
-									score[y-4] += 50 * ap_ratio;
-								if ((int)(y-3) >= (int)ch_begin)
-									score[y-3] += 50 * ap_ratio;
-								if ((int)(y-2) >= (int)ch_begin)
-									score[y-2] += 50 * ap_ratio;
-								if ((int)(y-1) >= (int)ch_begin)
-									score[y-1] += 50 * ap_ratio;
-								if ((int)(y+1) < (int)ch_end)
-									score[y+1] += 40 * ap_ratio;
-								if ((int)(y+2) < (int)ch_end)
-									score[y+2] += 30 * ap_ratio;
-								if ((int)(y+3) < (int)ch_end)
-									score[y+3] += 20 * ap_ratio;
-							}	
-						}	
-						else {
-							if ((pBss->t_stamp[1] & 0x6) == 0) {
-								score[y] += 500;
-							}
-							else if ((pBss->t_stamp[1] & 0x4) == 0) {
-								score[y] += 500;
-								if ((int)(y+1) < (int)ch_end)
-									score[y+1] += 500;
-							}
-							else {	
-								score[y] += 500;
-								if ((int)(y-1) >= (int)ch_begin)
-									score[y-1] += 500;
-							}
-						}
-						break;
-					}
-				}
-			}
-		}
-
-#ifdef ACS_DEBUG_INFO//for debug
-		printk("\n");
-		for (y=ch_begin; y<ch_end; y++)
-			printk("6. after ap check: chnl[%d]:%d\n", priv->available_chnl[y],score[y]);
-		printk("\n");
-#endif		
-
-#ifdef 	SS_CH_LOAD_PROC
-
-		// caculate noise level -- suggested by wilson
-		for (y=ch_begin; y<ch_end; y++)  {
-			int fa_lv=0, cca_lv=0;
-			if (priv->chnl_ss_fa_count[y]>1000) {
-				fa_lv = 100;
-			} else if (priv->chnl_ss_fa_count[y]>500) {
-				fa_lv = 34 * (priv->chnl_ss_fa_count[y]-500) / 500 + 66;
-			} else if (priv->chnl_ss_fa_count[y]>200) {
-				fa_lv = 33 * (priv->chnl_ss_fa_count[y] - 200) / 300 + 33;
-			} else if (priv->chnl_ss_fa_count[y]>100) {
-				fa_lv = 18 * (priv->chnl_ss_fa_count[y] - 100) / 100 + 15;
-			} else {
-				fa_lv = 15 * priv->chnl_ss_fa_count[y] / 100;
-			} 
-			if (priv->chnl_ss_cca_count[y]>400) {
-				cca_lv = 100;
-			} else if (priv->chnl_ss_cca_count[y]>200) {
-				cca_lv = 34 * (priv->chnl_ss_cca_count[y] - 200) / 200 + 66;
-			} else if (priv->chnl_ss_cca_count[y]>80) {
-				cca_lv = 33 * (priv->chnl_ss_cca_count[y] - 80) / 120 + 33;
-			} else if (priv->chnl_ss_cca_count[y]>40) {
-				cca_lv = 18 * (priv->chnl_ss_cca_count[y] - 40) / 40 + 15;
-			} else {
-				cca_lv = 15 * priv->chnl_ss_cca_count[y] / 40;
-			}
-
-			priv->chnl_ss_load[y] = (((fa_lv > cca_lv)? fa_lv : cca_lv)*75+((score[y]>100)?100:score[y])*25)/100;
-
-			DEBUG_INFO("ch:%d f=%d (%d), c=%d (%d), fl=%d, cl=%d, sc=%d, cu=%d\n", 
-					priv->available_chnl[y],
-					priv->chnl_ss_fa_count[y], fa_thd,
-					priv->chnl_ss_cca_count[y], cca_thd,
-					fa_lv, 
-					cca_lv,
-					score[y],					
-					priv->chnl_ss_load[y]);
-			
-		}		
-#endif		
-	}
-#endif
-
-choose_ch:
-
-#ifdef DFS
-	// heavy weighted DFS channel
-	if (idx_5G_begin >= 0){
-		for (i=idx_5G_begin; i<priv->available_chnl_num; i++) {
-			if (!priv->pmib->dot11DFSEntry.disable_DFS && is_DFS_channel(priv->available_chnl[i]) 
-			&& (score[i]!= 0xffffffff)){
-					score[i] += 1600; 
-		}
-	}
-	}
-#endif
-
-
-//prevent Auto Channel selecting wrong channel in 40M mode-----------------
-	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
-		&& priv->pshare->is_40m_bw) {
-#if 0
-		if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 1) {
-			//Upper Primary Channel, cannot select the two lowest channels
-			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
-				score[0] = 0xffffffff;
-				score[1] = 0xffffffff;
-				score[2] = 0xffffffff;
-				score[3] = 0xffffffff;
-				score[4] = 0xffffffff;
-
-				score[13] = 0xffffffff;
-				score[12] = 0xffffffff;
-				score[11] = 0xffffffff;
-			}
-
-//			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) {
-//				score[idx_5G_begin] = 0xffffffff;
-//				score[idx_5G_begin + 1] = 0xffffffff;
-//			}
-		}
-		else if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 2) {
-			//Lower Primary Channel, cannot select the two highest channels
-			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
-				score[0] = 0xffffffff;
-				score[1] = 0xffffffff;
-				score[2] = 0xffffffff;
-
-				score[13] = 0xffffffff;
-				score[12] = 0xffffffff;
-				score[11] = 0xffffffff;
-				score[10] = 0xffffffff;
-				score[9] = 0xffffffff;
-			}
-
-//			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) {
-//				score[priv->available_chnl_num - 2] = 0xffffffff;
-//				score[priv->available_chnl_num - 1] = 0xffffffff;
-//			}
-		}
-#endif
-		for (i=0; i<=idx_2G_end; ++i)
-			if (priv->available_chnl[i] == 14)
-				score[i] = 0xffffffff;		// mask chan14
-
-#ifdef RTK_5G_SUPPORT
-		if (idx_5G_begin >= 0) {
-			for (i=idx_5G_begin; i<priv->available_chnl_num; i++) {
-				int ch = priv->available_chnl[i];
-				if(priv->available_chnl[i] > 144) 
-					--ch;
-				if((ch%4) || ch==140 || ch == 164 )	//mask ch 140, ch 165, ch 184...
-					score[i] = 0xffffffff;
-			}
-		}
-#endif
-
-		
-	}
-
-	if (priv->pmib->dot11RFEntry.disable_ch1213) {
-		for (i=0; i<=idx_2G_end; ++i) {
-			int ch = priv->available_chnl[i];
-			if ((ch == 12) || (ch == 13))
-				score[i] = 0xffffffff;
-		}
-	}
-
-	if (((priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_GLOBAL) ||
-			(priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_WORLD_WIDE)) &&
-		 (idx_2G_end >= 11) && (idx_2G_end < 14)) {
-		score[13] = 0xffffffff;	// mask chan14
-		score[12] = 0xffffffff; // mask chan13
-		score[11] = 0xffffffff; // mask chan12
-	}
-	
-//------------------------------------------------------------------
-
-#ifdef _DEBUG_RTL8192CD_
-	for (i=0; i<priv->available_chnl_num; i++) {
-		len += sprintf(tmpbuf+len, "ch%d:%u ", priv->available_chnl[i], score[i]);		
-	}
-	strcat(tmpbuf, "\n");
-	panic_printk("%s", tmpbuf);
-
-#endif
-
-	if ( (priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_5G)
-		&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == HT_CHANNEL_WIDTH_80)) 
-	{
-		for (i=0; i<priv->available_chnl_num; i++) {
-			if (is80MChannel(priv->available_chnl, priv->available_chnl_num, priv->available_chnl[i])) {
-				tmpScore = 0;
-				for (j=0; j<4; j++) {
-					if ((tmpScore != 0xffffffff) && (score[i+j] != 0xffffffff))
-						tmpScore += score[i+j];
-					else
-						tmpScore = 0xffffffff;
-				}
-				tmpScore = tmpScore / 4;
-				if (minScore > tmpScore) {
-					minScore = tmpScore;
-
-					tmpScore = 0xffffffff;
-					for (j=0; j<4; j++) {
-						if (score[i+j] < tmpScore) {
-							tmpScore = score[i+j];
-							tmpIdx = i+j;
-						}
-					}
-
-					idx = tmpIdx;
-				}
-				i += 3;
-			}
-		}
-		if (minScore == 0xffffffff) {
-			// there is no 80M channels
-			priv->pshare->is_40m_bw = HT_CHANNEL_WIDTH_20;
-			for (i=0; i<priv->available_chnl_num; i++) {
-				if (score[i] < minScore) {
-					minScore = score[i];
-					idx = i;
-				}
-			}
-		}
-	}
-	else if( (priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_5G)
-			&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == HT_CHANNEL_WIDTH_20_40))
- 	{
-		for (i=0; i<priv->available_chnl_num; i++) {
-			if(is40MChannel(priv->available_chnl,priv->available_chnl_num,priv->available_chnl[i])) {
-				tmpScore = 0;
-				for(j=0;j<2;j++) {
-					if ((tmpScore != 0xffffffff) && (score[i+j] != 0xffffffff))
-						tmpScore += score[i+j];
-					else
-						tmpScore = 0xffffffff;
-				}
-				tmpScore = tmpScore / 2;
-				if(minScore > tmpScore) {
-					minScore = tmpScore;
-
-					tmpScore = 0xffffffff;
-					for (j=0; j<2; j++) {
-						if (score[i+j] < tmpScore) {
-							tmpScore = score[i+j];
-							tmpIdx = i+j;
-						}
-					}
-
-					idx = tmpIdx;
-				}
-				i += 1;
-			}
-		}
-		if (minScore == 0xffffffff) {
-			// there is no 40M channels
-			priv->pshare->is_40m_bw = HT_CHANNEL_WIDTH_20;
-			for (i=0; i<priv->available_chnl_num; i++) {
-				if (score[i] < minScore) {
-					minScore = score[i];
-					idx = i;
-				}
-			}
-		}
-	}
-	else if( (priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_2G)
-			&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == HT_CHANNEL_WIDTH_20_40)
-			&& (priv->available_chnl_num >= 8) )
-	{
-		u4Byte groupScore[14];
-
-		memset(groupScore, 0xff , sizeof(groupScore));
-		for (i=0; i<priv->available_chnl_num-4; i++) {
-			if (score[i] != 0xffffffff && score[i+4] != 0xffffffff) {
-				groupScore[i] = score[i] + score[i+4];
-				DEBUG_INFO("groupScore, ch %d,%d: %d\n", i+1, i+5, groupScore[i]);
-				if (groupScore[i] < minScore) {
-#ifdef AUTOCH_SS_SPEEDUP
-					if(priv->pmib->miscEntry.autoch_1611_enable)
-					{
-						if(priv->available_chnl[i]==1 || priv->available_chnl[i]==6 || priv->available_chnl[i]==11)
-						{
-							minScore = groupScore[i];
-							idx = i;
-						}
-					}
-					else
-#endif
-					{					
-						minScore = groupScore[i];
-						idx = i;
-					}
-				}
-			}
-		}
-
-		if (score[idx] < score[idx+4]) {
-			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;			
-		} else {
-			idx = idx + 4;
-			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;			
-		}
-	}
-	else 
-	{
-		for (i=0; i<priv->available_chnl_num; i++) {
-			if (score[i] < minScore) {
-#ifdef AUTOCH_SS_SPEEDUP
-				if(priv->pmib->miscEntry.autoch_1611_enable)
-				{
-					if(priv->available_chnl[i]==1 || priv->available_chnl[i]==6 || priv->available_chnl[i]==11)
-					{
-						minScore = score[i];
-						idx = i;
-					}
-				}
-				else
-#endif
-				{				
-					minScore = score[i];
-					idx = i;
-				}
-			}
-		}
-	}
-
-	if (IS_A_CUT_8881A(priv) &&
-		(priv->pmib->dot11nConfigEntry.dot11nUse40M == HT_CHANNEL_WIDTH_80)) {
-		if ((priv->available_chnl[idx] == 36) ||
-			(priv->available_chnl[idx] == 52) ||
-			(priv->available_chnl[idx] == 100) ||
-			(priv->available_chnl[idx] == 116) ||
-			(priv->available_chnl[idx] == 132) ||
-			(priv->available_chnl[idx] == 149) ||
-			(priv->available_chnl[idx] == 165))
-			idx++;
-		else if ((priv->available_chnl[idx] == 48) ||
-			(priv->available_chnl[idx] == 64) ||
-			(priv->available_chnl[idx] == 112) ||
-			(priv->available_chnl[idx] == 128) ||
-			(priv->available_chnl[idx] == 144) ||
-			(priv->available_chnl[idx] == 161) ||
-			(priv->available_chnl[idx] == 177))
-			idx--;
-	}
-
-	minChan = priv->available_chnl[idx];
-
-	// skip channel 14 if don't support ofdm
-	if ((priv->pmib->dot11RFEntry.disable_ch14_ofdm) &&
-			(minChan == 14)) {
-		score[idx] = 0xffffffff;
-		
-		minScore = 0xffffffff;
-		for (i=0; i<priv->available_chnl_num; i++) {
-			if (score[i] < minScore) {
-				minScore = score[i];
-				idx = i;
-			}
-		}
-		minChan = priv->available_chnl[idx];
-	}
-
-#if 0
-	//Check if selected channel available for 80M/40M BW or NOT ?
-	if(priv->pmib->dot11RFEntry.phyBandSelect == PHY_BAND_5G)
-	{
-		if(priv->pmib->dot11nConfigEntry.dot11nUse40M == HT_CHANNEL_WIDTH_80)
-		{
-			if(!is80MChannel(priv->available_chnl,priv->available_chnl_num,minChan))
-			{
-				//printk("BW=80M, selected channel = %d is unavaliable! reduce to 40M\n", minChan);
-				//priv->pmib->dot11nConfigEntry.dot11nUse40M = HT_CHANNEL_WIDTH_20_40;
-				priv->pshare->is_40m_bw = HT_CHANNEL_WIDTH_20_40;
-			}
-		}
-			
-		if(priv->pmib->dot11nConfigEntry.dot11nUse40M == HT_CHANNEL_WIDTH_20_40)
-		{
-			if(!is40MChannel(priv->available_chnl,priv->available_chnl_num,minChan))
-			{
-				//printk("BW=40M, selected channel = %d is unavaliable! reduce to 20M\n", minChan);
-				//priv->pmib->dot11nConfigEntry.dot11nUse40M = HT_CHANNEL_WIDTH_20;
-				priv->pshare->is_40m_bw = HT_CHANNEL_WIDTH_20;
-			}
-		}
-	}
-#endif
-
-#ifdef CONFIG_RTL_NEW_AUTOCH
-	RTL_W32(RXERR_RPT, RXERR_RPT_RST);
-#endif
-
-// auto adjust contro-sideband
-	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
-			&& (priv->pshare->is_40m_bw ==1 || priv->pshare->is_40m_bw ==2)) {
-
-#ifdef RTK_5G_SUPPORT
-		if (priv->pmib->dot11RFEntry.phyBandSelect & PHY_BAND_5G) {
-			if( (minChan>144) ? ((minChan-1)%8) : (minChan%8)) {
-				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
-			} else {
-				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
-			}
-
-		} else
-#endif		
-		{
-#if 0
-#ifdef CONFIG_RTL_NEW_AUTOCH
-			unsigned int ch_max;
-
-			if (priv->available_chnl[idx_2G_end] >= 13)
-				ch_max = 13;
-			else
-				ch_max = priv->available_chnl[idx_2G_end];
-
-			if ((minChan >= 5) && (minChan <= (ch_max-5))) {
-				if (score[minChan+4] > score[minChan-4]) { // what if some channels were cancelled?
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
-				} else {
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
-				}
-			} else
-#endif
-			{
-				if (minChan < 5) {
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
-				}
-				else if (minChan > 7) {
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
-				}
-			}
-#endif
-		}
-	}
-//-----------------------
-
-#if defined(__ECOS) && defined(CONFIG_SDIO_HCI)
-	panic_printk("Auto channel choose ch:%d\n", minChan);
-#else
-#ifdef _DEBUG_RTL8192CD_
-	panic_printk("Auto channel choose ch:%d\n", minChan);
-#endif
-#endif
-#ifdef ACS_DEBUG_INFO//for debug
-	printk("7. minChan:%d 2nd_offset:%d\n", minChan, priv->pshare->offset_2nd_chan);
-#endif
-
-	return minChan;
-}
-*/
-
-#endif
-
-VOID
-phydm_CLMInit(
-	IN		PVOID			pDM_VOID,
-	IN		u2Byte			sampleNum			/*unit : 4us*/
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;		
-
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_TIME_PERIOD_11AC, bMaskLWord, sampleNum);	/*4us sample 1 time*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_11AC, BIT8, 0x1);							/*Enable CCX for CLM*/
-	} else if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_TIME_PERIOD_11N, bMaskLWord, sampleNum);	/*4us sample 1 time*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_11N, BIT8, 0x1);								/*Enable CCX for CLM*/	
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("[%s] : CLM sampleNum = %d\n", __func__, sampleNum));
-		
-}
-
-VOID
-phydm_CLMtrigger(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_11AC, BIT0, 0x0);	/*Trigger CLM*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_11AC, BIT0, 0x1);
-	} else if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_11N, BIT0, 0x0);	/*Trigger CLM*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CLM_11N, BIT0, 0x1);
-	}
-}
-
-BOOLEAN
-phydm_checkCLMready(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			value32 = 0;
-	BOOLEAN			ret = FALSE;
-	
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_CLM_RESULT_11AC, bMaskDWord);				/*make sure CLM calc is ready*/
-	else if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_CLM_READY_11N, bMaskDWord);				/*make sure CLM calc is ready*/
-
-	if (value32 & BIT16)
-		ret = TRUE;
-	else
-		ret = FALSE;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("[%s] : CLM ready = %d\n", __func__, ret));
-
-	return ret;
-}
-
-u2Byte
-phydm_getCLMresult(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			value32 = 0;
-	u2Byte			results = 0;
-	
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_CLM_RESULT_11AC, bMaskDWord);				/*read CLM calc result*/
-	else if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_CLM_RESULT_11N, bMaskDWord);				/*read CLM calc result*/
-
-	results = (u2Byte)(value32 & bMaskLWord);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ACS, ODM_DBG_LOUD, ("[%s] : CLM result = %d\n", __func__, results));
-	
-	return results;
-/*results are number of CCA times in sampleNum*/
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+u8
+odm_get_auto_channel_select_result(
+	void			*dm_void,
+	u8			band
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct acs_info					*acs = &dm->dm_acs;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (band == ODM_BAND_2_4G) {
+		PHYDM_DBG(dm, ODM_COMP_API, "clean_CH_2g=%d\n", acs->clean_channel_2g);
+		return (u8)acs->clean_channel_2g;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "clean_CH_5g=%d\n", acs->clean_channel_5g);
+		return (u8)acs->clean_channel_5g;
+	}
+#else
+	return (u8)acs->clean_channel_2g;
+#endif
+
+}
+
+void
+odm_auto_channel_select_init(
+	void			*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct acs_info						*acs = &dm->dm_acs;
+	u8						i;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	if (acs->is_force_acs_result)
+		return;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	acs->clean_channel_2g = 1;
+	acs->clean_channel_5g = 36;
+
+	for (i = 0; i < ODM_MAX_CHANNEL_2G; ++i) {
+		acs->channel_info_2g[0][i] = 0;
+		acs->channel_info_2g[1][i] = 0;
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		for (i = 0; i < ODM_MAX_CHANNEL_5G; ++i) {
+			acs->channel_info_5g[0][i] = 0;
+			acs->channel_info_5g[1][i] = 0;
+		}
+	}
+#endif
+}
+
+void
+odm_auto_channel_select_reset(
+	void			*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct acs_info						*acs = &dm->dm_acs;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	if (acs->is_force_acs_result)
+		return;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	ccx_info->nhm_period = 0x1388;	/*20ms*/
+	phydm_nhm_setting(dm, SET_NHM_SETTING);
+	phydm_nhm_trigger(dm);
+#endif
+}
+
+void
+odm_auto_channel_select(
+	void			*dm_void,
+	u8			channel
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct acs_info						*acs = &dm->dm_acs;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u8						channel_idx = 0, search_idx = 0;
+	u8						noisy_nhm_th = 0x52;
+	u8						i, noisy_nhm_th_index, low_pwr_cnt = 0;
+	u16						max_score = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR)) {
+		PHYDM_DBG(dm, DBG_DIG, "Return: Not support\n");
+		return;
+	}
+
+	if (acs->is_force_acs_result) {
+		PHYDM_DBG(dm, DBG_DIG, "Force clean CH{2G,5G}={%d,%d}\n",
+			acs->clean_channel_2g, acs->clean_channel_5g);
+		return;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_API, "CH=%d\n", channel);
+
+	phydm_get_nhm_result(dm);
+	noisy_nhm_th_index = (noisy_nhm_th - ccx_info->nhm_th[0]) << 2;
+
+	for (i = 0; i <= 11; i++) {
+		if (i <= noisy_nhm_th_index)
+			low_pwr_cnt += ccx_info->nhm_result[i];
+	}
+
+	ccx_info->nhm_period = 0x2710;
+	phydm_nhm_setting(dm, SET_NHM_SETTING);
+
+	if (channel >= 1 && channel <= 14) {
+		channel_idx = channel - 1;
+		acs->channel_info_2g[1][channel_idx]++;
+
+		if (acs->channel_info_2g[1][channel_idx] >= 2)
+			acs->channel_info_2g[0][channel_idx] = (acs->channel_info_2g[0][channel_idx] >> 1) +
+				(acs->channel_info_2g[0][channel_idx] >> 2) + (low_pwr_cnt >> 2);
+		else
+			acs->channel_info_2g[0][channel_idx] = low_pwr_cnt;
+
+		PHYDM_DBG(dm, ODM_COMP_API, "low_pwr_cnt = %d\n", low_pwr_cnt);
+		PHYDM_DBG(dm, ODM_COMP_API, "CH_Info[0][%d]=%d, CH_Info[1][%d]=%d\n", channel_idx, acs->channel_info_2g[0][channel_idx], channel_idx, acs->channel_info_2g[1][channel_idx]);
+
+		for (search_idx = 0; search_idx < ODM_MAX_CHANNEL_2G; search_idx++) {
+			if (acs->channel_info_2g[1][search_idx] != 0 && acs->channel_info_2g[0][search_idx] >= max_score) {
+				max_score = acs->channel_info_2g[0][search_idx];
+				acs->clean_channel_2g = search_idx + 1;
+			}
+		}
+		PHYDM_DBG(dm, ODM_COMP_API, "clean_CH_2g=%d, max_score=%d\n",
+				acs->clean_channel_2g, max_score);
+
+	} else if (channel >= 36) {
+		/* Need to do */
+		acs->clean_channel_5g = channel;
+	}
+#endif
+}
+
+boolean
+phydm_acs_check(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv		*priv = dm->priv;
+
+	if ((priv->auto_channel != 0) && (priv->auto_channel != 2)) /* if struct acs_info running, do not do FA/CCA counter read */
+		return true;
+	else
+		return false;
+#else
+	return false;
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+void
+phydm_auto_channel_select_setting_ap(
+	void   *dm_void,
+	u32  setting,             /* 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING */
+	u32  acs_step
+)
+{
+	struct dm_struct           *dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv       *priv           = dm->priv;
+	struct acs_info                    *acs         = &dm->dm_acs;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+	/* 3 Store Default setting */
+	if (setting == STORE_DEFAULT_NHM_SETTING) {
+		PHYDM_DBG(dm, ODM_COMP_API, "STORE_DEFAULT_NHM_SETTING\n");
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {  /* store reg0x990, reg0x994, reg0x998, reg0x99c, Reg0x9a0 */
+			acs->reg0x990 = odm_read_4byte(dm, ODM_REG_CCX_PERIOD_11AC);                /* reg0x990 */
+			acs->reg0x994 = odm_read_4byte(dm, ODM_REG_NHM_TH9_TH10_11AC);           /* reg0x994 */
+			acs->reg0x998 = odm_read_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC);       /* reg0x998 */
+			acs->reg0x99c = odm_read_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC);       /* Reg0x99c */
+			acs->reg0x9a0 = odm_read_1byte(dm, ODM_REG_NHM_TH8_11AC);                   /* Reg0x9a0, u8 */
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			acs->reg0x890 = odm_read_4byte(dm, ODM_REG_NHM_TH9_TH10_11N);             /* reg0x890 */
+			acs->reg0x894 = odm_read_4byte(dm, ODM_REG_CCX_PERIOD_11N);                  /* reg0x894 */
+			acs->reg0x898 = odm_read_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N);         /* reg0x898 */
+			acs->reg0x89c = odm_read_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N);         /* Reg0x89c */
+			acs->reg0xe28 = odm_read_1byte(dm, ODM_REG_NHM_TH8_11N);                     /* Reg0xe28, u8 */
+		}
+	}
+
+	/* 3 Restore Default setting */
+	else if (setting == RESTORE_DEFAULT_NHM_SETTING) {
+		PHYDM_DBG(dm, ODM_COMP_API, "RESTORE_DEFAULT_NHM_SETTING\n");
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {  /* store reg0x990, reg0x994, reg0x998, reg0x99c, Reg0x9a0 */
+			odm_write_4byte(dm, ODM_REG_CCX_PERIOD_11AC,          acs->reg0x990);
+			odm_write_4byte(dm, ODM_REG_NHM_TH9_TH10_11AC,     acs->reg0x994);
+			odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, acs->reg0x998);
+			odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, acs->reg0x99c);
+			odm_write_1byte(dm, ODM_REG_NHM_TH8_11AC,             acs->reg0x9a0);
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			odm_write_4byte(dm, ODM_REG_NHM_TH9_TH10_11N,     acs->reg0x890);
+			odm_write_4byte(dm, ODM_REG_CCX_PERIOD_11AC,          acs->reg0x894);
+			odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N, acs->reg0x898);
+			odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N, acs->reg0x89c);
+			odm_write_1byte(dm, ODM_REG_NHM_TH8_11N,             acs->reg0xe28);
+		}
+	}
+
+	/* 3 struct acs_info setting */
+	else if (setting == ACS_NHM_SETTING) {
+		PHYDM_DBG(dm, ODM_COMP_API, "ACS_NHM_SETTING\n");
+		u16  period;
+		period = 0x61a8;
+		acs->acs_step = acs_step;
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			/* 4 Set NHM period, 0x990[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms */
+			odm_write_2byte(dm, ODM_REG_CCX_PERIOD_11AC + 2, period);
+			/* 4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0 */
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(8) | BIT(9) | BIT(10), 3);
+
+			if (acs->acs_step == 0) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xe50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x82786e64);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff8c);
+				odm_write_1byte(dm, ODM_REG_NHM_TH8_11AC, 0xff);
+				odm_write_2byte(dm, ODM_REG_NHM_TH9_TH10_11AC + 2, 0xffff);
+
+			} else if (acs->acs_step == 1) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xe50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x5a50463c);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff64);
+
+			}
+
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			/* 4 Set NHM period, 0x894[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms */
+			odm_write_2byte(dm, ODM_REG_CCX_PERIOD_11AC + 2, period);
+			/* 4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0 */
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(8) | BIT(9) | BIT(10), 3);
+
+			if (acs->acs_step == 0) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xc58, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x82786e64);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff8c);
+				odm_write_1byte(dm, ODM_REG_NHM_TH8_11N, 0xff);
+				odm_write_2byte(dm, ODM_REG_NHM_TH9_TH10_11N + 2, 0xffff);
+
+			} else if (acs->acs_step == 1) {
+				/* 4 Set IGI */
+				odm_set_bb_reg(dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+				if (get_rf_mimo_mode(priv) != RF_1T1R)
+					odm_set_bb_reg(dm, 0xc58, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
+
+				/* 4 Set struct acs_info NHM threshold */
+				odm_write_4byte(dm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x5a50463c);
+				odm_write_4byte(dm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff64);
+
+			}
+		}
+	}
+
+}
+
+void
+phydm_get_nhm_statistics_ap(
+	void       *dm_void,
+	u32      idx,                /* @ 2G, Real channel number = idx+1 */
+	u32      acs_step
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv     *priv    = dm->priv;
+	struct acs_info                  *acs    = &dm->dm_acs;
+	u32                value32 = 0;
+	u8                i;
+
+	acs->acs_step = acs_step;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/* 4 Check if NHM result is ready */
+		for (i = 0; i < 20; i++) {
+			ODM_delay_ms(1);
+			if (odm_get_bb_reg(dm, REG_FPGA0_PSD_REPORT, BIT(17)))
+				break;
+		}
+
+		/* 4 Get NHM Statistics */
+		if (acs->acs_step == 1) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
+
+			acs->nhm_cnt[idx][9] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][8] = (value32 & MASKBYTE0);
+
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11N);   /* ODM_REG_NHM_CNT3_TO_CNT0_11N */
+
+			acs->nhm_cnt[idx][7] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][6] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][5] = (value32 & MASKBYTE1) >> 8;
+
+		} else if (acs->acs_step == 2) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11N);  /* ODM_REG_NHM_CNT3_TO_CNT0_11N */
+
+			acs->nhm_cnt[idx][4] = odm_read_1byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
+			acs->nhm_cnt[idx][3] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][2] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][1] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][0] = (value32 & MASKBYTE0);
+		}
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		/* 4 Check if NHM result is ready */
+		for (i = 0; i < 20; i++) {
+			ODM_delay_ms(1);
+			if (odm_get_bb_reg(dm, ODM_REG_NHM_DUR_READY_11AC, BIT(16)))
+				break;
+		}
+
+		if (acs->acs_step == 1) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
+
+			acs->nhm_cnt[idx][9] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][8] = (value32 & MASKBYTE0);
+
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11AC);    /* ODM_REG_NHM_CNT3_TO_CNT0_11AC */
+
+			acs->nhm_cnt[idx][7] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][6] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][5] = (value32 & MASKBYTE1) >> 8;
+
+		} else if (acs->acs_step == 2) {
+			value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11AC);     /* ODM_REG_NHM_CNT3_TO_CNT0_11AC */
+
+			acs->nhm_cnt[idx][4] = odm_read_1byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
+			acs->nhm_cnt[idx][3] = (value32 & MASKBYTE3) >> 24;
+			acs->nhm_cnt[idx][2] = (value32 & MASKBYTE2) >> 16;
+			acs->nhm_cnt[idx][1] = (value32 & MASKBYTE1) >> 8;
+			acs->nhm_cnt[idx][0] = (value32 & MASKBYTE0);
+		}
+	}
+
+}
+
+
+/* #define ACS_DEBUG_INFO */ /* acs debug default off */
+#if 0
+int phydm_AutoChannelSelectAP(
+	void   *dm_void,
+	u32  ACS_Type,                      /*  0: RXCount_Type, 1:NHM_Type */
+	u32  available_chnl_num        /*  amount of all channels */
+)
+{
+	struct dm_struct               *dm = (struct dm_struct *)dm_void;
+	struct acs_info                    *acs    = &dm->dm_acs;
+	struct rtl8192cd_priv			*priv    = dm->priv;
+
+	static u32           score2G[MAX_2G_CHANNEL_NUM], score5G[MAX_5G_CHANNEL_NUM];
+	u32                  score[MAX_BSS_NUM], use_nhm = 0;
+	u32                  minScore = 0xffffffff;
+	u32                  tmpScore, tmpIdx = 0;
+	u32                  traffic_check = 0;
+	u32                  fa_count_weighting = 1;
+	int                     i, j, idx = 0, idx_2G_end = -1, idx_5G_begin = -1, minChan = 0;
+	struct bss_desc *pBss = NULL;
+
+#ifdef _DEBUG_RTL8192CD_
+	char tmpbuf[400];
+	int len = 0;
+#endif
+
+	memset(score2G, '\0', sizeof(score2G));
+	memset(score5G, '\0', sizeof(score5G));
+
+	for (i = 0; i < priv->available_chnl_num; i++) {
+		if (priv->available_chnl[i] <= 14)
+			idx_2G_end = i;
+		else
+			break;
+	}
+
+	for (i = 0; i < priv->available_chnl_num; i++) {
+		if (priv->available_chnl[i] > 14) {
+			idx_5G_begin = i;
+			break;
+		}
+	}
+
+	/*  DELETE */
+#ifndef CONFIG_RTL_NEW_AUTOCH
+	for (i = 0; i < priv->site_survey->count; i++) {
+		pBss = &priv->site_survey->bss[i];
+		for (idx = 0; idx < priv->available_chnl_num; idx++) {
+			if (pBss->channel == priv->available_chnl[idx]) {
+				if (pBss->channel <= 14)
+					setChannelScore(idx, score2G, 0, MAX_2G_CHANNEL_NUM - 1);
+				else
+					score5G[idx - idx_5G_begin] += 5;
+				break;
+			}
+		}
+	}
+#endif
+
+	if (idx_2G_end >= 0)
+		for (i = 0; i <= idx_2G_end; i++)
+			score[i] = score2G[i];
+	if (idx_5G_begin >= 0)
+		for (i = idx_5G_begin; i < priv->available_chnl_num; i++)
+			score[i] = score5G[i - idx_5G_begin];
+
+#ifdef CONFIG_RTL_NEW_AUTOCH
+	{
+		u32 y, ch_begin = 0, ch_end = priv->available_chnl_num;
+
+		u32 do_ap_check = 1, ap_ratio = 0;
+
+		if (idx_2G_end >= 0)
+			ch_end = idx_2G_end + 1;
+		if (idx_5G_begin >= 0)
+			ch_begin = idx_5G_begin;
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("1. init: chnl[%d] 20M_rx[%d] 40M_rx[%d] fa_cnt[%d] score[%d]\n",
+			       priv->available_chnl[y],
+			       priv->chnl_ss_mac_rx_count[y],
+			       priv->chnl_ss_mac_rx_count_40M[y],
+			       priv->chnl_ss_fa_count[y],
+			       score[y]);
+		printk("\n");
+#endif
+
+#if defined(CONFIG_RTL_88E_SUPPORT) || defined(CONFIG_WLAN_HAL_8192EE)
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E) && priv->pmib->dot11RFEntry.acs_type) {
+			u32 tmp_score[MAX_BSS_NUM];
+			memcpy(tmp_score, score, sizeof(score));
+			if (find_clean_channel(priv, ch_begin, ch_end, tmp_score)) {
+				/* memcpy(score, tmp_score, sizeof(score)); */
+#ifdef _DEBUG_RTL8192CD_
+				printk("!! Found clean channel, select minimum FA channel\n");
+#endif
+				goto USE_CLN_CH;
+			}
+#ifdef _DEBUG_RTL8192CD_
+			printk("!! Not found clean channel, use NHM algorithm\n");
+#endif
+			use_nhm = 1;
+USE_CLN_CH:
+			for (y = ch_begin; y < ch_end; y++) {
+				for (i = 0; i <= 9; i++) {
+					u32 val32 = priv->nhm_cnt[y][i];
+					for (j = 0; j < i; j++)
+						val32 *= 3;
+					score[y] += val32;
+				}
+
+#ifdef _DEBUG_RTL8192CD_
+				printk("nhm_cnt_%d: H<-[ %3d %3d %3d %3d %3d %3d %3d %3d %3d %3d]->L, score: %d\n",
+				       y + 1, priv->nhm_cnt[y][9], priv->nhm_cnt[y][8], priv->nhm_cnt[y][7],
+				       priv->nhm_cnt[y][6], priv->nhm_cnt[y][5], priv->nhm_cnt[y][4],
+				       priv->nhm_cnt[y][3], priv->nhm_cnt[y][2], priv->nhm_cnt[y][1],
+				       priv->nhm_cnt[y][0], score[y]);
+#endif
+			}
+
+			if (!use_nhm)
+				memcpy(score, tmp_score, sizeof(score));
+
+			goto choose_ch;
+		}
+#endif
+
+		/*  For each channel, weighting behind channels with MAC RX counter */
+		/* For each channel, weighting the channel with FA counter */
+
+		for (y = ch_begin; y < ch_end; y++) {
+			score[y] += 8 * priv->chnl_ss_mac_rx_count[y];
+			if (priv->chnl_ss_mac_rx_count[y] > 30)
+				do_ap_check = 0;
+			if (priv->chnl_ss_mac_rx_count[y] > MAC_RX_COUNT_THRESHOLD)
+				traffic_check = 1;
+
+#ifdef RTK_5G_SUPPORT
+			if (*dm->band_type == ODM_BAND_2_4G)
+#endif
+			{
+				if ((int)(y - 4) >= (int)ch_begin)
+					score[y - 4] += 2 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y - 3) >= (int)ch_begin)
+					score[y - 3] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y - 2) >= (int)ch_begin)
+					score[y - 2] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y - 1) >= (int)ch_begin)
+					score[y - 1] += 10 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 1) < (int)ch_end)
+					score[y + 1] += 10 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 2) < (int)ch_end)
+					score[y + 2] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 3) < (int)ch_end)
+					score[y + 3] += 8 * priv->chnl_ss_mac_rx_count[y];
+				if ((int)(y + 4) < (int)ch_end)
+					score[y + 4] += 2 * priv->chnl_ss_mac_rx_count[y];
+			}
+
+			/* this is for CH_LOAD caculation */
+			if (priv->chnl_ss_cca_count[y] > priv->chnl_ss_fa_count[y])
+				priv->chnl_ss_cca_count[y] -= priv->chnl_ss_fa_count[y];
+			else
+				priv->chnl_ss_cca_count[y] = 0;
+		}
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("2. after 20M check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+#endif
+
+		for (y = ch_begin; y < ch_end; y++) {
+			if (priv->chnl_ss_mac_rx_count_40M[y]) {
+				score[y] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+				if (priv->chnl_ss_mac_rx_count_40M[y] > 30)
+					do_ap_check = 0;
+				if (priv->chnl_ss_mac_rx_count_40M[y] > MAC_RX_COUNT_THRESHOLD)
+					traffic_check = 1;
+
+#ifdef RTK_5G_SUPPORT
+				if (*dm->band_type == ODM_BAND_2_4G)
+#endif
+				{
+					if ((int)(y - 6) >= (int)ch_begin)
+						score[y - 6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 5) >= (int)ch_begin)
+						score[y - 5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 4) >= (int)ch_begin)
+						score[y - 4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 3) >= (int)ch_begin)
+						score[y - 3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y - 2) >= (int)ch_begin)
+						score[y - 2] += (5 * priv->chnl_ss_mac_rx_count_40M[y]) / 2;
+					if ((int)(y - 1) >= (int)ch_begin)
+						score[y - 1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 1) < (int)ch_end)
+						score[y + 1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 2) < (int)ch_end)
+						score[y + 2] += (5 * priv->chnl_ss_mac_rx_count_40M[y]) / 2;
+					if ((int)(y + 3) < (int)ch_end)
+						score[y + 3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 4) < (int)ch_end)
+						score[y + 4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 5) < (int)ch_end)
+						score[y + 5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
+					if ((int)(y + 6) < (int)ch_end)
+						score[y + 6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
+				}
+			}
+		}
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("3. after 40M check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+		printk("4. do_ap_check=%d traffic_check=%d\n", do_ap_check, traffic_check);
+		printk("\n");
+#endif
+
+		if (traffic_check == 0)
+			fa_count_weighting = 5;
+		else
+			fa_count_weighting = 1;
+
+		for (y = ch_begin; y < ch_end; y++)
+			score[y] += fa_count_weighting * priv->chnl_ss_fa_count[y];
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("5. after fa check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+#endif
+
+		if (do_ap_check) {
+			for (i = 0; i < priv->site_survey->count; i++) {
+				pBss = &priv->site_survey->bss[i];
+				for (y = ch_begin; y < ch_end; y++) {
+					if (pBss->channel == priv->available_chnl[y]) {
+						if (pBss->channel <= 14) {
+#ifdef ACS_DEBUG_INFO/* for debug */
+							printk("\n");
+							printk("chnl[%d] has ap rssi=%d bw[0x%02x]\n",
+							       pBss->channel, pBss->rssi, pBss->t_stamp[1]);
+							printk("\n");
+#endif
+							if (pBss->rssi > 60)
+								ap_ratio = 4;
+							else if (pBss->rssi > 35)
+								ap_ratio = 2;
+							else
+								ap_ratio = 1;
+
+							if ((pBss->t_stamp[1] & 0x6) == 0) {
+								score[y] += 50 * ap_ratio;
+								if ((int)(y - 4) >= (int)ch_begin)
+									score[y - 4] += 10 * ap_ratio;
+								if ((int)(y - 3) >= (int)ch_begin)
+									score[y - 3] += 20 * ap_ratio;
+								if ((int)(y - 2) >= (int)ch_begin)
+									score[y - 2] += 30 * ap_ratio;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 40 * ap_ratio;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 40 * ap_ratio;
+								if ((int)(y + 2) < (int)ch_end)
+									score[y + 2] += 30 * ap_ratio;
+								if ((int)(y + 3) < (int)ch_end)
+									score[y + 3] += 20 * ap_ratio;
+								if ((int)(y + 4) < (int)ch_end)
+									score[y + 4] += 10 * ap_ratio;
+							} else if ((pBss->t_stamp[1] & 0x4) == 0) {
+								score[y] += 50 * ap_ratio;
+								if ((int)(y - 3) >= (int)ch_begin)
+									score[y - 3] += 20 * ap_ratio;
+								if ((int)(y - 2) >= (int)ch_begin)
+									score[y - 2] += 30 * ap_ratio;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 40 * ap_ratio;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 50 * ap_ratio;
+								if ((int)(y + 2) < (int)ch_end)
+									score[y + 2] += 50 * ap_ratio;
+								if ((int)(y + 3) < (int)ch_end)
+									score[y + 3] += 50 * ap_ratio;
+								if ((int)(y + 4) < (int)ch_end)
+									score[y + 4] += 50 * ap_ratio;
+								if ((int)(y + 5) < (int)ch_end)
+									score[y + 5] += 40 * ap_ratio;
+								if ((int)(y + 6) < (int)ch_end)
+									score[y + 6] += 30 * ap_ratio;
+								if ((int)(y + 7) < (int)ch_end)
+									score[y + 7] += 20 * ap_ratio;
+							} else {
+								score[y] += 50 * ap_ratio;
+								if ((int)(y - 7) >= (int)ch_begin)
+									score[y - 7] += 20 * ap_ratio;
+								if ((int)(y - 6) >= (int)ch_begin)
+									score[y - 6] += 30 * ap_ratio;
+								if ((int)(y - 5) >= (int)ch_begin)
+									score[y - 5] += 40 * ap_ratio;
+								if ((int)(y - 4) >= (int)ch_begin)
+									score[y - 4] += 50 * ap_ratio;
+								if ((int)(y - 3) >= (int)ch_begin)
+									score[y - 3] += 50 * ap_ratio;
+								if ((int)(y - 2) >= (int)ch_begin)
+									score[y - 2] += 50 * ap_ratio;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 50 * ap_ratio;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 40 * ap_ratio;
+								if ((int)(y + 2) < (int)ch_end)
+									score[y + 2] += 30 * ap_ratio;
+								if ((int)(y + 3) < (int)ch_end)
+									score[y + 3] += 20 * ap_ratio;
+							}
+						} else {
+							if ((pBss->t_stamp[1] & 0x6) == 0)
+								score[y] += 500;
+							else if ((pBss->t_stamp[1] & 0x4) == 0) {
+								score[y] += 500;
+								if ((int)(y + 1) < (int)ch_end)
+									score[y + 1] += 500;
+							} else {
+								score[y] += 500;
+								if ((int)(y - 1) >= (int)ch_begin)
+									score[y - 1] += 500;
+							}
+						}
+						break;
+					}
+				}
+			}
+		}
+
+#ifdef ACS_DEBUG_INFO/* for debug */
+		printk("\n");
+		for (y = ch_begin; y < ch_end; y++)
+			printk("6. after ap check: chnl[%d]:%d\n", priv->available_chnl[y], score[y]);
+		printk("\n");
+#endif
+
+#ifdef SS_CH_LOAD_PROC
+
+		/*  caculate noise level -- suggested by wilson */
+		for (y = ch_begin; y < ch_end; y++)  {
+			int fa_lv = 0, cca_lv = 0;
+			if (priv->chnl_ss_fa_count[y] > 1000)
+				fa_lv = 100;
+			else if (priv->chnl_ss_fa_count[y] > 500)
+				fa_lv = 34 * (priv->chnl_ss_fa_count[y] - 500) / 500 + 66;
+			else if (priv->chnl_ss_fa_count[y] > 200)
+				fa_lv = 33 * (priv->chnl_ss_fa_count[y] - 200) / 300 + 33;
+			else if (priv->chnl_ss_fa_count[y] > 100)
+				fa_lv = 18 * (priv->chnl_ss_fa_count[y] - 100) / 100 + 15;
+			else
+				fa_lv = 15 * priv->chnl_ss_fa_count[y] / 100;
+			if (priv->chnl_ss_cca_count[y] > 400)
+				cca_lv = 100;
+			else if (priv->chnl_ss_cca_count[y] > 200)
+				cca_lv = 34 * (priv->chnl_ss_cca_count[y] - 200) / 200 + 66;
+			else if (priv->chnl_ss_cca_count[y] > 80)
+				cca_lv = 33 * (priv->chnl_ss_cca_count[y] - 80) / 120 + 33;
+			else if (priv->chnl_ss_cca_count[y] > 40)
+				cca_lv = 18 * (priv->chnl_ss_cca_count[y] - 40) / 40 + 15;
+			else
+				cca_lv = 15 * priv->chnl_ss_cca_count[y] / 40;
+
+			priv->chnl_ss_load[y] = (((fa_lv > cca_lv) ? fa_lv : cca_lv) * 75 + ((score[y] > 100) ? 100 : score[y]) * 25) / 100;
+
+			DEBUG_INFO("ch:%d f=%d (%d), c=%d (%d), fl=%d, cl=%d, sc=%d, cu=%d\n",
+				   priv->available_chnl[y],
+				   priv->chnl_ss_fa_count[y], fa_thd,
+				   priv->chnl_ss_cca_count[y], cca_thd,
+				   fa_lv,
+				   cca_lv,
+				   score[y],
+				   priv->chnl_ss_load[y]);
+
+		}
+#endif
+	}
+#endif
+
+choose_ch:
+
+#ifdef DFS
+	/*  heavy weighted DFS channel */
+	if (idx_5G_begin >= 0) {
+		for (i = idx_5G_begin; i < priv->available_chnl_num; i++) {
+			if (!priv->pmib->dot11DFSEntry.disable_DFS && is_DFS_channel(priv->available_chnl[i])
+			    && (score[i] != 0xffffffff))
+				score[i] += 1600;
+		}
+	}
+#endif
+
+
+	/* prevent Auto channel selecting wrong channel in 40M mode----------------- */
+	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
+	    && priv->pshare->is_40m_bw) {
+#if 0
+		if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 1) {
+			/* Upper Primary channel, cannot select the two lowest channels */
+			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
+				score[0] = 0xffffffff;
+				score[1] = 0xffffffff;
+				score[2] = 0xffffffff;
+				score[3] = 0xffffffff;
+				score[4] = 0xffffffff;
+
+				score[13] = 0xffffffff;
+				score[12] = 0xffffffff;
+				score[11] = 0xffffffff;
+			}
+
+			/*			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) { */
+			/*				score[idx_5G_begin] = 0xffffffff; */
+			/*				score[idx_5G_begin + 1] = 0xffffffff; */
+			/*			} */
+		} else if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 2) {
+			/* Lower Primary channel, cannot select the two highest channels */
+			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
+				score[0] = 0xffffffff;
+				score[1] = 0xffffffff;
+				score[2] = 0xffffffff;
+
+				score[13] = 0xffffffff;
+				score[12] = 0xffffffff;
+				score[11] = 0xffffffff;
+				score[10] = 0xffffffff;
+				score[9] = 0xffffffff;
+			}
+
+			/*			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) { */
+			/*				score[priv->available_chnl_num - 2] = 0xffffffff; */
+			/*				score[priv->available_chnl_num - 1] = 0xffffffff; */
+			/*			} */
+		}
+#endif
+		for (i = 0; i <= idx_2G_end; ++i)
+			if (priv->available_chnl[i] == 14)
+				score[i] = 0xffffffff;		/*  mask chan14 */
+
+#ifdef RTK_5G_SUPPORT
+		if (idx_5G_begin >= 0) {
+			for (i = idx_5G_begin; i < priv->available_chnl_num; i++) {
+				int ch = priv->available_chnl[i];
+				if (priv->available_chnl[i] > 144)
+					--ch;
+				if ((ch % 4) || ch == 140 || ch == 164)	/* mask ch 140, ch 165, ch 184... */
+					score[i] = 0xffffffff;
+			}
+		}
+#endif
+
+
+	}
+
+	if (priv->pmib->dot11RFEntry.disable_ch1213) {
+		for (i = 0; i <= idx_2G_end; ++i) {
+			int ch = priv->available_chnl[i];
+			if ((ch == 12) || (ch == 13))
+				score[i] = 0xffffffff;
+		}
+	}
+
+	if (((priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_GLOBAL) ||
+	     (priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_WORLD_WIDE)) &&
+	    (idx_2G_end >= 11) && (idx_2G_end < 14)) {
+		score[13] = 0xffffffff;	/*  mask chan14 */
+		score[12] = 0xffffffff; /*  mask chan13 */
+		score[11] = 0xffffffff; /*  mask chan12 */
+	}
+
+	/* ------------------------------------------------------------------ */
+
+#ifdef _DEBUG_RTL8192CD_
+	for (i = 0; i < priv->available_chnl_num; i++)
+		len += sprintf(tmpbuf + len, "ch%d:%u ", priv->available_chnl[i], score[i]);
+	strcat(tmpbuf, "\n");
+	panic_printk("%s", tmpbuf);
+
+#endif
+
+	if ((*dm->band_type == ODM_BAND_5G)
+	    && (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80)) {
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (is80MChannel(priv->available_chnl, priv->available_chnl_num, priv->available_chnl[i])) {
+				tmpScore = 0;
+				for (j = 0; j < 4; j++) {
+					if ((tmpScore != 0xffffffff) && (score[i + j] != 0xffffffff))
+						tmpScore += score[i + j];
+					else
+						tmpScore = 0xffffffff;
+				}
+				tmpScore = tmpScore / 4;
+				if (minScore > tmpScore) {
+					minScore = tmpScore;
+
+					tmpScore = 0xffffffff;
+					for (j = 0; j < 4; j++) {
+						if (score[i + j] < tmpScore) {
+							tmpScore = score[i + j];
+							tmpIdx = i + j;
+						}
+					}
+
+					idx = tmpIdx;
+				}
+				i += 3;
+			}
+		}
+		if (minScore == 0xffffffff) {
+			/*  there is no 80M channels */
+			priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
+			for (i = 0; i < priv->available_chnl_num; i++) {
+				if (score[i] < minScore) {
+					minScore = score[i];
+					idx = i;
+				}
+			}
+		}
+	} else if ((*dm->band_type == ODM_BAND_5G)
+		&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40)) {
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (is40MChannel(priv->available_chnl, priv->available_chnl_num, priv->available_chnl[i])) {
+				tmpScore = 0;
+				for (j = 0; j < 2; j++) {
+					if ((tmpScore != 0xffffffff) && (score[i + j] != 0xffffffff))
+						tmpScore += score[i + j];
+					else
+						tmpScore = 0xffffffff;
+				}
+				tmpScore = tmpScore / 2;
+				if (minScore > tmpScore) {
+					minScore = tmpScore;
+
+					tmpScore = 0xffffffff;
+					for (j = 0; j < 2; j++) {
+						if (score[i + j] < tmpScore) {
+							tmpScore = score[i + j];
+							tmpIdx = i + j;
+						}
+					}
+
+					idx = tmpIdx;
+				}
+				i += 1;
+			}
+		}
+		if (minScore == 0xffffffff) {
+			/*  there is no 40M channels */
+			priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
+			for (i = 0; i < priv->available_chnl_num; i++) {
+				if (score[i] < minScore) {
+					minScore = score[i];
+					idx = i;
+				}
+			}
+		}
+	} else if ((*dm->band_type == ODM_BAND_2_4G)
+		&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40)
+		   && (priv->available_chnl_num >= 8)) {
+		u32 groupScore[14];
+
+		memset(groupScore, 0xff, sizeof(groupScore));
+		for (i = 0; i < priv->available_chnl_num - 4; i++) {
+			if (score[i] != 0xffffffff && score[i + 4] != 0xffffffff) {
+				groupScore[i] = score[i] + score[i + 4];
+				DEBUG_INFO("groupScore, ch %d,%d: %d\n", i + 1, i + 5, groupScore[i]);
+				if (groupScore[i] < minScore) {
+#ifdef AUTOCH_SS_SPEEDUP
+					if (priv->pmib->miscEntry.autoch_1611_enable) {
+						if (priv->available_chnl[i] == 1 || priv->available_chnl[i] == 6 || priv->available_chnl[i] == 11) {
+							minScore = groupScore[i];
+							idx = i;
+						}
+					} else
+#endif
+					{
+						minScore = groupScore[i];
+						idx = i;
+					}
+				}
+			}
+		}
+
+		if (score[idx] < score[idx + 4]) {
+			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+		} else {
+			idx = idx + 4;
+			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+		}
+	} else {
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (score[i] < minScore) {
+#ifdef AUTOCH_SS_SPEEDUP
+				if (priv->pmib->miscEntry.autoch_1611_enable) {
+					if (priv->available_chnl[i] == 1 || priv->available_chnl[i] == 6 || priv->available_chnl[i] == 11) {
+						minScore = score[i];
+						idx = i;
+					}
+				} else
+#endif
+				{
+					minScore = score[i];
+					idx = i;
+				}
+			}
+		}
+	}
+
+	if (IS_A_CUT_8881A(priv) &&
+	    (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80)) {
+		if ((priv->available_chnl[idx] == 36) ||
+		    (priv->available_chnl[idx] == 52) ||
+		    (priv->available_chnl[idx] == 100) ||
+		    (priv->available_chnl[idx] == 116) ||
+		    (priv->available_chnl[idx] == 132) ||
+		    (priv->available_chnl[idx] == 149) ||
+		    (priv->available_chnl[idx] == 165))
+			idx++;
+		else if ((priv->available_chnl[idx] == 48) ||
+			 (priv->available_chnl[idx] == 64) ||
+			 (priv->available_chnl[idx] == 112) ||
+			 (priv->available_chnl[idx] == 128) ||
+			 (priv->available_chnl[idx] == 144) ||
+			 (priv->available_chnl[idx] == 161) ||
+			 (priv->available_chnl[idx] == 177))
+			idx--;
+	}
+
+	minChan = priv->available_chnl[idx];
+
+	/*  skip channel 14 if don't support ofdm */
+	if ((priv->pmib->dot11RFEntry.disable_ch14_ofdm) &&
+	    (minChan == 14)) {
+		score[idx] = 0xffffffff;
+
+		minScore = 0xffffffff;
+		for (i = 0; i < priv->available_chnl_num; i++) {
+			if (score[i] < minScore) {
+				minScore = score[i];
+				idx = i;
+			}
+		}
+		minChan = priv->available_chnl[idx];
+	}
+
+#if 0
+	/* Check if selected channel available for 80M/40M BW or NOT ? */
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80) {
+			if (!is80MChannel(priv->available_chnl, priv->available_chnl_num, minChan)) {
+				/* priv->pmib->dot11n_config_entry.dot11nUse40M = CHANNEL_WIDTH_40; */
+				priv->pshare->is_40m_bw = CHANNEL_WIDTH_40;
+			}
+		}
+
+		if (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40) {
+			if (!is40MChannel(priv->available_chnl, priv->available_chnl_num, minChan)) {
+				/* priv->pmib->dot11n_config_entry.dot11nUse40M = CHANNEL_WIDTH_20; */
+				priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
+			}
+		}
+	}
+#endif
+
+#ifdef CONFIG_RTL_NEW_AUTOCH
+	RTL_W32(RXERR_RPT, RXERR_RPT_RST);
+#endif
+
+	/*  auto adjust contro-sideband */
+	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
+	    && (priv->pshare->is_40m_bw == 1 || priv->pshare->is_40m_bw == 2)) {
+#ifdef RTK_5G_SUPPORT
+		if (*dm->band_type == ODM_BAND_5G) {
+			if ((minChan > 144) ? ((minChan - 1) % 8) : (minChan % 8)) {
+				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+			} else {
+				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+			}
+
+		} else
+#endif
+		{
+#if 0
+#ifdef CONFIG_RTL_NEW_AUTOCH
+			unsigned int ch_max;
+
+			if (priv->available_chnl[idx_2G_end] >= 13)
+				ch_max = 13;
+			else
+				ch_max = priv->available_chnl[idx_2G_end];
+
+			if ((minChan >= 5) && (minChan <= (ch_max - 5))) {
+				if (score[minChan + 4] > score[minChan - 4]) { /*  what if some channels were cancelled? */
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+				} else {
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+				}
+			} else
+#endif
+			{
+				if (minChan < 5) {
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
+				} else if (minChan > 7) {
+					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
+					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
+				}
+			}
+#endif
+		}
+	}
+	/* ----------------------- */
+
+#if defined(__ECOS) && defined(CONFIG_SDIO_HCI)
+	panic_printk("Auto channel choose ch:%d\n", minChan);
+#else
+#ifdef _DEBUG_RTL8192CD_
+	panic_printk("Auto channel choose ch:%d\n", minChan);
+#endif
+#endif
+#ifdef ACS_DEBUG_INFO/* for debug */
+	printk("7. minChan:%d 2nd_offset:%d\n", minChan, priv->pshare->offset_2nd_chan);
+#endif
+
+	return minChan;
+}
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.h
index d193eab4fb56..fb69bfc0802d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_acs.h
@@ -1,129 +1,116 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMACS_H__
-#define    __PHYDMACS_H__
-
-#define ACS_VERSION	"1.0"
-#define CLM_VERSION "1.0"
-
-#define ODM_MAX_CHANNEL_2G			14
-#define ODM_MAX_CHANNEL_5G			24
-
-// For phydm_AutoChannelSelectSettingAP()
-#define STORE_DEFAULT_NHM_SETTING               0
-#define RESTORE_DEFAULT_NHM_SETTING             1
-#define ACS_NHM_SETTING                         2
-
-typedef struct _ACS_
-{
-	BOOLEAN		bForceACSResult;
-	u1Byte		CleanChannel_2G;
-	u1Byte		CleanChannel_5G;
-	u2Byte		Channel_Info_2G[2][ODM_MAX_CHANNEL_2G];		//Channel_Info[1]: Channel Score, Channel_Info[2]:Channel_Scan_Times
-	u2Byte		Channel_Info_5G[2][ODM_MAX_CHANNEL_5G];	
-
-#if ( DM_ODM_SUPPORT_TYPE & ODM_AP )    
-    u1Byte              ACS_Step;
-    // NHM Count 0-11
-    u1Byte              NHM_Cnt[14][11];
-
-    // AC-Series, for storing previous setting
-    u4Byte              Reg0x990; 
-    u4Byte              Reg0x994;
-    u4Byte              Reg0x998;
-    u4Byte              Reg0x99C;
-    u1Byte              Reg0x9A0;   // u1Byte
-
-    // N-Series, for storing previous setting
-    u4Byte              Reg0x890; 
-    u4Byte              Reg0x894;
-    u4Byte              Reg0x898;
-    u4Byte              Reg0x89C;
-    u1Byte              Reg0xE28;   // u1Byte
-#endif
-
-}ACS, *PACS;
-
-
-VOID
-odm_AutoChannelSelectInit(
-	IN		PVOID			pDM_VOID
-);
-
-VOID
-odm_AutoChannelSelectReset(
-	IN		PVOID			pDM_VOID
-);
-
-VOID
-odm_AutoChannelSelect(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Channel
-);
-
-u1Byte
-ODM_GetAutoChannelSelectResult(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Band
-);
-
-#if ( DM_ODM_SUPPORT_TYPE & ODM_AP )
-
-VOID
-phydm_AutoChannelSelectSettingAP(
-    IN  PVOID   pDM_VOID,
-    IN  u4Byte  Setting,             // 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING
-    IN  u4Byte  acs_step        
-);
-
-VOID
-phydm_GetNHMStatisticsAP(
-    IN  PVOID       pDM_VOID,
-    IN  u4Byte      idx,                // @ 2G, Real channel number = idx+1
-    IN  u4Byte      acs_step
-);
-
-#endif  //#if ( DM_ODM_SUPPORT_TYPE & ODM_AP )
-
-
-VOID
-phydm_CLMInit(
-	IN		PVOID			pDM_VOID,
-	IN		u2Byte			sampleNum
-);
-
-VOID
-phydm_CLMtrigger(
-	IN		PVOID			pDM_VOID
-);
-
-BOOLEAN
-phydm_checkCLMready(
-	IN		PVOID			pDM_VOID
-);
-
-u2Byte
-phydm_getCLMresult(
-	IN		PVOID			pDM_VOID
-);
-
-
-#endif  //#ifndef	__PHYDMACS_H__
\ No newline at end of file
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMACS_H__
+#define    __PHYDMACS_H__
+
+#define ACS_VERSION	"1.1"	/*20150729 by YuChen*/
+#define CLM_VERSION "1.0"
+
+#define ODM_MAX_CHANNEL_2G			14
+#define ODM_MAX_CHANNEL_5G			24
+
+/* For phydm_auto_channel_select_setting_ap() */
+#define STORE_DEFAULT_NHM_SETTING               0
+#define RESTORE_DEFAULT_NHM_SETTING             1
+#define ACS_NHM_SETTING                         2
+
+struct acs_info {
+	boolean		is_force_acs_result;
+	u8		clean_channel_2g;
+	u8		clean_channel_5g;
+	u16		channel_info_2g[2][ODM_MAX_CHANNEL_2G];		/* Channel_Info[1]: channel score, Channel_Info[2]:Channel_Scan_Times */
+	u16		channel_info_5g[2][ODM_MAX_CHANNEL_5G];
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	u8              acs_step;
+	/* NHM count 0-11 */
+	u8              nhm_cnt[14][11];
+
+	/* AC-Series, for storing previous setting */
+	u32              reg0x990;
+	u32              reg0x994;
+	u32              reg0x998;
+	u32              reg0x99c;
+	u8              reg0x9a0;   /* u8 */
+
+	/* N-Series, for storing previous setting */
+	u32              reg0x890;
+	u32              reg0x894;
+	u32              reg0x898;
+	u32              reg0x89c;
+	u8              reg0xe28;   /* u8 */
+#endif
+
+};
+
+
+void
+odm_auto_channel_select_init(
+	void			*dm_void
+);
+
+void
+odm_auto_channel_select_reset(
+	void			*dm_void
+);
+
+void
+odm_auto_channel_select(
+	void			*dm_void,
+	u8			channel
+);
+
+u8
+odm_get_auto_channel_select_result(
+	void			*dm_void,
+	u8			band
+);
+
+boolean
+phydm_acs_check(
+	void	*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+void
+phydm_auto_channel_select_setting_ap(
+	void   *dm_void,
+	u32  setting,             /* 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING */
+	u32  acs_step
+);
+
+void
+phydm_get_nhm_statistics_ap(
+	void       *dm_void,
+	u32      idx,                /* @ 2G, Real channel number = idx+1 */
+	u32      acs_step
+);
+
+#endif  /* #if ( DM_ODM_SUPPORT_TYPE & ODM_AP ) */
+
+#endif  /* #ifndef	__PHYDMACS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.c
index 7a42d7db5d0f..7f6bace25e78 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.c
@@ -1,946 +1,1006 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-#if WPP_SOFTWARE_TRACE
-#include "PhyDM_Adaptivity.tmh"
-#endif
-#endif
-
-
-VOID
-Phydm_CheckAdaptivity(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTIVITY_STATISTICS	Adaptivity = (PADAPTIVITY_STATISTICS)PhyDM_Get_Structure(pDM_Odm, PHYDM_ADAPTIVITY);
-	
-	if (pDM_Odm->SupportAbility & ODM_BB_ADAPTIVITY) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		if (pDM_Odm->APTotalNum > Adaptivity->APNumTH) {
-			pDM_Odm->Adaptivity_enable = FALSE;
-			pDM_Odm->adaptivity_flag = FALSE;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("AP total num > %d!!, disable adaptivity\n", Adaptivity->APNumTH));
-		} else
-#endif
-		{
-			if (Adaptivity->DynamicLinkAdaptivity == TRUE) {
-				if (pDM_Odm->bLinked && Adaptivity->bCheck == FALSE) {
-					Phydm_NHMCounterStatistics(pDM_Odm);
-					Phydm_CheckEnvironment(pDM_Odm);
-				} else if (!pDM_Odm->bLinked)
-					Adaptivity->bCheck = FALSE;
-			} else {
-				pDM_Odm->Adaptivity_enable = TRUE;
-
-				if (pDM_Odm->SupportICType & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA))
-					pDM_Odm->adaptivity_flag = FALSE;
-				else
-					pDM_Odm->adaptivity_flag = TRUE;
-			}
-		}
-	} else {
-		pDM_Odm->Adaptivity_enable = FALSE;
-		pDM_Odm->adaptivity_flag = FALSE;
-	}
-
-	
-
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-BOOLEAN
-Phydm_CheckChannelPlan(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		pAdapter	= pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PMGNT_INFO		pMgntInfo = &(pAdapter->MgntInfo);
-	
-	if (pMgntInfo->RegEnableAdaptivity == 2) {
-		if (pDM_Odm->Carrier_Sense_enable == FALSE) {		/*check domain Code for Adaptivity or CarrierSense*/
-			if ((*pDM_Odm->pBandType == ODM_BAND_5G) &&
-			    !(pDM_Odm->odm_Regulation5G == REGULATION_ETSI || pDM_Odm->odm_Regulation5G == REGULATION_WW)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("Adaptivity skip 5G domain code : %d\n", pDM_Odm->odm_Regulation5G));
-				pDM_Odm->Adaptivity_enable = FALSE;
-				pDM_Odm->adaptivity_flag = FALSE;
-				return TRUE;
-			} else if ((*pDM_Odm->pBandType == ODM_BAND_2_4G) &&
-				   !(pDM_Odm->odm_Regulation2_4G == REGULATION_ETSI || pDM_Odm->odm_Regulation2_4G == REGULATION_WW)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("Adaptivity skip 2.4G domain code : %d\n", pDM_Odm->odm_Regulation2_4G));
-				pDM_Odm->Adaptivity_enable = FALSE;
-				pDM_Odm->adaptivity_flag = FALSE;
-				return TRUE;
-
-			} else if ((*pDM_Odm->pBandType != ODM_BAND_2_4G) && (*pDM_Odm->pBandType != ODM_BAND_5G)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("Adaptivity neither 2G nor 5G band, return\n"));
-				pDM_Odm->Adaptivity_enable = FALSE;
-				pDM_Odm->adaptivity_flag = FALSE;
-				return TRUE;
-			}
-		} else {
-			if ((*pDM_Odm->pBandType == ODM_BAND_5G) &&
-			    !(pDM_Odm->odm_Regulation5G == REGULATION_MKK || pDM_Odm->odm_Regulation5G == REGULATION_WW)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("CarrierSense skip 5G domain code : %d\n", pDM_Odm->odm_Regulation5G));
-				pDM_Odm->Adaptivity_enable = FALSE;
-				pDM_Odm->adaptivity_flag = FALSE;
-				return TRUE;
-			}
-
-			else if ((*pDM_Odm->pBandType == ODM_BAND_2_4G) &&
-				   !(pDM_Odm->odm_Regulation2_4G == REGULATION_MKK  || pDM_Odm->odm_Regulation2_4G == REGULATION_WW)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("CarrierSense skip 2.4G domain code : %d\n", pDM_Odm->odm_Regulation2_4G));
-				pDM_Odm->Adaptivity_enable = FALSE;
-				pDM_Odm->adaptivity_flag = FALSE;
-				return TRUE;
-
-			} else if ((*pDM_Odm->pBandType != ODM_BAND_2_4G) && (*pDM_Odm->pBandType != ODM_BAND_5G)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("CarrierSense neither 2G nor 5G band, return\n"));
-				pDM_Odm->Adaptivity_enable = FALSE;
-				pDM_Odm->adaptivity_flag = FALSE;
-				return TRUE;
-			}
-		}
-	}
-
-	return FALSE;
-
-}
-#endif
-
-VOID
-Phydm_NHMCounterStatisticsInit(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES) {
-		/*PHY parameters initialize for n series*/
-		ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TIMER_11N + 2, 0xC350);			/*0x894[31:16]=0x0xC350	Time duration for NHM unit: us, 0xc350=200ms*/
-		ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N + 2, 0xffff);		/*0x890[31:16]=0xffff		th_9, th_10*/
-		ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11N, 0xffffff50);		/*0x898=0xffffff52			th_3, th_2, th_1, th_0*/
-		ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffffff);		/*0x89c=0xffffffff			th_7, th_6, th_5, th_4*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_FPGA0_IQK_11N, bMaskByte0, 0xff);		/*0xe28[7:0]=0xff			th_8*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N, BIT10 | BIT9 | BIT8, 0x1);	/*0x890[10:8]=1			ignoreCCA ignore PHYTXON enable CCX*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RSTC_11N, BIT7, 0x1);			/*0xc0c[7]=1				max power among all RX ants*/
-	}
-#if (RTL8195A_SUPPORT == 0)
-	else if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) {
-		/*PHY parameters initialize for ac series*/
-		ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TIMER_11AC + 2, 0xC350);			/*0x990[31:16]=0xC350	Time duration for NHM unit: us, 0xc350=200ms*/
-		ODM_Write2Byte(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC + 2, 0xffff);		/*0x994[31:16]=0xffff		th_9, th_10*/
-		ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0xffffff50);	/*0x998=0xffffff52			th_3, th_2, th_1, th_0*/
-		ODM_Write4Byte(pDM_Odm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffffff);	/*0x99c=0xffffffff			th_7, th_6, th_5, th_4*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH8_11AC, bMaskByte0, 0xff);		/*0x9a0[7:0]=0xff			th_8*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC, BIT8 | BIT9 | BIT10, 0x1); /*0x994[10:8]=1			ignoreCCA ignore PHYTXON	enable CCX*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_9E8_11AC, BIT0, 0x1);				/*0x9e8[7]=1				max power among all RX ants*/
-
-	}
-#endif
-}
-
-VOID
-Phydm_NHMCounterStatistics(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (!(pDM_Odm->SupportAbility & ODM_BB_NHM_CNT))
-		return;
-
-	/*Get NHM report*/
-	Phydm_GetNHMCounterStatistics(pDM_Odm);
-
-	/*Reset NHM counter*/
-	Phydm_NHMCounterStatisticsReset(pDM_Odm);
-}
-
-VOID
-Phydm_GetNHMCounterStatistics(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte		value32 = 0;
-#if (RTL8195A_SUPPORT == 0)
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_NHM_CNT_11AC, bMaskDWord);
-	else if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-#endif
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_NHM_CNT_11N, bMaskDWord);
-
-	pDM_Odm->NHM_cnt_0 = (u1Byte)(value32 & bMaskByte0);
-	pDM_Odm->NHM_cnt_1 = (u1Byte)((value32 & bMaskByte1) >> 8);
-
-}
-
-VOID
-Phydm_NHMCounterStatisticsReset(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N, BIT1, 0);
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11N, BIT1, 1);
-	}
-#if (RTL8195A_SUPPORT == 0)
-	else if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC, BIT1, 0);
-		ODM_SetBBReg(pDM_Odm, ODM_REG_NHM_TH9_TH10_11AC, BIT1, 1);
-	}
-
-#endif
-
-}
-
-VOID
-Phydm_SetEDCCAThreshold(
-	IN	PVOID	pDM_VOID,
-	IN	s1Byte	H2L,
-	IN	s1Byte	L2H
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, bMaskByte2|bMaskByte0, (u4Byte)((u1Byte)L2H|(u1Byte)H2L<<16));
-#if (RTL8195A_SUPPORT == 0)
-	else if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		ODM_SetBBReg(pDM_Odm, rFPGA0_XB_LSSIReadBack, bMaskLWord, (u2Byte)((u1Byte)L2H|(u1Byte)H2L<<8));
-#endif
-
-}
-
-VOID
-Phydm_SetLNA(
-	IN	PVOID				pDM_VOID,
-	IN	PhyDM_set_LNA	type
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	if (pDM_Odm->SupportICType & (ODM_RTL8188E | ODM_RTL8192E)) {
-		if (type == PhyDM_disable_LNA) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x0000f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0x37f82);	/*disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);
-			if (pDM_Odm->RFType > ODM_1T1R) {
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x1);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x30, 0xfffff, 0x18000);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x31, 0xfffff, 0x0000f);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x32, 0xfffff, 0x37f82);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x0);
-			}
-		} else if (type == PhyDM_enable_LNA) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x0000f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0x77f82);	/*back to normal*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);
-			if (pDM_Odm->RFType > ODM_1T1R) {
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x1);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x30, 0xfffff, 0x18000);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x31, 0xfffff, 0x0000f);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x32, 0xfffff, 0x77f82);
-				ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x0);
-			}
-		}
-	} else if (pDM_Odm->SupportICType & ODM_RTL8723B) {
-		if (type == PhyDM_disable_LNA) {
-			/*S0*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x0001f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0xe6137);	/*disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);
-			/*S1*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xed, 0x00020, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x43, 0xfffff, 0x3008d);	/*select Rx mode and disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xed, 0x00020, 0x0);
-		} else if (type == PhyDM_enable_LNA) {
-			/*S0*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x0001f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0xe6177);	/*disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);
-			/*S1*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xed, 0x00020, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x43, 0xfffff, 0x300bd);	/*select Rx mode and disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xed, 0x00020, 0x0);
-		}
-	
-	} else if (pDM_Odm->SupportICType & ODM_RTL8812) {
-		if (type == PhyDM_disable_LNA) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);
-				if (pDM_Odm->RFType > ODM_1T1R) {
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x1);
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x0);
-				}
-		} else if (type == PhyDM_enable_LNA) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);
-				if (pDM_Odm->RFType > ODM_1T1R) {
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x1);
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xef, 0x80000, 0x0);
-				}
-		}
-	} else if (pDM_Odm->SupportICType & (ODM_RTL8821 | ODM_RTL8881A)) {
-		if (type == PhyDM_disable_LNA) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x0002f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0xfb09b);	/*disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);
-		} else if (type == PhyDM_enable_LNA) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x1);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x31, 0xfffff, 0x0002f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x32, 0xfffff, 0xfb0bb);	/*disable LNA*/
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xef, 0x80000, 0x0);	
-		}
-	}
-}
-
-
-
-VOID
-Phydm_SetTRxMux(
-	IN	PVOID				pDM_VOID,
-	IN	PhyDM_Trx_MUX_Type	txMode,
-	IN	PhyDM_Trx_MUX_Type	rxMode
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_RPT_FORMAT_11N, BIT3 | BIT2 | BIT1, txMode);			/*set TXmod to standby mode to remove outside noise affect*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_RPT_FORMAT_11N, BIT22 | BIT21 | BIT20, rxMode);		/*set RXmod to standby mode to remove outside noise affect*/
-		if (pDM_Odm->RFType > ODM_1T1R) {
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT3 | BIT2 | BIT1, txMode);		/*set TXmod to standby mode to remove outside noise affect*/
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT22 | BIT21 | BIT20, rxMode);	/*set RXmod to standby mode to remove outside noise affect*/
-		}
-	}
-#if (RTL8195A_SUPPORT == 0)
-	else if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) {
-		ODM_SetBBReg(pDM_Odm, ODM_REG_TRMUX_11AC, BIT11 | BIT10 | BIT9 | BIT8, txMode);				/*set TXmod to standby mode to remove outside noise affect*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_TRMUX_11AC, BIT7 | BIT6 | BIT5 | BIT4, rxMode);				/*set RXmod to standby mode to remove outside noise affect*/
-		if (pDM_Odm->RFType > ODM_1T1R) {
-			ODM_SetBBReg(pDM_Odm, ODM_REG_TRMUX_11AC_B, BIT11 | BIT10 | BIT9 | BIT8, txMode);		/*set TXmod to standby mode to remove outside noise affect*/
-			ODM_SetBBReg(pDM_Odm, ODM_REG_TRMUX_11AC_B, BIT7 | BIT6 | BIT5 | BIT4, rxMode);			/*set RXmod to standby mode to remove outside noise affect*/
-		}
-	}
-#endif
-
-}
-
-VOID
-Phydm_MACEDCCAState(
-	IN	PVOID					pDM_VOID,
-	IN	PhyDM_MACEDCCA_Type		State
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if (State == PhyDM_IGNORE_EDCCA) {
-		ODM_SetMACReg(pDM_Odm, REG_TX_PTCL_CTRL, BIT15, 1);	/*ignore EDCCA	reg520[15]=1*/
-		ODM_SetMACReg(pDM_Odm, REG_RD_CTRL, BIT11, 0);			/*reg524[11]=0*/
-	} else {	/*don't set MAC ignore EDCCA signal*/
-		ODM_SetMACReg(pDM_Odm, REG_TX_PTCL_CTRL, BIT15, 0);	/*don't ignore EDCCA	 reg520[15]=0*/
-		ODM_SetMACReg(pDM_Odm, REG_RD_CTRL, BIT11, 1);			/*reg524[11]=1	*/
-	}
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("EDCCA enable State = %d\n", State));
-
-}
-
-BOOLEAN
-Phydm_CalNHMcnt(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte			Base = 0;
-
-	Base = pDM_Odm->NHM_cnt_0 + pDM_Odm->NHM_cnt_1;
-
-	if (Base != 0) {
-		pDM_Odm->NHM_cnt_0 = ((pDM_Odm->NHM_cnt_0) << 8) / Base;
-		pDM_Odm->NHM_cnt_1 = ((pDM_Odm->NHM_cnt_1) << 8) / Base;
-	}
-	if ((pDM_Odm->NHM_cnt_0 - pDM_Odm->NHM_cnt_1) >= 100)
-		return TRUE;			/*clean environment*/
-	else
-		return FALSE;		/*noisy environment*/
-
-}
-
-
-VOID
-Phydm_CheckEnvironment(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTIVITY_STATISTICS	Adaptivity = (PADAPTIVITY_STATISTICS)PhyDM_Get_Structure(pDM_Odm, PHYDM_ADAPTIVITY);
-	BOOLEAN 	isCleanEnvironment = FALSE;
-
-	if (Adaptivity->bFirstLink == TRUE) {
-		if (pDM_Odm->SupportICType & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA))
-			pDM_Odm->adaptivity_flag = FALSE;
-		else
-			pDM_Odm->adaptivity_flag = TRUE;
-
-		Adaptivity->bFirstLink = FALSE;
-		return;
-	} else {
-		if (Adaptivity->NHMWait < 3) {		/*Start enter NHM after 4 NHMWait*/
-			Adaptivity->NHMWait++;
-			Phydm_NHMCounterStatistics(pDM_Odm);
-			return;
-		} else {
-			Phydm_NHMCounterStatistics(pDM_Odm);
-			isCleanEnvironment = Phydm_CalNHMcnt(pDM_Odm);
-			if (isCleanEnvironment == TRUE) {
-				pDM_Odm->TH_L2H_ini = Adaptivity->TH_L2H_ini_backup;			/*adaptivity mode*/
-				pDM_Odm->TH_EDCCA_HL_diff = Adaptivity->TH_EDCCA_HL_diff_backup;
-
-				pDM_Odm->Adaptivity_enable = TRUE;
-
-				if (pDM_Odm->SupportICType & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA))
-					pDM_Odm->adaptivity_flag = FALSE;
-				else
-					pDM_Odm->adaptivity_flag = TRUE;
-			} else {
-				pDM_Odm->TH_L2H_ini = pDM_Odm->TH_L2H_ini_mode2;			/*mode2*/
-				pDM_Odm->TH_EDCCA_HL_diff = pDM_Odm->TH_EDCCA_HL_diff_mode2;
-
-				pDM_Odm->adaptivity_flag = FALSE;
-				pDM_Odm->Adaptivity_enable = FALSE;
-			}
-			Adaptivity->NHMWait = 0;
-			Adaptivity->bFirstLink = TRUE;
-			Adaptivity->bCheck = TRUE;
-		}
-
-	}
-
-
-}
-
-VOID
-Phydm_SearchPwdBLowerBound(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTIVITY_STATISTICS	Adaptivity = (PADAPTIVITY_STATISTICS)PhyDM_Get_Structure(pDM_Odm, PHYDM_ADAPTIVITY);
-	u4Byte			value32 = 0;
-	u1Byte			cnt, IGI = 0x45;		/*IGI = 0x50 for cal EDCCA lower bound*/
-	u1Byte			txEdcca1 = 0, txEdcca0 = 0;
-	BOOLEAN			bAdjust = TRUE;
-	s1Byte 			TH_L2H_dmc, TH_H2L_dmc, IGI_target = 0x32;
-	s1Byte 			Diff;
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
-		Phydm_SetLNA(pDM_Odm, PhyDM_disable_LNA);
-	else {
-		Phydm_SetTRxMux(pDM_Odm, PhyDM_STANDBY_MODE, PhyDM_STANDBY_MODE);
-		odm_PauseDIG(pDM_Odm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_0, 0x7e);
-	}
-
-	Diff = IGI_target - (s1Byte)IGI;
-	TH_L2H_dmc = pDM_Odm->TH_L2H_ini + Diff;
-	if (TH_L2H_dmc > 10)
-		TH_L2H_dmc = 10;
-	TH_H2L_dmc = TH_L2H_dmc - pDM_Odm->TH_EDCCA_HL_diff;
-
-	Phydm_SetEDCCAThreshold(pDM_Odm, TH_H2L_dmc, TH_L2H_dmc);
-	ODM_delay_ms(5);
-
-	while (bAdjust) {
-		for (cnt = 0; cnt < 20; cnt++) {
-			if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-				value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11N, bMaskDWord);
-#if (RTL8195A_SUPPORT == 0)
-			else if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-				value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC, bMaskDWord);
-#endif
-			if (value32 & BIT30 && (pDM_Odm->SupportICType & (ODM_RTL8723A | ODM_RTL8723B | ODM_RTL8188E)))
-				txEdcca1 = txEdcca1 + 1;
-			else if (value32 & BIT29)
-				txEdcca1 = txEdcca1 + 1;
-			else
-				txEdcca0 = txEdcca0 + 1;
-		}
-
-		if (txEdcca1 > 1) {
-			IGI = IGI - 1;
-			TH_L2H_dmc = TH_L2H_dmc + 1;
-			if (TH_L2H_dmc > 10)
-				TH_L2H_dmc = 10;
-			TH_H2L_dmc = TH_L2H_dmc - pDM_Odm->TH_EDCCA_HL_diff;
-
-			Phydm_SetEDCCAThreshold(pDM_Odm, TH_H2L_dmc, TH_L2H_dmc);
-			if (TH_L2H_dmc == 10) {
-				bAdjust = FALSE;
-				Adaptivity->H2L_lb = TH_H2L_dmc;
-				Adaptivity->L2H_lb = TH_L2H_dmc;
-				pDM_Odm->Adaptivity_IGI_upper = IGI;
-			}
-
-			txEdcca1 = 0;
-			txEdcca0 = 0;
-
-		} else {
-			bAdjust = FALSE;
-			Adaptivity->H2L_lb = TH_H2L_dmc;
-			Adaptivity->L2H_lb = TH_L2H_dmc;
-			pDM_Odm->Adaptivity_IGI_upper = IGI;
-			txEdcca1 = 0;
-			txEdcca0 = 0;
-		}
-	}
-
-	pDM_Odm->Adaptivity_IGI_upper = pDM_Odm->Adaptivity_IGI_upper - pDM_Odm->DCbackoff;
-	Adaptivity->H2L_lb = Adaptivity->H2L_lb + pDM_Odm->DCbackoff;
-	Adaptivity->L2H_lb = Adaptivity->L2H_lb + pDM_Odm->DCbackoff;
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
-		Phydm_SetLNA(pDM_Odm, PhyDM_enable_LNA);
-	else {
-		Phydm_SetTRxMux(pDM_Odm, PhyDM_TX_MODE, PhyDM_RX_MODE);
-		odm_PauseDIG(pDM_Odm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_0, NONE);
-	}
-	
-	Phydm_SetEDCCAThreshold(pDM_Odm, 0x7f, 0x7f);				/*resume to no link state*/
-}
-
-VOID
-Phydm_AdaptivityInit(
-	IN 	PVOID	 	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTIVITY_STATISTICS	Adaptivity = (PADAPTIVITY_STATISTICS)PhyDM_Get_Structure(pDM_Odm, PHYDM_ADAPTIVITY);
-	s1Byte	IGItarget = 0x32;
-	/*pDIG_T pDM_DigTable = &pDM_Odm->DM_DigTable;*/
-#if(DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		pAdapter	= pDM_Odm->Adapter;
-	PMGNT_INFO		pMgntInfo = &(pAdapter->MgntInfo);
-	pDM_Odm->Carrier_Sense_enable = (BOOLEAN)pMgntInfo->RegEnableCarrierSense;
-	pDM_Odm->DCbackoff = (u1Byte)pMgntInfo->RegDCbackoff;
-	Adaptivity->DynamicLinkAdaptivity = (BOOLEAN)pMgntInfo->RegDmLinkAdaptivity;
-	Adaptivity->APNumTH = (u1Byte)pMgntInfo->RegAPNumTH;
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	pDM_Odm->Carrier_Sense_enable = (pDM_Odm->Adapter->registrypriv.adaptivity_mode != 0) ? TRUE : FALSE;
-	pDM_Odm->DCbackoff = pDM_Odm->Adapter->registrypriv.adaptivity_dc_backoff;
-	Adaptivity->DynamicLinkAdaptivity = (pDM_Odm->Adapter->registrypriv.adaptivity_dml != 0) ? TRUE : FALSE;
-#endif
-
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-
-	if (pDM_Odm->Carrier_Sense_enable == FALSE) {
-#if(DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		if (pMgntInfo->RegL2HForAdaptivity != 0)
-			pDM_Odm->TH_L2H_ini = pMgntInfo->RegL2HForAdaptivity;
-		else
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-		if (pDM_Odm->Adapter->registrypriv.adaptivity_th_l2h_ini != 0)
-			pDM_Odm->TH_L2H_ini = pDM_Odm->Adapter->registrypriv.adaptivity_th_l2h_ini;
-		else
-#endif
-			pDM_Odm->TH_L2H_ini = 0xf5;
-	} else
-			pDM_Odm->TH_L2H_ini = 0xa;
-
-#if(DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (pMgntInfo->RegHLDiffForAdaptivity != 0)
-		pDM_Odm->TH_EDCCA_HL_diff = pMgntInfo->RegHLDiffForAdaptivity;
-	else
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (pDM_Odm->Adapter->registrypriv.adaptivity_th_edcca_hl_diff != 0)
-		pDM_Odm->TH_EDCCA_HL_diff = pDM_Odm->Adapter->registrypriv.adaptivity_th_edcca_hl_diff;
-	else
-#endif
-		pDM_Odm->TH_EDCCA_HL_diff = 7;
-
-	Adaptivity->TH_L2H_ini_backup = pDM_Odm->TH_L2H_ini;
-	Adaptivity->TH_EDCCA_HL_diff_backup = pDM_Odm->TH_EDCCA_HL_diff;
-
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv = pDM_Odm->priv;
-
-	if (pDM_Odm->Carrier_Sense_enable) {
-		pDM_Odm->TH_L2H_ini = 0xa;
-		pDM_Odm->TH_EDCCA_HL_diff = 7;
-	} else {
-		Adaptivity->TH_L2H_ini_backup = pDM_Odm->TH_L2H_ini;	/*set by mib*/
-		pDM_Odm->TH_EDCCA_HL_diff = 7;
-	}
-
-	Adaptivity->TH_EDCCA_HL_diff_backup = pDM_Odm->TH_EDCCA_HL_diff;
-	if (priv->pshare->rf_ft_var.adaptivity_enable == 2)
-		Adaptivity->DynamicLinkAdaptivity = TRUE;
-	else
-		Adaptivity->DynamicLinkAdaptivity = FALSE;
-
-#endif
-
-	pDM_Odm->Adaptivity_IGI_upper = 0;
-	pDM_Odm->Adaptivity_enable = FALSE;	/*use this flag to decide enable or disable*/
-
-	if (pDM_Odm->mp_mode == TRUE)
-		pDM_Odm->EDCCA_enable = FALSE;
-	else	
-		pDM_Odm->EDCCA_enable = TRUE;		/*even no adaptivity, we still enable EDCCA*/
-
-	pDM_Odm->TH_L2H_ini_mode2 = 20;
-	pDM_Odm->TH_EDCCA_HL_diff_mode2 = 8;
-	
-	Adaptivity->IGI_Base = 0x32;
-	Adaptivity->IGI_target = 0x1c;
-	Adaptivity->H2L_lb = 0;
-	Adaptivity->L2H_lb = 0;
-	Adaptivity->NHMWait = 0;
-	Adaptivity->bCheck = FALSE;
-	Adaptivity->bFirstLink = TRUE;
-	Adaptivity->AdajustIGILevel = 0;
-
-	Phydm_MACEDCCAState(pDM_Odm, PhyDM_DONT_IGNORE_EDCCA);
-
-	/*Search pwdB lower bound*/
-	if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11N, bMaskDWord, 0x208);
-#if (RTL8195A_SUPPORT == 0)
-	else if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC, bMaskDWord, 0x209);
-#endif
-
-	if (pDM_Odm->SupportICType & ODM_IC_11N_GAIN_IDX_EDCCA) {
-		/*ODM_SetBBReg(pDM_Odm, ODM_REG_EDCCA_DOWN_OPT_11N, BIT12 | BIT11 | BIT10, 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_EDCCA_DCNF_11N, BIT21 | BIT20, 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
-	}
-#if (RTL8195A_SUPPORT == 0)
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_GAIN_IDX_EDCCA) {		/*8814a no need to find pwdB lower bound, maybe*/
-		/*ODM_SetBBReg(pDM_Odm, ODM_REG_EDCCA_DOWN_OPT, BIT30 | BIT29 | BIT28, 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
-		ODM_SetBBReg(pDM_Odm, ODM_REG_ACBB_EDCCA_ENHANCE, BIT29 | BIT28, 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
-	}
-
-	if(!(pDM_Odm->SupportICType & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)))
-		Phydm_SearchPwdBLowerBound(pDM_Odm);
-#endif
-
-/*we need to consider PwdB upper bound for 8814 later IC*/
-	Adaptivity->AdajustIGILevel = (u1Byte)((pDM_Odm->TH_L2H_ini + IGItarget) - PwdBUpperBound + DFIRloss);	/*IGI = L2H - PwdB - DFIRloss*/
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("TH_L2H_ini = 0x%x, TH_EDCCA_HL_diff = 0x%x, Adaptivity->AdajustIGILevel = 0x%x\n", pDM_Odm->TH_L2H_ini, pDM_Odm->TH_EDCCA_HL_diff, Adaptivity->AdajustIGILevel));
-
-	/*phydm_setEDCCAThresholdAPI(pDM_Odm, pDM_DigTable->CurIGValue);*/
-
-}
-
-
-VOID
-Phydm_Adaptivity(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			IGI
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	s1Byte			TH_L2H_dmc, TH_H2L_dmc;
-	s1Byte			Diff = 0, IGI_target;
-	PADAPTIVITY_STATISTICS	Adaptivity = (PADAPTIVITY_STATISTICS)PhyDM_Get_Structure(pDM_Odm, PHYDM_ADAPTIVITY);
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		pAdapter	= pDM_Odm->Adapter;
-	BOOLEAN			bFwCurrentInPSMode = FALSE;
-	PMGNT_INFO		pMgntInfo = &(pAdapter->MgntInfo);
-
-	pAdapter->HalFunc.GetHwRegHandler(pAdapter, HW_VAR_FW_PSMODE_STATUS, (pu1Byte)(&bFwCurrentInPSMode));
-
-	/*Disable EDCCA mode while under LPS mode, added by Roger, 2012.09.14.*/
-	if (bFwCurrentInPSMode)
-		return;
-#endif
-
-	if ((pDM_Odm->EDCCA_enable == FALSE) || (pDM_Odm->bWIFITest == TRUE)) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("Disable EDCCA!!!\n"));
-		return;
-	}
-
-	if (!(pDM_Odm->SupportAbility & ODM_BB_ADAPTIVITY)) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("adaptivity disable, enable EDCCA mode!!!\n"));
-		pDM_Odm->TH_L2H_ini = pDM_Odm->TH_L2H_ini_mode2;
-		pDM_Odm->TH_EDCCA_HL_diff = pDM_Odm->TH_EDCCA_HL_diff_mode2;
-	}
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	else{
-		if (Phydm_CheckChannelPlan(pDM_Odm) || (pDM_Odm->APTotalNum > Adaptivity->APNumTH)) {
-			pDM_Odm->TH_L2H_ini = pDM_Odm->TH_L2H_ini_mode2;
-			pDM_Odm->TH_EDCCA_HL_diff = pDM_Odm->TH_EDCCA_HL_diff_mode2;
-		}
-	}
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("odm_Adaptivity() =====>\n"));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("IGI_Base=0x%x, TH_L2H_ini = %d, TH_EDCCA_HL_diff = %d\n",
-			 Adaptivity->IGI_Base, pDM_Odm->TH_L2H_ini, pDM_Odm->TH_EDCCA_HL_diff));
-#if (RTL8195A_SUPPORT == 0)
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) {
-		/*fix AC series when enable EDCCA hang issue*/
-		ODM_SetBBReg(pDM_Odm, 0x800, BIT10, 1);	/*ADC_mask disable*/
-		ODM_SetBBReg(pDM_Odm, 0x800, BIT10, 0);	/*ADC_mask enable*/
-	}
-#endif
-	if (*pDM_Odm->pBandWidth == ODM_BW20M)		/*CHANNEL_WIDTH_20*/
-		IGI_target = Adaptivity->IGI_Base;
-	else if (*pDM_Odm->pBandWidth == ODM_BW40M)
-		IGI_target = Adaptivity->IGI_Base + 2;
-#if (RTL8195A_SUPPORT == 0)
-	else if (*pDM_Odm->pBandWidth == ODM_BW80M)
-		IGI_target = Adaptivity->IGI_Base + 2;
-#endif
-	else
-		IGI_target = Adaptivity->IGI_Base;
-	Adaptivity->IGI_target = (u1Byte) IGI_target;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("BandWidth=%s, IGI_target=0x%x, DynamicLinkAdaptivity = %d\n",
-			 (*pDM_Odm->pBandWidth == ODM_BW80M) ? "80M" : ((*pDM_Odm->pBandWidth == ODM_BW40M) ? "40M" : "20M"), IGI_target, Adaptivity->DynamicLinkAdaptivity));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("RSSI_min = %d, Adaptivity->AdajustIGILevel= 0x%x, adaptivity_flag = %d, Adaptivity_enable = %d\n",
-			 pDM_Odm->RSSI_Min, Adaptivity->AdajustIGILevel, pDM_Odm->adaptivity_flag, pDM_Odm->Adaptivity_enable));
-
-	if ((Adaptivity->DynamicLinkAdaptivity == TRUE) && (!pDM_Odm->bLinked) && (pDM_Odm->Adaptivity_enable == FALSE)) {
-		Phydm_SetEDCCAThreshold(pDM_Odm, 0x7f, 0x7f);
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("In DynamicLink mode(noisy) and No link, Turn off EDCCA!!\n"));
-		return;
-	}
-
-	if (pDM_Odm->SupportICType & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
-		if ((Adaptivity->AdajustIGILevel > IGI) && (pDM_Odm->Adaptivity_enable == TRUE)) 
-			Diff = Adaptivity->AdajustIGILevel - IGI;
-		
-		TH_L2H_dmc = pDM_Odm->TH_L2H_ini - Diff + IGI_target;
-		TH_H2L_dmc = TH_L2H_dmc - pDM_Odm->TH_EDCCA_HL_diff;
-	}
-#if (RTL8195A_SUPPORT == 0)
-	else	{
-		Diff = IGI_target - (s1Byte)IGI;
-		TH_L2H_dmc = pDM_Odm->TH_L2H_ini + Diff;
-		if (TH_L2H_dmc > 10 && (pDM_Odm->Adaptivity_enable == TRUE))
-			TH_L2H_dmc = 10;
-
-		TH_H2L_dmc = TH_L2H_dmc - pDM_Odm->TH_EDCCA_HL_diff;
-
-		/*replace lower bound to prevent EDCCA always equal 1*/
-		if (TH_H2L_dmc < Adaptivity->H2L_lb)
-			TH_H2L_dmc = Adaptivity->H2L_lb;
-		if (TH_L2H_dmc < Adaptivity->L2H_lb)
-			TH_L2H_dmc = Adaptivity->L2H_lb;
-	}
-#endif
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("IGI=0x%x, TH_L2H_dmc = %d, TH_H2L_dmc = %d\n", IGI, TH_L2H_dmc, TH_H2L_dmc));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("Adaptivity_IGI_upper=0x%x, H2L_lb = 0x%x, L2H_lb = 0x%x\n", pDM_Odm->Adaptivity_IGI_upper, Adaptivity->H2L_lb, Adaptivity->L2H_lb));
-
-	Phydm_SetEDCCAThreshold(pDM_Odm, TH_H2L_dmc, TH_L2H_dmc);
-	return;
-}
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-Phydm_AdaptivityBSOD(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		pAdapter = pDM_Odm->Adapter;
-	PMGNT_INFO		pMgntInfo = &(pAdapter->MgntInfo);
-	u1Byte			count = 0;
-	u4Byte			u4Value;
-
-	/*
-	1. turn off RF (TRX Mux in standby mode)
-	2. H2C mac id drop
-	3. ignore EDCCA
-	4. wait for clear FIFO
-	5. don't ignore EDCCA
-	6. turn on RF (TRX Mux in TRx mdoe)
-	7. H2C mac id resume
-	*/
-
-	RT_TRACE(COMP_MLME, DBG_WARNING, ("MAC id drop packet!!!!!\n"));
-
-	pAdapter->dropPktByMacIdCnt++;
-	pMgntInfo->bDropPktInProgress = TRUE;
-
-	pAdapter->HalFunc.GetHwRegHandler(pAdapter, HW_VAR_MAX_Q_PAGE_NUM, (pu1Byte)(&u4Value));
-	RT_TRACE(COMP_INIT, DBG_LOUD, ("Queue Reserved Page Number = 0x%08x\n", u4Value));
-	pAdapter->HalFunc.GetHwRegHandler(pAdapter, HW_VAR_AVBL_Q_PAGE_NUM, (pu1Byte)(&u4Value));
-	RT_TRACE(COMP_INIT, DBG_LOUD, ("Available Queue Page Number = 0x%08x\n", u4Value));
-
-#if 1
-
-	/*Standby mode*/
-	Phydm_SetTRxMux(pDM_Odm, PhyDM_STANDBY_MODE, PhyDM_STANDBY_MODE);
-	ODM_Write_DIG(pDM_Odm, 0x20);
-
-	/*H2C mac id drop*/
-	MacIdIndicateDisconnect(pAdapter);
-
-	/*Ignore EDCCA*/
-	Phydm_MACEDCCAState(pDM_Odm, PhyDM_IGNORE_EDCCA);
-
-	delay_ms(50);
-	count = 5;
-
-#else
-
-	do {
-
-		u8Byte 		diffTime, curTime, oldestTime;
-		u1Byte		queueIdx
-
-		//3 Standby mode
-		Phydm_SetTRxMux(pDM_Odm, PhyDM_STANDBY_MODE, PhyDM_STANDBY_MODE);
-		ODM_Write_DIG(pDM_Odm, 0x20);
-
-		//3 H2C mac id drop
-		MacIdIndicateDisconnect(pAdapter);
-
-		//3 Ignore EDCCA
-		Phydm_MACEDCCAState(pDM_Odm, PhyDM_IGNORE_EDCCA);
-
-		count++;
-		delay_ms(10);
-
-		// Check latest packet
-		curTime = PlatformGetCurrentTime();
-		oldestTime = 0xFFFFFFFFFFFFFFFF;
-
-		for (queueIdx = 0; queueIdx < MAX_TX_QUEUE; queueIdx++) {
-			if (!IS_DATA_QUEUE(queueIdx))
-				continue;
-
-			if (!pAdapter->bTcbBusyQEmpty[queueIdx]) {
-				RT_TRACE(COMP_MLME, DBG_WARNING, ("oldestTime = %llu\n", oldestTime));
-				RT_TRACE(COMP_MLME, DBG_WARNING, ("Q[%d] = %llu\n", queueIdx, pAdapter->firstTcbSysTime[queueIdx]));
-				if (pAdapter->firstTcbSysTime[queueIdx] < oldestTime)
-					oldestTime = pAdapter->firstTcbSysTime[queueIdx];
-			}
-		}
-
-		diffTime = curTime - oldestTime;
-
-		RT_TRACE(COMP_MLME, DBG_WARNING, ("diff s = %llu\n", (diffTime / 1000000)));
-
-	} while (((diffTime / 1000000) >= 4) && (oldestTime != 0xFFFFFFFFFFFFFFFF));
-#endif
-
-	/*Resume EDCCA*/
-	Phydm_MACEDCCAState(pDM_Odm, PhyDM_DONT_IGNORE_EDCCA);
-
-	/*Turn on TRx mode*/
-	Phydm_SetTRxMux(pDM_Odm, PhyDM_TX_MODE, PhyDM_RX_MODE);
-	ODM_Write_DIG(pDM_Odm, 0x20);
-
-	/*Resume H2C macid*/
-	MacIdRecoverMediaStatus(pAdapter);
-
-	pAdapter->HalFunc.GetHwRegHandler(pAdapter, HW_VAR_AVBL_Q_PAGE_NUM, (pu1Byte)(&u4Value));
-	RT_TRACE(COMP_INIT, DBG_LOUD, ("Available Queue Page Number = 0x%08x\n", u4Value));
-
-	pMgntInfo->bDropPktInProgress = FALSE;
-	RT_TRACE(COMP_MLME, DBG_WARNING, ("End of MAC id drop packet, spent %dms\n", count * 10));
-
-}
-
-#endif
-
-VOID
-phydm_setEDCCAThresholdAPI(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte	IGI
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTIVITY_STATISTICS	Adaptivity = (PADAPTIVITY_STATISTICS)PhyDM_Get_Structure(pDM_Odm, PHYDM_ADAPTIVITY);
-	s1Byte			TH_L2H_dmc, TH_H2L_dmc;
-	s1Byte			Diff = 0, IGI_target = 0x32;
-
-	if (pDM_Odm->SupportAbility & ODM_BB_ADAPTIVITY) {
-
-		if (pDM_Odm->SupportICType & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
-			if (Adaptivity->AdajustIGILevel > IGI) 
-				Diff = Adaptivity->AdajustIGILevel - IGI;
-		
-			TH_L2H_dmc = pDM_Odm->TH_L2H_ini - Diff + IGI_target;
-			TH_H2L_dmc = TH_L2H_dmc - pDM_Odm->TH_EDCCA_HL_diff;
-		}
-#if (RTL8195A_SUPPORT == 0)
-		else	{
-			Diff = IGI_target - (s1Byte)IGI;
-			TH_L2H_dmc = pDM_Odm->TH_L2H_ini + Diff;
-			if (TH_L2H_dmc > 10)
-				TH_L2H_dmc = 10;
-
-			TH_H2L_dmc = TH_L2H_dmc - pDM_Odm->TH_EDCCA_HL_diff;
-
-			/*replace lower bound to prevent EDCCA always equal 1*/
-			if (TH_H2L_dmc < Adaptivity->H2L_lb)
-				TH_H2L_dmc = Adaptivity->H2L_lb;
-			if (TH_L2H_dmc < Adaptivity->L2H_lb)
-				TH_L2H_dmc = Adaptivity->L2H_lb;
-		}
-#endif
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("API :IGI=0x%x, TH_L2H_dmc = %d, TH_H2L_dmc = %d\n", IGI, TH_L2H_dmc, TH_H2L_dmc));
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_ADAPTIVITY, ODM_DBG_LOUD, ("API :Adaptivity_IGI_upper=0x%x, H2L_lb = 0x%x, L2H_lb = 0x%x\n", pDM_Odm->Adaptivity_IGI_upper, Adaptivity->H2L_lb, Adaptivity->L2H_lb));
-
-		Phydm_SetEDCCAThreshold(pDM_Odm, TH_H2L_dmc, TH_L2H_dmc);
-	}
-
-}
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	#if WPP_SOFTWARE_TRACE
+		#include "PhyDM_Adaptivity.tmh"
+	#endif
+#endif
+
+void
+phydm_dig_up_bound_lmt_en(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVITY) ||
+		(!dm->adaptivity_flag) ||
+		(!dm->is_linked) ||
+		(!dm->adaptivity_enable)
+	) {
+		adaptivity->igi_up_bound_lmt_cnt = 0;
+		adaptivity->igi_lmt_en = false;	
+		return;
+	}
+
+	if (dm->total_tp > 1) {
+		adaptivity->igi_lmt_en = true;			
+		adaptivity->igi_up_bound_lmt_cnt = adaptivity->igi_up_bound_lmt_val;
+		PHYDM_DBG(dm, DBG_ADPTVTY, "TP >1, Start limit IGI upper bound\n");
+	} else {
+		if (adaptivity->igi_up_bound_lmt_cnt == 0)
+			adaptivity->igi_lmt_en = false;
+		else
+			adaptivity->igi_up_bound_lmt_cnt--;
+	}
+
+	PHYDM_DBG(dm, DBG_ADPTVTY, "IGI_lmt_cnt = %d\n", adaptivity->igi_up_bound_lmt_cnt);
+}
+
+void
+phydm_check_adaptivity(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVITY)) {
+		dm->adaptivity_enable = false;
+		return;
+	}
+	
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (dm->ap_total_num > adaptivity->ap_num_th) {
+		dm->adaptivity_enable = false;
+		PHYDM_DBG(dm, DBG_ADPTVTY, "AP total num > %d!!, disable adaptivity\n", adaptivity->ap_num_th);
+		return;
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (adaptivity->dynamic_link_adaptivity) {
+		if (dm->is_linked && adaptivity->is_check == false) {
+			phydm_check_environment(dm);
+		} else if (!dm->is_linked)
+			adaptivity->is_check = false;
+
+		return;
+	}
+#endif
+	
+	dm->adaptivity_enable = true;
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+boolean
+phydm_check_channel_plan(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter	= dm->adapter;
+	PMGNT_INFO		mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+
+	if (mgnt_info->RegEnableAdaptivity == 2) {
+		if (dm->carrier_sense_enable == false) {		/*check domain Code for adaptivity or CarrierSense*/
+			if ((*dm->band_type == ODM_BAND_5G) &&
+				!(dm->odm_regulation_5g == REGULATION_ETSI || dm->odm_regulation_5g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity skip 5G domain code : %d\n", dm->odm_regulation_5g);
+				dm->adaptivity_enable = false;
+				return true;
+			} else if ((*dm->band_type == ODM_BAND_2_4G) &&
+				!(dm->odm_regulation_2_4g == REGULATION_ETSI || dm->odm_regulation_2_4g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity skip 2.4G domain code : %d\n", dm->odm_regulation_2_4g);
+				dm->adaptivity_enable = false;
+				return true;
+
+			} else if ((*dm->band_type != ODM_BAND_2_4G) && (*dm->band_type != ODM_BAND_5G)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity neither 2G nor 5G band, return\n");
+				dm->adaptivity_enable = false;
+				return true;
+			}
+		} else {
+			if ((*dm->band_type == ODM_BAND_5G) &&
+				!(dm->odm_regulation_5g == REGULATION_MKK || dm->odm_regulation_5g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "CarrierSense skip 5G domain code : %d\n", dm->odm_regulation_5g);
+				dm->adaptivity_enable = false;
+				return true;
+			}
+
+			else if ((*dm->band_type == ODM_BAND_2_4G) &&
+				!(dm->odm_regulation_2_4g == REGULATION_MKK  || dm->odm_regulation_2_4g == REGULATION_WW)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "CarrierSense skip 2.4G domain code : %d\n", dm->odm_regulation_2_4g);
+				dm->adaptivity_enable = false;
+				return true;
+
+			} else if ((*dm->band_type != ODM_BAND_2_4G) && (*dm->band_type != ODM_BAND_5G)) {
+				PHYDM_DBG(dm, DBG_ADPTVTY, "CarrierSense neither 2G nor 5G band, return\n");
+				dm->adaptivity_enable = false;
+				return true;
+			}
+		}
+	}
+
+	return false;
+
+}
+#endif
+
+void
+phydm_set_edcca_threshold(
+	void	*dm_void,
+	s8	H2L,
+	s8	L2H
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)((u8)L2H | (u8)H2L << 16));
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_set_bb_reg(dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)((u8)L2H | (u8)H2L << 8));
+#endif
+
+}
+
+void
+phydm_set_lna(
+	void				*dm_void,
+	enum phydm_set_lna	type
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E)) {
+		if (type == phydm_disable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x37f82);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x37f82);
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		} else if (type == phydm_enable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x77f82);	/*back to normal*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x77f82);
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		}
+	} else if (dm->support_ic_type & ODM_RTL8723B) {
+		if (type == phydm_disable_lna) {
+			/*S0*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0001f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xe6137);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			/*S1*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x43, 0xfffff, 0x3008d);	/*select Rx mode and disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x0);
+		} else if (type == phydm_enable_lna) {
+			/*S0*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0001f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xe6177);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			/*S1*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x43, 0xfffff, 0x300bd);	/*select Rx mode and disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xed, 0x00020, 0x0);
+		}
+
+	} else if (dm->support_ic_type & ODM_RTL8812) {
+		if (type == phydm_disable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		} else if (type == phydm_enable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+			if (dm->rf_type > RF_1T1R) {
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
+				odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
+				odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);
+			}
+		}
+	} else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
+		if (type == phydm_disable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0002f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xfb09b);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+		} else if (type == phydm_enable_lna) {
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0002f);
+			odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xfb0bb);	/*disable LNA*/
+			odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);
+		}
+	}
+}
+
+
+
+void
+phydm_set_trx_mux(
+	void				*dm_void,
+	enum phydm_trx_mux_type	tx_mode,
+	enum phydm_trx_mux_type	rx_mode
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N, BIT(3) | BIT(2) | BIT(1), tx_mode);			/*set TXmod to standby mode to remove outside noise affect*/
+		odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N, BIT(22) | BIT(21) | BIT(20), rx_mode);		/*set RXmod to standby mode to remove outside noise affect*/
+		if (dm->rf_type > RF_1T1R) {
+			odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT(3) | BIT(2) | BIT(1), tx_mode);		/*set TXmod to standby mode to remove outside noise affect*/
+			odm_set_bb_reg(dm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT(22) | BIT(21) | BIT(20), rx_mode);	/*set RXmod to standby mode to remove outside noise affect*/
+		}
+	}
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(11) | BIT(10) | BIT(9) | BIT(8), tx_mode);				/*set TXmod to standby mode to remove outside noise affect*/
+		odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(7) | BIT(6) | BIT(5) | BIT(4), rx_mode);				/*set RXmod to standby mode to remove outside noise affect*/
+		if (dm->rf_type > RF_1T1R) {
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC_B, BIT(11) | BIT(10) | BIT(9) | BIT(8), tx_mode);		/*set TXmod to standby mode to remove outside noise affect*/
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC_B, BIT(7) | BIT(6) | BIT(5) | BIT(4), rx_mode);			/*set RXmod to standby mode to remove outside noise affect*/
+		}
+	}
+#endif
+
+}
+
+void
+phydm_mac_edcca_state(
+	void					*dm_void,
+	enum phydm_mac_edcca_type		state
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (state == phydm_ignore_edcca) {
+		odm_set_mac_reg(dm, REG_TX_PTCL_CTRL, BIT(15), 1);	/*ignore EDCCA	reg520[15]=1*/
+		/*		odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 0);			*/ /*reg524[11]=0*/
+	} else {	/*don't set MAC ignore EDCCA signal*/
+		odm_set_mac_reg(dm, REG_TX_PTCL_CTRL, BIT(15), 0);	/*don't ignore EDCCA	 reg520[15]=0*/
+		/*		odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 1);			*/ /*reg524[11]=1	*/
+	}
+	PHYDM_DBG(dm, DBG_ADPTVTY, "EDCCA enable state = %d\n", state);
+
+}
+
+void
+phydm_search_pwdb_lower_bound(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u32			value32 = 0, reg_value32 = 0;
+	u8			cnt, try_count = 0;
+	u8			tx_edcca1 = 0;
+	boolean			is_adjust = true;
+	s8			th_l2h_dmc, th_h2l_dmc, igi_target = 0x32;
+	s8			diff;
+	u8			IGI = adaptivity->igi_base + 30 + (u8)dm->th_l2h_ini - (u8)dm->th_edcca_hl_diff;
+
+	if (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
+		phydm_set_lna(dm, phydm_disable_lna);
+
+	diff = igi_target - (s8)IGI;
+	th_l2h_dmc = dm->th_l2h_ini + diff;
+	if (th_l2h_dmc > 10)
+		th_l2h_dmc = 10;
+
+	th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+	phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+	ODM_delay_ms(30);
+
+	while (is_adjust) {
+		/*check CCA status*/
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, 0x0)) {/*set debug port to 0x0*/
+			reg_value32 = phydm_get_bb_dbg_port_value(dm);
+
+			while (reg_value32 & BIT(3) && try_count < 3) {
+				ODM_delay_ms(3);
+				try_count = try_count + 1;
+				reg_value32 = phydm_get_bb_dbg_port_value(dm);
+			}
+			phydm_release_bb_dbg_port(dm);
+			try_count = 0;
+		}
+
+		/*count EDCCA signal = 1 times*/
+		for (cnt = 0; cnt < 20; cnt++) {
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, adaptivity->adaptivity_dbg_port)) {
+				value32 = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+			}
+
+			if (value32 & BIT(30) && (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E)))
+				tx_edcca1 = tx_edcca1 + 1;
+			else if (value32 & BIT(29))
+				tx_edcca1 = tx_edcca1 + 1;
+		}
+
+		if (tx_edcca1 > 1) {
+			IGI = IGI - 1;
+			th_l2h_dmc = th_l2h_dmc + 1;
+			if (th_l2h_dmc > 10)
+				th_l2h_dmc = 10;
+
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+			phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+			tx_edcca1 = 0;
+			if (th_l2h_dmc == 10)
+				is_adjust = false;
+
+		} else
+			is_adjust = false;
+
+	}
+
+	adaptivity->adapt_igi_up = IGI - dm->dc_backoff;
+	adaptivity->h2l_lb = th_h2l_dmc + dm->dc_backoff;
+	adaptivity->l2h_lb = th_l2h_dmc + dm->dc_backoff;
+
+	if (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
+		phydm_set_lna(dm, phydm_enable_lna);
+
+	phydm_set_edcca_threshold(dm, 0x7f, 0x7f);				/*resume to no link state*/
+}
+
+boolean
+phydm_re_search_condition(
+	void				*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u8			adaptivity_igi_upper = adaptivity->adapt_igi_up + dm->dc_backoff;
+	/*s8		TH_L2H_dmc, IGI_target = 0x32;*/
+	/*s8		diff;*/
+
+	/*TH_L2H_dmc = 10;*/
+
+	/*diff = TH_L2H_dmc - dm->TH_L2H_ini;*/
+	/*lowest_IGI_upper = IGI_target - diff;*/
+	/*if ((adaptivity_igi_upper - lowest_IGI_upper) <= 5)*/
+
+	if (adaptivity_igi_upper <= 0x26)
+		return true;
+	else
+		return false;
+}
+
+void
+phydm_adaptivity_info_init(
+	void				*dm_void,
+	enum phydm_adapinfo	cmn_info,
+	u32				value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	switch (cmn_info)	{
+	case PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE:
+		dm->carrier_sense_enable = (boolean)value;
+		break;
+
+	case PHYDM_ADAPINFO_DCBACKOFF:
+		dm->dc_backoff = (u8)value;
+		break;
+
+	case PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY:
+		adaptivity->dynamic_link_adaptivity = (boolean)value;
+		break;
+
+	case PHYDM_ADAPINFO_TH_L2H_INI:
+		dm->th_l2h_ini = (s8)value;
+		break;
+
+	case PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF:
+		dm->th_edcca_hl_diff = (s8)value;
+		break;
+
+	case PHYDM_ADAPINFO_AP_NUM_TH:
+		adaptivity->ap_num_th = (u8)value;
+		break;
+
+	default:
+		break;
+
+	}
+
+}
+
+void
+phydm_adaptivity_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	s8	igi_target = 0x32;
+	/*struct phydm_dig_struct* dig_t = &dm->dm_dig_table;*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_WIN))
+
+	if (dm->carrier_sense_enable == false) {
+		if (dm->th_l2h_ini == 0)
+			phydm_set_l2h_th_ini(dm);
+	} else
+		dm->th_l2h_ini = 0xa;
+
+	if (dm->th_edcca_hl_diff == 0)
+		dm->th_edcca_hl_diff = 7;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	if (dm->wifi_test == true || *dm->mp_mode == true)
+#else
+	if ((dm->wifi_test & RT_WIFI_LOGO) == true)
+#endif
+		dm->edcca_enable = false;		/*even no adaptivity, we still enable EDCCA, AP side use mib control*/
+	else
+		dm->edcca_enable = true;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	if (dm->carrier_sense_enable) {
+		dm->th_l2h_ini = 0xa;
+		dm->th_edcca_hl_diff = 7;
+	} else {
+		dm->th_l2h_ini = dm->TH_L2H_default;	/*set by mib*/
+		dm->th_edcca_hl_diff = dm->th_edcca_hl_diff_default;
+	}
+
+	if (priv->pshare->rf_ft_var.adaptivity_enable == 2)
+		adaptivity->dynamic_link_adaptivity = true;
+	else
+		adaptivity->dynamic_link_adaptivity = false;
+
+#endif
+
+	adaptivity->adapt_igi_up = 0;
+	dm->adaptivity_enable = false;	/*use this flag to decide enable or disable*/
+
+	dm->th_l2h_ini_mode2 = 20;
+	dm->th_edcca_hl_diff_mode2 = 8;
+	adaptivity->debug_mode = false;
+	adaptivity->th_l2h_ini_backup = dm->th_l2h_ini;
+	adaptivity->th_edcca_hl_diff_backup = dm->th_edcca_hl_diff;
+
+	adaptivity->igi_base = 0x32;
+	adaptivity->igi_target = 0x1c;
+	adaptivity->h2l_lb = 0;
+	adaptivity->l2h_lb = 0;
+	adaptivity->is_check = false;
+	adaptivity->adajust_igi_level = 0;
+	adaptivity->is_stop_edcca = false;
+	adaptivity->backup_h2l = 0;
+	adaptivity->backup_l2h = 0;
+	adaptivity->adaptivity_dbg_port = (dm->support_ic_type & ODM_IC_11N_SERIES) ? 0x208 : 0x209;
+
+	phydm_mac_edcca_state(dm, phydm_dont_ignore_edcca);
+
+	if (dm->support_ic_type & ODM_IC_11N_GAIN_IDX_EDCCA) {
+		/*odm_set_bb_reg(dm, ODM_REG_EDCCA_DOWN_OPT_11N, BIT(12) | BIT(11) | BIT(10), 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
+		if (dm->support_ic_type & ODM_RTL8197F) {
+			odm_set_bb_reg(dm, ODM_REG_PAGE_B1_97F, BIT(30), 0x1);								/*set to page B1*/
+			odm_set_bb_reg(dm, ODM_REG_EDCCA_DCNF_97F, BIT(27) | BIT(26), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+			odm_set_bb_reg(dm, ODM_REG_PAGE_B1_97F, BIT(30), 0x0);
+		} else
+			odm_set_bb_reg(dm, ODM_REG_EDCCA_DCNF_11N, BIT(21) | BIT(20), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+	}
+#if (RTL8195A_SUPPORT == 0)
+	if (dm->support_ic_type & ODM_IC_11AC_GAIN_IDX_EDCCA) {		/*8814a no need to find pwdB lower bound, maybe*/
+		/*odm_set_bb_reg(dm, ODM_REG_EDCCA_DOWN_OPT, BIT(30) | BIT(29) | BIT(28), 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
+		odm_set_bb_reg(dm, ODM_REG_ACBB_EDCCA_ENHANCE, BIT(29) | BIT(28), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+	}
+
+	if (!(dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA))) {
+		phydm_search_pwdb_lower_bound(dm);
+		if (phydm_re_search_condition(dm))
+			phydm_search_pwdb_lower_bound(dm);
+	} else
+		phydm_set_edcca_threshold(dm, 0x7f, 0x7f);				/*resume to no link state*/
+#endif
+	/*forgetting factor setting*/
+	phydm_set_forgetting_factor(dm);
+
+	/*pwdb mode setting with 0: mean, 1:max*/
+	phydm_set_pwdb_mode(dm);
+
+	/*we need to consider PwdB upper bound for 8814 later IC*/
+	adaptivity->adajust_igi_level = (u8)((dm->th_l2h_ini + igi_target) - pwdb_upper_bound + dfir_loss);	/*IGI = L2H - PwdB - dfir_loss*/
+
+	/*Check this later on Windows*/
+	/*phydm_set_edcca_threshold_api(dm, dig_t->cur_ig_value);*/
+
+	dm->adaptivity_flag = (dm->support_ic_type & ODM_IC_GAIN_IDX_EDCCA) ? false : true;
+	
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	adaptivity->igi_up_bound_lmt_val = 180;
+#else
+	adaptivity->igi_up_bound_lmt_val = 90;
+#endif
+	adaptivity->igi_up_bound_lmt_cnt = 0;
+	adaptivity->igi_lmt_en = false;
+
+}
+
+
+void
+phydm_adaptivity(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct			*dig_t = &dm->dm_dig_table;
+	u8			igi = dig_t->cur_ig_value;
+	s8			th_l2h_dmc, th_h2l_dmc;
+	s8			diff = 0, igi_target = 0x32;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PADAPTER    adapter	= (PADAPTER)dm->adapter;
+	u32			is_fw_current_in_ps_mode = false;
+	u8			disable_ap_adapt_setting;
+
+	adapter->HalFunc.GetHwRegHandler(adapter, HW_VAR_FW_PSMODE_STATUS, (u8 *)(&is_fw_current_in_ps_mode));
+
+	/*Disable EDCCA mode while under LPS mode, added by Roger, 2012.09.14.*/
+	if (is_fw_current_in_ps_mode)
+		return;
+#endif
+
+	if (!dm->edcca_enable || adaptivity->is_stop_edcca) {
+		PHYDM_DBG(dm, DBG_ADPTVTY, "Disable EDCCA!!!\n");
+		return;
+	}
+
+	phydm_check_adaptivity(dm);	/*Check adaptivity enable*/
+	phydm_dig_up_bound_lmt_en(dm);
+
+	if ((!(dm->support_ability & ODM_BB_ADAPTIVITY)) && adaptivity->debug_mode == false) {
+		PHYDM_DBG(dm, DBG_ADPTVTY, "adaptivity disable, enable EDCCA mode!!!\n");
+		dm->th_l2h_ini = dm->th_l2h_ini_mode2;
+		dm->th_edcca_hl_diff = dm->th_edcca_hl_diff_mode2;
+	}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	else if (adaptivity->debug_mode == false) {
+		disable_ap_adapt_setting = false;
+		if (dm->soft_ap_mode != NULL) {
+			if (*dm->soft_ap_mode != 0 && (dm->soft_ap_special_setting & BIT(0)))
+				disable_ap_adapt_setting = true;
+			PHYDM_DBG(dm, DBG_ADPTVTY, "soft_ap_setting = %x, soft_ap = %d, dis_ap_adapt = %d\n", 
+				dm->soft_ap_special_setting, *dm->soft_ap_mode, disable_ap_adapt_setting);
+		}
+		if (phydm_check_channel_plan(dm) || (dm->ap_total_num > adaptivity->ap_num_th) || disable_ap_adapt_setting) {
+			dm->th_l2h_ini = dm->th_l2h_ini_mode2;
+			dm->th_edcca_hl_diff = dm->th_edcca_hl_diff_mode2;
+		} else {
+			dm->th_l2h_ini = adaptivity->th_l2h_ini_backup;
+			dm->th_edcca_hl_diff = adaptivity->th_edcca_hl_diff_backup;
+		}
+	}
+#endif
+	else if (adaptivity->debug_mode == true) {
+		dm->th_l2h_ini = adaptivity->th_l2h_ini_debug;
+		dm->th_edcca_hl_diff = 7;
+		adaptivity->adajust_igi_level = (u8)((dm->th_l2h_ini + igi_target) - pwdb_upper_bound + dfir_loss);	/*IGI = L2H - PwdB - dfir_loss*/
+	}
+	PHYDM_DBG(dm, DBG_ADPTVTY, "odm_Adaptivity() =====>\n");
+	PHYDM_DBG(dm, DBG_ADPTVTY, "igi_base=0x%x, th_l2h_ini = %d, th_edcca_hl_diff = %d\n",
+		adaptivity->igi_base, dm->th_l2h_ini, dm->th_edcca_hl_diff);
+#if (RTL8195A_SUPPORT == 0)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		/*fix AC series when enable EDCCA hang issue*/
+		odm_set_bb_reg(dm, 0x800, BIT(10), 1);	/*ADC_mask disable*/
+		odm_set_bb_reg(dm, 0x800, BIT(10), 0);	/*ADC_mask enable*/
+	}
+#endif
+
+	igi_target = adaptivity->igi_base;
+	adaptivity->igi_target = (u8) igi_target;
+
+	PHYDM_DBG(dm, DBG_ADPTVTY, "band_width=%s, igi_target=0x%x, dynamic_link_adaptivity = %d\n",
+		(*dm->band_width == CHANNEL_WIDTH_80) ? "80M" : ((*dm->band_width == CHANNEL_WIDTH_40) ? "40M" : "20M"), igi_target, adaptivity->dynamic_link_adaptivity);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "adajust_igi_level= 0x%x, adaptivity_flag = %d, adaptivity_enable = %d\n",
+		adaptivity->adajust_igi_level, dm->adaptivity_flag, dm->adaptivity_enable);
+
+	if (adaptivity->dynamic_link_adaptivity && (!dm->is_linked) && !dm->adaptivity_enable) {
+		phydm_set_edcca_threshold(dm, 0x7f, 0x7f);
+		PHYDM_DBG(dm, DBG_ADPTVTY, "In DynamicLink mode(noisy) and No link, Turn off EDCCA!!\n");
+		return;
+	}
+
+	if (dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+		if ((adaptivity->adajust_igi_level > igi) && dm->adaptivity_enable)
+			diff = adaptivity->adajust_igi_level - igi;
+		else if (dm->adaptivity_enable == false)
+			diff = 0x3e - igi;
+
+		th_l2h_dmc = dm->th_l2h_ini - diff + igi_target;
+		th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+	}
+#if (RTL8195A_SUPPORT == 0)
+	else	{
+		diff = igi_target - (s8)igi;
+		th_l2h_dmc = dm->th_l2h_ini + diff;
+		if (th_l2h_dmc > 10 && dm->adaptivity_enable)
+			th_l2h_dmc = 10;
+
+		th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+
+		/*replace lower bound to prevent EDCCA always equal 1*/
+		if (th_h2l_dmc < adaptivity->h2l_lb)
+			th_h2l_dmc = adaptivity->h2l_lb;
+		if (th_l2h_dmc < adaptivity->l2h_lb)
+			th_l2h_dmc = adaptivity->l2h_lb;
+	}
+#endif
+	adaptivity->th_l2h = th_l2h_dmc;
+	adaptivity->th_h2l = th_h2l_dmc;
+	PHYDM_DBG(dm, DBG_ADPTVTY, "IGI=0x%x, th_l2h_dmc = %d, th_h2l_dmc = %d\n", igi, th_l2h_dmc, th_h2l_dmc);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "adapt_igi_up=0x%x, h2l_lb = 0x%x, l2h_lb = 0x%x\n", adaptivity->adapt_igi_up, adaptivity->h2l_lb, adaptivity->l2h_lb);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "debug_mode = %d\n", adaptivity->debug_mode);
+	phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+
+	if (dm->adaptivity_enable == true)
+		odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 1);
+
+	return;
+}
+
+/*This API is for solving USB can't Tx problem due to USB3.0 interference in 2.4G*/
+void
+phydm_pause_edcca(
+	void	*dm_void,
+	boolean	is_pasue_edcca
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8	IGI = dig_t->cur_ig_value;
+	s8	diff = 0;
+
+	if (is_pasue_edcca) {
+		adaptivity->is_stop_edcca = true;
+
+		if (dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+			if (adaptivity->adajust_igi_level > IGI)
+				diff = adaptivity->adajust_igi_level - IGI;
+
+			adaptivity->backup_l2h = dm->th_l2h_ini - diff + adaptivity->igi_target;
+			adaptivity->backup_h2l = adaptivity->backup_l2h - dm->th_edcca_hl_diff;
+		}
+#if (RTL8195A_SUPPORT == 0)
+		else {
+			diff = adaptivity->igi_target - (s8)IGI;
+			adaptivity->backup_l2h = dm->th_l2h_ini + diff;
+			if (adaptivity->backup_l2h > 10)
+				adaptivity->backup_l2h = 10;
+
+			adaptivity->backup_h2l = adaptivity->backup_l2h - dm->th_edcca_hl_diff;
+
+			/*replace lower bound to prevent EDCCA always equal 1*/
+			if (adaptivity->backup_h2l < adaptivity->h2l_lb)
+				adaptivity->backup_h2l = adaptivity->h2l_lb;
+			if (adaptivity->backup_l2h < adaptivity->l2h_lb)
+				adaptivity->backup_l2h = adaptivity->l2h_lb;
+		}
+#endif
+		PHYDM_DBG(dm, DBG_ADPTVTY, "pauseEDCCA : L2Hbak = 0x%x, H2Lbak = 0x%x, IGI = 0x%x\n", adaptivity->backup_l2h, adaptivity->backup_h2l, IGI);
+
+		/*Disable EDCCA*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (odm_is_work_item_scheduled(&adaptivity->phydm_pause_edcca_work_item) == false)
+			odm_schedule_work_item(&adaptivity->phydm_pause_edcca_work_item);
+#else
+		phydm_pause_edcca_work_item_callback(dm);
+#endif
+
+	} else {
+		adaptivity->is_stop_edcca = false;
+		PHYDM_DBG(dm, DBG_ADPTVTY, "resumeEDCCA : L2Hbak = 0x%x, H2Lbak = 0x%x, IGI = 0x%x\n", adaptivity->backup_l2h, adaptivity->backup_h2l, IGI);
+		/*Resume EDCCA*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (odm_is_work_item_scheduled(&adaptivity->phydm_resume_edcca_work_item) == false)
+			odm_schedule_work_item(&adaptivity->phydm_resume_edcca_work_item);
+#else
+		phydm_resume_edcca_work_item_callback(dm);
+#endif
+
+	}
+
+}
+
+
+void
+phydm_pause_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)(0x7f | 0x7f << 16));
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_set_bb_reg(dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)(0x7f | 0x7f << 8));
+#endif
+
+}
+
+void
+phydm_resume_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)((u8)adaptivity->backup_l2h | (u8)adaptivity->backup_h2l << 16));
+#if (RTL8195A_SUPPORT == 0)
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_set_bb_reg(dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)((u8)adaptivity->backup_l2h | (u8)adaptivity->backup_h2l << 8));
+#endif
+
+}
+
+
+void
+phydm_set_edcca_threshold_api(
+	void	*dm_void,
+	u8	IGI
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	s8			th_l2h_dmc, th_h2l_dmc;
+	s8			diff = 0, igi_target = 0x32;
+
+	if (dm->support_ability & ODM_BB_ADAPTIVITY) {
+		if (dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+			if (adaptivity->adajust_igi_level > IGI)
+				diff = adaptivity->adajust_igi_level - IGI;
+
+			th_l2h_dmc = dm->th_l2h_ini - diff + igi_target;
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+		}
+#if (RTL8195A_SUPPORT == 0)
+		else	{
+			diff = igi_target - (s8)IGI;
+			th_l2h_dmc = dm->th_l2h_ini + diff;
+			if (th_l2h_dmc > 10)
+				th_l2h_dmc = 10;
+
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+
+			/*replace lower bound to prevent EDCCA always equal 1*/
+			if (th_h2l_dmc < adaptivity->h2l_lb)
+				th_h2l_dmc = adaptivity->h2l_lb;
+			if (th_l2h_dmc < adaptivity->l2h_lb)
+				th_l2h_dmc = adaptivity->l2h_lb;
+		}
+#endif
+		PHYDM_DBG(dm, DBG_ADPTVTY, "API :IGI=0x%x, th_l2h_dmc = %d, th_h2l_dmc = %d\n", IGI, th_l2h_dmc, th_h2l_dmc);
+		PHYDM_DBG(dm, DBG_ADPTVTY, "API :adapt_igi_up=0x%x, h2l_lb = 0x%x, l2h_lb = 0x%x\n", adaptivity->adapt_igi_up, adaptivity->h2l_lb, adaptivity->l2h_lb);
+
+		phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+	}
+}
+
+void
+phydm_adaptivity_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 reg_value32;
+	s8 h2l_diff = 0;
+
+	if (dm_value[0] == PHYDM_ADAPT_DEBUG) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Adaptivity Debug Mode ===>\n");
+		adaptivity->debug_mode = true;
+		adaptivity->th_l2h_ini_debug = (s8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "th_l2h_ini_debug = %d\n",
+			       adaptivity->th_l2h_ini_debug);
+	} else if (dm_value[0] == PHYDM_ADAPT_RESUME) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "===> Adaptivity Resume\n");
+		adaptivity->debug_mode = false;
+	} else if (dm_value[0] == PHYDM_EDCCA_TH_PAUSE) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "EDCCA Threshold Pause\n");
+		dm->edcca_enable = false;
+	} else if (dm_value[0] == PHYDM_EDCCA_RESUME) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "EDCCA Resume\n");
+		dm->edcca_enable = true;
+	} else if (dm_value[0] == PHYDM_ADAPT_MSG) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "debug_mode = %s, th_l2h_ini = %d\n",
+			       (adaptivity->debug_mode ? "TRUE" : "FALSE"),
+			       dm->th_l2h_ini);
+		if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			reg_value32 = odm_get_bb_reg(dm, 0xc4c, MASKDWORD);
+			h2l_diff = (s8)(0x000000ff & reg_value32) - (s8)((0x00ff0000 & reg_value32)>>16);
+		}
+#if (RTL8195A_SUPPORT == 0)
+		else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			reg_value32 = odm_get_bb_reg(dm, 0x8a4, MASKDWORD);
+			h2l_diff = (s8)(0x000000ff & reg_value32) - (s8)((0x0000ff00 & reg_value32)>>8);
+		}
+#endif
+		if (h2l_diff == 7)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "adaptivity is enabled\n");
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "adaptivity is disabled\n");
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_set_l2h_th_ini(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
+			dm->th_l2h_ini = 0xf2;
+		else
+			dm->th_l2h_ini = 0xef;
+	} else
+		dm->th_l2h_ini = 0xf5;
+}
+
+void
+phydm_set_forgetting_factor(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
+		odm_set_bb_reg(dm, 0x8a0, BIT(1) | BIT(0), 0);
+}
+
+void
+phydm_set_pwdb_mode(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ability & ODM_BB_ADAPTIVITY) {
+		if (dm->support_ic_type & ODM_RTL8822B)
+			odm_set_bb_reg(dm, 0x8dc, BIT(5), 0x1);
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0xce8, BIT(13), 0x1);
+	} else {
+		if (dm->support_ic_type & ODM_RTL8822B)
+			odm_set_bb_reg(dm, 0x8dc, BIT(5), 0x0);
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0xce8, BIT(13), 0x0);
+	}
+}
+
+void
+phydm_set_edcca_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (val_len != 2) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][adaptivity]Need val_len = 2\n");
+		return;
+	}
+	if (dm->pause_ability & BIT(F13_ADPTVTY))
+		dm->adaptivity.is_stop_edcca = true;
+	else
+		dm->adaptivity.is_stop_edcca = false;
+
+	phydm_set_edcca_threshold(dm, (s8)val_buf[1], (s8)val_buf[0]);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.h
index 6af28292c8ca..375593b5251b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adaptivity.h
@@ -1,172 +1,218 @@
-
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMADAPTIVITY_H__
-#define    __PHYDMADAPTIVITY_H__
-
-#define ADAPTIVITY_VERSION	"9.0"
-
-#define PwdBUpperBound	7
-#define DFIRloss	5
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-typedef enum _tag_PhyDM_REGULATION_Type {
-	REGULATION_FCC = 0,
-	REGULATION_MKK = 1,
-	REGULATION_ETSI = 2,
-	REGULATION_WW = 3,	
-	
-	MAX_REGULATION_NUM = 4
-} PhyDM_REGULATION_TYPE;
-#endif
-
-typedef enum tag_PhyDM_set_LNA {
-	PhyDM_disable_LNA		= 0,
-	PhyDM_enable_LNA		= 1,
-} PhyDM_set_LNA;
-
-
-typedef enum tag_PhyDM_TRx_MUX_Type
-{
-	PhyDM_SHUTDOWN			= 0,
-	PhyDM_STANDBY_MODE		= 1,
-	PhyDM_TX_MODE			= 2,
-	PhyDM_RX_MODE			= 3
-}PhyDM_Trx_MUX_Type;
-
-typedef enum tag_PhyDM_MACEDCCA_Type
-{
-	PhyDM_IGNORE_EDCCA			= 0,
-	PhyDM_DONT_IGNORE_EDCCA	= 1
-}PhyDM_MACEDCCA_Type;
-
-typedef struct _ADAPTIVITY_STATISTICS {
-	s1Byte			TH_L2H_ini_backup;
-	s1Byte			TH_EDCCA_HL_diff_backup;
-	s1Byte			IGI_Base;
-	u1Byte			IGI_target;
-	u1Byte			NHMWait;
-	s1Byte			H2L_lb;
-	s1Byte			L2H_lb;
-	BOOLEAN			bFirstLink;
-	BOOLEAN			bCheck;
-	BOOLEAN			DynamicLinkAdaptivity;
-	u1Byte			APNumTH;
-	u1Byte			AdajustIGILevel;
-} ADAPTIVITY_STATISTICS, *PADAPTIVITY_STATISTICS;
-
-VOID
-Phydm_CheckAdaptivity(
-	IN		PVOID			pDM_VOID
-	);
-
-VOID
-Phydm_CheckEnvironment(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-Phydm_NHMCounterStatisticsInit(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-Phydm_NHMCounterStatistics(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-Phydm_NHMCounterStatisticsReset(
-	IN		PVOID			pDM_VOID
-);
-
-VOID
-Phydm_GetNHMCounterStatistics(
-	IN		PVOID			pDM_VOID
-);
-
-VOID
-Phydm_MACEDCCAState(
-	IN	PVOID					pDM_VOID,
-	IN	PhyDM_MACEDCCA_Type		State
-);
-
-VOID
-Phydm_SetEDCCAThreshold(
-	IN		PVOID		pDM_VOID,
-	IN		s1Byte		H2L,
-	IN		s1Byte		L2H
-);
-
-VOID
-Phydm_SetTRxMux(
-	IN		PVOID			pDM_VOID,
-	IN		PhyDM_Trx_MUX_Type			txMode,
-	IN		PhyDM_Trx_MUX_Type			rxMode
-);	
-
-BOOLEAN
-Phydm_CalNHMcnt(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-Phydm_SearchPwdBLowerBound(
-	IN		PVOID					pDM_VOID
-);
-
-VOID 
-Phydm_AdaptivityInit(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-Phydm_Adaptivity(
-	IN		PVOID					pDM_VOID,
-	IN		u1Byte					IGI
-	);
-
-VOID
-phydm_setEDCCAThresholdAPI(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte	IGI
-);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-Phydm_DisableEDCCA(
-	IN		PVOID					pDM_VOID
-);
-
-VOID
-Phydm_DynamicEDCCA(
-	IN		PVOID					pDM_VOID
-);
-
-VOID
-Phydm_AdaptivityBSOD(
-	IN		PVOID					pDM_VOID
-);
-
-#endif
-
-
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDMADAPTIVITY_H__
+#define    __PHYDMADAPTIVITY_H__
+
+#define ADAPTIVITY_VERSION	"9.5.7"	/*20170627 changed by Kevin, move adapt_igi_up from phydm.h to phydm_adaptivity.h*/
+
+#define pwdb_upper_bound	7
+#define dfir_loss	7
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+enum phydm_regulation_type {
+	REGULATION_FCC		= 0,
+	REGULATION_MKK		= 1,
+	REGULATION_ETSI		= 2,
+	REGULATION_WW		= 3,
+	MAX_REGULATION_NUM	= 4
+};
+#endif
+
+enum phydm_adapinfo {
+	PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE = 0,
+	PHYDM_ADAPINFO_DCBACKOFF,
+	PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY,
+	PHYDM_ADAPINFO_TH_L2H_INI,
+	PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF,
+	PHYDM_ADAPINFO_AP_NUM_TH
+};
+
+enum phydm_set_lna {
+	phydm_disable_lna		= 0,
+	phydm_enable_lna		= 1,
+};
+
+enum phydm_trx_mux_type {
+	phydm_shutdown			= 0,
+	phydm_standby_mode		= 1,
+	phydm_tx_mode			= 2,
+	phydm_rx_mode			= 3
+};
+
+enum phydm_mac_edcca_type {
+	phydm_ignore_edcca			= 0,
+	phydm_dont_ignore_edcca		= 1
+};
+
+enum phydm_adaptivity_mode {
+	PHYDM_ADAPT_MSG			= 0,
+	PHYDM_ADAPT_DEBUG		= 1,
+	PHYDM_ADAPT_RESUME		= 2,
+	PHYDM_EDCCA_TH_PAUSE	= 3,
+	PHYDM_EDCCA_RESUME		= 4
+};
+
+struct phydm_adaptivity_struct {
+	s8			th_l2h_ini_backup;
+	s8			th_edcca_hl_diff_backup;
+	s8			igi_base;
+	u8			igi_target;
+	s8			h2l_lb;
+	s8			l2h_lb;
+	boolean		is_check;
+	boolean		dynamic_link_adaptivity;
+	u8			ap_num_th;
+	u8			adajust_igi_level;
+	s8			backup_l2h;
+	s8			backup_h2l;
+	boolean			is_stop_edcca;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_WORK_ITEM	phydm_pause_edcca_work_item;
+	RT_WORK_ITEM	phydm_resume_edcca_work_item;
+#endif
+	u32			adaptivity_dbg_port; /*N:0x208, AC:0x209*/
+	u8			debug_mode;
+	s8			th_l2h_ini_debug;
+	u16			igi_up_bound_lmt_cnt;	/*When igi_up_bound_lmt_cnt !=0, limit IGI upper bound to "adapt_igi_up"*/
+	u16			igi_up_bound_lmt_val;	/*max value of igi_up_bound_lmt_cnt*/
+	boolean		igi_lmt_en;
+	u8			adapt_igi_up;
+	s8			rvrt_val[2];
+	s8			th_l2h;
+	s8			th_h2l;
+};
+
+void
+phydm_pause_edcca(
+	void	*dm_void,
+	boolean	is_pasue_edcca
+);
+
+void
+phydm_check_environment(
+	void					*dm_void
+);
+
+void
+phydm_mac_edcca_state(
+	void					*dm_void,
+	enum phydm_mac_edcca_type		state
+);
+
+void
+phydm_set_edcca_threshold(
+	void		*dm_void,
+	s8		H2L,
+	s8		L2H
+);
+
+void
+phydm_set_trx_mux(
+	void			*dm_void,
+	enum phydm_trx_mux_type			tx_mode,
+	enum phydm_trx_mux_type			rx_mode
+);
+
+void
+phydm_search_pwdb_lower_bound(
+	void					*dm_void
+);
+
+void
+phydm_adaptivity_info_init(
+	void			*dm_void,
+	enum phydm_adapinfo	cmn_info,
+	u32				value
+);
+
+void
+phydm_adaptivity_init(
+	void					*dm_void
+);
+
+void
+phydm_adaptivity(
+	void			*dm_void
+);
+
+void
+phydm_set_edcca_threshold_api(
+	void	*dm_void,
+	u8	IGI
+);
+
+void
+phydm_pause_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+phydm_resume_edcca_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+phydm_adaptivity_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_set_l2h_th_ini(
+	void		*dm_void
+);
+
+void
+phydm_set_forgetting_factor(
+	void		*dm_void
+);
+
+void
+phydm_set_pwdb_mode(
+	void		*dm_void
+);
+
+void
+phydm_set_edcca_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adc_sampling.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adc_sampling.c
new file mode 100644
index 000000000000..07851c9c83e0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adc_sampling.c
@@ -0,0 +1,791 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#if ((RTL8197F_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
+		#include "rtl8197f/Hal8197FPhyReg.h"
+		#include "WlanHAL/HalMac88XX/halmac_reg2.h"
+	#else
+		#include "WlanHAL/HalHeader/HalComReg.h"
+	#endif
+#endif
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#if WPP_SOFTWARE_TRACE
+	#include "phydm_adc_sampling.tmh"
+#endif
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+boolean
+phydm_la_buffer_allocate(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+#endif
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	boolean	ret = true;
+
+	pr_debug("[LA mode BufferAllocate]\n");
+
+	if (adc_smp_buf->length == 0) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (PlatformAllocateMemoryWithZero(adapter, (void **)&adc_smp_buf->octet, adc_smp_buf->buffer_size) != RT_STATUS_SUCCESS)
+			ret = false;
+#else
+		odm_allocate_memory(dm, (void **)&adc_smp_buf->octet, adc_smp_buf->buffer_size);
+
+		if (!adc_smp_buf->octet)
+			ret = false;
+#endif
+
+		if (ret)
+			adc_smp_buf->length = adc_smp_buf->buffer_size;
+	}
+
+	return ret;
+}
+#endif
+
+void
+phydm_la_get_tx_pkt_buf(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	u32				i = 0, value32, data_l = 0, data_h = 0;
+	u32				addr, finish_addr;
+	u32				end_addr = (adc_smp_buf->start_pos  + adc_smp_buf->buffer_size) - 1;	/*end_addr = 0x3ffff;*/
+	boolean				is_round_up;
+	static u32			page = 0xFF;
+	u32				smp_cnt = 0, smp_number = 0, addr_8byte = 0;
+	u8				backup_dma = 0;
+
+	odm_memory_set(dm, adc_smp_buf->octet, 0, adc_smp_buf->length);
+	odm_write_1byte(dm, 0x0106, 0x69);
+
+	pr_debug("GetTxPktBuf\n");
+
+	value32 = odm_read_4byte(dm, 0x7c0);
+	is_round_up = (boolean)((value32 & BIT(31)) >> 31);
+	finish_addr = (value32 & 0x7FFF0000) >> 16;	/*Reg7C0[30:16]: finish addr (unit: 8byte)*/
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		odm_set_bb_reg(dm, 0x7c0, BIT(0), 0x0);
+		
+		/*Stop DMA*/
+		backup_dma = odm_get_mac_reg(dm, 0x300, MASKLWORD);
+		odm_set_mac_reg(dm, 0x300, 0x7fff, 0x7fff);
+
+		/*move LA mode content from IMEM to TxPktBuffer
+			Source : OCPBASE_IMEM 0x00000000
+			Destination : OCPBASE_TXBUF 0x18780000
+			Length : 64K*/
+		GET_HAL_INTERFACE(dm->priv)->init_ddma_handler(dm->priv, OCPBASE_IMEM, OCPBASE_TXBUF, 0x10000);
+	}
+	#endif
+	#endif
+
+	if (is_round_up) {
+		addr = (finish_addr + 1) << 3;
+		pr_debug("is_round_up = ((%d)), finish_addr=((0x%x)), 0x7c0=((0x%x))\n", is_round_up, finish_addr, value32);
+		smp_number = ((adc_smp_buf->buffer_size) >> 3);	/*Byte to 8Byte (64bit)*/
+	} else	 {
+		addr = adc_smp_buf->start_pos;
+		addr_8byte = addr >> 3;
+		
+		if (addr_8byte > finish_addr)
+			smp_number = addr_8byte - finish_addr;
+		else
+			smp_number = finish_addr - addr_8byte;
+
+		pr_debug("is_round_up = ((%d)), finish_addr=((0x%x * 8Byte)), Start_Addr = ((0x%x * 8Byte)), smp_number = ((%d))\n", is_round_up, finish_addr, addr_8byte, smp_number);
+
+	}
+	/*
+	dbg_print("is_round_up = %d, finish_addr=0x%x, value32=0x%x\n", is_round_up, finish_addr, value32);
+	dbg_print("end_addr = %x, adc_smp_buf->start_pos = 0x%x, adc_smp_buf->buffer_size = 0x%x\n", end_addr, adc_smp_buf->start_pos, adc_smp_buf->buffer_size);
+	*/
+
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		for (addr = 0x0, i = 0; addr < end_addr; addr += 8, i += 2) {	/*64K byte*/
+			if ((addr & 0xfff) == 0)
+				odm_set_bb_reg(dm, 0x0140, MASKLWORD, 0x780 + (addr >> 12));
+			data_l = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff), MASKDWORD);
+			data_h = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff) + 4, MASKDWORD);
+
+			pr_debug("%08x%08x\n", data_h, data_l);
+		}
+	} else {
+	
+		i = 0;
+		while (addr != (finish_addr << 3)) {
+			if (page != (addr >> 12)) {
+				/*Reg140=0x780+(addr>>12), addr=0x30~0x3F, total 16 pages*/
+				page = (addr >> 12);
+			}
+			odm_set_bb_reg(dm, 0x0140, MASKLWORD, 0x780 + page);
+
+			/*pDataL = 0x8000+(addr&0xfff);*/
+			data_l = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff), MASKDWORD);
+			data_h = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff) + 4, MASKDWORD);
+
+			#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+			adc_smp_buf->octet[i] = data_h;
+			adc_smp_buf->octet[i + 1] = data_l;
+			#endif
+
+		#if DBG /*WIN driver check build*/
+			pr_debug("%08x%08x\n", data_h, data_l);
+		#else	/*WIN driver free build*/
+			#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("%08x%08x\n", adc_smp_buf->octet[i], adc_smp_buf->octet[i + 1]));
+			#endif
+		#endif
+
+			i = i + 2;
+
+			if ((addr + 8) >= end_addr)
+				addr = adc_smp_buf->start_pos;
+			else
+				addr = addr + 8;
+
+			smp_cnt++;
+			if (smp_cnt >= (smp_number - 1))
+				break;
+		}
+		pr_debug("smp_cnt = ((%d))\n", smp_cnt);
+		
+		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("smp_cnt = ((%d))\n", smp_cnt));
+		#endif
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		odm_set_mac_reg(dm, 0x300, 0x7fff, backup_dma);	/*Resume DMA*/
+	#endif
+	#endif
+}
+
+void
+phydm_la_mode_set_mac_iq_dump(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+	u32			reg_value;
+
+	odm_write_1byte(dm, 0x7c0, 0);		/*clear all 0x7c0*/
+	odm_set_mac_reg(dm, 0x7c0, BIT(0), 1);  /*Enable LA mode HW block*/
+
+	if (adc_smp->la_trig_mode == PHYDM_MAC_TRIG) {
+		adc_smp->is_bb_trigger = 0;
+		odm_set_mac_reg(dm, 0x7c0, BIT(2), 1); /*polling bit for MAC mode*/
+		odm_set_mac_reg(dm, 0x7c0, BIT(4) | BIT(3), adc_smp->la_trigger_edge); /*trigger mode for MAC*/
+
+		pr_debug("[MAC_trig] ref_mask = ((0x%x)), ref_value = ((0x%x)), dbg_port = ((0x%x))\n", adc_smp->la_mac_mask_or_hdr_sel, adc_smp->la_trig_sig_sel, adc_smp->la_dbg_port);
+		/*[Set MAC Debug Port]*/
+		odm_set_mac_reg(dm, 0xF4, BIT(16), 1);
+		odm_set_mac_reg(dm, 0x38, 0xff0000, adc_smp->la_dbg_port);
+		odm_set_mac_reg(dm, 0x7c4, MASKDWORD, adc_smp->la_mac_mask_or_hdr_sel);
+		odm_set_mac_reg(dm, 0x7c8, MASKDWORD, adc_smp->la_trig_sig_sel);
+
+	} else {
+		adc_smp->is_bb_trigger = 1;
+		odm_set_mac_reg(dm, 0x7c0, BIT(1), 1); /*polling bit for BB ADC mode*/
+
+		if (adc_smp->la_trig_mode == PHYDM_ADC_MAC_TRIG) {
+			odm_set_mac_reg(dm, 0x7c0, BIT(3), 1); /*polling bit for MAC trigger event*/
+			odm_set_mac_reg(dm, 0x7c0, BIT(7) | BIT(6), adc_smp->la_trig_sig_sel);
+
+			if (adc_smp->la_trig_sig_sel == ADCSMP_TRIG_REG)
+				odm_set_mac_reg(dm, 0x7c0, BIT(5), 1); /* manual trigger 0x7C0[5] = 0->1*/
+		}
+	}
+
+	reg_value = odm_get_bb_reg(dm, 0x7c0, 0xff);
+	pr_debug("4. [Set MAC IQ dump] 0x7c0[7:0] = ((0x%x))\n", reg_value);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("4. [Set MAC IQ dump] 0x7c0[7:0] = ((0x%x))\n", reg_value));
+#endif
+
+}
+
+void
+phydm_adc_smp_start(
+	void			*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp				*adc_smp = &dm->adcsmp;
+	u8					tmp_u1b;
+	u8					while_cnt = 0;
+	u8					polling_ok = false, target_polling_bit;
+
+	phydm_la_mode_bb_setting(dm);
+	phydm_la_mode_set_trigger_time(dm, adc_smp->la_trigger_time);
+
+	if (dm->support_ic_type & ODM_RTL8197F)
+		odm_set_bb_reg(dm, 0xd00, BIT(26), 0x1);
+	else {	/*for 8814A and 8822B?*/
+		odm_write_1byte(dm, 0x8b4, 0x80);
+		/* odm_set_bb_reg(dm, 0x8b4, BIT(7), 1); */
+	}
+
+	phydm_la_mode_set_mac_iq_dump(dm);
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	watchdog_stop(dm->priv);
+	#endif
+
+	target_polling_bit = (adc_smp->is_bb_trigger) ? BIT(1) : BIT(2);
+	do { /*Polling time always use 100ms, when it exceed 2s, break while loop*/
+		tmp_u1b = odm_read_1byte(dm, 0x7c0);
+
+		if (adc_smp->adc_smp_state != ADCSMP_STATE_SET) {
+			pr_debug("[state Error] adc_smp_state != ADCSMP_STATE_SET\n");
+			break;
+
+		} else if (tmp_u1b & target_polling_bit) {
+			ODM_delay_ms(100);
+			while_cnt = while_cnt + 1;
+			continue;
+		} else {
+			pr_debug("[LA Query OK] polling_bit=((0x%x))\n", target_polling_bit);
+			polling_ok = true;
+			break;
+		}
+	} while (while_cnt < 20);
+
+	if (adc_smp->adc_smp_state == ADCSMP_STATE_SET) {
+		if (polling_ok)
+			phydm_la_get_tx_pkt_buf(dm);
+		else
+			pr_debug("[Polling timeout]\n");
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	watchdog_resume(dm->priv);
+	#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (adc_smp->adc_smp_state == ADCSMP_STATE_SET)
+		adc_smp->adc_smp_state = ADCSMP_STATE_QUERY;
+#endif
+
+	pr_debug("[LA mode] LA_pattern_count = ((%d))\n", adc_smp->la_count);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("[LA mode] la_count = ((%d))\n", adc_smp->la_count));
+#endif
+
+
+	adc_smp_stop(dm);
+
+	if (adc_smp->la_count == 0) {
+		pr_debug("LA Dump finished ---------->\n\n\n");
+		phydm_release_bb_dbg_port(dm);
+		
+		if ((dm->support_ic_type & ODM_RTL8821C) && (dm->cut_version >= ODM_CUT_B))
+			odm_set_bb_reg(dm, 0x95c, BIT(23), 0);
+
+	} else {
+		adc_smp->la_count--;
+		pr_debug("LA Dump more ---------->\n\n\n");
+		adc_smp_set(dm, adc_smp->la_trig_mode, adc_smp->la_trig_sig_sel, adc_smp->la_dma_type, adc_smp->la_trigger_time, 0);
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+void
+adc_smp_work_item_callback(
+	void	*context
+)
+{
+	void			*adapter = (void *)context;
+	PHAL_DATA_TYPE		hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+
+	pr_debug("[WorkItem Call back] LA_State=((%d))\n", adc_smp->adc_smp_state);
+	phydm_adc_smp_start(dm);
+}
+#endif
+
+void
+adc_smp_set(
+	void	*dm_void,
+	u8	trig_mode,
+	u32	trig_sig_sel,
+	u8	dma_data_sig_sel,
+	u32	trigger_time,
+	u16	polling_time
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	boolean				is_set_success = true;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+
+	adc_smp->la_trig_mode = trig_mode;
+	adc_smp->la_trig_sig_sel = trig_sig_sel;
+	adc_smp->la_dma_type = dma_data_sig_sel;
+	adc_smp->la_trigger_time = trigger_time;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (adc_smp->adc_smp_state != ADCSMP_STATE_IDLE)
+		is_set_success = false;
+	else if (adc_smp->adc_smp_buf.length == 0)
+		is_set_success = phydm_la_buffer_allocate(dm);
+#endif
+
+	if (is_set_success) {
+		adc_smp->adc_smp_state = ADCSMP_STATE_SET;
+
+		pr_debug("[LA Set Success] LA_State=((%d))\n", adc_smp->adc_smp_state);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+		pr_debug("ADCSmp_work_item_index = ((%d))\n", adc_smp->la_work_item_index);
+		if (adc_smp->la_work_item_index != 0) {
+			odm_schedule_work_item(&adc_smp->adc_smp_work_item_1);
+			adc_smp->la_work_item_index = 0;
+		} else {
+			odm_schedule_work_item(&adc_smp->adc_smp_work_item);
+			adc_smp->la_work_item_index = 1;
+		}
+#else
+		phydm_adc_smp_start(dm);
+#endif
+	} else
+		pr_debug("[LA Set Fail] LA_State=((%d))\n", adc_smp->adc_smp_state);
+
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+enum rt_status
+adc_smp_query(
+	void				*dm_void,
+	ULONG				information_buffer_length,
+	void				*information_buffer,
+	PULONG				bytes_written
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	enum rt_status			ret_status = RT_STATUS_SUCCESS;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	pr_debug("[%s] LA_State=((%d))", __func__, adc_smp->adc_smp_state);
+
+	if (information_buffer_length != adc_smp_buf->buffer_size)	{
+		*bytes_written = 0;
+		ret_status = RT_STATUS_RESOURCE;
+	} else if (adc_smp_buf->length != adc_smp_buf->buffer_size) {
+		*bytes_written = 0;
+		ret_status = RT_STATUS_RESOURCE;
+	} else if (adc_smp->adc_smp_state != ADCSMP_STATE_QUERY) {
+		*bytes_written = 0;
+		ret_status = RT_STATUS_PENDING;
+	} else {
+		odm_move_memory(dm, information_buffer, adc_smp_buf->octet, adc_smp_buf->buffer_size);
+		*bytes_written = adc_smp_buf->buffer_size;
+
+		adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
+	}
+
+	pr_debug("Return status %d\n", ret_status);
+
+	return ret_status;
+}
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+void
+adc_smp_query(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		*pused
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	u32 used = *pused;
+	u32 i;
+	/* struct timespec t; */
+	/* rtw_get_current_timespec(&t); */
+
+	pr_debug("%s adc_smp_state %d", __func__, adc_smp->adc_smp_state);
+
+	for (i = 0; i < (adc_smp_buf->length >> 2) - 2; i += 2) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%08x%08x\n", adc_smp_buf->octet[i],
+			       adc_smp_buf->octet[i + 1]);
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n");
+	/* PDM_SNPF((output+used, out_len-used, "\n[%lu.%06lu]\n", t.tv_sec, t.tv_nsec)); */
+	*pused = used;
+}
+
+s32
+adc_smp_get_sample_counts(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	return (adc_smp_buf->length >> 2) - 2;
+}
+
+s32
+adc_smp_query_single_data(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		index
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+	u32 used = 0;
+
+	/* dbg_print("%s adc_smp_state %d\n", __func__, adc_smp->adc_smp_state); */
+	if (adc_smp->adc_smp_state != ADCSMP_STATE_QUERY) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"Error: la data is not ready yet ...\n");
+		return -1;
+	}
+
+	if (index < ((adc_smp_buf->length >> 2) - 2)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%08x%08x\n",
+			       adc_smp_buf->octet[index],
+			       adc_smp_buf->octet[index + 1]);
+	}
+	return 0;
+}
+
+#endif
+
+void
+adc_smp_stop(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+
+	adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
+	pr_debug("[LA_Stop] LA_state = ((%d))\n", adc_smp->adc_smp_state);
+}
+
+void
+adc_smp_init(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
+
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		adc_smp_buf->start_pos = 0x30000;
+		adc_smp_buf->buffer_size = 0x10000;
+	} else if (dm->support_ic_type & ODM_RTL8822B) {
+		adc_smp_buf->start_pos = 0x20000;
+		adc_smp_buf->buffer_size = 0x20000;
+	} else if (dm->support_ic_type & ODM_RTL8197F) {
+		adc_smp_buf->start_pos = 0x00000;
+		adc_smp_buf->buffer_size = 0x10000;
+	} else if (dm->support_ic_type & ODM_RTL8821C) {
+		adc_smp_buf->start_pos = 0x8000;
+		adc_smp_buf->buffer_size = 0x8000;
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+adc_smp_de_init(
+	void			*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp			*adc_smp = &dm->adcsmp;
+	struct rt_adcsmp_string	*adc_smp_buf = &adc_smp->adc_smp_buf;
+
+	adc_smp_stop(dm);
+
+	if (adc_smp_buf->length != 0x0) {
+		odm_free_memory(dm, adc_smp_buf->octet, adc_smp_buf->length);
+		adc_smp_buf->length = 0x0;
+	}
+}
+
+#endif
+
+
+void
+phydm_la_mode_bb_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp		*adc_smp = &dm->adcsmp;
+
+	u8	trig_mode = adc_smp->la_trig_mode;
+	u32	trig_sig_sel = adc_smp->la_trig_sig_sel;
+	u32	dbg_port = adc_smp->la_dbg_port;
+	u8	is_trigger_edge = adc_smp->la_trigger_edge;
+	u8	sampling_rate = adc_smp->la_smp_rate;
+	u8	la_dma_type = adc_smp->la_dma_type;
+	u32	dbg_port_header_sel = 0;
+
+	pr_debug("1. [BB Setting] trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
+		trig_mode, dbg_port, is_trigger_edge, sampling_rate, trig_sig_sel, la_dma_type);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("1. [LA mode bb_setting]trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
+		trig_mode, dbg_port, is_trigger_edge, sampling_rate, trig_sig_sel, la_dma_type));
+#endif
+
+	if (trig_mode == PHYDM_MAC_TRIG)
+		trig_sig_sel = 0; /*ignore this setting*/
+
+	/*set BB debug port*/
+	if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, dbg_port)) {
+		pr_debug("Set dbg_port((0x%x)) success\n", dbg_port);
+	}
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (trig_mode == PHYDM_ADC_RF0_TRIG)
+			dbg_port_header_sel = 9;	/*DBGOUT_RFC_a[31:0]*/
+		else if (trig_mode == PHYDM_ADC_RF1_TRIG)
+			dbg_port_header_sel = 8;	/*DBGOUT_RFC_b[31:0]*/
+		else if ((trig_mode == PHYDM_ADC_BB_TRIG) || (trig_mode == PHYDM_ADC_MAC_TRIG)) {
+			
+			if (adc_smp->la_mac_mask_or_hdr_sel <= 0xf) {
+				dbg_port_header_sel = adc_smp->la_mac_mask_or_hdr_sel;
+			} else {
+				dbg_port_header_sel = 0;
+			}
+		}
+
+		phydm_bb_dbg_port_header_sel(dm, dbg_port_header_sel);
+
+		odm_set_bb_reg(dm, 0x95c, 0xf00, la_dma_type);	/*0x95C[11:8]*/
+		odm_set_bb_reg(dm, 0x95C, 0x1f, trig_sig_sel);	/*0x95C[4:0], BB debug port bit*/
+		odm_set_bb_reg(dm, 0x95C, BIT(31), is_trigger_edge); /*0: posedge, 1: negedge*/
+		odm_set_bb_reg(dm, 0x95c, 0xe0, sampling_rate);
+		/*	(0:) '80MHz'
+			(1:) '40MHz'
+			(2:) '20MHz'
+			(3:) '10MHz'
+			(4:) '5MHz'
+			(5:) '2.5MHz'
+			(6:) '1.25MHz'
+			(7:) '160MHz (for BW160 ic)'
+		*/
+		if ((dm->support_ic_type & ODM_RTL8821C) && (dm->cut_version >= ODM_CUT_B)) {
+			odm_set_bb_reg(dm, 0x95c, BIT(23), 1);
+		}
+	} else {
+		odm_set_bb_reg(dm, 0x9a0, 0xf00, la_dma_type);	/*0x9A0[11:8]*/
+		odm_set_bb_reg(dm, 0x9a0, 0x1f, trig_sig_sel);	/*0x9A0[4:0], BB debug port bit*/
+		odm_set_bb_reg(dm, 0x9A0, BIT(31), is_trigger_edge); /*0: posedge, 1: negedge*/
+		odm_set_bb_reg(dm, 0x9A0, 0xe0, sampling_rate);
+		/*	(0:) '80MHz'
+			(1:) '40MHz'
+			(2:) '20MHz'
+			(3:) '10MHz'
+			(4:) '5MHz'
+			(5:) '2.5MHz'
+			(6:) '1.25MHz'
+			(7:) '160MHz (for BW160 ic)'
+		*/
+	}
+}
+
+void
+phydm_la_mode_set_trigger_time(
+	void		*dm_void,
+	u32		trigger_time_mu_sec
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			trigger_time_unit_num;
+	u32			time_unit = 0;
+
+	if (trigger_time_mu_sec < 128) {
+		time_unit = 0; /*unit: 1mu sec*/
+	} else if (trigger_time_mu_sec < 256) {
+		time_unit = 1; /*unit: 2mu sec*/
+	} else if (trigger_time_mu_sec < 512) {
+		time_unit = 2; /*unit: 4mu sec*/
+	} else if (trigger_time_mu_sec < 1024) {
+		time_unit = 3; /*unit: 8mu sec*/
+	} else if (trigger_time_mu_sec < 2048) {
+		time_unit = 4; /*unit: 16mu sec*/
+	} else if (trigger_time_mu_sec < 4096) {
+		time_unit = 5; /*unit: 32mu sec*/
+	} else if (trigger_time_mu_sec < 8192) {
+		time_unit = 6; /*unit: 64mu sec*/
+	}
+
+	trigger_time_unit_num = (u8)(trigger_time_mu_sec >> time_unit);
+
+	pr_debug("2. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n", trigger_time_unit_num, time_unit);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("3. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n", trigger_time_unit_num, time_unit));
+#endif
+
+	odm_set_mac_reg(dm, 0x7cc, BIT(20) | BIT(19) | BIT(18), time_unit);
+	odm_set_mac_reg(dm, 0x7c0, 0x7f00, (trigger_time_unit_num & 0x7f));
+
+}
+
+
+void
+phydm_lamode_trigger_setting(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp	*adc_smp = &dm->adcsmp;
+	u8		trig_mode, dma_data_sig_sel;
+	u32		trig_sig_sel;
+	boolean		is_enable_la_mode;
+	u32		trigger_time_mu_sec;
+	char 		help[] = "-h";
+	u32			var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & PHYDM_IC_SUPPORT_LA_MODE) {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+		is_enable_la_mode = (boolean)var1[0];
+		/*dbg_print("echo cmd input_num = %d\n", input_num);*/
+
+		if ((strcmp(input[1], help) == 0)) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "{En} {0:BB,1:BB_MAC,2:RF0,3:RF1,4:MAC} \n {BB:dbg_port[bit],BB_MAC:0-ok/1-fail/2-cca,MAC:ref} {DMA type} {TrigTime} \n {DbgPort_head/ref_mask} {dbg_port} {0:P_Edge, 1:N_Edge} {SpRate:0-80M,1-40M,2-20M} {Capture num}\n");
+			/**/
+		} else if ((is_enable_la_mode == 1)) {
+			PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
+
+			trig_mode = (u8)var1[1];
+
+			if (trig_mode == PHYDM_MAC_TRIG)
+				PHYDM_SSCANF(input[3], DCMD_HEX, &var1[2]);
+			else
+				PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+			trig_sig_sel = var1[2];
+
+			PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
+			PHYDM_SSCANF(input[5], DCMD_DECIMAL, &var1[4]);
+			PHYDM_SSCANF(input[6], DCMD_HEX, &var1[5]);
+			PHYDM_SSCANF(input[7], DCMD_HEX, &var1[6]);
+			PHYDM_SSCANF(input[8], DCMD_DECIMAL, &var1[7]);
+			PHYDM_SSCANF(input[9], DCMD_DECIMAL, &var1[8]);
+			PHYDM_SSCANF(input[10], DCMD_DECIMAL, &var1[9]);
+
+			dma_data_sig_sel = (u8)var1[3];
+			trigger_time_mu_sec = var1[4]; /*unit: us*/
+
+			adc_smp->la_mac_mask_or_hdr_sel = var1[5];
+			adc_smp->la_dbg_port = var1[6];
+			adc_smp->la_trigger_edge = (u8) var1[7];
+			adc_smp->la_smp_rate = (u8)(var1[8] & 0x7);
+			adc_smp->la_count = var1[9];
+
+
+			pr_debug("echo lamode %d %d %d %d %d %d %x %d %d %d\n", var1[0], var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], var1[7], var1[8], var1[9]);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("echo lamode %d %d %d %d %d %d %x %d %d %d\n", var1[0], var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], var1[7], var1[8], var1[9]));
+#endif
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "a.En= ((1)),  b.mode = ((%d)), c.Trig_Sel = ((0x%x)), d.Dma_type = ((%d))\n",
+				       trig_mode, trig_sig_sel,
+				       dma_data_sig_sel);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "e.Trig_Time = ((%dus)), f.Dbg_head/mac_ref_mask = ((0x%x)), g.dbg_port = ((0x%x))\n",
+				       trigger_time_mu_sec,
+				       adc_smp->la_mac_mask_or_hdr_sel,
+				       adc_smp->la_dbg_port);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "h.Trig_edge = ((%d)), i.smp rate = ((%d MHz)), j.Cap_num = ((%d))\n",
+				       adc_smp->la_trigger_edge,
+				       (80 >> adc_smp->la_smp_rate),
+				       adc_smp->la_count);
+
+			adc_smp_set(dm, trig_mode, trig_sig_sel, dma_data_sig_sel, trigger_time_mu_sec, 0);
+
+		} else {
+			adc_smp_stop(dm);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Disable LA mode\n");
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif	/*endif PHYDM_LA_MODE_SUPPORT == 1*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adc_sampling.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adc_sampling.h
new file mode 100644
index 000000000000..b68c00fdd735
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_adc_sampling.h
@@ -0,0 +1,173 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __INC_ADCSMP_H
+#define __INC_ADCSMP_H
+
+#define DYNAMIC_LA_MODE	"2.0"  /*2017.02.06  Dino */
+
+#if (PHYDM_LA_MODE_SUPPORT == 1)
+
+struct rt_adcsmp_string {
+	u32		*octet;
+	u32		length;
+	u32		buffer_size;
+	u32		start_pos;
+};
+
+
+enum rt_adcsmp_trig_sel {
+	PHYDM_ADC_BB_TRIG	= 0,
+	PHYDM_ADC_MAC_TRIG	= 1,
+	PHYDM_ADC_RF0_TRIG	= 2,
+	PHYDM_ADC_RF1_TRIG	= 3,
+	PHYDM_MAC_TRIG		= 4
+};
+
+
+enum rt_adcsmp_trig_sig_sel {
+	ADCSMP_TRIG_CRCOK	= 0,
+	ADCSMP_TRIG_CRCFAIL	= 1,
+	ADCSMP_TRIG_CCA		= 2,
+	ADCSMP_TRIG_REG		= 3
+};
+
+
+enum rt_adcsmp_state {
+	ADCSMP_STATE_IDLE		= 0,
+	ADCSMP_STATE_SET		= 1,
+	ADCSMP_STATE_QUERY	=	2
+};
+
+
+struct rt_adcsmp {
+	struct rt_adcsmp_string		adc_smp_buf;
+	enum rt_adcsmp_state		adc_smp_state;
+	u8					la_trig_mode;
+	u32					la_trig_sig_sel;
+	u8					la_dma_type;
+	u32					la_trigger_time;
+	u32					la_mac_mask_or_hdr_sel; /*1.BB mode: for debug port header sel; 2.MAC mode: for reference mask*/
+	u32					la_dbg_port;
+	u8					la_trigger_edge;
+	u8					la_smp_rate;
+	u32					la_count;
+	u8					is_bb_trigger;
+	u8					la_work_item_index;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_WORK_ITEM	adc_smp_work_item;
+	RT_WORK_ITEM	adc_smp_work_item_1;
+#endif
+};
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+void
+adc_smp_work_item_callback(
+	void	*context
+);
+#endif
+
+void
+adc_smp_set(
+	void	*dm_void,
+	u8	trig_mode,
+	u32	trig_sig_sel,
+	u8	dma_data_sig_sel,
+	u32	trigger_time,
+	u16	polling_time
+);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+enum rt_status
+adc_smp_query(
+	void	*dm_void,
+	ULONG	information_buffer_length,
+	void	*information_buffer,
+	PULONG	bytes_written
+);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+void
+adc_smp_query(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		*pused
+);
+
+s32
+adc_smp_get_sample_counts(
+	void		*dm_void
+);
+
+s32
+adc_smp_query_single_data(
+	void		*dm_void,
+	void		*output,
+	u32		out_len,
+	u32		index
+);
+
+#endif
+void
+adc_smp_stop(
+	void	*dm_void
+);
+
+void
+adc_smp_init(
+	void	*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+adc_smp_de_init(
+	void			*dm_void
+);
+#endif
+
+void
+phydm_la_mode_bb_setting(
+	void		*dm_void
+);
+
+void
+phydm_la_mode_set_trigger_time(
+	void		*dm_void,
+	u32		trigger_time_mu_sec
+);
+
+void
+phydm_lamode_trigger_setting(
+	void		*dm_void,
+	char			input[][16],
+	u32		*_used,
+	char			*output,
+	u32		*_out_len,
+	u32		input_num
+);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.c
index 862c5971fae9..f35728198cb6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.c
@@ -1,964 +1,844 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-//#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE))
-#if(defined(CONFIG_ANT_DETECTION))
-
-//IS_ANT_DETECT_SUPPORT_SINGLE_TONE(Adapter)	
-//IS_ANT_DETECT_SUPPORT_RSSI(Adapter)		
-//IS_ANT_DETECT_SUPPORT_PSD(Adapter)
-
-//1 [1. Single Tone Method] ===================================================
-
-//
-// 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(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	PADAPTER	pAdapter	 =  pDM_Odm->Adapter;
-
-	u1Byte btAntNum=BT_GetPgAntNum(pAdapter);
-	// Set default antenna A and B status
-	if(btAntNum == 2)
-	{
-		pDM_SWAT_Table->ANTA_ON=TRUE;
-		pDM_SWAT_Table->ANTB_ON=TRUE;
-	
-	}
-	else if(btAntNum == 1)
-	{// Set antenna A as default
-		pDM_SWAT_Table->ANTA_ON=TRUE;
-		pDM_SWAT_Table->ANTB_ON=FALSE;
-	
-	}
-	else
-	{
-		RT_ASSERT(FALSE, ("Incorrect antenna number!!\n"));
-	}
-}
-
-
-//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. 
-//
-// Added by Roger, 2011.12.15
-//
-BOOLEAN
-ODM_SingleDualAntennaDetection(
-	IN		PVOID		pDM_VOID,
-	IN		u1Byte			mode
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER	pAdapter	 =  pDM_Odm->Adapter;
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	u4Byte		CurrentChannel,RfLoopReg;
-	u1Byte		n;
-	u4Byte		Reg88c, Regc08, Reg874, Regc50, Reg948, Regb2c, Reg92c, Reg930, Reg064, AFE_rRx_Wait_CCA;
-	u1Byte		initial_gain = 0x5a;
-	u4Byte		PSD_report_tmp;
-	u4Byte		AntA_report = 0x0, AntB_report = 0x0, AntO_report = 0x0;
-	BOOLEAN		bResult = TRUE;
-	u4Byte		AFE_Backup[16];
-	u4Byte		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};
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SingleDualAntennaDetection()============>\n"));	
-
-	
-	if (!(pDM_Odm->SupportICType & ODM_RTL8723B))
-		return bResult;
-
-	// Retrieve antenna detection registry info, added by Roger, 2012.11.27.
-	if(!IS_ANT_DETECT_SUPPORT_SINGLE_TONE(pAdapter))
-		return bResult;
-
-	//1 Backup Current RF/BB Settings	
-	
-	CurrentChannel = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, ODM_CHANNEL, bRFRegOffsetMask);
-	RfLoopReg = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x00, bRFRegOffsetMask);
-	if (pDM_Odm->SupportICType & ODM_RTL8723B) {
-		Reg92c = ODM_GetBBReg(pDM_Odm, rDPDT_control, bMaskDWord);	
-		Reg930 = ODM_GetBBReg(pDM_Odm, rfe_ctrl_anta_src, bMaskDWord);
-		Reg948 = ODM_GetBBReg(pDM_Odm, rS0S1_PathSwitch, bMaskDWord);
-		Regb2c = ODM_GetBBReg(pDM_Odm, rAGC_table_select, bMaskDWord);
-		Reg064 = ODM_GetMACReg(pDM_Odm, rSYM_WLBT_PAPE_SEL, BIT29);
-		ODM_SetBBReg(pDM_Odm, rDPDT_control, 0x3, 0x1);
-		ODM_SetBBReg(pDM_Odm, rfe_ctrl_anta_src, 0xff, 0x77);
-		ODM_SetMACReg(pDM_Odm, rSYM_WLBT_PAPE_SEL, BIT29, 0x1);  //dbg 7
-		ODM_SetBBReg(pDM_Odm, rS0S1_PathSwitch, 0x3c0, 0x0);//dbg 8
-		ODM_SetBBReg(pDM_Odm, rAGC_table_select, BIT31, 0x0);
-	}
-
-	ODM_StallExecution(10);
-	
-	//Store A Path Register 88c, c08, 874, c50
-	Reg88c = ODM_GetBBReg(pDM_Odm, rFPGA0_AnalogParameter4, bMaskDWord);
-	Regc08 = ODM_GetBBReg(pDM_Odm, rOFDM0_TRMuxPar, bMaskDWord);
-	Reg874 = ODM_GetBBReg(pDM_Odm, rFPGA0_XCD_RFInterfaceSW, bMaskDWord);
-	Regc50 = ODM_GetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskDWord);	
-	
-	// Store AFE Registers
-	if (pDM_Odm->SupportICType & ODM_RTL8723B)
-		AFE_rRx_Wait_CCA = ODM_GetBBReg(pDM_Odm, rRx_Wait_CCA,bMaskDWord);
-	
-	//Set PSD 128 pts
-	ODM_SetBBReg(pDM_Odm, rFPGA0_PSDFunction, BIT14|BIT15, 0x0);  //128 pts
-	
-	// To SET CH1 to do
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, ODM_CHANNEL, bRFRegOffsetMask, 0x7401);     //Channel 1
-	
-	// AFE all on step
-	if (pDM_Odm->SupportICType & ODM_RTL8723B)
-		ODM_SetBBReg(pDM_Odm, rRx_Wait_CCA, bMaskDWord, 0x01c00016);
-
-	// 3 wire Disable
-	ODM_SetBBReg(pDM_Odm, rFPGA0_AnalogParameter4, bMaskDWord, 0xCCF000C0);
-	
-	//BB IQK Setting
-	ODM_SetBBReg(pDM_Odm, rOFDM0_TRMuxPar, bMaskDWord, 0x000800E4);
-	ODM_SetBBReg(pDM_Odm, rFPGA0_XCD_RFInterfaceSW, bMaskDWord, 0x22208000);
-
-	//IQK setting tone@ 4.34Mhz
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x10008C1C);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK, bMaskDWord, 0x01007c00);	
-
-	//Page B init
-	ODM_SetBBReg(pDM_Odm, rConfig_AntA, bMaskDWord, 0x00080000);
-	ODM_SetBBReg(pDM_Odm, rConfig_AntA, bMaskDWord, 0x0f600000);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK, bMaskDWord, 0x01004800);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x10008c1f);
-	if (pDM_Odm->SupportICType & ODM_RTL8723B) {
-		ODM_SetBBReg(pDM_Odm, rTx_IQK_PI_A, bMaskDWord, 0x82150016);
-		ODM_SetBBReg(pDM_Odm, rRx_IQK_PI_A, bMaskDWord, 0x28150016);
-	}
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Rsp, bMaskDWord, 0x001028d0);	
-	ODM_SetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, 0x7f, initial_gain);
-
-	//IQK Single tone start
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, 0xffffff00, 0x808000);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf9000000);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf8000000);
-	
-	ODM_StallExecution(10000);
-
-	// PSD report of antenna A
-	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;
-	}
-
-	 // change to Antenna B
-	if (pDM_Odm->SupportICType & ODM_RTL8723B) {
-		//ODM_SetBBReg(pDM_Odm, rDPDT_control, 0x3, 0x2);
-		ODM_SetBBReg(pDM_Odm, rS0S1_PathSwitch, 0xfff, 0x280);
-		ODM_SetBBReg(pDM_Odm, rAGC_table_select, BIT31, 0x1);
-	}
-
-	ODM_StallExecution(10);	
-
-	// PSD report of antenna B
-	PSD_report_tmp=0x0;
-	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;
-	}
-
-	//Close IQK Single Tone function
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, 0xffffff00, 0x000000);
-
-	//1 Return to antanna A
-	if (pDM_Odm->SupportICType & ODM_RTL8723B) {
-		// external DPDT
-		ODM_SetBBReg(pDM_Odm, rDPDT_control, bMaskDWord, Reg92c);
-
-		//internal S0/S1
-		ODM_SetBBReg(pDM_Odm, rS0S1_PathSwitch, bMaskDWord, Reg948);
-		ODM_SetBBReg(pDM_Odm, rAGC_table_select, bMaskDWord, Regb2c);
-		ODM_SetBBReg(pDM_Odm, rfe_ctrl_anta_src, bMaskDWord, Reg930);
-		ODM_SetMACReg(pDM_Odm, rSYM_WLBT_PAPE_SEL, BIT29, Reg064);
-	}
-	
-	ODM_SetBBReg(pDM_Odm, rFPGA0_AnalogParameter4, bMaskDWord, Reg88c);
-	ODM_SetBBReg(pDM_Odm, rOFDM0_TRMuxPar, bMaskDWord, Regc08);
-	ODM_SetBBReg(pDM_Odm, rFPGA0_XCD_RFInterfaceSW, bMaskDWord, Reg874);
-	ODM_SetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, 0x7F, 0x40);
-	ODM_SetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskDWord, Regc50);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask,CurrentChannel);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x00, bRFRegOffsetMask,RfLoopReg);
-
-	//Reload AFE Registers
-	if (pDM_Odm->SupportICType & ODM_RTL8723B)
-		ODM_SetBBReg(pDM_Odm, rRx_Wait_CCA, bMaskDWord, AFE_rRx_Wait_CCA);
-
-	if (pDM_Odm->SupportICType & ODM_RTL8723B) {
-		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));	
-		
-		//2 Test Ant B based on Ant A is ON
-		if((AntA_report >= 100) && (AntB_report >= 100) && (AntA_report <= 135) && (AntB_report <= 135))
-		{
-			u1Byte TH1=2, TH2=6;
-		
-			if((AntA_report - AntB_report < TH1) || (AntB_report - AntA_report < TH1))
-			{
-				pDM_SWAT_Table->ANTA_ON=TRUE;
-				pDM_SWAT_Table->ANTB_ON=TRUE;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("ODM_SingleDualAntennaDetection(): Dual Antenna\n"));
-			}
-			else if(((AntA_report - AntB_report >= TH1) && (AntA_report - AntB_report <= TH2)) || 
-				((AntB_report - AntA_report >= TH1) && (AntB_report - AntA_report <= TH2)))
-			{
-				pDM_SWAT_Table->ANTA_ON=FALSE;
-				pDM_SWAT_Table->ANTB_ON=FALSE;
-				bResult = FALSE;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SingleDualAntennaDetection(): Need to check again\n"));
-			}
-			else
-			{
-				pDM_SWAT_Table->ANTA_ON = TRUE;
-				pDM_SWAT_Table->ANTB_ON=FALSE;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("ODM_SingleDualAntennaDetection(): Single Antenna\n"));
-			}
-			pDM_Odm->AntDetectedInfo.bAntDetected= TRUE;
-			pDM_Odm->AntDetectedInfo.dBForAntA = AntA_report;
-			pDM_Odm->AntDetectedInfo.dBForAntB = AntB_report;
-			pDM_Odm->AntDetectedInfo.dBForAntO = AntO_report;
-				
-		}
-		else
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("return FALSE!!\n"));
-			bResult = FALSE;
-		}
-	}
-	return bResult;
-
-}
-
-
-
-//1 [2. Scan AP RSSI Method] ==================================================
-
-
-
-
-BOOLEAN
-ODM_SwAntDivCheckBeforeLink(
-	IN		PVOID		pDM_VOID
-	)
-{
-
-#if (RT_MEM_SIZE_LEVEL != RT_MEM_SIZE_MINIMUM)
-
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE*	pHalData = GET_HAL_DATA(Adapter);
-	PMGNT_INFO		pMgntInfo = &Adapter->MgntInfo;
-	pSWAT_T			pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	s1Byte			Score = 0;
-	PRT_WLAN_BSS	pTmpBssDesc, pTestBssDesc;
-	u1Byte			power_target_L = 9, power_target_H = 16;
-	u1Byte			tmp_power_diff = 0,power_diff = 0,avg_power_diff = 0,max_power_diff = 0,min_power_diff = 0xff;
-	u2Byte			index, counter = 0;
-	static u1Byte		ScanChannel;
-	u4Byte			tmp_SWAS_NoLink_BK_Reg948;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ANTA_ON = (( %d )) , ANTB_ON = (( %d ))\n", pDM_Odm->DM_SWAT_Table.ANTA_ON, pDM_Odm->DM_SWAT_Table.ANTB_ON));
-
-	//if(HP id)
-	{
-		if(pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult==TRUE && pDM_Odm->SupportICType == ODM_RTL8723B)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("8723B RSSI-based Antenna Detection is done\n"));
-			return FALSE;
-		}
-		
-		if(pDM_Odm->SupportICType == ODM_RTL8723B)
-		{
-			if(pDM_SWAT_Table->SWAS_NoLink_BK_Reg948 == 0xff)
-				pDM_SWAT_Table->SWAS_NoLink_BK_Reg948 = ODM_Read4Byte(pDM_Odm, rS0S1_PathSwitch );
-		}
-	}
-
-	if (pDM_Odm->Adapter == NULL)  //For BSOD when plug/unplug fast.  //By YJ,120413
-	{	// The ODM structure is not initialized.
-		return FALSE;
-	}
-
-	// Retrieve antenna detection registry info, added by Roger, 2012.11.27.
-	if(!IS_ANT_DETECT_SUPPORT_RSSI(Adapter))
-	{
-		return FALSE;
-	}
-	else
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Antenna Detection: RSSI Method\n"));	
-	}
-
-	// Since driver is going to set BB register, it shall check if there is another thread controlling BB/RF.
-	PlatformAcquireSpinLock(Adapter, RT_RF_STATE_SPINLOCK);
-	if(pHalData->eRFPowerState!=eRfOn || pMgntInfo->RFChangeInProgress || pMgntInfo->bMediaConnect)
-	{
-		PlatformReleaseSpinLock(Adapter, RT_RF_STATE_SPINLOCK);
-	
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, 
-				("ODM_SwAntDivCheckBeforeLink(): RFChangeInProgress(%x), eRFPowerState(%x)\n", 
-				pMgntInfo->RFChangeInProgress, pHalData->eRFPowerState));
-	
-		pDM_SWAT_Table->SWAS_NoLink_State = 0;
-		
-		return FALSE;
-	}
-	else
-	{
-		PlatformReleaseSpinLock(Adapter, RT_RF_STATE_SPINLOCK);
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("pDM_SWAT_Table->SWAS_NoLink_State = %d\n", pDM_SWAT_Table->SWAS_NoLink_State));
-	//1 Run AntDiv mechanism "Before Link" part.
-	if(pDM_SWAT_Table->SWAS_NoLink_State == 0)
-	{
-		//1 Prepare to do Scan again to check current antenna state.
-
-		// Set check state to next step.
-		pDM_SWAT_Table->SWAS_NoLink_State = 1;
-	
-		// Copy Current Scan list.
-		pMgntInfo->tmpNumBssDesc = pMgntInfo->NumBssDesc;
-		PlatformMoveMemory((PVOID)Adapter->MgntInfo.tmpbssDesc, (PVOID)pMgntInfo->bssDesc, sizeof(RT_WLAN_BSS)*MAX_BSS_DESC);
-		
-		// Go back to scan function again.
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink: Scan one more time\n"));
-		pMgntInfo->ScanStep=0;
-		pMgntInfo->bScanAntDetect = TRUE;
-		ScanChannel = odm_SwAntDivSelectScanChnl(Adapter);
-
-		
-		if(pDM_Odm->SupportICType & (ODM_RTL8188E|ODM_RTL8821))
-		{
-			if(pDM_FatTable->RxIdleAnt == MAIN_ANT)
-				ODM_UpdateRxIdleAnt(pDM_Odm, AUX_ANT);
-			else
-				ODM_UpdateRxIdleAnt(pDM_Odm, MAIN_ANT);
-			if(ScanChannel == 0)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, 
-					("ODM_SwAntDivCheckBeforeLink(): No AP List Avaiable, Using Ant(%s)\n", (pDM_FatTable->RxIdleAnt==MAIN_ANT)?"AUX_ANT":"MAIN_ANT"));
-
-				if(IS_5G_WIRELESS_MODE(pMgntInfo->dot11CurrentWirelessMode))
-				{
-					pDM_SWAT_Table->Ant5G = pDM_FatTable->RxIdleAnt;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("pDM_SWAT_Table->Ant5G=%s\n", (pDM_FatTable->RxIdleAnt==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-				}
-				else
-				{
-					pDM_SWAT_Table->Ant2G = pDM_FatTable->RxIdleAnt;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("pDM_SWAT_Table->Ant2G=%s\n", (pDM_FatTable->RxIdleAnt==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-				}
-				return FALSE;
-			}
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, 
-				("ODM_SwAntDivCheckBeforeLink: Change to %s for testing.\n", ((pDM_FatTable->RxIdleAnt == MAIN_ANT)?"MAIN_ANT":"AUX_ANT")));
-		} else if (pDM_Odm->SupportICType & (ODM_RTL8723B)) {
-			/*Switch Antenna to another one.*/
-				
-			tmp_SWAS_NoLink_BK_Reg948 = ODM_Read4Byte(pDM_Odm, rS0S1_PathSwitch);
-			
-			if ((pDM_SWAT_Table->CurAntenna == MAIN_ANT) && (tmp_SWAS_NoLink_BK_Reg948 == 0x200)) {
-				ODM_SetBBReg(pDM_Odm, rS0S1_PathSwitch, 0xfff, 0x280);
-				ODM_SetBBReg(pDM_Odm, rAGC_table_select, BIT31, 0x1);
-				pDM_SWAT_Table->CurAntenna = AUX_ANT;
-			} else {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Reg[948]= (( %x )) was in wrong state\n", tmp_SWAS_NoLink_BK_Reg948));
-				return FALSE;
-			}
-			ODM_StallExecution(10);
-
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink: Change to (( %s-ant))  for testing.\n", (pDM_SWAT_Table->CurAntenna == MAIN_ANT)?"MAIN":"AUX"));
-		}
-		
-		odm_SwAntDivConstructScanChnl(Adapter, ScanChannel);
-		PlatformSetTimer(Adapter, &pMgntInfo->ScanTimer, 5);
-
-		return TRUE;
-	}
-	else //pDM_SWAT_Table->SWAS_NoLink_State == 1
-	{
-		//1 ScanComple() is called after antenna swiched.
-		//1 Check scan result and determine which antenna is going
-		//1 to be used.
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,(" tmpNumBssDesc= (( %d )) \n",pMgntInfo->tmpNumBssDesc));// debug for Dino
-		
-		for(index = 0; index < pMgntInfo->tmpNumBssDesc; index++)
-		{
-			pTmpBssDesc = &(pMgntInfo->tmpbssDesc[index]); // Antenna 1
-			pTestBssDesc = &(pMgntInfo->bssDesc[index]); // Antenna 2
-
-			if(PlatformCompareMemory(pTestBssDesc->bdBssIdBuf, pTmpBssDesc->bdBssIdBuf, 6)!=0)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink(): ERROR!! This shall not happen.\n"));
-				continue;
-			}
-
-			if(pDM_Odm->SupportICType != ODM_RTL8723B)
-			{
-				if(pTmpBssDesc->ChannelNumber == ScanChannel)
-				{
-			if(pTmpBssDesc->RecvSignalPower > pTestBssDesc->RecvSignalPower)
-			{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink: Compare scan entry: Score++\n"));
-						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", pTmpBssDesc->bdSsIdBuf, pTmpBssDesc->bdSsIdLen);
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("at ch %d, Original: %d, Test: %d\n\n", pTmpBssDesc->ChannelNumber, pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-			
-				Score++;
-				PlatformMoveMemory(pTestBssDesc, pTmpBssDesc, sizeof(RT_WLAN_BSS));
-			}
-			else if(pTmpBssDesc->RecvSignalPower < pTestBssDesc->RecvSignalPower)
-			{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink: Compare scan entry: Score--\n"));
-						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", pTmpBssDesc->bdSsIdBuf, pTmpBssDesc->bdSsIdLen);
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("at ch %d, Original: %d, Test: %d\n\n", pTmpBssDesc->ChannelNumber, pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-				Score--;
-			}
-					else
-					{
-						if(pTestBssDesc->bdTstamp - pTmpBssDesc->bdTstamp < 5000)
-						{
-							RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", pTmpBssDesc->bdSsIdBuf, pTmpBssDesc->bdSsIdLen);
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("at ch %d, Original: %d, Test: %d\n", pTmpBssDesc->ChannelNumber, pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("The 2nd Antenna didn't get this AP\n\n"));
-						}
-					}
-				}
-			}
-			else // 8723B
-			{ 
-				if(pTmpBssDesc->ChannelNumber == ScanChannel)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("ChannelNumber == ScanChannel -> (( %d )) \n", pTmpBssDesc->ChannelNumber ));
-				
-					if(pTmpBssDesc->RecvSignalPower > pTestBssDesc->RecvSignalPower) // Pow(Ant1) > Pow(Ant2)
-					{
-						counter++;
-						tmp_power_diff=(u1Byte)(pTmpBssDesc->RecvSignalPower - pTestBssDesc->RecvSignalPower);
-						power_diff = power_diff + tmp_power_diff;	
-						
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Original: %d, Test: %d\n", pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-						ODM_PRINT_ADDR(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, ("SSID:"), pTmpBssDesc->bdSsIdBuf);
-						ODM_PRINT_ADDR(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, ("BSSID:"), pTmpBssDesc->bdBssIdBuf);
-
-						//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("tmp_power_diff: (( %d)),max_power_diff: (( %d)),min_power_diff: (( %d))  \n", tmp_power_diff,max_power_diff,min_power_diff));
-						if(tmp_power_diff > max_power_diff)
-							max_power_diff=tmp_power_diff;
-						if(tmp_power_diff < min_power_diff)
-							min_power_diff=tmp_power_diff;
-						//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("max_power_diff: (( %d)),min_power_diff: (( %d))  \n",max_power_diff,min_power_diff));
-						
-						PlatformMoveMemory(pTestBssDesc, pTmpBssDesc, sizeof(RT_WLAN_BSS));
-					}
-					else if(pTestBssDesc->RecvSignalPower > pTmpBssDesc->RecvSignalPower) // Pow(Ant1) < Pow(Ant2)
-					{
-						counter++;
-						tmp_power_diff=(u1Byte)(pTestBssDesc->RecvSignalPower - pTmpBssDesc->RecvSignalPower);
-						power_diff = power_diff + tmp_power_diff;						
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Original: %d, Test: %d\n", pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-						ODM_PRINT_ADDR(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, ("SSID:"), pTmpBssDesc->bdSsIdBuf);
-						ODM_PRINT_ADDR(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, ("BSSID:"), pTmpBssDesc->bdBssIdBuf);							
-						if(tmp_power_diff > max_power_diff)
-							max_power_diff=tmp_power_diff;
-						if(tmp_power_diff < min_power_diff)
-							min_power_diff=tmp_power_diff;							
-					}
-					else // Pow(Ant1) = Pow(Ant2)
-					{
-						if(pTestBssDesc->bdTstamp > pTmpBssDesc->bdTstamp) //  Stamp(Ant1) < Stamp(Ant2) 
-					{
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("time_diff: %lld\n", (pTestBssDesc->bdTstamp-pTmpBssDesc->bdTstamp)/1000));
-						if(pTestBssDesc->bdTstamp - pTmpBssDesc->bdTstamp > 5000)
-						{
-							counter++;
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Original: %d, Test: %d\n", pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-							ODM_PRINT_ADDR(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, ("SSID:"), pTmpBssDesc->bdSsIdBuf);
-								ODM_PRINT_ADDR(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, ("BSSID:"), pTmpBssDesc->bdBssIdBuf);
-								min_power_diff = 0;
-						}
-					}
-						else
-						{
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Error !!!]: Time_diff: %lld\n", (pTestBssDesc->bdTstamp-pTmpBssDesc->bdTstamp)/1000));
-						}
-				}
-			}
-		}
-		}
-
-		if(pDM_Odm->SupportICType & (ODM_RTL8188E|ODM_RTL8821))
-		{
-			if(pMgntInfo->NumBssDesc!=0 && Score<0)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,
-							("ODM_SwAntDivCheckBeforeLink(): Using Ant(%s)\n", (pDM_FatTable->RxIdleAnt==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-			}
-			else
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, 
-						("ODM_SwAntDivCheckBeforeLink(): Remain Ant(%s)\n", (pDM_FatTable->RxIdleAnt==MAIN_ANT)?"AUX_ANT":"MAIN_ANT"));
-
-				if(pDM_FatTable->RxIdleAnt == MAIN_ANT)
-					ODM_UpdateRxIdleAnt(pDM_Odm, AUX_ANT);
-				else
-					ODM_UpdateRxIdleAnt(pDM_Odm, MAIN_ANT);
-			}
-			
-			if(IS_5G_WIRELESS_MODE(pMgntInfo->dot11CurrentWirelessMode))
-			{
-				pDM_SWAT_Table->Ant5G = pDM_FatTable->RxIdleAnt;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("pDM_SWAT_Table->Ant5G=%s\n", (pDM_FatTable->RxIdleAnt==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-			}
-			else
-			{
-				pDM_SWAT_Table->Ant2G = pDM_FatTable->RxIdleAnt;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("pDM_SWAT_Table->Ant2G=%s\n", (pDM_FatTable->RxIdleAnt==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-			}
-		}
-		else if(pDM_Odm->SupportICType == ODM_RTL8723B)
-		{
-			if(counter == 0)
-			{	
-				if(pDM_Odm->DM_SWAT_Table.Pre_Aux_FailDetec == FALSE)
-				{
-					pDM_Odm->DM_SWAT_Table.Pre_Aux_FailDetec = TRUE;
-					pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult=FALSE;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Counter=(( 0 )) , [[ Cannot find any AP with Aux-ant ]] ->  Scan Target-channel again  \n"));	
-
-                                        //3 [ Scan again ]
-					odm_SwAntDivConstructScanChnl(Adapter, ScanChannel);
-					PlatformSetTimer(Adapter, &pMgntInfo->ScanTimer, 5);
-					return TRUE;
-				}
-				else// Pre_Aux_FailDetec == TRUE
-				{
-					//2 [ Single Antenna ]
-					pDM_Odm->DM_SWAT_Table.Pre_Aux_FailDetec = FALSE;
-					pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult=TRUE;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Counter=(( 0 )) , [[  Still cannot find any AP ]] \n"));
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink(): Single antenna\n"));	
-				}
-				pDM_Odm->DM_SWAT_Table.Aux_FailDetec_Counter++;
-			}
-			else
-			{
-				pDM_Odm->DM_SWAT_Table.Pre_Aux_FailDetec = FALSE;
-				
-				if(counter==3)
-				{
-					avg_power_diff = ((power_diff-max_power_diff - min_power_diff)>>1)+ ((max_power_diff + min_power_diff)>>2);
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("counter: (( %d )) ,  power_diff: (( %d )) \n", counter, power_diff));
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ counter==3 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d )) \n", avg_power_diff,max_power_diff, min_power_diff));
-				}
-				else if(counter>=4)
-				{
-					avg_power_diff=(power_diff-max_power_diff - min_power_diff) / (counter - 2);
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("counter: (( %d )) ,  power_diff: (( %d )) \n", counter, power_diff));
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ counter>=4 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d )) \n", avg_power_diff,max_power_diff, min_power_diff));
-					
-				}
-				else//counter==1,2
-				{
-					avg_power_diff=power_diff/counter;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("avg_power_diff: (( %d )) , counter: (( %d )) ,  power_diff: (( %d )) \n", avg_power_diff,counter, power_diff));
-				}
-
-				//2 [ Retry ]
-				if( (avg_power_diff >=power_target_L) && (avg_power_diff <=power_target_H)  )
-				{
-					pDM_Odm->DM_SWAT_Table.Retry_Counter++;
-					
-					if(pDM_Odm->DM_SWAT_Table.Retry_Counter<=3)
-					{
-						pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult=FALSE;
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[[ Low confidence result ]] avg_power_diff= (( %d ))  ->  Scan Target-channel again ]] \n", avg_power_diff));	
-
-					         //3 [ Scan again ]
-						odm_SwAntDivConstructScanChnl(Adapter, ScanChannel);
-						PlatformSetTimer(Adapter, &pMgntInfo->ScanTimer, 5);
-						return TRUE;					         
-					}
-					else
-			{
-						pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult=TRUE;
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[[ Still Low confidence result ]]  (( Retry_Counter > 3 )) \n"));
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink(): Single antenna\n"));
-					}
-					
-				}
-				//2 [ Dual Antenna ]
-				else if( (pMgntInfo->NumBssDesc != 0) && (avg_power_diff < power_target_L)   ) 
-				{
-					pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult=TRUE;
-					if(pDM_Odm->DM_SWAT_Table.ANTB_ON == FALSE)
-					{
-						pDM_Odm->DM_SWAT_Table.ANTA_ON = TRUE;
-						pDM_Odm->DM_SWAT_Table.ANTB_ON = TRUE;
-					}
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("ODM_SwAntDivCheckBeforeLink(): Dual antenna\n"));
-					pDM_Odm->DM_SWAT_Table.Dual_Ant_Counter++;
-
-					// set bt coexDM from 1ant coexDM to 2ant coexDM
-					BT_SetBtCoexAntNum(Adapter, BT_COEX_ANT_TYPE_DETECTED, 2);
-					
-					//3 [ Init antenna diversity ]
-					pDM_Odm->SupportAbility |= ODM_BB_ANT_DIV; 
-					ODM_AntDivInit(pDM_Odm);
-				}
-				//2 [ Single Antenna ]
-				else if(avg_power_diff > power_target_H)
-				{
-					pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult=TRUE;
-					if(pDM_Odm->DM_SWAT_Table.ANTB_ON == TRUE)
-					{
-						pDM_Odm->DM_SWAT_Table.ANTA_ON = TRUE;
-						pDM_Odm->DM_SWAT_Table.ANTB_ON = FALSE;
-						//BT_SetBtCoexAntNum(Adapter, BT_COEX_ANT_TYPE_DETECTED, 1);
-					}
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink(): Single antenna\n"));
-					pDM_Odm->DM_SWAT_Table.Single_Ant_Counter++;
-				}
-			}
-			//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("bResult=(( %d ))\n",pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("Dual_Ant_Counter = (( %d )), Single_Ant_Counter = (( %d )) , Retry_Counter = (( %d )) , Aux_FailDetec_Counter = (( %d ))\n\n\n",
-			pDM_Odm->DM_SWAT_Table.Dual_Ant_Counter,pDM_Odm->DM_SWAT_Table.Single_Ant_Counter,pDM_Odm->DM_SWAT_Table.Retry_Counter,pDM_Odm->DM_SWAT_Table.Aux_FailDetec_Counter));
-
-			//2 recover the antenna setting
-
-			if(pDM_Odm->DM_SWAT_Table.ANTB_ON == FALSE)
-				ODM_SetBBReg(pDM_Odm, rS0S1_PathSwitch, 0xfff, (pDM_SWAT_Table->SWAS_NoLink_BK_Reg948));
-			
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("bResult=(( %d )), Recover  Reg[948]= (( %x )) \n\n",pDM_Odm->DM_SWAT_Table.RSSI_AntDect_bResult, pDM_SWAT_Table->SWAS_NoLink_BK_Reg948 ));
-
-			
-		}
-		
-		// Check state reset to default and wait for next time.
-		pDM_SWAT_Table->SWAS_NoLink_State = 0;
-		pMgntInfo->bScanAntDetect = FALSE;
-
-		return FALSE;
-	}
-
-#else
-		return	FALSE;
-#endif
-
-return FALSE;
-}
-
-
-
-
-
-
-//1 [3. PSD Method] ==========================================================
-
-
-
-
-u4Byte
-odm_GetPSDData(
-	IN 	PVOID			pDM_VOID,
-	IN u2Byte			point,
-	IN u1Byte 		initial_gain)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			psd_report;
-	
-	ODM_SetBBReg(pDM_Odm, 0x808, 0x3FF, point);
-	ODM_SetBBReg(pDM_Odm, 0x808, BIT22, 1);  //Start PSD calculation, Reg808[22]=0->1
-	ODM_StallExecution(150);//Wait for HW PSD report
-	ODM_SetBBReg(pDM_Odm, 0x808, BIT22, 0);//Stop PSD calculation,  Reg808[22]=1->0
-	psd_report = ODM_GetBBReg(pDM_Odm,0x8B4, bMaskDWord) & 0x0000FFFF;//Read PSD report, Reg8B4[15:0]
-	
-	psd_report = (u4Byte) (odm_ConvertTo_dB(psd_report));//+(u4Byte)(initial_gain);
-	return psd_report;
-}
-
-
-
-VOID
-ODM_SingleDualAntennaDetection_PSD(
-	IN	 PVOID 	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte	Channel_ori;
-	u1Byte 	initial_gain = 0x36;
-	u1Byte	tone_idx;
-	u1Byte	Tone_lenth_1=7, Tone_lenth_2=4;
-	u2Byte	Tone_idx_1[7]={88, 104, 120, 8, 24, 40, 56};
-	u2Byte	Tone_idx_2[4]={8, 24, 40, 56};
-	u4Byte	PSD_report_Main[11]={0}, PSD_report_Aux[11]={0};
-	//u1Byte	Tone_lenth_1=4, Tone_lenth_2=2;
-	//u2Byte	Tone_idx_1[4]={88, 120, 24, 56};
-	//u2Byte	Tone_idx_2[2]={ 24,  56};
-	//u4Byte	PSD_report_Main[6]={0}, PSD_report_Aux[6]={0};
-
-	u4Byte	PSD_report_temp,MAX_PSD_report_Main=0,MAX_PSD_report_Aux=0;
-	u4Byte	PSD_power_threshold;
-	u4Byte	Main_psd_result=0, Aux_psd_result=0;
-	u4Byte	Regc50, Reg948, Regb2c,Regc14,Reg908;
-	u4Byte	i=0,test_num=8;
-	
-
-	if(pDM_Odm->SupportICType != ODM_RTL8723B)
-		return;
-	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SingleDualAntennaDetection_PSD()============> \n"));	
-	
-	//2 [ Backup Current RF/BB Settings ]	
-	
-	Channel_ori = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, ODM_CHANNEL, bRFRegOffsetMask);
-	Reg948 = ODM_GetBBReg(pDM_Odm, rS0S1_PathSwitch, bMaskDWord);
-	Regb2c =  ODM_GetBBReg(pDM_Odm, rAGC_table_select, bMaskDWord);
-	Regc50 = ODM_GetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskDWord);
-	Regc14 = ODM_GetBBReg(pDM_Odm, 0xc14, bMaskDWord);
-	Reg908 = ODM_GetBBReg(pDM_Odm, 0x908, bMaskDWord);
-
-	//2 [ Setting for doing PSD function (CH4)]
-	ODM_SetBBReg(pDM_Odm, rFPGA0_RFMOD, BIT24, 0); //disable whole CCK block
-	ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0xFF); // Turn off TX  ->  Pause TX Queue
-	ODM_SetBBReg(pDM_Odm, 0xC14, bMaskDWord, 0x0); // [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA]
-
-	// PHYTXON while loop
-	ODM_SetBBReg(pDM_Odm, 0x908, bMaskDWord, 0x803); 
-	while (ODM_GetBBReg(pDM_Odm, 0xdf4, BIT6)) 
-	{
-		i++;
-		if (i > 1000000) 
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Wait in %s() more than %d times!\n", __FUNCTION__, i));	
-			break;
-		}
-	}
-	
-	ODM_SetBBReg(pDM_Odm, 0xc50, 0x7f, initial_gain);  
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     // Set RF to CH4 & 40M
-	ODM_SetBBReg(pDM_Odm, rFPGA0_AnalogParameter4, 0xf00000, 0xf);	// 3 wire Disable    88c[23:20]=0xf
-	ODM_SetBBReg(pDM_Odm, rFPGA0_PSDFunction, BIT14|BIT15, 0x0);  //128 pt	//Set PSD 128 ptss
-	ODM_StallExecution(3000);	
-	
-	
-	//2 [ Doing PSD Function in (CH4)]
-	
-        //Antenna A
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Switch to Main-ant   (CH4)\n"));
-	ODM_SetBBReg(pDM_Odm, 0x948, 0xfff, 0x200);
-	ODM_StallExecution(10);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("dbg\n"));
-	for (i=0;i<test_num;i++)
-	{	
-		for (tone_idx=0;tone_idx<Tone_lenth_1;tone_idx++)
-		{
-			PSD_report_temp = odm_GetPSDData(pDM_Odm, Tone_idx_1[tone_idx], initial_gain);
-			//if(  PSD_report_temp>PSD_report_Main[tone_idx]  )
-				PSD_report_Main[tone_idx]+=PSD_report_temp;
-		}
-	}
-        //Antenna B
-       ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Switch to Aux-ant   (CH4)\n"));
-       ODM_SetBBReg(pDM_Odm, 0x948, 0xfff, 0x280);
-       ODM_StallExecution(10);	
-	for (i=0;i<test_num;i++)
-	{
-		for (tone_idx=0;tone_idx<Tone_lenth_1;tone_idx++)
-		{
-			PSD_report_temp = odm_GetPSDData(pDM_Odm, Tone_idx_1[tone_idx], initial_gain);
-			//if(  PSD_report_temp>PSD_report_Aux[tone_idx]  )
-				PSD_report_Aux[tone_idx]+=PSD_report_temp;
-		}
-	}
-	//2 [ Doing PSD Function in (CH8)]
-
-	ODM_SetBBReg(pDM_Odm, rFPGA0_AnalogParameter4, 0xf00000, 0x0);	// 3 wire enable    88c[23:20]=0x0
-	ODM_StallExecution(3000);	
-	
-	ODM_SetBBReg(pDM_Odm, 0xc50, 0x7f, initial_gain);  
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     // Set RF to CH8 & 40M
-	
-	ODM_SetBBReg(pDM_Odm, rFPGA0_AnalogParameter4, 0xf00000, 0xf);	// 3 wire Disable    88c[23:20]=0xf
-	ODM_StallExecution(3000);
-
-        //Antenna A
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Switch to Main-ant   (CH8)\n"));
-	ODM_SetBBReg(pDM_Odm, 0x948, 0xfff, 0x200);
-	ODM_StallExecution(10);
-
-	for (i=0;i<test_num;i++)
-	{
-		for (tone_idx=0;tone_idx<Tone_lenth_2;tone_idx++)
-		{
-			PSD_report_temp = odm_GetPSDData(pDM_Odm, Tone_idx_2[tone_idx], initial_gain);
-			//if(  PSD_report_temp>PSD_report_Main[tone_idx]  )
-				PSD_report_Main[Tone_lenth_1+tone_idx]+=PSD_report_temp;
-		}
-	}
-
-        //Antenna B
-        ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Switch to Aux-ant   (CH8)\n"));
-        ODM_SetBBReg(pDM_Odm, 0x948, 0xfff, 0x280);
-	ODM_StallExecution(10);	
-
-	for (i=0;i<test_num;i++)
-	{
-		for (tone_idx=0;tone_idx<Tone_lenth_2;tone_idx++)
-		{
-			PSD_report_temp = odm_GetPSDData(pDM_Odm, Tone_idx_2[tone_idx], initial_gain);
-			//if(  PSD_report_temp>PSD_report_Aux[tone_idx]  )
-				PSD_report_Aux[Tone_lenth_1+tone_idx]+=PSD_report_temp;
-		}
-	}
-
-        //2 [ Calculate Result ]
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\nMain PSD Result: (ALL) \n"));
-	for (tone_idx=0;tone_idx<(Tone_lenth_1+Tone_lenth_2);tone_idx++)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Tone-%d]: %d, \n",(tone_idx+1), PSD_report_Main[tone_idx] ));
-		Main_psd_result+= PSD_report_Main[tone_idx];
-		if(PSD_report_Main[tone_idx]>MAX_PSD_report_Main)
-			MAX_PSD_report_Main=PSD_report_Main[tone_idx];
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("--------------------------- \nTotal_Main= (( %d ))\n", Main_psd_result));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("MAX_Main = (( %d ))\n", MAX_PSD_report_Main));
-	
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\nAux PSD Result: (ALL) \n"));
-	for (tone_idx=0;tone_idx<(Tone_lenth_1+Tone_lenth_2);tone_idx++)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Tone-%d]: %d, \n",(tone_idx+1), PSD_report_Aux[tone_idx] ));
-		Aux_psd_result+= PSD_report_Aux[tone_idx];
-		if(PSD_report_Aux[tone_idx]>MAX_PSD_report_Aux)
-			MAX_PSD_report_Aux=PSD_report_Aux[tone_idx];
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("--------------------------- \nTotal_Aux= (( %d ))\n", Aux_psd_result));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("MAX_Aux = (( %d ))\n\n", MAX_PSD_report_Aux));
-		
-	//Main_psd_result=Main_psd_result-MAX_PSD_report_Main;
-	//Aux_psd_result=Aux_psd_result-MAX_PSD_report_Aux;
-	PSD_power_threshold=(Main_psd_result*7)>>3;
-	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Main_result , Aux_result ] = [ %d , %d ], PSD_power_threshold=(( %d ))\n", Main_psd_result, Aux_psd_result,PSD_power_threshold));
-	
-	//3 [ Dual Antenna ]
-	 if(Aux_psd_result >= PSD_power_threshold   ) 
-	{
-		if(pDM_Odm->DM_SWAT_Table.ANTB_ON == FALSE)
-		{
-			pDM_Odm->DM_SWAT_Table.ANTA_ON = TRUE;
-			pDM_Odm->DM_SWAT_Table.ANTB_ON = TRUE;
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("ODM_SwAntDivCheckBeforeLink(): Dual antenna\n"));
-		
-		// set bt coexDM from 1ant coexDM to 2ant coexDM
-		//BT_SetBtCoexAntNum(pAdapter, BT_COEX_ANT_TYPE_DETECTED, 2);
-					
-		// Init antenna diversity
-		pDM_Odm->SupportAbility |= ODM_BB_ANT_DIV; 
-		ODM_AntDivInit(pDM_Odm);
-		}
-	//3 [ Single Antenna ]
-	else
-	{
-		if(pDM_Odm->DM_SWAT_Table.ANTB_ON == TRUE)
-		{
-			pDM_Odm->DM_SWAT_Table.ANTA_ON = TRUE;
-			pDM_Odm->DM_SWAT_Table.ANTB_ON = FALSE;
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SwAntDivCheckBeforeLink(): Single antenna\n"));
-	}
-
-	//2 [ Recover all parameters ]
-	
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask,Channel_ori);	
-	ODM_SetBBReg(pDM_Odm, rFPGA0_AnalogParameter4, 0xf00000, 0x0);	// 3 wire enable    88c[23:20]=0x0
-	ODM_SetBBReg(pDM_Odm, 0xc50, 0x7f, Regc50);  	
-	
-	ODM_SetBBReg(pDM_Odm, rS0S1_PathSwitch, bMaskDWord, Reg948);
-	ODM_SetBBReg(pDM_Odm, rAGC_table_select, bMaskDWord, Regb2c);
-
-	ODM_SetBBReg(pDM_Odm, rFPGA0_RFMOD, BIT24, 1); //enable whole CCK block
-	ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0x0); //Turn on TX 	// Resume TX Queue
-	ODM_SetBBReg(pDM_Odm, 0xC14, bMaskDWord, Regc14); // [ Set IQK Matrix = 0 ] equivalent to [ Turn on CCA]
-	ODM_SetBBReg(pDM_Odm, 0x908, bMaskDWord, Reg908); 
-	
-	return;
-
-}
-
-#endif
-void
-odm_SwAntDetectInit(
-	IN		PVOID		pDM_VOID
-	)
-{
-#if(defined(CONFIG_ANT_DETECTION))
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-
-	//pDM_SWAT_Table->PreAntenna = MAIN_ANT;
-	//pDM_SWAT_Table->CurAntenna = MAIN_ANT;
-	pDM_SWAT_Table->SWAS_NoLink_State = 0;
-	pDM_SWAT_Table->Pre_Aux_FailDetec = FALSE;
-	pDM_SWAT_Table->SWAS_NoLink_BK_Reg948 = 0xff;
-#endif
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* #if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE)) */
+#if (defined(CONFIG_ANT_DETECTION))
+
+/* IS_ANT_DETECT_SUPPORT_SINGLE_TONE(adapter)
+ * IS_ANT_DETECT_SUPPORT_RSSI(adapter)
+ * IS_ANT_DETECT_SUPPORT_PSD(adapter) */
+
+/* 1 [1. Single Tone method] =================================================== */
+
+/*
+ * Description:
+ *	Set Single/Dual Antenna default setting for products that do not do detection in advance.
+ *
+ * Added by Joseph, 2012.03.22
+ *   */
+void
+odm_single_dual_antenna_default_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	void	*adapter	 =  dm->adapter;
+
+	u8 bt_ant_num = BT_GetPgAntNum(adapter);
+	/* Set default antenna A and B status */
+	if (bt_ant_num == 2) {
+		dm_swat_table->ANTA_ON = true;
+		dm_swat_table->ANTB_ON = true;
+
+	} else if (bt_ant_num == 1) {
+		/* Set antenna A as default */
+		dm_swat_table->ANTA_ON = true;
+		dm_swat_table->ANTB_ON = false;
+
+	} else
+		RT_ASSERT(false, ("Incorrect antenna number!!\n"));
+}
+
+
+/* 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.
+ *
+ * Added by Roger, 2011.12.15
+ *   */
+boolean
+odm_single_dual_antenna_detection(
+	void		*dm_void,
+	u8			mode
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter	 =  dm->adapter;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	u32		current_channel, rf_loop_reg;
+	u8		n;
+	u32		reg88c, regc08, reg874, regc50, reg948, regb2c, reg92c, reg930, reg064, afe_rrx_wait_cca;
+	u8		initial_gain = 0x5a;
+	u32		PSD_report_tmp;
+	u32		ant_a_report = 0x0, ant_b_report = 0x0, ant_0_report = 0x0;
+	boolean		is_result = true;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection()============>\n");
+
+
+	if (!(dm->support_ic_type & ODM_RTL8723B))
+		return is_result;
+
+	/* Retrieve antenna detection registry info, added by Roger, 2012.11.27. */
+	if (!IS_ANT_DETECT_SUPPORT_SINGLE_TONE(((PADAPTER)adapter)))
+		return is_result;
+
+	/* 1 Backup Current RF/BB Settings */
+
+	current_channel = odm_get_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
+	rf_loop_reg = odm_get_rf_reg(dm, RF_PATH_A, 0x00, RFREGOFFSETMASK);
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		reg92c = odm_get_bb_reg(dm, REG_DPDT_CONTROL, MASKDWORD);
+		reg930 = odm_get_bb_reg(dm, rfe_ctrl_anta_src, MASKDWORD);
+		reg948 = odm_get_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
+		regb2c = odm_get_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD);
+		reg064 = odm_get_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29));
+		odm_set_bb_reg(dm, REG_DPDT_CONTROL, 0x3, 0x1);
+		odm_set_bb_reg(dm, rfe_ctrl_anta_src, 0xff, 0x77);
+		odm_set_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), 0x1);  /* dbg 7 */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0x3c0, 0x0);/* dbg 8 */
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x0);
+	}
+
+	ODM_delay_us(10);
+
+	/* Store A path Register 88c, c08, 874, c50 */
+	reg88c = odm_get_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD);
+	regc08 = odm_get_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD);
+	reg874 = odm_get_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD);
+	regc50 = odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
+
+	/* Store AFE Registers */
+	if (dm->support_ic_type & ODM_RTL8723B)
+		afe_rrx_wait_cca = odm_get_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD);
+
+	/* Set PSD 128 pts */
+	odm_set_bb_reg(dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0); /* 128 pts */
+
+	/* To SET CH1 to do */
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK, 0x7401);     /* channel 1 */
+
+	/* AFE all on step */
+	if (dm->support_ic_type & ODM_RTL8723B)
+		odm_set_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD, 0x01c00016);
+
+	/* 3 wire Disable */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, 0xCCF000C0);
+
+	/* BB IQK setting */
+	odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800E4);
+	odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x22208000);
+
+	/* IQK setting tone@ 4.34Mhz */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x10008C1C);
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
+
+	/* Page B init */
+	odm_set_bb_reg(dm, REG_CONFIG_ANT_A, MASKDWORD, 0x00080000);
+	odm_set_bb_reg(dm, REG_CONFIG_ANT_A, MASKDWORD, 0x0f600000);
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x10008c1f);
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82150016);
+		odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28150016);
+	}
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x001028d0);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, 0x7f, initial_gain);
+
+	/* IQK Single tone start */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+
+	ODM_delay_us(10000);
+
+	/* PSD report of antenna A */
+	PSD_report_tmp = 0x0;
+	for (n = 0; n < 2; n++) {
+		PSD_report_tmp = phydm_get_psd_data(dm, 14, initial_gain);
+		if (PSD_report_tmp > ant_a_report)
+			ant_a_report = PSD_report_tmp;
+	}
+
+	/* change to Antenna B */
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		/* odm_set_bb_reg(dm, REG_DPDT_CONTROL, 0x3, 0x2); */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
+	}
+
+	ODM_delay_us(10);
+
+	/* PSD report of antenna B */
+	PSD_report_tmp = 0x0;
+	for (n = 0; n < 2; n++) {
+		PSD_report_tmp = phydm_get_psd_data(dm, 14, initial_gain);
+		if (PSD_report_tmp > ant_b_report)
+			ant_b_report = PSD_report_tmp;
+	}
+
+	/* Close IQK Single Tone function */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+
+	/* 1 Return to antanna A */
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		/* external DPDT */
+		odm_set_bb_reg(dm, REG_DPDT_CONTROL, MASKDWORD, reg92c);
+
+		/* internal S0/S1 */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
+		odm_set_bb_reg(dm, rfe_ctrl_anta_src, MASKDWORD, reg930);
+		odm_set_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), reg064);
+	}
+
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, reg88c);
+	odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, regc08);
+	odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, reg874);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, 0x7F, 0x40);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD, regc50);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, current_channel);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x00, RFREGOFFSETMASK, rf_loop_reg);
+
+	/* Reload AFE Registers */
+	if (dm->support_ic_type & ODM_RTL8723B)
+		odm_set_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD, afe_rrx_wait_cca);
+
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "psd_report_A[%d]= %d\n", 2416, ant_a_report);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "psd_report_B[%d]= %d\n", 2416, ant_b_report);
+
+		/* 2 Test ant B based on ant A is ON */
+		if ((ant_a_report >= 100) && (ant_b_report >= 100) && (ant_a_report <= 135) && (ant_b_report <= 135)) {
+			u8 TH1 = 2, TH2 = 6;
+
+			if ((ant_a_report - ant_b_report < TH1) || (ant_b_report - ant_a_report < TH1)) {
+				dm_swat_table->ANTA_ON = true;
+				dm_swat_table->ANTB_ON = true;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection(): Dual Antenna\n");
+			} else if (((ant_a_report - ant_b_report >= TH1) && (ant_a_report - ant_b_report <= TH2)) ||
+				((ant_b_report - ant_a_report >= TH1) && (ant_b_report - ant_a_report <= TH2))) {
+				dm_swat_table->ANTA_ON = false;
+				dm_swat_table->ANTB_ON = false;
+				is_result = false;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection(): Need to check again\n");
+			} else {
+				dm_swat_table->ANTA_ON = true;
+				dm_swat_table->ANTB_ON = false;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection(): Single Antenna\n");
+			}
+			dm->ant_detected_info.is_ant_detected = true;
+			dm->ant_detected_info.db_for_ant_a = ant_a_report;
+			dm->ant_detected_info.db_for_ant_b = ant_b_report;
+			dm->ant_detected_info.db_for_ant_o = ant_0_report;
+
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "return false!!\n");
+			is_result = false;
+		}
+	}
+	return is_result;
+
+}
+
+
+
+/* 1 [2. Scan AP RSSI method] ================================================== */
+
+
+
+
+boolean
+odm_sw_ant_div_check_before_link(
+	void		*dm_void
+)
+{
+#if (RT_MEM_SIZE_LEVEL != RT_MEM_SIZE_MINIMUM)
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	//PMGNT_INFO		mgnt_info = &adapter->MgntInfo;
+	PMGNT_INFO		mgnt_info = &(((PADAPTER)(adapter))->MgntInfo);
+	struct sw_antenna_switch			*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	s8			score = 0;
+	PRT_WLAN_BSS	p_tmp_bss_desc, p_test_bss_desc;
+	u8			power_target_L = 9, power_target_H = 16;
+	u8			tmp_power_diff = 0, power_diff = 0, avg_power_diff = 0, max_power_diff = 0, min_power_diff = 0xff;
+	u16			index, counter = 0;
+	static u8		scan_channel;
+	u32			tmp_swas_no_link_bk_reg948;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "ANTA_ON = (( %d )) , ANTB_ON = (( %d ))\n", dm->dm_swat_table.ANTA_ON, dm->dm_swat_table.ANTB_ON);
+
+	/* if(HP id) */
+	{
+		if (dm->dm_swat_table.rssi_ant_dect_result == true && dm->support_ic_type == ODM_RTL8723B) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "8723B RSSI-based Antenna Detection is done\n");
+			return false;
+		}
+
+		if (dm->support_ic_type == ODM_RTL8723B) {
+			if (dm_swat_table->swas_no_link_bk_reg948 == 0xff)
+				dm_swat_table->swas_no_link_bk_reg948 = odm_read_4byte(dm, REG_S0_S1_PATH_SWITCH);
+		}
+	}
+
+	if (dm->adapter == NULL) { /* For BSOD when plug/unplug fast.  //By YJ,120413 */
+		/* The ODM structure is not initialized. */
+		return false;
+	}
+
+	/* Retrieve antenna detection registry info, added by Roger, 2012.11.27. */
+	if (!IS_ANT_DETECT_SUPPORT_RSSI(((PADAPTER)adapter)))
+		return false;
+	else
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Antenna Detection: RSSI method\n");
+
+	/* Since driver is going to set BB register, it shall check if there is another thread controlling BB/RF. */
+	odm_acquire_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+	if (hal_data->eRFPowerState != eRfOn || mgnt_info->RFChangeInProgress || mgnt_info->bMediaConnect) {
+		odm_release_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			"odm_sw_ant_div_check_before_link(): rf_change_in_progress(%x), e_rf_power_state(%x)\n",
+			mgnt_info->RFChangeInProgress, hal_data->eRFPowerState);
+
+		dm_swat_table->swas_no_link_state = 0;
+
+		return false;
+	} else
+		odm_release_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->swas_no_link_state = %d\n", dm_swat_table->swas_no_link_state);
+	/* 1 Run AntDiv mechanism "Before Link" part. */
+	if (dm_swat_table->swas_no_link_state == 0) {
+		/* 1 Prepare to do Scan again to check current antenna state. */
+
+		/* Set check state to next step. */
+		dm_swat_table->swas_no_link_state = 1;
+
+		/* Copy Current Scan list. */
+		mgnt_info->tmpNumBssDesc = mgnt_info->NumBssDesc;
+		PlatformMoveMemory((void *)mgnt_info->tmpbssDesc, (void *)mgnt_info->bssDesc, sizeof(RT_WLAN_BSS) * MAX_BSS_DESC);
+
+		/* Go back to scan function again. */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Scan one more time\n");
+		mgnt_info->ScanStep = 0;
+		mgnt_info->bScanAntDetect = true;
+		scan_channel = odm_sw_ant_div_select_scan_chnl(adapter);
+
+
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
+			if (fat_tab->rx_idle_ant == MAIN_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
+			else
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			if (scan_channel == 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					"odm_sw_ant_div_check_before_link(): No AP List Avaiable, Using ant(%s)\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "AUX_ANT" : "MAIN_ANT");
+
+				if (IS_5G_WIRELESS_MODE(mgnt_info->dot11CurrentWirelessMode)) {
+					dm_swat_table->ant_5g = fat_tab->rx_idle_ant;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_5g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+				} else {
+					dm_swat_table->ant_2g = fat_tab->rx_idle_ant;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_2g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+				}
+				return false;
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				"odm_sw_ant_div_check_before_link: Change to %s for testing.\n", ((fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+		} else if (dm->support_ic_type & (ODM_RTL8723B)) {
+			/*Switch Antenna to another one.*/
+
+			tmp_swas_no_link_bk_reg948 = odm_read_4byte(dm, REG_S0_S1_PATH_SWITCH);
+
+			if ((dm_swat_table->cur_antenna == MAIN_ANT) && (tmp_swas_no_link_bk_reg948 == 0x200)) {
+				odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
+				odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
+				dm_swat_table->cur_antenna = AUX_ANT;
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Reg[948]= (( %x )) was in wrong state\n", tmp_swas_no_link_bk_reg948);
+				return false;
+			}
+			ODM_delay_us(10);
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Change to (( %s-ant))  for testing.\n", (dm_swat_table->cur_antenna == MAIN_ANT) ? "MAIN" : "AUX");
+		}
+
+		odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
+		PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
+
+		return true;
+	} else { /* dm_swat_table->swas_no_link_state == 1 */
+		/* 1 ScanComple() is called after antenna swiched. */
+		/* 1 Check scan result and determine which antenna is going */
+		/* 1 to be used. */
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, " tmp_num_bss_desc= (( %d ))\n", mgnt_info->tmpNumBssDesc); /* debug for Dino */
+
+		for (index = 0; index < mgnt_info->tmpNumBssDesc; index++) {
+			p_tmp_bss_desc = &mgnt_info->tmpbssDesc[index]; /* Antenna 1 */
+			p_test_bss_desc = &mgnt_info->bssDesc[index]; /* Antenna 2 */
+
+			if (PlatformCompareMemory(p_test_bss_desc->bdBssIdBuf, p_tmp_bss_desc->bdBssIdBuf, 6) != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): ERROR!! This shall not happen.\n");
+				continue;
+			}
+
+			if (dm->support_ic_type != ODM_RTL8723B) {
+				if (p_tmp_bss_desc->ChannelNumber == scan_channel) {
+					if (p_tmp_bss_desc->RecvSignalPower > p_test_bss_desc->RecvSignalPower) {
+						PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Compare scan entry: score++\n");
+						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+
+						score++;
+						PlatformMoveMemory(p_test_bss_desc, p_tmp_bss_desc, sizeof(RT_WLAN_BSS));
+					} else if (p_tmp_bss_desc->RecvSignalPower < p_test_bss_desc->RecvSignalPower) {
+						PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link: Compare scan entry: score--\n");
+						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						score--;
+					} else {
+						if (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp < 5000) {
+							RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
+							PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+							PHYDM_DBG(dm, DBG_ANT_DIV, "The 2nd Antenna didn't get this AP\n\n");
+						}
+					}
+				}
+			} else { /* 8723B */
+				if (p_tmp_bss_desc->ChannelNumber == scan_channel) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "channel_number == scan_channel->(( %d ))\n", p_tmp_bss_desc->ChannelNumber);
+
+					if (p_tmp_bss_desc->RecvSignalPower > p_test_bss_desc->RecvSignalPower) { /* Pow(Ant1) > Pow(Ant2) */
+						counter++;
+						tmp_power_diff = (u8)(p_tmp_bss_desc->RecvSignalPower - p_test_bss_desc->RecvSignalPower);
+						power_diff = power_diff + tmp_power_diff;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
+
+						/* PHYDM_DBG(dm,DBG_ANT_DIV, "tmp_power_diff: (( %d)),max_power_diff: (( %d)),min_power_diff: (( %d))\n", tmp_power_diff,max_power_diff,min_power_diff); */
+						if (tmp_power_diff > max_power_diff)
+							max_power_diff = tmp_power_diff;
+						if (tmp_power_diff < min_power_diff)
+							min_power_diff = tmp_power_diff;
+						/* PHYDM_DBG(dm,DBG_ANT_DIV, "max_power_diff: (( %d)),min_power_diff: (( %d))\n",max_power_diff,min_power_diff); */
+
+						PlatformMoveMemory(p_test_bss_desc, p_tmp_bss_desc, sizeof(RT_WLAN_BSS));
+					} else if (p_test_bss_desc->RecvSignalPower > p_tmp_bss_desc->RecvSignalPower) { /* Pow(Ant1) < Pow(Ant2) */
+						counter++;
+						tmp_power_diff = (u8)(p_test_bss_desc->RecvSignalPower - p_tmp_bss_desc->RecvSignalPower);
+						power_diff = power_diff + tmp_power_diff;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
+						if (tmp_power_diff > max_power_diff)
+							max_power_diff = tmp_power_diff;
+						if (tmp_power_diff < min_power_diff)
+							min_power_diff = tmp_power_diff;
+					} else { /* Pow(Ant1) = Pow(Ant2) */
+						if (p_test_bss_desc->bdTstamp > p_tmp_bss_desc->bdTstamp) { /* Stamp(Ant1) < Stamp(Ant2) */
+							PHYDM_DBG(dm, DBG_ANT_DIV, "time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000);
+							if (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp > 5000) {
+								counter++;
+								PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+								PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+								PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
+								min_power_diff = 0;
+							}
+						} else
+							PHYDM_DBG(dm, DBG_ANT_DIV, "[Error !!!]: Time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000);
+					}
+				}
+			}
+		}
+
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
+			if (mgnt_info->NumBssDesc != 0 && score < 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					"odm_sw_ant_div_check_before_link(): Using ant(%s)\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					"odm_sw_ant_div_check_before_link(): Remain ant(%s)\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "AUX_ANT" : "MAIN_ANT");
+
+				if (fat_tab->rx_idle_ant == MAIN_ANT)
+					odm_update_rx_idle_ant(dm, AUX_ANT);
+				else
+					odm_update_rx_idle_ant(dm, MAIN_ANT);
+			}
+
+			if (IS_5G_WIRELESS_MODE(mgnt_info->dot11CurrentWirelessMode)) {
+				dm_swat_table->ant_5g = fat_tab->rx_idle_ant;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_5g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+			} else {
+				dm_swat_table->ant_2g = fat_tab->rx_idle_ant;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_2g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+			}
+		} else if (dm->support_ic_type == ODM_RTL8723B) {
+			if (counter == 0) {
+				if (dm->dm_swat_table.pre_aux_fail_detec == false) {
+					dm->dm_swat_table.pre_aux_fail_detec = true;
+					dm->dm_swat_table.rssi_ant_dect_result = false;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter=(( 0 )) , [[ Cannot find any AP with Aux-ant ]] ->  Scan Target-channel again\n");
+
+					/* 3 [ Scan again ] */
+					odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
+					PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
+					return true;
+				} else { /* pre_aux_fail_detec == true */
+					/* 2 [ Single Antenna ] */
+					dm->dm_swat_table.pre_aux_fail_detec = false;
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter=(( 0 )) , [[  Still cannot find any AP ]]\n");
+					PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+				}
+				dm->dm_swat_table.aux_fail_detec_counter++;
+			} else {
+				dm->dm_swat_table.pre_aux_fail_detec = false;
+
+				if (counter == 3) {
+					avg_power_diff = ((power_diff - max_power_diff - min_power_diff) >> 1) + ((max_power_diff + min_power_diff) >> 2);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ counter==3 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff);
+				} else if (counter >= 4) {
+					avg_power_diff = (power_diff - max_power_diff - min_power_diff) / (counter - 2);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ counter>=4 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff);
+
+				} else { /* counter==1,2 */
+					avg_power_diff = power_diff / counter;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "avg_power_diff: (( %d )) , counter: (( %d )) ,  power_diff: (( %d ))\n", avg_power_diff, counter, power_diff);
+				}
+
+				/* 2 [ Retry ] */
+				if ((avg_power_diff >= power_target_L) && (avg_power_diff <= power_target_H)) {
+					dm->dm_swat_table.retry_counter++;
+
+					if (dm->dm_swat_table.retry_counter <= 3) {
+						dm->dm_swat_table.rssi_ant_dect_result = false;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[[ Low confidence result ]] avg_power_diff= (( %d ))  ->  Scan Target-channel again ]]\n", avg_power_diff);
+
+						/* 3 [ Scan again ] */
+						odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
+						PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
+						return true;
+					} else {
+						dm->dm_swat_table.rssi_ant_dect_result = true;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[[ Still Low confidence result ]]  (( retry_counter > 3 ))\n");
+						PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+					}
+
+				}
+				/* 2 [ Dual Antenna ] */
+				else if ((mgnt_info->NumBssDesc != 0) && (avg_power_diff < power_target_L)) {
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					if (dm->dm_swat_table.ANTB_ON == false) {
+						dm->dm_swat_table.ANTA_ON = true;
+						dm->dm_swat_table.ANTB_ON = true;
+					}
+					PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Dual antenna\n");
+					dm->dm_swat_table.dual_ant_counter++;
+
+					/* set bt coexDM from 1ant coexDM to 2ant coexDM */
+					BT_SetBtCoexAntNum(adapter, BT_COEX_ANT_TYPE_DETECTED, 2);
+
+					/* 3 [ Init antenna diversity ] */
+					dm->support_ability |= ODM_BB_ANT_DIV;
+					odm_ant_div_init(dm);
+				}
+				/* 2 [ Single Antenna ] */
+				else if (avg_power_diff > power_target_H) {
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					if (dm->dm_swat_table.ANTB_ON == true) {
+						dm->dm_swat_table.ANTA_ON = true;
+						dm->dm_swat_table.ANTB_ON = false;
+						/* bt_set_bt_coex_ant_num(adapter, BT_COEX_ANT_TYPE_DETECTED, 1); */
+					}
+					PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+					dm->dm_swat_table.single_ant_counter++;
+				}
+			}
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "is_result=(( %d ))\n",dm->dm_swat_table.rssi_ant_dect_result); */
+			PHYDM_DBG(dm, DBG_ANT_DIV, "dual_ant_counter = (( %d )), single_ant_counter = (( %d )) , retry_counter = (( %d )) , aux_fail_detec_counter = (( %d ))\n\n\n",
+				dm->dm_swat_table.dual_ant_counter, dm->dm_swat_table.single_ant_counter, dm->dm_swat_table.retry_counter, dm->dm_swat_table.aux_fail_detec_counter);
+
+			/* 2 recover the antenna setting */
+
+			if (dm->dm_swat_table.ANTB_ON == false)
+				odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, (dm_swat_table->swas_no_link_bk_reg948));
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "is_result=(( %d )), Recover  Reg[948]= (( %x ))\n\n", dm->dm_swat_table.rssi_ant_dect_result, dm_swat_table->swas_no_link_bk_reg948);
+
+
+		}
+
+		/* Check state reset to default and wait for next time. */
+		dm_swat_table->swas_no_link_state = 0;
+		mgnt_info->bScanAntDetect = false;
+
+		return false;
+	}
+
+#else
+	return	false;
+#endif
+
+	return false;
+}
+
+
+
+
+
+
+/* 1 [3. PSD method] ========================================================== */
+void
+odm_single_dual_antenna_detection_psd(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	channel_ori;
+	u8	initial_gain = 0x36;
+	u8	tone_idx;
+	u8	tone_lenth_1 = 7, tone_lenth_2 = 4;
+	u16	tone_idx_1[7] = {88, 104, 120, 8, 24, 40, 56};
+	u16	tone_idx_2[4] = {8, 24, 40, 56};
+	u32	psd_report_main[11] = {0}, psd_report_aux[11] = {0};
+	/* u8	tone_lenth_1=4, tone_lenth_2=2; */
+	/* u16	tone_idx_1[4]={88, 120, 24, 56}; */
+	/* u16	tone_idx_2[2]={ 24,  56}; */
+	/* u32	psd_report_main[6]={0}, psd_report_aux[6]={0}; */
+
+	u32	PSD_report_temp, max_psd_report_main = 0, max_psd_report_aux = 0;
+	u32	PSD_power_threshold;
+	u32	main_psd_result = 0, aux_psd_result = 0;
+	u32	regc50, reg948, regb2c, regc14, reg908;
+	u32	i = 0, test_num = 8;
+
+
+	if (dm->support_ic_type != ODM_RTL8723B)
+		return;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_single_dual_antenna_detection_psd()============>\n");
+
+	/* 2 [ Backup Current RF/BB Settings ] */
+
+	channel_ori = odm_get_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
+	reg948 = odm_get_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
+	regb2c =  odm_get_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD);
+	regc50 = odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
+	regc14 = odm_get_bb_reg(dm, 0xc14, MASKDWORD);
+	reg908 = odm_get_bb_reg(dm, 0x908, MASKDWORD);
+
+	/* 2 [ setting for doing PSD function (CH4)] */
+	odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT(24), 0); /* disable whole CCK block */
+	odm_write_1byte(dm, REG_TXPAUSE, 0xFF); /* Turn off TX  ->  Pause TX Queue */
+	odm_set_bb_reg(dm, 0xC14, MASKDWORD, 0x0); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
+
+	/* PHYTXON while loop */
+	odm_set_bb_reg(dm, 0x908, MASKDWORD, 0x803);
+	while (odm_get_bb_reg(dm, 0xdf4, BIT(6))) {
+		i++;
+		if (i > 1000000) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Wait in %s() more than %d times!\n", __FUNCTION__, i);
+			break;
+		}
+	}
+
+	odm_set_bb_reg(dm, 0xc50, 0x7f, initial_gain);
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     /* Set RF to CH4 & 40M */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+	odm_set_bb_reg(dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0);  /* 128 pt	 */ /* Set PSD 128 ptss */
+	ODM_delay_us(3000);
+
+
+	/* 2 [ Doing PSD Function in (CH4)] */
+
+	/* Antenna A */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Main-ant   (CH4)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x200);
+	ODM_delay_us(10);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "dbg\n");
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_1; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_1[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
+			psd_report_main[tone_idx] += PSD_report_temp;
+		}
+	}
+	/* Antenna B */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Aux-ant   (CH4)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x280);
+	ODM_delay_us(10);
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_1; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_1[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
+			psd_report_aux[tone_idx] += PSD_report_temp;
+		}
+	}
+	/* 2 [ Doing PSD Function in (CH8)] */
+
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0);	/* 3 wire enable    88c[23:20]=0x0 */
+	ODM_delay_us(3000);
+
+	odm_set_bb_reg(dm, 0xc50, 0x7f, initial_gain);
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     /* Set RF to CH8 & 40M */
+
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+	ODM_delay_us(3000);
+
+	/* Antenna A */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Main-ant   (CH8)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x200);
+	ODM_delay_us(10);
+
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_2; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_2[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
+			psd_report_main[tone_lenth_1 + tone_idx] += PSD_report_temp;
+		}
+	}
+
+	/* Antenna B */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Aux-ant   (CH8)\n");
+	odm_set_bb_reg(dm, 0x948, 0xfff, 0x280);
+	ODM_delay_us(10);
+
+	for (i = 0; i < test_num; i++) {
+		for (tone_idx = 0; tone_idx < tone_lenth_2; tone_idx++) {
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_2[tone_idx], initial_gain);
+			/* if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
+			psd_report_aux[tone_lenth_1 + tone_idx] += PSD_report_temp;
+		}
+	}
+
+	/* 2 [ Calculate Result ] */
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\nMain PSD Result: (ALL)\n");
+	for (tone_idx = 0; tone_idx < (tone_lenth_1 + tone_lenth_2); tone_idx++) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Tone-%d]: %d,\n", (tone_idx + 1), psd_report_main[tone_idx]);
+		main_psd_result += psd_report_main[tone_idx];
+		if (psd_report_main[tone_idx] > max_psd_report_main)
+			max_psd_report_main = psd_report_main[tone_idx];
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "--------------------------- \nTotal_Main= (( %d ))\n", main_psd_result);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "MAX_Main = (( %d ))\n", max_psd_report_main);
+
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\nAux PSD Result: (ALL)\n");
+	for (tone_idx = 0; tone_idx < (tone_lenth_1 + tone_lenth_2); tone_idx++) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Tone-%d]: %d,\n", (tone_idx + 1), psd_report_aux[tone_idx]);
+		aux_psd_result += psd_report_aux[tone_idx];
+		if (psd_report_aux[tone_idx] > max_psd_report_aux)
+			max_psd_report_aux = psd_report_aux[tone_idx];
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "--------------------------- \nTotal_Aux= (( %d ))\n", aux_psd_result);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "MAX_Aux = (( %d ))\n\n", max_psd_report_aux);
+
+	/* main_psd_result=main_psd_result-max_psd_report_main; */
+	/* aux_psd_result=aux_psd_result-max_psd_report_aux; */
+	PSD_power_threshold = (main_psd_result * 7) >> 3;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Main_result, Aux_result ] = [ %d , %d ], PSD_power_threshold=(( %d ))\n", main_psd_result, aux_psd_result, PSD_power_threshold);
+
+	/* 3 [ Dual Antenna ] */
+	if (aux_psd_result >= PSD_power_threshold) {
+		if (dm->dm_swat_table.ANTB_ON == false) {
+			dm->dm_swat_table.ANTA_ON = true;
+			dm->dm_swat_table.ANTB_ON = true;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Dual antenna\n");
+
+		/* set bt coexDM from 1ant coexDM to 2ant coexDM */
+		/* bt_set_bt_coex_ant_num(adapter, BT_COEX_ANT_TYPE_DETECTED, 2); */
+
+		/* Init antenna diversity */
+		dm->support_ability |= ODM_BB_ANT_DIV;
+		odm_ant_div_init(dm);
+	}
+	/* 3 [ Single Antenna ] */
+	else {
+		if (dm->dm_swat_table.ANTB_ON == true) {
+			dm->dm_swat_table.ANTA_ON = true;
+			dm->dm_swat_table.ANTB_ON = false;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_sw_ant_div_check_before_link(): Single antenna\n");
+	}
+
+	/* 2 [ Recover all parameters ] */
+
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, channel_ori);
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0);	/* 3 wire enable    88c[23:20]=0x0 */
+	odm_set_bb_reg(dm, 0xc50, 0x7f, regc50);
+
+	odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
+	odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
+
+	odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT(24), 1); /* enable whole CCK block */
+	odm_write_1byte(dm, REG_TXPAUSE, 0x0); /* Turn on TX	 */ /* Resume TX Queue */
+	odm_set_bb_reg(dm, 0xC14, MASKDWORD, regc14); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn on CCA] */
+	odm_set_bb_reg(dm, 0x908, MASKDWORD, reg908);
+
+	return;
+
+}
+
+#endif
+void
+odm_sw_ant_detect_init(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_ANT_DETECTION))
+#if (RTL8723B_SUPPORT == 1)
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+
+	if (dm->support_ic_type != ODM_RTL8723B)
+		return;
+
+	/* dm_swat_table->pre_antenna = MAIN_ANT; */
+	/* dm_swat_table->cur_antenna = MAIN_ANT; */
+	dm_swat_table->swas_no_link_state = 0;
+	dm_swat_table->pre_aux_fail_detec = false;
+	dm_swat_table->swas_no_link_bk_reg948 = 0xff;
+
+	#ifdef CONFIG_PSD_TOOL
+	phydm_psd_init(dm);
+	#endif
+#endif
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.h
index 419d9ea956c2..7371e2a4776c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdect.h
@@ -1,98 +1,101 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMANTDECT_H__
-#define    __PHYDMANTDECT_H__
-
-#define ANTDECT_VERSION	"2.1"	/*2015.07.29 by YuChen*/
-
-#if(defined(CONFIG_ANT_DETECTION))
-//#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE))
-//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*/
-
-#define	MAX_ANTENNA_DETECTION_CNT	10 
-
-
-typedef struct _ANT_DETECTED_INFO{
-	BOOLEAN			bAntDetected;
-	u4Byte			dBForAntA;
-	u4Byte			dBForAntB;
-	u4Byte			dBForAntO;
-}ANT_DETECTED_INFO, *PANT_DETECTED_INFO;
-
-
-typedef enum tag_SW_Antenna_Switch_Definition
-{
-	Antenna_A = 1,
-	Antenna_B = 2,	
-	Antenna_MAX = 3,
-}DM_SWAS_E;
-
-
-
-//1 [1. Single Tone Method] ===================================================
-
-
-
-VOID
-ODM_SingleDualAntennaDefaultSetting(
-	IN		PVOID		pDM_VOID
-	);
-
-BOOLEAN
-ODM_SingleDualAntennaDetection(
-	IN		PVOID		pDM_VOID,
-	IN		u1Byte			mode
-	);
-
-//1 [2. Scan AP RSSI Method] ==================================================
-
-#define SwAntDivCheckBeforeLink	ODM_SwAntDivCheckBeforeLink
-
-BOOLEAN 
-ODM_SwAntDivCheckBeforeLink(
-	IN		PVOID		pDM_VOID
-	);
-
-
-
-
-//1 [3. PSD Method] ==========================================================
-
-
-VOID
-ODM_SingleDualAntennaDetection_PSD(
-	IN		PVOID		pDM_VOID
-);
-
-#endif
-
-VOID
-odm_SwAntDetectInit(
-	IN		PVOID		pDM_VOID
-	);
-
-
-#endif
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMANTDECT_H__
+#define    __PHYDMANTDECT_H__
+
+#define ANTDECT_VERSION	"2.1"	/*2015.07.29 by YuChen*/
+
+#if (defined(CONFIG_ANT_DETECTION))
+/* #if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE)) */
+/* 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*/
+
+#define	MAX_ANTENNA_DETECTION_CNT	10
+
+
+struct _ANT_DETECTED_INFO {
+	boolean			is_ant_detected;
+	u32			db_for_ant_a;
+	u32			db_for_ant_b;
+	u32			db_for_ant_o;
+};
+
+
+enum dm_swas {
+	antenna_a = 1,
+	antenna_b = 2,
+	antenna_max = 3,
+};
+
+
+
+/* 1 [1. Single Tone method] =================================================== */
+
+
+
+void
+odm_single_dual_antenna_default_setting(
+	void		*dm_void
+);
+
+boolean
+odm_single_dual_antenna_detection(
+	void		*dm_void,
+	u8			mode
+);
+
+/* 1 [2. Scan AP RSSI method] ================================================== */
+
+#define sw_ant_div_check_before_link	odm_sw_ant_div_check_before_link
+
+boolean
+odm_sw_ant_div_check_before_link(
+	void		*dm_void
+);
+
+
+
+
+/* 1 [3. PSD method] ========================================================== */
+
+
+void
+odm_single_dual_antenna_detection_psd(
+	void		*dm_void
+);
+
+#endif
+
+void
+odm_sw_ant_detect_init(
+	void		*dm_void
+);
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.c
index 73f215a26d5e..aa98cf22d15e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.c
@@ -1,4754 +1,4703 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-//======================================================
-// when antenna test utility is on or some testing need to disable antenna diversity
-// call this function to disable all ODM related mechanisms which will switch antenna.
-//======================================================
-VOID
-ODM_StopAntennaSwitchDm(
-	IN		PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	// disable ODM antenna diversity
-	pDM_Odm->SupportAbility &= ~ODM_BB_ANT_DIV;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("STOP Antenna Diversity \n"));
-}
-
-VOID
-ODM_SetAntConfig(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte		antSetting	// 0=A, 1=B, 2=C, ....
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if(pDM_Odm->SupportICType == ODM_RTL8723B)
-	{
-		if(antSetting == 0)		// ant A
-			ODM_SetBBReg(pDM_Odm, 0x948, bMaskDWord, 0x00000000);
-		else if(antSetting == 1)
-			ODM_SetBBReg(pDM_Odm, 0x948, bMaskDWord, 0x00000280);
-	}
-}
-
-//======================================================
-
-
-VOID
-ODM_SwAntDivRestAfterLink(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	pFAT_T		pDM_FatTable = &pDM_Odm->DM_FatTable;
-	u4Byte             i;
-
-	if (pDM_Odm->AntDivType == S0S1_SW_ANTDIV) {
-		
-		pDM_SWAT_Table->try_flag = SWAW_STEP_INIT;
-		pDM_SWAT_Table->RSSI_Trying = 0;
-		pDM_SWAT_Table->Double_chk_flag= 0;
-		
-		pDM_FatTable->RxIdleAnt=MAIN_ANT;
-		
-		for (i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-		{
-			pDM_FatTable->MainAnt_Sum[i] = 0;
-			pDM_FatTable->AuxAnt_Sum[i] = 0;
-			pDM_FatTable->MainAnt_Cnt[i] = 0;
-			pDM_FatTable->AuxAnt_Cnt[i] = 0;
-		}
-
-	}
-}
-
-
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-VOID
-odm_AntDiv_on_off( 
-	IN 	PVOID		pDM_VOID ,
-	IN 	u1Byte 		swch
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	
-	if(pDM_FatTable->AntDiv_OnOff != swch)
-	{
-		if (pDM_Odm->AntDivType == S0S1_SW_ANTDIV) 
-			return;
-
-		if(pDM_Odm->SupportICType & ODM_N_ANTDIV_SUPPORT)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("(( Turn %s )) N-Series HW-AntDiv block\n",(swch==ANTDIV_ON)?"ON" : "OFF"));
-			ODM_SetBBReg(pDM_Odm, 0xc50 , BIT7, swch); //OFDM AntDiv function block enable
-			ODM_SetBBReg(pDM_Odm, 0xa00 , BIT15, swch); //CCK AntDiv function block enable
-		}
-		else if(pDM_Odm->SupportICType & ODM_AC_ANTDIV_SUPPORT)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("(( Turn %s )) AC-Series HW-AntDiv block\n",(swch==ANTDIV_ON)?"ON" : "OFF"));
-			if (pDM_Odm->SupportICType == ODM_RTL8812) {
-				ODM_SetBBReg(pDM_Odm, 0xc50 , BIT7, swch); //OFDM AntDiv function block enable
-				ODM_SetBBReg(pDM_Odm, 0xa00 , BIT15, swch); //CCK AntDiv function block enable
-			} else {
-				ODM_SetBBReg(pDM_Odm, 0x8D4 , BIT24, swch); //OFDM AntDiv function block enable
-				
-				if( (pDM_Odm->CutVersion >= ODM_CUT_C) && (pDM_Odm->SupportICType == ODM_RTL8821) && ( pDM_Odm->AntDivType != S0S1_SW_ANTDIV))
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("(( Turn %s )) CCK HW-AntDiv block\n",(swch==ANTDIV_ON)?"ON" : "OFF"));
-					ODM_SetBBReg(pDM_Odm, 0x800 , BIT25, swch); 
-					ODM_SetBBReg(pDM_Odm, 0xA00 , BIT15, swch); //CCK AntDiv function block enable
-				}
-		        }
-		}
-	}
-	pDM_FatTable->AntDiv_OnOff =swch;
-	
-}
-
-VOID
-phydm_FastTraining_enable(
-	IN		PVOID		pDM_VOID, 
-	IN 		u1Byte  			swch
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			enable;
-
-	if (swch == FAT_ON)
-		enable=1;
-	else
-		enable=0;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Fast Ant Training_en = ((%d))\n", enable));
-
-	if (pDM_Odm->SupportICType == ODM_RTL8188E) {
-		ODM_SetBBReg(pDM_Odm, 0xe08 , BIT16, enable);	/*enable fast training*/
-		/**/
-	} else if (pDM_Odm->SupportICType == ODM_RTL8192E) {
-		ODM_SetBBReg(pDM_Odm, 0xB34 , BIT28, enable);	/*enable fast training (path-A)*/
-		/*ODM_SetBBReg(pDM_Odm, 0xB34 , BIT29, enable);*/	/*enable fast training (path-B)*/
-	} else if (pDM_Odm->SupportICType == ODM_RTL8821) {
-		ODM_SetBBReg(pDM_Odm, 0x900 , BIT19, enable);	/*enable fast training */
-		/**/
-	}
-}
-
-VOID
-odm_Tx_By_TxDesc_or_Reg( 
-	IN 		PVOID		pDM_VOID, 
-	IN 		u1Byte 			swch
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte enable;
-
-	enable = (swch == TX_BY_DESC) ? 1 : 0;
-
-	if(pDM_Odm->AntDivType != CGCS_RX_HW_ANTDIV)
-	{
-		if(pDM_Odm->SupportICType & ODM_N_ANTDIV_SUPPORT)
-		{
-				ODM_SetBBReg(pDM_Odm, 0x80c , BIT21, enable); 
-		}	
-		else if(pDM_Odm->SupportICType & ODM_AC_ANTDIV_SUPPORT)
-		{
-				ODM_SetBBReg(pDM_Odm, 0x900 , BIT18, enable); 
-		}
-	}
-}
-
-VOID
-ODM_UpdateRxIdleAnt(
-	IN 		PVOID 		pDM_VOID, 
-	IN 		u1Byte 		Ant
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	u4Byte	DefaultAnt, OptionalAnt,value32;
-
-	if(pDM_FatTable->RxIdleAnt != Ant)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] RxIdleAnt =%s\n",(Ant==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-
-		if(!(pDM_Odm->SupportICType & ODM_RTL8723B))
-                	pDM_FatTable->RxIdleAnt = Ant;
-
-		if(Ant == MAIN_ANT)
-		{
-			DefaultAnt   =  ANT1_2G; 
-			OptionalAnt =  ANT2_2G; 
-		}
-		else
-		{
-			DefaultAnt  =   ANT2_2G;
-			OptionalAnt =  ANT1_2G;
-		}
-	
-		if(pDM_Odm->SupportICType & ODM_N_ANTDIV_SUPPORT)
-		{
-			if(pDM_Odm->SupportICType==ODM_RTL8192E)
-			{
-				ODM_SetBBReg(pDM_Odm, 0xB38 , BIT5|BIT4|BIT3, DefaultAnt); //Default RX
-				ODM_SetBBReg(pDM_Odm, 0xB38 , BIT8|BIT7|BIT6, OptionalAnt);//Optional RX
-				ODM_SetBBReg(pDM_Odm, 0x860, BIT14|BIT13|BIT12, DefaultAnt);//Default TX	
-			}
-			#if (RTL8723B_SUPPORT == 1)
-			else if (pDM_Odm->SupportICType == ODM_RTL8723B) {
-				
-				value32 = ODM_GetBBReg(pDM_Odm, 0x948, 0xFFF);
-			
-				if(value32 !=0x280)
-					ODM_UpdateRxIdleAnt_8723B(pDM_Odm, Ant, DefaultAnt, OptionalAnt);
-				else {
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: Fail to set RX antenna due to 0x948 = 0x280\n"));
-					/**/
-				}
-			}
-			#endif
-			else { /*8188E & 8188F*/
-
-				#if (RTL8188F_SUPPORT == 1)
-				if (pDM_Odm->SupportICType == ODM_RTL8188F) {
-					phydm_update_rx_idle_antenna_8188F(pDM_Odm, DefaultAnt);
-					/**/
-				}
-				#endif
-				
-				ODM_SetBBReg(pDM_Odm, 0x864 , BIT5|BIT4|BIT3, DefaultAnt);		/*Default RX*/
-				ODM_SetBBReg(pDM_Odm, 0x864 , BIT8|BIT7|BIT6, OptionalAnt);	/*Optional RX*/
-				ODM_SetBBReg(pDM_Odm, 0x860, BIT14|BIT13|BIT12, DefaultAnt);	/*Default TX*/
-			}
-		}
-		else if(pDM_Odm->SupportICType & ODM_AC_ANTDIV_SUPPORT)
-		{
-			u2Byte	value16 = ODM_Read2Byte(pDM_Odm, ODM_REG_TRMUX_11AC+2);
-			//
-			// 2014/01/14 MH/Luke.Lee Add direct write for register 0xc0a to prevnt 
-			// incorrect 0xc08 bit0-15 .We still not know why it is changed.
-			//
-			value16 &= ~(BIT11|BIT10|BIT9|BIT8|BIT7|BIT6|BIT5|BIT4|BIT3);
-			value16 |= ((u2Byte)DefaultAnt <<3);
-			value16 |= ((u2Byte)OptionalAnt <<6);
-			value16 |= ((u2Byte)DefaultAnt <<9);
-			ODM_Write2Byte(pDM_Odm, ODM_REG_TRMUX_11AC+2, value16);
-			/*
-			ODM_SetBBReg(pDM_Odm, ODM_REG_TRMUX_11AC , BIT21|BIT20|BIT19, DefaultAnt);	 //Default RX
-			ODM_SetBBReg(pDM_Odm, ODM_REG_TRMUX_11AC , BIT24|BIT23|BIT22, OptionalAnt);//Optional RX
-			ODM_SetBBReg(pDM_Odm, ODM_REG_TRMUX_11AC , BIT27|BIT26|BIT25, DefaultAnt);	 //Default TX
-			*/
-		}
-
-		if(pDM_Odm->SupportICType==ODM_RTL8188E)
-		{		
-			ODM_SetMACReg(pDM_Odm, 0x6D8 , BIT7|BIT6, DefaultAnt);	//PathA Resp Tx
-		}
-		else
-		{
-			ODM_SetMACReg(pDM_Odm, 0x6D8 , BIT10|BIT9|BIT8, DefaultAnt);	//PathA Resp Tx
-		}	
-
-	}
-	else// pDM_FatTable->RxIdleAnt == Ant
-        {
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Stay in Ori-Ant ]  RxIdleAnt =%s\n",(Ant==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-		pDM_FatTable->RxIdleAnt = Ant;
-	}
-}
-
-VOID
-odm_UpdateTxAnt(
-	IN 		PVOID 		pDM_VOID, 
-	IN 		u1Byte 		Ant, 
-	IN 		u4Byte 		MacId
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	u1Byte	TxAnt;
-
-	if (pDM_Odm->AntDivType==CG_TRX_SMART_ANTDIV)
-	{
-		TxAnt=Ant;
-	}
-	else
-	{
-        	if(Ant == MAIN_ANT)
-        		TxAnt = ANT1_2G;
-        	else
-        		TxAnt = ANT2_2G;
-	}
-	
-	pDM_FatTable->antsel_a[MacId] = TxAnt&BIT0;
-	pDM_FatTable->antsel_b[MacId] = (TxAnt&BIT1)>>1;
-	pDM_FatTable->antsel_c[MacId] = (TxAnt&BIT2)>>2;
-	
-	//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Tx from TxInfo]: MacID:(( %d )),  TxAnt = (( %s ))\n", MacId,(Ant==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-	//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("antsel_tr_mux=(( 3'b%d%d%d ))\n",pDM_FatTable->antsel_c[MacId] , pDM_FatTable->antsel_b[MacId] , pDM_FatTable->antsel_a[MacId] ));
-	
-}
-
-#ifdef BEAMFORMING_SUPPORT
-#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-VOID
-odm_BDC_Init(
-	IN 		PVOID 		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pBDC_T	pDM_BdcTable=&pDM_Odm->DM_BdcTable;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\n[ BDC Initialization......] \n"));
-	pDM_BdcTable->BDC_state=BDC_DIV_TRAIN_STATE;
-	pDM_BdcTable->BDC_Mode=BDC_MODE_NULL;
-	pDM_BdcTable->BDC_Try_flag=0;
-	pDM_BdcTable->BDCcoexType_wBfer=0;
-	pDM_Odm->bdc_holdstate=0xff;
-	
-	if(pDM_Odm->SupportICType == ODM_RTL8192E)
-	{
-		ODM_SetBBReg(pDM_Odm, 0xd7c , 0x0FFFFFFF, 0x1081008); 
-		ODM_SetBBReg(pDM_Odm, 0xd80 , 0x0FFFFFFF, 0); 
-	}
-	else if(pDM_Odm->SupportICType == ODM_RTL8812)
-	{
-		ODM_SetBBReg(pDM_Odm, 0x9b0 , 0x0FFFFFFF, 0x1081008);     //0x9b0[30:0] = 01081008
-		ODM_SetBBReg(pDM_Odm, 0x9b4 , 0x0FFFFFFF, 0);                 //0x9b4[31:0] = 00000000
-	}
-	
-}
-
-
-VOID
-odm_CSI_on_off(
-	IN 		PVOID 		pDM_VOID, 
-	IN 		u1Byte 			CSI_en
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if(CSI_en==CSI_ON)
-	{
-		if(pDM_Odm->SupportICType == ODM_RTL8192E)
-		{
-			ODM_SetMACReg(pDM_Odm, 0xd84 , BIT11, 1);  //0xd84[11]=1
-		}
-		else if(pDM_Odm->SupportICType == ODM_RTL8812)
-		{
-			ODM_SetMACReg(pDM_Odm, 0x9b0 , BIT31, 1);  //0x9b0[31]=1
-		}
-	
-	}
-	else if(CSI_en==CSI_OFF)
-	{
-		if(pDM_Odm->SupportICType == ODM_RTL8192E)
-		{
-			ODM_SetMACReg(pDM_Odm, 0xd84 , BIT11, 0);  //0xd84[11]=0
-		}
-		else if(pDM_Odm->SupportICType == ODM_RTL8812)
-		{
-			ODM_SetMACReg(pDM_Odm, 0x9b0 , BIT31, 0);  //0x9b0[31]=0
-		}
-	}	
-}
-
-VOID
-odm_BDCcoexType_withBferClient(
-	IN 		PVOID 		pDM_VOID, 
-	IN 		u1Byte 			swch
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pBDC_T 	pDM_BdcTable = &pDM_Odm->DM_BdcTable;
-	u1Byte     BDCcoexType_wBfer;
-	
-	if(swch==DIVON_CSIOFF)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[BDCcoexType: 1] {DIV,CSI} ={1,0} \n"));
-		BDCcoexType_wBfer=1;
-
-		if(BDCcoexType_wBfer != pDM_BdcTable->BDCcoexType_wBfer)
-		{
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);
-			odm_CSI_on_off(pDM_Odm,CSI_OFF);
-			pDM_BdcTable->BDCcoexType_wBfer=1;
-		}
-	}
-	else if(swch==DIVOFF_CSION)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[BDCcoexType: 2] {DIV,CSI} ={0,1}\n"));
-		BDCcoexType_wBfer=2;
-
-		if(BDCcoexType_wBfer != pDM_BdcTable->BDCcoexType_wBfer)
-		{
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-			odm_CSI_on_off(pDM_Odm,CSI_ON);
-			pDM_BdcTable->BDCcoexType_wBfer=2;
-		}
-	}
-}
-
-VOID
-odm_BF_AntDiv_ModeArbitration(
-	IN 		PVOID 		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pBDC_T 			pDM_BdcTable = &pDM_Odm->DM_BdcTable;
-	u1Byte			current_BDC_Mode;
-
-	#if(DM_ODM_SUPPORT_TYPE  == ODM_AP)
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\n"));
-	
-		//2 Mode 1
-		if((pDM_BdcTable->num_Txbfee_Client !=0) && (pDM_BdcTable->num_Txbfer_Client == 0))
-		{
-			current_BDC_Mode=BDC_MODE_1;
-			
-			if(current_BDC_Mode != pDM_BdcTable->BDC_Mode)
-			{
-				pDM_BdcTable->BDC_Mode=BDC_MODE_1;
-				odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF);
-				pDM_BdcTable->BDC_RxIdleUpdate_counter=1;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Change to (( Mode1 ))\n"));
-			}
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Antdiv + BF coextance Mode] : (( Mode1 ))\n"));
-		}
-		//2 Mode 2
-		else if((pDM_BdcTable->num_Txbfee_Client ==0) && (pDM_BdcTable->num_Txbfer_Client != 0))
-		{
-			current_BDC_Mode=BDC_MODE_2;
-			
-			if(current_BDC_Mode != pDM_BdcTable->BDC_Mode)
-			{
-				pDM_BdcTable->BDC_Mode=BDC_MODE_2;
-				pDM_BdcTable->BDC_state=BDC_DIV_TRAIN_STATE;
-				pDM_BdcTable->BDC_Try_flag=0;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Change to (( Mode2 ))\n"));
-				
-			}
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Antdiv + BF coextance Mode] : (( Mode2 ))\n"));
-		}
-		//2 Mode 3
-		else if((pDM_BdcTable->num_Txbfee_Client !=0) && (pDM_BdcTable->num_Txbfer_Client != 0))
-		{
-			current_BDC_Mode=BDC_MODE_3;
-			
-			if(current_BDC_Mode != pDM_BdcTable->BDC_Mode)
-			{
-				pDM_BdcTable->BDC_Mode=BDC_MODE_3;
-				pDM_BdcTable->BDC_state=BDC_DIV_TRAIN_STATE;
-				pDM_BdcTable->BDC_Try_flag=0;
-				pDM_BdcTable->BDC_RxIdleUpdate_counter=1;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Change to (( Mode3 ))\n"));
-			}
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Antdiv + BF coextance Mode] : (( Mode3 ))\n"));
-		}
-		//2 Mode 4
-		else if((pDM_BdcTable->num_Txbfee_Client ==0) && (pDM_BdcTable->num_Txbfer_Client == 0))
-		{
-			current_BDC_Mode=BDC_MODE_4;
-			
-			if(current_BDC_Mode != pDM_BdcTable->BDC_Mode)
-			{
-				pDM_BdcTable->BDC_Mode=BDC_MODE_4;
-				odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF);
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Change to (( Mode4 ))\n"));
-			}
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Antdiv + BF coextance Mode] : (( Mode4 ))\n"));
-		}
-	#endif
-
-}
-
-VOID
-odm_DivTrainState_setting( 
-	IN		PVOID 		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pBDC_T	pDM_BdcTable=&pDM_Odm->DM_BdcTable;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\n*****[S T A R T ]*****  [2-0. DIV_TRAIN_STATE] \n"));
-	pDM_BdcTable->BDC_Try_counter =2;
-	pDM_BdcTable->BDC_Try_flag=1; 
-	pDM_BdcTable->BDC_state=BDC_BFer_TRAIN_STATE;					
-	odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF);
-}
-
-VOID
-odm_BDCcoex_BFeeRxDiv_Arbitration(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pBDC_T    pDM_BdcTable = &pDM_Odm->DM_BdcTable;
-	BOOLEAN StopBF_flag;
-	u1Byte 	BDC_active_Mode;
-
-
-	#if(DM_ODM_SUPPORT_TYPE  == ODM_AP)
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***{ num_BFee,  num_BFer , num_Client}  = (( %d  ,  %d  ,  %d))  \n",pDM_BdcTable->num_Txbfee_Client,pDM_BdcTable->num_Txbfer_Client,pDM_BdcTable->num_Client));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***{ num_BF_tars,  num_DIV_tars }  = ((  %d  ,  %d ))  \n",pDM_BdcTable->num_BfTar , pDM_BdcTable->num_DivTar ));
-
-		//2 [ MIB control ]
-		if (pDM_Odm->bdc_holdstate==2) 
-		{
-			odm_BDCcoexType_withBferClient( pDM_Odm, DIVOFF_CSION); 
-			pDM_BdcTable->BDC_state=BDC_BF_HOLD_STATE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Force in [ BF STATE] \n"));
-			return;	
-		}
-		else if (pDM_Odm->bdc_holdstate==1) 
-		{
-			pDM_BdcTable->BDC_state=BDC_DIV_HOLD_STATE;
-			odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF); 
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Force in [ DIV STATE] \n"));
-			return;	
-		}
-
-		//------------------------------------------------------------
-
-
-		
-		//2 Mode 2 & 3
-		if(pDM_BdcTable->BDC_Mode==BDC_MODE_2 ||pDM_BdcTable->BDC_Mode==BDC_MODE_3)
-		{
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\n{ Try_flag ,  Try_counter } = {  %d , %d  } \n",pDM_BdcTable->BDC_Try_flag,pDM_BdcTable->BDC_Try_counter));
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BDCcoexType = (( %d ))  \n\n", pDM_BdcTable->BDCcoexType_wBfer));
-			
-                        // All Client have Bfer-Cap-------------------------------
-			if(pDM_BdcTable->num_Txbfer_Client == pDM_BdcTable->num_Client) //BFer STA Only?: yes
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BFer STA only?  (( Yes ))\n"));
-				pDM_BdcTable->BDC_Try_flag=0;
-				pDM_BdcTable->BDC_state=BDC_DIV_TRAIN_STATE;
-				odm_BDCcoexType_withBferClient( pDM_Odm, DIVOFF_CSION);
-				return;
-			}
-			else
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BFer STA only?  (( No ))\n"));
-			}
-			//
-			if(pDM_BdcTable->bAll_BFSta_Idle==FALSE && pDM_BdcTable->bAll_DivSta_Idle==TRUE)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("All DIV-STA are idle, but BF-STA not\n"));
-				pDM_BdcTable->BDC_Try_flag=0;
-				pDM_BdcTable->BDC_state=BDC_BFer_TRAIN_STATE;
-				odm_BDCcoexType_withBferClient( pDM_Odm, DIVOFF_CSION);
-				return;
-			}
-			else if(pDM_BdcTable->bAll_BFSta_Idle==TRUE && pDM_BdcTable->bAll_DivSta_Idle==FALSE)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("All BF-STA are idle, but DIV-STA not\n"));
-				pDM_BdcTable->BDC_Try_flag=0;
-				pDM_BdcTable->BDC_state=BDC_DIV_TRAIN_STATE;
-				odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF);
-				return;
-			}
-
-			//Select active mode--------------------------------------
-			if(pDM_BdcTable->num_BfTar ==0) //  Selsect_1,  Selsect_2
-			{
-				if(pDM_BdcTable->num_DivTar ==0)  // Selsect_3
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Select active mode (( 1 )) \n"));
-					pDM_BdcTable->BDC_active_Mode=1;
-				}
-				else
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Select active mode  (( 2 ))\n"));
-					pDM_BdcTable->BDC_active_Mode=2;
-				}
-				pDM_BdcTable->BDC_Try_flag=0;
-				pDM_BdcTable->BDC_state=BDC_DIV_TRAIN_STATE;
-				odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF);
-				return;
-			}
-			else // num_BfTar > 0
-			{			
-				if(pDM_BdcTable->num_DivTar ==0)  // Selsect_3
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Select active mode (( 3 ))\n"));		
-					pDM_BdcTable->BDC_active_Mode=3;
-					pDM_BdcTable->BDC_Try_flag=0;
-					pDM_BdcTable->BDC_state=BDC_BFer_TRAIN_STATE;
-					odm_BDCcoexType_withBferClient( pDM_Odm, DIVOFF_CSION);
-					return;
-				}
-				else // Selsect_4
-				{
-					BDC_active_Mode=4;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Select active mode (( 4 ))\n"));	
-					
-					if(BDC_active_Mode!=pDM_BdcTable->BDC_active_Mode)
-					{
-						pDM_BdcTable->BDC_active_Mode=4;
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Change to active mode (( 4 ))  &  return!!! \n"));	
-						return;
-					}
-				}
-			}
-
-#if 1
-		if (pDM_Odm->bdc_holdstate==0xff) 
-		{
-			pDM_BdcTable->BDC_state=BDC_DIV_HOLD_STATE;
-			odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF); 
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Force in [ DIV STATE] \n"));	
-			return;
-		}
-#endif
-
-			// Does Client number changed ? -------------------------------
-			if(pDM_BdcTable->num_Client !=pDM_BdcTable->pre_num_Client)
-			{ 
-				pDM_BdcTable->BDC_Try_flag=0;
-				pDM_BdcTable->BDC_state=BDC_DIV_TRAIN_STATE;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[  The number of client has been changed !!!]   return to (( BDC_DIV_TRAIN_STATE )) \n"));	
-			}
-			pDM_BdcTable->pre_num_Client=pDM_BdcTable->num_Client;
-
-			if( pDM_BdcTable->BDC_Try_flag==0)
-			{
-				//2 DIV_TRAIN_STATE (Mode 2-0)
-				if(pDM_BdcTable->BDC_state==BDC_DIV_TRAIN_STATE)
-				{
-					odm_DivTrainState_setting( pDM_Odm);
-				}
-				//2 BFer_TRAIN_STATE (Mode 2-1)
-				else if(pDM_BdcTable->BDC_state==BDC_BFer_TRAIN_STATE) 
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*****[2-1. BFer_TRAIN_STATE ]*****  \n"));
-					
-					//if(pDM_BdcTable->num_BfTar==0) 
-					//{
-					//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BF_tars exist?  : (( No )),   [ BDC_BFer_TRAIN_STATE ] >> [BDC_DIV_TRAIN_STATE] \n"));
-					//	odm_DivTrainState_setting( pDM_Odm);
-					//}
-					//else //num_BfTar != 0
-					//{
-						pDM_BdcTable->BDC_Try_counter=2;
-						pDM_BdcTable->BDC_Try_flag=1;
-						pDM_BdcTable->BDC_state=BDC_DECISION_STATE;
-						odm_BDCcoexType_withBferClient( pDM_Odm, DIVOFF_CSION); 
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BF_tars exist?  : (( Yes )),   [ BDC_BFer_TRAIN_STATE ] >> [BDC_DECISION_STATE] \n"));
-					//}
-				}
-				//2 DECISION_STATE (Mode 2-2)
-				else if(pDM_BdcTable->BDC_state==BDC_DECISION_STATE)
-				{			
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*****[2-2. DECISION_STATE]***** \n"));
-					//if(pDM_BdcTable->num_BfTar==0) 
-					//{
-					//	ODM_AntDiv_Printk(("BF_tars exist?  : (( No )),   [ DECISION_STATE ] >> [BDC_DIV_TRAIN_STATE] \n"));
-					//	odm_DivTrainState_setting( pDM_Odm);
-					//}
-					//else //num_BfTar != 0
-					//{
-						if(pDM_BdcTable->BF_pass==FALSE || pDM_BdcTable->DIV_pass == FALSE)
-							StopBF_flag=TRUE;
-						else
-							StopBF_flag=FALSE;
-						
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BF_tars exist?  : (( Yes )),  {BF_pass, DIV_pass, StopBF_flag }  = { %d, %d, %d } \n" ,pDM_BdcTable->BF_pass,pDM_BdcTable->DIV_pass,StopBF_flag));
-					
-						if(StopBF_flag==TRUE) //DIV_en
-						{
-							pDM_BdcTable->BDC_Hold_counter=10; //20
-							odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF); 
-							pDM_BdcTable->BDC_state=BDC_DIV_HOLD_STATE;
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ StopBF_flag= ((TRUE)),   BDC_DECISION_STATE ] >> [BDC_DIV_HOLD_STATE] \n"));
-						}
-						else //BF_en
-						{
-							pDM_BdcTable->BDC_Hold_counter=10; //20
-							odm_BDCcoexType_withBferClient( pDM_Odm, DIVOFF_CSION); 
-							pDM_BdcTable->BDC_state=BDC_BF_HOLD_STATE;
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[StopBF_flag= ((FALSE)),   BDC_DECISION_STATE ] >> [BDC_BF_HOLD_STATE] \n"));
-						}
-					//}
-				}
-				//2 BF-HOLD_STATE (Mode 2-3)
-				else if(pDM_BdcTable->BDC_state==BDC_BF_HOLD_STATE)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*****[2-3. BF_HOLD_STATE ]*****\n"));	
-
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BDC_Hold_counter = (( %d )) \n",pDM_BdcTable->BDC_Hold_counter ));	
-
-					if(pDM_BdcTable->BDC_Hold_counter==1)
-					{
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE] \n"));	
-						odm_DivTrainState_setting( pDM_Odm);
-					}
-					else
-					{
-						pDM_BdcTable->BDC_Hold_counter--;
-						
-						//if(pDM_BdcTable->num_BfTar==0) 
-						//{
-						//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BF_tars exist?  : (( No )),   [ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE] \n"));	
-						//	odm_DivTrainState_setting( pDM_Odm);
-						//}
-						//else //num_BfTar != 0
-						//{
-							//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BF_tars exist?  : (( Yes ))\n"));	
-							pDM_BdcTable->BDC_state=BDC_BF_HOLD_STATE;
-							odm_BDCcoexType_withBferClient( pDM_Odm, DIVOFF_CSION);
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ BDC_BF_HOLD_STATE ] >> [BDC_BF_HOLD_STATE] \n"));	
-						//}
-					}
-				
-				}
-				//2 DIV-HOLD_STATE (Mode 2-4)
-				else if(pDM_BdcTable->BDC_state==BDC_DIV_HOLD_STATE)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*****[2-4. DIV_HOLD_STATE ]*****\n"));	
-					
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("BDC_Hold_counter = (( %d )) \n",pDM_BdcTable->BDC_Hold_counter ));
-					
-					if(pDM_BdcTable->BDC_Hold_counter==1)
-					{
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE] \n"));	
-						odm_DivTrainState_setting( pDM_Odm);
-					}
-					else
-					{
-						pDM_BdcTable->BDC_Hold_counter--;
-						pDM_BdcTable->BDC_state=BDC_DIV_HOLD_STATE;
-						odm_BDCcoexType_withBferClient( pDM_Odm, DIVON_CSIOFF); 
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_HOLD_STATE] \n"));	
-					}
-				
-				}
-				
-			}
-			else if( pDM_BdcTable->BDC_Try_flag==1)
-			{
-				//2 Set Training Counter
-				if(pDM_BdcTable->BDC_Try_counter >1)
-				{
-					pDM_BdcTable->BDC_Try_counter--;
-					if(pDM_BdcTable->BDC_Try_counter ==1)
-						pDM_BdcTable->BDC_Try_flag=0; 
-						
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Training !!\n"));
-					//return ;
-				}
-				
-			}
-			
-		}
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\n[end]\n"));
-
-	#endif //#if(DM_ODM_SUPPORT_TYPE  == ODM_AP)
-
-
-
-
-	
-
-}
-
-#endif
-#endif //#ifdef BEAMFORMING_SUPPORT
-
-
-#if (RTL8188E_SUPPORT == 1)
-
-
-VOID
-odm_RX_HWAntDiv_Init_88E(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte	value32;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-
-	if(pDM_Odm->mp_mode == TRUE)
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_IGI_A_11N , BIT7, 0); // disable HW AntDiv 
-		ODM_SetBBReg(pDM_Odm, ODM_REG_LNA_SWITCH_11N , BIT31, 1);  // 1:CG, 0:CS
-        	return;
-	}
-	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8188E AntDiv_Init =>  AntDivType=[CGCS_RX_HW_ANTDIV]\n"));
-	
-	//MAC Setting
-	value32 = ODM_GetMACReg(pDM_Odm, ODM_REG_ANTSEL_PIN_11N, bMaskDWord);
-	ODM_SetMACReg(pDM_Odm, ODM_REG_ANTSEL_PIN_11N, bMaskDWord, value32|(BIT23|BIT25)); //Reg4C[25]=1, Reg4C[23]=1 for pin output
-	//Pin Settings
-	ODM_SetBBReg(pDM_Odm, ODM_REG_PIN_CTRL_11N , BIT9|BIT8, 0);//Reg870[8]=1'b0, Reg870[9]=1'b0 		//antsel antselb by HW
-	ODM_SetBBReg(pDM_Odm, ODM_REG_RX_ANT_CTRL_11N , BIT10, 0);	//Reg864[10]=1'b0 	//antsel2 by HW
-	ODM_SetBBReg(pDM_Odm, ODM_REG_LNA_SWITCH_11N , BIT22, 1);	//Regb2c[22]=1'b0 	//disable CS/CG switch
-	ODM_SetBBReg(pDM_Odm, ODM_REG_LNA_SWITCH_11N , BIT31, 1);	//Regb2c[31]=1'b1	//output at CG only
-	//OFDM Settings
-	ODM_SetBBReg(pDM_Odm, ODM_REG_ANTDIV_PARA1_11N , bMaskDWord, 0x000000a0);
-	//CCK Settings
-	ODM_SetBBReg(pDM_Odm, ODM_REG_BB_PWR_SAV4_11N , BIT7, 1); //Fix CCK PHY status report issue
-	ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_ANTDIV_PARA2_11N , BIT4, 1); //CCK complete HW AntDiv within 64 samples	
-	
-	ODM_SetBBReg(pDM_Odm, ODM_REG_ANT_MAPPING1_11N , 0xFFFF, 0x0001);	//antenna mapping table
-
-	pDM_FatTable->enable_ctrl_frame_antdiv = 1;
-}
-
-VOID
-odm_TRX_HWAntDiv_Init_88E(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte	value32;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	
-	if(pDM_Odm->mp_mode == TRUE)
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_IGI_A_11N , BIT7, 0); // disable HW AntDiv 
-		ODM_SetBBReg(pDM_Odm, ODM_REG_RX_ANT_CTRL_11N , BIT5|BIT4|BIT3, 0); //Default RX   (0/1)
-		return;
-	}
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8188E AntDiv_Init =>  AntDivType=[CG_TRX_HW_ANTDIV (SPDT)]\n"));
-	
-	//MAC Setting
-	value32 = ODM_GetMACReg(pDM_Odm, ODM_REG_ANTSEL_PIN_11N, bMaskDWord);
-	ODM_SetMACReg(pDM_Odm, ODM_REG_ANTSEL_PIN_11N, bMaskDWord, value32|(BIT23|BIT25)); //Reg4C[25]=1, Reg4C[23]=1 for pin output
-	//Pin Settings
-	ODM_SetBBReg(pDM_Odm, ODM_REG_PIN_CTRL_11N , BIT9|BIT8, 0);//Reg870[8]=1'b0, Reg870[9]=1'b0 		//antsel antselb by HW
-	ODM_SetBBReg(pDM_Odm, ODM_REG_RX_ANT_CTRL_11N , BIT10, 0);	//Reg864[10]=1'b0 	//antsel2 by HW
-	ODM_SetBBReg(pDM_Odm, ODM_REG_LNA_SWITCH_11N , BIT22, 0);	//Regb2c[22]=1'b0 	//disable CS/CG switch
-	ODM_SetBBReg(pDM_Odm, ODM_REG_LNA_SWITCH_11N , BIT31, 1);	//Regb2c[31]=1'b1	//output at CG only
-	//OFDM Settings
-	ODM_SetBBReg(pDM_Odm, ODM_REG_ANTDIV_PARA1_11N , bMaskDWord, 0x000000a0);
-	//CCK Settings
-	ODM_SetBBReg(pDM_Odm, ODM_REG_BB_PWR_SAV4_11N , BIT7, 1); //Fix CCK PHY status report issue
-	ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_ANTDIV_PARA2_11N , BIT4, 1); //CCK complete HW AntDiv within 64 samples
-
-	//antenna mapping table
-	if(!pDM_Odm->bIsMPChip) //testchip
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_RX_DEFUALT_A_11N , BIT10|BIT9|BIT8, 1);	//Reg858[10:8]=3'b001
-		ODM_SetBBReg(pDM_Odm, ODM_REG_RX_DEFUALT_A_11N , BIT13|BIT12|BIT11, 2);	//Reg858[13:11]=3'b010
-	}
-	else //MPchip
-		ODM_SetBBReg(pDM_Odm, ODM_REG_ANT_MAPPING1_11N , bMaskDWord, 0x0201);	/*Reg914=3'b010, Reg915=3'b001*/
-
-	pDM_FatTable->enable_ctrl_frame_antdiv = 1;
-}
-
-
-#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-VOID
-odm_Smart_HWAntDiv_Init_88E(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte	value32, i;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8188E AntDiv_Init =>  AntDivType=[CG_TRX_SMART_ANTDIV]\n"));
-    
-	if(pDM_Odm->mp_mode == TRUE)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("pDM_Odm->AntDivType: %d\n", pDM_Odm->AntDivType));
-		return;
-	}
-
-	pDM_FatTable->TrainIdx = 0;
-	pDM_FatTable->FAT_State = FAT_PREPARE_STATE;
-	
-	pDM_Odm->fat_comb_a=5;
-	pDM_Odm->antdiv_intvl = 0x64; // 100ms
-
-	for(i=0; i<6; i++)
-	{
-		pDM_FatTable->Bssid[i] = 0;
-	}
-	for(i=0; i< (pDM_Odm->fat_comb_a) ; i++)
-	{
-		pDM_FatTable->antSumRSSI[i] = 0;
-		pDM_FatTable->antRSSIcnt[i] = 0;
-		pDM_FatTable->antAveRSSI[i] = 0;
-	}
-
-	//MAC Setting
-	value32 = ODM_GetMACReg(pDM_Odm, 0x4c, bMaskDWord);
-	ODM_SetMACReg(pDM_Odm, 0x4c, bMaskDWord, value32|(BIT23|BIT25)); //Reg4C[25]=1, Reg4C[23]=1 for pin output
-	value32 = ODM_GetMACReg(pDM_Odm,  0x7B4, bMaskDWord);
-	ODM_SetMACReg(pDM_Odm, 0x7b4, bMaskDWord, value32|(BIT16|BIT17)); //Reg7B4[16]=1 enable antenna training, Reg7B4[17]=1 enable A2 match
-	//value32 = PlatformEFIORead4Byte(Adapter, 0x7B4);
-	//PlatformEFIOWrite4Byte(Adapter, 0x7b4, value32|BIT18);	//append MACID in reponse packet
-
-	//Match MAC ADDR
-	ODM_SetMACReg(pDM_Odm, 0x7b4, 0xFFFF, 0);
-	ODM_SetMACReg(pDM_Odm, 0x7b0, bMaskDWord, 0);
-	
-	ODM_SetBBReg(pDM_Odm, 0x870 , BIT9|BIT8, 0);//Reg870[8]=1'b0, Reg870[9]=1'b0 		//antsel antselb by HW
-	ODM_SetBBReg(pDM_Odm, 0x864 , BIT10, 0);	//Reg864[10]=1'b0 	//antsel2 by HW
-	ODM_SetBBReg(pDM_Odm, 0xb2c , BIT22, 0);	//Regb2c[22]=1'b0 	//disable CS/CG switch
-	ODM_SetBBReg(pDM_Odm, 0xb2c , BIT31, 0);	//Regb2c[31]=1'b1	//output at CS only
-	ODM_SetBBReg(pDM_Odm, 0xca4 , bMaskDWord, 0x000000a0);
-	
-	//antenna mapping table
-	if(pDM_Odm->fat_comb_a == 2)
-	{
-		if(!pDM_Odm->bIsMPChip) //testchip
-		{
-			ODM_SetBBReg(pDM_Odm, 0x858 , BIT10|BIT9|BIT8, 1);	//Reg858[10:8]=3'b001
-			ODM_SetBBReg(pDM_Odm, 0x858 , BIT13|BIT12|BIT11, 2);	//Reg858[13:11]=3'b010
-		}
-		else //MPchip
-		{
-			ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte0, 1);
-			ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte1, 2);
-		}
-	}
-	else
-	{
-		if(!pDM_Odm->bIsMPChip) //testchip
-		{
-			ODM_SetBBReg(pDM_Odm, 0x858 , BIT10|BIT9|BIT8, 0);	//Reg858[10:8]=3'b000
-			ODM_SetBBReg(pDM_Odm, 0x858 , BIT13|BIT12|BIT11, 1);	//Reg858[13:11]=3'b001
-			ODM_SetBBReg(pDM_Odm, 0x878 , BIT16, 0);
-			ODM_SetBBReg(pDM_Odm, 0x858 , BIT15|BIT14, 2);	//(Reg878[0],Reg858[14:15])=3'b010
-			ODM_SetBBReg(pDM_Odm, 0x878 , BIT19|BIT18|BIT17, 3);//Reg878[3:1]=3b'011
-			ODM_SetBBReg(pDM_Odm, 0x878 , BIT22|BIT21|BIT20, 4);//Reg878[6:4]=3b'100
-			ODM_SetBBReg(pDM_Odm, 0x878 , BIT25|BIT24|BIT23, 5);//Reg878[9:7]=3b'101 
-			ODM_SetBBReg(pDM_Odm, 0x878 , BIT28|BIT27|BIT26, 6);//Reg878[12:10]=3b'110 
-			ODM_SetBBReg(pDM_Odm, 0x878 , BIT31|BIT30|BIT29, 7);//Reg878[15:13]=3b'111
-		}
-		else //MPchip
-		{
-			ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte0, 4);     // 0: 3b'000
-			ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte1, 2);     // 1: 3b'001	
-			ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte2, 0);     // 2: 3b'010
-			ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte3, 1);     // 3: 3b'011
-			ODM_SetBBReg(pDM_Odm, 0x918 , bMaskByte0, 3);     // 4: 3b'100
-			ODM_SetBBReg(pDM_Odm, 0x918 , bMaskByte1, 5);     // 5: 3b'101
-			ODM_SetBBReg(pDM_Odm, 0x918 , bMaskByte2, 6);     // 6: 3b'110
-			ODM_SetBBReg(pDM_Odm, 0x918 , bMaskByte3, 255); // 7: 3b'111
-		}
-	}
-
-	//Default Ant Setting when no fast training
-	ODM_SetBBReg(pDM_Odm, 0x864 , BIT5|BIT4|BIT3, 0);	//Default RX
-	ODM_SetBBReg(pDM_Odm, 0x864 , BIT8|BIT7|BIT6, 1);	//Optional RX
-	ODM_SetBBReg(pDM_Odm, 0x860 , BIT14|BIT13|BIT12, 0);//Default TX
-
-	//Enter Traing state
-	ODM_SetBBReg(pDM_Odm, 0x864 , BIT2|BIT1|BIT0, (pDM_Odm->fat_comb_a-1));	//Reg864[2:0]=3'd6	//ant combination=reg864[2:0]+1
-
-	//SW Control
-	//PHY_SetBBReg(Adapter, 0x864 , BIT10, 1);
-	//PHY_SetBBReg(Adapter, 0x870 , BIT9, 1);
-	//PHY_SetBBReg(Adapter, 0x870 , BIT8, 1);
-	//PHY_SetBBReg(Adapter, 0x864 , BIT11, 1);
-	//PHY_SetBBReg(Adapter, 0x860 , BIT9, 0);
-	//PHY_SetBBReg(Adapter, 0x860 , BIT8, 0);
-}
-#endif
-
-#endif //#if (RTL8188E_SUPPORT == 1)
-
-
-#if (RTL8192E_SUPPORT == 1)
-VOID
-odm_RX_HWAntDiv_Init_92E(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	
-	if(pDM_Odm->mp_mode == TRUE)
-	{
-		odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-		ODM_SetBBReg(pDM_Odm, 0xc50 , BIT8, 0); //r_rxdiv_enable_anta  Regc50[8]=1'b0  0: control by c50[9]
-		ODM_SetBBReg(pDM_Odm, 0xc50 , BIT9, 1);  // 1:CG, 0:CS
-		return;
-	}
-	
-	 ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8192E AntDiv_Init =>  AntDivType=[CGCS_RX_HW_ANTDIV]\n"));
-	
-	 //Pin Settings
-	 ODM_SetBBReg(pDM_Odm, 0x870 , BIT8, 0);//Reg870[8]=1'b0,    // "antsel" is controled by HWs
-	 ODM_SetBBReg(pDM_Odm, 0xc50 , BIT8, 1); //Regc50[8]=1'b1  //" CS/CG switching" is controled by HWs
-
-	 //Mapping table
-	 ODM_SetBBReg(pDM_Odm, 0x914 , 0xFFFF, 0x0100); //antenna mapping table
-	  
-	 //OFDM Settings
-	 ODM_SetBBReg(pDM_Odm, 0xca4 , 0x7FF, 0xA0); //thershold
-	 ODM_SetBBReg(pDM_Odm, 0xca4 , 0x7FF000, 0x0); //bias
-	 
-	 //CCK Settings
-	 ODM_SetBBReg(pDM_Odm, 0xa04 , 0xF000000, 0); //Select which path to receive for CCK_1 & CCK_2
-	 ODM_SetBBReg(pDM_Odm, 0xb34 , BIT30, 0); //(92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0
-	 ODM_SetBBReg(pDM_Odm, 0xa74 , BIT7, 1); //Fix CCK PHY status report issue
-	 ODM_SetBBReg(pDM_Odm, 0xa0c , BIT4, 1); //CCK complete HW AntDiv within 64 samples 	 
-	 
-	 #ifdef ODM_EVM_ENHANCE_ANTDIV
-	//EVM enhance AntDiv method init----------------------------------------------------------------------
-	pDM_FatTable->EVM_method_enable=0;
-	pDM_FatTable->FAT_State = NORMAL_STATE_MIAN;
-	pDM_Odm->antdiv_intvl = 0x64; 
-	ODM_SetBBReg(pDM_Odm, 0x910 , 0x3f, 0xf );	   
-	pDM_Odm->antdiv_evm_en=1;
-	//pDM_Odm->antdiv_period=1;
-
-	#endif
-	 
-}
-
-VOID
-odm_TRX_HWAntDiv_Init_92E(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	
-	if(pDM_Odm->mp_mode == TRUE)
-	{
-		odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-		ODM_SetBBReg(pDM_Odm, 0xc50 , BIT8, 0); //r_rxdiv_enable_anta  Regc50[8]=1'b0  0: control by c50[9]
-		ODM_SetBBReg(pDM_Odm, 0xc50 , BIT9, 1);  // 1:CG, 0:CS
-		return;
-	}
-
-	 ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8192E AntDiv_Init =>  AntDivType=[ Only for DIR605, CG_TRX_HW_ANTDIV]\n"));
-	
-	//3 --RFE pin setting---------
-	//[MAC]
-	ODM_SetMACReg(pDM_Odm, 0x38, BIT11, 1);            //DBG PAD Driving control (GPIO 8)
-	ODM_SetMACReg(pDM_Odm, 0x4c, BIT23, 0);            //path-A , RFE_CTRL_3 
-	ODM_SetMACReg(pDM_Odm, 0x4c, BIT29, 1);            //path-A , RFE_CTRL_8
-	//[BB]
-	ODM_SetBBReg(pDM_Odm, 0x944 , BIT3, 1);              //RFE_buffer
-	ODM_SetBBReg(pDM_Odm, 0x944 , BIT8, 1);	
-	ODM_SetBBReg(pDM_Odm, 0x940 , BIT7|BIT6, 0x0); // r_rfe_path_sel_   (RFE_CTRL_3)
-	ODM_SetBBReg(pDM_Odm, 0x940 , BIT17|BIT16, 0x0); // r_rfe_path_sel_   (RFE_CTRL_8)
-	ODM_SetBBReg(pDM_Odm, 0x944 , BIT31, 0);     //RFE_buffer
-	ODM_SetBBReg(pDM_Odm, 0x92C , BIT3, 0);     //rfe_inv  (RFE_CTRL_3)
-	ODM_SetBBReg(pDM_Odm, 0x92C , BIT8, 1);     //rfe_inv  (RFE_CTRL_8)
-	ODM_SetBBReg(pDM_Odm, 0x930 , 0xF000, 0x8);           //path-A , RFE_CTRL_3 
-	ODM_SetBBReg(pDM_Odm, 0x934 , 0xF, 0x8);           //path-A , RFE_CTRL_8
-	//3 -------------------------
-	
-	 //Pin Settings
-	ODM_SetBBReg(pDM_Odm, 0xC50 , BIT8, 0);	   //path-A   	//disable CS/CG switch
-
-/* Let it follows PHY_REG for bit9 setting
-	if(pDM_Odm->priv->pshare->rf_ft_var.use_ext_pa || pDM_Odm->priv->pshare->rf_ft_var.use_ext_lna)
-		ODM_SetBBReg(pDM_Odm, 0xC50 , BIT9, 1);//path-A 	//output at CS
-	else
-		ODM_SetBBReg(pDM_Odm, 0xC50 , BIT9, 0);    //path-A 	//output at CG ->normal power
-*/
-
-	ODM_SetBBReg(pDM_Odm, 0x870 , BIT9|BIT8, 0);  //path-A  	//antsel antselb by HW
-	ODM_SetBBReg(pDM_Odm, 0xB38 , BIT10, 0);	   //path-A    	//antsel2 by HW	
- 
-	//Mapping table
-	 ODM_SetBBReg(pDM_Odm, 0x914 , 0xFFFF, 0x0100); //antenna mapping table
-	  
-	 //OFDM Settings
-	 ODM_SetBBReg(pDM_Odm, 0xca4 , 0x7FF, 0xA0); //thershold
-	 ODM_SetBBReg(pDM_Odm, 0xca4 , 0x7FF000, 0x0); //bias
-	 
-	 //CCK Settings
-	 ODM_SetBBReg(pDM_Odm, 0xa04 , 0xF000000, 0); //Select which path to receive for CCK_1 & CCK_2
-	 ODM_SetBBReg(pDM_Odm, 0xb34 , BIT30, 0); //(92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0
-	 ODM_SetBBReg(pDM_Odm, 0xa74 , BIT7, 1); //Fix CCK PHY status report issue
-	 ODM_SetBBReg(pDM_Odm, 0xa0c , BIT4, 1); //CCK complete HW AntDiv within 64 samples 
-
-	 //Timming issue
-	 ODM_SetBBReg(pDM_Odm, 0xE20 , BIT23|BIT22|BIT21|BIT20, 8); //keep antidx after tx for ACK ( unit x 32 mu sec)
-
-	#ifdef ODM_EVM_ENHANCE_ANTDIV
-	//EVM enhance AntDiv method init----------------------------------------------------------------------
-	pDM_FatTable->EVM_method_enable=0;
-	pDM_FatTable->FAT_State = NORMAL_STATE_MIAN;
-	pDM_Odm->antdiv_intvl = 0x64; 
-	ODM_SetBBReg(pDM_Odm, 0x910 , 0x3f, 0xf );	   
-	pDM_Odm->antdiv_evm_en=1;
-	//pDM_Odm->antdiv_period=1;
-	#endif
-}
-
-#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-VOID
-odm_Smart_HWAntDiv_Init_92E(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8192E AntDiv_Init =>  AntDivType=[CG_TRX_SMART_ANTDIV]\n"));
-}
-#endif
-
-#endif //#if (RTL8192E_SUPPORT == 1)
-
-
-#if (RTL8723B_SUPPORT == 1)
-VOID
-odm_TRX_HWAntDiv_Init_8723B(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8723B AntDiv_Init =>  AntDivType=[CG_TRX_HW_ANTDIV(DPDT)]\n"));
-      
-	//Mapping Table
-	ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte0, 0);
-	ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte1, 1);
-	
-	//OFDM HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , 0x7FF, 0xa0); //thershold
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , 0x7FF000, 0x00); //bias
-		
-	//CCK HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0xA74 , BIT7, 1); //patch for clk from 88M to 80M
-	ODM_SetBBReg(pDM_Odm, 0xA0C , BIT4, 1); //do 64 samples
-	
-	//BT Coexistence
-	ODM_SetBBReg(pDM_Odm, 0x864, BIT12, 0); //keep antsel_map when GNT_BT = 1
-	ODM_SetBBReg(pDM_Odm, 0x874 , BIT23, 0); //Disable hw antsw & fast_train.antsw when GNT_BT=1
-
-        //Output Pin Settings
-	ODM_SetBBReg(pDM_Odm, 0x870 , BIT8, 0); //
-		
-	ODM_SetBBReg(pDM_Odm, 0x948 , BIT6, 0); //WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL)
-	ODM_SetBBReg(pDM_Odm, 0x948 , BIT7, 0);
-		
-	ODM_SetMACReg(pDM_Odm, 0x40 , BIT3, 1);
-	ODM_SetMACReg(pDM_Odm, 0x38 , BIT11, 1);
-	ODM_SetMACReg(pDM_Odm, 0x4C ,  BIT24|BIT23, 2); //select DPDT_P and DPDT_N as output pin
-		
-	ODM_SetBBReg(pDM_Odm, 0x944 , BIT0|BIT1, 3); //in/out
-	ODM_SetBBReg(pDM_Odm, 0x944 , BIT31, 0); //
-
-	ODM_SetBBReg(pDM_Odm, 0x92C , BIT1, 0); //DPDT_P non-inverse
-	ODM_SetBBReg(pDM_Odm, 0x92C , BIT0, 1); //DPDT_N inverse
-
-	ODM_SetBBReg(pDM_Odm, 0x930 , 0xF0, 8); // DPDT_P = ANTSEL[0]
-	ODM_SetBBReg(pDM_Odm, 0x930 , 0xF, 8); // DPDT_N = ANTSEL[0]
-
-	//Timming issue
-	ODM_SetBBReg(pDM_Odm, 0xE20 , BIT23|BIT22|BIT21|BIT20, 8); //keep antidx after tx for ACK ( unit x 32 mu sec)
-
-	//2 [--For HW Bug Setting]
-	if(pDM_Odm->AntType == ODM_AUTO_ANT)
-		ODM_SetBBReg(pDM_Odm, 0xA00 , BIT15, 0); //CCK AntDiv function block enable
-
-}
-
-	
-
-VOID
-odm_S0S1_SWAntDiv_Init_8723B(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	pFAT_T		pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8723B AntDiv_Init => AntDivType=[ S0S1_SW_AntDiv] \n"));
-
-	//Mapping Table
-	ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte0, 0);
-	ODM_SetBBReg(pDM_Odm, 0x914 , bMaskByte1, 1);
-	
-	//Output Pin Settings
-	//ODM_SetBBReg(pDM_Odm, 0x948 , BIT6, 0x1); 
-	ODM_SetBBReg(pDM_Odm, 0x870 , BIT9|BIT8, 0); 
-
-	pDM_FatTable->bBecomeLinked  =FALSE;
-	pDM_SWAT_Table->try_flag = SWAW_STEP_INIT;	
-	pDM_SWAT_Table->Double_chk_flag = 0;
-
-	//Timming issue
-	ODM_SetBBReg(pDM_Odm, 0xE20 , BIT23|BIT22|BIT21|BIT20, 8); //keep antidx after tx for ACK ( unit x 32 mu sec)
-	
-	//2 [--For HW Bug Setting]
-	ODM_SetBBReg(pDM_Odm, 0x80C , BIT21, 0); //TX Ant  by Reg
-
-}
-
-VOID
-ODM_UpdateRxIdleAnt_8723B(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Ant,
-	IN		u4Byte			DefaultAnt, 
-	IN		u4Byte			OptionalAnt
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	PADAPTER 		pAdapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u1Byte			count=0;
-	u1Byte			u1Temp;
-	u1Byte			H2C_Parameter;
-	
-	if(!pDM_Odm->bLinked)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: Fail to set RX antenna due to no link\n"));
-		return;
-	}
-
-#if 0
-	// Send H2C command to FW
-	// Enable wifi calibration
-	H2C_Parameter = TRUE;
-	ODM_FillH2CCmd(pDM_Odm, ODM_H2C_WIFI_CALIBRATION, 1, &H2C_Parameter);
-
-	// Check if H2C command sucess or not (0x1e6)
-	u1Temp = ODM_Read1Byte(pDM_Odm, 0x1e6);
-	while((u1Temp != 0x1) && (count < 100))
-	{
-		ODM_delay_us(10);	
-		u1Temp = ODM_Read1Byte(pDM_Odm, 0x1e6);
-		count++;
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: H2C command status = %d, count = %d\n", u1Temp, count));
-
-	if(u1Temp == 0x1)
-	{
-		// Check if BT is doing IQK (0x1e7)
-		count = 0;
-		u1Temp = ODM_Read1Byte(pDM_Odm, 0x1e7);
-		while((!(u1Temp & BIT0))  && (count < 100))
-		{
-			ODM_delay_us(50);	
-			u1Temp = ODM_Read1Byte(pDM_Odm, 0x1e7);
-			count++;
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: BT IQK status = %d, count = %d\n", u1Temp, count));
-
-		if(u1Temp & BIT0)
-		{
-			ODM_SetBBReg(pDM_Odm, 0x948 , BIT6, 0x1);
-			ODM_SetBBReg(pDM_Odm, 0x948 , BIT9, DefaultAnt);	
-			ODM_SetBBReg(pDM_Odm, 0x864 , BIT5|BIT4|BIT3, DefaultAnt);	//Default RX
-			ODM_SetBBReg(pDM_Odm, 0x864 , BIT8|BIT7|BIT6, OptionalAnt);	//Optional RX
-			ODM_SetBBReg(pDM_Odm, 0x860, BIT14|BIT13|BIT12, DefaultAnt); //Default TX	
-			pDM_FatTable->RxIdleAnt = Ant;
-
-			// Set TX AGC by S0/S1
-			// Need to consider Linux driver
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			 pAdapter->HalFunc.SetTxPowerLevelHandler(pAdapter, pHalData->CurrentChannel);
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-			rtw_hal_set_tx_power_level(pAdapter, pHalData->CurrentChannel);
-#endif
-
-			// Set IQC by S0/S1
-			ODM_SetIQCbyRFpath(pDM_Odm,DefaultAnt);
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: Sucess to set RX antenna\n"));
-		}
-		else
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: Fail to set RX antenna due to BT IQK\n"));
-	}
-	else
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: Fail to set RX antenna due to H2C command fail\n"));
-
-	// Send H2C command to FW
-	// Disable wifi calibration
-	H2C_Parameter = FALSE;
-	ODM_FillH2CCmd(pDM_Odm, ODM_H2C_WIFI_CALIBRATION, 1, &H2C_Parameter);
-#else
-
-	ODM_SetBBReg(pDM_Odm, 0x948 , BIT6, 0x1);
-	ODM_SetBBReg(pDM_Odm, 0x948 , BIT9, DefaultAnt);	
-	ODM_SetBBReg(pDM_Odm, 0x864 , BIT5|BIT4|BIT3, DefaultAnt);          /*Default RX*/
-	ODM_SetBBReg(pDM_Odm, 0x864 , BIT8|BIT7|BIT6, OptionalAnt);         /*Optional RX*/
-	ODM_SetBBReg(pDM_Odm, 0x860, BIT14|BIT13|BIT12, DefaultAnt);        /*Default TX*/
-	pDM_FatTable->RxIdleAnt = Ant;
-
-	/* Set TX AGC by S0/S1 */
-	/* Need to consider Linux driver */
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		 pAdapter->HalFunc.SetTxPowerLevelHandler(pAdapter, pHalData->CurrentChannel);
-	#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-		rtw_hal_set_tx_power_level(pAdapter, pHalData->CurrentChannel);
-	#endif
-
-	/* Set IQC by S0/S1 */
-	ODM_SetIQCbyRFpath(pDM_Odm, DefaultAnt);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Ant ] 8723B: Success to set RX antenna\n"));
-
-#endif
-}
-
-BOOLEAN
-phydm_IsBtEnable_8723b(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			bt_state;
-	/*u4Byte			reg75;*/
-
-	/*reg75 = ODM_GetBBReg(pDM_Odm, 0x74 , BIT8);*/
-	/*ODM_SetBBReg(pDM_Odm, 0x74 , BIT8, 0x0);*/
-	ODM_SetBBReg(pDM_Odm, 0xa0 , BIT24|BIT25|BIT26, 0x5);
-	bt_state = ODM_GetBBReg(pDM_Odm, 0xa0 , (BIT3|BIT2|BIT1|BIT0));
-	/*ODM_SetBBReg(pDM_Odm, 0x74 , BIT8, reg75);*/
-
-	if ((bt_state == 4) || (bt_state == 7) || (bt_state == 9) || (bt_state == 13))
-		return TRUE;
-	else
-		return FALSE;
-}
-#endif //#if (RTL8723B_SUPPORT == 1)
-
-#if (RTL8821A_SUPPORT == 1)
-#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-VOID
-phydm_hl_smart_ant_type1_init_8821a(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	u4Byte			value32;
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8821A SmartAnt_Init => AntDivType=[Hong-Lin Smart Ant Type1]\n"));
-	
-	/*----------------------------------------
-	GPIO 2-3 for Beam control 
-	    reg0x66[2]=0
-	    reg0x44[27:26] = 0
-	    reg0x44[23:16] //enable_output for P_GPIO[7:0]
-	    reg0x44[15:8] //output_value for P_GPIO[7:0]
-	    reg0x40[1:0] = 0 //GPIO function
-	------------------------------------------*/
-	
-	/*GPIO Setting*/
-	ODM_SetMACReg(pDM_Odm, 0x64 , BIT18, 0); 
-	ODM_SetMACReg(pDM_Odm, 0x44 , BIT27|BIT26, 0);
-	ODM_SetMACReg(pDM_Odm, 0x44 , BIT19|BIT18, 0x3);	/*enable_output for P_GPIO[3:2]*/
-	/*ODM_SetMACReg(pDM_Odm, 0x44 , BIT11|BIT10, 0);*/ /*output value*/
-	ODM_SetMACReg(pDM_Odm, 0x40 , BIT1|BIT0, 0);		/*GPIO function*/
-
-	/*Hong_lin smart antenna HW Setting*/
-	pdm_sat_table->data_codeword_bit_num  = 24;/*max=32*/
-	pdm_sat_table->beam_patten_num_each_ant = 4;
-
-	#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
-	pdm_sat_table->latch_time = 100; /*mu sec*/
-	#elif DEV_BUS_TYPE == RT_USB_INTERFACE
-	pdm_sat_table->latch_time = 100; /*mu sec*/
-	#endif
-	pdm_sat_table->pkt_skip_statistic_en = 0;
-	
-	pdm_sat_table->ant_num  = 2;/*max=8*/
-
-	pdm_sat_table->fix_beam_pattern_en  = 0;
-	pdm_sat_table->decision_holding_period = 0;
-
-	/*beam training setting*/
-	pdm_sat_table->pkt_counter = 0;
-	pdm_sat_table->per_beam_training_pkt_num = 10;
-
-	/*set default beam*/
-	pdm_sat_table->fast_training_beam_num = 0;
-	pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-	phydm_set_all_ant_same_beam_num(pDM_Odm);
-
-	pDM_FatTable->FAT_State = FAT_BEFORE_LINK_STATE;
-
-	/*[BB] FAT Setting*/
-	ODM_SetBBReg(pDM_Odm, 0xc08 , BIT18|BIT17|BIT16, pdm_sat_table->ant_num);
-	ODM_SetBBReg(pDM_Odm, 0xc08 , BIT31, 0); /*increase ant num every FAT period 0:+1, 1+2*/
-	ODM_SetBBReg(pDM_Odm, 0x8c4 , BIT2|BIT1, 1); /*change cca antenna timming threshold if no CCA occurred: 0:200ms / 1:100ms / 2:no use / 3: 300*/
-	ODM_SetBBReg(pDM_Odm, 0x8c4 , BIT0, 1); /*FAT_watchdog_en*/
-	
-	value32 = ODM_GetMACReg(pDM_Odm,  0x7B4, bMaskDWord);
-	ODM_SetMACReg(pDM_Odm, 0x7b4, bMaskDWord, value32|(BIT16|BIT17));	/*Reg7B4[16]=1 enable antenna training */
-																		/*Reg7B4[17]=1 enable  match MAC Addr*/
-	ODM_SetMACReg(pDM_Odm, 0x7b4, 0xFFFF, 0);/*Match MAC ADDR*/
-	ODM_SetMACReg(pDM_Odm, 0x7b0, bMaskDWord, 0);
-
-}
-#endif
-
-VOID
-odm_TRX_HWAntDiv_Init_8821A(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8821A AntDiv_Init => AntDivType=[ CG_TRX_HW_ANTDIV (DPDT)] \n"));
-
-	//Output Pin Settings
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT25, 0);
-
-	ODM_SetMACReg(pDM_Odm, 0x64 , BIT29, 1); //PAPE by WLAN control
-	ODM_SetMACReg(pDM_Odm, 0x64 , BIT28, 1); //LNAON by WLAN control
-
-	ODM_SetBBReg(pDM_Odm, 0xCB0 , bMaskDWord, 0x77775745);
-	ODM_SetBBReg(pDM_Odm, 0xCB8 , BIT16, 0);
-	
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT23, 0); //select DPDT_P and DPDT_N as output pin
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT24, 1); //by WLAN control
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , 0xF, 8); // DPDT_P = ANTSEL[0]
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , 0xF0, 8); // DPDT_N = ANTSEL[0]
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT29, 0); //DPDT_P non-inverse
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT28, 1); //DPDT_N inverse
-
-	//Mapping Table
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte0, 0);
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte1, 1);
-
-	//OFDM HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF, 0xA0); //thershold
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF000, 0x10); //bias
-		
-	//CCK HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0xA74 , BIT7, 1); //patch for clk from 88M to 80M
-	ODM_SetBBReg(pDM_Odm, 0xA0C , BIT4, 1); //do 64 samples
-
-	ODM_SetBBReg(pDM_Odm, 0x800 , BIT25, 0); //ANTSEL_CCK sent to the smart_antenna circuit
-	ODM_SetBBReg(pDM_Odm, 0xA00 , BIT15, 0); //CCK AntDiv function block enable
-
-	//BT Coexistence
-	ODM_SetBBReg(pDM_Odm, 0xCAC , BIT9, 1); //keep antsel_map when GNT_BT = 1
-	ODM_SetBBReg(pDM_Odm, 0x804 , BIT4, 1); //Disable hw antsw & fast_train.antsw when GNT_BT=1
-
-	//Timming issue
-	ODM_SetBBReg(pDM_Odm, 0x818 , BIT23|BIT22|BIT21|BIT20, 8); //keep antidx after tx for ACK ( unit x 32 mu sec)
-	ODM_SetBBReg(pDM_Odm, 0x8CC , BIT20|BIT19|BIT18, 3); //settling time of antdiv by RF LNA = 100ns
-
-	//response TX ant by RX ant
-	ODM_SetMACReg(pDM_Odm, 0x668 , BIT3, 1);
-			
-}
-
-VOID
-odm_S0S1_SWAntDiv_Init_8821A(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8821A AntDiv_Init => AntDivType=[ S0S1_SW_AntDiv]\n"));
-
-	//Output Pin Settings
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT25, 0);
-
-	ODM_SetMACReg(pDM_Odm, 0x64 , BIT29, 1); //PAPE by WLAN control
-	ODM_SetMACReg(pDM_Odm, 0x64 , BIT28, 1); //LNAON by WLAN control
-
-	ODM_SetBBReg(pDM_Odm, 0xCB0 , bMaskDWord, 0x77775745);
-	ODM_SetBBReg(pDM_Odm, 0xCB8 , BIT16, 0);
-	
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT23, 0); //select DPDT_P and DPDT_N as output pin
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT24, 1); //by WLAN control
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , 0xF, 8); // DPDT_P = ANTSEL[0]
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , 0xF0, 8); // DPDT_N = ANTSEL[0]
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT29, 0); //DPDT_P non-inverse
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT28, 1); //DPDT_N inverse
-
-	//Mapping Table
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte0, 0);
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte1, 1);
-
-	//OFDM HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF, 0xA0); //thershold
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF000, 0x10); //bias
-		
-	//CCK HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0xA74 , BIT7, 1); //patch for clk from 88M to 80M
-	ODM_SetBBReg(pDM_Odm, 0xA0C , BIT4, 1); //do 64 samples
-
-	ODM_SetBBReg(pDM_Odm, 0x800 , BIT25, 0); //ANTSEL_CCK sent to the smart_antenna circuit
-	ODM_SetBBReg(pDM_Odm, 0xA00 , BIT15, 0); //CCK AntDiv function block enable
-
-	//BT Coexistence
-	ODM_SetBBReg(pDM_Odm, 0xCAC , BIT9, 1); //keep antsel_map when GNT_BT = 1
-	ODM_SetBBReg(pDM_Odm, 0x804 , BIT4, 1); //Disable hw antsw & fast_train.antsw when GNT_BT=1
-
-	//Timming issue
-	ODM_SetBBReg(pDM_Odm, 0x818 , BIT23|BIT22|BIT21|BIT20, 8); //keep antidx after tx for ACK ( unit x 32 mu sec)
-	ODM_SetBBReg(pDM_Odm, 0x8CC , BIT20|BIT19|BIT18, 3); //settling time of antdiv by RF LNA = 100ns
-
-	//response TX ant by RX ant
-	ODM_SetMACReg(pDM_Odm, 0x668 , BIT3, 1);
-
-
-	ODM_SetBBReg(pDM_Odm, 0x900 , BIT18, 0); 
-	
-	pDM_SWAT_Table->try_flag = SWAW_STEP_INIT;	
-	pDM_SWAT_Table->Double_chk_flag = 0;
-	pDM_SWAT_Table->CurAntenna = MAIN_ANT;
-	pDM_SWAT_Table->PreAntenna = MAIN_ANT;
-	pDM_SWAT_Table->SWAS_NoLink_State = 0;
-
-}
-#endif //#if (RTL8821A_SUPPORT == 1)
-
-#if (RTL8881A_SUPPORT == 1)
-VOID
-odm_RX_HWAntDiv_Init_8881A(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8881A AntDiv_Init => AntDivType=[ CGCS_RX_HW_ANTDIV] \n"));
-
-}
-
-VOID
-odm_TRX_HWAntDiv_Init_8881A(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8881A AntDiv_Init => AntDivType=[ CG_TRX_HW_ANTDIV (SPDT)] \n"));
-
-	//Output Pin Settings
-	// [SPDT related]
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT25, 0);
-	ODM_SetMACReg(pDM_Odm, 0x4C , BIT26, 0);
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT31, 0); //delay buffer
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT22, 0); 
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT24, 1);
-	ODM_SetBBReg(pDM_Odm, 0xCB0 , 0xF00, 8); // DPDT_P = ANTSEL[0]
-	ODM_SetBBReg(pDM_Odm, 0xCB0 , 0xF0000, 8); // DPDT_N = ANTSEL[0]	
-	
-	//Mapping Table
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte0, 0);
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte1, 1);
-
-	//OFDM HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF, 0xA0); //thershold
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF000, 0x0); //bias
-	ODM_SetBBReg(pDM_Odm, 0x8CC , BIT20|BIT19|BIT18, 3); //settling time of antdiv by RF LNA = 100ns
-	
-	//CCK HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0xA74 , BIT7, 1); //patch for clk from 88M to 80M
-	ODM_SetBBReg(pDM_Odm, 0xA0C , BIT4, 1); //do 64 samples
-
-	//Timming issue
-	ODM_SetBBReg(pDM_Odm, 0x818 , BIT23|BIT22|BIT21|BIT20, 8); //keep antidx after tx for ACK ( unit x 32 mu sec)
-
-	//2 [--For HW Bug Setting]
-
-	ODM_SetBBReg(pDM_Odm, 0x900 , BIT18, 0); //TX Ant  by Reg //  A-cut bug
-}
-
-#endif //#if (RTL8881A_SUPPORT == 1)
-
-
-#if (RTL8812A_SUPPORT == 1)
-VOID
-odm_TRX_HWAntDiv_Init_8812A(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8812A AntDiv_Init => AntDivType=[ CG_TRX_HW_ANTDIV (SPDT)] \n"));
-
-	//3 //3 --RFE pin setting---------
-	//[BB]
-	ODM_SetBBReg(pDM_Odm, 0x900 , BIT10|BIT9|BIT8, 0x0);	  //disable SW switch
-	ODM_SetBBReg(pDM_Odm, 0x900 , BIT17|BIT16, 0x0);	 
-	ODM_SetBBReg(pDM_Odm, 0x974 , BIT7|BIT6, 0x3);     // in/out
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT31, 0); //delay buffer
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT26, 0); 
-	ODM_SetBBReg(pDM_Odm, 0xCB4 , BIT27, 1);
-	ODM_SetBBReg(pDM_Odm, 0xCB0 , 0xF000000, 8); // DPDT_P = ANTSEL[0]
-	ODM_SetBBReg(pDM_Odm, 0xCB0 , 0xF0000000, 8); // DPDT_N = ANTSEL[0]
-	//3 -------------------------
-
-	//Mapping Table
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte0, 0);
-	ODM_SetBBReg(pDM_Odm, 0xCA4 , bMaskByte1, 1);
-
-	//OFDM HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF, 0xA0); //thershold
-	ODM_SetBBReg(pDM_Odm, 0x8D4 , 0x7FF000, 0x0); //bias
-	ODM_SetBBReg(pDM_Odm, 0x8CC , BIT20|BIT19|BIT18, 3); //settling time of antdiv by RF LNA = 100ns
-	
-	//CCK HW AntDiv Parameters
-	ODM_SetBBReg(pDM_Odm, 0xA74 , BIT7, 1); //patch for clk from 88M to 80M
-	ODM_SetBBReg(pDM_Odm, 0xA0C , BIT4, 1); //do 64 samples
-
-	//Timming issue
-	ODM_SetBBReg(pDM_Odm, 0x818 , BIT23|BIT22|BIT21|BIT20, 8); //keep antidx after tx for ACK ( unit x 32 mu sec)
-
-	//2 [--For HW Bug Setting]
-
-	ODM_SetBBReg(pDM_Odm, 0x900 , BIT18, 0); //TX Ant  by Reg //  A-cut bug
-	
-}
-
-#endif //#if (RTL8812A_SUPPORT == 1)
-
-#if (RTL8188F_SUPPORT == 1)
-VOID
-odm_S0S1_SWAntDiv_Init_8188F(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	pFAT_T		pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***8188F AntDiv_Init => AntDivType=[ S0S1_SW_AntDiv]\n"));
-
-
-	/*GPIO Setting*/
-	/*ODM_SetMACReg(pDM_Odm, 0x64 , BIT18, 0); */
-	/*ODM_SetMACReg(pDM_Odm, 0x44 , BIT28|BIT27, 0);*/
-	ODM_SetMACReg(pDM_Odm, 0x44 , BIT20|BIT19, 0x3);	/*enable_output for P_GPIO[4:3]*/
-	/*ODM_SetMACReg(pDM_Odm, 0x44 , BIT12|BIT11, 0);*/ /*output value*/
-	/*ODM_SetMACReg(pDM_Odm, 0x40 , BIT1|BIT0, 0);*/		/*GPIO function*/
-
-	pDM_FatTable->bBecomeLinked  = FALSE;
-	pDM_SWAT_Table->try_flag = SWAW_STEP_INIT;	
-	pDM_SWAT_Table->Double_chk_flag = 0;
-}
-
-VOID
-phydm_update_rx_idle_antenna_8188F(
-	IN	PVOID	pDM_VOID,
-	IN	u4Byte	default_ant
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte		codeword;
-
-	if (default_ant == ANT1_2G)
-		codeword = 1; /*2'b01*/
-	else
-		codeword = 2;/*2'b10*/
-	
-	ODM_SetMACReg(pDM_Odm, 0x44 , (BIT12|BIT11), codeword); /*GPIO[4:3] output value*/
-}
-
-#endif
-
-
-
-#ifdef ODM_EVM_ENHANCE_ANTDIV
-
-VOID
-odm_EVM_FastAnt_Reset(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-		
-	pDM_FatTable->EVM_method_enable=0;
-	odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);
-	pDM_FatTable->FAT_State = NORMAL_STATE_MIAN;
-	pDM_Odm->antdiv_period=0;
-	ODM_SetMACReg(pDM_Odm, 0x608, BIT8, 0);
-}
-
-
-VOID
-odm_EVM_Enhance_AntDiv(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte	Main_RSSI, Aux_RSSI ;
-	u4Byte	Main_CRC_utility=0,Aux_CRC_utility=0,utility_ratio=1;
-	u4Byte	Main_EVM, Aux_EVM,Diff_RSSI=0,diff_EVM=0;	
-	u1Byte	score_EVM=0,score_CRC=0;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	u4Byte	value32, i;
-	BOOLEAN Main_above1=FALSE,Aux_above1=FALSE;
-	BOOLEAN Force_antenna=FALSE;
-	PSTA_INFO_T   	pEntry;
-	pDM_FatTable->TargetAnt_enhance=0xFF;
-	
-	
-	if((pDM_Odm->SupportICType & ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC))
-	{
-		if(pDM_Odm->bOneEntryOnly)
-		{
-			//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[One Client only] \n"));
-			i = pDM_Odm->OneEntry_MACID;
-
-			Main_RSSI = (pDM_FatTable->MainAnt_Cnt[i]!=0)?(pDM_FatTable->MainAnt_Sum[i]/pDM_FatTable->MainAnt_Cnt[i]):0;
-			Aux_RSSI = (pDM_FatTable->AuxAnt_Cnt[i]!=0)?(pDM_FatTable->AuxAnt_Sum[i]/pDM_FatTable->AuxAnt_Cnt[i]):0;
-
-			if((Main_RSSI==0 && Aux_RSSI !=0 && Aux_RSSI>=FORCE_RSSI_DIFF) || (Main_RSSI!=0 && Aux_RSSI==0 && Main_RSSI>=FORCE_RSSI_DIFF))
-			{
-				Diff_RSSI=FORCE_RSSI_DIFF;
-			}
-			else if(Main_RSSI!=0 && Aux_RSSI !=0)
-			{
-				Diff_RSSI = (Main_RSSI>=Aux_RSSI)?(Main_RSSI-Aux_RSSI):(Aux_RSSI-Main_RSSI); 
-			}
-			
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" Main_Cnt = (( %d ))  , Main_RSSI= ((  %d )) \n", pDM_FatTable->MainAnt_Cnt[i], Main_RSSI));
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" Aux_Cnt   = (( %d ))  , Aux_RSSI = ((  %d )) \n" , pDM_FatTable->AuxAnt_Cnt[i] , Aux_RSSI));
-						
-			if(  ((Main_RSSI>=Evm_RSSI_TH_High||Aux_RSSI>=Evm_RSSI_TH_High )|| (pDM_FatTable->EVM_method_enable==1)  )
-				//&& (Diff_RSSI <= FORCE_RSSI_DIFF + 1)
-                                    )
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[> TH_H || EVM_method_enable==1]  && "));
-				
-				if(((Main_RSSI>=Evm_RSSI_TH_Low)||(Aux_RSSI>=Evm_RSSI_TH_Low) ))
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[> TH_L ] \n"));
-
-					//2 [ Normal state Main]
-					if(pDM_FatTable->FAT_State == NORMAL_STATE_MIAN)
-					{
-
-						pDM_FatTable->EVM_method_enable=1;
-						odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-						pDM_Odm->antdiv_period=3;
-
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ start training: MIAN] \n"));
-						pDM_FatTable->MainAntEVM_Sum[i] = 0;
-						pDM_FatTable->AuxAntEVM_Sum[i] = 0;
-						pDM_FatTable->MainAntEVM_Cnt[i] = 0;
-						pDM_FatTable->AuxAntEVM_Cnt[i] = 0;
-
-						pDM_FatTable->FAT_State = NORMAL_STATE_AUX;
-						ODM_SetMACReg(pDM_Odm, 0x608, BIT8, 1); //Accept CRC32 Error packets.
-						ODM_UpdateRxIdleAnt(pDM_Odm, MAIN_ANT);
-						
-						pDM_FatTable->CRC32_Ok_Cnt=0;
-						pDM_FatTable->CRC32_Fail_Cnt=0;
-						ODM_SetTimer(pDM_Odm,&pDM_Odm->EVM_FastAntTrainingTimer, pDM_Odm->antdiv_intvl ); //m
-					}
-					//2 [ Normal state Aux ]
-					else if(pDM_FatTable->FAT_State == NORMAL_STATE_AUX)
-					{
-						pDM_FatTable->MainCRC32_Ok_Cnt=pDM_FatTable->CRC32_Ok_Cnt;
-						pDM_FatTable->MainCRC32_Fail_Cnt=pDM_FatTable->CRC32_Fail_Cnt;
-						
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ start training: AUX] \n"));
-						pDM_FatTable->FAT_State = TRAINING_STATE;
-						ODM_UpdateRxIdleAnt(pDM_Odm, AUX_ANT);
-
-						pDM_FatTable->CRC32_Ok_Cnt=0;
-						pDM_FatTable->CRC32_Fail_Cnt=0;
-						ODM_SetTimer(pDM_Odm,&pDM_Odm->EVM_FastAntTrainingTimer, pDM_Odm->antdiv_intvl ); //ms
-					}					
-					else if(pDM_FatTable->FAT_State == TRAINING_STATE)
-					{
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Training state ] \n"));
-						pDM_FatTable->FAT_State = NORMAL_STATE_MIAN;
-						
-						//3 [CRC32 statistic]
-						pDM_FatTable->AuxCRC32_Ok_Cnt=pDM_FatTable->CRC32_Ok_Cnt;
-						pDM_FatTable->AuxCRC32_Fail_Cnt=pDM_FatTable->CRC32_Fail_Cnt;
-
-						if( (pDM_FatTable->MainCRC32_Ok_Cnt  >= ((pDM_FatTable->AuxCRC32_Ok_Cnt)<<1)) || (Diff_RSSI>=18))
-						{
-							pDM_FatTable->TargetAnt_CRC32=MAIN_ANT;
-							Force_antenna=TRUE;
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("CRC32 Force Main \n"));
-						}
-						else if((pDM_FatTable->AuxCRC32_Ok_Cnt  >= ((pDM_FatTable->MainCRC32_Ok_Cnt)<<1)) || (Diff_RSSI>=18))
-						{
-							pDM_FatTable->TargetAnt_CRC32=AUX_ANT;
-							Force_antenna=TRUE;
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("CRC32 Force Aux \n"));
-						}
-						else
-						{
-							if(pDM_FatTable->MainCRC32_Fail_Cnt<=5)
-								pDM_FatTable->MainCRC32_Fail_Cnt=5;
-							
-							if(pDM_FatTable->AuxCRC32_Fail_Cnt<=5)
-								pDM_FatTable->AuxCRC32_Fail_Cnt=5;
-						
-							if(pDM_FatTable->MainCRC32_Ok_Cnt >pDM_FatTable->MainCRC32_Fail_Cnt )
-								Main_above1=TRUE;
-						
-							if(pDM_FatTable->AuxCRC32_Ok_Cnt >pDM_FatTable->AuxCRC32_Fail_Cnt )
-								Aux_above1=TRUE;
-
-							if(Main_above1==TRUE && Aux_above1==FALSE)
-							{
-								Force_antenna=TRUE;
-								pDM_FatTable->TargetAnt_CRC32=MAIN_ANT;
-							}
-							else if(Main_above1==FALSE && Aux_above1==TRUE)
-							{
-								Force_antenna=TRUE;
-								pDM_FatTable->TargetAnt_CRC32=AUX_ANT;
-							}
-							else if(Main_above1==TRUE && Aux_above1==TRUE)
-							{
-								Main_CRC_utility=((pDM_FatTable->MainCRC32_Ok_Cnt)<<7)/pDM_FatTable->MainCRC32_Fail_Cnt;
-								Aux_CRC_utility=((pDM_FatTable->AuxCRC32_Ok_Cnt)<<7)/pDM_FatTable->AuxCRC32_Fail_Cnt;
-								pDM_FatTable->TargetAnt_CRC32 = (Main_CRC_utility==Aux_CRC_utility)?(pDM_FatTable->pre_TargetAnt_enhance):((Main_CRC_utility>=Aux_CRC_utility)?MAIN_ANT:AUX_ANT);
-								
-								if(Main_CRC_utility!=0 && Aux_CRC_utility!=0)
-								{
-									if(Main_CRC_utility>=Aux_CRC_utility)
-										utility_ratio=(Main_CRC_utility<<1)/Aux_CRC_utility;
-									else
-										utility_ratio=(Aux_CRC_utility<<1)/Main_CRC_utility;
-								}
-							}
-							else if(Main_above1==FALSE && Aux_above1==FALSE)
-							{
-								if(pDM_FatTable->MainCRC32_Ok_Cnt==0)
-									pDM_FatTable->MainCRC32_Ok_Cnt=1;
-								if(pDM_FatTable->AuxCRC32_Ok_Cnt==0)
-									pDM_FatTable->AuxCRC32_Ok_Cnt=1;
-								
-								Main_CRC_utility=((pDM_FatTable->MainCRC32_Fail_Cnt)<<7)/pDM_FatTable->MainCRC32_Ok_Cnt;
-								Aux_CRC_utility=((pDM_FatTable->AuxCRC32_Fail_Cnt)<<7)/pDM_FatTable->AuxCRC32_Ok_Cnt;
-								pDM_FatTable->TargetAnt_CRC32 = (Main_CRC_utility==Aux_CRC_utility)?(pDM_FatTable->pre_TargetAnt_enhance):((Main_CRC_utility<=Aux_CRC_utility)?MAIN_ANT:AUX_ANT);	
-
-								if(Main_CRC_utility!=0 && Aux_CRC_utility!=0)
-								{
-									if(Main_CRC_utility>=Aux_CRC_utility)
-										utility_ratio=(Main_CRC_utility<<1)/(Aux_CRC_utility);
-									else
-										utility_ratio=(Aux_CRC_utility<<1)/(Main_CRC_utility);
-								}
-							}
-						}
-						ODM_SetMACReg(pDM_Odm, 0x608, BIT8, 0);//NOT Accept CRC32 Error packets.
-
-						//3 [EVM statistic]			
-						Main_EVM = (pDM_FatTable->MainAntEVM_Cnt[i]!=0)?(pDM_FatTable->MainAntEVM_Sum[i]/pDM_FatTable->MainAntEVM_Cnt[i]):0;
-						Aux_EVM = (pDM_FatTable->AuxAntEVM_Cnt[i]!=0)?(pDM_FatTable->AuxAntEVM_Sum[i]/pDM_FatTable->AuxAntEVM_Cnt[i]):0;
-						pDM_FatTable->TargetAnt_EVM = (Main_EVM==Aux_EVM)?(pDM_FatTable->pre_TargetAnt_enhance):((Main_EVM>=Aux_EVM)?MAIN_ANT:AUX_ANT);
-
-						if((Main_EVM==0 || Aux_EVM==0))
-							diff_EVM=0;
-						else if(Main_EVM>=Aux_EVM)
-							diff_EVM=Main_EVM-Aux_EVM;
-						else
-							diff_EVM=Aux_EVM-Main_EVM;
-
-						//2 [ Decision state ]					
-						if(pDM_FatTable->TargetAnt_EVM ==pDM_FatTable->TargetAnt_CRC32 )
-						{
-							if( (utility_ratio<2 && Force_antenna==FALSE)  && diff_EVM<=2)
-								pDM_FatTable->TargetAnt_enhance=pDM_FatTable->pre_TargetAnt_enhance;
-							else
-								pDM_FatTable->TargetAnt_enhance=pDM_FatTable->TargetAnt_EVM;
-						}
-						else if(diff_EVM<=2 && (utility_ratio > 4 && Force_antenna==FALSE)) 
-						{
-							pDM_FatTable->TargetAnt_enhance=pDM_FatTable->TargetAnt_CRC32;
-						}
-						else if(diff_EVM>=20) // 
-						{
-							pDM_FatTable->TargetAnt_enhance=pDM_FatTable->TargetAnt_EVM;
-						}
-						else if(utility_ratio>=6 && Force_antenna==FALSE) // utility_ratio>3
-						{
-							pDM_FatTable->TargetAnt_enhance=pDM_FatTable->TargetAnt_CRC32;
-						}
-						else
-						{
-							if(Force_antenna==TRUE)
-								score_CRC=3;
-							else if(utility_ratio>=4) //>2
-								score_CRC=2;
-					else if(utility_ratio>=3) //>1.5
-						score_CRC=1;
-					else
-						score_CRC=0;
-					
-					if(diff_EVM>=10)
-						score_EVM=2;
-					else if(diff_EVM>=5)
-						score_EVM=1;
-					else
-						score_EVM=0;
-
-					if(score_CRC>score_EVM)
-						pDM_FatTable->TargetAnt_enhance=pDM_FatTable->TargetAnt_CRC32;
-					else if(score_CRC<score_EVM)
-						pDM_FatTable->TargetAnt_enhance=pDM_FatTable->TargetAnt_EVM;
-					else
-						pDM_FatTable->TargetAnt_enhance=pDM_FatTable->pre_TargetAnt_enhance;
-				}
-				pDM_FatTable->pre_TargetAnt_enhance=pDM_FatTable->TargetAnt_enhance;
-
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] : MainEVM_Cnt = (( %d ))  , Main_EVM= ((  %d )) \n",i, pDM_FatTable->MainAntEVM_Cnt[i], Main_EVM));
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] : AuxEVM_Cnt   = (( %d ))  , Aux_EVM = ((  %d )) \n" ,i, pDM_FatTable->AuxAntEVM_Cnt[i] , Aux_EVM));
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** TargetAnt_EVM = (( %s ))\n", ( pDM_FatTable->TargetAnt_EVM  ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("M_CRC_Ok = (( %d ))  , M_CRC_Fail = ((  %d )), Main_CRC_utility = (( %d )) \n" , pDM_FatTable->MainCRC32_Ok_Cnt, pDM_FatTable->MainCRC32_Fail_Cnt,Main_CRC_utility));
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("A_CRC_Ok  = (( %d ))  , A_CRC_Fail = ((  %d )), Aux_CRC_utility   = ((  %d )) \n" , pDM_FatTable->AuxCRC32_Ok_Cnt, pDM_FatTable->AuxCRC32_Fail_Cnt,Aux_CRC_utility));
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** TargetAnt_CRC32 = (( %s ))\n", ( pDM_FatTable->TargetAnt_CRC32 ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("****** TargetAnt_enhance = (( %s ))******\n", ( pDM_FatTable->TargetAnt_enhance ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-				
-					
-					}
-				}
-				else // RSSI< = Evm_RSSI_TH_Low
-				{ 
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ <TH_L: escape from > TH_L ] \n"));
-					odm_EVM_FastAnt_Reset(pDM_Odm);
-				}
-			}
-			else 
-			{ 
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[escape from> TH_H || EVM_method_enable==1] \n"));
-				odm_EVM_FastAnt_Reset(pDM_Odm);
-			}
-		}
-		else
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[multi-Client] \n"));
-			odm_EVM_FastAnt_Reset(pDM_Odm);
-		}			
-	}
-}
-
-VOID
-odm_EVM_FastAntTrainingCallback(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("******odm_EVM_FastAntTrainingCallback****** \n"));
-	odm_HW_AntDiv(pDM_Odm);
-}
-#endif
-
-VOID
-odm_HW_AntDiv(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte	i,MinMaxRSSI=0xFF,  AntDivMaxRSSI=0, MaxRSSI=0, LocalMaxRSSI;
-	u4Byte	Main_RSSI, Aux_RSSI;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;	
-	u1Byte	RxIdleAnt = pDM_FatTable->RxIdleAnt, TargetAnt = 7;
-	pDIG_T	pDM_DigTable = &pDM_Odm->DM_DigTable;
-	PSTA_INFO_T   	pEntry;
-
-	#ifdef BEAMFORMING_SUPPORT
-	#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-	pBDC_T    pDM_BdcTable = &pDM_Odm->DM_BdcTable;
-	u4Byte	TH1=500000;
-	u4Byte	TH2=10000000; 
-	u4Byte	MA_rx_Temp, degrade_TP_temp, improve_TP_temp;
-	u1Byte	Monitor_RSSI_threshold=30;
-
-	pDM_BdcTable->BF_pass=TRUE;
-	pDM_BdcTable->DIV_pass=TRUE;
-	pDM_BdcTable->bAll_DivSta_Idle=TRUE;
-	pDM_BdcTable->bAll_BFSta_Idle=TRUE;
-	pDM_BdcTable->num_BfTar=0 ;
-	pDM_BdcTable->num_DivTar=0;
-	pDM_BdcTable->num_Client=0;
-	#endif
-	#endif
-
-	if(!pDM_Odm->bLinked) //bLinked==False
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[No Link!!!]\n"));
-		
-		if(pDM_FatTable->bBecomeLinked == TRUE)
-		{
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-			ODM_UpdateRxIdleAnt(pDM_Odm, MAIN_ANT);
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm, TX_BY_REG);
-			pDM_Odm->antdiv_period=0;
-
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-		}
-		return;
-	}	
-	else
-	{
-		if(pDM_FatTable->bBecomeLinked ==FALSE)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Linked !!!]\n"));
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm , TX_BY_DESC);
-			
-			//if(pDM_Odm->SupportICType == ODM_RTL8821 )
-				//ODM_SetBBReg(pDM_Odm, 0x800 , BIT25, 0); //CCK AntDiv function disable
-				
-			//#if(DM_ODM_SUPPORT_TYPE  == ODM_AP)
-			//else if(pDM_Odm->SupportICType == ODM_RTL8881A)
-			//	ODM_SetBBReg(pDM_Odm, 0x800 , BIT25, 0); //CCK AntDiv function disable
-			//#endif
-			
-			//else if(pDM_Odm->SupportICType == ODM_RTL8723B ||pDM_Odm->SupportICType == ODM_RTL8812)
-				//ODM_SetBBReg(pDM_Odm, 0xA00 , BIT15, 0); //CCK AntDiv function disable
-			
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-
-			if(pDM_Odm->SupportICType==ODM_RTL8723B && pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV)
-			{
-				ODM_SetBBReg(pDM_Odm, 0x930 , 0xF0, 8); // DPDT_P = ANTSEL[0]   // for 8723B AntDiv function patch.  BB  Dino  130412	
-				ODM_SetBBReg(pDM_Odm, 0x930 , 0xF, 8); // DPDT_N = ANTSEL[0]
-			}
-			
-			//2 BDC Init
-			#ifdef BEAMFORMING_SUPPORT
-			#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-				odm_BDC_Init(pDM_Odm);
-			#endif
-			#endif
-			
-			#ifdef ODM_EVM_ENHANCE_ANTDIV
-				odm_EVM_FastAnt_Reset(pDM_Odm);
-			#endif
-		}	
-	}	
-
-	//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\n AntDiv Start =>\n"));
-
-	#ifdef ODM_EVM_ENHANCE_ANTDIV
-	if(pDM_Odm->antdiv_evm_en==1)
-	{
-		odm_EVM_Enhance_AntDiv(pDM_Odm);
-		if(pDM_FatTable->FAT_State !=NORMAL_STATE_MIAN)
-			return;
-	}
-	else
-	{
-		odm_EVM_FastAnt_Reset(pDM_Odm);
-	}
-	#endif
-	
-	//2 BDC Mode Arbitration
-	#ifdef BEAMFORMING_SUPPORT
-	#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if(pDM_Odm->antdiv_evm_en == 0 ||pDM_FatTable->EVM_method_enable==0)
-	{
-		odm_BF_AntDiv_ModeArbitration(pDM_Odm);
-	}
-	#endif
-	#endif
-
-	for (i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-	{
-		pEntry = pDM_Odm->pODM_StaInfo[i];
-		if(IS_STA_VALID(pEntry))
-		{
-			//2 Caculate RSSI per Antenna
-			Main_RSSI = (pDM_FatTable->MainAnt_Cnt[i]!=0)?(pDM_FatTable->MainAnt_Sum[i]/pDM_FatTable->MainAnt_Cnt[i]):0;
-			Aux_RSSI = (pDM_FatTable->AuxAnt_Cnt[i]!=0)?(pDM_FatTable->AuxAnt_Sum[i]/pDM_FatTable->AuxAnt_Cnt[i]):0;
-			TargetAnt = (Main_RSSI==Aux_RSSI)?pDM_FatTable->RxIdleAnt:((Main_RSSI>=Aux_RSSI)?MAIN_ANT:AUX_ANT);
-		
-			//ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("*** SupportICType=[%d] \n",pDM_Odm->SupportICType));
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] : Main_Cnt = (( %d ))  , Main_RSSI= ((  %d )) \n",i, pDM_FatTable->MainAnt_Cnt[i], Main_RSSI));
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] : Aux_Cnt   = (( %d ))  , Aux_RSSI = ((  %d )) \n" ,i, pDM_FatTable->AuxAnt_Cnt[i] , Aux_RSSI));
-			//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** MAC ID:[ %d ] , TargetAnt = (( %s )) \n", i ,( TargetAnt ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-			//ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("*** Phy_AntSel_A=[ %d, %d, %d] \n",((pDM_Odm->DM_FatTable.antsel_rx_keep_0)&BIT2)>>2,
-			//	                                                                              ((pDM_Odm->DM_FatTable.antsel_rx_keep_0)&BIT1) >>1, ((pDM_Odm->DM_FatTable.antsel_rx_keep_0)&BIT0)));
-
-			LocalMaxRSSI = (Main_RSSI>Aux_RSSI)?Main_RSSI:Aux_RSSI;
-			//2 Select MaxRSSI for DIG
-			if((LocalMaxRSSI > AntDivMaxRSSI) && (LocalMaxRSSI < 40))
-				AntDivMaxRSSI = LocalMaxRSSI;
-			if(LocalMaxRSSI > MaxRSSI)
-				MaxRSSI = LocalMaxRSSI;
-
-			//2 Select RX Idle Antenna
-			if ( (LocalMaxRSSI != 0) &&  (LocalMaxRSSI < MinMaxRSSI) )
-			{
-				RxIdleAnt = TargetAnt;
-				MinMaxRSSI = LocalMaxRSSI;
-			}
-
-			#ifdef ODM_EVM_ENHANCE_ANTDIV
-			if(pDM_Odm->antdiv_evm_en==1)
-			{
-				if(pDM_FatTable->TargetAnt_enhance!=0xFF)
-				{
-					TargetAnt=pDM_FatTable->TargetAnt_enhance;
-					RxIdleAnt = pDM_FatTable->TargetAnt_enhance;
-				}
-			}
-			#endif
-
-			//2 Select TX Antenna
-			if(pDM_Odm->AntDivType != CGCS_RX_HW_ANTDIV)
-			{
-				#ifdef BEAMFORMING_SUPPORT
-				#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-					if(pDM_BdcTable->w_BFee_Client[i]==0)
-				#endif	
-				#endif
-					{
-						odm_UpdateTxAnt(pDM_Odm, TargetAnt, i);
-					}
-			}
-
-			//------------------------------------------------------------
-
-			#ifdef BEAMFORMING_SUPPORT
-			#if(DM_ODM_SUPPORT_TYPE  == ODM_AP) 
-
-			pDM_BdcTable->num_Client++;
-
-			if(pDM_BdcTable->BDC_Mode==BDC_MODE_2 ||pDM_BdcTable->BDC_Mode==BDC_MODE_3)
-			{
-				//2 Byte Counter
-
-				MA_rx_Temp=  (pEntry->rx_byte_cnt_LowMAW)<<3 ; //  RX  TP   ( bit /sec)
-				
-				if(pDM_BdcTable->BDC_state==BDC_BFer_TRAIN_STATE)
-				{
-					pDM_BdcTable->MA_rx_TP_DIV[i]=  MA_rx_Temp ;
-				}
-				else
-				{
-					pDM_BdcTable->MA_rx_TP[i] =MA_rx_Temp ;
-				}
-
-				if( (MA_rx_Temp < TH2)   &&  (MA_rx_Temp > TH1) && (LocalMaxRSSI<=Monitor_RSSI_threshold))
-				{
-					if(pDM_BdcTable->w_BFer_Client[i]==1) // Bfer_Target
-					{
-						pDM_BdcTable->num_BfTar++;
-						
-						if(pDM_BdcTable->BDC_state==BDC_DECISION_STATE && pDM_BdcTable->BDC_Try_flag==0)
-						{
-						        improve_TP_temp = (pDM_BdcTable->MA_rx_TP_DIV[i] * 9)>>3 ; //* 1.125
-					        	pDM_BdcTable->BF_pass = (pDM_BdcTable->MA_rx_TP[i] > improve_TP_temp)?TRUE:FALSE;
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] :  { MA_rx_TP,improve_TP_temp , MA_rx_TP_DIV,  BF_pass}={ %d,  %d, %d , %d }  \n" ,i,pDM_BdcTable->MA_rx_TP[i],improve_TP_temp,pDM_BdcTable->MA_rx_TP_DIV[i], pDM_BdcTable->BF_pass ));
-						}		
-					}		
-					else// DIV_Target
-					{
-						pDM_BdcTable->num_DivTar++;
-						
-						if(pDM_BdcTable->BDC_state==BDC_DECISION_STATE && pDM_BdcTable->BDC_Try_flag==0)
-						{
-					        	degrade_TP_temp=(pDM_BdcTable->MA_rx_TP_DIV[i]*5)>>3;//* 0.625
-					        	pDM_BdcTable->DIV_pass = (pDM_BdcTable->MA_rx_TP[i] >degrade_TP_temp)?TRUE:FALSE;
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] :  { MA_rx_TP, degrade_TP_temp , MA_rx_TP_DIV,  DIV_pass}=\n{ %d,  %d, %d , %d }  \n" ,i,pDM_BdcTable->MA_rx_TP[i],degrade_TP_temp,pDM_BdcTable->MA_rx_TP_DIV[i], pDM_BdcTable->DIV_pass ));
-						}							
-					}
-				}
-
-				if(MA_rx_Temp > TH1)
-				{
-					if(pDM_BdcTable->w_BFer_Client[i]==1) // Bfer_Target
-					{
-						pDM_BdcTable->bAll_BFSta_Idle=FALSE;
-					}		
-					else// DIV_Target
-					{
-						pDM_BdcTable->bAll_DivSta_Idle=FALSE;
-					}
-				}
-		
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] :  { BFmeeCap , BFmerCap}  = { %d , %d } \n" ,i, pDM_BdcTable->w_BFee_Client[i] , pDM_BdcTable->w_BFer_Client[i]));
-
-				if(pDM_BdcTable->BDC_state==BDC_BFer_TRAIN_STATE)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] :    MA_rx_TP_DIV = (( %d ))  \n",i,pDM_BdcTable->MA_rx_TP_DIV[i]  ));
-					
-				}
-				else
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Client[ %d ] :    MA_rx_TP = (( %d ))  \n",i,pDM_BdcTable->MA_rx_TP[i]  ));
-				}
-			
-			}
-			#endif
-			#endif
-
-		}
-
-		#ifdef BEAMFORMING_SUPPORT
-		#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-		if(pDM_BdcTable->BDC_Try_flag==0)
-		#endif
-		#endif	
-		{
-        		pDM_FatTable->MainAnt_Sum[i] = 0;
-        		pDM_FatTable->AuxAnt_Sum[i] = 0;
-        		pDM_FatTable->MainAnt_Cnt[i] = 0;
-         		pDM_FatTable->AuxAnt_Cnt[i] = 0;
-                }
-	}
-       
-
-	
-	//2 Set RX Idle Antenna & TX Antenna(Because of HW Bug )	
-	#if(DM_ODM_SUPPORT_TYPE  == ODM_AP ) 
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** RxIdleAnt = (( %s ))\n\n", ( RxIdleAnt ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-		
-		#ifdef BEAMFORMING_SUPPORT
-		#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-			if(pDM_BdcTable->BDC_Mode==BDC_MODE_1 ||pDM_BdcTable->BDC_Mode==BDC_MODE_3)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** BDC_RxIdleUpdate_counter = (( %d ))\n", pDM_BdcTable->BDC_RxIdleUpdate_counter));
-			
-				if(pDM_BdcTable->BDC_RxIdleUpdate_counter==1)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***Update RxIdle Antenna!!! \n"));
-					pDM_BdcTable->BDC_RxIdleUpdate_counter=30;
-					ODM_UpdateRxIdleAnt(pDM_Odm, RxIdleAnt);
-				}
-				else
-				{
-					pDM_BdcTable->BDC_RxIdleUpdate_counter--;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***NOT update RxIdle Antenna because of BF  ( need to fix TX-ant)\n"));
-				}
-			}
-			else
-		#endif
-		#endif	
-				ODM_UpdateRxIdleAnt(pDM_Odm, RxIdleAnt);
-	#else
-	
-		ODM_UpdateRxIdleAnt(pDM_Odm, RxIdleAnt);
-	
-	#endif//#if(DM_ODM_SUPPORT_TYPE  == ODM_AP)
-
-
-
-	//2 BDC Main Algorithm
-	#ifdef BEAMFORMING_SUPPORT
-	#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if(pDM_Odm->antdiv_evm_en ==0 ||pDM_FatTable->EVM_method_enable==0)
-	{
-		odm_BDCcoex_BFeeRxDiv_Arbitration(pDM_Odm);
-	}
-	#endif
-	#endif
-
-	if(AntDivMaxRSSI == 0)
-		pDM_DigTable->AntDiv_RSSI_max = pDM_Odm->RSSI_Min;
-	else
-		pDM_DigTable->AntDiv_RSSI_max = AntDivMaxRSSI;
-	
-	pDM_DigTable->RSSI_max = MaxRSSI;
-}
-
-
-
-#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-
-VOID
-odm_S0S1_SWAntDiv_Reset(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T		pDM_SWAT_Table	= &pDM_Odm->DM_SWAT_Table;
-	pFAT_T		pDM_FatTable		= &pDM_Odm->DM_FatTable;
-
-	pDM_FatTable->bBecomeLinked  = FALSE;
-	pDM_SWAT_Table->try_flag = SWAW_STEP_INIT;	
-	pDM_SWAT_Table->Double_chk_flag = 0;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("odm_S0S1_SWAntDiv_Reset(): pDM_FatTable->bBecomeLinked = %d\n", pDM_FatTable->bBecomeLinked));
-}
-
-VOID
-odm_S0S1_SwAntDiv(
-	IN		PVOID			pDM_VOID,	
-	IN		u1Byte			Step
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T			pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;	
-	u4Byte			i, MinMaxRSSI = 0xFF, LocalMaxRSSI, LocalMinRSSI;
-	u4Byte			Main_RSSI, Aux_RSSI;
-	u1Byte			HighTraffic_TrainTime_U = 0x32, HighTraffic_TrainTime_L = 0, Train_time_temp;
-	u1Byte			LowTraffic_TrainTime_U = 200, LowTraffic_TrainTime_L = 0;
-	u1Byte			RxIdleAnt = pDM_SWAT_Table->PreAntenna, TargetAnt, nextAnt = 0;
-	PSTA_INFO_T		pEntry = NULL;
-	u4Byte			value32;
-
-	
-	if(!pDM_Odm->bLinked) //bLinked==False
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[No Link!!!]\n"));
-		if(pDM_FatTable->bBecomeLinked == TRUE)
-		{
-			if (pDM_Odm->SupportICType == ODM_RTL8723B) {
-				
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Set REG 948[9:6]=0x0\n"));
-				ODM_SetBBReg(pDM_Odm, 0x948 , (BIT9|BIT8|BIT7|BIT6), 0x0); 
-			}
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-		}
-		return;
-	}
-	else
-	{
-		if(pDM_FatTable->bBecomeLinked ==FALSE)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Linked !!!]\n"));
-			
-			if(pDM_Odm->SupportICType == ODM_RTL8723B)
-			{
-				value32 = ODM_GetBBReg(pDM_Odm, 0x864, BIT5|BIT4|BIT3);
-
-				#if (RTL8723B_SUPPORT == 1)
-					if (value32 == 0x0)
-						ODM_UpdateRxIdleAnt_8723B(pDM_Odm, MAIN_ANT, ANT1_2G, ANT2_2G);
-					else if (value32 == 0x1)
-						ODM_UpdateRxIdleAnt_8723B(pDM_Odm, AUX_ANT, ANT2_2G, ANT1_2G);
-				#endif
-				
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("8723B: First link! Force antenna to  %s\n",(value32 == 0x0?"MAIN":"AUX") ));
-			}			
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-		}
-	}
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[%d] { try_flag=(( %d )), Step=(( %d )), Double_chk_flag = (( %d )) }\n",
-		__LINE__,pDM_SWAT_Table->try_flag,Step,pDM_SWAT_Table->Double_chk_flag));
-
-	// Handling step mismatch condition.
-	// Peak step is not finished at last time. Recover the variable and check again.
-	if(	Step != pDM_SWAT_Table->try_flag	)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Step != try_flag]    Need to Reset After Link\n"));
-		ODM_SwAntDivRestAfterLink(pDM_Odm);
-	}
-
-	if (pDM_SWAT_Table->try_flag == SWAW_STEP_INIT) {
-		
-		pDM_SWAT_Table->try_flag = SWAW_STEP_PEEK;
-		pDM_SWAT_Table->Train_time_flag=0;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[set try_flag = 0]  Prepare for peek!\n\n"));
-		return;
-		
-	} else {
-	
-		//1 Normal State (Begin Trying)
-		if (pDM_SWAT_Table->try_flag == SWAW_STEP_PEEK) {
-		
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("TxOkCnt=(( %llu )), RxOkCnt=(( %llu )), TrafficLoad = (%d))\n", pDM_Odm->curTxOkCnt, pDM_Odm->curRxOkCnt, pDM_Odm->TrafficLoad));
-			
-			if (pDM_Odm->TrafficLoad == TRAFFIC_HIGH)
-			{
-				Train_time_temp = pDM_SWAT_Table->Train_time ;
-				
-				if(pDM_SWAT_Table->Train_time_flag==3)
-				{
-					HighTraffic_TrainTime_L=0xa;
-					
-					if(Train_time_temp<=16)
-						Train_time_temp=HighTraffic_TrainTime_L;
-					else
-						Train_time_temp-=16;
-					
-				}				
-				else if(pDM_SWAT_Table->Train_time_flag==2)
-				{
-					Train_time_temp-=8;
-					HighTraffic_TrainTime_L=0xf;
-				}	
-				else if(pDM_SWAT_Table->Train_time_flag==1)
-				{
-					Train_time_temp-=4;
-					HighTraffic_TrainTime_L=0x1e;
-				}
-				else if(pDM_SWAT_Table->Train_time_flag==0)
-				{
-					Train_time_temp+=8;
-					HighTraffic_TrainTime_L=0x28;
-				}
-
-				
-				//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** Train_time_temp = ((%d))\n",Train_time_temp));
-
-				//--
-				if(Train_time_temp > HighTraffic_TrainTime_U)
-					Train_time_temp=HighTraffic_TrainTime_U;
-				
-				else if(Train_time_temp < HighTraffic_TrainTime_L)
-					Train_time_temp=HighTraffic_TrainTime_L;
-
-				pDM_SWAT_Table->Train_time = Train_time_temp; /*10ms~200ms*/
-				
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Train_time_flag=((%d)), Train_time=((%d))\n", pDM_SWAT_Table->Train_time_flag, pDM_SWAT_Table->Train_time));
-
-			} else if ((pDM_Odm->TrafficLoad == TRAFFIC_MID) || (pDM_Odm->TrafficLoad == TRAFFIC_LOW)) { 
-			
-				Train_time_temp=pDM_SWAT_Table->Train_time ;
-				
-				if(pDM_SWAT_Table->Train_time_flag==3)
-				{
-					LowTraffic_TrainTime_L=10;
-					if(Train_time_temp<50)
-						Train_time_temp=LowTraffic_TrainTime_L;
-					else
-						Train_time_temp-=50;
-				}				
-				else if(pDM_SWAT_Table->Train_time_flag==2)
-				{
-					Train_time_temp-=30;
-					LowTraffic_TrainTime_L=36;
-				}	
-				else if(pDM_SWAT_Table->Train_time_flag==1)
-				{
-					Train_time_temp-=10;
-					LowTraffic_TrainTime_L=40;
-				}
-				else
-					Train_time_temp+=10;	
-				
-				//--
-				if(Train_time_temp >= LowTraffic_TrainTime_U)
-					Train_time_temp=LowTraffic_TrainTime_U;
-				
-				else if(Train_time_temp <= LowTraffic_TrainTime_L)
-					Train_time_temp=LowTraffic_TrainTime_L;
-
-				pDM_SWAT_Table->Train_time = Train_time_temp; /*10ms~200ms*/
-				
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Train_time_flag=((%d)) , Train_time=((%d))\n", pDM_SWAT_Table->Train_time_flag, pDM_SWAT_Table->Train_time));
-
-			} else {
-				pDM_SWAT_Table->Train_time = 0xc8; /*200ms*/
-
-			}
-				
-			//-----------------
-		
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Current MinMaxRSSI is ((%d))\n", pDM_FatTable->MinMaxRSSI));
-
-                        //---reset index---
-			if (pDM_SWAT_Table->reset_idx >= RSSI_CHECK_RESET_PERIOD) {
-				
-				pDM_FatTable->MinMaxRSSI = 0;
-				pDM_SWAT_Table->reset_idx = 0;
-			}
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("reset_idx = (( %d ))\n", pDM_SWAT_Table->reset_idx));
-
-			pDM_SWAT_Table->reset_idx++;
-
-			//---double check flag---
-			if ((pDM_FatTable->MinMaxRSSI > RSSI_CHECK_THRESHOLD) && (pDM_SWAT_Table->Double_chk_flag == 0))
-			{			
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" MinMaxRSSI is ((%d)), and > %d\n",
-					pDM_FatTable->MinMaxRSSI, RSSI_CHECK_THRESHOLD));
-
-				pDM_SWAT_Table->Double_chk_flag =1;
-				pDM_SWAT_Table->try_flag = SWAW_STEP_DETERMINE; 
-				pDM_SWAT_Table->RSSI_Trying = 0;
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Test the current Ant for (( %d )) ms again\n", pDM_SWAT_Table->Train_time));
-				ODM_UpdateRxIdleAnt(pDM_Odm, pDM_FatTable->RxIdleAnt);
-				ODM_SetTimer(pDM_Odm, &(pDM_SWAT_Table->phydm_SwAntennaSwitchTimer), pDM_SWAT_Table->Train_time); /*ms*/	
-				return;
-			}
-			
-			nextAnt = (pDM_FatTable->RxIdleAnt == MAIN_ANT)? AUX_ANT : MAIN_ANT;
-
-			pDM_SWAT_Table->try_flag = SWAW_STEP_DETERMINE;
-			
-			if(pDM_SWAT_Table->reset_idx<=1)
-				pDM_SWAT_Table->RSSI_Trying = 2;
-			else
-				pDM_SWAT_Table->RSSI_Trying = 1;
-
-			odm_S0S1_SwAntDivByCtrlFrame(pDM_Odm, SWAW_STEP_PEEK);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[set try_flag=1]  Normal State:  Begin Trying!!\n"));	
-			
-		} else if ((pDM_SWAT_Table->try_flag == SWAW_STEP_DETERMINE) && (pDM_SWAT_Table->Double_chk_flag == 0)) {
-			
-			nextAnt = (pDM_FatTable->RxIdleAnt  == MAIN_ANT)? AUX_ANT : MAIN_ANT;		
-			pDM_SWAT_Table->RSSI_Trying--;
-		}
-		
-		//1 Decision State
-		if ((pDM_SWAT_Table->try_flag == SWAW_STEP_DETERMINE) && (pDM_SWAT_Table->RSSI_Trying == 0)) {
-			
-			BOOLEAN bByCtrlFrame = FALSE;
-			u8Byte	pkt_cnt_total = 0;
-		
-			for (i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-			{
-				pEntry = pDM_Odm->pODM_StaInfo[i];
-				if(IS_STA_VALID(pEntry))
-				{
-					//2 Caculate RSSI per Antenna
-					Main_RSSI = (pDM_FatTable->MainAnt_Cnt[i]!=0)?(pDM_FatTable->MainAnt_Sum[i]/pDM_FatTable->MainAnt_Cnt[i]):0;
-					Aux_RSSI = (pDM_FatTable->AuxAnt_Cnt[i]!=0)?(pDM_FatTable->AuxAnt_Sum[i]/pDM_FatTable->AuxAnt_Cnt[i]):0;
-					
-					if(pDM_FatTable->MainAnt_Cnt[i]<=1 && pDM_FatTable->CCK_counter_main>=1)
-						Main_RSSI=0;	
-					
-					if(pDM_FatTable->AuxAnt_Cnt[i]<=1 && pDM_FatTable->CCK_counter_aux>=1)
-						Aux_RSSI=0;
-					
-					TargetAnt = (Main_RSSI==Aux_RSSI)?pDM_SWAT_Table->PreAntenna:((Main_RSSI>=Aux_RSSI)?MAIN_ANT:AUX_ANT);
-					LocalMaxRSSI = (Main_RSSI>=Aux_RSSI) ? Main_RSSI : Aux_RSSI;
-					LocalMinRSSI = (Main_RSSI>=Aux_RSSI) ? Aux_RSSI : Main_RSSI;
-					
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***  CCK_counter_main = (( %d ))  , CCK_counter_aux= ((  %d )) \n", pDM_FatTable->CCK_counter_main, pDM_FatTable->CCK_counter_aux));
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***  OFDM_counter_main = (( %d ))  , OFDM_counter_aux= ((  %d )) \n", pDM_FatTable->OFDM_counter_main, pDM_FatTable->OFDM_counter_aux));
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***  Main_Cnt = (( %d ))  , Main_RSSI= ((  %d )) \n", pDM_FatTable->MainAnt_Cnt[i], Main_RSSI));
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***  Aux_Cnt   = (( %d ))  , Aux_RSSI = ((  %d )) \n", pDM_FatTable->AuxAnt_Cnt[i]  , Aux_RSSI ));
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** MAC ID:[ %d ] , TargetAnt = (( %s )) \n", i ,( TargetAnt ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-					
-					//2 Select RX Idle Antenna
-					
-					if (LocalMaxRSSI != 0 && LocalMaxRSSI < MinMaxRSSI)
-					{
-						RxIdleAnt = TargetAnt;
-						MinMaxRSSI = LocalMaxRSSI;
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** LocalMaxRSSI-LocalMinRSSI = ((%d))\n",(LocalMaxRSSI-LocalMinRSSI)));
-				
-						if((LocalMaxRSSI-LocalMinRSSI)>8)
-						{
-							if(LocalMinRSSI != 0)
-								pDM_SWAT_Table->Train_time_flag=3;
-							else
-							{
-								if (MinMaxRSSI > RSSI_CHECK_THRESHOLD)
-									pDM_SWAT_Table->Train_time_flag=0;
-								else
-									pDM_SWAT_Table->Train_time_flag=3;
-							}
-						}
-						else if((LocalMaxRSSI-LocalMinRSSI)>5)
-							pDM_SWAT_Table->Train_time_flag=2;
-						else if((LocalMaxRSSI-LocalMinRSSI)>2)
-							pDM_SWAT_Table->Train_time_flag=1;
-						else
-							pDM_SWAT_Table->Train_time_flag=0;
-							
-					}
-					
-					//2 Select TX Antenna
-					if(TargetAnt == MAIN_ANT)
-						pDM_FatTable->antsel_a[i] = ANT1_2G;
-					else
-						pDM_FatTable->antsel_a[i] = ANT2_2G;
-			
-				}
-				pDM_FatTable->MainAnt_Sum[i] = 0;
-				pDM_FatTable->AuxAnt_Sum[i] = 0;
-				pDM_FatTable->MainAnt_Cnt[i] = 0;
-				pDM_FatTable->AuxAnt_Cnt[i] = 0;
-			}
-
-			if(pDM_SWAT_Table->bSWAntDivByCtrlFrame)
-			{
-				odm_S0S1_SwAntDivByCtrlFrame(pDM_Odm, SWAW_STEP_DETERMINE);
-				bByCtrlFrame = TRUE;
-			}
-
-			pkt_cnt_total = pDM_FatTable->CCK_counter_main + pDM_FatTable->CCK_counter_aux + 
-							pDM_FatTable->OFDM_counter_main + pDM_FatTable->OFDM_counter_aux;
-			pDM_FatTable->CCK_counter_main=0;
-			pDM_FatTable->CCK_counter_aux=0;
-			pDM_FatTable->OFDM_counter_main=0;
-			pDM_FatTable->OFDM_counter_aux=0;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("Control frame packet counter = %d, Data frame packet counter = %llu\n", 
-				pDM_SWAT_Table->PktCnt_SWAntDivByCtrlFrame, pkt_cnt_total));
-			
-			if(MinMaxRSSI == 0xff || ((pkt_cnt_total < (pDM_SWAT_Table->PktCnt_SWAntDivByCtrlFrame >> 1)) && pDM_Odm->PhyDbgInfo.NumQryBeaconPkt < 2))
-			{	
-				MinMaxRSSI = 0;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("Check RSSI of control frame because MinMaxRSSI == 0xff\n"));
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("bByCtrlFrame = %d\n", bByCtrlFrame));
-				
-				if(bByCtrlFrame)
-				{
-					Main_RSSI = (pDM_FatTable->MainAnt_CtrlFrame_Cnt!=0)?(pDM_FatTable->MainAnt_CtrlFrame_Sum/pDM_FatTable->MainAnt_CtrlFrame_Cnt):0;
-					Aux_RSSI = (pDM_FatTable->AuxAnt_CtrlFrame_Cnt!=0)?(pDM_FatTable->AuxAnt_CtrlFrame_Sum/pDM_FatTable->AuxAnt_CtrlFrame_Cnt):0;
-					
-					if(pDM_FatTable->MainAnt_CtrlFrame_Cnt<=1 && pDM_FatTable->CCK_CtrlFrame_Cnt_main>=1)
-						Main_RSSI=0;	
-					
-					if(pDM_FatTable->AuxAnt_CtrlFrame_Cnt<=1 && pDM_FatTable->CCK_CtrlFrame_Cnt_aux>=1)
-						Aux_RSSI=0;
-
-					if (Main_RSSI != 0 || Aux_RSSI != 0)
-					{
-						RxIdleAnt = (Main_RSSI==Aux_RSSI)?pDM_SWAT_Table->PreAntenna:((Main_RSSI>=Aux_RSSI)?MAIN_ANT:AUX_ANT);
-						LocalMaxRSSI = (Main_RSSI>=Aux_RSSI) ? Main_RSSI : Aux_RSSI;
-						LocalMinRSSI = (Main_RSSI>=Aux_RSSI) ? Aux_RSSI : Main_RSSI;
-
-						if((LocalMaxRSSI-LocalMinRSSI)>8)
-							pDM_SWAT_Table->Train_time_flag=3;
-						else if((LocalMaxRSSI-LocalMinRSSI)>5)
-							pDM_SWAT_Table->Train_time_flag=2;
-						else if((LocalMaxRSSI-LocalMinRSSI)>2)
-							pDM_SWAT_Table->Train_time_flag=1;
-						else
-							pDM_SWAT_Table->Train_time_flag=0;
-
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("Control frame: Main_RSSI = %d, Aux_RSSI = %d\n", Main_RSSI, Aux_RSSI));
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("RxIdleAnt decided by control frame = %s\n", (RxIdleAnt == MAIN_ANT?"MAIN":"AUX")));
-					}
-				}
-			}
-
-			pDM_FatTable->MinMaxRSSI = MinMaxRSSI;
-			pDM_SWAT_Table->try_flag = SWAW_STEP_PEEK;
-						
-			if( pDM_SWAT_Table->Double_chk_flag==1)
-			{
-				pDM_SWAT_Table->Double_chk_flag=0;
-				
-				if (pDM_FatTable->MinMaxRSSI > RSSI_CHECK_THRESHOLD) {
-					
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" [Double check] MinMaxRSSI ((%d)) > %d again!!\n",
-						pDM_FatTable->MinMaxRSSI, RSSI_CHECK_THRESHOLD));
-					
-					ODM_UpdateRxIdleAnt(pDM_Odm, RxIdleAnt);	
-					
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[reset try_flag = 0] Training accomplished !!!]\n\n\n"));
-					return;
-				}
-				else
-				{
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" [Double check] MinMaxRSSI ((%d)) <= %d !!\n",
-						pDM_FatTable->MinMaxRSSI, RSSI_CHECK_THRESHOLD));
-
-					nextAnt = (pDM_FatTable->RxIdleAnt  == MAIN_ANT)? AUX_ANT : MAIN_ANT;
-					pDM_SWAT_Table->try_flag = SWAW_STEP_PEEK; 
-					pDM_SWAT_Table->reset_idx = RSSI_CHECK_RESET_PERIOD;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[set try_flag=0]  Normal State:  Need to tryg again!!\n\n\n"));
-					return;
-				}
-			}
-			else
-			{
-				if (pDM_FatTable->MinMaxRSSI < RSSI_CHECK_THRESHOLD)
-					pDM_SWAT_Table->reset_idx = RSSI_CHECK_RESET_PERIOD;
-				
-				pDM_SWAT_Table->PreAntenna =RxIdleAnt;
-				ODM_UpdateRxIdleAnt(pDM_Odm, RxIdleAnt );
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("[reset try_flag = 0] Training accomplished !!!] \n\n\n"));
-				return;
-			}
-			
-		}
-
-	}
-
-	//1 4.Change TRX antenna
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("RSSI_Trying = (( %d )),    Ant: (( %s )) >>> (( %s )) \n",
-		pDM_SWAT_Table->RSSI_Trying, (pDM_FatTable->RxIdleAnt  == MAIN_ANT?"MAIN":"AUX"),(nextAnt == MAIN_ANT?"MAIN":"AUX")));
-		
-	ODM_UpdateRxIdleAnt(pDM_Odm, nextAnt);
-
-	//1 5.Reset Statistics
-
-	pDM_FatTable->RxIdleAnt  = nextAnt;
-
-	//1 6.Set next timer   (Trying State)
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" Test ((%s)) Ant for (( %d )) ms\n", (nextAnt == MAIN_ANT?"MAIN":"AUX"), pDM_SWAT_Table->Train_time));
-	ODM_SetTimer(pDM_Odm, &(pDM_SWAT_Table->phydm_SwAntennaSwitchTimer), pDM_SWAT_Table->Train_time); /*ms*/
-}
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-ODM_SW_AntDiv_Callback(
-	PRT_TIMER		pTimer
-)
-{
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	pSWAT_T			pDM_SWAT_Table = &pHalData->DM_OutSrc.DM_SWAT_Table;
-
-	#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-		#if USE_WORKITEM
-			ODM_ScheduleWorkItem(&pDM_SWAT_Table->phydm_SwAntennaSwitchWorkitem);
-		#else
-			{
-			//DbgPrint("SW_antdiv_Callback");
-			odm_S0S1_SwAntDiv(&pHalData->DM_OutSrc, SWAW_STEP_DETERMINE);
-			}
-		#endif
-	#else
-	ODM_ScheduleWorkItem(&pDM_SWAT_Table->phydm_SwAntennaSwitchWorkitem);
-	#endif
-}
-VOID
-ODM_SW_AntDiv_WorkitemCallback(
-    IN PVOID            pContext
-    )
-{
-	PADAPTER		pAdapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	
-	//DbgPrint("SW_antdiv_Workitem_Callback");
-	odm_S0S1_SwAntDiv(&pHalData->DM_OutSrc, SWAW_STEP_DETERMINE);
-}
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-VOID
-ODM_SW_AntDiv_WorkitemCallback(
-	IN PVOID	pContext
-)
-{
-	PADAPTER
-	pAdapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE
-	*pHalData = GET_HAL_DATA(pAdapter);
-
-	/*DbgPrint("SW_antdiv_Workitem_Callback");*/
-	odm_S0S1_SwAntDiv(&pHalData->odmpriv, SWAW_STEP_DETERMINE);
-}
-
-VOID
-ODM_SW_AntDiv_Callback(void *FunctionContext)
-{
-	PDM_ODM_T	pDM_Odm= (PDM_ODM_T)FunctionContext;
-	PADAPTER	padapter = pDM_Odm->Adapter;
-	if(padapter->net_closed == _TRUE)
-		return;
-	
-	#if 0 /* Can't do I/O in timer callback*/
-	odm_S0S1_SwAntDiv(pDM_Odm, SWAW_STEP_DETERMINE);
-	#else
-	rtw_run_in_thread_cmd(padapter, ODM_SW_AntDiv_WorkitemCallback, padapter);
-	#endif
-}
-
-
-#endif
-
-VOID
-odm_S0S1_SwAntDivByCtrlFrame(
-	IN		PVOID			pDM_VOID,	
-	IN		u1Byte			Step
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSWAT_T	pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	pFAT_T		pDM_FatTable = &pDM_Odm->DM_FatTable;
-	
-	switch(Step)
-	{
-		case SWAW_STEP_PEEK:
-			pDM_SWAT_Table->PktCnt_SWAntDivByCtrlFrame = 0;
-			pDM_SWAT_Table->bSWAntDivByCtrlFrame = TRUE;
-			pDM_FatTable->MainAnt_CtrlFrame_Cnt = 0;
-			pDM_FatTable->AuxAnt_CtrlFrame_Cnt = 0;
-			pDM_FatTable->MainAnt_CtrlFrame_Sum = 0;
-			pDM_FatTable->AuxAnt_CtrlFrame_Sum = 0;
-			pDM_FatTable->CCK_CtrlFrame_Cnt_main = 0;
-			pDM_FatTable->CCK_CtrlFrame_Cnt_aux = 0;
-			pDM_FatTable->OFDM_CtrlFrame_Cnt_main = 0;
-			pDM_FatTable->OFDM_CtrlFrame_Cnt_aux = 0;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("odm_S0S1_SwAntDivForAPMode(): Start peek and reset counter\n"));
-			break;
-		case SWAW_STEP_DETERMINE:
-			pDM_SWAT_Table->bSWAntDivByCtrlFrame = FALSE;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("odm_S0S1_SwAntDivForAPMode(): Stop peek\n"));
-			break;
-		default:
-			pDM_SWAT_Table->bSWAntDivByCtrlFrame = FALSE;
-			break;
-	}			
-}
-
-VOID
-odm_AntselStatisticsOfCtrlFrame(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			antsel_tr_mux,
-	IN		u4Byte			RxPWDBAll
-	
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-	if(antsel_tr_mux == ANT1_2G)
-	{
-		pDM_FatTable->MainAnt_CtrlFrame_Sum+=RxPWDBAll;
-		pDM_FatTable->MainAnt_CtrlFrame_Cnt++;
-	}
-	else
-	{
-		pDM_FatTable->AuxAnt_CtrlFrame_Sum+=RxPWDBAll;
-		pDM_FatTable->AuxAnt_CtrlFrame_Cnt++;
-	}
-}
-
-VOID
-odm_S0S1_SwAntDivByCtrlFrame_ProcessRSSI(
-	IN		PVOID			pDM_VOID,	
-	IN		PVOID			p_phy_info_void,
-	IN		PVOID			p_pkt_info_void
-	//IN		PODM_PHY_INFO_T		pPhyInfo,
-	//IN		PODM_PACKET_INFO_T		pPktinfo
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_PHY_INFO_T	 pPhyInfo=(PODM_PHY_INFO_T)p_phy_info_void;
-	PODM_PACKET_INFO_T 	pPktinfo=(PODM_PACKET_INFO_T)p_pkt_info_void;
-	pSWAT_T	pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	pFAT_T		pDM_FatTable = &pDM_Odm->DM_FatTable;
-	BOOLEAN		isCCKrate;
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_ANT_DIV))
-		return;
-
-	if(pDM_Odm->AntDivType != S0S1_SW_ANTDIV)
-		return;
-
-	// In try state
-	if(!pDM_SWAT_Table->bSWAntDivByCtrlFrame)
-		return;
-
-	// No HW error and match receiver address
-	if(!pPktinfo->bToSelf)
-		return;
-	
-	pDM_SWAT_Table->PktCnt_SWAntDivByCtrlFrame++;
-	isCCKrate = ((pPktinfo->DataRate >= DESC_RATE1M ) && (pPktinfo->DataRate <= DESC_RATE11M ))?TRUE :FALSE;
-
-	if(isCCKrate)
-	{
-	 	pDM_FatTable->antsel_rx_keep_0 = (pDM_FatTable->RxIdleAnt == MAIN_ANT) ? ANT1_2G : ANT2_2G;
-
-		if(pDM_FatTable->antsel_rx_keep_0==ANT1_2G)
-			pDM_FatTable->CCK_CtrlFrame_Cnt_main++;
-		else
-			pDM_FatTable->CCK_CtrlFrame_Cnt_aux++;
-
-		odm_AntselStatisticsOfCtrlFrame(pDM_Odm, pDM_FatTable->antsel_rx_keep_0, pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A]);
-	}
-	else
-	{
-		if(pDM_FatTable->antsel_rx_keep_0==ANT1_2G)
-			pDM_FatTable->OFDM_CtrlFrame_Cnt_main++;
-		else
-			pDM_FatTable->OFDM_CtrlFrame_Cnt_aux++;
-
-		odm_AntselStatisticsOfCtrlFrame(pDM_Odm, pDM_FatTable->antsel_rx_keep_0, pPhyInfo->RxPWDBAll);
-	}
-}
-
-#endif //#if (RTL8723B_SUPPORT == 1)||(RTL8821A_SUPPORT == 1)
-
-
-
-
-VOID
-odm_SetNextMACAddrTarget(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	PSTA_INFO_T   	pEntry;
-	u4Byte			value32, i;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("odm_SetNextMACAddrTarget() ==>\n"));
-	
-	if (pDM_Odm->bLinked)
-	{
-		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-			
-			if ((pDM_FatTable->TrainIdx+1) == ODM_ASSOCIATE_ENTRY_NUM)
-				pDM_FatTable->TrainIdx = 0;
-			else
-				pDM_FatTable->TrainIdx++;
-			
-			pEntry = pDM_Odm->pODM_StaInfo[pDM_FatTable->TrainIdx];
-			
-			if (IS_STA_VALID(pEntry)) {
-				
-				/*Match MAC ADDR*/
-				#if (DM_ODM_SUPPORT_TYPE & (ODM_AP | ODM_CE))
-				value32 = (pEntry->hwaddr[5]<<8)|pEntry->hwaddr[4];
-				#else
-				value32 = (pEntry->MacAddr[5]<<8)|pEntry->MacAddr[4];
-				#endif
-				
-				ODM_SetMACReg(pDM_Odm, 0x7b4, 0xFFFF, value32);/*0x7b4~0x7b5*/
-				
-				#if (DM_ODM_SUPPORT_TYPE & (ODM_AP | ODM_CE))
-				value32 = (pEntry->hwaddr[3]<<24)|(pEntry->hwaddr[2]<<16) |(pEntry->hwaddr[1]<<8) |pEntry->hwaddr[0];
-				#else
-				value32 = (pEntry->MacAddr[3]<<24)|(pEntry->MacAddr[2]<<16) |(pEntry->MacAddr[1]<<8) |pEntry->MacAddr[0];
-				#endif
-				ODM_SetMACReg(pDM_Odm, 0x7b0, bMaskDWord, value32);/*0x7b0~0x7b3*/
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("pDM_FatTable->TrainIdx=%d\n", pDM_FatTable->TrainIdx));
-				
-				#if (DM_ODM_SUPPORT_TYPE & (ODM_AP | ODM_CE))
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Training MAC Addr = %x:%x:%x:%x:%x:%x\n",
-					pEntry->hwaddr[5], pEntry->hwaddr[4], pEntry->hwaddr[3], pEntry->hwaddr[2], pEntry->hwaddr[1], pEntry->hwaddr[0]));
-				#else
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Training MAC Addr = %x:%x:%x:%x:%x:%x\n",
-					pEntry->MacAddr[5], pEntry->MacAddr[4], pEntry->MacAddr[3], pEntry->MacAddr[2], pEntry->MacAddr[1], pEntry->MacAddr[0]));
-				#endif
-
-				break;
-			}
-		}
-	}
-
-#if 0
-	//
-	//2012.03.26 LukeLee: This should be removed later, the MAC address is changed according to MACID in turn
-	//
-	#if( DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	{		
-		PADAPTER	Adapter =  pDM_Odm->Adapter;
-		PMGNT_INFO	pMgntInfo = &Adapter->MgntInfo;
-
-		for (i=0; i<6; i++)
-		{
-			Bssid[i] = pMgntInfo->Bssid[i];
-			//DbgPrint("Bssid[%d]=%x\n", i, Bssid[i]);
-		}
-	}
-	#endif
-
-	//odm_SetNextMACAddrTarget(pDM_Odm);
-	
-	//1 Select MAC Address Filter
-	for (i=0; i<6; i++)
-	{
-		if(Bssid[i] != pDM_FatTable->Bssid[i])
-		{
-			bMatchBSSID = FALSE;
-			break;
-		}
-	}
-	if(bMatchBSSID == FALSE)
-	{
-		//Match MAC ADDR
-		value32 = (Bssid[5]<<8)|Bssid[4];
-		ODM_SetMACReg(pDM_Odm, 0x7b4, 0xFFFF, value32);
-		value32 = (Bssid[3]<<24)|(Bssid[2]<<16) |(Bssid[1]<<8) |Bssid[0];
-		ODM_SetMACReg(pDM_Odm, 0x7b0, bMaskDWord, value32);
-	}
-
-	return bMatchBSSID;
-#endif
-				
-}
-
-#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-
-VOID
-odm_FastAntTraining(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-	u4Byte	MaxRSSI_pathA=0, Pckcnt_pathA=0;
-	u1Byte	i,TargetAnt_pathA=0;
-	BOOLEAN	bPktFilterMacth_pathA = FALSE;
-	#if(RTL8192E_SUPPORT == 1)
-	u4Byte	MaxRSSI_pathB=0, Pckcnt_pathB=0;
-	u1Byte	TargetAnt_pathB=0;
-	BOOLEAN	bPktFilterMacth_pathB = FALSE;
-	#endif
-
-
-	if(!pDM_Odm->bLinked) //bLinked==False
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[No Link!!!]\n"));
-		
-		if(pDM_FatTable->bBecomeLinked == TRUE)
-		{
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-			phydm_FastTraining_enable(pDM_Odm , FAT_OFF);
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm, TX_BY_REG);
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-		}
-		return;
-	}
-	else
-	{
-		if(pDM_FatTable->bBecomeLinked ==FALSE)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Linked!!!]\n"));
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm , TX_BY_DESC);
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-		}
-	}
-
-		
-        if(pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-           ODM_SetBBReg(pDM_Odm, 0x864 , BIT2|BIT1|BIT0, ((pDM_Odm->fat_comb_a)-1));
-        }
-	#if(RTL8192E_SUPPORT == 1)
-        else if(pDM_Odm->SupportICType == ODM_RTL8192E)
-        {
-           ODM_SetBBReg(pDM_Odm, 0xB38 , BIT2|BIT1|BIT0, ((pDM_Odm->fat_comb_a)-1) );	   //path-A  // ant combination=regB38[2:0]+1
-	   ODM_SetBBReg(pDM_Odm, 0xB38 , BIT18|BIT17|BIT16, ((pDM_Odm->fat_comb_b)-1) );  //path-B  // ant combination=regB38[18:16]+1
-        }
-	#endif
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("==>odm_FastAntTraining()\n"));
-
-	//1 TRAINING STATE
-	if(pDM_FatTable->FAT_State == FAT_TRAINING_STATE)
-	{
-		//2 Caculate RSSI per Antenna
-
-                //3 [path-A]---------------------------
-		for (i=0; i<(pDM_Odm->fat_comb_a); i++) // i : antenna index
-		{
-			if(pDM_FatTable->antRSSIcnt[i] == 0)
-				pDM_FatTable->antAveRSSI[i] = 0;
-			else
-			{
-			pDM_FatTable->antAveRSSI[i] = pDM_FatTable->antSumRSSI[i] /pDM_FatTable->antRSSIcnt[i];
-				bPktFilterMacth_pathA = TRUE;
-			}
-			
-			if(pDM_FatTable->antAveRSSI[i] > MaxRSSI_pathA)
-			{
-				MaxRSSI_pathA = pDM_FatTable->antAveRSSI[i];
-                                Pckcnt_pathA = pDM_FatTable ->antRSSIcnt[i];
-				TargetAnt_pathA =  i ; 
-			}
-                        else if(pDM_FatTable->antAveRSSI[i] == MaxRSSI_pathA)
-			{
-				if(  (pDM_FatTable->antRSSIcnt[i] )   >   Pckcnt_pathA)
-			{
-					MaxRSSI_pathA = pDM_FatTable->antAveRSSI[i];
-					Pckcnt_pathA = pDM_FatTable ->antRSSIcnt[i];
-				        TargetAnt_pathA = i ;
-			        }
-			}
-
-			ODM_RT_TRACE("*** Ant-Index : [ %d ],      Counter = (( %d )),     Avg RSSI = (( %d )) \n", i, pDM_FatTable->antRSSIcnt[i],  pDM_FatTable->antAveRSSI[i] );
-		}
-
-
-		/*
-		#if(RTL8192E_SUPPORT == 1)
-		//3 [path-B]---------------------------
-		for (i=0; i<(pDM_Odm->fat_comb_b); i++)
-		{
-			if(pDM_FatTable->antRSSIcnt_pathB[i] == 0)
-				pDM_FatTable->antAveRSSI_pathB[i] = 0;				
-			else // (antRSSIcnt[i] != 0)
-			{
-				pDM_FatTable->antAveRSSI_pathB[i] = pDM_FatTable->antSumRSSI_pathB[i] /pDM_FatTable->antRSSIcnt_pathB[i];
-				bPktFilterMacth_pathB = TRUE;
-			}
-			if(pDM_FatTable->antAveRSSI_pathB[i] > MaxRSSI_pathB)
-			{
-				MaxRSSI_pathB = pDM_FatTable->antAveRSSI_pathB[i];
-                                Pckcnt_pathB = pDM_FatTable ->antRSSIcnt_pathB[i];
-				TargetAnt_pathB = (u1Byte) i; 
-			}
-                        if(pDM_FatTable->antAveRSSI_pathB[i] == MaxRSSI_pathB)
-			{
-				if(pDM_FatTable ->antRSSIcnt_pathB > Pckcnt_pathB)
-		{
-					MaxRSSI_pathB = pDM_FatTable->antAveRSSI_pathB[i];
-					TargetAnt_pathB = (u1Byte) i;
-				} 
-		}
-			if (pDM_Odm->fat_print_rssi==1)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***{Path-B}: Sum RSSI[%d] = (( %d )),      cnt RSSI [%d] = (( %d )),     Avg RSSI[%d] = (( %d )) \n",
-				i, pDM_FatTable->antSumRSSI_pathB[i], i, pDM_FatTable->antRSSIcnt_pathB[i], i, pDM_FatTable->antAveRSSI_pathB[i]));
-			}
-		}
-		#endif
-		*/
-
-	//1 DECISION STATE
-
-		//2 Select TRX Antenna
-
-		phydm_FastTraining_enable(pDM_Odm, FAT_OFF);
-
-		//3 [path-A]---------------------------
-		if(bPktFilterMacth_pathA  == FALSE)
-		{
-			//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("{Path-A}: None Packet is matched\n"));
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("{Path-A}: None Packet is matched\n"));
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-		}
-		else
-		{
-			ODM_RT_TRACE("TargetAnt_pathA = (( %d )) , MaxRSSI_pathA = (( %d )) \n",TargetAnt_pathA,MaxRSSI_pathA);
-
-			//3 [ update RX-optional ant ]        Default RX is Omni, Optional RX is the best decision by FAT
-			if(pDM_Odm->SupportICType == ODM_RTL8188E)
-			{
-				ODM_SetBBReg(pDM_Odm, 0x864 , BIT8|BIT7|BIT6, TargetAnt_pathA);	
-			}
-			else if(pDM_Odm->SupportICType == ODM_RTL8192E)
-			{
-				ODM_SetBBReg(pDM_Odm, 0xB38 , BIT8|BIT7|BIT6, TargetAnt_pathA);//Optional RX [pth-A]
-			}
-			//3 [ update TX ant ]
-			odm_UpdateTxAnt(pDM_Odm, TargetAnt_pathA, (pDM_FatTable->TrainIdx)); 
-
-			if(TargetAnt_pathA == 0)
-				odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-		}
-		/*
-		#if(RTL8192E_SUPPORT == 1)
-		//3 [path-B]---------------------------
-		if(bPktFilterMacth_pathB == FALSE)
-		{
-			if (pDM_Odm->fat_print_rssi==1)
-			{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("***[%d]{Path-B}: None Packet is matched\n\n\n",__LINE__));
-			}
-		}
-		else
-		{
-			if (pDM_Odm->fat_print_rssi==1)
-			{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, 
-				(" ***TargetAnt_pathB = (( %d )) *** MaxRSSI = (( %d ))***\n\n\n",TargetAnt_pathB,MaxRSSI_pathB));
-			}
-			ODM_SetBBReg(pDM_Odm, 0xB38 , BIT21|BIT20|BIT19, TargetAnt_pathB);	//Default RX is Omni, Optional RX is the best decision by FAT		
-			ODM_SetBBReg(pDM_Odm, 0x80c , BIT21, 1); //Reg80c[21]=1'b1		//from TX Info
-
-			pDM_FatTable->antsel_pathB[pDM_FatTable->TrainIdx] = TargetAnt_pathB;
-		}
-		#endif
-		*/
-
-		//2 Reset Counter
-		for(i=0; i<(pDM_Odm->fat_comb_a); i++)
-		{
-			pDM_FatTable->antSumRSSI[i] = 0;
-			pDM_FatTable->antRSSIcnt[i] = 0;
-		}
-		/*
-		#if(RTL8192E_SUPPORT == 1)
-		for(i=0; i<=(pDM_Odm->fat_comb_b); i++)
-		{
-			pDM_FatTable->antSumRSSI_pathB[i] = 0;
-			pDM_FatTable->antRSSIcnt_pathB[i] = 0;
-		}
-		#endif
-		*/
-		
-		pDM_FatTable->FAT_State = FAT_PREPARE_STATE;
-		return;
-	}
-
-	//1 NORMAL STATE
-	if (pDM_FatTable->FAT_State == FAT_PREPARE_STATE)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Start Prepare State ]\n"));
-
-		odm_SetNextMACAddrTarget(pDM_Odm);
-
-		//2 Prepare Training
-		pDM_FatTable->FAT_State = FAT_TRAINING_STATE;
-		phydm_FastTraining_enable(pDM_Odm , FAT_ON);
-		odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);		//enable HW AntDiv
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Start Training State]\n"));
-
-		ODM_SetTimer(pDM_Odm,&pDM_Odm->FastAntTrainingTimer, pDM_Odm->antdiv_intvl ); //ms
-	}
-		
-}
-
-VOID
-odm_FastAntTrainingCallback(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PADAPTER	padapter = pDM_Odm->Adapter;
-	if(padapter->net_closed == _TRUE)
-	    return;
-	//if(*pDM_Odm->pbNet_closed == TRUE)
-	   // return;
-#endif
-
-#if USE_WORKITEM
-	ODM_ScheduleWorkItem(&pDM_Odm->FastAntTrainingWorkitem);
-#else
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("******odm_FastAntTrainingCallback****** \n"));
-	odm_FastAntTraining(pDM_Odm);
-#endif
-}
-
-VOID
-odm_FastAntTrainingWorkItemCallback(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("******odm_FastAntTrainingWorkItemCallback****** \n"));
-	odm_FastAntTraining(pDM_Odm);
-}
-
-#endif
-
-#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-
-u4Byte
-phydm_construct_hl_beam_codeword(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*beam_pattern_idx,
-	IN		u4Byte		ant_num
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte		codeword = 0;
-	u4Byte		data_tmp;
-	u1Byte		i;
-
-	if (ant_num < 8) {
-		for (i = 0; i < ant_num; i++) {
-			/*ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("beam_pattern_num[%x] = %x\n",i,beam_pattern_num[i] ));*/
-			if (beam_pattern_idx[i] == 0) {
-				data_tmp = 0x1;
-				/**/
-			} else if (beam_pattern_idx[i] == 1) {
-				data_tmp = 0x2;
-				/**/
-			} else if (beam_pattern_idx[i] == 2) {
-				data_tmp = 0x4;
-				/**/
-			} else if (beam_pattern_idx[i] == 3) {
-				data_tmp = 0x8;
-				/**/
-			}  
-			codeword |= (data_tmp<<(i*4));
-		}
-	}
-
-	return codeword;
-}
-
-VOID
-phydm_update_beam_pattern(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		codeword,
-	IN		u4Byte		codeword_length
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);
-	u1Byte			i;
-	BOOLEAN			beam_ctrl_signal;
-	u4Byte			one = 0x1;
-	u4Byte			reg44_tmp_p, reg44_tmp_n, reg44_ori;
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] Set Beam Pattern =0x%x\n", codeword));
-	
-	reg44_ori = ODM_GetMACReg(pDM_Odm, 0x44, bMaskDWord);
-	/*ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("reg44_ori =0x%x\n", reg44_ori));*/
-	
-	for (i = 0; i <= (codeword_length-1); i++) {
-		beam_ctrl_signal = (BOOLEAN)((codeword&BIT(i)) >> i);
-
-		if (pDM_Odm->DebugComponents & ODM_COMP_ANT_DIV) {
-			
-			if (i == (codeword_length-1)) {
-				DbgPrint("%d ]\n", beam_ctrl_signal);
-				/**/
-			} else if (i == 0) {
-				DbgPrint("Send codeword[1:24] ---> [ %d ", beam_ctrl_signal);	
-				/**/
-			} else if ((i % 4) == 3) {
-				DbgPrint("%d  |  ", beam_ctrl_signal);	
-				/**/
-			} else {
-				DbgPrint("%d ", beam_ctrl_signal);
-				/**/
-			}
-		}
-		
-		#if 1
-		reg44_tmp_p = reg44_ori & (~(BIT11|BIT10)); /*clean bit 10 & 11*/
-		reg44_tmp_p |= ((1<<11) | (beam_ctrl_signal<<10));
-		reg44_tmp_n = reg44_ori & (~(BIT11|BIT10));
-
-		/*ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n));*/
-		ODM_SetMACReg(pDM_Odm, 0x44 , bMaskDWord, reg44_tmp_p);
-		ODM_SetMACReg(pDM_Odm, 0x44 , bMaskDWord, reg44_tmp_n); 
-		#else
-		ODM_SetMACReg(pDM_Odm, 0x44 , BIT11|BIT10, ((1<<1) | beam_ctrl_signal));
-		ODM_SetMACReg(pDM_Odm, 0x44 , BIT11, 0); 
-		#endif
-
-	}
-}
-
-VOID
-phydm_update_rx_idle_beam(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);
-	u4Byte			i;
-
-	pdm_sat_table->update_beam_codeword = phydm_construct_hl_beam_codeword(pDM_Odm, &(pdm_sat_table->rx_idle_beam[0]), pdm_sat_table->ant_num);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Set target beam_pattern codeword = (( 0x%x ))\n", pdm_sat_table->update_beam_codeword));
-
-	for (i = 0; i < (pdm_sat_table->ant_num); i++) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Update Rx-Idle-Beam ] RxIdleBeam[%d] =%d\n", i, pdm_sat_table->rx_idle_beam[i]));
-		/**/
-	}
-	
-	#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	phydm_update_beam_pattern(pDM_Odm, pdm_sat_table->update_beam_codeword, pdm_sat_table->data_codeword_bit_num);
-	#else
-	ODM_ScheduleWorkItem(&pdm_sat_table->hl_smart_antenna_workitem);
-	/*ODM_StallExecution(1);*/
-	#endif
-	
-	pdm_sat_table->pre_codeword = pdm_sat_table->update_beam_codeword;
-}
-
-VOID
-phydm_hl_smart_ant_cmd(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value,
-	IN		u4Byte		*_used,
-	OUT		char			*output,
-	IN		u4Byte		*_out_len
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);	
-	u4Byte			used = *_used;
-	u4Byte			out_len = *_out_len;
-	u4Byte			one = 0x1;
-	u4Byte			codeword_length = pdm_sat_table->data_codeword_bit_num;
-	u4Byte			beam_ctrl_signal, i;
-	
-	if (dm_value[0] == 1) { /*fix beam pattern*/
-		
-		pdm_sat_table->fix_beam_pattern_en = dm_value[1];
-		
-		if (pdm_sat_table->fix_beam_pattern_en == 1) {
-			
-			pdm_sat_table->fix_beam_pattern_codeword = dm_value[2];
-
-			if (pdm_sat_table->fix_beam_pattern_codeword  > (one<<codeword_length)) {
-				
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n", 
-					pdm_sat_table->fix_beam_pattern_codeword, codeword_length));
-				(pdm_sat_table->fix_beam_pattern_codeword) &= 0xffffff;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] Auto modify to (0x%x)\n", pdm_sat_table->fix_beam_pattern_codeword));
-			}
-			
-			pdm_sat_table->update_beam_codeword = pdm_sat_table->fix_beam_pattern_codeword;
-
-			/*---------------------------------------------------------*/
-			PHYDM_SNPRINTF((output+used, out_len-used, "Fix Beam Pattern\n"));
-			for (i = 0; i <= (codeword_length-1); i++) {
-				beam_ctrl_signal = (BOOLEAN)((pdm_sat_table->update_beam_codeword&BIT(i)) >> i);
-				
-				if (i == (codeword_length-1)) {
-					PHYDM_SNPRINTF((output+used, out_len-used, "%d]\n", beam_ctrl_signal));
-					/**/
-				} else if (i == 0) {
-					PHYDM_SNPRINTF((output+used, out_len-used, "Send Codeword[1:24] to RFU -> [%d", beam_ctrl_signal));
-					/**/
-				} else if ((i % 4) == 3) {
-					PHYDM_SNPRINTF((output+used, out_len-used, "%d|", beam_ctrl_signal));
-					/**/
-				} else {
-					PHYDM_SNPRINTF((output+used, out_len-used, "%d", beam_ctrl_signal));
-					/**/
-				}
-			}
-			/*---------------------------------------------------------*/
-
-			
-			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-			phydm_update_beam_pattern(pDM_Odm, pdm_sat_table->update_beam_codeword, pdm_sat_table->data_codeword_bit_num);
-			#else
-			ODM_ScheduleWorkItem(&pdm_sat_table->hl_smart_antenna_workitem);
-			/*ODM_StallExecution(1);*/
-			#endif
-		} else if (pdm_sat_table->fix_beam_pattern_en == 0) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] Smart Antenna: Enable\n"));
-		}
-		
-	} else if (dm_value[0] == 2) { /*set latch time*/
-		
-		pdm_sat_table->latch_time = dm_value[1];
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ]  latch_time =0x%x\n", pdm_sat_table->latch_time));
-	} else if (dm_value[0] == 3) {
-	
-		pdm_sat_table->fix_training_num_en = dm_value[1];
-		
-		if (pdm_sat_table->fix_training_num_en == 1) {
-			pdm_sat_table->per_beam_training_pkt_num = dm_value[2];
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ]  Fix per_beam_training_pkt_num = (( 0x%x ))\n", pdm_sat_table->per_beam_training_pkt_num));
-		} else if (pdm_sat_table->fix_training_num_en == 0) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ]  AUTO per_beam_training_pkt_num\n"));
-			/**/
-		}
-	}
-		
-}
-
-
-void
-phydm_set_all_ant_same_beam_num(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);
-
-	if (pDM_Odm->AntDivType == HL_SW_SMART_ANT_TYPE1) { /*2Ant for 8821A*/
-		
-		pdm_sat_table->rx_idle_beam[0] = pdm_sat_table->fast_training_beam_num;
-		pdm_sat_table->rx_idle_beam[1] = pdm_sat_table->fast_training_beam_num;
-	}
-	
-	pdm_sat_table->update_beam_codeword = phydm_construct_hl_beam_codeword(pDM_Odm, &(pdm_sat_table->rx_idle_beam[0]), pdm_sat_table->ant_num);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] Set all ant beam_pattern: codeword = (( 0x%x ))\n", pdm_sat_table->update_beam_codeword));
-
-	#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	phydm_update_beam_pattern(pDM_Odm, pdm_sat_table->update_beam_codeword, pdm_sat_table->data_codeword_bit_num);
-	#else
-	ODM_ScheduleWorkItem(&pdm_sat_table->hl_smart_antenna_workitem);
-	/*ODM_StallExecution(1);*/
-	#endif
-}
-
-VOID
-odm_FastAntTraining_hl_smart_antenna_type1(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pSAT_T		pdm_sat_table = &(pDM_Odm->dm_sat_table);
-	pFAT_T		pDM_FatTable	 = &(pDM_Odm->DM_FatTable);
-	pSWAT_T		pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	u4Byte		codeword = 0, i, j;
-	u4Byte		TargetAnt;
-	u4Byte		avg_rssi_tmp;
-	u4Byte		target_ant_beam_max_rssi[SUPPORT_RF_PATH_NUM] = {0};
-	u4Byte		max_beam_ant_rssi = 0;
-	u4Byte		target_ant_beam[SUPPORT_RF_PATH_NUM] = {0};
-	u4Byte		beam_tmp;
-
-
-	if (!pDM_Odm->bLinked) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[No Link!!!]\n"));
-				
-		if (pDM_FatTable->bBecomeLinked == TRUE) {
-			
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Link -> no Link\n"));
-			pDM_FatTable->FAT_State = FAT_BEFORE_LINK_STATE;
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm, TX_BY_REG);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("change to (( %d )) FAT_state\n", pDM_FatTable->FAT_State));
-			
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-		}
-		return;
-		
-	} else {
-		if (pDM_FatTable->bBecomeLinked == FALSE) {
-			
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Linked !!!]\n"));
-			
-			pDM_FatTable->FAT_State = FAT_PREPARE_STATE;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("change to (( %d )) FAT_state\n", pDM_FatTable->FAT_State));
-			
-			/*pdm_sat_table->fast_training_beam_num = 0;*/
-			/*phydm_set_all_ant_same_beam_num(pDM_Odm);*/
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm, TX_BY_DESC);
-			
-			pDM_FatTable->bBecomeLinked = pDM_Odm->bLinked;
-		}
-	}
-
-	/*ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("HL Smart Ant Training: State (( %d ))\n", pDM_FatTable->FAT_State));*/
-
-	/* [DECISION STATE] */
-	/*=======================================================================================*/
-	if (pDM_FatTable->FAT_State == FAT_DECISION_STATE) {
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 3. In Decision State]\n"));
-		phydm_FastTraining_enable(pDM_Odm , FAT_OFF);
-		
-		/*compute target beam in each antenna*/
-		for (i = 0; i < (pdm_sat_table->ant_num); i++) {
-			for (j = 0; j < (pdm_sat_table->beam_patten_num_each_ant); j++) {
-
-				if (pdm_sat_table->pkt_rssi_cnt[i][j] == 0) {
-					avg_rssi_tmp = pdm_sat_table->pkt_rssi_pre[i][j];
-					/**/
-				} else {
-					avg_rssi_tmp = (pdm_sat_table->pkt_rssi_sum[i][j]) / (pdm_sat_table->pkt_rssi_cnt[i][j]);
-					pdm_sat_table->pkt_rssi_pre[i][j] = avg_rssi_tmp;
-					/**/
-				}
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Ant[%d], Beam[%d]: pkt_num=(( %d )), avg_rssi=(( %d ))\n", i, j, pdm_sat_table->pkt_rssi_cnt[i][j], avg_rssi_tmp));
-				
-				if (avg_rssi_tmp > target_ant_beam_max_rssi[i]) {
-					target_ant_beam[i] = j;
-					target_ant_beam_max_rssi[i] = avg_rssi_tmp;
-				}
-
-				/*reset counter value*/
-				pdm_sat_table->pkt_rssi_sum[i][j] = 0;
-				pdm_sat_table->pkt_rssi_cnt[i][j] = 0;
-								
-			}
-			pdm_sat_table->rx_idle_beam[i] = target_ant_beam[i];
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("---------> Target of Ant[%d]: Beam_num-(( %d )) RSSI= ((%d))\n", 
-					i,  target_ant_beam[i], target_ant_beam_max_rssi[i]));
-
-			if (target_ant_beam_max_rssi[i] > max_beam_ant_rssi) {
-				TargetAnt = i;
-				max_beam_ant_rssi = target_ant_beam_max_rssi[i];
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Target of Ant = (( %d )) max_beam_ant_rssi = (( %d ))\n", 
-					TargetAnt,  max_beam_ant_rssi));
-			}
-		}
-
-		if (TargetAnt == 0) 
-			TargetAnt = MAIN_ANT;
-		else if (TargetAnt == 1)
-			TargetAnt = AUX_ANT;
-
-		/* [ update RX ant ]*/
-		ODM_UpdateRxIdleAnt(pDM_Odm, (u1Byte)TargetAnt);
-
-		/* [ update TX ant ]*/
-		odm_UpdateTxAnt(pDM_Odm, (u1Byte)TargetAnt, (pDM_FatTable->TrainIdx));
-		
-		/*set beam in each antenna*/
-		phydm_update_rx_idle_beam(pDM_Odm);
-
-		phydm_FastTraining_enable(pDM_Odm , FAT_OFF);
-		odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);		
-		pDM_FatTable->FAT_State = FAT_PREPARE_STATE;
-
-	} 
-	/* [TRAINING STATE] */
-	else if (pDM_FatTable->FAT_State == FAT_TRAINING_STATE) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2. In Training State]\n"));
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("fat_beam_n = (( %d )), pre_fat_beam_n = (( %d ))\n", 
-			pdm_sat_table->fast_training_beam_num, pdm_sat_table->pre_fast_training_beam_num));
-		
-		if (pdm_sat_table->fast_training_beam_num > pdm_sat_table->pre_fast_training_beam_num) {
-			
-			pdm_sat_table->force_update_beam_en = 0;
-
-		} else {
-		
-			pdm_sat_table->force_update_beam_en = 1;
-			
-			pdm_sat_table->pkt_counter = 0;
-			beam_tmp = pdm_sat_table->fast_training_beam_num;
-			if (pdm_sat_table->fast_training_beam_num >= (pdm_sat_table->beam_patten_num_each_ant-1)) {
-				
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n", pdm_sat_table->fast_training_beam_num));	
-				phydm_FastTraining_enable(pDM_Odm , FAT_OFF);
-				pDM_FatTable->FAT_State = FAT_DECISION_STATE;					
-				odm_FastAntTraining_hl_smart_antenna_type1(pDM_Odm);
-
-			} else {
-				pdm_sat_table->fast_training_beam_num++;
-				
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, pdm_sat_table->fast_training_beam_num));
-				phydm_set_all_ant_same_beam_num(pDM_Odm);
-				pDM_FatTable->FAT_State = FAT_TRAINING_STATE;	
-				
-			}
-		}
-		pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Update Pre_Beam =(( %d ))\n", pdm_sat_table->pre_fast_training_beam_num));
-	}
-	/*  [Prepare State] */
-	/*=======================================================================================*/
-	else if (pDM_FatTable->FAT_State == FAT_PREPARE_STATE) {
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("\n\n[ 1. In Prepare State]\n"));
-		
-		if (pDM_Odm->pre_TrafficLoad == (pDM_Odm->TrafficLoad)) {
-			if (pdm_sat_table->decision_holding_period != 0) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Holding_period = (( %d )), return!!!\n", pdm_sat_table->decision_holding_period));
-				pdm_sat_table->decision_holding_period--;
-				return;
-			}
-		}
-				
-		
-		/* Set training packet number*/
-		if (pdm_sat_table->fix_training_num_en == 0) {
-
-			switch (pDM_Odm->TrafficLoad) {
-
-			case TRAFFIC_HIGH: 
-				pdm_sat_table->per_beam_training_pkt_num = 20;
-				pdm_sat_table->decision_holding_period = 0;
-				break;
-			case TRAFFIC_MID: 
-				pdm_sat_table->per_beam_training_pkt_num = 10;
-				pdm_sat_table->decision_holding_period = 1;
-				break;
-			case TRAFFIC_LOW: 
-				pdm_sat_table->per_beam_training_pkt_num = 5; /*ping 60000*/
-				pdm_sat_table->decision_holding_period = 3;
-				break;
-			case TRAFFIC_ULTRA_LOW: 
-				pdm_sat_table->per_beam_training_pkt_num = 2;
-				pdm_sat_table->decision_holding_period = 5;
-				break;
-			default:
-				break;			
-			}
-		}
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Fix_training_num = (( %d )), per_beam_training_pkt_num = (( %d ))\n",
-			pdm_sat_table->fix_training_num_en , pdm_sat_table->per_beam_training_pkt_num));
-		
-		/* Set training MAC Addr. of target */
-		odm_SetNextMACAddrTarget(pDM_Odm);
-
-		phydm_FastTraining_enable(pDM_Odm , FAT_ON);
-		odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-		pdm_sat_table->pkt_counter = 0;
-		pdm_sat_table->fast_training_beam_num = 0;
-		phydm_set_all_ant_same_beam_num(pDM_Odm);
-		pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-		pDM_FatTable->FAT_State = FAT_TRAINING_STATE;
-	}
-		
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-phydm_beam_switch_workitem_callback(
-	IN	PVOID	pContext
-	)
-{
-	PADAPTER		pAdapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);
-
-	#if DEV_BUS_TYPE != RT_PCI_INTERFACE
-	pdm_sat_table->pkt_skip_statistic_en = 1;
-	#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n", pdm_sat_table->pkt_skip_statistic_en));
-	
-	phydm_update_beam_pattern(pDM_Odm, pdm_sat_table->update_beam_codeword, pdm_sat_table->data_codeword_bit_num);
-
-	#if DEV_BUS_TYPE != RT_PCI_INTERFACE
-	/*ODM_StallExecution(pdm_sat_table->latch_time);*/
-	pdm_sat_table->pkt_skip_statistic_en = 0;
-	#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n", pdm_sat_table->pkt_skip_statistic_en, pdm_sat_table->latch_time));
-}
-
-VOID
-phydm_beam_decision_workitem_callback(
-	IN	PVOID	pContext
-	)
-{
-	PADAPTER		pAdapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] Beam decision Workitem Callback\n"));
-	odm_FastAntTraining_hl_smart_antenna_type1(pDM_Odm);
-}
-#endif
-
-#endif /*#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1*/
-
-VOID
-ODM_AntDivInit(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	pSWAT_T			pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_ANT_DIV))
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[Return!!!]   Not Support Antenna Diversity Function\n"));
-		return;
-	}
-        //---
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if(pDM_FatTable->AntDiv_2G_5G == ODM_ANTDIV_2G)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[2G AntDiv Init]: Only Support 2G Antenna Diversity Function\n"));
-		if(!(pDM_Odm->SupportICType & ODM_ANTDIV_2G_SUPPORT_IC))
-			return;
-	}
-	else 	if(pDM_FatTable->AntDiv_2G_5G == ODM_ANTDIV_5G)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[5G AntDiv Init]: Only Support 5G Antenna Diversity Function\n"));
-		if(!(pDM_Odm->SupportICType & ODM_ANTDIV_5G_SUPPORT_IC))
-			return;
-	}
-	else 	if(pDM_FatTable->AntDiv_2G_5G == (ODM_ANTDIV_2G|ODM_ANTDIV_5G))
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[2G & 5G AntDiv Init]:Support Both 2G & 5G Antenna Diversity Function\n"));
-	}
-
-#endif	
-	//---
-
-	//2 [--General---]
-	pDM_Odm->antdiv_period=0;
-
-	pDM_FatTable->bBecomeLinked =FALSE;
-	pDM_FatTable->AntDiv_OnOff =0xff;
-
-	//3       -   AP   -
-	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	
-		#ifdef BEAMFORMING_SUPPORT
-		#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-		odm_BDC_Init(pDM_Odm);
-		#endif
-		#endif
-		
-	//3     -   WIN   -
-	#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		pDM_SWAT_Table->Ant5G = MAIN_ANT;
-		pDM_SWAT_Table->Ant2G = MAIN_ANT;
-		pDM_FatTable->CCK_counter_main=0;
-		pDM_FatTable->CCK_counter_aux=0;
-		pDM_FatTable->OFDM_counter_main=0;
-		pDM_FatTable->OFDM_counter_aux=0;
-	#endif
-
-	//2 [---Set MAIN_ANT as default antenna if Auto-Ant enable---]
-	odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-
-	pDM_Odm->AntType = ODM_AUTO_ANT;
-
-	pDM_FatTable->RxIdleAnt = 0xff; /*to make RX-idle-antenna will be updated absolutly*/
-	ODM_UpdateRxIdleAnt(pDM_Odm, MAIN_ANT);
-		
-	//2 [---Set TX Antenna---]
-	odm_Tx_By_TxDesc_or_Reg(pDM_Odm, TX_BY_REG);
-
-		
-	//2 [--88E---]
-	if(pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-	#if (RTL8188E_SUPPORT == 1)
-		//pDM_Odm->AntDivType = CGCS_RX_HW_ANTDIV;
-		//pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-		//pDM_Odm->AntDivType = CG_TRX_SMART_ANTDIV;
-
-		if( (pDM_Odm->AntDivType != CGCS_RX_HW_ANTDIV)  && (pDM_Odm->AntDivType != CG_TRX_HW_ANTDIV) && (pDM_Odm->AntDivType != CG_TRX_SMART_ANTDIV))
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[Return!!!]  88E Not Supprrt This AntDiv Type\n"));
-			pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-			return;
-		}
-		
-		if(pDM_Odm->AntDivType == CGCS_RX_HW_ANTDIV)
-			odm_RX_HWAntDiv_Init_88E(pDM_Odm);
-		else if(pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV)
-			odm_TRX_HWAntDiv_Init_88E(pDM_Odm);
-		#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-		else if(pDM_Odm->AntDivType == CG_TRX_SMART_ANTDIV)
-			odm_Smart_HWAntDiv_Init_88E(pDM_Odm);
-	        #endif	
-	#endif
-	}
-	
-	//2 [--92E---]
-	#if (RTL8192E_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8192E)
-	{	
-		//pDM_Odm->AntDivType = CGCS_RX_HW_ANTDIV;
-		//pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-		//pDM_Odm->AntDivType = CG_TRX_SMART_ANTDIV;
-
-		if( (pDM_Odm->AntDivType != CGCS_RX_HW_ANTDIV) && (pDM_Odm->AntDivType != CG_TRX_HW_ANTDIV)   && (pDM_Odm->AntDivType != CG_TRX_SMART_ANTDIV))
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[Return!!!]  8192E Not Supprrt This AntDiv Type\n"));
-			pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-			return;
-		}
-		
-		if(pDM_Odm->AntDivType == CGCS_RX_HW_ANTDIV)
-			odm_RX_HWAntDiv_Init_92E(pDM_Odm);
-		else if(pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV)
-			odm_TRX_HWAntDiv_Init_92E(pDM_Odm);
-		#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-		else if(pDM_Odm->AntDivType == CG_TRX_SMART_ANTDIV)
-			odm_Smart_HWAntDiv_Init_92E(pDM_Odm);
-		#endif
-	
-	}
-	#endif	
-	
-	//2 [--8723B---]
-	#if (RTL8723B_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8723B)
-	{		
-		//pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-		//pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-
-		if(pDM_Odm->AntDivType != S0S1_SW_ANTDIV && pDM_Odm->AntDivType != CG_TRX_HW_ANTDIV)
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[Return!!!] 8723B  Not Supprrt This AntDiv Type\n"));
-			pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-			return;
-		}
-			
-		if( pDM_Odm->AntDivType==S0S1_SW_ANTDIV)
-			odm_S0S1_SWAntDiv_Init_8723B(pDM_Odm);
-		else if(pDM_Odm->AntDivType==CG_TRX_HW_ANTDIV)
-			odm_TRX_HWAntDiv_Init_8723B(pDM_Odm);		
-	}
-	#endif
-	
-	//2 [--8811A 8821A---]
-	#if (RTL8821A_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8821)
-	{
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-		pDM_Odm->AntDivType = HL_SW_SMART_ANT_TYPE1;
-		
-		if (pDM_Odm->AntDivType == HL_SW_SMART_ANT_TYPE1) {
-			
-			odm_TRX_HWAntDiv_Init_8821A(pDM_Odm);
-			phydm_hl_smart_ant_type1_init_8821a(pDM_Odm);
-		} else 
-		#endif
-		{
-			/*pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;*/
-			pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-				
-			if (pDM_Odm->AntDivType != CG_TRX_HW_ANTDIV && pDM_Odm->AntDivType != S0S1_SW_ANTDIV) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[Return!!!] 8821A & 8811A  Not Supprrt This AntDiv Type\n"));
-				pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-				return;
-			}
-			if (pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV)	
-				odm_TRX_HWAntDiv_Init_8821A(pDM_Odm);
-			else if (pDM_Odm->AntDivType == S0S1_SW_ANTDIV)
-				odm_S0S1_SWAntDiv_Init_8821A(pDM_Odm);
-		}
-	}
-	#endif
-	
-	//2 [--8881A---]
-	#if (RTL8881A_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8881A)
-	{
-			//pDM_Odm->AntDivType = CGCS_RX_HW_ANTDIV;
-			//pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-			
-			if(pDM_Odm->AntDivType != CGCS_RX_HW_ANTDIV && pDM_Odm->AntDivType != CG_TRX_HW_ANTDIV)
-			{
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[Return!!!] 8881A  Not Supprrt This AntDiv Type\n"));
-				pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-				return;
-			}
-			if(pDM_Odm->AntDivType == CGCS_RX_HW_ANTDIV)
-				odm_RX_HWAntDiv_Init_8881A(pDM_Odm);
-			else if(pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV)
-				odm_TRX_HWAntDiv_Init_8881A(pDM_Odm);	
-	}
-	#endif
-	
-	//2 [--8812---]
-	#if (RTL8812A_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8812)
-	{	
-			//pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-			
-			if( pDM_Odm->AntDivType != CG_TRX_HW_ANTDIV)
-			{
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[Return!!!] 8812A  Not Supprrt This AntDiv Type\n"));
-				pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-				return;
-			}
-			odm_TRX_HWAntDiv_Init_8812A(pDM_Odm);
-	}
-	#endif
-
-	/*[--8188F---]*/
-	#if (RTL8188F_SUPPORT == 1)
-	else if (pDM_Odm->SupportICType == ODM_RTL8188F) {
-		
-		pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-		odm_S0S1_SWAntDiv_Init_8188F(pDM_Odm);
-	}
-	#endif
-	/*
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** SupportICType=[%lu]\n",pDM_Odm->SupportICType));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** AntDiv SupportAbility=[%lu]\n",(pDM_Odm->SupportAbility & ODM_BB_ANT_DIV)>>6));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("*** AntDiv Type=[%d]\n",pDM_Odm->AntDivType));
-	*/
-}
-
-VOID
-ODM_AntDiv(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		pAdapter	= pDM_Odm->Adapter;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);
-	#endif
-
-	if(*pDM_Odm->pBandType == ODM_BAND_5G )
-	{
-		if(pDM_FatTable->idx_AntDiv_counter_5G <  pDM_Odm->antdiv_period )
-		{
-			pDM_FatTable->idx_AntDiv_counter_5G++;
-			return;
-		}
-		else
-			pDM_FatTable->idx_AntDiv_counter_5G=0;
-	}
-	else 	if(*pDM_Odm->pBandType == ODM_BAND_2_4G )
-	{
-		if(pDM_FatTable->idx_AntDiv_counter_2G <  pDM_Odm->antdiv_period )
-		{
-			pDM_FatTable->idx_AntDiv_counter_2G++;
-			return;
-		}
-		else
-			pDM_FatTable->idx_AntDiv_counter_2G=0;
-	}
-	
-	//----------
-	if(!(pDM_Odm->SupportAbility & ODM_BB_ANT_DIV))
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[Return!!!]   Not Support Antenna Diversity Function\n"));
-		return;
-	}
-
-	//----------
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-	if (pDM_FatTable->enable_ctrl_frame_antdiv) {
-		
-		if ((pDM_Odm->data_frame_num <= 10) && (pDM_Odm->bLinked))
-			pDM_FatTable->use_ctrl_frame_antdiv = 1;
-		else
-			pDM_FatTable->use_ctrl_frame_antdiv = 0;
-		
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("use_ctrl_frame_antdiv = (( %d )), data_frame_num = (( %d ))\n", pDM_FatTable->use_ctrl_frame_antdiv, pDM_Odm->data_frame_num));
-		pDM_Odm->data_frame_num = 0;
-	}
-
-	if(pAdapter->MgntInfo.AntennaTest)
-		return;
-	
-        {
-	#if (BEAMFORMING_SUPPORT == 1)			
-	        BEAMFORMING_CAP		BeamformCap = (pDM_Odm->BeamformingInfo.BeamformCap);
-
-		if( BeamformCap & BEAMFORMEE_CAP ) //  BFmee On  &&   Div On ->  Div Off
-		{	
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[ AntDiv : OFF ]   BFmee ==1 \n"));
-			if(pDM_FatTable->fix_ant_bfee == 0)
-			{
-				odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-				pDM_FatTable->fix_ant_bfee = 1;
-			}
-			return;
-		}
-		else // BFmee Off   &&   Div Off ->  Div On
-		{
-			if((pDM_FatTable->fix_ant_bfee == 1)  &&  pDM_Odm->bLinked) 
-			{
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ AntDiv : ON ]   BFmee ==0\n"));
-				if((pDM_Odm->AntDivType!=S0S1_SW_ANTDIV) )
-					odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);
-
-				pDM_FatTable->fix_ant_bfee = 0;
-			}
-		}
-	#endif	
-	}
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	//----------just for fool proof
-
-	if(pDM_Odm->antdiv_rssi)
-		pDM_Odm->DebugComponents |= ODM_COMP_ANT_DIV;
-	else
-		pDM_Odm->DebugComponents &= ~ODM_COMP_ANT_DIV;
-
-	if(pDM_FatTable->AntDiv_2G_5G == ODM_ANTDIV_2G)
-	{
-		//ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[ 2G AntDiv Running ]\n"));
-		if(!(pDM_Odm->SupportICType & ODM_ANTDIV_2G_SUPPORT_IC))
-			return;
-	}
-	else if(pDM_FatTable->AntDiv_2G_5G == ODM_ANTDIV_5G)
-	{
-		//ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[ 5G AntDiv Running ]\n"));
-		if(!(pDM_Odm->SupportICType & ODM_ANTDIV_5G_SUPPORT_IC))
-			return;
-	}
-	//else 	if(pDM_FatTable->AntDiv_2G_5G == (ODM_ANTDIV_2G|ODM_ANTDIV_5G))
-	//{
-		//ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("[ 2G & 5G AntDiv Running ]\n"));
-	//}
-#endif
-
-	//----------
-
-	if (pDM_Odm->antdiv_select==1)
-		pDM_Odm->AntType = ODM_FIX_MAIN_ANT;
-	else if (pDM_Odm->antdiv_select==2)
-		pDM_Odm->AntType = ODM_FIX_AUX_ANT;
-	else  //if (pDM_Odm->antdiv_select==0)
-		pDM_Odm->AntType = ODM_AUTO_ANT;
-
-	//ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,ODM_DBG_LOUD,("AntType= (( %d )) , pre_AntType= (( %d ))  \n",pDM_Odm->AntType,pDM_Odm->pre_AntType));
-	
-	if(pDM_Odm->AntType != ODM_AUTO_ANT)
-	{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Fix Antenna at (( %s ))\n",(pDM_Odm->AntType == ODM_FIX_MAIN_ANT)?"MAIN":"AUX"));
-			
-		if(pDM_Odm->AntType != pDM_Odm->pre_AntType)
-		{
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm, TX_BY_REG);
-						
-			if(pDM_Odm->AntType == ODM_FIX_MAIN_ANT)
-				ODM_UpdateRxIdleAnt(pDM_Odm, MAIN_ANT);
-			else if(pDM_Odm->AntType == ODM_FIX_AUX_ANT)
-				ODM_UpdateRxIdleAnt(pDM_Odm, AUX_ANT);
-		}
-		pDM_Odm->pre_AntType=pDM_Odm->AntType; 
-		return;
-	}
-	else
-	{
-		if(pDM_Odm->AntType != pDM_Odm->pre_AntType)
-		{
-			odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);
-			odm_Tx_By_TxDesc_or_Reg(pDM_Odm , TX_BY_DESC);
-		}
-		pDM_Odm->pre_AntType=pDM_Odm->AntType;
-	}
-	 
-	
-	//3 -----------------------------------------------------------------------------------------------------------
-	//2 [--88E---]
-	if(pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-		#if (RTL8188E_SUPPORT == 1)
-		if(pDM_Odm->AntDivType==CG_TRX_HW_ANTDIV ||pDM_Odm->AntDivType==CGCS_RX_HW_ANTDIV)
-			odm_HW_AntDiv(pDM_Odm);
-
-		#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-		else if (pDM_Odm->AntDivType==CG_TRX_SMART_ANTDIV)
-			odm_FastAntTraining(pDM_Odm);	
-		#endif
-		
-		#endif
-
-	}
-	//2 [--92E---]	
-	#if (RTL8192E_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8192E)
-	{
-		if(pDM_Odm->AntDivType==CGCS_RX_HW_ANTDIV || pDM_Odm->AntDivType==CG_TRX_HW_ANTDIV)
-			odm_HW_AntDiv(pDM_Odm);
-		
-		#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-		else if (pDM_Odm->AntDivType==CG_TRX_SMART_ANTDIV)
-			odm_FastAntTraining(pDM_Odm);	
-		#endif
-		
-	}
-	#endif
-
-	#if (RTL8723B_SUPPORT == 1)	
-	//2 [--8723B---]
-	else if(pDM_Odm->SupportICType == ODM_RTL8723B)
-	{
-		if (phydm_IsBtEnable_8723b(pDM_Odm)) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[BT is enable!!!] AntDiv: OFF\n"));
-			if (pDM_FatTable->bBecomeLinked == TRUE) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Set REG 948[9:6]=0x0\n"));
-				if (pDM_Odm->SupportICType == ODM_RTL8723B)
-					ODM_SetBBReg(pDM_Odm, 0x948 , BIT9|BIT8|BIT7|BIT6, 0x0); 
-				
-				pDM_FatTable->bBecomeLinked = FALSE;
-			}
-		} else {
-			if (pDM_Odm->AntDivType == S0S1_SW_ANTDIV) {
-				
-				#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-				odm_S0S1_SwAntDiv(pDM_Odm, SWAW_STEP_PEEK);
-				#endif
-			} else if (pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV)
-				odm_HW_AntDiv(pDM_Odm);
-		}
-	}
-	#endif
-	
-	//2 [--8821A---]
-	#if (RTL8821A_SUPPORT == 1)
-	else if (pDM_Odm->SupportICType == ODM_RTL8821)
-	{
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-		if (pDM_Odm->AntDivType == HL_SW_SMART_ANT_TYPE1) {
-
-			if (pdm_sat_table->fix_beam_pattern_en != 0) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n", pdm_sat_table->fix_beam_pattern_codeword));
-				/*return;*/
-			} else {
-				/*ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ SmartAnt ] AntDivType = HL_SW_SMART_ANT_TYPE1\n"));*/
-				odm_FastAntTraining_hl_smart_antenna_type1(pDM_Odm);
-			}
-
-		} else 
-		#endif
-		{
-			if (!pDM_Odm->bBtEnabled)  /*BT disabled*/
-			{
-				if (pDM_Odm->AntDivType == S0S1_SW_ANTDIV) {
-					pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" [S0S1_SW_ANTDIV]  ->  [CG_TRX_HW_ANTDIV]\n"));
-					/*ODM_SetBBReg(pDM_Odm, 0x8D4 , BIT24, 1); */
-					if (pDM_FatTable->bBecomeLinked == TRUE)
-						odm_AntDiv_on_off(pDM_Odm, ANTDIV_ON);
-				}
-				
-			} else { /*BT enabled*/
-			
-				if (pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV) {
-					pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, (" [CG_TRX_HW_ANTDIV]  ->  [S0S1_SW_ANTDIV]\n"));
-					/*ODM_SetBBReg(pDM_Odm, 0x8D4 , BIT24, 0);*/
-					odm_AntDiv_on_off(pDM_Odm, ANTDIV_OFF);
-				}	
-			}
-
-			if (pDM_Odm->AntDivType == S0S1_SW_ANTDIV) {
-
-				#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-				odm_S0S1_SwAntDiv(pDM_Odm, SWAW_STEP_PEEK);
-				#endif
-			} else if (pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV)
-				odm_HW_AntDiv(pDM_Odm);
-		}
-	}
-	#endif
-	
-	//2 [--8881A---]
-	#if (RTL8881A_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8881A)		
-		odm_HW_AntDiv(pDM_Odm);
-	#endif
-	
-	//2 [--8812A---]
-	#if (RTL8812A_SUPPORT == 1)
-	else if(pDM_Odm->SupportICType == ODM_RTL8812)
-		odm_HW_AntDiv(pDM_Odm);
-	#endif
-
-	#if (RTL8188F_SUPPORT == 1)	
-	/* [--8188F---]*/
-	else if (pDM_Odm->SupportICType == ODM_RTL8188F)	{
-	
-		#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		odm_S0S1_SwAntDiv(pDM_Odm, SWAW_STEP_PEEK);
-		#endif		
-	}
-	#endif
-
-}
-
-
-VOID
-odm_AntselStatistics(
-	IN		PVOID			pDM_VOID,	
-	IN		u1Byte			antsel_tr_mux,
-	IN		u4Byte			MacId,
-	IN		u4Byte			utility,
-	IN            u1Byte			method
-
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-	if(method==RSSI_METHOD)
-	{
-		if(antsel_tr_mux == ANT1_2G)
-		{
-			pDM_FatTable->MainAnt_Sum[MacId]+=utility;
-			pDM_FatTable->MainAnt_Cnt[MacId]++;
-		}
-		else
-		{
-			pDM_FatTable->AuxAnt_Sum[MacId]+=utility;
-			pDM_FatTable->AuxAnt_Cnt[MacId]++;
-		}
-	}
-	#ifdef ODM_EVM_ENHANCE_ANTDIV
-	else if(method==EVM_METHOD)
-	{
-		if(antsel_tr_mux == ANT1_2G)
-		{
-			pDM_FatTable->MainAntEVM_Sum[MacId]+=(utility<<5);
-			pDM_FatTable->MainAntEVM_Cnt[MacId]++;
-		}
-		else
-		{
-			pDM_FatTable->AuxAntEVM_Sum[MacId]+=(utility<<5);
-			pDM_FatTable->AuxAntEVM_Cnt[MacId]++;
-		}
-	}
-	else if(method==CRC32_METHOD)
-	{
-		if(utility==0)
-			pDM_FatTable->CRC32_Fail_Cnt++;
-		else
-			pDM_FatTable->CRC32_Ok_Cnt+=utility;
-	}
-	#endif
-}
-
-
-VOID
-ODM_Process_RSSIForAntDiv(	
-	IN OUT		PVOID			pDM_VOID,	
-	IN			PVOID			p_phy_info_void,
-	IN			PVOID			p_pkt_info_void
-	//IN		PODM_PHY_INFO_T				pPhyInfo,
-	//IN		PODM_PACKET_INFO_T			pPktinfo
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_PHY_INFO_T 	pPhyInfo=(PODM_PHY_INFO_T)p_phy_info_void;
-	PODM_PACKET_INFO_T	 pPktinfo=(PODM_PACKET_INFO_T)p_pkt_info_void;
-	u1Byte			isCCKrate=0,CCKMaxRate=ODM_RATE11M;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-	pSAT_T			pdm_sat_table = &(pDM_Odm->dm_sat_table);
-	u4Byte			beam_tmp;
-	#endif
-
-	#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN))
-	u4Byte			RxPower_Ant0, RxPower_Ant1;	
-	u4Byte			RxEVM_Ant0, RxEVM_Ant1;
-	#else
-	u1Byte			RxPower_Ant0, RxPower_Ant1;	
-	u1Byte			RxEVM_Ant0, RxEVM_Ant1;
-	#endif
-
-	CCKMaxRate=ODM_RATE11M;
-	isCCKrate = (pPktinfo->DataRate <= CCKMaxRate)?TRUE:FALSE;
-		
-	if ((pDM_Odm->SupportICType & (ODM_RTL8192E|ODM_RTL8812)) && (pPktinfo->DataRate > CCKMaxRate))
-	{
-		RxPower_Ant0 = pPhyInfo->RxMIMOSignalStrength[0];
-		RxPower_Ant1= pPhyInfo->RxMIMOSignalStrength[1];
-
-		RxEVM_Ant0 =pPhyInfo->RxMIMOSignalQuality[0];
-		RxEVM_Ant1 =pPhyInfo->RxMIMOSignalQuality[1];
-	}
-	else
-		RxPower_Ant0=pPhyInfo->RxPWDBAll;
-
-	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-	if (pDM_Odm->AntDivType == HL_SW_SMART_ANT_TYPE1)
-	{
-		if ((pDM_Odm->SupportICType & ODM_HL_SMART_ANT_TYPE1_SUPPORT) && 
-			(pPktinfo->bPacketToSelf)   && 
-			(pDM_FatTable->FAT_State == FAT_TRAINING_STATE)
-			) {
-			
-			if (pdm_sat_table->pkt_skip_statistic_en == 0) {
-				/*
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
-					pPktinfo->StationID, pDM_FatTable->antsel_rx_keep_0, pDM_FatTable->hw_antsw_occur, pdm_sat_table->fast_training_beam_num, RxPower_Ant0));
-				*/
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("StaID[%d]:  antsel_pathA = ((%d)), bPacketToSelf = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
-					pPktinfo->StationID, pDM_FatTable->antsel_rx_keep_0, pPktinfo->bPacketToSelf, pdm_sat_table->fast_training_beam_num, RxPower_Ant0));
-
-				
-				pdm_sat_table->pkt_rssi_sum[pDM_FatTable->antsel_rx_keep_0][pdm_sat_table->fast_training_beam_num] += RxPower_Ant0;
-				pdm_sat_table->pkt_rssi_cnt[pDM_FatTable->antsel_rx_keep_0][pdm_sat_table->fast_training_beam_num]++;
-				pdm_sat_table->pkt_counter++;
-			
-				/*swich beam every N pkt*/
-				if ((pdm_sat_table->pkt_counter) >= (pdm_sat_table->per_beam_training_pkt_num)) {
-
-					pdm_sat_table->pkt_counter = 0;
-					beam_tmp = pdm_sat_table->fast_training_beam_num;
-									
-					if (pdm_sat_table->fast_training_beam_num >= (pdm_sat_table->beam_patten_num_each_ant-1)) {
-						
-						pDM_FatTable->FAT_State = FAT_DECISION_STATE;
-						
-						#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-						odm_FastAntTraining_hl_smart_antenna_type1(pDM_Odm);
-						#else
-						ODM_ScheduleWorkItem(&pdm_sat_table->hl_smart_antenna_decision_workitem);
-						#endif
-
-
-					} else {
-						pdm_sat_table->fast_training_beam_num++;
-						phydm_set_all_ant_same_beam_num(pDM_Odm);
-						
-						pDM_FatTable->FAT_State = FAT_TRAINING_STATE;	
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("Update  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, pdm_sat_table->fast_training_beam_num));
-					}
-				}
-			}
-		}
-	} else 
-	#endif
-	if (pDM_Odm->AntDivType == CG_TRX_SMART_ANTDIV) {
-		if( (pDM_Odm->SupportICType & ODM_SMART_ANT_SUPPORT) &&  (pPktinfo->bPacketToSelf)   && (pDM_FatTable->FAT_State == FAT_TRAINING_STATE) )//(pPktinfo->bPacketMatchBSSID && (!pPktinfo->bPacketBeacon))
-		{
-			u1Byte	antsel_tr_mux;
-			antsel_tr_mux = (pDM_FatTable->antsel_rx_keep_2<<2) |(pDM_FatTable->antsel_rx_keep_1 <<1) |pDM_FatTable->antsel_rx_keep_0;
-			pDM_FatTable->antSumRSSI[antsel_tr_mux] += RxPower_Ant0;
-			pDM_FatTable->antRSSIcnt[antsel_tr_mux]++;
-		}
-	}
-	else //AntDivType != CG_TRX_SMART_ANTDIV 
-	{
-		if ((pDM_Odm->SupportICType & ODM_ANTDIV_SUPPORT) && (pPktinfo->bPacketToSelf || pDM_FatTable->use_ctrl_frame_antdiv))
-		{
-			if(pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8192E)
-			{
-				odm_AntselStatistics(pDM_Odm, pDM_FatTable->antsel_rx_keep_0, pPktinfo->StationID,RxPower_Ant0,RSSI_METHOD);
-
-				#ifdef ODM_EVM_ENHANCE_ANTDIV
-				if(!isCCKrate)
-				{
-					odm_AntselStatistics(pDM_Odm, pDM_FatTable->antsel_rx_keep_0, pPktinfo->StationID,RxEVM_Ant0,EVM_METHOD);
-				}
-				#endif
-			}
-			else// SupportICType == ODM_RTL8821 and ODM_RTL8723B and ODM_RTL8812)
-			{
-				if(isCCKrate && (pDM_Odm->AntDivType == S0S1_SW_ANTDIV))
-				{
-				 	pDM_FatTable->antsel_rx_keep_0 = (pDM_FatTable->RxIdleAnt == MAIN_ANT) ? ANT1_2G : ANT2_2G;
-
-
-					if(pDM_FatTable->antsel_rx_keep_0==ANT1_2G)
-						pDM_FatTable->CCK_counter_main++;
-					else// if(pDM_FatTable->antsel_rx_keep_0==ANT2_2G)
-						pDM_FatTable->CCK_counter_aux++;
-
-					odm_AntselStatistics(pDM_Odm, pDM_FatTable->antsel_rx_keep_0, pPktinfo->StationID, RxPower_Ant0,RSSI_METHOD);
-				}
-				else
-				{
-					if(pDM_FatTable->antsel_rx_keep_0==ANT1_2G)
-						pDM_FatTable->OFDM_counter_main++;
-					else// if(pDM_FatTable->antsel_rx_keep_0==ANT2_2G)
-						pDM_FatTable->OFDM_counter_aux++;
-					odm_AntselStatistics(pDM_Odm, pDM_FatTable->antsel_rx_keep_0, pPktinfo->StationID, RxPower_Ant0,RSSI_METHOD);
-				}
-			}
-		}
-	}
-	//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("isCCKrate=%d, PWDB_ALL=%d\n",isCCKrate, pPhyInfo->RxPWDBAll));
-	//ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("antsel_tr_mux=3'b%d%d%d\n",pDM_FatTable->antsel_rx_keep_2, pDM_FatTable->antsel_rx_keep_1, pDM_FatTable->antsel_rx_keep_0));
-}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-VOID
-ODM_SetTxAntByTxInfo(
-	IN		PVOID			pDM_VOID,	
-	IN		pu1Byte			pDesc,
-	IN		u1Byte			macId	
-
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T	pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-	if (!(pDM_Odm->SupportAbility & ODM_BB_ANT_DIV))
-		return;
-
-	if (pDM_Odm->AntDivType == CGCS_RX_HW_ANTDIV)
-		return;
-
-
-	if (pDM_Odm->SupportICType == ODM_RTL8723B) {
-#if (RTL8723B_SUPPORT == 1)
-		SET_TX_DESC_ANTSEL_A_8723B(pDesc, pDM_FatTable->antsel_a[macId]);
-		/*ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[8723B] SetTxAntByTxInfo_WIN: MacID=%d, antsel_tr_mux=3'b%d%d%d\n", 
-			macId, pDM_FatTable->antsel_c[macId], pDM_FatTable->antsel_b[macId], pDM_FatTable->antsel_a[macId]));*/
-#endif
-	} else if (pDM_Odm->SupportICType == ODM_RTL8821) {
-#if (RTL8821A_SUPPORT == 1)
-		SET_TX_DESC_ANTSEL_A_8812(pDesc, pDM_FatTable->antsel_a[macId]);
-		/*ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[8821A] SetTxAntByTxInfo_WIN: MacID=%d, antsel_tr_mux=3'b%d%d%d\n", 
-			macId, pDM_FatTable->antsel_c[macId], pDM_FatTable->antsel_b[macId], pDM_FatTable->antsel_a[macId]));*/
-#endif
-	} else if (pDM_Odm->SupportICType == ODM_RTL8188E) {
-#if (RTL8188E_SUPPORT == 1)
-		SET_TX_DESC_ANTSEL_A_88E(pDesc, pDM_FatTable->antsel_a[macId]);
-		SET_TX_DESC_ANTSEL_B_88E(pDesc, pDM_FatTable->antsel_b[macId]);
-		SET_TX_DESC_ANTSEL_C_88E(pDesc, pDM_FatTable->antsel_c[macId]);
-		/*ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[8188E] SetTxAntByTxInfo_WIN: MacID=%d, antsel_tr_mux=3'b%d%d%d\n", 
-			macId, pDM_FatTable->antsel_c[macId], pDM_FatTable->antsel_b[macId], pDM_FatTable->antsel_a[macId]));*/
-#endif
-	}
-}
-#elif(DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-VOID
-ODM_SetTxAntByTxInfo(
-	struct	rtl8192cd_priv		*priv,
-	struct	tx_desc	*pdesc,
-	unsigned short			aid	
-)
-{
-	pFAT_T		pDM_FatTable = &priv->pshare->_dmODM.DM_FatTable;
-	u4Byte		SupportICType = priv->pshare->_dmODM.SupportICType;
-
-	if (SupportICType == ODM_RTL8881A) {
-		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);	*/
-		pdesc->Dword6 &= set_desc(~(BIT(18)|BIT(17)|BIT(16)));	
-		pdesc->Dword6 |= set_desc(pDM_FatTable->antsel_a[aid]<<16);
-	} else if (SupportICType == ODM_RTL8192E) {
-		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8192E******\n",__FUNCTION__,__LINE__);	*/
-		pdesc->Dword6 &= set_desc(~(BIT(18)|BIT(17)|BIT(16)));	
-		pdesc->Dword6 |= set_desc(pDM_FatTable->antsel_a[aid]<<16);
-	} else if (SupportICType == ODM_RTL8188E) {
-		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8188E******\n",__FUNCTION__,__LINE__);*/
-		pdesc->Dword2 &= set_desc(~BIT(24));
-		pdesc->Dword2 &= set_desc(~BIT(25));
-		pdesc->Dword7 &= set_desc(~BIT(29));
-
-		pdesc->Dword2 |= set_desc(pDM_FatTable->antsel_a[aid]<<24);
-		pdesc->Dword2 |= set_desc(pDM_FatTable->antsel_b[aid]<<25);
-		pdesc->Dword7 |= set_desc(pDM_FatTable->antsel_c[aid]<<29);
-			
-		
-	} else if (SupportICType == ODM_RTL8812) {
-		/*[path-A]*/
-		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);*/
-			
-		pdesc->Dword6 &= set_desc(~BIT(16));
-		pdesc->Dword6 &= set_desc(~BIT(17));
-		pdesc->Dword6 &= set_desc(~BIT(18));
-
-		pdesc->Dword6 |= set_desc(pDM_FatTable->antsel_a[aid]<<16);
-		pdesc->Dword6 |= set_desc(pDM_FatTable->antsel_b[aid]<<17);
-		pdesc->Dword6 |= set_desc(pDM_FatTable->antsel_c[aid]<<18);
-			
-	}
-}
-#endif
-
-
-VOID
-ODM_AntDiv_Config(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("WIN Config Antenna Diversity\n"));
-		if(pDM_Odm->SupportICType==ODM_RTL8723B)
-		{
-			if((!pDM_Odm->DM_SWAT_Table.ANTA_ON || !pDM_Odm->DM_SWAT_Table.ANTB_ON))
-				pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-		}
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("CE Config Antenna Diversity\n"));
-		if(pDM_Odm->SupportICType & ODM_ANTDIV_SUPPORT)
-		{
-			pDM_Odm->SupportAbility |= ODM_BB_ANT_DIV;	
-		}
-		
-		if(pDM_Odm->SupportICType==ODM_RTL8723B)
-		{
-			pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-		}				
-
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("AP Config Antenna Diversity\n"));
-
-	//2 [ NOT_SUPPORT_ANTDIV ]
-	#if(defined(CONFIG_NOT_SUPPORT_ANTDIV)) 
-		pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Disable AntDiv function] : Not Support 2.4G & 5G Antenna Diversity\n"));
-		
-		//2 [ 2G&5G_SUPPORT_ANTDIV ]
-	#elif(defined(CONFIG_2G5G_SUPPORT_ANTDIV))
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Enable AntDiv function] : 2.4G & 5G Support Antenna Diversity Simultaneously \n"));
-		pDM_FatTable->AntDiv_2G_5G = (ODM_ANTDIV_2G|ODM_ANTDIV_5G);
-
-		if(pDM_Odm->SupportICType & ODM_ANTDIV_SUPPORT)
-			pDM_Odm->SupportAbility |= ODM_BB_ANT_DIV;
-		if(*pDM_Odm->pBandType == ODM_BAND_5G )
-		{
-				#if ( defined(CONFIG_5G_CGCS_RX_DIVERSITY) )
-					pDM_Odm->AntDivType = CGCS_RX_HW_ANTDIV; 
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = CGCS_RX_HW_ANTDIV\n"));
-					panic_printk("[ 5G] : AntDiv Type = CGCS_RX_HW_ANTDIV\n");
-				#elif( defined(CONFIG_5G_CG_TRX_DIVERSITY)||defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
-					pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = CG_TRX_HW_ANTDIV\n"));				
-					panic_printk("[ 5G] : AntDiv Type = CG_TRX_HW_ANTDIV\n");
-				#elif( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) )
-					pDM_Odm->AntDivType = CG_TRX_SMART_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = CG_SMART_ANTDIV\n"));
-				#elif( defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY) )
-					pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = S0S1_SW_ANTDIV\n"));
-				#endif
-		}		
-		else if(*pDM_Odm->pBandType == ODM_BAND_2_4G )
-		 {
-				#if ( defined(CONFIG_2G_CGCS_RX_DIVERSITY) )
-						pDM_Odm->AntDivType = CGCS_RX_HW_ANTDIV;
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = CGCS_RX_HW_ANTDIV\n"));		
-				#elif( defined(CONFIG_2G_CG_TRX_DIVERSITY) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
-						pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = CG_TRX_HW_ANTDIV\n"));
-				#elif( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-						pDM_Odm->AntDivType = CG_TRX_SMART_ANTDIV;
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = CG_SMART_ANTDIV\n"));
-				#elif( defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY) )
-					pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = S0S1_SW_ANTDIV\n"));
-				#endif
-		}
-		
-		//2 [ 5G_SUPPORT_ANTDIV ]
-	#elif(defined(CONFIG_5G_SUPPORT_ANTDIV))
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n"));
-		panic_printk("[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n");
-		pDM_FatTable->AntDiv_2G_5G = (ODM_ANTDIV_5G);
-		if(*pDM_Odm->pBandType == ODM_BAND_5G )
-		{
-				if(pDM_Odm->SupportICType & ODM_ANTDIV_5G_SUPPORT_IC)
-				pDM_Odm->SupportAbility |= ODM_BB_ANT_DIV;	
-				#if ( defined(CONFIG_5G_CGCS_RX_DIVERSITY) )
-					pDM_Odm->AntDivType = CGCS_RX_HW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = CGCS_RX_HW_ANTDIV\n"));
-					panic_printk("[ 5G] : AntDiv Type = CGCS_RX_HW_ANTDIV\n");
-				#elif( defined(CONFIG_5G_CG_TRX_DIVERSITY) )
-					pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-					panic_printk("[ 5G] : AntDiv Type = CG_TRX_HW_ANTDIV\n");
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = CG_TRX_HW_ANTDIV\n"));
-				#elif( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) )
-					pDM_Odm->AntDivType = CG_TRX_SMART_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = CG_SMART_ANTDIV\n"));
-				#elif( defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY) )
-					pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 5G] : AntDiv Type = S0S1_SW_ANTDIV\n"));
-				#endif
-		}
-		else if(*pDM_Odm->pBandType == ODM_BAND_2_4G )
-		{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("Not Support 2G AntDivType\n"));
-				pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-		}
-		
-		//2 [ 2G_SUPPORT_ANTDIV ]
-	#elif(defined(CONFIG_2G_SUPPORT_ANTDIV)) 
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ Enable AntDiv function] : Only 2.4G Support Antenna Diversity\n"));
-		pDM_FatTable->AntDiv_2G_5G = (ODM_ANTDIV_2G);
-		if(*pDM_Odm->pBandType == ODM_BAND_2_4G )
-		{
-				if(pDM_Odm->SupportICType & ODM_ANTDIV_2G_SUPPORT_IC)
-					pDM_Odm->SupportAbility |= ODM_BB_ANT_DIV;
-				#if ( defined(CONFIG_2G_CGCS_RX_DIVERSITY) )
-					pDM_Odm->AntDivType = CGCS_RX_HW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = CGCS_RX_HW_ANTDIV\n"));		
-				#elif( defined(CONFIG_2G_CG_TRX_DIVERSITY) )
-					pDM_Odm->AntDivType = CG_TRX_HW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = CG_TRX_HW_ANTDIV\n"));
-				#elif( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-					pDM_Odm->AntDivType = CG_TRX_SMART_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = CG_SMART_ANTDIV\n"));
-				#elif( defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY) )
-					pDM_Odm->AntDivType = S0S1_SW_ANTDIV;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("[ 2.4G] : AntDiv Type = S0S1_SW_ANTDIV\n"));
-				#endif
-		}
-		else if(*pDM_Odm->pBandType == ODM_BAND_5G )
-		{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD,("Not Support 5G AntDivType\n"));
-				pDM_Odm->SupportAbility &= ~(ODM_BB_ANT_DIV);
-		}
-	#endif	
-#endif	
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("SupportAbility = (( %x ))\n", pDM_Odm->SupportAbility ));
-
-}
-
-
-VOID
-ODM_AntDivTimers(
-	IN		PVOID		pDM_VOID,	
-	IN 		u1Byte		state
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if(state==INIT_ANTDIV_TIMMER)
-	{
-		#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-			ODM_InitializeTimer(pDM_Odm, &(pDM_Odm->DM_SWAT_Table.phydm_SwAntennaSwitchTimer),
-			(RT_TIMER_CALL_BACK)ODM_SW_AntDiv_Callback, NULL, "phydm_SwAntennaSwitchTimer");
-		#elif ( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-			ODM_InitializeTimer(pDM_Odm,&pDM_Odm->FastAntTrainingTimer,
-			(RT_TIMER_CALL_BACK)odm_FastAntTrainingCallback, NULL, "FastAntTrainingTimer");
-		#endif
-
-		#ifdef ODM_EVM_ENHANCE_ANTDIV
-			ODM_InitializeTimer(pDM_Odm,&pDM_Odm->EVM_FastAntTrainingTimer,
-			(RT_TIMER_CALL_BACK)odm_EVM_FastAntTrainingCallback, NULL, "EVM_FastAntTrainingTimer");
-		#endif
-	}
-	else if(state==CANCEL_ANTDIV_TIMMER)
-	{
-		#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-			ODM_CancelTimer(pDM_Odm, &(pDM_Odm->DM_SWAT_Table.phydm_SwAntennaSwitchTimer));
-		#elif ( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-			ODM_CancelTimer(pDM_Odm,&pDM_Odm->FastAntTrainingTimer);
-		#endif
-
-		#ifdef ODM_EVM_ENHANCE_ANTDIV
-			ODM_CancelTimer(pDM_Odm,&pDM_Odm->EVM_FastAntTrainingTimer);
-		#endif
-	}
-	else if(state==RELEASE_ANTDIV_TIMMER)
-	{
-		#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-			ODM_ReleaseTimer(pDM_Odm, &(pDM_Odm->DM_SWAT_Table.phydm_SwAntennaSwitchTimer));
-		#elif ( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-			ODM_ReleaseTimer(pDM_Odm,&pDM_Odm->FastAntTrainingTimer);
-		#endif
-
-		#ifdef ODM_EVM_ENHANCE_ANTDIV
-			ODM_ReleaseTimer(pDM_Odm,&pDM_Odm->EVM_FastAntTrainingTimer);
-		#endif
-	}
-
-}
-
-#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
-
-VOID
-ODM_AntDivReset(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->AntDivType == S0S1_SW_ANTDIV)
-	{
-		#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		odm_S0S1_SWAntDiv_Reset(pDM_Odm);
-		#endif
-	}
-
-}
-
-VOID
-odm_AntennaDiversityInit(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if(pDM_Odm->mp_mode == TRUE)
-		return;
-	
-	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-		ODM_AntDiv_Config(pDM_Odm);
-		ODM_AntDivInit(pDM_Odm);
-	#endif
-}
-
-VOID
-odm_AntennaDiversity(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if(pDM_Odm->mp_mode == TRUE)
-		return;
-
-	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-		ODM_AntDiv(pDM_Odm);
-	#endif
-}
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ******************************************************
+ * when antenna test utility is on or some testing need to disable antenna diversity
+ * call this function to disable all ODM related mechanisms which will switch antenna.
+ * ****************************************************** */
+void
+odm_stop_antenna_switch_dm(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	/* disable ODM antenna diversity */
+	dm->support_ability &= ~ODM_BB_ANT_DIV;
+	odm_ant_div_on_off(dm, ANTDIV_OFF);
+	odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "STOP Antenna Diversity\n");
+}
+
+void
+phydm_enable_antenna_diversity(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	dm->support_ability |= ODM_BB_ANT_DIV;
+	dm->antdiv_select = 0;
+	PHYDM_DBG(dm, DBG_ANT_DIV, "AntDiv is enabled & Re-Init AntDiv\n");
+	odm_antenna_diversity_init(dm);
+}
+
+void
+odm_set_ant_config(
+	void	*dm_void,
+	u8		ant_setting	/* 0=A, 1=B, 2=C, .... */
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (ant_setting == 0)		/* ant A*/
+			odm_set_bb_reg(dm, 0x948, MASKDWORD, 0x00000000);
+		else if (ant_setting == 1)
+			odm_set_bb_reg(dm, 0x948, MASKDWORD, 0x00000280);
+	} else if (dm->support_ic_type == ODM_RTL8723D) {
+		if (ant_setting == 0)		/* ant A*/
+			odm_set_bb_reg(dm, 0x948, MASKLWORD, 0x0000);
+		else if (ant_setting == 1)
+			odm_set_bb_reg(dm, 0x948, MASKLWORD, 0x0280);
+	}
+}
+
+/* ****************************************************** */
+
+
+void
+odm_sw_ant_div_rest_after_link(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	u32	i;
+
+	if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+		dm_swat_table->try_flag = SWAW_STEP_INIT;
+		dm_swat_table->rssi_trying = 0;
+		dm_swat_table->double_chk_flag = 0;
+		fat_tab->rx_idle_ant = MAIN_ANT;
+
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
+			phydm_antdiv_reset_statistic(dm, i);
+	}
+	
+#endif	
+}
+
+void
+odm_ant_div_on_off(
+	void		*dm_void,
+	u8		swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	if (fat_tab->ant_div_on_off != swch) {
+		if (dm->ant_div_type == S0S1_SW_ANTDIV)
+			return;
+
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) N-Series HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+			odm_set_bb_reg(dm, 0xc50, BIT(7), swch);
+			odm_set_bb_reg(dm, 0xa00, BIT(15), swch);
+
+#if (RTL8723D_SUPPORT == 1)
+			/*Mingzhi 2017-05-08*/
+			if (dm->support_ic_type == ODM_RTL8723D) {
+				if (swch == ANTDIV_ON) {
+					odm_set_bb_reg(dm, 0xce0, BIT(1), 1);
+					odm_set_bb_reg(dm, 0x948, BIT(6), 1);          /*1:HW ctrl  0:SW ctrl*/
+					}
+				else{
+					odm_set_bb_reg(dm, 0xce0, BIT(1), 0);
+					odm_set_bb_reg(dm, 0x948, BIT(6), 0);          /*1:HW ctrl  0:SW ctrl*/
+				}
+			}			
+#endif
+
+		} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) AC-Series HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+			if (dm->support_ic_type & ODM_RTL8812) {
+				odm_set_bb_reg(dm, 0xc50, BIT(7), swch); /* OFDM AntDiv function block enable */
+				odm_set_bb_reg(dm, 0xa00, BIT(15), swch); /* CCK AntDiv function block enable */
+			} else {
+				odm_set_bb_reg(dm, 0x8D4, BIT(24), swch); /* OFDM AntDiv function block enable */
+
+				if ((dm->cut_version >= ODM_CUT_C) && (dm->support_ic_type == ODM_RTL8821) && (dm->ant_div_type != S0S1_SW_ANTDIV)) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) CCK HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+					odm_set_bb_reg(dm, 0x800, BIT(25), swch);
+					odm_set_bb_reg(dm, 0xA00, BIT(15), swch); /* CCK AntDiv function block enable */
+				} else if (dm->support_ic_type == ODM_RTL8821C) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "(( Turn %s )) CCK HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF");
+					odm_set_bb_reg(dm, 0x800, BIT(25), swch);
+					odm_set_bb_reg(dm, 0xA00, BIT(15), swch); /* CCK AntDiv function block enable */
+				}
+			}
+		}
+	}
+	fat_tab->ant_div_on_off = swch;
+
+}
+
+void
+odm_tx_by_tx_desc_or_reg(
+	void		*dm_void,
+	u8			swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u8 enable;
+
+	if (fat_tab->b_fix_tx_ant == NO_FIX_TX_ANT)
+		enable = (swch == TX_BY_DESC) ? 1 : 0;
+	else
+		enable = 0;/*Force TX by Reg*/
+
+	if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT)
+			odm_set_bb_reg(dm, 0x80c, BIT(21), enable);
+		else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT)
+			odm_set_bb_reg(dm, 0x900, BIT(18), enable);
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv] TX_Ant_BY (( %s ))\n", (enable == TX_BY_DESC) ? "DESC" : "REG");
+	}
+}
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+void
+phydm_antdiv_reset_statistic(
+	void	*dm_void,
+	u32	macid
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	fat_tab->main_ant_sum[macid] = 0;
+	fat_tab->aux_ant_sum[macid] = 0;
+	fat_tab->main_ant_cnt[macid] = 0;
+	fat_tab->aux_ant_cnt[macid] = 0;
+	fat_tab->main_ant_sum_cck[macid] = 0;
+	fat_tab->aux_ant_sum_cck[macid] = 0;
+	fat_tab->main_ant_cnt_cck[macid] = 0;
+	fat_tab->aux_ant_cnt_cck[macid] = 0;
+}
+
+void
+phydm_fast_training_enable(
+	void		*dm_void,
+	u8			swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			enable;
+
+	if (swch == FAT_ON)
+		enable = 1;
+	else
+		enable = 0;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Fast ant Training_en = ((%d))\n", enable);
+
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		odm_set_bb_reg(dm, 0xe08, BIT(16), enable);	/*enable fast training*/
+		/**/
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, 0xB34, BIT(28), enable);	/*enable fast training (path-A)*/
+		/*odm_set_bb_reg(dm, 0xB34, BIT(29), enable);*/	/*enable fast training (path-B)*/
+	} else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8822B)) {
+		odm_set_bb_reg(dm, 0x900, BIT(19), enable);	/*enable fast training */
+		/**/
+	}
+}
+
+void
+phydm_keep_rx_ack_ant_by_tx_ant_time(
+	void		*dm_void,
+	u32		time
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	/* Timming issue: keep Rx ant after tx for ACK ( time x 3.2 mu sec)*/
+	if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+		odm_set_bb_reg(dm, 0xE20, BIT(23) | BIT(22) | BIT(21) | BIT(20), time);
+		/**/
+	} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+		odm_set_bb_reg(dm, 0x818, BIT(23) | BIT(22) | BIT(21) | BIT(20), time);
+		/**/
+	}
+}
+
+void
+odm_update_rx_idle_ant(
+	void		*dm_void,
+	u8		ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	u32			default_ant, optional_ant, value32, default_tx_ant;
+
+	if (fat_tab->rx_idle_ant != ant) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] rx_idle_ant =%s\n", (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+		if (!(dm->support_ic_type & ODM_RTL8723B))
+			fat_tab->rx_idle_ant = ant;
+
+		if (ant == MAIN_ANT) {
+			default_ant   =  ANT1_2G;
+			optional_ant =  ANT2_2G;
+		} else {
+			default_ant  =   ANT2_2G;
+			optional_ant =  ANT1_2G;
+		}
+
+		if (fat_tab->b_fix_tx_ant != NO_FIX_TX_ANT)
+			default_tx_ant = (fat_tab->b_fix_tx_ant == FIX_TX_AT_MAIN) ? 0 : 1;
+		else
+			default_tx_ant = default_ant;
+
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+			if (dm->support_ic_type == ODM_RTL8192E) {
+				odm_set_bb_reg(dm, 0xB38, BIT(5) | BIT(4) | BIT(3), default_ant); /* Default RX */
+				odm_set_bb_reg(dm, 0xB38, BIT(8) | BIT(7) | BIT(6), optional_ant); /* Optional RX */
+				odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant); /* Default TX */
+			}
+#if (RTL8723B_SUPPORT == 1)
+			else if (dm->support_ic_type == ODM_RTL8723B) {
+				value32 = odm_get_bb_reg(dm, 0x948, 0xFFF);
+
+				if (value32 != 0x280)
+					odm_update_rx_idle_ant_8723b(dm, ant, default_ant, optional_ant);
+				else
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to 0x948 = 0x280\n");
+			}
+#endif
+
+#if (RTL8723D_SUPPORT == 1)         /*Mingzhi 2017-05-08*/
+			else if (dm->support_ic_type == ODM_RTL8723D) {
+					phydm_set_tx_ant_pwr_8723d(dm, ant);
+					odm_update_rx_idle_ant_8723d(dm, ant, default_ant, optional_ant);
+
+			}
+#endif
+
+			else { /*8188E & 8188F*/
+/*
+				if (dm->support_ic_type == ODM_RTL8723D) {
+#if (RTL8723D_SUPPORT == 1)
+					phydm_set_tx_ant_pwr_8723d(dm, ant);
+#endif
+				}
+*/
+#if (RTL8188F_SUPPORT == 1)
+				if (dm->support_ic_type == ODM_RTL8188F) {
+					phydm_update_rx_idle_antenna_8188F(dm, default_ant);
+					/**/
+				}
+#endif
+
+				odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);		/*Default RX*/
+				odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);	/*Optional RX*/
+				odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_tx_ant);	/*Default TX*/
+			}
+		} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+			u16	value16 = odm_read_2byte(dm, ODM_REG_TRMUX_11AC + 2);
+			/*  */
+			/* 2014/01/14 MH/Luke.Lee Add direct write for register 0xc0a to prevnt */
+			/* incorrect 0xc08 bit0-15 .We still not know why it is changed. */
+			/*  */
+			value16 &= ~(BIT(11) | BIT(10) | BIT(9) | BIT(8) | BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3));
+			value16 |= ((u16)default_ant << 3);
+			value16 |= ((u16)optional_ant << 6);
+			value16 |= ((u16)default_ant << 9);
+			odm_write_2byte(dm, ODM_REG_TRMUX_11AC + 2, value16);
+#if 0
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(21) | BIT20 | BIT19, default_ant);	 /* Default RX */
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(24) | BIT23 | BIT22, optional_ant); /* Optional RX */
+			odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, BIT(27) | BIT26 | BIT25, default_ant);	 /* Default TX */
+#endif
+		}
+
+		if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A)) {
+			odm_set_mac_reg(dm, 0x6D8, 0x7, default_tx_ant);		/*PathA Resp Tx*/
+			/**/
+		} else if (dm->support_ic_type == ODM_RTL8188E) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(7) | BIT(6), default_tx_ant);		/*PathA Resp Tx*/
+			/**/
+		} else {
+			odm_set_mac_reg(dm, 0x6D8, BIT(10) | BIT(9) | BIT(8), default_tx_ant);	/*PathA Resp Tx*/
+			/**/
+		}
+
+	} else { /* fat_tab->rx_idle_ant == ant */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Stay in Ori-ant ]  rx_idle_ant =%s\n", (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+		fat_tab->rx_idle_ant = ant;
+	}
+}
+
+void
+phydm_set_antdiv_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (val_len != 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][antdiv]Need val_len=1\n");
+		return;
+	}
+	
+	odm_update_rx_idle_ant(dm, (u8)(*val_buf));
+}
+
+void
+odm_update_tx_ant(
+	void		*dm_void,
+	u8		ant,
+	u32		mac_id
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u8	tx_ant;
+
+	if (fat_tab->b_fix_tx_ant != NO_FIX_TX_ANT)
+		ant = (fat_tab->b_fix_tx_ant == FIX_TX_AT_MAIN) ? MAIN_ANT : AUX_ANT;
+
+	if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+		tx_ant = ant;
+	else {
+		if (ant == MAIN_ANT)
+			tx_ant = ANT1_2G;
+		else
+			tx_ant = ANT2_2G;
+	}
+
+	fat_tab->antsel_a[mac_id] = tx_ant & BIT(0);
+	fat_tab->antsel_b[mac_id] = (tx_ant & BIT(1)) >> 1;
+	fat_tab->antsel_c[mac_id] = (tx_ant & BIT(2)) >> 2;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[Set TX-DESC value]: mac_id:(( %d )),  tx_ant = (( %s ))\n", mac_id, (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+	/* PHYDM_DBG(dm,DBG_ANT_DIV,"antsel_tr_mux=(( 3'b%d%d%d ))\n",fat_tab->antsel_c[mac_id] , fat_tab->antsel_b[mac_id] , fat_tab->antsel_a[mac_id] ); */
+
+}
+
+#ifdef BEAMFORMING_SUPPORT
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_bdc_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n[ BDC Initialization......]\n");
+	dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+	dm_bdc_table->bdc_mode = BDC_MODE_NULL;
+	dm_bdc_table->bdc_try_flag = 0;
+	dm_bdc_table->bd_ccoex_type_wbfer = 0;
+	dm->bdc_holdstate = 0xff;
+
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, 0xd7c, 0x0FFFFFFF, 0x1081008);
+		odm_set_bb_reg(dm, 0xd80, 0x0FFFFFFF, 0);
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		odm_set_bb_reg(dm, 0x9b0, 0x0FFFFFFF, 0x1081008);     /* 0x9b0[30:0] = 01081008 */
+		odm_set_bb_reg(dm, 0x9b4, 0x0FFFFFFF, 0);                 /* 0x9b4[31:0] = 00000000 */
+	}
+
+}
+
+
+void
+odm_CSI_on_off(
+	void		*dm_void,
+	u8			CSI_en
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (CSI_en == CSI_ON) {
+		if (dm->support_ic_type == ODM_RTL8192E)
+			odm_set_mac_reg(dm, 0xd84, BIT(11), 1);  /* 0xd84[11]=1 */
+		else if (dm->support_ic_type == ODM_RTL8812)
+			odm_set_mac_reg(dm, 0x9b0, BIT(31), 1);  /* 0x9b0[31]=1 */
+
+	} else if (CSI_en == CSI_OFF) {
+		if (dm->support_ic_type == ODM_RTL8192E)
+			odm_set_mac_reg(dm, 0xd84, BIT(11), 0);  /* 0xd84[11]=0 */
+		else if (dm->support_ic_type == ODM_RTL8812)
+			odm_set_mac_reg(dm, 0x9b0, BIT(31), 0);  /* 0x9b0[31]=0 */
+	}
+}
+
+void
+odm_bd_ccoex_type_with_bfer_client(
+	void		*dm_void,
+	u8			swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+	u8     bd_ccoex_type_wbfer;
+
+	if (swch == DIVON_CSIOFF) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[BDCcoexType: 1] {DIV,CSI} ={1,0}\n");
+		bd_ccoex_type_wbfer = 1;
+
+		if (bd_ccoex_type_wbfer != dm_bdc_table->bd_ccoex_type_wbfer) {
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+			odm_CSI_on_off(dm, CSI_OFF);
+			dm_bdc_table->bd_ccoex_type_wbfer = 1;
+		}
+	} else if (swch == DIVOFF_CSION) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[BDCcoexType: 2] {DIV,CSI} ={0,1}\n");
+		bd_ccoex_type_wbfer = 2;
+
+		if (bd_ccoex_type_wbfer != dm_bdc_table->bd_ccoex_type_wbfer) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_CSI_on_off(dm, CSI_ON);
+			dm_bdc_table->bd_ccoex_type_wbfer = 2;
+		}
+	}
+}
+
+void
+odm_bf_ant_div_mode_arbitration(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_			*dm_bdc_table = &dm->dm_bdc_table;
+	u8			current_bdc_mode;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n");
+
+	/* 2 mode 1 */
+	if ((dm_bdc_table->num_txbfee_client != 0) && (dm_bdc_table->num_txbfer_client == 0)) {
+		current_bdc_mode = BDC_MODE_1;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_1;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			dm_bdc_table->bdc_rx_idle_update_counter = 1;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode1 ))\n");
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode1 ))\n");
+	}
+	/* 2 mode 2 */
+	else if ((dm_bdc_table->num_txbfee_client == 0) && (dm_bdc_table->num_txbfer_client != 0)) {
+		current_bdc_mode = BDC_MODE_2;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_2;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			dm_bdc_table->bdc_try_flag = 0;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode2 ))\n");
+
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode2 ))\n");
+	}
+	/* 2 mode 3 */
+	else if ((dm_bdc_table->num_txbfee_client != 0) && (dm_bdc_table->num_txbfer_client != 0)) {
+		current_bdc_mode = BDC_MODE_3;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_3;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->bdc_rx_idle_update_counter = 1;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode3 ))\n");
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode3 ))\n");
+	}
+	/* 2 mode 4 */
+	else if ((dm_bdc_table->num_txbfee_client == 0) && (dm_bdc_table->num_txbfer_client == 0)) {
+		current_bdc_mode = BDC_MODE_4;
+
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_4;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode4 ))\n");
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Antdiv + BF coextance mode] : (( Mode4 ))\n");
+	}
+#endif
+
+}
+
+void
+odm_div_train_state_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n*****[S T A R T ]*****  [2-0. DIV_TRAIN_STATE]\n");
+	dm_bdc_table->bdc_try_counter = 2;
+	dm_bdc_table->bdc_try_flag = 1;
+	dm_bdc_table->BDC_state = bdc_bfer_train_state;
+	odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+}
+
+void
+odm_bd_ccoex_bfee_rx_div_arbitration(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_    *dm_bdc_table = &dm->dm_bdc_table;
+	boolean stop_bf_flag;
+	u8	bdc_active_mode;
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***{ num_BFee,  num_BFer, num_client}  = (( %d  ,  %d  ,  %d))\n", dm_bdc_table->num_txbfee_client, dm_bdc_table->num_txbfer_client, dm_bdc_table->num_client);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***{ num_BF_tars,  num_DIV_tars }  = ((  %d  ,  %d ))\n", dm_bdc_table->num_bf_tar, dm_bdc_table->num_div_tar);
+
+	/* 2 [ MIB control ] */
+	if (dm->bdc_holdstate == 2) {
+		odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+		dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ BF STATE]\n");
+		return;
+	} else if (dm->bdc_holdstate == 1) {
+		dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+		odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ DIV STATE]\n");
+		return;
+	}
+
+	/* ------------------------------------------------------------ */
+
+
+
+	/* 2 mode 2 & 3 */
+	if (dm_bdc_table->bdc_mode == BDC_MODE_2 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n{ Try_flag,  Try_counter } = {  %d , %d  }\n", dm_bdc_table->bdc_try_flag, dm_bdc_table->bdc_try_counter);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "BDCcoexType = (( %d ))\n\n", dm_bdc_table->bd_ccoex_type_wbfer);
+
+		/* All Client have Bfer-Cap------------------------------- */
+		if (dm_bdc_table->num_txbfer_client == dm_bdc_table->num_client) { /* BFer STA Only?: yes */
+			PHYDM_DBG(dm, DBG_ANT_DIV, "BFer STA only?  (( Yes ))\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+			return;
+		} else
+			PHYDM_DBG(dm, DBG_ANT_DIV, "BFer STA only?  (( No ))\n");
+		/*  */
+		if (dm_bdc_table->is_all_bf_sta_idle == false && dm_bdc_table->is_all_div_sta_idle == true) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "All DIV-STA are idle, but BF-STA not\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = bdc_bfer_train_state;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+			return;
+		} else if (dm_bdc_table->is_all_bf_sta_idle == true && dm_bdc_table->is_all_div_sta_idle == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "All BF-STA are idle, but DIV-STA not\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			return;
+		}
+
+		/* Select active mode-------------------------------------- */
+		if (dm_bdc_table->num_bf_tar == 0) { /* Selsect_1,  Selsect_2 */
+			if (dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode (( 1 ))\n");
+				dm_bdc_table->bdc_active_mode = 1;
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode  (( 2 ))\n");
+				dm_bdc_table->bdc_active_mode = 2;
+			}
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			return;
+		} else { /* num_bf_tar > 0 */
+			if (dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode (( 3 ))\n");
+				dm_bdc_table->bdc_active_mode = 3;
+				dm_bdc_table->bdc_try_flag = 0;
+				dm_bdc_table->BDC_state = bdc_bfer_train_state;
+				odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+				return;
+			} else { /* Selsect_4 */
+				bdc_active_mode = 4;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Select active mode (( 4 ))\n");
+
+				if (bdc_active_mode != dm_bdc_table->bdc_active_mode) {
+					dm_bdc_table->bdc_active_mode = 4;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "Change to active mode (( 4 ))  &  return!!!\n");
+					return;
+				}
+			}
+		}
+
+#if 1
+		if (dm->bdc_holdstate == 0xff) {
+			dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ DIV STATE]\n");
+			return;
+		}
+#endif
+
+		/* Does Client number changed ? ------------------------------- */
+		if (dm_bdc_table->num_client != dm_bdc_table->pre_num_client) {
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[  The number of client has been changed !!!]   return to (( BDC_DIV_TRAIN_STATE ))\n");
+		}
+		dm_bdc_table->pre_num_client = dm_bdc_table->num_client;
+
+		if (dm_bdc_table->bdc_try_flag == 0) {
+			/* 2 DIV_TRAIN_STATE (mode 2-0) */
+			if (dm_bdc_table->BDC_state == BDC_DIV_TRAIN_STATE)
+				odm_div_train_state_setting(dm);
+			/* 2 BFer_TRAIN_STATE (mode 2-1) */
+			else if (dm_bdc_table->BDC_state == bdc_bfer_train_state) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-1. BFer_TRAIN_STATE ]*****\n");
+
+				/* if(dm_bdc_table->num_bf_tar==0) */
+				/* { */
+				/*	PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( No )),   [ bdc_bfer_train_state ] >> [BDC_DIV_TRAIN_STATE]\n"); */
+				/*	odm_div_train_state_setting( dm); */
+				/* } */
+				/* else */ /* num_bf_tar != 0 */
+				/* { */
+				dm_bdc_table->bdc_try_counter = 2;
+				dm_bdc_table->bdc_try_flag = 1;
+				dm_bdc_table->BDC_state = BDC_DECISION_STATE;
+				odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+				PHYDM_DBG(dm, DBG_ANT_DIV, "BF_tars exist?  : (( Yes )),   [ bdc_bfer_train_state ] >> [BDC_DECISION_STATE]\n");
+				/* } */
+			}
+			/* 2 DECISION_STATE (mode 2-2) */
+			else if (dm_bdc_table->BDC_state == BDC_DECISION_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-2. DECISION_STATE]*****\n");
+				/* if(dm_bdc_table->num_bf_tar==0) */
+				/* { */
+				/*	ODM_AntDiv_Printk(("BF_tars exist?  : (( No )),   [ DECISION_STATE ] >> [BDC_DIV_TRAIN_STATE]\n")); */
+				/*	odm_div_train_state_setting( dm); */
+				/* } */
+				/* else */ /* num_bf_tar != 0 */
+				/* { */
+				if (dm_bdc_table->BF_pass == false || dm_bdc_table->DIV_pass == false)
+					stop_bf_flag = true;
+				else
+					stop_bf_flag = false;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "BF_tars exist?  : (( Yes )),  {BF_pass, DIV_pass, stop_bf_flag }  = { %d, %d, %d }\n", dm_bdc_table->BF_pass, dm_bdc_table->DIV_pass, stop_bf_flag);
+
+				if (stop_bf_flag == true) { /* DIV_en */
+					dm_bdc_table->bdc_hold_counter = 10; /* 20 */
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+					dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ stop_bf_flag= ((true)),   BDC_DECISION_STATE ] >> [BDC_DIV_HOLD_STATE]\n");
+				} else { /* BF_en */
+					dm_bdc_table->bdc_hold_counter = 10; /* 20 */
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+					dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[stop_bf_flag= ((false)),   BDC_DECISION_STATE ] >> [BDC_BF_HOLD_STATE]\n");
+				}
+				/* } */
+			}
+			/* 2 BF-HOLD_STATE (mode 2-3) */
+			else if (dm_bdc_table->BDC_state == BDC_BF_HOLD_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-3. BF_HOLD_STATE ]*****\n");
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "bdc_hold_counter = (( %d ))\n", dm_bdc_table->bdc_hold_counter);
+
+				if (dm_bdc_table->bdc_hold_counter == 1) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n");
+					odm_div_train_state_setting(dm);
+				} else {
+					dm_bdc_table->bdc_hold_counter--;
+
+					/* if(dm_bdc_table->num_bf_tar==0) */
+					/* { */
+					/*	PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( No )),   [ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n"); */
+					/*	odm_div_train_state_setting( dm); */
+					/* } */
+					/* else */ /* num_bf_tar != 0 */
+					/* { */
+					/* PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( Yes ))\n"); */
+					dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_BF_HOLD_STATE ] >> [BDC_BF_HOLD_STATE]\n");
+					/* } */
+				}
+
+			}
+			/* 2 DIV-HOLD_STATE (mode 2-4) */
+			else if (dm_bdc_table->BDC_state == BDC_DIV_HOLD_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*****[2-4. DIV_HOLD_STATE ]*****\n");
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "bdc_hold_counter = (( %d ))\n", dm_bdc_table->bdc_hold_counter);
+
+				if (dm_bdc_table->bdc_hold_counter == 1) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n");
+					odm_div_train_state_setting(dm);
+				} else {
+					dm_bdc_table->bdc_hold_counter--;
+					dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_HOLD_STATE]\n");
+				}
+
+			}
+
+		} else if (dm_bdc_table->bdc_try_flag == 1) {
+			/* 2 Set Training counter */
+			if (dm_bdc_table->bdc_try_counter > 1) {
+				dm_bdc_table->bdc_try_counter--;
+				if (dm_bdc_table->bdc_try_counter == 1)
+					dm_bdc_table->bdc_try_flag = 0;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Training !!\n");
+				/* return ; */
+			}
+
+		}
+
+	}
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n[end]\n");
+
+#endif /* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+
+
+
+
+
+
+}
+
+#endif
+#endif /* #ifdef BEAMFORMING_SUPPORT */
+
+
+#if (RTL8188E_SUPPORT == 1)
+
+
+void
+odm_rx_hw_ant_div_init_88e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	value32;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_set_bb_reg(dm, ODM_REG_IGI_A_11N, BIT(7), 0); /* disable HW AntDiv */
+		odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);  /* 1:CG, 0:CS */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188E AntDiv_Init =>  ant_div_type=[CGCS_RX_HW_ANTDIV]\n");
+
+	/* MAC setting */
+	value32 = odm_get_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
+	odm_set_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	/* Pin Settings */
+	odm_set_bb_reg(dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 1);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);	/* regb2c[31]=1'b1	 */ /* output at CG only */
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
+	/* CCK Settings */
+	odm_set_bb_reg(dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+	odm_set_bb_reg(dm, ODM_REG_ANT_MAPPING1_11N, 0xFFFF, 0x0001);	/* antenna mapping table */
+
+	fat_tab->enable_ctrl_frame_antdiv = 1;
+}
+
+void
+odm_trx_hw_ant_div_init_88e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	value32;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_set_bb_reg(dm, ODM_REG_IGI_A_11N, BIT(7), 0); /* disable HW AntDiv */
+		odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(5) | BIT4 | BIT3, 0); /* Default RX   (0/1) */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188E AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV (SPDT)]\n");
+
+	/* MAC setting */
+	value32 = odm_get_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
+	odm_set_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	/* Pin Settings */
+	odm_set_bb_reg(dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 0);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);	/* regb2c[31]=1'b1	 */ /* output at CG only */
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
+	/* CCK Settings */
+	odm_set_bb_reg(dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+	/* antenna mapping table */
+	if (!dm->is_mp_chip) { /* testchip */
+		odm_set_bb_reg(dm, ODM_REG_RX_DEFAULT_A_11N, BIT(10) | BIT(9) | BIT(8), 1);	/* Reg858[10:8]=3'b001 */
+		odm_set_bb_reg(dm, ODM_REG_RX_DEFAULT_A_11N, BIT(13) | BIT(12) | BIT(11), 2);	/* Reg858[13:11]=3'b010 */
+	} else /* MPchip */
+		odm_set_bb_reg(dm, ODM_REG_ANT_MAPPING1_11N, MASKDWORD, 0x0201);	/*Reg914=3'b010, Reg915=3'b001*/
+
+	fat_tab->enable_ctrl_frame_antdiv = 1;
+}
+
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+void
+odm_smart_hw_ant_div_init_88e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	value32, i;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n");
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "dm->ant_div_type: %d\n", dm->ant_div_type);
+		return;
+	}
+#endif
+
+	fat_tab->train_idx = 0;
+	fat_tab->fat_state = FAT_PREPARE_STATE;
+
+	dm->fat_comb_a = 5;
+	dm->antdiv_intvl = 0x64; /* 100ms */
+
+	for (i = 0; i < 6; i++)
+		fat_tab->bssid[i] = 0;
+	for (i = 0; i < (dm->fat_comb_a) ; i++) {
+		fat_tab->ant_sum_rssi[i] = 0;
+		fat_tab->ant_rssi_cnt[i] = 0;
+		fat_tab->ant_ave_rssi[i] = 0;
+	}
+
+	/* MAC setting */
+	value32 = odm_get_mac_reg(dm, 0x4c, MASKDWORD);
+	odm_set_mac_reg(dm, 0x4c, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	value32 = odm_get_mac_reg(dm,  0x7B4, MASKDWORD);
+	odm_set_mac_reg(dm, 0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17))); /* Reg7B4[16]=1 enable antenna training, Reg7B4[17]=1 enable A2 match */
+	/* value32 = platform_efio_read_4byte(adapter, 0x7B4); */
+	/* platform_efio_write_4byte(adapter, 0x7b4, value32|BIT(18));	 */ /* append MACID in reponse packet */
+
+	/* Match MAC ADDR */
+	odm_set_mac_reg(dm, 0x7b4, 0xFFFF, 0);
+	odm_set_mac_reg(dm, 0x7b0, MASKDWORD, 0);
+
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, 0x864, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, 0xb2c, BIT(22), 0);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, 0xb2c, BIT(31), 0);	/* regb2c[31]=1'b1	 */ /* output at CS only */
+	odm_set_bb_reg(dm, 0xca4, MASKDWORD, 0x000000a0);
+
+	/* antenna mapping table */
+	if (dm->fat_comb_a == 2) {
+		if (!dm->is_mp_chip) { /* testchip */
+			odm_set_bb_reg(dm, 0x858, BIT(10) | BIT(9) | BIT(8), 1);	/* Reg858[10:8]=3'b001 */
+			odm_set_bb_reg(dm, 0x858, BIT(13) | BIT(12) | BIT(11), 2);	/* Reg858[13:11]=3'b010 */
+		} else { /* MPchip */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE0, 1);
+			odm_set_bb_reg(dm, 0x914, MASKBYTE1, 2);
+		}
+	} else {
+		if (!dm->is_mp_chip) { /* testchip */
+			odm_set_bb_reg(dm, 0x858, BIT(10) | BIT(9) | BIT(8), 0);	/* Reg858[10:8]=3'b000 */
+			odm_set_bb_reg(dm, 0x858, BIT(13) | BIT(12) | BIT(11), 1);	/* Reg858[13:11]=3'b001 */
+			odm_set_bb_reg(dm, 0x878, BIT(16), 0);
+			odm_set_bb_reg(dm, 0x858, BIT(15) | BIT(14), 2);	/* (Reg878[0],Reg858[14:15])=3'b010 */
+			odm_set_bb_reg(dm, 0x878, BIT(19) | BIT(18) | BIT(17), 3); /* Reg878[3:1]=3b'011 */
+			odm_set_bb_reg(dm, 0x878, BIT(22) | BIT(21) | BIT(20), 4); /* Reg878[6:4]=3b'100 */
+			odm_set_bb_reg(dm, 0x878, BIT(25) | BIT(24) | BIT(23), 5); /* Reg878[9:7]=3b'101 */
+			odm_set_bb_reg(dm, 0x878, BIT(28) | BIT(27) | BIT(26), 6); /* Reg878[12:10]=3b'110 */
+			odm_set_bb_reg(dm, 0x878, BIT(31) | BIT(30) | BIT(29), 7); /* Reg878[15:13]=3b'111 */
+		} else { /* MPchip */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE0, 4);     /* 0: 3b'000 */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE1, 2);     /* 1: 3b'001 */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE2, 0);     /* 2: 3b'010 */
+			odm_set_bb_reg(dm, 0x914, MASKBYTE3, 1);     /* 3: 3b'011 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE0, 3);     /* 4: 3b'100 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE1, 5);     /* 5: 3b'101 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE2, 6);     /* 6: 3b'110 */
+			odm_set_bb_reg(dm, 0x918, MASKBYTE3, 255); /* 7: 3b'111 */
+		}
+	}
+
+	/* Default ant setting when no fast training */
+	odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), 0);	/* Default RX */
+	odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), 1);	/* Optional RX */
+	odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), 0); /* Default TX */
+
+	/* Enter Traing state */
+	odm_set_bb_reg(dm, 0x864, BIT(2) | BIT(1) | BIT(0), (dm->fat_comb_a - 1));	/* reg864[2:0]=3'd6	 */ /* ant combination=reg864[2:0]+1 */
+
+	/* SW Control */
+	/* phy_set_bb_reg(adapter, 0x864, BIT10, 1); */
+	/* phy_set_bb_reg(adapter, 0x870, BIT9, 1); */
+	/* phy_set_bb_reg(adapter, 0x870, BIT8, 1); */
+	/* phy_set_bb_reg(adapter, 0x864, BIT11, 1); */
+	/* phy_set_bb_reg(adapter, 0x860, BIT9, 0); */
+	/* phy_set_bb_reg(adapter, 0x860, BIT8, 0); */
+}
+#endif
+
+#endif /* #if (RTL8188E_SUPPORT == 1) */
+
+
+#if (RTL8192E_SUPPORT == 1)
+void
+odm_rx_hw_ant_div_init_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		odm_set_bb_reg(dm, 0xc50, BIT(8), 0); /* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
+		odm_set_bb_reg(dm, 0xc50, BIT(9), 1);  /* 1:CG, 0:CS */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8192E AntDiv_Init =>  ant_div_type=[CGCS_RX_HW_ANTDIV]\n");
+
+	/* Pin Settings */
+	odm_set_bb_reg(dm, 0x870, BIT(8), 0);/* reg870[8]=1'b0,     */ /* "antsel" is controled by HWs */
+	odm_set_bb_reg(dm, 0xc50, BIT(8), 1); /* regc50[8]=1'b1   */ /* " CS/CG switching" is controled by HWs */
+
+	/* Mapping table */
+	odm_set_bb_reg(dm, 0x914, 0xFFFF, 0x0100); /* antenna mapping table */
+
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF000, 0x0); /* bias */
+
+	/* CCK Settings */
+	odm_set_bb_reg(dm, 0xa04, 0xF000000, 0); /* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, 0xb34, BIT(30), 0); /* (92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, 0xa74, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, 0xa0c, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+
+}
+
+void
+odm_trx_hw_ant_div_init_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if 0
+	if (*(dm->mp_mode) == true) {
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		odm_set_bb_reg(dm, 0xc50, BIT(8), 0); /* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
+		odm_set_bb_reg(dm, 0xc50, BIT(9), 1);  /* 1:CG, 0:CS */
+		return;
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8192E AntDiv_Init =>  ant_div_type=[ Only for DIR605, CG_TRX_HW_ANTDIV]\n");
+
+	/* 3 --RFE pin setting--------- */
+	/* [MAC] */
+	odm_set_mac_reg(dm, 0x38, BIT(11), 1);            /* DBG PAD Driving control (GPIO 8) */
+	odm_set_mac_reg(dm, 0x4c, BIT(23), 0);            /* path-A, RFE_CTRL_3 */
+	odm_set_mac_reg(dm, 0x4c, BIT(29), 1);            /* path-A, RFE_CTRL_8 */
+	/* [BB] */
+	odm_set_bb_reg(dm, 0x944, BIT(3), 1);              /* RFE_buffer */
+	odm_set_bb_reg(dm, 0x944, BIT(8), 1);
+	odm_set_bb_reg(dm, 0x940, BIT(7) | BIT(6), 0x0); /* r_rfe_path_sel_   (RFE_CTRL_3) */
+	odm_set_bb_reg(dm, 0x940, BIT(17) | BIT(16), 0x0); /* r_rfe_path_sel_   (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, 0x944, BIT(31), 0);     /* RFE_buffer */
+	odm_set_bb_reg(dm, 0x92C, BIT(3), 0);     /* rfe_inv  (RFE_CTRL_3) */
+	odm_set_bb_reg(dm, 0x92C, BIT(8), 1);     /* rfe_inv  (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, 0x930, 0xF000, 0x8);           /* path-A, RFE_CTRL_3 */
+	odm_set_bb_reg(dm, 0x934, 0xF, 0x8);           /* path-A, RFE_CTRL_8 */
+	/* 3 ------------------------- */
+
+	/* Pin Settings */
+	odm_set_bb_reg(dm, 0xC50, BIT(8), 0);	/* path-A  	 */ /* disable CS/CG switch */
+
+#if 0
+	/* Let it follows PHY_REG for bit9 setting */
+	if (dm->priv->pshare->rf_ft_var.use_ext_pa || dm->priv->pshare->rf_ft_var.use_ext_lna)
+		odm_set_bb_reg(dm, 0xC50, BIT(9), 1);	/* path-A 	output at CS */
+	else
+		odm_set_bb_reg(dm, 0xC50, BIT(9), 0);	/* path-A 	output at CG ->normal power */
+#endif
+
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);	/* path-A*/	/* antsel antselb by HW */
+	odm_set_bb_reg(dm, 0xB38, BIT(10), 0);	/* path-A	*/	/* antsel2 by HW */
+
+	/* Mapping table */
+	odm_set_bb_reg(dm, 0x914, 0xFFFF, 0x0100); /* antenna mapping table */
+
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0xca4, 0x7FF000, 0x0); /* bias */
+
+	/* CCK Settings */
+	odm_set_bb_reg(dm, 0xa04, 0xF000000, 0); /* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, 0xb34, BIT(30), 0); /* (92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, 0xa74, BIT(7), 1); /* Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, 0xa0c, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+}
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+void
+odm_smart_hw_ant_div_init_92e(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8192E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n");
+}
+#endif
+
+#endif /* #if (RTL8192E_SUPPORT == 1) */
+
+#if (RTL8723D_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8723d(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[8723D] AntDiv_Init =>  ant_div_type=[S0S1_HW_TRX_AntDiv]\n");
+
+	/*BT Coexistence*/
+	/*keep antsel_map when GNT_BT = 1*/
+	odm_set_bb_reg(dm, 0x864, BIT(12), 1);
+	/* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	odm_set_bb_reg(dm, 0x874, BIT(23), 0);
+	/* Disable hw antsw & fast_train.antsw when BT TX/RX */
+	odm_set_bb_reg(dm, 0xE64, 0xFFFF0000, 0x000c);
+
+
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);
+	/*PTA setting: WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL)*/
+	/*odm_set_bb_reg(dm, 0x948, BIT6, 0);*/
+	/*odm_set_bb_reg(dm, 0x948, BIT8, 0);*/
+	/*GNT_WL tx*/
+	odm_set_bb_reg(dm, 0x950, BIT(29), 0);
+
+
+	/*Mapping Table*/
+	odm_set_bb_reg(dm, 0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0x914, MASKBYTE1, 3);
+	/* odm_set_bb_reg(dm, 0x864, BIT5|BIT4|BIT3, 0); */
+	/* odm_set_bb_reg(dm, 0x864, BIT8|BIT7|BIT6, 1); */
+
+	/* Set WLBB_SEL_RF_ON 1 if RXFIR_PWDB > 0xCcc[3:0] */
+	odm_set_bb_reg(dm, 0xCcc, BIT(12), 0);
+	/* Low-to-High threshold for WLBB_SEL_RF_ON when OFDM enable */
+	odm_set_bb_reg(dm, 0xCcc, 0x0F, 0x01);
+	/* High-to-Low threshold for WLBB_SEL_RF_ON when OFDM enable */
+	odm_set_bb_reg(dm, 0xCcc, 0xF0, 0x0);
+	/* b Low-to-High threshold for WLBB_SEL_RF_ON when OFDM disable ( only CCK ) */
+	odm_set_bb_reg(dm, 0xAbc, 0xFF, 0x06);
+	/* High-to-Low threshold for WLBB_SEL_RF_ON when OFDM disable ( only CCK ) */
+	odm_set_bb_reg(dm, 0xAbc, 0xFF00, 0x00);
+
+
+	/*OFDM HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF, 0xa0);
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF000, 0x00);
+	odm_set_bb_reg(dm, 0xC5C, BIT(20) | BIT(19) | BIT(18), 0x04);
+
+	/*CCK HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1);
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1);
+	odm_set_bb_reg(dm, 0xAA8, BIT(8), 0);
+
+	odm_set_bb_reg(dm, 0xA0C, 0x0F, 0xf);
+	odm_set_bb_reg(dm, 0xA14, 0x1F, 0x8);
+	odm_set_bb_reg(dm, 0xA10, BIT(13), 0x1);
+	odm_set_bb_reg(dm, 0xA74, BIT(8), 0x0);
+	odm_set_bb_reg(dm, 0xB34, BIT(30), 0x1);
+
+	/*disable antenna training	*/
+	odm_set_bb_reg(dm, 0xE08, BIT(16), 0);
+	odm_set_bb_reg(dm, 0xc50, BIT(8), 0);
+
+}
+/*Mingzhi 2017-05-08*/
+
+void
+odm_update_rx_idle_ant_8723d(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	void		*adapter = dm->adapter;
+	u8			count = 0;
+	
+
+/*	odm_set_bb_reg(dm, 0x948, BIT(6), 0x1);	*/
+	odm_set_bb_reg(dm, 0x948, BIT(7), default_ant);
+	odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);      /*Default RX*/
+	odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);     /*Optional RX*/
+	odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant);    /*Default TX*/
+	fat_tab->rx_idle_ant = ant;
+
+}
+
+void
+phydm_set_tx_ant_pwr_8723d(
+	void			*dm_void,
+	u8			ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	PADAPTER    adapter = (PADAPTER)dm->adapter;
+
+	fat_tab->rx_idle_ant = ant;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	adapter->HalFunc.SetTxPowerLevelHandler(adapter, *dm->channel);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	rtw_hal_set_tx_power_level(adapter, *dm->channel);
+#endif
+
+}
+#endif
+
+#if (RTL8723B_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8723b(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8723B AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV(DPDT)]\n");
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0x914, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF, 0xa0); /* thershold */
+	odm_set_bb_reg(dm, 0xCA4, 0x7FF000, 0x00); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0x864, BIT(12), 0); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x874, BIT(23), 0); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	/* Output Pin Settings */
+	odm_set_bb_reg(dm, 0x870, BIT(8), 0);
+
+	odm_set_bb_reg(dm, 0x948, BIT(6), 0); /* WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL) */
+	odm_set_bb_reg(dm, 0x948, BIT(7), 0);
+
+	odm_set_mac_reg(dm, 0x40, BIT(3), 1);
+	odm_set_mac_reg(dm, 0x38, BIT(11), 1);
+	odm_set_mac_reg(dm, 0x4C,  BIT(24) | BIT(23), 2); /* select DPDT_P and DPDT_N as output pin */
+
+	odm_set_bb_reg(dm, 0x944, BIT(0) | BIT(1), 3); /* in/out */
+	odm_set_bb_reg(dm, 0x944, BIT(31), 0);
+
+	odm_set_bb_reg(dm, 0x92C, BIT(1), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0x92C, BIT(0), 1); /* DPDT_N inverse */
+
+	odm_set_bb_reg(dm, 0x930, 0xF0, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0x930, 0xF, 8); /* DPDT_N = ANTSEL[0] */
+
+	/* 2 [--For HW Bug setting] */
+	if (dm->ant_type == ODM_AUTO_ANT)
+		odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+}
+
+
+
+void
+odm_s0s1_sw_ant_div_init_8723b(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8723B AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0x914, MASKBYTE1, 1);
+
+	/* Output Pin Settings */
+	/* odm_set_bb_reg(dm, 0x948, BIT6, 0x1); */
+	odm_set_bb_reg(dm, 0x870, BIT(9) | BIT(8), 0);
+
+	fat_tab->is_become_linked  = false;
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+
+	/* 2 [--For HW Bug setting] */
+	odm_set_bb_reg(dm, 0x80C, BIT(21), 0); /* TX ant  by Reg */
+
+}
+
+void
+odm_update_rx_idle_ant_8723b(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	PADAPTER    adapter = (PADAPTER)dm->adapter;
+	u8			count = 0;
+	/*u8			u1_temp;*/
+	/*u8			h2c_parameter;*/
+
+	if ((!dm->is_linked) && (dm->ant_type == ODM_AUTO_ANT)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to no link\n");
+		return;
+	}
+
+#if 0
+	/* Send H2C command to FW */
+	/* Enable wifi calibration */
+	h2c_parameter = true;
+	odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+
+	/* Check if H2C command sucess or not (0x1e6) */
+	u1_temp = odm_read_1byte(dm, 0x1e6);
+	while ((u1_temp != 0x1) && (count < 100)) {
+		ODM_delay_us(10);
+		u1_temp = odm_read_1byte(dm, 0x1e6);
+		count++;
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: H2C command status = %d, count = %d\n", u1_temp, count);
+
+	if (u1_temp == 0x1) {
+		/* Check if BT is doing IQK (0x1e7) */
+		count = 0;
+		u1_temp = odm_read_1byte(dm, 0x1e7);
+		while ((!(u1_temp & BIT(0)))  && (count < 100)) {
+			ODM_delay_us(50);
+			u1_temp = odm_read_1byte(dm, 0x1e7);
+			count++;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: BT IQK status = %d, count = %d\n", u1_temp, count);
+
+		if (u1_temp & BIT(0)) {
+			odm_set_bb_reg(dm, 0x948, BIT(6), 0x1);
+			odm_set_bb_reg(dm, 0x948, BIT(9), default_ant);
+			odm_set_bb_reg(dm, 0x864, BIT(5) | BIT4 | BIT3, default_ant);	/* Default RX */
+			odm_set_bb_reg(dm, 0x864, BIT(8) | BIT7 | BIT6, optional_ant);	/* Optional RX */
+			odm_set_bb_reg(dm, 0x860, BIT(14) | BIT13 | BIT12, default_ant); /* Default TX */
+			fat_tab->rx_idle_ant = ant;
+
+			/* Set TX AGC by S0/S1 */
+			/* Need to consider Linux driver */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			adapter->hal_func.set_tx_power_level_handler(adapter, *dm->channel);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+			rtw_hal_set_tx_power_level(adapter, *dm->channel);
+#endif
+
+			/* Set IQC by S0/S1 */
+			odm_set_iqc_by_rfpath(dm, default_ant);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n");
+		} else
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to BT IQK\n");
+	} else
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to H2C command fail\n");
+
+	/* Send H2C command to FW */
+	/* Disable wifi calibration */
+	h2c_parameter = false;
+	odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+#else
+
+	odm_set_bb_reg(dm, 0x948, BIT(6), 0x1);
+	odm_set_bb_reg(dm, 0x948, BIT(9), default_ant);
+	odm_set_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);      /*Default RX*/
+	odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);     /*Optional RX*/
+	odm_set_bb_reg(dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant);    /*Default TX*/
+	fat_tab->rx_idle_ant = ant;
+
+	/* Set TX AGC by S0/S1 */
+	/* Need to consider Linux driver */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	adapter->HalFunc.SetTxPowerLevelHandler(adapter, *dm->channel);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	rtw_hal_set_tx_power_level(adapter, *dm->channel);
+#endif
+
+	/* Set IQC by S0/S1 */
+	odm_set_iqc_by_rfpath(dm, default_ant);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n");
+
+#endif
+}
+
+boolean
+phydm_is_bt_enable_8723b(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			bt_state;
+	/*u32			reg75;*/
+
+	/*reg75 = odm_get_bb_reg(dm, 0x74, BIT8);*/
+	/*odm_set_bb_reg(dm, 0x74, BIT8, 0x0);*/
+	odm_set_bb_reg(dm, 0xa0, BIT(24) | BIT(25) | BIT(26), 0x5);
+	bt_state = odm_get_bb_reg(dm, 0xa0, (BIT(3) | BIT(2) | BIT(1) | BIT(0)));
+	/*odm_set_bb_reg(dm, 0x74, BIT8, reg75);*/
+
+	if ((bt_state == 4) || (bt_state == 7) || (bt_state == 9) || (bt_state == 13))
+		return true;
+	else
+		return false;
+}
+#endif /* #if (RTL8723B_SUPPORT == 1) */
+
+#if (RTL8821A_SUPPORT == 1)
+
+void
+odm_trx_hw_ant_div_init_8821a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (DPDT)]\n");
+
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+}
+
+void
+odm_s0s1_sw_ant_div_init_8821a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821A AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0);
+
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+	dm_swat_table->cur_antenna = MAIN_ANT;
+	dm_swat_table->pre_antenna = MAIN_ANT;
+	dm_swat_table->swas_no_link_state = 0;
+
+}
+#endif /* #if (RTL8821A_SUPPORT == 1) */
+
+#if (RTL8821C_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8821c(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821C AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (DPDT)]\n");
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	/* Timming issue */
+	odm_set_bb_reg(dm, 0x818, BIT(23) | BIT(22) | BIT(21) | BIT(20), 0); /*keep antidx after tx for ACK ( unit x 3.2 mu sec)*/
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+}
+
+void
+phydm_s0s1_sw_ant_div_init_8821c(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821C AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+	/* Output Pin Settings */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+
+	odm_set_bb_reg(dm, 0xCB8, BIT(16), 0);
+
+	odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /* by WLAN control */
+	odm_set_bb_reg(dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
+	odm_set_bb_reg(dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x00); /* bias */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	odm_set_bb_reg(dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+
+	/* BT Coexistence */
+	odm_set_bb_reg(dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0);
+
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+	dm_swat_table->cur_antenna = MAIN_ANT;
+	dm_swat_table->pre_antenna = MAIN_ANT;
+	dm_swat_table->swas_no_link_state = 0;
+
+}
+#endif /* #if (RTL8821C_SUPPORT == 1) */
+
+
+#if (RTL8881A_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8881a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8881A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (SPDT)]\n");
+
+	/* Output Pin Settings */
+	/* [SPDT related] */
+	odm_set_mac_reg(dm, 0x4C, BIT(25), 0);
+	odm_set_mac_reg(dm, 0x4C, BIT(26), 0);
+	odm_set_bb_reg(dm, 0xCB4, BIT(31), 0); /* delay buffer */
+	odm_set_bb_reg(dm, 0xCB4, BIT(22), 0);
+	odm_set_bb_reg(dm, 0xCB4, BIT(24), 1);
+	odm_set_bb_reg(dm, 0xCB0, 0xF00, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB0, 0xF0000, 8); /* DPDT_N = ANTSEL[0] */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x0); /* bias */
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	/* 2 [--For HW Bug setting] */
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0); /* TX ant  by Reg */ /* A-cut bug */
+}
+
+#endif /* #if (RTL8881A_SUPPORT == 1) */
+
+
+#if (RTL8812A_SUPPORT == 1)
+void
+odm_trx_hw_ant_div_init_8812a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8812A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (SPDT)]\n");
+
+	/* 3 */ /* 3 --RFE pin setting--------- */
+	/* [BB] */
+	odm_set_bb_reg(dm, 0x900, BIT(10) | BIT(9) | BIT(8), 0x0);	 /* disable SW switch */
+	odm_set_bb_reg(dm, 0x900, BIT(17) | BIT(16), 0x0);
+	odm_set_bb_reg(dm, 0x974, BIT(7) | BIT(6), 0x3);   /* in/out */
+	odm_set_bb_reg(dm, 0xCB4, BIT(31), 0); /* delay buffer */
+	odm_set_bb_reg(dm, 0xCB4, BIT(26), 0);
+	odm_set_bb_reg(dm, 0xCB4, BIT(27), 1);
+	odm_set_bb_reg(dm, 0xCB0, 0xF000000, 8); /* DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, 0xCB0, 0xF0000000, 8); /* DPDT_N = ANTSEL[0] */
+	/* 3 ------------------------- */
+
+	/* Mapping Table */
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, 0xCA4, MASKBYTE1, 1);
+
+	/* OFDM HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, 0x8D4, 0x7FF000, 0x0); /* bias */
+	odm_set_bb_reg(dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+
+	/* CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+
+	/* 2 [--For HW Bug setting] */
+
+	odm_set_bb_reg(dm, 0x900, BIT(18), 0); /* TX ant  by Reg */ /* A-cut bug */
+
+}
+
+#endif /* #if (RTL8812A_SUPPORT == 1) */
+
+#if (RTL8188F_SUPPORT == 1)
+void
+odm_s0s1_sw_ant_div_init_8188f(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8188F AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+
+	/*GPIO setting*/
+	/*odm_set_mac_reg(dm, 0x64, BIT(18), 0); */
+	/*odm_set_mac_reg(dm, 0x44, BIT(28)|BIT(27), 0);*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(20) | BIT(19), 0x3);*/	/*enable_output for P_GPIO[4:3]*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(12)|BIT(11), 0);*/ /*output value*/
+	/*odm_set_mac_reg(dm, 0x40, BIT(1)|BIT(0), 0);*/		/*GPIO function*/
+
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB)
+			odm_set_mac_reg(dm, 0x44, BIT(20) | BIT(19), 0x3);	/*enable_output for P_GPIO[4:3]*/
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			odm_set_mac_reg(dm, 0x44, BIT(18), 0x1);	/*enable_output for P_GPIO[2]*/
+	}
+	
+	fat_tab->is_become_linked  = false;
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+}
+
+void
+phydm_update_rx_idle_antenna_8188F(
+	void	*dm_void,
+	u32	default_ant
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		codeword;
+
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB) {
+			if (default_ant == ANT1_2G)
+				codeword = 1; /*2'b01*/
+			else
+				codeword = 2;/*2'b10*/
+			odm_set_mac_reg(dm, 0x44, (BIT(12) | BIT(11)), codeword); /*GPIO[4:3] output value*/
+		} else if (dm->support_interface == ODM_ITRF_SDIO) {
+			if (default_ant == ANT1_2G) {
+				codeword = 0; /*1'b0*/
+				odm_set_bb_reg(dm, 0x870, BIT(9)|BIT(8), 0x3);
+				odm_set_bb_reg(dm, 0x860, BIT(9)|BIT(8), 0x1);
+			} else {
+				codeword = 1;/*1'b1*/
+				odm_set_bb_reg(dm, 0x870, BIT(9)|BIT(8), 0x3);
+				odm_set_bb_reg(dm, 0x860, BIT(9)|BIT(8), 0x2);
+			}
+			odm_set_mac_reg(dm, 0x44, BIT(10), codeword); /*GPIO[2] output value*/
+		}	
+	}
+}
+#endif
+
+
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+void
+phydm_evm_sw_antdiv_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	/*EVM enhance AntDiv method init----------------------------------------------------------------------*/
+	fat_tab->evm_method_enable = 0;
+	fat_tab->fat_state = NORMAL_STATE_MIAN;
+	fat_tab->fat_state_cnt = 0;
+	fat_tab->pre_antdiv_rssi = 0;
+
+	dm->antdiv_intvl = 30;
+	dm->antdiv_train_num = 2;
+	odm_set_bb_reg(dm, 0x910, 0x3f, 0xf);
+	dm->antdiv_evm_en = 1;
+	/*dm->antdiv_period=1;*/
+	dm->evm_antdiv_period = 3;
+	dm->stop_antdiv_rssi_th = 3;
+	dm->stop_antdiv_tp_th = 80;
+	dm->antdiv_tp_period = 3;
+	dm->stop_antdiv_tp_diff_th = 5;
+}
+
+void
+odm_evm_fast_ant_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	fat_tab->evm_method_enable = 0;
+	odm_ant_div_on_off(dm, ANTDIV_ON);
+	fat_tab->fat_state = NORMAL_STATE_MIAN;
+	fat_tab->fat_state_cnt = 0;
+	dm->antdiv_period = 0;
+	odm_set_mac_reg(dm, 0x608, BIT(8), 0);
+}
+
+
+void
+odm_evm_enhance_ant_div(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	main_rssi, aux_rssi ;
+	u32	main_crc_utility = 0, aux_crc_utility = 0, utility_ratio = 1;
+	u32	main_evm, aux_evm, diff_rssi = 0, diff_EVM = 0;
+	u32	main_2ss_evm[2], aux_2ss_evm[2];
+	u32	main_1ss_evm, aux_1ss_evm;
+	u32	main_2ss_evm_sum, aux_2ss_evm_sum;
+	u8	score_EVM = 0, score_CRC = 0;
+	u8	rssi_larger_ant = 0;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u32	value32, i;
+	boolean main_above1 = false, aux_above1 = false;
+	boolean force_antenna = false;
+	struct cmn_sta_info	*sta;
+	u32	antdiv_tp_main_avg, antdiv_tp_aux_avg;
+	u8	curr_rssi, rssi_diff;
+	u32	tp_diff;
+	u8	tp_diff_return = 0, tp_return = 0, rssi_return = 0;
+	u8	target_ant_evm_1ss, target_ant_evm_2ss;
+	u8	decision_evm_ss;
+	u8	next_ant;
+
+	fat_tab->target_ant_enhance = 0xFF;
+
+	if ((dm->support_ic_type & ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC)) {
+		if (dm->is_one_entry_only) {
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "[One Client only]\n"); */
+			i = dm->one_entry_macid;
+			sta = dm->phydm_sta_info[i];
+
+			main_rssi = (fat_tab->main_ant_cnt[i] != 0) ? (fat_tab->main_ant_sum[i] / fat_tab->main_ant_cnt[i]) : 0;
+			aux_rssi = (fat_tab->aux_ant_cnt[i] != 0) ? (fat_tab->aux_ant_sum[i] / fat_tab->aux_ant_cnt[i]) : 0;
+
+			if ((main_rssi == 0 && aux_rssi != 0 && aux_rssi >= FORCE_RSSI_DIFF) || (main_rssi != 0 && aux_rssi == 0 && main_rssi >= FORCE_RSSI_DIFF))
+				diff_rssi = FORCE_RSSI_DIFF;
+			else if (main_rssi != 0 && aux_rssi != 0)
+				diff_rssi = (main_rssi >= aux_rssi) ? (main_rssi - aux_rssi) : (aux_rssi - main_rssi);
+
+			if (main_rssi >= aux_rssi)
+				rssi_larger_ant = MAIN_ANT;
+			else
+				rssi_larger_ant = AUX_ANT;
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Main_Cnt=(( %d )), main_rssi=(( %d ))\n", fat_tab->main_ant_cnt[i], main_rssi);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Aux_Cnt=(( %d )), aux_rssi=(( %d ))\n", fat_tab->aux_ant_cnt[i], aux_rssi);
+
+			if (((main_rssi >= evm_rssi_th_high || aux_rssi >= evm_rssi_th_high) || (fat_tab->evm_method_enable == 1))
+			/* && (diff_rssi <= FORCE_RSSI_DIFF + 1) */
+			) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "> TH_H || evm_method_enable==1\n");
+
+				if (((main_rssi >= evm_rssi_th_low) || (aux_rssi >= evm_rssi_th_low))) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "> TH_L, fat_state_cnt =((%d))\n", fat_tab->fat_state_cnt);
+
+					/*Traning state: 0(alt) 1(ori) 2(alt) 3(ori)============================================================*/
+					if (fat_tab->fat_state_cnt < ((dm->antdiv_train_num)<<1)) {
+						if (fat_tab->fat_state_cnt == 0) {
+							/*Reset EVM 1SS Method */
+							fat_tab->main_ant_evm_sum[i] = 0;
+							fat_tab->aux_ant_evm_sum[i] = 0;
+							fat_tab->main_ant_evm_cnt[i] = 0;
+							fat_tab->aux_ant_evm_cnt[i] = 0;
+							/*Reset EVM 2SS Method */
+							fat_tab->main_ant_evm_2ss_sum[i][0] = 0;
+							fat_tab->main_ant_evm_2ss_sum[i][1] = 0;
+							fat_tab->aux_ant_evm_2ss_sum[i][0] = 0;
+							fat_tab->aux_ant_evm_2ss_sum[i][1] = 0;
+							fat_tab->main_ant_evm_2ss_cnt[i] = 0;
+							fat_tab->aux_ant_evm_2ss_cnt[i] = 0;
+							#if 0
+							/*Reset TP Method */
+							fat_tab->antdiv_tp_main = 0;
+							fat_tab->antdiv_tp_aux = 0;
+							fat_tab->antdiv_tp_main_cnt = 0;
+							fat_tab->antdiv_tp_aux_cnt = 0;
+							#endif
+							/*Reset CRC Method */
+							fat_tab->main_crc32_ok_cnt = 0;
+							fat_tab->main_crc32_fail_cnt = 0;
+							fat_tab->aux_crc32_ok_cnt = 0;
+							fat_tab->aux_crc32_fail_cnt = 0;
+
+							#ifdef SKIP_EVM_ANTDIV_TRAINING_PATCH
+							if ((*dm->band_width == CHANNEL_WIDTH_20) && (sta->mimo_type == RF_2T2R)) {
+								/*1. Skip training: RSSI*/
+								/*PHYDM_DBG(pDM_Odm,DBG_ANT_DIV, "TargetAnt_enhance=((%d)), RxIdleAnt=((%d))\n", pDM_FatTable->TargetAnt_enhance, pDM_FatTable->RxIdleAnt);*/
+								curr_rssi = (u8)((fat_tab->rx_idle_ant == MAIN_ANT) ? main_rssi : aux_rssi);
+								rssi_diff = (curr_rssi > fat_tab->pre_antdiv_rssi) ? (curr_rssi - fat_tab->pre_antdiv_rssi) : (fat_tab->pre_antdiv_rssi - curr_rssi);
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[1] rssi_return, curr_rssi=((%d)), pre_rssi=((%d))\n", curr_rssi, fat_tab->pre_antdiv_rssi);
+
+								fat_tab->pre_antdiv_rssi = curr_rssi;
+								if ((rssi_diff < (dm->stop_antdiv_rssi_th)) && (curr_rssi != 0))
+									rssi_return = 1;
+
+								/*2. Skip training: TP Diff*/
+								tp_diff = (dm->rx_tp > fat_tab->pre_antdiv_tp) ? (dm->rx_tp  - fat_tab->pre_antdiv_tp) : (fat_tab->pre_antdiv_tp - dm->rx_tp);
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[2] tp_diff_return, curr_tp=((%d)), pre_tp=((%d))\n", dm->rx_tp, fat_tab->pre_antdiv_tp);
+								fat_tab->pre_antdiv_tp = dm->rx_tp;
+								if ((tp_diff < (u32)(dm->stop_antdiv_tp_diff_th)  && (dm->rx_tp != 0)))
+									tp_diff_return = 1;
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[3] tp_return, curr_rx_tp=((%d))\n", dm->rx_tp);
+								/*3. Skip training: TP*/
+								if (dm->rx_tp >= (u32)(dm->stop_antdiv_tp_th))
+									tp_return = 1;
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[4] Return {rssi, tp_diff, tp} = {%d, %d, %d}\n", rssi_return, tp_diff_return, tp_return);
+								/*4. Joint Return Decision*/
+								if (tp_return) {
+									if (tp_diff_return || rssi_diff) {
+										PHYDM_DBG(dm, DBG_ANT_DIV, "***Return EVM SW AntDiv\n");
+										return;
+									}
+								}
+							}
+							#endif
+
+							fat_tab->evm_method_enable = 1;
+							odm_ant_div_on_off(dm, ANTDIV_OFF);
+							dm->antdiv_period = dm->evm_antdiv_period;
+							odm_set_mac_reg(dm, 0x608, BIT(8), 1); /*RCR accepts CRC32-Error packets*/
+
+						}
+
+
+					fat_tab->fat_state_cnt++;
+					next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+					odm_update_rx_idle_ant(dm, next_ant);
+					odm_set_timer(dm, &dm->evm_fast_ant_training_timer, dm->antdiv_intvl); //ms
+
+					}
+					/*Decision state: 4==============================================================*/
+					else {
+						fat_tab->fat_state_cnt = 0;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[Decisoin state ]\n");
+
+						/* 3 [CRC32 statistic] */
+						#if 0
+						if ((fat_tab->main_crc32_ok_cnt > ((fat_tab->aux_crc32_ok_cnt) << 1)) || ((diff_rssi >= 40) && (rssi_larger_ant == MAIN_ANT))) {
+							fat_tab->target_ant_crc32 = MAIN_ANT;
+							force_antenna = true;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "CRC32 Force Main\n");
+						} else if ((fat_tab->aux_crc32_ok_cnt > ((fat_tab->main_crc32_ok_cnt) << 1)) || ((diff_rssi >= 40) && (rssi_larger_ant == AUX_ANT))) {
+							fat_tab->target_ant_crc32 = AUX_ANT;
+							force_antenna = true;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "CRC32 Force Aux\n");
+						} else
+						#endif
+						{
+							if (fat_tab->main_crc32_fail_cnt <= 5)
+								fat_tab->main_crc32_fail_cnt = 5;
+
+							if (fat_tab->aux_crc32_fail_cnt <= 5)
+								fat_tab->aux_crc32_fail_cnt = 5;
+
+							if (fat_tab->main_crc32_ok_cnt > fat_tab->main_crc32_fail_cnt)
+								main_above1 = true;
+
+							if (fat_tab->aux_crc32_ok_cnt > fat_tab->aux_crc32_fail_cnt)
+								aux_above1 = true;
+
+							if (main_above1 == true && aux_above1 == false) {
+								force_antenna = true;
+								fat_tab->target_ant_crc32 = MAIN_ANT;
+							} else if (main_above1 == false && aux_above1 == true) {
+								force_antenna = true;
+								fat_tab->target_ant_crc32 = AUX_ANT;
+							} else if (main_above1 == true && aux_above1 == true) {
+								main_crc_utility = ((fat_tab->main_crc32_ok_cnt) << 7) / fat_tab->main_crc32_fail_cnt;
+								aux_crc_utility = ((fat_tab->aux_crc32_ok_cnt) << 7) / fat_tab->aux_crc32_fail_cnt;
+								fat_tab->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (fat_tab->pre_target_ant_enhance) : ((main_crc_utility >= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
+
+								if (main_crc_utility != 0 && aux_crc_utility != 0) {
+									if (main_crc_utility >= aux_crc_utility)
+										utility_ratio = (main_crc_utility << 1) / aux_crc_utility;
+									else
+										utility_ratio = (aux_crc_utility << 1) / main_crc_utility;
+								}
+							} else if (main_above1 == false && aux_above1 == false) {
+								if (fat_tab->main_crc32_ok_cnt == 0)
+									fat_tab->main_crc32_ok_cnt = 1;
+								if (fat_tab->aux_crc32_ok_cnt == 0)
+									fat_tab->aux_crc32_ok_cnt = 1;
+
+								main_crc_utility = ((fat_tab->main_crc32_fail_cnt) << 7) / fat_tab->main_crc32_ok_cnt;
+								aux_crc_utility = ((fat_tab->aux_crc32_fail_cnt) << 7) / fat_tab->aux_crc32_ok_cnt;
+								fat_tab->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (fat_tab->pre_target_ant_enhance) : ((main_crc_utility <= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
+
+								if (main_crc_utility != 0 && aux_crc_utility != 0) {
+									if (main_crc_utility >= aux_crc_utility)
+										utility_ratio = (main_crc_utility << 1) / (aux_crc_utility);
+									else
+										utility_ratio = (aux_crc_utility << 1) / (main_crc_utility);
+								}
+							}
+						}
+						odm_set_mac_reg(dm, 0x608, BIT(8), 0);/* NOT Accept CRC32 Error packets. */
+						PHYDM_DBG(dm, DBG_ANT_DIV, "MAIN_CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", fat_tab->main_crc32_ok_cnt, fat_tab->main_crc32_fail_cnt, main_crc_utility);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "AUX__CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", fat_tab->aux_crc32_ok_cnt, fat_tab->aux_crc32_fail_cnt, aux_crc_utility);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***1.TargetAnt_CRC32 = ((%s))\n", (fat_tab->target_ant_crc32 == MAIN_ANT)?"MAIN_ANT":"AUX_ANT");
+
+						/* 3 [EVM statistic] */
+						/*1SS EVM*/
+						main_1ss_evm = (fat_tab->main_ant_evm_cnt[i] != 0) ? (fat_tab->main_ant_evm_sum[i] / fat_tab->main_ant_evm_cnt[i]) : 0;
+						aux_1ss_evm = (fat_tab->aux_ant_evm_cnt[i] != 0) ? (fat_tab->aux_ant_evm_sum[i] / fat_tab->aux_ant_evm_cnt[i]) : 0;
+						target_ant_evm_1ss = (main_1ss_evm == aux_1ss_evm) ? (fat_tab->pre_target_ant_enhance) : ((main_1ss_evm >= aux_1ss_evm) ? MAIN_ANT : AUX_ANT);
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main1ss_EVM= ((  %d ))\n", fat_tab->main_ant_evm_cnt[i], main_1ss_evm);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_1ss_EVM = ((  %d ))\n", fat_tab->main_ant_evm_cnt[i], aux_1ss_evm);
+
+						/*2SS EVM*/
+						main_2ss_evm[0] = (fat_tab->main_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->main_ant_evm_2ss_sum[i][0] / fat_tab->main_ant_evm_2ss_cnt[i]) : 0;
+						main_2ss_evm[1] = (fat_tab->main_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->main_ant_evm_2ss_sum[i][1] / fat_tab->main_ant_evm_2ss_cnt[i]) : 0;
+						main_2ss_evm_sum = main_2ss_evm[0] + main_2ss_evm[1];
+
+						aux_2ss_evm[0] = (fat_tab->aux_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->aux_ant_evm_2ss_sum[i][0] / fat_tab->aux_ant_evm_2ss_cnt[i]) : 0;
+						aux_2ss_evm[1] = (fat_tab->aux_ant_evm_2ss_cnt[i] != 0) ? (fat_tab->aux_ant_evm_2ss_sum[i][1] / fat_tab->aux_ant_evm_2ss_cnt[i]) : 0;
+						aux_2ss_evm_sum = aux_2ss_evm[0] + aux_2ss_evm[1];
+
+						target_ant_evm_2ss = (main_2ss_evm_sum == aux_2ss_evm_sum) ? (fat_tab->pre_target_ant_enhance) : ((main_2ss_evm_sum >= aux_2ss_evm_sum) ? MAIN_ANT : AUX_ANT);
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
+							fat_tab->main_ant_evm_2ss_cnt[i], main_2ss_evm[0], main_2ss_evm[1], main_2ss_evm_sum);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
+							fat_tab->aux_ant_evm_2ss_cnt[i], aux_2ss_evm[0], aux_2ss_evm[1], aux_2ss_evm_sum);
+
+						if ((main_2ss_evm_sum + aux_2ss_evm_sum) != 0) {
+							decision_evm_ss = 2;
+							main_evm = main_2ss_evm_sum;
+							aux_evm = aux_2ss_evm_sum;
+							fat_tab->target_ant_evm = target_ant_evm_2ss;
+						} else {
+							decision_evm_ss = 1;
+							main_evm = main_1ss_evm;
+							aux_evm = aux_1ss_evm;
+							fat_tab->target_ant_evm = target_ant_evm_1ss;
+						}
+
+						if ((main_evm == 0 || aux_evm == 0))
+							diff_EVM = 100;
+						else if (main_evm >= aux_evm)
+							diff_EVM = main_evm - aux_evm;
+						else
+							diff_EVM = aux_evm - main_evm;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***2.TargetAnt_EVM((%d-ss)) = ((%s))\n", decision_evm_ss, (fat_tab->target_ant_evm == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+
+						//3 [TP statistic]
+						antdiv_tp_main_avg = (fat_tab->antdiv_tp_main_cnt != 0) ? (fat_tab->antdiv_tp_main / fat_tab->antdiv_tp_main_cnt) : 0;
+						antdiv_tp_aux_avg = (fat_tab->antdiv_tp_aux_cnt != 0) ? (fat_tab->antdiv_tp_aux / fat_tab->antdiv_tp_aux_cnt) : 0;
+						fat_tab->target_ant_tp = (antdiv_tp_main_avg == antdiv_tp_aux_avg) ? (fat_tab->pre_target_ant_enhance) : ((antdiv_tp_main_avg >= antdiv_tp_aux_avg) ? MAIN_ANT : AUX_ANT);
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main_TP = ((%d))\n", fat_tab->antdiv_tp_main_cnt, antdiv_tp_main_avg);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_TP = ((%d))\n", fat_tab->antdiv_tp_aux_cnt, antdiv_tp_aux_avg);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***3.TargetAnt_TP = ((%s))\n", (fat_tab->target_ant_tp == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+						/*Reset TP Method */
+						fat_tab->antdiv_tp_main = 0;
+						fat_tab->antdiv_tp_aux = 0;
+						fat_tab->antdiv_tp_main_cnt = 0;
+						fat_tab->antdiv_tp_aux_cnt = 0;
+
+						/* 2 [ Decision state ] */
+						if (fat_tab->target_ant_evm == fat_tab->target_ant_crc32) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 1, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+
+							if ((utility_ratio < 2 && force_antenna == false) && diff_EVM <= 30)
+								fat_tab->target_ant_enhance = fat_tab->pre_target_ant_enhance;
+							else
+								fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
+						}
+						#if 0
+						else if ((diff_EVM <= 50 && (utility_ratio > 4 && force_antenna == false)) || (force_antenna == true)) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 2, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
+						}
+						#endif
+						else if (diff_EVM >= 20) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 3, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
+						} else if (utility_ratio >= 6 && force_antenna == false) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 4, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
+						} else {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 5, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+
+							if (force_antenna == true)
+								score_CRC = 2;
+							else if (utility_ratio >= 5) /*>2.5*/
+								score_CRC = 2;
+							else if (utility_ratio >= 4) /*>2*/
+								score_CRC = 1;
+							else
+								score_CRC = 0;
+
+							if (diff_EVM >= 15)
+								score_EVM = 3;
+							else if (diff_EVM >= 10)
+								score_EVM = 2;
+							else if (diff_EVM >= 5)
+								score_EVM = 1;
+							else
+								score_EVM = 0;
+
+							if (score_CRC > score_EVM)
+								fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
+							else if (score_CRC < score_EVM)
+								fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
+							else
+								fat_tab->target_ant_enhance = fat_tab->pre_target_ant_enhance;
+						}
+						fat_tab->pre_target_ant_enhance = fat_tab->target_ant_enhance;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "*** 4.TargetAnt_enhance = (( %s ))******\n", (fat_tab->target_ant_enhance == MAIN_ANT)?"MAIN_ANT":"AUX_ANT");
+
+
+					}
+				} else { /* RSSI< = evm_rssi_th_low */
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ <TH_L: escape from > TH_L ]\n");
+					odm_evm_fast_ant_reset(dm);
+				}
+			} else {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[escape from> TH_H || evm_method_enable==1]\n");
+				odm_evm_fast_ant_reset(dm);
+			}
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[multi-Client]\n");
+			odm_evm_fast_ant_reset(dm);
+		}
+	}
+}
+
+void
+odm_evm_fast_ant_training_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******AntDiv_Callback******\n");
+	odm_hw_ant_div(dm);
+}
+#endif
+
+void
+odm_hw_ant_div(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	i, min_max_rssi = 0xFF,  ant_div_max_rssi = 0, max_rssi = 0, local_max_rssi;
+	u32	main_rssi, aux_rssi, mian_cnt, aux_cnt;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	u8	rx_idle_ant = fat_tab->rx_idle_ant, target_ant = 7;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct cmn_sta_info	*sta;
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct _BF_DIV_COEX_    *dm_bdc_table = &dm->dm_bdc_table;
+	u32	TH1 = 500000;
+	u32	TH2 = 10000000;
+	u32	ma_rx_temp, degrade_TP_temp, improve_TP_temp;
+	u8	monitor_rssi_threshold = 30;
+
+	dm_bdc_table->BF_pass = true;
+	dm_bdc_table->DIV_pass = true;
+	dm_bdc_table->is_all_div_sta_idle = true;
+	dm_bdc_table->is_all_bf_sta_idle = true;
+	dm_bdc_table->num_bf_tar = 0 ;
+	dm_bdc_table->num_div_tar = 0;
+	dm_bdc_table->num_client = 0;
+#endif
+#endif
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_update_rx_idle_ant(dm, MAIN_ANT);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			dm->antdiv_period = 0;
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+			/*odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);*/
+
+			/* if(dm->support_ic_type == ODM_RTL8821 ) */
+			/* odm_set_bb_reg(dm, 0x800, BIT(25), 0); */ /* CCK AntDiv function disable */
+
+			/* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+			/* else if(dm->support_ic_type == ODM_RTL8881A) */
+			/* odm_set_bb_reg(dm, 0x800, BIT(25), 0); */ /* CCK AntDiv function disable */
+			/* #endif */
+
+			/* else if(dm->support_ic_type == ODM_RTL8723B ||dm->support_ic_type == ODM_RTL8812) */
+			/* odm_set_bb_reg(dm, 0xA00, BIT(15), 0); */ /* CCK AntDiv function disable */
+
+			fat_tab->is_become_linked = dm->is_linked;
+
+			if (dm->support_ic_type == ODM_RTL8723B && dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+				odm_set_bb_reg(dm, 0x930, 0xF0, 8); /* DPDT_P = ANTSEL[0]   */ /* for 8723B AntDiv function patch.  BB  Dino  130412 */
+				odm_set_bb_reg(dm, 0x930, 0xF, 8); /* DPDT_N = ANTSEL[0] */
+			}
+
+			/* 2 BDC Init */
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+			odm_bdc_init(dm);
+#endif
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+			odm_evm_fast_ant_reset(dm);
+#endif
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	if (dm->antdiv_evm_en == 1) {
+		odm_evm_enhance_ant_div(dm);
+		if (fat_tab->fat_state_cnt != 0)
+			return;
+	} else
+		odm_evm_fast_ant_reset(dm);
+#endif
+
+	/* 2 BDC mode Arbitration */
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (dm->antdiv_evm_en == 0 || fat_tab->evm_method_enable == 0)
+		odm_bf_ant_div_mode_arbitration(dm);
+#endif
+#endif
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
+			/* 2 Caculate RSSI per Antenna */
+			if ((fat_tab->main_ant_cnt[i] != 0) || (fat_tab->aux_ant_cnt[i] != 0)) {
+				mian_cnt = fat_tab->main_ant_cnt[i];
+				aux_cnt = fat_tab->aux_ant_cnt[i];
+				main_rssi = (mian_cnt != 0) ? (fat_tab->main_ant_sum[i] / mian_cnt) : 0;
+				aux_rssi = (aux_cnt != 0) ? (fat_tab->aux_ant_sum[i] / aux_cnt) : 0;
+				target_ant = (mian_cnt == aux_cnt) ? fat_tab->rx_idle_ant : ((mian_cnt >= aux_cnt) ? MAIN_ANT : AUX_ANT); /*Use counter number for OFDM*/
+
+			} else {	/*CCK only case*/
+				mian_cnt = fat_tab->main_ant_cnt_cck[i];
+				aux_cnt = fat_tab->aux_ant_cnt_cck[i];
+				main_rssi = (mian_cnt != 0) ? (fat_tab->main_ant_sum_cck[i] / mian_cnt) : 0;
+				aux_rssi = (aux_cnt != 0) ? (fat_tab->aux_ant_sum_cck[i] / aux_cnt) : 0;
+				target_ant = (main_rssi == aux_rssi) ? fat_tab->rx_idle_ant : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT); /*Use RSSI for CCK only case*/
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] : Main_Cnt = (( %d ))  ,  CCK_Main_Cnt = (( %d )) ,  main_rssi= ((  %d ))\n", i, fat_tab->main_ant_cnt[i], fat_tab->main_ant_cnt_cck[i], main_rssi);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] : Aux_Cnt   = (( %d ))  , CCK_Aux_Cnt   = (( %d )) ,  aux_rssi = ((  %d ))\n", i, fat_tab->aux_ant_cnt[i], fat_tab->aux_ant_cnt_cck[i], aux_rssi);
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "*** MAC ID:[ %d ] , target_ant = (( %s ))\n", i ,( target_ant ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"); */
+
+			local_max_rssi = (main_rssi > aux_rssi) ? main_rssi : aux_rssi;
+			/* 2 Select max_rssi for DIG */
+			if ((local_max_rssi > ant_div_max_rssi) && (local_max_rssi < 40))
+				ant_div_max_rssi = local_max_rssi;
+			if (local_max_rssi > max_rssi)
+				max_rssi = local_max_rssi;
+
+			/* 2 Select RX Idle Antenna */
+			if ((local_max_rssi != 0) && (local_max_rssi < min_max_rssi)) {
+				rx_idle_ant = target_ant;
+				min_max_rssi = local_max_rssi;
+			}
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+			if (dm->antdiv_evm_en == 1) {
+				if (fat_tab->target_ant_enhance != 0xFF) {
+					target_ant = fat_tab->target_ant_enhance;
+					rx_idle_ant = fat_tab->target_ant_enhance;
+				}
+			}
+#endif
+
+			/* 2 Select TX Antenna */
+			if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+				if (dm_bdc_table->w_bfee_client[i] == 0)
+#endif
+#endif
+				{
+					odm_update_tx_ant(dm, target_ant, i);
+				}
+			}
+
+			/* ------------------------------------------------------------ */
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+			dm_bdc_table->num_client++;
+
+			if (dm_bdc_table->bdc_mode == BDC_MODE_2 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+				/* 2 Byte counter */
+
+				ma_rx_temp = sta->rx_moving_average_tp; /* RX  TP   ( bit /sec) */
+
+				if (dm_bdc_table->BDC_state == bdc_bfer_train_state)
+					dm_bdc_table->MA_rx_TP_DIV[i] =  ma_rx_temp ;
+				else
+					dm_bdc_table->MA_rx_TP[i] = ma_rx_temp ;
+
+				if ((ma_rx_temp < TH2)   && (ma_rx_temp > TH1) && (local_max_rssi <= monitor_rssi_threshold)) {
+					if (dm_bdc_table->w_bfer_client[i] == 1) { /* Bfer_Target */
+						dm_bdc_table->num_bf_tar++;
+
+						if (dm_bdc_table->BDC_state == BDC_DECISION_STATE && dm_bdc_table->bdc_try_flag == 0) {
+							improve_TP_temp = (dm_bdc_table->MA_rx_TP_DIV[i] * 9) >> 3 ; /* * 1.125 */
+							dm_bdc_table->BF_pass = (dm_bdc_table->MA_rx_TP[i] > improve_TP_temp) ? true : false;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { MA_rx_TP,improve_TP_temp, MA_rx_TP_DIV,  BF_pass}={ %d,  %d, %d , %d }\n", i, dm_bdc_table->MA_rx_TP[i], improve_TP_temp, dm_bdc_table->MA_rx_TP_DIV[i], dm_bdc_table->BF_pass);
+						}
+					} else { /* DIV_Target */
+						dm_bdc_table->num_div_tar++;
+
+						if (dm_bdc_table->BDC_state == BDC_DECISION_STATE && dm_bdc_table->bdc_try_flag == 0) {
+							degrade_TP_temp = (dm_bdc_table->MA_rx_TP_DIV[i] * 5) >> 3; /* * 0.625 */
+							dm_bdc_table->DIV_pass = (dm_bdc_table->MA_rx_TP[i] > degrade_TP_temp) ? true : false;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { MA_rx_TP, degrade_TP_temp, MA_rx_TP_DIV,  DIV_pass}=\n{ %d,  %d, %d , %d }\n", i, dm_bdc_table->MA_rx_TP[i], degrade_TP_temp, dm_bdc_table->MA_rx_TP_DIV[i], dm_bdc_table->DIV_pass);
+						}
+					}
+				}
+
+				if (ma_rx_temp > TH1) {
+					if (dm_bdc_table->w_bfer_client[i] == 1) /* Bfer_Target */
+						dm_bdc_table->is_all_bf_sta_idle = false;
+					else/* DIV_Target */
+						dm_bdc_table->is_all_div_sta_idle = false;
+				}
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { BFmeeCap, BFmerCap}  = { %d , %d }\n", i, dm_bdc_table->w_bfee_client[i], dm_bdc_table->w_bfer_client[i]);
+
+				if (dm_bdc_table->BDC_state == bdc_bfer_train_state)
+					PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :    MA_rx_TP_DIV = (( %d ))\n", i, dm_bdc_table->MA_rx_TP_DIV[i]);
+
+				else
+					PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :    MA_rx_TP = (( %d ))\n", i, dm_bdc_table->MA_rx_TP[i]);
+
+			}
+#endif
+#endif
+
+		}
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		if (dm_bdc_table->bdc_try_flag == 0)
+#endif
+#endif
+		{
+			phydm_antdiv_reset_statistic(dm, i);
+		}
+	}
+
+
+
+	/* 2 Set RX Idle Antenna & TX Antenna(Because of HW Bug ) */
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** rx_idle_ant = (( %s ))\n", (rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (dm_bdc_table->bdc_mode == BDC_MODE_1 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "*** bdc_rx_idle_update_counter = (( %d ))\n", dm_bdc_table->bdc_rx_idle_update_counter);
+
+		if (dm_bdc_table->bdc_rx_idle_update_counter == 1) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "***Update RxIdle Antenna!!!\n");
+			dm_bdc_table->bdc_rx_idle_update_counter = 30;
+			odm_update_rx_idle_ant(dm, rx_idle_ant);
+		} else {
+			dm_bdc_table->bdc_rx_idle_update_counter--;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "***NOT update RxIdle Antenna because of BF  ( need to fix TX-ant)\n");
+		}
+	} else
+#endif
+#endif
+		odm_update_rx_idle_ant(dm, rx_idle_ant);
+#else
+
+	odm_update_rx_idle_ant(dm, rx_idle_ant);
+
+#endif/* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+
+
+
+	/* 2 BDC Main Algorithm */
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (dm->antdiv_evm_en == 0 || fat_tab->evm_method_enable == 0)
+		odm_bd_ccoex_bfee_rx_div_arbitration(dm);
+
+	dm_bdc_table->num_txbfee_client = 0;
+	dm_bdc_table->num_txbfer_client = 0;
+#endif
+#endif
+
+	if (ant_div_max_rssi == 0)
+		dig_t->ant_div_rssi_max = dm->rssi_min;
+	else
+		dig_t->ant_div_rssi_max = ant_div_max_rssi;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***AntDiv End***\n\n");
+}
+
+
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+
+void
+odm_s0s1_sw_ant_div_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch		*dm_swat_table	= &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab		= &dm->dm_fat_table;
+
+	fat_tab->is_become_linked  = false;
+	dm_swat_table->try_flag = SWAW_STEP_INIT;
+	dm_swat_table->double_chk_flag = 0;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_s0s1_sw_ant_div_reset(): fat_tab->is_become_linked = %d\n", fat_tab->is_become_linked);
+}
+
+void
+odm_s0s1_sw_ant_div(
+	void			*dm_void,
+	u8			step
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch			*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	u32			i, min_max_rssi = 0xFF, local_max_rssi, local_min_rssi;
+	u32			main_rssi, aux_rssi;
+	u8			high_traffic_train_time_u = 0x32, high_traffic_train_time_l = 0, train_time_temp;
+	u8			low_traffic_train_time_u = 200, low_traffic_train_time_l = 0;
+	u8			rx_idle_ant = dm_swat_table->pre_antenna, target_ant = dm_swat_table->pre_antenna, next_ant = 0;
+	struct cmn_sta_info		*entry = NULL;
+	u32			value32;
+	u32			main_ant_sum = 0;
+	u32			aux_ant_sum = 0;
+	u32			main_ant_cnt = 0;
+	u32			aux_ant_cnt = 0;
+
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+		if (fat_tab->is_become_linked == true) {
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			if (dm->support_ic_type == ODM_RTL8723B) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Set REG 948[9:6]=0x0\n");
+				odm_set_bb_reg(dm, 0x948, (BIT(9) | BIT(8) | BIT(7) | BIT(6)), 0x0);
+			}
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+
+			if (dm->support_ic_type == ODM_RTL8723B) {
+				value32 = odm_get_bb_reg(dm, 0x864, BIT(5) | BIT(4) | BIT(3));
+
+#if (RTL8723B_SUPPORT == 1)
+				if (value32 == 0x0)
+					odm_update_rx_idle_ant_8723b(dm, MAIN_ANT, ANT1_2G, ANT2_2G);
+				else if (value32 == 0x1)
+					odm_update_rx_idle_ant_8723b(dm, AUX_ANT, ANT2_2G, ANT1_2G);
+#endif
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "8723B: First link! Force antenna to  %s\n", (value32 == 0x0 ? "MAIN" : "AUX"));
+			}
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%d] { try_flag=(( %d )), step=(( %d )), double_chk_flag = (( %d )) }\n",
+		__LINE__, dm_swat_table->try_flag, step, dm_swat_table->double_chk_flag);
+
+	/* Handling step mismatch condition. */
+	/* Peak step is not finished at last time. Recover the variable and check again. */
+	if (step != dm_swat_table->try_flag) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[step != try_flag]    Need to Reset After Link\n");
+		odm_sw_ant_div_rest_after_link(dm);
+	}
+
+	if (dm_swat_table->try_flag == SWAW_STEP_INIT) {
+		dm_swat_table->try_flag = SWAW_STEP_PEEK;
+		dm_swat_table->train_time_flag = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[set try_flag = 0]  Prepare for peek!\n\n");
+		return;
+
+	} else {
+		/* 1 Normal state (Begin Trying) */
+		if (dm_swat_table->try_flag == SWAW_STEP_PEEK) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "TxOkCnt=(( %llu )), RxOkCnt=(( %llu )), traffic_load = (%d))\n", dm->cur_tx_ok_cnt, dm->cur_rx_ok_cnt, dm->traffic_load);
+
+			if (dm->traffic_load == TRAFFIC_HIGH) {
+				train_time_temp = dm_swat_table->train_time ;
+
+				if (dm_swat_table->train_time_flag == 3) {
+					high_traffic_train_time_l = 0xa;
+
+					if (train_time_temp <= 16)
+						train_time_temp = high_traffic_train_time_l;
+					else
+						train_time_temp -= 16;
+
+				} else if (dm_swat_table->train_time_flag == 2) {
+					train_time_temp -= 8;
+					high_traffic_train_time_l = 0xf;
+				} else if (dm_swat_table->train_time_flag == 1) {
+					train_time_temp -= 4;
+					high_traffic_train_time_l = 0x1e;
+				} else if (dm_swat_table->train_time_flag == 0) {
+					train_time_temp += 8;
+					high_traffic_train_time_l = 0x28;
+				}
+				
+				if (dm->support_ic_type == ODM_RTL8188F) {
+					if (dm->support_interface == ODM_ITRF_SDIO)
+						high_traffic_train_time_l += 0xa;
+				}
+
+				/* PHYDM_DBG(dm,DBG_ANT_DIV, "*** train_time_temp = ((%d))\n",train_time_temp); */
+
+				/* -- */
+				if (train_time_temp > high_traffic_train_time_u)
+					train_time_temp = high_traffic_train_time_u;
+
+				else if (train_time_temp < high_traffic_train_time_l)
+					train_time_temp = high_traffic_train_time_l;
+
+				dm_swat_table->train_time = train_time_temp; /*10ms~200ms*/
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "train_time_flag=((%d)), train_time=((%d))\n", dm_swat_table->train_time_flag, dm_swat_table->train_time);
+
+			} else if ((dm->traffic_load == TRAFFIC_MID) || (dm->traffic_load == TRAFFIC_LOW)) {
+				train_time_temp = dm_swat_table->train_time ;
+
+				if (dm_swat_table->train_time_flag == 3) {
+					low_traffic_train_time_l = 10;
+					if (train_time_temp < 50)
+						train_time_temp = low_traffic_train_time_l;
+					else
+						train_time_temp -= 50;
+				} else if (dm_swat_table->train_time_flag == 2) {
+					train_time_temp -= 30;
+					low_traffic_train_time_l = 36;
+				} else if (dm_swat_table->train_time_flag == 1) {
+					train_time_temp -= 10;
+					low_traffic_train_time_l = 40;
+				} else {
+					train_time_temp += 10;
+					low_traffic_train_time_l = 50;
+				}
+
+				if (dm->support_ic_type == ODM_RTL8188F) {
+					if (dm->support_interface == ODM_ITRF_SDIO)
+						low_traffic_train_time_l += 10;
+				}
+
+				/* -- */
+				if (train_time_temp >= low_traffic_train_time_u)
+					train_time_temp = low_traffic_train_time_u;
+
+				else if (train_time_temp <= low_traffic_train_time_l)
+					train_time_temp = low_traffic_train_time_l;
+
+				dm_swat_table->train_time = train_time_temp; /*10ms~200ms*/
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "train_time_flag=((%d)) , train_time=((%d))\n", dm_swat_table->train_time_flag, dm_swat_table->train_time);
+
+			} else {
+				dm_swat_table->train_time = 0xc8; /*200ms*/
+
+			}
+
+			/* ----------------- */
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Current min_max_rssi is ((%d))\n", fat_tab->min_max_rssi);
+
+			/* ---reset index--- */
+			if (dm_swat_table->reset_idx >= RSSI_CHECK_RESET_PERIOD) {
+				fat_tab->min_max_rssi = 0;
+				dm_swat_table->reset_idx = 0;
+			}
+			PHYDM_DBG(dm, DBG_ANT_DIV, "reset_idx = (( %d ))\n", dm_swat_table->reset_idx);
+
+			dm_swat_table->reset_idx++;
+
+			/* ---double check flag--- */
+			if ((fat_tab->min_max_rssi > RSSI_CHECK_THRESHOLD) && (dm_swat_table->double_chk_flag == 0)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, " min_max_rssi is ((%d)), and > %d\n",
+					fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
+
+				dm_swat_table->double_chk_flag = 1;
+				dm_swat_table->try_flag = SWAW_STEP_DETERMINE;
+				dm_swat_table->rssi_trying = 0;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Test the current ant for (( %d )) ms again\n", dm_swat_table->train_time);
+				odm_update_rx_idle_ant(dm, fat_tab->rx_idle_ant);
+				odm_set_timer(dm,
+					      &dm_swat_table->phydm_sw_antenna_switch_timer,
+					      dm_swat_table->train_time); /*ms*/
+				return;
+			}
+
+			next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+
+			dm_swat_table->try_flag = SWAW_STEP_DETERMINE;
+
+			if (dm_swat_table->reset_idx <= 1)
+				dm_swat_table->rssi_trying = 2;
+			else
+				dm_swat_table->rssi_trying = 1;
+
+			odm_s0s1_sw_ant_div_by_ctrl_frame(dm, SWAW_STEP_PEEK);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[set try_flag=1]  Normal state:  Begin Trying!!\n");
+
+		} else if ((dm_swat_table->try_flag == SWAW_STEP_DETERMINE) && (dm_swat_table->double_chk_flag == 0)) {
+			next_ant = (fat_tab->rx_idle_ant  == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+			dm_swat_table->rssi_trying--;
+		}
+
+		/* 1 Decision state */
+		if ((dm_swat_table->try_flag == SWAW_STEP_DETERMINE) && (dm_swat_table->rssi_trying == 0)) {
+			boolean is_by_ctrl_frame = false;
+			u64	pkt_cnt_total = 0;
+
+			for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+				entry = dm->phydm_sta_info[i];
+				if (is_sta_active(entry)) {
+					/* 2 Caculate RSSI per Antenna */
+					#if 0
+					main_ant_sum = (u32)fat_tab->main_ant_sum[i] + (u32)fat_tab->main_ant_sum_cck[i];
+					aux_ant_sum = (u32)fat_tab->aux_ant_sum[i] + (u32)fat_tab->aux_ant_sum_cck[i];
+					main_ant_cnt = (u32)fat_tab->main_ant_cnt[i] + (u32)fat_tab->main_ant_cnt_cck[i];
+					aux_ant_cnt = (u32)fat_tab->aux_ant_cnt[i] + (u32)fat_tab->aux_ant_cnt_cck[i];
+
+					main_rssi = (main_ant_cnt != 0) ? (main_ant_sum / main_ant_cnt) : 0;
+					aux_rssi = (aux_ant_cnt != 0) ? (aux_ant_sum / aux_ant_cnt) : 0;
+
+					if (fat_tab->main_ant_cnt[i] <= 1 && fat_tab->main_ant_cnt_cck[i] >= 1)
+						main_rssi = 0;
+
+					if (fat_tab->aux_ant_cnt[i] <= 1 && fat_tab->aux_ant_cnt_cck[i] >= 1)
+						aux_rssi = 0;
+					#endif
+					if ((fat_tab->main_ant_cnt[i] != 0) || (fat_tab->aux_ant_cnt[i] != 0)) {
+						main_ant_cnt = (u32)fat_tab->main_ant_cnt[i];
+						aux_ant_cnt = (u32)fat_tab->aux_ant_cnt[i];
+						main_rssi = (main_ant_cnt != 0) ? (fat_tab->main_ant_sum[i] / main_ant_cnt) : 0;
+						aux_rssi = (aux_ant_cnt != 0) ? (fat_tab->aux_ant_sum[i] / aux_ant_cnt) : 0;
+						if (dm_swat_table->pre_antenna == MAIN_ANT) {
+							target_ant = ((aux_ant_cnt > main_ant_cnt) && (aux_rssi >= main_rssi)) ? AUX_ANT : dm_swat_table->pre_antenna;
+						} else {
+							target_ant = ((main_ant_cnt > aux_ant_cnt) && (main_rssi >= aux_rssi)) ? MAIN_ANT : dm_swat_table->pre_antenna;
+						}
+
+					} else {	/*CCK only case*/
+						main_ant_cnt = fat_tab->main_ant_cnt_cck[i];
+						aux_ant_cnt = fat_tab->aux_ant_cnt_cck[i];
+						main_rssi = (main_ant_cnt != 0) ? (fat_tab->main_ant_sum_cck[i] / main_ant_cnt) : 0;
+						aux_rssi = (aux_ant_cnt != 0) ? (fat_tab->aux_ant_sum_cck[i] / aux_ant_cnt) : 0;
+						target_ant = (main_rssi == aux_rssi) ? fat_tab->rx_idle_ant : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT); /*Use RSSI for CCK only case*/
+					}
+					#if 0
+					target_ant = (main_rssi == aux_rssi) ? dm_swat_table->pre_antenna : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT);
+					#endif
+					local_max_rssi = (main_rssi >= aux_rssi) ? main_rssi : aux_rssi;
+					local_min_rssi = (main_rssi >= aux_rssi) ? aux_rssi : main_rssi;
+
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  CCK_counter_main = (( %d ))  , CCK_counter_aux= ((  %d ))\n", fat_tab->main_ant_cnt_cck[i], fat_tab->aux_ant_cnt_cck[i]);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  OFDM_counter_main = (( %d ))  , OFDM_counter_aux= ((  %d ))\n", fat_tab->main_ant_cnt[i], fat_tab->aux_ant_cnt[i]);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  Main_Cnt = (( %d ))  , main_rssi= ((  %d ))\n", main_ant_cnt, main_rssi);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "***  Aux_Cnt   = (( %d ))  , aux_rssi = ((  %d ))\n", aux_ant_cnt, aux_rssi);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "*** MAC ID:[ %d ] , target_ant = (( %s ))\n", i, (target_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+					/* 2 Select RX Idle Antenna */
+
+					if (local_max_rssi != 0 && local_max_rssi < min_max_rssi) {
+						rx_idle_ant = target_ant;
+						min_max_rssi = local_max_rssi;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "*** local_max_rssi-local_min_rssi = ((%d))\n", (local_max_rssi - local_min_rssi));
+
+						if ((local_max_rssi - local_min_rssi) > 8) {
+							if (local_min_rssi != 0)
+								dm_swat_table->train_time_flag = 3;
+							else {
+								if (min_max_rssi > RSSI_CHECK_THRESHOLD)
+									dm_swat_table->train_time_flag = 0;
+								else
+									dm_swat_table->train_time_flag = 3;
+							}
+						} else if ((local_max_rssi - local_min_rssi) > 5)
+							dm_swat_table->train_time_flag = 2;
+						else if ((local_max_rssi - local_min_rssi) > 2)
+							dm_swat_table->train_time_flag = 1;
+						else
+							dm_swat_table->train_time_flag = 0;
+
+					}
+
+					/* 2 Select TX Antenna */
+					if (target_ant == MAIN_ANT)
+						fat_tab->antsel_a[i] = ANT1_2G;
+					else
+						fat_tab->antsel_a[i] = ANT2_2G;
+
+				}
+				phydm_antdiv_reset_statistic(dm, i);
+				pkt_cnt_total += (main_ant_cnt + aux_ant_cnt);
+			}
+
+			if (dm_swat_table->is_sw_ant_div_by_ctrl_frame) {
+				odm_s0s1_sw_ant_div_by_ctrl_frame(dm, SWAW_STEP_DETERMINE);
+				is_by_ctrl_frame = true;
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Control frame packet counter = %d, data frame packet counter = %llu\n",
+				dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame, pkt_cnt_total);
+
+			if (min_max_rssi == 0xff || ((pkt_cnt_total < (dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame >> 1)) && dm->phy_dbg_info.num_qry_beacon_pkt < 2)) {
+				min_max_rssi = 0;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Check RSSI of control frame because min_max_rssi == 0xff\n");
+				PHYDM_DBG(dm, DBG_ANT_DIV, "is_by_ctrl_frame = %d\n", is_by_ctrl_frame);
+
+				if (is_by_ctrl_frame) {
+					main_rssi = (fat_tab->main_ant_ctrl_frame_cnt != 0) ? (fat_tab->main_ant_ctrl_frame_sum / fat_tab->main_ant_ctrl_frame_cnt) : 0;
+					aux_rssi = (fat_tab->aux_ant_ctrl_frame_cnt != 0) ? (fat_tab->aux_ant_ctrl_frame_sum / fat_tab->aux_ant_ctrl_frame_cnt) : 0;
+
+					if (fat_tab->main_ant_ctrl_frame_cnt <= 1 && fat_tab->cck_ctrl_frame_cnt_main >= 1)
+						main_rssi = 0;
+
+					if (fat_tab->aux_ant_ctrl_frame_cnt <= 1 && fat_tab->cck_ctrl_frame_cnt_aux >= 1)
+						aux_rssi = 0;
+
+					if (main_rssi != 0 || aux_rssi != 0) {
+						rx_idle_ant = (main_rssi == aux_rssi) ? dm_swat_table->pre_antenna : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT);
+						local_max_rssi = (main_rssi >= aux_rssi) ? main_rssi : aux_rssi;
+						local_min_rssi = (main_rssi >= aux_rssi) ? aux_rssi : main_rssi;
+
+						if ((local_max_rssi - local_min_rssi) > 8)
+							dm_swat_table->train_time_flag = 3;
+						else if ((local_max_rssi - local_min_rssi) > 5)
+							dm_swat_table->train_time_flag = 2;
+						else if ((local_max_rssi - local_min_rssi) > 2)
+							dm_swat_table->train_time_flag = 1;
+						else
+							dm_swat_table->train_time_flag = 0;
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Control frame: main_rssi = %d, aux_rssi = %d\n", main_rssi, aux_rssi);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "rx_idle_ant decided by control frame = %s\n", (rx_idle_ant == MAIN_ANT ? "MAIN" : "AUX"));
+					}
+				}
+			}
+
+			fat_tab->min_max_rssi = min_max_rssi;
+			dm_swat_table->try_flag = SWAW_STEP_PEEK;
+
+			if (dm_swat_table->double_chk_flag == 1) {
+				dm_swat_table->double_chk_flag = 0;
+
+				if (fat_tab->min_max_rssi > RSSI_CHECK_THRESHOLD) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [Double check] min_max_rssi ((%d)) > %d again!!\n",
+						fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
+
+					odm_update_rx_idle_ant(dm, rx_idle_ant);
+
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[reset try_flag = 0] Training accomplished !!!]\n\n\n");
+					return;
+				} else {
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [Double check] min_max_rssi ((%d)) <= %d !!\n",
+						fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
+
+					next_ant = (fat_tab->rx_idle_ant  == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+					dm_swat_table->try_flag = SWAW_STEP_PEEK;
+					dm_swat_table->reset_idx = RSSI_CHECK_RESET_PERIOD;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[set try_flag=0]  Normal state:  Need to tryg again!!\n\n\n");
+					return;
+				}
+			} else {
+				if (fat_tab->min_max_rssi < RSSI_CHECK_THRESHOLD)
+					dm_swat_table->reset_idx = RSSI_CHECK_RESET_PERIOD;
+
+				dm_swat_table->pre_antenna = rx_idle_ant;
+				odm_update_rx_idle_ant(dm, rx_idle_ant);
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[reset try_flag = 0] Training accomplished !!!]\n\n\n");
+				return;
+			}
+
+		}
+
+	}
+
+	/* 1 4.Change TRX antenna */
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "rssi_trying = (( %d )),    ant: (( %s )) >>> (( %s ))\n",
+		dm_swat_table->rssi_trying, (fat_tab->rx_idle_ant  == MAIN_ANT ? "MAIN" : "AUX"), (next_ant == MAIN_ANT ? "MAIN" : "AUX"));
+
+	odm_update_rx_idle_ant(dm, next_ant);
+
+	/* 1 5.Reset Statistics */
+
+	fat_tab->rx_idle_ant  = next_ant;
+
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_SDIO) {
+			ODM_delay_us(200);
+			
+			if (fat_tab->rx_idle_ant == MAIN_ANT) {
+				fat_tab->main_ant_sum[0] = 0;
+				fat_tab->main_ant_cnt[0] = 0;
+				fat_tab->main_ant_sum_cck[0] = 0;
+				fat_tab->main_ant_cnt_cck[0] = 0;	
+			} else {
+				fat_tab->aux_ant_sum[0] = 0;
+				fat_tab->aux_ant_cnt[0] = 0;
+				fat_tab->aux_ant_sum_cck[0] = 0;
+				fat_tab->aux_ant_cnt_cck[0] = 0;	
+			}	
+		}	
+	}
+
+	/* 1 6.Set next timer   (Trying state) */
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, " Test ((%s)) ant for (( %d )) ms\n", (next_ant == MAIN_ANT ? "MAIN" : "AUX"), dm_swat_table->train_time);
+	odm_set_timer(dm, &dm_swat_table->phydm_sw_antenna_switch_timer,
+		      dm_swat_table->train_time); /*ms*/
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_sw_antdiv_callback(
+	struct phydm_timer_list		*timer
+)
+{
+	void		*adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct sw_antenna_switch			*dm_swat_table = &hal_data->DM_OutSrc.dm_swat_table;
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm_swat_table->phydm_sw_antenna_switch_workitem);
+#else
+	{
+		/* dbg_print("SW_antdiv_Callback"); */
+		odm_s0s1_sw_ant_div(&hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
+	}
+#endif
+#else
+	odm_schedule_work_item(&dm_swat_table->phydm_sw_antenna_switch_workitem);
+#endif
+}
+void
+odm_sw_antdiv_workitem_callback(
+	void            *context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	/* dbg_print("SW_antdiv_Workitem_Callback"); */
+	odm_s0s1_sw_ant_div(&hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
+}
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+odm_sw_antdiv_workitem_callback(
+	void	*context
+)
+{
+	void *
+	adapter = (void *)context;
+	HAL_DATA_TYPE
+	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	/*dbg_print("SW_antdiv_Workitem_Callback");*/
+	odm_s0s1_sw_ant_div(&hal_data->odmpriv, SWAW_STEP_DETERMINE);
+}
+
+void
+odm_sw_antdiv_callback(void *function_context)
+{
+	struct dm_struct	*dm = (struct dm_struct *)function_context;
+	void	*padapter = dm->adapter;
+	if (*(dm->is_net_closed) == true)
+		return;
+
+#if 0 /* Can't do I/O in timer callback*/
+	odm_s0s1_sw_ant_div(dm, SWAW_STEP_DETERMINE);
+#else
+	rtw_run_in_thread_cmd(padapter, odm_sw_antdiv_workitem_callback, padapter);
+#endif
+}
+
+
+#endif
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame(
+	void			*dm_void,
+	u8			step
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch	*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	switch (step) {
+	case SWAW_STEP_PEEK:
+		dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame = 0;
+		dm_swat_table->is_sw_ant_div_by_ctrl_frame = true;
+		fat_tab->main_ant_ctrl_frame_cnt = 0;
+		fat_tab->aux_ant_ctrl_frame_cnt = 0;
+		fat_tab->main_ant_ctrl_frame_sum = 0;
+		fat_tab->aux_ant_ctrl_frame_sum = 0;
+		fat_tab->cck_ctrl_frame_cnt_main = 0;
+		fat_tab->cck_ctrl_frame_cnt_aux = 0;
+		fat_tab->ofdm_ctrl_frame_cnt_main = 0;
+		fat_tab->ofdm_ctrl_frame_cnt_aux = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_S0S1_SwAntDivForAPMode(): Start peek and reset counter\n");
+		break;
+	case SWAW_STEP_DETERMINE:
+		dm_swat_table->is_sw_ant_div_by_ctrl_frame = false;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "odm_S0S1_SwAntDivForAPMode(): Stop peek\n");
+		break;
+	default:
+		dm_swat_table->is_sw_ant_div_by_ctrl_frame = false;
+		break;
+	}
+}
+
+void
+odm_antsel_statistics_of_ctrl_frame(
+	void			*dm_void,
+	u8			antsel_tr_mux,
+	u32			rx_pwdb_all
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	if (antsel_tr_mux == ANT1_2G) {
+		fat_tab->main_ant_ctrl_frame_sum += rx_pwdb_all;
+		fat_tab->main_ant_ctrl_frame_cnt++;
+	} else {
+		fat_tab->aux_ant_ctrl_frame_sum += rx_pwdb_all;
+		fat_tab->aux_ant_ctrl_frame_cnt++;
+	}
+}
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+	/*	struct phydm_phyinfo_struct*		phy_info, */
+	/*	struct phydm_perpkt_info_struct*		pktinfo */
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct	*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct	*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct sw_antenna_switch	*dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type != S0S1_SW_ANTDIV)
+		return;
+
+	/* In try state */
+	if (!dm_swat_table->is_sw_ant_div_by_ctrl_frame)
+		return;
+
+	/* No HW error and match receiver address */
+	if (!pktinfo->is_to_self)
+		return;
+
+	dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame++;
+
+	if (pktinfo->is_cck_rate) {
+		fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
+
+		if (fat_tab->antsel_rx_keep_0 == ANT1_2G)
+			fat_tab->cck_ctrl_frame_cnt_main++;
+		else
+			fat_tab->cck_ctrl_frame_cnt_aux++;
+
+		odm_antsel_statistics_of_ctrl_frame(dm, fat_tab->antsel_rx_keep_0, phy_info->rx_mimo_signal_strength[RF_PATH_A]);
+	} else {
+		fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
+		
+		if (fat_tab->antsel_rx_keep_0 == ANT1_2G)
+			fat_tab->ofdm_ctrl_frame_cnt_main++;
+		else
+			fat_tab->ofdm_ctrl_frame_cnt_aux++;
+
+		odm_antsel_statistics_of_ctrl_frame(dm, fat_tab->antsel_rx_keep_0, phy_info->rx_pwdb_all);
+	}
+}
+
+#endif /* #if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) */
+
+
+
+
+void
+odm_set_next_mac_addr_target(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	struct cmn_sta_info	*entry;
+	u32			value32, i;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "odm_set_next_mac_addr_target() ==>\n");
+
+	if (dm->is_linked) {
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+			if ((fat_tab->train_idx + 1) == ODM_ASSOCIATE_ENTRY_NUM)
+				fat_tab->train_idx = 0;
+			else
+				fat_tab->train_idx++;
+
+			entry = dm->phydm_sta_info[fat_tab->train_idx];
+
+			if (is_sta_active(entry)) {
+				/*Match MAC ADDR*/
+				value32 = (entry->mac_addr[5] << 8) | entry->mac_addr[4];
+
+				odm_set_mac_reg(dm, 0x7b4, 0xFFFF, value32);/*0x7b4~0x7b5*/
+
+				value32 = (entry->mac_addr[3] << 24) | (entry->mac_addr[2] << 16) | (entry->mac_addr[1] << 8) | entry->mac_addr[0];
+
+				odm_set_mac_reg(dm, 0x7b0, MASKDWORD, value32);/*0x7b0~0x7b3*/
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "fat_tab->train_idx=%d\n", fat_tab->train_idx);
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Training MAC addr = %x:%x:%x:%x:%x:%x\n",
+					entry->mac_addr[5], entry->mac_addr[4], entry->mac_addr[3], entry->mac_addr[2], entry->mac_addr[1], entry->mac_addr[0]);
+
+				break;
+			}
+		}
+	}
+
+}
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+
+void
+odm_fast_ant_training(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	u32	max_rssi_path_a = 0, pckcnt_path_a = 0;
+	u8	i, target_ant_path_a = 0;
+	boolean	is_pkt_filter_macth_path_a = false;
+#if (RTL8192E_SUPPORT == 1)
+	u32	max_rssi_path_b = 0, pckcnt_path_b = 0;
+	u8	target_ant_path_b = 0;
+	boolean	is_pkt_filter_macth_path_b = false;
+#endif
+
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			phydm_fast_training_enable(dm, FAT_OFF);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked!!!]\n");
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+
+	if (dm->support_ic_type == ODM_RTL8188E)
+		odm_set_bb_reg(dm, 0x864, BIT(2) | BIT(1) | BIT(0), ((dm->fat_comb_a) - 1));
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, 0xB38, BIT(2) | BIT(1) | BIT(0), ((dm->fat_comb_a) - 1));	   /* path-A  */ /* ant combination=regB38[2:0]+1 */
+		odm_set_bb_reg(dm, 0xB38, BIT(18) | BIT(17) | BIT(16), ((dm->fat_comb_b) - 1));  /* path-B  */ /* ant combination=regB38[18:16]+1 */
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "==>odm_fast_ant_training()\n");
+
+	/* 1 TRAINING STATE */
+	if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		/* 2 Caculate RSSI per Antenna */
+
+		/* 3 [path-A]--------------------------- */
+		for (i = 0; i < (dm->fat_comb_a); i++) { /* i : antenna index */
+			if (fat_tab->ant_rssi_cnt[i] == 0)
+				fat_tab->ant_ave_rssi[i] = 0;
+			else {
+				fat_tab->ant_ave_rssi[i] = fat_tab->ant_sum_rssi[i] / fat_tab->ant_rssi_cnt[i];
+				is_pkt_filter_macth_path_a = true;
+			}
+
+			if (fat_tab->ant_ave_rssi[i] > max_rssi_path_a) {
+				max_rssi_path_a = fat_tab->ant_ave_rssi[i];
+				pckcnt_path_a = fat_tab->ant_rssi_cnt[i];
+				target_ant_path_a =  i ;
+			} else if (fat_tab->ant_ave_rssi[i] == max_rssi_path_a) {
+				if ((fat_tab->ant_rssi_cnt[i])   >   pckcnt_path_a) {
+					max_rssi_path_a = fat_tab->ant_ave_rssi[i];
+					pckcnt_path_a = fat_tab->ant_rssi_cnt[i];
+					target_ant_path_a = i ;
+				}
+			}
+
+			PHYDM_DBG("*** ant-index : [ %d ],      counter = (( %d )),     Avg RSSI = (( %d ))\n", i, fat_tab->ant_rssi_cnt[i],  fat_tab->ant_ave_rssi[i]);
+		}
+
+
+#if 0
+#if (RTL8192E_SUPPORT == 1)
+		/* 3 [path-B]--------------------------- */
+		for (i = 0; i < (dm->fat_comb_b); i++) {
+			if (fat_tab->antRSSIcnt_pathB[i] == 0)
+				fat_tab->antAveRSSI_pathB[i] = 0;
+			else { /*  (ant_rssi_cnt[i] != 0) */
+				fat_tab->antAveRSSI_pathB[i] = fat_tab->antSumRSSI_pathB[i] / fat_tab->antRSSIcnt_pathB[i];
+				is_pkt_filter_macth_path_b = true;
+			}
+			if (fat_tab->antAveRSSI_pathB[i] > max_rssi_path_b) {
+				max_rssi_path_b = fat_tab->antAveRSSI_pathB[i];
+				pckcnt_path_b = fat_tab->antRSSIcnt_pathB[i];
+				target_ant_path_b = (u8) i;
+			}
+			if (fat_tab->antAveRSSI_pathB[i] == max_rssi_path_b) {
+				if (fat_tab->antRSSIcnt_pathB > pckcnt_path_b) {
+					max_rssi_path_b = fat_tab->antAveRSSI_pathB[i];
+					target_ant_path_b = (u8) i;
+				}
+			}
+			if (dm->fat_print_rssi == 1) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "***{path-B}: Sum RSSI[%d] = (( %d )),      cnt RSSI [%d] = (( %d )),     Avg RSSI[%d] = (( %d ))\n",
+					i, fat_tab->antSumRSSI_pathB[i], i, fat_tab->antRSSIcnt_pathB[i], i, fat_tab->antAveRSSI_pathB[i]);
+			}
+		}
+#endif
+#endif
+
+		/* 1 DECISION STATE */
+
+		/* 2 Select TRX Antenna */
+
+		phydm_fast_training_enable(dm, FAT_OFF);
+
+		/* 3 [path-A]--------------------------- */
+		if (is_pkt_filter_macth_path_a  == false) {
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "{path-A}: None Packet is matched\n"); */
+			PHYDM_DBG(dm, DBG_ANT_DIV, "{path-A}: None Packet is matched\n");
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+		} else {
+			PHYDM_DBG("target_ant_path_a = (( %d )) , max_rssi_path_a = (( %d ))\n", target_ant_path_a, max_rssi_path_a);
+
+			/* 3 [ update RX-optional ant ]        Default RX is Omni, Optional RX is the best decision by FAT */
+			if (dm->support_ic_type == ODM_RTL8188E)
+				odm_set_bb_reg(dm, 0x864, BIT(8) | BIT(7) | BIT(6), target_ant_path_a);
+			else if (dm->support_ic_type == ODM_RTL8192E)
+				odm_set_bb_reg(dm, 0xB38, BIT(8) | BIT(7) | BIT(6), target_ant_path_a); /* Optional RX [pth-A] */
+
+			/* 3 [ update TX ant ] */
+			odm_update_tx_ant(dm, target_ant_path_a, (fat_tab->train_idx));
+
+			if (target_ant_path_a == 0)
+				odm_ant_div_on_off(dm, ANTDIV_OFF);
+		}
+#if 0
+#if (RTL8192E_SUPPORT == 1)
+		/* 3 [path-B]--------------------------- */
+		if (is_pkt_filter_macth_path_b == false) {
+			if (dm->fat_print_rssi == 1)
+				PHYDM_DBG(dm, DBG_ANT_DIV, "***[%d]{path-B}: None Packet is matched\n\n\n", __LINE__);
+		} else {
+			if (dm->fat_print_rssi == 1) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					" ***target_ant_path_b = (( %d )) *** max_rssi = (( %d ))***\n\n\n", target_ant_path_b, max_rssi_path_b);
+			}
+			odm_set_bb_reg(dm, 0xB38, BIT(21) | BIT20 | BIT19, target_ant_path_b);	/* Default RX is Omni, Optional RX is the best decision by FAT */
+			odm_set_bb_reg(dm, 0x80c, BIT(21), 1); /* Reg80c[21]=1'b1		//from TX Info */
+
+			fat_tab->antsel_pathB[fat_tab->train_idx] = target_ant_path_b;
+		}
+#endif
+#endif
+
+		/* 2 Reset counter */
+		for (i = 0; i < (dm->fat_comb_a); i++) {
+			fat_tab->ant_sum_rssi[i] = 0;
+			fat_tab->ant_rssi_cnt[i] = 0;
+		}
+		/*
+		#if (RTL8192E_SUPPORT == 1)
+		for(i=0; i<=(dm->fat_comb_b); i++)
+		{
+			fat_tab->antSumRSSI_pathB[i] = 0;
+			fat_tab->antRSSIcnt_pathB[i] = 0;
+		}
+		#endif
+		*/
+
+		fat_tab->fat_state = FAT_PREPARE_STATE;
+		return;
+	}
+
+	/* 1 NORMAL STATE */
+	if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Start Prepare state ]\n");
+
+		odm_set_next_mac_addr_target(dm);
+
+		/* 2 Prepare Training */
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+		phydm_fast_training_enable(dm, FAT_ON);
+		odm_ant_div_on_off(dm, ANTDIV_ON);		/* enable HW AntDiv */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Start Training state]\n");
+
+		odm_set_timer(dm, &dm->fast_ant_training_timer, dm->antdiv_intvl); /* ms */
+	}
+
+}
+
+void
+odm_fast_ant_training_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (*(dm->is_net_closed) == true)
+		return;
+#endif
+
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm->fast_ant_training_workitem);
+#else
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******odm_fast_ant_training_callback******\n");
+	odm_fast_ant_training(dm);
+#endif
+}
+
+void
+odm_fast_ant_training_work_item_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******odm_fast_ant_training_work_item_callback******\n");
+	odm_fast_ant_training(dm);
+}
+
+#endif
+
+void
+odm_ant_div_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	struct sw_antenna_switch			*dm_swat_table = &dm->dm_swat_table;
+
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]   Not Support Antenna Diversity Function\n");
+		return;
+	}
+	/* --- */
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_2G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[2G AntDiv Init]: Only Support 2G Antenna Diversity Function\n");
+		if (!(dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
+			return;
+	} else	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_5G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[5G AntDiv Init]: Only Support 5G Antenna Diversity Function\n");
+		if (!(dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
+			return;
+	} else	if (fat_tab->ant_div_2g_5g == (ODM_ANTDIV_2G | ODM_ANTDIV_5G))
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[2G & 5G AntDiv Init]:Support Both 2G & 5G Antenna Diversity Function\n");
+
+#endif
+	/* --- */
+
+	/* 2 [--General---] */
+	dm->antdiv_period = 0;
+
+	fat_tab->is_become_linked = false;
+	fat_tab->ant_div_on_off = 0xff;
+
+	/* 3       -   AP   - */
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	odm_bdc_init(dm);
+#endif
+#endif
+
+	/* 3     -   WIN   - */
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	dm_swat_table->ant_5g = MAIN_ANT;
+	dm_swat_table->ant_2g = MAIN_ANT;
+#endif
+
+	/* 2 [---Set MAIN_ANT as default antenna if Auto-ant enable---] */
+	odm_ant_div_on_off(dm, ANTDIV_OFF);
+
+	dm->ant_type = ODM_AUTO_ANT;
+
+	fat_tab->rx_idle_ant = 0xff; /*to make RX-idle-antenna will be updated absolutly*/
+	odm_update_rx_idle_ant(dm, MAIN_ANT);
+	phydm_keep_rx_ack_ant_by_tx_ant_time(dm, 0);  /* Timming issue: keep Rx ant after tx for ACK ( 5 x 3.2 mu = 16mu sec)*/
+
+	/* 2 [---Set TX Antenna---] */
+	if (fat_tab->p_force_tx_ant_by_desc == NULL) {
+	fat_tab->force_tx_ant_by_desc = 0;
+	fat_tab->p_force_tx_ant_by_desc = &fat_tab->force_tx_ant_by_desc;
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "p_force_tx_ant_by_desc = %d\n", *fat_tab->p_force_tx_ant_by_desc);
+
+	if (*fat_tab->p_force_tx_ant_by_desc == true)
+		odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	else
+	odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+
+
+	/* 2 [--88E---] */
+	if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		/* dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
+
+		if ((dm->ant_div_type != CGCS_RX_HW_ANTDIV)  && (dm->ant_div_type != CG_TRX_HW_ANTDIV) && (dm->ant_div_type != CG_TRX_SMART_ANTDIV)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]  88E Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_rx_hw_ant_div_init_88e(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_88e(dm);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_smart_hw_ant_div_init_88e(dm);
+#endif
+#endif
+	}
+
+	/* 2 [--92E---] */
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		/* dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
+
+		if ((dm->ant_div_type != CGCS_RX_HW_ANTDIV) && (dm->ant_div_type != CG_TRX_HW_ANTDIV)   && (dm->ant_div_type != CG_TRX_SMART_ANTDIV)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]  8192E Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_rx_hw_ant_div_init_92e(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_92e(dm);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_smart_hw_ant_div_init_92e(dm);
+#endif
+
+	}
+#endif
+
+	/* 2 [--8723B---] */
+#if (RTL8723B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type != S0S1_SW_ANTDIV && dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8723B  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		if (dm->ant_div_type == S0S1_SW_ANTDIV)
+			odm_s0s1_sw_ant_div_init_8723b(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_8723b(dm);
+	}
+#endif
+	/*2 [--8723D---]*/
+#if (RTL8723D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		if (fat_tab->p_default_s0_s1 == NULL) {
+			fat_tab->default_s0_s1 = 1;
+			fat_tab->p_default_s0_s1 = &fat_tab->default_s0_s1;
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "default_s0_s1 = %d\n", *fat_tab->p_default_s0_s1);
+
+		if (*fat_tab->p_default_s0_s1 == true)
+			odm_update_rx_idle_ant(dm, MAIN_ANT);
+		else
+			odm_update_rx_idle_ant(dm, AUX_ANT);
+
+		if (dm->ant_div_type == S0S1_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_8723d(dm);
+		else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8723D  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+	}
+#endif
+	/* 2 [--8811A 8821A---] */
+#if (RTL8821A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		dm->ant_div_type = HL_SW_SMART_ANT_TYPE1;
+
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+			odm_trx_hw_ant_div_init_8821a(dm);
+			phydm_hl_smart_ant_type1_init_8821a(dm);
+		} else
+		#endif
+		{
+			#ifdef ODM_CONFIG_BT_COEXIST
+			dm->ant_div_type = S0S1_SW_ANTDIV;
+			#else
+			dm->ant_div_type = CG_TRX_HW_ANTDIV;
+			#endif
+
+			if (dm->ant_div_type != CG_TRX_HW_ANTDIV && dm->ant_div_type != S0S1_SW_ANTDIV) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8821A & 8811A  Not Supprrt This AntDiv type\n");
+				dm->support_ability &= ~(ODM_BB_ANT_DIV);
+				return;
+			}
+			if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_trx_hw_ant_div_init_8821a(dm);
+			else if (dm->ant_div_type == S0S1_SW_ANTDIV)
+				odm_s0s1_sw_ant_div_init_8821a(dm);
+		}
+	}
+#endif
+
+	/* 2 [--8821C---] */
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		if (dm->ant_div_type != S0S1_SW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8821C  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+		phydm_s0s1_sw_ant_div_init_8821c(dm);
+		odm_trx_hw_ant_div_init_8821c(dm);
+	}
+#endif
+
+	/* 2 [--8881A---] */
+#if (RTL8881A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8881A) {
+		/* dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+			odm_trx_hw_ant_div_init_8881a(dm);
+			/**/
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8881A  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		odm_trx_hw_ant_div_init_8881a(dm);
+	}
+#endif
+
+	/* 2 [--8812---] */
+#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8812) {
+		/* dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!] 8812A  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+		odm_trx_hw_ant_div_init_8812a(dm);
+	}
+#endif
+
+	/*[--8188F---]*/
+#if (RTL8188F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8188F) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		odm_s0s1_sw_ant_div_init_8188f(dm);
+	}
+#endif
+
+	/*[--8822B---]*/
+#if (RTL8822B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		dm->ant_div_type = HL_SW_SMART_ANT_TYPE2;
+
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE2)
+			phydm_hl_smart_ant_type2_init_8822b(dm);
+		#endif
+	}
+#endif
+
+	/*
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** support_ic_type=[%lu]\n",dm->support_ic_type);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** AntDiv support_ability=[%lu]\n",(dm->support_ability & ODM_BB_ANT_DIV)>>6);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** AntDiv type=[%d]\n",dm->ant_div_type);
+	*/
+}
+
+void
+odm_ant_div(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter	= dm->adapter;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+
+	if (dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "tp_active_occur=((%d)), evm_method_enable=((%d))\n",
+		dm->tp_active_occur, fat_tab->evm_method_enable);
+
+		if ((dm->tp_active_occur == 1) && (fat_tab->evm_method_enable == 1)) {
+			fat_tab->idx_ant_div_counter_5g = dm->antdiv_period;
+			fat_tab->idx_ant_div_counter_2g = dm->antdiv_period;
+		}
+	}
+#endif
+
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (fat_tab->idx_ant_div_counter_5g <  dm->antdiv_period) {
+			fat_tab->idx_ant_div_counter_5g++;
+			return;
+		} else
+			fat_tab->idx_ant_div_counter_5g = 0;
+	} else	if (*dm->band_type == ODM_BAND_2_4G) {
+		if (fat_tab->idx_ant_div_counter_2g <  dm->antdiv_period) {
+			fat_tab->idx_ant_div_counter_2g++;
+			return;
+		} else
+			fat_tab->idx_ant_div_counter_2g = 0;
+	}
+
+	/* ---------- */
+
+	/* ---------- */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN || DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+	if (fat_tab->enable_ctrl_frame_antdiv) {
+		if ((dm->data_frame_num <= 10) && (dm->is_linked))
+			fat_tab->use_ctrl_frame_antdiv = 1;
+		else
+			fat_tab->use_ctrl_frame_antdiv = 0;
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "use_ctrl_frame_antdiv = (( %d )), data_frame_num = (( %d ))\n", fat_tab->use_ctrl_frame_antdiv, dm->data_frame_num);
+		dm->data_frame_num = 0;
+	}
+
+	{
+#if (BEAMFORMING_SUPPORT == 1)
+
+		enum beamforming_cap		beamform_cap = phydm_get_beamform_cap(dm);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "is_bt_continuous_turn = ((%d))\n", dm->is_bt_continuous_turn);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv Beam Cap ]   cap= ((%d))\n", beamform_cap);
+		if (!dm->is_bt_continuous_turn) {
+			if ((beamform_cap & BEAMFORMEE_CAP) && (!(*fat_tab->is_no_csi_feedback))) { /* BFmee On  &&   Div On->Div Off */
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv : OFF ]   BFmee ==1; cap= ((%d))\n", beamform_cap);
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv BF]   is_no_csi_feedback= ((%d))\n", *(fat_tab->is_no_csi_feedback));
+				if (fat_tab->fix_ant_bfee == 0) {
+					odm_ant_div_on_off(dm, ANTDIV_OFF);
+					fat_tab->fix_ant_bfee = 1;
+				}
+				return;
+			} else { /* BFmee Off   &&   Div Off->Div On */
+				if ((fat_tab->fix_ant_bfee == 1)  &&  dm->is_linked) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv : ON ]   BFmee ==0; cap=((%d))\n", beamform_cap);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ AntDiv BF]   is_no_csi_feedback= ((%d))\n", *(fat_tab->is_no_csi_feedback));
+					if (dm->ant_div_type != S0S1_SW_ANTDIV)
+						odm_ant_div_on_off(dm, ANTDIV_ON);
+
+					fat_tab->fix_ant_bfee = 0;
+				}
+			}
+		} else {
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+		}
+#endif
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	/* ----------just for fool proof */
+
+	if (dm->antdiv_rssi)
+		dm->debug_components |= DBG_ANT_DIV;
+	else
+		dm->debug_components &= ~DBG_ANT_DIV;
+
+	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_2G) {
+		/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 2G AntDiv Running ]\n"); */
+		if (!(dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
+			return;
+	} else if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_5G) {
+		/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 5G AntDiv Running ]\n"); */
+		if (!(dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
+			return;
+	}
+	/* else 	if(fat_tab->ant_div_2g_5g == (ODM_ANTDIV_2G|ODM_ANTDIV_5G)) */
+	/* { */
+	/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 2G & 5G AntDiv Running ]\n"); */
+	/* } */
+#endif
+
+	/* ---------- */
+
+	if (dm->antdiv_select == 1)
+		dm->ant_type = ODM_FIX_MAIN_ANT;
+	else if (dm->antdiv_select == 2)
+		dm->ant_type = ODM_FIX_AUX_ANT;
+	else { /* if (dm->antdiv_select==0) */
+		dm->ant_type = ODM_AUTO_ANT;
+
+		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		/*Stop Antenna diversity for CMW500 testing case*/
+		if (dm->consecutive_idlel_time >= 10) {
+			dm->ant_type = ODM_FIX_MAIN_ANT;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv: OFF] No TP case, consecutive_idlel_time=((%d))\n", dm->consecutive_idlel_time);
+		}
+		#endif
+	}
+
+	/* PHYDM_DBG(dm, DBG_ANT_DIV,"ant_type= (( %d )) , pre_ant_type= (( %d ))\n",dm->ant_type,dm->pre_ant_type); */
+
+	if (dm->ant_type != ODM_AUTO_ANT) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Fix Antenna at (( %s ))\n", (dm->ant_type == ODM_FIX_MAIN_ANT) ? "MAIN" : "AUX");
+
+		if (dm->ant_type != dm->pre_ant_type) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+
+			if (dm->ant_type == ODM_FIX_MAIN_ANT)
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			else if (dm->ant_type == ODM_FIX_AUX_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
+		}
+		dm->pre_ant_type = dm->ant_type;
+		return;
+	} else {
+		if (dm->ant_type != dm->pre_ant_type) {
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+		}
+		dm->pre_ant_type = dm->ant_type;
+	}
+
+
+	/* 3 ----------------------------------------------------------------------------------------------------------- */
+	/* 2 [--88E---] */
+	if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV || dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_fast_ant_training(dm);
+#endif
+
+#endif
+
+	}
+	/* 2 [--92E---] */
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV || dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_fast_ant_training(dm);
+#endif
+
+	}
+#endif
+
+#if (RTL8723B_SUPPORT == 1)
+	/* 2 [--8723B---] */
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		if (phydm_is_bt_enable_8723b(dm)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[BT is enable!!!]\n");
+			if (fat_tab->is_become_linked == true) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Set REG 948[9:6]=0x0\n");
+				if (dm->support_ic_type == ODM_RTL8723B)
+					odm_set_bb_reg(dm, 0x948, BIT(9) | BIT(8) | BIT(7) | BIT(6), 0x0);
+
+				fat_tab->is_become_linked = false;
+			}
+		} else {
+			if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+				odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+#endif
+			} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_hw_ant_div(dm);
+		}
+	}
+#endif
+	/*8723D*/
+#if (RTL8723D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		odm_hw_ant_div(dm);
+		/**/
+	}
+#endif
+
+	/* 2 [--8821A---] */
+#if (RTL8821A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+			if (sat_tab->fix_beam_pattern_en != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, " [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n", sat_tab->fix_beam_pattern_codeword);
+				/*return;*/
+			} else {
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] ant_div_type = HL_SW_SMART_ANT_TYPE1\n");*/
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
+			}
+
+		} else
+		#endif
+		{
+			#ifdef ODM_CONFIG_BT_COEXIST
+			if (!dm->bt_info_table.is_bt_enabled) { /*BT disabled*/
+				if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+					dm->ant_div_type = CG_TRX_HW_ANTDIV;
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [S0S1_SW_ANTDIV]  ->  [CG_TRX_HW_ANTDIV]\n");
+					/*odm_set_bb_reg(dm, 0x8D4, BIT24, 1); */
+					if (fat_tab->is_become_linked == true)
+						odm_ant_div_on_off(dm, ANTDIV_ON);
+				}
+
+			} else { /*BT enabled*/
+
+				if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+					dm->ant_div_type = S0S1_SW_ANTDIV;
+					PHYDM_DBG(dm, DBG_ANT_DIV, " [CG_TRX_HW_ANTDIV]  ->  [S0S1_SW_ANTDIV]\n");
+					/*odm_set_bb_reg(dm, 0x8D4, BIT24, 0);*/
+					odm_ant_div_on_off(dm, ANTDIV_OFF);
+				}
+			}
+			#endif
+
+			if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+				#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+				odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+				#endif
+			} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_hw_ant_div(dm);
+		}
+	}
+#endif
+
+	/* 2 [--8821C---] */
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		if (!dm->is_bt_continuous_turn) {
+			dm->ant_div_type = S0S1_SW_ANTDIV;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "is_bt_continuous_turn = ((%d))   ==> SW AntDiv\n", dm->is_bt_continuous_turn);
+
+		} else {
+			dm->ant_div_type = CG_TRX_HW_ANTDIV;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "is_bt_continuous_turn = ((%d))   ==> HW AntDiv\n", dm->is_bt_continuous_turn);
+			odm_ant_div_on_off(dm, ANTDIV_ON);
+		}
+
+		if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+			odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+#endif
+		} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+	}
+#endif
+
+	/* 2 [--8881A---] */
+#if (RTL8881A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8881A)
+		odm_hw_ant_div(dm);
+#endif
+
+	/* 2 [--8812A---] */
+#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8812)
+		odm_hw_ant_div(dm);
+#endif
+
+#if (RTL8188F_SUPPORT == 1)
+	/* [--8188F---]*/
+	else if (dm->support_ic_type == ODM_RTL8188F)	{
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+#endif
+	}
+#endif
+
+	/* [--8822B---]*/
+#if (RTL8822B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) {
+			if (sat_tab->fix_beam_pattern_en != 0)
+				PHYDM_DBG(dm, DBG_ANT_DIV, " [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n", sat_tab->fix_beam_pattern_codeword);
+			else
+				phydm_fast_ant_training_hl_smart_antenna_type2(dm);
+		}
+		#endif
+	}
+#endif
+
+
+}
+
+
+void
+odm_antsel_statistics(
+	void			*dm_void,
+	void			*phy_info_void,
+	u8			antsel_tr_mux,
+	u32			mac_id,
+	u32			utility,
+	u8			method,
+	u8			is_cck_rate
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+	struct phydm_phyinfo_struct	*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+
+	if (method == RSSI_METHOD) {
+		if (is_cck_rate) {
+			if (antsel_tr_mux == ANT1_2G) {
+				if (fat_tab->main_ant_sum_cck[mac_id] > 65435) /*to prevent u16 overflow, max(RSSI)=100, 65435+100 = 65535 (u16)*/
+					return;
+
+				fat_tab->main_ant_sum_cck[mac_id] += (u16)utility;
+				fat_tab->main_ant_cnt_cck[mac_id]++;
+			} else {
+				if (fat_tab->aux_ant_sum_cck[mac_id] > 65435)
+					return;
+
+				fat_tab->aux_ant_sum_cck[mac_id] += (u16)utility;
+				fat_tab->aux_ant_cnt_cck[mac_id]++;
+			}
+
+		} else { /*ofdm rate*/
+
+			if (antsel_tr_mux == ANT1_2G) {
+				if (fat_tab->main_ant_sum[mac_id] > 65435)
+					return;
+
+				fat_tab->main_ant_sum[mac_id] += (u16)utility;
+				fat_tab->main_ant_cnt[mac_id]++;
+			} else {
+				if (fat_tab->aux_ant_sum[mac_id] > 65435)
+					return;
+
+				fat_tab->aux_ant_sum[mac_id] += (u16)utility;
+				fat_tab->aux_ant_cnt[mac_id]++;
+			}
+		}
+	}
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	else if (method == EVM_METHOD) {
+		if (dm->rate_ss == 1) {
+			if (antsel_tr_mux == ANT1_2G) {
+				fat_tab->main_ant_evm_sum[mac_id] += ((phy_info->rx_mimo_evm_dbm[0])<<5);
+				fat_tab->main_ant_evm_cnt[mac_id]++;
+			} else {
+				fat_tab->aux_ant_evm_sum[mac_id] += ((phy_info->rx_mimo_evm_dbm[0])<<5);
+				fat_tab->aux_ant_evm_cnt[mac_id]++;
+			}
+
+		} else {/*>= 2SS*/
+
+			if (antsel_tr_mux == ANT1_2G) {
+				fat_tab->main_ant_evm_2ss_sum[mac_id][0] += (phy_info->rx_mimo_evm_dbm[0]<<5);
+				fat_tab->main_ant_evm_2ss_sum[mac_id][1] += (phy_info->rx_mimo_evm_dbm[1]<<5);
+				fat_tab->main_ant_evm_2ss_cnt[mac_id]++;
+
+			} else {
+				fat_tab->aux_ant_evm_2ss_sum[mac_id][0] += (phy_info->rx_mimo_evm_dbm[0]<<5);
+				fat_tab->aux_ant_evm_2ss_sum[mac_id][1] += (phy_info->rx_mimo_evm_dbm[1]<<5);
+				fat_tab->aux_ant_evm_2ss_cnt[mac_id]++;
+			}
+		}
+
+	} else if (method == CRC32_METHOD) {
+		if (antsel_tr_mux == ANT1_2G) {
+			fat_tab->main_crc32_ok_cnt += utility;
+			fat_tab->main_crc32_fail_cnt++;
+		} else {
+			fat_tab->aux_crc32_ok_cnt += utility;
+			fat_tab->aux_crc32_fail_cnt++;
+		}
+
+	} else if (method == TP_METHOD) {
+		if (((utility <= ODM_RATEMCS15) && (utility >= ODM_RATEMCS0)) &&
+			(fat_tab->fat_state_cnt <= dm->antdiv_tp_period)
+		) {
+			if (antsel_tr_mux == ANT1_2G) {
+				fat_tab->antdiv_tp_main += (phy_rate_table[utility])<<5;
+				fat_tab->antdiv_tp_main_cnt++;
+			} else {
+				fat_tab->antdiv_tp_aux += (phy_rate_table[utility])<<5;
+				fat_tab->antdiv_tp_aux_cnt++;
+			}
+		}
+	}
+#endif
+}
+
+void
+odm_process_rssi_for_ant_div(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct			*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct				*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	u32			beam_tmp;
+	u8			next_ant;
+	u8			train_pkt_number;
+#endif
+	u8			rx_power_ant0 = phy_info->rx_mimo_signal_strength[0];
+	u8			rx_power_ant1 = phy_info->rx_mimo_signal_strength[1];
+	u8			rx_evm_ant0 = phy_info->rx_mimo_signal_quality[0];
+	u8			rx_evm_ant1 = phy_info->rx_mimo_signal_quality[1];
+	u8			rssi_avg;
+
+	if ((dm->support_ic_type & ODM_IC_2SS) && (!pktinfo->is_cck_rate)) {
+		if (rx_power_ant1 < 100)
+			rssi_avg = (u8)odm_convert_to_db((odm_convert_to_linear(rx_power_ant0) + odm_convert_to_linear(rx_power_ant1))>>1); /*averaged PWDB*/
+		
+	} else {
+		rx_power_ant0 = (u8)phy_info->rx_pwdb_all;
+		rssi_avg = rx_power_ant0;
+	}
+	
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+	if ((dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) && (fat_tab->fat_state == FAT_TRAINING_STATE))
+		phydm_process_rssi_for_hb_smtant_type2(dm, phy_info, pktinfo, rssi_avg);	/*for 8822B*/
+	else
+#endif
+
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+#ifdef CONFIG_FAT_PATCH
+	if ((dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) && (fat_tab->fat_state == FAT_TRAINING_STATE)) {
+		/*[Beacon]*/
+		if (pktinfo->is_packet_beacon) {
+			sat_tab->beacon_counter++;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "MatchBSSID_beacon_counter = ((%d))\n", sat_tab->beacon_counter);
+
+			if (sat_tab->beacon_counter >= sat_tab->pre_beacon_counter + 2) {
+				if (sat_tab->ant_num > 1) {
+					next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+					odm_update_rx_idle_ant(dm, next_ant);
+				}
+
+				sat_tab->update_beam_idx++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
+					sat_tab->pre_beacon_counter, sat_tab->pkt_counter, sat_tab->update_beam_idx);
+
+				sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+				sat_tab->pkt_counter = 0;
+			}
+		}
+		/*[data]*/
+		else if (pktinfo->is_packet_to_self) {
+			if (sat_tab->pkt_skip_statistic_en == 0) {
+				/*
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, fat_tab->hw_antsw_occur, sat_tab->fast_training_beam_num, rx_power_ant0);
+				*/
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ID[%d][pkt_cnt = %d]: {ANT, Beam} = {%d, %d}, RSSI = ((%d))\n",
+					pktinfo->station_id, sat_tab->pkt_counter, fat_tab->antsel_rx_keep_0, sat_tab->fast_training_beam_num, rx_power_ant0);
+
+				sat_tab->pkt_rssi_sum[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num] += rx_power_ant0;
+				sat_tab->pkt_rssi_cnt[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num]++;
+				sat_tab->pkt_counter++;
+
+				#if 1
+				train_pkt_number = sat_tab->beam_train_cnt[fat_tab->rx_idle_ant - 1][sat_tab->fast_training_beam_num];
+				#else
+				train_pkt_number =  sat_tab->per_beam_training_pkt_num;
+				#endif
+
+				/*Swich Antenna erery N pkts*/
+				if (sat_tab->pkt_counter == train_pkt_number) {
+					if (sat_tab->ant_num > 1) {
+						PHYDM_DBG(dm, DBG_ANT_DIV, "packet enugh ((%d ))pkts ---> Switch antenna\n", train_pkt_number);
+						next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+						odm_update_rx_idle_ant(dm, next_ant);
+					}
+
+					sat_tab->update_beam_idx++;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), update_beam_idx_counter = ((%d))\n",
+						sat_tab->pre_beacon_counter, sat_tab->update_beam_idx);
+
+					sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+					sat_tab->pkt_counter = 0;
+				}
+			}
+		}
+
+		/*Swich Beam after switch "sat_tab->ant_num" antennas*/
+		if (sat_tab->update_beam_idx == sat_tab->ant_num) {
+			sat_tab->update_beam_idx = 0;
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+
+			if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+				fat_tab->fat_state = FAT_DECISION_STATE;
+
+				#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
+				#else
+				odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+				#endif
+
+
+			} else {
+				sat_tab->fast_training_beam_num++;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Update Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+				phydm_set_all_ant_same_beam_num(dm);
+
+				fat_tab->fat_state = FAT_TRAINING_STATE;
+			}
+		}
+
+	}
+#else
+
+	if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+		if ((dm->support_ic_type & ODM_HL_SMART_ANT_TYPE1_SUPPORT) &&
+		    (pktinfo->is_packet_to_self)   &&
+		    (fat_tab->fat_state == FAT_TRAINING_STATE)
+		   ) {
+			if (sat_tab->pkt_skip_statistic_en == 0) {
+				/*
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, fat_tab->hw_antsw_occur, sat_tab->fast_training_beam_num, rx_power_ant0);
+				*/
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), is_packet_to_self = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, pktinfo->is_packet_to_self, sat_tab->fast_training_beam_num, rx_power_ant0);
+
+
+				sat_tab->pkt_rssi_sum[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num] += rx_power_ant0;
+				sat_tab->pkt_rssi_cnt[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num]++;
+				sat_tab->pkt_counter++;
+
+				/*swich beam every N pkt*/
+				if ((sat_tab->pkt_counter) >= (sat_tab->per_beam_training_pkt_num)) {
+					sat_tab->pkt_counter = 0;
+					beam_tmp = sat_tab->fast_training_beam_num;
+
+					if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+						fat_tab->fat_state = FAT_DECISION_STATE;
+
+						#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+						odm_fast_ant_training_hl_smart_antenna_type1(dm);
+						#else
+						odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+						#endif
+
+
+					} else {
+						sat_tab->fast_training_beam_num++;
+						phydm_set_all_ant_same_beam_num(dm);
+
+						fat_tab->fat_state = FAT_TRAINING_STATE;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Update  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+					}
+				}
+			}
+		}
+	}
+#endif
+	else
+#endif
+		if (dm->ant_div_type == CG_TRX_SMART_ANTDIV) {
+			if ((dm->support_ic_type & ODM_SMART_ANT_SUPPORT) && (pktinfo->is_packet_to_self)   && (fat_tab->fat_state == FAT_TRAINING_STATE)) { /* (pktinfo->is_packet_match_bssid && (!pktinfo->is_packet_beacon)) */
+				u8	antsel_tr_mux;
+				antsel_tr_mux = (fat_tab->antsel_rx_keep_2 << 2) | (fat_tab->antsel_rx_keep_1 << 1) | fat_tab->antsel_rx_keep_0;
+				fat_tab->ant_sum_rssi[antsel_tr_mux] += rx_power_ant0;
+				fat_tab->ant_rssi_cnt[antsel_tr_mux]++;
+			}
+		} else { /* ant_div_type != CG_TRX_SMART_ANTDIV */
+			if ((dm->support_ic_type & ODM_ANTDIV_SUPPORT) && (pktinfo->is_packet_to_self || fat_tab->use_ctrl_frame_antdiv)) {
+				if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+					if (pktinfo->is_cck_rate || (dm->support_ic_type == ODM_RTL8188F))
+						fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
+
+						odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_power_ant0, RSSI_METHOD, pktinfo->is_cck_rate);
+
+				} else {
+					
+					odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_power_ant0, RSSI_METHOD, pktinfo->is_cck_rate);
+
+					#ifdef ODM_EVM_ENHANCE_ANTDIV
+					if (dm->support_ic_type == ODM_RTL8192E) {
+						if (!pktinfo->is_cck_rate) {
+							odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_evm_ant0, EVM_METHOD, pktinfo->is_cck_rate);
+							odm_antsel_statistics(dm, phy_info, fat_tab->antsel_rx_keep_0, pktinfo->station_id, rx_evm_ant0, TP_METHOD, pktinfo->is_cck_rate);
+						}
+
+					}
+					#endif
+				}
+			}
+		}
+	/* PHYDM_DBG(dm,DBG_ANT_DIV,"is_cck_rate=%d, pwdb_all=%d\n",pktinfo->is_cck_rate, phy_info->rx_pwdb_all); */
+	/* PHYDM_DBG(dm,DBG_ANT_DIV,"antsel_tr_mux=3'b%d%d%d\n",fat_tab->antsel_rx_keep_2, fat_tab->antsel_rx_keep_1, fat_tab->antsel_rx_keep_0); */
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+odm_set_tx_ant_by_tx_info(
+	void			*dm_void,
+	u8			*desc,
+	u8			mac_id
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+		return;
+
+
+	if (dm->support_ic_type == ODM_RTL8723B) {
+#if (RTL8723B_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8723B(desc, fat_tab->antsel_a[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8723B] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8821) {
+#if (RTL8821A_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8812(desc, fat_tab->antsel_a[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8821A] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_88E(desc, fat_tab->antsel_a[mac_id]);
+		SET_TX_DESC_ANTSEL_B_88E(desc, fat_tab->antsel_b[mac_id]);
+		SET_TX_DESC_ANTSEL_C_88E(desc, fat_tab->antsel_c[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8188E] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8821C) {
+#if (RTL8821C_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8821C(desc, fat_tab->antsel_a[mac_id]);
+		/*PHYDM_DBG(dm,DBG_ANT_DIV, "[8821C] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+			mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id], fat_tab->antsel_a[mac_id]);*/
+#endif
+	}
+}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_set_tx_ant_by_tx_info(
+	struct	rtl8192cd_priv		*priv,
+	struct	tx_desc	*pdesc,
+	unsigned short			aid
+)
+{
+	struct dm_struct	*dm = GET_PDM_ODM(priv);/*&(priv->pshare->_dmODM);*/
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+		return;
+
+	if (dm->support_ic_type == ODM_RTL8881A) {
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);	*/
+		pdesc->Dword6 &= set_desc(~(BIT(18) | BIT(17) | BIT(16)));
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8192E******\n",__FUNCTION__,__LINE__);	*/
+		pdesc->Dword6 &= set_desc(~(BIT(18) | BIT(17) | BIT(16)));
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8188E******\n",__FUNCTION__,__LINE__);*/
+		pdesc->Dword2 &= set_desc(~BIT(24));
+		pdesc->Dword2 &= set_desc(~BIT(25));
+		pdesc->Dword7 &= set_desc(~BIT(29));
+
+		pdesc->Dword2 |= set_desc(fat_tab->antsel_a[aid] << 24);
+		pdesc->Dword2 |= set_desc(fat_tab->antsel_b[aid] << 25);
+		pdesc->Dword7 |= set_desc(fat_tab->antsel_c[aid] << 29);
+
+
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		/*[path-A]*/
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);*/
+
+		pdesc->Dword6 &= set_desc(~BIT(16));
+		pdesc->Dword6 &= set_desc(~BIT(17));
+		pdesc->Dword6 &= set_desc(~BIT(18));
+
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_b[aid] << 17);
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_c[aid] << 18);
+
+	}
+}
+
+
+#if 1 /*def CONFIG_WLAN_HAL*/
+void
+odm_set_tx_ant_by_tx_info_hal(
+	struct	rtl8192cd_priv		*priv,
+	void	*pdesc_data,
+	u16					aid
+)
+{
+	struct dm_struct	*dm = GET_PDM_ODM(priv);/*&(priv->pshare->_dmODM);*/
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	PTX_DESC_DATA_88XX	pdescdata = (PTX_DESC_DATA_88XX)pdesc_data;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
+		return;
+
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+		return;
+
+	if (dm->support_ic_type & (ODM_RTL8881A | ODM_RTL8192E | ODM_RTL8814A)) {
+		/*panic_printk("[%s] [%d] ******odm_set_tx_ant_by_tx_info_hal******\n",__FUNCTION__,__LINE__);*/
+		pdescdata->ant_sel = 1;
+		pdescdata->ant_sel_a = fat_tab->antsel_a[aid];
+	}
+}
+#endif	/*#ifdef CONFIG_WLAN_HAL*/
+
+#endif
+
+
+void
+odm_ant_div_config(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "WIN Config Antenna Diversity\n");
+	/*
+	if(dm->support_ic_type==ODM_RTL8723B)
+	{
+		if((!dm->dm_swat_table.ANTA_ON || !dm->dm_swat_table.ANTB_ON))
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	}
+	*/
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		dm->ant_div_type = S0S1_TRX_HW_ANTDIV;
+		/**/
+	}
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "CE Config Antenna Diversity\n");
+
+	if (dm->support_ic_type == ODM_RTL8723B)
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+
+
+
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "AP Config Antenna Diversity\n");
+
+	/* 2 [ NOT_SUPPORT_ANTDIV ] */
+#if (defined(CONFIG_NOT_SUPPORT_ANTDIV))
+	dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Disable AntDiv function] : Not Support 2.4G & 5G Antenna Diversity\n");
+
+	/* 2 [ 2G&5G_SUPPORT_ANTDIV ] */
+#elif (defined(CONFIG_2G5G_SUPPORT_ANTDIV))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Enable AntDiv function] : 2.4G & 5G Support Antenna Diversity Simultaneously\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_2G | ODM_ANTDIV_5G);
+
+	if (dm->support_ic_type & ODM_ANTDIV_SUPPORT)
+		dm->support_ability |= ODM_BB_ANT_DIV;
+	if (*dm->band_type == ODM_BAND_5G) {
+#if (defined(CONFIG_5G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+		panic_printk("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_TRX_DIVERSITY) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+		panic_printk("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	} else if (*dm->band_type == ODM_BAND_2_4G) {
+#if (defined(CONFIG_2G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_TRX_DIVERSITY) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	}
+
+	/* 2 [ 5G_SUPPORT_ANTDIV ] */
+#elif (defined(CONFIG_5G_SUPPORT_ANTDIV))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n");
+	panic_printk("[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_5G);
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC)
+			dm->support_ability |= ODM_BB_ANT_DIV;
+#if (defined(CONFIG_5G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+		panic_printk("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_TRX_DIVERSITY))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		panic_printk("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	} else if (*dm->band_type == ODM_BAND_2_4G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Not Support 2G ant_div_type\n");
+		dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	}
+
+	/* 2 [ 2G_SUPPORT_ANTDIV ] */
+#elif (defined(CONFIG_2G_SUPPORT_ANTDIV))
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Enable AntDiv function] : Only 2.4G Support Antenna Diversity\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_2G);
+	if (*dm->band_type == ODM_BAND_2_4G) {
+		if (dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC)
+			dm->support_ability |= ODM_BB_ANT_DIV;
+#if (defined(CONFIG_2G_CGCS_RX_DIVERSITY))
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_TRX_DIVERSITY))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n");
+#elif (defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY))
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n");
+#endif
+	} else if (*dm->band_type == ODM_BAND_5G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Not Support 5G ant_div_type\n");
+		dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	}
+#endif
+#endif
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv Config Info] AntDiv_SupportAbility = (( %x ))\n", ((dm->support_ability & ODM_BB_ANT_DIV) ? 1 : 0));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv Config Info] be_fix_tx_ant = ((%d))\n", dm->dm_fat_table.b_fix_tx_ant);
+
+}
+
+
+void
+odm_ant_div_timers(
+	void		*dm_void,
+	u8		state
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	if (state == INIT_ANTDIV_TIMMER) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_initialize_timer(dm,
+				     &dm->dm_swat_table.phydm_sw_antenna_switch_timer,
+				     (void *)odm_sw_antdiv_callback, NULL,
+				     "phydm_sw_antenna_switch_timer");
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_initialize_timer(dm, &dm->fast_ant_training_timer,
+			(void *)odm_fast_ant_training_callback, NULL, "fast_ant_training_timer");
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+		odm_initialize_timer(dm, &dm->evm_fast_ant_training_timer,
+			(void *)odm_evm_fast_ant_training_callback, NULL, "evm_fast_ant_training_timer");
+#endif
+	} else if (state == CANCEL_ANTDIV_TIMMER) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_cancel_timer(dm,
+				 &dm->dm_swat_table.phydm_sw_antenna_switch_timer);
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_cancel_timer(dm, &dm->fast_ant_training_timer);
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+		odm_cancel_timer(dm, &dm->evm_fast_ant_training_timer);
+#endif
+	} else if (state == RELEASE_ANTDIV_TIMMER) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_release_timer(dm,
+				  &dm->dm_swat_table.phydm_sw_antenna_switch_timer);
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_release_timer(dm, &dm->fast_ant_training_timer);
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+		odm_release_timer(dm, &dm->evm_fast_ant_training_timer);
+#endif
+	}
+
+}
+
+void
+phydm_antdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	/*struct phydm_fat_struct*			fat_tab = &dm->dm_fat_table;*/
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm_value[0] == 1) { /*fixed or auto antenna*/
+
+		if (dm_value[1] == 0) {
+			dm->ant_type = ODM_AUTO_ANT;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "AntDiv: Auto\n");
+		} else if (dm_value[1] == 1) {
+			dm->ant_type = ODM_FIX_MAIN_ANT;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "AntDiv: Fix Main\n");
+		} else if (dm_value[1] == 2) {
+			dm->ant_type = ODM_FIX_AUX_ANT;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "AntDiv: Fix Aux\n");
+		}
+
+		if (dm->ant_type != ODM_AUTO_ANT) {
+			odm_stop_antenna_switch_dm(dm);
+			if (dm->ant_type == ODM_FIX_MAIN_ANT)
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			else if (dm->ant_type == ODM_FIX_AUX_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
+		} else {
+			phydm_enable_antenna_diversity(dm);
+		}
+		dm->pre_ant_type = dm->ant_type;
+	} else if (dm_value[0] == 2) { /*dynamic period for AntDiv*/
+
+		dm->antdiv_period = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "AntDiv_period = ((%d))\n", dm->antdiv_period);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
+
+void
+odm_ant_div_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		odm_s0s1_sw_ant_div_reset(dm);
+#endif
+	}
+
+}
+
+void
+odm_antenna_diversity_init(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+#if 0
+	if (*(dm->mp_mode) == true)
+		return;
+#endif
+
+	odm_ant_div_config(dm);
+	odm_ant_div_init(dm);
+#endif
+}
+
+void
+odm_antenna_diversity(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (*dm->mp_mode == true)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Return!!!]   Not Support Antenna Diversity Function\n");
+		return;
+	}
+
+	if (dm->pause_ability & ODM_BB_ANT_DIV) {
+		
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Return: Pause AntDIv in LV=%d\n", dm->pause_lv_table.lv_antdiv);
+		return;
+	}
+
+	odm_ant_div(dm);
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.h
index 8d72d289b79d..ced9f55d29e4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_antdiv.h
@@ -1,567 +1,618 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef	__PHYDMANTDIV_H__
-#define    __PHYDMANTDIV_H__
-
-/*#define ANTDIV_VERSION	"2.0"  //2014.11.04*/
-/*#define ANTDIV_VERSION	"2.1"  //2015.01.13  Dino*/
-/*#define ANTDIV_VERSION	"2.2"  2015.01.16  Dino*/
-/*#define ANTDIV_VERSION	"3.1"  2015.07.29  YuChen, remove 92c 92d 8723a*/
-/*#define ANTDIV_VERSION	"3.2"  2015.08.11  Stanley, disable antenna diversity when BT is enable for 8723B*/
-/*#define ANTDIV_VERSION	"3.3"  2015.08.12  Stanley. 8723B does not need to check the antenna is control by BT, 
-							because antenna diversity only works when BT is disable or radio off*/
-#define ANTDIV_VERSION	"3.4"  /*2015.08.28  Dino  1.Add 8821A Smart Antenna 2. Add 8188F SW S0S1 Antenna Diversity*/
-
-//1 ============================================================
-//1  Definition 
-//1 ============================================================
-
-#define	MAIN_ANT	1
-#define	AUX_ANT	2
-
-#define ANT1_2G 0 // = ANT2_5G
-#define ANT2_2G 1 // = ANT1_5G
-/*smart antenna*/
-#define SUPPORT_RF_PATH_NUM 4
-#define SUPPORT_BEAM_PATTERN_NUM 4
-
-
-//Antenna Diversty Control Type
-#define	ODM_AUTO_ANT		0
-#define	ODM_FIX_MAIN_ANT	1
-#define	ODM_FIX_AUX_ANT	2
-
-#define ODM_N_ANTDIV_SUPPORT		(ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8723B|ODM_RTL8188F)
-#define ODM_AC_ANTDIV_SUPPORT	(ODM_RTL8821|ODM_RTL8881A|ODM_RTL8812)
-#define ODM_ANTDIV_SUPPORT		(ODM_N_ANTDIV_SUPPORT|ODM_AC_ANTDIV_SUPPORT)
-#define ODM_SMART_ANT_SUPPORT	(ODM_RTL8188E|ODM_RTL8192E)
-#define ODM_HL_SMART_ANT_TYPE1_SUPPORT		(ODM_RTL8821)
-
-#define ODM_ANTDIV_2G_SUPPORT_IC			(ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8723B|ODM_RTL8881A|ODM_RTL8188F)
-#define ODM_ANTDIV_5G_SUPPORT_IC			(ODM_RTL8821|ODM_RTL8881A|ODM_RTL8812)
-
-#define ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC	(ODM_RTL8192E)
-
-#define ODM_ANTDIV_2G	BIT0
-#define ODM_ANTDIV_5G	BIT1
-
-#define ANTDIV_ON	1
-#define ANTDIV_OFF	0
-
-#define FAT_ON	1
-#define FAT_OFF	0
-
-#define TX_BY_DESC	1
-#define TX_BY_REG	0
-
-#define RSSI_METHOD		0
-#define EVM_METHOD		1
-#define CRC32_METHOD	2
-
-#define INIT_ANTDIV_TIMMER		0
-#define CANCEL_ANTDIV_TIMMER	1
-#define RELEASE_ANTDIV_TIMMER	2
-
-#define CRC32_FAIL	1
-#define CRC32_OK	0
-
-#define Evm_RSSI_TH_High	25
-#define Evm_RSSI_TH_Low	20
-
-#define NORMAL_STATE_MIAN	1
-#define NORMAL_STATE_AUX	2
-#define TRAINING_STATE		3
-
-#define FORCE_RSSI_DIFF 10
-
-#define CSI_ON	1
-#define CSI_OFF	0
-
-#define DIVON_CSIOFF 1
-#define DIVOFF_CSION 2
-
-#define BDC_DIV_TRAIN_STATE	0
-#define BDC_BFer_TRAIN_STATE	1
-#define BDC_DECISION_STATE		2
-#define BDC_BF_HOLD_STATE		3
-#define BDC_DIV_HOLD_STATE		4
-
-#define BDC_MODE_1 1
-#define BDC_MODE_2 2
-#define BDC_MODE_3 3
-#define BDC_MODE_4 4
-#define BDC_MODE_NULL 0xff
-
-/*SW S0S1 antenna diversity*/
-#define SWAW_STEP_INIT			0xff
-#define SWAW_STEP_PEEK		0
-#define SWAW_STEP_DETERMINE	1
-
-#define RSSI_CHECK_RESET_PERIOD	10
-#define RSSI_CHECK_THRESHOLD		50
-
-/*Hong Lin Smart antenna*/
-#define HL_SMTANT_2WIRE_DATA_LEN 24
-
-//1 ============================================================
-//1  structure
-//1 ============================================================
-
-
-typedef struct _SW_Antenna_Switch_
-{
-	u1Byte		Double_chk_flag;	/*If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than check this antenna again*/
-	u1Byte		try_flag;
-	s4Byte		PreRSSI;
-	u1Byte		CurAntenna;
-	u1Byte		PreAntenna;
-	u1Byte		RSSI_Trying;
-	u1Byte 		reset_idx;
-	u1Byte		Train_time;
-	u1Byte		Train_time_flag; /*base on RSSI difference between two antennas*/
-	RT_TIMER	phydm_SwAntennaSwitchTimer;
-	u4Byte		PktCnt_SWAntDivByCtrlFrame;
-	BOOLEAN		bSWAntDivByCtrlFrame;
-	
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	#if USE_WORKITEM
-	RT_WORK_ITEM	phydm_SwAntennaSwitchWorkitem;	
-	#endif
-	#endif	
-
-	/* AntDect (Before link Antenna Switch check) need to be moved*/
-	u2Byte		Single_Ant_Counter;
-	u2Byte		Dual_Ant_Counter;
-	u2Byte		Aux_FailDetec_Counter;
-	u2Byte		Retry_Counter;	
-	u1Byte		SWAS_NoLink_State;
-	u4Byte		SWAS_NoLink_BK_Reg948;
-	BOOLEAN		ANTA_ON;	/*To indicate Ant A is or not*/
-	BOOLEAN		ANTB_ON;	/*To indicate Ant B is on or not*/
-	BOOLEAN		Pre_Aux_FailDetec;
-	BOOLEAN		RSSI_AntDect_bResult;	
-	u1Byte		Ant5G;
-	u1Byte		Ant2G;
-
-	
-}SWAT_T, *pSWAT_T;
-
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-typedef struct _BF_DIV_COEX_
-{
-	BOOLEAN w_BFer_Client[ODM_ASSOCIATE_ENTRY_NUM];
-	BOOLEAN w_BFee_Client[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
-
-	u1Byte  BDCcoexType_wBfer;
-	u1Byte num_Txbfee_Client;
-	u1Byte num_Txbfer_Client;
-	u1Byte BDC_Try_counter;
-	u1Byte BDC_Hold_counter;
-	u1Byte BDC_Mode;
-	u1Byte BDC_active_Mode;
-	u1Byte BDC_state;
-	u1Byte BDC_RxIdleUpdate_counter;
-	u1Byte num_Client;
-	u1Byte pre_num_Client;
-	u1Byte num_BfTar;
-	u1Byte num_DivTar;
-	
-	BOOLEAN bAll_DivSta_Idle;
-	BOOLEAN bAll_BFSta_Idle;
-	BOOLEAN BDC_Try_flag;
-	BOOLEAN BF_pass;
-	BOOLEAN DIV_pass;	
-}BDC_T,*pBDC_T;
-#endif
-#endif
-
-#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-typedef struct _SMART_ANTENNA_TRAINNING_ {
-	u4Byte	latch_time;
-	BOOLEAN	pkt_skip_statistic_en;
-	u4Byte	fix_beam_pattern_en;
-	u4Byte	fix_training_num_en;
-	u4Byte	fix_beam_pattern_codeword;
-	u4Byte	update_beam_codeword;
-	u4Byte	ant_num; /*number of smart beam antenna*/
-	u4Byte	beam_patten_num_each_ant;/*number of  beam can be switched in each antenna*/
-	u4Byte	data_codeword_bit_num;
-	u4Byte	per_beam_training_pkt_num;
-	u1Byte	decision_holding_period;
-	u4Byte	pkt_counter;
-	u4Byte	fast_training_beam_num;
-	u4Byte	pre_fast_training_beam_num;
-	u4Byte	pkt_rssi_pre[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
-	u4Byte	pkt_rssi_sum[8][SUPPORT_BEAM_PATTERN_NUM];
-	u4Byte	pkt_rssi_cnt[8][SUPPORT_BEAM_PATTERN_NUM];
-	u4Byte	rx_idle_beam[SUPPORT_RF_PATH_NUM];
-	u4Byte	pre_codeword;
-	BOOLEAN	force_update_beam_en;
-
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	RT_WORK_ITEM	hl_smart_antenna_workitem;
-	RT_WORK_ITEM	hl_smart_antenna_decision_workitem;	
-	#endif
-
-} SAT_T, *pSAT_T;
-#endif
-
-typedef struct _FAST_ANTENNA_TRAINNING_
-{
-	u1Byte	Bssid[6];
-	u1Byte	antsel_rx_keep_0;
-	u1Byte	antsel_rx_keep_1;
-	u1Byte	antsel_rx_keep_2;
-	u1Byte	antsel_rx_keep_3;
-	u4Byte	antSumRSSI[7];
-	u4Byte	antRSSIcnt[7];
-	u4Byte	antAveRSSI[7];
-	u1Byte	FAT_State;
-	u4Byte	TrainIdx;
-	u1Byte	antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
-	u1Byte	antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
-	u1Byte	antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	MainAnt_Sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	AuxAnt_Sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	MainAnt_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	AuxAnt_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u1Byte	RxIdleAnt;
-	u1Byte	AntDiv_OnOff;
-	BOOLEAN	bBecomeLinked;
-	u4Byte	MinMaxRSSI;
-	u1Byte	idx_AntDiv_counter_2G;
-	u1Byte	idx_AntDiv_counter_5G;
-	u1Byte	AntDiv_2G_5G;
-	u4Byte    CCK_counter_main;
-	u4Byte    CCK_counter_aux;	
-	u4Byte    OFDM_counter_main;
-	u4Byte    OFDM_counter_aux;
-
-	#ifdef ODM_EVM_ENHANCE_ANTDIV
-	u4Byte	MainAntEVM_Sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	AuxAntEVM_Sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	MainAntEVM_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	AuxAntEVM_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	BOOLEAN	EVM_method_enable;
-	u1Byte	TargetAnt_EVM;
-	u1Byte	TargetAnt_CRC32;
-	u1Byte	TargetAnt_enhance;
-	u1Byte	pre_TargetAnt_enhance;
-	u2Byte	Main_MPDU_OK_cnt;
-	u2Byte	Aux_MPDU_OK_cnt;	
-
-	u4Byte	CRC32_Ok_Cnt;
-	u4Byte	CRC32_Fail_Cnt;
-	u4Byte	MainCRC32_Ok_Cnt;
-	u4Byte	AuxCRC32_Ok_Cnt;
-	u4Byte	MainCRC32_Fail_Cnt;
-	u4Byte	AuxCRC32_Fail_Cnt;
-	#endif	
-	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	u4Byte    CCK_CtrlFrame_Cnt_main;
-	u4Byte    CCK_CtrlFrame_Cnt_aux;
-	u4Byte    OFDM_CtrlFrame_Cnt_main;
-	u4Byte    OFDM_CtrlFrame_Cnt_aux;
-	u4Byte	MainAnt_CtrlFrame_Sum;
-	u4Byte	AuxAnt_CtrlFrame_Sum;
-	u4Byte	MainAnt_CtrlFrame_Cnt;
-	u4Byte	AuxAnt_CtrlFrame_Cnt;
-	#endif
-	BOOLEAN	fix_ant_bfee;
-	BOOLEAN	enable_ctrl_frame_antdiv;
-	BOOLEAN	use_ctrl_frame_antdiv;
-	u1Byte	hw_antsw_occur;
-}FAT_T,*pFAT_T;
-
-
-//1 ============================================================
-//1  enumeration
-//1 ============================================================
-
-
-
-typedef enum _FAT_STATE /*Fast antenna training*/
-{
-	FAT_BEFORE_LINK_STATE	= 0,
-	FAT_PREPARE_STATE			= 1,
-	FAT_TRAINING_STATE		= 2,
-	FAT_DECISION_STATE		= 3
-}FAT_STATE_E, *PFAT_STATE_E;
-
-typedef enum _ANT_DIV_TYPE
-{
-	CG_TRX_HW_ANTDIV			= 0x01,
-	CGCS_RX_HW_ANTDIV		= 0x02,
-	CG_TRX_SMART_ANTDIV		= 0x03,
-	S0S1_SW_ANTDIV			= 0x04, /*8723B intrnal switch S0 S1*/
-	HL_SW_SMART_ANT_TYPE1	= 0x10 /*Hong-Lin Smart antenna use for 8821AE which is a 2 Ant. entitys, and each Ant. is equipped with 4 antenna patterns*/
-}ANT_DIV_TYPE_E, *PANT_DIV_TYPE_E;
-
-
-//1 ============================================================
-//1  function prototype
-//1 ============================================================
-
-
-VOID
-ODM_StopAntennaSwitchDm(
-	IN	PVOID	pDM_VOID
-	);
-VOID
-ODM_SetAntConfig(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte		antSetting	// 0=A, 1=B, 2=C, ....
-	);
-
-
-#define SwAntDivRestAfterLink	ODM_SwAntDivRestAfterLink
-
-VOID ODM_SwAntDivRestAfterLink(	
-	IN	PVOID	pDM_VOID
-	);
-
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-
-VOID
-ODM_UpdateRxIdleAnt(
-	IN		PVOID		pDM_VOID, 
-	IN		 u1Byte		Ant
-);
-
-#if (RTL8723B_SUPPORT == 1)
-VOID
-ODM_UpdateRxIdleAnt_8723B(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Ant,
-	IN		u4Byte			DefaultAnt, 
-	IN		u4Byte			OptionalAnt
-);
-#endif
-
-#if (RTL8188F_SUPPORT == 1)
-VOID
-phydm_update_rx_idle_antenna_8188F(
-	IN	PVOID	pDM_VOID,
-	IN	u4Byte	default_ant
-);
-#endif
-
-
-#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-ODM_SW_AntDiv_Callback(
-	IN 	PRT_TIMER		pTimer
-	);
-
-VOID
-ODM_SW_AntDiv_WorkitemCallback(
-	IN	PVOID	pContext
-	);
-
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-VOID
-ODM_SW_AntDiv_WorkitemCallback(
-	IN PVOID	pContext
-);
-
-VOID
-ODM_SW_AntDiv_Callback(
-	void 		*FunctionContext
-	);
-
-#endif
-
-VOID
-odm_S0S1_SwAntDivByCtrlFrame(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Step
-);
-
-VOID
-odm_AntselStatisticsOfCtrlFrame(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			antsel_tr_mux,
-	IN		u4Byte			RxPWDBAll
-);
-
-VOID
-odm_S0S1_SwAntDivByCtrlFrame_ProcessRSSI(
-	IN		PVOID				pDM_VOID,
-	IN		PVOID		p_phy_info_void,
-	IN		PVOID		p_pkt_info_void
-);
-
-#endif
-
-#ifdef ODM_EVM_ENHANCE_ANTDIV
-VOID
-odm_EVM_FastAntTrainingCallback(
-	IN		PVOID		pDM_VOID
-);
-#endif
-
-VOID
-odm_HW_AntDiv(
-	IN		PVOID		pDM_VOID
-);
-
-#if( defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY) ) ||( defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY) )
-VOID
-odm_FastAntTraining(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_FastAntTrainingCallback(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_FastAntTrainingWorkItemCallback(
-	IN		PVOID		pDM_VOID
-);
-#endif
-
-
-#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-phydm_beam_switch_workitem_callback(
-	IN	PVOID	pContext
-	);
-
-VOID
-phydm_beam_decision_workitem_callback(
-	IN	PVOID	pContext
-	);
-
-#endif
-
-VOID
-phydm_update_beam_pattern(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		codeword,
-	IN		u4Byte		codeword_length
-	);
-
-void
-phydm_set_all_ant_same_beam_num(
-	IN		PVOID		pDM_VOID
-	);
-
-VOID
-phydm_hl_smart_ant_cmd(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value,
-	IN		u4Byte		*_used,
-	OUT		char			*output,
-	IN		u4Byte		*_out_len
-);
-
-#endif/*#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1*/
-
-VOID
-ODM_AntDivInit(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-ODM_AntDiv(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_AntselStatistics(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			antsel_tr_mux,
-	IN		u4Byte			MacId,
-	IN		u4Byte			utility,
-	IN		u1Byte			method
-);
-
-VOID
-ODM_Process_RSSIForAntDiv(	
-	IN OUT	PVOID		pDM_VOID,
-	IN		PVOID		p_phy_info_void,
-	IN		PVOID		p_pkt_info_void
-);
-
-
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-VOID
-ODM_SetTxAntByTxInfo(
-	IN		PVOID			pDM_VOID,
-	IN		pu1Byte			pDesc,
-	IN		u1Byte			macId	
-);
-
-#elif(DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-VOID
-ODM_SetTxAntByTxInfo(
-	struct	rtl8192cd_priv		*priv,
-	struct 	tx_desc			*pdesc,
-	unsigned short			aid	
-);
-
-#endif
-
-
-VOID
-ODM_AntDiv_Config(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-ODM_AntDivTimers(
-	IN		PVOID		pDM_VOID,
-	IN 		u1Byte		state
-);
-
-#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
-
-VOID
-ODM_AntDivReset(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_AntennaDiversityInit(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_AntennaDiversity(
-	IN		PVOID		pDM_VOID
-);
-
-
-#endif /*#ifndef	__ODMANTDIV_H__*/
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMANTDIV_H__
+#define    __PHYDMANTDIV_H__
+
+/*#define ANTDIV_VERSION	"2.0"  //2014.11.04*/
+/*#define ANTDIV_VERSION	"2.1"  //2015.01.13  Dino*/
+/*#define ANTDIV_VERSION	"2.2"  2015.01.16  Dino*/
+/*#define ANTDIV_VERSION	"3.1"  2015.07.29  YuChen, remove 92c 92d 8723a*/
+/*#define ANTDIV_VERSION	"3.2"  2015.08.11  Stanley, disable antenna diversity when BT is enable for 8723B*/
+/*#define ANTDIV_VERSION	"3.3"  2015.08.12  Stanley. 8723B does not need to check the antenna is control by BT,
+							because antenna diversity only works when BT is disable or radio off*/
+/*#define ANTDIV_VERSION	"3.4"  2015.08.28  Dino  1.Add 8821A Smart Antenna 2. Add 8188F SW S0S1 Antenna Diversity*/
+/*#define ANTDIV_VERSION	"3.5"  2015.10.07  Stanley  Always check antenna detection result from BT-coex. for 8723B, not from PHYDM*/
+/*#define ANTDIV_VERSION	"3.6"*/  /*2015.11.16  Stanley  */
+/*#define ANTDIV_VERSION	"3.7"*/  /*2015.11.20  Dino Add SmartAnt FAT Patch */
+/*#define ANTDIV_VERSION	"3.8"  2015.12.21  Dino, Add SmartAnt dynamic training packet num */
+/*#define ANTDIV_VERSION	"3.9"  2016.01.05  Dino, Add SmartAnt cmd for converting single & two smtant, and add cmd for adjust truth table */
+#define ANTDIV_VERSION	"4.0"  /*2017.05.25  Mark, Add SW antenna diversity for 8821c because HW transient issue */
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define	ANTDIV_INIT		0xff
+#define	MAIN_ANT	1		/*ant A or ant Main   or S1*/
+#define	AUX_ANT		2		/*AntB or ant Aux   or S0*/
+#define	MAX_ANT		3		/* 3 for AP using*/
+
+#define ANT1_2G 0 /* = ANT2_5G	for 8723D  BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */
+#define ANT2_2G 1 /* = ANT1_5G	for 8723D  BTG S0  RX S0S1 diversity for 8723D, TX fixed at S1 */
+/*smart antenna*/
+#define SUPPORT_RF_PATH_NUM 4
+#define SUPPORT_BEAM_PATTERN_NUM 4
+#define NUM_ANTENNA_8821A	2
+
+#define SUPPORT_BEAM_SET_PATTERN_NUM		16
+
+#define	NO_FIX_TX_ANT		0
+#define	FIX_TX_AT_MAIN	1
+#define	FIX_AUX_AT_MAIN	2
+
+/* Antenna Diversty Control type */
+#define	ODM_AUTO_ANT		0
+#define	ODM_FIX_MAIN_ANT	1
+#define	ODM_FIX_AUX_ANT	2
+
+#define ODM_N_ANTDIV_SUPPORT		(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A)
+#define ODM_AC_ANTDIV_SUPPORT	(ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)
+#define ODM_ANTDIV_SUPPORT		(ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)
+#define ODM_SMART_ANT_SUPPORT	(ODM_RTL8188E | ODM_RTL8192E)
+#define ODM_HL_SMART_ANT_TYPE1_SUPPORT		(ODM_RTL8821 | ODM_RTL8822B)
+
+#define ODM_ANTDIV_2G_SUPPORT_IC			(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D)
+#define ODM_ANTDIV_5G_SUPPORT_IC			(ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C)
+
+#define ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC	(ODM_RTL8192E)
+
+#define ODM_ANTDIV_2G	BIT(0)
+#define ODM_ANTDIV_5G	BIT(1)
+
+#define ANTDIV_ON	1
+#define ANTDIV_OFF	0
+
+#define FAT_ON	1
+#define FAT_OFF	0
+
+#define TX_BY_DESC	1
+#define TX_BY_REG	0
+
+#define RSSI_METHOD	0
+#define EVM_METHOD		1
+#define CRC32_METHOD	2
+#define TP_METHOD		3
+
+#define INIT_ANTDIV_TIMMER		0
+#define CANCEL_ANTDIV_TIMMER	1
+#define RELEASE_ANTDIV_TIMMER	2
+
+#define CRC32_FAIL	1
+#define CRC32_OK	0
+
+#define evm_rssi_th_high	25
+#define evm_rssi_th_low	20
+
+#define NORMAL_STATE_MIAN	1
+#define NORMAL_STATE_AUX	2
+#define TRAINING_STATE		3
+
+#define FORCE_RSSI_DIFF 10
+
+#define CSI_ON	1
+#define CSI_OFF	0
+
+#define DIVON_CSIOFF 1
+#define DIVOFF_CSION 2
+
+#define BDC_DIV_TRAIN_STATE	0
+#define bdc_bfer_train_state	1
+#define BDC_DECISION_STATE		2
+#define BDC_BF_HOLD_STATE		3
+#define BDC_DIV_HOLD_STATE		4
+
+#define BDC_MODE_1 1
+#define BDC_MODE_2 2
+#define BDC_MODE_3 3
+#define BDC_MODE_4 4
+#define BDC_MODE_NULL 0xff
+
+/*SW S0S1 antenna diversity*/
+#define SWAW_STEP_INIT			0xff
+#define SWAW_STEP_PEEK		0
+#define SWAW_STEP_DETERMINE	1
+
+#define RSSI_CHECK_RESET_PERIOD	10
+#define RSSI_CHECK_THRESHOLD		50
+
+/*Hong Lin Smart antenna*/
+#define HL_SMTANT_2WIRE_DATA_LEN 24
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+struct sw_antenna_switch {
+	u8		double_chk_flag;	/*If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than check this antenna again*/
+	u8		try_flag;
+	s32		pre_rssi;
+	u8		cur_antenna;
+	u8		pre_antenna;
+	u8		rssi_trying;
+	u8		reset_idx;
+	u8		train_time;
+	u8		train_time_flag; /*base on RSSI difference between two antennas*/
+	struct phydm_timer_list	phydm_sw_antenna_switch_timer;
+	u32		pkt_cnt_sw_ant_div_by_ctrl_frame;
+	boolean		is_sw_ant_div_by_ctrl_frame;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	phydm_sw_antenna_switch_workitem;
+#endif
+#endif
+
+	/* AntDect (Before link Antenna Switch check) need to be moved*/
+	u16		single_ant_counter;
+	u16		dual_ant_counter;
+	u16		aux_fail_detec_counter;
+	u16		retry_counter;
+	u8		swas_no_link_state;
+	u32		swas_no_link_bk_reg948;
+	boolean		ANTA_ON;	/*To indicate ant A is or not*/
+	boolean		ANTB_ON;	/*To indicate ant B is on or not*/
+	boolean		pre_aux_fail_detec;
+	boolean		rssi_ant_dect_result;
+	u8		ant_5g;
+	u8		ant_2g;
+
+
+};
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+struct _BF_DIV_COEX_ {
+	boolean w_bfer_client[ODM_ASSOCIATE_ENTRY_NUM];
+	boolean w_bfee_client[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
+
+	u8  bd_ccoex_type_wbfer;
+	u8 num_txbfee_client;
+	u8 num_txbfer_client;
+	u8 bdc_try_counter;
+	u8 bdc_hold_counter;
+	u8 bdc_mode;
+	u8 bdc_active_mode;
+	u8 BDC_state;
+	u8 bdc_rx_idle_update_counter;
+	u8 num_client;
+	u8 pre_num_client;
+	u8 num_bf_tar;
+	u8 num_div_tar;
+
+	boolean is_all_div_sta_idle;
+	boolean is_all_bf_sta_idle;
+	boolean bdc_try_flag;
+	boolean BF_pass;
+	boolean DIV_pass;
+};
+#endif
+#endif
+
+
+struct phydm_fat_struct {
+	u8	bssid[6];
+	u8	antsel_rx_keep_0;
+	u8	antsel_rx_keep_1;
+	u8	antsel_rx_keep_2;
+	u8	antsel_rx_keep_3;
+	u32	ant_sum_rssi[7];
+	u32	ant_rssi_cnt[7];
+	u32	ant_ave_rssi[7];
+	u8	fat_state;
+	u8	fat_state_cnt;
+	u32	train_idx;
+	u8	antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	rx_idle_ant;
+	u8	rvrt_val;
+	u8	ant_div_on_off;
+	boolean	is_become_linked;
+	u32	min_max_rssi;
+	u8	idx_ant_div_counter_2g;
+	u8	idx_ant_div_counter_5g;
+	u8	ant_div_2g_5g;
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	/*For 1SS RX phy rate*/
+	u32	main_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	main_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+
+	/*For 2SS RX phy rate*/
+	u32	main_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];	/*2SS with A1+B*/
+	u32	aux_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];	/*2SS with A2+B*/
+	u32	main_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+
+	boolean	evm_method_enable;
+	u8	target_ant_evm;
+	u8	target_ant_crc32;
+	u8	target_ant_tp;
+	u8	target_ant_enhance;
+	u8	pre_target_ant_enhance;
+	u16	main_mpdu_ok_cnt;
+	u16	aux_mpdu_ok_cnt;
+
+	u32	crc32_ok_cnt;
+	u32	crc32_fail_cnt;
+	u32	main_crc32_ok_cnt;
+	u32	aux_crc32_ok_cnt;
+	u32	main_crc32_fail_cnt;
+	u32	aux_crc32_fail_cnt;
+
+	u32	antdiv_tp_main;
+	u32	antdiv_tp_aux;
+	u32	antdiv_tp_main_cnt;
+	u32	antdiv_tp_aux_cnt;
+
+	u8	pre_antdiv_rssi;
+	u8	pre_antdiv_tp;
+#endif
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	u32    cck_ctrl_frame_cnt_main;
+	u32    cck_ctrl_frame_cnt_aux;
+	u32    ofdm_ctrl_frame_cnt_main;
+	u32    ofdm_ctrl_frame_cnt_aux;
+	u32	main_ant_ctrl_frame_sum;
+	u32	aux_ant_ctrl_frame_sum;
+	u32	main_ant_ctrl_frame_cnt;
+	u32	aux_ant_ctrl_frame_cnt;
+#endif
+	u8	b_fix_tx_ant;
+	boolean	fix_ant_bfee;
+	boolean	enable_ctrl_frame_antdiv;
+	boolean	use_ctrl_frame_antdiv;
+	boolean	*is_no_csi_feedback;
+	u8	hw_antsw_occur;
+	u8	*p_force_tx_ant_by_desc;
+	u8	force_tx_ant_by_desc; /*A temp value, will hook to driver team's outer parameter later*/
+	u8    *p_default_s0_s1;
+	u8    default_s0_s1;
+};
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+enum fat_state /*Fast antenna training*/
+{
+	FAT_BEFORE_LINK_STATE	= 0,
+	FAT_PREPARE_STATE			= 1,
+	FAT_TRAINING_STATE		= 2,
+	FAT_DECISION_STATE		= 3
+};
+
+enum ant_div_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,
+	S0S1_SW_ANTDIV          = 0x06, /*8723B intrnal switch S0 S1*/
+	S0S1_TRX_HW_ANTDIV     = 0x07, /*TRX S0S1 diversity for 8723D*/
+	HL_SW_SMART_ANT_TYPE1	= 0x10, /*Hong-Lin Smart antenna use for 8821AE which is a 2 ant. entitys, and each ant. is equipped with 4 antenna patterns*/
+	HL_SW_SMART_ANT_TYPE2	= 0x11 /*Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/
+};
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+
+void
+odm_stop_antenna_switch_dm(
+	void	*dm_void
+);
+
+void
+phydm_enable_antenna_diversity(
+	void			*dm_void
+);
+
+void
+odm_set_ant_config(
+	void	*dm_void,
+	u8		ant_setting	/* 0=A, 1=B, 2=C, .... */
+);
+
+
+#define sw_ant_div_rest_after_link	odm_sw_ant_div_rest_after_link
+
+void odm_sw_ant_div_rest_after_link(
+	void	*dm_void
+);
+
+void
+odm_ant_div_on_off(
+	void		*dm_void,
+	u8		swch
+);
+
+void
+odm_tx_by_tx_desc_or_reg(
+	void		*dm_void,
+	u8		swch
+);
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+
+void
+phydm_antdiv_reset_statistic(
+	void	*dm_void,
+	u32	macid
+);
+
+void
+odm_update_rx_idle_ant(
+	void		*dm_void,
+	u8		ant
+);
+
+void
+phydm_set_antdiv_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+#if (RTL8723B_SUPPORT == 1)
+void
+odm_update_rx_idle_ant_8723b(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+);
+#endif
+
+#if (RTL8188F_SUPPORT == 1)
+void
+phydm_update_rx_idle_antenna_8188F(
+	void	*dm_void,
+	u32	default_ant
+);
+#endif
+
+#if (RTL8723D_SUPPORT == 1)
+
+void
+phydm_set_tx_ant_pwr_8723d(
+	void			*dm_void,
+	u8			ant
+);
+
+void
+odm_update_rx_idle_ant_8723d(
+	void			*dm_void,
+	u8			ant,
+	u32			default_ant,
+	u32			optional_ant
+);
+
+#endif
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_sw_antdiv_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_sw_antdiv_workitem_callback(
+	void	*context
+);
+
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+odm_sw_antdiv_workitem_callback(
+	void	*context
+);
+
+void
+odm_sw_antdiv_callback(
+	void		*function_context
+);
+
+#endif
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame(
+	void			*dm_void,
+	u8			step
+);
+
+void
+odm_antsel_statistics_of_ctrl_frame(
+	void			*dm_void,
+	u8			antsel_tr_mux,
+	u32			rx_pwdb_all
+);
+
+void
+odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
+	void				*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void
+);
+
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+void
+phydm_evm_sw_antdiv_init(
+	void		*dm_void
+);
+
+void
+odm_evm_fast_ant_training_callback(
+	void		*dm_void
+);
+#endif
+
+void
+odm_hw_ant_div(
+	void		*dm_void
+);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+void
+odm_fast_ant_training(
+	void		*dm_void
+);
+
+void
+odm_fast_ant_training_callback(
+	void		*dm_void
+);
+
+void
+odm_fast_ant_training_work_item_callback(
+	void		*dm_void
+);
+#endif
+
+void
+odm_ant_div_init(
+	void		*dm_void
+);
+
+void
+odm_ant_div(
+	void		*dm_void
+);
+
+void
+odm_antsel_statistics(
+	void			*dm_void,
+	void			*phy_info_void,
+	u8			antsel_tr_mux,
+	u32			mac_id,
+	u32			utility,
+	u8			method,
+	u8			is_cck_rate
+);
+
+void
+odm_process_rssi_for_ant_div(
+	void		*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void
+);
+
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+odm_set_tx_ant_by_tx_info(
+	void			*dm_void,
+	u8			*desc,
+	u8			mac_id
+);
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+struct tx_desc; /*declared tx_desc here or compile error happened when enabled 8822B*/
+
+void
+odm_set_tx_ant_by_tx_info(
+	struct	rtl8192cd_priv		*priv,
+	struct	tx_desc			*pdesc,
+	unsigned short			aid
+);
+
+#if 1/*def def CONFIG_WLAN_HAL*/
+void
+odm_set_tx_ant_by_tx_info_hal(
+	struct	rtl8192cd_priv		*priv,
+	void	*pdesc_data,
+	u16		aid
+);
+#endif	/*#ifdef CONFIG_WLAN_HAL*/
+#endif
+
+
+void
+odm_ant_div_config(
+	void		*dm_void
+);
+
+void
+odm_ant_div_timers(
+	void		*dm_void,
+	u8		state
+);
+
+void
+phydm_antdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
+
+void
+odm_ant_div_reset(
+	void		*dm_void
+);
+
+void
+odm_antenna_diversity_init(
+	void		*dm_void
+);
+
+void
+odm_antenna_diversity(
+	void		*dm_void
+);
+
+#endif /*#ifndef	__ODMANTDIV_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_api.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_api.c
new file mode 100644
index 000000000000..cffd2fcf2be5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_api.c
@@ -0,0 +1,1425 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_dynamic_ant_weighting(
+	void		*dm_void
+)
+{
+struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+	#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8197F))
+		phydm_dynamic_ant_weighting_8197f(dm);
+	#endif
+
+	#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8812)) {
+		phydm_dynamic_ant_weighting_8812a(dm);
+	}
+	#endif
+
+	#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8822B)) {
+		phydm_dynamic_ant_weighting_8822b(dm);
+	}
+	#endif
+#endif
+}
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void
+phydm_dyn_ant_weight_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "echo dis_dym_ant_weighting {0/1}\n");
+
+	} else {
+	
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 1) {
+			dm->is_disable_dym_ant_weighting = 1;
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Disable dyn-ant-weighting\n");
+		} else {
+			dm->is_disable_dym_ant_weighting = 0;
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Enable dyn-ant-weighting\n");
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
+
+void
+phydm_iq_gen_en(
+	void		*dm_void
+)
+{
+#ifdef  PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	i;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		for (i = RF_PATH_A; i <= RF_PATH_B; i++) {
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x1); /*RF mode table write enable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x33, 0xF, 3); /*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3E, 0xfffff, 0x00036); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3F, 0xfffff, 0x5AFCE); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x0); /*RF mode table write disable*/
+		}
+	}
+	#endif
+#endif
+}
+
+void
+phydm_dis_cdd(
+	void		*dm_void
+)
+{
+#ifdef  PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x808, 0x3ffff00, 0);
+		odm_set_bb_reg(dm, 0x9ac, 0x1fff, 0);
+		odm_set_bb_reg(dm, 0x9ac, BIT(13), 1);
+	}
+	#endif
+#endif
+}
+
+void
+phydm_pathb_q_matrix_rotate_en(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		phydm_iq_gen_en(dm);
+
+		#ifdef PHYDM_COMMON_API_SUPPORT
+		if (phydm_api_trx_mode(dm, BB_PATH_AB, BB_PATH_AB, true) == false)
+			return;
+		#endif
+
+		phydm_dis_cdd(dm);
+		odm_set_bb_reg(dm, 0x195c, MASKDWORD, 0x40000);	/*Set Q matrix r_v11 =1*/
+		phydm_pathb_q_matrix_rotate(dm, 0);
+		odm_set_bb_reg(dm, 0x191c, BIT(7), 1);		/*Set Q matrix enable*/
+	}
+	#endif
+#endif
+}
+
+void
+phydm_pathb_q_matrix_rotate(
+	void		*dm_void,
+	u16		phase_idx
+)
+{
+#ifdef  PHYDM_COMPILE_IC_2SS
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32	phase_table_0[12] = {0x40000, 0x376CF, 0x20000, 0x00000, 0xFE0000, 0xFC8930, 
+						0xFC0000, 0xFC8930, 0xFDFFFF, 0x000000, 0x020000, 0x0376CF};
+	u32	phase_table_1[12] = {0x00000, 0x1FFFF, 0x376CF, 0x40000, 0x0376CF, 0x01FFFF, 
+						0x000000, 0xFDFFFF, 0xFC8930, 0xFC0000, 0xFC8930, 0xFDFFFF};
+
+	if (phase_idx >= 12) {
+		PHYDM_DBG(dm, ODM_COMP_API, "Phase Set Error: %d\n", phase_idx);
+		return;
+	}
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x1954, 0xffffff, phase_table_0[phase_idx]); /*Set Q matrix r_v21*/
+		odm_set_bb_reg(dm, 0x1950, 0xffffff, phase_table_1[phase_idx]);
+	}
+	#endif
+#endif
+}
+
+void
+phydm_init_trx_antenna_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	
+	if (dm->support_ic_type & (ODM_RTL8814A)) {
+		u8	rx_ant = 0, tx_ant = 0;
+
+		rx_ant = (u8)odm_get_bb_reg(dm, ODM_REG(BB_RX_PATH, dm), ODM_BIT(BB_RX_PATH, dm));
+		tx_ant = (u8)odm_get_bb_reg(dm, ODM_REG(BB_TX_PATH, dm), ODM_BIT(BB_TX_PATH, dm));
+		dm->tx_ant_status = (tx_ant & 0xf);
+		dm->rx_ant_status = (rx_ant & 0xf);
+	} else if (dm->support_ic_type & (ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B)) {/* JJ ADD 20161014 */
+		dm->tx_ant_status = 0x1;
+		dm->rx_ant_status = 0x1;
+
+	}
+}
+
+void
+phydm_config_ofdm_tx_path(
+	void			*dm_void,
+	u32			path
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if ((RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1))
+	u8	ofdm_tx_path = 0x33;
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+		if (path == BB_PATH_A) {
+			odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x81121111);
+			/**/
+		} else if (path == BB_PATH_B) {
+			odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x82221222);
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x83321333);
+			/**/
+		}
+
+
+	}
+#endif
+
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8812)) {
+		if (path == BB_PATH_A) {
+			ofdm_tx_path = 0x11;
+			/**/
+		} else if (path == BB_PATH_B) {
+			ofdm_tx_path = 0x22;
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			ofdm_tx_path = 0x33;
+			/**/
+		}
+
+		odm_set_bb_reg(dm, 0x80c, 0xff00, ofdm_tx_path);
+	}
+#endif
+}
+
+void
+phydm_config_ofdm_rx_path(
+	void			*dm_void,
+	u32			path
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	ofdm_rx_path = 0;
+
+
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+#if (RTL8192E_SUPPORT == 1)
+		if (path == BB_PATH_A) {
+			ofdm_rx_path = 1;
+			/**/
+		} else if (path == BB_PATH_B) {
+			ofdm_rx_path = 2;
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			ofdm_rx_path = 3;
+			/**/
+		}
+
+		odm_set_bb_reg(dm, 0xC04, 0xff, (((ofdm_rx_path) << 4) | ofdm_rx_path));
+		odm_set_bb_reg(dm, 0xD04, 0xf, ofdm_rx_path);
+#endif
+	}
+#if (RTL8812A_SUPPORT || RTL8822B_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8822B)) {
+		if (path == BB_PATH_A) {
+			ofdm_rx_path = 1;
+			/**/
+		} else if (path == BB_PATH_B) {
+			ofdm_rx_path = 2;
+			/**/
+		} else  if (path == BB_PATH_AB) {
+			ofdm_rx_path = 3;
+			/**/
+		}
+
+		odm_set_bb_reg(dm, 0x808, MASKBYTE0, ((ofdm_rx_path << 4) | ofdm_rx_path));
+	}
+#endif
+}
+
+void
+phydm_config_cck_rx_antenna_init(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	/*CCK 2R CCA parameters*/
+	odm_set_bb_reg(dm, 0xa00, BIT(15), 0x0); /*Disable antenna diversity*/
+	odm_set_bb_reg(dm, 0xa70, BIT(7), 0); /*Concurrent CCA at LSB & USB*/
+	odm_set_bb_reg(dm, 0xa74, BIT(8), 0); /*RX path diversity enable*/
+	odm_set_bb_reg(dm, 0xa14, BIT(7), 0); /*r_en_mrc_antsel*/
+	odm_set_bb_reg(dm, 0xa20, (BIT(5) | BIT(4)), 1); /*MBC weighting*/
+
+	if (dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F)) {
+		odm_set_bb_reg(dm, 0xa08, BIT(28), 1); /*r_cck_2nd_sel_eco*/
+		/**/
+	} else if (dm->support_ic_type & ODM_RTL8814A) {
+		odm_set_bb_reg(dm, 0xa84, BIT(28), 1); /*2R CCA only*/
+		/**/
+	}
+#endif
+}
+
+void
+phydm_config_cck_rx_path(
+	void		*dm_void,
+	enum bb_path			path
+)
+{
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	path_div_select = 0;
+	u8	cck_path[2] = {0};
+	u8	en_2R_path = 0;
+	u8	en_2R_mrc = 0;
+	u8	i = 0, j =0; 
+	u8	num_enable_path = 0;
+	u8	cck_mrc_max_path = 2;
+	
+	for (i = 0; i < 4; i++) {
+		if (path & BIT(i)) { /*ex: PHYDM_ABCD*/
+			num_enable_path++;
+			cck_path[j] = i;
+			j++;
+		}
+		if (num_enable_path >= cck_mrc_max_path)
+			break;
+	}
+
+	if (num_enable_path > 1) {
+		path_div_select = 1;
+		en_2R_path = 1;
+		en_2R_mrc = 1;
+	} else {
+		path_div_select = 0;
+		en_2R_path = 0;
+		en_2R_mrc = 0;
+	}
+		
+	odm_set_bb_reg(dm, 0xa04, (BIT(27) | BIT(26)), cck_path[0]);	/*CCK_1 input signal path*/
+	odm_set_bb_reg(dm, 0xa04, (BIT(25) | BIT(24)), cck_path[1]);	/*CCK_2 input signal path*/
+	odm_set_bb_reg(dm, 0xa74, BIT(8), path_div_select);	/*enable Rx path diversity*/
+	odm_set_bb_reg(dm, 0xa2c, BIT(18), en_2R_path);	/*enable 2R Rx path*/
+	odm_set_bb_reg(dm, 0xa2c, BIT(22), en_2R_mrc);	/*enable 2R MRC*/
+	
+#endif
+}
+
+void
+phydm_config_cck_tx_path(
+	void		*dm_void,
+	enum	bb_path	path
+)
+{
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (path == BB_PATH_A)
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0x8);
+	else if (path == BB_PATH_B)
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0x4);
+	else if (path == BB_PATH_AB)
+		odm_set_bb_reg(dm, 0xa04, 0xf0000000, 0xc);
+#endif
+}
+
+void
+phydm_config_trx_path(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/*
+	dm_value[0]: 0:CCK, 1:OFDM
+	dm_value[1]: 1:TX, 2:RX
+	dm_value[2]: 1:path_A, 2:path_B, 3:path_AB
+	*/
+	
+	/* CCK */
+	if (dm_value[0] == 0) {
+		if (dm_value[1] == 1) { /*TX*/
+			if (dm_value[2] == 1)
+				phydm_config_cck_tx_path(dm, BB_PATH_A);
+			else if (dm_value[2] == 2)
+				phydm_config_cck_tx_path(dm, BB_PATH_B);
+			else if (dm_value[2] == 3)
+				phydm_config_cck_tx_path(dm, BB_PATH_AB);
+		} else if (dm_value[1] == 2) { /*RX*/
+
+			phydm_config_cck_rx_antenna_init(dm);
+
+			if (dm_value[2] == 1)
+				phydm_config_cck_rx_path(dm, BB_PATH_A);
+			else  if (dm_value[2] == 2)
+				phydm_config_cck_rx_path(dm, BB_PATH_B);
+			else  if (dm_value[2] == 3) {
+				phydm_config_cck_rx_path(dm, BB_PATH_AB);
+			}
+		}
+	}
+	/* OFDM */
+	else if (dm_value[0] == 1) {
+		if (dm_value[1] == 1) { /*TX*/
+			phydm_config_ofdm_tx_path(dm, dm_value[2]);
+			/**/
+		} else if (dm_value[1] == 2) { /*RX*/
+			phydm_config_ofdm_rx_path(dm, dm_value[2]);
+			/**/
+		}
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+			"PHYDM Set path [%s] [%s] = [%s%s%s%s]\n",
+			(dm_value[0] == 1) ? "OFDM" : "CCK",
+			(dm_value[1] == 1) ? "TX" : "RX",
+			(dm_value[2] & 0x1) ? "A" : "",
+			(dm_value[2] & 0x2) ? "B" : "",
+			(dm_value[2] & 0x4) ? "C" : "",
+			(dm_value[2] & 0x8) ? "D" : ""
+			);
+
+}
+
+void
+phydm_tx_2path(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
+		phydm_api_trx_mode(dm, BB_PATH_AB, (enum bb_path)dm->rx_ant_status, true);
+	}
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) {
+		phydm_config_cck_tx_path(dm, BB_PATH_AB);
+		phydm_config_ofdm_tx_path(dm, BB_PATH_AB);
+	}
+#endif
+}
+
+void
+phydm_stop_3_wire(
+	void		*dm_void,
+	u8		set_type
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (set_type == PHYDM_SET) {
+		/*[Stop 3-wires]*/
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, 0xc00, 0xf, 0x4);/*	hardware 3-wire off */
+			odm_set_bb_reg(dm, 0xe00, 0xf, 0x4);/*	hardware 3-wire off */
+		} else {
+			odm_set_bb_reg(dm, 0x88c, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+		}
+		
+	} else {  /*if (set_type == PHYDM_REVERT)*/
+		
+		/*[Start 3-wires]*/
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, 0xc00, 0xf, 0x7);/*	hardware 3-wire on */
+			odm_set_bb_reg(dm, 0xe00, 0xf, 0x7);/*	hardware 3-wire on */
+		} else {
+			odm_set_bb_reg(dm, 0x88c, 0xf00000, 0x0);	/* 3 wire enable 88c[23:20]=0x0 */
+		}
+	}
+}
+
+u8
+phydm_stop_ic_trx(
+	void		*dm_void,
+	u8		set_type
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	phydm_api_stuc 	*api = &dm->api_table;
+	u32		i;
+	u8		trx_idle_success = false;
+	u32		dbg_port_value = 0;
+
+	if (set_type == PHYDM_SET) {
+		/*[Stop TRX]---------------------------------------------------------------------*/
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, 0x0) == false) /*set debug port to 0x0*/
+			return PHYDM_SET_FAIL;
+		
+		for (i = 0; i<10000; i++) {
+			dbg_port_value = phydm_get_bb_dbg_port_value(dm);
+			if ((dbg_port_value & (BIT(17) | BIT(3))) == 0)	/* PHYTXON && CCA_all */ {
+				PHYDM_DBG(dm, ODM_COMP_API, "PSD wait for ((%d)) times\n", i);
+				
+				trx_idle_success = true;
+				break;
+			}
+		}
+		phydm_release_bb_dbg_port(dm);
+		
+		if (trx_idle_success) {
+			api->tx_queue_bitmap = (u8)odm_get_bb_reg(dm, 0x520, 0xff0000);
+			
+			odm_set_bb_reg(dm, 0x520, 0xff0000, 0xff); /*pause all TX queue*/
+			
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				odm_set_bb_reg(dm, 0x808, BIT(28), 0); /*disable CCK block*/
+				odm_set_bb_reg(dm, 0x838, BIT(1), 1); /*disable OFDM RX CCA*/
+			} else {
+				/*TBD*/
+				odm_set_bb_reg(dm, 0x800, BIT(24), 0); /* disable whole CCK block */
+
+
+				api->rx_iqc_reg_1 = odm_get_bb_reg(dm, 0xc14, MASKDWORD);
+				api->rx_iqc_reg_2 = odm_get_bb_reg(dm, 0xc1c, MASKDWORD);
+				
+				odm_set_bb_reg(dm, 0xc14, MASKDWORD, 0x0); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
+				odm_set_bb_reg(dm, 0xc1c, MASKDWORD, 0x0);
+			}
+				
+		} else {
+			return PHYDM_SET_FAIL;
+		}
+		
+		return PHYDM_SET_SUCCESS;
+		
+	} else {  /*if (set_type == PHYDM_REVERT)*/
+
+		odm_set_bb_reg(dm, 0x520, 0xff0000, (u32)(api->tx_queue_bitmap)); /*Release all TX queue*/
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, 0x808, BIT(28), 1); /*enable CCK block*/
+			odm_set_bb_reg(dm, 0x838, BIT(1), 0); /*enable OFDM RX CCA*/
+		} else {
+			/*TBD*/
+			odm_set_bb_reg(dm, 0x800, BIT(24), 1); /* enable whole CCK block */
+			
+			odm_set_bb_reg(dm, 0xc14, MASKDWORD, api->rx_iqc_reg_1); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
+			odm_set_bb_reg(dm, 0xc1c, MASKDWORD, api->rx_iqc_reg_2);
+		}
+
+		return PHYDM_SET_SUCCESS;
+	}
+	
+}
+
+void
+phydm_set_ext_switch(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			ext_ant_switch =  dm_value[0];
+
+#if (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
+		/*Output Pin Settings*/
+		odm_set_mac_reg(dm, 0x4C, BIT(23), 0); /*select DPDT_P and DPDT_N as output pin*/
+		odm_set_mac_reg(dm, 0x4C, BIT(24), 1); /*by WLAN control*/
+
+		odm_set_bb_reg(dm, 0xCB4, 0xFF, 77); /*DPDT_N = 1b'0*/  /*DPDT_P = 1b'0*/
+
+		if (ext_ant_switch == MAIN_ANT) {
+			odm_set_bb_reg(dm, 0xCB4, (BIT(29) | BIT(28)), 1);
+			PHYDM_DBG(dm, ODM_COMP_API, "***8821A set ant switch = 2b'01 (Main)\n");
+		} else if (ext_ant_switch == AUX_ANT) {
+			odm_set_bb_reg(dm, 0xCB4, BIT(29) | BIT(28), 2);
+			PHYDM_DBG(dm, ODM_COMP_API, "***8821A set ant switch = 2b'10 (Aux)\n");
+		}
+	}
+#endif
+}
+
+void
+phydm_csi_mask_enable(
+	void		*dm_void,
+	u32		enable
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = 0;
+
+	reg_value = (enable == FUNC_ENABLE) ? 1 : 0;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xD2C, BIT(28), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable CSI Mask:  Reg 0xD2C[28] = ((0x%x))\n", reg_value);
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x874, BIT(0), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable CSI Mask:  Reg 0x874[0] = ((0x%x))\n", reg_value);
+	}
+
+}
+
+void
+phydm_clean_all_csi_mask(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xD40, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0xD44, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0xD48, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0xD4c, MASKDWORD, 0);
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x880, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x884, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x888, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x88c, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x890, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x894, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x898, MASKDWORD, 0);
+		odm_set_bb_reg(dm, 0x89c, MASKDWORD, 0);
+	}
+}
+
+void
+phydm_set_csi_mask_reg(
+	void		*dm_void,
+	u32		tone_idx_tmp,
+	u8		tone_direction
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		byte_offset, bit_offset;
+	u32		target_reg;
+	u8		reg_tmp_value;
+	u32		tone_num = 64;
+	u32		tone_num_shift = 0;
+	u32		csi_mask_reg_p = 0, csi_mask_reg_n = 0;
+
+	/* calculate real tone idx*/
+	if ((tone_idx_tmp % 10) >= 5)
+		tone_idx_tmp += 10;
+
+	tone_idx_tmp = (tone_idx_tmp / 10);
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		tone_num = 64;
+		csi_mask_reg_p = 0xD40;
+		csi_mask_reg_n = 0xD48;
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		tone_num = 128;
+		csi_mask_reg_p = 0x880;
+		csi_mask_reg_n = 0x890;
+	}
+
+	if (tone_direction == FREQ_POSITIVE) {
+		if (tone_idx_tmp >= (tone_num - 1))
+			tone_idx_tmp = (tone_num - 1);
+
+		byte_offset = (u8)(tone_idx_tmp >> 3);
+		bit_offset = (u8)(tone_idx_tmp & 0x7);
+		target_reg = csi_mask_reg_p + byte_offset;
+
+	} else {
+		tone_num_shift = tone_num;
+
+		if (tone_idx_tmp >= tone_num)
+			tone_idx_tmp = tone_num;
+
+		tone_idx_tmp = tone_num - tone_idx_tmp;
+
+		byte_offset = (u8)(tone_idx_tmp >> 3);
+		bit_offset = (u8)(tone_idx_tmp & 0x7);
+		target_reg = csi_mask_reg_n + byte_offset;
+	}
+
+	reg_tmp_value = odm_read_1byte(dm, target_reg);
+	PHYDM_DBG(dm, ODM_COMP_API, "Pre Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n", (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value);
+	reg_tmp_value |= BIT(bit_offset);
+	odm_write_1byte(dm, target_reg, reg_tmp_value);
+	PHYDM_DBG(dm, ODM_COMP_API, "New Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n", (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value);
+}
+
+void
+phydm_set_nbi_reg(
+	void		*dm_void,
+	u32		tone_idx_tmp,
+	u32		bw
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32	nbi_table_128[NBI_TABLE_SIZE_128] = {25, 55, 85, 115, 135, 155, 185, 205, 225, 245,		/*1~10*/		/*tone_idx X 10*/
+		     265, 285, 305, 335, 355, 375, 395, 415, 435, 455,	/*11~20*/
+					     485, 505, 525, 555, 585, 615, 635
+						};				/*21~27*/
+
+	u32	nbi_table_256[NBI_TABLE_SIZE_256] = { 25,   55,   85, 115, 135, 155, 175, 195, 225, 245,	/*1~10*/
+		265, 285, 305, 325, 345, 365, 385, 405, 425, 445,	/*11~20*/
+		465, 485, 505, 525, 545, 565, 585, 605, 625, 645,	/*21~30*/
+		665, 695, 715, 735, 755, 775, 795, 815, 835, 855,	/*31~40*/
+		875, 895, 915, 935, 955, 975, 995, 1015, 1035, 1055,	/*41~50*/
+		      1085, 1105, 1125, 1145, 1175, 1195, 1225, 1255, 1275
+						};	/*51~59*/
+
+	u32	reg_idx = 0;
+	u32	i;
+	u8	nbi_table_idx = FFT_128_TYPE;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+
+		nbi_table_idx = FFT_128_TYPE;
+	else if (dm->support_ic_type & ODM_IC_11AC_1_SERIES)
+
+		nbi_table_idx = FFT_256_TYPE;
+	else if (dm->support_ic_type & ODM_IC_11AC_2_SERIES) {
+		if (bw == 80)
+			nbi_table_idx = FFT_256_TYPE;
+		else /*20M, 40M*/
+			nbi_table_idx = FFT_128_TYPE;
+	}
+
+	if (nbi_table_idx == FFT_128_TYPE) {
+		for (i = 0; i < NBI_TABLE_SIZE_128; i++) {
+			if (tone_idx_tmp < nbi_table_128[i]) {
+				reg_idx = i + 1;
+				break;
+			}
+		}
+
+	} else if (nbi_table_idx == FFT_256_TYPE) {
+		for (i = 0; i < NBI_TABLE_SIZE_256; i++) {
+			if (tone_idx_tmp < nbi_table_256[i]) {
+				reg_idx = i + 1;
+				break;
+			}
+		}
+	}
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xc40, 0x1f000000, reg_idx);
+		PHYDM_DBG(dm, ODM_COMP_API, "Set tone idx:  Reg0xC40[28:24] = ((0x%x))\n", reg_idx);
+		/**/
+	} else {
+		odm_set_bb_reg(dm, 0x87c, 0xfc000, reg_idx);
+		PHYDM_DBG(dm, ODM_COMP_API, "Set tone idx: Reg0x87C[19:14] = ((0x%x))\n", reg_idx);
+		/**/
+	}
+}
+
+
+void
+phydm_nbi_enable(
+	void		*dm_void,
+	u32		enable
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = 0;
+
+	reg_value = (enable == FUNC_ENABLE) ? 1 : 0;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, 0xc40, BIT(9), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable NBI Reg0xC40[9] = ((0x%x))\n", reg_value);
+
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (dm->support_ic_type & (ODM_RTL8822B|ODM_RTL8821C)) {
+			odm_set_bb_reg(dm, 0x87c, BIT(13), reg_value);
+			odm_set_bb_reg(dm, 0xc20, BIT(28), reg_value);
+			if (dm->rf_type > RF_1T1R)
+				odm_set_bb_reg(dm, 0xe20, BIT(28), reg_value);
+		} else
+			odm_set_bb_reg(dm, 0x87c, BIT(13), reg_value);
+		PHYDM_DBG(dm, ODM_COMP_API, "Enable NBI Reg0x87C[13] = ((0x%x))\n", reg_value);
+	}
+}
+
+u8
+phydm_calculate_fc(
+	void		*dm_void,
+	u32		channel,
+	u32		bw,
+	u32		second_ch,
+	u32		*fc_in
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		fc = *fc_in;
+	u32		start_ch_per_40m[NUM_START_CH_40M] = {36, 44, 52, 60, 100, 108, 116, 124, 132, 140, 149, 157, 165, 173};
+	u32		start_ch_per_80m[NUM_START_CH_80M] = {36, 52, 100, 116, 132, 149, 165};
+	u32		*start_ch = &start_ch_per_40m[0];
+	u32		num_start_channel = NUM_START_CH_40M;
+	u32		channel_offset = 0;
+	u32		i;
+
+	/*2.4G*/
+	if (channel <= 14 && channel > 0) {
+		if (bw == 80)
+			return	PHYDM_SET_FAIL;
+
+		fc = 2412 + (channel - 1) * 5;
+
+		if (bw == 40 && (second_ch == PHYDM_ABOVE)) {
+			if (channel >= 10) {
+				PHYDM_DBG(dm, ODM_COMP_API, "CH = ((%d)), Scnd_CH = ((%d)) Error setting\n", channel, second_ch);
+				return	PHYDM_SET_FAIL;
+			}
+			fc += 10;
+		} else if (bw == 40 && (second_ch == PHYDM_BELOW)) {
+			if (channel <= 2) {
+				PHYDM_DBG(dm, ODM_COMP_API, "CH = ((%d)), Scnd_CH = ((%d)) Error setting\n", channel, second_ch);
+				return	PHYDM_SET_FAIL;
+			}
+			fc -= 10;
+		}
+	}
+	/*5G*/
+	else if (channel >= 36 && channel <= 177) {
+		if (bw != 20) {
+			if (bw == 40) {
+				num_start_channel = NUM_START_CH_40M;
+				start_ch = &start_ch_per_40m[0];
+				channel_offset = CH_OFFSET_40M;
+			} else if (bw == 80) {
+				num_start_channel = NUM_START_CH_80M;
+				start_ch = &start_ch_per_80m[0];
+				channel_offset = CH_OFFSET_80M;
+			}
+
+			for (i = 0; i < (num_start_channel - 1); i++) {
+				if (channel < start_ch[i + 1]) {
+					channel = start_ch[i] + channel_offset;
+					break;
+				}
+			}
+			PHYDM_DBG(dm, ODM_COMP_API, "Mod_CH = ((%d))\n", channel);
+		}
+
+		fc = 5180 + (channel - 36) * 5;
+
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "CH = ((%d)) Error setting\n", channel);
+		return	PHYDM_SET_FAIL;
+	}
+
+	*fc_in = fc;
+
+	return PHYDM_SET_SUCCESS;
+}
+
+
+u8
+phydm_calculate_intf_distance(
+	void		*dm_void,
+	u32		bw,
+	u32		fc,
+	u32		f_interference,
+	u32		*tone_idx_tmp_in
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		bw_up, bw_low;
+	u32		int_distance;
+	u32		tone_idx_tmp;
+	u8		set_result = PHYDM_SET_NO_NEED;
+
+	bw_up = fc + bw / 2;
+	bw_low = fc - bw / 2;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "[f_l, fc, fh] = [ %d, %d, %d ], f_int = ((%d))\n", bw_low, fc, bw_up, f_interference);
+
+	if ((f_interference >= bw_low) && (f_interference <= bw_up)) {
+		int_distance = (fc >= f_interference) ? (fc - f_interference) : (f_interference - fc);
+		tone_idx_tmp = (int_distance << 5); /* =10*(int_distance /0.3125) */
+		PHYDM_DBG(dm, ODM_COMP_API, "int_distance = ((%d MHz)) Mhz, tone_idx_tmp = ((%d.%d))\n", int_distance, (tone_idx_tmp / 10), (tone_idx_tmp % 10));
+		*tone_idx_tmp_in = tone_idx_tmp;
+		set_result = PHYDM_SET_SUCCESS;
+	}
+
+	return	set_result;
+
+}
+
+
+u8
+phydm_csi_mask_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		second_ch
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		fc = 2412;
+	u8		tone_direction;
+	u32		tone_idx_tmp;
+	u8		set_result = PHYDM_SET_SUCCESS;
+
+	if (enable == FUNC_DISABLE) {
+		set_result = PHYDM_SET_SUCCESS;
+		phydm_clean_all_csi_mask(dm);
+
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Set CSI MASK_] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			channel, bw, f_interference, (((bw == 20) || (channel > 14)) ? "Don't care" : (second_ch == PHYDM_ABOVE) ? "H" : "L"));
+
+		/*calculate fc*/
+		if (phydm_calculate_fc(dm, channel, bw, second_ch, &fc) == PHYDM_SET_FAIL)
+			set_result = PHYDM_SET_FAIL;
+
+		else {
+			/*calculate interference distance*/
+			if (phydm_calculate_intf_distance(dm, bw, fc, f_interference, &tone_idx_tmp) == PHYDM_SET_SUCCESS) {
+				tone_direction = (f_interference >= fc) ? FREQ_POSITIVE : FREQ_NEGATIVE;
+				phydm_set_csi_mask_reg(dm, tone_idx_tmp, tone_direction);
+				set_result = PHYDM_SET_SUCCESS;
+			} else
+				set_result = PHYDM_SET_NO_NEED;
+		}
+	}
+
+	if (set_result == PHYDM_SET_SUCCESS)
+		phydm_csi_mask_enable(dm, enable);
+	else
+		phydm_csi_mask_enable(dm, FUNC_DISABLE);
+
+	return	set_result;
+}
+
+u8
+phydm_nbi_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		second_ch
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32		fc = 2412;
+	u32		tone_idx_tmp;
+	u8		set_result = PHYDM_SET_SUCCESS;
+
+	if (enable == FUNC_DISABLE)
+		set_result = PHYDM_SET_SUCCESS;
+
+	else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Set NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			channel, bw, f_interference, (((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "Don't care" : (second_ch == PHYDM_ABOVE) ? "H" : "L"));
+
+		/*calculate fc*/
+		if (phydm_calculate_fc(dm, channel, bw, second_ch, &fc) == PHYDM_SET_FAIL)
+			set_result = PHYDM_SET_FAIL;
+
+		else {
+			/*calculate interference distance*/
+			if (phydm_calculate_intf_distance(dm, bw, fc, f_interference, &tone_idx_tmp) == PHYDM_SET_SUCCESS) {
+				phydm_set_nbi_reg(dm, tone_idx_tmp, bw);
+				set_result = PHYDM_SET_SUCCESS;
+			} else
+				set_result = PHYDM_SET_NO_NEED;
+		}
+	}
+
+	if (set_result == PHYDM_SET_SUCCESS)
+		phydm_nbi_enable(dm, enable);
+	else
+		phydm_nbi_enable(dm, FUNC_DISABLE);
+
+	return	set_result;
+}
+
+void
+phydm_api_debug(
+	void		*dm_void,
+	u32		function_map,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			channel =  dm_value[1];
+	u32			bw =  dm_value[2];
+	u32			f_interference =  dm_value[3];
+	u32			second_ch =  dm_value[4];
+	u8			set_result = 0;
+
+	/*PHYDM_API_NBI*/
+	/*-------------------------------------------------------------------------------------------------------------------------------*/
+	if (function_map == PHYDM_API_NBI) {
+		if (dm_value[0] == 100) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[HELP-NBI]  EN(on=1, off=2)   CH   BW(20/40/80)  f_intf(Mhz)    Scnd_CH(L=1, H=2)\n");
+			return;
+
+		} else if (dm_value[0] == FUNC_ENABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Enable NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+				       channel, bw, f_interference,
+				       ((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "Don't care" : ((second_ch == PHYDM_ABOVE) ? "H" : "L"));
+			set_result = phydm_nbi_setting(dm, FUNC_ENABLE, channel, bw, f_interference, second_ch);
+
+		} else if (dm_value[0] == FUNC_DISABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "[Disable NBI]\n");
+			set_result = phydm_nbi_setting(dm, FUNC_DISABLE, channel, bw, f_interference, second_ch);
+
+		} else
+
+			set_result = PHYDM_SET_FAIL;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[NBI set result: %s]\n",
+			       (set_result == PHYDM_SET_SUCCESS) ? "Success" : ((set_result == PHYDM_SET_NO_NEED) ? "No need" : "Error"));
+
+	}
+
+	/*PHYDM_CSI_MASK*/
+	/*-------------------------------------------------------------------------------------------------------------------------------*/
+	else if (function_map == PHYDM_API_CSI_MASK) {
+		if (dm_value[0] == 100) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[HELP-CSI MASK]  EN(on=1, off=2)   CH   BW(20/40/80)  f_intf(Mhz)    Scnd_CH(L=1, H=2)\n");
+			return;
+
+		} else if (dm_value[0] == FUNC_ENABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Enable CSI MASK] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+				       channel, bw, f_interference,
+				       (channel > 14) ? "Don't care" : (((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "H" : "L"));
+			set_result = phydm_csi_mask_setting(dm,	FUNC_ENABLE, channel, bw, f_interference, second_ch);
+
+		} else if (dm_value[0] == FUNC_DISABLE) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "[Disable CSI MASK]\n");
+			set_result = phydm_csi_mask_setting(dm, FUNC_DISABLE, channel, bw, f_interference, second_ch);
+
+		} else
+
+			set_result = PHYDM_SET_FAIL;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[CSI MASK set result: %s]\n",
+			       (set_result == PHYDM_SET_SUCCESS) ? "Success" : ((set_result == PHYDM_SET_NO_NEED) ? "No need" : "Error"));
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_stop_ck320(
+	void			*dm_void,
+	u8			enable
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = enable ? 1 : 0;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, 0x8b4, BIT(6), reg_value);
+		/**/
+	} else { 
+
+		if (dm->support_ic_type & ODM_IC_N_2SS) {	/*N-2SS*/
+			odm_set_bb_reg(dm, 0x87c, BIT(29), reg_value);
+			/**/
+		} else {	/*N-1SS*/
+			odm_set_bb_reg(dm, 0x87c, BIT(31), reg_value);
+			/**/
+		}
+	}
+}
+
+boolean
+phydm_set_bb_txagc_offset(
+	void			*dm_void,
+	s8			power_offset, 	/*(unit: dB)*/
+	u8			add_half_db		/*(+0.5 dB)*/
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	s8		power_idx = power_offset * 2;
+	boolean		set_success = false;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "power_offset=%d, add_half_db =%d\n", power_offset, add_half_db);
+
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (power_offset > -16 || power_offset < 15) {
+			if (add_half_db)
+				power_idx += 1;
+
+			power_idx &= 0x3f;
+
+			PHYDM_DBG(dm, ODM_COMP_API, "Reg_idx =0x%x\n", power_idx);
+			odm_set_bb_reg(dm, 0x8b4, 0x3f, power_idx);
+			set_success = true;
+		} else {
+			pr_debug("[Warning] TX AGC Offset Setting error!");
+		}
+	}
+	#endif
+	
+	#if	ODM_IC_11N_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (power_offset > -8 || power_offset < 7) {
+			if (add_half_db)
+				power_idx += 1;
+
+			power_idx &= 0x1f;
+			
+			PHYDM_DBG(dm, ODM_COMP_API, "Reg_idx =0x%x\n", power_idx);
+			odm_set_bb_reg(dm, 0x80c, 0x1f00, power_idx);
+			odm_set_bb_reg(dm, 0x80c, 0x3e000, power_idx);
+			set_success = true;
+		} else {
+			pr_debug("[Warning] TX AGC Offset Setting error!");
+		}
+	}
+	#endif
+	
+	return	set_success;
+}
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+boolean
+phydm_api_set_txagc(
+	void				*dm_void,
+	u32				power_index,
+	enum rf_path		path,
+	u8				hw_rate,
+	boolean			is_single_rate
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	boolean		ret = false;
+	u8	i;
+
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+		if (is_single_rate) {
+			
+			#if (RTL8822B_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8822B)
+				ret = phydm_write_txagc_1byte_8822b(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (RTL8821C_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8821C)
+				ret = phydm_write_txagc_1byte_8821c(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+			set_current_tx_agc(dm->priv, path, hw_rate, (u8)power_index);
+			#endif
+
+		} else {
+			#if (RTL8822B_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8822B)
+				ret = config_phydm_write_txagc_8822b(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (RTL8821C_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8821C)
+				ret = config_phydm_write_txagc_8821c(dm, power_index, path, hw_rate);
+			#endif
+			
+			#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+			for (i = 0; i < 4; i++)
+				set_current_tx_agc(dm->priv, path, (hw_rate + i), (u8)power_index);
+			#endif
+		}
+	}
+#endif
+
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_write_txagc_8197f(dm, power_index, path, hw_rate);
+#endif
+
+	return ret;
+}
+
+u8
+phydm_api_get_txagc(
+	void				*dm_void,
+	enum rf_path		path,
+	u8				hw_rate
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	ret = 0;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_read_txagc_8822b(dm, path, hw_rate);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_read_txagc_8197f(dm, path, hw_rate);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C)
+		ret = config_phydm_read_txagc_8821c(dm, path, hw_rate);
+#endif
+
+	return ret;
+}
+
+
+boolean
+phydm_api_switch_bw_channel(
+	void					*dm_void,
+	u8					central_ch,
+	u8					primary_ch_idx,
+	enum channel_width	bandwidth
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;	
+	boolean		ret = false;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_switch_channel_bw_8822b(dm, central_ch, primary_ch_idx, bandwidth);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_switch_channel_bw_8197f(dm, central_ch, primary_ch_idx, bandwidth);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C)
+		ret = config_phydm_switch_channel_bw_8821c(dm, central_ch, primary_ch_idx, bandwidth);
+#endif
+
+	return ret;
+}
+
+boolean
+phydm_api_trx_mode(
+	void				*dm_void,
+	enum bb_path	tx_path,
+	enum bb_path	rx_path,
+	boolean			is_tx2_path
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	boolean		ret = false;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_trx_mode_8822b(dm, tx_path, rx_path, is_tx2_path);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_trx_mode_8197f(dm, tx_path, rx_path, is_tx2_path);
+#endif
+
+	return ret;
+}
+#endif
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_normal_driver_rx_sniffer(
+	struct dm_struct			*dm,
+	u8				*desc,
+	PRT_RFD_STATUS		rt_rfd_status,
+	u8				*drv_info,
+	u8				phy_status
+)
+{
+#if (defined(CONFIG_PHYDM_RX_SNIFFER_PARSING))
+	u32		*msg;
+	u16		seq_num;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	if (rt_rfd_status->packet_report_type != NORMAL_RX)
+		return;
+
+	if (!dm->is_linked) {
+		if (rt_rfd_status->is_hw_error)
+			return;
+	}
+
+	if (!(fat_tab->fat_state == FAT_TRAINING_STATE))
+		return;
+
+	if (phy_status == true) {
+		if ((dm->rx_pkt_type == type_block_ack) || (dm->rx_pkt_type == type_rts) || (dm->rx_pkt_type == type_cts))
+			seq_num = 0;
+		else
+			seq_num = rt_rfd_status->seq_num;
+
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, "%04d , %01s, rate=0x%02x, L=%04d , %s , %s",
+				seq_num,
+				/*rt_rfd_status->mac_id,*/
+			((rt_rfd_status->is_crc) ? "C" : (rt_rfd_status->is_ampdu) ? "A" : "_"),
+				rt_rfd_status->data_rate,
+				rt_rfd_status->length,
+			((rt_rfd_status->band_width == 0) ? "20M" : ((rt_rfd_status->band_width == 1) ? "40M" : "80M")),
+				((rt_rfd_status->is_ldpc) ? "LDP" : "BCC"));
+
+		if (dm->rx_pkt_type == type_asoc_req) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "AS_REQ");
+			/**/
+		} else if (dm->rx_pkt_type == type_asoc_rsp) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "AS_RSP");
+			/**/
+		} else if (dm->rx_pkt_type == type_probe_req) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "PR_REQ");
+			/**/
+		} else if (dm->rx_pkt_type == type_probe_rsp) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "PR_RSP");
+			/**/
+		} else if (dm->rx_pkt_type == type_deauth) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "DEAUTH");
+			/**/
+		} else if (dm->rx_pkt_type == type_beacon) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "BEACON");
+			/**/
+		} else if (dm->rx_pkt_type == type_block_ack_req) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "BA_REQ");
+			/**/
+		} else if (dm->rx_pkt_type == type_rts) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__RTS_");
+			/**/
+		} else if (dm->rx_pkt_type == type_cts) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__CTS_");
+			/**/
+		} else if (dm->rx_pkt_type == type_ack) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__ACK_");
+			/**/
+		} else if (dm->rx_pkt_type == type_block_ack) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__BA__");
+			/**/
+		} else if (dm->rx_pkt_type == type_data) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "_DATA_");
+			/**/
+		} else if (dm->rx_pkt_type == type_data_ack) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "Data_Ack");
+			/**/
+		} else if (dm->rx_pkt_type == type_qos_data) {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "QoS_Data");
+			/**/
+		} else {
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [0x%x]", dm->rx_pkt_type);
+			/**/
+		}
+
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [RSSI=%d,%d,%d,%d ]",
+				dm->rssi_a,
+				dm->rssi_b,
+				dm->rssi_c,
+				dm->rssi_d);
+
+		msg = (u32 *)drv_info;
+
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , P-STS[28:0]=%08x-%08x-%08x-%08x-%08x-%08x-%08x\n",
+			msg[6], msg[5], msg[4], msg[3], msg[2], msg[1], msg[1]);
+	} else {
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, "%04d , %01s, rate=0x%02x, L=%04d , %s , %s\n",
+				rt_rfd_status->seq_num,
+				/*rt_rfd_status->mac_id,*/
+			((rt_rfd_status->is_crc) ? "C" : (rt_rfd_status->is_ampdu) ? "A" : "_"),
+				rt_rfd_status->data_rate,
+				rt_rfd_status->length,
+			((rt_rfd_status->band_width == 0) ? "20M" : ((rt_rfd_status->band_width == 1) ? "40M" : "80M")),
+				((rt_rfd_status->is_ldpc) ? "LDP" : "BCC"));
+	}
+
+
+#endif
+}
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_api.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_api.h
new file mode 100644
index 000000000000..3f31e05e59bc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_api.h
@@ -0,0 +1,251 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_API_H__
+#define    __PHYDM_API_H__
+
+#define PHYDM_API_VERSION	"1.0"		/* 2017.07.10  Dino, Add phydm_api.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+#define	FUNC_ENABLE 1
+#define	FUNC_DISABLE 2
+
+/*NBI API------------------------------------*/
+#define	NBI_TABLE_SIZE_128	27
+#define	NBI_TABLE_SIZE_256	59
+
+#define	NUM_START_CH_80M	7
+#define	NUM_START_CH_40M	14
+
+#define	CH_OFFSET_40M		2
+#define	CH_OFFSET_80M		6
+
+#define	FFT_128_TYPE	1
+#define	FFT_256_TYPE	2
+
+#define	FREQ_POSITIVE	1
+#define	FREQ_NEGATIVE	2
+/*------------------------------------------------*/
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+struct phydm_api_stuc {
+	u32	rx_iqc_reg_1;	/*N-mode: for pathA REG0xc14*/
+	u32	rx_iqc_reg_2;	/*N-mode: for pathB REG0xc1c*/
+	u8	tx_queue_bitmap;/*REG0x520[23:16]*/
+
+};
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_dynamic_ant_weighting(
+	void		*dm_void
+);
+
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void
+phydm_dyn_ant_weight_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+#endif
+
+void
+phydm_pathb_q_matrix_rotate_en(
+	void		*dm_void
+);
+
+void
+phydm_pathb_q_matrix_rotate(
+	void		*dm_void,
+	u16		phase_idx
+);
+
+void
+phydm_init_trx_antenna_setting(
+	void		*dm_void
+);
+
+void
+phydm_config_ofdm_rx_path(
+	void		*dm_void,
+	u32		path
+);
+
+void
+phydm_config_cck_rx_path(
+	void		*dm_void,
+	enum bb_path	path
+);
+
+void
+phydm_config_cck_rx_antenna_init(
+	void		*dm_void
+);
+
+void
+phydm_config_trx_path(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_tx_2path(
+	void		*dm_void
+);
+
+void
+phydm_stop_3_wire(
+	void		*dm_void,
+	u8		set_type
+);
+
+u8
+phydm_stop_ic_trx(
+	void		*dm_void,
+	u8		set_type
+);
+
+void
+phydm_set_ext_switch(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_nbi_enable(
+	void		*dm_void,
+	u32		enable
+);
+
+u8
+phydm_csi_mask_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		Second_ch
+);
+
+u8
+phydm_nbi_setting(
+	void		*dm_void,
+	u32		enable,
+	u32		channel,
+	u32		bw,
+	u32		f_interference,
+	u32		second_ch
+);
+
+
+void
+phydm_api_debug(
+	void		*dm_void,
+	u32		function_map,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+phydm_stop_ck320(
+	void			*dm_void,
+	u8			enable
+);
+
+boolean
+phydm_set_bb_txagc_offset(
+	void			*dm_void,
+	s8			power_offset,
+	u8			add_half_db
+);
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+
+boolean
+phydm_api_set_txagc(
+	void				*dm_void,
+	u32				power_index,
+	enum rf_path		path,
+	u8				hw_rate,
+	boolean			is_single_rate
+);
+
+u8
+phydm_api_get_txagc(
+	void				*dm_void,
+	enum rf_path		path,
+	u8				hw_rate
+);
+
+boolean
+phydm_api_switch_bw_channel(
+	void					*dm_void,
+	u8					central_ch,
+	u8					primary_ch_idx,
+	enum channel_width	bandwidth
+);
+
+boolean
+phydm_api_trx_mode(
+	void				*dm_void,
+	enum bb_path	tx_path,
+	enum bb_path	rx_path,
+	boolean			is_tx2_path
+);
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_auto_dbg.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_auto_dbg.c
new file mode 100644
index 000000000000..40ad5b3ff5b0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_auto_dbg.c
@@ -0,0 +1,683 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef PHYDM_AUTO_DEGBUG
+
+void
+phydm_check_hang_reset(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+
+	atd_t->dbg_step = 0;
+	atd_t->auto_dbg_type = AUTO_DBG_STOP;
+	phydm_pause_dm_watchdog(dm, PHYDM_RESUME);
+	dm->debug_components &= (~ODM_COMP_API);
+}
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+void
+phydm_auto_check_hang_engine_n(
+	void			*dm_void
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+	struct	n_dbgport_803	dbgport_803 = {0};
+	u32		value32_tmp = 0, value32_tmp_2 = 0;
+	u8		i;
+	u32		curr_dbg_port_val[DBGPORT_CHK_NUM];
+	u16		curr_ofdm_t_cnt;
+	u16		curr_ofdm_r_cnt;
+	u16		curr_cck_t_cnt;
+	u16		curr_cck_r_cnt;
+	u16		curr_ofdm_crc_error_cnt;
+	u16		curr_cck_crc_error_cnt;
+	u16		diff_ofdm_t_cnt;
+	u16		diff_ofdm_r_cnt;
+	u16		diff_cck_t_cnt;
+	u16		diff_cck_r_cnt;
+	u16		diff_ofdm_crc_error_cnt;
+	u16		diff_cck_crc_error_cnt;
+	u8		rf_mode;
+
+
+	if (atd_t->auto_dbg_type == AUTO_DBG_STOP)
+		return;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		phydm_check_hang_reset(dm);
+		return;
+	}
+
+	if (atd_t->dbg_step == 0) {
+		pr_debug("dbg_step=0\n\n");
+		
+		/*Reset all packet counter*/
+		odm_set_bb_reg(dm, 0xf14, BIT(16), 1);
+		odm_set_bb_reg(dm, 0xf14, BIT(16), 0);
+
+
+
+	} else if (atd_t->dbg_step == 1)  {
+		pr_debug("dbg_step=1\n\n");
+
+		/*Check packet counter Register*/
+		atd_t->ofdm_t_cnt = (u16)odm_get_bb_reg(dm, 0x9cc, MASKHWORD);
+		atd_t->ofdm_r_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKLWORD);
+		atd_t->ofdm_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKHWORD);
+		
+		atd_t->cck_t_cnt = (u16)odm_get_bb_reg(dm, 0x9d0, MASKHWORD);;
+		atd_t->cck_r_cnt = (u16)odm_get_bb_reg(dm, 0xfa0, MASKHWORD);
+		atd_t->cck_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf84, 0x3fff);	
+
+
+		/*Check Debug Port*/
+		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
+			
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, (u32)atd_t->dbg_port_table[i])) {
+				atd_t->dbg_port_val[i] = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+			}
+		}
+	
+	} else if (atd_t->dbg_step == 2)  {
+		pr_debug("dbg_step=2\n\n");
+
+		/*Check packet counter Register*/
+		curr_ofdm_t_cnt = (u16)odm_get_bb_reg(dm, 0x9cc, MASKHWORD);
+		curr_ofdm_r_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKLWORD);
+		curr_ofdm_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf94, MASKHWORD);
+		
+		curr_cck_t_cnt = (u16)odm_get_bb_reg(dm, 0x9d0, MASKHWORD);;
+		curr_cck_r_cnt = (u16)odm_get_bb_reg(dm, 0xfa0, MASKHWORD);
+		curr_cck_crc_error_cnt = (u16)odm_get_bb_reg(dm, 0xf84, 0x3fff);	
+
+		/*Check Debug Port*/
+		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
+			
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, (u32)atd_t->dbg_port_table[i])) {
+				curr_dbg_port_val[i] = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+			}
+		}
+	
+		/*=== Make check hang decision ================================*/
+		pr_debug("Check Hang Decision\n\n");
+
+		/* ----- Check RF Register -----------------------------------*/
+		for (i = 0; i < dm->num_rf_path; i++) {
+		
+			rf_mode = (u8)odm_get_rf_reg(dm, i, 0x0, 0xf0000);
+				
+			pr_debug("RF0x0[%d] = 0x%x\n", i, rf_mode);
+
+			if (rf_mode > 3) {
+				pr_debug("Incorrect RF mode\n");
+				pr_debug("ReasonCode:RHN-1\n");
+
+				
+			}
+		}
+
+		value32_tmp = odm_get_rf_reg(dm, 0, 0xb0, 0xf0000);
+			
+		if (dm->support_ic_type == ODM_RTL8188E) {
+			if (value32_tmp != 0xff8c8) {
+				pr_debug("ReasonCode:RHN-3\n");
+			}
+		}
+
+		/* ----- Check BB Register -----------------------------------*/
+		
+		/*BB mode table*/
+		value32_tmp = odm_get_bb_reg(dm, 0x824, 0xe);
+		value32_tmp_2 = odm_get_bb_reg(dm, 0x82c, 0xe);
+		pr_debug("BB TX mode table {A, B}= {%d, %d}\n", value32_tmp, value32_tmp_2);
+
+		if ((value32_tmp > 3) || (value32_tmp_2 > 3)) {
+			
+			pr_debug("ReasonCode:RHN-2\n");
+		}
+
+		value32_tmp = odm_get_bb_reg(dm, 0x824, 0x700000);
+		value32_tmp_2 = odm_get_bb_reg(dm, 0x82c, 0x700000);
+		pr_debug("BB RX mode table {A, B}= {%d, %d}\n", value32_tmp, value32_tmp_2);
+
+		if ((value32_tmp > 3) || (value32_tmp_2 > 3)) {
+			
+			pr_debug("ReasonCode:RHN-2\n");
+		}
+		
+
+		/*BB HW Block*/
+		value32_tmp = odm_get_bb_reg(dm, 0x800, MASKDWORD);
+		
+		if (!(value32_tmp & BIT(24))) {
+			pr_debug("Reg0x800[24] = 0, CCK BLK is disabled\n");
+			pr_debug("ReasonCode: THN-3\n");
+		}
+		
+		if (!(value32_tmp & BIT(25))) {
+			pr_debug("Reg0x800[24] = 0, OFDM BLK is disabled\n");
+			pr_debug("ReasonCode:THN-3\n");
+		}
+
+		/*BB Continue TX*/
+		value32_tmp = odm_get_bb_reg(dm, 0xd00, 0x70000000);
+		pr_debug("Continue TX=%d\n", value32_tmp);
+		if (value32_tmp != 0) {
+			pr_debug("ReasonCode: THN-4\n");
+		}
+		
+
+		/* ----- Check Packet Counter --------------------------------*/
+		diff_ofdm_t_cnt = curr_ofdm_t_cnt - atd_t->ofdm_t_cnt;
+		diff_ofdm_r_cnt = curr_ofdm_r_cnt - atd_t->ofdm_r_cnt;
+		diff_ofdm_crc_error_cnt = curr_ofdm_crc_error_cnt - atd_t->ofdm_crc_error_cnt;
+		
+		diff_cck_t_cnt = curr_cck_t_cnt - atd_t->cck_t_cnt;
+		diff_cck_r_cnt = curr_cck_r_cnt - atd_t->cck_r_cnt;
+		diff_cck_crc_error_cnt = curr_cck_crc_error_cnt - atd_t->cck_crc_error_cnt;
+
+		pr_debug("OFDM[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			atd_t->ofdm_t_cnt, atd_t->ofdm_r_cnt, atd_t->ofdm_crc_error_cnt);
+		pr_debug("OFDM[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			curr_ofdm_t_cnt, curr_ofdm_r_cnt, curr_ofdm_crc_error_cnt);
+		pr_debug("OFDM_diff {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			diff_ofdm_t_cnt, diff_ofdm_r_cnt, diff_ofdm_crc_error_cnt);
+
+		pr_debug("CCK[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			atd_t->cck_t_cnt, atd_t->cck_r_cnt, atd_t->cck_crc_error_cnt);
+		pr_debug("CCK[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			curr_cck_t_cnt, curr_cck_r_cnt, curr_cck_crc_error_cnt);
+		pr_debug("CCK_diff {TX, RX, CRC_error} = {%d, %d, %d}\n", 
+			diff_cck_t_cnt, diff_cck_r_cnt, diff_cck_crc_error_cnt);
+
+		/* ----- Check Dbg Port --------------------------------*/
+
+		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
+			pr_debug("Dbg_port=((0x%x))\n", atd_t->dbg_port_table[i]);
+			pr_debug("Val{pre, curr}={0x%x, 0x%x}\n", atd_t->dbg_port_val[i], curr_dbg_port_val[i]);
+
+			if ((atd_t->dbg_port_table[i]) == 0) {
+				if (atd_t->dbg_port_val[i] == curr_dbg_port_val[i]) {
+					
+					pr_debug("BB state hang\n");
+					pr_debug("ReasonCode:\n");
+				}
+
+			} else if (atd_t->dbg_port_table[i] == 0x803) {
+				if (atd_t->dbg_port_val[i] == curr_dbg_port_val[i]) {
+					//dbgport_803 = (struct n_dbgport_803 )(atd_t->dbg_port_val[i]);
+
+					odm_move_memory(dm, &dbgport_803,
+							  &atd_t->dbg_port_val[i],
+							sizeof(struct n_dbgport_803));
+
+					pr_debug("RSTB{BB, GLB, OFDM}={%d, %d, %d}\n", dbgport_803.bb_rst_b, dbgport_803.glb_rst_b, dbgport_803.ofdm_rst_b);
+					pr_debug("{ofdm_tx_en, cck_tx_en, phy_tx_on}={%d, %d, %d}\n", dbgport_803.ofdm_tx_en, dbgport_803.cck_tx_en, dbgport_803.phy_tx_on);
+					pr_debug("CCA_PP{OFDM, CCK}={%d, %d}\n", dbgport_803.ofdm_cca_pp, dbgport_803.cck_cca_pp);
+
+					if (dbgport_803.phy_tx_on)
+						pr_debug("Maybe TX Hang\n");
+					else if (dbgport_803.ofdm_cca_pp || dbgport_803.cck_cca_pp)
+						pr_debug("Maybe RX Hang\n");	
+				}
+
+			} else if (atd_t->dbg_port_table[i] == 0x208) {
+				if ((atd_t->dbg_port_val[i] & BIT(30)) && (curr_dbg_port_val[i] & BIT(30))) {
+					
+					pr_debug("EDCCA Pause TX\n");
+					pr_debug("ReasonCode: THN-2\n");
+				}
+
+			} else if (atd_t->dbg_port_table[i] == 0xab0) {
+				if (((atd_t->dbg_port_val[i] & 0xffffff) == 0) || 
+					((curr_dbg_port_val[i] & 0xffffff) == 0)) {
+					
+					pr_debug("Wrong L-SIG formate\n");
+					pr_debug("ReasonCode: THN-1\n");
+				}
+			}
+		}
+		
+		phydm_check_hang_reset(dm);
+	}
+
+	atd_t->dbg_step++;
+	
+}
+
+void
+phydm_bb_auto_check_hang_start_n(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32	value32 = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		return;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, 
+		       "PHYDM auto check hang (N-series) is started, Please check the system log\n");
+
+	dm->debug_components |= ODM_COMP_API;
+	atd_t->auto_dbg_type = AUTO_DBG_CHECK_HANG;
+	atd_t->dbg_step = 0;
+	
+
+	phydm_pause_dm_watchdog(dm, PHYDM_PAUSE);
+
+
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_bb_rx_hang_info_n(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32	value32 = 0;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		return;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "not support now\n");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif	
+
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+void
+phydm_bb_rx_hang_info_ac(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32	value32 = 0;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		return;
+
+	value32 = odm_get_bb_reg(dm, 0xF80, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		         "\r\n %-35s = 0x%x", "rptreg of sc/bw/ht/...",
+		       value32);
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, 0x198c, BIT(2) | BIT(1) | BIT(0), 7);
+
+	/* dbg_port = basic state machine */
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x000);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "basic state machine",
+			       value32);
+	}
+
+	/* dbg_port = state machine */
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x007);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "state machine", value32);
+	}
+
+	/* dbg_port = CCA-related*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x204);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "CCA-related", value32);
+	}
+
+
+	/* dbg_port = edcca/rxd*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x278);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "edcca/rxd", value32);
+	}
+
+	/* dbg_port = rx_state/mux_state/ADC_MASK_OFDM*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x290);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x",
+			       "rx_state/mux_state/ADC_MASK_OFDM", value32);
+	}
+
+	/* dbg_port = bf-related*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B2);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "bf-related", value32);
+	}
+
+	/* dbg_port = bf-related*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B8);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "bf-related", value32);
+	}
+
+	/* dbg_port = txon/rxd*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA03);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "txon/rxd", value32);
+	}
+
+	/* dbg_port = l_rate/l_length*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0B);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "l_rate/l_length",
+			       value32);
+	}
+
+	/* dbg_port = rxd/rxd_hit*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0D);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rxd/rxd_hit", value32);
+	}
+
+	/* dbg_port = dis_cca*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAA0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "dis_cca", value32);
+	}
+
+
+	/* dbg_port = tx*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAB0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "tx", value32);
+	}
+
+	/* dbg_port = rx plcp*/
+	{
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD1);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD2);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD3);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = 0x%x", "rx plcp", value32);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
+
+void
+phydm_auto_dbg_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Show dbg port: {1} {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Auto check hang: {1} {2}\n");
+		return;
+	} else if (var1[0] == 1) {
+		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
+
+		if (var1[1] == 1) {
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+				phydm_bb_rx_hang_info_ac(dm, &used, output, &out_len);
+				#else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+				#endif
+			} else {
+				#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+				phydm_bb_rx_hang_info_n(dm, &used, output, &out_len);
+				#else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+				#endif
+			}
+		} else if (var1[1] == 2) {
+		
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+			} else {
+				#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+				phydm_bb_auto_check_hang_start_n(dm, &used, output, &out_len);
+				#else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Not support\n");
+				#endif
+			}
+		}
+	} 
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif
+
+void
+phydm_auto_dbg_engine(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_AUTO_DEGBUG
+	u32	value32 = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+
+	if (atd_t->auto_dbg_type == AUTO_DBG_STOP)
+		return;
+
+	pr_debug("%s ======>\n", __func__);
+	
+	if (atd_t->auto_dbg_type == AUTO_DBG_CHECK_HANG) {
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			pr_debug("Not Support\n");
+		} else {
+			#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+			phydm_auto_check_hang_engine_n(dm);
+			#else
+			pr_debug("Not Support\n");
+			#endif
+		}
+
+	} else if (atd_t->auto_dbg_type == AUTO_DBG_CHECK_RA) {
+	
+		pr_debug("Not Support\n");
+
+	}
+#endif
+}
+
+void
+phydm_auto_dbg_engine_init(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_AUTO_DEGBUG
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struc	*atd_t = &dm->auto_dbg_table;
+	u16 dbg_port_table[DBGPORT_CHK_NUM] = {0x0, 0x803, 0x208, 0xab0, 0xab1, 0xab2};
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>n", __func__);
+
+	odm_move_memory(dm, &atd_t->dbg_port_table[0],
+			  &dbg_port_table[0], (DBGPORT_CHK_NUM * 2));
+
+	phydm_check_hang_reset(dm);
+#endif
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_auto_dbg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_auto_dbg.h
new file mode 100644
index 000000000000..1446c826f25e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_auto_dbg.h
@@ -0,0 +1,125 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_AUTO_DBG_H__
+#define    __PHYDM_AUTO_DBG_H__
+
+#define AUTO_DBG_VERSION	"1.0"		/* 2017.05.015  Dino, Add phydm_auto_dbg.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define	AUTO_CHK_HANG_STEP_MAX	3
+#define	DBGPORT_CHK_NUM			6
+
+#ifdef PHYDM_AUTO_DEGBUG
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+enum auto_dbg_type_e{
+	AUTO_DBG_STOP 		= 0,
+	AUTO_DBG_CHECK_HANG 	= 1,
+	AUTO_DBG_CHECK_RA	= 2,
+	AUTO_DBG_CHECK_DIG	= 3	
+};
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+struct n_dbgport_803 {
+	/*BYTE 3*/
+	u8 bb_rst_b: 1;
+	u8 glb_rst_b: 1;
+	u8 zero_1bit_1:1;
+	u8 ofdm_rst_b: 1;
+	u8 cck_txpe: 1;
+	u8 ofdm_txpe: 1;
+	u8 phy_tx_on: 1;
+	u8 tdrdy: 1;
+	/*BYTE 2*/
+	u8 txd:8;
+	/*BYTE 1*/
+	u8 cck_cca_pp: 1; 
+	u8 ofdm_cca_pp: 1;
+	u8 rx_rst: 1;
+	u8 rdrdy: 1;
+	u8 rxd_7_4: 4;
+	/*BYTE 0*/
+	u8 rxd_3_0: 4;
+	u8 ofdm_tx_en: 1; 
+	u8 cck_tx_en: 1;
+	u8 zero_1bit_2:1;
+	u8 clk_80m: 1;
+};
+
+struct phydm_auto_dbg_struc {
+	enum	auto_dbg_type_e	auto_dbg_type;
+	u8		dbg_step;
+	u16		dbg_port_table[DBGPORT_CHK_NUM];
+	u32		dbg_port_val[DBGPORT_CHK_NUM];
+	u16		ofdm_t_cnt;
+	u16		ofdm_r_cnt;
+	u16		cck_t_cnt;
+	u16		cck_r_cnt;
+	u16		ofdm_crc_error_cnt;
+	u16		cck_crc_error_cnt;
+
+};
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+
+void
+phydm_auto_dbg_console(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+#endif
+
+void
+phydm_auto_dbg_engine(
+	void			*dm_void
+);
+
+void
+phydm_auto_dbg_engine_init(
+	void		*dm_void
+);
+#endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.c
index 346931549830..79b09ec49cfc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.c
@@ -1,1940 +1,2059 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#if WPP_SOFTWARE_TRACE
-#include "phydm_beamforming.tmh"
-#endif
-#endif
-
-#if (BEAMFORMING_SUPPORT == 1)
-
-PRT_BEAMFORM_STAINFO
-phydm_staInfoInit(
-	IN PDM_ODM_T		pDM_Odm,
-	IN u2Byte			staIdx
-	)
-{
-	PRT_BEAMFORMING_INFO		pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORM_STAINFO		pEntry = &(pBeamInfo->BeamformSTAinfo);
-	PSTA_INFO_T					pSTA = pDM_Odm->pODM_StaInfo[staIdx];
-	PADAPTER					Adapter = pDM_Odm->Adapter;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PMGNT_INFO					pMgntInfo = &Adapter->MgntInfo;
-	PRT_HIGH_THROUGHPUT		pHTInfo = GET_HT_INFO(pMgntInfo);
-	PRT_VERY_HIGH_THROUGHPUT	pVHTInfo = GET_VHT_INFO(pMgntInfo);
-
-	ODM_MoveMemory(pDM_Odm, pEntry->MyMacAddr, Adapter->CurrentAddress, 6);
-	
-	pEntry->HtBeamformCap = pHTInfo->HtBeamformCap;
-	pEntry->VhtBeamformCap = pVHTInfo->VhtBeamformCap;
-
-	/*IBSS, AP mode*/
-	if (staIdx != 0) {
-		pEntry->AID = pSTA->AID;
-		pEntry->RA = pSTA->MacAddr;
-		pEntry->MacID = pSTA->AssociatedMacId;
-		pEntry->WirelessMode = pSTA->WirelessMode;
-		pEntry->BW = pSTA->BandWidth;
-		pEntry->CurBeamform = pSTA->HTInfo.HtCurBeamform;
-	} else {/*client mode*/
-		pEntry->AID = pMgntInfo->mAId;
-		pEntry->RA = pMgntInfo->Bssid;
-		pEntry->MacID = pMgntInfo->mMacId;
-		pEntry->WirelessMode = pMgntInfo->dot11CurrentWirelessMode;
-		pEntry->BW = pMgntInfo->dot11CurrentChannelBandWidth;
-		pEntry->CurBeamform = pHTInfo->HtCurBeamform;
-	}	
-
-	if ((pEntry->WirelessMode & WIRELESS_MODE_AC_5G) || (pEntry->WirelessMode & WIRELESS_MODE_AC_24G)) {
-		if (staIdx != 0)
-			pEntry->CurBeamformVHT = pSTA->VHTInfo.VhtCurBeamform;
-		else
-			pEntry->CurBeamformVHT = pVHTInfo->VhtCurBeamform;	
-		}
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("pSTA->wireless_mode = 0x%x, staidx = %d\n", pSTA->WirelessMode, staIdx));
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-	if (!IS_STA_VALID(pSTA)) {
-		rtw_warn_on(1);
-		DBG_871X("%s => sta_info(mac_id:%d) failed\n", __func__, staIdx);
-		return pEntry;
-	}
-	
-	ODM_MoveMemory(pDM_Odm, pEntry->MyMacAddr, adapter_mac_addr(pSTA->padapter), 6);
-	pEntry->HtBeamformCap = pSTA->htpriv.beamform_cap;
-
-	pEntry->AID = pSTA->aid;
-	pEntry->RA = pSTA->hwaddr;
-	pEntry->MacID = pSTA->mac_id;
-	pEntry->WirelessMode = pSTA->wireless_mode;
-	pEntry->BW = pSTA->bw_mode;
-
-	pEntry->CurBeamform = pSTA->htpriv.beamform_cap;
-#if	ODM_IC_11AC_SERIES_SUPPORT
-	if ((pEntry->WirelessMode & WIRELESS_MODE_AC_5G) || (pEntry->WirelessMode & WIRELESS_MODE_AC_24G)) {
-		pEntry->CurBeamformVHT = pSTA->vhtpriv.beamform_cap;
-		pEntry->VhtBeamformCap = pSTA->vhtpriv.beamform_cap;
-	}
-#endif
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("pSTA->wireless_mode = 0x%x, staidx = %d\n", pSTA->wireless_mode, staIdx));
-#endif
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("pEntry->CurBeamform = 0x%x, pEntry->CurBeamformVHT = 0x%x\n", pEntry->CurBeamform, pEntry->CurBeamformVHT));
-	return pEntry;
-
-}
-void phydm_staInfoUpdate(
-	IN PDM_ODM_T			pDM_Odm,
-	IN u2Byte				staIdx,
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry
-	)
-{
-	PSTA_INFO_T pSTA = pDM_Odm->pODM_StaInfo[staIdx];
-	
-	if (!IS_STA_VALID(pSTA))
-		return;
-	
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	pSTA->txbf_paid = pBeamformEntry->P_AID;
-	pSTA->txbf_gid = pBeamformEntry->G_ID;
-#endif	
-}
-	
-
-u1Byte
-Beamforming_GetHTNDPTxRate(
-	IN	PVOID	pDM_VOID,
-	u1Byte	CompSteeringNumofBFer
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte Nr_index = 0;
-	u1Byte NDPTxRate;
-	/*Find Nr*/
-	
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		Nr_index = TxBF_Nr(halTxbf8814A_GetNtx(pDM_Odm), CompSteeringNumofBFer);
-	else
-		Nr_index = TxBF_Nr(1, CompSteeringNumofBFer);
-	
-	switch (Nr_index) {
-	case 1:
-	NDPTxRate = MGN_MCS8;
-	break;
-
-	case 2:
-	NDPTxRate = MGN_MCS16;
-	break;
-
-	case 3:
-	NDPTxRate = MGN_MCS24;
-	break;
-			
-	default:
-	NDPTxRate = MGN_MCS8;
-	break;
-	}
-
-return NDPTxRate;
-
-}
-
-u1Byte
-Beamforming_GetVHTNDPTxRate(
-	IN	PVOID	pDM_VOID,
-	u1Byte	CompSteeringNumofBFer
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte Nr_index = 0;
-	u1Byte NDPTxRate;
-	/*Find Nr*/
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		Nr_index = TxBF_Nr(halTxbf8814A_GetNtx(pDM_Odm), CompSteeringNumofBFer);
-	else
-		Nr_index = TxBF_Nr(1, CompSteeringNumofBFer);
-	
-	switch (Nr_index) {
-	case 1:
-	NDPTxRate = MGN_VHT2SS_MCS0;
-	break;
-
-	case 2:
-	NDPTxRate = MGN_VHT3SS_MCS0;
-	break;
-
-	case 3:
-	NDPTxRate = MGN_VHT4SS_MCS0;
-	break;
-			
-	default:
-	NDPTxRate = MGN_VHT2SS_MCS0;
-	break;
-	}
-
-return NDPTxRate;
-
-}
-
-
-PRT_BEAMFORMEE_ENTRY
-phydm_Beamforming_GetBFeeEntryByAddr(
-	IN	PVOID		pDM_VOID,
-	IN	pu1Byte		RA,
-	OUT	pu1Byte		Idx
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	i = 0;
-	PRT_BEAMFORMING_INFO pBeamInfo = &pDM_Odm->BeamformingInfo;
-	
-	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (pBeamInfo->BeamformeeEntry[i].bUsed && (eqMacAddr(RA, pBeamInfo->BeamformeeEntry[i].MacAddr))) {
-			*Idx = i;
-			return &(pBeamInfo->BeamformeeEntry[i]);
-		}
-	}
-
-	return NULL;
-}
-
-PRT_BEAMFORMER_ENTRY
-phydm_Beamforming_GetBFerEntryByAddr(
-	IN	PVOID	pDM_VOID,
-	IN	pu1Byte 	TA,
-	OUT	pu1Byte	Idx
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte		i = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	
-	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
-		if (pBeamInfo->BeamformerEntry[i].bUsed &&  (eqMacAddr(TA, pBeamInfo->BeamformerEntry[i].MacAddr))) {
-			*Idx = i;
-			return &(pBeamInfo->BeamformerEntry[i]);
-		}
-	}
-
-	return NULL;
-}
-
-
-PRT_BEAMFORMEE_ENTRY
-phydm_Beamforming_GetEntryByMacId(
-	IN	PVOID		pDM_VOID,
-	IN	u1Byte		MacId,
-	OUT	pu1Byte		Idx
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	i = 0;
-	PRT_BEAMFORMING_INFO pBeamInfo = &pDM_Odm->BeamformingInfo;
-	
-	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (pBeamInfo->BeamformeeEntry[i].bUsed && (MacId == pBeamInfo->BeamformeeEntry[i].MacId)) {
-			*Idx = i;
-			return &(pBeamInfo->BeamformeeEntry[i]);
-		}
-	}
-
-	return NULL;
-}
-
-
-BEAMFORMING_CAP
-phydm_Beamforming_GetEntryBeamCapByMacId(
-	IN	PVOID		pDM_VOID,
-	IN	u1Byte		MacId
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	i = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	BEAMFORMING_CAP			BeamformEntryCap = BEAMFORMING_CAP_NONE;
-	
-	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (pBeamInfo->BeamformeeEntry[i].bUsed && (MacId == pBeamInfo->BeamformeeEntry[i].MacId)) {
-			BeamformEntryCap =  pBeamInfo->BeamformeeEntry[i].BeamformEntryCap;
-			i = BEAMFORMEE_ENTRY_NUM;
-		}
-	}
-
-	return BeamformEntryCap;
-}
-
-
-PRT_BEAMFORMEE_ENTRY
-phydm_Beamforming_GetFreeBFeeEntry(
-	IN	PVOID		pDM_VOID,
-	OUT	pu1Byte		Idx
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	i = 0;
-	PRT_BEAMFORMING_INFO pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (pBeamInfo->BeamformeeEntry[i].bUsed == FALSE) {
-			*Idx = i;
-			return &(pBeamInfo->BeamformeeEntry[i]);
-		}	
-	}
-	return NULL;
-}
-
-PRT_BEAMFORMER_ENTRY
-phydm_Beamforming_GetFreeBFerEntry(
-	IN	PVOID		pDM_VOID,
-	OUT	pu1Byte		Idx
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	i = 0;
-	PRT_BEAMFORMING_INFO pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s ===>\n", __func__));
-
-	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
-		if (pBeamInfo->BeamformerEntry[i].bUsed == FALSE) {
-			*Idx = i;
-			return &(pBeamInfo->BeamformerEntry[i]);
-		}	
-	}
-	return NULL;
-}
-
-/*
-// Description: Get the first entry index of MU Beamformee.
-//
-// Return Value: Index of the first MU sta.
-//
-// 2015.05.25. Created by tynli.
-//
-*/
-u1Byte
-phydm_Beamforming_GetFirstMUBFeeEntryIdx(
-	IN	PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					idx = 0xFF;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	BOOLEAN					bFound = FALSE;
-
-	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		if (pBeamInfo->BeamformeeEntry[idx].bUsed && pBeamInfo->BeamformeeEntry[idx].is_mu_sta) {			
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] idx=%d!\n", __func__, idx));
-			bFound = TRUE;
-			break;
-		}	
-	}
-
-	if (!bFound)
-		idx = 0xFF;
-
-	return idx;
-}
-
-
-/*Add SU BFee and MU BFee*/
-PRT_BEAMFORMEE_ENTRY
-Beamforming_AddBFeeEntry(
-	IN	PVOID				pDM_VOID,
-	IN	PRT_BEAMFORM_STAINFO	pSTA,
-	IN	BEAMFORMING_CAP	BeamformCap,
-	IN	u1Byte				NumofSoundingDim,
-	IN	u1Byte				CompSteeringNumofBFer,
-	OUT	pu1Byte				Idx
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMEE_ENTRY	pEntry = phydm_Beamforming_GetFreeBFeeEntry(pDM_Odm, Idx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (pEntry != NULL) {	
-		pEntry->bUsed = TRUE;
-		pEntry->AID = pSTA->AID;
-		pEntry->MacId = pSTA->MacID;
-		pEntry->SoundBW = pSTA->BW;
-		ODM_MoveMemory(pDM_Odm, pEntry->MyMacAddr, pSTA->MyMacAddr, 6);
-		
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_AP)) {
-			/*BSSID[44:47] xor BSSID[40:43]*/
-			u2Byte BSSID = ((pSTA->MyMacAddr[5] & 0xf0) >> 4) ^ (pSTA->MyMacAddr[5] & 0xf);
-			/*(dec(A) + dec(B)*32) mod 512*/
-			pEntry->P_AID = (pSTA->AID + BSSID * 32) & 0x1ff;
-			pEntry->G_ID = 63;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: BFee P_AID addressed to STA=%d\n", __func__, pEntry->P_AID));
-		} else if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS)) {
-			/*ad hoc mode*/
-			pEntry->P_AID = 0;
-			pEntry->G_ID = 63;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: BFee P_AID as IBSS=%d\n", __func__, pEntry->P_AID));
-		} else {
-			/*client mode*/
-			pEntry->P_AID =  pSTA->RA[5];
-			/*BSSID[39:47]*/
-			pEntry->P_AID = (pEntry->P_AID << 1) | (pSTA->RA[4] >> 7);
-			pEntry->G_ID = 0;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: BFee P_AID addressed to AP=0x%X\n", __func__, pEntry->P_AID));
-		}
-		cpMacAddr(pEntry->MacAddr, pSTA->RA);
-		pEntry->bTxBF = FALSE;
-		pEntry->bSound = FALSE;
-		pEntry->SoundPeriod = 400;
-		pEntry->BeamformEntryCap = BeamformCap;
-		pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-
-/*		pEntry->LogSeq = 0xff;				Move to Beamforming_AddBFerEntry*/
-/*		pEntry->LogRetryCnt = 0;			Move to Beamforming_AddBFerEntry*/
-/*		pEntry->LogSuccessCnt = 0;		Move to Beamforming_AddBFerEntry*/
-
-		pEntry->LogStatusFailCnt = 0;
-
-		pEntry->NumofSoundingDim = NumofSoundingDim;
-		pEntry->CompSteeringNumofBFer = CompSteeringNumofBFer;
-
-		if (BeamformCap & BEAMFORMER_CAP_VHT_MU) {
-			pDM_Odm->BeamformingInfo.beamformee_mu_cnt += 1;
-			pEntry->is_mu_sta = TRUE;
-			pDM_Odm->BeamformingInfo.FirstMUBFeeIndex = phydm_Beamforming_GetFirstMUBFeeEntryIdx(pDM_Odm);
-		} else if  (BeamformCap & BEAMFORMER_CAP_VHT_SU) {
-			pDM_Odm->BeamformingInfo.beamformee_su_cnt += 1;
-			pEntry->is_mu_sta = FALSE;
-		}
-
-		return pEntry;
-	}
-	else
-		return NULL;
-}
-
-/*Add SU BFee and MU BFer*/
-PRT_BEAMFORMER_ENTRY
-Beamforming_AddBFerEntry(
-	IN	PVOID				pDM_VOID,
-	IN	PRT_BEAMFORM_STAINFO	pSTA,
-	IN	BEAMFORMING_CAP	BeamformCap,
-	IN	u1Byte				NumofSoundingDim,
-	OUT	pu1Byte				Idx
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMER_ENTRY	pEntry = phydm_Beamforming_GetFreeBFerEntry(pDM_Odm, Idx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (pEntry != NULL) {
-		pEntry->bUsed = TRUE;
-		ODM_MoveMemory(pDM_Odm, pEntry->MyMacAddr, pSTA->MyMacAddr, 6);
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_AP)) {
-			/*BSSID[44:47] xor BSSID[40:43]*/
-			u2Byte BSSID = ((pSTA->MyMacAddr[5] & 0xf0) >> 4) ^ (pSTA->MyMacAddr[5] & 0xf);
-			
-			pEntry->P_AID = (pSTA->AID + BSSID * 32) & 0x1ff;
-			pEntry->G_ID = 63;
-			/*(dec(A) + dec(B)*32) mod 512*/
-		} else if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS)) {
-			pEntry->P_AID = 0;
-			pEntry->G_ID = 63;
-		} else {
-			pEntry->P_AID =  pSTA->RA[5];
-			/*BSSID[39:47]*/
-			pEntry->P_AID = (pEntry->P_AID << 1) | (pSTA->RA[4] >> 7);
-			pEntry->G_ID = 0;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: P_AID addressed to AP=0x%X\n", __func__, pEntry->P_AID));
-		}
-		
-		cpMacAddr(pEntry->MacAddr, pSTA->RA);
-		pEntry->BeamformEntryCap = BeamformCap;
-
-		pEntry->PreLogSeq = 0;	/*Modified by Jeffery @2015-04-13*/
-		pEntry->LogSeq = 0;		/*Modified by Jeffery @2014-10-29*/
-		pEntry->LogRetryCnt = 0;	/*Modified by Jeffery @2014-10-29*/
-		pEntry->LogSuccess = 0;	/*LogSuccess is NOT needed to be accumulated, so  LogSuccessCnt->LogSuccess, 2015-04-13, Jeffery*/
-		pEntry->ClockResetTimes = 0;	/*Modified by Jeffery @2015-04-13*/
-
-		pEntry->NumofSoundingDim = NumofSoundingDim;
-
-		if (BeamformCap & BEAMFORMEE_CAP_VHT_MU) {
-			pDM_Odm->BeamformingInfo.beamformer_mu_cnt += 1;
-			pEntry->is_mu_ap = TRUE;
-			pEntry->AID = pSTA->AID;
-		} else if (BeamformCap & BEAMFORMEE_CAP_VHT_SU) {
-			pDM_Odm->BeamformingInfo.beamformer_su_cnt += 1;
-			pEntry->is_mu_ap = FALSE;
-		}
-
-		return pEntry;
-	}
-	else
-		return NULL;
-}
-
-#if 0
-BOOLEAN
-Beamforming_RemoveEntry(
-	IN	PADAPTER			Adapter,
-	IN	pu1Byte		RA,
-	OUT	pu1Byte		Idx
-	)
-{
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T				pDM_Odm = &pHalData->DM_OutSrc;
-
-	PRT_BEAMFORMER_ENTRY	pBFerEntry = phydm_Beamforming_GetBFerEntryByAddr(pDM_Odm, RA, Idx);
-	PRT_BEAMFORMEE_ENTRY	pEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, Idx);
-	BOOLEAN ret = FALSE;
-    
-	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s Start!\n", __func__));
-	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, pBFerEntry=0x%x\n", __func__, pBFerEntry));
-	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, pEntry=0x%x\n", __func__, pEntry));
-	
-	if (pEntry != NULL) {	
-		pEntry->bUsed = FALSE;
-		pEntry->BeamformEntryCap = BEAMFORMING_CAP_NONE;
-		/*pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;*/
-		pEntry->bBeamformingInProgress = FALSE;
-		ret = TRUE;
-	} 
-	if (pBFerEntry != NULL) {
-		pBFerEntry->bUsed = FALSE;
-		pBFerEntry->BeamformEntryCap = BEAMFORMING_CAP_NONE;
-		ret = TRUE;
-	}
-	return ret;
-
-}
-#endif
-
-/* Used for BeamformingStart_V1  */
-VOID
-phydm_Beamforming_NDPARate(
-	IN	PVOID		pDM_VOID,
-	CHANNEL_WIDTH 	BW, 
-	u1Byte			Rate
-)
-{
-	u2Byte			NDPARate = Rate;
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (NDPARate == 0) {
-		if(pDM_Odm->RSSI_Min > 30) // link RSSI > 30%
-			NDPARate = ODM_RATE24M;
-		else
-			NDPARate = ODM_RATE6M;
-	}
-
-	if (NDPARate < ODM_RATEMCS0)
-		BW = (CHANNEL_WIDTH)ODM_BW20M;
-
-	NDPARate = (NDPARate << 8) | BW;
-	HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_RATE, (pu1Byte)&NDPARate);
-
-}
-
-
-/* Used for BeamformingStart_SW and  BeamformingStart_FW */
-VOID
-phydm_Beamforming_DymNDPARate(
-	IN	PVOID		pDM_VOID
-)
-{
-	u2Byte			NDPARate = ODM_RATE6M, BW;
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (pDM_Odm->RSSI_Min > 30)	/*link RSSI > 30%*/
-		NDPARate = ODM_RATE24M;
-	else
-		NDPARate = ODM_RATE6M;
-
-	BW = ODM_BW20M;
-	NDPARate = NDPARate << 8 | BW;
-	HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_RATE, (pu1Byte)&NDPARate);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s End, NDPA Rate = 0x%X\n", __func__, NDPARate));
-}
-
-/*	
-*	SW Sounding : SW Timer unit 1ms 
-*				 HW Timer unit (1/32000) s  32k is clock. 
-*	FW Sounding : FW Timer unit 10ms
-*/
-VOID
-Beamforming_DymPeriod(
-	IN	PVOID		pDM_VOID,
-	IN  u8          status
-)
-{
-	u1Byte 					Idx;
-	BOOLEAN					bChangePeriod = FALSE;	
-	u2Byte					SoundPeriod_SW, SoundPeriod_FW;
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_SOUNDING_INFO		pSoundInfo = &(pBeamInfo->SoundingInfo);
-
-	PRT_BEAMFORMEE_ENTRY	pEntry = &(pBeamInfo->BeamformeeEntry[pBeamInfo->BeamformeeCurIdx]);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-	
-	//3 TODO  per-client throughput caculation.
-
-	if ((*(pDM_Odm->pCurrentTxTP) + *(pDM_Odm->pCurrentRxTP) > 2) && ((pEntry->LogStatusFailCnt <= 20) || status)) {
-		SoundPeriod_SW = 40;	/* 40ms */
-		SoundPeriod_FW = 40;	/* From  H2C cmd, unit = 10ms */
-	} else {
-		SoundPeriod_SW = 4000;/* 4s */
-		SoundPeriod_FW = 400;
-	}
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]SoundPeriod_SW=%d, SoundPeriod_FW=%d\n",	__func__, SoundPeriod_SW, SoundPeriod_FW));
-
-	for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-		pBeamformEntry = pBeamInfo->BeamformeeEntry+Idx;
-		
-		if (pBeamformEntry->DefaultCSICnt > 20) {
-			/*Modified by David*/
-			SoundPeriod_SW = 4000;
-			SoundPeriod_FW = 400;
-		}
-		
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Period = %d\n", __func__, SoundPeriod_SW));		
-		if (pBeamformEntry->BeamformEntryCap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) {
-			if (pSoundInfo->SoundMode == SOUNDING_FW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_FW_HT_TIMER) {				
-				if (pBeamformEntry->SoundPeriod != SoundPeriod_FW) {
-					pBeamformEntry->SoundPeriod = SoundPeriod_FW;
-					bChangePeriod = TRUE;		/*Only FW sounding need to send H2C packet to change sound period. */
-				}
-			} else if (pBeamformEntry->SoundPeriod != SoundPeriod_SW) {
-				pBeamformEntry->SoundPeriod = SoundPeriod_SW;
-			}
-		}
-	}
-
-	if (bChangePeriod)
-		HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_FW_NDPA, (pu1Byte)&Idx);
-}
-
-
-
-
-BOOLEAN
-Beamforming_SendHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW,
-	IN	u1Byte			QIdx
-	)
-{
-	BOOLEAN		ret = TRUE;
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (QIdx == BEACON_QUEUE)
-		ret = SendFWHTNDPAPacket(pDM_Odm, RA, BW);
-	else
-		ret = SendSWHTNDPAPacket(pDM_Odm, RA, BW);
-
-	return ret;
-}
-
-
-
-BOOLEAN
-Beamforming_SendVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW,
-	IN	u1Byte			QIdx
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	BOOLEAN		ret = TRUE;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-
-	HalComTxbf_Set(pDM_Odm, TXBF_SET_GET_TX_RATE, NULL);
-
-	if ((pDM_Odm->TxBfDataRate >= ODM_RATEVHTSS3MCS7) && (pDM_Odm->TxBfDataRate <= ODM_RATEVHTSS3MCS9)) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("@%s: 3SS VHT 789 don't sounding\n", __func__));
-
-	} else  {
-		if (QIdx == BEACON_QUEUE) /* Send to reserved page => FW NDPA */
-			ret = SendFWVHTNDPAPacket(pDM_Odm, RA, AID, BW);
-		else {
-#ifdef SUPPORT_MU_BF
-		#if (SUPPORT_MU_BF == 1)
-			pBeamInfo->is_mu_sounding = TRUE;
-			ret = SendSWVHTMUNDPAPacket(pDM_Odm, BW);
-		#else
-			pBeamInfo->is_mu_sounding = FALSE;
-			ret = SendSWVHTNDPAPacket(pDM_Odm, RA, AID, BW);
-		#endif
-#else
-			pBeamInfo->is_mu_sounding = FALSE;
-			ret = SendSWVHTNDPAPacket(pDM_Odm, RA, AID, BW);
-#endif
-		}
-	}
-		return ret;
-}
-
-
-BEAMFORMING_NOTIFY_STATE
-phydm_beamfomring_bSounding(
-	IN	PVOID				pDM_VOID,
-	PRT_BEAMFORMING_INFO 	pBeamInfo,
-	pu1Byte					Idx
-	)
-{
-	BEAMFORMING_NOTIFY_STATE	bSounding = BEAMFORMING_NOTIFY_NONE;
-	RT_BEAMFORMING_OID_INFO	BeamOidInfo = pBeamInfo->BeamformingOidInfo;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	/*if(( Beamforming_GetBeamCap(pBeamInfo) & BEAMFORMER_CAP) == 0)*/
-	/*bSounding = BEAMFORMING_NOTIFY_RESET;*/
-	if (BeamOidInfo.SoundOidMode == SOUNDING_STOP_All_TIMER)
-		bSounding = BEAMFORMING_NOTIFY_RESET;
-	else {
-		u1Byte i;
-
-		for (i = 0 ; i < BEAMFORMEE_ENTRY_NUM ; i++) {
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("@%s: BFee Entry %d bUsed=%d, bSound=%d\n", __func__, i, pBeamInfo->BeamformeeEntry[i].bUsed, pBeamInfo->BeamformeeEntry[i].bSound));
-			if (pBeamInfo->BeamformeeEntry[i].bUsed && (!pBeamInfo->BeamformeeEntry[i].bSound)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: Add BFee entry %d\n", __func__, i));
-				*Idx = i;
-				if (pBeamInfo->BeamformeeEntry[i].is_mu_sta)
-					bSounding = BEAMFORMEE_NOTIFY_ADD_MU;
-				else
-					bSounding = BEAMFORMEE_NOTIFY_ADD_SU;
-			}
-
-			if ((!pBeamInfo->BeamformeeEntry[i].bUsed) && pBeamInfo->BeamformeeEntry[i].bSound) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: Delete BFee entry %d\n", __func__, i));
-				*Idx = i;
-				if (pBeamInfo->BeamformeeEntry[i].is_mu_sta)
-					bSounding = BEAMFORMEE_NOTIFY_DELETE_MU;
-				else
-					bSounding = BEAMFORMEE_NOTIFY_DELETE_SU;
-			}
-		}
-	}
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s End, bSounding = %d\n", __func__, bSounding));
-	return bSounding;
-}
-
-
-//This function is unused
-u1Byte
-phydm_beamforming_SoundingIdx(
-	IN	PVOID				pDM_VOID,
-	PRT_BEAMFORMING_INFO 		pBeamInfo
-	)
-{
-	u1Byte					Idx = 0;
-	RT_BEAMFORMEE_ENTRY	BeamEntry;
-	RT_BEAMFORMING_OID_INFO	BeamOidInfo = pBeamInfo->BeamformingOidInfo;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (BeamOidInfo.SoundOidMode == SOUNDING_SW_HT_TIMER || BeamOidInfo.SoundOidMode == SOUNDING_SW_VHT_TIMER ||
-		BeamOidInfo.SoundOidMode == SOUNDING_HW_HT_TIMER || BeamOidInfo.SoundOidMode == SOUNDING_HW_VHT_TIMER)
-		Idx = BeamOidInfo.SoundOidIdx;
-	else {
-		u1Byte	i;
-		for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-			if (pBeamInfo->BeamformeeEntry[i].bUsed && (FALSE == pBeamInfo->BeamformeeEntry[i].bSound)) {
-				Idx = i;
-				break;
-			}
-		}
-	}
-
-	return Idx;
-}
-
-
-SOUNDING_MODE
-phydm_beamforming_SoundingMode(
-	IN	PVOID				pDM_VOID,
-	PRT_BEAMFORMING_INFO 	pBeamInfo,
-	u1Byte					Idx
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte 			SupportInterface = pDM_Odm->SupportInterface;
-
-	RT_BEAMFORMEE_ENTRY		BeamEntry = pBeamInfo->BeamformeeEntry[Idx];
-	RT_BEAMFORMING_OID_INFO	BeamOidInfo = pBeamInfo->BeamformingOidInfo;
-	SOUNDING_MODE				Mode = BeamOidInfo.SoundOidMode;
-
-	if (BeamOidInfo.SoundOidMode == SOUNDING_SW_VHT_TIMER || BeamOidInfo.SoundOidMode == SOUNDING_HW_VHT_TIMER) {
-		if (BeamEntry.BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)
-			Mode = BeamOidInfo.SoundOidMode;
-		else 
-			Mode = SOUNDING_STOP_All_TIMER;
-	} else if (BeamOidInfo.SoundOidMode == SOUNDING_SW_HT_TIMER || BeamOidInfo.SoundOidMode == SOUNDING_HW_HT_TIMER) {
-		if (BeamEntry.BeamformEntryCap & BEAMFORMER_CAP_HT_EXPLICIT)
-			Mode = BeamOidInfo.SoundOidMode;
-		else
-			Mode = SOUNDING_STOP_All_TIMER;
-	} else if (BeamEntry.BeamformEntryCap & BEAMFORMER_CAP_VHT_SU) {
-		if ((SupportInterface == ODM_ITRF_USB) && !(pDM_Odm->SupportICType & (ODM_RTL8814A | ODM_RTL8822B)))
-			Mode = SOUNDING_FW_VHT_TIMER;
-		else
-			Mode = SOUNDING_SW_VHT_TIMER;
-	} else if (BeamEntry.BeamformEntryCap & BEAMFORMER_CAP_HT_EXPLICIT) {
-		if ((SupportInterface == ODM_ITRF_USB) && !(pDM_Odm->SupportICType & (ODM_RTL8814A | ODM_RTL8822B)))
-			Mode = SOUNDING_FW_HT_TIMER;
-		else
-			Mode = SOUNDING_SW_HT_TIMER;
-	} else 
-		Mode = SOUNDING_STOP_All_TIMER;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] SupportInterface=%d, Mode=%d\n", __func__, SupportInterface, Mode));
-
-	return Mode;
-}
-
-
-u2Byte
-phydm_beamforming_SoundingTime(
-	IN	PVOID				pDM_VOID,
-	PRT_BEAMFORMING_INFO 	pBeamInfo,
-	SOUNDING_MODE			Mode,
-	u1Byte					Idx
-	)
-{
-	u2Byte						SoundingTime = 0xffff;
-	RT_BEAMFORMEE_ENTRY		BeamEntry = pBeamInfo->BeamformeeEntry[Idx];
-	RT_BEAMFORMING_OID_INFO	BeamOidInfo = pBeamInfo->BeamformingOidInfo;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (Mode == SOUNDING_HW_HT_TIMER || Mode == SOUNDING_HW_VHT_TIMER)
-		SoundingTime = BeamOidInfo.SoundOidPeriod * 32;
-	else if (Mode == SOUNDING_SW_HT_TIMER || Mode == SOUNDING_SW_VHT_TIMER)
-		/*Modified by David*/
-		SoundingTime = BeamEntry.SoundPeriod;	/*BeamOidInfo.SoundOidPeriod;*/
-	else
-		SoundingTime = BeamEntry.SoundPeriod;
-
-	return SoundingTime;
-}
-
-
-CHANNEL_WIDTH
-phydm_beamforming_SoundingBW(
-	IN	PVOID				pDM_VOID,
-	PRT_BEAMFORMING_INFO 	pBeamInfo,
-	SOUNDING_MODE			Mode,
-	u1Byte					Idx
-	)
-{
-	CHANNEL_WIDTH				SoundingBW = CHANNEL_WIDTH_20;
-	RT_BEAMFORMEE_ENTRY		BeamEntry = pBeamInfo->BeamformeeEntry[Idx];
-	RT_BEAMFORMING_OID_INFO	BeamOidInfo = pBeamInfo->BeamformingOidInfo;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (Mode == SOUNDING_HW_HT_TIMER || Mode == SOUNDING_HW_VHT_TIMER)
-		SoundingBW = BeamOidInfo.SoundOidBW;
-	else if (Mode == SOUNDING_SW_HT_TIMER || Mode == SOUNDING_SW_VHT_TIMER)
-		/*Modified by David*/
-		SoundingBW = BeamEntry.SoundBW;		/*BeamOidInfo.SoundOidBW;*/
-	else 
-		SoundingBW = BeamEntry.SoundBW;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s, SoundingBW=0x%X\n", __func__, SoundingBW));
-
-	return SoundingBW;
-}
-
-
-BOOLEAN
-phydm_Beamforming_SelectBeamEntry(
-	IN	PVOID				pDM_VOID,
-	PRT_BEAMFORMING_INFO 	pBeamInfo
-	)
-{
-	PRT_SOUNDING_INFO		pSoundInfo = &(pBeamInfo->SoundingInfo);
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	/*pEntry.bSound is different between first and latter NDPA, and should not be used as BFee entry selection*/
-	/*BTW, latter modification should sync to the selection mechanism of AP/ADSL instead of the fixed SoundIdx.*/
-	pSoundInfo->SoundIdx = phydm_beamforming_SoundingIdx(pDM_Odm, pBeamInfo);
-	/*pSoundInfo->SoundIdx = 0;*/
-
-	if (pSoundInfo->SoundIdx < BEAMFORMEE_ENTRY_NUM)
-		pSoundInfo->SoundMode = phydm_beamforming_SoundingMode(pDM_Odm, pBeamInfo, pSoundInfo->SoundIdx);
-	else
-		pSoundInfo->SoundMode = SOUNDING_STOP_All_TIMER;
-	
-	if (SOUNDING_STOP_All_TIMER == pSoundInfo->SoundMode) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Return because of SOUNDING_STOP_All_TIMER\n", __func__));
-		return FALSE;
-	} else {
-		pSoundInfo->SoundBW = phydm_beamforming_SoundingBW(pDM_Odm, pBeamInfo, pSoundInfo->SoundMode, pSoundInfo->SoundIdx );
-		pSoundInfo->SoundPeriod = phydm_beamforming_SoundingTime(pDM_Odm, pBeamInfo, pSoundInfo->SoundMode, pSoundInfo->SoundIdx );
-		return TRUE;
-	}
-}
-
-/*SU BFee Entry Only*/
-BOOLEAN
-phydm_beamforming_StartPeriod(
-	IN	PVOID				pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER					Adapter = pDM_Odm->Adapter;
-	BOOLEAN						Ret = TRUE;
-	PRT_BEAMFORMING_INFO 		pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_SOUNDING_INFO			pSoundInfo = &(pBeamInfo->SoundingInfo); 
-	
-	phydm_Beamforming_DymNDPARate(pDM_Odm);
-
-	phydm_Beamforming_SelectBeamEntry(pDM_Odm, pBeamInfo);		// Modified
-
-	if (pSoundInfo->SoundMode == SOUNDING_SW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_SW_HT_TIMER)
-		ODM_SetTimer(pDM_Odm, &pBeamInfo->BeamformingTimer, pSoundInfo->SoundPeriod);
-	else if (pSoundInfo->SoundMode == SOUNDING_HW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_HW_HT_TIMER ||
-			pSoundInfo->SoundMode == SOUNDING_AUTO_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_AUTO_HT_TIMER) {
-		HAL_HW_TIMER_TYPE TimerType = HAL_TIMER_TXBF;
-		u4Byte	val = (pSoundInfo->SoundPeriod | (TimerType<<16));
-
-		//HW timer stop: All IC has the same setting
-		Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_HW_REG_TIMER_STOP,  (pu1Byte)(&TimerType));
-		//ODM_Write1Byte(pDM_Odm, 0x15F, 0);
-		//HW timer init: All IC has the same setting, but 92E & 8812A only write 2 bytes
-		Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_HW_REG_TIMER_INIT,  (pu1Byte)(&val));
-		//ODM_Write1Byte(pDM_Odm, 0x164, 1);
-		//ODM_Write4Byte(pDM_Odm, 0x15C, val);
-		//HW timer start: All IC has the same setting
-		Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_HW_REG_TIMER_START,  (pu1Byte)(&TimerType));
-		//ODM_Write1Byte(pDM_Odm, 0x15F, 0x5);
-	} else if (pSoundInfo->SoundMode == SOUNDING_FW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_FW_HT_TIMER)
-		Ret = BeamformingStart_FW(pDM_Odm, pSoundInfo->SoundIdx);
-	else
-		Ret = FALSE;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] SoundIdx=%d, SoundMode=%d, SoundBW=%d, SoundPeriod=%d\n", __func__, 
-			pSoundInfo->SoundIdx, pSoundInfo->SoundMode, pSoundInfo->SoundBW, pSoundInfo->SoundPeriod));
-
-	return Ret;
-}
-
-// Used after Beamforming_Leave, and will clear the setting of the "already deleted" entry
-/*SU BFee Entry Only*/
-VOID
-phydm_beamforming_EndPeriod_SW(
-	IN	PVOID				pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER					Adapter = pDM_Odm->Adapter;
-	u1Byte						Idx = 0;
-	PRT_BEAMFORMEE_ENTRY		pBeamformEntry;
-	PRT_BEAMFORMING_INFO 		pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_SOUNDING_INFO			pSoundInfo = &(pBeamInfo->SoundingInfo);
-	
-	HAL_HW_TIMER_TYPE TimerType = HAL_TIMER_TXBF;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (pSoundInfo->SoundMode == SOUNDING_SW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_SW_HT_TIMER)
-		ODM_CancelTimer(pDM_Odm, &pBeamInfo->BeamformingTimer);
-	else if (pSoundInfo->SoundMode == SOUNDING_HW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_HW_HT_TIMER ||
-				pSoundInfo->SoundMode == SOUNDING_AUTO_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_AUTO_HT_TIMER)
-		/*HW timer stop: All IC has the same setting*/
-		Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_HW_REG_TIMER_STOP,  (pu1Byte)(&TimerType));
-		/*ODM_Write1Byte(pDM_Odm, 0x15F, 0);*/
-}
-
-VOID
-phydm_beamforming_EndPeriod_FW(
-	IN	PVOID				pDM_VOID
-	)
-{
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte				Idx = 0;
-
-	HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_FW_NDPA, (pu1Byte)&Idx);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]\n", __func__));
-}
-
-
-/*SU BFee Entry Only*/
-VOID 
-phydm_beamforming_ClearEntry_SW(
-	IN	PVOID			pDM_VOID,
-	BOOLEAN				IsDelete,
-	u1Byte				DeleteIdx
-	)
-{
-	u1Byte						Idx = 0;
-	PRT_BEAMFORMEE_ENTRY		pBeamformEntry = NULL;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO 		pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	if (IsDelete) {
-		if (DeleteIdx < BEAMFORMEE_ENTRY_NUM) {
-			pBeamformEntry = pBeamInfo->BeamformeeEntry + DeleteIdx;
-			if (!((!pBeamformEntry->bUsed) && pBeamformEntry->bSound)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] SW DeleteIdx is wrong!!!!!\n", __func__));
-				return;
-			}
-		}
-
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] SW delete BFee entry %d\n", __func__, DeleteIdx));
-		if (pBeamformEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSING) {
-			pBeamformEntry->bBeamformingInProgress = FALSE;
-			pBeamformEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-		} else if (pBeamformEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			pBeamformEntry->BeamformEntryState  = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-			HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_STATUS, (pu1Byte)&DeleteIdx);
-		}
-		pBeamformEntry->bSound = FALSE;
-	} else {
-		for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-			pBeamformEntry = pBeamInfo->BeamformeeEntry+Idx;
-
-			/*Used after bSounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
-			/*This function is mainly used in case "BeamOidInfo.SoundOidMode == SOUNDING_STOP_All_TIMER".*/
-			/*However, setting oid doesn't delete entries (bUsed is still TRUE), new entries may fail to be added in.*/
-		
-			if (pBeamformEntry->bSound) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] SW reset BFee entry %d\n", __func__, Idx));
-				/*	
-				*	If End procedure is 
-				*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
-				*	After C2H packet return , status bit will be set to zero. 
-				*
-				*	2. After C2H packet, then reset state to initialized and clear status bit.
-				*/
-
-				if (pBeamformEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-					phydm_Beamforming_End_SW(pDM_Odm, 0);
-				else if (pBeamformEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-					pBeamformEntry->BeamformEntryState  = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-					HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_STATUS, (pu1Byte)&Idx);
-				}
-
-				pBeamformEntry->bSound = FALSE;
-			}
-		}
-	}
-}
-
-VOID
-phydm_beamforming_ClearEntry_FW(
-	IN	PVOID			pDM_VOID,
-	BOOLEAN				IsDelete,
-	u1Byte				DeleteIdx
-	)
-{
-	u1Byte						Idx = 0;
-	PRT_BEAMFORMEE_ENTRY		pBeamformEntry = NULL;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO 		pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	if (IsDelete) {
-		if (DeleteIdx < BEAMFORMEE_ENTRY_NUM) {
-			pBeamformEntry = pBeamInfo->BeamformeeEntry + DeleteIdx;
-
-			if (!((!pBeamformEntry->bUsed) && pBeamformEntry->bSound)) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] FW DeleteIdx is wrong!!!!!\n", __func__));
-				return;
-			}
-		}
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: FW delete BFee entry %d\n", __func__, DeleteIdx));
-		pBeamformEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-		pBeamformEntry->bSound = FALSE;
-	} else {
-		for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-			pBeamformEntry = pBeamInfo->BeamformeeEntry+Idx;
-
-			/*Used after bSounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
-			/*This function is mainly used in case "BeamOidInfo.SoundOidMode == SOUNDING_STOP_All_TIMER".*/
-			/*However, setting oid doesn't delete entries (bUsed is still TRUE), new entries may fail to be added in.*/
-		
-			if (pBeamformEntry->bSound) {
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]FW reset BFee entry %d\n", __func__, Idx));
-				/*	
-				*	If End procedure is 
-				*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
-				*	After C2H packet return , status bit will be set to zero. 
-				*
-				*	2. After C2H packet, then reset state to initialized and clear status bit.
-				*/
-				
-				pBeamformEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-				pBeamformEntry->bSound = FALSE;
-			}
-		}
-	}
-}
-
-/*
-* 	Called : 
-*	1. Add and delete entry : Beamforming_Enter/Beamforming_Leave
-*	2. FW trigger :  Beamforming_SetTxBFen
-*	3. Set OID_RT_BEAMFORMING_PERIOD : BeamformingControl_V2
-*/
-VOID
-phydm_Beamforming_Notify(
-	IN	PVOID			pDM_VOID
-	)
-{
-	u1Byte						Idx=BEAMFORMEE_ENTRY_NUM;
-	BEAMFORMING_NOTIFY_STATE	bSounding = BEAMFORMING_NOTIFY_NONE;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO 		pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_SOUNDING_INFO			pSoundInfo = &(pBeamInfo->SoundingInfo);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	bSounding = phydm_beamfomring_bSounding(pDM_Odm, pBeamInfo, &Idx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s, Before notify, bSounding=%d, Idx=%d\n", __func__, bSounding, Idx));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: pBeamInfo->beamformee_su_cnt = %d\n", __func__, pBeamInfo->beamformee_su_cnt));
-	
-
-	switch (bSounding) {
-	case BEAMFORMEE_NOTIFY_ADD_SU:
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: BEAMFORMEE_NOTIFY_ADD_SU\n", __func__));
-		phydm_beamforming_StartPeriod(pDM_Odm);
-	break;
-
-	case BEAMFORMEE_NOTIFY_DELETE_SU:
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: BEAMFORMEE_NOTIFY_DELETE_SU\n", __func__));
-		if (pSoundInfo->SoundMode == SOUNDING_FW_HT_TIMER || pSoundInfo->SoundMode == SOUNDING_FW_VHT_TIMER) {
-			phydm_beamforming_ClearEntry_FW(pDM_Odm, TRUE, Idx);
-			if (pBeamInfo->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
-				phydm_beamforming_EndPeriod_FW(pDM_Odm);
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: No BFee left\n", __func__));
-			}
-		} else {
-			phydm_beamforming_ClearEntry_SW(pDM_Odm, TRUE, Idx);
-			if (pBeamInfo->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
-				phydm_beamforming_EndPeriod_SW(pDM_Odm);
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: No BFee left\n", __func__));
-			}
-		}
-	break;
-
-	case BEAMFORMEE_NOTIFY_ADD_MU:
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: BEAMFORMEE_NOTIFY_ADD_MU\n", __func__));
-		if (pBeamInfo->beamformee_mu_cnt == 2) {
-			/*if (pSoundInfo->SoundMode == SOUNDING_SW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_SW_HT_TIMER)
-				ODM_SetTimer(pDM_Odm, &pBeamInfo->BeamformingTimer, pSoundInfo->SoundPeriod);*/
-			ODM_SetTimer(pDM_Odm, &pBeamInfo->BeamformingTimer, 1000); /*Do MU sounding every 1sec*/
-		} else
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: Less or larger than 2 MU STAs, not to set timer\n", __func__));
-	break;
-
-	case BEAMFORMEE_NOTIFY_DELETE_MU:
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: BEAMFORMEE_NOTIFY_DELETE_MU\n", __func__));
-		if (pBeamInfo->beamformee_mu_cnt == 1) {
-			/*if (pSoundInfo->SoundMode == SOUNDING_SW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_SW_HT_TIMER)*/{
-				ODM_CancelTimer(pDM_Odm, &pBeamInfo->BeamformingTimer);
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: Less than 2 MU STAs, stop sounding\n", __func__));
-			}
-		}
-	break;
-
-	case BEAMFORMING_NOTIFY_RESET:
-		if (pSoundInfo->SoundMode == SOUNDING_FW_HT_TIMER || pSoundInfo->SoundMode == SOUNDING_FW_VHT_TIMER) {	
-			phydm_beamforming_ClearEntry_FW(pDM_Odm, FALSE, Idx);
-			phydm_beamforming_EndPeriod_FW(pDM_Odm);
-		} else {
-			phydm_beamforming_ClearEntry_SW(pDM_Odm, FALSE, Idx);
-			phydm_beamforming_EndPeriod_SW(pDM_Odm);
-		}
-
-	break;
-
-	default:
-	break;
-	}
-
-}
-
-
-
-BOOLEAN
-Beamforming_InitEntry(
-	IN	PVOID		pDM_VOID,
-	IN	u2Byte		staIdx,
-	pu1Byte			BFerBFeeIdx
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMEE_ENTRY		pBeamformEntry = NULL;
-	PRT_BEAMFORMER_ENTRY		pBeamformerEntry = NULL;
-	PRT_BEAMFORM_STAINFO		pSTA = NULL;
-	BEAMFORMING_CAP			BeamformCap = BEAMFORMING_CAP_NONE;
-	u1Byte						BFerIdx=0xF, BFeeIdx=0xF;
-	u1Byte						NumofSoundingDim = 0, CompSteeringNumofBFer = 0;
-
-	pSTA = phydm_staInfoInit(pDM_Odm, staIdx);
-
-	/*The current setting does not support Beaforming*/
-	if (BEAMFORMING_CAP_NONE == pSTA->HtBeamformCap && BEAMFORMING_CAP_NONE == pSTA->VhtBeamformCap) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("The configuration disabled Beamforming! Skip...\n"));		
-		return FALSE;
-	}
-
-	if (pSTA->WirelessMode < WIRELESS_MODE_N_24G)
-		return FALSE;
-	else {	/*HT*/
-		/*We are Beamformee because the STA is Beamformer*/
-		if (TEST_FLAG(pSTA->CurBeamform, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
-			BeamformCap =(BEAMFORMING_CAP)(BeamformCap |BEAMFORMEE_CAP_HT_EXPLICIT);
-			NumofSoundingDim = (pSTA->CurBeamform&BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP)>>6;
-		}
-		/*We are Beamformer because the STA is Beamformee*/
-		if (TEST_FLAG(pSTA->CurBeamform, BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
-			TEST_FLAG(pSTA->HtBeamformCap, BEAMFORMING_HT_BEAMFORMER_TEST)) {
-			BeamformCap =(BEAMFORMING_CAP)(BeamformCap | BEAMFORMER_CAP_HT_EXPLICIT);
-			CompSteeringNumofBFer = (pSTA->CurBeamform & BEAMFORMING_HT_BEAMFORMER_STEER_NUM)>>4;
-		}
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] HT CurBeamform=0x%X, BeamformCap=0x%X\n", __func__, pSTA->CurBeamform, BeamformCap));
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] HT NumofSoundingDim=%d, CompSteeringNumofBFer=%d\n", __func__, NumofSoundingDim, CompSteeringNumofBFer));
-#if	(ODM_IC_11AC_SERIES_SUPPORT == 1)
-		if (pSTA->WirelessMode & WIRELESS_MODE_AC_5G || pSTA->WirelessMode & WIRELESS_MODE_AC_24G) {	/*VHT*/	
-
-			/* We are Beamformee because the STA is SU Beamformer*/
-			if (TEST_FLAG(pSTA->CurBeamformVHT, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
-				BeamformCap =(BEAMFORMING_CAP)(BeamformCap |BEAMFORMEE_CAP_VHT_SU);
-				NumofSoundingDim = (pSTA->CurBeamformVHT & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM)>>12;
-			}
-			/* We are Beamformer because the STA is SU Beamformee*/
-			if (TEST_FLAG(pSTA->CurBeamformVHT, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) ||
-				TEST_FLAG(pSTA->VhtBeamformCap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
-				BeamformCap =(BEAMFORMING_CAP)(BeamformCap |BEAMFORMER_CAP_VHT_SU);
-				CompSteeringNumofBFer = (pSTA->CurBeamformVHT & BEAMFORMING_VHT_BEAMFORMER_STS_CAP)>>8;
-			}
-			/* We are Beamformee because the STA is MU Beamformer*/
-			if (TEST_FLAG(pSTA->CurBeamformVHT, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
-				BeamformCap = (BEAMFORMING_CAP)(BeamformCap | BEAMFORMEE_CAP_VHT_MU);
-				NumofSoundingDim = (pSTA->CurBeamformVHT & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM)>>12;
-			}
-			/* We are Beamformer because the STA is MU Beamformee*/
-			if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_AP)) { /* Only AP mode supports to act an MU beamformer */
-				if (TEST_FLAG(pSTA->CurBeamformVHT, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE) ||
-					TEST_FLAG(pSTA->VhtBeamformCap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
-					BeamformCap = (BEAMFORMING_CAP)(BeamformCap | BEAMFORMER_CAP_VHT_MU);
-					CompSteeringNumofBFer = (pSTA->CurBeamformVHT & BEAMFORMING_VHT_BEAMFORMER_STS_CAP)>>8;
-				}
-			}
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]VHT CurBeamformVHT=0x%X, BeamformCap=0x%X\n", __func__, pSTA->CurBeamformVHT, BeamformCap));
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]VHT NumofSoundingDim=0x%X, CompSteeringNumofBFer=0x%X\n", __func__, NumofSoundingDim, CompSteeringNumofBFer));
-			
-		}
-#endif
-	}
-
-
-	if(BeamformCap == BEAMFORMING_CAP_NONE)
-		return FALSE;
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Self BF Entry Cap = 0x%02X\n", __func__, BeamformCap));
-
-	/*We are BFee, so the entry is BFer*/
-	if (BeamformCap & (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP_HT_EXPLICIT)) {
-		pBeamformerEntry = phydm_Beamforming_GetBFerEntryByAddr(pDM_Odm, pSTA->RA, &BFerIdx);
-		
-		if (pBeamformerEntry == NULL) {
-			pBeamformerEntry = Beamforming_AddBFerEntry(pDM_Odm, pSTA, BeamformCap, NumofSoundingDim , &BFerIdx);
-			if (pBeamformerEntry == NULL)
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]Not enough BFer entry!!!!!\n", __func__));
-		}
-	}
-
-	/*We are BFer, so the entry is BFee*/
-	if (BeamformCap & (BEAMFORMER_CAP_VHT_MU | BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP_HT_EXPLICIT)) {
-		pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, pSTA->RA, &BFeeIdx);
-
-		/*如果BFeeIdx = 0xF 則代表目前entry當中沒有相同的MACID在內*/
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Get BFee entry 0x%X by address\n", __func__, BFeeIdx));
-		if (pBeamformEntry == NULL) {
-			pBeamformEntry = Beamforming_AddBFeeEntry(pDM_Odm, pSTA, BeamformCap, NumofSoundingDim, CompSteeringNumofBFer, &BFeeIdx);
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]: pSTA->AID=%d, pSTA->MacID=%d\n", __func__, pSTA->AID, pSTA->MacID));
-
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]: Add BFee entry %d\n", __func__, BFeeIdx));
-
-			if (pBeamformEntry == NULL)
-				return FALSE;
-			else
-				pBeamformEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
-		} else {
-			/*Entry has been created. If entry is initialing or progressing then errors occur.*/
-			if (pBeamformEntry->BeamformEntryState != BEAMFORMING_ENTRY_STATE_INITIALIZED && 
-				pBeamformEntry->BeamformEntryState != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-				return FALSE;
-			} else
-				pBeamformEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
-		}
-		pBeamformEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-		phydm_staInfoUpdate(pDM_Odm, staIdx, pBeamformEntry);
-	}
-
-	*BFerBFeeIdx = (BFerIdx<<4) | BFeeIdx;
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] End: BFerIdx=0x%X, BFeeIdx=0x%X, BFerBFeeIdx=0x%X\n", __func__, BFerIdx, BFeeIdx, *BFerBFeeIdx));
-
-	return TRUE;
-}
-
-
-VOID
-Beamforming_DeInitEntry(
-	IN	PVOID		pDM_VOID,
-	pu1Byte			RA
-	)
-{
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte				Idx = 0;
-
-	PRT_BEAMFORMER_ENTRY	pBFerEntry = phydm_Beamforming_GetBFerEntryByAddr(pDM_Odm, RA, &Idx);
-	PRT_BEAMFORMEE_ENTRY	pBFeeEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-	BOOLEAN ret = FALSE;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n",  __func__));
-	
-	if (pBFeeEntry != NULL) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s, pBFeeEntry\n", __func__));
-		pBFeeEntry->bUsed = FALSE;
-		pBFeeEntry->BeamformEntryCap = BEAMFORMING_CAP_NONE;
-		pBFeeEntry->bBeamformingInProgress = FALSE;
-		if (pBFeeEntry->is_mu_sta) {
-			pDM_Odm->BeamformingInfo.beamformee_mu_cnt -= 1;
-			pDM_Odm->BeamformingInfo.FirstMUBFeeIndex = phydm_Beamforming_GetFirstMUBFeeEntryIdx(pDM_Odm);
-		} else {
-			pDM_Odm->BeamformingInfo.beamformee_su_cnt -= 1;
-		}
-		ret = TRUE;
-	} 
-	
-	if (pBFerEntry != NULL) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s, pBFerEntry\n", __func__));
-		pBFerEntry->bUsed = FALSE;
-		pBFerEntry->BeamformEntryCap = BEAMFORMING_CAP_NONE;
-		if (pBFerEntry->is_mu_ap)
-			pDM_Odm->BeamformingInfo.beamformer_mu_cnt -= 1;
-		else
-			pDM_Odm->BeamformingInfo.beamformer_su_cnt -= 1;
-		ret = TRUE;
-	}
-
-	if (ret == TRUE)
-		HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_LEAVE, (pu1Byte)&Idx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s End, Idx = 0x%X\n", __func__, Idx));
-}
-
-
-VOID
-Beamforming_Reset(
-	IN	PVOID				pDM_VOID
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					Idx = 0;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &(pDM_Odm->BeamformingInfo);
-
-	for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-		if (pBeamformingInfo->BeamformeeEntry[Idx].bUsed == TRUE) {
-			pBeamformingInfo->BeamformeeEntry[Idx].bUsed = FALSE;
-			pBeamformingInfo->BeamformeeEntry[Idx].BeamformEntryCap = BEAMFORMING_CAP_NONE;
-			/*pBeamformingInfo->BeamformeeEntry[Idx].BeamformEntryState = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;*/
-			/*Modified by David*/
-			pBeamformingInfo->BeamformeeEntry[Idx].bBeamformingInProgress = FALSE;
-			HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_LEAVE, (pu1Byte)&Idx);
-		}
-	}
-
-	for (Idx = 0; Idx < BEAMFORMER_ENTRY_NUM; Idx++) {
-		pBeamformingInfo->BeamformerEntry[Idx].bUsed = FALSE;
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Idx=%d, bUsed=%d\n", __func__, Idx, pBeamformingInfo->BeamformerEntry[Idx].bUsed));
-	}
-
-}
-
-
-BOOLEAN
-BeamformingStart_V1(
-	IN	PVOID		pDM_VOID,
-	pu1Byte			RA,
-	BOOLEAN			Mode,
-	CHANNEL_WIDTH	BW,
-	u1Byte			Rate
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					Idx = 0;
-	PRT_BEAMFORMEE_ENTRY	pEntry;
-	BOOLEAN					ret = TRUE;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	
-	pEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	if (pEntry->bUsed == FALSE) {
-		pEntry->bBeamformingInProgress = FALSE;
-		return FALSE;
-	} else {
-		if (pEntry->bBeamformingInProgress)
-			return FALSE;
-
-		pEntry->bBeamformingInProgress = TRUE;
-
-		if (Mode == 1) {	
-			if (!(pEntry->BeamformEntryCap & BEAMFORMER_CAP_HT_EXPLICIT)) {
-				pEntry->bBeamformingInProgress = FALSE;
-				return FALSE;
-			}
-		} else if (Mode == 0) {
-			if (!(pEntry->BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)) {
-				pEntry->bBeamformingInProgress = FALSE;
-				return FALSE;
-			}
-		}
-
-		if (pEntry->BeamformEntryState != BEAMFORMING_ENTRY_STATE_INITIALIZED && pEntry->BeamformEntryState != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			pEntry->bBeamformingInProgress = FALSE;
-			return FALSE;
-		} else {
-			pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSING;
-			pEntry->bSound = TRUE;
-		}
-	}
-
-	pEntry->SoundBW = BW;
-	pBeamInfo->BeamformeeCurIdx = Idx;
-	phydm_Beamforming_NDPARate(pDM_Odm, BW, Rate);
-	HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_STATUS, (pu1Byte)&Idx);
-
-	if (Mode == 1)
-		ret = Beamforming_SendHTNDPAPacket(pDM_Odm, RA, BW, NORMAL_QUEUE);	
-	else
-		ret = Beamforming_SendVHTNDPAPacket(pDM_Odm, RA, pEntry->AID, BW, NORMAL_QUEUE);
-
-	if (ret == FALSE) {
-		Beamforming_Leave(pDM_Odm, RA);
-		pEntry->bBeamformingInProgress = FALSE;
-		return FALSE;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s  Idx %d\n", __func__, Idx));
-	return TRUE;
-}
-
-
-BOOLEAN
-BeamformingStart_SW(
-	IN	PVOID		pDM_VOID,
-	u1Byte			Idx,
-	u1Byte			Mode, 
-	CHANNEL_WIDTH	BW
-	)
-{
-	pu1Byte					RA = NULL;
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMEE_ENTRY	pEntry;
-	BOOLEAN					ret = TRUE;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-
-	pEntry = &(pBeamInfo->BeamformeeEntry[Idx]);
-
-	if (pEntry->bUsed == FALSE) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("Skip Beamforming, no entry for Idx =%d\n", Idx));
-		pEntry->bBeamformingInProgress = FALSE;
-		return FALSE;
-	} else {
-		if (pEntry->bBeamformingInProgress) {
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("bBeamformingInProgress, skip...\n"));
-			return FALSE;
-		}
-
-		pEntry->bBeamformingInProgress = TRUE;
-		RA = pEntry->MacAddr;
-		
-		if (Mode == SOUNDING_SW_HT_TIMER || Mode == SOUNDING_HW_HT_TIMER || Mode == SOUNDING_AUTO_HT_TIMER) {	
-			if (!(pEntry->BeamformEntryCap & BEAMFORMER_CAP_HT_EXPLICIT)) {
-				pEntry->bBeamformingInProgress = FALSE;
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Return by not support BEAMFORMER_CAP_HT_EXPLICIT <==\n", __func__));
-				return FALSE;
-			}
-		} else if (Mode == SOUNDING_SW_VHT_TIMER || Mode == SOUNDING_HW_VHT_TIMER || Mode == SOUNDING_AUTO_VHT_TIMER) {
-			if (!(pEntry->BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)) {
-				pEntry->bBeamformingInProgress = FALSE;
-				ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Return by not support BEAMFORMER_CAP_VHT_SU <==\n", __func__));
-				return FALSE;
-			}
-		}
-		if (pEntry->BeamformEntryState != BEAMFORMING_ENTRY_STATE_INITIALIZED && pEntry->BeamformEntryState != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			pEntry->bBeamformingInProgress = FALSE;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Return by incorrect BeamformEntryState(%d) <==\n", __func__, pEntry->BeamformEntryState));
-			return FALSE;
-		} else {
-			pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSING;
-			pEntry->bSound = TRUE;
-		}
-	}
-
-	pBeamInfo->BeamformeeCurIdx = Idx;
-	/*2014.12.22 Luke: Need to be checked*/
-	/*GET_TXBF_INFO(Adapter)->fTxbfSet(Adapter, TXBF_SET_SOUNDING_STATUS, (pu1Byte)&Idx);*/
-
-	if (Mode == SOUNDING_SW_HT_TIMER || Mode == SOUNDING_HW_HT_TIMER || Mode == SOUNDING_AUTO_HT_TIMER)
-		ret = Beamforming_SendHTNDPAPacket(pDM_Odm, RA , BW, NORMAL_QUEUE);	
-	else
-		ret = Beamforming_SendVHTNDPAPacket(pDM_Odm, RA , pEntry->AID, BW, NORMAL_QUEUE);
-
-	if (ret == FALSE) {
-		Beamforming_Leave(pDM_Odm, RA);
-		pEntry->bBeamformingInProgress = FALSE;
-		return FALSE;
-	}
-
-	
-	/*--------------------------
-	// Send BF Report Poll for MU BF
-	--------------------------*/
-#ifdef SUPPORT_MU_BF
-#if (SUPPORT_MU_BF == 1)
-{
-	u1Byte				idx, PollSTACnt = 0;
-	BOOLEAN				bGetFirstBFee = FALSE;
-	
-	if (pBeamInfo->beamformee_mu_cnt > 1) { /* More than 1 MU STA*/
-	
-		for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-			pEntry = &(pBeamInfo->BeamformeeEntry[idx]);
-			if (pEntry->is_mu_sta) {
-				if (bGetFirstBFee) {
-					PollSTACnt++;
-					if (PollSTACnt == (pBeamInfo->beamformee_mu_cnt - 1))/* The last STA*/
-						SendSWVHTBFReportPoll(pDM_Odm, pEntry->MacAddr, TRUE);
-					else
-						SendSWVHTBFReportPoll(pDM_Odm, pEntry->MacAddr, FALSE);
-				} else {
-					bGetFirstBFee = TRUE;
-				}
-			}
-		}
-	}
-}
-#endif
-#endif
-	return TRUE;
-}
-
-
-BOOLEAN
-BeamformingStart_FW(
-	IN PVOID		pDM_VOID,
-	u1Byte			Idx
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pu1Byte					RA = NULL;
-	PRT_BEAMFORMEE_ENTRY	pEntry;
-	BOOLEAN					ret = TRUE;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-
-	pEntry = &(pBeamInfo->BeamformeeEntry[Idx]);
-	if (pEntry->bUsed == FALSE) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("Skip Beamforming, no entry for Idx =%d\n", Idx));
-		return FALSE;
-	}
-
-	pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSING;
-	pEntry->bSound = TRUE;
-	HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_FW_NDPA, (pu1Byte)&Idx);
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] End, Idx=0x%X\n", __func__, Idx));
-	return TRUE;
-}
-
-VOID
-Beamforming_CheckSoundingSuccess(
-	IN PVOID			pDM_VOID,
-	BOOLEAN			Status	
-)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pEntry = &(pBeamInfo->BeamformeeEntry[pBeamInfo->BeamformeeCurIdx]);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[David]@%s Start!\n", __func__));
-
-	if (Status == 1) {
-		if (pEntry->LogStatusFailCnt == 21)
-			Beamforming_DymPeriod(pDM_Odm, Status);
-		pEntry->LogStatusFailCnt = 0;
-	} else if (pEntry->LogStatusFailCnt <= 20) {
-		pEntry->LogStatusFailCnt++;
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s LogStatusFailCnt %d\n", __func__, pEntry->LogStatusFailCnt));
-	}
-	if (pEntry->LogStatusFailCnt > 20) {
-		pEntry->LogStatusFailCnt = 21;
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s LogStatusFailCnt > 20, Stop SOUNDING\n", __func__));
-		Beamforming_DymPeriod(pDM_Odm, Status);
-	}
-}
-
-VOID
-phydm_Beamforming_End_SW(
-	IN PVOID		pDM_VOID,
-	BOOLEAN			Status	
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO 	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pEntry = &(pBeamInfo->BeamformeeEntry[pBeamInfo->BeamformeeCurIdx]);
-
-	if (pEntry->BeamformEntryState != BEAMFORMING_ENTRY_STATE_PROGRESSING) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] BeamformStatus %d\n", __func__, pEntry->BeamformEntryState));
-		return;
-	}
-
-	if ((pDM_Odm->TxBfDataRate >= ODM_RATEVHTSS3MCS7) && (pDM_Odm->TxBfDataRate <= ODM_RATEVHTSS3MCS9)) {
-		ODM_RT_TRACE(pDM_Odm, BEAMFORMING_DEBUG, ODM_DBG_LOUD, ("[%s] VHT3SS 7,8,9, do not apply V matrix.\n", __func__));
-		pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-		HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_STATUS, (pu1Byte)&(pBeamInfo->BeamformeeCurIdx));
-	} else if (Status == 1) {
-		pEntry->LogStatusFailCnt = 0;
-		pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSED;
-		HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_STATUS, (pu1Byte)&(pBeamInfo->BeamformeeCurIdx));
-	} else {
-		pEntry->LogStatusFailCnt++;
-		pEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-		HalComTxbf_Set(pDM_Odm, TXBF_SET_TX_PATH_RESET, (pu1Byte)&(pBeamInfo->BeamformeeCurIdx));
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] LogStatusFailCnt %d\n", __func__, pEntry->LogStatusFailCnt));
-	}
-	
-	if (pEntry->LogStatusFailCnt > 30) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s LogStatusFailCnt > 50, Stop SOUNDING\n", __func__));
-		pEntry->bSound = FALSE;
-		Beamforming_DeInitEntry(pDM_Odm, pEntry->MacAddr); 
-
-		/*Modified by David - Every action of deleting entry should follow by Notify*/
-		phydm_Beamforming_Notify(pDM_Odm);
-	}	
-	pEntry->bBeamformingInProgress = FALSE;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: Status=%d\n", __func__, Status));
-}	
-
-
-VOID
-Beamforming_TimerCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN PVOID			pDM_VOID
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	IN PVOID            pContext
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER					Adapter = pDM_Odm->Adapter;
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PADAPTER					Adapter = (PADAPTER)pContext;
-	PHAL_DATA_TYPE				pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T					pDM_Odm = &pHalData->odmpriv;
-#endif
-	BOOLEAN						ret = FALSE;
-	PRT_BEAMFORMING_INFO		pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY		pEntry = &(pBeamInfo->BeamformeeEntry[pBeamInfo->BeamformeeCurIdx]);
-	PRT_SOUNDING_INFO			pSoundInfo = &(pBeamInfo->SoundingInfo);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	if (pEntry->bBeamformingInProgress) {
-	 	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("bBeamformingInProgress, reset it\n"));
-		phydm_Beamforming_End_SW(pDM_Odm, 0);
-	 }
-
-	ret = phydm_Beamforming_SelectBeamEntry(pDM_Odm, pBeamInfo);
-#if (SUPPORT_MU_BF == 1)
-	if (ret && pBeamInfo->beamformee_mu_cnt > 1)
-		ret = 1;
-	else
-		ret = 0;
-#endif
-	if (ret)
-		ret = BeamformingStart_SW(pDM_Odm, pSoundInfo->SoundIdx, pSoundInfo->SoundMode, pSoundInfo->SoundBW);
-	else
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s, Error value return from BeamformingStart_V2\n", __func__));
-
-	if ((pBeamInfo->beamformee_su_cnt != 0) || (pBeamInfo->beamformee_mu_cnt > 1)) {
-		if (pSoundInfo->SoundMode == SOUNDING_SW_VHT_TIMER || pSoundInfo->SoundMode == SOUNDING_SW_HT_TIMER)
-			ODM_SetTimer(pDM_Odm, &pBeamInfo->BeamformingTimer, pSoundInfo->SoundPeriod);
-		else {
-			u4Byte	val = (pSoundInfo->SoundPeriod << 16) | HAL_TIMER_TXBF;
-			Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_HW_REG_TIMER_RESTART, (pu1Byte)(&val));
-		}
-	}
-}
-
-
-VOID
-Beamforming_SWTimerCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PRT_TIMER		pTimer
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	void *FunctionContext
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-	Beamforming_TimerCallback(pDM_Odm);
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)FunctionContext;
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-	if (Adapter->net_closed == TRUE)
-		return;
-	rtw_run_in_thread_cmd(Adapter, Beamforming_TimerCallback, Adapter);
-#endif
-	
-}
-
-
-VOID
-phydm_Beamforming_Init(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO 		pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PHAL_TXBF_INFO				pTxbfInfo = &pBeamInfo->TxbfInfo;
-	PRT_BEAMFORMING_OID_INFO	pBeamOidInfo = &(pBeamInfo->BeamformingOidInfo);
-	
-	pBeamOidInfo->SoundOidMode = SOUNDING_STOP_OID_TIMER;
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Mode (%d)\n", __func__, pBeamOidInfo->SoundOidMode));
-
-	pBeamInfo->beamformee_su_cnt = 0;
-	pBeamInfo->beamformer_su_cnt = 0;
-	pBeamInfo->beamformee_mu_cnt = 0;
-	pBeamInfo->beamformer_mu_cnt = 0;
-	pBeamInfo->beamformee_mu_reg_maping = 0;
-	pBeamInfo->mu_ap_index = 0;
-	pBeamInfo->is_mu_sounding = FALSE;
-	pBeamInfo->FirstMUBFeeIndex = 0xFF;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	pBeamInfo->SourceAdapter = pDM_Odm->Adapter;
-#endif
-	halComTxbf_beamformInit(pDM_Odm);
-}	
-
-
-VOID
-Beamforming_Enter(
-	IN PVOID			pDM_VOID,
-	IN u2Byte		staIdx
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			BFerBFeeIdx = 0xff;
-	
-	if (Beamforming_InitEntry(pDM_Odm, staIdx, &BFerBFeeIdx))
-		HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_ENTER, (pu1Byte)&BFerBFeeIdx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] End!\n", __func__));
-}
-
-
-VOID
-Beamforming_Leave(
-	IN PVOID			pDM_VOID,
-	pu1Byte			RA
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (RA == NULL)
-		Beamforming_Reset(pDM_Odm);
-	else
-		Beamforming_DeInitEntry(pDM_Odm, RA);
-
-	phydm_Beamforming_Notify(pDM_Odm);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] End!!\n", __func__));
-}
-
-#if 0
-//Nobody calls this function
-VOID
-phydm_Beamforming_SetTxBFen(
-	IN	PVOID		pDM_VOID,
-	u1Byte			MacId,
-	BOOLEAN			bTxBF
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					Idx = 0;
-	PRT_BEAMFORMEE_ENTRY	pEntry;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	pEntry = phydm_Beamforming_GetEntryByMacId(pDM_Odm, MacId, &Idx);
-
-	if(pEntry == NULL)
-		return;
-	else
-		pEntry->bTxBF = bTxBF;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s MacId %d TxBF %d\n", __func__, pEntry->MacId, pEntry->bTxBF));
-
-	phydm_Beamforming_Notify(pDM_Odm);
-}
-#endif
-
-BEAMFORMING_CAP
-phydm_Beamforming_GetBeamCap(
-	IN PVOID						pDM_VOID,
-	IN PRT_BEAMFORMING_INFO 	pBeamInfo
-	)
-{
-	u1Byte					i;
-	BOOLEAN 				bSelfBeamformer = FALSE;
-	BOOLEAN 				bSelfBeamformee = FALSE;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	BEAMFORMING_CAP 		BeamformCap = BEAMFORMING_CAP_NONE;
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		BeamformeeEntry = pBeamInfo->BeamformeeEntry[i];
-
-		if (BeamformeeEntry.bUsed) {
-			bSelfBeamformer = TRUE;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] BFee entry %d bUsed=TRUE\n", __func__, i));
-			break;
-		}
-	}
-
-	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
-		BeamformerEntry = pBeamInfo->BeamformerEntry[i];
-
-		if (BeamformerEntry.bUsed) {
-			bSelfBeamformee = TRUE;
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]: BFer entry %d bUsed=TRUE\n", __func__, i));
-			break;
-		}
-	}
-
-	if (bSelfBeamformer)
-		BeamformCap = (BEAMFORMING_CAP)(BeamformCap | BEAMFORMER_CAP);
-	if (bSelfBeamformee)
-		BeamformCap = (BEAMFORMING_CAP)(BeamformCap | BEAMFORMEE_CAP);
-
-	return BeamformCap;
-}
-
-
-BOOLEAN
-BeamformingControl_V1(
-	IN PVOID			pDM_VOID,
-	pu1Byte			RA,
-	u1Byte			AID,
-	u1Byte			Mode, 
-	CHANNEL_WIDTH	BW,
-	u1Byte			Rate
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	BOOLEAN		ret = TRUE;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("AID (%d), Mode (%d), BW (%d)\n", AID, Mode, BW));
-
-	switch (Mode) {	
-	case 0:
-	ret = BeamformingStart_V1(pDM_Odm, RA, 0, BW, Rate);
-	break;
-	case 1:
-	ret = BeamformingStart_V1(pDM_Odm, RA, 1, BW, Rate);
-	break;
-	case 2:
-	phydm_Beamforming_NDPARate(pDM_Odm, BW, Rate);
-	ret = Beamforming_SendVHTNDPAPacket(pDM_Odm, RA, AID, BW, NORMAL_QUEUE);
-	break;
-	case 3:
-	phydm_Beamforming_NDPARate(pDM_Odm, BW, Rate);
-	ret = Beamforming_SendHTNDPAPacket(pDM_Odm, RA, BW, NORMAL_QUEUE);
-	break;
-	}
-	return ret;
-}
-
-/*Only OID uses this function*/
-BOOLEAN
-phydm_BeamformingControl_V2(
-	IN	PVOID		pDM_VOID,
-	u1Byte			Idx,
-	u1Byte			Mode, 
-	CHANNEL_WIDTH	BW,
-	u2Byte			Period
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO		pBeamInfo =  &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMING_OID_INFO	pBeamOidInfo = &(pBeamInfo->BeamformingOidInfo);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Start!\n", __func__));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("Idx (%d), Mode (%d), BW (%d), Period (%d)\n", Idx, Mode, BW, Period));
-
-	pBeamOidInfo->SoundOidIdx = Idx;
-	pBeamOidInfo->SoundOidMode = (SOUNDING_MODE) Mode;
-	pBeamOidInfo->SoundOidBW = BW;
-	pBeamOidInfo->SoundOidPeriod = Period;
-
-	phydm_Beamforming_Notify(pDM_Odm);
-
-	return TRUE;
-}
-
-
-VOID
-phydm_Beamforming_Watchdog(
-	IN	PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO 		pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_TRACE, ("%s Start!\n", __func__));
-
-	if (pBeamInfo->beamformee_su_cnt == 0)
-		return;
-
-	Beamforming_DymPeriod(pDM_Odm,0);
-	phydm_Beamforming_DymNDPARate(pDM_Odm);
-
-}
-
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#if WPP_SOFTWARE_TRACE
+		#include "phydm_beamforming.tmh"
+	#endif
+#endif
+
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+phydm_get_txbf_device_num(
+	void	*dm_void,
+	u8	macid
+)
+{
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*For BDC*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = dm->phydm_sta_info[macid];
+	struct bf_cmn_info		*bf = NULL;
+	struct _BF_DIV_COEX_		*dm_bdc_table = &dm->dm_bdc_table;
+	u8	act_as_bfer = 0;
+	u8	act_as_bfee = 0;
+	
+	if (is_sta_active(sta)) {
+		bf = &(sta->bf_info);
+	} else {
+		PHYDM_DBG(dm, DBG_TXBF, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+
+	 if (sta->support_wireless_set & WIRELESS_VHT) {
+		if (bf->vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMEE_ENABLE)
+			act_as_bfer = 1;
+
+		if (bf->vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMER_ENABLE)
+			act_as_bfee = 1;
+		
+	} else if (sta->support_wireless_set & WIRELESS_HT) {
+		if (bf->ht_beamform_cap & BEAMFORMING_HT_BEAMFORMEE_ENABLE)
+			act_as_bfer = 1;
+
+		if (bf->ht_beamform_cap & BEAMFORMING_HT_BEAMFORMER_ENABLE)
+			act_as_bfee = 1;
+
+	}
+
+	if (act_as_bfer)) { /* Our Device act as BFer */
+		dm_bdc_table->w_bfee_client[macid] = true; 
+		dm_bdc_table->num_txbfee_client++;
+	} else
+		dm_bdc_table->w_bfee_client[macid] = false; 
+	
+	if (act_as_bfee)) { /* Our Device act as BFee */
+		dm_bdc_table->w_bfer_client[macid] = true; 
+		dm_bdc_table->num_txbfer_client++;
+	} else
+		dm_bdc_table->w_bfer_client[macid] = false; 
+
+#endif
+#endif
+}
+
+struct _RT_BEAMFORM_STAINFO *
+phydm_sta_info_init(
+	struct dm_struct		*dm,
+	u16			sta_idx
+)
+{
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORM_STAINFO		*entry = &beam_info->beamform_sta_info;
+	struct sta_info					*sta = dm->odm_sta_info[sta_idx];
+	struct cmn_sta_info				*cmn_sta = dm->phydm_sta_info[sta_idx];
+	//void					*adapter = dm->adapter;
+	PADAPTER				adapter = (PADAPTER)dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PMGNT_INFO					p_MgntInfo = &((adapter)->MgntInfo);
+	PRT_HIGH_THROUGHPUT		p_ht_info = GET_HT_INFO(p_MgntInfo);
+	PRT_VERY_HIGH_THROUGHPUT	p_vht_info = GET_VHT_INFO(p_MgntInfo);
+#endif
+
+	if (!is_sta_active(cmn_sta)) {
+		
+		PHYDM_DBG(dm, DBG_TXBF, "%s => sta_info(mac_id:%d) failed\n", __func__, sta_idx);
+		#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		rtw_warn_on(1);
+		#endif
+		
+		return entry;
+	}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
+	odm_move_memory(dm, (PVOID)(entry->my_mac_addr), (PVOID)(adapter->CurrentAddress), 6);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	odm_move_memory(dm, entry->my_mac_addr, adapter_mac_addr(sta->padapter), 6);
+#endif
+
+	entry->aid = cmn_sta->aid;
+	entry->ra = cmn_sta->mac_addr;
+	entry->mac_id = cmn_sta->mac_id;
+	entry->bw = cmn_sta->bw_mode;
+	entry->cur_beamform = cmn_sta->bf_info.ht_beamform_cap;
+	entry->ht_beamform_cap = cmn_sta->bf_info.ht_beamform_cap;
+	
+#if	ODM_IC_11AC_SERIES_SUPPORT
+	if (cmn_sta->support_wireless_set & WIRELESS_VHT) {
+		entry->cur_beamform_vht = cmn_sta->bf_info.vht_beamform_cap;
+		entry->vht_beamform_cap = cmn_sta->bf_info.vht_beamform_cap;
+	}
+#endif
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) /*To Be Removed */	
+	entry->ht_beamform_cap = p_ht_info->HtBeamformCap;		/*To Be Removed*/
+	entry->vht_beamform_cap = p_vht_info->VhtBeamformCap;	/*To Be Removed*/
+	
+	if (sta_idx == 0) { /*client mode*/
+		#if	ODM_IC_11AC_SERIES_SUPPORT
+		if (cmn_sta->support_wireless_set & WIRELESS_VHT)
+			entry->cur_beamform_vht = p_vht_info->VhtCurBeamform;
+		#endif
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_TXBF, "wireless_set = 0x%x, staidx = %d\n", cmn_sta->support_wireless_set, sta_idx);
+	PHYDM_DBG(dm, DBG_TXBF, "entry->cur_beamform = 0x%x, entry->cur_beamform_vht = 0x%x\n", entry->cur_beamform, entry->cur_beamform_vht);
+	return entry;
+
+}
+void phydm_sta_info_update(
+	struct dm_struct			*dm,
+	u16				sta_idx,
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry
+)
+{
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+
+	if (!is_sta_active(sta))
+		return;
+
+	sta->bf_info.p_aid = beamform_entry->p_aid;
+	sta->bf_info.g_id = beamform_entry->g_id;
+}
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_bfee_entry_by_addr(
+	void		*dm_void,
+	u8		*RA,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used && (eq_mac_addr(RA, beam_info->beamformee_entry[i].mac_addr))) {
+			*idx = i;
+			return &beam_info->beamformee_entry[i];
+		}
+	}
+
+	return NULL;
+}
+
+struct _RT_BEAMFORMER_ENTRY *
+phydm_beamforming_get_bfer_entry_by_addr(
+	void	*dm_void,
+	u8	*TA,
+	u8	*idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		i = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
+		if (beam_info->beamformer_entry[i].is_used && (eq_mac_addr(TA, beam_info->beamformer_entry[i].mac_addr))) {
+			*idx = i;
+			return &beam_info->beamformer_entry[i];
+		}
+	}
+
+	return NULL;
+}
+
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_entry_by_mac_id(
+	void		*dm_void,
+	u8		mac_id,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used && (mac_id == beam_info->beamformee_entry[i].mac_id)) {
+			*idx = i;
+			return &beam_info->beamformee_entry[i];
+		}
+	}
+
+	return NULL;
+}
+
+
+enum beamforming_cap
+phydm_beamforming_get_entry_beam_cap_by_mac_id(
+	void		*dm_void,
+	u8		mac_id
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	enum beamforming_cap			beamform_entry_cap = BEAMFORMING_CAP_NONE;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used && (mac_id == beam_info->beamformee_entry[i].mac_id)) {
+			beamform_entry_cap =  beam_info->beamformee_entry[i].beamform_entry_cap;
+			i = BEAMFORMEE_ENTRY_NUM;
+		}
+	}
+
+	return beamform_entry_cap;
+}
+
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_free_bfee_entry(
+	void		*dm_void,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		if (beam_info->beamformee_entry[i].is_used == false) {
+			*idx = i;
+			return &beam_info->beamformee_entry[i];
+		}
+	}
+	return NULL;
+}
+
+struct _RT_BEAMFORMER_ENTRY *
+phydm_beamforming_get_free_bfer_entry(
+	void		*dm_void,
+	u8		*idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8	i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s ===>\n", __func__);
+
+	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
+		if (beam_info->beamformer_entry[i].is_used == false) {
+			*idx = i;
+			return &beam_info->beamformer_entry[i];
+		}
+	}
+	return NULL;
+}
+
+/*
+ * Description: Get the first entry index of MU Beamformee.
+ *
+ * Return value: index of the first MU sta.
+ *
+ * 2015.05.25. Created by tynli.
+ *
+ */
+u8
+phydm_beamforming_get_first_mu_bfee_entry_idx(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u8					idx = 0xFF;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	boolean					is_found = false;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].is_mu_sta) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] idx=%d!\n", __func__, idx);
+			is_found = true;
+			break;
+		}
+	}
+
+	if (!is_found)
+		idx = 0xFF;
+
+	return idx;
+}
+
+
+/*Add SU BFee and MU BFee*/
+struct _RT_BEAMFORMEE_ENTRY *
+beamforming_add_bfee_entry(
+	void					*dm_void,
+	struct _RT_BEAMFORM_STAINFO	*sta,
+	enum beamforming_cap		beamform_cap,
+	u8					num_of_sounding_dim,
+	u8					comp_steering_num_of_bfer,
+	u8					*idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY	*entry = phydm_beamforming_get_free_bfee_entry(dm, idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (entry != NULL) {
+		entry->is_used = true;
+		entry->aid = sta->aid;
+		entry->mac_id = sta->mac_id;
+		entry->sound_bw = sta->bw;
+		odm_move_memory(dm, entry->my_mac_addr, sta->my_mac_addr, 6);
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) {
+			/*BSSID[44:47] xor BSSID[40:43]*/
+			u16 bssid = ((sta->my_mac_addr[5] & 0xf0) >> 4) ^ (sta->my_mac_addr[5] & 0xf);
+			/*(dec(A) + dec(B)*32) mod 512*/
+			entry->p_aid = (sta->aid + bssid * 32) & 0x1ff;
+			entry->g_id = 63;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: BFee P_AID addressed to STA=%d\n", __func__, entry->p_aid);
+		} else if (phydm_acting_determine(dm, phydm_acting_as_ibss)) {
+			/*ad hoc mode*/
+			entry->p_aid = 0;
+			entry->g_id = 63;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: BFee P_AID as IBSS=%d\n", __func__, entry->p_aid);
+		} else {
+			/*client mode*/
+			entry->p_aid =  sta->ra[5];
+			/*BSSID[39:47]*/
+			entry->p_aid = (entry->p_aid << 1) | (sta->ra[4] >> 7);
+			entry->g_id = 0;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: BFee P_AID addressed to AP=0x%X\n", __func__, entry->p_aid);
+		}
+		cp_mac_addr(entry->mac_addr, sta->ra);
+		entry->is_txbf = false;
+		entry->is_sound = false;
+		entry->sound_period = 400;
+		entry->beamform_entry_cap = beamform_cap;
+		entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+
+		/*		entry->log_seq = 0xff;				Move to beamforming_add_bfer_entry*/
+		/*		entry->log_retry_cnt = 0;			Move to beamforming_add_bfer_entry*/
+		/*		entry->LogSuccessCnt = 0;		Move to beamforming_add_bfer_entry*/
+
+		entry->log_status_fail_cnt = 0;
+
+		entry->num_of_sounding_dim = num_of_sounding_dim;
+		entry->comp_steering_num_of_bfer = comp_steering_num_of_bfer;
+
+		if (beamform_cap & BEAMFORMER_CAP_VHT_MU) {
+			dm->beamforming_info.beamformee_mu_cnt += 1;
+			entry->is_mu_sta = true;
+			dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(dm);
+		} else if (beamform_cap & (BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP_HT_EXPLICIT)) {
+			dm->beamforming_info.beamformee_su_cnt += 1;
+			entry->is_mu_sta = false;
+		}
+
+		return entry;
+	} else
+		return NULL;
+}
+
+/*Add SU BFee and MU BFer*/
+struct _RT_BEAMFORMER_ENTRY *
+beamforming_add_bfer_entry(
+	void					*dm_void,
+	struct _RT_BEAMFORM_STAINFO	*sta,
+	enum beamforming_cap		beamform_cap,
+	u8					num_of_sounding_dim,
+	u8					*idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMER_ENTRY	*entry = phydm_beamforming_get_free_bfer_entry(dm, idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (entry != NULL) {
+		entry->is_used = true;
+		odm_move_memory(dm, entry->my_mac_addr, sta->my_mac_addr, 6);
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) {
+			/*BSSID[44:47] xor BSSID[40:43]*/
+			u16 bssid = ((sta->my_mac_addr[5] & 0xf0) >> 4) ^ (sta->my_mac_addr[5] & 0xf);
+
+			entry->p_aid = (sta->aid + bssid * 32) & 0x1ff;
+			entry->g_id = 63;
+			/*(dec(A) + dec(B)*32) mod 512*/
+		} else if (phydm_acting_determine(dm, phydm_acting_as_ibss)) {
+			entry->p_aid = 0;
+			entry->g_id = 63;
+		} else {
+			entry->p_aid =  sta->ra[5];
+			/*BSSID[39:47]*/
+			entry->p_aid = (entry->p_aid << 1) | (sta->ra[4] >> 7);
+			entry->g_id = 0;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: P_AID addressed to AP=0x%X\n", __func__, entry->p_aid);
+		}
+
+		cp_mac_addr(entry->mac_addr, sta->ra);
+		entry->beamform_entry_cap = beamform_cap;
+
+		entry->pre_log_seq = 0;	/*Modified by Jeffery @2015-04-13*/
+		entry->log_seq = 0;		/*Modified by Jeffery @2014-10-29*/
+		entry->log_retry_cnt = 0;	/*Modified by Jeffery @2014-10-29*/
+		entry->log_success = 0;	/*log_success is NOT needed to be accumulated, so  LogSuccessCnt->log_success, 2015-04-13, Jeffery*/
+		entry->clock_reset_times = 0;	/*Modified by Jeffery @2015-04-13*/
+
+		entry->num_of_sounding_dim = num_of_sounding_dim;
+
+		if (beamform_cap & BEAMFORMEE_CAP_VHT_MU) {
+			dm->beamforming_info.beamformer_mu_cnt += 1;
+			entry->is_mu_ap = true;
+			entry->aid = sta->aid;
+		} else if (beamform_cap & (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP_HT_EXPLICIT)) {
+			dm->beamforming_info.beamformer_su_cnt += 1;
+			entry->is_mu_ap = false;
+		}
+
+		return entry;
+	} else
+		return NULL;
+}
+
+#if 0
+boolean
+beamforming_remove_entry(
+	void			*adapter,
+	u8		*RA,
+	u8		*idx
+)
+{
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct				*dm = &hal_data->DM_OutSrc;
+
+	struct _RT_BEAMFORMER_ENTRY	*bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, RA, idx);
+	struct _RT_BEAMFORMEE_ENTRY	*entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, idx);
+	boolean ret = false;
+
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s Start!\n", __func__));
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, bfer_entry=0x%x\n", __func__, bfer_entry));
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, entry=0x%x\n", __func__, entry));
+
+	if (entry != NULL) {
+		entry->is_used = false;
+		entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		/*entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;*/
+		entry->is_beamforming_in_progress = false;
+		ret = true;
+	}
+	if (bfer_entry != NULL) {
+		bfer_entry->is_used = false;
+		bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		ret = true;
+	}
+	return ret;
+
+}
+#endif
+
+/* Used for beamforming_start_v1 */
+void
+phydm_beamforming_ndpa_rate(
+	void		*dm_void,
+	enum channel_width	BW,
+	u8			rate
+)
+{
+	u16			ndpa_rate = rate;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (ndpa_rate == 0) {
+		if (dm->rssi_min > 30) /* link RSSI > 30% */
+			ndpa_rate = ODM_RATE24M;
+		else
+			ndpa_rate = ODM_RATE6M;
+	}
+
+	if (ndpa_rate < ODM_RATEMCS0)
+		BW = (enum channel_width)CHANNEL_WIDTH_20;
+
+	ndpa_rate = (ndpa_rate << 8) | BW;
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
+
+}
+
+
+/* Used for beamforming_start_sw and  beamforming_start_fw */
+void
+phydm_beamforming_dym_ndpa_rate(
+	void		*dm_void
+)
+{
+	u16			ndpa_rate = ODM_RATE6M, BW;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	ndpa_rate = ODM_RATE6M;
+	BW = CHANNEL_WIDTH_20;
+
+	ndpa_rate = ndpa_rate << 8 | BW;
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, NDPA rate = 0x%X\n", __func__, ndpa_rate);
+}
+
+/*
+*	SW Sounding : SW Timer unit 1ms
+*				 HW Timer unit (1/32000) s  32k is clock.
+*	FW Sounding : FW Timer unit 10ms
+*/
+void
+beamforming_dym_period(
+	void		*dm_void,
+	u8          status
+)
+{
+	u8					idx;
+	boolean					is_change_period = false;
+	u16					sound_period_sw, sound_period_fw;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO		*sound_info = &beam_info->sounding_info;
+
+	struct _RT_BEAMFORMEE_ENTRY	*entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	/* 3 TODO  per-client throughput caculation. */
+
+	if ((*dm->current_tx_tp + *dm->current_rx_tp > 2) && ((entry->log_status_fail_cnt <= 20) || status)) {
+		sound_period_sw = 40;	/* 40ms */
+		sound_period_fw = 40;	/* From  H2C cmd, unit = 10ms */
+	} else {
+		sound_period_sw = 4000;/* 4s */
+		sound_period_fw = 400;
+	}
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]sound_period_sw=%d, sound_period_fw=%d\n",	__func__, sound_period_sw, sound_period_fw);
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		beamform_entry = beam_info->beamformee_entry + idx;
+
+		if (beamform_entry->default_csi_cnt > 20) {
+			/*Modified by David*/
+			sound_period_sw = 4000;
+			sound_period_fw = 400;
+		}
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] period = %d\n", __func__, sound_period_sw);
+		if ((beamform_entry->beamform_entry_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) == 0)
+			continue;
+
+		if (sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || sound_info->sound_mode == SOUNDING_FW_HT_TIMER) {
+			if (beamform_entry->sound_period != sound_period_fw) {
+				beamform_entry->sound_period = sound_period_fw;
+				is_change_period = true;		/*Only FW sounding need to send H2C packet to change sound period. */
+			}
+		} else if (beamform_entry->sound_period != sound_period_sw)
+			beamform_entry->sound_period = sound_period_sw;
+	}
+
+	if (is_change_period)
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+}
+
+
+
+
+boolean
+beamforming_send_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW,
+	u8			q_idx
+)
+{
+	boolean		ret = true;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (q_idx == BEACON_QUEUE)
+		ret = send_fw_ht_ndpa_packet(dm, RA, BW);
+	else
+		ret = send_sw_ht_ndpa_packet(dm, RA, BW);
+
+	return ret;
+}
+
+
+
+boolean
+beamforming_send_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW,
+	u8			q_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	boolean					ret = true;
+
+	hal_com_txbf_set(dm, TXBF_SET_GET_TX_RATE, NULL);
+
+	if ((beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7) && (beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9) && (!beam_info->snding3ss))
+		PHYDM_DBG(dm, DBG_TXBF, "@%s: 3SS VHT 789 don't sounding\n", __func__);
+
+	else  {
+		if (q_idx == BEACON_QUEUE) /* Send to reserved page => FW NDPA */
+			ret = send_fw_vht_ndpa_packet(dm, RA, AID, BW);
+		else {
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+			beam_info->is_mu_sounding = true;
+			ret = send_sw_vht_mu_ndpa_packet(dm, BW);
+#else
+			beam_info->is_mu_sounding = false;
+			ret = send_sw_vht_ndpa_packet(dm, RA, AID, BW);
+#endif
+#else
+			beam_info->is_mu_sounding = false;
+			ret = send_sw_vht_ndpa_packet(dm, RA, AID, BW);
+#endif
+		}
+	}
+	return ret;
+}
+
+
+enum beamforming_notify_state
+phydm_beamfomring_is_sounding(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	u8					*idx
+)
+{
+	enum beamforming_notify_state	is_sounding = BEAMFORMING_NOTIFY_NONE;
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8 i;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	/*if(( Beamforming_GetBeamCap(beam_info) & BEAMFORMER_CAP) == 0)*/
+	/*is_sounding = BEAMFORMING_NOTIFY_RESET;*/
+	if (beam_oid_info.sound_oid_mode == sounding_stop_all_timer) {
+		is_sounding = BEAMFORMING_NOTIFY_RESET;
+		goto out;
+	}
+
+		for (i = 0 ; i < BEAMFORMEE_ENTRY_NUM ; i++) {
+			PHYDM_DBG(dm, DBG_TXBF, "@%s: BFee Entry %d is_used=%d, is_sound=%d\n", __func__, i, beam_info->beamformee_entry[i].is_used, beam_info->beamformee_entry[i].is_sound);
+			if (beam_info->beamformee_entry[i].is_used && (!beam_info->beamformee_entry[i].is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF, "%s: Add BFee entry %d\n", __func__, i);
+				*idx = i;
+				if (beam_info->beamformee_entry[i].is_mu_sta)
+					is_sounding = BEAMFORMEE_NOTIFY_ADD_MU;
+				else
+					is_sounding = BEAMFORMEE_NOTIFY_ADD_SU;
+			}
+
+			if ((!beam_info->beamformee_entry[i].is_used) && beam_info->beamformee_entry[i].is_sound) {
+				PHYDM_DBG(dm, DBG_TXBF, "%s: Delete BFee entry %d\n", __func__, i);
+				*idx = i;
+				if (beam_info->beamformee_entry[i].is_mu_sta)
+					is_sounding = BEAMFORMEE_NOTIFY_DELETE_MU;
+				else
+					is_sounding = BEAMFORMEE_NOTIFY_DELETE_SU;
+			}
+		}
+
+out:
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, is_sounding = %d\n", __func__, is_sounding);
+	return is_sounding;
+}
+
+
+/* This function is unused */
+u8
+phydm_beamforming_sounding_idx(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO		*beam_info
+)
+{
+	u8					idx = 0;
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (beam_oid_info.sound_oid_mode == SOUNDING_SW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_SW_VHT_TIMER ||
+	    beam_oid_info.sound_oid_mode == SOUNDING_HW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_VHT_TIMER)
+		idx = beam_oid_info.sound_oid_idx;
+	else {
+		u8	i;
+		for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+			if (beam_info->beamformee_entry[i].is_used && (!beam_info->beamformee_entry[i].is_sound)) {
+				idx = i;
+				break;
+			}
+		}
+	}
+
+	return idx;
+}
+
+
+enum sounding_mode
+phydm_beamforming_sounding_mode(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	u8					idx
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			support_interface = dm->support_interface;
+
+	struct _RT_BEAMFORMEE_ENTRY		beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	enum sounding_mode				mode = beam_oid_info.sound_oid_mode;
+
+	if (beam_oid_info.sound_oid_mode == SOUNDING_SW_VHT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_VHT_TIMER) {
+		if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			mode = beam_oid_info.sound_oid_mode;
+		else
+			mode = sounding_stop_all_timer;
+	} else if (beam_oid_info.sound_oid_mode == SOUNDING_SW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_HT_TIMER) {
+		if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+			mode = beam_oid_info.sound_oid_mode;
+		else
+			mode = sounding_stop_all_timer;
+	} else if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_VHT_SU) {
+		if ((support_interface == ODM_ITRF_USB) && !(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
+			mode = SOUNDING_FW_VHT_TIMER;
+		else
+			mode = SOUNDING_SW_VHT_TIMER;
+	} else if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT) {
+		if ((support_interface == ODM_ITRF_USB) && !(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
+			mode = SOUNDING_FW_HT_TIMER;
+		else
+			mode = SOUNDING_SW_HT_TIMER;
+	} else
+		mode = sounding_stop_all_timer;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] support_interface=%d, mode=%d\n", __func__, support_interface, mode);
+
+	return mode;
+}
+
+
+u16
+phydm_beamforming_sounding_time(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	enum sounding_mode			mode,
+	u8					idx
+)
+{
+	u16						sounding_time = 0xffff;
+	struct _RT_BEAMFORMEE_ENTRY		beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_HW_VHT_TIMER)
+		sounding_time = beam_oid_info.sound_oid_period * 32;
+	else if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_SW_VHT_TIMER)
+		/*Modified by David*/
+		sounding_time = beam_entry.sound_period;	/*beam_oid_info.sound_oid_period;*/
+	else
+		sounding_time = beam_entry.sound_period;
+
+	return sounding_time;
+}
+
+
+enum channel_width
+phydm_beamforming_sounding_bw(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info,
+	enum sounding_mode			mode,
+	u8					idx
+)
+{
+	enum channel_width				sounding_bw = CHANNEL_WIDTH_20;
+	struct _RT_BEAMFORMEE_ENTRY		beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	if (mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_HW_VHT_TIMER)
+		sounding_bw = beam_oid_info.sound_oid_bw;
+	else if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_SW_VHT_TIMER)
+		/*Modified by David*/
+		sounding_bw = beam_entry.sound_bw;		/*beam_oid_info.sound_oid_bw;*/
+	else
+		sounding_bw = beam_entry.sound_bw;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s, sounding_bw=0x%X\n", __func__, sounding_bw);
+
+	return sounding_bw;
+}
+
+
+boolean
+phydm_beamforming_select_beam_entry(
+	void				*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	struct _RT_SOUNDING_INFO		*sound_info = &beam_info->sounding_info;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+
+	/*entry.is_sound is different between first and latter NDPA, and should not be used as BFee entry selection*/
+	/*BTW, latter modification should sync to the selection mechanism of AP/ADSL instead of the fixed sound_idx.*/
+	sound_info->sound_idx = phydm_beamforming_sounding_idx(dm, beam_info);
+	/*sound_info->sound_idx = 0;*/
+
+	if (sound_info->sound_idx < BEAMFORMEE_ENTRY_NUM)
+		sound_info->sound_mode = phydm_beamforming_sounding_mode(dm, beam_info, sound_info->sound_idx);
+	else
+		sound_info->sound_mode = sounding_stop_all_timer;
+
+	if (sounding_stop_all_timer == sound_info->sound_mode) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] Return because of sounding_stop_all_timer\n", __func__);
+		return false;
+	} else {
+		sound_info->sound_bw = phydm_beamforming_sounding_bw(dm, beam_info, sound_info->sound_mode, sound_info->sound_idx);
+		sound_info->sound_period = phydm_beamforming_sounding_time(dm, beam_info, sound_info->sound_mode, sound_info->sound_idx);
+		return true;
+	}
+}
+
+/*SU BFee Entry Only*/
+boolean
+phydm_beamforming_start_period(
+	void				*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	boolean						ret = true;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO			*sound_info = &beam_info->sounding_info;
+
+	phydm_beamforming_dym_ndpa_rate(dm);
+
+	phydm_beamforming_select_beam_entry(dm, beam_info);		/* Modified */
+
+	if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+		odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);
+	else if (sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
+		sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER) {
+		HAL_HW_TIMER_TYPE timer_type = HAL_TIMER_TXBF;
+		u32	val = (sound_info->sound_period | (timer_type << 16));
+
+		/* HW timer stop: All IC has the same setting */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
+		/* odm_write_1byte(dm, 0x15F, 0); */
+		/* HW timer init: All IC has the same setting, but 92E & 8812A only write 2 bytes */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_INIT, (u8 *)(&val));
+		/* odm_write_1byte(dm, 0x164, 1); */
+		/* odm_write_4byte(dm, 0x15C, val); */
+		/* HW timer start: All IC has the same setting */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_START, (u8 *)(&timer_type));
+		/* odm_write_1byte(dm, 0x15F, 0x5); */
+	} else if (sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || sound_info->sound_mode == SOUNDING_FW_HT_TIMER)
+		ret = beamforming_start_fw(dm, sound_info->sound_idx);
+	else
+		ret = false;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] sound_idx=%d, sound_mode=%d, sound_bw=%d, sound_period=%d\n", __func__,
+		sound_info->sound_idx, sound_info->sound_mode, sound_info->sound_bw, sound_info->sound_period);
+
+	return ret;
+}
+
+/* Used after beamforming_leave, and will clear the setting of the "already deleted" entry
+ *SU BFee Entry Only*/
+void
+phydm_beamforming_end_period_sw(
+	void				*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	/*void					*adapter = dm->adapter;*/
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO			*sound_info = &beam_info->sounding_info;
+
+	HAL_HW_TIMER_TYPE timer_type = HAL_TIMER_TXBF;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+		odm_cancel_timer(dm, &beam_info->beamforming_timer);
+	else if (sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
+		sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER)
+		/*HW timer stop: All IC has the same setting*/
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
+	/*odm_write_1byte(dm, 0x15F, 0);*/
+}
+
+void
+phydm_beamforming_end_period_fw(
+	void				*dm_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	u8				idx = 0;
+
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]\n", __func__);
+}
+
+
+/*SU BFee Entry Only*/
+void
+phydm_beamforming_clear_entry_sw(
+	void			*dm_void,
+	boolean				is_delete,
+	u8				delete_idx
+)
+{
+	u8						idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+
+	if (is_delete) {
+		if (delete_idx < BEAMFORMEE_ENTRY_NUM) {
+			beamform_entry = beam_info->beamformee_entry + delete_idx;
+			if (!((!beamform_entry->is_used) && beamform_entry->is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF, "[%s] SW delete_idx is wrong!!!!!\n", __func__);
+				return;
+			}
+		}
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] SW delete BFee entry %d\n", __func__, delete_idx);
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING) {
+			beamform_entry->is_beamforming_in_progress = false;
+			beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		} else if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			beamform_entry->beamform_entry_state  = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&delete_idx);
+		}
+		beamform_entry->is_sound = false;
+		return;
+	}
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		beamform_entry = beam_info->beamformee_entry + idx;
+
+		/*Used after is_sounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
+		/*This function is mainly used in case "beam_oid_info.sound_oid_mode == sounding_stop_all_timer".*/
+		/*However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
+
+		if (!beamform_entry->is_sound)
+			continue;
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] SW reset BFee entry %d\n", __func__, idx);
+		/*
+		*	If End procedure is
+		*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
+		*	After C2H packet return , status bit will be set to zero.
+		*
+		*	2. After C2H packet, then reset state to initialized and clear status bit.
+		*/
+
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+			phydm_beamforming_end_sw(dm, 0);
+		else if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			beamform_entry->beamform_entry_state  = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
+		}
+
+		beamform_entry->is_sound = false;
+	}
+}
+
+void
+phydm_beamforming_clear_entry_fw(
+	void			*dm_void,
+	boolean				is_delete,
+	u8				delete_idx
+)
+{
+	u8						idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+
+	if (is_delete) {
+		if (delete_idx < BEAMFORMEE_ENTRY_NUM) {
+			beamform_entry = beam_info->beamformee_entry + delete_idx;
+
+			if (!((!beamform_entry->is_used) && beamform_entry->is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF, "[%s] FW delete_idx is wrong!!!!!\n", __func__);
+				return;
+			}
+		}
+		PHYDM_DBG(dm, DBG_TXBF, "%s: FW delete BFee entry %d\n", __func__, delete_idx);
+		beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		beamform_entry->is_sound = false;
+	} else {
+		for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+			beamform_entry = beam_info->beamformee_entry + idx;
+
+			/*Used after is_sounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
+			/*This function is mainly used in case "beam_oid_info.sound_oid_mode == sounding_stop_all_timer".*/
+			/*However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
+
+			if (beamform_entry->is_sound) {
+				PHYDM_DBG(dm, DBG_TXBF, "[%s]FW reset BFee entry %d\n", __func__, idx);
+				/*
+				*	If End procedure is
+				*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
+				*	After C2H packet return , status bit will be set to zero.
+				*
+				*	2. After C2H packet, then reset state to initialized and clear status bit.
+				*/
+
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+				beamform_entry->is_sound = false;
+			}
+		}
+	}
+}
+
+/*
+*	Called :
+*	1. Add and delete entry : beamforming_enter/beamforming_leave
+*	2. FW trigger :  Beamforming_SetTxBFen
+*	3. Set OID_RT_BEAMFORMING_PERIOD : beamforming_control_v2
+*/
+void
+phydm_beamforming_notify(
+	void			*dm_void
+)
+{
+	u8						idx = BEAMFORMEE_ENTRY_NUM;
+	enum beamforming_notify_state	is_sounding = BEAMFORMING_NOTIFY_NONE;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO			*sound_info = &beam_info->sounding_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	is_sounding = phydm_beamfomring_is_sounding(dm, beam_info, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s, Before notify, is_sounding=%d, idx=%d\n", __func__, is_sounding, idx);
+	PHYDM_DBG(dm, DBG_TXBF, "%s: beam_info->beamformee_su_cnt = %d\n", __func__, beam_info->beamformee_su_cnt);
+
+
+	switch (is_sounding) {
+	case BEAMFORMEE_NOTIFY_ADD_SU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_ADD_SU\n", __func__);
+		phydm_beamforming_start_period(dm);
+		break;
+
+	case BEAMFORMEE_NOTIFY_DELETE_SU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_DELETE_SU\n", __func__);
+		if (sound_info->sound_mode == SOUNDING_FW_HT_TIMER || sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
+			phydm_beamforming_clear_entry_fw(dm, true, idx);
+			if (beam_info->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
+				phydm_beamforming_end_period_fw(dm);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: No BFee left\n", __func__);
+			}
+		} else {
+			phydm_beamforming_clear_entry_sw(dm, true, idx);
+			if (beam_info->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
+				phydm_beamforming_end_period_sw(dm);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: No BFee left\n", __func__);
+			}
+		}
+		break;
+
+	case BEAMFORMEE_NOTIFY_ADD_MU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_ADD_MU\n", __func__);
+		if (beam_info->beamformee_mu_cnt == 2) {
+			/*if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+				odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);*/
+			odm_set_timer(dm, &beam_info->beamforming_timer, 1000); /*Do MU sounding every 1sec*/
+		} else
+			PHYDM_DBG(dm, DBG_TXBF, "%s: Less or larger than 2 MU STAs, not to set timer\n", __func__);
+		break;
+
+	case BEAMFORMEE_NOTIFY_DELETE_MU:
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_DELETE_MU\n", __func__);
+		if (beam_info->beamformee_mu_cnt == 1) {
+			/*if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)*/{
+				odm_cancel_timer(dm, &beam_info->beamforming_timer);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: Less than 2 MU STAs, stop sounding\n", __func__);
+			}
+		}
+		break;
+
+	case BEAMFORMING_NOTIFY_RESET:
+		if (sound_info->sound_mode == SOUNDING_FW_HT_TIMER || sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
+			phydm_beamforming_clear_entry_fw(dm, false, idx);
+			phydm_beamforming_end_period_fw(dm);
+		} else {
+			phydm_beamforming_clear_entry_sw(dm, false, idx);
+			phydm_beamforming_end_period_sw(dm);
+		}
+
+		break;
+
+	default:
+		break;
+	}
+
+}
+
+
+
+boolean
+beamforming_init_entry(
+	void		*dm_void,
+	u16		sta_idx,
+	u8			*bfer_bfee_idx
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info				*cmn_sta = dm->phydm_sta_info[sta_idx];
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	struct _RT_BEAMFORMER_ENTRY		*beamformer_entry = NULL;
+	struct _RT_BEAMFORM_STAINFO		*sta = NULL;
+	enum beamforming_cap			beamform_cap = BEAMFORMING_CAP_NONE;
+	u8						bfer_idx = 0xF, bfee_idx = 0xF;
+	u8						num_of_sounding_dim = 0, comp_steering_num_of_bfer = 0;
+
+	if (!is_sta_active(cmn_sta)) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s => sta_info(mac_id:%d) failed\n",
+			  __func__, sta_idx);
+		#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		rtw_warn_on(1);
+		#endif
+		return false;
+	}
+
+	sta = phydm_sta_info_init(dm, sta_idx);
+
+	/*The current setting does not support Beaforming*/
+	if (BEAMFORMING_CAP_NONE == sta->ht_beamform_cap && BEAMFORMING_CAP_NONE == sta->vht_beamform_cap) {
+		PHYDM_DBG(dm, DBG_TXBF, "The configuration disabled Beamforming! Skip...\n");
+		return false;
+	}
+
+	if (!(cmn_sta->support_wireless_set & (WIRELESS_VHT | WIRELESS_HT)))
+		return false;
+	else {
+		if (cmn_sta->support_wireless_set & WIRELESS_HT) {/*HT*/
+			if (TEST_FLAG(sta->cur_beamform, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {/*We are Beamformee because the STA is Beamformer*/
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_HT_EXPLICIT);
+			num_of_sounding_dim = (sta->cur_beamform & BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP) >> 6;
+			}
+			/*We are Beamformer because the STA is Beamformee*/
+			if (TEST_FLAG(sta->cur_beamform, BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
+				TEST_FLAG(sta->ht_beamform_cap, BEAMFORMING_HT_BEAMFORMER_TEST)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_HT_EXPLICIT);
+			comp_steering_num_of_bfer = (sta->cur_beamform & BEAMFORMING_HT_BEAMFORMER_STEER_NUM) >> 4;
+			}
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] HT cur_beamform=0x%X, beamform_cap=0x%X\n", __func__, sta->cur_beamform, beamform_cap);
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] HT num_of_sounding_dim=%d, comp_steering_num_of_bfer=%d\n", __func__, num_of_sounding_dim, comp_steering_num_of_bfer);
+		}
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+		if (cmn_sta->support_wireless_set & WIRELESS_VHT) {	/*VHT*/
+
+		/* We are Beamformee because the STA is SU Beamformer*/
+		if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_VHT_SU);
+			num_of_sounding_dim = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
+		}
+		/* We are Beamformer because the STA is SU Beamformee*/
+		if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) ||
+				TEST_FLAG(sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_VHT_SU);
+			comp_steering_num_of_bfer = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
+		}
+		/* We are Beamformee because the STA is MU Beamformer*/
+		if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
+			beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_VHT_MU);
+			num_of_sounding_dim = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
+		}
+		/* We are Beamformer because the STA is MU Beamformee*/
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) { /* Only AP mode supports to act an MU beamformer */
+			if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE) ||
+					TEST_FLAG(sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
+				beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_VHT_MU);
+				comp_steering_num_of_bfer = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
+			}
+		}
+		PHYDM_DBG(dm, DBG_TXBF, "[%s]VHT cur_beamform_vht=0x%X, beamform_cap=0x%X\n", __func__, sta->cur_beamform_vht, beamform_cap);
+		PHYDM_DBG(dm, DBG_TXBF, "[%s]VHT num_of_sounding_dim=0x%X, comp_steering_num_of_bfer=0x%X\n", __func__, num_of_sounding_dim, comp_steering_num_of_bfer);
+
+		}
+#endif
+	}
+
+
+	if (beamform_cap == BEAMFORMING_CAP_NONE)
+		return false;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Self BF Entry Cap = 0x%02X\n", __func__, beamform_cap);
+
+	/*We are BFee, so the entry is BFer*/
+	if (beamform_cap & (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP_HT_EXPLICIT)) {
+		beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, sta->ra, &bfer_idx);
+
+		if (beamformer_entry == NULL) {
+			beamformer_entry = beamforming_add_bfer_entry(dm, sta, beamform_cap, num_of_sounding_dim, &bfer_idx);
+			if (beamformer_entry == NULL)
+				PHYDM_DBG(dm, DBG_TXBF, "[%s]Not enough BFer entry!!!!!\n", __func__);
+		}
+	}
+
+	/*We are BFer, so the entry is BFee*/
+	if (beamform_cap & (BEAMFORMER_CAP_VHT_MU | BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP_HT_EXPLICIT)) {
+		beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, sta->ra, &bfee_idx);
+
+		/*如果BFeeIdx = 0xF 則代表目前entry當中沒有相同的MACID在內*/
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] Get BFee entry 0x%X by address\n", __func__, bfee_idx);
+		if (beamform_entry == NULL) {
+			beamform_entry = beamforming_add_bfee_entry(dm, sta, beamform_cap, num_of_sounding_dim, comp_steering_num_of_bfer, &bfee_idx);
+			PHYDM_DBG(dm, DBG_TXBF, "[%s]: sta->AID=%d, sta->mac_id=%d\n", __func__, sta->aid, sta->mac_id);
+
+			PHYDM_DBG(dm, DBG_TXBF, "[%s]: Add BFee entry %d\n", __func__, bfee_idx);
+
+			if (beamform_entry == NULL)
+				return false;
+			else
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+		} else {
+			/*Entry has been created. If entry is initialing or progressing then errors occur.*/
+			if (beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED &&
+			    beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED)
+				return false;
+			else
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+		}
+		beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+		phydm_sta_info_update(dm, sta_idx, beamform_entry);
+	}
+
+	*bfer_bfee_idx = (bfer_idx << 4) | bfee_idx;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End: bfer_idx=0x%X, bfee_idx=0x%X, bfer_bfee_idx=0x%X\n", __func__, bfer_idx, bfee_idx, *bfer_bfee_idx);
+
+	return true;
+}
+
+
+void
+beamforming_deinit_entry(
+	void		*dm_void,
+	u8			*RA
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	u8				idx = 0;
+
+	struct _RT_BEAMFORMER_ENTRY	*bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, RA, &idx);
+	struct _RT_BEAMFORMEE_ENTRY	*bfee_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	boolean ret = false;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n",  __func__);
+
+	if (bfee_entry != NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, bfee_entry\n", __func__);
+		bfee_entry->is_used = false;
+		bfee_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		bfee_entry->is_beamforming_in_progress = false;
+		if (bfee_entry->is_mu_sta) {
+			dm->beamforming_info.beamformee_mu_cnt -= 1;
+			dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(dm);
+		} else
+			dm->beamforming_info.beamformee_su_cnt -= 1;
+		ret = true;
+	}
+
+	if (bfer_entry != NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, bfer_entry\n", __func__);
+		bfer_entry->is_used = false;
+		bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		if (bfer_entry->is_mu_ap)
+			dm->beamforming_info.beamformer_mu_cnt -= 1;
+		else
+			dm->beamforming_info.beamformer_su_cnt -= 1;
+		ret = true;
+	}
+
+	if (ret == true)
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_LEAVE, (u8 *)&idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, idx = 0x%X\n", __func__, idx);
+}
+
+
+boolean
+beamforming_start_v1(
+	void		*dm_void,
+	u8			*RA,
+	boolean			mode,
+	enum channel_width	BW,
+	u8			rate
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u8					idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	boolean					ret = true;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	if (entry->is_used == false) {
+		entry->is_beamforming_in_progress = false;
+		return false;
+	} else {
+		if (entry->is_beamforming_in_progress)
+			return false;
+
+		entry->is_beamforming_in_progress = true;
+
+		if (mode == 1) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
+				entry->is_beamforming_in_progress = false;
+				return false;
+			}
+		} else if (mode == 0) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
+				entry->is_beamforming_in_progress = false;
+				return false;
+			}
+		}
+
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			entry->is_beamforming_in_progress = false;
+			return false;
+		} else {
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+			entry->is_sound = true;
+		}
+	}
+
+	entry->sound_bw = BW;
+	beam_info->beamformee_cur_idx = idx;
+	phydm_beamforming_ndpa_rate(dm, BW, rate);
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
+
+	if (mode == 1)
+		ret = beamforming_send_ht_ndpa_packet(dm, RA, BW, NORMAL_QUEUE);
+	else
+		ret = beamforming_send_vht_ndpa_packet(dm, RA, entry->aid, BW, NORMAL_QUEUE);
+
+	if (ret == false) {
+		beamforming_leave(dm, RA);
+		entry->is_beamforming_in_progress = false;
+		return false;
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s  idx %d\n", __func__, idx);
+	return true;
+}
+
+
+boolean
+beamforming_start_sw(
+	void		*dm_void,
+	u8			idx,
+	u8			mode,
+	enum channel_width	BW
+)
+{
+	u8					*ra = NULL;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	boolean					ret = true;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+	u8				i, poll_sta_cnt = 0;
+	boolean				is_get_first_bfee = false;
+#endif
+#endif
+
+	if (beam_info->is_mu_sounding) {
+		beam_info->is_mu_sounding_in_progress = true;
+		entry = &beam_info->beamformee_entry[idx];
+		ra = entry->mac_addr;
+
+	} else {
+		entry = &beam_info->beamformee_entry[idx];
+
+		if (entry->is_used == false) {
+			PHYDM_DBG(dm, DBG_TXBF, "Skip Beamforming, no entry for idx =%d\n", idx);
+			entry->is_beamforming_in_progress = false;
+			return false;
+		}
+
+		if (entry->is_beamforming_in_progress) {
+			PHYDM_DBG(dm, DBG_TXBF, "is_beamforming_in_progress, skip...\n");
+			return false;
+		}
+
+		entry->is_beamforming_in_progress = true;
+		ra = entry->mac_addr;
+
+		if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_AUTO_HT_TIMER) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
+				entry->is_beamforming_in_progress = false;
+				PHYDM_DBG(dm, DBG_TXBF, "%s Return by not support BEAMFORMER_CAP_HT_EXPLICIT <==\n", __func__);
+				return false;
+			}
+		} else if (mode == SOUNDING_SW_VHT_TIMER || mode == SOUNDING_HW_VHT_TIMER || mode == SOUNDING_AUTO_VHT_TIMER) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
+				entry->is_beamforming_in_progress = false;
+				PHYDM_DBG(dm, DBG_TXBF, "%s Return by not support BEAMFORMER_CAP_VHT_SU <==\n", __func__);
+				return false;
+			}
+		}
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			entry->is_beamforming_in_progress = false;
+			PHYDM_DBG(dm, DBG_TXBF, "%s Return by incorrect beamform_entry_state(%d) <==\n", __func__, entry->beamform_entry_state);
+			return false;
+		} else {
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+			entry->is_sound = true;
+		}
+
+		beam_info->beamformee_cur_idx = idx;
+	}
+
+	/*2014.12.22 Luke: Need to be checked*/
+	/*GET_TXBF_INFO(adapter)->fTxbfSet(adapter, TXBF_SET_SOUNDING_STATUS, (u8*)&idx);*/
+
+	if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_AUTO_HT_TIMER)
+		ret = beamforming_send_ht_ndpa_packet(dm, ra, BW, NORMAL_QUEUE);
+	else
+		ret = beamforming_send_vht_ndpa_packet(dm, ra, entry->aid, BW, NORMAL_QUEUE);
+
+	if (ret == false) {
+		beamforming_leave(dm, ra);
+		entry->is_beamforming_in_progress = false;
+		return false;
+	}
+
+
+	/*--------------------------
+	 * Send BF Report Poll for MU BF
+	--------------------------*/
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+	if (beam_info->beamformee_mu_cnt <= 1)
+		goto out;
+
+	/* More than 1 MU STA*/
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		entry = &beam_info->beamformee_entry[i];
+		if (!entry->is_mu_sta)
+			continue;
+
+		if (!is_get_first_bfee) {
+			is_get_first_bfee = true;
+			continue;
+		}
+
+		poll_sta_cnt++;
+		if (poll_sta_cnt == (beam_info->beamformee_mu_cnt - 1))/* The last STA*/
+			send_sw_vht_bf_report_poll(dm, entry->mac_addr, true);
+		else
+			send_sw_vht_bf_report_poll(dm, entry->mac_addr, false);
+	}
+out:
+#endif
+#endif
+	return true;
+}
+
+
+boolean
+beamforming_start_fw(
+	void		*dm_void,
+	u8			idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	entry = &beam_info->beamformee_entry[idx];
+	if (entry->is_used == false) {
+		PHYDM_DBG(dm, DBG_TXBF, "Skip Beamforming, no entry for idx =%d\n", idx);
+		return false;
+	}
+
+	entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+	entry->is_sound = true;
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End, idx=0x%X\n", __func__, idx);
+	return true;
+}
+
+void
+beamforming_check_sounding_success(
+	void			*dm_void,
+	boolean			status
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
+
+	PHYDM_DBG(dm, DBG_TXBF, "[David]@%s Start!\n", __func__);
+
+	if (status == 1) {
+		if (entry->log_status_fail_cnt == 21)
+			beamforming_dym_period(dm, status);
+		entry->log_status_fail_cnt = 0;
+	} else if (entry->log_status_fail_cnt <= 20) {
+		entry->log_status_fail_cnt++;
+		PHYDM_DBG(dm, DBG_TXBF, "%s log_status_fail_cnt %d\n", __func__, entry->log_status_fail_cnt);
+	}
+	if (entry->log_status_fail_cnt > 20) {
+		entry->log_status_fail_cnt = 21;
+		PHYDM_DBG(dm, DBG_TXBF, "%s log_status_fail_cnt > 20, Stop SOUNDING\n", __func__);
+		beamforming_dym_period(dm, status);
+	}
+}
+
+void
+phydm_beamforming_end_sw(
+	void		*dm_void,
+	boolean			status
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
+
+	if (beam_info->is_mu_sounding) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s: MU sounding done\n", __func__);
+		beam_info->is_mu_sounding_in_progress = false;
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+				 (u8 *)&beam_info->beamformee_cur_idx);
+	} else {
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSING) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] BeamformStatus %d\n", __func__, entry->beamform_entry_state);
+			return;
+		}
+
+		if ((beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7) && (beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9) && (!beam_info->snding3ss)) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] VHT3SS 7,8,9, do not apply V matrix.\n", __func__);
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+					 (u8 *)&beam_info->beamformee_cur_idx);
+		} else if (status == 1) {
+			entry->log_status_fail_cnt = 0;
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+					 (u8 *)&beam_info->beamformee_cur_idx);
+		} else {
+			entry->log_status_fail_cnt++;
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_TX_PATH_RESET,
+					 (u8 *)&beam_info->beamformee_cur_idx);
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] log_status_fail_cnt %d\n", __func__, entry->log_status_fail_cnt);
+		}
+
+		if (entry->log_status_fail_cnt > 50) {
+			PHYDM_DBG(dm, DBG_TXBF, "%s log_status_fail_cnt > 50, Stop SOUNDING\n", __func__);
+			entry->is_sound = false;
+			beamforming_deinit_entry(dm, entry->mac_addr);
+
+			/*Modified by David - Every action of deleting entry should follow by Notify*/
+			phydm_beamforming_notify(dm);
+		}
+
+		entry->is_beamforming_in_progress = false;
+	}
+	PHYDM_DBG(dm, DBG_TXBF, "%s: status=%d\n", __func__, status);
+}
+
+
+void
+beamforming_timer_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void			*dm_void
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void            *context
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void					*adapter = (void *)context;
+	PHAL_DATA_TYPE				hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct					*dm = &hal_data->odmpriv;
+#endif
+	boolean						ret = false;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY		*entry = &(beam_info->beamformee_entry[beam_info->beamformee_cur_idx]);
+	struct _RT_SOUNDING_INFO			*sound_info = &(beam_info->sounding_info);
+	boolean					is_beamforming_in_progress;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (beam_info->is_mu_sounding)
+		is_beamforming_in_progress = beam_info->is_mu_sounding_in_progress;
+	else
+		is_beamforming_in_progress = entry->is_beamforming_in_progress;
+
+	if (is_beamforming_in_progress) {
+		PHYDM_DBG(dm, DBG_TXBF, "is_beamforming_in_progress, reset it\n");
+		phydm_beamforming_end_sw(dm, 0);
+	}
+
+	ret = phydm_beamforming_select_beam_entry(dm, beam_info);
+#if (SUPPORT_MU_BF == 1)
+	if (ret && beam_info->beamformee_mu_cnt > 1)
+		ret = 1;
+	else
+		ret = 0;
+#endif
+	if (ret)
+		ret = beamforming_start_sw(dm, sound_info->sound_idx, sound_info->sound_mode, sound_info->sound_bw);
+	else
+		PHYDM_DBG(dm, DBG_TXBF, "%s, Error value return from BeamformingStart_V2\n", __func__);
+
+	if ((beam_info->beamformee_su_cnt != 0) || (beam_info->beamformee_mu_cnt > 1)) {
+		if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+			odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);
+		else {
+			u32	val = (sound_info->sound_period << 16) | HAL_TIMER_TXBF;
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_RESTART, (u8 *)(&val));
+		}
+	}
+}
+
+
+void
+beamforming_sw_timer_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct phydm_timer_list		*timer
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void *function_context
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+	beamforming_timer_callback(dm);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	struct dm_struct	*dm = (struct dm_struct *)function_context;
+	void	*adapter = dm->adapter;
+
+	if (*(dm->is_net_closed) == true)
+		return;
+	rtw_run_in_thread_cmd(adapter, beamforming_timer_callback, adapter);
+#endif
+
+}
+
+
+void
+phydm_beamforming_init(
+	void			*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMING_OID_INFO	*beam_oid_info = &beam_info->beamforming_oid_info;
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	
+	#ifdef BEAMFORMING_VERSION_1
+	if (hal_data->beamforming_version != BEAMFORMING_VERSION_1) {
+		return;
+	}
+	#endif
+	#endif
+
+	beam_oid_info->sound_oid_mode = SOUNDING_STOP_OID_TIMER;
+	PHYDM_DBG(dm, DBG_TXBF, "%s mode (%d)\n", __func__, beam_oid_info->sound_oid_mode);
+
+	beam_info->beamformee_su_cnt = 0;
+	beam_info->beamformer_su_cnt = 0;
+	beam_info->beamformee_mu_cnt = 0;
+	beam_info->beamformer_mu_cnt = 0;
+	beam_info->beamformee_mu_reg_maping = 0;
+	beam_info->mu_ap_index = 0;
+	beam_info->is_mu_sounding = false;
+	beam_info->first_mu_bfee_index = 0xFF;
+	beam_info->apply_v_matrix = true;
+	beam_info->snding3ss = false;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	beam_info->source_adapter = dm->adapter;
+#endif
+	hal_com_txbf_beamform_init(dm);
+}
+
+
+boolean
+phydm_acting_determine(
+	void			*dm_void,
+	enum phydm_acting_type	type
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean		ret = false;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PADAPTER    adapter = (PADAPTER)dm->beamforming_info.source_adapter;
+#else
+	struct _ADAPTER	*adapter = dm->adapter;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	if (type == phydm_acting_as_ap)
+		ret = ACTING_AS_AP(adapter);
+	else if (type == phydm_acting_as_ibss)
+		ret = ACTING_AS_IBSS(((PADAPTER)(adapter)));
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	struct mlme_priv			*pmlmepriv = &adapter->mlmepriv;
+
+	if (type == phydm_acting_as_ap)
+		ret = check_fwstate(pmlmepriv, WIFI_AP_STATE);
+	else if (type == phydm_acting_as_ibss)
+		ret = check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
+#endif
+
+	return ret;
+
+}
+
+void
+beamforming_enter(
+	void			*dm_void,
+	u16		sta_idx
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			bfer_bfee_idx = 0xff;
+
+	if (beamforming_init_entry(dm, sta_idx, &bfer_bfee_idx))
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_ENTER, (u8 *)&bfer_bfee_idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End!\n", __func__);
+}
+
+
+void
+beamforming_leave(
+	void			*dm_void,
+	u8			*RA
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (RA != NULL) {
+		beamforming_deinit_entry(dm, RA);
+		phydm_beamforming_notify(dm);
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End!!\n", __func__);
+}
+
+#if 0
+/* Nobody calls this function */
+void
+phydm_beamforming_set_txbf_en(
+	void		*dm_void,
+	u8			mac_id,
+	boolean			is_txbf
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u8					idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	entry = phydm_beamforming_get_entry_by_mac_id(dm, mac_id, &idx);
+
+	if (entry == NULL)
+		return;
+	else
+		entry->is_txbf = is_txbf;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s mac_id %d TxBF %d\n", __func__, entry->mac_id, entry->is_txbf);
+
+	phydm_beamforming_notify(dm);
+}
+#endif
+
+enum beamforming_cap
+phydm_beamforming_get_beam_cap(
+	void						*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	u8					i;
+	boolean				is_self_beamformer = false;
+	boolean				is_self_beamformee = false;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	enum beamforming_cap		beamform_cap = BEAMFORMING_CAP_NONE;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		beamformee_entry = beam_info->beamformee_entry[i];
+
+		if (beamformee_entry.is_used) {
+			is_self_beamformer = true;
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] BFee entry %d is_used=true\n", __func__, i);
+			break;
+		}
+	}
+
+	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
+		beamformer_entry = beam_info->beamformer_entry[i];
+
+		if (beamformer_entry.is_used) {
+			is_self_beamformee = true;
+			PHYDM_DBG(dm, DBG_TXBF, "[%s]: BFer entry %d is_used=true\n", __func__, i);
+			break;
+		}
+	}
+
+	if (is_self_beamformer)
+		beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP);
+	if (is_self_beamformee)
+		beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP);
+
+	return beamform_cap;
+}
+
+
+boolean
+beamforming_control_v1(
+	void			*dm_void,
+	u8			*RA,
+	u8			AID,
+	u8			mode,
+	enum channel_width	BW,
+	u8			rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean		ret = true;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	PHYDM_DBG(dm, DBG_TXBF, "AID (%d), mode (%d), BW (%d)\n", AID, mode, BW);
+
+	switch (mode) {
+	case 0:
+		ret = beamforming_start_v1(dm, RA, 0, BW, rate);
+		break;
+	case 1:
+		ret = beamforming_start_v1(dm, RA, 1, BW, rate);
+		break;
+	case 2:
+		phydm_beamforming_ndpa_rate(dm, BW, rate);
+		ret = beamforming_send_vht_ndpa_packet(dm, RA, AID, BW, NORMAL_QUEUE);
+		break;
+	case 3:
+		phydm_beamforming_ndpa_rate(dm, BW, rate);
+		ret = beamforming_send_ht_ndpa_packet(dm, RA, BW, NORMAL_QUEUE);
+		break;
+	}
+	return ret;
+}
+
+/*Only OID uses this function*/
+boolean
+phydm_beamforming_control_v2(
+	void		*dm_void,
+	u8			idx,
+	u8			mode,
+	enum channel_width	BW,
+	u16			period
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info =  &dm->beamforming_info;
+	struct _RT_BEAMFORMING_OID_INFO	*beam_oid_info = &beam_info->beamforming_oid_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+	PHYDM_DBG(dm, DBG_TXBF, "idx (%d), mode (%d), BW (%d), period (%d)\n", idx, mode, BW, period);
+
+	beam_oid_info->sound_oid_idx = idx;
+	beam_oid_info->sound_oid_mode = (enum sounding_mode) mode;
+	beam_oid_info->sound_oid_bw = BW;
+	beam_oid_info->sound_oid_period = period;
+
+	phydm_beamforming_notify(dm);
+
+	return true;
+}
+
+
+void
+phydm_beamforming_watchdog(
+	void		*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO		*beam_info = &dm->beamforming_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (beam_info->beamformee_su_cnt == 0)
+		return;
+
+	beamforming_dym_period(dm, 0);
+}
+enum beamforming_cap
+phydm_get_beamform_cap(
+	void			*dm_void
+)
+{
+	struct dm_struct                    *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info                     *sta = NULL;
+	struct bf_cmn_info                      *bf_info = NULL;
+	struct _RT_BEAMFORMING_INFO             *beam_info = &dm->beamforming_info;
+	void                         *adapter = dm->adapter;
+	enum beamforming_cap                     beamform_cap = BEAMFORMING_CAP_NONE;
+	u8                                       macid;
+	u8                                       ht_curbeamformcap = 0;
+	u16                                      vht_curbeamformcap = 0;
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PMGNT_INFO                              p_MgntInfo = &(((PADAPTER)(adapter))->MgntInfo);
+	PRT_VERY_HIGH_THROUGHPUT                p_vht_info = GET_VHT_INFO(p_MgntInfo);
+	PRT_HIGH_THROUGHPUT                     p_ht_info  = GET_HT_INFO(p_MgntInfo);
+
+	ht_curbeamformcap = p_ht_info->HtCurBeamform;
+	vht_curbeamformcap = p_vht_info->VhtCurBeamform;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s] WIN ht_curcap = %d ; vht_curcap = %d\n", __func__, ht_curbeamformcap, vht_curbeamformcap);
+
+	if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) /*We are Beamformee because the STA is Beamformer*/
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP));
+
+	/*We are Beamformer because the STA is Beamformee*/
+	if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP));
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+
+	/* We are Beamformee because the STA is SU Beamformer*/
+	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP));
+
+	/* We are Beamformer because the STA is SU Beamformee*/
+	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP));
+
+	/* We are Beamformee because the STA is MU Beamformer*/
+	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE))
+		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP));
+	#endif
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+
+		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		sta = dm->phydm_sta_info[macid];
+
+		if (!is_sta_active(sta))
+			continue;
+
+		bf_info = &sta->bf_info;
+		vht_curbeamformcap = bf_info->vht_beamform_cap;
+		ht_curbeamformcap  = bf_info->ht_beamform_cap;
+
+		if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) /*We are Beamformee because the STA is Beamformer*/
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP));
+
+		/*We are Beamformer because the STA is Beamformee*/
+		if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP));
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+		/* We are Beamformee because the STA is SU Beamformer*/
+		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP));
+
+		/* We are Beamformer because the STA is SU Beamformee*/
+		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP));
+
+		/* We are Beamformee because the STA is MU Beamformer*/
+		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE))
+			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP));
+	#endif
+}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s] CE ht_curcap = %d ; vht_curcap = %d\n", __func__, ht_curbeamformcap, vht_curbeamformcap);
+
+#endif
+
+return beamform_cap;
+
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.h
index a1f1079a0a06..d053779c8584 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_beamforming.h
@@ -1,366 +1,412 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __INC_BEAMFORMING_H
-#define __INC_BEAMFORMING_H
-
-#ifndef BEAMFORMING_SUPPORT
-#define	BEAMFORMING_SUPPORT		0
-#endif
-
-/*Beamforming Related*/
-#include "txbf/halcomtxbf.h"
-#include "txbf/haltxbfjaguar.h"
-#include "txbf/haltxbf8192e.h"
-#include "txbf/haltxbf8814a.h"
-#include "txbf/haltxbf8821b.h"
-#include "txbf/haltxbf8822b.h"
-#include "txbf/haltxbfinterface.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-
-#define MAX_BEAMFORMEE_SU	2
-#define MAX_BEAMFORMER_SU	2
-#if (RTL8822B_SUPPORT == 1)
-#define MAX_BEAMFORMEE_MU	6
-#define MAX_BEAMFORMER_MU	1
-#else
-#define MAX_BEAMFORMEE_MU	0
-#define MAX_BEAMFORMER_MU	0
-#endif
-
-#define BEAMFORMEE_ENTRY_NUM		(MAX_BEAMFORMEE_SU + MAX_BEAMFORMEE_MU)
-#define BEAMFORMER_ENTRY_NUM		(MAX_BEAMFORMER_SU + MAX_BEAMFORMER_MU)
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-/*for different naming between WIN and CE*/
-#define BEACON_QUEUE	BCN_QUEUE_INX
-#define NORMAL_QUEUE	MGT_QUEUE_INX
-#define RT_DISABLE_FUNC RTW_DISABLE_FUNC
-#define RT_ENABLE_FUNC RTW_ENABLE_FUNC
-#endif
-
-typedef enum _BEAMFORMING_ENTRY_STATE {
-	BEAMFORMING_ENTRY_STATE_UNINITIALIZE, 
-	BEAMFORMING_ENTRY_STATE_INITIALIZEING, 
-	BEAMFORMING_ENTRY_STATE_INITIALIZED, 
-	BEAMFORMING_ENTRY_STATE_PROGRESSING, 
-	BEAMFORMING_ENTRY_STATE_PROGRESSED 
-} BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;
-
-
-typedef enum _BEAMFORMING_NOTIFY_STATE {
-	BEAMFORMING_NOTIFY_NONE,
-	BEAMFORMING_NOTIFY_ADD,
-	BEAMFORMING_NOTIFY_DELETE,
-	BEAMFORMEE_NOTIFY_ADD_SU,
-	BEAMFORMEE_NOTIFY_DELETE_SU,
-	BEAMFORMEE_NOTIFY_ADD_MU,
-	BEAMFORMEE_NOTIFY_DELETE_MU,
-	BEAMFORMING_NOTIFY_RESET
-} BEAMFORMING_NOTIFY_STATE, *PBEAMFORMING_NOTIFY_STATE;
-
-typedef enum _BEAMFORMING_CAP {
-	BEAMFORMING_CAP_NONE = 0x0,
-	BEAMFORMER_CAP_HT_EXPLICIT = BIT1, 
-	BEAMFORMEE_CAP_HT_EXPLICIT = BIT2, 
-	BEAMFORMER_CAP_VHT_SU = BIT5,			/* Self has er Cap, because Reg er  & peer ee */
-	BEAMFORMEE_CAP_VHT_SU = BIT6,			/* Self has ee Cap, because Reg ee & peer er */
-	BEAMFORMER_CAP_VHT_MU = BIT7,			/* Self has er Cap, because Reg er  & peer ee */
-	BEAMFORMEE_CAP_VHT_MU = BIT8,			/* Self has ee Cap, because Reg ee & peer er */
-	BEAMFORMER_CAP = BIT9,
-	BEAMFORMEE_CAP = BIT10,
-}BEAMFORMING_CAP, *PBEAMFORMING_CAP;
-
-
-typedef enum _SOUNDING_MODE {
-	SOUNDING_SW_VHT_TIMER = 0x0,
-	SOUNDING_SW_HT_TIMER = 0x1, 
-	SOUNDING_STOP_All_TIMER = 0x2, 
-	SOUNDING_HW_VHT_TIMER = 0x3,			
-	SOUNDING_HW_HT_TIMER = 0x4,
-	SOUNDING_STOP_OID_TIMER = 0x5, 
-	SOUNDING_AUTO_VHT_TIMER = 0x6,
-	SOUNDING_AUTO_HT_TIMER = 0x7,
-	SOUNDING_FW_VHT_TIMER = 0x8,
-	SOUNDING_FW_HT_TIMER = 0x9,
-}SOUNDING_MODE, *PSOUNDING_MODE;
-
-typedef struct _RT_BEAMFORM_STAINFO {
-	pu1Byte						RA; 
-	u2Byte						AID; 
-	u2Byte						MacID;
-	u1Byte						MyMacAddr[6];
-	WIRELESS_MODE				WirelessMode;
-	CHANNEL_WIDTH				BW;
-	BEAMFORMING_CAP			BeamformCap;
-	u1Byte						HtBeamformCap;
-	u2Byte						VhtBeamformCap;
-	u1Byte						CurBeamform; 
-	u2Byte						CurBeamformVHT;
-} RT_BEAMFORM_STAINFO, *PRT_BEAMFORM_STAINFO;
-
-
-typedef struct _RT_BEAMFORMEE_ENTRY {
-	BOOLEAN bUsed;
-	BOOLEAN	bTxBF;
-	BOOLEAN bSound;
-	u2Byte	AID;				/*Used to construct AID field of NDPA packet.*/
-	u2Byte	MacId;				/*Used to Set Reg42C in IBSS mode. */
-	u2Byte	P_AID;				/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
-	u2Byte	G_ID;				/*Used to fill Tx DESC*/
-	u1Byte	MyMacAddr[6];
-	u1Byte	MacAddr[6];			/*Used to fill Reg6E4 to fill Mac address of CSI report frame.*/
-	CHANNEL_WIDTH			SoundBW;		/*Sounding BandWidth*/
-	u2Byte					SoundPeriod;
-	BEAMFORMING_CAP			BeamformEntryCap;
-	BEAMFORMING_ENTRY_STATE	BeamformEntryState;	
-	BOOLEAN						bBeamformingInProgress;
-	/*u1Byte	LogSeq;									// Move to _RT_BEAMFORMER_ENTRY*/
-	/*u2Byte	LogRetryCnt:3;		// 0~4				// Move to _RT_BEAMFORMER_ENTRY*/
-	/*u2Byte	LogSuccessCnt:2;		// 0~2				// Move to _RT_BEAMFORMER_ENTRY*/
-	u2Byte	LogStatusFailCnt:5;	// 0~21
-	u2Byte	DefaultCSICnt:5;		// 0~21
-	u1Byte	CSIMatrix[327];
-	u2Byte	CSIMatrixLen;
-	u1Byte	NumofSoundingDim;
-	u1Byte	CompSteeringNumofBFer;
-	u1Byte	su_reg_index;
-	/*For MU-MIMO*/
-	BOOLEAN	is_mu_sta;
-	u1Byte	mu_reg_index;
-	u1Byte	gid_valid[8];
-	u1Byte	user_position[16];
-} RT_BEAMFORMEE_ENTRY, *PRT_BEAMFORMEE_ENTRY;
-
-typedef struct _RT_BEAMFORMER_ENTRY {
-	BOOLEAN 			bUsed;
-	/*P_AID of BFer entry is probably not used*/
-	u2Byte				P_AID;					/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
-	u2Byte				G_ID;
-	u1Byte				MyMacAddr[6];
-	u1Byte				MacAddr[6];
-	BEAMFORMING_CAP	BeamformEntryCap;
-	u1Byte				NumofSoundingDim;
-	u1Byte				ClockResetTimes;		/*Modified by Jeffery @2015-04-10*/
-	u1Byte				PreLogSeq;				/*Modified by Jeffery @2015-03-30*/
-	u1Byte				LogSeq;					/*Modified by Jeffery @2014-10-29*/
-	u2Byte				LogRetryCnt:3;			/*Modified by Jeffery @2014-10-29*/
-	u2Byte				LogSuccess:2;			/*Modified by Jeffery @2014-10-29*/
-	u1Byte				su_reg_index;
-	 /*For MU-MIMO*/
-	BOOLEAN				is_mu_ap;
-	u1Byte				gid_valid[8];
-	u1Byte				user_position[16];
-	u2Byte				AID;
-} RT_BEAMFORMER_ENTRY, *PRT_BEAMFORMER_ENTRY;
-
-typedef struct _RT_SOUNDING_INFO {
-	u1Byte			SoundIdx;
-	CHANNEL_WIDTH	SoundBW;
-	SOUNDING_MODE	SoundMode; 
-	u2Byte			SoundPeriod;
-} RT_SOUNDING_INFO, *PRT_SOUNDING_INFO;
-
-
-
-typedef struct _RT_BEAMFORMING_OID_INFO {
-	u1Byte			SoundOidIdx;
-	CHANNEL_WIDTH	SoundOidBW;	
-	SOUNDING_MODE	SoundOidMode;
-	u2Byte			SoundOidPeriod;
-} RT_BEAMFORMING_OID_INFO, *PRT_BEAMFORMING_OID_INFO;
-
-
-typedef struct _RT_BEAMFORMING_INFO {
-	BEAMFORMING_CAP			BeamformCap;
-	RT_BEAMFORMEE_ENTRY		BeamformeeEntry[BEAMFORMEE_ENTRY_NUM];
-	RT_BEAMFORMER_ENTRY		BeamformerEntry[BEAMFORMER_ENTRY_NUM];
-	RT_BEAMFORM_STAINFO		BeamformSTAinfo;
-	u1Byte					BeamformeeCurIdx;
-	RT_TIMER					BeamformingTimer;
-	RT_TIMER					mu_timer;
-	RT_SOUNDING_INFO			SoundingInfo;
-	RT_BEAMFORMING_OID_INFO	BeamformingOidInfo;
-	HAL_TXBF_INFO			TxbfInfo;
-	u1Byte					SoundingSequence;
-	u1Byte					beamformee_su_cnt;
-	u1Byte					beamformer_su_cnt;
-	u4Byte					beamformee_su_reg_maping;
-	u4Byte					beamformer_su_reg_maping;
-	/*For MU-MINO*/
-	u1Byte					beamformee_mu_cnt;
-	u1Byte					beamformer_mu_cnt;
-	u4Byte					beamformee_mu_reg_maping;
-	u1Byte					mu_ap_index;
-	BOOLEAN					is_mu_sounding;
-	u1Byte					FirstMUBFeeIndex;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER				SourceAdapter;
-#endif
-	/* Control register */
-	u4Byte					RegMUTxCtrl;		/* For USB/SDIO interfaces aync I/O  */
-} RT_BEAMFORMING_INFO, *PRT_BEAMFORMING_INFO;
-
-
-typedef struct _RT_NDPA_STA_INFO {
-	u2Byte	AID:12;	
-	u2Byte	FeedbackType:1;
-	u2Byte	NcIndex:3;	
-} RT_NDPA_STA_INFO, *PRT_NDPA_STA_INFO;
-
-
-BEAMFORMING_CAP
-phydm_Beamforming_GetEntryBeamCapByMacId(
-	IN	PVOID	pDM_VOID,
-	IN 	u1Byte 	MacId
- );
-
-PRT_BEAMFORMEE_ENTRY
-phydm_Beamforming_GetBFeeEntryByAddr(
-	IN	PVOID		pDM_VOID,
-	IN	pu1Byte		RA,
-	OUT	pu1Byte		Idx
-	);
-
-PRT_BEAMFORMER_ENTRY
-phydm_Beamforming_GetBFerEntryByAddr(
-	IN	PVOID	pDM_VOID,
-	IN	pu1Byte	TA,
-	OUT	pu1Byte	Idx
-	);
-
-u1Byte
-Beamforming_GetHTNDPTxRate(
-	IN	PVOID	pDM_VOID,
-	u1Byte	CompSteeringNumofBFer
-);
-
-u1Byte
-Beamforming_GetVHTNDPTxRate(
-	IN	PVOID	pDM_VOID,
-	u1Byte	CompSteeringNumofBFer
-);
-
-VOID
-phydm_Beamforming_Notify(
-	IN	PVOID	pDM_VOID
-	);
-
-
-VOID
-Beamforming_Enter(
-	IN PVOID		pDM_VOID,
-	IN u2Byte	staIdx
-	);
-
-VOID
-Beamforming_Leave(
-	IN PVOID		pDM_VOID,
-	pu1Byte			RA
-	);
-
-BOOLEAN
-BeamformingStart_FW(
-	IN PVOID			pDM_VOID,
-	u1Byte			Idx
-	);
-
-VOID
-Beamforming_CheckSoundingSuccess(
-	IN PVOID			pDM_VOID,
-	BOOLEAN			Status	
-);
-
-VOID
-phydm_Beamforming_End_SW(
-	IN PVOID		pDM_VOID,
-	BOOLEAN			Status	
-	);
-
-VOID
-Beamforming_TimerCallback(
-	IN PVOID			pDM_VOID
-	);
-
-VOID
-phydm_Beamforming_Init(
-	IN	PVOID		pDM_VOID
-	);
-
-
-
-BEAMFORMING_CAP
-phydm_Beamforming_GetBeamCap(
-	IN PVOID			pDM_VOID,
-	IN PRT_BEAMFORMING_INFO 	pBeamInfo
-	);
-
-
-BOOLEAN
-BeamformingControl_V1(
-	IN PVOID			pDM_VOID,
-	pu1Byte			RA,
-	u1Byte			AID,
-	u1Byte			Mode,
-	CHANNEL_WIDTH	BW,
-	u1Byte			Rate
-	);
-
-
-BOOLEAN
-phydm_BeamformingControl_V2(
-	IN	PVOID		pDM_VOID,
-	u1Byte			Idx,
-	u1Byte			Mode, 
-	CHANNEL_WIDTH	BW,
-	u2Byte			Period
-	);
-
-VOID
-phydm_Beamforming_Watchdog(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-Beamforming_SWTimerCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PRT_TIMER		pTimer
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	void *FunctionContext
-#endif
-	);
-
-BOOLEAN
-Beamforming_SendHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW, 
-	IN	u1Byte			QIdx
-	);
-
-
-BOOLEAN
-Beamforming_SendVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW,
-	IN	u1Byte			QIdx
-	);
-
-#else
-#define Beamforming_GidPAid(Adapter, pTcb)
-#define Beamforming_Enter(pDM_Odm, staIdx)
-#define Beamforming_Leave(pDM_Odm, RA)
-#define Beamforming_End_FW(pDMOdm)
-#define BeamformingControl_V1(pDM_Odm, RA, AID, Mode, BW, Rate)		TRUE
-#define BeamformingControl_V2(pDM_Odm, Idx, Mode, BW, Period)		TRUE
-#define phydm_Beamforming_End_SW(pDM_Odm, _Status)
-#define Beamforming_TimerCallback(pDM_Odm)
-#define phydm_Beamforming_Init(pDM_Odm)
-#define phydm_BeamformingControl_V2(pDM_Odm, _Idx, _Mode, _BW, _Period)	FALSE
-#define Beamforming_Watchdog(pDM_Odm)
-#define phydm_Beamforming_Watchdog(pDM_Odm)
-
-
-#endif
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __INC_PHYDM_BEAMFORMING_H
+#define __INC_PHYDM_BEAMFORMING_H
+
+#ifndef BEAMFORMING_SUPPORT
+	#define	BEAMFORMING_SUPPORT		0
+#endif
+
+/*Beamforming Related*/
+#include "txbf/halcomtxbf.h"
+#include "txbf/haltxbfjaguar.h"
+#include "txbf/haltxbf8192e.h"
+#include "txbf/haltxbf8814a.h"
+#include "txbf/haltxbf8822b.h"
+#include "txbf/haltxbfinterface.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+#define eq_mac_addr(a,b)						( ((a)[0]==(b)[0] && (a)[1]==(b)[1] && (a)[2]==(b)[2] && (a)[3]==(b)[3] && (a)[4]==(b)[4] && (a)[5]==(b)[5]) ? 1:0 )
+#define cp_mac_addr(des,src)					((des)[0]=(src)[0],(des)[1]=(src)[1],(des)[2]=(src)[2],(des)[3]=(src)[3],(des)[4]=(src)[4],(des)[5]=(src)[5])
+
+#endif
+
+#define MAX_BEAMFORMEE_SU	2
+#define MAX_BEAMFORMER_SU	2
+#if (RTL8822B_SUPPORT == 1)
+	#define MAX_BEAMFORMEE_MU	6
+	#define MAX_BEAMFORMER_MU	1
+#else
+	#define MAX_BEAMFORMEE_MU	0
+	#define MAX_BEAMFORMER_MU	0
+#endif
+
+#define BEAMFORMEE_ENTRY_NUM		(MAX_BEAMFORMEE_SU + MAX_BEAMFORMEE_MU)
+#define BEAMFORMER_ENTRY_NUM		(MAX_BEAMFORMER_SU + MAX_BEAMFORMER_MU)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	/*for different naming between WIN and CE*/
+	#define BEACON_QUEUE	BCN_QUEUE_INX
+	#define NORMAL_QUEUE	MGT_QUEUE_INX
+	#define RT_DISABLE_FUNC RTW_DISABLE_FUNC
+	#define RT_ENABLE_FUNC RTW_ENABLE_FUNC
+#endif
+
+enum beamforming_entry_state {
+	BEAMFORMING_ENTRY_STATE_UNINITIALIZE,
+	BEAMFORMING_ENTRY_STATE_INITIALIZEING,
+	BEAMFORMING_ENTRY_STATE_INITIALIZED,
+	BEAMFORMING_ENTRY_STATE_PROGRESSING,
+	BEAMFORMING_ENTRY_STATE_PROGRESSED
+};
+
+
+enum beamforming_notify_state {
+	BEAMFORMING_NOTIFY_NONE,
+	BEAMFORMING_NOTIFY_ADD,
+	BEAMFORMING_NOTIFY_DELETE,
+	BEAMFORMEE_NOTIFY_ADD_SU,
+	BEAMFORMEE_NOTIFY_DELETE_SU,
+	BEAMFORMEE_NOTIFY_ADD_MU,
+	BEAMFORMEE_NOTIFY_DELETE_MU,
+	BEAMFORMING_NOTIFY_RESET
+};
+
+enum beamforming_cap {
+	BEAMFORMING_CAP_NONE = 0x0,
+	BEAMFORMER_CAP_HT_EXPLICIT = BIT(1),
+	BEAMFORMEE_CAP_HT_EXPLICIT = BIT(2),
+	BEAMFORMER_CAP_VHT_SU = BIT(5),			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_SU = BIT(6),			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP_VHT_MU = BIT(7),			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_MU = BIT(8),			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP = BIT(9),
+	BEAMFORMEE_CAP = BIT(10),
+};
+
+
+enum sounding_mode {
+	SOUNDING_SW_VHT_TIMER = 0x0,
+	SOUNDING_SW_HT_TIMER = 0x1,
+	sounding_stop_all_timer = 0x2,
+	SOUNDING_HW_VHT_TIMER = 0x3,
+	SOUNDING_HW_HT_TIMER = 0x4,
+	SOUNDING_STOP_OID_TIMER = 0x5,
+	SOUNDING_AUTO_VHT_TIMER = 0x6,
+	SOUNDING_AUTO_HT_TIMER = 0x7,
+	SOUNDING_FW_VHT_TIMER = 0x8,
+	SOUNDING_FW_HT_TIMER = 0x9,
+};
+
+struct _RT_BEAMFORM_STAINFO {
+	u8						*ra;
+	u16						aid;
+	u16						mac_id;
+	u8						my_mac_addr[6];
+	/*WIRELESS_MODE				wireless_mode;*/
+	enum channel_width				bw;
+	enum beamforming_cap			beamform_cap;
+	u8						ht_beamform_cap;
+	u16						vht_beamform_cap;
+	u8						cur_beamform;
+	u16						cur_beamform_vht;
+};
+
+
+struct _RT_BEAMFORMEE_ENTRY {
+	boolean is_used;
+	boolean	is_txbf;
+	boolean is_sound;
+	u16	aid;				/*Used to construct AID field of NDPA packet.*/
+	u16	mac_id;				/*Used to Set Reg42C in IBSS mode. */
+	u16	p_aid;				/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u8	g_id;				/*Used to fill Tx DESC*/
+	u8	my_mac_addr[6];
+	u8	mac_addr[6];			/*Used to fill Reg6E4 to fill Mac address of CSI report frame.*/
+	enum channel_width			sound_bw;		/*Sounding band_width*/
+	u16					sound_period;
+	enum beamforming_cap			beamform_entry_cap;
+	enum beamforming_entry_state	beamform_entry_state;
+	boolean						is_beamforming_in_progress;
+	/*u8	log_seq;									// Move to _RT_BEAMFORMER_ENTRY*/
+	/*u16	log_retry_cnt:3;		// 0~4				// Move to _RT_BEAMFORMER_ENTRY*/
+	/*u16	LogSuccessCnt:2;		// 0~2				// Move to _RT_BEAMFORMER_ENTRY*/
+	u16	log_status_fail_cnt:5;	/* 0~21 */
+	u16	default_csi_cnt:5;		/* 0~21 */
+	u8	csi_matrix[327];
+	u16	csi_matrix_len;
+	u8	num_of_sounding_dim;
+	u8	comp_steering_num_of_bfer;
+	u8	su_reg_index;
+	/*For MU-MIMO*/
+	boolean	is_mu_sta;
+	u8	mu_reg_index;
+	u8	gid_valid[8];
+	u8	user_position[16];
+};
+
+struct _RT_BEAMFORMER_ENTRY {
+	boolean			is_used;
+	/*P_AID of BFer entry is probably not used*/
+	u16				p_aid;					/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u8				g_id;
+	u8				my_mac_addr[6];
+	u8				mac_addr[6];
+	enum beamforming_cap		beamform_entry_cap;
+	u8				num_of_sounding_dim;
+	u8				clock_reset_times;		/*Modified by Jeffery @2015-04-10*/
+	u8				pre_log_seq;				/*Modified by Jeffery @2015-03-30*/
+	u8				log_seq;					/*Modified by Jeffery @2014-10-29*/
+	u16				log_retry_cnt:3;			/*Modified by Jeffery @2014-10-29*/
+	u16				log_success:2;			/*Modified by Jeffery @2014-10-29*/
+	u8				su_reg_index;
+	/*For MU-MIMO*/
+	boolean				is_mu_ap;
+	u8				gid_valid[8];
+	u8				user_position[16];
+	u16				aid;
+};
+
+struct _RT_SOUNDING_INFO {
+	u8			sound_idx;
+	enum channel_width	sound_bw;
+	enum sounding_mode	sound_mode;
+	u16			sound_period;
+};
+
+
+
+struct _RT_BEAMFORMING_OID_INFO {
+	u8			sound_oid_idx;
+	enum channel_width	sound_oid_bw;
+	enum sounding_mode	sound_oid_mode;
+	u16			sound_oid_period;
+};
+
+
+struct _RT_BEAMFORMING_INFO {
+	enum beamforming_cap			beamform_cap;
+	struct _RT_BEAMFORMEE_ENTRY		beamformee_entry[BEAMFORMEE_ENTRY_NUM];
+	struct _RT_BEAMFORMER_ENTRY		beamformer_entry[BEAMFORMER_ENTRY_NUM];
+	struct _RT_BEAMFORM_STAINFO		beamform_sta_info;
+	u8					beamformee_cur_idx;
+	struct phydm_timer_list					beamforming_timer;
+	struct phydm_timer_list					mu_timer;
+	struct _RT_SOUNDING_INFO			sounding_info;
+	struct _RT_BEAMFORMING_OID_INFO	beamforming_oid_info;
+	struct _HAL_TXBF_INFO			txbf_info;
+	u8					sounding_sequence;
+	u8					beamformee_su_cnt;
+	u8					beamformer_su_cnt;
+	u32					beamformee_su_reg_maping;
+	u32					beamformer_su_reg_maping;
+	/*For MU-MINO*/
+	u8					beamformee_mu_cnt;
+	u8					beamformer_mu_cnt;
+	u32					beamformee_mu_reg_maping;
+	u8					mu_ap_index;
+	boolean					is_mu_sounding;
+	u8					first_mu_bfee_index;
+	boolean					is_mu_sounding_in_progress;
+	boolean					dbg_disable_mu_tx;
+	boolean					apply_v_matrix;
+	boolean					snding3ss;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void				*source_adapter;
+#endif
+	/* Control register */
+	u32					reg_mu_tx_ctrl;		/* For USB/SDIO interfaces aync I/O */
+	u8					tx_bf_data_rate;
+	u8					last_usb_hub;
+};
+
+
+void
+phydm_get_txbf_device_num(
+	void	*dm_void,
+	u8	macid
+);
+
+struct _RT_NDPA_STA_INFO {
+	u16	aid:12;
+	u16	feedback_type:1;
+	u16	nc_index:3;
+};
+
+enum phydm_acting_type {
+	phydm_acting_as_ibss = 0,
+	phydm_acting_as_ap = 1
+};
+
+
+enum beamforming_cap
+phydm_beamforming_get_entry_beam_cap_by_mac_id(
+	void	*dm_void,
+	u8	mac_id
+);
+
+struct _RT_BEAMFORMEE_ENTRY *
+phydm_beamforming_get_bfee_entry_by_addr(
+	void		*dm_void,
+	u8		*RA,
+	u8		*idx
+);
+
+struct _RT_BEAMFORMER_ENTRY *
+phydm_beamforming_get_bfer_entry_by_addr(
+	void	*dm_void,
+	u8	*TA,
+	u8	*idx
+);
+
+void
+phydm_beamforming_notify(
+	void	*dm_void
+);
+
+boolean
+phydm_acting_determine(
+	void		*dm_void,
+	enum phydm_acting_type	type
+);
+
+void
+beamforming_enter(
+	void		*dm_void,
+	u16	sta_idx
+);
+
+void
+beamforming_leave(
+	void		*dm_void,
+	u8			*RA
+);
+
+boolean
+beamforming_start_fw(
+	void			*dm_void,
+	u8			idx
+);
+
+void
+beamforming_check_sounding_success(
+	void			*dm_void,
+	boolean			status
+);
+
+void
+phydm_beamforming_end_sw(
+	void		*dm_void,
+	boolean			status
+);
+
+void
+beamforming_timer_callback(
+	void			*dm_void
+);
+
+void
+phydm_beamforming_init(
+	void		*dm_void
+);
+
+
+
+enum beamforming_cap
+phydm_beamforming_get_beam_cap(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+);
+
+enum beamforming_cap
+phydm_get_beamform_cap(
+	void			*dm_void
+);
+
+boolean
+beamforming_control_v1(
+	void			*dm_void,
+	u8			*RA,
+	u8			AID,
+	u8			mode,
+	enum channel_width	BW,
+	u8			rate
+);
+
+
+boolean
+phydm_beamforming_control_v2(
+	void		*dm_void,
+	u8			idx,
+	u8			mode,
+	enum channel_width	BW,
+	u16			period
+);
+
+void
+phydm_beamforming_watchdog(
+	void		*dm_void
+);
+
+void
+beamforming_sw_timer_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct phydm_timer_list		*timer
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void *function_context
+#endif
+);
+
+boolean
+beamforming_send_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW,
+	u8			q_idx
+);
+
+
+boolean
+beamforming_send_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW,
+	u8			q_idx
+);
+
+#else
+#define beamforming_gid_paid(adapter, tcb)
+#define	phydm_acting_determine(dm, type)	false
+#define beamforming_enter(dm, sta_idx)
+#define beamforming_leave(dm, RA)
+#define beamforming_end_fw(dm)
+#define beamforming_control_v1(dm, RA, AID, mode, BW, rate)		true
+#define beamforming_control_v2(dm, idx, mode, BW, period)		true
+#define phydm_beamforming_end_sw(dm, _status)
+#define beamforming_timer_callback(dm)
+#define phydm_beamforming_init(dm)
+#define phydm_beamforming_control_v2(dm, _idx, _mode, _BW, _period)	false
+#define beamforming_watchdog(dm)
+#define phydm_beamforming_watchdog(dm)
+
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cck_pd.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cck_pd.c
new file mode 100644
index 000000000000..cdd2b6791bdf
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cck_pd.c
@@ -0,0 +1,472 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+ 
+#ifdef PHYDM_SUPPORT_CCKPD
+
+void
+phydm_write_cck_cca_th_new_cs_ratio(
+	void			*dm_void,
+	u8			cca_th,
+	u8			cca_th_aaa
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "[New] pd_th=0x%x, cs_ratio=0x%x\n\n", cca_th, cca_th_aaa);
+
+	if (cckpd_t->cur_cck_cca_thres != cca_th) {
+		
+		cckpd_t->cur_cck_cca_thres = cca_th;
+		odm_set_bb_reg(dm, 0xa08, 0xf0000, cca_th);
+		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+		
+	}
+
+	if (cckpd_t->cck_cca_th_aaa != cca_th_aaa) {
+		
+		cckpd_t->cck_cca_th_aaa = cca_th_aaa;
+		odm_set_bb_reg(dm, 0xaa8, 0x1f0000, cca_th_aaa);
+		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+	}
+	
+}
+
+void
+phydm_write_cck_cca_th(
+	void			*dm_void,
+	u8			cca_th
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "New cck_cca_th=((0x%x))\n\n", cca_th);
+
+	if (cckpd_t->cur_cck_cca_thres != cca_th) {
+		
+		odm_write_1byte(dm, ODM_REG(CCK_CCA, dm), cca_th);
+		cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+	}
+	cckpd_t->cur_cck_cca_thres = cca_th;
+}
+
+void
+phydm_set_cckpd_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+
+	if (val_len != 2) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][CCKPD]Need val_len=2\n");
+		return;
+	}
+	
+	/*val_buf[0]: 0xa0a*/
+	/*val_buf[1]: 0xaaa*/
+	
+	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC) {
+		phydm_write_cck_cca_th_new_cs_ratio(dm, (u8)val_buf[0], (u8)val_buf[1]);
+	} else {
+		phydm_write_cck_cca_th(dm, (u8)val_buf[0]);
+	}
+
+}
+
+boolean
+phydm_stop_cck_pd_th(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT))) {
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Not Support\n");
+
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+		#ifdef MCR_WIRELESS_EXTEND
+		phydm_write_cck_cca_th(dm, 0x43);
+		#endif
+		#endif
+		
+		return true;
+	}
+
+	if (dm->pause_ability & ODM_BB_CCK_PD) {
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: Pause CCKPD in LV=%d\n", dm->pause_lv_table.lv_cckpd);
+		return true;
+	}
+
+	#if 0/*(DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))*/
+	if (dm->ext_lna)
+		return true;
+	#endif
+
+	return false;
+	
+}
+
+void
+phydm_cckpd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	u8	cur_cck_cca_th= cckpd_t->cur_cck_cca_thres;
+
+	if (dm->is_linked) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+
+		/*Add hp_hw_id condition due to 22B LPS power consumption issue and [PCIE-1596]*/
+		if (dm->hp_hw_id && (dm->traffic_load == TRAFFIC_ULTRA_LOW))
+			cur_cck_cca_th = 0x40;
+		else if (dm->rssi_min > 35)
+			cur_cck_cca_th = 0xcd;
+		else if (dm->rssi_min > 20) {
+			
+			if (cckpd_t->cck_fa_ma > 500)
+				cur_cck_cca_th = 0xcd;
+			else if (cckpd_t->cck_fa_ma < 250)
+				cur_cck_cca_th = 0x83;
+			
+		} else {
+			if((dm->p_advance_ota & PHYDM_ASUS_OTA_SETTING) && (cckpd_t->cck_fa_ma > 200))
+				cur_cck_cca_th = 0xc3; /*for ASUS OTA test*/
+			else
+				cur_cck_cca_th = 0x83;
+		}
+		
+#else	/*ODM_AP*/
+		if (dig_t->cur_ig_value > 0x32)
+			cur_cck_cca_th = 0xed;
+		else if (dig_t->cur_ig_value > 0x2a)
+			cur_cck_cca_th = 0xdd;
+		else if (dig_t->cur_ig_value > 0x24)
+			cur_cck_cca_th = 0xcd;
+		else 
+			cur_cck_cca_th = 0x83;
+		
+#endif
+	} else {
+	
+		if (cckpd_t->cck_fa_ma > 1000)
+			cur_cck_cca_th = 0x83;
+		else if (cckpd_t->cck_fa_ma < 500)
+			cur_cck_cca_th = 0x40;
+	}
+
+	phydm_write_cck_cca_th(dm, cur_cck_cca_th);
+	/*PHYDM_DBG(dm, DBG_CCKPD, "New cck_cca_th=((0x%x))\n\n", cur_cck_cca_th);*/
+
+}
+
+void
+phydm_cckpd_new_cs_ratio(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	u8	pd_th = 0, cs_ration = 0, cs_2r_offset = 0;
+	u8	igi_curr = dig_t->cur_ig_value;
+	u8	en_2rcca;
+	boolean is_update = true;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	en_2rcca = (u8)(odm_get_bb_reg(dm, 0xa2c, BIT(18)) && odm_get_bb_reg(dm, 0xa2c, BIT(22)));
+
+	if (dm->is_linked) {
+		
+		if ((igi_curr > 0x38) && (dm->rssi_min > 32)) {
+			cs_ration = dig_t->aaa_default + AAA_BASE + AAA_STEP * 2;
+			cs_2r_offset = 5;
+			pd_th = 0xd;
+		} else if ((igi_curr > 0x2a) && (dm->rssi_min > 32)) {
+			cs_ration = dig_t->aaa_default + AAA_BASE + AAA_STEP;
+			cs_2r_offset = 4;
+			pd_th = 0xd;
+		} else if ((igi_curr > 0x24) || (dm->rssi_min > 24 && dm->rssi_min <= 30)) {
+			cs_ration = dig_t->aaa_default + AAA_BASE;
+			cs_2r_offset = 3;
+			pd_th = 0xd;
+		} else if ((igi_curr <= 0x24) || (dm->rssi_min < 22)) {
+			
+			if (cckpd_t->cck_fa_ma > 1000) {
+				cs_ration = dig_t->aaa_default + AAA_STEP;
+				cs_2r_offset = 1;
+				pd_th = 0x7;
+			} else if (cckpd_t->cck_fa_ma < 500) {
+				cs_ration = dig_t->aaa_default;
+				pd_th = 0x3;
+			} else {
+				is_update = false;
+				cs_ration = cckpd_t->cck_cca_th_aaa;
+				pd_th = cckpd_t->cur_cck_cca_thres;
+			}
+		}
+	} else {
+	
+		if (cckpd_t->cck_fa_ma > 1000) {
+			cs_ration = dig_t->aaa_default + AAA_STEP;
+			cs_2r_offset = 1;
+			pd_th = 0x7;
+		} else if (cckpd_t->cck_fa_ma < 500) {
+			cs_ration = dig_t->aaa_default;
+			pd_th = 0x3;
+		} else {
+			is_update = false;
+			cs_ration = cckpd_t->cck_cca_th_aaa;
+			pd_th = cckpd_t->cur_cck_cca_thres;
+		}
+	}
+	
+	if (en_2rcca)
+		cs_ration = (cs_ration >= cs_2r_offset) ? (cs_ration - cs_2r_offset) : 0;
+
+	PHYDM_DBG(dm, DBG_CCKPD, 
+	"[New] cs_ratio=0x%x, pd_th=0x%x\n", cs_ration, pd_th);
+
+	if (is_update) {
+		cckpd_t->cur_cck_cca_thres = pd_th;
+		cckpd_t->cck_cca_th_aaa = cs_ration;
+		odm_set_bb_reg(dm, 0xa08, 0xf0000, pd_th);
+		odm_set_bb_reg(dm, 0xaa8, 0x1f0000, cs_ration);
+	}
+	/*phydm_write_cck_cca_th_new_cs_ratio(dm, pd_th, cs_ration);*/
+}
+
+#endif
+
+void
+phydm_cck_pd_th(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct		*fa_t= &dm->false_alm_cnt;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	u32	cnt_cck_fail_tmp = fa_t->cnt_cck_fail;
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct	*fa_acc_t = &dm->false_alm_cnt_acc;
+	#endif
+	
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	if (phydm_stop_cck_pd_th(dm) == true)
+		return;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	cnt_cck_fail_tmp = (dm->original_dig_restore) ? (fa_t->cnt_cck_fail) : (fa_acc_t->cnt_cck_fail_1sec);
+#endif
+	
+	if (cckpd_t->cck_fa_ma == CCK_FA_MA_RESET)
+		cckpd_t->cck_fa_ma = cnt_cck_fail_tmp;
+	else {
+		cckpd_t->cck_fa_ma = ((cckpd_t->cck_fa_ma << 1) +
+									cckpd_t->cck_fa_ma + cnt_cck_fail_tmp) >> 2;
+	}
+	
+	PHYDM_DBG(dm, DBG_CCKPD, "CCK FA=%d\n", cckpd_t->cck_fa_ma);
+
+	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC)
+		phydm_cckpd_new_cs_ratio(dm);
+	else
+		phydm_cckpd(dm);
+	
+#endif
+}
+
+void
+odm_pause_cck_packet_detection(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type,
+	enum phydm_pause_level		pause_lv,
+	u8					cck_pd_th
+)
+{
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct	*cckpd_t = &dm->dm_cckpd_table;
+	s8	max_level;
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	if ((cckpd_t->pause_bitmap == 0) &&
+		(!(dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT)))) {
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: not support\n");
+		return;
+	}
+
+	if (pause_lv >= PHYDM_PAUSE_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: Wrong LV !\n");
+		return;
+	}
+	PHYDM_DBG(dm, DBG_CCKPD, "Set pause{Type, LV, val} = {%d, %d, 0x%x}\n", 
+		pause_type, pause_lv, cck_pd_th);
+
+	PHYDM_DBG(dm, DBG_CCKPD, "pause LV=0x%x\n", cckpd_t->pause_bitmap);
+
+	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
+		PHYDM_DBG(dm, DBG_CCKPD, "pause val[%d]=0x%x\n", 
+										i, cckpd_t->pause_cckpd_value[i]);
+	}
+
+	switch (pause_type) {
+	case PHYDM_PAUSE:
+	{
+		/* Disable CCK PD */
+		dm->support_ability &= ~ODM_BB_CCK_PD;
+		
+		PHYDM_DBG(dm, DBG_CCKPD, "Pause CCK PD th\n");
+
+		/* Backup original CCK PD threshold decided by CCK PD mechanism */
+		if (cckpd_t->pause_bitmap == 0) {
+			
+			cckpd_t->cckpd_bkp = cckpd_t->cur_cck_cca_thres;
+			
+			PHYDM_DBG(dm, DBG_CCKPD, "cckpd_bkp=0x%x\n", 
+				cckpd_t->cckpd_bkp);
+		}
+
+		cckpd_t->pause_bitmap |= BIT(pause_lv); /* Update pause level */
+		cckpd_t->pause_cckpd_value[pause_lv] = cck_pd_th; 
+
+		/* Write new CCK PD threshold */
+		if (BIT(pause_lv + 1) > cckpd_t->pause_bitmap) {
+			PHYDM_DBG(dm, DBG_CCKPD, "> ori pause LV=0x%x\n", 
+				cckpd_t->pause_bitmap);
+			
+			phydm_write_cck_cca_th(dm, cck_pd_th);
+		}
+		break;
+	}
+	case PHYDM_RESUME:
+	{
+		/* check if the level is illegal or not */
+		if ((cckpd_t->pause_bitmap & (BIT(pause_lv))) != 0) {
+			
+			cckpd_t->pause_bitmap &= (~(BIT(pause_lv)));
+			cckpd_t->pause_cckpd_value[pause_lv] = 0;
+			PHYDM_DBG(dm, DBG_CCKPD, "Resume CCK PD\n");
+		} else {
+		
+			PHYDM_DBG(dm, DBG_CCKPD, "Wrong resume LV\n");
+			break;
+		}
+
+		/* Resume CCKPD */
+		if (cckpd_t->pause_bitmap == 0) {
+			
+			PHYDM_DBG(dm, DBG_CCKPD, "Revert bkp_CCKPD=0x%x\n", 
+														cckpd_t->cckpd_bkp);
+			
+			phydm_write_cck_cca_th(dm, cckpd_t->cckpd_bkp);
+			dm->support_ability |= ODM_BB_CCK_PD;/* Enable CCKPD */
+			break;
+		}
+
+		if (BIT(pause_lv) <= cckpd_t->pause_bitmap)
+			break;
+
+		/* Calculate the maximum level now */
+		for (max_level = (pause_lv - 1); max_level >= 0; max_level--) {
+			if (cckpd_t->pause_bitmap & BIT(max_level))
+				break;
+		}
+
+		/* write CCKPD of lower level */
+		phydm_write_cck_cca_th(dm, cckpd_t->pause_cckpd_value[max_level]);
+		PHYDM_DBG(dm, DBG_CCKPD, "Write CCKPD=0x%x for max_LV=%d\n",
+			cckpd_t->pause_cckpd_value[max_level], max_level);
+		break;
+	}
+	default:
+		PHYDM_DBG(dm, DBG_CCKPD, "Wrong  type\n");
+		break;
+	}
+
+	PHYDM_DBG(dm, DBG_CCKPD, "New pause bitmap=0x%x\n", 
+													cckpd_t->pause_bitmap);
+	
+	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
+		PHYDM_DBG(dm, DBG_CCKPD, "pause val[%d]=0x%x\n", 
+										i, cckpd_t->pause_cckpd_value[i]);
+	}
+#endif
+}
+
+void
+phydm_cck_pd_init(
+	void		*dm_void
+)
+{
+#ifdef PHYDM_SUPPORT_CCKPD
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct		*cckpd_t = &dm->dm_cckpd_table;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+
+	cckpd_t->cur_cck_cca_thres = 0;
+	cckpd_t->cck_cca_th_aaa = 0;
+	
+	cckpd_t->pause_bitmap = 0;
+
+	if (dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC) {
+		dig_t->aaa_default = odm_read_1byte(dm, 0xaaa) & 0x1f;
+		dig_t->a0a_default = (u8)odm_get_bb_reg(dm, R_0xa08, 0xff0000);
+		cckpd_t->cck_cca_th_aaa = dig_t->aaa_default;
+		cckpd_t->cur_cck_cca_thres = dig_t->a0a_default;
+	} else {
+		dig_t->a0a_default = (u8)odm_get_bb_reg(dm, R_0xa08, 0xff0000);
+		cckpd_t->cur_cck_cca_thres = dig_t->a0a_default;
+	}
+
+	odm_memory_set(dm, cckpd_t->pause_cckpd_value, 0, PHYDM_PAUSE_MAX_NUM);
+#endif
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cck_pd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cck_pd.h
new file mode 100644
index 000000000000..3c226154035c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cck_pd.h
@@ -0,0 +1,95 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_CCK_PD_H__
+#define    __PHYDM_CCK_PD_H__
+
+#define CCK_PD_VERSION	"1.0"		/* 2017.05.09  Dino, Add phydm_cck_pd.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+#define	AAA_BASE	4
+#define	AAA_STEP	2
+
+#define	CCK_FA_MA_RESET	0xffffffff
+
+#define	EXTEND_CCK_CCATH_AAA_IC	(ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8723D |ODM_RTL8710B)
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+#ifdef PHYDM_SUPPORT_CCKPD
+struct phydm_cckpd_struct {
+	u8		cur_cck_cca_thres; /*0xA0A*/
+	u8		cck_cca_th_aaa; /*0xAAA*/
+	u32		cck_fa_ma;
+	u8		cckpd_bkp;
+	u32		rvrt_val[2];
+	u8		pause_bitmap;/*will be removed*/
+	u8		pause_lv;
+	u8		pause_cckpd_value[PHYDM_PAUSE_MAX_NUM]; /*will be removed*/
+};
+#endif
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_set_cckpd_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+void
+phydm_cck_pd_th(
+	void		*dm_void
+);
+
+void
+odm_pause_cck_packet_detection(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type,
+	enum phydm_pause_level		pause_level,
+	u8					cck_pd_threshold
+);
+
+void
+phydm_cck_pd_init(
+	void		*dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_ccx.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_ccx.c
new file mode 100644
index 000000000000..b6f4809c640f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_ccx.c
@@ -0,0 +1,2082 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_ccx_hw_restart(
+	void			*dm_void
+)/*Will Restart NHM/CLM/FAHM simultaneously*/
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32	reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? R_0x994 : R_0x890;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	odm_set_bb_reg(dm, reg1, 0x7, 0x0); /*disable NHM,CLM, FAHM*/
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x994, BIT(8), 0x0);
+		odm_set_bb_reg(dm, R_0x994, BIT(8), 0x1);
+
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0x890, BIT(8), 0x0);
+		odm_set_bb_reg(dm, R_0x890, BIT(8), 0x1);
+	}
+}
+
+#ifdef FAHM_SUPPORT
+
+u16
+phydm_hw_divider(
+	void	*dm_void,
+	u16	numerator,
+	u16	denumerator
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16	result = DEVIDER_ERROR;
+	u32	tmp_u32 = ((numerator << 16) | denumerator);
+	u32	reg_devider_input;
+	u32	reg_devider_rpt;
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg_devider_input =  0x1cbc;
+		reg_devider_rpt = 0x1f98;
+	} else {
+		reg_devider_input =  0x980;
+		reg_devider_rpt = 0x9f0;
+	}
+
+	odm_set_bb_reg(dm, reg_devider_input, MASKDWORD, tmp_u32);
+
+	for (i = 0; i < 10; i++) {
+		ODM_delay_ms(1);
+		if (odm_get_bb_reg(dm, reg_devider_rpt, BIT(24))) { /*Chk HW rpt is ready*/
+			
+			result = (u16)odm_get_bb_reg(dm, reg_devider_rpt, MASKBYTE2);
+			break;
+		}
+	}
+	return	result;
+}
+
+void
+phydm_fahm_trigger(
+	void		*dm_void,
+	u16		trigger_period	/*unit (4us)*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u32		fahm_reg1;
+	u32		fahm_reg2;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x1cf8, 0xffff00, trigger_period);
+		
+		fahm_reg1 =  0x994;
+	} else {
+	
+		odm_set_bb_reg(dm, R_0x978, 0xff000000, (trigger_period & 0xff));		
+		odm_set_bb_reg(dm, R_0x97c, 0xff, (trigger_period & 0xff00)>>8);
+		
+		fahm_reg1 =  0x890;
+	}
+
+	odm_set_bb_reg(dm, fahm_reg1, BIT(2), 0);
+	odm_set_bb_reg(dm, fahm_reg1, BIT(2), 1);
+}
+
+void
+phydm_fahm_set_valid_cnt(
+	void		*dm_void,
+	u8		numerator_sel,
+	u8		denumerator_sel
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u32		fahm_reg1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if ((ccx_info->fahm_nume_sel == numerator_sel) && 
+		(ccx_info->fahm_denum_sel == denumerator_sel)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "no need to update\n");
+		return;
+	}
+
+	ccx_info->fahm_nume_sel = numerator_sel;
+	ccx_info->fahm_denum_sel = denumerator_sel;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		fahm_reg1 =  0x994;
+	} else {
+		fahm_reg1 =  0x890;
+	}
+
+	odm_set_bb_reg(dm, fahm_reg1, 0xe0, numerator_sel);
+	odm_set_bb_reg(dm, fahm_reg1, 0x7000, denumerator_sel);
+}
+
+void
+phydm_fahm_get_result(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u16		fahm_rpt_cnt[12];	/*packet count*/
+	u16		fahm_rpt[12];		/*percentage*/
+	u16		fahm_denumerator;	/*packet count*/
+	u32		reg_rpt, reg_rpt_2;
+	u32		reg_val_tmp;
+	boolean	is_ready = false;
+	u8		i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg_rpt =  0x1f80;
+		reg_rpt_2 = 0x1f98;
+	} else {
+		reg_rpt =  0x9d8;
+		reg_rpt_2 = 0x9f0;
+	}
+
+	for (i = 0; i < 3; i++) {
+		
+		if (odm_get_bb_reg(dm, reg_rpt_2, BIT(31))) { /*Chk HW rpt is ready*/
+			
+			is_ready = true;
+			break;
+		}
+		ODM_delay_ms(1);
+	}
+
+	if (is_ready == false)
+		return;
+
+	/*Get Denumerator*/
+	fahm_denumerator = (u16)odm_get_bb_reg(dm, reg_rpt_2, MASKLWORD);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Reg[0x%x] fahm_denmrtr = %d\n", reg_rpt_2, fahm_denumerator);
+	
+
+	/*Get nemerator*/
+	for (i = 0; i<6; i++) {
+		reg_val_tmp = odm_get_bb_reg(dm, reg_rpt + (i<<2), MASKDWORD);
+		
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Reg[0x%x] fahm_denmrtr = %d\n", reg_rpt + (i*4), reg_val_tmp);
+		
+		fahm_rpt_cnt[i*2] = (u16)(reg_val_tmp & MASKLWORD);
+		fahm_rpt_cnt[i*2 +1] = (u16)((reg_val_tmp & MASKHWORD)>>16);
+	}
+
+	for (i = 0; i<12; i++) {
+		fahm_rpt[i] = phydm_hw_divider(dm, fahm_rpt_cnt[i], fahm_denumerator);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RPT_cnt[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
+		  fahm_rpt_cnt[11], fahm_rpt_cnt[10], fahm_rpt_cnt[9],
+		  fahm_rpt_cnt[8], fahm_rpt_cnt[7], fahm_rpt_cnt[6], 
+		  fahm_rpt_cnt[5], fahm_rpt_cnt[4], fahm_rpt_cnt[3],
+		  fahm_rpt_cnt[2], fahm_rpt_cnt[1], fahm_rpt_cnt[0]);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RPT[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
+		  fahm_rpt[11], fahm_rpt[10], fahm_rpt[9], fahm_rpt[8],
+		  fahm_rpt[7], fahm_rpt[6], 
+		  fahm_rpt[5], fahm_rpt[4], fahm_rpt[3], fahm_rpt[2],
+		  fahm_rpt[1], fahm_rpt[0]);
+	
+}
+
+void
+phydm_fahm_set_th_by_igi(
+	void		*dm_void,
+	u8		igi
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u8	fahm_th[11];
+	u8	rssi_th[11];	/*in RSSI scale*/
+	u8	th_gap = 2 * IGI_TO_NHM_TH_MULTIPLIER;	/*beacuse unit is 0.5dB for FAHM*/
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if (ccx_info->env_mntr_igi == igi) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "No need to update FAHM_th, IGI=0x%x\n", ccx_info->env_mntr_igi);
+		return;
+	}
+
+	ccx_info->env_mntr_igi = igi;	/*bkp IGI*/
+
+	if (igi >= CCA_CAP) 
+		fahm_th[0] = (igi - CCA_CAP) * IGI_TO_NHM_TH_MULTIPLIER;
+	else
+		fahm_th[0] = 0;
+	
+	rssi_th[0] = igi -10 - CCA_CAP;
+	
+	for (i = 1; i <= 10; i++) {
+		fahm_th[i] = fahm_th[0] + th_gap * i;
+		rssi_th[i] = rssi_th[0] +  (i<<1);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RSSI_th[10:0]=[%d, %d, %d, (IGI)%d, %d, %d, %d, %d, %d, %d, %d]\n",
+		  rssi_th[10], rssi_th[9], rssi_th[8], rssi_th[7], rssi_th[6],
+		  rssi_th[5], rssi_th[4], rssi_th[3], rssi_th[2], rssi_th[1],
+		  rssi_th[0]);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		odm_set_bb_reg(dm, R_0x1c38, 0xffffff00, ((fahm_th[2]<<24) |(fahm_th[1]<<16) | (fahm_th[0]<<8)));
+		odm_set_bb_reg(dm, R_0x1c78, 0xffffff00, ((fahm_th[5]<<24) |(fahm_th[4]<<16) | (fahm_th[3]<<8)));
+		odm_set_bb_reg(dm, R_0x1c7c, 0xffffff00, ((fahm_th[7]<<24) |(fahm_th[6]<<16)));
+		odm_set_bb_reg(dm, R_0x1cb8, 0xffffff00, ((fahm_th[10]<<24) |(fahm_th[9]<<16) | (fahm_th[8]<<8)));
+	} else {
+		odm_set_bb_reg(dm, R_0x970, MASKDWORD, ((fahm_th[3]<<24) |(fahm_th[2]<<16) | (fahm_th[1]<<8) | fahm_th[0]));
+		odm_set_bb_reg(dm, R_0x974, MASKDWORD, ((fahm_th[7]<<24) |(fahm_th[6]<<16) | (fahm_th[5]<<8) | fahm_th[4]));
+		odm_set_bb_reg(dm, R_0x978, MASKDWORD, ((fahm_th[10]<<16) | (fahm_th[9]<<8) | fahm_th[8]));
+	}	
+}
+
+void
+phydm_fahm_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u32	fahm_reg1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x\n", dm->dm_dig_table.cur_ig_value);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		fahm_reg1 =  0x994;
+	} else {
+		fahm_reg1 =  0x890;
+	}
+
+	ccx_info->fahm_period = 65535;
+	
+	odm_set_bb_reg(dm, fahm_reg1, 0x6, 3);	/*FAHM HW block enable*/
+	
+	phydm_fahm_set_valid_cnt(dm, FAHM_INCLD_FA, (FAHM_INCLD_FA| FAHM_INCLD_CRC_OK |FAHM_INCLD_CRC_ER));
+	phydm_fahm_set_th_by_igi(dm, dm->dm_dig_table.cur_ig_value);
+}
+
+void
+phydm_fahm_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx_info = &dm->dm_ccx_info;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i;
+
+	for (i = 0; i < 2; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+	}
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "{1: trigger, 2:get result}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "{3: MNTR mode sel} {1: driver, 2. FW}\n");
+		return;
+	} else if (var1[0] == 1) { /* Set & trigger CLM */
+		
+		phydm_fahm_set_th_by_igi(dm, dm->dm_dig_table.cur_ig_value);
+		phydm_fahm_trigger(dm, ccx_info->fahm_period);
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Monitor FAHM for %d * 4us\n",
+			       ccx_info->fahm_period);
+		
+	} else if (var1[0] == 2) { /* Get CLM results */
+
+		phydm_fahm_get_result(dm);
+		PDM_SNPF(out_len, used, output + used, out_len - used,"FAHM_result=%d us\n",
+			       (ccx_info->clm_result<<2));
+
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Error\n");
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif /*#ifdef FAHM_SUPPORT*/
+
+#ifdef NHM_SUPPORT
+
+void
+phydm_nhm_racing_release(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	value32;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "lv:(%d)->(0)\n", ccx->nhm_set_lv);
+	
+	ccx->nhm_ongoing = false;
+	ccx->nhm_set_lv = NHM_RELEASE;
+
+	if (!((ccx->nhm_app == NHM_BACKGROUND) || (ccx->nhm_app == NHM_ACS)))
+		phydm_pause_func(dm, F00_DIG, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, 1, &value32);
+	
+	ccx->nhm_app = NHM_BACKGROUND;
+}
+
+u8
+phydm_nhm_racing_ctrl(
+	void			*dm_void,
+	enum phydm_nhm_level	 nhm_lv
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u8	set_result = PHYDM_SET_SUCCESS;
+	/*acquire to control NHM API*/
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_ongoing=%d, lv:(%d)->(%d)\n", 
+		  ccx->nhm_ongoing, ccx->nhm_set_lv, nhm_lv);
+	if (ccx->nhm_ongoing) {
+		if (nhm_lv <= ccx->nhm_set_lv) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			phydm_ccx_hw_restart(dm);
+			ccx->nhm_ongoing = false;
+		}
+	}
+	
+	if (set_result)
+		ccx->nhm_set_lv = nhm_lv;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm racing success=%d\n", set_result);
+	return set_result;
+}
+
+
+void
+phydm_nhm_trigger(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	nhm_reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? 0x994 : 0x890;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	
+	/*Trigger NHM*/
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 0);
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 1);
+	ccx->nhm_trigger_time = dm->phydm_sys_up_time;
+	ccx->nhm_rpt_stamp++;
+	ccx->nhm_ongoing = true;
+}
+
+boolean
+phydm_nhm_check_rdy(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	boolean	is_ready = false;
+	u32		reg1 = 0, reg1_bit = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 =  0xfb4;
+		reg1_bit = 16;
+	} else {
+		reg1 =  0x8b4;
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			reg1_bit = 25;	
+		} else {
+			reg1_bit = 17;
+		}
+	}
+
+	if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit)))
+		is_ready = true;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM rdy=%d\n", is_ready);
+	return is_ready;
+}
+
+void
+phydm_nhm_get_utility(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	
+	if (ccx->nhm_rpt_sum >= ccx->nhm_result[0])
+		ccx->nhm_ratio = (u8)(((ccx->nhm_rpt_sum - ccx->nhm_result[0]) * 100) >> 8);
+	else {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[warning] nhm_rpt_sum invalid\n");
+		ccx->nhm_ratio = 0;
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_ratio=%d\n", ccx->nhm_ratio);
+}
+
+boolean
+phydm_nhm_get_result(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx = &dm->dm_ccx_info;
+	u32			value32;
+	u8			i;
+	u32	nhm_reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? 0x994 : 0x890;
+	u16	nhm_rpt_sum_tmp = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 0);
+
+	if (phydm_nhm_check_rdy(dm) == false) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM report Fail\n");
+		phydm_nhm_racing_release(dm);
+		return false;
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		value32 = odm_read_4byte(dm, 0xfa8);
+		odm_move_memory(dm, &ccx->nhm_result[0], &value32, 4);
+
+		value32 = odm_read_4byte(dm, 0xfac);
+		odm_move_memory(dm, &ccx->nhm_result[4], &value32, 4);
+
+		value32 = odm_read_4byte(dm, 0xfb0);
+		odm_move_memory(dm, &ccx->nhm_result[8], &value32, 4);
+
+		/*Get NHM duration*/
+		value32 = odm_read_4byte(dm, 0xfb4);
+		ccx->nhm_duration = (u16)(value32 & MASKLWORD);
+	} else {
+		value32 = odm_read_4byte(dm, 0x8d8);
+		odm_move_memory(dm, &ccx->nhm_result[0], &value32, 4);
+
+		value32 = odm_read_4byte(dm, 0x8dc);
+		odm_move_memory(dm, &ccx->nhm_result[4], &value32, 4);
+
+		value32 = odm_get_bb_reg(dm, R_0x8d0, 0xffff0000);
+		odm_move_memory(dm, &ccx->nhm_result[8], &value32, 2);
+
+		value32 = odm_read_4byte(dm, 0x8d4);
+		/*odm_move_memory(dm, &ccx->nhm_result[10], (&value32 + 2), 2);*/
+		ccx->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
+		
+		/*Get NHM duration*/
+		ccx->nhm_duration = (u16)(value32 & MASKLWORD);
+	}
+
+	/* sum all nhm_result */	
+	if (ccx->nhm_period >= 65530) {
+		value32 = (ccx->nhm_duration * 100) >> 16;
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM valid time = %d, valid: %d percent\n", ccx->nhm_duration, value32);
+	}
+
+	for (i = 0; i < NHM_RPT_NUM; i++)
+		nhm_rpt_sum_tmp += (u16)ccx->nhm_result[i];
+
+	ccx->nhm_rpt_sum = (u8)nhm_rpt_sum_tmp;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM_Rpt[%d](H->L)[%d %d %d %d %d %d %d %d %d %d %d %d]\n",
+		ccx->nhm_rpt_stamp,
+		ccx->nhm_result[11], ccx->nhm_result[10], ccx->nhm_result[9],
+		ccx->nhm_result[8], ccx->nhm_result[7], ccx->nhm_result[6],
+		ccx->nhm_result[5], ccx->nhm_result[4], ccx->nhm_result[3],
+		ccx->nhm_result[2], ccx->nhm_result[1], ccx->nhm_result[0]);
+
+	phydm_nhm_racing_release(dm);
+
+	if (nhm_rpt_sum_tmp > 255) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[Warning] Invalid NHM RPT, total=%d\n",
+			  nhm_rpt_sum_tmp);
+		return false;
+	}
+
+	return true;
+}
+
+void
+phydm_nhm_set_th_reg(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	u32	reg1 = 0,  reg2 = 0, reg3 = 0, reg4 = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = 0x994;
+		reg2 = 0x998;
+		reg3 = 0x99c;
+		reg4 = 0x9a0;
+	} else {
+		reg1 = 0x890;
+		reg2 = 0x898;
+		reg3 = 0x89c;
+		reg4 = 0xe28;
+	}
+	
+	/*Set NHM threshold*/ /*Unit: PWdB U(8,1)*/
+	pdm_set_reg(dm, reg2, MASKDWORD, BYTE_2_DWORD(ccx->nhm_th[3], ccx->nhm_th[2], ccx->nhm_th[1], ccx->nhm_th[0]));
+	pdm_set_reg(dm, reg3, MASKDWORD, BYTE_2_DWORD(ccx->nhm_th[7], ccx->nhm_th[6], ccx->nhm_th[5], ccx->nhm_th[4]));
+	pdm_set_reg(dm, reg4, MASKBYTE0, ccx->nhm_th[8]);
+	pdm_set_reg(dm, reg1, 0xffff0000, BYTE_2_DWORD(0, 0, ccx->nhm_th[10], ccx->nhm_th[9]));
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Update NHM_th[H->L]=[%d %d %d %d %d %d %d %d %d %d %d]\n",
+		ccx->nhm_th[10], ccx->nhm_th[9], ccx->nhm_th[8],ccx->nhm_th[7], 
+		ccx->nhm_th[6], ccx->nhm_th[5],ccx->nhm_th[4], ccx->nhm_th[3], 
+		ccx->nhm_th[2], ccx->nhm_th[1], ccx->nhm_th[0]);
+}
+
+boolean
+phydm_nhm_th_update_chk(
+	void		*dm_void,
+	enum nhm_application	nhm_app,
+	u8	*nhm_th,
+	u32	*igi_new
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	boolean	is_update = false;
+	u8	igi_curr = dm->dm_dig_table.cur_ig_value;
+	u8	nhm_igi_th_11k_low[NHM_TH_NUM] = {0x12, 0x15, 0x18, 0x1b, 0x1e, 0x23, 0x28, 0x2c, 0x78, 0x78, 0x78};
+	u8	nhm_igi_th_11k_high[NHM_TH_NUM] = {0x1e, 0x23, 0x28, 0x2d, 0x32, 0x37, 0x78, 0x78, 0x78, 0x78, 0x78};
+	u8	nhm_igi_th_xbox[NHM_TH_NUM] = {0x1a, 0x2c, 0x2e, 0x30, 0x32, 0x34, 0x36, 0x38, 0x3a, 0x3c, 0x3d};
+	u8	i;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "App=%d, nhm_igi=0x%x, igi_curr=0x%x\n", nhm_app, ccx->nhm_igi, igi_curr);
+
+	if (igi_curr < 0x10)/* Protect for invalid IGI*/
+		return	false;
+
+	switch (nhm_app) {
+
+	case NHM_BACKGROUND:	/*Get IGI form driver parameter(cur_ig_value)*/
+	case NHM_ACS:
+		if ((ccx->nhm_igi != igi_curr) || (ccx->nhm_app != nhm_app)) {
+			is_update = true;
+			*igi_new = (u32)igi_curr;
+			nhm_th[0] = (u8)IGI_2_NHM_TH(igi_curr - CCA_CAP);
+			for (i = 1; i <= 10; i++)
+				nhm_th[i] = nhm_th[0] + IGI_2_NHM_TH(2 * i);
+		}
+		break;
+		
+	case IEEE_11K_HIGH:
+		is_update = true;
+		*igi_new = 0x2c;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_11k_high[i]);
+		break;
+		
+	case IEEE_11K_LOW:
+		is_update = true;
+		*igi_new = 0x20;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_11k_low[i]);
+		break;
+		
+	case INTEL_XBOX:
+		is_update = true;
+		*igi_new = 0x36;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_xbox[i]);
+		break;
+		
+	case NHM_DBG:	/*Get IGI form register*/
+		igi_curr = (u8)odm_get_bb_reg(dm, R_0xc50, MASKBYTE0);
+		if ((ccx->nhm_igi != igi_curr) || (ccx->nhm_app != nhm_app)) {
+			is_update = true;
+			*igi_new = (u32)igi_curr;
+			nhm_th[0] = (u8)IGI_2_NHM_TH(igi_curr - CCA_CAP);
+			for (i = 1; i <= 10; i++)
+				nhm_th[i] = nhm_th[0] + IGI_2_NHM_TH(2 * i);
+		}
+		break;
+	}
+
+	if (is_update) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[Update NHM_TH] igi_RSSI=%d\n", 
+			  IGI_2_RSSI(*igi_new));
+		
+		for (i = 0; i < NHM_TH_NUM; i++) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM_th[%d](RSSI) = %d\n",
+				  i, NTH_TH_2_RSSI(nhm_th[i]));
+		}
+	} else {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "No need to update NHM_TH\n");
+	}
+	return is_update;
+}
+
+void
+phydm_nhm_set(
+	void		*dm_void,
+	enum nhm_inexclude_txon_all	include_tx,
+	enum nhm_inexclude_cca_all	include_cca,
+	enum nhm_divider_opt_all	divi_opt,
+	enum nhm_application		nhm_app,
+	u16		period
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	u8	nhm_th[NHM_TH_NUM] = {0};
+	u8	i = 0;
+	u32	igi = 0x20;
+	u32	reg1 = 0, reg2 = 0;
+	u32	val_tmp = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "incld{tx, cca}={%d, %d}, divi_opt=%d, period=%d\n",
+		  include_tx, include_cca, divi_opt, period);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = 0x994;
+		reg2 = 0x990;
+	} else {
+		reg1 = 0x890;
+		reg2 = 0x894;
+	}
+
+	/*Set disable_ignore_cca, disable_ignore_txon, ccx_en*/
+	if ((include_tx != ccx->nhm_include_txon) ||
+		(include_cca != ccx->nhm_include_cca) ||
+		(divi_opt != ccx->nhm_divider_opt)) {
+
+		val_tmp = (u32)BIT_2_BYTE(divi_opt, include_tx, include_cca, 1);
+		pdm_set_reg(dm, reg1, 0xf00, val_tmp);
+
+		ccx->nhm_include_txon = include_tx;
+		ccx->nhm_include_cca = include_cca;
+		ccx->nhm_divider_opt = divi_opt;
+		/*
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "val_tmp=%d, incld{tx, cca}={%d, %d}, divi_opt=%d, period=%d\n",
+		  val_tmp, include_tx, include_cca, divi_opt, period);
+
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "0x994=0x%x\n", odm_get_bb_reg(dm, 0x994, 0xf00));
+		*/
+		
+	}
+	
+	/*Set NHM period*/
+	if (period != ccx->nhm_period) {
+		pdm_set_reg(dm, reg2, MASKHWORD, period);
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Update NHM period ((%d)) -> ((%d))\n",
+			  ccx->nhm_period, period);
+
+		ccx->nhm_period = period;
+	}
+
+	/*Set NHM threshold*/
+	if (phydm_nhm_th_update_chk(dm, nhm_app, &(nhm_th[0]), &igi)) {
+
+		/*Pause IGI*/
+		if ((nhm_app == NHM_BACKGROUND) || (nhm_app == NHM_ACS)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "DIG Free Run\n");
+		} else if (phydm_pause_func(dm, F00_DIG, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, 1, &igi) == PAUSE_FAIL) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pause DIG Fail\n");
+			return;
+		} else {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pause DIG=0x%x\n", igi);
+		}
+		ccx->nhm_app = nhm_app;
+		ccx->nhm_igi = (u8)igi;
+		odm_move_memory(dm, &ccx->nhm_th[0], &nhm_th, NHM_TH_NUM);
+
+		/*Set NHM th*/
+		phydm_nhm_set_th_reg(dm);
+	}
+}
+
+u8
+phydm_nhm_mntr_set(
+	void			*dm_void,
+	struct nhm_para_info	*nhm_para
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16	nhm_time = 0;	/*unit: 4us*/
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (nhm_para->mntr_time == 0)
+		return PHYDM_SET_FAIL;
+
+	if (nhm_para->nhm_lv >= NHM_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Wrong LV=%d\n", nhm_para->nhm_lv);
+		return PHYDM_SET_FAIL;
+	}
+
+	if (phydm_nhm_racing_ctrl(dm, nhm_para->nhm_lv) == PHYDM_SET_FAIL)
+		return PHYDM_SET_FAIL;
+		
+	if (nhm_para->mntr_time >= 262)
+		nhm_time = NHM_PERIOD_MAX;
+	else
+		nhm_time = nhm_para->mntr_time * MS_TO_4US_RATIO;
+
+	phydm_nhm_set(dm, nhm_para->incld_txon, nhm_para->incld_cca, nhm_para->div_opt, nhm_para->nhm_app, nhm_time);
+	
+	return PHYDM_SET_SUCCESS;
+}
+
+/*Environment Monitor*/
+boolean
+phydm_nhm_mntr_chk(
+	void	*dm_void,
+	u16	monitor_time		/*unit ms*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	struct nhm_para_info	nhm_para = {0};
+	boolean			nhm_chk_result = false;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (ccx->nhm_manual_ctrl) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM in manual ctrl\n");
+		return nhm_chk_result;
+	}
+
+	if (ccx->nhm_app != NHM_BACKGROUND && 
+	   ((ccx->nhm_trigger_time + MAX_ENV_MNTR_TIME) > dm->phydm_sys_up_time)) {
+	   
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_app=%d, trigger_time %d, sys_time=%d\n", 
+			  ccx->nhm_app, ccx->nhm_trigger_time, dm->phydm_sys_up_time);
+		
+		return nhm_chk_result;
+	}
+	
+	/*[NHM get result & calculate Utility----------------------------*/	
+	if (phydm_nhm_get_result(dm)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM_rpt success\n");
+		phydm_nhm_get_utility(dm);
+	}
+
+	/*[NHM trigger]-------------------------------------------------*/
+	nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+	nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+	nhm_para.div_opt = NHM_CNT_ALL;
+	nhm_para.nhm_app = NHM_BACKGROUND;
+	nhm_para.nhm_lv	= NHM_LV_1;
+	nhm_para.mntr_time = monitor_time;
+	
+	nhm_chk_result = phydm_nhm_mntr_set(dm, &nhm_para);
+		
+	return nhm_chk_result;
+}
+
+void
+phydm_nhm_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "cur_igi=0x%x\n", dm->dm_dig_table.cur_ig_value);
+
+	ccx->nhm_app = NHM_BACKGROUND;
+	ccx->nhm_igi = 0xff;
+
+	/*Set NHM threshold*/
+	ccx->nhm_ongoing = false;
+	ccx->nhm_set_lv = NHM_RELEASE;
+
+	if (phydm_nhm_th_update_chk(dm, ccx->nhm_app, &(ccx->nhm_th[0]), (u32*)(&ccx->nhm_igi))) {
+		phydm_nhm_set_th_reg(dm);
+	}
+	ccx->nhm_period = 0;
+	
+	ccx->nhm_include_cca = NHM_CCA_INIT;
+	ccx->nhm_include_txon = NHM_TXON_INIT;
+	ccx->nhm_divider_opt = NHM_CNT_INIT;
+	
+	ccx->nhm_manual_ctrl = 0;
+	ccx->nhm_rpt_stamp = 0;
+}
+
+void
+phydm_nhm_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	struct nhm_para_info	nhm_para;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	boolean		nhm_rpt_success = true;
+	u8		i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+	
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "NHM Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "NHM Adv-Trigger: {2} {Include TXON} {Include CCA}\n{0:Cnt_all, 1:Cnt valid} {App} {LV} {0~262ms}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "NHM Get Result: {100}\n");
+	} else if (var1[0] == 100) { /*Get NHM results*/
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "IGI=0x%x, rpt_stamp=%d\n", ccx->nhm_igi, ccx->nhm_rpt_stamp);
+
+		nhm_rpt_success = phydm_nhm_get_result(dm);
+
+		if (nhm_rpt_success) {
+			for (i = 0; i <= 11; i++) {
+				PDM_SNPF(out_len, used, output + used, out_len - used, "nhm_rpt[%d] = %d (%d percent)\n",
+				 	i, ccx->nhm_result[i],
+					 (((ccx->nhm_result[i] * 100) + 128) >> 8));
+			}
+		} else {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Get NHM_rpt Fail\n");
+		}
+		ccx->nhm_manual_ctrl = 0;
+				
+	} else {	/* NMH trigger */
+	
+		ccx->nhm_manual_ctrl = 1;
+
+		if (var1[0] == 1) {
+			nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+			nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+			nhm_para.div_opt = NHM_CNT_ALL;
+			nhm_para.nhm_app = NHM_DBG;
+			nhm_para.nhm_lv = NHM_LV_4;
+			nhm_para.mntr_time = 262;
+		} else {
+			for (i = 1; i < 7; i++) {
+				if (input[i + 1]) {
+					PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				}
+			}
+			nhm_para.incld_txon = (enum nhm_inexclude_txon_all)var1[1];
+			nhm_para.incld_cca = (enum nhm_inexclude_cca_all)var1[2];
+			nhm_para.div_opt = (enum nhm_divider_opt_all)var1[3];
+			nhm_para.nhm_app = (enum nhm_application)var1[4];
+			nhm_para.nhm_lv = (enum phydm_nhm_level)var1[5];
+			nhm_para.mntr_time = (u16)var1[6];
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, " txon=%d, cca=%d, dev=%d, app=%d, lv=%d, time=%d ms\n",
+			nhm_para.incld_txon, nhm_para.incld_cca, 
+			nhm_para.div_opt, nhm_para.nhm_app, nhm_para.nhm_lv,
+			nhm_para.mntr_time);
+		
+		if (phydm_nhm_mntr_set(dm, &nhm_para) == PHYDM_SET_SUCCESS) {
+			phydm_nhm_trigger(dm);
+		}
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "IGI=0x%x, rpt_stamp=%d\n", 
+			ccx->nhm_igi, ccx->nhm_rpt_stamp);
+		
+		for (i = 0; i <= 10; i++) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "NHM_th[%d] RSSI = %d\n",
+				 i, NTH_TH_2_RSSI(ccx->nhm_th[i]));
+		}
+	}
+		
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif	/*#ifdef NHM_SUPPORT*/
+
+#if 1
+
+void
+phydm_set_nhm_th_by_igi(
+	void			*dm_void,
+	u8				igi
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u8	th_gap = 2 * IGI_TO_NHM_TH_MULTIPLIER;
+	u8	i;
+
+	ccx_info->echo_igi = igi;
+	ccx_info->nhm_th[0] = (ccx_info->echo_igi - CCA_CAP) * IGI_TO_NHM_TH_MULTIPLIER;
+	for (i = 1; i <= 10; i++)
+		ccx_info->nhm_th[i] = ccx_info->nhm_th[0] + th_gap * i;
+}
+
+
+
+void
+phydm_nhm_setting(
+	void		*dm_void,
+	u8	nhm_setting
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx_info = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x\n", ccx_info->echo_igi);
+	
+	if (nhm_setting == SET_NHM_SETTING) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+		"NHM_th[H->L]=[0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x]\n",
+		ccx_info->nhm_th[10], ccx_info->nhm_th[9], ccx_info->nhm_th[8],
+		ccx_info->nhm_th[7], ccx_info->nhm_th[6], ccx_info->nhm_th[5],
+		ccx_info->nhm_th[4], ccx_info->nhm_th[3], ccx_info->nhm_th[2],
+		ccx_info->nhm_th[1], ccx_info->nhm_th[0]);
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (nhm_setting == SET_NHM_SETTING) {
+			/*Set inexclude_cca, inexclude_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9), ccx_info->nhm_include_cca);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10), ccx_info->nhm_include_txon);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(11), ccx_info->nhm_divider_opt);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD, ccx_info->nhm_period);
+
+			/*Set NHM threshold*/ /*Unit: PWdB U(8,1)*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0, ccx_info->nhm_th[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1, ccx_info->nhm_th[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2, ccx_info->nhm_th[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3, ccx_info->nhm_th[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0, ccx_info->nhm_th[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1, ccx_info->nhm_th[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2, ccx_info->nhm_th[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3, ccx_info->nhm_th[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0, ccx_info->nhm_th[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2, ccx_info->nhm_th[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3, ccx_info->nhm_th[10]);
+
+			/*CCX EN*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(8), CCX_EN);
+
+		} else if (nhm_setting == STORE_NHM_SETTING) {
+			/*Store pervious disable_ignore_cca, disable_ignore_txon*/
+			ccx_info->nhm_inexclude_cca_restore = (enum nhm_inexclude_cca_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9));
+			ccx_info->nhm_inexclude_txon_restore = (enum nhm_inexclude_txon_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10));
+
+			/*Store pervious NHM period*/
+			ccx_info->nhm_period_restore = (u16)odm_get_bb_reg(dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD);
+
+			/*Store NHM threshold*/
+			ccx_info->nhm_th_restore[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0);
+			ccx_info->nhm_th_restore[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1);
+			ccx_info->nhm_th_restore[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2);
+			ccx_info->nhm_th_restore[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3);
+			ccx_info->nhm_th_restore[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0);
+			ccx_info->nhm_th_restore[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1);
+			ccx_info->nhm_th_restore[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2);
+			ccx_info->nhm_th_restore[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3);
+			ccx_info->nhm_th_restore[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0);
+			ccx_info->nhm_th_restore[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2);
+			ccx_info->nhm_th_restore[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3);
+		} else if (nhm_setting == RESTORE_NHM_SETTING) {
+			/*Set disable_ignore_cca, disable_ignore_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9), ccx_info->nhm_inexclude_cca_restore);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10), ccx_info->nhm_inexclude_txon_restore);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD, ccx_info->nhm_period);
+
+			/*Set NHM threshold*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0, ccx_info->nhm_th_restore[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1, ccx_info->nhm_th_restore[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2, ccx_info->nhm_th_restore[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3, ccx_info->nhm_th_restore[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0, ccx_info->nhm_th_restore[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1, ccx_info->nhm_th_restore[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2, ccx_info->nhm_th_restore[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3, ccx_info->nhm_th_restore[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0, ccx_info->nhm_th_restore[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2, ccx_info->nhm_th_restore[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3, ccx_info->nhm_th_restore[10]);
+		} else
+			return;
+	}
+
+	else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (nhm_setting == SET_NHM_SETTING) {
+			/*Set disable_ignore_cca, disable_ignore_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9), ccx_info->nhm_include_cca);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10), ccx_info->nhm_include_txon);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(11), ccx_info->nhm_divider_opt);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD, ccx_info->nhm_period);
+
+			/*Set NHM threshold*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0, ccx_info->nhm_th[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1, ccx_info->nhm_th[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2, ccx_info->nhm_th[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3, ccx_info->nhm_th[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0, ccx_info->nhm_th[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1, ccx_info->nhm_th[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2, ccx_info->nhm_th[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3, ccx_info->nhm_th[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0, ccx_info->nhm_th[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2, ccx_info->nhm_th[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3, ccx_info->nhm_th[10]);
+
+			/*CCX EN*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(8), CCX_EN);
+		} else if (nhm_setting == STORE_NHM_SETTING) {
+			/*Store pervious disable_ignore_cca, disable_ignore_txon*/
+			ccx_info->nhm_inexclude_cca_restore = (enum nhm_inexclude_cca_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9));
+			ccx_info->nhm_inexclude_txon_restore = (enum nhm_inexclude_txon_all)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10));
+
+			/*Store pervious NHM period*/
+			ccx_info->nhm_period_restore = (u16)odm_get_bb_reg(dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD);
+
+			/*Store NHM threshold*/
+			ccx_info->nhm_th_restore[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0);
+			ccx_info->nhm_th_restore[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1);
+			ccx_info->nhm_th_restore[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2);
+			ccx_info->nhm_th_restore[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3);
+			ccx_info->nhm_th_restore[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0);
+			ccx_info->nhm_th_restore[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1);
+			ccx_info->nhm_th_restore[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2);
+			ccx_info->nhm_th_restore[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3);
+			ccx_info->nhm_th_restore[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0);
+			ccx_info->nhm_th_restore[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2);
+			ccx_info->nhm_th_restore[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3);
+
+		} else if (nhm_setting == RESTORE_NHM_SETTING) {
+			/*Set disable_ignore_cca, disable_ignore_txon*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9), ccx_info->nhm_inexclude_cca_restore);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10), ccx_info->nhm_inexclude_txon_restore);
+
+			/*Set NHM period*/
+			odm_set_bb_reg(dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD, ccx_info->nhm_period_restore);
+
+			/*Set NHM threshold*/
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0, ccx_info->nhm_th_restore[0]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1, ccx_info->nhm_th_restore[1]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2, ccx_info->nhm_th_restore[2]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3, ccx_info->nhm_th_restore[3]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0, ccx_info->nhm_th_restore[4]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1, ccx_info->nhm_th_restore[5]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2, ccx_info->nhm_th_restore[6]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3, ccx_info->nhm_th_restore[7]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0, ccx_info->nhm_th_restore[8]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2, ccx_info->nhm_th_restore[9]);
+			odm_set_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3, ccx_info->nhm_th_restore[10]);
+		} else
+			return;
+
+	}
+}
+
+void
+phydm_get_nhm_result(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u32			value32;
+	u8			i;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11AC);
+		ccx_info->nhm_result[0] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[1] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[2] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[3] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
+		ccx_info->nhm_result[4] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[5] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[6] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[7] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT11_TO_CNT8_11AC);
+		ccx_info->nhm_result[8] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[9] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		/*Get NHM duration*/
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_DUR_READY_11AC);
+		ccx_info->nhm_duration = (u16)(value32 & MASKLWORD);
+
+	}
+
+	else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT_11N);
+		ccx_info->nhm_result[0] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[1] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[2] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[3] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
+		ccx_info->nhm_result[4] = (u8)(value32 & MASKBYTE0);
+		ccx_info->nhm_result[5] = (u8)((value32 & MASKBYTE1) >> 8);
+		ccx_info->nhm_result[6] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[7] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT9_TO_CNT8_11N);
+		ccx_info->nhm_result[8] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[9] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT10_TO_CNT11_11N);
+		ccx_info->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx_info->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
+
+		/*Get NHM duration*/
+		value32 = odm_read_4byte(dm, ODM_REG_NHM_CNT10_TO_CNT11_11N);
+		ccx_info->nhm_duration = (u16)(value32 & MASKLWORD);
+
+	}
+
+	/* sum all nhm_result */
+	ccx_info->nhm_rpt_sum = 0;
+	for (i = 0; i <= 11; i++)
+		ccx_info->nhm_rpt_sum += ccx_info->nhm_result[i];
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+	"NHM_result=(H->L)[%d %d %d %d (igi) %d %d %d %d %d %d %d %d]\n",
+		ccx_info->nhm_result[11], ccx_info->nhm_result[10], ccx_info->nhm_result[9],
+		ccx_info->nhm_result[8], ccx_info->nhm_result[7], ccx_info->nhm_result[6],
+		ccx_info->nhm_result[5], ccx_info->nhm_result[4], ccx_info->nhm_result[3],
+		ccx_info->nhm_result[2], ccx_info->nhm_result[1], ccx_info->nhm_result[0]);
+
+}
+
+boolean
+phydm_check_nhm_rdy(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			i;
+	boolean			is_ready = false;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (odm_get_bb_reg(dm, ODM_REG_NHM_DUR_READY_11AC, BIT(16)))
+			is_ready = 1;
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			if (odm_get_bb_reg(dm, R_0x8b4, BIT(25)))
+				is_ready = 1;
+		} else {
+			if (odm_get_bb_reg(dm, R_0x8b4, BIT(17)))
+				is_ready = 1;
+		}
+	}
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM rdy=%d\n", is_ready);
+	return is_ready;
+}
+
+void
+phydm_ccx_monitor_trigger(
+	void			*dm_void,
+	u16			monitor_time		/*unit ms*/
+)
+{
+	u8			nhm_th[11], i, igi;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u16 	monitor_time_4us = 0;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+
+	if (monitor_time == 0)
+		return;
+
+	if (monitor_time >= 262)
+		monitor_time_4us = 65534;
+	else
+		monitor_time_4us = monitor_time * MS_TO_4US_RATIO;
+
+	/* check if NHM threshold is changed */
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		nhm_th[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0);
+		nhm_th[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1);
+		nhm_th[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2);
+		nhm_th[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3);
+		nhm_th[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0);
+		nhm_th[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1);
+		nhm_th[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2);
+		nhm_th[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3);
+		nhm_th[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0);
+		nhm_th[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2);
+		nhm_th[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3);
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		
+		nhm_th[0] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0);
+		nhm_th[1] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1);
+		nhm_th[2] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2);
+		nhm_th[3] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3);
+		nhm_th[4] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0);
+		nhm_th[5] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1);
+		nhm_th[6] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2);
+		nhm_th[7] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3);
+		nhm_th[8] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH8_11N, MASKBYTE0);
+		nhm_th[9] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2);
+		nhm_th[10] = (u8)odm_get_bb_reg(dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3);
+	}
+
+	for (i = 0; i <= 10; i++) {
+		
+		if (nhm_th[i] != ccx_info->nhm_th[i]) {	
+			PHYDM_DBG(dm, DBG_ENV_MNTR,
+				"nhm_th[%d] != ccx_info->nhm_th[%d]!!\n", i, i);
+		}
+	}
+	/*[NHM]*/
+	igi = (u8)odm_get_bb_reg(dm, R_0xc50, MASKBYTE0);
+	phydm_set_nhm_th_by_igi(dm, igi);
+
+	ccx_info->nhm_period = monitor_time_4us;
+	ccx_info->nhm_include_cca = NHM_EXCLUDE_CCA;
+	ccx_info->nhm_include_txon = NHM_EXCLUDE_TXON;
+	ccx_info->nhm_divider_opt = NHM_CNT_ALL;
+
+	phydm_nhm_setting(dm, SET_NHM_SETTING);
+	phydm_nhm_trigger(dm);
+
+	/*[CLM]*/
+	ccx_info->clm_period = monitor_time_4us;
+	
+	if (ccx_info->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		phydm_clm_setting(dm, ccx_info->clm_period);
+		phydm_clm_trigger(dm);
+	} else if (ccx_info->clm_mntr_mode == CLM_FW_MNTR){
+		phydm_clm_h2c(dm, monitor_time_4us, true);
+	}
+
+}
+
+void
+phydm_ccx_monitor_result(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u32					clm_result_tmp = 0;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "%s ======>\n", __func__);
+
+	if (phydm_check_nhm_rdy(dm)) {
+		phydm_get_nhm_result(dm);
+
+		if (ccx_info->nhm_rpt_sum != 0)
+			ccx_info->nhm_ratio  = (u8)(((ccx_info->nhm_rpt_sum - ccx_info->nhm_result[0])*100) >> 8);
+	}
+
+	if (ccx_info->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		
+		if (!phydm_clm_check_rdy(dm))
+			goto out;
+
+		phydm_clm_get_result(dm);
+
+		if (ccx_info->clm_period != 0) {
+			if (ccx_info->clm_period == 64000)
+				ccx_info->clm_ratio = (u8)(((ccx_info->clm_result >> 6) + 5) /10);
+			else if (ccx_info->clm_period == 65535) {
+				clm_result_tmp = (u32)(ccx_info->clm_result * 100);
+				ccx_info->clm_ratio = (u8)((clm_result_tmp + (1<<15)) >> 16);
+			} else
+				ccx_info->clm_ratio = (u8)((ccx_info->clm_result*100) / ccx_info->clm_period);
+		}
+
+	} else {
+		if (ccx_info->clm_fw_result_cnt != 0)
+			ccx_info->clm_ratio = (u8)(ccx_info->clm_fw_result_acc /ccx_info->clm_fw_result_cnt);
+		else
+			ccx_info->clm_ratio = 0;
+
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+			ccx_info->clm_fw_result_acc, ccx_info->clm_fw_result_cnt);
+		
+		ccx_info->clm_fw_result_acc = 0;
+		ccx_info->clm_fw_result_cnt = 0;
+	}
+
+out:
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x, nhm_ratio=%d, clm_ratio=%d\n\n",
+		ccx_info->echo_igi, ccx_info->nhm_ratio, ccx_info->clm_ratio);
+		
+}
+
+
+#endif
+
+
+#ifdef CLM_SUPPORT
+
+void
+phydm_clm_racing_release(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	value32;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "lv:(%d)->(0)\n", ccx->clm_set_lv);
+	
+	ccx->clm_ongoing = false;
+	ccx->clm_set_lv = CLM_RELEASE;
+	ccx->clm_app = CLM_BACKGROUND;
+}
+
+u8
+phydm_clm_racing_ctrl(
+	void			*dm_void,
+	enum phydm_nhm_level	 clm_lv
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u8	set_result = PHYDM_SET_SUCCESS;
+	/*acquire to control CLM API*/
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_ongoing=%d, lv:(%d)->(%d)\n", 
+		  ccx->clm_ongoing, ccx->clm_set_lv, clm_lv);
+	if (ccx->clm_ongoing) {
+		if (clm_lv <= ccx->clm_set_lv) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			phydm_ccx_hw_restart(dm);
+			ccx->clm_ongoing = false;
+		}
+	}
+	
+	if (set_result)
+		ccx->clm_set_lv = clm_lv;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm racing success=%d\n", set_result);
+	return set_result;
+}
+
+
+void
+phydm_clm_c2h_report_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	u8	clm_report = cmd_buf[0];
+	u8	clm_report_idx = cmd_buf[1];
+
+	if (cmd_len >=12)
+		return;
+	
+	ccx_info->clm_fw_result_acc += clm_report;
+	ccx_info->clm_fw_result_cnt++;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%d] clm_report= %d\n", ccx_info->clm_fw_result_cnt, clm_report);
+	
+}
+
+void
+phydm_clm_h2c(
+	void	*dm_void,
+	u16	obs_time,
+	u8	fw_clm_en
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8		h2c_val[H2C_MAX_LENGTH] = {0};
+	u8		i = 0;
+	u8		obs_time_idx = 0;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "obs_time_index=%d *4 us\n", obs_time);
+
+	for (i =1; i<=16; i++) {
+		if (obs_time & BIT(16 -i)) {
+			obs_time_idx = 16-i;
+			break;
+		}
+	}
+	
+	/*
+	obs_time =(2^16 -1) ~ (2^15)  => obs_time_idx = 15  (65535 ~ 32768)
+	obs_time =(2^15 -1) ~ (2^14)  => obs_time_idx = 14
+	...
+	...
+	...
+	obs_time =(2^1 -1) ~ (2^0)  => obs_time_idx = 0
+
+	*/
+
+	h2c_val[0] = obs_time_idx | (((fw_clm_en) ? 1 : 0)<< 7);
+	h2c_val[1] = CLM_MAX_REPORT_TIME;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "PHYDM h2c[0x4d]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_FW_CLM_MNTR, H2C_MAX_LENGTH, h2c_val);
+
+}
+
+void
+phydm_clm_setting(
+	void			*dm_void,
+	u16			clm_period	/*4us sample 1 time*/
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+
+	if (ccx->clm_period != clm_period) {
+
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, R_0x990, MASKLWORD, clm_period);
+
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			odm_set_bb_reg(dm, R_0x894, MASKLWORD, clm_period);
+		}
+
+		ccx->clm_period = clm_period;
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Update CLM period ((%d)) -> ((%d))\n",
+			  ccx->clm_period, clm_period);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Set CLM period=%d * 4us\n", ccx->clm_period);
+
+}
+
+void
+phydm_clm_trigger(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? R_0x994 : R_0x890;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x0);
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x1);
+
+	ccx->clm_trigger_time = dm->phydm_sys_up_time;
+	ccx->clm_rpt_stamp++;
+	ccx->clm_ongoing = true;
+}
+
+boolean
+phydm_clm_check_rdy(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean			is_ready = false;
+	u32			reg1 = 0, reg1_bit = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = ODM_REG_CLM_RESULT_11AC;
+		reg1_bit = 16;
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			reg1 = R_0x8b4;
+			reg1_bit = 24;
+		} else {
+			reg1 = R_0x8b4;
+			reg1_bit = 16;
+		}
+	}
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM rdy=%d\n", is_ready);
+	return is_ready;
+}
+
+void
+phydm_clm_get_utility(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32	clm_result_tmp;
+
+	if (ccx->clm_period == 0) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[warning] clm_period = 0\n");
+		ccx->clm_ratio = 0;
+	} else if (ccx->clm_period >= 65530) {
+		clm_result_tmp = (u32)(ccx->clm_result * 100);
+		ccx->clm_ratio = (u8)((clm_result_tmp + (1<<15)) >> 16);
+	} else
+		ccx->clm_ratio = (u8)((ccx->clm_result*100) / ccx->clm_period);
+}
+
+boolean
+phydm_clm_get_result(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+	u32	reg1 = (dm->support_ic_type & ODM_IC_11AC_SERIES) ? R_0x994 : R_0x890;
+
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x0);
+	if (phydm_clm_check_rdy(dm) == false) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM report Fail\n");
+		phydm_clm_racing_release(dm);
+		return false;
+	}
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		ccx_info->clm_result = (u16)odm_get_bb_reg(dm, R_0xfa4, MASKLWORD);
+	else if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		ccx_info->clm_result = (u16)odm_get_bb_reg(dm, R_0x8d0, MASKLWORD);
+
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM result = %d *4 us\n", ccx_info->clm_result);
+	phydm_clm_racing_release(dm);
+	return true;
+}
+
+void
+phydm_clm_mntr_fw(
+	void	*dm_void,
+	u16	monitor_time	/*unit ms*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u32			clm_result_tmp = 0;
+
+	/*[Get CLM report]*/
+	if (ccx->clm_fw_result_cnt != 0)
+		ccx->clm_ratio = (u8)(ccx->clm_fw_result_acc /ccx->clm_fw_result_cnt);
+	else
+		ccx->clm_ratio = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+		ccx->clm_fw_result_acc, ccx->clm_fw_result_cnt);
+	
+	ccx->clm_fw_result_acc = 0;
+	ccx->clm_fw_result_cnt = 0;
+	
+
+	/*[CLM trigger]*/
+	if (monitor_time >= 262)
+		ccx->clm_period = 65535;
+	else
+		ccx->clm_period = monitor_time * MS_TO_4US_RATIO;
+	
+	phydm_clm_h2c(dm, monitor_time, true);
+
+}
+
+u8
+phydm_clm_mntr_set(
+	void	*dm_void,
+	struct	clm_para_info	*clm_para
+)
+{
+	/*Driver Monitor CLM*/
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u16			clm_period = 0;
+
+	
+	if (clm_para->mntr_time == 0)
+		return PHYDM_SET_FAIL;
+
+	if (clm_para->clm_lv >= CLM_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[WARNING] Wrong LV=%d\n", clm_para->clm_lv);
+		return PHYDM_SET_FAIL;
+	}
+
+	if (phydm_clm_racing_ctrl(dm, clm_para->clm_lv) == PHYDM_SET_FAIL)
+		return PHYDM_SET_FAIL;
+	
+	if (clm_para->mntr_time >= 262)
+		clm_period = CLM_PERIOD_MAX;
+	else
+		clm_period = clm_para->mntr_time * MS_TO_4US_RATIO;
+
+	ccx->clm_app = clm_para->clm_app;
+	phydm_clm_setting(dm, clm_period);
+	
+	return PHYDM_SET_SUCCESS;
+}
+
+boolean
+phydm_clm_mntr_chk(
+	void	*dm_void,
+	u16	monitor_time	/*unit ms*/
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	struct clm_para_info	clm_para = {0};
+	u32			clm_result_tmp = 0;
+	boolean			clm_chk_result = false;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+
+	if (ccx->clm_manual_ctrl) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM in manual ctrl\n");
+		return clm_chk_result;
+	}
+
+	if ((ccx->clm_app != CLM_BACKGROUND) &&
+	    (ccx->clm_trigger_time + MAX_ENV_MNTR_TIME) > dm->phydm_sys_up_time) {
+	   
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "trigger_time %d, sys_time=%d\n", 
+			  ccx->clm_trigger_time, dm->phydm_sys_up_time);
+		
+		return clm_chk_result;
+	}
+	
+	clm_para.clm_app = CLM_BACKGROUND;
+	clm_para.clm_lv	= CLM_LV_1;
+	clm_para.mntr_time = monitor_time;
+	
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		
+		/*[Get CLM report]*/
+		if (phydm_clm_get_result(dm)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM_rpt success\n");
+			phydm_clm_get_utility(dm);
+		}
+
+		/*[CLM trigger]-------------------------------------------------*/
+		if (phydm_clm_mntr_set(dm, &clm_para) == PHYDM_SET_SUCCESS) {
+			clm_chk_result = true;
+		}
+	} else {
+		phydm_clm_mntr_fw(dm, monitor_time);
+	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_ratio=%d\n", ccx->clm_ratio);
+	return clm_chk_result;
+}
+
+void
+phydm_set_clm_mntr_mode(
+	void			*dm_void,
+	enum clm_monitor_mode mode
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx_info = &dm->dm_ccx_info;
+
+	if (ccx_info->clm_mntr_mode != mode) {
+		
+		ccx_info->clm_mntr_mode = mode;
+		phydm_ccx_hw_restart(dm);
+
+		if (mode == CLM_DRIVER_MNTR)
+			phydm_clm_h2c(dm,0, 0);
+	}
+}
+
+void
+phydm_clm_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	
+	ccx->clm_ongoing = false;
+	ccx->clm_manual_ctrl = 0;
+	ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+	ccx->clm_period = 0;
+	ccx->clm_rpt_stamp = 0;
+	phydm_clm_setting(dm, 65535);
+}
+
+void
+phydm_clm_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	struct clm_para_info	clm_para = {0};
+	u32		i;
+
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+	}
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM Driver Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM Driver Adv-Trigger: {2} {app} {LV} {0~262ms}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM FW Trigger: {3}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "CLM Get Result: {100}\n");
+	} else if (var1[0] == 100) { /* Get CLM results */
+
+		if (phydm_clm_get_result(dm)) {
+			phydm_clm_get_utility(dm);
+		}
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "clm_rpt_stamp=%d\n",
+			 ccx->clm_rpt_stamp);
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "clm_ratio:((%d percent)) = (%d us/ %d us)\n",
+			ccx->clm_ratio, ccx->clm_result<<2, ccx->clm_period<<2);
+		
+		ccx->clm_manual_ctrl = 0;
+		
+	} else { /* Set & trigger CLM */
+		ccx->clm_manual_ctrl = 1;
+		
+		if (var1[0] == 1) {
+			clm_para.clm_app = CLM_BACKGROUND;
+			clm_para.clm_lv	= CLM_LV_4;
+			clm_para.mntr_time = 262;
+			ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+			
+		} else if (var1[0] == 2) {
+			clm_para.clm_app = (enum clm_application )var1[1];
+			clm_para.clm_lv	= (enum phydm_clm_level )var1[2];
+			ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+			clm_para.mntr_time = (u16)var1[3];
+			
+		} else if (var1[0] == 3) {
+			clm_para.clm_app = CLM_BACKGROUND;
+			clm_para.clm_lv	= CLM_LV_4;
+			ccx->clm_mntr_mode = CLM_FW_MNTR;
+			clm_para.mntr_time = 262;
+		}
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used, "app=%d, lv=%d, mode=%s, time=%d ms\n",
+			  clm_para.clm_app, clm_para.clm_lv, 
+			  ((ccx->clm_mntr_mode == CLM_FW_MNTR) ? "FW" : "driver"),
+			  clm_para.mntr_time);
+		
+		if (phydm_clm_mntr_set(dm, &clm_para) == PHYDM_SET_SUCCESS) {
+			phydm_clm_trigger(dm);
+			/**/
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "clm_rpt_stamp=%d\n",
+			 ccx->clm_rpt_stamp);
+		
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif	/*#ifdef CLM_SUPPORT*/
+
+u8
+phydm_env_mntr_trigger(
+	void			*dm_void,
+	struct	nhm_para_info	*nhm_para,
+	struct	clm_para_info	*clm_para,
+	struct	env_trig_rpt	*trig_rpt
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	boolean			nhm_set_ok = false;
+	boolean			clm_set_ok = false;
+	u8			trigger_result = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	/*[NHM]*/
+	nhm_set_ok = phydm_nhm_mntr_set(dm, nhm_para);
+	
+	/*[CLM]*/
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		clm_set_ok = phydm_clm_mntr_set(dm, clm_para);
+	} else if (ccx->clm_mntr_mode == CLM_FW_MNTR){
+		phydm_clm_h2c(dm, CLM_PERIOD_MAX, true);
+		trigger_result |= CLM_SUCCESS;
+	}
+
+	if (nhm_set_ok) {
+		phydm_nhm_trigger(dm);
+		trigger_result |= NHM_SUCCESS;
+	}
+	
+	if (clm_set_ok) {
+		phydm_clm_trigger(dm);
+		trigger_result |= CLM_SUCCESS;
+	}
+
+	trig_rpt->nhm_rpt_stamp = ccx->nhm_rpt_stamp;
+	trig_rpt->clm_rpt_stamp = ccx->clm_rpt_stamp;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_rpt_stamp=%d, clm_rpt_stamp=%d,\n\n",
+		  trig_rpt->nhm_rpt_stamp, trig_rpt->clm_rpt_stamp);
+
+	return trigger_result;
+#endif
+}
+
+u8
+phydm_env_mntr_result(
+	void			*dm_void,
+	struct	env_mntr_rpt	*rpt
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	u8			env_mntr_rpt = 0;
+	u32			clm_result_tmp = 0;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	/*Get NHM result*/
+	if (phydm_nhm_get_result(dm)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM_rpt success\n");
+		phydm_nhm_get_utility(dm);
+		rpt->nhm_ratio = ccx->nhm_ratio;
+		env_mntr_rpt |= NHM_SUCCESS;
+		odm_move_memory(dm, &rpt->nhm_result[0], &ccx->nhm_result[0], NHM_RPT_NUM);
+	} else {
+		rpt->nhm_ratio = ENV_MNTR_FAIL;
+	}
+	
+	/*Get CLM result*/
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		
+		if (phydm_clm_get_result(dm)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM_rpt success\n");
+			phydm_clm_get_utility(dm);
+			env_mntr_rpt |= CLM_SUCCESS;
+			rpt->clm_ratio = ccx->clm_ratio;
+		} else {
+			rpt->clm_ratio = ENV_MNTR_FAIL;
+		}
+
+	} else {
+		if (ccx->clm_fw_result_cnt != 0)
+			ccx->clm_ratio = (u8)(ccx->clm_fw_result_acc /ccx->clm_fw_result_cnt);
+		else
+			ccx->clm_ratio = 0;
+
+		rpt->clm_ratio = ccx->clm_ratio;
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+			ccx->clm_fw_result_acc, ccx->clm_fw_result_cnt);
+		
+		ccx->clm_fw_result_acc = 0;
+		ccx->clm_fw_result_cnt = 0;
+		env_mntr_rpt |= CLM_SUCCESS;
+	}
+
+	rpt->nhm_rpt_stamp = ccx->nhm_rpt_stamp;
+	rpt->clm_rpt_stamp = ccx->clm_rpt_stamp;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x, nhm_ratio=%d, clm_ratio=%d, nhm_rpt_stamp=%d, clm_rpt_stamp=%d\n\n",
+		ccx->nhm_igi, rpt->nhm_ratio, rpt->clm_ratio, rpt->nhm_rpt_stamp, rpt->clm_rpt_stamp);
+	
+	return env_mntr_rpt;
+#endif
+}
+
+/*Environment Monitor*/
+void
+phydm_env_mntr_watchdog(
+	void	*dm_void
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info		*ccx = &dm->dm_ccx_info;
+	boolean			nhm_chk_ok = false;
+	boolean			clm_chk_ok = false;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	nhm_chk_ok = phydm_nhm_mntr_chk(dm, 262);/*monitor 262ms*/
+	clm_chk_ok = phydm_clm_mntr_chk(dm, 262); /*monitor 262ms*/
+
+	if (nhm_chk_ok)
+		phydm_nhm_trigger(dm);
+	
+	if (clm_chk_ok)
+		phydm_clm_trigger(dm);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Summary: nhm_ratio=((%d)) clm_ratio=((%d))\n\n",
+		  ccx->nhm_ratio, ccx->clm_ratio);
+#endif
+}
+
+
+void
+phydm_env_monitor_init(
+	void			*dm_void
+)
+{
+#if(defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __FUNCTION__);
+	
+	phydm_ccx_hw_restart(dm);
+	phydm_nhm_init(dm);
+	phydm_clm_init(dm);
+#endif
+}
+
+void
+phydm_env_mntr_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ccx_info	*ccx = &dm->dm_ccx_info;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	struct clm_para_info	clm_para = {0};
+	struct nhm_para_info	nhm_para = {0};
+	struct env_mntr_rpt	rpt = {0};
+	struct env_trig_rpt	trig_rpt = {0};
+	u8		set_result;
+	u8		i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Get Result: {100}\n");
+	} else if (var1[0] == 100) { /* Get CLM results */
+
+		set_result = phydm_env_mntr_result(dm, &rpt);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Set Result=%d\n nhm_ratio=%d clm_ratio=%d\n nhm_rpt_stamp=%d, clm_rpt_stamp=%d, \n", 
+			set_result, rpt.nhm_ratio, rpt.clm_ratio, rpt.nhm_rpt_stamp, rpt.clm_rpt_stamp);
+
+		for (i = 0; i <= 11; i++) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "nhm_rpt[%d] = %d (%d percent)\n",
+			 	i, rpt.nhm_result[i],
+				 (((rpt.nhm_result[i] * 100) + 128) >> 8));
+		}
+		
+	} else { /* Set & trigger CLM */
+		/*nhm para*/
+		nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+		nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+		nhm_para.div_opt = NHM_CNT_ALL;
+		nhm_para.nhm_app = NHM_ACS;
+		nhm_para.nhm_lv	= NHM_LV_2;
+		nhm_para.mntr_time = 262;
+		
+		/*clm para*/
+		clm_para.clm_app = CLM_ACS;
+		clm_para.clm_lv	= CLM_LV_2;
+		clm_para.mntr_time = 262;
+
+		set_result = phydm_env_mntr_trigger(dm, &nhm_para, &clm_para, &trig_rpt);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Set Result=%d, nhm_rpt_stamp=%d, clm_rpt_stamp=%d\n", 
+			set_result, trig_rpt.nhm_rpt_stamp, trig_rpt.clm_rpt_stamp);
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_ccx.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_ccx.h
new file mode 100644
index 000000000000..f006f8f23072
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_ccx.h
@@ -0,0 +1,385 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMCCX_H__
+#define	__PHYDMCCX_H__
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define CCX_EN 1
+
+#define	MAX_ENV_MNTR_TIME	8	/*second*/
+#define	IGI_TO_NHM_TH_MULTIPLIER 2
+#define	MS_TO_4US_RATIO		250
+#define	CCA_CAP			14
+#define	CLM_MAX_REPORT_TIME	10
+#define	DEVIDER_ERROR		0xffff
+#define CLM_PERIOD_MAX		65535
+#define NHM_PERIOD_MAX		65534
+#define	NHM_TH_NUM		11	/*threshold number of NHM*/
+#define	NHM_RPT_NUM		12
+
+#define	IGI_2_NHM_TH(igi)	((igi) << 1)/*NHM_threshold = IGI * 2*/
+#define	NTH_TH_2_RSSI(th)	((th >> 1) - 10)
+
+/*FAHM*/
+#define	FAHM_INCLD_FA		BIT(0)
+#define	FAHM_INCLD_CRC_OK	BIT(1)
+#define	FAHM_INCLD_CRC_ER	BIT(2)
+
+#define NHM_SUCCESS		BIT(0)
+#define CLM_SUCCESS		BIT(1)
+#define FAHM_SUCCESS		BIT(2)
+#define	ENV_MNTR_FAIL		0xff
+
+/* 1 ============================================================
+ * 1 enumrate
+ * 1 ============================================================ */
+enum phydm_clm_level {
+	CLM_RELEASE 		= 0,
+	CLM_LV_1		= 1,	/* Low Priority function */
+	CLM_LV_2		= 2,	/* Middle Priority function */
+	CLM_LV_3		= 3,	/* High priority function (ex: Check hang function) */
+	CLM_LV_4		= 4,	/* Debug function (the highest priority) */
+	CLM_MAX_NUM 		= 5
+};
+
+enum phydm_nhm_level {
+	NHM_RELEASE 		= 0,
+	NHM_LV_1		= 1,	/* Low Priority function */
+	NHM_LV_2		= 2,	/* Middle Priority function */
+	NHM_LV_3		= 3,	/* High priority function (ex: Check hang function) */
+	NHM_LV_4		= 4,	/* Debug function (the highest priority) */
+	NHM_MAX_NUM 		= 5
+};
+
+enum nhm_divider_opt_all {
+	NHM_CNT_ALL		= 0,	/*nhm SUM report <= 255*/
+	NHM_VALID		= 1,	/*nhm SUM report = 255*/
+	NHM_CNT_INIT
+};
+
+enum nhm_setting {
+	SET_NHM_SETTING,
+	STORE_NHM_SETTING,
+	RESTORE_NHM_SETTING
+};
+
+enum nhm_inexclude_cca_all {
+	NHM_EXCLUDE_CCA		= 0,
+	NHM_INCLUDE_CCA		= 1,
+	NHM_CCA_INIT
+};
+
+enum nhm_inexclude_txon_all {
+	NHM_EXCLUDE_TXON	= 0,
+	NHM_INCLUDE_TXON	= 1,
+	NHM_TXON_INIT
+};
+
+enum nhm_application {
+	NHM_BACKGROUND		= 0,/*default*/
+	NHM_ACS			= 1,
+	IEEE_11K_HIGH		= 2,
+	IEEE_11K_LOW		= 3,
+	INTEL_XBOX		= 4,
+	NHM_DBG			= 5, /*manual trigger*/
+};
+
+enum clm_application {
+	CLM_BACKGROUND		= 0,/*default*/
+	CLM_ACS			= 1,
+};
+
+enum clm_monitor_mode {
+	CLM_DRIVER_MNTR		= 1,
+	CLM_FW_MNTR		= 2
+};
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+struct env_trig_rpt {
+	u8			nhm_rpt_stamp;
+	u8			clm_rpt_stamp;
+};
+
+
+struct env_mntr_rpt {
+	u8			nhm_ratio;
+	u8			nhm_result[NHM_RPT_NUM];
+	u8			clm_ratio;
+	u8			nhm_rpt_stamp;
+	u8			clm_rpt_stamp;
+};
+
+struct nhm_para_info {
+	enum nhm_inexclude_txon_all	incld_txon;	/*Include TX on*/
+	enum nhm_inexclude_cca_all	incld_cca;	/*Include CCA*/
+	enum nhm_divider_opt_all	div_opt;	/*divider option*/
+	enum nhm_application		nhm_app;
+	enum phydm_nhm_level 		nhm_lv;
+	u16				mntr_time;	/*0~262 unit ms*/
+	
+};
+
+struct clm_para_info {
+	enum clm_application		clm_app;
+	enum phydm_clm_level 		clm_lv;
+	u16				mntr_time;	/*0~262 unit ms*/
+};
+
+struct ccx_info {
+	u32			nhm_trigger_time;
+	u32			clm_trigger_time;
+#ifdef NHM_SUPPORT
+	enum nhm_application		nhm_app;
+	enum nhm_inexclude_txon_all	nhm_include_txon;
+	enum nhm_inexclude_cca_all	nhm_include_cca;
+	enum nhm_divider_opt_all 	nhm_divider_opt;
+	/*Report*/
+	u8			nhm_th[NHM_TH_NUM];
+	u8			nhm_result[NHM_RPT_NUM];
+	u16			nhm_period;	/* 4us per unit */
+	u8			nhm_igi;
+	u8			nhm_manual_ctrl;
+	u8			nhm_ratio;	/*1% per nuit, it means the interference igi can't overcome.*/
+	u8			nhm_rpt_sum;
+	u16			nhm_duration;	/*Real time of NHM_VALID */
+	u8			nhm_set_lv;
+	boolean			nhm_ongoing;
+	u8			nhm_rpt_stamp;
+#endif
+#ifdef CLM_SUPPORT
+	enum clm_application	clm_app;
+	u8			clm_manual_ctrl;
+	u8			clm_set_lv;
+	boolean			clm_ongoing;
+	u16			clm_period;	/* 4us per unit */
+	u16			clm_result;
+	u8			clm_ratio;
+	u32			clm_fw_result_acc;
+	u8			clm_fw_result_cnt;
+	enum clm_monitor_mode	clm_mntr_mode;
+	u8			clm_rpt_stamp;
+#endif
+#ifdef FAHM_SUPPORT
+	boolean			fahm_ongoing;
+	u8			env_mntr_igi;
+	u8			fahm_nume_sel;	/*fahm_numerator_sel: select {FA, CRCOK, CRC_fail} */
+	u8			fahm_denum_sel;	/*fahm_denumerator_sel: select {FA, CRCOK, CRC_fail} */
+	u16			fahm_period;	/*unit: 4us*/
+#endif
+#if 1	/*Will remove*/
+	/*Previous Settings*/
+	enum nhm_inexclude_txon_all	nhm_inexclude_txon_restore;
+	enum nhm_inexclude_cca_all	nhm_inexclude_cca_restore;
+	u8			nhm_th_restore[NHM_TH_NUM];
+	u16			nhm_period_restore;/* 4us per unit */
+	u8			echo_igi;	/* nhm_result comes from this igi */
+#endif
+};
+
+/* 1 ============================================================
+ * 1 structure
+ * 1 ============================================================ */
+
+void
+phydm_get_nhm_result(
+	void			*dm_void
+);
+
+void
+phydm_set_nhm_th_by_igi(
+	void			*dm_void,
+	u8			igi
+);
+
+void
+phydm_nhm_setting(
+	void			*dm_void,
+	u8			nhm_setting
+);
+
+void
+phydm_ccx_monitor_trigger(
+	void			*dm_void,
+	u16			monitor_time
+);
+
+void
+phydm_ccx_monitor_result(
+	void			*dm_void
+);
+
+
+#ifdef FAHM_SUPPORT
+
+void
+phydm_fahm_init(
+	void			*dm_void
+);
+
+void
+phydm_fahm_dbg(
+	void			*dm_void,
+	char			input[][16],
+	u32			*_used,
+	char			*output,
+	u32			*_out_len,
+	u32			input_num
+);
+
+#endif
+
+
+/*NHM*/
+#ifdef NHM_SUPPORT
+void
+phydm_nhm_trigger(
+	void			*dm_void
+);
+
+void
+phydm_nhm_init(
+	void			*dm_void
+);
+
+void
+phydm_nhm_dbg(
+	void			*dm_void,
+	char			input[][16],
+	u32			*_used,
+	char			*output,
+	u32			*_out_len,
+	u32			input_num
+);
+#endif
+
+/*CLM*/
+#ifdef CLM_SUPPORT
+void
+phydm_clm_c2h_report_handler(
+	void			*dm_void,
+	u8			*cmd_buf,
+	u8			cmd_len
+);
+
+void
+phydm_clm_h2c(
+	void	*dm_void,
+	u16	obs_time,
+	u8	fw_clm_en
+);
+
+
+void
+phydm_clm_setting(
+	void			*dm_void,
+	u16			clm_period
+);
+
+void
+phydm_clm_trigger(
+	void			*dm_void
+);
+
+boolean
+phydm_clm_check_rdy(
+	void			*dm_void
+);
+
+void
+phydm_clm_get_utility(
+	void		*dm_void
+);
+
+boolean
+phydm_clm_get_result(
+	void			*dm_void
+);
+
+u8
+phydm_clm_mntr_set(
+	void	*dm_void,
+	struct	clm_para_info	*clm_para
+);
+
+void
+phydm_set_clm_mntr_mode(
+	void			*dm_void,
+	enum clm_monitor_mode 	mode
+);
+
+void
+phydm_clm_dbg(
+	void			*dm_void,
+	char			input[][16],
+	u32			*_used,
+	char			*output,
+	u32			*_out_len,
+	u32			input_num
+);
+#endif
+
+u8
+phydm_env_mntr_trigger(
+	void			*dm_void,
+	struct	nhm_para_info	*nhm_para,
+	struct	clm_para_info	*clm_para,
+	struct	env_trig_rpt	*rpt
+);
+
+u8
+phydm_env_mntr_result(
+	void			*dm_void,
+	struct	env_mntr_rpt	*rpt
+);
+
+void
+phydm_env_mntr_watchdog(
+	void	*dm_void
+);
+
+
+void
+phydm_env_monitor_init(
+	void			*dm_void
+);
+
+void
+phydm_env_mntr_dbg(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.c
index 64e2965670b6..241ae1236d73 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.c
@@ -1,347 +1,372 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-VOID
-odm_SetCrystalCap(
-	IN		PVOID					pDM_VOID,
-	IN		u1Byte					CrystalCap
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PCFO_TRACKING				pCfoTrack = (PCFO_TRACKING)PhyDM_Get_Structure( pDM_Odm, PHYDM_CFOTRACK);
-	BOOLEAN 					bEEPROMCheck;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PADAPTER					Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE				*pHalData = GET_HAL_DATA(Adapter);
-
-	bEEPROMCheck = (pHalData->EEPROMVersion >= 0x01)?TRUE:FALSE;
-#else
-	bEEPROMCheck = TRUE;
-#endif
-
-	if(pCfoTrack->CrystalCap == CrystalCap)
-		return;
-
-	pCfoTrack->CrystalCap = CrystalCap;
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8188E | ODM_RTL8188F)) {
-		/* write 0x24[22:17] = 0x24[16:11] = CrystalCap */
-		CrystalCap = CrystalCap & 0x3F;
-		ODM_SetBBReg(pDM_Odm, REG_AFE_XTAL_CTRL, 0x007ff800, (CrystalCap|(CrystalCap << 6)));
-	} else if (pDM_Odm->SupportICType & ODM_RTL8812) {
-		/* write 0x2C[30:25] = 0x2C[24:19] = CrystalCap */
-		CrystalCap = CrystalCap & 0x3F;
-		ODM_SetBBReg(pDM_Odm, REG_MAC_PHY_CTRL, 0x7FF80000, (CrystalCap|(CrystalCap << 6)));
-	} else if (((pDM_Odm->SupportICType & ODM_RTL8723A) && bEEPROMCheck) ||
-		(pDM_Odm->SupportICType & (ODM_RTL8703B|ODM_RTL8723B|ODM_RTL8192E|ODM_RTL8821))) {
-		/* 0x2C[23:18] = 0x2C[17:12] = CrystalCap */
-		CrystalCap = CrystalCap & 0x3F;
-		ODM_SetBBReg(pDM_Odm, REG_MAC_PHY_CTRL, 0x00FFF000, (CrystalCap|(CrystalCap << 6)));	
-	} else if (pDM_Odm->SupportICType & ODM_RTL8821B) {
-		/* write 0x28[6:1] = 0x24[30:25] = CrystalCap */
-		CrystalCap = CrystalCap & 0x3F;
-		ODM_SetBBReg(pDM_Odm, REG_AFE_XTAL_CTRL, 0x7E000000, CrystalCap);
-		ODM_SetBBReg(pDM_Odm, REG_AFE_PLL_CTRL, 0x7E, CrystalCap);
-	} else if (pDM_Odm->SupportICType & ODM_RTL8814A) {
-		/* write 0x2C[26:21] = 0x2C[20:15] = CrystalCap */
-		CrystalCap = CrystalCap & 0x3F;
-		ODM_SetBBReg(pDM_Odm, REG_MAC_PHY_CTRL, 0x07FF8000, (CrystalCap|(CrystalCap << 6)));
-	} else if (pDM_Odm->SupportICType & ODM_RTL8822B) {
-		/* write 0x24[30:25] = 0x28[6:1] = CrystalCap */
-		CrystalCap = CrystalCap & 0x3F;
-		ODM_SetBBReg(pDM_Odm, REG_AFE_XTAL_CTRL, 0x7e000000, CrystalCap);
-		ODM_SetBBReg(pDM_Odm, REG_AFE_PLL_CTRL, 0x7e, CrystalCap);
-	} else {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("odm_SetCrystalCap(): Use default setting.\n"));
-		ODM_SetBBReg(pDM_Odm, REG_MAC_PHY_CTRL, 0xFFF000, (CrystalCap|(CrystalCap << 6)));
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("odm_SetCrystalCap(): CrystalCap = 0x%x\n", CrystalCap));
-#endif
-}
-
-u1Byte
-odm_GetDefaultCrytaltalCap(
-	IN		PVOID					pDM_VOID
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte						CrystalCap = 0x20;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PADAPTER					Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE				*pHalData = GET_HAL_DATA(Adapter);
-
-	CrystalCap = pHalData->CrystalCap;
-#else
-	prtl8192cd_priv	priv		= pDM_Odm->priv;
-
-	if(priv->pmib->dot11RFEntry.xcap > 0)
-		CrystalCap = priv->pmib->dot11RFEntry.xcap;
-#endif
-
-	CrystalCap = CrystalCap & 0x3f;
-
-	return CrystalCap;
-}
-
-VOID
-odm_SetATCStatus(
-	IN		PVOID					pDM_VOID,
-	IN		BOOLEAN					ATCStatus
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PCFO_TRACKING				pCfoTrack = (PCFO_TRACKING)PhyDM_Get_Structure( pDM_Odm, PHYDM_CFOTRACK);
-
-	if(pCfoTrack->bATCStatus == ATCStatus)
-		return;
-	
-	ODM_SetBBReg(pDM_Odm, ODM_REG(BB_ATC,pDM_Odm), ODM_BIT(BB_ATC,pDM_Odm), ATCStatus);
-	pCfoTrack->bATCStatus = ATCStatus;
-}
-
-BOOLEAN
-odm_GetATCStatus(
-	IN		PVOID					pDM_VOID
-)
-{
-	BOOLEAN						ATCStatus;
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	ATCStatus = (BOOLEAN)ODM_GetBBReg(pDM_Odm, ODM_REG(BB_ATC,pDM_Odm), ODM_BIT(BB_ATC,pDM_Odm));
-	return ATCStatus;
-}
-
-VOID
-ODM_CfoTrackingReset(
-	IN		PVOID					pDM_VOID
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PCFO_TRACKING				pCfoTrack = (PCFO_TRACKING)PhyDM_Get_Structure( pDM_Odm, PHYDM_CFOTRACK);
-
-	pCfoTrack->DefXCap = odm_GetDefaultCrytaltalCap(pDM_Odm);
-	pCfoTrack->bAdjust = TRUE;
-
-	if(pCfoTrack->CrystalCap > pCfoTrack->DefXCap)
-	{
-		odm_SetCrystalCap(pDM_Odm, pCfoTrack->CrystalCap - 1);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD,
-			("ODM_CfoTrackingReset(): approch default value (0x%x)\n", pCfoTrack->CrystalCap));
-	} else if (pCfoTrack->CrystalCap < pCfoTrack->DefXCap)
-	{
-		odm_SetCrystalCap(pDM_Odm, pCfoTrack->CrystalCap + 1);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD,
-			("ODM_CfoTrackingReset(): approch default value (0x%x)\n", pCfoTrack->CrystalCap));
-	}
-
-	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	odm_SetATCStatus(pDM_Odm, TRUE);
-	#endif
-}
-
-VOID
-ODM_CfoTrackingInit(
-	IN		PVOID					pDM_VOID
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PCFO_TRACKING				pCfoTrack = (PCFO_TRACKING)PhyDM_Get_Structure( pDM_Odm, PHYDM_CFOTRACK);
-
-	pCfoTrack->DefXCap = pCfoTrack->CrystalCap = odm_GetDefaultCrytaltalCap(pDM_Odm);
-	pCfoTrack->bATCStatus = odm_GetATCStatus(pDM_Odm);
-	pCfoTrack->bAdjust = TRUE;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking_init()=========> \n"));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking_init(): bATCStatus = %d, CrystalCap = 0x%x \n",pCfoTrack->bATCStatus, pCfoTrack->DefXCap));
-}
-
-VOID
-ODM_CfoTracking(
-	IN		PVOID					pDM_VOID
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PCFO_TRACKING				pCfoTrack = (PCFO_TRACKING)PhyDM_Get_Structure( pDM_Odm, PHYDM_CFOTRACK);
-	int							CFO_kHz_A, CFO_kHz_B, CFO_ave = 0;
-	int							CFO_ave_diff;
-	int							CrystalCap = (int)pCfoTrack->CrystalCap;
-	u1Byte						Adjust_Xtal = 1;
-
-	//4 Support ability
-	if(!(pDM_Odm->SupportAbility & ODM_BB_CFO_TRACKING))
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): Return: SupportAbility ODM_BB_CFO_TRACKING is disabled\n"));
-		return;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking()=========> \n"));
-
-	if(!pDM_Odm->bLinked || !pDM_Odm->bOneEntryOnly)
-	{	
-		//4 No link or more than one entry
-		ODM_CfoTrackingReset(pDM_Odm);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): Reset: bLinked = %d, bOneEntryOnly = %d\n", 
-			pDM_Odm->bLinked, pDM_Odm->bOneEntryOnly));
-	}
-	else
-	{
-		//3 1. CFO Tracking
-		//4 1.1 No new packet
-		if(pCfoTrack->packetCount == pCfoTrack->packetCount_pre)
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): packet counter doesn't change\n"));
-			return;
-		}
-		pCfoTrack->packetCount_pre = pCfoTrack->packetCount;
-	
-		//4 1.2 Calculate CFO
-		CFO_kHz_A =  (int)((pCfoTrack->CFO_tail[0] * 3125)  / 10)>>7; /* CFO_tail[1:0] is S(8,7),    (num_subcarrier>>7) x 312.5K = CFO value(K Hz)   */
-		CFO_kHz_B =  (int)((pCfoTrack->CFO_tail[1] * 3125)  / 10)>>7;
-		
-		if(pDM_Odm->RFType < ODM_2T2R)
-			CFO_ave = CFO_kHz_A;
-		else
-			CFO_ave = (int)(CFO_kHz_A + CFO_kHz_B) >> 1;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): CFO_kHz_A = %dkHz, CFO_kHz_B = %dkHz, CFO_ave = %dkHz\n", 
-						CFO_kHz_A, CFO_kHz_B, CFO_ave));
-
-		//4 1.3 Avoid abnormal large CFO
-		CFO_ave_diff = (pCfoTrack->CFO_ave_pre >= CFO_ave)?(pCfoTrack->CFO_ave_pre - CFO_ave):(CFO_ave - pCfoTrack->CFO_ave_pre);
-		if(CFO_ave_diff > 20 && pCfoTrack->largeCFOHit == 0 && !pCfoTrack->bAdjust)
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): first large CFO hit\n"));
-			pCfoTrack->largeCFOHit = 1;
-			return;
-		}
-		else
-			pCfoTrack->largeCFOHit = 0;
-		pCfoTrack->CFO_ave_pre = CFO_ave;
-
-		//4 1.4 Dynamic Xtal threshold
-		if(pCfoTrack->bAdjust == FALSE)
-		{
-			if(CFO_ave > CFO_TH_XTAL_HIGH || CFO_ave < (-CFO_TH_XTAL_HIGH))
-				pCfoTrack->bAdjust = TRUE;
-		}
-		else
-		{
-			if(CFO_ave < CFO_TH_XTAL_LOW && CFO_ave > (-CFO_TH_XTAL_LOW))
-				pCfoTrack->bAdjust = FALSE;
-		}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-		//4 1.5 BT case: Disable CFO tracking
-		if(pDM_Odm->bBtEnabled)
-		{
-			pCfoTrack->bAdjust = FALSE;
-			odm_SetCrystalCap(pDM_Odm, pCfoTrack->DefXCap);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): Disable CFO tracking for BT!!\n"));
-		}
-/*
-		//4 1.6 Big jump 
-		if(pCfoTrack->bAdjust)
-		{
-			if(CFO_ave > CFO_TH_XTAL_LOW)
-				Adjust_Xtal =  Adjust_Xtal + ((CFO_ave - CFO_TH_XTAL_LOW) >> 2);
-			else if(CFO_ave < (-CFO_TH_XTAL_LOW))
-				Adjust_Xtal =  Adjust_Xtal + ((CFO_TH_XTAL_LOW - CFO_ave) >> 2);
-
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): Crystal cap offset = %d\n", Adjust_Xtal));
-		}
-*/
-#endif
-		
-		//4 1.7 Adjust Crystal Cap.
-		if(pCfoTrack->bAdjust)
-		{
-			if(CFO_ave > CFO_TH_XTAL_LOW)
-				CrystalCap = CrystalCap + Adjust_Xtal;
-			else if(CFO_ave < (-CFO_TH_XTAL_LOW))
-				CrystalCap = CrystalCap - Adjust_Xtal;
-
-			if(CrystalCap > 0x3f)
-				CrystalCap = 0x3f;
-			else if (CrystalCap < 0)
-				CrystalCap = 0;
-
-			odm_SetCrystalCap(pDM_Odm, (u1Byte)CrystalCap);
-		}
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): Crystal cap = 0x%x, Default Crystal cap = 0x%x\n", 
-			pCfoTrack->CrystalCap, pCfoTrack->DefXCap));
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-		if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-			return;
-		
-		//3 2. Dynamic ATC switch
-		if(CFO_ave < CFO_TH_ATC && CFO_ave > -CFO_TH_ATC)
-		{
-			odm_SetATCStatus(pDM_Odm, FALSE);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): Disable ATC!!\n"));
-		}
-		else
-		{
-			odm_SetATCStatus(pDM_Odm, TRUE);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CFO_TRACKING, ODM_DBG_LOUD, ("ODM_CfoTracking(): Enable ATC!!\n"));
-		}
-#endif
-	}
-}
-
-VOID
-ODM_ParsingCFO(
-	IN		PVOID			pDM_VOID,
-	IN		PVOID			pPktinfo_VOID,
-	IN		s1Byte* 			pcfotail
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_PACKET_INFO_T		pPktinfo = (PODM_PACKET_INFO_T)pPktinfo_VOID;
-	PCFO_TRACKING			pCfoTrack = (PCFO_TRACKING)PhyDM_Get_Structure( pDM_Odm, PHYDM_CFOTRACK);
-	u1Byte					i;
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_CFO_TRACKING))
-		return;
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	if(pPktinfo->bPacketMatchBSSID)
-#else
-	if(pPktinfo->StationID != 0)
-#endif
-	{				
-		//3 Update CFO report for path-A & path-B
-		// Only paht-A and path-B have CFO tail and short CFO
-		for(i = ODM_RF_PATH_A; i <= ODM_RF_PATH_B; i++)   
-		{
-			pCfoTrack->CFO_tail[i] = (int)pcfotail[i];
-	 	}
-
-		//3 Update packet counter
-		if(pCfoTrack->packetCount == 0xffffffff)
-			pCfoTrack->packetCount = 0;
-		else
-	 		pCfoTrack->packetCount++;
-	}
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_set_crystal_cap(
+	void					*dm_void,
+	u8					crystal_cap
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	if (cfo_track->crystal_cap == crystal_cap)
+		return;
+
+	crystal_cap = crystal_cap & 0x3F;
+	cfo_track->crystal_cap = crystal_cap;
+
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8188F)) {
+		#if (RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
+		/* write 0x24[22:17] = 0x24[16:11] = crystal_cap */
+		odm_set_bb_reg(dm, REG_AFE_XTAL_CTRL, 0x007ff800, (crystal_cap | (crystal_cap << 6)));
+		#endif
+	}
+	#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type & ODM_RTL8812) {
+	
+		/* write 0x2C[30:25] = 0x2C[24:19] = crystal_cap */
+		odm_set_bb_reg(dm, REG_MAC_PHY_CTRL, 0x7FF80000, (crystal_cap | (crystal_cap << 6)));
+		
+	} 
+	#endif
+	#if (RTL8703B_SUPPORT == 1) || (RTL8723B_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8723D_SUPPORT == 1)
+	else if ((dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723B | ODM_RTL8192E | ODM_RTL8821 | ODM_RTL8723D))) {
+	
+		/* 0x2C[23:18] = 0x2C[17:12] = crystal_cap */
+		odm_set_bb_reg(dm, REG_MAC_PHY_CTRL, 0x00FFF000, (crystal_cap | (crystal_cap << 6)));
+		
+	}
+	#endif
+	#if (RTL8814A_SUPPORT == 1)	
+	else if (dm->support_ic_type & ODM_RTL8814A) {
+	
+		/* write 0x2C[26:21] = 0x2C[20:15] = crystal_cap */
+		odm_set_bb_reg(dm, REG_MAC_PHY_CTRL, 0x07FF8000, (crystal_cap | (crystal_cap << 6)));
+		
+	}
+	#endif
+	#if (RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
+	else if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8197F)) {
+	
+		/* write 0x24[30:25] = 0x28[6:1] = crystal_cap */
+		odm_set_bb_reg(dm, REG_AFE_XTAL_CTRL, 0x7e000000, crystal_cap);
+		odm_set_bb_reg(dm, REG_AFE_PLL_CTRL, 0x7e, crystal_cap);
+		
+	}
+	#endif
+	#if (RTL8710B_SUPPORT == 1)
+	else if (dm->support_ic_type & (ODM_RTL8710B)) {
+	
+		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)		
+		/* write 0x60[29:24] = 0x60[23:18] = crystal_cap */
+		HAL_SetSYSOnReg((PADAPTER)dm->adapter, REG_SYS_XTAL_CTRL0, 0x3FFC0000, (crystal_cap | (crystal_cap << 6)));
+		#endif
+	}
+	#endif
+	PHYDM_DBG(dm, DBG_CFO_TRK, "Set rystal_cap = 0x%x\n", cfo_track->crystal_cap);
+
+}
+
+u8
+phydm_get_default_crytaltal_cap(
+	void					*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8						crystal_cap = 0x20;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	struct rtl_efuse *rtlefuse = rtl_efuse(rtlpriv);
+
+	crystal_cap = rtlefuse->crystalcap;
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	crystal_cap = hal_data->crystal_cap;
+#else
+	struct rtl8192cd_priv	*priv	= dm->priv;
+
+	if (priv->pmib->dot11RFEntry.xcap > 0)
+		crystal_cap = priv->pmib->dot11RFEntry.xcap;
+#endif
+
+	crystal_cap = crystal_cap & 0x3f;
+
+	return crystal_cap;
+}
+
+void
+phydm_set_atc_status(
+	void					*dm_void,
+	boolean					atc_status
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	if (cfo_track->is_atc_status == atc_status)
+		return;
+
+	odm_set_bb_reg(dm, ODM_REG(BB_ATC, dm), ODM_BIT(BB_ATC, dm), atc_status);
+	cfo_track->is_atc_status = atc_status;
+}
+
+boolean
+phydm_get_atc_status(
+	void					*dm_void
+)
+{
+	boolean						atc_status;
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+
+	atc_status = (boolean)odm_get_bb_reg(dm, ODM_REG(BB_ATC, dm), ODM_BIT(BB_ATC, dm));
+	return atc_status;
+}
+
+void
+phydm_cfo_tracking_reset(
+	void					*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	PHYDM_DBG(dm, DBG_CFO_TRK, "%s ======>\n", __func__);
+
+	cfo_track->def_x_cap = phydm_get_default_crytaltal_cap(dm);
+	cfo_track->is_adjust = true;
+
+	if (cfo_track->crystal_cap > cfo_track->def_x_cap) {
+		
+		phydm_set_crystal_cap(dm, cfo_track->crystal_cap - 1);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "approch to Init-val (0x%x)\n", cfo_track->crystal_cap);
+		
+	} else if (cfo_track->crystal_cap < cfo_track->def_x_cap) {
+	
+		phydm_set_crystal_cap(dm, cfo_track->crystal_cap + 1);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "approch to init-val 0x%x\n", cfo_track->crystal_cap);
+	}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_set_atc_status(dm, true);
+#endif
+}
+
+void
+phydm_cfo_tracking_init(
+	void					*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+
+	cfo_track->def_x_cap = cfo_track->crystal_cap = phydm_get_default_crytaltal_cap(dm);
+	cfo_track->is_atc_status = phydm_get_atc_status(dm);
+	cfo_track->is_adjust = true;
+	PHYDM_DBG(dm, DBG_CFO_TRK, "ODM_CfoTracking_init()=========>\n");
+	PHYDM_DBG(dm, DBG_CFO_TRK, "ODM_CfoTracking_init(): is_atc_status = %d, crystal_cap = 0x%x\n", cfo_track->is_atc_status, cfo_track->def_x_cap);
+
+#if RTL8822B_SUPPORT
+	/* Crystal cap. control by WiFi */
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, 0x10, 0x40, 0x1);
+#endif
+
+#if RTL8821C_SUPPORT
+	/* Crystal cap. control by WiFi */
+	if (dm->support_ic_type & ODM_RTL8821C)
+		odm_set_bb_reg(dm, 0x10, 0x40, 0x1);
+#endif
+}
+
+void
+phydm_cfo_tracking(
+	void					*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	s32						cfo_avg = 0, cfo_path_sum = 0;	/*avg among each path*/
+	u32						cfo_rpt_sum, cfo_khz_avg[4] = {0};
+	s8						crystal_cap = cfo_track->crystal_cap;
+	u8						i, valid_path_cnt = 0;
+
+	if (!(dm->support_ability & ODM_BB_CFO_TRACKING)) {
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_CFO_TRK, "%s ======>\n", __func__);
+
+	if (!dm->is_linked || !dm->is_one_entry_only) {
+		phydm_cfo_tracking_reset(dm);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "is_linked = %d, one_entry_only = %d\n",
+			dm->is_linked, dm->is_one_entry_only);
+		
+	} else {
+		
+		/* No new packet */
+		if (cfo_track->packet_count == cfo_track->packet_count_pre) {
+			PHYDM_DBG(dm, DBG_CFO_TRK, "Pkt cnt doesn't change\n");
+			return;
+		}
+		cfo_track->packet_count_pre = cfo_track->packet_count;
+
+		/*Calculate CFO */
+		for (i = 0; i < dm->num_rf_path; i++) {
+			if (cfo_track->CFO_cnt[i] == 0)
+				continue;
+
+			valid_path_cnt++;
+			cfo_rpt_sum = (u32)CFO_HW_RPT_2_KHZ(((cfo_track->CFO_tail[i] < 0) ? (0 - cfo_track->CFO_tail[i]) :  cfo_track->CFO_tail[i]));
+			cfo_khz_avg[i] = cfo_rpt_sum / cfo_track->CFO_cnt[i];
+
+			PHYDM_DBG(dm, DBG_CFO_TRK, "[Path-%d] CFO_sum = (( %d )), cnt = (( %d )) , CFO_avg= (( %s%d )) kHz\n",
+				i, cfo_rpt_sum, cfo_track->CFO_cnt[i], ((cfo_track->CFO_tail[i] < 0) ? "-" : " "), cfo_khz_avg[i]);
+		}
+
+		for (i = 0; i < valid_path_cnt; i++) {
+			if (cfo_track->CFO_tail[i] < 0) {
+				cfo_path_sum += (0 - (s32)cfo_khz_avg[i]);
+			} else
+				cfo_path_sum += (s32)cfo_khz_avg[i];
+		}
+
+		if (valid_path_cnt >= 2)
+			cfo_avg = cfo_path_sum / valid_path_cnt;
+		else
+			cfo_avg = cfo_path_sum;
+
+		cfo_track->CFO_ave_pre = cfo_avg;
+
+		PHYDM_DBG(dm, DBG_CFO_TRK, "path_cnt = ((%d)), CFO_avg_path=((%d kHz))\n", valid_path_cnt, cfo_avg);
+
+		/*reset counter*/
+		for (i = 0; i < dm->num_rf_path; i++) {
+			cfo_track->CFO_tail[i] = 0;
+			cfo_track->CFO_cnt[i] = 0;
+		}
+
+		/* To adjust crystal cap or not */
+		if (cfo_track->is_adjust == false) {
+			if (cfo_avg > CFO_TRK_ENABLE_TH || cfo_avg < (-CFO_TRK_ENABLE_TH))
+				cfo_track->is_adjust = true;
+		} else {
+			if (cfo_avg < CFO_TRK_STOP_TH && cfo_avg > (-CFO_TRK_STOP_TH))
+				cfo_track->is_adjust = false;
+		}
+
+		#ifdef ODM_CONFIG_BT_COEXIST
+		/*BT case: Disable CFO tracking */
+		if (dm->bt_info_table.is_bt_enabled) {
+			cfo_track->is_adjust = false;
+			phydm_set_crystal_cap(dm, cfo_track->def_x_cap);
+			PHYDM_DBG(dm, DBG_CFO_TRK, "Disable CFO tracking for BT\n");
+		}
+		#endif
+		
+		/*Adjust Crystal Cap. */
+		if (cfo_track->is_adjust) {
+			if (cfo_avg > CFO_TRK_STOP_TH)
+				crystal_cap += 1;
+			else if (cfo_avg < (-CFO_TRK_STOP_TH))
+				crystal_cap -=1;
+
+			if (crystal_cap > 0x3f)
+				crystal_cap = 0x3f;
+			else if (crystal_cap < 0)
+				crystal_cap = 0;
+
+			phydm_set_crystal_cap(dm, (u8)crystal_cap);
+		}
+		
+		PHYDM_DBG(dm, DBG_CFO_TRK, "Crystal cap{Current, Default}={0x%x, 0x%x}\n\n",
+			cfo_track->crystal_cap, cfo_track->def_x_cap);
+
+		/* Dynamic ATC switch */
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			if (cfo_avg < CFO_TH_ATC && cfo_avg > -CFO_TH_ATC) {
+				phydm_set_atc_status(dm, false);
+				PHYDM_DBG(dm, DBG_CFO_TRK, "Disable ATC\n");
+			} else {
+				phydm_set_atc_status(dm, true);
+				PHYDM_DBG(dm, DBG_CFO_TRK, "Enable ATC\n");
+			}
+		}
+		#endif
+	}
+}
+
+void
+phydm_parsing_cfo(
+	void			*dm_void,
+	void			*pktinfo_void,
+	s8			*pcfotail,
+	u8			num_ss
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_perpkt_info_struct		*pktinfo = (struct phydm_perpkt_info_struct *)pktinfo_void;
+	struct phydm_cfo_track_struct			*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	u8					i;
+
+	if (!(dm->support_ability & ODM_BB_CFO_TRACKING))
+		return;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (pktinfo->is_packet_match_bssid)
+#else
+	if (pktinfo->station_id != 0)
+#endif
+	{
+		if (num_ss > dm->num_rf_path) /*For fool proof*/
+			num_ss = dm->num_rf_path;
+
+		/*PHYDM_DBG(dm, DBG_CFO_TRK, "num_ss = ((%d)),  dm->num_rf_path = ((%d))\n", num_ss,  dm->num_rf_path);*/
+
+
+		/* 3 Update CFO report for path-A & path-B */
+		/* Only paht-A and path-B have CFO tail and short CFO */
+		for (i = 0; i < num_ss; i++) {
+			cfo_track->CFO_tail[i] += pcfotail[i];
+			cfo_track->CFO_cnt[i]++;
+			/*PHYDM_DBG(dm, DBG_CFO_TRK, "[ID %d][path %d][rate 0x%x] CFO_tail = ((%d)), CFO_tail_sum = ((%d)), CFO_cnt = ((%d))\n",
+				pktinfo->station_id, i, pktinfo->data_rate, pcfotail[i], cfo_track->CFO_tail[i], cfo_track->CFO_cnt[i]);
+			*/
+		}
+
+		/* 3 Update packet counter */
+		if (cfo_track->packet_count == 0xffffffff)
+			cfo_track->packet_count = 0;
+		else
+			cfo_track->packet_count++;
+	}
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.h
index b1cc48777378..0193b97f7762 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_cfotracking.h
@@ -1,68 +1,72 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef	__PHYDMCFOTRACK_H__
-#define    __PHYDMCFOTRACK_H__
-
-#define CFO_TRACKING_VERSION	"1.2" /*2015.06.17*/
-
-#define		CFO_TH_XTAL_HIGH			20			// kHz
-#define		CFO_TH_XTAL_LOW			10			// kHz
-#define		CFO_TH_ATC					80			// kHz
-
-typedef struct _CFO_TRACKING_
-{
-	BOOLEAN			bATCStatus;
-	BOOLEAN			largeCFOHit;
-	BOOLEAN			bAdjust;
-	u1Byte			CrystalCap;
-	u1Byte			DefXCap;
-	int				CFO_tail[2];
-	int				CFO_ave_pre;
-	u4Byte			packetCount;
-	u4Byte			packetCount_pre;
-
-	BOOLEAN			bForceXtalCap;
-	BOOLEAN			bReset;
-}CFO_TRACKING, *PCFO_TRACKING;
-
-VOID
-ODM_CfoTrackingReset(
-	IN		PVOID					pDM_VOID
-);
-
-VOID
-ODM_CfoTrackingInit(
-	IN		PVOID					pDM_VOID
-);
-
-VOID
-ODM_CfoTracking(
-	IN		PVOID					pDM_VOID
-);
-
-VOID
-ODM_ParsingCFO(
-	IN		PVOID					pDM_VOID,
-	IN		PVOID					pPktinfo_VOID,
-	IN     	s1Byte* 					pcfotail
-);
-
-#endif
\ No newline at end of file
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMCFOTRACK_H__
+#define    __PHYDMCFOTRACK_H__
+
+#define CFO_TRACKING_VERSION	"1.4" /*2015.10.01	Stanley, Modify for 8822B*/
+
+#define		CFO_TRK_ENABLE_TH			20	/* (kHz)  enable CFO Tracking threshold*/
+#define		CFO_TRK_STOP_TH			10	/* (kHz)  disable CFO Tracking threshold*/
+#define		CFO_TH_ATC					80	/* kHz */
+
+struct phydm_cfo_track_struct {
+	boolean		is_atc_status;
+	boolean		is_adjust;	/*already modify crystal cap*/
+	u8			crystal_cap;
+	u8			def_x_cap;
+	s32			CFO_tail[4];
+	u32			CFO_cnt[4];
+	s32			CFO_ave_pre;
+	u32			packet_count;
+	u32			packet_count_pre;
+};
+
+void
+phydm_set_crystal_cap(
+	void					*dm_void,
+	u8					crystal_cap
+);
+
+void
+phydm_cfo_tracking_init(
+	void					*dm_void
+);
+
+void
+phydm_cfo_tracking(
+	void					*dm_void
+);
+
+void
+phydm_parsing_cfo(
+	void					*dm_void,
+	void					*pktinfo_void,
+	s8					*pcfotail,
+	u8					num_ss
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.c
index acbb01cb5c11..3afd8e5201ab 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.c
@@ -1,2005 +1,3787 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-
-VOID
-PHYDM_InitDebugSetting(
-	IN		PDM_ODM_T		pDM_Odm
-)
-{
-	pDM_Odm->DebugLevel = ODM_DBG_TRACE;
-
-	pDM_Odm->DebugComponents			=
-		\
-#if DBG
-//BB Functions
-//									ODM_COMP_DIG					|
-//									ODM_COMP_RA_MASK				|
-//									ODM_COMP_DYNAMIC_TXPWR		|
-//									ODM_COMP_FA_CNT				|
-//									ODM_COMP_RSSI_MONITOR			|
-//									ODM_COMP_CCK_PD				|
-/*									ODM_COMP_ANT_DIV				|*/
-//									ODM_COMP_PWR_SAVE				|
-//									ODM_COMP_PWR_TRAIN			|
-//									ODM_COMP_RATE_ADAPTIVE		|
-//									ODM_COMP_PATH_DIV				|
-//									ODM_COMP_DYNAMIC_PRICCA		|
-//									ODM_COMP_RXHP					|
-//									ODM_COMP_MP 					|
-//									ODM_COMP_CFO_TRACKING		|
-//									ODM_COMP_ACS					|
-//									PHYDM_COMP_ADAPTIVITY			|
-//									PHYDM_COMP_RA_DBG				|
-/*									PHYDM_COMP_TXBF					|*/
-//MAC Functions
-//									ODM_COMP_EDCA_TURBO			|
-//									ODM_COMP_EARLY_MODE			|
-/*									ODM_FW_DEBUG_TRACE				|*/
-//RF Functions
-//									ODM_COMP_TX_PWR_TRACK		|
-//									ODM_COMP_RX_GAIN_TRACK		|
-//									ODM_COMP_CALIBRATION			|
-//Common
-/*									ODM_PHY_CONFIG					|*/
-//									ODM_COMP_COMMON				|
-//									ODM_COMP_INIT					|
-//									ODM_COMP_PSD					|
-/*									ODM_COMP_NOISY_DETECT			|*/
-#endif
-		0;
-
-	pDM_Odm->fw_buff_is_enpty = TRUE;
-	pDM_Odm->pre_c2h_seq = 0;
-}
-
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-static u1Byte	BbDbgBuf[BB_TMP_BUF_SIZE];
-
-VOID
-phydm_BB_RxHang_Info(IN PDM_ODM_T pDM_Odm)
-{
-	u4Byte	value32 = 0;
-
-
-	if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		return;
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xF80 , bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "rptreg of sc/bw/ht/...", value32);
-	DCMD_Printf(BbDbgBuf);
-
-	/* dbg_port = state machine */
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0x007);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "state machine", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = CCA-related*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0x204);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "CCA-related", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-
-	/* dbg_port = edcca/rxd*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0x278);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "edcca/rxd", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = rx_state/mux_state/ADC_MASK_OFDM*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0x290);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "rx_state/mux_state/ADC_MASK_OFDM", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = bf-related*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0x2B2);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "bf-related", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = bf-related*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0x2B8);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "bf-related", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = txon/rxd*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xA03);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "txon/rxd", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = l_rate/l_length*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xA0B);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "l_rate/l_length", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = rxd/rxd_hit*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xA0D);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "rxd/rxd_hit", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = dis_cca*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xAA0);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "dis_cca", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-
-	/* dbg_port = tx*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xAB0);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "tx", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	/* dbg_port = rx plcp*/
-	{
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xAD0);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "rx plcp", (value32));
-		DCMD_Printf(BbDbgBuf);
-
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xAD1);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "rx plcp", (value32));
-		DCMD_Printf(BbDbgBuf);
-
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xAD2);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "rx plcp", (value32));
-		DCMD_Printf(BbDbgBuf);
-
-		ODM_SetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord, 0xAD3);
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_DBG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8fc", value32);
-		DCMD_Printf(BbDbgBuf);
-
-		value32 = ODM_GetBBReg(pDM_Odm, ODM_REG_RPT_11AC , bMaskDWord);
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "rx plcp", (value32));
-		DCMD_Printf(BbDbgBuf);
-	}
-
-}
-
-VOID
-phydm_BB_Debug_Info(IN PDM_ODM_T pDM_Odm)
-{
-
-	u1Byte	RX_HT_BW, RX_VHT_BW, RXSC, RX_HT, RX_BW;
-	static u1Byte vRX_BW ;
-	u4Byte	value32, value32_1, value32_2, value32_3;
-	s4Byte	SFO_A, SFO_B, SFO_C, SFO_D;
-	s4Byte	LFO_A, LFO_B, LFO_C, LFO_D;
-	static u1Byte	MCSS, Tail, Parity, rsv, vrsv, idx, smooth, htsound, agg, stbc, vstbc, fec, fecext, sgi, sgiext, htltf, vgid, vNsts, vtxops, vrsv2, vbrsv, bf, vbcrc;
-	static u2Byte	HLength, htcrc8, Length;
-	static u2Byte vpaid;
-	static u2Byte	vLength, vhtcrc8, vMCSS, vTail, vbTail;
-	static u1Byte	HMCSS, HRX_BW;
-
-
-	u1Byte    pwDB;
-	s1Byte    RXEVM_0, RXEVM_1, RXEVM_2 ;
-	u1Byte    RF_gain_pathA, RF_gain_pathB, RF_gain_pathC, RF_gain_pathD;
-	u1Byte    RX_SNR_pathA, RX_SNR_pathB, RX_SNR_pathC, RX_SNR_pathD;
-	s4Byte    sig_power;
-	const char *RXHT_table[3] = {"legacy", "HT", "VHT"};
-	const char *BW_table[3] = {"20M", "40M", "80M"};
-	const char *RXSC_table[7] = {"duplicate/full bw", "usc20-1", "lsc20-1", "usc20-2", "lsc20-2",  "usc40", "lsc40"};
-
-	const char *L_rate[8] = {"6M", "9M", "12M", "18M", "24M", "36M", "48M", "54M"};
-
-
-	/*
-	const double evm_comp_20M = 0.579919469776867; //10*log10(64.0/56.0)
-	const double evm_comp_40M = 0.503051183113957; //10*log10(128.0/114.0)
-	const double evm_comp_80M = 0.244245993314183; //10*log10(256.0/242.0)
-	const double evm_comp_160M = 0.244245993314183; //10*log10(512.0/484.0)
-	   */
-
-	if (pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		return;
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s\n", "BB Report Info");
-	DCMD_Printf(BbDbgBuf);
-
-	/*BW & Mode Detection*/
-	
-	value32 = ODM_GetBBReg(pDM_Odm, 0xf80 , bMaskDWord);
-	value32_2 = value32;
-	RX_HT_BW = (u1Byte)(value32 & 0x1);
-	RX_VHT_BW = (u1Byte)((value32 >> 1) & 0x3);
-	RXSC = (u1Byte)(value32 & 0x78);
-	value32_1 = (value32 & 0x180) >> 7;
-	RX_HT = (u1Byte)(value32_1);
-	/*
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "F80", value32_2);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "RX_HT_BW", RX_HT_BW);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "RX_VHT_BW", RX_VHT_BW);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "RX_SC", RXSC);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "RX_HT", RX_HT);
-	DCMD_Printf(BbDbgBuf);
-	*/
-
-	/*rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  RX_HT:%s ", RXHT_table[RX_HT]);*/
-	/*DCMD_Printf(BbDbgBuf);*/
-	RX_BW = 0;
-
-	if (RX_HT == 2) {
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  Mode: VHT Mode");
-		DCMD_Printf(BbDbgBuf);
-		if (RX_VHT_BW == 0) {
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "     BW=20M");
-			DCMD_Printf(BbDbgBuf);
-		} else if (RX_VHT_BW == 1) {
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "     BW=40M");
-			DCMD_Printf(BbDbgBuf);
-		} else {
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "     BW=80M");
-			DCMD_Printf(BbDbgBuf);
-		}
-		RX_BW = RX_VHT_BW;
-	} else if (RX_HT == 1) {
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  Mode: HT Mode");
-		DCMD_Printf(BbDbgBuf);
-		if (RX_HT_BW == 0) {
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "     BW=20M");
-			DCMD_Printf(BbDbgBuf);
-		} else if (RX_HT_BW == 1) {
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "     BW=40M");
-			DCMD_Printf(BbDbgBuf);
-		}
-		RX_BW = RX_HT_BW;
-	} else {
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  Mode: Legeacy Mode");
-		DCMD_Printf(BbDbgBuf);
-	}
-
-	if (RX_HT != 0) {
-		if (RXSC == 0)
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  duplicate/full bw");
-		else if (RXSC == 1)
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  usc20-1");
-		else if (RXSC == 2)
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  lsc20-1");
-		else if (RXSC == 3)
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  usc20-2");
-		else if (RXSC == 4)
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  lsc20-2");
-		else if (RXSC == 9)
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  usc40");
-		else if (RXSC == 10)
-			rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n  lsc40");
-		DCMD_Printf(BbDbgBuf);
-	}
-	/*
-	if(RX_HT == 2){
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "  BW:%s", BW_table[RX_VHT_BW]);
-		RX_BW = RX_VHT_BW;
-		}
-	else if(RX_HT == 1){
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "  BW:%s", BW_table[RX_HT_BW]);
-		RX_BW = RX_HT_BW;
-		}
-	else
-		rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE,  "");
-	
-	DCMD_Printf(BbDbgBuf);	
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "  RXSC:%s", RXSC_table[RXSC]);
-	DCMD_Printf(BbDbgBuf);
-	*/
-
-
-/*	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "dB Conversion: 10log(65)", ODM_PWdB_Conversion(65,10,0));*/
-/*	DCMD_Printf(BbDbgBuf);*/
-
-	/* RX signal power and AGC related info*/
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xF90 , bMaskDWord);
-	pwDB = (u1Byte)((value32 & bMaskByte1) >> 8);
-	pwDB = pwDB >> 1;
-	sig_power = -110 + pwDB;
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "OFDM RX Signal Power(dB)", sig_power);
-	DCMD_Printf(BbDbgBuf);
-
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xd14 , bMaskDWord);
-	RX_SNR_pathA = (u1Byte)(value32 & 0xFF) >> 1;
-	RF_gain_pathA = (s1Byte)((value32 & bMaskByte1) >> 8);
-	RF_gain_pathA *= 2;
-	value32 = ODM_GetBBReg(pDM_Odm, 0xd54 , bMaskDWord);
-	RX_SNR_pathB = (u1Byte)(value32 & 0xFF) >> 1;
-	RF_gain_pathB = (s1Byte)((value32 & bMaskByte1) >> 8);
-	RF_gain_pathB *= 2;
-	value32 = ODM_GetBBReg(pDM_Odm, 0xd94 , bMaskDWord);
-	RX_SNR_pathC = (u1Byte)(value32 & 0xFF) >> 1;
-	RF_gain_pathC = (s1Byte)((value32 & bMaskByte1) >> 8);
-	RF_gain_pathC *= 2;
-	value32 = ODM_GetBBReg(pDM_Odm, 0xdd4 , bMaskDWord);
-	RX_SNR_pathD = (u1Byte)(value32 & 0xFF) >> 1;
-	RF_gain_pathD = (s1Byte)((value32 & bMaskByte1) >> 8);
-	RF_gain_pathD *= 2;
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "OFDM RX RF Gain(A/B/C/D)", RF_gain_pathA, RF_gain_pathA, RF_gain_pathC, RF_gain_pathD);
-	DCMD_Printf(BbDbgBuf);
-
-
-	/* RX Counter related info*/
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xF08, bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "OFDM CCA Counter", ((value32&0xFFFF0000)>>16));
-	DCMD_Printf(BbDbgBuf);
-	
-	value32 = ODM_GetBBReg(pDM_Odm, 0xFD0, bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "OFDM SBD Fail Counter", value32&0xFFFF);
-	DCMD_Printf(BbDbgBuf);
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xFC4, bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d", "VHT SIGA/SIGB CRC8 Fail Counter", value32&0xFFFF, ((value32&0xFFFF0000)>>16));
-	DCMD_Printf(BbDbgBuf);
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xFCC, bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "CCK CCA Counter", value32&0xFFFF);
-	DCMD_Printf(BbDbgBuf);
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xFBC, bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d", "LSIG (\"Parity Fail\"/\"Rate Illegal\") Counter", value32&0xFFFF, ((value32&0xFFFF0000)>>16));
-	DCMD_Printf(BbDbgBuf);
-
-	value32_1 = ODM_GetBBReg(pDM_Odm, 0xFC8, bMaskDWord);
-	value32_2 = ODM_GetBBReg(pDM_Odm, 0xFC0, bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d", "HT/VHT MCS NOT SUPPORT counter", ((value32_2&0xFFFF0000)>>16), value32_1&0xFFFF);
-	DCMD_Printf(BbDbgBuf);
-
-
-	/* PostFFT related info*/
-
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xF8c , bMaskDWord);
-	RXEVM_0 = (s1Byte)((value32 & bMaskByte2) >> 16);
-	RXEVM_0 /= 2;
-	if (RXEVM_0 < -63)
-		RXEVM_0 = 0;
-
-	DCMD_Printf(BbDbgBuf);
-	RXEVM_1 = (s1Byte)((value32 & bMaskByte3) >> 24);
-	RXEVM_1 /= 2;
-	value32 = ODM_GetBBReg(pDM_Odm, 0xF88 , bMaskDWord);
-	RXEVM_2 = (s1Byte)((value32 & bMaskByte2) >> 16);
-	RXEVM_2 /= 2;
-
-	if (RXEVM_1 < -63)
-		RXEVM_1 = 0;
-	if (RXEVM_2 < -63)
-		RXEVM_2 = 0;
-
-	/*
-	if(RX_BW == 0){
-		RXEVM_0 -= evm_comp_20M;
-		RXEVM_1 -= evm_comp_20M;
-		RXEVM_2 -= evm_comp_20M;
-		}
-	else if(RX_BW == 1){
-		RXEVM_0 -= evm_comp_40M;
-		RXEVM_1 -= evm_comp_40M;
-		RXEVM_2 -= evm_comp_40M;
-		}
-	else if (RX_BW == 2){
-		RXEVM_0 -= evm_comp_80M;
-		RXEVM_1 -= evm_comp_80M;
-		RXEVM_2 -= evm_comp_80M;
-		}
-		*/
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d", "RXEVM (1ss/2ss/3ss)", RXEVM_0, RXEVM_1, RXEVM_2);
-	DCMD_Printf(BbDbgBuf);
-
-/*	value32 = ODM_GetBBReg(pDM_Odm, 0xD14 ,bMaskDWord);*/
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)", RX_SNR_pathA, RX_SNR_pathB, RX_SNR_pathC, RX_SNR_pathD);
-	DCMD_Printf(BbDbgBuf);
-/*	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "B_RXSNR", (value32&0xFF00)>>9);*/
-/*	DCMD_Printf(BbDbgBuf);*/
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xF8C , bMaskDWord);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d", "CSI_1st /CSI_2nd", value32&0xFFFF, ((value32&0xFFFF0000)>>16));
-	DCMD_Printf(BbDbgBuf);
-
-
-	//BW & Mode Detection
-
-	//Reset Page F Counter
-	ODM_SetBBReg(pDM_Odm, 0xB58 , BIT0, 1);
-	ODM_SetBBReg(pDM_Odm, 0xB58 , BIT0, 0);
-
-	//CFO Report Info
-	//Short CFO
-	value32 = ODM_GetBBReg(pDM_Odm, 0xd0c , bMaskDWord);
-	value32_1 = ODM_GetBBReg(pDM_Odm, 0xd4c , bMaskDWord);
-	value32_2 = ODM_GetBBReg(pDM_Odm, 0xd8c , bMaskDWord);
-	value32_3 = ODM_GetBBReg(pDM_Odm, 0xdcc , bMaskDWord);
-
-	SFO_A = (s4Byte)(value32 & bMask12Bits);
-	SFO_B = (s4Byte)(value32_1 & bMask12Bits);
-	SFO_C = (s4Byte)(value32_2 & bMask12Bits);
-	SFO_D = (s4Byte)(value32_3 & bMask12Bits);
-
-	LFO_A = (s4Byte)(value32 >> 16);
-	LFO_B = (s4Byte)(value32_1 >> 16);
-	LFO_C = (s4Byte)(value32_2 >> 16);
-	LFO_D = (s4Byte)(value32_3 >> 16);
-
-	//SFO 2's to dec
-	if (SFO_A > 2047)
-		SFO_A = SFO_A - 4096;
-	SFO_A = (SFO_A * 312500) / 2048;
-
-	if (SFO_B > 2047)
-		SFO_B = SFO_B - 4096;
-	SFO_B = (SFO_B * 312500) / 2048;
-	if (SFO_C > 2047)
-		SFO_C = SFO_C - 4096;
-	SFO_C = (SFO_C * 312500) / 2048;
-	if (SFO_D > 2047)
-		SFO_D = SFO_D - 4096;
-	SFO_D = (SFO_D * 312500) / 2048;
-
-	//LFO 2's to dec
-
-	if (LFO_A > 4095)
-		LFO_A = LFO_A - 8192;
-
-	if (LFO_B > 4095)
-		LFO_B = LFO_B - 8192;
-
-	if (LFO_C > 4095)
-		LFO_C = LFO_C - 8192;
-
-	if (LFO_D > 4095)
-		LFO_D = LFO_D - 8192;
-	LFO_A = LFO_A * 312500 / 4096;
-	LFO_B = LFO_B * 312500 / 4096;
-	LFO_C = LFO_C * 312500 / 4096;
-	LFO_D = LFO_D * 312500 / 4096;
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "CFO Report Info");
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d/ %d/ %d", "  Short CFO(Hz) <A/B/C/D>", SFO_A, SFO_B, SFO_C, SFO_D);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d/ %d/ %d", "  Long CFO(Hz) <A/B/C/D>", LFO_A, LFO_B, LFO_C, LFO_D);
-	DCMD_Printf(BbDbgBuf);
-
-	//SCFO
-	value32 = ODM_GetBBReg(pDM_Odm, 0xd10 , bMaskDWord);
-	value32_1 = ODM_GetBBReg(pDM_Odm, 0xd50 , bMaskDWord);
-	value32_2 = ODM_GetBBReg(pDM_Odm, 0xd90 , bMaskDWord);
-	value32_3 = ODM_GetBBReg(pDM_Odm, 0xdd0 , bMaskDWord);
-
-	SFO_A = (s4Byte)(value32 & 0x7ff);
-	SFO_B = (s4Byte)(value32_1 & 0x7ff);
-	SFO_C = (s4Byte)(value32_2 & 0x7ff);
-	SFO_D = (s4Byte)(value32_3 & 0x7ff);
-
-	if (SFO_A > 1023)
-		SFO_A = SFO_A - 2048;
-
-	if (SFO_B > 2047)
-		SFO_B = SFO_B - 4096;
-
-	if (SFO_C > 2047)
-		SFO_C = SFO_C - 4096;
-
-	if (SFO_D > 2047)
-		SFO_D = SFO_D - 4096;
-
-	SFO_A = SFO_A * 312500 / 1024;
-	SFO_B = SFO_B * 312500 / 1024;
-	SFO_C = SFO_C * 312500 / 1024;
-	SFO_D = SFO_D * 312500 / 1024;
-
-	LFO_A = (s4Byte)(value32 >> 16);
-	LFO_B = (s4Byte)(value32_1 >> 16);
-	LFO_C = (s4Byte)(value32_2 >> 16);
-	LFO_D = (s4Byte)(value32_3 >> 16);
-
-	if (LFO_A > 4095)
-		LFO_A = LFO_A - 8192;
-
-	if (LFO_B > 4095)
-		LFO_B = LFO_B - 8192;
-
-	if (LFO_C > 4095)
-		LFO_C = LFO_C - 8192;
-
-	if (LFO_D > 4095)
-		LFO_D = LFO_D - 8192;
-	LFO_A = LFO_A * 312500 / 4096;
-	LFO_B = LFO_B * 312500 / 4096;
-	LFO_C = LFO_C * 312500 / 4096;
-	LFO_D = LFO_D * 312500 / 4096;
-	
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d/ %d/ %d", "  Value SCFO(Hz) <A/B/C/D>", SFO_A, SFO_B, SFO_C, SFO_D);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d/ %d/ %d", "  ACQ CFO(Hz) <A/B/C/D>", LFO_A, LFO_B, LFO_C, LFO_D);
-	DCMD_Printf(BbDbgBuf);
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xd14 , bMaskDWord);
-	value32_1 = ODM_GetBBReg(pDM_Odm, 0xd54 , bMaskDWord);
-	value32_2 = ODM_GetBBReg(pDM_Odm, 0xd94 , bMaskDWord);
-	value32_3 = ODM_GetBBReg(pDM_Odm, 0xdd4 , bMaskDWord);
-
-	LFO_A = (s4Byte)(value32 >> 16);
-	LFO_B = (s4Byte)(value32_1 >> 16);
-	LFO_C = (s4Byte)(value32_2 >> 16);
-	LFO_D = (s4Byte)(value32_3 >> 16);
-
-	if (LFO_A > 4095)
-		LFO_A = LFO_A - 8192;
-
-	if (LFO_B > 4095)
-		LFO_B = LFO_B - 8192;
-
-	if (LFO_C > 4095)
-		LFO_C = LFO_C - 8192;
-
-	if (LFO_D > 4095)
-		LFO_D = LFO_D - 8192;
-
-	LFO_A = LFO_A * 312500 / 4096;
-	LFO_B = LFO_B * 312500 / 4096;
-	LFO_C = LFO_C * 312500 / 4096;
-	LFO_D = LFO_D * 312500 / 4096;
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d/ %d/ %d", "  End CFO(Hz) <A/B/C/D>", LFO_A, LFO_B, LFO_C, LFO_D);
-	DCMD_Printf(BbDbgBuf);
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xf20 , bMaskDWord);  /*L SIG*/
-
-	Tail = (u1Byte)((value32 & 0xfc0000) >> 16);
-	Parity = (u1Byte)((value32 & 0x20000) >> 16);
-	Length = (u2Byte)((value32 & 0x1ffe00) >> 8);
-	rsv = (u1Byte)(value32 & 0x10);
-	MCSS = (u1Byte)(value32 & 0x0f);
-
-	switch (MCSS) {
-	case 0x0b:
-		idx = 0;
-		break;
-	case 0x0f:
-		idx = 1;
-		break;
-	case 0x0a:
-		idx = 2;
-		break;
-	case 0x0e:
-		idx = 3;
-		break;
-	case 0x09:
-		idx = 4;
-		break;
-	case 0x08:
-		idx = 5;
-		break;
-	case 0x0c:
-		idx = 6;
-		break;
-	default:
-		idx = 6;
-		break;
-
-	}
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "L-SIG");
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n   Rate:%s", L_rate[idx]);		
-	DCMD_Printf(BbDbgBuf);	
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x/ %x /%x", "  Rsv/Length/Parity", rsv, RX_BW, Length);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "HT-SIG1");
-	DCMD_Printf(BbDbgBuf);
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xf2c , bMaskDWord);  /*HT SIG*/
-	if (RX_HT == 1) {
-
-		HMCSS = (u1Byte)(value32 & 0x7F);
-		HRX_BW = (u1Byte)(value32 & 0x80);
-		HLength = (u2Byte)((value32 >> 8) & 0xffff);
-	}
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x / %x/ %x", "  MCS/BW/Length", HMCSS, HRX_BW, HLength);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "HT-SIG2");
-	DCMD_Printf(BbDbgBuf);
-
-	value32 = ODM_GetBBReg(pDM_Odm, 0xf30 , bMaskDWord);  /*HT SIG*/
-
-	if (RX_HT == 1) {
-		smooth = (u1Byte)(value32 & 0x01);
-		htsound = (u1Byte)(value32 & 0x02);
-		rsv = (u1Byte)(value32 & 0x04);
-		agg = (u1Byte)(value32 & 0x08);
-		stbc = (u1Byte)(value32 & 0x30);
-		fec = (u1Byte)(value32 & 0x40);
-		sgi = (u1Byte)(value32 & 0x80);
-		htltf = (u1Byte)((value32 & 0x300) >> 8);
-		htcrc8 = (u2Byte)((value32 & 0x3fc00) >> 8);
-		Tail = (u1Byte)((value32 & 0xfc0000) >> 16);
-
-
-	}
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x / %x/ %x/ %x/ %x/ %x", "  Smooth/NoSound/Rsv/Aggregate/STBC/LDPC", smooth, htsound, rsv, agg, stbc, fec);
-	DCMD_Printf(BbDbgBuf);
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x / %x/ %x/ %x", "  SGI/E-HT-LTFs/CRC/Tail", sgi, htltf, htcrc8, Tail);
-	DCMD_Printf(BbDbgBuf);
-
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "VHT-SIG-A1");
-	DCMD_Printf(BbDbgBuf);
-	value32 = ODM_GetBBReg(pDM_Odm, 0xf2c , bMaskDWord);  /*VHT SIG A1*/
-	if (RX_HT == 2) {
-		/* value32 = ODM_GetBBReg(pDM_Odm, 0xf2c ,bMaskDWord);*/
-		vRX_BW = (u1Byte)(value32 & 0x03);
-		vrsv = (u1Byte)(value32 & 0x04);
-		vstbc = (u1Byte)(value32 & 0x08);
-		vgid = (u1Byte)((value32 & 0x3f0) >> 4);
-		vNsts = (u1Byte)(((value32 & 0x1c00) >> 8) + 1);
-		vpaid = (u2Byte)(value32 & 0x3fe);
-		vtxops = (u1Byte)((value32 & 0x400000) >> 20);
-		vrsv2 = (u1Byte)((value32 & 0x800000) >> 20);
-	}
-
-	/*rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x", "F2C", value32);*/
-	/*DCMD_Printf(BbDbgBuf);*/
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x / %x/ %x/ %x/ %x/ %x /%x /%x", "  BW/Rsv1/STBC/GID/Nsts/PAID/TXOPPS/Rsv2", vRX_BW, vrsv, vstbc, vgid, vNsts, vpaid, vtxops, vrsv2);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "VHT-SIG-A2");
-	DCMD_Printf(BbDbgBuf);
-	value32 = ODM_GetBBReg(pDM_Odm, 0xf30 , bMaskDWord);  /*VHT SIG*/
-
-
-	if (RX_HT == 2) {
-		/*value32 = ODM_GetBBReg(pDM_Odm, 0xf30 ,bMaskDWord); */  /*VHT SIG*/
-
-		//sgi=(u1Byte)(value32&0x01);
-		sgiext = (u1Byte)(value32 & 0x03);
-		//fec = (u1Byte)(value32&0x04);
-		fecext = (u1Byte)(value32 & 0x0C);
-
-		vMCSS = (u1Byte)(value32 & 0xf0);
-		bf = (u1Byte)((value32 & 0x100) >> 8);
-		vrsv = (u1Byte)((value32 & 0x200) >> 8);
-		vhtcrc8 = (u2Byte)((value32 & 0x3fc00) >> 8);
-		vTail = (u1Byte)((value32 & 0xfc0000) >> 16);
-	}
-	/*rsprintf(BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x", "F30", value32);*/
-	/*DCMD_Printf(BbDbgBuf);*/
-	
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x / %x/ %x/ %x/ %x/ %x/ %x", "  SGI/FEC/MCS/BF/Rsv/CRC/Tail", sgiext, fecext, vMCSS, bf, vrsv, vhtcrc8, vTail);
-	DCMD_Printf(BbDbgBuf);
-
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "VHT-SIG-B");
-	DCMD_Printf(BbDbgBuf);
-	value32 = ODM_GetBBReg(pDM_Odm, 0xf34 , bMaskDWord);  /*VHT SIG*/
-	{
-		vLength = (u2Byte)(value32 & 0x1fffff);
-		vbrsv = (u1Byte)((value32 & 0x600000) >> 20);
-		vbTail = (u2Byte)((value32 & 0x1f800000) >> 20);
-		vbcrc = (u1Byte)((value32 & 0x80000000) >> 28);
-
-	}
-	/*rsprintf(BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x", "F34", value32);*/
-	/*DCMD_Printf(BbDbgBuf);*/
-	rsprintf((char *)BbDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %x / %x/ %x/ %x/", "  Length/Rsv/Tail/CRC", vLength, vbrsv, vbTail, vbcrc);
-	DCMD_Printf(BbDbgBuf);
-
-
-}
-
-void phydm_sbd_check(
-	IN	PDM_ODM_T					pDM_Odm
-)
-{
-	static u4Byte	pkt_cnt = 0;
-	static BOOLEAN sbd_state = 0;
-	u4Byte	sym_count, count, value32;
-
-	if (sbd_state == 0) {
-		pkt_cnt++;
-		if (pkt_cnt % 5 == 0) { /*read SBD conter once every 5 packets*/
-			ODM_SetTimer(pDM_Odm, &pDM_Odm->sbdcnt_timer, 0); /*ms*/
-			sbd_state = 1;
-		}
-	} else { /*read counter*/
-		value32 = ODM_GetBBReg(pDM_Odm, 0xF98, bMaskDWord);
-		sym_count = (value32 & 0x7C000000) >> 26;
-		count = (value32 & 0x3F00000) >> 20;
-		DbgPrint("#SBD#    sym_count   %d   count   %d\n", sym_count, count);
-		sbd_state = 0;
-	}
-}
-
-void phydm_sbd_callback(
-	PRT_TIMER		pTimer
-)
-{
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-#if USE_WORKITEM
-	ODM_ScheduleWorkItem(&pDM_Odm->sbdcnt_workitem);
-#else
-	phydm_sbd_check(pDM_Odm);
-#endif
-}
-
-void phydm_sbd_workitem_callback(
-	IN PVOID            pContext
-)
-{
-	PADAPTER	pAdapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	phydm_sbd_check(pDM_Odm);
-}
-#endif
-VOID
-phydm_BasicDbgMessage
-(
-	IN		PVOID			pDM_VOID
-)
-{
-#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PFALSE_ALARM_STATISTICS FalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure(pDM_Odm , PHYDM_FALSEALMCNT);
-	pDIG_T	pDM_DigTable = &pDM_Odm->DM_DigTable;
-	u1Byte	legacy_table[12] = {1, 2, 5, 11, 6, 9, 12, 18, 24, 36, 48, 54};
-	u1Byte	vht_en = ((pDM_Odm->RxRate) >= ODM_RATEVHTSS1MCS0) ? 1 : 0;
-
-	if (pDM_Odm->RxRate <= ODM_RATE11M) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("[CCK AGC Report] LNA_idx = 0x%x, VGA_idx = 0x%x\n",
-			pDM_Odm->cck_lna_idx, pDM_Odm->cck_vga_idx));		
-	} else {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("[OFDM AGC Report] { 0x%x, 0x%x, 0x%x, 0x%x }\n",
-			pDM_Odm->ofdm_agc_idx[0], pDM_Odm->ofdm_agc_idx[1], pDM_Odm->ofdm_agc_idx[2], pDM_Odm->ofdm_agc_idx[3]));	
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("RSSI: { %d,  %d,  %d,  %d },    RxRate: { %s%s%s%s%d%s}\n",
-		(pDM_Odm->RSSI_A == 0xff) ? 0 : pDM_Odm->RSSI_A , 
-		(pDM_Odm->RSSI_B == 0xff) ? 0 : pDM_Odm->RSSI_B , 
-		(pDM_Odm->RSSI_C == 0xff) ? 0 : pDM_Odm->RSSI_C, 
-		(pDM_Odm->RSSI_D == 0xff) ? 0 : pDM_Odm->RSSI_D,
-		((pDM_Odm->RxRate >= ODM_RATEVHTSS1MCS0) && (pDM_Odm->RxRate <= ODM_RATEVHTSS1MCS9)) ? "VHT 1ss  " : "",
-		((pDM_Odm->RxRate >= ODM_RATEVHTSS2MCS0) && (pDM_Odm->RxRate <= ODM_RATEVHTSS2MCS9)) ? "VHT 2ss " : "",
-		((pDM_Odm->RxRate >= ODM_RATEVHTSS3MCS0) && (pDM_Odm->RxRate <= ODM_RATEVHTSS3MCS9)) ? "VHT 3ss " : "",
-		(pDM_Odm->RxRate >= ODM_RATEMCS0) ? "MCS " : "",
-		(vht_en) ? ((pDM_Odm->RxRate - ODM_RATEVHTSS1MCS0)%10) : ((pDM_Odm->RxRate >= ODM_RATEMCS0) ? (pDM_Odm->RxRate - ODM_RATEMCS0) : ((pDM_Odm->RxRate <= ODM_RATE54M)?legacy_table[pDM_Odm->RxRate]:0)),
-		(pDM_Odm->RxRate >= ODM_RATEMCS0) ? "" : "M"));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",	
-		FalseAlmCnt->Cnt_CCK_CCA, FalseAlmCnt->Cnt_OFDM_CCA, FalseAlmCnt->Cnt_CCA_all));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",	
-		FalseAlmCnt->Cnt_Cck_fail, FalseAlmCnt->Cnt_Ofdm_fail, FalseAlmCnt->Cnt_all));
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), CRC8_fail = (( %d )), Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d ))\n",	
-		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));
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("bLinked = %d, RSSI_Min = %d, CurrentIGI = 0x%x, bNoisy=%d\n\n",
-		pDM_Odm->bLinked, pDM_Odm->RSSI_Min, pDM_DigTable->CurIGValue, pDM_Odm->NoisyDecision));    
-/*
-	temp_reg = ODM_GetBBReg(pDM_Odm, 0xDD0, bMaskByte0);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD, ("0xDD0 = 0x%x\n",temp_reg));
-		
-	temp_reg = ODM_GetBBReg(pDM_Odm, 0xDDc, bMaskByte1);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD, ("0xDDD = 0x%x\n",temp_reg));
-	
-	temp_reg = ODM_GetBBReg(pDM_Odm, 0xc50, bMaskByte0);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD, ("0xC50 = 0x%x\n",temp_reg));
-
-	temp_reg = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x0, 0x3fe0);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD, ("RF 0x0[13:5] = 0x%x\n\n",temp_reg));
-*/	
-
-#endif
-}
-
-
-VOID phydm_BasicProfile(
-	IN		PVOID			pDM_VOID,
-	IN		u4Byte			*_used,
-	OUT		char				*output,
-	IN		u4Byte			*_out_len
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	char  *Cut = NULL;
-	char *ICType = NULL;
-	u4Byte used = *_used;
-	u4Byte out_len = *_out_len;
-	u4Byte	commit_ver = 0;
-	u4Byte	date = 0;
-	char	*commit_by = NULL;
-	u4Byte	release_ver = 0;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-35s\n", "% Basic Profile %"));
-
-	if (pDM_Odm->SupportICType == ODM_RTL8192C)			
-		ICType = "RTL8192C";
-	else if (pDM_Odm->SupportICType == ODM_RTL8192D)
-		ICType = "RTL8192D";
-	else if (pDM_Odm->SupportICType == ODM_RTL8723A)
-		ICType = "RTL8723A";
-	else if (pDM_Odm->SupportICType == ODM_RTL8188E)
-		ICType = "RTL8188E";
-	else if (pDM_Odm->SupportICType == ODM_RTL8812)
-		ICType = "RTL8812A";
-	else if (pDM_Odm->SupportICType == ODM_RTL8821)
-		ICType = "RTL8821A";
-	else if (pDM_Odm->SupportICType == ODM_RTL8192E)
-		ICType = "RTL8192E";
-	else if (pDM_Odm->SupportICType == ODM_RTL8723B)
-		ICType = "RTL8723B";
-	else if (pDM_Odm->SupportICType == ODM_RTL8814A)
-		ICType = "RTL8814A";
-	else if (pDM_Odm->SupportICType == ODM_RTL8881A)
-		ICType = "RTL8881A";
-	else if (pDM_Odm->SupportICType == ODM_RTL8821B)
-		ICType = "RTL8821B";
-	else if (pDM_Odm->SupportICType == ODM_RTL8822B)
-		ICType = "RTL8822B";
-#if (RTL8703B_SUPPORT == 1)
-	else if (pDM_Odm->SupportICType == ODM_RTL8703B) {
-		ICType = "RTL8703B";
-		date = RELEASE_DATE_8703B;
-		commit_by = COMMIT_BY_8703B;
-		release_ver = RELEASE_VERSION_8703B;
-	} 
-#endif
-	else if (pDM_Odm->SupportICType == ODM_RTL8195A)
-		ICType = "RTL8195A";
-	else if (pDM_Odm->SupportICType == ODM_RTL8188F)
-		ICType = "RTL8188F";
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s (MP Chip: %s)\n", "IC Type", ICType, pDM_Odm->bIsMPChip ? "Yes" : "No"));
-
-	if (pDM_Odm->CutVersion == ODM_CUT_A)			
-		Cut = "A";
-	else if (pDM_Odm->CutVersion == ODM_CUT_B)            
-		Cut = "B";
-	else if (pDM_Odm->CutVersion == ODM_CUT_C)            
-		Cut = "C";
-	else if (pDM_Odm->CutVersion == ODM_CUT_D)            
-		Cut = "D";
-	else if (pDM_Odm->CutVersion == ODM_CUT_E)            
-		Cut = "E";
-	else if (pDM_Odm->CutVersion == ODM_CUT_F)            
-		Cut = "F";
-	else if (pDM_Odm->CutVersion == ODM_CUT_I)            
-		Cut = "I";
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Cut Version", Cut));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d\n", "PHY Parameter Version", ODM_GetHWImgVersion(pDM_Odm)));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d\n", "PHY Parameter Commit date", date));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "PHY Parameter Commit by", commit_by));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d\n", "PHY Parameter Release Version", release_ver));
-	
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	{
-		PADAPTER		       Adapter = pDM_Odm->Adapter;
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d (Subversion: %d)\n", "FW Version", Adapter->MgntInfo.FirmwareVersion, Adapter->MgntInfo.FirmwareSubVersion));
-	}
-#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	{
-		struct rtl8192cd_priv *priv = pDM_Odm->priv;
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d (Subversion: %d)\n", "FW Version", priv->pshare->fw_version, priv->pshare->fw_sub_version));
-	}
-#else
-	{
-		PADAPTER		       Adapter = pDM_Odm->Adapter;
-		HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d (Subversion: %d)\n", "FW Version", pHalData->FirmwareVersion, pHalData->FirmwareSubVersion));
-	}
-#endif
-	//1 PHY DM Version List
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-35s\n", "% PHYDM Version %"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Adaptivity", ADAPTIVITY_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "DIG", DIG_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Dynamic BB PowerSaving", DYNAMIC_BBPWRSAV_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "CFO Tracking", CFO_TRACKING_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Antenna Diversity", ANTDIV_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Power Tracking", POWRTRACKING_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Dynamic TxPower", DYNAMIC_TXPWR_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "RA Info", RAINFO_VERSION));
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Antenna Detection", ANTDECT_VERSION));
-#endif
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Auto Channel Selection", ACS_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "EDCA Turbo", EDCATURBO_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Path Diversity", PATHDIV_VERSION));
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "RxHP", RXHP_VERSION));
-#endif
-#if (RTL8822B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType & ODM_RTL8822B)
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "PHY config 8822B", PHY_CONFIG_VERSION_8822B));
-	
-#endif
-	*_used = used;
-	*_out_len = out_len;
-
-}
-
-VOID
-phydm_fw_trace_en_h2c(
-	IN	PVOID	pDM_VOID,
-	IN	BOOLEAN		enable,
-	IN	u4Byte		monitor_mode,
-	IN	u4Byte		macid
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
-	u1Byte			H2C_Parameter[3] = {0};
-
-	H2C_Parameter[0] = enable;
-	H2C_Parameter[1] = (u1Byte)monitor_mode;
-	H2C_Parameter[2] = (u1Byte)macid;
-	ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("---->\n"));
-	if (monitor_mode == 0){
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[H2C] FW_debug_en: (( %d ))\n", enable));
-	} else {
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[H2C] FW_debug_en: (( %d )), mode: (( %d )), macid: (( %d ))\n", enable, monitor_mode, macid));
-	}
-	ODM_FillH2CCmd(pDM_Odm, PHYDM_H2C_FW_TRACE_EN, 3, H2C_Parameter);
-}
-
-VOID
-phydm_get_per_path_txagc(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			path,
-	IN		u4Byte			*_used,
-	OUT		char				*output,
-	IN		u4Byte			*_out_len
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			rate_idx;
-	u1Byte			txagc;
-	u4Byte			used = *_used;
-	u4Byte			out_len = *_out_len;
-
-#if (RTL8822B_SUPPORT == 1)
-	if ((pDM_Odm->SupportICType & ODM_RTL8822B) && (path <= ODM_RF_PATH_B)) {
-		for (rate_idx = 0; rate_idx <= 0x53; rate_idx++) {
-			if (rate_idx == ODM_RATE1M)
-				PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s\n", "CCK====>"));
-			else if (rate_idx == ODM_RATE6M)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "OFDM====>"));
-			else if (rate_idx == ODM_RATEMCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 1ss====>"));
-			else if (rate_idx == ODM_RATEMCS8)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 2ss====>"));
-			else if (rate_idx == ODM_RATEMCS16)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 3ss====>"));
-			else if (rate_idx == ODM_RATEMCS24)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 4ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS1MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 1ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS2MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 2ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS3MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 3ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS4MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 4ss====>"));
-			
-			txagc = config_phydm_read_txagc_8822b(pDM_Odm, path, rate_idx);
-			if (config_phydm_read_txagc_check_8822b(txagc))
-				PHYDM_SNPRINTF((output + used, out_len - used, "  0x%02x    ", txagc));
-			else
-				PHYDM_SNPRINTF((output + used, out_len - used, "  0x%s    ", "xx"));
-		}
-	}
-#endif
-}
-
-
-VOID
-phydm_get_txagc(
-	IN		PVOID			pDM_VOID,
-	IN		u4Byte			*_used,
-	OUT		char				*output,
-	IN		u4Byte			*_out_len
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			used = *_used;
-	u4Byte			out_len = *_out_len;
-	
-	/* Path-A */
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-35s\n", "Path-A===================="));
-	phydm_get_per_path_txagc(pDM_Odm, ODM_RF_PATH_A, _used, output, _out_len);
-	
-	/* Path-B */
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%-35s\n", "Path-B===================="));
-	phydm_get_per_path_txagc(pDM_Odm, ODM_RF_PATH_B, _used, output, _out_len);
-
-	/* Path-C */
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%-35s\n", "Path-C===================="));
-	phydm_get_per_path_txagc(pDM_Odm, ODM_RF_PATH_C, _used, output, _out_len);
-
-	/* Path-D */
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%-35s\n", "Path-D===================="));
-	phydm_get_per_path_txagc(pDM_Odm, ODM_RF_PATH_D, _used, output, _out_len);
-
-}
-
-VOID
-phydm_set_txagc(
-	IN		PVOID			pDM_VOID,
-	IN		u4Byte			*const dm_value,
-	IN		u4Byte			*_used,
-	OUT		char				*output,
-	IN		u4Byte			*_out_len
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			used = *_used;
-	u4Byte			out_len = *_out_len;
-
-#if (RTL8822B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType & ODM_RTL8822B) {
-		if (dm_value[0] <= 1) {
-			if (phydm_write_txagc_1byte_8822b(pDM_Odm, dm_value[2], dm_value[0], (u1Byte)dm_value[1]))
-				PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s%x%s%x\n", "Write path-", dm_value[0], "rate index-0x", dm_value[1], " = 0x", dm_value[2]));
-			else
-				PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s%x%s\n", "Write path-", (dm_value[0] & 0x1), "rate index-0x", (dm_value[1] & 0x7f), " fail"));
-		} else {
-			PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s%x%s\n", "Write path-", (dm_value[0] & 0x1), "rate index-0x", (dm_value[1] & 0x7f), " fail"));
-		}
-	}
-#endif
-}
-
-VOID
-odm_debug_trace(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value,
-	IN		u4Byte		*_used,
-	OUT		char		*output,
-	IN		u4Byte		*_out_len
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u8Byte			pre_debug_components, one = 1;
-	u4Byte used = *_used;
-	u4Byte out_len = *_out_len;
-
-	pre_debug_components = pDM_Odm->DebugComponents;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%s\n", "================================"));
-	if (dm_value[0] == 100) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[Debug Message] PhyDM Selection"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "00. (( %s ))DIG\n", ((pDM_Odm->DebugComponents & ODM_COMP_DIG) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "01. (( %s ))RA_MASK\n", ((pDM_Odm->DebugComponents & ODM_COMP_RA_MASK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "02. (( %s ))DYNAMIC_TXPWR\n", ((pDM_Odm->DebugComponents & ODM_COMP_DYNAMIC_TXPWR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "03. (( %s ))FA_CNT\n", ((pDM_Odm->DebugComponents & ODM_COMP_FA_CNT) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "04. (( %s ))RSSI_MONITOR\n", ((pDM_Odm->DebugComponents & ODM_COMP_RSSI_MONITOR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "05. (( %s ))CCK_PD\n", ((pDM_Odm->DebugComponents & ODM_COMP_CCK_PD) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "06. (( %s ))ANT_DIV\n", ((pDM_Odm->DebugComponents & ODM_COMP_ANT_DIV) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "07. (( %s ))PWR_SAVE\n", ((pDM_Odm->DebugComponents & ODM_COMP_PWR_SAVE) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "08. (( %s ))PWR_TRAIN\n", ((pDM_Odm->DebugComponents & ODM_COMP_PWR_TRAIN) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "09. (( %s ))RATE_ADAPTIVE\n", ((pDM_Odm->DebugComponents & ODM_COMP_RATE_ADAPTIVE) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "10. (( %s ))PATH_DIV\n", ((pDM_Odm->DebugComponents & ODM_COMP_PATH_DIV) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "11. (( %s ))PSD\n", ((pDM_Odm->DebugComponents & ODM_COMP_PSD) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "12. (( %s ))DYNAMIC_PRICCA\n", ((pDM_Odm->DebugComponents & ODM_COMP_DYNAMIC_PRICCA) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "13. (( %s ))RXHP\n", ((pDM_Odm->DebugComponents & ODM_COMP_RXHP) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "14. (( %s ))MP\n", ((pDM_Odm->DebugComponents & ODM_COMP_MP) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "15. (( %s ))CFO_TRACKING\n", ((pDM_Odm->DebugComponents & ODM_COMP_CFO_TRACKING) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "16. (( %s ))ACS\n", ((pDM_Odm->DebugComponents & ODM_COMP_ACS) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "17. (( %s ))ADAPTIVITY\n", ((pDM_Odm->DebugComponents & PHYDM_COMP_ADAPTIVITY) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "18. (( %s ))RA_DBG\n", ((pDM_Odm->DebugComponents & PHYDM_COMP_RA_DBG) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "20. (( %s ))EDCA_TURBO\n", ((pDM_Odm->DebugComponents & ODM_COMP_EDCA_TURBO) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "21. (( %s ))EARLY_MODE\n", ((pDM_Odm->DebugComponents & ODM_COMP_EARLY_MODE) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "22. (( %s ))FW_DEBUG_TRACE\n", ((pDM_Odm->DebugComponents & ODM_FW_DEBUG_TRACE) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "24. (( %s ))TX_PWR_TRACK\n", ((pDM_Odm->DebugComponents & ODM_COMP_TX_PWR_TRACK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "25. (( %s ))RX_GAIN_TRACK\n", ((pDM_Odm->DebugComponents & ODM_COMP_RX_GAIN_TRACK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "26. (( %s ))CALIBRATION\n", ((pDM_Odm->DebugComponents & ODM_COMP_CALIBRATION) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "28. (( %s ))PHY_CONFIG\n", ((pDM_Odm->DebugComponents & ODM_PHY_CONFIG) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "29. (( %s ))BEAMFORMING_DEBUG\n", ((pDM_Odm->DebugComponents & BEAMFORMING_DEBUG) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "30. (( %s ))COMMON\n", ((pDM_Odm->DebugComponents & ODM_COMP_COMMON) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "31. (( %s ))INIT\n", ((pDM_Odm->DebugComponents & ODM_COMP_INIT) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-
-	} else if (dm_value[0] == 101) {
-		pDM_Odm->DebugComponents = 0;
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "Disable all debug components"));
-	} else {
-		if (dm_value[1] == 1) { /*enable*/
-			pDM_Odm->DebugComponents |= (one << dm_value[0]);
-
-			if (dm_value[0] == 22) { /*FW trace function*/
-				phydm_fw_trace_en_h2c(pDM_Odm, 1, dm_value[2], dm_value[3]); /*H2C to enable C2H Msg*/
-			}
-		} else if (dm_value[1] == 2) { /*disable*/
-			pDM_Odm->DebugComponents &= ~(one << dm_value[0]);
-
-			if (dm_value[0] == 22) { /*FW trace function*/
-				phydm_fw_trace_en_h2c(pDM_Odm, 0, dm_value[2], dm_value[3]); /*H2C to disable C2H Msg*/
-			}
-		} else
-			PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[Warning!!!]  1:enable,  2:disable"));
-	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "pre-DbgComponents = 0x%x\n", (u4Byte)pre_debug_components));
-	PHYDM_SNPRINTF((output + used, out_len - used, "Curr-DbgComponents = 0x%x\n", ((u4Byte)pDM_Odm->DebugComponents)));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-}
-
-VOID
-phydm_DumpBbReg(
-	IN		PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			Addr = 0;
-	
-	/* BB Reg */
-	for (Addr = 0x800; Addr < 0xfff; Addr += 4)
-		DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8822B|ODM_RTL8814A)) {
-
-		if (pDM_Odm->RFType > ODM_2T2R) {
-			for (Addr = 0x1800; Addr < 0x18ff; Addr += 4)
-				DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-		}
-
-		if (pDM_Odm->RFType > ODM_3T3R) {
-			for (Addr = 0x1a00; Addr < 0x1aff; Addr += 4)
-				DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-		}
-
-		for (Addr = 0x1900; Addr < 0x19ff; Addr += 4)
-			DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-
-		for (Addr = 0x1c00; Addr < 0x1cff; Addr += 4)
-			DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-
-		for (Addr = 0x1f00; Addr < 0x1fff; Addr += 4)
-			DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-	}
-}
-
-VOID
-phydm_DumpAllReg(
-	IN		PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte			Addr = 0;
-
-	/* dump MAC register */
-	DbgPrint("MAC==========\n");
-	for (Addr = 0; Addr < 0x7ff; Addr += 4)
-		DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-
-	for (Addr = 1000; Addr < 0x17ff; Addr += 4)
-		DbgPrint("%04x %08x\n", Addr, ODM_GetBBReg(pDM_Odm, Addr, bMaskDWord));
-
-	/* dump BB register */
-	DbgPrint("BB==========\n");
-	phydm_DumpBbReg(pDM_Odm);
-
-	/* dump RF register */
-	DbgPrint("RF-A==========\n");
-	for (Addr = 0; Addr < 0xFF; Addr++)
-		DbgPrint("%02x %05x\n", Addr, ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, Addr, bRFRegOffsetMask));
-
-	if (pDM_Odm->RFType > ODM_1T1R) {
-		DbgPrint("RF-B==========\n");
-		for (Addr = 0; Addr < 0xFF; Addr++)
-			DbgPrint("%02x %05x\n", Addr, ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, Addr, bRFRegOffsetMask));
-	}
-
-	if (pDM_Odm->RFType > ODM_2T2R) {
-		DbgPrint("RF-C==========\n");
-		for (Addr = 0; Addr < 0xFF; Addr++)
-			DbgPrint("%02x %05x\n", Addr, ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_C, Addr, bRFRegOffsetMask));
-	}
-
-	if (pDM_Odm->RFType > ODM_3T3R) {
-		DbgPrint("RF-D==========\n");
-		for (Addr = 0; Addr < 0xFF; Addr++)
-			DbgPrint("%02x %05x\n", Addr, ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_D, Addr, bRFRegOffsetMask));
-	}
-}
-
-struct _PHYDM_COMMAND {
-	char name[16];
-	u1Byte id;
-};
-
-enum PHYDM_CMD_ID {
-	PHYDM_DEMO,
-	PHYDM_RA,
-	PHYDM_PROFILE,
-	PHYDM_PATHDIV,
-	PHYDM_DEBUG,
-	PHYDM_SUPPORT_ABILITY,
-	PHYDM_GET_TXAGC,
-	PHYDM_SET_TXAGC,
-	PHYDM_SMART_ANT,
-	PHYDM_API,
-	PHYDM_TRX_PATH,
-	PHYDM_LA_MODE,
-	PHYDM_DUMP_REG
-};
-
-struct _PHYDM_COMMAND phy_dm_ary[] = {
-	{"demo", PHYDM_DEMO},
-	{"ra", PHYDM_RA},
-	{"profile", PHYDM_PROFILE},
-	{"pathdiv", PHYDM_PATHDIV},
-	{"dbg", PHYDM_DEBUG},
-	{"ability", PHYDM_SUPPORT_ABILITY},
-	{"get_txagc", PHYDM_GET_TXAGC},
-	{"set_txagc", PHYDM_SET_TXAGC},
-	{"smtant", PHYDM_SMART_ANT},
-	{"api", PHYDM_API},
-	{"trxpath", PHYDM_TRX_PATH},
-	{"lamode", PHYDM_LA_MODE},
-	{"dumpreg", PHYDM_DUMP_REG}
-};
-
-VOID
-phydm_cmd_parser(
-	IN PDM_ODM_T	pDM_Odm,
-	IN char		input[][MAX_ARGV],
-	IN u4Byte	input_num,
-	IN u1Byte	flag,
-	OUT char	*output,
-	IN u4Byte	out_len
-)
-{
-	u4Byte used = 0;
-	u1Byte id = 0;
-	int var1[5] = {0};
-	int i, input_idx = 0;
-
-	if (flag == 0) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "GET, nothing to print\n"));
-		return;
-	}
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n"));
-
-	//Parsing Cmd ID
-	if (input_num) {
-		int n, i;
-
-		n = sizeof(phy_dm_ary) / sizeof(struct _PHYDM_COMMAND);
-		for (i = 0; i < n; i++) {
-			if (strcmp(phy_dm_ary[i].name, input[0]) == 0) {
-				id = phy_dm_ary[i].id;
-				break;
-			}
-		}
-		if (i == n) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "SET, command not found!\n"));
-			return;
-		}
-	}
-
-	switch (id) {
-	case PHYDM_DEMO: /*echo demo 10 0x3a z abcde >cmd*/
-			{
-				u4Byte   directory = 0;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_AP))				
-				char   char_temp;
-#else
-				u4Byte char_temp = ' ';
-#endif
-		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &directory);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Decimal Value = %d\n", directory));
-		PHYDM_SSCANF(input[2], DCMD_HEX, &directory);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Hex Value = 0x%x\n", directory));
-		PHYDM_SSCANF(input[3], DCMD_CHAR, &char_temp);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Char = %c\n", char_temp));
-		PHYDM_SNPRINTF((output + used, out_len - used, "String = %s\n", input[4]));
-	}
-	break;
-
-	case PHYDM_RA:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-
-				PHYDM_SNPRINTF((output + used, out_len - used, "new SET, RA_var[%d]= (( %d ))\n", i , var1[i]));
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "odm_RA_debug\n"));*/
-#if (defined(CONFIG_RA_DBG_CMD))
-			odm_RA_debug((PVOID)pDM_Odm, var1);
-#endif
-		}
-
-
-		break;
-
-	case PHYDM_PATHDIV:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, PATHDIV_var[%d]= (( %d ))\n", i , var1[i]));*/
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "odm_PATHDIV_debug\n"));*/
-#if (defined(CONFIG_PATH_DIVERSITY))
-			odm_pathdiv_debug(pDM_Odm, (u4Byte *)var1, &used, output, &out_len);
-#endif
-		}
-
-		break;
-
-	case PHYDM_DEBUG:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, Debug_var[%d]= (( %d ))\n", i , var1[i]));*/
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "odm_debug_comp\n"));*/
-			odm_debug_trace(pDM_Odm, (u4Byte *)var1, &used, output, &out_len);
-		}
-
-
-		break;
-
-	case PHYDM_SUPPORT_ABILITY:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, support ablity_var[%d]= (( %d ))\n", i , var1[i]));*/
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "support ablity\n"));*/
-			phydm_support_ablity_debug(pDM_Odm, (u4Byte *)var1, &used, output, &out_len);
-		}
-
-		break;
-		
-	case PHYDM_SMART_ANT:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-			#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-			phydm_hl_smart_ant_cmd(pDM_Odm, (u4Byte *)var1, &used, output, &out_len);
-			#endif
-			#endif
-		}
-
-		break;
-
-	case PHYDM_API:
-#if (RTL8822B_SUPPORT == 1)
-	{
-		if (pDM_Odm->SupportICType & ODM_RTL8822B) {
-			BOOLEAN	bEnableDbgMode;
-			u1Byte central_ch, primary_ch_idx, bandwidth;
-			
-			for (i = 0; i < 4; i++) {
-				if (input[i + 1])
-					PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-			}
-			
-			bEnableDbgMode = (BOOLEAN)var1[0];
-			central_ch = (u1Byte) var1[1];
-			primary_ch_idx = (u1Byte) var1[2];
-			bandwidth = (ODM_BW_E) var1[3];
-
-			if (bEnableDbgMode) {
-				pDM_Odm->bDisablePhyApi = FALSE;
-			config_phydm_switch_channel_bw_8822b(pDM_Odm, central_ch, primary_ch_idx, bandwidth);
-				pDM_Odm->bDisablePhyApi = TRUE;
-			PHYDM_SNPRINTF((output+used, out_len-used, "central_ch = %d, primary_ch_idx = %d, bandwidth = %d\n", central_ch, primary_ch_idx, bandwidth));
-			} else {
-				pDM_Odm->bDisablePhyApi = FALSE;
-				PHYDM_SNPRINTF((output+used, out_len-used, "Disable API debug mode\n"));
-			}
-		} else
-			PHYDM_SNPRINTF((output+used, out_len-used, "This IC doesn't support PHYDM API function\n"));
-	}
-#else
-		PHYDM_SNPRINTF((output+used, out_len-used, "This IC doesn't support PHYDM API function\n"));
-#endif
-		break;	
-		
-	case PHYDM_PROFILE: /*echo profile, >cmd*/
-		phydm_BasicProfile(pDM_Odm, &used, output, &out_len);
-		break;
-
-	case PHYDM_GET_TXAGC:
-		phydm_get_txagc(pDM_Odm, &used, output, &out_len);
-		break;
-		
-	case PHYDM_SET_TXAGC:
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, support ablity_var[%d]= (( %d ))\n", i , var1[i]));*/
-				input_idx++;
-			}
-		}
-		
-		phydm_set_txagc(pDM_Odm, (u4Byte *)var1, &used, output, &out_len);
-		break;
-		
-	case PHYDM_TRX_PATH:
-#if (RTL8822B_SUPPORT == 1)
-	{
-		if (pDM_Odm->SupportICType & ODM_RTL8822B) {
-			u1Byte		TxPath, RxPath;
-			BOOLEAN		bEnableDbgMode, bTx2Path;
-			
-			for (i = 0; i < 4; i++) {
-				if (input[i + 1])
-					PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-			}
-
-			bEnableDbgMode = (BOOLEAN)var1[0];
-			TxPath = (u1Byte) var1[1];
-			RxPath = (u1Byte) var1[2];
-			bTx2Path = (BOOLEAN) var1[3];
-
-			if (bEnableDbgMode) {
-				pDM_Odm->bDisablePhyApi = FALSE;
-				config_phydm_trx_mode_8822b(pDM_Odm, TxPath, RxPath, bTx2Path);
-				pDM_Odm->bDisablePhyApi = TRUE;
-				PHYDM_SNPRINTF((output+used, out_len-used, "TxPath = 0x%x, RxPath = 0x%x, bTx2Path = %d\n", TxPath, RxPath, bTx2Path));
-			} else {
-				pDM_Odm->bDisablePhyApi = FALSE;
-				PHYDM_SNPRINTF((output+used, out_len-used, "Disable API debug mode\n"));
-			}
-		} else
-			PHYDM_SNPRINTF((output+used, out_len-used, "This IC doesn't support PHYDM API function\n"));
-	}
-#else
-		PHYDM_SNPRINTF((output+used, out_len-used, "This IC doesn't support PHYDM API function\n"));
-#endif
-		break;
-
-	case PHYDM_LA_MODE:
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-#if ((RTL8822B_SUPPORT == 1) || (RTL8814A_SUPPORT == 1))
-	{
-		if (pDM_Odm->SupportICType & (ODM_RTL8814A | ODM_RTL8822B)) {
-			u2Byte		PollingTime;
-			u1Byte		TrigSel, TrigSigSel, DmaDataSigSel, TriggerTime;
-			BOOLEAN		bEnableLaMode;
-
-			for (i = 0; i < 6; i++) {
-				if (input[i + 1])
-					PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-			}
-
-			bEnableLaMode = (BOOLEAN)var1[0];
-			if (bEnableLaMode) {
-				TrigSel = (u1Byte)var1[1];
-				TrigSigSel = (u1Byte)var1[2];
-				DmaDataSigSel = (u1Byte)var1[3];
-				TriggerTime = (u1Byte)var1[4];
-				PollingTime = (((u1Byte)var1[5]) << 6);
-
-				ADCSmp_Set(pDM_Odm->Adapter, TrigSel, TrigSigSel, DmaDataSigSel, TriggerTime, PollingTime);
-				PHYDM_SNPRINTF((output+used, out_len-used, "TrigSel = %d, TrigSigSel = %d, DmaDataSigSel = %d\n", TrigSel, TrigSigSel, DmaDataSigSel));
-				PHYDM_SNPRINTF((output+used, out_len-used, "TriggerTime = %d, PollingTime = %d\n", TriggerTime, PollingTime));
-			} else {
-				ADCSmp_Stop(pDM_Odm->Adapter);
-				PHYDM_SNPRINTF((output+used, out_len-used, "Disable LA mode\n"));
-			}
-		} else
-			PHYDM_SNPRINTF((output+used, out_len-used, "This IC doesn't support LA mode\n"));
-	}
-#else
-		PHYDM_SNPRINTF((output+used, out_len-used, "This IC doesn't support LA mode\n"));
-#endif
-#else
-		PHYDM_SNPRINTF((output+used, out_len-used, "This IC doesn't support LA mode\n"));
-#endif
-		break;
-
-	case PHYDM_DUMP_REG:
-	{
-		u1Byte	type = 0;
-		
-		if (input[1]) {
-			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-			type = (u1Byte)var1[0];
-		}
-
-		if (type == 0)
-			phydm_DumpBbReg(pDM_Odm);
-		else if (type == 1)
-			phydm_DumpAllReg(pDM_Odm);
-	}
-		break;
-	default:
-		PHYDM_SNPRINTF((output + used, out_len - used, "SET, unknown command!\n"));
-		break;
-
-	}
-}
-
-#ifdef __ECOS
-char *strsep(char **s, const char *ct)
-{
-	char *sbegin = *s;
-	char *end;
-
-	if (sbegin == NULL)
-		return NULL;
-
-	end = strpbrk(sbegin, ct);
-	if (end)
-		*end++ = '\0';
-	*s = end;
-	return sbegin;
-}
-#endif
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_AP))
-s4Byte
-phydm_cmd(
-	IN PDM_ODM_T	pDM_Odm,
-	IN char		*input,
-	IN u4Byte	in_len,
-	IN u1Byte	flag,
-	OUT char	*output,
-	IN u4Byte	out_len
-)
-{
-	char *token;
-	u4Byte	Argc = 0;
-	char		Argv[MAX_ARGC][MAX_ARGV];
-
-	do {
-		token = strsep(&input, ", ");
-		if (token) {
-			strcpy(Argv[Argc], token);
-			Argc++;
-		} else
-			break;
-	} while (Argc < MAX_ARGC);
-
-	if (Argc == 1)
-		Argv[0][strlen(Argv[0]) - 1] = '\0';
-
-	phydm_cmd_parser(pDM_Odm, Argv, Argc, flag, output, out_len);
-
-	return 0;
-}
-#endif
-
-
-VOID
-phydm_fw_trace_handler(
-	IN	PVOID	pDM_VOID,
-	IN	pu1Byte	CmdBuf,
-	IN	u1Byte	CmdLen
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	/*u1Byte	debug_trace_11byte[60];*/
-	u1Byte		freg_num, c2h_seq, buf_0 = 0;
-
-	if (CmdLen > 12)
-		return;
-
-	buf_0 = CmdBuf[0];
-	freg_num = (buf_0 & 0xf);
-	c2h_seq = (buf_0 & 0xf0) >> 4;
-	/*ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW debug message] freg_num = (( %d )), c2h_seq = (( %d ))\n", freg_num,c2h_seq ));*/
-
-	/*strncpy(debug_trace_11byte,&CmdBuf[1],(CmdLen-1));*/
-	/*debug_trace_11byte[CmdLen-1] = '\0';*/
-	/*ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW debug message] %s\n", debug_trace_11byte));*/
-	/*ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW debug message] CmdLen = (( %d ))\n", CmdLen));*/
-	/*ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW debug message] c2h_cmd_start  = (( %d ))\n", pDM_Odm->c2h_cmd_start));*/
-
-
-
-	/*ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("pre_seq = (( %d )), current_seq = (( %d ))\n", pDM_Odm->pre_c2h_seq, c2h_seq));*/
-	/*ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("fw_buff_is_enpty = (( %d ))\n", pDM_Odm->fw_buff_is_enpty));*/
-
-	if ((c2h_seq != pDM_Odm->pre_c2h_seq)  &&  pDM_Odm->fw_buff_is_enpty == FALSE) {
-		pDM_Odm->fw_debug_trace[pDM_Odm->c2h_cmd_start] = '\0';
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW Dbg Queue Overflow] %s\n", pDM_Odm->fw_debug_trace));
-		pDM_Odm->c2h_cmd_start = 0;
-	}
-
-	if ((CmdLen - 1) > (60 - pDM_Odm->c2h_cmd_start)) {
-		pDM_Odm->fw_debug_trace[pDM_Odm->c2h_cmd_start] = '\0';
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW Dbg Queue error: wrong C2H length] %s\n", pDM_Odm->fw_debug_trace));
-		pDM_Odm->c2h_cmd_start = 0;
-		return;
-	}
-
-	strncpy((char *)&(pDM_Odm->fw_debug_trace[pDM_Odm->c2h_cmd_start]), (char *)&CmdBuf[1], (CmdLen-1));
-	pDM_Odm->c2h_cmd_start += (CmdLen - 1);
-	pDM_Odm->fw_buff_is_enpty = FALSE;	
-	
-	if (freg_num == 0 || pDM_Odm->c2h_cmd_start >= 60) {
-		if (pDM_Odm->c2h_cmd_start < 60)
-			pDM_Odm->fw_debug_trace[pDM_Odm->c2h_cmd_start] = '\0';
-		else
-			pDM_Odm->fw_debug_trace[59] = '\0';
-
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW DBG Msg] %s\n", pDM_Odm->fw_debug_trace));
-		/*DbgPrint("[FW DBG Msg] %s\n", pDM_Odm->fw_debug_trace);*/
-		pDM_Odm->c2h_cmd_start = 0;
-		pDM_Odm->fw_buff_is_enpty = TRUE;
-	}
-
-	pDM_Odm->pre_c2h_seq = c2h_seq;
-}
-
-VOID
-phydm_fw_trace_handler_code(
-	IN	PVOID	pDM_VOID,
-	IN	pu1Byte	Buffer,
-	IN	u1Byte	CmdLen
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	function = Buffer[0];
-	u1Byte	dbg_num = Buffer[1];
-	u2Byte	content_0 = (((u2Byte)Buffer[3])<<8)|((u2Byte)Buffer[2]);
-	u2Byte	content_1 = (((u2Byte)Buffer[5])<<8)|((u2Byte)Buffer[4]);		
-	u2Byte	content_2 = (((u2Byte)Buffer[7])<<8)|((u2Byte)Buffer[6]);	
-	u2Byte	content_3 = (((u2Byte)Buffer[9])<<8)|((u2Byte)Buffer[8]);
-	u2Byte	content_4 = (((u2Byte)Buffer[11])<<8)|((u2Byte)Buffer[10]);
-
-	if(CmdLen >12) {
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW Msg] Invalid cmd length (( %d )) >12 \n", CmdLen));
-	}
-	
-	//ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW Msg] Func=((%d)),  num=((%d)), ct_0=((%d)), ct_1=((%d)), ct_2=((%d)), ct_3=((%d)), ct_4=((%d))\n", 
-	//	function, dbg_num, content_0, content_1, content_2, content_3, content_4));
-	
-	/*--------------------------------------------*/
-	if(function == RATE_DECISION) {
-		if(dbg_num == 0) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin] RA_CNT=((%d))  Max_device=((%d))--------------------------->\n", content_1, content_2));
-			} else if(content_0 == 2) {
-				 ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin] Check RA macid= ((%d)), MediaStatus=((%d)), Dis_RA=((%d)),  try_bit=((0x%x))\n", content_1, content_2, content_3, content_4));
-			} else if(content_0 == 3) {
-				 ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateDecisoin] Check RA  total=((%d)),  drop=((0x%x)), TXRPT_TRY_bit=((%x)), bNoisy=((%x))\n", content_1, content_2, content_3, content_4));
-			}
-		} else if(dbg_num == 1) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin] RTY[0,1,2,3]=[ %d,  %d,  %d,  %d ] \n", content_1, content_2, content_3, content_4));
-			} else if(content_0 == 2) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin] RTY[4]=[ %d ], drop=((%d)), total=((%d)),  current_rate=((0x%x))\n", content_1, content_2, content_3, content_4));
-			} else if(content_0 == 3) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin] penality_idx=((%d ))\n", content_1));
-			}
-		}
-		
-		else if(dbg_num == 3) {
-			if (content_0 == 1)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateDecisoin] Fast_RA (( DOWN ))  total=((%d)),  total>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4));
-			else if (content_0 == 2)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateDecisoin] Fast_RA (( UP ))  total_acc=((%d)),  total_acc>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4));
-			else if (content_0 == 3)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateDecisoin] Fast_RA (( UP )) ((Rate Down Hold))  RA_CNT=((%d))\n", content_1));
-			else if (content_0 == 4)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateDecisoin] Fast_RA (( UP )) ((tota_accl<5 skip))  RA_CNT=((%d))\n", content_1));
-			else if (content_0 == 8)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateDecisoin] Fast_RA (( Reset Tx Rpt )) RA_CNT=((%d))\n", content_1));
-		}
-		
-		else if(dbg_num == 5) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin]  (( UP))  Nsc=((%d)), N_High=((%d))\n", content_1, content_2));
-			} else if(content_0 == 2) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin]  ((DOWN))  Nsc=((%d)), N_Low=((%d))\n", content_1, content_2));
-			} else if(content_0 == 3) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin]  ((HOLD))  Nsc=((%d)), N_High=((%d)), N_Low=((%d)), Reset_CNT=((%d))\n", content_1, content_2, content_3, content_4));
-			}
-		}
-		else if(dbg_num == 0x60) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin]  ((AP RPT))  macid=((%d)), BUPDATE[macid]=((%d))\n", content_1, content_2));
-			} else if(content_0 == 4) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin]  ((AP RPT))  pass=((%d)), rty_num=((%d)), drop=((%d)), total=((%d))\n", content_1, content_2, content_3, content_4));
-			} else if(content_0 == 5) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("[FW][RateDecisoin]  ((AP RPT))  PASS=((%d)), RTY_NUM=((%d)), DROP=((%d)), TOTAL=((%d))\n", content_1, content_2, content_3, content_4));
-			}
-		}
-		else if(dbg_num == 0xff) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE,ODM_DBG_LOUD,("\n\n"));
-			} 
-		}
-		
-	} 
-	/*--------------------------------------------*/
-	else if (function == INIT_RA_TABLE){
-		if(dbg_num == 3) {
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][INIT_RA_INFO] Ra_init, RA_SKIP_CNT = (( %d ))\n", content_0));
-		}
-		
-	} 
-	/*--------------------------------------------*/
-	else if (function == RATE_UP) {
-		if(dbg_num == 2) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateUp]  ((Highest rate -> return)), macid=((%d))  Nsc=((%d))\n", content_1, content_2));
-			}
-		} else if(dbg_num == 5) {
-			if (content_0 == 0)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateUp]  ((Rate UP)), up_rate_tmp=((0x%x)), rate_idx=((0x%x)), SGI_en=((%d)),  SGI=((%d))\n", content_1, content_2, content_3, content_4));
-			else if (content_0 == 1)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateUp]  ((Rate UP)), rate_1=((0x%x)), rate_2=((0x%x)), BW=((%d)), Try_Bit=((%d))\n", content_1, content_2, content_3, content_4));
-		}
-		
-	} 
-	/*--------------------------------------------*/
-	else if (function == RATE_DOWN) {
-		 if(dbg_num == 5) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][RateDownStep]  ((Rate Down)), macid=((%d)),  rate=((0x%x)),  BW=((%d))\n", content_1, content_2, content_3));
-			}
-		}
-	} else if (function == TRY_DONE) {
-		if (dbg_num == 1) {
-			if (content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][Try Done]  ((try succsess )) macid=((%d)), Try_Done_cnt=((%d))\n", content_1, content_2));
-				/**/
-			}
-		} else if (dbg_num == 2) {
-			if (content_0 == 1)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][Try Done]  ((try fail )) macid=((%d)), Try_Done_cnt=((%d)),  multi_try_rate=((%d))\n", content_1, content_2, content_3));
-		}
-	}
-	/*--------------------------------------------*/
-	else if (function == F_RATE_AP_RPT) {
-		 if(dbg_num == 1) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][AP RPT]  ((1)), SPE_STATIS=((0x%x))---------->\n", content_3));				
-			} 
-		} else if(dbg_num == 2) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][AP RPT]  RTY_all=((%d))\n", content_1));				
-			} 
-		} else if(dbg_num == 3) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][AP RPT]  MACID1[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2));
-			} 
-		} else if(dbg_num == 4) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][AP RPT]  MACID2[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2));
-			} 
-		} else if(dbg_num == 5) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][AP RPT]  MACID1[%d], PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2));
-			} 
-		} else if(dbg_num == 6) {
-			if(content_0 == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW][AP RPT]  MACID2[%d],, PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2));
-			} 
-		}
-	}
-	/*--------------------------------------------*/
-		
-
-}
-
-VOID
-phydm_fw_trace_handler_8051(
-	IN	PVOID	pDM_VOID,
-	IN	pu1Byte	Buffer,
-	IN	u1Byte	CmdLen
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if 0
-	if (CmdLen >= 3)
-		CmdBuf[CmdLen - 1] = '\0';
-	ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW DBG Msg] %s\n", &(CmdBuf[3])));
-#else
-
-	int i = 0;
-	u1Byte	Extend_c2hSubID = 0, Extend_c2hDbgLen = 0, Extend_c2hDbgSeq = 0;
-	u1Byte	fw_debug_trace[128];
-	pu1Byte	Extend_c2hDbgContent = 0;
-	
-	if (CmdLen > 127)
-		return;
-
-	Extend_c2hSubID = Buffer[0];
-	Extend_c2hDbgLen = Buffer[1];
-	Extend_c2hDbgContent = Buffer + 2; /*DbgSeq+DbgContent  for show HEX*/
-
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	RT_DISP(FC2H, C2H_Summary, ("[Extend C2H packet], Extend_c2hSubId=0x%x, Extend_c2hDbgLen=%d\n", 
-			Extend_c2hSubID, Extend_c2hDbgLen));
-	
-	RT_DISP_DATA(FC2H, C2H_Summary, "[Extend C2H packet], Content Hex:", Extend_c2hDbgContent, CmdLen-2);
-	#endif
-
-GoBackforAggreDbgPkt:
-	i = 0;
-	Extend_c2hDbgSeq = Buffer[2];
-	Extend_c2hDbgContent = Buffer + 3;
-	
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	RT_DISP(FC2H, C2H_Summary, ("[RTKFW, SEQ= %d] :", Extend_c2hDbgSeq));
-	#endif	
-
-	for (; ; i++) {
-		fw_debug_trace[i] = Extend_c2hDbgContent[i];
-		if (Extend_c2hDbgContent[i + 1] == '\0') {
-			fw_debug_trace[i + 1] = '\0';
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW DBG Msg] %s", &(fw_debug_trace[0])));
-			break;
-		} else if (Extend_c2hDbgContent[i] == '\n') {
-			fw_debug_trace[i + 1] = '\0';
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("[FW DBG Msg] %s", &(fw_debug_trace[0])));
-			Buffer = Extend_c2hDbgContent + i + 3;
-			goto GoBackforAggreDbgPkt;
-		}
-	}
-
-
-#endif
-}
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_init_debug_setting(
+	struct dm_struct		*dm
+)
+{
+	dm->debug_level = ODM_DBG_TRACE;
+
+	dm->fw_debug_components = 0;
+	dm->debug_components =
+		\
+#if DBG
+		/*BB Functions*/
+		/*									DBG_DIG						|*/
+		/*									DBG_RA_MASK					|*/
+		/*									DBG_DYN_TXPWR					|*/
+		/*									DBG_FA_CNT						|*/
+		/*									DBG_RSSI_MNTR					|*/
+		/*									DBG_CCKPD						|*/
+		/*									DBG_ANT_DIV					|*/
+		/*									DBG_SMT_ANT					|*/
+		/*									DBG_PWR_TRAIN					|*/
+		/*									DBG_RA							|*/
+		/*									DBG_PATH_DIV					|*/
+		/*									DBG_DFS						|*/
+		/*									DBG_DYN_ARFR					|*/
+		/*									DBG_ADPTVTY					|*/
+		/*									DBG_CFO_TRK					|*/
+		/*									DBG_ENV_MNTR					|*/
+		/*									DBG_PRI_CCA					|*/
+		/*									DBG_ADPTV_SOML					|*/
+		/*									DBG_LNA_SAT_CHK				|*/
+		/*									DBG_DYN_RX_PATH				|*/
+		/*									DBG_PHY_STATUS					|*/
+		/*									DBG_TMP						|*/
+		/*									DBG_FW_TRACE					|*/
+		/*									DBG_TXBF						|*/
+		/*									DBG_COMMON_FLOW				|*/
+		/*									ODM_COMP_TX_PWR_TRACK		|*/
+		/*									ODM_COMP_CALIBRATION			|*/
+		/*									ODM_COMP_MP					|*/
+		/*									ODM_PHY_CONFIG					|*/
+		/*									ODM_COMP_INIT					|*/
+		/*									ODM_COMP_COMMON				|*/
+		/*									ODM_COMP_API					|*/
+
+
+#endif
+		0;
+
+	dm->fw_buff_is_enpty = true;
+	dm->pre_c2h_seq = 0;
+	dm->c2h_cmd_start = 0;
+	dm->cmn_dbg_msg_cnt = PHYDM_WATCH_DOG_PERIOD;
+	dm->cmn_dbg_msg_period = PHYDM_WATCH_DOG_PERIOD;
+}
+
+void
+phydm_bb_dbg_port_header_sel(
+	void			*dm_void,
+	u32			header_idx
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		odm_set_bb_reg(dm, 0x8f8, (BIT(25) | BIT(24) | BIT(23) | BIT(22)), header_idx);
+		
+		/*
+		header_idx:
+			(0:) '{ofdm_dbg[31:0]}'
+			(1:) '{cca,crc32_fail,dbg_ofdm[29:0]}'
+			(2:) '{vbon,crc32_fail,dbg_ofdm[29:0]}'
+			(3:) '{cca,crc32_ok,dbg_ofdm[29:0]}'
+			(4:) '{vbon,crc32_ok,dbg_ofdm[29:0]}'
+			(5:) '{dbg_iqk_anta}'
+			(6:) '{cca,ofdm_crc_ok,dbg_dp_anta[29:0]}'
+			(7:) '{dbg_iqk_antb}'
+			(8:) '{DBGOUT_RFC_b[31:0]}'
+			(9:) '{DBGOUT_RFC_a[31:0]}'
+			(a:) '{dbg_ofdm}'
+			(b:) '{dbg_cck}'
+		*/
+	}
+}
+
+void
+phydm_bb_dbg_port_clock_en(
+	void			*dm_void,
+	u8			enable
+) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		reg_value = 0;
+	
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814A | ODM_RTL8814B)) {
+		
+		reg_value = enable ? 0x7 : 0;
+		odm_set_bb_reg(dm, 0x198c, 0x7, reg_value); /*enable/disable debug port clock, for power saving*/
+	}
+}
+
+u8
+phydm_set_bb_dbg_port(
+	void			*dm_void,
+	u8			curr_dbg_priority,
+	u32			debug_port
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	dbg_port_result = false;
+
+	if (curr_dbg_priority > dm->pre_dbg_priority) {
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			
+			phydm_bb_dbg_port_clock_en(dm, true);
+			
+			odm_set_bb_reg(dm, 0x8fc, MASKDWORD, debug_port);
+			/**/
+		} else /*if (dm->support_ic_type & ODM_IC_11N_SERIES)*/ {
+			odm_set_bb_reg(dm, 0x908, MASKDWORD, debug_port);
+			/**/
+		}
+		PHYDM_DBG(dm, ODM_COMP_API, "DbgPort ((0x%x)) set success, Cur_priority=((%d)), Pre_priority=((%d))\n", debug_port, curr_dbg_priority, dm->pre_dbg_priority);
+		dm->pre_dbg_priority = curr_dbg_priority;
+		dbg_port_result = true;
+	}
+		
+	return dbg_port_result;
+}
+
+void
+phydm_release_bb_dbg_port(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	phydm_bb_dbg_port_clock_en(dm, false);
+	phydm_bb_dbg_port_header_sel(dm, 0);
+
+	dm->pre_dbg_priority = BB_DBGPORT_RELEASE;
+	PHYDM_DBG(dm, ODM_COMP_API, "Release BB dbg_port\n");
+}
+
+u32
+phydm_get_bb_dbg_port_value(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	dbg_port_value = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		dbg_port_value = odm_get_bb_reg(dm, 0xfa0, MASKDWORD);
+		/**/
+	} else /*if (dm->support_ic_type & ODM_IC_11N_SERIES)*/ {
+		dbg_port_value = odm_get_bb_reg(dm, 0xdf4, MASKDWORD);
+		/**/
+	}
+	PHYDM_DBG(dm, ODM_COMP_API, "dbg_port_value = 0x%x\n", dbg_port_value);
+	return	dbg_port_value;
+}
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+
+void
+phydm_bb_debug_info_n_series(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	u32	value32 = 0, value32_1 = 0;
+	u8	rf_gain_a = 0, rf_gain_b = 0, rf_gain_c = 0, rf_gain_d = 0;
+	u8	rx_snr_a = 0, rx_snr_b = 0, rx_snr_c = 0, rx_snr_d = 0;
+
+	s8    rxevm_0 = 0, rxevm_1 = 0;
+	s32	short_cfo_a = 0, short_cfo_b = 0, long_cfo_a = 0, long_cfo_b = 0;
+	s32	scfo_a = 0, scfo_b = 0, avg_cfo_a = 0, avg_cfo_b = 0;
+	s32	cfo_end_a = 0, cfo_end_b = 0, acq_cfo_a = 0, acq_cfo_b = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s\n", "BB Report Info");
+
+	/*AGC result*/
+	value32 = odm_get_bb_reg(dm, 0xdd0, MASKDWORD);
+	rf_gain_a = (u8)(value32 & 0x3f);
+	rf_gain_a = rf_gain_a << 1;
+
+	rf_gain_b = (u8)((value32 >> 8) & 0x3f);
+	rf_gain_b = rf_gain_b << 1;
+
+	rf_gain_c = (u8)((value32 >> 16) & 0x3f);
+	rf_gain_c = rf_gain_c << 1;
+
+	rf_gain_d = (u8)((value32 >> 24) & 0x3f);
+	rf_gain_d = rf_gain_d << 1;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d",
+		       "OFDM RX RF Gain(A/B/C/D)", rf_gain_a, rf_gain_b,
+		       rf_gain_c, rf_gain_d);
+
+	/*SNR report*/
+	value32 = odm_get_bb_reg(dm, 0xdd4, MASKDWORD);
+	rx_snr_a = (u8)(value32 & 0xff);
+	rx_snr_a = rx_snr_a >> 1;
+
+	rx_snr_b = (u8)((value32 >> 8) & 0xff);
+	rx_snr_b = rx_snr_b >> 1;
+
+	rx_snr_c = (u8)((value32 >> 16) & 0xff);
+	rx_snr_c = rx_snr_c >> 1;
+
+	rx_snr_d = (u8)((value32 >> 24) & 0xff);
+	rx_snr_d = rx_snr_d >> 1;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)",
+		       rx_snr_a, rx_snr_b, rx_snr_c, rx_snr_d);
+
+	/* PostFFT related info*/
+	value32 = odm_get_bb_reg(dm, 0xdd8, MASKDWORD);
+
+	rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_0 /= 2;
+	if (rxevm_0 < -63)
+		rxevm_0 = 0;
+
+	rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+	rxevm_1 /= 2;
+	if (rxevm_1 < -63)
+		rxevm_1 = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "RXEVM (1ss/2ss)", rxevm_0,
+		       rxevm_1);
+
+	/*CFO Report Info*/
+	odm_set_bb_reg(dm, 0xd00, BIT(26), 1);
+
+	/*Short CFO*/
+	value32 = odm_get_bb_reg(dm, 0xdac, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xdb0, MASKDWORD);
+
+	short_cfo_b = (s32)(value32 & 0xfff);			/*S(12,11)*/
+	short_cfo_a = (s32)((value32 & 0x0fff0000) >> 16);
+
+	long_cfo_b = (s32)(value32_1 & 0x1fff);		/*S(13,12)*/
+	long_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+
+	/*SFO 2's to dec*/
+	if (short_cfo_a > 2047)
+		short_cfo_a = short_cfo_a - 4096;
+	if (short_cfo_b > 2047)
+		short_cfo_b = short_cfo_b - 4096;
+
+	short_cfo_a = (short_cfo_a * 312500) / 2048;
+	short_cfo_b = (short_cfo_b * 312500) / 2048;
+
+	/*LFO 2's to dec*/
+
+	if (long_cfo_a > 4095)
+		long_cfo_a = long_cfo_a - 8192;
+
+	if (long_cfo_b > 4095)
+		long_cfo_b = long_cfo_b - 8192;
+
+	long_cfo_a = long_cfo_a * 312500 / 4096;
+	long_cfo_b = long_cfo_b * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "CFO Report Info");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "Short CFO(Hz) <A/B>",
+		       short_cfo_a, short_cfo_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "Long CFO(Hz) <A/B>",
+		       long_cfo_a, long_cfo_b);
+
+	/*SCFO*/
+	value32 = odm_get_bb_reg(dm, 0xdb8, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xdb4, MASKDWORD);
+
+	scfo_b = (s32)(value32 & 0x7ff);			/*S(11,10)*/
+	scfo_a = (s32)((value32 & 0x07ff0000) >> 16);
+
+	if (scfo_a > 1023)
+		scfo_a = scfo_a - 2048;
+
+	if (scfo_b > 1023)
+		scfo_b = scfo_b - 2048;
+
+	scfo_a = scfo_a * 312500 / 1024;
+	scfo_b = scfo_b * 312500 / 1024;
+
+	avg_cfo_b = (s32)(value32_1 & 0x1fff);	/*S(13,12)*/
+	avg_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+
+	if (avg_cfo_a > 4095)
+		avg_cfo_a = avg_cfo_a - 8192;
+
+	if (avg_cfo_b > 4095)
+		avg_cfo_b = avg_cfo_b - 8192;
+
+	avg_cfo_a = avg_cfo_a * 312500 / 4096;
+	avg_cfo_b = avg_cfo_b * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "value SCFO(Hz) <A/B>", scfo_a,
+		       scfo_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "Avg CFO(Hz) <A/B>", avg_cfo_a,
+		       avg_cfo_b);
+
+	value32 = odm_get_bb_reg(dm, 0xdbc, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xde0, MASKDWORD);
+
+	cfo_end_b = (s32)(value32 & 0x1fff);		/*S(13,12)*/
+	cfo_end_a = (s32)((value32 & 0x1fff0000) >> 16);
+
+	if (cfo_end_a > 4095)
+		cfo_end_a = cfo_end_a - 8192;
+
+	if (cfo_end_b > 4095)
+		cfo_end_b = cfo_end_b - 8192;
+
+	cfo_end_a = cfo_end_a * 312500 / 4096;
+	cfo_end_b = cfo_end_b * 312500 / 4096;
+
+	acq_cfo_b = (s32)(value32_1 & 0x1fff);	/*S(13,12)*/
+	acq_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+
+	if (acq_cfo_a > 4095)
+		acq_cfo_a = acq_cfo_a - 8192;
+
+	if (acq_cfo_b > 4095)
+		acq_cfo_b = acq_cfo_b - 8192;
+
+	acq_cfo_a = acq_cfo_a * 312500 / 4096;
+	acq_cfo_b = acq_cfo_b * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "End CFO(Hz) <A/B>", cfo_end_a,
+		       cfo_end_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "ACQ CFO(Hz) <A/B>", acq_cfo_a,
+		       acq_cfo_b);
+
+}
+
+
+void
+phydm_bb_debug_info(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	char *tmp_string = NULL;
+
+	u8	rx_ht_bw, rx_vht_bw, rxsc, rx_ht, rx_bw;
+	static u8 v_rx_bw ;
+	u32	value32, value32_1, value32_2, value32_3;
+	s32	sfo_a, sfo_b, sfo_c, sfo_d;
+	s32	lfo_a, lfo_b, lfo_c, lfo_d;
+	static u8	MCSS, tail, parity, rsv, vrsv, idx, smooth, htsound, agg, stbc, vstbc, fec, fecext, sgi, sgiext, htltf, vgid, v_nsts, vtxops, vrsv2, vbrsv, bf, vbcrc;
+	static u16	h_length, htcrc8, length;
+	static u16 vpaid;
+	static u16	v_length, vhtcrc8, v_mcss, v_tail, vb_tail;
+	static u8	hmcss, hrx_bw;
+
+	u8    pwdb;
+	s8    rxevm_0, rxevm_1, rxevm_2 ;
+	u8    rf_gain_path_a, rf_gain_path_b, rf_gain_path_c, rf_gain_path_d;
+	u8    rx_snr_path_a, rx_snr_path_b, rx_snr_path_c, rx_snr_path_d;
+	s32    sig_power;
+
+	const char *L_rate[8] = {"6M", "9M", "12M", "18M", "24M", "36M", "48M", "54M"};
+
+#if 0
+	const double evm_comp_20M = 0.579919469776867; /* 10*log10(64.0/56.0) */
+	const double evm_comp_40M = 0.503051183113957; /* 10*log10(128.0/114.0) */
+	const double evm_comp_80M = 0.244245993314183; /* 10*log10(256.0/242.0) */
+	const double evm_comp_160M = 0.244245993314183; /* 10*log10(512.0/484.0) */
+#endif
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		phydm_bb_debug_info_n_series(dm, &used, output, &out_len);
+		return;
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s\n", "BB Report Info");
+
+	/*BW & mode Detection*/
+
+	value32 = odm_get_bb_reg(dm, 0xf80, MASKDWORD);
+	value32_2 = value32;
+	rx_ht_bw = (u8)(value32 & 0x1);
+	rx_vht_bw = (u8)((value32 >> 1) & 0x3);
+	rxsc = (u8)(value32 & 0x78);
+	value32_1 = (value32 & 0x180) >> 7;
+	rx_ht = (u8)(value32_1);
+
+	rx_bw = 0;
+
+	if (rx_ht == 2) {
+		if (rx_vht_bw == 0)
+			tmp_string = "20M";
+		else if (rx_vht_bw == 1)
+			tmp_string = "40M";
+		else
+			tmp_string = "80M";
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s %s %s", "mode", "VHT", tmp_string);
+		rx_bw = rx_vht_bw;
+	} else if (rx_ht == 1) {
+		if (rx_ht_bw == 0)
+			tmp_string = "20M";
+		else if (rx_ht_bw == 1)
+			tmp_string = "40M";
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s %s %s", "mode", "HT", tmp_string);
+		rx_bw = rx_ht_bw;
+	} else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s %s", "mode", "Legacy");
+
+	if (rx_ht != 0) {
+		if (rxsc == 0)
+			tmp_string = "duplicate/full bw";
+		else if (rxsc == 1)
+			tmp_string = "usc20-1";
+		else if (rxsc == 2)
+			tmp_string = "lsc20-1";
+		else if (rxsc == 3)
+			tmp_string = "usc20-2";
+		else if (rxsc == 4)
+			tmp_string = "lsc20-2";
+		else if (rxsc == 9)
+			tmp_string = "usc40";
+		else if (rxsc == 10)
+			tmp_string = "lsc40";
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s", tmp_string);
+	}
+
+	/* RX signal power and AGC related info*/
+
+	value32 = odm_get_bb_reg(dm, 0xF90, MASKDWORD);
+	pwdb = (u8)((value32 & MASKBYTE1) >> 8);
+	pwdb = pwdb >> 1;
+	sig_power = -110 + pwdb;
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "OFDM RX Signal Power(dB)",
+		       sig_power);
+
+	value32 = odm_get_bb_reg(dm, 0xd14, MASKDWORD);
+	rx_snr_path_a = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_a = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_a *= 2;
+	value32 = odm_get_bb_reg(dm, 0xd54, MASKDWORD);
+	rx_snr_path_b = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_b = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_b *= 2;
+	value32 = odm_get_bb_reg(dm, 0xd94, MASKDWORD);
+	rx_snr_path_c = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_c = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_c *= 2;
+	value32 = odm_get_bb_reg(dm, 0xdd4, MASKDWORD);
+	rx_snr_path_d = (u8)(value32 & 0xFF) >> 1;
+	rf_gain_path_d = (s8)((value32 & MASKBYTE1) >> 8);
+	rf_gain_path_d *= 2;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d",
+		       "OFDM RX RF Gain(A/B/C/D)", rf_gain_path_a,
+		       rf_gain_path_b, rf_gain_path_c, rf_gain_path_d);
+
+
+	/* RX counter related info*/
+
+	value32 = odm_get_bb_reg(dm, 0xF08, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "OFDM CCA counter",
+		       ((value32 & 0xFFFF0000) >> 16));
+
+	value32 = odm_get_bb_reg(dm, 0xFD0, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "OFDM SBD Fail counter",
+		       value32 & 0xFFFF);
+
+	value32 = odm_get_bb_reg(dm, 0xFC4, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d",
+		       "VHT SIGA/SIGB CRC8 Fail counter", value32 & 0xFFFF,
+		       ((value32 & 0xFFFF0000) >> 16));
+
+	value32 = odm_get_bb_reg(dm, 0xFCC, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d", "CCK CCA counter", value32 & 0xFFFF);
+
+	value32 = odm_get_bb_reg(dm, 0xFBC, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d",
+		       "LSIG (parity Fail/rate Illegal) counter",
+		       value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16));
+
+	value32_1 = odm_get_bb_reg(dm, 0xFC8, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xFC0, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d",
+		       "HT/VHT MCS NOT SUPPORT counter",
+		       ((value32_2 & 0xFFFF0000) >> 16), value32_1 & 0xFFFF);
+
+	/* PostFFT related info*/
+	value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+	rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_0 /= 2;
+	if (rxevm_0 < -63)
+		rxevm_0 = 0;
+
+	rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+	rxevm_1 /= 2;
+	value32 = odm_get_bb_reg(dm, 0xF88, MASKDWORD);
+	rxevm_2 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_2 /= 2;
+
+	if (rxevm_1 < -63)
+		rxevm_1 = 0;
+	if (rxevm_2 < -63)
+		rxevm_2 = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d", "RXEVM (1ss/2ss/3ss)",
+		       rxevm_0, rxevm_1, rxevm_2);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)",
+		       rx_snr_path_a, rx_snr_path_b, rx_snr_path_c,
+		       rx_snr_path_d);
+
+	value32 = odm_get_bb_reg(dm, 0xF8C, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d", "CSI_1st /CSI_2nd",
+		       value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16));
+
+	/*BW & mode Detection*/
+
+	/*Reset Page F counter*/
+	odm_set_bb_reg(dm, 0xB58, BIT(0), 1);
+	odm_set_bb_reg(dm, 0xB58, BIT(0), 0);
+
+	/*CFO Report Info*/
+	/*Short CFO*/
+	value32 = odm_get_bb_reg(dm, 0xd0c, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd4c, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd8c, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xdcc, MASKDWORD);
+
+	sfo_a = (s32)(value32 & 0xfff);
+	sfo_b = (s32)(value32_1 & 0xfff);
+	sfo_c = (s32)(value32_2 & 0xfff);
+	sfo_d = (s32)(value32_3 & 0xfff);
+
+	lfo_a = (s32)(value32 >> 16);
+	lfo_b = (s32)(value32_1 >> 16);
+	lfo_c = (s32)(value32_2 >> 16);
+	lfo_d = (s32)(value32_3 >> 16);
+
+	/*SFO 2's to dec*/
+	if (sfo_a > 2047)
+		sfo_a = sfo_a - 4096;
+	sfo_a = (sfo_a * 312500) / 2048;
+	if (sfo_b > 2047)
+		sfo_b = sfo_b - 4096;
+	sfo_b = (sfo_b * 312500) / 2048;
+	if (sfo_c > 2047)
+		sfo_c = sfo_c - 4096;
+	sfo_c = (sfo_c * 312500) / 2048;
+	if (sfo_d > 2047)
+		sfo_d = sfo_d - 4096;
+	sfo_d = (sfo_d * 312500) / 2048;
+
+	/*LFO 2's to dec*/
+
+	if (lfo_a > 4095)
+		lfo_a = lfo_a - 8192;
+
+	if (lfo_b > 4095)
+		lfo_b = lfo_b - 8192;
+
+	if (lfo_c > 4095)
+		lfo_c = lfo_c - 8192;
+
+	if (lfo_d > 4095)
+		lfo_d = lfo_d - 8192;
+	lfo_a = lfo_a * 312500 / 4096;
+	lfo_b = lfo_b * 312500 / 4096;
+	lfo_c = lfo_c * 312500 / 4096;
+	lfo_d = lfo_d * 312500 / 4096;
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "CFO Report Info");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "Short CFO(Hz) <A/B/C/D>", sfo_a, sfo_b, sfo_c, sfo_d);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "Long CFO(Hz) <A/B/C/D>", lfo_a, lfo_b, lfo_c, lfo_d);
+
+	/*SCFO*/
+	value32 = odm_get_bb_reg(dm, 0xd10, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd50, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd90, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xdd0, MASKDWORD);
+
+	sfo_a = (s32)(value32 & 0x7ff);
+	sfo_b = (s32)(value32_1 & 0x7ff);
+	sfo_c = (s32)(value32_2 & 0x7ff);
+	sfo_d = (s32)(value32_3 & 0x7ff);
+
+	if (sfo_a > 1023)
+		sfo_a = sfo_a - 2048;
+
+	if (sfo_b > 2047)
+		sfo_b = sfo_b - 4096;
+
+	if (sfo_c > 2047)
+		sfo_c = sfo_c - 4096;
+
+	if (sfo_d > 2047)
+		sfo_d = sfo_d - 4096;
+
+	sfo_a = sfo_a * 312500 / 1024;
+	sfo_b = sfo_b * 312500 / 1024;
+	sfo_c = sfo_c * 312500 / 1024;
+	sfo_d = sfo_d * 312500 / 1024;
+
+	lfo_a = (s32)(value32 >> 16);
+	lfo_b = (s32)(value32_1 >> 16);
+	lfo_c = (s32)(value32_2 >> 16);
+	lfo_d = (s32)(value32_3 >> 16);
+
+	if (lfo_a > 4095)
+		lfo_a = lfo_a - 8192;
+
+	if (lfo_b > 4095)
+		lfo_b = lfo_b - 8192;
+
+	if (lfo_c > 4095)
+		lfo_c = lfo_c - 8192;
+
+	if (lfo_d > 4095)
+		lfo_d = lfo_d - 8192;
+	lfo_a = lfo_a * 312500 / 4096;
+	lfo_b = lfo_b * 312500 / 4096;
+	lfo_c = lfo_c * 312500 / 4096;
+	lfo_d = lfo_d * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "value SCFO(Hz) <A/B/C/D>", sfo_a, sfo_b, sfo_c, sfo_d);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "ACQ CFO(Hz) <A/B/C/D>", lfo_a, lfo_b, lfo_c, lfo_d);
+
+	value32 = odm_get_bb_reg(dm, 0xd14, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd54, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd94, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xdd4, MASKDWORD);
+
+	lfo_a = (s32)(value32 >> 16);
+	lfo_b = (s32)(value32_1 >> 16);
+	lfo_c = (s32)(value32_2 >> 16);
+	lfo_d = (s32)(value32_3 >> 16);
+
+	if (lfo_a > 4095)
+		lfo_a = lfo_a - 8192;
+
+	if (lfo_b > 4095)
+		lfo_b = lfo_b - 8192;
+
+	if (lfo_c > 4095)
+		lfo_c = lfo_c - 8192;
+
+	if (lfo_d > 4095)
+		lfo_d = lfo_d - 8192;
+
+	lfo_a = lfo_a * 312500 / 4096;
+	lfo_b = lfo_b * 312500 / 4096;
+	lfo_c = lfo_c * 312500 / 4096;
+	lfo_d = lfo_d * 312500 / 4096;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %d / %d / %d /%d",
+		       "End CFO(Hz) <A/B/C/D>", lfo_a, lfo_b, lfo_c, lfo_d);
+
+	value32 = odm_get_bb_reg(dm, 0xf20, MASKDWORD);  /*L SIG*/
+
+	tail = (u8)((value32 & 0xfc0000) >> 16);
+	parity = (u8)((value32 & 0x20000) >> 16);
+	length = (u16)((value32 & 0x1ffe00) >> 8);
+	rsv = (u8)(value32 & 0x10);
+	MCSS = (u8)(value32 & 0x0f);
+
+	switch (MCSS) {
+	case 0x0b:
+		idx = 0;
+		break;
+	case 0x0f:
+		idx = 1;
+		break;
+	case 0x0a:
+		idx = 2;
+		break;
+	case 0x0e:
+		idx = 3;
+		break;
+	case 0x09:
+		idx = 4;
+		break;
+	case 0x08:
+		idx = 5;
+		break;
+	case 0x0c:
+		idx = 6;
+		break;
+	default:
+		idx = 6;
+		break;
+
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "L-SIG");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s : %s", "rate", L_rate[idx]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x", "Rsv/length/parity", rsv,
+		       rx_bw, length);
+
+	value32 = odm_get_bb_reg(dm, 0xf2c, MASKDWORD);  /*HT SIG*/
+	if (rx_ht == 1) {
+		hmcss = (u8)(value32 & 0x7F);
+		hrx_bw = (u8)(value32 & 0x80);
+		h_length = (u16)((value32 >> 8) & 0xffff);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "HT-SIG1");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x", "MCS/BW/length", hmcss,
+		       hrx_bw, h_length);
+
+	value32 = odm_get_bb_reg(dm, 0xf30, MASKDWORD);  /*HT SIG*/
+
+	if (rx_ht == 1) {
+		smooth = (u8)(value32 & 0x01);
+		htsound = (u8)(value32 & 0x02);
+		rsv = (u8)(value32 & 0x04);
+		agg = (u8)(value32 & 0x08);
+		stbc = (u8)(value32 & 0x30);
+		fec = (u8)(value32 & 0x40);
+		sgi = (u8)(value32 & 0x80);
+		htltf = (u8)((value32 & 0x300) >> 8);
+		htcrc8 = (u16)((value32 & 0x3fc00) >> 8);
+		tail = (u8)((value32 & 0xfc0000) >> 16);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "HT-SIG2");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x / %x / %x",
+		       "Smooth/NoSound/Rsv/Aggregate/STBC/LDPC", smooth,
+		       htsound, rsv, agg, stbc, fec);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x",
+		       "SGI/E-HT-LTFs/CRC/tail", sgi, htltf, htcrc8, tail);
+
+	value32 = odm_get_bb_reg(dm, 0xf2c, MASKDWORD);  /*VHT SIG A1*/
+	if (rx_ht == 2) {
+		/* value32 = odm_get_bb_reg(dm, 0xf2c,MASKDWORD);*/
+		v_rx_bw = (u8)(value32 & 0x03);
+		vrsv = (u8)(value32 & 0x04);
+		vstbc = (u8)(value32 & 0x08);
+		vgid = (u8)((value32 & 0x3f0) >> 4);
+		v_nsts = (u8)(((value32 & 0x1c00) >> 8) + 1);
+		vpaid = (u16)(value32 & 0x3fe);
+		vtxops = (u8)((value32 & 0x400000) >> 20);
+		vrsv2 = (u8)((value32 & 0x800000) >> 20);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "VHT-SIG-A1");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x / %x",
+		       "BW/Rsv1/STBC/GID/Nsts/PAID/TXOPPS/Rsv2", v_rx_bw,
+		       vrsv, vstbc, vgid, v_nsts, vpaid, vtxops, vrsv2);
+
+	value32 = odm_get_bb_reg(dm, 0xf30, MASKDWORD);  /*VHT SIG*/
+
+	if (rx_ht == 2) {
+		/*value32 = odm_get_bb_reg(dm, 0xf30,MASKDWORD); */  /*VHT SIG*/
+
+		/* sgi=(u8)(value32&0x01); */
+		sgiext = (u8)(value32 & 0x03);
+		/* fec = (u8)(value32&0x04); */
+		fecext = (u8)(value32 & 0x0C);
+
+		v_mcss = (u8)(value32 & 0xf0);
+		bf = (u8)((value32 & 0x100) >> 8);
+		vrsv = (u8)((value32 & 0x200) >> 8);
+		vhtcrc8 = (u16)((value32 & 0x3fc00) >> 8);
+		v_tail = (u8)((value32 & 0xfc0000) >> 16);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "VHT-SIG-A2");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x",
+		       "SGI/FEC/MCS/BF/Rsv/CRC/tail", sgiext, fecext, v_mcss,
+		       bf, vrsv, vhtcrc8, v_tail);
+
+	value32 = odm_get_bb_reg(dm, 0xf34, MASKDWORD);  /*VHT SIG*/
+	{
+		v_length = (u16)(value32 & 0x1fffff);
+		vbrsv = (u8)((value32 & 0x600000) >> 20);
+		vb_tail = (u16)((value32 & 0x1f800000) >> 20);
+		vbcrc = (u8)((value32 & 0x80000000) >> 28);
+
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s", "VHT-SIG-B");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\r\n %-35s = %x / %x / %x / %x",
+		       "length/Rsv/tail/CRC", v_length, vbrsv, vb_tail, vbcrc);
+
+	/*for Condition number*/
+	if (dm->support_ic_type & ODM_RTL8822B) {
+		s32	condition_num = 0;
+		char *factor = NULL;
+
+		odm_set_bb_reg(dm, 0x1988, BIT(22), 0x1);	/*enable report condition number*/
+
+		condition_num = odm_get_bb_reg(dm, 0xf84, MASKDWORD);
+		condition_num = (condition_num & 0x3ffff) >> 4;
+
+		if (*dm->band_width == CHANNEL_WIDTH_80)
+			factor = "256/234";
+		else if (*dm->band_width == CHANNEL_WIDTH_40)
+			factor = "128/108";
+		else if (*dm->band_width == CHANNEL_WIDTH_20) {
+			if (rx_ht != 2 || rx_ht != 1)
+				factor = "64/52";	/*HT or VHT*/
+			else
+				factor = "64/48";	/*legacy*/
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n %-35s = %d (factor = %s)",
+			       "Condition number", condition_num, factor);
+
+	}
+	*_used = used;
+	*_out_len = out_len;
+
+}
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+void phydm_sbd_check(
+	struct dm_struct					*dm
+)
+{
+	static u32	pkt_cnt = 0;
+	static boolean sbd_state = 0;
+	u32	sym_count, count, value32;
+
+	if (sbd_state == 0) {
+		pkt_cnt++;
+		if (pkt_cnt % 5 == 0) { /*read SBD conter once every 5 packets*/
+			odm_set_timer(dm, &dm->sbdcnt_timer, 0); /*ms*/
+			sbd_state = 1;
+		}
+	} else { /*read counter*/
+		value32 = odm_get_bb_reg(dm, 0xF98, MASKDWORD);
+		sym_count = (value32 & 0x7C000000) >> 26;
+		count = (value32 & 0x3F00000) >> 20;
+		pr_debug("#SBD#    sym_count   %d   count   %d\n", sym_count, count);
+		sbd_state = 0;
+	}
+}
+#endif
+
+void phydm_sbd_callback(
+	struct phydm_timer_list		*timer
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	void		*adapter = timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	#if USE_WORKITEM
+	odm_schedule_work_item(&dm->sbdcnt_workitem);
+	#else
+	phydm_sbd_check(dm);
+	#endif
+#endif
+}
+
+void phydm_sbd_workitem_callback(
+	void            *context
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	void	*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	phydm_sbd_check(dm);
+#endif
+}
+#endif
+
+void
+phydm_reset_rx_rate_distribution(
+	struct dm_struct	*dm
+)
+{
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+
+	odm_memory_set(dm, &dbg->num_qry_legacy_pkt[0], 0,
+		       (LEGACY_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_ht_pkt[0], 0,
+		       (HT_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_pkt_sc_20m[0], 0,
+		       (LOW_BW_RATE_NUM * 2));
+	
+	dbg->ht_pkt_not_zero = false;
+	dbg->low_bw_20_occur = false;
+	
+#if	ODM_IC_11AC_SERIES_SUPPORT
+	odm_memory_set(dm, &dbg->num_qry_vht_pkt[0], 0,
+		       (VHT_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_pkt_sc_40m[0], 0,
+		       (LOW_BW_RATE_NUM * 2));
+	
+	dbg->vht_pkt_not_zero = false;
+	dbg->low_bw_40_occur = false;
+#endif
+}
+
+void
+phydm_rx_rate_distribution
+(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+	u8	i = 0, j = 0;
+	u8	rate_num = dm->num_rf_path, rate_ss_shift = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[RxRate Cnt] =============>\n");
+
+	/*======CCK=============================================================*/
+	if (*dm->channel <= 14) {
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* CCK = {%d, %d, %d, %d}\n",
+			dbg->num_qry_legacy_pkt[0],
+			dbg->num_qry_legacy_pkt[1],
+			dbg->num_qry_legacy_pkt[2],
+			dbg->num_qry_legacy_pkt[3]
+			);
+	}
+	/*======OFDM============================================================*/
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* OFDM = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+		dbg->num_qry_legacy_pkt[4], dbg->num_qry_legacy_pkt[5],
+		dbg->num_qry_legacy_pkt[6], dbg->num_qry_legacy_pkt[7],
+		dbg->num_qry_legacy_pkt[8], dbg->num_qry_legacy_pkt[9],
+		dbg->num_qry_legacy_pkt[10], dbg->num_qry_legacy_pkt[11]);
+
+	/*======HT==============================================================*/
+	if (dbg->ht_pkt_not_zero) {
+		
+		for (i = 0; i < rate_num; i++) {
+			
+			rate_ss_shift = (i << 3);
+			
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "* HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+				(rate_ss_shift), (rate_ss_shift+7),
+				dbg->num_qry_ht_pkt[rate_ss_shift + 0], dbg->num_qry_ht_pkt[rate_ss_shift + 1],
+				dbg->num_qry_ht_pkt[rate_ss_shift + 2], dbg->num_qry_ht_pkt[rate_ss_shift + 3],
+				dbg->num_qry_ht_pkt[rate_ss_shift + 4], dbg->num_qry_ht_pkt[rate_ss_shift + 5],
+				dbg->num_qry_ht_pkt[rate_ss_shift + 6], dbg->num_qry_ht_pkt[rate_ss_shift + 7]);
+		}
+
+		if (dbg->low_bw_20_occur) {
+			for (i = 0; i < rate_num; i++) {
+				
+				rate_ss_shift = (i << 3);
+				
+				PHYDM_DBG(dm, ODM_COMP_COMMON, "* [Low BW 20M] HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+					(rate_ss_shift), (rate_ss_shift+7),
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 0], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 1],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 2], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 3],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 4], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 5],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 6], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 7]);
+			}
+		}	
+	}
+
+
+	
+#if	ODM_IC_11AC_SERIES_SUPPORT
+	/*======VHT=============================================================*/
+	if (dbg->vht_pkt_not_zero) {
+		for (i = 0; i < rate_num; i++) {
+			rate_ss_shift = 10 * i;
+	
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "* VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+				(i + 1),
+				dbg->num_qry_vht_pkt[rate_ss_shift + 0], dbg->num_qry_vht_pkt[rate_ss_shift + 1],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 2], dbg->num_qry_vht_pkt[rate_ss_shift + 3],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 4], dbg->num_qry_vht_pkt[rate_ss_shift + 5],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 6], dbg->num_qry_vht_pkt[rate_ss_shift + 7],
+				dbg->num_qry_vht_pkt[rate_ss_shift + 8], dbg->num_qry_vht_pkt[rate_ss_shift + 9]);
+		}
+
+		if (dbg->low_bw_20_occur) {
+			for (i = 0; i < rate_num; i++) {
+				rate_ss_shift = 10 * i;
+				
+				PHYDM_DBG(dm, ODM_COMP_COMMON, "*[Low BW 20M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+					(i + 1),
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 0], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 1],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 2], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 3],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 4], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 5],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 6], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 7],
+					dbg->num_qry_pkt_sc_20m[rate_ss_shift + 8], dbg->num_qry_pkt_sc_20m[rate_ss_shift + 9]);
+			}
+		}
+
+		if (dbg->low_bw_40_occur) {
+			for (i = 0; i < rate_num; i++) {
+				rate_ss_shift = 10 * i;
+				
+				PHYDM_DBG(dm, ODM_COMP_COMMON, "*[Low BW 40M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+					(i + 1),
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 0], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 1],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 2], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 3],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 4], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 5],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 6], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 7],
+					dbg->num_qry_pkt_sc_40m[rate_ss_shift + 8], dbg->num_qry_pkt_sc_40m[rate_ss_shift + 9]);
+			}
+		}
+	}
+#endif
+	
+}
+
+void
+phydm_get_avg_phystatus_val
+(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_phystatus_statistic		*dbg_statistic = &dm->phy_dbg_info.phystatus_statistic_info;
+	struct phydm_phystatus_avg		*dbg_avg = &dm->phy_dbg_info.phystatus_statistic_avg;
+	
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[Avg PHY Statistic] ==============>\n");
+
+	phydm_reset_phystatus_avg(dm);
+
+	/*CCK*/
+	dbg_avg->rssi_cck_avg = (u8)((dbg_statistic->rssi_cck_cnt != 0) ? (dbg_statistic->rssi_cck_sum/dbg_statistic->rssi_cck_cnt) : 0);
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* cck Cnt= ((%d)) RSSI:{%d}\n", dbg_statistic->rssi_cck_cnt, dbg_avg->rssi_cck_avg);
+	
+	/*OFDM*/
+	if (dbg_statistic->rssi_ofdm_cnt != 0) {
+		dbg_avg->rssi_ofdm_avg = (u8)(dbg_statistic->rssi_ofdm_sum/dbg_statistic->rssi_ofdm_cnt);
+		dbg_avg->evm_ofdm_avg = (u8)(dbg_statistic->evm_ofdm_sum/dbg_statistic->rssi_ofdm_cnt);
+		dbg_avg->snr_ofdm_avg = (u8)(dbg_statistic->snr_ofdm_sum/dbg_statistic->rssi_ofdm_cnt);
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* ofdm Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
+		dbg_statistic->rssi_ofdm_cnt, dbg_avg->rssi_ofdm_avg, dbg_avg->evm_ofdm_avg, dbg_avg->snr_ofdm_avg);
+	
+	if (dbg_statistic->rssi_1ss_cnt != 0) {
+		dbg_avg->rssi_1ss_avg = (u8)(dbg_statistic->rssi_1ss_sum/dbg_statistic->rssi_1ss_cnt);
+		dbg_avg->evm_1ss_avg = (u8)(dbg_statistic->evm_1ss_sum/dbg_statistic->rssi_1ss_cnt);
+		dbg_avg->snr_1ss_avg = (u8)(dbg_statistic->snr_1ss_sum/dbg_statistic->rssi_1ss_cnt);
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "* 1-ss Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
+		dbg_statistic->rssi_1ss_cnt, dbg_avg->rssi_1ss_avg, dbg_avg->evm_1ss_avg, dbg_avg->snr_1ss_avg);
+
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {
+		if (dbg_statistic->rssi_2ss_cnt != 0) {
+			dbg_avg->rssi_2ss_avg[0] = (u8)(dbg_statistic->rssi_2ss_sum[0] /dbg_statistic->rssi_2ss_cnt);
+			dbg_avg->rssi_2ss_avg[1] = (u8)(dbg_statistic->rssi_2ss_sum[1] /dbg_statistic->rssi_2ss_cnt);
+			
+			dbg_avg->evm_2ss_avg[0] = (u8)(dbg_statistic->evm_2ss_sum[0] /dbg_statistic->rssi_2ss_cnt);
+			dbg_avg->evm_2ss_avg[1] = (u8)(dbg_statistic->evm_2ss_sum[1] /dbg_statistic->rssi_2ss_cnt);
+			
+			dbg_avg->snr_2ss_avg[0] = (u8)(dbg_statistic->snr_2ss_sum[0] /dbg_statistic->rssi_2ss_cnt);
+			dbg_avg->snr_2ss_avg[1] = (u8)(dbg_statistic->snr_2ss_sum[1] /dbg_statistic->rssi_2ss_cnt);
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* 2-ss Cnt= ((%d)) RSSI:{%d, %d}, EVM:{%d, %d}, SNR:{%d, %d}\n",
+			dbg_statistic->rssi_2ss_cnt, 
+			dbg_avg->rssi_2ss_avg[0], dbg_avg->rssi_2ss_avg[1], 
+			dbg_avg->evm_2ss_avg[0], dbg_avg->evm_2ss_avg[1], 
+			dbg_avg->snr_2ss_avg[0], dbg_avg->snr_2ss_avg[1]);
+	}
+	#endif
+
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
+		if (dbg_statistic->rssi_3ss_cnt != 0) {
+			dbg_avg->rssi_3ss_avg[0] = (u8)(dbg_statistic->rssi_3ss_sum[0] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->rssi_3ss_avg[1] = (u8)(dbg_statistic->rssi_3ss_sum[1] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->rssi_3ss_avg[2] = (u8)(dbg_statistic->rssi_3ss_sum[2] /dbg_statistic->rssi_3ss_cnt);
+			
+			dbg_avg->evm_3ss_avg[0] = (u8)(dbg_statistic->evm_3ss_sum[0] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->evm_3ss_avg[1] = (u8)(dbg_statistic->evm_3ss_sum[1] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->evm_3ss_avg[2] = (u8)(dbg_statistic->evm_3ss_sum[2] /dbg_statistic->rssi_3ss_cnt);
+
+			dbg_avg->snr_3ss_avg[0] = (u8)(dbg_statistic->snr_3ss_sum[0] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->snr_3ss_avg[1] = (u8)(dbg_statistic->snr_3ss_sum[1] /dbg_statistic->rssi_3ss_cnt);
+			dbg_avg->snr_3ss_avg[2] = (u8)(dbg_statistic->snr_3ss_sum[2] /dbg_statistic->rssi_3ss_cnt);
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* 3-ss Cnt= ((%d)) RSSI:{%d, %d, %d} EVM:{%d, %d, %d} SNR:{%d, %d, %d}\n",
+			dbg_statistic->rssi_3ss_cnt, 
+			dbg_avg->rssi_3ss_avg[0], dbg_avg->rssi_3ss_avg[1], dbg_avg->rssi_3ss_avg[2],
+			dbg_avg->evm_3ss_avg[0], dbg_avg->evm_3ss_avg[1], dbg_avg->evm_3ss_avg[2],
+			dbg_avg->snr_3ss_avg[0], dbg_avg->snr_3ss_avg[1], dbg_avg->snr_3ss_avg[2]);
+	}
+	#endif
+
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+		if (dbg_statistic->rssi_4ss_cnt != 0) {
+			dbg_avg->rssi_4ss_avg[0] = (u8)(dbg_statistic->rssi_4ss_sum[0] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[1] = (u8)(dbg_statistic->rssi_4ss_sum[1] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[2] = (u8)(dbg_statistic->rssi_4ss_sum[2] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[3] = (u8)(dbg_statistic->rssi_4ss_sum[3] /dbg_statistic->rssi_4ss_cnt);
+
+			dbg_avg->evm_4ss_avg[0] = (u8)(dbg_statistic->evm_4ss_sum[0] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[1] = (u8)(dbg_statistic->evm_4ss_sum[1] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[2] = (u8)(dbg_statistic->evm_4ss_sum[2] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[3] = (u8)(dbg_statistic->evm_4ss_sum[3] /dbg_statistic->rssi_4ss_cnt);
+
+			dbg_avg->snr_4ss_avg[0] = (u8)(dbg_statistic->snr_4ss_sum[0] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[1] = (u8)(dbg_statistic->snr_4ss_sum[1] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[2] = (u8)(dbg_statistic->snr_4ss_sum[2] /dbg_statistic->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[3] = (u8)(dbg_statistic->snr_4ss_sum[3] /dbg_statistic->rssi_4ss_cnt);
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "* 4-ss Cnt= ((%d)) RSSI:{%d, %d, %d, %d} EVM:{%d, %d, %d, %d} SNR:{%d, %d, %d, %d}\n",
+			dbg_statistic->rssi_4ss_cnt, 
+			dbg_avg->rssi_4ss_avg[0], dbg_avg->rssi_4ss_avg[1], dbg_avg->rssi_4ss_avg[2], dbg_avg->rssi_4ss_avg[3],
+			dbg_avg->evm_4ss_avg[0], dbg_avg->evm_4ss_avg[1], dbg_avg->evm_4ss_avg[2], dbg_avg->evm_4ss_avg[3],
+			dbg_avg->snr_4ss_avg[0], dbg_avg->snr_4ss_avg[1], dbg_avg->snr_4ss_avg[2], dbg_avg->snr_4ss_avg[3]);
+	}
+	#endif
+
+	
+
+}
+
+void
+phydm_get_phy_statistic(
+	void		*dm_void
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+	phydm_rx_rate_distribution(dm);
+	phydm_reset_rx_rate_distribution(dm);
+	
+	phydm_get_avg_phystatus_val(dm);
+	phydm_reset_phystatus_statistic(dm);
+};
+
+void
+phydm_basic_dbg_message
+(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct ra_table	*ra_tab = &dm->dm_ra_table;
+	u16	macid, phydm_macid, client_cnt = 0;
+	struct cmn_sta_info	*entry = NULL;
+	s32	tmp_val = 0;
+	u8	tmp_val_u1 = 0;
+
+	if (!(dm->debug_components & ODM_COMP_COMMON))
+		return;
+
+	if (dm->cmn_dbg_msg_cnt < dm->cmn_dbg_msg_period) {
+		dm->cmn_dbg_msg_cnt += PHYDM_WATCH_DOG_PERIOD;
+		return;
+	} else {
+		dm->cmn_dbg_msg_cnt = PHYDM_WATCH_DOG_PERIOD;
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[PHYDM Common MSG] System up time: ((%d sec))----->\n", dm->phydm_sys_up_time);
+
+	if (dm->is_linked) {
+		PHYDM_DBG(dm, ODM_COMP_COMMON,
+			  "ID=((%d)), BW=((%d)), fc=((CH-%d))\n", dm->curr_station_id, 20<<*dm->band_width, *dm->channel);
+
+		if ((*dm->channel <= 14) && (*dm->band_width == CHANNEL_WIDTH_40)) {
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "Primary CCA at ((%s SB))\n",
+				((*dm->sec_ch_offset == SECOND_CH_AT_LSB)?"U":"L"));
+		}
+
+		if ((dm->support_ic_type & PHYSTS_2ND_TYPE_IC) || dm->rx_rate > ODM_RATE11M) {
+			
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "[AGC Idx] {0x%x, 0x%x, 0x%x, 0x%x}\n",
+				dm->ofdm_agc_idx[0], dm->ofdm_agc_idx[1], dm->ofdm_agc_idx[2], dm->ofdm_agc_idx[3]);
+		} else {
+		
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "[CCK AGC Idx] {LNA, VGA}={0x%x, 0x%x}\n",
+				dm->cck_lna_idx, dm->cck_vga_idx);
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "RSSI:{%d, %d, %d, %d}, RxRate:",
+			(dm->rssi_a == 0xff) ? 0 : dm->rssi_a,
+			(dm->rssi_b == 0xff) ? 0 : dm->rssi_b,
+			(dm->rssi_c == 0xff) ? 0 : dm->rssi_c,
+			(dm->rssi_d == 0xff) ? 0 : dm->rssi_d);
+
+		phydm_print_rate(dm, dm->rx_rate, ODM_COMP_COMMON);
+
+		phydm_get_phy_statistic(dm);
+
+		/*Print TX rate*/
+		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+			entry = dm->phydm_sta_info[macid];
+			if (!is_sta_active(entry)) {
+				continue;
+			}
+
+			phydm_macid = (dm->phydm_macid_table[macid]);
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "TxRate[%d]:", macid);
+			phydm_print_rate(dm, entry->ra_info.curr_tx_rate, ODM_COMP_COMMON);
+
+			client_cnt++;
+
+			if (client_cnt >= dm->number_linked_client)
+				break;
+		}
+
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "TP {Tx, Rx, Total} = {%d, %d, %d}Mbps, Traffic_Load=(%d))\n",
+			dm->tx_tp, dm->rx_tp, dm->total_tp, dm->traffic_load);
+
+		tmp_val_u1 = (cfo_track->crystal_cap > cfo_track->def_x_cap) ? (cfo_track->crystal_cap - cfo_track->def_x_cap) : (cfo_track->def_x_cap - cfo_track->crystal_cap);
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "CFO_avg = ((%d kHz)) , CFO_tracking = ((%s%d))\n",
+			cfo_track->CFO_ave_pre, ((cfo_track->crystal_cap > cfo_track->def_x_cap) ? "+" : "-"), tmp_val_u1);
+
+		/* Condition number */
+	#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			tmp_val = phydm_get_condition_number_8822B(dm);
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "Condi_Num=((%d))\n", tmp_val);
+		}
+	#endif
+
+	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		/*STBC or LDPC pkt*/
+		if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC)
+			PHYDM_DBG(dm, ODM_COMP_COMMON, "Coding: LDPC=((%s)), STBC=((%s))\n", (dm->phy_dbg_info.is_ldpc_pkt) ? "Y" : "N", (dm->phy_dbg_info.is_stbc_pkt) ? "Y" : "N");
+	#endif
+	} else
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "No Link !!!\n");
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all);
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all);
+
+	#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		PHYDM_DBG(dm, ODM_COMP_COMMON, "[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), CRC8_fail = (( %d )), Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d ))\n",
+			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail);
+	}
+	#endif
+
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "is_linked = %d, Num_client = %d, rssi_min = %d, IGI = 0x%x, bNoisy=%d\n\n",
+		dm->is_linked, dm->number_linked_client, dm->rssi_min, dig_t->cur_ig_value, dm->noisy_decision);
+}
+
+
+void phydm_basic_profile(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	char  *cut = NULL;
+	char *ic_type = NULL;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32	date = 0;
+	char	*commit_by = NULL;
+	u32	release_ver = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "% Basic Profile %");
+
+	if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		ic_type = "RTL8188E";
+		date = RELEASE_DATE_8188E;
+		commit_by = COMMIT_BY_8188E;
+		release_ver = RELEASE_VERSION_8188E;
+#endif
+	}
+#if (RTL8812A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8812) {
+		ic_type = "RTL8812A";
+		date = RELEASE_DATE_8812A;
+		commit_by = COMMIT_BY_8812A;
+		release_ver = RELEASE_VERSION_8812A;
+	}
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821) {
+		ic_type = "RTL8821A";
+		date = RELEASE_DATE_8821A;
+		commit_by = COMMIT_BY_8821A;
+		release_ver = RELEASE_VERSION_8821A;
+	}
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		ic_type = "RTL8192E";
+		date = RELEASE_DATE_8192E;
+		commit_by = COMMIT_BY_8192E;
+		release_ver = RELEASE_VERSION_8192E;
+	}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		ic_type = "RTL8723B";
+		date = RELEASE_DATE_8723B;
+		commit_by = COMMIT_BY_8723B;
+		release_ver = RELEASE_VERSION_8723B;
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8814A) {
+		ic_type = "RTL8814A";
+		date = RELEASE_DATE_8814A;
+		commit_by = COMMIT_BY_8814A;
+		release_ver = RELEASE_VERSION_8814A;
+	}
+#endif
+#if (RTL8881A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8881A) {
+		ic_type = "RTL8881A";
+		/**/
+	}
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		ic_type = "RTL8822B";
+		date = RELEASE_DATE_8822B;
+		commit_by = COMMIT_BY_8822B;
+		release_ver = RELEASE_VERSION_8822B;
+	}
+#endif
+#if (RTL8197F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8197F) {
+		ic_type = "RTL8197F";
+		date = RELEASE_DATE_8197F;
+		commit_by = COMMIT_BY_8197F;
+		release_ver = RELEASE_VERSION_8197F;
+	}
+#endif
+
+#if (RTL8703B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8703B) {
+		ic_type = "RTL8703B";
+		date = RELEASE_DATE_8703B;
+		commit_by = COMMIT_BY_8703B;
+		release_ver = RELEASE_VERSION_8703B;
+
+	}
+#endif
+#if (RTL8195A_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8195A) {
+		ic_type = "RTL8195A";
+		/**/
+	}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8188F) {
+		ic_type = "RTL8188F";
+		date = RELEASE_DATE_8188F;
+		commit_by = COMMIT_BY_8188F;
+		release_ver = RELEASE_VERSION_8188F;
+	}
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		ic_type = "RTL8723D";
+		date = RELEASE_DATE_8723D;
+		commit_by = COMMIT_BY_8723D;
+		release_ver = RELEASE_VERSION_8723D;
+		/**/
+	}
+#endif
+
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8710B) {
+		ic_type = "RTL8710B";
+		date = RELEASE_DATE_8710B;
+		commit_by = COMMIT_BY_8710B;
+		release_ver = RELEASE_VERSION_8710B;
+		/**/
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		ic_type = "RTL8821C";
+		date = RELEASE_DATE_8821C;
+		commit_by = COMMIT_BY_8821C;
+		release_ver = RELEASE_VERSION_8821C;
+	}
+#endif
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s (MP Chip: %s)\n", "IC type", ic_type,
+		       dm->is_mp_chip ? "Yes" : "No");
+
+	if (dm->cut_version == ODM_CUT_A)
+		cut = "A";
+	else if (dm->cut_version == ODM_CUT_B)
+		cut = "B";
+	else if (dm->cut_version == ODM_CUT_C)
+		cut = "C";
+	else if (dm->cut_version == ODM_CUT_D)
+		cut = "D";
+	else if (dm->cut_version == ODM_CUT_E)
+		cut = "E";
+	else if (dm->cut_version == ODM_CUT_F)
+		cut = "F";
+	else if (dm->cut_version == ODM_CUT_I)
+		cut = "I";
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "RFE type", dm->rfe_type);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Cut Ver", cut);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "PHY Para Ver",
+		       odm_get_hw_img_version(dm));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "PHY Para Commit date", date);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "PHY Para Commit by", commit_by);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %d\n", "PHY Para Release Ver", release_ver);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	{
+		void		*adapter = dm->adapter;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       ((PADAPTER)adapter)->MgntInfo.FirmwareVersion,
+			       ((PADAPTER)adapter)->MgntInfo.FirmwareSubVersion);
+	}
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	{
+		struct rtl8192cd_priv *priv = dm->priv;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       priv->pshare->fw_version,
+			       priv->pshare->fw_sub_version);
+	}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	{
+		struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+		struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       rtlhal->fw_version, rtlhal->fw_subversion);
+	}
+#else
+	{
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %d (Subversion: %d)\n", "FW Ver",
+			       hal_data->firmware_version,
+			       hal_data->firmware_sub_version);
+	}
+#endif
+	/* 1 PHY DM version List */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "% PHYDM version %");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Code base", PHYDM_CODE_BASE);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Release Date", PHYDM_RELEASE_DATE);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Adaptivity", ADAPTIVITY_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "DIG", DIG_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "CFO Tracking", CFO_TRACKING_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "AntDiv", ANTDIV_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Dynamic TxPower",
+		       DYNAMIC_TXPWR_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "RA Info", RAINFO_VERSION);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "AntDetect", ANTDECT_VERSION);
+#endif
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "PathDiv", PATHDIV_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "LA mode", DYNAMIC_LA_MODE);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "Primary CCA", PRIMARYCCA_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "  %-35s: %s\n", "DFS", DFS_VERSION);
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %s\n", "PHY config 8822B",
+			       PHY_CONFIG_VERSION_8822B);
+
+#endif
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %-35s: %s\n", "PHY config 8197F",
+			       PHY_CONFIG_VERSION_8197F);
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+	
+	/* RF Function version List */
+	halrf_basic_profile(dm_void, &used, output, &out_len);
+
+#endif /*#if CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+void
+phydm_fw_trace_en_h2c(
+	void		*dm_void,
+	boolean		enable,
+	u32		fw_debug_component,
+	u32		monitor_mode,
+	u32		macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			h2c_parameter[7] = {0};
+	u8			cmd_length;
+
+	if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+		h2c_parameter[0] = enable;
+		h2c_parameter[1] = (u8)(fw_debug_component & MASKBYTE0);
+		h2c_parameter[2] = (u8)((fw_debug_component & MASKBYTE1) >> 8);
+		h2c_parameter[3] = (u8)((fw_debug_component & MASKBYTE2) >> 16);
+		h2c_parameter[4] = (u8)((fw_debug_component & MASKBYTE3) >> 24);
+		h2c_parameter[5] = (u8)monitor_mode;
+		h2c_parameter[6] = (u8)macid;
+		cmd_length = 7;
+
+	} else {
+		h2c_parameter[0] = enable;
+		h2c_parameter[1] = (u8)monitor_mode;
+		h2c_parameter[2] = (u8)macid;
+		cmd_length = 3;
+	}
+
+
+	PHYDM_DBG(dm, DBG_FW_TRACE, "---->\n");
+	if (monitor_mode == 0)
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[H2C] FW_debug_en: (( %d ))\n", enable);
+	else
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[H2C] FW_debug_en: (( %d )), mode: (( %d )), macid: (( %d ))\n", enable, monitor_mode, macid);
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_FW_TRACE_EN, cmd_length, h2c_parameter);
+}
+
+void
+phydm_get_per_path_txagc(
+	void			*dm_void,
+	u8			path,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			rate_idx;
+	u8			txagc;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+	if (((dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) && (path <= RF_PATH_B)) ||
+		((dm->support_ic_type & (ODM_RTL8821C)) && (path <= RF_PATH_A))) {
+		for (rate_idx = 0; rate_idx <= 0x53; rate_idx++) {
+			if (rate_idx == ODM_RATE1M)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "  %-35s\n",
+					       "CCK====>");
+			else if (rate_idx == ODM_RATE6M)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "OFDM====>");
+			else if (rate_idx == ODM_RATEMCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 1ss====>");
+			else if (rate_idx == ODM_RATEMCS8)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 2ss====>");
+			else if (rate_idx == ODM_RATEMCS16)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 3ss====>");
+			else if (rate_idx == ODM_RATEMCS24)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "HT 4ss====>");
+			else if (rate_idx == ODM_RATEVHTSS1MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 1ss====>");
+			else if (rate_idx == ODM_RATEVHTSS2MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 2ss====>");
+			else if (rate_idx == ODM_RATEVHTSS3MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 3ss====>");
+			else if (rate_idx == ODM_RATEVHTSS4MCS0)
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "\n  %-35s\n",
+					       "VHT 4ss====>");
+
+			txagc = phydm_api_get_txagc(dm, (enum rf_path) path, rate_idx);
+			if (config_phydm_read_txagc_check(txagc))
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "  0x%02x    ",
+					       txagc);
+			else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "  0x%s    ",
+					       "xx");
+		}
+	}
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+
+}
+
+
+void
+phydm_get_txagc(
+	void			*dm_void,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	/* path-A */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "%-35s\n", "path-A====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_A, &used, output, &out_len);
+
+	/* path-B */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\n%-35s\n", "path-B====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_B, &used, output, &out_len);
+
+	/* path-C */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\n%-35s\n", "path-C====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_C, &used, output, &out_len);
+
+	/* path-D */
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "\n%-35s\n", "path-D====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_D, &used, output, &out_len);
+
+	*_used = used;
+	*_out_len = out_len;
+
+}
+
+void
+phydm_set_txagc(
+	void			*dm_void,
+	u32			*const dm_value,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u8	i;
+	u32	power_index;
+	boolean	status = true;
+
+	/*dm_value[1] = path*/
+	/*dm_value[2] = hw_rate*/
+	/*dm_value[3] = power_index*/
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+	if ((dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)) == 0)
+		return;
+	
+	if (dm_value[1] >= dm->num_rf_path) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "  %s%d   %s%x%s\n", "Write path-",
+			       (dm_value[1] & 0x1), "rate index-0x",
+			       (dm_value[2] & 0x7f), " fail");
+	} else if ((u8)dm_value[2] != 0xff) {
+		if (phydm_api_set_txagc(dm, dm_value[3], (enum rf_path) dm_value[1], (u8)dm_value[2], true))
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s%x%s%x\n",
+				       "Write path-", dm_value[1],
+				       "rate index-0x", dm_value[2], " = 0x",
+				       dm_value[3]);
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s%x%s\n",
+				       "Write path-", (dm_value[1] & 0x1),
+				       "rate index-0x", (dm_value[2] & 0x7f),
+				       " fail");
+	} else {
+		power_index = (dm_value[3] & 0x3f);
+
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+			power_index = (power_index << 24) | (power_index << 16) | (power_index << 8) | (power_index);
+
+			for (i = 0; i < ODM_RATEVHTSS2MCS9; i += 4)
+				status = (status & phydm_api_set_txagc(dm, power_index, (enum rf_path) dm_value[1], i, false));
+		} else if (dm->support_ic_type & ODM_RTL8197F) {
+			for (i = 0; i <= ODM_RATEMCS15; i++)
+				status = (status & phydm_api_set_txagc(dm, power_index, (enum rf_path) dm_value[1], i, false));
+		}
+
+		if (status)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s%x\n",
+				       "Write all TXAGC of path-",
+				       dm_value[1], " = 0x", dm_value[3]);
+		else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %s%d   %s\n",
+				       "Write all TXAGC of path-",
+				       dm_value[1], " fail");
+	}
+
+#endif
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_debug_trace(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u64			pre_debug_components, one = 1;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			dm_value[10] = {0};
+
+	u8	i;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+		}
+	}
+
+	pre_debug_components = dm->debug_components;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n================================\n");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "[DBG MSG] Component Selection\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "================================\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used, "00. (( %s ))DIG\n",
+			       ((dm->debug_components & DBG_DIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "01. (( %s ))RA_MASK\n",
+			       ((dm->debug_components & DBG_RA_MASK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "02. (( %s ))DYN_TXPWR\n",
+			       ((dm->debug_components & DBG_DYN_TXPWR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "03. (( %s ))FA_CNT\n",
+			       ((dm->debug_components & DBG_FA_CNT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "04. (( %s ))RSSI_MNTR\n",
+			       ((dm->debug_components & DBG_RSSI_MNTR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "05. (( %s ))CCKPD\n",
+			       ((dm->debug_components & DBG_CCKPD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "06. (( %s ))ANT_DIV\n",
+			       ((dm->debug_components & DBG_ANT_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "07. (( %s ))SMT_ANT\n",
+			       ((dm->debug_components & DBG_SMT_ANT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "08. (( %s ))PWR_TRAIN\n",
+			       ((dm->debug_components & F08_PWR_TRAIN) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "09. (( %s ))RA\n",
+			       ((dm->debug_components & DBG_RA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "10. (( %s ))PATH_DIV\n",
+			       ((dm->debug_components & DBG_PATH_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "11. (( %s ))DFS\n",
+			       ((dm->debug_components & DBG_DFS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "12. (( %s ))DYN_ARFR\n",
+			       ((dm->debug_components & DBG_DYN_ARFR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "13. (( %s ))ADAPTIVITY\n",
+			       ((dm->debug_components & DBG_ADPTVTY) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "14. (( %s ))CFO_TRK\n",
+			       ((dm->debug_components & DBG_CFO_TRK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "15. (( %s ))ENV_MNTR\n",
+			       ((dm->debug_components & DBG_ENV_MNTR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "16. (( %s ))PRI_CCA\n",
+			       ((dm->debug_components & DBG_PRI_CCA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "17. (( %s ))ADPTV_SOML\n",
+			       ((dm->debug_components & DBG_ADPTV_SOML) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "18. (( %s ))LNA_SAT_CHK\n",
+			       ((dm->debug_components & DBG_LNA_SAT_CHK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "19. (( %s ))DRP\n",
+			       ((dm->debug_components & DBG_DYN_RX_PATH) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "20. (( %s ))PHY_STATUS\n",
+			       ((dm->debug_components & DBG_PHY_STATUS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "21. (( %s ))TMP\n",
+			       ((dm->debug_components & DBG_TMP) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "22. (( %s ))FW_DBG_TRACE\n",
+			       ((dm->debug_components & DBG_FW_TRACE) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "23. (( %s ))TXBF\n",
+			       ((dm->debug_components & DBG_TXBF) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "24. (( %s ))COMMON_FLOW\n",
+			       ((dm->debug_components & DBG_COMMON_FLOW) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "25. (( %s ))TX_PWR_TRK\n",
+			       ((dm->debug_components & ODM_COMP_TX_PWR_TRACK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "26. (( %s ))CALIBRATION\n",
+			       ((dm->debug_components & ODM_COMP_CALIBRATION) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "27. (( %s ))MP\n",
+			       ((dm->debug_components & ODM_COMP_MP) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "28. (( %s ))PHY_CONFIG\n",
+			       ((dm->debug_components & ODM_PHY_CONFIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "29. (( %s ))INIT\n",
+			       ((dm->debug_components & ODM_COMP_INIT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "30. (( %s ))COMMON\n",
+			       ((dm->debug_components & ODM_COMP_COMMON) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "31. (( %s ))API\n",
+			       ((dm->debug_components & ODM_COMP_API) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used, "================================\n");
+
+	} else if (dm_value[0] == 101) {
+		dm->debug_components = 0;
+		PDM_SNPF(out_len, used, output + used, out_len - used, "Disable all debug components\n");
+	} else {
+		if (dm_value[1] == 1)   /*enable*/
+			dm->debug_components |= (one << dm_value[0]);
+		else if (dm_value[1] == 2)   /*disable*/
+			dm->debug_components &= ~(one << dm_value[0]);
+		else
+			PDM_SNPF(out_len, used, output + used, out_len - used, "[Warning]  1:on,  2:off\n");
+
+		if ((BIT(dm_value[0]) == DBG_PHY_STATUS) && (dm_value[1] == 1)) {
+
+			dm->phy_dbg_info.show_phy_sts_all_pkt = (u8)dm_value[2];
+			dm->phy_dbg_info.show_phy_sts_max_cnt = (u16)dm_value[3];
+
+			PDM_SNPF(out_len, used, output + used, out_len - used, "show_phy_sts_all_pkt=%d, show_phy_sts_max=%d\n\n",
+				dm->phy_dbg_info.show_phy_sts_all_pkt,
+				dm->phy_dbg_info.show_phy_sts_max_cnt);
+
+		} else if ((BIT(dm_value[0]) == ODM_COMP_COMMON) && (dm_value[1] == 1)) {
+			dm->cmn_dbg_msg_period = (u8)dm_value[2];
+
+			if (dm->cmn_dbg_msg_period < PHYDM_WATCH_DOG_PERIOD)
+				dm->cmn_dbg_msg_period = PHYDM_WATCH_DOG_PERIOD;
+
+			PDM_SNPF(out_len, used, output + used, out_len - used, "cmn_dbg_msg_period=%d\n",
+				dm->cmn_dbg_msg_period);
+		}
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "pre-DbgComponents = 0x%llx\n", pre_debug_components);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Curr-DbgComponents = 0x%llx\n", dm->debug_components);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "================================\n");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_fw_debug_trace(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			pre_fw_debug_components, one = 1;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	pre_fw_debug_components = dm->fw_debug_components;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%s\n",
+		       "================================");
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "[FW Debug Component]");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "00. (( %s ))RA\n",
+			       ((dm->fw_debug_components & PHYDM_FW_COMP_RA) ? ("V") : (".")));
+
+		if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "01. (( %s ))MU\n",
+				       ((dm->fw_debug_components & PHYDM_FW_COMP_MU) ? ("V") : (".")));
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "02. (( %s ))path Div\n",
+				       ((dm->fw_debug_components & PHYDM_FW_COMP_PATH_DIV) ? ("V") : (".")));
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "03. (( %s ))Power training\n",
+				       ((dm->fw_debug_components & PHYDM_FW_COMP_PT) ? ("V") : (".")));
+		}
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "================================");
+
+	} else {
+		if (dm_value[0] == 101) {
+			dm->fw_debug_components = 0;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "%s\n",
+				       "Clear all fw debug components");
+		} else {
+			if (dm_value[1] == 1)   /*enable*/
+				dm->fw_debug_components |= (one << dm_value[0]);
+			else if (dm_value[1] == 2)   /*disable*/
+				dm->fw_debug_components &= ~(one << dm_value[0]);
+			else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used, "%s\n",
+					       "[Warning!!!]  1:enable,  2:disable");
+		}
+
+		if (dm->fw_debug_components == 0) {
+			dm->debug_components &= ~DBG_FW_TRACE;
+			phydm_fw_trace_en_h2c(dm, false, dm->fw_debug_components, dm_value[2], dm_value[3]); /*H2C to enable C2H Msg*/
+		} else {
+			dm->debug_components |= DBG_FW_TRACE;
+			phydm_fw_trace_en_h2c(dm, true, dm->fw_debug_components, dm_value[2], dm_value[3]); /*H2C to enable C2H Msg*/
+		}
+	}
+}
+
+void
+phydm_dump_bb_reg(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			addr = 0;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+
+	/* BB Reg, For Nseries IC we only need to dump page8 to pageF using 3 digits*/
+	for (addr = 0x800; addr < 0xfff; addr += 4) {
+		if (dm->support_ic_type & ODM_IC_11N_SERIES)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%03x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+		else
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8814A | ODM_RTL8821C)) {
+		if (dm->rf_type > RF_2T2R) {
+			for (addr = 0x1800; addr < 0x18ff; addr += 4)
+				PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+							 "0x%04x 0x%08x\n",
+							 addr,
+							 odm_get_bb_reg(dm, addr, MASKDWORD));
+		}
+
+		if (dm->rf_type > RF_3T3R) {
+			for (addr = 0x1a00; addr < 0x1aff; addr += 4)
+				PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+							 "0x%04x 0x%08x\n",
+							 addr,
+							 odm_get_bb_reg(dm, addr, MASKDWORD));
+		}
+
+		for (addr = 0x1900; addr < 0x19ff; addr += 4)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+		for (addr = 0x1c00; addr < 0x1cff; addr += 4)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+		for (addr = 0x1f00; addr < 0x1fff; addr += 4)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used,
+					       out_len - used,
+						 "0x%04x 0x%08x\n", addr,
+						 odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_dump_all_reg(
+	void			*dm_void,
+	u32			*_used,
+	char				*output,
+	u32			*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			addr = 0;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	/* dump MAC register */
+	PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+				 "MAC==========\n");
+	for (addr = 0; addr < 0x7ff; addr += 4)
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "0x%04x 0x%08x\n",
+					 addr,
+					 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+	for (addr = 0x1000; addr < 0x17ff; addr += 4)
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "0x%04x 0x%08x\n",
+					 addr,
+					 odm_get_bb_reg(dm, addr, MASKDWORD));
+
+	/* dump BB register */
+	PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+				 "BB==========\n");
+	phydm_dump_bb_reg(dm, &used, output, &out_len);
+
+	/* dump RF register */
+	PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+				 "RF-A==========\n");
+	for (addr = 0; addr < 0xFF; addr++)
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "0x%02x 0x%05x\n",
+					 addr,
+					 odm_get_rf_reg(dm, RF_PATH_A, addr, RFREGOFFSETMASK));
+
+	if (dm->rf_type > RF_1T1R) {
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "RF-B==========\n");
+		for (addr = 0; addr < 0xFF; addr++)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+						 "0x%02x 0x%05x\n", addr,
+						 odm_get_rf_reg(dm, RF_PATH_B, addr, RFREGOFFSETMASK));
+	}
+
+	if (dm->rf_type > RF_2T2R) {
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "RF-C==========\n");
+		for (addr = 0; addr < 0xFF; addr++)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+						 "0x%02x 0x%05x\n", addr,
+						 odm_get_rf_reg(dm, RF_PATH_C, addr, RFREGOFFSETMASK));
+	}
+
+	if (dm->rf_type > RF_3T3R) {
+		PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used, "RF-D==========\n");
+		for (addr = 0; addr < 0xFF; addr++)
+			PHYDM_VAST_INFO_SNPRINTF(out_len, used, output + used, out_len - used,
+						 "0x%02x 0x%05x\n", addr,
+						 odm_get_rf_reg(dm, RF_PATH_D, addr, RFREGOFFSETMASK));
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_enable_big_jump(
+	struct dm_struct	*dm,
+	boolean		state
+)
+{
+#if (RTL8822B_SUPPORT == 1)
+	struct phydm_dig_struct			*dig_t = &dm->dm_dig_table;
+
+	if (state == false) {
+		dm->dm_dig_table.enable_adjust_big_jump = false;
+		odm_set_bb_reg(dm, 0x8c8, 0xfe, ((dig_t->big_jump_step3 << 5) | (dig_t->big_jump_step2 << 3) | dig_t->big_jump_step1));
+	} else
+		dm->dm_dig_table.enable_adjust_big_jump = true;
+#endif
+}
+
+#if (RTL8822B_SUPPORT == 1 | RTL8821C_SUPPORT == 1 | RTL8814B_SUPPORT == 1)
+
+void
+phydm_show_rx_rate(
+	struct dm_struct			*dm,
+	u32			*_used,
+	char			*output,
+	u32			*_out_len
+)
+{
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "=====Rx SU rate Statistics=====\n");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS0 = %d, 1SS MCS1 = %d, 1SS MCS2 = %d, 1SS MCS 3 = %d\n",
+		       dm->phy_dbg_info.num_qry_vht_pkt[0],
+		       dm->phy_dbg_info.num_qry_vht_pkt[1],
+		       dm->phy_dbg_info.num_qry_vht_pkt[2],
+		       dm->phy_dbg_info.num_qry_vht_pkt[3]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS4 = %d, 1SS MCS5 = %d, 1SS MCS6 = %d, 1SS MCS 7 = %d\n",
+		       dm->phy_dbg_info.num_qry_vht_pkt[4],
+		       dm->phy_dbg_info.num_qry_vht_pkt[5],
+		       dm->phy_dbg_info.num_qry_vht_pkt[6],
+		       dm->phy_dbg_info.num_qry_vht_pkt[7]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS8 = %d, 1SS MCS9 = %d\n",
+		       dm->phy_dbg_info.num_qry_vht_pkt[8],
+		       dm->phy_dbg_info.num_qry_vht_pkt[9]);
+			   
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {			   
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS0 = %d, 2SS MCS1 = %d, 2SS MCS2 = %d, 2SS MCS 3 = %d\n",
+				   dm->phy_dbg_info.num_qry_vht_pkt[10],
+				   dm->phy_dbg_info.num_qry_vht_pkt[11],
+				   dm->phy_dbg_info.num_qry_vht_pkt[12],
+				   dm->phy_dbg_info.num_qry_vht_pkt[13]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS4 = %d, 2SS MCS5 = %d, 2SS MCS6 = %d, 2SS MCS 7 = %d\n",
+				   dm->phy_dbg_info.num_qry_vht_pkt[14],
+				   dm->phy_dbg_info.num_qry_vht_pkt[15],
+				   dm->phy_dbg_info.num_qry_vht_pkt[16],
+				   dm->phy_dbg_info.num_qry_vht_pkt[17]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS8 = %d, 2SS MCS9 = %d\n",
+				   dm->phy_dbg_info.num_qry_vht_pkt[18],
+				   dm->phy_dbg_info.num_qry_vht_pkt[19]);
+	}
+#endif
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "=====Rx MU rate Statistics=====\n");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS0 = %d, 1SS MCS1 = %d, 1SS MCS2 = %d, 1SS MCS 3 = %d\n",
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[0],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[1],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[2],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[3]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS4 = %d, 1SS MCS5 = %d, 1SS MCS6 = %d, 1SS MCS 7 = %d\n",
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[4],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[5],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[6],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[7]);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "1SS MCS8 = %d, 1SS MCS9 = %d\n",
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[8],
+		       dm->phy_dbg_info.num_qry_mu_vht_pkt[9]);
+			   
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {			   
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS0 = %d, 2SS MCS1 = %d, 2SS MCS2 = %d, 2SS MCS 3 = %d\n",
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[10],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[11],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[12],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[13]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS4 = %d, 2SS MCS5 = %d, 2SS MCS6 = %d, 2SS MCS 7 = %d\n",
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[14],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[15],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[16],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[17]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				   "2SS MCS8 = %d, 2SS MCS9 = %d\n",
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[18],
+				   dm->phy_dbg_info.num_qry_mu_vht_pkt[19]);
+	}
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif
+
+void
+phydm_per_tone_evm(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		i, j;
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		var1[4] = {0};
+	u32		value32, tone_num, round;
+	s8		rxevm_0, rxevm_1;
+	s32		avg_num, evm_tone_0[256] = {0}, evm_tone_1[256] = {0};
+	s32		rxevm_sum_0, rxevm_sum_1;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		pr_debug("n series not support yet !\n");
+		return;
+	}
+
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+	}
+	avg_num = var1[0];
+	round = var1[1];
+
+	if (dm->is_linked) {
+		pr_debug("ID=((%d)), BW=((%d)), fc=((CH-%d))\n", dm->curr_station_id,
+		          20<<*dm->band_width, *dm->channel);
+		pr_debug("avg_num =((%d)), round =((%d))\n", avg_num, round);
+		#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+		watchdog_stop(dm->priv);
+		#endif
+		for (j = 0; j < round; j++) {
+			pr_debug("\nround((%d))\n", (j + 1));
+		if (*dm->band_width == CHANNEL_WIDTH_20) {
+			for (tone_num = 228; tone_num <= 255; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone((-%-3d)) RXEVM (1ss/2ss) =%d , %d\n", (256 - tone_num), evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+
+			for (tone_num = 1; tone_num <= 28; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(( %-3d)) RXEVM (1ss/2ss) =%d , %d\n", tone_num, evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+		} else if (*dm->band_width == CHANNEL_WIDTH_40) {
+			for (tone_num = 198; tone_num <= 254; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone((-%-3d)) RXEVM (1ss/2ss) =%d , %d\n", (256 - tone_num), evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+
+			for (tone_num = 2; tone_num <= 58; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(( %-3d)) RXEVM (1ss/2ss) =%d , %d\n", tone_num, evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+		} else if (*dm->band_width == CHANNEL_WIDTH_80) {
+			for (tone_num = 134; tone_num <= 254; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone((-%-3d)) RXEVM (1ss/2ss) =%d , %d\n", (256 - tone_num), evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+
+			for (tone_num = 2; tone_num <= 122; tone_num++) {
+				odm_set_bb_reg(dm, 0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					value32 = odm_get_bb_reg(dm, 0xF8c, MASKDWORD);
+
+					rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(( %-3d)) RXEVM (1ss/2ss) =%d , %d\n", tone_num, evm_tone_0[tone_num], evm_tone_1[tone_num]);
+			}
+			}
+		}
+	} else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+		               "No Link !!\n");
+
+}
+
+void
+phydm_api_adjust(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+	boolean	is_enable_dbg_mode;
+	u8 central_ch, primary_ch_idx;
+	enum channel_width	bandwidth;
+	
+#ifdef PHYDM_COMMON_API_SUPPORT
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{en} {ch_num} {prm_ch 1/2/3/4/9/10} {0:20M, 1:40M, 2:80M}\n");
+		goto out;
+
+	}
+
+	if ((dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "This IC doesn't support PHYDM API function\n");
+		/**/
+		goto out;
+	}
+
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+	}
+
+	is_enable_dbg_mode = (boolean)var1[0];
+	central_ch = (u8) var1[1];
+	primary_ch_idx = (u8) var1[2];
+	bandwidth = (enum channel_width)var1[3];
+
+	if (is_enable_dbg_mode) {
+		dm->is_disable_phy_api = false;
+		phydm_api_switch_bw_channel(dm, central_ch, primary_ch_idx, bandwidth);
+		dm->is_disable_phy_api = true;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "central_ch = %d, primary_ch_idx = %d, bandwidth = %d\n",
+			       central_ch, primary_ch_idx, bandwidth);
+	} else {
+		dm->is_disable_phy_api = false;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Disable API debug mode\n");
+	}
+out:
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "This IC doesn't support PHYDM API function\n");
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_parameter_adjust(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct				*cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(dm, PHYDM_CFOTRACK);
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "1. X_cap = ((0x%x))\n",
+			       cfo_track->crystal_cap);
+
+	} else {
+	
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 0) {
+			PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
+			phydm_set_crystal_cap(dm, (u8)var1[1]);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "X_cap = ((0x%x))\n",
+				       cfo_track->crystal_cap);
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+struct phydm_command {
+	char name[16];
+	u8 id;
+};
+
+enum PHYDM_CMD_ID {
+	PHYDM_HELP,
+	PHYDM_DEMO,
+	PHYDM_DIG,
+	PHYDM_RA,
+	PHYDM_PROFILE,
+	PHYDM_ANTDIV,
+	PHYDM_PATHDIV,
+	PHYDM_DEBUG,
+	PHYDM_FW_DEBUG,
+	PHYDM_SUPPORT_ABILITY,
+	PHYDM_RF_SUPPORTABILITY,
+	PHYDM_RF_PROFILE,
+	PHYDM_RF_IQK_INFO,
+	PHYDM_IQK,
+	PHYDM_IQK_DEBUG,
+	PHYDM_GET_TXAGC,
+	PHYDM_SET_TXAGC,
+	PHYDM_SMART_ANT,
+	PHYDM_API,
+	PHYDM_TRX_PATH,
+	PHYDM_LA_MODE,
+	PHYDM_DUMP_REG,
+	PHYDM_AUTO_DBG,
+	PHYDM_BIG_JUMP,
+	PHYDM_SHOW_RXRATE,
+	PHYDM_NBI_EN,
+	PHYDM_CSI_MASK_EN,
+	PHYDM_DFS_DEBUG,
+	PHYDM_NHM,
+	PHYDM_CLM,
+	PHYDM_FAHM,
+	PHYDM_ENV_MNTR,
+	PHYDM_BB_INFO,
+	PHYDM_TXBF,
+	PHYDM_H2C,
+	PHYDM_ANT_SWITCH,
+	PHYDM_DYNAMIC_RA_PATH,
+	PHYDM_ADAPTIVE_SOML,
+	PHYDM_PSD,
+	PHYDM_DEBUG_PORT,
+	PHYDM_DIS_HTSTF_CONTROL,
+	PHYDM_TUNE_PARAMETER,
+	PHYDM_ADAPTIVITY_DEBUG,
+	PHYDM_DIS_DYM_ANT_WEIGHTING,
+	PHYDM_FORECE_PT_STATE,
+	PHYDM_DIS_RXHP_CTR,
+	PHYDM_STA_INFO,
+	PHYDM_PAUSE_FUNC,
+	PHYDM_PER_TONE_EVM
+};
+
+struct phydm_command phy_dm_ary[] = {
+	{"-h", PHYDM_HELP},		/*do not move this element to other position*/
+	{"demo", PHYDM_DEMO},	/*do not move this element to other position*/
+	{"dig", PHYDM_DIG},	
+	{"ra", PHYDM_RA},
+	{"profile", PHYDM_PROFILE},
+	{"antdiv", PHYDM_ANTDIV},
+	{"pathdiv", PHYDM_PATHDIV},
+	{"dbg", PHYDM_DEBUG},
+	{"fw_dbg", PHYDM_FW_DEBUG},
+	{"ability", PHYDM_SUPPORT_ABILITY},
+	{"rf_ability", PHYDM_RF_SUPPORTABILITY},
+	{"rf_profile", PHYDM_RF_PROFILE},
+	{"iqk_info", PHYDM_RF_IQK_INFO},
+	{"iqk", PHYDM_IQK},
+	{"iqk_dbg", PHYDM_IQK_DEBUG},
+	{"get_txagc", PHYDM_GET_TXAGC},
+	{"set_txagc", PHYDM_SET_TXAGC},
+	{"smtant", PHYDM_SMART_ANT},
+	{"api", PHYDM_API},
+	{"trxpath", PHYDM_TRX_PATH},
+	{"lamode", PHYDM_LA_MODE},
+	{"dumpreg", PHYDM_DUMP_REG},
+	{"auto_dbg", PHYDM_AUTO_DBG},
+	{"bigjump", PHYDM_BIG_JUMP},
+	{"rxrate", PHYDM_SHOW_RXRATE},
+	{"nbi", PHYDM_NBI_EN},
+	{"csi_mask", PHYDM_CSI_MASK_EN},
+	{"dfs", PHYDM_DFS_DEBUG},
+	{"nhm", PHYDM_NHM},
+	{"clm", PHYDM_CLM},
+	{"fahm", PHYDM_FAHM},
+	{"env_mntr", PHYDM_ENV_MNTR},	
+	{"bbinfo", PHYDM_BB_INFO},
+	{"txbf", PHYDM_TXBF},
+	{"h2c", PHYDM_H2C},
+	{"ant_switch", PHYDM_ANT_SWITCH},
+	{"drp", PHYDM_DYNAMIC_RA_PATH},
+	{"soml", PHYDM_ADAPTIVE_SOML},
+	{"psd", PHYDM_PSD},
+	{"dbgport", PHYDM_DEBUG_PORT},
+	{"dis_htstf", PHYDM_DIS_HTSTF_CONTROL},
+	{"tune_para", PHYDM_TUNE_PARAMETER},
+	{"adapt_debug", PHYDM_ADAPTIVITY_DEBUG},
+	{"dis_dym_ant_wgt", PHYDM_DIS_DYM_ANT_WEIGHTING},
+	{"force_pt_state", PHYDM_FORECE_PT_STATE},
+	{"dis_drxhp", PHYDM_DIS_RXHP_CTR},
+	{"sta_info", PHYDM_STA_INFO},
+	{"pause", PHYDM_PAUSE_FUNC},
+	{"evm", PHYDM_PER_TONE_EVM}
+};
+
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+
+void
+phydm_cmd_parser(
+	struct dm_struct	*dm,
+	char		input[][MAX_ARGV],
+	u32	input_num,
+	u8	flag,
+	char		*output,
+	u32	out_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	u32 used = 0;
+	u8 id = 0;
+	int var1[10] = {0};
+	int i, input_idx = 0, phydm_ary_size = sizeof(phy_dm_ary) / sizeof(struct phydm_command);
+	char help[] = "-h";
+
+	if (flag == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "GET, nothing to print\n");
+		return;
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n");
+
+	/* Parsing Cmd ID */
+	if (input_num) {
+		for (i = 0; i < phydm_ary_size; i++) {
+			if (strcmp(phy_dm_ary[i].name, input[0]) == 0) {
+				id = phy_dm_ary[i].id;
+				break;
+			}
+		}
+		if (i == phydm_ary_size) {
+			PDM_SNPF(out_len, used, output + used, out_len - used, "SET, command not found!\n");
+			return;
+		}
+	}
+
+	switch (id) {
+	case PHYDM_HELP:
+	{
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BB cmd ==>\n");
+		for (i = 0; i < phydm_ary_size - 2; i++) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "  %-5d: %s\n", i, phy_dm_ary[i + 2].name);
+			/**/
+		}
+	}
+	break;
+
+	case PHYDM_DEMO: { /*echo demo 10 0x3a z abcde >cmd*/
+		u32 directory = 0;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+		char char_temp;
+#else
+		u32 char_temp = ' ';
+#endif
+
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &directory);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Decimal value = %d\n", directory);
+		PHYDM_SSCANF(input[2], DCMD_HEX, &directory);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Hex value = 0x%x\n", directory);
+		PHYDM_SSCANF(input[3], DCMD_CHAR, &char_temp);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Char = %c\n", char_temp);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "String = %s\n", input[4]);
+	}
+	break;
+	
+	case PHYDM_DIG:
+
+		phydm_dig_debug(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_RA:
+		phydm_ra_debug(dm, &input[0], &used, output, &out_len);
+		break;
+
+	case PHYDM_ANTDIV:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+
+				/*PDM_SNPF((output+used, out_len-used, "new SET, PATHDIV_var[%d]= (( %d ))\n", i, var1[i]));*/
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			/*PDM_SNPF((output+used, out_len-used, "odm_PATHDIV_debug\n"));*/
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+			phydm_antdiv_debug(dm, (u32 *)var1, &used, output, &out_len);
+#endif
+		}
+
+		break;
+
+	case PHYDM_PATHDIV:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+
+				/*PDM_SNPF((output+used, out_len-used, "new SET, PATHDIV_var[%d]= (( %d ))\n", i, var1[i]));*/
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			/*PDM_SNPF((output+used, out_len-used, "odm_PATHDIV_debug\n"));*/
+#if (defined(CONFIG_PATH_DIVERSITY))
+			odm_pathdiv_debug(dm, (u32 *)var1, &used, output, &out_len);
+#endif
+		}
+
+		break;
+
+	case PHYDM_DEBUG:
+
+		phydm_debug_trace(dm, &input[0], &used, output, &out_len);
+
+		break;
+
+	case PHYDM_FW_DEBUG:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_fw_debug_trace(dm, (u32 *)var1, &used, output, &out_len);
+
+		break;
+
+	case PHYDM_SUPPORT_ABILITY:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+
+				/*PDM_SNPF((output+used, out_len-used, "new SET, support ablity_var[%d]= (( %d ))\n", i, var1[i]));*/
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			/*PDM_SNPF((output+used, out_len-used, "support ablity\n"));*/
+			phydm_support_ability_debug(dm, (u32 *)var1, &used, output, &out_len);
+		}
+
+		break;
+
+	case PHYDM_RF_SUPPORTABILITY:
+		halrf_support_ability_debug(dm, &input[0], &used, output, &out_len);
+		break;
+
+	case PHYDM_RF_PROFILE:
+		halrf_basic_profile(dm, &used, output, &out_len);
+		break;
+		
+	case PHYDM_RF_IQK_INFO:
+		#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+			halrf_iqk_info_dump(dm, &used, output, &out_len);
+		#endif
+		break;
+
+	case PHYDM_IQK:
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "TRX IQK Trigger\n");
+		halrf_iqk_trigger(dm, false);
+
+		#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+			halrf_iqk_info_dump(dm, &used, output, &out_len);
+		#endif
+		
+		break;
+		
+	case PHYDM_IQK_DEBUG:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+			if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+				halrf_iqk_debug(dm, (u32 *)var1, &used, output, &out_len);
+			#endif
+		}
+		break;
+		
+	case PHYDM_SMART_ANT:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		phydm_hl_smart_ant_debug_type2(dm, &input[0], &used, output, &out_len, input_num);
+		#elif (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
+		phydm_hl_smart_ant_debug(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+	
+	#endif
+
+	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+		phydm_cumitek_smt_ant_debug(dm, &input[0], &used, output, &out_len, input_num);
+	#endif
+		}
+
+		break;
+
+	case PHYDM_API:
+		phydm_api_adjust(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_PROFILE:
+		phydm_basic_profile(dm, &used, output, &out_len);
+		break;
+
+	case PHYDM_GET_TXAGC:
+		phydm_get_txagc(dm, &used, output, &out_len);
+		break;
+
+	case PHYDM_SET_TXAGC:
+	{
+		boolean		is_enable_dbg_mode;
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if ((strcmp(input[1], help) == 0)) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "{En} {pathA~D(0~3)} {rate_idx(Hex), All_rate:0xff} {txagc_idx (Hex)}\n");
+			/**/
+
+		} else {
+			is_enable_dbg_mode = (boolean)var1[0];
+			if (is_enable_dbg_mode) {
+				dm->is_disable_phy_api = false;
+				phydm_set_txagc(dm, (u32 *)var1, &used, output, &out_len);
+				dm->is_disable_phy_api = true;
+			} else {
+				dm->is_disable_phy_api = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Disable API debug mode\n");
+			}
+		}
+	}
+	break;
+
+	case PHYDM_TRX_PATH:
+
+		for (i = 0; i < 4; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
+			u8		tx_path, rx_path;
+			boolean		is_enable_dbg_mode, is_tx2_path;
+
+			is_enable_dbg_mode = (boolean)var1[0];
+			tx_path = (u8) var1[1];
+			rx_path = (u8) var1[2];
+			is_tx2_path = (boolean) var1[3];
+
+			if (is_enable_dbg_mode) {
+				dm->is_disable_phy_api = false;
+				phydm_api_trx_mode(dm, (enum bb_path) tx_path, (enum bb_path) rx_path, is_tx2_path);
+				dm->is_disable_phy_api = true;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "tx_path = 0x%x, rx_path = 0x%x, is_tx2_path = %d\n",
+					       tx_path, rx_path, is_tx2_path);
+			} else {
+				dm->is_disable_phy_api = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Disable API debug mode\n");
+			}
+		} else
+#endif
+			phydm_config_trx_path(dm, (u32 *)var1, &used, output, &out_len);
+
+		break;
+
+	case PHYDM_LA_MODE:
+
+		#if (PHYDM_LA_MODE_SUPPORT == 1)
+		phydm_lamode_trigger_setting(dm, &input[0], &used, output, &out_len, input_num);
+		#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "This IC doesn't support LA mode\n");
+		#endif
+
+		break;
+
+	case PHYDM_DUMP_REG:
+	{
+		u8	type = 0;
+
+		if (input[1]) {
+			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+			type = (u8)var1[0];
+		}
+
+		if (type == 0)
+			phydm_dump_bb_reg(dm, &used, output, &out_len);
+		else if (type == 1)
+			phydm_dump_all_reg(dm, &used, output, &out_len);
+	}
+	break;
+
+	case PHYDM_BIG_JUMP:
+	{
+#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			if (input[1]) {
+				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+				phydm_enable_big_jump(dm, (boolean)(var1[0]));
+			} else
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "unknown command!\n");
+		} else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "The command is only for 8822B!\n");
+#endif
+		break;
+	}
+
+	case PHYDM_AUTO_DBG:
+		#ifdef PHYDM_AUTO_DEGBUG
+		phydm_auto_dbg_console(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	case PHYDM_SHOW_RXRATE:
+	{
+#if (RTL8822B_SUPPORT == 1 | RTL8821C_SUPPORT == 1 | RTL8814B_SUPPORT == 1)
+		u8	rate_idx;
+		if ((dm->support_ic_type & PHYDM_IC_SUPPORT_MU_BFEE) == 0)
+			break;
+
+		if (input[1])
+			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 1)
+			phydm_show_rx_rate(dm, &used, output, &out_len);
+		else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "Reset Rx rate counter\n");
+
+			for (rate_idx = 0; rate_idx < VHT_RATE_NUM; rate_idx++) {
+				dm->phy_dbg_info.num_qry_vht_pkt[rate_idx] = 0;
+				dm->phy_dbg_info.num_qry_mu_vht_pkt[rate_idx] = 0;
+			}
+		}
+#endif
+		break;
+	}
+
+	case PHYDM_NBI_EN:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			phydm_api_debug(dm, PHYDM_API_NBI, (u32 *)var1, &used, output, &out_len);
+			/**/
+		}
+
+
+		break;
+
+	case PHYDM_CSI_MASK_EN:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+			phydm_api_debug(dm, PHYDM_API_CSI_MASK, (u32 *)var1, &used, output, &out_len);
+			/**/
+		}
+
+
+		break;
+
+	case PHYDM_DFS_DEBUG:
+	{
+#ifdef CONFIG_PHYDM_DFS_MASTER
+		u32 var[4] = {0};
+
+		for (i = 0; i < 4; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_dfs_debug(dm, var, &used, output, &out_len);
+#endif
+		break;
+	}
+
+	case PHYDM_NHM:
+		#ifdef NHM_SUPPORT
+		phydm_nhm_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	case PHYDM_CLM:
+		#ifdef CLM_SUPPORT
+		phydm_clm_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	#ifdef FAHM_SUPPORT
+	case PHYDM_FAHM:
+		phydm_fahm_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+	#endif
+
+	case PHYDM_ENV_MNTR:
+		phydm_env_mntr_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+	
+
+	case PHYDM_BB_INFO:
+	{
+		s32 value32 = 0;
+
+		phydm_bb_debug_info(dm, &used, output, &out_len);
+
+		if (dm->support_ic_type & ODM_RTL8822B && input[1]) {
+			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+			odm_set_bb_reg(dm, 0x1988, 0x003fff00, var1[0]);
+			value32 = odm_get_bb_reg(dm, 0xf84, MASKDWORD);
+			value32 = (value32 & 0xff000000) >> 24;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n %-35s = condition num = %d, subcarriers = %d\n",
+				       "Over condition num subcarrier",
+				       var1[0], value32);
+			odm_set_bb_reg(dm, 0x1988, BIT(22), 0x0);	/*disable report condition number*/
+		}
+	}
+	break;
+
+	case PHYDM_TXBF:
+	{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (BEAMFORMING_SUPPORT == 1)
+		struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+		if (var1[0] == 0) {
+			beamforming_info->apply_v_matrix = false;
+			beamforming_info->snding3ss = true;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n dont apply V matrix and 3SS 789 snding\n");
+		} else if (var1[0] == 1) {
+			beamforming_info->apply_v_matrix = true;
+			beamforming_info->snding3ss = true;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n apply V matrix and 3SS 789 snding\n");
+		} else if (var1[0] == 2) {
+			beamforming_info->apply_v_matrix = true;
+			beamforming_info->snding3ss = false;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "\r\n default txbf setting\n");
+		} else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "\r\n unknown cmd!!\n");
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "\r\n no TxBF !!\n");
+#endif
+#endif
+	}
+		break;
+
+	case PHYDM_H2C:
+
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_h2C_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+
+		break;
+
+	case PHYDM_ANT_SWITCH:
+
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+#if (RTL8821A_SUPPORT == 1)
+			phydm_set_ext_switch(dm, (u32 *)var1, &used, output, &out_len);
+#else
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Not Support IC");
+#endif
+		}
+
+
+		break;
+
+	case PHYDM_DYNAMIC_RA_PATH:
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_drp_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Not Support IC");
+#endif
+
+		break;
+
+	case PHYDM_ADAPTIVE_SOML:
+
+#ifdef CONFIG_ADAPTIVE_SOML
+		for (i = 0; i < 8; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_soml_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+#else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Not Support IC");
+#endif
+
+		break;
+
+	case PHYDM_PSD:
+
+		#ifdef CONFIG_PSD_TOOL
+		phydm_psd_debug(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+
+		break;
+		
+	case PHYDM_DEBUG_PORT:
+		{
+			u32	dbg_port_value;
+
+			PHYDM_SSCANF(input[1], DCMD_HEX, &var1[0]);
+
+			dm->debug_components |= ODM_COMP_API;
+			if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_3, var1[0])) {/*set debug port to 0x0*/
+
+				dbg_port_value = phydm_get_bb_dbg_port_value(dm);
+				phydm_release_bb_dbg_port(dm);
+				
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dbg Port[0x%x] = ((0x%x))\n",
+					       var1[0], dbg_port_value);
+			}
+			dm->debug_components &= (~ODM_COMP_API);
+		}
+		break;
+		
+	case PHYDM_DIS_HTSTF_CONTROL:
+		{
+			if (input[1])
+				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+			if (var1[0] == 1) {
+				
+				/* setting being false is for debug */
+				dm->bhtstfdisabled = true;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic HT-STF Gain Control is Disable\n");
+			}
+			else {
+				
+				/* default setting should be true, always be dynamic control*/
+				dm->bhtstfdisabled = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic HT-STF Gain Control is Enable\n");
+			}
+		}
+		break;
+		
+	case PHYDM_TUNE_PARAMETER:
+		phydm_parameter_adjust(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_ADAPTIVITY_DEBUG:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1)
+			phydm_adaptivity_debug(dm, (u32 *)var1, &used, output, &out_len);
+
+		break;
+
+	case PHYDM_DIS_DYM_ANT_WEIGHTING:	
+		#ifdef DYN_ANT_WEIGHTING_SUPPORT
+		phydm_dyn_ant_weight_dbg(dm, &input[0], &used, output, &out_len, input_num);
+		#endif
+		break;
+
+	case PHYDM_FORECE_PT_STATE:
+		{
+		#ifdef PHYDM_POWER_TRAINING_SUPPORT	
+			phydm_pow_train_debug(dm, &input[0], &used, output, &out_len, input_num);
+		#else
+			PDM_SNPF(out_len, used, output + used, out_len - used, "Pow training: Not Support\n");
+		#endif
+		
+		break;
+		}
+
+	case PHYDM_DIS_RXHP_CTR:
+		{
+			if (input[1])
+				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+			if (var1[0] == 1) {
+				/* the setting being on is at debug mode to disconnect RxHP seeting with SoML on/odd */
+				dm->disrxhpsoml = true;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic RxHP Control with SoML on/off is Disable\n");
+			}
+			else if (var1[0] == 0) {
+				/* default setting, RxHP setting will follow SoML on/off setting */
+				dm->disrxhpsoml = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Dynamic RxHP Control with SoML on/off is Enable\n");
+			}
+			else {
+				dm->disrxhpsoml = false;
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "Default Setting, Dynamic RxHP Control with SoML on/off is Enable\n");
+			}
+		}
+		break;
+		
+	case PHYDM_STA_INFO:
+		phydm_show_sta_info(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_PAUSE_FUNC:
+		phydm_pause_func_console(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	case PHYDM_PER_TONE_EVM:
+		phydm_per_tone_evm(dm, &input[0], &used, output, &out_len, input_num);
+		break;
+
+	default:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "SET, unknown command!\n");
+		break;
+
+	}
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+#ifdef __ECOS
+char *strsep(char **s, const char *ct)
+{
+	char *sbegin = *s;
+	char *end;
+
+	if (sbegin == NULL)
+		return NULL;
+
+	end = strpbrk(sbegin, ct);
+	if (end)
+		*end++ = '\0';
+	*s = end;
+	return sbegin;
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+s32
+phydm_cmd(
+	struct dm_struct	*dm,
+	char		*input,
+	u32	in_len,
+	u8	flag,
+	char	*output,
+	u32	out_len
+)
+{
+	char *token;
+	u32	argc = 0;
+	char		argv[MAX_ARGC][MAX_ARGV];
+
+	do {
+		token = strsep(&input, ", ");
+		if (token) {
+			strcpy(argv[argc], token);
+			argc++;
+		} else
+			break;
+	} while (argc < MAX_ARGC);
+
+	if (argc == 1)
+		argv[0][strlen(argv[0]) - 1] = '\0';
+
+	phydm_cmd_parser(dm, argv, argc, flag, output, out_len);
+
+	return 0;
+}
+#endif
+
+
+void
+phydm_fw_trace_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	/*u8	debug_trace_11byte[60];*/
+	u8		freg_num, c2h_seq, buf_0 = 0;
+
+
+	if (!(dm->support_ic_type & PHYDM_IC_3081_SERIES))
+		return;
+
+	if ((cmd_len > 12) || (cmd_len == 0)) {
+		pr_debug("[Warning] Error C2H cmd_len=%d\n", cmd_len);
+		return;
+	}
+
+	buf_0 = cmd_buf[0];
+	freg_num = (buf_0 & 0xf);
+	c2h_seq = (buf_0 & 0xf0) >> 4;
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] freg_num = (( %d )), c2h_seq = (( %d ))\n", freg_num,c2h_seq );*/
+
+	/*strncpy(debug_trace_11byte,&cmd_buf[1],(cmd_len-1));*/
+	/*debug_trace_11byte[cmd_len-1] = '\0';*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] %s\n", debug_trace_11byte);*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] cmd_len = (( %d ))\n", cmd_len);*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"[FW debug message] c2h_cmd_start  = (( %d ))\n", dm->c2h_cmd_start);*/
+
+
+
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"pre_seq = (( %d )), current_seq = (( %d ))\n", dm->pre_c2h_seq, c2h_seq);*/
+	/*PHYDM_DBG(dm, DBG_FW_TRACE,"fw_buff_is_enpty = (( %d ))\n", dm->fw_buff_is_enpty);*/
+
+	if ((c2h_seq != dm->pre_c2h_seq)  &&  dm->fw_buff_is_enpty == false) {
+		dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW Dbg Queue Overflow] %s\n", dm->fw_debug_trace);
+		dm->c2h_cmd_start = 0;
+	}
+
+	if ((cmd_len - 1) > (60 - dm->c2h_cmd_start)) {
+		dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW Dbg Queue error: wrong C2H length] %s\n", dm->fw_debug_trace);
+		dm->c2h_cmd_start = 0;
+		return;
+	}
+
+	strncpy((char *)&dm->fw_debug_trace[dm->c2h_cmd_start],
+		(char *)&cmd_buf[1], (cmd_len - 1));
+	dm->c2h_cmd_start += (cmd_len - 1);
+	dm->fw_buff_is_enpty = false;
+
+	if (freg_num == 0 || dm->c2h_cmd_start >= 60) {
+		if (dm->c2h_cmd_start < 60)
+			dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		else
+			dm->fw_debug_trace[59] = '\0';
+
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s\n", dm->fw_debug_trace);
+		/*dbg_print("[FW DBG Msg] %s\n", dm->fw_debug_trace);*/
+		dm->c2h_cmd_start = 0;
+		dm->fw_buff_is_enpty = true;
+	}
+
+	dm->pre_c2h_seq = c2h_seq;
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+void
+phydm_fw_trace_handler_code(
+	void	*dm_void,
+	u8	*buffer,
+	u8	cmd_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	function = buffer[0];
+	u8	dbg_num = buffer[1];
+	u16	content_0 = (((u16)buffer[3]) << 8) | ((u16)buffer[2]);
+	u16	content_1 = (((u16)buffer[5]) << 8) | ((u16)buffer[4]);
+	u16	content_2 = (((u16)buffer[7]) << 8) | ((u16)buffer[6]);
+	u16	content_3 = (((u16)buffer[9]) << 8) | ((u16)buffer[8]);
+	u16	content_4 = (((u16)buffer[11]) << 8) | ((u16)buffer[10]);
+
+	if (cmd_len > 12)
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW Msg] Invalid cmd length (( %d )) >12\n", cmd_len);
+
+	/* PHYDM_DBG(dm, DBG_FW_TRACE,"[FW Msg] Func=((%d)),  num=((%d)), ct_0=((%d)), ct_1=((%d)), ct_2=((%d)), ct_3=((%d)), ct_4=((%d))\n", */
+	/*	function, dbg_num, content_0, content_1, content_2, content_3, content_4); */
+
+	/*--------------------------------------------*/
+#ifdef CONFIG_RA_FW_DBG_CODE
+	if (function == RATE_DECISION) {
+		if (dbg_num == 0) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RA_CNT=((%d))  Max_device=((%d))--------------------------->\n", content_1, content_2);
+			else if (content_0 == 2)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Check RA macid= ((%d)), MediaStatus=((%d)), Dis_RA=((%d)),  try_bit=((0x%x))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Check RA  total=((%d)),  drop=((0x%x)), TXRPT_TRY_bit=((%x)), bNoisy=((%x))\n", content_1, content_2, content_3, content_4);
+		} else if (dbg_num == 1) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RTY[0,1,2,3]=[ %d , %d , %d , %d ]\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 2) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RTY[4]=[ %d ], drop=(( %d )), total=(( %d )), current_rate=((0x %x ))", content_1, content_2, content_3, content_4);
+				phydm_print_rate(dm, (u8)content_4, DBG_FW_TRACE);
+			} else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] penality_idx=(( %d ))\n", content_1);
+			else if (content_0 == 4)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RSSI=(( %d )), ra_stage = (( %d ))\n", content_1, content_2);
+		} else if (dbg_num == 3) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( DOWN ))  total=((%d)),  total>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 2)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( UP ))  total_acc=((%d)),  total_acc>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( UP )) ((rate Down Hold))  RA_CNT=((%d))\n", content_1);
+			else if (content_0 == 4)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( UP )) ((tota_accl<5 skip))  RA_CNT=((%d))\n", content_1);
+			else if (content_0 == 8)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] Fast_RA (( Reset Tx Rpt )) RA_CNT=((%d))\n", content_1);
+		} else if (dbg_num == 4) {
+			if (content_0 == 3) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] RER_CNT   PCR_ori =(( %d )),  ratio_ori =(( %d )), pcr_updown_bitmap =(( 0x%x )), pcr_var_diff =(( %d ))\n", content_1, content_2, content_3, content_4);
+				/**/
+			} else if (content_0 == 4) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] pcr_shift_value =(( %s%d )), rate_down_threshold =(( %d )), rate_up_threshold =(( %d ))\n", ((content_1) ? "+" : "-"), content_2, content_3, content_4);
+				/**/
+			} else if (content_0 == 5) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] pcr_mean =(( %d )), PCR_VAR =(( %d )), offset =(( %d )), decision_offset_p =(( %d ))\n", content_1, content_2, content_3, content_4);
+				/**/
+			}
+		} else if (dbg_num == 5) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] (( UP))  Nsc=(( %d )), N_High=(( %d )), RateUp_Waiting=(( %d )), RateUp_Fail=(( %d ))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 2)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((DOWN))  Nsc=(( %d )), N_Low=(( %d ))\n", content_1, content_2);
+			else if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((HOLD))  Nsc=((%d)), N_High=((%d)), N_Low=((%d)), Reset_CNT=((%d))\n", content_1, content_2, content_3, content_4);
+		} else if (dbg_num == 0x60) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((AP RPT))  macid=((%d)), BUPDATE[macid]=((%d))\n", content_1, content_2);
+			else if (content_0 == 4)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((AP RPT))  pass=((%d)), rty_num=((%d)), drop=((%d)), total=((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 5)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW] ((AP RPT))  PASS=((%d)), RTY_NUM=((%d)), DROP=((%d)), TOTAL=((%d))\n", content_1, content_2, content_3, content_4);
+		}
+	} else if (function == INIT_RA_TABLE) {
+		if (dbg_num == 3)
+			PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][INIT_RA_INFO] Ra_init, RA_SKIP_CNT = (( %d ))\n", content_0);
+ 	} else if (function == RATE_UP) {
+		if (dbg_num == 2) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateUp]  ((Highest rate->return)), macid=((%d))  Nsc=((%d))\n", content_1, content_2);
+		} else if (dbg_num == 5) {
+			if (content_0 == 0)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateUp]  ((rate UP)), up_rate_tmp=((0x%x)), rate_idx=((0x%x)), SGI_en=((%d)),  SGI=((%d))\n", content_1, content_2, content_3, content_4);
+			else if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateUp]  ((rate UP)), rate_1=((0x%x)), rate_2=((0x%x)), BW=((%d)), Try_Bit=((%d))\n", content_1, content_2, content_3, content_4);
+		}
+	} else if (function == RATE_DOWN) {
+		if (dbg_num == 5) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][RateDownStep]  ((rate Down)), macid=((%d)), rate1=((0x%x)),  rate2=((0x%x)), BW=((%d))\n", content_1, content_2, content_3, content_4);
+		}
+	} else if (function == TRY_DONE) {
+		if (dbg_num == 1) {
+			if (content_0 == 1) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][Try Done]  ((try succsess )) macid=((%d)), Try_Done_cnt=((%d))\n", content_1, content_2);
+				/**/
+			}
+		} else if (dbg_num == 2) {
+			if (content_0 == 1) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][Try Done]  ((try)) macid=((%d)), Try_Done_cnt=((%d)),  rate_2=((%d)),  try_succes=((%d))\n", content_1, content_2, content_3, content_4);
+				/**/
+			}
+		}
+	} else if (function == RA_H2C) {
+		if (dbg_num == 1) {
+			if (content_0 == 0) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][H2C=0x49]  fw_trace_en=((%d)), mode =((%d)),  macid=((%d))\n", content_1, content_2, content_3);
+				/**/
+			}
+		}
+	} else if (function == F_RATE_AP_RPT) {
+		if (dbg_num == 1) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  ((1)), SPE_STATIS=((0x%x))---------->\n", content_3);
+		} else if (dbg_num == 2) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  RTY_all=((%d))\n", content_1);
+		} else if (dbg_num == 3) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID1[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2);
+		} else if (dbg_num == 4) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID2[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2);
+		} else if (dbg_num == 5) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID1[%d], PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2);
+		} else if (dbg_num == 6) {
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][AP RPT]  MACID2[%d],, PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2);
+		}
+	} else if (function == DBC_FW_CLM) {
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][CLM][%d, %d] = {%d, %d, %d, %d}\n", dbg_num, content_0, content_1, content_2, content_3, content_4);
+	} else {
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n", function, dbg_num, content_0, content_1, content_2, content_3, content_4);
+	}
+#else
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n", function, dbg_num, content_0, content_1, content_2, content_3, content_4);
+#endif
+	/*--------------------------------------------*/
+
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+void
+phydm_fw_trace_handler_8051(
+	void	*dm_void,
+	u8	*buffer,
+	u8	cmd_len
+)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if 0
+	if (cmd_len >= 3)
+		cmd_buf[cmd_len - 1] = '\0';
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s\n", &(cmd_buf[3]));
+#else
+
+	int i = 0;
+	u8	extend_c2h_sub_id = 0, extend_c2h_dbg_len = 0, extend_c2h_dbg_seq = 0;
+	u8	fw_debug_trace[128];
+	u8	*extend_c2h_dbg_content = 0;
+
+	if (cmd_len > 127)
+		return;
+
+	extend_c2h_sub_id = buffer[0];
+	extend_c2h_dbg_len = buffer[1];
+	extend_c2h_dbg_content = buffer + 2; /*DbgSeq+DbgContent  for show HEX*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISP(FC2H, C2H_Summary, ("[Extend C2H packet], Extend_c2hSubId=0x%x, extend_c2h_dbg_len=%d\n",
+				    extend_c2h_sub_id, extend_c2h_dbg_len));
+
+	RT_DISP_DATA(FC2H, C2H_Summary, "[Extend C2H packet], Content Hex:", extend_c2h_dbg_content, cmd_len - 2);
+#endif
+
+go_backfor_aggre_dbg_pkt:
+	i = 0;
+	extend_c2h_dbg_seq = buffer[2];
+	extend_c2h_dbg_content = buffer + 3;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISP(FC2H, C2H_Summary, ("[RTKFW, SEQ= %d] :", extend_c2h_dbg_seq));
+#endif
+
+	for (; ; i++) {
+		fw_debug_trace[i] = extend_c2h_dbg_content[i];
+		if (extend_c2h_dbg_content[i + 1] == '\0') {
+			fw_debug_trace[i + 1] = '\0';
+			PHYDM_DBG(dm, DBG_FW_TRACE,
+				  "[FW DBG Msg] %s", &fw_debug_trace[0]);
+			break;
+		} else if (extend_c2h_dbg_content[i] == '\n') {
+			fw_debug_trace[i + 1] = '\0';
+			PHYDM_DBG(dm, DBG_FW_TRACE,
+				  "[FW DBG Msg] %s", &fw_debug_trace[0]);
+			buffer = extend_c2h_dbg_content + i + 3;
+			goto go_backfor_aggre_dbg_pkt;
+		}
+	}
+
+
+#endif
+#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.h
index 2f5859b583ea..fc79f2e85105 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_debug.h
@@ -1,330 +1,393 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-
-#ifndef	__ODM_DBG_H__
-#define __ODM_DBG_H__
-
-#define DEBUG_VERSION	"1.0"  /*2015.01.13 Dino*/
-//-----------------------------------------------------------------------------
-//	Define the debug levels
-//
-//	1.	DBG_TRACE and DBG_LOUD are used for normal cases.
-//	So that, they can help SW engineer to develope 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
-
-/*FW DBG MSG*/
-#define	RATE_DECISION	BIT0
-#define	INIT_RA_TABLE	BIT1
-#define	RATE_UP			BIT2
-#define	RATE_DOWN		BIT3
-#define	TRY_DONE		BIT4
-#define	F_RATE_AP_RPT	BIT7
-
-//-----------------------------------------------------------------------------
-// Define the tracing components
-//
-//-----------------------------------------------------------------------------
-//BB Functions
-#define	ODM_COMP_DIG					BIT0	
-#define	ODM_COMP_RA_MASK				BIT1	
-#define	ODM_COMP_DYNAMIC_TXPWR		BIT2
-#define	ODM_COMP_FA_CNT				BIT3
-#define	ODM_COMP_RSSI_MONITOR		BIT4
-#define	ODM_COMP_CCK_PD				BIT5
-#define	ODM_COMP_ANT_DIV				BIT6
-#define	ODM_COMP_PWR_SAVE			BIT7
-#define	ODM_COMP_PWR_TRAIN			BIT8
-#define	ODM_COMP_RATE_ADAPTIVE		BIT9
-#define	ODM_COMP_PATH_DIV			BIT10
-#define	ODM_COMP_PSD					BIT11
-#define	ODM_COMP_DYNAMIC_PRICCA		BIT12
-#define	ODM_COMP_RXHP					BIT13
-#define	ODM_COMP_MP					BIT14
-#define	ODM_COMP_CFO_TRACKING		BIT15
-#define	ODM_COMP_ACS					BIT16
-#define	PHYDM_COMP_ADAPTIVITY		BIT17
-#define	PHYDM_COMP_RA_DBG			BIT18
-#define	PHYDM_COMP_TXBF				BIT19
-//MAC Functions
-#define	ODM_COMP_EDCA_TURBO			BIT20
-#define	ODM_COMP_EARLY_MODE			BIT21
-#define	ODM_FW_DEBUG_TRACE			BIT22
-//RF Functions
-#define	ODM_COMP_TX_PWR_TRACK		BIT24
-#define	ODM_COMP_RX_GAIN_TRACK		BIT25
-#define	ODM_COMP_CALIBRATION			BIT26
-//Common Functions
-#define	ODM_PHY_CONFIG				BIT28
-#define	BEAMFORMING_DEBUG				BIT29
-#define	ODM_COMP_COMMON				BIT30
-#define	ODM_COMP_INIT					BIT31
-#define	ODM_COMP_NOISY_DETECT		BIT32
-
-/*------------------------Export Marco Definition---------------------------*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define RT_PRINTK				DbgPrint
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#define DbgPrint	printk
-	#define RT_PRINTK(fmt, args...)	DbgPrint( "%s(): " fmt, __FUNCTION__, ## args);
-	#define	RT_DISP(dbgtype, dbgflag, printstr)
-#else
-	#define DbgPrint	panic_printk
-	#define RT_PRINTK(fmt, args...)	DbgPrint( "%s(): " fmt, __FUNCTION__, ## args);
-#endif
-
-#ifndef ASSERT
-	#define ASSERT(expr)
-#endif
-
-#if DBG
-#define ODM_RT_TRACE(pDM_Odm, comp, level, fmt)									\
-	do {	\
-		if(((comp) & pDM_Odm->DebugComponents) && (level <= pDM_Odm->DebugLevel || level == ODM_DBG_SERIOUS))	\
-		{																			\
-			if(pDM_Odm->SupportICType == ODM_RTL8192C)								\
-				DbgPrint("[ODM-92C] ");												\
-			else if(pDM_Odm->SupportICType == ODM_RTL8192D)							\
-				DbgPrint("[ODM-92D] ");												\
-			else if(pDM_Odm->SupportICType == ODM_RTL8723A)							\
-				DbgPrint("[ODM-8723A] ");											\
-			else if(pDM_Odm->SupportICType == ODM_RTL8188E)							\
-				DbgPrint("[ODM-8188E] ");											\
-			else if(pDM_Odm->SupportICType == ODM_RTL8192E) 						\
-				DbgPrint("[ODM-8192E] ");											\
-			else if(pDM_Odm->SupportICType == ODM_RTL8812)							\
-				DbgPrint("[ODM-8812] ");											\
-			else if(pDM_Odm->SupportICType == ODM_RTL8821)							\
-				DbgPrint("[ODM-8821] ");											\
-			else if(pDM_Odm->SupportICType == ODM_RTL8814A)							\
-				DbgPrint("[ODM-8814] ");											\
-			else if(pDM_Odm->SupportICType == ODM_RTL8703B)							\
-				DbgPrint("[ODM-8703B] ");											\
-			else if(pDM_Odm->SupportICType == ODM_RTL8822B)							\
-				DbgPrint("[ODM-8822] ");											\
-			else if (pDM_Odm->SupportICType == ODM_RTL8188F)							\
-				DbgPrint("[ODM-8188F] ");											\
-			RT_PRINTK fmt;															\
-		}	\
-	} while (0)
-	
-#define ODM_RT_TRACE_F(pDM_Odm, comp, level, fmt)									\
-		if(((comp) & pDM_Odm->DebugComponents) && (level <= pDM_Odm->DebugLevel))	\
-		{																			\
-			RT_PRINTK fmt;															\
-		}
-
-#define ODM_RT_ASSERT(pDM_Odm, expr, fmt)											\
-		if(!(expr)) {																	\
-			DbgPrint( "Assertion failed! %s at ......\n", #expr);								\
-			DbgPrint( "      ......%s,%s,line=%d\n",__FILE__,__FUNCTION__,__LINE__);			\
-			RT_PRINTK fmt;															\
-			ASSERT(FALSE);															\
-		}
-#define ODM_dbg_enter() { DbgPrint("==> %s\n", __FUNCTION__); }
-#define ODM_dbg_exit() { DbgPrint("<== %s\n", __FUNCTION__); }
-#define ODM_dbg_trace(str) { DbgPrint("%s:%s\n", __FUNCTION__, str); }
-
-#define ODM_PRINT_ADDR(pDM_Odm, comp, level, title_str, ptr)							\
-			if(((comp) & pDM_Odm->DebugComponents) && (level <= pDM_Odm->DebugLevel))	\
-			{																		\
-				int __i;																\
-				pu1Byte	__ptr = (pu1Byte)ptr;											\
-				DbgPrint("[ODM] ");													\
-				DbgPrint(title_str);													\
-				DbgPrint(" ");														\
-				for( __i=0; __i<6; __i++ )												\
-					DbgPrint("%02X%s", __ptr[__i], (__i==5)?"":"-");						\
-				DbgPrint("\n");														\
-			}
-#else
-#define ODM_RT_TRACE(pDM_Odm, comp, level, fmt)
-#define ODM_RT_TRACE_F(pDM_Odm, comp, level, fmt)
-#define ODM_RT_ASSERT(pDM_Odm, expr, fmt)
-#define ODM_dbg_enter()
-#define ODM_dbg_exit()
-#define ODM_dbg_trace(str)
-#define ODM_PRINT_ADDR(pDM_Odm, comp, level, title_str, ptr)
-#endif
-
-
-VOID 
-PHYDM_InitDebugSetting(IN		PDM_ODM_T		pDM_Odm);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID phydm_BB_RxHang_Info(IN PDM_ODM_T pDM_Odm);
-#endif
-
-#define	BB_TMP_BUF_SIZE		100
-VOID phydm_BB_Debug_Info(IN PDM_ODM_T pDM_Odm);
-VOID phydm_BasicDbgMessage(	IN		PVOID			pDM_VOID);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#define	PHYDM_DBGPRINT		0
-#define	PHYDM_SSCANF(x, y, z)	DCMD_Scanf(x, y, z)
-#if (PHYDM_DBGPRINT == 1)
-#define	PHYDM_SNPRINTF(msg)	\
-		do {\
-			rsprintf msg;\
-			DbgPrint(output);\
-		} while (0)
-#else
-#define	PHYDM_SNPRINTF(msg)	\
-		do {\
-			rsprintf msg;\
-			DCMD_Printf(output);\
-		} while (0)
-#endif
-#else
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#define	PHYDM_DBGPRINT		0
-#else
-#define	PHYDM_DBGPRINT		1
-#endif
-#define	MAX_ARGC				20
-#define	MAX_ARGV				16
-#define	DCMD_DECIMAL			"%d"
-#define	DCMD_CHAR				"%c"
-#define	DCMD_HEX				"%x"
-
-#define	PHYDM_SSCANF(x, y, z)	sscanf(x, y, z)
-#if (PHYDM_DBGPRINT == 1)
-#define	PHYDM_SNPRINTF(msg)\
-		do {\
-			snprintf msg;\
-			DbgPrint(output);\
-		} while (0)
-#else
-#define	PHYDM_SNPRINTF(msg)\
-		do {\
-			if(out_len > used)\
-				used+=snprintf msg;\
-		} while (0)
-#endif
-#endif
-
-
-VOID phydm_BasicProfile(
-	IN		PVOID			pDM_VOID,
-	IN		u4Byte			*_used,
-	OUT		char				*output,
-	IN		u4Byte			*_out_len
-	);
-#if(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_AP))
-s4Byte
-phydm_cmd(
-	IN PDM_ODM_T	pDM_Odm,
-	IN char		*input,
-	IN u4Byte	in_len,
-	IN u1Byte	flag,
-	OUT char	*output,
-	IN u4Byte	out_len
-);
-#endif
-VOID
-phydm_cmd_parser(
-	IN PDM_ODM_T	pDM_Odm,
-	IN char		input[][16],
-	IN u4Byte	input_num,
-	IN u1Byte	flag,
-	OUT char	*output,
-	IN u4Byte	out_len
-);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void phydm_sbd_check(
-	IN	PDM_ODM_T					pDM_Odm
-	);
-
-void phydm_sbd_callback(
-	PRT_TIMER		pTimer
-	);
-
-void phydm_sbd_workitem_callback(
-    IN PVOID            pContext
-	);
-#endif
-
-VOID
-phydm_fw_trace_en_h2c(
-	IN	PVOID	pDM_VOID,
-	IN	BOOLEAN		enable,
-	IN	u4Byte		monitor_mode,
-	IN	u4Byte		macid
-);
-
-VOID
-phydm_fw_trace_handler(
-	IN		PVOID	pDM_VOID,
-	IN		pu1Byte	CmdBuf,
-	IN		u1Byte	CmdLen
-);
-
-VOID
-phydm_fw_trace_handler_code(
-	IN	PVOID	pDM_VOID,
-	IN	pu1Byte	Buffer,
-	IN	u1Byte	CmdLen
-);
-
-VOID
-phydm_fw_trace_handler_8051(
-	IN	PVOID	pDM_VOID,
-	IN	pu1Byte	CmdBuf,
-	IN	u1Byte	CmdLen
-);
-
-#endif	// __ODM_DBG_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__ODM_DBG_H__
+#define __ODM_DBG_H__
+
+/*#define DEBUG_VERSION	"1.1"*/  /*2015.07.29 YuChen*/
+/*#define DEBUG_VERSION	"1.2"*/  /*2015.08.28 Dino*/
+/*#define DEBUG_VERSION	"1.3"*/  /*2016.04.28 YuChen*/
+#define DEBUG_VERSION	"1.4"  /*2017.03.13 Dino*/
+
+/* -----------------------------------------------------------------------------
+ *	Define the debug levels
+ *
+ *	1.	DBG_TRACE and DBG_LOUD are used for normal cases.
+ *	So that, they can help SW engineer to develope 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
+
+/*FW DBG MSG*/
+#define	RATE_DECISION	1
+#define	INIT_RA_TABLE	2
+#define	RATE_UP		4
+#define	RATE_DOWN		8
+#define	TRY_DONE		16
+#define	RA_H2C			32
+#define	F_RATE_AP_RPT	64
+#define	DBC_FW_CLM	9		
+
+/* -----------------------------------------------------------------------------
+ * Define the tracing components
+ *
+ * -----------------------------------------------------------------------------
+ *BB FW Functions*/
+#define	PHYDM_FW_COMP_RA			BIT(0)
+#define	PHYDM_FW_COMP_MU			BIT(1)
+#define	PHYDM_FW_COMP_PATH_DIV		BIT(2)
+#define	PHYDM_FW_COMP_PT				BIT(3)
+
+/*------------------------Export Marco Definition---------------------------*/
+
+#define	config_phydm_read_txagc_check(data)		(data != INVALID_TXAGC_DATA)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	extern	VOID DCMD_Printf(const char *pMsg);
+
+	#define	pr_debug				DbgPrint
+	#define	dcmd_printf				DCMD_Printf
+	#define	dcmd_scanf				DCMD_Scanf
+	#define	RT_PRINTK				pr_debug
+	#define	PRINT_MAX_SIZE		512
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#undef pr_debug
+	#define pr_debug	printk
+	#define RT_PRINTK(fmt, args...)	pr_debug(fmt, ## args)
+	#define	RT_DISP(dbgtype, dbgflag, printstr)
+	#define RT_TRACE(adapter, comp, drv_level, fmt, args...)	\
+		RTW_INFO(fmt, ## args)
+#else
+	#define pr_debug	panic_printk
+	/*#define RT_PRINTK(fmt, args...)	pr_debug("%s(): " fmt, __FUNCTION__, ## args);*/
+	#define RT_PRINTK(fmt, args...)	pr_debug(fmt, ## args)
+#endif
+
+#ifndef ASSERT
+	#define ASSERT(expr)
+#endif
+
+#if DBG
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+#define PHYDM_DBG(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & (dm->debug_components)) {          \
+			pr_debug("[PHYDM] ");			\
+			RT_PRINTK(fmt, ## args);				\
+		}						\
+	} while (0)
+
+#define PHYDM_DBG_F(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			RT_PRINTK(fmt, ## args);				\
+		}						\
+	} while (0)
+
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)		\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			int __i;				\
+			u8 *__ptr = (u8 *)addr;			\
+			pr_debug("[PHYDM] ");			\
+			pr_debug(title_str);			\
+			pr_debug(" ");				\
+			for (__i = 0; __i < 6; __i++)		\
+				pr_debug("%02X%s", __ptr[__i], (__i == 5) ? "" : "-");\
+			pr_debug("\n");				\
+		}						\
+	} while (0)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+static __inline void PHYDM_DBG(PDM_ODM_T dm, int comp, char *fmt, ...)
+{
+
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->debug_components) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		DbgPrint("Failed (%d) to print message to buffer\n", rt_status);
+		return;
+	}
+
+	DbgPrint("[PHYDM] %s", buf);
+}
+
+static __inline void PHYDM_DBG_F(PDM_ODM_T dm, int comp, char *fmt, ...)
+{
+
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->debug_components) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		/*DbgPrint("DM Print Fail\n");*/
+		return;
+	}
+
+	DbgPrint("%s", buf);
+}
+
+#define PHYDM_PRINT_ADDR(p_dm, comp, title_str, ptr)							 do {\
+		if ((comp) & p_dm->debug_components) { \
+			\
+			int __i;																\
+			u8 *__ptr = (u8 *)ptr;											\
+			pr_debug("[PHYDM] ");													\
+			pr_debug(title_str);													\
+			pr_debug(" ");														\
+			for (__i = 0; __i < 6; __i++)												\
+				pr_debug("%02X%s", __ptr[__i], (__i == 5) ? "" : "-");						\
+			pr_debug("\n");														\
+		}	\
+	} while (0)
+
+#else
+#define PHYDM_DBG(dm, comp, fmt, args...)                                      \
+	do {								\
+		if ((comp) & (dm->debug_components)) {                         \
+			RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+				 DBG_DMESG, "[PHYDM] " fmt, ##args);           \
+		}												\
+	} while (0)
+
+#define PHYDM_DBG_F(dm, comp, fmt, args...)                                    \
+	do {								\
+		if ((comp) & dm->debug_components) {                           \
+			RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+				 DBG_DMESG, fmt, ##args);                      \
+		}	\
+	} while (0)
+
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)                            \
+	do {								\
+		if ((comp) & dm->debug_components) {                           \
+			RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+				 DBG_DMESG, "[PHYDM] " title_str "%pM\n",      \
+				 addr);                                        \
+		}							\
+	} while (0)
+#endif
+
+#define ODM_RT_TRACE(dm, comp, level, fmt)
+
+#else
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+static	__inline	void	PHYDM_DBG(struct dm_struct	*dm, int comp, char *fmt, ...)
+{}
+static __inline void PHYDM_DBG_F(struct dm_struct	*dm, int comp, char *fmt, ...)
+{}
+#else
+#define PHYDM_DBG(dm, comp, fmt)
+#define PHYDM_DBG_F(dm, comp, fmt)
+#endif
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, ptr)
+#define ODM_RT_TRACE(dm, comp, level, fmt)
+#endif
+
+#define	BB_DBGPORT_PRIORITY_3	3	/*Debug function (the highest priority)*/
+#define	BB_DBGPORT_PRIORITY_2	2	/*Check hang function & Strong function*/
+#define	BB_DBGPORT_PRIORITY_1	1	/*Watch dog function*/
+#define	BB_DBGPORT_RELEASE		0	/*Init value (the lowest priority)*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#define	PHYDM_DBGPRINT		0
+#define	PHYDM_SSCANF(x, y, z)	dcmd_scanf(x, y, z)
+#define	PHYDM_VAST_INFO_SNPRINTF	PDM_SNPF
+#if (PHYDM_DBGPRINT == 1)
+#define	PDM_SNPF(msg)	\
+	do {\
+		rsprintf msg;\
+		pr_debug("%s", output);\
+	} while (0)
+#else
+
+static __inline void PDM_SNPF(u32	out_len, u32 used, char * buff, int len, char *fmt, ...)
+{
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		/*DbgPrint("DM Print Fail\n");*/
+		return;
+	}
+
+	DCMD_Printf(buf);
+}
+
+#endif	/*#if (PHYDM_DBGPRINT == 1)*/
+#else	/*(DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))*/
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE) || defined(__OSK__)
+	#define	PHYDM_DBGPRINT		0
+	#else
+	#define	PHYDM_DBGPRINT		1
+	#endif
+#define	MAX_ARGC				20
+#define	MAX_ARGV				16
+#define	DCMD_DECIMAL			"%d"
+#define	DCMD_CHAR				"%c"
+#define	DCMD_HEX				"%x"
+
+#define	PHYDM_SSCANF(x, y, z)	sscanf(x, y, z)
+
+#define	PHYDM_VAST_INFO_SNPRINTF(out_len, used, buff, len, fmt, args...)	\
+	do {								\
+		RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+			DBG_DMESG, fmt, ##args);		\
+	} while (0)
+
+#if (PHYDM_DBGPRINT == 1)
+#define	PDM_SNPF(out_len, used, buff, len, fmt, args...)		\
+	do {								\
+		snprintf(buff, len, fmt, ##args);			\
+		pr_debug("%s", output);					\
+	} while (0)
+#else
+#define	PDM_SNPF(out_len, used, buff, len, fmt, args...)		\
+	do {								\
+		if (out_len > used)					\
+			used += snprintf(buff, len, fmt, ##args);	\
+	} while (0)
+#endif
+#endif
+
+void phydm_init_debug_setting(struct dm_struct *dm);
+
+void phydm_bb_dbg_port_header_sel(void *dm_void, u32 header_idx);
+
+u8 phydm_set_bb_dbg_port(void *dm_void, u8 curr_dbg_priority, u32 debug_port);
+
+void phydm_release_bb_dbg_port(void *dm_void);
+
+u32 phydm_get_bb_dbg_port_value(void *dm_void);
+
+void phydm_reset_rx_rate_distribution(struct dm_struct *dm);
+
+void phydm_rx_rate_distribution(void *dm_void);
+
+void phydm_get_avg_phystatus_val(void *dm_void);
+
+void phydm_get_phy_statistic(void *dm_void);
+
+void phydm_basic_dbg_message(void *dm_void);
+
+void phydm_basic_profile(void *dm_void, u32 *_used, char *output,
+			 u32 *_out_len);
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+s32 phydm_cmd(struct dm_struct *dm, char *input, u32 in_len, u8 flag,
+	      char *output, u32 out_len);
+#endif
+void phydm_cmd_parser(struct dm_struct *dm, char input[][16], u32 input_num,
+		      u8 flag, char *output, u32 out_len);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phydm_sbd_check(
+	struct	dm_struct	*dm
+);
+
+void phydm_sbd_callback(
+	struct phydm_timer_list		*timer
+);
+
+void phydm_sbd_workitem_callback(
+	void	*context
+);
+#endif
+
+void phydm_fw_trace_en_h2c(void *dm_void, boolean enable,
+			   u32 fw_debug_component, u32 monitor_mode, u32 macid);
+
+void phydm_fw_trace_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+void phydm_fw_trace_handler_code(void *dm_void, u8 *buffer, u8 cmd_len);
+
+void phydm_fw_trace_handler_8051(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+#endif /* __ODM_DBG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dfs.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dfs.c
new file mode 100644
index 000000000000..a930e0fc18fd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dfs.c
@@ -0,0 +1,690 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*
+============================================================
+ include files
+============================================================
+*/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if defined(CONFIG_PHYDM_DFS_MASTER)
+
+boolean phydm_dfs_is_meteorology_channel(void *dm_void){
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	
+	u8 c_channel = *dm->channel;
+	u8 band_width = *dm->band_width;
+	
+	return ( (band_width == CHANNEL_WIDTH_80 && (c_channel) >= 116 && (c_channel) <= 128) || 
+	  (band_width == CHANNEL_WIDTH_40 && (c_channel) >= 116 && (c_channel) <= 128) ||
+	  (band_width == CHANNEL_WIDTH_20 && (c_channel) >= 120 && (c_channel) <= 128) );
+}
+
+void phydm_radar_detect_reset(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+	odm_set_bb_reg(dm, 0x924, BIT(15), 1);
+}
+
+void phydm_radar_detect_disable(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+	PHYDM_DBG(dm, DBG_DFS, "\n");
+}
+
+static void phydm_radar_detect_with_dbg_parm(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_set_bb_reg(dm, 0x918, MASKDWORD, dm->radar_detect_reg_918);
+	odm_set_bb_reg(dm, 0x91c, MASKDWORD, dm->radar_detect_reg_91c);
+	odm_set_bb_reg(dm, 0x920, MASKDWORD, dm->radar_detect_reg_920);
+	odm_set_bb_reg(dm, 0x924, MASKDWORD, dm->radar_detect_reg_924);
+}
+
+/* Init radar detection parameters, called after ch, bw is set */
+void phydm_radar_detect_enable(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	u8 region_domain = dm->dfs_region_domain;
+	u8 c_channel = *dm->channel;
+	u8 band_width = *dm->band_width;
+	u8 enable = 0;
+
+	PHYDM_DBG(dm, DBG_DFS, "test, region_domain = %d\n", region_domain);
+	if (region_domain == PHYDM_DFS_DOMAIN_UNKNOWN) {
+		PHYDM_DBG(dm, DBG_DFS, "PHYDM_DFS_DOMAIN_UNKNOWN\n");
+		goto exit;
+	}
+
+	if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8812 | ODM_RTL8881A)) {
+		odm_set_bb_reg(dm, 0x814, 0x3fffffff, 0x04cc4d10);
+		odm_set_bb_reg(dm, 0x834, MASKBYTE0, 0x06);
+
+		if (dm->radar_detect_dbg_parm_en) {
+			phydm_radar_detect_with_dbg_parm(dm);
+			enable = 1;
+			goto exit;
+		}
+
+		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c17ecdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0fa21a20);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0f69204);
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67234);
+
+			if (c_channel >= 52 && c_channel <= 64) {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16ecdf);
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0f141a20);
+			} else {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16acdf);
+				if (band_width == CHANNEL_WIDTH_20)
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64721a20);
+				else
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68721a20);
+			}
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16acdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67231);
+			if (band_width == CHANNEL_WIDTH_20)
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64741a20);
+			else
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68741a20);
+
+		} else {
+			/* not supported */
+			PHYDM_DBG(dm, DBG_DFS, "Unsupported dfs_region_domain:%d\n", region_domain);
+			goto exit;
+		}
+
+	} else if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
+		odm_set_bb_reg(dm, 0x814, 0x3fffffff, 0x04cc4d10);
+		odm_set_bb_reg(dm, 0x834, MASKBYTE0, 0x06);
+
+		/* 8822B only, when BW = 20M, DFIR output is 40Mhz, but DFS input is 80MMHz, so it need to upgrade to 80MHz */
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+			if (band_width == CHANNEL_WIDTH_20)
+				odm_set_bb_reg(dm, 0x1984, BIT(26), 1);
+			else
+				odm_set_bb_reg(dm, 0x1984, BIT(26), 0);
+		}
+
+		if (dm->radar_detect_dbg_parm_en) {
+			phydm_radar_detect_with_dbg_parm(dm);
+			enable = 1;
+			goto exit;
+		}
+
+		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16acdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0fa21a20);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0f57204);
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67234);
+
+			if (c_channel >= 52 && c_channel <= 64) {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c16ecdf);
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x0f141a20);
+			} else {
+				odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c166cdf);
+				if (band_width == CHANNEL_WIDTH_20)
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64721a20);
+				else
+					odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68721a20);
+			}
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			odm_set_bb_reg(dm, 0x918, MASKDWORD, 0x1c166cdf);
+			odm_set_bb_reg(dm, 0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, 0x920, MASKDWORD, 0xe0d67231);
+			if (band_width == CHANNEL_WIDTH_20)
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x64741a20);
+			else
+				odm_set_bb_reg(dm, 0x91c, MASKDWORD, 0x68741a20);
+
+		} else {
+			/* not supported */
+			PHYDM_DBG(dm, DBG_DFS, "Unsupported dfs_region_domain:%d\n", region_domain);
+			goto exit;
+		}
+	} else {
+		/* not supported IC type*/
+		PHYDM_DBG(dm, DBG_DFS, "Unsupported IC type:%d\n", dm->support_ic_type);
+		goto exit;
+	}
+
+	enable = 1;
+
+	dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, 0x91c, 0x000000ff);
+	dfs->pwdb_th = (u8)odm_get_bb_reg(dm, 0x918, 0x00001f00);
+	dfs->peak_th = (u8)odm_get_bb_reg(dm, 0x918, 0x00030000);
+	dfs->short_pulse_cnt_th = (u8)odm_get_bb_reg(dm, 0x920, 0x000f0000);
+	dfs->long_pulse_cnt_th = (u8)odm_get_bb_reg(dm, 0x920, 0x00f00000);
+	dfs->peak_window = (u8)odm_get_bb_reg(dm, 0x920, 0x00000300);
+	dfs->nb2wb_th = (u8)odm_get_bb_reg(dm, 0x920, 0x0000e000);
+
+	phydm_dfs_parameter_init(dm);
+
+exit:
+	if (enable) {
+		phydm_radar_detect_reset(dm);
+		PHYDM_DBG(dm, DBG_DFS, "on cch:%u, bw:%u\n", c_channel, band_width);
+	} else
+		phydm_radar_detect_disable(dm);
+}
+
+void phydm_dfs_parameter_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+
+	u8 i;
+	
+	dfs->fa_mask_th = 30;
+	dfs->det_print = 1;
+	dfs->det_print2 = 0;
+	dfs->st_l2h_min = 0x20;
+	dfs->st_l2h_max = 0x4e;
+	dfs->pwdb_scalar_factor = 12;
+	dfs->pwdb_th = 8;
+	for (i = 0 ; i < 5 ; i++) {
+		dfs->pulse_flag_hist[i] = 0;
+		dfs->radar_det_mask_hist[i] = 0;
+		dfs->fa_inc_hist[i] = 0;
+	}
+
+}
+
+void phydm_dfs_dynamic_setting(
+	void *dm_void
+){
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+
+	u8 peak_th_cur=0, short_pulse_cnt_th_cur=0, long_pulse_cnt_th_cur=0, three_peak_opt_cur=0, three_peak_th2_cur=0;
+	u8 peak_window_cur=0, nb2wb_th_cur=0;
+	u8 region_domain = dm->dfs_region_domain;
+	u8 c_channel = *dm->channel;
+	
+	if (dm->rx_tp <= 2) {
+		dfs->idle_mode = 1;
+		if(dfs->force_TP_mode)
+			dfs->idle_mode = 0;
+	} else{
+		dfs->idle_mode = 0;
+	}
+
+	if ((dfs->idle_mode == 1)) { /*idle (no traffic)*/
+		peak_th_cur = 3;
+		short_pulse_cnt_th_cur = 6;
+		long_pulse_cnt_th_cur = 13;
+		peak_window_cur = 2;
+		nb2wb_th_cur = 6;
+		three_peak_opt_cur = 1;
+		three_peak_th2_cur = 2;
+		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			if ((c_channel >= 52) && (c_channel <= 64)) {
+				short_pulse_cnt_th_cur = 14;
+				long_pulse_cnt_th_cur = 15;
+				nb2wb_th_cur = 3;
+				three_peak_th2_cur = 0;                
+			} else {
+				short_pulse_cnt_th_cur = 6;
+				nb2wb_th_cur = 3;
+				three_peak_th2_cur = 0;
+				long_pulse_cnt_th_cur = 10;
+			}
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			three_peak_th2_cur = 0;
+		} else if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			long_pulse_cnt_th_cur = 15;
+			if (phydm_dfs_is_meteorology_channel(dm)) {/*need to add check cac end condition*/
+				peak_th_cur = 2;
+				nb2wb_th_cur = 3;
+				three_peak_opt_cur = 1;
+				three_peak_th2_cur = 0;	
+				short_pulse_cnt_th_cur = 7;
+			} else {
+				three_peak_opt_cur = 1;
+				three_peak_th2_cur = 0;	
+				short_pulse_cnt_th_cur = 7;
+				nb2wb_th_cur = 3;
+			}
+		} else	/*default: FCC*/
+			three_peak_th2_cur = 0;
+
+	} else { /*in service (with TP)*/
+		peak_th_cur = 2;
+		short_pulse_cnt_th_cur = 6;
+		long_pulse_cnt_th_cur = 9;
+		peak_window_cur = 2;
+		nb2wb_th_cur = 3;
+		three_peak_opt_cur = 1;
+		three_peak_th2_cur = 2;
+		if(region_domain == PHYDM_DFS_DOMAIN_MKK){
+			if ((c_channel >= 52) && (c_channel <= 64)) {
+				long_pulse_cnt_th_cur = 15;
+				short_pulse_cnt_th_cur = 5; /*for high duty cycle*/
+				three_peak_th2_cur = 0;			
+			}
+			else {
+				three_peak_opt_cur = 0;
+				three_peak_th2_cur = 0;
+				long_pulse_cnt_th_cur = 8;
+			}
+		}		
+		else if(region_domain == PHYDM_DFS_DOMAIN_FCC){
+		}
+		else if(region_domain == PHYDM_DFS_DOMAIN_ETSI){
+			long_pulse_cnt_th_cur = 15;
+			short_pulse_cnt_th_cur = 5;
+			three_peak_opt_cur = 0;
+		}
+	}
+
+}
+
+
+boolean
+phydm_radar_detect_dm_check(
+	void *dm_void
+){
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	u8 region_domain = dm->dfs_region_domain, index = 0;
+
+	u16 i = 0, k = 0, fa_count_cur = 0, fa_count_inc = 0, total_fa_in_hist = 0, pre_post_now_acc_fa_in_hist = 0, max_fa_in_hist = 0, vht_crc_ok_cnt_cur = 0;
+	u16 vht_crc_ok_cnt_inc = 0, ht_crc_ok_cnt_cur = 0, ht_crc_ok_cnt_inc = 0, leg_crc_ok_cnt_cur = 0, leg_crc_ok_cnt_inc = 0;
+	u16 total_crc_ok_cnt_inc = 0, short_pulse_cnt_cur = 0, short_pulse_cnt_inc = 0, long_pulse_cnt_cur = 0, long_pulse_cnt_inc = 0, total_pulse_count_inc = 0;
+	u32 regf98_value = 0, reg918_value = 0, reg91c_value = 0, reg920_value = 0, reg924_value = 0;
+	boolean tri_short_pulse = 0, tri_long_pulse = 0, radar_type = 0, fault_flag_det = 0, fault_flag_psd = 0, fa_flag = 0, radar_detected = 0;
+	u8 st_l2h_new = 0, fa_mask_th = 0, sum = 0;
+	u8 c_channel = *dm->channel;
+		
+	/*Get FA count during past 100ms*/
+	fa_count_cur = (u16)odm_get_bb_reg(dm, 0xf48, 0x0000ffff);
+	
+	if (dfs->fa_count_pre == 0)
+		fa_count_inc = 0;
+	else if (fa_count_cur >= dfs->fa_count_pre)
+		fa_count_inc = fa_count_cur - dfs->fa_count_pre;
+	else
+		fa_count_inc = fa_count_cur;
+	dfs->fa_count_pre = fa_count_cur;
+
+	dfs->fa_inc_hist[dfs->mask_idx] = fa_count_inc;
+	
+	for (i=0; i<5; i++) {		
+		total_fa_in_hist = total_fa_in_hist + dfs->fa_inc_hist[i];		
+		if (dfs->fa_inc_hist[i] > max_fa_in_hist)			
+			max_fa_in_hist = dfs->fa_inc_hist[i];	
+	}	
+	if (dfs->mask_idx >= 2)		
+		index = dfs->mask_idx - 2;
+	else		
+		index = 5 + dfs->mask_idx - 2;	
+	if (index == 0)		
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] + dfs->fa_inc_hist[index+1] + dfs->fa_inc_hist[4];	
+	else if (index == 4)		
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] + dfs->fa_inc_hist[0] + dfs->fa_inc_hist[index-1];	
+	else		
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] + dfs->fa_inc_hist[index+1] + dfs->fa_inc_hist[index-1];
+		
+	/*Get VHT CRC32 ok count during past 100ms*/
+	vht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, 0xf0c, 0x00003fff);
+	if (vht_crc_ok_cnt_cur >= dfs->vht_crc_ok_cnt_pre)
+		vht_crc_ok_cnt_inc = vht_crc_ok_cnt_cur - dfs->vht_crc_ok_cnt_pre;
+	else
+		vht_crc_ok_cnt_inc = vht_crc_ok_cnt_cur;
+	dfs->vht_crc_ok_cnt_pre = vht_crc_ok_cnt_cur;
+
+	/*Get HT CRC32 ok count during past 100ms*/
+	ht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, 0xf10, 0x00003fff);
+	if (ht_crc_ok_cnt_cur >= dfs->ht_crc_ok_cnt_pre)
+		ht_crc_ok_cnt_inc = ht_crc_ok_cnt_cur - dfs->ht_crc_ok_cnt_pre;
+	else
+		ht_crc_ok_cnt_inc = ht_crc_ok_cnt_cur;
+	dfs->ht_crc_ok_cnt_pre = ht_crc_ok_cnt_cur;
+
+	/*Get Legacy CRC32 ok count during past 100ms*/
+	leg_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, 0xf14, 0x00003fff);
+	if (leg_crc_ok_cnt_cur >= dfs->leg_crc_ok_cnt_pre)
+		leg_crc_ok_cnt_inc = leg_crc_ok_cnt_cur - dfs->leg_crc_ok_cnt_pre;
+	else
+		leg_crc_ok_cnt_inc = leg_crc_ok_cnt_cur;
+	dfs->leg_crc_ok_cnt_pre = leg_crc_ok_cnt_cur;
+
+	if ((vht_crc_ok_cnt_cur == 0x3fff) ||
+		(ht_crc_ok_cnt_cur == 0x3fff) ||
+		(leg_crc_ok_cnt_cur == 0x3fff)) {
+		odm_set_bb_reg(dm, 0xb58, BIT(0), 1);
+		odm_set_bb_reg(dm, 0xb58, BIT(0), 0);
+	}
+
+	total_crc_ok_cnt_inc = vht_crc_ok_cnt_inc + ht_crc_ok_cnt_inc + leg_crc_ok_cnt_inc;
+
+	/*Get short pulse count, need carefully handle the counter overflow*/
+	regf98_value = odm_get_bb_reg(dm, 0xf98, 0xffffffff);
+	short_pulse_cnt_cur = (u16)(regf98_value & 0x000000ff);
+	if (short_pulse_cnt_cur >= dfs->short_pulse_cnt_pre)
+		short_pulse_cnt_inc = short_pulse_cnt_cur - dfs->short_pulse_cnt_pre;
+	else
+		short_pulse_cnt_inc = short_pulse_cnt_cur;
+	dfs->short_pulse_cnt_pre = short_pulse_cnt_cur;
+
+	/*Get long pulse count, need carefully handle the counter overflow*/
+	long_pulse_cnt_cur = (u16)((regf98_value & 0x0000ff00) >> 8);
+	if (long_pulse_cnt_cur >= dfs->long_pulse_cnt_pre)
+		long_pulse_cnt_inc = long_pulse_cnt_cur - dfs->long_pulse_cnt_pre;
+	else
+		long_pulse_cnt_inc = long_pulse_cnt_cur;
+	dfs->long_pulse_cnt_pre = long_pulse_cnt_cur;
+
+	total_pulse_count_inc = short_pulse_cnt_inc + long_pulse_cnt_inc;
+
+	if (dfs->det_print){
+		PHYDM_DBG(dm, DBG_DFS, "=====================================================================\n");
+		PHYDM_DBG(dm, DBG_DFS, "Total_CRC_OK_cnt_inc[%d] VHT_CRC_ok_cnt_inc[%d] HT_CRC_ok_cnt_inc[%d] LEG_CRC_ok_cnt_inc[%d] FA_count_inc[%d]\n",
+			total_crc_ok_cnt_inc, vht_crc_ok_cnt_inc, ht_crc_ok_cnt_inc, leg_crc_ok_cnt_inc, fa_count_inc);
+		PHYDM_DBG(dm, DBG_DFS, "Init_Gain[%x] 0x91c[%x] 0xf98[%08x] short_pulse_cnt_inc[%d] long_pulse_cnt_inc[%d]\n",
+			dfs->igi_cur, dfs->st_l2h_cur, regf98_value, short_pulse_cnt_inc, long_pulse_cnt_inc);
+		PHYDM_DBG(dm, DBG_DFS, "Throughput: %dMbps\n", dm->rx_tp);
+		reg918_value = odm_get_bb_reg(dm, 0x918, 0xffffffff);
+		reg91c_value = odm_get_bb_reg(dm, 0x91c, 0xffffffff);
+		reg920_value = odm_get_bb_reg(dm, 0x920, 0xffffffff);
+		reg924_value = odm_get_bb_reg(dm, 0x924, 0xffffffff);
+		PHYDM_DBG(dm, DBG_DFS, "0x918[%08x] 0x91c[%08x] 0x920[%08x] 0x924[%08x]\n", reg918_value, reg91c_value, reg920_value, reg924_value);
+		PHYDM_DBG(dm, DBG_DFS, "dfs_regdomain = %d, dbg_mode = %d, idle_mode = %d\n", region_domain, dfs->dbg_mode, dfs->idle_mode);
+	}
+	tri_short_pulse = (regf98_value & BIT(17))? 1 : 0;
+	tri_long_pulse = (regf98_value & BIT(19))? 1 : 0;
+
+	if(tri_short_pulse)
+		radar_type = 0;
+	else if(tri_long_pulse)
+		radar_type = 1;
+
+	if (tri_short_pulse) {
+		odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+		odm_set_bb_reg(dm, 0x924, BIT(15), 1);
+	}
+	if (tri_long_pulse) {
+		odm_set_bb_reg(dm, 0x924, BIT(15), 0);
+		odm_set_bb_reg(dm, 0x924, BIT(15), 1);
+		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {	
+			if ((c_channel >= 52) && (c_channel <= 64)) {
+				tri_long_pulse = 0;
+			}
+		}
+		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			tri_long_pulse = 0;
+		}
+	}
+
+	st_l2h_new = dfs->st_l2h_cur;
+	dfs->pulse_flag_hist[dfs->mask_idx] = tri_short_pulse | tri_long_pulse;
+
+	/* PSD(not ready) */
+
+	fault_flag_det = 0;
+	fault_flag_psd = 0;
+	fa_flag = 0;
+	if(region_domain == PHYDM_DFS_DOMAIN_ETSI){
+		fa_mask_th = dfs->fa_mask_th + 20;		
+	}
+	else{
+		fa_mask_th = dfs->fa_mask_th;		
+	}
+	if (max_fa_in_hist >= fa_mask_th || total_fa_in_hist >= fa_mask_th || pre_post_now_acc_fa_in_hist >= fa_mask_th || (dfs->igi_cur >= 0x30)){		
+		st_l2h_new = dfs->st_l2h_max;
+		dfs->radar_det_mask_hist[index] = 1;		
+		if (dfs->pulse_flag_hist[index] == 1){			
+			dfs->pulse_flag_hist[index] = 0;			
+			if (dfs->det_print2){
+				PHYDM_DBG(dm, DBG_DFS, "Radar is masked : FA mask\n");
+			}
+		}
+		fa_flag = 1;
+	} else {
+		dfs->radar_det_mask_hist[index] = 0;
+	}
+
+	if (dfs->det_print) {
+		PHYDM_DBG(dm, DBG_DFS, "mask_idx: %d\n", dfs->mask_idx);
+		PHYDM_DBG(dm, DBG_DFS, "radar_det_mask_hist: ");
+		for (i=0; i<5; i++)
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->radar_det_mask_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS, "pulse_flag_hist: ");
+		for (i=0; i<5; i++)
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->pulse_flag_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS, "fa_inc_hist: ");
+		for (i=0; i<5; i++)			
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->fa_inc_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS,
+			"\nfa_mask_th: %d max_fa_in_hist: %d total_fa_in_hist: %d pre_post_now_acc_fa_in_hist: %d ", fa_mask_th, max_fa_in_hist, total_fa_in_hist, pre_post_now_acc_fa_in_hist);
+	}
+
+	sum = 0;
+	for (k=0; k<5; k++) {
+		if (dfs->radar_det_mask_hist[k] == 1)
+			sum++;
+	}
+
+	if (dfs->mask_hist_checked <= 5)
+		dfs->mask_hist_checked++;
+
+	if ((dfs->mask_hist_checked >= 5) && dfs->pulse_flag_hist[index])
+	{
+		if (sum <= 2) 
+		{
+			radar_detected = 1 ;
+			PHYDM_DBG(dm, DBG_DFS, "Detected type %d radar signal!\n", radar_type);
+		}
+		else {
+			fault_flag_det = 1;
+			if (dfs->det_print2){
+				PHYDM_DBG(dm, DBG_DFS, "Radar is masked : mask_hist large than thd\n");
+			}
+		}
+	}
+
+	dfs->mask_idx++;
+	if (dfs->mask_idx == 5)
+		dfs->mask_idx = 0;
+
+	if ((fault_flag_det == 0) && (fault_flag_psd == 0) && (fa_flag ==0)) {		
+		if (dfs->igi_cur < 0x30) {
+			st_l2h_new = dfs->st_l2h_min;
+		}
+	}
+	
+	if ((st_l2h_new != dfs->st_l2h_cur)) {
+		if (st_l2h_new < dfs->st_l2h_min) {			
+			dfs->st_l2h_cur = dfs->st_l2h_min;			
+		}
+		else if (st_l2h_new > dfs->st_l2h_max)
+			dfs->st_l2h_cur = dfs->st_l2h_max;
+		else
+			dfs->st_l2h_cur = st_l2h_new;
+		odm_set_bb_reg(dm, 0x91c, 0xff, dfs->st_l2h_cur);
+
+		dfs->pwdb_th = ((int)dfs->st_l2h_cur - (int)dfs->igi_cur)/2 + dfs->pwdb_scalar_factor;
+		dfs->pwdb_th = MAX_2(dfs->pwdb_th, (int)dfs->pwdb_th); /*limit the pwdb value to absoulte lower bound 8*/
+		dfs->pwdb_th = MIN_2(dfs->pwdb_th, 0x1f);    /*limit the pwdb value to absoulte upper bound 0x1f*/
+		odm_set_bb_reg(dm, 0x918, 0x00001f00, dfs->pwdb_th);
+	}
+
+	if (dfs->det_print) {
+		PHYDM_DBG(dm, DBG_DFS,
+			"fault_flag_det[%d], fault_flag_psd[%d], DFS_detected [%d]\n", fault_flag_det, fault_flag_psd, radar_detected);
+	}
+
+	return radar_detected;
+
+}
+
+boolean phydm_radar_detect(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	boolean enable_DFS = false;
+	boolean radar_detected = false;
+
+	dfs->igi_cur = (u8)odm_get_bb_reg(dm, 0xc50, 0x0000007f);
+
+	dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, 0x91c, 0x000000ff);
+
+	/* dynamic pwdb calibration */
+	if (dfs->igi_pre != dfs->igi_cur) {
+		dfs->pwdb_th = ((int)dfs->st_l2h_cur - (int)dfs->igi_cur)/2 + dfs->pwdb_scalar_factor;
+		dfs->pwdb_th = MAX_2(dfs->pwdb_th_cur, (int)dfs->pwdb_th); /* limit the pwdb value to absoulte lower bound 0xa */
+		dfs->pwdb_th = MIN_2(dfs->pwdb_th_cur, 0x1f);    /* limit the pwdb value to absoulte upper bound 0x1f */
+		odm_set_bb_reg(dm,  0x918, 0x00001f00, dfs->pwdb_th);
+	}
+
+	dfs->igi_pre = dfs->igi_cur;
+
+	phydm_dfs_dynamic_setting(dm);
+	radar_detected = phydm_radar_detect_dm_check(dm);
+
+	if (odm_get_bb_reg(dm, 0x924, BIT(15)))
+		enable_DFS = true;
+
+	if (enable_DFS && radar_detected) {
+		PHYDM_DBG(dm, DBG_DFS, "Radar detect: enable_DFS:%d, radar_detected:%d\n", enable_DFS, radar_detected);
+		phydm_radar_detect_reset(dm);
+                if (dfs->dbg_mode == 1){
+			PHYDM_DBG(dm, DBG_DFS, "Radar is detected in DFS dbg mode.\n");
+			radar_detected = 0;
+		}
+	}
+
+	return enable_DFS && radar_detected;
+}
+
+
+void
+phydm_dfs_debug(
+	void		*dm_void,
+	u32		*const argv,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS	*dfs = (struct _DFS_STATISTICS *)phydm_get_structure(dm, PHYDM_DFS);
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	dfs->dbg_mode = (boolean)argv[0];
+	dfs->force_TP_mode = (boolean)argv[1];
+	dfs->det_print = (boolean)argv[2];
+	dfs->det_print2 = (boolean)argv[3];
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "dbg_mode: %d, force_TP_mode: %d, det_print: %d, det_print2: %d\n",
+		       dfs->dbg_mode, dfs->force_TP_mode, dfs->det_print,
+		       dfs->det_print2);
+	
+	/*switch (argv[0]) {
+	case 1:
+#if defined(CONFIG_PHYDM_DFS_MASTER)
+		 set dbg parameters for radar detection instead of the default value 
+		if (argv[1] == 1) {
+			dm->radar_detect_reg_918 = argv[2];
+			dm->radar_detect_reg_91c = argv[3];
+			dm->radar_detect_reg_920 = argv[4];
+			dm->radar_detect_reg_924 = argv[5];
+			dm->radar_detect_dbg_parm_en = 1;
+
+			PDM_SNPF((output + used, out_len - used, "Radar detection with dbg parameter\n"));
+			PDM_SNPF((output + used, out_len - used, "reg918:0x%08X\n", dm->radar_detect_reg_918));
+			PDM_SNPF((output + used, out_len - used, "reg91c:0x%08X\n", dm->radar_detect_reg_91c));
+			PDM_SNPF((output + used, out_len - used, "reg920:0x%08X\n", dm->radar_detect_reg_920));
+			PDM_SNPF((output + used, out_len - used, "reg924:0x%08X\n", dm->radar_detect_reg_924));
+		} else {
+			dm->radar_detect_dbg_parm_en = 0;
+			PDM_SNPF((output + used, out_len - used, "Radar detection with default parameter\n"));
+		}
+		phydm_radar_detect_enable(dm);
+#endif  defined(CONFIG_PHYDM_DFS_MASTER) 
+
+		break;
+	default:
+		break;
+	}*/
+}
+
+
+
+#endif /* defined(CONFIG_PHYDM_DFS_MASTER) */
+
+boolean
+phydm_is_dfs_band(
+	void		*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (((*dm->channel >= 52) && (*dm->channel <= 64)) ||
+		((*dm->channel >= 100) && (*dm->channel <= 140)))
+		return true;
+	else
+		return false;
+}
+
+boolean
+phydm_dfs_master_enabled(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	return *dm->dfs_master_enabled ? true : false;
+#else
+	return false;
+#endif
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dfs.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dfs.h
new file mode 100644
index 000000000000..a5c87fdf8917
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dfs.h
@@ -0,0 +1,119 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __PHYDM_DFS_H__
+#define __PHYDM_DFS_H__
+
+#define DFS_VERSION	"1.1"
+
+/* ============================================================
+  Definition
+ ============================================================
+*/
+
+/*
+============================================================
+1  structure
+ ============================================================
+*/
+
+struct _DFS_STATISTICS {
+	u8			mask_idx;
+	u8			igi_cur;
+	u8			igi_pre;
+	u8			st_l2h_cur;
+	u16			fa_count_pre;
+	u16			fa_inc_hist[5];	
+	u16			vht_crc_ok_cnt_pre;
+	u16			ht_crc_ok_cnt_pre;
+	u16			leg_crc_ok_cnt_pre;
+	u16			short_pulse_cnt_pre;
+	u16			long_pulse_cnt_pre;
+	u8			pwdb_th;
+	u8			pwdb_th_cur;
+	u8			pwdb_scalar_factor;	
+	u8			peak_th;
+	u8			short_pulse_cnt_th;
+	u8			long_pulse_cnt_th;
+	u8			peak_window;
+	u8			nb2wb_th;
+	u8			fa_mask_th;
+	u8			det_flag_offset;
+	u8			st_l2h_max;
+	u8			st_l2h_min;
+	u8			mask_hist_checked;
+	boolean		pulse_flag_hist[5];
+	boolean		radar_det_mask_hist[5];
+	boolean		idle_mode;
+	boolean		force_TP_mode;
+	boolean		dbg_mode;
+	boolean		det_print;
+	boolean		det_print2;
+};
+
+
+/* ============================================================
+  enumeration
+ ============================================================
+*/
+
+enum phydm_dfs_region_domain {
+	PHYDM_DFS_DOMAIN_UNKNOWN = 0,
+	PHYDM_DFS_DOMAIN_FCC = 1,
+	PHYDM_DFS_DOMAIN_MKK = 2,
+	PHYDM_DFS_DOMAIN_ETSI = 3,
+};
+
+/*
+============================================================
+  function prototype
+============================================================
+*/
+#if defined(CONFIG_PHYDM_DFS_MASTER)
+void phydm_radar_detect_reset(void *dm_void);
+void phydm_radar_detect_disable(void *dm_void);
+void phydm_radar_detect_enable(void *dm_void);
+boolean phydm_radar_detect(void *dm_void);
+void phydm_dfs_parameter_init(void *dm_void);
+void phydm_dfs_debug(void *dm_void, u32 *const argv, u32 *_used, char *output, u32 *_out_len);
+#endif /* defined(CONFIG_PHYDM_DFS_MASTER) */
+
+boolean 
+phydm_dfs_is_meteorology_channel(
+	void		*dm_void
+);
+
+boolean
+phydm_is_dfs_band(
+	void		*dm_void
+);
+
+boolean
+phydm_dfs_master_enabled(
+	void		*dm_void
+);
+
+#endif /*#ifndef __PHYDM_DFS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.c
index 468281fb7ed2..f43bb485b57e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.c
@@ -1,2086 +1,1869 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-
-VOID
-ODM_ChangeDynamicInitGainThresh(
-	IN	PVOID		pDM_VOID,
-	IN	u4Byte		DM_Type,
-	IN	u4Byte		DM_Value
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T			pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-	if (DM_Type == DIG_TYPE_THRESH_HIGH)
-	{
-		pDM_DigTable->RssiHighThresh = DM_Value;		
-	}
-	else if (DM_Type == DIG_TYPE_THRESH_LOW)
-	{
-		pDM_DigTable->RssiLowThresh = DM_Value;
-	}
-	else if (DM_Type == DIG_TYPE_ENABLE)
-	{
-		pDM_DigTable->Dig_Enable_Flag	= TRUE;
-	}	
-	else if (DM_Type == DIG_TYPE_DISABLE)
-	{
-		pDM_DigTable->Dig_Enable_Flag = FALSE;
-	}	
-	else if (DM_Type == DIG_TYPE_BACKOFF)
-	{
-		if(DM_Value > 30)
-			DM_Value = 30;
-		pDM_DigTable->BackoffVal = (u1Byte)DM_Value;
-	}
-	else if(DM_Type == DIG_TYPE_RX_GAIN_MIN)
-	{
-		if(DM_Value == 0)
-			DM_Value = 0x1;
-		pDM_DigTable->rx_gain_range_min = (u1Byte)DM_Value;
-	}
-	else if(DM_Type == DIG_TYPE_RX_GAIN_MAX)
-	{
-		if(DM_Value > 0x50)
-			DM_Value = 0x50;
-		pDM_DigTable->rx_gain_range_max = (u1Byte)DM_Value;
-	}
-}	// DM_ChangeDynamicInitGainThresh //
-
-int 
-getIGIForDiff(int value_IGI)
-{
-	#define ONERCCA_LOW_TH		0x30
-	#define ONERCCA_LOW_DIFF		8
-
-	if (value_IGI < ONERCCA_LOW_TH) {
-		if ((ONERCCA_LOW_TH - value_IGI) < ONERCCA_LOW_DIFF)
-			return ONERCCA_LOW_TH;
-		else
-			return value_IGI + ONERCCA_LOW_DIFF;
-	} else {
-		return value_IGI;
-	}
-}
-
-VOID
-odm_FAThresholdCheck(
-	IN		PVOID			pDM_VOID,
-	IN		BOOLEAN			bDFSBand,
-	IN		BOOLEAN			bPerformance,
-	IN		u4Byte			RxTp,
-	IN		u4Byte			TxTp,
-	OUT		u4Byte*			dm_FA_thres
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	if(pDM_Odm->bLinked && (bPerformance||bDFSBand))
-	{
-		if(pDM_Odm->SupportICType == ODM_RTL8192D)
-		{
-			// 8192D special case
-			dm_FA_thres[0] = DM_DIG_FA_TH0_92D;
-			dm_FA_thres[1] = DM_DIG_FA_TH1_92D;
-			dm_FA_thres[2] = DM_DIG_FA_TH2_92D;
-		}
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-		else if(pDM_Odm->SupportPlatform & (ODM_AP|ODM_ADSL))
-		{
-			// For AP
-			if((RxTp>>2) > TxTp && RxTp < 10000 && RxTp > 500)			// 10Mbps & 0.5Mbps
-			{
-				dm_FA_thres[0] = 0x080;
-				dm_FA_thres[1] = 0x100;
-				dm_FA_thres[2] = 0x200;			
-			}
-			else
-			{
-				dm_FA_thres[0] = 0x100;
-				dm_FA_thres[1] = 0x200;
-				dm_FA_thres[2] = 0x300;	
-			}
-		}
-#else
-		else if(pDM_Odm->SupportICType == ODM_RTL8723A && pDM_Odm->bBtLimitedDig)
-		{
-			// 8723A BT special case
-			dm_FA_thres[0] = DM_DIG_FA_TH0;
-			dm_FA_thres[1] = 0x250;
-			dm_FA_thres[2] = 0x300;
-		}
-#endif
-		else
-		{
-			// For NIC
-			dm_FA_thres[0] = DM_DIG_FA_TH0;
-			dm_FA_thres[1] = DM_DIG_FA_TH1;
-			dm_FA_thres[2] = DM_DIG_FA_TH2;
-		}
-	}
-	else
-	{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-		if(bDFSBand)
-		{
-			// For DFS band and no link
-			dm_FA_thres[0] = 250;
-			dm_FA_thres[1] = 1000;
-			dm_FA_thres[2] = 2000;
-		}
-		else
-#endif
-		{
-			dm_FA_thres[0] = 2000;
-			dm_FA_thres[1] = 4000;
-			dm_FA_thres[2] = 5000;
-		}
-	}
-	return;
-}
-
-u1Byte
-odm_ForbiddenIGICheck(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			DIG_Dynamic_MIN,
-	IN		u1Byte			CurrentIGI
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T						pDM_DigTable = &pDM_Odm->DM_DigTable;
-	PFALSE_ALARM_STATISTICS 	pFalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm, PHYDM_FALSEALMCNT);
-	u1Byte						rx_gain_range_min = pDM_DigTable->rx_gain_range_min;
-
-	if(pFalseAlmCnt->Cnt_all > 10000)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Abnormally false alarm case. \n"));
-
-		if(pDM_DigTable->LargeFAHit != 3)
-			pDM_DigTable->LargeFAHit++;
-		
-		if(pDM_DigTable->ForbiddenIGI < CurrentIGI)//if(pDM_DigTable->ForbiddenIGI < pDM_DigTable->CurIGValue)
-		{
-			pDM_DigTable->ForbiddenIGI = CurrentIGI;//pDM_DigTable->ForbiddenIGI = pDM_DigTable->CurIGValue;
-			pDM_DigTable->LargeFAHit = 1;
-		}
-
-		if(pDM_DigTable->LargeFAHit >= 3)
-		{
-			if((pDM_DigTable->ForbiddenIGI + 2) > pDM_DigTable->rx_gain_range_max)
-				rx_gain_range_min = pDM_DigTable->rx_gain_range_max;
-			else
-				rx_gain_range_min = (pDM_DigTable->ForbiddenIGI + 2);
-			pDM_DigTable->Recover_cnt = 1800;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Abnormally false alarm case: Recover_cnt = %d \n", pDM_DigTable->Recover_cnt));
-		}
-	}
-	else
-	{
-		if(pDM_DigTable->Recover_cnt != 0)
-		{
-			pDM_DigTable->Recover_cnt --;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Normal Case: Recover_cnt = %d \n", pDM_DigTable->Recover_cnt));
-		}
-		else
-		{
-			if(pDM_DigTable->LargeFAHit < 3)
-			{
-				if((pDM_DigTable->ForbiddenIGI - 2) < DIG_Dynamic_MIN) //DM_DIG_MIN)
-				{
-					pDM_DigTable->ForbiddenIGI = DIG_Dynamic_MIN; //DM_DIG_MIN;
-					rx_gain_range_min = DIG_Dynamic_MIN; //DM_DIG_MIN;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Normal Case: At Lower Bound\n"));
-				}
-				else
-				{
-					pDM_DigTable->ForbiddenIGI -= 2;
-					rx_gain_range_min = (pDM_DigTable->ForbiddenIGI + 2);
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Normal Case: Approach Lower Bound\n"));
-				}
-			}
-			else
-			{
-				pDM_DigTable->LargeFAHit = 0;
-			}
-		}
-	}
-	
-	return rx_gain_range_min;
-
-}
-
-VOID
-odm_InbandNoiseCalculate (	
-	IN		PVOID		pDM_VOID
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T				pDM_DigTable = &pDM_Odm->DM_DigTable;
-	u1Byte				IGIBackup, TimeCnt = 0, ValidCnt = 0;
-	BOOLEAN				bTimeout = TRUE;
-	s1Byte				sNoise_A, sNoise_B;
-	s4Byte				NoiseRpt_A = 0,NoiseRpt_B = 0;
-	u4Byte				tmp = 0;
-	static	u1Byte		failCnt = 0;
-
-	if(!(pDM_Odm->SupportICType & (ODM_RTL8192E)))
-		return;
-
-	if(pDM_Odm->RFType == ODM_1T1R || *(pDM_Odm->pOnePathCCA) != ODM_CCA_2R)
-		return;
-
-	if(!pDM_DigTable->bNoiseEst)
-		return;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_InbandNoiseEstimate()========>\n"));
-	
-	//1 Set initial gain.
-	IGIBackup = pDM_DigTable->CurIGValue;
-	pDM_DigTable->IGIOffset_A = 0;
-	pDM_DigTable->IGIOffset_B = 0;
-	ODM_Write_DIG(pDM_Odm, 0x24);
-
-	//1 Update idle time power report	
-	if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		ODM_SetBBReg(pDM_Odm, ODM_REG_TX_ANT_CTRL_11N, BIT25, 0x0);
-
-	delay_ms(2);
-
-	//1 Get noise power level
-	while(1)
-	{
-		//2 Read Noise Floor Report
-		if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-			tmp = ODM_GetBBReg(pDM_Odm, 0x8f8, bMaskLWord);
-
-		sNoise_A = (s1Byte)(tmp & 0xff);
-		sNoise_B = (s1Byte)((tmp & 0xff00)>>8);
-
-		//ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("sNoise_A = %d, sNoise_B = %d\n",sNoise_A, sNoise_B));
-
-		if((sNoise_A < 20 && sNoise_A >= -70) && (sNoise_B < 20 && sNoise_B >= -70))
-		{
-			ValidCnt++;
-			NoiseRpt_A += sNoise_A;
-			NoiseRpt_B += sNoise_B;
-			//ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("sNoise_A = %d, sNoise_B = %d\n",sNoise_A, sNoise_B));
-		}
-
-		TimeCnt++;
-		bTimeout = (TimeCnt >= 150)?TRUE:FALSE;
-		
-		if(ValidCnt == 20 || bTimeout)
-			break;
-
-		delay_ms(2);
-		
-	}
-
-	//1 Keep idle time power report	
-	if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-		ODM_SetBBReg(pDM_Odm, ODM_REG_TX_ANT_CTRL_11N, BIT25, 0x1);
-
-	//1 Recover IGI
-	ODM_Write_DIG(pDM_Odm, IGIBackup);
-	
-	//1 Calculate Noise Floor
-	if(ValidCnt != 0)
-	{
-		NoiseRpt_A  /= (ValidCnt<<1);
-		NoiseRpt_B  /= (ValidCnt<<1);
-	}
-	
-	if(bTimeout)
-	{
-		NoiseRpt_A = 0;
-		NoiseRpt_B = 0;
-
-		failCnt ++;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("Noise estimate fail time = %d\n", failCnt));
-		
-		if(failCnt == 3)
-		{
-			failCnt = 0;
-			pDM_DigTable->bNoiseEst = FALSE;
-		}
-	}
-	else
-	{
-		NoiseRpt_A = -110 + 0x24 + NoiseRpt_A -6;
-		NoiseRpt_B = -110 + 0x24 + NoiseRpt_B -6;
-		pDM_DigTable->bNoiseEst = FALSE;
-		failCnt = 0;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("NoiseRpt_A = %d, NoiseRpt_B = %d\n", NoiseRpt_A, NoiseRpt_B));
-	}
-
-	//1 Calculate IGI Offset
-	if(NoiseRpt_A > NoiseRpt_B)
-	{
-		pDM_DigTable->IGIOffset_A = NoiseRpt_A - NoiseRpt_B;
-		pDM_DigTable->IGIOffset_B = 0;
-	}
-	else
-	{
-		pDM_DigTable->IGIOffset_A = 0;
-		pDM_DigTable->IGIOffset_B = NoiseRpt_B - NoiseRpt_A;
-	}
-
-#endif
-	return;
-}
-
-VOID
-odm_DigForBtHsMode(
-	IN		PVOID		pDM_VOID
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T					pDM_DigTable=&pDM_Odm->DM_DigTable;
-	u1Byte					digForBtHs=0;
-	u1Byte					digUpBound=0x5a;
-	
-	if(pDM_Odm->bBtConnectProcess)
-	{
-		if(pDM_Odm->SupportICType&(ODM_RTL8723A))
-			digForBtHs = 0x28;
-		else
-			digForBtHs = 0x22;
-	}
-	else
-	{
-		//
-		// Decide DIG value by BT HS RSSI.
-		//
-		digForBtHs = pDM_Odm->btHsRssi+4;
-		
-		//DIG Bound
-		if(pDM_Odm->SupportICType&(ODM_RTL8723A))
-			digUpBound = 0x3e;
-		
-		if(digForBtHs > digUpBound)
-			digForBtHs = digUpBound;
-		if(digForBtHs < 0x1c)
-			digForBtHs = 0x1c;
-
-		// update Current IGI
-		pDM_DigTable->BT30_CurIGI = digForBtHs;
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DigForBtHsMode() : set DigValue=0x%x\n", digForBtHs));
-#endif
-}
-
-VOID
-ODM_Write_DIG(
-	IN	PVOID			pDM_VOID,
-	IN	u1Byte			CurrentIGI
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T			pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-	if (pDM_DigTable->bStopDIG) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("ODM_Write_DIG(): Stop Writing IGI\n"));
-		return;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_TRACE, ("ODM_Write_DIG(): ODM_REG(IGI_A,pDM_Odm)=0x%x, ODM_BIT(IGI,pDM_Odm)=0x%x\n",
-		ODM_REG(IGI_A,pDM_Odm),ODM_BIT(IGI,pDM_Odm)));
-
-	//1 Check initial gain by upper bound		
-	if ((!pDM_DigTable->bPSDInProgress) && pDM_Odm->bLinked)
-	{
-		if (CurrentIGI > pDM_DigTable->rx_gain_range_max) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_TRACE, ("ODM_Write_DIG(): CurrentIGI(0x%02x) is larger than upper bound !!\n", CurrentIGI));
-			CurrentIGI = pDM_DigTable->rx_gain_range_max;
-		}
-		if (pDM_Odm->SupportAbility & ODM_BB_ADAPTIVITY && pDM_Odm->adaptivity_flag == TRUE)
-		{
-			if(CurrentIGI > pDM_Odm->Adaptivity_IGI_upper)
-				CurrentIGI = pDM_Odm->Adaptivity_IGI_upper;
-	
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("ODM_Write_DIG(): Adaptivity case: Force upper bound to 0x%x !!!!!!\n", CurrentIGI));
-		}
-	}
-
-	if(pDM_DigTable->CurIGValue != CurrentIGI)
-	{
-
-		/*Add by YuChen for USB IO too slow issue*/
-		if ((pDM_Odm->SupportAbility & ODM_BB_ADAPTIVITY) && (CurrentIGI > pDM_DigTable->CurIGValue))
-			Phydm_Adaptivity(pDM_Odm, CurrentIGI);
-
-		//1 Set IGI value
-		if(pDM_Odm->SupportPlatform & (ODM_WIN|ODM_CE))
-		{ 
-			ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_A,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-
-			if(pDM_Odm->RFType > ODM_1T1R)
-				ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_B,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-
-			if((pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) && (pDM_Odm->RFType > ODM_2T2R))
-			{
-				ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_C,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-				ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_D,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-			}
-		}
-		else if(pDM_Odm->SupportPlatform & (ODM_AP|ODM_ADSL))
-		{
-			switch(*(pDM_Odm->pOnePathCCA))
-			{
-				case ODM_CCA_2R:
-					ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_A,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-
-					if(pDM_Odm->RFType > ODM_1T1R)
-						ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_B,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-					
-					if((pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) && (pDM_Odm->RFType > ODM_2T2R))
-					{
-						ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_C,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-						ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_D,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-					}
-					break;
-				case ODM_CCA_1R_A:
-					ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_A,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-					if(pDM_Odm->RFType != ODM_1T1R)
-						ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_B,pDM_Odm), ODM_BIT(IGI,pDM_Odm), getIGIForDiff(CurrentIGI));
-					break;
-				case ODM_CCA_1R_B:
-					ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_A,pDM_Odm), ODM_BIT(IGI,pDM_Odm), getIGIForDiff(CurrentIGI));
-					if(pDM_Odm->RFType != ODM_1T1R)
-						ODM_SetBBReg(pDM_Odm, ODM_REG(IGI_B,pDM_Odm), ODM_BIT(IGI,pDM_Odm), CurrentIGI);
-					break;
-			}
-		}
-		pDM_DigTable->CurIGValue = CurrentIGI;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_TRACE, ("ODM_Write_DIG(): CurrentIGI(0x%02x).\n", CurrentIGI));
-	
-}
-
-VOID
-odm_PauseDIG(
-	IN		PVOID					pDM_VOID,
-	IN		PHYDM_PAUSE_TYPE		PauseType,
-	IN		PHYDM_PAUSE_LEVEL		pause_level,
-	IN		u1Byte					IGIValue
-)
-{
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T				pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG()=========> level = %d\n", pause_level));
-
-	if ((pDM_DigTable->pause_dig_level == 0) && (!(pDM_Odm->SupportAbility & ODM_BB_DIG) || !(pDM_Odm->SupportAbility & ODM_BB_FA_CNT))) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, 
-			("odm_PauseDIG(): Return: SupportAbility DIG or FA is disabled !!\n"));
-		return;
-	}
-
-	if (pause_level > DM_DIG_MAX_PAUSE_TYPE) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, 
-			("odm_PauseDIG(): Return: Wrong pause level !!\n"));
-		return;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): pause level = 0x%x, Current value = 0x%x\n", pDM_DigTable->pause_dig_level, IGIValue));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): pause value = 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n", 
-		pDM_DigTable->pause_dig_value[7], pDM_DigTable->pause_dig_value[6], pDM_DigTable->pause_dig_value[5], pDM_DigTable->pause_dig_value[4],
-		pDM_DigTable->pause_dig_value[3], pDM_DigTable->pause_dig_value[2], pDM_DigTable->pause_dig_value[1], pDM_DigTable->pause_dig_value[0]));
-	
-	switch (PauseType) {
-	/* Pause DIG */
-	case PHYDM_PAUSE:
-	{
-		/* Disable DIG */
-		ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_ABILITY, pDM_Odm->SupportAbility & (~ODM_BB_DIG));
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): Pause DIG !!\n"));
-		
-		/* Backup IGI value */
-		if (pDM_DigTable->pause_dig_level == 0) {
-			pDM_DigTable->IGIBackup = pDM_DigTable->CurIGValue;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): Backup IGI  = 0x%x, new IGI = 0x%x\n", pDM_DigTable->IGIBackup, IGIValue));
-		}
-
-		/* Record IGI value */
-		pDM_DigTable->pause_dig_value[pause_level] = IGIValue;
-
-		/* Update pause level */
-		pDM_DigTable->pause_dig_level = (pDM_DigTable->pause_dig_level | BIT(pause_level));
-
-		/* Write new IGI value */
-		if (BIT(pause_level + 1) > pDM_DigTable->pause_dig_level) {
-			ODM_Write_DIG(pDM_Odm, IGIValue);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): IGI of higher level = 0x%x\n",  IGIValue));
-		}
-		break;
-	}
-	/* Resume DIG */
-	case PHYDM_RESUME:
-	{
-		/* check if the level is illegal or not */
-		if ((pDM_DigTable->pause_dig_level & (BIT(pause_level))) != 0) {
-			pDM_DigTable->pause_dig_level = pDM_DigTable->pause_dig_level & (~(BIT(pause_level)));
-			pDM_DigTable->pause_dig_value[pause_level] = 0;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): Resume DIG !!\n"));
-		} else {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): Wrong resume level !!\n"));
-			break;
-		}
-
-		/* Resume DIG */
-		if (pDM_DigTable->pause_dig_level == 0) {
-			/* Write backup IGI value */
-			ODM_Write_DIG(pDM_Odm, pDM_DigTable->IGIBackup);
-			pDM_DigTable->bIgnoreDIG = TRUE;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): Write original IGI = 0x%x\n", pDM_DigTable->IGIBackup));
-
-			/* Enable DIG */
-			ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_ABILITY, pDM_Odm->SupportAbility | ODM_BB_DIG);	
-			break;
-		}
-
-		if (BIT(pause_level) > pDM_DigTable->pause_dig_level) {
-			u1Byte		max_level;
-		
-			/* Calculate the maximum level now */
-			for (max_level = (pause_level - 1); max_level >= 0; max_level--) {
-				if ((pDM_DigTable->pause_dig_level & BIT(max_level)) > 0)
-					break;
-			}
-		
-			/* write IGI of lower level */
-			ODM_Write_DIG(pDM_Odm, pDM_DigTable->pause_dig_value[max_level]);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): Write IGI (0x%x) of level (%d)\n",  
-				 pDM_DigTable->pause_dig_value[max_level], max_level));
-			break;
-		}
-		break;
-	}
-	default:
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): Wrong  type !!\n"));
-		break;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): pause level = 0x%x, Current value = 0x%x\n", pDM_DigTable->pause_dig_level, IGIValue));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_PauseDIG(): pause value = 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n", 
-		pDM_DigTable->pause_dig_value[7], pDM_DigTable->pause_dig_value[6], pDM_DigTable->pause_dig_value[5], pDM_DigTable->pause_dig_value[4],
-		pDM_DigTable->pause_dig_value[3], pDM_DigTable->pause_dig_value[2], pDM_DigTable->pause_dig_value[1], pDM_DigTable->pause_dig_value[0]));
-
-}
-
-BOOLEAN 
-odm_DigAbort(
-	IN		PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T			pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv = pDM_Odm->priv;
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		pAdapter	= pDM_Odm->Adapter;
-	pRXHP_T			pRX_HP_Table  = &pDM_Odm->DM_RXHP_Table;
-#endif
-
-	//SupportAbility
-	if(!(pDM_Odm->SupportAbility & ODM_BB_FA_CNT))
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: SupportAbility ODM_BB_FA_CNT is disabled\n"));
-		return	TRUE;
-	}
-
-	//SupportAbility
-	if(!(pDM_Odm->SupportAbility & ODM_BB_DIG))
-	{	
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: SupportAbility ODM_BB_DIG is disabled\n"));
-		return	TRUE;
-	}
-
-	//ScanInProcess
-	if(*(pDM_Odm->pbScanInProcess))
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: In Scan Progress \n"));
-	    	return	TRUE;
-	}
-
-	if(pDM_DigTable->bIgnoreDIG)
-	{
-		pDM_DigTable->bIgnoreDIG = FALSE;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: Ignore DIG \n"));
-	    	return	TRUE;
-	}
-
-	//add by Neil Chen to avoid PSD is processing
-	if(pDM_Odm->bDMInitialGainEnable == FALSE)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: PSD is Processing \n"));
-		return	TRUE;
-	}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#if OS_WIN_FROM_WIN7(OS_VERSION)
-	if(IsAPModeExist( pAdapter) && pAdapter->bInHctTest)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: Is AP mode or In HCT Test \n"));
-	    	return	TRUE;
-	}
-	#endif
-
-	if(pDM_Odm->bBtHsOperation)
-	{
-		odm_DigForBtHsMode(pDM_Odm);
-	}	
-
-	if(!(pDM_Odm->SupportICType &(ODM_RTL8723A|ODM_RTL8188E)))
-	{
-		if(pRX_HP_Table->RXHP_flag == 1)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: In RXHP Operation \n"));
-			return	TRUE;	
-		}
-	}
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#ifdef CONFIG_SPECIAL_SETTING_FOR_FUNAI_TV	
-	if((pDM_Odm->bLinked) && (pDM_Odm->Adapter->registrypriv.force_igi !=0))
-	{	
-		printk("pDM_Odm->RSSI_Min=%d \n",pDM_Odm->RSSI_Min);
-		ODM_Write_DIG(pDM_Odm,pDM_Odm->Adapter->registrypriv.force_igi);
-		return	TRUE;
-	}
-	#endif
-#else
-	if (!(priv->up_time > 5))
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Return: Not In DIG Operation Period \n"));
-		return	TRUE;
-	}
-#endif
-
-	return	FALSE;
-}
-
-VOID
-odm_DIGInit(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T						pDM_DigTable = &pDM_Odm->DM_DigTable;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	PFALSE_ALARM_STATISTICS 	FalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm, PHYDM_FALSEALMCNT);
-#endif
-
-	pDM_DigTable->bStopDIG = FALSE;
-	pDM_DigTable->bIgnoreDIG = FALSE;
-	pDM_DigTable->bPSDInProgress = FALSE;
-	pDM_DigTable->CurIGValue = (u1Byte) ODM_GetBBReg(pDM_Odm, ODM_REG(IGI_A,pDM_Odm), ODM_BIT(IGI,pDM_Odm));
-	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;
-	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->bMediaConnect_0 = FALSE;
-	pDM_DigTable->bMediaConnect_1 = FALSE;
-
-	//To Initialize pDM_Odm->bDMInitialGainEnable == FALSE to avoid DIG error
-	pDM_Odm->bDMInitialGainEnable = TRUE;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	pDM_DigTable->DIG_Dynamic_MIN_0 = 0x25;
-	pDM_DigTable->DIG_Dynamic_MIN_1 = 0x25;
-
-	// For AP\ ADSL modified DIG
-	pDM_DigTable->bTpTarget = FALSE;
-	pDM_DigTable->bNoiseEst = TRUE;
-	pDM_DigTable->IGIOffset_A = 0;
-	pDM_DigTable->IGIOffset_B = 0;
-	pDM_DigTable->TpTrainTH_min = 0;
-
-	// For RTL8881A
-	FalseAlmCnt->Cnt_Ofdm_fail_pre = 0;
-
-	//Dyanmic EDCCA
-	if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-	{
-		ODM_SetBBReg(pDM_Odm, 0xC50, 0xFFFF0000, 0xfafd);
-	}
-#else
-	pDM_DigTable->DIG_Dynamic_MIN_0 = DM_DIG_MIN_NIC;
-	pDM_DigTable->DIG_Dynamic_MIN_1 = DM_DIG_MIN_NIC;
-
-	//To Initi BT30 IGI
-	pDM_DigTable->BT30_CurIGI=0x32;
-
-	ODM_Memory_Set(pDM_Odm, pDM_DigTable->pause_dig_value, 0, (DM_DIG_MAX_PAUSE_TYPE + 1));
-	pDM_DigTable->pause_dig_level = 0;
-	ODM_Memory_Set(pDM_Odm, pDM_DigTable->pause_cckpd_value, 0, (DM_DIG_MAX_PAUSE_TYPE + 1));
-	pDM_DigTable->pause_cckpd_level = 0;
-#endif
-
-	if(pDM_Odm->BoardType & (ODM_BOARD_EXT_PA|ODM_BOARD_EXT_LNA))
-	{
-		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;
-	}
-	
-}
-
-
-VOID 
-odm_DIG(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER					pAdapter	= pDM_Odm->Adapter;
-	HAL_DATA_TYPE				*pHalData = GET_HAL_DATA(pDM_Odm->Adapter);
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv				priv = pDM_Odm->priv;
-	PSTA_INFO_T   				pEntry;
-#endif
-
-	// Common parameters
-	pDIG_T						pDM_DigTable = &pDM_Odm->DM_DigTable;
-	PFALSE_ALARM_STATISTICS		pFalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm, PHYDM_FALSEALMCNT);
-	BOOLEAN						FirstConnect,FirstDisConnect;
-	u1Byte						DIG_MaxOfMin, DIG_Dynamic_MIN;
-	u1Byte						dm_dig_max, dm_dig_min;
-	u1Byte						CurrentIGI = pDM_DigTable->CurIGValue;
-	u1Byte						offset;
-	u4Byte						dm_FA_thres[3];
-	u4Byte						TxTp = 0, RxTp = 0;
-	BOOLEAN						bDFSBand = FALSE;
-	BOOLEAN						bPerformance = TRUE, bFirstTpTarget = FALSE, bFirstCoverage = FALSE;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	u4Byte						TpTrainTH_MIN = DM_DIG_TP_Target_TH0;
-	static		u1Byte			TimeCnt = 0;
-	u1Byte						i;
-#endif
-
-	if(odm_DigAbort(pDM_Odm) == TRUE)
-		return;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG()===========================>\n\n"));
-	
-
-	//1 Update status
-#if (RTL8192D_SUPPORT==1) 
-	if(pDM_Odm->SupportICType == ODM_RTL8192D)
-	{
-		if(*(pDM_Odm->pMacPhyMode) == ODM_DMSP)
-		{
-			if(*(pDM_Odm->pbMasterOfDMSP))
-			{
-				DIG_Dynamic_MIN = pDM_DigTable->DIG_Dynamic_MIN_0;
-				FirstConnect = (pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == FALSE);
-				FirstDisConnect = (!pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == TRUE);
-			}
-			else
-			{
-				DIG_Dynamic_MIN = pDM_DigTable->DIG_Dynamic_MIN_1;
-				FirstConnect = (pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_1 == FALSE);
-				FirstDisConnect = (!pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_1 == TRUE);
-			}
-		}
-		else
-		{
-			if(*(pDM_Odm->pBandType) == ODM_BAND_5G)
-			{
-				DIG_Dynamic_MIN = pDM_DigTable->DIG_Dynamic_MIN_0;
-				FirstConnect = (pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == FALSE);
-				FirstDisConnect = (!pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == TRUE);
-			}
-			else
-			{
-				DIG_Dynamic_MIN = pDM_DigTable->DIG_Dynamic_MIN_1;
-				FirstConnect = (pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_1 == FALSE);
-				FirstDisConnect = (!pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_1 == TRUE);
-			}
-		}
-	}
-	else
-#endif
-	{	
-		DIG_Dynamic_MIN = pDM_DigTable->DIG_Dynamic_MIN_0;
-		FirstConnect = (pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == FALSE);
-		FirstDisConnect = (!pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == TRUE);
-	}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	//1 Noise Floor Estimate
-	//pDM_DigTable->bNoiseEst = (FirstConnect)?TRUE:pDM_DigTable->bNoiseEst;
-	//odm_InbandNoiseCalculate (pDM_Odm);
-	
-	//1 Mode decision
-	if(pDM_Odm->bLinked)
-	{
-		//2 Calculate total TP
-		for (i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++)
-		{
-			pEntry = pDM_Odm->pODM_StaInfo[i];
-			if(IS_STA_VALID(pEntry))
-			{
-				RxTp += (u4Byte)(pEntry->rx_byte_cnt_LowMAW>>7);
-				TxTp += (u4Byte)(pEntry->tx_byte_cnt_LowMAW>>7);			//Kbps
-			}
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): TX TP = %dkbps, RX TP = %dkbps\n", TxTp, RxTp));
-	}
-
-	switch(pDM_Odm->priv->pshare->rf_ft_var.dig_cov_enable)
-	{
-		case 0:
-		{
-			bPerformance = TRUE;
-			break;
-		}
-		case 1:
-		{
-			bPerformance = FALSE;
-			break;
-		}
-		case 2:
-		{
-			if(pDM_Odm->bLinked)
-			{
-				if(pDM_DigTable->TpTrainTH_min > DM_DIG_TP_Target_TH0)
-					TpTrainTH_MIN = pDM_DigTable->TpTrainTH_min;
-
-				if(pDM_DigTable->TpTrainTH_min > DM_DIG_TP_Target_TH1)
-					TpTrainTH_MIN = DM_DIG_TP_Target_TH1;
-
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): TP training mode lower bound = %dkbps\n", TpTrainTH_MIN));
-
-				//2 Decide DIG mode by total TP
-				if((TxTp + RxTp) > DM_DIG_TP_Target_TH1)			// change to performance mode
-				{
-					bFirstTpTarget = (!pDM_DigTable->bTpTarget)?TRUE:FALSE;
-					pDM_DigTable->bTpTarget = TRUE;
-					bPerformance = TRUE;
-				}
-				else if((TxTp + RxTp) < TpTrainTH_MIN)	// change to coverage mode
-				{
-					bFirstCoverage = (pDM_DigTable->bTpTarget)?TRUE:FALSE;
-					
-					if(TimeCnt < DM_DIG_TP_Training_Period)
-					{
-						pDM_DigTable->bTpTarget = FALSE;
-						bPerformance = FALSE;
-						TimeCnt++;
-					}
-					else
-					{
-						pDM_DigTable->bTpTarget = TRUE;
-						bPerformance = TRUE;
-						bFirstTpTarget = TRUE;
-						TimeCnt = 0;
-					}
-				}
-				else										// remain previous mode
-				{
-					bPerformance = pDM_DigTable->bTpTarget;
-
-					if(!bPerformance)
-					{
-						if(TimeCnt < DM_DIG_TP_Training_Period)
-							TimeCnt++;
-						else
-						{
-							pDM_DigTable->bTpTarget = TRUE;
-							bPerformance = TRUE;
-							bFirstTpTarget = TRUE;
-							TimeCnt = 0;
-						}
-					}
-				}
-
-				if(!bPerformance)
-					pDM_DigTable->TpTrainTH_min = RxTp + TxTp;
-
-			}
-			else
-			{
-				bPerformance = FALSE;
-				pDM_DigTable->TpTrainTH_min = 0;
-			}
-			break;
-		}
-		default:
-			bPerformance = TRUE;
-	}
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("====== DIG mode = %d  ======\n", pDM_Odm->priv->pshare->rf_ft_var.dig_cov_enable));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("====== bPerformance = %d ======\n", bPerformance));
-#endif
-
-	//1 Boundary Decision
-#if (RTL8192C_SUPPORT==1) 
-	if((pDM_Odm->SupportICType & ODM_RTL8192C) && (pDM_Odm->BoardType & (ODM_BOARD_EXT_LNA | ODM_BOARD_EXT_PA)))
-	{
-		//2 High power case
-		if(pDM_Odm->SupportPlatform & (ODM_AP|ODM_ADSL))
-		{
-			dm_dig_max = DM_DIG_MAX_AP_HP;
-			dm_dig_min = DM_DIG_MIN_AP_HP;
-		}
-		else
-		{
-			dm_dig_max = DM_DIG_MAX_NIC_HP;
-			dm_dig_min = DM_DIG_MIN_NIC_HP;
-		}
-		DIG_MaxOfMin = DM_DIG_MAX_AP_HP;
-	}
-	else
-#endif
-	{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-		//2 For AP\ADSL
-		if(!bPerformance)
-		{
-			dm_dig_max = DM_DIG_MAX_AP_COVERAGR;
-			dm_dig_min = DM_DIG_MIN_AP_COVERAGE;
-			DIG_MaxOfMin = DM_DIG_MAX_OF_MIN_COVERAGE;
-		}
-		else
-		{
-			dm_dig_max = DM_DIG_MAX_AP;
-			dm_dig_min = DM_DIG_MIN_AP;
-			DIG_MaxOfMin = DM_DIG_MAX_OF_MIN;
-		}
-
-		//4 DFS band
-		if (((*pDM_Odm->pChannel>= 52) &&(*pDM_Odm->pChannel <= 64)) ||
-			((*pDM_Odm->pChannel >= 100) &&	(*pDM_Odm->pChannel <= 140)))
-		{
-			bDFSBand = TRUE;
-			if (*pDM_Odm->pBandWidth == ODM_BW20M){
-				dm_dig_min = DM_DIG_MIN_AP_DFS+2;
-			}
-			else{
-				dm_dig_min = DM_DIG_MIN_AP_DFS;
-			}
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): ====== In DFS band ======\n"));
-		}
-		
-		//4 TX2path
-		if (priv->pmib->dot11RFEntry.tx2path && !bDFSBand && (*(pDM_Odm->pWirelessMode) == ODM_WM_B))
-				dm_dig_max = 0x2A;
-
-#if RTL8192E_SUPPORT
-#ifdef HIGH_POWER_EXT_LNA
-		if ((pDM_Odm->SupportICType & (ODM_RTL8192E)) && (pDM_Odm->ExtLNA))
-			dm_dig_max = 0x42;						
-#endif
-#endif
-
-#else
-		//2 For WIN\CE
-		if(pDM_Odm->SupportICType >= ODM_RTL8188E)
-			dm_dig_max = 0x5A;
-		else
-			dm_dig_max = DM_DIG_MAX_NIC;
-		
-		if(pDM_Odm->SupportICType != ODM_RTL8821)
-			dm_dig_min = DM_DIG_MIN_NIC;
-		else
-			dm_dig_min = 0x1C;
-
-		DIG_MaxOfMin = DM_DIG_MAX_AP;
-#endif	
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Absolutly upper bound = 0x%x, lower bound = 0x%x\n",dm_dig_max, dm_dig_min));
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	// for P2P case
-	if(0 < *pDM_Odm->pu1ForcedIgiLb)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): P2P case: Force IGI lb to: %u !!!!!!\n", *pDM_Odm->pu1ForcedIgiLb));
-		dm_dig_min = *pDM_Odm->pu1ForcedIgiLb;
-		dm_dig_max = (dm_dig_min <= dm_dig_max) ? (dm_dig_max) : (dm_dig_min + 1);
-	}
-#endif
-
-	//1 Adjust boundary by RSSI
-	if(pDM_Odm->bLinked && bPerformance)
-	{
-		//2 Modify DIG upper bound
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-		offset = 15;
-#else
-		//4 Modify DIG upper bound for 92E, 8723A\B, 8821 & 8812 BT
-		if((pDM_Odm->SupportICType & (ODM_RTL8192E|ODM_RTL8723B|ODM_RTL8812|ODM_RTL8821|ODM_RTL8723A)) && (pDM_Odm->bBtLimitedDig==1))
-		{
-			offset = 10;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Coex. case: Force upper bound to RSSI + %d !!!!!!\n", offset));		
-		}
-		else
-			offset = 15;
-#endif
-
-		if((pDM_Odm->RSSI_Min + offset) > dm_dig_max )
-			pDM_DigTable->rx_gain_range_max = dm_dig_max;
-		else if((pDM_Odm->RSSI_Min + offset) < dm_dig_min )
-			pDM_DigTable->rx_gain_range_max = dm_dig_min;
-		else
-			pDM_DigTable->rx_gain_range_max = pDM_Odm->RSSI_Min + offset;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-		//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;
-		}
-#else
-		{
-			//4 For AP
-#ifdef __ECOS
-			HAL_REORDER_BARRIER();
-#else
-			rmb();
-#endif
-			if (bDFSBand)
-			{
-				DIG_Dynamic_MIN = dm_dig_min;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): DFS band: Force lower bound to 0x%x after link !!!!!!\n", dm_dig_min));
-			}
-			else 
-			{
-				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;
-			}
-		}
-#endif
-	}
-	else
-	{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-		if(bPerformance && bDFSBand)
-		{
-			pDM_DigTable->rx_gain_range_max = 0x28;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): DFS band: Force upper bound to 0x%x before link !!!!!!\n", pDM_DigTable->rx_gain_range_max));
-		}
-		else
-#endif
-		{
-			pDM_DigTable->rx_gain_range_max = DM_DIG_MAX_OF_MIN;
-		}
-		DIG_Dynamic_MIN = dm_dig_min;
-	}
-	
-	//1 Force Lower Bound for AntDiv
-	if(pDM_Odm->bLinked && !pDM_Odm->bOneEntryOnly)
-	{
-		if((pDM_Odm->SupportICType & ODM_ANTDIV_SUPPORT) && (pDM_Odm->SupportAbility & ODM_BB_ANT_DIV))
-		{
-			if (pDM_Odm->AntDivType == CG_TRX_HW_ANTDIV || pDM_Odm->AntDivType == CG_TRX_SMART_ANTDIV) {
-				if (pDM_DigTable->AntDiv_RSSI_max > DIG_MaxOfMin)
-					DIG_Dynamic_MIN = DIG_MaxOfMin;
-				else
-					DIG_Dynamic_MIN = (u1Byte) pDM_DigTable->AntDiv_RSSI_max;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Antenna diversity case: Force lower bound to 0x%x !!!!!!\n", DIG_Dynamic_MIN));
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Antenna diversity case: RSSI_max = 0x%x !!!!!!\n", pDM_DigTable->AntDiv_RSSI_max));
-			}
-		}
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Adjust boundary by RSSI Upper bound = 0x%x, Lower bound = 0x%x\n",
-		pDM_DigTable->rx_gain_range_max, DIG_Dynamic_MIN));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Link status: bLinked = %d, RSSI = %d, bFirstConnect = %d, bFirsrDisConnect = %d\n\n",
-		pDM_Odm->bLinked, pDM_Odm->RSSI_Min, FirstConnect, FirstDisConnect));
-
-	//1 Modify DIG lower bound, deal with abnormal case
-	//2 Abnormal false alarm case
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	if(bDFSBand)
-	{
-		pDM_DigTable->rx_gain_range_min = DIG_Dynamic_MIN;
-	}
-	else
-#endif
-	{
-		if(!pDM_Odm->bLinked)
-		{
-			pDM_DigTable->rx_gain_range_min = DIG_Dynamic_MIN;
-
-			if (FirstDisConnect)
-				pDM_DigTable->ForbiddenIGI = DIG_Dynamic_MIN;
-		}
-		else
-			pDM_DigTable->rx_gain_range_min = odm_ForbiddenIGICheck(pDM_Odm, DIG_Dynamic_MIN, CurrentIGI);
-	}
-
-	//2 Abnormal # beacon case
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	if(pDM_Odm->bLinked && !FirstConnect)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("Beacon Num (%d)\n", pDM_Odm->PhyDbgInfo.NumQryBeaconPkt));
-		if((pDM_Odm->PhyDbgInfo.NumQryBeaconPkt < 5) && (pDM_Odm->bsta_state))
-		{
-			pDM_DigTable->rx_gain_range_min = dm_dig_min;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Abnrormal #beacon (%d) case in STA mode: Force lower bound to 0x%x !!!!!!\n\n",
-				pDM_Odm->PhyDbgInfo.NumQryBeaconPkt, pDM_DigTable->rx_gain_range_min));
-		}
-	}
-#endif
-
-	//2 Abnormal lower bound case
-	if(pDM_DigTable->rx_gain_range_min > pDM_DigTable->rx_gain_range_max)
-	{
-		pDM_DigTable->rx_gain_range_min = pDM_DigTable->rx_gain_range_max;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Abnrormal lower bound case: Force lower bound to 0x%x !!!!!!\n\n",pDM_DigTable->rx_gain_range_min));
-	}
-
-	
-	//1 False alarm threshold decision
-	odm_FAThresholdCheck(pDM_Odm, bDFSBand, bPerformance, RxTp, TxTp, dm_FA_thres);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): False alarm threshold = %d, %d, %d \n\n", dm_FA_thres[0], dm_FA_thres[1], dm_FA_thres[2]));
-
-	//1 Adjust initial gain by false alarm
-	if(pDM_Odm->bLinked && bPerformance)
-	{
-		//2 After link
-		ODM_RT_TRACE(pDM_Odm,	ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Adjust IGI after link\n"));
-
-		if(bFirstTpTarget || (FirstConnect && bPerformance))
-		{	
-			pDM_DigTable->LargeFAHit = 0;
-			
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-			if(bDFSBand)
-			{
-				if(pDM_Odm->RSSI_Min > 0x28)
-					CurrentIGI = 0x28;
-				else
-					CurrentIGI = pDM_Odm->RSSI_Min;
-				ODM_RT_TRACE(pDM_Odm,	ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): DFS band: One-shot to 0x28 upmost!!!!!!\n"));
-			}
-			else
-#endif
-			{
-				if(pDM_Odm->RSSI_Min < DIG_MaxOfMin)
-				{
-					if(CurrentIGI < pDM_Odm->RSSI_Min)
-						CurrentIGI = pDM_Odm->RSSI_Min;
-				}
-				else
-				{
-					if(CurrentIGI < DIG_MaxOfMin)
-						CurrentIGI = DIG_MaxOfMin;
-				}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-#if (RTL8812A_SUPPORT==1) 
-				if(pDM_Odm->SupportICType == ODM_RTL8812)
-					ODM_ConfigBBWithHeaderFile(pDM_Odm, CONFIG_BB_AGC_TAB_DIFF);
-#endif
-#endif
-			}
-
-			ODM_RT_TRACE(pDM_Odm,	ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): First connect case: IGI does on-shot to 0x%x\n", CurrentIGI));
-
-		}
-		else
-		{
-			if(pFalseAlmCnt->Cnt_all > dm_FA_thres[2])
-				CurrentIGI = CurrentIGI + 4;
-			else if (pFalseAlmCnt->Cnt_all > dm_FA_thres[1])
-				CurrentIGI = CurrentIGI + 2;
-			else if(pFalseAlmCnt->Cnt_all < dm_FA_thres[0])
-				CurrentIGI = CurrentIGI - 2;
-
-			//4 Abnormal # beacon case
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-			if((pDM_Odm->PhyDbgInfo.NumQryBeaconPkt < 5) && (pFalseAlmCnt->Cnt_all < DM_DIG_FA_TH1) && (pDM_Odm->bsta_state))
-			{						
-				CurrentIGI = pDM_DigTable->rx_gain_range_min;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Abnormal #beacon (%d) case: IGI does one-shot to 0x%x\n", 
-					pDM_Odm->PhyDbgInfo.NumQryBeaconPkt, CurrentIGI));
-			}
-#endif
-		}
-	}	
-	else
-	{
-		//2 Before link
-		ODM_RT_TRACE(pDM_Odm,	ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): Adjust IGI before link\n"));
-		
-		if(FirstDisConnect || bFirstCoverage)
-		{
-			CurrentIGI = dm_dig_min;
-			ODM_RT_TRACE(pDM_Odm,	ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): First disconnect case: IGI does on-shot to lower bound\n"));
-		}
-		else
-		{
-			if(pFalseAlmCnt->Cnt_all > dm_FA_thres[2])
-				CurrentIGI = CurrentIGI + 4;
-			else if (pFalseAlmCnt->Cnt_all > dm_FA_thres[1])
-				CurrentIGI = CurrentIGI + 2;
-			else if(pFalseAlmCnt->Cnt_all < dm_FA_thres[0])
-				CurrentIGI = CurrentIGI - 2;
-		}
-	}
-
-	//1 Check initial gain by upper/lower bound
-	if(CurrentIGI < pDM_DigTable->rx_gain_range_min)
-		CurrentIGI = pDM_DigTable->rx_gain_range_min;
-	
-	if(CurrentIGI > pDM_DigTable->rx_gain_range_max)
-		CurrentIGI = pDM_DigTable->rx_gain_range_max;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): CurIGValue=0x%x, TotalFA = %d\n\n", CurrentIGI, pFalseAlmCnt->Cnt_all));	
-
-	//1 High power RSSI threshold
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	if((pDM_Odm->SupportICType == ODM_RTL8723A)&& (pHalData->UndecoratedSmoothedPWDB > DM_DIG_HIGH_PWR_THRESHOLD))
-	{
-		// High power IGI lower bound
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): UndecoratedSmoothedPWDB(%#x)\n", pHalData->UndecoratedSmoothedPWDB));
-		if(CurrentIGI < DM_DIG_HIGH_PWR_IGI_LOWER_BOUND)
-		{
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG(): CurIGValue(%#x)\n", pDM_DigTable->CurIGValue));
-			//pDM_DigTable->CurIGValue = DM_DIG_HIGH_PWR_IGI_LOWER_BOUND;
-			CurrentIGI=DM_DIG_HIGH_PWR_IGI_LOWER_BOUND;
-		}
-	}
-	if((pDM_Odm->SupportICType & ODM_RTL8723A) && IS_WIRELESS_MODE_G(pAdapter))
-	{
-		if(pHalData->UndecoratedSmoothedPWDB > 0x28)
-		{
-			if(CurrentIGI < DM_DIG_Gmode_HIGH_PWR_IGI_LOWER_BOUND)
-			{
-			 	//pDM_DigTable->CurIGValue = DM_DIG_Gmode_HIGH_PWR_IGI_LOWER_BOUND;
-				CurrentIGI = DM_DIG_Gmode_HIGH_PWR_IGI_LOWER_BOUND;
-			}	
-		} 
-	}
-#endif
-
-	//1 Update status
-#if (RTL8192D_SUPPORT==1) 
-	if(pDM_Odm->SupportICType == ODM_RTL8192D)
-	{
-		//sherry  delete DualMacSmartConncurrent 20110517
-		if(*(pDM_Odm->pMacPhyMode) == ODM_DMSP)
-		{
-			ODM_Write_DIG_DMSP(pDM_Odm, CurrentIGI);//ODM_Write_DIG_DMSP(pDM_Odm, pDM_DigTable->CurIGValue);
-			if(*(pDM_Odm->pbMasterOfDMSP))
-			{
-				pDM_DigTable->bMediaConnect_0 = pDM_Odm->bLinked;
-				pDM_DigTable->DIG_Dynamic_MIN_0 = DIG_Dynamic_MIN;
-			}
-			else
-			{
-				pDM_DigTable->bMediaConnect_1 = pDM_Odm->bLinked;
-				pDM_DigTable->DIG_Dynamic_MIN_1 = DIG_Dynamic_MIN;
-			}
-		}
-		else
-		{
-			ODM_Write_DIG(pDM_Odm, CurrentIGI);//ODM_Write_DIG(pDM_Odm, pDM_DigTable->CurIGValue);
-			if(*(pDM_Odm->pBandType) == ODM_BAND_5G)
-			{
-				pDM_DigTable->bMediaConnect_0 = pDM_Odm->bLinked;
-				pDM_DigTable->DIG_Dynamic_MIN_0 = DIG_Dynamic_MIN;
-			}
-			else
-			{
-				pDM_DigTable->bMediaConnect_1 = pDM_Odm->bLinked;
-				pDM_DigTable->DIG_Dynamic_MIN_1 = DIG_Dynamic_MIN;
-			}
-		}
-	}
-	else
-#endif
-	{
-#if ((DM_ODM_SUPPORT_TYPE & ODM_WIN) || ((DM_ODM_SUPPORT_TYPE & ODM_CE) && (ODM_CONFIG_BT_COEXIST == 1)))
-		if(pDM_Odm->bBtHsOperation)
-		{
-			if(pDM_Odm->bLinked)
-			{
-				if(pDM_DigTable->BT30_CurIGI > (CurrentIGI))
-					ODM_Write_DIG(pDM_Odm, CurrentIGI);
-				else
-					ODM_Write_DIG(pDM_Odm, pDM_DigTable->BT30_CurIGI);
-					
-				pDM_DigTable->bMediaConnect_0 = pDM_Odm->bLinked;
-				pDM_DigTable->DIG_Dynamic_MIN_0 = DIG_Dynamic_MIN;
-			}
-			else
-			{
-				if(pDM_Odm->bLinkInProcess)
-					ODM_Write_DIG(pDM_Odm, 0x1c);
-				else if(pDM_Odm->bBtConnectProcess)
-					ODM_Write_DIG(pDM_Odm, 0x28);
-				else
-					ODM_Write_DIG(pDM_Odm, pDM_DigTable->BT30_CurIGI);//ODM_Write_DIG(pDM_Odm, pDM_DigTable->CurIGValue);	
-			}
-		}
-		else		// BT is not using
-#endif
-		{
-			ODM_Write_DIG(pDM_Odm, CurrentIGI);//ODM_Write_DIG(pDM_Odm, pDM_DigTable->CurIGValue);
-			pDM_DigTable->bMediaConnect_0 = pDM_Odm->bLinked;
-			pDM_DigTable->DIG_Dynamic_MIN_0 = DIG_Dynamic_MIN;
-		}
-	}
-}
-
-VOID
-odm_DIGbyRSSI_LPS(
-	IN		PVOID		pDM_VOID
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PFALSE_ALARM_STATISTICS		pFalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm, PHYDM_FALSEALMCNT);
-
-	u1Byte	RSSI_Lower=DM_DIG_MIN_NIC;   //0x1E or 0x1C
-	u1Byte	CurrentIGI=pDM_Odm->RSSI_Min;
-
-	if(odm_DigAbort(pDM_Odm) == TRUE)
-		return;
-
-	CurrentIGI=CurrentIGI+RSSI_OFFSET_DIG;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIGbyRSSI_LPS()==>\n"));
-
-	// Using FW PS mode to make IGI
-	//Adjust by  FA in LPS MODE
-	if(pFalseAlmCnt->Cnt_all> DM_DIG_FA_TH2_LPS)
-		CurrentIGI = CurrentIGI+4;
-	else if (pFalseAlmCnt->Cnt_all > DM_DIG_FA_TH1_LPS)
-		CurrentIGI = CurrentIGI+2;
-	else if(pFalseAlmCnt->Cnt_all < DM_DIG_FA_TH0_LPS)
-		CurrentIGI = CurrentIGI-2;	
-
-
-	//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_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIGbyRSSI_LPS(): pFalseAlmCnt->Cnt_all = %d\n",pFalseAlmCnt->Cnt_all));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIGbyRSSI_LPS(): pDM_Odm->RSSI_Min = %d\n",pDM_Odm->RSSI_Min));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIGbyRSSI_LPS(): CurrentIGI = 0x%x\n",CurrentIGI));
-
-	ODM_Write_DIG(pDM_Odm, CurrentIGI);//ODM_Write_DIG(pDM_Odm, pDM_DigTable->CurIGValue);
-#endif
-}
-
-//3============================================================
-//3 FASLE ALARM CHECK
-//3============================================================
-
-VOID 
-odm_FalseAlarmCounterStatistics(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PFALSE_ALARM_STATISTICS 	FalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm, PHYDM_FALSEALMCNT);
-	u4Byte 						ret_value;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-//Mark there, and check this in odm_DMWatchDog
-#if 0 //(DM_ODM_SUPPORT_TYPE == ODM_AP)
-	prtl8192cd_priv priv		= pDM_Odm->priv;
-	if( (priv->auto_channel != 0) && (priv->auto_channel != 2) )
-		return;
-#endif
-#endif
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_FA_CNT))
-		return;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics()======>\n"));
-
-#if (ODM_IC_11N_SERIES_SUPPORT == 1) 
-	if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES)
-	{
-
-		//hold ofdm counter
-		ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_HOLDC_11N, BIT31, 1); //hold page C counter
-		ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RSTD_11N, BIT31, 1); //hold page D counter
-	
-		ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_OFDM_FA_TYPE1_11N, bMaskDWord);
-		FalseAlmCnt->Cnt_Fast_Fsync = (ret_value&0xffff);
-		FalseAlmCnt->Cnt_SB_Search_fail = ((ret_value&0xffff0000)>>16);		
-
-		ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_OFDM_FA_TYPE2_11N, bMaskDWord);
-		FalseAlmCnt->Cnt_OFDM_CCA = (ret_value&0xffff); 
-		FalseAlmCnt->Cnt_Parity_Fail = ((ret_value&0xffff0000)>>16);	
-
-		ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_OFDM_FA_TYPE3_11N, bMaskDWord);
-		FalseAlmCnt->Cnt_Rate_Illegal = (ret_value&0xffff);
-		FalseAlmCnt->Cnt_Crc8_fail = ((ret_value&0xffff0000)>>16);
-
-		ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_OFDM_FA_TYPE4_11N, bMaskDWord);
-		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;
-
-#if (RTL8188E_SUPPORT==1)
-		if(pDM_Odm->SupportICType == ODM_RTL8188E)
-		{
-			ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_SC_CNT_11N, bMaskDWord);
-			FalseAlmCnt->Cnt_BW_LSC = (ret_value&0xffff);
-			FalseAlmCnt->Cnt_BW_USC = ((ret_value&0xffff0000)>>16);
-		}
-#endif
-
-#if (RTL8192D_SUPPORT==1) 
-		if(pDM_Odm->SupportICType == ODM_RTL8192D)
-		{
-			odm_GetCCKFalseAlarm_92D(pDM_Odm);
-		}
-		else
-#endif
-		{
-			//hold cck counter
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11N, BIT12, 1); 
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11N, BIT14, 1); 
-		
-			ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_CCK_FA_LSB_11N, bMaskByte0);
-			FalseAlmCnt->Cnt_Cck_fail = ret_value;
-
-			ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_CCK_FA_MSB_11N, bMaskByte3);
-			FalseAlmCnt->Cnt_Cck_fail +=  (ret_value& 0xff)<<8;
-
-			ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_CCK_CCA_CNT_11N, bMaskDWord);
-			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 (RTL8192C_SUPPORT==1)
-		if(pDM_Odm->SupportICType == ODM_RTL8192C)
-			odm_ResetFACounter_92C(pDM_Odm);
-#endif
-
-#if (RTL8192D_SUPPORT==1)
-		if(pDM_Odm->SupportICType == ODM_RTL8192D)
-			odm_ResetFACounter_92D(pDM_Odm);
-#endif
-
-		if(pDM_Odm->SupportICType >=ODM_RTL8723A)
-		{
-			//reset false alarm counter registers
-			ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RSTC_11N, BIT31, 1);
-			ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RSTC_11N, BIT31, 0);
-			ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RSTD_11N, BIT27, 1);
-			ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RSTD_11N, BIT27, 0);
-
-			//update ofdm counter
-			ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_HOLDC_11N, BIT31, 0); //update page C counter
-			ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RSTD_11N, BIT31, 0); //update page D counter
-
-			//reset CCK CCA counter
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11N, BIT13|BIT12, 0); 
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11N, BIT13|BIT12, 2); 
-			//reset CCK FA counter
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11N, BIT15|BIT14, 0); 
-			ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11N, BIT15|BIT14, 2); 
-		}
-		
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): 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, ("odm_FalseAlarmCounterStatistics(): 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, ("odm_FalseAlarmCounterStatistics(): Cnt_Crc8_fail=%d, Cnt_Mcs_fail=%d\n",
-		FalseAlmCnt->Cnt_Crc8_fail, FalseAlmCnt->Cnt_Mcs_fail));
-	}
-#endif
-
-#if (ODM_IC_11AC_SERIES_SUPPORT == 1) 
-	if(pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-	{
-		u4Byte CCKenable;
-		
-		/* read OFDM FA counter */
-		FalseAlmCnt->Cnt_Ofdm_fail = ODM_GetBBReg(pDM_Odm, ODM_REG_OFDM_FA_11AC, bMaskLWord);
-		
-
-		/* Read CCK FA counter */
-		FalseAlmCnt->Cnt_Cck_fail = ODM_GetBBReg(pDM_Odm, ODM_REG_CCK_FA_11AC, bMaskLWord);
-
-		/* read CCK/OFDM CCA counter */
-		ret_value = ODM_GetBBReg(pDM_Odm, ODM_REG_CCK_CCA_CNT_11AC, bMaskDWord);
-		FalseAlmCnt->Cnt_OFDM_CCA = (ret_value & 0xffff0000) >> 16;
-		FalseAlmCnt->Cnt_CCK_CCA = ret_value & 0xffff;
-
-#if (RTL8881A_SUPPORT==1) 
-		/* For 8881A */
-		if(pDM_Odm->SupportICType == ODM_RTL8881A)
-		{
-			u4Byte Cnt_Ofdm_fail_temp = 0;
-		
-			if(FalseAlmCnt->Cnt_Ofdm_fail >= FalseAlmCnt->Cnt_Ofdm_fail_pre)
-			{
-				Cnt_Ofdm_fail_temp = FalseAlmCnt->Cnt_Ofdm_fail_pre;
-				FalseAlmCnt->Cnt_Ofdm_fail_pre = FalseAlmCnt->Cnt_Ofdm_fail;
-				FalseAlmCnt->Cnt_Ofdm_fail = FalseAlmCnt->Cnt_Ofdm_fail - Cnt_Ofdm_fail_temp;
-			}
-			else
-				FalseAlmCnt->Cnt_Ofdm_fail_pre = FalseAlmCnt->Cnt_Ofdm_fail;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_Ofdm_fail=%d\n",	FalseAlmCnt->Cnt_Ofdm_fail_pre));
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_Ofdm_fail_pre=%d\n",	Cnt_Ofdm_fail_temp));
-			
-			/* Reset FA counter by enable/disable OFDM */
-			if(FalseAlmCnt->Cnt_Ofdm_fail_pre >= 0x7fff)
-			{
-				// reset OFDM
-				ODM_SetBBReg(pDM_Odm, ODM_REG_BB_RX_PATH_11AC, BIT29,0);
-				ODM_SetBBReg(pDM_Odm, ODM_REG_BB_RX_PATH_11AC, BIT29,1);
-				FalseAlmCnt->Cnt_Ofdm_fail_pre = 0;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Reset false alarm counter\n"));
-			}
-		}
-#endif
-
-		/* reset OFDM FA coutner */
-		ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RST_11AC, BIT17, 1);
-		ODM_SetBBReg(pDM_Odm, ODM_REG_OFDM_FA_RST_11AC, BIT17, 0);
-
-		/* reset CCK FA counter */
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11AC, BIT15, 0);
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CCK_FA_RST_11AC, BIT15, 1);
-
-		/* reset CCA counter */
-		ODM_SetBBReg(pDM_Odm, ODM_REG_RST_RPT_11AC, BIT0, 1);
-		ODM_SetBBReg(pDM_Odm, ODM_REG_RST_RPT_11AC, BIT0, 0);
-
-		CCKenable =  ODM_GetBBReg(pDM_Odm, ODM_REG_BB_RX_PATH_11AC, BIT28);
-		if(CCKenable)//if(*pDM_Odm->pBandType == ODM_BAND_2_4G)
-		{
-			FalseAlmCnt->Cnt_all = FalseAlmCnt->Cnt_Ofdm_fail + FalseAlmCnt->Cnt_Cck_fail;
-			FalseAlmCnt->Cnt_CCA_all = FalseAlmCnt->Cnt_CCK_CCA + FalseAlmCnt->Cnt_OFDM_CCA;
-		}
-		else
-		{
-			FalseAlmCnt->Cnt_all = FalseAlmCnt->Cnt_Ofdm_fail;
-			FalseAlmCnt->Cnt_CCA_all = FalseAlmCnt->Cnt_OFDM_CCA;
-		}
-
-	}
-#endif
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_OFDM_CCA=%d\n", FalseAlmCnt->Cnt_OFDM_CCA));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_CCK_CCA=%d\n", FalseAlmCnt->Cnt_CCK_CCA));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_CCA_all=%d\n", FalseAlmCnt->Cnt_CCA_all));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_Ofdm_fail=%d\n", FalseAlmCnt->Cnt_Ofdm_fail));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_Cck_fail=%d\n", FalseAlmCnt->Cnt_Cck_fail));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Cnt_Ofdm_fail=%d\n", FalseAlmCnt->Cnt_Ofdm_fail));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_FA_CNT, ODM_DBG_LOUD, ("odm_FalseAlarmCounterStatistics(): Total False Alarm=%d\n\n", FalseAlmCnt->Cnt_all));
-}
-
-//3============================================================
-//3 CCK Packet Detect Threshold
-//3============================================================
-
-VOID
-odm_PauseCCKPacketDetection(
-	IN		PVOID					pDM_VOID,
-	IN		PHYDM_PAUSE_TYPE		PauseType,
-	IN		PHYDM_PAUSE_LEVEL		pause_level,
-	IN		u1Byte					CCKPDThreshold
-)
-{
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T				pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection()=========> level = %d\n", pause_level));
-
-	if ((pDM_DigTable->pause_cckpd_level == 0) && (!(pDM_Odm->SupportAbility & ODM_BB_CCK_PD) || !(pDM_Odm->SupportAbility & ODM_BB_FA_CNT))) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("Return: SupportAbility ODM_BB_CCK_PD or ODM_BB_FA_CNT is disabled\n"));
-		return;
-	}
-
-	if (pause_level > DM_DIG_MAX_PAUSE_TYPE) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, 
-			("odm_PauseCCKPacketDetection(): Return: Wrong pause level !!\n"));
-		return;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): pause level = 0x%x, Current value = 0x%x\n", pDM_DigTable->pause_cckpd_level, CCKPDThreshold));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): pause value = 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n", 
-		pDM_DigTable->pause_cckpd_value[7], pDM_DigTable->pause_cckpd_value[6], pDM_DigTable->pause_cckpd_value[5], pDM_DigTable->pause_cckpd_value[4],
-		pDM_DigTable->pause_cckpd_value[3], pDM_DigTable->pause_cckpd_value[2], pDM_DigTable->pause_cckpd_value[1], pDM_DigTable->pause_cckpd_value[0]));
-
-	switch (PauseType) {
-	/* Pause CCK Packet Detection Threshold */
-	case PHYDM_PAUSE:
-	{
-		/* Disable CCK PD */
-		ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_ABILITY, pDM_Odm->SupportAbility & (~ODM_BB_CCK_PD));
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): Pause CCK packet detection threshold !!\n"));
-
-		/* Backup original CCK PD threshold decided by CCK PD mechanism */
-		if (pDM_DigTable->pause_cckpd_level == 0) {
-			pDM_DigTable->CCKPDBackup = pDM_DigTable->CurCCK_CCAThres;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, 
-				("odm_PauseCCKPacketDetection(): Backup CCKPD  = 0x%x, new CCKPD = 0x%x\n", pDM_DigTable->CCKPDBackup, CCKPDThreshold));
-		}
-
-		/* Update pause level */
-		pDM_DigTable->pause_cckpd_level = (pDM_DigTable->pause_cckpd_level | BIT(pause_level));
-
-		/* Record CCK PD threshold */
-		pDM_DigTable->pause_cckpd_value[pause_level] = CCKPDThreshold;
-		
-		/* Write new CCK PD threshold */
-		if (BIT(pause_level + 1) > pDM_DigTable->pause_cckpd_level) {
-			ODM_Write_CCK_CCA_Thres(pDM_Odm, CCKPDThreshold);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): CCKPD of higher level = 0x%x\n", CCKPDThreshold));
-		}
-		break;
-	}
-	/* Resume CCK Packet Detection Threshold */
-	case PHYDM_RESUME:
-	{	
-		/* check if the level is illegal or not */
-		if ((pDM_DigTable->pause_cckpd_level & (BIT(pause_level))) != 0) {
-			pDM_DigTable->pause_cckpd_level = pDM_DigTable->pause_cckpd_level & (~(BIT(pause_level)));
-			pDM_DigTable->pause_cckpd_value[pause_level] = 0;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): Resume CCK PD !!\n"));
-		} else {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): Wrong resume level !!\n"));
-			break;
-		}
-
-		/* Resume DIG */
-		if (pDM_DigTable->pause_cckpd_level == 0) {
-			/* Write backup IGI value */
-			ODM_Write_CCK_CCA_Thres(pDM_Odm, pDM_DigTable->CCKPDBackup);
-			/* pDM_DigTable->bIgnoreDIG = TRUE; */
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): Write original CCKPD = 0x%x\n", pDM_DigTable->CCKPDBackup));
-
-			/* Enable DIG */
-			ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_ABILITY, pDM_Odm->SupportAbility | ODM_BB_CCK_PD);	
-			break;
-		}
-
-		if (BIT(pause_level) > pDM_DigTable->pause_cckpd_level) {
-			u1Byte	max_level;
-		
-			/* Calculate the maximum level now */
-			for (max_level = (pause_level - 1); max_level >= 0; max_level--) {
-				if ((pDM_DigTable->pause_cckpd_level & BIT(max_level)) > 0)
-					break;
-			}
-		
-			/* write CCKPD of lower level */
-			ODM_Write_CCK_CCA_Thres(pDM_Odm, pDM_DigTable->pause_cckpd_value[max_level]);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): Write CCKPD (0x%x) of level (%d)\n", 
-				pDM_DigTable->pause_cckpd_value[max_level], max_level));
-			break;
-		}
-		break;
-	}
-	default:
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): Wrong  type !!\n"));
-		break;
-	}	
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): pause level = 0x%x, Current value = 0x%x\n", pDM_DigTable->pause_cckpd_level, CCKPDThreshold));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_PauseCCKPacketDetection(): pause value = 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n", 
-		pDM_DigTable->pause_cckpd_value[7], pDM_DigTable->pause_cckpd_value[6], pDM_DigTable->pause_cckpd_value[5], pDM_DigTable->pause_cckpd_value[4],
-		pDM_DigTable->pause_cckpd_value[3], pDM_DigTable->pause_cckpd_value[2], pDM_DigTable->pause_cckpd_value[1], pDM_DigTable->pause_cckpd_value[0]));
-}
-
-
-VOID 
-odm_CCKPacketDetectionThresh(
-	IN		PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PFALSE_ALARM_STATISTICS 	FalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm, PHYDM_FALSEALMCNT);
-	u1Byte						CurCCK_CCAThres, RSSI_thd = 55;
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-//modify by Guo.Mingzhi 2011-12-29
-	if (pDM_Odm->bDualMacSmartConcurrent == TRUE)
-//	if (pDM_Odm->bDualMacSmartConcurrent == FALSE)
-		return;
-	if(pDM_Odm->bBtHsOperation)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_CCKPacketDetectionThresh() write 0xcd for BT HS mode!!\n"));
-		ODM_Write_CCK_CCA_Thres(pDM_Odm, 0xcd);
-		return;
-	}
-#endif
-
-	if((!(pDM_Odm->SupportAbility & ODM_BB_CCK_PD)) ||(!(pDM_Odm->SupportAbility & ODM_BB_FA_CNT)))
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_CCKPacketDetectionThresh()  return==========\n"));
-#ifdef MCR_WIRELESS_EXTEND
-		ODM_Write_CCK_CCA_Thres(pDM_Odm, 0x43);
-#endif
-		return;
-	}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	if(pDM_Odm->ExtLNA)
-		return;
-#endif
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_CCKPacketDetectionThresh()  ==========>\n"));
-
-	if (pDM_Odm->bLinked)
-	{
-		if (pDM_Odm->RSSI_Min > RSSI_thd)
-			CurCCK_CCAThres = 0xcd;
-		else if ((pDM_Odm->RSSI_Min <= RSSI_thd) && (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;
-	}
-	
-#if (RTL8192D_SUPPORT==1) 
-	if((pDM_Odm->SupportICType == ODM_RTL8192D) && (*pDM_Odm->pBandType == ODM_BAND_2_4G))
-		ODM_Write_CCK_CCA_Thres_92D(pDM_Odm, CurCCK_CCAThres);
-	else
-#endif
-		ODM_Write_CCK_CCA_Thres(pDM_Odm, CurCCK_CCAThres);
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CCK_PD, ODM_DBG_LOUD, ("odm_CCKPacketDetectionThresh()  CurCCK_CCAThres = 0x%x\n",CurCCK_CCAThres));
-}
-
-VOID
-ODM_Write_CCK_CCA_Thres(
-	IN	PVOID			pDM_VOID,
-	IN	u1Byte			CurCCK_CCAThres
-	)
-{
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T				pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-	if(pDM_DigTable->CurCCK_CCAThres!=CurCCK_CCAThres)		//modify by Guo.Mingzhi 2012-01-03
-	{
-		ODM_Write1Byte(pDM_Odm, ODM_REG(CCK_CCA,pDM_Odm), CurCCK_CCAThres);
-	}
-	pDM_DigTable->PreCCK_CCAThres = pDM_DigTable->CurCCK_CCAThres;
-	pDM_DigTable->CurCCK_CCAThres = CurCCK_CCAThres;
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-// <20130108, Kordan> E.g., With LNA used, we make the Rx power smaller to have a better EVM. (Asked by Willis)
-VOID
-odm_RFEControl(
-	IN	PDM_ODM_T	pDM_Odm,
-	IN  u8Byte		RSSIVal
-	)
-{
-	PADAPTER		Adapter = (PADAPTER)pDM_Odm->Adapter;
-    HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	static u1Byte 	TRSW_HighPwr = 0;
-	 
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("===> odm_RFEControl, RSSI = %d, TRSW_HighPwr = 0x%X, pHalData->RFEType = %d\n",
-		         RSSIVal, TRSW_HighPwr, pHalData->RFEType ));
-
-    if (pHalData->RFEType == 3) {	   
-		
-        pDM_Odm->RSSI_TRSW = RSSIVal;
-
-        if (pDM_Odm->RSSI_TRSW >= pDM_Odm->RSSI_TRSW_H) 
-		{				 
-            TRSW_HighPwr = 1; // Switch to
-            PHY_SetBBReg(Adapter, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x1);  // Set ANTSW=1/ANTSWB=0  for SW control
-            PHY_SetBBReg(Adapter, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x3);  // Set ANTSW=1/ANTSWB=0  for SW control
-            
-        } 
-		else if (pDM_Odm->RSSI_TRSW <= pDM_Odm->RSSI_TRSW_L) 
-        {	  
-            TRSW_HighPwr = 0; // Switched back
-            PHY_SetBBReg(Adapter, r_ANTSEL_SW_Jaguar, BIT1|BIT0, 0x1);  // Set ANTSW=1/ANTSWB=0  for SW control
-            PHY_SetBBReg(Adapter, r_ANTSEL_SW_Jaguar, BIT9|BIT8, 0x0);  // Set ANTSW=1/ANTSWB=0  for SW control
-
-        }
-    }  
-
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("(pDM_Odm->RSSI_TRSW_H, pDM_Odm->RSSI_TRSW_L) = (%d, %d)\n", pDM_Odm->RSSI_TRSW_H, pDM_Odm->RSSI_TRSW_L));		
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("(RSSIVal, RSSIVal, pDM_Odm->RSSI_TRSW_iso) = (%d, %d, %d)\n", 
-				 RSSIVal, pDM_Odm->RSSI_TRSW_iso, pDM_Odm->RSSI_TRSW));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("<=== odm_RFEControl, RSSI = %d, TRSW_HighPwr = 0x%X\n", RSSIVal, TRSW_HighPwr));	
-}
-
-VOID
-odm_MPT_DIGWorkItemCallback(
-    IN PVOID            pContext
-    )
-{
-	PADAPTER	Adapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	ODM_MPT_DIG(pDM_Odm);
-}
-
-VOID
-odm_MPT_DIGCallback(
-	PRT_TIMER		pTimer
-)
-{
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-       HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	  PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-
-	#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-		#if USE_WORKITEM
-			PlatformScheduleWorkItem(&pDM_Odm->MPT_DIGWorkitem);
-		#else
-			ODM_MPT_DIG(pDM_Odm);
-		#endif
-	#else
-		PlatformScheduleWorkItem(&pDM_Odm->MPT_DIGWorkitem);
-	#endif
-
-}
-
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-VOID
-odm_MPT_DIGCallback(
-	IN		PVOID					pDM_VOID
-)
-{
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if USE_WORKITEM
-	PlatformScheduleWorkItem(&pDM_Odm->MPT_DIGWorkitem);
-#else
-	ODM_MPT_DIG(pDM_Odm);
-#endif
-}
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE != ODM_CE)
-VOID
-odm_MPT_Write_DIG(
-	IN		PVOID					pDM_VOID,
-	IN		u1Byte					CurIGValue
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T						pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-	ODM_Write1Byte( pDM_Odm, ODM_REG(IGI_A,pDM_Odm), CurIGValue);
-
-	if(pDM_Odm->RFType > ODM_1T1R)
-		ODM_Write1Byte( pDM_Odm, ODM_REG(IGI_B,pDM_Odm), CurIGValue);
-
-	if((pDM_Odm->SupportICType & ODM_IC_11AC_SERIES) && (pDM_Odm->RFType > ODM_2T2R))
-	{
-		ODM_Write1Byte( pDM_Odm, ODM_REG(IGI_C,pDM_Odm), CurIGValue);
-		ODM_Write1Byte( pDM_Odm, ODM_REG(IGI_D,pDM_Odm), CurIGValue);	
-	}
-
-	pDM_DigTable->CurIGValue = CurIGValue;
-	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("CurIGValue = 0x%x\n", CurIGValue));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("pDM_Odm->RFType = 0x%x\n", pDM_Odm->RFType));
-}
-
-VOID
-ODM_MPT_DIG(
-	IN		PVOID					pDM_VOID
-	)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pDIG_T						pDM_DigTable = &pDM_Odm->DM_DigTable;
-	PFALSE_ALARM_STATISTICS		pFalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure( pDM_Odm, PHYDM_FALSEALMCNT);
-	u1Byte						CurrentIGI = pDM_DigTable->CurIGValue;
-	u1Byte						DIG_Upper = 0x40, DIG_Lower = 0x20;
-	u4Byte						RXOK_cal;
-	u4Byte						RxPWDBAve_final;
-	u1Byte						IGI_A = 0x20, IGI_B = 0x20;
-	
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-	#if ODM_FIX_2G_DIG
-	IGI_A = 0x22;
-	IGI_B = 0x24;		
-	#endif
-	
-#else
-	if (!(pDM_Odm->priv->pshare->rf_ft_var.mp_specific && pDM_Odm->priv->pshare->mp_dig_on))
-		return;
-
-	if (*pDM_Odm->pBandType == ODM_BAND_5G)
-		DIG_Lower = 0x22;
-#endif
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("===> ODM_MPT_DIG, pBandType = %d\n", *pDM_Odm->pBandType));
-	
-#if (ODM_FIX_2G_DIG || (DM_ODM_SUPPORT_TYPE & ODM_AP))
-	if (*pDM_Odm->pBandType == ODM_BAND_5G || (pDM_Odm->SupportICType & (ODM_RTL8814A|ODM_RTL8822B))) // for 5G or 8814
-#else
-	if (1) // for both 2G/5G
-#endif
-		{
-		odm_FalseAlarmCounterStatistics(pDM_Odm);
-
-		RXOK_cal = pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK + pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM;
-		RxPWDBAve_final = (RXOK_cal != 0)?pDM_Odm->RxPWDBAve/RXOK_cal:0;
-
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK = 0;
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM = 0;
-		pDM_Odm->RxPWDBAve = 0;
-		pDM_Odm->MPDIG_2G = FALSE;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		pDM_Odm->Times_2G = 0;
-#endif
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("RX OK = %d\n", RXOK_cal));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("RSSI = %d\n", RxPWDBAve_final));
-	
-		if (RXOK_cal >= 70 && RxPWDBAve_final <= 40)
-		{
-			if (CurrentIGI > 0x24)
-				odm_MPT_Write_DIG(pDM_Odm, 0x24);
-		}
-		else
-		{
-			if(pFalseAlmCnt->Cnt_all > 1000){
-				CurrentIGI = CurrentIGI + 8;
-			}
-			else if(pFalseAlmCnt->Cnt_all > 200){
-				CurrentIGI = CurrentIGI + 4;
-			}
-			else if (pFalseAlmCnt->Cnt_all > 50){
-				CurrentIGI = CurrentIGI + 2;
-			}
-			else if (pFalseAlmCnt->Cnt_all < 2){
-				CurrentIGI = CurrentIGI - 2;
-			}
-			
-			if (CurrentIGI < DIG_Lower ){
-				CurrentIGI = DIG_Lower;
-			}
-
-			if(CurrentIGI > DIG_Upper){
-				CurrentIGI = DIG_Upper;
-			}
-
-			odm_MPT_Write_DIG(pDM_Odm, CurrentIGI);
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("DIG = 0x%x, Cnt_all = %d, Cnt_Ofdm_fail = %d, Cnt_Cck_fail = %d\n", 
-				CurrentIGI, pFalseAlmCnt->Cnt_all, pFalseAlmCnt->Cnt_Ofdm_fail, pFalseAlmCnt->Cnt_Cck_fail));
-		}
-	}
-	else
-	{
-		if(pDM_Odm->MPDIG_2G == FALSE)
-		{
-			if((pDM_Odm->SupportPlatform & ODM_WIN) && !(pDM_Odm->SupportICType & (ODM_RTL8814A|ODM_RTL8822B)))
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DIG, ODM_DBG_LOUD, ("===> Fix IGI\n"));
-				ODM_Write1Byte( pDM_Odm, ODM_REG(IGI_A,pDM_Odm), IGI_A);
-				ODM_Write1Byte( pDM_Odm, ODM_REG(IGI_B,pDM_Odm), IGI_B);
-				pDM_DigTable->CurIGValue = IGI_B;
-			}
-			else
-				odm_MPT_Write_DIG(pDM_Odm, IGI_A);
-		}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		pDM_Odm->Times_2G++;
-
-		if (pDM_Odm->Times_2G == 3)
-#endif
-		{
-			pDM_Odm->MPDIG_2G = TRUE;
-		}
-	}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (pDM_Odm->SupportICType == ODM_RTL8812)
-		odm_RFEControl(pDM_Odm, RxPWDBAve_final);
-#endif
-
-	ODM_SetTimer(pDM_Odm, &pDM_Odm->MPT_DIGTimer, 700);
-}
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+
+boolean
+phydm_dig_go_up_check(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ccx_info			*ccx_info = &dm->dm_ccx_info;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+	u8		cur_ig_value = dig_t->cur_ig_value;
+	u8		max_cover_bond;
+	u8		rx_gain_range_max = dig_t->rx_gain_range_max;
+	u8		i = 0, j = 0;
+	u8		total_nhm_cnt = ccx_info->nhm_rpt_sum;
+	u32		dig_cover_cnt = 0;
+	u32		over_dig_cover_cnt = 0;
+	boolean		ret = true;
+
+	if (*dm->bb_op_mode == PHYDM_PERFORMANCE_MODE)
+		return ret;
+
+	max_cover_bond = DIG_MAX_BALANCE_MODE - dig_t->dig_upcheck_initial_value;
+
+	if (cur_ig_value < max_cover_bond - 6)
+		dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_0;
+	else if (cur_ig_value <= DIG_MAX_BALANCE_MODE)
+		dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_1;
+	else	/* cur_ig_value > DM_DIG_MAX_AP, foolproof */
+		dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_2;
+	
+
+	PHYDM_DBG(dm, DBG_DIG, "check_lv = %d, max_cover_bond = 0x%x\n",
+			dig_t->dig_go_up_check_level,
+			max_cover_bond);
+
+	if (total_nhm_cnt == 0)
+		return true;
+
+	if (dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_0) {
+		for (i = 3; i<=11; i++)
+			dig_cover_cnt += ccx_info->nhm_result[i];
+		ret = ((dig_t->dig_level0_ratio_reciprocal * dig_cover_cnt) >= total_nhm_cnt) ? true : false;
+	} else if (dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_1) {
+		
+		/* search index */
+		for (i = 0; i<=10; i++) {
+			if ((max_cover_bond * 2) == ccx_info->nhm_th[i]) {
+				for(j =(i+1); j <= 11; j++)
+					over_dig_cover_cnt += ccx_info->nhm_result[j];
+				break;
+			}
+		}
+		ret = (dig_t->dig_level1_ratio_reciprocal * over_dig_cover_cnt < total_nhm_cnt) ? true : false;
+
+		if (!ret) {
+			/* update dig_t->rx_gain_range_max */
+			dig_t->rx_gain_range_max = (rx_gain_range_max >= max_cover_bond - 6) ? (max_cover_bond - 6) : rx_gain_range_max;
+
+			PHYDM_DBG(dm, DBG_DIG,
+				"Noise pwr over DIG can filter, lock rx_gain_range_max to 0x%x\n",
+				dig_t->rx_gain_range_max);
+		}
+	} else if (dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_2) {
+		/* cur_ig_value > DM_DIG_MAX_AP, foolproof */
+		ret = true;
+	}
+
+	return ret;
+}
+
+void
+odm_fa_threshold_check(
+	void			*dm_void,
+	boolean			is_dfs_band,
+	boolean			is_performance
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+
+	if (dig_t->is_dbg_fa_th) {
+		
+		PHYDM_DBG(dm, DBG_DIG, "Manual Fix FA_th\n");
+	
+	} else if (dm->is_linked && (is_performance || is_dfs_band)) {
+		if (dm->rssi_min < 20) {	/*[PHYDM-252]*/
+			dig_t->fa_th[0] = 500;
+			dig_t->fa_th[1] = 750;
+			dig_t->fa_th[2] = 1000;
+		} else if (((dm->rx_tp >> 2) > dm->tx_tp) && /*Test RX TP*/
+			(dm->rx_tp < 10) && (dm->rx_tp > 1)) {	/*RXTP = 1 ~ 10Mbps*/
+			dig_t->fa_th[0] = 125;
+			dig_t->fa_th[1] = 250;
+			dig_t->fa_th[2] = 500;
+		} else {
+			dig_t->fa_th[0] = 250;
+			dig_t->fa_th[1] = 500;
+			dig_t->fa_th[2] = 750;
+		}
+	} else {
+		if (is_dfs_band) {	/* For DFS band and no link */
+			
+			dig_t->fa_th[0] = 250;
+			dig_t->fa_th[1] = 1000;
+			dig_t->fa_th[2] = 2000;
+		} else {
+			dig_t->fa_th[0] = 2000;
+			dig_t->fa_th[1] = 4000;
+			dig_t->fa_th[2] = 5000;
+		}
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "FA_th={%d,%d,%d}\n",
+		dig_t->fa_th[0], dig_t->fa_th[1], dig_t->fa_th[2]);
+
+}
+
+void
+phydm_set_big_jump_step(
+	void			*dm_void,
+	u8			current_igi
+)
+{
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8		step1[8] = {24, 30, 40, 50, 60, 70, 80, 90};
+	u8		i;
+
+	if (dig_t->enable_adjust_big_jump == 0)
+		return;
+
+	for (i = 0; i <= dig_t->big_jump_step1; i++) {
+		if ((current_igi + step1[i]) > dig_t->big_jump_lmt[dig_t->agc_table_idx]) {
+			if (i != 0)
+				i = i - 1;
+			break;
+		} else if (i == dig_t->big_jump_step1)
+			break;
+	}
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, 0x8c8, 0xe, i);
+	else if (dm->support_ic_type & ODM_RTL8197F)
+		odm_set_bb_reg(dm, ODM_REG_BB_AGC_SET_2_11N, 0xe, i);
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"phydm_set_big_jump_step(): bigjump = %d (ori = 0x%x), LMT=0x%x\n",
+		i, dig_t->big_jump_step1, dig_t->big_jump_lmt[dig_t->agc_table_idx]);
+#endif
+}
+
+void
+odm_write_dig(
+	void			*dm_void,
+	u8			current_igi
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+
+	PHYDM_DBG(dm, DBG_DIG, "odm_write_dig===>\n");
+
+	/* 1 Check IGI by upper bound */
+	if (adaptivity->igi_lmt_en && 
+		(current_igi > adaptivity->adapt_igi_up) && dm->is_linked) {
+		
+		current_igi = adaptivity->adapt_igi_up;
+
+		PHYDM_DBG(dm, DBG_DIG,
+			"Force to Adaptivity Upper bound=((0x%x))\n", current_igi);
+	}
+
+	if (dig_t->cur_ig_value != current_igi) {
+		#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+		/* Modify big jump step for 8822B and 8197F */
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F))
+			phydm_set_big_jump_step(dm, current_igi);
+		#endif
+
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		/* Set IGI value of CCK for new CCK AGC */
+		if (dm->cck_new_agc && (dm->support_ic_type & PHYSTS_2ND_TYPE_IC))
+			odm_set_bb_reg(dm, 0xa0c, 0x3f00, (current_igi >> 1));
+		#endif
+
+		/*Add by YuChen for USB IO too slow issue*/
+		if (dm->support_ic_type &
+			(ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+			if ((dm->support_ability & ODM_BB_ADAPTIVITY) &&
+				(current_igi < dig_t->cur_ig_value)) {
+				dig_t->cur_ig_value = current_igi;
+				phydm_adaptivity(dm);
+			}
+		} else {
+			if ((dm->support_ability & ODM_BB_ADAPTIVITY) &&
+				(current_igi > dig_t->cur_ig_value)) {
+				dig_t->cur_ig_value = current_igi;
+				phydm_adaptivity(dm);
+			}
+		}
+
+		/* Set IGI value */
+		odm_set_bb_reg(dm, ODM_REG(IGI_A, dm), ODM_BIT(IGI, dm), current_igi);
+
+		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS)
+			odm_set_bb_reg(dm, ODM_REG(IGI_B, dm), ODM_BIT(IGI, dm), current_igi);
+		#endif
+
+		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+			odm_set_bb_reg(dm, ODM_REG(IGI_C, dm), ODM_BIT(IGI, dm), current_igi);
+			odm_set_bb_reg(dm, ODM_REG(IGI_D, dm), ODM_BIT(IGI, dm), current_igi);
+		}
+		#endif
+		
+		dig_t->cur_ig_value = current_igi;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "New_igi=((0x%x))\n\n", current_igi);
+}
+
+void
+phydm_set_dig_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (val_len != 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][DIG]Need val_len=1\n");
+		return;
+	}
+	
+	odm_write_dig(dm, (u8)(*val_buf));
+}
+
+void
+odm_pause_dig(
+	void					*dm_void,
+	enum phydm_pause_type		type,
+	enum phydm_pause_level		lv,
+	u8				igi_input
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	rpt = false;
+	u32	igi = (u32)igi_input;
+
+	PHYDM_DBG(dm, DBG_DIG, "[%s]type = %s, LV = %d, igi = 0x%x\n",
+		  __func__,
+		 ((type == PHYDM_PAUSE) ? "Pause" : ((type == PHYDM_RESUME) ? "Resume" : "PauseNoSet")),
+		  lv, igi);
+
+	switch (type) {
+	
+	case PHYDM_PAUSE:
+	case PHYDM_PAUSE_NO_SET:
+	{
+		rpt = phydm_pause_func(dm, F00_DIG, PHYDM_PAUSE, lv, 1, &igi);
+		break;
+	}
+	
+	case PHYDM_RESUME:
+	{
+		rpt = phydm_pause_func(dm, F00_DIG, PHYDM_RESUME, lv, 1, &igi);
+		break;
+	}
+	default:
+		PHYDM_DBG(dm, DBG_DIG, "Wrong type\n");
+		break;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "pause_result=%d\n", rpt);
+}
+
+
+boolean
+odm_dig_abort(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter	= dm->adapter;
+#endif
+
+	/* support_ability */
+	if ((!(dm->support_ability & ODM_BB_FA_CNT)) ||
+		(!(dm->support_ability & ODM_BB_DIG)) ||
+		*dm->is_scan_in_process) {
+		PHYDM_DBG(dm, DBG_DIG, "Not Support\n");
+		return true;
+	}
+
+	if (dm->pause_ability & ODM_BB_DIG) {
+		
+		PHYDM_DBG(dm, DBG_DIG, "Return: Pause DIG in LV=%d\n", dm->pause_lv_table.lv_dig);
+		return true;
+	}
+	
+	if (dig_t->is_ignore_dig) {
+		dig_t->is_ignore_dig = false;
+		PHYDM_DBG(dm, DBG_DIG, "Return: Ignore DIG\n");
+		return true;
+	}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if OS_WIN_FROM_WIN7(OS_VERSION)
+	if (IsAPModeExist(adapter) && ((PADAPTER)(adapter))->bInHctTest) {
+		PHYDM_DBG(dm, DBG_DIG, " Return: Is AP mode or In HCT Test\n");
+		return true;
+	}
+#endif
+#endif
+
+	return false;
+}
+
+void
+phydm_dig_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct phydm_fa_struct	*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+#endif
+	u32			ret_value = 0;
+	u8			i;
+
+	dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+	dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
+	dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+
+	dig_t->is_ignore_dig = false;
+	dig_t->cur_ig_value = (u8) odm_get_bb_reg(dm, ODM_REG(IGI_A, dm), ODM_BIT(IGI, dm));
+	dig_t->is_media_connect = false;
+
+	dig_t->fa_th[0] = 250;
+	dig_t->fa_th[1] = 500;
+	dig_t->fa_th[2] = 750;
+	dig_t->is_dbg_fa_th = false;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	/* For RTL8881A */
+	false_alm_cnt->cnt_ofdm_fail_pre = 0;
+#endif
+
+	odm_memory_set(dm, dig_t->pause_dig_value, 0, PHYDM_PAUSE_MAX_NUM);
+	dig_t->pause_lv_bitmap = 0;
+
+	dig_t->rx_gain_range_max = DIG_MAX_BALANCE_MODE;
+	dig_t->rx_gain_range_min = dig_t->cur_ig_value;
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	dig_t->enable_adjust_big_jump = 1;
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret_value = odm_get_bb_reg(dm, 0x8c8, MASKLWORD);
+	else if (dm->support_ic_type & ODM_RTL8197F)
+		ret_value = odm_get_bb_reg(dm, 0xc74, MASKLWORD);
+
+	dig_t->big_jump_step1 = (u8)(ret_value & 0xe) >> 1;
+	dig_t->big_jump_step2 = (u8)(ret_value & 0x30) >> 4;
+	dig_t->big_jump_step3 = (u8)(ret_value & 0xc0) >> 6;
+
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
+		for (i = 0; i < sizeof(dig_t->big_jump_lmt); i++) {
+			if (dig_t->big_jump_lmt[i] == 0)
+				dig_t->big_jump_lmt[i] = 0x64;		/* Set -10dBm as default value */
+		}
+	}
+#endif
+
+	dm->pre_rssi_min = 0;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	dm->original_dig_restore = 1;
+#endif
+}
+
+boolean
+phydm_dig_performance_mode_decision(
+	struct dm_struct		*dm
+)
+{
+	boolean	is_performance = true;
+
+#ifdef PHYDM_DIG_MODE_DECISION_SUPPORT
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+
+	switch (dig_t->dig_mode_decision) {
+	case PHYDM_DIG_PERFORAMNCE_MODE:
+		is_performance = true;
+		break;
+	case PHYDM_DIG_COVERAGE_MODE:
+		is_performance = false;
+		break;
+	default:
+		is_performance = true;
+		break;
+	}
+#endif
+
+	return is_performance;
+}
+
+void
+phydm_dig_abs_boundary_decision(
+	struct dm_struct		*dm,
+	boolean	is_performance,
+	boolean	is_dfs_band
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+
+	if (!dm->is_linked) {
+		dig_t->dm_dig_max = DIG_MAX_COVERAGR;
+		dig_t->dm_dig_min = DIG_MIN_COVERAGE;
+	} else if (is_dfs_band == true) {
+		if (*dm->band_width == CHANNEL_WIDTH_20)
+			dig_t->dm_dig_min = DIG_MIN_DFS + 2;
+		else
+			dig_t->dm_dig_min = DIG_MIN_DFS;
+
+		dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+		dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+
+	} else if (!is_performance) {
+		dig_t->dm_dig_max = DIG_MAX_COVERAGR;
+		dig_t->dm_dig_min = DIG_MIN_COVERAGE;
+		#if (DIG_HW == 1)
+		dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
+		#else
+		dig_t->dig_max_of_min = DIG_MAX_OF_MIN_COVERAGE;
+		#endif
+	} else {
+		if (*dm->bb_op_mode == PHYDM_BALANCE_MODE) {	/*service > 2 devices*/
+			dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+			#if (DIG_HW == 1)
+			dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
+			#else
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+			#endif
+		} else if (*dm->bb_op_mode == PHYDM_PERFORMANCE_MODE) {	/*service 1 devices*/
+			dig_t->dm_dig_max = DIG_MAX_PERFORMANCE_MODE;
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_PERFORMANCE_MODE;
+		}
+
+		if (dm->support_ic_type &
+			(ODM_RTL8814A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8822B))
+			dig_t->dm_dig_min = 0x1c;
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			dig_t->dm_dig_min = 0x1e;		/*For HW setting*/
+		else
+			dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"Abs-bound{Max, Min}={0x%x, 0x%x}, Max_of_min =  0x%x\n",
+		dig_t->dm_dig_max,
+		dig_t->dm_dig_min,
+		dig_t->dig_max_of_min);
+
+}
+
+void
+phydm_dig_dym_boundary_decision(
+	struct dm_struct		*dm,
+	boolean	is_performance
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8 offset = 15, tmp_max = 0;
+	u8 max_of_rssi_min = 0;
+
+	PHYDM_DBG(dm, DBG_DIG,
+			"Offset=((%d))\n", offset);
+
+	/* DIG lower bound */
+	if (dm->rssi_min > dig_t->dig_max_of_min)
+		dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+	else if (dm->rssi_min < dig_t->dm_dig_min)
+		dig_t->rx_gain_range_min = dig_t->dm_dig_min;
+	else
+		dig_t->rx_gain_range_min = dm->rssi_min;
+
+	/* DIG upper bound */
+	tmp_max = dig_t->rx_gain_range_min + offset;
+	if (dig_t->rx_gain_range_min != dm->rssi_min) {
+		max_of_rssi_min = dm->rssi_min + offset;
+		if (tmp_max > max_of_rssi_min)
+			tmp_max = max_of_rssi_min;
+	}
+
+	if (tmp_max > dig_t->dm_dig_max)
+		dig_t->rx_gain_range_max = dig_t->dm_dig_max;
+	else
+		dig_t->rx_gain_range_max = tmp_max;
+
+	/* 1 Force Lower Bound for AntDiv */
+	if (dm->is_one_entry_only != 0)
+		goto out;
+
+	if ((dm->support_ic_type & ODM_ANTDIV_SUPPORT) && (dm->support_ability & ODM_BB_ANT_DIV)) {
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV || dm->ant_div_type == CG_TRX_SMART_ANTDIV) {
+			if (dig_t->ant_div_rssi_max > dig_t->dig_max_of_min)
+				dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+			else
+				dig_t->rx_gain_range_min = (u8)dig_t->ant_div_rssi_max;
+			
+			PHYDM_DBG(dm, DBG_DIG,
+				"AntDiv: Force Dyn-Min = 0x%x, RSSI_max = 0x%x\n",
+				dig_t->rx_gain_range_min, dig_t->ant_div_rssi_max);
+		}
+	}
+
+out:
+	PHYDM_DBG(dm, DBG_DIG,
+		"Dym-bound{Max, Min}={0x%x, 0x%x}\n",
+		dig_t->rx_gain_range_max, dig_t->rx_gain_range_min);
+}
+
+void
+phydm_dig_abnormal_case(
+	struct dm_struct		*dm,
+	u8	current_igi,
+	boolean	is_performance,
+	boolean	is_dfs_band
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	boolean	first_connect = false, first_dis_connect = false;
+
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	/* Modify DIG lower bound, deal with abnormal case */
+	if (!dm->is_linked && is_dfs_band && is_performance) {
+		dig_t->rx_gain_range_max = DIG_MAX_DFS;
+		PHYDM_DBG(dm, DBG_DIG,
+			"DFS band: Force max to 0x%x before link\n", dig_t->rx_gain_range_max);
+	}
+
+	if (is_dfs_band)
+		dig_t->rx_gain_range_min = dig_t->dm_dig_min;
+
+	/* Abnormal lower bound case */
+	if (dig_t->rx_gain_range_min > dig_t->rx_gain_range_max)
+		dig_t->rx_gain_range_min = dig_t->rx_gain_range_max;
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"Abnoraml checked {Max, Min}={0x%x, 0x%x}\n",
+		dig_t->rx_gain_range_max, dig_t->rx_gain_range_min);
+
+}
+
+u8
+phydm_dig_current_igi_by_fa_th(
+	struct dm_struct		*dm,
+	u8			current_igi,
+	u32			false_alm_cnt,
+	u8			*step_size
+)
+{
+	boolean	dig_go_up_check = true;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	
+	dig_go_up_check = phydm_dig_go_up_check(dm);
+
+	if ((false_alm_cnt > dig_t->fa_th[2]) && dig_go_up_check)
+		current_igi = current_igi + step_size[0];
+	else if ((false_alm_cnt > dig_t->fa_th[1]) && dig_go_up_check)
+		current_igi = current_igi + step_size[1];
+	else if (false_alm_cnt < dig_t->fa_th[0])
+		current_igi = current_igi - step_size[2];
+
+	return current_igi;
+
+}
+
+u8
+phydm_dig_igi_start_value(
+	struct dm_struct		*dm,
+	boolean	is_performance,
+	u8		current_igi,
+	u32		false_alm_cnt,
+	boolean	is_dfs_band
+)
+{
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	u8		step_size[3] = {0};
+	boolean	first_connect = false, first_dis_connect = false;
+
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	if (dm->is_linked) {
+		if (dm->pre_rssi_min <= dm->rssi_min) {
+			step_size[0] = 2;
+			step_size[1] = 1;
+			step_size[2] = 2;
+		} else {
+			step_size[0] = 4;
+			step_size[1] = 2;
+			step_size[2] = 2;
+		}
+		dm->pre_rssi_min = dm->rssi_min;
+	} else {
+		step_size[0] = 2;
+		step_size[1] = 1;
+		step_size[2] = 2;
+	}
+	
+	PHYDM_DBG(dm, DBG_DIG,
+		"step_size = {-%d,  +%d, +%d}\n", step_size[2], step_size[1], step_size[0]);
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"rssi_min = %d, pre_rssi_min = %d\n", dm->rssi_min, dm->pre_rssi_min);
+
+	if (dm->is_linked && is_performance) {
+		/* 2 After link */
+		PHYDM_DBG(dm, DBG_DIG, "Adjust IGI after link\n");
+
+		if (first_connect && is_performance) {
+			if (is_dfs_band) {
+				if (dm->rssi_min > DIG_MAX_DFS)
+					current_igi = DIG_MAX_DFS;
+				else
+					current_igi = dm->rssi_min;
+				PHYDM_DBG(dm, DBG_DIG,
+					"DFS band: one shot IGI to 0x%x most\n", dig_t->rx_gain_range_max);
+			} else
+				current_igi = dig_t->rx_gain_range_min;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				odm_config_bb_with_header_file(dm, CONFIG_BB_AGC_TAB_DIFF);
+#endif
+#endif
+			PHYDM_DBG(dm, DBG_DIG,
+				"First connect case: IGI does on-shot to 0x%x\n", current_igi);
+		} else {
+			/* 4 Abnormal # beacon case */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))		
+			if ((dm->phy_dbg_info.num_qry_beacon_pkt < 5) &&
+				(false_alm_cnt < DM_DIG_FA_TH1) && (dm->bsta_state)) {
+				if (dm->support_ic_type != ODM_RTL8723D) {
+					dig_t->rx_gain_range_min = 0x1c;
+					current_igi = dig_t->rx_gain_range_min;
+					PHYDM_DBG(dm, DBG_DIG,
+						"Abnormal #beacon (%d) case: IGI does one-shot to 0x%x\n",
+						dm->phy_dbg_info.num_qry_beacon_pkt, current_igi);
+				}
+			} else
+#endif
+				current_igi = phydm_dig_current_igi_by_fa_th(dm,
+						current_igi, false_alm_cnt, step_size);
+		}
+	} else {
+		/* 2 Before link */
+		PHYDM_DBG(dm, DBG_DIG, "Adjust IGI before link\n");
+
+		if (first_dis_connect) {
+			current_igi = dig_t->dm_dig_min;
+			PHYDM_DBG(dm, DBG_DIG, "First disconnect case: IGI does on-shot to lower bound\n");
+		} else {
+			PHYDM_DBG(dm, DBG_DIG,
+				"Pre_IGI=((0x%x)), FA=((%d))\n", current_igi, false_alm_cnt);
+
+			current_igi = phydm_dig_current_igi_by_fa_th(dm,
+						current_igi, false_alm_cnt, step_size);
+		}
+	}
+
+	return current_igi;
+
+}
+
+void
+phydm_dig(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct		*falm_cnt = &dm->false_alm_cnt;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
+#endif
+	boolean		first_connect, first_dis_connect;
+	u8			current_igi = dig_t->cur_ig_value;
+	u32			false_alm_cnt= falm_cnt->cnt_all;
+	boolean		is_dfs_band = false, is_performance = true;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0) {
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+		
+		current_igi = dig_t->cur_ig_value_tdma;
+		false_alm_cnt = falm_cnt_acc->cnt_all_1sec;
+	}
+#endif
+
+	if (odm_dig_abort(dm) == true) {
+		dig_t->cur_ig_value = (u8)odm_get_bb_reg(dm, 0xc50, 0x7f);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "%s Start===>\n", __func__);
+
+	/* 1 Update status */
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"is_linked = %d, RSSI = %d, 1stConnect = %d, 1stDisconnect = %d\n",
+		dm->is_linked, dm->rssi_min, first_connect, first_dis_connect);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP | ODM_CE))
+	/* Modify lower bound for DFS band */
+	if (dm->is_dfs_band) {
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+		if (phydm_dfs_master_enabled(dm))
+		#endif
+			is_dfs_band = true;
+		
+		PHYDM_DBG(dm, DBG_DIG, "In DFS band\n");
+	}
+#endif
+
+	is_performance = phydm_dig_performance_mode_decision(dm);
+	PHYDM_DBG(dm, DBG_DIG,
+		"DIG ((%s)) mode\n", (is_performance ? "Performance" : "Coverage"));
+
+	/* Boundary Decision */
+	phydm_dig_abs_boundary_decision(dm, is_performance, is_dfs_band);
+
+	/*init dym boundary*/
+	dig_t->rx_gain_range_max = dig_t->dig_max_of_min;	/*if no link, always stay at lower bound*/
+	dig_t->rx_gain_range_min = dig_t->dm_dig_min;
+
+	/* Adjust boundary by RSSI */
+	if (dm->is_linked)
+		phydm_dig_dym_boundary_decision(dm, is_performance);
+
+	/*Abnormal case check*/
+	phydm_dig_abnormal_case(dm, current_igi, is_performance, is_dfs_band);
+
+	/* False alarm threshold decision */
+	odm_fa_threshold_check(dm, is_dfs_band, is_performance);
+
+	/* 1 Adjust initial gain by false alarm */
+	current_igi = phydm_dig_igi_start_value(dm,
+		is_performance, current_igi, false_alm_cnt, is_dfs_band);
+
+	/* 1 Check initial gain by upper/lower bound */
+	if (current_igi < dig_t->rx_gain_range_min)
+		current_igi = dig_t->rx_gain_range_min;
+
+	if (current_igi > dig_t->rx_gain_range_max)
+		current_igi = dig_t->rx_gain_range_max;
+
+	PHYDM_DBG(dm, DBG_DIG, "New_IGI=((0x%x))\n", current_igi);
+
+	/* 1 Update status */
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0) {
+		dig_t->cur_ig_value_tdma = current_igi;
+		/*It is possible fa_acc_1sec_tsf >= */
+		/*1sec while tdma_dig_state == 0*/
+		if (dig_t->tdma_dig_state != 0)
+			odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+	} else
+#endif 
+		odm_write_dig(dm, current_igi);
+
+	dig_t->is_media_connect = dm->is_linked;
+	
+	PHYDM_DBG(dm, DBG_DIG, "DIG end\n");
+}
+
+void
+phydm_dig_lps_32k(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	current_igi = dm->rssi_min;
+
+
+	odm_write_dig(dm, current_igi);
+}
+
+void
+phydm_dig_by_rssi_lps(
+	void		*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct	*falm_cnt;
+
+	u8	rssi_lower = DIG_MIN_LPS; /* 0x1E or 0x1C */
+	u8	current_igi = dm->rssi_min;
+
+	falm_cnt = &dm->false_alm_cnt;
+	if (odm_dig_abort(dm) == true)
+		return;
+
+	current_igi = current_igi + RSSI_OFFSET_DIG_LPS;
+	PHYDM_DBG(dm, DBG_DIG, "%s==>\n", __func__);
+
+	/* Using FW PS mode to make IGI */
+	/* Adjust by  FA in LPS MODE */
+	if (falm_cnt->cnt_all > DM_DIG_FA_TH2_LPS)
+		current_igi = current_igi + 4;
+	else if (falm_cnt->cnt_all > DM_DIG_FA_TH1_LPS)
+		current_igi = current_igi + 2;
+	else if (falm_cnt->cnt_all < DM_DIG_FA_TH0_LPS)
+		current_igi = current_igi - 2;
+
+
+	/* Lower bound checking */
+
+	/* RSSI Lower bound check */
+	if ((dm->rssi_min - 10) > DIG_MIN_LPS)
+		rssi_lower = (dm->rssi_min - 10);
+	else
+		rssi_lower = DIG_MIN_LPS;
+
+	/* Upper and Lower Bound checking */
+	if (current_igi > DIG_MAX_LPS)
+		current_igi = DIG_MAX_LPS;
+	else if (current_igi < rssi_lower)
+		current_igi = rssi_lower;
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"%s falm_cnt->cnt_all = %d\n", __func__,
+		falm_cnt->cnt_all);
+	PHYDM_DBG(dm, DBG_DIG,
+		"%s dm->rssi_min = %d\n", __func__,
+		dm->rssi_min);
+	PHYDM_DBG(dm, DBG_DIG,
+		"%s current_igi = 0x%x\n", __func__,
+		current_igi);
+
+	/* odm_write_dig(dm, dig_t->cur_ig_value); */
+	odm_write_dig(dm, current_igi);
+#endif
+}
+
+/* 3============================================================
+ * 3 FASLE ALARM CHECK
+ * 3============================================================ */
+void
+phydm_false_alarm_counter_reg_reset(
+	void					*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
+#endif
+	u32	false_alm_cnt;
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore == 0) {
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+
+		false_alm_cnt = falm_cnt_acc->cnt_all_1sec;
+	} else 
+#endif
+	{
+		false_alm_cnt = falm_cnt->cnt_all;
+	}
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/*reset false alarm counter registers*/
+		odm_set_bb_reg(dm, 0xC0C, BIT(31), 1);
+		odm_set_bb_reg(dm, 0xC0C, BIT(31), 0);
+		odm_set_bb_reg(dm, 0xD00, BIT(27), 1);
+		odm_set_bb_reg(dm, 0xD00, BIT(27), 0);
+
+		/*update ofdm counter*/
+		/*update page C counter*/
+		odm_set_bb_reg(dm, 0xD00, BIT(31), 0);
+		/*update page D counter*/
+		odm_set_bb_reg(dm, 0xD00, BIT(31), 0);
+
+		/*reset CCK CCA counter*/
+		odm_set_bb_reg(dm, 0xA2C, BIT(13) | BIT(12), 0);
+		odm_set_bb_reg(dm, 0xA2C, BIT(13) | BIT(12), 2);
+
+		/*reset CCK FA counter*/
+		odm_set_bb_reg(dm, 0xA2C, BIT(15) | BIT(14), 0);
+		odm_set_bb_reg(dm, 0xA2C, BIT(15) | BIT(14), 2);
+
+		/*reset CRC32 counter*/
+		odm_set_bb_reg(dm, 0xF14, BIT(16), 1);
+		odm_set_bb_reg(dm, 0xF14, BIT(16), 0);
+	}
+#endif	/* #if (ODM_IC_11N_SERIES_SUPPORT == 1) */
+
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	#if (RTL8881A_SUPPORT == 1)
+			/* Reset FA counter by enable/disable OFDM */
+			if (false_alm_cnt->cnt_ofdm_fail_pre >= 0x7fff) {
+				/* reset OFDM */
+				odm_set_bb_reg(dm, 0x808, BIT(29), 0);
+				odm_set_bb_reg(dm, 0x808, BIT(29), 1);
+				false_alm_cnt->cnt_ofdm_fail_pre = 0;
+				PHYDM_DBG(dm, DBG_FA_CNT, "Reset FA_cnt\n");
+			}
+	#endif	/* #if (RTL8881A_SUPPORT == 1) */
+			/* reset OFDM FA countner */
+			odm_set_bb_reg(dm, 0x9A4, BIT(17), 1);
+			odm_set_bb_reg(dm, 0x9A4, BIT(17), 0);
+
+			/* reset CCK FA counter */
+			odm_set_bb_reg(dm, 0xA2C, BIT(15), 0);
+			odm_set_bb_reg(dm, 0xA2C, BIT(15), 1);
+
+			/* reset CCA counter */
+			odm_set_bb_reg(dm, 0xB58, BIT(0), 1);
+			odm_set_bb_reg(dm, 0xB58, BIT(0), 0);
+		}
+#endif	/* #if (ODM_IC_11AC_SERIES_SUPPORT == 1) */
+}
+
+void
+phydm_false_alarm_counter_reg_hold(
+	void					*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/*hold ofdm counter*/
+		/*hold page C counter*/
+		odm_set_bb_reg(dm, 0xC00, BIT(31), 1);
+		/*hold page D counter*/
+		odm_set_bb_reg(dm, 0xD00, BIT(31), 1);
+
+		//hold cck counter
+		odm_set_bb_reg(dm, 0xA2C, BIT(12), 1);
+		odm_set_bb_reg(dm, 0xA2C, BIT(14), 1);
+	}
+}
+
+void
+odm_false_alarm_counter_statistics(
+	void		*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct	*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u32						ret_value;
+
+	if (!(dm->support_ability & ODM_BB_FA_CNT))
+		return;
+
+	PHYDM_DBG(dm, DBG_FA_CNT, "FA_Counter()======>\n");
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/* hold ofdm & cck counter */
+		phydm_false_alarm_counter_reg_hold(dm);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE1_11N, MASKDWORD);
+		false_alm_cnt->cnt_fast_fsync = (ret_value & 0xffff);
+		false_alm_cnt->cnt_sb_search_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE2_11N, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_cca = (ret_value & 0xffff);
+		false_alm_cnt->cnt_parity_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE3_11N, MASKDWORD);
+		false_alm_cnt->cnt_rate_illegal = (ret_value & 0xffff);
+		false_alm_cnt->cnt_crc8_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE4_11N, MASKDWORD);
+		false_alm_cnt->cnt_mcs_fail = (ret_value & 0xffff);
+
+		false_alm_cnt->cnt_ofdm_fail =
+			false_alm_cnt->cnt_parity_fail + false_alm_cnt->cnt_rate_illegal +
+			false_alm_cnt->cnt_crc8_fail + false_alm_cnt->cnt_mcs_fail +
+			false_alm_cnt->cnt_fast_fsync + false_alm_cnt->cnt_sb_search_fail;
+
+		/* read CCK CRC32 counter */
+		false_alm_cnt->cnt_cck_crc32_error = odm_get_bb_reg(dm, ODM_REG_CCK_CRC32_ERROR_CNT_11N, MASKDWORD);
+		false_alm_cnt->cnt_cck_crc32_ok = odm_get_bb_reg(dm, ODM_REG_CCK_CRC32_OK_CNT_11N, MASKDWORD);
+
+		/* read OFDM CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_CRC32_CNT_11N, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ofdm_crc32_ok = ret_value & 0xffff;
+
+		/* read HT CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11N, MASKDWORD);
+		false_alm_cnt->cnt_ht_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ht_crc32_ok = ret_value & 0xffff;
+
+		/* read VHT CRC32 counter */
+		false_alm_cnt->cnt_vht_crc32_error = 0;
+		false_alm_cnt->cnt_vht_crc32_ok = 0;
+		
+#if (RTL8723D_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8723D) {
+			/* read HT CRC32 agg counter */
+			ret_value = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11N_AGG, MASKDWORD);
+			false_alm_cnt->cnt_ht_crc32_error_agg = (ret_value & 0xffff0000) >> 16;
+			false_alm_cnt->cnt_ht_crc32_ok_agg= ret_value & 0xffff;
+		}
+#endif
+		
+#if (RTL8188E_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8188E) {
+			ret_value = odm_get_bb_reg(dm, ODM_REG_SC_CNT_11N, MASKDWORD);
+			false_alm_cnt->cnt_bw_lsc = (ret_value & 0xffff);
+			false_alm_cnt->cnt_bw_usc = ((ret_value & 0xffff0000) >> 16);
+		}
+#endif
+
+		{
+			ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_FA_LSB_11N, MASKBYTE0);
+			false_alm_cnt->cnt_cck_fail = ret_value;
+
+			ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_FA_MSB_11N, MASKBYTE3);
+			false_alm_cnt->cnt_cck_fail += (ret_value & 0xff) << 8;
+
+			ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CCA_CNT_11N, MASKDWORD);
+			false_alm_cnt->cnt_cck_cca = ((ret_value & 0xFF) << 8) | ((ret_value & 0xFF00) >> 8);
+		}
+
+		false_alm_cnt->cnt_all_pre = false_alm_cnt->cnt_all;
+
+		false_alm_cnt->time_fa_all = (false_alm_cnt->cnt_fast_fsync + false_alm_cnt->cnt_sb_search_fail) * 12 +
+					  (false_alm_cnt->cnt_parity_fail + false_alm_cnt->cnt_rate_illegal) * 28 +
+					  false_alm_cnt->cnt_crc8_fail * 36 +
+					  false_alm_cnt->cnt_mcs_fail * 32 +
+					  false_alm_cnt->cnt_cck_fail * 80;
+
+		false_alm_cnt->cnt_all = (false_alm_cnt->cnt_fast_fsync +
+					  false_alm_cnt->cnt_sb_search_fail +
+					  false_alm_cnt->cnt_parity_fail +
+					  false_alm_cnt->cnt_rate_illegal +
+					  false_alm_cnt->cnt_crc8_fail +
+					  false_alm_cnt->cnt_mcs_fail +
+					  false_alm_cnt->cnt_cck_fail);
+
+		false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_ofdm_cca + false_alm_cnt->cnt_cck_cca;
+
+		PHYDM_DBG(dm, DBG_FA_CNT,
+			"[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), CRC8_fail = (( %d )), Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d ))\n",
+			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail);
+		
+	}
+#endif
+
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		u32 cck_enable;
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE1_11AC, MASKDWORD);
+		false_alm_cnt->cnt_fast_fsync = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE2_11AC, MASKDWORD);
+		false_alm_cnt->cnt_sb_search_fail = (ret_value & 0xffff);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE3_11AC, MASKDWORD);
+		false_alm_cnt->cnt_parity_fail = (ret_value & 0xffff);
+		false_alm_cnt->cnt_rate_illegal = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE4_11AC, MASKDWORD);
+		false_alm_cnt->cnt_crc8_fail = (ret_value & 0xffff);
+		false_alm_cnt->cnt_mcs_fail = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE5_11AC, MASKDWORD);
+		false_alm_cnt->cnt_crc8_fail_vht = (ret_value & 0xffff);
+
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE6_11AC, MASKDWORD);
+		false_alm_cnt->cnt_mcs_fail_vht = (ret_value & 0xffff);
+
+		/* read OFDM FA counter */
+		false_alm_cnt->cnt_ofdm_fail = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_11AC, MASKLWORD);
+
+		/* Read CCK FA counter */
+		false_alm_cnt->cnt_cck_fail = odm_get_bb_reg(dm, ODM_REG_CCK_FA_11AC, MASKLWORD);
+
+		/* read CCK/OFDM CCA counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CCA_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_cca = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_cck_cca = ret_value & 0xffff;
+
+		/* read CCK CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_cck_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_cck_crc32_ok = ret_value & 0xffff;
+
+		/* read OFDM CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_ofdm_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ofdm_crc32_ok = ret_value & 0xffff;
+
+		/* read HT CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_ht_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_ht_crc32_ok = ret_value & 0xffff;
+
+		/* read VHT CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, ODM_REG_VHT_CRC32_CNT_11AC, MASKDWORD);
+		false_alm_cnt->cnt_vht_crc32_error = (ret_value & 0xffff0000) >> 16;
+		false_alm_cnt->cnt_vht_crc32_ok = ret_value & 0xffff;
+
+#if (RTL8881A_SUPPORT == 1)
+		/* For 8881A */
+		if (dm->support_ic_type == ODM_RTL8881A) {
+			u32 cnt_ofdm_fail_temp = 0;
+
+			if (false_alm_cnt->cnt_ofdm_fail >= false_alm_cnt->cnt_ofdm_fail_pre) {
+				cnt_ofdm_fail_temp = false_alm_cnt->cnt_ofdm_fail_pre;
+				false_alm_cnt->cnt_ofdm_fail_pre = false_alm_cnt->cnt_ofdm_fail;
+				false_alm_cnt->cnt_ofdm_fail = false_alm_cnt->cnt_ofdm_fail - cnt_ofdm_fail_temp;
+			} else
+				false_alm_cnt->cnt_ofdm_fail_pre = false_alm_cnt->cnt_ofdm_fail;
+			PHYDM_DBG(dm, DBG_FA_CNT, "odm_false_alarm_counter_statistics(): cnt_ofdm_fail=%d\n",	false_alm_cnt->cnt_ofdm_fail_pre);
+			PHYDM_DBG(dm, DBG_FA_CNT, "odm_false_alarm_counter_statistics(): cnt_ofdm_fail_pre=%d\n",	cnt_ofdm_fail_temp);
+		}
+#endif
+		cck_enable =  odm_get_bb_reg(dm, ODM_REG_BB_RX_PATH_11AC, BIT(28));
+		if (cck_enable) { /* if(*dm->band_type == ODM_BAND_2_4G) */
+			false_alm_cnt->cnt_all = false_alm_cnt->cnt_ofdm_fail + false_alm_cnt->cnt_cck_fail;
+			false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_cck_cca + false_alm_cnt->cnt_ofdm_cca;
+		} else {
+			false_alm_cnt->cnt_all = false_alm_cnt->cnt_ofdm_fail;
+			false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_ofdm_cca;
+		}
+	}
+#endif
+
+	if (dm->support_ic_type != ODM_RTL8723D) {
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, 0x0)) {/*set debug port to 0x0*/
+			false_alm_cnt->dbg_port0 = phydm_get_bb_dbg_port_value(dm);
+			phydm_release_bb_dbg_port(dm);
+		}
+
+		if (phydm_set_bb_dbg_port(dm, BB_DBGPORT_PRIORITY_1, adaptivity->adaptivity_dbg_port)) {
+			if (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E))
+				false_alm_cnt->edcca_flag = (boolean)((phydm_get_bb_dbg_port_value(dm) & BIT(30)) >> 30);
+			else
+				false_alm_cnt->edcca_flag = (boolean)((phydm_get_bb_dbg_port_value(dm) & BIT(29)) >> 29);
+			phydm_release_bb_dbg_port(dm);
+		}
+	} else {
+		false_alm_cnt->edcca_flag = (boolean)(odm_get_bb_reg(dm, 0x9a0, BIT(29)));
+	}
+
+	phydm_false_alarm_counter_reg_reset(dm_void);
+
+	false_alm_cnt->time_fa_all = (false_alm_cnt->cnt_fast_fsync + false_alm_cnt->cnt_sb_search_fail) * 12 +
+					  (false_alm_cnt->cnt_parity_fail + false_alm_cnt->cnt_rate_illegal) * 28 +
+					  (false_alm_cnt->cnt_crc8_fail + false_alm_cnt->cnt_crc8_fail_vht + false_alm_cnt->cnt_mcs_fail_vht) * 36 +
+					  false_alm_cnt->cnt_mcs_fail * 32 +
+					  false_alm_cnt->cnt_cck_fail * 80;
+
+	false_alm_cnt->cnt_crc32_error_all = false_alm_cnt->cnt_vht_crc32_error + false_alm_cnt->cnt_ht_crc32_error + false_alm_cnt->cnt_ofdm_crc32_error + false_alm_cnt->cnt_cck_crc32_error;
+	false_alm_cnt->cnt_crc32_ok_all = false_alm_cnt->cnt_vht_crc32_ok + false_alm_cnt->cnt_ht_crc32_ok + false_alm_cnt->cnt_ofdm_crc32_ok + false_alm_cnt->cnt_cck_crc32_ok;
+
+	PHYDM_DBG(dm, DBG_FA_CNT,
+			"[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), HT_CRC8_fail = (( %d )), HT_Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d )), VHT_CRC8_fail = (( %d )), VHT_Mcs_fail = (( %d ))\n",
+			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail, false_alm_cnt->cnt_crc8_fail_vht, false_alm_cnt->cnt_mcs_fail_vht);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all);
+
+	PHYDM_DBG(dm, DBG_FA_CNT, "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all);
+
+	PHYDM_DBG(dm, DBG_FA_CNT, "[CCK]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_cck_crc32_error, false_alm_cnt->cnt_cck_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[OFDM]CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_ofdm_crc32_error, false_alm_cnt->cnt_ofdm_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[ HT ]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_ht_crc32_error, false_alm_cnt->cnt_ht_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[VHT]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_vht_crc32_error, false_alm_cnt->cnt_vht_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[TOTAL]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_crc32_error_all, false_alm_cnt->cnt_crc32_ok_all);
+	PHYDM_DBG(dm, DBG_FA_CNT, "FA_Cnt: Dbg port 0x0 = 0x%x, EDCCA = %d\n\n", false_alm_cnt->dbg_port0, false_alm_cnt->edcca_flag);
+}
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+void
+phydm_set_tdma_dig_timer(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32	delta_time_us = dm->tdma_dig_timer_ms * 1000;
+	struct phydm_dig_struct	*dig_t;
+	u32	timeout;
+	u32	current_time_stamp, diff_time_stamp, regb0;
+	
+	dig_t = &dm->dm_dig_table;
+	/*some IC has no FREERUN_CUNT register, like 92E*/
+	if (dm->support_ic_type & ODM_RTL8197F)
+		current_time_stamp = odm_get_bb_reg(dm, 0x568, bMaskDWord);
+	else
+		return;
+
+	timeout = current_time_stamp + delta_time_us;
+
+	diff_time_stamp = current_time_stamp - dig_t->cur_timestamp;
+	dig_t->pre_timestamp = dig_t->cur_timestamp;
+	dig_t->cur_timestamp = current_time_stamp;
+
+	/*HIMR0, it shows HW interrupt mask*/
+	regb0 = odm_get_bb_reg(dm, 0xb0, bMaskDWord);
+
+	PHYDM_DBG(dm, DBG_DIG,
+		"Set next tdma_dig_timer\n");
+	PHYDM_DBG(dm, DBG_DIG,
+		"current_time_stamp=%d, delta_time_us=%d, timeout=%d, diff_time_stamp=%d, Reg0xb0 = 0x%x\n",
+		current_time_stamp,
+		delta_time_us,
+		timeout,
+		diff_time_stamp,
+		regb0);
+
+	if (dm->support_ic_type & ODM_RTL8197F)		/*REG_PS_TIMER2*/
+		odm_set_bb_reg(dm, 0x588, bMaskDWord, timeout);
+	else {
+		PHYDM_DBG(dm, DBG_DIG,
+					"NOT 97F, TDMA-DIG timer does NOT start!\n");
+		return;
+	}
+}
+
+void
+phydm_tdma_dig_timer_check(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t;
+
+	dig_t = &dm->dm_dig_table;
+	
+	PHYDM_DBG(dm, DBG_DIG,
+				"tdma_dig_cnt=%d, pre_tdma_dig_cnt=%d\n",
+				dig_t->tdma_dig_cnt,
+				dig_t->pre_tdma_dig_cnt);
+
+	if ((dig_t->tdma_dig_cnt == 0) ||
+		(dig_t->tdma_dig_cnt == dig_t->pre_tdma_dig_cnt)) {
+		if (dm->support_ability & ODM_BB_DIG) {
+			/*if interrupt mask info is got.*/
+			/*Reg0xb0 is no longer needed*/
+			/*regb0 = odm_get_bb_reg(dm, 0xb0, bMaskDWord);*/
+			PHYDM_DBG(dm, DBG_DIG,
+						"Check fail, IntMask[0]=0x%x, restart tdma_dig_timer !!!\n",
+						*dm->interrupt_mask);
+
+			phydm_tdma_dig_add_interrupt_mask_handler(dm);
+			phydm_enable_rx_related_interrupt_handler(dm);
+			phydm_set_tdma_dig_timer(dm);
+		}
+	} else
+		PHYDM_DBG(dm, DBG_DIG,
+					"Check pass, update pre_tdma_dig_cnt\n");
+
+	dig_t->pre_tdma_dig_cnt = dig_t->tdma_dig_cnt;
+}
+
+/*different IC/team may use different timer for tdma-dig*/
+void
+phydm_tdma_dig_add_interrupt_mask_handler(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if (DM_ODM_SUPPORT_TYPE == (ODM_AP))
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_add_interrupt_mask_handler(dm, HAL_INT_TYPE_PSTIMEOUT2);	/*HAL_INT_TYPE_PSTIMEOUT2*/
+#elif (DM_ODM_SUPPORT_TYPE == (ODM_WIN))
+#elif (DM_ODM_SUPPORT_TYPE == (ODM_CE))
+#endif
+}
+
+void
+phydm_tdma_dig(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm;
+	struct phydm_dig_struct	*dig_t;
+	struct phydm_fa_struct *falm_cnt;
+	u32	reg_c50;
+	
+	dm = (struct dm_struct *)dm_void;
+	dig_t = &dm->dm_dig_table;
+	falm_cnt = &dm->false_alm_cnt;
+	reg_c50 = odm_get_bb_reg(dm, 0xc50, MASKBYTE0);
+
+	dig_t->tdma_dig_state =
+		dig_t->tdma_dig_cnt % dm->tdma_dig_state_number;
+
+	PHYDM_DBG(dm, DBG_DIG,
+				"tdma_dig_state=%d, regc50=0x%x\n",
+				dig_t->tdma_dig_state,
+				reg_c50);
+
+	dig_t->tdma_dig_cnt++;
+
+	if (dig_t->tdma_dig_state == 1) {
+		// update IGI from tdma_dig_state == 0
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+
+		odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+		phydm_tdma_false_alarm_counter_check(dm);
+		PHYDM_DBG(dm, DBG_DIG,
+			"tdma_dig_state=%d, reset FA counter !!!\n",
+			dig_t->tdma_dig_state);
+
+	} else if (dig_t->tdma_dig_state == 0) {
+		/* update dig_t->CurIGValue,*/
+		/* it may different from dig_t->cur_ig_value_tdma */
+		/* TDMA IGI upperbond @ L-state = */
+		/* rf_ft_var.tdma_dig_low_upper_bond = 0x26 */
+
+		if (dig_t->cur_ig_value >= dm->tdma_dig_low_upper_bond)
+			dig_t->low_ig_value = dm->tdma_dig_low_upper_bond;
+		else
+			dig_t->low_ig_value = dig_t->cur_ig_value;
+
+		odm_write_dig(dm, dig_t->low_ig_value);
+		phydm_tdma_false_alarm_counter_check(dm);
+	} else
+		phydm_tdma_false_alarm_counter_check(dm);
+}
+
+/*============================================================*/
+/*FASLE ALARM CHECK*/
+/*============================================================*/
+
+void
+phydm_tdma_false_alarm_counter_check(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm;
+	struct phydm_fa_struct	*falm_cnt;
+	struct phydm_fa_acc_struct	*falm_cnt_acc;
+	struct phydm_dig_struct	*dig_t;
+	boolean	rssi_dump_en = 0;
+	u32 timestamp;
+	u8 tdma_dig_state_number;
+
+	dm = (struct dm_struct *)dm_void;
+	falm_cnt = &dm->false_alm_cnt;
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+	dig_t = &dm->dm_dig_table;
+
+	if (dig_t->tdma_dig_state == 1)
+		phydm_false_alarm_counter_reset(dm);
+		/* Reset FalseAlarmCounterStatistics */
+		/* fa_acc_1sec_tsf = fa_acc_1sec_tsf, keep */
+		/* fa_end_tsf = fa_start_tsf = TSF */
+	else {
+		odm_false_alarm_counter_statistics(dm);
+		if (dm->support_ic_type & ODM_RTL8197F)		/*REG_FREERUN_CNT*/
+			timestamp = odm_get_bb_reg(dm, 0x568, bMaskDWord);
+		else {
+			PHYDM_DBG(dm, DBG_DIG,
+						"Caution! NOT 97F! TDMA-DIG timer does NOT start!!!\n");
+			return;
+		}
+		dig_t->fa_end_timestamp = timestamp;
+		dig_t->fa_acc_1sec_timestamp +=
+			(dig_t->fa_end_timestamp - dig_t->fa_start_timestamp);
+
+		/*prevent dumb*/
+		if (dm->tdma_dig_state_number == 1)
+			dm->tdma_dig_state_number = 2;
+
+		tdma_dig_state_number = dm->tdma_dig_state_number;
+		dig_t->sec_factor =
+			tdma_dig_state_number / (tdma_dig_state_number - 1);
+
+		/*1sec = 1000000us*/
+		if (dig_t->fa_acc_1sec_timestamp >= (u32)(1000000 / dig_t->sec_factor)) {
+			rssi_dump_en = 1;
+			phydm_false_alarm_counter_acc(dm, rssi_dump_en);
+			PHYDM_DBG(dm, DBG_DIG,
+						"sec_factor = %u, total FA = %u, is_linked=%u\n",
+						dig_t->sec_factor,
+						falm_cnt_acc->cnt_all,
+						dm->is_linked);
+
+			phydm_noisy_detection(dm);
+			phydm_cck_pd_th(dm);
+			phydm_dig(dm);
+			phydm_false_alarm_counter_acc_reset(dm);
+
+			/* Reset FalseAlarmCounterStatistics */
+			/* fa_end_tsf = fa_start_tsf = TSF, keep */
+			/* fa_acc_1sec_tsf = 0 */
+			phydm_false_alarm_counter_reset(dm);
+		} else
+			phydm_false_alarm_counter_acc(dm, rssi_dump_en);
+	}
+}
+
+void
+phydm_false_alarm_counter_acc(
+	void		*dm_void,
+	boolean		rssi_dump_en
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct			*falm_cnt;
+	struct phydm_fa_acc_struct		*falm_cnt_acc;
+	struct phydm_dig_struct	*dig_t;
+	
+	falm_cnt = &dm->false_alm_cnt;
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+	dig_t = &dm->dm_dig_table;
+
+	falm_cnt_acc->cnt_parity_fail += falm_cnt->cnt_parity_fail;
+	falm_cnt_acc->cnt_rate_illegal += falm_cnt->cnt_rate_illegal;
+	falm_cnt_acc->cnt_crc8_fail += falm_cnt->cnt_crc8_fail;
+	falm_cnt_acc->cnt_mcs_fail += falm_cnt->cnt_mcs_fail;
+	falm_cnt_acc->cnt_ofdm_fail += falm_cnt->cnt_ofdm_fail;
+	falm_cnt_acc->cnt_cck_fail += falm_cnt->cnt_cck_fail;
+	falm_cnt_acc->cnt_all += falm_cnt->cnt_all;
+	falm_cnt_acc->cnt_fast_fsync += falm_cnt->cnt_fast_fsync;
+	falm_cnt_acc->cnt_sb_search_fail += falm_cnt->cnt_sb_search_fail;
+	falm_cnt_acc->cnt_ofdm_cca += falm_cnt->cnt_ofdm_cca;
+	falm_cnt_acc->cnt_cck_cca += falm_cnt->cnt_cck_cca;
+	falm_cnt_acc->cnt_cca_all += falm_cnt->cnt_cca_all;
+	falm_cnt_acc->cnt_cck_crc32_error += falm_cnt->cnt_cck_crc32_error;
+	falm_cnt_acc->cnt_cck_crc32_ok += falm_cnt->cnt_cck_crc32_ok;
+	falm_cnt_acc->cnt_ofdm_crc32_error += falm_cnt->cnt_ofdm_crc32_error;
+	falm_cnt_acc->cnt_ofdm_crc32_ok += falm_cnt->cnt_ofdm_crc32_ok;
+	falm_cnt_acc->cnt_ht_crc32_error += falm_cnt->cnt_ht_crc32_error;
+	falm_cnt_acc->cnt_ht_crc32_ok += falm_cnt->cnt_ht_crc32_ok;
+	falm_cnt_acc->cnt_vht_crc32_error += falm_cnt->cnt_vht_crc32_error;
+	falm_cnt_acc->cnt_vht_crc32_ok += falm_cnt->cnt_vht_crc32_ok;
+	falm_cnt_acc->cnt_crc32_error_all += falm_cnt->cnt_crc32_error_all;
+	falm_cnt_acc->cnt_crc32_ok_all += falm_cnt->cnt_crc32_ok_all;
+
+	if (rssi_dump_en == 1) {
+		falm_cnt_acc->cnt_all_1sec =
+			falm_cnt_acc->cnt_all * dig_t->sec_factor;
+		falm_cnt_acc->cnt_cca_all_1sec =
+			falm_cnt_acc->cnt_cca_all * dig_t->sec_factor;
+		falm_cnt_acc->cnt_cck_fail_1sec =
+			falm_cnt_acc->cnt_cck_fail * dig_t->sec_factor;
+	}
+}
+
+void
+phydm_false_alarm_counter_acc_reset(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_acc_struct *falm_cnt_acc;
+
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+
+	/* Cnt_all_for_rssi_dump & Cnt_CCA_all_for_rssi_dump */
+	/* do NOT need to be reset */
+	odm_memory_set(dm, falm_cnt_acc, 0, sizeof(falm_cnt_acc));
+}
+
+void
+phydm_false_alarm_counter_reset(
+	void		*dm_void
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt;
+	struct phydm_dig_struct	*dig_t;
+	u32	timestamp;
+
+	falm_cnt = &dm->false_alm_cnt;
+	dig_t = &dm->dm_dig_table;
+
+	memset(falm_cnt, 0, sizeof(dm->false_alm_cnt));
+	phydm_false_alarm_counter_reg_reset(dm);
+
+	if (dig_t->tdma_dig_state != 1)
+		dig_t->fa_acc_1sec_timestamp = 0;
+	else
+		dig_t->fa_acc_1sec_timestamp = dig_t->fa_acc_1sec_timestamp;
+
+	/*REG_FREERUN_CNT*/
+	timestamp = odm_get_bb_reg(dm, 0x568, bMaskDWord);
+	dig_t->fa_start_timestamp = timestamp;
+	dig_t->fa_end_timestamp = timestamp;
+}
+
+#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+void
+phydm_lna_sat_chk_init(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __FUNCTION__);
+
+	lna_info->check_time = 0;
+	lna_info->sat_cnt_acc_patha = 0;
+	lna_info->sat_cnt_acc_pathb = 0;
+	lna_info->cur_sat_status = 0;
+	lna_info->pre_sat_status = 0;
+	lna_info->cur_timer_check_cnt = 0;
+	lna_info->pre_timer_check_cnt = 0;
+}
+
+void
+phydm_set_ofdm_agc_tab(
+	void	*dm_void,
+	u8		tab_sel
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	/* table sel:0/2, 1 is used for CCK */
+	if (tab_sel == OFDM_AGC_TAB_0)
+		odm_set_bb_reg(dm, 0xc70, 0x1e00, OFDM_AGC_TAB_0);
+	else if (tab_sel == OFDM_AGC_TAB_2)
+		odm_set_bb_reg(dm, 0xc70, 0x1e00, OFDM_AGC_TAB_2);
+	else
+		odm_set_bb_reg(dm, 0xc70, 0x1e00, OFDM_AGC_TAB_0);
+}
+
+u8
+phydm_get_ofdm_agc_tab(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	return (u1Byte)odm_get_bb_reg(dm, 0xc70, 0x1e00);
+}
+
+void
+phydm_lna_sat_chk(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	u1Byte			igi_rssi_min, rssi_min = dm->rssi_min;
+	u4Byte			sat_status_patha, sat_status_pathb;
+	u1Byte			igi_restore = dig_t->cur_ig_value;
+	u1Byte			i, lna_sat_chk_cnt = dm->lna_sat_chk_cnt;
+	u4Byte			lna_sat_cnt_thd = 0;
+	u1Byte			agc_tab;
+	u4Byte			max_check_time = 0;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __FUNCTION__);
+
+	if (!(dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"support ability is disabled, return.\n");
+		return;
+	}
+
+	if (dm->is_disable_lna_sat_chk) {
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"is_disable_lna_sat_chk=%d, return.\n", dm->is_disable_lna_sat_chk);
+		return;
+	}
+
+	//func_start = ODM_GetBBReg(pDM_Odm, 0x560, bMaskDWord);
+
+	// move igi to target pin of rssi_min
+	if ((rssi_min == 0) || (rssi_min == 0xff)) {
+		// adapt agc table 0
+		phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		phydm_lna_sat_chk_init(dm);
+		return;
+	} else if (rssi_min % 2 != 0)
+		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI - 1;
+	else
+		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI;
+
+	if ((dm->lna_sat_chk_period_ms > 0) && (dm->lna_sat_chk_period_ms <= ONE_SEC_MS))
+		max_check_time = lna_sat_chk_cnt*(ONE_SEC_MS/(dm->lna_sat_chk_period_ms))*5;
+	else
+		max_check_time = lna_sat_chk_cnt * 5;
+
+	lna_sat_cnt_thd = (max_check_time * dm->lna_sat_chk_duty_cycle)/100;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		"check_time=%d, rssi_min=%d, igi_rssi_min=0x%x\nlna_sat_chk_cnt=%d, lna_sat_chk_period_ms=%d, max_check_time=%d, lna_sat_cnt_thd=%d\n",
+		lna_info->check_time,
+		rssi_min,
+		igi_rssi_min,
+		lna_sat_chk_cnt,
+		dm->lna_sat_chk_period_ms,
+		max_check_time,
+		lna_sat_cnt_thd);
+
+	odm_write_dig(dm, igi_rssi_min);
+
+	// adapt agc table 0 check saturation status
+	phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+	// open rf power detection ckt & set detection range
+	odm_set_rf_reg(dm, RF_PATH_A, 0x86, 0x1f, 0x10);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x86, 0x1f, 0x10);
+
+	// check saturation status
+	for (i = 0; i < lna_sat_chk_cnt; i++) {
+		sat_status_patha = odm_get_rf_reg(dm, RF_PATH_A, 0xae, 0xc0000);
+		sat_status_pathb = odm_get_rf_reg(dm, RF_PATH_B, 0xae, 0xc0000);
+		if (sat_status_patha != 0)
+			lna_info->sat_cnt_acc_patha++;
+		if (sat_status_pathb != 0)
+			lna_info->sat_cnt_acc_pathb++;
+
+		if ((lna_info->sat_cnt_acc_patha >= lna_sat_cnt_thd) ||
+			(lna_info->sat_cnt_acc_pathb >= lna_sat_cnt_thd)) {
+			lna_info->cur_sat_status = 1;
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"cur_sat_status=%d, check_time=%d\n",
+			lna_info->cur_sat_status,
+			lna_info->check_time);
+			break;
+		} else
+			lna_info->cur_sat_status = 0;
+	}
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		"cur_sat_status=%d, pre_sat_status=%d, sat_cnt_acc_patha=%d, sat_cnt_acc_pathb=%d\n",
+		lna_info->cur_sat_status,
+		lna_info->pre_sat_status,
+		lna_info->sat_cnt_acc_patha,
+		lna_info->sat_cnt_acc_pathb);
+
+	// agc table decision
+	if (lna_info->cur_sat_status) {
+		if (!dm->is_disable_gain_table_switch)
+			phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_2);
+		lna_info->check_time = 0;
+		lna_info->sat_cnt_acc_patha = 0;
+		lna_info->sat_cnt_acc_pathb = 0;
+		lna_info->pre_sat_status = lna_info->cur_sat_status;
+
+	} else if (lna_info->check_time <= (max_check_time - 1)) {
+		if (lna_info->pre_sat_status && (!dm->is_disable_gain_table_switch))
+			phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_2);
+		lna_info->check_time++;
+
+	} else if (lna_info->check_time == max_check_time) {
+		if (!dm->is_disable_gain_table_switch && (lna_info->pre_sat_status == 1))
+			phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		lna_info->check_time = 0;
+		lna_info->sat_cnt_acc_patha = 0;
+		lna_info->sat_cnt_acc_pathb = 0;
+		lna_info->pre_sat_status = lna_info->cur_sat_status;
+	}
+
+	agc_tab = phydm_get_ofdm_agc_tab(dm);
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "use AGC tab %d\n", agc_tab);
+	//func_end = ODM_GetBBReg(pDM_Odm, 0x560, bMaskDWord);
+
+	//PHYDM_DBG(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("function process time=%d\n",
+	//	func_end - func_start));
+
+	// restore previous igi
+	odm_write_dig(dm, igi_restore);
+	lna_info->cur_timer_check_cnt++;
+	odm_set_timer(dm, &lna_info->phydm_lna_sat_chk_timer, dm->lna_sat_chk_period_ms);
+}
+
+void
+phydm_lna_sat_chk_callback(
+	void		*dm_void
+
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __FUNCTION__);
+	phydm_lna_sat_chk(dm);
+}
+
+void
+phydm_lna_sat_chk_timers(
+	void		*dm_void,
+	u8			state
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	if (state == INIT_LNA_SAT_CHK_TIMMER) {
+		odm_initialize_timer(dm,
+				     &lna_info->phydm_lna_sat_chk_timer,
+				     (void *)phydm_lna_sat_chk_callback, NULL,
+				     "phydm_lna_sat_chk_timer");
+	} else if (state == CANCEL_LNA_SAT_CHK_TIMMER) {
+		odm_cancel_timer(dm, &lna_info->phydm_lna_sat_chk_timer);
+	} else if (state == RELEASE_LNA_SAT_CHK_TIMMER) {
+		odm_release_timer(dm, &lna_info->phydm_lna_sat_chk_timer);
+	}
+}
+
+void
+phydm_lna_sat_chk_watchdog(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_info_struct *lna_info = &dm->dm_lna_sat_info;
+
+	u1Byte rssi_min = dm->rssi_min;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __FUNCTION__);
+
+	if (!(dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"support ability is disabled, return.\n");
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "pre_timer_check_cnt=%d, cur_timer_check_cnt=%d\n",
+		lna_info->pre_timer_check_cnt,
+		lna_info->cur_timer_check_cnt);
+
+	if (dm->is_disable_lna_sat_chk) {
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"is_disable_lna_sat_chk=%d, return.\n", dm->is_disable_lna_sat_chk);
+		return;
+	}
+
+	if ((dm->support_ic_type & ODM_RTL8197F) == 0) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"SupportICType != ODM_RTL8197F, return.\n");
+		return;
+	}
+
+	if ((rssi_min == 0) || (rssi_min == 0xff)) {
+		// adapt agc table 0
+		phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			"rssi_min=%d, return.\n", rssi_min);
+		return;
+	}
+
+	if (lna_info->cur_timer_check_cnt == lna_info->pre_timer_check_cnt) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "Timer check fail, restart timer.\n");
+		phydm_lna_sat_chk(dm);
+	} else {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "Timer check pass.\n");
+	}
+	lna_info->pre_timer_check_cnt = lna_info->cur_timer_check_cnt;
+}
+#endif	/*#if (PHYDM_LNA_SAT_CHK_SUPPORT == 1)*/
+
+void
+phydm_dig_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct	*dig_t = &dm->dm_dig_table;
+	char		help[] = "-h";
+	char		monitor[] = "-m";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+
+	if ((strcmp(input[1], help) == 0))
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{0} fa[0] fa[1] fa[2]\n");
+	else if ((strcmp(input[1], monitor) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Read DIG fa_th[0:2]= {%d, %d, %d}\n", 
+			       dig_t->fa_th[0], dig_t->fa_th[1],
+			       dig_t->fa_th[2]);
+
+	} else {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		for (i = 1; i < 10; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+		}
+
+		if (var1[0] == 0) {
+			dig_t->is_dbg_fa_th = true;
+			dig_t->fa_th[0] =  (u16)var1[1];
+			dig_t->fa_th[1] =  (u16)var1[2];
+			dig_t->fa_th[2] =  (u16)var1[3];
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "Set DIG fa_th[0:2]= {%d, %d, %d}\n", 
+				       dig_t->fa_th[0], dig_t->fa_th[1],
+				       dig_t->fa_th[2]);
+		} else
+			dig_t->is_dbg_fa_th = false;
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.h
index 7e2b13bbff66..733cf3832bb1 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dig.h
@@ -1,327 +1,364 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMDIG_H__
-#define    __PHYDMDIG_H__
-
-#define DIG_VERSION	"1.8"	/*2015.07.01*/
-
-/* Pause DIG & CCKPD */
-#define		DM_DIG_MAX_PAUSE_TYPE		0x7
-
-typedef struct _Dynamic_Initial_Gain_Threshold_
-{
-	BOOLEAN		bStopDIG;		// for debug
-	BOOLEAN		bIgnoreDIG;
-	BOOLEAN		bPSDInProgress;
-
-	u1Byte		Dig_Enable_Flag;
-	u1Byte		Dig_Ext_Port_Stage;
-	
-	int		   	RssiLowThresh;
-	int		    	RssiHighThresh;
-
-	u4Byte		FALowThresh;
-	u4Byte		FAHighThresh;
-
-	u1Byte		CurSTAConnectState;
-	u1Byte		PreSTAConnectState;
-	u1Byte		CurMultiSTAConnectState;
-
-	u1Byte		PreIGValue;
-	u1Byte		CurIGValue;
-	u1Byte		BackupIGValue;		//MP DIG
-	u1Byte		BT30_CurIGI;
-	u1Byte		IGIBackup;
-
-	s1Byte		BackoffVal;
-	s1Byte		BackoffVal_range_max;
-	s1Byte		BackoffVal_range_min;
-	u1Byte		rx_gain_range_max;
-	u1Byte		rx_gain_range_min;
-	u1Byte		Rssi_val_min;
-
-	u1Byte		PreCCK_CCAThres;
-	u1Byte		CurCCK_CCAThres;
-	u1Byte		PreCCKPDState;
-	u1Byte		CurCCKPDState;
-	u1Byte		CCKPDBackup;
-	u1Byte		pause_cckpd_level;
-	u1Byte		pause_cckpd_value[DM_DIG_MAX_PAUSE_TYPE + 1];
-
-	u1Byte		LargeFAHit;
-	u1Byte		ForbiddenIGI;
-	u4Byte		Recover_cnt;
-
-	u1Byte		DIG_Dynamic_MIN_0;
-	u1Byte		DIG_Dynamic_MIN_1;
-	BOOLEAN		bMediaConnect_0;
-	BOOLEAN		bMediaConnect_1;
-
-	u4Byte		AntDiv_RSSI_max;
-	u4Byte		RSSI_max;
-
-	u1Byte		*bP2PInProcess;
-
-	u1Byte		pause_dig_level;
-	u1Byte		pause_dig_value[DM_DIG_MAX_PAUSE_TYPE + 1];
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	BOOLEAN		bTpTarget;
-	BOOLEAN		bNoiseEst;
-	u4Byte		TpTrainTH_min;
-	u1Byte		IGIOffset_A;
-	u1Byte		IGIOffset_B;
-#endif
-}DIG_T,*pDIG_T;
-
-typedef struct _FALSE_ALARM_STATISTICS{
-	u4Byte	Cnt_Parity_Fail;
-	u4Byte	Cnt_Rate_Illegal;
-	u4Byte	Cnt_Crc8_fail;
-	u4Byte	Cnt_Mcs_fail;
-	u4Byte	Cnt_Ofdm_fail;
-	u4Byte	Cnt_Ofdm_fail_pre;	//For RTL8881A
-	u4Byte	Cnt_Cck_fail;
-	u4Byte	Cnt_all;
-	u4Byte	Cnt_Fast_Fsync;
-	u4Byte	Cnt_SB_Search_fail;
-	u4Byte	Cnt_OFDM_CCA;
-	u4Byte	Cnt_CCK_CCA;
-	u4Byte	Cnt_CCA_all;
-	u4Byte	Cnt_BW_USC;	//Gary
-	u4Byte	Cnt_BW_LSC;	//Gary
-}FALSE_ALARM_STATISTICS, *PFALSE_ALARM_STATISTICS;
-
-typedef enum tag_Dynamic_Init_Gain_Operation_Type_Definition
-{
-	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
-}DM_DIG_OP_E;
-
-/*
-typedef enum tag_CCK_Packet_Detection_Threshold_Type_Definition
-{
-	CCK_PD_STAGE_LowRssi = 0,
-	CCK_PD_STAGE_HighRssi = 1,
-	CCK_PD_STAGE_MAX = 3,
-}DM_CCK_PDTH_E;
-
-typedef enum tag_DIG_EXT_PORT_ALGO_Definition
-{
-	DIG_EXT_PORT_STAGE_0 = 0,
-	DIG_EXT_PORT_STAGE_1 = 1,
-	DIG_EXT_PORT_STAGE_2 = 2,
-	DIG_EXT_PORT_STAGE_3 = 3,
-	DIG_EXT_PORT_STAGE_MAX = 4,
-}DM_DIG_EXT_PORT_ALG_E;
-
-typedef enum tag_DIG_Connect_Definition
-{
-	DIG_STA_DISCONNECT = 0,	
-	DIG_STA_CONNECT = 1,
-	DIG_STA_BEFORE_CONNECT = 2,
-	DIG_MultiSTA_DISCONNECT = 3,
-	DIG_MultiSTA_CONNECT = 4,
-	DIG_CONNECT_MAX
-}DM_DIG_CONNECT_E;
-
-
-#define DM_MultiSTA_InitGainChangeNotify(Event) {DM_DigTable.CurMultiSTAConnectState = Event;}
-
-#define DM_MultiSTA_InitGainChangeNotify_CONNECT(_ADAPTER)	\
-	DM_MultiSTA_InitGainChangeNotify(DIG_MultiSTA_CONNECT)
-
-#define DM_MultiSTA_InitGainChangeNotify_DISCONNECT(_ADAPTER)	\
-	DM_MultiSTA_InitGainChangeNotify(DIG_MultiSTA_DISCONNECT)
-*/
-
-typedef enum tag_PHYDM_Pause_Type {
-	PHYDM_PAUSE = BIT0,
-	PHYDM_RESUME = BIT1
-} PHYDM_PAUSE_TYPE;
-
-typedef enum tag_PHYDM_Pause_Level {
-/* number of pause level can't exceed DM_DIG_MAX_PAUSE_TYPE */
-	PHYDM_PAUSE_LEVEL_0 = 0,
-	PHYDM_PAUSE_LEVEL_1 = 1,
-	PHYDM_PAUSE_LEVEL_2 = 2,
-	PHYDM_PAUSE_LEVEL_3 = 3,
-	PHYDM_PAUSE_LEVEL_4 = 4,
-	PHYDM_PAUSE_LEVEL_5 = 5,
-	PHYDM_PAUSE_LEVEL_6 = 6,
-	PHYDM_PAUSE_LEVEL_7 = DM_DIG_MAX_PAUSE_TYPE		/* maximum level */
-} PHYDM_PAUSE_LEVEL;
-
-
-#define		DM_DIG_THRESH_HIGH			40
-#define		DM_DIG_THRESH_LOW			35
-
-#define		DM_FALSEALARM_THRESH_LOW	400
-#define		DM_FALSEALARM_THRESH_HIGH	1000
-
-#define		DM_DIG_MAX_NIC				0x3e
-#define		DM_DIG_MIN_NIC				0x1e //0x22//0x1c
-#define		DM_DIG_MAX_OF_MIN_NIC		0x3e
-
-#define		DM_DIG_MAX_AP					0x3e
-#define		DM_DIG_MIN_AP					0x1c
-#define		DM_DIG_MAX_OF_MIN			0x2A	//0x32
-#define		DM_DIG_MIN_AP_DFS				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
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-#define		DM_DIG_MAX_AP_COVERAGR		0x26
-#define		DM_DIG_MIN_AP_COVERAGE		0x1c
-#define		DM_DIG_MAX_OF_MIN_COVERAGE	0x22
-
-#define		DM_DIG_TP_Target_TH0			500
-#define		DM_DIG_TP_Target_TH1			1000
-#define		DM_DIG_TP_Training_Period		10
-#endif
-
-//vivi 92c&92d has different definition, 20110504
-//this is for 92c
-#if (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	#ifdef CONFIG_SPECIAL_SETTING_FOR_FUNAI_TV
-	#define		DM_DIG_FA_TH0				0x80//0x20
-	#else
-	#define		DM_DIG_FA_TH0				0x200//0x20
-	#endif
-#else
-	#define		DM_DIG_FA_TH0				0x200//0x20
-#endif
-
-#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
-
-#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
-
-VOID
-ODM_ChangeDynamicInitGainThresh(
-	IN		PVOID					pDM_VOID,
-	IN		u4Byte  					DM_Type,
-	IN		u4Byte 					DM_Value
-	);
-
-VOID
-ODM_Write_DIG(
-	IN		PVOID					pDM_VOID, 	
-	IN		u1Byte					CurrentIGI
-	);
-
-VOID
-odm_PauseDIG(
-	IN		PVOID					pDM_VOID,
-	IN		PHYDM_PAUSE_TYPE		PauseType,
-	IN		PHYDM_PAUSE_LEVEL		pause_level,
-	IN		u1Byte					IGIValue
-	);
-
-VOID
-odm_DIGInit(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID	
-odm_DIG(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-odm_DIGbyRSSI_LPS(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID 
-odm_FalseAlarmCounterStatistics(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-odm_PauseCCKPacketDetection(
-	IN		PVOID					pDM_VOID,
-	IN		PHYDM_PAUSE_TYPE		PauseType,
-	IN		PHYDM_PAUSE_LEVEL		pause_level,
-	IN		u1Byte					CCKPDThreshold
-	);
-
-VOID 
-odm_CCKPacketDetectionThresh(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID 
-ODM_Write_CCK_CCA_Thres(
-	IN		PVOID					pDM_VOID, 
-	IN		u1Byte					CurCCK_CCAThres
-	);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-odm_MPT_DIGCallback(
-	PRT_TIMER						pTimer
-);
-
-VOID
-odm_MPT_DIGWorkItemCallback(
-    IN 		PVOID            			pContext
-    );
-
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-VOID
-odm_MPT_DIGCallback(
-	IN		PVOID					pDM_VOID
-);
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE != ODM_CE)
-VOID
-ODM_MPT_DIG(
-	IN		PVOID					pDM_VOID
-);
-#endif
-
-
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMDIG_H__
+#define	__PHYDMDIG_H__
+
+/*#define DIG_VERSION	"1.4"*/		/* 2017.04.18  YuChen. refine DIG code structure*/
+/*#define DIG_VERSION	"2.0"*/		/* 2017.05.09  Dino. Move CCKPD to new files*/
+/*#define DIG_VERSION	"2.1"*/		/* 2017.06.01  YuChen. Refine DFS condition*/
+#define DIG_VERSION	"2.2"		/* 2017.06.13  YuChen. Remove MP dig*/
+
+#define DIG_HW		0
+
+/*--------------------Define ---------------------------------------*/
+
+/*=== [DIG Boundary] ========================================*/
+/*DIG coverage mode*/
+#define		DIG_MAX_COVERAGR				0x26
+#define		DIG_MIN_COVERAGE				0x1c
+#define		DIG_MAX_OF_MIN_COVERAGE		0x22
+/*DIG performance mode*/
+#if (DIG_HW == 1)
+#define		DIG_MAX_BALANCE_MODE		0x32
+#else
+#define		DIG_MAX_BALANCE_MODE		0x3e
+#endif
+#define		DIG_MAX_OF_MIN_BALANCE_MODE		0x2a
+
+#define		DIG_MAX_PERFORMANCE_MODE		0x5a
+#define		DIG_MAX_OF_MIN_PERFORMANCE_MODE		0x40	/*from 3E -> 2A, refine by YuChen 2017/04/18*/
+
+#define		DIG_MIN_PERFORMANCE			0x20
+
+/*DIG DFS function*/
+#define		DIG_MAX_DFS					0x28
+#define		DIG_MIN_DFS					0x20
+
+/*DIG LPS function*/
+#define		DIG_MAX_LPS					0x3e
+#define		DIG_MIN_LPS					0x20
+
+/*=== [DIG FA Threshold] ======================================*/
+
+/*Normal*/
+#define		DM_DIG_FA_TH0					500
+#define		DM_DIG_FA_TH1					750
+
+/*LPS*/
+#define		DM_DIG_FA_TH0_LPS			4	/* -> 4 lps */
+#define		DM_DIG_FA_TH1_LPS			15	/* -> 15 lps */
+#define		DM_DIG_FA_TH2_LPS			30	/* -> 30 lps */
+
+#define		RSSI_OFFSET_DIG_LPS			5
+
+/*LNA saturation check*/
+#define OFDM_AGC_TAB_0			0
+#define	OFDM_AGC_TAB_2			2
+#define	DIFF_RSSI_TO_IGI		10
+#define	ONE_SEC_MS				1000
+
+/*--------------------Enum-----------------------------------*/
+enum dig_goupcheck_level {
+	DIG_GOUPCHECK_LEVEL_0,
+	DIG_GOUPCHECK_LEVEL_1,
+	DIG_GOUPCHECK_LEVEL_2
+};
+
+enum phydm_dig_mode {
+	PHYDM_DIG_PERFORAMNCE_MODE	= 0,
+	PHYDM_DIG_COVERAGE_MODE	= 1,
+};
+
+enum lna_sat_timer_state {
+	INIT_LNA_SAT_CHK_TIMMER,
+	CANCEL_LNA_SAT_CHK_TIMMER,
+	RELEASE_LNA_SAT_CHK_TIMMER
+};
+/*--------------------Define Struct-----------------------------------*/
+
+struct phydm_dig_struct {
+	boolean	is_ignore_dig; /*for old pause function*/
+	boolean	is_dbg_fa_th;
+	u8		dig_mode_decision;
+	u8		cur_ig_value;
+	u8		rvrt_val;
+	u8		igi_backup;
+	u8		rx_gain_range_max;	/*dig_dynamic_max*/
+	u8		rx_gain_range_min;	/*dig_dynamic_min*/
+	u8		dm_dig_max;			/*Absolutly upper bound*/
+	u8		dm_dig_min;			/*Absolutly lower bound*/
+	u8		dig_max_of_min;		/*Absolutly max of min*/
+	boolean	is_media_connect;
+	u32		ant_div_rssi_max;
+	u8		*is_p2p_in_process;
+	u8		pause_lv_bitmap; /*bit-map of pause level*/
+	u8		pause_dig_value[PHYDM_PAUSE_MAX_NUM];
+	enum dig_goupcheck_level		dig_go_up_check_level;
+	u8		aaa_default;
+	u8		a0a_default;
+	u16		fa_th[3];
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	u8		rf_gain_idx;
+	u8		agc_table_idx;
+	u8		big_jump_lmt[16];
+	u8		enable_adjust_big_jump:1;
+	u8		big_jump_step1:3;
+	u8		big_jump_step2:2;
+	u8		big_jump_step3:2;
+#endif
+	u8		dig_upcheck_initial_value;
+	u8		dig_level0_ratio_reciprocal;
+	u8		dig_level1_ratio_reciprocal;
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	u8		cur_ig_value_tdma;
+	u8		low_ig_value;
+	u8		tdma_dig_state;	/*To distinguish which state is now.(L-sate or H-state)*/
+	u8		tdma_dig_cnt;	/*for phydm_tdma_dig_timer_check use*/
+	u8		pre_tdma_dig_cnt;
+	u8		sec_factor;
+	u32		cur_timestamp;
+	u32		pre_timestamp;
+	u32		fa_start_timestamp;
+	u32		fa_end_timestamp;
+	u32		fa_acc_1sec_timestamp;
+#endif	
+};
+
+struct phydm_fa_struct {
+	u32		cnt_parity_fail;
+	u32		cnt_rate_illegal;
+	u32		cnt_crc8_fail;
+	u32		cnt_crc8_fail_vht;
+	u32		cnt_mcs_fail;
+	u32		cnt_mcs_fail_vht;
+	u32		cnt_ofdm_fail;
+	u32		cnt_ofdm_fail_pre;	/* For RTL8881A */
+	u32		cnt_cck_fail;
+	u32		cnt_all;
+	u32		cnt_all_pre;
+	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;
+	u32		cnt_bw_lsc;
+	u32		cnt_cck_crc32_error;
+	u32		cnt_cck_crc32_ok;
+	u32		cnt_ofdm_crc32_error;
+	u32		cnt_ofdm_crc32_ok;
+	u32		cnt_ht_crc32_error;
+	u32		cnt_ht_crc32_ok;
+	u32		cnt_ht_crc32_error_agg;
+	u32		cnt_ht_crc32_ok_agg;
+	u32		cnt_vht_crc32_error;
+	u32		cnt_vht_crc32_ok;
+	u32		cnt_crc32_error_all;
+	u32		cnt_crc32_ok_all;
+	u32		time_fa_all;
+	boolean	cck_block_enable;
+	boolean	ofdm_block_enable;
+	u32		dbg_port0;
+	boolean	edcca_flag;
+};
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+struct phydm_fa_acc_struct {
+	u32		cnt_parity_fail;
+	u32		cnt_rate_illegal;
+	u32		cnt_crc8_fail;
+	u32		cnt_mcs_fail;
+	u32		cnt_ofdm_fail;
+	u32		cnt_ofdm_fail_pre;	/*For RTL8881A*/
+	u32		cnt_cck_fail;
+	u32		cnt_all;
+	u32		cnt_all_pre;
+	u32		cnt_fast_fsync;
+	u32		cnt_sb_search_fail;
+	u32		cnt_ofdm_cca;
+	u32		cnt_cck_cca;
+	u32		cnt_cca_all;
+	u32		cnt_cck_crc32_error;
+	u32		cnt_cck_crc32_ok;
+	u32		cnt_ofdm_crc32_error;
+	u32		cnt_ofdm_crc32_ok;
+	u32		cnt_ht_crc32_error;
+	u32		cnt_ht_crc32_ok;
+	u32		cnt_vht_crc32_error;
+	u32		cnt_vht_crc32_ok;
+	u32		cnt_crc32_error_all;
+	u32		cnt_crc32_ok_all;
+	u32		cnt_all_1sec;
+	u32		cnt_cca_all_1sec;
+	u32		cnt_cck_fail_1sec;
+};
+
+#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+struct phydm_lna_sat_info_struct {
+	u32			sat_cnt_acc_patha;
+	u32			sat_cnt_acc_pathb;
+	u32			check_time;
+	boolean		pre_sat_status;
+	boolean		cur_sat_status;
+	struct phydm_timer_list	phydm_lna_sat_chk_timer;
+	u32			cur_timer_check_cnt;
+	u32			pre_timer_check_cnt;
+};
+
+/*--------------------Function declaration-----------------------------*/
+void
+odm_write_dig(
+	void					*dm_void,
+	u8					current_igi
+);
+
+void
+phydm_set_dig_val(
+	void			*dm_void,
+	u32			*val_buf,
+	u8			val_len
+);
+
+void
+odm_pause_dig(
+	void					*dm_void,
+	enum phydm_pause_type		pause_type,
+	enum phydm_pause_level		pause_level,
+	u8					igi_value
+);
+
+void
+phydm_dig_init(
+	void					*dm_void
+);
+
+void
+phydm_dig(
+	void					*dm_void
+);
+
+void
+phydm_dig_lps_32k(
+	void		*dm_void
+);
+
+void
+phydm_dig_by_rssi_lps(
+	void					*dm_void
+);
+
+void
+odm_false_alarm_counter_statistics(
+	void					*dm_void
+);
+
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+void
+phydm_set_tdma_dig_timer(
+	void					*dm_void
+);
+
+void
+phydm_tdma_dig_timer_check(
+	void					*dm_void
+);
+
+void
+phydm_tdma_dig(
+	void		*dm_void
+);
+
+void
+phydm_tdma_false_alarm_counter_check(
+	void		*dm_void
+);
+
+void
+phydm_tdma_dig_add_interrupt_mask_handler(
+	void		*dm_void
+);
+
+void
+phydm_false_alarm_counter_reset(
+	void		*dm_void
+);
+
+void
+phydm_false_alarm_counter_acc(
+	void		*dm_void,
+	boolean		rssi_dump_en
+	);
+
+void
+phydm_false_alarm_counter_acc_reset(
+	void		*dm_void
+	);
+
+#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+void
+phydm_set_ofdm_agc_tab(
+	void	*dm_void,
+	u8		tab_sel
+);
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+u8
+phydm_get_ofdm_agc_tab(
+	void	*dm_void
+);
+
+void
+phydm_lna_sat_chk(
+	void		*dm_void
+);
+
+void
+phydm_lna_sat_chk_timers(
+	void		*dm_void,
+	u8			state
+);
+
+void
+phydm_lna_sat_chk_watchdog(
+	void		*dm_void
+);
+
+#endif	/*#if (PHYDM_LNA_SAT_CHK_SUPPORT == 1)*/
+
+void
+phydm_dig_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamic_rx_path.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamic_rx_path.c
new file mode 100644
index 000000000000..193d0205eea1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamic_rx_path.c
@@ -0,0 +1,353 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+
+void
+phydm_process_phy_status_for_dynamic_rx_path(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct		*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct		*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(dm->dm_drp_table);
+}
+
+void
+phydm_drp_get_statistic(
+	void			*dm_void
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_						*p_dm_drp_table = &(dm->dm_drp_table);
+	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+
+	odm_false_alarm_counter_statistics(dm);
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all);
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all);
+}
+
+void
+phydm_dynamic_rx_path(
+	void			*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(dm->dm_drp_table);
+	u8		training_set_timmer_en;
+	u8		curr_drp_state;
+	u32		rx_ok_cal;
+	u32		RSSI = 0;
+	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_RX_PATH)) {
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Return Init]   Not Support Dynamic RX PAth\n");
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "Current drp_state = ((%d))\n", p_dm_drp_table->drp_state);
+
+	curr_drp_state = p_dm_drp_table->drp_state;
+
+	if (p_dm_drp_table->drp_state == DRP_INIT_STATE) {
+
+		phydm_drp_get_statistic(dm);
+
+		if (false_alm_cnt->cnt_crc32_ok_all > 20) {	/*Signal + Interference*/
+			PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Stop DRP Training] cnt_crc32_ok_all = ((%d))\n", false_alm_cnt->cnt_crc32_ok_all);
+			p_dm_drp_table->drp_state  = DRP_INIT_STATE;
+			training_set_timmer_en = false;
+		} else {/*Interference only*/
+			PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Start DRP Training] cnt_crc32_ok_all = ((%d))\n", false_alm_cnt->cnt_crc32_ok_all);
+			p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_0;
+			p_dm_drp_table->curr_rx_path = BB_PATH_AB;
+			training_set_timmer_en = true;
+		}
+
+	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_0) {
+
+		phydm_drp_get_statistic(dm);
+
+		p_dm_drp_table->curr_cca_all_cnt_0 = false_alm_cnt->cnt_cca_all;
+		p_dm_drp_table->curr_fa_all_cnt_0 = false_alm_cnt->cnt_all;
+
+		p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_1;
+		p_dm_drp_table->curr_rx_path = BB_PATH_B;
+		training_set_timmer_en = true;
+
+	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_1) {
+
+		phydm_drp_get_statistic(dm);
+
+		p_dm_drp_table->curr_cca_all_cnt_1 = false_alm_cnt->cnt_cca_all;
+		p_dm_drp_table->curr_fa_all_cnt_1 = false_alm_cnt->cnt_all;
+
+#if 1
+		p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
+#else
+
+		if (*(dm->mp_mode)) {
+			rx_ok_cal = dm->phy_dbg_info.num_qry_phy_status_cck + dm->phy_dbg_info.num_qry_phy_status_ofdm;
+			RSSI = (rx_ok_cal != 0) ? dm->rx_pwdb_ave / rx_ok_cal : 0;
+			PHYDM_DBG(dm, DBG_DYN_RX_PATH, "MP RSSI = ((%d))\n", RSSI);
+		}
+
+		if (RSSI > p_dm_drp_table->rssi_threshold)
+
+			p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
+
+		else  {
+
+			p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_2;
+			p_dm_drp_table->curr_rx_path = BB_PATH_A;
+			training_set_timmer_en = true;
+		}
+#endif
+	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_2) {
+
+		phydm_drp_get_statistic(dm);
+
+		p_dm_drp_table->curr_cca_all_cnt_2 = false_alm_cnt->cnt_cca_all;
+		p_dm_drp_table->curr_fa_all_cnt_2 = false_alm_cnt->cnt_all;
+		p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
+	}
+
+	if (p_dm_drp_table->drp_state == DRP_DECISION_STATE) {
+
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "Current drp_state = ((%d))\n", p_dm_drp_table->drp_state);
+
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[0] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_0, p_dm_drp_table->curr_fa_all_cnt_0);
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[1] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_1, p_dm_drp_table->curr_fa_all_cnt_1);
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[2] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_2, p_dm_drp_table->curr_fa_all_cnt_2);
+
+		if (p_dm_drp_table->curr_fa_all_cnt_1 < p_dm_drp_table->curr_fa_all_cnt_0) {
+
+			if ((p_dm_drp_table->curr_fa_all_cnt_0 - p_dm_drp_table->curr_fa_all_cnt_1) > p_dm_drp_table->fa_diff_threshold)
+				p_dm_drp_table->curr_rx_path = BB_PATH_B;
+			else
+				p_dm_drp_table->curr_rx_path = BB_PATH_AB;
+		} else
+			p_dm_drp_table->curr_rx_path = BB_PATH_AB;
+
+		phydm_config_ofdm_rx_path(dm, p_dm_drp_table->curr_rx_path);
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Training Result]  curr_rx_path = ((%s%s)),\n",
+			((p_dm_drp_table->curr_rx_path & BB_PATH_A)  ? "A"  : " "), ((p_dm_drp_table->curr_rx_path & BB_PATH_B)  ? "B"  : " "));
+
+		p_dm_drp_table->drp_state = DRP_INIT_STATE;
+		training_set_timmer_en = false;
+	}
+
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "DRP_state: ((%d)) -> ((%d))\n", curr_drp_state, p_dm_drp_table->drp_state);
+
+	if (training_set_timmer_en) {
+
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Training en]  curr_rx_path = ((%s%s)), training_time = ((%d ms))\n",
+			((p_dm_drp_table->curr_rx_path & BB_PATH_A)  ? "A"  : " "), ((p_dm_drp_table->curr_rx_path & BB_PATH_B)  ? "B"  : " "), p_dm_drp_table->training_time);
+
+		phydm_config_ofdm_rx_path(dm, p_dm_drp_table->curr_rx_path);
+		odm_set_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer), p_dm_drp_table->training_time); /*ms*/
+	} else
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "DRP period end\n\n", curr_drp_state, p_dm_drp_table->drp_state);
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_dynamic_rx_path_callback(
+	struct phydm_timer_list		*timer
+)
+{
+	void		*adapter = (void *)timer->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &(hal_data->DM_OutSrc);
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table = &(dm->dm_drp_table);
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&(p_dm_drp_table->phydm_dynamic_rx_path_workitem));
+#else
+	{
+		/* dbg_print("phydm_dynamic_rx_path\n"); */
+		phydm_dynamic_rx_path(dm);
+	}
+#endif
+#else
+	odm_schedule_work_item(&(p_dm_drp_table->phydm_dynamic_rx_path_workitem));
+#endif
+}
+
+void
+phydm_dynamic_rx_path_workitem_callback(
+	void		*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &(hal_data->DM_OutSrc);
+
+	/* dbg_print("phydm_dynamic_rx_path\n"); */
+	phydm_dynamic_rx_path(dm);
+}
+#else if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+phydm_dynamic_rx_path_callback(
+	void *function_context
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)function_context;
+	void	*padapter = dm->adapter;
+
+	if (*(dm->is_net_closed) == true)
+		return;
+
+#if 0 /* Can't do I/O in timer callback*/
+	odm_s0s1_sw_ant_div(dm, SWAW_STEP_DETERMINE);
+#else
+	/*rtw_run_in_thread_cmd(padapter, odm_sw_antdiv_workitem_callback, padapter);*/
+#endif
+}
+
+#endif
+
+void
+phydm_dynamic_rx_path_timers(
+	void		*dm_void,
+	u8		state
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table	= &(dm->dm_drp_table);
+
+	if (state == INIT_DRP_TIMMER) {
+
+		odm_initialize_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer),
+			(void *)phydm_dynamic_rx_path_callback, NULL, "phydm_sw_antenna_switch_timer");
+	} else if (state == CANCEL_DRP_TIMMER)
+
+		odm_cancel_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer));
+
+	else if (state == RELEASE_DRP_TIMMER)
+
+		odm_release_timer(dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer));
+
+}
+
+void
+phydm_dynamic_rx_path_init(
+	void			*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(dm->dm_drp_table);
+	boolean			ret_value;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_RX_PATH)) {
+		PHYDM_DBG(dm, DBG_DYN_RX_PATH, "[Return]   Not Support Dynamic RX PAth\n");
+		return;
+	}
+	PHYDM_DBG(dm, DBG_DYN_RX_PATH, "phydm_dynamic_rx_path_init\n");
+
+	p_dm_drp_table->drp_state = DRP_INIT_STATE;
+	p_dm_drp_table->rssi_threshold = DRP_RSSI_TH;
+	p_dm_drp_table->fa_count_thresold = 50;
+	p_dm_drp_table->fa_diff_threshold = 50;
+	p_dm_drp_table->training_time = 100; /*ms*/
+	p_dm_drp_table->drp_skip_counter = 0;
+	p_dm_drp_table->drp_period  = 0;
+	p_dm_drp_table->drp_init_finished = true;
+
+	ret_value = phydm_api_trx_mode(dm, (enum bb_path)BB_PATH_AB, (enum bb_path)BB_PATH_AB, true);
+
+}
+
+void
+phydm_drp_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table = &(dm->dm_drp_table);
+
+	switch (dm_value[0])	{
+
+	case DRP_TRAINING_TIME:
+		p_dm_drp_table->training_time = (u16)dm_value[1];
+		break;
+	case DRP_TRAINING_PERIOD:
+		p_dm_drp_table->drp_period = (u8)dm_value[1];
+		break;
+	case DRP_RSSI_THRESHOLD:
+		p_dm_drp_table->rssi_threshold = (u8)dm_value[1];
+		break;
+	case DRP_FA_THRESHOLD:
+		p_dm_drp_table->fa_count_thresold = dm_value[1];
+		break;
+	case DRP_FA_DIFF_THRESHOLD:
+		p_dm_drp_table->fa_diff_threshold = dm_value[1];
+		break;
+	default:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[DRP] unknown command\n");
+		break;
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_dynamic_rx_path_caller(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table	= &(dm->dm_drp_table);
+
+	if (p_dm_drp_table->drp_skip_counter <  p_dm_drp_table->drp_period)
+		p_dm_drp_table->drp_skip_counter++;
+	else
+		p_dm_drp_table->drp_skip_counter = 0;
+
+	if (p_dm_drp_table->drp_skip_counter != 0)
+		return;
+
+	if (p_dm_drp_table->drp_init_finished != true)
+		return;
+
+	phydm_dynamic_rx_path(dm);
+
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamic_rx_path.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamic_rx_path.h
new file mode 100644
index 000000000000..a86589d6a762
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamic_rx_path.h
@@ -0,0 +1,152 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMDYMICRXPATH_H__
+#define    __PHYDMDYMICRXPATH_H__
+
+#define DYNAMIC_RX_PATH_VERSION	"1.0"  /*2016.07.15  Dino */
+
+
+#define	DRP_RSSI_TH	35
+
+#define INIT_DRP_TIMMER		0
+#define CANCEL_DRP_TIMMER		1
+#define RELEASE_DRP_TIMMER		2
+
+#if (RTL8822B_SUPPORT == 1)
+struct drp_rtl8822b_struct {
+	enum bb_path	path_judge;
+	u16	path_a_cck_fa;
+	u16	path_b_cck_fa;
+	
+};
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+
+enum drp_state {
+	DRP_INIT_STATE				= 0,
+	DRP_TRAINING_STATE_0	= 1,
+	DRP_TRAINING_STATE_1		= 2,
+	DRP_TRAINING_STATE_2		= 3,
+	DRP_DECISION_STATE		= 4
+};
+
+enum adjustable_value {
+	DRP_TRAINING_TIME		= 0,
+	DRP_TRAINING_PERIOD	= 1,
+	DRP_RSSI_THRESHOLD	= 2,
+	DRP_FA_THRESHOLD		= 3,
+	DRP_FA_DIFF_THRESHOLD = 4
+};
+
+struct _DYNAMIC_RX_PATH_ {
+	u8			curr_rx_path;
+	u8			drp_state;
+	u16			training_time;
+	u8			rssi_threshold;
+	u32			fa_count_thresold;
+	u32			fa_diff_threshold;
+	u32			curr_cca_all_cnt_0;
+	u32			curr_fa_all_cnt_0;
+	u32			curr_cca_all_cnt_1;
+	u32			curr_fa_all_cnt_1;
+	u32			curr_cca_all_cnt_2;
+	u32			curr_fa_all_cnt_2;
+	u8			drp_skip_counter;
+	u8			drp_period;
+	u8			drp_init_finished;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	phydm_dynamic_rx_path_workitem;
+#endif
+#endif
+	struct phydm_timer_list		phydm_dynamic_rx_path_timer;
+
+};
+
+
+
+void
+phydm_process_phy_status_for_dynamic_rx_path(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+);
+
+void
+phydm_dynamic_rx_path(
+	void			*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_dynamic_rx_path_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+phydm_dynamic_rx_path_workitem_callback(
+	void		*context
+);
+
+#else if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+void
+phydm_dynamic_rx_path_callback(
+	void *function_context
+);
+
+#endif
+
+void
+phydm_dynamic_rx_path_timers(
+	void		*dm_void,
+	u8		state
+);
+
+void
+phydm_dynamic_rx_path_init(
+	void			*dm_void
+);
+
+void
+phydm_drp_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+void
+phydm_dynamic_rx_path_caller(
+	void			*dm_void
+);
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamicbbpowersaving.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamicbbpowersaving.c
deleted file mode 100644
index 23fc0022aeca..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamicbbpowersaving.c
+++ /dev/null
@@ -1,219 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-VOID 
-odm_DynamicBBPowerSavingInit(
-	IN		PVOID					pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPS_T	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_DynamicBBPowerSaving(
-	IN		PVOID					pDM_VOID
-	)
-{	
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-
-	if (pDM_Odm->SupportICType != ODM_RTL8723A)
-		return;
-	if(!(pDM_Odm->SupportAbility & ODM_BB_PWR_SAVE))
-		return;
-	if(!(pDM_Odm->SupportPlatform & (ODM_WIN|ODM_CE)))
-		return;
-	
-	//1 2.Power Saving for 92C
-	if((pDM_Odm->SupportICType == ODM_RTL8192C) &&(pDM_Odm->RFType == ODM_2T2R))
-	{
-		odm_1R_CCA(pDM_Odm);
-	}
-	
-	// 20100628 Joseph: Turn off BB power save for 88CE because it makesthroughput unstable.
-	// 20100831 Joseph: Turn ON BB power save again after modifying AGC delay from 900ns ot 600ns.
-	//1 3.Power Saving for 88C
-	else
-	{
-		ODM_RF_Saving(pDM_Odm, FALSE);
-	}
-#endif	// #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	
-}
-
-VOID
-odm_1R_CCA(
-	IN		PVOID					pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPS_T	pDM_PSTable = &pDM_Odm->DM_PSTable;
-
-	if(pDM_Odm->RSSI_Min!= 0xFF)
-	{
-		 
-		if(pDM_PSTable->PreCCAState == CCA_2R)
-		{
-			if(pDM_Odm->RSSI_Min >= 35)
-				pDM_PSTable->CurCCAState = CCA_1R;
-			else
-				pDM_PSTable->CurCCAState = CCA_2R;
-			
-		}
-		else{
-			if(pDM_Odm->RSSI_Min <= 30)
-				pDM_PSTable->CurCCAState = CCA_2R;
-			else
-				pDM_PSTable->CurCCAState = CCA_1R;
-		}
-	}
-	else{
-		pDM_PSTable->CurCCAState=CCA_MAX;
-	}
-	
-	if(pDM_PSTable->PreCCAState != pDM_PSTable->CurCCAState)
-	{
-		if(pDM_PSTable->CurCCAState == CCA_1R)
-		{
-			if(  pDM_Odm->RFType ==ODM_2T2R )
-			{
-				ODM_SetBBReg(pDM_Odm, 0xc04  , bMaskByte0, 0x13);
-				//PHY_SetBBReg(pAdapter, 0xe70, bMaskByte3, 0x20);
-			}
-			else
-			{
-				ODM_SetBBReg(pDM_Odm, 0xc04  , bMaskByte0, 0x23);
-				//PHY_SetBBReg(pAdapter, 0xe70, 0x7fc00000, 0x10c); // Set RegE70[30:22] = 9b'100001100
-			}
-		}
-		else
-		{
-			ODM_SetBBReg(pDM_Odm, 0xc04  , bMaskByte0, 0x33);
-			//PHY_SetBBReg(pAdapter,0xe70, bMaskByte3, 0x63);
-		}
-		pDM_PSTable->PreCCAState = pDM_PSTable->CurCCAState;
-	}
-}
-
-void
-ODM_RF_Saving(
-	IN		PVOID					pDM_VOID,
-	IN	u1Byte		bForceInNormal 
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-	pPS_T	pDM_PSTable = &pDM_Odm->DM_PSTable;
-	u1Byte	Rssi_Up_bound = 30 ;
-	u1Byte	Rssi_Low_bound = 25;
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if(pDM_Odm->PatchID == 40 ) //RT_CID_819x_FUNAI_TV
-	{
-		Rssi_Up_bound = 50 ;
-		Rssi_Low_bound = 45;
-	}
-#endif
-	if(pDM_PSTable->initialize == 0){
-		
-		pDM_PSTable->Reg874 = (ODM_GetBBReg(pDM_Odm, 0x874, bMaskDWord)&0x1CC000)>>14;
-		pDM_PSTable->RegC70 = (ODM_GetBBReg(pDM_Odm, 0xc70, bMaskDWord)&BIT3)>>3;
-		pDM_PSTable->Reg85C = (ODM_GetBBReg(pDM_Odm, 0x85c, bMaskDWord)&0xFF000000)>>24;
-		pDM_PSTable->RegA74 = (ODM_GetBBReg(pDM_Odm, 0xa74, bMaskDWord)&0xF000)>>12;
-		//Reg818 = PHY_QueryBBReg(pAdapter, 0x818, bMaskDWord);
-		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.
-			if(pDM_Odm->SupportICType == ODM_RTL8723A)
-			{
-				ODM_SetBBReg(pDM_Odm, 0x874  , BIT5, 0x1); //Reg874[5]=1b'1
-			}
-			ODM_SetBBReg(pDM_Odm, 0x874  , 0x1C0000, 0x2); //Reg874[20:18]=3'b010
-			ODM_SetBBReg(pDM_Odm, 0xc70, BIT3, 0); //RegC70[3]=1'b0
-			ODM_SetBBReg(pDM_Odm, 0x85c, 0xFF000000, 0x63); //Reg85C[31:24]=0x63
-			ODM_SetBBReg(pDM_Odm, 0x874, 0xC000, 0x2); //Reg874[15:14]=2'b10
-			ODM_SetBBReg(pDM_Odm, 0xa74, 0xF000, 0x3); //RegA75[7:4]=0x3
-			ODM_SetBBReg(pDM_Odm, 0x818, BIT28, 0x0); //Reg818[28]=1'b0
-			ODM_SetBBReg(pDM_Odm, 0x818, BIT28, 0x1); //Reg818[28]=1'b1
-		}
-		else
-		{
-			ODM_SetBBReg(pDM_Odm, 0x874  , 0x1CC000, pDM_PSTable->Reg874); 
-			ODM_SetBBReg(pDM_Odm, 0xc70, BIT3, pDM_PSTable->RegC70); 
-			ODM_SetBBReg(pDM_Odm, 0x85c, 0xFF000000, pDM_PSTable->Reg85C);
-			ODM_SetBBReg(pDM_Odm, 0xa74, 0xF000, pDM_PSTable->RegA74); 
-			ODM_SetBBReg(pDM_Odm,0x818, BIT28, 0x0);  
-
-			if(pDM_Odm->SupportICType == ODM_RTL8723A)
-			{
-				ODM_SetBBReg(pDM_Odm,0x874  , BIT5, 0x0); //Reg874[5]=1b'0
-			}
-		}
-		pDM_PSTable->PreRFState =pDM_PSTable->CurRFState;
-	}
-#endif	
-}
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamicbbpowersaving.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamicbbpowersaving.h
deleted file mode 100644
index 0556e3f5da5e..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamicbbpowersaving.h
+++ /dev/null
@@ -1,63 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMDYNAMICBBPOWERSAVING_H__
-#define    __PHYDMDYNAMICBBPOWERSAVING_H__
-
-#define DYNAMIC_BBPWRSAV_VERSION	"1.0"
-
-typedef struct _Dynamic_Power_Saving_
-{
-	u1Byte		PreCCAState;
-	u1Byte		CurCCAState;
-
-	u1Byte		PreRFState;
-	u1Byte		CurRFState;
-
-	int		    Rssi_val_min;
-	
-	u1Byte		initialize;
-	u4Byte		Reg874,RegC70,Reg85C,RegA74;
-	
-}PS_T,*pPS_T;
-
-#define dm_RF_Saving	ODM_RF_Saving
-
-void ODM_RF_Saving(
-	IN		PVOID					pDM_VOID,
-	IN	u1Byte		bForceInNormal
-);
-
-VOID 
-odm_DynamicBBPowerSavingInit(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID 
-odm_DynamicBBPowerSaving(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-odm_1R_CCA(
-	IN		PVOID					pDM_VOID
-	);
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.c
index afb3be921f1a..b2cfde661a29 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.c
@@ -1,633 +1,713 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-VOID 
-odm_DynamicTxPowerInit(
-	IN		PVOID					pDM_VOID	
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO			pMgntInfo = &Adapter->MgntInfo;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-
-	#if DEV_BUS_TYPE==RT_USB_INTERFACE					
-	if(RT_GetInterfaceSelection(Adapter) == INTF_SEL1_USB_High_Power)
-	{
-		odm_DynamicTxPowerSavePowerIndex(pDM_Odm);
-		pMgntInfo->bDynamicTxPowerEnable = TRUE;
-	}		
-	else	
-	#else
-	//so 92c pci do not need dynamic tx power? vivi check it later
-	if(IS_HARDWARE_TYPE_8192D(Adapter))
-		pMgntInfo->bDynamicTxPowerEnable = TRUE;
-	else
-		pMgntInfo->bDynamicTxPowerEnable = FALSE;
-	#endif
-	
-
-	pHalData->LastDTPLvl = TxHighPwrLevel_Normal;
-	pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-
-
-#endif
-	
-}
-
-VOID
-odm_DynamicTxPowerSavePowerIndex(
-	IN		PVOID					pDM_VOID	
-	)
-{	
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-	u1Byte		index;
-	u4Byte		Power_Index_REG[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
-	
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);	
-	for(index = 0; index< 6; index++)
-		pHalData->PowerIndex_backup[index] = PlatformEFIORead1Byte(Adapter, Power_Index_REG[index]);
-	
-	
-#endif
-#endif
-}
-
-VOID
-odm_DynamicTxPowerRestorePowerIndex(
-	IN		PVOID					pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-	u1Byte			index;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u4Byte			Power_Index_REG[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	for(index = 0; index< 6; index++)
-		PlatformEFIOWrite1Byte(Adapter, Power_Index_REG[index], pHalData->PowerIndex_backup[index]);
-
-
-#endif
-#endif
-}
-
-VOID
-odm_DynamicTxPowerWritePowerIndex(
-	IN		PVOID					pDM_VOID, 
-	IN 	u1Byte		Value)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			index;
-	u4Byte			Power_Index_REG[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
-	
-	for(index = 0; index< 6; index++)
-		//PlatformEFIOWrite1Byte(Adapter, Power_Index_REG[index], Value);
-		ODM_Write1Byte(pDM_Odm, Power_Index_REG[index], Value);
-
-}
-
-
-VOID 
-odm_DynamicTxPower(
-	IN		PVOID					pDM_VOID
-	)
-{
-	// 
-	// For AP/ADSL use prtl8192cd_priv
-	// For CE/NIC use PADAPTER
-	//
-	//PADAPTER		pAdapter = pDM_Odm->Adapter;
-//	prtl8192cd_priv	priv		= pDM_Odm->priv;
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if (!(pDM_Odm->SupportAbility & ODM_BB_DYNAMIC_TXPWR))
-		return;
-	//
-	// 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.
-	//
-	switch	(pDM_Odm->SupportPlatform)
-	{
-		case	ODM_WIN:
-		case	ODM_CE:
-			odm_DynamicTxPowerNIC(pDM_Odm);
-			break;	
-		case	ODM_AP:
-			odm_DynamicTxPowerAP(pDM_Odm);
-			break;		
-
-		case	ODM_ADSL:
-			//odm_DIGAP(pDM_Odm);
-			break;	
-	}
-
-	
-}
-
-
-VOID 
-odm_DynamicTxPowerNIC(
-	IN		PVOID					pDM_VOID
-	)
-{	
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	if (!(pDM_Odm->SupportAbility & ODM_BB_DYNAMIC_TXPWR))
-		return;
-	
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-
-	if(pDM_Odm->SupportICType == ODM_RTL8192C)	
-	{
-		odm_DynamicTxPower_92C(pDM_Odm);
-	}
-	else if(pDM_Odm->SupportICType == ODM_RTL8192D)
-	{
-		odm_DynamicTxPower_92D(pDM_Odm);
-	}
-	else if (pDM_Odm->SupportICType == ODM_RTL8821)
-	{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-		PADAPTER		Adapter	 =  pDM_Odm->Adapter;
-		PMGNT_INFO		pMgntInfo = GetDefaultMgntInfo(Adapter);
-
-		if (pMgntInfo->RegRspPwr == 1)
-		{
-			if(pDM_Odm->RSSI_Min > 60)
-			{
-				ODM_SetMACReg(pDM_Odm, ODM_REG_RESP_TX_11AC, BIT20|BIT19|BIT18, 1); // Resp TXAGC offset = -3dB
-
-			}
-			else if(pDM_Odm->RSSI_Min < 55)
-			{
-				ODM_SetMACReg(pDM_Odm, ODM_REG_RESP_TX_11AC, BIT20|BIT19|BIT18, 0); // Resp TXAGC offset = 0dB
-			}
-		}
-#endif
-	}
-#endif	
-}
-
-VOID 
-odm_DynamicTxPowerAP(
-	IN		PVOID					pDM_VOID
-
-	)
-{	
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-//#if ((RTL8192C_SUPPORT==1) || (RTL8192D_SUPPORT==1) || (RTL8188E_SUPPORT==1) || (RTL8812E_SUPPORT==1))
-
-
-	prtl8192cd_priv	priv		= pDM_Odm->priv;
-	s4Byte i;
-	s2Byte pwr_thd = TX_POWER_NEAR_FIELD_THRESH_AP;
-
-	if(!priv->pshare->rf_ft_var.tx_pwr_ctrl)
-		return;
-	
-#if ((RTL8812E_SUPPORT==1) || (RTL8881A_SUPPORT==1) || (RTL8814A_SUPPORT==1))
-	if (pDM_Odm->SupportICType & (ODM_RTL8812 | ODM_RTL8881A | ODM_RTL8814A))
-		pwr_thd = TX_POWER_NEAR_FIELD_THRESH_8812;
-#endif
-
-#if defined(CONFIG_RTL_92D_SUPPORT) || defined(CONFIG_RTL_92C_SUPPORT)
-	if(CHIP_VER_92X_SERIES(priv))
-	{
-#ifdef HIGH_POWER_EXT_PA
-	if(pDM_Odm->ExtPA)
-		tx_power_control(priv);
-#endif		
-	}
-#endif	
-	/*
-	 *	Check if station is near by to use lower tx power
-	 */
-
-	if ((priv->up_time % 3) == 0 )  {
-		int disable_pwr_ctrl = ((pDM_Odm->FalseAlmCnt.Cnt_all > 1000 ) || ((pDM_Odm->FalseAlmCnt.Cnt_all > 300 ) && ((RTL_R8(0xc50) & 0x7f) >= 0x32))) ? 1 : 0;
-			
-		for(i=0; i<ODM_ASSOCIATE_ENTRY_NUM; i++){
-			PSTA_INFO_T pstat = pDM_Odm->pODM_StaInfo[i];
-			if(IS_STA_VALID(pstat) ) {
-					if(disable_pwr_ctrl)
-						pstat->hp_level = 0;
-					 else if ((pstat->hp_level == 0) && (pstat->rssi > pwr_thd))
-					pstat->hp_level = 1;
-						else if ((pstat->hp_level == 1) && (pstat->rssi < (pwr_thd-8)))
-					pstat->hp_level = 0;
-			}
-		}
-
-#if defined(CONFIG_WLAN_HAL_8192EE)
-		if (GET_CHIP_VER(priv) == VERSION_8192E) {
-			if( !disable_pwr_ctrl && (pDM_Odm->RSSI_Min != 0xff) ) {
-				if(pDM_Odm->RSSI_Min > pwr_thd)
-					RRSR_power_control_11n(priv,  1 );
-				else if(pDM_Odm->RSSI_Min < (pwr_thd-8))
-					RRSR_power_control_11n(priv,  0 );
-			} else {
-					RRSR_power_control_11n(priv,  0 );
-			}
-		}
-#endif			
-
-#ifdef CONFIG_WLAN_HAL_8814AE
-		if (GET_CHIP_VER(priv) == VERSION_8814A) {
-			if (!disable_pwr_ctrl && (pDM_Odm->RSSI_Min != 0xff)) {
-				if (pDM_Odm->RSSI_Min > pwr_thd)
-					RRSR_power_control_14(priv,  1);
-				else if (pDM_Odm->RSSI_Min < (pwr_thd-8))
-					RRSR_power_control_14(priv,  0);
-			} else {
-					RRSR_power_control_14(priv,  0);
-			}
-		}
-#endif		
-
-	}
-//#endif	
-
-#endif	
-}
-
-
-VOID 
-odm_DynamicTxPower_92C(
-	IN		PVOID					pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO			pMgntInfo = &Adapter->MgntInfo;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	s4Byte				UndecoratedSmoothedPWDB;
-
-	// 2012/01/12 MH According to Luke's suggestion, only high power will support the feature.
-	if (pDM_Odm->ExtPA == FALSE)
-		return;
-
-	// STA not connected and AP not connected
-	if((!pMgntInfo->bMediaConnect) &&	
-		(pHalData->EntryMinUndecoratedSmoothedPWDB == 0))
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("Not connected to any \n"));
-		pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-
-		//the LastDTPlvl should reset when disconnect, 
-		//otherwise the tx power level wouldn't change when disconnect and connect again.
-		// Maddest 20091220.
-		 pHalData->LastDTPLvl=TxHighPwrLevel_Normal;
-		return;
-	}
-
-#if (INTEL_PROXIMITY_SUPPORT == 1)
-	// Intel set fixed tx power 
-	if(pMgntInfo->IntelProximityModeInfo.PowerOutput > 0)
-	{
-		switch(pMgntInfo->IntelProximityModeInfo.PowerOutput){
-			case 1:
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_100;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_100\n"));
-				break;
-			case 2:
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_70;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_70\n"));
-				break;
-			case 3:
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_50;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_50\n"));
-				break;
-			case 4:
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_35;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_35\n"));
-				break;
-			case 5:
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_15;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_15\n"));
-				break;
-			default:
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_100;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_100\n"));
-				break;
-		}		
-	}
-	else
-#endif		
-	{ 
-		if(	(pMgntInfo->bDynamicTxPowerEnable != TRUE) ||
-			pMgntInfo->IOTAction & HT_IOT_ACT_DISABLE_HIGH_POWER)
-		{
-			pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-		}
-		else
-		{
-			if(pMgntInfo->bMediaConnect)	// Default port
-			{
-				if(ACTING_AS_AP(Adapter) || ACTING_AS_IBSS(Adapter))
-				{
-					UndecoratedSmoothedPWDB = pHalData->EntryMinUndecoratedSmoothedPWDB;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("AP Client PWDB = 0x%x \n", UndecoratedSmoothedPWDB));
-				}
-				else
-				{
-					UndecoratedSmoothedPWDB = pHalData->UndecoratedSmoothedPWDB;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("STA Default Port PWDB = 0x%x \n", UndecoratedSmoothedPWDB));
-				}
-			}
-			else // associated entry pwdb
-			{	
-				UndecoratedSmoothedPWDB = pHalData->EntryMinUndecoratedSmoothedPWDB;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("AP Ext Port PWDB = 0x%x \n", UndecoratedSmoothedPWDB));
-			}
-				
-			if(UndecoratedSmoothedPWDB >= TX_POWER_NEAR_FIELD_THRESH_LVL2)
-			{
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Level2;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_Level1 (TxPwr=0x0)\n"));
-			}
-			else if((UndecoratedSmoothedPWDB < (TX_POWER_NEAR_FIELD_THRESH_LVL2-3)) &&
-				(UndecoratedSmoothedPWDB >= TX_POWER_NEAR_FIELD_THRESH_LVL1) )
-			{
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Level1;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_Level1 (TxPwr=0x10)\n"));
-			}
-			else if(UndecoratedSmoothedPWDB < (TX_POWER_NEAR_FIELD_THRESH_LVL1-5))
-			{
-				pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_Normal\n"));
-			}
-		}
-	}
-	if( pHalData->DynamicTxHighPowerLvl != pHalData->LastDTPLvl )
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("PHY_SetTxPowerLevel8192C() Channel = %d \n" , pHalData->CurrentChannel));
-		PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
-		if(	(pHalData->DynamicTxHighPowerLvl == TxHighPwrLevel_Normal) &&
-			(pHalData->LastDTPLvl == TxHighPwrLevel_Level1 || pHalData->LastDTPLvl == TxHighPwrLevel_Level2)) //TxHighPwrLevel_Normal
-			odm_DynamicTxPowerRestorePowerIndex(pDM_Odm);
-		else if(pHalData->DynamicTxHighPowerLvl == TxHighPwrLevel_Level1)
-			odm_DynamicTxPowerWritePowerIndex(pDM_Odm, 0x14);
-		else if(pHalData->DynamicTxHighPowerLvl == TxHighPwrLevel_Level2)
-			odm_DynamicTxPowerWritePowerIndex(pDM_Odm, 0x10);
-	}
-	pHalData->LastDTPLvl = pHalData->DynamicTxHighPowerLvl;
-
-	
-
-
-#endif	// #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-}
-
-
-VOID 
-odm_DynamicTxPower_92D(
-	IN		PVOID					pDM_VOID
-	)
-{
-#if (RTL8192D_SUPPORT==1)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO			pMgntInfo = &Adapter->MgntInfo;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	s4Byte				UndecoratedSmoothedPWDB;
-
-	PADAPTER	BuddyAdapter = Adapter->BuddyAdapter;
-	BOOLEAN		bGetValueFromBuddyAdapter = dm_DualMacGetParameterFromBuddyAdapter(Adapter);
-	u1Byte		HighPowerLvlBackForMac0 = TxHighPwrLevel_Level1;
-
-	// 2012/01/12 MH According to Luke's suggestion, only high power will support the feature.
-	if (pDM_Odm->ExtPA == FALSE)
-		return;
-
-	// If dynamic high power is disabled.
-	if( (pMgntInfo->bDynamicTxPowerEnable != TRUE) ||
-		pMgntInfo->IOTAction & HT_IOT_ACT_DISABLE_HIGH_POWER)
-	{
-		pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-		return;
-	}
-
-	// STA not connected and AP not connected
-	if((!pMgntInfo->bMediaConnect) &&	
-		(pHalData->EntryMinUndecoratedSmoothedPWDB == 0))
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("Not connected to any \n"));
-		pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-
-		//the LastDTPlvl should reset when disconnect, 
-		//otherwise the tx power level wouldn't change when disconnect and connect again.
-		// Maddest 20091220.
-		 pHalData->LastDTPLvl=TxHighPwrLevel_Normal;
-		return;
-	}
-	
-	if(pMgntInfo->bMediaConnect)	// Default port
-	{
-		if(ACTING_AS_AP(Adapter) || pMgntInfo->mIbss)
-		{
-			UndecoratedSmoothedPWDB = pHalData->EntryMinUndecoratedSmoothedPWDB;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("AP Client PWDB = 0x%x \n", UndecoratedSmoothedPWDB));
-		}
-		else
-		{
-			UndecoratedSmoothedPWDB = pHalData->UndecoratedSmoothedPWDB;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("STA Default Port PWDB = 0x%x \n", UndecoratedSmoothedPWDB));
-		}
-	}
-	else // associated entry pwdb
-	{	
-		UndecoratedSmoothedPWDB = pHalData->EntryMinUndecoratedSmoothedPWDB;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("AP Ext Port PWDB = 0x%x \n", UndecoratedSmoothedPWDB));
-	}
-	
-	if(IS_HARDWARE_TYPE_8192D(Adapter) && GET_HAL_DATA(Adapter)->CurrentBandType == 1){
-		if(UndecoratedSmoothedPWDB >= 0x33)
-		{
-			pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Level2;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("5G:TxHighPwrLevel_Level2 (TxPwr=0x0)\n"));
-		}
-		else if((UndecoratedSmoothedPWDB <0x33) &&
-			(UndecoratedSmoothedPWDB >= 0x2b) )
-		{
-			pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Level1;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("5G:TxHighPwrLevel_Level1 (TxPwr=0x10)\n"));
-		}
-		else if(UndecoratedSmoothedPWDB < 0x2b)
-		{
-			pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("5G:TxHighPwrLevel_Normal\n"));
-		}
-
-	}
-	else
-	
-	{
-		if(UndecoratedSmoothedPWDB >= TX_POWER_NEAR_FIELD_THRESH_LVL2)
-		{
-			pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Level1;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_Level1 (TxPwr=0x0)\n"));
-		}
-		else if((UndecoratedSmoothedPWDB < (TX_POWER_NEAR_FIELD_THRESH_LVL2-3)) &&
-			(UndecoratedSmoothedPWDB >= TX_POWER_NEAR_FIELD_THRESH_LVL1) )
-		{
-			pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Level1;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_Level1 (TxPwr=0x10)\n"));
-		}
-		else if(UndecoratedSmoothedPWDB < (TX_POWER_NEAR_FIELD_THRESH_LVL1-5))
-		{
-			pHalData->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("TxHighPwrLevel_Normal\n"));
-		}
-
-	}
-
-//sherry  delete flag 20110517
-	if(bGetValueFromBuddyAdapter)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() mac 0 for mac 1 \n"));
-		if(Adapter->DualMacDMSPControl.bChangeTxHighPowerLvlForAnotherMacOfDMSP)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() change value \n"));
-			HighPowerLvlBackForMac0 = pHalData->DynamicTxHighPowerLvl;
-			pHalData->DynamicTxHighPowerLvl = Adapter->DualMacDMSPControl.CurTxHighLvlForAnotherMacOfDMSP;
-			PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
-			pHalData->DynamicTxHighPowerLvl = HighPowerLvlBackForMac0;
-			Adapter->DualMacDMSPControl.bChangeTxHighPowerLvlForAnotherMacOfDMSP = FALSE;
-		}						
-	}
-
-	if( (pHalData->DynamicTxHighPowerLvl != pHalData->LastDTPLvl) )
-	{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("PHY_SetTxPowerLevel8192S() Channel = %d \n" , pHalData->CurrentChannel));
-			if(Adapter->DualMacSmartConcurrent == TRUE)
-			{
-				if(BuddyAdapter == NULL)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() BuddyAdapter == NULL case \n"));
-					if(!Adapter->bSlaveOfDMSP)
-					{
-						PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
-					}
-				}
-				else
-				{
-					if(pHalData->MacPhyMode92D == DUALMAC_SINGLEPHY)
-					{
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() BuddyAdapter DMSP \n"));
-						if(Adapter->bSlaveOfDMSP)
-						{
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() bslave case  \n"));
-							BuddyAdapter->DualMacDMSPControl.bChangeTxHighPowerLvlForAnotherMacOfDMSP = TRUE;
-							BuddyAdapter->DualMacDMSPControl.CurTxHighLvlForAnotherMacOfDMSP = pHalData->DynamicTxHighPowerLvl;
-						}
-						else
-						{
-							ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() master case  \n"));					
-							if(!bGetValueFromBuddyAdapter)
-							{
-								ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() mac 0 for mac 0 \n"));
-								PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
-							}
-						}
-					}
-					else
-					{
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_DYNAMIC_TXPWR,DBG_LOUD,("dm_DynamicTxPower() BuddyAdapter DMDP\n"));
-						PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
-					}
-				}
-			}
-			else
-			{
-				PHY_SetTxPowerLevel8192C(Adapter, pHalData->CurrentChannel);
-			}
-
-		}
-	pHalData->LastDTPLvl = pHalData->DynamicTxHighPowerLvl;
-
-
-#endif	// #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#endif
-}
-
-VOID 
-odm_DynamicTxPower_8821(
-	IN		PVOID			pDM_VOID,	
-	IN		pu1Byte			pDesc,
-	IN		u1Byte			macId	
-	)
-{
-#if (RTL8821A_SUPPORT == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PSTA_INFO_T		pEntry;
-	u1Byte			reg0xc56_byte;
-	u1Byte			reg0xe56_byte;
-	u1Byte			txpwr_offset = 0;
-	
-	pEntry = pDM_Odm->pODM_StaInfo[macId];	
-
-	reg0xc56_byte = ODM_Read1Byte(pDM_Odm, 0xc56);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("reg0xc56_byte=%d\n", reg0xc56_byte));
-
-	if (pEntry[macId].rssi_stat.UndecoratedSmoothedPWDB > 85) {
-
-		/* Avoid TXAGC error after TX power offset is applied.
-		For example: Reg0xc56=0x6, if txpwr_offset=3( reduce 11dB )
-		Total power = 6-11= -5( overflow!! ), PA may be burned !
-		so txpwr_offset should be adjusted by Reg0xc56*/
-		
-		if (reg0xc56_byte < 7)
-			txpwr_offset = 1;
-		else if (reg0xc56_byte < 11)
-			txpwr_offset = 2;
-		else
-			txpwr_offset = 3;
-		
-		SET_TX_DESC_TX_POWER_OFFSET_8812(pDesc, txpwr_offset);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("odm_DynamicTxPower_8821: RSSI=%d, txpwr_offset=%d\n", pEntry[macId].rssi_stat.UndecoratedSmoothedPWDB, txpwr_offset));
-
-	} else{
-		SET_TX_DESC_TX_POWER_OFFSET_8812(pDesc, txpwr_offset);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_DYNAMIC_TXPWR, DBG_LOUD, ("odm_DynamicTxPower_8821: RSSI=%d, txpwr_offset=%d\n", pEntry[macId].rssi_stat.UndecoratedSmoothedPWDB, txpwr_offset));
-
-	}
-#endif	/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
-#endif	/*#if (RTL8821A_SUPPORT==1)*/
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* *********************Power training init************************ */
+void phydm_pow_train_init(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	PMGNT_INFO			mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	/* This is for power training init @ 11N serious */	
+	#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (RT_GetInterfaceSelection((PADAPTER)adapter) == INTF_SEL1_USB_High_Power) {
+		odm_dynamic_tx_power_save_power_index(dm);
+	}
+	#else
+
+		/* so 92c pci do not need dynamic tx power? vivi check it later */
+	#endif
+#endif
+
+}
+
+void
+odm_dynamic_tx_power_save_power_index(
+	void					*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8		index;
+	u32		power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	/* Save PT index, but nothing used?? */
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	for (index = 0; index < 6; index++)
+		hal_data->PowerIndex_backup[index] = PlatformEFIORead1Byte((PADAPTER)adapter, power_index_reg[index]);
+
+
+#endif
+#endif
+}
+
+void
+odm_dynamic_tx_power_restore_power_index(
+	void					*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			index;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	u32			power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
+
+	for (index = 0; index < 6; index++)
+		PlatformEFIOWrite1Byte(adapter, power_index_reg[index], hal_data->PowerIndex_backup[index]);
+
+
+
+#endif
+}
+
+void
+odm_dynamic_tx_power_write_power_index(
+	void					*dm_void,
+	u8		value)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			index;
+	u32			power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
+
+	for (index = 0; index < 6; index++)
+		/* platform_efio_write_1byte(adapter, power_index_reg[index], value); */
+		odm_write_1byte(dm, power_index_reg[index], value);
+
+}
+
+/* ************************************************************ */
+
+#ifdef CONFIG_DYNAMIC_TX_TWR
+
+boolean
+phydm_check_rates(
+	void				*dm_void,
+	u8				rate_idx
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		check_rate_bitmap0 = 0x08080808; /* check CCK11M, OFDM54M, MCS7, MCS15*/
+	u32		check_rate_bitmap1 = 0x80200808; /* check MCS23, MCS31, VHT1SS M9, VHT2SS M9*/
+	u32		check_rate_bitmap2 = 0x00080200; /* check VHT3SS M9, VHT4SS M9*/
+	u32		bitmap_result;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0xfffff000;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
+
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0x003ff000;
+		check_rate_bitmap0 &= 0x000fffff;
+	}
+#endif
+
+	
+	if (rate_idx >= 64)
+		bitmap_result = BIT(rate_idx-64) & check_rate_bitmap2;
+	else if (rate_idx >= 32)
+		bitmap_result = BIT(rate_idx-32) & check_rate_bitmap1;
+	else if (rate_idx <= 31)
+		bitmap_result = BIT(rate_idx) & check_rate_bitmap0;
+
+	if (bitmap_result!=0)
+		return true;
+	else
+		return false;
+}
+
+enum rf_path
+phydm_check_paths(
+	void				*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	enum rf_path					max_path;
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		max_path = RF_PATH_B;
+#endif
+
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F) 
+		max_path = RF_PATH_B;
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) 
+		max_path = RF_PATH_A;
+#endif
+	return max_path;
+}
+
+u8
+phydm_search_min_power_index(
+	void				*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	enum rf_path		path;
+	enum rf_path		max_path;
+	u8		min_gain_index = 0x3f;
+	u8		gain_index;
+	u8		rate_idx;
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "phydm_search_min_power_index\n");
+	max_path = phydm_check_paths(dm);
+	for (path = 0; path <= max_path; path++)
+		for (rate_idx = 0; rate_idx < 84; rate_idx++)
+			if (phydm_check_rates(dm, rate_idx)) {
+				gain_index = phydm_api_get_txagc(dm, path, rate_idx);
+				PHYDM_DBG(dm, DBG_DYN_TXPWR, "Support Rate: ((%d)) -> Gain index: ((%d))\n", rate_idx, gain_index);
+				if (gain_index < min_gain_index)
+					min_gain_index = gain_index;
+			}
+	
+	return min_gain_index;
+}
+
+
+void
+phydm_dynamic_tx_power_init(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	dm->last_dtp_lvl = tx_high_pwr_level_normal;
+	dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
+	dm->min_power_index = phydm_search_min_power_index(dm);
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "DTP init: Min Gain index: ((%d))\n", dm->min_power_index);
+}
+
+u8
+phydm_pwr_lvl_check(
+	void					*dm_void,
+	u8					input_rssi
+)
+{
+	if (input_rssi >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
+		return tx_high_pwr_level_level2;
+		/**/
+	} else if (input_rssi >= TX_POWER_NEAR_FIELD_THRESH_LVL1) {
+		return tx_high_pwr_level_level1;
+		/**/
+	} else if (input_rssi < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
+		return tx_high_pwr_level_normal;
+		/**/
+	}
+	else {
+		return tx_high_pwr_level_normal;
+	}
+}
+
+void
+phydm_dynamic_response_power(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	now_pwr_lvl;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	if (dm->last_dtp_lvl != dm->dynamic_tx_high_power_lvl) {
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "Response Power update_DTP_lv: ((%d)) -> ((%d))\n", dm->last_dtp_lvl, dm->dynamic_tx_high_power_lvl);
+		dm->last_dtp_lvl = dm->dynamic_tx_high_power_lvl;
+		now_pwr_lvl = dm->dynamic_tx_high_power_lvl;
+		if (now_pwr_lvl == tx_high_pwr_level_level2 || now_pwr_lvl == tx_high_pwr_level_level1) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT(19) | BIT(18), 1); /* Resp TXAGC offset = -3dB*/
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Response Power Set TX power: level 1\n");
+		} else if (now_pwr_lvl == tx_high_pwr_level_normal) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT(19) | BIT(18), 0); /* Resp TXAGC offset = 0dB*/
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Response Power Set TX power: normal\n");
+		}
+	}
+}
+
+void
+phydm_dtp_fill_cmninfo(
+	void					*dm_void,
+	u8					macid,
+	u8					dtp_lvl
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dtp_info 				*dtp= NULL;
+	dtp = &dm->phydm_sta_info[macid]->dtp_stat;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	if (dtp_lvl == tx_high_pwr_level_level2)
+		dtp->dyn_tx_power = PHYDM_OFFSET_MINUS_7DB;
+	else if (dtp_lvl == tx_high_pwr_level_level1)
+		dtp->dyn_tx_power = PHYDM_OFFSET_MINUS_3DB;
+	else
+		dtp->dyn_tx_power = PHYDM_OFFSET_ZERO;
+	
+}
+
+void
+phydm_dtp_per_sta(
+	void					*dm_void,
+	u8					macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct dtp_info				*dtp = NULL;
+	struct rssi_info				*rssi = NULL;
+	if (is_sta_active(sta)) {
+		dtp = &sta->dtp_stat;
+		rssi = &sta->rssi_stat;
+		dtp->sta_tx_high_power_lvl = phydm_pwr_lvl_check(dm,rssi->rssi);
+		if (dtp->sta_tx_high_power_lvl != dtp->sta_last_dtp_lvl) {
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "STA=%d : update_DTP_lv: ((%d)) -> ((%d))\n", macid, dm->last_dtp_lvl, dm->dynamic_tx_high_power_lvl);
+			dm->last_dtp_lvl = dm->dynamic_tx_high_power_lvl;
+			phydm_dtp_fill_cmninfo(dm, macid, dm->dynamic_tx_high_power_lvl);
+		}
+	}
+}
+
+
+#else
+void
+phydm_dynamic_tx_power_init(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	PMGNT_INFO			mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+
+	/*if (!IS_HARDWARE_TYPE_8814A(adapter)) {*/
+	/*	PHYDM_DBG(dm,DBG_DYN_TXPWR, */
+	/*	("DynamicTxPowerEnable=%d\n", mgnt_info->is_dynamic_tx_power_enable));*/
+	/*	return;*/
+	/*} else*/
+	{
+		mgnt_info->bDynamicTxPowerEnable = true;
+		PHYDM_DBG(dm, DBG_DYN_TXPWR,
+			"DynamicTxPowerEnable=%d\n", mgnt_info->bDynamicTxPowerEnable);
+	}
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (RT_GetInterfaceSelection((PADAPTER)adapter) == INTF_SEL1_USB_High_Power) {
+		mgnt_info->bDynamicTxPowerEnable = true;
+	} else
+#else
+	/* so 92c pci do not need dynamic tx power? vivi check it later */
+	mgnt_info->bDynamicTxPowerEnable = false;
+#endif
+
+
+		hal_data->LastDTPLvl = tx_high_pwr_level_normal;
+	hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+	dm->last_dtp_lvl = tx_high_pwr_level_normal;
+	dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
+	dm->tx_agc_ofdm_18_6 = odm_get_bb_reg(dm, 0xC24, MASKDWORD); /*TXAGC {18M 12M 9M 6M}*/
+
+#endif
+
+}
+
+
+
+void
+odm_dynamic_tx_power_nic_ce(
+	void					*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+#if (RTL8821A_SUPPORT == 1)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			val;
+	u8			rssi_tmp = dm->rssi_min;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+
+	if (rssi_tmp >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
+		dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_level2;
+		/**/
+	} else if (rssi_tmp >= TX_POWER_NEAR_FIELD_THRESH_LVL1) {
+		dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_level1;
+		/**/
+	} else if (rssi_tmp < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
+		dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
+		/**/
+	}
+
+	if (dm->last_dtp_lvl == dm->dynamic_tx_high_power_lvl)
+		return;
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "update_DTP_lv: ((%d)) -> ((%d))\n", dm->last_dtp_lvl, dm->dynamic_tx_high_power_lvl);
+
+	dm->last_dtp_lvl = dm->dynamic_tx_high_power_lvl;
+
+	if (dm->support_ic_type & (ODM_RTL8821)) {
+		if (dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_level2) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT19 | BIT18, 1); /* Resp TXAGC offset = -3dB*/
+
+			val = dm->tx_agc_ofdm_18_6 & 0xff;
+			if (val >= 0x20)
+				val -= 0x16;
+
+			odm_set_bb_reg(dm, 0xC24, 0xff, val);
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Set TX power: level 2\n");
+		} else if (dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_level1) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT19 | BIT18, 1); /* Resp TXAGC offset = -3dB*/
+
+			val = dm->tx_agc_ofdm_18_6 & 0xff;
+			if (val >= 0x20)
+				val -= 0x10;
+
+			odm_set_bb_reg(dm, 0xC24, 0xff, val);
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Set TX power: level 1\n");
+		} else if (dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_normal) {
+			odm_set_mac_reg(dm, 0x6D8, BIT(20) | BIT19 | BIT18, 0); /* Resp TXAGC offset = 0dB*/
+			odm_set_bb_reg(dm, 0xC24, MASKDWORD, dm->tx_agc_ofdm_18_6);
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "Set TX power: normal\n");
+		}
+	}
+
+#endif
+#endif
+}
+
+
+void
+odm_dynamic_tx_power(
+	void					*dm_void
+)
+{
+	/*  */
+	/* For AP/ADSL use struct rtl8192cd_priv* */
+	/* For CE/NIC use struct void* */
+	/*  */
+	/* struct void*		adapter = dm->adapter;
+	*	struct rtl8192cd_priv*	priv		= dm->priv; */
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	/*  */
+	/* 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. */
+	/*  */
+	switch	(dm->support_platform) {
+	case	ODM_WIN:
+		odm_dynamic_tx_power_nic(dm);
+		break;
+	case	ODM_CE:
+		odm_dynamic_tx_power_nic_ce(dm);
+		break;
+	default:
+		break;
+	}
+
+
+}
+
+
+void
+odm_dynamic_tx_power_nic(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+	if (dm->support_ic_type == ODM_RTL8814A)
+		odm_dynamic_tx_power_8814a(dm);
+	else if (dm->support_ic_type & ODM_RTL8821) {
+		void		*adapter	 =  dm->adapter;
+		PMGNT_INFO		mgnt_info = GetDefaultMgntInfo((PADAPTER)adapter);
+
+		if (mgnt_info->RegRspPwr == 1)	{
+			if (dm->rssi_min > 60)
+				odm_set_mac_reg(dm, ODM_REG_RESP_TX_11AC, BIT(20) | BIT19 | BIT18, 1); /*Resp TXAGC offset = -3dB*/
+			else if (dm->rssi_min < 55)
+				odm_set_mac_reg(dm, ODM_REG_RESP_TX_11AC, BIT(20) | BIT19 | BIT18, 0); /*Resp TXAGC offset = 0dB*/
+		}
+	}
+#endif
+}
+
+
+void
+odm_dynamic_tx_power_8821(
+	void			*dm_void,
+	u8			*desc,
+	u8			mac_id
+)
+{
+#if (RTL8821A_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*entry;
+	u8			reg0xc56_byte;
+	u8			txpwr_offset = 0;
+
+	entry = dm->phydm_sta_info[mac_id];
+
+	reg0xc56_byte = odm_read_1byte(dm, 0xc56);
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "reg0xc56_byte=%d\n", reg0xc56_byte);
+
+	if (entry[mac_id].rssi_stat.rssi > 85) {
+		/* Avoid TXAGC error after TX power offset is applied.
+		For example: Reg0xc56=0x6, if txpwr_offset=3( reduce 11dB )
+		Total power = 6-11= -5( overflow!! ), PA may be burned !
+		so txpwr_offset should be adjusted by Reg0xc56*/
+
+		if (reg0xc56_byte < 7)
+			txpwr_offset = 1;
+		else if (reg0xc56_byte < 11)
+			txpwr_offset = 2;
+		else
+			txpwr_offset = 3;
+
+		SET_TX_DESC_TX_POWER_OFFSET_8812(desc, txpwr_offset);
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "odm_dynamic_tx_power_8821: RSSI=%d, txpwr_offset=%d\n", entry[mac_id].rssi_stat.rssi, txpwr_offset);
+
+	} else {
+		SET_TX_DESC_TX_POWER_OFFSET_8812(desc, txpwr_offset);
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "odm_dynamic_tx_power_8821: RSSI=%d, txpwr_offset=%d\n", entry[mac_id].rssi_stat.rssi, txpwr_offset);
+
+	}
+#endif	/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+#endif	/*#if (RTL8821A_SUPPORT==1)*/
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_dynamic_tx_power_8814a(
+	void					*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	PMGNT_INFO			mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	s32				undecorated_smoothed_pwdb = dm->rssi_min;
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		"TxLevel=%d mgnt_info->iot_action=%x mgnt_info->is_dynamic_tx_power_enable=%d\n",
+		hal_data->DynamicTxHighPowerLvl, mgnt_info->IOTAction, mgnt_info->bDynamicTxPowerEnable);
+
+	/*STA not connected and AP not connected*/
+	if ((!mgnt_info->bMediaConnect) && (hal_data->EntryMinUndecoratedSmoothedPWDB == 0)) {
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "Not connected to any reset power lvl\n");
+		hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+		return;
+	}
+
+
+	if (!mgnt_info->bDynamicTxPowerEnable || mgnt_info->IOTAction & HT_IOT_ACT_DISABLE_HIGH_POWER)
+		hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+	else {
+
+		/*Should we separate as 2.4G/5G band?*/
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "rssi_tmp = %d\n", undecorated_smoothed_pwdb);
+
+		if (undecorated_smoothed_pwdb >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
+			hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_level2;
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "tx_high_pwr_level_level1 (TxPwr=0x0)\n");
+		} else if ((undecorated_smoothed_pwdb < (TX_POWER_NEAR_FIELD_THRESH_LVL2 - 3)) &&
+			(undecorated_smoothed_pwdb >= TX_POWER_NEAR_FIELD_THRESH_LVL1)) {
+			hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_level1;
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "tx_high_pwr_level_level1 (TxPwr=0x10)\n");
+		} else if (undecorated_smoothed_pwdb < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
+			hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+			PHYDM_DBG(dm, DBG_DYN_TXPWR, "tx_high_pwr_level_normal\n");
+		}
+	}
+
+
+	if (hal_data->DynamicTxHighPowerLvl != hal_data->LastDTPLvl) {
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "odm_dynamic_tx_power_8814a() channel = %d\n", hal_data->CurrentChannel);
+		odm_set_tx_power_level8814(adapter, hal_data->CurrentChannel, hal_data->DynamicTxHighPowerLvl);
+	}
+
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		"odm_dynamic_tx_power_8814a() channel = %d  TXpower lvl=%d/%d\n",
+		hal_data->CurrentChannel, hal_data->LastDTPLvl, hal_data->DynamicTxHighPowerLvl);
+
+	hal_data->LastDTPLvl = hal_data->DynamicTxHighPowerLvl;
+
+}
+
+
+
+/**/
+/*For normal driver we always use the FW method to configure TX power index to reduce I/O transaction.*/
+/**/
+/**/
+void
+odm_set_tx_power_level8814(
+	void		*adapter,
+	u8			channel,
+	u8			pwr_lvl
+)
+{
+#if (DEV_BUS_TYPE == RT_USB_INTERFACE)
+	u32			i, j, k = 0;
+	u32			value[264] = {0};
+	u32			path = 0, power_index, txagc_table_wd = 0x00801000;
+
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+
+	u8	jaguar2_rates[][4] = { {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M},
+		{MGN_6M, MGN_9M, MGN_12M, MGN_18M},
+		{MGN_24M, MGN_36M, MGN_48M, MGN_54M},
+		{MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3},
+		{MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7},
+		{MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11},
+		{MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15},
+		{MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19},
+		{MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23},
+		{MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3},
+		{MGN_VHT1SS_MCS4, MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7},
+		{MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9, MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1},
+		{MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4, MGN_VHT2SS_MCS5},
+		{MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9},
+		{MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3},
+		{MGN_VHT3SS_MCS4, MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7},
+		{MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9, 0, 0}
+	};
+
+	for (path = RF_PATH_A; path <= RF_PATH_D; ++path) {
+		u8	usb_host = UsbModeQueryHubUsbType((PADAPTER)adapter);
+		u8	usb_rfset = UsbModeQueryRfSet((PADAPTER)adapter);
+		u8	usb_rf_type = RT_GetRFType((PADAPTER)adapter);
+
+		for (i = 0; i <= 16; i++) {
+			for (j = 0; j <= 3; j++) {
+				if (jaguar2_rates[i][j] == 0)
+					continue;
+
+				txagc_table_wd =  0x00801000;
+				power_index = (u32) PHY_GetTxPowerIndex((PADAPTER)adapter, (u8)path, jaguar2_rates[i][j], hal_data->CurrentChannelBW, channel);
+
+				/*for Query bus type to recude tx power.*/
+				if (usb_host != USB_MODE_U3 && usb_rfset == 1 && IS_HARDWARE_TYPE_8814AU(adapter) && usb_rf_type == RF_3T3R) {
+					if (channel <= 14) {
+						if (power_index >= 16)
+							power_index -= 16;
+						else
+							power_index = 0;
+					} else
+						power_index = 0;
+				}
+
+				if (pwr_lvl == tx_high_pwr_level_level1) {
+					if (power_index >= 0x10)
+						power_index -= 0x10;
+					else
+						power_index = 0;
+				} else if (pwr_lvl == tx_high_pwr_level_level2)
+					power_index = 0;
+
+				txagc_table_wd |= (path << 8) | MRateToHwRate(jaguar2_rates[i][j]) | (power_index << 24);
+
+				PHY_SetTxPowerIndexShadow((PADAPTER)adapter, (u8)power_index, (u8)path, jaguar2_rates[i][j]);
+
+				value[k++] = txagc_table_wd;
+			}
+		}
+	}
+
+	if (((PADAPTER)adapter)->MgntInfo.bScanInProgress == false &&  ((PADAPTER)adapter)->MgntInfo.RegFWOffload == 2)
+		HalDownloadTxPowerLevel8814((PADAPTER)adapter, value);
+#endif
+}
+#endif
+
+#endif /* #ifdef CONFIG_DYNAMIC_TX_TWR */
+
+void
+phydm_dynamic_tx_power(
+	void					*dm_void
+)
+{
+#ifdef CONFIG_DYNAMIC_TX_TWR
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = NULL;
+	u8		i;
+	u8		cnt = 0;
+	u8		rssi_min = dm->rssi_min;
+	u8		rssi_tmp;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	/* Response Power */
+	dm->dynamic_tx_high_power_lvl = phydm_pwr_lvl_check(dm, rssi_min);
+	phydm_dynamic_response_power(dm);
+	/* Per STA Tx power */
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		phydm_dtp_per_sta(dm, i);
+		cnt++;
+		if (cnt >= dm->number_linked_client)
+			break;
+	}
+#endif
+}
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.h
index 69e1849d6cf9..e4907568ef6b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_dynamictxpower.h
@@ -1,98 +1,135 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMDYNAMICTXPOWER_H__
-#define    __PHYDMDYNAMICTXPOWER_H__
-
-/*#define DYNAMIC_TXPWR_VERSION	"1.0"*/
-#define DYNAMIC_TXPWR_VERSION	"1.1" /*2015.01.13*/
-
-#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		TX_POWER_NEAR_FIELD_THRESH_8812	60
-
-#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
-
-VOID 
-odm_DynamicTxPowerInit(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-odm_DynamicTxPowerRestorePowerIndex(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID 
-odm_DynamicTxPowerNIC(
-	IN		PVOID					pDM_VOID
-	);
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-VOID
-odm_DynamicTxPowerSavePowerIndex(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID
-odm_DynamicTxPowerWritePowerIndex(
-	IN		PVOID					pDM_VOID, 
-	IN 	u1Byte		Value);
-
-VOID 
-odm_DynamicTxPower_92C(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID 
-odm_DynamicTxPower_92D(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID 
-odm_DynamicTxPower_8821(
-	IN		PVOID					pDM_VOID,	
-	IN		pu1Byte					pDesc,
-	IN		u1Byte					macId
-	);
-
-#endif
-
-VOID 
-odm_DynamicTxPower(
-	IN		PVOID					pDM_VOID
-	);
-
-VOID 
-odm_DynamicTxPowerAP(
-	IN		PVOID					pDM_VOID
-	);
-
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMDYNAMICTXPOWER_H__
+#define    __PHYDMDYNAMICTXPOWER_H__
+
+/*#define DYNAMIC_TXPWR_VERSION	"1.0"*/
+/*#define DYNAMIC_TXPWR_VERSION	"1.3" */ /*2015.08.26, Add 8814 Dynamic TX power*/
+#define DYNAMIC_TXPWR_VERSION	"1.4" /*2015.11.06, Add CE 8821A Dynamic TX power*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	60
+	#define		TX_POWER_NEAR_FIELD_THRESH_AP	0x3F
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	67
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
+	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	60
+#endif
+
+#define		tx_high_pwr_level_normal		0
+#define		tx_high_pwr_level_level1		1
+#define		tx_high_pwr_level_level2		2
+
+#define		tx_high_pwr_level_bt1			3
+#define		tx_high_pwr_level_bt2			4
+#define		tx_high_pwr_level_15			5
+#define		tx_high_pwr_level_35			6
+#define		tx_high_pwr_level_50			7
+#define		tx_high_pwr_level_70			8
+#define		tx_high_pwr_level_100			9
+
+enum phydm_dtp_power_offset {
+	PHYDM_OFFSET_ZERO = 0,
+	PHYDM_OFFSET_MINUS_3DB = 1, 
+	PHYDM_OFFSET_MINUS_7DB = 2,
+	PHYDM_OFFSET_MINUS_11DB = 3,
+	PHYDM_OFFSET_ADD_3DB = 4,
+	PHYDM_OFFSET_ADD_6DB = 5
+};
+
+void
+phydm_pow_train_init(
+	void					*dm_void
+);
+
+void
+phydm_dynamic_tx_power(
+	void					*dm_void
+);
+
+void
+odm_dynamic_tx_power_restore_power_index(
+	void					*dm_void
+);
+
+void
+odm_dynamic_tx_power_nic(
+	void					*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+void
+odm_dynamic_tx_power_save_power_index(
+	void					*dm_void
+);
+
+void
+odm_dynamic_tx_power_write_power_index(
+	void					*dm_void,
+	u8		value);
+
+void
+odm_dynamic_tx_power_8821(
+	void					*dm_void,
+	u8					*desc,
+	u8					mac_id
+);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+odm_dynamic_tx_power_8814a(
+	void					*dm_void
+);
+
+
+void
+odm_set_tx_power_level8814(
+	void		*adapter,
+	u8			channel,
+	u8			pwr_lvl
+);
+#endif
+#endif
+
+void
+odm_dynamic_tx_power(
+	void					*dm_void
+);
+
+void
+phydm_dynamic_tx_power(
+	void					*dm_void
+);
+
+void
+phydm_dynamic_tx_power_init(
+	void					*dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_edcaturbocheck.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_edcaturbocheck.c
deleted file mode 100644
index 255d9855fc2c..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_edcaturbocheck.c
+++ /dev/null
@@ -1,835 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-VOID
-ODM_EdcaTurboInit(
-	IN 	PVOID	 	pDM_VOID)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-#if (DM_ODM_SUPPORT_TYPE==ODM_WIN)
-	PADAPTER	Adapter = NULL;
-	HAL_DATA_TYPE	*pHalData = NULL;
-
-	if(pDM_Odm->Adapter==NULL)	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("EdcaTurboInit fail!!!\n"));
-		return;
-	}
-
-	Adapter=pDM_Odm->Adapter;
-	pHalData=GET_HAL_DATA(Adapter);
-
-	pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = FALSE;	
-	pDM_Odm->DM_EDCA_Table.bIsCurRDLState = FALSE;
-	pHalData->bIsAnyNonBEPkts = FALSE;
-	
-#elif(DM_ODM_SUPPORT_TYPE==ODM_CE)
-	PADAPTER	Adapter = pDM_Odm->Adapter;	
-	pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = FALSE;	
-	pDM_Odm->DM_EDCA_Table.bIsCurRDLState = FALSE;
-	Adapter->recvpriv.bIsAnyNonBEPkts =FALSE;
-
-#endif	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Orginial VO PARAM: 0x%x\n",ODM_Read4Byte(pDM_Odm,ODM_EDCA_VO_PARAM)));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Orginial VI PARAM: 0x%x\n",ODM_Read4Byte(pDM_Odm,ODM_EDCA_VI_PARAM)));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Orginial BE PARAM: 0x%x\n",ODM_Read4Byte(pDM_Odm,ODM_EDCA_BE_PARAM)));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Orginial BK PARAM: 0x%x\n",ODM_Read4Byte(pDM_Odm,ODM_EDCA_BK_PARAM)));
-
-	
-}	// ODM_InitEdcaTurbo
-
-VOID
-odm_EdcaTurboCheck(
-	IN 	PVOID	 	pDM_VOID
-	)
-{
-	// 
-	// For AP/ADSL use prtl8192cd_priv
-	// For CE/NIC use PADAPTER
-	//
-
-	//
-	// 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.
-	//
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("odm_EdcaTurboCheck========================>\n"));
-
-	if(!(pDM_Odm->SupportAbility& ODM_MAC_EDCA_TURBO ))
-		return;
-
-	switch	(pDM_Odm->SupportPlatform)
-	{
-		case	ODM_WIN:
-
-#if(DM_ODM_SUPPORT_TYPE==ODM_WIN)
-			odm_EdcaTurboCheckMP(pDM_Odm);
-#endif
-			break;
-
-		case	ODM_CE:
-#if(DM_ODM_SUPPORT_TYPE==ODM_CE)
-			odm_EdcaTurboCheckCE(pDM_Odm);
-#endif
-			break;
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("<========================odm_EdcaTurboCheck\n"));
-
-}	// odm_CheckEdcaTurbo
-
-#if(DM_ODM_SUPPORT_TYPE==ODM_CE)
-
-
-VOID
-odm_EdcaTurboCheckCE(
-	IN 	PVOID	 	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		       Adapter = pDM_Odm->Adapter;
-	u32	EDCA_BE_UL = 0x5ea42b;//Parameter suggested by Scott  //edca_setting_UL[pMgntInfo->IOTPeer];
-	u32	EDCA_BE_DL = 0x5ea42b;//Parameter suggested by Scott  //edca_setting_DL[pMgntInfo->IOTPeer];
-	u32	ICType=pDM_Odm->SupportICType;
-	u32	IOTPeer=0;
-	u8	WirelessMode=0xFF;                   //invalid value
-	u32 	trafficIndex;
-	u32	edca_param;
-	u64	cur_tx_bytes = 0;
-	u64	cur_rx_bytes = 0;
-	u8	bbtchange = _FALSE;
-	u8	bBiasOnRx = _FALSE;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	struct dvobj_priv		*pdvobjpriv = adapter_to_dvobj(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);
-
-	if(pDM_Odm->bLinked != _TRUE)
-	{
-		precvpriv->bIsAnyNonBEPkts = _FALSE;
-		return;
-	}
-
-	if ((pregpriv->wifi_spec == 1) )//|| (pmlmeinfo->HT_enable == 0))
-	{
-		precvpriv->bIsAnyNonBEPkts = _FALSE;
-		return;
-	}
-
-	if(pDM_Odm->pWirelessMode!=NULL)
-		WirelessMode=*(pDM_Odm->pWirelessMode);
-
-	IOTPeer = pmlmeinfo->assoc_AP_vendor;
-
-	if (IOTPeer >=  HT_IOT_PEER_MAX)
-	{
-		precvpriv->bIsAnyNonBEPkts = _FALSE;
-		return;
-	}
-
-	if(	(pDM_Odm->SupportICType == ODM_RTL8192C) ||
-		(pDM_Odm->SupportICType == ODM_RTL8723A) ||
-		(pDM_Odm->SupportICType == ODM_RTL8188E))
-	{
-		if((IOTPeer == HT_IOT_PEER_RALINK)||(IOTPeer == HT_IOT_PEER_ATHEROS))
-			bBiasOnRx = _TRUE;
-	}
-
-	// Check if the status needs to be changed.
-	if((bbtchange) || (!precvpriv->bIsAnyNonBEPkts) )
-	{
-		cur_tx_bytes = pdvobjpriv->traffic_stat.cur_tx_bytes;
-		cur_rx_bytes = pdvobjpriv->traffic_stat.cur_rx_bytes;
-
-		//traffic, TX or RX
-		if(bBiasOnRx)
-		{
-			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 (ICType == ODM_RTL8192D) {
-				// Single PHY
-				if (pDM_Odm->RFType == ODM_2T2R) {
-					EDCA_BE_UL = 0x60a42b;    //0x5ea42b;
-					EDCA_BE_DL = 0x60a42b;    //0x5ea42b;
-			} else {
-					EDCA_BE_UL = 0x6ea42b;
-					EDCA_BE_DL = 0x6ea42b;
-			}
-			}
-			else
-			{
-				if(pDM_Odm->SupportInterface==ODM_ITRF_PCIE) {
-					if((ICType==ODM_RTL8192C)&&(pDM_Odm->RFType==ODM_2T2R)) {
-						EDCA_BE_UL = 0x60a42b;
-						EDCA_BE_DL = 0x60a42b;
-					} else {
-						EDCA_BE_UL = 0x6ea42b;
-						EDCA_BE_DL = 0x6ea42b;
-					}
-				}
-			}
-		
-			//92D txop can't be set to 0x3e for cisco1250
-			if((ICType!=ODM_RTL8192D) && (IOTPeer== HT_IOT_PEER_CISCO) &&(WirelessMode==ODM_WM_N24G))
-			{
-				EDCA_BE_DL = edca_setting_DL[IOTPeer];
-				EDCA_BE_UL = edca_setting_UL[IOTPeer];
-			}
-			//merge from 92s_92c_merge temp brunch v2445    20120215 
-			else if((IOTPeer == HT_IOT_PEER_CISCO) &&((WirelessMode==ODM_WM_G)||(WirelessMode==(ODM_WM_B|ODM_WM_G))||(WirelessMode==ODM_WM_A)||(WirelessMode==ODM_WM_B)))
-			{
-				EDCA_BE_DL = edca_setting_DL_GMode[IOTPeer];
-			}
-			else if((IOTPeer== HT_IOT_PEER_AIRGO )&& ((WirelessMode==ODM_WM_G)||(WirelessMode==ODM_WM_A)))
-			{
-				EDCA_BE_DL = 0xa630;
-			}
-			else if(IOTPeer == HT_IOT_PEER_MARVELL)
-			{
-				EDCA_BE_DL = edca_setting_DL[IOTPeer];
-				EDCA_BE_UL = edca_setting_UL[IOTPeer];
-			}
-			else if(IOTPeer == HT_IOT_PEER_ATHEROS)
-			{
-				// Set DL EDCA for Atheros peer to 0x3ea42b. Suggested by SD3 Wilson for ASUS TP issue. 
-				EDCA_BE_DL = edca_setting_DL[IOTPeer];
-			}
-
-			if((ICType==ODM_RTL8812)||(ICType==ODM_RTL8821)||(ICType==ODM_RTL8192E))           //add 8812AU/8812AE
-			{
-				EDCA_BE_UL = 0x5ea42b;
-				EDCA_BE_DL = 0x5ea42b;
-
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("8812A: EDCA_BE_UL=0x%x EDCA_BE_DL =0x%x",EDCA_BE_UL,EDCA_BE_DL));
-			}
-
-			if (trafficIndex == DOWN_LINK)
-				edca_param = EDCA_BE_DL;
-			else
-				edca_param = EDCA_BE_UL;
-
-			rtw_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)
-		{
-			rtw_write32(Adapter, REG_EDCA_BE_PARAM, pHalData->AcParam_BE);
-			pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = _FALSE;
-		}
-	}
-
-}
-
-
-#elif(DM_ODM_SUPPORT_TYPE==ODM_WIN)
-VOID
-odm_EdcaTurboCheckMP(
-	IN 	PVOID	 	pDM_VOID
-	)
-{
-
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		       Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-
-	PADAPTER 			pDefaultAdapter = GetDefaultAdapter(Adapter);
-	PADAPTER 			pExtAdapter = GetFirstExtAdapter(Adapter);//NULL;
-	PMGNT_INFO			pMgntInfo = &Adapter->MgntInfo;
-	PSTA_QOS			pStaQos = Adapter->MgntInfo.pStaQos;
-	//[Win7 Count Tx/Rx statistic for Extension Port] odm_CheckEdcaTurbo's Adapter is always Default. 2009.08.20, by Bohn
-	u8Byte				Ext_curTxOkCnt = 0;
-	u8Byte				Ext_curRxOkCnt = 0;	
-	//For future Win7  Enable Default Port to modify AMPDU size dynamically, 2009.08.20, Bohn.	
-	u1Byte TwoPortStatus = (u1Byte)TWO_PORT_STATUS__WITHOUT_ANY_ASSOCIATE;
-
-	// Keep past Tx/Rx packet count for RT-to-RT EDCA turbo.
-	u8Byte				curTxOkCnt = 0;
-	u8Byte				curRxOkCnt = 0;	
-	u4Byte				EDCA_BE_UL = 0x5ea42b;//Parameter suggested by Scott  //edca_setting_UL[pMgntInfo->IOTPeer];
-	u4Byte				EDCA_BE_DL = 0x5ea42b;//Parameter suggested by Scott  //edca_setting_DL[pMgntInfo->IOTPeer];
-	u4Byte                         EDCA_BE = 0x5ea42b;
-	u1Byte                         IOTPeer=0;
-	BOOLEAN                      *pbIsCurRDLState=NULL;
-	BOOLEAN                      bLastIsCurRDLState=FALSE;
-	BOOLEAN				 bBiasOnRx=FALSE;
-	BOOLEAN				bEdcaTurboOn=FALSE;
-	u1Byte				TxRate = 0xFF;
-	u8Byte				value64;	
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("odm_EdcaTurboCheckMP========================>"));
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Orginial BE PARAM: 0x%x\n",ODM_Read4Byte(pDM_Odm,ODM_EDCA_BE_PARAM)));
-
-////===============================
-////list paramter for different platform
-////===============================
-	bLastIsCurRDLState=pDM_Odm->DM_EDCA_Table.bIsCurRDLState;
-	pbIsCurRDLState=&(pDM_Odm->DM_EDCA_Table.bIsCurRDLState);	
-
-	//2012/09/14 MH Add 
-	if (pMgntInfo->NumNonBePkt > pMgntInfo->RegEdcaThresh && !Adapter->MgntInfo.bWiFiConfg)
-		pHalData->bIsAnyNonBEPkts = TRUE;
-
-	pMgntInfo->NumNonBePkt = 0;
-
-       // Caculate TX/RX TP:
-	//curTxOkCnt = Adapter->TxStats.NumTxBytesUnicast - pMgntInfo->lastTxOkCnt;
-	//curRxOkCnt = Adapter->RxStats.NumRxBytesUnicast - pMgntInfo->lastRxOkCnt;
-	curTxOkCnt = Adapter->TxStats.NumTxBytesUnicast - pDM_Odm->lastTxOkCnt;
-	curRxOkCnt = Adapter->RxStats.NumRxBytesUnicast - pDM_Odm->lastRxOkCnt;
-	pDM_Odm->lastTxOkCnt = Adapter->TxStats.NumTxBytesUnicast;
-	pDM_Odm->lastRxOkCnt = Adapter->RxStats.NumRxBytesUnicast;
-
-	if(pExtAdapter == NULL) 
-		pExtAdapter = pDefaultAdapter;
-
-	Ext_curTxOkCnt = pExtAdapter->TxStats.NumTxBytesUnicast - pMgntInfo->Ext_lastTxOkCnt;
-	Ext_curRxOkCnt = pExtAdapter->RxStats.NumRxBytesUnicast - pMgntInfo->Ext_lastRxOkCnt;
-	GetTwoPortSharedResource(Adapter,TWO_PORT_SHARED_OBJECT__STATUS,NULL,&TwoPortStatus);
-	//For future Win7  Enable Default Port to modify AMPDU size dynamically, 2009.08.20, Bohn.
-	if(TwoPortStatus == TWO_PORT_STATUS__EXTENSION_ONLY)
-	{
-		curTxOkCnt = Ext_curTxOkCnt ;
-		curRxOkCnt = Ext_curRxOkCnt ;
-	}
-	//
-	IOTPeer=pMgntInfo->IOTPeer;
-	bBiasOnRx=(pMgntInfo->IOTAction & HT_IOT_ACT_EDCA_BIAS_ON_RX)?TRUE:FALSE;
-	bEdcaTurboOn=((!pHalData->bIsAnyNonBEPkts))?TRUE:FALSE;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("bIsAnyNonBEPkts : 0x%lx  \n",pHalData->bIsAnyNonBEPkts));
-
-
-////===============================
-////check if edca turbo is disabled
-////===============================
-	if(odm_IsEdcaTurboDisable(pDM_Odm))
-	{
-		pHalData->bIsAnyNonBEPkts = FALSE;
-		pMgntInfo->lastTxOkCnt = Adapter->TxStats.NumTxBytesUnicast;
-		pMgntInfo->lastRxOkCnt = Adapter->RxStats.NumRxBytesUnicast;
-		pMgntInfo->Ext_lastTxOkCnt = pExtAdapter->TxStats.NumTxBytesUnicast;
-		pMgntInfo->Ext_lastRxOkCnt = pExtAdapter->RxStats.NumRxBytesUnicast;
-
-	}
-
-////===============================
-////remove iot case out
-////===============================
-	ODM_EdcaParaSelByIot(pDM_Odm, &EDCA_BE_UL, &EDCA_BE_DL);
-
-
-////===============================
-////Check if the status needs to be changed.
-////===============================
-	if(bEdcaTurboOn)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("bEdcaTurboOn : 0x%x bBiasOnRx : 0x%x\n",bEdcaTurboOn,bBiasOnRx));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("curTxOkCnt : 0x%lx \n",curTxOkCnt));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("curRxOkCnt : 0x%lx \n",curRxOkCnt));
-		if(bBiasOnRx)
-			odm_EdcaChooseTrafficIdx(pDM_Odm,curTxOkCnt, curRxOkCnt,   TRUE,  pbIsCurRDLState);
-		else
-			odm_EdcaChooseTrafficIdx(pDM_Odm,curTxOkCnt, curRxOkCnt,   FALSE,  pbIsCurRDLState);
-
-//modify by Guo.Mingzhi 2011-12-29
-			EDCA_BE=((*pbIsCurRDLState)==TRUE)?EDCA_BE_DL:EDCA_BE_UL;
-			if(IS_HARDWARE_TYPE_8821U(Adapter))
-			{
-				if(pMgntInfo->RegTxDutyEnable)
-				{
-					//2013.01.23 LukeLee: debug for 8811AU thermal issue (reduce Tx duty cycle)
-					if(!pMgntInfo->ForcedDataRate) //auto rate
-					{
-						if(pDM_Odm->TxRate != 0xFF)
-							TxRate = Adapter->HalFunc.GetHwRateFromMRateHandler(pDM_Odm->TxRate); 
-					}
-					else //force rate
-					{
-						TxRate = (u1Byte) pMgntInfo->ForcedDataRate;
-					}
-
-					value64 = (curRxOkCnt<<2);
-					if(curTxOkCnt < value64) //Downlink
-						ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-					else //Uplink
-					{
-						/*DbgPrint("pRFCalibrateInfo->ThermalValue = 0x%X\n", pRFCalibrateInfo->ThermalValue);*/
-						/*if(pRFCalibrateInfo->ThermalValue < pHalData->EEPROMThermalMeter)*/
-						if((pDM_Odm->RFCalibrateInfo.ThermalValue < 0x2c) || (*pDM_Odm->pBandType == BAND_ON_2_4G))
-							ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-						else
-						{
-							switch (TxRate)
-							{
-								case MGN_VHT1SS_MCS6:
-								case MGN_VHT1SS_MCS5:
-								case MGN_MCS6:
-								case MGN_MCS5:
-								case MGN_48M:
-								case MGN_54M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0x1ea42b);
-								break;
-								case MGN_VHT1SS_MCS4:
-								case MGN_MCS4:
-								case MGN_36M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa42b);
-								break;
-								case MGN_VHT1SS_MCS3:
-								case MGN_MCS3:
-								case MGN_24M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa47f);
-								break;
-								case MGN_VHT1SS_MCS2:
-								case MGN_MCS2:
-								case MGN_18M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa57f);
-								break;
-								case MGN_VHT1SS_MCS1:
-								case MGN_MCS1:
-								case MGN_9M:
-								case MGN_12M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa77f);
-								break;
-								case MGN_VHT1SS_MCS0:
-								case MGN_MCS0:
-								case MGN_6M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa87f);
-								break;
-								default:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-								break;
-							}
-						}
-					}				
-				}
-				else
-				{
-					ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-				}
-
-			}
-			else if (IS_HARDWARE_TYPE_8812AU(Adapter)){
-				if(pMgntInfo->RegTxDutyEnable)
-				{
-					//2013.07.26 Wilson: debug for 8812AU thermal issue (reduce Tx duty cycle)
-					// it;s the same issue as 8811AU
-					if(!pMgntInfo->ForcedDataRate) //auto rate
-					{
-						if(pDM_Odm->TxRate != 0xFF)
-							TxRate = Adapter->HalFunc.GetHwRateFromMRateHandler(pDM_Odm->TxRate); 
-					}
-					else //force rate
-					{
-						TxRate = (u1Byte) pMgntInfo->ForcedDataRate;
-					}
-
-					value64 = (curRxOkCnt<<2);
-					if(curTxOkCnt < value64) //Downlink
-						ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-					else //Uplink
-					{
-						/*DbgPrint("pRFCalibrateInfo->ThermalValue = 0x%X\n", pRFCalibrateInfo->ThermalValue);*/
-						/*if(pRFCalibrateInfo->ThermalValue < pHalData->EEPROMThermalMeter)*/
-						if((pDM_Odm->RFCalibrateInfo.ThermalValue < 0x2c) || (*pDM_Odm->pBandType == BAND_ON_2_4G))
-							ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-						else
-						{
-							switch (TxRate)
-							{
-								case MGN_VHT2SS_MCS9:
-								case MGN_VHT1SS_MCS9:									
-								case MGN_VHT1SS_MCS8:
-								case MGN_MCS15:
-								case MGN_MCS7:									
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0x1ea44f);							
-								case MGN_VHT2SS_MCS8:
-								case MGN_VHT1SS_MCS7:
-								case MGN_MCS14:
-								case MGN_MCS6:
-								case MGN_54M:									
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa44f);
-								case MGN_VHT2SS_MCS7:
-								case MGN_VHT2SS_MCS6:
-								case MGN_VHT1SS_MCS6:
-								case MGN_VHT1SS_MCS5:
-								case MGN_MCS13:
-								case MGN_MCS5:
-								case MGN_48M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa630);
-								break;
-								case MGN_VHT2SS_MCS5:
-								case MGN_VHT2SS_MCS4:
-								case MGN_VHT1SS_MCS4:
-								case MGN_VHT1SS_MCS3:	
-								case MGN_MCS12:
-								case MGN_MCS4:	
-								case MGN_MCS3:	
-								case MGN_36M:
-								case MGN_24M:	
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa730);
-								break;
-								case MGN_VHT2SS_MCS3:
-								case MGN_VHT2SS_MCS2:
-								case MGN_VHT2SS_MCS1:
-								case MGN_VHT1SS_MCS2:
-								case MGN_VHT1SS_MCS1:	
-								case MGN_MCS11:	
-								case MGN_MCS10:	
-								case MGN_MCS9:		
-								case MGN_MCS2:	
-								case MGN_MCS1:
-								case MGN_18M:	
-								case MGN_12M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa830);
-								break;
-								case MGN_VHT2SS_MCS0:
-								case MGN_VHT1SS_MCS0:
-								case MGN_MCS0:	
-								case MGN_MCS8:
-								case MGN_9M:	
-								case MGN_6M:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,0xa87f);
-								break;
-								default:
-									ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-								break;
-							}
-						}
-					}				
-				}
-				else
-				{
-					ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-				}
-			}
-			else
-				ODM_Write4Byte(pDM_Odm,ODM_EDCA_BE_PARAM,EDCA_BE);
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("EDCA Turbo on: EDCA_BE:0x%lx\n",EDCA_BE));
-
-		pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = TRUE;
-		
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("EDCA_BE_DL : 0x%lx  EDCA_BE_UL : 0x%lx  EDCA_BE : 0x%lx  \n",EDCA_BE_DL,EDCA_BE_UL,EDCA_BE));
-
-	}
-	else
-	{
-		// Turn Off EDCA turbo here.
-		// Restore original EDCA according to the declaration of AP.
-		 if(pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA)
-		{
-			Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_AC_PARAM, GET_WMM_PARAM_ELE_SINGLE_AC_PARAM(pStaQos->WMMParamEle, AC0_BE) );
-
-			pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = FALSE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Restore EDCA BE: 0x%lx  \n",pDM_Odm->WMMEDCA_BE));
-
-		}
-	}
-
-}
-
-
-//check if edca turbo is disabled
-BOOLEAN
-odm_IsEdcaTurboDisable(
-	IN 	PVOID	 	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		       Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO			pMgntInfo = &Adapter->MgntInfo;
-	u4Byte				IOTPeer=pMgntInfo->IOTPeer;
-
-	if(pDM_Odm->bBtDisableEdcaTurbo)
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD, ("EdcaTurboDisable for BT!!\n"));
-		return TRUE;
-	}
-
-	if((!(pDM_Odm->SupportAbility& ODM_MAC_EDCA_TURBO ))||
-		(pDM_Odm->bWIFITest)||
-		(IOTPeer>= HT_IOT_PEER_MAX))
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD, ("EdcaTurboDisable\n"));
-		return TRUE;
-	}
-
-
-	// 1. We do not turn on EDCA turbo mode for some AP that has IOT issue
-	// 2. User may disable EDCA Turbo mode with OID settings.
-	if(pMgntInfo->IOTAction & HT_IOT_ACT_DISABLE_EDCA_TURBO){
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD, ("IOTAction:EdcaTurboDisable\n"));
-		return	TRUE;
-		}
-		
-	return	FALSE;
-	
-
-}
-
-//add iot case here: for MP/CE
-VOID 
-ODM_EdcaParaSelByIot(
-	IN 	PVOID	 	pDM_VOID,
-	OUT	u4Byte		*EDCA_BE_UL,
-	OUT u4Byte		*EDCA_BE_DL
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		       Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	u4Byte                         IOTPeer=0;
-	u4Byte                         ICType=pDM_Odm->SupportICType;
-	u1Byte                         WirelessMode=0xFF;                   //invalid value
-	u4Byte				RFType=pDM_Odm->RFType;
-	u4Byte                         IOTPeerSubType = 0;
-
-	PMGNT_INFO			pMgntInfo = &Adapter->MgntInfo;
-	u1Byte 				TwoPortStatus = (u1Byte)TWO_PORT_STATUS__WITHOUT_ANY_ASSOCIATE;
-
-	if(pDM_Odm->pWirelessMode!=NULL)
-		WirelessMode=*(pDM_Odm->pWirelessMode);
-		
-///////////////////////////////////////////////////////////
-////list paramter for different platform
-
-	IOTPeer=pMgntInfo->IOTPeer;
-	IOTPeerSubType=pMgntInfo->IOTPeerSubtype;
-	GetTwoPortSharedResource(Adapter,TWO_PORT_SHARED_OBJECT__STATUS,NULL,&TwoPortStatus);
-
-
-	if(ICType==ODM_RTL8192D)
-	{      
-		// Single PHY
-		if(pDM_Odm->RFType==ODM_2T2R)
-		{
-			(*EDCA_BE_UL) = 0x60a42b;    //0x5ea42b;
-			(*EDCA_BE_DL) = 0x60a42b;    //0x5ea42b;
-
-		}
-		else
-		{
-			(*EDCA_BE_UL) = 0x6ea42b;
-			(*EDCA_BE_DL) = 0x6ea42b;
-		}
-
-	}
-////============================
-/// IOT case for MP
-////============================	
-
-	else
-	{
-
-		if(pDM_Odm->SupportInterface==ODM_ITRF_PCIE){
-			if((ICType==ODM_RTL8192C)&&(pDM_Odm->RFType==ODM_2T2R))			{
-				(*EDCA_BE_UL) = 0x60a42b;
-				(*EDCA_BE_DL) = 0x60a42b;
-			}
-			else
-			{
-				(*EDCA_BE_UL) = 0x6ea42b;
-				(*EDCA_BE_DL) = 0x6ea42b;
-			}
-		}
-	}
- 
-	if(TwoPortStatus == TWO_PORT_STATUS__EXTENSION_ONLY)
-	{
-		(*EDCA_BE_UL) = 0x5ea42b;//Parameter suggested by Scott  //edca_setting_UL[ExtAdapter->MgntInfo.IOTPeer];
-		(*EDCA_BE_DL) = 0x5ea42b;//Parameter suggested by Scott  //edca_setting_DL[ExtAdapter->MgntInfo.IOTPeer];
-	}
-     
-	#if (INTEL_PROXIMITY_SUPPORT == 1)
-	if(pMgntInfo->IntelClassModeInfo.bEnableCA == TRUE)
-	{
-		(*EDCA_BE_UL) = (*EDCA_BE_DL) = 0xa44f;
-	}
-	else
-	#endif		
-	{
-		if((pMgntInfo->IOTAction & (HT_IOT_ACT_FORCED_ENABLE_BE_TXOP|HT_IOT_ACT_AMSDU_ENABLE)))
-		{// To check whether we shall force turn on TXOP configuration.
-			if(!((*EDCA_BE_UL) & 0xffff0000))
-				(*EDCA_BE_UL) |= 0x005e0000; // Force TxOP limit to 0x005e for UL.
-			if(!((*EDCA_BE_DL) & 0xffff0000))
-				(*EDCA_BE_DL) |= 0x005e0000; // Force TxOP limit to 0x005e for DL.
-		}
-		
-		//92D txop can't be set to 0x3e for cisco1250
-		if((ICType!=ODM_RTL8192D) && (IOTPeer== HT_IOT_PEER_CISCO) &&(WirelessMode==ODM_WM_N24G))
-		{
-			(*EDCA_BE_DL) = edca_setting_DL[IOTPeer];
-			(*EDCA_BE_UL) = edca_setting_UL[IOTPeer];
-		}
-		//merge from 92s_92c_merge temp brunch v2445    20120215 
-		else if((IOTPeer == HT_IOT_PEER_CISCO) &&((WirelessMode==ODM_WM_G)||(WirelessMode==(ODM_WM_B|ODM_WM_G))||(WirelessMode==ODM_WM_A)||(WirelessMode==ODM_WM_B)))
-		{
-			(*EDCA_BE_DL) = edca_setting_DL_GMode[IOTPeer];
-		}
-		else if((IOTPeer== HT_IOT_PEER_AIRGO )&& ((WirelessMode==ODM_WM_G)||(WirelessMode==ODM_WM_A)))
-		{
-			(*EDCA_BE_DL) = 0xa630;
-		}
-
-		else if(IOTPeer == HT_IOT_PEER_MARVELL)
-		{
-			(*EDCA_BE_DL) = edca_setting_DL[IOTPeer];
-			(*EDCA_BE_UL) = edca_setting_UL[IOTPeer];
-		}
-		else if(IOTPeer == HT_IOT_PEER_ATHEROS && IOTPeerSubType != HT_IOT_PEER_TPLINK_AC1750)
-		{
-			// Set DL EDCA for Atheros peer to 0x3ea42b. Suggested by SD3 Wilson for ASUS TP issue. 
-			if(WirelessMode==ODM_WM_G)
-				(*EDCA_BE_DL) = edca_setting_DL_GMode[IOTPeer];
-			else
-				(*EDCA_BE_DL) = edca_setting_DL[IOTPeer];
-
-			if(ICType == ODM_RTL8821)
-				 (*EDCA_BE_DL) = 0x5ea630;
-			
-		}
-	}
-
-    	if((ICType == ODM_RTL8192D)&&(IOTPeerSubType == HT_IOT_PEER_LINKSYS_E4200_V1)&&((WirelessMode==ODM_WM_N5G)))
-	{
-		(*EDCA_BE_DL) = 0x432b;
-		(*EDCA_BE_UL) = 0x432b;
-	}		
-
-
-
-	if((ICType==ODM_RTL8812)||(ICType==ODM_RTL8192E))           //add 8812AU/8812AE
-	{
-		(*EDCA_BE_UL) = 0x5ea42b;
-		(*EDCA_BE_DL) = 0x5ea42b;
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("8812A: EDCA_BE_UL=0x%lx EDCA_BE_DL =0x%lx\n",(*EDCA_BE_UL),(*EDCA_BE_DL)));
-	}
-
-	if((ICType==ODM_RTL8814A) && (IOTPeer == HT_IOT_PEER_REALTEK))           /*8814AU and 8814AR*/
-	{
-		(*EDCA_BE_UL) = 0x5ea42b;
-		(*EDCA_BE_DL) = 0xa42b;
-
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("8814A: EDCA_BE_UL=0x%lx EDCA_BE_DL =0x%lx\n",(*EDCA_BE_UL),(*EDCA_BE_DL)));
-	}
-
-	
-
-	// Revised for Atheros DIR-655 IOT issue to improve down link TP, added by Roger, 2013.03.22.
-	if((ICType == ODM_RTL8723A) && (IOTPeerSubType== HT_IOT_PEER_ATHEROS_DIR655) && 
-		(pMgntInfo->dot11CurrentChannelNumber == 6))
-	{
-		(*EDCA_BE_DL) = 0xa92b;
-	}
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Special: EDCA_BE_UL=0x%lx EDCA_BE_DL =0x%lx, IOTPeer = %d\n",(*EDCA_BE_UL),(*EDCA_BE_DL), IOTPeer));
-
-}
-
-
-VOID
-odm_EdcaChooseTrafficIdx( 
-	IN 	PVOID	 	pDM_VOID,
-	IN	u8Byte  			cur_tx_bytes,  
-	IN	u8Byte  			cur_rx_bytes, 
-	IN	BOOLEAN 		bBiasOnRx,
-	OUT BOOLEAN 		*pbIsCurRDLState
-	)
-{	
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	if(bBiasOnRx)
-	{
-	  
-		if(cur_tx_bytes>(cur_rx_bytes*4))
-		{
-			*pbIsCurRDLState=FALSE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Uplink Traffic\n "));
-
-		}
-		else
-		{
-			*pbIsCurRDLState=TRUE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Balance Traffic\n"));
-
-		}
-	}
-	else
-	{
-		if(cur_rx_bytes>(cur_tx_bytes*4))
-		{
-			*pbIsCurRDLState=TRUE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Downlink	Traffic\n"));
-
-		}
-		else
-		{
-			*pbIsCurRDLState=FALSE;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_EDCA_TURBO,ODM_DBG_LOUD,("Balance Traffic\n"));
-		}
-	}
-
-	return ;
-}
-
-#endif
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_edcaturbocheck.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_edcaturbocheck.h
deleted file mode 100644
index 982df9249a19..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_edcaturbocheck.h
+++ /dev/null
@@ -1,100 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMEDCATURBOCHECK_H__
-#define    __PHYDMEDCATURBOCHECK_H__
-
-/*#define EDCATURBO_VERSION	"2.1"*/
-#define EDCATURBO_VERSION	"2.2"	/*2015.01.13*/
-
-typedef struct _EDCA_TURBO_
-{
-	BOOLEAN bCurrentTurboEDCA;
-	BOOLEAN bIsCurRDLState;
-
-	#if(DM_ODM_SUPPORT_TYPE == ODM_CE	)
-	u4Byte	prv_traffic_idx; // edca turbo
-	#endif
-
-}EDCA_T,*pEDCA_T;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-static u4Byte edca_setting_UL[HT_IOT_PEER_MAX] = 
-// UNKNOWN		REALTEK_90	REALTEK_92SE	BROADCOM		RALINK		ATHEROS		CISCO		MERU        MARVELL	92U_AP		SELF_AP(DownLink/Tx)
-{ 0x5e4322, 		0xa44f, 		0x5e4322,		0x5ea32b,  		0x5ea422, 	0x5ea322,	0x3ea430,	0x5ea42b, 0x5ea44f,	0x5e4322,	0x5e4322};
-
-
-static u4Byte edca_setting_DL[HT_IOT_PEER_MAX] = 
-// UNKNOWN		REALTEK_90	REALTEK_92SE	BROADCOM		RALINK		ATHEROS		CISCO		MERU,       MARVELL	92U_AP		SELF_AP(UpLink/Rx)
-{ 0xa44f, 		0x5ea44f, 	0x5e4322, 		0x5ea42b, 		0xa44f, 		0xa630, 		0x5ea630,	0x5ea42b, 0xa44f,		0xa42b,		0xa42b};
-
-static u4Byte edca_setting_DL_GMode[HT_IOT_PEER_MAX] = 
-// UNKNOWN		REALTEK_90	REALTEK_92SE	BROADCOM		RALINK		ATHEROS		CISCO		MERU,       MARVELL	92U_AP		SELF_AP
-{ 0x4322, 		0xa44f, 		0x5e4322,		0xa42b, 			0x5e4322, 	0x4322, 		0xa42b,		0x5ea42b, 0xa44f,		0x5e4322,	0x5ea42b};
-
-#endif
-
-
-
-VOID
-odm_EdcaTurboCheck(
-	IN 	PVOID	 	pDM_VOID
-	);
-VOID
-ODM_EdcaTurboInit(
-	IN 	PVOID	 	pDM_VOID
-);
-
-#if(DM_ODM_SUPPORT_TYPE==ODM_WIN)
-VOID
-odm_EdcaTurboCheckMP(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-//check if edca turbo is disabled
-BOOLEAN
-odm_IsEdcaTurboDisable(
-	IN 	PVOID	 	pDM_VOID
-);
-//choose edca paramter for special IOT case
-VOID 
-ODM_EdcaParaSelByIot(
-	IN		PVOID					pDM_VOID,
-	OUT	u4Byte		*EDCA_BE_UL,
-	OUT u4Byte		*EDCA_BE_DL
-	);
-//check if it is UL or DL
-VOID
-odm_EdcaChooseTrafficIdx( 
-	IN 	PVOID	 	pDM_VOID,
-	IN	u8Byte  			cur_tx_bytes,  
-	IN	u8Byte  			cur_rx_bytes, 
-	IN	BOOLEAN 		bBiasOnRx,
-	OUT BOOLEAN 		*pbIsCurRDLState
-	);
-
-#elif (DM_ODM_SUPPORT_TYPE==ODM_CE)
-VOID
-odm_EdcaTurboCheckCE(
-	IN 	PVOID	 	pDM_VOID
-	);
-#endif
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features.h
index 78b56bebb144..74995d553dd9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features.h
@@ -1,115 +1,53 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef	__PHYDM_FEATURES_H__
-#define __PHYDM_FEATURES
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	/*Antenna Diversity*/
-	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
-	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
-	
-		#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
-		#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		#endif
-		
-		#if (RTL8821A_SUPPORT == 1)
-		/*#define CONFIG_HL_SMART_ANTENNA_TYPE1*/
-		#endif
-	#endif
-
-	/*#define CONFIG_PATH_DIVERSITY*/
-	/*#define CONFIG_RA_DYNAMIC_RTY_LIMIT*/
-	#define CONFIG_ANT_DETECTION
-	#define CONFIG_RA_DBG_CMD
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-	/*  [ Configure RA Debug H2C CMD ]*/
-	#define CONFIG_RA_DBG_CMD
-	
-	/*#define CONFIG_PATH_DIVERSITY*/
-	/*#define CONFIG_RA_DYNAMIC_RTY_LIMIT*/
-	#define CONFIG_RA_DYNAMIC_RATE_ID
-	
-	/* [ Configure Antenna Diversity ] */
-	#if defined(CONFIG_RTL_8881A_ANT_SWITCH) || defined(CONFIG_SLOT_0_ANT_SWITCH) || defined(CONFIG_SLOT_1_ANT_SWITCH)
-		#define CONFIG_PHYDM_ANTENNA_DIVERSITY 
-		#define ODM_EVM_ENHANCE_ANTDIV
-
-		/*----------*/
-		
-		#if (!defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A) && !defined(CONFIG_2G_CGCS_RX_DIVERSITY) && !defined(CONFIG_2G_CG_TRX_DIVERSITY) && !defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-			#define CONFIG_NO_2G_DIVERSITY
-		#endif
-
-		#ifdef CONFIG_NO_5G_DIVERSITY_8881A
-			#define CONFIG_NO_5G_DIVERSITY
-		#elif defined(CONFIG_5G_CGCS_RX_DIVERSITY_8881A)
-			#define CONFIG_5G_CGCS_RX_DIVERSITY
-		#elif defined(CONFIG_5G_CG_TRX_DIVERSITY_8881A)
-			#define CONFIG_5G_CG_TRX_DIVERSITY
-		#elif defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A)
-			#define CONFIG_2G5G_CG_TRX_DIVERSITY
-		#endif
-		#if (!defined(CONFIG_NO_5G_DIVERSITY) && !defined(CONFIG_5G_CGCS_RX_DIVERSITY) && !defined(CONFIG_5G_CG_TRX_DIVERSITY) && !defined(CONFIG_2G5G_CG_TRX_DIVERSITY) && !defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
-			#define CONFIG_NO_5G_DIVERSITY
-		#endif	
-		 /*----------*/
-		#if (defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY))
-			#define CONFIG_NOT_SUPPORT_ANTDIV 
-		#elif (!defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY))
-			#define CONFIG_2G_SUPPORT_ANTDIV
-		#elif (defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY))
-			#define CONFIG_5G_SUPPORT_ANTDIV
-		#elif ((!defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY)) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY))
-			#define CONFIG_2G5G_SUPPORT_ANTDIV 
-		#endif
-		 /*----------*/
-	#endif
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-	/*Antenna Diversity*/
-	#ifdef CONFIG_ANTENNA_DIVERSITY
-		#define CONFIG_PHYDM_ANTENNA_DIVERSITY
-		
-		#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
-		
-			#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
-			#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-			#endif
-			
-			#if (RTL8821A_SUPPORT == 1)
-			/*#define CONFIG_HL_SMART_ANTENNA_TYPE1*/
-			#endif
-		#endif
-	#endif
-	
-	/*#define CONFIG_RA_DBG_CMD*/
-	/*#define CONFIG_ANT_DETECTION*/
-	/*#define CONFIG_PATH_DIVERSITY*/
-	/*#define CONFIG_RA_DYNAMIC_RTY_LIMIT*/
-
-#endif
-
-
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_FEATURES_H__
+#define __PHYDM_FEATURES_H__
+
+#define ODM_DC_CANCELLATION_SUPPORT		(ODM_RTL8188F | ODM_RTL8710B)
+#define ODM_RECEIVER_BLOCKING_SUPPORT	(ODM_RTL8188E | ODM_RTL8192E)
+
+#if ((RTL8814A_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+	#define PHYDM_LA_MODE_SUPPORT			1
+#else
+	#define PHYDM_LA_MODE_SUPPORT			0
+#endif
+
+/*20170103 YuChen add for FW API*/
+#define PHYDM_FW_API_ENABLE_8822B			1
+#define PHYDM_FW_API_FUNC_ENABLE_8822B		1
+#define PHYDM_FW_API_ENABLE_8821C			1
+#define PHYDM_FW_API_FUNC_ENABLE_8821C		1
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#include	"phydm_features_win.h"
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#include	"phydm_features_ce.h"
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#include	"phydm_features_ap.h"
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_ap.h
new file mode 100644
index 000000000000..5a64f8a59997
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_ap.h
@@ -0,0 +1,132 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDM_FEATURES_AP_H__
+#define __PHYDM_FEATURES_AP_H__
+
+#if (RTL8822B_SUPPORT == 1 || RTL8812A_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	/*#define PHYDM_TDMA_DIG_SUPPORT*/
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	#define PHYDM_LNA_SAT_CHK_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_POWER_TRAINING_SUPPORT*/
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#define PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
+	#define	PHYDM_PRIMARY_CCA
+#endif
+
+#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	/*#define	CONFIG_ADAPTIVE_SOML*/
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8821A_SUPPORT == 1 || RTL8881A_SUPPORT == 1 || RTL8192E_SUPPORT == 1 || RTL8723B_SUPPORT == 1)
+	/*#define	CONFIG_RA_FW_DBG_CODE*/
+#endif
+
+/* #define CONFIG_DYNAMIC_TX_TWR */
+#define PHYDM_DIG_MODE_DECISION_SUPPORT
+/*#define	CONFIG_PSD_TOOL*/
+#define PHYDM_SUPPORT_CCKPD
+#define RA_MASK_PHYDMLIZE_AP
+/* #define	CONFIG_RA_DBG_CMD*/
+/*#define	CONFIG_PATH_DIVERSITY*/
+/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+#define	CONFIG_RA_DYNAMIC_RATE_ID
+#define	CONFIG_BB_TXBF_API
+/*#define	ODM_CONFIG_BT_COEXIST*/
+/*#define	PHYDM_3RD_REFORM_RA_MASK*/
+#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+#if !defined(CONFIG_DISABLE_PHYDM_DEBUG_FUNCTION)
+	#define CONFIG_PHYDM_DEBUG_FUNCTION
+#endif
+
+/* [ Configure Antenna Diversity ] */
+#if defined(CONFIG_RTL_8881A_ANT_SWITCH) || defined(CONFIG_SLOT_0_ANT_SWITCH) || defined(CONFIG_SLOT_1_ANT_SWITCH)
+	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
+	#define ODM_EVM_ENHANCE_ANTDIV
+	#define SKIP_EVM_ANTDIV_TRAINING_PATCH
+
+	/*----------*/
+
+	#if (!defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A) && !defined(CONFIG_2G_CGCS_RX_DIVERSITY) && !defined(CONFIG_2G_CG_TRX_DIVERSITY) && !defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		#define CONFIG_NO_2G_DIVERSITY
+	#endif
+
+	#ifdef CONFIG_NO_5G_DIVERSITY_8881A
+		#define CONFIG_NO_5G_DIVERSITY
+	#elif defined(CONFIG_5G_CGCS_RX_DIVERSITY_8881A)
+		#define CONFIG_5G_CGCS_RX_DIVERSITY
+	#elif defined(CONFIG_5G_CG_TRX_DIVERSITY_8881A)
+		#define CONFIG_5G_CG_TRX_DIVERSITY
+	#elif defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A)
+		#define CONFIG_2G5G_CG_TRX_DIVERSITY
+	#endif
+	#if (!defined(CONFIG_NO_5G_DIVERSITY) && !defined(CONFIG_5G_CGCS_RX_DIVERSITY) && !defined(CONFIG_5G_CG_TRX_DIVERSITY) && !defined(CONFIG_2G5G_CG_TRX_DIVERSITY) && !defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
+		#define CONFIG_NO_5G_DIVERSITY
+	#endif
+	/*----------*/
+	#if (defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY))
+		#define CONFIG_NOT_SUPPORT_ANTDIV
+	#elif (!defined(CONFIG_NO_2G_DIVERSITY) && defined(CONFIG_NO_5G_DIVERSITY))
+		#define CONFIG_2G_SUPPORT_ANTDIV
+	#elif (defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY))
+		#define CONFIG_5G_SUPPORT_ANTDIV
+	#elif ((!defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_NO_5G_DIVERSITY)) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY))
+			#define CONFIG_2G5G_SUPPORT_ANTDIV
+	#endif
+		/*----------*/
+#endif /*Antenna Diveristy*/
+
+/*[SmartAntenna]*/
+/*#define	CONFIG_SMART_ANTENNA*/
+#ifdef CONFIG_SMART_ANTENNA
+	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+#endif
+/* --------------------------------------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_ce.h
new file mode 100644
index 000000000000..33b1879b3868
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_ce.h
@@ -0,0 +1,133 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_FEATURES_CE_H__
+#define __PHYDM_FEATURES_CE_H__
+
+#if (RTL8822B_SUPPORT == 1 || RTL8812A_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+/*#define PHYDM_TDMA_DIG_SUPPORT*/
+/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+
+#if (RTL8822B_SUPPORT == 1)
+	#define PHYDM_POWER_TRAINING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#define PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+	#define	PHYDM_PRIMARY_CCA
+#endif
+
+#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define	CONFIG_ADAPTIVE_SOML
+#endif
+
+
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#endif
+
+#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	#define	CONFIG_RECEIVER_BLOCKING
+#endif
+
+/* #define CONFIG_DYNAMIC_TX_TWR */
+#define PHYDM_SUPPORT_CCKPD
+#define RA_MASK_PHYDMLIZE_CE
+
+/*Antenna Diversity*/
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+		#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1)
+			#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		#endif
+
+		#if (RTL8821A_SUPPORT == 1)
+			/*#define CONFIG_HL_SMART_ANTENNA_TYPE1*/
+		#endif
+
+		#if (RTL8822B_SUPPORT == 1)
+			/*#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
+		#endif
+	#endif
+#endif
+
+/*[SmartAntenna]*/
+/*#define	CONFIG_SMART_ANTENNA*/
+#ifdef CONFIG_SMART_ANTENNA
+	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+#endif
+/* --------------------------------------------------*/
+
+#ifdef CONFIG_DFS_MASTER
+	#define CONFIG_PHYDM_DFS_MASTER
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8821A_SUPPORT == 1 || RTL8881A_SUPPORT == 1 || RTL8192E_SUPPORT == 1 || RTL8723B_SUPPORT == 1)
+	/*#define	CONFIG_RA_FW_DBG_CODE*/
+#endif
+
+/*#define PHYDM_DIG_MODE_DECISION_SUPPORT*/
+#define	CONFIG_PSD_TOOL
+/*#define	CONFIG_RA_DBG_CMD*/
+/*#define	CONFIG_ANT_DETECTION*/
+/*#define	CONFIG_PATH_DIVERSITY*/
+/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+#define	CONFIG_BB_TXBF_API
+#define	CONFIG_PHYDM_DEBUG_FUNCTION
+
+#ifdef CONFIG_BT_COEXIST
+	#define	ODM_CONFIG_BT_COEXIST
+#endif
+#define	PHYDM_3RD_REFORM_RA_MASK
+#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+/*#define	PHYDM_AUTO_DEGBUG*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_win.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_win.h
new file mode 100644
index 000000000000..16b6021c198b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_features_win.h
@@ -0,0 +1,121 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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	__PHYDM_FEATURES_WIN_H__
+#define __PHYDM_FEATURES_WIN_H__
+
+#if (RTL8822B_SUPPORT == 1 || RTL8812A_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+/*#define PHYDM_TDMA_DIG_SUPPORT*/
+/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+
+#if (RTL8822B_SUPPORT == 1)
+	#define	PHYDM_POWER_TRAINING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	#define	PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	#define	PHYDM_PRIMARY_CCA
+#endif
+
+#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	/*#define	CONFIG_ADAPTIVE_SOML*/
+#endif
+
+
+/*Antenna Diversity*/
+#define	CONFIG_PHYDM_ANTENNA_DIVERSITY
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+	#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1)
+		#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	#endif
+
+	/* --[SmtAnt]-----------------------------------------*/
+	#if (RTL8821A_SUPPORT == 1)
+		/*#define	CONFIG_HL_SMART_ANTENNA_TYPE1*/
+		#define	CONFIG_FAT_PATCH
+	#endif
+	
+	#if (RTL8822B_SUPPORT == 1)
+		/*#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
+	#endif
+	
+	#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1) || defined(CONFIG_HL_SMART_ANTENNA_TYPE2))
+		#define	CONFIG_HL_SMART_ANTENNA
+	#endif
+
+	/* --------------------------------------------------*/
+
+#endif
+
+/*[SmartAntenna]*/
+#define	CONFIG_SMART_ANTENNA
+#ifdef CONFIG_SMART_ANTENNA
+		/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+#endif
+	/* --------------------------------------------------*/
+
+#if (RTL8822B_SUPPORT == 1)
+	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#endif
+
+#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+	#define	CONFIG_RECEIVER_BLOCKING
+#endif
+
+#if (RTL8812A_SUPPORT == 1 || RTL8821A_SUPPORT == 1 || RTL8881A_SUPPORT == 1 || RTL8192E_SUPPORT == 1 || RTL8723B_SUPPORT == 1)
+	#define	CONFIG_RA_FW_DBG_CODE
+#endif
+
+/* #define CONFIG_DYNAMIC_TX_TWR */
+/*#define PHYDM_DIG_MODE_DECISION_SUPPORT	*/
+#define	CONFIG_PSD_TOOL
+#define	PHYDM_SUPPORT_CCKPD
+#define	RA_MASK_PHYDMLIZE_WIN
+/*#define	CONFIG_PATH_DIVERSITY*/
+/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+#define CONFIG_ANT_DETECTION
+/*#define	CONFIG_RA_DBG_CMD*/
+#define	CONFIG_BB_TXBF_API
+#define	ODM_CONFIG_BT_COEXIST
+#define	PHYDM_3RD_REFORM_RA_MASK
+#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
+#define	CONFIG_PHYDM_DFS_MASTER
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+#define	PHYDM_AUTO_DEGBUG
+#define CONFIG_PHYDM_DEBUG_FUNCTION
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.c
index 1d5765986ddd..21f927f7abec 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.c
@@ -1,3331 +1,1026 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#define READ_AND_CONFIG_MP(ic, txt) (ODM_ReadAndConfig_MP_##ic##txt(pDM_Odm))
-#define READ_AND_CONFIG_TC(ic, txt) (ODM_ReadAndConfig_TC_##ic##txt(pDM_Odm))
-
-
-#if (PHYDM_TESTCHIP_SUPPORT == 1)
-#define READ_AND_CONFIG(ic, txt) do {\
-                                            if (pDM_Odm->bIsMPChip)\
-                                    		    READ_AND_CONFIG_MP(ic,txt);\
-                                            else\
-                                                READ_AND_CONFIG_TC(ic,txt);\
-                                    } while(0)
-#else
-  #define READ_AND_CONFIG     READ_AND_CONFIG_MP
-#endif
-
-
-#define READ_FIRMWARE_MP(ic, txt) 		(ODM_ReadFirmware_MP_##ic##txt(pDM_Odm, pFirmware, pSize))
-#define READ_FIRMWARE_TC(ic, txt) 		(ODM_ReadFirmware_TC_##ic##txt(pDM_Odm, pFirmware, pSize))		
-
-#if (PHYDM_TESTCHIP_SUPPORT == 1)
-#define READ_FIRMWARE(ic, txt) do {\
-						if (pDM_Odm->bIsMPChip)\
-							READ_FIRMWARE_MP(ic,txt);\
-						else\
-							READ_FIRMWARE_TC(ic,txt);\
-					} while(0) 
-#else
-#define READ_FIRMWARE     READ_FIRMWARE_MP
-#endif
-						
-#define GET_VERSION_MP(ic, txt) 		(ODM_GetVersion_MP_##ic##txt())
-#define GET_VERSION_TC(ic, txt) 		(ODM_GetVersion_TC_##ic##txt())
-#define GET_VERSION(ic, txt) (pDM_Odm->bIsMPChip?GET_VERSION_MP(ic,txt):GET_VERSION_TC(ic,txt))
-
-u1Byte
-odm_QueryRxPwrPercentage(
-	IN		s1Byte		AntPower
-	)
-{
-	if ((AntPower <= -100) || (AntPower >= 20))
-	{
-		return	0;
-	}
-	else if (AntPower >= 0)
-	{
-		return	100;
-	}
-	else
-	{
-		return	(100+AntPower);
-	}
-	
-}
-
-
-//
-// 2012/01/12 MH MOve some signal strength smooth method to MP HAL layer.
-// IF other SW team do not support the feature, remove this section.??
-//
-s4Byte
-odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Lenovo(	
-	IN OUT PDM_ODM_T pDM_Odm,
-	s4Byte CurrSig 
-)
-{	
-	s4Byte RetSig = 0;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	//if(pDM_Odm->SupportInterface  == ODM_ITRF_PCIE) 
-	{
-		// Step 1. Scale mapping.
-		// 20100611 Joseph: Re-tunning RSSI presentation for Lenovo.
-		// 20100426 Joseph: Modify Signal strength mapping.
-		// This modification makes the RSSI indication similar to Intel solution.
-		// 20100414 Joseph: Tunning RSSI for Lenovo according to RTL8191SE.
-		if(CurrSig >= 54 && CurrSig <= 100)
-		{
-			RetSig = 100;
-		}
-		else if(CurrSig>=42 && CurrSig <= 53 )
-		{
-			RetSig = 95;
-		}
-		else if(CurrSig>=36 && CurrSig <= 41 )
-		{
-			RetSig = 74 + ((CurrSig - 36) *20)/6;
-		}
-		else if(CurrSig>=33 && CurrSig <= 35 )
-		{
-			RetSig = 65 + ((CurrSig - 33) *8)/2;
-		}
-		else if(CurrSig>=18 && CurrSig <= 32 )
-		{
-			RetSig = 62 + ((CurrSig - 18) *2)/15;
-		}
-		else if(CurrSig>=15 && CurrSig <= 17 )
-		{
-			RetSig = 33 + ((CurrSig - 15) *28)/2;
-		}
-		else if(CurrSig>=10 && CurrSig <= 14 )
-		{
-			RetSig = 39;
-		}
-		else if(CurrSig>=8 && CurrSig <= 9 )
-		{
-			RetSig = 33;
-		}
-		else if(CurrSig <= 8 )
-		{
-			RetSig = 19;
-		}
-	}
-#endif //ENDIF (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	return RetSig;
-}
-
-s4Byte
-odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Netcore(	
-	IN OUT PDM_ODM_T pDM_Odm,
-	s4Byte CurrSig 
-)
-{
-	s4Byte RetSig = 0;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	//if(pDM_Odm->SupportInterface  == ODM_ITRF_USB)
-	{
-		// Netcore request this modification because 2009.04.13 SU driver use it. 
-		if(CurrSig >= 31 && CurrSig <= 100)
-		{
-			RetSig = 100;
-		}	
-		else if(CurrSig >= 21 && CurrSig <= 30)
-		{
-			RetSig = 90 + ((CurrSig - 20) / 1);
-		}
-		else if(CurrSig >= 11 && CurrSig <= 20)
-		{
-			RetSig = 80 + ((CurrSig - 10) / 1);
-		}
-		else if(CurrSig >= 7 && CurrSig <= 10)
-		{
-			RetSig = 69 + (CurrSig - 7);
-		}
-		else if(CurrSig == 6)
-		{
-			RetSig = 54;
-		}
-		else if(CurrSig == 5)
-		{
-			RetSig = 45;
-		}
-		else if(CurrSig == 4)
-		{
-			RetSig = 36;
-		}
-		else if(CurrSig == 3)
-		{
-			RetSig = 27;
-		}
-		else if(CurrSig == 2)
-		{
-			RetSig = 18;
-		}
-		else if(CurrSig == 1)
-		{
-			RetSig = 9;
-		}
-		else
-		{
-			RetSig = CurrSig;
-		}
-	}
-#endif //ENDIF (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	return RetSig;
-}
-
-
-s4Byte
-odm_SignalScaleMapping_92CSeries(	
-	IN OUT PDM_ODM_T pDM_Odm,
-	IN s4Byte CurrSig 
-)
-{
-	s4Byte RetSig = 0; 
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE) 
-	if(pDM_Odm->SupportInterface  == ODM_ITRF_PCIE) 
-	{
-		// Step 1. Scale mapping.
-		if(CurrSig >= 61 && CurrSig <= 100)
-		{
-			RetSig = 90 + ((CurrSig - 60) / 4);
-		}
-		else if(CurrSig >= 41 && CurrSig <= 60)
-		{
-			RetSig = 78 + ((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 >= 5 && CurrSig <= 20)
-		{
-			RetSig = 42 + (((CurrSig - 5) * 2) / 3);
-		}
-		else if(CurrSig == 4)
-		{
-			RetSig = 36;
-		}
-		else if(CurrSig == 3)
-		{
-			RetSig = 27;
-		}
-		else if(CurrSig == 2)
-		{
-			RetSig = 18;
-		}
-		else if(CurrSig == 1)
-		{
-			RetSig = 9;
-		}
-		else
-		{
-			RetSig = CurrSig;
-		}
-	}
-#endif
-
-#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) ||(DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-	if((pDM_Odm->SupportInterface  == ODM_ITRF_USB) || (pDM_Odm->SupportInterface  == ODM_ITRF_SDIO))
-	{
-		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;
-		}
-	}
-
-#endif
-	return RetSig;
-}
-s4Byte
-odm_SignalScaleMapping(	
-	IN OUT PDM_ODM_T pDM_Odm,
-	IN	s4Byte CurrSig 
-)
-{	
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if(	(pDM_Odm->SupportPlatform == ODM_WIN) && 
-		(pDM_Odm->SupportInterface  != ODM_ITRF_PCIE) && //USB & SDIO
-		(pDM_Odm->PatchID==10))//pMgntInfo->CustomerID == RT_CID_819x_Netcore
-	{
-		return odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Netcore(pDM_Odm,CurrSig);
-	}
-	else if(	(pDM_Odm->SupportPlatform == ODM_WIN) && 
-			(pDM_Odm->SupportInterface  == ODM_ITRF_PCIE) &&
-			(pDM_Odm->PatchID==19))//pMgntInfo->CustomerID == RT_CID_819x_Lenovo)
-	{
-		return odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Lenovo(pDM_Odm, CurrSig);
-	}else
-#endif
-        {		
-		return odm_SignalScaleMapping_92CSeries(pDM_Odm,CurrSig);
-	}
-	
-}
-
-
-
-static u1Byte odm_SQ_process_patch_RT_CID_819x_Lenovo(
-	IN PDM_ODM_T	pDM_Odm,
-	IN u1Byte 		isCCKrate,
-	IN u1Byte 		PWDB_ALL,
-	IN u1Byte 		path,
-	IN u1Byte 		RSSI
-)
-{
-	u1Byte	SQ = 0;
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)			
-
-	if(isCCKrate){
-		
-		if(IS_HARDWARE_TYPE_8723AE(pDM_Odm->Adapter))
-		{
-
-			//
-			// <Roger_Notes> Expected signal strength and bars indication at Lenovo lab. 2013.04.11
-			// 802.11n, 802.11b, 802.11g only at channel 6
-			//
-			//		Attenuation (dB)	OS Signal Bars	RSSI by Xirrus (dBm)
-			//			50				5			-52
-			//			55				5			-54
-			//			60				5			-55
-			//			65				5			-59
-			//			70				5			-63
-			//			75				5			-66
-			//			80				4			-72
-			//			85				3			-75
-			//			90				3			-80
-			//			95				2			-85
-			//			100				1			-89
-			//			102				1			-90
-			//			104				1			-91
-			//
-			RT_TRACE(COMP_DBG, DBG_WARNING, ("odm_SQ_process_patch_RT_CID_819x_Lenovo\n"));
-			
-#if OS_WIN_FROM_WIN8(OS_VERSION)	
-			if(PWDB_ALL >= 50)
-				SQ = 100;
-			else if(PWDB_ALL >= 23 && PWDB_ALL < 50)				
-				SQ = 80;
-			else if(PWDB_ALL >= 18 && PWDB_ALL < 23)
-				SQ = 60;
-			else if(PWDB_ALL >= 8 && PWDB_ALL < 18)
-				SQ = 40;
-			else
-				SQ = 10;
-#else
-			if(PWDB_ALL >= 34)
-				SQ = 100;
-			else if(PWDB_ALL >= 23 && PWDB_ALL < 34)				
-				SQ = 80;
-			else if(PWDB_ALL >= 18 && PWDB_ALL < 23)
-				SQ = 60;
-			else if(PWDB_ALL >= 8 && PWDB_ALL < 18)
-				SQ = 40;
-			else
-				SQ = 10;	
-
-			if(PWDB_ALL == 0)// Abnormal case, do not indicate the value above 20 on Win7
-				SQ = 20;
-#endif		
-
-		}
-		else if(IS_HARDWARE_TYPE_8192E(pDM_Odm->Adapter)){
-
-			//
-			// <Roger_Notes> Expected signal strength and bars indication at Lenovo lab. 2013.04.11
-			// 802.11n, 802.11b, 802.11g only at channel 6
-			//
-			//		Attenuation (dB)	OS Signal Bars	RSSI by Xirrus (dBm)
-			//			50				5			-49
-			//			55				5			-49
-			//			60				5			-50
-			//			65				5			-51
-			//			70				5			-52
-			//			75				5			-54
-			//			80				5			-55
-			//			85				4			-60
-			//			90				3			-63
-			//			95				3			-65
-			//			100				2			-67
-			//			102				2			-67
-			//			104				1			-70
-			//			
-
-			if(PWDB_ALL >= 50)
-				SQ = 100;
-			else if(PWDB_ALL >= 35 && PWDB_ALL < 50)				
-				SQ = 80;
-			else if(PWDB_ALL >= 31 && PWDB_ALL < 35)
-				SQ = 60;
-			else if(PWDB_ALL >= 22 && PWDB_ALL < 31)
-				SQ = 40;
-			else if(PWDB_ALL >= 18 && PWDB_ALL < 22)
-				SQ = 20;
-			else
-				SQ = 10;
-		} else {
-			if (PWDB_ALL >= 50)
-				SQ = 100;
-			else if (PWDB_ALL >= 35 && PWDB_ALL < 50)				
-				SQ = 80;
-			else if (PWDB_ALL >= 22 && PWDB_ALL < 35)
-				SQ = 60;
-			else if (PWDB_ALL >= 18 && PWDB_ALL < 22)
-				SQ = 40;
-			else
-				SQ = 10;
-		}
-		
-	}
-	else
-	{//OFDM rate		
-
-		if(IS_HARDWARE_TYPE_8723AE(pDM_Odm->Adapter) ||
-			IS_HARDWARE_TYPE_8192E(pDM_Odm->Adapter))
-		{
-			if(RSSI >= 45)
-				SQ = 100;
-			else if(RSSI >= 22 && RSSI < 45)
-				SQ = 80;
-			else if(RSSI >= 18 && RSSI < 22)
-				SQ = 40;
-			else
-			SQ = 20;
-		} else {
-			if(RSSI >= 45)
-			SQ = 100;
-			else if(RSSI >= 22 && RSSI < 45)
-			SQ = 80;
-		else if(RSSI >= 18 && RSSI < 22)
-			SQ = 40;
-		else
-			SQ = 20;			
-		}
-	}
-
-	RT_TRACE(COMP_DBG, DBG_TRACE, ("isCCKrate(%#d), PWDB_ALL(%#d), RSSI(%#d), SQ(%#d)\n", isCCKrate, PWDB_ALL, RSSI, SQ));
-	
-#endif
-	return SQ;
-}
-
-static u1Byte odm_SQ_process_patch_RT_CID_819x_Acer(
-	IN PDM_ODM_T	pDM_Odm,
-	IN u1Byte 		isCCKrate,
-	IN u1Byte 		PWDB_ALL,
-	IN u1Byte 		path,
-	IN u1Byte 		RSSI
-)
-{
-	u1Byte	SQ = 0;
-	
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)			
-
-	if(isCCKrate){
-
-			RT_TRACE(COMP_DBG, DBG_WARNING, ("odm_SQ_process_patch_RT_Acer\n"));
-			
-#if OS_WIN_FROM_WIN8(OS_VERSION)	
-
-			if(PWDB_ALL >= 50)
-				SQ = 100;
-			else if(PWDB_ALL >= 35 && PWDB_ALL < 50)				
-				SQ = 80;
-			else if(PWDB_ALL >= 30 && PWDB_ALL < 35)
-				SQ = 60;
-			else if(PWDB_ALL >= 25 && PWDB_ALL < 30)
-				SQ = 40;
-			else if(PWDB_ALL >= 20 && PWDB_ALL < 25)
-				SQ = 20;
-			else
-				SQ = 10;	
-#else
-			if(PWDB_ALL >= 50)
-				SQ = 100;
-			else if(PWDB_ALL >= 35 && PWDB_ALL < 50)				
-				SQ = 80;
-			else if(PWDB_ALL >= 30 && PWDB_ALL < 35)
-				SQ = 60;
-			else if(PWDB_ALL >= 25 && PWDB_ALL < 30)
-				SQ = 40;
-			else if(PWDB_ALL >= 20 && PWDB_ALL < 25)
-				SQ = 20;
-			else
-				SQ = 10;	
-
-			if(PWDB_ALL == 0)// Abnormal case, do not indicate the value above 20 on Win7
-				SQ = 20;
-#endif		
-
-		
-		
-	}
-	else
-	{//OFDM rate		
-
-		if(IS_HARDWARE_TYPE_8723AE(pDM_Odm->Adapter) ||
-			IS_HARDWARE_TYPE_8192E(pDM_Odm->Adapter))
-		{
-			if(RSSI >= 45)
-				SQ = 100;
-			else if(RSSI >= 22 && RSSI < 45)
-				SQ = 80;
-			else if(RSSI >= 18 && RSSI < 22)
-				SQ = 40;
-			else
-			SQ = 20;
-	}
-		else
-		{
-			if(RSSI >= 35)
-			SQ = 100;
-			else if(RSSI >= 30 && RSSI < 35)
-			SQ = 80;
-		else if(RSSI >= 25 && RSSI < 30)
-			SQ = 40;
-		else
-			SQ = 20;			
-	}
-	}
-
-	RT_TRACE(COMP_DBG, DBG_LOUD, ("isCCKrate(%#d), PWDB_ALL(%#d), RSSI(%#d), SQ(%#d)\n", isCCKrate, PWDB_ALL, RSSI, SQ));
-	
-#endif
-	return SQ;
-}
-			
-static u1Byte 
-odm_EVMdbToPercentage(
-    IN		s1Byte Value
-    )
-{
-	//
-	// -33dB~0dB to 0%~99%
-	//
-	s1Byte ret_val;
-    
-	ret_val = Value;
-	ret_val /= 2;
-
-	/*DbgPrint("Value=%d\n", Value);*/
-	/*ODM_RT_DISP(FRX, RX_PHY_SQ, ("EVMdbToPercentage92C Value=%d / %x\n", ret_val, ret_val));*/
-#ifdef ODM_EVM_ENHANCE_ANTDIV
-	if (ret_val >= 0)
-		ret_val = 0;
-
-	if (ret_val <= -40)
-		ret_val = -40;
-
-	ret_val = 0 - ret_val;
-	ret_val *= 3;
-#else
-	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;
-#endif
-
-	return (u1Byte)ret_val;
-}
-			
-static u1Byte 
-odm_EVMdbm_JaguarSeries(
-	IN  s1Byte Value
-	)
-{
-	s1Byte ret_val = Value;
-	
-	// -33dB~0dB to 33dB ~ 0dB
-	if(ret_val == -128)
-		ret_val = 127;
-	else if (ret_val < 0)
-		ret_val = 0 - ret_val;
-	
-	ret_val  = ret_val >> 1;
-	return (u1Byte)ret_val;
-}
-
-static s2Byte
-odm_Cfo(
-  IN s1Byte Value
-)
-{
-	s2Byte  ret_val;
-
-	if (Value < 0)
-	{
-		ret_val = 0 - Value;
-		ret_val = (ret_val << 1) + (ret_val >> 1) ;  //  *2.5~=312.5/2^7
-		ret_val = ret_val | BIT12;  // set bit12 as 1 for negative cfo
-	}
-	else
-	{
-		ret_val = Value;
-		ret_val = (ret_val << 1) + (ret_val>>1) ;  //  *2.5~=312.5/2^7
-	}
-	return ret_val;
-}
-
-#if(ODM_IC_11N_SERIES_SUPPORT == 1)
-
-s1Byte
-odm_CCKRSSI_8703B(
-	IN		u2Byte	LNA_idx,
-	IN		u1Byte	VGA_idx
-	)
-{
-	s1Byte	rx_pwr_all = 0x00;
-	
-	switch (LNA_idx) {
-	case 0xf:
-		rx_pwr_all = -48 - (2 * VGA_idx);
-		break;		
-	case 0xb:
-		rx_pwr_all = -42 - (2 * VGA_idx); /*TBD*/
-		break;
-	case 0xa:
-		rx_pwr_all = -36 - (2 * VGA_idx);
-		break;
-	case 8:
-		rx_pwr_all = -32 - (2 * VGA_idx);
-		break;
-	case 7:	
-		rx_pwr_all = -28 - (2 * VGA_idx); /*TBD*/
-		break;
-	case 4:	
-		rx_pwr_all = -16 - (2 * VGA_idx);
-		break;
-	case 0:	
-		rx_pwr_all = -2 - (2 * VGA_idx);
-		break;
-	default:
-	/*rx_pwr_all = -53+(2*(31-VGA_idx));*/
-	/*DbgPrint("wrong LNA index\n");*/
-		break;
-			
-	}
-	return	rx_pwr_all;
-}
-
-VOID
-odm_RxPhyStatus92CSeries_Parsing(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	OUT		PODM_PHY_INFO_T			pPhyInfo,		
-	IN 		pu1Byte						pPhyStatus,
-	IN		PODM_PACKET_INFO_T			pPktinfo
-	)
-{							
-	SWAT_T				*pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	u1Byte				i, Max_spatial_stream;
-	s1Byte				rx_pwr[4], rx_pwr_all=0;
-	u1Byte				EVM, PWDB_ALL = 0, PWDB_ALL_BT;
-	u1Byte				RSSI, total_rssi=0;
-	BOOLEAN				isCCKrate=FALSE;	
-	u1Byte				rf_rx_num = 0;
-	u1Byte				cck_highpwr = 0;
-	u1Byte				LNA_idx = 0;
-	u1Byte				VGA_idx = 0;
-	PPHY_STATUS_RPT_8192CD_T pPhyStaRpt = (PPHY_STATUS_RPT_8192CD_T)pPhyStatus;
-
-	isCCKrate = (pPktinfo->DataRate <= ODM_RATE11M) ? TRUE : FALSE;
-	pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_A] = -1;
-	pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_B] = -1;
-
-
-	if(isCCKrate)
-	{
-		u1Byte report;
-		u1Byte 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)
-		//
-
-		//if(pHalData->eRFPowerState == eRfOn)
-			cck_highpwr = pDM_Odm->bCckHighPower;
-		//else
-		//	cck_highpwr = FALSE;
-
-		cck_agc_rpt =  pPhyStaRpt->cck_agc_rpt_ofdm_cfosho_a ;
-		
-		//2011.11.28 LukeLee: 88E use different LNA & VGA gain table
-		//The RSSI formula should be modified according to the gain table
-		//In 88E, cck_highpwr is always set to 1
-		if (pDM_Odm->SupportICType & (ODM_RTL8703B)) {
-			
-			#if (RTL8703B_SUPPORT == 1)
-			if (pDM_Odm->cck_agc_report_type == 1) {  /*4 bit LNA*/
-
-				u1Byte cck_agc_rpt_b = (pPhyStaRpt->cck_rpt_b_ofdm_cfosho_b & BIT7) ? 1 : 0;
-								
-				LNA_idx = (cck_agc_rpt_b << 3) | ((cck_agc_rpt & 0xE0) >> 5);
-				VGA_idx = (cck_agc_rpt & 0x1F);
-				
-				rx_pwr_all = odm_CCKRSSI_8703B(LNA_idx, VGA_idx);
-				PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-				if (PWDB_ALL > 100)
-					PWDB_ALL = 100;	
-			
-			}
-			#endif
-		} else if (pDM_Odm->SupportICType & (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8188F)) /*3 bit LNA*/
-		{
-			LNA_idx = ((cck_agc_rpt & 0xE0) >>5);
-			VGA_idx = (cck_agc_rpt & 0x1F); 
-			if(pDM_Odm->SupportICType & (ODM_RTL8188E|ODM_RTL8192E))
-			{
-				if(pDM_Odm->cck_agc_report_type == 0 && (pDM_Odm->SupportICType & ODM_RTL8192E) )
-				{
-					switch(LNA_idx)
-					{
-						case 7:
-							rx_pwr_all = -45  - 2*(VGA_idx);
-							break;
-						case 6:
-							rx_pwr_all = -43 -2*(VGA_idx); 
-							break;
-						case 5:
-							rx_pwr_all = -27 - 2*(VGA_idx); 
-							break;
-						case 4:
-							rx_pwr_all = -21 - 2*(VGA_idx); 
-							break;
-						case 3:
-							rx_pwr_all = -18 - 2*(VGA_idx); 
-							break;
-						case 2:
-							rx_pwr_all = -6 - 2*(VGA_idx);
-							break;
-						case 1:
-							rx_pwr_all = 9 -2*(VGA_idx);
-							break;
-						case 0:
-							rx_pwr_all = 15 -2*(VGA_idx);
-							break;
-						default:
-
-							break;
-					}
-
-					if(pDM_Odm->BoardType & ODM_BOARD_EXT_LNA)
-					{
-						rx_pwr_all -= pDM_Odm->ExtLNAGain;
-					}
-					
-					PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-				}
-				else
-				{					
-					switch(LNA_idx)
-					{
-						case 7:
-							if(VGA_idx <= 27)
-								rx_pwr_all = -100 + 2*(27-VGA_idx); //VGA_idx = 27~2
-							else
-							rx_pwr_all = -100;
-							break;
-						case 6:
-							rx_pwr_all = -48 + 2*(2-VGA_idx); //VGA_idx = 2~0
-							break;
-						case 5:
-							rx_pwr_all = -42 + 2*(7-VGA_idx); //VGA_idx = 7~5
-							break;
-						case 4:
-							rx_pwr_all = -36 + 2*(7-VGA_idx); //VGA_idx = 7~4
-							break;
-						case 3:
-							//rx_pwr_all = -28 + 2*(7-VGA_idx); //VGA_idx = 7~0
-							rx_pwr_all = -24 + 2*(7-VGA_idx); //VGA_idx = 7~0
-							break;
-						case 2:
-							if(cck_highpwr)
-								rx_pwr_all = -12 + 2*(5-VGA_idx); //VGA_idx = 5~0
-							else
-								rx_pwr_all = -6+ 2*(5-VGA_idx);
-							break;
-						case 1:
-								rx_pwr_all = 8-2*VGA_idx;
-							break;
-						case 0:
-							rx_pwr_all = 14-2*VGA_idx;
-							break;
-						default:
-							//DbgPrint("CCK Exception default\n");
-							break;
-					}
-					rx_pwr_all += 8;
-
-					//2012.10.08 LukeLee: Modify for 92E CCK RSSI
-					if(pDM_Odm->SupportICType == ODM_RTL8192E)
-						rx_pwr_all += 8;
-					
-					PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-					if(cck_highpwr == FALSE)
-					{
-						if(PWDB_ALL >= 80)
-							PWDB_ALL = ((PWDB_ALL-80)<<1)+((PWDB_ALL-80)>>1)+80;
-						else if((PWDB_ALL <= 78) && (PWDB_ALL >= 20))
-							PWDB_ALL += 3;
-						if(PWDB_ALL>100)
-							PWDB_ALL = 100;
-					}
-				}
-			}
-			else if(pDM_Odm->SupportICType & (ODM_RTL8723B))
-			{
-#if (RTL8723B_SUPPORT == 1)			
-				rx_pwr_all = odm_CCKRSSI_8723B(LNA_idx,VGA_idx);
-				PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-				if(PWDB_ALL>100)
-					PWDB_ALL = 100;	
-#endif				
-			} else if (pDM_Odm->SupportICType & (ODM_RTL8188F)) {
-#if (RTL8188F_SUPPORT == 1)
-				rx_pwr_all = odm_CCKRSSI_8188F(LNA_idx, VGA_idx);
-				PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-				if (PWDB_ALL > 100)
-					PWDB_ALL = 100;
-#endif
-			}
-		}
-		else
-		{
-			if(!cck_highpwr)
-			{			
-				report =( cck_agc_rpt & 0xc0 )>>6;
-				switch(report)
-				{
-					// 03312009 modified by cosa
-					// 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 = pDrvInfo->cfosho[0] & 0x60;			
-				//report = pPhyStaRpt->cck_agc_rpt_ofdm_cfosho_a& 0x60;
-				
-				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_EXT_LNA | ODM_BOARD_EXT_PA))
-			{
-				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 if (PWDB_ALL <= 25)
-				//	PWDB_ALL += 8;
-			}
-			else//Modification for int-LNA board
-			{
-				if(PWDB_ALL > 99)
-				  	PWDB_ALL -= 8;
-				else if(PWDB_ALL > 50 && PWDB_ALL <= 68)
-					PWDB_ALL += 4;
-			}
-		}
-
-		pDM_Odm->cck_lna_idx = LNA_idx;
-		pDM_Odm->cck_vga_idx = VGA_idx;
-		pPhyInfo->RxPWDBAll = PWDB_ALL;
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-		pPhyInfo->BTRxRSSIPercentage = PWDB_ALL;
-		pPhyInfo->RecvSignalPower = rx_pwr_all;
-#endif		
-		//
-		// (3) Get Signal Quality (EVM)
-		//
-		//if(pPktinfo->bPacketMatchBSSID)
-		{
-			u1Byte	SQ,SQ_rpt;			
-			
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)			
-			if((pDM_Odm->SupportPlatform == ODM_WIN) &&
-				(pDM_Odm->PatchID==RT_CID_819x_Lenovo)){
-				SQ = odm_SQ_process_patch_RT_CID_819x_Lenovo(pDM_Odm,isCCKrate,PWDB_ALL,0,0);
-			}else if((pDM_Odm->SupportPlatform == ODM_WIN) &&
-				(pDM_Odm->PatchID==RT_CID_819x_Acer))
-			{
-				SQ = odm_SQ_process_patch_RT_CID_819x_Acer(pDM_Odm,isCCKrate,PWDB_ALL,0,0);
-			}else 
-#endif
-			if(pPhyInfo->RxPWDBAll > 40 && !pDM_Odm->bInHctTest){
-				SQ = 100;
-			}
-			else{						
-				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;
-			
-			}
-			
-			//DbgPrint("cck SQ = %d\n", SQ);
-			pPhyInfo->SignalQuality = SQ;
-			pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_A] = SQ;
-			pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_B] = -1;
-		}
-
-		for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_MAX; i++) {
-			if (i == 0)
-				pPhyInfo->RxMIMOSignalStrength[0] = PWDB_ALL;
-			else
-				pPhyInfo->RxMIMOSignalStrength[1] = 0;
-		}
-	}
-	else //2 is OFDM rate
-	{
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM++;
-
-		// 
-		// (1)Get RSSI for HT rate
-		//
-		
-       	 for(i = ODM_RF_PATH_A; i < ODM_RF_PATH_MAX; i++)   
-		{
-			// 2008/01/30 MH we will judge RF RX path now.
-			if (pDM_Odm->RFPathRxEnable & BIT(i))
-				rf_rx_num++;
-			//else
-				//continue;
-
-			rx_pwr[i] = ((pPhyStaRpt->path_agc[i].gain& 0x3F)*2) - 110;
-			pDM_Odm->ofdm_agc_idx[i] = (pPhyStaRpt->path_agc[i].gain & 0x3F);
-
-		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-			pPhyInfo->RxPwr[i] = rx_pwr[i];
-		#endif	
-
-			/* Translate DBM to percentage. */
-			RSSI = odm_QueryRxPwrPercentage(rx_pwr[i]);
-			total_rssi += RSSI;
-			//RT_DISP(FRX, RX_PHY_SS, ("RF-%d RXPWR=%x RSSI=%d\n", i, rx_pwr[i], RSSI));
-
-
-			if(pDM_Odm->SupportICType&ODM_RTL8192C)
-			{	
-			        //Modification for ext-LNA board	
-				if(pDM_Odm->BoardType & (ODM_BOARD_EXT_LNA | ODM_BOARD_EXT_PA))
-				{
-					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] =(u1Byte) RSSI;
-
-		#if (DM_ODM_SUPPORT_TYPE &  (/*ODM_WIN|*/ODM_CE|ODM_AP))
-			//Get Rx snr value in DB		
-			pPhyInfo->RxSNR[i] = pDM_Odm->PhyDbgInfo.RxSNRdB[i] = (s4Byte)(pPhyStaRpt->path_rxsnr[i]/2);
-		#endif
-		
-			/* Record Signal Strength for next packet */
-			//if(pPktinfo->bPacketMatchBSSID)
-			{				
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)				
-				if((pDM_Odm->SupportPlatform == ODM_WIN) &&
-					(pDM_Odm->PatchID==RT_CID_819x_Lenovo))
-				{
-					if(i==ODM_RF_PATH_A)
-						pPhyInfo->SignalQuality = odm_SQ_process_patch_RT_CID_819x_Lenovo(pDM_Odm,isCCKrate,PWDB_ALL,i,RSSI);
-				
-				}		
-				else if((pDM_Odm->SupportPlatform == ODM_WIN) &&
-					(pDM_Odm->PatchID==RT_CID_819x_Acer))
-				{
-					pPhyInfo->SignalQuality = odm_SQ_process_patch_RT_CID_819x_Acer(pDM_Odm,isCCKrate,PWDB_ALL,0,RSSI);
-				}	
-#endif				
-			}
-		}
-		
-		
-		//
-		// (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_BT = PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);	
-	
-	
-		pPhyInfo->RxPWDBAll = PWDB_ALL;
-		//ODM_RT_TRACE(pDM_Odm,ODM_COMP_RSSI_MONITOR, ODM_DBG_LOUD, ("ODM OFDM RSSI=%d\n",pPhyInfo->RxPWDBAll));
-	#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-		pPhyInfo->BTRxRSSIPercentage = PWDB_ALL_BT;
-		pPhyInfo->RxPower = rx_pwr_all;
-		pPhyInfo->RecvSignalPower = rx_pwr_all;
-	#endif
-		
-		if((pDM_Odm->SupportPlatform == ODM_WIN) &&(pDM_Odm->PatchID==19)){
-			//do nothing	
-		}else if((pDM_Odm->SupportPlatform == ODM_WIN) &&(pDM_Odm->PatchID==25)){
-			//do nothing	
-		}
-		else{//pMgntInfo->CustomerID != RT_CID_819x_Lenovo
-			//
-			// (3)EVM of HT rate
-			//
-			if(pPktinfo->DataRate >=ODM_RATEMCS8 && pPktinfo->DataRate <=ODM_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
-
-				//GET_RX_STATUS_DESC_RX_MCS(pDesc), pDrvInfo->rxevm[i], "%", EVM));
-				
-				//if(pPktinfo->bPacketMatchBSSID)
-				{
-					if(i==ODM_RF_PATH_A) // Fill value in RFD, Get the first spatial stream only
-					{						
-						pPhyInfo->SignalQuality = (u1Byte)(EVM & 0xff);
-					}					
-					pPhyInfo->RxMIMOSignalQuality[i] = (u1Byte)(EVM & 0xff);
-				}
-			}
-		}
-
-		ODM_ParsingCFO(pDM_Odm, pPktinfo, pPhyStaRpt->path_cfotail);
-		
-	}
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-	//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)
-	{		
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		// 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/	
-		pPhyInfo->SignalStrength = SignalScaleProc(pDM_Odm->Adapter, PWDB_ALL, TRUE, TRUE);
-#else
-	#ifdef CONFIG_SIGNAL_SCALE_MAPPING
-		pPhyInfo->SignalStrength = (u1Byte)(odm_SignalScaleMapping(pDM_Odm, PWDB_ALL));/*PWDB_ALL;*/
-	#else
-		pPhyInfo->SignalStrength = (u1Byte)PWDB_ALL;
-	#endif
-#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
-	}
-	else
-	{	
-		if (rf_rx_num != 0)
-		{			
-		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			// 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/	
-			pPhyInfo->SignalStrength = SignalScaleProc(pDM_Odm->Adapter, (total_rssi /= rf_rx_num), TRUE, FALSE);
-		#else
-			#ifdef CONFIG_SIGNAL_SCALE_MAPPING
-			pPhyInfo->SignalStrength = (u1Byte)(odm_SignalScaleMapping(pDM_Odm, total_rssi /= rf_rx_num));
-			#else
-			total_rssi/=rf_rx_num;
-			pPhyInfo->SignalStrength = (u1Byte)total_rssi;
-			#endif
-		#endif
-		}
-	}
-#endif /*#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))*/
-
-	//DbgPrint("isCCKrate = %d, pPhyInfo->RxPWDBAll = %d, pPhyStaRpt->cck_agc_rpt_ofdm_cfosho_a = 0x%x\n", 
-		//isCCKrate, pPhyInfo->RxPWDBAll, pPhyStaRpt->cck_agc_rpt_ofdm_cfosho_a);
-
-	//For 92C/92D HW (Hybrid) Antenna Diversity
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	//For 88E HW Antenna Diversity
-	pDM_Odm->DM_FatTable.antsel_rx_keep_0 = pPhyStaRpt->ant_sel;
-	pDM_Odm->DM_FatTable.antsel_rx_keep_1 = pPhyStaRpt->ant_sel_b;
-	pDM_Odm->DM_FatTable.antsel_rx_keep_2 = pPhyStaRpt->antsel_rx_keep_2;
-#endif
-}
-#endif
-
-#if	ODM_IC_11AC_SERIES_SUPPORT
-
-VOID
-odm_RxPhyBWJaguarSeries_Parsing(
-	OUT		PODM_PHY_INFO_T			pPhyInfo,
-	IN		PODM_PACKET_INFO_T			pPktinfo,
-	IN		PPHY_STATUS_RPT_8812_T		pPhyStaRpt
-)
-{
-
-	if(pPktinfo->DataRate <= ODM_RATE54M) {
-		switch (pPhyStaRpt->r_RFMOD) {
-		case 1:
-			if (pPhyStaRpt->sub_chnl == 0)
-				pPhyInfo->BandWidth = 1;
-			else
-				pPhyInfo->BandWidth = 0;
-			break;
-
-		case 2:
-			if (pPhyStaRpt->sub_chnl == 0)
-				pPhyInfo->BandWidth = 2;
-			else if (pPhyStaRpt->sub_chnl == 9 || pPhyStaRpt->sub_chnl == 10)
-				pPhyInfo->BandWidth = 1;
-			else
-				pPhyInfo->BandWidth = 0;
-			break;
-
-		default:
-		case 0:
-			pPhyInfo->BandWidth = 0;
-			break;
-		}
-	}
-
-}
-
-VOID
-odm_RxPhyStatusJaguarSeries_Parsing(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	OUT		PODM_PHY_INFO_T			pPhyInfo,
-	IN 		pu1Byte						pPhyStatus,
-	IN		PODM_PACKET_INFO_T			pPktinfo
-)
-{
-	u1Byte					i, Max_spatial_stream;
-	s1Byte					rx_pwr[4], rx_pwr_all = 0;
-	u1Byte					EVM, EVMdbm, PWDB_ALL = 0, PWDB_ALL_BT;
-	u1Byte					RSSI, avg_rssi = 0, best_rssi = 0, second_rssi = 0;
-	u1Byte					isCCKrate = 0;	
-	u1Byte					rf_rx_num = 0;
-	u1Byte					cck_highpwr = 0;
-	u1Byte					LNA_idx, VGA_idx;
-	PPHY_STATUS_RPT_8812_T pPhyStaRpt = (PPHY_STATUS_RPT_8812_T)pPhyStatus;
-	pFAT_T					pDM_FatTable = &pDM_Odm->DM_FatTable;
-
-	odm_RxPhyBWJaguarSeries_Parsing(pPhyInfo, pPktinfo, pPhyStaRpt);
-
-	if (pPktinfo->DataRate <= ODM_RATE11M)
-		isCCKrate = TRUE;
-	else
-		isCCKrate = FALSE;
-
-	pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_A] = -1;
-	pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_B] = -1;
-	pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_C] = -1;
-	pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_D] = -1;
-
-	if (isCCKrate) {
-		u1Byte cck_agc_rpt;
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK++;
-
-		/*(1)Hardware does not provide RSSI for CCK*/
-		/*(2)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
-
-		/*if(pHalData->eRFPowerState == eRfOn)*/
-		cck_highpwr = pDM_Odm->bCckHighPower;
-		/*else*/
-		/*cck_highpwr = FALSE;*/
-
-		cck_agc_rpt =  pPhyStaRpt->cfosho[0] ;
-		LNA_idx = ((cck_agc_rpt & 0xE0) >> 5);
-		VGA_idx = (cck_agc_rpt & 0x1F);
-
-		if (pDM_Odm->SupportICType == ODM_RTL8812) {
-			switch (LNA_idx) {
-			case 7:
-				if (VGA_idx <= 27)
-					rx_pwr_all = -100 + 2 * (27 - VGA_idx); /*VGA_idx = 27~2*/
-				else
-					rx_pwr_all = -100;
-				break;
-			case 6:
-				rx_pwr_all = -48 + 2 * (2 - VGA_idx); /*VGA_idx = 2~0*/
-				break;
-			case 5:
-				rx_pwr_all = -42 + 2 * (7 - VGA_idx); /*VGA_idx = 7~5*/
-				break;
-			case 4:
-				rx_pwr_all = -36 + 2 * (7 - VGA_idx); /*VGA_idx = 7~4*/
-				break;
-			case 3:
-				/*rx_pwr_all = -28 + 2*(7-VGA_idx); VGA_idx = 7~0*/
-				rx_pwr_all = -24 + 2 * (7 - VGA_idx); /*VGA_idx = 7~0*/
-				break;
-			case 2:
-				if (cck_highpwr)
-					rx_pwr_all = -12 + 2 * (5 - VGA_idx); /*VGA_idx = 5~0*/
-				else
-					rx_pwr_all = -6 + 2 * (5 - VGA_idx);
-				break;
-			case 1:
-				rx_pwr_all = 8 - 2 * VGA_idx;
-				break;
-			case 0:
-				rx_pwr_all = 14 - 2 * VGA_idx;
-				break;
-			default:
-				/*DbgPrint("CCK Exception default\n");*/
-				break;
-			}
-			rx_pwr_all += 6;
-			PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-
-			if (cck_highpwr == FALSE) {
-				if (PWDB_ALL >= 80)
-					PWDB_ALL = ((PWDB_ALL - 80) << 1) + ((PWDB_ALL - 80) >> 1) + 80;
-				else if ((PWDB_ALL <= 78) && (PWDB_ALL >= 20))
-					PWDB_ALL += 3;
-				if (PWDB_ALL > 100)
-					PWDB_ALL = 100;
-			}
-		} else if (pDM_Odm->SupportICType & (ODM_RTL8821 | ODM_RTL8881A)) {
-			s1Byte Pout = -6;
-
-			switch (LNA_idx) {
-			case 5:
-				rx_pwr_all = Pout - 32 - (2 * VGA_idx);
-				break;
-			case 4:
-				rx_pwr_all = Pout - 24 - (2 * VGA_idx);
-				break;
-			case 2:
-				rx_pwr_all = Pout - 11 - (2 * VGA_idx);
-				break;
-			case 1:
-				rx_pwr_all = Pout + 5 - (2 * VGA_idx);
-				break;
-			case 0:
-				rx_pwr_all = Pout + 21 - (2 * VGA_idx);
-				break;
-			}
-			PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-		} else if (pDM_Odm->SupportICType == ODM_RTL8814A || pDM_Odm->SupportICType == ODM_RTL8822B) {
-			s1Byte Pout = -6;
-
-			switch (LNA_idx) {
-			/*CCK only use LNA: 2, 3, 5, 7*/
-			case 7:
-				rx_pwr_all = Pout - 32 - (2 * VGA_idx);
-				break;
-			case 5:
-				rx_pwr_all = Pout - 22 - (2 * VGA_idx);
-				break;
-			case 3:
-				rx_pwr_all = Pout - 2 - (2 * VGA_idx);
-				break;
-			case 2:
-				rx_pwr_all = Pout + 5 - (2 * VGA_idx);
-				break;
-			/*case 6:*/
-			/*rx_pwr_all = Pout -26 - (2*VGA_idx);*/
-			/*break;*/
-			/*case 4:*/
-			/*rx_pwr_all = Pout - 8 - (2*VGA_idx);*/
-			/*break;*/
-			/*case 1:*/
-			/*rx_pwr_all = Pout + 21 - (2*VGA_idx);*/
-			/*break;*/
-			/*case 0:*/
-			/*rx_pwr_all = Pout + 10 - (2*VGA_idx);*/
-/*			//	break;*/
-			default:
-/*				//DbgPrint("CCK Exception default\n");*/
-				break;
-			}
-			PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-		}
-
-		pPhyInfo->RxPWDBAll = PWDB_ALL;
-/*		//if(pPktinfo->StationID == 0)*/
-/*		//{*/
-/*		//	DbgPrint("CCK: LNA_idx = %d, VGA_idx = %d, pPhyInfo->RxPWDBAll = %d\n",*/
-/*		//		LNA_idx, VGA_idx, pPhyInfo->RxPWDBAll);*/
-/*		//}*/
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-		pPhyInfo->BTRxRSSIPercentage = PWDB_ALL;
-		pPhyInfo->RecvSignalPower = rx_pwr_all;
-#endif
-		/*(3) Get Signal Quality (EVM)*/
-		if (pPktinfo->bPacketMatchBSSID) {
-			u1Byte	SQ, SQ_rpt;
-
-			if ((pDM_Odm->SupportPlatform == ODM_WIN) &&
-				(pDM_Odm->PatchID == RT_CID_819x_Lenovo)) {
-				SQ = odm_SQ_process_patch_RT_CID_819x_Lenovo(pDM_Odm, isCCKrate, PWDB_ALL, 0, 0);
-			} else if (pPhyInfo->RxPWDBAll > 40 && !pDM_Odm->bInHctTest) {
-				SQ = 100;
-			} else {
-				SQ_rpt = pPhyStaRpt->pwdb_all;
-
-				if (SQ_rpt > 64)
-					SQ = 0;
-				else if (SQ_rpt < 20)
-					SQ = 100;
-				else
-					SQ = ((64 - SQ_rpt) * 100) / 44;
-			}
-
-/*			//DbgPrint("cck SQ = %d\n", SQ);*/
-			pPhyInfo->SignalQuality = SQ;
-			pPhyInfo->RxMIMOSignalQuality[ODM_RF_PATH_A] = SQ;
-		}
-
-		for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-			if (i == 0)
-				pPhyInfo->RxMIMOSignalStrength[0] = PWDB_ALL;
-			else
-				pPhyInfo->RxMIMOSignalStrength[i] = 0;
-		}
-	} else {		 
-		/*is OFDM rate*/
-		pDM_FatTable->hw_antsw_occur = pPhyStaRpt->hw_antsw_occur;
-		
-		pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM++;
-
-		/*(1)Get RSSI for OFDM rate*/
-
-		for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-			/*2008/01/30 MH we will judge RF RX path now.*/
-/*			//DbgPrint("pDM_Odm->RFPathRxEnable = %x\n", pDM_Odm->RFPathRxEnable);*/
-			if (pDM_Odm->RFPathRxEnable & BIT(i))
-				rf_rx_num++;
-/*			//else*/
-/*			//continue;*/
-			/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
-/*			//if((pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8821)) && (!pDM_Odm->bIsMPChip))*/
-			if (i < ODM_RF_PATH_C)
-				rx_pwr[i] = (pPhyStaRpt->gain_trsw[i] & 0x7F) - 110;
-			else
-				rx_pwr[i] = (pPhyStaRpt->gain_trsw_cd[i - 2] & 0x7F) - 110;
-/*			//else*/
-			/*rx_pwr[i] = ((pPhyStaRpt->gain_trsw[i]& 0x3F)*2) - 110;  OLD FORMULA*/
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-			pPhyInfo->RxPwr[i] = rx_pwr[i];
-#endif
-
-			/* Translate DBM to percentage. */
-			RSSI = odm_QueryRxPwrPercentage(rx_pwr[i]);	
-		
-			/*total_rssi += RSSI;*/
-			/*Get the best two RSSI*/
-			if (RSSI > best_rssi && RSSI > second_rssi) {
-				second_rssi = best_rssi;
-				best_rssi = RSSI;
-			} else if (RSSI > second_rssi && RSSI <= best_rssi)
-				second_rssi = RSSI;
-
-			/*RT_DISP(FRX, RX_PHY_SS, ("RF-%d RXPWR=%x RSSI=%d\n", i, rx_pwr[i], RSSI));*/
-
-			pPhyInfo->RxMIMOSignalStrength[i] = (u1Byte) RSSI;
-
-
-			/*Get Rx snr value in DB*/
-			if (i < ODM_RF_PATH_C)
-				pPhyInfo->RxSNR[i] = pDM_Odm->PhyDbgInfo.RxSNRdB[i] = pPhyStaRpt->rxsnr[i] / 2;
-			else if (pDM_Odm->SupportICType & (ODM_RTL8814A | ODM_RTL8822B))
-				pPhyInfo->RxSNR[i] = pDM_Odm->PhyDbgInfo.RxSNRdB[i] = pPhyStaRpt->csi_current[i - 2] / 2;
-
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-			/*(2) CFO_short  & CFO_tail*/
-			if (i < ODM_RF_PATH_C) {
-				pPhyInfo->Cfo_short[i] = odm_Cfo((pPhyStaRpt->cfosho[i]));
-				pPhyInfo->Cfo_tail[i] = odm_Cfo((pPhyStaRpt->cfotail[i]));
-			}
-#endif
-			/* Record Signal Strength for next packet */
-			if (pPktinfo->bPacketMatchBSSID) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-				if ((pDM_Odm->SupportPlatform == ODM_WIN) &&
-					(pDM_Odm->PatchID == RT_CID_819x_Lenovo)) {
-					if (i == ODM_RF_PATH_A)
-						pPhyInfo->SignalQuality = odm_SQ_process_patch_RT_CID_819x_Lenovo(pDM_Odm, isCCKrate, PWDB_ALL, i, RSSI);
-
-				}
-#endif
-			}
-		}
-
-		/*(3)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
-
-		/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
-		if ((pDM_Odm->SupportICType & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)) && (!pDM_Odm->bIsMPChip))
-			rx_pwr_all = (pPhyStaRpt->pwdb_all & 0x7f) - 110;
-		else
-			rx_pwr_all = (((pPhyStaRpt->pwdb_all) >> 1) & 0x7f) - 110;	 /*OLD FORMULA*/
-
-		PWDB_ALL_BT = PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-
-		pPhyInfo->RxPWDBAll = PWDB_ALL;
-		/*ODM_RT_TRACE(pDM_Odm,ODM_COMP_RSSI_MONITOR, ODM_DBG_LOUD, ("ODM OFDM RSSI=%d\n",pPhyInfo->RxPWDBAll));*/
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-		pPhyInfo->BTRxRSSIPercentage = PWDB_ALL_BT;
-		pPhyInfo->RxPower = rx_pwr_all;
-		pPhyInfo->RecvSignalPower = rx_pwr_all;
-#endif
-
-		if ((pDM_Odm->SupportPlatform == ODM_WIN) && (pDM_Odm->PatchID == 19)) {
-			/*do nothing*/
-		} else {
-			/*pMgntInfo->CustomerID != RT_CID_819x_Lenovo*/
-
-			/*(4)EVM of OFDM rate*/
-			
-			if ((pPktinfo->DataRate >= ODM_RATEMCS8) &&
-				(pPktinfo->DataRate <= ODM_RATEMCS15))
-				Max_spatial_stream = 2;
-			else if ((pPktinfo->DataRate >= ODM_RATEVHTSS2MCS0) &&
-					 (pPktinfo->DataRate <= ODM_RATEVHTSS2MCS9))
-				Max_spatial_stream = 2;
-			else if ((pPktinfo->DataRate >= ODM_RATEMCS16) &&
-					 (pPktinfo->DataRate <= ODM_RATEMCS23))
-				Max_spatial_stream = 3;
-			else if ((pPktinfo->DataRate >= ODM_RATEVHTSS3MCS0) &&
-					 (pPktinfo->DataRate <= ODM_RATEVHTSS3MCS9))
-				Max_spatial_stream = 3;
-			else
-				Max_spatial_stream = 1;
-
-			if (pPktinfo->bPacketMatchBSSID) {
-				/*DbgPrint("pPktinfo->DataRate = %d\n", pPktinfo->DataRate);*/
-
-				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.*/
-
-					if (pPktinfo->DataRate >= ODM_RATE6M && pPktinfo->DataRate <= ODM_RATE54M) {
-						if (i == ODM_RF_PATH_A) {
-							EVM = odm_EVMdbToPercentage((pPhyStaRpt->sigevm));	/*dbm*/
-							EVM += 20;
-							if (EVM > 100)
-								EVM = 100;
-						}
-					} else {
-						if (i < ODM_RF_PATH_C) {
-							if (pPhyStaRpt->rxevm[i] == -128)
-								pPhyStaRpt->rxevm[i] = -25;
-							EVM = odm_EVMdbToPercentage((pPhyStaRpt->rxevm[i]));	/*dbm*/
-						} else {
-							if (pPhyStaRpt->rxevm_cd[i - 2] == -128){
-								pPhyStaRpt->rxevm_cd[i - 2] = -25;
-							}
-							EVM = odm_EVMdbToPercentage((pPhyStaRpt->rxevm_cd[i - 2]));	/*dbm*/
-						}
-					}
-
-					if (i < ODM_RF_PATH_C)
-						EVMdbm = odm_EVMdbm_JaguarSeries(pPhyStaRpt->rxevm[i]);
-					else
-						EVMdbm = odm_EVMdbm_JaguarSeries(pPhyStaRpt->rxevm_cd[i - 2]);
-					/*RT_DISP(FRX, RX_PHY_SQ, ("RXRATE=%x RXEVM=%x EVM=%s%d\n",*/
-					/*pPktinfo->DataRate, pPhyStaRpt->rxevm[i], "%", EVM));*/
-
-					{
-						if (i == ODM_RF_PATH_A) { 
-							/*Fill value in RFD, Get the first spatial stream only*/
-							pPhyInfo->SignalQuality = EVM;
-						}
-						pPhyInfo->RxMIMOSignalQuality[i] = EVM;
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-						pPhyInfo->RxMIMOEVMdbm[i] = EVMdbm;
-#endif
-					}
-				}
-			}
-		}
-
-		ODM_ParsingCFO(pDM_Odm, pPktinfo, pPhyStaRpt->cfotail);
-
-	}
-/*	//DbgPrint("isCCKrate= %d, pPhyInfo->SignalStrength=%d % PWDB_AL=%d rf_rx_num=%d\n", isCCKrate, pPhyInfo->SignalStrength, PWDB_ALL, rf_rx_num);*/
-
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-	/*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) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		/*2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/
-		pPhyInfo->SignalStrength = SignalScaleProc(pDM_Odm->Adapter, PWDB_ALL, FALSE, TRUE);
-#else
-		pPhyInfo->SignalStrength = (u1Byte)(odm_SignalScaleMapping(pDM_Odm, PWDB_ALL));/*PWDB_ALL;*/
-#endif
-	} else {	
-		if (rf_rx_num != 0) {
-			/* 2015/01 Sean, use the best two RSSI only, suggested by Ynlin and ChenYu.*/
-			if (rf_rx_num == 1)
-				avg_rssi = best_rssi;
-			else
-				avg_rssi = (best_rssi + second_rssi)/2;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/	
-			pPhyInfo->SignalStrength = SignalScaleProc(pDM_Odm->Adapter, avg_rssi, FALSE, FALSE);
-#else
-			pPhyInfo->SignalStrength = (u1Byte)(odm_SignalScaleMapping(pDM_Odm, avg_rssi));
-#endif
-		}
-	}
-#endif
-	pDM_Odm->RxPWDBAve = pDM_Odm->RxPWDBAve + pPhyInfo->RxPWDBAll;
-
-	pDM_Odm->DM_FatTable.antsel_rx_keep_0 = pPhyStaRpt->antidx_anta;
-	pDM_Odm->DM_FatTable.antsel_rx_keep_1 = pPhyStaRpt->antidx_antb;
-	pDM_Odm->DM_FatTable.antsel_rx_keep_2 = pPhyStaRpt->antidx_antc;
-	pDM_Odm->DM_FatTable.antsel_rx_keep_3 = pPhyStaRpt->antidx_antd;
-	/*ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("StaID[%d]:  antidx_anta = ((%d)), MatchBSSID =  ((%d))\n", pPktinfo->StationID, pPhyStaRpt->antidx_anta, pPktinfo->bPacketMatchBSSID));*/
-
-
-/*		DbgPrint("pPhyStaRpt->antidx_anta = %d, pPhyStaRpt->antidx_antb = %d\n",*/
-/*			pPhyStaRpt->antidx_anta, pPhyStaRpt->antidx_antb);*/
-/*		DbgPrint("----------------------------\n");*/
-/*		DbgPrint("pPktinfo->StationID=%d, pPktinfo->DataRate=0x%x\n",pPktinfo->StationID, pPktinfo->DataRate);*/
-/*		DbgPrint("pPhyStaRpt->r_RFMOD = %d\n", pPhyStaRpt->r_RFMOD);*/
-/*		DbgPrint("pPhyStaRpt->gain_trsw[0]=0x%x, pPhyStaRpt->gain_trsw[1]=0x%x\n",*/
-/*				pPhyStaRpt->gain_trsw[0],pPhyStaRpt->gain_trsw[1]);*/
-/*		DbgPrint("pPhyStaRpt->gain_trsw[2]=0x%x, pPhyStaRpt->gain_trsw[3]=0x%x\n",*/
-/*				pPhyStaRpt->gain_trsw_cd[0],pPhyStaRpt->gain_trsw_cd[1]);*/
-/*		DbgPrint("pPhyStaRpt->pwdb_all = 0x%x, pPhyInfo->RxPWDBAll = %d\n", pPhyStaRpt->pwdb_all, pPhyInfo->RxPWDBAll);*/
-/*		DbgPrint("pPhyStaRpt->cfotail[i] = 0x%x, pPhyStaRpt->CFO_tail[i] = 0x%x\n", pPhyStaRpt->cfotail[0], pPhyStaRpt->cfotail[1]);*/
-/*		DbgPrint("pPhyStaRpt->rxevm[0] = %d, pPhyStaRpt->rxevm[1] = %d\n", pPhyStaRpt->rxevm[0], pPhyStaRpt->rxevm[1]);*/
-/*		DbgPrint("pPhyStaRpt->rxevm[2] = %d, pPhyStaRpt->rxevm[3] = %d\n", pPhyStaRpt->rxevm_cd[0], pPhyStaRpt->rxevm_cd[1]);*/
-/*		DbgPrint("pPhyInfo->RxMIMOSignalStrength[0]=%d, pPhyInfo->RxMIMOSignalStrength[1]=%d, RxPWDBAll=%d\n",*/
-/*				pPhyInfo->RxMIMOSignalStrength[0], pPhyInfo->RxMIMOSignalStrength[1], pPhyInfo->RxPWDBAll);*/
-/*		DbgPrint("pPhyInfo->RxMIMOSignalStrength[2]=%d, pPhyInfo->RxMIMOSignalStrength[3]=%d\n",*/
-/*				pPhyInfo->RxMIMOSignalStrength[2], pPhyInfo->RxMIMOSignalStrength[3]);*/
-/*		DbgPrint("ppPhyInfo->RxMIMOSignalQuality[0]=%d, pPhyInfo->RxMIMOSignalQuality[1]=%d\n",*/
-/*				pPhyInfo->RxMIMOSignalQuality[0], pPhyInfo->RxMIMOSignalQuality[1]);*/
-/*		DbgPrint("ppPhyInfo->RxMIMOSignalQuality[2]=%d, pPhyInfo->RxMIMOSignalQuality[3]=%d\n",*/
-/*				pPhyInfo->RxMIMOSignalQuality[2], pPhyInfo->RxMIMOSignalQuality[3]);*/
-
-}
-
-#endif
-
-VOID
-odm_Init_RSSIForDM(
-	IN OUT	PDM_ODM_T	pDM_Odm
-	)
-{
-
-}
-
-VOID
-odm_Process_RSSIForDM(	
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	IN		PODM_PHY_INFO_T				pPhyInfo,
-	IN		PODM_PACKET_INFO_T			pPktinfo
-	)
-{
-	
-	s4Byte			UndecoratedSmoothedPWDB, UndecoratedSmoothedCCK, UndecoratedSmoothedOFDM, RSSI_Ave;
-	u1Byte			i, isCCKrate=0;	
-	u1Byte			RSSI_max, RSSI_min;
-	u4Byte			OFDM_pkt=0; 
-	u4Byte			Weighting=0;
-	PSTA_INFO_T           	pEntry;
-	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))	
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	#endif
-
-	if (pPktinfo->StationID >= ODM_ASSOCIATE_ENTRY_NUM)
-		return;
-
-	#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-	odm_S0S1_SwAntDivByCtrlFrame_ProcessRSSI(pDM_Odm, pPhyInfo, pPktinfo);
-	#endif
-
-	//
-	// 2012/05/30 MH/Luke.Lee Add some description 
-	// In windows driver: AP/IBSS mode STA
-	//
-	//if (pDM_Odm->SupportPlatform == ODM_WIN)
-	//{
-	//	pEntry = pDM_Odm->pODM_StaInfo[pDM_Odm->pAidMap[pPktinfo->StationID-1]];			
-	//}
-	//else
-		pEntry = pDM_Odm->pODM_StaInfo[pPktinfo->StationID];							
-
-	if(!IS_STA_VALID(pEntry) )
-	{		
-		return;
-	}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))	
-	if ((pDM_Odm->SupportAbility & ODM_BB_ANT_DIV) &&
-		(pDM_FatTable->enable_ctrl_frame_antdiv)
-	)
-	{
-		if (pPktinfo->bPacketMatchBSSID)
-			pDM_Odm->data_frame_num++;
-				
-		if ((pDM_FatTable->use_ctrl_frame_antdiv)) {
-			if (!pPktinfo->bToSelf)/*data frame + CTRL frame*/
-				return;
-		} else {
-			if ((!pPktinfo->bPacketMatchBSSID))/*data frame only*/
-				return;
-		}	
-	} else
-#endif
-	{
-		if ((!pPktinfo->bPacketMatchBSSID))/*data frame only*/
-			return;
-	}
-
-	if(pPktinfo->bPacketBeacon)
-		pDM_Odm->PhyDbgInfo.NumQryBeaconPkt++;
-	
-	isCCKrate = (pPktinfo->DataRate <= ODM_RATE11M )?TRUE :FALSE;
-	pDM_Odm->RxRate = pPktinfo->DataRate;
-
-	//--------------Statistic for antenna/path diversity------------------
-	if(pDM_Odm->SupportAbility & ODM_BB_ANT_DIV)
-	{
-		#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-			ODM_Process_RSSIForAntDiv(pDM_Odm,pPhyInfo,pPktinfo);
-		#endif
-	}
-	#if(defined(CONFIG_PATH_DIVERSITY))
-	else if(pDM_Odm->SupportAbility & ODM_BB_PATH_DIV)
-	{
-		phydm_process_rssi_for_path_div(pDM_Odm,pPhyInfo,pPktinfo);
-	}
-	#endif
-	//-----------------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 (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1)
-			if (pDM_Odm->SupportICType & (ODM_RTL8814A|ODM_RTL8822B)) {
-				u1Byte RX_count = 0;
-				u4Byte RSSI_linear = 0;
-
-				if (pDM_Odm->RXAntStatus & ODM_RF_A) {
-					pDM_Odm->RSSI_A = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A];
-					RX_count++;
-					RSSI_linear += odm_ConvertTo_linear(pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A]);
-				} else
-					pDM_Odm->RSSI_A = 0;
-
-				if (pDM_Odm->RXAntStatus & ODM_RF_B) {
-					pDM_Odm->RSSI_B = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B];
-					RX_count++;
-					RSSI_linear += odm_ConvertTo_linear(pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B]);
-				} else
-					pDM_Odm->RSSI_B = 0;
-				
-				if (pDM_Odm->RXAntStatus & ODM_RF_C) {
-					pDM_Odm->RSSI_C = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_C];
-					RX_count++;
-					RSSI_linear += odm_ConvertTo_linear(pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_C]);
-				} else
-					pDM_Odm->RSSI_C = 0;
-
-				if (pDM_Odm->RXAntStatus & ODM_RF_D) {
-					pDM_Odm->RSSI_D = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_D];
-					RX_count++;
-					RSSI_linear += odm_ConvertTo_linear(pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_D]);
-				} else
-					pDM_Odm->RSSI_D = 0;
-
-				/* Calculate average RSSI */
-				switch (RX_count) {
-				case 2:
-					RSSI_linear = (RSSI_linear >> 1);
-					break;
-				case 3:
-					RSSI_linear = ((RSSI_linear) + (RSSI_linear << 1) + (RSSI_linear << 3)) >> 5;	/* RSSI_linear/3 ~ RSSI_linear*11/32 */
-					break;
-				case 4:
-					RSSI_linear = (RSSI_linear >> 2);
-					break;
-				}			
-				RSSI_Ave = odm_ConvertTo_dB(RSSI_linear);
-			} else
-#endif
-			{
-				if (pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B] == 0) {
-					RSSI_Ave = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A];
-					pDM_Odm->RSSI_A = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A];
-					pDM_Odm->RSSI_B = 0;
-				} else {
-					/*DbgPrint("pRfd->Status.RxMIMOSignalStrength[0] = %d, pRfd->Status.RxMIMOSignalStrength[1] = %d\n",*/ 
-						/*pRfd->Status.RxMIMOSignalStrength[0], pRfd->Status.RxMIMOSignalStrength[1]);*/
-					pDM_Odm->RSSI_A =  pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A];
-					pDM_Odm->RSSI_B = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B];
-				
-					if (pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A] > pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B]) {
-						RSSI_max = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A];
-						RSSI_min = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B];
-					} else {
-						RSSI_max = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B];
-						RSSI_min = pPhyInfo->RxMIMOSignalStrength[ODM_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 > (u4Byte)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);
-				}
-			}				
-			if (pEntry->rssi_stat.OFDM_pkt != 64) {
-				i = 63;
-				pEntry->rssi_stat.OFDM_pkt -= (u4Byte)(((pEntry->rssi_stat.PacketMap>>i)&BIT0)-1);
-			}
-			pEntry->rssi_stat.PacketMap = (pEntry->rssi_stat.PacketMap<<1) | BIT0;			
-										
-		}
-		else
-		{
-			RSSI_Ave = pPhyInfo->RxPWDBAll;
-			pDM_Odm->RSSI_A = (u1Byte) pPhyInfo->RxPWDBAll;
-			pDM_Odm->RSSI_B = 0xFF;
-			pDM_Odm->RSSI_C = 0xFF;
-			pDM_Odm->RSSI_D = 0xFF;
-
-			//1 Process CCK RSSI
-			if(UndecoratedSmoothedCCK <= 0)	// initialize
-			{
-				UndecoratedSmoothedCCK = pPhyInfo->RxPWDBAll;
-			}
-			else
-			{
-				if(pPhyInfo->RxPWDBAll > (u4Byte)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);
-				}
-			}
-			i = 63;
-			pEntry->rssi_stat.OFDM_pkt -= (u4Byte)((pEntry->rssi_stat.PacketMap>>i)&BIT0);			
-			pEntry->rssi_stat.PacketMap = pEntry->rssi_stat.PacketMap<<1;			
-		}
-
-		//if(pEntry)
-		{
-			//2011.07.28 LukeLee: modified to prevent unstable CCK RSSI
-			if (pEntry->rssi_stat.OFDM_pkt == 64) { /* speed up when all packets are OFDM*/
-				UndecoratedSmoothedPWDB = UndecoratedSmoothedOFDM;
-			} else {
-				if (pEntry->rssi_stat.ValidBit < 64)
-					pEntry->rssi_stat.ValidBit++;
-
-				if (pEntry->rssi_stat.ValidBit == 64) {
-					Weighting = ((pEntry->rssi_stat.OFDM_pkt<<4) > 64)?64:(pEntry->rssi_stat.OFDM_pkt<<4);
-					UndecoratedSmoothedPWDB = (Weighting*UndecoratedSmoothedOFDM+(64-Weighting)*UndecoratedSmoothedCCK)>>6;
-				} else {
-					if (pEntry->rssi_stat.ValidBit != 0)
-						UndecoratedSmoothedPWDB = (pEntry->rssi_stat.OFDM_pkt*UndecoratedSmoothedOFDM+(pEntry->rssi_stat.ValidBit-pEntry->rssi_stat.OFDM_pkt)*UndecoratedSmoothedCCK)/pEntry->rssi_stat.ValidBit;
-					else
-						UndecoratedSmoothedPWDB = 0;
-				}
-			}
-			#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-			if (pEntry->rssi_stat.UndecoratedSmoothedPWDB == -1)
-				phydm_ra_rssi_rpt_wk(pDM_Odm);
-			#endif
-			pEntry->rssi_stat.UndecoratedSmoothedCCK = UndecoratedSmoothedCCK;
-			pEntry->rssi_stat.UndecoratedSmoothedOFDM = UndecoratedSmoothedOFDM;
-			pEntry->rssi_stat.UndecoratedSmoothedPWDB = UndecoratedSmoothedPWDB;
-
-			//DbgPrint("OFDM_pkt=%d, Weighting=%d\n", OFDM_pkt, Weighting);
-			//DbgPrint("UndecoratedSmoothedOFDM=%d, UndecoratedSmoothedPWDB=%d, UndecoratedSmoothedCCK=%d\n", 
-			//	UndecoratedSmoothedOFDM, UndecoratedSmoothedPWDB, UndecoratedSmoothedCCK);
-			
-		}
-	
-	}
-}
-
-
-#if(ODM_IC_11N_SERIES_SUPPORT ==1)
-//
-// Endianness before calling this API
-//
-VOID
-ODM_PhyStatusQuery_92CSeries(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	OUT		PODM_PHY_INFO_T				pPhyInfo,
-	IN 		pu1Byte						pPhyStatus,	
-	IN		PODM_PACKET_INFO_T			pPktinfo
-	)
-{
-	odm_RxPhyStatus92CSeries_Parsing(pDM_Odm, pPhyInfo, pPhyStatus, pPktinfo);
-	odm_Process_RSSIForDM(pDM_Odm, pPhyInfo, pPktinfo);
-}
-#endif
-
-
-//
-// Endianness before calling this API
-//
-#if	ODM_IC_11AC_SERIES_SUPPORT
-
-VOID
-ODM_PhyStatusQuery_JaguarSeries(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	OUT		PODM_PHY_INFO_T			pPhyInfo,
-	IN 		pu1Byte						pPhyStatus,	
-	IN		PODM_PACKET_INFO_T			pPktinfo
-	)
-{
-	odm_RxPhyStatusJaguarSeries_Parsing(
-							pDM_Odm,
-							pPhyInfo,
-							pPhyStatus,
-							pPktinfo);
-	
-	odm_Process_RSSIForDM(pDM_Odm,pPhyInfo,pPktinfo);
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	//phydm_sbd_check(pDM_Odm);
-#endif
-}
-#endif
-
-VOID
-ODM_PhyStatusQuery(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	OUT		PODM_PHY_INFO_T			pPhyInfo,
-	IN 		pu1Byte						pPhyStatus,	
-	IN		PODM_PACKET_INFO_T			pPktinfo
-	)
-{
-#if (RTL8822B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType & ODM_RTL8822B) {
-		phydm_RxPhyStatusJaguarSeries2(pDM_Odm, pPhyStatus, pPktinfo, pPhyInfo);
-		return;
-	}
-#endif
-
-#if	ODM_IC_11AC_SERIES_SUPPORT
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		ODM_PhyStatusQuery_JaguarSeries(pDM_Odm, pPhyInfo, pPhyStatus, pPktinfo);
-#endif
-
-#if	ODM_IC_11N_SERIES_SUPPORT
-	if(pDM_Odm->SupportICType & ODM_IC_11N_SERIES )
-		ODM_PhyStatusQuery_92CSeries(pDM_Odm,pPhyInfo,pPhyStatus,pPktinfo);
-#endif
-}
-	
-// For future use.
-VOID
ODM_MacStatusQuery(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	IN 		pu1Byte						pMacStatus,
-	IN		u1Byte						MacID,	
-	IN		BOOLEAN						bPacketMatchBSSID,
-	IN		BOOLEAN						bPacketToSelf,
-	IN		BOOLEAN						bPacketBeacon
-	)
-{
-	// 2011/10/19 Driver team will handle in the future.
-	
-}
-
-
-//
-// If you want to add a new IC, Please follow below template and generate a new one.
-// 
-//
-
-HAL_STATUS
-ODM_ConfigRFWithHeaderFile(
-	IN 	PDM_ODM_T	        	pDM_Odm,
-	IN 	ODM_RF_Config_Type 		ConfigType,
-	IN 	ODM_RF_RADIO_PATH_E 	eRFPath
-    )
-{
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)	
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO		pMgntInfo = &(Adapter->MgntInfo);	
-#endif
-
-   ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, 
-		 		("===>ODM_ConfigRFWithHeaderFile (%s)\n", (pDM_Odm->bIsMPChip) ? "MPChip" : "TestChip"));
-    ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, 
-				("pDM_Odm->SupportPlatform: 0x%X, pDM_Odm->SupportInterface: 0x%X, pDM_Odm->BoardType: 0x%X\n",
-				pDM_Odm->SupportPlatform, pDM_Odm->SupportInterface, pDM_Odm->BoardType));
-
-//1 AP doesn't use PHYDM power tracking table in these ICs
-#if (DM_ODM_SUPPORT_TYPE !=  ODM_AP)
-#if (RTL8723A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8723A)
-	{
-		if(ConfigType == CONFIG_RF_RADIO) {
-			if(eRFPath == ODM_RF_PATH_A)
-				READ_AND_CONFIG_MP(8723A,_RadioA);
-		}
-	}
-#endif
-#if (RTL8812A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8812)
-	{
-		if(ConfigType == CONFIG_RF_RADIO) {
-			if(eRFPath == ODM_RF_PATH_A){
-				READ_AND_CONFIG_MP(8812A,_RadioA);
-			}
-			else if(eRFPath == ODM_RF_PATH_B){
-				READ_AND_CONFIG_MP(8812A,_RadioB);
-			}
-		}
-		else if(ConfigType == CONFIG_RF_TXPWR_LMT) {
-			#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-			HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-			if ((pHalData->EEPROMSVID == 0x17AA && pHalData->EEPROMSMID == 0xA811) ||
-				(pHalData->EEPROMSVID == 0x10EC && pHalData->EEPROMSMID == 0xA812) ||
-				(pHalData->EEPROMSVID == 0x10EC && pHalData->EEPROMSMID == 0x8812))
-				READ_AND_CONFIG_MP(8812A,_TXPWR_LMT_HM812A03);
-			else
-			#endif				
-			READ_AND_CONFIG_MP(8812A,_TXPWR_LMT);
-		}
-	}
-#endif
-#if (RTL8821A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8821)
-	{
-		if(ConfigType == CONFIG_RF_RADIO) {
-	 		if(eRFPath == ODM_RF_PATH_A){
-				READ_AND_CONFIG_MP(8821A,_RadioA);
-			}
-		}
-		else if(ConfigType == CONFIG_RF_TXPWR_LMT) {
-			if (pDM_Odm->SupportInterface == ODM_ITRF_USB) {
-				if (pDM_Odm->ExtPA5G || pDM_Odm->ExtLNA5G)
-					READ_AND_CONFIG_MP(8821A,_TXPWR_LMT_8811AU_FEM);
-				else
-					READ_AND_CONFIG_MP(8821A,_TXPWR_LMT_8811AU_IPA);				
-			} 
-			else {
-				#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-				if (pMgntInfo->CustomerID == RT_CID_8821AE_ASUS_MB)
-					READ_AND_CONFIG_MP(8821A,_TXPWR_LMT_8821A_SAR_8mm);
-				else if (pMgntInfo->CustomerID == RT_CID_ASUS_NB)
-					READ_AND_CONFIG_MP(8821A,_TXPWR_LMT_8821A_SAR_5mm);
-				else
-				#endif
-					READ_AND_CONFIG_MP(8821A,_TXPWR_LMT_8821A);			
-			}
-		}
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("<===8821_ODM_ConfigRFWithHeaderFile\n"));
-	}
-#endif
-
-#if (RTL8723B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8723B)
-	{
-		if(ConfigType == CONFIG_RF_RADIO)
-			READ_AND_CONFIG_MP(8723B,_RadioA);
-		else if(ConfigType == CONFIG_RF_TXPWR_LMT)
-			READ_AND_CONFIG_MP(8723B,_TXPWR_LMT);
-	}
-#endif
-
-#if (RTL8192E_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8192E)
-	{
-		if(ConfigType == CONFIG_RF_RADIO) {
-		 	if(eRFPath == ODM_RF_PATH_A)
-				READ_AND_CONFIG_MP(8192E,_RadioA);
-			else if(eRFPath == ODM_RF_PATH_B)
-				READ_AND_CONFIG_MP(8192E,_RadioB);
-		} else if (ConfigType == CONFIG_RF_TXPWR_LMT) {
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)	/*Refine by Vincent Lan for 5mm SAR pwr limit*/
-			HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-
-			if ((pHalData->EEPROMSVID == 0x11AD && pHalData->EEPROMSMID == 0x8192) || 
-				(pHalData->EEPROMSVID == 0x11AD && pHalData->EEPROMSMID == 0x8193))
-				READ_AND_CONFIG_MP(8192E, _TXPWR_LMT_8192E_SAR_5mm);
-			else
-#endif	
-			READ_AND_CONFIG_MP(8192E,_TXPWR_LMT);
-	}
-	}
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE !=  ODM_AP)
-
-//1 All platforms support
-#if (RTL8188E_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-		if(ConfigType == CONFIG_RF_RADIO) {
-			if(eRFPath == ODM_RF_PATH_A)
-					READ_AND_CONFIG_MP(8188E,_RadioA);
-		}
-		else if(ConfigType == CONFIG_RF_TXPWR_LMT)
-			READ_AND_CONFIG_MP(8188E,_TXPWR_LMT);
-	}
-#endif
-#if (RTL8814A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8814A)
-	{
-		if(ConfigType == CONFIG_RF_RADIO) {
-		 	if(eRFPath == ODM_RF_PATH_A)
-				READ_AND_CONFIG_MP(8814A,_RadioA);
-			else if(eRFPath == ODM_RF_PATH_B)
-				READ_AND_CONFIG_MP(8814A,_RadioB);
-			else if(eRFPath == ODM_RF_PATH_C)
-				READ_AND_CONFIG_MP(8814A,_RadioC);
-			else if(eRFPath == ODM_RF_PATH_D)
-				READ_AND_CONFIG_MP(8814A,_RadioD);
-		}	
-		else if(ConfigType == CONFIG_RF_TXPWR_LMT) 
-			READ_AND_CONFIG_MP(8814A,_TXPWR_LMT);
-	}
-#endif
-#if (RTL8703B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8703B) {
-		if (ConfigType == CONFIG_RF_RADIO) {
-			if (eRFPath == ODM_RF_PATH_A)
-				READ_AND_CONFIG_MP(8703B, _RadioA);
-		}	
-	}
-#endif
-
-#if (RTL8188F_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8188F) {
-		if (ConfigType == CONFIG_RF_RADIO) {
-			if (eRFPath == ODM_RF_PATH_A)
-				READ_AND_CONFIG_MP(8188F, _RadioA);
-		} else if (ConfigType == CONFIG_RF_TXPWR_LMT)
-			READ_AND_CONFIG_MP(8188F, _TXPWR_LMT);
-	}
-#endif
-
-//1 New ICs (WIN only)
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-#if (RTL8821B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8821B)
-	{
-		if (ConfigType == CONFIG_RF_RADIO) {
-	 		if (eRFPath == ODM_RF_PATH_A)
-				READ_AND_CONFIG(8821B, _RadioA);
-		} else if (ConfigType == CONFIG_RF_TXPWR_LMT)
-			READ_AND_CONFIG(8821B, _TXPWR_LMT);
-	}
-#endif
-#if (RTL8822B_SUPPORT == 1)
-		if (pDM_Odm->SupportICType == ODM_RTL8822B)
-		{
-			if(ConfigType == CONFIG_RF_RADIO) {
-				if(eRFPath == ODM_RF_PATH_A)
-					READ_AND_CONFIG_MP(8822B, _RadioA);
-				else if(eRFPath == ODM_RF_PATH_B)
-					READ_AND_CONFIG_MP(8822B, _RadioB);
-			}	
-		}
-#endif
-#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-#if (RTL8188F_SUPPORT == 1)
-		if (pDM_Odm->SupportICType == ODM_RTL8188F)
-		{
-			if(ConfigType == CONFIG_RF_RADIO) {
-				if(eRFPath == ODM_RF_PATH_A)
-					READ_AND_CONFIG_TC(8188F,_RadioA);
-			}	
-		}
-#endif
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-
-	return HAL_STATUS_SUCCESS;
-}
-
-HAL_STATUS
-ODM_ConfigRFWithTxPwrTrackHeaderFile(
-	IN 	PDM_ODM_T	        	pDM_Odm
-    )
-{
-   	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, 
-		 		 ("===>ODM_ConfigRFWithTxPwrTrackHeaderFile (%s)\n", (pDM_Odm->bIsMPChip) ? "MPChip" : "TestChip"));
-   	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, 
-				 ("pDM_Odm->SupportPlatform: 0x%X, pDM_Odm->SupportInterface: 0x%X, pDM_Odm->BoardType: 0x%X\n",
-				 pDM_Odm->SupportPlatform, pDM_Odm->SupportInterface, pDM_Odm->BoardType));
-
-
-//1 AP doesn't use PHYDM power tracking table in these ICs
-#if (DM_ODM_SUPPORT_TYPE !=  ODM_AP)
-#if RTL8821A_SUPPORT
-	if(pDM_Odm->SupportICType == ODM_RTL8821)
-	{
-		if (pDM_Odm->SupportInterface == ODM_ITRF_PCIE)
-			READ_AND_CONFIG_MP(8821A,_TxPowerTrack_PCIE);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_USB)
-			READ_AND_CONFIG_MP(8821A,_TxPowerTrack_USB);			
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_SDIO)
-			READ_AND_CONFIG_MP(8821A,_TxPowerTrack_SDIO);
-	}
-#endif	
-#if RTL8812A_SUPPORT	
-	if(pDM_Odm->SupportICType == ODM_RTL8812)
-	{
-		if (pDM_Odm->SupportInterface == ODM_ITRF_PCIE)
-			READ_AND_CONFIG_MP(8812A,_TxPowerTrack_PCIE);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_USB) {
-			if (pDM_Odm->RFEType == 3 && pDM_Odm->bIsMPChip) 
-				READ_AND_CONFIG_MP(8812A,_TxPowerTrack_RFE3);	
-			else
-				READ_AND_CONFIG_MP(8812A,_TxPowerTrack_USB);	
-		}
-		
-	}
-#endif	
-#if RTL8192E_SUPPORT 	
-	if(pDM_Odm->SupportICType == ODM_RTL8192E)
-	{
-		if (pDM_Odm->SupportInterface == ODM_ITRF_PCIE)
-			READ_AND_CONFIG_MP(8192E,_TxPowerTrack_PCIE);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_USB)
-			READ_AND_CONFIG_MP(8192E,_TxPowerTrack_USB); 
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_SDIO)
-			READ_AND_CONFIG_MP(8192E,_TxPowerTrack_SDIO); 
-	}
-#endif
-#if RTL8723B_SUPPORT 	
-	if(pDM_Odm->SupportICType == ODM_RTL8723B)
-	{
-		if (pDM_Odm->SupportInterface == ODM_ITRF_PCIE)
-			READ_AND_CONFIG_MP(8723B,_TxPowerTrack_PCIE);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_USB)
-			READ_AND_CONFIG_MP(8723B,_TxPowerTrack_USB);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_SDIO)
-			READ_AND_CONFIG_MP(8723B,_TxPowerTrack_SDIO); 			
-	}
-#endif	
-#if RTL8188E_SUPPORT 	
-	if(pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-		if (pDM_Odm->SupportInterface == ODM_ITRF_PCIE)
-			READ_AND_CONFIG_MP(8188E,_TxPowerTrack_PCIE);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_USB)
-			READ_AND_CONFIG_MP(8188E,_TxPowerTrack_USB);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_SDIO)
-			READ_AND_CONFIG_MP(8188E,_TxPowerTrack_SDIO);
-	}
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE !=  ODM_AP)
-
-//1 All platforms support
-#if RTL8814A_SUPPORT
-	if(pDM_Odm->SupportICType == ODM_RTL8814A) 
-	{
-		if(pDM_Odm->RFEType == 0)
-			READ_AND_CONFIG_MP(8814A,_TxPowerTrack_Type0);
-		else if(pDM_Odm->RFEType == 2)
-			READ_AND_CONFIG_MP(8814A,_TxPowerTrack_Type2);
-		else if (pDM_Odm->RFEType == 5)
-			READ_AND_CONFIG_MP(8814A, _TxPowerTrack_Type5);
-		else
-			READ_AND_CONFIG_MP(8814A,_TxPowerTrack);
-	}
-#endif	
-#if RTL8703B_SUPPORT
-	if (pDM_Odm->SupportICType == ODM_RTL8703B) {
-		if (pDM_Odm->SupportInterface == ODM_ITRF_USB)
-			READ_AND_CONFIG_MP(8703B, _TxPowerTrack_USB);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_SDIO)
-			READ_AND_CONFIG_MP(8703B, _TxPowerTrack_SDIO);		
-	}
-#endif
-
-#if RTL8188F_SUPPORT
-	if (pDM_Odm->SupportICType == ODM_RTL8188F) {
-		if (pDM_Odm->SupportInterface == ODM_ITRF_USB)
-			READ_AND_CONFIG_MP(8188F, _TxPowerTrack_USB);
-		else if (pDM_Odm->SupportInterface == ODM_ITRF_SDIO)
-			READ_AND_CONFIG_MP(8188F, _TxPowerTrack_SDIO);
-	}
-#endif
-
-//1 New ICs (WIN only)
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-#if RTL8821B_SUPPORT
-	if(pDM_Odm->SupportICType == ODM_RTL8821B)
-			READ_AND_CONFIG(8821B,_TxPowerTrack);			
-#endif	
-#if RTL8822B_SUPPORT
-/*	if(pDM_Odm->SupportICType == ODM_RTL8822B)
-			READ_AND_CONFIG_MP(8822B, _TxPowerTrack);			*/
-#endif	
-
-#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-#if RTL8188F_SUPPORT
-	if(pDM_Odm->SupportICType == ODM_RTL8188F)
-			READ_AND_CONFIG_TC(8188F,_TxPowerTrack_PCIE);			
-#endif	
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-
-
-	return HAL_STATUS_SUCCESS;
-}
-
-HAL_STATUS
-ODM_ConfigBBWithHeaderFile(
-	IN 	PDM_ODM_T	             	pDM_Odm,
-	IN 	ODM_BB_Config_Type 		ConfigType
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)	
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO		pMgntInfo = &(Adapter->MgntInfo);	
-#endif
-
-//1 AP doesn't use PHYDM initialization in these ICs
-#if (DM_ODM_SUPPORT_TYPE !=  ODM_AP)	
-#if (RTL8723A_SUPPORT == 1) 
-	if(pDM_Odm->SupportICType == ODM_RTL8723A)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG){
-			READ_AND_CONFIG_MP(8723A,_PHY_REG);
-		}else if(ConfigType == CONFIG_BB_AGC_TAB){
-			READ_AND_CONFIG_MP(8723A,_AGC_TAB);
-		}		
-	}		
-#endif
-#if (RTL8812A_SUPPORT == 1) 
-	if(pDM_Odm->SupportICType == ODM_RTL8812)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG){
-			READ_AND_CONFIG_MP(8812A,_PHY_REG);
-		}else if(ConfigType == CONFIG_BB_AGC_TAB){
-			READ_AND_CONFIG_MP(8812A,_AGC_TAB);
-		}
-		else if(ConfigType == CONFIG_BB_PHY_REG_PG)
-		{
-			if (pDM_Odm->RFEType == 3 && pDM_Odm->bIsMPChip) 
-				READ_AND_CONFIG_MP(8812A,_PHY_REG_PG_ASUS);
-			#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-			else if (pMgntInfo->CustomerID == RT_CID_WNC_NEC && pDM_Odm->bIsMPChip) 
-				READ_AND_CONFIG_MP(8812A,_PHY_REG_PG_NEC);
-			#endif			
-			else
-				READ_AND_CONFIG_MP(8812A,_PHY_REG_PG);
-		}
-		else if(ConfigType == CONFIG_BB_PHY_REG_MP){
-			READ_AND_CONFIG_MP(8812A,_PHY_REG_MP);
-		}
-		else if(ConfigType == CONFIG_BB_AGC_TAB_DIFF)
-		{
-			if ((36 <= *pDM_Odm->pChannel)  && (*pDM_Odm->pChannel  <= 64)) 
-				AGC_DIFF_CONFIG_MP(8812A,LB);
-			else if (100 <= *pDM_Odm->pChannel) 
-				AGC_DIFF_CONFIG_MP(8812A,HB);
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_LOUD, (" ===> phy_ConfigBBWithHeaderFile() phy:Rtl8812AGCTABArray\n"));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_LOUD, (" ===> phy_ConfigBBWithHeaderFile() agc:Rtl8812PHY_REGArray\n"));
-	}		
-#endif
-#if (RTL8821A_SUPPORT == 1) 
-	if(pDM_Odm->SupportICType == ODM_RTL8821)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG){
-			READ_AND_CONFIG_MP(8821A,_PHY_REG);
-		}else if(ConfigType == CONFIG_BB_AGC_TAB){
-			READ_AND_CONFIG_MP(8821A,_AGC_TAB);
-		}else if(ConfigType == CONFIG_BB_PHY_REG_PG){
-			READ_AND_CONFIG_MP(8821A,_PHY_REG_PG);
-		}		
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_LOUD, (" ===> phy_ConfigBBWithHeaderFile() phy:Rtl8821AGCTABArray\n"));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_LOUD, (" ===> phy_ConfigBBWithHeaderFile() agc:Rtl8821PHY_REGArray\n"));
-	}		
-#endif
-#if (RTL8723B_SUPPORT == 1)
-	if(pDM_Odm->SupportICType == ODM_RTL8723B)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG){
-			READ_AND_CONFIG_MP(8723B,_PHY_REG);
-		}else if(ConfigType == CONFIG_BB_AGC_TAB){
-			READ_AND_CONFIG_MP(8723B,_AGC_TAB);
-		}else if(ConfigType == CONFIG_BB_PHY_REG_PG){
-			READ_AND_CONFIG_MP(8723B,_PHY_REG_PG);
-		}
-	}
-#endif
-#if (RTL8192E_SUPPORT == 1)
-	if(pDM_Odm->SupportICType == ODM_RTL8192E)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG){
-			READ_AND_CONFIG_MP(8192E,_PHY_REG);
-		}else if(ConfigType == CONFIG_BB_AGC_TAB){
-			READ_AND_CONFIG_MP(8192E,_AGC_TAB);
-		}else if(ConfigType == CONFIG_BB_PHY_REG_PG){
-			READ_AND_CONFIG_MP(8192E,_PHY_REG_PG);
-		}
-	}
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE !=  ODM_AP)
-
-
-//1 All platforms support
-#if (RTL8188E_SUPPORT == 1)
-	if(pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG)
-			READ_AND_CONFIG_MP(8188E,_PHY_REG);
-		else if(ConfigType == CONFIG_BB_AGC_TAB)
-			READ_AND_CONFIG_MP(8188E,_AGC_TAB);
-		else if(ConfigType == CONFIG_BB_PHY_REG_PG)
-			READ_AND_CONFIG_MP(8188E,_PHY_REG_PG);
-	}
-#endif
-#if (RTL8814A_SUPPORT == 1)
-	if(pDM_Odm->SupportICType == ODM_RTL8814A)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG){
-			READ_AND_CONFIG_MP(8814A,_PHY_REG);
-		}else if(ConfigType == CONFIG_BB_AGC_TAB){
-			READ_AND_CONFIG_MP(8814A,_AGC_TAB);
-		}else if(ConfigType == CONFIG_BB_PHY_REG_PG){
-			READ_AND_CONFIG_MP(8814A,_PHY_REG_PG);
-		}else if(ConfigType == CONFIG_BB_PHY_REG_MP){
-			READ_AND_CONFIG_MP(8814A,_PHY_REG_MP);
-		}
-	}
-#endif
-#if (RTL8703B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8703B) {
-		if (ConfigType == CONFIG_BB_PHY_REG)
-			READ_AND_CONFIG_MP(8703B, _PHY_REG);
-		else if (ConfigType == CONFIG_BB_AGC_TAB)
-			READ_AND_CONFIG_MP(8703B, _AGC_TAB);
-		else if (ConfigType == CONFIG_BB_PHY_REG_PG)
-			READ_AND_CONFIG_MP(8703B, _PHY_REG_PG);
-	}
-#endif
-
-#if (RTL8188F_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8188F) {
-		if (ConfigType == CONFIG_BB_PHY_REG) 
-			READ_AND_CONFIG_MP(8188F, _PHY_REG);
-		else if (ConfigType == CONFIG_BB_AGC_TAB) 
-			READ_AND_CONFIG_MP(8188F, _AGC_TAB);
-		else if (ConfigType == CONFIG_BB_PHY_REG_PG) 
-			READ_AND_CONFIG_MP(8188F, _PHY_REG_PG);
-	}
-#endif
-
-//1 New ICs (WIN only)
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-#if (RTL8821B_SUPPORT == 1) 
-	if(pDM_Odm->SupportICType == ODM_RTL8821B)
-	{
-		if (ConfigType == CONFIG_BB_PHY_REG) {
-			READ_AND_CONFIG(8821B,_PHY_REG);
-		} else if (ConfigType == CONFIG_BB_AGC_TAB) { 
-		    READ_AND_CONFIG(8821B,_AGC_TAB);
-		} else if (ConfigType == CONFIG_BB_PHY_REG_PG) {
-			READ_AND_CONFIG(8821B,_PHY_REG_PG);
-		}
-	}		
-#endif
-#if (RTL8822B_SUPPORT == 1)
-	if(pDM_Odm->SupportICType == ODM_RTL8822B)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG)
-			READ_AND_CONFIG_MP(8822B, _PHY_REG);
-		else if(ConfigType == CONFIG_BB_AGC_TAB)
-			READ_AND_CONFIG_MP(8822B, _AGC_TAB);
-/*		else if(ConfigType == CONFIG_BB_PHY_REG_PG)
-			READ_AND_CONFIG_MP(8822B, _PHY_REG_PG);
-		else if(ConfigType == CONFIG_BB_PHY_REG_MP)
-			READ_AND_CONFIG_MP(8822B, _PHY_REG_MP); */
-	}
-#endif
-#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-#if (RTL8188F_SUPPORT == 1)
-	if(pDM_Odm->SupportICType == ODM_RTL8188F)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG)
-			READ_AND_CONFIG_TC(8188F,_PHY_REG);
-		else if(ConfigType == CONFIG_BB_AGC_TAB)
-			READ_AND_CONFIG_TC(8188F,_AGC_TAB);
-		else if(ConfigType == CONFIG_BB_PHY_REG_PG)
-			READ_AND_CONFIG_TC(8188F,_PHY_REG_PG);
-	}
-#endif
-#endif
-#if (RTL8195A_SUPPORT == 1)
-	if(pDM_Odm->SupportICType == ODM_RTL8195A)
-	{
-		if(ConfigType == CONFIG_BB_PHY_REG)
-			READ_AND_CONFIG(8195A,_PHY_REG);
-		else if(ConfigType == CONFIG_BB_AGC_TAB)
-			READ_AND_CONFIG(8195A,_AGC_TAB);
-		else if(ConfigType == CONFIG_BB_PHY_REG_PG)
-			READ_AND_CONFIG(8195A,_PHY_REG_PG);
-	}
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-
-	return HAL_STATUS_SUCCESS; 
-}                 
-
-HAL_STATUS
-ODM_ConfigMACWithHeaderFile(
-	IN 	PDM_ODM_T	pDM_Odm
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)	
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO		pMgntInfo = &(Adapter->MgntInfo);	
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, 
-		 		("===>ODM_ConfigMACWithHeaderFile (%s)\n", (pDM_Odm->bIsMPChip) ? "MPChip" : "TestChip"));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, 
-				("pDM_Odm->SupportPlatform: 0x%X, pDM_Odm->SupportInterface: 0x%X, pDM_Odm->BoardType: 0x%X\n",
-				pDM_Odm->SupportPlatform, pDM_Odm->SupportInterface, pDM_Odm->BoardType));
-
-//1 AP doesn't use PHYDM initialization in these ICs
-#if (DM_ODM_SUPPORT_TYPE !=  ODM_AP)	
-#if (RTL8723A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8723A){
-		READ_AND_CONFIG_MP(8723A,_MAC_REG);
-	}
-#endif
-#if (RTL8812A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8812){
-		READ_AND_CONFIG_MP(8812A,_MAC_REG);
-	}
-#endif
-#if (RTL8821A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8821){
-		READ_AND_CONFIG_MP(8821A,_MAC_REG);
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("<===8821_ODM_ConfigMACwithHeaderFile\n"));
-	}
-#endif
-#if (RTL8723B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8723B){
-		READ_AND_CONFIG_MP(8723B,_MAC_REG);
-	}
-#endif
-#if (RTL8192E_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8192E){
-		READ_AND_CONFIG_MP(8192E,_MAC_REG);
-	}
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE !=  ODM_AP)
-
-//1 All platforms support
-#if (RTL8188E_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8188E){
-		READ_AND_CONFIG_MP(8188E,_MAC_REG);
-	}
-#endif
-#if (RTL8814A_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8814A){
-		READ_AND_CONFIG_MP(8814A,_MAC_REG);
-	}
-#endif
-#if (RTL8703B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8703B)
-		READ_AND_CONFIG_MP(8703B, _MAC_REG);
-#endif
-
-#if (RTL8188F_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8188F) 
-		READ_AND_CONFIG_MP(8188F, _MAC_REG);
-#endif
-
-//1 New ICs (WIN only)
-#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)
-#if (RTL8821B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8821B){
-		READ_AND_CONFIG(8821B,_MAC_REG);
-	}
-#endif
-#if (RTL8822B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8822B)
-		READ_AND_CONFIG_MP(8822B, _MAC_REG);
-#endif
-
-#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-#if (RTL8188F_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8188F)
-		READ_AND_CONFIG_TC(8188F,_MAC_REG);
-#endif
-#endif
-#if (RTL8195A_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8195A)
-		READ_AND_CONFIG_MP(8195A,_MAC_REG);
-#endif
-#endif /*#if (DM_ODM_SUPPORT_TYPE &  ODM_WIN)*/
-
-	return HAL_STATUS_SUCCESS;    
-} 
-
-HAL_STATUS
-ODM_ConfigFWWithHeaderFile(
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN 	ODM_FW_Config_Type 	ConfigType,
-	OUT u1Byte				*pFirmware,
-	OUT u4Byte				*pSize
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-
-#if (RTL8188E_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8188E)
-	{
-	#ifdef CONFIG_SFW_SUPPORTED
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8188E_T,_FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8188E_T,_FW_WoWLAN);
-		else if(ConfigType == CONFIG_FW_NIC_2)
-			READ_FIRMWARE_MP(8188E_S,_FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN_2)
-			READ_FIRMWARE_MP(8188E_S,_FW_WoWLAN);
-		#ifdef CONFIG_AP_WOWLAN
-		if (ConfigType == CONFIG_FW_AP)
-			READ_FIRMWARE_MP(8188E_T,_FW_AP);
-		else if (ConfigType == CONFIG_FW_AP_2)
-			READ_FIRMWARE_MP(8188E_S,_FW_AP);
-		#endif //CONFIG_AP_WOWLAN
-	#else
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8188E_T,_FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8188E_T,_FW_WoWLAN);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP)
-			READ_FIRMWARE_MP(8188E_T,_FW_AP);
-		#endif //CONFIG_AP_WOWLAN
-	#endif
-	}
-#endif
-#if (RTL8723B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8723B)
-	{
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8723B,_FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8723B,_FW_WoWLAN);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP_WoWLAN)
-			READ_FIRMWARE(8723B,_FW_AP_WoWLAN);
-		#endif
-		
-	}
-#endif //#if (RTL8723B_SUPPORT == 1)  
-#if (RTL8812A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8812)
-	{
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8812A,_FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8812A,_FW_WoWLAN);
-		else if (ConfigType == CONFIG_FW_BT)
-			READ_FIRMWARE_MP(8812A,_FW_NIC_BT);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP_WoWLAN)
-			READ_FIRMWARE(8812A,_FW_AP);
-		#endif
-	}
-#endif
-#if (RTL8821A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8821){
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8821A,_FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8821A,_FW_WoWLAN);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP_WoWLAN)
-			READ_FIRMWARE_MP(8821A , _FW_AP);
-		#endif /*CONFIG_AP_WOWLAN*/
-		else if (ConfigType == CONFIG_FW_BT)
-			READ_FIRMWARE_MP(8821A,_FW_NIC_BT);
-	}
-#endif
-#if (RTL8192E_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8192E)
-	{
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8192E,_FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8192E,_FW_WoWLAN);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP_WoWLAN)
-			READ_FIRMWARE_MP(8192E,_FW_AP);
-		#endif
-	}
-#endif
-#if (RTL8814A_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8814A)
-	{
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8814A,_FW_NIC);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP_WoWLAN)
-			READ_FIRMWARE_MP(8814A,_FW_AP);
-		#endif
-	}
-#endif
-#if (RTL8703B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8703B) {
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8703B, _FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8703B, _FW_WoWLAN);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP_WoWLAN)
-			READ_FIRMWARE(8703B, _FW_AP_WoWLAN);
-		#endif
-	}
-#endif
-
-#if (RTL8188F_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8188F) {
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8188F, _FW_NIC);
-		else if (ConfigType == CONFIG_FW_WoWLAN)
-			READ_FIRMWARE_MP(8188F, _FW_WoWLAN);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP)
-			READ_FIRMWARE_MP(8188F,_FW_AP);
-		#endif
-	}
-#endif
-
-//1 New ICs (WIN only)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#if (RTL8821B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8821B)
-	{
-	}
-#endif
-#if (RTL8822B_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8822B)
-	{
-		/*
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8822B,_FW_NIC);
-		#ifdef CONFIG_AP_WOWLAN
-		else if (ConfigType == CONFIG_FW_AP_WoWLAN)
-			READ_FIRMWARE(8822B,_FW_AP);
-		#endif */
-	}
-#endif
-#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-#if (RTL8188F_SUPPORT == 1)
-	if (pDM_Odm->SupportICType == ODM_RTL8188F)
-	{
-		if (ConfigType == CONFIG_FW_NIC)
-			READ_FIRMWARE_MP(8188F,_FW_NIC);
-	}
-#endif
-#endif
-#endif//(DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-#endif//(DM_ODM_SUPPORT_TYPE != ODM_AP)
-	return HAL_STATUS_SUCCESS;    
-} 
-
-u4Byte 
-ODM_GetHWImgVersion(
-	IN	PDM_ODM_T	pDM_Odm
-	)
-{
-    u4Byte  Version=0;
-
-//1 AP doesn't use PHYDM initialization in these ICs
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-#if (RTL8723A_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8723A)
-		Version = GET_VERSION_MP(8723A,_MAC_REG);
-#endif
-#if (RTL8723B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8723B)
-		Version = GET_VERSION_MP(8723B,_MAC_REG);
-#endif
-#if (RTL8821A_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8821)
-		Version = GET_VERSION_MP(8821A,_MAC_REG);
-#endif
-#if (RTL8192E_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8192E)
-		Version = GET_VERSION_MP(8192E,_MAC_REG);
-#endif
-#if (RTL8812A_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8812)
-		Version = GET_VERSION_MP(8812A,_MAC_REG);
-#endif
-#endif //(DM_ODM_SUPPORT_TYPE != ODM_AP)
-
-/*1 All platforms support*/
-#if (RTL8188E_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8188E)
-		Version = GET_VERSION_MP(8188E,_MAC_REG);
-#endif
-#if (RTL8814A_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8814A)
-		Version = GET_VERSION_MP(8814A,_MAC_REG);
-#endif
-#if (RTL8703B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8703B)
-		Version = GET_VERSION_MP(8703B, _MAC_REG);
-#endif
-#if (RTL8188F_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8188F)
-		Version = GET_VERSION_MP(8188F, _MAC_REG);
-#endif
-
-//1 New ICs (WIN only)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#if (RTL8821B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8821B)
-		Version = GET_VERSION(8821B,_MAC_REG);
-#endif
-#if (RTL8822B_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8822B)
-		Version = GET_VERSION(8822B, _MAC_REG);
-#endif
-#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-#if (RTL8188F_SUPPORT == 1)  
-	if (pDM_Odm->SupportICType == ODM_RTL8188F)
-		Version = GET_VERSION_TC(8188F, _MAC_REG);
-#endif
-#endif
-#endif //(DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-	return Version;
-}
-
-#if (RTL8822B_SUPPORT == 1)
-/* For 8822B only!! need to move to FW finally */
-/*==============================================*/
-
-VOID
-phydm_ResetPhyInfo(
-	IN		PDM_ODM_T					pPhydm,
-	OUT		PODM_PHY_INFO_T			pPhyInfo
-)
-{
-	pPhyInfo->RxPWDBAll = 0;
-	pPhyInfo->SignalQuality = 0;
-	pPhyInfo->BandWidth = 0;
-#if (RTL8822B_SUPPORT == 1)
-	pPhyInfo->RxCount = 0;
-#endif
-	ODM_Memory_Set(pPhydm, pPhyInfo->RxMIMOSignalQuality, 0 , 4);
-	ODM_Memory_Set(pPhydm, pPhyInfo->RxMIMOSignalStrength, 0, 4);
-	ODM_Memory_Set(pPhydm, pPhyInfo->RxSNR, 0, 4);
-
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))	
-	pPhyInfo->RxPower = -110;
-	pPhyInfo->RecvSignalPower = -110;
-	pPhyInfo->BTRxRSSIPercentage = 0;
-	pPhyInfo->SignalStrength = 0;
-	pPhyInfo->btCoexPwrAdjust = 0;
-#if (RTL8822B_SUPPORT == 1)
-	pPhyInfo->channel = 0;
-	pPhyInfo->bMuPacket = 0;
-	pPhyInfo->bBeamformed = 0;
-	pPhyInfo->rxsc = 0;
-#endif
-	ODM_Memory_Set(pPhydm, pPhyInfo->RxPwr, -110, 4);
-	ODM_Memory_Set(pPhydm, pPhyInfo->RxMIMOEVMdbm, 0, 4);
-	ODM_Memory_Set(pPhydm, pPhyInfo->Cfo_short, 0, 8);
-	ODM_Memory_Set(pPhydm, pPhyInfo->Cfo_tail, 0, 8);
-#endif
-}
-
-VOID
-phydm_SetPerPathPhyInfo(
-	IN		u1Byte							RxPath,
-	IN		s1Byte							RxPwr,
-	IN		s1Byte							RxEVM,
-	IN		s1Byte							Cfo_tail,
-	IN		s1Byte							RxSNR,
-	OUT		PODM_PHY_INFO_T				pPhyInfo
-)
-{
-	u1Byte			EVMdBm = 0;
-	u1Byte			EVMPercentage = 0;
-
-	/* SNR is S(8,1), EVM is S(8,1), CFO is S(8,7) */
-	
-	if (RxEVM < 0) {
-		/* Calculate EVM in dBm */
-		EVMdBm = ((u1Byte)(0 - RxEVM) >> 1);
-
-		/* Calculate EVM in percentage */
-		if (EVMdBm >= 33)
-			EVMPercentage = 100;
-		else 
-			EVMPercentage = (EVMdBm << 1) + (EVMdBm);
-	}
-	
-
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-	pPhyInfo->RxPwr[RxPath] = RxPwr;
-	pPhyInfo->RxMIMOEVMdbm[RxPath] = EVMdBm;
-
-	/* CFO = CFO_tail * 312.5 / 2^7 ~= CFO tail * 39/512 (kHz)*/
-	pPhyInfo->Cfo_tail[RxPath] = Cfo_tail;
-	pPhyInfo->Cfo_tail[RxPath] = ((pPhyInfo->Cfo_tail[RxPath] << 5) + (pPhyInfo->Cfo_tail[RxPath] << 2) +
-		(pPhyInfo->Cfo_tail[RxPath] << 1) + (pPhyInfo->Cfo_tail[RxPath])) >> 9;
-#endif
-
-	pPhyInfo->RxMIMOSignalStrength[RxPath] = odm_QueryRxPwrPercentage(RxPwr);
-	pPhyInfo->RxMIMOSignalQuality[RxPath] = EVMPercentage;
-	pPhyInfo->RxSNR[RxPath] = RxSNR >> 1;
-
-/*
-	//if (pPktinfo->bPacketMatchBSSID) 
-	{
-		DbgPrint("Path (%d)--------\n", RxPath);
-		DbgPrint("RxPwr = %d, Signal strength = %d\n", pPhyInfo->RxPwr[RxPath], pPhyInfo->RxMIMOSignalStrength[RxPath]);
-		DbgPrint("EVMdBm = %d, Signal quality = %d\n", pPhyInfo->RxMIMOEVMdbm[RxPath], pPhyInfo->RxMIMOSignalQuality[RxPath]);
-		DbgPrint("CFO = %d, SNR = %d\n", pPhyInfo->Cfo_tail[RxPath], pPhyInfo->RxSNR[RxPath]);
-	}	
-*/
-}
-
-VOID
-phydm_SetCommonPhyInfo(
-	IN		s1Byte							RxPower,
-	IN		u1Byte							channel,
-	IN		BOOLEAN							bBeamformed,
-	IN		BOOLEAN							bMuPacket,
-	IN		u1Byte							bandwidth,
-	IN		u1Byte							signalQuality,
-	IN		u1Byte							rxsc,
-	OUT		PODM_PHY_INFO_T				pPhyInfo
-)
-{
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-	pPhyInfo->RxPower = RxPower;											/* RSSI in dB */
-	pPhyInfo->RecvSignalPower = RxPower;										/* RSSI in dB */
-	pPhyInfo->channel = channel;												/* channel number */
-	pPhyInfo->bBeamformed = bBeamformed;									/* apply BF */
-	pPhyInfo->bMuPacket = bMuPacket;										/* MU packet */
-	pPhyInfo->rxsc = rxsc;
-#endif
-	pPhyInfo->RxPWDBAll = odm_QueryRxPwrPercentage(RxPower);				/* RSSI in percentage */
-	pPhyInfo->SignalQuality = signalQuality;										/* signal quality */
-	pPhyInfo->BandWidth = bandwidth;											/* bandwidth */
-
-/*
-	//if (pPktinfo->bPacketMatchBSSID)
-	{
-		DbgPrint("RxPWDBAll = %d, RxPower = %d, RecvSignalPower = %d\n", pPhyInfo->RxPWDBAll, pPhyInfo->RxPower, pPhyInfo->RecvSignalPower);
-		DbgPrint("SignalQuality = %d\n", pPhyInfo->SignalQuality);
-		DbgPrint("bBeamformed = %d, bMuPacket = %d, RxCount = %d\n", pPhyInfo->bBeamformed, pPhyInfo->bMuPacket, pPhyInfo->RxCount + 1);
-		DbgPrint("channel = %d, rxsc = %d, BandWidth = %d\n", channel, rxsc, bandwidth);
-	}
-*/
-}
-
-VOID
-phydm_GetRxPhyStatusType0(
-	IN		PDM_ODM_T						pDM_Odm,
-	IN		pu1Byte							pPhyStatus,
-	IN		PODM_PACKET_INFO_T				pPktinfo,
-	OUT		PODM_PHY_INFO_T				pPhyInfo
-)
-{
-	/* Type 0 is used for cck packet */
-	
-	PPHY_STATUS_RPT_JAGUAR2_TYPE0	pPhyStaRpt = (PPHY_STATUS_RPT_JAGUAR2_TYPE0)pPhyStatus;
-	u1Byte							i, SQ = 0;
-
-	/* Calculate Signal Quality*/
-	if (pPktinfo->bPacketMatchBSSID) {
-		if (pPhyStaRpt->signal_quality >= 64)
-			SQ = 0;
-		else if (pPhyStaRpt->signal_quality <= 20)
-			SQ = 100;
-		else {
-			/* mapping to 2~99% */
-			SQ = 64 - pPhyStaRpt->signal_quality;
-			SQ = ((SQ << 3) + SQ) >> 2;
-		}
-	}
-
-	/* Update CCK packet counter */
-	pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK++;
-
-	/* Update Common information */
-	phydm_SetCommonPhyInfo((pPhyStaRpt->pwdb - 110), pPhyStaRpt->channel, FALSE, 
-		FALSE, ODM_BW20M, SQ, pPhyStaRpt->rxsc, pPhyInfo);
-
-	/* Update CCK pwdb */
-	phydm_SetPerPathPhyInfo(ODM_RF_PATH_A, (pPhyStaRpt->pwdb - 110), 0, 0, 0, pPhyInfo);					/* Update per-path information */
-
-/*
-	//if (pPktinfo->bPacketMatchBSSID)
-	{
-		DbgPrint("pwdb = 0x%x, MP gain index = 0x%x, TRSW = 0x%x\n", pPhyStaRpt->pwdb, pPhyStaRpt->gain, pPhyStaRpt->trsw);
-		DbgPrint("channel = %d, band = %d, rxsc = %d\n", pPhyStaRpt->channel, pPhyStaRpt->band, pPhyStaRpt->rxsc);
-		DbgPrint("agc_table = 0x%x, agc_rpt 0x%x, bb_power = 0x%x\n", pPhyStaRpt->agc_table, pPhyStaRpt->agc_rpt, pPhyStaRpt->bb_power);
-		DbgPrint("length = %d, SQ = %d\n", pPhyStaRpt->length, pPhyStaRpt->signal_quality);
-		DbgPrint("antidx a = 0x%x, b = 0x%x, c = 0x%x, d = 0x%x\n", pPhyStaRpt->antidx_a, pPhyStaRpt->antidx_b, pPhyStaRpt->antidx_c, pPhyStaRpt->antidx_d);
-		DbgPrint("rsvd_0 = 0x%x, rsvd_1 = 0x%x, rsvd_2 = 0x%x\n", pPhyStaRpt->rsvd_0, pPhyStaRpt->rsvd_1, pPhyStaRpt->rsvd_2);
-		DbgPrint("rsvd_3 = 0x%x, rsvd_4 = 0x%x, rsvd_5 = 0x%x\n", pPhyStaRpt->rsvd_3, pPhyStaRpt->rsvd_4, pPhyStaRpt->rsvd_5);
-		DbgPrint("rsvd_6 = 0x%x, rsvd_7 = 0x%x, rsvd_8 = 0x%x\n", pPhyStaRpt->rsvd_6, pPhyStaRpt->rsvd_7, pPhyStaRpt->rsvd_8);
-	}
-*/
-}
-
-VOID
-phydm_GetRxPhyStatusType1(
-	IN		PDM_ODM_T						pDM_Odm,
-	IN		pu1Byte							pPhyStatus,
-	IN		PODM_PACKET_INFO_T				pPktinfo,
-	OUT		PODM_PHY_INFO_T				pPhyInfo
-)
-{
-	/* Type 1 is used for ofdm packet */
-
-	PPHY_STATUS_RPT_JAGUAR2_TYPE1	pPhyStaRpt = (PPHY_STATUS_RPT_JAGUAR2_TYPE1)pPhyStatus;
-	s1Byte							rx_pwr_db = -120;
-	u1Byte							i, rxsc, bw, RxCount = 0;
-	BOOLEAN							bMU;
-
-	/* Update OFDM packet counter */
-	pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM++;
-
-	/* Update per-path information */
-	for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-		if (pDM_Odm->RXAntStatus & BIT(i)) {
-			s1Byte	rx_path_pwr_db;
-
-			/* RX path counter */
-			RxCount++;
-
-			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO SQ) */
-			/* EVM report is reported by stream, not path */
-			rx_path_pwr_db = pPhyStaRpt->pwdb[i] - 110;					/* per-path pwdb in dB domain */
-			phydm_SetPerPathPhyInfo(i, rx_path_pwr_db, pPhyStaRpt->rxevm[RxCount - 1], 
-				pPhyStaRpt->cfo_tail[i], pPhyStaRpt->rxsnr[i], pPhyInfo);
-
-			/* search maximum pwdb */
-			if (rx_path_pwr_db > rx_pwr_db)
-				rx_pwr_db = rx_path_pwr_db;
-		}
-	}
-
-	/* mapping RX counter from 1~4 to 0~3 */
-	if (RxCount > 0)
-		pPhyInfo->RxCount = RxCount - 1;
-	
-	/* Check if MU packet or not */
-	if ((pPhyStaRpt->gid != 0) && (pPhyStaRpt->gid != 63)) {
-		bMU = TRUE;
-		pDM_Odm->PhyDbgInfo.NumQryMuPkt++;
-	} else
-		bMU = FALSE;
-
-	/* Count BF packet */
-	pDM_Odm->PhyDbgInfo.NumQryBfPkt = pDM_Odm->PhyDbgInfo.NumQryBfPkt + pPhyStaRpt->beamformed;
-
-	/* Check sub-channel */
-	if ((pPktinfo->DataRate > ODM_RATE11M) && (pPktinfo->DataRate < ODM_RATEMCS0))
-		rxsc = pPhyStaRpt->l_rxsc;
-	else
-		rxsc = pPhyStaRpt->ht_rxsc;
-
-	/* Check RX bandwidth */
-	if ((rxsc >= 1) && (rxsc <= 8))
-		bw = ODM_BW20M;
-	else if ((rxsc >= 9) && (rxsc <= 12))
-		bw = ODM_BW40M;
-	else if (rxsc >= 13)
-		bw = ODM_BW80M;
-	else
-		bw = pPhyStaRpt->rf_mode;
-
-	/* Update packet information */
-	phydm_SetCommonPhyInfo(rx_pwr_db, pPhyStaRpt->channel, (BOOLEAN)pPhyStaRpt->beamformed,
-		bMU, bw, odm_EVMdbToPercentage(pPhyStaRpt->rxevm[0]), rxsc, pPhyInfo);
-
-/*
-	//if (pPktinfo->bPacketMatchBSSID)
-	{
-		DbgPrint("channel = %d, band = %d, l_rxsc = %d, ht_rxsc = %d, rf_mode = %d\n", pPhyStaRpt->channel, pPhyStaRpt->band, pPhyStaRpt->l_rxsc, pPhyStaRpt->ht_rxsc, pPhyStaRpt->rf_mode);
-		DbgPrint("Antidx A = %d, B = %d, C = %d, D = %d\n", pPhyStaRpt->antidx_a, pPhyStaRpt->antidx_b, pPhyStaRpt->antidx_c, pPhyStaRpt->antidx_d);
-		DbgPrint("pwdb A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->pwdb[0], pPhyStaRpt->pwdb[1], pPhyStaRpt->pwdb[2], pPhyStaRpt->pwdb[3]);
-		DbgPrint("EVM  A: %d, B: %d, C: %d, D: %d\n", pPhyStaRpt->rxevm[0], pPhyStaRpt->rxevm[1], pPhyStaRpt->rxevm[2], pPhyStaRpt->rxevm[3]);
-		DbgPrint("SNR  A: %d, B: %d, C: %d, D: %d\n", pPhyStaRpt->rxsnr[0], pPhyStaRpt->rxsnr[1], pPhyStaRpt->rxsnr[2], pPhyStaRpt->rxsnr[3]);
-		DbgPrint("CFO  A: %d, B: %d, C: %d, D: %d\n", pPhyStaRpt->cfo_tail[0], pPhyStaRpt->cfo_tail[1], pPhyStaRpt->cfo_tail[2], pPhyStaRpt->cfo_tail[3]);
-		DbgPrint("paid = %d, gid = %d, length = %d\n", (pPhyStaRpt->paid + (pPhyStaRpt->paid_msb<<8)), pPhyStaRpt->gid, pPhyStaRpt->lsig_length);
-		DbgPrint("ldpc: %d, stbc: %d, bf: %d, gnt_bt: %d, antsw: %d\n", pPhyStaRpt->ldpc, pPhyStaRpt->stbc, pPhyStaRpt->beamformed, pPhyStaRpt->gnt_bt, pPhyStaRpt->hw_antsw_occu);
-		DbgPrint("NBI: %d, pos: %d\n", pPhyStaRpt->nb_intf_flag, (pPhyStaRpt->intf_pos + (pPhyStaRpt->intf_pos_msb<<8)));
-		DbgPrint("rsvd_0 = %d, rsvd_1 = %d, rsvd_2 = %d, rsvd_3 = %d, rsvd_4 = %d, rsvd_5 = %d\n", pPhyStaRpt->rsvd_0, pPhyStaRpt->rsvd_1, pPhyStaRpt->rsvd_2, pPhyStaRpt->rsvd_3, pPhyStaRpt->rsvd_4, pPhyStaRpt->rsvd_5);
-	}
-	DbgPrint("phydm_GetRxPhyStatusType1   pPktinfo->bPacketMatchBSSID = %d\n", pPktinfo->bPacketMatchBSSID);
-	DbgPrint("pPktinfo->DataRate = 0x%x\n", pPktinfo->DataRate);
-*/
-}
-
-VOID
-phydm_GetRxPhyStatusType2(
-	IN		PDM_ODM_T						pDM_Odm,
-	IN		pu1Byte							pPhyStatus,
-	IN		PODM_PACKET_INFO_T				pPktinfo,
-	OUT		PODM_PHY_INFO_T				pPhyInfo
-)
-{
-	PPHY_STATUS_RPT_JAGUAR2_TYPE2	pPhyStaRpt = (PPHY_STATUS_RPT_JAGUAR2_TYPE2)pPhyStatus;
-	s1Byte							rx_pwr_db = -120;
-	u1Byte							i, rxsc, bw, RxCount = 0;
-
-	/* Update OFDM packet counter */
-	pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM++;
-
-	/* Update per-path information */
-	for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-		if (pDM_Odm->RXAntStatus & BIT(i)) {
-			s1Byte	rx_path_pwr_db;
-
-			/* RX path counter */
-			RxCount++;
-
-			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO SQ) */
-			rx_path_pwr_db = pPhyStaRpt->pwdb[i] - 110;					/* per-path pwdb in dB domain */
-			phydm_SetPerPathPhyInfo(i, rx_path_pwr_db, 0, 0, 0, pPhyInfo);
-
-			/* search maximum pwdb */
-			if (rx_path_pwr_db > rx_pwr_db)
-				rx_pwr_db = rx_path_pwr_db;
-		}
-	}
-
-	/* mapping RX counter from 1~4 to 0~3 */
-	if (RxCount > 0)
-		pPhyInfo->RxCount = RxCount - 1;
-	
-	/* Check RX sub-channel */
-	if ((pPktinfo->DataRate > ODM_RATE11M) && (pPktinfo->DataRate < ODM_RATEMCS0))
-		rxsc = pPhyStaRpt->l_rxsc;
-	else
-		rxsc = pPhyStaRpt->ht_rxsc;
-
-	/* Check RX bandwidth */
-	/* the BW information of sc=0 is useless, because there is no information of RF mode*/
-	if ((rxsc >= 1) && (rxsc <= 8))
-		bw = ODM_BW20M;
-	else if ((rxsc >= 9) && (rxsc <= 12))
-		bw = ODM_BW40M;
-	else if (rxsc >= 13)
-		bw = ODM_BW80M;
-	else
-		bw = ODM_BW20M;
-
-	/* Update packet information */
-	phydm_SetCommonPhyInfo(rx_pwr_db, pPhyStaRpt->channel, (BOOLEAN)pPhyStaRpt->beamformed,
-		FALSE, bw, 0, rxsc, pPhyInfo);
-
-/*
-	//if (pPktinfo->bPacketMatchBSSID)
-	{
-		DbgPrint("channel = %d, band = %d, l_rxsc = %d, ht_rxsc = %d\n", pPhyStaRpt->channel, pPhyStaRpt->band, pPhyStaRpt->l_rxsc, pPhyStaRpt->ht_rxsc);
-		DbgPrint("pwdb A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->pwdb[0], pPhyStaRpt->pwdb[1], pPhyStaRpt->pwdb[2], pPhyStaRpt->pwdb[3]);
-		DbgPrint("Agc table A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->agc_table_a, pPhyStaRpt->agc_table_b, pPhyStaRpt->agc_table_c, pPhyStaRpt->agc_table_d);
-		DbgPrint("Gain A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->gain_a, pPhyStaRpt->gain_b, pPhyStaRpt->gain_c, pPhyStaRpt->gain_d);
-		DbgPrint("TRSW A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->trsw_a, pPhyStaRpt->trsw_b, pPhyStaRpt->trsw_c, pPhyStaRpt->trsw_d);
-		DbgPrint("AAGC step A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->aagc_step_a, pPhyStaRpt->aagc_step_b, pPhyStaRpt->aagc_step_c, pPhyStaRpt->aagc_step_d);
-		DbgPrint("HT AAGC gain A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->ht_aagc_gain[0], pPhyStaRpt->ht_aagc_gain[1], pPhyStaRpt->ht_aagc_gain[2], pPhyStaRpt->ht_aagc_gain[3]);
-		DbgPrint("DAGC gain A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", pPhyStaRpt->dagc_gain[0], pPhyStaRpt->dagc_gain[1], pPhyStaRpt->dagc_gain[2], pPhyStaRpt->dagc_gain[3]);
-		DbgPrint("ldpc: %d, stbc: %d, bf: %d, gnt_bt: %d, antsw: %d\n", pPhyStaRpt->ldpc, pPhyStaRpt->stbc, pPhyStaRpt->beamformed, pPhyStaRpt->gnt_bt, pPhyStaRpt->hw_antsw_occu);
-		DbgPrint("counter: %d, syn_count: %d\n", pPhyStaRpt->counter, pPhyStaRpt->syn_count);
-		DbgPrint("cnt_cca2agc_rdy: %d, cnt_pw2cca: %d, shift_l_map\n", pPhyStaRpt->cnt_cca2agc_rdy, pPhyStaRpt->cnt_pw2cca, pPhyStaRpt->shift_l_map);
-		DbgPrint("rsvd_0 = %d, rsvd_1 = %d, rsvd_2 = %d, rsvd_3 = %d, rsvd_4 = %d, rsvd_5 = %d\n", pPhyStaRpt->rsvd_0, pPhyStaRpt->rsvd_1, pPhyStaRpt->rsvd_2, pPhyStaRpt->rsvd_3, pPhyStaRpt->rsvd_4);
-		DbgPrint("rsvd_5 = %d, rsvd_6 = %d, rsvd_6 = %d\n", pPhyStaRpt->rsvd_5, pPhyStaRpt->rsvd_6, pPhyStaRpt->rsvd_7);
-	}
-*/
-}
-
-VOID
-phydm_GetRxPhyStatusType5(
-	IN		pu1Byte				pPhyStatus
-)
-{
-/*
-	DbgPrint("DW0: 0x%02x%02x%02x%02x\n", *(pPhyStatus + 3), *(pPhyStatus + 2), *(pPhyStatus + 1), *(pPhyStatus + 0));
-	DbgPrint("DW1: 0x%02x%02x%02x%02x\n", *(pPhyStatus + 7), *(pPhyStatus + 6), *(pPhyStatus + 5), *(pPhyStatus + 4));
-	DbgPrint("DW2: 0x%02x%02x%02x%02x\n", *(pPhyStatus + 11), *(pPhyStatus + 10), *(pPhyStatus + 9), *(pPhyStatus + 8));
-	DbgPrint("DW3: 0x%02x%02x%02x%02x\n", *(pPhyStatus + 15), *(pPhyStatus + 14), *(pPhyStatus + 13), *(pPhyStatus + 12));
-	DbgPrint("DW4: 0x%02x%02x%02x%02x\n", *(pPhyStatus + 19), *(pPhyStatus + 18), *(pPhyStatus + 17), *(pPhyStatus + 16));
-	DbgPrint("DW5: 0x%02x%02x%02x%02x\n", *(pPhyStatus + 23), *(pPhyStatus + 22), *(pPhyStatus + 21), *(pPhyStatus + 20));
-	DbgPrint("DW6: 0x%02x%02x%02x%02x\n", *(pPhyStatus + 27), *(pPhyStatus + 26), *(pPhyStatus + 25), *(pPhyStatus + 24));
-*/
-}
-
-VOID
-phydm_Process_RSSIForDM_Jaguar2(	
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	IN		PODM_PHY_INFO_T			pPhyInfo,
-	IN		PODM_PACKET_INFO_T			pPktinfo
-	)
-{
-	u4Byte				UndecoratedSmoothedPWDB, RSSI_Ave;
-	u1Byte				i;
-	PSTA_INFO_T			pEntry;
-
-	if (pPktinfo->StationID >= ODM_ASSOCIATE_ENTRY_NUM)
-		return;
-
-	pEntry = pDM_Odm->pODM_StaInfo[pPktinfo->StationID];							
-
-	if (!IS_STA_VALID(pEntry))
-		return;
-
-	if ((!pPktinfo->bPacketMatchBSSID))/*data frame only*/
-		return;
-
-	if (pPktinfo->bPacketBeacon)
-		pDM_Odm->PhyDbgInfo.NumQryBeaconPkt++;
-	
-	if (pPktinfo->bPacketToSelf || pPktinfo->bPacketBeacon) {
-		u4Byte RSSI_linear = 0;
-
-		UndecoratedSmoothedPWDB = (u4Byte)pEntry->rssi_stat.UndecoratedSmoothedPWDB;
-		pDM_Odm->RSSI_A = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_A];
-		pDM_Odm->RSSI_B = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_B];
-		pDM_Odm->RSSI_C = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_C];
-		pDM_Odm->RSSI_D = pPhyInfo->RxMIMOSignalStrength[ODM_RF_PATH_D];
-
-		for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-			if (pPhyInfo->RxMIMOSignalStrength[i] != 0)
-				RSSI_linear += odm_ConvertTo_linear(pPhyInfo->RxMIMOSignalStrength[i]);
-		}
-
-		switch (pPhyInfo->RxCount + 1) {
-		case 2:
-			RSSI_linear = (RSSI_linear >> 1);
-			break;
-		case 3:
-			RSSI_linear = ((RSSI_linear) + (RSSI_linear << 1) + (RSSI_linear << 3)) >> 5;	/* RSSI_linear/3 ~ RSSI_linear*11/32 */
-			break;
-		case 4:
-			RSSI_linear = (RSSI_linear >> 2);
-			break;
-		}
-		RSSI_Ave = odm_ConvertTo_dB(RSSI_linear);
-
-		if (UndecoratedSmoothedPWDB <= 0)
-			UndecoratedSmoothedPWDB = pPhyInfo->RxPWDBAll;
-		else
-			UndecoratedSmoothedPWDB = (RSSI_Ave + ((UndecoratedSmoothedPWDB<<4) - UndecoratedSmoothedPWDB))>>4;
-
-		#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-		if (pEntry->rssi_stat.UndecoratedSmoothedPWDB == -1)
-			phydm_ra_rssi_rpt_wk(pDM_Odm);
-		#endif
-
-		pEntry->rssi_stat.UndecoratedSmoothedPWDB = (s4Byte)UndecoratedSmoothedPWDB;
-	}
-}
-
-VOID
-phydm_RxPhyStatusJaguarSeries2(
-	IN		PDM_ODM_T					pPhydm,
-	IN		pu1Byte						pPhyStatus,
-	IN		PODM_PACKET_INFO_T			pPktinfo,
-	OUT		PODM_PHY_INFO_T			pPhyInfo
-)
-{
-	u1Byte		phy_status_type = (*pPhyStatus & 0xf);
-
-	/*DbgPrint("phydm_RxPhyStatusJaguarSeries2================> (page: %d)\n", phy_status_type);*/
-	
-	/* Memory reset */
-	phydm_ResetPhyInfo(pPhydm, pPhyInfo);
-
-	/* Phy status parsing */
-	switch (phy_status_type) {
-	case 0:
-	{
-		phydm_GetRxPhyStatusType0(pPhydm, pPhyStatus, pPktinfo, pPhyInfo);
-		break;
-	}
-	case 1:
-	{
-		phydm_GetRxPhyStatusType1(pPhydm, pPhyStatus, pPktinfo, pPhyInfo);
-		break;
-	}
-	case 2:
-	{
-		phydm_GetRxPhyStatusType2(pPhydm, pPhyStatus, pPktinfo, pPhyInfo);
-		break;
-	}
-	case 5:
-	{
-		phydm_GetRxPhyStatusType5(pPhyStatus);
-		return;
-	}
-	default:
-		return;
-	}
-
-	/* Update signal strength to UI, and pPhyInfo->RxPWDBAll is the maximum RSSI of all path */
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	pPhyInfo->SignalStrength = SignalScaleProc(pPhydm->Adapter, pPhyInfo->RxPWDBAll, FALSE, FALSE);
-#else
-	pPhyInfo->SignalStrength = (u1Byte)(odm_SignalScaleMapping(pPhydm, pPhyInfo->RxPWDBAll));
-#endif
-
-	/* Calculate average RSSI and smoothed RSSI */
-	phydm_Process_RSSIForDM_Jaguar2(pPhydm, pPhyInfo, pPktinfo);
-
-}
-/*==============================================*/
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#define READ_AND_CONFIG_MP(ic, txt) (odm_read_and_config_mp_##ic##txt(dm))
+#define READ_AND_CONFIG_TC(ic, txt) (odm_read_and_config_tc_##ic##txt(dm))
+
+
+#if (PHYDM_TESTCHIP_SUPPORT == 1)
+#define READ_AND_CONFIG(ic, txt) do {\
+		if (dm->is_mp_chip)\
+			READ_AND_CONFIG_MP(ic, txt);\
+		else\
+			READ_AND_CONFIG_TC(ic, txt);\
+	} while (0)
+#else
+#define READ_AND_CONFIG     READ_AND_CONFIG_MP
+#endif
+
+#define GET_VERSION_MP(ic, txt)		(odm_get_version_mp_##ic##txt())
+#define GET_VERSION_TC(ic, txt)		(odm_get_version_tc_##ic##txt())
+
+#if (PHYDM_TESTCHIP_SUPPORT == 1)
+	#define GET_VERSION(ic, txt) (dm->is_mp_chip ? GET_VERSION_MP(ic, txt) : GET_VERSION_TC(ic, txt))
+#else
+	#define GET_VERSION(ic, txt) GET_VERSION_MP(ic, txt)
+#endif
+
+enum hal_status
+odm_config_rf_with_header_file(
+	struct dm_struct		*dm,
+	enum odm_rf_config_type		config_type,
+	u8			e_rf_path
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PMGNT_INFO		mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+#endif
+	enum hal_status	result = HAL_STATUS_SUCCESS;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"===>odm_config_rf_with_header_file (%s)\n", (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		dm->support_platform, dm->support_interface, dm->board_type);
+
+	/* 1 AP doesn't use PHYDM power tracking table in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8812a, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8812a, _radiob);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+			HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+			if ((hal_data->EEPROMSVID == 0x17AA && hal_data->EEPROMSMID == 0xA811) ||
+			    (hal_data->EEPROMSVID == 0x10EC && hal_data->EEPROMSMID == 0xA812) ||
+			    (hal_data->EEPROMSVID == 0x10EC && hal_data->EEPROMSMID == 0x8812))
+				READ_AND_CONFIG_MP(8812a, _txpwr_lmt_hm812a03);
+			else
+#endif
+				READ_AND_CONFIG_MP(8812a, _txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8821a, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			if (dm->support_interface == ODM_ITRF_USB) {
+				if (dm->ext_pa_5g || dm->ext_lna_5g)
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8811a_u_fem);
+				else
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8811a_u_ipa);
+			} else {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+				if (mgnt_info->CustomerID == RT_CID_8821AE_ASUS_MB)
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a_sar_8mm);
+				else if (mgnt_info->CustomerID == RT_CID_ASUS_NB)
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a_sar_5mm);
+				else
+#endif
+					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a);
+			}
+		}
+	}
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8192e, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8192e, _radiob);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)	/*Refine by Vincent Lan for 5mm SAR pwr limit*/
+			HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+			if ((hal_data->EEPROMSVID == 0x11AD && hal_data->EEPROMSMID == 0x8192) ||
+			    (hal_data->EEPROMSVID == 0x11AD && hal_data->EEPROMSMID == 0x8193))
+				READ_AND_CONFIG_MP(8192e, _txpwr_lmt_8192e_sar_5mm);
+			else
+#endif
+				READ_AND_CONFIG_MP(8192e, _txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8723d, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8723d, _txpwr_lmt);
+	}
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8710b, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8710b, _txpwr_lmt);
+	}
+#endif
+
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+	/* 1 All platforms support */
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8188e, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8188e, _txpwr_lmt);
+	}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (config_type == CONFIG_RF_RADIO)
+			READ_AND_CONFIG_MP(8723b, _radioa);
+		else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8723b, _txpwr_lmt);
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8814a, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8814a, _radiob);
+			else if (e_rf_path == RF_PATH_C)
+				READ_AND_CONFIG_MP(8814a, _radioc);
+			else if (e_rf_path == RF_PATH_D)
+				READ_AND_CONFIG_MP(8814a, _radiod);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type0);
+			else if (dm->rfe_type == 1)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type1);				
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type2);		
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type3);		
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type5);		
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type8);
+			else
+				READ_AND_CONFIG_MP(8814a,_txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8703b, _radioa);
+		}
+	}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8188f, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8188f, _txpwr_lmt);
+	}
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8822b, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8822b, _radiob);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type5);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type3);
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type4);
+			else if (dm->rfe_type == 12)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type12);
+			else if (dm->rfe_type == 15)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type15);
+			else if (dm->rfe_type == 16)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type16);
+			else if (dm->rfe_type == 17)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type17);
+			else
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt);
+
+		}
+	}
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8197f, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8197f, _radiob);
+		}
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG(8821c, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG(8821c, _txpwr_lmt);
+	}
+#endif
+
+	if (config_type == CONFIG_RF_RADIO) {
+		if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+			result = phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_END,
+							0,
+							0,
+							0,
+							(enum rf_path)0,
+							0);
+			PHYDM_DBG(dm, ODM_COMP_INIT,
+				"rf param offload end!result = %d", result);
+		}
+	}
+
+	return result;
+}
+
+enum hal_status
+odm_config_rf_with_tx_pwr_track_header_file(
+	struct dm_struct		*dm
+)
+{
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"===>odm_config_rf_with_tx_pwr_track_header_file (%s)\n", (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		dm->support_platform, dm->support_interface, dm->board_type);
+
+
+	/* 1 AP doesn't use PHYDM power tracking table in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if RTL8821A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8821a, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8821a, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8821a, _txpowertrack_sdio);
+	}
+#endif
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8812) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8812a, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB) {
+			if (dm->rfe_type == 3 && dm->is_mp_chip)
+				READ_AND_CONFIG_MP(8812a, _txpowertrack_rfe3);
+			else
+				READ_AND_CONFIG_MP(8812a, _txpowertrack_usb);
+		}
+
+	}
+#endif
+#if RTL8192E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8192e, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8192e, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8192e, _txpowertrack_sdio);
+	}
+#endif
+#if RTL8723D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8723d, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8723d, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8723d, _txpowertrack_sdio);
+
+		READ_AND_CONFIG_MP(8723d, _txxtaltrack);
+	}
+#endif
+/* JJ ADD 20161014 */
+#if RTL8710B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		if (dm->package_type == 1)
+			READ_AND_CONFIG_MP(8710b, _txpowertrack_qfn48m_smic);
+		else if (dm->package_type == 5)
+			READ_AND_CONFIG_MP(8710b, _txpowertrack_qfn48m_umc);
+		
+		READ_AND_CONFIG_MP(8710b, _txxtaltrack);
+	}
+#endif
+
+#if RTL8188E_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (odm_get_mac_reg(dm, 0xF0, 0xF000) >= 8) {		/*if 0xF0[15:12] >= 8, SMIC*/
+			if (dm->support_interface == ODM_ITRF_PCIE)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_pcie_icut);
+			else if (dm->support_interface == ODM_ITRF_USB)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_usb_icut);
+			else if (dm->support_interface == ODM_ITRF_SDIO)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_sdio_icut);
+		} else {	/*else 0xF0[15:12] < 8, TSMC*/
+			if (dm->support_interface == ODM_ITRF_PCIE)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_pcie);
+			else if (dm->support_interface == ODM_ITRF_USB)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_usb);
+			else if (dm->support_interface == ODM_ITRF_SDIO)
+				READ_AND_CONFIG_MP(8188e, _txpowertrack_sdio);
+		}
+
+	}
+#endif
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+	/* 1 All platforms support */
+#if RTL8723B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
+			READ_AND_CONFIG_MP(8723b, _txpowertrack_pcie);
+		else if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8723b, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8723b, _txpowertrack_sdio);
+	}
+#endif
+#if RTL8814A_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8814A) {
+		if (dm->rfe_type == 0)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type0);
+		else if (dm->rfe_type == 2)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type2);
+		else if (dm->rfe_type == 5)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type5);
+		else if (dm->rfe_type == 7)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type7);
+		else if (dm->rfe_type == 8)
+			READ_AND_CONFIG_MP(8814a, _txpowertrack_type8);
+		else
+			READ_AND_CONFIG_MP(8814a, _txpowertrack);
+
+		READ_AND_CONFIG_MP(8814a, _txpowertssi);
+	}
+#endif
+#if RTL8703B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8703B) {
+		if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8703b, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8703b, _txpowertrack_sdio);
+
+		READ_AND_CONFIG_MP(8703b, _txxtaltrack);
+	}
+#endif
+
+#if RTL8188F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB)
+			READ_AND_CONFIG_MP(8188f, _txpowertrack_usb);
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			READ_AND_CONFIG_MP(8188f, _txpowertrack_sdio);
+	}
+#endif
+
+#if RTL8822B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (dm->rfe_type == 0)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type0);
+		else if (dm->rfe_type == 1)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type1);
+		else if (dm->rfe_type == 2)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type2);
+		else if ((dm->rfe_type == 3) || (dm->rfe_type == 5))
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type3_type5);
+		else if (dm->rfe_type == 4)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type4);
+		else if (dm->rfe_type == 6)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type6);
+		else if (dm->rfe_type == 7)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type7);
+		else if (dm->rfe_type == 8)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type8);
+		else if (dm->rfe_type == 9)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type9);
+		else if (dm->rfe_type == 10)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type10);
+		else if (dm->rfe_type == 11)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type11);
+		else if (dm->rfe_type == 12)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type12);
+		else if (dm->rfe_type == 13)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type13);
+		else if (dm->rfe_type == 14)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type14);
+		else if (dm->rfe_type == 15)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type15);
+		else if (dm->rfe_type == 16)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type16);
+		else if (dm->rfe_type == 17)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type17);
+		else
+			READ_AND_CONFIG_MP(8822b, _txpowertrack);
+	}
+#endif
+
+#if RTL8197F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (dm->rfe_type == 0)
+			READ_AND_CONFIG_MP(8197f, _txpowertrack_type0);
+		else if (dm->rfe_type == 1)
+			READ_AND_CONFIG_MP(8197f, _txpowertrack_type1);
+		else
+			READ_AND_CONFIG_MP(8197f, _txpowertrack);
+	}
+#endif
+
+#if RTL8821C_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (dm->rfe_type == 0x5)
+			READ_AND_CONFIG(8821c, _txpowertrack_type0x28);
+		else if (dm->rfe_type == 0x4)
+			READ_AND_CONFIG(8821c, _txpowertrack_type0x20);
+		else
+			READ_AND_CONFIG(8821c, _txpowertrack);
+	}
+#endif
+
+	return HAL_STATUS_SUCCESS;
+}
+
+enum hal_status
+odm_config_bb_with_header_file(
+	struct dm_struct		*dm,
+	enum odm_bb_config_type		config_type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PMGNT_INFO		mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+#endif
+	enum hal_status	result = HAL_STATUS_SUCCESS;
+
+	/* 1 AP doesn't use PHYDM initialization in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8812a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8812a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 3 && dm->is_mp_chip)
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_asus);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			else if (mgnt_info->CustomerID == RT_CID_WNC_NEC && dm->is_mp_chip)
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_nec);
+#if RT_PLATFORM == PLATFORM_MACOSX
+			/*{1827}{1024} for BUFFALO power by rate table. Isaiah 2013-11-29*/
+			else if (mgnt_info->CustomerID == RT_CID_DNI_BUFFALO)
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_dni);
+			/* TP-Link T4UH, Isaiah 2015-03-16*/
+			else if (mgnt_info->CustomerID == RT_CID_TPLINK_HPWR) {
+				pr_debug("RT_CID_TPLINK_HPWR:: _PHY_REG_PG_TPLINK\n");
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_tplink);
+			}
+#endif
+#endif
+			else
+				READ_AND_CONFIG_MP(8812a, _phy_reg_pg);
+		} else if (config_type == CONFIG_BB_PHY_REG_MP)
+			READ_AND_CONFIG_MP(8812a, _phy_reg_mp);
+		else if (config_type == CONFIG_BB_AGC_TAB_DIFF) {
+			dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
+			/*AGC_TAB DIFF dont support FW offload*/
+			if ((*dm->channel >= 36)  && (*dm->channel  <= 64))
+				AGC_DIFF_CONFIG_MP(8812a, lb);
+			else if (*dm->channel >= 100)
+				AGC_DIFF_CONFIG_MP(8812a, hb);
+		}
+	}
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8821a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8821a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+			HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+			if ((hal_data->EEPROMSVID == 0x1043 && hal_data->EEPROMSMID == 0x207F))
+				READ_AND_CONFIG_MP(8821a, _phy_reg_pg_e202_sa);
+			else
+#endif
+#if (RT_PLATFORM == PLATFORM_MACOSX)
+				/*{1827}{1022} for BUFFALO power by rate table. Isaiah 2013-10-18*/
+				if (mgnt_info->CustomerID == RT_CID_DNI_BUFFALO) {
+					/*{1024} for BUFFALO power by rate table. (JP/US)*/
+					if (mgnt_info->ChannelPlan == RT_CHANNEL_DOMAIN_US_2G_CANADA_5G)
+						READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_us);
+					else
+						READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_jp);
+				} else
+#endif
+#endif
+					READ_AND_CONFIG_MP(8821a, _phy_reg_pg);
+		}
+	}
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8192e, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8192e, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8192e, _phy_reg_pg);
+	}
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8723d, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8723d, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8723d, _phy_reg_pg);
+	}
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8710b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8710b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8710b, _phy_reg_pg);
+	}
+#endif
+
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+
+	/* 1 All platforms support */
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8188e, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8188e, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8188e, _phy_reg_pg);
+	}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8723b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8723b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8723b, _phy_reg_pg);
+	}
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8814a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8814a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type0);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type2);				
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type3);		
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type4);		
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type5);		
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type8);
+			else
+				READ_AND_CONFIG_MP(8814a,_phy_reg_pg);
+		}
+		else if (config_type == CONFIG_BB_PHY_REG_MP)
+			READ_AND_CONFIG_MP(8814a, _phy_reg_mp);
+	}
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8703b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8703b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8703b, _phy_reg_pg);
+	}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8188f, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8188f, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8188f, _phy_reg_pg);
+	}
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8822b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8822b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type3);
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type4);
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type5);
+			else if (dm->rfe_type == 12)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type12);
+			else if (dm->rfe_type == 15)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type15);
+			else if (dm->rfe_type == 16)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type16);
+			else if (dm->rfe_type == 17)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type17);
+			else
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg);
+		}
+	}
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (config_type == CONFIG_BB_PHY_REG) {
+			READ_AND_CONFIG_MP(8197f, _phy_reg);
+			if (dm->cut_version == ODM_CUT_A)
+				phydm_phypara_a_cut(dm);
+		} else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8197f, _agc_tab);
+	}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG(8821c, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB) {
+			READ_AND_CONFIG(8821c, _agc_tab);
+			/* According to RFEtype, choosing correct AGC table*/
+			if (dm->default_rf_set_8821c == SWITCH_TO_BTG)
+				AGC_DIFF_CONFIG_MP(8821c, btg);
+		} else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 0x5)
+				READ_AND_CONFIG(8821c, _phy_reg_pg_type0x28);
+			else
+				READ_AND_CONFIG(8821c, _phy_reg_pg);
+		} else if (config_type == CONFIG_BB_AGC_TAB_DIFF) {
+			dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
+			/*AGC_TAB DIFF dont support FW offload*/
+			if (dm->current_rf_set_8821c == SWITCH_TO_BTG)
+				AGC_DIFF_CONFIG_MP(8821c, btg);
+			else if (dm->current_rf_set_8821c == SWITCH_TO_WLG)
+				AGC_DIFF_CONFIG_MP(8821c, wlg);
+		} else if (config_type == CONFIG_BB_PHY_REG_MP)
+			READ_AND_CONFIG(8821c, _phy_reg_mp);
+	}
+#endif
+
+#if (RTL8195A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195A) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG(8195a, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG(8195a, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG(8195a, _phy_reg_pg);
+	}
+#endif
+
+	if (config_type == CONFIG_BB_PHY_REG || config_type == CONFIG_BB_AGC_TAB)
+		if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+			result = phydm_set_reg_by_fw(dm,
+								PHYDM_HALMAC_CMD_END,
+								0,
+								0,
+								0,
+								(enum rf_path)0,
+								0);
+			PHYDM_DBG(dm, ODM_COMP_INIT,
+				"phy param offload end!result = %d", result);
+		}
+
+	return result;
+}
+
+enum hal_status
+odm_config_mac_with_header_file(
+	struct dm_struct	*dm
+)
+{
+	enum hal_status	result = HAL_STATUS_SUCCESS;
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"===>odm_config_mac_with_header_file (%s)\n", (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		"support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		dm->support_platform, dm->support_interface, dm->board_type);
+
+	/* 1 AP doesn't use PHYDM initialization in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812)
+		READ_AND_CONFIG_MP(8812a, _mac_reg);
+#endif
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821)
+		READ_AND_CONFIG_MP(8821a, _mac_reg);
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E)
+		READ_AND_CONFIG_MP(8192e, _mac_reg);
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D)
+		READ_AND_CONFIG_MP(8723d, _mac_reg);
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B)
+		READ_AND_CONFIG_MP(8710b, _mac_reg);
+#endif
+
+#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+
+	/* 1 All platforms support */
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		READ_AND_CONFIG_MP(8188e, _mac_reg);
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B)
+		READ_AND_CONFIG_MP(8723b, _mac_reg);
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A)
+		READ_AND_CONFIG_MP(8814a, _mac_reg);
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B)
+		READ_AND_CONFIG_MP(8703b, _mac_reg);
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F)
+		READ_AND_CONFIG_MP(8188f, _mac_reg);
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B)
+		READ_AND_CONFIG_MP(8822b, _mac_reg);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F)
+		READ_AND_CONFIG_MP(8197f, _mac_reg);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		READ_AND_CONFIG(8821c, _mac_reg);
+#endif
+
+#if (RTL8195A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195A)
+		READ_AND_CONFIG_MP(8195a, _mac_reg);
+#endif
+
+	if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+		result = phydm_set_reg_by_fw(dm,
+							PHYDM_HALMAC_CMD_END,
+							0,
+							0,
+							0,
+							(enum rf_path)0,
+							0);
+		PHYDM_DBG(dm, ODM_COMP_INIT,
+			"mac param offload end!result = %d", result);
+	}
+
+	return result;
+}
+
+u32
+odm_get_hw_img_version(
+	struct dm_struct	*dm
+)
+{
+	u32  version = 0;
+
+	/* 1 AP doesn't use PHYDM initialization in these ICs */
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821)
+		version = GET_VERSION_MP(8821a, _mac_reg);
+#endif
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192E)
+		version = GET_VERSION_MP(8192e, _mac_reg);
+#endif
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812)
+		version = GET_VERSION_MP(8812a, _mac_reg);
+#endif
+#if (RTL8723D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723D)
+		version = GET_VERSION_MP(8723d, _mac_reg);
+#endif
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8710B)
+		version = GET_VERSION_MP(8710b, _mac_reg);
+#endif
+
+#endif /* (DM_ODM_SUPPORT_TYPE != ODM_AP) */
+
+	/*1 All platforms support*/
+#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		version = GET_VERSION_MP(8188e, _mac_reg);
+#endif
+#if (RTL8723B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8723B)
+		version = GET_VERSION_MP(8723b, _mac_reg);
+#endif
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A)
+		version = GET_VERSION_MP(8814a, _mac_reg);
+#endif
+#if (RTL8703B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8703B)
+		version = GET_VERSION_MP(8703b, _mac_reg);
+#endif
+#if (RTL8188F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188F)
+		version = GET_VERSION_MP(8188f, _mac_reg);
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B)
+		version = GET_VERSION_MP(8822b, _mac_reg);
+#endif
+
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F)
+		version = GET_VERSION_MP(8197f, _mac_reg);
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		version = GET_VERSION(8821c, _mac_reg);
+#endif
+
+	return version;
+}
+
+
+u32
+query_phydm_trx_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_trx_capability_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_stbc_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_stbc_capability_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_ldpc_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_ldpc_capability_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_txbf_parameters(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_txbf_parameters_8821c(dm);
+#endif
+
+	return value32;
+}
+
+u32
+query_phydm_txbf_capability(
+	struct dm_struct					*dm
+)
+{
+	u32 value32 = 0xFFFFFFFF;
+
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_txbf_capability_8821c(dm);
+#endif
+
+	return value32;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.h
index e56f1c200176..1d1143ed4480 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_hwconfig.h
@@ -1,506 +1,104 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-
-#ifndef	__HALHWOUTSRC_H__
-#define __HALHWOUTSRC_H__
-
-
-/*--------------------------Define -------------------------------------------*/ 
-
-#define AGC_DIFF_CONFIG_MP(ic, band) (ODM_ReadAndConfig_MP_##ic##_AGC_TAB_DIFF(pDM_Odm, Array_MP_##ic##_AGC_TAB_DIFF_##band, \
-                                                                              sizeof(Array_MP_##ic##_AGC_TAB_DIFF_##band)/sizeof(u4Byte)))
-#define AGC_DIFF_CONFIG_TC(ic, band) (ODM_ReadAndConfig_TC_##ic##_AGC_TAB_DIFF(pDM_Odm, Array_TC_##ic##_AGC_TAB_DIFF_##band, \
-                                                                              sizeof(Array_TC_##ic##_AGC_TAB_DIFF_##band)/sizeof(u4Byte)))
-
-#define AGC_DIFF_CONFIG(ic, band) do {\
-                                            if (pDM_Odm->bIsMPChip)\
-                                    		    AGC_DIFF_CONFIG_MP(ic,band);\
-                                            else\
-                                                AGC_DIFF_CONFIG_TC(ic,band);\
-                                    } while(0)
-
-
-//============================================================
-// structure and define
-//============================================================
-
-__PACK typedef struct _Phy_Rx_AGC_Info
-{
-	#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)	
-		u1Byte	gain:7,trsw:1;			
-	#else			
-		u1Byte	trsw:1,gain:7;
-	#endif
-} __WLAN_ATTRIB_PACK__ PHY_RX_AGC_INFO_T, *pPHY_RX_AGC_INFO_T;
-
-__PACK typedef struct _Phy_Status_Rpt_8192cd {
-	PHY_RX_AGC_INFO_T path_agc[2];
-	u1Byte	ch_corr[2];
-	u1Byte	cck_sig_qual_ofdm_pwdb_all;
-	u1Byte	cck_agc_rpt_ofdm_cfosho_a;
-	u1Byte	cck_rpt_b_ofdm_cfosho_b;
-	u1Byte	rsvd_1;/*ch_corr_msb;*/
-	u1Byte	noise_power_db_msb;
-	s1Byte	path_cfotail[2];
-	u1Byte	pcts_mask[2];
-	s1Byte	stream_rxevm[2];
-	u1Byte	path_rxsnr[2];
-	u1Byte	noise_power_db_lsb;
-	u1Byte	rsvd_2[3];
-	u1Byte	stream_csi[2];
-	u1Byte	stream_target_csi[2];
-	s1Byte	sig_evm;
-	u1Byte	rsvd_3;
-
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte	antsel_rx_keep_2: 1;	/*ex_intf_flg:1;*/
-	u1Byte	sgi_en: 1;
-	u1Byte	rxsc: 2;
-	u1Byte	idle_long: 1;
-	u1Byte	r_ant_train_en: 1;
-	u1Byte	ant_sel_b: 1;
-	u1Byte	ant_sel: 1;
-#else	/*_BIG_ENDIAN_	*/
-	u1Byte	ant_sel: 1;
-	u1Byte	ant_sel_b: 1;
-	u1Byte	r_ant_train_en: 1;
-	u1Byte	idle_long: 1;
-	u1Byte	rxsc: 2;
-	u1Byte	sgi_en: 1;
-	u1Byte	antsel_rx_keep_2: 1;/*ex_intf_flg:1;*/
-#endif
-} __WLAN_ATTRIB_PACK__ PHY_STATUS_RPT_8192CD_T, *PPHY_STATUS_RPT_8192CD_T;
-
-
-typedef struct _Phy_Status_Rpt_8812 {
-/*	DWORD 0*/
-	u1Byte			gain_trsw[2];							/*path-A and path-B {TRSW, gain[6:0] }*/
-	u1Byte			chl_num_LSB;							/*channel number[7:0]*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte			chl_num_MSB: 2;							/*channel number[9:8]*/
-	u1Byte			sub_chnl: 4;								/*sub-channel location[3:0]*/
-	u1Byte			r_RFMOD: 2;								/*RF mode[1:0]*/
-#else	/*_BIG_ENDIAN_	*/
-	u1Byte			r_RFMOD: 2;
-	u1Byte			sub_chnl: 4;
-	u1Byte			chl_num_MSB: 2;
-#endif
-
-/*	DWORD 1*/
-	u1Byte			pwdb_all;								/*CCK signal quality / OFDM pwdb all*/
-	s1Byte			cfosho[2];		/*DW1 byte 1 DW1 byte2	CCK AGC report and CCK_BB_Power / OFDM Path-A and Path-B short CFO*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	/*this should be checked again because the definition of 8812 and 8814 is different*/
-/*	u1Byte			r_cck_rx_enable_pathc:2;					cck rx enable pathc[1:0]*/
-/*	u1Byte			cck_rx_path:4;							cck rx path[3:0]*/
-	u1Byte			resvd_0: 6;
-	u1Byte			bt_RF_ch_MSB: 2;						/*8812A:2'b0			8814A: bt rf channel keep[7:6]*/
-#else	/*_BIG_ENDIAN_*/
-	u1Byte			bt_RF_ch_MSB: 2;
-	u1Byte			resvd_0: 6;
-#endif
-
-/*	DWORD 2*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte			ant_div_sw_a: 1;							/*8812A: ant_div_sw_a    8814A: 1'b0*/
-	u1Byte			ant_div_sw_b: 1;							/*8812A: ant_div_sw_b    8814A: 1'b0*/
-	u1Byte			bt_RF_ch_LSB: 6;						/*8812A: 6'b0                   8814A: bt rf channel keep[5:0]*/
-#else	/*_BIG_ENDIAN_	*/
-	u1Byte			bt_RF_ch_LSB: 6;
-	u1Byte			ant_div_sw_b: 1;
-	u1Byte			ant_div_sw_a: 1;
-#endif
-	s1Byte			cfotail[2];		   /*DW2 byte 1 DW2 byte 2	path-A and path-B CFO tail*/
-	u1Byte			PCTS_MSK_RPT_0;						/*PCTS mask report[7:0]*/
-	u1Byte			PCTS_MSK_RPT_1;						/*PCTS mask report[15:8]*/
-
-/*	DWORD 3*/
-	s1Byte			rxevm[2];	         /*DW3 byte 1 DW3 byte 2	stream 1 and stream 2 RX EVM*/
-	s1Byte			rxsnr[2];	         /*DW3 byte 3 DW4 byte 0	path-A and path-B RX SNR*/
-
-/*	DWORD 4*/
-	u1Byte			PCTS_MSK_RPT_2;						/*PCTS mask report[23:16]*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte			PCTS_MSK_RPT_3: 6;						/*PCTS mask report[29:24]*/
-	u1Byte			pcts_rpt_valid: 1;							/*pcts_rpt_valid*/
-	u1Byte			resvd_1: 1;								/*1'b0*/
-#else	/*_BIG_ENDIAN_*/
-	u1Byte			resvd_1: 1;
-	u1Byte			pcts_rpt_valid: 1;
-	u1Byte			PCTS_MSK_RPT_3: 6;
-#endif
-	s1Byte			rxevm_cd[2];	   /*DW 4 byte 3 DW5 byte 0  8812A: 16'b0	8814A: stream 3 and stream 4 RX EVM*/
-
-/*	DWORD 5*/
-	u1Byte			csi_current[2];	   /*DW5 byte 1 DW5 byte 2	8812A: stream 1 and 2 CSI	8814A:  path-C and path-D RX SNR*/
-	u1Byte			gain_trsw_cd[2];	   /*DW5 byte 3 DW6 byte 0	path-C and path-D {TRSW, gain[6:0] }*/
-
-/*	DWORD 6*/
-	s1Byte			sigevm;									/*signal field EVM*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte			antidx_antc: 3;							/*8812A: 3'b0		8814A: antidx_antc[2:0]*/
-	u1Byte			antidx_antd: 3;							/*8812A: 3'b0		8814A: antidx_antd[2:0]*/
-	u1Byte			dpdt_ctrl_keep: 1;						/*8812A: 1'b0		8814A: dpdt_ctrl_keep*/
-	u1Byte			GNT_BT_keep: 1;							/*8812A: 1'b0		8814A: GNT_BT_keep*/
-#else	/*_BIG_ENDIAN_*/
-	u1Byte			GNT_BT_keep: 1;
-	u1Byte			dpdt_ctrl_keep: 1;
-	u1Byte			antidx_antd: 3;
-	u1Byte			antidx_antc: 3;
-#endif
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte			antidx_anta: 3;							/*antidx_anta[2:0]*/
-	u1Byte			antidx_antb: 3;							/*antidx_antb[2:0]*/
-	u1Byte			hw_antsw_occur: 2;								/*1'b0*/
-#else	/*_BIG_ENDIAN_*/
-	u1Byte			hw_antsw_occur: 2;
-	u1Byte			antidx_antb: 3;
-	u1Byte			antidx_anta: 3;
-#endif
-} PHY_STATUS_RPT_8812_T, *PPHY_STATUS_RPT_8812_T;
-
-VOID
-odm_Init_RSSIForDM(
-	IN OUT	PDM_ODM_T	pDM_Odm
-	);
-
-VOID
-ODM_PhyStatusQuery(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	OUT		PODM_PHY_INFO_T			pPhyInfo,
-	IN 		pu1Byte						pPhyStatus,	
-	IN		PODM_PACKET_INFO_T			pPktinfo
-	);
-
-VOID
-ODM_MacStatusQuery(
-	IN OUT	PDM_ODM_T					pDM_Odm,
-	IN 		pu1Byte						pMacStatus,
-	IN		u1Byte						MacID,	
-	IN		BOOLEAN						bPacketMatchBSSID,
-	IN		BOOLEAN						bPacketToSelf,
-	IN		BOOLEAN						bPacketBeacon
-	);
-
-HAL_STATUS
-ODM_ConfigRFWithTxPwrTrackHeaderFile(
-	IN 	PDM_ODM_T	        	pDM_Odm
-    );
-    
-HAL_STATUS
-ODM_ConfigRFWithHeaderFile(
-	IN 	PDM_ODM_T	        	pDM_Odm,
-	IN 	ODM_RF_Config_Type 		ConfigType,
-	IN 	ODM_RF_RADIO_PATH_E 	eRFPath
-	);
-
-HAL_STATUS
-ODM_ConfigBBWithHeaderFile(
-	IN  	PDM_ODM_T	                pDM_Odm,
-	IN	ODM_BB_Config_Type		ConfigType
-    );
-
-HAL_STATUS
-ODM_ConfigMACWithHeaderFile(
-	IN  	PDM_ODM_T	pDM_Odm
-    );
-
-HAL_STATUS
-ODM_ConfigFWWithHeaderFile(
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN 	ODM_FW_Config_Type 	ConfigType,
-	OUT u1Byte				*pFirmware,
-	OUT u4Byte				*pSize
-	);
-
-u4Byte 
-ODM_GetHWImgVersion(
-	IN	PDM_ODM_T	pDM_Odm
-	);
-
-s4Byte
-odm_SignalScaleMapping(	
-	IN OUT PDM_ODM_T pDM_Odm,
-	IN	s4Byte CurrSig 
-	);
-
-#if (RTL8822B_SUPPORT == 1)
-/*For 8822B only!! need to move to FW finally */
-/*==============================================*/
-VOID
-phydm_RxPhyStatusJaguarSeries2(
-	IN		PDM_ODM_T					pPhydm,
-	IN		pu1Byte						pPhyStatus,
-	IN		PODM_PACKET_INFO_T			pPktinfo,
-	OUT		PODM_PHY_INFO_T			pPhyInfo
-);
-
-typedef struct _Phy_Status_Rpt_Jaguar2_Type0 {
-	/* DW0 */
-	u1Byte		page_num;
-	u1Byte		pwdb;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		gain: 6;
-	u1Byte		rsvd_0: 1;
-	u1Byte		trsw: 1;
-#else
-	u1Byte		trsw: 1;
-	u1Byte		rsvd_0: 1;
-	u1Byte		gain: 6;
-#endif
-	u1Byte		rsvd_1;
-
-	/* DW1 */
-	u1Byte		rsvd_2;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		rxsc: 4;
-	u1Byte		agc_table: 4;
-#else
-	u1Byte		agc_table: 4;
-	u1Byte		rxsc: 4;
-#endif
-	u1Byte		channel;
-	u1Byte		band;
-
-	/* DW2 */
-	u2Byte		length;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		antidx_a: 3;
-	u1Byte		antidx_b: 3;
-	u1Byte		rsvd_3: 2;
-	u1Byte		antidx_c: 3;
-	u1Byte		antidx_d: 3;
-	u1Byte		rsvd_4:2;
-#else
-	u1Byte		rsvd_3: 2;
-	u1Byte		antidx_b: 3;
-	u1Byte		antidx_a: 3;
-	u1Byte		rsvd_4:2;
-	u1Byte		antidx_d: 3;
-	u1Byte		antidx_c: 3;
-#endif
-
-	/* DW3 */
-	u1Byte		signal_quality;
-	u1Byte		agc_rpt;
-	u1Byte		bb_power;
-	u1Byte		rsvd_5;
-
-	/* DW4 */
-	u4Byte		rsvd_6;
-
-	/* DW5 */
-	u4Byte		rsvd_7;
-
-	/* DW6 */
-	u4Byte		rsvd_8;
-} PHY_STATUS_RPT_JAGUAR2_TYPE0, *PPHY_STATUS_RPT_JAGUAR2_TYPE0;
-
-typedef struct _Phy_Status_Rpt_Jaguar2_Type1 {
-	/* DW0 and DW1 */
-	u1Byte		page_num;
-	u1Byte		pwdb[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		l_rxsc: 4;
-	u1Byte		ht_rxsc: 4;
-#else
-	u1Byte		ht_rxsc: 4;
-	u1Byte		l_rxsc: 4;
-#endif
-	u1Byte		channel;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		band: 2;
-	u1Byte		rsvd_0: 1;
-	u1Byte		hw_antsw_occu: 1;
-	u1Byte		gnt_bt: 1;
-	u1Byte		ldpc: 1;
-	u1Byte		stbc: 1;
-	u1Byte		beamformed: 1;
-#else
-	u1Byte		beamformed: 1;
-	u1Byte		stbc: 1;
-	u1Byte		ldpc: 1;
-	u1Byte		gnt_bt: 1;
-	u1Byte		hw_antsw_occu: 1;
-	u1Byte		rsvd_0: 1;
-	u1Byte		band: 2;
-#endif
-
-	/* DW2 */
-	u2Byte		lsig_length;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		antidx_a: 3;
-	u1Byte		antidx_b: 3;
-	u1Byte		rsvd_1: 2;
-	u1Byte		antidx_c: 3;
-	u1Byte		antidx_d: 3;
-	u1Byte		rsvd_2: 2;
-#else
-	u1Byte		rsvd_1: 2;
-	u1Byte		antidx_b: 3;
-	u1Byte		antidx_a: 3;
-	u1Byte		rsvd_2: 2;
-	u1Byte		antidx_d: 3;
-	u1Byte		antidx_c: 3;
-#endif
-
-	/* DW3 */
-	u1Byte		paid;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		paid_msb: 1;
-	u1Byte		gid: 6;
-	u1Byte		rsvd_3: 1;
-#else
-	u1Byte		rsvd_3: 1;
-	u1Byte		gid: 6;
-	u1Byte		paid_msb: 1;
-#endif
-	u1Byte		intf_pos;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		intf_pos_msb: 1;
-	u1Byte		rsvd_4: 2;
-	u1Byte		nb_intf_flag: 1;
-	u1Byte		rf_mode: 2;
-	u1Byte		rsvd_5: 2;
-#else
-	u1Byte		rsvd_5: 2;
-	u1Byte		rf_mode: 2;
-	u1Byte		nb_intf_flag: 1;
-	u1Byte		rsvd_4: 2;
-	u1Byte		intf_pos_msb: 1;
-#endif
-
-	/* DW4 */
-	s1Byte		rxevm[4];			/* s(8,1) */
-
-	/* DW5 */
-	s1Byte		cfo_tail[4];			/* s(8,7) */
-
-	/* DW6 */
-	s1Byte		rxsnr[4];			/* s(8,1) */
-} PHY_STATUS_RPT_JAGUAR2_TYPE1, *PPHY_STATUS_RPT_JAGUAR2_TYPE1;
-
-typedef struct _Phy_Status_Rpt_Jaguar2_Type2 {
-	/* DW0 ane DW1 */
-	u1Byte		page_num;
-	u1Byte		pwdb[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)	
-	u1Byte		l_rxsc: 4;
-	u1Byte		ht_rxsc: 4;
-#else
-	u1Byte		ht_rxsc: 4;
-	u1Byte		l_rxsc: 4;
-#endif
-	u1Byte		channel;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		band: 2;
-	u1Byte		rsvd_0: 1;
-	u1Byte		hw_antsw_occu: 1;
-	u1Byte		gnt_bt: 1;
-	u1Byte		ldpc: 1;
-	u1Byte		stbc: 1;
-	u1Byte		beamformed: 1;
-#else
-	u1Byte		beamformed: 1;
-	u1Byte		stbc: 1;
-	u1Byte		ldpc: 1;
-	u1Byte		gnt_bt: 1;
-	u1Byte		hw_antsw_occu: 1;
-	u1Byte		rsvd_0: 1;
-	u1Byte		band: 2;
-#endif
-
-	/* DW2 */
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		shift_l_map: 6;
-	u1Byte		rsvd_1: 2;
-#else
-	u1Byte		rsvd_1: 2;
-	u1Byte		shift_l_map: 6;
-#endif
-	u1Byte		cnt_pw2cca;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		agc_table_a: 4;
-	u1Byte		agc_table_b: 4;
-	u1Byte		agc_table_c: 4;
-	u1Byte		agc_table_d: 4;
-#else
-	u1Byte		agc_table_b: 4;
-	u1Byte		agc_table_a: 4;
-	u1Byte		agc_table_d: 4;
-	u1Byte		agc_table_c: 4;
-#endif
-
-	/* DW3 ~ DW6*/
-	u1Byte		cnt_cca2agc_rdy;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		gain_a: 6;
-	u1Byte		rsvd_2: 1;
-	u1Byte		trsw_a: 1;
-	u1Byte		gain_b: 6;
-	u1Byte		rsvd_3: 1;
-	u1Byte		trsw_b: 1;
-	u1Byte		gain_c: 6;
-	u1Byte		rsvd_4: 1;
-	u1Byte		trsw_c: 1;
-	u1Byte		gain_d: 6;
-	u1Byte		rsvd_5: 1;
-	u1Byte		trsw_d: 1;
-	u1Byte		aagc_step_a: 2;
-	u1Byte		aagc_step_b: 2;
-	u1Byte		aagc_step_c: 2;
-	u1Byte		aagc_step_d: 2;
-#else
-	u1Byte		trsw_a: 1;
-	u1Byte		rsvd_2: 1;
-	u1Byte		gain_a: 6;
-	u1Byte		trsw_b: 1;
-	u1Byte		rsvd_3: 1;
-	u1Byte		gain_b: 6;
-	u1Byte		trsw_c: 1;
-	u1Byte		rsvd_4: 1;
-	u1Byte		gain_c: 6;
-	u1Byte		trsw_d: 1;
-	u1Byte		rsvd_5: 1;
-	u1Byte		gain_d: 6;
-	u1Byte		aagc_step_d: 2;
-	u1Byte		aagc_step_c: 2;
-	u1Byte		aagc_step_b: 2;
-	u1Byte		aagc_step_a: 2;
-#endif
-	u1Byte		ht_aagc_gain[4];
-	u1Byte		dagc_gain[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u1Byte		counter: 6;
-	u1Byte		rsvd_6: 2;
-	u1Byte		syn_count: 5;
-	u1Byte		rsvd_7:3;
-#else
-	u1Byte		rsvd_6: 2;
-	u1Byte		counter: 6;
-	u1Byte		rsvd_7:3;
-	u1Byte		syn_count: 5;
-#endif
-} PHY_STATUS_RPT_JAGUAR2_TYPE2, *PPHY_STATUS_RPT_JAGUAR2_TYPE2;
-/*==============================================*/
-#endif
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__HALHWOUTSRC_H__
+#define __HALHWOUTSRC_H__
+
+
+/*--------------------------Define -------------------------------------------*/
+#define AGC_DIFF_CONFIG_MP(ic, band) (odm_read_and_config_mp_##ic##_agc_tab_diff(dm, array_mp_##ic##_agc_tab_diff_##band, \
+		      sizeof(array_mp_##ic##_agc_tab_diff_##band)/sizeof(u32)))
+#define AGC_DIFF_CONFIG_TC(ic, band) (odm_read_and_config_tc_##ic##_agc_tab_diff(dm, array_tc_##ic##_agc_tab_diff_##band, \
+		      sizeof(array_tc_##ic##_agc_tab_diff_##band)/sizeof(u32)))
+
+#define AGC_DIFF_CONFIG(ic, band) do {\
+		if (dm->is_mp_chip)\
+			AGC_DIFF_CONFIG_MP(ic, band);\
+		else\
+			AGC_DIFF_CONFIG_TC(ic, band);\
+	} while (0)
+
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+enum hal_status
+odm_config_rf_with_tx_pwr_track_header_file(
+	struct dm_struct		*dm
+);
+
+enum hal_status
+odm_config_rf_with_header_file(
+	struct dm_struct		*dm,
+	enum odm_rf_config_type		config_type,
+	u8						e_rf_path
+);
+
+enum hal_status
+odm_config_bb_with_header_file(
+	struct dm_struct	*dm,
+	enum odm_bb_config_type		config_type
+);
+
+enum hal_status
+odm_config_mac_with_header_file(
+	struct dm_struct	*dm
+);
+
+u32
+odm_get_hw_img_version(
+	struct dm_struct	*dm
+);
+
+
+u32
+query_phydm_trx_capability(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_stbc_capability(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_ldpc_capability(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_txbf_parameters(
+	struct dm_struct					*dm
+);
+
+u32
+query_phydm_txbf_capability(
+	struct dm_struct					*dm
+);
+
+#endif /*#ifndef	__HALHWOUTSRC_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.c
index 6b97b03eb787..83f843dc1a77 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.c
@@ -1,1014 +1,1413 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-//
-// ODM IO Relative API.
-//
-
-u1Byte
-ODM_Read1Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv	= pDM_Odm->priv;
-	return	RTL_R8(RegAddr);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return rtw_read8(Adapter,RegAddr);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return	PlatformEFIORead1Byte(Adapter, RegAddr);
-#endif	
-
-}
-
-
-u2Byte
-ODM_Read2Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv	= pDM_Odm->priv;
-	return	RTL_R16(RegAddr);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return rtw_read16(Adapter,RegAddr);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return	PlatformEFIORead2Byte(Adapter, RegAddr);
-#endif	
-
-}
-
-
-u4Byte
-ODM_Read4Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv	= pDM_Odm->priv;
-	return	RTL_R32(RegAddr);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return rtw_read32(Adapter,RegAddr);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return	PlatformEFIORead4Byte(Adapter, RegAddr);
-#endif	
-
-}
-
-
-VOID
-ODM_Write1Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr,
-	IN	u1Byte			Data
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv	= pDM_Odm->priv;
-	RTL_W8(RegAddr, Data);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	rtw_write8(Adapter,RegAddr, Data);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformEFIOWrite1Byte(Adapter, RegAddr, Data);
-#endif
-	
-}
-
-
-VOID
-ODM_Write2Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr,
-	IN	u2Byte			Data
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv	= pDM_Odm->priv;
-	RTL_W16(RegAddr, Data);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	rtw_write16(Adapter,RegAddr, Data);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformEFIOWrite2Byte(Adapter, RegAddr, Data);
-#endif	
-
-}
-
-
-VOID
-ODM_Write4Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr,
-	IN	u4Byte			Data
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	prtl8192cd_priv	priv	= pDM_Odm->priv;
-	RTL_W32(RegAddr, Data);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	rtw_write32(Adapter,RegAddr, Data);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformEFIOWrite4Byte(Adapter, RegAddr, Data);
-#endif	
-
-}
-
-
-VOID
-ODM_SetMACReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask,
-	IN	u4Byte		Data
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	PHY_SetBBReg(pDM_Odm->priv, RegAddr, BitMask, Data);
-#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PHY_SetBBReg(Adapter, RegAddr, BitMask, Data);
-#endif	
-}
-
-
-u4Byte 
-ODM_GetMACReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	return PHY_QueryBBReg(pDM_Odm->priv, RegAddr, BitMask);
-#elif(DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	return PHY_QueryMacReg(pDM_Odm->Adapter, RegAddr, BitMask);
-#endif	
-}
-
-
-VOID
-ODM_SetBBReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask,
-	IN	u4Byte		Data
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	PHY_SetBBReg(pDM_Odm->priv, RegAddr, BitMask, Data);
-#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PHY_SetBBReg(Adapter, RegAddr, BitMask, Data);
-#endif	
-}
-
-
-u4Byte 
-ODM_GetBBReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	return PHY_QueryBBReg(pDM_Odm->priv, RegAddr, BitMask);
-#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return PHY_QueryBBReg(Adapter, RegAddr, BitMask);
-#endif	
-}
-
-
-VOID
-ODM_SetRFReg(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	ODM_RF_RADIO_PATH_E	eRFPath,
-	IN	u4Byte				RegAddr,
-	IN	u4Byte				BitMask,
-	IN	u4Byte				Data
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	PHY_SetRFReg(pDM_Odm->priv, eRFPath, RegAddr, BitMask, Data);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PHY_SetRFReg(Adapter, eRFPath, RegAddr, BitMask, Data);
-	ODM_delay_us(2);
-	
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PHY_SetRFReg(pDM_Odm->Adapter, eRFPath, RegAddr, BitMask, Data);
-#endif	
-}
-
-
-u4Byte 
-ODM_GetRFReg(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	ODM_RF_RADIO_PATH_E	eRFPath,
-	IN	u4Byte				RegAddr,
-	IN	u4Byte				BitMask
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	return PHY_QueryRFReg(pDM_Odm->priv, eRFPath, RegAddr, BitMask, 1);
-#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_WIN))
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	return PHY_QueryRFReg(Adapter, eRFPath, RegAddr, BitMask);
-#endif	
-}
-
-
-
-
-//
-// ODM Memory relative API.
-//
-VOID
-ODM_AllocateMemory(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	OUT	PVOID		*pPtr,
-	IN	u4Byte		length
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	*pPtr = kmalloc(length, GFP_ATOMIC);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE )
-	*pPtr = rtw_zvmalloc(length);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformAllocateMemory(Adapter, pPtr, length);
-#endif	
-}
-
-// length could be ignored, used to detect memory leakage.
-VOID
-ODM_FreeMemory(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	OUT	PVOID		pPtr,
-	IN	u4Byte		length
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	kfree(pPtr);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE )	
-	rtw_vmfree(pPtr, length);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	//PADAPTER    Adapter = pDM_Odm->Adapter;
-	PlatformFreeMemory(pPtr, length);
-#endif	
-}
-
-VOID
-ODM_MoveMemory(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	OUT PVOID		pDest,
-	IN  PVOID		pSrc,
-	IN  u4Byte		Length
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	memcpy(pDest, pSrc, Length);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE )	
-	_rtw_memcpy(pDest, pSrc, Length);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformMoveMemory(pDest, pSrc, Length);
-#endif	
-}
-
-void ODM_Memory_Set(
-	IN	PDM_ODM_T	pDM_Odm,
-	IN	PVOID		pbuf,
-	IN	s1Byte		value,
-	IN	u4Byte		length
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	memset(pbuf, value, length);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE )	
-	_rtw_memset(pbuf,value, length);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformFillMemory(pbuf,length,value);
-#endif
-}
-s4Byte ODM_CompareMemory(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	PVOID           pBuf1,
-	IN	PVOID           pBuf2,
-	IN	u4Byte          length
-       )
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	return memcmp(pBuf1,pBuf2,length);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE )	
-	return _rtw_memcmp(pBuf1,pBuf2,length);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)	
-	return PlatformCompareMemory(pBuf1,pBuf2,length);
-#endif	
-}
-
-
-
-//
-// ODM MISC relative API.
-//
-VOID
-ODM_AcquireSpinLock(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	RT_SPINLOCK_TYPE	type
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	rtw_odm_acquirespinlock(Adapter, type);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformAcquireSpinLock(Adapter, type);
-#endif	
-}
-VOID
-ODM_ReleaseSpinLock(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	RT_SPINLOCK_TYPE	type
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE )
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	rtw_odm_releasespinlock(Adapter, type);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformReleaseSpinLock(Adapter, type);
-#endif	
-}
-
-//
-// Work item relative API. FOr MP driver only~!
-//
-VOID
-ODM_InitializeWorkItem(	
-	IN 	PDM_ODM_T					pDM_Odm,
-	IN	PRT_WORK_ITEM				pRtWorkItem,
-	IN	RT_WORKITEM_CALL_BACK		RtWorkItemCallback,
-	IN	PVOID						pContext,
-	IN	const char*					szID
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformInitializeWorkItem(Adapter, pRtWorkItem, RtWorkItemCallback, pContext, szID);
-#endif	
-}
-
-
-VOID
-ODM_StartWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformStartWorkItem(pRtWorkItem);
-#endif	
-}
-
-
-VOID
-ODM_StopWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformStopWorkItem(pRtWorkItem);
-#endif	
-}
-
-
-VOID
-ODM_FreeWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformFreeWorkItem(pRtWorkItem);
-#endif	
-}
-
-
-VOID
-ODM_ScheduleWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformScheduleWorkItem(pRtWorkItem);
-#endif	
-}
-
-
-VOID
-ODM_IsWorkItemScheduled(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformIsWorkItemScheduled(pRtWorkItem);
-#endif	
-}
-
-
-
-//
-// ODM Timer relative API.
-//
-VOID
-ODM_StallExecution(	
-	IN	u4Byte	usDelay
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	rtw_udelay_os(usDelay);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformStallExecution(usDelay);
-#endif	
-}
-
-VOID
-ODM_delay_ms(IN u4Byte	ms)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	delay_ms(ms);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	rtw_mdelay_os(ms);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	delay_ms(ms);
-#endif			
-}
-
-VOID
-ODM_delay_us(IN u4Byte	us)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	delay_us(us);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	rtw_udelay_os(us);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformStallExecution(us);
-#endif			
-}
-
-VOID
-ODM_sleep_ms(IN u4Byte	ms)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	rtw_msleep_os(ms);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)	
-#endif		
-}
-
-VOID
-ODM_sleep_us(IN u4Byte	us)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	rtw_usleep_os(us);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)	
-#endif		
-}
-
-VOID
-ODM_SetTimer(	
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	PRT_TIMER 		pTimer, 
-	IN	u4Byte 			msDelay
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	mod_timer(pTimer, jiffies + RTL_MILISECONDS_TO_JIFFIES(msDelay));
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	_set_timer(pTimer,msDelay ); //ms
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PlatformSetTimer(Adapter, pTimer, msDelay);
-#endif	
-
-}
-
-VOID
-ODM_InitializeTimer(
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	PRT_TIMER 			pTimer, 
-	IN	RT_TIMER_CALL_BACK	CallBackFunc, 
-	IN	PVOID				pContext,
-	IN	const char*			szID
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	init_timer(pTimer);
-	pTimer->function = CallBackFunc;
-	pTimer->data = (unsigned long)pDM_Odm;
-	mod_timer(pTimer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	_init_timer(pTimer,Adapter->pnetdev,CallBackFunc,pDM_Odm);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	PlatformInitializeTimer(Adapter, pTimer, CallBackFunc,pContext,szID);
-#endif	
-}
-
-
-VOID
-ODM_CancelTimer(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	PRT_TIMER		pTimer
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	del_timer(pTimer);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	_cancel_timer_ex(pTimer);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	PlatformCancelTimer(Adapter, pTimer);
-#endif
-}
-
-
-VOID
-ODM_ReleaseTimer(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	PRT_TIMER		pTimer
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
-	PADAPTER Adapter = pDM_Odm->Adapter;
-
-    // <20120301, Kordan> If the initilization fails, InitializeAdapterXxx will return regardless of InitHalDm. 
-    // Hence, uninitialized timers cause BSOD when the driver releases resources since the init fail.
-    if (pTimer == 0) 
-    {
-        ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_SERIOUS, ("=====>ODM_ReleaseTimer(), The timer is NULL! Please check it!\n"));
-        return;
-    }
-        
-	PlatformReleaseTimer(Adapter, pTimer);
-#endif
-}
-
-BOOLEAN
-phydm_actingDetermine(
-	IN PDM_ODM_T		pDM_Odm,
-	IN PHYDM_ACTING_TYPE	type
-	)
-{
-	BOOLEAN		ret = FALSE;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER	Adapter = pDM_Odm->BeamformingInfo.SourceAdapter;
-#else
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	if (type == PhyDM_ACTING_AS_AP)
-		ret = ACTING_AS_AP(Adapter);
-	else if (type == PhyDM_ACTING_AS_IBSS)
-		ret = ACTING_AS_IBSS(Adapter);
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct mlme_priv			*pmlmepriv = &(Adapter->mlmepriv);
-
-	if (type == PhyDM_ACTING_AS_AP)
-		ret = check_fwstate(pmlmepriv, WIFI_AP_STATE);
-	else if (type == PhyDM_ACTING_AS_IBSS)
-		ret = check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
-#endif
-
-	return ret;
-
-}
-
-
-u1Byte
-phydm_trans_h2c_id(
-	IN	PDM_ODM_T	pDM_Odm,
-	IN	u1Byte		phydm_h2c_id
-)
-{
-	u1Byte platform_h2c_id=0xff;
-
-	
-	switch(phydm_h2c_id)
-	{
-		//1 [0]
-		case ODM_H2C_RSSI_REPORT:
-
-			#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-				if(pDM_Odm->SupportICType == ODM_RTL8188E)
-				{
-					platform_h2c_id = H2C_88E_RSSI_REPORT;
-				}
-				else if(pDM_Odm->SupportICType == ODM_RTL8814A)
-				{
-					platform_h2c_id =H2C_8814A_RSSI_REPORT;                            
-				}
-				else
-				{
-					platform_h2c_id = H2C_RSSI_REPORT;
-				}
-				
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-				platform_h2c_id = H2C_RSSI_SETTING;
-
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_AP)
-				#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
-					if (pDM_Odm->SupportICType == ODM_RTL8881A || pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8814A || (pDM_Odm->SupportICType == ODM_RTL8822B)) 
-					{
-						platform_h2c_id =H2C_88XX_RSSI_REPORT;				
-						/*ODM_RT_TRACE(pDM_Odm,PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[H2C] H2C_88XX_RSSI_REPORT CMD_ID = (( %d ))\n", platform_h2c_id));*/
-					} else
-				#endif
-				#if(RTL8812A_SUPPORT==1) 
-					if(pDM_Odm->SupportICType == ODM_RTL8812)
-					{
-						platform_h2c_id = H2C_8812_RSSI_REPORT;
-					} else
-				#endif				
-					{}
-			#endif
-			
-				break;
-
-		//1 [3]	
-		case ODM_H2C_WIFI_CALIBRATION:
-			#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-					platform_h2c_id =H2C_WIFI_CALIBRATION;
-			
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-				#if(RTL8723B_SUPPORT==1) 
-					platform_h2c_id = H2C_8723B_BT_WLAN_CALIBRATION;
-				#endif
-				
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-			
-			#endif
-			
-				break;		
-	
-			
-		//1 [4]
-		case ODM_H2C_IQ_CALIBRATION:
-			#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-				platform_h2c_id =H2C_IQ_CALIBRATION;
-			
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-				#if((RTL8812A_SUPPORT==1) ||(RTL8821A_SUPPORT==1))
-				platform_h2c_id = H2C_8812_IQ_CALIBRATION;
-				#endif
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-			
-			#endif
-			
-				break;
-		//1 [5]
-		case ODM_H2C_RA_PARA_ADJUST:
-
-			#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-				if (pDM_Odm->SupportICType & (ODM_RTL8814A | ODM_RTL8822B))
-					platform_h2c_id = H2C_8814A_RA_PARA_ADJUST;
-				else
-					platform_h2c_id = H2C_RA_PARA_ADJUST;
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-				#if((RTL8812A_SUPPORT==1) ||(RTL8821A_SUPPORT==1))
-					platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
-				#elif ((RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
-					platform_h2c_id = H2C_RA_PARA_ADJUST;
-				#elif(RTL8192E_SUPPORT==1)
-					platform_h2c_id =H2C_8192E_RA_PARA_ADJUST;
-				#elif(RTL8723B_SUPPORT==1) 
-					platform_h2c_id =H2C_8723B_RA_PARA_ADJUST;
-				#endif
-				
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_AP)
-				#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1)) 
-					if (pDM_Odm->SupportICType == ODM_RTL8881A || pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8814A || (pDM_Odm->SupportICType == ODM_RTL8822B)) {
-						platform_h2c_id =H2C_88XX_RA_PARA_ADJUST;				
-						/*ODM_RT_TRACE(pDM_Odm,PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[H2C] H2C_88XX_RA_PARA_ADJUST CMD_ID = (( %d ))\n", platform_h2c_id));*/
-					} else
-				#endif
-				#if(RTL8812A_SUPPORT==1) 
-					if(pDM_Odm->SupportICType == ODM_RTL8812)
-					{
-						platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
-					} else
-				#endif
-					{}
-			#endif
-			
-				break;
-
-
-		//1 [6]
-		case PHYDM_H2C_DYNAMIC_TX_PATH:
-
-			#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-				if(pDM_Odm->SupportICType == ODM_RTL8814A)
-				{
-					platform_h2c_id =H2C_8814A_DYNAMIC_TX_PATH;
-				}
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-				#if (RTL8814A_SUPPORT == 1)
-				if (pDM_Odm->SupportICType == ODM_RTL8814A)
-					platform_h2c_id = H2C_DYNAMIC_TX_PATH;
-				#endif
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_AP)
-				#if(RTL8814A_SUPPORT==1)
-					if( pDM_Odm->SupportICType == ODM_RTL8814A)
-					{
-						platform_h2c_id = H2C_88XX_DYNAMIC_TX_PATH;				
-					} 
-				#endif
-
-			#endif
-			
-				break;
-
-		/* [7]*/
-		case PHYDM_H2C_FW_TRACE_EN:
-
-			#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-				if (pDM_Odm->SupportICType & (ODM_RTL8814A|ODM_RTL8822B))
-					platform_h2c_id = H2C_8814A_FW_TRACE_EN;
-				else 
-					platform_h2c_id = H2C_FW_TRACE_EN;
-				
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-
-				
-			#elif(DM_ODM_SUPPORT_TYPE & ODM_AP)
-				#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
-					if (pDM_Odm->SupportICType == ODM_RTL8881A || pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8814A || (pDM_Odm->SupportICType == ODM_RTL8822B))
-						platform_h2c_id  = H2C_88XX_FW_TRACE_EN;
-					else
-				#endif
-				#if (RTL8812A_SUPPORT == 1) 
-					if (pDM_Odm->SupportICType == ODM_RTL8812) {
-						platform_h2c_id = H2C_8812_FW_TRACE_EN;
-					} else
-				#endif
-					{}
-
-			#endif
-			
-				break;
-
-		case PHYDM_H2C_TXBF:
-#if ((RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1))
-			platform_h2c_id  = 0x41;	/*H2C_TxBF*/
-#endif
-		break;
-
-		default:
-			platform_h2c_id=0xff;
-			break;	
-	}	
-	
-	return platform_h2c_id;
-	
-}
-
-//
-// ODM FW relative API.
-//
-
-VOID
-ODM_FillH2CCmd(
-	IN	PDM_ODM_T		pDM_Odm,
-	IN	u1Byte 			phydm_h2c_id,
-	IN	u4Byte 			CmdLen,
-	IN	pu1Byte			pCmdBuffer
-)
-{
-	PADAPTER 	Adapter = pDM_Odm->Adapter;
-	u1Byte		platform_h2c_id;
-
-	platform_h2c_id=phydm_trans_h2c_id(pDM_Odm, phydm_h2c_id);
-
-	if(platform_h2c_id==0xff)
-	{
-		ODM_RT_TRACE(pDM_Odm,PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[H2C] Wrong H2C CMD-ID !! platform_h2c_id==0xff ,  PHYDM_ElementID=((%d )) \n",phydm_h2c_id));
-		return;
-	}
-
-	#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		if (pDM_Odm->SupportICType == ODM_RTL8188E)		
-			if (!pDM_Odm->RaSupport88E)
-				FillH2CCmd88E(Adapter, platform_h2c_id, CmdLen, pCmdBuffer);		
-		else if (pDM_Odm->SupportICType == ODM_RTL8192C)		
-			FillH2CCmd92C(Adapter, platform_h2c_id, CmdLen, pCmdBuffer);		
-		else if (pDM_Odm->SupportICType == ODM_RTL8814A)		
-			FillH2CCmd8814A(Adapter, platform_h2c_id, CmdLen, pCmdBuffer);		
-		else if (pDM_Odm->SupportICType == ODM_RTL8822B)		
-#if (RTL8822B_SUPPORT == 1)
-			FillH2CCmd8822B(Adapter, platform_h2c_id, CmdLen, pCmdBuffer);
-#endif		
-		else				
-			FillH2CCmd(Adapter, platform_h2c_id, CmdLen, pCmdBuffer);
-		
-	#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-		rtw_hal_fill_h2c_cmd(Adapter, platform_h2c_id, CmdLen, pCmdBuffer);
-
-	#elif(DM_ODM_SUPPORT_TYPE & ODM_AP)	
-		#if((RTL8881A_SUPPORT==1)||(RTL8192E_SUPPORT==1)||(RTL8814A_SUPPORT==1)) 
-			if(pDM_Odm->SupportICType == ODM_RTL8881A || pDM_Odm->SupportICType == ODM_RTL8192E|| pDM_Odm->SupportICType == ODM_RTL8814A) 
-			{
-				GET_HAL_INTERFACE(pDM_Odm->priv)->FillH2CCmdHandler(pDM_Odm->priv, platform_h2c_id, CmdLen, pCmdBuffer);
-				//FillH2CCmd88XX(pDM_Odm->priv, platform_h2c_id, CmdLen, pCmdBuffer);				
-			} else
-		#endif
-		#if(RTL8812A_SUPPORT==1) 
-			if(pDM_Odm->SupportICType == ODM_RTL8812)
-			{
-				FillH2CCmd8812(pDM_Odm->priv, platform_h2c_id, CmdLen, pCmdBuffer);
-			} else
-		#endif
-			{}
-	#endif
-}
-
-u1Byte
-phydm_c2H_content_parsing(
-	IN	PVOID			pDM_VOID,
-	IN	u1Byte			c2hCmdId,
-	IN	u1Byte			c2hCmdLen,
-	IN	pu1Byte			tmpBuf
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-	#endif
-	u1Byte	Extend_c2hSubID = 0;
-	u1Byte	find_c2h_cmd = TRUE;
-
-	switch (c2hCmdId) {
-	case PHYDM_C2H_DBG:
-		if (pDM_Odm->SupportICType & (ODM_RTL8814A|ODM_RTL8822B))
-			phydm_fw_trace_handler(pDM_Odm, tmpBuf, c2hCmdLen);
-		
-		break;
-
-	case PHYDM_C2H_RA_RPT:
-		phydm_c2h_ra_report_handler(pDM_Odm, tmpBuf, c2hCmdLen);
-		break;
-
-	case PHYDM_C2H_RA_PARA_RPT:
-		ODM_C2HRaParaReportHandler(pDM_Odm, tmpBuf, c2hCmdLen);
-		break;
-		
-	case PHYDM_C2H_DYNAMIC_TX_PATH_RPT:
-		if (pDM_Odm->SupportICType & (ODM_RTL8814A))
-			phydm_c2h_dtp_handler(pDM_Odm, tmpBuf, c2hCmdLen);
-		
-		break;
-		
-	case PHYDM_C2H_IQK_FINISH:
-		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		
-		if (pDM_Odm->SupportICType & (ODM_RTL8812 | ODM_RTL8821)) {
-			
-			RT_TRACE(COMP_MP, DBG_LOUD, ("== FW IQK Finish ==\n"));
-			PlatformAcquireSpinLock(Adapter, RT_IQK_SPINLOCK);
-			pDM_Odm->RFCalibrateInfo.bIQKInProgress = FALSE;
-			PlatformReleaseSpinLock(Adapter, RT_IQK_SPINLOCK);
-			pDM_Odm->RFCalibrateInfo.IQK_ProgressingTime = 0;
-			pDM_Odm->RFCalibrateInfo.IQK_ProgressingTime = ODM_GetProgressingTime(pDM_Odm, pDM_Odm->RFCalibrateInfo.IQK_StartTime);
-		}
-		
-		#endif
-		break;
-
-	case PHYDM_C2H_DBG_CODE:
-		phydm_fw_trace_handler_code(pDM_Odm, tmpBuf, c2hCmdLen);
-		break;	
-
-	case PHYDM_C2H_EXTEND:
-		Extend_c2hSubID = tmpBuf[0];
-		if (Extend_c2hSubID == PHYDM_EXTEND_C2H_DBG_PRINT)
-			phydm_fw_trace_handler_8051(pDM_Odm, tmpBuf, c2hCmdLen);
-		
-		break;
-
-	default:
-		find_c2h_cmd = FALSE;
-		break;
-	}
-
-	return find_c2h_cmd;
-
-}
-
-u8Byte
-ODM_GetCurrentTime(	
-	IN 	PDM_ODM_T		pDM_Odm
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	return  0;
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	return (u8Byte)rtw_get_current_time();
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)	
-	return  PlatformGetCurrentTime();
-#endif
-}
-
-u8Byte
-ODM_GetProgressingTime(	
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u8Byte			Start_Time
-	)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	return  0;
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	return rtw_get_passing_time_ms((u4Byte)Start_Time);
-#elif(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	return   ((PlatformGetCurrentTime() - Start_Time)>>10);
-#endif
-}
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/*
+ * ODM IO Relative API.
+ *   */
+
+u8
+odm_read_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	return	RTL_R8(reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_read_byte(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	return rtw_read8(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	return	PlatformEFIORead1Byte(adapter, reg_addr);
+#endif
+
+}
+
+
+u16
+odm_read_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	return	RTL_R16(reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_read_word(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	return rtw_read16(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	return	PlatformEFIORead2Byte(adapter, reg_addr);
+#endif
+
+}
+
+
+u32
+odm_read_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	return	RTL_R32(reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_read_dword(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	return rtw_read32(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	return	PlatformEFIORead4Byte(adapter, reg_addr);
+#endif
+
+}
+
+
+void
+odm_write_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u8			data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	RTL_W8(reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_write_byte(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	rtw_write8(adapter, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformEFIOWrite1Byte(adapter, reg_addr, data);
+#endif
+
+}
+
+
+void
+odm_write_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u16			data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	RTL_W16(reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_write_word(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	rtw_write16(adapter, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformEFIOWrite2Byte(adapter, reg_addr, data);
+#endif
+
+}
+
+
+void
+odm_write_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u32			data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct rtl8192cd_priv	*priv	= dm->priv;
+	RTL_W32(reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_write_dword(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void		*adapter = dm->adapter;
+	rtw_write32(adapter, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformEFIOWrite4Byte(adapter, reg_addr, data);
+#endif
+
+}
+
+
+void
+odm_set_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	phy_set_bb_reg(dm->priv, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetBBReg((PADAPTER)dm->adapter, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_set_bbreg(rtlpriv->hw, reg_addr, bit_mask, data);
+#else
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
+#endif
+}
+
+
+u32
+odm_get_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return phy_query_bb_reg(dm->priv, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_QueryMacReg((PADAPTER)dm->adapter, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_get_bbreg(rtlpriv->hw, reg_addr, bit_mask);
+#else
+	return phy_query_mac_reg(dm->adapter, reg_addr, bit_mask);
+#endif
+}
+
+
+void
+odm_set_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	phy_set_bb_reg(dm->priv, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetBBReg((PADAPTER)dm->adapter, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_set_bbreg(rtlpriv->hw, reg_addr, bit_mask, data);
+#else
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
+#endif
+}
+
+
+u32
+odm_get_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return phy_query_bb_reg(dm->priv, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_QueryBBReg((PADAPTER)dm->adapter, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_get_bbreg(rtlpriv->hw, reg_addr, bit_mask);
+#else
+	return phy_query_bb_reg(dm->adapter, reg_addr, bit_mask);
+#endif
+}
+
+
+void
+odm_set_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask,
+	u32				data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	phy_set_rf_reg(dm->priv, e_rf_path, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetRFReg((PADAPTER)dm->adapter, e_rf_path, reg_addr, bit_mask, data);
+	ODM_delay_us(2);
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_set_rfreg(rtlpriv->hw, e_rf_path, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	phy_set_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask, data);
+#endif
+}
+
+u32
+odm_get_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return phy_query_rf_reg(dm->priv, e_rf_path, reg_addr, bit_mask, 1);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_QueryRFReg((PADAPTER)dm->adapter, e_rf_path, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	return rtl_get_rfreg(rtlpriv->hw, e_rf_path, reg_addr, bit_mask);
+#else
+	return phy_query_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask);
+#endif
+}
+
+enum hal_status
+phydm_set_reg_by_fw(
+	struct dm_struct			*dm,
+	enum phydm_halmac_param	config_type,
+	u32	offset,
+	u32	data,
+	u32	mask,
+	enum rf_path	e_rf_path,
+	u32 delay_time
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	return HAL_MAC_Config_PHY_WriteNByte(dm,
+									config_type,
+									offset,
+									data,
+									mask,
+									e_rf_path,
+									delay_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "Not support for CE MAC80211 driver!\n");
+#else
+	return rtw_phydm_cfg_phy_para(dm,
+							config_type,
+							offset,
+							data,
+							mask,
+							e_rf_path,
+							delay_time);
+#endif
+#endif
+
+}
+
+
+/*
+ * ODM Memory relative API.
+ *   */
+void
+odm_allocate_memory(
+	struct dm_struct	*dm,
+	void **ptr,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	*ptr = kmalloc(length, GFP_ATOMIC);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	*ptr = kmalloc(length, GFP_ATOMIC);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	*ptr = rtw_zvmalloc(length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformAllocateMemory(adapter, ptr, length);
+#endif
+}
+
+/* length could be ignored, used to detect memory leakage. */
+void
+odm_free_memory(
+	struct dm_struct	*dm,
+	void		*ptr,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	kfree(ptr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	kfree(ptr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_vmfree(ptr, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	/* struct void*    adapter = dm->adapter; */
+	PlatformFreeMemory(ptr, length);
+#endif
+}
+
+void
+odm_move_memory(
+	struct dm_struct	*dm,
+	void		*dest,
+	void		*src,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	memcpy(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	memcpy(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_rtw_memcpy(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformMoveMemory(dest, src, length);
+#endif
+}
+
+void odm_memory_set(
+	struct dm_struct	*dm,
+	void		*pbuf,
+	s8		value,
+	u32		length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	memset(pbuf, value, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	memset(pbuf, value, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_rtw_memset(pbuf, value, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformFillMemory(pbuf, length, value);
+#endif
+}
+s32 odm_compare_memory(
+	struct dm_struct		*dm,
+	void           *buf1,
+	void           *buf2,
+	u32          length
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return memcmp(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	return memcmp(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return _rtw_memcmp(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PlatformCompareMemory(buf1, buf2, length);
+#endif
+}
+
+
+
+/*
+ * ODM MISC relative API.
+ *   */
+void
+odm_acquire_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	rtl_odm_acquirespinlock(rtlpriv, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void *adapter = dm->adapter;
+	rtw_odm_acquirespinlock(adapter, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformAcquireSpinLock(adapter, type);
+#endif
+}
+void
+odm_release_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+	rtl_odm_releasespinlock(rtlpriv, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void *adapter = dm->adapter;
+	rtw_odm_releasespinlock(adapter, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformReleaseSpinLock(adapter, type);
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+/*
+ * Work item relative API. FOr MP driver only~!
+ *   */
+void
+odm_initialize_work_item(
+	struct dm_struct					*dm,
+	PRT_WORK_ITEM				p_rt_work_item,
+	RT_WORKITEM_CALL_BACK		rt_work_item_callback,
+	void						*context,
+	const char					*sz_id
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformInitializeWorkItem(adapter, p_rt_work_item, rt_work_item_callback, context, sz_id);
+#endif
+}
+
+
+void
+odm_start_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStartWorkItem(p_rt_work_item);
+#endif
+}
+
+
+void
+odm_stop_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStopWorkItem(p_rt_work_item);
+#endif
+}
+
+
+void
+odm_free_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformFreeWorkItem(p_rt_work_item);
+#endif
+}
+
+
+void
+odm_schedule_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformScheduleWorkItem(p_rt_work_item);
+#endif
+}
+
+
+boolean
+odm_is_work_item_scheduled(
+	PRT_WORK_ITEM	p_rt_work_item
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PlatformIsWorkItemScheduled(p_rt_work_item);
+#endif
+}
+#endif
+
+
+/*
+ * ODM Timer relative API.
+ *   */
+
+void
+ODM_delay_ms(u32	ms)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_ms(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	mdelay(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_mdelay_os(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	delay_ms(ms);
+#endif
+}
+
+void
+ODM_delay_us(u32	us)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_us(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	udelay(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_udelay_os(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStallExecution(us);
+#endif
+}
+
+void
+ODM_sleep_ms(u32	ms)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_ms(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	msleep(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_msleep_os(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	delay_ms(ms);
+#endif
+}
+
+void
+ODM_sleep_us(u32	us)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	delay_us(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	usleep_range(us, us + 1);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	rtw_usleep_os(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PlatformStallExecution(us);
+#endif
+}
+
+void
+odm_set_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer,
+	u32			ms_delay
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	mod_timer(timer, jiffies + RTL_MILISECONDS_TO_JIFFIES(ms_delay));
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	mod_timer(timer, jiffies + msecs_to_jiffies(ms_delay));
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_set_timer(timer, ms_delay); /* ms */
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void		*adapter = dm->adapter;
+	PlatformSetTimer(adapter, timer, ms_delay);
+#endif
+
+}
+
+void
+odm_initialize_timer(
+	struct dm_struct			*dm,
+	struct phydm_timer_list			*timer,
+	void	*call_back_func,
+	void				*context,
+	const char			*sz_id
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	init_timer(timer);
+	timer->function = call_back_func;
+	timer->data = (unsigned long)dm;
+	/*mod_timer(timer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	*/
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	init_timer(timer);
+	timer->function = call_back_func;
+	timer->data = (unsigned long)dm;
+	/*mod_timer(timer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	*/
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	struct _ADAPTER *adapter = dm->adapter;
+
+	_init_timer(timer, adapter->pnetdev, call_back_func, dm);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void *adapter = dm->adapter;
+
+	PlatformInitializeTimer(adapter, timer, (RT_TIMER_CALL_BACK)call_back_func, context, sz_id);
+#endif
+}
+
+
+void
+odm_cancel_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	del_timer(timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	del_timer(timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	_cancel_timer_ex(timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void *adapter = dm->adapter;
+	PlatformCancelTimer(adapter, timer);
+#endif
+}
+
+
+void
+odm_release_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+	void *adapter = dm->adapter;
+
+	/* <20120301, Kordan> If the initilization fails, InitializeAdapterXxx will return regardless of InitHalDm.
+	 * Hence, uninitialized timers cause BSOD when the driver releases resources since the init fail. */
+	if (timer == 0) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "=====>odm_release_timer(), The timer is NULL! Please check it!\n");
+		return;
+	}
+
+	PlatformReleaseTimer(adapter, timer);
+#endif
+}
+
+
+u8
+phydm_trans_h2c_id(
+	struct dm_struct	*dm,
+	u8		phydm_h2c_id
+)
+{
+	u8 platform_h2c_id = phydm_h2c_id;
+
+	switch (phydm_h2c_id) {
+	/* 1 [0] */
+	case ODM_H2C_RSSI_REPORT:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type == ODM_RTL8188E)
+			platform_h2c_id = H2C_88E_RSSI_REPORT;
+		else if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_8814A_RSSI_REPORT;
+		else
+			platform_h2c_id = H2C_RSSI_REPORT;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+		platform_h2c_id = H2C_RSSI_SETTING;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
+			platform_h2c_id = H2C_88XX_RSSI_REPORT;
+		else
+#endif
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				platform_h2c_id = H2C_8812_RSSI_REPORT;
+			else
+#endif
+			{}
+#endif
+
+		break;
+
+	/* 1 [3] */
+	case ODM_H2C_WIFI_CALIBRATION:
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		platform_h2c_id = H2C_WIFI_CALIBRATION;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (RTL8723B_SUPPORT == 1)
+		platform_h2c_id = H2C_8723B_BT_WLAN_CALIBRATION;
+#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#endif
+		break;
+
+
+	/* 1 [4] */
+	case ODM_H2C_IQ_CALIBRATION:
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		platform_h2c_id = H2C_IQ_CALIBRATION;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		platform_h2c_id = H2C_8812_IQ_CALIBRATION;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#endif
+
+		break;
+	/* 1 [5] */
+	case ODM_H2C_RA_PARA_ADJUST:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B))
+			platform_h2c_id = H2C_8814A_RA_PARA_ADJUST;
+		else
+			platform_h2c_id = H2C_RA_PARA_ADJUST;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
+#elif ((RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
+		platform_h2c_id = H2C_RA_PARA_ADJUST;
+#elif (RTL8192E_SUPPORT == 1)
+		platform_h2c_id = H2C_8192E_RA_PARA_ADJUST;
+#elif (RTL8723B_SUPPORT == 1)
+		platform_h2c_id = H2C_8723B_RA_PARA_ADJUST;
+#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
+			platform_h2c_id = H2C_88XX_RA_PARA_ADJUST;
+		else
+#endif
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
+			else
+#endif
+			{}
+#endif
+
+		break;
+
+
+	/* 1 [6] */
+	case PHYDM_H2C_DYNAMIC_TX_PATH:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_8814A_DYNAMIC_TX_PATH;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (RTL8814A_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_DYNAMIC_TX_PATH;
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (RTL8814A_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8814A)
+			platform_h2c_id = H2C_88XX_DYNAMIC_TX_PATH;
+#endif
+
+#endif
+
+		break;
+
+	/* [7]*/
+	case PHYDM_H2C_FW_TRACE_EN:
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B))
+			platform_h2c_id = H2C_8814A_FW_TRACE_EN;
+		else
+			platform_h2c_id = H2C_FW_TRACE_EN;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+		platform_h2c_id = 0x49;
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
+			platform_h2c_id  = H2C_88XX_FW_TRACE_EN;
+		else
+#endif
+#if (RTL8812A_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8812)
+				platform_h2c_id = H2C_8812_FW_TRACE_EN;
+			else
+#endif
+			{}
+
+#endif
+
+		break;
+
+	case PHYDM_H2C_TXBF:
+#if ((RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1))
+		platform_h2c_id  = 0x41;	/*H2C_TxBF*/
+#endif
+		break;
+
+	case PHYDM_H2C_MU:
+#if (RTL8822B_SUPPORT == 1)
+		platform_h2c_id  = 0x4a;	/*H2C_MU*/
+#endif
+		break;
+
+	default:
+		platform_h2c_id = phydm_h2c_id;
+		break;
+	}
+
+	return platform_h2c_id;
+
+}
+
+/*ODM FW relative API.*/
+
+void
+odm_fill_h2c_cmd(
+	struct dm_struct		*dm,
+	u8			phydm_h2c_id,
+	u32			cmd_len,
+	u8			*cmd_buffer
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+#else
+	PADAPTER	adapter = (PADAPTER)dm->adapter;
+#endif
+	u8		h2c_id = phydm_trans_h2c_id(dm, phydm_h2c_id);
+
+	PHYDM_DBG(dm, DBG_RA, "[H2C]  h2c_id=((0x%x))\n", h2c_id);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	if (dm->support_ic_type == ODM_RTL8188E)	{
+		if (!dm->ra_support88e)
+			FillH2CCmd88E(adapter, h2c_id, cmd_len, cmd_buffer);
+	} else if (dm->support_ic_type == ODM_RTL8814A)
+		FillH2CCmd8814A(adapter, h2c_id, cmd_len, cmd_buffer);
+	else if (dm->support_ic_type == ODM_RTL8822B)
+		FillH2CCmd8822B(adapter, h2c_id, cmd_len, cmd_buffer);
+	else
+		FillH2CCmd(adapter, h2c_id, cmd_len, cmd_buffer);
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+
+	#ifdef DM_ODM_CE_MAC80211
+	rtlpriv->cfg->ops->fill_h2c_cmd(rtlpriv->hw, h2c_id,cmd_len, cmd_buffer);
+	#else
+	rtw_hal_fill_h2c_cmd(adapter, h2c_id, cmd_len, cmd_buffer);
+	#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8812) {
+		fill_h2c_cmd8812(dm->priv, h2c_id, cmd_len, cmd_buffer);
+	} else
+	#endif
+	{
+		GET_HAL_INTERFACE(dm->priv)->fill_h2c_cmd_handler(dm->priv, h2c_id, cmd_len, cmd_buffer);
+	}
+#endif
+}
+
+u8
+phydm_c2H_content_parsing(
+	void			*dm_void,
+	u8			c2h_cmd_id,
+	u8			c2h_cmd_len,
+	u8			*tmp_buf
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+#endif
+	u8	extend_c2h_sub_id = 0;
+	u8	find_c2h_cmd = true;
+	
+	if ((c2h_cmd_len > 12) || (c2h_cmd_len == 0)) {
+		pr_debug("[Warning] Error C2H ID=%d, len=%d\n", c2h_cmd_id, c2h_cmd_len);
+		
+		find_c2h_cmd = false;
+		return find_c2h_cmd;
+	}
+	
+	switch (c2h_cmd_id) {
+	case PHYDM_C2H_DBG:
+		phydm_fw_trace_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_RA_RPT:
+		phydm_c2h_ra_report_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_RA_PARA_RPT:
+		odm_c2h_ra_para_report_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_DYNAMIC_TX_PATH_RPT:
+		if (dm->support_ic_type & (ODM_RTL8814A))
+			phydm_c2h_dtp_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_IQK_FINISH:
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+		if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821)) {
+			RT_TRACE(COMP_MP, DBG_LOUD, ("== FW IQK Finish ==\n"));
+			odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+			dm->rf_calibrate_info.is_iqk_in_progress = false;
+			odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+			dm->rf_calibrate_info.iqk_progressing_time = 0;
+			dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(dm, dm->rf_calibrate_info.iqk_start_time);
+		}
+
+#endif
+		break;
+
+	case PHYDM_C2H_CLM_MONITOR:
+		phydm_clm_c2h_report_handler(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_DBG_CODE:
+		phydm_fw_trace_handler_code(dm, tmp_buf, c2h_cmd_len);
+		break;
+
+	case PHYDM_C2H_EXTEND:
+		extend_c2h_sub_id = tmp_buf[0];
+		if (extend_c2h_sub_id == PHYDM_EXTEND_C2H_DBG_PRINT)
+			phydm_fw_trace_handler_8051(dm, tmp_buf, c2h_cmd_len);
+
+		break;
+
+	default:
+		find_c2h_cmd = false;
+		break;
+	}
+
+	return find_c2h_cmd;
+
+}
+
+u64
+odm_get_current_time(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return (u64)rtw_get_current_time();
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	return jiffies;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return rtw_get_current_time();
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return  PlatformGetCurrentTime();
+#endif
+}
+
+u64
+odm_get_progressing_time(
+	struct dm_struct		*dm,
+	u64			start_time
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	return rtw_get_passing_time_ms((u32)start_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	return jiffies_to_msecs(jiffies - start_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return rtw_get_passing_time_ms((systime)start_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return ((PlatformGetCurrentTime() - start_time) >> 10);
+#endif
+}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE)) && !defined(DM_ODM_CE_MAC80211)
+
+void
+phydm_set_hw_reg_handler_interface (
+	struct dm_struct		*dm,
+	u8				RegName,
+	u8				*val
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
+	struct _ADAPTER *adapter = (PADAPTER)dm->adapter;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	((PADAPTER)adapter)->HalFunc.SetHwRegHandler(adapter, RegName, val);
+#else
+	adapter->hal_func.set_hw_reg_handler(adapter, RegName, val);
+#endif
+
+#endif
+
+}
+
+void
+phydm_get_hal_def_var_handler_interface (
+	struct dm_struct		*dm,
+	enum _HAL_DEF_VARIABLE		e_variable,
+	void						*value
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
+	struct _ADAPTER *adapter = (PADAPTER)dm->adapter;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	adapter->HalFunc.GetHalDefVarHandler(adapter, e_variable, value);
+#else
+	adapter->hal_func.get_hal_def_var_handler(adapter, e_variable, value);
+#endif
+
+#endif
+}
+
+#endif
+
+void
+odm_set_tx_power_index_by_rate_section (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				channel,
+	u8				rate_section
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetTxPowerIndexByRateSection((PADAPTER)dm->adapter, path, channel, rate_section);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	phy_set_tx_power_index_by_rs((PADAPTER)dm->adapter, channel, path, rate_section);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	phy_set_tx_power_index_by_rate_section(dm->adapter, path, channel, rate_section);
+#endif
+}
+
+
+u8
+odm_get_tx_power_index (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				tx_rate,
+	u8				band_width,
+	u8				channel
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return PHY_GetTxPowerIndex((PADAPTER)dm->adapter, path, tx_rate, (CHANNEL_WIDTH)band_width, channel);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+
+	return phy_get_tx_power_index(adapter, (enum rf_path)path, tx_rate, band_width, channel);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return phy_get_tx_power_index(dm->adapter, path, tx_rate, band_width, channel);
+#endif
+}
+
+
+
+u8
+odm_efuse_one_byte_read(
+	struct dm_struct	*dm,
+	u16			addr,
+	u8			*data,
+	boolean		b_pseu_do_test
+	)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	return (u8)EFUSE_OneByteRead((PADAPTER)dm->adapter, addr, data, b_pseu_do_test);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+
+	return rtl_efuse_onebyte_read(adapter, addr, data, b_pseu_do_test);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	return efuse_onebyte_read(dm->adapter, addr, data, b_pseu_do_test);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	/*ReadEFuseByte(dm->priv, addr, data);*/
+	/*return true;*/
+#endif
+}
+
+
+
+void
+odm_efuse_logical_map_read(
+	struct	dm_struct	*dm,
+	u8	type,
+	u16	offset,
+	u32	*data
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	EFUSE_ShadowRead((PADAPTER)dm->adapter, type, offset, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+
+	rtl_efuse_logical_map_read(adapter, type, offset, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	efuse_logical_map_read(dm->adapter, type, offset, data);
+#endif
+}
+
+enum hal_status
+odm_iq_calibrate_by_fw(
+	struct dm_struct	*dm,
+	u8 clear,
+	u8 segment
+	)
+{
+	enum hal_status iqk_result = HAL_STATUS_FAILURE;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct _ADAPTER *adapter = (PADAPTER)dm->adapter;
+	
+	if (HAL_MAC_FWIQK_Trigger(&GET_HAL_MAC_INFO(adapter), clear, segment) == 0)
+		iqk_result = HAL_STATUS_SUCCESS;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void		*adapter = dm->adapter;
+	iqk_result = rtl_phydm_fw_iqk(adapter, clear, segment);
+#else
+	iqk_result = rtw_phydm_fw_iqk(dm, clear, segment);
+#endif
+#endif
+	return iqk_result;
+}
+
+void
+odm_cmn_info_ptr_array_hook(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	u16			index,
+	void			*value
+)
+{
+	switch	(cmn_info) {
+	/*Dynamic call by reference pointer.	*/
+	case	ODM_CMNINFO_STA_STATUS:
+		dm->odm_sta_info[index] = (struct sta_info *)value;
+		break;
+	/* To remove the compiler warning, must add an empty default statement to handle the other values. */
+	default:
+		/* do nothing */
+		break;
+	}
+
+}
+
+void
+phydm_cmn_sta_info_hook(
+	struct dm_struct		*dm,
+	u8			mac_id,
+	struct cmn_sta_info *pcmn_sta_info
+)
+{
+	dm->phydm_sta_info[mac_id] = pcmn_sta_info;
+
+	if (is_sta_active(pcmn_sta_info))
+		dm->phydm_macid_table[pcmn_sta_info->mac_id] = mac_id;
+}
+
+void
+phydm_macid2sta_idx_table(
+	struct dm_struct	*dm,
+	u8			entry_idx,
+	struct cmn_sta_info	*pcmn_sta_info
+)
+{
+	if (is_sta_active(pcmn_sta_info))
+		dm->phydm_macid_table[pcmn_sta_info->mac_id] = entry_idx;
+}
+
+void
+phydm_add_interrupt_mask_handler(
+	struct dm_struct		*dm,
+	u8							interrupt_type
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	#if IS_EXIST_PCI || IS_EXIST_EMBEDDED
+	GET_HAL_INTERFACE(priv)->AddInterruptMaskHandler(priv, interrupt_type);
+	#endif
+	
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#endif
+}
+
+void
+phydm_enable_rx_related_interrupt_handler(
+	struct dm_struct		*dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	struct rtl8192cd_priv	*priv = dm->priv;
+
+	#if IS_EXIST_PCI || IS_EXIST_EMBEDDED
+	GET_HAL_INTERFACE(priv)->EnableRxRelatedInterruptHandler(priv);
+	#endif
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#endif
+}
+
+#if 0
+boolean
+phydm_get_txbf_en(
+	struct dm_struct		*dm,
+	u16							mac_id,
+	u8							i
+)
+{
+	boolean txbf_en = false;
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && !defined(DM_ODM_CE_MAC80211)
+
+	#ifdef CONFIG_BEAMFORMING
+	enum beamforming_cap beamform_cap;
+	void *adapter = dm->adapter;
+	#if (BEAMFORMING_SUPPORT == 1)
+	beamform_cap =
+	phydm_beamforming_get_entry_beam_cap_by_mac_id(dm, mac_id);
+	#else/*for drv beamforming*/
+	beamform_cap =
+	beamforming_get_entry_beam_cap_by_mac_id(&adapter->mlmepriv, mac_id);
+	#endif
+	if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
+		txbf_en = true;
+	else
+		txbf_en = false;
+	#endif /*#ifdef CONFIG_BEAMFORMING*/
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	#if (BEAMFORMING_SUPPORT == 1)
+	u8 idx = 0xff;
+	boolean act_bfer = false;
+	BEAMFORMING_CAP beamform_cap = BEAMFORMING_CAP_NONE;
+	PRT_BEAMFORMING_ENTRY	entry = NULL;
+	struct rtl8192cd_priv *priv			= dm->priv;
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
+
+	dm_bdc_table->num_txbfee_client = 0;
+	dm_bdc_table->num_txbfer_client = 0;
+	#endif
+	#endif
+
+	#if (BEAMFORMING_SUPPORT == 1)
+	beamform_cap = Beamforming_GetEntryBeamCapByMacId(priv, mac_id);
+	entry = Beamforming_GetEntryByMacId(priv, mac_id, &idx);
+	if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) {
+		if (entry->Sounding_En)
+			txbf_en = true;
+		else
+			txbf_en = false;
+		act_bfer = true;
+	}
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*BDC*/
+	if (act_bfer == true) {
+		dm_bdc_table->w_bfee_client[i] = true; /* AP act as BFer */
+		dm_bdc_table->num_txbfee_client++;
+	} else
+		dm_bdc_table->w_bfee_client[i] = false; /* AP act as BFer */
+	
+	if (beamform_cap & (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP_VHT_SU)) {
+		dm_bdc_table->w_bfer_client[i] = true; /* AP act as BFee */
+		dm_bdc_table->num_txbfer_client++;
+	} else
+		dm_bdc_table->w_bfer_client[i] = false; /* AP act as BFer */
+
+	#endif
+	#endif
+
+#endif
+	return txbf_en;
+
+}
+#endif
+
+void
+phydm_iqk_wait(
+	struct dm_struct		*dm,
+	u32		timeout
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, ODM_COMP_COMMON, "Not support for CE MAC80211 driver!\n");
+#else
+	void		*adapter = dm->adapter;
+
+	rtl8812_iqk_wait(adapter, timeout);
+#endif
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.h
index 3288849d042f..45ceb00fc27f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_interface.h
@@ -1,442 +1,527 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-
-#ifndef	__ODM_INTERFACE_H__
-#define __ODM_INTERFACE_H__
-
-#define INTERFACE_VERSION	"1.0"		/*2015.01.13  Dino*/
-
-//
-// =========== Constant/Structure/Enum/... Define
-//
-
-
-
-//
-// =========== Macro Define
-//
-
-#define _reg_all(_name)			ODM_##_name
-#define _reg_ic(_name, _ic)		ODM_##_name##_ic
-#define _bit_all(_name)			BIT_##_name
-#define _bit_ic(_name, _ic)		BIT_##_name##_ic
-
-// _cat: implemented by Token-Pasting Operator.
-#if 0
-#define _cat(_name, _ic_type, _func)								\
-	( 															\
-		_func##_all(_name)										\
-	)
-#endif
-
-/*===================================
-
-#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
-
-#ifdef __ECOS
-#define _rtk_cat(_name, _ic_type, _func)		\
-	( 					\
-		((_ic_type) & ODM_IC_11N_SERIES)? _func##_11N(_name):		\
-		_func##_11AC(_name)	\
-	)
-#else
-
-#define _cat(_name, _ic_type, _func)									\
-	( 															\
-		((_ic_type) & ODM_IC_11N_SERIES)? _func##_11N(_name):		\
-		_func##_11AC(_name)									\
-	)
-#endif
-/* 
-// only sample code
-//#define _cat(_name, _ic_type, _func)									\
-//	( 															\
-//		((_ic_type) & ODM_RTL8192C)? _func##_ic(_name, _8192C):		\
-//		((_ic_type) & ODM_RTL8192D)? _func##_ic(_name, _8192D):		\
-//		((_ic_type) & ODM_RTL8192S)? _func##_ic(_name, _8192S):		\
-//		((_ic_type) & ODM_RTL8723A)? _func##_ic(_name, _8723A):		\
-//		((_ic_type) & ODM_RTL8188E)? _func##_ic(_name, _8188E):		\
-//		_func##_ic(_name, _8195)									\
-//	)
-*/
-
-// _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.
-#ifdef __ECOS
-#define ODM_REG(_name, _pDM_Odm)	_rtk_cat(_name, _pDM_Odm->SupportICType, _reg)
-#define ODM_BIT(_name, _pDM_Odm)	_rtk_cat(_name, _pDM_Odm->SupportICType, _bit)
-#else
-#define ODM_REG(_name, _pDM_Odm)	_cat(_name, _pDM_Odm->SupportICType, _reg)
-#define ODM_BIT(_name, _pDM_Odm)	_cat(_name, _pDM_Odm->SupportICType, _bit)
-#endif
-typedef enum _PHYDM_H2C_CMD {
-	ODM_H2C_RSSI_REPORT = 0,
-	ODM_H2C_PSD_RESULT = 1,	
-	ODM_H2C_PathDiv = 2,
-	ODM_H2C_WIFI_CALIBRATION = 3,
-	ODM_H2C_IQ_CALIBRATION = 4,
-	ODM_H2C_RA_PARA_ADJUST = 5,
-	PHYDM_H2C_DYNAMIC_TX_PATH = 6,
-	PHYDM_H2C_FW_TRACE_EN = 7,
-	PHYDM_H2C_TXBF = 8,
-	ODM_MAX_H2CCMD
-} PHYDM_H2C_CMD;
-
-typedef enum _PHYDM_C2H_EVT {
-	PHYDM_C2H_DBG = 0,
-	PHYDM_C2H_LB = 1,
-	PHYDM_C2H_XBF = 2,
-	PHYDM_C2H_TX_REPORT = 3,
-	PHYDM_C2H_INFO = 9,
-	PHYDM_C2H_BT_MP = 11,
-	PHYDM_C2H_RA_RPT = 12,
-	PHYDM_C2H_RA_PARA_RPT = 14,
-	PHYDM_C2H_DYNAMIC_TX_PATH_RPT = 15,
-	PHYDM_C2H_IQK_FINISH = 17, /*0x11*/
-	PHYDM_C2H_DBG_CODE = 0xFE,
-	PHYDM_C2H_EXTEND = 0xFF,
-} PHYDM_C2H_EVT;
-
-typedef enum _PHYDM_EXTEND_C2H_EVT {
-	PHYDM_EXTEND_C2H_DBG_PRINT = 0
-
-} PHYDM_EXTEND_C2H_EVT;
-
-typedef enum _PHYDM_ACTING_TYPE {
-	PhyDM_ACTING_AS_IBSS = 0,
-	PhyDM_ACTING_AS_AP = 1
-} PHYDM_ACTING_TYPE;
-
-
-//
-// 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.
-//
-#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
-typedef  void *PRT_WORK_ITEM ;
-typedef  void RT_WORKITEM_HANDLE,*PRT_WORKITEM_HANDLE;
-typedef VOID (*RT_WORKITEM_CALL_BACK)(PVOID pContext);
-
-#if 0
-typedef struct tasklet_struct RT_WORKITEM_HANDLE, *PRT_WORKITEM_HANDLE;
-
-typedef struct _RT_WORK_ITEM
-{
-	
-	RT_WORKITEM_HANDLE			Handle;			// Platform-dependent handle for this workitem, e.g. Ndis Workitem object.
-	PVOID						Adapter;		// Pointer to Adapter object.
-	PVOID						pContext;		// Parameter to passed to CallBackFunc(). 
-	RT_WORKITEM_CALL_BACK		CallbackFunc;	// Callback function of the workitem.
-	u1Byte						RefCount;		// 0: driver is going to unload, 1: No such workitem scheduled, 2: one workitem is schedueled. 
-	PVOID						pPlatformExt;	// Pointer to platform-dependent extension.	
-	BOOLEAN						bFree;
-	char						szID[36];		// An identity string of this workitem.
-}RT_WORK_ITEM, *PRT_WORK_ITEM;
-
-#endif
-
-
-#endif
-
-//
-// =========== Extern Variable ??? It should be forbidden.
-//
-
-
-//
-// =========== EXtern Function Prototype
-//
-
-
-u1Byte
-ODM_Read1Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr
-	);
-
-u2Byte
-ODM_Read2Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr
-	);
-
-u4Byte
-ODM_Read4Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr
-	);
-
-VOID
-ODM_Write1Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr,
-	IN	u1Byte			Data
-	);
-
-VOID
-ODM_Write2Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr,
-	IN	u2Byte			Data
-	);
-
-VOID
-ODM_Write4Byte(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u4Byte			RegAddr,
-	IN	u4Byte			Data
-	);
-
-VOID
-ODM_SetMACReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask,
-	IN	u4Byte		Data
-	);
-
-u4Byte 
-ODM_GetMACReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask
-	);
-
-VOID
-ODM_SetBBReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask,
-	IN	u4Byte		Data
-	);
-
-u4Byte 
-ODM_GetBBReg(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	u4Byte		RegAddr,
-	IN	u4Byte		BitMask
-	);
-
-VOID
-ODM_SetRFReg(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	ODM_RF_RADIO_PATH_E	eRFPath,
-	IN	u4Byte				RegAddr,
-	IN	u4Byte				BitMask,
-	IN	u4Byte				Data
-	);
-
-u4Byte 
-ODM_GetRFReg(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	ODM_RF_RADIO_PATH_E	eRFPath,
-	IN	u4Byte				RegAddr,
-	IN	u4Byte				BitMask
-	);
-
-
-//
-// Memory Relative Function.
-//
-VOID
-ODM_AllocateMemory(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	OUT	PVOID		*pPtr,
-	IN	u4Byte		length
-	);
-VOID
-ODM_FreeMemory(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	OUT	PVOID		pPtr,
-	IN	u4Byte		length
-	);
-
-VOID
-ODM_MoveMemory(	
-	IN 	PDM_ODM_T	pDM_Odm,
-	OUT PVOID		pDest,
-	IN  PVOID		pSrc,
-	IN  u4Byte		Length
-	);
-
-s4Byte ODM_CompareMemory(
-	IN 	PDM_ODM_T	pDM_Odm,
-	IN	PVOID           pBuf1,
-      IN	PVOID           pBuf2,
-      IN	u4Byte          length
-       );
-
-void ODM_Memory_Set
-	(IN 	PDM_ODM_T	pDM_Odm,
-		IN  PVOID	pbuf,
-		IN  s1Byte	value,
-		IN  u4Byte	length);
-	
-//
-// ODM MISC-spin lock relative API.
-//
-VOID
-ODM_AcquireSpinLock(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	RT_SPINLOCK_TYPE	type
-	);
-
-VOID
-ODM_ReleaseSpinLock(	
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	RT_SPINLOCK_TYPE	type
-	);
-
-
-//
-// ODM MISC-workitem relative API.
-//
-VOID
-ODM_InitializeWorkItem(	
-	IN 	PDM_ODM_T					pDM_Odm,
-	IN	PRT_WORK_ITEM				pRtWorkItem,
-	IN	RT_WORKITEM_CALL_BACK		RtWorkItemCallback,
-	IN	PVOID						pContext,
-	IN	const char*					szID
-	);
-
-VOID
-ODM_StartWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	);
-
-VOID
-ODM_StopWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	);
-
-VOID
-ODM_FreeWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	);
-
-VOID
-ODM_ScheduleWorkItem(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	);
-
-VOID
-ODM_IsWorkItemScheduled(	
-	IN	PRT_WORK_ITEM	pRtWorkItem
-	);
-
-//
-// ODM Timer relative API.
-//
-VOID
-ODM_StallExecution(	
-	IN	u4Byte	usDelay
-	);
-
-VOID
-ODM_delay_ms(IN u4Byte	ms);
-
-
-
-VOID
-ODM_delay_us(IN u4Byte	us);
-
-VOID
-ODM_sleep_ms(IN u4Byte	ms);
-
-VOID
-ODM_sleep_us(IN u4Byte	us);
-
-VOID
-ODM_SetTimer(	
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	PRT_TIMER 		pTimer, 
-	IN	u4Byte 			msDelay
-	);
-
-VOID
-ODM_InitializeTimer(
-	IN 	PDM_ODM_T			pDM_Odm,
-	IN	PRT_TIMER 			pTimer, 
-	IN	RT_TIMER_CALL_BACK	CallBackFunc, 
-	IN	PVOID				pContext,
-	IN	const char*			szID
-	);
-
-VOID
-ODM_CancelTimer(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	PRT_TIMER		pTimer
-	);
-
-VOID
-ODM_ReleaseTimer(
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	PRT_TIMER		pTimer
-	);
-
-BOOLEAN
-phydm_actingDetermine(
-	IN	PDM_ODM_T		pDM_Odm,
-	IN	PHYDM_ACTING_TYPE	type
-	);
-
-//
-// ODM FW relative API.
-//
-VOID
-ODM_FillH2CCmd(
-	IN	PDM_ODM_T		pDM_Odm,
-	IN	u1Byte 			ElementID,
-	IN	u4Byte 			CmdLen,
-	IN	pu1Byte			pCmdBuffer
-);
-
-u1Byte
-phydm_c2H_content_parsing(
-	IN	PVOID			pDM_VOID,
-	IN	u1Byte			c2hCmdId,
-	IN	u1Byte			c2hCmdLen,
-	IN	pu1Byte			tmpBuf
-);
-
-u8Byte
-ODM_GetCurrentTime(	
-	IN 	PDM_ODM_T		pDM_Odm
-	);
-u8Byte
-ODM_GetProgressingTime(	
-	IN 	PDM_ODM_T		pDM_Odm,
-	IN	u8Byte			Start_Time
-	);
-
-#endif	// __ODM_INTERFACE_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__ODM_INTERFACE_H__
+#define __ODM_INTERFACE_H__
+
+#define INTERFACE_VERSION	"1.2"		/*2017.05.03  YuChen add phy param offload HAL MAC API*/
+
+#define pdm_set_reg	odm_set_bb_reg
+
+/*=========== Constant/Structure/Enum/... Define*/
+
+enum phydm_h2c_cmd {
+	PHYDM_H2C_RA_MASK		= 0x40,
+	PHYDM_H2C_TXBF			= 0x41,
+	ODM_H2C_RSSI_REPORT		= 0x42,
+	ODM_H2C_IQ_CALIBRATION	= 0x45,
+	PHYDM_RA_MASK_ABOVE_3SS = 0x46,
+	ODM_H2C_RA_PARA_ADJUST	= 0x47,
+	PHYDM_H2C_DYNAMIC_TX_PATH = 0x48,
+	PHYDM_H2C_FW_TRACE_EN	= 0x49,
+	ODM_H2C_WIFI_CALIBRATION	= 0x6d,
+	PHYDM_H2C_MU				= 0x4a,
+	PHYDM_H2C_FW_GENERAL_INIT = 0x4c,
+	PHYDM_H2C_FW_CLM_MNTR = 0x4d,
+	ODM_MAX_H2CCMD
+};
+
+enum phydm_c2h_evt {
+	PHYDM_C2H_DBG = 0,
+	PHYDM_C2H_LB = 1,
+	PHYDM_C2H_XBF = 2,
+	PHYDM_C2H_TX_REPORT = 3,
+	PHYDM_C2H_INFO = 9,
+	PHYDM_C2H_BT_MP = 11,
+	PHYDM_C2H_RA_RPT = 12,
+	PHYDM_C2H_RA_PARA_RPT = 14,
+	PHYDM_C2H_DYNAMIC_TX_PATH_RPT = 15,
+	PHYDM_C2H_IQK_FINISH = 17, /*0x11*/
+	PHYDM_C2H_CLM_MONITOR = 0x2a,
+	PHYDM_C2H_DBG_CODE = 0xFE,
+	PHYDM_C2H_EXTEND = 0xFF,
+};
+
+enum phydm_extend_c2h_evt {
+	PHYDM_EXTEND_C2H_DBG_PRINT = 0
+
+};
+
+enum phydm_halmac_param {
+	PHYDM_HALMAC_CMD_MAC_W8 = 0,
+	PHYDM_HALMAC_CMD_MAC_W16 = 1,
+	PHYDM_HALMAC_CMD_MAC_W32 = 2,
+	PHYDM_HALMAC_CMD_BB_W8,
+	PHYDM_HALMAC_CMD_BB_W16,
+	PHYDM_HALMAC_CMD_BB_W32,
+	PHYDM_HALMAC_CMD_RF_W,
+	PHYDM_HALMAC_CMD_DELAY_US,
+	PHYDM_HALMAC_CMD_DELAY_MS,
+	PHYDM_HALMAC_CMD_END = 0XFF,
+};
+
+/*=========== Macro Define*/
+
+#define _reg_all(_name)			ODM_##_name
+#define _reg_ic(_name, _ic)		ODM_##_name##_ic
+#define _bit_all(_name)			BIT_##_name
+#define _bit_ic(_name, _ic)		BIT_##_name##_ic
+
+/* _cat: implemented by Token-Pasting Operator. */
+#if 0
+#define _cat(_name, _ic_type, _func)								\
+	(\
+	 _func##_all(_name)										\
+	)
+#endif
+
+/*===================================
+
+#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
+
+#ifdef __ECOS
+#define _rtk_cat(_name, _ic_type, _func)		\
+	(\
+	 ((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) :		\
+	 _func##_11AC(_name)	\
+	)
+#else
+
+#define _cat(_name, _ic_type, _func)									\
+	(\
+	 ((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) :		\
+	 _func##_11AC(_name)									\
+	)
+#endif
+/*
+ * only sample code
+ *#define _cat(_name, _ic_type, _func)									\
+ *	(															\
+ *		((_ic_type) & ODM_RTL8188E) ? _func##_ic(_name, _8188E) :		\
+ *		_func##_ic(_name, _8195)									\
+ *	)
+ */
+
+/* _name: name of register or bit.
+ * Example: "ODM_REG(R_A_AGC_CORE1, dm)"
+ * gets "ODM_R_A_AGC_CORE1" or "ODM_R_A_AGC_CORE1_8192C", depends on support_ic_type. */
+#ifdef __ECOS
+	#define ODM_REG(_name, _pdm_odm)	_rtk_cat(_name, _pdm_odm->support_ic_type, _reg)
+	#define ODM_BIT(_name, _pdm_odm)	_rtk_cat(_name, _pdm_odm->support_ic_type, _bit)
+#else
+	#define ODM_REG(_name, _pdm_odm)	_cat(_name, _pdm_odm->support_ic_type, _reg)
+	#define ODM_BIT(_name, _pdm_odm)	_cat(_name, _pdm_odm->support_ic_type, _bit)
+#endif
+
+/*
+ * =========== Extern Variable ??? It should be forbidden.
+ *   */
+
+
+/*
+ * =========== EXtern Function Prototype
+ *   */
+
+
+u8
+odm_read_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+);
+
+u16
+odm_read_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+);
+
+u32
+odm_read_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr
+);
+
+void
+odm_write_1byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u8			data
+);
+
+void
+odm_write_2byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u16			data
+);
+
+void
+odm_write_4byte(
+	struct dm_struct		*dm,
+	u32			reg_addr,
+	u32			data
+);
+
+void
+odm_set_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+);
+
+u32
+odm_get_mac_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+);
+
+void
+odm_set_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask,
+	u32		data
+);
+
+u32
+odm_get_bb_reg(
+	struct dm_struct	*dm,
+	u32		reg_addr,
+	u32		bit_mask
+);
+
+void
+odm_set_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask,
+	u32				data
+);
+
+u32
+odm_get_rf_reg(
+	struct dm_struct			*dm,
+	u8			e_rf_path,
+	u32				reg_addr,
+	u32				bit_mask
+);
+
+
+/*
+ * Memory Relative Function.
+ *   */
+void
+odm_allocate_memory(
+	struct dm_struct	*dm,
+	void **ptr,
+	u32		length
+);
+void
+odm_free_memory(
+	struct dm_struct	*dm,
+	void		*ptr,
+	u32		length
+);
+
+void
+odm_move_memory(
+	struct dm_struct	*dm,
+	void		*dest,
+	void		*src,
+	u32		length
+);
+
+s32 odm_compare_memory(
+	struct dm_struct	*dm,
+	void           *buf1,
+	void           *buf2,
+	u32          length
+);
+
+void odm_memory_set(
+	struct dm_struct	*dm,
+	void	*pbuf,
+	s8	value,
+	u32	length
+);
+
+/*
+ * ODM MISC-spin lock relative API.
+ *   */
+void
+odm_acquire_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+);
+
+void
+odm_release_spin_lock(
+	struct dm_struct			*dm,
+	enum rt_spinlock_type	type
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+/*
+ * ODM MISC-workitem relative API.
+ *   */
+void
+odm_initialize_work_item(
+	struct dm_struct					*dm,
+	PRT_WORK_ITEM				p_rt_work_item,
+	RT_WORKITEM_CALL_BACK		rt_work_item_callback,
+	void						*context,
+	const char					*sz_id
+);
+
+void
+odm_start_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+void
+odm_stop_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+void
+odm_free_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+void
+odm_schedule_work_item(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+
+boolean
+odm_is_work_item_scheduled(
+	PRT_WORK_ITEM	p_rt_work_item
+);
+#endif
+
+/*
+ * ODM Timer relative API.
+ *   */
+void
+ODM_delay_ms(u32	ms);
+
+void
+ODM_delay_us(u32	us);
+
+void
+ODM_sleep_ms(u32	ms);
+
+void
+ODM_sleep_us(u32	us);
+
+void
+odm_set_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer,
+	u32			ms_delay
+);
+
+void
+odm_initialize_timer(
+	struct dm_struct			*dm,
+	struct phydm_timer_list			*timer,
+	void	*call_back_func,
+	void				*context,
+	const char			*sz_id
+);
+
+void
+odm_cancel_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_release_timer(
+	struct dm_struct		*dm,
+	struct phydm_timer_list		*timer
+);
+
+/*ODM FW relative API.*/
+
+
+enum hal_status
+phydm_set_reg_by_fw(
+	struct dm_struct			*dm,
+	enum phydm_halmac_param	config_type,
+	u32	offset,
+	u32	data,
+	u32	mask,
+	enum rf_path	e_rf_path,
+	u32 delay_time
+);
+
+void
+odm_fill_h2c_cmd(
+	struct dm_struct		*dm,
+	u8			element_id,
+	u32			cmd_len,
+	u8			*cmd_buffer
+);
+
+u8
+phydm_c2H_content_parsing(
+	void			*dm_void,
+	u8			c2h_cmd_id,
+	u8			c2h_cmd_len,
+	u8			*tmp_buf
+);
+
+u64
+odm_get_current_time(
+	struct dm_struct		*dm
+);
+u64
+odm_get_progressing_time(
+	struct dm_struct		*dm,
+	u64			start_time
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE)) && !defined(DM_ODM_CE_MAC80211)
+
+void
+phydm_set_hw_reg_handler_interface (
+	struct dm_struct		*dm,
+	u8				reg_Name,
+	u8				*val
+	);
+
+void
+phydm_get_hal_def_var_handler_interface (
+	struct dm_struct		*dm,
+	enum _HAL_DEF_VARIABLE		e_variable,
+	void						*value
+	);
+
+#endif
+
+void
+odm_set_tx_power_index_by_rate_section (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				channel,
+	u8				rate_section
+);
+
+u8
+odm_get_tx_power_index (
+	struct dm_struct	*dm,
+	enum rf_path		path,
+	u8				tx_rate,
+	u8				band_width,
+	u8				channel
+);
+
+u8
+odm_efuse_one_byte_read(
+	struct dm_struct	*dm,
+	u16			addr,
+	u8			*data,
+	boolean		b_pseu_do_test
+);
+
+void
+odm_efuse_logical_map_read(
+	struct	dm_struct	*dm,
+	u8	type,
+	u16	offset,
+	u32	*data
+);
+
+enum hal_status
+odm_iq_calibrate_by_fw(
+	struct dm_struct	*dm,
+	u8 clear,
+	u8 segment
+);
+
+void
+odm_cmn_info_ptr_array_hook(
+	struct dm_struct		*dm,
+	enum odm_cmninfo	cmn_info,
+	u16			index,
+	void			*value
+);
+
+void
+phydm_cmn_sta_info_hook(
+	struct dm_struct		*dm,
+	u8			index,
+	struct cmn_sta_info *pcmn_sta_info
+);
+
+void
+phydm_macid2sta_idx_table(
+	struct dm_struct	*dm,
+	u8			entry_idx,
+	struct cmn_sta_info	*pcmn_sta_info
+);
+
+void
+phydm_add_interrupt_mask_handler(
+	struct dm_struct		*dm,
+	u8							interrupt_type
+);
+
+void
+phydm_enable_rx_related_interrupt_handler(
+	struct dm_struct		*dm
+);
+
+#if 0
+boolean
+phydm_get_txbf_en(
+	struct dm_struct		*dm,
+	u16		mac_id,
+	u8		i
+);
+#endif
+
+void
+phydm_iqk_wait(
+	struct dm_struct		*dm,
+	u32		timeout
+);
+#endif /* __ODM_INTERFACE_H__ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_math_lib.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_math_lib.c
new file mode 100644
index 000000000000..868e8c719895
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_math_lib.c
@@ -0,0 +1,180 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+const u16 db_invert_table[12][8] = {
+	{	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}
+};
+
+
+/*Y = 10*log(X)*/
+s32
+odm_pwdb_conversion(
+	s32 X,
+	u32 total_bit,
+	u32 decimal_bit
+)
+{
+	s32 Y, integer = 0, decimal = 0;
+	u32 i;
+
+	if (X == 0)
+		X = 1; /* log2(x), x can't be 0 */
+
+	for (i = (total_bit - 1); i > 0; i--) {
+		if (X & BIT(i)) {
+			integer = i;
+			if (i > 0)
+				decimal = (X & BIT(i - 1)) ? 2 : 0; /* decimal is 0.5dB*3=1.5dB~=2dB */
+			break;
+		}
+	}
+
+	Y = 3 * (integer - decimal_bit) + decimal; /* 10*log(x)=3*log2(x), */
+
+	return Y;
+}
+
+s32
+odm_sign_conversion(
+	s32 value,
+	u32 total_bit
+)
+{
+	if (value & BIT(total_bit - 1))
+		value -= BIT(total_bit);
+	
+	return value;
+}
+
+void
+phydm_seq_sorting(
+	void	*dm_void,
+	u32	*value,
+	u32	*rank_idx,
+	u32	*idx_out,
+	u8	seq_length
+)
+{
+	u8		i = 0, j = 0;
+	u32		tmp_a, tmp_b;
+	u32		tmp_idx_a, tmp_idx_b;
+
+	for (i = 0; i < seq_length; i++) {
+		rank_idx[i] = i;
+		/**/
+	}
+
+	for (i = 0; i < (seq_length - 1); i++) {
+		for (j = 0; j < (seq_length - 1 - i); j++) {
+			tmp_a = value[j];
+			tmp_b = value[j + 1];
+
+			tmp_idx_a = rank_idx[j];
+			tmp_idx_b = rank_idx[j + 1];
+
+			if (tmp_a < tmp_b) {
+				value[j] = tmp_b;
+				value[j + 1] = tmp_a;
+
+				rank_idx[j] = tmp_idx_b;
+				rank_idx[j + 1] = tmp_idx_a;
+			}
+		}
+	}
+
+	for (i = 0; i < seq_length; i++) {
+		idx_out[rank_idx[i]] = i + 1;
+		/**/
+	}
+}
+
+u32
+odm_convert_to_db(
+	u32	value)
+{
+	u8 i;
+	u8 j;
+	u32 dB;
+
+	value = value & 0xFFFF;
+
+	for (i = 0; i < 12; i++) {
+		if (value <= db_invert_table[i][7])
+			break;
+	}
+
+	if (i >= 12) {
+		return 96;	/* maximum 96 dB */
+	}
+
+	for (j = 0; j < 8; j++) {
+		if (value <= db_invert_table[i][j])
+			break;
+	}
+
+	dB = (i << 3) + j + 1;
+
+	return dB;
+}
+
+u32
+odm_convert_to_linear(
+	u32	value)
+{
+	u8 i;
+	u8 j;
+	u32 linear;
+
+	/* 1dB~96dB */
+
+	value = value & 0xFF;
+
+	i = (u8)((value - 1) >> 3);
+	j = (u8)(value - 1) - (i << 3);
+
+	linear = db_invert_table[i][j];
+
+	return linear;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_math_lib.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_math_lib.h
new file mode 100644
index 000000000000..29fab30a2bbd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_math_lib.h
@@ -0,0 +1,88 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_MATH_LIB_H__
+#define    __PHYDM_MATH_LIB_H__
+
+#define AUTO_MATH_LIB_VERSION	"1.0"		/* 2017.06.06*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+s32
+odm_pwdb_conversion(
+	s32 X,
+	u32 total_bit,
+	u32 decimal_bit
+);
+
+s32
+odm_sign_conversion(
+	s32 value,
+	u32 total_bit
+);
+
+void
+phydm_seq_sorting(
+	void	*dm_void,
+	u32	*value,
+	u32	*rank_idx,
+	u32	*idx_out,
+	u8	seq_length
+);
+
+u32 
+odm_convert_to_db(
+	u32	 value
+);
+
+u32
+odm_convert_to_linear(
+	u32	value
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.c
index 22c50dbc343a..82e89519f7c5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.c
@@ -1,299 +1,428 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-//#include "mp_precomp.h"
-#include "phydm_precomp.h"
-#include "phydm_noisemonitor.h"
-
-//=================================================
-// This function is for inband noise test utility only
-// To obtain the inband noise level(dbm), do the following.
-// 1. disable DIG and Power Saving 
-// 2. Set initial gain = 0x1a
-// 3. Stop updating idle time pwer report (for driver read)
-//	- 0x80c[25]
-//
-//=================================================
-
-#define Valid_Min				-35
-#define Valid_Max			10
-#define ValidCnt				5	
-
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_CE))
-
-s2Byte odm_InbandNoise_Monitor_NSeries(PDM_ODM_T	pDM_Odm,u8 bPauseDIG,u8 IGIValue,u32 max_time)
-{
-	u4Byte				tmp4b;	
-	u1Byte				max_rf_path=0,rf_path;	
-	u1Byte				reg_c50, reg_c58,valid_done=0;	
-	struct noise_level		noise_data;
-	u32 start  = 0, 	func_start=0,	func_end = 0;
-
-	func_start = ODM_GetCurrentTime(pDM_Odm);
-	pDM_Odm->noise_level.noise_all = 0;
-	
-	if((pDM_Odm->RFType == ODM_1T2R) ||(pDM_Odm->RFType == ODM_2T2R))	
-		max_rf_path = 2;
-	else
-		max_rf_path = 1;
-	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("odm_DebugControlInbandNoise_Nseries() ==> \n"));
-
-	ODM_Memory_Set(pDM_Odm,&noise_data,0,sizeof(struct noise_level));
-	
-	//
-	// Step 1. Disable DIG && Set initial gain.
-	//
-	
-	if(bPauseDIG)
-	{
-		odm_PauseDIG(pDM_Odm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, IGIValue);
-	}
-	//
-	// Step 2. Disable all power save for read registers
-	//
-	//dcmd_DebugControlPowerSave(pAdapter, PSDisable);
-
-	//
-	// Step 3. Get noise power level
-	//
-	start = ODM_GetCurrentTime(pDM_Odm);
-	while(1)
-	{
-		
-		//Stop updating idle time pwer report (for driver read)
-		ODM_SetBBReg(pDM_Odm, rFPGA0_TxGainStage, BIT25, 1);	
-		
-		//Read Noise Floor Report
-		tmp4b = ODM_GetBBReg(pDM_Odm, 0x8f8,bMaskDWord );
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("Noise Floor Report (0x8f8) = 0x%08x\n", tmp4b));
-		
-		//ODM_SetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskByte0, TestInitialGain);
-		//if(max_rf_path == 2)
-		//	ODM_SetBBReg(pDM_Odm, rOFDM0_XBAGCCore1, bMaskByte0, TestInitialGain);
-		
-		//update idle time pwer report per 5us
-		ODM_SetBBReg(pDM_Odm, rFPGA0_TxGainStage, BIT25, 0);
-		
-		noise_data.value[ODM_RF_PATH_A] = (u1Byte)(tmp4b&0xff);		
-		noise_data.value[ODM_RF_PATH_B]  = (u1Byte)((tmp4b&0xff00)>>8);
-	
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD, ("value_a = 0x%x(%d), value_b = 0x%x(%d)\n", 
-			noise_data.value[ODM_RF_PATH_A], noise_data.value[ODM_RF_PATH_A], noise_data.value[ODM_RF_PATH_B], noise_data.value[ODM_RF_PATH_B]));
-
-		 for(rf_path = ODM_RF_PATH_A; rf_path < max_rf_path; rf_path++) 
-		 {
-		 	noise_data.sval[rf_path] = (s1Byte)noise_data.value[rf_path];
-			noise_data.sval[rf_path] /= 2;
-		 }	
-		 	
-		
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("sval_a = %d, sval_b = %d\n", 
-			noise_data.sval[ODM_RF_PATH_A], noise_data.sval[ODM_RF_PATH_B]));
-		//ODM_delay_ms(10);
-		//ODM_sleep_ms(10);
-
-		for(rf_path = ODM_RF_PATH_A; rf_path < max_rf_path; rf_path++) 
-		{
-			if( (noise_data.valid_cnt[rf_path] < ValidCnt) && (noise_data.sval[rf_path] < Valid_Max && noise_data.sval[rf_path] >= Valid_Min))
-			{
-				noise_data.valid_cnt[rf_path]++;
-				noise_data.sum[rf_path] += noise_data.sval[rf_path];
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("RF_Path:%d Valid sval = %d\n", rf_path,noise_data.sval[rf_path]));
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("Sum of sval = %d, \n", noise_data.sum[rf_path]));
-				if(noise_data.valid_cnt[rf_path] == ValidCnt)
-				{				
-					valid_done++;
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("After divided, RF_Path:%d ,sum = %d \n", rf_path,noise_data.sum[rf_path]));
-				}				
-			
-			}
-			
-		}
-
-		//printk("####### valid_done:%d #############\n",valid_done);
-		if ((valid_done==max_rf_path) || (ODM_GetProgressingTime(pDM_Odm,start) > max_time))
-		{
-			for(rf_path = ODM_RF_PATH_A; rf_path < max_rf_path; rf_path++)
-			{ 
-				//printk("%s PATH_%d - sum = %d, valid_cnt = %d \n",__FUNCTION__,rf_path,noise_data.sum[rf_path], noise_data.valid_cnt[rf_path]);
-				if(noise_data.valid_cnt[rf_path])
-					noise_data.sum[rf_path] /= noise_data.valid_cnt[rf_path];		
-				else
-					noise_data.sum[rf_path]  = 0;
-			}
-			break;
-		}
-	}
-	reg_c50 = (s4Byte)ODM_GetBBReg(pDM_Odm,rOFDM0_XAAGCCore1,bMaskByte0);
-	reg_c50 &= ~BIT7;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("0x%x = 0x%02x(%d)\n", rOFDM0_XAAGCCore1, reg_c50, reg_c50));
-	pDM_Odm->noise_level.noise[ODM_RF_PATH_A] = -110 + reg_c50 + noise_data.sum[ODM_RF_PATH_A];
-	pDM_Odm->noise_level.noise_all += pDM_Odm->noise_level.noise[ODM_RF_PATH_A];
-		
-	if(max_rf_path == 2){
-		reg_c58 = (s4Byte)ODM_GetBBReg(pDM_Odm,rOFDM0_XBAGCCore1,bMaskByte0);
-		reg_c58 &= ~BIT7;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("0x%x = 0x%02x(%d)\n", rOFDM0_XBAGCCore1, reg_c58, reg_c58));
-		pDM_Odm->noise_level.noise[ODM_RF_PATH_B] = -110 + reg_c58 + noise_data.sum[ODM_RF_PATH_B];
-		pDM_Odm->noise_level.noise_all += pDM_Odm->noise_level.noise[ODM_RF_PATH_B];
-	}
-	pDM_Odm->noise_level.noise_all /= max_rf_path;
-	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,("noise_a = %d, noise_b = %d\n", 
-		pDM_Odm->noise_level.noise[ODM_RF_PATH_A],
-		pDM_Odm->noise_level.noise[ODM_RF_PATH_B]));
-
-	//
-	// Step 4. Recover the Dig
-	//
-	if(bPauseDIG)
-	{
-		odm_PauseDIG(pDM_Odm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, IGIValue);
-	}	
-	func_end = ODM_GetProgressingTime(pDM_Odm,func_start) ;	
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("odm_DebugControlInbandNoise_Nseries() <==\n"));
-	return pDM_Odm->noise_level.noise_all;
-
-}
-
-s2Byte	
-odm_InbandNoise_Monitor_ACSeries(PDM_ODM_T	pDM_Odm, u8 bPauseDIG, u8 IGIValue, u32 max_time
-	)
-{
-	s4Byte          rxi_buf_anta, rxq_buf_anta; /*rxi_buf_antb, rxq_buf_antb;*/
-	s4Byte	        value32, pwdb_A = 0, sval, noise, sum;
-	BOOLEAN	        pd_flag;
-	u1Byte			i, valid_cnt;
-	u32 start = 0, func_start = 0, func_end = 0;
-
-
-	if (!(pDM_Odm->SupportICType & (ODM_RTL8812 | ODM_RTL8821)))
-		return 0;
-	
-	func_start = ODM_GetCurrentTime(pDM_Odm);
-	pDM_Odm->noise_level.noise_all = 0;
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("odm_InbandNoise_Monitor_ACSeries() ==>\n"));
-	
-	/* Step 1. Disable DIG && Set initial gain. */
-	if (bPauseDIG)
-		odm_PauseDIG(pDM_Odm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, IGIValue);
-
-	/* Step 2. Disable all power save for read registers */
-	/*dcmd_DebugControlPowerSave(pAdapter, PSDisable); */
-
-	/* Step 3. Get noise power level */
-	start = ODM_GetCurrentTime(pDM_Odm);
-
-	/* reset counters */
-	sum = 0;
-	valid_cnt = 0;
-
-	/* Step 3. Get noise power level */
-	while (1) {
-		/*Set IGI=0x1C */
-		ODM_Write_DIG(pDM_Odm, 0x1C);
-		/*stop CK320&CK88 */
-		ODM_SetBBReg(pDM_Odm, 0x8B4, BIT6, 1);
-		/*Read Path-A */
-		ODM_SetBBReg(pDM_Odm, 0x8FC, bMaskDWord, 0x200); /*set debug port*/
-		value32 = ODM_GetBBReg(pDM_Odm, 0xFA0, bMaskDWord); /*read debug port*/
-		
-		rxi_buf_anta = (value32 & 0xFFC00) >> 10; /*rxi_buf_anta=RegFA0[19:10]*/
-		rxq_buf_anta = value32 & 0x3FF; /*rxq_buf_anta=RegFA0[19:10]*/
-
-		pd_flag = (BOOLEAN) ((value32 & BIT31) >> 31);
-
-		/*Not in packet detection period or Tx state */
-		if ((!pd_flag) || (rxi_buf_anta != 0x200)) {
-			/*sign conversion*/
-			rxi_buf_anta = ODM_SignConversion(rxi_buf_anta, 10);
-			rxq_buf_anta = ODM_SignConversion(rxq_buf_anta, 10);
-
-			pwdb_A = ODM_PWdB_Conversion(rxi_buf_anta * rxi_buf_anta + rxq_buf_anta * rxq_buf_anta, 20, 18); /*S(10,9)*S(10,9)=S(20,18)*/
-
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("pwdb_A= %d dB, rxi_buf_anta= 0x%x, rxq_buf_anta= 0x%x\n", pwdb_A, rxi_buf_anta & 0x3FF, rxq_buf_anta & 0x3FF));
-		}
-
-		/*BB Reset*/
-		ODM_Write1Byte(pDM_Odm, 0x02, ODM_Read1Byte(pDM_Odm, 0x02) & (~BIT0));
-		ODM_Write1Byte(pDM_Odm, 0x02, ODM_Read1Byte(pDM_Odm, 0x02) | BIT0);
-
-		/*Start CK320&CK88*/
-		ODM_SetBBReg(pDM_Odm, 0x8B4, BIT6, 0);
-
-		sval = pwdb_A;
-
-		if (sval < 0 && sval >= -27) {
-			if (valid_cnt < ValidCnt) {
-				valid_cnt++;
-				sum += sval;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("Valid sval = %d\n", sval));
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("Sum of sval = %d,\n", sum));
-				if ((valid_cnt >= ValidCnt) || (ODM_GetProgressingTime(pDM_Odm, start) > max_time)) {
-					sum /= valid_cnt;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("After divided, sum = %d\n", sum)); 
-					break;
-				}
-			}
-		}
-	}
-
-	/*ADC backoff is 12dB,*/ 
-	/*Ptarget=0x1C-110=-82dBm*/
-	noise = sum + 12 + 0x1C - 110; 
-	
-	/*Offset*/
-	noise = noise - 3;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("noise = %d\n", noise));
-	pDM_Odm->noise_level.noise_all = (s2Byte)noise;
-
-	/* Step 4. Recover the Dig*/
-	if (bPauseDIG)
-		odm_PauseDIG(pDM_Odm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, IGIValue);
-	
-	func_end = ODM_GetProgressingTime(pDM_Odm, func_start);
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("odm_InbandNoise_Monitor_ACSeries() <==\n"));
-
-	return pDM_Odm->noise_level.noise_all;
-}
-
-
-
-s2Byte
-ODM_InbandNoise_Monitor(PVOID pDM_VOID, u8 bPauseDIG, u8 IGIValue, u32 max_time)
-{
-
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if (pDM_Odm->SupportICType & ODM_IC_11AC_SERIES)
-		return odm_InbandNoise_Monitor_ACSeries(pDM_Odm, bPauseDIG, IGIValue, max_time);
-	else
-		return odm_InbandNoise_Monitor_NSeries(pDM_Odm, bPauseDIG, IGIValue, max_time);
-}
-
-#endif
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* *************************************************
+ * This function is for inband noise test utility only
+ * To obtain the inband noise level(dbm), do the following.
+ * 1. disable DIG and Power Saving
+ * 2. Set initial gain = 0x1a
+ * 3. Stop updating idle time pwer report (for driver read)
+ *	- 0x80c[25]
+ *
+ * ************************************************* */
+
+#define VALID_CNT				5
+
+void phydm_set_noise_data_sum(struct noise_level *noise_data, u8 max_rf_path)
+{
+	u8 rf_path;
+
+	for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+		if (noise_data->valid_cnt[rf_path])
+			noise_data->sum[rf_path] /= noise_data->valid_cnt[rf_path];
+		else
+			noise_data->sum[rf_path]  = 0;
+	}
+}
+
+s16 odm_inband_noise_monitor_n_series(struct dm_struct	*dm, u8 is_pause_dig, u8 igi_value, u32 max_time)
+{
+	u32				tmp4b;
+	u8				max_rf_path = 0, rf_path;
+	u8				reg_c50, reg_c58, valid_done = 0;
+	struct noise_level		noise_data;
+	u64	start  = 0, func_start = 0,	func_end = 0;
+
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
+
+	if ((dm->rf_type == RF_1T2R) || (dm->rf_type == RF_2T2R))
+		max_rf_path = 2;
+	else
+		max_rf_path = 1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "odm_DebugControlInbandNoise_Nseries() ==>\n");
+
+	odm_memory_set(dm, &noise_data, 0, sizeof(struct noise_level));
+	/* step 1. Disable DIG && Set initial gain. */
+
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	/* step 3. Get noise power level */
+	start = odm_get_current_time(dm);
+	while (1) {
+		/* Stop updating idle time pwer report (for driver read) */
+		odm_set_bb_reg(dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 1);
+
+		/* Read Noise Floor Report */
+		tmp4b = odm_get_bb_reg(dm, 0x8f8, MASKDWORD);
+
+		/* update idle time pwer report per 5us */
+		odm_set_bb_reg(dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 0);
+
+		ODM_delay_us(5);
+
+		noise_data.value[RF_PATH_A] = (u8)(tmp4b & 0xff);
+		noise_data.value[RF_PATH_B]  = (u8)((tmp4b & 0xff00) >> 8);
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			noise_data.sval[rf_path] = (s8)noise_data.value[rf_path];
+			noise_data.sval[rf_path] /= 2;
+		}
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			if (noise_data.valid_cnt[rf_path] >= VALID_CNT)
+				continue;
+
+			noise_data.valid_cnt[rf_path]++;
+			noise_data.sum[rf_path] += noise_data.sval[rf_path];
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "rf_path:%d Valid sval = %d\n", rf_path, noise_data.sval[rf_path]);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d,\n", noise_data.sum[rf_path]);
+			if (noise_data.valid_cnt[rf_path] == VALID_CNT)
+				valid_done++;
+		}
+		if ((valid_done == max_rf_path) || (odm_get_progressing_time(dm, start) > max_time)) {
+			phydm_set_noise_data_sum(&noise_data, max_rf_path);
+			break;
+		}
+	}
+	reg_c50 = (u8)odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKBYTE0);
+	reg_c50 &= ~BIT(7);
+	dm->noise_level.noise[RF_PATH_A] = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
+	dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_A];
+
+	if (max_rf_path == 2) {
+		reg_c58 = (u8)odm_get_bb_reg(dm, REG_OFDM_0_XB_AGC_CORE1, MASKBYTE0);
+		reg_c58 &= ~BIT(7);
+		dm->noise_level.noise[RF_PATH_B] = (s8)(-110 + reg_c58 + noise_data.sum[RF_PATH_B]);
+		dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_B];
+	}
+	dm->noise_level.noise_all /= max_rf_path;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "noise_a = %d, noise_b = %d, noise_all = %d\n",
+		dm->noise_level.noise[RF_PATH_A], dm->noise_level.noise[RF_PATH_B],
+		dm->noise_level.noise_all);
+
+	/* step 4. Recover the Dig */
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
+	func_end = odm_get_progressing_time(dm, func_start);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "end\n");
+	return dm->noise_level.noise_all;
+
+}
+
+
+s16
+phydm_idle_noise_measurement_ac(
+	struct dm_struct	*dm,
+	u8	is_pause_dig,
+	u8	igi_value,
+	u32	max_time
+	)
+{
+	u32				tmp4b;
+	u8				max_rf_path = 0, rf_path;
+	u8				reg_c50, reg_e50, valid_done = 0;
+	u64				start  = 0, func_start = 0, func_end = 0;
+	struct noise_level	noise_data;
+
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
+
+	if ((dm->rf_type == RF_1T2R) || (dm->rf_type == RF_2T2R))
+		max_rf_path = 2;
+	else
+		max_rf_path = 1;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "phydm_idle_noise_measurement_ac==>\n");
+
+	odm_memory_set(dm, &noise_data, 0, sizeof(struct noise_level));
+
+	/*Step 1. Disable DIG && Set initial gain.*/
+
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	/*Step 2. Get noise power level*/
+	start = odm_get_current_time(dm);
+
+	while (1) {
+		/*Stop updating idle time pwer report (for driver read)*/
+		odm_set_bb_reg(dm, 0x9e4, BIT(30), 0x1);
+
+		/*Read Noise Floor Report*/
+		tmp4b = odm_get_bb_reg(dm, 0xff0, MASKDWORD);
+
+		/*update idle time pwer report per 5us*/
+		odm_set_bb_reg(dm, 0x9e4, BIT(30), 0x0);
+
+		ODM_delay_us(5);
+
+		noise_data.value[RF_PATH_A] = (u8)(tmp4b & 0xff);
+		noise_data.value[RF_PATH_B] = (u8)((tmp4b & 0xff00) >> 8);
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			noise_data.sval[rf_path] = (s8)noise_data.value[rf_path];
+			noise_data.sval[rf_path] = noise_data.sval[rf_path] >> 1;
+		}
+
+		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
+			if (noise_data.valid_cnt[rf_path] >= VALID_CNT)
+				continue;
+
+			noise_data.valid_cnt[rf_path]++;
+			noise_data.sum[rf_path] += noise_data.sval[rf_path];
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Path:%d Valid sval = %d\n", rf_path, noise_data.sval[rf_path]);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d\n", noise_data.sum[rf_path]);
+			if (noise_data.valid_cnt[rf_path] == VALID_CNT)
+				valid_done++;
+		}
+
+		if ((valid_done == max_rf_path) || (odm_get_progressing_time(dm, start) > max_time)) {
+			phydm_set_noise_data_sum(&noise_data, max_rf_path);
+			break;
+		}
+	}
+	reg_c50 = (u8)odm_get_bb_reg(dm, 0xc50, MASKBYTE0);
+	reg_c50 &= ~BIT(7);
+	dm->noise_level.noise[RF_PATH_A] = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
+	dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_A];
+
+	if (max_rf_path == 2) {
+		reg_e50 = (u8)odm_get_bb_reg(dm, 0xe50, MASKBYTE0);
+		reg_e50 &= ~BIT(7);
+		dm->noise_level.noise[RF_PATH_B] = (s8)(-110 + reg_e50 + noise_data.sum[RF_PATH_B]);
+		dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_B];
+	}
+	dm->noise_level.noise_all /= max_rf_path;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "noise_a = %d, noise_b = %d, noise_all = %d\n",
+		dm->noise_level.noise[RF_PATH_A], dm->noise_level.noise[RF_PATH_B],
+		dm->noise_level.noise_all);
+
+	/*Step 3. Recover the Dig*/
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
+	func_end = odm_get_progressing_time(dm, func_start);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "end\n");
+	return dm->noise_level.noise_all;
+
+}
+
+
+s16
+odm_inband_noise_monitor_ac_series(
+	struct dm_struct	*dm,
+	u8 is_pause_dig,
+	u8 igi_value,
+	u32 max_time
+	)
+{
+	s32          rxi_buf_anta, rxq_buf_anta; /*rxi_buf_antb, rxq_buf_antb;*/
+	s32	        value32, pwdb_A = 0, sval, noise, sum = 0;
+	boolean	        pd_flag;
+	u8		valid_cnt = 0;
+	u64	start = 0, func_start = 0, func_end = 0;
+
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+		return phydm_idle_noise_measurement_ac(dm, is_pause_dig, igi_value, max_time);
+
+	if (!(dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A)))
+		return 0;
+
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "odm_inband_noise_monitor_ac_series() ==>\n");
+
+	/* step 1. Disable DIG && Set initial gain. */
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	/* step 3. Get noise power level */
+	start = odm_get_current_time(dm);
+
+	/* step 3. Get noise power level */
+	while (1) {
+		/*Set IGI=0x1C */
+		odm_write_dig(dm, 0x1C);
+		/*stop CK320&CK88 */
+		odm_set_bb_reg(dm, 0x8B4, BIT(6), 1);
+		/*Read path-A */
+		odm_set_bb_reg(dm, 0x8FC, MASKDWORD, 0x200); /*set debug port*/
+		value32 = odm_get_bb_reg(dm, 0xFA0, MASKDWORD); /*read debug port*/
+
+		rxi_buf_anta = (value32 & 0xFFC00) >> 10; /*rxi_buf_anta=RegFA0[19:10]*/
+		rxq_buf_anta = value32 & 0x3FF; /*rxq_buf_anta=RegFA0[19:10]*/
+
+		pd_flag = (boolean)((value32 & BIT(31)) >> 31);
+
+		/*Not in packet detection period or Tx state */
+		if ((!pd_flag) || (rxi_buf_anta != 0x200)) {
+			/*sign conversion*/
+			rxi_buf_anta = odm_sign_conversion(rxi_buf_anta, 10);
+			rxq_buf_anta = odm_sign_conversion(rxq_buf_anta, 10);
+
+			pwdb_A = odm_pwdb_conversion(rxi_buf_anta * rxi_buf_anta + rxq_buf_anta * rxq_buf_anta, 20, 18); /*S(10,9)*S(10,9)=S(20,18)*/
+
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pwdb_A= %d dB, rxi_buf_anta= 0x%x, rxq_buf_anta= 0x%x\n", pwdb_A, rxi_buf_anta & 0x3FF, rxq_buf_anta & 0x3FF);
+		}
+		/*Start CK320&CK88*/
+		odm_set_bb_reg(dm, 0x8B4, BIT(6), 0);
+		/*BB Reset*/
+		odm_write_1byte(dm, 0x02, odm_read_1byte(dm, 0x02) & (~BIT(0)));
+		odm_write_1byte(dm, 0x02, odm_read_1byte(dm, 0x02) | BIT(0));
+		/*PMAC Reset*/
+		odm_write_1byte(dm, 0xB03, odm_read_1byte(dm, 0xB03) & (~BIT(0)));
+		odm_write_1byte(dm, 0xB03, odm_read_1byte(dm, 0xB03) | BIT(0));
+		/*CCK Reset*/
+		if (odm_read_1byte(dm, 0x80B) & BIT(4)) {
+			odm_write_1byte(dm, 0x80B, odm_read_1byte(dm, 0x80B) & (~BIT(4)));
+			odm_write_1byte(dm, 0x80B, odm_read_1byte(dm, 0x80B) | BIT(4));
+		}
+
+		sval = pwdb_A;
+
+		if ((sval < 0 && sval >= -27) && (valid_cnt < VALID_CNT)){
+			valid_cnt++;
+			sum += sval;
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Valid sval = %d\n", sval);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d,\n", sum);
+			if ((valid_cnt >= VALID_CNT) || (odm_get_progressing_time(dm, start) > max_time)) {
+				sum /= VALID_CNT;
+				PHYDM_DBG(dm, DBG_ENV_MNTR, "After divided, sum = %d\n", sum);
+				break;
+			}
+		}
+	}
+
+	/*ADC backoff is 12dB,*/
+	/*Ptarget=0x1C-110=-82dBm*/
+	noise = sum + 12 + 0x1C - 110;
+
+	/*Offset*/
+	noise = noise - 3;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "noise = %d\n", noise);
+	dm->noise_level.noise_all = (s16)noise;
+
+	/* step 4. Recover the Dig*/
+	if (is_pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
+
+	func_end = odm_get_progressing_time(dm, func_start);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "odm_inband_noise_monitor_ac_series() <==\n");
+
+	return dm->noise_level.noise_all;
+}
+
+
+
+s16
+odm_inband_noise_monitor(
+	void *dm_void,
+	u8 is_pause_dig,
+	u8 igi_value,
+	u32 max_time
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	igi_value = 0x32;	/*since HW ability is about +15~-35, we fix IGI = -60 for maximum coverage*/
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		return odm_inband_noise_monitor_ac_series(dm, is_pause_dig, igi_value, max_time);
+	else
+		return odm_inband_noise_monitor_n_series(dm, is_pause_dig, igi_value, max_time);
+}
+
+void
+phydm_noisy_detection(
+	void *dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u32  total_fa_cnt, total_cca_cnt;
+	u32  score = 0, i, score_smooth;
+
+	total_cca_cnt = dm->false_alm_cnt.cnt_cca_all;
+	total_fa_cnt  = dm->false_alm_cnt.cnt_all;
+
+#if 0
+	if (total_fa_cnt * 16 >= total_cca_cnt * 14)    /*  87.5 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 12) /*  75 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 10) /*  56.25 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 8) /*  50 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 7) /*  43.75 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 6) /*  37.5 */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 5) /*  31.25% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 4) /*  25% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 3) /*  18.75% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 2) /*  12.5% */
+		;
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 1) /*  6.25% */
+		;
+#endif
+	for (i = 0; i <= 16; i++) {
+		if (total_fa_cnt * 16 >= total_cca_cnt * (16 - i)) {
+			score = 16 - i;
+			break;
+		}
+	}
+
+	/* noisy_decision_smooth = noisy_decision_smooth>>1 + (score<<3)>>1; */
+	dm->noisy_decision_smooth = (dm->noisy_decision_smooth >> 1) + (score << 2);
+
+	/* Round the noisy_decision_smooth: +"3" comes from (2^3)/2-1 */
+	score_smooth = (total_cca_cnt >= 300) ? ((dm->noisy_decision_smooth + 3) >> 3) : 0;
+
+	dm->noisy_decision = (score_smooth >= 3) ? 1 : 0;
+	
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		"[NoisyDetection] CCA_cnt=%d,FA_cnt=%d, noisy_dec_smooth=%d, score=%d, score_smooth=%d, noisy_dec=%d\n",
+		total_cca_cnt, total_fa_cnt, dm->noisy_decision_smooth, score, score_smooth, dm->noisy_decision);
+
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.h
index 6625be61633a..470432c4ebd7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_noisemonitor.h
@@ -1,49 +1,56 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- *****************************************************************************/
-#ifndef	__ODMNOISEMONITOR_H__
-#define __ODMNOISEMONITOR_H__
-
-#define	ODM_MAX_CHANNEL_NUM					38//14+24
-struct noise_level
-{
-	//u1Byte				value_a, value_b;
-	u1Byte				value[MAX_RF_PATH];
-	//s1Byte				sval_a, sval_b;
-	s1Byte				sval[MAX_RF_PATH];
-	
-	//s4Byte				noise_a=0, noise_b=0,sum_a=0, sum_b=0;
-	//s4Byte				noise[ODM_RF_PATH_MAX];
-	s4Byte				sum[MAX_RF_PATH];
-	//u1Byte				valid_cnt_a=0, valid_cnt_b=0, 
-	u1Byte				valid[MAX_RF_PATH];
-	u1Byte				valid_cnt[MAX_RF_PATH];
-
-};
-
-
-typedef struct _ODM_NOISE_MONITOR_
-{
-	s1Byte			noise[MAX_RF_PATH];
-	s2Byte			noise_all;	
-}ODM_NOISE_MONITOR;
-
-s2Byte ODM_InbandNoise_Monitor(PVOID pDM_VOID,u8 bPauseDIG,u8 IGIValue,u32 max_time);
-
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef	__ODMNOISEMONITOR_H__
+#define __ODMNOISEMONITOR_H__
+
+#define	ODM_MAX_CHANNEL_NUM					38/* 14+24 */
+struct noise_level {
+	u8				value[PHYDM_MAX_RF_PATH];
+	s8				sval[PHYDM_MAX_RF_PATH];
+	s32				sum[PHYDM_MAX_RF_PATH];
+	u8				valid[PHYDM_MAX_RF_PATH];
+	u8				valid_cnt[PHYDM_MAX_RF_PATH];
+};
+
+
+struct odm_noise_monitor {
+	s8			noise[PHYDM_MAX_RF_PATH];
+	s16			noise_all;
+};
+
+s16 odm_inband_noise_monitor(
+	void *dm_void,
+	u8 is_pause_dig,
+	u8 igi_value,
+	u32 max_time
+);
+
+void
+phydm_noisy_detection(
+	void *dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.c
index 433d091e44d1..b2e82db275d2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.c
@@ -1,2311 +1,710 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#if(defined(CONFIG_PATH_DIVERSITY))
-#if RTL8814A_SUPPORT
-
-VOID
-phydm_dtp_fix_tx_path(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte	path
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPATHDIV_T		pDM_PathDiv = &pDM_Odm->DM_PathDiv;
-	u1Byte			i,num_enable_path=0;
-
-	if(path==pDM_PathDiv->pre_tx_path)
-	{
-		return;
-	}
-	else
-	{
-		pDM_PathDiv->pre_tx_path=path;
-	}
-
-	ODM_SetBBReg( pDM_Odm, 0x93c, BIT18|BIT19, 3);
-
-	for(i=0; i<4; i++)
-	{
-		if(path&BIT(i))
-			num_enable_path++;
-	}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Number of trun-on path : (( %d ))\n", num_enable_path));
-
-	if(num_enable_path == 1)
-	{
-		ODM_SetBBReg( pDM_Odm, 0x93c, 0xf00000, path);
-	
-		if(path==PHYDM_A)//1-1
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( A ))\n"));
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT25|BIT24, 0);
-		}
-		else 	if(path==PHYDM_B)//1-2
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( B ))\n"));
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT27|BIT26, 0);
-		}
-		else 	if(path==PHYDM_C)//1-3
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( C ))\n"));
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT29|BIT28, 0);
-
-		}
-		else 	if(path==PHYDM_D)//1-4
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( D ))\n"));
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT31|BIT30, 0);
-		}
-
-	}
-	else 	if(num_enable_path == 2)
-	{
-		ODM_SetBBReg( pDM_Odm, 0x93c, 0xf00000, path);
-		ODM_SetBBReg( pDM_Odm, 0x940, 0xf0, path);
-	
-		if(path==PHYDM_AB)//2-1
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( A B ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT25|BIT24, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT27|BIT26, 1);
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT9|BIT8, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT11|BIT10, 1);			
-		}
-		else 	if(path==PHYDM_AC)//2-2
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( A C ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT25|BIT24, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT29|BIT28, 1);
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT9|BIT8, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT13|BIT12, 1);	
-		}
-		else 	if(path==PHYDM_AD)//2-3
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( A D ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT25|BIT24, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT31|BIT30, 1);
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT9|BIT8, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT15|BIT14, 1);	
-		}
-		else 	if(path==PHYDM_BC)//2-4
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( B C ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT27|BIT26, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT29|BIT28, 1);
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT11|BIT10, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT13|BIT12, 1);	
-		}
-		else 	if(path==PHYDM_BD)//2-5
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( B D ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT27|BIT26, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT31|BIT30, 1);
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT11|BIT10, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT15|BIT14, 1);	
-		}
-		else 	if(path==PHYDM_CD)//2-6
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( C D ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT29|BIT28, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT31|BIT30, 1);
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT13|BIT12, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT15|BIT14, 1);	
-		}
-
-	}
-	else 	if(num_enable_path == 3)
-	{
-		ODM_SetBBReg( pDM_Odm, 0x93c, 0xf00000, path);
-		ODM_SetBBReg( pDM_Odm, 0x940, 0xf0, path);
-		ODM_SetBBReg( pDM_Odm, 0x940, 0xf0000, path);
-	
-		if(path==PHYDM_ABC)//3-1
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( A B C))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT25|BIT24, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT27|BIT26, 1);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT29|BIT28, 2);			
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT9|BIT8, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT11|BIT10, 1);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT13|BIT12, 2);
-			//set for 3ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT21|BIT20, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT23|BIT22, 1);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT25|BIT24, 2);
-		}
-		else 	if(path==PHYDM_ABD)//3-2
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( A B D ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT25|BIT24, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT27|BIT26, 1);		
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT31|BIT30, 2);
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT9|BIT8, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT11|BIT10, 1);		
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT15|BIT14, 2);
-			//set for 3ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT21|BIT20, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT23|BIT22, 1);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT27|BIT26, 2);
-
-		}
-		else 	if(path==PHYDM_ACD)//3-3
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( A C D ))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT25|BIT24, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT29|BIT28, 1);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT31|BIT30, 2);			
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT9|BIT8, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT13|BIT12, 1);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT15|BIT14, 2);
-			//set for 3ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT21|BIT20, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT25|BIT24, 1);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT27|BIT26, 2);
-		}
-		else 	if(path==PHYDM_BCD)//3-4
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path (( B C D))\n"));
-			//set for 1ss
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT27|BIT26, 0);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT29|BIT28, 1);
-			ODM_SetBBReg( pDM_Odm, 0x93c, BIT31|BIT30, 2);			
-			//set for 2ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT11|BIT10, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT13|BIT12, 1);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT15|BIT14, 2);
-			//set for 3ss
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT23|BIT22, 0);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT25|BIT24, 1);
-			ODM_SetBBReg( pDM_Odm, 0x940, BIT27|BIT26, 2);
-		}
-	}
-	else 	if(num_enable_path == 4)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" Trun on path ((A  B C D))\n"));
-	}
-
-}
-
-VOID
-phydm_find_default_path(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPATHDIV_T		pDM_PathDiv = &pDM_Odm->DM_PathDiv;
-	u4Byte	rssi_avg_a=0, rssi_avg_b=0, rssi_avg_c=0, rssi_avg_d=0, rssi_avg_bcd=0;
-	u4Byte	rssi_total_a=0, rssi_total_b=0, rssi_total_c=0, rssi_total_d=0;
-
-	//2 Default Path Selection By RSSI
-
-	rssi_avg_a = (pDM_PathDiv->path_a_cnt_all > 0)? (pDM_PathDiv->path_a_sum_all / pDM_PathDiv->path_a_cnt_all) :0 ;
-	rssi_avg_b = (pDM_PathDiv->path_b_cnt_all > 0)? (pDM_PathDiv->path_b_sum_all / pDM_PathDiv->path_b_cnt_all) :0 ;
-	rssi_avg_c = (pDM_PathDiv->path_c_cnt_all > 0)? (pDM_PathDiv->path_c_sum_all / pDM_PathDiv->path_c_cnt_all) :0 ;
-	rssi_avg_d = (pDM_PathDiv->path_d_cnt_all > 0)? (pDM_PathDiv->path_d_sum_all / pDM_PathDiv->path_d_cnt_all) :0 ;
-
-
-	pDM_PathDiv->path_a_sum_all = 0;
- 	pDM_PathDiv->path_a_cnt_all = 0;
-	pDM_PathDiv->path_b_sum_all = 0;
- 	pDM_PathDiv->path_b_cnt_all = 0;
-	pDM_PathDiv->path_c_sum_all = 0;
- 	pDM_PathDiv->path_c_cnt_all = 0;
-	pDM_PathDiv->path_d_sum_all = 0;
- 	pDM_PathDiv->path_d_cnt_all = 0;
-
-	if(pDM_PathDiv->use_path_a_as_default_ant == 1)
-	{
-		rssi_avg_bcd=(rssi_avg_b+rssi_avg_c+rssi_avg_d)/3;
-
-		if( (rssi_avg_a + ANT_DECT_RSSI_TH) > rssi_avg_bcd  )
-		{
-			pDM_PathDiv->is_pathA_exist=TRUE;
-			pDM_PathDiv->default_path=PATH_A;
-		}
-		else
-		{
-			pDM_PathDiv->is_pathA_exist=FALSE;
-		}
-	}
-	else
-	{
-		if( (rssi_avg_a >=rssi_avg_b) && (rssi_avg_a >=rssi_avg_c)&&(rssi_avg_a >=rssi_avg_d))
-			pDM_PathDiv->default_path=PATH_A;
-		else if(  (rssi_avg_b >=rssi_avg_c)&&(rssi_avg_b >=rssi_avg_d))
-			pDM_PathDiv->default_path=PATH_B;
-		else if(  rssi_avg_c >=rssi_avg_d)
-			pDM_PathDiv->default_path=PATH_C;
-		else
-			pDM_PathDiv->default_path=PATH_D;
-	}
-
-
-}
-
-
-VOID
-phydm_candidate_dtp_update(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPATHDIV_T		pDM_PathDiv = &pDM_Odm->DM_PathDiv;
-
-	pDM_PathDiv->num_candidate=3;
-	
-	if(pDM_PathDiv->use_path_a_as_default_ant == 1)
-	{
-		if(pDM_PathDiv->num_tx_path==3)
-		{
-			if(pDM_PathDiv->is_pathA_exist)
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_ABC; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_ABD; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_ACD;
-			}
-			else // use path BCD 
-			{
-				pDM_PathDiv->num_candidate=1;
-				phydm_dtp_fix_tx_path(pDM_Odm, PHYDM_BCD);
-				return;
-			}
-		}
-		else 	if(pDM_PathDiv->num_tx_path==2)
-		{
-			if(pDM_PathDiv->is_pathA_exist)
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_AB; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_AC; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_AD; 
-			}
-			else
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_BC; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_BD; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_CD; 
-			}	
-		}
-	}
-	else
-	{
-		//2 3 TX Mode 
-		if(pDM_PathDiv->num_tx_path==3)//choose 3 ant form 4 
-		{
-			if(pDM_PathDiv->default_path == PATH_A) //choose 2 ant form 3
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_ABC; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_ABD; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_ACD; 
-			}
-			else if(pDM_PathDiv->default_path==PATH_B)
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_ABC; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_ABD; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_BCD; 
-			}
-			else if(pDM_PathDiv->default_path == PATH_C)
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_ABC; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_ACD; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_BCD; 
-			}
-			else if(pDM_PathDiv->default_path == PATH_D)
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_ABD; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_ACD; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_BCD; 
-			}
-		}
-		
-		//2 2 TX Mode 
-		else if(pDM_PathDiv->num_tx_path==2)//choose 2 ant form 4 
-		{
-			if(pDM_PathDiv->default_path == PATH_A) //choose 2 ant form 3
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_AB; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_AC; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_AD; 
-			}
-			else if(pDM_PathDiv->default_path==PATH_B)
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_AB; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_BC; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_BD; 
-			}
-			else if(pDM_PathDiv->default_path == PATH_C)
-			{
-				pDM_PathDiv->ant_candidate_1 =  PHYDM_AC; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_BC; 
-				pDM_PathDiv->ant_candidate_3 =  PHYDM_CD; 
-			}
-			else if(pDM_PathDiv->default_path == PATH_D)
-			{
-				pDM_PathDiv->ant_candidate_1=  PHYDM_AD; 
-				pDM_PathDiv->ant_candidate_2 =  PHYDM_BD; 
-				pDM_PathDiv->ant_candidate_3=  PHYDM_CD; 
-			}
-		}
-	}
-}
-
-
-VOID
-phydm_dynamic_tx_path(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPATHDIV_T		pDM_PathDiv = &pDM_Odm->DM_PathDiv;	
-	
-	PSTA_INFO_T   	pEntry;
-	u4Byte	i;
-	u1Byte	num_client=0;
-	u1Byte	H2C_Parameter[6] ={0};
-
-
-	if(!pDM_Odm->bLinked) //bLinked==False
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("DTP_8814 [No Link!!!]\n"));
-		
-		if(pDM_PathDiv->bBecomeLinked == TRUE)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" [Be disconnected]----->\n"));
-			pDM_PathDiv->bBecomeLinked = pDM_Odm->bLinked;
-		}
-		return;
-	}	
-	else
-	{
-		if(pDM_PathDiv->bBecomeLinked ==FALSE)
-		{
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, (" [Be Linked !!!]----->\n"));
-			pDM_PathDiv->bBecomeLinked = pDM_Odm->bLinked;
-		}	
-	}	
-	
-	//2 [Period CTRL]
-	if(pDM_PathDiv->dtp_period >=2)
-	{
-		pDM_PathDiv->dtp_period=0;	
-	}
-	else
-	{	
-		//ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("Phydm_Dynamic_Tx_Path_8814A()  Stay = (( %d ))\n",pDM_PathDiv->dtp_period));
-		pDM_PathDiv->dtp_period++;		
-		return;
-	}
-	
-
-	//2 [Fix Path]
-	if (pDM_Odm->path_select != PHYDM_AUTO_PATH)
-	{
-		return;
-	}
-	
-	//2 [Check Bfer]	
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#if (BEAMFORMING_SUPPORT == 1)
-	{
-		BEAMFORMING_CAP		BeamformCap = (pDM_Odm->BeamformingInfo.BeamformCap);
-
-		if( BeamformCap & BEAMFORMER_CAP ) //  BFmer On  &&   Div On ->  Div Off
-		{	
-			if( pDM_PathDiv->fix_path_bfer == 0) 
-			{
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_PATH_DIV,ODM_DBG_LOUD,("[ PathDiv : OFF ]   BFmer ==1  \n"));
-				pDM_PathDiv->fix_path_bfer = 1 ;			
-			}
-			return;
-		}
-		else // BFmer Off   &&   Div Off ->  Div On
-		{
-			if( pDM_PathDiv->fix_path_bfer == 1 ) 
-			{
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_PATH_DIV,ODM_DBG_LOUD,("[ PathDiv : ON ]   BFmer ==0 \n"));
-				pDM_PathDiv->fix_path_bfer = 0;
-			}
-		}
-	}
-	#endif	
-	#endif
-
-	if(pDM_PathDiv->use_path_a_as_default_ant ==1)
-	{
-		phydm_find_default_path(pDM_Odm);
-		phydm_candidate_dtp_update(pDM_Odm);	
-	}
-	else
-	{
-		if( pDM_PathDiv->dtp_state == PHYDM_DTP_INIT)
-		{
-			phydm_find_default_path(pDM_Odm);
-			phydm_candidate_dtp_update(pDM_Odm);
-			pDM_PathDiv->dtp_state = PHYDM_DTP_RUNNING_1;
-		}
-		
-		else 	if( pDM_PathDiv->dtp_state == PHYDM_DTP_RUNNING_1)
-		{
-			pDM_PathDiv->dtp_check_patha_counter++;
-			
-			if(pDM_PathDiv->dtp_check_patha_counter>=NUM_RESET_DTP_PERIOD)
-			{
-				pDM_PathDiv->dtp_check_patha_counter=0;
-				pDM_PathDiv->dtp_state = PHYDM_DTP_INIT;
-			}
-			//2 Search space update		
-			else
-			{
-				// 1.  find the worst candidate
-				
-
-				// 2. repalce the worst candidate
-			}
-		}
-	}
-
-	//2 Dynamic Path Selection H2C
-
-	if(pDM_PathDiv->num_candidate == 1)
-	{
-		return;
-	}
-	else
-	{	
-		H2C_Parameter[0] =  pDM_PathDiv->num_candidate;
-		H2C_Parameter[1] =  pDM_PathDiv->num_tx_path;	
-		H2C_Parameter[2] =  pDM_PathDiv->ant_candidate_1; 
-		H2C_Parameter[3] =  pDM_PathDiv->ant_candidate_2; 
-		H2C_Parameter[4] =  pDM_PathDiv->ant_candidate_3; 
-
-		ODM_FillH2CCmd(pDM_Odm, PHYDM_H2C_DYNAMIC_TX_PATH, 6, H2C_Parameter);
-	}
-
-}
-
-
-
-VOID
-phydm_dynamic_tx_path_init(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPATHDIV_T		pDM_PathDiv  = &(pDM_Odm->DM_PathDiv);
-	PADAPTER		pAdapter = pDM_Odm->Adapter;
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	USB_MODE_MECH	*pUsbModeMech = &pAdapter->UsbModeMechanism;
-	#endif
-	u1Byte 			search_space_2[NUM_CHOOSE2_FROM4]= {PHYDM_AB, PHYDM_AC, PHYDM_AD, PHYDM_BC, PHYDM_BD, PHYDM_CD };
-	u1Byte 			search_space_3[NUM_CHOOSE3_FROM4]= {PHYDM_BCD, PHYDM_ACD,  PHYDM_ABD, PHYDM_ABC};
-
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		pDM_PathDiv->is_u3_mode = (pUsbModeMech->CurUsbMode==USB_MODE_U3)? 1 : 0 ;
-	#else
-		pDM_PathDiv->is_u3_mode = 1;
-	#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("Dynamic TX Path Init 8814\n"));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("is_u3_mode = (( %d ))\n", pDM_PathDiv->is_u3_mode));
-
-	memcpy(&(pDM_PathDiv->search_space_2[0]), &(search_space_2[0]), NUM_CHOOSE2_FROM4);
-	memcpy(&(pDM_PathDiv->search_space_3[0]), &(search_space_3[0]), NUM_CHOOSE3_FROM4);
-
-	pDM_PathDiv->use_path_a_as_default_ant= 1;
-	pDM_PathDiv->dtp_state = PHYDM_DTP_INIT;	
-	pDM_Odm->path_select = PHYDM_AUTO_PATH;
-	pDM_PathDiv->path_div_type = PHYDM_4R_PATH_DIV;
-
-	
-	if(pDM_PathDiv->is_u3_mode )
-	{
-		pDM_PathDiv->num_tx_path=3;
-		phydm_dtp_fix_tx_path(pDM_Odm, PHYDM_BCD);/* 3TX  Set Init TX Path*/
-		
-	}
-	else
-	{
-		pDM_PathDiv->num_tx_path=2;
-		phydm_dtp_fix_tx_path(pDM_Odm, PHYDM_BC);/* 2TX // Set Init TX Path*/
-	}
-	
-}
-
-
-VOID
-phydm_process_rssi_for_path_div(	
-	IN OUT		PVOID			pDM_VOID,	
-	IN			PVOID			p_phy_info_void,
-	IN			PVOID			p_pkt_info_void
-	)
-{
-	PDM_ODM_T			pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_PHY_INFO_T 		pPhyInfo=(PODM_PHY_INFO_T)p_phy_info_void;
-	PODM_PACKET_INFO_T	 pPktinfo=(PODM_PACKET_INFO_T)p_pkt_info_void;
-	pPATHDIV_T			pDM_PathDiv  = &(pDM_Odm->DM_PathDiv);
-
-	if(pPktinfo->bPacketToSelf || pPktinfo->bPacketMatchBSSID)
-	{
-		if(pPktinfo->DataRate > ODM_RATE11M)
-		{
-			if(pDM_PathDiv->path_div_type == PHYDM_4R_PATH_DIV)
-			{
-				#if RTL8814A_SUPPORT
-				if(pDM_Odm->SupportICType & ODM_RTL8814A)
-				{
-					pDM_PathDiv->path_a_sum_all+=pPhyInfo->RxMIMOSignalStrength[0];
-					pDM_PathDiv->path_a_cnt_all++;
-					
-					pDM_PathDiv->path_b_sum_all+=pPhyInfo->RxMIMOSignalStrength[1];
-					pDM_PathDiv->path_b_cnt_all++;
-					
-					pDM_PathDiv->path_c_sum_all+=pPhyInfo->RxMIMOSignalStrength[2];
-					pDM_PathDiv->path_c_cnt_all++;
-					
-					pDM_PathDiv->path_d_sum_all+=pPhyInfo->RxMIMOSignalStrength[3];
-					pDM_PathDiv->path_d_cnt_all++;
-				}
-				#endif
-			}
-			else
-			{
-				pDM_PathDiv->PathA_Sum[pPktinfo->StationID]+=pPhyInfo->RxMIMOSignalStrength[0];
-				pDM_PathDiv->PathA_Cnt[pPktinfo->StationID]++;
-
-				pDM_PathDiv->PathB_Sum[pPktinfo->StationID]+=pPhyInfo->RxMIMOSignalStrength[1];
-				pDM_PathDiv->PathB_Cnt[pPktinfo->StationID]++;
-			}
-		}
-	}
-	
-	
-}
-
-#endif //#if RTL8814A_SUPPORT
-
-VOID
-odm_pathdiv_debug(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value,
-	IN		u4Byte		*_used,
-	OUT		char			*output,
-	IN		u4Byte		*_out_len
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPATHDIV_T			pDM_PathDiv  = &(pDM_Odm->DM_PathDiv);
-	u4Byte used = *_used;
-	u4Byte out_len = *_out_len;
-	
-	pDM_Odm->path_select = (dm_value[0] & 0xf);
-	PHYDM_SNPRINTF((output+used, out_len-used,"Path_select = (( 0x%x ))\n",pDM_Odm->path_select ));
-	
-	//2 [Fix Path]
-	if (pDM_Odm->path_select != PHYDM_AUTO_PATH)
-	{
-		PHYDM_SNPRINTF((output+used, out_len-used,"Trun on path  [%s%s%s%s]\n",
-			((pDM_Odm->path_select) & 0x1)?"A":"",
-			((pDM_Odm->path_select) & 0x2)?"B":"",
-			((pDM_Odm->path_select) & 0x4)?"C":"",
-			((pDM_Odm->path_select) & 0x8)?"D":"" ));
-		
-		phydm_dtp_fix_tx_path( pDM_Odm, pDM_Odm->path_select );
-	}
-	else
-	{
-		PHYDM_SNPRINTF((output+used, out_len-used,"%s\n","Auto Path"));
-	}
-}
-
-#endif // #if(defined(CONFIG_PATH_DIVERSITY))
-
-VOID
-phydm_c2h_dtp_handler(
- IN	PVOID	pDM_VOID,
- IN 	pu1Byte   CmdBuf,
- IN 	u1Byte	CmdLen
-)
-{
-#if(defined(CONFIG_PATH_DIVERSITY))
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pPATHDIV_T		pDM_PathDiv  = &(pDM_Odm->DM_PathDiv);
-
-	u1Byte  macid = CmdBuf[0]; 
-	u1Byte  target = CmdBuf[1];	
-	u1Byte  nsc_1 = CmdBuf[2];
-	u1Byte  nsc_2 = CmdBuf[3];
-	u1Byte  nsc_3 = CmdBuf[4];
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_PATH_DIV,ODM_DBG_LOUD,("Target_candidate = (( %d ))\n", target));
-	/*
-	if( (nsc_1 >= nsc_2) &&  (nsc_1 >= nsc_3))
-	{
-		phydm_dtp_fix_tx_path(pDM_Odm, pDM_PathDiv->ant_candidate_1);
-	}
-	else 	if( nsc_2 >= nsc_3)
-	{
-		phydm_dtp_fix_tx_path(pDM_Odm, pDM_PathDiv->ant_candidate_2);
-	}
-	else
-	{
-		phydm_dtp_fix_tx_path(pDM_Odm, pDM_PathDiv->ant_candidate_3);	
-	}
-	*/
-#endif	
-}
-
-VOID
-odm_PathDiversity(
-	IN	PVOID	pDM_VOID
-)
-{
-#if(defined(CONFIG_PATH_DIVERSITY))
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if(!(pDM_Odm->SupportAbility & ODM_BB_PATH_DIV))
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_PATH_DIV,ODM_DBG_LOUD,("Return: Not Support PathDiv\n"));
-		return;
-	}
-
-	#if RTL8812A_SUPPORT
-
-	if(pDM_Odm->SupportICType & ODM_RTL8812)
-			ODM_PathDiversity_8812A(pDM_Odm);
-		else
-	#endif
-
-	#if RTL8814A_SUPPORT
-		if(pDM_Odm->SupportICType & ODM_RTL8814A)
-			phydm_dynamic_tx_path(pDM_Odm);
-		else
-	#endif
-    		{}
-#endif
-}
-
-VOID
-odm_PathDiversityInit(
-	IN	PVOID	pDM_VOID
-)
-{
-#if(defined(CONFIG_PATH_DIVERSITY))
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	/*pDM_Odm->SupportAbility |= ODM_BB_PATH_DIV;*/
-	
-	if(pDM_Odm->mp_mode == TRUE)
-		return;
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_PATH_DIV))
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_PATH_DIV,ODM_DBG_LOUD,("Return: Not Support PathDiv\n"));
-		return;
-	}
-
-#if RTL8812A_SUPPORT
-		if(pDM_Odm->SupportICType & ODM_RTL8812)
-			ODM_PathDiversityInit_8812A(pDM_Odm);
-		else
-	#endif
-
-	#if RTL8814A_SUPPORT
-		if(pDM_Odm->SupportICType & ODM_RTL8814A)
-			phydm_dynamic_tx_path_init(pDM_Odm);
-		else
-	#endif	
-		{}
-#endif
-}
-
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-//
-// 2011/12/02 MH Copy from MP oursrc for temporarily test.
-//
-#if RTL8192C_SUPPORT
-BOOLEAN
-odm_IsConnected_92C(
-	IN	PADAPTER	Adapter
-)
-{
-	PRT_WLAN_STA	pEntry;
-	PMGNT_INFO		pMgntInfo = &(Adapter->MgntInfo);
-	u4Byte		i;
-	BOOLEAN		bConnected=FALSE;
-	
-	if(pMgntInfo->mAssoc)
-	{
-		bConnected = TRUE;
-	}
-	else
-	{
-		for(i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
-		{
-			if(IsAPModeExist(Adapter)  && GetFirstExtAdapter(Adapter) != NULL)
-				pEntry = AsocEntry_EnumStation(GetFirstExtAdapter(Adapter), i);
-			else
-				pEntry = AsocEntry_EnumStation(GetDefaultAdapter(Adapter), i);
-
-			if(pEntry!=NULL)
-			{
-				if(pEntry->bAssociated)
-				{
-					bConnected = TRUE;
-					break;
-				}
-			}
-			else
-			{
-				break;
-			}
-		}
-	}
-	return	bConnected;
-}
-
-BOOLEAN
-ODM_PathDiversityBeforeLink92C(
-	//IN	PADAPTER	Adapter
-	IN		PDM_ODM_T		pDM_Odm
-	)
-{
-#if (RT_MEM_SIZE_LEVEL != RT_MEM_SIZE_MINIMUM)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE*	pHalData = NULL;
-	PMGNT_INFO		pMgntInfo = NULL;
-	//pSWAT_T		pDM_SWAT_Table = &Adapter->DM_SWAT_Table;
-	pPD_T			pDM_PDTable = NULL;
-
-	s1Byte			Score = 0;
-	PRT_WLAN_BSS	pTmpBssDesc;
-	PRT_WLAN_BSS	pTestBssDesc;
-
-	u1Byte			target_chnl = 0;
-	u2Byte			index;
-
-	if (pDM_Odm->Adapter == NULL)  //For BSOD when plug/unplug fast.  //By YJ,120413
-	{	// The ODM structure is not initialized.
-		return FALSE;
-	}
-	pHalData = GET_HAL_DATA(Adapter);
-	pMgntInfo = &Adapter->MgntInfo;
-	pDM_PDTable = &Adapter->DM_PDTable;
-	
-	// Condition that does not need to use path diversity.
-	if((!(pHalData->CVID_Version==VERSION_1_BEFORE_8703B && IS_92C_SERIAL(pHalData->VersionID))) || (pHalData->PathDivCfg!=1) || pMgntInfo->AntennaTest )
-	{
-		RT_TRACE(COMP_INIT, DBG_LOUD, 
-				("ODM_PathDiversityBeforeLink92C(): No PathDiv Mechanism before link.\n"));
-		return FALSE;
-	}
-
-	// Since driver is going to set BB register, it shall check if there is another thread controlling BB/RF.
-	PlatformAcquireSpinLock(Adapter, RT_RF_STATE_SPINLOCK);
-	if(pHalData->eRFPowerState!=eRfOn || pMgntInfo->RFChangeInProgress || pMgntInfo->bMediaConnect)
-	{
-		PlatformReleaseSpinLock(Adapter, RT_RF_STATE_SPINLOCK);
-	
-		RT_TRACE(COMP_INIT, DBG_LOUD, 
-				("ODM_PathDiversityBeforeLink92C(): RFChangeInProgress(%x), eRFPowerState(%x)\n", 
-				pMgntInfo->RFChangeInProgress,
-				pHalData->eRFPowerState));
-	
-		//pDM_SWAT_Table->SWAS_NoLink_State = 0;
-		pDM_PDTable->PathDiv_NoLink_State = 0;
-		
-		return FALSE;
-	}
-	else
-	{
-		PlatformReleaseSpinLock(Adapter, RT_RF_STATE_SPINLOCK);
-	}
-
-	//1 Run AntDiv mechanism "Before Link" part.
-	//if(pDM_SWAT_Table->SWAS_NoLink_State == 0)
-	if(pDM_PDTable->PathDiv_NoLink_State == 0)
-	{
-		//1 Prepare to do Scan again to check current antenna state.
-
-		// Set check state to next step.
-		//pDM_SWAT_Table->SWAS_NoLink_State = 1;
-		pDM_PDTable->PathDiv_NoLink_State = 1;
-	
-		// Copy Current Scan list.
-		Adapter->MgntInfo.tmpNumBssDesc = pMgntInfo->NumBssDesc;
-		PlatformMoveMemory((PVOID)Adapter->MgntInfo.tmpbssDesc, (PVOID)pMgntInfo->bssDesc, sizeof(RT_WLAN_BSS)*MAX_BSS_DESC);
-
-		// Switch Antenna to another one.
-		if(pDM_PDTable->DefaultRespPath == 0)
-		{
-			PHY_SetBBReg(Adapter, rCCK0_AFESetting  , 0x0F000000, 0x05); // TRX path = PathB
-			odm_SetRespPath_92C(Adapter, 1);
-			pDM_PDTable->OFDMTXPath = 0xFFFFFFFF;
-			pDM_PDTable->CCKTXPath = 0xFFFFFFFF;
-		}
-		else
-		{
-			PHY_SetBBReg(Adapter, rCCK0_AFESetting  , 0x0F000000, 0x00); // TRX path = PathA
-			odm_SetRespPath_92C(Adapter, 0);
-			pDM_PDTable->OFDMTXPath = 0x0;
-			pDM_PDTable->CCKTXPath = 0x0;
-		}
-#if 0	
-
-		pDM_SWAT_Table->PreAntenna = pDM_SWAT_Table->CurAntenna;
-		pDM_SWAT_Table->CurAntenna = (pDM_SWAT_Table->CurAntenna==Antenna_A)?Antenna_B:Antenna_A;
-		
-		RT_TRACE(COMP_INIT, DBG_LOUD, 
-			("ODM_SwAntDivCheckBeforeLink: Change to Ant(%s) for testing.\n", (pDM_SWAT_Table->CurAntenna==Antenna_A)?"A":"B"));
-		//PHY_SetBBReg(Adapter, rFPGA0_XA_RFInterfaceOE, 0x300, DM_SWAT_Table.CurAntenna);
-		pDM_SWAT_Table->SWAS_NoLink_BK_Reg860 = ((pDM_SWAT_Table->SWAS_NoLink_BK_Reg860 & 0xfffffcff) | (pDM_SWAT_Table->CurAntenna<<8));
-		PHY_SetBBReg(Adapter, rFPGA0_XA_RFInterfaceOE, bMaskDWord, pDM_SWAT_Table->SWAS_NoLink_BK_Reg860);
-#endif
-
-		// Go back to scan function again.
-		RT_TRACE(COMP_INIT, DBG_LOUD, ("ODM_PathDiversityBeforeLink92C: Scan one more time\n"));
-		pMgntInfo->ScanStep=0;
-		target_chnl = odm_SwAntDivSelectScanChnl(Adapter);
-		odm_SwAntDivConstructScanChnl(Adapter, target_chnl);
-		PlatformSetTimer(Adapter, &pMgntInfo->ScanTimer, 5);
-
-		return TRUE;
-	}
-	else
-	{
-		//1 ScanComple() is called after antenna swiched.
-		//1 Check scan result and determine which antenna is going
-		//1 to be used.
-
-		for(index=0; index<Adapter->MgntInfo.tmpNumBssDesc; index++)
-		{
-			pTmpBssDesc = &(Adapter->MgntInfo.tmpbssDesc[index]);
-			pTestBssDesc = &(pMgntInfo->bssDesc[index]);
-
-			if(PlatformCompareMemory(pTestBssDesc->bdBssIdBuf, pTmpBssDesc->bdBssIdBuf, 6)!=0)
-			{
-				RT_TRACE(COMP_INIT, DBG_LOUD, ("ODM_PathDiversityBeforeLink92C(): ERROR!! This shall not happen.\n"));
-				continue;
-			}
-
-			if(pTmpBssDesc->RecvSignalPower > pTestBssDesc->RecvSignalPower)
-			{
-				RT_TRACE(COMP_INIT, DBG_LOUD, ("ODM_PathDiversityBeforeLink92C: Compare scan entry: Score++\n"));
-				RT_PRINT_STR(COMP_INIT, DBG_LOUD, "SSID: ", pTestBssDesc->bdSsIdBuf, pTestBssDesc->bdSsIdLen);
-				RT_TRACE(COMP_INIT, DBG_LOUD, ("Original: %d, Test: %d\n", pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-			
-				Score++;
-				PlatformMoveMemory(pTestBssDesc, pTmpBssDesc, sizeof(RT_WLAN_BSS));
-			}
-			else if(pTmpBssDesc->RecvSignalPower < pTestBssDesc->RecvSignalPower)
-			{
-				RT_TRACE(COMP_INIT, DBG_LOUD, ("ODM_PathDiversityBeforeLink92C: Compare scan entry: Score--\n"));
-				RT_PRINT_STR(COMP_INIT, DBG_LOUD, "SSID: ", pTestBssDesc->bdSsIdBuf, pTestBssDesc->bdSsIdLen);
-				RT_TRACE(COMP_INIT, DBG_LOUD, ("Original: %d, Test: %d\n", pTmpBssDesc->RecvSignalPower, pTestBssDesc->RecvSignalPower));
-				Score--;
-			}
-
-		}
-
-		if(pMgntInfo->NumBssDesc!=0 && Score<=0)
-		{
-			RT_TRACE(COMP_INIT, DBG_LOUD,
-				("ODM_PathDiversityBeforeLink92C(): DefaultRespPath=%d\n", pDM_PDTable->DefaultRespPath));
-
-			//pDM_SWAT_Table->PreAntenna = pDM_SWAT_Table->CurAntenna;
-		}
-		else
-		{
-			RT_TRACE(COMP_INIT, DBG_LOUD, 
-				("ODM_PathDiversityBeforeLink92C(): DefaultRespPath=%d\n", pDM_PDTable->DefaultRespPath));
-
-			if(pDM_PDTable->DefaultRespPath == 0)
-			{
-				pDM_PDTable->OFDMTXPath = 0xFFFFFFFF;
-				pDM_PDTable->CCKTXPath = 0xFFFFFFFF;
-				odm_SetRespPath_92C(Adapter, 1);
-			}
-			else
-			{
-				pDM_PDTable->OFDMTXPath = 0x0;
-				pDM_PDTable->CCKTXPath = 0x0;
-				odm_SetRespPath_92C(Adapter, 0);
-			}
-			PHY_SetBBReg(Adapter, rCCK0_AFESetting  , 0x0F000000, 0x01); // RX path = PathAB
-
-			//pDM_SWAT_Table->CurAntenna = pDM_SWAT_Table->PreAntenna;
-
-			//PHY_SetBBReg(Adapter, rFPGA0_XA_RFInterfaceOE, 0x300, DM_SWAT_Table.CurAntenna);
-			//pDM_SWAT_Table->SWAS_NoLink_BK_Reg860 = ((pDM_SWAT_Table->SWAS_NoLink_BK_Reg860 & 0xfffffcff) | (pDM_SWAT_Table->CurAntenna<<8));
-			//PHY_SetBBReg(Adapter, rFPGA0_XA_RFInterfaceOE, bMaskDWord, pDM_SWAT_Table->SWAS_NoLink_BK_Reg860);
-		}
-
-		// Check state reset to default and wait for next time.
-		//pDM_SWAT_Table->SWAS_NoLink_State = 0;
-		pDM_PDTable->PathDiv_NoLink_State = 0;
-
-		return FALSE;
-	}
-#else
-		return	FALSE;
-#endif
-	
-}
-
-
-
-VOID
-odm_PathDiversityAfterLink_92C(
-	IN	PADAPTER	Adapter
-)
-{
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	pPD_T		pDM_PDTable = &Adapter->DM_PDTable;
-	u1Byte		DefaultRespPath=0;
-
-	if((!(pHalData->CVID_Version==VERSION_1_BEFORE_8703B && IS_92C_SERIAL(pHalData->VersionID))) || (pHalData->PathDivCfg != 1) || (pHalData->eRFPowerState == eRfOff))
-	{
-		if(pHalData->PathDivCfg == 0)
-		{
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("No ODM_TXPathDiversity()\n"));
-		}
-		else
-		{
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("2T ODM_TXPathDiversity()\n"));
-		}
-		return;
-	}
-	if(!odm_IsConnected_92C(Adapter))
-	{
-		RT_TRACE(	COMP_INIT, DBG_LOUD, ("ODM_TXPathDiversity(): No Connections\n"));
-		return;
-	}
-	
-	
-	if(pDM_PDTable->TrainingState == 0)
-	{
-		RT_TRACE(	COMP_INIT, DBG_LOUD, ("ODM_TXPathDiversity() ==>\n"));
-		odm_OFDMTXPathDiversity_92C(Adapter);
-
-		if((pDM_PDTable->CCKPathDivEnable == TRUE) && (pDM_PDTable->OFDM_Pkt_Cnt < 100))
-		{
-			//RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: TrainingState=0\n"));
-			
-			if(pDM_PDTable->CCK_Pkt_Cnt > 300)
-				pDM_PDTable->Timer = 20;
-			else if(pDM_PDTable->CCK_Pkt_Cnt > 100)
-				pDM_PDTable->Timer = 60;
-			else
-				pDM_PDTable->Timer = 250;
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: timer=%d\n",pDM_PDTable->Timer));
-
-			PHY_SetBBReg(Adapter, rCCK0_AFESetting  , 0x0F000000, 0x00); // RX path = PathA
-			pDM_PDTable->TrainingState = 1;
-			ODM_SetTimer( pDM_Odm, &pDM_Odm->CCKPathDiversityTimer, pDM_PDTable->Timer); //ms
-		}
-		else
-		{
-			pDM_PDTable->CCKTXPath = pDM_PDTable->OFDMTXPath;
-			DefaultRespPath = pDM_PDTable->OFDMDefaultRespPath;
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_SetRespPath_92C: Skip odm_CCKTXPathDiversity_92C, DefaultRespPath is OFDM\n"));
-			odm_SetRespPath_92C(Adapter, DefaultRespPath);
-			odm_ResetPathDiversity_92C(Adapter);
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("ODM_TXPathDiversity() <==\n"));
-		}
-	}
-	else if(pDM_PDTable->TrainingState == 1)
-	{		
-		//RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: TrainingState=1\n"));
-		PHY_SetBBReg(Adapter, rCCK0_AFESetting  , 0x0F000000, 0x05); // RX path = PathB
-		pDM_PDTable->TrainingState = 2;
-		ODM_SetTimer( pDM_Odm, &pDM_Odm->CCKPathDiversityTimer, pDM_PDTable->Timer); //ms
-	}
-	else
-	{
-		//RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: TrainingState=2\n"));
-		pDM_PDTable->TrainingState = 0;	
-		odm_CCKTXPathDiversity_92C(Adapter); 
-		if(pDM_PDTable->OFDM_Pkt_Cnt != 0)
-		{
-			DefaultRespPath = pDM_PDTable->OFDMDefaultRespPath;
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_SetRespPath_92C: DefaultRespPath is OFDM\n"));
-		}
-		else
-		{
-			DefaultRespPath = pDM_PDTable->CCKDefaultRespPath;
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_SetRespPath_92C: DefaultRespPath is CCK\n"));
-		}
-		odm_SetRespPath_92C(Adapter, DefaultRespPath);
-		odm_ResetPathDiversity_92C(Adapter);
-		RT_TRACE(	COMP_INIT, DBG_LOUD, ("ODM_TXPathDiversity() <==\n"));
-	}
-
-}
-
-VOID
-odm_SetRespPath_92C(
-	IN	PADAPTER	Adapter,
-	IN	u1Byte	DefaultRespPath
-	)
-{
-	pPD_T	pDM_PDTable = &Adapter->DM_PDTable;
-
-	RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_SetRespPath_92C: Select Response Path=%d\n",DefaultRespPath));
-	if(DefaultRespPath != pDM_PDTable->DefaultRespPath)
-	{
-		if(DefaultRespPath == 0)
-		{
-			PlatformEFIOWrite1Byte(Adapter, 0x6D8, (PlatformEFIORead1Byte(Adapter, 0x6D8)&0xc0)|0x15);	
-		}
-		else
-		{
-			PlatformEFIOWrite1Byte(Adapter, 0x6D8, (PlatformEFIORead1Byte(Adapter, 0x6D8)&0xc0)|0x2A);
-		}	
-	}
-	pDM_PDTable->DefaultRespPath = DefaultRespPath;
-}
-
-VOID
-odm_OFDMTXPathDiversity_92C(
-	IN	PADAPTER	Adapter)
-{
-//	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	PMGNT_INFO		pMgntInfo = &(Adapter->MgntInfo);
-	PRT_WLAN_STA	pEntry;
-	u1Byte	i, DefaultRespPath = 0;
-	s4Byte	MinRSSI = 0xFF;
-	pPD_T	pDM_PDTable = &Adapter->DM_PDTable;
-	pDM_PDTable->OFDMTXPath = 0;
-	
-	//1 Default Port
-	if(pMgntInfo->mAssoc)
-	{
-		RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_OFDMTXPathDiversity_92C: Default port RSSI[0]=%d, RSSI[1]=%d\n",
-			Adapter->RxStats.RxRSSIPercentage[0], Adapter->RxStats.RxRSSIPercentage[1]));
-		if(Adapter->RxStats.RxRSSIPercentage[0] > Adapter->RxStats.RxRSSIPercentage[1])
-		{
-			pDM_PDTable->OFDMTXPath = pDM_PDTable->OFDMTXPath & (~BIT0);
-			MinRSSI =  Adapter->RxStats.RxRSSIPercentage[1];
-			DefaultRespPath = 0;
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_OFDMTXPathDiversity_92C: Default port Select Path-0\n"));
-		}
-		else
-		{
-			pDM_PDTable->OFDMTXPath =  pDM_PDTable->OFDMTXPath | BIT0;
-			MinRSSI =  Adapter->RxStats.RxRSSIPercentage[0];
-			DefaultRespPath = 1;
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_OFDMTXPathDiversity_92C: Default port Select Path-1\n"));
-		}
-			//RT_TRACE(	COMP_INIT, DBG_LOUD, ("pDM_PDTable->OFDMTXPath =0x%x\n",pDM_PDTable->OFDMTXPath));
-	}
-	//1 Extension Port
-	for(i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
-	{
-		if(IsAPModeExist(Adapter)  && GetFirstExtAdapter(Adapter) != NULL)
-			pEntry = AsocEntry_EnumStation(GetFirstExtAdapter(Adapter), i);
-		else
-			pEntry = AsocEntry_EnumStation(GetDefaultAdapter(Adapter), i);
-
-		if(pEntry!=NULL)
-		{
-			if(pEntry->bAssociated)
-			{
-				RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_OFDMTXPathDiversity_92C: MACID=%d, RSSI_0=%d, RSSI_1=%d\n", 
-					pEntry->AssociatedMacId, pEntry->rssi_stat.RxRSSIPercentage[0], pEntry->rssi_stat.RxRSSIPercentage[1]));
-				
-				if(pEntry->rssi_stat.RxRSSIPercentage[0] > pEntry->rssi_stat.RxRSSIPercentage[1])
-				{
-					pDM_PDTable->OFDMTXPath = pDM_PDTable->OFDMTXPath & ~(BIT(pEntry->AssociatedMacId));
-					//pHalData->TXPath = pHalData->TXPath & ~(1<<(pEntry->AssociatedMacId));
-					RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_OFDMTXPathDiversity_92C: MACID=%d Select Path-0\n", pEntry->AssociatedMacId));
-					if(pEntry->rssi_stat.RxRSSIPercentage[1] < MinRSSI)
-					{
-						MinRSSI = pEntry->rssi_stat.RxRSSIPercentage[1];
-						DefaultRespPath = 0;
-					}
-				}
-				else
-				{
-					pDM_PDTable->OFDMTXPath = pDM_PDTable->OFDMTXPath | BIT(pEntry->AssociatedMacId);
-					//pHalData->TXPath = pHalData->TXPath | (1 << (pEntry->AssociatedMacId));
-					RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_OFDMTXPathDiversity_92C: MACID=%d Select Path-1\n", pEntry->AssociatedMacId));
-					if(pEntry->rssi_stat.RxRSSIPercentage[0] < MinRSSI)
-					{
-						MinRSSI = pEntry->rssi_stat.RxRSSIPercentage[0];
-						DefaultRespPath = 1;
-					}
-				}
-			}
-		}
-		else
-		{
-			break;
-		}
-	}
-
-	pDM_PDTable->OFDMDefaultRespPath = DefaultRespPath;
-}
-
-
-VOID
-odm_CCKTXPathDiversity_92C(
-	IN	PADAPTER	Adapter
-)
-{
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	PMGNT_INFO		pMgntInfo = &(Adapter->MgntInfo);
-	PRT_WLAN_STA	pEntry;
-	s4Byte	MinRSSI = 0xFF;
-	u1Byte	i, DefaultRespPath = 0;
-//	BOOLEAN	bBModePathDiv = FALSE;
-	pPD_T	pDM_PDTable = &Adapter->DM_PDTable;
-
-	//1 Default Port
-	if(pMgntInfo->mAssoc)
-	{
-		if(pHalData->OFDM_Pkt_Cnt == 0)
-		{
-			for(i=0; i<2; i++)
-			{
-				if(pDM_PDTable->RSSI_CCK_Path_cnt[i] > 1) //Because the first packet is discarded
-					pDM_PDTable->RSSI_CCK_Path[i] = pDM_PDTable->RSSI_CCK_Path[i] / (pDM_PDTable->RSSI_CCK_Path_cnt[i]-1);
-				else
-					pDM_PDTable->RSSI_CCK_Path[i] = 0;
-			}
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: pDM_PDTable->RSSI_CCK_Path[0]=%d, pDM_PDTable->RSSI_CCK_Path[1]=%d\n",
-				pDM_PDTable->RSSI_CCK_Path[0], pDM_PDTable->RSSI_CCK_Path[1]));
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: pDM_PDTable->RSSI_CCK_Path_cnt[0]=%d, pDM_PDTable->RSSI_CCK_Path_cnt[1]=%d\n",
-				pDM_PDTable->RSSI_CCK_Path_cnt[0], pDM_PDTable->RSSI_CCK_Path_cnt[1]));
-		
-			if(pDM_PDTable->RSSI_CCK_Path[0] > pDM_PDTable->RSSI_CCK_Path[1])
-			{
-				pDM_PDTable->CCKTXPath = pDM_PDTable->CCKTXPath & (~BIT0);
-				MinRSSI =  pDM_PDTable->RSSI_CCK_Path[1];
-				DefaultRespPath = 0;
-				RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: Default port Select CCK Path-0\n"));
-			}
-			else if(pDM_PDTable->RSSI_CCK_Path[0] < pDM_PDTable->RSSI_CCK_Path[1])
-			{
-				pDM_PDTable->CCKTXPath =  pDM_PDTable->CCKTXPath | BIT0;
-				MinRSSI =  pDM_PDTable->RSSI_CCK_Path[0];
-				DefaultRespPath = 1;
-				RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: Default port Select CCK Path-1\n"));
-			}
-			else
-			{
-				if((pDM_PDTable->RSSI_CCK_Path[0] != 0) && (pDM_PDTable->RSSI_CCK_Path[0] < MinRSSI))
-				{
-					pDM_PDTable->CCKTXPath = pDM_PDTable->CCKTXPath & (~BIT0);
-					RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: Default port Select CCK Path-0\n"));
-					MinRSSI =  pDM_PDTable->RSSI_CCK_Path[1];
-					DefaultRespPath = 0;
-				}
-				else
-				{
-					RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: Default port unchange CCK Path\n"));
-				}
-			}
-		}
-		else //Follow OFDM decision
-		{
-			pDM_PDTable->CCKTXPath = (pDM_PDTable->CCKTXPath & (~BIT0)) | (pDM_PDTable->OFDMTXPath &BIT0);
-			RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: Follow OFDM decision, Default port Select CCK Path-%d\n",
-				pDM_PDTable->CCKTXPath &BIT0));
-		}
-	}
-	//1 Extension Port
-	for(i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
-	{
-		if(IsAPModeExist(Adapter)  && GetFirstExtAdapter(Adapter) != NULL)
-			pEntry = AsocEntry_EnumStation(GetFirstExtAdapter(Adapter), i);
-		else
-			pEntry = AsocEntry_EnumStation(GetDefaultAdapter(Adapter), i);
-
-		if(pEntry!=NULL)
-		{
-			if(pEntry->bAssociated)
-			{
-				if(pEntry->rssi_stat.OFDM_Pkt_Cnt == 0)
-				{
-					u1Byte j=0;
-					for(j=0; j<2; j++)
-					{
-						if(pEntry->rssi_stat.RSSI_CCK_Path_cnt[j] > 1)
-							pEntry->rssi_stat.RSSI_CCK_Path[j] = pEntry->rssi_stat.RSSI_CCK_Path[j] / (pEntry->rssi_stat.RSSI_CCK_Path_cnt[j]-1);
-						else
-							pEntry->rssi_stat.RSSI_CCK_Path[j] = 0;
-					}
-					RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: MACID=%d, RSSI_CCK0=%d, RSSI_CCK1=%d\n", 
-						pEntry->AssociatedMacId, pEntry->rssi_stat.RSSI_CCK_Path[0], pEntry->rssi_stat.RSSI_CCK_Path[1]));
-					
-					if(pEntry->rssi_stat.RSSI_CCK_Path[0] >pEntry->rssi_stat.RSSI_CCK_Path[1])
-					{
-						pDM_PDTable->CCKTXPath = pDM_PDTable->CCKTXPath & ~(BIT(pEntry->AssociatedMacId));
-						RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: MACID=%d Select CCK Path-0\n", pEntry->AssociatedMacId));
-						if(pEntry->rssi_stat.RSSI_CCK_Path[1] < MinRSSI)
-						{
-							MinRSSI = pEntry->rssi_stat.RSSI_CCK_Path[1];
-							DefaultRespPath = 0;
-						}
-					}
-					else if(pEntry->rssi_stat.RSSI_CCK_Path[0] <pEntry->rssi_stat.RSSI_CCK_Path[1])
-					{
-						pDM_PDTable->CCKTXPath = pDM_PDTable->CCKTXPath | BIT(pEntry->AssociatedMacId);
-						RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: MACID=%d Select CCK Path-1\n", pEntry->AssociatedMacId));
-						if(pEntry->rssi_stat.RSSI_CCK_Path[0] < MinRSSI)
-						{
-							MinRSSI = pEntry->rssi_stat.RSSI_CCK_Path[0];
-							DefaultRespPath = 1;
-						}
-					}
-					else
-					{
-						if((pEntry->rssi_stat.RSSI_CCK_Path[0] != 0) && (pEntry->rssi_stat.RSSI_CCK_Path[0] < MinRSSI))
-						{
-							pDM_PDTable->CCKTXPath = pDM_PDTable->CCKTXPath & ~(BIT(pEntry->AssociatedMacId));
-							MinRSSI = pEntry->rssi_stat.RSSI_CCK_Path[1];
-							DefaultRespPath = 0;
-							RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: MACID=%d Select CCK Path-0\n", pEntry->AssociatedMacId));
-						}
-						else
-						{
-							RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: MACID=%d unchange CCK Path\n", pEntry->AssociatedMacId));
-						}
-					}
-				}
-				else //Follow OFDM decision
-				{
-					pDM_PDTable->CCKTXPath = (pDM_PDTable->CCKTXPath & (~(BIT(pEntry->AssociatedMacId)))) | (pDM_PDTable->OFDMTXPath & BIT(pEntry->AssociatedMacId));
-					RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C: Follow OFDM decision, MACID=%d Select CCK Path-%d\n",
-						pEntry->AssociatedMacId, (pDM_PDTable->CCKTXPath & BIT(pEntry->AssociatedMacId))>>(pEntry->AssociatedMacId)));
-				}
-			}
-		}
-		else
-		{
-			break;
-		}
-	}
-
-	RT_TRACE(	COMP_INIT, DBG_LOUD, ("odm_CCKTXPathDiversity_92C:MinRSSI=%d\n",MinRSSI));
-
-	if(MinRSSI == 0xFF)
-		DefaultRespPath = pDM_PDTable->CCKDefaultRespPath;
-
-	pDM_PDTable->CCKDefaultRespPath = DefaultRespPath;
-}
-
-
-VOID
-odm_ResetPathDiversity_92C(
-		IN	PADAPTER	Adapter
-)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	pPD_T	pDM_PDTable = &Adapter->DM_PDTable;
-	PRT_WLAN_STA	pEntry;
-	u4Byte	i,j;
-
-	pDM_PDTable->CCK_Pkt_Cnt = 0;
-	pDM_PDTable->OFDM_Pkt_Cnt = 0;
-	pHalData->CCK_Pkt_Cnt =0;
-	pHalData->OFDM_Pkt_Cnt =0;
-	
-	if(pDM_PDTable->CCKPathDivEnable == TRUE)	
-		PHY_SetBBReg(Adapter, rCCK0_AFESetting  , 0x0F000000, 0x01); //RX path = PathAB
-
-	for(i=0; i<2; i++)
-	{
-		pDM_PDTable->RSSI_CCK_Path_cnt[i]=0;
-		pDM_PDTable->RSSI_CCK_Path[i] = 0;
-	}
-	for(i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
-	{
-		if(IsAPModeExist(Adapter)  && GetFirstExtAdapter(Adapter) != NULL)
-			pEntry = AsocEntry_EnumStation(GetFirstExtAdapter(Adapter), i);
-		else
-			pEntry = AsocEntry_EnumStation(GetDefaultAdapter(Adapter), i);
-
-		if(pEntry!=NULL)
-		{
-			pEntry->rssi_stat.CCK_Pkt_Cnt = 0;
-			pEntry->rssi_stat.OFDM_Pkt_Cnt = 0;
-			for(j=0; j<2; j++)
-			{
-				pEntry->rssi_stat.RSSI_CCK_Path_cnt[j] = 0;
-				pEntry->rssi_stat.RSSI_CCK_Path[j] = 0;
-			}
-		}
-		else
-			break;
-	}
-}
-
-
-
-
-
-VOID
-odm_CCKTXPathDiversityCallback(
-	PRT_TIMER		pTimer
-)
-{
-#if USE_WORKITEM
-       PADAPTER	Adapter = (PADAPTER)pTimer->Adapter;
-       HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	   PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PADAPTER	Adapter = (PADAPTER)pTimer->Adapter;
-#endif
-
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-#if USE_WORKITEM
-	PlatformScheduleWorkItem(&pDM_Odm->CCKPathDiversityWorkitem);
-#else
-	odm_PathDiversityAfterLink_92C(Adapter);
-#endif
-#else
-	PlatformScheduleWorkItem(&pDM_Odm->CCKPathDiversityWorkitem);
-#endif
-
-}
-
-
-VOID
-odm_CCKTXPathDiversityWorkItemCallback(
-    IN PVOID            pContext
-    )
-{
-	PADAPTER	Adapter = (PADAPTER)pContext;
-
-	odm_CCKTXPathDiversity_92C(Adapter);
-}
-
-//
-// 20100514 Luke/Joseph:
-// Callback function for 500ms antenna test trying.
-//
-VOID
-odm_PathDivChkAntSwitchCallback(
-	PRT_TIMER		pTimer
-)
-{
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-
-#if USE_WORKITEM
-	PlatformScheduleWorkItem(&pDM_Odm->PathDivSwitchWorkitem);
-#else
-	odm_PathDivChkAntSwitch(pDM_Odm);
-#endif
-#else
-	PlatformScheduleWorkItem(&pDM_Odm->PathDivSwitchWorkitem);
-#endif
-
-//odm_SwAntDivChkAntSwitch(Adapter, SWAW_STEP_DETERMINE);
-
-}
-
-
-VOID
-odm_PathDivChkAntSwitchWorkitemCallback(
-    IN PVOID            pContext
-    )
-{
-	PADAPTER	pAdapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	odm_PathDivChkAntSwitch(pDM_Odm);
-}
-
-
- //MAC0_ACCESS_PHY1
-
-// 2011-06-22 Neil Chen & Gary Hsin
-// Refer to Jr.Luke's SW ANT DIV
-// 92D Path Diversity Main function
-// refer to 88C software antenna diversity
-// 
-VOID
-odm_PathDivChkAntSwitch(
-	PDM_ODM_T		pDM_Odm
-	//PADAPTER		Adapter,
-	//u1Byte			Step
-)
-{
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PMGNT_INFO		pMgntInfo = &Adapter->MgntInfo;
-
-
-	pSWAT_T			pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-	s4Byte			curRSSI=100, RSSI_A, RSSI_B;
-	u1Byte			nextAntenna=AUX_ANT;
-	static u8Byte		lastTxOkCnt=0, lastRxOkCnt=0;
-	u8Byte			curTxOkCnt, curRxOkCnt;
-	static u8Byte		TXByteCnt_A=0, TXByteCnt_B=0, RXByteCnt_A=0, RXByteCnt_B=0;
-	u8Byte			CurByteCnt=0, PreByteCnt=0;
-	static u1Byte		TrafficLoad = TRAFFIC_LOW;
-	u1Byte			Score_A=0, Score_B=0;
-	u1Byte			i=0x0;
-       // Neil Chen
-       static u1Byte        pathdiv_para=0x0;     
-       static u1Byte        switchfirsttime=0x00;
-	// u1Byte                 regB33 = (u1Byte) PHY_QueryBBReg(Adapter, 0xB30,BIT27);
-	u1Byte			regB33 = (u1Byte)ODM_GetBBReg(pDM_Odm, PATHDIV_REG, BIT27);
-
-
-       //u1Byte                 reg637 =0x0;   
-       static u1Byte        fw_value=0x0;         
-	//u8Byte			curTxOkCnt_tmp, curRxOkCnt_tmp;
-       PADAPTER            BuddyAdapter = Adapter->BuddyAdapter;     // another adapter MAC
-        // Path Diversity   //Neil Chen--2011--06--22
-
-	//u1Byte                 PathDiv_Trigger = (u1Byte) PHY_QueryBBReg(Adapter, 0xBA0,BIT31);
-	u1Byte                 PathDiv_Trigger = (u1Byte) ODM_GetBBReg(pDM_Odm, PATHDIV_TRI,BIT31);
-	u1Byte                 PathDiv_Enable = pHalData->bPathDiv_Enable;
-
-
-	//DbgPrint("Path Div PG Value:%x \n",PathDiv_Enable);	
-       if((BuddyAdapter==NULL)||(!PathDiv_Enable)||(PathDiv_Trigger)||(pHalData->CurrentBandType == BAND_ON_2_4G))
-       {
-           return;
-       }
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD,("===================>odm_PathDivChkAntSwitch()\n"));
-
-       // The first time to switch path excluding 2nd, 3rd, ....etc....
-	if(switchfirsttime==0)
-	{
-	    if(regB33==0)
-	    {
-	       pDM_SWAT_Table->CurAntenna = MAIN_ANT;    // Default MAC0_5G-->Path A (current antenna)     
-	    }	    
-	}
-
-	// Condition that does not need to use antenna diversity.
-	if(pDM_Odm->SupportICType != ODM_RTL8192D)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("odm_PathDiversityMechanims(): No PathDiv Mechanism.\n"));
-		return;
-	}
-
-	// Radio off: Status reset to default and return.
-	if(pHalData->eRFPowerState==eRfOff)
-	{
-		//ODM_SwAntDivRestAfterLink(Adapter);
-		return;
-	}
-
-       /*
-	// Handling step mismatch condition.
-	// Peak step is not finished at last time. Recover the variable and check again.
-	if(	Step != pDM_SWAT_Table->try_flag	)
-	{
-		ODM_SwAntDivRestAfterLink(Adapter);
-	} */
-	
-	if(pDM_SWAT_Table->try_flag == 0xff)
-	{
-		// Select RSSI checking target
-		if(pMgntInfo->mAssoc && !ACTING_AS_AP(Adapter))
-		{
-			// Target: Infrastructure mode AP.
-			pHalData->RSSI_target = NULL;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("odm_PathDivMechanism(): RSSI_target is DEF AP!\n"));
-		}
-		else
-		{
-			u1Byte			index = 0;
-			PRT_WLAN_STA	pEntry = NULL;
-			PADAPTER		pTargetAdapter = NULL;
-		
-			if(	pMgntInfo->mIbss || ACTING_AS_AP(Adapter) )
-			{
-				// Target: AP/IBSS peer.
-				pTargetAdapter = Adapter;
-			}
-			else if(IsAPModeExist(Adapter)  && GetFirstExtAdapter(Adapter) != NULL)
-			{
-				// Target: VWIFI peer.
-				pTargetAdapter = GetFirstExtAdapter(Adapter);
-			}
-
-			if(pTargetAdapter != NULL)
-			{
-				for(index=0; index<ODM_ASSOCIATE_ENTRY_NUM; index++)
-				{
-					pEntry = AsocEntry_EnumStation(pTargetAdapter, index);
-					if(pEntry != NULL)
-					{
-						if(pEntry->bAssociated)
-							break;			
-					}
-				}
-			}
-
-			if(pEntry == NULL)
-			{
-				ODM_PathDivRestAfterLink(pDM_Odm);
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("odm_SwAntDivChkAntSwitch(): No Link.\n"));
-				return;
-			}
-			else
-			{
-				pHalData->RSSI_target = pEntry;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("odm_SwAntDivChkAntSwitch(): RSSI_target is PEER STA\n"));
-			}
-		}
-			
-		pHalData->RSSI_cnt_A = 0;
-		pHalData->RSSI_cnt_B = 0;
-		pDM_SWAT_Table->try_flag = 0;
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("odm_SwAntDivChkAntSwitch(): Set try_flag to 0 prepare for peak!\n"));
-		return;
-	}
-	else
-	{
-	       // 1st step
-		curTxOkCnt = Adapter->TxStats.NumTxBytesUnicast - lastTxOkCnt;
-		curRxOkCnt = Adapter->RxStats.NumRxBytesUnicast - lastRxOkCnt;
-		lastTxOkCnt = Adapter->TxStats.NumTxBytesUnicast;
-		lastRxOkCnt = Adapter->RxStats.NumRxBytesUnicast;
-	
-		if(pDM_SWAT_Table->try_flag == 1)   // Training State
-		{
-			if(pDM_SWAT_Table->CurAntenna == MAIN_ANT)
-			{
-				TXByteCnt_A += curTxOkCnt;
-				RXByteCnt_A += curRxOkCnt;
-			}
-			else
-			{
-				TXByteCnt_B += curTxOkCnt;
-				RXByteCnt_B += curRxOkCnt;
-			}
-		
-			nextAntenna = (pDM_SWAT_Table->CurAntenna == MAIN_ANT)? AUX_ANT : MAIN_ANT;
-			pDM_SWAT_Table->RSSI_Trying--;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH DIV=: RSSI_Trying = %d\n",pDM_SWAT_Table->RSSI_Trying));
-			if(pDM_SWAT_Table->RSSI_Trying == 0)
-			{
-				CurByteCnt = (pDM_SWAT_Table->CurAntenna == MAIN_ANT)? (TXByteCnt_A+RXByteCnt_A) : (TXByteCnt_B+RXByteCnt_B);
-				PreByteCnt = (pDM_SWAT_Table->CurAntenna == MAIN_ANT)? (TXByteCnt_B+RXByteCnt_B) : (TXByteCnt_A+RXByteCnt_A);
-				
-				if(TrafficLoad == TRAFFIC_HIGH)
-				{
-					//CurByteCnt = PlatformDivision64(CurByteCnt, 9);
-					PreByteCnt =PreByteCnt*9;
-				}
-				else if(TrafficLoad == TRAFFIC_LOW)
-				{
-					//CurByteCnt = PlatformDivision64(CurByteCnt, 2);
-					PreByteCnt =PreByteCnt*2;
-				}
-				if(pHalData->RSSI_cnt_A > 0)
-					RSSI_A = pHalData->RSSI_sum_A/pHalData->RSSI_cnt_A; 
-				else
-					RSSI_A = 0;
-				if(pHalData->RSSI_cnt_B > 0)
-					RSSI_B = pHalData->RSSI_sum_B/pHalData->RSSI_cnt_B; 
-		             else
-					RSSI_B = 0;
-				curRSSI = (pDM_SWAT_Table->CurAntenna == MAIN_ANT)? RSSI_A : RSSI_B;
-				pDM_SWAT_Table->PreRSSI =  (pDM_SWAT_Table->CurAntenna == MAIN_ANT)? RSSI_B : RSSI_A;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH DIV=: PreRSSI = %d, CurRSSI = %d\n",pDM_SWAT_Table->PreRSSI, curRSSI));
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH DIV=: preAntenna= %s, curAntenna= %s \n", 
-				(pDM_SWAT_Table->PreAntenna == MAIN_ANT?"MAIN":"AUX"), (pDM_SWAT_Table->CurAntenna == MAIN_ANT?"MAIN":"AUX")));
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH DIV=: RSSI_A= %d, RSSI_cnt_A = %d, RSSI_B= %d, RSSI_cnt_B = %d\n",
-					RSSI_A, pHalData->RSSI_cnt_A, RSSI_B, pHalData->RSSI_cnt_B));
-			}
-
-		}
-		else   // try_flag=0
-		{
-		
-			if(pHalData->RSSI_cnt_A > 0)
-				RSSI_A = pHalData->RSSI_sum_A/pHalData->RSSI_cnt_A; 
-			else
-				RSSI_A = 0;
-			if(pHalData->RSSI_cnt_B > 0)
-				RSSI_B = pHalData->RSSI_sum_B/pHalData->RSSI_cnt_B; 
-			else
-				RSSI_B = 0;	
-			curRSSI = (pDM_SWAT_Table->CurAntenna == MAIN_ANT)? RSSI_A : RSSI_B;
-			pDM_SWAT_Table->PreRSSI =  (pDM_SWAT_Table->PreAntenna == MAIN_ANT)? RSSI_A : RSSI_B;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH DIV=: PreRSSI = %d, CurRSSI = %d\n", pDM_SWAT_Table->PreRSSI, curRSSI));
-		       ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH DIV=: preAntenna= %s, curAntenna= %s \n", 
-			(pDM_SWAT_Table->PreAntenna == MAIN_ANT?"MAIN":"AUX"), (pDM_SWAT_Table->CurAntenna == MAIN_ANT?"MAIN":"AUX")));
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH DIV=: RSSI_A= %d, RSSI_cnt_A = %d, RSSI_B= %d, RSSI_cnt_B = %d\n",
-				RSSI_A, pHalData->RSSI_cnt_A, RSSI_B, pHalData->RSSI_cnt_B));
-			//RT_TRACE(COMP_INIT, DBG_LOUD, ("Ekul:curTxOkCnt = %d\n", curTxOkCnt));
-			//RT_TRACE(COMP_INIT, DBG_LOUD, ("Ekul:curRxOkCnt = %d\n", curRxOkCnt));
-		}
-
-		//1 Trying State
-		if((pDM_SWAT_Table->try_flag == 1)&&(pDM_SWAT_Table->RSSI_Trying == 0))
-		{
-
-			if(pDM_SWAT_Table->TestMode == TP_MODE)
-			{
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: TestMode = TP_MODE"));
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH= TRY:CurByteCnt = %"i64fmt"d,", CurByteCnt));
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH= TRY:PreByteCnt = %"i64fmt"d\n",PreByteCnt));		
-				if(CurByteCnt < PreByteCnt)
-				{
-					if(pDM_SWAT_Table->CurAntenna == MAIN_ANT)
-						pDM_SWAT_Table->SelectAntennaMap=pDM_SWAT_Table->SelectAntennaMap<<1;
-					else
-						pDM_SWAT_Table->SelectAntennaMap=(pDM_SWAT_Table->SelectAntennaMap<<1)+1;
-				}
-				else
-				{
-					if(pDM_SWAT_Table->CurAntenna == MAIN_ANT)
-						pDM_SWAT_Table->SelectAntennaMap=(pDM_SWAT_Table->SelectAntennaMap<<1)+1;
-					else
-						pDM_SWAT_Table->SelectAntennaMap=pDM_SWAT_Table->SelectAntennaMap<<1;
-				}
-				for (i= 0; i<8; i++)
-				{
-					if(((pDM_SWAT_Table->SelectAntennaMap>>i)&BIT0) == 1)
-						Score_A++;
-					else
-						Score_B++;
-				}
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("SelectAntennaMap=%x\n ",pDM_SWAT_Table->SelectAntennaMap));
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Score_A=%d, Score_B=%d\n", Score_A, Score_B));
-			
-				if(pDM_SWAT_Table->CurAntenna == MAIN_ANT)
-				{
-					nextAntenna = (Score_A >= Score_B)?MAIN_ANT:AUX_ANT;
-				}
-				else
-				{
-					nextAntenna = (Score_B >= Score_A)?AUX_ANT:MAIN_ANT;
-				}
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: nextAntenna=%s\n",(nextAntenna==MAIN_ANT)?"MAIN":"AUX"));
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: preAntenna= %s, curAntenna= %s \n", 
-				(pDM_SWAT_Table->PreAntenna == MAIN_ANT?"MAIN":"AUX"), (pDM_SWAT_Table->CurAntenna == MAIN_ANT?"MAIN":"AUX")));
-
-				if(nextAntenna != pDM_SWAT_Table->CurAntenna)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Switch back to another antenna"));
-				}
-				else
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: current anntena is good\n"));
-				}	
-			}
-
-                    
-			if(pDM_SWAT_Table->TestMode == RSSI_MODE)
-			{	
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: TestMode = RSSI_MODE"));
-				pDM_SWAT_Table->SelectAntennaMap=0xAA;
-				if(curRSSI < pDM_SWAT_Table->PreRSSI) //Current antenna is worse than previous antenna
-				{
-					//RT_TRACE(COMP_INIT, DBG_LOUD, ("SWAS: Switch back to another antenna"));
-					nextAntenna = (pDM_SWAT_Table->CurAntenna == MAIN_ANT)?AUX_ANT : MAIN_ANT;
-				}
-				else // current anntena is good
-				{
-					nextAntenna =pDM_SWAT_Table->CurAntenna;
-					//RT_TRACE(COMP_INIT, DBG_LOUD, ("SWAS: current anntena is good\n"));
-				}
-			}
-			
-			pDM_SWAT_Table->try_flag = 0;
-			pHalData->RSSI_sum_A = 0;
-			pHalData->RSSI_cnt_A = 0;
-			pHalData->RSSI_sum_B = 0;
-			pHalData->RSSI_cnt_B = 0;
-			TXByteCnt_A = 0;
-			TXByteCnt_B = 0;
-			RXByteCnt_A = 0;
-			RXByteCnt_B = 0;
-			
-		}
-
-		//1 Normal State
-		else if(pDM_SWAT_Table->try_flag == 0)
-		{
-			if(TrafficLoad == TRAFFIC_HIGH)
-			{
-				if ((curTxOkCnt+curRxOkCnt) > 3750000)//if(PlatformDivision64(curTxOkCnt+curRxOkCnt, 2) > 1875000)
-					TrafficLoad = TRAFFIC_HIGH;
-				else
-					TrafficLoad = TRAFFIC_LOW;
-			}
-			else if(TrafficLoad == TRAFFIC_LOW)
-				{
-				if ((curTxOkCnt+curRxOkCnt) > 3750000)//if(PlatformDivision64(curTxOkCnt+curRxOkCnt, 2) > 1875000)
-					TrafficLoad = TRAFFIC_HIGH;
-				else
-					TrafficLoad = TRAFFIC_LOW;
-			}
-			if(TrafficLoad == TRAFFIC_HIGH)
-				pDM_SWAT_Table->bTriggerAntennaSwitch = 0;
-			//RT_TRACE(COMP_INIT, DBG_LOUD, ("Normal:TrafficLoad = %llu\n", curTxOkCnt+curRxOkCnt));
-
-			//Prepare To Try Antenna		
-				nextAntenna = (pDM_SWAT_Table->CurAntenna == MAIN_ANT)? AUX_ANT : MAIN_ANT;
-				pDM_SWAT_Table->try_flag = 1;
-			if((curRxOkCnt+curTxOkCnt) > 1000)
-			{
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-	                    pDM_SWAT_Table->RSSI_Trying = 4;                           
-#else
-	                    pDM_SWAT_Table->RSSI_Trying = 2;
-#endif
-				pDM_SWAT_Table->TestMode = TP_MODE;
-			}
-			else
-			{
-				pDM_SWAT_Table->RSSI_Trying = 2;
-				pDM_SWAT_Table->TestMode = RSSI_MODE;
-
-			}
-                          
-			//RT_TRACE(COMP_INIT, DBG_LOUD, ("SWAS: Normal State -> Begin Trying!\n"));			
-			pHalData->RSSI_sum_A = 0;
-			pHalData->RSSI_cnt_A = 0;
-			pHalData->RSSI_sum_B = 0;
-			pHalData->RSSI_cnt_B = 0;
-		} // end of try_flag=0
-	}
-	
-	//1 4.Change TRX antenna
-	if(nextAntenna != pDM_SWAT_Table->CurAntenna)
-	{
-	
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Change TX Antenna!\n "));
-		//PHY_SetBBReg(Adapter, rFPGA0_XA_RFInterfaceOE, 0x300, nextAntenna); for 88C
-		if(nextAntenna==MAIN_ANT)
-		{
-		    ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Next Antenna is RF PATH A\n "));
-		    pathdiv_para = 0x02;   //02 to switchback to RF path A
-		    fw_value = 0x03;
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-                 odm_PathDiversity_8192D(pDM_Odm, pathdiv_para);
-#else
-                 ODM_FillH2CCmd(pDM_Odm, ODM_H2C_PathDiv,1,(pu1Byte)(&fw_value));	
-#endif
-		}	
-	       else if(nextAntenna==AUX_ANT)
-	       {
-	           ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Next Antenna is RF PATH B\n "));
-	           if(switchfirsttime==0)  // First Time To Enter Path Diversity
-	           {
-	               switchfirsttime=0x01;
-                      pathdiv_para = 0x00;
-			  fw_value=0x00;    // to backup RF Path A Releated Registers		  
-					  
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-                     odm_PathDiversity_8192D(pDM_Odm, pathdiv_para);
-#else
-                     ODM_FillH2CCmd(pDM_Odm, ODM_H2C_PathDiv,1,(pu1Byte)(&fw_value));	
-                     //for(u1Byte n=0; n<80,n++)
-                     //{
-                     //delay_us(500);
-			  ODM_delay_ms(500);
-                     odm_PathDiversity_8192D(pDM_Odm, pathdiv_para);
-			 		 
-			 fw_value=0x01;   	// to backup RF Path A Releated Registers		 
-                     ODM_FillH2CCmd(pDM_Odm, ODM_H2C_PathDiv,1,(pu1Byte)(&fw_value));	
-#endif	
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: FIRST TIME To DO PATH SWITCH!\n "));	
-	           }		   
-		    else
-		    {
-		        pathdiv_para = 0x01;
-			 fw_value = 0x02;	
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-                     odm_PathDiversity_8192D(pDM_Odm, pathdiv_para);
-#else
-                     ODM_FillH2CCmd(pDM_Odm, ODM_H2C_PathDiv,1,(pu1Byte)(&fw_value));	
-#endif	
-		    }		
-	       }
-           //   odm_PathDiversity_8192D(Adapter, pathdiv_para);
-	}
-
-	//1 5.Reset Statistics
-	pDM_SWAT_Table->PreAntenna = pDM_SWAT_Table->CurAntenna;
-	pDM_SWAT_Table->CurAntenna = nextAntenna;
-	pDM_SWAT_Table->PreRSSI = curRSSI;
-
-	//1 6.Set next timer
-
-	if(pDM_SWAT_Table->RSSI_Trying == 0)
-		return;
-
-	if(pDM_SWAT_Table->RSSI_Trying%2 == 0)
-	{
-		if(pDM_SWAT_Table->TestMode == TP_MODE)
-		{
-			if(TrafficLoad == TRAFFIC_HIGH)
-			{
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-				ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 10 ); //ms
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Test another antenna for 10 ms\n"));
-#else
-				ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 20 ); //ms
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Test another antenna for 20 ms\n"));
-#endif				
-			}
-			else if(TrafficLoad == TRAFFIC_LOW)
-			{
-				ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 50 ); //ms
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Test another antenna for 50 ms\n"));
-			}
-		}
-		else   // TestMode == RSSI_MODE
-		{
-			ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 500 ); //ms
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Test another antenna for 500 ms\n"));
-		}
-	}
-	else
-	{
-		if(pDM_SWAT_Table->TestMode == TP_MODE)
-		{
-			if(TrafficLoad == TRAFFIC_HIGH)
-				
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-				ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 90 ); //ms
-				//ODM_RT_TRACE(pDM_Odm,ODM_COMP_PATH_DIV, ODM_DBG_LOUD, ("=PATH=: Test another antenna for 90 ms\n"));
-#else		
-				ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 180); //ms
-#endif				
-			else if(TrafficLoad == TRAFFIC_LOW)
-				ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 100 ); //ms
-		}
-		else
-			ODM_SetTimer( pDM_Odm, &pDM_Odm->PathDivSwitchTimer, 500 ); //ms
-	}
-}
-
-
-
-VOID
-ODM_CCKPathDiversityChkPerPktRssi(
-	PADAPTER		Adapter,
-	BOOLEAN			bIsDefPort,
-	BOOLEAN			bMatchBSSID,
-	PRT_WLAN_STA	pEntry,
-	PRT_RFD			pRfd,
-	pu1Byte			pDesc
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	BOOLEAN			bCount = FALSE;
-	pPD_T	pDM_PDTable = &Adapter->DM_PDTable;
-	//BOOLEAN	isCCKrate = RX_HAL_IS_CCK_RATE_92C(pDesc);
-#if DEV_BUS_TYPE != RT_SDIO_INTERFACE
-	BOOLEAN	isCCKrate = RX_HAL_IS_CCK_RATE(Adapter, pDesc);
-#else  //below code would be removed if we have verified SDIO
-	BOOLEAN	isCCKrate = IS_HARDWARE_TYPE_8188E(Adapter) ? RX_HAL_IS_CCK_RATE_88E(pDesc) : RX_HAL_IS_CCK_RATE_92C(pDesc);
-#endif
-
-	if ((pHalData->PathDivCfg != 1))
-		return;
-		
-	if(pHalData->RSSI_target==NULL && bIsDefPort && bMatchBSSID)
-		bCount = TRUE;
-	else if(pHalData->RSSI_target!=NULL && pEntry!=NULL && pHalData->RSSI_target==pEntry)
-		bCount = TRUE;
-
-	if(bCount && isCCKrate)
-	{
-		if(pDM_PDTable->TrainingState == 1 )
-		{
-			if(pEntry)
-			{
-				if(pEntry->rssi_stat.RSSI_CCK_Path_cnt[0] != 0)
-					pEntry->rssi_stat.RSSI_CCK_Path[0] += pRfd->Status.RxPWDBAll;
-				pEntry->rssi_stat.RSSI_CCK_Path_cnt[0]++;
-			}
-			else
-			{
-				if(pDM_PDTable->RSSI_CCK_Path_cnt[0] != 0)
-					pDM_PDTable->RSSI_CCK_Path[0] += pRfd->Status.RxPWDBAll;
-				pDM_PDTable->RSSI_CCK_Path_cnt[0]++;
-			}
-		}
-		else if(pDM_PDTable->TrainingState == 2 )
-		{
-			if(pEntry)
-			{
-				if(pEntry->rssi_stat.RSSI_CCK_Path_cnt[1] != 0)
-					pEntry->rssi_stat.RSSI_CCK_Path[1] += pRfd->Status.RxPWDBAll;
-				pEntry->rssi_stat.RSSI_CCK_Path_cnt[1]++;
-			}
-			else
-			{
-				if(pDM_PDTable->RSSI_CCK_Path_cnt[1] != 0)
-					pDM_PDTable->RSSI_CCK_Path[1] += pRfd->Status.RxPWDBAll;
-				pDM_PDTable->RSSI_CCK_Path_cnt[1]++;
-			}
-		}
-	}
-}
-
-
-
-
-//Neil Chen---2011--06--22
-//----92D Path Diversity----//
-//#ifdef PathDiv92D
-//==================================
-//3 Path Diversity 
-//==================================
-//
-// 20100514 Luke/Joseph:
-// Add new function for antenna diversity after link.
-// This is the main function of antenna diversity after link.
-// This function is called in HalDmWatchDog() and ODM_SwAntDivChkAntSwitchCallback().
-// HalDmWatchDog() calls this function with SWAW_STEP_PEAK to initialize the antenna test.
-// In SWAW_STEP_PEAK, another antenna and a 500ms timer will be set for testing.
-// After 500ms, ODM_SwAntDivChkAntSwitchCallback() calls this function to compare the signal just
-// listened on the air with the RSSI of original antenna.
-// It chooses the antenna with better RSSI.
-// There is also a aged policy for error trying. Each error trying will cost more 5 seconds waiting 
-// penalty to get next try.
-//
-//
-// 20100503 Joseph:
-// Add new function SwAntDivCheck8192C().
-// This is the main function of Antenna diversity function before link.
-// Mainly, it just retains last scan result and scan again.
-// After that, it compares the scan result to see which one gets better RSSI.
-// It selects antenna with better receiving power and returns better scan result.
-//
-
-
-//
-// 20100514 Luke/Joseph:
-// This function is used to gather the RSSI information for antenna testing.
-// It selects the RSSI of the peer STA that we want to know.
-//
-VOID
-ODM_PathDivChkPerPktRssi(
-	PADAPTER		Adapter,
-	BOOLEAN			bIsDefPort,
-	BOOLEAN			bMatchBSSID,
-	PRT_WLAN_STA	pEntry,
-	PRT_RFD			pRfd
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);	
-	BOOLEAN			bCount = FALSE;
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	pSWAT_T			pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-
-	if(pHalData->RSSI_target==NULL && bIsDefPort && bMatchBSSID)
-		bCount = TRUE;
-	else if(pHalData->RSSI_target!=NULL && pEntry!=NULL && pHalData->RSSI_target==pEntry)
-		bCount = TRUE;
-
-	if(bCount)
-	{
-		//1 RSSI for SW Antenna Switch
-		if(pDM_SWAT_Table->CurAntenna == MAIN_ANT)
-		{
-			pHalData->RSSI_sum_A += pRfd->Status.RxPWDBAll;
-			pHalData->RSSI_cnt_A++;
-		}
-		else
-		{
-			pHalData->RSSI_sum_B += pRfd->Status.RxPWDBAll;
-			pHalData->RSSI_cnt_B++;
-
-		}
-	}
-}
-
-
-//
-// 20100514 Luke/Joseph:
-// Add new function to reset antenna diversity state after link.
-//
-VOID
-ODM_PathDivRestAfterLink(
-	IN	PDM_ODM_T		pDM_Odm
-	)
-{
-	PADAPTER		Adapter=pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	pSWAT_T			pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-
-	pHalData->RSSI_cnt_A = 0;
-	pHalData->RSSI_cnt_B = 0;
-	pDM_SWAT_Table->try_flag = 0x0;       // NOT 0xff
-	pDM_SWAT_Table->RSSI_Trying = 0;
-	pDM_SWAT_Table->SelectAntennaMap=0xAA;
-	pDM_SWAT_Table->CurAntenna = MAIN_ANT;  
-}
-
-
-//==================================================
-//3 PathDiv End
-//==================================================
-
-
-VOID
-ODM_FillTXPathInTXDESC(
-		IN	PADAPTER	Adapter,
-		IN	PRT_TCB		pTcb,
-		IN	pu1Byte		pDesc
-)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u4Byte	TXPath;
-	pPD_T	pDM_PDTable = &Adapter->DM_PDTable;
-
-	//2011.09.05  Add by Luke Lee for path diversity
-	if(pHalData->PathDivCfg == 1)
-	{	
-		TXPath = (pDM_PDTable->OFDMTXPath >> pTcb->macId) & BIT0;
-		//RT_TRACE(	COMP_INIT, DBG_LOUD, ("Fill TXDESC: macID=%d, TXPath=%d\n", pTcb->macId, TXPath));
-		//SET_TX_DESC_TX_ANT_CCK(pDesc,TXPath);
-		if(TXPath == 0)
-		{
-			SET_TX_DESC_TX_ANTL_92C(pDesc,1);
-			SET_TX_DESC_TX_ANT_HT_92C(pDesc,1);
-		}
-		else
-		{
-			SET_TX_DESC_TX_ANTL_92C(pDesc,2);
-			SET_TX_DESC_TX_ANT_HT_92C(pDesc,2);
-		}
-		TXPath = (pDM_PDTable->CCKTXPath >> pTcb->macId) & BIT0;
-		if(TXPath == 0)
-		{
-			SET_TX_DESC_TX_ANT_CCK_92C(pDesc,1);
-		}
-		else
-		{
-			SET_TX_DESC_TX_ANT_CCK_92C(pDesc,2);
-		}
-	}
-}
-
-//Only for MP //Neil Chen--2012--0502--
-VOID
-odm_PathDivInit_92D(
-IN	PDM_ODM_T 	pDM_Odm)
-{
-	pPATHDIV_PARA	pathIQK = &pDM_Odm->pathIQK;
-
-	pathIQK->org_2g_RegC14=0x0;
-	pathIQK->org_2g_RegC4C=0x0;
-	pathIQK->org_2g_RegC80=0x0;
-	pathIQK->org_2g_RegC94=0x0;
-	pathIQK->org_2g_RegCA0=0x0;
-	pathIQK->org_5g_RegC14=0x0;
-	pathIQK->org_5g_RegCA0=0x0;
-	pathIQK->org_5g_RegE30=0x0;
-	pathIQK->swt_2g_RegC14=0x0;
-	pathIQK->swt_2g_RegC4C=0x0;
-	pathIQK->swt_2g_RegC80=0x0;
-	pathIQK->swt_2g_RegC94=0x0;
-	pathIQK->swt_2g_RegCA0=0x0;
-	pathIQK->swt_5g_RegC14=0x0;
-	pathIQK->swt_5g_RegCA0=0x0;
-	pathIQK->swt_5g_RegE30=0x0;
-
-}
-
-
-u1Byte
-odm_SwAntDivSelectScanChnl(
-	IN	PADAPTER	Adapter
-	)
-{
-#if (RT_MEM_SIZE_LEVEL != RT_MEM_SIZE_MINIMUM)
-	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(Adapter);
-	PMGNT_INFO			pMgntInfo = &(Adapter->MgntInfo);
-	PDM_ODM_T			pDM_Odm = &pHalData->DM_OutSrc;
-	u2Byte 				i;
-	u1Byte				j, ScanChannel = 0, ChannelNum = 0;
-	PRT_CHANNEL_LIST	pChannelList = GET_RT_CHANNEL_LIST(pMgntInfo);
-	u1Byte 				EachChannelSTAs[MAX_SCAN_CHANNEL_NUM] = {0};
-
-	if(pMgntInfo->tmpNumBssDesc == 0)
-		return 0;
-
-	for(i = 0; i < pMgntInfo->tmpNumBssDesc; i++)
-	{		
-		ChannelNum = pMgntInfo->tmpbssDesc[i].ChannelNumber;
-		for(j = 0; j < pChannelList->ChannelLen; j++)
-		{
-			if(pChannelList->ChnlListEntry[j].ChannelNum == ChannelNum)
-			{
-				EachChannelSTAs[j]++;
-				break;
-			}
-		}
-	}
-	
-	for(i = 0; i < MAX_SCAN_CHANNEL_NUM; i++)
-		{
-		if(EachChannelSTAs[i] > EachChannelSTAs[ScanChannel])
-			ScanChannel = (u1Byte)i;
-		}
-
-	if(EachChannelSTAs[ScanChannel] == 0)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, ("odm_SwAntDivSelectScanChnl(): Scan List is empty.\n"));
-		return 0;
-	}
-	
-	ScanChannel = pChannelList->ChnlListEntry[ScanChannel].ChannelNum;
-
-	
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_ANT_DIV, DBG_LOUD, 
-		("odm_SwAntDivSelectScanChnl(): Channel (( %d )) is select as scan channel.\n", ScanChannel));
-
-	return ScanChannel;
-#else
-	return	0;
-#endif	
-}
-
-
-VOID
-odm_SwAntDivConstructScanChnl(
-	IN	PADAPTER	Adapter,
-	IN	u1Byte		ScanChnl
-	)
-{
-
-	PMGNT_INFO			pMgntInfo = &Adapter->MgntInfo;
-
-	if(ScanChnl == 0)
-	{
-		u1Byte				i;		
-		PRT_CHANNEL_LIST	pChannelList = GET_RT_CHANNEL_LIST(pMgntInfo);
-	
-		// 20100519 Joseph: Original antenna scanned nothing. 
-		// Test antenna shall scan all channel with half period in this condition.
-
-		RT_TRACE_F(COMP_SCAN, DBG_TRACE, (" RT_CHNL_LIST_ACTION_CONSTRUCT chnl %d \n", ScanChnl));
-
-		RtActChannelList(Adapter, RT_CHNL_LIST_ACTION_CONSTRUCT_SCAN_LIST, NULL, NULL);
-		for(i = 0; i < pChannelList->ChannelLen; i++)
-			pChannelList->ChnlListEntry[i].ScanPeriod /= 2;
-	}
-	else
-	{
-		// The using of this CustomizedScanRequest is a trick to rescan the two channels 
-		//	under the NORMAL scanning process. It will not affect MGNT_INFO.CustomizedScanRequest.
-		CUSTOMIZED_SCAN_REQUEST CustomScanReq;
-
-		CustomScanReq.bEnabled = TRUE;
-		CustomScanReq.Channels[0] = ScanChnl;
-		CustomScanReq.Channels[1] = pMgntInfo->dot11CurrentChannelNumber;
-		CustomScanReq.nChannels = 2;
-		CustomScanReq.ScanType = SCAN_ACTIVE;
-		CustomScanReq.Duration = DEFAULT_PASSIVE_SCAN_PERIOD;
-
-		RT_TRACE_F(COMP_SCAN, DBG_TRACE, (" RT_CHNL_LIST_ACTION_CONSTRUCT chnl %d \n", ScanChnl));
-
-		RtActChannelList(Adapter, RT_CHNL_LIST_ACTION_CONSTRUCT_SCAN_LIST, &CustomScanReq, NULL);
-	}
-
-}
-#else
-
-VOID
-odm_PathDivChkAntSwitchCallback(
-	PRT_TIMER		pTimer
-)
-{
-}
-
-VOID
-odm_PathDivChkAntSwitchWorkitemCallback(
-    IN PVOID            pContext
-    )
-{
-}
-
-VOID
-odm_CCKTXPathDiversityCallback(
-	PRT_TIMER		pTimer
-)
-{
-}
-
-VOID
-odm_CCKTXPathDiversityWorkItemCallback(
-    IN PVOID            pContext
-    )
-{
-}
-u1Byte
-odm_SwAntDivSelectScanChnl(
-	IN	PADAPTER	Adapter
-	)
-{
-	return	0;
-}
-VOID
-odm_SwAntDivConstructScanChnl(
-	IN	PADAPTER	Adapter,
-	IN	u1Byte		ScanChnl
-	)
-{
-}
-
-
-#endif
-
-#endif	// #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (defined(CONFIG_PATH_DIVERSITY))
+#if RTL8814A_SUPPORT
+
+void
+phydm_dtp_fix_tx_path(
+	void	*dm_void,
+	u8	path
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+	u8			i, num_enable_path = 0;
+
+	if (path == dm_path_div->pre_tx_path)
+		return;
+	else
+		dm_path_div->pre_tx_path = path;
+
+	odm_set_bb_reg(dm, 0x93c, BIT(18) | BIT(19), 3);
+
+	for (i = 0; i < 4; i++) {
+		if (path & BIT(i))
+			num_enable_path++;
+	}
+	PHYDM_DBG(dm, DBG_PATH_DIV, " number of turn-on path : (( %d ))\n", num_enable_path);
+
+	if (num_enable_path == 1) {
+		odm_set_bb_reg(dm, 0x93c, 0xf00000, path);
+
+		if (path == BB_PATH_A) { /* 1-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+		} else 	if (path == BB_PATH_B) { /* 1-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+		} else 	if (path == BB_PATH_C) { /* 1-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( C ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 0);
+
+		} else 	if (path == BB_PATH_D) { /* 1-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( D ))\n");
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 0);
+		}
+
+	} else	if (num_enable_path == 2) {
+		odm_set_bb_reg(dm, 0x93c, 0xf00000, path);
+		odm_set_bb_reg(dm, 0x940, 0xf0, path);
+
+		if (path == (BB_PATH_AB)) { /* 2-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A B ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 1);
+		} else 	if (path == BB_PATH_AC) { /* 2-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A C ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+		} else 	if (path == BB_PATH_AD) { /* 2-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 1);
+		} else 	if (path == BB_PATH_BC) { /* 2-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B C ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+		} else 	if (path == BB_PATH_BD) { /* 2-5 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 1);
+		} else 	if (path == BB_PATH_CD) { /* 2-6 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( C D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 1);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 1);
+		}
+
+	} else	if (num_enable_path == 3) {
+		odm_set_bb_reg(dm, 0x93c, 0xf00000, path);
+		odm_set_bb_reg(dm, 0x940, 0xf0, path);
+		odm_set_bb_reg(dm, 0x940, 0xf0000, path);
+
+		if (path == BB_PATH_ABC) { /* 3-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A B C))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(23) | BIT(22), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(25) | BIT(24), 2);
+		} else 	if (path == BB_PATH_ABD) { /* 3-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A B D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(23) | BIT(22), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(27) | BIT(26), 2);
+
+		} else 	if (path == BB_PATH_ACD) { /* 3-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A C D ))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(25) | BIT(24), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(27) | BIT(26), 2);
+		} else 	if (path == BB_PATH_BCD) { /* 3-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B C D))\n");
+			/* set for 1ss */
+			odm_set_bb_reg(dm, 0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, 0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, 0x93c, BIT(31) | BIT(30), 2);
+			/* set for 2ss */
+			odm_set_bb_reg(dm, 0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(13) | BIT(12), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(15) | BIT(14), 2);
+			/* set for 3ss */
+			odm_set_bb_reg(dm, 0x940, BIT(23) | BIT(22), 0);
+			odm_set_bb_reg(dm, 0x940, BIT(25) | BIT(24), 1);
+			odm_set_bb_reg(dm, 0x940, BIT(27) | BIT(26), 2);
+		}
+	} else	if (num_enable_path == 4)
+		PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path ((A  B C D))\n");
+
+}
+
+void
+phydm_find_default_path(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+	u32	rssi_avg_a = 0, rssi_avg_b = 0, rssi_avg_c = 0, rssi_avg_d = 0, rssi_avg_bcd = 0;
+	u32	rssi_total_a = 0, rssi_total_b = 0, rssi_total_c = 0, rssi_total_d = 0;
+
+	/* 2 Default path Selection By RSSI */
+
+	rssi_avg_a = (dm_path_div->path_a_cnt_all > 0) ? (dm_path_div->path_a_sum_all / dm_path_div->path_a_cnt_all) : 0 ;
+	rssi_avg_b = (dm_path_div->path_b_cnt_all > 0) ? (dm_path_div->path_b_sum_all / dm_path_div->path_b_cnt_all) : 0 ;
+	rssi_avg_c = (dm_path_div->path_c_cnt_all > 0) ? (dm_path_div->path_c_sum_all / dm_path_div->path_c_cnt_all) : 0 ;
+	rssi_avg_d = (dm_path_div->path_d_cnt_all > 0) ? (dm_path_div->path_d_sum_all / dm_path_div->path_d_cnt_all) : 0 ;
+
+
+	dm_path_div->path_a_sum_all = 0;
+	dm_path_div->path_a_cnt_all = 0;
+	dm_path_div->path_b_sum_all = 0;
+	dm_path_div->path_b_cnt_all = 0;
+	dm_path_div->path_c_sum_all = 0;
+	dm_path_div->path_c_cnt_all = 0;
+	dm_path_div->path_d_sum_all = 0;
+	dm_path_div->path_d_cnt_all = 0;
+
+	if (dm_path_div->use_path_a_as_default_ant == 1) {
+		rssi_avg_bcd = (rssi_avg_b + rssi_avg_c + rssi_avg_d) / 3;
+
+		if ((rssi_avg_a + ANT_DECT_RSSI_TH) > rssi_avg_bcd) {
+			dm_path_div->is_path_a_exist = true;
+			dm_path_div->default_path = PATH_A;
+		} else
+			dm_path_div->is_path_a_exist = false;
+	} else {
+		if ((rssi_avg_a >= rssi_avg_b) && (rssi_avg_a >= rssi_avg_c) && (rssi_avg_a >= rssi_avg_d))
+			dm_path_div->default_path = PATH_A;
+		else if ((rssi_avg_b >= rssi_avg_c) && (rssi_avg_b >= rssi_avg_d))
+			dm_path_div->default_path = PATH_B;
+		else if (rssi_avg_c >= rssi_avg_d)
+			dm_path_div->default_path = PATH_C;
+		else
+			dm_path_div->default_path = PATH_D;
+	}
+
+
+}
+
+
+void
+phydm_candidate_dtp_update(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+
+	dm_path_div->num_candidate = 3;
+
+	if (dm_path_div->use_path_a_as_default_ant == 1) {
+		if (dm_path_div->num_tx_path == 3) {
+			if (dm_path_div->is_path_a_exist) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_ACD;
+			} else { /* use path BCD */
+				dm_path_div->num_candidate = 1;
+				phydm_dtp_fix_tx_path(dm, BB_PATH_BCD);
+				return;
+			}
+		} else	if (dm_path_div->num_tx_path == 2) {
+			if (dm_path_div->is_path_a_exist) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AB;
+				dm_path_div->ant_candidate_2 =  BB_PATH_AC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_AD;
+			} else {
+				dm_path_div->ant_candidate_1 =  BB_PATH_BC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+			}
+		}
+	} else {
+		/* 2 3 TX mode */
+		if (dm_path_div->num_tx_path == 3) { /* choose 3 ant form 4 */
+			if (dm_path_div->default_path == PATH_A) { /* choose 2 ant form 3 */
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_ACD;
+			} else if (dm_path_div->default_path == PATH_B) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
+			} else if (dm_path_div->default_path == PATH_C) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ACD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
+			} else if (dm_path_div->default_path == PATH_D) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_ABD;
+				dm_path_div->ant_candidate_2 =  BB_PATH_ACD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
+			}
+		}
+
+		/* 2 2 TX mode */
+		else if (dm_path_div->num_tx_path == 2) { /* choose 2 ant form 4 */
+			if (dm_path_div->default_path == PATH_A) { /* choose 2 ant form 3 */
+				dm_path_div->ant_candidate_1 =  BB_PATH_AB;
+				dm_path_div->ant_candidate_2 =  BB_PATH_AC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_AD;
+			} else if (dm_path_div->default_path == PATH_B) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AB;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_BD;
+			} else if (dm_path_div->default_path == PATH_C) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AC;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BC;
+				dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+			} else if (dm_path_div->default_path == PATH_D) {
+				dm_path_div->ant_candidate_1 =  BB_PATH_AD;
+				dm_path_div->ant_candidate_2 =  BB_PATH_BD;
+				dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+			}
+		}
+	}
+}
+
+
+void
+phydm_dynamic_tx_path(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div = &dm->dm_path_div;
+
+	struct sta_info	*entry;
+	u32	i;
+	u8	num_client = 0;
+	u8	h2c_parameter[6] = {0};
+
+
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_PATH_DIV, "DTP_8814 [No Link!!!]\n");
+
+		if (dm_path_div->is_become_linked == true) {
+			PHYDM_DBG(dm, DBG_PATH_DIV, " [Be disconnected]----->\n");
+			dm_path_div->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (dm_path_div->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_PATH_DIV, " [Be Linked !!!]----->\n");
+			dm_path_div->is_become_linked = dm->is_linked;
+		}
+	}
+
+	/* 2 [period CTRL] */
+	if (dm_path_div->dtp_period >= 2)
+		dm_path_div->dtp_period = 0;
+	else {
+		/* PHYDM_DBG(dm,DBG_PATH_DIV, "Phydm_Dynamic_Tx_Path_8814A()  Stay = (( %d ))\n",dm_path_div->dtp_period); */
+		dm_path_div->dtp_period++;
+		return;
+	}
+
+
+	/* 2 [Fix path] */
+	if (dm->path_select != PHYDM_AUTO_PATH)
+		return;
+
+	/* 2 [Check Bfer] */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if (BEAMFORMING_SUPPORT == 1)
+	{
+		enum beamforming_cap		beamform_cap = (dm->beamforming_info.beamform_cap);
+
+		if (beamform_cap & BEAMFORMER_CAP) { /* BFmer On  &&   Div On->Div Off */
+			if (dm_path_div->fix_path_bfer == 0) {
+				PHYDM_DBG(dm, DBG_PATH_DIV, "[ PathDiv : OFF ]   BFmer ==1\n");
+				dm_path_div->fix_path_bfer = 1 ;
+			}
+			return;
+		} else { /* BFmer Off   &&   Div Off->Div On */
+			if (dm_path_div->fix_path_bfer == 1) {
+				PHYDM_DBG(dm, DBG_PATH_DIV, "[ PathDiv : ON ]   BFmer ==0\n");
+				dm_path_div->fix_path_bfer = 0;
+			}
+		}
+	}
+#endif
+#endif
+
+	if (dm_path_div->use_path_a_as_default_ant == 1) {
+		phydm_find_default_path(dm);
+		phydm_candidate_dtp_update(dm);
+	} else {
+		if (dm_path_div->phydm_dtp_state == PHYDM_DTP_INIT) {
+			phydm_find_default_path(dm);
+			phydm_candidate_dtp_update(dm);
+			dm_path_div->phydm_dtp_state = PHYDM_DTP_RUNNING_1;
+		}
+
+		else	if (dm_path_div->phydm_dtp_state == PHYDM_DTP_RUNNING_1) {
+			dm_path_div->dtp_check_patha_counter++;
+
+			if (dm_path_div->dtp_check_patha_counter >= NUM_RESET_DTP_PERIOD) {
+				dm_path_div->dtp_check_patha_counter = 0;
+				dm_path_div->phydm_dtp_state = PHYDM_DTP_INIT;
+			}
+#if 0
+			/* 2 Search space update */
+			else {
+				/* 1.  find the worst candidate */
+
+
+				/* 2. repalce the worst candidate */
+			}
+#endif
+		}
+	}
+
+	/* 2 Dynamic path Selection H2C */
+
+	if (dm_path_div->num_candidate == 1)
+		return;
+	else {
+		h2c_parameter[0] =  dm_path_div->num_candidate;
+		h2c_parameter[1] =  dm_path_div->num_tx_path;
+		h2c_parameter[2] =  dm_path_div->ant_candidate_1;
+		h2c_parameter[3] =  dm_path_div->ant_candidate_2;
+		h2c_parameter[4] =  dm_path_div->ant_candidate_3;
+
+		odm_fill_h2c_cmd(dm, PHYDM_H2C_DYNAMIC_TX_PATH, 6, h2c_parameter);
+	}
+
+}
+
+
+
+void
+phydm_dynamic_tx_path_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div  = &dm->dm_path_div;
+	void		*adapter = dm->adapter;
+	u8			search_space_2[NUM_CHOOSE2_FROM4] = {BB_PATH_AB, BB_PATH_AC, BB_PATH_AD, BB_PATH_BC, BB_PATH_BD, BB_PATH_CD };
+	u8			search_space_3[NUM_CHOOSE3_FROM4] = {BB_PATH_BCD, BB_PATH_ACD,  BB_PATH_ABD, BB_PATH_ABC};
+
+#if ((DM_ODM_SUPPORT_TYPE == ODM_WIN) && USB_SWITCH_SUPPORT)
+	dm_path_div->is_u3_mode = (*dm->hub_usb_mode == 2) ? 1 : 0;
+	PHYDM_DBG(dm, DBG_PATH_DIV, "[WIN USB] is_u3_mode = (( %d ))\n", dm_path_div->is_u3_mode);
+#else
+	dm_path_div->is_u3_mode = 1;
+#endif
+	PHYDM_DBG(dm, DBG_PATH_DIV, "Dynamic TX path Init 8814\n");
+
+	memcpy(&dm_path_div->search_space_2[0], &search_space_2[0],
+	       NUM_CHOOSE2_FROM4);
+	memcpy(&dm_path_div->search_space_3[0], &search_space_3[0],
+	       NUM_CHOOSE3_FROM4);
+
+	dm_path_div->use_path_a_as_default_ant = 1;
+	dm_path_div->phydm_dtp_state = PHYDM_DTP_INIT;
+	dm->path_select = PHYDM_AUTO_PATH;
+	dm_path_div->phydm_path_div_type = PHYDM_4R_PATH_DIV;
+
+
+	if (dm_path_div->is_u3_mode) {
+		dm_path_div->num_tx_path = 3;
+		phydm_dtp_fix_tx_path(dm, BB_PATH_BCD);/* 3TX  Set Init TX path*/
+
+	} else {
+		dm_path_div->num_tx_path = 2;
+		phydm_dtp_fix_tx_path(dm, BB_PATH_BC);/* 2TX // Set Init TX path*/
+	}
+
+}
+
+
+void
+phydm_process_rssi_for_path_div(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+)
+{
+	struct dm_struct			*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct		*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct	*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct _ODM_PATH_DIVERSITY_			*dm_path_div  = &dm->dm_path_div;
+
+	if (!(pktinfo->is_packet_to_self || pktinfo->is_packet_match_bssid))
+		return;
+
+	if (pktinfo->data_rate <= ODM_RATE11M)
+		return;
+
+	if (dm_path_div->phydm_path_div_type == PHYDM_4R_PATH_DIV) {
+#if RTL8814A_SUPPORT
+		if (dm->support_ic_type & ODM_RTL8814A) {
+			dm_path_div->path_a_sum_all += phy_info->rx_mimo_signal_strength[0];
+			dm_path_div->path_a_cnt_all++;
+
+			dm_path_div->path_b_sum_all += phy_info->rx_mimo_signal_strength[1];
+			dm_path_div->path_b_cnt_all++;
+
+			dm_path_div->path_c_sum_all += phy_info->rx_mimo_signal_strength[2];
+			dm_path_div->path_c_cnt_all++;
+
+			dm_path_div->path_d_sum_all += phy_info->rx_mimo_signal_strength[3];
+			dm_path_div->path_d_cnt_all++;
+		}
+#endif
+	} else {
+		dm_path_div->path_a_sum[pktinfo->station_id] += phy_info->rx_mimo_signal_strength[0];
+		dm_path_div->path_a_cnt[pktinfo->station_id]++;
+
+		dm_path_div->path_b_sum[pktinfo->station_id] += phy_info->rx_mimo_signal_strength[1];
+		dm_path_div->path_b_cnt[pktinfo->station_id]++;
+	}
+}
+
+#endif /* #if RTL8814A_SUPPORT */
+
+void
+odm_pathdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_			*dm_path_div  = &dm->dm_path_div;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	dm->path_select = (dm_value[0] & 0xf);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Path_select = (( 0x%x ))\n", dm->path_select);
+
+	/* 2 [Fix path] */
+	if (dm->path_select != PHYDM_AUTO_PATH) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				"Trun on path  [%s%s%s%s]\n",
+				((dm->path_select) & 0x1) ? "A" : "",
+				((dm->path_select) & 0x2) ? "B" : "",
+				((dm->path_select) & 0x4) ? "C" : "",
+				((dm->path_select) & 0x8) ? "D" : "");
+
+		phydm_dtp_fix_tx_path(dm, dm->path_select);
+	} else
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "%s\n", "Auto path");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif /*  #if(defined(CONFIG_PATH_DIVERSITY)) */
+
+void
+phydm_c2h_dtp_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8	cmd_len
+)
+{
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_		*dm_path_div  = &dm->dm_path_div;
+
+	u8  macid = cmd_buf[0];
+	u8  target = cmd_buf[1];
+	u8  nsc_1 = cmd_buf[2];
+	u8  nsc_2 = cmd_buf[3];
+	u8  nsc_3 = cmd_buf[4];
+
+	PHYDM_DBG(dm, DBG_PATH_DIV, "Target_candidate = (( %d ))\n", target);
+	/*
+	if( (nsc_1 >= nsc_2) &&  (nsc_1 >= nsc_3))
+	{
+		phydm_dtp_fix_tx_path(dm, dm_path_div->ant_candidate_1);
+	}
+	else	if( nsc_2 >= nsc_3)
+	{
+		phydm_dtp_fix_tx_path(dm, dm_path_div->ant_candidate_2);
+	}
+	else
+	{
+		phydm_dtp_fix_tx_path(dm, dm_path_div->ant_candidate_3);
+	}
+	*/
+#endif
+}
+
+void
+odm_path_diversity(
+	void	*dm_void
+)
+{
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_PATH_DIV)) {
+		PHYDM_DBG(dm, DBG_PATH_DIV, "Return: Not Support PathDiv\n");
+		return;
+	}
+
+#if RTL8812A_SUPPORT
+
+	if (dm->support_ic_type & ODM_RTL8812)
+		odm_path_diversity_8812a(dm);
+	else
+#endif
+
+#if RTL8814A_SUPPORT
+		if (dm->support_ic_type & ODM_RTL8814A)
+			phydm_dynamic_tx_path(dm);
+		else
+#endif
+		{}
+#endif
+}
+
+void
+phydm_path_diversity_init(
+	void	*dm_void
+)
+{
+#if (defined(CONFIG_PATH_DIVERSITY))
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	/*dm->support_ability |= ODM_BB_PATH_DIV;*/
+
+	if (*dm->mp_mode == true)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PATH_DIV)) {
+		PHYDM_DBG(dm, DBG_PATH_DIV, "Return: Not Support PathDiv\n");
+		return;
+	}
+
+#if RTL8812A_SUPPORT
+	if (dm->support_ic_type & ODM_RTL8812)
+		odm_path_diversity_init_8812a(dm);
+	else
+#endif
+
+#if RTL8814A_SUPPORT
+		if (dm->support_ic_type & ODM_RTL8814A)
+			phydm_dynamic_tx_path_init(dm);
+		else
+#endif
+		{}
+#endif
+}
+
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+/*
+ * 2011/12/02 MH Copy from MP oursrc for temporarily test.
+ *   */
+
+void
+odm_path_div_chk_ant_switch_callback(
+	struct phydm_timer_list		*timer
+)
+{
+}
+
+void
+odm_path_div_chk_ant_switch_workitem_callback(
+	void            *context
+)
+{
+}
+
+void
+odm_cck_tx_path_diversity_callback(
+	struct phydm_timer_list		*timer
+)
+{
+}
+
+void
+odm_cck_tx_path_diversity_work_item_callback(
+	void            *context
+)
+{
+}
+u8
+odm_sw_ant_div_select_scan_chnl(
+	void	*adapter
+)
+{
+	return	0;
+}
+void
+odm_sw_ant_div_construct_scan_chnl(
+	void	*adapter,
+	u8		scan_chnl
+)
+{
+}
+
+#endif	/*  #if (DM_ODM_SUPPORT_TYPE == ODM_WIN) */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.h
index ca2116f43bdd..866f24825347 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pathdiv.h
@@ -1,324 +1,305 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMPATHDIV_H__
-#define    __PHYDMPATHDIV_H__
-/*#define PATHDIV_VERSION "2.0" //2014.11.04*/
-#define PATHDIV_VERSION	"3.0" /*2015.01.13 Dino*/
-
-#if(defined(CONFIG_PATH_DIVERSITY))
-#define USE_PATH_A_AS_DEFAULT_ANT   //for 8814 dynamic TX path selection
-
-#define	NUM_RESET_DTP_PERIOD 5
-#define	ANT_DECT_RSSI_TH 3 
-
-#define PATH_A 1
-#define PATH_B 2
-#define PATH_C 3
-#define PATH_D 4
-
-#define PHYDM_AUTO_PATH	0
-#define PHYDM_FIX_PATH		1
-
-#define NUM_CHOOSE2_FROM4 6
-#define NUM_CHOOSE3_FROM4 4
-
-
-#define		PHYDM_A		 BIT0
-#define		PHYDM_B		 BIT1
-#define		PHYDM_C		 BIT2
-#define		PHYDM_D		 BIT3
-#define		PHYDM_AB	 (BIT0 | BIT1)  // 0
-#define		PHYDM_AC	 (BIT0 | BIT2)  // 1
-#define		PHYDM_AD	 (BIT0 | BIT3)  // 2
-#define		PHYDM_BC	 (BIT1 | BIT2)  // 3
-#define		PHYDM_BD	 (BIT1 | BIT3)  // 4
-#define		PHYDM_CD	 (BIT2 | BIT3)  // 5
-
-#define		PHYDM_ABC	 (BIT0 | BIT1 | BIT2) /* 0*/
-#define		PHYDM_ABD	 (BIT0 | BIT1 | BIT3) /* 1*/
-#define		PHYDM_ACD	 (BIT0 | BIT2 | BIT3) /* 2*/
-#define		PHYDM_BCD	 (BIT1 | BIT2 | BIT3) /* 3*/
-
-#define		PHYDM_ABCD	 (BIT0 | BIT1 | BIT2 | BIT3)
-
-
-typedef enum dtp_state
-{
-	PHYDM_DTP_INIT=1,
-	PHYDM_DTP_RUNNING_1
-
-}PHYDM_DTP_STATE;
-
-typedef enum path_div_type
-{
-	PHYDM_2R_PATH_DIV = 1,
-	PHYDM_4R_PATH_DIV = 2
-}PHYDM_PATH_DIV_TYPE;
-
-VOID
-phydm_process_rssi_for_path_div(	
-	IN OUT		PVOID			pDM_VOID,	
-	IN			PVOID			p_phy_info_void,
-	IN			PVOID			p_pkt_info_void
-	);
-
-typedef struct _ODM_PATH_DIVERSITY_
-{
-	u1Byte	RespTxPath;
-	u1Byte	PathSel[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	PathA_Sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u4Byte	PathB_Sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u2Byte	PathA_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u2Byte	PathB_Cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u1Byte	path_div_type;
-  #if RTL8814A_SUPPORT
-	
-	u4Byte	path_a_sum_all;
-	u4Byte	path_b_sum_all;
-	u4Byte	path_c_sum_all;
-	u4Byte	path_d_sum_all;
-
-	u4Byte	path_a_cnt_all;
-	u4Byte	path_b_cnt_all;
-	u4Byte	path_c_cnt_all;
-	u4Byte	path_d_cnt_all;
-	
-	u1Byte	dtp_period;
-	BOOLEAN	bBecomeLinked;
-	BOOLEAN	is_u3_mode;
-	u1Byte	num_tx_path;
-	u1Byte	default_path;
-	u1Byte	num_candidate;
-	u1Byte	ant_candidate_1;
-	u1Byte	ant_candidate_2;
-	u1Byte	ant_candidate_3;
-	u1Byte     dtp_state;
-	u1Byte	dtp_check_patha_counter;
-	BOOLEAN	fix_path_bfer;
-	u1Byte	search_space_2[NUM_CHOOSE2_FROM4];
-	u1Byte	search_space_3[NUM_CHOOSE3_FROM4];
-	
-	u1Byte	pre_tx_path;
-	u1Byte	use_path_a_as_default_ant;
-	BOOLEAN is_pathA_exist;
-
-  #endif
-}PATHDIV_T, *pPATHDIV_T;
-
-
-#endif //#if(defined(CONFIG_PATH_DIVERSITY))
-
-VOID
-phydm_c2h_dtp_handler(
-	 IN	PVOID	pDM_VOID,
-	 IN 	pu1Byte   CmdBuf,
-	 IN 	u1Byte	CmdLen
-	);
-
-VOID
-odm_PathDiversityInit(
-	IN	PVOID	pDM_VOID
-	);
-
-VOID
-odm_PathDiversity(
-	IN	PVOID	pDM_VOID
-	);
-
-VOID
-odm_pathdiv_debug(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value,
-	IN		u4Byte		*_used,
-	OUT		char		*output,
-	IN		u4Byte		*_out_len
-	);
-
-
-
-//1 [OLD IC]--------------------------------------------------------------------------------
-
-
-
-
-
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) 
-
-//#define   PATHDIV_ENABLE 	 1
-#define dm_PathDiv_RSSI_Check	ODM_PathDivChkPerPktRssi
-#define PathDivCheckBeforeLink8192C	ODM_PathDiversityBeforeLink92C
-
-
-
-
-typedef struct _PathDiv_Parameter_define_
-{
-	u4Byte org_5g_RegE30;
-	u4Byte org_5g_RegC14;
-	u4Byte org_5g_RegCA0;
-	u4Byte swt_5g_RegE30;
-	u4Byte swt_5g_RegC14;
-	u4Byte swt_5g_RegCA0;
-	//for 2G IQK information
-	u4Byte org_2g_RegC80;
-	u4Byte org_2g_RegC4C;
-	u4Byte org_2g_RegC94;
-	u4Byte org_2g_RegC14;
-	u4Byte org_2g_RegCA0;
-
-	u4Byte swt_2g_RegC80;
-	u4Byte swt_2g_RegC4C;
-	u4Byte swt_2g_RegC94;
-	u4Byte swt_2g_RegC14;
-	u4Byte swt_2g_RegCA0;
-}PATHDIV_PARA,*pPATHDIV_PARA;
-
-VOID	
-odm_PathDiversityInit_92C(
-	IN	PADAPTER	Adapter
-	);
-
-VOID	
-odm_2TPathDiversityInit_92C(
-	IN	PADAPTER	Adapter
-	);
-
-VOID	
-odm_1TPathDiversityInit_92C(	
-	IN	PADAPTER	Adapter
-	);
-
-BOOLEAN
-odm_IsConnected_92C(
-	IN	PADAPTER	Adapter
-	);
-
-BOOLEAN 
-ODM_PathDiversityBeforeLink92C(
-	//IN	PADAPTER	Adapter
-	IN		PDM_ODM_T		pDM_Odm
-	);
-
-VOID	
-odm_PathDiversityAfterLink_92C(
-	IN	PADAPTER	Adapter
-	);
-
-VOID
-odm_SetRespPath_92C(	
-	IN	PADAPTER	Adapter, 	
-	IN	u1Byte	DefaultRespPath
-	);
-
-VOID	
-odm_OFDMTXPathDiversity_92C(
-	IN	PADAPTER	Adapter
-	);
-
-VOID	
-odm_CCKTXPathDiversity_92C(	
-	IN	PADAPTER	Adapter
-	);
-
-VOID	
-odm_ResetPathDiversity_92C(	
-	IN	PADAPTER	Adapter
-	);
-
-VOID
-odm_CCKTXPathDiversityCallback(
-	PRT_TIMER		pTimer
-	);
-
-VOID
-odm_CCKTXPathDiversityWorkItemCallback(
-	IN PVOID            pContext
-	);
-
-VOID
-odm_PathDivChkAntSwitchCallback(
-	PRT_TIMER		pTimer
-	);
-
-VOID
-odm_PathDivChkAntSwitchWorkitemCallback(
-	IN PVOID            pContext
-	);
-
-
-VOID 
-odm_PathDivChkAntSwitch(
-	PDM_ODM_T    pDM_Odm
-	);
-
-VOID
-ODM_CCKPathDiversityChkPerPktRssi(
-	PADAPTER		Adapter,
-	BOOLEAN			bIsDefPort,
-	BOOLEAN			bMatchBSSID,
-	PRT_WLAN_STA	pEntry,
-	PRT_RFD			pRfd,
-	pu1Byte			pDesc
-	);
-
-VOID 
-ODM_PathDivChkPerPktRssi(
-	PADAPTER		Adapter,
-	BOOLEAN			bIsDefPort,
-	BOOLEAN			bMatchBSSID,
-	PRT_WLAN_STA	pEntry,
-	PRT_RFD			pRfd	
-	);
-
-VOID
-ODM_PathDivRestAfterLink(
-	IN	PDM_ODM_T		pDM_Odm
-	);
-
-VOID
-ODM_FillTXPathInTXDESC(
-		IN	PADAPTER	Adapter,
-		IN	PRT_TCB		pTcb,
-		IN	pu1Byte		pDesc
-	);
-
-VOID
-odm_PathDivInit_92D(
-	IN	PDM_ODM_T 	pDM_Odm
-	);
-
-u1Byte
-odm_SwAntDivSelectScanChnl(
-	IN	PADAPTER	Adapter
-	);
-
-VOID
-odm_SwAntDivConstructScanChnl(
-	IN	PADAPTER	Adapter,
-	IN	u1Byte		ScanChnl
-	);
-	
- #endif       //#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) 
- 
- 
- #endif		 //#ifndef  __ODMPATHDIV_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMPATHDIV_H__
+#define    __PHYDMPATHDIV_H__
+/*#define PATHDIV_VERSION "2.0" //2014.11.04*/
+#define PATHDIV_VERSION	"3.1" /*2015.07.29 by YuChen*/
+
+#if (defined(CONFIG_PATH_DIVERSITY))
+#define USE_PATH_A_AS_DEFAULT_ANT   /* for 8814 dynamic TX path selection */
+
+#define	NUM_RESET_DTP_PERIOD 5
+#define	ANT_DECT_RSSI_TH 3
+
+#define PATH_A 1
+#define PATH_B 2
+#define PATH_C 3
+#define PATH_D 4
+
+#define PHYDM_AUTO_PATH	0
+#define PHYDM_FIX_PATH		1
+
+#define NUM_CHOOSE2_FROM4 6
+#define NUM_CHOOSE3_FROM4 4
+
+enum phydm_dtp_state {
+	PHYDM_DTP_INIT = 1,
+	PHYDM_DTP_RUNNING_1
+
+};
+
+enum phydm_path_div_type {
+	PHYDM_2R_PATH_DIV = 1,
+	PHYDM_4R_PATH_DIV = 2
+};
+
+void
+phydm_process_rssi_for_path_div(
+	void			*dm_void,
+	void			*phy_info_void,
+	void			*pkt_info_void
+);
+
+struct _ODM_PATH_DIVERSITY_ {
+	u8	resp_tx_path;
+	u8	path_sel[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	path_a_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	path_b_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	path_a_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	path_b_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u8	phydm_path_div_type;
+#if RTL8814A_SUPPORT
+
+	u32	path_a_sum_all;
+	u32	path_b_sum_all;
+	u32	path_c_sum_all;
+	u32	path_d_sum_all;
+
+	u32	path_a_cnt_all;
+	u32	path_b_cnt_all;
+	u32	path_c_cnt_all;
+	u32	path_d_cnt_all;
+
+	u8	dtp_period;
+	boolean	is_become_linked;
+	boolean	is_u3_mode;
+	u8	num_tx_path;
+	u8	default_path;
+	u8	num_candidate;
+	u8	ant_candidate_1;
+	u8	ant_candidate_2;
+	u8	ant_candidate_3;
+	u8     phydm_dtp_state;
+	u8	dtp_check_patha_counter;
+	boolean	fix_path_bfer;
+	u8	search_space_2[NUM_CHOOSE2_FROM4];
+	u8	search_space_3[NUM_CHOOSE3_FROM4];
+
+	u8	pre_tx_path;
+	u8	use_path_a_as_default_ant;
+	boolean is_path_a_exist;
+
+#endif
+};
+
+
+#endif /* #if(defined(CONFIG_PATH_DIVERSITY)) */
+
+void
+phydm_c2h_dtp_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8	cmd_len
+);
+
+void
+phydm_path_diversity_init(
+	void	*dm_void
+);
+
+void
+odm_path_diversity(
+	void	*dm_void
+);
+
+void
+odm_pathdiv_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+
+
+/* 1 [OLD IC]-------------------------------------------------------------------------------- */
+
+
+
+
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+/* #define   PATHDIV_ENABLE	 1 */
+#define dm_path_div_rssi_check	odm_path_div_chk_per_pkt_rssi
+#define path_div_check_before_link8192c	odm_path_diversity_before_link92c
+
+
+
+
+struct _path_div_parameter_define_ {
+	u32 org_5g_rege30;
+	u32 org_5g_regc14;
+	u32 org_5g_regca0;
+	u32 swt_5g_rege30;
+	u32 swt_5g_regc14;
+	u32 swt_5g_regca0;
+	/* for 2G IQK information */
+	u32 org_2g_regc80;
+	u32 org_2g_regc4c;
+	u32 org_2g_regc94;
+	u32 org_2g_regc14;
+	u32 org_2g_regca0;
+
+	u32 swt_2g_regc80;
+	u32 swt_2g_regc4c;
+	u32 swt_2g_regc94;
+	u32 swt_2g_regc14;
+	u32 swt_2g_regca0;
+};
+
+void
+odm_path_diversity_init_92c(
+	void	*adapter
+);
+
+void
+odm_2t_path_diversity_init_92c(
+	void	*adapter
+);
+
+void
+odm_1t_path_diversity_init_92c(
+	void	*adapter
+);
+
+boolean
+odm_is_connected_92c(
+	void	*adapter
+);
+
+boolean
+odm_path_diversity_before_link92c(
+	/* struct void*	adapter */
+	struct dm_struct		*dm
+);
+
+void
+odm_path_diversity_after_link_92c(
+	void	*adapter
+);
+
+void
+odm_set_resp_path_92c(
+	void	*adapter,
+	u8	default_resp_path
+);
+
+void
+odm_ofdm_tx_path_diversity_92c(
+	void	*adapter
+);
+
+void
+odm_cck_tx_path_diversity_92c(
+	void	*adapter
+);
+
+void
+odm_reset_path_diversity_92c(
+	void	*adapter
+);
+
+void
+odm_cck_tx_path_diversity_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_cck_tx_path_diversity_work_item_callback(
+	void            *context
+);
+
+void
+odm_path_div_chk_ant_switch_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+odm_path_div_chk_ant_switch_workitem_callback(
+	void            *context
+);
+
+
+void
+odm_path_div_chk_ant_switch(
+	struct dm_struct    *dm
+);
+
+void
+odm_cck_path_diversity_chk_per_pkt_rssi(
+	void		*adapter,
+	boolean			is_def_port,
+	boolean			is_match_bssid,
+	struct _WLAN_STA	*entry,
+	PRT_RFD			rfd,
+	u8			*desc
+);
+
+void
+odm_path_div_chk_per_pkt_rssi(
+	void		*adapter,
+	boolean			is_def_port,
+	boolean			is_match_bssid,
+	struct _WLAN_STA	*entry,
+	PRT_RFD			rfd
+);
+
+void
+odm_path_div_rest_after_link(
+	struct dm_struct		*dm
+);
+
+void
+odm_fill_tx_path_in_txdesc(
+	void	*adapter,
+	PRT_TCB		tcb,
+	u8		*desc
+);
+
+void
+odm_path_div_init_92d(
+	struct dm_struct	*dm
+);
+
+u8
+odm_sw_ant_div_select_scan_chnl(
+	void	*adapter
+);
+
+void
+odm_sw_ant_div_construct_scan_chnl(
+	void	*adapter,
+	u8		scan_chnl
+);
+
+#endif       /* #if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) */
+
+
+#endif		 /* #ifndef  __ODMPATHDIV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_phystatus.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_phystatus.c
new file mode 100644
index 000000000000..8ee4049aa595
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_phystatus.c
@@ -0,0 +1,2570 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_rx_statistic_cal(
+	struct dm_struct				*phydm,
+	struct phydm_phyinfo_struct			*phy_info,
+	u8									*phy_status_inf,
+	struct phydm_perpkt_info_struct				*pktinfo
+)
+{
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+	struct phy_status_rpt_jaguar2_type1	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type1 *)phy_status_inf;
+	u8		phy_status_type = (*phy_status_inf & 0xf);
+#endif
+	u8									date_rate = (pktinfo->data_rate & 0x7f);
+	u8		bw_idx = phy_info->band_width ;
+
+	if (date_rate <= ODM_RATE54M) {
+		phydm->phy_dbg_info.num_qry_legacy_pkt[date_rate]++;
+		/**/
+	} else if (date_rate <= ODM_RATEMCS31) {
+		phydm->phy_dbg_info.ht_pkt_not_zero = true;
+
+		if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+			if ((bw_idx == *phydm->band_width)) {
+				
+				phydm->phy_dbg_info.num_qry_ht_pkt[date_rate - ODM_RATEMCS0]++;
+
+			} else if (bw_idx == CHANNEL_WIDTH_20) {
+			
+				phydm->phy_dbg_info.num_qry_pkt_sc_20m[date_rate - ODM_RATEMCS0]++;
+				phydm->phy_dbg_info.low_bw_20_occur = true;
+			}
+		} else {
+			phydm->phy_dbg_info.num_qry_ht_pkt[date_rate - ODM_RATEMCS0]++;
+		}
+	}
+	#if ODM_IC_11AC_SERIES_SUPPORT
+	else if (date_rate <= ODM_RATEVHTSS4MCS9) {
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		if ((phy_status_type == 1) && 
+			(phy_sta_rpt->gid != 0) && 
+			(phy_sta_rpt->gid != 63) && 
+			(phydm->support_ic_type & PHYSTS_2ND_TYPE_IC)) {
+			phydm->phy_dbg_info.num_qry_mu_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
+			if (pktinfo->ppdu_cnt < 4) {
+				phydm->phy_dbg_info.num_of_ppdu[pktinfo->ppdu_cnt] = date_rate | BIT(7);
+				phydm->phy_dbg_info.gid_num[pktinfo->ppdu_cnt] = phy_sta_rpt->gid;
+			}
+		} else
+		#endif
+		{
+			phydm->phy_dbg_info.vht_pkt_not_zero = true;
+			
+			if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+				if ((bw_idx == *phydm->band_width)) {
+					phydm->phy_dbg_info.num_qry_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
+
+				} else if (bw_idx == CHANNEL_WIDTH_20) {
+					phydm->phy_dbg_info.num_qry_pkt_sc_20m[date_rate - ODM_RATEVHTSS1MCS0]++;
+					phydm->phy_dbg_info.low_bw_20_occur = true;
+				} else /*if (bw_idx == CHANNEL_WIDTH_40)*/ {
+					phydm->phy_dbg_info.num_qry_pkt_sc_40m[date_rate - ODM_RATEVHTSS1MCS0]++;
+					phydm->phy_dbg_info.low_bw_40_occur = true;
+				}
+			} else {
+				phydm->phy_dbg_info.num_qry_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
+			}
+
+			#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+			if (pktinfo->ppdu_cnt < 4) {
+				phydm->phy_dbg_info.num_of_ppdu[pktinfo->ppdu_cnt] = date_rate;
+				phydm->phy_dbg_info.gid_num[pktinfo->ppdu_cnt] = phy_sta_rpt->gid;
+			}
+			#endif
+		}
+	}
+	#endif
+}
+
+void
+phydm_reset_phystatus_avg(
+	struct dm_struct	*dm
+)
+{
+	struct phydm_phystatus_avg		*dbg_avg = &dm->phy_dbg_info.phystatus_statistic_avg;
+
+	odm_memory_set(dm, &dbg_avg->rssi_cck_avg, 0,
+		       sizeof(struct phydm_phystatus_avg));
+}
+
+void
+phydm_reset_phystatus_statistic(
+	struct dm_struct	*dm
+)
+{
+	struct phydm_phystatus_statistic		*dbg_statistic = &dm->phy_dbg_info.phystatus_statistic_info;
+
+	odm_memory_set(dm, &dbg_statistic->rssi_cck_sum, 0,
+		       sizeof(struct phydm_phystatus_statistic));
+}
+
+void
+phydm_avg_phystatus_index(
+	struct dm_struct			*dm,
+	struct phydm_phyinfo_struct		*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	struct phydm_phystatus_statistic		*dbg_statistic = &dm->phy_dbg_info.phystatus_statistic_info;
+
+	if (pktinfo->data_rate <= ODM_RATE11M) {
+		/*RSSI*/
+		dbg_statistic->rssi_cck_sum += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_cck_cnt++;
+	} else if (pktinfo->data_rate <= ODM_RATE54M) {
+		/*evm*/
+		dbg_statistic->evm_ofdm_sum += phy_info->rx_mimo_evm_dbm[0];
+
+		/*SNR*/
+		dbg_statistic->snr_ofdm_sum += phy_info->rx_snr[0];
+
+		/*RSSI*/
+		dbg_statistic->rssi_ofdm_sum += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_ofdm_cnt++;
+	} else if (pktinfo->rate_ss == 1) {
+		/*evm*/
+		dbg_statistic->evm_1ss_sum += phy_info->rx_mimo_evm_dbm[0];
+
+		/*SNR*/
+		dbg_statistic->snr_1ss_sum += phy_info->rx_snr[0];
+
+		dbg_statistic->rssi_1ss_sum += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_1ss_cnt++;
+	} else if (pktinfo->rate_ss == 2) {
+		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		/*evm*/
+		dbg_statistic->evm_2ss_sum[0] += phy_info->rx_mimo_evm_dbm[0];
+		dbg_statistic->evm_2ss_sum[1] += phy_info->rx_mimo_evm_dbm[1];
+
+		/*SNR*/
+		dbg_statistic->snr_2ss_sum[0] += phy_info->rx_snr[0];
+		dbg_statistic->snr_2ss_sum[1] += phy_info->rx_snr[1];
+
+		/*RSSI*/
+		dbg_statistic->rssi_2ss_sum[0] += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_2ss_sum[1] += phy_info->rx_mimo_signal_strength[1];
+		dbg_statistic->rssi_2ss_cnt++;
+		#endif
+	} else if (pktinfo->rate_ss == 3) {
+		#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+		/*evm*/
+		dbg_statistic->evm_3ss_sum[0] += phy_info->rx_mimo_evm_dbm[0];
+		dbg_statistic->evm_3ss_sum[1] += phy_info->rx_mimo_evm_dbm[1];
+		dbg_statistic->evm_3ss_sum[2] += phy_info->rx_mimo_evm_dbm[2];
+
+		/*SNR*/
+		dbg_statistic->snr_3ss_sum[0] += phy_info->rx_snr[0];
+		dbg_statistic->snr_3ss_sum[1] += phy_info->rx_snr[1];
+		dbg_statistic->snr_3ss_sum[2] += phy_info->rx_snr[2];
+
+		/*RSSI*/
+		dbg_statistic->rssi_3ss_sum[0] += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_3ss_sum[1] += phy_info->rx_mimo_signal_strength[1];
+		dbg_statistic->rssi_3ss_sum[2] += phy_info->rx_mimo_signal_strength[2];
+		dbg_statistic->rssi_3ss_cnt++;
+		#endif
+	} else if (pktinfo->rate_ss == 4) {
+		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		/*evm*/
+		dbg_statistic->evm_4ss_sum[0] += phy_info->rx_mimo_evm_dbm[0];
+		dbg_statistic->evm_4ss_sum[1] += phy_info->rx_mimo_evm_dbm[1];
+		dbg_statistic->evm_4ss_sum[2] += phy_info->rx_mimo_evm_dbm[2];
+		dbg_statistic->evm_4ss_sum[3] += phy_info->rx_mimo_evm_dbm[3];
+
+		/*SNR*/
+		dbg_statistic->snr_4ss_sum[0] += phy_info->rx_snr[0];
+		dbg_statistic->snr_4ss_sum[1] += phy_info->rx_snr[1];
+		dbg_statistic->snr_4ss_sum[2] += phy_info->rx_snr[2];
+		dbg_statistic->snr_4ss_sum[3] += phy_info->rx_snr[3];
+
+		/*RSSI*/
+		dbg_statistic->rssi_4ss_sum[0] += phy_info->rx_mimo_signal_strength[0];
+		dbg_statistic->rssi_4ss_sum[1] += phy_info->rx_mimo_signal_strength[1];
+		dbg_statistic->rssi_4ss_sum[2] += phy_info->rx_mimo_signal_strength[2];
+		dbg_statistic->rssi_4ss_sum[3] += phy_info->rx_mimo_signal_strength[3];
+		dbg_statistic->rssi_4ss_cnt++;
+		#endif
+	}
+}
+
+u8 phydm_get_signal_quality(
+	struct phydm_phyinfo_struct *phy_info,
+	struct dm_struct *dm,
+	struct phy_status_rpt_8192cd *phy_sta_rpt
+	)
+{
+	u8 sq_rpt;
+	u8 result = 0;
+
+	if (phy_info->rx_pwdb_all > 40 && !dm->is_in_hct_test)
+		result = 100;
+	else {
+		sq_rpt = phy_sta_rpt->cck_sig_qual_ofdm_pwdb_all;
+
+		if (sq_rpt > 64)
+			result = 0;
+		else if (sq_rpt < 20)
+			result = 100;
+		else
+			result = ((64 - sq_rpt) * 100) / 44;
+
+	}
+
+	return result;
+}
+
+u8
+phydm_query_rx_pwr_percentage(
+	s8		ant_power
+)
+{
+	if ((ant_power <= -100) || (ant_power >= 20))
+		return	0;
+	else if (ant_power >= 0)
+		return	100;
+	else
+		return 100 + ant_power;
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+s32
+phydm_signal_scale_mapping_92c_series(
+	struct dm_struct *dm,
+	s32 curr_sig
+)
+{
+	s32 ret_sig = 0;
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	if (dm->support_interface  == ODM_ITRF_PCIE) {
+		/* step 1. Scale mapping. */
+		if (curr_sig >= 61 && curr_sig <= 100)
+			ret_sig = 90 + ((curr_sig - 60) / 4);
+		else if (curr_sig >= 41 && curr_sig <= 60)
+			ret_sig = 78 + ((curr_sig - 40) / 2);
+		else if (curr_sig >= 31 && curr_sig <= 40)
+			ret_sig = 66 + (curr_sig - 30);
+		else if (curr_sig >= 21 && curr_sig <= 30)
+			ret_sig = 54 + (curr_sig - 20);
+		else if (curr_sig >= 5 && curr_sig <= 20)
+			ret_sig = 42 + (((curr_sig - 5) * 2) / 3);
+		else if (curr_sig == 4)
+			ret_sig = 36;
+		else if (curr_sig == 3)
+			ret_sig = 27;
+		else if (curr_sig == 2)
+			ret_sig = 18;
+		else if (curr_sig == 1)
+			ret_sig = 9;
+		else
+			ret_sig = curr_sig;
+	}
+#endif
+
+#if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
+	if ((dm->support_interface  == ODM_ITRF_USB) || (dm->support_interface  == ODM_ITRF_SDIO)) {
+		if (curr_sig >= 51 && curr_sig <= 100)
+			ret_sig = 100;
+		else if (curr_sig >= 41 && curr_sig <= 50)
+			ret_sig = 80 + ((curr_sig - 40) * 2);
+		else if (curr_sig >= 31 && curr_sig <= 40)
+			ret_sig = 66 + (curr_sig - 30);
+		else if (curr_sig >= 21 && curr_sig <= 30)
+			ret_sig = 54 + (curr_sig - 20);
+		else if (curr_sig >= 10 && curr_sig <= 20)
+			ret_sig = 42 + (((curr_sig - 10) * 2) / 3);
+		else if (curr_sig >= 5 && curr_sig <= 9)
+			ret_sig = 22 + (((curr_sig - 5) * 3) / 2);
+		else if (curr_sig >= 1 && curr_sig <= 4)
+			ret_sig = 6 + (((curr_sig - 1) * 3) / 2);
+		else
+			ret_sig = curr_sig;
+	}
+
+#endif
+	return ret_sig;
+}
+
+s32
+phydm_signal_scale_mapping(
+	struct dm_struct *dm,
+	s32 curr_sig
+)
+{
+	#ifdef CONFIG_SIGNAL_SCALE_MAPPING
+		return phydm_signal_scale_mapping_92c_series(dm, curr_sig);
+	#else
+		return curr_sig;
+	#endif
+
+}
+#endif
+
+void
+phydm_process_signal_strength(
+	struct dm_struct				*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	u8		avg_rssi = 0, tmp_rssi = 0, best_rssi = 0, second_rssi = 0;
+	u8		i;
+
+	/* 2015/01 Sean, use the best two RSSI only, suggested by Ynlin and ChenYu.*/
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		
+		tmp_rssi = phy_info->rx_mimo_signal_strength[i];
+
+		/*Get the best two RSSI*/
+		if (tmp_rssi > best_rssi && tmp_rssi > second_rssi) {
+			second_rssi = best_rssi;
+			best_rssi = tmp_rssi;
+		} else if (tmp_rssi > second_rssi && tmp_rssi <= best_rssi)
+			second_rssi = tmp_rssi;
+	}
+
+	if (best_rssi == 0)
+		return;
+
+	avg_rssi = (pktinfo->rate_ss == 1) ? best_rssi : ((best_rssi + second_rssi) >> 1);
+
+	if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		
+		/* Update signal strength to UI, and phy_info->rx_pwdb_all is the maximum RSSI of all path */
+		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, phy_info->rx_pwdb_all, false, false);
+		#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, phy_info->rx_pwdb_all));
+		#endif
+
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+
+		/*UI BSS List signal strength(in percentage), make it good looking, from 0~100.*/
+		/*It is assigned to the BSS List in GetValueFromBeaconOrProbeRsp().*/
+		if (pktinfo->is_cck_rate) {
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			/*2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/
+			phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, phy_info->rx_pwdb_all, false, true);
+			#else
+			phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, phy_info->rx_pwdb_all));/*pwdb_all;*/
+			#endif
+		} else {
+		
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/
+			phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, avg_rssi, false, false);
+			#else
+			phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, avg_rssi));
+			#endif
+		}
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+	#if	ODM_IC_11N_SERIES_SUPPORT
+
+		/* UI BSS List signal strength(in percentage), make it good looking, from 0~100. */
+		/* It is assigned to the BSS List in GetValueFromBeaconOrProbeRsp(). */
+		if (pktinfo->is_cck_rate) {
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/ */
+			phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, phy_info->rx_pwdb_all, true, true);
+			#else
+			phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, phy_info->rx_pwdb_all));/*pwdb_all;*/
+			#endif
+		} else {
+						
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+				/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/ */
+				phy_info->signal_strength = SignalScaleProc((PADAPTER)dm->adapter, avg_rssi, true, false);
+			#else
+				phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(dm, avg_rssi));
+			#endif
+		}
+	#endif
+	}
+}
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+static u8 phydm_sq_patch_rt_cid_819x_lenovo(
+	struct dm_struct	*dm,
+	u8		is_cck_rate,
+	u8		pwdb_all,
+	u8		path,
+	u8		RSSI
+)
+{
+	u8	sq = 0;
+
+	if (is_cck_rate) {
+		if (IS_HARDWARE_TYPE_8192E(dm->adapter)) {
+			/*  */
+			/* <Roger_Notes> Expected signal strength and bars indication at Lenovo lab. 2013.04.11 */
+			/* 802.11n, 802.11b, 802.11g only at channel 6 */
+			/*  */
+			/*		Attenuation (dB)	OS Signal Bars	RSSI by Xirrus (dBm) */
+			/*			50				5			-49 */
+			/*			55				5			-49 */
+			/*			60				5			-50 */
+			/*			65				5			-51 */
+			/*			70				5			-52 */
+			/*			75				5			-54 */
+			/*			80				5			-55 */
+			/*			85				4			-60 */
+			/*			90				3			-63 */
+			/*			95				3			-65 */
+			/*			100				2			-67 */
+			/*			102				2			-67 */
+			/*			104				1			-70 */
+			/*  */
+
+			if (pwdb_all >= 50)
+				sq = 100;
+			else if (pwdb_all >= 35 && pwdb_all < 50)
+				sq = 80;
+			else if (pwdb_all >= 31 && pwdb_all < 35)
+				sq = 60;
+			else if (pwdb_all >= 22 && pwdb_all < 31)
+				sq = 40;
+			else if (pwdb_all >= 18 && pwdb_all < 22)
+				sq = 20;
+			else
+				sq = 10;
+		} else {
+			if (pwdb_all >= 50)
+				sq = 100;
+			else if (pwdb_all >= 35 && pwdb_all < 50)
+				sq = 80;
+			else if (pwdb_all >= 22 && pwdb_all < 35)
+				sq = 60;
+			else if (pwdb_all >= 18 && pwdb_all < 22)
+				sq = 40;
+			else
+				sq = 10;
+		}
+
+	} else {
+		/* OFDM rate */
+
+		if (IS_HARDWARE_TYPE_8192E(dm->adapter)) {
+			if (RSSI >= 45)
+				sq = 100;
+			else if (RSSI >= 22 && RSSI < 45)
+				sq = 80;
+			else if (RSSI >= 18 && RSSI < 22)
+				sq = 40;
+			else
+				sq = 20;
+		} else {
+			if (RSSI >= 45)
+				sq = 100;
+			else if (RSSI >= 22 && RSSI < 45)
+				sq = 80;
+			else if (RSSI >= 18 && RSSI < 22)
+				sq = 40;
+			else
+				sq = 20;
+		}
+	}
+
+	RT_TRACE(COMP_DBG, DBG_TRACE, ("is_cck_rate(%#d), pwdb_all(%#d), RSSI(%#d), sq(%#d)\n", is_cck_rate, pwdb_all, RSSI, sq));
+
+
+	return sq;
+}
+
+static u8 phydm_sq_patch_rt_cid_819x_acer(
+	struct dm_struct	*dm,
+	u8		is_cck_rate,
+	u8		pwdb_all,
+	u8		path,
+	u8		RSSI
+)
+{
+	u8	sq = 0;
+
+	if (is_cck_rate) {
+		RT_TRACE(COMP_DBG, DBG_WARNING, ("odm_SQ_process_patch_RT_Acer\n"));
+
+#if OS_WIN_FROM_WIN8(OS_VERSION)
+
+		if (pwdb_all >= 50)
+			sq = 100;
+		else if (pwdb_all >= 35 && pwdb_all < 50)
+			sq = 80;
+		else if (pwdb_all >= 30 && pwdb_all < 35)
+			sq = 60;
+		else if (pwdb_all >= 25 && pwdb_all < 30)
+			sq = 40;
+		else if (pwdb_all >= 20 && pwdb_all < 25)
+			sq = 20;
+		else
+			sq = 10;
+#else
+		if (pwdb_all >= 50)
+			sq = 100;
+		else if (pwdb_all >= 35 && pwdb_all < 50)
+			sq = 80;
+		else if (pwdb_all >= 30 && pwdb_all < 35)
+			sq = 60;
+		else if (pwdb_all >= 25 && pwdb_all < 30)
+			sq = 40;
+		else if (pwdb_all >= 20 && pwdb_all < 25)
+			sq = 20;
+		else
+			sq = 10;
+
+		if (pwdb_all == 0) /* Abnormal case, do not indicate the value above 20 on Win7 */
+			sq = 20;
+#endif
+
+
+
+	} else {
+		/* OFDM rate */
+
+		if (IS_HARDWARE_TYPE_8192E(dm->adapter)) {
+			if (RSSI >= 45)
+				sq = 100;
+			else if (RSSI >= 22 && RSSI < 45)
+				sq = 80;
+			else if (RSSI >= 18 && RSSI < 22)
+				sq = 40;
+			else
+				sq = 20;
+		} else {
+			if (RSSI >= 35)
+				sq = 100;
+			else if (RSSI >= 30 && RSSI < 35)
+				sq = 80;
+			else if (RSSI >= 25 && RSSI < 30)
+				sq = 40;
+			else
+				sq = 20;
+		}
+	}
+
+	RT_TRACE(COMP_DBG, DBG_LOUD, ("is_cck_rate(%#d), pwdb_all(%#d), RSSI(%#d), sq(%#d)\n", is_cck_rate, pwdb_all, RSSI, sq));
+
+
+	return sq;
+}
+#endif
+
+static u8
+phydm_evm_db_to_percentage(
+	s8 value
+)
+{
+	/*  */
+	/* -33dB~0dB to 0%~99% */
+	/*  */
+	s8 ret_val;
+
+	ret_val = value;
+	ret_val /= 2;
+
+	/*dbg_print("value=%d\n", value);*/
+	/*ODM_RT_DISP(FRX, RX_PHY_SQ, ("EVMdbToPercentage92C value=%d / %x\n", ret_val, ret_val));*/
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	if (ret_val >= 0)
+		ret_val = 0;
+
+	if (ret_val <= -40)
+		ret_val = -40;
+
+	ret_val = 0 - ret_val;
+	ret_val *= 3;
+#else
+	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;
+#endif
+
+	return (u8)ret_val;
+}
+
+static u8
+phydm_evm_dbm_jaguar_series(
+	s8 value
+)
+{
+	s8 ret_val = value;
+
+	/* -33dB~0dB to 33dB ~ 0dB */
+	if (ret_val == -128)
+		ret_val = 127;
+	else if (ret_val < 0)
+		ret_val = 0 - ret_val;
+
+	ret_val  = ret_val >> 1;
+	return (u8)ret_val;
+}
+
+static s16
+phydm_cfo(
+	s8 value
+)
+{
+	s16  ret_val;
+
+	if (value < 0) {
+		ret_val = 0 - value;
+		ret_val = (ret_val << 1) + (ret_val >> 1) ;  /* *2.5~=312.5/2^7 */
+		ret_val = ret_val | BIT(12);  /* set bit12 as 1 for negative cfo */
+	} else {
+		ret_val = value;
+		ret_val = (ret_val << 1) + (ret_val >> 1) ; /* *2.5~=312.5/2^7 */
+	}
+	return ret_val;
+}
+
+s8
+phydm_cck_rssi_convert(
+	struct dm_struct	*dm,
+	u16		lna_idx,
+	u8		vga_idx
+)
+{
+	return (dm->cck_lna_gain_table[lna_idx] - (vga_idx << 1));
+}
+
+void
+phydm_get_cck_rssi_table_from_reg(
+	struct dm_struct	*dm
+)
+{
+	u8	used_lna_idx_tmp;
+	u32	reg_0xa80 = 0x7431, reg_0xabc = 0xcbe5edfd; /*example: {-53, -43, -33, -27, -19, -13, -3, 1}*/ /*{0xCB, 0xD5, 0xDF, 0xE5, 0xED, 0xF3, 0xFD, 0x2}*/
+	u8	i;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "CCK LNA Gain table init\n");
+
+	if (!(dm->support_ic_type & (ODM_RTL8197F)))
+		return;
+
+	reg_0xa80 = odm_get_bb_reg(dm, 0xa80, 0xFFFF);
+	reg_0xabc = odm_get_bb_reg(dm, 0xabc, MASKDWORD);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "reg_0xa80 = 0x%x\n", reg_0xa80);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "reg_0xabc = 0x%x\n", reg_0xabc);
+
+	for (i = 0; i <= 3; i++) {
+		used_lna_idx_tmp = (u8)((reg_0xa80 >> (4*i)) & 0x7);
+		dm->cck_lna_gain_table[used_lna_idx_tmp] = (s8)((reg_0xabc >> (8*i)) & 0xff);
+	}
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "cck_lna_gain_table = {%d,%d,%d,%d,%d,%d,%d,%d}\n",
+		dm->cck_lna_gain_table[0],
+		dm->cck_lna_gain_table[1],
+		dm->cck_lna_gain_table[2],
+		dm->cck_lna_gain_table[3],
+		dm->cck_lna_gain_table[4],
+		dm->cck_lna_gain_table[5],
+		dm->cck_lna_gain_table[6],
+		dm->cck_lna_gain_table[7]);
+
+}
+
+u8
+phydm_rate_to_num_ss(
+	struct dm_struct		*dm,
+	u8			data_rate
+)
+{
+	u8	num_ss = 1;
+
+	if (data_rate  <= ODM_RATE54M)
+		num_ss = 1;
+	else if (data_rate  <= ODM_RATEMCS31)
+		num_ss = ((data_rate  - ODM_RATEMCS0) >> 3) + 1;
+	else if (data_rate  <= ODM_RATEVHTSS1MCS9)
+		num_ss = 1;
+	else if (data_rate  <= ODM_RATEVHTSS2MCS9)
+		num_ss = 2;
+	else if (data_rate  <= ODM_RATEVHTSS3MCS9)
+		num_ss = 3;
+	else if (data_rate  <= ODM_RATEVHTSS4MCS9)
+		num_ss = 4;
+
+	return num_ss;
+}
+
+
+
+#if (RTL8703B_SUPPORT == 1)
+s8
+phydm_cck_rssi_8703B(
+	u16	LNA_idx,
+	u8	VGA_idx
+)
+{
+	s8	rx_pwr_all = 0x00;
+
+	switch (LNA_idx) {
+	case 0xf:
+		rx_pwr_all = -48 - (2 * VGA_idx);
+		break;
+	case 0xb:
+		rx_pwr_all = -42 - (2 * VGA_idx); /*TBD*/
+		break;
+	case 0xa:
+		rx_pwr_all = -36 - (2 * VGA_idx);
+		break;
+	case 8:
+		rx_pwr_all = -32 - (2 * VGA_idx);
+		break;
+	case 7:
+		rx_pwr_all = -19 - (2 * VGA_idx);
+		break;
+	case 4:
+		rx_pwr_all = -6 - (2 * VGA_idx);
+		break;
+	case 0:
+		rx_pwr_all = -2 - (2 * VGA_idx);
+		break;
+	default:
+		/*rx_pwr_all = -53+(2*(31-VGA_idx));*/
+		/*dbg_print("wrong LNA index\n");*/
+		break;
+
+	}
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8195A_SUPPORT == 1)
+s8
+phydm_cck_rssi_8195a(
+	struct dm_struct	*dm,
+	u16		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {0, -8, -15, -22, -29, -36, -45, -54};
+	s8	lna_gain_table_1[8] = {0, -8, -15, -22, -29, -36, -45, -54};/*use 8195A to calibrate this table. 2016.06.24, Dino*/
+
+	if (dm->cck_agc_report_type == 0)
+		lna_gain = lna_gain_table_0[LNA_idx];
+	else
+		lna_gain = lna_gain_table_1[LNA_idx];
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+s8
+phydm_cck_rssi_8192e(
+	struct dm_struct	*dm,
+	u16		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {15, 9, -10, -21, -23, -27, -43, -44};
+	s8	lna_gain_table_1[8] = {24, 18, 13, -4, -11, -18, -31, -36};/*use 8192EU to calibrate this table. 2015.12.15, Dino*/
+
+	if (dm->cck_agc_report_type == 0)
+		lna_gain = lna_gain_table_0[LNA_idx];
+	else
+		lna_gain = lna_gain_table_1[LNA_idx];
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+s8
+phydm_cck_rssi_8188e(
+	struct dm_struct	*dm,
+	u16		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {17, -1, -13, -29, -32, -35, -38, -41};/*only use lna0/1/2/3/7*/
+	s8	lna_gain_table_1[8] = {29, 20, 12, 3, -6, -15, -24, -33}; /*only use lna3 /7*/
+	s8	lna_gain_table_2[8] = {17, -1, -13, -17, -32, -43, -38, -47};/*only use lna1/3/5/7*/
+
+	if (dm->cut_version >= ODM_CUT_I) {	/*SMIC*/
+		if (dm->ext_lna == 0x1) {
+			switch (dm->type_glna) {
+				case 0x2:	/*eLNA 14dB*/
+					lna_gain = lna_gain_table_2[LNA_idx];
+					break;
+				default:
+					lna_gain = lna_gain_table_0[LNA_idx];
+					break;
+			}
+		} else {
+			lna_gain = lna_gain_table_0[LNA_idx];
+		}
+	} else {	 /*TSMC*/
+		lna_gain = lna_gain_table_1[LNA_idx];
+	}
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+s8
+phydm_cck_rssi_8821c(
+	struct dm_struct	*dm,
+	u8		LNA_idx,
+	u8		VGA_idx
+)
+{
+	s8	rx_pwr_all = 0;
+	s8	lna_gain = 0;
+	s8	lna_gain_table_0[8] = {22, 8, -6, -22, -31, -40, -46, -52};/*only use lna2/3/5/7*/
+	s8	lna_gain_table_1[16] = {10, 6, 2, -2, -6, -10, -14, -17,
+		-20, -24, -28, -31, -34, -37, -40, -44}; /*only use lna4/8/C/F*/
+
+	if (dm->cck_agc_report_type == 0)
+		lna_gain = lna_gain_table_0[LNA_idx];
+	else
+		lna_gain = lna_gain_table_1[LNA_idx];
+
+	rx_pwr_all = lna_gain - (2 * VGA_idx);
+
+	return	rx_pwr_all;
+}
+#endif
+
+#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+void
+phydm_rx_phy_status92c_series_parsing(
+	struct dm_struct					*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	u8						*phy_status_inf,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	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				rf_rx_num = 0;
+	u8				LNA_idx = 0;
+	u8				VGA_idx = 0;
+	u8				cck_agc_rpt;
+	u8				stream_rxevm_tmp = 0;
+	u8				sq;
+	struct phy_status_rpt_8192cd *phy_sta_rpt = (struct phy_status_rpt_8192cd *)phy_status_inf;
+
+	if (pktinfo->is_to_self)
+		dm->curr_station_id = pktinfo->station_id;
+
+	if (pktinfo->is_cck_rate) {
+		
+		cck_agc_rpt = phy_sta_rpt->cck_agc_rpt_ofdm_cfosho_a;
+
+		if (dm->support_ic_type & (ODM_RTL8703B)) {
+#if (RTL8703B_SUPPORT == 1)
+			if (dm->cck_agc_report_type == 1) {  /*4 bit LNA*/
+
+				u8 cck_agc_rpt_b = (phy_sta_rpt->cck_rpt_b_ofdm_cfosho_b & BIT(7)) ? 1 : 0;
+
+				LNA_idx = (cck_agc_rpt_b << 3) | ((cck_agc_rpt & 0xE0) >> 5);
+				VGA_idx = (cck_agc_rpt & 0x1F);
+
+				rx_pwr_all = phydm_cck_rssi_8703B(LNA_idx, VGA_idx);
+			}
+#endif
+		} else { /*3 bit LNA*/
+
+			LNA_idx = ((cck_agc_rpt & 0xE0) >> 5);
+			VGA_idx = (cck_agc_rpt & 0x1F);
+
+			if (dm->support_ic_type & (ODM_RTL8188E)) {
+#if (RTL8188E_SUPPORT == 1)
+				rx_pwr_all = phydm_cck_rssi_8188e(dm, LNA_idx, VGA_idx);
+				/**/
+#endif
+			}
+#if (RTL8192E_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8192E)) {
+				rx_pwr_all = phydm_cck_rssi_8192e(dm, LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+#if (RTL8723B_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8723B)) {
+				rx_pwr_all = odm_CCKRSSI_8723B(LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+#if (RTL8188F_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8188F)) {
+				rx_pwr_all = odm_CCKRSSI_8188F(LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+#if (RTL8195A_SUPPORT == 1)
+			else if (dm->support_ic_type & (ODM_RTL8195A)) {
+				rx_pwr_all = phydm_cck_rssi_8195a(LNA_idx, VGA_idx);
+				/**/
+			}
+#endif
+		}
+
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "ext_lna_gain (( %d )), LNA_idx: (( 0x%x )), VGA_idx: (( 0x%x )), rx_pwr_all: (( %d ))\n",
+			dm->ext_lna_gain, LNA_idx, VGA_idx, rx_pwr_all);
+
+#if ~(RTL8188E_SUPPORT == 1)
+		if (dm->board_type & ODM_BOARD_EXT_LNA)
+			rx_pwr_all -= dm->ext_lna_gain;
+#endif
+
+		pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+		if (pktinfo->is_to_self) {
+			dm->cck_lna_idx = LNA_idx;
+			dm->cck_vga_idx = VGA_idx;
+		}
+		
+		phy_info->rx_pwdb_all = pwdb_all;
+		phy_info->bt_rx_rssi_percentage = pwdb_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+		
+		/* (3) Get Signal Quality (EVM) */
+		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO)
+			sq = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+		else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER)
+			sq = phydm_sq_patch_rt_cid_819x_acer(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+		else
+		#endif
+			sq = phydm_get_signal_quality(phy_info, dm, phy_sta_rpt);
+
+		/* dbg_print("cck sq = %d\n", sq); */
+		phy_info->signal_quality = sq;
+		phy_info->rx_mimo_signal_quality[RF_PATH_A] = sq;
+		phy_info->rx_mimo_signal_quality[RF_PATH_B] = -1;
+		
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			if (i == 0)
+				phy_info->rx_mimo_signal_strength[0] = pwdb_all;
+			else
+				phy_info->rx_mimo_signal_strength[i] = 0;
+		}
+	} else { /* 2 is OFDM rate */
+
+		/*  */
+		/* (1)Get RSSI for HT rate */
+		/*  */
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH_N; i++) {
+			
+			if (dm->rf_path_rx_enable & BIT(i))
+				rf_rx_num++;
+
+			rx_pwr[i] = ((phy_sta_rpt->path_agc[i].gain & 0x3F) * 2) - 110;
+
+			if (pktinfo->is_to_self) {
+				dm->ofdm_agc_idx[i] = (phy_sta_rpt->path_agc[i].gain & 0x3F);
+				/**/
+			}
+
+			phy_info->rx_pwr[i] = rx_pwr[i];
+			RSSI = phydm_query_rx_pwr_percentage(rx_pwr[i]);
+			total_rssi += RSSI;
+			/* RT_DISP(FRX, RX_PHY_SS, ("RF-%d RXPWR=%x RSSI=%d\n", i, rx_pwr[i], RSSI)); */
+
+			phy_info->rx_mimo_signal_strength[i] = (u8) RSSI;
+
+			/* Get Rx snr value in DB */
+			phy_info->rx_snr[i] = (s8)(phy_sta_rpt->path_rxsnr[i] / 2);
+
+			/* Record Signal Strength for next packet */
+
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			if (i == RF_PATH_A) {
+				if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+					phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, i, RSSI);
+				} else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER)
+					phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_acer(dm, pktinfo->is_cck_rate, pwdb_all, 0, RSSI);
+			}
+			#endif
+		}
+
+		/* (2)PWDB, Average PWDB calculated by hardware (for rate adaptive) */
+		rx_pwr_all = (((phy_sta_rpt->cck_sig_qual_ofdm_pwdb_all) >> 1) & 0x7f) - 110;
+
+		pwdb_all_bt = pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+		phy_info->rx_pwdb_all = pwdb_all;
+		phy_info->bt_rx_rssi_percentage = pwdb_all_bt;
+		phy_info->rx_power = rx_pwr_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+			/* do nothing */
+		} else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER) {
+			/* do nothing */
+		} else {
+#endif
+		/* (3)EVM of HT rate */
+
+		if (pktinfo->data_rate >= ODM_RATEMCS8 && pktinfo->data_rate <= ODM_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 = phydm_evm_db_to_percentage((phy_sta_rpt->stream_rxevm[i]));	/* dbm */
+
+			if (i == RF_PATH_A) /* Fill value in RFD, Get the first spatial stream only */
+				phy_info->signal_quality = (u8)(EVM & 0xff);
+
+			phy_info->rx_mimo_signal_quality[i] = (u8)(EVM & 0xff);
+
+			if (phy_sta_rpt->stream_rxevm[i] < 0)
+				stream_rxevm_tmp = (u8)(0 - (phy_sta_rpt->stream_rxevm[i]));
+
+			if (stream_rxevm_tmp == 64)
+				stream_rxevm_tmp = 0;
+
+			phy_info->rx_mimo_evm_dbm[i] = stream_rxevm_tmp;
+
+		}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		}
+#endif
+
+		phydm_parsing_cfo(dm, pktinfo, phy_sta_rpt->path_cfotail, pktinfo->rate_ss);
+
+	}
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->ant_sel;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->ant_sel_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antsel_rx_keep_2;
+#endif
+
+}
+#endif
+
+#if	ODM_IC_11AC_SERIES_SUPPORT
+
+void
+phydm_rx_phy_bw_jaguar_series_parsing(
+	struct phydm_phyinfo_struct			*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo,
+	struct phy_status_rpt_8812		*phy_sta_rpt
+)
+{
+	if (pktinfo->data_rate <= ODM_RATE54M) {
+		switch (phy_sta_rpt->r_RFMOD) {
+		case 1:
+			if (phy_sta_rpt->sub_chnl == 0)
+				phy_info->band_width = 1;
+			else
+				phy_info->band_width = 0;
+			break;
+
+		case 2:
+			if (phy_sta_rpt->sub_chnl == 0)
+				phy_info->band_width = 2;
+			else if (phy_sta_rpt->sub_chnl == 9 || phy_sta_rpt->sub_chnl == 10)
+				phy_info->band_width = 1;
+			else
+				phy_info->band_width = 0;
+			break;
+
+		default:
+		case 0:
+			phy_info->band_width = 0;
+			break;
+		}
+	}
+
+}
+
+void
+phydm_rx_phy_status_jaguar_series_parsing(
+	struct dm_struct		*dm,
+	struct phydm_phyinfo_struct	*phy_info,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct		*pktinfo
+)
+{
+	u8					i, max_spatial_stream;
+	s8					rx_pwr[4], rx_pwr_all = 0;
+	u8					EVM = 0, evm_dbm, pwdb_all = 0, pwdb_all_bt;
+	u8					RSSI, avg_rssi = 0;
+	u8					rf_rx_num = 0;
+	u8					cck_highpwr = 0;
+	u8					LNA_idx, VGA_idx;
+	struct phy_status_rpt_8812 *phy_sta_rpt = (struct phy_status_rpt_8812 *)phy_status_inf;
+	struct phydm_fat_struct					*fat_tab = &dm->dm_fat_table;
+
+	phydm_rx_phy_bw_jaguar_series_parsing(phy_info, pktinfo, phy_sta_rpt);
+
+	if (pktinfo->is_to_self)
+		dm->curr_station_id = pktinfo->station_id;
+	else
+		dm->curr_station_id = 0xff;
+
+
+
+	if (pktinfo->is_cck_rate) {
+		u8 cck_agc_rpt;
+
+		/*(1)Hardware does not provide RSSI for CCK*/
+		/*(2)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
+
+		/*if(hal_data->e_rf_power_state == e_rf_on)*/
+		cck_highpwr = dm->is_cck_high_power;
+		/*else*/
+		/*cck_highpwr = false;*/
+
+		cck_agc_rpt = phy_sta_rpt->cfosho[0];
+		LNA_idx = ((cck_agc_rpt & 0xE0) >> 5);
+		VGA_idx = (cck_agc_rpt & 0x1F);
+
+		if (dm->support_ic_type == ODM_RTL8812) {
+			switch (LNA_idx) {
+			case 7:
+				if (VGA_idx <= 27)
+					rx_pwr_all = -100 + 2 * (27 - VGA_idx); /*VGA_idx = 27~2*/
+				else
+					rx_pwr_all = -100;
+				break;
+			case 6:
+				rx_pwr_all = -48 + 2 * (2 - VGA_idx); /*VGA_idx = 2~0*/
+				break;
+			case 5:
+				rx_pwr_all = -42 + 2 * (7 - VGA_idx); /*VGA_idx = 7~5*/
+				break;
+			case 4:
+				rx_pwr_all = -36 + 2 * (7 - VGA_idx); /*VGA_idx = 7~4*/
+				break;
+			case 3:
+				/*rx_pwr_all = -28 + 2*(7-VGA_idx); VGA_idx = 7~0*/
+				rx_pwr_all = -24 + 2 * (7 - VGA_idx); /*VGA_idx = 7~0*/
+				break;
+			case 2:
+				if (cck_highpwr)
+					rx_pwr_all = -12 + 2 * (5 - VGA_idx); /*VGA_idx = 5~0*/
+				else
+					rx_pwr_all = -6 + 2 * (5 - VGA_idx);
+				break;
+			case 1:
+				rx_pwr_all = 8 - 2 * VGA_idx;
+				break;
+			case 0:
+				rx_pwr_all = 14 - 2 * VGA_idx;
+				break;
+			default:
+				/*dbg_print("CCK Exception default\n");*/
+				break;
+			}
+			rx_pwr_all += 6;
+			pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+			if (cck_highpwr == false) {
+				if (pwdb_all >= 80)
+					pwdb_all = ((pwdb_all - 80) << 1) + ((pwdb_all - 80) >> 1) + 80;
+				else if ((pwdb_all <= 78) && (pwdb_all >= 20))
+					pwdb_all += 3;
+				if (pwdb_all > 100)
+					pwdb_all = 100;
+			}
+		} else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
+			s8 pout = -6;
+
+			switch (LNA_idx) {
+			case 5:
+				rx_pwr_all = pout - 32 - (2 * VGA_idx);
+				break;
+			case 4:
+				rx_pwr_all = pout - 24 - (2 * VGA_idx);
+				break;
+			case 2:
+				rx_pwr_all = pout - 11 - (2 * VGA_idx);
+				break;
+			case 1:
+				rx_pwr_all = pout + 5 - (2 * VGA_idx);
+				break;
+			case 0:
+				rx_pwr_all = pout + 21 - (2 * VGA_idx);
+				break;
+			}
+			pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+		} else if (dm->support_ic_type == ODM_RTL8814A) {
+			s8 pout = -6;
+
+			switch (LNA_idx) {
+			/*CCK only use LNA: 2, 3, 5, 7*/
+			case 7:
+				rx_pwr_all = pout - 32 - (2 * VGA_idx);
+				break;
+			case 5:
+				rx_pwr_all = pout - 22 - (2 * VGA_idx);
+				break;
+			case 3:
+				rx_pwr_all = pout - 2 - (2 * VGA_idx);
+				break;
+			case 2:
+				rx_pwr_all = pout + 5 - (2 * VGA_idx);
+				break;
+			/*case 6:*/
+			/*rx_pwr_all = pout -26 - (2*VGA_idx);*/
+			/*break;*/
+			/*case 4:*/
+			/*rx_pwr_all = pout - 8 - (2*VGA_idx);*/
+			/*break;*/
+			/*case 1:*/
+			/*rx_pwr_all = pout + 21 - (2*VGA_idx);*/
+			/*break;*/
+			/*case 0:*/
+			/*rx_pwr_all = pout + 10 - (2*VGA_idx);*/
+			/*	break; */
+			default:
+				/* dbg_print("CCK Exception default\n"); */
+				break;
+			}
+			pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+		}
+
+		dm->cck_lna_idx = LNA_idx;
+		dm->cck_vga_idx = VGA_idx;
+		phy_info->rx_pwdb_all = pwdb_all;
+		/* if(pktinfo->station_id == 0) */
+		/* { */
+		/*	dbg_print("CCK: LNA_idx = %d, VGA_idx = %d, phy_info->rx_pwdb_all = %d\n", */
+		/*		LNA_idx, VGA_idx, phy_info->rx_pwdb_all); */
+		/* } */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		phy_info->bt_rx_rssi_percentage = pwdb_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+#endif
+		/*(3) Get Signal Quality (EVM)*/
+		/*if (pktinfo->is_packet_match_bssid)*/
+		{
+			u8	sq, sq_rpt;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO)
+				sq = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+			else 
+#endif
+			if (phy_info->rx_pwdb_all > 40 && !dm->is_in_hct_test)
+				sq = 100;
+			else {
+				sq_rpt = phy_sta_rpt->pwdb_all;
+
+				if (sq_rpt > 64)
+					sq = 0;
+				else if (sq_rpt < 20)
+					sq = 100;
+				else
+					sq = ((64 - sq_rpt) * 100) / 44;
+			}
+
+			/* dbg_print("cck sq = %d\n", sq); */
+			phy_info->signal_quality = sq;
+			phy_info->rx_mimo_signal_quality[RF_PATH_A] = sq;
+		}
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			if (i == 0)
+				phy_info->rx_mimo_signal_strength[0] = pwdb_all;
+			else
+				phy_info->rx_mimo_signal_strength[i] = 0;
+		}
+	} else {
+		/*is OFDM rate*/
+		fat_tab->hw_antsw_occur = phy_sta_rpt->hw_antsw_occur;
+
+		/*(1)Get RSSI for OFDM rate*/
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			/*2008/01/30 MH we will judge RF RX path now.*/
+			/* dbg_print("dm->rf_path_rx_enable = %x\n", dm->rf_path_rx_enable); */
+			if (dm->rf_path_rx_enable & BIT(i))
+				rf_rx_num++;
+			/* else */
+			/* continue; */
+			/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
+			/* if((dm->support_ic_type & (ODM_RTL8812|ODM_RTL8821)) && (!dm->is_mp_chip)) */
+			if (i < RF_PATH_C) {
+				rx_pwr[i] = (phy_sta_rpt->gain_trsw[i] & 0x7F) - 110;
+
+				if (pktinfo->is_to_self)
+					dm->ofdm_agc_idx[i] = phy_sta_rpt->gain_trsw[i];
+
+			} else
+				rx_pwr[i] = (phy_sta_rpt->gain_trsw_cd[i - 2] & 0x7F) - 110;
+			/* else */
+			/*rx_pwr[i] = ((phy_sta_rpt->gain_trsw[i]& 0x3F)*2) - 110;  OLD FORMULA*/
+
+			phy_info->rx_pwr[i] = rx_pwr[i];
+
+			/* Translate DBM to percentage. */
+			RSSI = phydm_query_rx_pwr_percentage(rx_pwr[i]);
+
+			phy_info->rx_mimo_signal_strength[i] = (u8) RSSI;
+
+
+			/*Get Rx snr value in DB*/
+			if (i < RF_PATH_C)
+				phy_info->rx_snr[i] = phy_sta_rpt->rxsnr[i] / 2;
+			else if (dm->support_ic_type & (ODM_RTL8814A))
+				phy_info->rx_snr[i] = phy_sta_rpt->csi_current[i - 2] / 2;
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+			/*(2) CFO_short  & CFO_tail*/
+			if (i < RF_PATH_C) {
+				phy_info->cfo_short[i] = phydm_cfo((phy_sta_rpt->cfosho[i]));
+				phy_info->cfo_tail[i] = phydm_cfo((phy_sta_rpt->cfotail[i]));
+			}
+#endif
+			/* Record Signal Strength for next packet */
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			if (pktinfo->is_packet_match_bssid && (i == RF_PATH_A)) {
+				if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+					phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, i, RSSI);
+				}
+			}
+#endif
+		}
+
+		/*(3)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
+
+		/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
+		if ((dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)) && (!dm->is_mp_chip))
+			rx_pwr_all = (phy_sta_rpt->pwdb_all & 0x7f) - 110;
+		else
+			rx_pwr_all = (((phy_sta_rpt->pwdb_all) >> 1) & 0x7f) - 110;	 /*OLD FORMULA*/
+
+		pwdb_all_bt = pwdb_all = phydm_query_rx_pwr_percentage(rx_pwr_all);
+
+		phy_info->rx_pwdb_all = pwdb_all;
+		/*PHYDM_DBG(dm,DBG_RSSI_MNTR, "ODM OFDM RSSI=%d\n",phy_info->rx_pwdb_all);*/
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		phy_info->bt_rx_rssi_percentage = pwdb_all_bt;
+		phy_info->rx_power = rx_pwr_all;
+		phy_info->recv_signal_power = rx_pwr_all;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+			/*do nothing*/
+		} else {
+#endif
+		/*(4)EVM of OFDM rate*/
+
+		if ((pktinfo->data_rate >= ODM_RATEMCS8) &&
+			(pktinfo->data_rate <= ODM_RATEMCS15))
+			max_spatial_stream = 2;
+		else if ((pktinfo->data_rate >= ODM_RATEVHTSS2MCS0) &&
+			 (pktinfo->data_rate <= ODM_RATEVHTSS2MCS9))
+			max_spatial_stream = 2;
+		else if ((pktinfo->data_rate >= ODM_RATEMCS16) &&
+			 (pktinfo->data_rate <= ODM_RATEMCS23))
+			max_spatial_stream = 3;
+		else if ((pktinfo->data_rate >= ODM_RATEVHTSS3MCS0) &&
+			 (pktinfo->data_rate <= ODM_RATEVHTSS3MCS9))
+			max_spatial_stream = 3;
+		else
+			max_spatial_stream = 1;
+
+		/*if (pktinfo->is_packet_match_bssid) */
+			/*dbg_print("pktinfo->data_rate = %d\n", pktinfo->data_rate);*/
+
+		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.*/
+
+			if (pktinfo->data_rate >= ODM_RATE6M && pktinfo->data_rate <= ODM_RATE54M) {
+				if (i == RF_PATH_A) {
+					EVM = phydm_evm_db_to_percentage((phy_sta_rpt->sigevm));	/*dbm*/
+					EVM += 20;
+					if (EVM > 100)
+						EVM = 100;
+				}
+			} else {
+				if (i < RF_PATH_C) {
+					if (phy_sta_rpt->rxevm[i] == -128)
+						phy_sta_rpt->rxevm[i] = -25;
+					EVM = phydm_evm_db_to_percentage((phy_sta_rpt->rxevm[i]));	/*dbm*/
+				} else {
+					if (phy_sta_rpt->rxevm_cd[i - 2] == -128)
+						phy_sta_rpt->rxevm_cd[i - 2] = -25;
+					EVM = phydm_evm_db_to_percentage((phy_sta_rpt->rxevm_cd[i - 2]));	/*dbm*/
+				}
+			}
+
+			if (i < RF_PATH_C)
+				evm_dbm = phydm_evm_dbm_jaguar_series(phy_sta_rpt->rxevm[i]);
+			else
+				evm_dbm = phydm_evm_dbm_jaguar_series(phy_sta_rpt->rxevm_cd[i - 2]);
+			/*RT_DISP(FRX, RX_PHY_SQ, ("RXRATE=%x RXEVM=%x EVM=%s%d\n",*/
+			/*pktinfo->data_rate, phy_sta_rpt->rxevm[i], "%", EVM));*/
+
+			if (i == RF_PATH_A) {
+				/*Fill value in RFD, Get the first spatial stream only*/
+				phy_info->signal_quality = EVM;
+			}
+			phy_info->rx_mimo_signal_quality[i] = EVM;
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+			phy_info->rx_mimo_evm_dbm[i] = evm_dbm;
+#endif
+		}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		}
+#endif
+
+		phydm_parsing_cfo(dm, pktinfo, phy_sta_rpt->cfotail, pktinfo->rate_ss);
+
+	}
+	/* dbg_print("is_cck_rate= %d, phy_info->signal_strength=%d % PWDB_AL=%d rf_rx_num=%d\n", is_cck_rate, phy_info->signal_strength, pwdb_all, rf_rx_num); */
+
+	dm->rx_pwdb_ave = dm->rx_pwdb_ave + phy_info->rx_pwdb_all;
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->antidx_anta;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->antidx_antb;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antidx_antc;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sta_rpt->antidx_antd;
+#endif
+
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antidx_anta = ((%d)), MatchBSSID =  ((%d))\n", pktinfo->station_id, phy_sta_rpt->antidx_anta, pktinfo->is_packet_match_bssid);*/
+
+
+	/*		dbg_print("phy_sta_rpt->antidx_anta = %d, phy_sta_rpt->antidx_antb = %d\n",*/
+	/*			phy_sta_rpt->antidx_anta, phy_sta_rpt->antidx_antb);*/
+	/*		dbg_print("----------------------------\n");*/
+	/*		dbg_print("pktinfo->station_id=%d, pktinfo->data_rate=0x%x\n",pktinfo->station_id, pktinfo->data_rate);*/
+	/*		dbg_print("phy_sta_rpt->r_RFMOD = %d\n", phy_sta_rpt->r_RFMOD);*/
+	/*		dbg_print("phy_sta_rpt->gain_trsw[0]=0x%x, phy_sta_rpt->gain_trsw[1]=0x%x\n",*/
+	/*				phy_sta_rpt->gain_trsw[0],phy_sta_rpt->gain_trsw[1]);*/
+	/*		dbg_print("phy_sta_rpt->gain_trsw[2]=0x%x, phy_sta_rpt->gain_trsw[3]=0x%x\n",*/
+	/*				phy_sta_rpt->gain_trsw_cd[0],phy_sta_rpt->gain_trsw_cd[1]);*/
+	/*		dbg_print("phy_sta_rpt->pwdb_all = 0x%x, phy_info->rx_pwdb_all = %d\n", phy_sta_rpt->pwdb_all, phy_info->rx_pwdb_all);*/
+	/*		dbg_print("phy_sta_rpt->cfotail[i] = 0x%x, phy_sta_rpt->CFO_tail[i] = 0x%x\n", phy_sta_rpt->cfotail[0], phy_sta_rpt->cfotail[1]);*/
+	/*		dbg_print("phy_sta_rpt->rxevm[0] = %d, phy_sta_rpt->rxevm[1] = %d\n", phy_sta_rpt->rxevm[0], phy_sta_rpt->rxevm[1]);*/
+	/*		dbg_print("phy_sta_rpt->rxevm[2] = %d, phy_sta_rpt->rxevm[3] = %d\n", phy_sta_rpt->rxevm_cd[0], phy_sta_rpt->rxevm_cd[1]);*/
+	/*		dbg_print("phy_info->rx_mimo_signal_strength[0]=%d, phy_info->rx_mimo_signal_strength[1]=%d, rx_pwdb_all=%d\n",*/
+	/*				phy_info->rx_mimo_signal_strength[0], phy_info->rx_mimo_signal_strength[1], phy_info->rx_pwdb_all);*/
+	/*		dbg_print("phy_info->rx_mimo_signal_strength[2]=%d, phy_info->rx_mimo_signal_strength[3]=%d\n",*/
+	/*				phy_info->rx_mimo_signal_strength[2], phy_info->rx_mimo_signal_strength[3]);*/
+	/*		dbg_print("ppPhyInfo->rx_mimo_signal_quality[0]=%d, phy_info->rx_mimo_signal_quality[1]=%d\n",*/
+	/*				phy_info->rx_mimo_signal_quality[0], phy_info->rx_mimo_signal_quality[1]);*/
+	/*		dbg_print("ppPhyInfo->rx_mimo_signal_quality[2]=%d, phy_info->rx_mimo_signal_quality[3]=%d\n",*/
+	/*				phy_info->rx_mimo_signal_quality[2], phy_info->rx_mimo_signal_quality[3]);*/
+
+}
+
+#endif
+
+void
+phydm_reset_rssi_for_dm(
+	struct dm_struct	*dm,
+	u8		station_id
+)
+{
+	struct cmn_sta_info		*sta;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+#endif
+	sta = dm->phydm_sta_info[station_id];
+
+	if (!is_sta_active(sta)) {
+		/**/
+		return;
+	}
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "Reset RSSI for macid = (( %d ))\n", station_id);
+
+
+	sta->rssi_stat.rssi_cck = -1;
+	sta->rssi_stat.rssi_ofdm = -1;
+	sta->rssi_stat.rssi = -1;
+	sta->rssi_stat.ofdm_pkt_cnt = 0;
+	sta->rssi_stat.cck_pkt_cnt = 0;
+	sta->rssi_stat.cck_sum_power = 0;
+	sta->rssi_stat.is_send_rssi = RA_RSSI_STATE_INIT;
+	sta->rssi_stat.packet_map = 0;
+	sta->rssi_stat.valid_bit = 0;
+}
+
+void
+phydm_process_rssi_for_dm(
+	struct dm_struct					*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	s32			rssi_ave;
+	s8			undecorated_smoothed_pwdb, undecorated_smoothed_cck, undecorated_smoothed_ofdm;
+	u8			i;
+	u8			rssi_max, rssi_min;
+	u32			weighting = 0;
+	u8			send_rssi_2_fw = 0;
+	struct cmn_sta_info		*sta;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+#endif
+
+	if (pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
+		return;
+
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(dm, phy_info, pktinfo);
+#endif
+
+	sta = dm->phydm_sta_info[pktinfo->station_id];
+
+	if (!is_sta_active(sta)) {
+		return;
+		/**/
+	}
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if ((dm->support_ability & ODM_BB_ANT_DIV) &&
+	    (fat_tab->enable_ctrl_frame_antdiv)
+	   ) {
+		if (pktinfo->is_packet_match_bssid)
+			dm->data_frame_num++;
+
+		if ((fat_tab->use_ctrl_frame_antdiv)) {
+			if (!pktinfo->is_to_self)/*data frame + CTRL frame*/
+				return;
+		} else {
+			if ((!pktinfo->is_packet_match_bssid))/*data frame only*/
+				return;
+		}
+	} else
+#endif
+	{
+		if ((!pktinfo->is_packet_match_bssid))/*data frame only*/
+			return;
+	}
+
+	if (pktinfo->is_packet_beacon)
+		dm->phy_dbg_info.num_qry_beacon_pkt++;
+
+	/* --------------Statistic for antenna/path diversity------------------ */
+	if (dm->support_ability & ODM_BB_ANT_DIV) {
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+		odm_process_rssi_for_ant_div(dm, phy_info, pktinfo);
+#endif
+	}
+#if (defined(CONFIG_PATH_DIVERSITY))
+	else if (dm->support_ability & ODM_BB_PATH_DIV)
+		phydm_process_rssi_for_path_div(dm, phy_info, pktinfo);
+#endif
+	/* -----------------Smart Antenna Debug Message------------------ */
+
+	undecorated_smoothed_cck =  sta->rssi_stat.rssi_cck;
+	undecorated_smoothed_ofdm = sta->rssi_stat.rssi_ofdm;
+	undecorated_smoothed_pwdb = sta->rssi_stat.rssi;
+
+	if (pktinfo->is_packet_to_self || pktinfo->is_packet_beacon) {
+		if (!pktinfo->is_cck_rate) { /* ofdm rate */
+#if (RTL8814A_SUPPORT == 1)
+			if (dm->support_ic_type & (ODM_RTL8814A)) {
+				u8 rx_count = 0;
+				u32 rssi_linear = 0;
+
+				if (dm->rx_ant_status & BB_PATH_A) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_A]);
+				}
+
+				if (dm->rx_ant_status & BB_PATH_B) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_B]);
+				}
+
+				if (dm->rx_ant_status & BB_PATH_C) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_C]);
+				}
+
+				if (dm->rx_ant_status & BB_PATH_D) {
+					rx_count++;
+					rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[RF_PATH_D]);
+				}
+
+				/* Calculate average RSSI */
+				switch (rx_count) {
+				case 2:
+					rssi_linear = (rssi_linear >> 1);
+					break;
+				case 3:
+					rssi_linear = ((rssi_linear) + (rssi_linear << 1) + (rssi_linear << 3)) >> 5;	/* rssi_linear/3 ~ rssi_linear*11/32 */
+					break;
+				case 4:
+					rssi_linear = (rssi_linear >> 2);
+					break;
+				}
+				rssi_ave = odm_convert_to_db(rssi_linear);
+			} else
+#endif
+			{
+				if (phy_info->rx_mimo_signal_strength[RF_PATH_B] == 0) {
+					rssi_ave = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+				} else {
+					/*dbg_print("rfd->status.rx_mimo_signal_strength[0] = %d, rfd->status.rx_mimo_signal_strength[1] = %d\n",*/
+					/*rfd->status.rx_mimo_signal_strength[0], rfd->status.rx_mimo_signal_strength[1]);*/
+
+					if (phy_info->rx_mimo_signal_strength[RF_PATH_A] > phy_info->rx_mimo_signal_strength[RF_PATH_B]) {
+						rssi_max = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+						rssi_min = phy_info->rx_mimo_signal_strength[RF_PATH_B];
+					} else {
+						rssi_max = phy_info->rx_mimo_signal_strength[RF_PATH_B];
+						rssi_min = phy_info->rx_mimo_signal_strength[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 (undecorated_smoothed_ofdm <= 0) {	/* initialize */
+				undecorated_smoothed_ofdm = (s8)phy_info->rx_pwdb_all;
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "OFDM_INIT: (( %d ))\n", undecorated_smoothed_ofdm);
+			} else {
+				if (phy_info->rx_pwdb_all > (u32)undecorated_smoothed_ofdm) {
+					undecorated_smoothed_ofdm =
+						(s8)((((undecorated_smoothed_ofdm)*(RX_SMOOTH_FACTOR - 1)) +
+						(rssi_ave)) / (RX_SMOOTH_FACTOR));
+					undecorated_smoothed_ofdm = undecorated_smoothed_ofdm + 1;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "OFDM_1: (( %d ))\n", undecorated_smoothed_ofdm);
+				} else {
+					undecorated_smoothed_ofdm =
+						(s8)((((undecorated_smoothed_ofdm)*(RX_SMOOTH_FACTOR - 1)) +
+						(rssi_ave)) / (RX_SMOOTH_FACTOR));
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "OFDM_2: (( %d ))\n", undecorated_smoothed_ofdm);
+				}
+			}
+			if (sta->rssi_stat.ofdm_pkt_cnt != 64) {
+				i = 63;
+				sta->rssi_stat.ofdm_pkt_cnt -= (u8)(((sta->rssi_stat.packet_map >> i) & BIT(0)) - 1);
+			}
+			sta->rssi_stat.packet_map = (sta->rssi_stat.packet_map << 1) | BIT(0);
+
+		} else {
+			rssi_ave = phy_info->rx_pwdb_all;
+
+			if (sta->rssi_stat.cck_pkt_cnt <= 63)
+				sta->rssi_stat.cck_pkt_cnt++;
+
+			/* 1 Process CCK RSSI */
+			if (undecorated_smoothed_cck <= 0) {	/* initialize */
+				undecorated_smoothed_cck = (s8)phy_info->rx_pwdb_all;
+				sta->rssi_stat.cck_sum_power = (u16)phy_info->rx_pwdb_all ; /*reset*/
+				sta->rssi_stat.cck_pkt_cnt = 1; /*reset*/
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_INIT: (( %d ))\n", undecorated_smoothed_cck);
+			} else if (sta->rssi_stat.cck_pkt_cnt <= CCK_RSSI_INIT_COUNT) {
+				sta->rssi_stat.cck_sum_power = sta->rssi_stat.cck_sum_power + (u16)phy_info->rx_pwdb_all;
+				undecorated_smoothed_cck = sta->rssi_stat.cck_sum_power / sta->rssi_stat.cck_pkt_cnt;
+
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_0: (( %d )), SumPow = (( %d )), cck_pkt = (( %d ))\n",
+					undecorated_smoothed_cck, sta->rssi_stat.cck_sum_power, sta->rssi_stat.cck_pkt_cnt);
+			} else {
+				if (phy_info->rx_pwdb_all > (u32)undecorated_smoothed_cck) {
+					undecorated_smoothed_cck =
+						(s8)((((undecorated_smoothed_cck)*(RX_SMOOTH_FACTOR - 1)) +
+						(phy_info->rx_pwdb_all)) / (RX_SMOOTH_FACTOR));
+					undecorated_smoothed_cck = undecorated_smoothed_cck + 1;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_1: (( %d ))\n", undecorated_smoothed_cck);
+				} else {
+					undecorated_smoothed_cck =
+						(s8)((((undecorated_smoothed_cck)*(RX_SMOOTH_FACTOR - 1)) +
+						(phy_info->rx_pwdb_all)) / (RX_SMOOTH_FACTOR));
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "CCK_2: (( %d ))\n", undecorated_smoothed_cck);
+				}
+			}
+			i = 63;
+			sta->rssi_stat.ofdm_pkt_cnt -= (u8)((sta->rssi_stat.packet_map >> i) & BIT(0));
+			sta->rssi_stat.packet_map = sta->rssi_stat.packet_map << 1;
+		}
+
+		/* if(entry) */
+
+		/* 2011.07.28 LukeLee: modified to prevent unstable CCK RSSI */
+		if (sta->rssi_stat.ofdm_pkt_cnt == 64) { /* speed up when all packets are OFDM*/
+			undecorated_smoothed_pwdb = undecorated_smoothed_ofdm;
+			PHYDM_DBG(dm, DBG_RSSI_MNTR, "PWDB_0[%d] = (( %d ))\n", pktinfo->station_id, undecorated_smoothed_cck);
+		} else {
+			if (sta->rssi_stat.valid_bit < 64)
+				sta->rssi_stat.valid_bit++;
+
+			if (sta->rssi_stat.valid_bit == 64) {
+				weighting = ((sta->rssi_stat.ofdm_pkt_cnt) > 4) ? 64 : (sta->rssi_stat.ofdm_pkt_cnt << 4);
+				undecorated_smoothed_pwdb = (s8)((weighting * undecorated_smoothed_ofdm + (64 - weighting) * undecorated_smoothed_cck) >> 6);
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "PWDB_1[%d] = (( %d )), W = (( %d ))\n", pktinfo->station_id, undecorated_smoothed_cck, weighting);
+			} else {
+				if (sta->rssi_stat.valid_bit != 0)
+					undecorated_smoothed_pwdb =
+					(sta->rssi_stat.ofdm_pkt_cnt * undecorated_smoothed_ofdm + (sta->rssi_stat.valid_bit - sta->rssi_stat.ofdm_pkt_cnt) * undecorated_smoothed_cck) / sta->rssi_stat.valid_bit;
+				else
+					undecorated_smoothed_pwdb = 0;
+
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "PWDB_2[%d] = (( %d )), ofdm_pkt = (( %d )), Valid_Bit = (( %d ))\n",
+					pktinfo->station_id, undecorated_smoothed_cck, sta->rssi_stat.ofdm_pkt_cnt, sta->rssi_stat.valid_bit);
+			}
+		}
+
+
+		if ((sta->rssi_stat.ofdm_pkt_cnt >= 1 || sta->rssi_stat.cck_pkt_cnt >= 5) && (sta->rssi_stat.is_send_rssi == RA_RSSI_STATE_INIT)) {
+			send_rssi_2_fw = 1;
+			sta->rssi_stat.is_send_rssi = RA_RSSI_STATE_SEND;
+		}
+
+		sta->rssi_stat.rssi_cck = undecorated_smoothed_cck;
+		sta->rssi_stat.rssi_ofdm = undecorated_smoothed_ofdm;
+		sta->rssi_stat.rssi = undecorated_smoothed_pwdb;
+
+
+
+		if (send_rssi_2_fw) { /* Trigger init rate by RSSI */
+
+			if (sta->rssi_stat.ofdm_pkt_cnt != 0)
+				sta->rssi_stat.rssi = undecorated_smoothed_ofdm;
+
+			PHYDM_DBG(dm, DBG_RSSI_MNTR,
+				"[Send to FW] PWDB = (( %d )), ofdm_pkt = (( %d )), cck_pkt = (( %d ))\n",
+				undecorated_smoothed_pwdb, sta->rssi_stat.ofdm_pkt_cnt, sta->rssi_stat.cck_pkt_cnt);
+
+		}
+
+		/* dbg_print("ofdm_pkt=%d, weighting=%d\n", ofdm_pkt_cnt, weighting); */
+		/* dbg_print("undecorated_smoothed_ofdm=%d, undecorated_smoothed_pwdb=%d, undecorated_smoothed_cck=%d\n", */
+		/*	undecorated_smoothed_ofdm, undecorated_smoothed_pwdb, undecorated_smoothed_cck); */
+
+
+	}
+}
+
+/*
+ * Endianness before calling this API
+ *   */
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+/* For 8822B only!! need to move to FW finally */
+/*==============================================*/
+
+boolean
+phydm_query_is_mu_api(
+	struct dm_struct					*phydm,
+	u8							ppdu_idx,
+	u8							*p_data_rate,
+	u8							*p_gid
+)
+{
+	u8	data_rate = 0, gid = 0;
+	boolean is_mu = false;
+
+	data_rate = phydm->phy_dbg_info.num_of_ppdu[ppdu_idx];
+	gid = phydm->phy_dbg_info.gid_num[ppdu_idx];
+
+	if (data_rate & BIT(7)) {
+		is_mu = true;
+		data_rate = data_rate & ~(BIT(7));
+	} else
+		is_mu = false;
+
+	*p_data_rate = data_rate;
+	*p_gid = gid;
+
+	return is_mu;
+
+}
+
+void
+phydm_reset_phy_info(
+	struct dm_struct					*phydm,
+	struct phydm_phyinfo_struct			*phy_info
+)
+{
+	phy_info->rx_pwdb_all = 0;
+	phy_info->signal_quality = 0;
+	phy_info->band_width = 0;
+	phy_info->rx_count = 0;
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_quality, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_strength, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_snr, 0, 4);
+
+	phy_info->rx_power = -110;
+	phy_info->recv_signal_power = -110;
+	phy_info->bt_rx_rssi_percentage = 0;
+	phy_info->signal_strength = 0;
+	phy_info->channel = 0;
+	phy_info->is_mu_packet = 0;
+	phy_info->is_beamformed = 0;
+	phy_info->rxsc = 0;
+	odm_memory_set(phydm, phy_info->rx_pwr, -110, 4);
+	odm_memory_set(phydm, phy_info->cfo_short, 0, 8);
+	odm_memory_set(phydm, phy_info->cfo_tail, 0, 8);
+
+	odm_memory_set(phydm, phy_info->rx_mimo_evm_dbm, 0, 4);
+}
+
+void
+phydm_print_phy_status_jarguar2(
+	struct 	dm_struct			*dm,
+	u8								*phy_status_inf,
+	struct 	phydm_perpkt_info_struct	*pktinfo,
+	struct 	phydm_phyinfo_struct		*phy_info,
+	u8		phy_status_page_num
+)
+{
+	struct phy_status_rpt_jaguar2_type0	*rpt0 = (struct phy_status_rpt_jaguar2_type0 *)phy_status_inf;
+	struct phy_status_rpt_jaguar2_type1	*rpt = (struct phy_status_rpt_jaguar2_type1 *)phy_status_inf;
+	struct phy_status_rpt_jaguar2_type2	*rpt2 = (struct phy_status_rpt_jaguar2_type2 *)phy_status_inf;
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+	u32	phy_status[PHY_STATUS_JRGUAR2_DW_LEN] = {0};
+	u8	i;
+
+	odm_move_memory(dm, phy_status, phy_status_inf, (PHY_STATUS_JRGUAR2_DW_LEN<<2));
+
+	if (!(dm->debug_components & DBG_PHY_STATUS))
+		return;
+
+	if (dbg->show_phy_sts_all_pkt == 0) {
+		if (!pktinfo->is_packet_match_bssid)
+		{
+			return;
+		}
+	}
+
+	dbg->show_phy_sts_cnt++;
+	/*dbg_print("cnt=%d, max=%d\n", dbg->show_phy_sts_cnt, dbg->show_phy_sts_max_cnt);*/
+	
+	if (dbg->show_phy_sts_max_cnt != SHOW_PHY_STATUS_UNLIMITED) {
+		if (dbg->show_phy_sts_cnt > dbg->show_phy_sts_max_cnt) {
+			return;
+		}
+	}
+		
+	pr_debug("Phy Status Rpt: OFDM_%d\n", phy_status_page_num);
+	pr_debug("StaID=%d, RxRate = 0x%x match_bssid=%d\n", pktinfo->station_id, pktinfo->data_rate, pktinfo->is_packet_match_bssid);
+
+	for (i = 0; i < PHY_STATUS_JRGUAR2_DW_LEN; i++) {
+		pr_debug("Offset[%d:%d] = 0x%x\n", ((4 * i) + 3), (4*i), phy_status[i]);
+	}
+
+	if (phy_status_page_num == 0) {
+		pr_debug("[0] TRSW=%d, MP_gain_idx=%d, pwdb=%d\n", rpt0->trsw, rpt0->gain, rpt0->pwdb);
+		pr_debug("[4] band=%d, CH=%d, agc_table = %d, rxsc = %d\n", rpt0->band, rpt0->channel, rpt0->agc_table, rpt0->rxsc);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, LSIG_len=%d\n", 
+			rpt0->antidx_d, rpt0->antidx_c, rpt0->antidx_b, rpt0->antidx_a, rpt0->length);
+		pr_debug("[12] lna_h=%d, bb_power=%d, lna_l=%d, vga=%d, sq=%d\n", 
+			rpt0->lna_h, rpt0->bb_power, rpt0->lna_l, rpt0->vga, rpt0->signal_quality);
+		
+	} else if (phy_status_page_num == 1) {
+		pr_debug("[0] pwdb[D:A]={%d, %d, %d, %d}\n", 
+			rpt->pwdb[3], rpt->pwdb[2], rpt->pwdb[1], rpt->pwdb[0]);
+		pr_debug("[4] BF: %d, ldpc=%d, stbc=%d, g_bt=%d, antsw=%d, band=%d, CH=%d, rxsc[ht, l]={%d, %d}\n",  
+			rpt->beamformed, rpt->ldpc, rpt->stbc,  rpt->gnt_bt, 
+			rpt->hw_antsw_occu, rpt->band, rpt->channel, rpt->ht_rxsc, rpt->l_rxsc);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, LSIG_len=%d\n", 
+			rpt->antidx_d, rpt->antidx_c, rpt->antidx_b, rpt->antidx_a, rpt->lsig_length);
+		pr_debug("[12] rf_mode=%d, NBI=%d, Intf_pos=%d, GID=%d, PAID=%d\n", 
+			rpt->rf_mode, rpt->nb_intf_flag, 
+			(rpt->intf_pos + (rpt->intf_pos_msb<<8)), rpt->gid, 
+			(rpt->paid + (rpt->paid_msb<<8)));
+		pr_debug("[16] EVM[D:A]={%d, %d, %d, %d}\n", rpt->rxevm[3], rpt->rxevm[2], rpt->rxevm[1], rpt->rxevm[0]);
+		pr_debug("[20] CFO[D:A]={%d, %d, %d, %d}\n", rpt->cfo_tail[3], rpt->cfo_tail[2], rpt->cfo_tail[1], rpt->cfo_tail[0]);
+		pr_debug("[24] SNR[D:A]={%d, %d, %d, %d}\n\n", rpt->rxsnr[3], rpt->rxsnr[2], rpt->rxsnr[1], rpt->rxsnr[0]);
+
+	} else if (phy_status_page_num == 2) {
+		
+		pr_debug("[0] pwdb[D:A]={%d, %d, %d, %d}\n", 
+			rpt2->pwdb[3], rpt2->pwdb[2], rpt2->pwdb[1], rpt2->pwdb[0]);
+		pr_debug("[4] BF: %d, ldpc=%d, stbc=%d, g_bt=%d, antsw=%d, band=%d, CH=%d, rxsc[ht, l]={%d, %d}\n",  
+			rpt2->beamformed, rpt2->ldpc, rpt2->stbc,  rpt2->gnt_bt, 
+			rpt2->hw_antsw_occu, rpt2->band, rpt2->channel, rpt2->ht_rxsc, rpt2->l_rxsc);
+		pr_debug("[8] AgcTab[D:A]={%d, %d, %d, %d}, cnt_pw2cca=%d, shift_l_map=%d\n", 
+			rpt2->agc_table_d, rpt2->agc_table_c, rpt2->agc_table_b, rpt2->agc_table_a, 
+			rpt2->cnt_pw2cca, rpt2->shift_l_map);
+		pr_debug("[12] (TRSW|Gain)[D:A]={%d %d, %d %d, %d %d, %d %d}, cnt_cca2agc_rdy=%d\n", 
+			rpt2->trsw_d, rpt2->gain_d, rpt2->trsw_c, rpt2->gain_c, 
+			rpt2->trsw_b,rpt2->gain_b, rpt2->trsw_a, rpt2->gain_a, rpt2->cnt_cca2agc_rdy);
+		pr_debug("[16] AAGC step[D:A]={%d, %d, %d, %d} HT AAGC gain[D:A]={%d, %d, %d, %d}\n", 
+			rpt2->aagc_step_d, rpt2->aagc_step_c, rpt2->aagc_step_b, rpt2->aagc_step_a,
+			rpt2->ht_aagc_gain[3], rpt2->ht_aagc_gain[2], rpt2->ht_aagc_gain[1], rpt2->ht_aagc_gain[0]);
+		pr_debug("[20] DAGC gain[D:A]={%d, %d, %d, %d}\n", rpt2->dagc_gain[3], 
+			rpt2->dagc_gain[2], rpt2->dagc_gain[1], rpt2->dagc_gain[0]);
+		pr_debug("[24] syn_cnt: %d, Cnt=%d\n\n", rpt2->syn_count, rpt2->counter);
+	}
+
+}
+
+void
+phydm_set_per_path_phy_info(
+	u8							rx_path,
+	s8							rx_pwr,
+	s8							rx_evm,
+	s8							cfo_tail,
+	s8							rx_snr,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	u8			evm_dbm = 0;
+	u8			evm_percentage = 0;
+
+	/* SNR is S(8,1), EVM is S(8,1), CFO is S(8,7) */
+
+	if (rx_evm < 0) {
+		/* Calculate EVM in dBm */
+		evm_dbm = ((u8)(0 - rx_evm) >> 1);
+
+		if (evm_dbm == 64)
+			evm_dbm = 0; /*if 1SS rate, evm_dbm [2nd stream] =64*/
+
+		if (evm_dbm != 0) {
+			/* Convert EVM to 0%~100% percentage */
+			if (evm_dbm >= 34)
+				evm_percentage = 100;
+			else
+				evm_percentage = (evm_dbm << 1) + (evm_dbm);
+		}
+	}
+
+	phy_info->rx_pwr[rx_path] = rx_pwr;
+	
+	phy_info->cfo_tail[rx_path] = (cfo_tail * 5) >> 1; /* CFO(kHz) = CFO_tail * 312.5(kHz) / 2^7 ~= CFO tail * 5/2 (kHz)*/
+	phy_info->rx_mimo_evm_dbm[rx_path] = evm_dbm;
+	phy_info->rx_mimo_signal_strength[rx_path] = phydm_query_rx_pwr_percentage(rx_pwr);
+	phy_info->rx_mimo_signal_quality[rx_path] = evm_percentage;
+	phy_info->rx_snr[rx_path] = rx_snr >> 1;
+
+#if 0
+	/* if (pktinfo->is_packet_match_bssid) */
+	{
+		dbg_print("path (%d)--------\n", rx_path);
+		dbg_print("rx_pwr = %d, Signal strength = %d\n", phy_info->rx_pwr[rx_path], phy_info->rx_mimo_signal_strength[rx_path]);
+		dbg_print("evm_dbm = %d, Signal quality = %d\n", phy_info->rx_mimo_evm_dbm[rx_path], phy_info->rx_mimo_signal_quality[rx_path]);
+		dbg_print("CFO = %d, SNR = %d\n", phy_info->cfo_tail[rx_path], phy_info->rx_snr[rx_path]);
+	}
+#endif
+}
+
+void
+phydm_set_common_phy_info(
+	s8							rx_power,
+	u8							channel,
+	boolean						is_beamformed,
+	boolean						is_mu_packet,
+	u8							bandwidth,
+	u8							signal_quality,
+	u8							rxsc,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	phy_info->rx_power = rx_power;											/* RSSI in dB */
+	phy_info->recv_signal_power = rx_power;										/* RSSI in dB */
+	phy_info->channel = channel;												/* channel number */
+	phy_info->is_beamformed = is_beamformed;									/* apply BF */
+	phy_info->is_mu_packet = is_mu_packet;										/* MU packet */
+	phy_info->rxsc = rxsc;
+
+	phy_info->rx_pwdb_all = phydm_query_rx_pwr_percentage(rx_power);				/* RSSI in percentage */
+	phy_info->signal_quality = signal_quality;										/* signal quality */
+	phy_info->band_width = bandwidth;											/* bandwidth */
+
+#if 0
+	/* if (pktinfo->is_packet_match_bssid) */
+	{
+		dbg_print("rx_pwdb_all = %d, rx_power = %d, recv_signal_power = %d\n", phy_info->rx_pwdb_all, phy_info->rx_power, phy_info->recv_signal_power);
+		dbg_print("signal_quality = %d\n", phy_info->signal_quality);
+		dbg_print("is_beamformed = %d, is_mu_packet = %d, rx_count = %d\n", phy_info->is_beamformed, phy_info->is_mu_packet, phy_info->rx_count + 1);
+		dbg_print("channel = %d, rxsc = %d, band_width = %d\n", channel, rxsc, bandwidth);
+	}
+#endif
+}
+
+void
+phydm_get_rx_phy_status_type0(
+	struct dm_struct		*dm,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	/* type 0 is used for cck packet */
+	struct phy_status_rpt_jaguar2_type0	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type0 *)phy_status_inf;
+	u8							sq = 0;
+	s8							rx_power = phy_sta_rpt->pwdb - 110;
+
+
+	if (dm->support_ic_type & ODM_RTL8723D) {
+#if (RTL8723D_SUPPORT == 1)
+		rx_power = phy_sta_rpt->pwdb - 97;
+#endif
+	}
+/*#if (RTL8710B_SUPPORT == 1)*/
+	/*if (dm->support_ic_type & ODM_RTL8710B)*/
+		/*rx_power = phy_sta_rpt->pwdb - 97;*/
+/*#endif*/
+
+#if (RTL8821C_SUPPORT == 1)
+	else if (dm->support_ic_type & ODM_RTL8821C) {
+		if (phy_sta_rpt->pwdb >= -57)
+			rx_power = phy_sta_rpt->pwdb - 100;
+		else
+			rx_power = phy_sta_rpt->pwdb - 102;
+	}
+#endif
+
+	if (pktinfo->is_to_self) {
+		dm->ofdm_agc_idx[0] = phy_sta_rpt->pwdb;
+		dm->ofdm_agc_idx[1] = 0;
+		dm->ofdm_agc_idx[2] = 0;
+		dm->ofdm_agc_idx[3] = 0;
+	}
+
+
+	/* Calculate Signal Quality*/
+	if (pktinfo->is_packet_match_bssid) {
+		if (phy_sta_rpt->signal_quality >= 64)
+			sq = 0;
+		else if (phy_sta_rpt->signal_quality <= 20)
+			sq = 100;
+		else {
+			/* mapping to 2~99% */
+			sq = 64 - phy_sta_rpt->signal_quality;
+			sq = ((sq << 3) + sq) >> 2;
+		}
+	}
+
+	/* Modify CCK PWDB if old AGC */
+	if (dm->cck_new_agc == false) {
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8197F)
+			rx_power = phydm_cck_rssi_convert(dm, phy_sta_rpt->lna_l, phy_sta_rpt->vga);
+		else
+		#endif
+		{
+			u8	lna_idx, vga_idx;
+
+			lna_idx = ((phy_sta_rpt->lna_h << 3) | phy_sta_rpt->lna_l);
+			vga_idx = phy_sta_rpt->vga;
+
+			#if (RTL8723D_SUPPORT == 1)
+			if (dm->support_ic_type & ODM_RTL8723D)
+				rx_power = odm_cckrssi_8723d(lna_idx, vga_idx);
+			#endif
+
+			#if (RTL8710B_SUPPORT == 1)
+			if (dm->support_ic_type & ODM_RTL8710B)
+				rx_power = odm_cckrssi_8710b(lna_idx, vga_idx);
+			#endif
+
+			#if (RTL8822B_SUPPORT == 1)
+			/* Need to do !! */
+			/*if (dm->support_ic_type & ODM_RTL8822B) */
+			/*rx_power = odm_CCKRSSI_8822B(LNA_idx, VGA_idx);*/
+			#endif
+
+			#if (RTL8821C_SUPPORT == 1)
+				if (dm->support_ic_type & ODM_RTL8821C)
+					rx_power = phydm_cck_rssi_8821c(dm, lna_idx, vga_idx);
+			#endif
+		}
+
+	}
+
+	/* Confirm CCK RSSI */
+	#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		u8	bb_pwr_th_l = 5; /* round( 31*0.15 ) */
+		u8	bb_pwr_th_h = 27; /* round( 31*0.85 ) */
+
+		if ((phy_sta_rpt->bb_power < bb_pwr_th_l) || (phy_sta_rpt->bb_power > bb_pwr_th_h))
+			rx_power = 0; /* Error RSSI for CCK ; set 100*/
+	}
+	#endif
+
+	/*CCK no STBC and LDPC*/
+	dm->phy_dbg_info.is_ldpc_pkt = false;
+	dm->phy_dbg_info.is_stbc_pkt = false;
+
+	/* Update Common information */
+	phydm_set_common_phy_info(rx_power, phy_sta_rpt->channel, false,
+		  false, CHANNEL_WIDTH_20, sq, phy_sta_rpt->rxsc, phy_info);
+
+	/* Update CCK pwdb */
+	phydm_set_per_path_phy_info(RF_PATH_A, rx_power, 0, 0, 0, phy_info);					/* Update per-path information */
+
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sta_rpt->antidx_d;
+	
+}
+
+void
+phydm_get_rx_phy_status_type1(
+	struct dm_struct		*dm,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	/* type 1 is used for ofdm packet */
+	struct phy_status_rpt_jaguar2_type1	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type1 *)phy_status_inf;
+	s8		rx_pwr_db = -120;
+	s8		rx_path_pwr_db;
+	u8		i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
+	boolean	is_mu;
+
+	/* Update per-path information */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			rx_count++;
+
+			if (rx_count > dm->num_rf_path)
+				break;
+
+			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO sq) */
+			/* EVM report is reported by stream, not path */
+			rx_path_pwr_db = phy_sta_rpt->pwdb[i] - 110;					/* per-path pwdb in dB domain */
+
+			if (pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = phy_sta_rpt->pwdb[i];
+
+			phydm_set_per_path_phy_info(i, rx_path_pwr_db, phy_sta_rpt->rxevm[rx_count - 1],
+				phy_sta_rpt->cfo_tail[i], phy_sta_rpt->rxsnr[i], phy_info);
+
+			/* search maximum pwdb */
+			if (rx_path_pwr_db > rx_pwr_db)
+				rx_pwr_db = rx_path_pwr_db;
+		}
+	}
+
+	/* mapping RX counter from 1~4 to 0~3 */
+	if (rx_count > 0)
+		phy_info->rx_count = rx_count - 1;
+
+	/* Check if MU packet or not */
+	if ((phy_sta_rpt->gid != 0) && (phy_sta_rpt->gid != 63)) {
+		is_mu = true;
+		dm->phy_dbg_info.num_qry_mu_pkt++;
+	} else
+		is_mu = false;
+
+	/* count BF packet */
+	dm->phy_dbg_info.num_qry_bf_pkt = dm->phy_dbg_info.num_qry_bf_pkt + phy_sta_rpt->beamformed;
+
+	/*STBC or LDPC pkt*/
+	dm->phy_dbg_info.is_ldpc_pkt = phy_sta_rpt->ldpc;
+	dm->phy_dbg_info.is_stbc_pkt = phy_sta_rpt->stbc;
+
+	/* Check sub-channel */
+	if ((pktinfo->data_rate > ODM_RATE11M) && (pktinfo->data_rate < ODM_RATEMCS0))
+		rxsc = phy_sta_rpt->l_rxsc;
+	else
+		rxsc = phy_sta_rpt->ht_rxsc;
+
+	/* Check RX bandwidth */
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if ((rxsc >= 1) && (rxsc <= 8))
+			bw = CHANNEL_WIDTH_20;
+		else if ((rxsc >= 9) && (rxsc <= 12))
+			bw = CHANNEL_WIDTH_40;
+		else if (rxsc >= 13)
+			bw = CHANNEL_WIDTH_80;
+		else
+			bw = phy_sta_rpt->rf_mode;
+		
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (phy_sta_rpt->rf_mode == 0)
+			bw = CHANNEL_WIDTH_20;
+		else if ((rxsc == 1) || (rxsc == 2))
+			bw = CHANNEL_WIDTH_20;
+		else
+			bw = CHANNEL_WIDTH_40;
+	}
+
+	/* Update packet information */
+	phydm_set_common_phy_info(rx_pwr_db, phy_sta_rpt->channel, (boolean)phy_sta_rpt->beamformed,
+		is_mu, bw, phy_info->rx_mimo_signal_quality[0], rxsc, phy_info);
+
+	phydm_parsing_cfo(dm, pktinfo, phy_sta_rpt->cfo_tail, pktinfo->rate_ss);
+
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sta_rpt->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sta_rpt->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sta_rpt->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sta_rpt->antidx_d;
+	#endif
+}
+
+void
+phydm_get_rx_phy_status_type2(
+	struct dm_struct		*dm,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	struct phy_status_rpt_jaguar2_type2	*phy_sta_rpt = (struct phy_status_rpt_jaguar2_type2 *)phy_status_inf;
+	s8	rx_pwr_db_max = -120;
+	s8	rx_path_pwr_db;
+	u8	i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
+	
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			
+			rx_count++;
+			
+			if (rx_count > dm->num_rf_path)
+				break;
+
+			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO sq) */
+			#if (RTL8197F_SUPPORT == 1)
+			if ((dm->support_ic_type & ODM_RTL8197F) && (phy_sta_rpt->pwdb[i] == 0x7f)) { /*for 97f workaround*/
+
+				if (i == RF_PATH_A) {
+					rx_path_pwr_db = (phy_sta_rpt->gain_a) << 1;
+					rx_path_pwr_db = rx_path_pwr_db - 110;
+				} else if (i == RF_PATH_B) {
+					rx_path_pwr_db = (phy_sta_rpt->gain_b) << 1;
+					rx_path_pwr_db = rx_path_pwr_db - 110;
+				} else
+					rx_path_pwr_db = 0;
+			} else
+			#endif
+				rx_path_pwr_db = phy_sta_rpt->pwdb[i] - 110;	/*unit: (dBm)*/
+
+			phydm_set_per_path_phy_info(i, rx_path_pwr_db, 0, 0, 0, phy_info);
+
+			if (rx_path_pwr_db > rx_pwr_db_max	 /* search maximum pwdb */)
+				rx_pwr_db_max = rx_path_pwr_db;
+		}
+	}
+
+	/* mapping RX counter from 1~4 to 0~3 */
+	if (rx_count > 0)
+		phy_info->rx_count = rx_count - 1;
+
+	/* Check RX sub-channel */
+	if ((pktinfo->data_rate > ODM_RATE11M) && (pktinfo->data_rate < ODM_RATEMCS0))
+		rxsc = phy_sta_rpt->l_rxsc;
+	else
+		rxsc = phy_sta_rpt->ht_rxsc;
+
+	/*STBC or LDPC pkt*/
+	dm->phy_dbg_info.is_ldpc_pkt = phy_sta_rpt->ldpc;
+	dm->phy_dbg_info.is_stbc_pkt = phy_sta_rpt->stbc;
+
+	/* Check RX bandwidth */
+	/* the BW information of sc=0 is useless, because there is no information of RF mode*/
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if ((rxsc >= 1) && (rxsc <= 8))
+			bw = CHANNEL_WIDTH_20;
+		else if ((rxsc >= 9) && (rxsc <= 12))
+			bw = CHANNEL_WIDTH_40;
+		else if (rxsc >= 13)
+			bw = CHANNEL_WIDTH_80;
+
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (rxsc == 3)
+			bw = CHANNEL_WIDTH_40;
+		else if ((rxsc == 1) || (rxsc == 2))
+			bw = CHANNEL_WIDTH_20;
+	}
+
+	/* Update packet information */
+	phydm_set_common_phy_info(rx_pwr_db_max, phy_sta_rpt->channel, (boolean)phy_sta_rpt->beamformed,
+				  false, bw, 0, rxsc, phy_info);
+}
+
+void
+phydm_process_rssi_for_dm_new_type(
+	struct dm_struct			*dm,
+	struct phydm_phyinfo_struct		*phy_info,
+	struct phydm_perpkt_info_struct			*pktinfo
+)
+{
+	s32				rssi_pre;
+	u32				rssi_linear = 0;
+	s16				rssi_avg_db = 0;
+	u8				i;
+	struct cmn_sta_info	*sta;
+
+	if (pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
+		return;
+
+	sta = dm->phydm_sta_info[pktinfo->station_id];
+
+	if (!is_sta_active(sta))
+		return;
+
+	if ((!pktinfo->is_packet_match_bssid))/*data frame only*/
+		return;
+
+	if (pktinfo->is_packet_beacon)
+		dm->phy_dbg_info.num_qry_beacon_pkt++;
+
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	if (dm->support_ability & ODM_BB_ANT_DIV)
+		odm_process_rssi_for_ant_div(dm, phy_info, pktinfo);
+#endif
+
+#ifdef CONFIG_ADAPTIVE_SOML
+phydm_rx_qam_for_soml(dm, pktinfo);
+#endif
+
+#ifdef CONFIG_DYNAMIC_RX_PATH
+	phydm_process_phy_status_for_dynamic_rx_path(dm, phy_info, pktinfo);
+#endif
+
+	if (pktinfo->is_packet_to_self || pktinfo->is_packet_beacon) {
+		rssi_pre = sta->rssi_stat.rssi;
+
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			if (phy_info->rx_mimo_signal_strength[i] != 0)
+				rssi_linear += odm_convert_to_linear(phy_info->rx_mimo_signal_strength[i]);
+		}
+
+		switch (phy_info->rx_count + 1) {
+		case 2:
+			rssi_linear = (rssi_linear >> 1);
+			break;
+		case 3:
+			rssi_linear = ((rssi_linear) + (rssi_linear << 1) + (rssi_linear << 3)) >> 5;	/* rssi_linear/3 ~ rssi_linear*11/32 */
+			break;
+		case 4:
+			rssi_linear = (rssi_linear >> 2);
+			break;
+		}
+		
+		rssi_avg_db = (s16)odm_convert_to_db(rssi_linear);
+
+		if (rssi_pre <= 0) {
+			sta->rssi_stat.rssi_acc = (s16)(phy_info->rx_pwdb_all << RSSI_MA_FACTOR);
+			sta->rssi_stat.rssi = (s8)(phy_info->rx_pwdb_all);
+		} else {
+			sta->rssi_stat.rssi_acc = sta->rssi_stat.rssi_acc - (sta->rssi_stat.rssi_acc >> RSSI_MA_FACTOR) + rssi_avg_db;
+			sta->rssi_stat.rssi = (s8)((sta->rssi_stat.rssi_acc + (1 << (RSSI_MA_FACTOR - 1))) >> RSSI_MA_FACTOR);
+		}
+
+		#if 0
+		if (pktinfo->is_packet_match_bssid) {
+			PHYDM_DBG(dm, DBG_TMP, "RSSI[%d]{A,B,Avg}=%d, %d, %d\n", 
+				pktinfo->station_id, phy_info->rx_mimo_signal_strength[0], 
+				phy_info->rx_mimo_signal_strength[1], rssi_ave);
+			PHYDM_DBG(dm, DBG_TMP, "{new, old}=%d, %d\n", sta->rssi_stat.rssi, rssi_pre);
+		}
+		#endif
+		
+		if (pktinfo->is_cck_rate)
+			sta->rssi_stat.rssi_cck = (s8)rssi_avg_db;
+		else
+			sta->rssi_stat.rssi_ofdm = (s8)rssi_avg_db;
+
+
+	}
+}
+
+void
+phydm_rx_phy_status_new_type(
+	void							*dm_void,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct		*pktinfo,
+	struct phydm_phyinfo_struct	*phy_info
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#ifdef PHYDM_PHYSTAUS_SMP_MODE
+	struct pkt_process_info			*pkt_process = &dm->pkt_proc_struct;
+#endif
+	u8		phy_status_type = (*phy_status_inf & 0xf);
+
+#ifdef PHYDM_PHYSTAUS_SMP_MODE
+	if (pkt_process->phystatus_smp_mode_en && phy_status_type != 0) {
+		if (pkt_process->pre_ppdu_cnt == pktinfo->ppdu_cnt)
+			return;
+
+		pkt_process->pre_ppdu_cnt = pktinfo->ppdu_cnt;
+	}
+#endif
+	
+	phydm_reset_phy_info(dm, phy_info); /* Memory reset */
+	
+	/* Phy status parsing */
+	switch (phy_status_type) {
+	case 0:	/*CCK*/
+		phydm_get_rx_phy_status_type0(dm, phy_status_inf, pktinfo, phy_info);
+		break;
+	case 1:
+		phydm_get_rx_phy_status_type1(dm, phy_status_inf, pktinfo, phy_info);
+		break;
+	case 2:
+		phydm_get_rx_phy_status_type2(dm, phy_status_inf, pktinfo, phy_info);
+		break;
+	default:
+		break;
+	}
+	
+	#if (RTL8822B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_print_phy_status_jarguar2(dm, phy_status_inf, pktinfo, phy_info, phy_status_type);
+	#endif
+	
+}
+/*==============================================*/
+#endif
+
+void
+odm_phy_status_query(
+	struct dm_struct		*dm,
+	struct phydm_phyinfo_struct	*phy_info,
+	u8							*phy_status_inf,
+	struct phydm_perpkt_info_struct	*pktinfo
+)
+{
+	pktinfo->is_cck_rate = (pktinfo->data_rate <= ODM_RATE11M) ? true : false;
+	pktinfo->rate_ss = phydm_rate_to_num_ss(dm, pktinfo->data_rate);
+	dm->rate_ss = pktinfo->rate_ss;	/*For AP EVM SW antenna diversity use*/
+
+	if (pktinfo->is_cck_rate)
+		dm->phy_dbg_info.num_qry_phy_status_cck++;
+	else
+		dm->phy_dbg_info.num_qry_phy_status_ofdm++;
+	
+	/*Reset phy_info*/
+	odm_memory_set(dm, phy_info->rx_mimo_signal_strength, 0, 4);
+	odm_memory_set(dm, phy_info->rx_mimo_signal_quality, 0, 4);
+	
+	if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+		phydm_rx_phy_status_new_type(dm, phy_status_inf, pktinfo, phy_info);
+		phydm_process_rssi_for_dm_new_type(dm, phy_info, pktinfo);
+		#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		#if	ODM_IC_11AC_SERIES_SUPPORT
+		phydm_rx_phy_status_jaguar_series_parsing(dm, phy_info, phy_status_inf, pktinfo);
+		phydm_process_rssi_for_dm(dm, phy_info, pktinfo);
+		#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		#if	ODM_IC_11N_SERIES_SUPPORT
+		phydm_rx_phy_status92c_series_parsing(dm, phy_info, phy_status_inf, pktinfo);
+		phydm_process_rssi_for_dm(dm, phy_info, pktinfo);
+		#endif
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	phydm_process_signal_strength(dm, phy_info, pktinfo);
+	#endif
+
+	if (pktinfo->is_packet_match_bssid) {
+		
+		dm->rx_rate = pktinfo->data_rate;
+		dm->rssi_a = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+		dm->rssi_b = phy_info->rx_mimo_signal_strength[RF_PATH_B];
+		dm->rssi_c = phy_info->rx_mimo_signal_strength[RF_PATH_C];
+		dm->rssi_d = phy_info->rx_mimo_signal_strength[RF_PATH_D];
+		
+		phydm_avg_phystatus_index(dm, phy_info, pktinfo);
+		phydm_rx_statistic_cal(dm, phy_info, phy_status_inf, pktinfo);
+	}
+}
+
+void
+phydm_rx_phy_status_init(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info		*dbg = &dm->phy_dbg_info;
+#ifdef PHYDM_PHYSTAUS_SMP_MODE	
+	struct pkt_process_info			*pkt_process = &dm->pkt_proc_struct;
+
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		pkt_process->phystatus_smp_mode_en = 1;
+		pkt_process->pre_ppdu_cnt = 0xff;
+
+		odm_set_mac_reg(dm, 0x60f, BIT(7), 1); /*phystatus sampling mode enable*/
+
+		odm_set_bb_reg(dm, 0x9e4, 0x3ff, 0x0); /*First update timming*/
+		odm_set_bb_reg(dm, 0x9e4, 0xfc00, 0x0); /*Update Sampling time*/
+	}
+#endif
+
+	dbg->show_phy_sts_all_pkt = 0;
+	dbg->show_phy_sts_max_cnt = 1;
+	dbg->show_phy_sts_cnt = 0;
+	
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_phystatus.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_phystatus.h
new file mode 100644
index 000000000000..0d53069387fd
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_phystatus.h
@@ -0,0 +1,1084 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_PHYSTATUS_H__
+#define	__PHYDM_PHYSTATUS_H__
+
+
+/*--------------------------Define -------------------------------------------*/
+#define	CCK_RSSI_INIT_COUNT 5
+
+#define	RA_RSSI_STATE_INIT	0
+#define	RA_RSSI_STATE_SEND	1
+#define	RA_RSSI_STATE_HOLD	2
+
+#define	CFO_HW_RPT_2_KHZ(val) ((val<<1) + (val>>1))
+/* (X* 312.5 Khz)>>7 ~=  X*2.5 Khz= (X<<1 + X>>1)Khz  */
+
+#define	IGI_2_RSSI(igi)	(igi - 10)
+
+#define	PHY_STATUS_JRGUAR2_DW_LEN		7	/* 7*4 = 28 Byte */
+#define	SHOW_PHY_STATUS_UNLIMITED		0
+#define	RSSI_MA_FACTOR					4
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+__PACK struct phy_rx_agc_info {
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8	gain: 7, trsw: 1;
+#else
+	u8	trsw: 1, gain: 7;
+#endif
+};
+
+__PACK struct phy_status_rpt_8192cd {
+	struct phy_rx_agc_info path_agc[2];
+	u8	ch_corr[2];
+	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;
+	s8	path_cfotail[2];
+	u8	pcts_mask[2];
+	s8	stream_rxevm[2];
+	u8	path_rxsnr[2];
+	u8	noise_power_db_lsb;
+	u8	rsvd_2[3];
+	u8	stream_csi[2];
+	u8	stream_target_csi[2];
+	s8	sig_evm;
+	u8	rsvd_3;
+
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	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_8812 {
+	/*	DWORD 0*/
+	u8			gain_trsw[2];							/*path-A and path-B {TRSW, gain[6:0] }*/
+	u8			chl_num_LSB;							/*channel number[7:0]*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			chl_num_MSB: 2;							/*channel number[9:8]*/
+	u8			sub_chnl: 4;								/*sub-channel location[3:0]*/
+	u8			r_RFMOD: 2;								/*RF mode[1:0]*/
+#else	/*_BIG_ENDIAN_	*/
+	u8			r_RFMOD: 2;
+	u8			sub_chnl: 4;
+	u8			chl_num_MSB: 2;
+#endif
+
+	/*	DWORD 1*/
+	u8			pwdb_all;								/*CCK signal quality / OFDM pwdb all*/
+	s8			cfosho[2];		/*DW1 byte 1 DW1 byte2	CCK AGC report and CCK_BB_Power / OFDM path-A and path-B short CFO*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	/*this should be checked again because the definition of 8812 and 8814 is different*/
+	/*	u8			r_cck_rx_enable_pathc:2;					cck rx enable pathc[1:0]*/
+	/*	u8			cck_rx_path:4;							cck rx path[3:0]*/
+	u8			resvd_0: 6;
+	u8			bt_RF_ch_MSB: 2;						/*8812A:2'b0			8814A: bt rf channel keep[7:6]*/
+#else	/*_BIG_ENDIAN_*/
+	u8			bt_RF_ch_MSB: 2;
+	u8			resvd_0: 6;
+#endif
+
+	/*	DWORD 2*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			ant_div_sw_a: 1;							/*8812A: ant_div_sw_a    8814A: 1'b0*/
+	u8			ant_div_sw_b: 1;							/*8812A: ant_div_sw_b    8814A: 1'b0*/
+	u8			bt_RF_ch_LSB: 6;						/*8812A: 6'b0                   8814A: bt rf channel keep[5:0]*/
+#else	/*_BIG_ENDIAN_	*/
+	u8			bt_RF_ch_LSB: 6;
+	u8			ant_div_sw_b: 1;
+	u8			ant_div_sw_a: 1;
+#endif
+	s8			cfotail[2];		   /*DW2 byte 1 DW2 byte 2	path-A and path-B CFO tail*/
+	u8			PCTS_MSK_RPT_0;						/*PCTS mask report[7:0]*/
+	u8			PCTS_MSK_RPT_1;						/*PCTS mask report[15:8]*/
+
+	/*	DWORD 3*/
+	s8			rxevm[2];	         /*DW3 byte 1 DW3 byte 2	stream 1 and stream 2 RX EVM*/
+	s8			rxsnr[2];	         /*DW3 byte 3 DW4 byte 0	path-A and path-B RX SNR*/
+
+	/*	DWORD 4*/
+	u8			PCTS_MSK_RPT_2;						/*PCTS mask report[23:16]*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			PCTS_MSK_RPT_3: 6;						/*PCTS mask report[29:24]*/
+	u8			pcts_rpt_valid: 1;							/*pcts_rpt_valid*/
+	u8			resvd_1: 1;								/*1'b0*/
+#else	/*_BIG_ENDIAN_*/
+	u8			resvd_1: 1;
+	u8			pcts_rpt_valid: 1;
+	u8			PCTS_MSK_RPT_3: 6;
+#endif
+	s8			rxevm_cd[2];	   /*DW 4 byte 3 DW5 byte 0  8812A: 16'b0	8814A: stream 3 and stream 4 RX EVM*/
+
+	/*	DWORD 5*/
+	u8			csi_current[2];	   /*DW5 byte 1 DW5 byte 2	8812A: stream 1 and 2 CSI	8814A:  path-C and path-D RX SNR*/
+	u8			gain_trsw_cd[2];	   /*DW5 byte 3 DW6 byte 0	path-C and path-D {TRSW, gain[6:0] }*/
+
+	/*	DWORD 6*/
+	s8			sigevm;									/*signal field EVM*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			antidx_antc: 3;							/*8812A: 3'b0		8814A: antidx_antc[2:0]*/
+	u8			antidx_antd: 3;							/*8812A: 3'b0		8814A: antidx_antd[2:0]*/
+	u8			dpdt_ctrl_keep: 1;						/*8812A: 1'b0		8814A: dpdt_ctrl_keep*/
+	u8			GNT_BT_keep: 1;							/*8812A: 1'b0		8814A: GNT_BT_keep*/
+#else	/*_BIG_ENDIAN_*/
+	u8			GNT_BT_keep: 1;
+	u8			dpdt_ctrl_keep: 1;
+	u8			antidx_antd: 3;
+	u8			antidx_antc: 3;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8			antidx_anta: 3;							/*antidx_anta[2:0]*/
+	u8			antidx_antb: 3;							/*antidx_antb[2:0]*/
+	u8			hw_antsw_occur: 2;								/*1'b0*/
+#else	/*_BIG_ENDIAN_*/
+	u8			hw_antsw_occur: 2;
+	u8			antidx_antb: 3;
+	u8			antidx_anta: 3;
+#endif
+};
+
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+
+__PACK struct phy_status_rpt_jaguar2_type0 {
+	/* DW0 */
+	u8		page_num;
+	u8		pwdb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		gain: 6;
+	u8		rsvd_0: 1;
+	u8		trsw: 1;
+#else
+	u8		trsw: 1;
+	u8		rsvd_0: 1;
+	u8		gain: 6;
+#endif
+	u8		rsvd_1;
+
+	/* DW1 */
+	u8		rsvd_2;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rxsc: 4;
+	u8		agc_table: 4;
+#else
+	u8		agc_table: 4;
+	u8		rxsc: 4;
+#endif
+	u8		channel;
+	u8		band;
+
+	/* DW2 */
+	u16		length;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 3;
+	u8		antidx_b: 3;
+	u8		rsvd_3: 2;
+	u8		antidx_c: 3;
+	u8		antidx_d: 3;
+	u8		rsvd_4:2;
+#else
+	u8		rsvd_3: 2;
+	u8		antidx_b: 3;
+	u8		antidx_a: 3;
+	u8		rsvd_4:2;
+	u8		antidx_d: 3;
+	u8		antidx_c: 3;
+#endif
+
+	/* DW3 */
+	u8		signal_quality;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga:5;
+	u8		lna_l:3;
+	u8		bb_power:6;
+	u8		rsvd_9:1;
+	u8		lna_h:1;
+#else
+	u8		lna_l:3;
+	u8		vga:5;
+	u8		lna_h:1;
+	u8		rsvd_9:1;
+	u8		bb_power:6;
+#endif
+	u8		rsvd_5;
+
+	/* DW4 */
+	u32		rsvd_6;
+
+	/* DW5 */
+	u32		rsvd_7;
+
+	/* DW6 */
+	u32		rsvd_8;
+};
+
+__PACK struct phy_status_rpt_jaguar2_type1 {
+	/* DW0 and DW1 */
+	u8		page_num;
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 */
+	u16		lsig_length;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 3;
+	u8		antidx_b: 3;
+	u8		rsvd_1: 2;
+	u8		antidx_c: 3;
+	u8		antidx_d: 3;
+	u8		rsvd_2: 2;
+#else
+	u8		rsvd_1: 2;
+	u8		antidx_b: 3;
+	u8		antidx_a: 3;
+	u8		rsvd_2: 2;
+	u8		antidx_d: 3;
+	u8		antidx_c: 3;
+#endif
+
+	/* DW3 */
+	u8		paid;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		paid_msb: 1;
+	u8		gid: 6;
+	u8		rsvd_3: 1;
+#else
+	u8		rsvd_3: 1;
+	u8		gid: 6;
+	u8		paid_msb: 1;
+#endif
+	u8		intf_pos;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		intf_pos_msb: 1;
+	u8		rsvd_4: 2;
+	u8		nb_intf_flag: 1;
+	u8		rf_mode: 2;
+	u8		rsvd_5: 2;
+#else
+	u8		rsvd_5: 2;
+	u8		rf_mode: 2;
+	u8		nb_intf_flag: 1;
+	u8		rsvd_4: 2;
+	u8		intf_pos_msb: 1;
+#endif
+
+	/* DW4 */
+	s8		rxevm[4];			/* s(8,1) */
+
+	/* DW5 */
+	s8		cfo_tail[4];			/* s(8,7) */
+
+	/* DW6 */
+	s8		rxsnr[4];			/* s(8,1) */
+};
+
+__PACK struct phy_status_rpt_jaguar2_type2 {
+	/* DW0 ane DW1 */
+	u8		page_num;
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		shift_l_map: 6;
+	u8		rsvd_1: 2;
+#else
+	u8		rsvd_1: 2;
+	u8		shift_l_map: 6;
+#endif
+	u8		cnt_pw2cca;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		agc_table_a: 4;
+	u8		agc_table_b: 4;
+	u8		agc_table_c: 4;
+	u8		agc_table_d: 4;
+#else
+	u8		agc_table_b: 4;
+	u8		agc_table_a: 4;
+	u8		agc_table_d: 4;
+	u8		agc_table_c: 4;
+#endif
+
+	/* DW3 ~ DW6*/
+	u8		cnt_cca2agc_rdy;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		gain_a: 6;
+	u8		rsvd_2: 1;
+	u8		trsw_a: 1;
+	u8		gain_b: 6;
+	u8		rsvd_3: 1;
+	u8		trsw_b: 1;
+	u8		gain_c: 6;
+	u8		rsvd_4: 1;
+	u8		trsw_c: 1;
+	u8		gain_d: 6;
+	u8		rsvd_5: 1;
+	u8		trsw_d: 1;
+	u8		aagc_step_a: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_d: 2;
+#else
+	u8		trsw_a: 1;
+	u8		rsvd_2: 1;
+	u8		gain_a: 6;
+	u8		trsw_b: 1;
+	u8		rsvd_3: 1;
+	u8		gain_b: 6;
+	u8		trsw_c: 1;
+	u8		rsvd_4: 1;
+	u8		gain_c: 6;
+	u8		trsw_d: 1;
+	u8		rsvd_5: 1;
+	u8		gain_d: 6;
+	u8		aagc_step_d: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_a: 2;
+#endif
+	u8		ht_aagc_gain[4];
+	u8		dagc_gain[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		counter: 6;
+	u8		rsvd_6: 2;
+	u8		syn_count: 5;
+	u8		rsvd_7:3;
+#else
+	u8		rsvd_6: 2;
+	u8		counter: 6;
+	u8		rsvd_7:3;
+	u8		syn_count: 5;
+#endif
+};
+#endif
+
+/*==============================================*/
+#if (CONFIG_PHYSTS_3RD_TYPE)
+__PACK struct _phy_status_rpt_jaguar3_type0 {
+	/* DW0 : Offset 0 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb_a;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		gain_a: 6;
+	u8		rsvd_0: 1;
+	u8		trsw: 1;
+#else
+	u8		trsw: 1;
+	u8		rsvd_0: 1;
+	u8		gain_a: 6;
+#endif
+
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		agc_table_b:4;
+	u8		agc_table_c:4;
+#else
+	u8		agc_table_c:4;
+	u8		agc_table_b:4;
+#endif
+
+	/* DW1 : Offset 4 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rsvd_1: 4;
+	u8		agc_table_d: 4;
+#else
+	u8		agc_table_d: 4;
+	u8		rsvd_1: 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		agc_table_a: 4;
+#else
+	u8		agc_table_a: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band:2;
+	u8		rsvd_2_1: 1;
+	u8		hw_antsw_occur_keep_cck:1;
+	u8		gnt_bt_keep_cck:1;
+	u8		rsvd_2_2:3;
+#else
+	u8		rsvd_2_2:3;
+	u8		gnt_bt_keep_cck:1;
+	u8		hw_antsw_occur_keep_cck:1;
+	u8		rsvd_2_1: 1;
+	u8		band:2;
+#endif
+
+	/* DW2 : Offset 8 */
+	u16		length;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+
+	/* DW3 : Offset 12 */
+	u8		signal_quality;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_a:5;
+	u8		lna_l_a:3;
+	u8		bb_power_a:6;
+	u8		rsvd_3_1:1;
+	u8		lna_h_a:1;
+#else
+	u8		lna_l_a:3;
+	u8		vga_a:5;
+	u8		lna_h_a:1;
+	u8		rsvd_3_1:1;
+	u8		bb_power_a:6;
+#endif
+	u8		rsvd_3_2;
+
+	/* DW4 : Offset 16 */
+	u8		pwdb_b;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_b:5;
+	u8		lna_l_b:3;
+	u8		bb_power_b:6;
+	u8		rsvd_4_1:1;
+	u8		lna_h_b:1;
+	u8		gain_b: 6;
+	u8		rsvd_4_2:2;
+#else
+	u8		lna_l_b:3;
+	u8		vga_b:5;
+	u8		lna_h_b:1;
+	u8		rsvd_4_1:1;
+	u8		bb_power_b:6;
+	u8		rsvd_4_2:2;
+	u8		gain_b: 6;
+#endif
+
+	/* DW5 : Offset 20 */
+	u8		pwdb_c;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_c:5;
+	u8		lna_l_c:3;
+	u8		bb_power_c:6;
+	u8		rsvd_5_1:1;
+	u8		lna_h_c:1;
+	u8		gain_c: 6;
+	u8		rsvd_5_2:2;
+#else
+	u8		lna_l_c:3;
+	u8		vga_c:5;
+	u8		lna_h_c:1;
+	u8		rsvd_5_1:1;
+	u8		bb_power_c:6;
+	u8		rsvd_5_2:2;
+	u8		gain_c: 6;
+#endif
+
+	/* DW6 : Offset 24 */
+	u8		pwdb_d;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		vga_d:5;
+	u8		lna_l_d:3;
+	u8		bb_power_d:6;
+	u8		rsvd_6_1:1;
+	u8		lna_h_d:1;
+	u8		gain_d: 6;
+	u8		rsvd_6_2:2;
+#else
+	u8		lna_l_d:3;
+	u8		vga_d:5;
+	u8		lna_h_d:1;
+	u8		rsvd_6_1:1;
+	u8		bb_power_d:6;
+	u8		rsvd_6_2:2;
+	u8		gain_d: 6;
+#endif
+};
+
+__PACK struct _phy_status_rpt_jaguar3_type1 {
+	/* DW0 : Offset 0 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_pri_msb:2;
+#else
+	u8		channel_pri_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb_a;
+	u8		pwdb_b;
+	u8		pwdb_c;
+
+	/* DW1 : Offset 4 */
+	u8		pwdb_d;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_pri_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 2;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		rsvd_0: 2;
+	u8		band: 2;
+#endif
+
+	/* DW2 : Offset 8 */
+	u8		channel_sec_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		channel_sec_msb:2;
+	u8		rsvd_1: 2;
+	u8		hw_antsw_occur_a:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_d:1;
+#else
+	u8		hw_antsw_occur_d:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_a:1;
+	u8		rsvd_1: 2;
+	u8		channel_sec_msb:2;
+
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+
+	/* DW3 : Offset 12 */
+	u8		paid;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		paid_msb: 1;
+	u8		gid: 6;
+	u8		rsvd_3: 1;
+#else
+	u8		rsvd_3: 1;
+	u8		gid: 6;
+	u8		paid_msb: 1;
+#endif
+	u16		rsvd_4;
+/*
+	u8		rsvd_4;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rsvd_5: 6;
+	u8		rf_mode: 2;
+#else
+	u8		rf_mode: 2;
+	u8		rsvd_5: 6;
+#endif
+*/
+	/* DW4 */
+	s8		rxevm[4];			/* s(8,1) */
+
+	/* DW5 */
+	s8		cfo_tail[4];			/* s(8,7) */
+
+	/* DW6 */
+	s8		rxsnr[4];			/* s(8,1) */
+};
+__PACK struct _phy_status_rpt_jaguar3_type2_type3 {
+	/* Type2 is primary channel & type3 is secondary channel */
+	/* DW0 ane DW1 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		shift_l_map: 6;
+	u8		rsvd_1: 2;
+#else
+	u8		rsvd_1: 2;
+	u8		shift_l_map: 6;
+#endif
+	s8		pwed_th;	/* dynamic energy threshold S(8,2) */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		agc_table_a: 4;
+	u8		agc_table_b: 4;
+	u8		agc_table_c: 4;
+	u8		agc_table_d: 4;
+#else
+	u8		agc_table_b: 4;
+	u8		agc_table_a: 4;
+	u8		agc_table_d: 4;
+	u8		agc_table_c: 4;
+#endif
+
+	/* DW3 ~ DW6*/
+	u8		cnt_cca2agc_rdy; /* Time(ns) = cnt_cca2agc_ready*25 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		mp_gain_a: 6;
+	u8		mp_gain_b_lsb: 2;
+	u8		mp_gain_b_msb: 4;
+	u8		mp_gain_c_lsb: 4;
+	u8		mp_gain_c_msb: 2;
+	u8		avg_noise_pwr_lsb: 4;
+	u8		rsvd_3:2;
+	/* u8		r_rfmod:2; */
+	u8		mp_gain_d: 6;
+	u8		is_freq_select_fading: 1;
+	u8		rsvd_2: 1;
+	u8		aagc_step_a: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_d: 2;
+#else
+	u8		mp_gain_b_lsb: 2;
+	u8		mp_gain_a: 6;
+	u8		mp_gain_c_lsb: 4;
+	u8		mp_gain_b_msb: 4;
+	u8		rsvd_3:2;
+	/* u8		r_rfmod:2; */
+	u8		avg_noise_pwr_lsb: 4;
+	u8		mp_gain_c_msb: 2;
+	u8		rsvd_2: 1;
+	u8		is_freq_select_fading: 1;
+	u8		mp_gain_d: 6;
+	u8		aagc_step_d: 2;
+	u8		aagc_step_c: 2;
+	u8		aagc_step_b: 2;
+	u8		aagc_step_a: 2;
+#endif
+	u8		ht_aagc_gain[4];
+	u8		dagc_gain[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		counter: 6;
+	u8		syn_count_lsb: 2;
+	u8		syn_count_msb: 3;
+	u8		avg_noise_pwr_msb:5;
+#else
+	u8		syn_count_lsb: 2;
+	u8		counter: 6;
+	u8		avg_noise_pwr_msb:5;
+	u8		syn_count_msb: 3;
+#endif
+};
+
+__PACK struct _phy_status_rpt_jaguar3_type4 {
+	/* smart antenna */
+	/* DW0 ane DW1 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+
+	/* DW2 ~ DW3 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		bad_tone_cnt_min_eign_0:4;
+	u8		bad_tone_cnt_cn_excess_0:4;
+	u8		training_done_a:1;
+	u8		training_done_b:1;
+	u8		training_done_c:1;
+	u8		training_done_d:1;
+	u8		hw_antsw_occur_a:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_d:1;
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		bad_tone_cnt_cn_excess_0:4;
+	u8		bad_tone_cnt_min_eign_0:4;
+	u8		hw_antsw_occur_d:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_a:1;
+	u8		training_done_d:1;
+	u8		training_done_c:1;
+	u8		training_done_b:1;
+	u8		training_done_a:1;
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+	u8		tx_pkt_cnt;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		bad_tone_cnt_min_eign_1:4;
+	u8		bad_tone_cnt_cn_excess_1:4;
+	u8		avg_cond_num_0:7;
+	u8		avg_cond_num_1_lsb:1;
+	u8		avg_cond_num_1_msb:6;
+	u8		rsvd_1:2;
+#else
+	u8		bad_tone_cnt_cn_excess_1:4;
+	u8		bad_tone_cnt_min_eign_1:4;
+	u8		avg_cond_num_1_lsb:1;
+	u8		avg_cond_num_0:7;
+	u8		rsvd_1:2;
+	u8		avg_cond_num_1_msb:6;
+#endif
+
+	/* DW4 */
+	s8		rxevm[4];			/* s(8,1) */
+
+	/* DW5 */
+	u8		eigenvalue[4];			/* eigenvalue or eigenvalue of seg0 (in dB) */
+
+	/* DW6 */
+	s8		rxsnr[4];			/* s(8,1) */
+};
+
+__PACK struct _phy_status_rpt_jaguar2_type5 {
+	/* smart antenna */
+	/* DW0 ane DW1 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		page_num:4;
+	u8		pkt_cnt:2;
+	u8		channel_msb:2;
+#else
+	u8		channel_msb:2;
+	u8		pkt_cnt:2;
+	u8		page_num:4;
+#endif
+	u8		pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		l_rxsc: 4;
+	u8		ht_rxsc: 4;
+#else
+	u8		ht_rxsc: 4;
+	u8		l_rxsc: 4;
+#endif
+	u8		channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		band: 2;
+	u8		rsvd_0: 1;
+	u8		hw_antsw_occu: 1;
+	u8		gnt_bt: 1;
+	u8		ldpc: 1;
+	u8		stbc: 1;
+	u8		beamformed: 1;
+#else
+	u8		beamformed: 1;
+	u8		stbc: 1;
+	u8		ldpc: 1;
+	u8		gnt_bt: 1;
+	u8		hw_antsw_occu: 1;
+	u8		rsvd_0: 1;
+	u8		band: 2;
+#endif
+	/* DW2 ~ DW5 */
+	u8		rsvd_1;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		rsvd_2:4;
+	u8		hw_antsw_occur_a:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_d:1;
+	u8		antidx_a: 4;
+	u8		antidx_b: 4;
+	u8		antidx_c: 4;
+	u8		antidx_d: 4;
+#else
+	u8		hw_antsw_occur_d:1;
+	u8		hw_antsw_occur_c:1;
+	u8		hw_antsw_occur_b:1;
+	u8		hw_antsw_occur_a:1;
+	u8		rsvd_2:4;
+	u8		antidx_b: 4;
+	u8		antidx_a: 4;
+	u8		antidx_d: 4;
+	u8		antidx_c: 4;
+#endif
+	u8		tx_pkt_cnt;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8		inf_pos_0_A_flg:1;
+	u8		inf_pos_1_A_flg:1;
+	u8		inf_pos_0_B_flg:1;
+	u8		inf_pos_1_B_flg:1;
+	u8		inf_pos_0_C_flg:1;
+	u8		inf_pos_1_C_flg:1;
+	u8		inf_pos_0_D_flg:1;
+	u8		inf_pos_1_D_flg:1;
+#else
+	u8		inf_pos_1_D_flg:1;
+	u8		inf_pos_0_D_flg:1;
+	u8		inf_pos_1_C_flg:1;
+	u8		inf_pos_0_C_flg:1;
+	u8		inf_pos_1_B_flg:1;
+	u8		inf_pos_0_B_flg:1;
+	u8		inf_pos_1_A_flg:1;
+	u8		inf_pos_0_A_flg:1;
+#endif
+	u8		rsvd_3;
+	u8		rsvd_4;
+	u8		inf_pos_0_a;
+	u8		inf_pos_1_a;
+	u8		inf_pos_0_b;
+	u8		inf_pos_1_b;
+	u8		inf_pos_0_c;
+	u8		inf_pos_1_c;
+	u8		inf_pos_0_d;
+	u8		inf_pos_1_d;
+};
+#endif /*#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)*/
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+
+void
+phydm_rx_phy_status_new_type(
+	void						*dm_void,
+	u8						*phy_status_inf,
+	struct phydm_perpkt_info_struct			*pktinfo,
+	struct phydm_phyinfo_struct			*phy_info
+);
+
+boolean
+phydm_query_is_mu_api(
+	struct dm_struct			*phydm,
+	u8								ppdu_idx,
+	u8								*p_data_rate,
+	u8								*p_gid
+);
+#endif
+
+void
+phydm_reset_phystatus_avg(
+	struct dm_struct	*dm
+);
+
+void
+phydm_reset_phystatus_statistic(
+	struct dm_struct	*dm
+);
+
+void
+phydm_reset_rssi_for_dm(
+	struct dm_struct	*dm,
+	u8		station_id
+);
+
+void
+phydm_get_cck_rssi_table_from_reg(
+	struct dm_struct	*dm
+);
+
+u8
+phydm_rate_to_num_ss(
+	struct dm_struct		*dm,
+	u8			data_rate
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_normal_driver_rx_sniffer(
+	struct dm_struct			*dm,
+	u8				*desc,
+	PRT_RFD_STATUS		rt_rfd_status,
+	u8				*drv_info,
+	u8				phy_status
+);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+s32
+phydm_signal_scale_mapping(
+	struct dm_struct *dm,
+	s32 curr_sig
+);
+#endif
+
+void
+odm_phy_status_query(
+	struct dm_struct					*dm,
+	struct phydm_phyinfo_struct			*phy_info,
+	u8						*phy_status_inf,
+	struct phydm_perpkt_info_struct			*pktinfo
+);
+
+void
+phydm_rx_phy_status_init(
+	void			*dm_void
+);
+
+#endif /*#ifndef	__HALHWOUTSRC_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pow_train.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pow_train.c
new file mode 100644
index 000000000000..525cb130c90c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pow_train.c
@@ -0,0 +1,229 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+void
+phydm_reset_pt_para(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc	*pow_train_t = &dm->pow_train_table;
+
+	pow_train_t->pow_train_score = 0;
+	dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+	dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+}
+
+void
+phydm_update_power_training_state(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc	*pow_train_t = &dm->pow_train_table;
+	struct phydm_fa_struct			*fa_cnt = &dm->false_alm_cnt;
+	struct phydm_dig_struct		*dig_t = &dm->dm_dig_table;
+	u32	pt_score_tmp = 0;
+	u32 crc_ok_cnt;
+	u32 cca_all_cnt;
+
+
+	/*is_disable_power_training is the key to H2C to disable/enable power training*/
+	/*if is_disable_power_training == 1, it will use largest power*/
+	if (!(dm->support_ability & ODM_BB_PWR_TRAIN)) {
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_PWR_TRAIN, "%s ======>\n", __FUNCTION__);
+
+	if (pow_train_t->force_power_training_state == DISABLE_POW_TRAIN) {
+		
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Disable PT\n");
+		return;
+
+	} else if (pow_train_t->force_power_training_state == ENABLE_POW_TRAIN) {
+	
+		dm->is_disable_power_training = false;
+		phydm_reset_pt_para(dm);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Enable PT\n");
+		return;
+
+	} else if (pow_train_t->force_power_training_state == DYNAMIC_POW_TRAIN) {
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Dynamic PT\n");
+
+		if (!dm->is_linked) {
+			dm->is_disable_power_training = true;
+			pow_train_t->pow_train_score = 0;
+			dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+			dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "PT is disabled due to no link.\n");
+			return;
+		}
+
+		/* First connect */
+		if ((dm->is_linked) && (!dig_t->is_media_connect)) {
+			pow_train_t->pow_train_score = 0;
+			dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+			dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "(PT)First Connect\n");
+			return;
+		}
+
+		/* Compute score */
+		crc_ok_cnt = dm->phy_dbg_info.num_qry_phy_status_ofdm + dm->phy_dbg_info.num_qry_phy_status_cck;
+		cca_all_cnt = fa_cnt->cnt_cca_all;
+
+		if (crc_ok_cnt < cca_all_cnt) {
+			/* crc_ok <= (2/3)*cca */
+			if ((crc_ok_cnt + (crc_ok_cnt >> 1)) <= cca_all_cnt)
+				pt_score_tmp = DISABLE_PT_SCORE;
+
+			/* crc_ok <= (4/5)*cca */
+			else if ((crc_ok_cnt + (crc_ok_cnt >> 2)) <= cca_all_cnt)
+				pt_score_tmp = KEEP_PRE_PT_SCORE;
+
+			/* crc_ok > (4/5)*cca */
+			else
+				pt_score_tmp = ENABLE_PT_SCORE;
+		} else {
+			pt_score_tmp = ENABLE_PT_SCORE;
+		}
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "crc_ok_cnt = %d, cnt_cca_all = %d\n",
+				crc_ok_cnt, cca_all_cnt);
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "num_qry_phy_status_ofdm = %d, num_qry_phy_status_cck = %d\n",
+			dm->phy_dbg_info.num_qry_phy_status_ofdm, dm->phy_dbg_info.num_qry_phy_status_cck);
+		
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "pt_score_tmp = %d\n", pt_score_tmp);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "pt_score_tmp = 0(DISABLE), 1(KEEP), 2(ENABLE)\n");
+
+		/* smoothing */
+		pow_train_t->pow_train_score = (pt_score_tmp << 4) + (pow_train_t->pow_train_score >> 1) + (pow_train_t->pow_train_score >> 2);
+		pt_score_tmp = (pow_train_t->pow_train_score + 32) >> 6;
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "pow_train_score = %d, score after smoothing = %d\n",
+				pow_train_t->pow_train_score, pt_score_tmp);
+
+		/* mode decision */
+		if (pt_score_tmp == ENABLE_PT_SCORE) {
+			
+			dm->is_disable_power_training = false;
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "Enable power training under dynamic.\n");
+			
+		} else if (pt_score_tmp == DISABLE_PT_SCORE) {
+		
+			dm->is_disable_power_training = true;
+			PHYDM_DBG(dm, DBG_PWR_TRAIN, "Disable PT due to noisy.\n");
+		}
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Final, score = %d, is_disable_power_training = %d\n",
+			pt_score_tmp, dm->is_disable_power_training);
+
+		dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
+		dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+	} else {
+	
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
+
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "PT is disabled due to unknown pt state.\n");
+		return;
+	}
+}
+
+void
+phydm_pow_train_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc	*pow_train_t = &dm->pow_train_table;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "0: Dynamic state\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "1: Enable PT\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "2: Disable PT\n");
+		
+	} else {
+		for (i = 0; i < 10; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+			}
+		}
+
+		if (var1[0] == 0) {
+			pow_train_t->force_power_training_state = DYNAMIC_POW_TRAIN;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Dynamic state\n");
+		} else if (var1[0] == 1) {
+			pow_train_t->force_power_training_state = ENABLE_POW_TRAIN;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Enable PT\n");
+		} else if (var1[0] == 2) {
+			pow_train_t->force_power_training_state = DISABLE_POW_TRAIN;
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Disable PT\n");
+		} else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Set Error\n");
+		}		
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+#endif
+
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pow_train.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pow_train.h
new file mode 100644
index 000000000000..11ce1fb921b2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pow_train.h
@@ -0,0 +1,87 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_POW_TRAIN_H__
+#define    __PHYDM_POW_TRAIN_H__
+
+#define POW_TRAIN_VERSION	"1.0"		/* 2017.07.0141  Dino, Add phydm_pow_train.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+struct phydm_pow_train_stuc {
+	u8		force_power_training_state;
+	u32		pow_train_score;
+};
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+enum pow_train_state {
+	DYNAMIC_POW_TRAIN = 0,
+	ENABLE_POW_TRAIN = 1,
+	DISABLE_POW_TRAIN = 2
+};
+
+enum power_training_score {
+	DISABLE_PT_SCORE = 0,
+	KEEP_PRE_PT_SCORE = 1,
+	ENABLE_PT_SCORE = 2
+};
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_update_power_training_state(
+	void		*dm_void
+);
+
+void
+phydm_pow_train_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ap.c
deleted file mode 100644
index fce05cb685fe..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ap.c
+++ /dev/null
@@ -1,1050 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#if !defined(_OUTSRC_COEXIST)
-//============================================================
-// Global var
-//============================================================
-
-
-u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE_92D] = {
-	0x0b40002d, // 0,  -15.0dB	
-	0x0c000030, // 1,  -14.5dB
-	0x0cc00033, // 2,  -14.0dB
-	0x0d800036, // 3,  -13.5dB
-	0x0e400039, // 4,  -13.0dB    
-	0x0f00003c, // 5,  -12.5dB
-	0x10000040, // 6,  -12.0dB
-	0x11000044, // 7,  -11.5dB
-	0x12000048, // 8,  -11.0dB
-	0x1300004c, // 9,  -10.5dB
-	0x14400051, // 10, -10.0dB
-	0x15800056, // 11, -9.5dB
-	0x16c0005b, // 12, -9.0dB
-	0x18000060, // 13, -8.5dB
-	0x19800066, // 14, -8.0dB
-	0x1b00006c, // 15, -7.5dB
-	0x1c800072, // 16, -7.0dB
-	0x1e400079, // 17, -6.5dB
-	0x20000080, // 18, -6.0dB
-	0x22000088, // 19, -5.5dB
-	0x24000090, // 20, -5.0dB
-	0x26000098, // 21, -4.5dB
-	0x288000a2, // 22, -4.0dB
-	0x2ac000ab, // 23, -3.5dB
-	0x2d4000b5, // 24, -3.0dB
-	0x300000c0, // 25, -2.5dB
-	0x32c000cb, // 26, -2.0dB
-	0x35c000d7, // 27, -1.5dB
-	0x390000e4, // 28, -1.0dB
-	0x3c8000f2, // 29, -0.5dB
-	0x40000100, // 30, +0dB
-	0x43c0010f, // 31, +0.5dB
-	0x47c0011f, // 32, +1.0dB
-	0x4c000130, // 33, +1.5dB
-	0x50800142, // 34, +2.0dB
-	0x55400155, // 35, +2.5dB
-	0x5a400169, // 36, +3.0dB
-	0x5fc0017f, // 37, +3.5dB
-	0x65400195, // 38, +4.0dB
-	0x6b8001ae, // 39, +4.5dB
-	0x71c001c7, // 40, +5.0dB
-	0x788001e2, // 41, +5.5dB
-	0x7f8001fe  // 42, +6.0dB
-};               
-
-u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8] = {
-	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	//  0, -16.0dB
-	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	//  1, -15.5dB
-	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	//  2, -15.0dB
-	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	//  3, -14.5dB
-	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	//  4, -14.0dB
-	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	//  5, -13.5dB
-	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	//  6, -13.0dB
-	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	//  7, -12.5dB
-	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	//  8, -12.0dB
-	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	//  9, -11.5dB
-	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	// 10, -11.0dB
-	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	// 11, -10.5dB
-	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	// 12, -10.0dB
-	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	// 13, -9.5dB
-	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	// 14, -9.0dB 
-	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	// 15, -8.5dB
-	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	// 16, -8.0dB 
-	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	// 17, -7.5dB
-	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	// 18, -7.0dB 
-	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	// 19, -6.5dB
-    	{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02},	// 20, -6.0dB 
-	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	// 21, -5.5dB
-	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	// 22, -5.0dB 
-	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	// 23, -4.5dB
-	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	// 24, -4.0dB 
-	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	// 25, -3.5dB
-	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	// 26, -3.0dB
-	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	// 27, -2.5dB
-	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	// 28, -2.0dB 
-	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	// 29, -1.5dB
-	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	// 30, -1.0dB
-	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	// 31, -0.5dB
-	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} 	// 32, +0dB
-};                                                                  
-
-
-u1Byte CCKSwingTable_Ch14_New[CCK_TABLE_SIZE][8]= {
-	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	//  0, -16.0dB
-	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	//  1, -15.5dB
-	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	//  2, -15.0dB
-	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	//  3, -14.5dB
-	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	//  4, -14.0dB
-	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	//  5, -13.5dB
-	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	//  6, -13.0dB
-	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	//  7, -12.5dB
-	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	//  8, -12.0dB
-	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	//  9, -11.5dB
-	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	// 10, -11.0dB
-	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	// 11, -10.5dB
-	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	// 12, -10.0dB
-	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	// 13, -9.5dB
-	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	// 14, -9.0dB  
-	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	// 15, -8.5dB
-	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	// 16, -8.0dB  
-	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	// 17, -7.5dB
-	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	// 18, -7.0dB  
-	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	// 19, -6.5dB 
-	{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	// 20, -6.0dB  
-	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	// 21, -5.5dB
-	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	// 22, -5.0dB  
-	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	// 23, -4.5dB
-	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	// 24, -4.0dB  
-	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	// 25, -3.5dB  
-	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	// 26, -3.0dB  
-	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	// 27, -2.5dB
-	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	// 28, -2.0dB  
-	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	// 29, -1.5dB
-	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	// 30, -1.0dB  
-	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	// 31, -0.5dB 
-	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} 	// 32, +0dB	
-};
-
-u4Byte OFDMSwingTable[OFDM_TABLE_SIZE_92D] = {
-	0x0b40002d, // 0,  -15.0dB	
-	0x0c000030, // 1,  -14.5dB
-	0x0cc00033, // 2,  -14.0dB
-	0x0d800036, // 3,  -13.5dB
-	0x0e400039, // 4,  -13.0dB    
-	0x0f00003c, // 5,  -12.5dB
-	0x10000040, // 6,  -12.0dB
-	0x11000044, // 7,  -11.5dB
-	0x12000048, // 8,  -11.0dB
-	0x1300004c, // 9,  -10.5dB
-	0x14400051, // 10, -10.0dB
-	0x15800056, // 11, -9.5dB
-	0x16c0005b, // 12, -9.0dB
-	0x18000060, // 13, -8.5dB
-	0x19800066, // 14, -8.0dB
-	0x1b00006c, // 15, -7.5dB
-	0x1c800072, // 16, -7.0dB
-	0x1e400079, // 17, -6.5dB
-	0x20000080, // 18, -6.0dB
-	0x22000088, // 19, -5.5dB
-	0x24000090, // 20, -5.0dB
-	0x26000098, // 21, -4.5dB
-	0x288000a2, // 22, -4.0dB
-	0x2ac000ab, // 23, -3.5dB
-	0x2d4000b5, // 24, -3.0dB
-	0x300000c0, // 25, -2.5dB
-	0x32c000cb, // 26, -2.0dB
-	0x35c000d7, // 27, -1.5dB
-	0x390000e4, // 28, -1.0dB
-	0x3c8000f2, // 29, -0.5dB
-	0x40000100, // 30, +0dB
-	0x43c0010f, // 31, +0.5dB
-	0x47c0011f, // 32, +1.0dB
-	0x4c000130, // 33, +1.5dB
-	0x50800142, // 34, +2.0dB
-	0x55400155, // 35, +2.5dB
-	0x5a400169, // 36, +3.0dB
-	0x5fc0017f, // 37, +3.5dB
-	0x65400195, // 38, +4.0dB
-	0x6b8001ae, // 39, +4.5dB
-	0x71c001c7, // 40, +5.0dB
-	0x788001e2, // 41, +5.5dB
-	0x7f8001fe  // 42, +6.0dB
-};               
-
-
-u1Byte CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8] = {
-	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	//  0, -16.0dB
-	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	//  1, -15.5dB
-	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	//  2, -15.0dB
-	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	//  3, -14.5dB
-	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	//  4, -14.0dB
-	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	//  5, -13.5dB
-	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	//  6, -13.0dB
-	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	//  7, -12.5dB
-	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	//  8, -12.0dB
-	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	//  9, -11.5dB
-	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	// 10, -11.0dB
-	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	// 11, -10.5dB
-	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	// 12, -10.0dB
-	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	// 13, -9.5dB
-	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	// 14, -9.0dB 
-	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	// 15, -8.5dB
-	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	// 16, -8.0dB 
-	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	// 17, -7.5dB
-	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	// 18, -7.0dB 
-	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	// 19, -6.5dB
-    	{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02},	// 20, -6.0dB 
-	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	// 21, -5.5dB
-	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	// 22, -5.0dB 
-	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	// 23, -4.5dB
-	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	// 24, -4.0dB 
-	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	// 25, -3.5dB
-	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	// 26, -3.0dB
-	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	// 27, -2.5dB
-	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	// 28, -2.0dB 
-	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	// 29, -1.5dB
-	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	// 30, -1.0dB
-	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	// 31, -0.5dB
-	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} 	// 32, +0dB
-};                                                                  
-
-
-u1Byte CCKSwingTable_Ch14 [CCK_TABLE_SIZE][8]= {
-	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	//  0, -16.0dB
-	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	//  1, -15.5dB
-	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	//  2, -15.0dB
-	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	//  3, -14.5dB
-	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	//  4, -14.0dB
-	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	//  5, -13.5dB
-	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	//  6, -13.0dB
-	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	//  7, -12.5dB
-	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	//  8, -12.0dB
-	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	//  9, -11.5dB
-	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	// 10, -11.0dB
-	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	// 11, -10.5dB
-	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	// 12, -10.0dB
-	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	// 13, -9.5dB
-	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	// 14, -9.0dB  
-	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	// 15, -8.5dB
-	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	// 16, -8.0dB  
-	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	// 17, -7.5dB
-	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	// 18, -7.0dB  
-	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	// 19, -6.5dB 
-	{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	// 20, -6.0dB  
-	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	// 21, -5.5dB
-	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	// 22, -5.0dB  
-	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	// 23, -4.5dB
-	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	// 24, -4.0dB  
-	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	// 25, -3.5dB  
-	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	// 26, -3.0dB  
-	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	// 27, -2.5dB
-	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	// 28, -2.0dB  
-	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	// 29, -1.5dB
-	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	// 30, -1.0dB  
-	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	// 31, -0.5dB 
-	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} 	// 32, +0dB	
-};
-
-u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {
-{0x16, 0x15, 0x13, 0x10, 0xD, 0x9, 0x6, 0x3, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 0  -16dB */
-{0x18, 0x17, 0x15, 0x12, 0xE, 0xA, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 1  -15.5dB */
-{0x1B, 0x1A, 0x18, 0x14, 0x10, 0xB, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 2  -15dB */
-{0x1F, 0x1E, 0x1B, 0x17, 0x12, 0xD, 0x8, 0x5, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 3  -14.5dB */
-{0x22, 0x21, 0x1E, 0x19, 0x14, 0xE, 0x9, 0x5, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 4  -14dB */
-{0x26, 0x25, 0x22, 0x1C, 0x16, 0x10, 0xA, 0x6, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 5  -13.5dB */
-{0x2B, 0x2A, 0x26, 0x20, 0x19, 0x12, 0xC, 0x7, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 6  -13dB */
-{0x30, 0x2F, 0x2A, 0x24, 0x1C, 0x14, 0xD, 0x8, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 7  -12.5dB */
-{0x36, 0x34, 0x2F, 0x28, 0x1F, 0x17, 0xF, 0x9, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 8  -12dB */
-{0x3D, 0x3B, 0x35, 0x2D, 0x23, 0x19, 0x11, 0xA, 0x5, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 9  -11.5dB */
-{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0xB, 0x5, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 10  -11dB */
-{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0xC, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 11  -10.5dB */
-{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0xE, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 12  -10dB */
-{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0xF, 0x7, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 13  -9.5dB */
-{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x8, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 14  -9dB */
-{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x9, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 15  -8.5dB */
-{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0xA, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 16  -8dB */
-{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0xB, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 17  -7.5dB */
-{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0xD, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 18  -7dB */
-{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0xE, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0},        /* 19  -6.5dB */
-{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x5, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}      /* 20  -6dB */
-};
-
-
-#if 0
-u4Byte OFDMSwingTable_92E[OFDM_TABLE_SIZE_92E] = {
-	/* Index0   6  dB */ 0x7fc001ff,
-	/* Index1   5.7dB */ 0x7b4001ed,
-	/* Index2   5.4dB */ 0x774001dd,
-	/* Index3   5.1dB */ 0x734001cd,
-	/* Index4   4.8dB */ 0x6f4001bd,
-	/* Index5   4.5dB */ 0x6b8001ae,
-	/* Index6   4.2dB */ 0x67c0019f,
-	/* Index7   3.9dB */ 0x64400191,
-	/* Index8   3.6dB */ 0x60c00183,
-	/* Index9   3.3dB */ 0x5d800176,
-	/* Index10  3  dB */ 0x5a80016a,
-	/* Index11  2.7dB */ 0x5740015d,
-	/* Index12  2.4dB */ 0x54400151,
-	/* Index13  2.1dB */ 0x51800146,
-	/* Index14  1.8dB */ 0x4ec0013b,
-	/* Index15  1.5dB */ 0x4c000130,
-	/* Index16  1.2dB */ 0x49800126,
-	/* Index17  0.9dB */ 0x4700011c,
-	/* Index18  0.6dB */ 0x44800112,
-	/* Index19  0.3dB */ 0x42000108,
-	/* Index20  0  dB */ 0x40000100, // 20 This is OFDM base index
-	/* Index21 -0.3dB */ 0x3dc000f7,
-	/* Index22 -0.6dB */ 0x3bc000ef,
-	/* Index23 -0.9dB */ 0x39c000e7,
-	/* Index24 -1.2dB */ 0x37c000df,
-	/* Index25 -1.5dB */ 0x35c000d7,
-	/* Index26 -1.8dB */ 0x340000d0,
-	/* Index27 -2.1dB */ 0x324000c9,
-	/* Index28 -2.4dB */ 0x308000c2,
-	/* Index29 -2.7dB */ 0x2f0000bc,
-	/* Index30 -3  dB */ 0x2d4000b5,
-	/* Index31 -3.3dB */ 0x2bc000af,
-	/* Index32 -3.6dB */ 0x2a4000a9,
-	/* Index33 -3.9dB */ 0x28c000a3,
-	/* Index34 -4.2dB */ 0x2780009e,
-	/* Index35 -4.5dB */ 0x26000098,
-	/* Index36 -4.8dB */ 0x24c00093,
-	/* Index37 -5.1dB */ 0x2380008e,
-	/* Index38 -5.4dB */ 0x22400089,
-	/* Index39 -5.7dB */ 0x21400085,
-	/* Index40 -6  dB */ 0x20000080,
-	/* Index41 -6.3dB */ 0x1f00007c,
-	/* Index42 -6.6dB */ 0x1e000078,
-	/* Index43 -6.9dB */ 0x1d000074,
-	/* Index44 -7.2dB */ 0x1c000070,
-	/* Index45 -7.5dB */ 0x1b00006c,
-	/* Index46 -7.8dB */ 0x1a000068,
-	/* Index47 -8.1dB */ 0x19400065,
-	/* Index48 -8.4dB */ 0x18400061,
-	/* Index49 -8.7dB */ 0x1780005e,
-	/* Index50 -9  dB */ 0x16c0005b,
-	/* Index51 -9.3dB */ 0x16000058,
-	/* Index52 -9.6dB */ 0x15400055,
-	/* Index53 -9.9dB */ 0x14800052
-};
-u1Byte CCKSwingTable_Ch1_Ch13_92E[CCK_TABLE_SIZE_92E][8] = {
-	/* Index0    0  dB */    {0x36, 0x34 , 0x2E , 0x26 , 0x1C , 0x12 , 0x08 , 0x04},
-	/* Index1   -0.3dB */    {0x34, 0x32 , 0x2C , 0x25 , 0x1B , 0x11 , 0x08 , 0x04},
-	/* Index2   -0.6dB */    {0x32, 0x30 , 0x2B , 0x23 , 0x1A , 0x11 , 0x07 , 0x04},
-	/* Index3   -0.9dB */    {0x31, 0x2F , 0x29 , 0x22 , 0x19 , 0x10 , 0x07 , 0x04},
-	/* Index4   -1.2dB */    {0x2F, 0x2D , 0x28 , 0x21 , 0x18 , 0x10 , 0x07 , 0x03},
-	/* Index5   -1.5dB */    {0x2D, 0x2C , 0x27 , 0x20 , 0x18 , 0x0F , 0x07 , 0x03},
-	/* Index6   -1.8dB */    {0x2C, 0x2A , 0x25 , 0x1F , 0x17 , 0x0F , 0x06 , 0x03},
-	/* Index7   -2.1dB */    {0x2A, 0x29 , 0x24 , 0x1E , 0x16 , 0x0E , 0x06 , 0x03},
-	/* Index8   -2.4dB */    {0x29, 0x27 , 0x23 , 0x1D , 0x15 , 0x0E , 0x06 , 0x03},
-	/* Index9   -2.7dB */    {0x27, 0x26 , 0x22 , 0x1C , 0x14 , 0x0D , 0x06 , 0x03},
-	/* Index10  -3  dB */    {0x26, 0x25 , 0x20 , 0x1B , 0x14 , 0x0D , 0x06 , 0x03},
-	/* Index11  -3.3dB */    {0x25, 0x23 , 0x1F , 0x1A , 0x13 , 0x0C , 0x05 , 0x03},
-	/* Index12  -3.6dB */    {0x24, 0x22 , 0x1E , 0x19 , 0x12 , 0x0C , 0x05 , 0x03},
-	/* Index13  -3.9dB */    {0x22, 0x21 , 0x1D , 0x18 , 0x12 , 0x0B , 0x05 , 0x03},
-	/* Index14  -4.2dB */    {0x21, 0x20 , 0x1C , 0x17 , 0x11 , 0x0B , 0x05 , 0x02},
-	/* Index15  -4.5dB */    {0x20, 0x1F , 0x1B , 0x17 , 0x11 , 0x0B , 0x05 , 0x02},
-	/* Index16  -4.8dB */    {0x1F, 0x1E , 0x1A , 0x16 , 0x10 , 0x0A , 0x05 , 0x02},
-	/* Index17  -5.1dB */    {0x1E, 0x1D , 0x1A , 0x15 , 0x10 , 0x0A , 0x04 , 0x02},
-	/* Index18  -5.4dB */    {0x1D, 0x1C , 0x19 , 0x14 , 0x0F , 0x0A , 0x04 , 0x02},
-	/* Index19  -5.7dB */    {0x1C, 0x1B , 0x18 , 0x14 , 0x0E , 0x09 , 0x04 , 0x02},
-	/* Index20  -6.0dB */    {0x1B, 0x1A , 0x17 , 0x13 , 0x0E , 0x09 , 0x04 , 0x02}, // 20 This is CCK base index
-	/* Index21  -6.3dB */    {0x1A, 0x19 , 0x16 , 0x12 , 0x0E , 0x09 , 0x04 , 0x02},
-	/* Index22  -6.6dB */    {0x19, 0x18 , 0x15 , 0x12 , 0x0D , 0x08 , 0x04 , 0x02},
-	/* Index23  -6.9dB */    {0x18, 0x17 , 0x15 , 0x11 , 0x0D , 0x08 , 0x04 , 0x02},
-	/* Index24  -7.2dB */    {0x18, 0x17 , 0x14 , 0x11 , 0x0C , 0x08 , 0x03 , 0x02},
-	/* Index25  -7.5dB */    {0x17, 0x16 , 0x13 , 0x10 , 0x0C , 0x08 , 0x03 , 0x02},
-	/* Index26  -7.8dB */    {0x16, 0x15 , 0x13 , 0x0F , 0x0B , 0x07 , 0x03 , 0x02},
-	/* Index27  -8.1dB */    {0x15, 0x14 , 0x12 , 0x0F , 0x0B , 0x07 , 0x03 , 0x02},
-	/* Index28  -8.4dB */    {0x14, 0x14 , 0x11 , 0x0E , 0x0B , 0x07 , 0x03 , 0x02},
-	/* Index29  -8.7dB */    {0x14, 0x13 , 0x11 , 0x0E , 0x0A , 0x07 , 0x03 , 0x01},
-	/* Index30  -9.0dB */    {0x13, 0x12 , 0x10 , 0x0D , 0x0A , 0x06 , 0x03 , 0x01}, // 30 This is hp CCK base index
-	/* Index31  -9.3dB */    {0x12, 0x12 , 0x0F , 0x0D , 0x0A , 0x06 , 0x03 , 0x01},
-	/* Index32  -9.6dB */    {0x12, 0x11 , 0x0F , 0x0D , 0x09 , 0x06 , 0x03 , 0x01},
-	/* Index33  -9.9dB */    {0x11, 0x11 , 0x0F , 0x0C , 0x09 , 0x06 , 0x03 , 0x01},
-	/* Index34 -10.2dB */    {0x11, 0x11 , 0x0E , 0x0C , 0x09 , 0x06 , 0x02 , 0x01},
-	/* Index35 -10.5dB */    {0x10, 0x0F , 0x0E , 0x0B , 0x08 , 0x05 , 0x02 , 0x01},
-	/* Index36 -10.8dB */    {0x10, 0x0F , 0x0D , 0x0B , 0x08 , 0x05 , 0x02 , 0x01},
-	/* Index37 -11.1dB */    {0x0F, 0x0E , 0x0D , 0x0A , 0x08 , 0x05 , 0x02 , 0x01},
-	/* Index38 -11.4dB */    {0x0E, 0x0E , 0x0C , 0x0A , 0x07 , 0x05 , 0x02 , 0x01},
-	/* Index39 -11.7dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x07 , 0x05 , 0x02 , 0x01},
-	/* Index40 -12  dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x07 , 0x05 , 0x02 , 0x01},
-	/* Index41 -12.3dB */    {0x0D, 0x0D , 0x0B , 0x09 , 0x07 , 0x04 , 0x02 , 0x01},
-	/* Index42 -12.6dB */    {0x0D, 0x0C , 0x0B , 0x09 , 0x07 , 0x04 , 0x02 , 0x01},
-	/* Index43 -12.9dB */    {0x0C, 0x0C , 0x0A , 0x09 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index44 -13.2dB */    {0x0C, 0x0B , 0x0A , 0x08 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index45 -13.5dB */    {0x0B, 0x0B , 0x0A , 0x08 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index46 -13.8dB */    {0x0B, 0x0B , 0x09 , 0x08 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index47 -14.1dB */    {0x0B, 0x0A , 0x09 , 0x07 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index48 -14.4dB */    {0x0A, 0x0A , 0x09 , 0x07 , 0x05 , 0x03 , 0x02 , 0x01},
-	/* Index49 -14.7dB */    {0x0A, 0x0A , 0x08 , 0x07 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index50 -15  dB */    {0x0A, 0x09 , 0x08 , 0x07 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index51 -15.3dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index52 -15.6dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index53 -15.9dB */    {0x09, 0x08 , 0x07 , 0x06 , 0x04 , 0x03 , 0x01 , 0x01}
-};
-u1Byte CCKSwingTable_Ch14_92E[CCK_TABLE_SIZE_92E][8] = {
-	/* Index0    0  dB */    {0x36, 0x34 , 0x2E , 0x26 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index1   -0.3dB */    {0x34, 0x32 , 0x2C , 0x25 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index2   -0.6dB */    {0x32, 0x30 , 0x2B , 0x23 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index3   -0.9dB */    {0x31, 0x2F , 0x29 , 0x22 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index4   -1.2dB */    {0x2F, 0x2D , 0x28 , 0x21 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index5   -1.5dB */    {0x2D, 0x2C , 0x27 , 0x20 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index6   -1.8dB */    {0x2C, 0x2A , 0x25 , 0x1F , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index7   -2.1dB */    {0x2A, 0x29 , 0x24 , 0x1E , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index8   -2.4dB */    {0x29, 0x27 , 0x23 , 0x1D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index9   -2.7dB */    {0x27, 0x26 , 0x22 , 0x1C , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index10  -3  dB */    {0x26, 0x25 , 0x20 , 0x1B , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index11  -3.3dB */    {0x25, 0x23 , 0x1F , 0x1A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index12  -3.6dB */    {0x24, 0x22 , 0x1E , 0x19 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index13  -3.9dB */    {0x22, 0x21 , 0x1D , 0x18 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index14  -4.2dB */    {0x21, 0x20 , 0x1C , 0x17 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index15  -4.5dB */    {0x20, 0x1F , 0x1B , 0x17 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index16  -4.8dB */    {0x1F, 0x1E , 0x1A , 0x16 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index17  -5.1dB */    {0x1E, 0x1D , 0x1A , 0x15 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index18  -5.4dB */    {0x1D, 0x1C , 0x19 , 0x14 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index19  -5.7dB */    {0x1C, 0x1B , 0x18 , 0x14 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index20  -6  dB */     {0x1B, 0x1A , 0x17 , 0x13 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index21  -6.3dB */    {0x1A, 0x19 , 0x16 , 0x12 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index22  -6.6dB */    {0x19, 0x18 , 0x15 , 0x12 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index23  -6.9dB */    {0x18, 0x17 , 0x15 , 0x11 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index24  -7.2dB */    {0x18, 0x17 , 0x14 , 0x11 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index25  -7.5dB */    {0x17, 0x16 , 0x13 , 0x10 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index26  -7.8dB */    {0x16, 0x15 , 0x13 , 0x0F , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index27  -8.1dB */    {0x15, 0x14 , 0x12 , 0x0F , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index28  -8.4dB */    {0x14, 0x14 , 0x11 , 0x0E , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index29  -8.7dB */    {0x14, 0x13 , 0x11 , 0x0E , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index30  -9  dB */    {0x13, 0x12 , 0x10 , 0x0D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index31  -9.3dB */    {0x12, 0x12 , 0x0F , 0x0D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index32  -9.6dB */    {0x12, 0x11 , 0x0F , 0x0D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index33  -9.9dB */    {0x11, 0x11 , 0x0F , 0x0C , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index34 -10.2dB */    {0x11, 0x11 , 0x0E , 0x0C , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index35 -10.5dB */    {0x10, 0x0F , 0x0E , 0x0B , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index36 -10.8dB */    {0x10, 0x0F , 0x0D , 0x0B , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index37 -11.1dB */    {0x0F, 0x0E , 0x0D , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index38 -11.4dB */    {0x0E, 0x0E , 0x0C , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index39 -11.7dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index40 -12  dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index41 -12.3dB */    {0x0D, 0x0D , 0x0B , 0x09 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index42 -12.6dB */    {0x0D, 0x0C , 0x0B , 0x09 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index43 -12.9dB */    {0x0C, 0x0C , 0x0A , 0x09 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index44 -13.2dB */    {0x0C, 0x0B , 0x0A , 0x08 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index45 -13.5dB */    {0x0B, 0x0B , 0x0A , 0x08 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index46 -13.8dB */    {0x0B, 0x0B , 0x09 , 0x08 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index47 -14.1dB */    {0x0B, 0x0A , 0x09 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index48 -14.4dB */    {0x0A, 0x0A , 0x09 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index49 -14.7dB */    {0x0A, 0x0A , 0x08 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index50 -15  dB */    {0x0A, 0x09 , 0x08 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index51 -15.3dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index52 -15.6dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index53 -15.9dB */    {0x09, 0x08 , 0x07 , 0x06 , 0x00 , 0x00 , 0x00 , 0x00}
-};
-#endif
-
-#ifdef AP_BUILD_WORKAROUND
-
-unsigned int TxPwrTrk_OFDM_SwingTbl[TxPwrTrk_OFDM_SwingTbl_Len] = {
-	/*  +6.0dB */ 0x7f8001fe,
-	/*  +5.5dB */ 0x788001e2,
-	/*  +5.0dB */ 0x71c001c7,
-	/*  +4.5dB */ 0x6b8001ae,
-	/*  +4.0dB */ 0x65400195,
-	/*  +3.5dB */ 0x5fc0017f,
-	/*  +3.0dB */ 0x5a400169,
-	/*  +2.5dB */ 0x55400155,
-	/*  +2.0dB */ 0x50800142,
-	/*  +1.5dB */ 0x4c000130,
-	/*  +1.0dB */ 0x47c0011f,
-	/*  +0.5dB */ 0x43c0010f,
-	/*   0.0dB */ 0x40000100,
-	/*  -0.5dB */ 0x3c8000f2,
-	/*  -1.0dB */ 0x390000e4,
-	/*  -1.5dB */ 0x35c000d7,
-	/*  -2.0dB */ 0x32c000cb,
-	/*  -2.5dB */ 0x300000c0,
-	/*  -3.0dB */ 0x2d4000b5,
-	/*  -3.5dB */ 0x2ac000ab,
-	/*  -4.0dB */ 0x288000a2,
-	/*  -4.5dB */ 0x26000098,
-	/*  -5.0dB */ 0x24000090,
-	/*  -5.5dB */ 0x22000088,
-	/*  -6.0dB */ 0x20000080,
-	/*  -6.5dB */ 0x1a00006c,
-	/*  -7.0dB */ 0x1c800072,
-	/*  -7.5dB */ 0x18000060,
-	/*  -8.0dB */ 0x19800066,
-	/*  -8.5dB */ 0x15800056,
-	/*  -9.0dB */ 0x26c0005b,
-	/*  -9.5dB */ 0x14400051,
-	/* -10.0dB */ 0x24400051,
-	/* -10.5dB */ 0x1300004c,
-	/* -11.0dB */ 0x12000048,
-	/* -11.5dB */ 0x11000044,
-	/* -12.0dB */ 0x10000040
-};
-#endif
-
-#endif
-
-
-u1Byte DeltaSwingTableIdx_2GA_P_DEFAULT[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3
-, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
-u1Byte DeltaSwingTableIdx_2GA_N_DEFAULT[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4
-, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11}; 
-
-
-#ifdef CONFIG_WLAN_HAL_8192EE
-u4Byte OFDMSwingTable_92E[OFDM_TABLE_SIZE_92E] = {
-	/* Index0   6  dB */ 0x7fc001ff,
-	/* Index1   5.7dB */ 0x7b4001ed,
-	/* Index2   5.4dB */ 0x774001dd,
-	/* Index3   5.1dB */ 0x734001cd,
-	/* Index4   4.8dB */ 0x6f4001bd,
-	/* Index5   4.5dB */ 0x6b8001ae,
-	/* Index6   4.2dB */ 0x67c0019f,
-	/* Index7   3.9dB */ 0x64400191,
-	/* Index8   3.6dB */ 0x60c00183,
-	/* Index9   3.3dB */ 0x5d800176,
-	/* Index10  3  dB */ 0x5a80016a,
-	/* Index11  2.7dB */ 0x5740015d,
-	/* Index12  2.4dB */ 0x54400151,
-	/* Index13  2.1dB */ 0x51800146,
-	/* Index14  1.8dB */ 0x4ec0013b,
-	/* Index15  1.5dB */ 0x4c000130,
-	/* Index16  1.2dB */ 0x49800126,
-	/* Index17  0.9dB */ 0x4700011c,
-	/* Index18  0.6dB */ 0x44800112,
-	/* Index19  0.3dB */ 0x42000108,
-	/* Index20  0  dB */ 0x40000100, // 20 This is OFDM base index
-	/* Index21 -0.3dB */ 0x3dc000f7,
-	/* Index22 -0.6dB */ 0x3bc000ef,
-	/* Index23 -0.9dB */ 0x39c000e7,
-	/* Index24 -1.2dB */ 0x37c000df,
-	/* Index25 -1.5dB */ 0x35c000d7,
-	/* Index26 -1.8dB */ 0x340000d0,
-	/* Index27 -2.1dB */ 0x324000c9,
-	/* Index28 -2.4dB */ 0x308000c2,
-	/* Index29 -2.7dB */ 0x2f0000bc,
-	/* Index30 -3  dB */ 0x2d4000b5,
-	/* Index31 -3.3dB */ 0x2bc000af,
-	/* Index32 -3.6dB */ 0x2a4000a9,
-	/* Index33 -3.9dB */ 0x28c000a3,
-	/* Index34 -4.2dB */ 0x2780009e,
-	/* Index35 -4.5dB */ 0x26000098,
-	/* Index36 -4.8dB */ 0x24c00093,
-	/* Index37 -5.1dB */ 0x2380008e,
-	/* Index38 -5.4dB */ 0x22400089,
-	/* Index39 -5.7dB */ 0x21400085,
-	/* Index40 -6  dB */ 0x20000080,
-	/* Index41 -6.3dB */ 0x1f00007c,
-	/* Index42 -6.6dB */ 0x1e000078,
-	/* Index43 -6.9dB */ 0x1d000074,
-	/* Index44 -7.2dB */ 0x1c000070,
-	/* Index45 -7.5dB */ 0x1b00006c,
-	/* Index46 -7.8dB */ 0x1a000068,
-	/* Index47 -8.1dB */ 0x19400065,
-	/* Index48 -8.4dB */ 0x18400061,
-	/* Index49 -8.7dB */ 0x1780005e,
-	/* Index50 -9  dB */ 0x16c0005b,
-	/* Index51 -9.3dB */ 0x16000058,
-	/* Index52 -9.6dB */ 0x15400055,
-	/* Index53 -9.9dB */ 0x14800052
-};
-u1Byte CCKSwingTable_Ch1_Ch13_92E[CCK_TABLE_SIZE_92E][8] = {
-	/* Index0    0  dB */    {0x36, 0x34 , 0x2E , 0x26 , 0x1C , 0x12 , 0x08 , 0x04},
-	/* Index1   -0.3dB */    {0x34, 0x32 , 0x2C , 0x25 , 0x1B , 0x11 , 0x08 , 0x04},
-	/* Index2   -0.6dB */    {0x32, 0x30 , 0x2B , 0x23 , 0x1A , 0x11 , 0x07 , 0x04},
-	/* Index3   -0.9dB */    {0x31, 0x2F , 0x29 , 0x22 , 0x19 , 0x10 , 0x07 , 0x04},
-	/* Index4   -1.2dB */    {0x2F, 0x2D , 0x28 , 0x21 , 0x18 , 0x10 , 0x07 , 0x03},
-	/* Index5   -1.5dB */    {0x2D, 0x2C , 0x27 , 0x20 , 0x18 , 0x0F , 0x07 , 0x03},
-	/* Index6   -1.8dB */    {0x2C, 0x2A , 0x25 , 0x1F , 0x17 , 0x0F , 0x06 , 0x03},
-	/* Index7   -2.1dB */    {0x2A, 0x29 , 0x24 , 0x1E , 0x16 , 0x0E , 0x06 , 0x03},
-	/* Index8   -2.4dB */    {0x29, 0x27 , 0x23 , 0x1D , 0x15 , 0x0E , 0x06 , 0x03},
-	/* Index9   -2.7dB */    {0x27, 0x26 , 0x22 , 0x1C , 0x14 , 0x0D , 0x06 , 0x03},
-	/* Index10  -3  dB */    {0x26, 0x25 , 0x20 , 0x1B , 0x14 , 0x0D , 0x06 , 0x03},
-	/* Index11  -3.3dB */    {0x25, 0x23 , 0x1F , 0x1A , 0x13 , 0x0C , 0x05 , 0x03},
-	/* Index12  -3.6dB */    {0x24, 0x22 , 0x1E , 0x19 , 0x12 , 0x0C , 0x05 , 0x03},
-	/* Index13  -3.9dB */    {0x22, 0x21 , 0x1D , 0x18 , 0x12 , 0x0B , 0x05 , 0x03},
-	/* Index14  -4.2dB */    {0x21, 0x20 , 0x1C , 0x17 , 0x11 , 0x0B , 0x05 , 0x02},
-	/* Index15  -4.5dB */    {0x20, 0x1F , 0x1B , 0x17 , 0x11 , 0x0B , 0x05 , 0x02},
-	/* Index16  -4.8dB */    {0x1F, 0x1E , 0x1A , 0x16 , 0x10 , 0x0A , 0x05 , 0x02},
-	/* Index17  -5.1dB */    {0x1E, 0x1D , 0x1A , 0x15 , 0x10 , 0x0A , 0x04 , 0x02},
-	/* Index18  -5.4dB */    {0x1D, 0x1C , 0x19 , 0x14 , 0x0F , 0x0A , 0x04 , 0x02},
-	/* Index19  -5.7dB */    {0x1C, 0x1B , 0x18 , 0x14 , 0x0E , 0x09 , 0x04 , 0x02},
-	/* Index20  -6.0dB */    {0x1B, 0x1A , 0x17 , 0x13 , 0x0E , 0x09 , 0x04 , 0x02}, // 20 This is CCK base index
-	/* Index21  -6.3dB */    {0x1A, 0x19 , 0x16 , 0x12 , 0x0E , 0x09 , 0x04 , 0x02},
-	/* Index22  -6.6dB */    {0x19, 0x18 , 0x15 , 0x12 , 0x0D , 0x08 , 0x04 , 0x02},
-	/* Index23  -6.9dB */    {0x18, 0x17 , 0x15 , 0x11 , 0x0D , 0x08 , 0x04 , 0x02},
-	/* Index24  -7.2dB */    {0x18, 0x17 , 0x14 , 0x11 , 0x0C , 0x08 , 0x03 , 0x02},
-	/* Index25  -7.5dB */    {0x17, 0x16 , 0x13 , 0x10 , 0x0C , 0x08 , 0x03 , 0x02},
-	/* Index26  -7.8dB */    {0x16, 0x15 , 0x13 , 0x0F , 0x0B , 0x07 , 0x03 , 0x02},
-	/* Index27  -8.1dB */    {0x15, 0x14 , 0x12 , 0x0F , 0x0B , 0x07 , 0x03 , 0x02},
-	/* Index28  -8.4dB */    {0x14, 0x14 , 0x11 , 0x0E , 0x0B , 0x07 , 0x03 , 0x02},
-	/* Index29  -8.7dB */    {0x14, 0x13 , 0x11 , 0x0E , 0x0A , 0x07 , 0x03 , 0x01},
-	/* Index30  -9.0dB */    {0x13, 0x12 , 0x10 , 0x0D , 0x0A , 0x06 , 0x03 , 0x01}, // 30 This is hp CCK base index
-	/* Index31  -9.3dB */    {0x12, 0x12 , 0x0F , 0x0D , 0x0A , 0x06 , 0x03 , 0x01},
-	/* Index32  -9.6dB */    {0x12, 0x11 , 0x0F , 0x0D , 0x09 , 0x06 , 0x03 , 0x01},
-	/* Index33  -9.9dB */    {0x11, 0x11 , 0x0F , 0x0C , 0x09 , 0x06 , 0x03 , 0x01},
-	/* Index34 -10.2dB */    {0x11, 0x11 , 0x0E , 0x0C , 0x09 , 0x06 , 0x02 , 0x01},
-	/* Index35 -10.5dB */    {0x10, 0x0F , 0x0E , 0x0B , 0x08 , 0x05 , 0x02 , 0x01},
-	/* Index36 -10.8dB */    {0x10, 0x0F , 0x0D , 0x0B , 0x08 , 0x05 , 0x02 , 0x01},
-	/* Index37 -11.1dB */    {0x0F, 0x0E , 0x0D , 0x0A , 0x08 , 0x05 , 0x02 , 0x01},
-	/* Index38 -11.4dB */    {0x0E, 0x0E , 0x0C , 0x0A , 0x07 , 0x05 , 0x02 , 0x01},
-	/* Index39 -11.7dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x07 , 0x05 , 0x02 , 0x01},
-	/* Index40 -12  dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x07 , 0x05 , 0x02 , 0x01},
-	/* Index41 -12.3dB */    {0x0D, 0x0D , 0x0B , 0x09 , 0x07 , 0x04 , 0x02 , 0x01},
-	/* Index42 -12.6dB */    {0x0D, 0x0C , 0x0B , 0x09 , 0x07 , 0x04 , 0x02 , 0x01},
-	/* Index43 -12.9dB */    {0x0C, 0x0C , 0x0A , 0x09 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index44 -13.2dB */    {0x0C, 0x0B , 0x0A , 0x08 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index45 -13.5dB */    {0x0B, 0x0B , 0x0A , 0x08 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index46 -13.8dB */    {0x0B, 0x0B , 0x09 , 0x08 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index47 -14.1dB */    {0x0B, 0x0A , 0x09 , 0x07 , 0x06 , 0x04 , 0x02 , 0x01},
-	/* Index48 -14.4dB */    {0x0A, 0x0A , 0x09 , 0x07 , 0x05 , 0x03 , 0x02 , 0x01},
-	/* Index49 -14.7dB */    {0x0A, 0x0A , 0x08 , 0x07 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index50 -15  dB */    {0x0A, 0x09 , 0x08 , 0x07 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index51 -15.3dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index52 -15.6dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x05 , 0x03 , 0x01 , 0x01},
-	/* Index53 -15.9dB */    {0x09, 0x08 , 0x07 , 0x06 , 0x04 , 0x03 , 0x01 , 0x01}
-};
-u1Byte CCKSwingTable_Ch14_92E[CCK_TABLE_SIZE_92E][8] = {
-	/* Index0    0  dB */    {0x36, 0x34 , 0x2E , 0x26 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index1   -0.3dB */    {0x34, 0x32 , 0x2C , 0x25 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index2   -0.6dB */    {0x32, 0x30 , 0x2B , 0x23 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index3   -0.9dB */    {0x31, 0x2F , 0x29 , 0x22 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index4   -1.2dB */    {0x2F, 0x2D , 0x28 , 0x21 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index5   -1.5dB */    {0x2D, 0x2C , 0x27 , 0x20 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index6   -1.8dB */    {0x2C, 0x2A , 0x25 , 0x1F , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index7   -2.1dB */    {0x2A, 0x29 , 0x24 , 0x1E , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index8   -2.4dB */    {0x29, 0x27 , 0x23 , 0x1D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index9   -2.7dB */    {0x27, 0x26 , 0x22 , 0x1C , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index10  -3  dB */    {0x26, 0x25 , 0x20 , 0x1B , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index11  -3.3dB */    {0x25, 0x23 , 0x1F , 0x1A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index12  -3.6dB */    {0x24, 0x22 , 0x1E , 0x19 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index13  -3.9dB */    {0x22, 0x21 , 0x1D , 0x18 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index14  -4.2dB */    {0x21, 0x20 , 0x1C , 0x17 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index15  -4.5dB */    {0x20, 0x1F , 0x1B , 0x17 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index16  -4.8dB */    {0x1F, 0x1E , 0x1A , 0x16 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index17  -5.1dB */    {0x1E, 0x1D , 0x1A , 0x15 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index18  -5.4dB */    {0x1D, 0x1C , 0x19 , 0x14 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index19  -5.7dB */    {0x1C, 0x1B , 0x18 , 0x14 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index20  -6  dB */     {0x1B, 0x1A , 0x17 , 0x13 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index21  -6.3dB */    {0x1A, 0x19 , 0x16 , 0x12 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index22  -6.6dB */    {0x19, 0x18 , 0x15 , 0x12 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index23  -6.9dB */    {0x18, 0x17 , 0x15 , 0x11 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index24  -7.2dB */    {0x18, 0x17 , 0x14 , 0x11 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index25  -7.5dB */    {0x17, 0x16 , 0x13 , 0x10 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index26  -7.8dB */    {0x16, 0x15 , 0x13 , 0x0F , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index27  -8.1dB */    {0x15, 0x14 , 0x12 , 0x0F , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index28  -8.4dB */    {0x14, 0x14 , 0x11 , 0x0E , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index29  -8.7dB */    {0x14, 0x13 , 0x11 , 0x0E , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index30  -9  dB */    {0x13, 0x12 , 0x10 , 0x0D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index31  -9.3dB */    {0x12, 0x12 , 0x0F , 0x0D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index32  -9.6dB */    {0x12, 0x11 , 0x0F , 0x0D , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index33  -9.9dB */    {0x11, 0x11 , 0x0F , 0x0C , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index34 -10.2dB */    {0x11, 0x11 , 0x0E , 0x0C , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index35 -10.5dB */    {0x10, 0x0F , 0x0E , 0x0B , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index36 -10.8dB */    {0x10, 0x0F , 0x0D , 0x0B , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index37 -11.1dB */    {0x0F, 0x0E , 0x0D , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index38 -11.4dB */    {0x0E, 0x0E , 0x0C , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index39 -11.7dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index40 -12  dB */    {0x0E, 0x0D , 0x0C , 0x0A , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index41 -12.3dB */    {0x0D, 0x0D , 0x0B , 0x09 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index42 -12.6dB */    {0x0D, 0x0C , 0x0B , 0x09 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index43 -12.9dB */    {0x0C, 0x0C , 0x0A , 0x09 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index44 -13.2dB */    {0x0C, 0x0B , 0x0A , 0x08 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index45 -13.5dB */    {0x0B, 0x0B , 0x0A , 0x08 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index46 -13.8dB */    {0x0B, 0x0B , 0x09 , 0x08 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index47 -14.1dB */    {0x0B, 0x0A , 0x09 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index48 -14.4dB */    {0x0A, 0x0A , 0x09 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index49 -14.7dB */    {0x0A, 0x0A , 0x08 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index50 -15  dB */    {0x0A, 0x09 , 0x08 , 0x07 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index51 -15.3dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index52 -15.6dB */    {0x09, 0x09 , 0x08 , 0x06 , 0x00 , 0x00 , 0x00 , 0x00},
-	/* Index53 -15.9dB */    {0x09, 0x08 , 0x07 , 0x06 , 0x00 , 0x00 , 0x00 , 0x00}
-};
-#endif
-
-#if(RTL8814A_SUPPORT == 1)
-u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE] =
-{
-	0x081, // 0,  -12.0dB
-	0x088, // 1,  -11.5dB
-	0x090, // 2,  -11.0dB
-	0x099, // 3,  -10.5dB
-	0x0A2, // 4,  -10.0dB
-	0x0AC, // 5,  -9.5dB
-	0x0B6, // 6,  -9.0dB
-	0x0C0, // 7,  -8.5dB
-	0x0CC, // 8,  -8.0dB
-	0x0D8, // 9,  -7.5dB
-	0x0E5, // 10, -7.0dB
-	0x0F2, // 11, -6.5dB
-	0x101, // 12, -6.0dB
-	0x110, // 13, -5.5dB
-	0x120, // 14, -5.0dB
-	0x131, // 15, -4.5dB
-	0x143, // 16, -4.0dB
-	0x156, // 17, -3.5dB
-	0x16A, // 18, -3.0dB
-	0x180, // 19, -2.5dB
-	0x197, // 20, -2.0dB
-	0x1AF, // 21, -1.5dB
-	0x1C8, // 22, -1.0dB
-	0x1E3, // 23, -0.5dB
-	0x200, // 24, +0  dB
-	0x21E, // 25, +0.5dB
-	0x23E, // 26, +1.0dB
-	0x261, // 27, +1.5dB
-	0x285, // 28, +2.0dB
-	0x2AB, // 29, +2.5dB
-	0x2D3, // 30, +3.0dB
-	0x2FE, // 31, +3.5dB
-	0x32B, // 32, +4.0dB
-	0x35C, // 33, +4.5dB
-	0x38E, // 34, +5.0dB
-	0x3C4, // 35, +5.5dB
-	0x3FE  // 36, +6.0dB	
-};
-#elif(ODM_IC_11AC_SERIES_SUPPORT)
-u4Byte OFDMSwingTable_8812[OFDM_TABLE_SIZE_8812] = {	
-	0x3FE, // 0,  (6dB) 
-	0x3C4, // 1,  (5.5dB) 
-	0x38E, // 2,  (5dB)
-	0x35C, // 3,  (4.5dB)
-	0x32B, // 4,  (4dB)
-	0x2FE, // 5,  (3.5dB)
-	0x2D3, // 6,  (3dB)
-	0x2AB, // 7,  (2.5dB)
-	0x285, // 8,  (2dB)
-	0x261, // 9,  (1.5dB
-	0x23E, // 10, (1dB)
-	0x21E, // 11, (0.5dB)
-	0x200, // 12, (0dB)		8814 int PA 2G default
-	0x1E3, // 13, (-0.5dB)
-	0x1C8, // 14, (-1dB)
-	0x1AF, // 15, (-1.5dB)
-	0x197, // 16, (-2dB)
-	0x180, // 17, (-2.5dB)
-	0x16A, // 18, (-3dB)		8812 / 8814 int PA 5G / 8814 ext PA 2G5G default
-	0x156, // 19, (-3.5dB)
-	0x143, // 20, (-4dB)		8812 HP default
-	0x131, // 21, (-4.5dB)
-	0x120, // 22, (-5dB)
-	0x110, // 23, (-5.5dB)
-	0x101, // 24, (-6dB)
-	0x0F2, // 25, (-6.5dB)
-	0x0E5, // 26, (-7dB)
-	0x0D8, // 27, (-7.5dB)
-	0x0CC, // 28, (-8dB)
-	0x0C0, // 29, (-8.5dB)
-	0x0B6, // 30, (-9dB)
-	0x0AC, // 31, (-9.5dB)
-	0x0A2, // 32, (-10dB)
-	0x099, // 33, (-10.5dB)
-	0x090, // 34, (-11dB)
-	0x088, // 35, (-11.5dB)
-	0x081, // 36, (-12dB)	
-	0x079, // 37, (-12.5dB)
-	0x072, // 38, (-13dB)
-	0x06c, // 39, (-13.5dB)
-	0x066, // 40, (-14dB)
-	0x060, // 41, (-14.5dB)
-	0x05B  // 42, (-15dB)
-};
-#endif
-
-//#endif
-//3============================================================
-//3 Tx Power Tracking
-//3============================================================
-
-VOID
-odm_TXPowerTrackingInit(
-	IN	PVOID		pDM_VOID 
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	if(!(pDM_Odm->SupportICType & (ODM_RTL8814A|ODM_IC_11N_SERIES)))
-		return;
-#endif
-
-	odm_TXPowerTrackingThermalMeterInit(pDM_Odm);
-}	
-
-
-VOID
-odm_TXPowerTrackingThermalMeterInit(
-	IN	PVOID		pDM_VOID 
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-	u1Byte p;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO      	pMgntInfo = &Adapter->MgntInfo;
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	
-	pMgntInfo->bTXPowerTracking = TRUE;
-	pHalData->TXPowercount       = 0;
-	pHalData->bTXPowerTrackingInit = FALSE;
-
-	if(pDM_Odm->mp_mode == FALSE)
-		pHalData->TxPowerTrackControl = TRUE;
-	ODM_RT_TRACE(pDM_Odm,COMP_POWER_TRACKING, DBG_LOUD, ("pMgntInfo->bTXPowerTracking = %d\n", pMgntInfo->bTXPowerTracking));
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#ifdef CONFIG_RTL8188E
-	{
-		pDM_Odm->RFCalibrateInfo.bTXPowerTracking = _TRUE;
-		pDM_Odm->RFCalibrateInfo.TXPowercount = 0;
-		pDM_Odm->RFCalibrateInfo.bTXPowerTrackingInit = _FALSE;
-
-		if(pDM_Odm->mp_mode == FALSE)
-			pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = _TRUE;
-		
-		MSG_8192C("pDM_Odm TxPowerTrackControl = %d\n", pDM_Odm->RFCalibrateInfo.TxPowerTrackControl);
-	}
-	#else
-	{
-		PADAPTER		Adapter = pDM_Odm->Adapter;
-		HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-		struct dm_priv	*pdmpriv = &pHalData->dmpriv;
-
-		//if(IS_HARDWARE_TYPE_8192C(pHalData))
-		{
-			pdmpriv->bTXPowerTracking = _TRUE;
-			pdmpriv->TXPowercount = 0;
-			pdmpriv->bTXPowerTrackingInit = _FALSE;
-
-			if(pDM_Odm->mp_mode == FALSE)		//for mp driver, turn off txpwrtracking as default
-				pdmpriv->TxPowerTrackControl = _TRUE;
-
-		}
-		MSG_8192C("pdmpriv->TxPowerTrackControl = %d\n", pdmpriv->TxPowerTrackControl);
-	
-	}	
-	#endif//endif (CONFIG_RTL8188E==1)	
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-
-	#ifdef RTL8188E_SUPPORT
-	{
-		pDM_Odm->RFCalibrateInfo.bTXPowerTracking = _TRUE;
-		pDM_Odm->RFCalibrateInfo.TXPowercount = 0;
-		pDM_Odm->RFCalibrateInfo.bTXPowerTrackingInit = _FALSE;
-		pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = _TRUE;
-		pDM_Odm->RFCalibrateInfo.TM_Trigger = 0;
-	}
-	#endif
-#endif
-
-       pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = TRUE;
-	pDM_Odm->RFCalibrateInfo.DeltaPowerIndex = 0;
-	pDM_Odm->RFCalibrateInfo.DeltaPowerIndexLast = 0;
-	pDM_Odm->RFCalibrateInfo.PowerIndexOffset = 0;
-	pDM_Odm->RFCalibrateInfo.ThermalValue = 0;
-	pRFCalibrateInfo->DefaultOfdmIndex = 28;
-
-	
-#if RTL8188E_SUPPORT	
-	pRFCalibrateInfo->DefaultCckIndex = 20;	// -6 dB	
-#elif RTL8192E_SUPPORT
-	pRFCalibrateInfo->DefaultCckIndex = 8;	// -12 dB
-#endif
-	pRFCalibrateInfo->BbSwingIdxOfdmBase = pRFCalibrateInfo->DefaultOfdmIndex;
-	pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->DefaultCckIndex;
-	pDM_Odm->RFCalibrateInfo.CCK_index = pRFCalibrateInfo->DefaultCckIndex;
-	for(p = 0; p < MAX_RF_PATH; p++)
-	{
- 	pDM_Odm->RFCalibrateInfo.OFDM_index[p] = pRFCalibrateInfo->DefaultOfdmIndex;		
-	pRFCalibrateInfo->BbSwingIdxOfdm[p] = pRFCalibrateInfo->DefaultOfdmIndex;
-	pRFCalibrateInfo->KfreeOffset[p] = 0; // for 8814 kfree
-	}
-	pRFCalibrateInfo->BbSwingIdxCck = pRFCalibrateInfo->DefaultCckIndex;
-	
-}
-
-
-VOID
-ODM_TXPowerTrackingCheck(
-	IN	PVOID		pDM_VOID
-	)
-{
-	// 
-	// For AP/ADSL use prtl8192cd_priv
-	// For CE/NIC use PADAPTER
-	//
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-
-
-	if (!(pDM_Odm->SupportAbility & ODM_RF_TX_PWR_TRACK))
-		return;
-
-	//
-	// 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.
-	//
-	switch	(pDM_Odm->SupportPlatform)
-	{
-		case	ODM_WIN:
-			odm_TXPowerTrackingCheckMP(pDM_Odm);
-			break;
-
-		case	ODM_CE:
-			odm_TXPowerTrackingCheckCE(pDM_Odm);
-			break;
-
-		case	ODM_AP:
-			odm_TXPowerTrackingCheckAP(pDM_Odm);		
-			break;		
-		default:
-			break;
-	}
-
-}
-
-VOID
-odm_TXPowerTrackingCheckCE(
-	IN	PVOID		pDM_VOID
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-	#if(RTL8188E_SUPPORT==1)
-
-	//if(!pMgntInfo->bTXPowerTracking /*|| (!pdmpriv->TxPowerTrackControl && pdmpriv->bAPKdone)*/)
-	if(!(pDM_Odm->SupportAbility & ODM_RF_TX_PWR_TRACK))
-	{
-		return;
-	}
-
-	if(!pDM_Odm->RFCalibrateInfo.TM_Trigger)		//at least delay 1 sec
-	{
-		//pHalData->TxPowerCheckCnt++;	//cosa add for debug
-		ODM_SetRFReg(pDM_Odm, RF_PATH_A, RF_T_METER, bRFRegOffsetMask, 0x60);
-		//DBG_8192C("Trigger 92C Thermal Meter!!\n");
-		
-		pDM_Odm->RFCalibrateInfo.TM_Trigger = 1;
-		return;
-		
-	}
-	else
-	{
-		//DBG_8192C("Schedule TxPowerTracking direct call!!\n");
-		odm_TXPowerTrackingCallback_ThermalMeter_8188E(Adapter);
-		pDM_Odm->RFCalibrateInfo.TM_Trigger = 0;
-	}
-	#endif
-	
-#endif	
-}
-
-VOID
-odm_TXPowerTrackingCheckMP(
-	IN	PVOID		pDM_VOID 
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-	if (ODM_CheckPowerStatus(Adapter) == FALSE)
-		return;
-
-	if(!Adapter->bSlaveOfDMSP || Adapter->DualMacSmartConcurrent == FALSE)
-		odm_TXPowerTrackingThermalMeterCheck(Adapter);
-#endif
-	
-}
-
-
-VOID
-odm_TXPowerTrackingCheckAP(
-	IN	PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	prtl8192cd_priv	priv		= pDM_Odm->priv;
-
-#if ((RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8814A_SUPPORT == 1))	
-	if (pDM_Odm->SupportICType & (ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8812|ODM_RTL8881A|ODM_RTL8814A))
-		ODM_TXPowerTrackingCallback_ThermalMeter(pDM_Odm);
-	else
-#endif
-	{
-	}
-#endif	
-
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-odm_TXPowerTrackingThermalMeterCheck(
-	IN	PADAPTER		Adapter
-	)
-{
-#ifndef AP_BUILD_WORKAROUND
-#if (HAL_CODE_BASE==RTL8192_C)
-	PMGNT_INFO      		pMgntInfo = &Adapter->MgntInfo;
-	//HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(Adapter);
-	static u1Byte			TM_Trigger = 0;
-	//u1Byte					TxPowerCheckCnt = 5;	//10 sec
-
-	if(!pMgntInfo->bTXPowerTracking /*|| (!pHalData->TxPowerTrackControl && pHalData->bAPKdone)*/)
-	{
-		return;
-	}
-
-	if(!TM_Trigger)		//at least delay 1 sec
-	{
-		if (IS_HARDWARE_TYPE_8188E(Adapter) || IS_HARDWARE_TYPE_8812(Adapter))
-			PHY_SetRFReg(Adapter, RF_PATH_A, RF_T_METER_88E, BIT17 | BIT16, 0x03);
-		else
-			PHY_SetRFReg(Adapter, RF_PATH_A, RF_T_METER, bRFRegOffsetMask, 0x60);
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,("Trigger 92C Thermal Meter!!\n"));
-		
-		TM_Trigger = 1;
-		return;
-	}
-	else
-	{
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,("Schedule TxPowerTracking direct call!!\n"));		
-		odm_TXPowerTrackingDirectCall(Adapter); //Using direct call is instead, added by Roger, 2009.06.18.
-		TM_Trigger = 0;
-	}
-#endif
-#endif
-}
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ap.h
deleted file mode 100644
index 264b529a4fb7..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ap.h
+++ /dev/null
@@ -1,314 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMPOWERTRACKING_H__
-#define    __PHYDMPOWERTRACKING_H__
-
-#define POWRTRACKING_VERSION	"1.1"
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-#ifdef RTK_AC_SUPPORT
-#define ODM_IC_11AC_SERIES_SUPPORT		1
-#else
-#define ODM_IC_11AC_SERIES_SUPPORT		0
-#endif
-#else
-#define ODM_IC_11AC_SERIES_SUPPORT		1
-#endif
-
-#define		DPK_DELTA_MAPPING_NUM	13
-#define		index_mapping_HP_NUM	15
-#define		DELTA_SWINGIDX_SIZE     30
-#define		BAND_NUM 				3
-#define		MAX_RF_PATH	4
-#define 		TXSCALE_TABLE_SIZE 		37
-#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 IQK_Matrix_Settings_NUM	(14+24+21) // Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G
-
-#if !defined(_OUTSRC_COEXIST)
-#define	OFDM_TABLE_SIZE_92D 	43
-#define	OFDM_TABLE_SIZE 	37
-#define	CCK_TABLE_SIZE		33
-#define	CCK_TABLE_SIZE_88F	21
-
-
-
-//#define	OFDM_TABLE_SIZE_92E 	54
-//#define 	CCK_TABLE_SIZE_92E     	54
-extern	u4Byte OFDMSwingTable[OFDM_TABLE_SIZE_92D];
-extern	u1Byte CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch14 [CCK_TABLE_SIZE][8];
-
-
-extern	u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE_92D];
-extern	u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch14_New [CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16];
-
-#endif
-
-#define	ODM_OFDM_TABLE_SIZE 	37
-#define	ODM_CCK_TABLE_SIZE		33
-// <20140613, YuChen> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table.
-extern u1Byte DeltaSwingTableIdx_2GA_P_DEFAULT[DELTA_SWINGIDX_SIZE];
-extern u1Byte DeltaSwingTableIdx_2GA_N_DEFAULT[DELTA_SWINGIDX_SIZE]; 
-
-
-//extern	u4Byte OFDMSwingTable_92E[OFDM_TABLE_SIZE_92E];
-//extern	u1Byte CCKSwingTable_Ch1_Ch13_92E[CCK_TABLE_SIZE_92E][8];
-//extern	u1Byte CCKSwingTable_Ch14_92E[CCK_TABLE_SIZE_92E][8];
-
-#ifdef CONFIG_WLAN_HAL_8192EE
-#define	OFDM_TABLE_SIZE_92E 	54
-#define	CCK_TABLE_SIZE_92E     	54
-extern	u4Byte OFDMSwingTable_92E[OFDM_TABLE_SIZE_92E];
-extern	u1Byte CCKSwingTable_Ch1_Ch13_92E[CCK_TABLE_SIZE_92E][8];
-extern	u1Byte CCKSwingTable_Ch14_92E[CCK_TABLE_SIZE_92E][8];
-#endif
-
-#define	OFDM_TABLE_SIZE_8812 	43
-#define	AVG_THERMAL_NUM_8812	4
-
-#if(RTL8814A_SUPPORT == 1)
-extern u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE];
-#elif(ODM_IC_11AC_SERIES_SUPPORT)
-extern unsigned int OFDMSwingTable_8812[OFDM_TABLE_SIZE_8812];
-#endif
-
-#define dm_CheckTXPowerTracking 	ODM_TXPowerTrackingCheck
-
-typedef struct _IQK_MATRIX_REGS_SETTING{
-	BOOLEAN 	bIQKDone;
-	s4Byte		Value[1][IQK_Matrix_REG_NUM];
-}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;
-
-typedef struct ODM_RF_Calibration_Structure
-{
-	//for tx power tracking
-	
-	u4Byte	RegA24; // for TempCCK
-	s4Byte	RegE94;
-	s4Byte 	RegE9C;
-	s4Byte	RegEB4;
-	s4Byte	RegEBC;	
-
-	//u1Byte bTXPowerTracking;
-	u1Byte  	TXPowercount;
-	BOOLEAN bTXPowerTrackingInit; 
-	BOOLEAN bTXPowerTracking;
-	u1Byte  	TxPowerTrackControl; //for mp mode, turn off txpwrtracking as default
-	u1Byte  	TM_Trigger;
-    	u1Byte  	InternalPA5G[2];	//pathA / pathB
-	
-	u1Byte  	ThermalMeter[2];    // ThermalMeter, index 0 for RFIC0, and 1 for RFIC1
-	u1Byte  	ThermalValue;
-	u1Byte  	ThermalValue_LCK;
-	u1Byte  	ThermalValue_IQK;
-	u1Byte	ThermalValue_DPK;		
-	u1Byte	ThermalValue_AVG[AVG_THERMAL_NUM];
-	u1Byte	ThermalValue_AVG_index;		
-	u1Byte	ThermalValue_RxGain;
-	u1Byte	ThermalValue_Crystal;
-	u1Byte	ThermalValue_DPKstore;
-	u1Byte	ThermalValue_DPKtrack;
-	BOOLEAN	TxPowerTrackingInProgress;
-	BOOLEAN	bDPKenable;
-	
-	BOOLEAN	bReloadtxpowerindex;	
-	u1Byte 	bRfPiEnable;
-	u4Byte 	TXPowerTrackingCallbackCnt; //cosa add for debug
-
-	u1Byte 	bCCKinCH14;
-	u1Byte 	CCK_index;
-	u1Byte 	OFDM_index[MAX_RF_PATH];
-	s1Byte	PowerIndexOffset;
-	s1Byte	DeltaPowerIndex;
-	s1Byte	DeltaPowerIndexLast;	
-	BOOLEAN bTxPowerChanged;
-		
-	u1Byte 	ThermalValue_HP[HP_THERMAL_NUM];
-	u1Byte 	ThermalValue_HP_index;
-	IQK_MATRIX_REGS_SETTING IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];
-	BOOLEAN bNeedIQK;
-	u1Byte	Delta_IQK;
-	u1Byte	Delta_LCK;
-	u1Byte  DeltaSwingTableIdx_2GCCKA_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKA_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKB_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKB_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKC_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKC_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKD_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKD_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GB_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GB_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GC_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GC_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GD_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GD_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GA_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GA_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GB_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GB_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GC_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GC_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GD_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GD_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_P_8188E[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_N_8188E[DELTA_SWINGIDX_SIZE];
-	
-	u1Byte			BbSwingIdxOfdm[MAX_RF_PATH];
-	u1Byte			BbSwingIdxOfdmCurrent;
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))	
-	u1Byte			BbSwingIdxOfdmBase[MAX_RF_PATH];
-#else
-	u1Byte			BbSwingIdxOfdmBase;
-#endif
-	BOOLEAN			BbSwingFlagOfdm;
-	u1Byte			BbSwingIdxCck;
-	u1Byte			BbSwingIdxCckCurrent;
-	u1Byte			BbSwingIdxCckBase;
-	u1Byte			DefaultOfdmIndex;
-	u1Byte			DefaultCckIndex;	
-	BOOLEAN			BbSwingFlagCck;
-	
-	s1Byte			Absolute_OFDMSwingIdx[MAX_RF_PATH];   
-	s1Byte			Remnant_OFDMSwingIdx[MAX_RF_PATH];   
-	s1Byte			Remnant_CCKSwingIdx;
-	s1Byte			Modify_TxAGC_Value;       /*Remnat compensate value at TxAGC */
-	BOOLEAN			Modify_TxAGC_Flag_PathA;
-	BOOLEAN			Modify_TxAGC_Flag_PathB;
-	BOOLEAN			Modify_TxAGC_Flag_PathC;
-	BOOLEAN			Modify_TxAGC_Flag_PathD;
-	BOOLEAN			Modify_TxAGC_Flag_PathA_CCK;
-	
-	s1Byte			KfreeOffset[MAX_RF_PATH];
-    
-	//--------------------------------------------------------------------//	
-	
-	//for IQK	
-	u4Byte 	RegC04;
-	u4Byte 	Reg874;
-	u4Byte 	RegC08;
-	u4Byte 	RegB68;
-	u4Byte 	RegB6C;
-	u4Byte 	Reg870;
-	u4Byte 	Reg860;
-	u4Byte 	Reg864;
-	
-	BOOLEAN	bIQKInitialized;
-	BOOLEAN bLCKInProgress;
-	BOOLEAN	bAntennaDetected;
-	u4Byte	ADDA_backup[IQK_ADDA_REG_NUM];
-	u4Byte	IQK_MAC_backup[IQK_MAC_REG_NUM];
-	u4Byte	IQK_BB_backup_recover[9];
-	u4Byte	IQK_BB_backup[IQK_BB_REG_NUM];	
-
-	//for APK
-	u4Byte 	APKoutput[2][2]; //path A/B; output1_1a/output1_2a
-	u1Byte 	bAPKdone;
-	u1Byte 	bAPKThermalMeterIgnore;
-	u1Byte 	bDPdone;
-	u1Byte 	bDPPathAOK;
-	u1Byte 	bDPPathBOK;
-
-	/*Add by Yuchen for Kfree Phydm*/
-	u1Byte			RegRfKFreeEnable;	/*for registry*/
-	u1Byte			RfKFreeEnable;		/*for efuse enable check*/
-	
-}ODM_RF_CAL_T,*PODM_RF_CAL_T;
-
-VOID
-odm_TXPowerTrackingCheckAP(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-ODM_TXPowerTrackingCheck(
-	IN	PVOID		pDM_VOID
-	);
-
-
-VOID
-odm_TXPowerTrackingThermalMeterInit(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingInit(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingCheckMP(
-	IN	PVOID		pDM_VOID
-	);
-
-
-VOID
-odm_TXPowerTrackingCheckCE(
-	IN	PVOID		pDM_VOID
-	);
-
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) 
-
-VOID 
-odm_TXPowerTrackingCallbackThermalMeter92C(
-            IN PADAPTER	Adapter
-            );
-
-VOID
-odm_TXPowerTrackingCallbackRXGainThermalMeter92D(
-	IN PADAPTER 	Adapter
-	);
-
-VOID
-odm_TXPowerTrackingCallbackThermalMeter92D(
-            IN PADAPTER	Adapter
-            );
-
-VOID
-odm_TXPowerTrackingDirectCall92C(
-            IN	PADAPTER		Adapter
-            );
-
-VOID
-odm_TXPowerTrackingThermalMeterCheck(
-	IN	PADAPTER		Adapter
-	);
-
-#endif
-
-
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ce.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ce.c
deleted file mode 100644
index 530591461297..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ce.c
+++ /dev/null
@@ -1,705 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-/*============================================================	*/
-/* include files												*/
-/*============================================================	*/
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-//============================================================
-// Global var
-//============================================================
-
-u4Byte	OFDMSwingTable[OFDM_TABLE_SIZE] = {
-	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*/
-};
-
-u1Byte	CCKSwingTable_Ch1_Ch13[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 <== default */
-	{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*/
-};
-
-
-u1Byte	CCKSwingTable_Ch14[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  <== default*/
-	{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*/
-};
-
-
-u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE] = {
-	0x0b40002d, /* 0,  -15.0dB	*/
-	0x0c000030, /* 1,  -14.5dB*/
-	0x0cc00033, /* 2,  -14.0dB*/
-	0x0d800036, /* 3,  -13.5dB*/
-	0x0e400039, /* 4,  -13.0dB  */  
-	0x0f00003c, /* 5,  -12.5dB*/
-	0x10000040, /* 6,  -12.0dB*/
-	0x11000044, /* 7,  -11.5dB*/
-	0x12000048, /* 8,  -11.0dB*/
-	0x1300004c, /* 9,  -10.5dB*/
-	0x14400051, /* 10, -10.0dB*/
-	0x15800056, /* 11, -9.5dB*/
-	0x16c0005b, /* 12, -9.0dB*/
-	0x18000060, /* 13, -8.5dB*/
-	0x19800066, /* 14, -8.0dB*/
-	0x1b00006c, /* 15, -7.5dB*/
-	0x1c800072, /* 16, -7.0dB*/
-	0x1e400079, /* 17, -6.5dB*/
-	0x20000080, /* 18, -6.0dB*/
-	0x22000088, /* 19, -5.5dB*/
-	0x24000090, /* 20, -5.0dB*/
-	0x26000098, /* 21, -4.5dB*/
-	0x288000a2, /* 22, -4.0dB*/
-	0x2ac000ab, /* 23, -3.5dB*/
-	0x2d4000b5, /* 24, -3.0dB*/
-	0x300000c0, /* 25, -2.5dB*/
-	0x32c000cb, /* 26, -2.0dB*/
-	0x35c000d7, /* 27, -1.5dB*/
-	0x390000e4, /* 28, -1.0dB*/
-	0x3c8000f2, /* 29, -0.5dB*/
-	0x40000100, /* 30, +0dB*/
-	0x43c0010f, /* 31, +0.5dB*/
-	0x47c0011f, /* 32, +1.0dB*/
-	0x4c000130, /* 33, +1.5dB*/
-	0x50800142, /* 34, +2.0dB*/
-	0x55400155, /* 35, +2.5dB*/
-	0x5a400169, /* 36, +3.0dB*/
-	0x5fc0017f, /* 37, +3.5dB*/
-	0x65400195, /* 38, +4.0dB*/
-	0x6b8001ae, /* 39, +4.5dB*/
-	0x71c001c7, /* 40, +5.0dB*/
-	0x788001e2, /* 41, +5.5dB*/
-	0x7f8001fe  /* 42, +6.0dB*/
-};               
-
-
-u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {
-{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
-{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
-{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
-{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
-{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
-{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
-{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
-{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
-{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
-{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
-{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
-{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
-{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
-{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
-{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
-{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
-{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
-{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
-{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
-{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
-{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
-};
-
-
-u1Byte CCKSwingTable_Ch1_Ch13_88F[CCK_TABLE_SIZE_88F][16] = {
-{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
-{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
-{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
-{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
-{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
-{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
-{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
-{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
-{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
-{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
-{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
-{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
-{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
-{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
-{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
-{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
-{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
-{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
-{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
-{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
-{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
-};
-
-
-u1Byte CCKSwingTable_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {
-{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
-{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
-{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
-{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
-{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
-{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
-{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
-{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
-{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
-{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
-{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
-{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
-{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
-{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
-{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
-{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
-{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
-{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
-{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
-{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
-{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
-};
-
-
-u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8] = {
-	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/*  0, -16.0dB*/
-	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/*   1, -15.5dB*/
-	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/*  2, -15.0dB*/
-	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/*   3, -14.5dB*/
-	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   4, -14.0dB*/
-	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   5, -13.5dB*/
-	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/*   6, -13.0dB*/
-	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/*   7, -12.5dB*/
-	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/*  8, -12.0dB*/
-	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/*   9, -11.5dB*/
-	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  10, -11.0dB*/
-	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  11, -10.5dB*/
-	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  12, -10.0dB*/
-	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  13, -9.5dB*/
-	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/*  14, -9.0dB */
-	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/*  15, -8.5dB*/
-	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/*  16, -8.0dB */
-	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/*  17, -7.5dB*/
-	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/*  18, -7.0dB */
-	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/*  19, -6.5dB*/
-    {0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	/*20, -6.0dB */
-	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/*  21, -5.5dB*/
-	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
-	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/*  23, -4.5dB*/
-	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/*  24, -4.0dB */
-	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/*  25, -3.5dB*/
-	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/*  26, -3.0dB*/
-	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/*  27, -2.5dB*/
-	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/*  28, -2.0dB */
-	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/*  29, -1.5dB*/
-	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/*  30, -1.0dB*/
-	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/*  31, -0.5dB*/
-	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} 	/*  32, +0dB*/
-};                                                                  
-
-
-u1Byte CCKSwingTable_Ch14_New[CCK_TABLE_SIZE][8]= {
-	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/*  0, -16.0dB*/
-	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB*/
-	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  2, -15.0dB*/
-	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB*/
-	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  4, -14.0dB*/
-	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/*5, -13.5dB*/
-	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB*/
-	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/*  7, -12.5dB*/
-	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB*/
-	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB*/
-	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB*/
-	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/*11, -10.5dB*/
-	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB*/
-	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB*/
-	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/*14, -9.0dB  */
-	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB*/
-	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB  */
-	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB*/
-	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB  */
-	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
-	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB  */
-	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB*/
-	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB  */
-	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/*23, -4.5dB*/
-	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB  */
-	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB  */
-	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB  */
-	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/*27, -2.5dB*/
-	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB  */
-	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/*29, -1.5dB*/
-	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB  */
-	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
-	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} 	/* 32, +0dB	*/
-};
-
-u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE] =
-{
-	0x081, /* 0,  -12.0dB*/
-	0x088, /* 1,  -11.5dB*/
-	0x090, /* 2,  -11.0dB*/
-	0x099, /* 3,  -10.5dB*/
-	0x0A2, /* 4,  -10.0dB*/
-	0x0AC, /* 5,  -9.5dB*/
-	0x0B6, /* 6,  -9.0dB*/
-	0x0C0, /*7,  -8.5dB*/
-	0x0CC, /* 8,  -8.0dB*/
-	0x0D8, /* 9,  -7.5dB*/
-	0x0E5, /* 10, -7.0dB*/
-	0x0F2, /* 11, -6.5dB*/
-	0x101, /* 12, -6.0dB*/
-	0x110, /* 13, -5.5dB*/
-	0x120, /* 14, -5.0dB*/
-	0x131, /* 15, -4.5dB*/
-	0x143, /* 16, -4.0dB*/
-	0x156, /* 17, -3.5dB*/
-	0x16A, /* 18, -3.0dB*/
-	0x180, /* 19, -2.5dB*/
-	0x197, /* 20, -2.0dB*/
-	0x1AF, /* 21, -1.5dB*/
-	0x1C8, /* 22, -1.0dB*/
-	0x1E3, /* 23, -0.5dB*/
-	0x200, /* 24, +0  dB*/
-	0x21E, /* 25, +0.5dB*/
-	0x23E, /* 26, +1.0dB*/
-	0x261, /* 27, +1.5dB*/
-	0x285,/* 28, +2.0dB*/
-	0x2AB, /* 29, +2.5dB*/
-	0x2D3, /*30, +3.0dB*/
-	0x2FE, /* 31, +3.5dB*/
-	0x32B, /* 32, +4.0dB*/
-	0x35C, /* 33, +4.5dB*/
-	0x38E, /* 34, +5.0dB*/
-	0x3C4, /* 35, +5.5dB*/
-	0x3FE  /* 36, +6.0dB	*/
-};
-
-#ifdef AP_BUILD_WORKAROUND
-
-unsigned int TxPwrTrk_OFDM_SwingTbl[TxPwrTrk_OFDM_SwingTbl_Len] = {
-	/*  +6.0dB */ 0x7f8001fe,
-	/*  +5.5dB */ 0x788001e2,
-	/*  +5.0dB */ 0x71c001c7,
-	/*  +4.5dB */ 0x6b8001ae,
-	/*  +4.0dB */ 0x65400195,
-	/*  +3.5dB */ 0x5fc0017f,
-	/*  +3.0dB */ 0x5a400169,
-	/*  +2.5dB */ 0x55400155,
-	/*  +2.0dB */ 0x50800142,
-	/*  +1.5dB */ 0x4c000130,
-	/*  +1.0dB */ 0x47c0011f,
-	/*  +0.5dB */ 0x43c0010f,
-	/*   0.0dB */ 0x40000100,
-	/*  -0.5dB */ 0x3c8000f2,
-	/*  -1.0dB */ 0x390000e4,
-	/*  -1.5dB */ 0x35c000d7,
-	/*  -2.0dB */ 0x32c000cb,
-	/*  -2.5dB */ 0x300000c0,
-	/*  -3.0dB */ 0x2d4000b5,
-	/*  -3.5dB */ 0x2ac000ab,
-	/*  -4.0dB */ 0x288000a2,
-	/*  -4.5dB */ 0x26000098,
-	/*  -5.0dB */ 0x24000090,
-	/*  -5.5dB */ 0x22000088,
-	/*  -6.0dB */ 0x20000080,
-	/*  -6.5dB */ 0x1a00006c,
-	/*  -7.0dB */ 0x1c800072,
-	/*  -7.5dB */ 0x18000060,
-	/*  -8.0dB */ 0x19800066,
-	/*  -8.5dB */ 0x15800056,
-	/*  -9.0dB */ 0x26c0005b,
-	/*  -9.5dB */ 0x14400051,
-	/* -10.0dB */ 0x24400051,
-	/* -10.5dB */ 0x1300004c,
-	/* -11.0dB */ 0x12000048,
-	/* -11.5dB */ 0x11000044,
-	/* -12.0dB */ 0x10000040
-};
-#endif
-
-
-
-VOID
-odm_TXPowerTrackingInit(
-	IN	PVOID	pDM_VOID 
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	if (!(pDM_Odm->SupportICType & (ODM_RTL8814A | ODM_IC_11N_SERIES)))
-		return;
-#endif
-
-	odm_TXPowerTrackingThermalMeterInit(pDM_Odm);
-}	
-
-u1Byte 
-getSwingIndex(
-	IN	PVOID	pDM_VOID 
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u1Byte 			i = 0;
-	u4Byte 			bbSwing;
-	u4Byte 			swingTableSize;
-	pu4Byte 			pSwingTable;
-
-	if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8723B
-		|| pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8188F || pDM_Odm->SupportICType == ODM_RTL8703B
-	) {
-		bbSwing = PHY_QueryBBReg(Adapter, rOFDM0_XATxIQImbalance, 0xFFC00000);
-
-		pSwingTable = OFDMSwingTable_New;
-		swingTableSize = OFDM_TABLE_SIZE;
-	} else {
-#if ((RTL8812A_SUPPORT==1)||(RTL8821A_SUPPORT==1))
-		if (pDM_Odm->SupportICType == ODM_RTL8812 || pDM_Odm->SupportICType == ODM_RTL8821)
-		{
-			bbSwing = PHY_GetTxBBSwing_8812A(Adapter, pHalData->CurrentBandType, ODM_RF_PATH_A);
-			pSwingTable = TxScalingTable_Jaguar;
-			swingTableSize = TXSCALE_TABLE_SIZE;
-		}
-		else
-#endif
-		{
-			bbSwing = 0;
-			pSwingTable = OFDMSwingTable;
-			swingTableSize = OFDM_TABLE_SIZE;
-		}
-	}
-
-	for (i = 0; i < swingTableSize; ++i) {
-		u4Byte tableValue = pSwingTable[i];
-		
-		if (tableValue >= 0x100000 )
-			tableValue >>= 22;
-		if (bbSwing == tableValue)
-			break;
-	}
-	return i;
-}
-
-VOID
-odm_TXPowerTrackingThermalMeterInit(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte defaultSwingIndex = getSwingIndex(pDM_Odm);
-	u1Byte 			p = 0;
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-
-	if(pDM_Odm->mp_mode == FALSE)
-		pHalData->TxPowerTrackControl = TRUE;
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-
-	pRFCalibrateInfo->bTXPowerTracking = _TRUE;
-	pRFCalibrateInfo->TXPowercount = 0;
-	pRFCalibrateInfo->bTXPowerTrackingInit = _FALSE;
-
-	if(pDM_Odm->mp_mode == FALSE)
-		pRFCalibrateInfo->TxPowerTrackControl = _TRUE;
-	else
-		pRFCalibrateInfo->TxPowerTrackControl = _FALSE;	
-
-	if(pDM_Odm->mp_mode == FALSE)
-		pRFCalibrateInfo->TxPowerTrackControl = _TRUE;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("pDM_Odm TxPowerTrackControl = %d\n", pRFCalibrateInfo->TxPowerTrackControl));
-	
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	#ifdef RTL8188E_SUPPORT
-	{
-		pRFCalibrateInfo->bTXPowerTracking = _TRUE;
-		pRFCalibrateInfo->TXPowercount = 0;
-		pRFCalibrateInfo->bTXPowerTrackingInit = _FALSE;
-		pRFCalibrateInfo->TxPowerTrackControl = _TRUE;
-	}
-	#endif
-#endif
-
-	//pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = TRUE;
-	pRFCalibrateInfo->ThermalValue = pHalData->EEPROMThermalMeter;
-	pRFCalibrateInfo->ThermalValue_IQK = pHalData->EEPROMThermalMeter;
-	pRFCalibrateInfo->ThermalValue_LCK = pHalData->EEPROMThermalMeter;	
-
-		/*The index of "0 dB" in SwingTable.*/
-		if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8723B ||
-			pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8703B) {
-			pRFCalibrateInfo->DefaultOfdmIndex = (defaultSwingIndex >= OFDM_TABLE_SIZE) ? 30 : defaultSwingIndex;
-			pRFCalibrateInfo->DefaultCckIndex = 20;	
-		} else if (pDM_Odm->SupportICType == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
-			pRFCalibrateInfo->DefaultOfdmIndex = 28;							/*OFDM: -1dB*/
-			pRFCalibrateInfo->DefaultCckIndex = 20;							/*CCK:-6dB*/
-		} else {
-			pRFCalibrateInfo->DefaultOfdmIndex = (defaultSwingIndex >= TXSCALE_TABLE_SIZE) ? 24 : defaultSwingIndex;
-			pRFCalibrateInfo->DefaultCckIndex = 24;	
-		}
-
-	pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->DefaultCckIndex;
-	pRFCalibrateInfo->CCK_index = pRFCalibrateInfo->DefaultCckIndex;
-	
-	for (p = ODM_RF_PATH_A; p < MAX_RF_PATH; ++p)
-	{
-		pRFCalibrateInfo->BbSwingIdxOfdmBase[p] = pRFCalibrateInfo->DefaultOfdmIndex;		
-		pRFCalibrateInfo->OFDM_index[p] = pRFCalibrateInfo->DefaultOfdmIndex;		
-		pRFCalibrateInfo->DeltaPowerIndex[p] = 0;
-		pRFCalibrateInfo->DeltaPowerIndexLast[p] = 0;
-		pRFCalibrateInfo->PowerIndexOffset[p] = 0;
-	}
-	pRFCalibrateInfo->Modify_TxAGC_Value_OFDM = 0;			
-	pRFCalibrateInfo->Modify_TxAGC_Value_CCK = 0;			
-
-}
-
-
-VOID
-ODM_TXPowerTrackingCheck(
-	IN	PVOID	pDM_VOID
-	)
-{
-	/* 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. */
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	switch	(pDM_Odm->SupportPlatform)
-	{
-		case	ODM_WIN:
-			odm_TXPowerTrackingCheckMP(pDM_Odm);
-			break;
-
-		case	ODM_CE:
-			odm_TXPowerTrackingCheckCE(pDM_Odm);
-			break;
-
-		case	ODM_AP:
-			odm_TXPowerTrackingCheckAP(pDM_Odm);		
-			break;		
-
-		default:
-			break;	
-	}
-
-}
-
-VOID
-odm_TXPowerTrackingCheckCE(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-	if (!(pDM_Odm->SupportAbility & ODM_RF_TX_PWR_TRACK))
-		return;
-
-	if (!pDM_Odm->RFCalibrateInfo.TM_Trigger) {
-		
-		if (IS_HARDWARE_TYPE_8188E(Adapter) || IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8192E(Adapter)
-			|| IS_HARDWARE_TYPE_8723B(Adapter) || IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter)
-			|| IS_HARDWARE_TYPE_8703B(Adapter)
-		) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_T_METER_NEW, (BIT17 | BIT16), 0x03);
-		} else {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_T_METER_OLD, bRFRegOffsetMask, 0x60);
-		}
-		
-	
-		
-		pDM_Odm->RFCalibrateInfo.TM_Trigger = 1;
-		return;
-	}
-	else
-	{
-		
-		ODM_TXPowerTrackingCallback_ThermalMeter(Adapter);
-		pDM_Odm->RFCalibrateInfo.TM_Trigger = 0;
-	}
-
-#endif	
-}
-
-VOID
-odm_TXPowerTrackingCheckMP(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-	if (ODM_CheckPowerStatus(Adapter) == FALSE) 
-	{
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("===>ODM_CheckPowerStatus() return FALSE\n"));
-		return;
-	}
-
-	odm_TXPowerTrackingThermalMeterCheck(Adapter);
-#endif
-	
-}
-
-
-VOID
-odm_TXPowerTrackingCheckAP(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	prtl8192cd_priv	priv		= pDM_Odm->priv;
-
-	return;
-	
-#endif
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-odm_TXPowerTrackingThermalMeterCheck(
-	IN	PADAPTER		Adapter
-	)
-{
-#ifndef AP_BUILD_WORKAROUND
-	static u1Byte			TM_Trigger = 0;
-
-	if (!(GET_HAL_DATA(Adapter)->DM_OutSrc.SupportAbility & ODM_RF_TX_PWR_TRACK)) {
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
-			("===>odm_TXPowerTrackingThermalMeterCheck(),pMgntInfo->bTXPowerTracking is FALSE, return!!\n"));
-		return;
-	}
-
-	if (!TM_Trigger) {
-		if (IS_HARDWARE_TYPE_8188E(Adapter) || IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8192E(Adapter) ||
-				IS_HARDWARE_TYPE_8723B(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter) || IS_HARDWARE_TYPE_8188F(Adapter) 
-				|| IS_HARDWARE_TYPE_8703B(Adapter) || IS_HARDWARE_TYPE_8723D(Adapter))
-			PHY_SetRFReg(Adapter, ODM_RF_PATH_A, RF_T_METER_88E, BIT17 | BIT16, 0x03);
-		else
-			PHY_SetRFReg(Adapter, ODM_RF_PATH_A, RF_T_METER, bRFRegOffsetMask, 0x60);
-		
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,("Trigger Thermal Meter!!\n"));
-		
-		TM_Trigger = 1;
-		return;
-	} else {
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,("Schedule TxPowerTracking direct call!!\n"));		
-		odm_TXPowerTrackingDirectCall(Adapter); 
-		TM_Trigger = 0;
-	}
-#endif
-}
-#endif
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ce.h
deleted file mode 100644
index d6a36a84d0ed..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_ce.h
+++ /dev/null
@@ -1,297 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMPOWERTRACKING_H__
-#define    __PHYDMPOWERTRACKING_H__
-
-#define POWRTRACKING_VERSION	"1.1"
-
-#define		DPK_DELTA_MAPPING_NUM	13
-#define		index_mapping_HP_NUM	15	
-#define	OFDM_TABLE_SIZE 	43
-#define	CCK_TABLE_SIZE			33
-#define	CCK_TABLE_SIZE_88F	21
-#define TXSCALE_TABLE_SIZE 		37
-#define TXPWR_TRACK_TABLE_SIZE 	30
-#define DELTA_SWINGIDX_SIZE     30
-#define BAND_NUM 				4
-
-#define AVG_THERMAL_NUM		8
-#define HP_THERMAL_NUM		8
-#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 IQK_Matrix_REG_NUM	8
-#define IQK_Matrix_Settings_NUM	14+24+21 // Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G
-
-extern	u4Byte OFDMSwingTable[OFDM_TABLE_SIZE];
-extern	u1Byte CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch14 [CCK_TABLE_SIZE][8];
-
-extern	u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE];
-extern	u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch14_New [CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16];
-extern	u1Byte CCKSwingTable_Ch1_Ch13_88F[CCK_TABLE_SIZE_88F][16];
-extern	u1Byte CCKSwingTable_Ch14_88F[CCK_TABLE_SIZE_88F][16];
-
-extern  u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE];
-
-// <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table.
-static u1Byte DeltaSwingTableIdx_2GA_P_8188E[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
-static u1Byte DeltaSwingTableIdx_2GA_N_8188E[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11}; 
-
-#define dm_CheckTXPowerTracking 	ODM_TXPowerTrackingCheck
-
-typedef struct _IQK_MATRIX_REGS_SETTING{
-	BOOLEAN 	bIQKDone;
-	s4Byte		Value[3][IQK_Matrix_REG_NUM];
-	BOOLEAN 	bBWIqkResultSaved[3];	
-}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;
-
-typedef struct ODM_RF_Calibration_Structure
-{
-	//for tx power tracking
-	
-	u4Byte	RegA24; // for TempCCK
-	s4Byte	RegE94;
-	s4Byte 	RegE9C;
-	s4Byte	RegEB4;
-	s4Byte	RegEBC;	
-
-	u1Byte  	TXPowercount;
-	BOOLEAN bTXPowerTrackingInit; 
-	BOOLEAN bTXPowerTracking;
-	u1Byte  	TxPowerTrackControl; //for mp mode, turn off txpwrtracking as default
-	u1Byte  	TM_Trigger;
-    	u1Byte  	InternalPA5G[2];	//pathA / pathB
-	
-	u1Byte  	ThermalMeter[2];    // ThermalMeter, index 0 for RFIC0, and 1 for RFIC1
-	u1Byte  	ThermalValue;
-	u1Byte  	ThermalValue_LCK;
-	u1Byte  	ThermalValue_IQK;
-	u1Byte	ThermalValue_DPK;		
-	u1Byte	ThermalValue_AVG[AVG_THERMAL_NUM];
-	u1Byte	ThermalValue_AVG_index;		
-	u1Byte	ThermalValue_RxGain;
-	u1Byte	ThermalValue_Crystal;
-	u1Byte	ThermalValue_DPKstore;
-	u1Byte	ThermalValue_DPKtrack;
-	BOOLEAN	TxPowerTrackingInProgress;
-	
-	BOOLEAN	bReloadtxpowerindex;	
-	u1Byte 	bRfPiEnable;
-	u4Byte 	TXPowerTrackingCallbackCnt; //cosa add for debug
-
-
-	//------------------------- Tx power Tracking -------------------------//
-	u1Byte 	bCCKinCH14;
-	u1Byte 	CCK_index;
-	u1Byte 	OFDM_index[MAX_RF_PATH];
-	s1Byte	PowerIndexOffset[MAX_RF_PATH];
-	s1Byte	DeltaPowerIndex[MAX_RF_PATH];
-	s1Byte	DeltaPowerIndexLast[MAX_RF_PATH];	
-	BOOLEAN bTxPowerChanged;
-		
-	u1Byte 	ThermalValue_HP[HP_THERMAL_NUM];
-	u1Byte 	ThermalValue_HP_index;
-	IQK_MATRIX_REGS_SETTING IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];
-	u1Byte	Delta_LCK;
-	s1Byte  BBSwingDiff2G, BBSwingDiff5G; // Unit: dB
-	u1Byte  DeltaSwingTableIdx_2GCCKA_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKA_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKB_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKB_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKC_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKC_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKD_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKD_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GB_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GB_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GC_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GC_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GD_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GD_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GA_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GA_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GB_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GB_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GC_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GC_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GD_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GD_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_P_8188E[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_N_8188E[DELTA_SWINGIDX_SIZE];
-    
-	u1Byte			BbSwingIdxOfdm[MAX_RF_PATH];
-	u1Byte			BbSwingIdxOfdmCurrent;
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))	
-	u1Byte			BbSwingIdxOfdmBase[MAX_RF_PATH];
-#else
-	u1Byte			BbSwingIdxOfdmBase;
-#endif
-	BOOLEAN			BbSwingFlagOfdm;
-	u1Byte			BbSwingIdxCck;
-	u1Byte			BbSwingIdxCckCurrent;
-	u1Byte			BbSwingIdxCckBase;
-	u1Byte			DefaultOfdmIndex;
-	u1Byte			DefaultCckIndex;	
-	BOOLEAN			BbSwingFlagCck;
-	
-	s1Byte			Absolute_OFDMSwingIdx[MAX_RF_PATH];   
-	s1Byte			Remnant_OFDMSwingIdx[MAX_RF_PATH];   
-	s1Byte			Remnant_CCKSwingIdx;
-	s1Byte			Modify_TxAGC_Value;       /*Remnat compensate value at TxAGC */
-	BOOLEAN			Modify_TxAGC_Flag_PathA;
-	BOOLEAN			Modify_TxAGC_Flag_PathB;
-	BOOLEAN			Modify_TxAGC_Flag_PathC;
-	BOOLEAN			Modify_TxAGC_Flag_PathD;
-	BOOLEAN			Modify_TxAGC_Flag_PathA_CCK;
-	
-	s1Byte			KfreeOffset[MAX_RF_PATH];
-    
-	//--------------------------------------------------------------------//	
-	
-	//for IQK	
-	u4Byte 	RegC04;
-	u4Byte 	Reg874;
-	u4Byte 	RegC08;
-	u4Byte 	RegB68;
-	u4Byte 	RegB6C;
-	u4Byte 	Reg870;
-	u4Byte 	Reg860;
-	u4Byte 	Reg864;
-	
-	BOOLEAN	bIQKInitialized;
-	BOOLEAN bLCKInProgress;
-	BOOLEAN	bAntennaDetected;
-	BOOLEAN	bNeedIQK;
-	BOOLEAN	bIQKInProgress;	
-	u1Byte	Delta_IQK;
-	u4Byte	ADDA_backup[IQK_ADDA_REG_NUM];
-	u4Byte	IQK_MAC_backup[IQK_MAC_REG_NUM];
-	u4Byte	IQK_BB_backup_recover[9];
-	u4Byte	IQK_BB_backup[IQK_BB_REG_NUM];	
-	u4Byte 	TxIQC_8723B[2][3][2]; // { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}
-	u4Byte 	RxIQC_8723B[2][2][2]; // { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}
-	u4Byte	TxIQC_8703B[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
-	u4Byte	RxIQC_8703B[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
-
-	
-
-	// <James> IQK time measurement 
-	u8Byte	IQK_StartTime;
-	u8Byte	IQK_ProgressingTime;
-	u4Byte  LOK_Result;
-
-	//for APK
-	u4Byte 	APKoutput[2][2]; //path A/B; output1_1a/output1_2a
-	u1Byte 	bAPKdone;
-	u1Byte 	bAPKThermalMeterIgnore;
-	
-	// DPK
-	BOOLEAN bDPKFail;	
-	u1Byte 	bDPdone;
-	u1Byte 	bDPPathAOK;
-	u1Byte 	bDPPathBOK;
-
-	u4Byte	TxLOK[2];
-	u4Byte  DpkTxAGC;
-	s4Byte  DpkGain;
-	u4Byte  DpkThermal[4];
-	s1Byte Modify_TxAGC_Value_OFDM;
-	s1Byte Modify_TxAGC_Value_CCK;
-}ODM_RF_CAL_T,*PODM_RF_CAL_T;
-
-
-VOID	
-ODM_TXPowerTrackingCheck(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-
-VOID
-odm_TXPowerTrackingInit(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingCheckAP(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingThermalMeterInit(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingInit(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingCheckMP(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-
-VOID
-odm_TXPowerTrackingCheckCE(
-	IN 	PVOID	 	pDM_VOID
-	);
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) 
-
-VOID 
-odm_TXPowerTrackingCallbackThermalMeter92C(
-            IN PADAPTER	Adapter
-            );
-
-VOID
-odm_TXPowerTrackingCallbackRXGainThermalMeter92D(
-	IN PADAPTER 	Adapter
-	);
-
-VOID
-odm_TXPowerTrackingCallbackThermalMeter92D(
-            IN PADAPTER	Adapter
-            );
-
-VOID
-odm_TXPowerTrackingDirectCall92C(
-            IN	PADAPTER		Adapter
-            );
-
-VOID
-odm_TXPowerTrackingThermalMeterCheck(
-	IN	PADAPTER		Adapter
-	);
-
-#endif
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_win.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_win.c
deleted file mode 100644
index 2cf4c76c8868..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_win.c
+++ /dev/null
@@ -1,687 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-//============================================================
-// Global var
-//============================================================
-
-u4Byte	OFDMSwingTable[OFDM_TABLE_SIZE] = {
-	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
-};
-
-u1Byte	CCKSwingTable_Ch1_Ch13[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 <== default
-	{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
-};
-
-
-u1Byte	CCKSwingTable_Ch14[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  <== default
-	{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
-};
-
-
-u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE] = {
-	0x0b40002d, // 0,  -15.0dB	
-	0x0c000030, // 1,  -14.5dB
-	0x0cc00033, // 2,  -14.0dB
-	0x0d800036, // 3,  -13.5dB
-	0x0e400039, // 4,  -13.0dB    
-	0x0f00003c, // 5,  -12.5dB
-	0x10000040, // 6,  -12.0dB
-	0x11000044, // 7,  -11.5dB
-	0x12000048, // 8,  -11.0dB
-	0x1300004c, // 9,  -10.5dB
-	0x14400051, // 10, -10.0dB
-	0x15800056, // 11, -9.5dB
-	0x16c0005b, // 12, -9.0dB
-	0x18000060, // 13, -8.5dB
-	0x19800066, // 14, -8.0dB
-	0x1b00006c, // 15, -7.5dB
-	0x1c800072, // 16, -7.0dB
-	0x1e400079, // 17, -6.5dB
-	0x20000080, // 18, -6.0dB
-	0x22000088, // 19, -5.5dB
-	0x24000090, // 20, -5.0dB
-	0x26000098, // 21, -4.5dB
-	0x288000a2, // 22, -4.0dB
-	0x2ac000ab, // 23, -3.5dB
-	0x2d4000b5, // 24, -3.0dB
-	0x300000c0, // 25, -2.5dB
-	0x32c000cb, // 26, -2.0dB
-	0x35c000d7, // 27, -1.5dB
-	0x390000e4, // 28, -1.0dB
-	0x3c8000f2, // 29, -0.5dB
-	0x40000100, // 30, +0dB
-	0x43c0010f, // 31, +0.5dB
-	0x47c0011f, // 32, +1.0dB
-	0x4c000130, // 33, +1.5dB
-	0x50800142, // 34, +2.0dB
-	0x55400155, // 35, +2.5dB
-	0x5a400169, // 36, +3.0dB
-	0x5fc0017f, // 37, +3.5dB
-	0x65400195, // 38, +4.0dB
-	0x6b8001ae, // 39, +4.5dB
-	0x71c001c7, // 40, +5.0dB
-	0x788001e2, // 41, +5.5dB
-	0x7f8001fe  // 42, +6.0dB
-};               
-
-
-u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {
-{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
-{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
-{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
-{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
-{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
-{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
-{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
-{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
-{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
-{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
-{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
-{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
-{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
-{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
-{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
-{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
-{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
-{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
-{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
-{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
-{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
-};
-
-
-u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8] = {
-	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	//  0, -16.0dB
-	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	//  1, -15.5dB
-	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	//  2, -15.0dB
-	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	//  3, -14.5dB
-	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	//  4, -14.0dB
-	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	//  5, -13.5dB
-	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	//  6, -13.0dB
-	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	//  7, -12.5dB
-	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	//  8, -12.0dB
-	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	//  9, -11.5dB
-	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	// 10, -11.0dB
-	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	// 11, -10.5dB
-	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	// 12, -10.0dB
-	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	// 13, -9.5dB
-	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	// 14, -9.0dB 
-	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	// 15, -8.5dB
-	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	// 16, -8.0dB 
-	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	// 17, -7.5dB
-	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	// 18, -7.0dB 
-	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	// 19, -6.5dB
-    {0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	// 20, -6.0dB 
-	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	// 21, -5.5dB
-	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	// 22, -5.0dB 
-	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	// 23, -4.5dB
-	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	// 24, -4.0dB 
-	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	// 25, -3.5dB
-	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	// 26, -3.0dB
-	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	// 27, -2.5dB
-	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	// 28, -2.0dB 
-	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	// 29, -1.5dB
-	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	// 30, -1.0dB
-	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	// 31, -0.5dB
-	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} 	// 32, +0dB
-};                                                                  
-
-
-u1Byte CCKSwingTable_Ch14_New[CCK_TABLE_SIZE][8]= {
-	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	//  0, -16.0dB
-	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	//  1, -15.5dB
-	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	//  2, -15.0dB
-	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	//  3, -14.5dB
-	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	//  4, -14.0dB
-	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	//  5, -13.5dB
-	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	//  6, -13.0dB
-	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	//  7, -12.5dB
-	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	//  8, -12.0dB
-	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	//  9, -11.5dB
-	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	// 10, -11.0dB
-	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	// 11, -10.5dB
-	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	// 12, -10.0dB
-	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	// 13, -9.5dB
-	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	// 14, -9.0dB  
-	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	// 15, -8.5dB
-	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	// 16, -8.0dB  
-	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	// 17, -7.5dB
-	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	// 18, -7.0dB  
-	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	// 19, -6.5dB 
-	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	// 20, -6.0dB  
-	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	// 21, -5.5dB
-	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	// 22, -5.0dB  
-	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	// 23, -4.5dB
-	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	// 24, -4.0dB  
-	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	// 25, -3.5dB  
-	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	// 26, -3.0dB  
-	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	// 27, -2.5dB
-	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	// 28, -2.0dB  
-	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	// 29, -1.5dB
-	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	// 30, -1.0dB  
-	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	// 31, -0.5dB 
-	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} 	// 32, +0dB	
-};
-
-u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE] =
-{
-	0x081, // 0,  -12.0dB
-	0x088, // 1,  -11.5dB
-	0x090, // 2,  -11.0dB
-	0x099, // 3,  -10.5dB
-	0x0A2, // 4,  -10.0dB
-	0x0AC, // 5,  -9.5dB
-	0x0B6, // 6,  -9.0dB
-	0x0C0, // 7,  -8.5dB
-	0x0CC, // 8,  -8.0dB
-	0x0D8, // 9,  -7.5dB
-	0x0E5, // 10, -7.0dB
-	0x0F2, // 11, -6.5dB
-	0x101, // 12, -6.0dB
-	0x110, // 13, -5.5dB
-	0x120, // 14, -5.0dB
-	0x131, // 15, -4.5dB
-	0x143, // 16, -4.0dB
-	0x156, // 17, -3.5dB
-	0x16A, // 18, -3.0dB
-	0x180, // 19, -2.5dB
-	0x197, // 20, -2.0dB
-	0x1AF, // 21, -1.5dB
-	0x1C8, // 22, -1.0dB
-	0x1E3, // 23, -0.5dB
-	0x200, // 24, +0  dB
-	0x21E, // 25, +0.5dB
-	0x23E, // 26, +1.0dB
-	0x261, // 27, +1.5dB
-	0x285, // 28, +2.0dB
-	0x2AB, // 29, +2.5dB
-	0x2D3, // 30, +3.0dB
-	0x2FE, // 31, +3.5dB
-	0x32B, // 32, +4.0dB
-	0x35C, // 33, +4.5dB
-	0x38E, // 34, +5.0dB
-	0x3C4, // 35, +5.5dB
-	0x3FE  // 36, +6.0dB	
-};
-
-#ifdef AP_BUILD_WORKAROUND
-
-unsigned int TxPwrTrk_OFDM_SwingTbl[TxPwrTrk_OFDM_SwingTbl_Len] = {
-	/*  +6.0dB */ 0x7f8001fe,
-	/*  +5.5dB */ 0x788001e2,
-	/*  +5.0dB */ 0x71c001c7,
-	/*  +4.5dB */ 0x6b8001ae,
-	/*  +4.0dB */ 0x65400195,
-	/*  +3.5dB */ 0x5fc0017f,
-	/*  +3.0dB */ 0x5a400169,
-	/*  +2.5dB */ 0x55400155,
-	/*  +2.0dB */ 0x50800142,
-	/*  +1.5dB */ 0x4c000130,
-	/*  +1.0dB */ 0x47c0011f,
-	/*  +0.5dB */ 0x43c0010f,
-	/*   0.0dB */ 0x40000100,
-	/*  -0.5dB */ 0x3c8000f2,
-	/*  -1.0dB */ 0x390000e4,
-	/*  -1.5dB */ 0x35c000d7,
-	/*  -2.0dB */ 0x32c000cb,
-	/*  -2.5dB */ 0x300000c0,
-	/*  -3.0dB */ 0x2d4000b5,
-	/*  -3.5dB */ 0x2ac000ab,
-	/*  -4.0dB */ 0x288000a2,
-	/*  -4.5dB */ 0x26000098,
-	/*  -5.0dB */ 0x24000090,
-	/*  -5.5dB */ 0x22000088,
-	/*  -6.0dB */ 0x20000080,
-	/*  -6.5dB */ 0x1a00006c,
-	/*  -7.0dB */ 0x1c800072,
-	/*  -7.5dB */ 0x18000060,
-	/*  -8.0dB */ 0x19800066,
-	/*  -8.5dB */ 0x15800056,
-	/*  -9.0dB */ 0x26c0005b,
-	/*  -9.5dB */ 0x14400051,
-	/* -10.0dB */ 0x24400051,
-	/* -10.5dB */ 0x1300004c,
-	/* -11.0dB */ 0x12000048,
-	/* -11.5dB */ 0x11000044,
-	/* -12.0dB */ 0x10000040
-};
-
-#endif
-
-VOID
-odm_TXPowerTrackingInit(
-	IN	PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	if(!(pDM_Odm->SupportICType & (ODM_RTL8814A|ODM_IC_11N_SERIES|ODM_RTL8822B)))
-		return;
-#endif
-
-	odm_TXPowerTrackingThermalMeterInit(pDM_Odm);
-}	
-
-u1Byte 
-getSwingIndex(
-	IN	PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u1Byte 			i = 0;
-	u4Byte 			bbSwing;
-	u4Byte 			swingTableSize;
-	pu4Byte 			pSwingTable;
-
-	if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8723B ||
-		pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8188F || pDM_Odm->SupportICType == ODM_RTL8703B) 
-	{
-		bbSwing = PHY_QueryBBReg(Adapter, rOFDM0_XATxIQImbalance, 0xFFC00000);
-
-		pSwingTable = OFDMSwingTable_New;
-		swingTableSize = OFDM_TABLE_SIZE;
-	} else {
-		bbSwing = PHY_GetTxBBSwing_8812A(Adapter, pHalData->CurrentBandType, ODM_RF_PATH_A);
-		pSwingTable = TxScalingTable_Jaguar;
-		swingTableSize = TXSCALE_TABLE_SIZE;		
-	}
-
-	for (i = 0; i < swingTableSize; ++i) {
-		u4Byte tableValue = pSwingTable[i];
-		
-		if (tableValue >= 0x100000 )
-			tableValue >>= 22;
-		if (bbSwing == tableValue)
-			break;
-	}
-	return i;
-}
-
-VOID
-odm_TXPowerTrackingThermalMeterInit(
-	IN	PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte defaultSwingIndex = getSwingIndex(pDM_Odm);
-	PODM_RF_CAL_T	pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-	
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u1Byte 			p = 0;
-
-	if(pDM_Odm->mp_mode == FALSE)
-		pRFCalibrateInfo->TxPowerTrackControl = TRUE;
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#ifdef CONFIG_RTL8188E
-	{
-		pRFCalibrateInfo->bTXPowerTracking = _TRUE;
-		pRFCalibrateInfo->TXPowercount = 0;
-		pRFCalibrateInfo->bTXPowerTrackingInit = _FALSE;
-
-		if(pDM_Odm->mp_mode == FALSE)
-			pRFCalibrateInfo->TxPowerTrackControl = _TRUE;
-		
-		MSG_8192C("pDM_Odm TxPowerTrackControl = %d\n", pRFCalibrateInfo->TxPowerTrackControl);
-	}
-	#else
-	{
-		PADAPTER		Adapter = pDM_Odm->Adapter;
-		HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-		struct dm_priv	*pdmpriv = &pHalData->dmpriv;
-
-		pdmpriv->bTXPowerTracking = _TRUE;
-		pdmpriv->TXPowercount = 0;
-		pdmpriv->bTXPowerTrackingInit = _FALSE;
-
-		if(pDM_Odm->mp_mode == FALSE)
-			pdmpriv->TxPowerTrackControl = _TRUE;
-
-		MSG_8192C("pdmpriv->TxPowerTrackControl = %d\n", pdmpriv->TxPowerTrackControl);
-	
-	}	
-	#endif//endif (CONFIG_RTL8188E==1)	
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	#ifdef RTL8188E_SUPPORT
-	{
-		pRFCalibrateInfo->bTXPowerTracking = _TRUE;
-		pRFCalibrateInfo->TXPowercount = 0;
-		pRFCalibrateInfo->bTXPowerTrackingInit = _FALSE;
-		pRFCalibrateInfo->TxPowerTrackControl = _TRUE;
-	}
-	#endif
-#endif
-
-	pRFCalibrateInfo->TxPowerTrackControl = TRUE;
-	pRFCalibrateInfo->ThermalValue 		= pHalData->EEPROMThermalMeter;
-	pRFCalibrateInfo->ThermalValue_IQK 	= pHalData->EEPROMThermalMeter;
-	pRFCalibrateInfo->ThermalValue_LCK 	= pHalData->EEPROMThermalMeter;	
-
-	// The index of "0 dB" in SwingTable.
-	if (pDM_Odm->SupportICType == ODM_RTL8188E || pDM_Odm->SupportICType == ODM_RTL8723B ||
-		pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8703B) 
-	{
-		pRFCalibrateInfo->DefaultOfdmIndex = (defaultSwingIndex >= OFDM_TABLE_SIZE) ? 30 : defaultSwingIndex;
-		pRFCalibrateInfo->DefaultCckIndex = 20;	
-	}
-	else if(pDM_Odm->SupportICType == ODM_RTL8188F)          //add by Mingzhi.Guo  2015-03-23
-	{
-		pRFCalibrateInfo->DefaultOfdmIndex =28;							//OFDM: -1dB
-		pRFCalibrateInfo->DefaultCckIndex =20;							//CCK:-6dB
-	}
-	else
-	{
-		pRFCalibrateInfo->DefaultOfdmIndex = (defaultSwingIndex >= TXSCALE_TABLE_SIZE) ? 24 : defaultSwingIndex;
-		pRFCalibrateInfo->DefaultCckIndex = 24;	
-	}
-
-	pRFCalibrateInfo->BbSwingIdxCckBase = pRFCalibrateInfo->DefaultCckIndex;
-	pRFCalibrateInfo->CCK_index = pRFCalibrateInfo->DefaultCckIndex;
-	
-	for (p = ODM_RF_PATH_A; p < MAX_RF_PATH; ++p)
-	{
-		pRFCalibrateInfo->BbSwingIdxOfdmBase[p] = pRFCalibrateInfo->DefaultOfdmIndex;		
-	   	pRFCalibrateInfo->OFDM_index[p] = pRFCalibrateInfo->DefaultOfdmIndex;		
-		pRFCalibrateInfo->DeltaPowerIndex[p] = 0;
-		pRFCalibrateInfo->DeltaPowerIndexLast[p] = 0;
-		pRFCalibrateInfo->PowerIndexOffset[p] = 0;
-		pRFCalibrateInfo->KfreeOffset[p] = 0;
-	}
-	pRFCalibrateInfo->Modify_TxAGC_Value_OFDM=0;			//add by Mingzhi.Guo
-	pRFCalibrateInfo->Modify_TxAGC_Value_CCK=0;			//add by Mingzhi.Guo
-
-}
-
-
-VOID
-ODM_TXPowerTrackingCheck(
-	IN	PVOID		pDM_VOID
-	)
-{
-	//
-	// 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.
-	//
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	switch	(pDM_Odm->SupportPlatform)
-	{
-		case	ODM_WIN:
-			odm_TXPowerTrackingCheckMP(pDM_Odm);
-			break;
-
-		case	ODM_CE:
-			odm_TXPowerTrackingCheckCE(pDM_Odm);
-			break;
-
-		case	ODM_AP:
-			odm_TXPowerTrackingCheckAP(pDM_Odm);		
-			break;		
-
-		default:
-			break;	
-	}
-
-}
-
-VOID
-odm_TXPowerTrackingCheckCE(
-	IN	PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-	#if ((RTL8188F_SUPPORT == 1))
-	rtl8192c_odm_CheckTXPowerTracking(Adapter);
-	#endif
-
-	#if(RTL8188E_SUPPORT==1)
-
-	if(!(pDM_Odm->SupportAbility & ODM_RF_TX_PWR_TRACK))
-	{
-		return;
-	}
-
-	if(!pRFCalibrateInfo->TM_Trigger)		//at least delay 1 sec
-	{
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_T_METER, bRFRegOffsetMask, 0x60);
-		//DBG_8192C("Trigger 92C Thermal Meter!!\n");
-		
-		pRFCalibrateInfo->TM_Trigger = 1;
-		return;
-		
-	}
-	else
-	{
-		//DBG_8192C("Schedule TxPowerTracking direct call!!\n");
-		odm_TXPowerTrackingCallback_ThermalMeter_8188E(Adapter);
-		pRFCalibrateInfo->TM_Trigger = 0;
-	}
-	#endif
-#endif	
-}
-
-VOID
-odm_TXPowerTrackingCheckMP(
-	IN	PVOID		pDM_VOID
-	)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-
-	if(*pDM_Odm->pIsFcsModeEnable)
-		return;
-
-	if (ODM_CheckPowerStatus(Adapter) == FALSE) 
-	{
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("===>ODM_CheckPowerStatus() return FALSE\n"));
-		return;
-	}
-
-	if(IS_HARDWARE_TYPE_8821B(Adapter)) // TODO: Don't Do PowerTracking
-		return;
-	
-//	#if(RTL8192D_SUPPORT==1)
-//	if(!Adapter->bSlaveOfDMSP || Adapter->DualMacSmartConcurrent == FALSE)
-	if (IS_HARDWARE_TYPE_8814A(Adapter) || IS_HARDWARE_TYPE_8188F(Adapter))
-		odm_TXPowerTrackingThermalMeterCheck(Adapter);
-	else {
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("!Adapter->bSlaveOfDMSP || Adapter->DualMacSmartConcurrent == FALSE\n"));
-	}
-//	#endif
-#endif
-	
-}
-
-
-VOID
-odm_TXPowerTrackingCheckAP(
-	IN	PVOID		pDM_VOID
-	)
-{
-return;
-
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-odm_TXPowerTrackingDirectCall(
-	IN	PADAPTER		Adapter
-	)
-{
-	HAL_DATA_TYPE		*pHalData	= GET_HAL_DATA(Adapter);
-	PDM_ODM_T			pDM_Odm = &pHalData->DM_OutSrc;
-	
-	ODM_TXPowerTrackingCallback_ThermalMeter(Adapter);
-}
-
-VOID
-odm_TXPowerTrackingThermalMeterCheck(
-	IN	PADAPTER		Adapter
-	)
-{
-#ifndef AP_BUILD_WORKAROUND
-	static u1Byte			TM_Trigger = 0;
-
-	if(!(GET_HAL_DATA(Adapter)->DM_OutSrc.SupportAbility & ODM_RF_TX_PWR_TRACK))
-	{
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
-			("===>odm_TXPowerTrackingThermalMeterCheck(),pMgntInfo->bTXPowerTracking is FALSE, return!!\n"));
-		return;
-	}
-
-	if(!TM_Trigger)		//at least delay 1 sec
-	{
-		if (IS_HARDWARE_TYPE_8188E(Adapter) || IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8192E(Adapter) ||
-			    IS_HARDWARE_TYPE_8723B(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter) || IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8703B(Adapter))
-			PHY_SetRFReg(Adapter, ODM_RF_PATH_A, RF_T_METER_88E, BIT17 | BIT16, 0x03);
-		else
-			PHY_SetRFReg(Adapter, ODM_RF_PATH_A, RF_T_METER, bRFRegOffsetMask, 0x60);
-		
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,("Trigger Thermal Meter!!\n"));
-		
-		TM_Trigger = 1;
-		return;
-	}
-	else
-	{
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,("Schedule TxPowerTracking direct call!!\n"));		
-		odm_TXPowerTrackingDirectCall(Adapter); //Using direct call is instead, added by Roger, 2009.06.18.
-		TM_Trigger = 0;
-	}
-#endif
-}
-
-#endif //end #ifMP
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_win.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_win.h
deleted file mode 100644
index be43875f03ac..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_powertracking_win.h
+++ /dev/null
@@ -1,265 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__PHYDMPOWERTRACKING_H__
-#define    __PHYDMPOWERTRACKING_H__
-
-#define POWRTRACKING_VERSION	"1.1"
-
-#define	DPK_DELTA_MAPPING_NUM	13
-#define	index_mapping_HP_NUM	15	
-#define	TXSCALE_TABLE_SIZE 		37
-#define	TXPWR_TRACK_TABLE_SIZE 	30
-#define	DELTA_SWINGIDX_SIZE     30
-#define	BAND_NUM 				3
-#define	MAX_RF_PATH	4
-#define	CCK_TABLE_SIZE_88F	21
-
-
-#define	dm_CheckTXPowerTracking 	ODM_TXPowerTrackingCheck
-
-#define IQK_Matrix_Settings_NUM	14+24+21 // Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G
-#define	AVG_THERMAL_NUM		8
-#define	HP_THERMAL_NUM		8
-#define	IQK_Matrix_REG_NUM	8
-#define	IQK_MAC_REG_NUM		4
-#define	IQK_ADDA_REG_NUM		16
-
-#define	IQK_BB_REG_NUM		9
-
-
-extern	u4Byte OFDMSwingTable[OFDM_TABLE_SIZE];
-extern	u1Byte CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch14 [CCK_TABLE_SIZE][8];
-
-extern	u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE];
-extern	u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch14_New [CCK_TABLE_SIZE][8];
-extern	u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16];
-
-extern  u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE];
-
-// <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table.
-static u1Byte DeltaSwingTableIdx_2GA_P_8188E[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
-static u1Byte DeltaSwingTableIdx_2GA_N_8188E[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11}; 
-
-VOID
-ODM_TXPowerTrackingCheck(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingCheckAP(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingThermalMeterInit(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingInit(
-	IN	PVOID		pDM_VOID
-	);
-
-VOID
-odm_TXPowerTrackingCheckMP(
-	IN	PVOID		pDM_VOID
-	);
-
-
-VOID
-odm_TXPowerTrackingCheckCE(
-	IN	PVOID		pDM_VOID
-	);
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) 
-
-
-VOID
-odm_TXPowerTrackingThermalMeterCheck(
-	IN	PADAPTER		Adapter
-	);
-
-#endif
-
-typedef struct _IQK_MATRIX_REGS_SETTING{
-	BOOLEAN 	bIQKDone;
-	s4Byte		Value[3][IQK_Matrix_REG_NUM];
-	BOOLEAN 	bBWIqkResultSaved[3];	
-}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;
-
-typedef struct ODM_RF_Calibration_Structure
-{
-	//for tx power tracking
-	
-	u4Byte	RegA24; // for TempCCK
-	s4Byte	RegE94;
-	s4Byte 	RegE9C;
-	s4Byte	RegEB4;
-	s4Byte	RegEBC;	
-	//u1Byte bTXPowerTracking;
-	u1Byte  	TXPowercount;
-	BOOLEAN bTXPowerTrackingInit; 
-	BOOLEAN bTXPowerTracking;
-	u1Byte  	TxPowerTrackControl; //for mp mode, turn off txpwrtracking as default
-	u1Byte  	TM_Trigger;
-    	u1Byte  	InternalPA5G[2];	//pathA / pathB
-	
-	u1Byte  	ThermalMeter[2];    // ThermalMeter, index 0 for RFIC0, and 1 for RFIC1
-	u1Byte  	ThermalValue;
-	u1Byte  	ThermalValue_LCK;
-	u1Byte  	ThermalValue_IQK;
-	u1Byte	ThermalValue_AVG[AVG_THERMAL_NUM];
-	u1Byte	ThermalValue_AVG_index;		
-	u1Byte	ThermalValue_RxGain;
-	
-	BOOLEAN	bReloadtxpowerindex;	
-	u1Byte 	bRfPiEnable;
-	u4Byte 	TXPowerTrackingCallbackCnt; //cosa add for debug
-
-
-	//------------------------- Tx power Tracking -------------------------//
-	u1Byte 	bCCKinCH14;
-	u1Byte 	CCK_index;
-	u1Byte 	OFDM_index[MAX_RF_PATH];
-	s1Byte	PowerIndexOffset[MAX_RF_PATH];
-	s1Byte	DeltaPowerIndex[MAX_RF_PATH];
-	s1Byte	DeltaPowerIndexLast[MAX_RF_PATH];	
-	BOOLEAN bTxPowerChanged;
-		
-	u1Byte 	ThermalValue_HP[HP_THERMAL_NUM];
-	u1Byte 	ThermalValue_HP_index;
-	IQK_MATRIX_REGS_SETTING IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];
-	u1Byte	Delta_LCK;
-	s1Byte  BBSwingDiff2G, BBSwingDiff5G; // Unit: dB
-	u1Byte  DeltaSwingTableIdx_2GCCKA_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKA_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKB_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKB_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKC_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKC_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKD_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GCCKD_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GB_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GB_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GC_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GC_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GD_P[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GD_N[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GA_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GA_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GB_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GB_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GC_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GC_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GD_P[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_5GD_N[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_P_8188E[DELTA_SWINGIDX_SIZE];
-	u1Byte  DeltaSwingTableIdx_2GA_N_8188E[DELTA_SWINGIDX_SIZE];
-	
-	u1Byte			BbSwingIdxOfdm[MAX_RF_PATH];
-	u1Byte			BbSwingIdxOfdmCurrent;
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))	
-	u1Byte			BbSwingIdxOfdmBase[MAX_RF_PATH];
-#else
-	u1Byte			BbSwingIdxOfdmBase;
-#endif
-	BOOLEAN			BbSwingFlagOfdm;
-	u1Byte			BbSwingIdxCck;
-	u1Byte			BbSwingIdxCckCurrent;
-	u1Byte			BbSwingIdxCckBase;
-	u1Byte			DefaultOfdmIndex;
-	u1Byte			DefaultCckIndex;	
-	BOOLEAN			BbSwingFlagCck;
-	
-	s1Byte			Absolute_OFDMSwingIdx[MAX_RF_PATH];   
-	s1Byte			Remnant_OFDMSwingIdx[MAX_RF_PATH];   
-	s1Byte			Remnant_CCKSwingIdx;
-	s1Byte			Modify_TxAGC_Value;       /*Remnat compensate value at TxAGC */
-	BOOLEAN			Modify_TxAGC_Flag_PathA;
-	BOOLEAN			Modify_TxAGC_Flag_PathB;
-	BOOLEAN			Modify_TxAGC_Flag_PathC;
-	BOOLEAN			Modify_TxAGC_Flag_PathD;
-	BOOLEAN			Modify_TxAGC_Flag_PathA_CCK;
-	
-	s1Byte			KfreeOffset[MAX_RF_PATH];
-    
-	//--------------------------------------------------------------------//	
-	
-	//for IQK	
-	u4Byte 	RegC04;
-	u4Byte 	Reg874;
-	u4Byte 	RegC08;
-	u4Byte 	RegB68;
-	u4Byte 	RegB6C;
-	u4Byte 	Reg870;
-	u4Byte 	Reg860;
-	u4Byte 	Reg864;
-	
-	BOOLEAN	bIQKInitialized;
-	BOOLEAN bLCKInProgress;
-	BOOLEAN	bAntennaDetected;
-	BOOLEAN	bNeedIQK;
-	BOOLEAN	bIQKInProgress;	
-	u1Byte	Delta_IQK;
-	u4Byte	ADDA_backup[IQK_ADDA_REG_NUM];
-	u4Byte	IQK_MAC_backup[IQK_MAC_REG_NUM];
-	u4Byte	IQK_BB_backup_recover[9];
-	u4Byte	IQK_BB_backup[IQK_BB_REG_NUM];	
-	u4Byte	TxIQC_8723B[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
-	u4Byte	RxIQC_8723B[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
-	u4Byte	TxIQC_8703B[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
-	u4Byte	RxIQC_8703B[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
-	
-	
-
-	// <James> IQK time measurement 
-	u8Byte	IQK_StartTime;
-	u8Byte	IQK_ProgressingTime;
-	u4Byte  LOK_Result;
-
-	//for APK
-	u4Byte 	APKoutput[2][2]; //path A/B; output1_1a/output1_2a
-	u1Byte 	bAPKdone;
-	u1Byte 	bAPKThermalMeterIgnore;
-	
-	// DPK
-	BOOLEAN bDPKFail;	
-	u1Byte 	bDPdone;
-	u1Byte 	bDPPathAOK;
-	u1Byte 	bDPPathBOK;
-
-	u4Byte	TxLOK[2];
-	u4Byte  DpkTxAGC;
-	s4Byte  DpkGain;
-	u4Byte  DpkThermal[4];	
-
-	s1Byte Modify_TxAGC_Value_OFDM;
-	s1Byte Modify_TxAGC_Value_CCK;
-}ODM_RF_CAL_T,*PODM_RF_CAL_T;
-
-
-
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pre_define.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pre_define.h
index ea89aa04e1b8..2b17c048e4ea 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pre_define.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_pre_define.h
@@ -1,615 +1,748 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-
-#ifndef	__PHYDMPREDEFINE_H__
-#define    __PHYDMPREDEFINE_H__
-
-//1 ============================================================
-//1  Definition 
-//1 ============================================================
-
-//Max path of IC
-#define MAX_PATH_NUM_92CS		2
-#define MAX_PATH_NUM_8188E		1
-#define MAX_PATH_NUM_8192E		2
-#define MAX_PATH_NUM_8723B		1
-#define MAX_PATH_NUM_8812A		2
-#define MAX_PATH_NUM_8821A		1
-#define MAX_PATH_NUM_8814A		4
-#define MAX_PATH_NUM_8822B		2
-#define MAX_PATH_NUM_8821B		2
-#define MAX_PATH_NUM_8703B		1
-#define MAX_PATH_NUM_8188F		1
-
-//Max RF path
-#define ODM_RF_PATH_MAX 2
-#define ODM_RF_PATH_MAX_JAGUAR 4
-
-//number of entry
-#if(DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	#define	ASSOCIATE_ENTRY_NUM					MACID_NUM_SW_LIMIT  /* Max size of AsocEntry[].*/
-	#define	ODM_ASSOCIATE_ENTRY_NUM				ASSOCIATE_ENTRY_NUM
-#elif(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	#define ASSOCIATE_ENTRY_NUM					NUM_STAT
-	#define	ODM_ASSOCIATE_ENTRY_NUM				(ASSOCIATE_ENTRY_NUM+1)
-#else
-	#define ODM_ASSOCIATE_ENTRY_NUM				((ASSOCIATE_ENTRY_NUM*3)+1)
-#endif
-
-/* -----MGN rate--------------------------------- */
-
-#define	ODM_MGN_1M			0x02
-#define	ODM_MGN_2M			0x04
-#define	ODM_MGN_5_5M			0x0b
-#define	ODM_MGN_11M			0x16
-
-#define	ODM_MGN_6M			0x0c
-#define	ODM_MGN_9M			0x12
-#define	ODM_MGN_12M			0x18
-#define	ODM_MGN_18M			0x24
-#define	ODM_MGN_24M			0x30
-#define	ODM_MGN_36M			0x48
-#define	ODM_MGN_48M			0x60
-#define	ODM_MGN_54M			0x6c
-
-/*TxHT = 1*/
-#define	ODM_MGN_MCS0			0x80
-#define	ODM_MGN_MCS1			0x81
-#define	ODM_MGN_MCS2			0x82
-#define	ODM_MGN_MCS3			0x83
-#define	ODM_MGN_MCS4			0x84
-#define	ODM_MGN_MCS5			0x85
-#define	ODM_MGN_MCS6			0x86
-#define	ODM_MGN_MCS7			0x87
-#define	ODM_MGN_MCS8			0x88
-#define	ODM_MGN_MCS9			0x89
-#define	ODM_MGN_MCS10		0x8a
-#define	ODM_MGN_MCS11		0x8b
-#define	ODM_MGN_MCS12		0x8c
-#define	ODM_MGN_MCS13		0x8d
-#define	ODM_MGN_MCS14		0x8e
-#define	ODM_MGN_MCS15		0x8f
-#define	ODM_MGN_VHT1SS_MCS0	0x90
-#define	ODM_MGN_VHT1SS_MCS1	0x91
-#define	ODM_MGN_VHT1SS_MCS2	0x92
-#define	ODM_MGN_VHT1SS_MCS3	0x93
-#define	ODM_MGN_VHT1SS_MCS4	0x94
-#define	ODM_MGN_VHT1SS_MCS5	0x95
-#define	ODM_MGN_VHT1SS_MCS6	0x96
-#define	ODM_MGN_VHT1SS_MCS7	0x97
-#define	ODM_MGN_VHT1SS_MCS8	0x98
-#define	ODM_MGN_VHT1SS_MCS9	0x99
-#define	ODM_MGN_VHT2SS_MCS0	0x9a
-#define	ODM_MGN_VHT2SS_MCS1	0x9b
-#define	ODM_MGN_VHT2SS_MCS2	0x9c
-#define	ODM_MGN_VHT2SS_MCS3	0x9d
-#define	ODM_MGN_VHT2SS_MCS4	0x9e
-#define	ODM_MGN_VHT2SS_MCS5	0x9f
-#define	ODM_MGN_VHT2SS_MCS6	0xa0
-#define	ODM_MGN_VHT2SS_MCS7	0xa1
-#define	ODM_MGN_VHT2SS_MCS8	0xa2
-#define	ODM_MGN_VHT2SS_MCS9	0xa3
-
-#define	ODM_MGN_MCS0_SG		0xc0
-#define	ODM_MGN_MCS1_SG		0xc1
-#define	ODM_MGN_MCS2_SG		0xc2
-#define	ODM_MGN_MCS3_SG		0xc3
-#define	ODM_MGN_MCS4_SG		0xc4
-#define	ODM_MGN_MCS5_SG		0xc5
-#define	ODM_MGN_MCS6_SG		0xc6
-#define	ODM_MGN_MCS7_SG		0xc7
-#define	ODM_MGN_MCS8_SG		0xc8
-#define	ODM_MGN_MCS9_SG		0xc9
-#define	ODM_MGN_MCS10_SG		0xca
-#define	ODM_MGN_MCS11_SG		0xcb
-#define	ODM_MGN_MCS12_SG		0xcc
-#define	ODM_MGN_MCS13_SG		0xcd
-#define	ODM_MGN_MCS14_SG		0xce
-#define	ODM_MGN_MCS15_SG		0xcf
-
-/* -----DESC rate--------------------------------- */
-
-#define ODM_RATEMCS15_SG		0x1c
-#define ODM_RATEMCS32			0x20
-
-
-// CCK Rates, TxHT = 0
-#define ODM_RATE1M				0x00
-#define ODM_RATE2M				0x01
-#define ODM_RATE5_5M			0x02
-#define ODM_RATE11M				0x03
-// OFDM Rates, TxHT = 0
-#define ODM_RATE6M				0x04
-#define ODM_RATE9M				0x05
-#define ODM_RATE12M				0x06
-#define ODM_RATE18M				0x07
-#define ODM_RATE24M				0x08
-#define ODM_RATE36M				0x09
-#define ODM_RATE48M				0x0A
-#define ODM_RATE54M				0x0B
-// MCS Rates, TxHT = 1
-#define ODM_RATEMCS0			0x0C
-#define ODM_RATEMCS1			0x0D
-#define ODM_RATEMCS2			0x0E
-#define ODM_RATEMCS3			0x0F
-#define ODM_RATEMCS4			0x10
-#define ODM_RATEMCS5			0x11
-#define ODM_RATEMCS6			0x12
-#define ODM_RATEMCS7			0x13
-#define ODM_RATEMCS8			0x14
-#define ODM_RATEMCS9			0x15
-#define ODM_RATEMCS10			0x16
-#define ODM_RATEMCS11			0x17
-#define ODM_RATEMCS12			0x18
-#define ODM_RATEMCS13			0x19
-#define ODM_RATEMCS14			0x1A
-#define ODM_RATEMCS15			0x1B
-#define ODM_RATEMCS16			0x1C
-#define ODM_RATEMCS17			0x1D
-#define ODM_RATEMCS18			0x1E
-#define ODM_RATEMCS19			0x1F
-#define ODM_RATEMCS20			0x20
-#define ODM_RATEMCS21			0x21
-#define ODM_RATEMCS22			0x22
-#define ODM_RATEMCS23			0x23
-#define ODM_RATEMCS24			0x24
-#define ODM_RATEMCS25			0x25
-#define ODM_RATEMCS26			0x26
-#define ODM_RATEMCS27			0x27
-#define ODM_RATEMCS28			0x28
-#define ODM_RATEMCS29			0x29
-#define ODM_RATEMCS30			0x2A
-#define ODM_RATEMCS31			0x2B
-#define ODM_RATEVHTSS1MCS0		0x2C
-#define ODM_RATEVHTSS1MCS1		0x2D
-#define ODM_RATEVHTSS1MCS2		0x2E
-#define ODM_RATEVHTSS1MCS3		0x2F
-#define ODM_RATEVHTSS1MCS4		0x30
-#define ODM_RATEVHTSS1MCS5		0x31
-#define ODM_RATEVHTSS1MCS6		0x32
-#define ODM_RATEVHTSS1MCS7		0x33
-#define ODM_RATEVHTSS1MCS8		0x34
-#define ODM_RATEVHTSS1MCS9		0x35
-#define ODM_RATEVHTSS2MCS0		0x36
-#define ODM_RATEVHTSS2MCS1		0x37
-#define ODM_RATEVHTSS2MCS2		0x38
-#define ODM_RATEVHTSS2MCS3		0x39
-#define ODM_RATEVHTSS2MCS4		0x3A
-#define ODM_RATEVHTSS2MCS5		0x3B
-#define ODM_RATEVHTSS2MCS6		0x3C
-#define ODM_RATEVHTSS2MCS7		0x3D
-#define ODM_RATEVHTSS2MCS8		0x3E
-#define ODM_RATEVHTSS2MCS9		0x3F
-#define ODM_RATEVHTSS3MCS0		0x40
-#define ODM_RATEVHTSS3MCS1		0x41
-#define ODM_RATEVHTSS3MCS2		0x42
-#define ODM_RATEVHTSS3MCS3		0x43
-#define ODM_RATEVHTSS3MCS4		0x44
-#define ODM_RATEVHTSS3MCS5		0x45
-#define ODM_RATEVHTSS3MCS6		0x46
-#define ODM_RATEVHTSS3MCS7		0x47
-#define ODM_RATEVHTSS3MCS8		0x48
-#define ODM_RATEVHTSS3MCS9		0x49
-#define ODM_RATEVHTSS4MCS0		0x4A
-#define ODM_RATEVHTSS4MCS1		0x4B
-#define ODM_RATEVHTSS4MCS2		0x4C
-#define ODM_RATEVHTSS4MCS3		0x4D
-#define ODM_RATEVHTSS4MCS4		0x4E
-#define ODM_RATEVHTSS4MCS5		0x4F
-#define ODM_RATEVHTSS4MCS6		0x50
-#define ODM_RATEVHTSS4MCS7		0x51
-#define ODM_RATEVHTSS4MCS8		0x52
-#define ODM_RATEVHTSS4MCS9		0x53
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
-#else
-	#if (RTL8192E_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEMCS15+1)
-	#elif (RTL8723B_SUPPORT == 1) || (RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) 
-		#define ODM_NUM_RATE_IDX (ODM_RATEMCS7+1)
-	#elif (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) 
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS1MCS9+1)
-	#elif (RTL8812A_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS2MCS9+1)
-	#elif(RTL8814A_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS3MCS9+1)
-	#else
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
-	#endif
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#define CONFIG_SFW_SUPPORTED
-#endif
-
-//1 ============================================================
-//1  enumeration
-//1 ============================================================
-
-
-//	ODM_CMNINFO_INTERFACE
-typedef enum tag_ODM_Support_Interface_Definition
-{
-	ODM_ITRF_PCIE 	=	0x1,
-	ODM_ITRF_USB 	=	0x2,
-	ODM_ITRF_SDIO 	=	0x4,
-	ODM_ITRF_ALL 	=	0x7,
-}ODM_INTERFACE_E;
-
-// ODM_CMNINFO_IC_TYPE
-typedef enum tag_ODM_Support_IC_Type_Definition
-{
-	ODM_RTL8192S 	=	BIT0,
-	ODM_RTL8192C 	=	BIT1,
-	ODM_RTL8192D 	=	BIT2,
-	ODM_RTL8723A 	=	BIT3,
-	ODM_RTL8188E 	=	BIT4,
-	ODM_RTL8812 	=	BIT5,
-	ODM_RTL8821 	=	BIT6,
-	ODM_RTL8192E 	=	BIT7,	
-	ODM_RTL8723B	=	BIT8,
-	ODM_RTL8814A	=	BIT9,	
-	ODM_RTL8881A 	=	BIT10,
-	ODM_RTL8821B 	=	BIT11,
-	ODM_RTL8822B 	=	BIT12,
-	ODM_RTL8703B 	=	BIT13,
-	ODM_RTL8195A	=	BIT14,
-	ODM_RTL8188F 	=	BIT15
-}ODM_IC_TYPE_E;
-
-
-
-
-#define ODM_IC_11N_SERIES		(ODM_RTL8192S|ODM_RTL8192C|ODM_RTL8192D|ODM_RTL8723A|ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8723B|ODM_RTL8703B|ODM_RTL8188F)
-#define ODM_IC_11AC_SERIES		(ODM_RTL8812|ODM_RTL8821|ODM_RTL8814A|ODM_RTL8881A|ODM_RTL8821B|ODM_RTL8822B)
-#define ODM_IC_TXBF_SUPPORT		(ODM_RTL8192E|ODM_RTL8812|ODM_RTL8821|ODM_RTL8814A|ODM_RTL8881A|ODM_RTL8822B)
-#define ODM_IC_11N_GAIN_IDX_EDCCA		(ODM_RTL8195A|ODM_RTL8703B|ODM_RTL8188F)
-#define ODM_IC_11AC_GAIN_IDX_EDCCA		(ODM_RTL8814A|ODM_RTL8822B)
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-#ifdef RTK_AC_SUPPORT
-#define ODM_IC_11AC_SERIES_SUPPORT		1
-#else
-#define ODM_IC_11AC_SERIES_SUPPORT		0
-#endif
-
-#define ODM_IC_11N_SERIES_SUPPORT			1
-#define ODM_CONFIG_BT_COEXIST				0
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-#define ODM_IC_11AC_SERIES_SUPPORT		1
-#define ODM_IC_11N_SERIES_SUPPORT			1
-#define ODM_CONFIG_BT_COEXIST				1
-
-#else 
-
-#if((RTL8192C_SUPPORT == 1) || (RTL8192D_SUPPORT == 1) || (RTL8723A_SUPPORT == 1) || (RTL8188E_SUPPORT == 1) ||\
-(RTL8723B_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8195A_SUPPORT == 1) || (RTL8703B_SUPPORT == 1) || \
-(RTL8188F_SUPPORT == 1))
-#define ODM_IC_11N_SERIES_SUPPORT			1
-#define ODM_IC_11AC_SERIES_SUPPORT		0
-#else
-#define ODM_IC_11N_SERIES_SUPPORT			0
-#define ODM_IC_11AC_SERIES_SUPPORT		1
-#endif
-
-#ifdef CONFIG_BT_COEXIST
-#define ODM_CONFIG_BT_COEXIST				1
-#else
-#define ODM_CONFIG_BT_COEXIST				0
-#endif
-
-#endif
-
-
-//ODM_CMNINFO_CUT_VER
-typedef enum tag_ODM_Cut_Version_Definition
-{
-	ODM_CUT_A 		=	0,
-	ODM_CUT_B 		=	1,
-	ODM_CUT_C 		=	2,
-	ODM_CUT_D 		=	3,
-	ODM_CUT_E 		=	4,
-	ODM_CUT_F 		=	5,
-
-	ODM_CUT_I 		=	8,
-	ODM_CUT_J 		=	9,
-	ODM_CUT_K 		=	10,	
-	ODM_CUT_TEST 	=	15,
-}ODM_CUT_VERSION_E;
-
-// ODM_CMNINFO_FAB_VER
-typedef enum tag_ODM_Fab_Version_Definition
-{
-	ODM_TSMC 	=	0,
-	ODM_UMC 	=	1,
-}ODM_FAB_E;
-
-// ODM_CMNINFO_RF_TYPE
-//
-// For example 1T2R (A+AB = BIT0|BIT4|BIT5)
-//
-typedef enum tag_ODM_RF_Path_Bit_Definition
-{
-	ODM_RF_A = BIT0,
-	ODM_RF_B = BIT1,
-	ODM_RF_C = BIT2,
-	ODM_RF_D = BIT3,
-}ODM_RF_PATH_E;
-
-typedef enum tag_PHYDM_RF_TX_NUM {
-	ODM_1T	=	1,
-	ODM_2T	=	2,
-	ODM_3T	=	3,
-	ODM_4T	=	4,
-} ODM_RF_TX_NUM_E;
-
-typedef enum tag_ODM_RF_Type_Definition {
-	ODM_1T1R,
-	ODM_1T2R,
-	ODM_2T2R,
-	ODM_2T2R_GREEN,
-	ODM_2T3R,
-	ODM_2T4R,
-	ODM_3T3R,
-	ODM_3T4R,
-	ODM_4T4R,
-	ODM_XTXR
-}ODM_RF_TYPE_E;
-
-
-typedef enum tag_ODM_MAC_PHY_Mode_Definition
-{
-	ODM_SMSP	= 0,
-	ODM_DMSP	= 1,
-	ODM_DMDP	= 2,
-}ODM_MAC_PHY_MODE_E;
-
-
-typedef enum tag_BT_Coexist_Definition
-{	
-	ODM_BT_BUSY 		= 1,
-	ODM_BT_ON 			= 2,
-	ODM_BT_OFF 		= 3,
-	ODM_BT_NONE 		= 4,
-}ODM_BT_COEXIST_E;
-
-// ODM_CMNINFO_OP_MODE
-typedef enum tag_Operation_Mode_Definition
-{
-	ODM_NO_LINK 		= BIT0,
-	ODM_LINK 			= BIT1,
-	ODM_SCAN 			= BIT2,
-	ODM_POWERSAVE 	= BIT3,
-	ODM_AP_MODE 		= BIT4,
-	ODM_CLIENT_MODE	= BIT5,
-	ODM_AD_HOC 		= BIT6,
-	ODM_WIFI_DIRECT	= BIT7,
-	ODM_WIFI_DISPLAY	= BIT8,
-}ODM_OPERATION_MODE_E;
-
-// ODM_CMNINFO_WM_MODE
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-typedef enum tag_Wireless_Mode_Definition
-{
-	ODM_WM_UNKNOW	= 0x0,
-	ODM_WM_B			= BIT0,
-	ODM_WM_G			= BIT1,
-	ODM_WM_A			= BIT2,
-	ODM_WM_N24G		= BIT3,
-	ODM_WM_N5G		= BIT4,
-	ODM_WM_AUTO		= BIT5,
-	ODM_WM_AC		= BIT6,
-}ODM_WIRELESS_MODE_E;
-#else
-typedef enum tag_Wireless_Mode_Definition
-{
-	ODM_WM_UNKNOWN	= 0x00,/*0x0*/
-	ODM_WM_A			= BIT0, /* 0x1*/
-	ODM_WM_B			= BIT1, /* 0x2*/
-	ODM_WM_G			= BIT2,/* 0x4*/
-	ODM_WM_AUTO		= BIT3,/* 0x8*/
-	ODM_WM_N24G		= BIT4,/* 0x10*/
-	ODM_WM_N5G		= BIT5,/* 0x20*/
-	ODM_WM_AC_5G		= BIT6,/* 0x40*/
-	ODM_WM_AC_24G	= BIT7,/* 0x80*/
-	ODM_WM_AC_ONLY	= BIT8,/* 0x100*/
-	ODM_WM_MAX		= BIT11/* 0x800*/
-
-}ODM_WIRELESS_MODE_E;
-#endif
-
-// ODM_CMNINFO_BAND
-typedef enum tag_Band_Type_Definition
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	ODM_BAND_2_4G 	= BIT0,
-	ODM_BAND_5G 		= BIT1,
-#else
-	ODM_BAND_2_4G = 0,
-	ODM_BAND_5G,
-	ODM_BAND_ON_BOTH,
-	ODM_BANDMAX
-#endif
-}ODM_BAND_TYPE_E;
-
-
-// ODM_CMNINFO_SEC_CHNL_OFFSET
-typedef enum tag_Secondary_Channel_Offset_Definition
-{
-	ODM_DONT_CARE 	= 0,
-	ODM_BELOW 		= 1,
-	ODM_ABOVE 			= 2
-}ODM_SEC_CHNL_OFFSET_E;
-
-// ODM_CMNINFO_SEC_MODE
-typedef enum tag_Security_Definition
-{
-	ODM_SEC_OPEN 			= 0,
-	ODM_SEC_WEP40 		= 1,
-	ODM_SEC_TKIP 			= 2,
-	ODM_SEC_RESERVE 		= 3,
-	ODM_SEC_AESCCMP 		= 4,
-	ODM_SEC_WEP104 		= 5,
-	ODM_WEP_WPA_MIXED    = 6, // WEP + WPA
-	ODM_SEC_SMS4 			= 7,
-}ODM_SECURITY_E;
-
-// ODM_CMNINFO_BW
-typedef enum tag_Bandwidth_Definition
-{	
-	ODM_BW20M 		= 0,
-	ODM_BW40M 		= 1,
-	ODM_BW80M 		= 2,
-	ODM_BW160M 		= 3,
-	ODM_BW5M			= 4,
-	ODM_BW10M			= 5,
-	ODM_BW_MAX		= 6
-}ODM_BW_E;
-
-// ODM_CMNINFO_CHNL
-
-// ODM_CMNINFO_BOARD_TYPE
-typedef enum tag_Board_Definition
-{
-    ODM_BOARD_DEFAULT  	= 0, 	  // The DEFAULT case.
-    ODM_BOARD_MINICARD  = BIT(0), // 0 = non-mini card, 1= mini card.
-    ODM_BOARD_SLIM      = BIT(1), // 0 = non-slim card, 1 = slim card
-    ODM_BOARD_BT        = BIT(2), // 0 = without BT card, 1 = with BT
-    ODM_BOARD_EXT_PA    = BIT(3), // 0 = no 2G ext-PA, 1 = existing 2G ext-PA
-    ODM_BOARD_EXT_LNA   = BIT(4), // 0 = no 2G ext-LNA, 1 = existing 2G ext-LNA
-    ODM_BOARD_EXT_TRSW  = BIT(5), // 0 = no ext-TRSW, 1 = existing ext-TRSW
-    ODM_BOARD_EXT_PA_5G	= BIT(6), // 0 = no 5G ext-PA, 1 = existing 5G ext-PA
-    ODM_BOARD_EXT_LNA_5G= BIT(7), // 0 = no 5G ext-LNA, 1 = existing 5G ext-LNA
-}ODM_BOARD_TYPE_E;
-
-typedef enum tag_ODM_Package_Definition
-{
-    ODM_PACKAGE_DEFAULT  	 = 0, 	  
-    ODM_PACKAGE_QFN68        = BIT(0), 
-    ODM_PACKAGE_TFBGA90      = BIT(1), 
-    ODM_PACKAGE_TFBGA79      = BIT(2),	
-}ODM_Package_TYPE_E;
-
-typedef enum tag_ODM_TYPE_GPA_Definition {
-	TYPE_GPA0 = 0x0000,
-	TYPE_GPA1 = 0x0055,
-	TYPE_GPA2 = 0x00AA,
-	TYPE_GPA3 = 0x00FF,
-	TYPE_GPA4 = 0x5500,
-	TYPE_GPA5 = 0x5555,
-	TYPE_GPA6 = 0x55AA,
-	TYPE_GPA7 = 0x55FF,
-	TYPE_GPA8 = 0xAA00,
-	TYPE_GPA9 = 0xAA55,
-	TYPE_GPA10 = 0xAAAA,
-	TYPE_GPA11 = 0xAAFF,
-	TYPE_GPA12 = 0xFF00,
-	TYPE_GPA13 = 0xFF55,
-	TYPE_GPA14 = 0xFFAA,
-	TYPE_GPA15 = 0xFFFF,
-}ODM_TYPE_GPA_E;
-
-typedef enum tag_ODM_TYPE_APA_Definition {
-	TYPE_APA0 = 0x0000,
-	TYPE_APA1 = 0x0055,
-	TYPE_APA2 = 0x00AA,
-	TYPE_APA3 = 0x00FF,
-	TYPE_APA4 = 0x5500,
-	TYPE_APA5 = 0x5555,
-	TYPE_APA6 = 0x55AA,
-	TYPE_APA7 = 0x55FF,
-	TYPE_APA8 = 0xAA00,
-	TYPE_APA9 = 0xAA55,
-	TYPE_APA10 = 0xAAAA,
-	TYPE_APA11 = 0xAAFF,
-	TYPE_APA12 = 0xFF00,
-	TYPE_APA13 = 0xFF55,
-	TYPE_APA14 = 0xFFAA,
-	TYPE_APA15 = 0xFFFF,
-}ODM_TYPE_APA_E;
-
-typedef enum tag_ODM_TYPE_GLNA_Definition {
-	TYPE_GLNA0 = 0x0000,
-	TYPE_GLNA1 = 0x0055,
-	TYPE_GLNA2 = 0x00AA,
-	TYPE_GLNA3 = 0x00FF,
-	TYPE_GLNA4 = 0x5500,
-	TYPE_GLNA5 = 0x5555,
-	TYPE_GLNA6 = 0x55AA,
-	TYPE_GLNA7 = 0x55FF,
-	TYPE_GLNA8 = 0xAA00,
-	TYPE_GLNA9 = 0xAA55,
-	TYPE_GLNA10 = 0xAAAA,
-	TYPE_GLNA11 = 0xAAFF,
-	TYPE_GLNA12 = 0xFF00,
-	TYPE_GLNA13 = 0xFF55,
-	TYPE_GLNA14 = 0xFFAA,
-	TYPE_GLNA15 = 0xFFFF,
-}ODM_TYPE_GLNA_E;
-
-typedef enum tag_ODM_TYPE_ALNA_Definition {
-	TYPE_ALNA0 = 0x0000,
-	TYPE_ALNA1 = 0x0055,
-	TYPE_ALNA2 = 0x00AA,
-	TYPE_ALNA3 = 0x00FF,
-	TYPE_ALNA4 = 0x5500,
-	TYPE_ALNA5 = 0x5555,
-	TYPE_ALNA6 = 0x55AA,
-	TYPE_ALNA7 = 0x55FF,
-	TYPE_ALNA8 = 0xAA00,
-	TYPE_ALNA9 = 0xAA55,
-	TYPE_ALNA10 = 0xAAAA,
-	TYPE_ALNA11 = 0xAAFF,
-	TYPE_ALNA12 = 0xFF00,
-	TYPE_ALNA13 = 0xFF55,
-	TYPE_ALNA14 = 0xFFAA,
-	TYPE_ALNA15 = 0xFFFF,
-}ODM_TYPE_ALNA_E;
-
-
-typedef enum _ODM_RF_RADIO_PATH {
-    ODM_RF_PATH_A = 0,   //Radio Path A
-    ODM_RF_PATH_B = 1,   //Radio Path B
-    ODM_RF_PATH_C = 2,   //Radio Path C
-    ODM_RF_PATH_D = 3,   //Radio Path D
-    ODM_RF_PATH_AB,
-    ODM_RF_PATH_AC,
-    ODM_RF_PATH_AD,
-    ODM_RF_PATH_BC,
-    ODM_RF_PATH_BD,
-    ODM_RF_PATH_CD,
-    ODM_RF_PATH_ABC,
-    ODM_RF_PATH_ACD,
-    ODM_RF_PATH_BCD,
-    ODM_RF_PATH_ABCD,
-  //  ODM_RF_PATH_MAX,    //Max RF number 90 support
-} ODM_RF_RADIO_PATH_E, *PODM_RF_RADIO_PATH_E;
-
-typedef enum _ODM_PARAMETER_INIT {
-	ODM_PRE_SETTING = 0,
-	ODM_POST_SETTING = 1,
-} ODM_PARAMETER_INIT_E;
-
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDMPREDEFINE_H__
+#define    __PHYDMPREDEFINE_H__
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define PHYDM_CODE_BASE		"PHYDM_V024"
+#define PHYDM_RELEASE_DATE		"20171213"
+
+/*PHYDM API status*/
+#define	PHYDM_SET_FAIL		0
+#define	PHYDM_SET_SUCCESS	1
+#define	PHYDM_SET_NO_NEED	3
+
+/*PHYDM Set/Revert*/
+#define	PHYDM_SET				1
+#define	PHYDM_REVERT			2
+
+/* Max path of IC */
+/*N-IC*/
+#define MAX_PATH_NUM_8188E		1
+#define MAX_PATH_NUM_8188F		1
+#define MAX_PATH_NUM_8710B		1
+#define MAX_PATH_NUM_8723B		1
+#define MAX_PATH_NUM_8723D		1
+#define MAX_PATH_NUM_8703B		1
+#define MAX_PATH_NUM_8192E		2
+#define MAX_PATH_NUM_8192F		2
+#define MAX_PATH_NUM_8197F		2
+#define MAX_PATH_NUM_8198F		4
+/*AC-IC*/
+#define MAX_PATH_NUM_8821A		1
+#define MAX_PATH_NUM_8881A		1
+#define MAX_PATH_NUM_8821C		1
+#define MAX_PATH_NUM_8195B		1
+#define MAX_PATH_NUM_8812A		2
+#define MAX_PATH_NUM_8822B		2
+#define MAX_PATH_NUM_8822C		2
+#define MAX_PATH_NUM_8814A		4
+#define MAX_PATH_NUM_8814B		4
+#define MAX_PATH_NUM_8814C		4
+
+/* Max RF path */
+#define PHYDM_MAX_RF_PATH_N		2	/*For old N-series IC*/
+#define PHYDM_MAX_RF_PATH			4
+
+/* number of entry */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	#ifdef DM_ODM_CE_MAC80211
+		/* defined in wifi.h (32+1) */
+	#else
+		#define	ASSOCIATE_ENTRY_NUM					MACID_NUM_SW_LIMIT  /* Max size of asoc_entry[].*/
+	#endif
+	#define	ODM_ASSOCIATE_ENTRY_NUM				ASSOCIATE_ENTRY_NUM
+#elif(DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	#define ASSOCIATE_ENTRY_NUM					NUM_STAT
+	#define	ODM_ASSOCIATE_ENTRY_NUM				(ASSOCIATE_ENTRY_NUM+1)
+#else
+	#define ODM_ASSOCIATE_ENTRY_NUM				((ASSOCIATE_ENTRY_NUM*3)+1)
+#endif
+
+/* -----MGN rate--------------------------------- */
+
+enum ODM_MGN_RATE {
+	ODM_MGN_1M		= 0x02,
+	ODM_MGN_2M		= 0x04,
+	ODM_MGN_5_5M		= 0x0B,
+	ODM_MGN_6M		= 0x0C,
+	ODM_MGN_9M		= 0x12,
+	ODM_MGN_11M		= 0x16,
+	ODM_MGN_12M		= 0x18,
+	ODM_MGN_18M		= 0x24,
+	ODM_MGN_24M		= 0x30,
+	ODM_MGN_36M		= 0x48,
+	ODM_MGN_48M		= 0x60,
+	ODM_MGN_54M		= 0x6C,
+	ODM_MGN_MCS32	= 0x7F,
+	ODM_MGN_MCS0		= 0x80,
+	ODM_MGN_MCS1,
+	ODM_MGN_MCS2,
+	ODM_MGN_MCS3,
+	ODM_MGN_MCS4,
+	ODM_MGN_MCS5,
+	ODM_MGN_MCS6,
+	ODM_MGN_MCS7		= 0x87,
+	ODM_MGN_MCS8,
+	ODM_MGN_MCS9,
+	ODM_MGN_MCS10,
+	ODM_MGN_MCS11,
+	ODM_MGN_MCS12,
+	ODM_MGN_MCS13,
+	ODM_MGN_MCS14,
+	ODM_MGN_MCS15,
+	ODM_MGN_MCS16	= 0x90,
+	ODM_MGN_MCS17,
+	ODM_MGN_MCS18,
+	ODM_MGN_MCS19,
+	ODM_MGN_MCS20,
+	ODM_MGN_MCS21,
+	ODM_MGN_MCS22,
+	ODM_MGN_MCS23,
+	ODM_MGN_MCS24	= 0x98,
+	ODM_MGN_MCS25,
+	ODM_MGN_MCS26,
+	ODM_MGN_MCS27,
+	ODM_MGN_MCS28,
+	ODM_MGN_MCS29,
+	ODM_MGN_MCS30,
+	ODM_MGN_MCS31,
+	ODM_MGN_VHT1SS_MCS0	= 0xa0,
+	ODM_MGN_VHT1SS_MCS1,
+	ODM_MGN_VHT1SS_MCS2,
+	ODM_MGN_VHT1SS_MCS3,
+	ODM_MGN_VHT1SS_MCS4,
+	ODM_MGN_VHT1SS_MCS5,
+	ODM_MGN_VHT1SS_MCS6,
+	ODM_MGN_VHT1SS_MCS7,
+	ODM_MGN_VHT1SS_MCS8,
+	ODM_MGN_VHT1SS_MCS9,
+	ODM_MGN_VHT2SS_MCS0	= 0xaa,
+	ODM_MGN_VHT2SS_MCS1	= 0xab,
+	ODM_MGN_VHT2SS_MCS2,
+	ODM_MGN_VHT2SS_MCS3,
+	ODM_MGN_VHT2SS_MCS4,
+	ODM_MGN_VHT2SS_MCS5	= 0xaf,
+	ODM_MGN_VHT2SS_MCS6	= 0xb0,
+	ODM_MGN_VHT2SS_MCS7,
+	ODM_MGN_VHT2SS_MCS8,
+	ODM_MGN_VHT2SS_MCS9	= 0xb3,
+	ODM_MGN_VHT3SS_MCS0	= 0xb4,
+	ODM_MGN_VHT3SS_MCS1,
+	ODM_MGN_VHT3SS_MCS2,
+	ODM_MGN_VHT3SS_MCS3,
+	ODM_MGN_VHT3SS_MCS4,
+	ODM_MGN_VHT3SS_MCS5,
+	ODM_MGN_VHT3SS_MCS6,
+	ODM_MGN_VHT3SS_MCS7	= 0xbb,
+	ODM_MGN_VHT3SS_MCS8	= 0xbc,
+	ODM_MGN_VHT3SS_MCS9	= 0xbd,
+	ODM_MGN_VHT4SS_MCS0	= 0xbe,
+	ODM_MGN_VHT4SS_MCS1,
+	ODM_MGN_VHT4SS_MCS2,
+	ODM_MGN_VHT4SS_MCS3,
+	ODM_MGN_VHT4SS_MCS4,
+	ODM_MGN_VHT4SS_MCS5,
+	ODM_MGN_VHT4SS_MCS6,
+	ODM_MGN_VHT4SS_MCS7,
+	ODM_MGN_VHT4SS_MCS8,
+	ODM_MGN_VHT4SS_MCS9	= 0xc7,
+	ODM_MGN_UNKNOWN
+};
+
+#define	ODM_MGN_MCS0_SG		0xc0
+#define	ODM_MGN_MCS1_SG		0xc1
+#define	ODM_MGN_MCS2_SG		0xc2
+#define	ODM_MGN_MCS3_SG		0xc3
+#define	ODM_MGN_MCS4_SG		0xc4
+#define	ODM_MGN_MCS5_SG		0xc5
+#define	ODM_MGN_MCS6_SG		0xc6
+#define	ODM_MGN_MCS7_SG		0xc7
+#define	ODM_MGN_MCS8_SG		0xc8
+#define	ODM_MGN_MCS9_SG		0xc9
+#define	ODM_MGN_MCS10_SG		0xca
+#define	ODM_MGN_MCS11_SG		0xcb
+#define	ODM_MGN_MCS12_SG		0xcc
+#define	ODM_MGN_MCS13_SG		0xcd
+#define	ODM_MGN_MCS14_SG		0xce
+#define	ODM_MGN_MCS15_SG		0xcf
+
+/* -----DESC rate--------------------------------- */
+
+#define ODM_RATEMCS15_SG		0x1c
+#define ODM_RATEMCS32			0x20
+
+
+enum phydm_ctrl_info_rate {
+	ODM_RATE1M			= 0x00,
+	ODM_RATE2M			= 0x01,
+	ODM_RATE5_5M			= 0x02,
+	ODM_RATE11M			= 0x03,
+/* OFDM Rates, TxHT = 0 */
+	ODM_RATE6M			= 0x04,
+	ODM_RATE9M			= 0x05,
+	ODM_RATE12M			= 0x06,
+	ODM_RATE18M			= 0x07,
+	ODM_RATE24M			= 0x08,
+	ODM_RATE36M			= 0x09,
+	ODM_RATE48M			= 0x0A,
+	ODM_RATE54M			= 0x0B,
+/* MCS Rates, TxHT = 1 */
+	ODM_RATEMCS0			= 0x0C,
+	ODM_RATEMCS1			= 0x0D,
+	ODM_RATEMCS2			= 0x0E,
+	ODM_RATEMCS3			= 0x0F,
+	ODM_RATEMCS4			= 0x10,
+	ODM_RATEMCS5			= 0x11,
+	ODM_RATEMCS6			= 0x12,
+	ODM_RATEMCS7			= 0x13,
+	ODM_RATEMCS8			= 0x14,
+	ODM_RATEMCS9			= 0x15,
+	ODM_RATEMCS10			= 0x16,
+	ODM_RATEMCS11			= 0x17,
+	ODM_RATEMCS12			= 0x18,
+	ODM_RATEMCS13			= 0x19,
+	ODM_RATEMCS14			= 0x1A,
+	ODM_RATEMCS15			= 0x1B,
+	ODM_RATEMCS16			= 0x1C,
+	ODM_RATEMCS17			= 0x1D,
+	ODM_RATEMCS18			= 0x1E,
+	ODM_RATEMCS19			= 0x1F,
+	ODM_RATEMCS20			= 0x20,
+	ODM_RATEMCS21			= 0x21,
+	ODM_RATEMCS22			= 0x22,
+	ODM_RATEMCS23			= 0x23,
+	ODM_RATEMCS24			= 0x24,
+	ODM_RATEMCS25			= 0x25,
+	ODM_RATEMCS26			= 0x26,
+	ODM_RATEMCS27			= 0x27,
+	ODM_RATEMCS28			= 0x28,
+	ODM_RATEMCS29			= 0x29,
+	ODM_RATEMCS30			= 0x2A,
+	ODM_RATEMCS31			= 0x2B,
+	ODM_RATEVHTSS1MCS0	= 0x2C,
+	ODM_RATEVHTSS1MCS1	= 0x2D,
+	ODM_RATEVHTSS1MCS2	= 0x2E,
+	ODM_RATEVHTSS1MCS3	= 0x2F,
+	ODM_RATEVHTSS1MCS4	= 0x30,
+	ODM_RATEVHTSS1MCS5	= 0x31,
+	ODM_RATEVHTSS1MCS6	= 0x32,
+	ODM_RATEVHTSS1MCS7	= 0x33,
+	ODM_RATEVHTSS1MCS8	= 0x34,
+	ODM_RATEVHTSS1MCS9	= 0x35,
+	ODM_RATEVHTSS2MCS0	= 0x36,
+	ODM_RATEVHTSS2MCS1	= 0x37,
+	ODM_RATEVHTSS2MCS2	= 0x38,
+	ODM_RATEVHTSS2MCS3	= 0x39,
+	ODM_RATEVHTSS2MCS4	= 0x3A,
+	ODM_RATEVHTSS2MCS5	= 0x3B,
+	ODM_RATEVHTSS2MCS6	= 0x3C,
+	ODM_RATEVHTSS2MCS7	= 0x3D,
+	ODM_RATEVHTSS2MCS8	= 0x3E,
+	ODM_RATEVHTSS2MCS9	= 0x3F,
+	ODM_RATEVHTSS3MCS0	= 0x40,
+	ODM_RATEVHTSS3MCS1	= 0x41,
+	ODM_RATEVHTSS3MCS2	= 0x42,
+	ODM_RATEVHTSS3MCS3	= 0x43,
+	ODM_RATEVHTSS3MCS4	= 0x44,
+	ODM_RATEVHTSS3MCS5	= 0x45,
+	ODM_RATEVHTSS3MCS6	= 0x46,
+	ODM_RATEVHTSS3MCS7	= 0x47,
+	ODM_RATEVHTSS3MCS8	= 0x48,
+	ODM_RATEVHTSS3MCS9	= 0x49,
+	ODM_RATEVHTSS4MCS0	= 0x4A,
+	ODM_RATEVHTSS4MCS1	= 0x4B,
+	ODM_RATEVHTSS4MCS2	= 0x4C,
+	ODM_RATEVHTSS4MCS3	= 0x4D,
+	ODM_RATEVHTSS4MCS4	= 0x4E,
+	ODM_RATEVHTSS4MCS5	= 0x4F,
+	ODM_RATEVHTSS4MCS6	= 0x50,
+	ODM_RATEVHTSS4MCS7	= 0x51,
+	ODM_RATEVHTSS4MCS8	= 0x52,
+	ODM_RATEVHTSS4MCS9	= 0x53,
+};
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
+#else
+	#if (RTL8192E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEMCS15+1)
+	#elif (RTL8723B_SUPPORT == 1) || (RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEMCS7+1)
+	#elif (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS1MCS9+1)
+	#elif (RTL8812A_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS2MCS9+1)
+	#elif (RTL8814A_SUPPORT == 1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS3MCS9+1)
+	#else
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
+	#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define CONFIG_SFW_SUPPORTED
+#endif
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+/*	ODM_CMNINFO_INTERFACE */
+enum odm_interface {
+	ODM_ITRF_PCIE	=	0x1,
+	ODM_ITRF_USB	=	0x2,
+	ODM_ITRF_SDIO	=	0x4,
+	ODM_ITRF_ALL	=	0x7,
+};
+
+
+/*========[Run time IC flag] ===============================================================================]*/
+
+enum phydm_ic {
+	ODM_RTL8188E	=	BIT(0),
+	ODM_RTL8812	=	BIT(1),
+	ODM_RTL8821	=	BIT(2),
+	ODM_RTL8192E	=	BIT(3),
+	ODM_RTL8723B	=	BIT(4),
+	ODM_RTL8814A	=	BIT(5),
+	ODM_RTL8881A	=	BIT(6),
+	ODM_RTL8822B	=	BIT(7),
+	ODM_RTL8703B	=	BIT(8),
+	ODM_RTL8195A	=	BIT(9),
+	ODM_RTL8188F	=	BIT(10),
+	ODM_RTL8723D	=	BIT(11),
+	ODM_RTL8197F	=	BIT(12),
+	ODM_RTL8821C	=	BIT(13),
+	ODM_RTL8814B	=	BIT(14),
+	ODM_RTL8198F	=	BIT(15),
+	ODM_RTL8710B	=	BIT(16),
+	ODM_RTL8192F	=	BIT(17),
+	ODM_RTL8822C	=	BIT(18),
+	ODM_RTL8195B	=	BIT(19)
+};
+
+#define ODM_IC_N_1SS	(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8723B | ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8195A | ODM_RTL8710B)
+#define ODM_IC_N_2SS	(ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8192F)
+#define ODM_IC_N_3SS	0
+#define ODM_IC_N_4SS	(ODM_RTL8198F)
+
+#define ODM_IC_AC_1SS	(ODM_RTL8881A | ODM_RTL8821 | ODM_RTL8821C | ODM_RTL8195B)
+#define ODM_IC_AC_2SS	(ODM_RTL8812 | ODM_RTL8822B | ODM_RTL8822C)
+#define ODM_IC_AC_3SS	0
+#define ODM_IC_AC_4SS	(ODM_RTL8814A | ODM_RTL8814B)
+
+/*====the following macro DO NOT need to update when adding a new IC======= */
+#define ODM_IC_1SS	(ODM_IC_N_1SS | ODM_IC_AC_1SS)
+#define ODM_IC_2SS	(ODM_IC_N_2SS | ODM_IC_AC_2SS)
+#define ODM_IC_3SS	(ODM_IC_N_3SS | ODM_IC_AC_3SS)
+#define ODM_IC_4SS	(ODM_IC_N_4SS | ODM_IC_AC_4SS)
+
+#define PHYDM_IC_ABOVE_1SS	(ODM_IC_1SS | ODM_IC_2SS | ODM_IC_3SS | ODM_IC_4SS)
+#define PHYDM_IC_ABOVE_2SS	(ODM_IC_2SS | ODM_IC_3SS | ODM_IC_4SS)
+#define PHYDM_IC_ABOVE_3SS	(ODM_IC_3SS | ODM_IC_4SS)
+#define PHYDM_IC_ABOVE_4SS	ODM_IC_4SS
+
+#define ODM_IC_11N_SERIES		(ODM_IC_N_1SS | ODM_IC_N_2SS | ODM_IC_N_3SS | ODM_IC_N_4SS)
+#define ODM_IC_11AC_SERIES		(ODM_IC_AC_1SS | ODM_IC_AC_2SS | ODM_IC_AC_3SS | ODM_IC_AC_4SS)
+/*====================================================*/
+
+#define ODM_IC_11AC_1_SERIES			(ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)
+#define ODM_IC_11AC_2_SERIES			(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8195B)
+/*[EDCCA]*/
+#define ODM_IC_11N_GAIN_IDX_EDCCA	(ODM_RTL8195A | ODM_RTL8703B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8197F | ODM_RTL8710B)
+#define ODM_IC_11AC_GAIN_IDX_EDCCA	(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)
+#define ODM_IC_GAIN_IDX_EDCCA			(ODM_IC_11N_GAIN_IDX_EDCCA | ODM_IC_11AC_GAIN_IDX_EDCCA)
+/*[Phy status type]*/
+#define PHYSTS_2ND_TYPE_IC				(ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B | ODM_RTL8195B)
+#define PHYSTS_3RD_TYPE_IC				(ODM_RTL8198F | ODM_RTL8814B)
+/*[FW Type]*/
+#define PHYDM_IC_8051_SERIES			(ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8703B | ODM_RTL8188F)
+#define PHYDM_IC_3081_SERIES			(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F)
+/*[LA mode]*/
+#define PHYDM_IC_SUPPORT_LA_MODE		(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F)
+/*[BF]*/
+#define ODM_IC_TXBF_SUPPORT			(ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8881A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F)
+#define PHYDM_IC_SUPPORT_MU_BFEE		(ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814B | ODM_RTL8195B | ODM_RTL8198F)
+#define PHYDM_IC_SUPPORT_MU_BFER		(ODM_RTL8822B | ODM_RTL8814B | ODM_RTL8198F)
+
+
+/*========[Compile time IC flag] ===============================================================================]*/
+/*========[AC/N Support] ===========================*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	#ifdef RTK_AC_SUPPORT
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#else
+	#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#endif
+
+	#define ODM_IC_11N_SERIES_SUPPORT			1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#define ODM_IC_11N_SERIES_SUPPORT			1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+
+	#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#define ODM_IC_11N_SERIES_SUPPORT			1
+
+#else /*ODM_CE*/
+
+	#if ((RTL8188E_SUPPORT == 1) || \
+	(RTL8723B_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8195A_SUPPORT == 1) || (RTL8703B_SUPPORT == 1) || \
+	(RTL8188F_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
+		#define ODM_IC_11N_SERIES_SUPPORT			1
+		#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#else
+		#define ODM_IC_11N_SERIES_SUPPORT			0
+		#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#endif
+#endif
+
+/*===IC SS Compile Flag, prepare for code size reduction==============*/
+#if ((RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8723B_SUPPORT == 1) || (RTL8703B_SUPPORT == 1) ||\
+	(RTL8723D_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) ||\
+	(RTL8195A_SUPPORT == 1) || (RTL8710B_SUPPORT == 1) || (RTL8195B_SUPPORT == 1))
+	
+	#define PHYDM_COMPILE_IC_1SS
+#endif
+
+#if ((RTL8192E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
+	#define PHYDM_COMPILE_IC_2SS
+#endif
+
+/*#define PHYDM_COMPILE_IC_3SS*/
+
+#if ((RTL8814B_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8198F_SUPPORT == 1))
+	#define PHYDM_COMPILE_IC_4SS
+#endif
+
+/*==[ABOVE N-SS COMPILE FLAG]=============================*/
+#if (defined(PHYDM_COMPILE_IC_1SS) || defined(PHYDM_COMPILE_IC_2SS) || defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_1SS
+#endif
+
+#if (defined(PHYDM_COMPILE_IC_2SS) || defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_2SS
+#endif
+
+#if (defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_3SS
+#endif
+
+#if (defined(PHYDM_COMPILE_IC_4SS))
+	#define PHYDM_COMPILE_ABOVE_4SS
+#endif
+
+/*========[New Phy-Status Support] =========================================================================]*/
+#if (RTL8824B_SUPPORT == 1)
+	#define CONFIG_PHYSTS_3RD_TYPE		1
+#else
+	#define CONFIG_PHYSTS_3RD_TYPE		0
+#endif
+	
+#if ((RTL8197F_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8710B_SUPPORT == 1) )
+	#define ODM_PHY_STATUS_NEW_TYPE_SUPPORT			1
+#else
+	#define ODM_PHY_STATUS_NEW_TYPE_SUPPORT			0
+#endif
+
+/*==================================================================================================]*/
+
+#if ((RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+#define PHYDM_COMMON_API_SUPPORT
+#endif
+
+
+#define	CCK_RATE_NUM		4
+#define	OFDM_RATE_NUM	8
+
+#define	LEGACY_RATE_NUM	12
+
+#define	HT_RATE_NUM_4SS		32
+#define	VHT_RATE_NUM_4SS		40
+
+#define	HT_RATE_NUM_3SS		24
+#define	VHT_RATE_NUM_3SS		30
+
+#define	HT_RATE_NUM_2SS		16
+#define	VHT_RATE_NUM_2SS		20
+
+#define	HT_RATE_NUM_1SS		8
+#define	VHT_RATE_NUM_1SS		10
+
+#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	#define	HT_RATE_NUM		HT_RATE_NUM_4SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_4SS
+#elif (defined(PHYDM_COMPILE_ABOVE_3SS))
+	#define	HT_RATE_NUM		HT_RATE_NUM_3SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_3SS
+#elif (defined(PHYDM_COMPILE_ABOVE_2SS))
+	#define	HT_RATE_NUM		HT_RATE_NUM_2SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_2SS
+#else
+	#define	HT_RATE_NUM		HT_RATE_NUM_1SS
+	#define	VHT_RATE_NUM		VHT_RATE_NUM_1SS
+#endif
+
+#define	LOW_BW_RATE_NUM	VHT_RATE_NUM
+
+
+/* ODM_CMNINFO_CUT_VER */
+enum odm_cut_version {
+	ODM_CUT_A		=	0,
+	ODM_CUT_B		=	1,
+	ODM_CUT_C		=	2,
+	ODM_CUT_D		=	3,
+	ODM_CUT_E		=	4,
+	ODM_CUT_F		=	5,
+	ODM_CUT_G		=	6,
+	ODM_CUT_H		=	7,
+	ODM_CUT_I		=	8,
+	ODM_CUT_J		=	9,
+	ODM_CUT_K		=	10,
+	ODM_CUT_TEST	=	15,
+};
+
+/* ODM_CMNINFO_FAB_VER */
+enum odm_fab {
+	ODM_TSMC	=	0,
+	ODM_UMC	=	1,
+};
+
+/* 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 */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+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),
+};
+#else
+enum odm_wireless_mode {
+	ODM_WM_UNKNOWN	= 0x00,/*0x0*/
+	ODM_WM_A			= BIT(0), /* 0x1*/
+	ODM_WM_B			= BIT(1), /* 0x2*/
+	ODM_WM_G			= BIT(2),/* 0x4*/
+	ODM_WM_AUTO		= BIT(3),/* 0x8*/
+	ODM_WM_N24G		= BIT(4),/* 0x10*/
+	ODM_WM_N5G		= BIT(5),/* 0x20*/
+	ODM_WM_AC_5G		= BIT(6),/* 0x40*/
+	ODM_WM_AC_24G	= BIT(7),/* 0x80*/
+	ODM_WM_AC_ONLY	= BIT(8),/* 0x100*/
+	ODM_WM_MAX		= BIT(11)/* 0x800*/
+
+};
+#endif
+
+/* ODM_CMNINFO_BAND */
+enum odm_band_type {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	ODM_BAND_2_4G	= BIT(0),
+	ODM_BAND_5G		= BIT(1),
+#else
+	ODM_BAND_2_4G = 0,
+	ODM_BAND_5G,
+	ODM_BAND_ON_BOTH,
+	ODM_BANDMAX
+#endif
+};
+
+
+/* ODM_CMNINFO_SEC_CHNL_OFFSET */
+enum phydm_sec_chnl_offset {
+	PHYDM_DONT_CARE	= 0,
+	PHYDM_BELOW		= 1,
+	PHYDM_ABOVE		= 2
+};
+
+/* ODM_CMNINFO_SEC_MODE */
+enum odm_security {
+	ODM_SEC_OPEN			= 0,
+	ODM_SEC_WEP40		= 1,
+	ODM_SEC_TKIP			= 2,
+	ODM_SEC_RESERVE		= 3,
+	ODM_SEC_AESCCMP		= 4,
+	ODM_SEC_WEP104		= 5,
+	ODM_WEP_WPA_MIXED    = 6, /* WEP + WPA */
+	ODM_SEC_SMS4			= 7,
+};
+
+/* ODM_CMNINFO_CHNL */
+
+/* ODM_CMNINFO_BOARD_TYPE */
+enum odm_board_type {
+	ODM_BOARD_DEFAULT 	= 0,	  /* The DEFAULT case. */
+	ODM_BOARD_MINICARD  = BIT(0), /* 0 = non-mini card, 1= mini card. */
+	ODM_BOARD_SLIM      = BIT(1), /* 0 = non-slim card, 1 = slim card */
+	ODM_BOARD_BT        = BIT(2), /* 0 = without BT card, 1 = with BT */
+	ODM_BOARD_EXT_PA    = BIT(3), /* 0 = no 2G ext-PA, 1 = existing 2G ext-PA */
+	ODM_BOARD_EXT_LNA   = BIT(4), /* 0 = no 2G ext-LNA, 1 = existing 2G ext-LNA */
+	ODM_BOARD_EXT_TRSW  = BIT(5), /* 0 = no ext-TRSW, 1 = existing ext-TRSW */
+	ODM_BOARD_EXT_PA_5G	= BIT(6), /* 0 = no 5G ext-PA, 1 = existing 5G ext-PA */
+	ODM_BOARD_EXT_LNA_5G = BIT(7), /* 0 = no 5G ext-LNA, 1 = existing 5G ext-LNA */
+};
+
+enum odm_package_type {
+	ODM_PACKAGE_DEFAULT	 = 0,
+	ODM_PACKAGE_QFN68        = BIT(0),
+	ODM_PACKAGE_TFBGA90      = BIT(1),
+	ODM_PACKAGE_TFBGA79      = BIT(2),
+};
+
+enum odm_type_gpa {
+	TYPE_GPA0 = 0x0000,
+	TYPE_GPA1 = 0x0055,
+	TYPE_GPA2 = 0x00AA,
+	TYPE_GPA3 = 0x00FF,
+	TYPE_GPA4 = 0x5500,
+	TYPE_GPA5 = 0x5555,
+	TYPE_GPA6 = 0x55AA,
+	TYPE_GPA7 = 0x55FF,
+	TYPE_GPA8 = 0xAA00,
+	TYPE_GPA9 = 0xAA55,
+	TYPE_GPA10 = 0xAAAA,
+	TYPE_GPA11 = 0xAAFF,
+	TYPE_GPA12 = 0xFF00,
+	TYPE_GPA13 = 0xFF55,
+	TYPE_GPA14 = 0xFFAA,
+	TYPE_GPA15 = 0xFFFF,
+};
+
+enum odm_type_apa {
+	TYPE_APA0 = 0x0000,
+	TYPE_APA1 = 0x0055,
+	TYPE_APA2 = 0x00AA,
+	TYPE_APA3 = 0x00FF,
+	TYPE_APA4 = 0x5500,
+	TYPE_APA5 = 0x5555,
+	TYPE_APA6 = 0x55AA,
+	TYPE_APA7 = 0x55FF,
+	TYPE_APA8 = 0xAA00,
+	TYPE_APA9 = 0xAA55,
+	TYPE_APA10 = 0xAAAA,
+	TYPE_APA11 = 0xAAFF,
+	TYPE_APA12 = 0xFF00,
+	TYPE_APA13 = 0xFF55,
+	TYPE_APA14 = 0xFFAA,
+	TYPE_APA15 = 0xFFFF,
+};
+
+enum odm_type_glna {
+	TYPE_GLNA0 = 0x0000,
+	TYPE_GLNA1 = 0x0055,
+	TYPE_GLNA2 = 0x00AA,
+	TYPE_GLNA3 = 0x00FF,
+	TYPE_GLNA4 = 0x5500,
+	TYPE_GLNA5 = 0x5555,
+	TYPE_GLNA6 = 0x55AA,
+	TYPE_GLNA7 = 0x55FF,
+	TYPE_GLNA8 = 0xAA00,
+	TYPE_GLNA9 = 0xAA55,
+	TYPE_GLNA10 = 0xAAAA,
+	TYPE_GLNA11 = 0xAAFF,
+	TYPE_GLNA12 = 0xFF00,
+	TYPE_GLNA13 = 0xFF55,
+	TYPE_GLNA14 = 0xFFAA,
+	TYPE_GLNA15 = 0xFFFF,
+};
+
+enum odm_type_alna {
+	TYPE_ALNA0 = 0x0000,
+	TYPE_ALNA1 = 0x0055,
+	TYPE_ALNA2 = 0x00AA,
+	TYPE_ALNA3 = 0x00FF,
+	TYPE_ALNA4 = 0x5500,
+	TYPE_ALNA5 = 0x5555,
+	TYPE_ALNA6 = 0x55AA,
+	TYPE_ALNA7 = 0x55FF,
+	TYPE_ALNA8 = 0xAA00,
+	TYPE_ALNA9 = 0xAA55,
+	TYPE_ALNA10 = 0xAAAA,
+	TYPE_ALNA11 = 0xAAFF,
+	TYPE_ALNA12 = 0xFF00,
+	TYPE_ALNA13 = 0xFF55,
+	TYPE_ALNA14 = 0xFFAA,
+	TYPE_ALNA15 = 0xFFFF,
+};
+
+#define	PAUSE_FAIL		0
+#define	PAUSE_SUCCESS	1
+
+enum odm_parameter_init {
+	ODM_PRE_SETTING = 0,
+	ODM_POST_SETTING = 1,
+	ODM_INIT_FW_SETTING
+};
+
+
+enum phydm_pause_type {
+	PHYDM_PAUSE = 1,			/*Pause & Set new value*/
+	PHYDM_PAUSE_NO_SET = 2,	/*Pause & Stay in current value*/
+	PHYDM_RESUME = 3
+};
+
+enum phydm_pause_level {
+	PHYDM_PAUSE_RELEASE = -1,
+	PHYDM_PAUSE_LEVEL_0 = 0,	/* Low Priority function */
+	PHYDM_PAUSE_LEVEL_1 = 1,	/* Middle Priority function */
+	PHYDM_PAUSE_LEVEL_2 = 2,	/* High priority function (ex: Check hang function) */
+	PHYDM_PAUSE_LEVEL_3 = 3,	/* Debug function (the highest priority) */
+	PHYDM_PAUSE_MAX_NUM = 4
+};
+
+enum phydm_dis_hw_fun {
+	HW_FUN_DIS = 0,		/*Disable a cetain HW function & backup the original value*/
+	HW_FUN_RESUME = 1		/*Revert */
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_precomp.h
index 5669c15868ac..42404c5eb93f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_precomp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_precomp.h
@@ -1,320 +1,406 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef	__ODM_PRECOMP_H__
-#define __ODM_PRECOMP_H__
-
-#include "phydm_types.h"
-#include "phydm_features.h"
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#include "Precomp.h"		// We need to include mp_precomp.h due to batch file setting.
-#else
-#define		TEST_FALG___		1
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE ==ODM_CE) 
-#define 	RTL8192CE_SUPPORT 				0
-#define 	RTL8192CU_SUPPORT 				0
-#define 	RTL8192C_SUPPORT 				0	
-
-#define 	RTL8192DE_SUPPORT 				0
-#define 	RTL8192DU_SUPPORT 				0
-#define 	RTL8192D_SUPPORT 				0	
-
-#define 	RTL8723AU_SUPPORT				0
-#define 	RTL8723AS_SUPPORT				0
-#define 	RTL8723AE_SUPPORT				0
-#define 	RTL8723A_SUPPORT				0
-#define 	RTL8723_FPGA_VERIFICATION		0
-#endif
-
-//2 Config Flags and Structs - defined by each ODM Type
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	#include "../8192cd_cfg.h"
-	#include "../odm_inc.h"
-
-	#include "../8192cd.h"
-	#include "../8192cd_util.h"
-	#ifdef _BIG_ENDIAN_
-	#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_BIG
-	#else
-	#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
-	#endif
-
-	#ifdef AP_BUILD_WORKAROUND
-	#include "../8192cd_headers.h"
-	#include "../8192cd_debug.h"		
-	#endif
-
-#elif (DM_ODM_SUPPORT_TYPE ==ODM_CE)
-	#define __PACK
-	#define __WLAN_ATTRIB_PACK__
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#include "mp_precomp.h"
-	#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
-	#define __PACK
-	#define __WLAN_ATTRIB_PACK__
-#endif
-
-//2 OutSrc Header Files
- 
-#include "phydm.h" 
-#include "phydm_hwconfig.h"
-#include "phydm_debug.h"
-#include "phydm_regdefine11ac.h"
-#include "phydm_regdefine11n.h"
-#include "phydm_interface.h"
-#include "phydm_reg.h"
-
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_CE)
-#define RTL8821B_SUPPORT		0
-#define RTL8822B_SUPPORT		0
-
-VOID
-PHY_SetTxPowerLimit(
-	IN	PDM_ODM_T	pDM_Odm,
-	IN	u8	*Regulation,
-	IN	u8	*Band,
-	IN	u8	*Bandwidth,
-	IN	u8	*RateSection,
-	IN	u8	*RfPath,
-	IN	u8	*Channel,
-	IN	u8	*PowerLimit
-);
-
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-#define RTL8821B_SUPPORT		0
-#define RTL8822B_SUPPORT		0
-#define RTL8703B_SUPPORT		0
-#define RTL8188F_SUPPORT		0
-#endif
-
-#if RTL8188E_SUPPORT == 1
-#define RTL8188E_T_SUPPORT 1
-#ifdef CONFIG_SFW_SUPPORTED
-#define RTL8188E_S_SUPPORT 1
-#else
-#define RTL8188E_S_SUPPORT 0
-#endif
-#endif
-
-#if (RTL8188E_SUPPORT==1) 
-#include "rtl8188e/hal8188erateadaptive.h"//for  RA,Power training
-#include "rtl8188e/halhwimg8188e_mac.h"
-#include "rtl8188e/halhwimg8188e_rf.h"
-#include "rtl8188e/halhwimg8188e_bb.h"
-#include "rtl8188e/halhwimg8188e_t_fw.h"
-#include "rtl8188e/halhwimg8188e_s_fw.h"
-#include "rtl8188e/phydm_regconfig8188e.h"
-#include "rtl8188e/phydm_rtl8188e.h"
-#include "rtl8188e/hal8188ereg.h"
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#include "rtl8188e_hal.h" 
-	#include "rtl8188e/halphyrf_8188e_ce.h"
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#include "rtl8188e/halphyrf_8188e_win.h"
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	#include "rtl8188e/halphyrf_8188e_ap.h"
-#endif
-#endif  //88E END
-
-#if (RTL8192E_SUPPORT==1) 
-
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		#include "rtl8192e/halphyrf_8192e_win.h" /*FOR_8192E_IQK*/
-	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-		#include "rtl8192e/halphyrf_8192e_ap.h" /*FOR_8192E_IQK*/
-	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-		#include "rtl8192e/halphyrf_8192e_ce.h" /*FOR_8192E_IQK*/
-	#endif
-	
-#include "rtl8192e/phydm_rtl8192e.h" //FOR_8192E_IQK
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-	#include "rtl8192e/halhwimg8192e_bb.h"
-	#include "rtl8192e/halhwimg8192e_mac.h"
-	#include "rtl8192e/halhwimg8192e_rf.h"
-	#include "rtl8192e/phydm_regconfig8192e.h"
-	#include "rtl8192e/halhwimg8192e_fw.h"
-	#include "rtl8192e/hal8192ereg.h"
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#include "rtl8192e_hal.h"
-#endif
-#endif  //92E END
-
-#if (RTL8812A_SUPPORT==1)
-
-    #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-        #include "rtl8812a/halphyrf_8812a_win.h"
-    #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-        #include "rtl8812a/halphyrf_8812a_ap.h"
-    #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-        #include "rtl8812a/halphyrf_8812a_ce.h"
-    #endif
-
-    //#include "rtl8812a/HalPhyRf_8812A.h" //FOR_8812_IQK
-    #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-        #include "rtl8812a/halhwimg8812a_bb.h"
-        #include "rtl8812a/halhwimg8812a_mac.h"
-        #include "rtl8812a/halhwimg8812a_rf.h"
-        #include "rtl8812a/phydm_regconfig8812a.h"
-        #include "rtl8812a/halhwimg8812a_fw.h"
-        #include "rtl8812a/phydm_rtl8812a.h"
-    #endif
-
-    #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	    #include "rtl8812a_hal.h"
-    #endif
-
-#endif //8812 END
-
-#if (RTL8814A_SUPPORT==1)
-
-#include "rtl8814a/halhwimg8814a_mac.h"
-#include "rtl8814a/halhwimg8814a_rf.h"
-#include "rtl8814a/halhwimg8814a_bb.h"
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-	#include "rtl8814a/halhwimg8814a_fw.h"
-	#include "rtl8814a/phydm_rtl8814a.h"
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#include "rtl8814a/halphyrf_8814a_win.h"
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#include "rtl8814a/halphyrf_8814a_ce.h"
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	#include "rtl8814a/halphyrf_8814a_ap.h"
-#endif
-	#include "rtl8814a/phydm_regconfig8814a.h"
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#include "rtl8814a_hal.h"
-	#include "rtl8814a/phydm_iqk_8814a.h"
-#endif
-#endif //8814 END
-
-#if (RTL8881A_SUPPORT==1)//FOR_8881_IQK
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#include "rtl8821a/phydm_iqk_8821a_win.h"
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#include "rtl8821a/phydm_iqk_8821a_ce.h"
-#else
-#include "rtl8821a/phydm_iqk_8821a_ap.h"
-#endif
-//#include "rtl8881a/HalHWImg8881A_BB.h"
-//#include "rtl8881a/HalHWImg8881A_MAC.h"
-//#include "rtl8881a/HalHWImg8881A_RF.h"
-//#include "rtl8881a/odm_RegConfig8881A.h"
-#endif
-
-#if (RTL8723B_SUPPORT==1) 
-#include "rtl8723b/halhwimg8723b_mac.h"
-#include "rtl8723b/halhwimg8723b_rf.h"
-#include "rtl8723b/halhwimg8723b_bb.h"
-#include "rtl8723b/halhwimg8723b_fw.h"
-#include "rtl8723b/phydm_regconfig8723b.h"
-#include "rtl8723b/phydm_rtl8723b.h"
-#include "rtl8723b/hal8723breg.h"
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-    #include "rtl8723b/halphyrf_8723b_win.h"
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-    #include "rtl8723b/halphyrf_8723b_ce.h"
-    #include "rtl8723b/halhwimg8723b_mp.h"
-    #include "rtl8723b_hal.h"
-#endif
-#endif
-
-#if (RTL8821A_SUPPORT==1) 
-#include "rtl8821a/halhwimg8821a_mac.h"
-#include "rtl8821a/halhwimg8821a_rf.h"
-#include "rtl8821a/halhwimg8821a_bb.h"
-#include "rtl8821a/halhwimg8821a_fw.h"
-#include "rtl8821a/phydm_regconfig8821a.h"
-#include "rtl8821a/phydm_rtl8821a.h"
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#include "rtl8821a/halphyrf_8821a_win.h"
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#include "rtl8821a/halphyrf_8821a_ce.h"
-	#include "rtl8821a/phydm_iqk_8821a_ce.h"/*for IQK*/
-	#include "rtl8812a/halphyrf_8812a_ce.h"/*for IQK,LCK,Power-tracking*/
-	#include "rtl8812a_hal.h"
-#else
-#endif
-#endif
-
-#if (RTL8821B_SUPPORT==1) 
-#include "rtl8821b/halhwimg8821b_mac.h"
-#include "rtl8821b/halhwimg8821b_rf.h"
-#include "rtl8821b/halhwimg8821b_bb.h"
-#include "rtl8821b/halhwimg8821b_fw.h"
-#include "rtl8821b/phydm_regconfig8821b.h"
-#include "rtl8821b/halhwimg8821b_testchip_mac.h"
-#include "rtl8821b/halhwimg8821b_testchip_rf.h"
-#include "rtl8821b/halhwimg8821b_testchip_bb.h"
-#include "rtl8821b/halhwimg8821b_testchip_fw.h"
-#include "rtl8821b/halphyrf_8821b.h"
-#endif
-
-#if (RTL8822B_SUPPORT==1) 
-#include "rtl8822b/halhwimg8822b_mac.h"
-#include "rtl8822b/halhwimg8822b_rf.h"
-#include "rtl8822b/halhwimg8822b_bb.h"
-/*#include "rtl8822b/halhwimg8822b_fw.h"*/
-#include "rtl8822b/phydm_regconfig8822b.h"
-#include "rtl8822b/halphyrf_8822b.h"
-#include "rtl8822b/phydm_rtl8822b.h"
-#include "rtl8822b/phydm_hal_api8822b.h"
-#include "rtl8822b/version_rtl8822b.h"
-#endif
-
-#if (RTL8703B_SUPPORT==1) 
-#include "rtl8703b/phydm_regconfig8703b.h"
-#include "rtl8703b/halhwimg8703b_mac.h"
-#include "rtl8703b/halhwimg8703b_rf.h"
-#include "rtl8703b/halhwimg8703b_bb.h"
-#include "rtl8703b/halhwimg8703b_fw.h"
-#include "rtl8703b/halphyrf_8703b.h"
-#include "rtl8703b/version_rtl8703b.h"
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#include "rtl8703b_hal.h"
-#endif
-#endif
-
-#if (RTL8188F_SUPPORT == 1) 
-#include "rtl8188f/halhwimg8188f_mac.h"
-#include "rtl8188f/halhwimg8188f_rf.h"
-#include "rtl8188f/halhwimg8188f_bb.h"
-#include "rtl8188f/halhwimg8188f_fw.h"
-#include "rtl8188f/hal8188freg.h"
-#include "rtl8188f/phydm_rtl8188f.h"
-#include "rtl8188f/phydm_regconfig8188f.h"
-#include "rtl8188f/halphyrf_8188f.h" /* for IQK,LCK,Power-tracking */
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#include "rtl8188f_hal.h"
-#endif
-#endif
-
-#endif	// __ODM_PRECOMP_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__ODM_PRECOMP_H__
+#define __ODM_PRECOMP_H__
+
+#include "phydm_types.h"
+#include "phydm_features.h"
+#include "halrf/halrf_features.h"
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#include "Precomp.h"		/* We need to include mp_precomp.h due to batch file setting. */
+#else
+	#define		TEST_FALG___		1
+#endif
+
+/* 2 Config Flags and Structs - defined by each ODM type */
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#include "../8192cd_cfg.h"
+	#include "../odm_inc.h"
+
+	#include "../8192cd.h"
+	#include "../8192cd_util.h"
+	#ifdef _BIG_ENDIAN_
+		#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_BIG
+	#else
+		#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
+	#endif
+
+	#include "../8192cd_headers.h"
+	#include "../8192cd_debug.h"
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#ifdef DM_ODM_CE_MAC80211
+		#include "../wifi.h"
+		#include "rtl_phydm.h"
+	#endif
+	#define __PACK
+	#define __WLAN_ATTRIB_PACK__
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#include "mp_precomp.h"
+	#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
+	#define __PACK
+	#define __WLAN_ATTRIB_PACK__
+#endif
+
+/* 2 OutSrc Header Files */
+
+#include "phydm.h"
+#include "phydm_hwconfig.h"
+#include "phydm_phystatus.h"
+#include "phydm_debug.h"
+#include "phydm_regdefine11ac.h"
+#include "phydm_regdefine11n.h"
+#include "phydm_interface.h"
+#include "phydm_reg.h"
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && !defined(DM_ODM_CE_MAC80211)
+
+void
+phy_set_tx_power_limit(
+	struct dm_struct	*dm,
+	u8	*regulation,
+	u8	*band,
+	u8	*bandwidth,
+	u8	*rate_section,
+	u8	*rf_path,
+	u8	*channel,
+	u8	*power_limit
+);
+
+enum hal_status
+rtw_phydm_fw_iqk(
+	struct dm_struct	*dm,
+	u8 clear,
+	u8 segment
+);
+
+enum hal_status
+rtw_phydm_cfg_phy_para(
+	struct dm_struct	*dm,
+	enum phydm_halmac_param config_type,
+	u32 offset,
+	u32 data,
+	u32 mask,
+	enum rf_path e_rf_path,
+	u32 delay_time
+);
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#define RTL8703B_SUPPORT		0
+	#define RTL8188F_SUPPORT		0
+	#define RTL8723D_SUPPORT		0
+#endif
+
+/* JJ ADD 20161014 */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_AP|ODM_IOT))
+#define RTL8710B_SUPPORT		0
+#endif
+
+#if RTL8188E_SUPPORT == 1
+	#define RTL8188E_T_SUPPORT 1
+	#ifdef CONFIG_SFW_SUPPORTED
+		#define RTL8188E_S_SUPPORT 1
+	#else
+		#define RTL8188E_S_SUPPORT 0
+	#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#define	RTL8195B_SUPPORT 0	/*Just for PHYDM API development*/
+#define	RTL8198F_SUPPORT 0	/*Just for PHYDM API development*/
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+	#include "rtl8188e/hal8188erateadaptive.h" /* for  RA,Power training */
+	#include "rtl8188e/halhwimg8188e_mac.h"
+	#include "rtl8188e/halhwimg8188e_rf.h"
+	#include "rtl8188e/halhwimg8188e_bb.h"
+	#include "rtl8188e/phydm_regconfig8188e.h"
+	#include "rtl8188e/phydm_rtl8188e.h"
+	#include "rtl8188e/hal8188ereg.h"
+	#include "rtl8188e/version_rtl8188e.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8188e_hal.h"
+		#include "halrf/rtl8188e/halrf_8188e_ce.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8188e/halrf_8188e_win.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8188e/halrf_8188e_ap.h"
+	#endif
+#endif /* 88E END */
+
+#if (RTL8192E_SUPPORT == 1)
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8192e/halrf_8192e_win.h" /*FOR_8192E_IQK*/
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8192e/halrf_8192e_ap.h" /*FOR_8192E_IQK*/
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8192e/halrf_8192e_ce.h" /*FOR_8192E_IQK*/
+	#endif
+
+	#include "rtl8192e/phydm_rtl8192e.h" /* FOR_8192E_IQK */
+	#include "rtl8192e/version_rtl8192e.h"
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+		#include "rtl8192e/halhwimg8192e_bb.h"
+		#include "rtl8192e/halhwimg8192e_mac.h"
+		#include "rtl8192e/halhwimg8192e_rf.h"
+		#include "rtl8192e/phydm_regconfig8192e.h"
+		#include "rtl8192e/hal8192ereg.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8192e_hal.h"
+	#endif
+#endif /* 92E END */
+
+#if (RTL8812A_SUPPORT == 1)
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8812a/halrf_8812a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8812a/halrf_8812a_ap.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8812a/halrf_8812a_ce.h"
+	#endif
+
+	/* #include "halrf/rtl8812a/halrf_8812a.h"  */ /* FOR_8812_IQK */
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+		#include "rtl8812a/halhwimg8812a_bb.h"
+		#include "rtl8812a/halhwimg8812a_mac.h"
+		#include "rtl8812a/halhwimg8812a_rf.h"
+		#include "rtl8812a/phydm_regconfig8812a.h"
+		#include "rtl8812a/phydm_rtl8812a.h"
+	#endif
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8812a_hal.h"
+	#endif
+	#include "rtl8812a/version_rtl8812a.h"
+
+#endif /* 8812 END */
+
+#if (RTL8814A_SUPPORT == 1)
+
+	#include "rtl8814a/halhwimg8814a_mac.h"
+	#include "rtl8814a/halhwimg8814a_rf.h"
+	#include "rtl8814a/halhwimg8814a_bb.h"
+	#include "rtl8814a/version_rtl8814a.h"
+	#include "rtl8814a/phydm_rtl8814a.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8814a/halrf_8814a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8814a/halrf_8814a_ce.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8814a/halrf_8814a_ap.h"
+	#endif
+	#include "rtl8814a/phydm_regconfig8814a.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8814a_hal.h"
+		#include "halrf/rtl8814a/halrf_iqk_8814a.h"
+	#endif
+#endif /* 8814 END */
+
+#if (RTL8881A_SUPPORT == 1)/* FOR_8881_IQK */
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8821a/halrf_iqk_8821a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8821a/halrf_iqk_8821a_ce.h"
+	#else
+		#include "halrf/rtl8821a/halrf_iqk_8821a_ap.h"
+	#endif
+	/* #include "rtl8881a/HalHWImg8881A_BB.h" */
+	/* #include "rtl8881a/HalHWImg8881A_MAC.h" */
+	/* #include "rtl8881a/HalHWImg8881A_RF.h" */
+	/* #include "rtl8881a/odm_RegConfig8881A.h" */
+#endif
+
+#if (RTL8723B_SUPPORT == 1)
+	#include "rtl8723b/halhwimg8723b_mac.h"
+	#include "rtl8723b/halhwimg8723b_rf.h"
+	#include "rtl8723b/halhwimg8723b_bb.h"
+	#include "rtl8723b/phydm_regconfig8723b.h"
+	#include "rtl8723b/phydm_rtl8723b.h"
+	#include "rtl8723b/hal8723breg.h"
+	#include "rtl8723b/version_rtl8723b.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8723b/halrf_8723b_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8723b/halrf_8723b_ce.h"
+		#include "rtl8723b/halhwimg8723b_mp.h"
+		#include "rtl8723b_hal.h"
+	#else
+		#include "halrf/rtl8723b/halrf_8723b_ap.h"
+	#endif
+#endif
+
+#if (RTL8821A_SUPPORT == 1)
+	#include "rtl8821a/halhwimg8821a_mac.h"
+	#include "rtl8821a/halhwimg8821a_rf.h"
+	#include "rtl8821a/halhwimg8821a_bb.h"
+	#include "rtl8821a/phydm_regconfig8821a.h"
+	#include "rtl8821a/phydm_rtl8821a.h"
+	#include "rtl8821a/version_rtl8821a.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		#include "halrf/rtl8821a/halrf_8821a_win.h"
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "halrf/rtl8821a/halrf_8821a_ce.h"
+		#include "halrf/rtl8821a/halrf_iqk_8821a_ce.h"/*for IQK*/
+		#include "halrf/rtl8812a/halrf_8812a_ce.h"/*for IQK,LCK,Power-tracking*/
+		#include "rtl8812a_hal.h"
+	#else
+	#endif
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#include "../halmac/halmac_reg2.h"
+#endif
+
+
+#if (RTL8822B_SUPPORT == 1)
+	#include "rtl8822b/halhwimg8822b_mac.h"
+	#include "rtl8822b/halhwimg8822b_rf.h"
+	#include "rtl8822b/halhwimg8822b_bb.h"
+	#include "rtl8822b/phydm_regconfig8822b.h"
+	#include "halrf/rtl8822b/halrf_8822b.h"
+	#include "rtl8822b/phydm_rtl8822b.h"
+	#include "rtl8822b/phydm_hal_api8822b.h"
+	#include "rtl8822b/version_rtl8822b.h"
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#ifdef DM_ODM_CE_MAC80211
+			#include "../halmac/halmac_reg_8822b.h"
+		#else
+			#include <hal_data.h>		/* struct HAL_DATA_TYPE */
+			#include <rtl8822b_hal.h>	/* RX_SMOOTH_FACTOR, reg definition and etc.*/
+		#endif
+	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#endif
+
+#endif
+
+#if (RTL8703B_SUPPORT == 1)
+	#include "rtl8703b/phydm_regconfig8703b.h"
+	#include "rtl8703b/halhwimg8703b_mac.h"
+	#include "rtl8703b/halhwimg8703b_rf.h"
+	#include "rtl8703b/halhwimg8703b_bb.h"
+	#include "halrf/rtl8703b/halrf_8703b.h"
+	#include "rtl8703b/version_rtl8703b.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8703b_hal.h"
+	#endif
+#endif
+
+#if (RTL8188F_SUPPORT == 1)
+	#include "rtl8188f/halhwimg8188f_mac.h"
+	#include "rtl8188f/halhwimg8188f_rf.h"
+	#include "rtl8188f/halhwimg8188f_bb.h"
+	#include "rtl8188f/hal8188freg.h"
+	#include "rtl8188f/phydm_rtl8188f.h"
+	#include "rtl8188f/phydm_regconfig8188f.h"
+	#include "halrf/rtl8188f/halrf_8188f.h" /* for IQK,LCK,Power-tracking */
+	#include "rtl8188f/version_rtl8188f.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8188f_hal.h"
+	#endif
+#endif
+
+#if (RTL8723D_SUPPORT == 1)
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+
+		#include "rtl8723d/halhwimg8723d_bb.h"
+		#include "rtl8723d/halhwimg8723d_mac.h"
+		#include "rtl8723d/halhwimg8723d_rf.h"
+		#include "rtl8723d/phydm_regconfig8723d.h"
+		#include "rtl8723d/hal8723dreg.h"
+		#include "rtl8723d/phydm_rtl8723d.h"
+		#include "halrf/rtl8723d/halrf_8723d.h"
+		#include "rtl8723d/version_rtl8723d.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8723d_hal.h"
+	#endif
+#endif /* 8723D End */
+
+/* JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT == 1)
+	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+
+		#include "rtl8710b/halhwimg8710b_bb.h"
+		#include "rtl8710b/halhwimg8710b_mac.h"
+		#include "rtl8710b/halhwimg8710b_rf.h"
+		#include "rtl8710b/phydm_regconfig8710b.h"
+		#include "rtl8710b/hal8710breg.h"
+		#include "rtl8710b/phydm_rtl8710b.h"
+		#include "halrf/rtl8710b/halrf_8710b.h"
+		#include "rtl8710b/version_rtl8710b.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8710b_hal.h"
+	#endif
+#endif /* 8710B End */
+
+#if (RTL8197F_SUPPORT == 1)
+	#include "rtl8197f/halhwimg8197f_mac.h"
+	#include "rtl8197f/halhwimg8197f_rf.h"
+	#include "rtl8197f/halhwimg8197f_bb.h"
+	#include "rtl8197f/phydm_hal_api8197f.h"
+	#include "rtl8197f/version_rtl8197f.h"
+	#include "rtl8197f/phydm_rtl8197f.h"
+	#include "rtl8197f/phydm_regconfig8197f.h"
+	#include "halrf/rtl8197f/halrf_8197f.h"
+	#include "halrf/rtl8197f/halrf_iqk_8197f.h"
+#endif
+
+#if (RTL8821C_SUPPORT == 1)
+	#include "rtl8821c/phydm_hal_api8821c.h"
+	#include "rtl8821c/halhwimg8821c_mac.h"
+	#include "rtl8821c/halhwimg8821c_rf.h"
+	#include "rtl8821c/halhwimg8821c_bb.h"
+	#include "rtl8821c/phydm_regconfig8821c.h"
+	#include "halrf/rtl8821c/halrf_8821c.h"
+	#include "rtl8821c/version_rtl8821c.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8821c_hal.h"
+	#endif
+#endif
+
+#if (RTL8195B_SUPPORT == 1)
+	#include "rtl8195b/phydm_hal_api8195b.h"
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	#include "rtl8198f/phydm_hal_api8198F.h"
+#endif
+
+#endif /* __ODM_PRECOMP_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_primary_cca.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_primary_cca.c
new file mode 100644
index 000000000000..cef74468f853
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_primary_cca.c
@@ -0,0 +1,731 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+#ifdef PHYDM_PRIMARY_CCA
+
+void
+phydm_write_dynamic_cca(
+	void			*dm_void,
+	u8			curr_mf_state
+	
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct	*primary_cca = &dm->dm_pri_cca;
+
+	if (primary_cca->mf_state == curr_mf_state)
+		return;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (curr_mf_state == MF_USC_LSC) {
+			odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), MF_USC_LSC);
+			odm_set_bb_reg(dm, 0xc84, 0xf0000000, primary_cca->cca_th_40m_bkp); /*40M OFDM MF CCA threshold*/
+		} else {
+			odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), curr_mf_state);
+			odm_set_bb_reg(dm, 0xc84, 0xf0000000, 0); /*40M OFDM MF CCA threshold*/
+		}
+	}
+
+	primary_cca->mf_state = curr_mf_state;
+	PHYDM_DBG(dm, DBG_PRI_CCA,
+			"Set CCA at ((%s SB)), 0xc6c[8:7]=((%d))\n", ((curr_mf_state == MF_USC_LSC)?"D":((curr_mf_state == MF_LSC)?"L":"U")), curr_mf_state);
+}
+
+void
+phydm_primary_cca_reset(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct	*primary_cca = &dm->dm_pri_cca;
+
+	PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA] Reset\n");
+	primary_cca->mf_state = 0xff;
+	primary_cca->pre_bw = (enum channel_width)0xff;
+	phydm_write_dynamic_cca(dm, MF_USC_LSC);
+}
+
+void
+phydm_primary_cca_11n(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct	*primary_cca = &dm->dm_pri_cca;
+	enum channel_width	curr_bw = (enum channel_width)*dm->band_width;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+	
+	if (!dm->is_linked) { /* is_linked==False */
+		PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA][No Link!!!]\n");
+
+		if (primary_cca->pri_cca_is_become_linked == true) {
+			phydm_primary_cca_reset(dm);
+			primary_cca->pri_cca_is_become_linked = dm->is_linked;
+		}
+		return;
+		
+	} else {
+		if (primary_cca->pri_cca_is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA][Linked !!!]\n");
+			primary_cca->pri_cca_is_become_linked = dm->is_linked;
+		}
+	}
+	
+	if (curr_bw != primary_cca->pre_bw) {
+		PHYDM_DBG(dm, DBG_PRI_CCA, "[Primary CCA] start ==>\n");
+		primary_cca->pre_bw = curr_bw;
+
+		if (curr_bw == CHANNEL_WIDTH_40) {
+			
+			if (*dm->sec_ch_offset == SECOND_CH_AT_LSB) {/* Primary CH @ upper sideband*/
+				
+				PHYDM_DBG(dm, DBG_PRI_CCA, "BW40M, Primary CH at USB\n");
+				phydm_write_dynamic_cca(dm, MF_USC);
+				
+			} else {	/*Primary CH @ lower sideband*/
+				
+				PHYDM_DBG(dm, DBG_PRI_CCA, "BW40M, Primary CH at LSB\n");
+				phydm_write_dynamic_cca(dm, MF_LSC);
+			}
+		} else {
+		
+			PHYDM_DBG(dm, DBG_PRI_CCA, "Not BW40M, USB + LSB\n");
+			phydm_primary_cca_reset(dm);
+		}
+	}
+}
+
+#if 0
+#if (RTL8188E_SUPPORT == 1)
+void
+odm_dynamic_primary_cca_8188e(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sta_info	*entry;
+	struct cmn_sta_info	*sta;
+	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(dm, PHYDM_FALSEALMCNT);
+	struct phydm_pricca_struct		*primary_cca = &(dm->dm_pri_cca);
+	boolean		client_40mhz = false, client_tmp = false;      /* connected client BW */
+	boolean		is_connected = false;		/* connected or not */
+	u8	client_40mhz_pre = 0;
+	u32	counter = 0;
+	u8	delay = 1;
+	u64		cur_tx_ok_cnt;
+	u64		cur_rx_ok_cnt;
+	u8		sec_ch_offset = *(dm->sec_ch_offset);
+	u8		i;
+
+	if (!dm->is_linked)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	if (*(dm->band_width) == CHANNEL_WIDTH_20) {	/*curr bw*/
+		odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 0);
+		return;
+	}
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) || (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		sec_ch_offset = sec_ch_offset % 2 + 1; /* NIC's definition is reverse to AP   1:secondary below,  2: secondary above */
+	#endif
+	
+	PHYDM_DBG(dm, DBG_PRI_CCA, "Second CH Offset = %d\n", sec_ch_offset);
+
+	/* 3 Check Current WLAN Traffic */
+	cur_tx_ok_cnt = dm->tx_tp;
+	cur_rx_ok_cnt = dm->rx_tp;
+
+	/* ==================Debug Message==================== */
+	PHYDM_DBG(dm, DBG_PRI_CCA, "TP = %llu\n", cur_tx_ok_cnt + cur_rx_ok_cnt);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "is_BW40 = %d\n", *(dm->band_width));
+	PHYDM_DBG(dm, DBG_PRI_CCA, "BW_LSC = %d\n", false_alm_cnt->cnt_bw_lsc);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "BW_USC = %d\n", false_alm_cnt->cnt_bw_usc);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "CCA OFDM = %d\n", false_alm_cnt->cnt_ofdm_cca);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "CCA CCK = %d\n", false_alm_cnt->cnt_cck_cca);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "OFDM FA = %d\n", false_alm_cnt->cnt_ofdm_fail);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "CCK FA = %d\n", false_alm_cnt->cnt_cck_fail);
+	/* ================================================ */
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (ACTING_AS_AP(dm->adapter))   /* primary cca process only do at AP mode */
+#endif
+	{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		PHYDM_DBG(dm, DBG_PRI_CCA, "ACTING as AP mode=%d\n", ACTING_AS_AP(dm->adapter));
+		/* 3 To get entry's connection and BW infomation status. */
+		for (i = 0; i < ASSOCIATE_ENTRY_NUM; i++) {
+			if (IsAPModeExist(dm->adapter) && GetFirstExtAdapter(dm->adapter) != NULL)
+				entry = AsocEntry_EnumStation(GetFirstExtAdapter(dm->adapter), i);
+			else
+				entry = AsocEntry_EnumStation(GetDefaultAdapter(dm->adapter), i);
+			if (entry != NULL) {
+				client_tmp = entry->BandWidth;   /* client BW */
+				PHYDM_DBG(dm, DBG_PRI_CCA, "Client_BW=%d\n", client_tmp);
+				if (client_tmp > client_40mhz)
+					client_40mhz = client_tmp;     /* 40M/20M coexist => 40M priority is High */
+
+				if (entry->bAssociated) {
+					is_connected = true;  /* client is connected or not */
+					break;
+				}
+			} else
+				break;
+		}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		/* 3 To get entry's connection and BW infomation status. */
+
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+			sta = dm->phydm_sta_info[i];
+			if (is_sta_active(sta)) {
+				client_tmp = sta->bw_mode;
+				if (client_tmp > client_40mhz)
+					client_40mhz = client_tmp;     /* 40M/20M coexist => 40M priority is High */
+
+				is_connected = true;
+			}
+		}
+#endif
+		PHYDM_DBG(dm, DBG_PRI_CCA, "is_connected=%d\n", is_connected);
+		PHYDM_DBG(dm, DBG_PRI_CCA, "Is Client 40MHz=%d\n", client_40mhz);
+		/* 1 Monitor whether the interference exists or not */
+		if (primary_cca->monitor_flag == 1) {
+			if (sec_ch_offset == 1) {    /* secondary channel is below the primary channel */
+				if ((false_alm_cnt->cnt_ofdm_cca > 500) && (false_alm_cnt->cnt_bw_lsc > false_alm_cnt->cnt_bw_usc + 500)) {
+					if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1) {
+						primary_cca->intf_type = 1;
+						primary_cca->pri_cca_flag = 1;
+						odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT7, 2); /* USC MF */
+						if (primary_cca->dup_rts_flag == 1)
+							primary_cca->dup_rts_flag = 0;
+					} else {
+						primary_cca->intf_type = 2;
+						if (primary_cca->dup_rts_flag == 0)
+							primary_cca->dup_rts_flag = 1;
+					}
+
+				} else { /* interferecne disappear */
+					primary_cca->dup_rts_flag = 0;
+					primary_cca->intf_flag = 0;
+					primary_cca->intf_type = 0;
+				}
+			} else if (sec_ch_offset == 2) { /* secondary channel is above the primary channel */
+				if ((false_alm_cnt->cnt_ofdm_cca > 500) && (false_alm_cnt->cnt_bw_usc > false_alm_cnt->cnt_bw_lsc + 500)) {
+					if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1) {
+						primary_cca->intf_type = 1;
+						primary_cca->pri_cca_flag = 1;
+						odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT7, 1); /* LSC MF */
+						if (primary_cca->dup_rts_flag == 1)
+							primary_cca->dup_rts_flag = 0;
+					} else {
+						primary_cca->intf_type = 2;
+						if (primary_cca->dup_rts_flag == 0)
+							primary_cca->dup_rts_flag = 1;
+					}
+
+				} else { /* interferecne disappear */
+					primary_cca->dup_rts_flag = 0;
+					primary_cca->intf_flag = 0;
+					primary_cca->intf_type = 0;
+				}
+
+
+			}
+			primary_cca->monitor_flag = 0;
+		}
+
+		/* 1 Dynamic Primary CCA Main Function */
+		if (primary_cca->monitor_flag == 0) {
+			if (*(dm->band_width) == CHANNEL_WIDTH_40) {		/* if RFBW==40M mode which require to process primary cca */
+				/* 2 STA is NOT Connected */
+				if (!is_connected) {
+					PHYDM_DBG(dm, DBG_PRI_CCA, "STA NOT Connected!!!!\n");
+
+					if (primary_cca->pri_cca_flag == 1) {	/* reset primary cca when STA is disconnected */
+						primary_cca->pri_cca_flag = 0;
+						odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 0);
+					}
+					if (primary_cca->dup_rts_flag == 1)		/* reset Duplicate RTS when STA is disconnected */
+						primary_cca->dup_rts_flag = 0;
+
+					if (sec_ch_offset == 1) { /* secondary channel is below the primary channel */
+						if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_lsc * 5 > false_alm_cnt->cnt_bw_usc * 9)) {
+							primary_cca->intf_flag = 1;    /* secondary channel interference is detected!!! */
+							if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+								primary_cca->intf_type = 1;   	/* interference is shift */
+							else
+								primary_cca->intf_type = 2;   	/* interference is in-band */
+						} else {
+							primary_cca->intf_flag = 0;
+							primary_cca->intf_type = 0;
+						}
+					} else if (sec_ch_offset == 2) { /* secondary channel is above the primary channel */
+						if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_usc * 5 > false_alm_cnt->cnt_bw_lsc * 9)) {
+							primary_cca->intf_flag = 1;    /* secondary channel interference is detected!!! */
+							if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+								primary_cca->intf_type = 1;   	/* interference is shift */
+							else
+								primary_cca->intf_type = 2;   	/* interference is in-band */
+						} else {
+							primary_cca->intf_flag = 0;
+							primary_cca->intf_type = 0;
+						}
+					}
+					PHYDM_DBG(dm, DBG_PRI_CCA, "primary_cca=%d\n", primary_cca->pri_cca_flag);
+					PHYDM_DBG(dm, DBG_PRI_CCA, "Intf_Type=%d\n", primary_cca->intf_type);
+				}
+				/* 2 STA is Connected */
+				else {
+					if (client_40mhz == 0)		/* 3 */ { /* client BW = 20MHz */
+						if (primary_cca->pri_cca_flag == 0) {
+							primary_cca->pri_cca_flag = 1;
+							if (sec_ch_offset == 1)
+								odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 2);
+							else if (sec_ch_offset == 2)
+								odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 1);
+						}
+						PHYDM_DBG(dm, DBG_PRI_CCA, "STA Connected 20M!!! primary_cca=%d\n", primary_cca->pri_cca_flag);
+					} else		/* 3 */ { /* client BW = 40MHz */
+						if (primary_cca->intf_flag == 1) { /* interference is detected!! */
+							if (primary_cca->intf_type == 1) {
+								if (primary_cca->pri_cca_flag != 1) {
+									primary_cca->pri_cca_flag = 1;
+									if (sec_ch_offset == 1)
+										odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 2);
+									else if (sec_ch_offset == 2)
+										odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 1);
+								}
+							} else if (primary_cca->intf_type == 2) {
+								if (primary_cca->dup_rts_flag != 1)
+									primary_cca->dup_rts_flag = 1;
+							}
+						} else { /* if intf_flag==0 */
+							if ((cur_tx_ok_cnt + cur_rx_ok_cnt) < 1) { /* idle mode or TP traffic is very low */
+								if (sec_ch_offset == 1) {
+									if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_lsc * 5 > false_alm_cnt->cnt_bw_usc * 9)) {
+										primary_cca->intf_flag = 1;
+										if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+											primary_cca->intf_type = 1;   	/* interference is shift */
+										else
+											primary_cca->intf_type = 2;   	/* interference is in-band */
+									}
+								} else if (sec_ch_offset == 2) {
+									if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_usc * 5 > false_alm_cnt->cnt_bw_lsc * 9)) {
+										primary_cca->intf_flag = 1;
+										if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+											primary_cca->intf_type = 1;   	/* interference is shift */
+										else
+											primary_cca->intf_type = 2;   	/* interference is in-band */
+									}
+
+								}
+							} else { /* TP Traffic is High */
+								if (sec_ch_offset == 1) {
+									if (false_alm_cnt->cnt_bw_lsc > (false_alm_cnt->cnt_bw_usc + 500)) {
+										if (delay == 0) { /* add delay to avoid interference occurring abruptly, jump one time */
+											primary_cca->intf_flag = 1;
+											if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+												primary_cca->intf_type = 1;   	/* interference is shift */
+											else
+												primary_cca->intf_type = 2;   	/* interference is in-band */
+											delay = 1;
+										} else
+											delay = 0;
+									}
+								} else if (sec_ch_offset == 2) {
+									if (false_alm_cnt->cnt_bw_usc > (false_alm_cnt->cnt_bw_lsc + 500)) {
+										if (delay == 0) { /* add delay to avoid interference occurring abruptly */
+											primary_cca->intf_flag = 1;
+											if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
+												primary_cca->intf_type = 1;   	/* interference is shift */
+											else
+												primary_cca->intf_type = 2;   	/* interference is in-band */
+											delay = 1;
+										} else
+											delay = 0;
+									}
+								}
+							}
+						}
+						PHYDM_DBG(dm, DBG_PRI_CCA, "Primary CCA=%d\n", primary_cca->pri_cca_flag);
+						PHYDM_DBG(dm, DBG_PRI_CCA, "Duplicate RTS=%d\n", primary_cca->dup_rts_flag);
+					}
+
+				} /* end of connected */
+			}
+		}
+		/* 1 Dynamic Primary CCA Monitor counter */
+		if ((primary_cca->pri_cca_flag == 1) || (primary_cca->dup_rts_flag == 1)) {
+			if (client_40mhz == 0) {  /* client=20M no need to monitor primary cca flag */
+				client_40mhz_pre = client_40mhz;
+				return;
+			}
+			counter++;
+			PHYDM_DBG(dm, DBG_PRI_CCA, "counter=%d\n", counter);
+			if ((counter == 30) || ((client_40mhz - client_40mhz_pre) == 1)) { /* Every 60 sec to monitor one time */
+				primary_cca->monitor_flag = 1;     /* monitor flag is triggered!!!!! */
+				if (primary_cca->pri_cca_flag == 1) {
+					primary_cca->pri_cca_flag = 0;
+					odm_set_bb_reg(dm, 0xc6c, BIT(8) | BIT(7), 0);
+				}
+				counter = 0;
+			}
+		}
+	}
+
+	client_40mhz_pre = client_40mhz;
+}
+#endif
+
+#if (RTL8192E_SUPPORT == 1)
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_dynamic_primary_cca_mp_8192e(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	PADAPTER        adapter = (PADAPTER)dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	struct phydm_fa_struct		*false_alm_cnt = &(dm->false_alm_cnt);
+	struct phydm_pricca_struct		*primary_cca = &(dm->dm_pri_cca);
+	u64			OFDM_CCA, OFDM_FA, bw_usc_cnt, bw_lsc_cnt;
+	u8			sec_ch_offset;
+	static u8		count_down = PRI_CCA_MONITOR_TIME;
+
+	if (!dm->is_linked)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	OFDM_CCA = false_alm_cnt->cnt_ofdm_cca;
+	OFDM_FA = false_alm_cnt->cnt_ofdm_fail;
+	bw_usc_cnt = false_alm_cnt->cnt_bw_usc;
+	bw_lsc_cnt = false_alm_cnt->cnt_bw_lsc;
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: OFDM CCA=%d\n", OFDM_CCA);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: OFDM FA=%d\n", OFDM_FA);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: BW_USC=%d\n", bw_usc_cnt);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: BW_LSC=%d\n", bw_lsc_cnt);
+	sec_ch_offset = *(dm->sec_ch_offset);		/* NIC: 2: sec is below,  1: sec is above */
+
+	
+	if (IsAPModeExist(adapter)) {
+		phydm_write_dynamic_cca(dm, MF_USC_LSC);
+		return;
+	}
+
+	if (*(dm->band_width) != CHANNEL_WIDTH_40)
+		return;
+
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Cont Down= %d\n", count_down);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Primary_CCA_flag=%d\n", primary_cca->pri_cca_flag);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Intf_Type=%d\n", primary_cca->intf_type);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Intf_flag=%d\n", primary_cca->intf_flag);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "92E: Duplicate RTS Flag=%d\n", primary_cca->dup_rts_flag);
+
+	if (primary_cca->pri_cca_flag == 0) {
+		if (sec_ch_offset == SECOND_CH_AT_LSB) {  /* Primary channel is above   NOTE: duplicate CTS can remove this condition */
+
+			if ((OFDM_CCA > OFDMCCA_TH) && (bw_lsc_cnt > (bw_usc_cnt + bw_ind_bias))
+			    && (OFDM_FA > (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 1;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_USC);
+				primary_cca->pri_cca_flag = 1;
+			} else if ((OFDM_CCA > OFDMCCA_TH) && (bw_lsc_cnt > (bw_usc_cnt + bw_ind_bias))
+				&& (OFDM_FA < (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 2;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_USC);
+				primary_cca->pri_cca_flag = 1;
+				primary_cca->dup_rts_flag = 1;
+				hal_data->RTSEN = 1;
+			} else {
+				primary_cca->intf_type = 0;
+				primary_cca->intf_flag = 0;
+				phydm_write_dynamic_cca(dm, MF_USC_LSC);
+				hal_data->RTSEN = 0;
+				primary_cca->dup_rts_flag = 0;
+			}
+
+		} else if (sec_ch_offset == SECOND_CH_AT_USB) {
+			if ((OFDM_CCA > OFDMCCA_TH) && (bw_usc_cnt > (bw_lsc_cnt + bw_ind_bias))
+			    && (OFDM_FA > (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 1;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_LSC);
+				primary_cca->pri_cca_flag = 1;
+			} else if ((OFDM_CCA > OFDMCCA_TH) && (bw_usc_cnt > (bw_lsc_cnt + bw_ind_bias))
+				&& (OFDM_FA < (OFDM_CCA >> 1))) {
+				primary_cca->intf_type = 2;
+				primary_cca->intf_flag = 1;
+				phydm_write_dynamic_cca(dm, MF_LSC);
+				primary_cca->pri_cca_flag = 1;
+				primary_cca->dup_rts_flag = 1;
+				hal_data->RTSEN = 1;
+			} else {
+				primary_cca->intf_type = 0;
+				primary_cca->intf_flag = 0;
+				phydm_write_dynamic_cca(dm, MF_USC_LSC);
+				hal_data->RTSEN = 0;
+				primary_cca->dup_rts_flag = 0;
+			}
+
+		}
+
+	} else {	/* primary_cca->pri_cca_flag==1 */
+
+		count_down--;
+		if (count_down == 0) {
+			count_down = PRI_CCA_MONITOR_TIME;
+			primary_cca->pri_cca_flag = 0;
+			phydm_write_dynamic_cca(dm, MF_USC_LSC);   /* default */
+			hal_data->RTSEN = 0;
+			primary_cca->dup_rts_flag = 0;
+			primary_cca->intf_type = 0;
+			primary_cca->intf_flag = 0;
+		}
+
+	}
+}
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_intf_detection(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct		*false_alm_cnt = &(dm->false_alm_cnt);
+	struct phydm_pricca_struct			*primary_cca = &(dm->dm_pri_cca);
+
+	if ((false_alm_cnt->cnt_ofdm_cca > OFDMCCA_TH)
+	    && (false_alm_cnt->cnt_bw_lsc > (false_alm_cnt->cnt_bw_usc + bw_ind_bias))) {
+		primary_cca->intf_flag = 1;
+		primary_cca->ch_offset = 1;  /* 1:LSC, 2:USC */
+		if (false_alm_cnt->cnt_ofdm_fail > (false_alm_cnt->cnt_ofdm_cca >> 1))
+			primary_cca->intf_type = 1;
+		else
+			primary_cca->intf_type = 2;
+	} else if ((false_alm_cnt->cnt_ofdm_cca > OFDMCCA_TH)
+		&& (false_alm_cnt->cnt_bw_usc > (false_alm_cnt->cnt_bw_lsc + bw_ind_bias))) {
+		primary_cca->intf_flag = 1;
+		primary_cca->ch_offset = 2;  /* 1:LSC, 2:USC */
+		if (false_alm_cnt->cnt_ofdm_fail > (false_alm_cnt->cnt_ofdm_cca >> 1))
+			primary_cca->intf_type = 1;
+		else
+			primary_cca->intf_type = 2;
+	} else {
+		primary_cca->intf_flag = 0;
+		primary_cca->intf_type = 0;
+		primary_cca->ch_offset = 0;
+	}
+
+}
+
+void
+odm_dynamic_primary_cca_ap_8192e(
+	void			*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct		*primary_cca = &(dm->dm_pri_cca);
+	u8		i;
+	static u32	count_down = PRI_CCA_MONITOR_TIME;
+	u8		STA_BW = false, STA_BW_pre = false, STA_BW_TMP = false;
+	boolean		is_connected = false;
+	u8		sec_ch_offset;
+	u8		cur_mf_state;
+	struct cmn_sta_info	*entry;
+
+	if (!dm->is_linked)
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	sec_ch_offset = *(dm->sec_ch_offset);		/* AP: 1: sec is below,  2: sec is above */
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		entry = dm->phydm_sta_info[i];
+		if (is_sta_active(entry)) {
+			STA_BW_TMP = entry->bw_mode;
+			if (STA_BW_TMP > STA_BW)
+				STA_BW = STA_BW_TMP;
+			is_connected = true;
+		}
+	}
+
+	if (*(dm->band_width) == CHANNEL_WIDTH_40) {
+		
+		if (primary_cca->pri_cca_flag == 0) {
+			if (is_connected) {
+				if (STA_BW == CHANNEL_WIDTH_20) { /* 2 STA BW=20M */
+					primary_cca->pri_cca_flag = 1;
+					if (sec_ch_offset == 1) {
+						cur_mf_state = MF_USC;
+						phydm_write_dynamic_cca(dm, cur_mf_state);
+					} else if (sec_ch_offset == 2) {
+						cur_mf_state = MF_USC;
+						phydm_write_dynamic_cca(dm, cur_mf_state);
+					}
+				} else {     			/* 2  STA BW=40M */
+					if (primary_cca->intf_flag == 0)
+						odm_intf_detection(dm);
+					else {	/* intf_flag = 1 */
+						if (primary_cca->intf_type == 1) {
+							if (primary_cca->ch_offset == 1) {
+								cur_mf_state = MF_USC;
+								if (sec_ch_offset == 1)  /* AP,  1: primary is above  2: primary is below */
+									phydm_write_dynamic_cca(dm, cur_mf_state);
+							} else if (primary_cca->ch_offset == 2) {
+								cur_mf_state = MF_LSC;
+								if (sec_ch_offset == 2)
+									phydm_write_dynamic_cca(dm, cur_mf_state);
+							}
+						} else if (primary_cca->intf_type == 2)
+							PHYDM_DBG(dm, DBG_PRI_CCA, "92E: primary_cca->intf_type = 2\n");
+					}
+				}
+
+			} else		/* disconnected  interference detection */
+				odm_intf_detection(dm); /* end of disconnected */
+
+
+		} else {	/* primary_cca->pri_cca_flag == 1 */
+
+			if (STA_BW == 0) {
+				STA_BW_pre = STA_BW;
+				return;
+			}
+
+			count_down--;
+			if ((count_down == 0) || ((STA_BW & STA_BW_pre) != 1)) {
+				count_down = PRI_CCA_MONITOR_TIME;
+				primary_cca->pri_cca_flag = 0;
+				primary_cca->intf_type = 0;
+				primary_cca->intf_flag = 0;
+				cur_mf_state = MF_USC_LSC;
+				phydm_write_dynamic_cca(dm, cur_mf_state); /* default */
+			}
+		}
+		STA_BW_pre = STA_BW;
+
+	} else {
+		/* 2 Reset */
+		phydm_primary_cca_init(dm);
+		cur_mf_state = MF_USC_LSC;
+		phydm_write_dynamic_cca(dm, cur_mf_state);
+		count_down = PRI_CCA_MONITOR_TIME;
+	}
+
+}
+#endif
+
+
+#endif /* RTL8192E_SUPPORT == 1 */
+#endif
+
+
+#endif
+
+boolean
+odm_dynamic_primary_cca_dup_rts(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_PRIMARY_CCA
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct		*primary_cca = &dm->dm_pri_cca;
+
+	return	primary_cca->dup_rts_flag;
+#else
+	return	0;	
+#endif
+}
+
+void
+phydm_primary_cca_init(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_PRIMARY_CCA
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct		*primary_cca = &dm->dm_pri_cca;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA] Init ==>\n");
+	#if (RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1)
+	primary_cca->dup_rts_flag = 0;
+	primary_cca->intf_flag = 0;
+	primary_cca->intf_type = 0;
+	primary_cca->monitor_flag = 0;
+	primary_cca->pri_cca_flag = 0;
+	primary_cca->ch_offset = 0;
+	#endif
+	primary_cca->mf_state = 0xff;
+	primary_cca->pre_bw = (enum channel_width)0xff;
+	
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		primary_cca->cca_th_40m_bkp = (u8)odm_get_bb_reg(dm, 0xc84, 0xf0000000);
+#endif
+}
+
+void
+phydm_primary_cca(
+	void			*dm_void
+)
+{
+#ifdef PHYDM_PRIMARY_CCA
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ic_type & ODM_IC_11N_SERIES))
+		return;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
+
+	phydm_primary_cca_11n(dm);
+
+#endif
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_primary_cca.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_primary_cca.h
new file mode 100644
index 000000000000..2f5126928cb4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_primary_cca.h
@@ -0,0 +1,127 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_PRIMARYCCA_H__
+#define	__PHYDM_PRIMARYCCA_H__
+
+#define PRIMARYCCA_VERSION	"1.0"  /*2017.03.23, Dino*/
+
+/*============================================================*/
+/*Definition */
+/*============================================================*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+#define	SECOND_CH_AT_LSB	2	/*primary CH @ MSB,  SD4: HAL_PRIME_CHNL_OFFSET_UPPER*/
+#define	SECOND_CH_AT_USB	1	/*primary CH @ LSB,   SD4: HAL_PRIME_CHNL_OFFSET_LOWER*/
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#define	SECOND_CH_AT_LSB	2	/*primary CH @ MSB,  SD7: HAL_PRIME_CHNL_OFFSET_UPPER*/
+#define	SECOND_CH_AT_USB	1	/*primary CH @ LSB,   SD7: HAL_PRIME_CHNL_OFFSET_LOWER*/
+#else /*if (DM_ODM_SUPPORT_TYPE == ODM_AP)*/
+#define	SECOND_CH_AT_LSB	1	/*primary CH @ MSB,  SD8: HT_2NDCH_OFFSET_BELOW*/
+#define	SECOND_CH_AT_USB	2	/*primary CH @ LSB,   SD8: HT_2NDCH_OFFSET_ABOVE*/
+#endif
+
+#define	OFDMCCA_TH	500
+#define	bw_ind_bias		500
+#define	PRI_CCA_MONITOR_TIME	30
+
+#ifdef PHYDM_PRIMARY_CCA
+
+/*============================================================*/
+/*structure and define*/
+/*============================================================*/
+enum	primary_cca_ch_position {  /*N-series REG0xc6c[8:7]*/
+	MF_USC_LSC = 0,
+	MF_LSC = 1,
+	MF_USC = 2
+};
+
+struct phydm_pricca_struct {
+	#if (RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1)
+	u8	pri_cca_flag;
+	u8	intf_flag;
+	u8	intf_type;
+	u8	monitor_flag;
+	u8	ch_offset;
+	#endif
+	u8	dup_rts_flag;
+	u8	cca_th_40m_bkp; /*c84[31:28]*/
+	enum channel_width	pre_bw;
+	u8	pri_cca_is_become_linked;
+	u8	mf_state;
+};
+
+/*============================================================*/
+/*function prototype*/
+/*============================================================*/
+
+#if 0
+#if (RTL8192E_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_dynamic_primary_cca_mp_8192e(
+	void			*dm_void
+);
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_dynamic_primary_cca_ap_8192e(
+	void			*dm_void
+);
+#endif
+#endif
+
+#if (RTL8188E_SUPPORT == 1)
+
+void
+odm_dynamic_primary_cca_8188e(
+	void			*dm_void
+);
+#endif
+#endif
+
+#endif /*#ifdef PHYDM_PRIMARY_CCA*/
+
+
+boolean
+odm_dynamic_primary_cca_dup_rts(
+	void			*dm_void
+);
+
+void
+phydm_primary_cca_init(
+	void			*dm_void
+);
+
+void
+phydm_primary_cca(
+	void			*dm_void
+);
+
+
+#endif /*#ifndef	__PHYDM_PRIMARYCCA_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_psd.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_psd.c
new file mode 100644
index 000000000000..66b4d7584e03
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_psd.c
@@ -0,0 +1,403 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+//============================================================
+// include files
+//============================================================
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef CONFIG_PSD_TOOL
+
+u32
+phydm_get_psd_data(
+	void			*dm_void,
+	u32			psd_tone_idx,
+	u32			igi
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u32		psd_report = 0;
+	
+	odm_set_bb_reg(dm, dm_psd_table->psd_reg, 0x3ff, psd_tone_idx);
+	
+	odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(22), 1); /*PSD trigger start*/
+	ODM_delay_us(10);
+	odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(22), 0); /*PSD trigger stop*/
+
+	psd_report = odm_get_bb_reg(dm, dm_psd_table->psd_report_reg, 0xffff);
+	psd_report = odm_convert_to_db(psd_report) + igi;
+
+	return psd_report;
+}
+
+u8		psd_result_cali_tone_8821[7]= {21, 28, 33, 93, 98, 105, 127};
+u8		psd_result_cali_val_8821[7] = {67,69,71,72,71,69,67};	
+
+void
+phydm_psd(
+	void		*dm_void,
+	u32		igi,
+	u16		start_point,
+	u16		stop_point
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u32		i = 0, mod_tone_idx;
+	u32		t = 0;
+	u16		fft_max_half_bw;
+	u32		psd_igi_a_reg;
+	u32		psd_igi_b_reg;
+	u16		psd_fc_channel = dm_psd_table->psd_fc_channel;
+	u8		ag_rf_mode_reg = 0;
+	u8		rf_reg18_9_8 = 0;
+	u32		psd_result_tmp = 0;
+	u8		psd_result = 0;
+	u8		psd_result_cali_tone[7] = {0};
+	u8		psd_result_cali_val[7] = {0};
+	u8		noise_table_idx = 0;
+	u8		set_result;
+
+	if (dm->support_ic_type == ODM_RTL8821) {
+		odm_move_memory(dm, psd_result_cali_tone, psd_result_cali_tone_8821, 7);
+		odm_move_memory(dm, psd_result_cali_val, psd_result_cali_val_8821, 7);
+	}
+	
+	dm_psd_table->psd_in_progress = 1;
+
+	/*[Stop DIG]*/
+	dm->support_ability &= ~(ODM_BB_DIG);
+	dm->support_ability &= ~(ODM_BB_FA_CNT);
+
+
+
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD Start =>\n");
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		psd_igi_a_reg = 0xc50;
+		psd_igi_b_reg = 0xe50;
+	} else {
+		psd_igi_a_reg = 0xc50;
+		psd_igi_b_reg = 0xc58;
+	}
+	
+	/*[back up IGI]*/
+	dm_psd_table->initial_gain_backup = odm_get_bb_reg(dm, psd_igi_a_reg, 0xff);
+	odm_set_bb_reg(dm, psd_igi_a_reg, 0xff, 0x6e); /*IGI target at 0dBm & make it can't CCA*/
+	odm_set_bb_reg(dm, psd_igi_b_reg, 0xff, 0x6e); /*IGI target at 0dBm & make it can't CCA*/
+	ODM_delay_us(10);
+	
+	if (phydm_stop_ic_trx(dm, PHYDM_SET) == PHYDM_SET_FAIL) {
+		PHYDM_DBG(dm, ODM_COMP_API, "STOP_TRX_FAIL\n");
+		return;
+	}
+
+	/*[Set IGI]*/
+	odm_set_bb_reg(dm, psd_igi_a_reg, 0xff, igi);
+	odm_set_bb_reg(dm, psd_igi_b_reg, 0xff, igi);
+	
+	/*[Backup RF Reg]*/
+	dm_psd_table->rf_0x18_bkp = odm_get_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK);
+	dm_psd_table->rf_0x18_bkp_b = odm_get_rf_reg(dm, RF_PATH_B, 0x18, RFREGOFFSETMASK);
+
+	if (psd_fc_channel > 14) {
+		
+		rf_reg18_9_8 = 1;
+		
+		if (36 <= psd_fc_channel && psd_fc_channel <= 64) 
+			ag_rf_mode_reg = 0x1;
+		else if (100 <= psd_fc_channel && psd_fc_channel <= 140) 
+			ag_rf_mode_reg = 0x3; 
+		else if (140 < psd_fc_channel) 
+			ag_rf_mode_reg = 0x5; 
+	}
+
+	/* RF path-a */
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0xff, psd_fc_channel);     /* Set RF fc*/
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0x300, rf_reg18_9_8);
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0xc00, dm_psd_table->psd_bw_rf_reg);     /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, 0xf0000, ag_rf_mode_reg);     /* Set RF ag fc mode*/
+
+	/* RF path-b */
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0xff, psd_fc_channel);     /* Set RF fc*/
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0x300, rf_reg18_9_8);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0xc00, dm_psd_table->psd_bw_rf_reg);     /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, 0xf0000, ag_rf_mode_reg);     /* Set RF ag fc mode*/
+
+	PHYDM_DBG(dm, ODM_COMP_API, "0xc50=((0x%x))\n", odm_get_bb_reg(dm, 0xc50, MASKDWORD));
+	/*PHYDM_DBG(dm, ODM_COMP_API, "RF0x0=((0x%x))\n", odm_get_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK));*/
+	PHYDM_DBG(dm, ODM_COMP_API, "RF0x18=((0x%x))\n", odm_get_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK));
+	
+	/*[Stop 3-wires]*/
+	phydm_stop_3_wire(dm, PHYDM_SET);
+	
+	ODM_delay_us(10);
+
+	if (stop_point > (dm_psd_table->fft_smp_point-1))
+		stop_point = (dm_psd_table->fft_smp_point-1);	
+
+	if (start_point > (dm_psd_table->fft_smp_point-1))
+		start_point = (dm_psd_table->fft_smp_point-1);
+
+	if (start_point > stop_point)
+		stop_point = start_point;
+
+
+	for (i = start_point; i <= stop_point; i++ ) {
+		fft_max_half_bw = (dm_psd_table->fft_smp_point)>>1;
+
+		if (i < fft_max_half_bw) {
+			mod_tone_idx = i + fft_max_half_bw;
+		} else {
+			mod_tone_idx = i - fft_max_half_bw;
+		}
+		
+		psd_result_tmp = 0;
+		for (t = 0; t < dm_psd_table->sw_avg_time; t++) {
+			psd_result_tmp += phydm_get_psd_data(dm, mod_tone_idx, igi);
+			/**/
+		}
+		psd_result = (u8)((psd_result_tmp/dm_psd_table->sw_avg_time)) - dm_psd_table->psd_pwr_common_offset;
+
+		if( dm_psd_table->fft_smp_point == 128 && (dm_psd_table->noise_k_en)) {
+			if (i > psd_result_cali_tone[noise_table_idx]) {
+				noise_table_idx ++;
+			}
+
+			if (noise_table_idx > 6)
+				noise_table_idx = 6;
+
+			if (psd_result >= psd_result_cali_val[noise_table_idx])
+				psd_result = psd_result - psd_result_cali_val[noise_table_idx];
+			else
+				psd_result = 0;
+			
+
+			dm_psd_table->psd_result[i] = psd_result;
+		}
+		
+		PHYDM_DBG(dm, ODM_COMP_API, "[%d] N_cali = %d, PSD = %d\n", mod_tone_idx, psd_result_cali_val[noise_table_idx],  psd_result);
+
+	}
+
+	/*[Start 3-wires]*/
+	phydm_stop_3_wire(dm, PHYDM_REVERT);
+	
+	ODM_delay_us(10);
+
+	/*[Revert Reg]*/
+	set_result = phydm_stop_ic_trx(dm, PHYDM_REVERT);
+	
+	odm_set_bb_reg(dm, psd_igi_a_reg, 0xff, dm_psd_table->initial_gain_backup);
+	odm_set_bb_reg(dm, psd_igi_b_reg, 0xff, dm_psd_table->initial_gain_backup);
+	
+	odm_set_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, dm_psd_table->rf_0x18_bkp);
+	odm_set_rf_reg(dm, RF_PATH_B, 0x18, RFREGOFFSETMASK, dm_psd_table->rf_0x18_bkp_b);
+	
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD finished\n\n");
+	
+	dm->support_ability |= ODM_BB_DIG;
+	dm->support_ability |= ODM_BB_FA_CNT;
+	dm_psd_table->psd_in_progress = 0;
+	
+
+}
+
+void
+phydm_psd_para_setting(
+	void		*dm_void,
+	u8		sw_avg_time,
+	u8		hw_avg_time,	
+	u8		i_q_setting,
+	u16		fft_smp_point,
+	u8		ant_sel,
+	u8		psd_input,
+	u8		channel,
+	u8		noise_k_en
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u8		fft_smp_point_idx = 0;
+
+	dm_psd_table->fft_smp_point = fft_smp_point;
+
+	if (sw_avg_time == 0)
+		sw_avg_time = 1;
+	
+	dm_psd_table->sw_avg_time = sw_avg_time;
+	dm_psd_table->psd_fc_channel = channel;
+	dm_psd_table->noise_k_en = noise_k_en;
+		
+	if (fft_smp_point == 128)
+		fft_smp_point_idx = 0;
+	else if (fft_smp_point == 256)
+		fft_smp_point_idx = 1;
+	else if (fft_smp_point == 512)
+		fft_smp_point_idx = 2;
+	else if (fft_smp_point == 1024)
+		fft_smp_point_idx = 3;
+		
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		odm_set_bb_reg(dm, 0x910, BIT(11) | BIT(10), i_q_setting);
+		odm_set_bb_reg(dm, 0x910, BIT(13) | BIT(12), hw_avg_time);
+		odm_set_bb_reg(dm, 0x910, BIT(15) | BIT(14), fft_smp_point_idx);
+		odm_set_bb_reg(dm, 0x910, BIT(17) | BIT(16), ant_sel);
+		odm_set_bb_reg(dm, 0x910, BIT(23), psd_input);
+#if 0
+	} else {	/*ODM_IC_11N_SERIES*/
+#endif
+	}
+
+	/*bw = (*dm->band_width); //ODM_BW20M */
+	/*channel = *(dm->channel);*/
+	
+	
+
+
+}
+
+void
+phydm_psd_init(
+	void		*dm_void
+	)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD para init\n");
+
+	dm_psd_table->psd_in_progress = false;
+	
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		
+		dm_psd_table->psd_reg = 0x910;
+		dm_psd_table->psd_report_reg = 0xF44;
+
+		if (ODM_IC_11AC_2_SERIES)
+			dm_psd_table->psd_bw_rf_reg = 1;	/*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		else
+			dm_psd_table->psd_bw_rf_reg = 2;	/*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		
+	} else {
+		dm_psd_table->psd_reg = 0x808;
+		dm_psd_table->psd_report_reg = 0x8B4;
+		dm_psd_table->psd_bw_rf_reg = 2; /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+	}
+
+	if (dm->support_ic_type == ODM_RTL8812)
+		dm_psd_table->psd_pwr_common_offset = 0;
+	else if (dm->support_ic_type == ODM_RTL8821)
+		dm_psd_table->psd_pwr_common_offset = 0;
+	else
+		dm_psd_table->psd_pwr_common_offset = 0;
+
+	phydm_psd_para_setting(dm, 1, 2, 3, 128, 0, 0, 7, 0);
+	/*phydm_psd(dm, 0x3c, 0, 127);*/			/* target at -50dBm */
+
+
+}
+
+void
+phydm_psd_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u8		i;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{0} {sw_avg} {hw_avg 0:3} {1:I,2:Q,3:IQ} {fft_point: 128*(1:4)} {path_sel 0~3} {0:ADC, 1:RXIQC} {CH} {noise_k}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {IGI(hex)} {start_point} {stop_point}\n");
+		goto out;
+	}
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if (var1[0] == 0) {
+		for (i = 1; i < 10; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+			}
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "sw_avg_time=((%d)), hw_avg_time=((%d)), IQ=((%d)), fft=((%d)), path=((%d)), input =((%d)) ch=((%d)), noise_k=((%d))\n",
+					
+					var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], (u8)var1[7], (u8)var1[8]);
+		phydm_psd_para_setting(dm, (u8)var1[1], (u8)var1[2], (u8)var1[3], (u16)var1[4], (u8)var1[5], (u8)var1[6], (u8)var1[7], (u8)var1[8]);
+
+	} else if (var1[0] == 1) {
+		PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
+		PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+		PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "IGI=((0x%x)), start_point=((%d)), stop_point=((%d))\n",
+			       var1[1], var1[2], var1[3]);
+		dm->debug_components |= ODM_COMP_API;
+		phydm_psd(dm, var1[1], (u16)var1[2], (u16)var1[3]);
+		dm->debug_components &= (~ODM_COMP_API);
+	}
+
+out:
+	*_used = used;
+	*_out_len = out_len;
+	
+}
+
+u8
+phydm_get_psd_result_table(
+	void		*dm_void,
+	int 		index
+	)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	psd_info	*dm_psd_table = &dm->dm_psd_table;
+	u8 		temp_result = 0;
+
+	if(index<128)
+		temp_result = dm_psd_table->psd_result[index];
+
+	return temp_result;
+	
+}
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_psd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_psd.h
new file mode 100644
index 000000000000..7da6f2709f40
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_psd.h
@@ -0,0 +1,103 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMPSD_H__
+#define    __PHYDMPSD_H__
+
+/*#define PSD_VERSION	"1.0"*/  /*2016.09.22  Dino*/
+#define PSD_VERSION	"1.1"  /*2016.10.07  Dino, Add Option for PSD Tone index Selection */
+
+#ifdef CONFIG_PSD_TOOL
+
+
+struct psd_info {
+	u8	psd_in_progress;
+	u32	psd_reg;
+	u32	psd_report_reg;
+	u8	psd_pwr_common_offset;
+	u16	sw_avg_time;
+	u16	fft_smp_point;
+	u32	initial_gain_backup;
+	u32	rf_0x18_bkp;
+	u32	rf_0x18_bkp_b;
+	u16	psd_fc_channel;
+	u32	psd_bw_rf_reg;
+	u8	psd_result[128];
+	u8	noise_k_en;
+};
+
+u32
+phydm_get_psd_data(
+	void			*dm_void,
+	u32			psd_tone_idx,
+	u32			igi
+);
+
+void
+phydm_psd_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+void
+phydm_psd(
+	void		*dm_void,
+	u32		igi,
+	u16		start_point,
+	u16		stop_point
+);
+
+void
+phydm_psd_para_setting(
+	void		*dm_void,
+	u8		sw_avg_time,
+	u8		hw_avg_time,
+	u8		i_q_setting,
+	u16		fft_smp_point,
+	u8		ant_sel,
+	u8		psd_input,
+	u8		channel,
+	u8		noise_k_en
+);
+
+void
+phydm_psd_init(
+	void		*dm_void
+);
+
+u8
+phydm_get_psd_result_table(
+	void		*dm_void,
+	int		index
+);
+
+#endif
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.c
index f1f21c0904ea..0726d0a38ec5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.c
@@ -1,2574 +1,2442 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#if (defined(CONFIG_RA_DBG_CMD))
-VOID
-ODM_C2HRaParaReportHandler(
-	IN	PVOID	pDM_VOID,
-	IN pu1Byte   CmdBuf,
-	IN u1Byte   CmdLen
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		    pRA_Table = &pDM_Odm->DM_RA_Table;
-
-	u1Byte  para_idx = CmdBuf[0]; //Retry Penalty, NH, NL
-	u1Byte  RateTypeStart = CmdBuf[1];
-	u1Byte  RateTypeLength = CmdLen - 2;
-	u1Byte  i;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[ From FW C2H RA Para ]  CmdBuf[0]= (( %d ))\n", CmdBuf[0]));
-
-	if (para_idx == RADBG_RTY_PENALTY) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" |Rate Index|   |RTY Penality Index| \n"));
-
-		for (i = 0 ; i < (RateTypeLength) ; i++) {
-			if (pRA_Table->is_ra_dbg_init)
-				pRA_Table->RTY_P_default[RateTypeStart + i] = CmdBuf[2 + i];
-
-			pRA_Table->RTY_P[RateTypeStart + i] = CmdBuf[2 + i];
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("%8d  %15d \n", (RateTypeStart + i), pRA_Table->RTY_P[RateTypeStart + i]));
-		}
-
-	} else	if (para_idx == RADBG_N_HIGH) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" |Rate Index|    |N-High| \n"));
-
-
-	} else	if (para_idx == RADBG_N_LOW){
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" |Rate Index|   |N-Low| \n"));
-
-	}
-	else	 if (para_idx == RADBG_RATE_UP_RTY_RATIO) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" |Rate Index|   |Rate Up RTY Ratio| \n"));
-
-		for (i = 0 ; i < (RateTypeLength) ; i++) {
-			if (pRA_Table->is_ra_dbg_init)
-				pRA_Table->RATE_UP_RTY_RATIO_default[RateTypeStart + i] = CmdBuf[2 + i];
-
-			pRA_Table->RATE_UP_RTY_RATIO[RateTypeStart + i] = CmdBuf[2 + i];
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("%8d  %15d \n", (RateTypeStart + i), pRA_Table->RATE_UP_RTY_RATIO[RateTypeStart + i]));
-		}
-	} else	 if (para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" |Rate Index|   |Rate Down RTY Ratio| \n"));
-
-		for (i = 0 ; i < (RateTypeLength) ; i++) {
-			if (pRA_Table->is_ra_dbg_init)
-				pRA_Table->RATE_DOWN_RTY_RATIO_default[RateTypeStart + i] = CmdBuf[2 + i];
-
-			pRA_Table->RATE_DOWN_RTY_RATIO[RateTypeStart + i] = CmdBuf[2 + i];
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("%8d  %15d \n", (RateTypeStart + i), pRA_Table->RATE_DOWN_RTY_RATIO[RateTypeStart + i]));
-		}
-	} else	 if (para_idx == RADBG_DEBUG_MONITOR1) {
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("-------------------------------\n"));
-		if (pDM_Odm->SupportICType & PHYDM_IC_3081_SERIES) {
-
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "RSSI =", CmdBuf[1]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "Rate =", CmdBuf[2] & 0x7f));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "SGI =", (CmdBuf[2] & 0x80) >> 7));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "BW =", CmdBuf[3]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "BW_max =", CmdBuf[4]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "multi_rate0 =", CmdBuf[5]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "multi_rate1 =", CmdBuf[6]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "DISRA =",	CmdBuf[7]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "VHT_EN =", CmdBuf[8]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "SGI_support =",	CmdBuf[9]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "try_ness =", CmdBuf[10]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "pre_rate =", CmdBuf[11]));
-		} else {
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "RSSI =", CmdBuf[1]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %x \n", "BW =", CmdBuf[2]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "DISRA =", CmdBuf[3]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "VHT_EN =", CmdBuf[4]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "Hightest Rate =", CmdBuf[5]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "Lowest Rate =", CmdBuf[6]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "SGI_support =", CmdBuf[7]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "Rate_ID =",	CmdBuf[8]));;
-		}
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("-------------------------------\n"));
-	} else	 if (para_idx == RADBG_DEBUG_MONITOR2) {
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("-------------------------------\n"));
-		if (pDM_Odm->SupportICType & PHYDM_IC_3081_SERIES) {
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %d \n", "RateID =", CmdBuf[1]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "highest_rate =", CmdBuf[2]));
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  0x%x \n", "lowest_rate =", CmdBuf[3]));
-
-			for (i = 4 ; i <= 11 ; i++)
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("RAMASK =  0x%x \n", CmdBuf[i]));
-		} else {
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  %x%x  %x%x  %x%x  %x%x \n", "RA Mask:",
-						 CmdBuf[8], CmdBuf[7], CmdBuf[6], CmdBuf[5], CmdBuf[4], CmdBuf[3], CmdBuf[2], CmdBuf[1]));
-		}
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("-------------------------------\n"));
-	} else	 if (para_idx == RADBG_DEBUG_MONITOR3) {
-
-		for (i = 0 ; i < (CmdLen - 1) ; i++)
-			ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("content[%d] =  %d \n", i, CmdBuf[1 + i]));
-	} else	 if (para_idx == RADBG_DEBUG_MONITOR4)
-		ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("%5s  {%d.%d} \n", "RA Version =", CmdBuf[1], CmdBuf[2]));
-
-}
-
-VOID
-odm_RA_ParaAdjust_Send_H2C(
-	IN	PVOID	pDM_VOID
-)
-{
-
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
-	u1Byte			H2C_Parameter[6] = {0};
-
-	H2C_Parameter[0] =  RA_FIRST_MACID;
-
-	//ODM_RT_TRACE(pDM_Odm,PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("RA_Para_feedback_req= (( %d ))  \n",pRA_Table->RA_Para_feedback_req ));
-	if (pRA_Table->RA_Para_feedback_req) { //H2C_Parameter[5]=1 ; ask FW for all RA parameters
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[H2C] Ask FW for RA parameter \n"));
-		H2C_Parameter[5] |= BIT1; //ask FW to report RA parameters
-		H2C_Parameter[1] =  pRA_Table->para_idx; //pRA_Table->para_idx;
-		pRA_Table->RA_Para_feedback_req = 0;
-	} else {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[H2C] Send H2C to FW for modifying RA parameter \n"));
-
-		H2C_Parameter[1] =  pRA_Table->para_idx;
-		H2C_Parameter[2] =  pRA_Table->rate_idx;
-		//1 [8 bit]
-		if (pRA_Table->para_idx == RADBG_RTY_PENALTY || pRA_Table->para_idx == RADBG_RATE_UP_RTY_RATIO || pRA_Table->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
-			H2C_Parameter[3] = pRA_Table->value;
-			H2C_Parameter[4] = 0;
-		}
-		//1 [16 bit]
-		else { //if ((pRA_Table->rate_idx==RADBG_N_HIGH)||(pRA_Table->rate_idx==RADBG_N_LOW))
-			H2C_Parameter[3] = (u1Byte)(((pRA_Table->value_16) & 0xf0) >> 4); //byte1
-			H2C_Parameter[4] = (u1Byte)((pRA_Table->value_16) & 0x0f);	   //byte0
-		}
-	}
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" H2C_Parameter[1] = 0x%x  \n", H2C_Parameter[1]));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" H2C_Parameter[2] = 0x%x  \n", H2C_Parameter[2]));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" H2C_Parameter[3] = 0x%x  \n", H2C_Parameter[3]));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" H2C_Parameter[4] = 0x%x  \n", H2C_Parameter[4]));
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" H2C_Parameter[5] = 0x%x  \n", H2C_Parameter[5]));
-
-	ODM_FillH2CCmd(pDM_Odm, ODM_H2C_RA_PARA_ADJUST, 6, H2C_Parameter);
-
-}
-
-
-VOID
-odm_RA_ParaAdjust(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
-	u1Byte			para_idx = pRA_Table->para_idx;
-	u1Byte			rate_idx = pRA_Table->rate_idx;
-	u1Byte			value = pRA_Table->value;
-	u1Byte			Pre_value = 0xff;
-
-	BOOLEAN			sign = 0;
-
-	if (pRA_Table->para_idx == RADBG_RTY_PENALTY) {
-		Pre_value = pRA_Table->RTY_P[rate_idx];
-		pRA_Table->RTY_P[rate_idx] = value;
-		pRA_Table->RTY_P_modify_note[rate_idx] = 1;
-	} else 	if (pRA_Table->para_idx == RADBG_N_HIGH) {
-
-	} else 	if (pRA_Table->para_idx == RADBG_N_LOW) {
-
-	} else	 if (pRA_Table->para_idx == RADBG_RATE_UP_RTY_RATIO) {
-		Pre_value = pRA_Table->RATE_UP_RTY_RATIO[rate_idx];
-		pRA_Table->RATE_UP_RTY_RATIO[rate_idx] = value;
-		pRA_Table->RATE_UP_RTY_RATIO_modify_note[rate_idx] = 1;
-	} else	 if (pRA_Table->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
-		Pre_value = pRA_Table->RATE_DOWN_RTY_RATIO[rate_idx];
-		pRA_Table->RATE_DOWN_RTY_RATIO[rate_idx] = value;
-		pRA_Table->RATE_DOWN_RTY_RATIO_modify_note[rate_idx] = 1;
-	}
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("  Change RA Papa[%d], Rate[ %d ],   ((%d))  ->  ((%d)) \n", pRA_Table->para_idx, rate_idx, Pre_value, value));
-	odm_RA_ParaAdjust_Send_H2C(pDM_Odm);
-}
-
-
-VOID
-phydm_ra_print_msg(
-	IN		PVOID		pDM_VOID,
-	IN		u1Byte		*value,
-	IN		u1Byte		*value_default,
-	IN		u1Byte		*modify_note
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
-	u4Byte i;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" |Rate index| |Current-value| |Default-value| |Modify?| \n"));
-	for (i = 0 ; i <= (pRA_Table->rate_length); i++) {
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("     [ %d ]  %20d  %25d  %20s \n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  ")));
-#else
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("     [ %d ]  %10d  %14d  %14s \n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  ")));
-#endif
-	}
-
-}
-
-VOID
-odm_RA_debug(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
-
-	pRA_Table->is_ra_dbg_init = FALSE;
-
-	if (dm_value[0] == 100) { /*1 Print RA Parameters*/
-		u1Byte	default_pointer_value;
-		u1Byte	*pvalue;
-		u1Byte	*pvalue_default;
-		u1Byte	*pmodify_note;
-
-		pvalue = pvalue_default = pmodify_note = &default_pointer_value;
-
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("\n------------------------------------------------------------------------------------\n"));
-
-		if (dm_value[1] == RADBG_RTY_PENALTY) { /* [1]*/
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" [1] RTY_PENALTY\n"));
-			pvalue		=	&(pRA_Table->RTY_P[0]);
-			pvalue_default	=	&(pRA_Table->RTY_P_default[0]);
-			pmodify_note	=	(u1Byte *)&(pRA_Table->RTY_P_modify_note[0]);
-		} else if (dm_value[1] == RADBG_N_HIGH) { /* [2]*/
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" [2] N_HIGH\n"));
-
-		} else if (dm_value[1] == RADBG_N_LOW) { /*[3]*/
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" [3] N_LOW\n"));
-
-		} else if (dm_value[1] == RADBG_RATE_UP_RTY_RATIO) { /* [8]*/
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" [8] RATE_UP_RTY_RATIO\n"));
-			pvalue		=	&(pRA_Table->RATE_UP_RTY_RATIO[0]);
-			pvalue_default	=	&(pRA_Table->RATE_UP_RTY_RATIO_default[0]);
-			pmodify_note	=	(u1Byte *)&(pRA_Table->RATE_UP_RTY_RATIO_modify_note[0]);
-		} else if (dm_value[1] == RADBG_RATE_DOWN_RTY_RATIO) { /* [9]*/
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" [9] RATE_DOWN_RTY_RATIO\n"));
-			pvalue		=	&(pRA_Table->RATE_DOWN_RTY_RATIO[0]);
-			pvalue_default	=	&(pRA_Table->RATE_DOWN_RTY_RATIO_default[0]);
-			pmodify_note	=	(u1Byte *)&(pRA_Table->RATE_DOWN_RTY_RATIO_modify_note[0]);
-		}
-
-		phydm_ra_print_msg(pDM_Odm, pvalue, pvalue_default, pmodify_note);
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("\n------------------------------------------------------------------------------------\n\n"));
-
-	} else if (dm_value[0] == 101) {
-		pRA_Table->para_idx = (u1Byte)dm_value[1];
-
-		pRA_Table->RA_Para_feedback_req = 1;
-		odm_RA_ParaAdjust_Send_H2C(pDM_Odm);
-	} else {
-		pRA_Table->para_idx = (u1Byte)dm_value[0];
-		pRA_Table->rate_idx  = (u1Byte)dm_value[1];
-		pRA_Table->value = (u1Byte)dm_value[2];
-
-		odm_RA_ParaAdjust(pDM_Odm);
-	}
-
-}
-
-VOID
-odm_RA_ParaAdjust_init(
-	IN		PVOID		pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		        pRA_Table = &pDM_Odm->DM_RA_Table;
-	u1Byte			i;
-	u1Byte			ra_para_pool_u8[3] = { RADBG_RTY_PENALTY,  RADBG_RATE_UP_RTY_RATIO, RADBG_RATE_DOWN_RTY_RATIO};
-	/*
-		RTY_PENALTY		=	1,  //u8
-		N_HIGH 				=	2,
-		N_LOW				=	3,
-		RATE_UP_TABLE		=	4,
-		RATE_DOWN_TABLE	=	5,
-		TRYING_NECESSARY	=	6,
-		DROPING_NECESSARY =	7,
-		RATE_UP_RTY_RATIO	=	8, //u8
-		RATE_DOWN_RTY_RATIO=	9, //u8
-		ALL_PARA		=	0xff
-
-	*/
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("odm_RA_ParaAdjust_init \n"));
-
-	pRA_Table->is_ra_dbg_init = TRUE;
-	for (i = 0; i < 3; i++) {
-		pRA_Table->RA_Para_feedback_req = 1;
-		pRA_Table->para_idx	=	ra_para_pool_u8[i];
-		odm_RA_ParaAdjust_Send_H2C(pDM_Odm);
-	}
-
-	if (pDM_Odm->SupportICType == ODM_RTL8192E)
-		pRA_Table->rate_length = ODM_RATEMCS15;
-	else if ((pDM_Odm->SupportICType == ODM_RTL8723B) || (pDM_Odm->SupportICType == ODM_RTL8188E))
-		pRA_Table->rate_length = ODM_RATEMCS7;
-	else if ((pDM_Odm->SupportICType == ODM_RTL8821) || (pDM_Odm->SupportICType == ODM_RTL8881A))
-		pRA_Table->rate_length = ODM_RATEVHTSS1MCS9;
-	else if (pDM_Odm->SupportICType == ODM_RTL8812)
-		pRA_Table->rate_length = ODM_RATEVHTSS2MCS9;
-	else if (pDM_Odm->SupportICType == ODM_RTL8814A)
-		pRA_Table->rate_length = ODM_RATEVHTSS3MCS9;
-	else
-		pRA_Table->rate_length = ODM_RATEVHTSS4MCS9;
-
-}
-
-#else
-
-VOID
-ODM_C2HRaParaReportHandler(
-	IN	PVOID	pDM_VOID,
-	IN pu1Byte   CmdBuf,
-	IN u1Byte   CmdLen
-)
-{
-}
-
-VOID
-odm_RA_debug(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value
-)
-{
-}
-
-VOID
-odm_RA_ParaAdjust_init(
-	IN		PVOID		pDM_VOID
-)
-
-{
-}
-
-#endif //#if (defined(CONFIG_RA_DBG_CMD))
-
-VOID
-phydm_ra_dynamic_retry_count(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		        pRA_Table = &pDM_Odm->DM_RA_Table;
-	PSTA_INFO_T		pEntry;
-	u1Byte	i, retry_offset;
-	u4Byte	ma_rx_tp;
-	/*ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("pDM_Odm->pre_b_noisy = %d\n", pDM_Odm->pre_b_noisy ));*/
-	if (pDM_Odm->pre_b_noisy != pDM_Odm->NoisyDecision) {
-
-		if (pDM_Odm->NoisyDecision) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("->Noisy Env. RA fallback value\n"));
-			ODM_SetMACReg(pDM_Odm, 0x430, bMaskDWord, 0x0);
-			ODM_SetMACReg(pDM_Odm, 0x434, bMaskDWord, 0x04030201);		
-		} else {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("->Clean Env. RA fallback value\n"));
-			ODM_SetMACReg(pDM_Odm, 0x430, bMaskDWord, 0x02010000);
-			ODM_SetMACReg(pDM_Odm, 0x434, bMaskDWord, 0x06050403);		
-		}
-		pDM_Odm->pre_b_noisy = pDM_Odm->NoisyDecision;
-	}
-}
-
-#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
-
-VOID
-phydm_retry_limit_table_bound(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte	*retry_limit,
-	IN	u1Byte	offset
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		        pRA_Table = &pDM_Odm->DM_RA_Table;
-
-	if (*retry_limit >  offset) {
-		
-		*retry_limit -= offset;
-		
-		if (*retry_limit < pRA_Table->retrylimit_low)
-			*retry_limit = pRA_Table->retrylimit_low;
-		else if (*retry_limit > pRA_Table->retrylimit_high)
-			*retry_limit = pRA_Table->retrylimit_high;
-	} else
-		*retry_limit = pRA_Table->retrylimit_low;
-}
-
-VOID
-phydm_reset_retry_limit_table(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		        pRA_Table = &pDM_Odm->DM_RA_Table;
-	u1Byte			i;
-
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) /*support all IC platform*/
-
-	#else
-		#if ((RTL8192E_SUPPORT == 1) || (RTL8723B_SUPPORT == 1) || (RTL8188E_SUPPORT == 1)) 
-			u1Byte per_rate_retrylimit_table_20M[ODM_RATEMCS15+1] = {
-				1, 1, 2, 4,					/*CCK*/
-				2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
-				2, 4, 6, 8, 12, 18, 20, 22,		/*20M HT-1SS*/
-				2, 4, 6, 8, 12, 18, 20, 22		/*20M HT-2SS*/
-			};
-			u1Byte per_rate_retrylimit_table_40M[ODM_RATEMCS15+1] = {
-				1, 1, 2, 4,					/*CCK*/
-				2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
-				4, 8, 12, 16, 24, 32, 32, 32,		/*40M HT-1SS*/
-				4, 8, 12, 16, 24, 32, 32, 32		/*40M HT-2SS*/
-			};
-
-		#elif (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) 
-
-		#elif (RTL8812A_SUPPORT == 1)
-
-		#elif(RTL8814A_SUPPORT == 1)
-
-		#else
-
-		#endif
-	#endif
-
-	memcpy(&(pRA_Table->per_rate_retrylimit_20M[0]), &(per_rate_retrylimit_table_20M[0]), ODM_NUM_RATE_IDX);
-	memcpy(&(pRA_Table->per_rate_retrylimit_40M[0]), &(per_rate_retrylimit_table_40M[0]), ODM_NUM_RATE_IDX);
-
-	for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
-		phydm_retry_limit_table_bound(pDM_Odm, &(pRA_Table->per_rate_retrylimit_20M[i]), 0);
-		phydm_retry_limit_table_bound(pDM_Odm, &(pRA_Table->per_rate_retrylimit_40M[i]), 0);
-	}	
-}
-
-VOID
-phydm_ra_dynamic_retry_limit(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		        pRA_Table = &pDM_Odm->DM_RA_Table;
-	PSTA_INFO_T		pEntry;
-	u1Byte	i, retry_offset;
-	u4Byte	ma_rx_tp;
-
-
-	if (pDM_Odm->pre_number_active_client == pDM_Odm->number_active_client) {
-		
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, (" pre_number_active_client ==  number_active_client\n"));
-		return;
-		
-	} else {
-		if (pDM_Odm->number_active_client == 1) {
-			phydm_reset_retry_limit_table(pDM_Odm);
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("one client only->reset to default value\n"));
-		} else {
-
-			retry_offset = pDM_Odm->number_active_client * pRA_Table->retry_descend_num;
-			
-			for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
-
-				phydm_retry_limit_table_bound(pDM_Odm, &(pRA_Table->per_rate_retrylimit_20M[i]), retry_offset);
-				phydm_retry_limit_table_bound(pDM_Odm, &(pRA_Table->per_rate_retrylimit_40M[i]), retry_offset);	
-			}				
-		}
-	}
-}
-
-VOID
-phydm_ra_dynamic_retry_limit_init(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		        pRA_Table = &pDM_Odm->DM_RA_Table;
-
-	pRA_Table->retry_descend_num = RA_RETRY_DESCEND_NUM;
-	pRA_Table->retrylimit_low = RA_RETRY_LIMIT_LOW;
-	pRA_Table->retrylimit_high = RA_RETRY_LIMIT_HIGH;
-	
-	phydm_reset_retry_limit_table(pDM_Odm);
-	
-}
-#else
-VOID
-phydm_ra_dynamic_retry_limit(
-	IN	PVOID	pDM_VOID
-)
-{
-}
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-VOID
-phydm_ra_dynamic_rate_id_on_assoc(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte	wireless_mode,
-	IN	u1Byte	init_rate_id
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("[ON ASSOC] rf_mode = ((0x%x)), wireless_mode = ((0x%x)), init_rate_id = ((0x%x))\n", pDM_Odm->RFType, wireless_mode, init_rate_id));
-	
-	if ((pDM_Odm->RFType == ODM_2T2R) | (pDM_Odm->RFType == ODM_2T2R_GREEN) | (pDM_Odm->RFType == ODM_2T3R) | (pDM_Odm->RFType == ODM_2T4R)) {
-		
-		if ((pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8192E)) &&
-			(wireless_mode & (ODM_WM_N24G | ODM_WM_N5G))
-			){
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("[ON ASSOC] set N-2SS ARFR5 table\n"));
-			ODM_SetMACReg(pDM_Odm, 0x4a4, bMaskDWord, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
-			ODM_SetMACReg(pDM_Odm, 0x4a8, bMaskDWord, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
-		} else if ((pDM_Odm->SupportICType & (ODM_RTL8812)) &&
-			(wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY))
-			){
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("[ON ASSOC] set AC-2SS ARFR0 table\n"));
-			ODM_SetMACReg(pDM_Odm, 0x444, bMaskDWord, 0x0fff);	/*AC-2SS, ARFR0, rate_id = 0x9*/
-			ODM_SetMACReg(pDM_Odm, 0x448, bMaskDWord, 0xff01f000);		/*AC-2SS, ARFR0, rate_id = 0x9*/
-		}
-	}
-
-}
-
-VOID
-phydm_ra_dynamic_rate_id_init(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	if (pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8192E)) {
-		
-		ODM_SetMACReg(pDM_Odm, 0x4a4, bMaskDWord, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
-		ODM_SetMACReg(pDM_Odm, 0x4a8, bMaskDWord, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
-		
-		ODM_SetMACReg(pDM_Odm, 0x444, bMaskDWord, 0x0fff);		/*AC-2SS, ARFR0, rate_id = 0x9*/
-		ODM_SetMACReg(pDM_Odm, 0x448, bMaskDWord, 0xff01f000);	/*AC-2SS, ARFR0, rate_id = 0x9*/
-	}
-}
-
-VOID
-phydm_update_rate_id(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte	rate,
-	IN	u1Byte	platform_macid
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		pRA_Table = &pDM_Odm->DM_RA_Table;
-	u1Byte		current_tx_ss;
-	u1Byte		rate_idx = rate & 0x7f; /*remove bit7 SGI*/
-	u1Byte		wireless_mode;
-	u1Byte		phydm_macid;
-	PSTA_INFO_T	pEntry;
-	
-	if (rate_idx >= ODM_RATEVHTSS2MCS0) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("Rate[%d]: (( VHT2SS-MCS%d ))\n", platform_macid, (rate_idx-ODM_RATEVHTSS2MCS0)));
-		/*dummy for SD4 check patch*/
-	} else if (rate_idx >= ODM_RATEVHTSS1MCS0) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("Rate[%d]: (( VHT1SS-MCS%d ))\n", platform_macid, (rate_idx-ODM_RATEVHTSS1MCS0)));
-		/*dummy for SD4 check patch*/
-	} else if (rate_idx >= ODM_RATEMCS0) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("Rate[%d]: (( HT-MCS%d ))\n", platform_macid, (rate_idx-ODM_RATEMCS0)));
-		/*dummy for SD4 check patch*/
-	} else {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("Rate[%d]: (( HT-MCS%d ))\n", platform_macid, rate_idx));
-		/*dummy for SD4 check patch*/
-	}
-		
-	phydm_macid = pDM_Odm->platform2phydm_macid_table[platform_macid];
-	pEntry = pDM_Odm->pODM_StaInfo[phydm_macid];
-	
-	if (IS_STA_VALID(pEntry)) {
-		wireless_mode = pEntry->WirelessMode;
-
-		if ((pDM_Odm->RFType  == ODM_2T2R) | (pDM_Odm->RFType  == ODM_2T2R_GREEN) | (pDM_Odm->RFType  == ODM_2T3R) | (pDM_Odm->RFType  == ODM_2T4R)) {
-			
-			pEntry->ratr_idx = pEntry->ratr_idx_init;
-			if (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G)) { /*N mode*/
-				if (rate_idx >= ODM_RATEMCS8 && rate_idx <= ODM_RATEMCS15) { /*2SS mode*/
-					
-					pEntry->ratr_idx = ARFR_5_RATE_ID;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("ARFR_5\n"));
-				}
-			} else if (wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY)) {/*AC mode*/
-				if (rate_idx >= ODM_RATEVHTSS2MCS0 && rate_idx <= ODM_RATEVHTSS2MCS9) {/*2SS mode*/
-					
-					pEntry->ratr_idx = ARFR_0_RATE_ID;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("ARFR_0\n"));
-				}
-			}
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("UPdate_RateID[%d]: (( 0x%x ))\n", platform_macid, pEntry->ratr_idx));
-		}
-	}
-
-}
-#endif
-
-VOID
-phydm_c2h_ra_report_handler(
-	IN PVOID	pDM_VOID,
-	IN pu1Byte   CmdBuf,
-	IN u1Byte   CmdLen
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		pRA_Table = &pDM_Odm->DM_RA_Table;
-	u1Byte	legacy_table[12] = {1,2,5,11,6,9,12,18,24,36,48,54};
-	u1Byte	macid = CmdBuf[1];
-	
-	u1Byte	rate = CmdBuf[0];
-	u1Byte	rate_idx = rate & 0x7f; /*remove bit7 SGI*/
-	u1Byte	vht_en=(rate_idx >= ODM_RATEVHTSS1MCS0)? 1 :0;	
-	u1Byte	b_sgi = (rate & 0x80)>>7;
-	
-	u1Byte	pre_rate = pRA_Table->link_tx_rate[macid];
-	u1Byte	pre_rate_idx = pre_rate & 0x7f; /*remove bit7 SGI*/
-	u1Byte	pre_vht_en=(pre_rate_idx >= ODM_RATEVHTSS1MCS0)? 1 :0;	
-	u1Byte	pre_b_sgi = (pre_rate & 0x80)>>7;
-	
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-	
-	GET_HAL_DATA(Adapter)->CurrentRARate = HwRateToMRate(rate_idx);	
-	#endif
-	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	ODM_UpdateInitRate(pDM_Odm, rate_idx);
-	#endif
-
-	/*ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD,("RA: rate_idx=0x%x , sgi = %d\n", rate_idx, b_sgi));*/
-	/*if (pDM_Odm->SupportICType & (ODM_RTL8703B))*/
-	{
-		if (CmdLen >= 4) {
-			if (CmdBuf[3] == 0) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("Init-Rate Update\n"));
-				/**/
-			} else if (CmdBuf[3] == 0xff) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("FW Level: Fix rate\n"));
-				/**/
-			} else if (CmdBuf[3] == 1) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("Try Success\n"));
-				/**/
-			} else if (CmdBuf[3] == 2) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("Try Fail & Try Again\n"));
-				/**/
-			} else if (CmdBuf[3] == 3) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("Rate Back\n"));
-				/**/
-			} else if (CmdBuf[3] == 4) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("start rate by RSSI\n"));
-				/**/
-			} else if (CmdBuf[3] == 5) {
-				ODM_RT_TRACE(pDM_Odm, ODM_FW_DEBUG_TRACE, ODM_DBG_LOUD, ("Try rate\n"));
-				/**/
-			}
-		}
-	}
-	
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("Tx Rate Update, MACID[%d] ( %s%s%s%s%d%s%s ) -> ( %s%s%s%s%d%s%s)\n",
-		macid,
-		((pre_rate_idx >= ODM_RATEVHTSS1MCS0) && (pre_rate_idx <= ODM_RATEVHTSS1MCS9)) ? "VHT 1ss  " : "",
-		((pre_rate_idx >= ODM_RATEVHTSS2MCS0) && (pre_rate_idx <= ODM_RATEVHTSS2MCS9)) ? "VHT 2ss " : "",
-		((pre_rate_idx >= ODM_RATEVHTSS3MCS0) && (pre_rate_idx <= ODM_RATEVHTSS3MCS9)) ? "VHT 3ss " : "",
-		(pre_rate_idx >= ODM_RATEMCS0) ? "MCS " : "",
-		(pre_vht_en) ? ((pre_rate_idx - ODM_RATEVHTSS1MCS0)%10) : ((pre_rate_idx >= ODM_RATEMCS0)? (pre_rate_idx - ODM_RATEMCS0) : ((pre_rate_idx <= ODM_RATE54M)?legacy_table[pre_rate_idx]:0)),
-		(pre_b_sgi) ? "-S" : "  ",
-		(pre_rate_idx >= ODM_RATEMCS0) ? "" : "M",
-		((rate_idx >= ODM_RATEVHTSS1MCS0) && (rate_idx <= ODM_RATEVHTSS1MCS9)) ? "VHT 1ss  " : "",
-		((rate_idx >= ODM_RATEVHTSS2MCS0) && (rate_idx <= ODM_RATEVHTSS2MCS9)) ? "VHT 2ss " : "",
-		((rate_idx >= ODM_RATEVHTSS3MCS0) && (rate_idx <= ODM_RATEVHTSS3MCS9)) ? "VHT 3ss " : "",
-		(rate_idx >= ODM_RATEMCS0) ? "MCS " : "",
-		(vht_en) ? ((rate_idx - ODM_RATEVHTSS1MCS0)%10) : ((rate_idx >= ODM_RATEMCS0)? (rate_idx - ODM_RATEMCS0) : ((rate_idx <= ODM_RATE54M)?legacy_table[rate_idx]:0)),
-		(b_sgi) ? "-S" : "  ",
-		(rate_idx >= ODM_RATEMCS0) ? "" : "M" ));
-
-	pRA_Table->link_tx_rate[macid] = rate;
-
-
-	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if (pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8192E))
-		phydm_update_rate_id(pDM_Odm, rate, macid);
-	#endif
-
-}
-
-VOID
-odm_RSSIMonitorInit(
-	IN		PVOID		pDM_VOID
-)
-{
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T		pRA_Table = &pDM_Odm->DM_RA_Table;
-	pRA_Table->firstconnect = FALSE;
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	pRA_Table->PT_collision_pre = TRUE;   //used in ODM_DynamicARFBSelect(WIN only)
-#endif
-#endif
-}
-
-VOID
-ODM_RAPostActionOnAssoc(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	pDM_Odm->H2C_RARpt_connect = 1;
-	odm_RSSIMonitorCheck(pDM_Odm);
-	pDM_Odm->H2C_RARpt_connect = 0;
-}
-
-VOID
-odm_RSSIMonitorCheck(
-	IN		PVOID		pDM_VOID
-)
-{
-	//
-	// For AP/ADSL use prtl8192cd_priv
-	// For CE/NIC use PADAPTER
-	//
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	if (!(pDM_Odm->SupportAbility & ODM_BB_RSSI_MONITOR))
-		return;
-
-	//
-	// 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.
-	//
-	switch	(pDM_Odm->SupportPlatform) {
-	case	ODM_WIN:
-		odm_RSSIMonitorCheckMP(pDM_Odm);
-		break;
-
-	case	ODM_CE:
-		odm_RSSIMonitorCheckCE(pDM_Odm);
-		break;
-
-	case	ODM_AP:
-		odm_RSSIMonitorCheckAP(pDM_Odm);
-		break;
-
-	case	ODM_ADSL:
-		//odm_DIGAP(pDM_Odm);
-		break;
-	}
-
-}	// odm_RSSIMonitorCheck
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-s4Byte
-phydm_FindMinimumRSSI(
-IN		PDM_ODM_T		pDM_Odm,
-IN		PADAPTER		pAdapter,
-IN OUT	BOOLEAN	*pbLink_temp
-
-	)
-{	
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PMGNT_INFO		pMgntInfo = &(pAdapter->MgntInfo);
-	BOOLEAN			act_as_ap = ACTING_AS_AP(pAdapter);
-
-	/*DbgPrint("bMediaConnect = %d,  ACTING_AS_AP = %d ,  EntryMinUndecoratedSmoothedPWDB = %d\n",
-		pMgntInfo->bMediaConnect,act_as_ap,pHalData->EntryMinUndecoratedSmoothedPWDB);*/
-
-	
-	/* 1.Determine the minimum RSSI */
-	if ((!pMgntInfo->bMediaConnect) ||	
-		(act_as_ap && (pHalData->EntryMinUndecoratedSmoothedPWDB == 0))) {/* We should check AP mode and Entry info.into consideration, revised by Roger, 2013.10.18*/
-	
-		pHalData->MinUndecoratedPWDBForDM = 0;
-		*pbLink_temp = FALSE;
-
-	} else
-		*pbLink_temp = TRUE; 
-	
-
-	if (pMgntInfo->bMediaConnect) {	/* Default port*/
-	
-		if (act_as_ap || pMgntInfo->mIbss) {
-			pHalData->MinUndecoratedPWDBForDM = pHalData->EntryMinUndecoratedSmoothedPWDB;
-			/**/
-		} else {
-			pHalData->MinUndecoratedPWDBForDM = pHalData->UndecoratedSmoothedPWDB;
-			/**/
-		}
-	} else { /* associated entry pwdb*/
-		pHalData->MinUndecoratedPWDBForDM = pHalData->EntryMinUndecoratedSmoothedPWDB;
-		/**/
-	}
-
-	return pHalData->MinUndecoratedPWDBForDM;
-}
-
-#endif
-
-VOID
-odm_RSSIMonitorCheckMP(
-	IN	PVOID	pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			H2C_Parameter[4] = {0};
-	u4Byte			i;
-	BOOLEAN			bExtRAInfo = FALSE;
-	u1Byte			cmdlen = 3;
-	u1Byte			TxBF_EN = 0, stbc_en = 0;
-
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PRT_WLAN_STA	pEntry = NULL;
-	s4Byte			tmpEntryMaxPWDB = 0, tmpEntryMinPWDB = 0xff;
-	PMGNT_INFO		pMgntInfo = &Adapter->MgntInfo;
-	PMGNT_INFO		pDefaultMgntInfo = &Adapter->MgntInfo;
-	u8Byte			curTxOkCnt = 0, curRxOkCnt = 0;
-	//BOOLEAN			FirstConnect = 0;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
-	pDIG_T			pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-#if (BEAMFORMING_SUPPORT == 1)
-	BEAMFORMING_CAP Beamform_cap = BEAMFORMING_CAP_NONE;
-#endif
-
-	PADAPTER	pLoopAdapter = GetDefaultAdapter(Adapter);
-
-	if (pDM_Odm->SupportICType & EXT_RA_INFO_SUPPORT_IC) {
-		bExtRAInfo = TRUE;
-		cmdlen = 4;
-	}
-
-	//FirstConnect = (pDM_Odm->bLinked) && (pDM_DigTable->bMediaConnect_0 == FALSE);
-	//pRA_Table->firstconnect = pHalData->bLinked;
-
-
-	/*
-		if(pDM_Odm->SupportICType == ODM_RTL8188E && (pDefaultMgntInfo->CustomerID==RT_CID_819x_HP))
-		{
-			if(curRxOkCnt >(curTxOkCnt*6))
-				PlatformEFIOWrite4Byte(Adapter, REG_ARFR0, 0x8f015);
-			else
-				PlatformEFIOWrite4Byte(Adapter, REG_ARFR0, 0xff015);
-		}
-
-
-		if(pDM_Odm->SupportICType == ODM_RTL8812 || pDM_Odm->SupportICType == ODM_RTL8821 ||
-		   pDM_Odm->SupportICType == ODM_RTL8814A|| pDM_Odm->SupportICType == ODM_RTL8822B)
-		{
-			if(curRxOkCnt >(curTxOkCnt*6))
-				H2C_Parameter[3]|=RAINFO_BE_RX_STATE;
-		}
-	*/
-
-	while (pLoopAdapter) {
-
-		if (pLoopAdapter != NULL) {
-			pMgntInfo = &pLoopAdapter->MgntInfo;
-			curTxOkCnt = pLoopAdapter->TxStats.NumTxBytesUnicast - pMgntInfo->lastTxOkCnt;
-			curRxOkCnt = pLoopAdapter->RxStats.NumRxBytesUnicast - pMgntInfo->lastRxOkCnt;
-			pMgntInfo->lastTxOkCnt = curTxOkCnt;
-			pMgntInfo->lastRxOkCnt = curRxOkCnt;
-		}
-
-		for (i = 0; i < ASSOCIATE_ENTRY_NUM; i++) {
-
-			if (IsAPModeExist(pLoopAdapter)) {
-				if (GetFirstExtAdapter(pLoopAdapter) != NULL &&
-					GetFirstExtAdapter(pLoopAdapter) == pLoopAdapter)
-					pEntry = AsocEntry_EnumStation(pLoopAdapter, i);
-				else if (GetFirstGOPort(pLoopAdapter) != NULL &&
-						 IsFirstGoAdapter(pLoopAdapter))
-					pEntry = AsocEntry_EnumStation(pLoopAdapter, i);
-			} else {
-				if (GetDefaultAdapter(pLoopAdapter) == pLoopAdapter)
-					pEntry = AsocEntry_EnumStation(pLoopAdapter, i);
-			}
-
-			if (pEntry != NULL) {
-				if (pEntry->bAssociated) {
-
-					RT_DISP_ADDR(FDM, DM_PWDB, ("pEntry->MacAddr ="), pEntry->MacAddr);
-					RT_DISP(FDM, DM_PWDB, ("pEntry->rssi = 0x%x(%d)\n",
-										   pEntry->rssi_stat.UndecoratedSmoothedPWDB, pEntry->rssi_stat.UndecoratedSmoothedPWDB));
-
-					//2 BF_en
-#if (BEAMFORMING_SUPPORT)
-					Beamform_cap = phydm_Beamforming_GetEntryBeamCapByMacId(pDM_Odm, pEntry->AssociatedMacId);
-					if (Beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
-						TxBF_EN = 1;
-#endif
-					//2 STBC_en
-					if ((IS_WIRELESS_MODE_AC(Adapter) && TEST_FLAG(pEntry->VHTInfo.STBC, STBC_VHT_ENABLE_TX)) ||
-						TEST_FLAG(pEntry->HTInfo.STBC, STBC_HT_ENABLE_TX))
-						stbc_en = 1;
-
-					if (pEntry->rssi_stat.UndecoratedSmoothedPWDB < tmpEntryMinPWDB)
-						tmpEntryMinPWDB = pEntry->rssi_stat.UndecoratedSmoothedPWDB;
-					if (pEntry->rssi_stat.UndecoratedSmoothedPWDB > tmpEntryMaxPWDB)
-						tmpEntryMaxPWDB = pEntry->rssi_stat.UndecoratedSmoothedPWDB;
-
-					if (bExtRAInfo) {
-						if (curRxOkCnt > (curTxOkCnt * 6))
-							H2C_Parameter[3] |= RAINFO_BE_RX_STATE;
-
-						if (TxBF_EN)
-							H2C_Parameter[3] |= RAINFO_BF_STATE;
-						else {
-							if (stbc_en)
-								H2C_Parameter[3] |= RAINFO_STBC_STATE;
-						}
-
-                        if ( pDM_Odm->NoisyDecision )
-                        {
-                            H2C_Parameter[3] |= RAINFO_NOISY_STATE;             // BIT2 
-                        }
-						else
-							H2C_Parameter[3] &= (~RAINFO_NOISY_STATE);
-                        
-						if (pDM_Odm->H2C_RARpt_connect)
-							H2C_Parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
-					}
-
-					H2C_Parameter[2] = (u1Byte)(pEntry->rssi_stat.UndecoratedSmoothedPWDB & 0xFF);
-					//H2C_Parameter[1] = 0x20;   // fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1
-					H2C_Parameter[0] = (pEntry->AssociatedMacId);
-
-					ODM_FillH2CCmd(pDM_Odm, ODM_H2C_RSSI_REPORT, cmdlen, H2C_Parameter);
-				}
-			} else
-				break;
-		}
-
-		pLoopAdapter = GetNextExtAdapter(pLoopAdapter);
-	}
-
-	if (tmpEntryMaxPWDB != 0) {	// If associated entry is found
-		pHalData->EntryMaxUndecoratedSmoothedPWDB = tmpEntryMaxPWDB;
-		RT_DISP(FDM, DM_PWDB, ("EntryMaxPWDB = 0x%x(%d)\n",	tmpEntryMaxPWDB, tmpEntryMaxPWDB));
-	} else
-		pHalData->EntryMaxUndecoratedSmoothedPWDB = 0;
-
-	if (tmpEntryMinPWDB != 0xff) { // If associated entry is found
-		pHalData->EntryMinUndecoratedSmoothedPWDB = tmpEntryMinPWDB;
-		RT_DISP(FDM, DM_PWDB, ("EntryMinPWDB = 0x%x(%d)\n", tmpEntryMinPWDB, tmpEntryMinPWDB));
-
-	} else
-		pHalData->EntryMinUndecoratedSmoothedPWDB = 0;
-
-	// Indicate Rx signal strength to FW.
-	if (pHalData->bUseRAMask) {
-		PRT_HIGH_THROUGHPUT 		pHTInfo = GET_HT_INFO(pDefaultMgntInfo);
-		PRT_VERY_HIGH_THROUGHPUT	pVHTInfo = GET_VHT_INFO(pDefaultMgntInfo);
-
-		//2 BF_en
-#if (BEAMFORMING_SUPPORT == 1)
-		Beamform_cap = phydm_Beamforming_GetEntryBeamCapByMacId(pDM_Odm, pDefaultMgntInfo->mMacId);
-
-		if (Beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
-			TxBF_EN = 1;
-#endif
-
-		//2 STBC_en
-		if ((IS_WIRELESS_MODE_AC(Adapter) && TEST_FLAG(pVHTInfo->VhtCurStbc, STBC_VHT_ENABLE_TX)) ||
-			TEST_FLAG(pHTInfo->HtCurStbc, STBC_HT_ENABLE_TX))
-			stbc_en = 1;
-
-		if (bExtRAInfo) {
-			if (TxBF_EN)
-				H2C_Parameter[3] |= RAINFO_BF_STATE;
-			else {
-				if (stbc_en)
-					H2C_Parameter[3] |= RAINFO_STBC_STATE;
-			}
-
-			if (pDM_Odm->H2C_RARpt_connect)
-				H2C_Parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
-			
-            if ( pDM_Odm->NoisyDecision==1 )
-            {
-                H2C_Parameter[3] |= RAINFO_NOISY_STATE;             // BIT2
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_NOISY_DETECT, ODM_DBG_LOUD, ("[RSSIMonitorCheckMP] Send H2C to FW\n"));
-            }
-			else
-				H2C_Parameter[3] &= (~RAINFO_NOISY_STATE);
-
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_NOISY_DETECT, ODM_DBG_LOUD, ("[RSSIMonitorCheckMP] H2C_Parameter=%x\n", H2C_Parameter[3]));
-		}
-
-		H2C_Parameter[2] = (u1Byte)(pHalData->UndecoratedSmoothedPWDB & 0xFF);
-		//H2C_Parameter[1] = 0x20;	// fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1
-		H2C_Parameter[0] = 0;		// fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1
-
-		ODM_FillH2CCmd(pDM_Odm, ODM_H2C_RSSI_REPORT, cmdlen, H2C_Parameter);
-
-		// BT 3.0 HS mode Rssi
-		if (pDM_Odm->bBtHsOperation) {
-			H2C_Parameter[2] = pDM_Odm->btHsRssi;
-			//H2C_Parameter[1] = 0x0;
-			H2C_Parameter[0] = 2;
-
-			ODM_FillH2CCmd(pDM_Odm, ODM_H2C_RSSI_REPORT, cmdlen, H2C_Parameter);
-		}
-	} else
-		PlatformEFIOWrite1Byte(Adapter, 0x4fe, (u1Byte)pHalData->UndecoratedSmoothedPWDB);
-
-	if ((pDM_Odm->SupportICType == ODM_RTL8812) || (pDM_Odm->SupportICType == ODM_RTL8192E))
-		odm_RSSIDumpToRegister(pDM_Odm);
-
-
-	{
-		PADAPTER pLoopAdapter = GetDefaultAdapter(Adapter);
-		BOOLEAN		default_pointer_value, *pbLink_temp = &default_pointer_value;
-		s4Byte	GlobalRSSI_min = 0xFF, LocalRSSI_Min;
-		BOOLEAN		bLink = FALSE;
-
-		while (pLoopAdapter) {
-			LocalRSSI_Min = phydm_FindMinimumRSSI(pDM_Odm, pLoopAdapter, pbLink_temp);
-			//DbgPrint("pHalData->bLinked=%d, LocalRSSI_Min=%d\n", pHalData->bLinked, LocalRSSI_Min);
-			if ((LocalRSSI_Min < GlobalRSSI_min) && (LocalRSSI_Min != 0))
-				GlobalRSSI_min = LocalRSSI_Min;
-
-			if (*pbLink_temp)
-				bLink = TRUE;
-
-			pLoopAdapter = GetNextExtAdapter(pLoopAdapter);
-		}
-
-		pHalData->bLinked = bLink;
-		ODM_CmnInfoUpdate(&pHalData->DM_OutSrc , ODM_CMNINFO_LINK, (u8Byte)bLink);
-
-		if (bLink)
-			ODM_CmnInfoUpdate(&pHalData->DM_OutSrc, ODM_CMNINFO_RSSI_MIN, (u8Byte)GlobalRSSI_min);
-		else
-			ODM_CmnInfoUpdate(&pHalData->DM_OutSrc, ODM_CMNINFO_RSSI_MIN, 0);
-
-	}
-
-#endif	// #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-/*H2C_RSSI_REPORT*/
-s8 phydm_rssi_report(PDM_ODM_T pDM_Odm, u8 mac_id)
-{
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(Adapter);
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
-	u8 H2C_Parameter[4] = {0};
-	u8 UL_DL_STATE = 0, STBC_TX = 0, TxBF_EN = 0;
-	u8 cmdlen = 4, first_connect = _FALSE;
-	u64	curTxOkCnt = 0, curRxOkCnt = 0;
-	PSTA_INFO_T pEntry = pDM_Odm->pODM_StaInfo[mac_id];
-	
-	if (!IS_STA_VALID(pEntry))
-		return _FAIL;
-
-	if (mac_id != pEntry->mac_id) {
-		DBG_871X("%s mac_id:%u:%u invalid\n", __func__, mac_id, pEntry->mac_id);
-		rtw_warn_on(1);
-		return _FAIL;
-	}	
-	
-	if (IS_MCAST(pEntry->hwaddr))  /*if(psta->mac_id ==1)*/
-		return _FAIL;
-
-	if (pEntry->rssi_stat.UndecoratedSmoothedPWDB == (-1)) {
-		DBG_871X("%s mac_id:%u, mac:"MAC_FMT", rssi == -1\n", __func__, pEntry->mac_id, MAC_ARG(pEntry->hwaddr));
-		return _FAIL;
-	}
-
-	curTxOkCnt = pdvobjpriv->traffic_stat.cur_tx_bytes;
-	curRxOkCnt = pdvobjpriv->traffic_stat.cur_rx_bytes;
-	if (curRxOkCnt > (curTxOkCnt * 6))
-		UL_DL_STATE = 1;
-	else
-		UL_DL_STATE = 0;
-	
-	#ifdef CONFIG_BEAMFORMING
-	{
-		#if (BEAMFORMING_SUPPORT == 1)
-		BEAMFORMING_CAP Beamform_cap = phydm_Beamforming_GetEntryBeamCapByMacId(pDM_Odm, pEntry->mac_id);
-		#else/*for drv beamforming*/
-		BEAMFORMING_CAP Beamform_cap = beamforming_get_entry_beam_cap_by_mac_id(&Adapter->mlmepriv, pEntry->mac_id);
-		#endif
-
-		if (Beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
-			TxBF_EN = 1;
-		else
-			TxBF_EN = 0;
-	}
-	#endif /*#ifdef CONFIG_BEAMFORMING*/
-		
-	if (TxBF_EN)
-		STBC_TX = 0;
-	else {
-		#ifdef CONFIG_80211AC_VHT
-		if (IsSupportedVHT(pEntry->wireless_mode))
-			STBC_TX = TEST_FLAG(pEntry->vhtpriv.stbc_cap, STBC_VHT_ENABLE_TX);
-		else
-		#endif
-			STBC_TX = TEST_FLAG(pEntry->htpriv.stbc_cap, STBC_HT_ENABLE_TX);
-	}
-		
-	H2C_Parameter[0] = (u8)(pEntry->mac_id & 0xFF);
-	H2C_Parameter[2] = pEntry->rssi_stat.UndecoratedSmoothedPWDB & 0x7F;
-		
-	if (UL_DL_STATE)
-		H2C_Parameter[3] |= RAINFO_BE_RX_STATE;
-		
-	if (TxBF_EN)
-		H2C_Parameter[3] |= RAINFO_BF_STATE;
-	if (STBC_TX)
-		H2C_Parameter[3] |= RAINFO_STBC_STATE;
-	if (pDM_Odm->NoisyDecision)
-		H2C_Parameter[3] |= RAINFO_NOISY_STATE;
-		
-	if (pEntry->ra_rpt_linked == _FALSE) {
-		H2C_Parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
-		pEntry->ra_rpt_linked = _TRUE;
-		first_connect = _TRUE;
-	}
-		
-	#if 1
-	if (first_connect) {
-		DBG_871X("%s mac_id:%u, mac:"MAC_FMT", rssi:%d\n", __func__,
-			pEntry->mac_id, MAC_ARG(pEntry->hwaddr), pEntry->rssi_stat.UndecoratedSmoothedPWDB);
-			
-		DBG_871X("%s RAINFO - TP:%s, TxBF:%s, STBC:%s, Noisy:%s, Firstcont:%s\n", __func__,
-			(UL_DL_STATE) ? "DL" : "UL", (TxBF_EN) ? "EN" : "DIS", (STBC_TX) ? "EN" : "DIS",
-			(pDM_Odm->NoisyDecision) ? "True" : "False", (first_connect) ? "True" : "False");
-	}
-	#endif
-		
-	if (pHalData->fw_ractrl == _TRUE) {
-		#if (RTL8188E_SUPPORT == 1)
-		if (pDM_Odm->SupportICType == ODM_RTL8188E)
-			cmdlen = 3;
-		#endif
-		ODM_FillH2CCmd(pDM_Odm, ODM_H2C_RSSI_REPORT, cmdlen, H2C_Parameter);
-	} else {
-		#if ((RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1))
-		if (pDM_Odm->SupportICType == ODM_RTL8188E)
-			ODM_RA_SetRSSI_8188E(pDM_Odm, (u8)(pEntry->mac_id & 0xFF), pEntry->rssi_stat.UndecoratedSmoothedPWDB & 0x7F);
-		#endif
-	}
-	return _SUCCESS;
-}
-
-void phydm_ra_rssi_rpt_wk_hdl(PVOID pContext)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pContext;
-	int i;
-	u8 mac_id = 0xFF;
-	PSTA_INFO_T	pEntry = NULL;	
-	
-	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		pEntry = pDM_Odm->pODM_StaInfo[i];
-		if (IS_STA_VALID(pEntry)) {
-			if (IS_MCAST(pEntry->hwaddr))  /*if(psta->mac_id ==1)*/
-				continue;
-			if (pEntry->ra_rpt_linked == _FALSE) {
-				mac_id = i;
-				break;
-			}
-		}
-	}
-	if (mac_id != 0xFF)
-		phydm_rssi_report(pDM_Odm, mac_id);
-}
-void phydm_ra_rssi_rpt_wk(PVOID pContext)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pContext;
-	
-	rtw_run_in_thread_cmd(pDM_Odm->Adapter, phydm_ra_rssi_rpt_wk_hdl, pDM_Odm);
-}
-#endif
-
-VOID
-odm_RSSIMonitorCheckCE(
-	IN		PVOID		pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);	
-	PSTA_INFO_T           pEntry;
-	int	i;
-	int	tmpEntryMaxPWDB = 0, tmpEntryMinPWDB = 0xff;
-	u8	sta_cnt = 0;
-	
-	if (pDM_Odm->bLinked != _TRUE)
-		return;	
-
-	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		pEntry = pDM_Odm->pODM_StaInfo[i];
-		if (IS_STA_VALID(pEntry)) {
-			if (IS_MCAST(pEntry->hwaddr))  /*if(psta->mac_id ==1)*/
-				continue;
-
-			if (pEntry->rssi_stat.UndecoratedSmoothedPWDB == (-1))
-				continue;
-
-			if (pEntry->rssi_stat.UndecoratedSmoothedPWDB < tmpEntryMinPWDB)
-				tmpEntryMinPWDB = pEntry->rssi_stat.UndecoratedSmoothedPWDB;
-
-			if (pEntry->rssi_stat.UndecoratedSmoothedPWDB > tmpEntryMaxPWDB)
-				tmpEntryMaxPWDB = pEntry->rssi_stat.UndecoratedSmoothedPWDB;
-
-			if (phydm_rssi_report(pDM_Odm, i))
-				sta_cnt++;
-		}
-	}
-	/*DBG_871X("%s==> sta_cnt(%d)\n", __func__, sta_cnt);*/
-
-	if (tmpEntryMaxPWDB != 0)	// If associated entry is found
-		pHalData->EntryMaxUndecoratedSmoothedPWDB = tmpEntryMaxPWDB;
-	else
-		pHalData->EntryMaxUndecoratedSmoothedPWDB = 0;
-
-	if (tmpEntryMinPWDB != 0xff) // If associated entry is found
-		pHalData->EntryMinUndecoratedSmoothedPWDB = tmpEntryMinPWDB;
-	else
-		pHalData->EntryMinUndecoratedSmoothedPWDB = 0;
-
-	FindMinimumRSSI(Adapter);//get pdmpriv->MinUndecoratedPWDBForDM
-
-	pDM_Odm->RSSI_Min = pHalData->MinUndecoratedPWDBForDM;
-	//ODM_CmnInfoUpdate(&pHalData->odmpriv ,ODM_CMNINFO_RSSI_MIN, pdmpriv->MinUndecoratedPWDBForDM);
-#endif//if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-}
-
-
-VOID
-odm_RSSIMonitorCheckAP(
-	IN		PVOID		pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-#if (RTL8812A_SUPPORT||RTL8881A_SUPPORT||RTL8192E_SUPPORT||RTL8814A_SUPPORT)
-
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte 			H2C_Parameter[4] = {0};
-	u4Byte			 i;
-	BOOLEAN			bExtRAInfo = FALSE;
-	u1Byte			cmdlen = 3 ;
-	u1Byte			TxBF_EN = 0, stbc_en = 0;
-
-	prtl8192cd_priv	priv		= pDM_Odm->priv;
-	PSTA_INFO_T 		pstat;
-	BOOLEAN			act_bfer = FALSE;
-
-#ifdef BEAMFORMING_SUPPORT
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	pBDC_T	pDM_BdcTable = &pDM_Odm->DM_BdcTable;
-	pDM_BdcTable->num_Txbfee_Client = 0;
-	pDM_BdcTable->num_Txbfer_Client = 0;
-#endif
-#endif
-
-	if (pDM_Odm->H2C_RARpt_connect) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("[RA Init] First Connected\n"));
-		/**/
-	} else if (priv->up_time % 2)
-		return;
-
-	if (pDM_Odm->SupportICType & EXT_RA_INFO_SUPPORT_IC) {
-		bExtRAInfo = TRUE;
-		cmdlen = 4;
-	}
-
-	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		pstat = pDM_Odm->pODM_StaInfo[i];
-
-		if (IS_STA_VALID(pstat)) {
-			if (pstat->sta_in_firmware != 1)
-				continue;
-
-			//2 BF_en
-#ifdef BEAMFORMING_SUPPORT
-			BEAMFORMING_CAP Beamform_cap = Beamforming_GetEntryBeamCapByMacId(priv, pstat->aid);
-
-			if (Beamform_cap == BEAMFORMER_CAP_HT_EXPLICIT || Beamform_cap == BEAMFORMER_CAP_VHT_SU ||
-				Beamform_cap == (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMEE_CAP_HT_EXPLICIT) ||
-				Beamform_cap == (BEAMFORMER_CAP_VHT_SU | BEAMFORMEE_CAP_VHT_SU)) {
-				TxBF_EN = 1;
-				act_bfer = TRUE;
-			}
-
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*BDC*/
-
-			if (act_bfer == TRUE) {
-				pDM_BdcTable->w_BFee_Client[i] = 1; //AP act as BFer
-				pDM_BdcTable->num_Txbfee_Client++;
-			} else {
-				pDM_BdcTable->w_BFee_Client[i] = 0; //AP act as BFer
-			}
-
-			if ((Beamform_cap & BEAMFORMEE_CAP_HT_EXPLICIT) || (Beamform_cap & BEAMFORMEE_CAP_VHT_SU)) {
-				pDM_BdcTable->w_BFer_Client[i] = 1; //AP act as BFee
-				pDM_BdcTable->num_Txbfer_Client++;
-			} else {
-				pDM_BdcTable->w_BFer_Client[i] = 0; //AP act as BFer
-			}
-#endif
-#endif
-
-			//2 STBC_en
-			if ((priv->pmib->dot11nConfigEntry.dot11nSTBC) &&
-				((pstat->ht_cap_buf.ht_cap_info & cpu_to_le16(_HTCAP_RX_STBC_CAP_))
-#ifdef RTK_AC_SUPPORT
-				 || (pstat->vht_cap_buf.vht_cap_info & cpu_to_le32(_VHTCAP_RX_STBC_CAP_))
-#endif
-				))
-				stbc_en = 1;
-
-			//2 RAINFO
-
-			if (bExtRAInfo) {
-				if ((pstat->rx_avarage)  > ((pstat->tx_avarage) * 6))
-					H2C_Parameter[3] |= RAINFO_BE_RX_STATE;
-
-				if (TxBF_EN)
-					H2C_Parameter[3] |= RAINFO_BF_STATE;
-				else {
-					if (stbc_en)
-						H2C_Parameter[3] |= RAINFO_STBC_STATE;
-				}
-
-                if ( pDM_Odm->NoisyDecision )
-                {
-                    H2C_Parameter[3] |= RAINFO_NOISY_STATE;             // BIT2
-                }
-				else
-					H2C_Parameter[3] &= (~RAINFO_NOISY_STATE);
-				
-				if (pDM_Odm->H2C_RARpt_connect) {
-					H2C_Parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_RATE_ADAPTIVE, ODM_DBG_LOUD, ("[RA Init] set Init rate by RSSI\n"));
-				}
-
-				/*ODM_RT_TRACE(pDM_Odm,PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[RAINFO] H2C_Para[3] = %x\n",H2C_Parameter[3]));*/
-			}
-
-			H2C_Parameter[2] = (u1Byte)(pstat->rssi & 0xFF);
-			H2C_Parameter[0] = REMAP_AID(pstat);
-
-            ODM_RT_TRACE(pDM_Odm,ODM_COMP_COMMON, ODM_DBG_LOUD,
-            ("H2C_Parameter[3]=%d\n", H2C_Parameter[3]));
-
-			//ODM_RT_TRACE(pDM_Odm,PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[RSSI] H2C_Para[2] = %x,  \n",H2C_Parameter[2]));
-			//ODM_RT_TRACE(pDM_Odm,PHYDM_COMP_RA_DBG, ODM_DBG_LOUD, ("[MACID] H2C_Para[0] = %x,  \n",H2C_Parameter[0]));
-
-			ODM_FillH2CCmd(pDM_Odm, ODM_H2C_RSSI_REPORT, cmdlen, H2C_Parameter);
-
-		}
-	}
-
-#endif
-#endif
-
-}
-
-
-VOID
-odm_RateAdaptiveMaskInit(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_RATE_ADAPTIVE	pOdmRA = &pDM_Odm->RateAdaptive;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PMGNT_INFO		pMgntInfo = &pDM_Odm->Adapter->MgntInfo;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pDM_Odm->Adapter);
-
-	pMgntInfo->Ratr_State = DM_RATR_STA_INIT;
-
-	if (pMgntInfo->DM_Type == DM_Type_ByDriver)
-		pHalData->bUseRAMask = TRUE;
-	else
-		pHalData->bUseRAMask = FALSE;
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	pOdmRA->Type = DM_Type_ByDriver;
-	if (pOdmRA->Type == DM_Type_ByDriver)
-		pDM_Odm->bUseRAMask = _TRUE;
-	else
-		pDM_Odm->bUseRAMask = _FALSE;
-#endif
-
-	pOdmRA->RATRState = DM_RATR_STA_INIT;
-
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	if (pDM_Odm->SupportICType == ODM_RTL8812)
-		pOdmRA->LdpcThres = 50;
-	else
-		pOdmRA->LdpcThres = 35;
-
-	pOdmRA->RtsThres = 35;
-
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	pOdmRA->LdpcThres = 35;
-	pOdmRA->bUseLdpc = FALSE;
-
-#else
-	pOdmRA->UltraLowRSSIThresh = 9;
-
-#endif
-
-	pOdmRA->HighRSSIThresh = 50;
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP) && \
-	((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-	pOdmRA->LowRSSIThresh = 23;
-#else
-	pOdmRA->LowRSSIThresh = 20;
-#endif
-}
-/*-----------------------------------------------------------------------------
- * 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.
- *
- *---------------------------------------------------------------------------*/
-VOID
-odm_RefreshRateAdaptiveMask(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_TRACE, ("odm_RefreshRateAdaptiveMask()---------->\n"));
-	if (!(pDM_Odm->SupportAbility & ODM_BB_RA_MASK)) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_TRACE, ("odm_RefreshRateAdaptiveMask(): Return cos not supported\n"));
-		return;
-	}
-	//
-	// 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.
-	//
-	switch	(pDM_Odm->SupportPlatform) {
-	case	ODM_WIN:
-		odm_RefreshRateAdaptiveMaskMP(pDM_Odm);
-		break;
-
-	case	ODM_CE:
-		odm_RefreshRateAdaptiveMaskCE(pDM_Odm);
-		break;
-
-	case	ODM_AP:
-	case	ODM_ADSL:
-		odm_RefreshRateAdaptiveMaskAPADSL(pDM_Odm);
-		break;
-	}
-
-}
-
-VOID
-odm_RefreshRateAdaptiveMaskMP(
-	IN		PVOID		pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				pAdapter	 =  pDM_Odm->Adapter;
-	PADAPTER 				pTargetAdapter = NULL;
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(pAdapter);
-	PMGNT_INFO				pMgntInfo = GetDefaultMgntInfo(pAdapter);
-
-	if (pAdapter->bDriverStopped) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_TRACE, ("<---- odm_RefreshRateAdaptiveMask(): driver is going to unload\n"));
-		return;
-	}
-
-	if (!pHalData->bUseRAMask) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("<---- odm_RefreshRateAdaptiveMask(): driver does not control rate adaptive mask\n"));
-		return;
-	}
-
-	// if default port is connected, update RA table for default port (infrastructure mode only)
-	if (pMgntInfo->mAssoc && (!ACTING_AS_AP(pAdapter))) {
-		odm_RefreshLdpcRtsMP(pAdapter, pDM_Odm, pMgntInfo->mMacId,  pMgntInfo->IOTPeer, pHalData->UndecoratedSmoothedPWDB);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("odm_RefreshRateAdaptiveMask(): Infrasture Mode\n"));
-		if (ODM_RAStateCheck(pDM_Odm, pHalData->UndecoratedSmoothedPWDB, pMgntInfo->bSetTXPowerTrainingByOid, &pMgntInfo->Ratr_State)) {
-			ODM_PRINT_ADDR(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("Target AP addr : "), pMgntInfo->Bssid);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("RSSI:%d, RSSI_LEVEL:%d\n", pHalData->UndecoratedSmoothedPWDB, pMgntInfo->Ratr_State));
-			pAdapter->HalFunc.UpdateHalRAMaskHandler(pAdapter, pMgntInfo->mMacId, NULL, pMgntInfo->Ratr_State);
-		} else if (pDM_Odm->bChangeState) {
-			ODM_PRINT_ADDR(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("Target AP addr : "), pMgntInfo->Bssid);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("Change Power Training State, bDisablePowerTraining = %d\n", pDM_Odm->bDisablePowerTraining));
-			pAdapter->HalFunc.UpdateHalRAMaskHandler(pAdapter, pMgntInfo->mMacId, NULL, pMgntInfo->Ratr_State);
-		}
-	}
-
-	//
-	// The following part configure AP/VWifi/IBSS rate adaptive mask.
-	//
-
-	if (pMgntInfo->mIbss) 	// Target: AP/IBSS peer.
-		pTargetAdapter = GetDefaultAdapter(pAdapter);
-	else
-		pTargetAdapter = GetFirstAPAdapter(pAdapter);
-
-	// if extension port (softap) is started, updaet RA table for more than one clients associate
-	if (pTargetAdapter != NULL) {
-		int	i;
-		PRT_WLAN_STA	pEntry;
-
-		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-			pEntry = AsocEntry_EnumStation(pTargetAdapter, i);
-			if (NULL != pEntry) {
-				if (pEntry->bAssociated) {
-					odm_RefreshLdpcRtsMP(pAdapter, pDM_Odm, pEntry->AssociatedMacId, pEntry->IOTPeer, pEntry->rssi_stat.UndecoratedSmoothedPWDB);
-
-					if (ODM_RAStateCheck(pDM_Odm, pEntry->rssi_stat.UndecoratedSmoothedPWDB, pMgntInfo->bSetTXPowerTrainingByOid, &pEntry->Ratr_State)) {
-						ODM_PRINT_ADDR(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("Target STA addr : "), pEntry->MacAddr);
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("RSSI:%d, RSSI_LEVEL:%d\n", pEntry->rssi_stat.UndecoratedSmoothedPWDB, pEntry->Ratr_State));
-						pAdapter->HalFunc.UpdateHalRAMaskHandler(pTargetAdapter, pEntry->AssociatedMacId, pEntry, pEntry->Ratr_State);
-					} else if (pDM_Odm->bChangeState) {
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("Change Power Training State, bDisablePowerTraining = %d\n", pDM_Odm->bDisablePowerTraining));
-						pAdapter->HalFunc.UpdateHalRAMaskHandler(pAdapter, pMgntInfo->mMacId, NULL, pMgntInfo->Ratr_State);
-					}
-				}
-			}
-		}
-	}
-
-	if (pMgntInfo->bSetTXPowerTrainingByOid)
-		pMgntInfo->bSetTXPowerTrainingByOid = FALSE;
-#endif	// #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-}
-
-
-VOID
-odm_RefreshRateAdaptiveMaskCE(
-	IN	PVOID	pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	i;
-	PADAPTER	pAdapter	 =  pDM_Odm->Adapter;
-	PODM_RATE_ADAPTIVE		pRA = &pDM_Odm->RateAdaptive;
-
-	if (RTW_CANNOT_RUN(pAdapter)) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_TRACE, ("<---- odm_RefreshRateAdaptiveMask(): driver is going to unload\n"));
-		return;
-	}
-
-	if (!pDM_Odm->bUseRAMask) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("<---- odm_RefreshRateAdaptiveMask(): driver does not control rate adaptive mask\n"));
-		return;
-	}
-
-	//printk("==> %s \n",__FUNCTION__);
-
-	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		PSTA_INFO_T pstat = pDM_Odm->pODM_StaInfo[i];
-		if (IS_STA_VALID(pstat)) {
-			if (IS_MCAST(pstat->hwaddr))  //if(psta->mac_id ==1)
-				continue;
-
-#if((RTL8812A_SUPPORT==1)||(RTL8821A_SUPPORT==1))
-			if ((pDM_Odm->SupportICType == ODM_RTL8812) || (pDM_Odm->SupportICType == ODM_RTL8821)) {
-				if (pstat->rssi_stat.UndecoratedSmoothedPWDB < pRA->LdpcThres) {
-					pRA->bUseLdpc = TRUE;
-					pRA->bLowerRtsRate = TRUE;
-					if ((pDM_Odm->SupportICType == ODM_RTL8821) && (pDM_Odm->CutVersion == ODM_CUT_A))
-						Set_RA_LDPC_8812(pstat, TRUE);
-					//DbgPrint("RSSI=%d, bUseLdpc = TRUE\n", pHalData->UndecoratedSmoothedPWDB);
-				} else if (pstat->rssi_stat.UndecoratedSmoothedPWDB > (pRA->LdpcThres - 5)) {
-					pRA->bUseLdpc = FALSE;
-					pRA->bLowerRtsRate = FALSE;
-					if ((pDM_Odm->SupportICType == ODM_RTL8821) && (pDM_Odm->CutVersion == ODM_CUT_A))
-						Set_RA_LDPC_8812(pstat, FALSE);
-					//DbgPrint("RSSI=%d, bUseLdpc = FALSE\n", pHalData->UndecoratedSmoothedPWDB);
-				}
-			}
-#endif
-
-			if (TRUE == ODM_RAStateCheck(pDM_Odm, pstat->rssi_stat.UndecoratedSmoothedPWDB, FALSE , &pstat->rssi_level)) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("RSSI:%d, RSSI_LEVEL:%d\n", pstat->rssi_stat.UndecoratedSmoothedPWDB, pstat->rssi_level));
-				//printk("RSSI:%d, RSSI_LEVEL:%d\n", pstat->rssi_stat.UndecoratedSmoothedPWDB, pstat->rssi_level);
-				rtw_hal_update_ra_mask(pstat, pstat->rssi_level);
-			} else if (pDM_Odm->bChangeState) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("Change Power Training State, bDisablePowerTraining = %d\n", pDM_Odm->bDisablePowerTraining));
-				rtw_hal_update_ra_mask(pstat, pstat->rssi_level);
-			}
-
-		}
-	}
-
-#endif
-}
-
-VOID
-odm_RefreshRateAdaptiveMaskAPADSL(
-	IN	PVOID	pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	struct rtl8192cd_priv *priv = pDM_Odm->priv;
-	struct aid_obj *aidarray;
-	u4Byte i;
-	PSTA_INFO_T pstat;
-
-	if (priv->up_time % 2)
-		return;
-
-	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		pstat = pDM_Odm->pODM_StaInfo[i];
-
-		if (IS_STA_VALID(pstat)) {
-#if defined(UNIVERSAL_REPEATER) || defined(MBSSID)
-			aidarray = container_of(pstat, struct aid_obj, station);
-			priv = aidarray->priv;
-#endif
-
-			if (!priv->pmib->dot11StationConfigEntry.autoRate)
-				continue;
-
-			if (ODM_RAStateCheck(pDM_Odm, (s4Byte)pstat->rssi, FALSE, &pstat->rssi_level)) {
-				ODM_PRINT_ADDR(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("Target STA addr : "), pstat->hwaddr);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("RSSI:%d, RSSI_LEVEL:%d\n", pstat->rssi, pstat->rssi_level));
-
-#ifdef CONFIG_WLAN_HAL
-				if (IS_HAL_CHIP(priv)) {
-#ifdef WDS
-//					if(!(pstat->state & WIFI_WDS))//if WDS donot setting
-#endif
-					GET_HAL_INTERFACE(priv)->UpdateHalRAMaskHandler(priv, pstat, pstat->rssi_level);
-				} else
-#endif
-#ifdef CONFIG_RTL_8812_SUPPORT
-					if (GET_CHIP_VER(priv) == VERSION_8812E)
-						UpdateHalRAMask8812(priv, pstat, 3);
-					else
-#endif
-#ifdef CONFIG_RTL_88E_SUPPORT
-						if (GET_CHIP_VER(priv) == VERSION_8188E) {
-#ifdef TXREPORT
-							add_RATid(priv, pstat);
-#endif
-						} else
-#endif
-						{
-#if defined(CONFIG_RTL_92D_SUPPORT) || defined(CONFIG_RTL_92C_SUPPORT)
-							add_update_RATid(priv, pstat);
-#endif
-						}
-			}
-		}
-	}
-#endif
-}
-
-
-// Return Value: BOOLEAN
-// - TRUE: RATRState is changed.
-BOOLEAN
-ODM_RAStateCheck(
-	IN		PVOID			pDM_VOID,
-	IN		s4Byte			RSSI,
-	IN		BOOLEAN			bForceUpdate,
-	OUT		pu1Byte			pRATRState
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PODM_RATE_ADAPTIVE pRA = &pDM_Odm->RateAdaptive;
-	const u1Byte GoUpGap = 5;
-	u1Byte HighRSSIThreshForRA = pRA->HighRSSIThresh;
-	u1Byte LowRSSIThreshForRA = pRA->LowRSSIThresh;
-	u1Byte RATRState;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("RSSI= (( %d )), Current_RSSI_level = (( %d ))\n", RSSI, *pRATRState));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("[Ori RA RSSI Thresh]  High= (( %d )), Low = (( %d ))\n", HighRSSIThreshForRA, LowRSSIThreshForRA));
-	// 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.
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	u1Byte UltraLowRSSIThreshForRA = pRA->UltraLowRSSIThresh;
-	if (pDM_Odm->SupportICType == ODM_RTL8881A)
-		LowRSSIThreshForRA = 30;		// for LDPC / BCC switch
-#endif
-
-	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;
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	case DM_RATR_STA_ULTRA_LOW:
-		HighRSSIThreshForRA += GoUpGap;
-		LowRSSIThreshForRA += GoUpGap;
-		UltraLowRSSIThreshForRA += GoUpGap;
-		break;
-#endif
-
-	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;
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP|ODM_ADSL))
-	else if (RSSI > UltraLowRSSIThreshForRA)
-		RATRState = DM_RATR_STA_LOW;
-	else
-		RATRState = DM_RATR_STA_ULTRA_LOW;
-#else
-	else
-		RATRState = DM_RATR_STA_LOW;
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("[Mod RA RSSI Thresh]  High= (( %d )), Low = (( %d ))\n", HighRSSIThreshForRA, LowRSSIThreshForRA));
-	/*printk("==>%s,RATRState:0x%02x ,RSSI:%d\n",__FUNCTION__,RATRState,RSSI);*/
-
-	if (*pRATRState != RATRState || bForceUpdate) {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, ("[RSSI Level Update] %d -> %d\n", *pRATRState, RATRState));
-		*pRATRState = RATRState;
-		return TRUE;
-	}
-
-	return FALSE;
-}
-
-VOID
-odm_RefreshBasicRateMask(
-	IN	PVOID	pDM_VOID
-)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		Adapter	 =  pDM_Odm->Adapter;
-	static u1Byte		Stage = 0;
-	u1Byte			CurStage = 0;
-	OCTET_STRING 	osRateSet;
-	PMGNT_INFO		pMgntInfo = GetDefaultMgntInfo(Adapter);
-	u1Byte 			RateSet[5] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M, MGN_6M};
-
-	if (pDM_Odm->SupportICType != ODM_RTL8812 && pDM_Odm->SupportICType != ODM_RTL8821)
-		return;
-
-	if (pDM_Odm->bLinked == FALSE)	// unlink Default port information
-		CurStage = 0;
-	else if (pDM_Odm->RSSI_Min < 40)	// link RSSI  < 40%
-		CurStage = 1;
-	else if (pDM_Odm->RSSI_Min > 45)	// link RSSI > 45%
-		CurStage = 3;
-	else
-		CurStage = 2;					// link  25% <= RSSI <= 30%
-
-	if (CurStage != Stage) {
-		if (CurStage == 1) {
-			FillOctetString(osRateSet, RateSet, 5);
-			FilterSupportRate(pMgntInfo->mBrates, &osRateSet, FALSE);
-			Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_BASIC_RATE, (pu1Byte)&osRateSet);
-		} else if (CurStage == 3 && (Stage == 1 || Stage == 2))
-			Adapter->HalFunc.SetHwRegHandler(Adapter, HW_VAR_BASIC_RATE, (pu1Byte)(&pMgntInfo->mBrates));
-	}
-
-	Stage = CurStage;
-#endif
-}
-
-
-VOID
-phydm_ra_info_init(
-	IN	PVOID	pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
-	phydm_ra_dynamic_retry_limit_init(pDM_Odm);
-	#endif
-	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	phydm_ra_dynamic_rate_id_init(pDM_Odm);
-	#endif
-
-	/*phydm_fw_trace_en_h2c(pDM_Odm, 1, 0, 0);*/
-}
-
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-u1Byte
-odm_Find_RTS_Rate(
-	IN		PVOID			pDM_VOID,
-	IN		u1Byte			Tx_Rate,
-	IN		BOOLEAN			bErpProtect
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	RTS_Ini_Rate = ODM_RATE6M;
-	
-	if (bErpProtect) /* use CCK rate as RTS*/
-		RTS_Ini_Rate = ODM_RATE1M;
-	else {
-		switch (Tx_Rate) {
-		case ODM_RATEVHTSS3MCS9:
-		case ODM_RATEVHTSS3MCS8:
-		case ODM_RATEVHTSS3MCS7:
-		case ODM_RATEVHTSS3MCS6:
-		case ODM_RATEVHTSS3MCS5:
-		case ODM_RATEVHTSS3MCS4:
-		case ODM_RATEVHTSS3MCS3:
-		case ODM_RATEVHTSS2MCS9:
-		case ODM_RATEVHTSS2MCS8:
-		case ODM_RATEVHTSS2MCS7:
-		case ODM_RATEVHTSS2MCS6:
-		case ODM_RATEVHTSS2MCS5:
-		case ODM_RATEVHTSS2MCS4:
-		case ODM_RATEVHTSS2MCS3:
-		case ODM_RATEVHTSS1MCS9:
-		case ODM_RATEVHTSS1MCS8:
-		case ODM_RATEVHTSS1MCS7:
-		case ODM_RATEVHTSS1MCS6:
-		case ODM_RATEVHTSS1MCS5:
-		case ODM_RATEVHTSS1MCS4:
-		case ODM_RATEVHTSS1MCS3:
-		case ODM_RATEMCS15:
-		case ODM_RATEMCS14:
-		case ODM_RATEMCS13:
-		case ODM_RATEMCS12:
-		case ODM_RATEMCS11:
-		case ODM_RATEMCS7:
-		case ODM_RATEMCS6:
-		case ODM_RATEMCS5:
-		case ODM_RATEMCS4:
-		case ODM_RATEMCS3:
-		case ODM_RATE54M:
-		case ODM_RATE48M:
-		case ODM_RATE36M:
-		case ODM_RATE24M:		
-			RTS_Ini_Rate = ODM_RATE24M;
-			break;
-		case ODM_RATEVHTSS3MCS2:
-		case ODM_RATEVHTSS3MCS1:
-		case ODM_RATEVHTSS2MCS2:
-		case ODM_RATEVHTSS2MCS1:
-		case ODM_RATEVHTSS1MCS2:
-		case ODM_RATEVHTSS1MCS1:
-		case ODM_RATEMCS10:
-		case ODM_RATEMCS9:
-		case ODM_RATEMCS2:
-		case ODM_RATEMCS1:
-		case ODM_RATE18M:
-		case ODM_RATE12M:
-			RTS_Ini_Rate = ODM_RATE12M;
-			break;
-		case ODM_RATEVHTSS3MCS0:
-		case ODM_RATEVHTSS2MCS0:
-		case ODM_RATEVHTSS1MCS0:
-		case ODM_RATEMCS8:
-		case ODM_RATEMCS0:
-		case ODM_RATE9M:
-		case ODM_RATE6M:
-			RTS_Ini_Rate = ODM_RATE6M;
-			break;
-		case ODM_RATE11M:
-		case ODM_RATE5_5M:
-		case ODM_RATE2M:
-		case ODM_RATE1M:
-			RTS_Ini_Rate = ODM_RATE1M;
-			break;
-		default:
-			RTS_Ini_Rate = ODM_RATE6M;
-			break;
-		}
-	}
-
-	if (*pDM_Odm->pBandType == 1) {
-		if (RTS_Ini_Rate < ODM_RATE6M)
-			RTS_Ini_Rate = ODM_RATE6M;
-	}
-	return RTS_Ini_Rate;
-
-}
-
-VOID
-odm_Set_RA_DM_ARFB_by_Noisy(
-	IN	PDM_ODM_T	pDM_Odm
-)
-{
-	/*DbgPrint("DM_ARFB ====>\n");*/
-	if (pDM_Odm->bNoisyState) {
-		ODM_Write4Byte(pDM_Odm, 0x430, 0x00000000);
-		ODM_Write4Byte(pDM_Odm, 0x434, 0x05040200);
-		/*DbgPrint("DM_ARFB ====> Noisy State\n");*/
-	} else {
-		ODM_Write4Byte(pDM_Odm, 0x430, 0x02010000);
-		ODM_Write4Byte(pDM_Odm, 0x434, 0x07050403);
-		/*DbgPrint("DM_ARFB ====> Clean State\n");*/
-	}
-
-}
-
-VOID
-ODM_UpdateNoisyState(
-	IN	PVOID		pDM_VOID,
-	IN	BOOLEAN		bNoisyStateFromC2H
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	/*DbgPrint("Get C2H Command! NoisyState=0x%x\n ", bNoisyStateFromC2H);*/
-	if (pDM_Odm->SupportICType == ODM_RTL8821  || pDM_Odm->SupportICType == ODM_RTL8812  ||
-		pDM_Odm->SupportICType == ODM_RTL8723B || pDM_Odm->SupportICType == ODM_RTL8192E || pDM_Odm->SupportICType == ODM_RTL8188E)
-		pDM_Odm->bNoisyState = bNoisyStateFromC2H;
-	odm_Set_RA_DM_ARFB_by_Noisy(pDM_Odm);
-};
-
-u4Byte
-Set_RA_DM_Ratrbitmap_by_Noisy(
-	IN	PVOID			pDM_VOID,
-	IN	WIRELESS_MODE	WirelessMode,
-	IN	u4Byte			ratr_bitmap,
-	IN	u1Byte			rssi_level
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte ret_bitmap = ratr_bitmap;
-	
-	return ret_bitmap;
-	
-	switch (WirelessMode) {
-	case WIRELESS_MODE_AC_24G:
-	case WIRELESS_MODE_AC_5G:
-	case WIRELESS_MODE_AC_ONLY:
-		if (pDM_Odm->bNoisyState) { /*in Noisy State*/
-			if (rssi_level == 1)
-				ret_bitmap &= 0xfc3e0c08;		// Reserve MCS 5-9
-			else if (rssi_level == 2)
-				ret_bitmap &= 0xfe3f8e08;		// Reserve MCS 3-9
-			else if (rssi_level == 3)
-				ret_bitmap &= 0xffffffff;
-			else
-				ret_bitmap &= 0xffffffff;
-		} else {                                /* in SNR State*/
-			if (rssi_level == 1)
-				ret_bitmap &= 0xfe3f0e08;		// Reserve MCS 4-9
-			else if (rssi_level == 2)
-				ret_bitmap &= 0xff3fcf8c;		// Reserve MCS 2-9
-			else if (rssi_level == 3)
-				ret_bitmap &= 0xffffffff;
-			else
-				ret_bitmap &= 0xffffffff;
-		}
-		break;
-	case WIRELESS_MODE_B:
-	case WIRELESS_MODE_A:
-	case WIRELESS_MODE_G:
-	case WIRELESS_MODE_N_24G:
-	case WIRELESS_MODE_N_5G:
-		if (pDM_Odm->bNoisyState) {
-			if (rssi_level == 1)
-				ret_bitmap &= 0x0f0e0c08;		// Reserve MCS 4-7; MCS12-15
-			else if (rssi_level == 2)
-				ret_bitmap &= 0x0fcfce0c;		// Reserve MCS 2-7; MCS10-15
-			else if (rssi_level == 3)
-				ret_bitmap &= 0xffffffff;
-			else
-				ret_bitmap &= 0xffffffff;
-		} else {
-			if (rssi_level == 1)
-				ret_bitmap &= 0x0f8f8e08;		// Reserve MCS 3-7; MCS11-15
-			else if (rssi_level == 2)
-				ret_bitmap &= 0x0fefef8c;		// Reserve MCS 1-7; MCS9-15
-			else if (rssi_level == 3)
-				ret_bitmap &= 0xffffffff;
-			else
-				ret_bitmap &= 0xffffffff;
-		}
-		break;
-	default:
-		break;
-	}
-	/*DbgPrint("DM_RAMask ====> rssi_LV = %d, BITMAP = %x\n", rssi_level, ret_bitmap);*/
-	return ret_bitmap;
-
-}
-
-VOID
-ODM_UpdateInitRate(
-	IN	PVOID		pDM_VOID,
-	IN	u1Byte		Rate
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			p = 0;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("Get C2H Command! Rate=0x%x\n", Rate));
-
-	pDM_Odm->TxRate = Rate;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-#if USE_WORKITEM
-		PlatformScheduleWorkItem(&pDM_Odm->RaRptWorkitem);
-#else
-		if (pDM_Odm->SupportICType == ODM_RTL8821) {
-#if (RTL8821A_SUPPORT == 1)
-			ODM_TxPwrTrackSetPwr8821A(pDM_Odm, MIX_MODE, ODM_RF_PATH_A, 0);
-#endif
-		} else if (pDM_Odm->SupportICType == ODM_RTL8812) {
-			for (p = ODM_RF_PATH_A; p < MAX_PATH_NUM_8812A; p++) {
-#if (RTL8812A_SUPPORT == 1)
-				ODM_TxPwrTrackSetPwr8812A(pDM_Odm, MIX_MODE, p, 0);
-#endif
-			}
-		} else if (pDM_Odm->SupportICType == ODM_RTL8723B) {
-#if (RTL8723B_SUPPORT == 1)
-			ODM_TxPwrTrackSetPwr_8723B(pDM_Odm, MIX_MODE, ODM_RF_PATH_A, 0);
-#endif
-		} else if (pDM_Odm->SupportICType == ODM_RTL8192E) {
-			for (p = ODM_RF_PATH_A; p < MAX_PATH_NUM_8192E; p++) {
-#if (RTL8192E_SUPPORT == 1)
-				ODM_TxPwrTrackSetPwr92E(pDM_Odm, MIX_MODE, p, 0);
-#endif
-			}
-		} else if (pDM_Odm->SupportICType == ODM_RTL8188E) {
-#if (RTL8188E_SUPPORT == 1)
-			ODM_TxPwrTrackSetPwr88E(pDM_Odm, MIX_MODE, ODM_RF_PATH_A, 0);
-#endif
-		}
-#endif
-#else
-		PlatformScheduleWorkItem(&pDM_Odm->RaRptWorkitem);
-#endif
-#endif
-
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-odm_RSSIDumpToRegister(
-	IN	PVOID	pDM_VOID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-
-	if (pDM_Odm->SupportICType == ODM_RTL8812) {
-		PlatformEFIOWrite1Byte(Adapter, rA_RSSIDump_Jaguar, Adapter->RxStats.RxRSSIPercentage[0]);
-		PlatformEFIOWrite1Byte(Adapter, rB_RSSIDump_Jaguar, Adapter->RxStats.RxRSSIPercentage[1]);
-
-		/* Rx EVM*/
-		PlatformEFIOWrite1Byte(Adapter, rS1_RXevmDump_Jaguar, Adapter->RxStats.RxEVMdbm[0]);
-		PlatformEFIOWrite1Byte(Adapter, rS2_RXevmDump_Jaguar, Adapter->RxStats.RxEVMdbm[1]);
-
-		/* Rx SNR*/
-		PlatformEFIOWrite1Byte(Adapter, rA_RXsnrDump_Jaguar, (u1Byte)(Adapter->RxStats.RxSNRdB[0]));
-		PlatformEFIOWrite1Byte(Adapter, rB_RXsnrDump_Jaguar, (u1Byte)(Adapter->RxStats.RxSNRdB[1]));
-
-		/* Rx Cfo_Short*/
-		PlatformEFIOWrite2Byte(Adapter, rA_CfoShortDump_Jaguar, Adapter->RxStats.RxCfoShort[0]);
-		PlatformEFIOWrite2Byte(Adapter, rB_CfoShortDump_Jaguar, Adapter->RxStats.RxCfoShort[1]);
-
-		/* Rx Cfo_Tail*/
-		PlatformEFIOWrite2Byte(Adapter, rA_CfoLongDump_Jaguar, Adapter->RxStats.RxCfoTail[0]);
-		PlatformEFIOWrite2Byte(Adapter, rB_CfoLongDump_Jaguar, Adapter->RxStats.RxCfoTail[1]);
-	} else if (pDM_Odm->SupportICType == ODM_RTL8192E) {
-		PlatformEFIOWrite1Byte(Adapter, rA_RSSIDump_92E, Adapter->RxStats.RxRSSIPercentage[0]);
-		PlatformEFIOWrite1Byte(Adapter, rB_RSSIDump_92E, Adapter->RxStats.RxRSSIPercentage[1]);
-		/* Rx EVM*/
-		PlatformEFIOWrite1Byte(Adapter, rS1_RXevmDump_92E, Adapter->RxStats.RxEVMdbm[0]);
-		PlatformEFIOWrite1Byte(Adapter, rS2_RXevmDump_92E, Adapter->RxStats.RxEVMdbm[1]);
-		/* Rx SNR*/
-		PlatformEFIOWrite1Byte(Adapter, rA_RXsnrDump_92E, (u1Byte)(Adapter->RxStats.RxSNRdB[0]));
-		PlatformEFIOWrite1Byte(Adapter, rB_RXsnrDump_92E, (u1Byte)(Adapter->RxStats.RxSNRdB[1]));
-		/* Rx Cfo_Short*/
-		PlatformEFIOWrite2Byte(Adapter, rA_CfoShortDump_92E, Adapter->RxStats.RxCfoShort[0]);
-		PlatformEFIOWrite2Byte(Adapter, rB_CfoShortDump_92E, Adapter->RxStats.RxCfoShort[1]);
-		/* Rx Cfo_Tail*/
-		PlatformEFIOWrite2Byte(Adapter, rA_CfoLongDump_92E, Adapter->RxStats.RxCfoTail[0]);
-		PlatformEFIOWrite2Byte(Adapter, rB_CfoLongDump_92E, Adapter->RxStats.RxCfoTail[1]);
-	}
-}
-
-VOID
-odm_RefreshLdpcRtsMP(
-	IN	PADAPTER			pAdapter,
-	IN	PDM_ODM_T			pDM_Odm,
-	IN	u1Byte				mMacId,
-	IN	u1Byte				IOTPeer,
-	IN	s4Byte				UndecoratedSmoothedPWDB
-)
-{
-	BOOLEAN					bCtlLdpc = FALSE;
-	PMGNT_INFO				pMgntInfo = GetDefaultMgntInfo(pAdapter);
-	PODM_RATE_ADAPTIVE		pRA = &pDM_Odm->RateAdaptive;
-
-	if (pDM_Odm->SupportICType != ODM_RTL8821 && pDM_Odm->SupportICType != ODM_RTL8812)
-		return;
-
-	if ((pDM_Odm->SupportICType == ODM_RTL8821) && (pDM_Odm->CutVersion == ODM_CUT_A))
-		bCtlLdpc = TRUE;
-	else if (pDM_Odm->SupportICType == ODM_RTL8812 &&
-			 IOTPeer == HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP)
-		bCtlLdpc = TRUE;
-
-	if (bCtlLdpc) {
-		if (UndecoratedSmoothedPWDB < (pRA->LdpcThres - 5))
-			MgntSet_TX_LDPC(pAdapter, mMacId, TRUE);
-		else if (UndecoratedSmoothedPWDB > pRA->LdpcThres)
-			MgntSet_TX_LDPC(pAdapter, mMacId, FALSE);
-	}
-
-	if (UndecoratedSmoothedPWDB < (pRA->RtsThres - 5))
-		pRA->bLowerRtsRate = TRUE;
-	else if (UndecoratedSmoothedPWDB > pRA->RtsThres)
-		pRA->bLowerRtsRate = FALSE;
-}
-
-VOID
-ODM_DynamicARFBSelect(
-	IN		PVOID		pDM_VOID,
-	IN 		u1Byte			rate,
-	IN  		BOOLEAN			Collision_State
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRA_T			pRA_Table = &pDM_Odm->DM_RA_Table;
-
-	if (pDM_Odm->SupportICType != ODM_RTL8192E)
-		return;
-
-	if (Collision_State == pRA_Table->PT_collision_pre)
-		return;
-
-	if (rate >= DESC_RATEMCS8  && rate <= DESC_RATEMCS12) {
-		if (Collision_State == 1) {
-			if (rate == DESC_RATEMCS12) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x0);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x07060501);
-			} else if (rate == DESC_RATEMCS11) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x0);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x07070605);
-			} else if (rate == DESC_RATEMCS10) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x0);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x08080706);
-			} else if (rate == DESC_RATEMCS9) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x0);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x08080707);
-			} else {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x0);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x09090808);
-			}
-		} else { /* Collision_State == 0*/
-			if (rate == DESC_RATEMCS12) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x05010000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x09080706);
-			} else if (rate == DESC_RATEMCS11) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x06050000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x09080807);
-			} else if (rate == DESC_RATEMCS10) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x07060000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x0a090908);
-			} else if (rate == DESC_RATEMCS9) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x07070000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x0a090808);
-			} else {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x08080000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x0b0a0909);
-			}
-		}
-	} else { /* MCS13~MCS15,  1SS, G-mode*/
-		if (Collision_State == 1) {
-			if (rate == DESC_RATEMCS15) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x00000000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x05040302);
-			} else if (rate == DESC_RATEMCS14) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x00000000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x06050302);
-			} else if (rate == DESC_RATEMCS13) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x00000000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x07060502);
-			} else {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x00000000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x06050402);
-			}
-		} else { // Collision_State == 0
-			if (rate == DESC_RATEMCS15) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x03020000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x07060504);
-			} else if (rate == DESC_RATEMCS14) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x03020000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x08070605);
-			} else if (rate == DESC_RATEMCS13) {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x05020000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x09080706);
-			} else {
-
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E, 0x04020000);
-				ODM_Write4Byte(pDM_Odm, REG_DARFRC_8192E+4, 0x08070605);
-			}
-
-
-		}
-
-	}
-	pRA_Table->PT_collision_pre = Collision_State;
-}
-
-VOID
-ODM_RateAdaptiveStateApInit(
-	IN	PVOID		PADAPTER_VOID,
-	IN	PRT_WLAN_STA  	pEntry
-)
-{
-	PADAPTER		Adapter = (PADAPTER)PADAPTER_VOID;
-	pEntry->Ratr_State = DM_RATR_STA_INIT;
-}
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
-
-static void
-FindMinimumRSSI(
-	IN	PADAPTER	pAdapter
-)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-
-	/*Determine the minimum RSSI*/
-
-	if ((pDM_Odm->bLinked != _TRUE) &&
-		(pHalData->EntryMinUndecoratedSmoothedPWDB == 0)) {
-		pHalData->MinUndecoratedPWDBForDM = 0;
-		/*ODM_RT_TRACE(pDM_Odm,COMP_BB_POWERSAVING, DBG_LOUD, ("Not connected to any\n"));*/
-	} else
-		pHalData->MinUndecoratedPWDBForDM = pHalData->EntryMinUndecoratedSmoothedPWDB;
-
-	/*DBG_8192C("%s=>MinUndecoratedPWDBForDM(%d)\n",__FUNCTION__,pdmpriv->MinUndecoratedPWDBForDM);*/
-	/*ODM_RT_TRACE(pDM_Odm,COMP_DIG, DBG_LOUD, ("MinUndecoratedPWDBForDM =%d\n",pHalData->MinUndecoratedPWDBForDM));*/
-}
-
-u8Byte
-PhyDM_Get_Rate_Bitmap_Ex(
-	IN	PVOID		pDM_VOID,
-	IN	u4Byte		macid,
-	IN	u8Byte		ra_mask,
-	IN	u1Byte		rssi_level,
-	OUT		u8Byte	*dm_RA_Mask,
-	OUT		u1Byte	*dm_RteID
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PSTA_INFO_T	pEntry;
-	u8Byte	rate_bitmap = 0;
-	u1Byte	WirelessMode;
-
-	pEntry = pDM_Odm->pODM_StaInfo[macid];
-	if (!IS_STA_VALID(pEntry))
-		return ra_mask;
-	WirelessMode = pEntry->wireless_mode;
-	switch (WirelessMode) {
-	case ODM_WM_B:
-		if (ra_mask & 0x000000000000000c) /* 11M or 5.5M enable */
-			rate_bitmap = 0x000000000000000d;
-		else
-			rate_bitmap = 0x000000000000000f;
-		break;
-
-	case (ODM_WM_G):
-	case (ODM_WM_A):
-		if (rssi_level == DM_RATR_STA_HIGH)
-			rate_bitmap = 0x0000000000000f00;
-		else
-			rate_bitmap = 0x0000000000000ff0;
-		break;
-
-	case (ODM_WM_B|ODM_WM_G):
-		if (rssi_level == DM_RATR_STA_HIGH)
-			rate_bitmap = 0x0000000000000f00;
-		else if (rssi_level == DM_RATR_STA_MIDDLE)
-			rate_bitmap = 0x0000000000000ff0;
-		else
-			rate_bitmap = 0x0000000000000ff5;
-		break;
-
-	case (ODM_WM_B|ODM_WM_G|ODM_WM_N24G):
-	case (ODM_WM_B|ODM_WM_N24G):
-	case (ODM_WM_G|ODM_WM_N24G):
-	case (ODM_WM_A|ODM_WM_N5G): {
-		if (pDM_Odm->RFType == ODM_1T2R || pDM_Odm->RFType == ODM_1T1R) {
-			if (rssi_level == DM_RATR_STA_HIGH)
-				rate_bitmap = 0x00000000000f0000;
-			else if (rssi_level == DM_RATR_STA_MIDDLE)
-				rate_bitmap = 0x00000000000ff000;
-			else {
-				if (*(pDM_Odm->pBandWidth) == ODM_BW40M)
-					rate_bitmap = 0x00000000000ff015;
-				else
-					rate_bitmap = 0x00000000000ff005;
-			}
-		} else if (pDM_Odm->RFType == ODM_2T2R  || pDM_Odm->RFType == ODM_2T3R  || pDM_Odm->RFType == ODM_2T4R) {
-			if (rssi_level == DM_RATR_STA_HIGH)
-				rate_bitmap = 0x000000000f8f0000;
-			else if (rssi_level == DM_RATR_STA_MIDDLE)
-				rate_bitmap = 0x000000000f8ff000;
-			else {
-				if (*(pDM_Odm->pBandWidth) == ODM_BW40M)
-					rate_bitmap = 0x000000000f8ff015;
-				else
-					rate_bitmap = 0x000000000f8ff005;
-			}
-		} else {
-			if (rssi_level == DM_RATR_STA_HIGH)
-				rate_bitmap = 0x0000000f0f0f0000;
-			else if (rssi_level == DM_RATR_STA_MIDDLE)
-				rate_bitmap = 0x0000000fcfcfe000;
-			else {
-				if (*(pDM_Odm->pBandWidth) == ODM_BW40M)
-					rate_bitmap = 0x0000000ffffff015;
-				else
-					rate_bitmap = 0x0000000ffffff005;
-			}
-		}
-	}
-	break;
-
-	case (ODM_WM_AC|ODM_WM_G):
-		if (rssi_level == 1)
-			rate_bitmap = 0x00000000fc3f0000;
-		else if (rssi_level == 2)
-			rate_bitmap = 0x00000000fffff000;
-		else
-			rate_bitmap = 0x00000000ffffffff;
-		break;
-
-	case (ODM_WM_AC|ODM_WM_A):
-
-		if (pDM_Odm->RFType == ODM_1T2R || pDM_Odm->RFType == ODM_1T1R) {
-			if (rssi_level == 1)				/* add by Gary for ac-series */
-				rate_bitmap = 0x00000000003f8000;
-			else if (rssi_level == 2)
-				rate_bitmap = 0x00000000003fe000;
-			else
-				rate_bitmap = 0x00000000003ff010;
-		} else if (pDM_Odm->RFType == ODM_2T2R  || pDM_Odm->RFType == ODM_2T3R  || pDM_Odm->RFType == ODM_2T4R) {
-			if (rssi_level == 1)				/* add by Gary for ac-series */
-				rate_bitmap = 0x00000000fe3f8000;       /* VHT 2SS MCS3~9 */
-			else if (rssi_level == 2)
-				rate_bitmap = 0x00000000fffff000;       /* VHT 2SS MCS0~9 */
-			else
-				rate_bitmap = 0x00000000fffff010;       /* All */
-		} else {
-			if (rssi_level == 1)				/* add by Gary for ac-series */
-				rate_bitmap = 0x000003f8fe3f8000ULL;       /* VHT 3SS MCS3~9 */
-			else if (rssi_level == 2)
-				rate_bitmap = 0x000003fffffff000ULL;       /* VHT3SS MCS0~9 */
-			else
-				rate_bitmap = 0x000003fffffff010ULL;       /* All */
-		}
-		break;
-
-	default:
-		if (pDM_Odm->RFType == ODM_1T2R || pDM_Odm->RFType == ODM_1T1R)
-			rate_bitmap = 0x00000000000fffff;
-		else if (pDM_Odm->RFType == ODM_2T2R  || pDM_Odm->RFType == ODM_2T3R  || pDM_Odm->RFType == ODM_2T4R)
-			rate_bitmap = 0x000000000fffffff;
-		else
-			rate_bitmap = 0x0000003fffffffffULL;
-		break;
-
-	}
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD, (" ==> rssi_level:0x%02x, WirelessMode:0x%02x, rate_bitmap:0x%016llx\n", rssi_level, WirelessMode, rate_bitmap));
-
-	return (ra_mask & rate_bitmap);
-}
-
-
-u4Byte
-ODM_Get_Rate_Bitmap(
-	IN	PVOID		pDM_VOID,
-	IN	u4Byte		macid,
-	IN	u4Byte 		ra_mask,
-	IN	u1Byte 		rssi_level
-)
-{
-	PDM_ODM_T		pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PSTA_INFO_T   	pEntry;
-	u4Byte 	rate_bitmap = 0;
-	u1Byte 	WirelessMode;
-	//u1Byte 	WirelessMode =*(pDM_Odm->pWirelessMode);
-
-
-	pEntry = pDM_Odm->pODM_StaInfo[macid];
-	if (!IS_STA_VALID(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_G):
-	case (ODM_WM_A):
-		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_B|ODM_WM_N24G)	:
-	case (ODM_WM_G|ODM_WM_N24G)	:
-	case (ODM_WM_A|ODM_WM_N5G)	: {
-		if (pDM_Odm->RFType == ODM_1T2R || pDM_Odm->RFType == ODM_1T1R) {
-			if (rssi_level == DM_RATR_STA_HIGH)
-				rate_bitmap = 0x000f0000;
-			else if (rssi_level == DM_RATR_STA_MIDDLE)
-				rate_bitmap = 0x000ff000;
-			else {
-				if (*(pDM_Odm->pBandWidth) == ODM_BW40M)
-					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 (*(pDM_Odm->pBandWidth) == ODM_BW40M)
-					rate_bitmap = 0x0f8ff015;
-				else
-					rate_bitmap = 0x0f8ff005;
-			}
-		}
-	}
-	break;
-
-	case (ODM_WM_AC|ODM_WM_G):
-		if (rssi_level == 1)
-			rate_bitmap = 0xfc3f0000;
-		else if (rssi_level == 2)
-			rate_bitmap = 0xfffff000;
-		else
-			rate_bitmap = 0xffffffff;
-		break;
-
-	case (ODM_WM_AC|ODM_WM_A):
-
-		if (pDM_Odm->RFType == RF_1T1R) {
-			if (rssi_level == 1)				// add by Gary for ac-series
-				rate_bitmap = 0x003f8000;
-			else if (rssi_level == 2)
-				rate_bitmap = 0x003ff000;
-			else
-				rate_bitmap = 0x003ff010;
-		} else {
-			if (rssi_level == 1)				// add by Gary for ac-series
-				rate_bitmap = 0xfe3f8000;       // VHT 2SS MCS3~9
-			else if (rssi_level == 2)
-				rate_bitmap = 0xfffff000;       // VHT 2SS MCS0~9
-			else
-				rate_bitmap = 0xfffff010;       // All
-		}
-		break;
-
-	default:
-		if (pDM_Odm->RFType == RF_1T2R)
-			rate_bitmap = 0x000fffff;
-		else
-			rate_bitmap = 0x0fffffff;
-		break;
-
-	}
-
-	DBG_871X("%s ==> rssi_level:0x%02x, WirelessMode:0x%02x, rate_bitmap:0x%08x\n", __func__, rssi_level, WirelessMode, rate_bitmap);
-	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 (ra_mask & rate_bitmap);
-
-}
-
-#endif //#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-#endif /*#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN| ODM_CE))*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_h2C_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			h2c_parameter[H2C_MAX_LENGTH] = {0};
+	u8			phydm_h2c_id = (u8)dm_value[0];
+	u8			i;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		       "Phydm Send H2C_ID (( 0x%x))\n", phydm_h2c_id);
+	for (i = 0; i < H2C_MAX_LENGTH; i++) {
+		h2c_parameter[i] = (u8)dm_value[i + 1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "H2C: Byte[%d] = ((0x%x))\n", i,
+			       h2c_parameter[i]);
+	}
+
+	odm_fill_h2c_cmd(dm, phydm_h2c_id, H2C_MAX_LENGTH, h2c_parameter);
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_fw_fix_rate(
+	void		*dm_void,
+	u8		en, 
+	u8		macid, 
+	u8		bw, 
+	u8		rate
+	
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32	reg_u32_tmp;
+
+	if (dm->support_ic_type & PHYDM_IC_8051_SERIES) {
+		
+		reg_u32_tmp = (bw << 24) | (rate << 16) | (macid << 8) | en;
+		odm_set_bb_reg(dm, 0x4a0, MASKDWORD, reg_u32_tmp);
+			
+	} else {
+	
+		if (en == 1)
+			reg_u32_tmp = (0x60 << 24) | (macid << 16) | (bw << 8) | rate;
+		else
+			reg_u32_tmp = 0x40000000;
+			
+		odm_set_bb_reg(dm, 0x450, MASKDWORD, reg_u32_tmp);
+	}
+	if (en == 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "FW fix TX rate[id =%d], %dM, Rate(%d)=", macid, (20 << bw), rate);
+		phydm_print_rate(dm, rate, ODM_COMP_API);
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "Auto Rate\n");
+	}
+}
+
+void
+phydm_ra_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	char	help[] = "-h";
+	u32	var1[5] = {0};
+	u8	i = 0;
+	u32	reg_u32_tmp;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+	}
+	
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {0:-,1:+} {ofst}: set offset\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {100}: show offset\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{2} {en} {macid} {bw} {rate}: fw fix rate\n");
+		
+	} else if (var1[0] == 1) { /*Adjust PCR offset*/
+
+		if (var1[1] == 100) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Get] RA_ofst=((%s%d))\n", 
+				       ((ra_tab->RA_threshold_offset == 0) ? " " : ((ra_tab->RA_offset_direction) ? "+" : "-")),
+				       ra_tab->RA_threshold_offset);
+
+		} else if (var1[1] == 0) {
+			ra_tab->RA_offset_direction = 0;
+			ra_tab->RA_threshold_offset = (u8)var1[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Set] RA_ofst=((-%d))\n",
+				       ra_tab->RA_threshold_offset);
+		} else if (var1[1] == 1) {
+			ra_tab->RA_offset_direction = 1;
+			ra_tab->RA_threshold_offset = (u8)var1[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[Set] RA_ofst=((+%d))\n",
+				       ra_tab->RA_threshold_offset);
+		}
+		
+	} else if (var1[0] == 2) { /*FW fix rate*/
+
+		PDM_SNPF(out_len, used, output + used, out_len - used, 
+			       "[FW fix TX Rate] {en, macid,bw,rate}={%d, %d, %d, 0x%x}",
+			       var1[1], var1[2], var1[3], var1[4]);
+		
+		phydm_fw_fix_rate(dm, (u8)var1[1], (u8)var1[2], (u8)var1[3], (u8)var1[4]);
+		
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[Set] Error\n");
+		/**/
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+
+void
+odm_c2h_ra_para_report_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+#if (defined(CONFIG_RA_DBG_CMD))
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+#endif
+
+	u8	para_idx = cmd_buf[0]; /*Retry Penalty, NH, NL*/
+#if (defined(CONFIG_RA_DBG_CMD))
+	u8	rate_type_start = cmd_buf[1];
+	u8	rate_type_length = cmd_len - 2;
+#endif
+	u8	i;
+
+
+	PHYDM_DBG(dm, DBG_RA, "[ From FW C2H RA Para ]  cmd_buf[0]= (( %d ))\n", cmd_buf[0]);
+
+#if (defined(CONFIG_RA_DBG_CMD))
+	if (para_idx == RADBG_RTY_PENALTY) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |RTY Penality index|\n");
+
+		for (i = 0 ; i < (rate_type_length) ; i++) {
+			if (ra_tab->is_ra_dbg_init)
+				ra_tab->RTY_P_default[rate_type_start + i] = cmd_buf[2 + i];
+
+			ra_tab->RTY_P[rate_type_start + i] = cmd_buf[2 + i];
+			PHYDM_DBG(dm, DBG_RA, "%8d  %15d\n", (rate_type_start + i), ra_tab->RTY_P[rate_type_start + i]);
+		}
+
+	} else	if (para_idx == RADBG_N_HIGH) {
+		/**/
+		PHYDM_DBG(dm, DBG_RA, " |rate index|    |N-High|\n");
+
+
+	} else if (para_idx == RADBG_N_LOW) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |N-Low|\n");
+		/**/
+	} else if (para_idx == RADBG_RATE_UP_RTY_RATIO) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |rate Up RTY Ratio|\n");
+
+		for (i = 0; i < (rate_type_length); i++) {
+			if (ra_tab->is_ra_dbg_init)
+				ra_tab->RATE_UP_RTY_RATIO_default[rate_type_start + i] = cmd_buf[2 + i];
+
+			ra_tab->RATE_UP_RTY_RATIO[rate_type_start + i] = cmd_buf[2 + i];
+			PHYDM_DBG(dm, DBG_RA, "%8d  %15d\n", (rate_type_start + i), ra_tab->RATE_UP_RTY_RATIO[rate_type_start + i]);
+		}
+	} else	 if (para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
+		PHYDM_DBG(dm, DBG_RA, " |rate index|   |rate Down RTY Ratio|\n");
+
+		for (i = 0; i < (rate_type_length); i++) {
+			if (ra_tab->is_ra_dbg_init)
+				ra_tab->RATE_DOWN_RTY_RATIO_default[rate_type_start + i] = cmd_buf[2 + i];
+
+			ra_tab->RATE_DOWN_RTY_RATIO[rate_type_start + i] = cmd_buf[2 + i];
+			PHYDM_DBG(dm, DBG_RA, "%8d  %15d\n", (rate_type_start + i), ra_tab->RATE_DOWN_RTY_RATIO[rate_type_start + i]);
+		}
+	} else
+#endif
+		if (para_idx == RADBG_DEBUG_MONITOR1) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+			if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "RSSI =", cmd_buf[1]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "rate =", cmd_buf[2] & 0x7f);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "SGI =", (cmd_buf[2] & 0x80) >> 7);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "BW =", cmd_buf[3]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "BW_max =", cmd_buf[4]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "multi_rate0 =", cmd_buf[5]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "multi_rate1 =", cmd_buf[6]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "DISRA =",	cmd_buf[7]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "VHT_EN =", cmd_buf[8]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "SGI_support =",	cmd_buf[9]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "try_ness =", cmd_buf[10]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "pre_rate =", cmd_buf[11]);
+			} else {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "RSSI =", cmd_buf[1]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %x\n", "BW =", cmd_buf[2]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "DISRA =", cmd_buf[3]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "VHT_EN =", cmd_buf[4]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Hightest rate =", cmd_buf[5]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "Lowest rate =", cmd_buf[6]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "SGI_support =", cmd_buf[7]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Rate_ID =",	cmd_buf[8]);
+			}
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+		} else	 if (para_idx == RADBG_DEBUG_MONITOR2) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+			if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "rate_id =", cmd_buf[1]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "highest_rate =", cmd_buf[2]);
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "lowest_rate =", cmd_buf[3]);
+
+				for (i = 4; i <= 11; i++)
+					PHYDM_DBG(dm, DBG_FW_TRACE, "RAMASK =  0x%x\n", cmd_buf[i]);
+			} else {
+				PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %x%x  %x%x  %x%x  %x%x\n", "RA Mask:",
+					cmd_buf[8], cmd_buf[7], cmd_buf[6], cmd_buf[5], cmd_buf[4], cmd_buf[3], cmd_buf[2], cmd_buf[1]);
+			}
+			PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
+		} else	 if (para_idx == RADBG_DEBUG_MONITOR3) {
+			for (i = 0; i < (cmd_len - 1); i++)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "content[%d] = %d\n", i, cmd_buf[1 + i]);
+		} else	 if (para_idx == RADBG_DEBUG_MONITOR4)
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  {%d.%d}\n", "RA version =", cmd_buf[1], cmd_buf[2]);
+		else if (para_idx == RADBG_DEBUG_MONITOR5) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "Current rate =", cmd_buf[1]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Retry ratio =", cmd_buf[2]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "rate down ratio =", cmd_buf[3]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "highest rate =", cmd_buf[4]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  {0x%x 0x%x}\n", "Muti-try =", cmd_buf[5], cmd_buf[6]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x%x%x%x%x\n", "RA mask =", cmd_buf[11], cmd_buf[10], cmd_buf[9], cmd_buf[8], cmd_buf[7]);
+		}
+}
+
+void
+phydm_ra_dynamic_retry_count(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_ARFR))
+		return;
+
+	/*PHYDM_DBG(dm, DBG_RA, "dm->pre_b_noisy = %d\n", dm->pre_b_noisy );*/
+	if (dm->pre_b_noisy != dm->noisy_decision) {
+		if (dm->noisy_decision) {
+			PHYDM_DBG(dm, DBG_DYN_ARFR, "Noisy Env. RA fallback\n");
+			odm_set_mac_reg(dm, 0x430, MASKDWORD, 0x0);
+			odm_set_mac_reg(dm, 0x434, MASKDWORD, 0x04030201);
+		} else {
+			PHYDM_DBG(dm, DBG_DYN_ARFR, "Clean Env. RA fallback\n");
+			odm_set_mac_reg(dm, 0x430, MASKDWORD, 0x01000000);
+			odm_set_mac_reg(dm, 0x434, MASKDWORD, 0x06050402);
+		}
+		dm->pre_b_noisy = dm->noisy_decision;
+	}
+}
+
+void
+phydm_print_rate(
+	void	*dm_void,
+	u8	rate,
+	u32	dbg_component
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		legacy_table[12] = {1, 2, 5, 11, 6, 9, 12, 18, 24, 36, 48, 54};
+	u8		rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8		vht_en = (rate_idx >= ODM_RATEVHTSS1MCS0) ? 1 : 0;
+	u8		b_sgi = (rate & 0x80) >> 7;
+
+	PHYDM_DBG_F(dm, dbg_component, "( %s%s%s%s%d%s%s)\n",
+		((rate_idx >= ODM_RATEVHTSS1MCS0) && (rate_idx <= ODM_RATEVHTSS1MCS9)) ? "VHT 1ss  " : "",
+		((rate_idx >= ODM_RATEVHTSS2MCS0) && (rate_idx <= ODM_RATEVHTSS2MCS9)) ? "VHT 2ss " : "",
+		((rate_idx >= ODM_RATEVHTSS3MCS0) && (rate_idx <= ODM_RATEVHTSS3MCS9)) ? "VHT 3ss " : "",
+			(rate_idx >= ODM_RATEMCS0) ? "MCS " : "",
+		(vht_en) ? ((rate_idx - ODM_RATEVHTSS1MCS0) % 10) : ((rate_idx >= ODM_RATEMCS0) ? (rate_idx - ODM_RATEMCS0) : ((rate_idx <= ODM_RATE54M) ? legacy_table[rate_idx] : 0)),
+			(b_sgi) ? "-S" : "  ",
+			(rate_idx >= ODM_RATEMCS0) ? "" : "M");
+}
+
+void
+phydm_c2h_ra_report_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8   cmd_len
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8	macid = cmd_buf[1];
+	u8	rate = cmd_buf[0];
+	u8	curr_ra_ratio = 0xff;
+	u8	curr_bw = 0xff;
+	u8	rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8	rate_order;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+
+	if (cmd_len >= 7) {
+		curr_ra_ratio = cmd_buf[5];
+		curr_bw = cmd_buf[6];
+		PHYDM_DBG(dm, DBG_RA, "RA retry ratio: [%d]:", curr_ra_ratio);
+			/**/
+	}
+	
+	if (cmd_buf[3] != 0) {
+		if (cmd_buf[3] == 0xff) {
+			PHYDM_DBG(dm, DBG_RA, "FW Level: Fix rate[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 1) {
+			PHYDM_DBG(dm, DBG_RA, "Try Success[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 2) {
+			PHYDM_DBG(dm, DBG_RA, "Try Fail & Try Again[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 3) {
+			PHYDM_DBG(dm, DBG_RA, "rate Back[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 4) {
+			PHYDM_DBG(dm, DBG_RA, "start rate by RSSI[%d]:", macid);
+			/**/
+		} else if (cmd_buf[3] == 5) {
+			PHYDM_DBG(dm, DBG_RA, "Try rate[%d]:", macid);
+			/**/
+		}
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "Tx rate Update[%d]:", macid);
+	phydm_print_rate(dm, rate, DBG_RA);
+	
+	if (macid >= 128) {
+		u8 gid_index = macid - 128;
+		ra_tab->mu1_rate[gid_index] = rate;
+	}
+	
+	/*ra_tab->link_tx_rate[macid] = rate;*/
+		
+	if (is_sta_active(sta)) {
+		sta->ra_info.curr_tx_rate = rate;
+		sta->ra_info.curr_tx_bw = (enum channel_width)curr_bw;
+		sta->ra_info.curr_retry_ratio= curr_ra_ratio;
+
+		/*if (sta->ra_info.curr_tx_bw <  sta->ra_info.ra_bw_mode)*/
+	}
+
+	/*trigger power training*/
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+
+	rate_order = phydm_rate_order_compute(dm, rate_idx);
+
+	if ((dm->is_one_entry_only) ||
+		((rate_order > ra_tab->highest_client_tx_order) && (ra_tab->power_tracking_flag == 1))
+		) {
+		halrf_update_pwr_track(dm, rate_idx);
+		ra_tab->power_tracking_flag = 0;
+	}
+
+#endif
+
+	/*trigger dynamic rate ID*/
+/*#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))*/	/*dino will refine here later*/
+#if 0
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E))
+		phydm_update_rate_id(dm, rate, macid);
+#endif
+
+}
+
+void
+odm_ra_post_action_on_assoc(
+	void	*dm_void
+)
+{
+#if 0
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	dm->h2c_rarpt_connect = 1;
+	phydm_rssi_monitor_check(dm);
+	dm->h2c_rarpt_connect = 0;
+#endif
+}
+
+void
+phydm_modify_RA_PCR_threshold(
+	void		*dm_void,
+	u8		RA_offset_direction,
+	u8		RA_threshold_offset
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->RA_offset_direction = RA_offset_direction;
+	ra_tab->RA_threshold_offset = RA_threshold_offset;
+	PHYDM_DBG(dm, DBG_RA_MASK, "Set RA_threshold_offset = (( %s%d ))\n", ((RA_threshold_offset == 0) ? " " : ((RA_offset_direction) ? "+" : "-")), RA_threshold_offset);
+}
+
+#if 0 /*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+void
+odm_refresh_rate_adaptive_mask_mp(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct ra_table					*ra_tab = &dm->dm_ra_table;
+	void				*adapter	 =  dm->adapter;
+	void				*target_adapter = NULL;
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA(adapter);
+	PMGNT_INFO				mgnt_info = GetDefaultMgntInfo(adapter);
+	void			*loop_adapter = GetDefaultAdapter(adapter);
+	PMGNT_INFO					p_loop_mgnt_info = &loop_adapter->MgntInfo;
+	HAL_DATA_TYPE				*loop_hal_data = GET_HAL_DATA(loop_adapter);
+	
+	u32		i;
+	struct sta_info *entry;
+	u8		ratr_state_new;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+
+	if (adapter->bDriverStopped) {
+		PHYDM_DBG(dm, DBG_RA_MASK, "driver is going to unload\n");
+		return;
+	}
+
+	if (!hal_data->bUseRAMask) {
+		PHYDM_DBG(dm, DBG_RA_MASK, "driver does not control rate adaptive mask\n");
+		return;
+	}
+
+	/* if default port is connected, update RA table for default port (infrastructure mode only) */
+	/* Need to consider other ports for P2P cases*/
+
+	while(loop_adapter){
+		p_loop_mgnt_info = &loop_adapter->MgntInfo;
+		loop_hal_data = GET_HAL_DATA(loop_adapter);
+	
+		if (p_loop_mgnt_info->mAssoc && (!ACTING_AS_AP(loop_adapter))) {
+			odm_refresh_ldpc_rts_mp(loop_adapter, dm, p_loop_mgnt_info->mMacId, p_loop_mgnt_info->IOTPeer, loop_hal_data->UndecoratedSmoothedPWDB);
+		/*PHYDM_DBG(dm, DBG_RA_MASK, "Infrasture mode\n");*/
+
+			ratr_state_new = phydm_rssi_lv_dec(dm, loop_hal_data->UndecoratedSmoothedPWDB, p_loop_mgnt_info->Ratr_State);
+
+			if ((p_loop_mgnt_info->Ratr_State != ratr_state_new) || (ra_tab->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+				ra_tab->up_ramask_cnt = 0;
+				PHYDM_PRINT_ADDR(dm, DBG_RA_MASK, ("Target AP addr :"), p_loop_mgnt_info->Bssid);
+				PHYDM_DBG(dm, DBG_RA_MASK, "Update RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n\n",
+					mgnt_info->Ratr_State, ratr_state_new, loop_hal_data->UndecoratedSmoothedPWDB);
+
+				p_loop_mgnt_info->Ratr_State = ratr_state_new;
+				adapter->HalFunc.UpdateHalRAMaskHandler(loop_adapter, p_loop_mgnt_info->mMacId, NULL);
+			} else {
+				PHYDM_DBG(dm, DBG_RA_MASK, "Stay in RA level  = (( %d ))\n\n", ratr_state_new);
+				/**/
+			}
+		}
+
+		loop_adapter = GetNextExtAdapter(loop_adapter);
+	}
+
+	/*  */
+	/* The following part configure AP/VWifi/IBSS rate adaptive mask. */
+	/*  */
+
+	if (mgnt_info->mIbss)	/* Target: AP/IBSS peer. */
+		target_adapter = GetDefaultAdapter(adapter);
+	else
+		target_adapter = GetFirstAPAdapter(adapter);
+
+	/* if extension port (softap) is started, updaet RA table for more than one clients associate */
+	if (target_adapter != NULL) {
+		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+			entry = AsocEntry_EnumStation(target_adapter, i);
+
+			if (is_sta_active((&GET_STA_INFO(entry)))) {
+				odm_refresh_ldpc_rts_mp(target_adapter, dm, GET_STA_INFO(entry).mac_id, entry->IOTPeer, GET_STA_INFO(entry).rssi_stat.rssi);
+
+				ratr_state_new = phydm_rssi_lv_dec(dm, GET_STA_INFO(entry).rssi_stat.rssi, GET_STA_INFO(entry).ra_info.rssi_level);
+
+				if ((GET_STA_INFO(entry).ra_info.rssi_level != ratr_state_new) || (ra_tab->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+					ra_tab->up_ramask_cnt = 0;
+					PHYDM_PRINT_ADDR(dm, DBG_RA_MASK, ("Target AP addr :"), GET_STA_INFO(entry).mac_addr);
+					PHYDM_DBG(dm, DBG_RA_MASK, "Update Tx RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n",
+						GET_STA_INFO(entry).ra_info.rssi_level, ratr_state_new,  GET_STA_INFO(entry).rssi_stat.rssi);
+
+					GET_STA_INFO(entry).ra_info.rssi_level = ratr_state_new;
+					adapter->HalFunc.UpdateHalRAMaskHandler(target_adapter, GET_STA_INFO(entry).mac_id, entry);
+				} else {
+					PHYDM_DBG(dm, DBG_RA_MASK, "Stay in RA level  = (( %d ))\n\n", ratr_state_new);
+					/**/
+				}
+
+			}
+		}
+	}
+}
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+void
+odm_refresh_rate_adaptive_mask_ap(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	struct rtl8192cd_priv *priv = dm->priv;
+	struct aid_obj *aidarray;
+	u32		i;
+	struct sta_info *entry;
+	struct cmn_sta_info	*sta;
+	u8		ratr_state_new;
+
+	if (priv->up_time % 2)
+		return;
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		entry = dm->odm_sta_info[i];
+		sta = dm->phydm_sta_info[i];
+
+		if (is_sta_active(sta)) {
+			#if defined(UNIVERSAL_REPEATER) || defined(MBSSID)
+			aidarray = container_of(entry, struct aid_obj, station);
+			priv = aidarray->priv;
+			#endif
+
+			if (!priv->pmib->dot11StationConfigEntry.autoRate)
+				continue;
+
+			ratr_state_new = phydm_rssi_lv_dec(dm, (u32)sta->rssi_stat.rssi, sta->ra_info.rssi_level);
+
+			if ((sta->ra_info.rssi_level != ratr_state_new) || (ra_tab->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+				ra_tab->up_ramask_cnt = 0;
+				PHYDM_PRINT_ADDR(dm, DBG_RA_MASK, "Target AP addr :", sta->mac_addr);
+				PHYDM_DBG(dm, DBG_RA_MASK, "Update Tx RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n", sta->ra_info.rssi_level, ratr_state_new, sta->rssi_stat.rssi);
+
+				sta->ra_info.rssi_level = ratr_state_new;
+				phydm_gen_ramask_h2c_AP(dm, priv, entry, sta->ra_info.rssi_level);
+			} else {
+				PHYDM_DBG(dm, DBG_RA_MASK, "Stay in RA level  = (( %d ))\n\n", ratr_state_new);
+				/**/
+			}
+		}
+	}
+}
+#endif
+
+void
+phydm_rate_adaptive_mask_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PADAPTER		adapter	= (PADAPTER)dm->adapter;
+	PMGNT_INFO		mgnt_info = &(adapter->MgntInfo);
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+
+
+	if (mgnt_info->DM_Type == dm_type_by_driver)
+		hal_data->bUseRAMask = true;
+	else
+		hal_data->bUseRAMask = false;
+
+#endif
+
+	ra_t->ldpc_thres = 35;
+	ra_t->up_ramask_cnt = 0;
+	ra_t->up_ramask_cnt_tmp = 0;
+
+}
+
+void
+phydm_refresh_rate_adaptive_mask(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+
+	if (!(dm->support_ability & ODM_BB_RA_MASK)) {
+		PHYDM_DBG(dm, DBG_RA_MASK, "Return: Not support\n");
+		return;
+	}
+
+	if (!dm->is_linked)
+		return;
+
+	ra_t->up_ramask_cnt++;
+	/*ra_t->up_ramask_cnt_tmp++;*/
+	
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+	odm_refresh_rate_adaptive_mask_ap(dm);
+
+#else
+
+	phydm_ra_mask_watchdog(dm);
+
+#endif
+	
+}
+
+void
+phydm_show_sta_info(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = NULL;
+	struct ra_sta_info			*ra = NULL;
+	#ifdef CONFIG_BEAMFORMING
+	struct bf_cmn_info		*bf = NULL;
+	#endif
+	char		help[] = "-h";
+	u32		var1[10] = {0};
+	u32		used = *_used;
+	u32		out_len = *_out_len;
+	u32		i, macid_start, macid_end;
+	u8		tatal_sta_num = 0;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "All STA: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "STA[macid]: {2} {macid}\n");
+		return;
+	} else if (var1[0] == 1) {
+		macid_start = 0;
+		macid_end = ODM_ASSOCIATE_ENTRY_NUM;
+	} else if (var1[0] == 2) {
+		macid_start = var1[1];
+		macid_end = var1[1];
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Warning input value!\n");
+		return;
+	}
+		
+	for (i = macid_start; i < macid_end; i++) {
+		
+		sta = dm->phydm_sta_info[i];
+
+
+		if (!is_sta_active(sta))
+			continue;
+
+		ra = &sta->ra_info;
+		#ifdef CONFIG_BEAMFORMING
+		bf = &sta->bf_info;
+		#endif
+
+		tatal_sta_num++;
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "==[MACID: %d]============>\n", sta->mac_id);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "AID:%d\n", sta->aid);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "ADDR:%x-%x-%x-%x-%x-%x\n", 
+			       sta->mac_addr[5], sta->mac_addr[4],
+			       sta->mac_addr[3], sta->mac_addr[2],
+			       sta->mac_addr[1], sta->mac_addr[0]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "DM_ctrl:0x%x\n", sta->dm_ctrl);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BW:%d, MIMO_Type:0x%x\n", sta->bw_mode,
+			       sta->mimo_type);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "STBC_en:%d, LDPC_en=%d\n", sta->stbc_en,
+			       sta->ldpc_en);
+
+		/*[RSSI Info]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "RSSI{All, OFDM, CCK}={%d, %d, %d}\n", 
+			       sta->rssi_stat.rssi, sta->rssi_stat.rssi_ofdm,
+			       sta->rssi_stat.rssi_cck);
+
+		/*[RA Info]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Rate_ID:%d, RSSI_LV:%d, ra_bw:%d, SGI_en:%d\n",
+			       
+			       ra->rate_id, ra->rssi_level, ra->ra_bw_mode,
+			       ra->is_support_sgi);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "VHT_en:%d, Wireless_set=0x%x, sm_ps=%d\n", 
+			       ra->is_vht_enable, sta->support_wireless_set,
+			       sta->sm_ps);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Dis{RA, PT}={%d, %d}, TxRx:%d, Noisy:%d\n", 
+			       ra->disable_ra, ra->disable_pt, ra->txrx_state,
+			       ra->is_noisy);
+		
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "TX{Rate, BW}={0x%x, %d}, RTY:%d\n", 
+			       ra->curr_tx_rate, ra->curr_tx_bw,
+			       ra->curr_retry_ratio);
+	
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "RA_Mask:0x%llx\n", ra->ramask);
+		
+		/*[TP]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "TP{TX,RX}={%d, %d}\n", 
+			       sta->tx_moving_average_tp,
+			       sta->rx_moving_average_tp);
+
+		#ifdef CONFIG_BEAMFORMING
+		/*[Beamforming]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BF CAP{HT,VHT}={0x%x, 0x%x}\n", 
+			       bf->ht_beamform_cap, bf->vht_beamform_cap);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "BF {p_aid,g_id}={0x%x, 0x%x}\n\n", 
+			       bf->p_aid, bf->g_id);
+		#endif
+	}
+
+	if (tatal_sta_num == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "No Linked STA\n");
+	}
+	
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#ifdef	PHYDM_3RD_REFORM_RA_MASK
+
+u8
+phydm_get_tx_stream_num(
+	void		*dm_void,
+	enum 	rf_type	mimo_type
+	
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	tx_num = 1;
+
+	if (mimo_type == RF_1T1R || mimo_type == RF_1T2R)
+		tx_num = 1;
+	else if (mimo_type == RF_2T2R || mimo_type == RF_2T3R  || mimo_type == RF_2T4R)
+		tx_num = 2;
+	else if (mimo_type == RF_3T3R || mimo_type == RF_3T4R)
+		tx_num = 3;
+	else if (mimo_type == RF_4T4R)
+		tx_num = 4;
+	else {
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] no mimo_type is found\n");
+	}
+	return tx_num;
+}
+
+u64
+phydm_get_bb_mod_ra_mask(
+	void		*dm_void,
+	u8		macid
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info			*ra = NULL;
+	enum channel_width		bw = (enum channel_width)0;
+	enum wireless_set			wireless_mode = (enum wireless_set)0;
+	u8		tx_stream_num = 1;
+	u8		rssi_lv = 0;
+	u64		ra_mask_bitmap = 0;
+	
+	if (is_sta_active(sta)) {
+		
+		ra = &sta->ra_info;
+		bw = ra->ra_bw_mode;
+		wireless_mode = sta->support_wireless_set;
+		tx_stream_num = phydm_get_tx_stream_num(dm, sta->mimo_type);
+		rssi_lv = ra->rssi_level;
+		ra_mask_bitmap = ra->ramask;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid sta_info\n", __func__);
+		return 0;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "macid=%d ori_RA_Mask= 0x%llx\n", sta->mac_id, ra_mask_bitmap);
+	PHYDM_DBG(dm, DBG_RA, "wireless_mode=0x%x, tx_stream_num=%d, BW=%d, MimoPs=%d, rssi_lv=%d\n",
+		wireless_mode, tx_stream_num, bw, sta->sm_ps, rssi_lv);
+	
+	if (sta->sm_ps == SM_PS_STATIC) /*mimo_ps_enable*/
+		tx_stream_num = 1;
+
+
+	/*[Modify RA Mask by Wireless Mode]*/
+
+	if (wireless_mode == WIRELESS_CCK)								/*B mode*/
+		ra_mask_bitmap &= 0x0000000f;
+	else if (wireless_mode == WIRELESS_OFDM)							/*G mode*/
+		ra_mask_bitmap &= 0x00000ff0;
+	else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM))			/*BG mode*/
+		ra_mask_bitmap &= 0x00000ff5;
+	else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {
+																	/*N_2G*/
+		if (tx_stream_num == 1) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x000ff015;
+			else
+				ra_mask_bitmap &= 0x000ff005;
+		} else if (tx_stream_num == 2) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x0ffff015;
+			else
+				ra_mask_bitmap &= 0x0ffff005;
+		} else if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0xffffff015;
+	} else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_HT)) {		/*N_5G*/
+	
+		if (tx_stream_num == 1) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x000ff030;
+			else
+				ra_mask_bitmap &= 0x000ff010;
+		} else if (tx_stream_num == 2) {
+			if (bw == CHANNEL_WIDTH_40)
+				ra_mask_bitmap &= 0x0ffff030;
+			else
+				ra_mask_bitmap &= 0x0ffff010;
+		} else if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0xffffff010;
+	} else if (wireless_mode ==  (WIRELESS_CCK |WIRELESS_OFDM | WIRELESS_VHT)) {
+																	/*AC_2G*/
+		if (tx_stream_num == 1)
+			ra_mask_bitmap &= 0x003ff015;
+		else if (tx_stream_num == 2)
+			ra_mask_bitmap &= 0xfffff015;
+		else if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0x3fffffff010;
+		
+
+		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
+			ra_mask_bitmap &= 0x1ff7fdfffff;
+		}
+	} else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_VHT)) {		/*AC_5G*/
+	
+		if (tx_stream_num == 1)
+			ra_mask_bitmap &= 0x003ff010;
+		else if (tx_stream_num == 2)
+			ra_mask_bitmap &= 0xfffff010;
+		else  if (tx_stream_num == 3)
+			ra_mask_bitmap &= 0x3fffffff010;
+
+		if (bw == CHANNEL_WIDTH_20) /* AC 20MHz doesn't support MCS9 */
+			ra_mask_bitmap &= 0x1ff7fdfffff;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] No RA mask is found\n");
+		/**/
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "Mod by mode=0x%llx\n", ra_mask_bitmap);
+
+	
+	/*[Modify RA Mask by RSSI level]*/
+	if (wireless_mode != WIRELESS_CCK) {
+		if (rssi_lv == 0)
+			ra_mask_bitmap &= 0xffffffffffffffff;
+		else if (rssi_lv == 1)
+			ra_mask_bitmap &= 0xfffffffffffffff0;
+		else if (rssi_lv == 2)
+			ra_mask_bitmap &= 0xffffffffffffefe0;
+		else if (rssi_lv == 3)
+			ra_mask_bitmap &= 0xffffffffffffcfc0;
+		else if (rssi_lv == 4)
+			ra_mask_bitmap &= 0xffffffffffff8f80;
+		else if (rssi_lv >= 5)
+			ra_mask_bitmap &= 0xffffffffffff0f00;
+
+	}
+	PHYDM_DBG(dm, DBG_RA, "Mod by RSSI=0x%llx\n", ra_mask_bitmap);
+
+	return ra_mask_bitmap;
+}
+
+u8
+phydm_get_rate_id(
+	void			*dm_void,
+	u8			macid
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info			*ra =NULL;
+	enum channel_width		bw = (enum channel_width)0;
+	enum wireless_set			wireless_mode = (enum wireless_set)0;
+	u8	tx_stream_num = 1;
+	u8	rate_id_idx = PHYDM_BGN_20M_1SS;
+
+	if (is_sta_active(sta)) {
+		
+		ra = &sta->ra_info;
+		bw = ra->ra_bw_mode;
+		wireless_mode = sta->support_wireless_set;
+		tx_stream_num = phydm_get_tx_stream_num(dm, sta->mimo_type);
+
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s: invalid sta_info\n", __func__);
+		return 0;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "macid=%d, wireless_set=0x%x, tx_stream_num=%d, BW=0x%x\n",
+			sta->mac_id, wireless_mode, tx_stream_num, bw);
+
+	if (wireless_mode == WIRELESS_CCK)								/*B mode*/
+		rate_id_idx = PHYDM_B_20M;
+	else if (wireless_mode ==  WIRELESS_OFDM)						/*G mode*/
+		rate_id_idx = PHYDM_G;
+	else if (wireless_mode ==  (WIRELESS_CCK | WIRELESS_OFDM))			/*BG mode*/
+		rate_id_idx = PHYDM_BG;
+	else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_HT)) {		/*GN mode*/
+	
+		if (tx_stream_num == 1)
+			rate_id_idx = PHYDM_GN_N1SS;
+		else if (tx_stream_num == 2)
+			rate_id_idx = PHYDM_GN_N2SS;
+		else if (tx_stream_num == 3)
+			rate_id_idx = PHYDM_ARFR5_N_3SS;
+	} else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {	/*BGN mode*/
+	
+
+		if (bw == CHANNEL_WIDTH_40) {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_BGN_40M_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_BGN_40M_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+
+		} else {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_BGN_20M_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_BGN_20M_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+		}
+	} else if (wireless_mode == (WIRELESS_OFDM | WIRELESS_VHT)) {	/*AC mode*/
+	
+		if (tx_stream_num == 1)
+			rate_id_idx = PHYDM_ARFR1_AC_1SS;
+		else if (tx_stream_num == 2)
+			rate_id_idx = PHYDM_ARFR0_AC_2SS;
+		else if (tx_stream_num == 3)
+			rate_id_idx = PHYDM_ARFR4_AC_3SS;
+	} else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_VHT)) {	/*AC 2.4G mode*/
+	
+		if (bw >= CHANNEL_WIDTH_80) {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_ARFR1_AC_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_ARFR0_AC_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		} else {
+			if (tx_stream_num == 1)
+				rate_id_idx = PHYDM_ARFR2_AC_2G_1SS;
+			else if (tx_stream_num == 2)
+				rate_id_idx = PHYDM_ARFR3_AC_2G_2SS;
+			else if (tx_stream_num == 3)
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		}
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] No rate_id is found\n");
+		rate_id_idx = 0;
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "Rate_ID=((0x%x))\n", rate_id_idx);
+
+	return rate_id_idx;
+}
+
+void
+phydm_ra_h2c(
+	void	*dm_void,
+	u8	macid,
+	u8	dis_ra,
+	u8	dis_pt,
+	u8	no_update_bw,
+	u8	init_ra_lv,
+	u64	ra_mask
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+	u8		h2c_val[H2C_MAX_LENGTH] = {0};
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+	
+	PHYDM_DBG(dm, DBG_RA, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA, "MACID=%d\n", sta->mac_id);
+
+	if (dm->is_disable_power_training == true)
+		dis_pt = true;
+	else if (dm->is_disable_power_training == false)
+		dis_pt = false;
+
+	h2c_val[0] = sta->mac_id;
+	h2c_val[1] = (ra->rate_id & 0x1f) | ((init_ra_lv & 0x3) << 5) | (ra->is_support_sgi << 7);
+	h2c_val[2] = (u8)((ra->ra_bw_mode) | (((sta->ldpc_en) ? 1 : 0) << 2) | 
+					((no_update_bw & 0x1) << 3) | (ra->is_vht_enable << 4) | 
+					((dis_pt & 0x1) << 6) | ((dis_ra & 0x1) << 7));
+	
+	h2c_val[3] = (u8)(ra_mask & 0xff);
+	h2c_val[4] = (u8)((ra_mask & 0xff00) >> 8);
+	h2c_val[5] = (u8)((ra_mask & 0xff0000) >> 16);
+	h2c_val[6] = (u8)((ra_mask & 0xff000000) >> 24);
+
+	PHYDM_DBG(dm, DBG_RA, "PHYDM h2c[0x40]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_RA_MASK, H2C_MAX_LENGTH, h2c_val);
+
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
+		
+		h2c_val[3] = (u8)((ra_mask >> 32) & 0x000000ff);
+		h2c_val[4] = (u8)(((ra_mask >> 32) & 0x0000ff00) >> 8);
+		h2c_val[5] = (u8)(((ra_mask >> 32) & 0x00ff0000) >> 16);
+		h2c_val[6] = (u8)(((ra_mask >> 32) & 0xff000000) >> 24);
+
+		PHYDM_DBG(dm, DBG_RA, "PHYDM h2c[0x46]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+		
+		odm_fill_h2c_cmd(dm, PHYDM_RA_MASK_ABOVE_3SS, 5, h2c_val);
+	}
+	#endif
+}
+
+void
+phydm_ra_registed(
+	void	*dm_void,
+	u8	macid,
+	u8	rssi_from_assoc
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+	u8	init_ra_lv;
+	u64	ra_mask;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA_MASK, "[Warning] %s invalid sta_info\n", __func__);
+		PHYDM_DBG(dm, DBG_RA_MASK, "MACID=%d\n", macid);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA_MASK, "MACID=%d, rssi_from_assoc=%d\n", 
+		sta->mac_id, rssi_from_assoc);
+
+	#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		ra->rate_id = phydm_get_rate_id_88e(dm, macid);
+	else
+	#endif
+	{
+		ra->rate_id = phydm_get_rate_id(dm, macid);
+	}
+	
+	/*ra->is_vht_enable = (sta->support_wireless_set | WIRELESS_VHT) ? 1 : 0;*/
+	/*ra->disable_ra = 0;*/
+	/*ra->disable_pt = 0;*/
+	ra_mask = phydm_get_bb_mod_ra_mask(dm, macid);
+
+
+	if (rssi_from_assoc > 40)
+		init_ra_lv = 1;
+	else if (rssi_from_assoc > 20)
+		init_ra_lv = 2;
+	else
+		init_ra_lv = 3;
+
+	if (ra_t->record_ra_info)
+		ra_t->record_ra_info(dm, macid, sta, ra_mask);
+
+	#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		/*Driver RA*/
+		odm_ra_update_rate_info_8188e(dm, macid, ra->rate_id, (u32)ra_mask, ra->is_support_sgi);
+	else
+	#endif
+	{
+		/*FW RA*/
+		phydm_ra_h2c(dm, macid, ra->disable_ra, ra->disable_pt, 0, init_ra_lv, ra_mask);
+	}
+
+	
+
+}
+
+void
+phydm_ra_offline(
+	void	*dm_void,
+	u8	macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA, "MACID=%d\n", sta->mac_id);
+
+	odm_memory_set(dm, &ra->rate_id, 0, sizeof(struct ra_sta_info));
+	ra->disable_ra = 1;
+	ra->disable_pt = 1;
+
+	if (ra_t->record_ra_info)
+		ra_t->record_ra_info(dm, macid, sta, 0);
+
+	if (dm->support_ic_type != ODM_RTL8188E)
+		phydm_ra_h2c(dm, macid, ra->disable_ra, ra->disable_pt, 0, 0, 0);
+}
+
+void
+phydm_ra_mask_watchdog(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = NULL;
+	struct ra_sta_info				*ra = NULL;
+	u8		macid;
+	u64		ra_mask;
+	u8		rssi_lv_new;
+
+	if (!(dm->support_ability & ODM_BB_RA_MASK))
+		return;
+	
+	if (((!dm->is_linked)) || (dm->phydm_sys_up_time % 2) == 1)
+		return;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+	
+	ra_t->up_ramask_cnt++;
+
+	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		
+		sta = dm->phydm_sta_info[macid];
+		
+		if (!is_sta_active(sta))
+			continue;
+
+		ra = &sta->ra_info;
+
+		if (ra->disable_ra)
+			continue;
+
+
+		/*to be modified*/
+		#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+		if ((dm->support_ic_type == ODM_RTL8812) ||
+			((dm->support_ic_type == ODM_RTL8821) && (dm->cut_version == ODM_CUT_A))
+			) {
+			
+			if (sta->rssi_stat.rssi < ra_t->ldpc_thres) {
+				
+				#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+				set_ra_ldpc_8812(sta, true);		/*LDPC TX enable*/
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+					{
+						MgntSet_TX_LDPC(macid, true);
+					}
+				#endif
+				PHYDM_DBG(dm, DBG_RA_MASK, "RSSI=%d, ldpc_en =TRUE\n", sta->rssi_stat.rssi);
+				
+			} else if (sta->rssi_stat.rssi > (ra_t->ldpc_thres + 3)) {
+				#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+				set_ra_ldpc_8812(sta, false);	/*LDPC TX disable*/
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+					{
+						MgntSet_TX_LDPC(macid, false);
+					}
+				#endif
+				PHYDM_DBG(dm, DBG_RA_MASK, "RSSI=%d, ldpc_en =FALSE\n", sta->rssi_stat.rssi);
+			}	
+		}
+		#endif
+
+		rssi_lv_new = phydm_rssi_lv_dec(dm, (u32)sta->rssi_stat.rssi, ra->rssi_level);
+
+		if ((ra->rssi_level != rssi_lv_new) || 
+			(ra_t->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+			PHYDM_DBG(dm, DBG_RA_MASK, "RSSI LV:((%d))->((%d))\n", ra->rssi_level, rssi_lv_new);
+			
+			ra->rssi_level = rssi_lv_new;
+			ra_t->up_ramask_cnt = 0;
+			
+			ra_mask = phydm_get_bb_mod_ra_mask(dm, macid);
+
+			if (ra_t->record_ra_info)
+				ra_t->record_ra_info(dm, macid, sta, ra_mask);
+
+			#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
+			if (dm->support_ic_type == ODM_RTL8188E)
+				/*Driver RA*/
+				odm_ra_update_rate_info_8188e(dm, macid, ra->rate_id, (u32)ra_mask, ra->is_support_sgi);
+			else
+			#endif
+			{
+				/*FW RA*/
+				phydm_ra_h2c(dm, macid, ra->disable_ra, ra->disable_pt, 1, 0, ra_mask);
+			}
+		}
+	}
+
+}
+#endif
+
+u8
+phydm_vht_en_mapping(
+	void			*dm_void,
+	u32			wireless_mode
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			vht_en_out = 0;
+
+	if ((wireless_mode == PHYDM_WIRELESS_MODE_AC_5G) ||
+	    (wireless_mode == PHYDM_WIRELESS_MODE_AC_24G) ||
+	    (wireless_mode == PHYDM_WIRELESS_MODE_AC_ONLY)
+	   ) {
+		vht_en_out = 1;
+		/**/
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "wireless_mode= (( 0x%x )), VHT_EN= (( %d ))\n", wireless_mode, vht_en_out);
+	return vht_en_out;
+}
+
+u8
+phydm_rate_id_mapping(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			bw
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8			rate_id_idx = 0;
+
+	PHYDM_DBG(dm, DBG_RA, "wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x ))\n",
+			wireless_mode, rf_type, bw);
+
+
+	switch (wireless_mode) {
+	case PHYDM_WIRELESS_MODE_N_24G:
+	{
+		if (bw == CHANNEL_WIDTH_40) {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_BGN_40M_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_BGN_40M_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+
+		} else {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_BGN_20M_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_BGN_20M_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR5_N_3SS;
+		}
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_N_5G:
+	{
+		if (rf_type == RF_1T1R)
+			rate_id_idx = PHYDM_GN_N1SS;
+		else if (rf_type == RF_2T2R)
+			rate_id_idx = PHYDM_GN_N2SS;
+		else
+			rate_id_idx = PHYDM_ARFR5_N_3SS;
+	}
+
+	break;
+
+	case PHYDM_WIRELESS_MODE_G:
+		rate_id_idx = PHYDM_BG;
+		break;
+
+	case PHYDM_WIRELESS_MODE_A:
+		rate_id_idx = PHYDM_G;
+		break;
+
+	case PHYDM_WIRELESS_MODE_B:
+		rate_id_idx = PHYDM_B_20M;
+		break;
+
+
+	case PHYDM_WIRELESS_MODE_AC_5G:
+	case PHYDM_WIRELESS_MODE_AC_ONLY:
+	{
+		if (rf_type == RF_1T1R)
+			rate_id_idx = PHYDM_ARFR1_AC_1SS;
+		else if (rf_type == RF_2T2R)
+			rate_id_idx = PHYDM_ARFR0_AC_2SS;
+		else
+			rate_id_idx = PHYDM_ARFR4_AC_3SS;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_AC_24G:
+	{
+		/*Becareful to set "Lowest rate" while using PHYDM_ARFR4_AC_3SS in 2.4G/5G*/
+		if (bw >= CHANNEL_WIDTH_80) {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_ARFR1_AC_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_ARFR0_AC_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		} else {
+			if (rf_type == RF_1T1R)
+				rate_id_idx = PHYDM_ARFR2_AC_2G_1SS;
+			else if (rf_type == RF_2T2R)
+				rate_id_idx = PHYDM_ARFR3_AC_2G_2SS;
+			else
+				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+		}
+	}
+	break;
+
+	default:
+		rate_id_idx = 0;
+		break;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "RA rate ID = (( 0x%x ))\n", rate_id_idx);
+
+	return rate_id_idx;
+}
+
+void
+phydm_update_hal_ra_mask(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			bw,
+	u8			mimo_ps_enable,
+	u8			disable_cck_rate,
+	u32			*ratr_bitmap_msb_in,
+	u32			*ratr_bitmap_lsb_in,
+	u8			tx_rate_level
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32			ratr_bitmap = *ratr_bitmap_lsb_in, ratr_bitmap_msb = *ratr_bitmap_msb_in;
+
+	/*PHYDM_DBG(dm, DBG_RA_MASK, "phydm_rf_type = (( %x )), rf_type = (( %x ))\n", phydm_rf_type, rf_type);*/
+	PHYDM_DBG(dm, DBG_RA_MASK, "Platfoem original RA Mask = (( 0x %x | %x ))\n", ratr_bitmap_msb, ratr_bitmap);
+
+	switch (wireless_mode) {
+	case PHYDM_WIRELESS_MODE_B:
+	{
+		ratr_bitmap &= 0x0000000f;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_G:
+	{
+		ratr_bitmap &= 0x00000ff5;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_A:
+	{
+		ratr_bitmap &= 0x00000ff0;
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_N_24G:
+	case PHYDM_WIRELESS_MODE_N_5G:
+	{
+		if (mimo_ps_enable)
+			rf_type = RF_1T1R;
+
+		if (rf_type == RF_1T1R) {
+			if (bw == CHANNEL_WIDTH_40)
+				ratr_bitmap &= 0x000ff015;
+			else
+				ratr_bitmap &= 0x000ff005;
+		} else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R) {
+			if (bw == CHANNEL_WIDTH_40)
+				ratr_bitmap &= 0x0ffff015;
+			else
+				ratr_bitmap &= 0x0ffff005;
+		} else { /*3T*/
+
+			ratr_bitmap &= 0xfffff015;
+			ratr_bitmap_msb &= 0xf;
+		}
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_AC_24G:
+	{
+		if (rf_type == RF_1T1R)
+			ratr_bitmap &= 0x003ff015;
+		else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R)
+			ratr_bitmap &= 0xfffff015;
+		else {/*3T*/
+
+			ratr_bitmap &= 0xfffff010;
+			ratr_bitmap_msb &= 0x3ff;
+		}
+
+		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
+			ratr_bitmap &= 0x7fdfffff;
+			ratr_bitmap_msb &= 0x1ff;
+		}
+	}
+	break;
+
+	case PHYDM_WIRELESS_MODE_AC_5G:
+	{
+		if (rf_type == RF_1T1R)
+			ratr_bitmap &= 0x003ff010;
+		else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R)
+			ratr_bitmap &= 0xfffff010;
+		else {/*3T*/
+
+			ratr_bitmap &= 0xfffff010;
+			ratr_bitmap_msb &= 0x3ff;
+		}
+
+		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
+			ratr_bitmap &= 0x7fdfffff;
+			ratr_bitmap_msb &= 0x1ff;
+		}
+	}
+	break;
+
+	default:
+		break;
+	}
+
+	if (wireless_mode != PHYDM_WIRELESS_MODE_B) {
+		if (tx_rate_level == 0)
+			ratr_bitmap &=  0xffffffff;
+		else if (tx_rate_level == 1)
+			ratr_bitmap &=  0xfffffff0;
+		else if (tx_rate_level == 2)
+			ratr_bitmap &=  0xffffefe0;
+		else if (tx_rate_level == 3)
+			ratr_bitmap &=  0xffffcfc0;
+		else if (tx_rate_level == 4)
+			ratr_bitmap &=  0xffff8f80;
+		else if (tx_rate_level >= 5)
+			ratr_bitmap &=  0xffff0f00;
+
+	}
+
+	if (disable_cck_rate)
+		ratr_bitmap &= 0xfffffff0;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x )), MimoPs_en = (( %d )), tx_rate_level= (( 0x%x ))\n",
+		wireless_mode, rf_type, bw, mimo_ps_enable, tx_rate_level);
+
+	/*PHYDM_DBG(dm, DBG_RA_MASK, "111 Phydm modified RA Mask = (( 0x %x | %x ))\n", ratr_bitmap_msb, ratr_bitmap);*/
+
+	*ratr_bitmap_lsb_in = ratr_bitmap;
+	*ratr_bitmap_msb_in = ratr_bitmap_msb;
+	PHYDM_DBG(dm, DBG_RA_MASK, "Phydm modified RA Mask = (( 0x %x | %x ))\n", *ratr_bitmap_msb_in, *ratr_bitmap_lsb_in);
+
+}
+
+u8
+phydm_rssi_lv_dec(
+	void			*dm_void,
+	u32			rssi,
+	u8			ratr_state
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	rssi_lv_table[RA_FLOOR_TABLE_SIZE] = {20, 34, 38, 42, 46, 50, 100}; /*MCS0 ~ MCS4 , VHT1SS MCS0 ~ MCS4 , G 6M~24M*/
+	u8	new_rssi_lv = 0;
+	u8	i;
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "curr RA level=(%d), Table_ori=[%d, %d, %d, %d, %d, %d]\n",
+		ratr_state, rssi_lv_table[0], rssi_lv_table[1], rssi_lv_table[2], rssi_lv_table[3], rssi_lv_table[4], rssi_lv_table[5]);
+
+	for (i = 0; i < RA_FLOOR_TABLE_SIZE; i++) {
+		if (i >= (ratr_state))
+			rssi_lv_table[i] += RA_FLOOR_UP_GAP;
+	}
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "RSSI=(%d), Table_mod=[%d, %d, %d, %d, %d, %d]\n",
+		rssi, rssi_lv_table[0], rssi_lv_table[1], rssi_lv_table[2], rssi_lv_table[3], rssi_lv_table[4], rssi_lv_table[5]);
+
+	for (i = 0; i < RA_FLOOR_TABLE_SIZE; i++) {
+		if (rssi < rssi_lv_table[i]) {
+			new_rssi_lv = i;
+			break;
+		}
+	}
+	return	new_rssi_lv;
+}
+
+u8
+phydm_rate_order_compute(
+	void	*dm_void,
+	u8	rate_idx
+)
+{
+	u8		rate_order = 0;
+
+	if (rate_idx >= ODM_RATEVHTSS4MCS0) {
+		rate_idx -= ODM_RATEVHTSS4MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEVHTSS3MCS0) {
+		rate_idx -= ODM_RATEVHTSS3MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEVHTSS2MCS0) {
+		rate_idx -= ODM_RATEVHTSS2MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEVHTSS1MCS0) {
+		rate_idx -= ODM_RATEVHTSS1MCS0;
+		/**/
+	} else if (rate_idx >= ODM_RATEMCS24) {
+		rate_idx -= ODM_RATEMCS24;
+		/**/
+	} else if (rate_idx >= ODM_RATEMCS16) {
+		rate_idx -= ODM_RATEMCS16;
+		/**/
+	} else if (rate_idx >= ODM_RATEMCS8) {
+		rate_idx -= ODM_RATEMCS8;
+		/**/
+	}
+	rate_order = rate_idx;
+
+	return rate_order;
+
+}
+
+u8
+phydm_rate2ss(
+	void	*dm_void,
+	u8	rate_idx
+)
+{
+	u8		ret = 0xff;
+	u8		i,j;
+	u8		search_idx;
+	u32		ss_mapping_tab[4][3] = {{0x00000000, 0x003ff000, 0x000ff000},
+								{0x00000000, 0xffc00000, 0x0ff00000},
+								{0x000003ff, 0x0000000f, 0xf0000000},
+								{0x000ffc00, 0x00000ff0, 0x00000000}};
+	if (rate_idx < 32) {
+		search_idx = rate_idx;
+		j = 0;
+	} else if (rate_idx < 64) {
+		search_idx = rate_idx - 32;
+		j = 1;
+	} else {
+		search_idx = rate_idx -64;
+		j = 2;
+	}
+	for (i = 0; i<4; i++)
+		if (ss_mapping_tab[i][j] & BIT(search_idx))
+			ret = i;
+	return ret;
+}
+
+u8
+phydm_rate2plcp(
+	void	*dm_void,
+	u8	rate_idx
+)
+{
+	u8		rate2ss = 0;
+	u8		vht_en = 0;
+	u8		ltftime = 0;
+	u8		plcptime = 0xff;
+
+	if (rate_idx < ODM_RATE6M) {
+		plcptime = 192;
+		/* CCK PLCP = 192us (long preamble) */
+	} else if (rate_idx < ODM_RATEMCS0) {
+		plcptime = 20;
+		/* LegOFDM PLCP = 20us */
+	} else {
+		if (rate_idx < ODM_RATEVHTSS1MCS0)
+			plcptime = 32;
+		/* HT mode PLCP = 20us + 12us + 4us x Nss */
+		else
+			plcptime = 36;
+		/* VHT mode PLCP = 20us + 16us + 4us x Nss */		
+		rate2ss = phydm_rate2ss(dm_void, rate_idx);
+		if (rate2ss == 0xff)
+			return 0xff;
+		else
+			ltftime = (rate2ss + 1) * 4;
+		plcptime += ltftime;
+		/**/
+	}
+	return plcptime;
+
+}
+
+u8
+phydm_get_plcp(
+	void	*dm_void,
+	u16	macid
+)
+{
+	u8		plcp_time = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info			*sta = NULL;
+	struct ra_sta_info				*ra = NULL;
+	sta = dm->phydm_sta_info[macid];
+	ra = &sta->ra_info;
+	plcp_time = phydm_rate2plcp(dm, ra->curr_tx_rate);
+	return plcp_time;
+}
+
+
+void
+phydm_ra_common_info_update(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = NULL;
+	u16		macid;
+	u8		rate_order_tmp;
+	u8		cnt = 0;
+
+	ra_tab->highest_client_tx_order = 0;
+	ra_tab->power_tracking_flag = 1;
+
+	if (!dm->number_linked_client)
+		return;
+
+	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		sta = dm->phydm_sta_info[macid];
+
+		if (is_sta_active(sta)) {
+			rate_order_tmp = phydm_rate_order_compute(dm, (sta->ra_info.curr_tx_rate & 0x7f));
+
+			if (rate_order_tmp >= (ra_tab->highest_client_tx_order)) {
+				ra_tab->highest_client_tx_order = rate_order_tmp;
+				ra_tab->highest_client_tx_rate_order = macid;
+			}
+
+			cnt++;
+
+			if (cnt == dm->number_linked_client)
+				break;
+		}
+	}
+	PHYDM_DBG(dm, DBG_RA, "MACID[%d], Highest Tx order Update for power traking: %d\n", (ra_tab->highest_client_tx_rate_order), (ra_tab->highest_client_tx_order));
+}
+
+void
+phydm_ra_info_watchdog(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	phydm_ra_common_info_update(dm);
+	#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+	phydm_ra_dynamic_retry_limit(dm);
+	#endif
+	phydm_ra_dynamic_retry_count(dm);
+	phydm_refresh_rate_adaptive_mask(dm);
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_refresh_basic_rate_mask(dm);
+	#endif
+}
+
+void
+phydm_ra_info_init(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->highest_client_tx_rate_order = 0;
+	ra_tab->highest_client_tx_order = 0;
+	ra_tab->RA_threshold_offset = 0;
+	ra_tab->RA_offset_direction = 0;
+	
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		u32	ret_value;
+
+		ret_value = odm_get_bb_reg(dm, 0x4c8, MASKBYTE2);
+		odm_set_bb_reg(dm, 0x4cc, MASKBYTE3, (ret_value - 1));
+	}
+#endif
+	
+	#ifdef CONFIG_RA_DYNAMIC_RTY_LIMIT
+	phydm_ra_dynamic_retry_limit_init(dm);
+	#endif
+
+	#ifdef CONFIG_RA_DYNAMIC_RATE_ID
+	phydm_ra_dynamic_rate_id_init(dm);
+	#endif
+
+	#ifdef CONFIG_RA_DBG_CMD
+	odm_ra_para_adjust_init(dm);
+	#endif
+
+	phydm_rate_adaptive_mask_init(dm);
+	
+}
+
+u8
+odm_find_rts_rate(
+	void			*dm_void,
+	u8			tx_rate,
+	boolean		is_erp_protect
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8	rts_ini_rate = ODM_RATE6M;
+
+	if (is_erp_protect) /* use CCK rate as RTS*/
+		rts_ini_rate = ODM_RATE1M;
+	else {
+		switch (tx_rate) {
+		case ODM_RATEVHTSS3MCS9:
+		case ODM_RATEVHTSS3MCS8:
+		case ODM_RATEVHTSS3MCS7:
+		case ODM_RATEVHTSS3MCS6:
+		case ODM_RATEVHTSS3MCS5:
+		case ODM_RATEVHTSS3MCS4:
+		case ODM_RATEVHTSS3MCS3:
+		case ODM_RATEVHTSS2MCS9:
+		case ODM_RATEVHTSS2MCS8:
+		case ODM_RATEVHTSS2MCS7:
+		case ODM_RATEVHTSS2MCS6:
+		case ODM_RATEVHTSS2MCS5:
+		case ODM_RATEVHTSS2MCS4:
+		case ODM_RATEVHTSS2MCS3:
+		case ODM_RATEVHTSS1MCS9:
+		case ODM_RATEVHTSS1MCS8:
+		case ODM_RATEVHTSS1MCS7:
+		case ODM_RATEVHTSS1MCS6:
+		case ODM_RATEVHTSS1MCS5:
+		case ODM_RATEVHTSS1MCS4:
+		case ODM_RATEVHTSS1MCS3:
+		case ODM_RATEMCS15:
+		case ODM_RATEMCS14:
+		case ODM_RATEMCS13:
+		case ODM_RATEMCS12:
+		case ODM_RATEMCS11:
+		case ODM_RATEMCS7:
+		case ODM_RATEMCS6:
+		case ODM_RATEMCS5:
+		case ODM_RATEMCS4:
+		case ODM_RATEMCS3:
+		case ODM_RATE54M:
+		case ODM_RATE48M:
+		case ODM_RATE36M:
+		case ODM_RATE24M:
+			rts_ini_rate = ODM_RATE24M;
+			break;
+		case ODM_RATEVHTSS3MCS2:
+		case ODM_RATEVHTSS3MCS1:
+		case ODM_RATEVHTSS2MCS2:
+		case ODM_RATEVHTSS2MCS1:
+		case ODM_RATEVHTSS1MCS2:
+		case ODM_RATEVHTSS1MCS1:
+		case ODM_RATEMCS10:
+		case ODM_RATEMCS9:
+		case ODM_RATEMCS2:
+		case ODM_RATEMCS1:
+		case ODM_RATE18M:
+		case ODM_RATE12M:
+			rts_ini_rate = ODM_RATE12M;
+			break;
+		case ODM_RATEVHTSS3MCS0:
+		case ODM_RATEVHTSS2MCS0:
+		case ODM_RATEVHTSS1MCS0:
+		case ODM_RATEMCS8:
+		case ODM_RATEMCS0:
+		case ODM_RATE9M:
+		case ODM_RATE6M:
+			rts_ini_rate = ODM_RATE6M;
+			break;
+		case ODM_RATE11M:
+		case ODM_RATE5_5M:
+		case ODM_RATE2M:
+		case ODM_RATE1M:
+			rts_ini_rate = ODM_RATE1M;
+			break;
+		default:
+			rts_ini_rate = ODM_RATE6M;
+			break;
+		}
+	}
+
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (rts_ini_rate < ODM_RATE6M)
+			rts_ini_rate = ODM_RATE6M;
+	}
+	return rts_ini_rate;
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_refresh_basic_rate_mask(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter	 =  dm->adapter;
+	static u8		stage = 0;
+	u8			cur_stage = 0;
+	OCTET_STRING	os_rate_set;
+	PMGNT_INFO		mgnt_info = GetDefaultMgntInfo(((PADAPTER)adapter));
+	u8			rate_set[5] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M, MGN_6M};
+
+	if (dm->support_ic_type != ODM_RTL8812 && dm->support_ic_type != ODM_RTL8821)
+		return;
+
+	if (dm->is_linked == false)	/* unlink Default port information */
+		cur_stage = 0;
+	else if (dm->rssi_min < 40)	/* link RSSI  < 40% */
+		cur_stage = 1;
+	else if (dm->rssi_min > 45)	/* link RSSI > 45% */
+		cur_stage = 3;
+	else
+		cur_stage = 2;					/* link  25% <= RSSI <= 30% */
+
+	if (cur_stage != stage) {
+		if (cur_stage == 1) {
+			FillOctetString(os_rate_set, rate_set, 5);
+			FilterSupportRate(mgnt_info->mBrates, &os_rate_set, false);
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_BASIC_RATE, (u8 *)&os_rate_set);
+		} else if (cur_stage == 3 && (stage == 1 || stage == 2))
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_BASIC_RATE, (u8 *)(&mgnt_info->mBrates));
+	}
+
+	stage = cur_stage;
+}
+
+#if 0
+void
+odm_refresh_ldpc_rts_mp(
+	void			*adapter,
+	struct dm_struct			*dm,
+	u8				m_mac_id,
+	u8				iot_peer,
+	s32				undecorated_smoothed_pwdb
+)
+{
+	boolean					is_ctl_ldpc = false;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+
+	if (dm->support_ic_type != ODM_RTL8821 && dm->support_ic_type != ODM_RTL8812)
+		return;
+
+	if ((dm->support_ic_type == ODM_RTL8821) && (dm->cut_version == ODM_CUT_A))
+		is_ctl_ldpc = true;
+	else if (dm->support_ic_type == ODM_RTL8812 &&
+		 iot_peer == HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP)
+		is_ctl_ldpc = true;
+
+	if (is_ctl_ldpc) {
+		if (undecorated_smoothed_pwdb < (ra_t->ldpc_thres - 5))
+			MgntSet_TX_LDPC(m_mac_id, true);
+		else if (undecorated_smoothed_pwdb > ra_t->ldpc_thres)
+			MgntSet_TX_LDPC(m_mac_id, false);
+	}
+}
+#endif
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+
+void
+phydm_gen_ramask_h2c_AP(
+	void			*dm_void,
+	struct rtl8192cd_priv *priv,
+	struct sta_info *entry,
+	u8			rssi_level
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type == ODM_RTL8812) {
+		#if (RTL8812A_SUPPORT == 1)
+		UpdateHalRAMask8812(priv, entry, rssi_level);
+		/**/
+		#endif
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+		#if (RTL8188E_SUPPORT == 1)
+		#ifdef TXREPORT
+		add_RATid(priv, entry);
+		/**/
+		#endif
+		#endif
+	} else {
+		#ifdef CONFIG_WLAN_HAL
+		GET_HAL_INTERFACE(priv)->UpdateHalRAMaskHandler(priv, entry, rssi_level);
+		#endif
+	} 
+}
+
+#endif
+
+#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+
+void
+phydm_retry_limit_table_bound(
+	void	*dm_void,
+	u8	*retry_limit,
+	u8	offset
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+
+	if (*retry_limit >  offset) {
+		*retry_limit -= offset;
+
+		if (*retry_limit < ra_tab->retrylimit_low)
+			*retry_limit = ra_tab->retrylimit_low;
+		else if (*retry_limit > ra_tab->retrylimit_high)
+			*retry_limit = ra_tab->retrylimit_high;
+	} else
+		*retry_limit = ra_tab->retrylimit_low;
+}
+
+void
+phydm_reset_retry_limit_table(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8			i;
+
+	u8 per_rate_retrylimit_table_20M[ODM_RATEMCS15 + 1] = {
+		1, 1, 2, 4,					/*CCK*/
+		2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
+		2, 4, 6, 8, 12, 18, 20, 22,		/*20M HT-1SS*/
+		2, 4, 6, 8, 12, 18, 20, 22		/*20M HT-2SS*/
+	};
+	u8 per_rate_retrylimit_table_40M[ODM_RATEMCS15 + 1] = {
+		1, 1, 2, 4,					/*CCK*/
+		2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
+		4, 8, 12, 16, 24, 32, 32, 32,		/*40M HT-1SS*/
+		4, 8, 12, 16, 24, 32, 32, 32		/*40M HT-2SS*/
+	};
+
+	memcpy(&ra_tab->per_rate_retrylimit_20M[0],
+	       &per_rate_retrylimit_table_20M[0], ODM_NUM_RATE_IDX);
+	memcpy(&ra_tab->per_rate_retrylimit_40M[0],
+	       &per_rate_retrylimit_table_40M[0], ODM_NUM_RATE_IDX);
+
+	for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
+		phydm_retry_limit_table_bound(dm,
+					      &ra_tab->per_rate_retrylimit_20M[i],
+					      0);
+		phydm_retry_limit_table_bound(dm,
+					      &ra_tab->per_rate_retrylimit_40M[i],
+					      0);
+	}
+}
+
+void
+phydm_ra_dynamic_retry_limit_init(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->retry_descend_num = RA_RETRY_DESCEND_NUM;
+	ra_tab->retrylimit_low = RA_RETRY_LIMIT_LOW;
+	ra_tab->retrylimit_high = RA_RETRY_LIMIT_HIGH;
+
+	phydm_reset_retry_limit_table(dm);
+
+}
+
+void
+phydm_ra_dynamic_retry_limit(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8	i, retry_offset;
+	u32	ma_rx_tp;
+
+
+	if (dm->pre_number_active_client == dm->number_active_client) {
+		PHYDM_DBG(dm, DBG_RA, " pre_number_active_client ==  number_active_client\n");
+		return;
+
+	} else {
+		if (dm->number_active_client == 1) {
+			phydm_reset_retry_limit_table(dm);
+			PHYDM_DBG(dm, DBG_RA, "one client only->reset to default value\n");
+		} else {
+			retry_offset = dm->number_active_client * ra_tab->retry_descend_num;
+
+			for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
+				phydm_retry_limit_table_bound(dm,
+							      &ra_tab->per_rate_retrylimit_20M[i],
+							      retry_offset);
+				phydm_retry_limit_table_bound(dm,
+							      &ra_tab->per_rate_retrylimit_40M[i],
+							      retry_offset);
+			}
+		}
+	}
+}
+#endif
+
+#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))
+void
+phydm_ra_dynamic_rate_id_on_assoc(
+	void	*dm_void,
+	u8	wireless_mode,
+	u8	init_rate_id
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_RA, "[ON ASSOC] rf_mode = ((0x%x)), wireless_mode = ((0x%x)), init_rate_id = ((0x%x))\n", dm->rf_type, wireless_mode, init_rate_id);
+
+	if ((dm->rf_type == RF_2T2R) || (dm->rf_type == RF_2T3R) || (dm->rf_type == RF_2T4R)) {
+		if ((dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) &&
+		    (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G))
+		   ) {
+			PHYDM_DBG(dm, DBG_RA, "[ON ASSOC] set N-2SS ARFR5 table\n");
+			odm_set_mac_reg(dm, 0x4a4, MASKDWORD, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
+			odm_set_mac_reg(dm, 0x4a8, MASKDWORD, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
+		} else if ((dm->support_ic_type & (ODM_RTL8812)) &&
+			(wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY))
+			  ) {
+			PHYDM_DBG(dm, DBG_RA, "[ON ASSOC] set AC-2SS ARFR0 table\n");
+			odm_set_mac_reg(dm, 0x444, MASKDWORD, 0x0fff);	/*AC-2SS, ARFR0, rate_id = 0x9*/
+			odm_set_mac_reg(dm, 0x448, MASKDWORD, 0xff01f000);		/*AC-2SS, ARFR0, rate_id = 0x9*/
+		}
+	}
+
+}
+
+void
+phydm_ra_dynamic_rate_id_init(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) {
+		odm_set_mac_reg(dm, 0x4a4, MASKDWORD, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
+		odm_set_mac_reg(dm, 0x4a8, MASKDWORD, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
+
+		odm_set_mac_reg(dm, 0x444, MASKDWORD, 0x0fff);		/*AC-2SS, ARFR0, rate_id = 0x9*/
+		odm_set_mac_reg(dm, 0x448, MASKDWORD, 0xff01f000);	/*AC-2SS, ARFR0, rate_id = 0x9*/
+	}
+}
+
+void
+phydm_update_rate_id(
+	void	*dm_void,
+	u8	rate,
+	u8	platform_macid
+)
+{
+#if 0
+
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
+	u8		current_tx_ss;
+	u8		rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8		wireless_mode;
+	u8		phydm_macid;
+	struct sta_info	*entry;
+	struct cmn_sta_info	*sta;
+
+
+#if	0
+	if (rate_idx >= ODM_RATEVHTSS2MCS0) {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( VHT2SS-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEVHTSS2MCS0));
+		/*dummy for SD4 check patch*/
+	} else if (rate_idx >= ODM_RATEVHTSS1MCS0) {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( VHT1SS-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEVHTSS1MCS0));
+		/*dummy for SD4 check patch*/
+	} else if (rate_idx >= ODM_RATEMCS0) {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( HT-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEMCS0));
+		/*dummy for SD4 check patch*/
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( HT-MCS%d ))\n", platform_macid, rate_idx);
+		/*dummy for SD4 check patch*/
+	}
+#endif
+
+	phydm_macid = dm->phydm_macid_table[platform_macid];
+	entry = dm->odm_sta_info[phydm_macid];
+	sta = dm->phydm_sta_info[phydm_macid];
+
+	if (is_sta_active(sta)) {
+		wireless_mode = entry->wireless_mode;
+
+		if ((dm->rf_type  == RF_2T2R) || (dm->rf_type  == RF_2T3R) || (dm->rf_type  == RF_2T4R)) {
+			if (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G)) { /*N mode*/
+				if (rate_idx >= ODM_RATEMCS8 && rate_idx <= ODM_RATEMCS15) { /*2SS mode*/
+
+					sta->ra_info.rate_id  = ARFR_5_RATE_ID;
+					PHYDM_DBG(dm, DBG_RA, "ARFR_5\n");
+				}
+			} else if (wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY)) {/*AC mode*/
+				if (rate_idx >= ODM_RATEVHTSS2MCS0 && rate_idx <= ODM_RATEVHTSS2MCS9) {/*2SS mode*/
+
+					sta->ra_info.rate_id  = ARFR_0_RATE_ID;
+					PHYDM_DBG(dm, DBG_RA, "ARFR_0\n");
+				}
+			} else
+				sta->ra_info.rate_id  = ARFR_0_RATE_ID;
+
+			PHYDM_DBG(dm, DBG_RA, "UPdate_RateID[%d]: (( 0x%x ))\n", platform_macid, sta->ra_info.rate_id);
+		}
+	}
+#endif
+}
+
+#endif
+
+#if (defined(CONFIG_RA_DBG_CMD))
+void
+odm_ra_para_adjust_send_h2c(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			h2c_parameter[6] = {0};
+
+	h2c_parameter[0] = RA_FIRST_MACID;
+
+	if (ra_tab->ra_para_feedback_req) { /*h2c_parameter[5]=1 ; ask FW for all RA parameters*/
+		PHYDM_DBG(dm, DBG_RA, "[H2C] Ask FW for RA parameter\n");
+		h2c_parameter[5] |= BIT(1); /*ask FW to report RA parameters*/
+		h2c_parameter[1] = ra_tab->para_idx; /*ra_tab->para_idx;*/
+		ra_tab->ra_para_feedback_req = 0;
+	} else {
+		PHYDM_DBG(dm, DBG_RA, "[H2C] Send H2C to FW for modifying RA parameter\n");
+
+		h2c_parameter[1] =  ra_tab->para_idx;
+		h2c_parameter[2] =  ra_tab->rate_idx;
+		/* [8 bit]*/
+		if (ra_tab->para_idx == RADBG_RTY_PENALTY || ra_tab->para_idx == RADBG_RATE_UP_RTY_RATIO || ra_tab->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
+			h2c_parameter[3] = ra_tab->value;
+			h2c_parameter[4] = 0;
+		}
+		/* [16 bit]*/
+		else {
+			h2c_parameter[3] = (u8)(((ra_tab->value_16) & 0xf0) >> 4); /*byte1*/
+			h2c_parameter[4] = (u8)((ra_tab->value_16) & 0x0f);	/*byte0*/
+		}
+	}
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[1] = 0x%x\n", h2c_parameter[1]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[2] = 0x%x\n", h2c_parameter[2]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[3] = 0x%x\n", h2c_parameter[3]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[4] = 0x%x\n", h2c_parameter[4]);
+	PHYDM_DBG(dm, DBG_RA, " h2c_parameter[5] = 0x%x\n", h2c_parameter[5]);
+
+	odm_fill_h2c_cmd(dm, ODM_H2C_RA_PARA_ADJUST, 6, h2c_parameter);
+
+}
+
+
+void
+odm_ra_para_adjust(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			rate_idx = ra_tab->rate_idx;
+	u8			value = ra_tab->value;
+	u8			pre_value = 0xff;
+
+	if (ra_tab->para_idx == RADBG_RTY_PENALTY) {
+		pre_value = ra_tab->RTY_P[rate_idx];
+		ra_tab->RTY_P[rate_idx] = value;
+		ra_tab->RTY_P_modify_note[rate_idx] = 1;
+	} else if (ra_tab->para_idx == RADBG_N_HIGH) {
+	} else if (ra_tab->para_idx == RADBG_N_LOW) {
+	} else if (ra_tab->para_idx == RADBG_RATE_UP_RTY_RATIO) {
+		pre_value = ra_tab->RATE_UP_RTY_RATIO[rate_idx];
+		ra_tab->RATE_UP_RTY_RATIO[rate_idx] = value;
+		ra_tab->RATE_UP_RTY_RATIO_modify_note[rate_idx] = 1;
+	} else if (ra_tab->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
+		pre_value = ra_tab->RATE_DOWN_RTY_RATIO[rate_idx];
+		ra_tab->RATE_DOWN_RTY_RATIO[rate_idx] = value;
+		ra_tab->RATE_DOWN_RTY_RATIO_modify_note[rate_idx] = 1;
+	}
+	PHYDM_DBG(dm, DBG_RA, "Change RA Papa[%d], rate[ %d ],   ((%d))  ->  ((%d))\n", ra_tab->para_idx, rate_idx, pre_value, value);
+	odm_ra_para_adjust_send_h2c(dm);
+}
+
+void
+phydm_ra_print_msg(
+	void		*dm_void,
+	u8		*value,
+	u8		*value_default,
+	u8		*modify_note
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u32 i;
+
+	PHYDM_DBG(dm, DBG_RA, " |rate index| |Current-value| |Default-value| |Modify?|\n");
+	for (i = 0 ; i <= (ra_tab->rate_length); i++) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+		PHYDM_DBG(dm, DBG_RA, "     [ %d ]  %20d  %25d  %20s\n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  "));
+#else
+		PHYDM_DBG(dm, DBG_RA, "     [ %d ]  %10d  %14d  %14s\n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  "));
+#endif
+	}
+
+}
+
+void
+odm_RA_debug(
+	void		*dm_void,
+	u32		*const dm_value
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->is_ra_dbg_init = false;
+
+	if (dm_value[0] == 100) { /*1 Print RA Parameters*/
+		u8	default_pointer_value;
+		u8	*pvalue;
+		u8	*pvalue_default;
+		u8	*pmodify_note;
+
+		pvalue = pvalue_default = pmodify_note = &default_pointer_value;
+
+		PHYDM_DBG(dm, DBG_RA, "\n------------------------------------------------------------------------------------\n");
+
+		if (dm_value[1] == RADBG_RTY_PENALTY) { /* [1]*/
+			PHYDM_DBG(dm, DBG_RA, " [1] RTY_PENALTY\n");
+			pvalue		=	&ra_tab->RTY_P[0];
+			pvalue_default	=	&ra_tab->RTY_P_default[0];
+			pmodify_note	=	(u8 *)&ra_tab->RTY_P_modify_note[0];
+		} else if (dm_value[1] == RADBG_N_HIGH)   /* [2]*/
+			PHYDM_DBG(dm, DBG_RA, " [2] N_HIGH\n");
+
+		else if (dm_value[1] == RADBG_N_LOW)   /*[3]*/
+			PHYDM_DBG(dm, DBG_RA, " [3] N_LOW\n");
+
+		else if (dm_value[1] == RADBG_RATE_UP_RTY_RATIO) { /* [8]*/
+			PHYDM_DBG(dm, DBG_RA, " [8] RATE_UP_RTY_RATIO\n");
+			pvalue		=	&ra_tab->RATE_UP_RTY_RATIO[0];
+			pvalue_default	=	&ra_tab->RATE_UP_RTY_RATIO_default[0];
+			pmodify_note	=	(u8 *)&ra_tab->RATE_UP_RTY_RATIO_modify_note[0];
+		} else if (dm_value[1] == RADBG_RATE_DOWN_RTY_RATIO) { /* [9]*/
+			PHYDM_DBG(dm, DBG_RA, " [9] RATE_DOWN_RTY_RATIO\n");
+			pvalue		=	&ra_tab->RATE_DOWN_RTY_RATIO[0];
+			pvalue_default	=	&ra_tab->RATE_DOWN_RTY_RATIO_default[0];
+			pmodify_note	=	(u8 *)&ra_tab->RATE_DOWN_RTY_RATIO_modify_note[0];
+		}
+
+		phydm_ra_print_msg(dm, pvalue, pvalue_default, pmodify_note);
+		PHYDM_DBG(dm, DBG_RA, "\n------------------------------------------------------------------------------------\n\n");
+
+	} else if (dm_value[0] == 101) {
+		ra_tab->para_idx = (u8)dm_value[1];
+
+		ra_tab->ra_para_feedback_req = 1;
+		odm_ra_para_adjust_send_h2c(dm);
+	} else {
+		ra_tab->para_idx = (u8)dm_value[0];
+		ra_tab->rate_idx  = (u8)dm_value[1];
+		ra_tab->value = (u8)dm_value[2];
+
+		odm_ra_para_adjust(dm);
+	}
+}
+
+void
+odm_ra_para_adjust_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			i;
+	u8			ra_para_pool_u8[3] = { RADBG_RTY_PENALTY,  RADBG_RATE_UP_RTY_RATIO, RADBG_RATE_DOWN_RTY_RATIO};
+	u8			rate_size_ht_1ss = 20, rate_size_ht_2ss = 28, rate_size_ht_3ss = 36;	 /*4+8+8+8+8 =36*/
+	u8			rate_size_vht_1ss = 10, rate_size_vht_2ss = 20, rate_size_vht_3ss = 30;	 /*10 + 10 +10 =30*/
+#if 0
+	/* RTY_PENALTY		=	1,   u8 */
+	/* N_HIGH 				=	2, */
+	/* N_LOW				=	3, */
+	/* RATE_UP_TABLE		=	4, */
+	/* RATE_DOWN_TABLE	=	5, */
+	/* TRYING_NECESSARY	=	6, */
+	/* DROPING_NECESSARY =	7, */
+	/* RATE_UP_RTY_RATIO	=	8,  u8 */
+	/* RATE_DOWN_RTY_RATIO=	9,  u8 */
+	/* ALL_PARA		=	0xff */
+
+#endif
+	PHYDM_DBG(dm, DBG_RA, "odm_ra_para_adjust_init\n");
+
+/* JJ ADD 20161014 */
+	if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8195A | ODM_RTL8703B | ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8723D | ODM_RTL8710B))
+		ra_tab->rate_length = rate_size_ht_1ss;
+	else if (dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F))
+		ra_tab->rate_length = rate_size_ht_2ss;
+	else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8821C))
+		ra_tab->rate_length = rate_size_ht_1ss + rate_size_vht_1ss;
+	else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8822B))
+		ra_tab->rate_length = rate_size_ht_2ss + rate_size_vht_2ss;
+	else if (dm->support_ic_type == ODM_RTL8814A)
+		ra_tab->rate_length = rate_size_ht_3ss + rate_size_vht_3ss;
+	else
+		ra_tab->rate_length = rate_size_ht_1ss;
+
+	ra_tab->is_ra_dbg_init = true;
+	for (i = 0; i < 3; i++) {
+		ra_tab->ra_para_feedback_req = 1;
+		ra_tab->para_idx	=	ra_para_pool_u8[i];
+		odm_ra_para_adjust_send_h2c(dm);
+	}
+}
+
+#endif /*#if (defined(CONFIG_RA_DBG_CMD))*/
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.h
index 35f26c3ef705..ae60f0101dce 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rainfo.h
@@ -1,445 +1,454 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef	__PHYDMRAINFO_H__
-#define    __PHYDMRAINFO_H__
-
-/*#define RAINFO_VERSION	"2.0"  //2014.11.04*/
-/*#define RAINFO_VERSION	"3.0"  //2015.01.13 Dino*/
-/*#define RAINFO_VERSION	"3.1"  //2015.01.14 Dino*/
-#define RAINFO_VERSION	"3.2"  /*2015.01.14 Dino*/
-
-#define HIGH_RSSI_THRESH	50
-#define LOW_RSSI_THRESH	20
-
-#define	ACTIVE_TP_THRESHOLD	150
-#define	RA_RETRY_DESCEND_NUM	2
-#define	RA_RETRY_LIMIT_LOW	4
-#define	RA_RETRY_LIMIT_HIGH	32
-
-#define PHYDM_IC_8051_SERIES		(ODM_RTL8881A|ODM_RTL8812|ODM_RTL8821|ODM_RTL8192S|ODM_RTL8192C|ODM_RTL8192D|ODM_RTL8723A|ODM_RTL8188E|ODM_RTL8192E|ODM_RTL8723B|ODM_RTL8703B|ODM_RTL8188F)
-#define PHYDM_IC_3081_SERIES		(ODM_RTL8814A|ODM_RTL8821B|ODM_RTL8822B)
-
-#define RAINFO_BE_RX_STATE			BIT0  // 1:RX    //ULDL
-#define RAINFO_STBC_STATE			BIT1
-//#define RAINFO_LDPC_STATE 			BIT2
-#define RAINFO_NOISY_STATE 			BIT2    // set by Noisy_Detection
-#define RAINFO_SHURTCUT_STATE 		BIT3
-#define RAINFO_SHURTCUT_FLAG 		BIT4
-#define RAINFO_INIT_RSSI_RATE_STATE  BIT5
-#define RAINFO_BF_STATE 				BIT6
-#define RAINFO_BE_TX_STATE 			BIT7 // 1:TX
-
-#define	RA_MASK_CCK		0xf
-#define	RA_MASK_OFDM		0xff0
-#define	RA_MASK_HT1SS		0xff000
-#define	RA_MASK_HT2SS		0xff00000
-/*#define	RA_MASK_MCS3SS	*/
-#define	RA_MASK_HT4SS		0xff0
-#define	RA_MASK_VHT1SS	0x3ff000
-#define	RA_MASK_VHT2SS	0xffc00000
-
-#if(DM_ODM_SUPPORT_TYPE == ODM_AP)
-#define	EXT_RA_INFO_SUPPORT_IC (ODM_RTL8881A |ODM_RTL8192E |ODM_RTL8812 |ODM_RTL8814A|ODM_RTL8822B)
-#define		RA_FIRST_MACID 	1
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#define	EXT_RA_INFO_SUPPORT_IC (ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8723B | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8703B)
-#define		RA_FIRST_MACID 	0
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-/*#define	EXT_RA_INFO_SUPPORT_IC (ODM_RTL8192E|ODM_RTL8812|ODM_RTL8821|ODM_RTL8723B|ODM_RTL8814A|ODM_RTL8822B|ODM_RTL8703B) */
-#define		RA_FIRST_MACID 	0
-#endif
-
-
-#define AP_InitRateAdaptiveState	ODM_RateAdaptiveStateApInit
-
-#define		DM_RATR_STA_INIT			0
-#define		DM_RATR_STA_HIGH			1
-#define 		DM_RATR_STA_MIDDLE		2
-#define 		DM_RATR_STA_LOW			3
-#if(DM_ODM_SUPPORT_TYPE & ODM_AP)
-#define		DM_RATR_STA_ULTRA_LOW	4
-#endif
-
-#define		DM_RA_RATE_UP				1
-#define		DM_RA_RATE_DOWN			2
-
-typedef enum _phydm_arfr_num {
-	ARFR_0_RATE_ID	=	0x9,
-	ARFR_1_RATE_ID	=	0xa,
-	ARFR_2_RATE_ID	=	0xb,
-	ARFR_3_RATE_ID	=	0xc,
-	ARFR_4_RATE_ID	=	0xd,
-	ARFR_5_RATE_ID	=	0xe
-} PHYDM_RA_ARFR_NUM_E;
-
-typedef enum _Phydm_ra_dbg_para {
-	RADBG_RTY_PENALTY			=	1,  //u8
-	RADBG_N_HIGH 				=	2,
-	RADBG_N_LOW				=	3,
-	RADBG_TRATE_UP_TABLE		=	4,
-	RADBG_TRATE_DOWN_TABLE	=	5,
-	RADBG_TRYING_NECESSARY	=	6,
-	RADBG_TDROPING_NECESSARY =	7,
-	RADBG_RATE_UP_RTY_RATIO	=	8, //u8
-	RADBG_RATE_DOWN_RTY_RATIO =	9, //u8
-
-	RADBG_DEBUG_MONITOR1 = 0xc,
-	RADBG_DEBUG_MONITOR2 = 0xd,
-	RADBG_DEBUG_MONITOR3 = 0xe,
-	RADBG_DEBUG_MONITOR4 = 0xf,
-	NUM_RA_PARA
-} PHYDM_RA_DBG_PARA_E;
-
-
-#if (RATE_ADAPTIVE_SUPPORT == 1)//88E RA
-typedef struct _ODM_RA_Info_ {
-	u1Byte RateID;
-	u4Byte RateMask;
-	u4Byte RAUseRate;
-	u1Byte RateSGI;
-	u1Byte RssiStaRA;
-	u1Byte PreRssiStaRA;
-	u1Byte SGIEnable;
-	u1Byte DecisionRate;
-	u1Byte PreRate;
-	u1Byte HighestRate;
-	u1Byte LowestRate;
-	u4Byte NscUp;
-	u4Byte NscDown;
-	u2Byte RTY[5];
-	u4Byte TOTAL;
-	u2Byte DROP;
-	u1Byte Active;
-	u2Byte RptTime;
-	u1Byte RAWaitingCounter;
-	u1Byte RAPendingCounter;
-#if 1 //POWER_TRAINING_ACTIVE == 1 // For compile  pass only~!
-	u1Byte PTActive;  // on or off
-	u1Byte PTTryState;  // 0 trying state, 1 for decision state
-	u1Byte PTStage;  // 0~6
-	u1Byte PTStopCount; //Stop PT counter
-	u1Byte PTPreRate;  // if rate change do PT
-	u1Byte PTPreRssi; // if RSSI change 5% do PT
-	u1Byte PTModeSS;  // decide whitch rate should do PT
-	u1Byte RAstage;  // StageRA, decide how many times RA will be done between PT
-	u1Byte PTSmoothFactor;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP) && ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-	u1Byte RateDownCounter;
-	u1Byte RateUpCounter;
-	u1Byte RateDirection;
-	u1Byte BoundingType;
-	u1Byte BoundingCounter;
-	u1Byte BoundingLearningTime;
-	u1Byte RateDownStartTime;
-#endif
-} ODM_RA_INFO_T, *PODM_RA_INFO_T;
-#endif
-
-
-typedef struct _Rate_Adaptive_Table_ {
-	u1Byte		firstconnect;
-#if(DM_ODM_SUPPORT_TYPE==ODM_WIN)
-	BOOLEAN		PT_collision_pre;
-#endif
-
-#if (defined(CONFIG_RA_DBG_CMD))
-	BOOLEAN		is_ra_dbg_init;
-
-	u1Byte	RTY_P[ODM_NUM_RATE_IDX];
-	u1Byte	RTY_P_default[ODM_NUM_RATE_IDX];
-	BOOLEAN	RTY_P_modify_note[ODM_NUM_RATE_IDX];
-
-	u1Byte	RATE_UP_RTY_RATIO[ODM_NUM_RATE_IDX];
-	u1Byte	RATE_UP_RTY_RATIO_default[ODM_NUM_RATE_IDX];
-	BOOLEAN	RATE_UP_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
-
-	u1Byte	RATE_DOWN_RTY_RATIO[ODM_NUM_RATE_IDX];
-	u1Byte	RATE_DOWN_RTY_RATIO_default[ODM_NUM_RATE_IDX];
-	BOOLEAN	RATE_DOWN_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
-
-	BOOLEAN RA_Para_feedback_req;
-
-	u1Byte   para_idx;
-	u1Byte	rate_idx;
-	u1Byte	value;
-	u2Byte	value_16;
-	u1Byte	rate_length;
-#endif
-	u1Byte	link_tx_rate[ODM_ASSOCIATE_ENTRY_NUM];
-
-	#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
-	u1Byte per_rate_retrylimit_20M[ODM_NUM_RATE_IDX];
-	u1Byte per_rate_retrylimit_40M[ODM_NUM_RATE_IDX];	
-	u1Byte			retry_descend_num;
-	u1Byte			retrylimit_low;
-	u1Byte			retrylimit_high;
-	#endif
-
-
-} RA_T, *pRA_T;
-
-typedef struct _ODM_RATE_ADAPTIVE {
-	u1Byte				Type;				// DM_Type_ByFW/DM_Type_ByDriver
-	u1Byte				HighRSSIThresh;		// if RSSI > HighRSSIThresh	=> RATRState is DM_RATR_STA_HIGH
-	u1Byte				LowRSSIThresh;		// if RSSI <= LowRSSIThresh	=> RATRState is DM_RATR_STA_LOW
-	u1Byte				RATRState;			// Current RSSI level, DM_RATR_STA_HIGH/DM_RATR_STA_MIDDLE/DM_RATR_STA_LOW
-
-#if(DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	u1Byte				LdpcThres;			// if RSSI > LdpcThres => switch from LPDC to BCC
-	BOOLEAN				bLowerRtsRate;
-#endif
-
-#if(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	u1Byte				RtsThres;
-#elif(DM_ODM_SUPPORT_TYPE & ODM_CE)
-	BOOLEAN				bUseLdpc;
-#else
-	u1Byte				UltraLowRSSIThresh;
-	u4Byte				LastRATR;			// RATR Register Content
-#endif
-
-} ODM_RATE_ADAPTIVE, *PODM_RATE_ADAPTIVE;
-
-VOID
-ODM_C2HRaParaReportHandler(
-	IN	PVOID	pDM_VOID,
-	IN pu1Byte   CmdBuf,
-	IN u1Byte   CmdLen
-);
-
-VOID
-odm_RA_ParaAdjust_Send_H2C(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-odm_RA_debug(
-	IN		PVOID		pDM_VOID,
-	IN		u4Byte		*const dm_value
-);
-
-VOID
-odm_RA_ParaAdjust_init(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_RA_ParaAdjust(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-phydm_ra_dynamic_retry_count(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-phydm_ra_dynamic_retry_limit(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-phydm_ra_dynamic_rate_id_on_assoc(
-	IN	PVOID	pDM_VOID,
-	IN	u1Byte	wireless_mode,
-	IN	u1Byte	init_rate_id
-);
-
-VOID
-phydm_c2h_ra_report_handler(
-	IN PVOID	pDM_VOID,
-	IN pu1Byte   CmdBuf,
-	IN u1Byte   CmdLen
-);
-
-VOID
-phydm_ra_info_init(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-odm_RSSIMonitorInit(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-odm_RSSIMonitorCheck(
-	IN	PVOID	pDM_VOID
-);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-s4Byte
-phydm_FindMinimumRSSI(
-IN		PDM_ODM_T		pDM_Odm,
-IN		PADAPTER		pAdapter,
-IN OUT	BOOLEAN	*pbLink_temp
-
-	);
-#endif
-
-VOID
-odm_RSSIMonitorCheckMP(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-odm_RSSIMonitorCheckCE(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-odm_RSSIMonitorCheckAP(
-	IN	PVOID	pDM_VOID
-);
-
-
-VOID
-odm_RateAdaptiveMaskInit(
-	IN 	PVOID	pDM_VOID
-);
-
-VOID
-odm_RefreshRateAdaptiveMask(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_RefreshRateAdaptiveMaskMP(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_RefreshRateAdaptiveMaskCE(
-	IN		PVOID		pDM_VOID
-);
-
-VOID
-odm_RefreshRateAdaptiveMaskAPADSL(
-	IN		PVOID		pDM_VOID
-);
-
-BOOLEAN
-ODM_RAStateCheck(
-	IN		PVOID		    pDM_VOID,
-	IN		s4Byte			RSSI,
-	IN		BOOLEAN			bForceUpdate,
-	OUT		pu1Byte			pRATRState
-);
-
-VOID
-odm_RefreshBasicRateMask(
-	IN		PVOID		pDM_VOID
-);
-VOID
-ODM_RAPostActionOnAssoc(
-	IN		PVOID	pDM_Odm
-);
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-
-u1Byte
-odm_Find_RTS_Rate(
-	IN	PVOID		pDM_VOID,
-	IN		u1Byte			Tx_Rate,
-	IN		BOOLEAN			bErpProtect
-);
-
-VOID
-ODM_UpdateNoisyState(
-	IN	PVOID		pDM_VOID,
-	IN	BOOLEAN		bNoisyStateFromC2H
-);
-
-u4Byte
-Set_RA_DM_Ratrbitmap_by_Noisy(
-	IN	PVOID			pDM_VOID,
-	IN	WIRELESS_MODE	WirelessMode,
-	IN	u4Byte			ratr_bitmap,
-	IN	u1Byte			rssi_level
-);
-
-VOID
-ODM_UpdateInitRate(
-	IN	PVOID		pDM_VOID,
-	IN	u1Byte		Rate
-);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-VOID
-odm_RSSIDumpToRegister(
-	IN	PVOID	pDM_VOID
-);
-
-VOID
-odm_RefreshLdpcRtsMP(
-	IN	PADAPTER			pAdapter,
-	IN	PDM_ODM_T			pDM_Odm,
-	IN	u1Byte				mMacId,
-	IN	u1Byte				IOTPeer,
-	IN	s4Byte				UndecoratedSmoothedPWDB
-);
-
-VOID
-ODM_DynamicARFBSelect(
-	IN		PVOID		pDM_VOID,
-	IN 		u1Byte		rate,
-	IN  	BOOLEAN		Collision_State
-);
-
-VOID
-ODM_RateAdaptiveStateApInit(
-	IN	PVOID			PADAPTER_VOID,
-	IN	PRT_WLAN_STA  	pEntry
-);
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-static void
-FindMinimumRSSI(
-	IN	PADAPTER	pAdapter
-);
-
-u8Byte
-PhyDM_Get_Rate_Bitmap_Ex(
-	IN	PVOID		pDM_VOID,
-	IN	u4Byte		macid,
-	IN	u8Byte		ra_mask,
-	IN	u1Byte		rssi_level,
-	OUT		u8Byte	*dm_RA_Mask,
-	OUT		u1Byte	*dm_RteID
-);
-u4Byte
-ODM_Get_Rate_Bitmap(
-	IN	PVOID	    pDM_VOID,
-	IN	u4Byte		macid,
-	IN	u4Byte 		ra_mask,
-	IN	u1Byte 		rssi_level
-);
-void phydm_ra_rssi_rpt_wk(PVOID pContext);
-
-#endif/*#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)*/
-
-#endif/*#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN| ODM_CE))*/
-
-#endif /*#ifndef	__ODMRAINFO_H__*/
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMRAINFO_H__
+#define    __PHYDMRAINFO_H__
+
+/*#define RAINFO_VERSION	"2.0"*/  /*2014.11.04*/
+/*#define RAINFO_VERSION	"3.0"*/  /*2015.01.13 Dino*/
+/*#define RAINFO_VERSION	"3.1"*/  /*2015.01.14 Dino*/
+/*#define RAINFO_VERSION	"3.3"*/  /*2015.07.29 YuChen*/
+/*#define RAINFO_VERSION	"3.4"*/  /*2015.12.15 Stanley*/
+/*#define RAINFO_VERSION	"4.0"*/  /*2016.03.24 Dino, Add more RA mask state and Phydm-lize partial ra mask function  */
+/*#define RAINFO_VERSION	"4.1"*/  /*2016.04.20 Dino, Add new function to adjust PCR RA threshold  */
+/*#define RAINFO_VERSION	"4.2"*/  /*2016.05.17 Dino, Add H2C debug cmd  */
+/*#define RAINFO_VERSION	"4.3"*/  /*2016.07.11 Dino, Fix RA hang in CCK 1M problem  */
+#define RAINFO_VERSION	"5.0"  /*2017.04.20 Dino, the 3rd PHYDM reform*/
+
+#define	FORCED_UPDATE_RAMASK_PERIOD	5
+
+#define	H2C_MAX_LENGTH	7
+
+#define	RA_FLOOR_UP_GAP		3
+#define	RA_FLOOR_TABLE_SIZE	7
+
+#define	ACTIVE_TP_THRESHOLD	1
+#define	RA_RETRY_DESCEND_NUM	2
+#define	RA_RETRY_LIMIT_LOW	4
+#define	RA_RETRY_LIMIT_HIGH	32
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define		RA_FIRST_MACID	1
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define	RA_FIRST_MACID	0
+	#define	WIN_DEFAULT_PORT_MACID	0
+	#define	WIN_BT_PORT_MACID	2
+#else /*if (DM_ODM_SUPPORT_TYPE == ODM_CE)*/
+	#define		RA_FIRST_MACID	0
+#endif
+
+
+enum phydm_ra_dbg_para {
+	RADBG_PCR_TH_OFFSET		=	0,
+	RADBG_RTY_PENALTY		=	1,
+	RADBG_N_HIGH				=	2,
+	RADBG_N_LOW				=	3,
+	RADBG_TRATE_UP_TABLE		=	4,
+	RADBG_TRATE_DOWN_TABLE	=	5,
+	RADBG_TRYING_NECESSARY	=	6,
+	RADBG_TDROPING_NECESSARY =	7,
+	RADBG_RATE_UP_RTY_RATIO	=	8,
+	RADBG_RATE_DOWN_RTY_RATIO =	9, /* u8 */
+
+	RADBG_DEBUG_MONITOR1 = 0xc,
+	RADBG_DEBUG_MONITOR2 = 0xd,
+	RADBG_DEBUG_MONITOR3 = 0xe,
+	RADBG_DEBUG_MONITOR4 = 0xf,
+	RADBG_DEBUG_MONITOR5 = 0x10,
+	NUM_RA_PARA
+};
+
+enum phydm_wireless_mode {
+	PHYDM_WIRELESS_MODE_UNKNOWN = 0x00,
+	PHYDM_WIRELESS_MODE_A		= 0x01,
+	PHYDM_WIRELESS_MODE_B		= 0x02,
+	PHYDM_WIRELESS_MODE_G		= 0x04,
+	PHYDM_WIRELESS_MODE_AUTO	= 0x08,
+	PHYDM_WIRELESS_MODE_N_24G	= 0x10,
+	PHYDM_WIRELESS_MODE_N_5G	= 0x20,
+	PHYDM_WIRELESS_MODE_AC_5G	= 0x40,
+	PHYDM_WIRELESS_MODE_AC_24G	= 0x80,
+	PHYDM_WIRELESS_MODE_AC_ONLY	= 0x100,
+	PHYDM_WIRELESS_MODE_MAX		= 0x800,
+	PHYDM_WIRELESS_MODE_ALL		= 0xFFFF
+};
+
+enum phydm_rateid_idx {
+	PHYDM_BGN_40M_2SS	= 0,
+	PHYDM_BGN_40M_1SS	= 1,
+	PHYDM_BGN_20M_2SS	= 2,
+	PHYDM_BGN_20M_1SS	= 3,
+	PHYDM_GN_N2SS			= 4,
+	PHYDM_GN_N1SS			= 5,
+	PHYDM_BG				= 6,
+	PHYDM_G				= 7,
+	PHYDM_B_20M			= 8,
+	PHYDM_ARFR0_AC_2SS	= 9,
+	PHYDM_ARFR1_AC_1SS	= 10,
+	PHYDM_ARFR2_AC_2G_1SS	= 11,
+	PHYDM_ARFR3_AC_2G_2SS	= 12,
+	PHYDM_ARFR4_AC_3SS	= 13,
+	PHYDM_ARFR5_N_3SS		= 14
+};
+
+#if (RATE_ADAPTIVE_SUPPORT == 1)/* 88E RA */
+struct _odm_ra_info_ {
+	u8 rate_id;
+	u32 rate_mask;
+	u32 ra_use_rate;
+	u8 rate_sgi;
+	u8 rssi_sta_ra;
+	u8 pre_rssi_sta_ra;
+	u8 sgi_enable;
+	u8 decision_rate;
+	u8 pre_rate;
+	u8 highest_rate;
+	u8 lowest_rate;
+	u32 nsc_up;
+	u32 nsc_down;
+	u16 RTY[5];
+	u32 TOTAL;
+	u16 DROP;
+	u8 active;
+	u16 rpt_time;
+	u8 ra_waiting_counter;
+	u8 ra_pending_counter;
+	u8 ra_drop_after_down;
+#if 1 /* POWER_TRAINING_ACTIVE == 1 */ /* For compile  pass only~! */
+	u8 pt_active;  /* on or off */
+	u8 pt_try_state;  /* 0 trying state, 1 for decision state */
+	u8 pt_stage;  /* 0~6 */
+	u8 pt_stop_count; /* Stop PT counter */
+	u8 pt_pre_rate;  /* if rate change do PT */
+	u8 pt_pre_rssi; /* if RSSI change 5% do PT */
+	u8 pt_mode_ss;  /* decide whitch rate should do PT */
+	u8 ra_stage;  /* StageRA, decide how many times RA will be done between PT */
+	u8 pt_smooth_factor;
+#endif
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP) &&	((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
+	u8 rate_down_counter;
+	u8 rate_up_counter;
+	u8 rate_direction;
+	u8 bounding_type;
+	u8 bounding_counter;
+	u8 bounding_learning_time;
+	u8 rate_down_start_time;
+#endif
+};
+#endif
+
+
+struct ra_table {
+	u8		firstconnect;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	boolean		PT_collision_pre;
+#endif
+
+#if (defined(CONFIG_RA_DBG_CMD))
+	boolean		is_ra_dbg_init;
+
+	u8	RTY_P[ODM_NUM_RATE_IDX];
+	u8	RTY_P_default[ODM_NUM_RATE_IDX];
+	boolean	RTY_P_modify_note[ODM_NUM_RATE_IDX];
+
+	u8	RATE_UP_RTY_RATIO[ODM_NUM_RATE_IDX];
+	u8	RATE_UP_RTY_RATIO_default[ODM_NUM_RATE_IDX];
+	boolean	RATE_UP_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
+
+	u8	RATE_DOWN_RTY_RATIO[ODM_NUM_RATE_IDX];
+	u8	RATE_DOWN_RTY_RATIO_default[ODM_NUM_RATE_IDX];
+	boolean	RATE_DOWN_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
+
+	boolean ra_para_feedback_req;
+
+	u8   para_idx;
+	u8	rate_idx;
+	u8	value;
+	u16	value_16;
+	u8	rate_length;
+#endif
+	/*u8	link_tx_rate[ODM_ASSOCIATE_ENTRY_NUM];*/
+	u8	mu1_rate[30];
+	u8	highest_client_tx_order;
+	u16	highest_client_tx_rate_order;
+	u8	power_tracking_flag;
+	u8	RA_threshold_offset;
+	u8	RA_offset_direction;
+	u8	up_ramask_cnt; /*force update_ra_mask counter*/
+	u8	up_ramask_cnt_tmp; /*Just for debug, should be removed latter*/
+
+#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+	u8	per_rate_retrylimit_20M[ODM_NUM_RATE_IDX];
+	u8	per_rate_retrylimit_40M[ODM_NUM_RATE_IDX];
+	u8	retry_descend_num;
+	u8	retrylimit_low;
+	u8	retrylimit_high;
+#endif
+	u8	ldpc_thres;			/* if RSSI > ldpc_thres => switch from LPDC to BCC */
+
+	void (*record_ra_info)(void *dm_void, u8 macid, struct cmn_sta_info *sta, u64 ra_mask);
+};
+
+void
+phydm_h2C_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+#if (defined(CONFIG_RA_DBG_CMD))
+
+void
+odm_RA_debug(
+	void		*dm_void,
+	u32		*const dm_value
+);
+
+void
+odm_ra_para_adjust_init(
+	void		*dm_void
+);
+
+#endif
+
+void
+phydm_ra_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+);
+
+void
+odm_c2h_ra_para_report_handler(
+	void	*dm_void,
+	u8	*cmd_buf,
+	u8	cmd_len
+);
+
+void
+odm_ra_para_adjust(
+	void		*dm_void
+);
+
+void
+phydm_ra_dynamic_retry_count(
+	void	*dm_void
+);
+
+void
+phydm_ra_dynamic_retry_limit(
+	void	*dm_void
+);
+
+void
+phydm_print_rate(
+	void	*dm_void,
+	u8	rate,
+	u32	dbg_component
+);
+
+void
+phydm_c2h_ra_report_handler(
+	void	*dm_void,
+	u8   *cmd_buf,
+	u8   cmd_len
+);
+
+u8
+phydm_rate_order_compute(
+	void	*dm_void,
+	u8	rate_idx
+);
+
+void
+phydm_ra_info_watchdog(
+	void	*dm_void
+);
+
+void
+phydm_ra_info_init(
+	void	*dm_void
+);
+
+void
+phydm_modify_RA_PCR_threshold(
+	void		*dm_void,
+	u8		RA_offset_direction,
+	u8		RA_threshold_offset
+);
+
+u8
+phydm_vht_en_mapping(
+	void			*dm_void,
+	u32			wireless_mode
+);
+
+u8
+phydm_rate_id_mapping(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			bw
+);
+
+void
+phydm_update_hal_ra_mask(
+	void			*dm_void,
+	u32			wireless_mode,
+	u8			rf_type,
+	u8			BW,
+	u8			mimo_ps_enable,
+	u8			disable_cck_rate,
+	u32			*ratr_bitmap_msb_in,
+	u32			*ratr_bitmap_in,
+	u8			tx_rate_level
+);
+
+void
+phydm_refresh_rate_adaptive_mask(
+	void		*dm_void
+);
+
+u8
+phydm_rssi_lv_dec(
+	void			*dm_void,
+	u32			rssi,
+	u8			ratr_state
+);
+
+void
+odm_ra_post_action_on_assoc(
+	void	*dm
+);
+
+u8
+odm_find_rts_rate(
+	void		*dm_void,
+	u8			tx_rate,
+	boolean			is_erp_protect
+);
+
+void
+phydm_show_sta_info(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+u8
+phydm_get_plcp(
+	void	*dm_void,
+	u16	macid
+);
+
+#ifdef	PHYDM_3RD_REFORM_RA_MASK
+
+void
+phydm_ra_registed(
+	void	*dm_void,
+	u8	macid,
+	u8	rssi_from_assoc
+);
+
+void
+phydm_ra_offline(
+	void	*dm_void,
+	u8	macid
+);
+
+
+void
+phydm_ra_mask_watchdog(
+	void	*dm_void
+);
+
+#endif
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+odm_refresh_basic_rate_mask(
+	void		*dm_void
+);
+
+void
+odm_update_init_rate_work_item_callback(
+	void	*context
+);
+
+void
+odm_refresh_ldpc_rts_mp(
+	void			*adapter,
+	struct dm_struct			*dm,
+	u8				m_mac_id,
+	u8				iot_peer,
+	s32				undecorated_smoothed_pwdb
+);
+
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+void
+phydm_gen_ramask_h2c_AP(
+	void			*dm_void,
+	struct rtl8192cd_priv *priv,
+	struct sta_info *entry,
+	u8			rssi_level
+);
+
+#endif/*#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))*/
+
+
+#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))
+void
+phydm_ra_dynamic_rate_id_on_assoc(
+	void	*dm_void,
+	u8	wireless_mode,
+	u8	init_rate_id
+);
+
+void
+phydm_ra_dynamic_rate_id_init(
+	void	*dm_void
+);
+
+void
+phydm_update_rate_id(
+	void	*dm_void,
+	u8	rate,
+	u8	platform_macid
+);
+
+#endif
+
+#endif /*#ifndef	__ODMRAINFO_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_reg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_reg.h
index 8deff91364f4..5565f4f5c1c9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_reg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_reg.h
@@ -1,208 +1,218 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-//============================================================
-// 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	RF_T_METER_OLD				0x24
-#define	RF_T_METER_NEW				0x42
-
-#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
-#define	ODM_RF_T_METER				0x24
-#define	ODM_RF_T_METER_92D			0x42
-#define	ODM_RF_T_METER_88E			0x42
-#define	ODM_RF_T_METER_92E			0x42
-#define	ODM_RF_T_METER_8812			0x42
-
-//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
-//
-#if(DM_ODM_SUPPORT_TYPE & (ODM_AP))
-// TX AGC 
-#define		rTxAGC_A_CCK11_CCK1_JAguar	0xc20
-#define		rTxAGC_A_Ofdm18_Ofdm6_JAguar	0xc24
-#define		rTxAGC_A_Ofdm54_Ofdm24_JAguar	0xc28
-#define		rTxAGC_A_MCS3_MCS0_JAguar	0xc2c
-#define		rTxAGC_A_MCS7_MCS4_JAguar	0xc30
-#define		rTxAGC_A_MCS11_MCS8_JAguar	0xc34
-#define		rTxAGC_A_MCS15_MCS12_JAguar	0xc38
-#define		rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	0xc3c
-#define		rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	0xc40
-#define		rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	0xc44
-#define		rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	0xc48
-#define		rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	0xc4c
-#if defined(CONFIG_WLAN_HAL_8814AE)
-#define		rTxAGC_A_MCS19_MCS16_JAguar	0xcd8
-#define		rTxAGC_A_MCS23_MCS20_JAguar	0xcdc
-#define		rTxAGC_A_Nss3Index3_Nss3Index0_JAguar	0xce0
-#define		rTxAGC_A_Nss3Index7_Nss3Index4_JAguar	0xce4
-#define		rTxAGC_A_Nss3Index9_Nss3Index8_JAguar	0xce8
-#endif
-#define		rTxAGC_B_CCK11_CCK1_JAguar	0xe20
-#define		rTxAGC_B_Ofdm18_Ofdm6_JAguar	0xe24
-#define		rTxAGC_B_Ofdm54_Ofdm24_JAguar	0xe28
-#define		rTxAGC_B_MCS3_MCS0_JAguar	0xe2c
-#define		rTxAGC_B_MCS7_MCS4_JAguar	0xe30
-#define		rTxAGC_B_MCS11_MCS8_JAguar	0xe34
-#define		rTxAGC_B_MCS15_MCS12_JAguar	0xe38
-#define		rTxAGC_B_Nss1Index3_Nss1Index0_JAguar	0xe3c
-#define		rTxAGC_B_Nss1Index7_Nss1Index4_JAguar	0xe40
-#define		rTxAGC_B_Nss2Index1_Nss1Index8_JAguar	0xe44
-#define		rTxAGC_B_Nss2Index5_Nss2Index2_JAguar	0xe48
-#define		rTxAGC_B_Nss2Index9_Nss2Index6_JAguar	0xe4c
-#if defined(CONFIG_WLAN_HAL_8814AE)
-#define		rTxAGC_B_MCS19_MCS16_JAguar	0xed8
-#define		rTxAGC_B_MCS23_MCS20_JAguar	0xedc
-#define		rTxAGC_B_Nss3Index3_Nss3Index0_JAguar	0xee0
-#define		rTxAGC_B_Nss3Index7_Nss3Index4_JAguar	0xee4
-#define		rTxAGC_B_Nss3Index9_Nss3Index8_JAguar	0xee8
-#define		rTxAGC_C_CCK11_CCK1_JAguar	0x1820
-#define		rTxAGC_C_Ofdm18_Ofdm6_JAguar	0x1824
-#define		rTxAGC_C_Ofdm54_Ofdm24_JAguar	0x1828
-#define		rTxAGC_C_MCS3_MCS0_JAguar	0x182c
-#define		rTxAGC_C_MCS7_MCS4_JAguar	0x1830
-#define		rTxAGC_C_MCS11_MCS8_JAguar	0x1834
-#define		rTxAGC_C_MCS15_MCS12_JAguar	0x1838
-#define		rTxAGC_C_Nss1Index3_Nss1Index0_JAguar	0x183c
-#define		rTxAGC_C_Nss1Index7_Nss1Index4_JAguar	0x1840
-#define		rTxAGC_C_Nss2Index1_Nss1Index8_JAguar	0x1844
-#define		rTxAGC_C_Nss2Index5_Nss2Index2_JAguar	0x1848
-#define		rTxAGC_C_Nss2Index9_Nss2Index6_JAguar	0x184c
-#define		rTxAGC_C_MCS19_MCS16_JAguar	0x18d8
-#define		rTxAGC_C_MCS23_MCS20_JAguar	0x18dc
-#define		rTxAGC_C_Nss3Index3_Nss3Index0_JAguar	0x18e0
-#define		rTxAGC_C_Nss3Index7_Nss3Index4_JAguar	0x18e4
-#define		rTxAGC_C_Nss3Index9_Nss3Index8_JAguar	0x18e8
-#define		rTxAGC_D_CCK11_CCK1_JAguar	0x1a20
-#define		rTxAGC_D_Ofdm18_Ofdm6_JAguar	0x1a24
-#define		rTxAGC_D_Ofdm54_Ofdm24_JAguar	0x1a28
-#define		rTxAGC_D_MCS3_MCS0_JAguar	0x1a2c
-#define		rTxAGC_D_MCS7_MCS4_JAguar	0x1a30
-#define		rTxAGC_D_MCS11_MCS8_JAguar	0x1a34
-#define		rTxAGC_D_MCS15_MCS12_JAguar	0x1a38
-#define		rTxAGC_D_Nss1Index3_Nss1Index0_JAguar	0x1a3c
-#define		rTxAGC_D_Nss1Index7_Nss1Index4_JAguar	0x1a40
-#define		rTxAGC_D_Nss2Index1_Nss1Index8_JAguar	0x1a44
-#define		rTxAGC_D_Nss2Index5_Nss2Index2_JAguar	0x1a48
-#define		rTxAGC_D_Nss2Index9_Nss2Index6_JAguar	0x1a4c
-#define		rTxAGC_D_MCS19_MCS16_JAguar	0x1ad8
-#define		rTxAGC_D_MCS23_MCS20_JAguar	0x1adc
-#define		rTxAGC_D_Nss3Index3_Nss3Index0_JAguar	0x1ae0
-#define		rTxAGC_D_Nss3Index7_Nss3Index4_JAguar	0x1ae4
-#define		rTxAGC_D_Nss3Index9_Nss3Index8_JAguar	0x1ae8
-#endif
-
-#define		bTxAGC_byte0_Jaguar	0xff
-#define		bTxAGC_byte1_Jaguar	0xff00
-#define		bTxAGC_byte2_Jaguar	0xff0000
-#define		bTxAGC_byte3_Jaguar	0xff000000
-#endif
-
-#define	BIT_FA_RESET					BIT0
-
-
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+/* ************************************************************
+ * 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	RF_T_METER_OLD				0x24
+#define	RF_T_METER_NEW				0x42
+
+#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
+
+/* LTE_COEX */
+#define REG_LTECOEX_CTRL			0x07C0
+#define REG_LTECOEX_WRITE_DATA		0x07C4
+#define REG_LTECOEX_READ_DATA		0x07C8
+#define REG_LTECOEX_PATH_CONTROL	0x70
+
+/* 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
+#define	ODM_RF_T_METER				0x24
+#define	ODM_RF_T_METER_92D			0x42
+#define	ODM_RF_T_METER_88E			0x42
+#define	ODM_RF_T_METER_92E			0x42
+#define	ODM_RF_T_METER_8812			0x42
+#define	REG_RF_TX_GAIN_OFFSET				0x55
+
+/* 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
+ *   */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	/* TX AGC */
+	#define		REG_TX_AGC_A_CCK_11_CCK_1_JAGUAR	0xc20
+	#define		REG_TX_AGC_A_OFDM18_OFDM6_JAGUAR	0xc24
+	#define		REG_TX_AGC_A_OFDM54_OFDM24_JAGUAR	0xc28
+	#define		REG_TX_AGC_A_MCS3_MCS0_JAGUAR	0xc2c
+	#define		REG_TX_AGC_A_MCS7_MCS4_JAGUAR	0xc30
+	#define		REG_TX_AGC_A_MCS11_MCS8_JAGUAR	0xc34
+	#define		REG_TX_AGC_A_MCS15_MCS12_JAGUAR	0xc38
+	#define		REG_TX_AGC_A_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0xc3c
+	#define		REG_TX_AGC_A_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0xc40
+	#define		REG_TX_AGC_A_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0xc44
+	#define		REG_TX_AGC_A_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0xc48
+	#define		REG_TX_AGC_A_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0xc4c
+	#if defined(CONFIG_WLAN_HAL_8814AE)
+		#define		REG_TX_AGC_A_MCS19_MCS16_JAGUAR	0xcd8
+		#define		REG_TX_AGC_A_MCS23_MCS20_JAGUAR	0xcdc
+		#define		REG_TX_AGC_A_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0xce0
+		#define		REG_TX_AGC_A_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0xce4
+		#define		REG_TX_AGC_A_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0xce8
+	#endif
+	#define		REG_TX_AGC_B_CCK_11_CCK_1_JAGUAR	0xe20
+	#define		REG_TX_AGC_B_OFDM18_OFDM6_JAGUAR	0xe24
+	#define		REG_TX_AGC_B_OFDM54_OFDM24_JAGUAR	0xe28
+	#define		REG_TX_AGC_B_MCS3_MCS0_JAGUAR	0xe2c
+	#define		REG_TX_AGC_B_MCS7_MCS4_JAGUAR	0xe30
+	#define		REG_TX_AGC_B_MCS11_MCS8_JAGUAR	0xe34
+	#define		REG_TX_AGC_B_MCS15_MCS12_JAGUAR	0xe38
+	#define		REG_TX_AGC_B_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0xe3c
+	#define		REG_TX_AGC_B_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0xe40
+	#define		REG_TX_AGC_B_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0xe44
+	#define		REG_TX_AGC_B_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0xe48
+	#define		REG_TX_AGC_B_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0xe4c
+	#if defined(CONFIG_WLAN_HAL_8814AE)
+		#define		REG_TX_AGC_B_MCS19_MCS16_JAGUAR	0xed8
+		#define		REG_TX_AGC_B_MCS23_MCS20_JAGUAR	0xedc
+		#define		REG_TX_AGC_B_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0xee0
+		#define		REG_TX_AGC_B_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0xee4
+		#define		REG_TX_AGC_B_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0xee8
+		#define		REG_TX_AGC_C_CCK_11_CCK_1_JAGUAR	0x1820
+		#define		REG_TX_AGC_C_OFDM18_OFDM6_JAGUAR	0x1824
+		#define		REG_TX_AGC_C_OFDM54_OFDM24_JAGUAR	0x1828
+		#define		REG_TX_AGC_C_MCS3_MCS0_JAGUAR	0x182c
+		#define		REG_TX_AGC_C_MCS7_MCS4_JAGUAR	0x1830
+		#define		REG_TX_AGC_C_MCS11_MCS8_JAGUAR	0x1834
+		#define		REG_TX_AGC_C_MCS15_MCS12_JAGUAR	0x1838
+		#define		REG_TX_AGC_C_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0x183c
+		#define		REG_TX_AGC_C_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0x1840
+		#define		REG_TX_AGC_C_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0x1844
+		#define		REG_TX_AGC_C_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0x1848
+		#define		REG_TX_AGC_C_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0x184c
+		#define		REG_TX_AGC_C_MCS19_MCS16_JAGUAR	0x18d8
+		#define		REG_TX_AGC_C_MCS23_MCS20_JAGUAR	0x18dc
+		#define		REG_TX_AGC_C_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0x18e0
+		#define		REG_TX_AGC_C_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0x18e4
+		#define		REG_TX_AGC_C_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0x18e8
+		#define		REG_TX_AGC_D_CCK_11_CCK_1_JAGUAR	0x1a20
+		#define		REG_TX_AGC_D_OFDM18_OFDM6_JAGUAR	0x1a24
+		#define		REG_TX_AGC_D_OFDM54_OFDM24_JAGUAR	0x1a28
+		#define		REG_TX_AGC_D_MCS3_MCS0_JAGUAR	0x1a2c
+		#define		REG_TX_AGC_D_MCS7_MCS4_JAGUAR	0x1a30
+		#define		REG_TX_AGC_D_MCS11_MCS8_JAGUAR	0x1a34
+		#define		REG_TX_AGC_D_MCS15_MCS12_JAGUAR	0x1a38
+		#define		REG_TX_AGC_D_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0x1a3c
+		#define		REG_TX_AGC_D_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0x1a40
+		#define		REG_TX_AGC_D_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0x1a44
+		#define		REG_TX_AGC_D_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0x1a48
+		#define		REG_TX_AGC_D_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0x1a4c
+		#define		REG_TX_AGC_D_MCS19_MCS16_JAGUAR	0x1ad8
+		#define		REG_TX_AGC_D_MCS23_MCS20_JAGUAR	0x1adc
+		#define		REG_TX_AGC_D_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0x1ae0
+		#define		REG_TX_AGC_D_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0x1ae4
+		#define		REG_TX_AGC_D_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0x1ae8
+	#endif
+
+	#define		is_tx_agc_byte0_jaguar	0xff
+	#define		is_tx_agc_byte1_jaguar	0xff00
+	#define		is_tx_agc_byte2_jaguar	0xff0000
+	#define		is_tx_agc_byte3_jaguar	0xff000000
+#endif
+
+#define	BIT_FA_RESET					BIT(0)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11ac.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11ac.h
index 3dfaf1f91af1..84f9bf0914ac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11ac.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11ac.h
@@ -1,90 +1,104 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#ifndef	__ODM_REGDEFINE11AC_H__
-#define __ODM_REGDEFINE11AC_H__
-
-//2 RF REG LIST
-
-
-
-//2 BB REG LIST
-//PAGE 8
-#define	ODM_REG_CCK_RPT_FORMAT_11AC	0x804
-#define	ODM_REG_BB_RX_PATH_11AC			0x808
-#define	ODM_REG_BB_TX_PATH_11AC			0x80c
-#define	ODM_REG_BB_ATC_11AC				0x860
-#define	ODM_REG_EDCCA_POWER_CAL		0x8dc
-#define	ODM_REG_DBG_RPT_11AC			0x8fc
-//PAGE 9
-#define	ODM_REG_EDCCA_DOWN_OPT			0x900
-#define	ODM_REG_ACBB_EDCCA_ENHANCE		0x944
-#define	ODM_REG_OFDM_FA_RST_11AC		0x9A4
-#define	ODM_REG_NHM_TIMER_11AC			0x990
-#define	ODM_REG_CLM_TIME_PERIOD_11AC	0x990
-#define	ODM_REG_NHM_TH9_TH10_11AC		0x994
-#define	ODM_REG_CLM_11AC					0x994
-#define	ODM_REG_NHM_TH3_TO_TH0_11AC	0x998
-#define	ODM_REG_NHM_TH7_TO_TH4_11AC	0x99c
-#define	ODM_REG_NHM_TH8_11AC			0x9a0
-#define	ODM_REG_NHM_9E8_11AC			0x9e8
-#define	ODM_REG_CSI_CONTENT_VALUE		0x9b4
-//PAGE A
-#define	ODM_REG_CCK_CCA_11AC			0xA0A
-#define	ODM_REG_CCK_FA_RST_11AC			0xA2C
-#define	ODM_REG_CCK_FA_11AC				0xA5C
-//PAGE B
-#define	ODM_REG_RST_RPT_11AC				0xB58
-//PAGE C
-#define	ODM_REG_TRMUX_11AC				0xC08
-#define	ODM_REG_IGI_A_11AC				0xC50
-//PAGE E
-#define	ODM_REG_IGI_B_11AC				0xE50
-#define	ODM_REG_TRMUX_11AC_B			0xE08
-//PAGE F
-#define	ODM_REG_CCK_CCA_CNT_11AC		0xF08
-#define	ODM_REG_OFDM_FA_11AC			0xF48
-#define	ODM_REG_RPT_11AC					0xfa0
-#define	ODM_REG_CLM_RESULT_11AC			0xfa4
-#define	ODM_REG_NHM_CNT_11AC			0xfa8
-#define ODM_REG_NHM_DUR_READY_11AC      0xfb4
-
-#define	ODM_REG_NHM_CNT7_TO_CNT4_11AC   0xfac
-#define	ODM_REG_NHM_CNT11_TO_CNT8_11AC  0xfb0
-#define	ODM_REG_OFDM_FA_TYPE2_11AC		0xFD0
-//PAGE 18
-#define	ODM_REG_IGI_C_11AC				0x1850
-//PAGE 1A
-#define	ODM_REG_IGI_D_11AC				0x1A50
-
-//2 MAC REG LIST
-#define	ODM_REG_RESP_TX_11AC				0x6D8
-
-
-
-//DIG Related
-#define	ODM_BIT_IGI_11AC					0xFFFFFFFF
-#define	ODM_BIT_CCK_RPT_FORMAT_11AC		BIT16
-#define	ODM_BIT_BB_RX_PATH_11AC			0xF
-#define	ODM_BIT_BB_TX_PATH_11AC			0xF
-#define	ODM_BIT_BB_ATC_11AC				BIT14
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__ODM_REGDEFINE11AC_H__
+#define __ODM_REGDEFINE11AC_H__
+
+/* 2 RF REG LIST */
+
+
+
+/* 2 BB REG LIST
+ * PAGE 8 */
+#define	ODM_REG_CCK_RPT_FORMAT_11AC	0x804
+#define	ODM_REG_BB_RX_PATH_11AC			0x808
+#define	ODM_REG_BB_TX_PATH_11AC			0x80c
+#define	ODM_REG_BB_ATC_11AC				0x860
+#define	ODM_REG_EDCCA_POWER_CAL		0x8dc
+#define	ODM_REG_DBG_RPT_11AC			0x8fc
+/* PAGE 9 */
+#define	ODM_REG_EDCCA_DOWN_OPT			0x900
+#define	ODM_REG_ACBB_EDCCA_ENHANCE		0x944
+#define	odm_adc_trigger_jaguar2			0x95C	/*ADC sample mode*/
+#define	ODM_REG_OFDM_FA_RST_11AC		0x9A4
+#define	ODM_REG_CCX_PERIOD_11AC			0x990
+#define	ODM_REG_NHM_TH9_TH10_11AC		0x994
+#define	ODM_REG_CLM_11AC					0x994
+#define	ODM_REG_NHM_TH3_TO_TH0_11AC	0x998
+#define	ODM_REG_NHM_TH7_TO_TH4_11AC	0x99c
+#define	ODM_REG_NHM_TH8_11AC			0x9a0
+#define	ODM_REG_NHM_9E8_11AC			0x9e8
+#define	ODM_REG_CSI_CONTENT_VALUE		0x9b4
+/* PAGE A */
+#define	ODM_REG_CCK_CCA_11AC			0xA0A
+#define	ODM_REG_CCK_FA_RST_11AC			0xA2C
+#define	ODM_REG_CCK_FA_11AC				0xA5C
+/* PAGE B */
+#define	ODM_REG_RST_RPT_11AC				0xB58
+/* PAGE C */
+#define	ODM_REG_TRMUX_11AC				0xC08
+#define	ODM_REG_IGI_A_11AC				0xC50
+/* PAGE E */
+#define	ODM_REG_IGI_B_11AC				0xE50
+#define	ODM_REG_TRMUX_11AC_B			0xE08
+/* PAGE F */
+#define	ODM_REG_CCK_CRC32_CNT_11AC		0xF04
+#define	ODM_REG_CCK_CCA_CNT_11AC		0xF08
+#define	ODM_REG_VHT_CRC32_CNT_11AC		0xF0c
+#define	ODM_REG_HT_CRC32_CNT_11AC		0xF10
+#define	ODM_REG_OFDM_CRC32_CNT_11AC	0xF14
+#define	ODM_REG_OFDM_FA_11AC			0xF48
+#define	ODM_REG_OFDM_FA_TYPE1_11AC		0xFCC
+#define	ODM_REG_OFDM_FA_TYPE2_11AC		0xFD0
+#define	ODM_REG_OFDM_FA_TYPE3_11AC		0xFBC
+#define	ODM_REG_OFDM_FA_TYPE4_11AC		0xFC0
+#define	ODM_REG_OFDM_FA_TYPE5_11AC		0xFC4
+#define	ODM_REG_OFDM_FA_TYPE6_11AC		0xFC8
+#define	ODM_REG_RPT_11AC					0xfa0
+#define	ODM_REG_CLM_RESULT_11AC			0xfa4
+#define	ODM_REG_NHM_CNT_11AC			0xfa8
+#define ODM_REG_NHM_DUR_READY_11AC      0xfb4
+
+#define	ODM_REG_NHM_CNT7_TO_CNT4_11AC   0xfac
+#define	ODM_REG_NHM_CNT11_TO_CNT8_11AC  0xfb0
+/* PAGE 18 */
+#define	ODM_REG_IGI_C_11AC				0x1850
+/* PAGE 1A */
+#define	ODM_REG_IGI_D_11AC				0x1A50
+
+/* 2 MAC REG LIST */
+#define	ODM_REG_RESP_TX_11AC				0x6D8
+
+
+
+/* DIG Related */
+#define	ODM_BIT_IGI_11AC					0x0000007F
+#define	ODM_BIT_CCK_RPT_FORMAT_11AC		BIT(16)
+#define	ODM_BIT_BB_RX_PATH_11AC			0xF
+#define	ODM_BIT_BB_TX_PATH_11AC			0xF
+#define	ODM_BIT_BB_ATC_11AC				BIT(14)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11n.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11n.h
index 2f09dc7f5e75..d9b208305d73 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11n.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regdefine11n.h
@@ -1,199 +1,220 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
-#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_CCK_RPT_FORMAT_11N_B	0x82C
-#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
-#define	ODM_REG_PSD_DATA_11N				0x8B4
-#define	ODM_REG_NHM_TIMER_11N			0x894
-#define	ODM_REG_CLM_TIME_PERIOD_11N			0x894
-#define	ODM_REG_NHM_TH9_TH10_11N		0x890
-#define	ODM_REG_CLM_11N					0x890
-#define	ODM_REG_NHM_TH3_TO_TH0_11N		0x898
-#define	ODM_REG_NHM_TH7_TO_TH4_11N		0x89c
-#define ODM_REG_NHM_TH8_11N				0xe28
-#define	ODM_REG_CLM_READY_11N			0x8b4
-#define	ODM_REG_CLM_RESULT_11N			0x8d0
-#define	ODM_REG_NHM_CNT_11N				0x8d8
-
-// For ACS, Jeffery, 2014-12-26
-#define	ODM_REG_NHM_CNT7_TO_CNT4_11N    0x8dc
-#define	ODM_REG_NHM_CNT9_TO_CNT8_11N    0x8d0
-#define	ODM_REG_NHM_CNT10_11N           0x8d4
-
-
-
-//PAGE 9
-#define	ODM_REG_DBG_RPT_11N				0x908
-#define	ODM_REG_BB_TX_PATH_11N			0x90c
-#define	ODM_REG_ANT_MAPPING1_11N		0x914
-#define	ODM_REG_ANT_MAPPING2_11N		0x918
-#define	ODM_REG_EDCCA_DOWN_OPT_11N	0x948
-
-//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_BB_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_L1SBD_PD_CH_11N			0XC6C
-#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_BB_ATC_11N				0xD2C
-#define	ODM_REG_OFDM_FA_TYPE2_11N		0xDA0
-#define	ODM_REG_OFDM_FA_TYPE3_11N		0xDA4
-#define	ODM_REG_OFDM_FA_TYPE4_11N		0xDA8
-#define	ODM_REG_RPT_11N					0xDF4
-//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_EDCCA_DCNF_11N			0xE24
-#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
-#define	ODM_REG_IGI_C_11N					0xF84
-#define	ODM_REG_IGI_D_11N					0xF88
-
-//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
-#define	ODM_BIT_CCK_RPT_FORMAT_11N		BIT9
-#define	ODM_BIT_BB_RX_PATH_11N			0xF
-#define	ODM_BIT_BB_TX_PATH_11N			0xF
-#define	ODM_BIT_BB_ATC_11N				BIT11
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#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_CCK_RPT_FORMAT_11N_B	0x82C
+#define	ODM_REG_RX_DEFAULT_A_11N		0x858
+#define	ODM_REG_RX_DEFAULT_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
+#define	ODM_REG_CCX_PERIOD_11N			0x894
+#define	ODM_REG_NHM_TH9_TH10_11N		0x890
+#define	ODM_REG_CLM_11N					0x890
+#define	ODM_REG_NHM_TH3_TO_TH0_11N		0x898
+#define	ODM_REG_NHM_TH7_TO_TH4_11N		0x89c
+#define ODM_REG_NHM_TH8_11N				0xe28
+#define	ODM_REG_CLM_READY_11N			0x8b4
+#define	ODM_REG_CLM_RESULT_11N			0x8d0
+#define	ODM_REG_NHM_CNT_11N				0x8d8
+
+/* For struct acs_info, Jeffery, 2014-12-26 */
+#define	ODM_REG_NHM_CNT7_TO_CNT4_11N		0x8dc
+#define	ODM_REG_NHM_CNT9_TO_CNT8_11N		0x8d0
+#define	ODM_REG_NHM_CNT10_TO_CNT11_11N	0x8d4
+
+/* PAGE 9 */
+#define	ODM_REG_BB_CTRL_PAGE9_11N		0x900
+#define	ODM_REG_DBG_RPT_11N				0x908
+#define	ODM_REG_BB_TX_PATH_11N			0x90c
+#define	ODM_REG_ANT_MAPPING1_11N		0x914
+#define	ODM_REG_ANT_MAPPING2_11N		0x918
+#define	ODM_REG_EDCCA_DOWN_OPT_11N	0x948
+#define	ODM_REG_RX_DFIR_MOD_97F			0x948
+#define	ODM_REG_SOML_97F					0x998
+
+/* PAGE A */
+#define	ODM_REG_CCK_ANTDIV_PARA1_11N	0xA00
+#define	ODM_REG_CCK_ANT_SEL_11N			0xA04
+#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
+#define	ODM_REG_RXCK_RFMOD				0xBB0
+#define	ODM_REG_EDCCA_DCNF_97F			0xBC0
+
+/* PAGE C */
+#define	ODM_REG_OFDM_FA_HOLDC_11N		0xC00
+#define	ODM_REG_BB_RX_PATH_11N			0xC04
+#define	ODM_REG_TRMUX_11N				0xC08
+#define	ODM_REG_OFDM_FA_RSTC_11N		0xC0C
+#define	ODM_REG_DOWNSAM_FACTOR_11N	0xC10
+#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_L1SBD_PD_CH_11N			0XC6C
+#define	ODM_REG_BB_PWR_SAV2_11N		0xC70
+#define	ODM_REG_BB_AGC_SET_2_11N		0xc74
+#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_SMALL_BANDWIDTH_11N	0xCE4
+#define	ODM_REG_OFDM_FA_TYPE1_11N		0xCF0
+/* PAGE D */
+#define	ODM_REG_OFDM_FA_RSTD_11N		0xD00
+#define	ODM_REG_BB_RX_ANT_11N			0xD04
+#define	ODM_REG_BB_ATC_11N				0xD2C
+#define	ODM_REG_OFDM_FA_TYPE2_11N		0xDA0
+#define	ODM_REG_OFDM_FA_TYPE3_11N		0xDA4
+#define	ODM_REG_OFDM_FA_TYPE4_11N		0xDA8
+#define	ODM_REG_RPT_11N					0xDF4
+/* 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_EDCCA_DCNF_11N			0xE24
+#define	ODM_REG_TAP_UPD_97F				0xE24
+#define	ODM_REG_FPGA0_IQK_11N			0xE28
+#define	ODM_REG_PAGE_B1_97F				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
+/* PAGE F */
+#define	ODM_REG_PAGE_F_RST_11N			0xF14
+#define	ODM_REG_IGI_C_11N					0xF84
+#define	ODM_REG_IGI_D_11N				0xF88
+#define	ODM_REG_CCK_CRC32_ERROR_CNT_11N	0xF84
+#define	ODM_REG_CCK_CRC32_OK_CNT_11N		0xF88
+#define	ODM_REG_HT_CRC32_CNT_11N		0xF90
+#define	ODM_REG_OFDM_CRC32_CNT_11N		0xF94
+#define	ODM_REG_HT_CRC32_CNT_11N_AGG	0xFB8
+
+/* 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
+#define	ODM_BIT_CCK_RPT_FORMAT_11N		BIT(9)
+#define	ODM_BIT_BB_RX_PATH_11N			0xF
+#define	ODM_BIT_BB_TX_PATH_11N			0xF
+#define	ODM_BIT_BB_ATC_11N				BIT(11)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regtable.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regtable.h
new file mode 100644
index 000000000000..e62f47c0aa6b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_regtable.h
@@ -0,0 +1,564 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+#define R_0x0 0x0
+#define R_0x00 0x00
+#define R_0x0140 0x0140
+#define R_0x040 0x040
+#define R_0x10 0x10
+#define R_0x1080 0x1080
+#define R_0x14c0 0x14c0
+#define R_0x14c4 0x14c4
+#define R_0x14c8 0x14c8
+#define R_0x14cc 0x14cc
+#define R_0x1518 0x1518
+#define R_0x1684 0x1684
+#define R_0x1688 0x1688
+#define R_0x168c 0x168c
+#define R_0x1700 0x1700
+#define R_0x1704 0x1704
+#define R_0x1800 0x1800
+#define R_0x183c 0x183c
+#define R_0x1840 0x1840
+#define R_0x1844 0x1844
+#define R_0x1848 0x1848
+#define R_0x188c 0x188c
+#define R_0x1894 0x1894
+#define R_0x18ac 0x18ac
+#define R_0x1900 0x1900
+#define R_0x1904 0x1904
+#define R_0x1908 0x1908
+#define R_0x1918 0x1918
+#define R_0x191c 0x191c
+#define R_0x1928 0x1928
+#define R_0x1950 0x1950
+#define R_0x1954 0x1954
+#define R_0x195c 0x195c
+#define R_0x1984 0x1984
+#define R_0x1988 0x1988
+#define R_0x198c 0x198c
+#define R_0x1990 0x1990
+#define R_0x1991 0x1991
+#define R_0x1998 0x1998
+#define R_0x19a8 0x19a8
+#define R_0x19d4 0x19d4
+#define R_0x19d8 0x19d8
+#define R_0x19e0 0x19e0
+#define R_0x19f0 0x19f0
+#define R_0x19f8 0x19f8
+#define R_0x1a00 0x1a00
+#define R_0x1a04 0x1a04
+#define R_0x1a24 0x1a24
+#define R_0x1a28 0x1a28
+#define R_0x1a2c 0x1a2c
+#define R_0x1a5c 0x1a5c
+#define R_0x1a84 0x1a84
+#define R_0x1a8c 0x1a8c
+#define R_0x1a94 0x1a94
+#define R_0x1aac 0x1aac
+#define R_0x1abc 0x1abc
+#define R_0x1ac0 0x1ac0
+#define R_0x1b00 0x1b00
+#define R_0x1b08 0x1b08
+#define R_0x1b0c 0x1b0c
+#define R_0x1b2c 0x1b2c
+#define R_0x1b38 0x1b38
+#define R_0x1b3c 0x1b3c
+#define R_0x1b8c 0x1b8c
+#define R_0x1b98 0x1b98
+#define R_0x1bc8 0x1bc8
+#define R_0x1bcc 0x1bcc
+#define R_0x1bd0 0x1bd0
+#define R_0x1bd4 0x1bd4
+#define R_0x1bd8 0x1bd8
+#define R_0x1bf0 0x1bf0
+#define R_0x1bfc 0x1bfc
+#define R_0x1c28 0x1c28
+#define R_0x1c38 0x1c38
+#define R_0x1c3c 0x1c3c
+#define R_0x1c68 0x1c68
+#define R_0x1c74 0x1c74
+#define R_0x1c78 0x1c78
+#define R_0x1c7c 0x1c7c
+#define R_0x1c90 0x1c90
+#define R_0x1c94 0x1c94
+#define R_0x1c98 0x1c98
+#define R_0x1c9c 0x1c9c
+#define R_0x1ca0 0x1ca0
+#define R_0x1cb8 0x1cb8
+#define R_0x1cf8 0x1cf8
+#define R_0x1d70 0x1d70
+#define R_0x1e2c 0x1e2c
+#define R_0x1e5c 0x1e5c
+#define R_0x1eb4 0x1eb4
+#define R_0x2c04 0x2c04
+#define R_0x2c08 0x2c08
+#define R_0x2c10 0x2c10
+#define R_0x2c14 0x2c14
+#define R_0x2d00 0x2d00
+#define R_0x2d04 0x2d04
+#define R_0x2d08 0x2d08
+#define R_0x2d10 0x2d10
+#define R_0x2d20 0x2d20
+#define R_0x2de8 0x2de8
+#define R_0x300 0x300
+#define R_0x38 0x38
+#define R_0x40 0x40
+#define R_0x4000 0x4000
+#define R_0x4008 0x4008
+#define R_0x4018 0x4018
+#define R_0x401c 0x401c
+#define R_0x4028 0x4028
+#define R_0x4100 0x4100
+#define R_0x413c 0x413c
+#define R_0x4140 0x4140
+#define R_0x4144 0x4144
+#define R_0x4148 0x4148
+#define R_0x430 0x430
+#define R_0x434 0x434
+#define R_0x44 0x44
+#define R_0x444 0x444
+#define R_0x448 0x448
+#define R_0x450 0x450
+#define R_0x454 0x454
+#define R_0x49c 0x49c
+#define R_0x4a0 0x4a0
+#define R_0x4a4 0x4a4
+#define R_0x4a8 0x4a8
+#define R_0x4c 0x4c
+#define R_0x4c8 0x4c8
+#define R_0x4cc 0x4cc
+#define R_0x5000 0x5000
+#define R_0x5008 0x5008
+#define R_0x5018 0x5018
+#define R_0x501c 0x501c
+#define R_0x5028 0x5028
+#define R_0x5100 0x5100
+#define R_0x5108 0x5108
+#define R_0x5118 0x5118
+#define R_0x511c 0x511c
+#define R_0x5128 0x5128
+#define R_0x520 0x520
+#define R_0x5200 0x5200
+#define R_0x522 0x522
+#define R_0x523c 0x523c
+#define R_0x5240 0x5240
+#define R_0x5244 0x5244
+#define R_0x5248 0x5248
+#define R_0x5300 0x5300
+#define R_0x533c 0x533c
+#define R_0x5340 0x5340
+#define R_0x5344 0x5344
+#define R_0x5348 0x5348
+#define R_0x550 0x550
+#define R_0x551 0x551
+#define R_0x568 0x568
+#define R_0x588 0x588
+#define R_0x604 0x604
+#define R_0x608 0x608
+#define R_0x60f 0x60f
+#define R_0x64 0x64
+#define R_0x66 0x66
+#define R_0x660 0x660
+#define R_0x668 0x668
+#define R_0x688 0x688
+#define R_0x6a0 0x6a0
+#define R_0x6d8 0x6d8
+#define R_0x6dc 0x6dc
+#define R_0x70 0x70
+#define R_0x74 0x74
+#define R_0x764 0x764
+#define R_0x7b0 0x7b0
+#define R_0x7b4 0x7b4
+#define R_0x7c0 0x7c0
+#define R_0x7c4 0x7c4
+#define R_0x7c8 0x7c8
+#define R_0x7cc 0x7cc
+#define R_0x7f0 0x7f0
+#define R_0x7f4 0x7f4
+#define R_0x7f8 0x7f8
+#define R_0x7fc 0x7fc
+#define R_0x800 0x800
+#define R_0x804 0x804
+#define R_0x808 0x808
+#define R_0x80c 0x80c
+#define R_0x810 0x810
+#define R_0x814 0x814
+#define R_0x818 0x818
+#define R_0x820 0x820
+#define R_0x824 0x824
+#define R_0x828 0x828
+#define R_0x82c 0x82c
+#define R_0x830 0x830
+#define R_0x834 0x834
+#define R_0x838 0x838
+#define R_0x83c 0x83c
+#define R_0x840 0x840
+#define R_0x848 0x848
+#define R_0x850 0x850
+#define R_0x854 0x854
+#define R_0x858 0x858
+#define R_0x860 0x860
+#define R_0x864 0x864
+#define R_0x86c 0x86c
+#define R_0x870 0x870
+#define R_0x874 0x874
+#define R_0x878 0x878
+#define R_0x87c 0x87c
+#define R_0x880 0x880
+#define R_0x884 0x884
+#define R_0x888 0x888
+#define R_0x88c 0x88c
+#define R_0x890 0x890
+#define R_0x894 0x894
+#define R_0x898 0x898
+#define R_0x89c 0x89c
+#define R_0x8a0 0x8a0
+#define R_0x8a4 0x8a4
+#define R_0x8ac 0x8ac
+#define R_0x8b4 0x8b4
+#define R_0x8c4 0x8c4
+#define R_0x8c8 0x8c8
+#define R_0x8cc 0x8cc
+#define R_0x8d0 0x8d0
+#define R_0x8d4 0x8d4
+#define R_0x8d8 0x8d8
+#define R_0x8dc 0x8dc
+#define R_0x8f0 0x8f0
+#define R_0x8f8 0x8f8
+#define R_0x8fc 0x8fc
+#define R_0x900 0x900
+#define R_0x908 0x908
+#define R_0x90c 0x90c
+#define R_0x910 0x910
+#define R_0x914 0x914
+#define R_0x918 0x918
+#define R_0x91c 0x91c
+#define R_0x920 0x920
+#define R_0x924 0x924
+#define R_0x92c 0x92c
+#define R_0x930 0x930
+#define R_0x934 0x934
+#define R_0x938 0x938
+#define R_0x93c 0x93c
+#define R_0x940 0x940
+#define R_0x944 0x944
+#define R_0x948 0x948
+#define R_0x94c 0x94c
+#define R_0x950 0x950
+#define R_0x958 0x958
+#define R_0x95c 0x95c
+#define R_0x970 0x970
+#define R_0x974 0x974
+#define R_0x978 0x978
+#define R_0x97c 0x97c
+#define R_0x98c 0x98c
+#define R_0x990 0x990
+#define R_0x994 0x994
+#define R_0x998 0x998
+#define R_0x9a0 0x9a0
+#define R_0x9a4 0x9a4
+#define R_0x9ac 0x9ac
+#define R_0x9b0 0x9b0
+#define R_0x9b4 0x9b4
+#define R_0x9cc 0x9cc
+#define R_0x9d0 0x9d0
+#define R_0x9e4 0x9e4
+#define R_0xa0 0xa0
+#define R_0xa00 0xa00
+#define R_0xa04 0xa04
+#define R_0xa08 0xa08
+#define R_0xa0c 0xa0c
+#define R_0xa10 0xa10
+#define R_0xa14 0xa14
+#define R_0xa20 0xa20
+#define R_0xa24 0xa24
+#define R_0xa28 0xa28
+#define R_0xa2c 0xa2c
+#define R_0xa70 0xa70
+#define R_0xa74 0xa74
+#define R_0xa78 0xa78
+#define R_0xa8 0xa8
+#define R_0xa80 0xa80
+#define R_0xa84 0xa84
+#define R_0xa9c 0xa9c
+#define R_0xaa8 0xaa8
+#define R_0xaac 0xaac
+#define R_0xab4 0xab4
+#define R_0xabc 0xabc
+#define R_0xac8 0xac8
+#define R_0xacc 0xacc
+#define R_0xad0 0xad0
+#define R_0xb0 0xb0
+#define R_0xb00 0xb00
+#define R_0xb04 0xb04
+#define R_0xb07 0xb07
+#define R_0xb08 0xb08
+#define R_0xb0c 0xb0c
+#define R_0xb10 0xb10
+#define R_0xb14 0xb14
+#define R_0xb18 0xb18
+#define R_0xb1c 0xb1c
+#define R_0xb20 0xb20
+#define R_0xb24 0xb24
+#define R_0xb28 0xb28
+#define R_0xb2b 0xb2b
+#define R_0xb2c 0xb2c
+#define R_0xb30 0xb30
+#define R_0xb34 0xb34
+#define R_0xb38 0xb38
+#define R_0xb3c 0xb3c
+#define R_0xb40 0xb40
+#define R_0xb44 0xb44
+#define R_0xb48 0xb48
+#define R_0xb54 0xb54
+#define R_0xb58 0xb58
+#define R_0xb60 0xb60
+#define R_0xb64 0xb64
+#define R_0xb68 0xb68
+#define R_0xb6a 0xb6a
+#define R_0xb6c 0xb6c
+#define R_0xb6e 0xb6e
+#define R_0xb70 0xb70
+#define R_0xb74 0xb74
+#define R_0xb77 0xb77
+#define R_0xb78 0xb78
+#define R_0xb7c 0xb7c
+#define R_0xb80 0xb80
+#define R_0xb84 0xb84
+#define R_0xb88 0xb88
+#define R_0xb8c 0xb8c
+#define R_0xb90 0xb90
+#define R_0xb94 0xb94
+#define R_0xb98 0xb98
+#define R_0xb9b 0xb9b
+#define R_0xb9c 0xb9c
+#define R_0xba0 0xba0
+#define R_0xba4 0xba4
+#define R_0xba8 0xba8
+#define R_0xbac 0xbac
+#define R_0xbad 0xbad
+#define R_0xbc0 0xbc0
+#define R_0xbc4 0xbc4
+#define R_0xbc8 0xbc8
+#define R_0xbcc 0xbcc
+#define R_0xbd8 0xbd8
+#define R_0xbdc 0xbdc
+#define R_0xbe0 0xbe0
+#define R_0xbe4 0xbe4
+#define R_0xbe8 0xbe8
+#define R_0xbec 0xbec
+#define R_0xbf0 0xbf0
+#define R_0xbf4 0xbf4
+#define R_0xbf8 0xbf8
+#define R_0xc00 0xc00
+#define R_0xc04 0xc04
+#define R_0xc08 0xc08
+#define R_0xc0c 0xc0c
+#define R_0xc10 0xc10
+#define R_0xc14 0xc14
+#define R_0xc1c 0xc1c
+#define R_0xc20 0xc20
+#define R_0xc24 0xc24
+#define R_0xc30 0xc30
+#define R_0xc38 0xc38
+#define R_0xc3c 0xc3c
+#define R_0xc40 0xc40
+#define R_0xc44 0xc44
+#define R_0xc4c 0xc4c
+#define R_0xc50 0xc50
+#define R_0xc54 0xc54
+#define R_0xc58 0xc58
+#define R_0xc5c 0xc5c
+#define R_0xc6c 0xc6c
+#define R_0xc70 0xc70
+#define R_0xc74 0xc74
+#define R_0xc78 0xc78
+#define R_0xc7c 0xc7c
+#define R_0xc80 0xc80
+#define R_0xc84 0xc84
+#define R_0xc88 0xc88
+#define R_0xc8c 0xc8c
+#define R_0xc90 0xc90
+#define R_0xc94 0xc94
+#define R_0xc9c 0xc9c
+#define R_0xca0 0xca0
+#define R_0xca4 0xca4
+#define R_0xca8 0xca8
+#define R_0xcac 0xcac
+#define R_0xcb0 0xcb0
+#define R_0xcb4 0xcb4
+#define R_0xcb8 0xcb8
+#define R_0xcbc 0xcbc
+#define R_0xcbd 0xcbd
+#define R_0xcbe 0xcbe
+#define R_0xcc4 0xcc4
+#define R_0xcc8 0xcc8
+#define R_0xccc 0xccc
+#define R_0xcd0 0xcd0
+#define R_0xcd4 0xcd4
+#define R_0xcd8 0xcd8
+#define R_0xce0 0xce0
+#define R_0xce4 0xce4
+#define R_0xce8 0xce8
+#define R_0xd00 0xd00
+#define R_0xd04 0xd04
+#define R_0xd0c 0xd0c
+#define R_0xd10 0xd10
+#define R_0xd14 0xd14
+#define R_0xd2c 0xd2c
+#define R_0xd30 0xd30
+#define R_0xd40 0xd40
+#define R_0xd44 0xd44
+#define R_0xd48 0xd48
+#define R_0xd4c 0xd4c
+#define R_0xd50 0xd50
+#define R_0xd54 0xd54
+#define R_0xd5c 0xd5c
+#define R_0xd6c 0xd6c
+#define R_0xd7c 0xd7c
+#define R_0xd80 0xd80
+#define R_0xd84 0xd84
+#define R_0xd8c 0xd8c
+#define R_0xd90 0xd90
+#define R_0xd94 0xd94
+#define R_0xdac 0xdac
+#define R_0xdb0 0xdb0
+#define R_0xdb4 0xdb4
+#define R_0xdb8 0xdb8
+#define R_0xdbc 0xdbc
+#define R_0xdcc 0xdcc
+#define R_0xdd0 0xdd0
+#define R_0xdd4 0xdd4
+#define R_0xdd8 0xdd8
+#define R_0xde0 0xde0
+#define R_0xdec 0xdec
+#define R_0xdf4 0xdf4
+#define R_0xe00 0xe00
+#define R_0xe04 0xe04
+#define R_0xe08 0xe08
+#define R_0xe10 0xe10
+#define R_0xe14 0xe14
+#define R_0xe1c 0xe1c
+#define R_0xe20 0xe20
+#define R_0xe24 0xe24
+#define R_0xe28 0xe28
+#define R_0xe30 0xe30
+#define R_0xe34 0xe34
+#define R_0xe38 0xe38
+#define R_0xe3c 0xe3c
+#define R_0xe40 0xe40
+#define R_0xe44 0xe44
+#define R_0xe48 0xe48
+#define R_0xe4c 0xe4c
+#define R_0xe50 0xe50
+#define R_0xe54 0xe54
+#define R_0xe5c 0xe5c
+#define R_0xe64 0xe64
+#define R_0xe70 0xe70
+#define R_0xe80 0xe80
+#define R_0xe84 0xe84
+#define R_0xe8c 0xe8c
+#define R_0xe90 0xe90
+#define R_0xe94 0xe94
+#define R_0xe98 0xe98
+#define R_0xe9c 0xe9c
+#define R_0xea0 0xea0
+#define R_0xea4 0xea4
+#define R_0xea8 0xea8
+#define R_0xeac 0xeac
+#define R_0xeb0 0xeb0
+#define R_0xeb4 0xeb4
+#define R_0xeb8 0xeb8
+#define R_0xebc 0xebc
+#define R_0xec0 0xec0
+#define R_0xec4 0xec4
+#define R_0xec8 0xec8
+#define R_0xecc 0xecc
+#define R_0xed4 0xed4
+#define R_0xee8 0xee8
+#define R_0xf0 0xf0
+#define R_0xf08 0xf08
+#define R_0xf0c 0xf0c
+#define R_0xf10 0xf10
+#define R_0xf14 0xf14
+#define R_0xf20 0xf20
+#define R_0xf2c 0xf2c
+#define R_0xf30 0xf30
+#define R_0xf34 0xf34
+#define R_0xf4 0xf4
+#define R_0xf44 0xf44
+#define R_0xf48 0xf48
+#define R_0xf4c 0xf4c
+#define R_0xf80 0xf80
+#define R_0xf84 0xf84
+#define R_0xf88 0xf88
+#define R_0xf8c 0xf8c
+#define R_0xf90 0xf90
+#define R_0xf94 0xf94
+#define R_0xf98 0xf98
+#define R_0xfa0 0xfa0
+#define R_0xfa4 0xfa4
+#define R_0xfbc 0xfbc
+#define R_0xfc0 0xfc0
+#define R_0xfc4 0xfc4
+#define R_0xfc8 0xfc8
+#define R_0xfcc 0xfcc
+#define R_0xfd0 0xfd0
+#define R_0xff0 0xff0
+#define RF_0x0 0x0
+#define RF_0x00 0x00
+#define RF_0x08 0x08
+#define RF_0x0c 0x0c
+#define RF_0x0d 0x0d
+#define RF_0x1 0x1
+#define RF_0x18 0x18
+#define RF_0x1bf0 0x1bf0
+#define RF_0x2 0x2
+#define RF_0x3 0x3
+#define RF_0x30 0x30
+#define RF_0x31 0x31
+#define RF_0x32 0x32
+#define RF_0x33 0x33
+#define RF_0x35 0x35
+#define RF_0x3e 0x3e
+#define RF_0x3f 0x3f
+#define RF_0x4 0x4
+#define RF_0x42 0x42
+#define RF_0x43 0x43
+#define RF_0x51 0x51
+#define RF_0x52 0x52
+#define RF_0x54 0x54
+#define RF_0x55 0x55
+#define RF_0x56 0x56
+#define RF_0x58 0x58
+#define RF_0x5c 0x5c
+#define RF_0x61 0x61
+#define RF_0x64 0x64
+#define RF_0x65 0x65
+#define RF_0x66 0x66
+#define RF_0x75 0x75
+#define RF_0x76 0x76
+#define RF_0x78 0x78
+#define RF_0x7f 0x7f
+#define RF_0x8 0x8
+#define RF_0x80 0x80
+#define RF_0x81 0x81
+#define RF_0x86 0x86
+#define RF_0x8d 0x8d
+#define RF_0x8f 0x8f
+#define RF_0xae 0xae
+#define RF_0xb0 0xb0
+#define RF_0xb8 0xb8
+#define RF_0xbc 0xbc
+#define RF_0xbe 0xbe
+#define RF_0xc4 0xc4
+#define RF_0xc9 0xc9
+#define RF_0xca 0xca
+#define RF_0xcc 0xcc
+#define RF_0xd 0xd
+#define RF_0xdd 0xdd
+#define RF_0xde 0xde
+#define RF_0xdf 0xdf
+#define RF_0xed 0xed
+#define RF_0xee 0xee
+#define RF_0xef 0xef
+#define RF_0xf5 0xf5
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rssi_monitor.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rssi_monitor.c
new file mode 100644
index 000000000000..c6e43bf2e12a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rssi_monitor.c
@@ -0,0 +1,451 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+ 
+#ifdef PHYDM_SUPPORT_RSSI_MONITOR
+
+#ifdef PHYDM_3RD_REFORM_RSSI_MONOTOR
+void
+phydm_rssi_monitor_h2c(
+	void	*dm_void,
+	u8	macid
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info				*ra = NULL;
+	u8		h2c_val[H2C_MAX_LENGTH] = {0};
+	u8		stbc_en, ldpc_en;
+	u8		bf_en = 0;
+	u8		is_rx, is_tx;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+	} else {
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "[Warning] %s invalid sta_info\n", __func__);
+		return;
+	}
+	
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "MACID=%d\n", sta->mac_id);
+
+	is_rx = (ra->txrx_state == RX_STATE) ? 1 : 0;
+	is_tx = (ra->txrx_state == TX_STATE) ? 1 : 0;
+	stbc_en = (sta->stbc_en) ? 1 : 0;
+	ldpc_en = (sta->ldpc_en) ? 1 : 0;
+
+	#ifdef CONFIG_BEAMFORMING
+	if ((sta->bf_info.ht_beamform_cap & BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
+		(sta->bf_info.vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) {
+		bf_en = 1;
+	}
+	#endif
+
+	if (ra_t->RA_threshold_offset != 0) {
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "RA_th_ofst = (( %s%d ))\n",
+			((ra_t->RA_offset_direction) ? "+" : "-"), ra_t->RA_threshold_offset);
+	}
+
+	h2c_val[0] = sta->mac_id;
+	h2c_val[1] = 0;
+	h2c_val[2] = sta->rssi_stat.rssi;
+	h2c_val[3] = is_rx | (stbc_en << 1) | ((dm->noisy_decision & 0x1) << 2) |  (bf_en << 6);
+	h2c_val[4] = (ra_t->RA_threshold_offset & 0x7f) | ((ra_t->RA_offset_direction & 0x1) << 7);
+	h2c_val[5] = 0;
+	h2c_val[6] = 0;
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "PHYDM h2c[0x42]=0x%x %x %x %x %x %x %x\n",
+		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]);
+
+	#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		odm_ra_set_rssi_8188e(dm, (u8)(sta->mac_id & 0xFF), sta->rssi_stat.rssi & 0x7F);
+	else
+	#endif 
+	{
+		odm_fill_h2c_cmd(dm, ODM_H2C_RSSI_REPORT, H2C_MAX_LENGTH, h2c_val);
+	}
+}
+
+void
+phydm_calculate_rssi_min_max(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info		*sta;
+	s8	rssi_max_tmp = 0, rssi_min_tmp = 100;
+	u8	i;
+	u8	sta_cnt = 0;
+
+	if (!dm->is_linked)
+		return;
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
+			sta_cnt++;
+
+			if (sta->rssi_stat.rssi < rssi_min_tmp)
+				rssi_min_tmp = sta->rssi_stat.rssi;
+
+			if (sta->rssi_stat.rssi > rssi_max_tmp)
+				rssi_max_tmp = sta->rssi_stat.rssi;
+
+			/*[Send RSSI to FW]*/
+			if (sta->ra_info.disable_ra == false)
+				phydm_rssi_monitor_h2c(dm, i);
+
+			if (sta_cnt == dm->number_linked_client)
+				break;
+		}
+	}
+
+	dm->rssi_max = (u8)rssi_max_tmp;
+	dm->rssi_min = (u8)rssi_min_tmp;
+
+}
+#endif
+
+
+#if 0/*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+s32
+phydm_find_minimum_rssi(
+	struct dm_struct	*dm,
+	void			*adapter,
+	boolean					*is_link_temp
+
+)
+{
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	PMGNT_INFO		mgnt_info = &adapter->MgntInfo;
+	boolean			act_as_ap = ACTING_AS_AP(adapter);
+
+	/* 1.Determine the minimum RSSI */
+	if ((!mgnt_info->bMediaConnect) ||
+	    (act_as_ap && (hal_data->EntryMinUndecoratedSmoothedPWDB == 0))) {/* We should check AP mode and Entry info.into consideration, revised by Roger, 2013.10.18*/
+
+		hal_data->MinUndecoratedPWDBForDM = 0;
+		*is_link_temp = false;
+
+	} else
+		*is_link_temp = true;
+
+
+	if (mgnt_info->bMediaConnect) {	/* Default port*/
+
+		if (act_as_ap || mgnt_info->mIbss) {
+			hal_data->MinUndecoratedPWDBForDM = hal_data->EntryMinUndecoratedSmoothedPWDB;
+			/**/
+		} else {
+			hal_data->MinUndecoratedPWDBForDM = GET_DEFAULT_RSSI(mgnt_info);
+			/**/
+		}
+	} else { /* associated entry pwdb*/
+		hal_data->MinUndecoratedPWDBForDM = hal_data->EntryMinUndecoratedSmoothedPWDB;
+		/**/
+	}
+
+	return hal_data->MinUndecoratedPWDBForDM;
+}
+
+void
+odm_rssi_monitor_check_mp(
+	void	*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table			*ra_tab = &dm->dm_ra_table;
+	u8			h2c_parameter[H2C_0X42_LENGTH] = {0};
+	u32			i;
+	boolean			is_ext_ra_info = true;
+	u8			cmdlen = H2C_0X42_LENGTH;
+	u8			tx_bf_en = 0, stbc_en = 0;
+
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	struct sta_info		*entry = NULL;
+	s32			tmp_entry_max_pwdb = 0, tmp_entry_min_pwdb = 0xff;
+	PMGNT_INFO		mgnt_info = &adapter->MgntInfo;
+	PMGNT_INFO		p_default_mgnt_info = &adapter->MgntInfo;
+	u64			cur_tx_ok_cnt = 0, cur_rx_ok_cnt = 0;
+#if (BEAMFORMING_SUPPORT == 1)
+#ifndef BEAMFORMING_VERSION_1
+	enum beamforming_cap beamform_cap = BEAMFORMING_CAP_NONE;
+#endif
+#endif
+	void	*loop_adapter = GetDefaultAdapter(adapter);
+
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		is_ext_ra_info = false;
+		cmdlen = 3;
+	}
+
+	while (loop_adapter) {
+		if (loop_adapter != NULL) {
+			mgnt_info = &loop_adapter->MgntInfo;
+			cur_tx_ok_cnt = loop_adapter->TxStats.NumTxBytesUnicast - mgnt_info->lastTxOkCnt;
+			cur_rx_ok_cnt = loop_adapter->RxStats.NumRxBytesUnicast - mgnt_info->lastRxOkCnt;
+			mgnt_info->lastTxOkCnt = cur_tx_ok_cnt;
+			mgnt_info->lastRxOkCnt = cur_rx_ok_cnt;
+		}
+
+		for (i = 0; i < ASSOCIATE_ENTRY_NUM; i++) {
+			if (IsAPModeExist(loop_adapter)) {
+				if (GetFirstExtAdapter(loop_adapter) != NULL &&
+				    GetFirstExtAdapter(loop_adapter) == loop_adapter)
+				entry = AsocEntry_EnumStation(loop_adapter, i);
+				else if (GetFirstGOPort(loop_adapter) != NULL &&
+					 IsFirstGoAdapter(loop_adapter))
+				entry = AsocEntry_EnumStation(loop_adapter, i);
+			} else {
+				if (GetDefaultAdapter(loop_adapter) == loop_adapter)
+					entry = AsocEntry_EnumStation(loop_adapter, i);
+			}
+
+			if (entry != NULL) {
+				if (entry->bAssociated) {
+					RT_DISP_ADDR(FDM, DM_PWDB, ("entry->mac_addr ="), GET_STA_INFO(entry).mac_addr);
+					RT_DISP(FDM, DM_PWDB, ("entry->rssi = 0x%x(%d)\n",
+						GET_STA_INFO(entry).rssi_stat.rssi, GET_STA_INFO(entry).rssi_stat.rssi));
+
+					/* 2 BF_en */
+#if (BEAMFORMING_SUPPORT == 1)
+#ifndef BEAMFORMING_VERSION_1
+					beamform_cap = phydm_beamforming_get_entry_beam_cap_by_mac_id(dm, GET_STA_INFO(entry).mac_id);
+					if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
+						tx_bf_en = 1;
+#else
+					if (Beamform_GetSupportBeamformerCap(GetDefaultAdapter(adapter), entry))
+						tx_bf_en = 1;
+#endif
+#endif
+					/* 2 STBC_en */
+					if ((IS_WIRELESS_MODE_AC(adapter) && TEST_FLAG(entry->VHTInfo.STBC, STBC_VHT_ENABLE_TX)) ||
+						TEST_FLAG(entry->HTInfo.STBC, STBC_HT_ENABLE_TX))
+						stbc_en = 1;
+
+					if (GET_STA_INFO(entry).rssi_stat.rssi < tmp_entry_min_pwdb)
+						tmp_entry_min_pwdb = GET_STA_INFO(entry).rssi_stat.rssi;
+					if (GET_STA_INFO(entry).rssi_stat.rssi > tmp_entry_max_pwdb)
+						tmp_entry_max_pwdb = GET_STA_INFO(entry).rssi_stat.rssi;
+
+					h2c_parameter[4] = (ra_tab->RA_threshold_offset & 0x7f) | (ra_tab->RA_offset_direction << 7);
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "RA_threshold_offset = (( %s%d ))\n", ((ra_tab->RA_threshold_offset == 0) ? " " : ((ra_tab->RA_offset_direction) ? "+" : "-")), ra_tab->RA_threshold_offset);
+
+					if (is_ext_ra_info) {
+						if (cur_rx_ok_cnt > (cur_tx_ok_cnt * 6))
+							h2c_parameter[3] |= RAINFO_BE_RX_STATE;
+
+						if (tx_bf_en)
+							h2c_parameter[3] |= RAINFO_BF_STATE;
+						else {
+							if (stbc_en)
+								h2c_parameter[3] |= RAINFO_STBC_STATE;
+						}
+
+						if (dm->noisy_decision)
+							h2c_parameter[3] |= RAINFO_NOISY_STATE;
+						else
+							h2c_parameter[3] &= (~RAINFO_NOISY_STATE);
+
+						if (dm->h2c_rarpt_connect) {
+							h2c_parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
+							PHYDM_DBG(dm, DBG_RSSI_MNTR, "h2c_rarpt_connect = (( %d ))\n", dm->h2c_rarpt_connect);
+						}
+
+					}
+
+					h2c_parameter[2] = (u8)(GET_STA_INFO(entry).rssi_stat.rssi & 0xFF);
+					/* h2c_parameter[1] = 0x20;*/ /* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1 */
+					h2c_parameter[0] = (GET_STA_INFO(entry).mac_id);
+
+					odm_fill_h2c_cmd(dm, ODM_H2C_RSSI_REPORT, cmdlen, h2c_parameter);
+				}
+			} else
+				break;
+		}
+
+		loop_adapter = GetNextExtAdapter(loop_adapter);
+	}
+
+
+	/*Default port*/
+	if (tmp_entry_max_pwdb != 0) {	/* If associated entry is found */
+		hal_data->EntryMaxUndecoratedSmoothedPWDB = tmp_entry_max_pwdb;
+		RT_DISP(FDM, DM_PWDB, ("EntryMaxPWDB = 0x%x(%d)\n",	tmp_entry_max_pwdb, tmp_entry_max_pwdb));
+	} else
+		hal_data->EntryMaxUndecoratedSmoothedPWDB = 0;
+
+	if (tmp_entry_min_pwdb != 0xff) { /* If associated entry is found */
+		hal_data->EntryMinUndecoratedSmoothedPWDB = tmp_entry_min_pwdb;
+		RT_DISP(FDM, DM_PWDB, ("EntryMinPWDB = 0x%x(%d)\n", tmp_entry_min_pwdb, tmp_entry_min_pwdb));
+
+	} else
+		hal_data->EntryMinUndecoratedSmoothedPWDB = 0;
+
+	/* Default porti sent RSSI to FW */
+	if (hal_data->bUseRAMask) {
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "1 RA First Link, RSSI[%d] = ((%d)) , ra_rpt_linked = ((%d))\n",
+			WIN_DEFAULT_PORT_MACID, GET_DEFAULT_RSSI(mgnt_info), hal_data->ra_rpt_linked);
+		if (GET_DEFAULT_RSSI(mgnt_info) > 0) {
+			PRT_HIGH_THROUGHPUT			p_ht_info = GET_HT_INFO(p_default_mgnt_info);
+			PRT_VERY_HIGH_THROUGHPUT	p_vht_info = GET_VHT_INFO(p_default_mgnt_info);
+
+			/* BF_en*/
+#if (BEAMFORMING_SUPPORT == 1)
+#ifndef BEAMFORMING_VERSION_1
+			beamform_cap = phydm_beamforming_get_entry_beam_cap_by_mac_id(dm, p_default_mgnt_info->m_mac_id);
+
+			if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
+				tx_bf_en = 1;
+#else
+			if (Beamform_GetSupportBeamformerCap(GetDefaultAdapter(adapter), NULL))
+				tx_bf_en = 1;
+#endif
+#endif
+
+			/* STBC_en*/
+			if ((IS_WIRELESS_MODE_AC(adapter) && TEST_FLAG(p_vht_info->VhtCurStbc, STBC_VHT_ENABLE_TX)) ||
+			    TEST_FLAG(p_ht_info->HtCurStbc, STBC_HT_ENABLE_TX))
+				stbc_en = 1;
+
+			h2c_parameter[4] = (ra_tab->RA_threshold_offset & 0x7f) | (ra_tab->RA_offset_direction << 7);
+			PHYDM_DBG(dm, DBG_RSSI_MNTR, "RA_threshold_offset = (( %s%d ))\n", ((ra_tab->RA_threshold_offset == 0) ? " " : ((ra_tab->RA_offset_direction) ? "+" : "-")), ra_tab->RA_threshold_offset);
+
+			if (is_ext_ra_info) {
+				if (tx_bf_en)
+					h2c_parameter[3] |= RAINFO_BF_STATE;
+				else {
+					if (stbc_en)
+						h2c_parameter[3] |= RAINFO_STBC_STATE;
+				}
+
+				if (dm->h2c_rarpt_connect) {
+					h2c_parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "h2c_rarpt_connect = (( %d ))\n", dm->h2c_rarpt_connect);
+				}
+
+
+				if (dm->noisy_decision == 1) {
+					h2c_parameter[3] |= RAINFO_NOISY_STATE;
+					PHYDM_DBG(dm, DBG_RSSI_MNTR, "[RSSIMonitorCheckMP] Send H2C to FW\n");
+				} else
+					h2c_parameter[3] &= (~RAINFO_NOISY_STATE);
+
+				PHYDM_DBG(dm, DBG_RSSI_MNTR, "[RSSIMonitorCheckMP] h2c_parameter=%x\n", h2c_parameter[3]);
+			}
+
+			h2c_parameter[2] = (u8)(GET_DEFAULT_RSSI(mgnt_info) & 0xFF);
+			/*h2c_parameter[1] = 0x20;*/	/* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1*/
+			h2c_parameter[0] = WIN_DEFAULT_PORT_MACID;		/* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1*/
+
+			odm_fill_h2c_cmd(dm, ODM_H2C_RSSI_REPORT, cmdlen, h2c_parameter);
+		}
+	
+	} else
+		PlatformEFIOWrite1Byte(adapter, 0x4fe, (u8)GET_DEFAULT_RSSI(mgnt_info));
+
+	{
+		void *loop_adapter = GetDefaultAdapter(adapter);
+		boolean		default_pointer_value, *is_link_temp = &default_pointer_value;
+		s32	global_rssi_min = 0xFF, local_rssi_min;
+		boolean		is_link = false;
+
+		while (loop_adapter) {
+			local_rssi_min = phydm_find_minimum_rssi(dm, loop_adapter, is_link_temp);
+			/* dbg_print("hal_data->is_linked=%d, local_rssi_min=%d\n", hal_data->is_linked, local_rssi_min); */
+
+			if (*is_link_temp)
+				is_link = true;
+
+			if ((local_rssi_min < global_rssi_min) && (*is_link_temp))
+				global_rssi_min = local_rssi_min;
+
+			loop_adapter = GetNextExtAdapter(loop_adapter);
+		}
+
+		hal_data->bLinked = is_link;
+
+		dm->is_linked = is_link;
+		dm->rssi_min = (u8)((is_link) ? global_rssi_min : 0);
+
+	}
+
+
+}
+
+#endif
+
+void
+phydm_rssi_monitor_check(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_RSSI_MONITOR))
+		return;
+
+	if ((dm->phydm_sys_up_time % 2) == 1) /*for AP watchdog period = 1 sec*/
+		return;
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
+
+
+	phydm_calculate_rssi_min_max(dm);
+
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "RSSI {max, min} = {%d, %d}\n",
+		dm->rssi_max, dm->rssi_min);
+
+}
+
+void
+phydm_rssi_monitor_init(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct ra_table	*ra_tab = &dm->dm_ra_table;
+
+	ra_tab->firstconnect = false;
+	dm->rssi_max = 0;
+	dm->rssi_min = 0;
+
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rssi_monitor.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rssi_monitor.h
new file mode 100644
index 000000000000..2a5a0d504e57
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rssi_monitor.h
@@ -0,0 +1,76 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+
+#ifndef	__PHYDM_RSSI_MONITOR_H__
+#define    __PHYDM_RSSI_MONITOR_H__
+
+#define RSSI_MONITOR_VERSION	"1.0"		/* 2017.05.011  Dino, Add phydm_rssi_monitor.h*/
+
+
+/* 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================ */
+
+#define	H2C_0X42_LENGTH	5
+
+#define RAINFO_BE_RX_STATE				BIT(0)	/* 1:RX*/ /* ULDL */
+#define RAINFO_STBC_STATE				BIT(1)
+#define RAINFO_NOISY_STATE 			BIT(2)	/* set by Noisy_Detection */
+/*#define RAINFO_SHURTCUT_STATE			BIT(3)*/
+/*#define RAINFO_SHURTCUT_FLAG			BIT(4)*/
+#define RAINFO_INIT_RSSI_RATE_STATE	BIT(5)
+#define RAINFO_BF_STATE				BIT(6)
+#define RAINFO_BE_TX_STATE 			BIT(7)	/* 1:TX */
+
+/* 1 ============================================================
+ * 1  structure
+ * 1 ============================================================ */
+
+
+
+
+/* 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================ */
+
+
+
+/* 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================ */
+
+void
+phydm_rssi_monitor_check(
+	void		*dm_void
+);
+
+void
+phydm_rssi_monitor_init(
+	void		*dm_void
+);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rxhp.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rxhp.c
deleted file mode 100644
index 8a4a273e2177..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rxhp.c
+++ /dev/null
@@ -1,1692 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-#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	SCAN_INTERVAL	1500 //ms
-#define	SYN_Length		5    // for 92D
-	
-#define	LNA_Low_Gain_1                      0x64
-#define	LNA_Low_Gain_2                      0x5A
-#define	LNA_Low_Gain_3                      0x58
-
-#define	pw_th_10dB					0x0
-#define	pw_th_16dB					0x3
-
-#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
-
-#define	Idle_Mode					0
-#define	High_TP_Mode				1
-#define	Low_TP_Mode				2
-
-
-VOID
-odm_PSDMonitorInit(
-	IN		PVOID			pDM_VOID
-	)
-{
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)|(DEV_BUS_TYPE == RT_USB_INTERFACE)
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	//HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	//PSD Monitor Setting
-	//Which path in ADC/DAC is turnned on for PSD: both I/Q
-	ODM_SetBBReg(pDM_Odm, ODM_PSDREG, BIT10|BIT11, 0x3);
-	//Ageraged number: 8
-	ODM_SetBBReg(pDM_Odm, ODM_PSDREG, BIT12|BIT13, 0x1);
-	pDM_Odm->bPSDinProcess = FALSE;
-	pDM_Odm->bUserAssignLevel = FALSE;
-	pDM_Odm->bPSDactive = FALSE;
-	//pDM_Odm->bDMInitialGainEnable=TRUE;		//change the initialization to DIGinit
-	//Set Debug Port
-	//PHY_SetBBReg(Adapter, 0x908, bMaskDWord, 0x803);
-	//PHY_SetBBReg(Adapter, 0xB34, bMaskByte0, 0x00); // pause PSD
-	//PHY_SetBBReg(Adapter, 0xB38, bMaskByte0, 10); //rescan
-	//PHY_SetBBReg(Adapter, 0xB38, bMaskByte2|bMaskByte3, 100); //interval
-
-	//PlatformSetTimer( Adapter, &pHalData->PSDTriggerTimer, 0); //ms
-#endif
-}
-
-VOID
-PatchDCTone(
-	IN		PVOID			pDM_VOID,
-	pu4Byte		PSD_report,
-	u1Byte 		initial_gain_psd
-)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	//HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	//PADAPTER	pAdapter;
-	
-	u4Byte	psd_report;
-
-	//2 Switch to CH11 to patch CH9 and CH13 DC tone
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x3FF, 11);
-	
-	if(pDM_Odm->SupportICType== ODM_RTL8192D)
-	{
-		if((*(pDM_Odm->pMacPhyMode) == ODM_SMSP)||(*(pDM_Odm->pMacPhyMode) == ODM_DMSP))
-		{
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_CHNLBW, 0x3FF, 11);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x25, 0xfffff, 0x643BC);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x26, 0xfffff, 0xFC038);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x27, 0xfffff, 0x77C1A);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x2B, 0xfffff, 0x41289);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x2C, 0xfffff, 0x01840);
-		}
-		else
-		{
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x25, 0xfffff, 0x643BC);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x26, 0xfffff, 0xFC038);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x27, 0xfffff, 0x77C1A);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x2B, 0xfffff, 0x41289);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x2C, 0xfffff, 0x01840);
-		}
-	}
-	
-	//Ch9 DC tone patch
-	psd_report = GetPSDData(pDM_Odm, 96, initial_gain_psd);
-	PSD_report[50] = psd_report;
-	//Ch13 DC tone patch
-	psd_report = GetPSDData(pDM_Odm, 32, initial_gain_psd);
-	PSD_report[70] = psd_report;
-	
-	//2 Switch to CH3 to patch CH1 and CH5 DC tone
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x3FF, 3);
-
-	
-	if(pDM_Odm->SupportICType==ODM_RTL8192D)
-	{
-		if((*(pDM_Odm->pMacPhyMode) == ODM_SMSP)||(*(pDM_Odm->pMacPhyMode) == ODM_DMSP))
-		{
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_CHNLBW, 0x3FF, 3);
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_B, 0x25, 0xfffff, 0x643BC);
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_B, 0x26, 0xfffff, 0xFC038);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x27, 0xfffff, 0x07C1A);
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_B, 0x2B, 0xfffff, 0x61289);
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_B, 0x2C, 0xfffff, 0x01C41);
-		}
-		else
-		{
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x25, 0xfffff, 0x643BC);
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x26, 0xfffff, 0xFC038);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x27, 0xfffff, 0x07C1A);
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x2B, 0xfffff, 0x61289);
-			//PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x2C, 0xfffff, 0x01C41);
-		}
-	}
-	
-	//Ch1 DC tone patch
-	psd_report = GetPSDData(pDM_Odm, 96, initial_gain_psd);
-	PSD_report[10] = psd_report;
-	//Ch5 DC tone patch
-	psd_report = GetPSDData(pDM_Odm, 32, initial_gain_psd);
-	PSD_report[30] = psd_report;
-
-}
-
-
-VOID
-GoodChannelDecision(
-	IN		PVOID			pDM_VOID,
-	pu4Byte		PSD_report,
-	pu1Byte		PSD_bitmap,
-	u1Byte 		RSSI_BT,
-	pu1Byte		PSD_bitmap_memory)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRXHP_T			pRX_HP_Table = &pDM_Odm->DM_RXHP_Table;
-	//s4Byte	TH1 =  SSBT-0x15;    // modify TH by Neil Chen
-	s4Byte	TH1= RSSI_BT+0x14;
-	s4Byte	TH2 = RSSI_BT+85;
-	//u2Byte    TH3;
-//	s4Byte	RegB34;
-	u1Byte	bitmap, Smooth_size[3], Smooth_TH[3];
-	//u1Byte	psd_bit;
-	u4Byte	i,n,j, byte_idx, bit_idx, good_cnt, good_cnt_smoothing, Smooth_Interval[3];
-	int 		start_byte_idx,start_bit_idx,cur_byte_idx, cur_bit_idx,NOW_byte_idx ;
-	
-//	RegB34 = PHY_QueryBBReg(Adapter,0xB34, bMaskDWord)&0xFF;
-
-	if((pDM_Odm->SupportICType == ODM_RTL8192C)||(pDM_Odm->SupportICType == ODM_RTL8192D))
-       {
-            TH1 = RSSI_BT + 0x14;  
-	}
-
-	Smooth_size[0]=Smooth_Size_1;
-	Smooth_size[1]=Smooth_Size_2;
-	Smooth_size[2]=Smooth_Size_3;
-	Smooth_TH[0]=Smooth_TH_1;
-	Smooth_TH[1]=Smooth_TH_2;
-	Smooth_TH[2]=Smooth_TH_3;
-	Smooth_Interval[0]=16;
-	Smooth_Interval[1]=15;
-	Smooth_Interval[2]=13;
-	good_cnt = 0;
-	if(pDM_Odm->SupportICType==ODM_RTL8723A)
-	{
-		//2 Threshold  
-
-		if(RSSI_BT >=41)
-			TH1 = 113;	
-		else if(RSSI_BT >=38)   // >= -15dBm
-			TH1 = 105;                              //0x69
-		else if((RSSI_BT >=33)&(RSSI_BT <38))
-			TH1 = 99+(RSSI_BT-33);         //0x63
-		else if((RSSI_BT >=26)&(RSSI_BT<33))
-			TH1 = 99-(33-RSSI_BT)+2;     //0x5e
-	 	else if((RSSI_BT >=24)&(RSSI_BT<26))
-			TH1 = 88-((RSSI_BT-24)*3);   //0x58
-		else if((RSSI_BT >=18)&(RSSI_BT<24))
-			TH1 = 77+((RSSI_BT-18)*2);
-		else if((RSSI_BT >=14)&(RSSI_BT<18))
-			TH1 = 63+((RSSI_BT-14)*2);
-		else if((RSSI_BT >=8)&(RSSI_BT<14))
-			TH1 = 58+((RSSI_BT-8)*2);
-		else if((RSSI_BT >=3)&(RSSI_BT<8))
-			TH1 = 52+(RSSI_BT-3);
-		else
-			TH1 = 51;
-	}
-
-	for (i = 0; i< 10; i++)
-		PSD_bitmap[i] = 0;
-	
-
-	 // Add By Gary
-       for (i=0; i<80; i++)
-	   	pRX_HP_Table->PSD_bitmap_RXHP[i] = 0;
-	// End
-
-
-
-	if(pDM_Odm->SupportICType==ODM_RTL8723A)
-	{
-		TH1 =TH1-SIR_STEP_SIZE;
-	}
-	while (good_cnt < PSD_CHMIN)
-	{
-		good_cnt = 0;
-		if(pDM_Odm->SupportICType==ODM_RTL8723A)
-		{
-		if(TH1 ==TH2)
-			break;
-		if((TH1+SIR_STEP_SIZE) < TH2)
-			TH1 += SIR_STEP_SIZE;
-		else
-			TH1 = TH2;
-		}
-		else
-		{
-			if(TH1==(RSSI_BT+0x1E))
-             		     break;    
-   			if((TH1+2) < (RSSI_BT+0x1E))
-				TH1+=3;
-		     	else
-				TH1 = RSSI_BT+0x1E;	
-             
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD,DBG_LOUD,("PSD: decision threshold is: %d", TH1));
-			 
-		for (i = 0; i< 80; i++)
-		{
-			if((s4Byte)(PSD_report[i]) < TH1)
-			{
-				byte_idx = i / 8;
-				bit_idx = i -8*byte_idx;
-				bitmap = PSD_bitmap[byte_idx];
-				PSD_bitmap[byte_idx] = bitmap | (u1Byte) (1 << bit_idx);
-			}
-		}
-
-#if DBG
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD: before smoothing\n"));
-		for(n=0;n<10;n++)
-		{
-			//DbgPrint("PSD_bitmap[%u]=%x\n", n, PSD_bitmap[n]);
-			for (i = 0; i<8; i++)
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD_bitmap[%u] =   %d\n", 2402+n*8+i, (PSD_bitmap[n]&BIT(i))>>i));
-		}
-#endif
-	
-		//1 Start of smoothing function
-
-		for (j=0;j<3;j++)
-		{
-			start_byte_idx=0;
-			start_bit_idx=0;
-			for(n=0; n<Smooth_Interval[j]; n++)
-			{
-				good_cnt_smoothing = 0;
-				cur_bit_idx = start_bit_idx;
-				cur_byte_idx = start_byte_idx;
-				for ( i=0; i < Smooth_size[j]; i++)
-				{
-					NOW_byte_idx = cur_byte_idx + (i+cur_bit_idx)/8;
-					if ( (PSD_bitmap[NOW_byte_idx]& BIT( (cur_bit_idx + i)%8)) != 0)
-						good_cnt_smoothing++;
-
-				}
-
-				if( good_cnt_smoothing < Smooth_TH[j] )
-				{
-					cur_bit_idx = start_bit_idx;
-					cur_byte_idx = start_byte_idx;
-					for ( i=0; i< Smooth_size[j] ; i++)
-					{	
-						NOW_byte_idx = cur_byte_idx + (i+cur_bit_idx)/8;				
-						PSD_bitmap[NOW_byte_idx] = PSD_bitmap[NOW_byte_idx] & (~BIT( (cur_bit_idx + i)%8));
-					}
-				}
-				start_bit_idx =  start_bit_idx + Smooth_Step_Size;
-				while ( (start_bit_idx)  > 7 )
-				{
-					start_byte_idx= start_byte_idx+start_bit_idx/8;
-					start_bit_idx = start_bit_idx%8;
-				}
-			}
-
-			ODM_RT_TRACE(	pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD: after %u smoothing", j+1));
-			for(n=0;n<10;n++)
-			{
-				for (i = 0; i<8; i++)
-				{
-					ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD_bitmap[%u] =   %d\n", 2402+n*8+i, (PSD_bitmap[n]&BIT(i))>>i));
-					
-					if ( ((PSD_bitmap[n]&BIT(i))>>i) ==1)  //----- Add By Gary
-					{
-	                                   pRX_HP_Table->PSD_bitmap_RXHP[8*n+i] = 1;
-					}                                                  // ------end by Gary
-				}
-			}
-
-		}
-
-	
-		good_cnt = 0;
-		for ( i = 0; i < 10; i++)
-		{
-			for (n = 0; n < 8; n++)
-				if((PSD_bitmap[i]& BIT(n)) != 0)
-					good_cnt++;
-		}
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, ODM_COMP_PSD,("PSD: good channel cnt = %u",good_cnt));
-	}
-
-	//RT_TRACE(ODM_COMP_PSD, DBG_LOUD,("PSD: SSBT=%d, TH2=%d, TH1=%d",SSBT,TH2,TH1));
-	for (i = 0; i <10; i++)
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD: PSD_bitmap[%u]=%x",i,PSD_bitmap[i]));
-/*	
-	//Update bitmap memory
-	for(i = 0; i < 80; i++)
-	{
-		byte_idx = i / 8;
-		bit_idx = i -8*byte_idx;
-		psd_bit = (PSD_bitmap[byte_idx] & BIT(bit_idx)) >> bit_idx;
-		bitmap = PSD_bitmap_memory[i]; 
-		PSD_bitmap_memory[i] = (bitmap << 1) |psd_bit;
-	}
-*/
-}
-
-
-
-VOID
-odm_PSD_Monitor(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	//HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	//PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	unsigned int 		pts, start_point, stop_point;
-	u1Byte			initial_gain ;
-	static u1Byte		PSD_bitmap_memory[80], init_memory = 0;
-	static u1Byte 		psd_cnt=0;
-	static u4Byte		PSD_report[80], PSD_report_tmp;
-	static u8Byte		lastTxOkCnt=0, lastRxOkCnt=0;
-	u1Byte 			H2C_PSD_DATA[5]={0,0,0,0,0};
-	static u1Byte		H2C_PSD_DATA_last[5] ={0,0,0,0,0};
-	u1Byte			idx[20]={96,99,102,106,109,112,115,118,122,125,
-					0,3,6,10,13,16,19,22,26,29};
-	u1Byte			n, i, channel, BBReset,tone_idx;
-	u1Byte			PSD_bitmap[10], SSBT=0,initial_gain_psd=0, RSSI_BT=0, initialGainUpper;
-	s4Byte    			PSD_skip_start, PSD_skip_stop;
-	u4Byte			CurrentChannel, RXIQI, RxIdleLowPwr, wlan_channel;
-	u4Byte			ReScan, Interval, Is40MHz;
-	u8Byte			curTxOkCnt, curRxOkCnt;
-	int 				cur_byte_idx, cur_bit_idx;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	PMGNT_INFO      	pMgntInfo = &Adapter->MgntInfo;
-	
-
-	if(*pDM_Odm->pbDriverIsGoingToPnpSetPowerSleep)
- 	{
-  		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("pbDriverIsGoingToPnpSetPowerSleep!!!!!!!!!!!!!!!\n"));
-  		return;
- 	}
-
-	
-	if( (*(pDM_Odm->pbScanInProcess)) ||
-		pDM_Odm->bLinkInProcess)
-	{
-		if((pDM_Odm->SupportICType==ODM_RTL8723A)&(pDM_Odm->SupportInterface==ODM_ITRF_PCIE))
-		{
-			ODM_SetTimer( pDM_Odm, &pDM_Odm->PSDTimer, 1500); //ms	
-			//psd_cnt=0;
-		}
-		return;
-	}
-
-	if(pDM_Odm->bBtHsOperation)
-	{
-		ReScan = 1;
-		Interval = SCAN_INTERVAL;
-	}
-	else
-	{
-	ReScan = PSD_RESCAN;
-	Interval = SCAN_INTERVAL;
-	}
-
-	//1 Initialization
-	if(init_memory == 0)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("Init memory\n"));
-		for(i = 0; i < 80; i++)
-			PSD_bitmap_memory[i] = 0xFF; // channel is always good
-		init_memory = 1;
-	}
-	if(psd_cnt == 0)
-	{
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("Enter dm_PSD_Monitor\n"));
-		for(i = 0; i < 80; i++)
-			PSD_report[i] = 0;
-	}
-
-	//1 Backup Current Settings
-	CurrentChannel = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
-/*
-	if(pDM_Odm->SupportICType==ODM_RTL8192D)
-	{
-		//2 Record Current synthesizer parameters based on current channel
-		if((*pDM_Odm->MacPhyMode92D == SINGLEMAC_SINGLEPHY)||(*pDM_Odm->MacPhyMode92D == DUALMAC_SINGLEPHY))
-		{
-			SYN_RF25 = ODM_GetRFReg(Adapter, ODM_RF_PATH_B, 0x25, bMaskDWord);
-			SYN_RF26 = ODM_GetRFReg(Adapter, ODM_RF_PATH_B, 0x26, bMaskDWord);
-			SYN_RF27 = ODM_GetRFReg(Adapter, ODM_RF_PATH_B, 0x27, bMaskDWord);
-			SYN_RF2B = ODM_GetRFReg(Adapter, ODM_RF_PATH_B, 0x2B, bMaskDWord);
-			SYN_RF2C = ODM_GetRFReg(Adapter, ODM_RF_PATH_B, 0x2C, bMaskDWord);
-       	}
-		else     // DualMAC_DualPHY 2G
-		{
-			SYN_RF25 = ODM_GetRFReg(Adapter, ODM_RF_PATH_A, 0x25, bMaskDWord);
-			SYN_RF26 = ODM_GetRFReg(Adapter, ODM_RF_PATH_A, 0x26, bMaskDWord);
-			SYN_RF27 = ODM_GetRFReg(Adapter, ODM_RF_PATH_A, 0x27, bMaskDWord);
-			SYN_RF2B = ODM_GetRFReg(Adapter, ODM_RF_PATH_A, 0x2B, bMaskDWord);
-			SYN_RF2C = ODM_GetRFReg(Adapter, ODM_RF_PATH_A, 0x2C, bMaskDWord);
-		}
-	}
-*/
-	//RXIQI = PHY_QueryBBReg(Adapter, 0xC14, bMaskDWord);
-	RXIQI = ODM_GetBBReg(pDM_Odm, 0xC14, bMaskDWord);
-
-	//RxIdleLowPwr = (PHY_QueryBBReg(Adapter, 0x818, bMaskDWord)&BIT28)>>28;
-	RxIdleLowPwr = (ODM_GetBBReg(pDM_Odm, 0x818, bMaskDWord)&BIT28)>>28;
-
-	//2???
-	if(CHNL_RUN_ABOVE_40MHZ(pMgntInfo))
-		Is40MHz = TRUE;
-	else
-		Is40MHz = FALSE;
-
-	ODM_RT_TRACE(pDM_Odm,	ODM_COMP_PSD, DBG_LOUD,("PSD Scan Start\n"));
-	//1 Turn off CCK
-	//PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT24, 0);
-	ODM_SetBBReg(pDM_Odm, rFPGA0_RFMOD, BIT24, 0);
-	//1 Turn off TX
-	//Pause TX Queue
-	//PlatformEFIOWrite1Byte(Adapter, REG_TXPAUSE, 0xFF);
-	ODM_Write1Byte(pDM_Odm,REG_TXPAUSE, 0xFF);
-	
-	//Force RX to stop TX immediately
-	//PHY_SetRFReg(Adapter, ODM_RF_PATH_A, RF_AC, bRFRegOffsetMask, 0x32E13);
-
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_AC, bRFRegOffsetMask, 0x32E13);
-	//1 Turn off RX
-	//Rx AGC off  RegC70[0]=0, RegC7C[20]=0
-	//PHY_SetBBReg(Adapter, 0xC70, BIT0, 0);
-	//PHY_SetBBReg(Adapter, 0xC7C, BIT20, 0);
-
-	ODM_SetBBReg(pDM_Odm, 0xC70, BIT0, 0);
-	ODM_SetBBReg(pDM_Odm, 0xC7C, BIT20, 0);
-
-	
-	//Turn off CCA
-	//PHY_SetBBReg(Adapter, 0xC14, bMaskDWord, 0x0);
-	ODM_SetBBReg(pDM_Odm, 0xC14, bMaskDWord, 0x0);
-	
-	//BB Reset
-	//BBReset = PlatformEFIORead1Byte(Adapter, 0x02);
-	BBReset = ODM_Read1Byte(pDM_Odm, 0x02);
-	
-	//PlatformEFIOWrite1Byte(Adapter, 0x02, BBReset&(~BIT0));
-	//PlatformEFIOWrite1Byte(Adapter, 0x02, BBReset|BIT0);
-	ODM_SetBBReg(pDM_Odm, 0x87C, BIT31, 1); //clock gated to prevent from AGC table mess 
-	ODM_Write1Byte(pDM_Odm,  0x02, BBReset&(~BIT0));
-	ODM_Write1Byte(pDM_Odm,  0x02, BBReset|BIT0);
-	ODM_SetBBReg(pDM_Odm, 0x87C, BIT31, 0);
-	
-	//1 Leave RX idle low power
-	//PHY_SetBBReg(Adapter, 0x818, BIT28, 0x0);
-
-	ODM_SetBBReg(pDM_Odm, 0x818, BIT28, 0x0);
-	//1 Fix initial gain
-	//if (IS_HARDWARE_TYPE_8723AE(Adapter))
-	//RSSI_BT = pHalData->RSSI_BT;
-       //else if((IS_HARDWARE_TYPE_8192C(Adapter))||(IS_HARDWARE_TYPE_8192D(Adapter)))      // Add by Gary
-       //    RSSI_BT = RSSI_BT_new;
-
-	if((pDM_Odm->SupportICType==ODM_RTL8723A)&(pDM_Odm->SupportInterface==ODM_ITRF_PCIE))
-	RSSI_BT=pDM_Odm->RSSI_BT;		//need to check C2H to pDM_Odm RSSI BT
-
-	if(RSSI_BT>=47)
-		RSSI_BT=47;
-	   
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD: RSSI_BT= %d\n", RSSI_BT));
-	
-	if(pDM_Odm->SupportICType==ODM_RTL8723A)
-	{
-	       //Neil add--2011--10--12
-		//2 Initial Gain index 
-		if(RSSI_BT >=35)   // >= -15dBm
-			initial_gain_psd = RSSI_BT*2;
-		else if((RSSI_BT >=33)&(RSSI_BT<35))
-			initial_gain_psd = RSSI_BT*2+6;
-		else if((RSSI_BT >=24)&(RSSI_BT<33))
-			initial_gain_psd = 70-(33-RSSI_BT);
-	 	else if((RSSI_BT >=19)&(RSSI_BT<24))
-			initial_gain_psd = 64-((24-RSSI_BT)*4);
-		else if((RSSI_BT >=14)&(RSSI_BT<19))
-			initial_gain_psd = 44-((18-RSSI_BT)*2);
-		else if((RSSI_BT >=8)&(RSSI_BT<14))
-			initial_gain_psd = 35-(14-RSSI_BT);
-		else
-			initial_gain_psd = 0x1B;
-	}
-	else
-	{
-	
-		//need to do	
-         	initial_gain_psd = pDM_Odm->RSSI_Min;    // PSD report based on RSSI
-           	//}  	
-	}
-	//if(RSSI_BT<0x17)
-	//	RSSI_BT +=3;
-	//DbgPrint("PSD: RSSI_BT= %d\n", RSSI_BT);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD: RSSI_BT= %d\n", RSSI_BT));
-
-	//initialGainUpper = 0x5E;  //Modify by neil chen
-	
-	if(pDM_Odm->bUserAssignLevel)
-	{
-		pDM_Odm->bUserAssignLevel = FALSE;
-		initialGainUpper = 0x7f;
-	}
-	else
-	{
-		initialGainUpper = 0x5E;
-	}
-	
-	/*
-	if (initial_gain_psd < 0x1a)
-		initial_gain_psd = 0x1a;
-	if (initial_gain_psd > initialGainUpper)
-		initial_gain_psd = initialGainUpper;
-	*/
-
-	//if(pDM_Odm->SupportICType==ODM_RTL8723A)
-	SSBT = RSSI_BT  * 2 +0x3E;
-	
-	
-	//if(IS_HARDWARE_TYPE_8723AE(Adapter))
-	//	SSBT = RSSI_BT  * 2 +0x3E;
-	//else if((IS_HARDWARE_TYPE_8192C(Adapter))||(IS_HARDWARE_TYPE_8192D(Adapter)))   // Add by Gary
-	//{
-	//	RSSI_BT = initial_gain_psd;
-	//	SSBT = RSSI_BT;
-	//}
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD: SSBT= %d\n", SSBT));
-	ODM_RT_TRACE(	pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD: initial gain= 0x%x\n", initial_gain_psd));
-	//DbgPrint("PSD: SSBT= %d", SSBT);
-	//need to do
-	pDM_Odm->bDMInitialGainEnable = FALSE;
-	initial_gain =(u1Byte) (ODM_GetBBReg(pDM_Odm, 0xc50, bMaskDWord) & 0x7F);
-	
-        // make sure the initial gain is under the correct range.
-	//initial_gain_psd &= 0x7f;
-	ODM_Write_DIG(pDM_Odm, initial_gain_psd);
-	//1 Turn off 3-wire
-	ODM_SetBBReg(pDM_Odm, 0x88c, BIT20|BIT21|BIT22|BIT23, 0xF);
-
-	//pts value = 128, 256, 512, 1024
-	pts = 128;
-
-	if(pts == 128)
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x0);
-		start_point = 64;
-		stop_point = 192;
-	}
-	else if(pts == 256)
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x1);
-		start_point = 128;
-		stop_point = 384;
-	}
-	else if(pts == 512)
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x2);
-		start_point = 256;
-		stop_point = 768;
-	}
-	else
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x3);
-		start_point = 512;
-		stop_point = 1536;
-	}
-	
-
-//3 Skip WLAN channels if WLAN busy
-
-	curTxOkCnt = *(pDM_Odm->pNumTxBytesUnicast) - lastTxOkCnt;
-	curRxOkCnt = *(pDM_Odm->pNumRxBytesUnicast) - lastRxOkCnt;
-	lastTxOkCnt = *(pDM_Odm->pNumTxBytesUnicast);
-	lastRxOkCnt = *(pDM_Odm->pNumRxBytesUnicast);	
-
-	PSD_skip_start=80;
-	PSD_skip_stop = 0;
-	wlan_channel = CurrentChannel & 0x0f;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD,DBG_LOUD,("PSD: current channel: %x, BW:%d \n", wlan_channel, Is40MHz));
-	if(pDM_Odm->SupportICType==ODM_RTL8723A)
-	{
-		if(pDM_Odm->bBtHsOperation)
-		{
-			if(pDM_Odm->bLinked)
-			{
-				if(Is40MHz)
-				{
-					PSD_skip_start = ((wlan_channel-1)*5 -Is40MHz*10)-2;  // Modify by Neil to add 10 chs to mask
-					PSD_skip_stop = (PSD_skip_start + (1+Is40MHz)*20)+4;
-				}
-				else
-				{
-					PSD_skip_start = ((wlan_channel-1)*5 -Is40MHz*10)-10;  // Modify by Neil to add 10 chs to mask
-					PSD_skip_stop = (PSD_skip_start + (1+Is40MHz)*20)+18; 
-				}
-			}
-			else
-			{
-				// mask for 40MHz
-				PSD_skip_start = ((wlan_channel-1)*5 -Is40MHz*10)-2;  // Modify by Neil to add 10 chs to mask
-				PSD_skip_stop = (PSD_skip_start + (1+Is40MHz)*20)+4;
-			}
-			if(PSD_skip_start < 0)
-				PSD_skip_start = 0;
-			if(PSD_skip_stop >80)
-				PSD_skip_stop = 80;
-		}
-		else
-		{
-			if((curRxOkCnt+curTxOkCnt) > 5)
-			{
-				if(Is40MHz)
-				{
-					PSD_skip_start = ((wlan_channel-1)*5 -Is40MHz*10)-2;  // Modify by Neil to add 10 chs to mask
-					PSD_skip_stop = (PSD_skip_start + (1+Is40MHz)*20)+4;
-				}
-				else
-				{
-					PSD_skip_start = ((wlan_channel-1)*5 -Is40MHz*10)-10;  // Modify by Neil to add 10 chs to mask
-					PSD_skip_stop = (PSD_skip_start + (1+Is40MHz)*20)+18; 
-				}
-				
-				if(PSD_skip_start < 0)
-					PSD_skip_start = 0;
-				if(PSD_skip_stop >80)
-					PSD_skip_stop = 80;
-			}
-		}
-	}
-#if 0	
-	else
-	{
-		if((curRxOkCnt+curTxOkCnt) > 1000)
-		{
-			PSD_skip_start = (wlan_channel-1)*5 -Is40MHz*10;
-			PSD_skip_stop = PSD_skip_start + (1+Is40MHz)*20;
-		}
-	}   
-#endif  //Reove RXHP Issue
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD,DBG_LOUD,("PSD: Skip tone from %d to %d \n", PSD_skip_start, PSD_skip_stop));
-
- 	for (n=0;n<80;n++)
- 	{
- 		if((n%20)==0)
- 		{
-			channel = (n/20)*4 + 1;
-					
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x3FF, channel);
-				}
-		tone_idx = n%20;
-		if ((n>=PSD_skip_start) && (n<PSD_skip_stop))
-		{	
-			PSD_report[n] = SSBT;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD,DBG_LOUD,("PSD:Tone %d skipped \n", n));
-		}
-		else
-		{
-			PSD_report_tmp =  GetPSDData(pDM_Odm, idx[tone_idx], initial_gain_psd);
-
-			if ( PSD_report_tmp > PSD_report[n])
-				PSD_report[n] = PSD_report_tmp;
-				
-		}
-	}
-
-	PatchDCTone(pDM_Odm, PSD_report, initial_gain_psd);
-      
-       //----end
-	//1 Turn on RX
-	//Rx AGC on
-	ODM_SetBBReg(pDM_Odm, 0xC70, BIT0, 1);
-	ODM_SetBBReg(pDM_Odm, 0xC7C, BIT20, 1);
-	//CCK on
-	ODM_SetBBReg(pDM_Odm, rFPGA0_RFMOD, BIT24, 1);
-	//1 Turn on TX
-	//Resume TX Queue
-	
-	ODM_Write1Byte(pDM_Odm,REG_TXPAUSE, 0x00);
-	//Turn on 3-wire
-	ODM_SetBBReg(pDM_Odm, 0x88c, BIT20|BIT21|BIT22|BIT23, 0x0);
-	//1 Restore Current Settings
-	//Resume DIG
-	pDM_Odm->bDMInitialGainEnable = TRUE;
-	
-	ODM_Write_DIG(pDM_Odm, initial_gain);
-
-	// restore originl center frequency
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask, CurrentChannel);
-
-	//Turn on CCA
-	ODM_SetBBReg(pDM_Odm, 0xC14, bMaskDWord, RXIQI);
-	//Restore RX idle low power
-	if(RxIdleLowPwr == TRUE)
-		ODM_SetBBReg(pDM_Odm, 0x818, BIT28, 1);
-	
-	psd_cnt++;
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD:psd_cnt = %d \n",psd_cnt));
-	if (psd_cnt < ReScan)
-		ODM_SetTimer(pDM_Odm, &pDM_Odm->PSDTimer, Interval);		
-	else
-	{
-		psd_cnt = 0;
-		for(i=0;i<80;i++)
-			//DbgPrint("psd_report[%d]=     %d \n", 2402+i, PSD_report[i]);
-			RT_TRACE(	ODM_COMP_PSD, DBG_LOUD,("psd_report[%d]=     %d \n", 2402+i, PSD_report[i]));
-
-
-		GoodChannelDecision(pDM_Odm, PSD_report, PSD_bitmap,RSSI_BT, PSD_bitmap_memory);
-
-		if(pDM_Odm->SupportICType==ODM_RTL8723A)
-		{
-			cur_byte_idx=0;
-			cur_bit_idx=0;
-
-			//2 Restore H2C PSD Data to Last Data
-		  	H2C_PSD_DATA_last[0] = H2C_PSD_DATA[0];
-			H2C_PSD_DATA_last[1] = H2C_PSD_DATA[1];
-			H2C_PSD_DATA_last[2] = H2C_PSD_DATA[2];
-			H2C_PSD_DATA_last[3] = H2C_PSD_DATA[3];
-			H2C_PSD_DATA_last[4] = H2C_PSD_DATA[4];
-
-	
-			//2 Translate 80bit channel map to 40bit channel	
-			for ( i=0;i<5;i++)
-			{
-				for(n=0;n<8;n++)
-				{
-					cur_byte_idx = i*2 + n/4;
-					cur_bit_idx = (n%4)*2;
-					if ( ((PSD_bitmap[cur_byte_idx]& BIT(cur_bit_idx)) != 0) && ((PSD_bitmap[cur_byte_idx]& BIT(cur_bit_idx+1)) != 0))
-						H2C_PSD_DATA[i] = H2C_PSD_DATA[i] | (u1Byte) (1 << n);
-				}
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("H2C_PSD_DATA[%d]=0x%x\n" ,i, H2C_PSD_DATA[i]));
-			}
-	
-			//3 To Compare the difference
-			for ( i=0;i<5;i++)
-			{
-				if(H2C_PSD_DATA[i] !=H2C_PSD_DATA_last[i])
-				{
-					FillH2CCmd92C(Adapter, H2C_92C_PSD_RESULT, 5, H2C_PSD_DATA);
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_PSD, DBG_LOUD,("Need to Update the AFH Map \n"));
-					break;
-				}
-				else
-				{
-					if(i==5)
-						ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("Not need to Update\n"));	
-				}
-			}
-			if(pDM_Odm->bBtHsOperation)
-			{
-				ODM_SetTimer(pDM_Odm, &pDM_Odm->PSDTimer, 10000);
-				ODM_RT_TRACE(	pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("Leave dm_PSD_Monitor\n"));		
-			}
-			else
-			{
-				ODM_SetTimer(pDM_Odm, &pDM_Odm->PSDTimer, 1500);
-				ODM_RT_TRACE(	pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("Leave dm_PSD_Monitor\n"));		
-		}
-	}
-    }
-}
-/*
-//Neil for Get BT RSSI
-// Be Triggered by BT C2H CMD
-VOID
-ODM_PSDGetRSSI(
-	IN	u1Byte	RSSI_BT)
-{
-
-
-}
-
-*/
-
-VOID
-ODM_PSDMonitor(
-	IN		PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	//HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	
-	//if(IS_HARDWARE_TYPE_8723AE(Adapter))
-	
-	if(pDM_Odm->SupportICType == ODM_RTL8723A)   //may need to add other IC type
-	{
-		if(pDM_Odm->SupportInterface==ODM_ITRF_PCIE)
-		{
-			if(!pDM_Odm->bBtEnabled) //need to check upper layer connection
-			{
-				pDM_Odm->bPSDactive=FALSE;
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD, ("odm_PSDMonitor, return for BT is disabled!!!\n"));
-		   		return; 
-			}
-
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD, ("odm_PSDMonitor\n"));
-		//{
-			pDM_Odm->bPSDinProcess = TRUE;
-	 		pDM_Odm->bPSDactive=TRUE;
-			odm_PSD_Monitor(pDM_Odm);
-			pDM_Odm->bPSDinProcess = FALSE;
-		}	
-	}	
-
-}
-VOID
-odm_PSDMonitorCallback(
-	PRT_TIMER		pTimer
-)
-{
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-       HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-
-	PlatformScheduleWorkItem(&pHalData->PSDMonitorWorkitem);
-}
-
-VOID
-odm_PSDMonitorWorkItemCallback(
-    IN PVOID            pContext
-    )
-{
-	PADAPTER	Adapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	ODM_PSDMonitor(pDM_Odm);
-}
-
-
- //cosa debug tool need to modify
-
-VOID
-ODM_PSDDbgControl(
-	IN	PADAPTER	Adapter,
-	IN	u4Byte		mode,
-	IN	u4Byte		btRssi
-	)
-{
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD, (" Monitor mode=%d, btRssi=%d\n", mode, btRssi));
-	if(mode)
-	{
-		pDM_Odm->RSSI_BT = (u1Byte)btRssi;
-		pDM_Odm->bUserAssignLevel = TRUE;
-		ODM_SetTimer( pDM_Odm, &pDM_Odm->PSDTimer, 0); //ms		
-	}
-	else
-	{
-		ODM_CancelTimer(pDM_Odm, &pDM_Odm->PSDTimer);
-	}
-#endif
-}
-
-
-//#if(DEV_BUS_TYPE == RT_PCI_INTERFACE)|(DEV_BUS_TYPE == RT_USB_INTERFACE)
-
-void	odm_RXHPInit(
-	IN		PVOID			pDM_VOID)
-{
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)|(DEV_BUS_TYPE == RT_USB_INTERFACE)
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRXHP_T			pRX_HP_Table  = &pDM_Odm->DM_RXHP_Table;
-   	u1Byte			index;
-
-	pRX_HP_Table->RXHP_enable = TRUE;
-	pRX_HP_Table->RXHP_flag = 0;
-	pRX_HP_Table->PSD_func_trigger = 0;
-	pRX_HP_Table->Pre_IGI = 0x20;
-	pRX_HP_Table->Cur_IGI = 0x20;
-	pRX_HP_Table->Cur_pw_th = pw_th_10dB;
-	pRX_HP_Table->Pre_pw_th = pw_th_10dB;
-	for(index=0; index<80; index++)
-		pRX_HP_Table->PSD_bitmap_RXHP[index] = 1;
-
-#if(DEV_BUS_TYPE == RT_USB_INTERFACE)
-	pRX_HP_Table->TP_Mode = Idle_Mode;
-#endif
-#endif
-}
-
-VOID
-odm_PSD_RXHP(
-	IN		PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRXHP_T			pRX_HP_Table  = &pDM_Odm->DM_RXHP_Table;
-	PADAPTER		Adapter =  pDM_Odm->Adapter;
-	PMGNT_INFO		pMgntInfo = &(Adapter->MgntInfo);
-	unsigned int 		pts, start_point, stop_point, initial_gain ;
-	static u1Byte		PSD_bitmap_memory[80], init_memory = 0;
-	static u1Byte 		psd_cnt=0;
-	static u4Byte		PSD_report[80], PSD_report_tmp;
-	static u8Byte		lastTxOkCnt=0, lastRxOkCnt=0;
-	u1Byte			idx[20]={96,99,102,106,109,112,115,118,122,125,
-					0,3,6,10,13,16,19,22,26,29};
-	u1Byte			n, i, channel, BBReset,tone_idx;
-	u1Byte			PSD_bitmap[10]/*, SSBT=0*/,initial_gain_psd=0, RSSI_BT=0, initialGainUpper;
-	s4Byte    			PSD_skip_start, PSD_skip_stop;
-	u4Byte			CurrentChannel, RXIQI, RxIdleLowPwr, wlan_channel;
-	u4Byte			ReScan, Interval, Is40MHz;
-	u8Byte			curTxOkCnt, curRxOkCnt;
-	//--------------2G band synthesizer for 92D switch RF channel using----------------- 
-	u1Byte			group_idx=0;
-	u4Byte			SYN_RF25=0, SYN_RF26=0, SYN_RF27=0, SYN_RF2B=0, SYN_RF2C=0;
-	u4Byte			SYN[5] = {0x25, 0x26, 0x27, 0x2B, 0x2C};    // synthesizer RF register for 2G channel
-	u4Byte			SYN_group[3][5] = {{0x643BC, 0xFC038, 0x77C1A, 0x41289, 0x01840},     // For CH1,2,4,9,10.11.12   {0x643BC, 0xFC038, 0x77C1A, 0x41289, 0x01840}
-									    {0x643BC, 0xFC038, 0x07C1A, 0x41289, 0x01840},     // For CH3,13,14
-									    {0x243BC, 0xFC438, 0x07C1A, 0x4128B, 0x0FC41}};   // For Ch5,6,7,8
-       //--------------------- Add by Gary for Debug setting ----------------------
-  	u1Byte                 RSSI_BT_new = (u1Byte) ODM_GetBBReg(pDM_Odm, 0xB9C, 0xFF);
-       u1Byte                 rssi_ctrl = (u1Byte) ODM_GetBBReg(pDM_Odm, 0xB38, 0xFF);
-       //---------------------------------------------------------------------
-	
-	if(pMgntInfo->bScanInProgress)
-	{
-		return;
-	}
-
-	ReScan = PSD_RESCAN;
-	Interval = SCAN_INTERVAL;
-
-
-	//1 Initialization
-	if(init_memory == 0)
-	{
-		RT_TRACE(	ODM_COMP_PSD, DBG_LOUD,("Init memory\n"));
-		for(i = 0; i < 80; i++)
-			PSD_bitmap_memory[i] = 0xFF; // channel is always good
-		init_memory = 1;
-	}
-	if(psd_cnt == 0)
-	{
-		RT_TRACE(ODM_COMP_PSD, DBG_LOUD,("Enter dm_PSD_Monitor\n"));
-		for(i = 0; i < 80; i++)
-			PSD_report[i] = 0;
-	}
-
-	//1 Backup Current Settings
-	CurrentChannel = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
-	if(pDM_Odm->SupportICType == ODM_RTL8192D)
-	{
-		//2 Record Current synthesizer parameters based on current channel
-		if((*(pDM_Odm->pMacPhyMode)==ODM_SMSP)||(*(pDM_Odm->pMacPhyMode)==ODM_DMSP))
-		{
-			SYN_RF25 = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x25, bMaskDWord);
-			SYN_RF26 = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x26, bMaskDWord);
-			SYN_RF27 = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x27, bMaskDWord);
-			SYN_RF2B = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x2B, bMaskDWord);
-			SYN_RF2C = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x2C, bMaskDWord);
-       	}
-		else     // DualMAC_DualPHY 2G
-		{
-			SYN_RF25 = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x25, bMaskDWord);
-			SYN_RF26 = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x26, bMaskDWord);
-			SYN_RF27 = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x27, bMaskDWord);
-			SYN_RF2B = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x2B, bMaskDWord);
-			SYN_RF2C = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x2C, bMaskDWord);
-		}
-	}
-	RXIQI = ODM_GetBBReg(pDM_Odm, 0xC14, bMaskDWord);
-	RxIdleLowPwr = (ODM_GetBBReg(pDM_Odm, 0x818, bMaskDWord)&BIT28)>>28;
-	Is40MHz = *(pDM_Odm->pBandWidth);
-	ODM_RT_TRACE(pDM_Odm,	ODM_COMP_PSD, DBG_LOUD,("PSD Scan Start\n"));
-	//1 Turn off CCK
-	ODM_SetBBReg(pDM_Odm, rFPGA0_RFMOD, BIT24, 0);
-	//1 Turn off TX
-	//Pause TX Queue
-	ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0xFF);
-	//Force RX to stop TX immediately
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_AC, bRFRegOffsetMask, 0x32E13);
-	//1 Turn off RX
-	//Rx AGC off  RegC70[0]=0, RegC7C[20]=0
-	ODM_SetBBReg(pDM_Odm, 0xC70, BIT0, 0);
-	ODM_SetBBReg(pDM_Odm, 0xC7C, BIT20, 0);
-	//Turn off CCA
-	ODM_SetBBReg(pDM_Odm, 0xC14, bMaskDWord, 0x0);
-	//BB Reset
-	ODM_SetBBReg(pDM_Odm, 0x87C, BIT31, 1); //clock gated to prevent from AGC table mess 
-	BBReset = ODM_Read1Byte(pDM_Odm, 0x02);
-	ODM_Write1Byte(pDM_Odm, 0x02, BBReset&(~BIT0));
-	ODM_Write1Byte(pDM_Odm, 0x02, BBReset|BIT0);
-	ODM_SetBBReg(pDM_Odm, 0x87C, BIT31, 0);
-	//1 Leave RX idle low power
-	ODM_SetBBReg(pDM_Odm, 0x818, BIT28, 0x0);
-	//1 Fix initial gain
-      	RSSI_BT = RSSI_BT_new;
-	RT_TRACE(ODM_COMP_PSD, DBG_LOUD,("PSD: RSSI_BT= %d\n", RSSI_BT));
-	
-	if(rssi_ctrl == 1)        // just for debug!!
-		initial_gain_psd = RSSI_BT_new; 
-     	else
-		initial_gain_psd = pDM_Odm->RSSI_Min;    // PSD report based on RSSI
-	
-	RT_TRACE(ODM_COMP_PSD, DBG_LOUD,("PSD: RSSI_BT= %d\n", RSSI_BT));
-	
-	initialGainUpper = 0x54;
-	
-	RSSI_BT = initial_gain_psd;
-	//SSBT = RSSI_BT;
-	
-	//RT_TRACE(	ODM_COMP_PSD, DBG_LOUD,("PSD: SSBT= %d\n", SSBT));
-	RT_TRACE(	ODM_COMP_PSD, DBG_LOUD,("PSD: initial gain= 0x%x\n", initial_gain_psd));
-	
-	pDM_Odm->bDMInitialGainEnable = FALSE;		
-	initial_gain = ODM_GetBBReg(pDM_Odm, 0xc50, bMaskDWord) & 0x7F;
-	//ODM_SetBBReg(pDM_Odm, 0xc50, 0x7F, initial_gain_psd);	
-	ODM_Write_DIG(pDM_Odm, initial_gain_psd);
-	//1 Turn off 3-wire
-	ODM_SetBBReg(pDM_Odm, 0x88c, BIT20|BIT21|BIT22|BIT23, 0xF);
-
-	//pts value = 128, 256, 512, 1024
-	pts = 128;
-
-	if(pts == 128)
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x0);
-		start_point = 64;
-		stop_point = 192;
-	}
-	else if(pts == 256)
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x1);
-		start_point = 128;
-		stop_point = 384;
-	}
-	else if(pts == 512)
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x2);
-		start_point = 256;
-		stop_point = 768;
-	}
-	else
-	{
-		ODM_SetBBReg(pDM_Odm, 0x808, BIT14|BIT15, 0x3);
-		start_point = 512;
-		stop_point = 1536;
-	}
-	
-
-//3 Skip WLAN channels if WLAN busy
-	curTxOkCnt = *(pDM_Odm->pNumTxBytesUnicast) - lastTxOkCnt;
-	curRxOkCnt = *(pDM_Odm->pNumRxBytesUnicast) - lastRxOkCnt;
-	lastTxOkCnt = *(pDM_Odm->pNumTxBytesUnicast);
-	lastRxOkCnt = *(pDM_Odm->pNumRxBytesUnicast);
-	
-	PSD_skip_start=80;
-	PSD_skip_stop = 0;
-	wlan_channel = CurrentChannel & 0x0f;
-
-	RT_TRACE(ODM_COMP_PSD,DBG_LOUD,("PSD: current channel: %x, BW:%d \n", wlan_channel, Is40MHz));
-	
-	if((curRxOkCnt+curTxOkCnt) > 1000)
-	{
-		PSD_skip_start = (wlan_channel-1)*5 -Is40MHz*10;
-		PSD_skip_stop = PSD_skip_start + (1+Is40MHz)*20;
-	}
-
-	RT_TRACE(ODM_COMP_PSD,DBG_LOUD,("PSD: Skip tone from %d to %d \n", PSD_skip_start, PSD_skip_stop));
-
- 	for (n=0;n<80;n++)
- 	{
- 		if((n%20)==0)
- 		{
-			channel = (n/20)*4 + 1;
-			if(pDM_Odm->SupportICType == ODM_RTL8192D)
-			{
-				switch(channel)
-				{
-					case 1: 
-					case 9:
-						group_idx = 0;
-						break;
-					case 5:
-						group_idx = 2;
-						break;
-					case 13:
-				 		group_idx = 1;
-						break;
-				}
-				if((*(pDM_Odm->pMacPhyMode)==ODM_SMSP)||(*(pDM_Odm->pMacPhyMode)==ODM_DMSP))   
-		{
-					for(i = 0; i < SYN_Length; i++)
-						ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, SYN[i], bMaskDWord, SYN_group[group_idx][i]);
-
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x3FF, channel);
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_CHNLBW, 0x3FF, channel);
-				}
-				else  // DualMAC_DualPHY 2G
-			{
-					for(i = 0; i < SYN_Length; i++)
-						ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, SYN[i], bMaskDWord, SYN_group[group_idx][i]);   
-					
-					ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x3FF, channel);
-				}
-			}
-			else
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x3FF, channel);
-			}	
-		tone_idx = n%20;
-		if ((n>=PSD_skip_start) && (n<PSD_skip_stop))
-		{	
-			PSD_report[n] = initial_gain_psd;//SSBT;
-			ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD,DBG_LOUD,("PSD:Tone %d skipped \n", n));
-		}
-		else
-		{
-			PSD_report_tmp =  GetPSDData(pDM_Odm, idx[tone_idx], initial_gain_psd);
-
-			if ( PSD_report_tmp > PSD_report[n])
-				PSD_report[n] = PSD_report_tmp;
-				
-		}
-	}
-
-	PatchDCTone(pDM_Odm, PSD_report, initial_gain_psd);
-      
-       //----end
-	//1 Turn on RX
-	//Rx AGC on
-	ODM_SetBBReg(pDM_Odm, 0xC70, BIT0, 1);
-	ODM_SetBBReg(pDM_Odm, 0xC7C, BIT20, 1);
-	//CCK on
-	ODM_SetBBReg(pDM_Odm, rFPGA0_RFMOD, BIT24, 1);
-	//1 Turn on TX
-	//Resume TX Queue
-	ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0x00);
-	//Turn on 3-wire
-	ODM_SetBBReg(pDM_Odm, 0x88c, BIT20|BIT21|BIT22|BIT23, 0x0);
-	//1 Restore Current Settings
-	//Resume DIG
-	pDM_Odm->bDMInitialGainEnable= TRUE;
-	//ODM_SetBBReg(pDM_Odm, 0xc50, 0x7F, initial_gain);
-	ODM_Write_DIG(pDM_Odm,(u1Byte) initial_gain);
-	// restore originl center frequency
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask, CurrentChannel);
-	if(pDM_Odm->SupportICType == ODM_RTL8192D)
-	{
-		if((*(pDM_Odm->pMacPhyMode)==ODM_SMSP)||(*(pDM_Odm->pMacPhyMode)==ODM_DMSP))
-		{
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_CHNLBW, bMaskDWord, CurrentChannel);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x25, bMaskDWord, SYN_RF25);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x26, bMaskDWord, SYN_RF26);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x27, bMaskDWord, SYN_RF27);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x2B, bMaskDWord, SYN_RF2B);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x2C, bMaskDWord, SYN_RF2C);
-		}
-		else     // DualMAC_DualPHY
-		{
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x25, bMaskDWord, SYN_RF25);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x26, bMaskDWord, SYN_RF26);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x27, bMaskDWord, SYN_RF27);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x2B, bMaskDWord, SYN_RF2B);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x2C, bMaskDWord, SYN_RF2C);
-		}
-	}
-	//Turn on CCA
-	ODM_SetBBReg(pDM_Odm, 0xC14, bMaskDWord, RXIQI);
-	//Restore RX idle low power
-	if(RxIdleLowPwr == TRUE)
-		ODM_SetBBReg(pDM_Odm, 0x818, BIT28, 1);
-	
-	psd_cnt++;
-	//gPrint("psd cnt=%d\n", psd_cnt);
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_PSD, DBG_LOUD,("PSD:psd_cnt = %d \n",psd_cnt));
-	if (psd_cnt < ReScan)
-	{
-		ODM_SetTimer(pDM_Odm, &pRX_HP_Table->PSDTimer, Interval);  //ms
-	}
-	else
-	{	
-		psd_cnt = 0;
-		for(i=0;i<80;i++)
-			RT_TRACE(	ODM_COMP_PSD, DBG_LOUD,("psd_report[%d]=     %d \n", 2402+i, PSD_report[i]));
-			//DbgPrint("psd_report[%d]=     %d \n", 2402+i, PSD_report[i]);
-
-		GoodChannelDecision(pDM_Odm, PSD_report, PSD_bitmap,RSSI_BT, PSD_bitmap_memory);
-
-	}
-}
-
-void odm_Write_RXHP(
-	IN		PVOID			pDM_VOID)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	pRXHP_T		pRX_HP_Table = &pDM_Odm->DM_RXHP_Table;
-	u4Byte		currentIGI;
-
-	if(pRX_HP_Table->Cur_IGI != pRX_HP_Table->Pre_IGI)
-	{
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskByte0, pRX_HP_Table->Cur_IGI);
-	     	ODM_SetBBReg(pDM_Odm, rOFDM0_XBAGCCore1, bMaskByte0, pRX_HP_Table->Cur_IGI);	
-	}
-	
-	if(pRX_HP_Table->Cur_pw_th != pRX_HP_Table->Pre_pw_th)
-{
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XAAGCCore2, BIT8|BIT9, pRX_HP_Table->Cur_pw_th);  // RegC54[9:8]=2'b11:  AGC Flow 3
-	}
-
-	if(pRX_HP_Table->RXHP_flag == 0)
-	{
-		pRX_HP_Table->Cur_IGI = 0x20;
-	}
-	else
-	{
-		currentIGI = ODM_GetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskByte0);
-		if(currentIGI<0x50)
-		{
-			ODM_SetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskByte0, pRX_HP_Table->Cur_IGI);
-	     		ODM_SetBBReg(pDM_Odm, rOFDM0_XBAGCCore1, bMaskByte0, pRX_HP_Table->Cur_IGI);	
-		}
-	}
-	pRX_HP_Table->Pre_IGI = pRX_HP_Table->Cur_IGI;
-	pRX_HP_Table->Pre_pw_th = pRX_HP_Table->Cur_pw_th;
-
-}
-
-
-void odm_RXHP(
-	IN		PVOID			pDM_VOID)
-{
-#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE) | (DEV_BUS_TYPE == RT_USB_INTERFACE)
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER	Adapter =  pDM_Odm->Adapter;
-	PMGNT_INFO	pMgntInfo = &(Adapter->MgntInfo);
-	pDIG_T		pDM_DigTable = &pDM_Odm->DM_DigTable;
-	pRXHP_T		pRX_HP_Table  = &pDM_Odm->DM_RXHP_Table;
-	PFALSE_ALARM_STATISTICS		FalseAlmCnt = (PFALSE_ALARM_STATISTICS)PhyDM_Get_Structure(pDM_Odm, PHYDM_FALSEALMCNT);
-	
-	u1Byte              	i, j, sum;
-	u1Byte			Is40MHz;
-	s1Byte              	Intf_diff_idx, MIN_Intf_diff_idx = 16;   
-       s4Byte              	cur_channel;    
-       u1Byte              	ch_map_intf_5M[17] = {0};     
-       static u4Byte		FA_TH = 0;	
-	static u1Byte      	psd_intf_flag = 0;
-	static s4Byte      	curRssi = 0;                
-       static s4Byte  		preRssi = 0;                                                                
-	static u1Byte		PSDTriggerCnt = 1;
-	
-	u1Byte			RX_HP_enable = (u1Byte)(ODM_GetBBReg(pDM_Odm, rOFDM0_XAAGCCore2, bMaskDWord)>>31);   // for debug!!
-
-#if(DEV_BUS_TYPE == RT_USB_INTERFACE)	
-	static s8Byte  		lastTxOkCnt = 0, lastRxOkCnt = 0;  
-       s8Byte			curTxOkCnt, curRxOkCnt;
-	s8Byte			curTPOkCnt;
-	s8Byte			TP_Acc3, TP_Acc5;
-	static s8Byte		TP_Buff[5] = {0};
-	static u1Byte		pre_state = 0, pre_state_flag = 0;
-	static u1Byte		Intf_HighTP_flag = 0, De_counter = 16; 
-	static u1Byte		TP_Degrade_flag = 0;
-#endif	   
-	static u1Byte		LatchCnt = 0;
-	
-	if(pDM_Odm->SupportICType & (ODM_RTL8723A|ODM_RTL8188E))
-		return;
-	//AGC RX High Power Mode is only applied on 2G band in 92D!!!
-	if(pDM_Odm->SupportICType == ODM_RTL8192D)
-	{
-		if(*(pDM_Odm->pBandType) != ODM_BAND_2_4G)
-			return;
-	}
-
-	if(!(pDM_Odm->SupportAbility & ODM_BB_RXHP))
-		return;
-
-
-	//RX HP ON/OFF
-	if(RX_HP_enable == 1)
-		pRX_HP_Table->RXHP_enable = FALSE;
-	else
-		pRX_HP_Table->RXHP_enable = TRUE;
-
-	if(pRX_HP_Table->RXHP_enable == FALSE)
-	{
-		if(pRX_HP_Table->RXHP_flag == 1)
-		{
-			pRX_HP_Table->RXHP_flag = 0;
-			psd_intf_flag = 0;
-		}
-		return;
-	}
-
-#if(DEV_BUS_TYPE == RT_USB_INTERFACE)	
-	//2 Record current TP for USB interface
-	curTxOkCnt = *(pDM_Odm->pNumTxBytesUnicast)-lastTxOkCnt;
-	curRxOkCnt = *(pDM_Odm->pNumRxBytesUnicast)-lastRxOkCnt;
-	lastTxOkCnt = *(pDM_Odm->pNumTxBytesUnicast);
-	lastRxOkCnt = *(pDM_Odm->pNumRxBytesUnicast);
-
-	curTPOkCnt = curTxOkCnt+curRxOkCnt;
-	TP_Buff[0] = curTPOkCnt;    // current TP  
-	TP_Acc3 = PlatformDivision64((TP_Buff[1]+TP_Buff[2]+TP_Buff[3]), 3);
-	TP_Acc5 = PlatformDivision64((TP_Buff[0]+TP_Buff[1]+TP_Buff[2]+TP_Buff[3]+TP_Buff[4]), 5);
-	
-	if(TP_Acc5 < 1000)
-		pRX_HP_Table->TP_Mode = Idle_Mode;
-	else if((1000 < TP_Acc5)&&(TP_Acc5 < 3750000))
-		pRX_HP_Table->TP_Mode = Low_TP_Mode;
-	else
-		pRX_HP_Table->TP_Mode = High_TP_Mode;
-
-	ODM_RT_TRACE(pDM_Odm, 	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RX HP TP Mode = %d\n", pRX_HP_Table->TP_Mode));
-	// Since TP result would be sampled every 2 sec, it needs to delay 4sec to wait PSD processing.
-	// When LatchCnt = 0, we would Get PSD result.
-	if(TP_Degrade_flag == 1)
-	{
-		LatchCnt--;
-		if(LatchCnt == 0)
-		{
-			TP_Degrade_flag = 0;
-		}
-	}
-	// When PSD function triggered by TP degrade 20%, and Interference Flag = 1
-	// Set a De_counter to wait IGI = upper bound. If time is UP, the Interference flag will be pull down.
-	if(Intf_HighTP_flag == 1)
-	{
-		De_counter--;
-		if(De_counter == 0)
-		{
-			Intf_HighTP_flag = 0;
-			psd_intf_flag = 0;
-		}
-	}
-#endif
-
-	//2 AGC RX High Power Mode by PSD only applied to STA Mode
-	//3 NOT applied 1. Ad Hoc Mode.
-	//3 NOT applied 2. AP Mode
-	if ((pMgntInfo->mAssoc) && (!pMgntInfo->mIbss) && (!ACTING_AS_AP(Adapter)))
-	{    
-		Is40MHz = *(pDM_Odm->pBandWidth);
-		curRssi = pDM_Odm->RSSI_Min;
-		cur_channel = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x0fff) & 0x0f;
-
-		/* check illegal channel and bandwidth */
-		if (Is40MHz && ((cur_channel < 3) || (cur_channel > 12))) {
-			ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("illegal channel setting, 40MHz channel = %d\n", cur_channel));
-			return;
-		}
-		
-		ODM_RT_TRACE(pDM_Odm, 	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RXHP RX HP flag = %d\n", pRX_HP_Table->RXHP_flag));
-		ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RXHP FA = %d\n", FalseAlmCnt->Cnt_all));
-		ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RXHP cur RSSI = %d, pre RSSI=%d\n", curRssi, preRssi));
-		ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RXHP current CH = %d\n", cur_channel));
-		ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RXHP Is 40MHz = %d\n", Is40MHz));
-       	//2 PSD function would be triggered 
-       	//3 1. Every 4 sec for PCIE
-       	//3 2. Before TP Mode (Idle TP<4kbps) for USB
-       	//3 3. After TP Mode (High TP) for USB 
-		if((curRssi > 68) && (pRX_HP_Table->RXHP_flag == 0))	// Only RSSI>TH and RX_HP_flag=0 will Do PSD process 
-		{
-#if (DEV_BUS_TYPE == RT_USB_INTERFACE)
-			//2 Before TP Mode ==> PSD would be trigger every 4 sec
-			if(pRX_HP_Table->TP_Mode == Idle_Mode)		//2.1 less wlan traffic <4kbps
-			{
-#endif
-				if(PSDTriggerCnt == 1)       
-				{    	
-					odm_PSD_RXHP(pDM_Odm);
-					pRX_HP_Table->PSD_func_trigger = 1;
-					PSDTriggerCnt = 0;
-				}
-				else
-				{
-             				PSDTriggerCnt++;
-				}
-#if(DEV_BUS_TYPE == RT_USB_INTERFACE)
-			}	
-			//2 After TP Mode ==> Check if TP degrade larger than 20% would trigger PSD function
-			if(pRX_HP_Table->TP_Mode == High_TP_Mode)
-			{
-				if((pre_state_flag == 0)&&(LatchCnt == 0)) 
-				{
-					// TP var < 5%
-					if((((curTPOkCnt-TP_Acc3)*20)<(TP_Acc3))&&(((curTPOkCnt-TP_Acc3)*20)>(-TP_Acc3)))
-					{
-						pre_state++;
-						if(pre_state == 3)      // hit pre_state condition => consecutive 3 times
-						{
-							pre_state_flag = 1;
-							pre_state = 0;
-						}
-
-					}
-					else
-					{
-						pre_state = 0;
-					}
-				}
-				//3 If pre_state_flag=1 ==> start to monitor TP degrade 20%
-				if(pre_state_flag == 1)		
-				{
-					if(((TP_Acc3-curTPOkCnt)*5)>(TP_Acc3))      // degrade 20%
-					{
-						odm_PSD_RXHP(pDM_Odm);
-						pRX_HP_Table->PSD_func_trigger = 1;
-						TP_Degrade_flag = 1;
-						LatchCnt = 2;
-						pre_state_flag = 0;
-					}
-					else if(((TP_Buff[2]-curTPOkCnt)*5)>TP_Buff[2])
-					{
-						odm_PSD_RXHP(pDM_Odm);
-						pRX_HP_Table->PSD_func_trigger = 1;
-						TP_Degrade_flag = 1;
-						LatchCnt = 2;
-						pre_state_flag = 0;
-					}
-					else if(((TP_Buff[3]-curTPOkCnt)*5)>TP_Buff[3])
-					{
-						odm_PSD_RXHP(pDM_Odm);
-						pRX_HP_Table->PSD_func_trigger = 1;
-						TP_Degrade_flag = 1;
-						LatchCnt = 2;
-						pre_state_flag = 0;
-					}
-				}
-			}
-#endif
-}
-
-#if (DEV_BUS_TYPE == RT_USB_INTERFACE)
-		for (i=0;i<4;i++)
-		{
-			TP_Buff[4-i] = TP_Buff[3-i];
-		}
-#endif
-		//2 Update PSD bitmap according to PSD report 
-		if((pRX_HP_Table->PSD_func_trigger == 1)&&(LatchCnt == 0))
-    		{	
-           		//2 Separate 80M bandwidth into 16 group with smaller 5M BW.
-			for (i = 0 ; i < 16 ; i++)
-           		{
-				sum = 0;
-				for(j = 0; j < 5 ; j++)
-                			sum += pRX_HP_Table->PSD_bitmap_RXHP[5*i + j];
-            
-                		if(sum < 5)
-                		{
-                			ch_map_intf_5M[i] = 1;  // interference flag
-                		}
-           		}
-			//=============just for debug=========================
-			//for(i=0;i<16;i++)
-				//DbgPrint("RX HP: ch_map_intf_5M[%d] = %d\n", i, ch_map_intf_5M[i]);
-			//===============================================
-			//2 Mask target channel 5M index
-	    		for(i = 0; i < (4+4*Is40MHz) ; i++)
-           		{
-				ch_map_intf_5M[cur_channel - (1+2*Is40MHz) + i] = 0;  
-           		}
-				
-           		psd_intf_flag = 0;
-	    		for(i = 0; i < 16; i++)
-           		{
-         			if(ch_map_intf_5M[i] == 1)
-	              	{
-	              		psd_intf_flag = 1;            // interference is detected!!!	
-	              		break;
-         			}
-	    		}
-				
-#if (DEV_BUS_TYPE == RT_USB_INTERFACE)
-			if(pRX_HP_Table->TP_Mode!=Idle_Mode)
-			{
-				if(psd_intf_flag == 1)     // to avoid psd_intf_flag always 1
-				{
-					Intf_HighTP_flag = 1;
-					De_counter = 32;     // 0x1E -> 0x3E needs 32 times by each IGI step =1
-				}
-			}
-#endif
-			ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RX HP psd_intf_flag = %d\n", psd_intf_flag));
-			//2 Distance between target channel and interference
-           		for(i = 0; i < 16; i++)
-          		{
-				if(ch_map_intf_5M[i] == 1)
-                		{
-					Intf_diff_idx = ((cur_channel+Is40MHz-(i+1))>0) ? (s1Byte)(cur_channel-2*Is40MHz-(i-2)) : (s1Byte)((i+1)-(cur_channel+2*Is40MHz));  
-                      		if(Intf_diff_idx < MIN_Intf_diff_idx)
-						MIN_Intf_diff_idx = Intf_diff_idx;    // the min difference index between interference and target
-		  		}
-	    		}
-	    		ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RX HP MIN_Intf_diff_idx = %d\n", MIN_Intf_diff_idx)); 
-			//2 Choose False Alarm Threshold
-			switch (MIN_Intf_diff_idx){
-      				case 0: 
-	   			case 1:
-	        		case 2:
-	        		case 3:	 	 
-                 			FA_TH = FA_RXHP_TH1;  
-                     		break;
-	        		case 4:				// CH5
-	        		case 5:				// CH6
-		   			FA_TH = FA_RXHP_TH2;	
-               			break;
-	        		case 6:				// CH7
-	        		case 7:				// CH8
-		      			FA_TH = FA_RXHP_TH3;
-                    			break; 
-               		case 8:				// CH9
-	        		case 9:				//CH10
-		      			FA_TH = FA_RXHP_TH4;
-                    			break; 	
-	        		case 10:
-	        		case 11:
-	        		case 12:
-	        		case 13:	 
-	        		case 14:
-	      			case 15:	 	
-		      			FA_TH = FA_RXHP_TH5;
-                    			break;  		
-       		}	
-			ODM_RT_TRACE(pDM_Odm,	ODM_COMP_RXHP, ODM_DBG_LOUD, ("RX HP FA_TH = %d\n", FA_TH));
-			pRX_HP_Table->PSD_func_trigger = 0;
-		}
-		//1 Monitor RSSI variation to choose the suitable IGI or Exit AGC RX High Power Mode
-         	if(pRX_HP_Table->RXHP_flag == 1)
-         	{
-              	if ((curRssi > 80)&&(preRssi < 80))
-              	{ 
-                   		pRX_HP_Table->Cur_IGI = LNA_Low_Gain_1;
-              	}
-              	else if ((curRssi < 80)&&(preRssi > 80))
-              	{
-                   		pRX_HP_Table->Cur_IGI = LNA_Low_Gain_2;
-			}
-	       	else if ((curRssi > 72)&&(preRssi < 72))
-	      		{
-                		pRX_HP_Table->Cur_IGI = LNA_Low_Gain_2;
-	       	}
-              	else if ((curRssi < 72)&&( preRssi > 72))
-	     		{
-                   		pRX_HP_Table->Cur_IGI = LNA_Low_Gain_3;
-	       	}
-	       	else if (curRssi < 68)		 //RSSI is NOT large enough!!==> Exit AGC RX High Power Mode
-	       	{
-                   		pRX_HP_Table->Cur_pw_th = pw_th_10dB;
-				pRX_HP_Table->RXHP_flag = 0;    // Back to Normal DIG Mode		  
-				psd_intf_flag = 0;
-			}
-		}
-		else    // pRX_HP_Table->RXHP_flag == 0
-		{
-			//1 Decide whether to enter AGC RX High Power Mode
-			if ((curRssi > 70) && (psd_intf_flag == 1) && (FalseAlmCnt->Cnt_all > FA_TH) &&  
-				(pDM_DigTable->CurIGValue == pDM_DigTable->rx_gain_range_max))
-			{
-             			if (curRssi > 80)
-             			{
-					pRX_HP_Table->Cur_IGI = LNA_Low_Gain_1;
-				}
-				else if (curRssi > 72) 
-              		{
-               			pRX_HP_Table->Cur_IGI = LNA_Low_Gain_2;
-				}
-             			else
-            			{
-                   			pRX_HP_Table->Cur_IGI = LNA_Low_Gain_3;
-				}
-           			pRX_HP_Table->Cur_pw_th = pw_th_16dB;		//RegC54[9:8]=2'b11: to enter AGC Flow 3
-				pRX_HP_Table->First_time_enter = TRUE;
-				pRX_HP_Table->RXHP_flag = 1;    //	RXHP_flag=1: AGC RX High Power Mode, RXHP_flag=0: Normal DIG Mode
-			}
-		}
-		preRssi = curRssi; 
-		odm_Write_RXHP(pDM_Odm);	
-	}
-#endif //#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-#endif //#if (DEV_BUS_TYPE == RT_PCI_INTERFACE) | (DEV_BUS_TYPE == RT_USB_INTERFACE)
-}
-
-
-VOID
-odm_PSD_RXHPCallback(
-	PRT_TIMER		pTimer
-)
-{
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	pRXHP_T			pRX_HP_Table  = &pDM_Odm->DM_RXHP_Table;
-	
-#if DEV_BUS_TYPE==RT_PCI_INTERFACE
-	#if USE_WORKITEM
-	ODM_ScheduleWorkItem(&pRX_HP_Table->PSDTimeWorkitem);
-	#else
-	odm_PSD_RXHP(pDM_Odm);
-	#endif
-#else
-	ODM_ScheduleWorkItem(&pRX_HP_Table->PSDTimeWorkitem);
-#endif
-	
-	}
-
-VOID
-odm_PSD_RXHPWorkitemCallback(
-    IN PVOID            pContext
-    )
-{
-	PADAPTER	pAdapter = (PADAPTER)pContext;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	
-	odm_PSD_RXHP(pDM_Odm);
-}
-
-#endif //#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-
- 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rxhp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rxhp.h
deleted file mode 100644
index a1fe97f1b62a..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_rxhp.h
+++ /dev/null
@@ -1,105 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef	__PHYDMRXHP_H__
-#define    __PHYDMRXHP_H__
-
-#define RXHP_VERSION	"1.0"
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-#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
-
-typedef struct _RX_High_Power_
-{
-	u1Byte		RXHP_flag;
-	u1Byte		PSD_func_trigger;
-	u1Byte		PSD_bitmap_RXHP[80];
-	u1Byte		Pre_IGI;
-	u1Byte		Cur_IGI;
-	u1Byte		Pre_pw_th;
-	u1Byte		Cur_pw_th;
-	BOOLEAN		First_time_enter;
-	BOOLEAN		RXHP_enable;
-	u1Byte		TP_Mode;
-	RT_TIMER	PSDTimer;
-	#if USE_WORKITEM
-	RT_WORK_ITEM		PSDTimeWorkitem;
-	#endif
-}RXHP_T, *pRXHP_T;
-
-#define	dm_PSDMonitorCallback	odm_PSDMonitorCallback
-VOID	odm_PSDMonitorCallback(PRT_TIMER		pTimer);
-
-VOID
-odm_PSDMonitorInit(
-	IN		PVOID			pDM_VOID
-	);
-
-void	odm_RXHPInit(
-	IN		PVOID			pDM_VOID);
-
-void odm_RXHP(
-	IN		PVOID			pDM_VOID);
-
-VOID
-odm_PSD_RXHPCallback(
-	PRT_TIMER		pTimer
-);
-
- VOID
-ODM_PSDDbgControl(
-	IN	PADAPTER	Adapter,
-	IN	u4Byte		mode,
-	IN	u4Byte		btRssi
-	);
-
- VOID
-odm_PSD_RXHPCallback(
-	PRT_TIMER		pTimer
-);
-
-VOID
-odm_PSD_RXHPWorkitemCallback(
-    IN PVOID            pContext
-    );
-
-VOID
-odm_PSDMonitorWorkItemCallback(
-    IN PVOID            pContext
-    );
-
- #endif
-
- #endif
- 
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_smt_ant.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_smt_ant.c
new file mode 100644
index 000000000000..bcefb1cfd5b1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_smt_ant.c
@@ -0,0 +1,2229 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ******************************************************
+ * when antenna test utility is on or some testing need to disable antenna diversity
+ * call this function to disable all ODM related mechanisms which will switch antenna.
+ * ****************************************************** */
+#if (defined(CONFIG_SMART_ANTENNA))
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+void
+phydm_cumitek_smt_ant_mapping_table_8822b(
+	void		*dm_void,
+	u8		*table_path_a,
+	u8		*table_path_b
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	u32		path_a_0to3_idx = 0;
+	u32		path_b_0to3_idx = 0;
+	u32		path_a_4to7_idx = 0;
+	u32		path_b_4to7_idx = 0;
+	
+	path_a_0to3_idx = ((table_path_a[3] & 0xf) << 24) | ((table_path_a[2] & 0xf) << 16) 
+						| ((table_path_a[1] & 0xf) << 8) | (table_path_a[0] & 0xf);
+
+	path_b_0to3_idx = ((table_path_b[3] & 0xf) << 28) | ((table_path_b[2] & 0xf) << 20) 
+						| ((table_path_b[1] & 0xf) << 12) | ((table_path_b[0] & 0xf) << 4);
+
+	path_a_4to7_idx = ((table_path_a[7] & 0xf) << 24) | ((table_path_a[6] & 0xf) << 16) 
+						| ((table_path_a[5] & 0xf) << 8) | (table_path_a[4] & 0xf);
+
+	path_b_4to7_idx = ((table_path_b[7] & 0xf) << 28) | ((table_path_b[6] & 0xf) << 20) 
+						| ((table_path_b[5] & 0xf) << 12) | ((table_path_b[4] & 0xf) << 4);
+
+
+	/*PHYDM_DBG(dm, DBG_SMT_ANT, "mapping table{A, B} = {0x%x, 0x%x}\n", path_a_0to3_idx, path_b_0to3_idx);*/
+
+	/*pathA*/
+	odm_set_bb_reg(dm, 0xca4, MASKDWORD, path_a_0to3_idx); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xca8, MASKDWORD, path_a_4to7_idx); /*ant map 2*/
+
+	/*pathB*/
+	odm_set_bb_reg(dm, 0xea4, MASKDWORD, path_b_0to3_idx); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xea8, MASKDWORD, path_b_4to7_idx); /*ant map 2*/
+
+}
+
+
+void
+phydm_cumitek_smt_ant_init_8822b(
+	void		*dm_void
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant				*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek		*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32		value32;
+
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[8822B Cumitek SmtAnt Int]\n");
+
+	/*========= MAC GPIO setting =================================*/
+	
+	/* Pin, pin_name, RFE_CTRL_NUM*/
+	
+	/* A0, 55, 5G_TRSW, 3*/
+	/* A1, 52, 5G_TRSW, 0*/
+	/* A2, 25, 5G_TRSW, 8*/
+	
+	/* B0, 16, 5G_TRSW, 4*/
+	/* B1, 13, 5G_TRSW, 11*/
+	/* B2, 24, 5G_TRSW, 9*/
+
+	/*for RFE_CTRL 8 & 9*/
+	odm_set_mac_reg(dm, 0x4c, BIT(24) | BIT(23), 2);
+	odm_set_mac_reg(dm, 0x44, BIT(27) | BIT(26), 0);
+
+	/*for RFE_CTRL 0*/
+	odm_set_mac_reg(dm, 0x4c, BIT(25), 0);
+	odm_set_mac_reg(dm, 0x64, BIT(29), 1);
+
+	/*for RFE_CTRL 2 & 3*/
+	odm_set_mac_reg(dm, 0x4c, BIT(26), 0);
+	odm_set_mac_reg(dm, 0x64, BIT(28), 1);
+
+	/*for RFE_CTRL 11*/
+	odm_set_mac_reg(dm, 0x40, BIT(3), 1);
+
+
+	/*0x604[25]=1 : 2bit mode for pathA&B&C&D*/
+	/*0x604[25]=0 : 3bit mode for pathA&B*/
+	smtant_table->tx_desc_mode = 0;
+	odm_set_mac_reg(dm, 0x604, BIT(25), (u32)smtant_table->tx_desc_mode);
+
+	/*========= BB RFE setting =================================*/
+	#if 0
+	/*path A*/
+	odm_set_bb_reg(dm, 0x1990, BIT(3), 0);		/*RFE_CTRL_3*/ /*A_0*/
+	odm_set_bb_reg(dm, 0xcbc, BIT(3), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xcb0, 0xf000, 8);
+
+	odm_set_bb_reg(dm, 0x1990, BIT(0), 0);		/*RFE_CTRL_0*/ /*A_1*/
+	odm_set_bb_reg(dm, 0xcbc, BIT(0), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xcb0, 0xf, 0x9);
+	
+	odm_set_bb_reg(dm, 0x1990, BIT(8), 0);		/*RFE_CTRL_8*/ /*A_2*/
+	odm_set_bb_reg(dm, 0xcbc, BIT(8), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xcb4, 0xf, 0xa);
+	
+
+	/*path B*/
+	odm_set_bb_reg(dm, 0x1990, BIT(4), 1);		/*RFE_CTRL_4*/	/*B_0*/
+	odm_set_bb_reg(dm, 0xdbc, BIT(4), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xdb0, 0xf0000, 0xb);
+	
+	odm_set_bb_reg(dm, 0x1990, BIT(11), 1);	/*RFE_CTRL_11*/	/*B_1*/
+	odm_set_bb_reg(dm, 0xdbc, BIT(11), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xdb4, 0xf000, 0xc);
+	
+	odm_set_bb_reg(dm, 0x1990, BIT(9), 1);		/*RFE_CTRL_9*/	/*B_2*/
+	odm_set_bb_reg(dm, 0xdbc, BIT(9), 0);		/*inv*/
+	odm_set_bb_reg(dm, 0xdb4, 0xf0, 0xd);
+	#endif
+	/*========= BB SmtAnt setting =================================*/
+	odm_set_mac_reg(dm, 0x6d8, BIT(22) | BIT(21), 2); /*resp tx by register*/
+	odm_set_mac_reg(dm, 0x668, BIT(3), 1);
+	odm_set_bb_reg(dm, 0x804, BIT(4), 0); /*lathch antsel*/
+	odm_set_bb_reg(dm, 0x818, 0xf00000, 0); /*keep tx by rx*/
+	odm_set_bb_reg(dm, 0x900, BIT(19), 0); /*fast train*/
+	odm_set_bb_reg(dm, 0x900, BIT(18), 1); /*1: by TXDESC*/
+
+	/*pathA*/
+	odm_set_bb_reg(dm, 0xca4, MASKDWORD, 0x03020100); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xca8, MASKDWORD, 0x07060504); /*ant map 2*/
+	odm_set_bb_reg(dm, 0xcac, BIT(9), 0); /*keep antsel map by GNT_BT*/
+
+	/*pathB*/
+	odm_set_bb_reg(dm, 0xea4, MASKDWORD, 0x30201000); /*ant map 1*/
+	odm_set_bb_reg(dm, 0xea8, MASKDWORD, 0x70605040); /*ant map 2*/
+	odm_set_bb_reg(dm, 0xeac, BIT(9), 0); /*keep antsel map by GNT_BT*/
+}
+
+void
+phydm_cumitek_smt_ant_init_8197f(
+	void		*dm_void
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32		value32;
+
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[8197F Cumitek SmtAnt Int]\n");
+
+	/*GPIO setting*/
+
+
+}
+
+void
+phydm_cumitek_smt_tx_ant_update(
+	void		*dm_void,
+	u8		tx_ant_idx_path_a,
+	u8		tx_ant_idx_path_b,
+	u32		mac_id
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[Cumitek] Set TX-ANT[%d] = (( A:0x%x ,  B:0x%x ))\n",
+		mac_id, tx_ant_idx_path_a, tx_ant_idx_path_b);
+
+	/*path-A*/
+	cumi_smtant_table->tx_ant_idx[0][mac_id] = tx_ant_idx_path_a; /*fill this value into TXDESC*/
+	
+	/*path-B*/	
+	cumi_smtant_table->tx_ant_idx[1][mac_id] = tx_ant_idx_path_b; /*fill this value into TXDESC*/
+}
+
+void
+phydm_cumitek_smt_rx_default_ant_update(
+	void		*dm_void,
+	u8		rx_ant_idx_path_a,
+	u8		rx_ant_idx_path_b
+)
+{
+	struct	dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[Cumitek] Set RX-ANT = (( A:0x%x, B:0x%x ))\n",
+		rx_ant_idx_path_a, rx_ant_idx_path_b);
+
+	/*path-A*/
+	if (cumi_smtant_table->rx_default_ant_idx[0] != rx_ant_idx_path_a) {
+		
+		#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			
+			odm_set_bb_reg(dm, 0xc08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_a); /*default RX antenna*/
+			odm_set_mac_reg(dm, 0x6d8, BIT(2) | BIT(1) | BIT(0), rx_ant_idx_path_a); /*default response TX antenna*/
+		}
+		#endif
+		
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
+		}
+		#endif
+
+		cumi_smtant_table->rx_default_ant_idx[0] = rx_ant_idx_path_a;
+	}
+
+	/*path-B*/
+	if (cumi_smtant_table->rx_default_ant_idx[1] != rx_ant_idx_path_b) {
+		
+		#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			
+			odm_set_bb_reg(dm, 0xe08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_b); /*default antenna*/
+			odm_set_mac_reg(dm, 0x6d8, BIT(5) | BIT(4) | BIT(3), rx_ant_idx_path_b); /*default response TX antenna*/
+		}
+		#endif
+		
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
+		}
+		#endif
+
+		cumi_smtant_table->rx_default_ant_idx[1] = rx_ant_idx_path_b;
+	}
+	
+}
+
+void
+phydm_cumitek_smt_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant			*smtant_table = &dm->smtant_table;
+	struct	smt_ant_cumitek	*cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	char			help[] = "-h";
+	u32			dm_value[10] = {0};
+	u8			i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &dm_value[0]);
+
+	if (strcmp(input[1], help) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{1} {PathA rx_ant_idx} {pathB rx_ant_idx}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{2} {PathA tx_ant_idx} {pathB tx_ant_idx} {macid}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{3} {PathA mapping table} {PathB mapping table}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "{4} {txdesc_mode 0:3bit, 1:2bit}\n");
+
+	} else if (dm_value[0] == 1) { /*fix rx_idle pattern*/
+	
+		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &dm_value[1]);
+		PHYDM_SSCANF(input[3], DCMD_DECIMAL, &dm_value[2]);
+
+		phydm_cumitek_smt_rx_default_ant_update(dm, (u8)dm_value[1], (u8)dm_value[2]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "RX Ant{A, B}={%d, %d}\n", dm_value[1],
+			       dm_value[2]);
+		
+	} else if (dm_value[0] == 2) { /*fix tx pattern*/ 
+
+
+		for (i = 1; i < 4; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "STA[%d] TX Ant{A, B}={%d, %d}\n",dm_value[3],
+			       dm_value[1], dm_value[2]);
+		phydm_cumitek_smt_tx_ant_update(dm, (u8)dm_value[1], (u8)dm_value[2], (u8)dm_value[3]);
+
+	} else if (dm_value[0] == 3) {
+		u8 table_path_a[8] = {0};
+		u8 table_path_b[8] = {0};
+
+		for (i = 1; i < 4; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Set Path-AB mapping table={%d, %d}\n",
+			       dm_value[1], dm_value[2]);
+
+		for (i = 0; i <8; i++) {
+			table_path_a[i] = (u8)((dm_value[1] >> (4 * i)) & 0xf);
+			table_path_b[i] = (u8)((dm_value[2] >> (4 * i)) & 0xf);
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Ant_Table_A[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n",
+			       
+			       table_path_a[7], table_path_a[6],
+			       table_path_a[5], table_path_a[4],
+			       table_path_a[3], table_path_a[2],
+			       table_path_a[1], table_path_a[0]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "Ant_Table_B[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n",
+			       
+			       table_path_b[7], table_path_b[6],
+			       table_path_b[5], table_path_b[4],
+			       table_path_b[3], table_path_b[2],
+			       table_path_b[1], table_path_b[0]);
+
+		phydm_cumitek_smt_ant_mapping_table_8822b(dm,
+							  &table_path_a[0],
+							  &table_path_b[0]);
+	}else if (dm_value[0] == 4) {
+		smtant_table->tx_desc_mode = (u8)dm_value[1];
+		odm_set_mac_reg(dm, 0x604, BIT(25), (u32)smtant_table->tx_desc_mode);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+
+#if (RTL8822B_SUPPORT == 1)
+void
+phydm_hl_smart_ant_type2_init_8822b(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	u8	j;
+	u8	rfu_codeword_table_init_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] = {
+			{1, 1},/*0*/
+			{1, 2},
+			{2, 1},
+			{2, 2},
+			{4, 0},
+			{5, 0},
+			{6, 0},
+			{7, 0},
+			{8, 0},/*8*/
+			{9, 0},
+			{0xa, 0},
+			{0xb, 0},
+			{0xc, 0},
+			{0xd, 0},
+			{0xe, 0},
+			{0xf, 0}
+		}; 
+	u8	rfu_codeword_table_init_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] ={
+		#if 1
+			{9, 1},/*0*/
+			{9, 9},
+			{1, 9},
+			{9, 6},
+			{2, 1},
+			{2, 9},
+			{9, 2},
+			{2, 2},/*8*/
+			{6, 1},
+			{6, 9},
+			{2, 9},
+			{2, 2},
+			{6, 2},
+			{6, 6},
+			{2, 6},
+			{1, 1}
+		#else
+			{1, 1},/*0*/
+			{9, 1},
+			{9, 9},
+			{1, 9},
+			{1, 2},
+			{9, 2},
+			{9, 6},
+			{1, 6},
+			{2, 1},/*8*/
+			{6, 1},
+			{6, 9},
+			{2, 9},
+			{2, 2},
+			{6, 2},
+			{6, 6},
+			{2, 6}
+		#endif
+		}; 		
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***RTK 8822B SmartAnt_Init: Hong-Bo SmrtAnt Type2]\n");
+
+	/* ---------------------------------------- */
+	/* GPIO 0-1 for Beam control */
+	/* reg0x66[2:0]=0 */
+	/* reg0x44[25:24] = 0 */
+	/* reg0x44[23:16]  enable_output for P_GPIO[7:0] */
+	/* reg0x44[15:8]  output_value for P_GPIO[7:0] */
+	/* reg0x40[1:0] = 0  GPIO function */
+	/* ------------------------------------------ */
+
+	odm_move_memory(dm, sat_tab->rfu_codeword_table_2g, rfu_codeword_table_init_2g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
+	odm_move_memory(dm, sat_tab->rfu_codeword_table_5g, rfu_codeword_table_init_5g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
+
+	/*GPIO setting*/
+	odm_set_mac_reg(dm, 0x64, (BIT(18) | BIT(17) | BIT(16)), 0);
+	odm_set_mac_reg(dm, 0x44, BIT(25) | BIT(24), 0);	/*config P_GPIO[3:2] to data port*/
+	odm_set_mac_reg(dm, 0x44, BIT(17) | BIT(16), 0x3);	/*enable_output for P_GPIO[3:2]*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(9)|BIT(8), 0);*/ /*P_GPIO[3:2] output value*/
+	odm_set_mac_reg(dm, 0x40, BIT(1) | BIT(0), 0);		/*GPIO function*/
+
+	/*Hong_lin smart antenna HW setting*/
+	sat_tab->rfu_protocol_type = 2;
+	sat_tab->rfu_protocol_delay_time = 45;
+	
+	sat_tab->rfu_codeword_total_bit_num  = 16;/*max=32bit*/
+	sat_tab->rfu_each_ant_bit_num = 4;
+	
+	sat_tab->total_beam_set_num = 4;
+	sat_tab->total_beam_set_num_2g = 4;
+	sat_tab->total_beam_set_num_5g = 8;
+
+#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#elif DEV_BUS_TYPE == RT_USB_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#endif
+	sat_tab->pkt_skip_statistic_en = 0;
+
+	sat_tab->ant_num = 2;
+	sat_tab->ant_num_total = MAX_PATH_NUM_8822B;
+	sat_tab->first_train_ant = MAIN_ANT;
+
+
+
+	sat_tab->fix_beam_pattern_en  = 0;
+	sat_tab->decision_holding_period = 0;
+
+	/*beam training setting*/
+	sat_tab->pkt_counter = 0;
+	sat_tab->per_beam_training_pkt_num = 10;
+
+	/*set default beam*/
+	sat_tab->fast_training_beam_num = 0;
+	sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+
+	for (j = 0; j < SUPPORT_BEAM_SET_PATTERN_NUM; j++) {
+		
+		sat_tab->beam_set_avg_rssi_pre[j] = 0;
+		sat_tab->beam_set_train_val_diff[j] = 0;
+		sat_tab->beam_set_train_cnt[j] = 0;
+	}
+	phydm_set_rfu_beam_pattern_type2(dm);
+	fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+	
+}
+#endif
+
+
+u32
+phydm_construct_hb_rfu_codeword_type2(
+	void		*dm_void,
+	u32		beam_set_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo		*sat_tab = &dm->dm_sat_table;
+	u32		sync_codeword = 0x7f;
+	u32		codeword = 0;
+	u32		data_tmp = 0;
+	u32		i;
+
+	for (i = 0; i < sat_tab->ant_num_total; i++) {
+		if (*dm->band_type == ODM_BAND_5G)
+			data_tmp = sat_tab->rfu_codeword_table_5g[beam_set_idx][i];
+		else
+			data_tmp = sat_tab->rfu_codeword_table_2g[beam_set_idx][i];
+			
+		codeword |= (data_tmp << (i * sat_tab->rfu_each_ant_bit_num));
+	}
+
+	codeword = (codeword<<8) | sync_codeword;
+	
+	return codeword;
+}
+
+void
+phydm_update_beam_pattern_type2(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u8			i;
+	boolean			beam_ctrl_signal;
+	u32			one = 0x1;
+	u32			reg44_tmp_p, reg44_tmp_n, reg44_ori;
+	u8			devide_num = 4;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Set codeword = ((0x%x))\n", codeword);
+
+	reg44_ori = odm_get_mac_reg(dm, 0x44, MASKDWORD);
+	reg44_tmp_p = reg44_ori;
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_ori =0x%x\n", reg44_ori);*/
+
+	/*devide_num = (sat_tab->rfu_protocol_type == 2) ? 8 : 4;*/
+
+	for (i = 0; i <= (codeword_length - 1); i++) {
+		beam_ctrl_signal = (boolean)((codeword & BIT(i)) >> i);
+		
+		#if 1
+		if (dm->debug_components & DBG_ANT_DIV) {
+			if (i == (codeword_length - 1)) {
+				pr_debug("%d ]\n", beam_ctrl_signal);
+				/**/
+			} else if (i == 0) {
+				pr_debug("Start sending codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
+				/**/
+			} else if ((i % devide_num) == (devide_num-1)) {
+				pr_debug("%d  |  ", beam_ctrl_signal);
+				/**/
+			} else {
+				pr_debug("%d ", beam_ctrl_signal);
+				/**/
+			}
+		}
+		#endif
+		
+		if (dm->support_ic_type == ODM_RTL8821) {
+			#if (RTL8821A_SUPPORT == 1)
+			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*clean bit 10 & 11*/
+			reg44_tmp_p |= ((1 << 11) | (beam_ctrl_signal << 10));
+			reg44_tmp_n = reg44_ori & (~(BIT(11) | BIT(10)));
+
+			/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n);*/
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+			#endif
+		}
+		#if (RTL8822B_SUPPORT == 1)
+		else if (dm->support_ic_type == ODM_RTL8822B) {
+			if (sat_tab->rfu_protocol_type == 2) {
+				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*clean bit 8*/
+				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*get new clk high/low, exclusive-or*/
+
+	
+				reg44_tmp_p |= (beam_ctrl_signal << 8);
+				
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(sat_tab->rfu_protocol_delay_time);
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal);*/
+				
+			} else {
+				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*clean bit 9 & 8*/
+				reg44_tmp_p |= ((1 << 9) | (beam_ctrl_signal << 8));
+				reg44_tmp_n = reg44_ori & (~(BIT(9) | BIT(8)));
+
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n); */
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(10);
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+				ODM_delay_us(10);
+			}
+		}
+		#endif
+	}
+}
+
+void
+phydm_update_rx_idle_beam_type2(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	u32			i;
+
+	sat_tab->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(dm, sat_tab->rx_idle_beam_set_idx);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-Beam ] BeamSet idx = ((%d))\n", sat_tab->rx_idle_beam_set_idx);
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+#endif
+
+	sat_tab->pre_codeword = sat_tab->update_beam_codeword;
+}
+
+
+void
+phydm_hl_smart_ant_debug_type2(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			one = 0x1;
+	u32			codeword_length = sat_tab->rfu_codeword_total_bit_num;
+	u32			beam_ctrl_signal, i;
+	u8			devide_num = 4;
+	char			help[] = "-h";
+	u32			dm_value[10] = {0};
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &dm_value[0]);
+	PHYDM_SSCANF(input[2], DCMD_DECIMAL, &dm_value[1]);
+	PHYDM_SSCANF(input[3], DCMD_DECIMAL, &dm_value[2]);
+	PHYDM_SSCANF(input[4], DCMD_DECIMAL, &dm_value[3]);
+	PHYDM_SSCANF(input[5], DCMD_DECIMAL, &dm_value[4]);
+
+
+	if (strcmp(input[1], help) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 1 {fix_en} {codeword(Hex)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 3 {Fix_training_num_en} {Per_beam_training_pkt_num} {Decision_holding_period}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 5 {0:show, 1:2G, 2:5G} {beam_num} {idxA(Hex)} {idxB(Hex)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 7 {0:show, 1:2G, 2:5G} {total_beam_set_num}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       " 8 {0:show, 1:set} {RFU delay time(us)}\n");
+
+	} else if (dm_value[0] == 1) { /*fix beam pattern*/
+
+		sat_tab->fix_beam_pattern_en = dm_value[1];
+
+		if (sat_tab->fix_beam_pattern_en == 1) {
+			PHYDM_SSCANF(input[3], DCMD_HEX, &dm_value[2]);
+			sat_tab->fix_beam_pattern_codeword = dm_value[2];
+
+			if (sat_tab->fix_beam_pattern_codeword  > (one << codeword_length)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
+					sat_tab->fix_beam_pattern_codeword, codeword_length);
+				
+				(sat_tab->fix_beam_pattern_codeword) &= 0xffffff;
+				
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Auto modify to (0x%x)\n", sat_tab->fix_beam_pattern_codeword);
+			}
+
+			sat_tab->update_beam_codeword = sat_tab->fix_beam_pattern_codeword;
+
+			/*---------------------------------------------------------*/
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Fix Beam Pattern\n");
+			
+			/*devide_num = (sat_tab->rfu_protocol_type == 2) ? 8 : 4;*/
+			
+			for (i = 0; i <= (codeword_length - 1); i++) {
+				beam_ctrl_signal = (boolean)((sat_tab->update_beam_codeword & BIT(i)) >> i);
+
+				if (i == (codeword_length - 1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "%d]\n",
+						       beam_ctrl_signal);
+					/**/
+				} else if (i == 0) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "Send Codeword[1:%d] to RFU -> [%d",
+						       sat_tab->rfu_codeword_total_bit_num,
+						       beam_ctrl_signal);
+					/**/
+				} else if ((i % devide_num) == (devide_num-1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d|",
+						       beam_ctrl_signal);
+					/**/
+				} else {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d",
+						       beam_ctrl_signal);
+					/**/
+				}
+			}
+			/*---------------------------------------------------------*/
+
+
+			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+			#else
+			odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+			/*odm_stall_execution(1);*/
+			#endif
+		} else if (sat_tab->fix_beam_pattern_en == 0)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Smart Antenna: Enable\n");
+
+	} else if (dm_value[0] == 2) { /*set latch time*/
+
+		sat_tab->latch_time = dm_value[1];
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ]  latch_time =0x%x\n", sat_tab->latch_time);
+	} else if (dm_value[0] == 3) {
+		sat_tab->fix_training_num_en = dm_value[1];
+
+		if (sat_tab->fix_training_num_en == 1) {
+			sat_tab->per_beam_training_pkt_num = (u8)dm_value[2];
+			sat_tab->decision_holding_period = (u8)dm_value[3];
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmtAnt] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
+				       sat_tab->fix_training_num_en,
+				       sat_tab->per_beam_training_pkt_num,
+				       sat_tab->decision_holding_period);
+
+		} else if (sat_tab->fix_training_num_en == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n");
+			/**/
+		}
+	} else if (dm_value[0] == 4) {
+		#if 0
+		if (dm_value[1] == 1) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = MAIN_ANT;
+
+		} else if (dm_value[1] == 2) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = AUX_ANT;
+
+		} else if (dm_value[1] == 3) {
+			sat_tab->ant_num = 2;
+			sat_tab->first_train_ant = MAIN_ANT;
+		}
+
+		PDM_SNPF((output + used, out_len - used, "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
+			sat_tab->ant_num, (sat_tab->first_train_ant - 1)));
+		#endif
+	} else if (dm_value[0] == 5) {	/*set beam set table*/
+
+		PHYDM_SSCANF(input[4], DCMD_HEX, &dm_value[3]);
+		PHYDM_SSCANF(input[5], DCMD_HEX, &dm_value[4]);
+
+		if (dm_value[1] == 1) { /*2G*/
+			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
+				sat_tab->rfu_codeword_table_2g[dm_value[2] ][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_2g[dm_value[2] ][1] = (u8)dm_value[4];
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Set 2G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       dm_value[2], dm_value[3],
+					       dm_value[4]);
+			}
+			
+		} else if (dm_value[1] == 2) { /*5G*/
+			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][1] = (u8)dm_value[4];
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       dm_value[2], dm_value[3],
+					       dm_value[4]);
+			}
+		} else  if (dm_value[1] == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmtAnt] 2G Beam Table==============>\n");
+			for (i = 0; i < sat_tab->total_beam_set_num_2g; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "2G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       i,
+					       sat_tab->rfu_codeword_table_2g[i][0],
+					       sat_tab->rfu_codeword_table_2g[i][1]);
+			}
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmtAnt] 5G Beam Table==============>\n");
+			for (i = 0; i < sat_tab->total_beam_set_num_5g; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					       i,
+					       sat_tab->rfu_codeword_table_5g[i][0],
+					       sat_tab->rfu_codeword_table_5g[i][1]);
+			}
+		}
+
+	} else if (dm_value[0] == 6) {
+		#if 0
+		if (dm_value[1] == 0) {
+			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][1] = (u8)dm_value[4];
+				PDM_SNPF((output + used, out_len - used, "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",dm_value[2], dm_value[3], dm_value[4]));
+			}
+		} else {
+			for (i = 0; i < sat_tab->total_beam_set_num_5g; i++) {
+				PDM_SNPF((output + used, out_len - used, "[SmtAnt] Read 5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					i, sat_tab->rfu_codeword_table_5g[i][0], sat_tab->rfu_codeword_table_5g[i][1]));
+			}
+		}
+		#endif
+	} else if (dm_value[0] == 7) {
+		if (dm_value[1] == 1) {
+			sat_tab->total_beam_set_num_2g = (u8)(dm_value[2]);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] total_beam_set_num_2g = ((%d))\n",
+				       sat_tab->total_beam_set_num_2g);
+
+		} else if (dm_value[1] == 2) {
+			sat_tab->total_beam_set_num_5g = (u8)(dm_value[2]);
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] total_beam_set_num_5g = ((%d))\n",
+				       sat_tab->total_beam_set_num_5g);
+		} else if (dm_value[1] == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Show total_beam_set_num{2g,5g} = {%d,%d}\n",
+				       
+				       sat_tab->total_beam_set_num_2g,
+				       sat_tab->total_beam_set_num_5g);
+		}
+
+	} else if (dm_value[0] == 8) {
+			if (dm_value[1] == 1) {
+				sat_tab->rfu_protocol_delay_time = (u16)(dm_value[2]);
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Set rfu_protocol_delay_time = ((%d))\n",
+					       sat_tab->rfu_protocol_delay_time);
+			} else if (dm_value[1] == 0) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[SmtAnt] Read rfu_protocol_delay_time = ((%d))\n",
+					       sat_tab->rfu_protocol_delay_time);
+			}
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_set_rfu_beam_pattern_type2(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+
+	if (dm->ant_div_type != HL_SW_SMART_ANT_TYPE2)
+		return;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Training beam_set index = (( 0x%x ))\n", sat_tab->fast_training_beam_num);
+	sat_tab->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(dm, sat_tab->fast_training_beam_num);
+
+	#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+	#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+	#endif
+}
+
+void
+phydm_fast_ant_training_hl_smart_antenna_type2(
+	void		*dm_void
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct		*fat_tab	 = &dm->dm_fat_table;
+	struct sw_antenna_switch				*dm_swat_table = &dm->dm_swat_table;
+	u32		codeword = 0;
+	u8		i = 0, j=0;
+	u8		avg_rssi_tmp;
+	u8		avg_rssi_tmp_ma;
+	u8		max_beam_ant_rssi = 0;
+	u8		rssi_target_beam = 0, target_beam_max_rssi = 0;
+	u8		evm1ss_target_beam = 0, evm2ss_target_beam = 0;
+	u32		target_beam_max_evm1ss = 0, target_beam_max_evm2ss = 0;
+	u32		beam_tmp;
+	u8		per_beam_val_diff_tmp = 0, training_pkt_num_offset;
+	u32		avg_evm2ss[2] = {0}, avg_evm2ss_sum = 0;
+	u32		avg_evm1ss = 0;
+	u32		beam_path_evm_2ss_cnt_all = 0; /*sum of all 2SS-pattern cnt*/
+	u32		beam_path_evm_1ss_cnt_all = 0; /*sum of all 1SS-pattern cnt*/
+	u8		decision_type;
+
+	if (!dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			sat_tab->decision_holding_period = 0;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Link->no Link\n");
+			fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+
+			fat_tab->fat_state = FAT_PREPARE_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+
+			/*sat_tab->fast_training_beam_num = 0;*/
+			/*phydm_set_rfu_beam_pattern_type2(dm);*/
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "HL Smart ant Training: state (( %d ))\n", fat_tab->fat_state);*/
+
+	/* [DECISION STATE] */
+	/*=======================================================================================*/
+	if (fat_tab->fat_state == FAT_DECISION_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 3. In Decision state]\n");
+
+		/*compute target beam in each antenna*/
+
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			/*[Decision1: RSSI]-------------------------------------------------------------------*/
+			if (sat_tab->statistic_pkt_cnt[j] == 0) {	/*if new RSSI = 0 -> MA_RSSI-=2*/
+				avg_rssi_tmp = sat_tab->beam_set_avg_rssi_pre[j];
+				avg_rssi_tmp = (avg_rssi_tmp >= 2) ? (avg_rssi_tmp - 2) : avg_rssi_tmp;
+				avg_rssi_tmp_ma = avg_rssi_tmp;
+			} else {
+				avg_rssi_tmp = (u8)((sat_tab->beam_set_rssi_avg_sum[j]) / (sat_tab->statistic_pkt_cnt[j]));
+				avg_rssi_tmp_ma = (avg_rssi_tmp + sat_tab->beam_set_avg_rssi_pre[j]) >> 1;
+			}
+
+			sat_tab->beam_set_avg_rssi_pre[j] = avg_rssi_tmp;
+
+			if (avg_rssi_tmp > target_beam_max_rssi) {
+				rssi_target_beam = j;
+				target_beam_max_rssi = avg_rssi_tmp;
+			}
+
+			/*[Decision2: EVM 2ss]-------------------------------------------------------------------*/
+			if (sat_tab->beam_path_evm_2ss_cnt[j] != 0) {
+				avg_evm2ss[0] =  sat_tab->beam_path_evm_2ss_sum[j][0] / sat_tab->beam_path_evm_2ss_cnt[j];
+				avg_evm2ss[1] =  sat_tab->beam_path_evm_2ss_sum[j][1] / sat_tab->beam_path_evm_2ss_cnt[j];
+				avg_evm2ss_sum = avg_evm2ss[0] + avg_evm2ss[1];
+				beam_path_evm_2ss_cnt_all += sat_tab->beam_path_evm_2ss_cnt[j];
+
+				sat_tab->beam_set_avg_evm_2ss_pre[j] = (u8)avg_evm2ss_sum;
+			}
+
+			if (avg_evm2ss_sum > target_beam_max_evm2ss) {
+				evm2ss_target_beam = j;
+				target_beam_max_evm2ss = avg_evm2ss_sum;
+			}
+
+			/*[Decision3: EVM 1ss]-------------------------------------------------------------------*/
+			if (sat_tab->beam_path_evm_1ss_cnt[j] != 0) {
+				avg_evm1ss =  sat_tab->beam_path_evm_1ss_sum[j] / sat_tab->beam_path_evm_1ss_cnt[j];
+				beam_path_evm_1ss_cnt_all += sat_tab->beam_path_evm_1ss_cnt[j];
+
+				sat_tab->beam_set_avg_evm_1ss_pre[j] = (u8)avg_evm1ss;
+			}
+				
+			if (avg_evm1ss > target_beam_max_evm1ss) {
+				evm1ss_target_beam = j;
+				target_beam_max_evm1ss = avg_evm1ss;
+			}
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Beam[%d] Pkt_cnt=(( %d )), avg{MA,rssi}={%d, %d}, EVM1={%d}, EVM2={%d, %d, %d}\n",
+				j, sat_tab->statistic_pkt_cnt[j], avg_rssi_tmp_ma, avg_rssi_tmp, avg_evm1ss, avg_evm2ss[0], avg_evm2ss[1], avg_evm2ss_sum);
+
+			/*reset counter value*/
+			sat_tab->beam_set_rssi_avg_sum[j] = 0;
+			sat_tab->beam_path_rssi_sum[j][0] = 0;
+			sat_tab->beam_path_rssi_sum[j][1] = 0;
+			sat_tab->statistic_pkt_cnt[j] = 0;
+			
+			sat_tab->beam_path_evm_2ss_sum[j][0] = 0;
+			sat_tab->beam_path_evm_2ss_sum[j][1] = 0;
+			sat_tab->beam_path_evm_2ss_cnt[j] = 0;
+			
+			sat_tab->beam_path_evm_1ss_sum[j] = 0;
+			sat_tab->beam_path_evm_1ss_cnt[j] = 0;
+		}
+		
+		/*[Joint Decision]-------------------------------------------------------------------*/
+		PHYDM_DBG(dm, DBG_ANT_DIV, "--->1.[RSSI]      Target Beam(( %d )) RSSI_max=((%d))\n", rssi_target_beam, target_beam_max_rssi);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "--->2.[Evm2SS] Target Beam(( %d )) EVM2SS_max=((%d))\n", evm2ss_target_beam, target_beam_max_evm2ss);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "--->3.[Evm1SS] Target Beam(( %d )) EVM1SS_max=((%d))\n", evm1ss_target_beam, target_beam_max_evm1ss);
+
+		if (target_beam_max_rssi <= 10) {
+			sat_tab->rx_idle_beam_set_idx = rssi_target_beam;
+			decision_type = 1;
+		} else {
+			if (beam_path_evm_2ss_cnt_all != 0) {
+				sat_tab->rx_idle_beam_set_idx = evm2ss_target_beam;
+				decision_type = 2;
+			} else if (beam_path_evm_1ss_cnt_all != 0) {
+				sat_tab->rx_idle_beam_set_idx = evm1ss_target_beam;
+				decision_type = 3;
+			} else {
+				sat_tab->rx_idle_beam_set_idx = rssi_target_beam;
+				decision_type = 1;
+			}
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "---> Decision_type=((%d)), Final Target Beam(( %d ))\n", decision_type, sat_tab->rx_idle_beam_set_idx);
+
+		/*Calculate packet counter offset*/
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			if (decision_type == 1) {
+				per_beam_val_diff_tmp = target_beam_max_rssi - sat_tab->beam_set_avg_rssi_pre[j];
+				
+			} else if (decision_type == 2) {
+				per_beam_val_diff_tmp = ((u8)target_beam_max_evm2ss - sat_tab->beam_set_avg_evm_2ss_pre[j]) >> 1;
+			} else if (decision_type == 3) {
+				per_beam_val_diff_tmp = (u8)target_beam_max_evm1ss - sat_tab->beam_set_avg_evm_1ss_pre[j];
+			}
+			sat_tab->beam_set_train_val_diff[j] = per_beam_val_diff_tmp;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Beam_Set[%d]: diff= ((%d))\n", j, per_beam_val_diff_tmp);
+		}
+
+		/*set beam in each antenna*/
+		phydm_update_rx_idle_beam_type2(dm);
+		fat_tab->fat_state = FAT_PREPARE_STATE;
+
+	}
+	/* [TRAINING STATE] */
+	else if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2. In Training state]\n");
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "curr_beam_idx = (( %d )), pre_beam_idx = (( %d ))\n",
+			sat_tab->fast_training_beam_num, sat_tab->pre_fast_training_beam_num);
+
+		if (sat_tab->fast_training_beam_num > sat_tab->pre_fast_training_beam_num)
+
+			sat_tab->force_update_beam_en = 0;
+
+		else {
+			sat_tab->force_update_beam_en = 1;
+
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+			if (sat_tab->fast_training_beam_num >= ((u32)sat_tab->total_beam_set_num - 1)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n", sat_tab->fast_training_beam_num);
+				fat_tab->fat_state = FAT_DECISION_STATE;
+				phydm_fast_ant_training_hl_smart_antenna_type2(dm);
+
+			} else {
+				sat_tab->fast_training_beam_num++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+				phydm_set_rfu_beam_pattern_type2(dm);
+				fat_tab->fat_state = FAT_TRAINING_STATE;
+
+			}
+		}
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Update Pre_Beam =(( %d ))\n", sat_tab->pre_fast_training_beam_num);
+	}
+	/*  [Prepare state] */
+	/*=======================================================================================*/
+	else if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n\n[ 1. In Prepare state]\n");
+
+		if (dm->pre_traffic_load == (dm->traffic_load)) {
+			if (sat_tab->decision_holding_period != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Holding_period = (( %d )), return!!!\n", sat_tab->decision_holding_period);
+				sat_tab->decision_holding_period--;
+				return;
+			}
+		}
+
+		/* Set training packet number*/
+		if (sat_tab->fix_training_num_en == 0) {
+			switch (dm->traffic_load) {
+			case TRAFFIC_HIGH:
+				sat_tab->per_beam_training_pkt_num = 8;
+				sat_tab->decision_holding_period = 2;
+				break;
+			case TRAFFIC_MID:
+				sat_tab->per_beam_training_pkt_num = 6;
+				sat_tab->decision_holding_period = 3;
+				break;
+			case TRAFFIC_LOW:
+				sat_tab->per_beam_training_pkt_num = 3; /*ping 60000*/
+				sat_tab->decision_holding_period = 4;
+				break;
+			case TRAFFIC_ULTRA_LOW:
+				sat_tab->per_beam_training_pkt_num = 1;
+				sat_tab->decision_holding_period = 6;
+				break;
+			default:
+				break;
+			}
+		}
+		
+		PHYDM_DBG(dm, DBG_ANT_DIV, "TrafficLoad = (( %d )), Fix_beam = (( %d )), per_beam_training_pkt_num = (( %d )), decision_holding_period = ((%d))\n",
+			dm->traffic_load, sat_tab->fix_training_num_en, sat_tab->per_beam_training_pkt_num, sat_tab->decision_holding_period);
+
+		/*Beam_set number*/
+		if (*dm->band_type == ODM_BAND_5G) {
+			sat_tab->total_beam_set_num = sat_tab->total_beam_set_num_5g;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "5G beam_set num = ((%d))\n", sat_tab->total_beam_set_num);
+		} else {
+			sat_tab->total_beam_set_num = sat_tab->total_beam_set_num_2g;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "2G beam_set num = ((%d))\n", sat_tab->total_beam_set_num);
+		}
+
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			training_pkt_num_offset = sat_tab->beam_set_train_val_diff[j];
+
+			if ((sat_tab->per_beam_training_pkt_num) > training_pkt_num_offset)
+				sat_tab->beam_set_train_cnt[j] = sat_tab->per_beam_training_pkt_num - training_pkt_num_offset;
+			else
+				sat_tab->beam_set_train_cnt[j] = 1;
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Beam_Set[ %d ] training_pkt_offset = ((%d)), training_pkt_num = ((%d))\n",
+				j, sat_tab->beam_set_train_val_diff[j], sat_tab->beam_set_train_cnt[j]);
+		}
+		
+		sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+		sat_tab->update_beam_idx = 0;
+		sat_tab->pkt_counter = 0;
+		
+		sat_tab->fast_training_beam_num = 0;
+		phydm_set_rfu_beam_pattern_type2(dm);
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+phydm_beam_switch_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	sat_tab->pkt_skip_statistic_en = 1;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n", sat_tab->pkt_skip_statistic_en);
+
+	phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	/*odm_stall_execution(sat_tab->latch_time);*/
+	sat_tab->pkt_skip_statistic_en = 0;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n", sat_tab->pkt_skip_statistic_en, sat_tab->latch_time);
+}
+
+void
+phydm_beam_decision_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam decision Workitem Callback\n");
+	phydm_fast_ant_training_hl_smart_antenna_type2(dm);
+}
+#endif
+
+void
+phydm_process_rssi_for_hb_smtant_type2(
+	void		*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void,
+	u8		rssi_avg	
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct			*phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct				*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo	*sat_tab = &dm->dm_sat_table;
+	u8		train_pkt_number;
+	u32		beam_tmp;
+	u8		rx_power_ant0 = phy_info->rx_mimo_signal_strength[0];
+	u8		rx_power_ant1 = phy_info->rx_mimo_signal_strength[1];
+	u8		rx_evm_ant0 = phy_info->rx_mimo_evm_dbm[0];
+	u8		rx_evm_ant1 = phy_info->rx_mimo_evm_dbm[1];
+
+	/*[Beacon]*/
+	if (pktinfo->is_packet_beacon) {
+		sat_tab->beacon_counter++;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "MatchBSSID_beacon_counter = ((%d))\n", sat_tab->beacon_counter);
+
+		if (sat_tab->beacon_counter >= sat_tab->pre_beacon_counter + 2) {
+			sat_tab->update_beam_idx++;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
+				sat_tab->pre_beacon_counter, sat_tab->pkt_counter, sat_tab->update_beam_idx);
+			
+			sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+			sat_tab->pkt_counter = 0;
+		}
+	}
+	/*[data]*/
+	else if (pktinfo->is_packet_to_self) {
+		if (sat_tab->pkt_skip_statistic_en == 0) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "ID[%d] pkt_cnt=((%d)): Beam_set = ((%d)), RSSI{A,B,avg} = {%d, %d, %d}\n",
+				pktinfo->station_id, sat_tab->pkt_counter,  sat_tab->fast_training_beam_num, rx_power_ant0, rx_power_ant1, rssi_avg);
+
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Rate_ss = ((%d)), EVM{A,B} = {%d, %d}, RX Rate =", pktinfo->rate_ss,  rx_evm_ant0, rx_evm_ant1);
+			phydm_print_rate(dm, dm->rx_rate, DBG_ANT_DIV);
+
+
+			if (sat_tab->pkt_counter >= 1)  /*packet skip count*/
+			{
+				sat_tab->beam_set_rssi_avg_sum[sat_tab->fast_training_beam_num] += rssi_avg;
+				sat_tab->statistic_pkt_cnt[sat_tab->fast_training_beam_num]++;
+				
+				sat_tab->beam_path_rssi_sum[sat_tab->fast_training_beam_num][0] += rx_power_ant0;
+				sat_tab->beam_path_rssi_sum[sat_tab->fast_training_beam_num][1] += rx_power_ant1;
+
+				if (pktinfo->rate_ss == 2) {
+					sat_tab->beam_path_evm_2ss_sum[sat_tab->fast_training_beam_num][0] += rx_evm_ant0;
+					sat_tab->beam_path_evm_2ss_sum[sat_tab->fast_training_beam_num][1] += rx_evm_ant1;
+					sat_tab->beam_path_evm_2ss_cnt[sat_tab->fast_training_beam_num]++;
+				} else {
+					sat_tab->beam_path_evm_1ss_sum[sat_tab->fast_training_beam_num] += rx_evm_ant0;
+					sat_tab->beam_path_evm_1ss_cnt[sat_tab->fast_training_beam_num]++;
+				}
+			}
+			
+			sat_tab->pkt_counter++;
+
+			train_pkt_number = sat_tab->beam_set_train_cnt[sat_tab->fast_training_beam_num];
+
+			if (sat_tab->pkt_counter >= train_pkt_number) {
+				sat_tab->update_beam_idx++;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), Update_new_beam = ((%d))\n",
+					sat_tab->pre_beacon_counter, sat_tab->update_beam_idx);
+				
+				sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+				sat_tab->pkt_counter = 0;
+			}
+		}
+	}
+
+	if (sat_tab->update_beam_idx > 0) {
+		
+		sat_tab->update_beam_idx = 0;
+
+		if (sat_tab->fast_training_beam_num >= ((u32)sat_tab->total_beam_set_num - 1)) {
+			fat_tab->fat_state = FAT_DECISION_STATE;
+
+			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			phydm_fast_ant_training_hl_smart_antenna_type2(dm); /*go to make decision*/
+			#else
+			odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+			#endif
+
+
+		} else {
+			beam_tmp = sat_tab->fast_training_beam_num;
+			sat_tab->fast_training_beam_num++;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Update Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+			phydm_set_rfu_beam_pattern_type2(dm);
+			sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+
+			fat_tab->fat_state = FAT_TRAINING_STATE;
+		}
+	}
+	
+}
+#endif
+
+#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
+
+void
+phydm_hl_smart_ant_type1_init_8821a(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	u32			value32;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***8821A SmartAnt_Init => ant_div_type=[Hong-Lin Smart ant Type1]\n");
+
+#if 0
+	/* ---------------------------------------- */
+	/* GPIO 2-3 for Beam control */
+	/* reg0x66[2]=0 */
+	/* reg0x44[27:26] = 0 */
+	/* reg0x44[23:16]  enable_output for P_GPIO[7:0] */
+	/* reg0x44[15:8]  output_value for P_GPIO[7:0] */
+	/* reg0x40[1:0] = 0  GPIO function */
+	/* ------------------------------------------ */
+#endif
+
+	/*GPIO setting*/
+	odm_set_mac_reg(dm, 0x64, BIT(18), 0);
+	odm_set_mac_reg(dm, 0x44, BIT(27) | BIT(26), 0);
+	odm_set_mac_reg(dm, 0x44, BIT(19) | BIT(18), 0x3);	/*enable_output for P_GPIO[3:2]*/
+	/*odm_set_mac_reg(dm, 0x44, BIT(11)|BIT(10), 0);*/ /*output value*/
+	odm_set_mac_reg(dm, 0x40, BIT(1) | BIT(0), 0);		/*GPIO function*/
+
+	/*Hong_lin smart antenna HW setting*/
+	sat_tab->rfu_codeword_total_bit_num  = 24;/*max=32*/
+	sat_tab->rfu_each_ant_bit_num = 4;
+	sat_tab->beam_patten_num_each_ant = 4;
+
+#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#elif DEV_BUS_TYPE == RT_USB_INTERFACE
+	sat_tab->latch_time = 100; /*mu sec*/
+#endif
+	sat_tab->pkt_skip_statistic_en = 0;
+
+	sat_tab->ant_num = 1;/*max=8*/
+	sat_tab->ant_num_total = NUM_ANTENNA_8821A;
+	sat_tab->first_train_ant = MAIN_ANT;
+
+	sat_tab->rfu_codeword_table[0] = 0x0;
+	sat_tab->rfu_codeword_table[1] = 0x4;
+	sat_tab->rfu_codeword_table[2] = 0x8;
+	sat_tab->rfu_codeword_table[3] = 0xc;
+
+	sat_tab->rfu_codeword_table_5g[0] = 0x1;
+	sat_tab->rfu_codeword_table_5g[1] = 0x2;
+	sat_tab->rfu_codeword_table_5g[2] = 0x4;
+	sat_tab->rfu_codeword_table_5g[3] = 0x8;
+
+	sat_tab->fix_beam_pattern_en  = 0;
+	sat_tab->decision_holding_period = 0;
+
+	/*beam training setting*/
+	sat_tab->pkt_counter = 0;
+	sat_tab->per_beam_training_pkt_num = 10;
+
+	/*set default beam*/
+	sat_tab->fast_training_beam_num = 0;
+	sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+	phydm_set_all_ant_same_beam_num(dm);
+
+	fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+
+	odm_set_bb_reg(dm, 0xCA4, MASKDWORD, 0x01000100);
+	odm_set_bb_reg(dm, 0xCA8, MASKDWORD, 0x01000100);
+
+	/*[BB] FAT setting*/
+	odm_set_bb_reg(dm, 0xc08, BIT(18) | BIT(17) | BIT(16), sat_tab->ant_num);
+	odm_set_bb_reg(dm, 0xc08, BIT(31), 0); /*increase ant num every FAT period 0:+1, 1+2*/
+	odm_set_bb_reg(dm, 0x8c4, BIT(2) | BIT(1), 1); /*change cca antenna timming threshold if no CCA occurred: 0:200ms / 1:100ms / 2:no use / 3: 300*/
+	odm_set_bb_reg(dm, 0x8c4, BIT(0), 1); /*FAT_watchdog_en*/
+
+	value32 = odm_get_mac_reg(dm,  0x7B4, MASKDWORD);
+	odm_set_mac_reg(dm, 0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17)));	/*Reg7B4[16]=1 enable antenna training */
+	/*Reg7B4[17]=1 enable  match MAC addr*/
+	odm_set_mac_reg(dm, 0x7b4, 0xFFFF, 0);/*Match MAC ADDR*/
+	odm_set_mac_reg(dm, 0x7b0, MASKDWORD, 0);
+
+}
+
+u32
+phydm_construct_hl_beam_codeword(
+	void		*dm_void,
+	u32		*beam_pattern_idx,
+	u32		ant_num
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo		*sat_tab = &dm->dm_sat_table;
+	u32		codeword = 0;
+	u32		data_tmp;
+	u32		i;
+	u32		break_counter = 0;
+
+	if (ant_num < 8) {
+		for (i = 0; i < (sat_tab->ant_num_total); i++) {
+			/*PHYDM_DBG(dm,DBG_ANT_DIV, "beam_pattern_num[%x] = %x\n",i,beam_pattern_num[i] );*/
+			if ((i < (sat_tab->first_train_ant - 1)) || (break_counter >= (sat_tab->ant_num))) {
+				data_tmp = 0;
+				/**/
+			} else {
+				break_counter++;
+
+				if (beam_pattern_idx[i] == 0) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[0];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[0];
+
+				} else if (beam_pattern_idx[i] == 1) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[1];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[1];
+
+				} else if (beam_pattern_idx[i] == 2) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[2];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[2];
+
+				} else if (beam_pattern_idx[i] == 3) {
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[3];
+					else
+						data_tmp = sat_tab->rfu_codeword_table[3];
+				}
+			}
+
+
+			codeword |= (data_tmp << (i * 4));
+
+		}
+	}
+
+	return codeword;
+}
+
+void
+phydm_update_beam_pattern(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u8			i;
+	boolean			beam_ctrl_signal;
+	u32			one = 0x1;
+	u32			reg44_tmp_p, reg44_tmp_n, reg44_ori;
+	u8			devide_num = 4;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Set Beam Pattern =0x%x\n", codeword);
+
+	reg44_ori = odm_get_mac_reg(dm, 0x44, MASKDWORD);
+	reg44_tmp_p = reg44_ori;
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_ori =0x%x\n", reg44_ori);*/
+
+	devide_num = (sat_tab->rfu_protocol_type == 2) ? 6 : 4;
+
+	for (i = 0; i <= (codeword_length - 1); i++) {
+		beam_ctrl_signal = (boolean)((codeword & BIT(i)) >> i);
+
+		if (dm->debug_components & DBG_ANT_DIV) {
+			if (i == (codeword_length - 1)) {
+				pr_debug("%d ]\n", beam_ctrl_signal);
+				/**/
+			} else if (i == 0) {
+				pr_debug("Send codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
+				/**/
+			} else if ((i % devide_num) == (devide_num-1)) {
+				pr_debug("%d  |  ", beam_ctrl_signal);
+				/**/
+			} else {
+				pr_debug("%d ", beam_ctrl_signal);
+				/**/
+			}
+		}
+
+		if (dm->support_ic_type == ODM_RTL8821) {
+			#if (RTL8821A_SUPPORT == 1)
+			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*clean bit 10 & 11*/
+			reg44_tmp_p |= ((1 << 11) | (beam_ctrl_signal << 10));
+			reg44_tmp_n = reg44_ori & (~(BIT(11) | BIT(10)));
+
+			/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n);*/
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+			odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+			#endif
+		}
+		#if (RTL8822B_SUPPORT == 1)
+		else if (dm->support_ic_type == ODM_RTL8822B) {
+			if (sat_tab->rfu_protocol_type == 2) {
+				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*clean bit 8*/
+				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*get new clk high/low, exclusive-or*/
+
+	
+				reg44_tmp_p |= (beam_ctrl_signal << 8);
+				
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(10);
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal);*/
+				
+			} else {
+				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*clean bit 9 & 8*/
+				reg44_tmp_p |= ((1 << 9) | (beam_ctrl_signal << 8));
+				reg44_tmp_n = reg44_ori & (~(BIT(9) | BIT(8)));
+
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n); */
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(10);
+				odm_set_mac_reg(dm, 0x44, MASKDWORD, reg44_tmp_n);
+				ODM_delay_us(10);
+			}
+		}
+		#endif
+	}
+}
+
+void
+phydm_update_rx_idle_beam(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct			*fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u32			i;
+
+	sat_tab->update_beam_codeword = phydm_construct_hl_beam_codeword(dm,
+									       &sat_tab->rx_idle_beam[0],
+									       sat_tab->ant_num);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Set target beam_pattern codeword = (( 0x%x ))\n", sat_tab->update_beam_codeword);
+
+	for (i = 0; i < (sat_tab->ant_num); i++) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Update Rx-Idle-Beam ] RxIdleBeam[%d] =%d\n", i, sat_tab->rx_idle_beam[i]);
+		/**/
+	}
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+#endif
+
+	sat_tab->pre_codeword = sat_tab->update_beam_codeword;
+}
+
+void
+phydm_hl_smart_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+	u32			used = *_used;
+	u32			out_len = *_out_len;
+	u32			one = 0x1;
+	u32			codeword_length = sat_tab->rfu_codeword_total_bit_num;
+	u32			beam_ctrl_signal, i;
+	u8			devide_num = 4;
+
+	if (dm_value[0] == 1) { /*fix beam pattern*/
+
+		sat_tab->fix_beam_pattern_en = dm_value[1];
+
+		if (sat_tab->fix_beam_pattern_en == 1) {
+			sat_tab->fix_beam_pattern_codeword = dm_value[2];
+
+			if (sat_tab->fix_beam_pattern_codeword  > (one << codeword_length)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
+					sat_tab->fix_beam_pattern_codeword, codeword_length);
+				
+				(sat_tab->fix_beam_pattern_codeword) &= 0xffffff;
+				
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Auto modify to (0x%x)\n", sat_tab->fix_beam_pattern_codeword);
+			}
+
+			sat_tab->update_beam_codeword = sat_tab->fix_beam_pattern_codeword;
+
+			/*---------------------------------------------------------*/
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used, "Fix Beam Pattern\n");
+			
+			devide_num = (sat_tab->rfu_protocol_type == 2) ? 6 : 4;
+			
+			for (i = 0; i <= (codeword_length - 1); i++) {
+				beam_ctrl_signal = (boolean)((sat_tab->update_beam_codeword & BIT(i)) >> i);
+
+				if (i == (codeword_length - 1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "%d]\n",
+						       beam_ctrl_signal);
+					/**/
+				} else if (i == 0) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used,
+						       "Send Codeword[1:24] to RFU -> [%d",
+						       beam_ctrl_signal);
+					/**/
+				} else if ((i % devide_num) == (devide_num-1)) {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d|",
+						       beam_ctrl_signal);
+					/**/
+				} else {
+					PDM_SNPF(out_len, used,
+						       output + used,
+						       out_len - used, "%d",
+						       beam_ctrl_signal);
+					/**/
+				}
+			}
+			/*---------------------------------------------------------*/
+
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+			odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+			/*odm_stall_execution(1);*/
+#endif
+		} else if (sat_tab->fix_beam_pattern_en == 0)
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Smart Antenna: Enable\n");
+
+	} else if (dm_value[0] == 2) { /*set latch time*/
+
+		sat_tab->latch_time = dm_value[1];
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ]  latch_time =0x%x\n", sat_tab->latch_time);
+	} else if (dm_value[0] == 3) {
+		sat_tab->fix_training_num_en = dm_value[1];
+
+		if (sat_tab->fix_training_num_en == 1) {
+			sat_tab->per_beam_training_pkt_num = (u8)dm_value[2];
+			sat_tab->decision_holding_period = (u8)dm_value[3];
+
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[SmartAnt][Dbg] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
+				       sat_tab->fix_training_num_en,
+				       sat_tab->per_beam_training_pkt_num,
+				       sat_tab->decision_holding_period);
+
+		} else if (sat_tab->fix_training_num_en == 0) {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n");
+			/**/
+		}
+	} else if (dm_value[0] == 4) {
+		if (dm_value[1] == 1) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = MAIN_ANT;
+
+		} else if (dm_value[1] == 2) {
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = AUX_ANT;
+
+		} else if (dm_value[1] == 3) {
+			sat_tab->ant_num = 2;
+			sat_tab->first_train_ant = MAIN_ANT;
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
+			       sat_tab->ant_num,
+			       (sat_tab->first_train_ant - 1));
+	} else if (dm_value[0] == 5) {
+		if (dm_value[1] <= 3) {
+			sat_tab->rfu_codeword_table[dm_value[1]] = dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+					"[ SmartAnt ] Set Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					dm_value[1], dm_value[2]);
+		} else {
+			for (i = 0; i < 4; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[ SmartAnt ] Show Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					       i,
+					       sat_tab->rfu_codeword_table[i]);
+			}
+		}
+	} else if (dm_value[0] == 6) {
+		if (dm_value[1] <= 3) {
+			sat_tab->rfu_codeword_table_5g[dm_value[1]] = dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+					"[ SmartAnt ] Set Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					dm_value[1], dm_value[2]);
+		} else {
+			for (i = 0; i < 4; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					       out_len - used,
+					       "[ SmartAnt ] Show Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					       i,
+					       sat_tab->rfu_codeword_table_5g[i]);
+			}
+		}
+	} else if (dm_value[0] == 7) {
+		if (dm_value[1] <= 4) {
+			sat_tab->beam_patten_num_each_ant = dm_value[1];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Set Beam number = (( %d ))\n",
+				       sat_tab->beam_patten_num_each_ant);
+		} else {
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "[ SmartAnt ] Show Beam number = (( %d ))\n",
+				       sat_tab->beam_patten_num_each_ant);
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+
+void
+phydm_set_all_ant_same_beam_num(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+
+	if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) { /*2ant for 8821A*/
+
+		sat_tab->rx_idle_beam[0] = sat_tab->fast_training_beam_num;
+		sat_tab->rx_idle_beam[1] = sat_tab->fast_training_beam_num;
+	}
+
+	sat_tab->update_beam_codeword = phydm_construct_hl_beam_codeword(dm,
+									       &sat_tab->rx_idle_beam[0],
+									       sat_tab->ant_num);
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Set all ant beam_pattern: codeword = (( 0x%x ))\n", sat_tab->update_beam_codeword);
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#else
+	odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+	/*odm_stall_execution(1);*/
+#endif
+}
+
+void
+odm_fast_ant_training_hl_smart_antenna_type1(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo		*sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct		*fat_tab	 = &dm->dm_fat_table;
+	struct sw_antenna_switch		*dm_swat_table = &dm->dm_swat_table;
+	u32		codeword = 0, i, j;
+	u32		target_ant;
+	u32		avg_rssi_tmp, avg_rssi_tmp_ma;
+	u32		target_ant_beam_max_rssi[SUPPORT_RF_PATH_NUM] = {0};
+	u32		max_beam_ant_rssi = 0;
+	u32		target_ant_beam[SUPPORT_RF_PATH_NUM] = {0};
+	u32		beam_tmp;
+	u8		next_ant;
+	u32		rssi_sorting_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u32		rank_idx_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u32		rank_idx_out[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u8		per_beam_rssi_diff_tmp = 0, training_pkt_num_offset;
+	u32		break_counter = 0;
+	u32		used_ant;
+
+
+	if (!dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Link->no Link\n");
+			fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+			odm_ant_div_on_off(dm, ANTDIV_OFF);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+
+			fat_tab->fat_state = FAT_PREPARE_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "change to (( %d )) FAT_state\n", fat_tab->fat_state);
+
+			/*sat_tab->fast_training_beam_num = 0;*/
+			/*phydm_set_all_ant_same_beam_num(dm);*/
+
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
+
+	if (*fat_tab->p_force_tx_ant_by_desc == false) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
+
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "HL Smart ant Training: state (( %d ))\n", fat_tab->fat_state);*/
+
+	/* [DECISION STATE] */
+	/*=======================================================================================*/
+	if (fat_tab->fat_state == FAT_DECISION_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 3. In Decision state]\n");
+		phydm_fast_training_enable(dm, FAT_OFF);
+
+		break_counter = 0;
+		/*compute target beam in each antenna*/
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				if (sat_tab->pkt_rssi_cnt[i][j] == 0) {
+					avg_rssi_tmp = sat_tab->pkt_rssi_pre[i][j];
+					avg_rssi_tmp = (avg_rssi_tmp >= 2) ? (avg_rssi_tmp - 2) : avg_rssi_tmp;
+					avg_rssi_tmp_ma = avg_rssi_tmp;
+				} else {
+					avg_rssi_tmp = (sat_tab->pkt_rssi_sum[i][j]) / (sat_tab->pkt_rssi_cnt[i][j]);
+					avg_rssi_tmp_ma = (avg_rssi_tmp + sat_tab->pkt_rssi_pre[i][j]) >> 1;
+				}
+
+				rssi_sorting_seq[j] = avg_rssi_tmp;
+				sat_tab->pkt_rssi_pre[i][j] = avg_rssi_tmp;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ant[%d], Beam[%d]: pkt_cnt=(( %d )), avg_rssi_MA=(( %d )), avg_rssi=(( %d ))\n",
+					i, j, sat_tab->pkt_rssi_cnt[i][j], avg_rssi_tmp_ma, avg_rssi_tmp);
+
+				if (avg_rssi_tmp > target_ant_beam_max_rssi[i]) {
+					target_ant_beam[i] = j;
+					target_ant_beam_max_rssi[i] = avg_rssi_tmp;
+				}
+
+				/*reset counter value*/
+				sat_tab->pkt_rssi_sum[i][j] = 0;
+				sat_tab->pkt_rssi_cnt[i][j] = 0;
+
+			}
+			sat_tab->rx_idle_beam[i] = target_ant_beam[i];
+			PHYDM_DBG(dm, DBG_ANT_DIV, "---------> Target of ant[%d]: Beam_num-(( %d )) RSSI= ((%d))\n",
+				i,  target_ant_beam[i], target_ant_beam_max_rssi[i]);
+
+			/*sorting*/
+			/*
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Pre]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]);
+			*/
+
+			/*phydm_seq_sorting(dm, &rssi_sorting_seq[0], &rank_idx_seq[0], &rank_idx_out[0], SUPPORT_BEAM_PATTERN_NUM);*/
+
+			/*
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rank_idx_seq = [%d, %d, %d, %d]\n", rank_idx_seq[0], rank_idx_seq[1], rank_idx_seq[2], rank_idx_seq[3]);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rank_idx_out = [%d, %d, %d, %d]\n", rank_idx_out[0], rank_idx_out[1], rank_idx_out[2], rank_idx_out[3]);
+			*/
+
+			if (target_ant_beam_max_rssi[i] > max_beam_ant_rssi) {
+				target_ant = i;
+				max_beam_ant_rssi = target_ant_beam_max_rssi[i];
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "Target of ant = (( %d )) max_beam_ant_rssi = (( %d ))\n",
+					target_ant,  max_beam_ant_rssi);*/
+			}
+			break_counter++;
+			if (break_counter >= (sat_tab->ant_num))
+				break;
+		}
+
+#ifdef CONFIG_FAT_PATCH
+		break_counter = 0;
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				per_beam_rssi_diff_tmp = (u8)(max_beam_ant_rssi - sat_tab->pkt_rssi_pre[i][j]);
+				sat_tab->beam_train_rssi_diff[i][j] = per_beam_rssi_diff_tmp;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ant[%d], Beam[%d]: RSSI_diff= ((%d))\n",
+						i,  j, per_beam_rssi_diff_tmp);
+			}
+			break_counter++;
+			if (break_counter >= (sat_tab->ant_num))
+				break;
+		}
+#endif
+
+		if (target_ant == 0)
+			target_ant = MAIN_ANT;
+		else if (target_ant == 1)
+			target_ant = AUX_ANT;
+
+		if (sat_tab->ant_num > 1) {
+			/* [ update RX ant ]*/
+			odm_update_rx_idle_ant(dm, (u8)target_ant);
+
+			/* [ update TX ant ]*/
+			odm_update_tx_ant(dm, (u8)target_ant, (fat_tab->train_idx));
+		}
+
+		/*set beam in each antenna*/
+		phydm_update_rx_idle_beam(dm);
+
+		odm_ant_div_on_off(dm, ANTDIV_ON);
+		fat_tab->fat_state = FAT_PREPARE_STATE;
+		return;
+
+	}
+	/* [TRAINING STATE] */
+	else if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2. In Training state]\n");
+
+		PHYDM_DBG(dm, DBG_ANT_DIV, "fat_beam_n = (( %d )), pre_fat_beam_n = (( %d ))\n",
+			sat_tab->fast_training_beam_num, sat_tab->pre_fast_training_beam_num);
+
+		if (sat_tab->fast_training_beam_num > sat_tab->pre_fast_training_beam_num)
+
+			sat_tab->force_update_beam_en = 0;
+
+		else {
+			sat_tab->force_update_beam_en = 1;
+
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+			if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n", sat_tab->fast_training_beam_num);
+				fat_tab->fat_state = FAT_DECISION_STATE;
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
+
+			} else {
+				sat_tab->fast_training_beam_num++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
+				phydm_set_all_ant_same_beam_num(dm);
+				fat_tab->fat_state = FAT_TRAINING_STATE;
+
+			}
+		}
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[prepare state] Update Pre_Beam =(( %d ))\n", sat_tab->pre_fast_training_beam_num);
+	}
+	/*  [Prepare state] */
+	/*=======================================================================================*/
+	else if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n\n[ 1. In Prepare state]\n");
+
+		if (dm->pre_traffic_load == (dm->traffic_load)) {
+			if (sat_tab->decision_holding_period != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Holding_period = (( %d )), return!!!\n", sat_tab->decision_holding_period);
+				sat_tab->decision_holding_period--;
+				return;
+			}
+		}
+
+
+		/* Set training packet number*/
+		if (sat_tab->fix_training_num_en == 0) {
+			switch (dm->traffic_load) {
+			case TRAFFIC_HIGH:
+				sat_tab->per_beam_training_pkt_num = 8;
+				sat_tab->decision_holding_period = 2;
+				break;
+			case TRAFFIC_MID:
+				sat_tab->per_beam_training_pkt_num = 6;
+				sat_tab->decision_holding_period = 3;
+				break;
+			case TRAFFIC_LOW:
+				sat_tab->per_beam_training_pkt_num = 3; /*ping 60000*/
+				sat_tab->decision_holding_period = 4;
+				break;
+			case TRAFFIC_ULTRA_LOW:
+				sat_tab->per_beam_training_pkt_num = 1;
+				sat_tab->decision_holding_period = 6;
+				break;
+			default:
+				break;
+			}
+		}
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Fix_training_en = (( %d )), training_pkt_num_base = (( %d )), holding_period = ((%d))\n",
+			sat_tab->fix_training_num_en, sat_tab->per_beam_training_pkt_num, sat_tab->decision_holding_period);
+
+
+#ifdef CONFIG_FAT_PATCH
+		break_counter = 0;
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				per_beam_rssi_diff_tmp = sat_tab->beam_train_rssi_diff[i][j];
+				training_pkt_num_offset = per_beam_rssi_diff_tmp;
+
+				if ((sat_tab->per_beam_training_pkt_num) > training_pkt_num_offset)
+					sat_tab->beam_train_cnt[i][j] = sat_tab->per_beam_training_pkt_num - training_pkt_num_offset;
+				else
+					sat_tab->beam_train_cnt[i][j] = 1;
+
+
+				PHYDM_DBG(dm, DBG_ANT_DIV, "ant[%d]: Beam_num-(( %d ))  training_pkt_num = ((%d))\n",
+					i,  j, sat_tab->beam_train_cnt[i][j]);
+			}
+			break_counter++;
+			if (break_counter >= (sat_tab->ant_num))
+				break;
+		}
+
+
+		phydm_fast_training_enable(dm, FAT_OFF);
+		sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+		sat_tab->update_beam_idx = 0;
+
+		if (*dm->band_type == ODM_BAND_5G) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Set 5G ant\n");
+			/*used_ant = (sat_tab->first_train_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;*/
+			used_ant = sat_tab->first_train_ant;
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Set 2.4G ant\n");
+			used_ant = sat_tab->first_train_ant;
+		}
+
+		odm_update_rx_idle_ant(dm, (u8)used_ant);
+
+#else
+		/* Set training MAC addr. of target */
+		odm_set_next_mac_addr_target(dm);
+		phydm_fast_training_enable(dm, FAT_ON);
+#endif
+
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		sat_tab->pkt_counter = 0;
+		sat_tab->fast_training_beam_num = 0;
+		phydm_set_all_ant_same_beam_num(dm);
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+	}
+
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+void
+phydm_beam_switch_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct smt_ant_honbo			*sat_tab = &dm->dm_sat_table;
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	sat_tab->pkt_skip_statistic_en = 1;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n", sat_tab->pkt_skip_statistic_en);
+
+	phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+
+#if DEV_BUS_TYPE != RT_PCI_INTERFACE
+	/*odm_stall_execution(sat_tab->latch_time);*/
+	sat_tab->pkt_skip_statistic_en = 0;
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n", sat_tab->pkt_skip_statistic_en, sat_tab->latch_time);
+}
+
+void
+phydm_beam_decision_workitem_callback(
+	void	*context
+)
+{
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Beam decision Workitem Callback\n");
+	odm_fast_ant_training_hl_smart_antenna_type1(dm);
+}
+#endif
+
+
+#endif /*#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1*/
+
+
+#endif/*#ifdef CONFIG_HL_SMART_ANTENNA*/
+
+
+
+void
+phydm_smt_ant_config(
+	void		*dm_void
+)
+{
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant				*smtant_table = &dm->smtant_table;
+
+	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+	
+		dm->support_ability |= ODM_BB_SMT_ANT;
+		smtant_table->smt_ant_vendor = SMTANT_CUMITEK;
+		smtant_table->smt_ant_type = 1;
+		#if (RTL8822B_SUPPORT == 1)
+		dm->rfe_type = SMTANT_TMP_RFE_TYPE;
+		#endif
+	#elif (defined(CONFIG_HL_SMART_ANTENNA))
+	
+		dm->support_ability |= ODM_BB_SMT_ANT;
+		smtant_table->smt_ant_vendor = SMTANT_HON_BO;
+		
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		smtant_table->smt_ant_type = 1;
+		#endif
+		
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		smtant_table->smt_ant_type = 2;
+		#endif
+	#endif
+
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[SmtAnt Config] Vendor=((%d)), Smt_ant_type =((%d))\n",
+		smtant_table->smt_ant_vendor, smtant_table->smt_ant_type);
+}
+#endif
+
+
+void
+phydm_smt_ant_init(
+	void		*dm_void
+)
+{
+#if (defined(CONFIG_SMART_ANTENNA))
+	struct	dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct	smt_ant				*smtant_table = &dm->smtant_table;
+	
+	phydm_smt_ant_config(dm);
+	
+
+	if (smtant_table->smt_ant_vendor == SMTANT_CUMITEK) {
+		
+		#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+		#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			phydm_cumitek_smt_ant_init_8822b(dm);
+			/**/
+		}
+		#endif
+		
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
+			phydm_cumitek_smt_ant_init_8197f(dm);
+			/**/
+		}
+		#endif
+		#endif /*#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))*/
+		
+	} else if (smtant_table->smt_ant_vendor == SMTANT_HON_BO) {
+		#if (defined(CONFIG_HL_SMART_ANTENNA))
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		if (dm->support_ic_type == ODM_RTL8821) {
+			phydm_hl_smart_ant_type1_init_8821a(dm);
+			/**/
+		}
+		#endif
+		
+		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			phydm_hl_smart_ant_type2_init_8822b(dm);
+			/**/
+		}
+		#endif
+		#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+	}
+#endif	
+}
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_smt_ant.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_smt_ant.h
new file mode 100644
index 000000000000..c2a34814d5c6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_smt_ant.h
@@ -0,0 +1,250 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDMSMTANT_H__
+#define    __PHYDMSMTANT_H__
+
+/*#define SMT_ANT_VERSION	"1.1"*/ /*2017.03.13*/
+/*#define SMT_ANT_VERSION	"1.2"*/ /*2017.03.28*/
+#define SMT_ANT_VERSION	"2.0" /* Add Cumitek SmtAnt 2017.05.25*/
+
+#define	SMTANT_RTK		1
+#define	SMTANT_HON_BO	2
+#define	SMTANT_CUMITEK	3
+
+#if (defined(CONFIG_SMART_ANTENNA))
+
+
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+struct smt_ant_cumitek {
+	u8	tx_ant_idx[2][ODM_ASSOCIATE_ENTRY_NUM]; /*[pathA~B] [MACID 0~128]*/
+	u8	rx_default_ant_idx[2]; /*[pathA~B]*/
+};
+#endif
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+struct smt_ant_honbo {
+	u32	latch_time;
+	boolean	pkt_skip_statistic_en;
+	u32	fix_beam_pattern_en;
+	u32	fix_training_num_en;
+	u32	fix_beam_pattern_codeword;
+	u32	update_beam_codeword;
+	u32	ant_num; /*number of "used" smart beam antenna*/
+	u32	ant_num_total;/*number of "total" smart beam antenna*/
+	u32	first_train_ant; /*decide witch antenna to train first*/
+
+	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+	u32	pkt_rssi_pre[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];/*rssi of each path with a certain beam pattern*/
+	u8	beam_train_rssi_diff[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
+	u8	beam_train_cnt[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
+	u32	rfu_codeword_table[4]; /*2G beam truth table*/
+	u32	rfu_codeword_table_5g[4]; /*5G beam truth table*/
+	u32	beam_patten_num_each_ant;/*number of  beam can be switched in each antenna*/
+	u32	rx_idle_beam[SUPPORT_RF_PATH_NUM];
+	u32	pkt_rssi_sum[8][SUPPORT_BEAM_PATTERN_NUM];
+	u32	pkt_rssi_cnt[8][SUPPORT_BEAM_PATTERN_NUM];
+	#endif
+	
+	u32	fast_training_beam_num;/*current training beam_set index*/
+	u32	pre_fast_training_beam_num;/*pre training beam_set index*/
+	u32	rfu_codeword_total_bit_num; /* total bit number of RFU protocol*/
+	u32	rfu_each_ant_bit_num; /* bit number of RFU protocol for each ant*/
+	u8	per_beam_training_pkt_num;
+	u8	decision_holding_period;
+	
+	
+	u32	pre_codeword;
+	boolean	force_update_beam_en;
+	u32	beacon_counter;
+	u32	pre_beacon_counter;
+	u8	pkt_counter;		/*packet number that each beam-set should be colected in training state*/
+	u8	update_beam_idx;	/*the index announce that the beam can be updated*/
+	u8	rfu_protocol_type;
+	u16	rfu_protocol_delay_time;
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_WORK_ITEM	hl_smart_antenna_workitem;
+	RT_WORK_ITEM	hl_smart_antenna_decision_workitem;
+	#endif
+
+
+	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+	u8	beam_set_avg_rssi_pre[SUPPORT_BEAM_SET_PATTERN_NUM];		/*avg pre_rssi of each beam set*/
+	u8	beam_set_train_val_diff[SUPPORT_BEAM_SET_PATTERN_NUM];	/*rssi of a beam pattern set, ex: a set = {ant1_beam=1, ant2_beam=3}*/
+	u8	beam_set_train_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];			/*training pkt num of each beam set*/
+	u32	beam_set_rssi_avg_sum[SUPPORT_BEAM_SET_PATTERN_NUM];			/*RSSI_sum of avg(pathA,pathB) for each beam-set)*/
+	u32	beam_path_rssi_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*RSSI_sum of each path for each beam-set)*/
+
+	u8	beam_set_avg_evm_2ss_pre[SUPPORT_BEAM_SET_PATTERN_NUM];	
+	u32	beam_path_evm_2ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*2SS evm_sum of each path for each beam-set)*/
+	u32	beam_path_evm_2ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
+
+	u8	beam_set_avg_evm_1ss_pre[SUPPORT_BEAM_SET_PATTERN_NUM];
+	u32	beam_path_evm_1ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM];/*1SS evm_sum of each path for each beam-set)*/
+	u32	beam_path_evm_1ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
+	
+	u32	statistic_pkt_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];				/*statistic_pkt_cnt for SmtAnt make decision*/
+	
+	u8	total_beam_set_num;	/*number of  beam set can be switched*/
+	u8	total_beam_set_num_2g;/*number of  beam set can be switched in 2G*/
+	u8	total_beam_set_num_5g;/*number of  beam set can be switched in 5G*/
+
+	u8	rfu_codeword_table_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*2G beam truth table*/
+	u8	rfu_codeword_table_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*5G beam truth table*/
+	u8	rx_idle_beam_set_idx;	/*the filanl decsion result*/
+	#endif
+	
+
+};
+#endif /*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+
+struct smt_ant {
+	u8	smt_ant_vendor;
+	u8	smt_ant_type;
+	u8	tx_desc_mode; /*0:3 bit mode, 1:2 bit mode*/
+	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+	struct	smt_ant_cumitek	cumi_smtant_table;
+	#endif
+};
+
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+void
+phydm_cumitek_smt_tx_ant_update(
+	void		*dm_void,
+	u8		tx_ant_idx_path_a,
+	u8		tx_ant_idx_path_b,
+	u32		mac_id
+);
+
+void
+phydm_cumitek_smt_rx_default_ant_update(
+	void		*dm_void,
+	u8		rx_ant_idx_path_a,
+	u8		rx_ant_idx_path_b
+);
+
+void
+phydm_cumitek_smt_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif
+
+
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_beam_switch_workitem_callback(
+	void	*context
+);
+
+void
+phydm_beam_decision_workitem_callback(
+	void	*context
+);
+#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+
+
+
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+void
+phydm_hl_smart_ant_type2_init_8822b(
+	void		*dm_void
+);
+
+void
+phydm_update_beam_pattern_type2(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+);
+
+void
+phydm_set_rfu_beam_pattern_type2(
+	void		*dm_void
+);
+
+void
+phydm_hl_smart_ant_debug_type2(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+void
+phydm_process_rssi_for_hb_smtant_type2(
+	void		*dm_void,
+	void		*phy_info_void,
+	void		*pkt_info_void,
+	u8		rssi_avg	
+);
+
+#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE2))*/
+
+
+#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
+
+void
+phydm_update_beam_pattern(
+	void		*dm_void,
+	u32		codeword,
+	u32		codeword_length
+);
+
+void
+phydm_set_all_ant_same_beam_num(
+	void		*dm_void
+);
+
+void
+phydm_hl_smart_ant_debug(
+	void		*dm_void,
+	char		input[][16],
+	u32		*_used,
+	char		*output,
+	u32		*_out_len,
+	u32		input_num
+);
+
+#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))*/
+#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+#endif/*#if (defined(CONFIG_SMART_ANTENNA))*/
+
+void
+phydm_smt_ant_init(
+	void		*dm_void
+);
+
+#endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_soml.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_soml.c
new file mode 100644
index 000000000000..9e846a9bef31
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_soml.c
@@ -0,0 +1,863 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/* ************************************************************
+ * include files
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void
+phydm_dynamicsoftmletting(
+	void		*dm_void
+)
+{
+	struct dm_struct            *dm = (struct dm_struct *)dm_void;
+	u32 ret_val;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (*dm->mp_mode == false) {
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			if ((!dm->is_linked)|(dm->iot_table.is_linked_cmw500))
+				return;
+
+			if (true == dm->bsomlenabled) {
+				PHYDM_DBG(dm, ODM_COMP_API, "PHYDM_DynamicSoftMLSetting(): SoML has been enable, skip dynamic SoML switch\n");
+				return; 		
+			}
+
+			ret_val = odm_get_bb_reg(dm, 0xf8c, MASKBYTE0);
+			PHYDM_DBG(dm, ODM_COMP_API, "PHYDM_DynamicSoftMLSetting(): Read 0xF8C = 0x%08X\n", ret_val);
+
+			if (ret_val < 0x16) {
+				PHYDM_DBG(dm, ODM_COMP_API, "PHYDM_DynamicSoftMLSetting(): 0xF8C(== 0x%08X) < 0x16, enable SoML\n", ret_val);
+				phydm_somlrxhp_setting(dm, true);
+				/*odm_set_bb_reg(dm, 0x19a8, MASKDWORD, 0xc10a0000);*/
+				dm->bsomlenabled = true;
+			}
+		}
+	}
+#endif
+
+}
+
+#ifdef CONFIG_ADAPTIVE_SOML
+void
+phydm_soml_on_off(
+	void		*dm_void,
+	u8		swch
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if (swch == SOML_ON) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "(( Turn on )) SOML\n");
+
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_somlrxhp_setting(dm, true);
+		else if (dm->support_ic_type == ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0x998, BIT(6), swch);
+
+	} else if (swch == SOML_OFF) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "(( Turn off )) SOML\n");
+
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_somlrxhp_setting(dm, false);
+		else if (dm->support_ic_type == ODM_RTL8197F)
+			odm_set_bb_reg(dm, 0x998, BIT(6), swch);
+	}
+	dm_soml_table->soml_on_off = swch;
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_adaptive_soml_callback(
+	struct phydm_timer_list		*timer
+)
+{
+	void		*adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm_soml_table->phydm_adaptive_soml_workitem);
+#else
+	{
+		/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_callback\n");*/
+		phydm_adsl(dm);
+	}
+#endif
+#else
+	odm_schedule_work_item(&dm_soml_table->phydm_adaptive_soml_workitem);
+#endif
+}
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void		*context
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	void		*adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_workitem_callback\n");*/
+	phydm_adsl(dm);
+#endif
+}
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void
+phydm_adaptive_soml_callback(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	void	*padapter = dm->adapter;
+	if (*(dm->is_net_closed) == true)
+		return;
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_adsl(dm);
+	else {
+		/* Can't do I/O in timer callback*/
+		rtw_run_in_thread_cmd(padapter, phydm_adaptive_soml_workitem_callback, padapter);
+	}
+}
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void	*context
+)
+{
+	void *	adapter = (void *)context;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->odmpriv;
+
+	/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_workitem_callback\n");*/
+	phydm_adsl(dm);
+}
+
+#else
+
+void
+phydm_adaptive_soml_callback(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "******SOML_Callback******\n");
+	phydm_adsl(dm);
+
+}
+#endif
+
+void
+phydm_rx_qam_for_soml(
+	void		*dm_void,
+	void		*pkt_info_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml				*dm_soml_table = &dm->dm_soml_table;
+	struct phydm_perpkt_info_struct	*pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	u8								date_rate = (pktinfo->data_rate & 0x7f);
+
+	if (dm_soml_table->soml_state_cnt < ((dm_soml_table->soml_train_num)<<1)) {
+		if (dm_soml_table->soml_on_off == SOML_ON)
+			return;
+		else if (dm_soml_table->soml_on_off == SOML_OFF) {
+			if ((date_rate >= ODM_RATEMCS8) && (date_rate <= ODM_RATEMCS10))
+				dm_soml_table->num_ht_qam[BPSK_QPSK]++;
+
+			else if ((date_rate >= ODM_RATEMCS11) && (date_rate <= ODM_RATEMCS12))
+				dm_soml_table->num_ht_qam[QAM16]++;
+
+			else if ((date_rate >= ODM_RATEMCS13) && (date_rate <= ODM_RATEMCS15))
+				dm_soml_table->num_ht_qam[QAM64]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS0) && (date_rate <= ODM_RATEVHTSS2MCS2))
+				dm_soml_table->num_vht_qam[BPSK_QPSK]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS3) && (date_rate <= ODM_RATEVHTSS2MCS4))
+				dm_soml_table->num_vht_qam[QAM16]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS5) && (date_rate <= ODM_RATEVHTSS2MCS5))
+				dm_soml_table->num_vht_qam[QAM64]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS8) && (date_rate <= ODM_RATEVHTSS2MCS9))
+				dm_soml_table->num_vht_qam[QAM256]++;
+		}
+	}
+}
+
+void
+phydm_soml_reset_rx_rate(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+	u8	order;
+
+	for (order = 0; order < HT_ORDER_TYPE; order++)
+		dm_soml_table->num_ht_qam[order] = 0;
+
+	for (order = 0; order < VHT_ORDER_TYPE; order++)
+		dm_soml_table->num_vht_qam[order] = 0;
+}
+
+void
+phydm_soml_cfo_process(
+	void		*dm_void,
+	s32		*diff_a,
+	s32		*diff_b
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+	u32	value32, value32_1, value32_2, value32_3;
+	s32	cfo_acq_a, cfo_acq_b, cfo_end_a, cfo_end_b;
+	s32	cfo_diff_a, cfo_diff_b;
+
+	value32 = odm_get_bb_reg(dm, 0xd10, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, 0xd14, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, 0xd50, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, 0xd54, MASKDWORD);
+
+	cfo_acq_a = (s32)((value32 & 0x1fff0000) >> 16);
+	cfo_end_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+	cfo_acq_b = (s32)((value32_2 & 0x1fff0000) >> 16);
+	cfo_end_b = (s32)((value32_3 & 0x1fff0000) >> 16);
+
+	*diff_a = ((cfo_acq_a >= cfo_end_a) ? (cfo_acq_a - cfo_end_a) : (cfo_end_a - cfo_acq_a));
+	*diff_b = ((cfo_acq_b >= cfo_end_b) ? (cfo_acq_b - cfo_end_b) : (cfo_end_b - cfo_acq_b));
+
+	*diff_a =  ((*diff_a * 312) + (*diff_a >> 1)) >> 12;  /* 312.5/2^12 */
+	*diff_b = ((*diff_b * 312) + (*diff_b >> 1)) >> 12; /* 312.5/2^12 */
+
+}
+
+void
+phydm_soml_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char		*output,
+	u32		*_out_len
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm_value[0] == 1) { /*Turn on/off SOML*/
+		dm_soml_table->soml_select = (u8)dm_value[1];
+
+	} else if (dm_value[0] == 2) { /*training number for SOML*/
+
+		dm_soml_table->soml_train_num = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_train_num = ((%d))\n",
+			       dm_soml_table->soml_train_num);
+	} else if (dm_value[0] == 3) { /*training interval for SOML*/
+
+		dm_soml_table->soml_intvl = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_intvl = ((%d))\n",
+			       dm_soml_table->soml_intvl);
+	} else if (dm_value[0] == 4) { /*function period for SOML*/
+
+		dm_soml_table->soml_period = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_period = ((%d))\n",
+			       dm_soml_table->soml_period);
+	} else if (dm_value[0] == 5) { /*delay_time for SOML*/
+
+		dm_soml_table->soml_delay_time = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_delay_time = ((%d))\n",
+			       dm_soml_table->soml_delay_time);
+	} else if (dm_value[0] == 6) { /* for SOML Rx QAM distribution th*/
+		if (dm_value[1] == 256) {
+			dm_soml_table->qam256_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "qam256_dist_th = ((%d))\n",
+				       dm_soml_table->qam256_dist_th);
+		} else if (dm_value[1] == 64) {
+			dm_soml_table->qam64_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "qam64_dist_th = ((%d))\n",
+				       dm_soml_table->qam64_dist_th);
+		} else if (dm_value[1] == 16) {
+			dm_soml_table->qam16_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "qam16_dist_th = ((%d))\n",
+				       dm_soml_table->qam16_dist_th);
+		} else if (dm_value[1] == 4) {
+			dm_soml_table->bpsk_qpsk_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "bpsk_qpsk_dist_th = ((%d))\n",
+				       dm_soml_table->bpsk_qpsk_dist_th);
+		}
+	} else if (dm_value[0] == 7) { /* for SOML cfo th*/
+		if (dm_value[1] == 256) {
+			dm_soml_table->cfo_qam256_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qam256_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qam256_th);
+		} else if (dm_value[1] == 64) {
+			dm_soml_table->cfo_qam64_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qam64_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qam64_th);
+		} else if (dm_value[1] == 16) {
+			dm_soml_table->cfo_qam16_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qam16_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qam16_th);
+		} else if (dm_value[1] == 4) {
+			dm_soml_table->cfo_qpsk_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used,
+				       out_len - used,
+				       "cfo_qpsk_th = ((%d KHz))\n",
+				       dm_soml_table->cfo_qpsk_th);
+		}
+	} else if (dm_value[0] == 100) { /*show parameters*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_select = ((%d))\n",
+			       dm_soml_table->soml_select);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_train_num = ((%d))\n",
+			       dm_soml_table->soml_train_num);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_intvl = ((%d))\n",
+			       dm_soml_table->soml_intvl);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_period = ((%d))\n",
+			       dm_soml_table->soml_period);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "soml_delay_time = ((%d))\n\n",
+			       dm_soml_table->soml_delay_time);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "qam256_dist_th = ((%d)),  qam64_dist_th = ((%d)), ",
+			       dm_soml_table->qam256_dist_th,
+			       dm_soml_table->qam64_dist_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "qam16_dist_th = ((%d)),  bpsk_qpsk_dist_th = ((%d))\n",
+			       dm_soml_table->qam16_dist_th,
+			       dm_soml_table->bpsk_qpsk_dist_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "cfo_qam256_th = ((%d KHz)),  cfo_qam64_th = ((%d KHz)), ",
+			       dm_soml_table->cfo_qam256_th,
+			       dm_soml_table->cfo_qam64_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			       "cfo_qam16_th = ((%d KHz)),  cfo_qpsk_th  = ((%d KHz))\n",
+			       dm_soml_table->cfo_qam16_th,
+			       dm_soml_table->cfo_qpsk_th);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void
+phydm_soml_statistics(
+	void		*dm_void,
+	u8		on_off_state
+
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	u8	i;
+	u32	num_bytes_diff;
+
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (on_off_state == SOML_ON) {
+			for (i = 0; i < HT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_ht_bytes[i] - dm_soml_table->pre_num_ht_bytes[i];
+				dm_soml_table->num_ht_bytes_on[i] += num_bytes_diff;
+				dm_soml_table->pre_num_ht_bytes[i] = dm_soml_table->num_ht_bytes[i];
+			}
+		} else if (on_off_state == SOML_OFF) {
+			for (i = 0; i < HT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_ht_bytes[i] - dm_soml_table->pre_num_ht_bytes[i];
+				dm_soml_table->num_ht_bytes_off[i] += num_bytes_diff;
+				dm_soml_table->pre_num_ht_bytes[i] = dm_soml_table->num_ht_bytes[i];
+			}
+		}
+	} else if (dm->support_ic_type == ODM_RTL8822B) {
+		if (on_off_state == SOML_ON) {
+			for (i = 0; i < VHT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_vht_bytes[i] - dm_soml_table->pre_num_vht_bytes[i];
+				dm_soml_table->num_vht_bytes_on[i] += num_bytes_diff;
+				dm_soml_table->pre_num_vht_bytes[i] = dm_soml_table->num_vht_bytes[i];
+			}
+		} else if (on_off_state == SOML_OFF) {
+			for (i = 0; i < VHT_RATE_IDX; i++) {
+				num_bytes_diff = dm_soml_table->num_vht_bytes[i] - dm_soml_table->pre_num_vht_bytes[i];
+				dm_soml_table->num_vht_bytes_off[i] += num_bytes_diff;
+				dm_soml_table->pre_num_vht_bytes[i] = dm_soml_table->num_vht_bytes[i];
+			}
+		}
+	}
+}
+
+void
+phydm_adsl(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml		*dm_soml_table = &dm->dm_soml_table;
+
+	u8	i;
+	u8	next_on_off;
+	u8	rate_num = 1, rate_ss_shift = 0;
+	u32	byte_total_on = 0, byte_total_off = 0, num_total_qam = 0;
+	u32	ht_reset[HT_RATE_IDX] = {0}, vht_reset[VHT_RATE_IDX] = {0};
+	u8	size = sizeof(ht_reset[0]);
+
+	if (dm->support_ic_type & ODM_IC_4SS)
+		rate_num = 4;
+	else if (dm->support_ic_type & ODM_IC_3SS)
+		rate_num = 3;
+	else if (dm->support_ic_type & ODM_IC_2SS)
+		rate_num = 2;
+
+	if ((dm->support_ic_type & ODM_ADAPTIVE_SOML_SUPPORT_IC)) {
+		if (TRUE) {
+			if ((dm->rssi_min >= SOML_RSSI_TH_HIGH) || (dm_soml_table->is_soml_method_enable == 1)) {
+				PHYDM_DBG(dm, DBG_ADPTV_SOML, "> TH_H || is_soml_method_enable==1\n");
+				PHYDM_DBG(dm, DBG_ADPTV_SOML, "soml_state_cnt =((%d)),  soml_on_off =((%s))\n", dm_soml_table->soml_state_cnt, (dm_soml_table->soml_on_off == SOML_ON) ? "SOML_ON" : "SOML_OFF");
+				/*Traning state: 0(alt) 1(ori) 2(alt) 3(ori)============================================================*/
+				if (dm_soml_table->soml_state_cnt < ((dm_soml_table->soml_train_num)<<1)) {
+					if (dm_soml_table->soml_state_cnt == 0) {
+						if (dm->support_ic_type == ODM_RTL8197F) {
+							odm_move_memory(dm, dm_soml_table->num_ht_bytes, ht_reset, HT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_ht_bytes_on, ht_reset, HT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_ht_bytes_off, ht_reset, HT_RATE_IDX*size);
+						} else if (dm->support_ic_type == ODM_RTL8822B) {
+							odm_move_memory(dm, dm_soml_table->num_vht_bytes, vht_reset, VHT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_vht_bytes_on, vht_reset, VHT_RATE_IDX*size);
+							odm_move_memory(dm, dm_soml_table->num_vht_bytes_off, vht_reset, VHT_RATE_IDX*size);
+							dm_soml_table->cfo_counter++;
+							phydm_soml_cfo_process(dm,
+									       &dm_soml_table->cfo_diff_a,
+									       &dm_soml_table->cfo_diff_b);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n", dm_soml_table->cfo_counter, dm_soml_table->cfo_diff_a, dm_soml_table->cfo_diff_b);
+							dm_soml_table->cfo_diff_sum_a += dm_soml_table->cfo_diff_a;
+							dm_soml_table->cfo_diff_sum_b += dm_soml_table->cfo_diff_b;
+						}
+
+						dm_soml_table->is_soml_method_enable = 1;
+						dm_soml_table->soml_state_cnt++;
+						next_on_off = (dm_soml_table->soml_on_off == SOML_ON) ? SOML_ON : SOML_OFF;
+						phydm_soml_on_off(dm, next_on_off);
+						odm_set_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer, dm_soml_table->soml_delay_time); /*ms*/
+					} else if ((dm_soml_table->soml_state_cnt % 2) != 0) {
+						dm_soml_table->soml_state_cnt++;
+						if (dm->support_ic_type == ODM_RTL8197F)
+							odm_move_memory(dm, dm_soml_table->pre_num_ht_bytes, dm_soml_table->num_ht_bytes, HT_RATE_IDX*size);
+						else if (dm->support_ic_type == ODM_RTL8822B) {
+							odm_move_memory(dm, dm_soml_table->pre_num_vht_bytes, dm_soml_table->num_vht_bytes, VHT_RATE_IDX*size);
+							dm_soml_table->cfo_counter++;
+							phydm_soml_cfo_process(dm,
+									       &dm_soml_table->cfo_diff_a,
+									       &dm_soml_table->cfo_diff_b);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n", dm_soml_table->cfo_counter, dm_soml_table->cfo_diff_a, dm_soml_table->cfo_diff_b);
+							dm_soml_table->cfo_diff_sum_a += dm_soml_table->cfo_diff_a;
+							dm_soml_table->cfo_diff_sum_b += dm_soml_table->cfo_diff_b;
+						}
+						odm_set_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer, dm_soml_table->soml_intvl); /*ms*/
+					} else if ((dm_soml_table->soml_state_cnt % 2) == 0) {
+						if (dm->support_ic_type == ODM_RTL8822B) {
+							dm_soml_table->cfo_counter++;
+							phydm_soml_cfo_process(dm,
+									       &dm_soml_table->cfo_diff_a,
+									       &dm_soml_table->cfo_diff_b);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n", dm_soml_table->cfo_counter, dm_soml_table->cfo_diff_a, dm_soml_table->cfo_diff_b);
+							dm_soml_table->cfo_diff_sum_a += dm_soml_table->cfo_diff_a;
+							dm_soml_table->cfo_diff_sum_b += dm_soml_table->cfo_diff_b;
+						}
+						dm_soml_table->soml_state_cnt++;
+						phydm_soml_statistics(dm, dm_soml_table->soml_on_off);
+						next_on_off = (dm_soml_table->soml_on_off == SOML_ON) ? SOML_OFF : SOML_ON;
+						phydm_soml_on_off(dm, next_on_off);
+						odm_set_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer, dm_soml_table->soml_delay_time); /*ms*/
+					}
+				}
+				/*Decision state: ==============================================================*/
+				else {
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[Decisoin state ]\n");
+					phydm_soml_statistics(dm, dm_soml_table->soml_on_off);
+					dm_soml_table->cfo_diff_avg_a = (dm_soml_table->cfo_counter != 0) ? (dm_soml_table->cfo_diff_sum_a  / dm_soml_table->cfo_counter) : 0;
+					dm_soml_table->cfo_diff_avg_b = (dm_soml_table->cfo_counter != 0) ? (dm_soml_table->cfo_diff_sum_b / dm_soml_table->cfo_counter) : 0;
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ cfo_diff_avg_a = %d KHz; cfo_diff_avg_b = %d KHz]\n", dm_soml_table->cfo_diff_avg_a, dm_soml_table->cfo_diff_avg_b);
+
+					/* [Search 1st and 2ed rate by counter] */
+					if (dm->support_ic_type == ODM_RTL8197F) {
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = (i << 3);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "*num_ht_bytes_on  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+								(rate_ss_shift), (rate_ss_shift+7),
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 0], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 1],
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 2], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 3],
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 4], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 5],
+								dm_soml_table->num_ht_bytes_on[rate_ss_shift + 6], dm_soml_table->num_ht_bytes_on[rate_ss_shift + 7]);
+						}
+
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = (i << 3);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "*num_ht_bytes_off  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+								(rate_ss_shift), (rate_ss_shift+7),
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 0], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 1],
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 2], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 3],
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 4], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 5],
+								dm_soml_table->num_ht_bytes_off[rate_ss_shift + 6], dm_soml_table->num_ht_bytes_off[rate_ss_shift + 7]);
+						}
+
+						for (i = 0; i < HT_RATE_IDX; i++) {
+							byte_total_on += dm_soml_table->num_ht_bytes_on[i];
+							byte_total_off += dm_soml_table->num_ht_bytes_off[i];
+						}
+
+					} else if (dm->support_ic_type == ODM_RTL8822B) {
+						for (i = 0; i < VHT_ORDER_TYPE; i++)
+							num_total_qam += dm_soml_table->num_vht_qam[i];
+
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ ((2SS)) BPSK_QPSK_count = %d ; 16QAM_count = %d ; 64QAM_count = %d ; 256QAM_count = %d ; num_total_qam = %d]\n", dm_soml_table->num_vht_qam[BPSK_QPSK], dm_soml_table->num_vht_qam[QAM16], dm_soml_table->num_vht_qam[QAM64], dm_soml_table->num_vht_qam[QAM256], num_total_qam);
+						if (((dm_soml_table->num_vht_qam[QAM256] * 100) > (num_total_qam * dm_soml_table->qam256_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qam256_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qam256_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  QAM256_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->qam256_dist_th, dm_soml_table->cfo_qam256_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						} else if (((dm_soml_table->num_vht_qam[QAM64] * 100) > (num_total_qam * dm_soml_table->qam64_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qam64_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qam64_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  QAM64_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->qam64_dist_th, dm_soml_table->cfo_qam64_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						} else if (((dm_soml_table->num_vht_qam[QAM16] * 100) > (num_total_qam * dm_soml_table->qam16_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qam16_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qam16_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  QAM16_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->qam16_dist_th, dm_soml_table->cfo_qam16_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						} else if (((dm_soml_table->num_vht_qam[BPSK_QPSK] * 100) > (num_total_qam * dm_soml_table->bpsk_qpsk_dist_th)) && (dm_soml_table->cfo_diff_avg_a > dm_soml_table->cfo_qpsk_th) && (dm_soml_table->cfo_diff_avg_b > dm_soml_table->cfo_qpsk_th)) {
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  BPSK_QPSK_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n", dm_soml_table->bpsk_qpsk_dist_th, dm_soml_table->cfo_qpsk_th);
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+							phydm_soml_on_off(dm, SOML_OFF);
+							return;
+						}
+
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = 10 * i;
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  num_vht_bytes_on  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d} ]\n",
+								(i + 1),
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 0], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 1],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 2], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 3],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 4], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 5],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 6], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 7],
+								dm_soml_table->num_vht_bytes_on[rate_ss_shift + 8], dm_soml_table->num_vht_bytes_on[rate_ss_shift + 9]);
+						}
+
+						for (i = 0; i < rate_num; i++) {
+							rate_ss_shift = 10 * i;
+							PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  num_vht_bytes_off  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d} ]\n",
+								(i + 1),
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 0], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 1],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 2], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 3],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 4], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 5],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 6], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 7],
+								dm_soml_table->num_vht_bytes_off[rate_ss_shift + 8], dm_soml_table->num_vht_bytes_off[rate_ss_shift + 9]);
+						}
+
+						for (i = 0; i < VHT_RATE_IDX; i++) {
+							byte_total_on += dm_soml_table->num_vht_bytes_on[i];
+							byte_total_off += dm_soml_table->num_vht_bytes_off[i];
+						}
+
+					}
+
+					/* [Decision] */
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[  byte_total_on = %d ; byte_total_off = %d ]\n", byte_total_on, byte_total_off);
+					if (byte_total_on > byte_total_off) {
+						next_on_off = SOML_ON;
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ byte_total_on > byte_total_off ==> SOML_ON ]\n");
+					} else if (byte_total_on < byte_total_off) {
+						next_on_off = SOML_OFF;
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ byte_total_on < byte_total_off ==> SOML_OFF ]\n");
+					} else {
+						PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ stay at soml_last_state ]\n");
+						next_on_off = dm_soml_table->soml_last_state;
+					}
+
+					PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+					phydm_soml_on_off(dm, next_on_off);
+					dm_soml_table->soml_last_state = next_on_off;
+				}
+			} else {
+				PHYDM_DBG(dm, DBG_ADPTV_SOML, "[escape from > TH_H || is_soml_method_enable==1]\n");
+				phydm_adaptive_soml_reset(dm);
+				phydm_soml_on_off(dm, SOML_ON);
+			}
+		} else {
+			PHYDM_DBG(dm, DBG_ADPTV_SOML, "[number_active_client != 1]\n");
+			phydm_adaptive_soml_reset(dm);
+			phydm_soml_on_off(dm, SOML_OFF);
+		}
+	}
+}
+
+void
+phydm_adaptive_soml_reset(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	dm_soml_table->soml_state_cnt = 0;
+	dm_soml_table->is_soml_method_enable = 0;
+	dm_soml_table->soml_counter = 0;
+}
+
+#endif /* end of CONFIG_ADAPTIVE_SOML*/
+
+void
+phydm_soml_bytes_acq(
+	void		*dm_void,
+	u8		rate_id,
+	u32		length
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if ((rate_id >= ODM_RATEMCS0) && (rate_id <= ODM_RATEMCS31))
+		dm_soml_table->num_ht_bytes[rate_id - ODM_RATEMCS0] += length;
+	else if ((rate_id >= ODM_RATEVHTSS1MCS0) && (rate_id <= ODM_RATEVHTSS4MCS9))
+		dm_soml_table->num_vht_bytes[rate_id - ODM_RATEVHTSS1MCS0] += length;
+
+#endif
+}
+
+void
+phydm_adaptive_soml_timers(
+	void		*dm_void,
+	u8		state
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if (state == INIT_SOML_TIMMER) {
+		odm_initialize_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer,
+			(void *)phydm_adaptive_soml_callback, NULL, "phydm_adaptive_soml_timer");
+	} else if (state == CANCEL_SOML_TIMMER) {
+		odm_cancel_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer);
+	} else if (state == RELEASE_SOML_TIMMER) {
+		odm_release_timer(dm, &dm_soml_table->phydm_adaptive_soml_timer);
+	}
+#endif
+}
+
+void
+phydm_adaptive_soml_init(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+#if 0
+	if (!(dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[Return]   Not Support Adaptive SOML\n");
+		return;
+	}
+#endif
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "phydm_adaptive_soml_init\n");
+
+	dm_soml_table->soml_state_cnt = 0;
+	dm_soml_table->soml_delay_time = 40;
+	dm_soml_table->soml_intvl = 150;
+	dm_soml_table->soml_train_num = 4;
+	dm_soml_table->is_soml_method_enable = 0;
+	dm_soml_table->soml_counter = 0;
+	dm_soml_table->soml_period = 1;
+	dm_soml_table->soml_select = 0;
+	dm_soml_table->cfo_counter = 0;
+	dm_soml_table->cfo_diff_sum_a = 0;
+	dm_soml_table->cfo_diff_sum_b = 0;
+
+	dm_soml_table->cfo_qpsk_th = 94;
+	dm_soml_table->cfo_qam16_th  = 38;
+	dm_soml_table->cfo_qam64_th = 17;
+	dm_soml_table->cfo_qam256_th = 7;
+
+	dm_soml_table->bpsk_qpsk_dist_th = 20;
+	dm_soml_table->qam16_dist_th = 20;
+	dm_soml_table->qam64_dist_th = 20;
+	dm_soml_table->qam256_dist_th = 20;
+
+	if (dm->support_ic_type == ODM_RTL8197F)
+		odm_set_bb_reg(dm, 0x998, BIT(25), 1);
+#endif
+}
+
+void
+phydm_adaptive_soml(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			"[Return!!!]   Not Support Adaptive SOML Function\n");
+		return;
+	}
+
+	if (dm_soml_table->soml_counter <  dm_soml_table->soml_period) {
+		dm_soml_table->soml_counter++;
+		return;
+	}
+	dm_soml_table->soml_counter = 0;
+	dm_soml_table->soml_state_cnt = 0;
+	dm_soml_table->cfo_counter = 0;
+	dm_soml_table->cfo_diff_sum_a = 0;
+	dm_soml_table->cfo_diff_sum_b = 0;
+
+	phydm_soml_reset_rx_rate(dm);
+
+	if (dm_soml_table->soml_select == 0) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Adaptive SOML Training !!!]\n");
+	} else if (dm_soml_table->soml_select == 1) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Stop Adaptive SOML !!!]\n");
+		phydm_soml_on_off(dm, SOML_ON);
+		return;
+	} else if (dm_soml_table->soml_select == 2) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Stop Adaptive SOML !!!]\n");
+		phydm_soml_on_off(dm, SOML_OFF);
+		return;
+	}
+
+	phydm_adsl(dm);
+
+#endif
+}
+
+void
+phydm_enable_adaptive_soml(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[%s][Return!!!]  enable Adaptive SOML\n", __func__);
+	dm->support_ability |= ODM_BB_ADAPTIVE_SOML;
+	phydm_soml_on_off(dm, SOML_ON);
+#endif
+}
+
+void
+phydm_stop_adaptive_soml(
+	void		*dm_void
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[%s][Return!!!]  Stop Adaptive SOML\n", __func__);
+	dm->support_ability &= ~ODM_BB_ADAPTIVE_SOML;
+	phydm_soml_on_off(dm, SOML_ON);
+	
+#endif
+}
+
+void
+phydm_adaptive_soml_para_set(
+	void		*dm_void,
+	u8		train_num,
+	u8		intvl,
+	u8		period,
+	u8		delay_time
+	
+)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml	*dm_soml_table = &dm->dm_soml_table;
+
+	dm_soml_table->soml_train_num = train_num;
+	dm_soml_table->soml_intvl = intvl;
+	dm_soml_table->soml_period = period;
+	dm_soml_table->soml_delay_time = delay_time;
+#endif
+}
+
+void
+phydm_init_soft_ml_setting(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	
+#if (RTL8822B_SUPPORT == 1)
+	if (*dm->mp_mode == false) {
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			/*odm_set_bb_reg(dm, 0x19a8, MASKDWORD, 0xd10a0000);*/
+			phydm_somlrxhp_setting(dm, true);
+			dm->bsomlenabled = true;
+		}
+	}
+#endif
+#if (RTL8821C_SUPPORT == 1)
+	if (*dm->mp_mode == false) {
+		if (dm->support_ic_type & ODM_RTL8821C)
+			odm_set_bb_reg(dm, 0x19a8, BIT(31)|BIT(30)|BIT(29)|BIT(28), 0xd);
+	}
+#endif
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_soml.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_soml.h
new file mode 100644
index 000000000000..e48694afe167
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_soml.h
@@ -0,0 +1,255 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef	__PHYDMSOML_H__
+#define    __PHYDMSOML_H__
+
+#define ADAPTIVE_SOML_VERSION	"1.0"
+
+#define ODM_ADAPTIVE_SOML_SUPPORT_IC	(ODM_RTL8822B | ODM_RTL8197F)
+
+#define INIT_SOML_TIMMER			0
+#define CANCEL_SOML_TIMMER			1
+#define RELEASE_SOML_TIMMER		2
+
+#define SOML_RSSI_TH_HIGH	25
+#define SOML_RSSI_TH_LOW	20
+
+#define HT_RATE_IDX			32
+#define VHT_RATE_IDX		40
+
+#define HT_ORDER_TYPE		3
+#define VHT_ORDER_TYPE		4
+
+/*
+#define CFO_QPSK_TH			20
+#define CFO_QAM16_TH		20
+#define CFO_QAM64_TH		20
+#define CFO_QAM256_TH		20
+
+#define BPSK_QPSK_DIST		20
+#define QAM16_DIST			30
+#define QAM64_DIST			30
+#define QAM256_DIST			20
+*/
+#define HT_TYPE		1
+#define VHT_TYPE		2
+
+#define SOML_ON		1
+#define SOML_OFF		0
+
+#ifdef CONFIG_ADAPTIVE_SOML
+
+struct adaptive_soml {
+	boolean		is_soml_method_enable;
+	u8			soml_on_off;
+	u8			soml_state_cnt;
+	u8			soml_delay_time;
+	u8			soml_intvl;
+	u8			soml_train_num;
+	u8			soml_counter;
+	u8			soml_period;
+	u8			soml_select;
+	u8			soml_last_state;
+	u8			cfo_qpsk_th;
+	u8			cfo_qam16_th;
+	u8			cfo_qam64_th;
+	u8			cfo_qam256_th;
+	u8			bpsk_qpsk_dist_th;
+	u8			qam16_dist_th;
+	u8			qam64_dist_th;
+	u8			qam256_dist_th;
+	u8			cfo_counter;
+	s32			cfo_diff_a;
+	s32			cfo_diff_b;
+	s32			cfo_diff_sum_a;
+	s32			cfo_diff_sum_b;
+	s32			cfo_diff_avg_a;
+	s32			cfo_diff_avg_b;
+	u32			num_ht_qam[HT_ORDER_TYPE];
+	u32			num_ht_bytes[HT_RATE_IDX];
+	u32			pre_num_ht_bytes[HT_RATE_IDX];
+	u32			num_ht_bytes_on[HT_RATE_IDX];
+	u32			num_ht_bytes_off[HT_RATE_IDX];
+	#if	ODM_IC_11AC_SERIES_SUPPORT
+	u32			num_vht_qam[VHT_ORDER_TYPE];
+	u32			num_qry_mu_vht_pkt[VHT_RATE_IDX];
+	u32			num_vht_bytes[VHT_RATE_IDX];
+	u32			pre_num_vht_bytes[VHT_RATE_IDX];
+	u32			num_vht_bytes_on[VHT_RATE_IDX];
+	u32			num_vht_bytes_off[VHT_RATE_IDX];
+	#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if USE_WORKITEM
+	RT_WORK_ITEM	phydm_adaptive_soml_workitem;
+#endif
+#endif
+	struct phydm_timer_list		phydm_adaptive_soml_timer;
+
+};
+
+enum qam_order {
+	BPSK_QPSK	= 0,
+	QAM16		= 1,
+	QAM64		= 2,
+	QAM256		= 3
+};
+
+void
+phydm_dynamicsoftmletting(
+	void		*dm_void
+);
+
+void
+phydm_soml_on_off(
+	void		*dm_void,
+	u8		swch
+);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+phydm_adaptive_soml_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void		*context
+);
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void
+phydm_adaptive_soml_callback(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml_workitem_callback(
+	void		*context
+);
+
+#else
+void
+phydm_adaptive_soml_callback(
+	void		*dm_void
+);
+
+#endif
+
+void
+phydm_rx_qam_for_soml(
+	void		*dm_void,
+	void		*pkt_info_void
+);
+
+void
+phydm_soml_reset_rx_rate(
+	void		*dm_void
+);
+
+void
+phydm_soml_cfo_process(
+	void		*dm_void,
+	s32		*diff_a,
+	s32		*diff_b
+);
+
+void
+phydm_soml_debug(
+	void		*dm_void,
+	u32		*const dm_value,
+	u32		*_used,
+	char			*output,
+	u32		*_out_len
+);
+
+void
+phydm_soml_statistics(
+	void		*dm_void,
+	u8		on_off_state
+
+);
+
+void
+phydm_adsl(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml_reset(
+	void		*dm_void
+);
+
+#endif
+void
+phydm_soml_bytes_acq(
+	void		*dm_void,
+	u8		rate_id,
+	u32		length
+);
+
+void
+phydm_adaptive_soml_timers(
+	void		*dm_void,
+	u8		state
+);
+
+void
+phydm_adaptive_soml_init(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml(
+	void		*dm_void
+);
+
+void
+phydm_enable_adaptive_soml(
+	void		*dm_void
+);
+
+void
+phydm_stop_adaptive_soml(
+	void		*dm_void
+);
+
+void
+phydm_adaptive_soml_para_set(
+	void		*dm_void,
+	u8		train_num,
+	u8		intvl,
+	u8		period,
+	u8		delay_time
+	
+);
+
+void
+phydm_init_soft_ml_setting(
+	void		*dm_void
+);
+
+#endif /*#ifndef	__PHYDMSOML_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_types.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_types.h
index 6c3be47379a6..f192a5d82abb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_types.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/phydm_types.h
@@ -1,260 +1,261 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __ODM_TYPES_H__
-#define __ODM_TYPES_H__
-
-
-/*Define Different SW team support*/
-#define	ODM_AP			0x01	/*BIT0*/
-#define	ODM_ADSL		0x02
-#define	ODM_CE			0x04	/*BIT2*/
-#define	ODM_WIN		0x08	/*BIT3*/
-#define	ODM_IOT		0x20	/*BIT5*/
-
-/*Deifne HW endian support*/
-#define	ODM_ENDIAN_BIG	0
-#define	ODM_ENDIAN_LITTLE	1
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#define GET_PDM_ODM(__pAdapter)	((PDM_ODM_T)(&((GET_HAL_DATA(__pAdapter))->DM_OutSrc)))
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#define GET_PDM_ODM(__pAdapter)	((PDM_ODM_T)(&((GET_HAL_DATA(__pAdapter))->odmpriv)))
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
-#define 	RT_PCI_INTERFACE				1
-#define 	RT_USB_INTERFACE				2
-#define 	RT_SDIO_INTERFACE				3
-#endif
-
-typedef enum _HAL_STATUS{
-	HAL_STATUS_SUCCESS,
-	HAL_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,*/
-}HAL_STATUS,*PHAL_STATUS;
-
-#if( DM_ODM_SUPPORT_TYPE == ODM_AP)
-#define		MP_DRIVER		0
-#endif
-#if(DM_ODM_SUPPORT_TYPE != ODM_WIN)
-
-#define		VISTA_USB_RX_REVISE			0
-
-//
-// Declare for ODM spin lock defintion temporarily fro compile pass.
-//
-typedef enum _RT_SPINLOCK_TYPE{
-	RT_TX_SPINLOCK = 1,
-	RT_RX_SPINLOCK = 2,
-	RT_RM_SPINLOCK = 3,
-	RT_CAM_SPINLOCK = 4,
-	RT_SCAN_SPINLOCK = 5,
-	RT_LOG_SPINLOCK = 7, 
-	RT_BW_SPINLOCK = 8,
-	RT_CHNLOP_SPINLOCK = 9,
-	RT_RF_OPERATE_SPINLOCK = 10,
-	RT_INITIAL_SPINLOCK = 11,
-	RT_RF_STATE_SPINLOCK = 12, // For RF state. Added by Bruce, 2007-10-30.
-#if VISTA_USB_RX_REVISE
-	RT_USBRX_CONTEXT_SPINLOCK = 13,
-	RT_USBRX_POSTPROC_SPINLOCK = 14, // protect data of Adapter->IndicateW/ IndicateR
-#endif
-	//Shall we define Ndis 6.2 SpinLock Here ?
-	RT_PORT_SPINLOCK=16,
-	RT_VNIC_SPINLOCK=17,
-	RT_HVL_SPINLOCK=18,	
-	RT_H2C_SPINLOCK = 20, // For H2C cmd. Added by tynli. 2009.11.09.
-
-	RT_BTData_SPINLOCK=25,
-
-	RT_WAPI_OPTION_SPINLOCK=26,
-	RT_WAPI_RX_SPINLOCK=27,
-
-      // add for 92D CCK control issue  
-	RT_CCK_PAGEA_SPINLOCK = 28,
-	RT_BUFFER_SPINLOCK = 29,
-	RT_CHANNEL_AND_BANDWIDTH_SPINLOCK = 30,
-	RT_GEN_TEMP_BUF_SPINLOCK = 31,
-	RT_AWB_SPINLOCK = 32,
-	RT_FW_PS_SPINLOCK = 33,
-	RT_HW_TIMER_SPIN_LOCK = 34,
-	RT_MPT_WI_SPINLOCK = 35,
-	RT_P2P_SPIN_LOCK = 36,	// Protect P2P context
-	RT_DBG_SPIN_LOCK = 37,
-	RT_IQK_SPINLOCK = 38,
-	RT_PENDED_OID_SPINLOCK = 39,
-	RT_CHNLLIST_SPINLOCK = 40,	
-	RT_INDIC_SPINLOCK = 41,	//protect indication	
-	RT_RFD_SPINLOCK = 42,
-	RT_SYNC_IO_CNT_SPINLOCK = 43,
-	RT_LAST_SPINLOCK,
-}RT_SPINLOCK_TYPE;
-
-#endif
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define	STA_INFO_T			RT_WLAN_STA
-	#define	PSTA_INFO_T			PRT_WLAN_STA
-	#define	__func__		__FUNCTION__
-	#define	PHYDM_TESTCHIP_SUPPORT	TESTCHIP_SUPPORT
-	#define bMaskH3Bytes			0xffffff00
-	#define SUCCESS	0
-	#define FAIL	(-1)
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-	// To let ADSL/AP project compile ok; it should be removed after all conflict are solved. Added by Annie, 2011-10-07.
-	#define ADSL_AP_BUILD_WORKAROUND
-	#define AP_BUILD_WORKAROUND
-
-	#ifdef AP_BUILD_WORKAROUND
-	#include "../typedef.h"
-	#else
-	typedef void					VOID,*PVOID;
-	typedef unsigned char			BOOLEAN,*PBOOLEAN;
-	typedef unsigned char			u1Byte,*pu1Byte;
-	typedef unsigned short			u2Byte,*pu2Byte;
-	typedef unsigned int			u4Byte,*pu4Byte;
-	typedef unsigned long long		u8Byte,*pu8Byte;
-#if 1
-/* In ARM platform, system would use the type -- "char" as "unsigned char"
- * And we only use s1Byte/ps1Byte as INT8 now, so changes the type of s1Byte.*/
-    typedef signed char				s1Byte,*ps1Byte;
-#else
-	typedef char					s1Byte,*ps1Byte;
-#endif
-	typedef short					s2Byte,*ps2Byte;
-	typedef long					s4Byte,*ps4Byte;
-	typedef long long				s8Byte,*ps8Byte;
-	#endif
-
-	typedef struct rtl8192cd_priv	*prtl8192cd_priv;
-	typedef struct stat_info		STA_INFO_T,*PSTA_INFO_T;
-	typedef struct timer_list		RT_TIMER, *PRT_TIMER;
-	typedef  void *				RT_TIMER_CALL_BACK;
-
-#ifdef CONFIG_PCI_HCI
-	#define DEV_BUS_TYPE		RT_PCI_INTERFACE
-#endif
-
-	#define _TRUE				1
-	#define _FALSE				0
-
-	#if (defined(TESTCHIP_SUPPORT))
-		#define	PHYDM_TESTCHIP_SUPPORT 1
-	#else
-		#define	PHYDM_TESTCHIP_SUPPORT 0
-	#endif
-	
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#include <drv_types.h>
-#if 0
-	typedef u8					u1Byte, *pu1Byte;
-	typedef u16					u2Byte,*pu2Byte;
-	typedef u32					u4Byte,*pu4Byte;
-	typedef u64					u8Byte,*pu8Byte;
-	typedef s8					s1Byte,*ps1Byte;
-	typedef s16					s2Byte,*ps2Byte;
-	typedef s32					s4Byte,*ps4Byte;
-	typedef s64					s8Byte,*ps8Byte;
-#else
-	#define u1Byte 		u8
-	#define	pu1Byte 	u8*	
-
-	#define u2Byte 		u16
-	#define	pu2Byte 	u16*		
-
-	#define u4Byte 		u32
-	#define	pu4Byte 	u32*	
-
-	#define u8Byte 		u64
-	#define	pu8Byte 	u64*
-
-	#define s1Byte 		s8
-	#define	ps1Byte 	s8*	
-
-	#define s2Byte 		s16
-	#define	ps2Byte 	s16*	
-
-	#define s4Byte 		s32
-	#define	ps4Byte 	s32*	
-
-	#define s8Byte 		s64
-	#define	ps8Byte 	s64*	
-	
-#endif
-	#ifdef CONFIG_USB_HCI
-		#define DEV_BUS_TYPE  	RT_USB_INTERFACE
-	#elif defined(CONFIG_PCI_HCI)
-		#define DEV_BUS_TYPE  	RT_PCI_INTERFACE
-	#elif defined(CONFIG_SDIO_HCI)
-		#define DEV_BUS_TYPE  	RT_SDIO_INTERFACE
-	#elif defined(CONFIG_GSPI_HCI)
-		#define DEV_BUS_TYPE  	RT_SDIO_INTERFACE
-	#endif
-	
-
-	#if defined(CONFIG_LITTLE_ENDIAN)	
-		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_LITTLE
-	#elif defined (CONFIG_BIG_ENDIAN)
-		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_BIG
-	#endif
-	
-	typedef struct timer_list		RT_TIMER, *PRT_TIMER;
-	typedef  void *				RT_TIMER_CALL_BACK;
-	#define	STA_INFO_T			struct sta_info
-	#define	PSTA_INFO_T		struct sta_info *
-		
-
-
-	#define TRUE 	_TRUE	
-	#define FALSE	_FALSE
-
-
-	#define SET_TX_DESC_ANTSEL_A_88E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 1, __Value)
-	#define SET_TX_DESC_ANTSEL_B_88E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 25, 1, __Value)
-	#define SET_TX_DESC_ANTSEL_C_88E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 29, 1, __Value)
-
-	//define useless flag to avoid compile warning
-	#define	USE_WORKITEM 0
-	#define	FOR_BRAZIL_PRETEST 0
-	/*#define	BT_30_SUPPORT			0*/
-	#define	FPGA_TWO_MAC_VERIFICATION	0
-	#define	RTL8881A_SUPPORT	0
-
-	#if (defined(TESTCHIP_SUPPORT))
-		#define	PHYDM_TESTCHIP_SUPPORT 1
-	#else
-		#define	PHYDM_TESTCHIP_SUPPORT 0
-	#endif
-#endif
-
-#define READ_NEXT_PAIR(v1, v2, i) do { if (i+2 >= ArrayLen) break; i += 2; v1 = Array[i]; v2 = Array[i+1]; } while(0)
-#define COND_ELSE  2
-#define COND_ENDIF 3
-
-#endif // __ODM_TYPES_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __ODM_TYPES_H__
+#define __ODM_TYPES_H__
+
+
+/*Define Different SW team support*/
+#define	ODM_AP			0x01	/*BIT(0)*/
+#define	ODM_CE			0x04	/*BIT(2)*/
+#define	ODM_WIN		0x08	/*BIT(3)*/
+#define	ODM_ADSL		0x10	/*BIT(4)*/		/*already combine with ODM_AP, and is nouse now*/
+#define	ODM_IOT		0x20	/*BIT(5)*/
+
+/*For FW API*/
+#define	__iram_odm_func__
+
+/*Deifne HW endian support*/
+#define	ODM_ENDIAN_BIG	0
+#define	ODM_ENDIAN_LITTLE	1
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&(GET_HAL_DATA(__padapter))->DM_OutSrc))
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&(GET_HAL_DATA(__padapter))->odmpriv))
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&__padapter->pshare->_dmODM))
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
+	#define	RT_PCI_INTERFACE				1
+	#define	RT_USB_INTERFACE				2
+	#define	RT_SDIO_INTERFACE				3
+#endif
+
+enum hal_status {
+	HAL_STATUS_SUCCESS,
+	HAL_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,*/
+};
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
+
+#define		VISTA_USB_RX_REVISE			0
+
+/*
+ * Declare for ODM spin lock defintion temporarily fro compile pass.
+ *   */
+enum rt_spinlock_type {
+	RT_TX_SPINLOCK = 1,
+	RT_RX_SPINLOCK = 2,
+	RT_RM_SPINLOCK = 3,
+	RT_CAM_SPINLOCK = 4,
+	RT_SCAN_SPINLOCK = 5,
+	RT_LOG_SPINLOCK = 7,
+	RT_BW_SPINLOCK = 8,
+	RT_CHNLOP_SPINLOCK = 9,
+	RT_RF_OPERATE_SPINLOCK = 10,
+	RT_INITIAL_SPINLOCK = 11,
+	RT_RF_STATE_SPINLOCK = 12, /* For RF state. Added by Bruce, 2007-10-30. */
+#if VISTA_USB_RX_REVISE
+	RT_USBRX_CONTEXT_SPINLOCK = 13,
+	RT_USBRX_POSTPROC_SPINLOCK = 14, /* protect data of adapter->IndicateW/ IndicateR */
+#endif
+	/* Shall we define Ndis 6.2 SpinLock Here ? */
+	RT_PORT_SPINLOCK = 16,
+	RT_VNIC_SPINLOCK = 17,
+	RT_HVL_SPINLOCK = 18,
+	RT_H2C_SPINLOCK = 20, /* For H2C cmd. Added by tynli. 2009.11.09. */
+
+	rt_bt_data_spinlock = 25,
+
+	RT_WAPI_OPTION_SPINLOCK = 26,
+	RT_WAPI_RX_SPINLOCK = 27,
+
+	/* add for 92D CCK control issue */
+	RT_CCK_PAGEA_SPINLOCK = 28,
+	RT_BUFFER_SPINLOCK = 29,
+	RT_CHANNEL_AND_BANDWIDTH_SPINLOCK = 30,
+	RT_GEN_TEMP_BUF_SPINLOCK = 31,
+	RT_AWB_SPINLOCK = 32,
+	RT_FW_PS_SPINLOCK = 33,
+	RT_HW_TIMER_SPIN_LOCK = 34,
+	RT_MPT_WI_SPINLOCK = 35,
+	RT_P2P_SPIN_LOCK = 36,	/* Protect P2P context */
+	RT_DBG_SPIN_LOCK = 37,
+	RT_IQK_SPINLOCK = 38,
+	RT_PENDED_OID_SPINLOCK = 39,
+	RT_CHNLLIST_SPINLOCK = 40,
+	RT_INDIC_SPINLOCK = 41,	/* protect indication */
+	RT_RFD_SPINLOCK = 42,
+	RT_SYNC_IO_CNT_SPINLOCK = 43,
+	RT_LAST_SPINLOCK,
+};
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define sta_info 	_RT_WLAN_STA
+	#define	__func__		__FUNCTION__
+	#define	PHYDM_TESTCHIP_SUPPORT	TESTCHIP_SUPPORT
+	#define MASKH3BYTES			0xffffff00
+	#define SUCCESS	0
+	#define FAIL	(-1)
+
+	#define	u8 		u1Byte
+	#define	s8 		s1Byte
+
+	#define	u16		u2Byte
+	#define	s16		s2Byte
+
+	#define	u32 	u4Byte
+	#define	s32 		s4Byte
+
+	#define	u64		u8Byte
+	#define	s64		s8Byte
+
+	#define	phydm_timer_list	_RT_TIMER
+	
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	#include "../typedef.h"
+
+	#ifdef CONFIG_PCI_HCI
+		#define DEV_BUS_TYPE		RT_PCI_INTERFACE
+	#endif
+
+	#if (defined(TESTCHIP_SUPPORT))
+		#define	PHYDM_TESTCHIP_SUPPORT 1
+	#else
+		#define	PHYDM_TESTCHIP_SUPPORT 0
+	#endif
+
+	#define	sta_info stat_info
+	#define	boolean	bool
+
+	#define	phydm_timer_list	timer_list
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+
+	#include <asm/byteorder.h>
+
+	#define DEV_BUS_TYPE	RT_PCI_INTERFACE
+
+	#if defined(__LITTLE_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_LITTLE
+	#elif defined(__BIG_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_BIG
+	#else
+		#error
+	#endif
+
+	/* define useless flag to avoid compile warning */
+	#define	USE_WORKITEM 0
+	#define	FOR_BRAZIL_PRETEST 0
+	#define	FPGA_TWO_MAC_VERIFICATION	0
+	#define	RTL8881A_SUPPORT	0
+	#define	PHYDM_TESTCHIP_SUPPORT 0
+
+
+	#define RATE_ADAPTIVE_SUPPORT			0
+	#define POWER_TRAINING_ACTIVE			0
+
+	#define sta_info	rtl_sta_info
+	#define	boolean		bool
+	#define	phydm_timer_list	rtw_timer_list
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#include <drv_types.h>
+
+	#ifdef CONFIG_USB_HCI
+		#define DEV_BUS_TYPE	RT_USB_INTERFACE
+	#elif defined(CONFIG_PCI_HCI)
+		#define DEV_BUS_TYPE	RT_PCI_INTERFACE
+	#elif defined(CONFIG_SDIO_HCI)
+		#define DEV_BUS_TYPE	RT_SDIO_INTERFACE
+	#elif defined(CONFIG_GSPI_HCI)
+		#define DEV_BUS_TYPE	RT_SDIO_INTERFACE
+	#endif
+
+
+	#if defined(CONFIG_LITTLE_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_LITTLE
+	#elif defined (CONFIG_BIG_ENDIAN)
+		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_BIG
+	#endif
+
+	#define	boolean	bool
+
+	#define SET_TX_DESC_ANTSEL_A_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+8, 24, 1, __value)
+	#define SET_TX_DESC_ANTSEL_B_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+8, 25, 1, __value)
+	#define SET_TX_DESC_ANTSEL_C_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+28, 29, 1, __value)
+
+	/* define useless flag to avoid compile warning */
+	#define	USE_WORKITEM 0
+	#define	FOR_BRAZIL_PRETEST 0
+	#define	FPGA_TWO_MAC_VERIFICATION	0
+	#define	RTL8881A_SUPPORT	0
+
+	#if (defined(TESTCHIP_SUPPORT))
+		#define	PHYDM_TESTCHIP_SUPPORT 1
+	#else
+		#define	PHYDM_TESTCHIP_SUPPORT 0
+	#endif
+
+	#define	phydm_timer_list	rtw_timer_list
+#endif
+
+#define READ_NEXT_PAIR(v1, v2, i) do { if (i+2 >= array_len) break; i += 2; v1 = array[i]; v2 = array[i+1]; } while (0)
+#define COND_ELSE  2
+#define COND_ENDIF 3
+
+#define	MASKBYTE0		0xff
+#define	MASKBYTE1		0xff00
+#define	MASKBYTE2		0xff0000
+#define	MASKBYTE3		0xff000000
+#define	MASKHWORD		0xffff0000
+#define	MASKLWORD		0x0000ffff
+#define	MASKDWORD		0xffffffff
+#define	MASK7BITS		0x7f
+#define	MASK12BITS		0xfff
+#define	MASKH4BITS		0xf0000000
+#define	MASK20BITS		0xfffff
+#define	MASKOFDM_D		0xffc00000
+#define	MASKCCK			0x3f3f3f3f
+#define RFREGOFFSETMASK	0xfffff
+#define MASKH3BYTES		0xffffff00
+#define MASKL3BYTES		0x00ffffff
+#define MASKBYTE2HIGHNIBBLE		0x00f00000
+#define MASKBYTE3LOWNIBBLE		0x0f000000
+#define	MASKL3BYTES			0x00ffffff
+#define RFREGOFFSETMASK	0xfffff
+
+#endif /* __ODM_TYPES_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtchnlplan.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtchnlplan.c
deleted file mode 100644
index 5f81e0526a10..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtchnlplan.c
+++ /dev/null
@@ -1,480 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-/******************************************************************************
-     
- History:
-	Data		Who		Remark (Internal History)
-	
-	05/14/2012	MH		Collect RTK inernal infromation and generate channel plan draft.
-	
-******************************************************************************/
-
-//============================================================
-// include files
-//============================================================
-#include "mp_precomp.h"
-#include "rtchnlplan.h"
-
-
-
-//
-//	Channel Plan Domain Code
-//
-
-/*
-	Channel Plan Contents					
-	Domain Code		EEPROM	Countries in Specific Domain		
-			2G RD		5G RD		Bit[6:0]	2G	5G	
-	Case	Old Define				00h~1Fh	Old Define	Old Define	
-	1		2G_WORLD	5G_NULL		20h		Worldwird 13	NA	
-	2		2G_ETSI1	5G_NULL		21h		Europe 2G		NA	
-	3		2G_FCC1		5G_NULL		22h		US 2G			NA	
-	4		2G_MKK1		5G_NULL		23h		Japan 2G		NA	
-	5		2G_ETSI2	5G_NULL		24h		France 2G		NA	
-	6		2G_FCC1		5G_FCC1		25h		US 2G			US 5G					八大國認證
-	7		2G_WORLD	5G_ETSI1	26h		Worldwird 13	Europe					八大國認證
-	8		2G_MKK1		5G_MKK1		27h		Japan 2G		Japan 5G				八大國認證
-	9		2G_WORLD	5G_KCC1		28h		Worldwird 13	Korea					八大國認證
-	10		2G_WORLD	5G_FCC2		29h		Worldwird 13	US o/w DFS Channels		
-	11		2G_WORLD	5G_FCC3		30h		Worldwird 13	India, Mexico	    	
-	12		2G_WORLD	5G_FCC4		31h		Worldwird 13	Venezuela	        	
-	13		2G_WORLD	5G_FCC5		32h		Worldwird 13	China	            	
-	14		2G_WORLD	5G_FCC6		33h		Worldwird 13	Israel	            	
-	15		2G_FCC1		5G_FCC7		34h		US 2G			US/Canada				八大國認證
-	16		2G_WORLD	5G_ETSI2	35h		Worldwird 13	Australia, New Zealand	八大國認證
-	17		2G_WORLD	5G_ETSI3	36h		Worldwird 13	Russia	
-	18		2G_MKK1		5G_MKK2		37h		Japan 2G		Japan (W52, W53)	
-	19		2G_MKK1		5G_MKK3		38h		Japan 2G		Japan (W56)	
-	20		2G_FCC1		5G_NCC1		39h		US 2G			Taiwan					八大國認證
-						
-	NA		2G_WORLD	5G_FCC1		7F		FCC	FCC DFS Channels	Realtek Define
-						
-						
-						
-						
-						
-	2.4G 	Regulatory 	Domains					
-	Case	2G RD		Regulation	Channels	Frequencyes		Note					Countries in Specific Domain
-	1		2G_WORLD	ETSI		1~13		2412~2472		Passive scan CH 12, 13	Worldwird 13
-	2		2G_ETSI1	ETSI		1~13		2412~2472								Europe
-	3		2G_FCC1		FCC			1~11		2412~2462								US
-	4		2G_MKK1		MKK			1~13, 14	2412~2472, 2484							Japan
-	5		2G_ETSI2	ETSI		10~13		2457~2472								France
-						
-						
-						
-						
-	5G Regulatory Domains					
-	Case	5G RD		Regulation	Channels			Frequencyes					Note											Countries in Specific Domain
-	1		5G_NULL		NA			NA					NA							Do not support 5GHz	
-	2		5G_ETSI1	ETSI		"36~48, 52~64,  	
-									100~140"			"5180~5240, 5260~5230
-														5500~5700"					Band1, Ban2, Band3								Europe
-	3		5G_ETSI2	ETSI		"36~48, 52~64, 
-									100~140, 149~165"	"5180~5240, 5260~5230
-														5500~5700, 5745~5825"		Band1, Ban2, Band3, Band4						Australia, New Zealand
-	4		5G_ETSI3	ETSI		"36~48, 52~64, 
-														100~132, 149~165"	
-														"5180~5240, 5260~5230
-														5500~5660, 5745~5825"		Band1, Ban2, Band3(except CH 136, 140), Band4"	Russia
-	5		5G_FCC1		FCC			"36~48, 52~64, 
-									100~140, 149~165"	
-														"5180~5240, 5260~5230
-														5500~5700, 5745~5825"		Band1(5150~5250MHz), 
-																					Band2(5250~5350MHz),
-																					Band3(5470~5725MHz),
-																					Band4(5725~5850MHz)"							US
-	6		5G_FCC2		FCC			36~48, 149~165		5180~5240, 5745~5825		Band1, Band4	FCC o/w DFS Channels
-	7		5G_FCC3		FCC			"36~48, 52~64, 
-									149~165"			"5180~5240, 5260~5230
-														5745~5825"					Band1, Ban2, Band4								India, Mexico
-	8		5G_FCC4		FCC			"36~48, 52~64, 
-									149~161"			"5180~5240, 5260~5230
-														5745~5805"					Band1, Ban2,
-																					Band4(except CH 165)"							Venezuela
-	9		5G_FCC5		FCC			149~165				5745~5825					Band4											China
-	10		5G_FCC6		FCC			36~48, 52~64		5180~5240, 5260~5230		Band1, Band2									Israel
-	11		5G_FCC7
-			5G_IC1		FCC
-						IC"			"36~48, 52~64, 
-									100~116, 136, 140, 
-									149~165"			"5180~5240, 5260~5230
-														5500~5580, 5680, 5700, 
-														5745~5825"					"Band1, Band2, 
-																					Band3(except 5600~5650MHz),
-																					Band4"											"US
-																																	Canada"
-	12		5G_KCC1		KCC			"36~48, 52~64, 
-									100~124, 149~165"	"5180~5240, 5260~5230
-														5500~5620, 5745~5825"		"Band1, Ban2, 
-																					Band3(5470~5650MHz),
-																					Band4"											Korea
-	13		5G_MKK1		MKK			"36~48, 52~64, 
-									100~140"			"5180~5240, 5260~5230
-														5500~5700"					W52, W53, W56									Japan
-	14		5G_MKK2		MKK			36~48, 52~64		5180~5240, 5260~5230		W52, W53										Japan (W52, W53)
-	15		5G_MKK3		MKK			100~140				5500~5700					W56	Japan (W56)
-	16		5G_NCC1		NCC			"56~64,
-									100~116, 136, 140,
-									149~165"			"5260~5320
-														5500~5580, 5680, 5700, 
-														5745~5825"					"Band2(except CH 52), 
-																					Band3(except 5600~5650MHz),
-																					Band4"											Taiwan
-						
-						
-*/						
-						
-//
-// 2.4G CHannel 
-//						
-/*
-
-	2.4G Band		Regulatory Domains																RTL8192D	
-	Channel Number	Channel Frequency	US		Canada	Europe	Spain	France	Japan	Japan		20M		40M
-					(MHz)				(FCC)	(IC)	(ETSI)							(MPHPT)				
-	1				2412				v		v		v								v			v		
-	2				2417				v		v		v								v			v		
-	3				2422				v		v		v								v			v		v
-	4				2427				v		v		v								v			v		v
-	5				2432				v		v		v								v			v		v
-	6				2437				v		v		v								v			v		v
-	7				2442				v		v		v								v			v		v
-	8				2447				v		v		v								v			v		v
-	9				2452				v		v		v								v			v		v
-	10				2457				v		v		v		v		v				v			v		v
-	11				2462				v		v		v		v		v				v			v		v
-	12				2467								v				v				v			v		v
-	13				2472								v				v				v			v	
-	14				2484														v					v	
-
-
-*/
-
-
-//
-// 5G Operating Channel
-//
-/*
-
-	5G Band		RTL8192D	RTL8195 (Jaguar)				Jaguar 2	Regulatory Domains											
-	Channel Number	Channel Frequency	Global	Global				Global	"US
-(FCC 15.407)"	"Canada
-(FCC, except 5.6~5.65GHz)"	Argentina, Australia, New Zealand, Brazil, S. Africa (FCC/ETSI)	"Europe
-(CE 301 893)"	China	India, Mexico, Singapore	Israel, Turkey	"Japan
-(MIC Item 19-3, 19-3-2)"	Korea	Russia, Ukraine	"Taiwan
-(NCC)"	Venezuela
-		(MHz)	(20MHz)	(20MHz)	(40MHz)	(80MHz)	(160MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)	(20MHz)
-"Band 1
-5.15GHz
-~
-5.25GHz"	36	5180	v	v	v	v		v	Indoor	Indoor	v	Indoor		v	Indoor	Indoor	v	v		v
-	40	5200	v	v				v	Indoor	Indoor	v	Indoor		v	Indoor	Indoor	v	v		v
-	44	5220	v	v	v			v	Indoor	Indoor	v	Indoor		v	Indoor	Indoor	v	v		v
-	48	5240	v	v				v	Indoor	Indoor	v	Indoor		v	Indoor	Indoor	v	v		v
-"Band 2
-5.25GHz
-~
-5.35GHz
-(DFS)"	52	5260	v	v	v	v		v	v	v	v	Indoor		v	Indoor	Indoor	v	v		v
-	56	5280	v	v				v	v	v	v	Indoor		v	Indoor	Indoor	v	v	Indoor	v
-	60	5300	v	v	v			v	v	v	v	Indoor		v	Indoor	Indoor	v	v	Indoor	v
-	64	5320	v	v				v	v	v	v	Indoor		v	Indoor	Indoor	v	v	Indoor	v
-																				
-"Band 3
-5.47GHz
-~
-5.725GHz
-(DFS)"	100	5500	v	v	v	v		v	v	v	v	v				v	v	v	v	
-	104	5520	v	v				v	v	v	v	v				v	v	v	v	
-	108	5540	v	v	v			v	v	v	v	v				v	v	v	v	
-	112	5560	v	v				v	v	v	v	v				v	v	v	v	
-	116	5580	v	v	v	v		v	v	v	v	v				v	v	v	v	
-	120	5600	v	v				v	Indoor		v	Indoor				v	v	v		
-	124	5620	v	v	v			v	Indoor		v	Indoor				v	v	v		
-	128	5640	v	v				v	Indoor		v	Indoor				v		v		
-	132	5660	v	v	v	E		v	Indoor		v	Indoor				v		v		
-	136	5680	v	v				v	v	v	v	v				v			v	
-	140	5700	v	v	E			v	v	v	v	v				v			v	
-	144	5720	E	E				E												
-"Band 4
-5.725GHz
-~
-5.85GHz
-(~5.9GHz)"	149	5745	v	v	v	v		v	v	v	v		v	v			v	v	v	v
-	153	5765	v	v				v	v	v	v		v	v			v	v	v	v
-	157	5785	v	v	v			v	v	v	v		v	v			v	v	v	v
-	161	5805	v	v				v	v	v	v		v	v			v	v	v	v
-	165	5825	v	v	P	P		v	v	v	v		v	v			v	v	v	
-	169	5845	P	P				P												
-	173	5865	P	P	P			P												
-	177	5885	P	P				P												
-Channel Count			28	28	14	7	0	28	24	20	24	19	5	13	8	19	20	22	15	12
-			E: FCC accepted the ask for CH144 from Accord.					PS: 160MHz 用 80MHz+80MHz實現？			Argentina	Belgium (比利時)		India	Israel			Russia		
-			P: Customer's requirement from James.								Australia	The Netherlands (荷蘭)		Mexico	Turkey			Ukraine		
-											New Zealand	UK (英國)		Singapore						
-											Brazil	Switzerland (瑞士)								
-
-
-*/
-
-/*---------------------------Define Local Constant---------------------------*/
-
-
-// define Maximum Power v.s each band for each region 
-// ISRAEL
-// Format:
-// RT_CHANNEL_DOMAIN_Region ={{{Chnl_Start, Chnl_end, Pwr_dB_Max}, {Chn2_Start, Chn2_end, Pwr_dB_Max}, {Chn3_Start, Chn3_end, Pwr_dB_Max}, {Chn4_Start, Chn4_end, Pwr_dB_Max}, {Chn5_Start, Chn5_end, Pwr_dB_Max}}, Limit_Num} */
-// RT_CHANNEL_DOMAIN_FCC ={{{01,11,30}, {36,48,17}, {52,64,24}, {100,140,24}, {149,165,30}}, 5} 
-// "NR" is non-release channle.
-// Issue--- Israel--Russia--New Zealand
-// DOMAIN_01= (2G_WORLD, 5G_NULL)
-// DOMAIN_02= (2G_ETSI1, 5G_NULL)
-// DOMAIN_03= (2G_FCC1, 5G_NULL)
-// DOMAIN_04= (2G_MKK1, 5G_NULL)
-// DOMAIN_05= (2G_ETSI2, 5G_NULL)
-// DOMAIN_06= (2G_FCC1, 5G_FCC1)
-// DOMAIN_07= (2G_WORLD, 5G_ETSI1)
-// DOMAIN_08= (2G_MKK1, 5G_MKK1)
-// DOMAIN_09= (2G_WORLD, 5G_KCC1)
-// DOMAIN_10= (2G_WORLD, 5G_FCC2)
-// DOMAIN_11= (2G_WORLD, 5G_FCC3)----india
-// DOMAIN_12= (2G_WORLD, 5G_FCC4)----Venezuela
-// DOMAIN_13= (2G_WORLD, 5G_FCC5)----China
-// DOMAIN_14= (2G_WORLD, 5G_FCC6)----Israel
-// DOMAIN_15= (2G_FCC1, 5G_FCC7)-----Canada
-// DOMAIN_16= (2G_WORLD, 5G_ETSI2)---Australia
-// DOMAIN_17= (2G_WORLD, 5G_ETSI3)---Russia
-// DOMAIN_18= (2G_MKK1, 5G_MKK2)-----Japan
-// DOMAIN_19= (2G_MKK1, 5G_MKK3)-----Japan
-// DOMAIN_20= (2G_FCC1, 5G_NCC1)-----Taiwan
-// DOMAIN_21= (2G_FCC1, 5G_NCC1)-----Taiwan
-
-
-static	RT_CHANNEL_PLAN_MAXPWR	ChnlPlanPwrMax_2G[] = {
-
-	// 2G_WORLD, 
-	{{1, 13, 20}, 1},	
-
-	// 2G_ETSI1
-	{{1, 13, 20}, 1},
-
-	/* RT_CHANNEL_DOMAIN_ETSI */
-	{{{1, 11, 17}, {40, 56, 17}, {60, 128, 17}, {0, 0, 0}, {149, 165, 17}}, 4},
-
-	// RT_CHANNEL_DOMAIN_MKK
-	{{{1, 11, 17}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}}, 1},
-
-	// Add new channel plan mex power table.
-	// ......
-	};
-
-
-/*
-//===========================================1:(2G_WORLD, 5G_NULL)
-
-RT_CHANNEL_PLAN_MAXPWR	RT_DOMAIN_01 ={{{01,13,20}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}}, 1} 
-
-//===========================================2:(2G_ETSI1, 5G_NULL)
-
-RT_DOMAIN_02 ={{{01,13,20}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}}, 1}
-
-//===========================================3:(2G_FCC1, 5G_NULL)
-
-RT_DOMAIN_03 ={{{01,11,30}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}}, 1}
-
-//===========================================4:(2G_MKK1, 5G_NULL)
-
-RT_DOMAIN_04 ={{{01,14,23}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}}, 1}
-
-//===========================================5:(2G_ETSI2, 5G_NULL)
-
-RT_DOMAIN_05 ={{{10,13,20}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}}, 1}
-
-//===========================================6:(2G_FCC1, 5G_FCC1)
-
-RT_DOMAIN_06 ={{{01,13,30}, {36,48,17}, {52,64,24}, {100,140,24}, {149,165,30}}, 5}
-
-//===========================================7:(2G_WORLD, 5G_ETSI1)
-
-RT_DOMAIN_07 ={{{01,13,20}, {36,48,23}, {52,64,23}, {100,140,30}, {NR,NR,0}}, 4}
-
-//===========================================8:(2G_MKK1, 5G_MKK1)
-
-RT_DOMAIN_08 ={{{01,14,23}, {36,48,23}, {52,64,23}, {100,140,23}, {NR,NR,0}}, 4}
-
-//===========================================9:(2G_WORLD, 5G_KCC1)
-
-RT_DOMAIN_09 ={{{01,13,20}, {36,48,17}, {52,64,23}, {100,124,23}, {149,165,23}}, 5}
-
-//===========================================10:(2G_WORLD, 5G_FCC2)
-
-RT_DOMAIN_10 ={{{01,13,20}, {36,48,17}, {NR,NR,0}, {NR,NR,0}, {149,165,30}}, 3}
-
-//===========================================11:(2G_WORLD, 5G_FCC3)
-RT_DOMAIN_11 ={{{01,13,20}, {36,48,23}, {52,64,23}, {NR,NR,0}, {149,165,23}}, 4}
-
-//===========================================12:(2G_WORLD, 5G_FCC4)
-RT_DOMAIN_12 ={{{01,13,20}, {36,48,24}, {52,64,24}, {NR,NR,0}, {149,161,27}}, 4}
-
-//===========================================13:(2G_WORLD, 5G_FCC5)
-RT_DOMAIN_13 ={{{01,13,20}, {NR,NR,0}, {NR,NR,0}, {NR,NR,0}, {149,165,27}}, 2}
-
-//===========================================14:(2G_WORLD, 5G_FCC6)
-RT_DOMAIN_14 ={{{01,13,20}, {36,48,17}, {52,64,17}, {NR,NR,0}, {NR,NR,0}}, 3}
-
-//===========================================15:(2G_FCC1, 5G_FCC7)
-RT_DOMAIN_15 ={{{01,11,30}, {36,48,23}, {52,64,24}, {100,140,24}, {149,165,30}}, 5}
-
-//===========================================16:(2G_WORLD, 5G_ETSI2)
-RT_DOMAIN_16 ={{{01,13,20}, {36,48,23}, {52,64,23}, {100,140,30}, {149,165,30}}, 5}
-
-//===========================================17:(2G_WORLD, 5G_ETSI3)
-RT_DOMAIN_17 ={{{01,13,20}, {36,48,23}, {52,64,23}, {100,132,30}, {149,165,20}}, 5}
-
-//===========================================18:(2G_MKK1, 5G_MKK2)
-RT_DOMAIN_18 ={{{01,14,23}, {36,48,23}, {52,64,23}, {NR,NR,0}, {NR,NR,0}}, 3}
-
-//===========================================19:(2G_MKK1, 5G_MKK3)
-RT_DOMAIN_19 ={{{01,14,23}, {NR,NR,0}, {NR,NR,0}, {100,140,23}, {NR,NR,0}}, 2}
-
-//===========================================20:(2G_FCC1, 5G_NCC1)
-RT_DOMAIN_20 ={{{01,11,30}, {NR,NR,0}, {56,64,23}, {100,140,24}, {149,165,30}}, 4}
-
-//===========================================21:(2G_FCC1, 5G_NCC2)
-RT_DOMAIN_21 ={{{01,11,30}, {NR,NR,0}, {56,64,23}, {NR,NR,0}, {149,165,30}}, 3}
-
-//===========================================22:(2G_WORLD, 5G_FCC3)
-RT_DOMAIN_22 ={{{01,13,24}, {36,48,20}, {52,64,24}, {NR,NR,0}, {149,165,30}}, 4}
-
-//===========================================23:(2G_WORLD, 5G_ETSI2)
-RT_DOMAIN_23 ={{{01,13,20}, {36,48,23}, {52,64,23}, {100,140,30}, {149,165,30}}, 5}
-
-*/
-
-//
-// Counter & Realtek Channel plan transfer table.
-//
-RT_CHNL_CTRY_TBL	RtCtryChnlTbl[] = 
-{
-
-	{
-		RT_CTRY_AL,							//	"Albania阿爾巴尼亞"					
-		"AL",
-		RT_2G_WORLD,
-		RT_5G_WORLD,		
-		RT_CHANNEL_DOMAIN_UNDEFINED			// 2G/5G world.
-	},
-#if 0	
-	{
-		RT_CTRY_BB,							//  "Barbados巴巴多斯"				
-		"BB",
-		RT_2G_WORLD,
-		RT_5G_NULL,		
-		RT_CHANNEL_DOMAIN_EFUSE_0x20		// 2G world. 5G_NULL
-	},
-	
-	{
-		RT_CTRY_DE,							//  "Germany德國"					
-		"DE",
-		RT_2G_WORLD,
-		RT_5G_ETSI1,		
-		RT_CHANNEL_DOMAIN_EFUSE_0x26
-	},
-	
-	{
-		RT_CTRY_US,							//  "Germany德國"					
-		"US",
-		RT_2G_FCC1,
-		RT_5G_FCC7,		
-		RT_CHANNEL_DOMAIN_EFUSE_0x34
-	},
-
-	{
-		RT_CTRY_JP,							//  "Germany德國"					
-		"JP",
-		RT_2G_MKK1,
-		RT_5G_MKK1,		
-		RT_CHANNEL_DOMAIN_EFUSE_0x34
-	},
-		
-	{
-		RT_CTRY_TW,							//  "Germany德國"					
-		"TW",
-		RT_2G_FCC1,
-		RT_5G_NCC1,		
-		RT_CHANNEL_DOMAIN_EFUSE_0x39
-	},	
-#endif
-
-};	// RtCtryChnlTbl
-
-//
-// Realtek Defined Channel plan.
-//
-#if 0
-
-static	RT_CHANNEL_PLAN_NEW		RtChnlPlan[] =
-{
-	// Channel Plan   0x20.
-	{
-		&RtCtryChnlTbl[1],					// RT_CHNL_CTRY_TBL Country & channel plan transfer table.		
-		RT_CHANNEL_DOMAIN_EFUSE_0x20,		// RT_CHANNEL_DOMAIN RT Channel Plan Define 
-		RT_2G_WORLD,						// RT_REGULATION_2G
-		RT_5G_NULL,							// RT_REGULATION_5G
-		RT_WORLD,							// RT_REGULATION_CMN RT Regulatory domain definition.
-		RT_SREQ_NA,							// RT Channel plan special & customerize requirement.
-		
-		CHNL_RT_2G_WORLD,
-		CHNL_RT_2G_WORLD_SCAN_TYPE,
-		&ChnlPlanPwrMax_2G[0],
-
-		CHNL_RT_5G_NULL,
-		CHNL_RT_5G_NULL_SCAN_TYPE,
-
-		
-	},
-	
-	// Channel Plan   0x26.
-	{
-		&RtCtryChnlTbl[1],					// RT_CHNL_CTRY_TBL Country & channel plan transfer table.		
-		RT_CHANNEL_DOMAIN_EFUSE_0x26,		// RT_CHANNEL_DOMAIN RT Channel Plan Define 
-		RT_2G_WORLD,						// RT_REGULATION_2G
-		RT_5G_ETSI1,						// RT_REGULATION_5G
-		RT_WORLD,							// RT_REGULATION_CMN RT Regulatory domain definition.
-		RT_SREQ_NA,							// RT Channel plan special & customerize requirement.
-		
-		CHNL_RT_2G_WORLD,					// 2G workd cannel
-		CHNL_RT_2G_WORLD_SCAN_TYPE,
-		&ChnlPlanPwrMax_2G[1],
-		
-		CHNL_RT_5G_ETSI1,
-		CHNL_RT_5G_ETSI1_SCAN_TYPE,
-		
-	}
-	
-	
-};
-#endif
-
-
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtchnlplan.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtchnlplan.h
deleted file mode 100644
index 37786cf8f00d..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtchnlplan.h
+++ /dev/null
@@ -1,699 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-
-#ifndef	__RT_CHANNELPLAN_H__
-#define __RT_CHANNELPLAN_H__
-
-typedef enum _RT_CHANNEL_DOMAIN_NEW
-{
-
-	//===== Add new channel plan above this line ===============//
-
-	// For new architecture we define different 2G/5G CH area for all country.
-	// 2.4 G only
-	RT_CHANNEL_DOMAIN_2G_WORLD_5G_NULL				= 0x20,
-	RT_CHANNEL_DOMAIN_2G_ETSI1_5G_NULL				= 0x21,
-	RT_CHANNEL_DOMAIN_2G_FCC1_5G_NULL				= 0x22,
-	RT_CHANNEL_DOMAIN_2G_MKK1_5G_NULL				= 0x23,
-	RT_CHANNEL_DOMAIN_2G_ETSI2_5G_NULL				= 0x24,
-	// 2.4 G + 5G type 1
-	RT_CHANNEL_DOMAIN_2G_FCC1_5G_FCC1				= 0x25,
-	RT_CHANNEL_DOMAIN_2G_WORLD_5G_ETSI1				= 0x26,
-	//RT_CHANNEL_DOMAIN_2G_WORLD_5G_ETSI1				= 0x27,
-	// .....
-
-	RT_CHANNEL_DOMAIN_MAX_NEW,
-	
-}RT_CHANNEL_DOMAIN_NEW, *PRT_CHANNEL_DOMAIN_NEW;
-
-
-#if 0
-#define DOMAIN_CODE_2G_WORLD \
-        {1,2,3,4,5,6,7,8,9,10,11,12,13}, 13
-#define DOMAIN_CODE_2G_ETSI1 \
-        {1,2,3,4,5,6,7,8,9,10,11,12,13}, 13
-#define DOMAIN_CODE_2G_ETSI2 \
-        {1,2,3,4,5,6,7,8,9,10,11}, 11
-#define DOMAIN_CODE_2G_FCC1 \
-        {1,2,3,4,5,6,7,8,9,10,11,12,13,14}, 14
-#define DOMAIN_CODE_2G_MKK1 \
-        {10,11,12,13}, 4
-
-#define DOMAIN_CODE_5G_ETSI1 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140}, 19
-#define DOMAIN_CODE_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
-#define DOMAIN_CODE_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
-#define DOMAIN_CODE_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
-#define DOMAIN_CODE_5G_FCC2 \
-        {36,40,44,48,149,153,157,161,165}, 9
-#define DOMAIN_CODE_5G_FCC3 \
-        {36,40,44,48,52,56,60,64,149,153,157,161,165}, 13
-#define DOMAIN_CODE_5G_FCC4 \
-        {36,40,44,48,52,56,60,64,149,153,157,161}, 12
-#define DOMAIN_CODE_5G_FCC5 \
-        {149,153,157,161,165}, 5
-#define DOMAIN_CODE_5G_FCC6 \
-        {36,40,44,48,52,56,60,64}, 8
-#define DOMAIN_CODE_5G_FCC7 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 20
-#define DOMAIN_CODE_5G_IC1 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 20
-#define DOMAIN_CODE_5G_KCC1 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,149,153,157,161,165}, 20
-#define DOMAIN_CODE_5G_MKK1 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140}, 19
-#define DOMAIN_CODE_5G_MKK2 \
-        {36,40,44,48,52,56,60,64}, 8
-#define DOMAIN_CODE_5G_MKK3 \
-        {100,104,108,112,116,120,124,128,132,136,140}, 11
-#define DOMAIN_CODE_5G_NCC1 \
-        {56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 24
-#define DOMAIN_CODE_5G_NCC2 \
-        {56,60,64,149,153,157,161,165}, 8  			
-#define UNDEFINED \
-        {0}, 0
-#endif
-
-//
-//
-//
-/*
-
-Countries							"Country Abbreviation"	Domain Code					SKU's	Ch# of 20MHz
-															2G			5G						Ch# of 40MHz
-"Albania阿爾巴尼亞"					AL													Local Test	
-									    					        	            	
-"Algeria阿爾及利亞"					DZ									CE TCF	    	
-					                    					        	            	
-"Antigua & Barbuda安提瓜島&巴布達"	AG						2G_WORLD					FCC TCF	
-					                    					        	        		
-"Argentina阿根廷"					AR						2G_WORLD					Local Test	
-									    					        	        		
-"Armenia亞美尼亞"					AM						2G_WORLD					ETSI	
-									    					        	        		
-"Aruba阿魯巴島"						AW						2G_WORLD					FCC TCF	
-															        	
-"Australia澳洲"						AU						2G_WORLD		5G_ETSI2		
-															        	
-"Austria奧地利"						AT						2G_WORLD		5G_ETSI1	CE	
-					    			    					        	
-"Azerbaijan阿塞拜彊"				AZ						2G_WORLD					CE TCF	
-					                    					        	
-"Bahamas巴哈馬"						BS						2G_WORLD				
-									    					        	
-"Barbados巴巴多斯"					BB						2G_WORLD					FCC TCF	
-									    					        	
-"Belgium比利時"						BE						2G_WORLD		5G_ETSI1	CE	
-															        	
-"Bermuda百慕達"						BM						2G_WORLD					FCC TCF	
-															        	        		
-"Brazil巴西"						BR						2G_WORLD					Local Test	
-									    					        	
-"Bulgaria保加利亞"					BG						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Canada加拿大"						CA						2G_FCC1			5G_FCC7		IC / FCC	IC / FCC
-					                    					        	
-"Cayman Islands開曼群島"			KY						2G_WORLD		5G_ETSI1	CE	
-					                    					        	
-"Chile智利"							CL						2G_WORLD					FCC TCF	
-																    	
-"China中國"							CN						2G_WORLD		5G_FCC5		信部?【2002】353? 	
-					                    					        	
-"Columbia哥倫比亞"					CO						2G_WORLD					Voluntary 	
-					    			    					        	
-"Costa Rica哥斯達黎加"				CR						2G_WORLD					FCC TCF	
-					    			    					        	
-"Cyprus塞浦路斯"					CY						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Czech 捷克"						CZ						2G_WORLD		5G_ETSI1	CE	
-															        	
-"Denmark丹麥"						DK						2G_WORLD		5G_ETSI1	CE	
-					                    					        	
-"Dominican Republic多明尼加共和國"	DO						2G_WORLD					FCC TCF	
-					                    					        	
-"Egypt埃及"	EG	2G_WORLD			CE T												CF	    	
-					                    					        	
-"El Salvador薩爾瓦多"				SV						2G_WORLD					Voluntary	
-					        		    					        	
-"Estonia愛沙尼亞"					EE						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Finland芬蘭"						FI						2G_WORLD		5G_ETSI1	CE	
-															        	
-"France法國"						FR										5G_E		TSI1	CE	
-															        	
-"Germany德國"						DE						2G_WORLD		5G_ETSI1	CE	
-															        	
-"Greece 希臘"						GR						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Guam關島"							GU						2G_WORLD				
-									    					        	
-"Guatemala瓜地馬拉"					GT						2G_WORLD				
-									    					        	
-"Haiti海地"							HT						2G_WORLD					FCC TCF	
-									    					        	
-"Honduras宏都拉斯"					HN						2G_WORLD					FCC TCF	
-									    					        	
-"Hungary匈牙利"						HU						2G_WORLD		5G_ETSI1	CE	
-															        	
-"Iceland冰島"						IS						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"India印度"							IN						2G_WORLD		5G_FCC3		FCC/CE TCF	
-															        	
-"Ireland愛爾蘭"						IE						2G_WORLD		5G_ETSI1	CE	
-															        	
-"Israel以色列"						IL										5G_F		CC6	CE TCF	
-															        	
-"Italy義大利"						IT						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Japan日本"							JP						2G_MKK1			5G_MKK1		MKK	MKK
-																    	
-"Korea韓國"							KR						2G_WORLD		5G_KCC1		KCC	KCC
-									    					        	
-"Latvia拉脫維亞"					LV						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Lithuania立陶宛"					LT						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Luxembourg盧森堡"					LU						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Malaysia馬來西亞"					MY						2G_WORLD					Local Test	
-									    					        	
-"Malta馬爾他"						MT						2G_WORLD		5G_ETSI1	CE	
-															        	
-"Mexico墨西哥"						MX						2G_WORLD		5G_FCC3		Local Test	
-															        	
-"Morocco摩洛哥"						MA													CE TCF	
-									    					        	
-"Netherlands荷蘭"					NL						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"New Zealand紐西蘭"					NZ						2G_WORLD		5G_ETSI2		
-									    					        	
-"Norway挪威"						NO						2G_WORLD		5G_ETSI1	CE	
-															        	
-"Panama巴拿馬 "						PA						2G_FCC1						Voluntary	
-									    					        	
-"Philippines菲律賓"					PH						2G_WORLD					FCC TCF	
-									    					        	
-"Poland波蘭"						PL						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Portugal葡萄牙"					PT						2G_WORLD		5G_ETSI1	CE	
-									    					        	
-"Romania羅馬尼亞"					RO						2G_WORLD		5G_ETSI1	CE	
-					        		    					        	
-"Russia俄羅斯"						RU						2G_WORLD		5G_ETSI3	CE TCF	
-					        		    					        	
-"Saudi Arabia沙地阿拉伯"			SA						2G_WORLD					CE TCF	
-					        		    					        	
-"Singapore新加坡"					SG						2G_WORLD				
-									    					        	
-"Slovakia斯洛伐克"					SK						2G_WORLD		5G_ETSI1	CE	
-					    			    					        	
-"Slovenia斯洛維尼亞"				SI						2G_WORLD		5G_ETSI1	CE	
-					    			    					        	
-"South Africa南非"					ZA						2G_WORLD					CE TCF	
-					        		    					        	
-"Spain西班牙"						ES										5G_ETSI1	CE	
-															        	
-"Sweden瑞典"						SE						2G_WORLD		5G_ETSI1	CE	
-					        		    					        	
-"Switzerland瑞士"					CH						2G_WORLD		5G_ETSI1	CE	
-					        		    					        	
-"Taiwan臺灣"						TW						2G_FCC1			5G_NCC1	NCC	
-															        	
-"Thailand泰國"						TH						2G_WORLD					FCC/CE TCF	
-															        	
-"Turkey土耳其"						TR						2G_WORLD				
-															        	
-"Ukraine烏克蘭"						UA						2G_WORLD					Local Test	
-					        		    					        	
-"United Kingdom英國"				GB						2G_WORLD		5G_ETSI1	CE	ETSI
-					    			    					        	
-"United States美國"					US						2G_FCC1			5G_FCC7		FCC	FCC
-					    			    					        	
-"Venezuela委內瑞拉"					VE						2G_WORLD		5G_FCC4		FCC TCF	
-					    			    					        	
-"Vietnam越南"						VN						2G_WORLD					FCC/CE TCF	
-					
-
-
-*/
-
-// Counter abbervation.
-typedef enum _RT_COUNTRY_DEFINE_NUM
-{
-	RT_CTRY_AL,				//	"Albania阿爾巴尼亞"					
-	RT_CTRY_DZ,             //  "Algeria阿爾及利亞"					
-	RT_CTRY_AG,             //  "Antigua & Barbuda安提瓜島&巴布達"	
-	RT_CTRY_AR,             //  "Argentina阿根廷"					
-	RT_CTRY_AM,             //  "Armenia亞美尼亞"					
-	RT_CTRY_AW,             //  "Aruba阿魯巴島"						
-	RT_CTRY_AU,             //  "Australia澳洲"						
-	RT_CTRY_AT,             //  "Austria奧地利"						
-	RT_CTRY_AZ,             //  "Azerbaijan阿塞拜彊"				
-	RT_CTRY_BS,             //  "Bahamas巴哈馬"					
-	RT_CTRY_BB,             //  "Barbados巴巴多斯"				
-	RT_CTRY_BE,             //  "Belgium比利時"					
-	RT_CTRY_BM,             //  "Bermuda百慕達"					
-	RT_CTRY_BR,             //  "Brazil巴西"						
-	RT_CTRY_BG,             //  "Bulgaria保加利亞"				
-	RT_CTRY_CA,             //  "Canada加拿大"					
-	RT_CTRY_KY,             //  "Cayman Islands開曼群島"			
-	RT_CTRY_CL,             //  "Chile智利"						
-	RT_CTRY_CN,             //  "China中國"						
-	RT_CTRY_CO,             //  "Columbia哥倫比亞"				
-	RT_CTRY_CR,             //  "Costa Rica哥斯達黎加"			
-	RT_CTRY_CY,             //  "Cyprus塞浦路斯"					
-	RT_CTRY_CZ,             //  "Czech 捷克"						
-	RT_CTRY_DK,             //  "Denmark丹麥"					
-	RT_CTRY_DO,             //  "Dominican Republic多明尼加共和國"	
-	RT_CTRY_CE,             //  "Egypt埃及"	EG	2G_WORLD			
-	RT_CTRY_SV,             //  "El Salvador薩爾瓦多"				
-	RT_CTRY_EE,             //  "Estonia愛沙尼亞"					
-	RT_CTRY_FI,             //  "Finland芬蘭"						
-	RT_CTRY_FR,             //  "France法國"						
-	RT_CTRY_DE,             //  "Germany德國"					
-	RT_CTRY_GR,             //  "Greece 希臘"					
-	RT_CTRY_GU,             //  "Guam關島"						
-	RT_CTRY_GT,             //  "Guatemala瓜地馬拉"				
-	RT_CTRY_HT,             //  "Haiti海地"						
-	RT_CTRY_HN,             //  "Honduras宏都拉斯"				
-	RT_CTRY_HU,             //  "Hungary匈牙利"					
-	RT_CTRY_IS,             //  "Iceland冰島"					
-	RT_CTRY_IN,             //  "India印度"						
-	RT_CTRY_IE,             //  "Ireland愛爾蘭"					
-	RT_CTRY_IL,             //  "Israel以色列"					
-	RT_CTRY_IT,             //  "Italy義大利"					
-	RT_CTRY_JP,             //  "Japan日本"						
-	RT_CTRY_KR,             //  "Korea韓國"						
-	RT_CTRY_LV,             //  "Latvia拉脫維亞"					
-	RT_CTRY_LT,             //  "Lithuania立陶宛"				
-	RT_CTRY_LU,             //  "Luxembourg盧森堡"				
-	RT_CTRY_MY,             //  "Malaysia馬來西亞"				
-	RT_CTRY_MT,             //  "Malta馬爾他"					
-	RT_CTRY_MX,             //  "Mexico墨西哥"					
-	RT_CTRY_MA,             //  "Morocco摩洛哥"					
-	RT_CTRY_NL,             //  "Netherlands荷蘭"				
-	RT_CTRY_NZ,             //  "New Zealand紐西蘭"				
-	RT_CTRY_NO,             //  "Norway挪威"						
-	RT_CTRY_PA,             //  "Panama巴拿馬 "					
-	RT_CTRY_PH,             //  "Philippines菲律賓"				
-	RT_CTRY_PL,             //  "Poland波蘭"						
-	RT_CTRY_PT,             //  "Portugal葡萄牙"					
-	RT_CTRY_RO,             //  "Romania羅馬尼亞"				
-	RT_CTRY_RU,             //  "Russia俄羅斯"					
-	RT_CTRY_SA,             //  "Saudi Arabia沙地阿拉伯"			
-	RT_CTRY_SG,             //  "Singapore新加坡"				
-	RT_CTRY_SK,             //  "Slovakia斯洛伐克"				
-	RT_CTRY_SI,             //  "Slovenia斯洛維尼亞"				
-	RT_CTRY_ZA,             //  "South Africa南非"				
-	RT_CTRY_ES,             //  "Spain西班牙"					
-	RT_CTRY_SE,             //  "Sweden瑞典"						
-	RT_CTRY_CH,             //  "Switzerland瑞士"				
-	RT_CTRY_TW,             //  "Taiwan臺灣"						
-	RT_CTRY_TH,             //  "Thailand泰國"					
-	RT_CTRY_TR,             //  "Turkey土耳其"					
-	RT_CTRY_UA,             //  "Ukraine烏克蘭"					
-	RT_CTRY_GB,             //  "United Kingdom英國"				
-	RT_CTRY_US,             //  "United States美國"				
-	RT_CTRY_VE,             //  "Venezuela委內瑞拉"				
-	RT_CTRY_VN,             //  "Vietnam越南"					
-	RT_CTRY_MAX,            //  
-	
-}RT_COUNTRY_NAME, *PRT_COUNTRY_NAME;
-    
-// Scan type including active and passive scan.
-typedef enum _RT_SCAN_TYPE_NEW
-{
-	SCAN_NULL,
-	SCAN_ACT,
-	SCAN_PAS,
-	SCAN_BOTH,
-}RT_SCAN_TYPE_NEW, *PRT_SCAN_TYPE_NEW;
-    
-
-// Power table sample.
-
-typedef struct _RT_CHNL_PLAN_LIMIT
-{
-	u2Byte	Chnl_Start;
-	u2Byte	Chnl_end;	
-	
-	u2Byte	Freq_Start;
-	u2Byte	Freq_end;	
-}RT_CHNL_PLAN_LIMIT, *PRT_CHNL_PLAN_LIMIT;
-
-    
-//    
-// 2.4G Regulatory Domains
-//
-typedef enum _RT_REGULATION_DOMAIN_2G
-{
-	RT_2G_NULL,   
-	RT_2G_WORLD,
-	RT_2G_ETSI1,
-	RT_2G_FCC1,
-	RT_2G_MKK1,
-	RT_2G_ETSI2	
-	
-}RT_REGULATION_2G, *PRT_REGULATION_2G;
-
-
-//typedef struct _RT_CHANNEL_BEHAVIOR
-//{
-//	u1Byte	Chnl;
-//	RT_SCAN_TYPE_NEW
-//	
-//}RT_CHANNEL_BEHAVIOR, *PRT_CHANNEL_BEHAVIOR;
-
-//typedef struct _RT_CHANNEL_PLAN_TYPE
-//{
-//	RT_CHANNEL_BEHAVIOR		
-//	u1Byte					Chnl_num;
-//}RT_CHNL_PLAN_TYPE, *PRT_CHNL_PLAN_TYPE;
-
-//
-// 2.4G Channel Number
-// Channel definition & number
-//
-#define CHNL_RT_2G_NULL \
-        {0}, 0
-#define CHNL_RT_2G_WORLD \
-        {1,2,3,4,5,6,7,8,9,10,11,12,13}, 13
-#define CHNL_RT_2G_WORLD_TEST \
-        {1,2,3,4,5,6,7,8,9,10,11,12,13}, 13
-
-#define CHNL_RT_2G_EFSI1 \
-        {1,2,3,4,5,6,7,8,9,10,11,12,13}, 13
-#define CHNL_RT_2G_FCC1 \
-        {1,2,3,4,5,6,7,8,9,10,11}, 11
-#define CHNL_RT_2G_MKK1 \
-        {1,2,3,4,5,6,7,8,9,10,11,12,13,14}, 14
-#define CHNL_RT_2G_ETSI2 \
-        {10,11,12,13}, 4
-
-//
-// 2.4G Channel Active or passive scan.
-//
-#define CHNL_RT_2G_NULL_SCAN_TYPE \
-        {SCAN_NULL}
-#define CHNL_RT_2G_WORLD_SCAN_TYPE \
-        {1,1,1,1,1,1,1,1,1,1,1,0,0}
-#define CHNL_RT_2G_EFSI1_SCAN_TYPE \
-        {1,1,1,1,1,1,1,1,1,1,1,1,1}
-#define CHNL_RT_2G_FCC1_SCAN_TYPE \
-        {1,1,1,1,1,1,1,1,1,1,1}
-#define CHNL_RT_2G_MKK1_SCAN_TYPE \
-        {1,1,1,1,1,1,1,1,1,1,1,1,1,1}
-#define CHNL_RT_2G_ETSI2_SCAN_TYPE \
-        {1,1,1,1}
-
-
-//
-// 2.4G Band & Frequency Section
-// Freqency start & end / band number
-//
-#define FREQ_RT_2G_NULL \
-        {0}, 0
-        // Passive scan CH 12, 13
-#define FREQ_RT_2G_WORLD \
-        {2412, 2472}, 1
-#define FREQ_RT_2G_EFSI1 \
-        {2412, 2472}, 1
-#define FREQ_RT_2G_FCC1 \
-        {2412, 2462}, 1
-#define FREQ_RT_2G_MKK1 \
-        {2412, 2484}, 1
-#define FREQ_RT_2G_ETSI2 \
-        {2457, 2472}, 1
-
-
-//    
-// 5G Regulatory Domains
-//
-typedef enum _RT_REGULATION_DOMAIN_5G
-{   
-	RT_5G_NULL,
-	RT_5G_WORLD,
-	RT_5G_ETSI1,
-	RT_5G_ETSI2,
-	RT_5G_ETSI3,
-	RT_5G_FCC1,	
-	RT_5G_FCC2,
-	RT_5G_FCC3,
-	RT_5G_FCC4,
-	RT_5G_FCC5,
-	RT_5G_FCC6,
-	RT_5G_FCC7,
-	RT_5G_IC1,
-	RT_5G_KCC1,
-	RT_5G_MKK1,
-	RT_5G_MKK2,
-	RT_5G_MKK3,
-	RT_5G_NCC1,
-	
-}RT_REGULATION_5G, *PRT_REGULATION_5G;
-
-//
-// 5G Channel Number
-//
-#define CHNL_RT_5G_NULL \
-        {0}, 0
-#define CHNL_RT_5G_WORLD \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140}, 19
-#define CHNL_RT_5G_ETSI1 \
-        {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
-#define CHNL_RT_5G_ETSI2 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,149,153,157,161,165}, 22
-#define CHNL_RT_5G_ETSI3 \
-        {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
-#define CHNL_RT_5G_FCC1 \
-        {36,40,44,48,149,153,157,161,165}, 9
-#define CHNL_RT_5G_FCC2 \
-        {36,40,44,48,52,56,60,64,149,153,157,161,165}, 13
-#define CHNL_RT_5G_FCC3 \
-        {36,40,44,48,52,56,60,64,149,153,157,161}, 12
-#define CHNL_RT_5G_FCC4 \
-        {149,153,157,161,165}, 5
-#define CHNL_RT_5G_FCC5 \
-        {36,40,44,48,52,56,60,64}, 8
-#define CHNL_RT_5G_FCC6 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 20
-#define CHNL_RT_5G_FCC7 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 20
-#define CHNL_RT_5G_IC1 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,149,153,157,161,165}, 20
-#define CHNL_RT_5G_KCC1 \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140}, 19
-#define CHNL_RT_5G_MKK1 \
-        {36,40,44,48,52,56,60,64}, 8
-#define CHNL_RT_5G_MKK2 \
-        {100,104,108,112,116,120,124,128,132,136,140}, 11
-#define CHNL_RT_5G_MKK3 \
-        {56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 24
-#define CHNL_RT_5G_NCC1 \
-        {56,60,64,149,153,157,161,165}, 8  	
-
-//
-// 5G Channel Active or passive scan.
-//
-#define CHNL_RT_5G_NULL_SCAN_TYPE \
-        {SCAN_NULL}
-#define CHNL_RT_5G_WORLD_SCAN_TYPE \
-        {1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1}
-#define CHNL_RT_5G_ETSI1_SCAN_TYPE \
-        {1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1}
-#define CHNL_RT_5G_ETSI2_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,149,153,157,161,165}, 22
-#define CHNL_RT_5G_ETSI3_SCAN_TYPE \
-        {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
-#define CHNL_RT_5G_FCC1_SCAN_TYPE \
-        {36,40,44,48,149,153,157,161,165}, 9
-#define CHNL_RT_5G_FCC2_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64,149,153,157,161,165}, 13
-#define CHNL_RT_5G_FCC3_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64,149,153,157,161}, 12
-#define CHNL_RT_5G_FCC4_SCAN_TYPE \
-        {149,153,157,161,165}, 5
-#define CHNL_RT_5G_FCC5_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64}, 8
-#define CHNL_RT_5G_FCC6_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 20
-#define CHNL_RT_5G_FCC7_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 20
-#define CHNL_RT_5G_IC1_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,149,153,157,161,165}, 20
-#define CHNL_RT_5G_KCC1_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140}, 19
-#define CHNL_RT_5G_MKK1_SCAN_TYPE \
-        {36,40,44,48,52,56,60,64}, 8
-#define CHNL_RT_5G_MKK2_SCAN_TYPE \
-        {100,104,108,112,116,120,124,128,132,136,140}, 11
-#define CHNL_RT_5G_MKK3_SCAN_TYPE \
-        {56,60,64,100,104,108,112,116,136,140,149,153,157,161,165}, 24
-#define CHNL_RT_5G_NCC1_SCAN_TYPE \
-        {56,60,64,149,153,157,161,165}, 8  	
-
-//    
-// Global Regulation
-//
-typedef enum _RT_REGULATION_COMMON
-{
-	RT_WORLD,   
-	RT_FCC,   
-	RT_MKK,
-	RT_ETSI,
-	RT_IC,
-	RT_CE,
-	RT_NCC,
-	
-}RT_REGULATION_CMN, *PRT_REGULATION_CMN;
-
-
-
-//    
-// Special requirement for different regulation domain.
-// For internal test or customerize special request.
-//
-typedef enum _RT_CHNLPLAN_SREQ
-{
-	RT_SREQ_NA						= 0x0,
-	RT_SREQ_2G_ADHOC_11N			= 0x00000001,
-	RT_SREQ_2G_ADHOC_11B			= 0x00000002,
-	RT_SREQ_2G_ALL_PASS				= 0x00000004,
-	RT_SREQ_2G_ALL_ACT				= 0x00000008,	
-	RT_SREQ_5G_ADHOC_11N			= 0x00000010,
-	RT_SREQ_5G_ADHOC_11AC			= 0x00000020,
-	RT_SREQ_5G_ALL_PASS				= 0x00000040,
-	RT_SREQ_5G_ALL_ACT				= 0x00000080,
-	RT_SREQ_C1_PLAN					= 0x00000100,	
-	RT_SREQ_C2_PLAN					= 0x00000200,	
-	RT_SREQ_C3_PLAN					= 0x00000400,	
-	RT_SREQ_C4_PLAN					= 0x00000800,	
-	RT_SREQ_NFC_ON					= 0x00001000,	
-	RT_SREQ_MASK					= 0x0000FFFF,   /* Requirements bit mask */
-	
-}RT_CHNLPLAN_SREQ, *PRT_CHNLPLAN_SREQ;
-
-
-//
-// RT_COUNTRY_NAME & RT_REGULATION_2G & RT_REGULATION_5G transfer table
-// 
-//
-typedef struct _RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-{   
-	//
-	// Define countery domain and corresponding 
-	//	
-	RT_COUNTRY_NAME		Country_Enum;
-	char				Country_Name[3];
-	
-	//char		Domain_Name[12];
-	RT_REGULATION_2G	Domain_2G;	
-
-	RT_REGULATION_5G	Domain_5G;	
-
-	RT_CHANNEL_DOMAIN	RtChDomain;
-	//u1Byte		Country_Area;
-    
-}RT_CHNL_CTRY_TBL, *PRT_CHNL_CTRY_TBL;
-    
-
-#define		RT_MAX_CHNL_NUM_2G		13
-#define		RT_MAX_CHNL_NUM_5G		44	
-
-// Power table sample.
-
-typedef struct _RT_CHNL_PLAN_PWR_LIMIT
-{
-	u2Byte	Chnl_Start;
-	u2Byte	Chnl_end;
-	u1Byte	dB_Max;
-	u2Byte	mW_Max;
-}RT_CHNL_PWR_LIMIT, *PRT_CHNL_PWR_LIMIT;
-
-
-#define		RT_MAX_BAND_NUM			5
-
-typedef struct _RT_CHANNEL_PLAN_MAXPWR
-{
-//	STRING_T
-	RT_CHNL_PWR_LIMIT	Chnl[RT_MAX_BAND_NUM];
-	u1Byte				Band_Useful_Num;
-
-	
-}RT_CHANNEL_PLAN_MAXPWR, *PRT_CHANNEL_PLAN_MAXPWR;
-
-
-//
-// Power By Rate Table.
-//
-
-
-
-typedef struct _RT_CHANNEL_PLAN_NEW
-{   
-	//
-	// Define countery domain and corresponding 
-	//
-	//char		Country_Name[36];
-	//u1Byte		Country_Enum;
-	
-	//char		Domain_Name[12];
-
-	
-	PRT_CHNL_CTRY_TBL		pCtryTransfer;
-	
-	RT_CHANNEL_DOMAIN		RtChDomain;	
-
-	RT_REGULATION_2G		Domain_2G;
-
-	RT_REGULATION_5G		Domain_5G;	
-
-	RT_REGULATION_CMN		Regulator;
-
-	RT_CHNLPLAN_SREQ		ChnlSreq;
-	
-	//RT_CHNL_PLAN_LIMIT		RtChnl;
-		
-	u1Byte	Chnl2G[MAX_CHANNEL_NUM];				// CHNL_RT_2G_WORLD
-	u1Byte	Len2G;
-	u1Byte	Chnl2GScanTp[MAX_CHANNEL_NUM];			// CHNL_RT_2G_WORLD_SCAN_TYPE
-	//u1Byte	Freq2G[2];								// FREQ_RT_2G_WORLD
-
-	u1Byte	Chnl5G[MAX_CHANNEL_NUM];				
-	u1Byte	Len5G;
-	u1Byte	Chnl5GScanTp[MAX_CHANNEL_NUM];
-	//u1Byte	Freq2G[2];								// FREQ_RT_2G_WORLD
-
-	RT_CHANNEL_PLAN_MAXPWR	ChnlMaxPwr;
-	
-    
-}RT_CHANNEL_PLAN_NEW, *PRT_CHANNEL_PLAN_NEW;
-    
-    
-#endif	// __RT_CHANNELPLAN_H__
-    
-    
-    
-    
- 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/hal8188freg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/hal8188freg.h
index 6284f863b213..9b8a33f384a6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/hal8188freg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/hal8188freg.h
@@ -1,4 +1,18 @@
 /* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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) 2009,  RealTEK Technology Inc. All Right Reserved.
  *
@@ -6,45 +20,45 @@
  *
  *
  * Note:	1. Define Mac register address and corresponding bit mask map
- *			
+ *
  *
  * Export:	Constants, macro, functions(API), global variables(None).
  *
- * Abbrev:	
+ * Abbrev:
  *
  * History:
- *		Data		Who		Remark 
- * 
+ *		data		Who		Remark
+ *
  *****************************************************************************/
 #ifndef __INC_HAL8188FREG_H
 #define __INC_HAL8188FREG_H
 
 
 
-//============================================================
-//
-//============================================================
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_SYS_ISO_CTRL_8188F			0x0000	// 2 Byte
-#define REG_SYS_FUNC_EN_8188F			0x0002	// 2 Byte
-#define REG_APS_FSMCO_8188F			0x0004	// 4 Byte
-#define REG_SYS_CLKR_8188F				0x0008	// 2 Byte
-#define REG_9346CR_8188F				0x000A	// 2 Byte
-#define REG_EE_VPD_8188F				0x000C	// 2 Byte
-#define REG_AFE_MISC_8188F				0x0010	// 1 Byte
-#define REG_SPS0_CTRL_8188F				0x0011	// 7 Byte
-#define REG_SPS_OCP_CFG_8188F			0x0018	// 4 Byte
-#define REG_RSV_CTRL_8188F				0x001C	// 3 Byte
-#define REG_RF_CTRL_8188F				0x001F	// 1 Byte
-#define REG_LPLDO_CTRL_8188F			0x0023	// 1 Byte
-#define REG_AFE_XTAL_CTRL_8188F		0x0024	// 4 Byte
-#define REG_AFE_PLL_CTRL_8188F			0x0028	// 4 Byte
-#define REG_MAC_PLL_CTRL_EXT_8188F		0x002c 	// 4 Byte
+/* ************************************************************
+ *
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8188F			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8188F			0x0002	/* 2 Byte */
+#define REG_APS_FSMCO_8188F			0x0004	/* 4 Byte */
+#define REG_SYS_CLKR_8188F				0x0008	/* 2 Byte */
+#define REG_9346CR_8188F				0x000A	/* 2 Byte */
+#define REG_EE_VPD_8188F				0x000C	/* 2 Byte */
+#define REG_AFE_MISC_8188F				0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8188F				0x0011	/* 7 Byte */
+#define REG_SPS_OCP_CFG_8188F			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8188F				0x001C	/* 3 Byte */
+#define REG_RF_CTRL_8188F				0x001F	/* 1 Byte */
+#define REG_LPLDO_CTRL_8188F			0x0023	/* 1 Byte */
+#define REG_AFE_XTAL_CTRL_8188F		0x0024	/* 4 Byte */
+#define REG_AFE_PLL_CTRL_8188F			0x0028	/* 4 Byte */
+#define REG_MAC_PLL_CTRL_EXT_8188F		0x002c	/* 4 Byte */
 #define REG_EFUSE_CTRL_8188F			0x0030
 #define REG_EFUSE_TEST_8188F			0x0034
 #define REG_PWR_DATA_8188F				0x0038
@@ -84,11 +98,11 @@
 #define REG_SYS_CFG1_8188F				0x00FC
 #define REG_ROM_VERSION					0x00FD
 
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_CR_8188F						0x0100
 #define REG_PBP_8188F					0x0104
 #define REG_PKT_BUFF_ACCESS_CTRL_8188F	0x0106
@@ -115,10 +129,11 @@
 #define REG_32K_CAL_REG1_8188F			0x0198
 #define REG_C2HEVT_MSG_NORMAL_8188F		0x01A0
 #define REG_C2HEVT_CMD_SEQ_88XX			0x01A1
-#define REG_C2hEVT_CMD_CONTENT_88XX		0x01A2
+#define reg_c2h_evt_cmd_content_88xx		0x01A2
 #define REG_C2HEVT_CMD_LEN_88XX			0x01AE
 #define REG_C2HEVT_CLEAR_8188F			0x01AF
 #define REG_MCUTST_1_8188F				0x01C0
+#define REG_MCUTST_2_8188F				0x01C4
 #define REG_MCUTST_WOWLAN_8188F			0x01C7
 #define REG_FMETHR_8188F				0x01C8
 #define REG_HMETFR_8188F				0x01CC
@@ -132,11 +147,11 @@
 #define REG_HMEBOX_EXT2_8188F			0x01F8
 #define REG_HMEBOX_EXT3_8188F			0x01FC
 
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_RQPN_8188F					0x0200
 #define REG_FIFOPAGE_8188F				0x0204
 #define REG_TDECTRL_8188F				0x0208
@@ -148,15 +163,15 @@
 #define REG_TDECTRL1_8188F				0x0228
 #define REG_DWBCN1_CTRL_8188F			0x0228
 
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_RXDMA_AGG_PG_TH_8188F		0x0280
-#define REG_FW_UPD_RDPTR_8188F			0x0284 // FW shall update this register before FW write RXPKT_RELEASE_POLL to 1
-#define REG_RXDMA_CONTROL_8188F			0x0286 // Control the RX DMA.
-#define REG_RXPKT_NUM_8188F				0x0287 // The number of packets in RXPKTBUF.	
+#define REG_FW_UPD_RDPTR_8188F			0x0284 /* FW shall update this register before FW write RXPKT_RELEASE_POLL to 1 */
+#define REG_RXDMA_CONTROL_8188F			0x0286 /* Control the RX DMA. */
+#define REG_RXPKT_NUM_8188F				0x0287 /* The number of packets in RXPKTBUF. */
 #define REG_RXDMA_STATUS_8188F			0x0288
 #define REG_RXDMA_PRO_8188F				0x0290
 #define REG_EARLY_MODE_CONTROL_8188F	0x02BC
@@ -164,41 +179,41 @@
 #define REG_RSVD6_8188F					0x02F4
 
 
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
 #define	REG_PCIE_CTRL_REG_8188F		0x0300
-#define	REG_INT_MIG_8188F				0x0304	// Interrupt Migration 
-#define	REG_BCNQ_DESA_8188F			0x0308	// TX Beacon Descriptor Address
-#define	REG_HQ_DESA_8188F				0x0310	// TX High Queue Descriptor Address
-#define	REG_MGQ_DESA_8188F			0x0318	// TX Manage Queue Descriptor Address
-#define	REG_VOQ_DESA_8188F			0x0320	// TX VO Queue Descriptor Address
-#define	REG_VIQ_DESA_8188F				0x0328	// TX VI Queue Descriptor Address
-#define	REG_BEQ_DESA_8188F			0x0330	// TX BE Queue Descriptor Address
-#define	REG_BKQ_DESA_8188F			0x0338	// TX BK Queue Descriptor Address
-#define	REG_RX_DESA_8188F				0x0340	// RX Queue	Descriptor Address
-#define	REG_DBI_WDATA_8188F			0x0348	// DBI Write Data
-#define	REG_DBI_RDATA_8188F			0x034C	// DBI Read Data
-#define	REG_DBI_ADDR_8188F				0x0350	// DBI Address
-#define	REG_DBI_FLAG_8188F				0x0352	// DBI Read/Write Flag
-#define	REG_MDIO_WDATA_8188F		0x0354	// MDIO for Write PCIE PHY
-#define	REG_MDIO_RDATA_8188F			0x0356	// MDIO for Reads PCIE PHY
-#define	REG_MDIO_CTL_8188F			0x0358	// MDIO for Control
-#define	REG_DBG_SEL_8188F				0x0360	// Debug Selection Register
-#define	REG_PCIE_HRPWM_8188F			0x0361	//PCIe RPWM
-#define	REG_PCIE_HCPWM_8188F			0x0363	//PCIe CPWM
-#define	REG_PCIE_MULTIFET_CTRL_8188F	0x036A	//PCIE Multi-Fethc Control
-
-#define	REG_MGQ_TXBD_NUM_8188F 			0x0380
-
-// spec version 11
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
+#define	REG_INT_MIG_8188F				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_DESA_8188F			0x0308	/* TX Beacon Descriptor Address */
+#define	REG_HQ_DESA_8188F				0x0310	/* TX High Queue Descriptor Address */
+#define	REG_MGQ_DESA_8188F			0x0318	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_DESA_8188F			0x0320	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_DESA_8188F				0x0328	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_DESA_8188F			0x0330	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_DESA_8188F			0x0338	/* TX BK Queue Descriptor Address */
+#define	REG_RX_DESA_8188F				0x0340	/* RX Queue	Descriptor Address */
+#define	REG_DBI_WDATA_8188F			0x0348	/* DBI Write data */
+#define	REG_DBI_RDATA_8188F			0x034C	/* DBI Read data */
+#define	REG_DBI_ADDR_8188F				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8188F				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8188F		0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8188F			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8188F			0x0358	/* MDIO for Control */
+#define	REG_DBG_SEL_8188F				0x0360	/* Debug Selection Register */
+#define	REG_PCIE_HRPWM_8188F			0x0361	/* PCIe RPWM */
+#define	REG_PCIE_HCPWM_8188F			0x0363	/* PCIe CPWM */
+#define	REG_PCIE_MULTIFET_CTRL_8188F	0x036A	/* PCIE Multi-Fethc Control */
+
+#define	REG_MGQ_TXBD_NUM_8188F			0x0380
+
+/* spec version 11
+ * -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_VOQ_INFORMATION_8188F		0x0400
 #define REG_VIQ_INFORMATION_8188F		0x0404
 #define REG_BEQ_INFORMATION_8188F		0x0408
@@ -248,11 +263,11 @@
 #define REG_MACID_PKT_DROP0_8188F		0x04D0
 #define REG_MACID_PKT_SLEEP_8188F		0x04D4
 
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_EDCA_VO_PARAM_8188F		0x0500
 #define REG_EDCA_VI_PARAM_8188F		0x0504
 #define REG_EDCA_BE_PARAM_8188F		0x0508
@@ -268,21 +283,21 @@
 #define REG_TXPAUSE_8188F				0x0522
 #define REG_DIS_TXREQ_CLR_8188F		0x0523
 #define REG_RD_CTRL_8188F				0x0524
-//
-// Format for offset 540h-542h:
-//	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
-//	[7:4]:   Reserved.
-//	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
-//	[23:20]: Reserved
-// Description:
-//	              |
-//     |<--Setup--|--Hold------------>|
-//	--------------|----------------------
-//                |
-//               TBTT
-// Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
-// Described by Designer Tim and Bruce, 2011-01-14.
-//
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
 #define REG_TBTT_PROHIBIT_8188F			0x0540
 #define REG_RD_NAV_NXT_8188F			0x0544
 #define REG_NAV_PROT_LEN_8188F			0x0546
@@ -297,7 +312,7 @@
 #define REG_USTIME_TSF_8188F			0x055C
 #define REG_BCN_MAX_ERR_8188F			0x055D
 #define REG_RXTSF_OFFSET_CCK_8188F		0x055E
-#define REG_RXTSF_OFFSET_OFDM_8188F	0x055F	
+#define REG_RXTSF_OFFSET_OFDM_8188F	0x055F
 #define REG_TSFTR_8188F					0x0560
 #define REG_CTWND_8188F					0x0572
 #define REG_SECONDARY_CCA_CTRL_8188F	0x0577
@@ -307,11 +322,11 @@
 #define REG_ACMHWCTRL_8188F			0x05C0
 #define REG_SCH_TXCMD_8188F			0x05F8
 
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_MAC_CR_8188F				0x0600
 #define REG_TCR_8188F					0x0604
 #define REG_RCR_8188F					0x0608
@@ -332,17 +347,17 @@
 #define REG_CTS2TO_8188F				0x0641
 #define REG_EIFS_8188F					0x0642
 
-#define REG_NAV_UPPER_8188F			0x0652	// unit of 128
+#define REG_NAV_UPPER_8188F			0x0652	/* unit of 128 */
 #define REG_TRXPTCL_CTL_8188F			0x0668
 
-// Security
+/* security */
 #define REG_CAMCMD_8188F				0x0670
 #define REG_CAMWRITE_8188F				0x0674
 #define REG_CAMREAD_8188F				0x0678
 #define REG_CAMDBG_8188F				0x067C
 #define REG_SECCFG_8188F				0x0680
 
-// Power
+/* Power */
 #define REG_WOW_CTRL_8188F				0x0690
 #define REG_PS_RX_INFO_8188F			0x0692
 #define REG_UAPSD_TID_8188F				0x0693
@@ -360,97 +375,97 @@
 #define REG_CSI_RPT_PARAM_BW40_8188F	0x06F8
 #define REG_CSI_RPT_PARAM_BW80_8188F	0x06FC
 
-// Hardware Port 2
+/* Hardware Port 2 */
 #define REG_MACID1_8188F				0x0700
 #define REG_BSSID1_8188F				0x0708
 #define REG_BFMEE_SEL_8188F				0x0714
 #define REG_SND_PTCL_CTRL_8188F			0x0718
 
-// LTE_COEX
+/* LTE_COEX */
 #define REG_LTECOEX_CTRL				0x07C0
 #define REG_LTECOEX_WRITE_DATA			0x07C4
 
-//-----------------------------------------------------
-//
-//	Redifine 8192C register definition for compatibility
-//
-//-----------------------------------------------------
-
-// TODO: use these definition when using REG_xxx naming rule.
-// NOTE: DO NOT Remove these definition. Use later.
-#define	EFUSE_CTRL_8188F					REG_EFUSE_CTRL_8188F		// E-Fuse Control.
-#define	EFUSE_TEST_8188F					REG_EFUSE_TEST_8188F		// E-Fuse Test.
-#define	MSR_8188F							(REG_CR_8188F + 2)		// Media Status register
+/* -----------------------------------------------------
+ *
+ *	Redifine 8192C register definition for compatibility
+ *
+ * ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+ * NOTE: DO NOT Remove these definition. Use later. */
+#define	EFUSE_CTRL_8188F					REG_EFUSE_CTRL_8188F		/* E-Fuse Control. */
+#define	EFUSE_TEST_8188F					REG_EFUSE_TEST_8188F		/* E-Fuse Test. */
+#define	MSR_8188F							(REG_CR_8188F + 2)		/* Media status register */
 #define	ISR_8188F							REG_HISR0_8188F
-#define	TSFR_8188F							REG_TSFTR_8188F			// Timing Sync Function Timer Register.
-					
-#define 	PBP_8188F							REG_PBP_8188F
+#define	TSFR_8188F							REG_TSFTR_8188F			/* Timing Sync Function Timer Register. */
 
-// Redifine MACID register, to compatible prior ICs.
-#define	IDR0_8188F							REG_MACID_8188F			// MAC ID Register, Offset 0x0050-0x0053
-#define	IDR4_8188F							(REG_MACID_8188F + 4)	// MAC ID Register, Offset 0x0054-0x0055
+#define	PBP_8188F							REG_PBP_8188F
 
+/* Redifine MACID register, to compatible prior ICs. */
+#define	IDR0_8188F							REG_MACID_8188F			/* MAC ID Register, Offset 0x0050-0x0053 */
+#define	IDR4_8188F							(REG_MACID_8188F + 4)	/* MAC ID Register, Offset 0x0054-0x0055 */
 
-//
-// 9. Security Control Registers	(Offset: )
-//
-#define	RWCAM_8188F						REG_CAMCMD_8188F		//IN 8190 Data Sheet is called CAMcmd
-#define	WCAMI_8188F						REG_CAMWRITE_8188F		// Software write CAM input content
-#define	RCAMO_8188F						REG_CAMREAD_8188F		// Software read/write CAM config
+
+/*
+ * 9. security Control Registers	(Offset: )
+ *   */
+#define	RWCAM_8188F						REG_CAMCMD_8188F		/* 8190 data Sheet is called CAMcmd */
+#define	WCAMI_8188F						REG_CAMWRITE_8188F		/* Software write CAM input content */
+#define	RCAMO_8188F						REG_CAMREAD_8188F		/* Software read/write CAM config */
 #define	CAMDBG_8188F						REG_CAMDBG_8188F
-#define	SECR_8188F							REG_SECCFG_8188F		//Security Configuration Register
+#define	SECR_8188F							REG_SECCFG_8188F		/* security Configuration Register */
 
 
-//----------------------------------------------------------------------------
-//       8195 IMR/ISR bits						(offset 0xB0,  8bits)
-//----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
 #define	IMR_DISABLED_8188F					0
-// IMR DW0(0x00B0-00B3) Bit 0-31
-#define	IMR_TIMER2_8188F					BIT31		// Timeout interrupt 2
-#define	IMR_TIMER1_8188F					BIT30		// Timeout interrupt 1	
-#define	IMR_PSTIMEOUT_8188F				BIT29		// Power Save Time Out Interrupt
-#define	IMR_GTINT4_8188F					BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define	IMR_GTINT3_8188F					BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define	IMR_TXBCN0ERR_8188F				BIT26		// Transmit Beacon0 Error			
-#define	IMR_TXBCN0OK_8188F				BIT25		// Transmit Beacon0 OK			
-#define	IMR_TSF_BIT32_TOGGLE_8188F		BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define	IMR_BCNDMAINT0_8188F				BIT20		// Beacon DMA Interrupt 0			
-#define	IMR_BCNDERR0_8188F				BIT16		// Beacon Queue DMA OK0			
-#define	IMR_HSISR_IND_ON_INT_8188F		BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)
-#define	IMR_BCNDMAINT_E_8188F			BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define	IMR_ATIMEND_8188F				BIT12		// CTWidnow End or ATIM Window End
-#define	IMR_C2HCMD_8188F					BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define	IMR_CPWM2_8188F					BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_CPWM_8188F					BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_HIGHDOK_8188F				BIT7			// High Queue DMA OK	
-#define	IMR_MGNTDOK_8188F				BIT6			// Management Queue DMA OK	
-#define	IMR_BKDOK_8188F					BIT5			// AC_BK DMA OK		
-#define	IMR_BEDOK_8188F					BIT4			// AC_BE DMA OK	
-#define	IMR_VIDOK_8188F					BIT3			// AC_VI DMA OK		
-#define	IMR_VODOK_8188F					BIT2			// AC_VO DMA OK	
-#define	IMR_RDU_8188F					BIT1			// Rx Descriptor Unavailable	
-#define	IMR_ROK_8188F					BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define	IMR_BCNDMAINT7_8188F				BIT27		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT6_8188F				BIT26		// Beacon DMA Interrupt 6
-#define	IMR_BCNDMAINT5_8188F				BIT25		// Beacon DMA Interrupt 5
-#define	IMR_BCNDMAINT4_8188F				BIT24		// Beacon DMA Interrupt 4
-#define	IMR_BCNDMAINT3_8188F				BIT23		// Beacon DMA Interrupt 3
-#define	IMR_BCNDMAINT2_8188F				BIT22		// Beacon DMA Interrupt 2
-#define	IMR_BCNDMAINT1_8188F				BIT21		// Beacon DMA Interrupt 1
-#define	IMR_BCNDOK7_8188F					BIT20		// Beacon Queue DMA OK Interrup 7
-#define	IMR_BCNDOK6_8188F					BIT19		// Beacon Queue DMA OK Interrup 6
-#define	IMR_BCNDOK5_8188F					BIT18		// Beacon Queue DMA OK Interrup 5
-#define	IMR_BCNDOK4_8188F					BIT17		// Beacon Queue DMA OK Interrup 4
-#define	IMR_BCNDOK3_8188F					BIT16		// Beacon Queue DMA OK Interrup 3
-#define	IMR_BCNDOK2_8188F					BIT15		// Beacon Queue DMA OK Interrup 2
-#define	IMR_BCNDOK1_8188F					BIT14		// Beacon Queue DMA OK Interrup 1
-#define	IMR_ATIMEND_E_8188F				BIT13		// ATIM Window End Extension for Win7
-#define	IMR_TXERR_8188F					BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define	IMR_RXERR_8188F					BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define	IMR_TXFOVW_8188F					BIT9			// Transmit FIFO Overflow
-#define	IMR_RXFOVW_8188F					BIT8			// Receive FIFO Overflow
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8188F					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8188F					BIT(30)		/* Timeout interrupt 1 */
+#define	IMR_PSTIMEOUT_8188F				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8188F					BIT(28)		/* When GTIMER4 expires, this bit is set to 1 */
+#define	IMR_GTINT3_8188F					BIT(27)		/* When GTIMER3 expires, this bit is set to 1 */
+#define	IMR_TXBCN0ERR_8188F				BIT(26)		/* Transmit Beacon0 Error */
+#define	IMR_TXBCN0OK_8188F				BIT(25)		/* Transmit Beacon0 OK */
+#define	IMR_TSF_BIT32_TOGGLE_8188F		BIT(24)		/* TSF Timer BIT32 toggle indication interrupt */
+#define	IMR_BCNDMAINT0_8188F				BIT(20)		/* Beacon DMA Interrupt 0 */
+#define	IMR_BCNDERR0_8188F				BIT(16)		/* Beacon Queue DMA OK0 */
+#define	IMR_HSISR_IND_ON_INT_8188F		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8188F			BIT(14)		/* Beacon DMA Interrupt Extension for Win7 */
+#define	IMR_ATIMEND_8188F				BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8188F					BIT(10)		/* CPU to Host Command INT status, Write 1 clear */
+#define	IMR_CPWM2_8188F					BIT(9)			/* CPU power mode exchange INT status, Write 1 clear */
+#define	IMR_CPWM_8188F					BIT(8)			/* CPU power mode exchange INT status, Write 1 clear */
+#define	IMR_HIGHDOK_8188F				BIT(7)			/* High Queue DMA OK */
+#define	IMR_MGNTDOK_8188F				BIT(6)			/* Management Queue DMA OK */
+#define	IMR_BKDOK_8188F					BIT(5)			/* AC_BK DMA OK */
+#define	IMR_BEDOK_8188F					BIT(4)			/* AC_BE DMA OK */
+#define	IMR_VIDOK_8188F					BIT(3)			/* AC_VI DMA OK */
+#define	IMR_VODOK_8188F					BIT(2)			/* AC_VO DMA OK */
+#define	IMR_RDU_8188F					BIT(1)			/* Rx Descriptor Unavailable */
+#define	IMR_ROK_8188F					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8188F				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8188F				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8188F				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8188F				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8188F				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8188F				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8188F				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8188F					BIT(20)		/* Beacon Queue DMA OK Interrup 7 */
+#define	IMR_BCNDOK6_8188F					BIT(19)		/* Beacon Queue DMA OK Interrup 6 */
+#define	IMR_BCNDOK5_8188F					BIT(18)		/* Beacon Queue DMA OK Interrup 5 */
+#define	IMR_BCNDOK4_8188F					BIT(17)		/* Beacon Queue DMA OK Interrup 4 */
+#define	IMR_BCNDOK3_8188F					BIT(16)		/* Beacon Queue DMA OK Interrup 3 */
+#define	IMR_BCNDOK2_8188F					BIT(15)		/* Beacon Queue DMA OK Interrup 2 */
+#define	IMR_BCNDOK1_8188F					BIT(14)		/* Beacon Queue DMA OK Interrup 1 */
+#define	IMR_ATIMEND_E_8188F				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8188F					BIT(11)		/* Tx Error Flag Interrupt status, write 1 clear. */
+#define	IMR_RXERR_8188F					BIT(10)		/* Rx Error Flag INT status, Write 1 clear */
+#define	IMR_TXFOVW_8188F					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8188F					BIT(8)			/* Receive FIFO Overflow */
 
 
 
@@ -458,7 +473,7 @@
 
 /*===================================================================
 =====================================================================
-Here the register defines are for 92C. When the define is as same with 92C, 
+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!!!!!!
 =====================================================================
@@ -477,387 +492,387 @@ Current IOREG MAP
 0x0600h ~ 0x07FFh   WMAC Configuration (512 Bytes)
 0x2000h ~ 0x3FFFh   8051 FW Download Region (8196 Bytes)
 */
-//----------------------------------------------------------------------------
-//		 8195 (TXPAUSE) transmission pause 	(Offset 0x522, 8 bits)
-//----------------------------------------------------------------------------
-/*
-#define		StopBecon			BIT6
-#define		StopHigh				BIT5
-#define		StopMgt				BIT4
-#define		StopVO				BIT3
-#define		StopVI				BIT2
-#define		StopBE				BIT1
-#define		StopBK				BIT0
-*/
-
-
-//============================================================================
-//       8192C Regsiter Bit and Content definition 
-//============================================================================
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-/*
-//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_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)
-
-
-//2 9346CR
-
-#define		BOOT_FROM_EEPROM		BIT(4)
-#define		EEPROM_EN				BIT(5)
-
-
-//2 RF_CTRL
-#define RF_EN						BIT(0)
-#define RF_RSTB					BIT(1)
-#define RF_SDMRSTB				BIT(2)
-
-//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 EFUSE_TEST (For RTL8188 partially)
-#define EF_TRPT						BIT(7)
-#define EF_CELL_SEL						(BIT(8)|BIT(9)) // 00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2
-#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
-
-
-//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 RAM_DL_SEL					BIT(7)
-#define ROM_DLEN						BIT(19)
-#define CPRST							BIT(23)
-
-
-
-//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)	// RTL ID
-#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
-
-*/
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-/*
-
-//2 Function Enable Registers
-//2 CR 0x0100-0x0103
-
-
-#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 CALTMR_EN					BIT(10)	// 32k CAL TMR enable
-
-// Network type
-#define _NETTYPE(x)					(((x) & 0x3) << 16)
-#define MASK_NETTYPE					0x30000
-#define NT_NO_LINK					0x0
-#define NT_LINK_AD_HOC				0x1
-#define NT_LINK_AP						0x2
-#define NT_AS_AP						0x3
-
-
-//2 PBP - Page Size Register 0x0104
-#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 0x010C
-#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 REG_C2HEVT_CLEAR 0x01AF 
-#define	C2H_EVT_HOST_CLOSE			0x00	// Set by driver and notify FW that the driver has read the C2H command message
-#define	C2H_EVT_FW_CLOSE			0xFF		// Set by FW indicating that FW had set the C2H command message and it's not yet read by driver.
-
-
-
-//2 LLT_INIT 0x01E0
-#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)
-
+/* ----------------------------------------------------------------------------
+ *		 8195 (TXPAUSE) transmission pause	(Offset 0x522, 8 bits)
+ * ----------------------------------------------------------------------------
+ *
+#define		StopBecon			BIT(6)
+#define		StopHigh				BIT(5)
+#define		StopMgt				BIT(4)
+#define		StopVO				BIT(3)
+#define		StopVI				BIT(2)
+#define		StopBE				BIT(1)
+#define		StopBK				BIT(0)
 */
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-/*
-//2 TDECTL 0x0208
-#define BLK_DESC_NUM_SHIFT			4
-#define BLK_DESC_NUM_MASK			0xF
 
 
-//2 TXDMA_OFFSET_CHK 0x020C
-#define DROP_DATA_EN				BIT(9)
-*/
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x028Bh	RX DMA Configuration
-//
-//-----------------------------------------------------
-/*
-//2 REG_RXDMA_CONTROL, 0x0286h
-
-// Write only. When this bit is set, RXDMA will decrease RX PKT counter by one. Before
-// this bit is polled, FW shall update RXFF_RD_PTR first. This register is write pulse and auto clear.
-#define	RXPKT_RELEASE_POLL			BIT(0)
-// Read only. When RXMA finishes on-going DMA operation, RXMDA will report idle state in 
-// this bit. FW can start releasing packets after RXDMA entering idle mode.
-#define	RXDMA_IDLE					BIT(1)	
-// When this bit is set, RXDMA will enter this mode after on-going RXDMA packet to host 
-// completed, and stop DMA packet to host. RXDMA will then report Default: 0;
-#define	RW_RELEASE_EN				BIT(2)
-*/
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-/*
-//2 FWHW_TXQ_CTRL 0x0420
-#define EN_AMPDU_RTY_NEW			BIT(7)
-
+/* ****************************************************************************
+ * 8192C Regsiter Bit and Content definition
+ * ****************************************************************************
+ * -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#if 0
+	/* 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_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)
+
+
+	/* 2 9346CR */
+
+	#define		BOOT_FROM_EEPROM		BIT(4)
+	#define		EEPROM_EN				BIT(5)
+
+
+	/* 2 RF_CTRL */
+	#define RF_EN						BIT(0)
+	#define RF_RSTB					BIT(1)
+	#define RF_SDMRSTB				BIT(2)
+
+	/* 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 EFUSE_TEST (For RTL8188 partially) */
+	#define EF_TRPT						BIT(7)
+	#define EF_CELL_SEL						(BIT(8) | BIT(9)) /*  00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2 */
+	#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
+
+
+	/* 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 RAM_DL_SEL					BIT(7)
+	#define ROM_DLEN						BIT(19)
+	#define CPRST							BIT(23)
+
+
+
+	/* 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)	/*  RTL ID */
+	#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
+
+#endif
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#if 0
+
+	/* 2 Function Enable Registers */
+	/* 2 CR 0x0100-0x0103 */
+
+
+	#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 CALTMR_EN					BIT(10)	/*  32k CAL TMR enable */
+
+	/*  Network type */
+	#define _NETTYPE(x)					(((x) & 0x3) << 16)
+	#define MASK_NETTYPE					0x30000
+	#define NT_NO_LINK					0x0
+	#define NT_LINK_AD_HOC				0x1
+	#define NT_LINK_AP						0x2
+	#define NT_AS_AP						0x3
+
+
+	/* 2 PBP - Page Size Register 0x0104 */
+	#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 0x010C */
+	#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 REG_C2HEVT_CLEAR 0x01AF */
+	#define	C2H_EVT_HOST_CLOSE			0x00	/*  Set by driver and notify FW that the driver has read the C2H command message */
+	#define	C2H_EVT_FW_CLOSE			0xFF		/*  Set by FW indicating that FW had set the C2H command message and it's not yet read by driver. */
+
+
+
+	/* 2 LLT_INIT 0x01E0 */
+	#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)
+
+#endif
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#if 0
+	/* 2 TDECTL 0x0208 */
+	#define BLK_DESC_NUM_SHIFT			4
+	#define BLK_DESC_NUM_MASK			0xF
 
-//2 REG_LIFECTRL_CTRL 0x0426
-#define	HAL92C_EN_PKT_LIFE_TIME_BK		BIT3
-#define	HAL92C_EN_PKT_LIFE_TIME_BE		BIT2
-#define	HAL92C_EN_PKT_LIFE_TIME_VI		BIT1
-#define	HAL92C_EN_PKT_LIFE_TIME_VO		BIT0
 
-#define	HAL92C_MSDU_LIFE_TIME_UNIT		128		// in us, said by Tim.
+	/* 2 TXDMA_OFFSET_CHK 0x020C */
+	#define DROP_DATA_EN				BIT(9)
+#endif
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x028Bh	RX DMA Configuration
+ *
+ * ----------------------------------------------------- */
+#if 0
+	/* 2 REG_RXDMA_CONTROL, 0x0286h */
+
+	/*  Write only. When this bit is set, RXDMA will decrease RX PKT counter by one. Before */
+	/*  this bit is polled, FW shall update RXFF_RD_PTR first. This register is write pulse and auto clear. */
+	#define	RXPKT_RELEASE_POLL			BIT(0)
+	/*  Read only. When RXMA finishes on-going DMA operation, RXMDA will report idle state in */
+	/*  this bit. FW can start releasing packets after RXDMA entering idle mode. */
+	#define	RXDMA_IDLE					BIT(1)
+	/*  When this bit is set, RXDMA will enter this mode after on-going RXDMA packet to host */
+	/*  completed, and stop DMA packet to host. RXDMA will then report Default: 0; */
+	#define	RW_RELEASE_EN				BIT(2)
+#endif
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#if 0
+	/* 2 FWHW_TXQ_CTRL 0x0420 */
+	#define EN_AMPDU_RTY_NEW			BIT(7)
 
 
-//2 SPEC SIFS 0x0428 
-#define _SPEC_SIFS_CCK(x)				((x) & 0xFF)
-#define _SPEC_SIFS_OFDM(x)				(((x) & 0xFF) << 8)
+	/* 2 REG_LIFECTRL_CTRL 0x0426 */
+	#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)
 
-//2 RL 0x042A
-#define	RETRY_LIMIT_SHORT_SHIFT		8
-#define	RETRY_LIMIT_LONG_SHIFT		0
+	#define	HAL92C_MSDU_LIFE_TIME_UNIT		128		/*  in us, said by Tim. */
 
-#define _LRL(x)							((x) & 0x3F)
-#define _SRL(x)							(((x) & 0x3F) << 8)
-*/
 
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-/*
-//2 EDCA setting 0x050C
-#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 SPEC SIFS 0x0428 */
+	#define _SPEC_SIFS_CCK(x)				((x) & 0xFF)
+	#define _SPEC_SIFS_OFDM(x)				(((x) & 0xFF) << 8)
 
+	/* 2 RL 0x042A */
+	#define	RETRY_LIMIT_SHORT_SHIFT		8
+	#define	RETRY_LIMIT_LONG_SHIFT		0
 
-//2 BCN_CTRL 0x0550
-#define EN_TXBCN_RPT						BIT(2)
-#define EN_BCN_FUNCTION					BIT(3)
+	#define _LRL(x)							((x) & 0x3F)
+	#define _SRL(x)							(((x) & 0x3F) << 8)
+#endif
 
-//2 TxPause 0x0522
-#define STOP_BCNQ						BIT(6)
-*/
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#if 0
+	/* 2 EDCA setting 0x050C */
+	#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 ACMHWCTRL 0x05C0
-#define	AcmHw_HwEn_8188F				BIT(0)
-#define	AcmHw_VoqEn_8188F				BIT(1)
-#define	AcmHw_ViqEn_8188F				BIT(2)
-#define	AcmHw_BeqEn_8188F				BIT(3)
-#define	AcmHw_VoqStatus_8188F			BIT(5)
-#define	AcmHw_ViqStatus_8188F			BIT(6)
-#define	AcmHw_BeqStatus_8188F			BIT(7)
+	/* 2 BCN_CTRL 0x0550 */
+	#define EN_TXBCN_RPT						BIT(2)
+	#define EN_BCN_FUNCTION					BIT(3)
 
+	/* 2 TxPause 0x0522 */
+	#define STOP_BCNQ						BIT(6)
+#endif
 
 
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-/*
+/* 2 ACMHWCTRL 0x05C0 */
+#define	acm_hw_hw_en_8188f				BIT(0)
+#define	acm_hw_voq_en_8188f				BIT(1)
+#define	acm_hw_viq_en_8188f				BIT(2)
+#define	acm_hw_beq_en_8188f				BIT(3)
+#define	acm_hw_voq_status_8188f			BIT(5)
+#define	acm_hw_viq_status_8188f			BIT(6)
+#define	acm_hw_beq_status_8188f			BIT(7)
 
-//2 TCR 0x0604
-#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)
-*/
 
-//----------------------------------------------------------------------------
-//       8195 (RCR) Receive Configuration Register	(Offset 0x608, 32 bits)
-//----------------------------------------------------------------------------
-/*
-#define	RCR_APPFCS					BIT31		// WMAC append FCS after pauload
-#define	RCR_APP_MIC					BIT30		// MACRX will retain the MIC at the bottom of the packet. 
-#define	RCR_APP_ICV					BIT29       // MACRX will retain the ICV at the bottom of the packet.
-#define	RCR_APP_PHYST_RXFF			BIT28       // HY Status is appended before RX packet in RXFF
-#define	RCR_APP_BA_SSN				BIT27		// SSN of previous TXBA is appended as after original RXDESC as the 4-th DW of RXDESC.
-#define	RCR_RSVD_BIT26				BIT26		// Reserved
-*/
-#define	RCR_TCPOFLD_EN				BIT25		// Enable TCP checksum offload
 
-#endif // #ifndef __INC_HAL8188FREG_H
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#if 0
+
+	/* 2 TCR 0x0604 */
+	#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)
+#endif
+
+/* ----------------------------------------------------------------------------
+ * 8195 (RCR) Receive Configuration Register	(Offset 0x608, 32 bits)
+ * ---------------------------------------------------------------------------- */
+#if 0
+	#define	RCR_APPFCS					BIT(31)		/*  WMAC append FCS after pauload */
+	#define	RCR_APP_MIC					BIT(30)		/*  MACRX will retain the MIC at the bottom of the packet. */
+	#define	RCR_APP_ICV					BIT(29)       /*  MACRX will retain the ICV at the bottom of the packet. */
+	#define	RCR_APP_PHYST_RXFF			BIT(28)       /*  HY status is appended before RX packet in RXFF */
+	#define	RCR_APP_BA_SSN				BIT(27)		/*  SSN of previous TXBA is appended as after original RXDESC as the 4-th DW of RXDESC. */
+	#define	RCR_RSVD_BIT(26)				BIT26		/*  Reserved */
+#endif
+#define	RCR_TCPOFLD_EN				BIT(25)		/* Enable TCP checksum offload */
+
+#endif /*  #ifndef __INC_HAL8188FREG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.c
index 9dc6eaf23bc4..e9803b780f78 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.c
@@ -1,599 +1,596 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.26*/
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (RTL8188F_SUPPORT == 1)
-static BOOLEAN
-CheckPositive(
-	IN  PDM_ODM_T     pDM_Odm,
-	IN  const u4Byte  Condition1,
-	IN  const u4Byte  Condition2,
-	IN	const u4Byte  Condition3,
-	IN	const u4Byte  Condition4
-)
-{
-	u1Byte    _BoardType = ((pDM_Odm->BoardType & BIT4) >> 4) << 0 | /* _GLNA*/
-				((pDM_Odm->BoardType & BIT3) >> 3) << 1 | /* _GPA*/ 
-				((pDM_Odm->BoardType & BIT7) >> 7) << 2 | /* _ALNA*/
-				((pDM_Odm->BoardType & BIT6) >> 6) << 3 | /* _APA */
-				((pDM_Odm->BoardType & BIT2) >> 2) << 4 | /* _BT*/  
-				((pDM_Odm->BoardType & BIT1) >> 1) << 5;  /* _NGFF*/  
-
-	u4Byte	cond1   = Condition1, cond2 = Condition2, cond3 = Condition3, cond4 = Condition4;
-
-	u1Byte	cut_version_for_para   = (pDM_Odm->CutVersion == ODM_CUT_A) ? 15 : pDM_Odm->CutVersion;
-	u1Byte	pkg_type_for_para   = (pDM_Odm->PackageType == 0) ? 15 : pDM_Odm->PackageType;
-
-	u4Byte    driver1 = cut_version_for_para       << 24 | 
-				(pDM_Odm->SupportInterface & 0xF0) << 16 | 
-				pDM_Odm->SupportPlatform  << 16 | 
-				pkg_type_for_para      << 12 | 
-				(pDM_Odm->SupportInterface & 0x0F) << 8  |
-				_BoardType;
-
-	u4Byte    driver2 = (pDM_Odm->TypeGLNA & 0xFF) <<  0 |  
-				(pDM_Odm->TypeGPA & 0xFF)  <<  8 | 
-				(pDM_Odm->TypeALNA & 0xFF) << 16 | 
-				(pDM_Odm->TypeAPA & 0xFF)  << 24; 
-
-u4Byte    driver3 = 0;
-
-	u4Byte    driver4 = (pDM_Odm->TypeGLNA & 0xFF00) >>  8 |
-				(pDM_Odm->TypeGPA & 0xFF00) |
-				(pDM_Odm->TypeALNA & 0xFF00) << 8 |
-				(pDM_Odm->TypeAPA & 0xFF00)  << 16;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("===> CheckPositive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("===> CheckPositive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("	(Platform, Interface) = (0x%X, 0x%X)\n", pDM_Odm->SupportPlatform, pDM_Odm->SupportInterface));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("	(Board, Package) = (0x%X, 0x%X)\n", pDM_Odm->BoardType, pDM_Odm->PackageType));
-
-
-	/*============== Value Defined Check ===============*/
-	/*QFN Type [15:12] and Cut Version [27:24] need to do value check*/
-	
-	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
-		return FALSE;
-	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
-		return FALSE;
-
-	/*=============== Bit Defined Check ================*/
-	/* We don't care [31:28] */
-
-	cond1   &= 0x00FF0FFF; 
-	driver1 &= 0x00FF0FFF; 
-
-	if ((cond1 & driver1) == cond1) {
-		u4Byte bitMask = 0;
-
-		if ((cond1 & 0x0F) == 0) /* BoardType is DONTCARE*/
-			return TRUE;
-
-		if ((cond1 & BIT0) != 0) /*GLNA*/
-			bitMask |= 0x000000FF;
-		if ((cond1 & BIT1) != 0) /*GPA*/
-			bitMask |= 0x0000FF00;
-		if ((cond1 & BIT2) != 0) /*ALNA*/
-			bitMask |= 0x00FF0000;
-		if ((cond1 & BIT3) != 0) /*APA*/
-			bitMask |= 0xFF000000;
-
-		if (((cond2 & bitMask) == (driver2 & bitMask)) && ((cond4 & bitMask) == (driver4 & bitMask)))  /* BoardType of each RF path is matched*/
-			return TRUE;
-		else
-			return FALSE;
-	} else
-		return FALSE;
-}
-static BOOLEAN
-CheckNegative(
-	IN  PDM_ODM_T     pDM_Odm,
-	IN  const u4Byte  Condition1,
-	IN  const u4Byte  Condition2
-)
-{
-	return TRUE;
-}
-
-/******************************************************************************
-*                           AGC_TAB.TXT
-******************************************************************************/
-
-u4Byte Array_MP_8188F_AGC_TAB[] = { 
-		0xC78, 0xFC000001,
-		0xC78, 0xFB010001,
-		0xC78, 0xFA020001,
-		0xC78, 0xF9030001,
-		0xC78, 0xF8040001,
-		0xC78, 0xF7050001,
-		0xC78, 0xF6060001,
-		0xC78, 0xF5070001,
-		0xC78, 0xF4080001,
-		0xC78, 0xF3090001,
-		0xC78, 0xF20A0001,
-		0xC78, 0xF10B0001,
-		0xC78, 0xF00C0001,
-		0xC78, 0xEF0D0001,
-		0xC78, 0xEE0E0001,
-		0xC78, 0xED0F0001,
-		0xC78, 0xEC100001,
-		0xC78, 0xEB110001,
-		0xC78, 0xEA120001,
-		0xC78, 0xE9130001,
-		0xC78, 0xE8140001,
-		0xC78, 0xE7150001,
-		0xC78, 0xE6160001,
-		0xC78, 0xE5170001,
-		0xC78, 0xE4180001,
-		0xC78, 0xE3190001,
-		0xC78, 0xE21A0001,
-		0xC78, 0xE11B0001,
-		0xC78, 0xE01C0001,
-		0xC78, 0xC21D0001,
-		0xC78, 0xC11E0001,
-		0xC78, 0xC01F0001,
-		0xC78, 0xA5200001,
-		0xC78, 0xA4210001,
-		0xC78, 0xA3220001,
-		0xC78, 0xA2230001,
-		0xC78, 0xA1240001,
-		0xC78, 0xA0250001,
-		0xC78, 0x65260001,
-		0xC78, 0x64270001,
-		0xC78, 0x63280001,
-		0xC78, 0x62290001,
-		0xC78, 0x612A0001,
-		0xC78, 0x442B0001,
-		0xC78, 0x432C0001,
-		0xC78, 0x422D0001,
-		0xC78, 0x412E0001,
-		0xC78, 0x402F0001,
-		0xC78, 0x21300001,
-		0xC78, 0x20310001,
-		0xC78, 0x05320001,
-		0xC78, 0x04330001,
-		0xC78, 0x03340001,
-		0xC78, 0x02350001,
-		0xC78, 0x01360001,
-		0xC78, 0x00370001,
-		0xC78, 0x00380001,
-		0xC78, 0x00390001,
-		0xC78, 0x003A0001,
-		0xC78, 0x003B0001,
-		0xC78, 0x003C0001,
-		0xC78, 0x003D0001,
-		0xC78, 0x003E0001,
-		0xC78, 0x003F0001,
-		0xC50, 0x69553422,
-		0xC50, 0x69553420,
-
-};
-
-void
-ODM_ReadAndConfig_MP_8188F_AGC_TAB(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-	u4Byte     i         = 0;
-	u1Byte     cCond;
-	BOOLEAN bMatched = TRUE, bSkipped = FALSE;
-	u4Byte     ArrayLen    = sizeof(Array_MP_8188F_AGC_TAB)/sizeof(u4Byte);
-	pu4Byte    Array       = Array_MP_8188F_AGC_TAB;
-	
-	u4Byte	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_8188F_AGC_TAB\n"));
-
-	while ((i + 1) < ArrayLen) {
-		v1 = Array[i];
-		v2 = Array[i + 1];
-
-		if (v1 & (BIT31 | BIT30)) {/*positive & negative condition*/
-			if (v1 & BIT31) {/* positive condition*/
-				cCond  = (u1Byte)((v1 & (BIT29|BIT28)) >> 28);
-				if (cCond == COND_ENDIF) {/*end*/
-					bMatched = TRUE;
-					bSkipped = FALSE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ENDIF\n"));
-				} else if (cCond == COND_ELSE) { /*else*/
-					bMatched = bSkipped?FALSE:TRUE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ELSE\n"));
-				} else {/*if , else if*/
-					pre_v1 = v1;
-					pre_v2 = v2;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IF or ELSE IF\n"));
-				}
-			} else if (v1 & BIT30) { /*negative condition*/
-				if (bSkipped == FALSE) {
-					if (CheckPositive(pDM_Odm, pre_v1, pre_v2, v1, v2)) {
-						bMatched = TRUE;
-						bSkipped = TRUE;
-					} else {
-						bMatched = FALSE;
-						bSkipped = FALSE;
-					}
-				} else
-					bMatched = FALSE;
-			}
-		} else {
-			if (bMatched)
-				odm_ConfigBB_AGC_8188F(pDM_Odm, v1, bMaskDWord, v2);
-		}
-		i = i + 2;
-	}
-}
-
-u4Byte
-ODM_GetVersion_MP_8188F_AGC_TAB(void)
-{
-	   return 36;
-}
-
-/******************************************************************************
-*                           PHY_REG.TXT
-******************************************************************************/
-
-u4Byte Array_MP_8188F_PHY_REG[] = { 
-		0x800, 0x80045700,
-		0x804, 0x00000001,
-		0x808, 0x0000FC00,
-		0x80C, 0x0000000A,
-		0x810, 0x10001331,
-		0x814, 0x020C3D10,
-		0x818, 0x00200385,
-		0x81C, 0x00000000,
-		0x820, 0x01000100,
-		0x824, 0x00390204,
-		0x828, 0x00000000,
-		0x82C, 0x00000000,
-		0x830, 0x00000000,
-		0x834, 0x00000000,
-		0x838, 0x00000000,
-		0x83C, 0x00000000,
-		0x840, 0x00010000,
-		0x844, 0x00000000,
-		0x848, 0x00000000,
-		0x84C, 0x00000000,
-		0x850, 0x00030000,
-		0x854, 0x00000000,
-		0x858, 0x569A569A,
-		0x85C, 0x569A569A,
-		0x860, 0x00000130,
-		0x864, 0x00000000,
-		0x868, 0x00000000,
-		0x86C, 0x27272700,
-		0x870, 0x00000000,
-		0x874, 0x25004000,
-		0x878, 0x00000808,
-		0x87C, 0x004F0201,
-		0x880, 0xB0000B1E,
-		0x884, 0x00000007,
-		0x888, 0x00000000,
-		0x88C, 0xCCC000C0,
-		0x890, 0x00000800,
-		0x894, 0xFFFFFFFE,
-		0x898, 0x40302010,
-		0x89C, 0x00706050,
-		0x900, 0x00000000,
-		0x904, 0x00000023,
-		0x908, 0x00000000,
-		0x90C, 0x81121111,
-		0x910, 0x00000002,
-		0x914, 0x00000201,
-		0x948, 0x99000000,
-		0x94C, 0x00000010,
-		0x950, 0x20003000,
-		0x954, 0x4A880000,
-		0x958, 0x4BC5D87A,
-		0x95C, 0x04EB9B79,
-		0x96C, 0x00000003,
-		0xA00, 0x00D046C8,
-		0xA04, 0x80FF800C,
-	0x80000400,	0x00000000,	0x40000000,	0x00000000,
-		0xA08, 0x8C038300,
-	0xA0000000,	0x00000000,
-		0xA08, 0x8C898300,
-	0xB0000000,	0x00000000,
-		0xA0C, 0x2E7F120F,
-		0xA10, 0x9500BB78,
-		0xA14, 0x1114D028,
-		0xA18, 0x00881117,
-		0xA1C, 0x89140F00,
-		0xA20, 0xD1D80000,
-		0xA24, 0x5A7DA0BD,
-		0xA28, 0x0000223B,
-		0xA2C, 0x00D30000,
-		0xA70, 0x101FBF00,
-		0xA74, 0x00000007,
-	0x80000400,	0x00000000,	0x40000000,	0x00000000,
-		0xA78, 0x00008900,
-	0xA0000000,	0x00000000,
-		0xA78, 0x00000900,
-	0xB0000000,	0x00000000,
-		0xA7C, 0x225B0606,
-		0xA80, 0x218075B1,
-		0xA84, 0x00120000,
-		0xA88, 0x040C0000,
-		0xA8C, 0x12345678,
-		0xA90, 0xABCDEF00,
-		0xA94, 0x001B1B89,
-		0xA98, 0x05100000,
-		0xA9C, 0x3F000000,
-		0xAA0, 0x00000000,
-		0xB2C, 0x00000000,
-		0xC00, 0x48071D40,
-		0xC04, 0x03A05611,
-		0xC08, 0x000000E4,
-		0xC0C, 0x6C6C6C6C,
-		0xC10, 0x18800000,
-		0xC14, 0x40000100,
-		0xC18, 0x08800000,
-		0xC1C, 0x40000100,
-		0xC20, 0x00000000,
-		0xC24, 0x00000000,
-		0xC28, 0x00000000,
-		0xC2C, 0x00000000,
-		0xC30, 0x69E9CC4A,
-		0xC34, 0x31000040,
-		0xC38, 0x21688080,
-		0xC3C, 0x00001714,
-		0xC40, 0x1F78403F,
-		0xC44, 0x00010036,
-		0xC48, 0xEC020107,
-		0xC4C, 0x007F037F,
-		0xC50, 0x69553420,
-		0xC54, 0x43BC0094,
-		0xC58, 0x00013169,
-		0xC5C, 0x00250492,
-		0xC60, 0x00000000,
-		0xC64, 0x7112848B,
-		0xC68, 0x47C07BFF,
-		0xC6C, 0x00000036,
-		0xC70, 0x2C7F000D,
-		0xC74, 0x020600DB,
-		0xC78, 0x0000001F,
-		0xC7C, 0x00B91612,
-		0xC80, 0x390000E4,
-	0x80000400,	0x00000000,	0x40000000,	0x00000000,
-		0xC84, 0x21F60000,
-	0xA0000000,	0x00000000,
-		0xC84, 0x11F60000,
-	0xB0000000,	0x00000000,
-		0xC88, 0x40000100,
-		0xC8C, 0x20200000,
-		0xC90, 0x00091521,
-		0xC94, 0x00000000,
-		0xC98, 0x00121820,
-		0xC9C, 0x00007F7F,
-		0xCA0, 0x00000000,
-		0xCA4, 0x000300A0,
-		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, 0x10000000,
-		0xCE8, 0x37644302,
-		0xCEC, 0x2F97D40C,
-		0xD00, 0x04030740,
-		0xD04, 0x40020401,
-		0xD08, 0x0000907F,
-		0xD0C, 0x20010201,
-		0xD10, 0xA0633333,
-		0xD14, 0x3333BC53,
-		0xD18, 0x7A8F5B6F,
-		0xD2C, 0xCB979975,
-		0xD30, 0x00000000,
-		0xD34, 0x40608000,
-		0xD38, 0x98000000,
-		0xD3C, 0x40127353,
-		0xD40, 0x00000000,
-		0xD44, 0x00000000,
-		0xD48, 0x00000000,
-		0xD4C, 0x00000000,
-		0xD50, 0x6437140A,
-		0xD54, 0x00000000,
-		0xD58, 0x00000282,
-		0xD5C, 0x30032064,
-		0xD60, 0x4653DE68,
-		0xD64, 0x04518A3C,
-		0xD68, 0x00002101,
-		0xD6C, 0x2A201C16,
-		0xD70, 0x1812362E,
-		0xD74, 0x322C2220,
-		0xD78, 0x000E3C24,
-		0xE00, 0x2D2D2D2D,
-		0xE04, 0x2D2D2D2D,
-		0xE08, 0x0390272D,
-		0xE10, 0x2D2D2D2D,
-		0xE14, 0x2D2D2D2D,
-		0xE18, 0x2D2D2D2D,
-		0xE1C, 0x2D2D2D2D,
-		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,
-		0xE60, 0x021400A0,
-		0xE64, 0x281600A0,
-		0xE6C, 0x01C00010,
-		0xE70, 0x01C00010,
-		0xE74, 0x02000010,
-		0xE78, 0x02000010,
-		0xE7C, 0x02000010,
-		0xE80, 0x02000010,
-		0xE84, 0x01C00010,
-		0xE88, 0x02000010,
-		0xE8C, 0x01C00010,
-		0xED0, 0x01C00010,
-		0xED4, 0x01C00010,
-		0xED8, 0x01C00010,
-		0xEDC, 0x00000010,
-		0xEE0, 0x00000010,
-		0xEEC, 0x03C00010,
-		0xF14, 0x00000003,
-		0xF4C, 0x00000000,
-		0xF00, 0x00000300,
-
-};
-
-void
-ODM_ReadAndConfig_MP_8188F_PHY_REG(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-	u4Byte     i         = 0;
-	u1Byte     cCond;
-	BOOLEAN bMatched = TRUE, bSkipped = FALSE;
-	u4Byte     ArrayLen    = sizeof(Array_MP_8188F_PHY_REG)/sizeof(u4Byte);
-	pu4Byte    Array       = Array_MP_8188F_PHY_REG;
-	
-	u4Byte	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_8188F_PHY_REG\n"));
-
-	while ((i + 1) < ArrayLen) {
-		v1 = Array[i];
-		v2 = Array[i + 1];
-
-		if (v1 & (BIT31 | BIT30)) {/*positive & negative condition*/
-			if (v1 & BIT31) {/* positive condition*/
-				cCond  = (u1Byte)((v1 & (BIT29|BIT28)) >> 28);
-				if (cCond == COND_ENDIF) {/*end*/
-					bMatched = TRUE;
-					bSkipped = FALSE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ENDIF\n"));
-				} else if (cCond == COND_ELSE) { /*else*/
-					bMatched = bSkipped?FALSE:TRUE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ELSE\n"));
-				} else {/*if , else if*/
-					pre_v1 = v1;
-					pre_v2 = v2;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IF or ELSE IF\n"));
-				}
-			} else if (v1 & BIT30) { /*negative condition*/
-				if (bSkipped == FALSE) {
-					if (CheckPositive(pDM_Odm, pre_v1, pre_v2, v1, v2)) {
-						bMatched = TRUE;
-						bSkipped = TRUE;
-					} else {
-						bMatched = FALSE;
-						bSkipped = FALSE;
-					}
-				} else
-					bMatched = FALSE;
-			}
-		} else {
-			if (bMatched)
-				odm_ConfigBB_PHY_8188F(pDM_Odm, v1, bMaskDWord, v2);
-		}
-		i = i + 2;
-	}
-}
-
-u4Byte
-ODM_GetVersion_MP_8188F_PHY_REG(void)
-{
-	   return 36;
-}
-
-/******************************************************************************
-*                           PHY_REG_PG.TXT
-******************************************************************************/
-
-u4Byte Array_MP_8188F_PHY_REG_PG[] = { 
-	0, 0, 0, 0x00000e08, 0x0000ff00, 0x00003200,
-	0, 0, 0, 0x0000086c, 0xffffff00, 0x32323200,
-	0, 0, 0, 0x00000e00, 0xffffffff, 0x34363636,
-	0, 0, 0, 0x00000e04, 0xffffffff, 0x28303234,
-	0, 0, 0, 0x00000e10, 0xffffffff, 0x30343434,
-	0, 0, 0, 0x00000e14, 0xffffffff, 0x26262830
-};
-
-void
-ODM_ReadAndConfig_MP_8188F_PHY_REG_PG(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-	u4Byte     i         = 0;
-	u4Byte     ArrayLen    = sizeof(Array_MP_8188F_PHY_REG_PG)/sizeof(u4Byte);
-	pu4Byte    Array       = Array_MP_8188F_PHY_REG_PG;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-
-	PlatformZeroMemory(pHalData->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
-	pHalData->nLinesReadPwrByRate = ArrayLen/6;
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_8188F_PHY_REG_PG\n"));
-
-	pDM_Odm->PhyRegPgVersion = 1;
-	pDM_Odm->PhyRegPgValueType = PHY_REG_PG_EXACT_VALUE;
-
-	for (i = 0; i < ArrayLen; i += 6) {
-		u4Byte v1 = Array[i];
-		u4Byte v2 = Array[i+1];
-		u4Byte v3 = Array[i+2];
-		u4Byte v4 = Array[i+3];
-		u4Byte v5 = Array[i+4];
-		u4Byte v6 = Array[i+5];
-
-	    odm_ConfigBB_PHY_REG_PG_8188F(pDM_Odm, v1, v2, v3, v4, v5, v6);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	rsprintf((char *)pHalData->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
-		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
-#endif
-	}
-}
-
-
-
-#endif /* end of HWIMG_SUPPORT*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: 3.5.2*/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8188F_SUPPORT == 1)
+static boolean
+check_positive(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2,
+	const u32	condition3,
+	const u32	condition4
+)
+{
+	u8	_board_type = ((dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
+			((dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
+			((dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
+			((dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
+			((dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
+			((dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
+			((dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
+
+	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
+
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
+
+	u32	driver1 = cut_version_for_para << 24 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
+			pkg_type_for_para << 12 |
+			(dm->support_interface & 0x0F) << 8  |
+			_board_type;
+
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
+
+	u32	driver3 = 0;
+
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Platform, Interface) = (0x%X, 0x%X)\n", dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Board, Package) = (0x%X, 0x%X)\n", dm->board_type, dm->package_type);
+
+
+	/*============== value Defined Check ===============*/
+	/*QFN type [15:12] and cut version [27:24] need to do value check*/
+
+	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
+		return false;
+	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
+		return false;
+
+	/*=============== Bit Defined Check ================*/
+	/* We don't care [31:28] */
+
+	cond1 &= 0x00FF0FFF;
+	driver1 &= 0x00FF0FFF;
+
+	if ((cond1 & driver1) == cond1) {
+		u32	bit_mask = 0;
+
+		if ((cond1 & 0x0F) == 0) /* board_type is DONTCARE*/
+			return true;
+
+		if ((cond1 & BIT(0)) != 0) /*GLNA*/
+			bit_mask |= 0x000000FF;
+		if ((cond1 & BIT(1)) != 0) /*GPA*/
+			bit_mask |= 0x0000FF00;
+		if ((cond1 & BIT(2)) != 0) /*ALNA*/
+			bit_mask |= 0x00FF0000;
+		if ((cond1 & BIT(3)) != 0) /*APA*/
+			bit_mask |= 0xFF000000;
+
+		if (((cond2 & bit_mask) == (driver2 & bit_mask)) && ((cond4 & bit_mask) == (driver4 & bit_mask)))  /* board_type of each RF path is matched*/
+			return true;
+		else
+			return false;
+	} else
+		return false;
+}
+static boolean
+check_negative(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2
+)
+{
+	return true;
+}
+
+/******************************************************************************
+*                           agc_tab.TXT
+******************************************************************************/
+
+u32 array_mp_8188f_agc_tab[] = {
+		0xC78, 0xFC000001,
+		0xC78, 0xFB010001,
+		0xC78, 0xFA020001,
+		0xC78, 0xF9030001,
+		0xC78, 0xF8040001,
+		0xC78, 0xF7050001,
+		0xC78, 0xF6060001,
+		0xC78, 0xF5070001,
+		0xC78, 0xF4080001,
+		0xC78, 0xF3090001,
+		0xC78, 0xF20A0001,
+		0xC78, 0xF10B0001,
+		0xC78, 0xF00C0001,
+		0xC78, 0xEF0D0001,
+		0xC78, 0xEE0E0001,
+		0xC78, 0xED0F0001,
+		0xC78, 0xEC100001,
+		0xC78, 0xEB110001,
+		0xC78, 0xEA120001,
+		0xC78, 0xE9130001,
+		0xC78, 0xE8140001,
+		0xC78, 0xE7150001,
+		0xC78, 0xE6160001,
+		0xC78, 0xE5170001,
+		0xC78, 0xE4180001,
+		0xC78, 0xE3190001,
+		0xC78, 0xE21A0001,
+		0xC78, 0xE11B0001,
+		0xC78, 0xE01C0001,
+		0xC78, 0xC21D0001,
+		0xC78, 0xC11E0001,
+		0xC78, 0xC01F0001,
+		0xC78, 0xA5200001,
+		0xC78, 0xA4210001,
+		0xC78, 0xA3220001,
+		0xC78, 0xA2230001,
+		0xC78, 0xA1240001,
+		0xC78, 0xA0250001,
+		0xC78, 0x65260001,
+		0xC78, 0x64270001,
+		0xC78, 0x63280001,
+		0xC78, 0x62290001,
+		0xC78, 0x612A0001,
+		0xC78, 0x442B0001,
+		0xC78, 0x432C0001,
+		0xC78, 0x422D0001,
+		0xC78, 0x412E0001,
+		0xC78, 0x402F0001,
+		0xC78, 0x21300001,
+		0xC78, 0x20310001,
+		0xC78, 0x05320001,
+		0xC78, 0x04330001,
+		0xC78, 0x03340001,
+		0xC78, 0x02350001,
+		0xC78, 0x01360001,
+		0xC78, 0x00370001,
+		0xC78, 0x00380001,
+		0xC78, 0x00390001,
+		0xC78, 0x003A0001,
+		0xC78, 0x003B0001,
+		0xC78, 0x003C0001,
+		0xC78, 0x003D0001,
+		0xC78, 0x003E0001,
+		0xC78, 0x003F0001,
+		0xC50, 0x69553422,
+		0xC50, 0x69553420,
+
+};
+
+void
+odm_read_and_config_mp_8188f_agc_tab(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8188f_agc_tab)/sizeof(u32);
+	u32	*array = array_mp_8188f_agc_tab;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8188f_agc_tab\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_bb_agc_8188f(dm, v1, MASKDWORD, v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8188f_agc_tab(void)
+{
+		return 38;
+}
+
+/******************************************************************************
+*                           phy_reg.TXT
+******************************************************************************/
+
+u32 array_mp_8188f_phy_reg[] = {
+		0x800, 0x80045700,
+		0x804, 0x00000001,
+		0x808, 0x0000FC00,
+		0x80C, 0x0000000A,
+		0x810, 0x10001331,
+		0x814, 0x020C3D10,
+		0x818, 0x00200385,
+		0x81C, 0x00000000,
+		0x820, 0x01000100,
+		0x824, 0x00390204,
+		0x828, 0x00000000,
+		0x82C, 0x00000000,
+		0x830, 0x00000000,
+		0x834, 0x00000000,
+		0x838, 0x00000000,
+		0x83C, 0x00000000,
+		0x840, 0x00010000,
+		0x844, 0x00000000,
+		0x848, 0x00000000,
+		0x84C, 0x00000000,
+		0x850, 0x00030000,
+		0x854, 0x00000000,
+		0x858, 0x569A569A,
+		0x85C, 0x569A569A,
+		0x860, 0x00000130,
+		0x864, 0x00000000,
+		0x868, 0x00000000,
+		0x86C, 0x27272700,
+		0x870, 0x00000000,
+		0x874, 0x25004000,
+		0x878, 0x00000808,
+		0x87C, 0x004F0201,
+		0x880, 0xB0000B1E,
+		0x884, 0x00000007,
+		0x888, 0x00000000,
+		0x88C, 0xCCC000C0,
+		0x890, 0x00000800,
+		0x894, 0xFFFFFFFE,
+		0x898, 0x40302010,
+		0x89C, 0x00706050,
+		0x900, 0x00000000,
+		0x904, 0x00000023,
+		0x908, 0x00000000,
+		0x90C, 0x81121111,
+		0x910, 0x00000002,
+		0x914, 0x00000201,
+		0x948, 0x99000000,
+		0x94C, 0x00000010,
+		0x950, 0x20003000,
+		0x954, 0x4A880000,
+		0x958, 0x4BC5D87A,
+		0x95C, 0x04EB9B79,
+		0x96C, 0x00000003,
+		0xA00, 0x00D046C8,
+		0xA04, 0x80FF800C,
+	0x80000400,	0x00000000,	0x40000000,	0x00000000,
+		0xA08, 0x8C038300,
+	0xA0000000,	0x00000000,
+		0xA08, 0x8C898300,
+	0xB0000000,	0x00000000,
+		0xA0C, 0x2E7F120F,
+		0xA10, 0x9500BB78,
+		0xA14, 0x1114D028,
+		0xA18, 0x00881117,
+		0xA1C, 0x89140F00,
+		0xA20, 0xD1D80000,
+		0xA24, 0x5A7DA0BD,
+		0xA28, 0x0000223B,
+		0xA2C, 0x00D30000,
+		0xA70, 0x101FBF00,
+		0xA74, 0x00000007,
+	0x80000400,	0x00000000,	0x40000000,	0x00000000,
+		0xA78, 0x00008900,
+	0xA0000000,	0x00000000,
+		0xA78, 0x00000900,
+	0xB0000000,	0x00000000,
+		0xA7C, 0x225B0606,
+		0xA80, 0x218075B1,
+		0xA84, 0x00120000,
+		0xA88, 0x040C0000,
+		0xA8C, 0x12345678,
+		0xA90, 0xABCDEF00,
+		0xA94, 0x001B1B89,
+		0xA98, 0x05100000,
+		0xA9C, 0x3F000000,
+		0xAA0, 0x00000000,
+		0xB2C, 0x00000000,
+		0xC00, 0x48071D40,
+		0xC04, 0x03A05611,
+		0xC08, 0x000000E4,
+		0xC0C, 0x6C6C6C6C,
+		0xC10, 0x18800000,
+		0xC14, 0x40000100,
+		0xC18, 0x08800000,
+		0xC1C, 0x40000100,
+		0xC20, 0x00000000,
+		0xC24, 0x00000000,
+		0xC28, 0x00000000,
+		0xC2C, 0x00000000,
+		0xC30, 0x69E9CC4A,
+		0xC34, 0x31000040,
+		0xC38, 0x21688080,
+		0xC3C, 0x00001714,
+		0xC40, 0x1F78403F,
+		0xC44, 0x00010036,
+		0xC48, 0xEC020107,
+		0xC4C, 0x007F037F,
+		0xC50, 0x69553420,
+		0xC54, 0x43BC0094,
+		0xC58, 0x00013169,
+		0xC5C, 0x00250492,
+		0xC60, 0x00000000,
+		0xC64, 0x7112848B,
+		0xC68, 0x47C07BFF,
+		0xC6C, 0x00000036,
+		0xC70, 0x2C7F000D,
+		0xC74, 0x020600DB,
+		0xC78, 0x0000001F,
+		0xC7C, 0x00B91612,
+		0xC80, 0x390000E4,
+	0x80000400,	0x00000000,	0x40000000,	0x00000000,
+		0xC84, 0x21F60000,
+	0xA0000000,	0x00000000,
+		0xC84, 0x11F60000,
+	0xB0000000,	0x00000000,
+		0xC88, 0x40000100,
+		0xC8C, 0x20200000,
+		0xC90, 0x00091521,
+		0xC94, 0x00000000,
+		0xC98, 0x00121820,
+		0xC9C, 0x00007F7F,
+		0xCA0, 0x00000000,
+		0xCA4, 0x000300A0,
+		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, 0x10000000,
+		0xCE8, 0x37644302,
+		0xCEC, 0x2F97D40C,
+		0xD00, 0x04030740,
+		0xD04, 0x40020401,
+		0xD08, 0x0000907F,
+		0xD0C, 0x20010201,
+		0xD10, 0xA0633333,
+		0xD14, 0x3333BC53,
+		0xD18, 0x7A8F5B6F,
+		0xD2C, 0xCB979975,
+		0xD30, 0x00000000,
+		0xD34, 0x40608000,
+		0xD38, 0x98000000,
+		0xD3C, 0x40127353,
+		0xD40, 0x00000000,
+		0xD44, 0x00000000,
+		0xD48, 0x00000000,
+		0xD4C, 0x00000000,
+		0xD50, 0x6437140A,
+		0xD54, 0x00000000,
+		0xD58, 0x00000282,
+		0xD5C, 0x30032064,
+		0xD60, 0x4653DE68,
+		0xD64, 0x04518A3C,
+		0xD68, 0x00002101,
+		0xD6C, 0x2A201C16,
+		0xD70, 0x1812362E,
+		0xD74, 0x322C2220,
+		0xD78, 0x000E3C24,
+		0xE00, 0x2D2D2D2D,
+		0xE04, 0x2D2D2D2D,
+		0xE08, 0x0390272D,
+		0xE10, 0x2D2D2D2D,
+		0xE14, 0x2D2D2D2D,
+		0xE18, 0x2D2D2D2D,
+		0xE1C, 0x2D2D2D2D,
+		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,
+		0xE60, 0x021400A0,
+		0xE64, 0x281600A0,
+		0xE6C, 0x01C00010,
+		0xE70, 0x01C00010,
+		0xE74, 0x02000010,
+		0xE78, 0x02000010,
+		0xE7C, 0x02000010,
+		0xE80, 0x02000010,
+		0xE84, 0x01C00010,
+		0xE88, 0x02000010,
+		0xE8C, 0x01C00010,
+		0xED0, 0x01C00010,
+		0xED4, 0x01C00010,
+		0xED8, 0x01C00010,
+		0xEDC, 0x00000010,
+		0xEE0, 0x00000010,
+		0xEEC, 0x03C00010,
+		0xF14, 0x00000003,
+		0xF4C, 0x00000000,
+		0xF00, 0x00000300,
+
+};
+
+void
+odm_read_and_config_mp_8188f_phy_reg(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8188f_phy_reg)/sizeof(u32);
+	u32	*array = array_mp_8188f_phy_reg;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8188f_phy_reg\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_bb_phy_8188f(dm, v1, MASKDWORD, v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8188f_phy_reg(void)
+{
+		return 38;
+}
+
+/******************************************************************************
+*                           phy_reg_pg.TXT
+******************************************************************************/
+
+u32 array_mp_8188f_phy_reg_pg[] = {
+	0, 0, 0, 0x00000e08, 0x0000ff00, 0x00003200,
+	0, 0, 0, 0x0000086c, 0xffffff00, 0x32323200,
+	0, 0, 0, 0x00000e00, 0xffffffff, 0x34363636,
+	0, 0, 0, 0x00000e04, 0xffffffff, 0x28303234,
+	0, 0, 0, 0x00000e10, 0xffffffff, 0x30343434,
+	0, 0, 0, 0x00000e14, 0xffffffff, 0x26262830
+};
+
+void
+odm_read_and_config_mp_8188f_phy_reg_pg(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+	u32	array_len = sizeof(array_mp_8188f_phy_reg_pg)/sizeof(u32);
+	u32	*array = array_mp_8188f_phy_reg_pg;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len/6;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8188f_phy_reg_pg\n");
+
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+
+	for (i = 0; i < array_len; i += 6) {
+		u32	v1 = array[i];
+		u32	v2 = array[i+1];
+		u32	v3 = array[i+2];
+		u32	v4 = array[i+3];
+		u32	v5 = array[i+4];
+		u32	v6 = array[i+5];
+
+		odm_config_bb_phy_reg_pg_8188f(dm, v1, v2, v3, v4, v5, v6);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+#endif
+	}
+}
+
+
+
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.h
index f1f96679a371..a4a164744193 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_bb.h
@@ -1,59 +1,55 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.26*/
-#if (RTL8188F_SUPPORT == 1)
-#ifndef __INC_MP_BB_HW_IMG_8188F_H
-#define __INC_MP_BB_HW_IMG_8188F_H
-
-
-/******************************************************************************
-*                           AGC_TAB.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_AGC_TAB(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_AGC_TAB(void);
-
-/******************************************************************************
-*                           PHY_REG.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_PHY_REG(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_PHY_REG(void);
-
-/******************************************************************************
-*                           PHY_REG_PG.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_PHY_REG_PG(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_PHY_REG_PG(void);
-
-#endif
-#endif /* end of HWIMG_SUPPORT*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: 3.5.2*/
+#if (RTL8188F_SUPPORT == 1)
+#ifndef __INC_MP_BB_HW_IMG_8188F_H
+#define __INC_MP_BB_HW_IMG_8188F_H
+
+
+/******************************************************************************
+*                           agc_tab.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_agc_tab(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_agc_tab(void);
+
+/******************************************************************************
+*                           phy_reg.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_phy_reg(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_phy_reg(void);
+
+/******************************************************************************
+*                           phy_reg_pg.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_phy_reg_pg(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_phy_reg_pg(void);
+
+#endif
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_fw.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_fw.c
deleted file mode 100644
index d7be9972126a..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_fw.c
+++ /dev/null
@@ -1,7843 +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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.16*/
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (RTL8188F_SUPPORT == 1)
-#if (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))
-
-
-u1Byte Array_MP_8188F_FW_AP[] = {
-0xF1, 0x88, 0x20, 0x00, 0x04, 0x00, 0x00, 0x00,
-0x08, 0x22, 0x17, 0x37, 0xCC, 0x45, 0x02, 0x00,
-0xBC, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x02, 0x87, 0x2E, 0x02, 0xBB, 0x0F, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xA6, 0xA1, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xBB, 0x61, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xBB, 0x10, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xB2, 0x56, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xBB, 0x60, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x02, 0x87, 0xDB, 0x02, 0x89, 0x08, 0x02, 0x80,
-0x86, 0x02, 0x80, 0x89, 0x02, 0x80, 0x8C, 0x02,
-0x8C, 0xCC, 0x02, 0xB1, 0xF5, 0x02, 0x80, 0x95,
-0x02, 0x80, 0x98, 0x02, 0x80, 0x9B, 0x02, 0x80,
-0x9E, 0x02, 0x80, 0xA1, 0x02, 0x80, 0xA4, 0x02,
-0x80, 0xA7, 0x02, 0x80, 0xAA, 0x02, 0x80, 0xAD,
-0x02, 0x80, 0xB0, 0x02, 0x89, 0xEF, 0x02, 0x80,
-0xB6, 0x02, 0x80, 0xB9, 0x02, 0xB8, 0x5C, 0x02,
-0x98, 0x99, 0x02, 0x98, 0x22, 0x02, 0xB8, 0xBE,
-0x02, 0xAF, 0xDF, 0x02, 0xB7, 0xF3, 0x02, 0x80,
-0xCE, 0x02, 0x80, 0xD1, 0x02, 0x80, 0xD4, 0x02,
-0x80, 0xD7, 0x00, 0x00, 0x00, 0x02, 0x80, 0xDD,
-0x02, 0x80, 0xE0, 0x02, 0x80, 0xE3, 0x02, 0x80,
-0xE6, 0x02, 0xC3, 0x23, 0x02, 0x80, 0xEC, 0x02,
-0x80, 0xEF, 0x02, 0x80, 0xF2, 0x02, 0x80, 0xF5,
-0x02, 0x80, 0xF8, 0x02, 0x80, 0xFB, 0x02, 0x80,
-0xFE, 0x02, 0x81, 0x01, 0x02, 0x81, 0x04, 0x02,
-0x81, 0x07, 0x02, 0x81, 0x0A, 0x02, 0x81, 0x0D,
-0x02, 0x81, 0x10, 0x02, 0x81, 0x13, 0x02, 0x81,
-0x16, 0x02, 0x81, 0x19, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x02, 0xA3, 0x76, 0x02,
-0xBB, 0xF0, 0x02, 0x9F, 0x7B, 0x02, 0x9F, 0x6E,
-0x02, 0x81, 0x40, 0x02, 0x8E, 0x28, 0x02, 0xC1,
-0x9B, 0x02, 0x81, 0x49, 0x02, 0x81, 0x4C, 0x02,
-0x81, 0x4F, 0x02, 0x81, 0x52, 0x02, 0x81, 0x55,
-0x02, 0x81, 0x58, 0x02, 0x81, 0x5B, 0x02, 0xC0,
-0xCC, 0x02, 0x81, 0x61, 0x02, 0x81, 0x64, 0x02,
-0xB7, 0x23, 0x02, 0xC2, 0x83, 0x02, 0xC2, 0xBF,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x15, 0xF0, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0x15,
-0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x05, 0xF0,
-0xFF, 0x0F, 0x00, 0x00, 0x00, 0x05, 0xF0, 0x0F,
-0x00, 0x00, 0x00, 0x00, 0x10, 0xF0, 0xFF, 0x0F,
-0x00, 0x00, 0x00, 0x10, 0xF0, 0x0F, 0x00, 0x00,
-0x00, 0x00, 0xF5, 0x0F, 0x00, 0x00, 0x00, 0x00,
-0x00, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x0D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0A,
-0x08, 0x03, 0x03, 0x00, 0x04, 0x09, 0x07, 0x03,
-0x03, 0x00, 0x04, 0x08, 0x06, 0x03, 0x02, 0x00,
-0x04, 0x08, 0x05, 0x03, 0x01, 0x00, 0x04, 0x0D,
-0x0A, 0x07, 0x05, 0x00, 0x08, 0x0C, 0x0A, 0x07,
-0x04, 0x00, 0x08, 0x0B, 0x0A, 0x06, 0x05, 0x00,
-0x08, 0x0B, 0x0A, 0x05, 0x03, 0x00, 0x08, 0x0B,
-0x0A, 0x03, 0x02, 0x00, 0x08, 0x14, 0x12, 0x0C,
-0x04, 0x00, 0x10, 0x14, 0x12, 0x09, 0x04, 0x00,
-0x10, 0x24, 0x22, 0x1C, 0x12, 0x00, 0x20, 0x24,
-0x22, 0x18, 0x0C, 0x00, 0x20, 0x24, 0x22, 0x14,
-0x06, 0x00, 0x20, 0x24, 0x22, 0x0F, 0x04, 0x00,
-0x20, 0x24, 0x21, 0x0A, 0x04, 0x00, 0x20, 0x23,
-0x21, 0x0C, 0x04, 0x00, 0x20, 0x23, 0x1F, 0x0A,
-0x04, 0x00, 0x20, 0x22, 0x1F, 0x0F, 0x04, 0x00,
-0x20, 0x21, 0x1F, 0x16, 0x0C, 0x00, 0x20, 0x31,
-0x2F, 0x20, 0x14, 0x00, 0x30, 0x31, 0x2F, 0x18,
-0x10, 0x00, 0x30, 0x31, 0x2C, 0x18, 0x0C, 0x00,
-0x30, 0x31, 0x2A, 0x14, 0x0C, 0x00, 0x30, 0x31,
-0x28, 0x14, 0x00, 0x00, 0x30, 0x31, 0x24, 0x14,
-0x00, 0x00, 0x30, 0x31, 0x1E, 0x14, 0x00, 0x00,
-0x30, 0x02, 0x02, 0x03, 0x04, 0x04, 0x08, 0x09,
-0x09, 0x0C, 0x0E, 0x10, 0x12, 0x02, 0x09, 0x0B,
-0x0E, 0x0D, 0x0F, 0x10, 0x12, 0x00, 0x04, 0x00,
-0x04, 0x00, 0x08, 0x00, 0x10, 0x00, 0x23, 0x00,
-0x2D, 0x00, 0x50, 0x00, 0x91, 0x00, 0xC3, 0x01,
-0x27, 0x01, 0x31, 0x01, 0x5E, 0x00, 0x8C, 0x00,
-0xC8, 0x00, 0xDC, 0x01, 0x5E, 0x01, 0x68, 0x01,
-0x9A, 0x01, 0xCC, 0x01, 0xEA, 0x02, 0x02, 0x04,
-0x08, 0x0C, 0x12, 0x18, 0x24, 0x30, 0x48, 0x60,
-0x6C, 0x14, 0x28, 0x32, 0x50, 0x78, 0xA0, 0xC8,
-0xE6, 0x01, 0x01, 0x01, 0x02, 0x01, 0x01, 0x02,
-0x02, 0x03, 0x03, 0x04, 0x04, 0x02, 0x04, 0x06,
-0x07, 0x07, 0x08, 0x08, 0x08, 0x01, 0x01, 0x01,
-0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
-0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x02,
-0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
-0x02, 0x03, 0x03, 0x04, 0x05, 0x01, 0x02, 0x03,
-0x04, 0x05, 0x06, 0x07, 0x08, 0x03, 0x03, 0x03,
-0x02, 0x03, 0x03, 0x03, 0x03, 0x03, 0x02, 0x02,
-0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02,
-0x02, 0x19, 0x06, 0x04, 0x02, 0x00, 0x18, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0xC2, 0xAF, 0x80, 0xFE, 0x32, 0x12, 0x84, 0x04,
-0x85, 0xD0, 0x0B, 0x75, 0xD0, 0x08, 0xAA, 0xE0,
-0xC2, 0x8C, 0xE5, 0x8A, 0x24, 0x67, 0xF5, 0x8A,
-0xE5, 0x8C, 0x34, 0x79, 0xF5, 0x8C, 0xD2, 0x8C,
-0xEC, 0x24, 0x87, 0xF8, 0xE6, 0xBC, 0x02, 0x02,
-0x74, 0xFF, 0xC3, 0x95, 0x81, 0xB4, 0x40, 0x00,
-0x40, 0xCE, 0x79, 0x03, 0x78, 0x80, 0x16, 0xE6,
-0x08, 0x70, 0x0B, 0xC2, 0xAF, 0xE6, 0x30, 0xE1,
-0x03, 0x44, 0x18, 0xF6, 0xD2, 0xAF, 0x08, 0xD9,
-0xED, 0xEA, 0x8B, 0xD0, 0x22, 0xE5, 0x0C, 0xFF,
-0x23, 0x24, 0x81, 0xF8, 0x0F, 0x08, 0x08, 0xBF,
-0x03, 0x04, 0x7F, 0x00, 0x78, 0x81, 0xE6, 0x30,
-0xE4, 0xF2, 0x00, 0xE5, 0x0C, 0xC3, 0x9F, 0x50,
-0x20, 0x05, 0x0C, 0x74, 0x86, 0x25, 0x0C, 0xF8,
-0xE6, 0xFD, 0xA6, 0x81, 0x08, 0xE6, 0xAE, 0x0C,
-0xBE, 0x02, 0x02, 0x74, 0xFF, 0xCD, 0xF8, 0xE8,
-0x6D, 0x60, 0xE0, 0x08, 0xE6, 0xC0, 0xE0, 0x80,
-0xF6, 0xE5, 0x0C, 0xD3, 0x9F, 0x40, 0x27, 0xE5,
-0x0C, 0x24, 0x87, 0xF8, 0xE6, 0xAE, 0x0C, 0xBE,
-0x02, 0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xCD,
-0xF8, 0xE5, 0x81, 0x6D, 0x60, 0x06, 0xD0, 0xE0,
-0xF6, 0x18, 0x80, 0xF5, 0xE5, 0x0C, 0x24, 0x86,
-0xC8, 0xF6, 0x15, 0x0C, 0x80, 0xD3, 0xE5, 0x0C,
-0x23, 0x24, 0x81, 0xF8, 0x7F, 0x04, 0xC2, 0xAF,
-0xE6, 0x30, 0xE0, 0x03, 0x10, 0xE2, 0x0C, 0x7F,
-0x00, 0x30, 0xE1, 0x07, 0x30, 0xE3, 0x04, 0x7F,
-0x08, 0x54, 0xF4, 0x54, 0x7C, 0xC6, 0xD2, 0xAF,
-0x54, 0x80, 0x42, 0x07, 0x22, 0x78, 0x86, 0xA6,
-0x81, 0x74, 0x02, 0x60, 0x06, 0xFF, 0x08, 0x76,
-0xFF, 0xDF, 0xFB, 0x7F, 0x03, 0xE4, 0x78, 0x80,
-0xF6, 0x08, 0xF6, 0x08, 0xDF, 0xFA, 0x78, 0x81,
-0x76, 0x30, 0x90, 0x87, 0xD0, 0x74, 0x01, 0x93,
-0xC0, 0xE0, 0xE4, 0x93, 0xC0, 0xE0, 0x43, 0x89,
-0x01, 0x75, 0x8A, 0x60, 0x75, 0x8C, 0x79, 0xD2,
-0x8C, 0xD2, 0xAF, 0x22, 0x02, 0xEF, 0xD3, 0x94,
-0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0x74, 0x81,
-0x2F, 0x2F, 0xF8, 0xE6, 0x20, 0xE5, 0xF4, 0xC2,
-0xAF, 0xE6, 0x44, 0x30, 0xF6, 0xD2, 0xAF, 0xAE,
-0x0C, 0xEE, 0xC3, 0x9F, 0x50, 0x21, 0x0E, 0x74,
-0x86, 0x2E, 0xF8, 0xE6, 0xF9, 0x08, 0xE6, 0x18,
-0xBE, 0x02, 0x02, 0x74, 0xFF, 0xFD, 0xED, 0x69,
-0x60, 0x09, 0x09, 0xE7, 0x19, 0x19, 0xF7, 0x09,
-0x09, 0x80, 0xF3, 0x16, 0x16, 0x80, 0xDA, 0xEE,
-0xD3, 0x9F, 0x40, 0x04, 0x05, 0x81, 0x05, 0x81,
-0xEE, 0xD3, 0x9F, 0x40, 0x22, 0x74, 0x86, 0x2E,
-0xF8, 0x08, 0xE6, 0xF9, 0xEE, 0xB5, 0x0C, 0x02,
-0xA9, 0x81, 0x18, 0x06, 0x06, 0xE6, 0xFD, 0xED,
-0x69, 0x60, 0x09, 0x19, 0x19, 0xE7, 0x09, 0x09,
-0xF7, 0x19, 0x80, 0xF3, 0x1E, 0x80, 0xD9, 0xEF,
-0x24, 0x86, 0xF8, 0xE6, 0x04, 0xF8, 0xEF, 0x2F,
-0x04, 0x90, 0x87, 0xD0, 0x93, 0xF6, 0x08, 0xEF,
-0x2F, 0x93, 0xF6, 0x7F, 0x00, 0x22, 0xEF, 0xD3,
-0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0xEF,
-0x23, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE5, 0xF4,
-0xC2, 0xAF, 0xE6, 0x54, 0x8C, 0xF6, 0xD2, 0xAF,
-0xE5, 0x0C, 0xB5, 0x07, 0x0A, 0x74, 0x86, 0x2F,
-0xF8, 0xE6, 0xF5, 0x81, 0x02, 0x84, 0x4D, 0x50,
-0x2E, 0x74, 0x87, 0x2F, 0xF8, 0xE6, 0xBF, 0x02,
-0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xF9, 0x74,
-0x86, 0x2F, 0xF8, 0xFB, 0xE6, 0xFC, 0xE9, 0x6C,
-0x60, 0x08, 0xA8, 0x05, 0xE7, 0xF6, 0x1D, 0x19,
-0x80, 0xF4, 0xA8, 0x03, 0xA6, 0x05, 0x1F, 0xE5,
-0x0C, 0xB5, 0x07, 0xE3, 0x7F, 0x00, 0x22, 0x74,
-0x87, 0x2F, 0xF8, 0xE6, 0xFD, 0x18, 0x86, 0x01,
-0x0F, 0x74, 0x86, 0x2F, 0xF8, 0xA6, 0x01, 0x08,
-0x86, 0x04, 0xE5, 0x0C, 0xB5, 0x07, 0x02, 0xAC,
-0x81, 0xED, 0x6C, 0x60, 0x08, 0x0D, 0x09, 0xA8,
-0x05, 0xE6, 0xF7, 0x80, 0xF4, 0xE5, 0x0C, 0xB5,
-0x07, 0xDE, 0x89, 0x81, 0x7F, 0x00, 0x22, 0xEF,
-0xD3, 0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22,
-0xEF, 0x23, 0x24, 0x81, 0xF8, 0xC2, 0xAF, 0xE6,
-0x30, 0xE5, 0x05, 0x30, 0xE0, 0x02, 0xD2, 0xE4,
-0xD2, 0xE2, 0xC6, 0xD2, 0xAF, 0x7F, 0x00, 0x30,
-0xE2, 0x01, 0x0F, 0x02, 0x84, 0x4C, 0x8F, 0xF0,
-0xE4, 0xFF, 0xFE, 0xE5, 0x0C, 0x23, 0x24, 0x80,
-0xF8, 0xC2, 0xA9, 0x30, 0xF7, 0x0D, 0x7F, 0x08,
-0xE6, 0x60, 0x0B, 0x2D, 0xF6, 0x60, 0x30, 0x50,
-0x2E, 0x80, 0x07, 0x30, 0xF1, 0x06, 0xED, 0xF6,
-0x60, 0x25, 0x7E, 0x02, 0x08, 0x30, 0xF0, 0x10,
-0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x23, 0x0E, 0x30,
-0xE2, 0x0C, 0xD2, 0xAF, 0x7F, 0x04, 0x80, 0x12,
-0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x13, 0x54, 0xEC,
-0x4E, 0xF6, 0xD2, 0xAF, 0x02, 0x84, 0x4D, 0x7F,
-0x08, 0x08, 0xEF, 0x44, 0x83, 0xF4, 0xC2, 0xAF,
-0x56, 0xC6, 0xD2, 0xAF, 0x54, 0x80, 0x4F, 0xFF,
-0x22, 0xEF, 0x2B, 0xFF, 0xEE, 0x3A, 0xFE, 0xED,
-0x39, 0xFD, 0xEC, 0x38, 0xFC, 0x22, 0xC3, 0xEF,
-0x9B, 0xFF, 0xEE, 0x9A, 0xFE, 0xED, 0x99, 0xFD,
-0xEC, 0x98, 0xFC, 0x22, 0xEF, 0x5B, 0xFF, 0xEE,
-0x5A, 0xFE, 0xED, 0x59, 0xFD, 0xEC, 0x58, 0xFC,
-0x22, 0xEF, 0x4B, 0xFF, 0xEE, 0x4A, 0xFE, 0xED,
-0x49, 0xFD, 0xEC, 0x48, 0xFC, 0x22, 0xE0, 0xFC,
-0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x22, 0xE0, 0xF8, 0xA3, 0xE0, 0xF9, 0xA3,
-0xE0, 0xFA, 0xA3, 0xE0, 0xFB, 0x22, 0xE0, 0xFB,
-0xA3, 0xE0, 0xFA, 0xA3, 0xE0, 0xF9, 0x22, 0xEB,
-0xF0, 0xA3, 0xEA, 0xF0, 0xA3, 0xE9, 0xF0, 0x22,
-0xD0, 0x83, 0xD0, 0x82, 0xF8, 0xE4, 0x93, 0x70,
-0x12, 0x74, 0x01, 0x93, 0x70, 0x0D, 0xA3, 0xA3,
-0x93, 0xF8, 0x74, 0x01, 0x93, 0xF5, 0x82, 0x88,
-0x83, 0xE4, 0x73, 0x74, 0x02, 0x93, 0x68, 0x60,
-0xEF, 0xA3, 0xA3, 0xA3, 0x80, 0xDF, 0x02, 0x87,
-0x6C, 0x02, 0x84, 0xDD, 0xE4, 0x93, 0xA3, 0xF8,
-0xE4, 0x93, 0xA3, 0x40, 0x03, 0xF6, 0x80, 0x01,
-0xF2, 0x08, 0xDF, 0xF4, 0x80, 0x29, 0xE4, 0x93,
-0xA3, 0xF8, 0x54, 0x07, 0x24, 0x0C, 0xC8, 0xC3,
-0x33, 0xC4, 0x54, 0x0F, 0x44, 0x20, 0xC8, 0x83,
-0x40, 0x04, 0xF4, 0x56, 0x80, 0x01, 0x46, 0xF6,
-0xDF, 0xE4, 0x80, 0x0B, 0x01, 0x02, 0x04, 0x08,
-0x10, 0x20, 0x40, 0x80, 0x90, 0x87, 0xB1, 0xE4,
-0x7E, 0x01, 0x93, 0x60, 0xBC, 0xA3, 0xFF, 0x54,
-0x3F, 0x30, 0xE5, 0x09, 0x54, 0x1F, 0xFE, 0xE4,
-0x93, 0xA3, 0x60, 0x01, 0x0E, 0xCF, 0x54, 0xC0,
-0x25, 0xE0, 0x60, 0xA8, 0x40, 0xB8, 0xE4, 0x93,
-0xA3, 0xFA, 0xE4, 0x93, 0xA3, 0xF8, 0xE4, 0x93,
-0xA3, 0xC8, 0xC5, 0x82, 0xC8, 0xCA, 0xC5, 0x83,
-0xCA, 0xF0, 0xA3, 0xC8, 0xC5, 0x82, 0xC8, 0xCA,
-0xC5, 0x83, 0xCA, 0xDF, 0xE9, 0xDE, 0xE7, 0x80,
-0xBE, 0x41, 0x94, 0xD9, 0x00, 0x41, 0x94, 0xDA,
-0x00, 0x41, 0x94, 0xDF, 0x00, 0x44, 0x94, 0xBF,
-0x41, 0x4E, 0x59, 0x00, 0x44, 0x94, 0xBB, 0x61,
-0x6E, 0x79, 0x00, 0x41, 0x94, 0xE1, 0x00, 0x00,
-0xAB, 0x0B, 0xB9, 0x94, 0xBA, 0xAA, 0x12, 0x5E,
-0x10, 0x7F, 0x04, 0x90, 0x94, 0xDD, 0xEF, 0xF0,
-0x7F, 0x02, 0xD1, 0x27, 0x90, 0x84, 0xC1, 0xE0,
-0xFF, 0x90, 0x94, 0xDD, 0xE0, 0xFE, 0xEF, 0x4E,
-0x90, 0x84, 0xC1, 0xF0, 0x22, 0x90, 0x02, 0x09,
-0xE0, 0xF5, 0x5B, 0x12, 0x02, 0xF6, 0x25, 0x5B,
-0x90, 0x84, 0xC6, 0xF0, 0xD1, 0x8C, 0x25, 0x5B,
-0x90, 0x84, 0xC7, 0x91, 0xAD, 0x25, 0x5B, 0x90,
-0x84, 0xC8, 0xF0, 0x90, 0x00, 0x03, 0x12, 0x03,
-0x0F, 0x25, 0x5B, 0x90, 0x84, 0xC9, 0xF0, 0x90,
-0x00, 0x04, 0x12, 0x03, 0x0F, 0x25, 0x5B, 0x90,
-0x84, 0xCA, 0xF0, 0x90, 0x00, 0x05, 0x12, 0x03,
-0x0F, 0x25, 0x5B, 0x90, 0x84, 0xCB, 0x11, 0x3F,
-0x25, 0x5B, 0x90, 0x84, 0xCC, 0xF0, 0x22, 0xF0,
-0x90, 0x00, 0x06, 0x02, 0x03, 0x0F, 0xF1, 0xDA,
-0xFF, 0x54, 0x7F, 0x90, 0x85, 0xC5, 0xF0, 0xEF,
-0x91, 0xB8, 0xA3, 0xF0, 0xD1, 0x8C, 0xFD, 0x54,
-0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x85, 0xC3,
-0xE0, 0x54, 0xF0, 0x4F, 0xF0, 0x90, 0x00, 0x03,
-0x12, 0x03, 0x0F, 0xFC, 0x54, 0x01, 0x25, 0xE0,
-0xFF, 0x90, 0x85, 0xC1, 0xE0, 0x54, 0xFD, 0x4F,
-0xF0, 0xEC, 0x54, 0x04, 0xFF, 0x90, 0x92, 0x3F,
-0xE0, 0x54, 0xFB, 0x4F, 0xF0, 0xED, 0x54, 0x0F,
-0xC4, 0x54, 0xF0, 0xFF, 0xF1, 0xD3, 0x91, 0xAC,
-0x90, 0x85, 0xC4, 0x11, 0x3F, 0x30, 0xE0, 0x4D,
-0xC3, 0x13, 0x54, 0x07, 0xFF, 0xC3, 0x94, 0x04,
-0x90, 0x85, 0xD8, 0x50, 0x04, 0xEF, 0xF0, 0x80,
-0x25, 0x74, 0x03, 0xF0, 0x31, 0xE9, 0xE9, 0x24,
-0x06, 0xF1, 0xCB, 0xFF, 0x74, 0x03, 0x24, 0xFD,
-0xFE, 0xEF, 0xC4, 0x54, 0x0F, 0xFD, 0xEF, 0x54,
-0x0F, 0xFF, 0xED, 0x2E, 0x54, 0x0F, 0xFE, 0xC4,
-0x54, 0xF0, 0x4F, 0x12, 0x03, 0x3C, 0x31, 0xE9,
-0x11, 0x40, 0xC4, 0x54, 0x0F, 0xFF, 0xC3, 0x94,
-0x04, 0x90, 0x85, 0xCD, 0x50, 0x05, 0x74, 0x04,
-0xF0, 0x80, 0x02, 0xEF, 0xF0, 0x31, 0xE9, 0x90,
-0x00, 0x04, 0x12, 0x03, 0x0F, 0xFD, 0x7F, 0x02,
-0x12, 0x57, 0x82, 0x31, 0xE9, 0x12, 0x71, 0xCB,
-0x12, 0xB3, 0x87, 0xF0, 0x90, 0x85, 0xC5, 0xF1,
-0xED, 0xF1, 0xD2, 0x90, 0x01, 0xBE, 0xF0, 0x22,
-0x90, 0x93, 0x36, 0x12, 0x86, 0xFF, 0x90, 0x93,
-0x35, 0xEF, 0xF0, 0x12, 0x87, 0x08, 0x89, 0x62,
-0x00, 0x89, 0x67, 0x01, 0x89, 0x6C, 0x06, 0x89,
-0x7D, 0x08, 0x89, 0x81, 0x09, 0x89, 0x86, 0x0A,
-0x89, 0x8B, 0x12, 0x89, 0x90, 0x13, 0x89, 0x94,
-0x14, 0x89, 0x99, 0x20, 0x89, 0x9D, 0x25, 0x89,
-0xA2, 0x26, 0x89, 0xA7, 0x40, 0x89, 0xAB, 0x42,
-0x89, 0xB0, 0x43, 0x89, 0xB5, 0x44, 0x89, 0xDC,
-0x47, 0x89, 0xBA, 0x49, 0x89, 0xBF, 0xC2, 0x89,
-0xC4, 0xC3, 0x89, 0xC9, 0xC4, 0x89, 0x71, 0xC6,
-0x89, 0x71, 0xC7, 0x89, 0x71, 0xC8, 0x00, 0x00,
-0x89, 0xCD, 0x31, 0xDD, 0x02, 0x87, 0xF5, 0x31,
-0xDD, 0x02, 0x90, 0x0A, 0x31, 0xDD, 0x02, 0xA0,
-0xC2, 0x90, 0x93, 0x35, 0xE0, 0xFF, 0xA3, 0x12,
-0x86, 0xF6, 0x02, 0xA1, 0x59, 0x31, 0xDD, 0xE1,
-0x07, 0x31, 0xDD, 0x02, 0x97, 0xF8, 0x31, 0xDD,
-0x02, 0x98, 0x0A, 0x31, 0xDD, 0x02, 0x9F, 0xF8,
-0x31, 0xDD, 0xC1, 0x92, 0x31, 0xDD, 0x02, 0xA2,
-0x8A, 0x31, 0xDD, 0x01, 0x46, 0x31, 0xDD, 0x02,
-0xA2, 0x99, 0x31, 0xDD, 0x02, 0xA2, 0xA1, 0x31,
-0xDD, 0x80, 0x44, 0x31, 0xDD, 0x02, 0x4E, 0x29,
-0x31, 0xDD, 0x02, 0x28, 0xE6, 0x31, 0xDD, 0x02,
-0x62, 0xFC, 0x31, 0xDD, 0x02, 0xBC, 0x2A, 0x31,
-0xDD, 0x02, 0xA7, 0xFD, 0x31, 0xDD, 0x02, 0xA8,
-0x05, 0x31, 0xDD, 0xE1, 0xB8, 0x90, 0x01, 0xC0,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x93, 0x35, 0xE0,
-0x90, 0x01, 0xC2, 0xF0, 0x22, 0x90, 0x93, 0x36,
-0x02, 0x86, 0xF6, 0x90, 0x93, 0x39, 0x12, 0x86,
-0xFF, 0x90, 0x93, 0x39, 0x02, 0x86, 0xF6, 0x31,
-0xE3, 0x12, 0x02, 0xF6, 0x54, 0x7F, 0xFD, 0xD1,
-0x8C, 0xFE, 0x54, 0x1F, 0x90, 0x93, 0x3D, 0x91,
-0xB4, 0x90, 0x93, 0x3C, 0x91, 0xAD, 0xFE, 0x54,
-0x03, 0xFC, 0xEE, 0x54, 0x30, 0xC4, 0x54, 0x0F,
-0x90, 0x93, 0x3F, 0x91, 0xAD, 0xFE, 0x54, 0x40,
-0xC4, 0x13, 0x13, 0x54, 0x03, 0x90, 0x93, 0x3E,
-0x91, 0xB4, 0xFF, 0x91, 0xAE, 0xFB, 0x54, 0x08,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x90, 0x93, 0x41,
-0xF0, 0xFA, 0xEB, 0x54, 0x04, 0x13, 0x13, 0x54,
-0x3F, 0xA3, 0xF0, 0xEF, 0x54, 0x01, 0xC4, 0x33,
-0x33, 0x33, 0x54, 0x80, 0x71, 0x41, 0x54, 0x7F,
-0x4F, 0xF0, 0x90, 0x93, 0x3E, 0xE0, 0x54, 0x01,
-0xC4, 0x33, 0x33, 0x54, 0xC0, 0x71, 0x41, 0x54,
-0xBF, 0x4F, 0xF0, 0xEA, 0x60, 0x02, 0x61, 0x40,
-0x90, 0x93, 0x3D, 0xE0, 0x54, 0x1F, 0x91, 0xBF,
-0x54, 0xE0, 0x4F, 0xF0, 0xEC, 0x54, 0x03, 0x71,
-0x41, 0x54, 0xFC, 0x4F, 0xF0, 0xEC, 0x54, 0x03,
-0x25, 0xE0, 0x25, 0xE0, 0x71, 0x41, 0x54, 0xF3,
-0x4F, 0xF0, 0x90, 0x93, 0x3C, 0xE0, 0x54, 0x01,
-0xC4, 0x33, 0x54, 0xE0, 0x91, 0xBF, 0x54, 0xDF,
-0x4F, 0xF0, 0x90, 0x93, 0x3F, 0xE0, 0x54, 0x03,
-0xC4, 0x54, 0xF0, 0x71, 0x41, 0x54, 0xCF, 0x4F,
-0xF1, 0xE3, 0xF5, 0x83, 0xE0, 0x54, 0xFB, 0xF1,
-0xE3, 0xF5, 0x83, 0xC0, 0x83, 0xC0, 0x82, 0xE0,
-0xFF, 0x90, 0x93, 0x42, 0xE0, 0x12, 0xAF, 0x4A,
-0xD0, 0x82, 0xD0, 0x83, 0xF0, 0x90, 0x92, 0x39,
-0xE0, 0x60, 0x35, 0x31, 0xE9, 0xE9, 0x24, 0x03,
-0xF1, 0xCB, 0x54, 0x1F, 0x12, 0x03, 0x3C, 0x90,
-0x93, 0x40, 0x74, 0x01, 0xF0, 0x90, 0x93, 0x40,
-0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50, 0x19, 0xEF,
-0x24, 0x03, 0xFF, 0xE4, 0x33, 0xFE, 0x31, 0xE9,
-0x8F, 0x82, 0x8E, 0x83, 0xE4, 0x12, 0x03, 0x4E,
-0x90, 0x93, 0x40, 0xE0, 0x04, 0xF0, 0x80, 0xDD,
-0x90, 0x92, 0x37, 0xE0, 0x54, 0x07, 0xFF, 0xBF,
-0x05, 0x0A, 0xEC, 0xB4, 0x01, 0x06, 0x90, 0x92,
-0x3C, 0x74, 0x01, 0xF0, 0xE4, 0x90, 0x93, 0x40,
-0xF0, 0x90, 0x93, 0x40, 0xE0, 0xFC, 0x24, 0x03,
-0xFF, 0xE4, 0x33, 0xFE, 0x31, 0xE9, 0x8F, 0x82,
-0x8E, 0x83, 0x12, 0x03, 0x0F, 0xFF, 0xED, 0xF1,
-0xFC, 0xE5, 0x82, 0x2C, 0x12, 0xB0, 0xF2, 0xEF,
-0xF0, 0x90, 0x93, 0x40, 0xE0, 0x04, 0xF0, 0xE0,
-0xB4, 0x04, 0xD6, 0xAF, 0x05, 0x12, 0x17, 0x8E,
-0x22, 0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90, 0x89,
-0x3F, 0x12, 0x05, 0x28, 0xE0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xF1, 0xB1, 0x20,
-0xE6, 0x02, 0x81, 0x73, 0x90, 0x00, 0x8C, 0xE0,
-0x90, 0x94, 0xD0, 0xF0, 0x7F, 0x8D, 0x12, 0x7B,
-0x51, 0x90, 0x94, 0xD1, 0xEF, 0xF0, 0x90, 0x00,
-0x8E, 0xE0, 0x90, 0x94, 0xD2, 0xF0, 0x90, 0x94,
-0xD1, 0xE0, 0x24, 0xFC, 0x60, 0x10, 0x24, 0x03,
-0x60, 0x02, 0x81, 0x6B, 0x90, 0x94, 0xD0, 0xE0,
-0xFF, 0x12, 0xB1, 0x0C, 0x81, 0x6B, 0x90, 0x94,
-0xD0, 0xE0, 0x24, 0xDC, 0xF5, 0x82, 0xE4, 0x34,
-0x8F, 0xF5, 0x83, 0xE0, 0xFB, 0xE4, 0xFD, 0xFF,
-0x91, 0xA5, 0x75, 0xF0, 0x12, 0x71, 0x46, 0x13,
-0x13, 0x54, 0x03, 0xFB, 0x0D, 0xE4, 0xFF, 0x91,
-0xA5, 0x75, 0xF0, 0x12, 0x71, 0x46, 0x91, 0xB8,
-0xFB, 0x0D, 0xE4, 0xFF, 0x91, 0xA5, 0x75, 0xF0,
-0x12, 0x71, 0x46, 0xC4, 0x54, 0x03, 0xFB, 0x0D,
-0xE4, 0xFF, 0x91, 0xA5, 0x75, 0xF0, 0x12, 0x12,
-0x97, 0xCE, 0xFB, 0xE4, 0xFD, 0x0F, 0x91, 0xA5,
-0x75, 0xF0, 0x12, 0x90, 0x89, 0x3D, 0x12, 0x05,
-0x28, 0x91, 0xA2, 0x75, 0xF0, 0x12, 0x91, 0xC4,
-0xC4, 0x13, 0x54, 0x01, 0xFB, 0x0D, 0x7F, 0x01,
-0x91, 0xA5, 0x75, 0xF0, 0x12, 0x91, 0xC4, 0x54,
-0x1F, 0x91, 0xA3, 0xF1, 0xFC, 0xE0, 0xFB, 0xE4,
-0xFD, 0x0F, 0x91, 0xA5, 0x75, 0xF0, 0x08, 0xA4,
-0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0x91,
-0xA0, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x02, 0xF5,
-0x82, 0xE4, 0x34, 0x82, 0x91, 0xA0, 0x75, 0xF0,
-0x08, 0xA4, 0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34,
-0x82, 0x91, 0xA0, 0x75, 0xF0, 0x08, 0xA4, 0x24,
-0x04, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83,
-0xE0, 0xFB, 0xE4, 0xFD, 0x0F, 0x91, 0xA5, 0x75,
-0xF0, 0x08, 0xA4, 0x24, 0x05, 0xF5, 0x82, 0xE4,
-0x34, 0x82, 0x91, 0xA0, 0x75, 0xF0, 0x08, 0xA4,
-0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0x91,
-0xA0, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x07, 0xF5,
-0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0xE0, 0xFB,
-0x0D, 0x91, 0x78, 0xF1, 0xB1, 0x30, 0xE0, 0x03,
-0x12, 0xB1, 0xE3, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xEF, 0x70, 0x04, 0x74, 0xF0, 0x80, 0x16, 0xEF,
-0xB4, 0x01, 0x04, 0x74, 0xF4, 0x80, 0x0E, 0xEF,
-0xB4, 0x02, 0x04, 0x74, 0xF8, 0x80, 0x06, 0xEF,
-0xB4, 0x03, 0x0C, 0x74, 0xFC, 0x2D, 0xF5, 0x82,
-0xE4, 0x34, 0x02, 0xF5, 0x83, 0xEB, 0xF0, 0x22,
-0xF5, 0x83, 0xE0, 0xFB, 0x0D, 0x91, 0x78, 0x90,
-0x94, 0xD0, 0xE0, 0x22, 0x4F, 0xF0, 0x90, 0x00,
-0x02, 0x02, 0x03, 0x0F, 0xF0, 0xEE, 0x54, 0x80,
-0xC4, 0x13, 0x13, 0x13, 0x54, 0x01, 0x22, 0xFF,
-0x75, 0xF0, 0x12, 0xED, 0x90, 0x89, 0x3E, 0x12,
-0x05, 0x28, 0xE0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xE0, 0xED, 0xF0,
-0x90, 0x85, 0xC1, 0xE0, 0xFE, 0xC4, 0x13, 0x13,
-0x54, 0x03, 0x30, 0xE0, 0x02, 0xC1, 0x23, 0xEE,
-0x91, 0xB8, 0x30, 0xE0, 0x02, 0xC1, 0x23, 0x90,
-0x85, 0xC8, 0xE0, 0xFE, 0x6F, 0x70, 0x02, 0xC1,
-0x23, 0xEF, 0x70, 0x02, 0xA1, 0x91, 0x24, 0xFE,
-0x70, 0x02, 0xA1, 0xCE, 0x24, 0xFE, 0x60, 0x4D,
-0x24, 0xFC, 0x70, 0x02, 0xC1, 0x0D, 0x24, 0xFC,
-0x60, 0x02, 0xC1, 0x1D, 0xEE, 0xB4, 0x0E, 0x03,
-0x12, 0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0, 0x70,
-0x05, 0x7F, 0x01, 0x12, 0x79, 0x80, 0x90, 0x85,
-0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x73, 0x8E,
-0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x04, 0x0F, 0x90,
-0x94, 0xE0, 0xE0, 0xFF, 0x60, 0x05, 0x12, 0x6D,
-0x4C, 0x80, 0x03, 0x12, 0x79, 0x61, 0x90, 0x85,
-0xC8, 0xE0, 0x64, 0x08, 0x60, 0x02, 0xC1, 0x1D,
-0x12, 0x7A, 0xB9, 0xC1, 0x1D, 0x90, 0x85, 0xC8,
-0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79, 0x80,
-0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12,
-0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E,
-0x08, 0xD1, 0x28, 0xBF, 0x01, 0x03, 0x12, 0x74,
-0x93, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x0C, 0x60,
-0x02, 0xC1, 0x1D, 0xD1, 0x28, 0xEF, 0x64, 0x01,
-0x60, 0x02, 0xC1, 0x1D, 0x12, 0x70, 0x9E, 0xC1,
-0x1D, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E, 0x08,
-0xD1, 0x28, 0xBF, 0x01, 0x03, 0x12, 0x74, 0x93,
-0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12,
-0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0C,
-0x08, 0xD1, 0x28, 0xBF, 0x01, 0x03, 0x12, 0x70,
-0x9E, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x04, 0x70,
-0x5C, 0x12, 0xC1, 0x9B, 0xEF, 0x64, 0x01, 0x70,
-0x54, 0x12, 0x77, 0xFE, 0x80, 0x4F, 0x90, 0x85,
-0xC8, 0xE0, 0xB4, 0x0E, 0x08, 0xD1, 0x28, 0xBF,
-0x01, 0x03, 0x12, 0x74, 0x93, 0x90, 0x85, 0xC8,
-0xE0, 0xB4, 0x06, 0x03, 0x12, 0x73, 0x8E, 0x90,
-0x85, 0xC8, 0xE0, 0xB4, 0x0C, 0x08, 0xD1, 0x28,
-0xBF, 0x01, 0x03, 0x12, 0x70, 0x9E, 0x90, 0x85,
-0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79,
-0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x04, 0x15,
-0x12, 0x79, 0xF3, 0x80, 0x10, 0x90, 0x85, 0xC8,
-0xE0, 0xB4, 0x0C, 0x09, 0x12, 0xB7, 0x0F, 0x30,
-0xE0, 0x03, 0x12, 0x7A, 0x8A, 0x90, 0x85, 0xC8,
-0xF1, 0xED, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12,
-0x7A, 0x29, 0xEF, 0x64, 0x01, 0x60, 0x05, 0x75,
-0x0E, 0x01, 0x80, 0x3A, 0x90, 0x85, 0xC1, 0xE0,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x05,
-0x75, 0x0E, 0x02, 0x80, 0x29, 0x90, 0x85, 0xC7,
-0xE0, 0xD3, 0x94, 0x04, 0x40, 0x05, 0x75, 0x0E,
-0x08, 0x80, 0x1B, 0x90, 0x92, 0x29, 0xE0, 0x30,
-0xE0, 0x0B, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x05,
-0x75, 0x0E, 0x11, 0x80, 0x09, 0x90, 0x01, 0xB8,
-0xE4, 0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90, 0x01,
-0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8, 0xE5,
-0x0E, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x12, 0x86, 0xF6, 0x90, 0x00, 0x01, 0x02,
-0x03, 0x0F, 0x12, 0x02, 0xF6, 0xFF, 0x54, 0x80,
-0xFE, 0x90, 0x89, 0x16, 0xE0, 0x54, 0x7F, 0x4E,
-0xFE, 0xF0, 0xEF, 0x54, 0x40, 0xFF, 0xEE, 0x54,
-0xBF, 0x12, 0xC5, 0xC2, 0x54, 0x20, 0xFD, 0xEF,
-0x54, 0xDF, 0x4D, 0xFF, 0x90, 0x89, 0x16, 0xF0,
-0xEE, 0x54, 0x10, 0xFE, 0xEF, 0x54, 0xEF, 0x4E,
-0xFF, 0xF0, 0x12, 0x02, 0xF6, 0x54, 0x0F, 0xFE,
-0xEF, 0x54, 0xF0, 0x4E, 0x90, 0x89, 0x16, 0xF0,
-0xD1, 0x8C, 0xFF, 0x54, 0x7F, 0x90, 0x89, 0x18,
-0xF0, 0xEF, 0x91, 0xB6, 0xFF, 0x90, 0x89, 0x17,
-0xE0, 0x54, 0xFE, 0x91, 0xAC, 0x90, 0x89, 0x19,
-0xF0, 0x90, 0x00, 0x03, 0x12, 0x03, 0x0F, 0x54,
-0x01, 0x25, 0xE0, 0xFF, 0x90, 0x89, 0x17, 0xE0,
-0x54, 0xFD, 0x4F, 0xF0, 0x12, 0xC5, 0x55, 0x20,
-0xE0, 0x02, 0x7D, 0x01, 0x02, 0x54, 0x9F, 0xF1,
-0xDA, 0x30, 0xE0, 0x14, 0x12, 0xC0, 0x82, 0x90,
-0x84, 0xC5, 0xE0, 0x64, 0x01, 0x70, 0x28, 0x90,
-0xFE, 0x10, 0xE0, 0x44, 0x04, 0xF0, 0x80, 0x1F,
-0x90, 0x92, 0x25, 0xE0, 0x60, 0x16, 0x7D, 0x10,
-0xE4, 0xFF, 0x12, 0x7B, 0xBF, 0x90, 0x01, 0x3C,
-0xE0, 0x30, 0xE4, 0x03, 0x74, 0x10, 0xF0, 0x90,
-0x01, 0x63, 0xE4, 0xF0, 0x12, 0xC0, 0xB6, 0x31,
-0xE9, 0xD1, 0x8C, 0x90, 0x92, 0x04, 0x91, 0xAD,
-0x90, 0x92, 0x05, 0xF0, 0x90, 0x92, 0x04, 0xE0,
-0x54, 0x01, 0x90, 0x92, 0x11, 0xF0, 0x90, 0x92,
-0x04, 0xE0, 0x54, 0x02, 0x90, 0x92, 0x12, 0xF0,
-0x90, 0x92, 0x04, 0xE0, 0x54, 0x04, 0x90, 0x92,
-0x13, 0xF0, 0x90, 0x92, 0x04, 0xE0, 0x54, 0x08,
-0x90, 0x92, 0x14, 0xF0, 0x90, 0x92, 0x04, 0xE0,
-0x54, 0x10, 0x90, 0x92, 0x15, 0xF0, 0x90, 0x92,
-0x05, 0xE0, 0x54, 0x01, 0x90, 0x92, 0x16, 0xF0,
-0x90, 0x92, 0x05, 0xE0, 0x54, 0x02, 0x90, 0x92,
-0x17, 0xF0, 0x90, 0x92, 0x05, 0xE0, 0x54, 0x04,
-0x90, 0x92, 0x18, 0xF0, 0x90, 0x92, 0x05, 0xE0,
-0x54, 0x08, 0x90, 0x92, 0x19, 0xF0, 0x90, 0x92,
-0x05, 0xE0, 0x54, 0x10, 0x90, 0x92, 0x1A, 0xF0,
-0x22, 0x7F, 0x8F, 0x12, 0x7B, 0x51, 0xEF, 0x22,
-0x12, 0x02, 0xF6, 0x90, 0x92, 0x25, 0xF0, 0xD1,
-0x8C, 0x90, 0x92, 0x26, 0x91, 0xAD, 0x90, 0x92,
-0x27, 0xF0, 0x22, 0xF9, 0xE4, 0x3A, 0xFA, 0x02,
-0x02, 0xF6, 0xF0, 0x90, 0x85, 0xC3, 0xE0, 0x54,
-0x0F, 0x22, 0x90, 0x93, 0x39, 0x12, 0x86, 0xFF,
-0x02, 0x02, 0xF6, 0xF0, 0x74, 0xCC, 0x2D, 0xF5,
-0x82, 0xE4, 0x34, 0x8F, 0x22, 0xE0, 0x90, 0x01,
-0xBA, 0xF0, 0x90, 0x85, 0xC7, 0xE0, 0x90, 0x01,
-0xBB, 0x22, 0x61, 0x4E, 0x75, 0xF0, 0x08, 0xA4,
-0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5,
-0x83, 0x22, 0x8B, 0x5B, 0x8A, 0x5C, 0x89, 0x5D,
-0x90, 0x92, 0x33, 0xE0, 0x70, 0x10, 0x12, 0x02,
-0xF6, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x06,
-0x90, 0x92, 0x39, 0x74, 0x01, 0xF0, 0x90, 0x92,
-0x35, 0xE0, 0x70, 0x0F, 0x11, 0xE0, 0xC4, 0x54,
-0x0F, 0xFF, 0xBF, 0x05, 0x06, 0x90, 0x92, 0x3A,
-0x74, 0x01, 0xF0, 0xAB, 0x5B, 0xAA, 0x5C, 0xA9,
-0x5D, 0x12, 0x8E, 0x8C, 0xFF, 0xF5, 0x5F, 0x12,
-0x02, 0xF6, 0xFE, 0xC3, 0x13, 0x30, 0xE0, 0x07,
-0x12, 0x8C, 0xAE, 0xF5, 0x60, 0x80, 0x02, 0x8F,
-0x60, 0x85, 0x5F, 0x5E, 0xE5, 0x5E, 0xD3, 0x95,
-0x60, 0x50, 0x28, 0x11, 0xE0, 0x54, 0x01, 0xFD,
-0xAF, 0x5E, 0x12, 0x6E, 0x5F, 0xAF, 0x5E, 0x12,
-0x77, 0x39, 0xEF, 0xAF, 0x5E, 0x70, 0x04, 0x11,
-0xA6, 0x80, 0x02, 0xF1, 0xC3, 0x90, 0x92, 0x3A,
-0xE0, 0x60, 0x04, 0xAF, 0x5E, 0x11, 0xA6, 0x05,
-0x5E, 0x80, 0xD1, 0xE5, 0x5F, 0x70, 0x16, 0xFF,
-0x12, 0x77, 0x39, 0xEF, 0x70, 0x0F, 0x12, 0xA3,
-0x76, 0x12, 0x79, 0x61, 0x12, 0xB6, 0xFE, 0x54,
-0xBF, 0xF0, 0x54, 0x7F, 0xF0, 0x22, 0x7D, 0x01,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x93, 0x39, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0x7D,
-0x44, 0x7F, 0x6F, 0x12, 0x9F, 0x79, 0x90, 0x93,
-0x3A, 0xE0, 0x90, 0x93, 0x39, 0xB4, 0x01, 0x09,
-0xE0, 0x11, 0xED, 0xE0, 0x44, 0x04, 0xF0, 0x80,
-0x07, 0xE0, 0x11, 0xED, 0xE0, 0x54, 0xFB, 0xF0,
-0x12, 0xBB, 0xEA, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xAB, 0x5B, 0xAA, 0x5C, 0xA9, 0x5D, 0x02, 0x02,
-0xF6, 0xE0, 0xFD, 0xE5, 0x75, 0xC4, 0x54, 0xF0,
-0x24, 0x05, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
-0x83, 0x22, 0x8D, 0x75, 0xEF, 0x30, 0xE6, 0x1A,
-0x31, 0x77, 0x11, 0xE9, 0xE0, 0x54, 0x03, 0x90,
-0x91, 0x0B, 0xF0, 0xE4, 0xFB, 0xAF, 0x75, 0x12,
-0x27, 0x3D, 0x31, 0x6A, 0xB1, 0xC7, 0x74, 0x01,
-0x80, 0x47, 0xD1, 0xED, 0x04, 0xF0, 0xD1, 0xED,
-0x64, 0x02, 0x70, 0x1D, 0x74, 0x76, 0x25, 0x75,
-0xD1, 0xE5, 0xE0, 0xFD, 0xF4, 0x60, 0x02, 0x80,
-0x04, 0x31, 0x77, 0xE0, 0xFD, 0x11, 0xEB, 0xF1,
-0x94, 0x31, 0x77, 0xB1, 0xC7, 0x74, 0x02, 0x80,
-0x20, 0xD1, 0xED, 0xD3, 0x94, 0x03, 0x40, 0x0D,
-0xAF, 0x75, 0x12, 0x6D, 0x94, 0x31, 0x6A, 0xB1,
-0xC7, 0x74, 0x03, 0x80, 0x0C, 0x31, 0x77, 0x11,
-0xE9, 0xF1, 0x94, 0x31, 0x77, 0xB1, 0xC7, 0x74,
-0x02, 0xF0, 0xAB, 0x75, 0xE4, 0xFD, 0xFF, 0x02,
-0x52, 0xC3, 0x74, 0xBC, 0x25, 0x75, 0xF5, 0x82,
-0xE4, 0x34, 0x90, 0xF5, 0x83, 0xE4, 0xF0, 0xE5,
-0x75, 0xC4, 0x54, 0xF0, 0x24, 0x00, 0xF5, 0x82,
-0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x90, 0x04,
-0x85, 0xE0, 0xF5, 0x6A, 0x90, 0x94, 0x75, 0xE0,
-0x04, 0xF0, 0xE4, 0xF5, 0x62, 0x90, 0x85, 0xBB,
-0xE0, 0xFF, 0xE5, 0x62, 0xC3, 0x9F, 0x40, 0x02,
-0xA1, 0xC6, 0xE5, 0x62, 0x31, 0x79, 0xE0, 0xF5,
-0x6C, 0x12, 0xC5, 0xA7, 0xF5, 0x83, 0xE0, 0x65,
-0x6C, 0x60, 0x18, 0x90, 0x8A, 0x71, 0xE5, 0x6C,
-0xF0, 0xE4, 0xA3, 0xF0, 0xAB, 0x62, 0xFD, 0xFF,
-0x12, 0x52, 0xC3, 0x12, 0xC5, 0xA7, 0xF5, 0x83,
-0xE5, 0x6C, 0xF0, 0x90, 0x04, 0xA0, 0xE0, 0x64,
-0x01, 0x70, 0x4C, 0xA3, 0xE0, 0x65, 0x62, 0x70,
-0x46, 0xA3, 0xE0, 0xF5, 0x63, 0xA3, 0xE0, 0x90,
-0x93, 0xC1, 0xF0, 0xE5, 0x62, 0x31, 0x79, 0xE0,
-0x65, 0x63, 0x70, 0x02, 0xA1, 0xC2, 0xE5, 0x62,
-0x31, 0x79, 0xE5, 0x63, 0xF0, 0xE5, 0x62, 0x11,
-0xED, 0xE0, 0x54, 0xFC, 0xFF, 0x90, 0x93, 0xC1,
-0xE0, 0x54, 0x03, 0x4F, 0xFF, 0xE5, 0x62, 0x11,
-0xED, 0xEF, 0xF0, 0x90, 0x8A, 0x71, 0xE5, 0x63,
-0xF0, 0xA3, 0x74, 0xFF, 0xF0, 0xAB, 0x62, 0xE4,
-0xFD, 0xFF, 0x12, 0x52, 0xC3, 0xA1, 0xC2, 0xAF,
-0x62, 0x12, 0x77, 0x39, 0xEF, 0x70, 0x02, 0xA1,
-0xC2, 0x75, 0xF0, 0x12, 0xE5, 0x62, 0x12, 0x8B,
-0x46, 0x12, 0x8C, 0xB8, 0x30, 0xE0, 0x02, 0xA1,
-0xC2, 0xE5, 0x62, 0x13, 0x13, 0x13, 0x54, 0x1F,
-0x24, 0x75, 0x12, 0xC5, 0x9D, 0x7C, 0x00, 0xE5,
-0x62, 0x12, 0xB1, 0xEA, 0x80, 0x05, 0xC3, 0x33,
-0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEE, 0x5C,
-0xFE, 0xEF, 0x5D, 0x4E, 0x60, 0x02, 0xA1, 0xC2,
-0xF1, 0x71, 0xE0, 0xFE, 0xA3, 0xE0, 0x4E, 0x70,
-0x07, 0xF1, 0x66, 0xE0, 0x70, 0x02, 0xA1, 0xC2,
-0xE5, 0x62, 0x75, 0xF0, 0x12, 0xA4, 0x24, 0x44,
-0xF9, 0x74, 0x89, 0x35, 0xF0, 0xFA, 0x7B, 0x01,
-0x90, 0x93, 0xB6, 0x12, 0x86, 0xFF, 0xF1, 0xDE,
-0x12, 0x03, 0xED, 0x2F, 0xFF, 0xD1, 0xCF, 0x2F,
-0xFF, 0x90, 0x00, 0x06, 0x12, 0x04, 0x18, 0x2F,
-0xFF, 0xF1, 0x8E, 0x2F, 0xF5, 0x6B, 0xF1, 0x71,
-0xE0, 0xF5, 0x67, 0xA3, 0xE0, 0xF5, 0x68, 0xF1,
-0x66, 0xE0, 0xFF, 0x90, 0x93, 0xB9, 0xE4, 0xF0,
-0xA3, 0xEF, 0xF0, 0xE5, 0x62, 0x31, 0x79, 0xE0,
-0xF5, 0x63, 0x54, 0x80, 0xFF, 0xE5, 0x63, 0x54,
-0x7F, 0xF5, 0x64, 0x75, 0xF0, 0x12, 0xE5, 0x62,
-0xF1, 0xCE, 0xFE, 0xE5, 0x64, 0xD3, 0x9E, 0x40,
-0x07, 0x8E, 0x64, 0xE5, 0x64, 0x4F, 0xF5, 0x63,
-0x74, 0x7C, 0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34,
-0x90, 0xF5, 0x83, 0xE0, 0xC3, 0x94, 0x05, 0x40,
-0x02, 0x81, 0x51, 0xE5, 0x64, 0x90, 0x82, 0xE1,
-0x93, 0xF5, 0x69, 0xEF, 0x60, 0x04, 0x05, 0x69,
-0x05, 0x69, 0xE5, 0x64, 0xC3, 0x94, 0x0C, 0x40,
-0x21, 0x74, 0x65, 0x25, 0x62, 0xF5, 0x82, 0xE4,
-0x34, 0x94, 0xF5, 0x83, 0xE0, 0xFF, 0x54, 0x7F,
-0xFE, 0xEF, 0x30, 0xE7, 0x06, 0xE5, 0x69, 0x2E,
-0xFF, 0x80, 0x05, 0xC3, 0xE5, 0x69, 0x9E, 0xFF,
-0x8F, 0x69, 0xE5, 0x69, 0xD3, 0x94, 0x1A, 0xAF,
-0x69, 0x40, 0x02, 0x7F, 0x1A, 0x8F, 0x69, 0xE5,
-0x63, 0x90, 0x83, 0x59, 0x93, 0xFF, 0xD3, 0x90,
-0x93, 0xBA, 0xE0, 0x9F, 0x90, 0x93, 0xB9, 0xE0,
-0x94, 0x00, 0x40, 0x02, 0x81, 0x17, 0xC3, 0xE5,
-0x68, 0x94, 0x0A, 0xE5, 0x67, 0x94, 0x00, 0x40,
-0x02, 0x61, 0xD3, 0xB1, 0xCE, 0xE0, 0xC3, 0x94,
-0x01, 0x40, 0x05, 0xB1, 0xCE, 0xE0, 0x14, 0xF0,
-0xF1, 0x88, 0xFF, 0x90, 0x93, 0xBA, 0xE0, 0x2F,
-0xFF, 0x90, 0x93, 0xB9, 0xE0, 0xD1, 0xFA, 0xD1,
-0xCE, 0x2F, 0xFD, 0xEE, 0x35, 0xF0, 0xFC, 0xE5,
-0x67, 0xC3, 0x13, 0xFE, 0xE5, 0x68, 0x13, 0xFF,
-0xD3, 0xED, 0x9F, 0xEC, 0x9E, 0x40, 0x0D, 0xE5,
-0x62, 0x94, 0x05, 0x50, 0x05, 0xB1, 0xCE, 0x74,
-0x03, 0xF0, 0x81, 0x17, 0x90, 0x93, 0xB6, 0x12,
-0x86, 0xF6, 0x12, 0x03, 0xED, 0x65, 0x6B, 0x70,
-0x02, 0xE5, 0xF0, 0x70, 0x2A, 0xE5, 0x62, 0xC3,
-0x94, 0x05, 0x50, 0x0A, 0xB1, 0xCE, 0xE0, 0xD3,
-0x94, 0x00, 0x40, 0x02, 0x80, 0x07, 0xE5, 0x6B,
-0xC3, 0x94, 0x03, 0x50, 0x08, 0x7D, 0x06, 0xAF,
-0x62, 0xF1, 0x0D, 0xA1, 0xC2, 0xE4, 0xFD, 0xAF,
-0x62, 0xD1, 0x0D, 0xF1, 0x09, 0x81, 0x51, 0xF1,
-0xC7, 0x80, 0x7E, 0xB1, 0xCE, 0xE4, 0xF0, 0x90,
-0x93, 0xC6, 0x74, 0x02, 0xF0, 0xAB, 0x69, 0xAD,
-0x62, 0xAF, 0x68, 0xAE, 0x67, 0x12, 0xBC, 0xB8,
-0x8E, 0x65, 0x8F, 0x66, 0x12, 0xC5, 0x66, 0xC3,
-0x74, 0x01, 0x93, 0x95, 0x66, 0xE4, 0x93, 0x95,
-0x65, 0x50, 0x0C, 0xB1, 0xDA, 0xE4, 0xF0, 0x7D,
-0x01, 0xAF, 0x62, 0xD1, 0x0D, 0x80, 0x4A, 0xF1,
-0xE6, 0xC3, 0xE5, 0x66, 0x9F, 0xE5, 0x65, 0x94,
-0x00, 0x50, 0x0D, 0xB1, 0xDA, 0xE4, 0xF0, 0x7D,
-0x01, 0xAF, 0x62, 0x12, 0xBD, 0xA6, 0x80, 0x31,
-0xF1, 0x09, 0xB1, 0xDA, 0xE0, 0x04, 0xF0, 0xE5,
-0x64, 0x90, 0x83, 0x6D, 0x93, 0xFF, 0xB1, 0xDA,
-0xE0, 0xC3, 0x9F, 0x40, 0x1C, 0xB1, 0xDA, 0xE4,
-0xF0, 0xF1, 0xE6, 0x12, 0xC5, 0x66, 0x74, 0x01,
-0x93, 0x2F, 0xFF, 0xE4, 0x93, 0x34, 0x00, 0xC3,
-0x13, 0xFE, 0xEF, 0x13, 0xFF, 0xE5, 0x62, 0xB1,
-0xFC, 0x75, 0xF0, 0x12, 0xE5, 0x62, 0x90, 0x89,
-0x43, 0x12, 0x05, 0x28, 0xE0, 0x64, 0x01, 0x60,
-0x02, 0xA1, 0xC0, 0x90, 0x93, 0xB6, 0x12, 0x86,
-0xF6, 0xF1, 0xDE, 0xAE, 0xF0, 0x12, 0x03, 0xED,
-0x2F, 0xFF, 0xE5, 0xF0, 0x3E, 0xD1, 0xCE, 0x2F,
-0xFF, 0xEE, 0xD1, 0xFA, 0xFE, 0x90, 0x00, 0x08,
-0xF1, 0x00, 0x90, 0x93, 0xBB, 0xF0, 0xA3, 0xEF,
-0xF0, 0x12, 0x03, 0xED, 0xFF, 0xC3, 0x90, 0x93,
-0xBC, 0xE0, 0x9F, 0xFE, 0x90, 0x93, 0xBB, 0xE0,
-0x95, 0xF0, 0x90, 0x93, 0xBD, 0xF0, 0xA3, 0xCE,
-0xF0, 0x90, 0x00, 0x06, 0x12, 0x04, 0x18, 0xFD,
-0xAC, 0xF0, 0x25, 0xE0, 0xFF, 0xEC, 0x33, 0xFE,
-0xEF, 0x2D, 0xFD, 0xEE, 0x3C, 0xFC, 0xD1, 0xCF,
-0x25, 0xE0, 0xFF, 0xE5, 0xF0, 0x33, 0xFE, 0x90,
-0x00, 0x02, 0xF1, 0x00, 0xCF, 0x2D, 0xFD, 0xEF,
-0x3C, 0xFC, 0xF1, 0x88, 0xAE, 0xF0, 0x78, 0x02,
-0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x2D,
-0xFF, 0xEC, 0x3E, 0x90, 0x93, 0xBF, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x93, 0xB9, 0xF1, 0xB0, 0x24,
-0x0C, 0xF5, 0x82, 0xE4, 0x34, 0x90, 0xD1, 0xD5,
-0x50, 0x07, 0x90, 0x93, 0xB9, 0xF1, 0x7C, 0x80,
-0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x62, 0x25,
-0xE0, 0x24, 0x0C, 0xF5, 0x82, 0xE4, 0x34, 0x90,
-0xD1, 0x05, 0x90, 0x93, 0xBB, 0xF1, 0xB0, 0x24,
-0x2C, 0xF5, 0x82, 0xE4, 0x34, 0x90, 0xD1, 0xD5,
-0x50, 0x07, 0x90, 0x93, 0xBB, 0xF1, 0x7C, 0x80,
-0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x62, 0x25,
-0xE0, 0x24, 0x2C, 0xF5, 0x82, 0xE4, 0x34, 0x90,
-0xD1, 0x05, 0x90, 0x93, 0xBF, 0xF1, 0xB0, 0x24,
-0x5C, 0xF5, 0x82, 0xE4, 0x34, 0x90, 0xD1, 0xD5,
-0x50, 0x07, 0x90, 0x93, 0xBF, 0xF1, 0x7C, 0x80,
-0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x62, 0x25,
-0xE0, 0x24, 0x5C, 0xF5, 0x82, 0xE4, 0x34, 0x90,
-0xD1, 0x05, 0xC3, 0x74, 0xFF, 0x95, 0x68, 0xFF,
-0x74, 0xFF, 0x95, 0x67, 0xFE, 0xF1, 0xEE, 0x34,
-0x90, 0xD1, 0xD5, 0x50, 0x0A, 0xE5, 0x68, 0x2D,
-0xFF, 0xE5, 0x67, 0x3C, 0xFE, 0x80, 0x04, 0x7E,
-0xFF, 0x7F, 0xFF, 0xF1, 0xEE, 0x34, 0x90, 0xD1,
-0x05, 0xF1, 0xD6, 0xFB, 0xC3, 0x74, 0xFF, 0x9B,
-0xFF, 0x74, 0xFF, 0x9E, 0xFE, 0x74, 0xFF, 0x94,
-0x00, 0xFD, 0x74, 0xFF, 0x94, 0x00, 0xFC, 0x90,
-0x8F, 0x77, 0x12, 0x86, 0xEA, 0xD3, 0x12, 0x04,
-0xB4, 0x50, 0x11, 0xF1, 0xD6, 0xFF, 0xE4, 0xFC,
-0xFD, 0x90, 0x8F, 0x77, 0x12, 0x86, 0xEA, 0x12,
-0x86, 0xA9, 0x80, 0x06, 0x74, 0xFF, 0xFF, 0xFE,
-0xFD, 0xFC, 0x90, 0x8F, 0x77, 0x12, 0x04, 0xEB,
-0xF1, 0xC7, 0x05, 0x62, 0x21, 0x95, 0x22, 0xE0,
-0x90, 0x8A, 0x71, 0xF0, 0xA3, 0x22, 0x74, 0x86,
-0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0x22, 0x74, 0xAC, 0x25, 0x62, 0xF5, 0x82,
-0xE4, 0x34, 0x8F, 0xF5, 0x83, 0x22, 0xE5, 0x6F,
-0x25, 0xE0, 0x24, 0xF5, 0xF5, 0x82, 0xE4, 0x34,
-0x82, 0xF5, 0x83, 0xE4, 0x93, 0xFE, 0x74, 0x01,
-0x93, 0xFF, 0xE5, 0x6D, 0x25, 0xE0, 0x24, 0x7B,
-0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x8F, 0x6D, 0x8D,
-0x6E, 0xEF, 0x31, 0x79, 0xE0, 0xFD, 0x54, 0x7F,
-0xF5, 0x6F, 0xED, 0x54, 0x80, 0xF5, 0x70, 0x75,
-0xF0, 0x12, 0xEF, 0xF1, 0xCE, 0xF5, 0x72, 0x75,
-0xF0, 0x12, 0xEF, 0x12, 0x8B, 0x46, 0xC4, 0x54,
-0x03, 0xF5, 0x73, 0xD1, 0xE1, 0x74, 0xFF, 0xF0,
-0xB1, 0xE6, 0xE5, 0x70, 0x4D, 0xFF, 0x12, 0xBE,
-0x5B, 0xEF, 0xF0, 0xE5, 0x6D, 0x11, 0xED, 0xE0,
-0x54, 0x03, 0xF5, 0x71, 0x74, 0x4C, 0x25, 0x6D,
-0x12, 0xBE, 0x67, 0xE5, 0x71, 0xF0, 0xE5, 0x6F,
-0x65, 0x72, 0x70, 0x22, 0x75, 0xF0, 0x12, 0xE5,
-0x6D, 0x12, 0x8C, 0xC4, 0xC4, 0x13, 0x54, 0x07,
-0x30, 0xE0, 0x0B, 0xE5, 0x70, 0x70, 0x07, 0xE5,
-0x6F, 0x44, 0x80, 0xFD, 0x80, 0x4B, 0xB1, 0xE6,
-0x7D, 0x07, 0xAF, 0x6D, 0xE1, 0x0D, 0xE5, 0x6F,
-0xC3, 0x95, 0x72, 0x50, 0x35, 0xAB, 0x6D, 0xAD,
-0x72, 0xAF, 0x6F, 0x12, 0x72, 0xEA, 0xAD, 0x07,
-0xE5, 0x6F, 0xC3, 0x94, 0x0C, 0x40, 0x2A, 0x75,
-0xF0, 0x12, 0xE5, 0x6D, 0x12, 0x8C, 0xC4, 0xFE,
-0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x1A, 0xE5,
-0x6E, 0x60, 0x16, 0xE5, 0x70, 0x70, 0x12, 0xE5,
-0x6F, 0x44, 0x80, 0xFD, 0xD1, 0xE1, 0xEF, 0xF0,
-0x80, 0x07, 0x12, 0xBE, 0x5B, 0xE5, 0x72, 0xF0,
-0xFD, 0x90, 0x91, 0x0B, 0xE5, 0x71, 0xF0, 0xAB,
-0x6E, 0xAF, 0x6D, 0x02, 0x27, 0x3D, 0xFE, 0x90,
-0x00, 0x04, 0x02, 0x04, 0x18, 0xF5, 0x83, 0xE0,
-0xFC, 0xA3, 0xE0, 0xFD, 0xD3, 0x9F, 0xEC, 0x9E,
-0x22, 0x74, 0x76, 0x25, 0x6D, 0xF5, 0x82, 0xE4,
-0x34, 0x94, 0xF5, 0x83, 0x22, 0x74, 0xBC, 0x25,
-0x75, 0xF5, 0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83,
-0xE0, 0x22, 0x35, 0xF0, 0xFE, 0x90, 0x00, 0x06,
-0x12, 0x04, 0x18, 0x2F, 0xFF, 0xEE, 0x35, 0xF0,
-0x22, 0x7D, 0x07, 0xAF, 0x62, 0xED, 0x30, 0xE0,
-0x22, 0x75, 0xF0, 0x12, 0xEF, 0x90, 0x89, 0x44,
-0xF1, 0x5A, 0x90, 0x89, 0x46, 0xF1, 0x5A, 0x90,
-0x89, 0x48, 0xF1, 0x5A, 0x90, 0x89, 0x4A, 0xF1,
-0x5A, 0x90, 0x89, 0x4C, 0x12, 0x05, 0x28, 0xE4,
-0xF0, 0xA3, 0xF0, 0xED, 0x30, 0xE1, 0x0A, 0x75,
-0xF0, 0x12, 0xEF, 0xF1, 0x76, 0xE4, 0xF0, 0xA3,
-0xF0, 0xED, 0x30, 0xE2, 0x08, 0x75, 0xF0, 0x12,
-0xEF, 0xF1, 0x6B, 0xE4, 0xF0, 0xF1, 0xA2, 0xE0,
-0x54, 0xBF, 0x44, 0x80, 0xFE, 0xF1, 0xA2, 0xEE,
-0xF0, 0x22, 0x12, 0x05, 0x28, 0xE4, 0xF0, 0xA3,
-0xF0, 0x75, 0xF0, 0x12, 0xEF, 0x22, 0x75, 0xF0,
-0x12, 0xE5, 0x62, 0x90, 0x89, 0x42, 0x02, 0x05,
-0x28, 0x75, 0xF0, 0x12, 0xE5, 0x62, 0x90, 0x89,
-0x40, 0x02, 0x05, 0x28, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0xED, 0x2F, 0xFF, 0xEC, 0x3E, 0xFE, 0x22,
-0x90, 0x93, 0xB6, 0x12, 0x86, 0xF6, 0x90, 0x00,
-0x08, 0x02, 0x04, 0x18, 0xE0, 0x54, 0x03, 0x90,
-0x91, 0x0B, 0xF0, 0x7B, 0x01, 0xAF, 0x75, 0x02,
-0x27, 0x3D, 0xEF, 0xC4, 0x54, 0xF0, 0x24, 0x03,
-0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22,
-0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xC3, 0x74, 0xFF,
-0x9F, 0xFF, 0x74, 0xFF, 0x9E, 0xFE, 0xE5, 0x62,
-0x25, 0xE0, 0x22, 0xE4, 0xFD, 0x01, 0xA8, 0x7D,
-0x01, 0xAF, 0x62, 0x02, 0x65, 0xC2, 0x90, 0x89,
-0x3C, 0x12, 0x05, 0x28, 0xE0, 0x22, 0x90, 0x93,
-0xBD, 0xE0, 0xFE, 0xA3, 0xE0, 0x22, 0x90, 0x00,
-0x02, 0x12, 0x04, 0x18, 0xFF, 0x22, 0xE5, 0x64,
-0x90, 0x83, 0x1D, 0x93, 0xFF, 0x22, 0xE5, 0x62,
-0x25, 0xE0, 0x24, 0x8C, 0xF5, 0x82, 0xE4, 0x22,
-0x12, 0x89, 0xE3, 0x12, 0x98, 0x1B, 0x75, 0x1E,
-0x05, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x1B, 0x02,
-0x6A, 0x21, 0x12, 0x89, 0xE3, 0x11, 0x1B, 0x75,
-0x1E, 0x05, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x20,
-0x02, 0x6A, 0x21, 0x8B, 0x1B, 0x8A, 0x1C, 0x89,
-0x1D, 0x22, 0x90, 0x93, 0x69, 0xEF, 0xF0, 0xA3,
-0x12, 0x86, 0xFF, 0x90, 0x94, 0xDA, 0xE0, 0xFE,
-0x04, 0xF0, 0x90, 0x00, 0x01, 0xEE, 0x12, 0x03,
-0x4E, 0x74, 0x00, 0x2F, 0xF9, 0xE4, 0x34, 0xFB,
-0xFA, 0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02, 0xC0,
-0x01, 0x90, 0x93, 0x6A, 0x12, 0x86, 0xF6, 0x11,
-0x1B, 0x75, 0x1E, 0x02, 0xD0, 0x01, 0xD0, 0x02,
-0xD0, 0x03, 0x12, 0x6A, 0x21, 0x90, 0x93, 0x69,
-0xE0, 0x24, 0x02, 0xF9, 0xE4, 0x34, 0xFB, 0xFA,
-0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01,
-0xA3, 0x12, 0x86, 0xF6, 0xE9, 0x24, 0x02, 0xF9,
-0xE4, 0x3A, 0x8B, 0x1B, 0xF5, 0x1C, 0x89, 0x1D,
-0x90, 0x93, 0x6A, 0x11, 0x90, 0xF5, 0x1E, 0xD0,
-0x01, 0xD0, 0x02, 0xD0, 0x03, 0x02, 0x6A, 0x21,
-0x12, 0x86, 0xF6, 0x90, 0x00, 0x0E, 0x02, 0x03,
-0x0F, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x93, 0x6D, 0x12, 0x86, 0xFF, 0x7F, 0x96,
-0x7E, 0x02, 0x12, 0x66, 0x80, 0xEF, 0x60, 0x45,
-0x11, 0xFA, 0xFE, 0xEF, 0x24, 0x01, 0xFF, 0xE4,
-0x3E, 0xFE, 0x90, 0x93, 0x70, 0xEF, 0xF0, 0xEE,
-0xFF, 0x90, 0xFD, 0x11, 0xF0, 0x90, 0x93, 0x70,
-0xE0, 0xFD, 0x90, 0x02, 0x94, 0xF0, 0xA3, 0xEF,
-0xF0, 0x90, 0x93, 0x6D, 0x11, 0x90, 0x24, 0x02,
-0xFF, 0xE4, 0x33, 0xFE, 0x12, 0x5A, 0xA5, 0x90,
-0x93, 0x70, 0xE0, 0x24, 0x18, 0xFF, 0x90, 0x93,
-0x6D, 0x12, 0x86, 0xF6, 0x12, 0x56, 0xF4, 0x90,
-0x02, 0x96, 0x74, 0x01, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x90, 0x01, 0x17, 0xE0, 0xFE, 0x90,
-0x01, 0x16, 0xE0, 0x7C, 0x00, 0x24, 0x00, 0xFF,
-0xEC, 0x3E, 0x22, 0x90, 0x92, 0x20, 0xE0, 0x90,
-0x94, 0x19, 0xF0, 0x90, 0x92, 0x21, 0xE0, 0x90,
-0x94, 0x1A, 0xF0, 0x90, 0x92, 0x22, 0xE0, 0x90,
-0x94, 0x1B, 0xF0, 0x90, 0x92, 0x23, 0xE0, 0x90,
-0x94, 0x1C, 0xF0, 0x90, 0x92, 0x24, 0xE0, 0x90,
-0x94, 0x1D, 0xF0, 0x90, 0x92, 0x11, 0xE0, 0x90,
-0x94, 0x1E, 0xF0, 0x90, 0x92, 0x12, 0xE0, 0x90,
-0x94, 0x1F, 0xF0, 0x90, 0x92, 0x13, 0xE0, 0x90,
-0x94, 0x20, 0xF0, 0x90, 0x92, 0x14, 0xE0, 0x90,
-0x94, 0x21, 0xF0, 0x90, 0x92, 0x15, 0xE0, 0x90,
-0x94, 0x22, 0xF0, 0x90, 0x92, 0x16, 0xE0, 0x90,
-0x94, 0x23, 0xF0, 0x90, 0x92, 0x17, 0xE0, 0x90,
-0x94, 0x24, 0xF0, 0x90, 0x92, 0x18, 0xE0, 0x90,
-0x94, 0x25, 0xF0, 0x90, 0x92, 0x19, 0xE0, 0x90,
-0x94, 0x26, 0xF0, 0x90, 0x92, 0x1A, 0xE0, 0x90,
-0x94, 0x27, 0xF0, 0xD1, 0x21, 0x90, 0x93, 0xC1,
-0xF0, 0xB1, 0xA5, 0x50, 0x04, 0xB1, 0xBF, 0x80,
-0xF8, 0x90, 0x01, 0x1F, 0xE0, 0xFE, 0x90, 0x01,
-0x1E, 0x31, 0x02, 0x90, 0x93, 0xB6, 0xF0, 0xA3,
-0xF1, 0xDF, 0xB1, 0xA5, 0x50, 0x4C, 0xB1, 0xE1,
-0x90, 0x93, 0xC1, 0xE0, 0xFE, 0x24, 0x28, 0xF5,
-0x82, 0xE4, 0x34, 0x94, 0xD1, 0x02, 0xE0, 0x24,
-0x4D, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0xFF, 0x74, 0xC3, 0x2E, 0xF5, 0x82, 0xE4,
-0x34, 0x93, 0xD1, 0x02, 0xE0, 0x24, 0x4E, 0xF9,
-0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0xEE, 0x12,
-0xC5, 0x82, 0x12, 0x86, 0xFF, 0xD1, 0x06, 0xE0,
-0x24, 0x38, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0xEE,
-0x12, 0xC5, 0x74, 0x12, 0x86, 0xFF, 0xB1, 0xCC,
-0x80, 0xB0, 0x90, 0x02, 0x87, 0xE0, 0x70, 0x02,
-0xA1, 0xA4, 0x90, 0x92, 0x03, 0xE0, 0x20, 0xE0,
-0x02, 0xA1, 0xA4, 0xE4, 0x90, 0x94, 0x32, 0xD1,
-0x29, 0x90, 0x93, 0xB6, 0xE0, 0xFF, 0xA3, 0xE0,
-0xA3, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93,
-0xB8, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xEC, 0x90,
-0xFD, 0x11, 0xF0, 0x12, 0xB9, 0x04, 0xE0, 0xFE,
-0x12, 0xB8, 0xF9, 0xE0, 0x7A, 0x00, 0x24, 0x00,
-0xFF, 0xEA, 0x3E, 0x54, 0x3F, 0x90, 0x93, 0xBA,
-0xF0, 0xA3, 0x12, 0xB9, 0x0F, 0x54, 0x0F, 0x33,
-0x33, 0x33, 0x54, 0xF8, 0x90, 0x93, 0xBD, 0xF0,
-0xFC, 0x74, 0x07, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
-0xFB, 0xF5, 0x83, 0xE0, 0x54, 0xC0, 0x90, 0x93,
-0xBF, 0xF0, 0xEC, 0x24, 0x18, 0x90, 0x93, 0xBC,
-0xF0, 0xFD, 0x90, 0x93, 0xB8, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0x12, 0x55, 0x36, 0xEF, 0x54, 0xFC,
-0x90, 0x93, 0xBE, 0xF0, 0x90, 0x93, 0xBD, 0xE0,
-0x24, 0x18, 0xFF, 0xE4, 0x33, 0x90, 0x93, 0xBA,
-0x8F, 0xF0, 0x12, 0x07, 0x0A, 0x90, 0x93, 0xBA,
-0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x12, 0x7A, 0xD0,
-0x90, 0x93, 0xB6, 0xEE, 0x8F, 0xF0, 0x12, 0x07,
-0x0A, 0x90, 0x85, 0xB7, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x90, 0x93, 0xB6, 0x12, 0x96, 0xD7, 0x40,
-0x1B, 0x90, 0x85, 0xB8, 0xE0, 0x24, 0x01, 0xFF,
-0x90, 0x85, 0xB7, 0xE0, 0x34, 0x00, 0xFE, 0xC3,
-0xED, 0x9F, 0xFF, 0xEC, 0x9E, 0x90, 0x93, 0xB6,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93, 0xBE, 0xE0,
-0x24, 0xC0, 0x60, 0x02, 0x81, 0xA8, 0xB1, 0xB2,
-0x24, 0x18, 0xFD, 0x12, 0x55, 0x36, 0xEF, 0x60,
-0x02, 0x81, 0x9B, 0xB1, 0xB2, 0x24, 0x19, 0xFD,
-0x12, 0x55, 0x36, 0x90, 0x93, 0xD7, 0xF1, 0xE7,
-0x90, 0x93, 0xD7, 0xE0, 0xFF, 0xB1, 0xF0, 0x9F,
-0x50, 0x15, 0xB1, 0xB2, 0x24, 0x1A, 0xF1, 0xD8,
-0x90, 0x93, 0xC0, 0xE0, 0x24, 0xD8, 0xF5, 0x82,
-0xE4, 0x34, 0x93, 0xB1, 0xF7, 0x80, 0xE1, 0x90,
-0x93, 0xD7, 0xE0, 0x70, 0x02, 0x61, 0xD0, 0xE4,
-0x90, 0x93, 0xC1, 0xF0, 0xB1, 0xA5, 0x40, 0x02,
-0x61, 0xB8, 0xB1, 0xE1, 0x90, 0x93, 0xC1, 0xE0,
-0xFF, 0x24, 0xC3, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xE0, 0xFE, 0x90, 0x93, 0xD7, 0xE0,
-0xFD, 0xEE, 0x6D, 0x70, 0x1E, 0xEF, 0x12, 0xC5,
-0x82, 0x12, 0x86, 0xF6, 0xC0, 0x03, 0xC0, 0x02,
-0xC0, 0x01, 0xD1, 0x11, 0xED, 0xF0, 0xD0, 0x01,
-0xD0, 0x02, 0xD0, 0x03, 0xD1, 0x33, 0xEF, 0x60,
-0x02, 0x80, 0x48, 0x90, 0x93, 0xD7, 0xE0, 0x64,
-0x03, 0x70, 0x4F, 0xD1, 0x11, 0x74, 0x03, 0xF0,
-0x7A, 0x94, 0x79, 0xBF, 0xD1, 0x33, 0xEF, 0x70,
-0x0E, 0xD1, 0x11, 0x74, 0x03, 0xF0, 0x7A, 0x94,
-0x79, 0xBB, 0xD1, 0x33, 0xEF, 0x60, 0x2B, 0x90,
-0x93, 0xC1, 0xE0, 0xFF, 0x24, 0x23, 0xF5, 0x82,
-0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0x60, 0x02,
-0x80, 0x0C, 0x90, 0x93, 0xC1, 0xE0, 0xFF, 0x24,
-0x1E, 0x12, 0xC5, 0xB1, 0x60, 0x05, 0x74, 0x32,
-0x2F, 0x80, 0x15, 0xB1, 0xD3, 0x74, 0x01, 0xF0,
-0x80, 0x12, 0x90, 0x93, 0xC1, 0xE0, 0x24, 0x32,
-0x80, 0x06, 0x90, 0x93, 0xC1, 0xE0, 0x24, 0x32,
-0xB1, 0xD9, 0xE4, 0xF0, 0xB1, 0xCC, 0x61, 0x14,
-0x90, 0x94, 0x32, 0xE0, 0x70, 0x50, 0xA3, 0xE0,
-0x70, 0x4C, 0xA3, 0xE0, 0x70, 0x48, 0xA3, 0xE0,
-0x70, 0x44, 0xA3, 0xE0, 0x70, 0x40, 0x81, 0x9B,
-0xE4, 0x90, 0x93, 0xC1, 0xF0, 0xB1, 0xA5, 0x50,
-0x1D, 0x74, 0x1E, 0x2E, 0x12, 0xC5, 0xB1, 0x60,
-0x09, 0x74, 0x32, 0x2E, 0xB1, 0xD9, 0xE4, 0xF0,
-0x80, 0x08, 0x74, 0x32, 0x2E, 0xB1, 0xD9, 0x74,
-0x01, 0xF0, 0xB1, 0xCC, 0x80, 0xDF, 0x90, 0x94,
-0x32, 0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E,
-0xA3, 0xE0, 0x70, 0x0A, 0xA3, 0xE0, 0x70, 0x06,
-0xA3, 0xE0, 0x70, 0x02, 0x81, 0x9B, 0xE4, 0x90,
-0x93, 0xC1, 0xF0, 0xB1, 0xA5, 0x40, 0x02, 0x81,
-0x9B, 0xB1, 0xE1, 0xB1, 0xD3, 0xE0, 0x60, 0x77,
-0x90, 0x92, 0x29, 0xE0, 0x30, 0xE0, 0x06, 0xC4,
-0x54, 0x0F, 0x30, 0xE0, 0x6A, 0xE4, 0xFF, 0xFE,
-0x90, 0x04, 0x1D, 0xE0, 0x60, 0x10, 0xD3, 0xEF,
-0x94, 0xE8, 0xEE, 0x94, 0x03, 0x50, 0x07, 0x0F,
-0xBF, 0x00, 0x01, 0x0E, 0x80, 0xEA, 0x90, 0x04,
-0x1D, 0xE0, 0x70, 0x4B, 0x90, 0x93, 0xC1, 0xE0,
-0x24, 0x19, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0xE0, 0xFF, 0x90, 0x94, 0xCC, 0x74, 0x06,
-0xF0, 0x7B, 0x08, 0x7D, 0x01, 0xD1, 0x67, 0x90,
-0x93, 0xBA, 0xEE, 0xF0, 0xA3, 0xF1, 0xE7, 0xB1,
-0xF0, 0x94, 0x06, 0x50, 0x1C, 0xB1, 0xB2, 0x24,
-0x0A, 0xF1, 0xD8, 0x90, 0x93, 0xBA, 0xA3, 0xE0,
-0xFE, 0x90, 0x93, 0xC0, 0xE0, 0x2E, 0x24, 0x2C,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xB1, 0xF7, 0x80,
-0xDE, 0xF1, 0xD1, 0x90, 0x06, 0x35, 0xF0, 0xB1,
-0xCC, 0x81, 0x13, 0xF1, 0xEF, 0x12, 0x7C, 0x0B,
-0x90, 0x06, 0x36, 0x74, 0xDD, 0xF0, 0x21, 0xF2,
-0x90, 0x93, 0xBF, 0xE0, 0x60, 0x02, 0xA1, 0x9D,
-0xB1, 0xB2, 0x24, 0x16, 0xFD, 0x12, 0x55, 0x36,
-0x90, 0x06, 0x34, 0xEF, 0xF0, 0xB1, 0xB2, 0x24,
-0x17, 0xFD, 0x12, 0x55, 0x36, 0x90, 0x06, 0x37,
-0xF1, 0xDF, 0xB1, 0xA5, 0x50, 0x42, 0xB1, 0xE1,
-0xE4, 0x90, 0x93, 0xC0, 0xF0, 0xB1, 0xF0, 0x94,
-0x06, 0x50, 0x31, 0xB1, 0xB2, 0x24, 0x04, 0x2D,
-0xFD, 0x12, 0x55, 0x36, 0x90, 0x93, 0xC1, 0xE0,
-0xFE, 0x12, 0xC5, 0x74, 0x12, 0x86, 0xF6, 0x90,
-0x93, 0xC0, 0xE0, 0xF5, 0x82, 0xD1, 0x61, 0x6F,
-0x60, 0x0E, 0x74, 0x2D, 0x2E, 0xF5, 0x82, 0xE4,
-0x34, 0x94, 0xF5, 0x83, 0xE4, 0xF0, 0x80, 0x04,
-0xB1, 0xFB, 0x80, 0xC9, 0xB1, 0xCC, 0x80, 0xBA,
-0x90, 0x94, 0x2D, 0xE0, 0x64, 0x01, 0x60, 0x17,
-0xA3, 0xE0, 0x64, 0x01, 0x60, 0x11, 0xA3, 0xE0,
-0x64, 0x01, 0x60, 0x0B, 0xA3, 0xE0, 0x64, 0x01,
-0x60, 0x05, 0xA3, 0xE0, 0xB4, 0x01, 0x06, 0x90,
-0x93, 0xC2, 0x74, 0x01, 0xF0, 0x90, 0x93, 0xC2,
-0xE0, 0x64, 0x01, 0x70, 0x52, 0x12, 0xC0, 0xB6,
-0x12, 0xB7, 0x06, 0x12, 0x5F, 0xE9, 0x90, 0x92,
-0x25, 0xE0, 0x70, 0x02, 0x21, 0xF2, 0x90, 0x01,
-0x3C, 0xE0, 0x30, 0xE4, 0x03, 0x74, 0x10, 0xF0,
-0x7D, 0x10, 0xE4, 0xFF, 0x12, 0x7B, 0xFD, 0x90,
-0x92, 0x26, 0xE0, 0x60, 0x07, 0xF5, 0x25, 0xE4,
-0xF5, 0x26, 0x80, 0x17, 0x90, 0x92, 0x27, 0xE0,
-0x60, 0x08, 0xFB, 0xE4, 0xF5, 0x25, 0xF5, 0x26,
-0x80, 0x0A, 0x75, 0x25, 0x20, 0xE4, 0xF5, 0x26,
-0xFB, 0x80, 0x01, 0xFB, 0x7D, 0x01, 0x7F, 0x60,
-0x7E, 0x01, 0x12, 0x76, 0x3D, 0x21, 0xF2, 0xD1,
-0x21, 0x90, 0x93, 0xC1, 0xF0, 0xB1, 0xA5, 0x50,
-0x04, 0xB1, 0xBF, 0x80, 0xF8, 0xF1, 0xEF, 0x12,
-0x7C, 0x0B, 0x21, 0xF2, 0x22, 0x90, 0x92, 0x0E,
-0xE0, 0xFF, 0x90, 0x93, 0xC1, 0xE0, 0xFE, 0xC3,
-0x9F, 0x22, 0x90, 0x93, 0xB8, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0x90, 0x93, 0xBC, 0xE0, 0x22, 0x74,
-0x2D, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0x74, 0x01, 0xF0, 0x90, 0x93, 0xC1, 0xE0,
-0x04, 0xF0, 0x22, 0x90, 0x93, 0xC1, 0xE0, 0x24,
-0x32, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0x22, 0x74, 0x19, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0x94, 0xF5, 0x83, 0xE0, 0xFF, 0x02, 0x7B, 0x2A,
-0x90, 0x93, 0xC0, 0xE0, 0xFD, 0xC3, 0x22, 0xF5,
-0x83, 0xEF, 0xF0, 0x90, 0x93, 0xC0, 0xE0, 0x04,
-0xF0, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x74, 0x28,
-0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0x22, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xD8, 0x90,
-0x94, 0x3A, 0x12, 0x86, 0xFF, 0x90, 0x94, 0x3D,
-0x22, 0xE4, 0x90, 0x93, 0xC2, 0xF0, 0x90, 0x94,
-0x2D, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
-0xA3, 0xF0, 0x22, 0x90, 0x94, 0x37, 0x12, 0x86,
-0xFF, 0xE4, 0xFF, 0x90, 0x94, 0x3D, 0xE0, 0xFE,
-0xEF, 0xC3, 0x9E, 0x50, 0x14, 0x90, 0x94, 0x3A,
-0xD1, 0x5C, 0xFE, 0x90, 0x94, 0x37, 0xD1, 0x5C,
-0x6E, 0x60, 0x03, 0x7F, 0x00, 0x22, 0x0F, 0x80,
-0xE2, 0x7F, 0x01, 0x22, 0x12, 0x86, 0xF6, 0x8F,
-0x82, 0x75, 0x83, 0x00, 0x02, 0x03, 0x0F, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94,
-0xCA, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x94,
-0xC9, 0xEF, 0xF0, 0xE4, 0xFD, 0xFC, 0x12, 0x7B,
-0x2A, 0x7C, 0x00, 0xAD, 0x07, 0x90, 0x94, 0xC9,
-0xE0, 0x90, 0x04, 0x25, 0xF0, 0x90, 0x94, 0xCA,
-0xE0, 0x60, 0x06, 0xF1, 0x0E, 0xE0, 0x44, 0x80,
-0xF0, 0xAF, 0x05, 0x74, 0x20, 0x2F, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x54, 0xC0,
-0xF0, 0xF1, 0x0E, 0xE0, 0x54, 0xC0, 0xF0, 0x90,
-0x94, 0xCC, 0xE0, 0xFF, 0xAE, 0x05, 0x74, 0x18,
-0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xEF, 0xF0, 0xF1, 0x03, 0xE0, 0x20, 0xE1, 0x15,
-0x54, 0x01, 0xFF, 0x90, 0x94, 0xCB, 0xE0, 0x25,
-0xE0, 0x25, 0xE0, 0xFB, 0xEF, 0x44, 0x02, 0x4B,
-0xFF, 0xF1, 0x03, 0xEF, 0xF0, 0xAF, 0x05, 0x74,
-0x11, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0x74, 0xFF, 0xF0, 0x74, 0x29, 0x2F, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x54,
-0xF7, 0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x74, 0x12, 0x2E, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0x74, 0x21,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x94, 0xC3, 0xEF, 0xF0, 0xA3, 0xEC, 0xF0,
-0xA3, 0xED, 0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60,
-0x21, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x94, 0xC8,
-0xF0, 0x7D, 0x36, 0x7F, 0xFF, 0xF1, 0x6E, 0xF1,
-0x7B, 0xBF, 0x01, 0x03, 0x12, 0xC5, 0x30, 0x90,
-0x94, 0xC8, 0xE0, 0xFF, 0x7D, 0x37, 0xF1, 0x6E,
-0x80, 0x03, 0x12, 0xC5, 0x30, 0x90, 0x05, 0x22,
-0xE0, 0x54, 0x6F, 0xFF, 0x7D, 0x38, 0xF1, 0x6E,
-0xF1, 0xD1, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
-0x94, 0xCF, 0xE0, 0xFF, 0x7D, 0x48, 0x90, 0x05,
-0x22, 0xEF, 0xF0, 0x90, 0x92, 0x01, 0xED, 0xF0,
-0x22, 0xF1, 0x6E, 0xE4, 0x90, 0x94, 0xCD, 0xF0,
-0xA3, 0xF0, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x94,
-0xCF, 0xF0, 0x7D, 0x47, 0x7F, 0xFF, 0xF1, 0x6E,
-0x90, 0x05, 0xF8, 0xE0, 0x70, 0x11, 0xA3, 0xE0,
-0x70, 0x0D, 0xA3, 0xE0, 0x70, 0x09, 0xA3, 0xE0,
-0x70, 0x05, 0xF1, 0x67, 0x7F, 0x01, 0x22, 0xD3,
-0x90, 0x94, 0xCE, 0xE0, 0x94, 0xE8, 0x90, 0x94,
-0xCD, 0xE0, 0x94, 0x03, 0x40, 0x0C, 0x90, 0x01,
-0xC0, 0xE0, 0x44, 0x20, 0xF0, 0xF1, 0x67, 0x7F,
-0x00, 0x22, 0x7F, 0x32, 0x7E, 0x00, 0x12, 0x7C,
-0x9F, 0x90, 0x94, 0xCD, 0x12, 0xAD, 0xF4, 0x80,
-0xBF, 0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0, 0x22,
-0xFC, 0xED, 0x2C, 0xFD, 0x02, 0x55, 0x36, 0xEF,
-0xF0, 0xE4, 0x90, 0x93, 0xC1, 0xF0, 0x22, 0xEF,
-0xF0, 0xE4, 0x90, 0x93, 0xC0, 0xF0, 0x22, 0x90,
-0x93, 0xB6, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0x12, 0x02, 0xF6, 0xFF, 0x90, 0x92, 0x28, 0xF0,
-0xBF, 0x01, 0x07, 0x11, 0x0B, 0xE4, 0x90, 0x92,
-0x28, 0xF0, 0x22, 0x11, 0xBB, 0x7F, 0xEF, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x06, 0x90,
-0x93, 0x39, 0xE0, 0xA3, 0xF0, 0x11, 0xBB, 0x7F,
-0xEE, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
-0x08, 0x90, 0x93, 0x39, 0xE0, 0x90, 0x93, 0x3B,
-0xF0, 0x11, 0xBB, 0x7F, 0xED, 0x7E, 0x00, 0x12,
-0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x93, 0x39,
-0xE0, 0x90, 0x93, 0x3C, 0xF0, 0x11, 0xBB, 0x7F,
-0xEC, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
-0x08, 0x90, 0x93, 0x39, 0xE0, 0x90, 0x93, 0x3D,
-0xF0, 0x11, 0xBB, 0x7F, 0xEB, 0x7E, 0x00, 0x12,
-0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x93, 0x39,
-0xE0, 0x90, 0x93, 0x3E, 0xF0, 0x90, 0x93, 0x3A,
-0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFB,
-0xA3, 0xE0, 0x90, 0x93, 0x42, 0xF0, 0x90, 0x93,
-0x3E, 0xE0, 0x90, 0x93, 0x43, 0xF0, 0x90, 0x93,
-0x44, 0x74, 0x12, 0xF0, 0x90, 0x93, 0x52, 0x74,
-0x05, 0xF0, 0x90, 0x93, 0x46, 0xEF, 0xF0, 0xA3,
-0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x93, 0x42,
-0xE0, 0x90, 0x93, 0x49, 0xF0, 0x90, 0x93, 0x43,
-0xE0, 0x90, 0x93, 0x4A, 0xF0, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x44, 0x12, 0x5E, 0x10, 0x7F, 0x04,
-0x02, 0x87, 0xDB, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0x39, 0x22, 0x12, 0x02, 0xF6, 0x64, 0x01, 0x60,
-0x02, 0x21, 0x4F, 0x90, 0x93, 0x58, 0xF0, 0x90,
-0x93, 0x58, 0xE0, 0xFF, 0xC3, 0x94, 0x10, 0x50,
-0x27, 0xEF, 0x31, 0x50, 0x7A, 0x93, 0x79, 0x57,
-0x12, 0x64, 0x37, 0xBF, 0x01, 0x12, 0x90, 0x93,
-0x57, 0xE0, 0xFF, 0xA3, 0xE0, 0x24, 0x59, 0xF5,
-0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEF, 0xF0,
-0x90, 0x93, 0x58, 0xE0, 0x04, 0xF0, 0x80, 0xCF,
-0x75, 0x1B, 0x01, 0x75, 0x1C, 0x93, 0x75, 0x1D,
-0x59, 0x75, 0x1E, 0x08, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x3B, 0x12, 0x6A, 0x21, 0x90, 0x93, 0x39,
-0x74, 0x24, 0xF0, 0x90, 0x93, 0x47, 0x74, 0x08,
-0xF0, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x93, 0x75,
-0x1D, 0x61, 0xF5, 0x1E, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x4A, 0x12, 0x6A, 0x21, 0x90, 0x93, 0x48,
-0x74, 0x25, 0xF0, 0x90, 0x93, 0x56, 0x74, 0x08,
-0xF0, 0x11, 0xBB, 0x12, 0x5E, 0x10, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0x48, 0x12, 0x87, 0xD6, 0x22,
-0x24, 0xDE, 0xFF, 0xE4, 0x33, 0xFE, 0x7B, 0x01,
-0x22, 0x12, 0x8F, 0xDA, 0x64, 0x01, 0x60, 0x02,
-0x21, 0xE6, 0xEF, 0x24, 0x39, 0x60, 0x12, 0x14,
-0x60, 0x19, 0x24, 0x02, 0x70, 0x1F, 0xE4, 0x90,
-0x93, 0x3F, 0xF0, 0xA3, 0x74, 0x06, 0xF0, 0x80,
-0x14, 0x90, 0x93, 0x3F, 0x74, 0x06, 0xF0, 0xA3,
-0xF0, 0x80, 0x0A, 0x90, 0x93, 0x3F, 0x74, 0x0C,
-0xF0, 0xA3, 0x74, 0x04, 0xF0, 0x31, 0xFA, 0x31,
-0xE7, 0x40, 0x1B, 0x90, 0x93, 0x3D, 0xE0, 0x31,
-0x50, 0x7A, 0x93, 0x79, 0x3C, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x07, 0x90, 0x93, 0x3C, 0xE0, 0xF4,
-0x70, 0x3C, 0x31, 0xEF, 0x80, 0xE1, 0x31, 0xFA,
-0x31, 0xE7, 0x40, 0x32, 0x90, 0x93, 0x3D, 0xE0,
-0xFD, 0x7C, 0x00, 0x24, 0xDE, 0xFF, 0xEC, 0x33,
-0xFE, 0xED, 0x24, 0x01, 0xFD, 0xEC, 0x33, 0xFC,
-0x90, 0x93, 0x3F, 0xE0, 0xFB, 0xC3, 0xED, 0x9B,
-0xFD, 0xEC, 0x94, 0x00, 0xFC, 0x12, 0x89, 0xE9,
-0x8D, 0x82, 0x8C, 0x83, 0x12, 0x03, 0x0F, 0xFD,
-0x51, 0x0B, 0x31, 0xEF, 0x80, 0xCA, 0x22, 0x90,
-0x93, 0x3E, 0xE0, 0xD3, 0x94, 0x00, 0x22, 0x90,
-0x93, 0x3D, 0xE0, 0x04, 0xF0, 0xA3, 0xE0, 0x14,
-0xF0, 0x22, 0x90, 0x93, 0x3F, 0xE0, 0x90, 0x93,
-0x3D, 0xF0, 0x90, 0x93, 0x40, 0xE0, 0x90, 0x93,
-0x3E, 0xF0, 0x22, 0x8E, 0x5B, 0x8F, 0x5C, 0x8D,
-0x5D, 0xE4, 0x90, 0x93, 0x41, 0xF0, 0x90, 0x00,
-0x37, 0xE0, 0x44, 0x80, 0xFD, 0x7F, 0x37, 0x12,
-0x7B, 0x3E, 0x7D, 0x69, 0x7F, 0xCF, 0x12, 0x7B,
-0x3E, 0xE5, 0x5C, 0xFD, 0x7F, 0x31, 0x12, 0x7B,
-0x3E, 0xE5, 0x5B, 0x54, 0x03, 0xFF, 0x90, 0x00,
-0x32, 0xE0, 0x54, 0xFC, 0x4F, 0xFD, 0x7F, 0x32,
-0x12, 0x7B, 0x3E, 0xAD, 0x5D, 0x7F, 0x30, 0x12,
-0x7B, 0x3E, 0x90, 0x00, 0x33, 0xE0, 0x44, 0x80,
-0xFD, 0x7F, 0x33, 0x12, 0x7B, 0x3E, 0x90, 0x00,
-0x33, 0xE0, 0x30, 0xE7, 0x09, 0x51, 0x82, 0x50,
-0x05, 0xE0, 0x04, 0xF0, 0x80, 0xF0, 0xE4, 0xFD,
-0x7F, 0xCF, 0x12, 0x7B, 0x3E, 0x90, 0x00, 0x37,
-0xE0, 0x54, 0x7F, 0xFD, 0x7F, 0x37, 0x12, 0x7B,
-0x3E, 0x51, 0x82, 0x7F, 0x00, 0x50, 0x02, 0x7F,
-0x01, 0x22, 0x90, 0x93, 0x41, 0xE0, 0xC3, 0x94,
-0x64, 0x22, 0x12, 0x02, 0xF6, 0x54, 0x01, 0xFF,
-0x90, 0x92, 0x3E, 0xE0, 0x54, 0xFE, 0x4F, 0xF0,
-0x22, 0x12, 0x02, 0xF6, 0x90, 0x86, 0x71, 0xF0,
-0x22, 0x12, 0x8F, 0xDA, 0xFF, 0x54, 0x01, 0xFE,
-0x90, 0x92, 0x29, 0xE0, 0x54, 0xFE, 0x4E, 0xFE,
-0xF0, 0xEF, 0x54, 0x02, 0xFF, 0xEE, 0x54, 0xFD,
-0x12, 0xC5, 0xC2, 0x54, 0x04, 0xFD, 0xEF, 0x54,
-0xFB, 0x4D, 0xFF, 0x90, 0x92, 0x29, 0xF0, 0xEE,
-0x54, 0x08, 0xFE, 0xEF, 0x54, 0xF7, 0x4E, 0xF0,
-0x90, 0x05, 0x52, 0xE0, 0x54, 0x07, 0xFF, 0x90,
-0x93, 0x39, 0x60, 0x13, 0x12, 0x8E, 0x89, 0xFD,
-0x90, 0x05, 0x56, 0xE0, 0xC3, 0x9D, 0x90, 0x92,
-0x2B, 0xF0, 0xA3, 0xED, 0xF0, 0x80, 0x23, 0x12,
-0x8E, 0x89, 0xFB, 0xFF, 0x90, 0x05, 0x54, 0xE0,
-0xC3, 0x9F, 0xFF, 0xE4, 0x94, 0x00, 0xFE, 0x7C,
-0x00, 0x7D, 0x05, 0x12, 0x03, 0x82, 0x90, 0x92,
-0x2B, 0xEF, 0xF0, 0xEB, 0x75, 0xF0, 0x05, 0x84,
-0xA3, 0xF0, 0x12, 0x89, 0xE9, 0x12, 0x02, 0xF6,
-0x20, 0xE0, 0x0C, 0x71, 0x76, 0x12, 0xBB, 0xEA,
-0x90, 0x01, 0x57, 0xE4, 0xF0, 0x80, 0x04, 0x91,
-0x05, 0x91, 0x0C, 0xB1, 0xBC, 0x20, 0xE0, 0x04,
-0xEF, 0x44, 0x20, 0xF0, 0x71, 0x6F, 0x30, 0xE0,
-0x17, 0x90, 0x85, 0xC5, 0x74, 0x01, 0xF0, 0xE4,
-0x90, 0x85, 0xC7, 0xF0, 0x90, 0x85, 0xC2, 0xE0,
-0x44, 0x04, 0x12, 0xB6, 0xD8, 0x02, 0x51, 0x7D,
-0xE4, 0x90, 0x85, 0xC5, 0xF0, 0x90, 0x85, 0xC7,
-0x74, 0x0C, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x54,
-0xFE, 0xF0, 0xA3, 0xE0, 0x54, 0xFB, 0xF0, 0x22,
-0xFD, 0xFF, 0x12, 0x9F, 0x6E, 0x71, 0x76, 0x90,
-0x92, 0x29, 0xE0, 0xC3, 0x13, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x7F, 0x02, 0x12,
-0xAF, 0x52, 0x7F, 0x02, 0x12, 0xAF, 0x42, 0x44,
-0x02, 0xF0, 0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0,
-0x90, 0x06, 0xB7, 0x74, 0x09, 0xF0, 0x90, 0x06,
-0xB4, 0x74, 0x86, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x90, 0x92, 0x29, 0xE0, 0x30, 0xE0, 0x0E,
-0x90, 0x01, 0x57, 0xE4, 0xF0, 0x71, 0x68, 0x30,
-0xE0, 0x02, 0x91, 0x05, 0x91, 0x0C, 0x22, 0x90,
-0x92, 0x29, 0xE0, 0x30, 0xE0, 0x46, 0xC4, 0x54,
-0x0F, 0x20, 0xE0, 0x0E, 0xB1, 0xB3, 0x91, 0x1D,
-0xE4, 0x71, 0x68, 0x30, 0xE0, 0x02, 0x91, 0x05,
-0x80, 0x3A, 0x90, 0x92, 0x29, 0xE0, 0xC4, 0x54,
-0x0F, 0x30, 0xE0, 0x28, 0xE4, 0x90, 0x91, 0x6E,
-0xF0, 0x90, 0x92, 0x2C, 0x91, 0x1D, 0x90, 0x92,
-0x29, 0xE0, 0x54, 0xEF, 0xF0, 0xE0, 0xC3, 0x13,
-0x30, 0xE0, 0x07, 0x7D, 0x04, 0x7F, 0x01, 0x02,
-0x57, 0x82, 0x7D, 0x31, 0x7F, 0xFF, 0x12, 0x9F,
-0x6E, 0x12, 0xBB, 0xF0, 0x22, 0x7D, 0x0C, 0x7F,
-0x01, 0x02, 0x57, 0x82, 0x90, 0x92, 0x29, 0xE0,
-0x44, 0x10, 0xF0, 0x22, 0xF0, 0xE4, 0x90, 0x91,
-0x6E, 0xF0, 0x90, 0x86, 0x6E, 0xE0, 0x90, 0x91,
-0x6F, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54, 0x7E,
-0x01, 0x02, 0x61, 0x41, 0xE4, 0xF5, 0x74, 0x90,
-0x85, 0xC5, 0xE0, 0x60, 0x54, 0xD1, 0x48, 0x70,
-0x50, 0x12, 0xC5, 0x08, 0x75, 0x74, 0x01, 0xE5,
-0x74, 0x60, 0x46, 0x90, 0x85, 0xC8, 0xE0, 0x20,
-0xE2, 0x07, 0x7D, 0x01, 0x7F, 0x04, 0x12, 0x8C,
-0xCC, 0x12, 0xC5, 0xBA, 0x90, 0x85, 0xCE, 0xE0,
-0x60, 0x04, 0x64, 0x01, 0x70, 0x13, 0xE4, 0x90,
-0x91, 0x6E, 0xF0, 0x90, 0x85, 0xCE, 0xE0, 0x91,
-0x95, 0x91, 0x1E, 0x90, 0x85, 0xCE, 0xE0, 0x80,
-0x12, 0xE4, 0x90, 0x91, 0x6E, 0x91, 0x8A, 0x91,
-0x1E, 0x90, 0x85, 0xCE, 0xE0, 0x75, 0xF0, 0x03,
-0xA4, 0x24, 0xFE, 0x91, 0x95, 0x90, 0x85, 0xDE,
-0xF0, 0x22, 0xF0, 0x90, 0x85, 0xCE, 0xE0, 0x75,
-0xF0, 0x03, 0xA4, 0x24, 0xFE, 0xFF, 0x90, 0x85,
-0xCD, 0xE0, 0x2F, 0x22, 0x91, 0x2C, 0xE4, 0xFF,
-0x12, 0xB2, 0x17, 0x90, 0x92, 0x03, 0xE0, 0x30,
-0xE0, 0x03, 0x12, 0xAD, 0xFB, 0x61, 0xA1, 0x90,
-0x92, 0x29, 0xE0, 0x30, 0xE0, 0x06, 0xB1, 0xB3,
-0x91, 0x1D, 0x91, 0x0C, 0x90, 0x84, 0xC5, 0xE0,
-0xB4, 0x01, 0x10, 0xB1, 0xBC, 0x20, 0xE0, 0x0B,
-0xEF, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x03,
-0x12, 0xC2, 0xE7, 0x22, 0x90, 0x85, 0xC5, 0xE0,
-0x70, 0x02, 0xA1, 0x8A, 0x90, 0x85, 0xDC, 0xE0,
-0x04, 0xF0, 0x90, 0x05, 0x61, 0xB1, 0xAC, 0x78,
-0x08, 0x12, 0x04, 0xD8, 0xA8, 0x04, 0xA9, 0x05,
-0xAA, 0x06, 0xAB, 0x07, 0x90, 0x05, 0x60, 0xB1,
-0xAC, 0x12, 0x86, 0xD1, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05, 0x62, 0xB1,
-0xAC, 0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86,
-0xD1, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0xA3, 0xB1, 0xAC, 0x78, 0x18, 0x12, 0x04,
-0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x86, 0xD1, 0x90, 0x85, 0xFC, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x92, 0x3F, 0xE0,
-0x54, 0xFE, 0xF0, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
-0x0D, 0x12, 0xB6, 0xD9, 0x12, 0x51, 0x7D, 0x90,
-0x92, 0x3F, 0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x85,
-0xC2, 0xE0, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x30,
-0xE0, 0x11, 0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4,
-0x0A, 0x7D, 0x02, 0x7F, 0x02, 0x12, 0x7C, 0x41,
-0x12, 0xB6, 0xE7, 0x90, 0x94, 0xDE, 0xE0, 0x04,
-0xF0, 0xE0, 0xC3, 0x94, 0x80, 0x40, 0x0B, 0x90,
-0x01, 0x98, 0xE0, 0x54, 0xFE, 0xF0, 0xE0, 0x44,
-0x01, 0xF0, 0x12, 0xBF, 0x93, 0xFF, 0xBF, 0x03,
-0x14, 0x90, 0x92, 0x31, 0xE0, 0xB4, 0x01, 0x0D,
-0x90, 0x01, 0xB8, 0xE0, 0x04, 0xF0, 0x90, 0x05,
-0x21, 0xE0, 0x44, 0x80, 0xF0, 0x7F, 0x01, 0x12,
-0xB1, 0xF5, 0x81, 0xAF, 0xE0, 0xFF, 0xE4, 0xFC,
-0xFD, 0xFE, 0x22, 0xE4, 0x90, 0x91, 0x6E, 0xF0,
-0x90, 0x92, 0x2B, 0x22, 0x90, 0x92, 0x29, 0xE0,
-0xFF, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x22, 0x90,
-0x85, 0xC5, 0xE0, 0x60, 0x02, 0xB1, 0xD1, 0x61,
-0xB7, 0x90, 0x85, 0xC2, 0xB1, 0xBF, 0x30, 0xE0,
-0x10, 0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x30,
-0xE0, 0x07, 0x7D, 0x02, 0x7F, 0x02, 0x12, 0x7C,
-0x41, 0x90, 0x85, 0xC1, 0x12, 0xB7, 0x12, 0x30,
-0xE0, 0x08, 0xEF, 0x12, 0xC5, 0x90, 0x70, 0x47,
-0x80, 0x42, 0x90, 0x85, 0xCE, 0xE0, 0x04, 0xF0,
-0x90, 0x85, 0xC9, 0xE0, 0x54, 0xEF, 0xF0, 0x12,
-0xC2, 0xB4, 0x9F, 0x40, 0x2F, 0xD1, 0x48, 0x70,
-0x2E, 0x12, 0x8F, 0xD3, 0x70, 0x05, 0x12, 0x70,
-0xDB, 0x80, 0x25, 0x12, 0x70, 0xDB, 0x90, 0x85,
-0xCF, 0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94, 0x02,
-0x40, 0x09, 0xD1, 0x40, 0xE4, 0x90, 0x85, 0xCF,
-0xF0, 0x80, 0x03, 0x12, 0x79, 0x41, 0xE4, 0x90,
-0x85, 0xCE, 0xF0, 0x22, 0x12, 0xB3, 0x4A, 0x22,
-0x90, 0x85, 0xC2, 0xE0, 0x54, 0xFB, 0xF0, 0x22,
-0xE4, 0xFF, 0x12, 0x77, 0x39, 0xEF, 0x64, 0x01,
-0x22, 0xD1, 0x48, 0x70, 0x0B, 0x90, 0x85, 0xC5,
-0xE0, 0x60, 0x05, 0x12, 0xB7, 0xE8, 0x91, 0x14,
-0x22, 0xE4, 0x90, 0x94, 0x4F, 0xF0, 0x90, 0x85,
-0xC5, 0xE0, 0x60, 0x34, 0xD1, 0x48, 0x70, 0x30,
-0x12, 0xB6, 0xF6, 0xF0, 0x12, 0xC5, 0x08, 0x90,
-0x94, 0x4F, 0x74, 0x01, 0xF0, 0xE4, 0x90, 0x85,
-0xCC, 0xF0, 0x04, 0x60, 0x1B, 0x90, 0x85, 0xC8,
-0xE0, 0x20, 0xE2, 0x07, 0x7D, 0x01, 0x7F, 0x04,
-0x12, 0x8C, 0xCC, 0x12, 0xC5, 0xBA, 0xE4, 0x90,
-0x91, 0x6E, 0xF0, 0x90, 0x85, 0xCD, 0x91, 0x1D,
-0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0,
-0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00,
-0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01,
-0xC4, 0x74, 0xA1, 0xF0, 0x74, 0xA6, 0xA3, 0xF0,
-0x12, 0x71, 0x90, 0xE5, 0x4C, 0x30, 0xE1, 0x03,
-0x12, 0xB1, 0xD8, 0xE5, 0x4C, 0x30, 0xE3, 0x03,
-0x12, 0xB2, 0x0B, 0xE5, 0x4C, 0x30, 0xE4, 0x03,
-0x12, 0xB2, 0x04, 0xE5, 0x4C, 0x30, 0xE5, 0x03,
-0x12, 0xBF, 0x47, 0xE5, 0x4E, 0x30, 0xE0, 0x02,
-0x91, 0x9C, 0xE5, 0x4E, 0x30, 0xE1, 0x02, 0x91,
-0xD4, 0xE5, 0x4E, 0x30, 0xE2, 0x03, 0x12, 0xBB,
-0x92, 0xE5, 0x4E, 0x30, 0xE3, 0x02, 0xD1, 0x51,
-0xE5, 0x4E, 0x30, 0xE4, 0x02, 0xF1, 0x6C, 0xE5,
-0x4E, 0x30, 0xE5, 0x03, 0x12, 0xBB, 0x9E, 0xE5,
-0x4E, 0x30, 0xE6, 0x03, 0x12, 0xB3, 0x91, 0xE5,
-0x4E, 0x30, 0xE7, 0x03, 0x12, 0xBF, 0x83, 0xE5,
-0x4F, 0x30, 0xE0, 0x03, 0x12, 0xBF, 0xA2, 0xE5,
-0x4F, 0x30, 0xE1, 0x03, 0x12, 0xBB, 0xBA, 0xE5,
-0x4F, 0x30, 0xE4, 0x03, 0x12, 0xBF, 0xAB, 0xE5,
-0x4F, 0x30, 0xE5, 0x02, 0xF1, 0x87, 0x74, 0xA1,
-0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xA6, 0xA3,
-0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0,
-0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
-0xF0, 0xD0, 0xE0, 0x32, 0xD1, 0x48, 0x70, 0x16,
-0x90, 0x85, 0xC5, 0xE0, 0x60, 0x10, 0x12, 0xB7,
-0xE8, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x12, 0xC5,
-0x90, 0x70, 0x03, 0x12, 0xB3, 0x4A, 0x22, 0xE4,
-0xF5, 0x74, 0x90, 0x85, 0xBB, 0xE0, 0xFF, 0xE5,
-0x74, 0xC3, 0x9F, 0x50, 0x67, 0xAF, 0x74, 0x12,
-0x77, 0x39, 0xEF, 0x60, 0x5B, 0xE5, 0x74, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0xFF, 0xE5, 0x74, 0x54,
-0x07, 0xFE, 0x74, 0x75, 0x2F, 0x12, 0xC5, 0x9D,
-0xAF, 0x06, 0x12, 0xB1, 0xED, 0x80, 0x05, 0xC3,
-0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEF,
-0x5D, 0x60, 0x35, 0xE5, 0x74, 0xC4, 0x54, 0xF0,
-0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
-0x83, 0xE0, 0x20, 0xE7, 0x02, 0x80, 0x13, 0xE5,
-0x74, 0xC4, 0x54, 0xF0, 0x24, 0x02, 0xF5, 0x82,
-0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0, 0xFF, 0x20,
-0xE7, 0x09, 0x90, 0x01, 0xC1, 0xE0, 0x44, 0x20,
-0xF0, 0x80, 0x05, 0xAD, 0x74, 0x12, 0x90, 0xFA,
-0x05, 0x74, 0x80, 0x8E, 0x22, 0x12, 0x02, 0xF6,
-0x90, 0x92, 0x31, 0xF0, 0x22, 0x12, 0x02, 0xF6,
-0xFF, 0x90, 0x92, 0x32, 0xF0, 0xBF, 0x01, 0x09,
-0x7F, 0x01, 0x11, 0x1A, 0xE4, 0x90, 0x92, 0x32,
-0xF0, 0x22, 0x90, 0x93, 0x71, 0xEF, 0xF0, 0x51,
-0x64, 0x7F, 0xF4, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x93, 0x90, 0xE0, 0x90,
-0x93, 0x92, 0xF0, 0x51, 0x64, 0x7F, 0xF5, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x93, 0x90, 0xE0, 0x90, 0x93, 0x93, 0xF0, 0x51,
-0x64, 0x7F, 0xF6, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x93, 0x90, 0xE0, 0x90,
-0x93, 0x94, 0xF0, 0x51, 0x64, 0x7F, 0xF7, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x93, 0x90, 0xE0, 0x90, 0x93, 0x95, 0xF0, 0x51,
-0x64, 0x7F, 0xF8, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x93, 0x90, 0xE0, 0x90,
-0x93, 0x96, 0xF0, 0x51, 0x64, 0x71, 0x04, 0xBF,
-0x01, 0x08, 0x90, 0x93, 0x90, 0xE0, 0x90, 0x93,
-0x97, 0xF0, 0x51, 0x64, 0x51, 0x6B, 0x70, 0x52,
-0x90, 0x93, 0x90, 0xE0, 0x90, 0x93, 0x98, 0xF0,
-0x54, 0x07, 0x60, 0x08, 0x90, 0x93, 0x90, 0xE0,
-0x54, 0xE0, 0x70, 0x3E, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x91, 0x7F, 0xFA, 0x51, 0x6D, 0x70, 0x32,
-0x90, 0x93, 0x90, 0xE0, 0xFC, 0x54, 0x07, 0x70,
-0x12, 0x90, 0x93, 0x98, 0xE0, 0xFE, 0x90, 0x93,
-0x91, 0xE0, 0x54, 0x07, 0xFD, 0xEE, 0x4D, 0x90,
-0x93, 0x98, 0xF0, 0xEC, 0x54, 0xE0, 0x70, 0x12,
-0x90, 0x93, 0x98, 0xE0, 0xFF, 0x90, 0x93, 0x91,
-0xE0, 0x54, 0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x93,
-0x98, 0xF0, 0x51, 0x64, 0x7F, 0xFD, 0x51, 0x6D,
-0x70, 0x46, 0x90, 0x93, 0x90, 0xE0, 0xFE, 0x54,
-0xCC, 0x90, 0x93, 0x99, 0xF0, 0xEE, 0x54, 0x0C,
-0xFF, 0x60, 0x08, 0x90, 0x93, 0x90, 0xE0, 0x54,
-0xC0, 0x70, 0x2D, 0xEF, 0x70, 0x11, 0x90, 0x93,
-0x99, 0xE0, 0xFF, 0x90, 0x93, 0x90, 0xE0, 0x54,
-0x03, 0xF1, 0x4A, 0x90, 0x93, 0x99, 0xF0, 0x90,
-0x93, 0x90, 0xE0, 0xFF, 0x54, 0xC0, 0x70, 0x10,
-0x90, 0x93, 0x99, 0xE0, 0xFE, 0xEF, 0x54, 0x30,
-0x25, 0xE0, 0x25, 0xE0, 0xFF, 0xEE, 0x4F, 0xF0,
-0x51, 0x64, 0x7F, 0xF0, 0x7E, 0x00, 0x12, 0x64,
-0x37, 0xBF, 0x01, 0x08, 0x90, 0x93, 0x90, 0xE0,
-0x90, 0x93, 0x9A, 0xF0, 0x51, 0x64, 0x7F, 0xF1,
-0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08,
-0x90, 0x93, 0x90, 0xE0, 0x90, 0x93, 0x9B, 0xF0,
-0x51, 0x64, 0x7F, 0xF2, 0x7E, 0x00, 0x12, 0x64,
-0x37, 0xBF, 0x01, 0x08, 0x90, 0x93, 0x90, 0xE0,
-0x90, 0x93, 0x9C, 0xF0, 0x51, 0x64, 0x7F, 0xF3,
-0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08,
-0x90, 0x93, 0x90, 0xE0, 0x90, 0x93, 0x9D, 0xF0,
-0x51, 0x64, 0x7F, 0xFC, 0x7E, 0x00, 0x12, 0x64,
-0x37, 0xBF, 0x01, 0x08, 0x90, 0x93, 0x90, 0xE0,
-0x90, 0x93, 0x9E, 0xF0, 0x90, 0x93, 0x72, 0x74,
-0x19, 0xF0, 0x90, 0x93, 0x80, 0x74, 0x08, 0xF0,
-0x90, 0x93, 0x92, 0xE0, 0x90, 0x93, 0x74, 0xF0,
-0x90, 0x93, 0x93, 0xE0, 0x90, 0x93, 0x75, 0xF0,
-0x90, 0x93, 0x94, 0xE0, 0x90, 0x93, 0x76, 0xF0,
-0x90, 0x93, 0x95, 0xE0, 0x90, 0x93, 0x77, 0xF0,
-0x90, 0x93, 0x96, 0xE0, 0x90, 0x93, 0x78, 0xF0,
-0x90, 0x93, 0x97, 0xE0, 0x90, 0x93, 0x79, 0xF0,
-0x90, 0x93, 0x98, 0xE0, 0x90, 0x93, 0x7A, 0xF0,
-0x90, 0x93, 0x99, 0xE0, 0x90, 0x93, 0x7B, 0xF0,
-0x90, 0x93, 0x81, 0x74, 0x1A, 0xF0, 0x90, 0x93,
-0x8F, 0x74, 0x05, 0xF0, 0x90, 0x93, 0x9A, 0xE0,
-0x90, 0x93, 0x83, 0xF0, 0x90, 0x93, 0x9B, 0xE0,
-0x90, 0x93, 0x84, 0xF0, 0x90, 0x93, 0x9C, 0xE0,
-0x90, 0x93, 0x85, 0xF0, 0x90, 0x93, 0x9D, 0xE0,
-0x90, 0x93, 0x86, 0xF0, 0x90, 0x93, 0x9E, 0xE0,
-0x90, 0x93, 0x87, 0xF0, 0x90, 0x93, 0x71, 0xE0,
-0xB4, 0x01, 0x17, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0x72, 0x12, 0x5E, 0x10, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x81, 0x12, 0x5E, 0x10, 0x7F, 0x04, 0x02,
-0x87, 0xDB, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x93,
-0x75, 0x1D, 0x72, 0x75, 0x1E, 0x0A, 0x7B, 0x01,
-0x7A, 0x01, 0x79, 0xA0, 0x12, 0x6A, 0x21, 0x75,
-0x1B, 0x01, 0x75, 0x1C, 0x93, 0x75, 0x1D, 0x83,
-0x75, 0x1E, 0x05, 0x7B, 0x01, 0x7A, 0x01, 0x79,
-0xAA, 0x02, 0x6A, 0x21, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x90, 0x22, 0x7F, 0xFB, 0x7E, 0x00, 0x12,
-0x64, 0x37, 0xEF, 0x64, 0x01, 0x22, 0x7E, 0x00,
-0x7F, 0x0B, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x92,
-0x79, 0x33, 0x12, 0x06, 0xDE, 0x51, 0xFD, 0x71,
-0x04, 0xBF, 0x01, 0x1C, 0x90, 0x93, 0x71, 0xE0,
-0xFE, 0x54, 0x01, 0x90, 0x92, 0x33, 0xF0, 0xEE,
-0x54, 0x04, 0x90, 0x92, 0x35, 0xF0, 0x90, 0x93,
-0x71, 0xE0, 0x54, 0x08, 0x90, 0x92, 0x34, 0xF0,
-0x51, 0xFD, 0x51, 0x6B, 0x70, 0x34, 0x90, 0x93,
-0x71, 0xE0, 0x54, 0x07, 0x70, 0x14, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0x72, 0x7F, 0xFA, 0xFE, 0x12,
-0x64, 0x37, 0xBF, 0x01, 0x0F, 0x90, 0x93, 0x72,
-0x80, 0x03, 0x90, 0x93, 0x71, 0xE0, 0x54, 0x07,
-0x90, 0x92, 0x37, 0xF0, 0x90, 0x93, 0x71, 0xE0,
-0x54, 0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90, 0x92,
-0x36, 0xF0, 0x51, 0xFD, 0x7F, 0xFD, 0x7E, 0x00,
-0x12, 0x64, 0x37, 0xBF, 0x01, 0x0E, 0x90, 0x93,
-0x71, 0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F,
-0x90, 0x92, 0x38, 0xF0, 0x22, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x71, 0x22, 0x7F, 0xF9, 0x7E, 0x00,
-0x02, 0x64, 0x37, 0x90, 0x00, 0x80, 0xE0, 0x44,
-0x80, 0xFD, 0x7F, 0x80, 0x12, 0x7B, 0x3E, 0xF1,
-0xA9, 0xF1, 0x84, 0x12, 0x7B, 0x9C, 0x91, 0x54,
-0xF1, 0x78, 0x7F, 0x01, 0x12, 0x85, 0x15, 0x90,
-0x92, 0x30, 0x74, 0x02, 0xF0, 0xFF, 0x12, 0x85,
-0x15, 0x90, 0x92, 0x30, 0xE0, 0x04, 0xF0, 0x91,
-0x79, 0x71, 0x75, 0x90, 0x01, 0xCC, 0x74, 0x0F,
-0xF0, 0x90, 0x00, 0x80, 0xE0, 0x44, 0x40, 0xFD,
-0x7F, 0x80, 0x12, 0x7B, 0x3E, 0x75, 0x20, 0xFF,
-0x12, 0x7C, 0xCD, 0x90, 0x01, 0xA0, 0xE0, 0xB4,
-0xFD, 0x04, 0xE4, 0xFF, 0x11, 0x1A, 0x91, 0xDF,
-0x90, 0x00, 0x81, 0xE0, 0x44, 0x04, 0xFD, 0x7F,
-0x81, 0x12, 0x7B, 0x3E, 0xF1, 0x5A, 0x51, 0x76,
-0xE4, 0xFF, 0x02, 0x85, 0x9E, 0xB1, 0xEE, 0x12,
-0x7B, 0xEF, 0x12, 0x3C, 0x03, 0x12, 0xBC, 0x32,
-0xB1, 0x30, 0x71, 0x8F, 0x91, 0x3D, 0xF1, 0xC2,
-0x90, 0x92, 0x31, 0x74, 0x01, 0xF0, 0x22, 0x90,
-0x92, 0x29, 0xE0, 0x54, 0xFE, 0xF0, 0x54, 0xFD,
-0xF0, 0x54, 0xEF, 0xF0, 0x44, 0x08, 0xF0, 0x90,
-0x84, 0xC5, 0xE0, 0xFF, 0x64, 0x02, 0x70, 0x2D,
-0x90, 0xFD, 0x80, 0xE0, 0x7E, 0x00, 0x30, 0xE0,
-0x02, 0x7E, 0x01, 0x90, 0x92, 0x2F, 0x91, 0x36,
-0x7E, 0x00, 0x30, 0xE1, 0x02, 0x7E, 0x01, 0x90,
-0x92, 0x2D, 0x91, 0x36, 0x7E, 0x00, 0x30, 0xE2,
-0x02, 0x7E, 0x01, 0x90, 0x92, 0x2E, 0x91, 0x36,
-0x90, 0x02, 0xFB, 0xF0, 0x22, 0xEF, 0x64, 0x01,
-0x70, 0x21, 0x91, 0x2F, 0x30, 0xE0, 0x02, 0x7F,
-0x01, 0x90, 0x92, 0x2F, 0xEF, 0xF0, 0x91, 0x2F,
-0x30, 0xE1, 0x02, 0x7F, 0x01, 0x90, 0x92, 0x2D,
-0xEF, 0xF0, 0x91, 0x2F, 0x30, 0xE2, 0x02, 0x7F,
-0x01, 0x80, 0x27, 0x90, 0x84, 0xC5, 0xE0, 0x64,
-0x03, 0x70, 0x24, 0x91, 0x28, 0x30, 0xE0, 0x02,
-0x7F, 0x01, 0x90, 0x92, 0x2F, 0xEF, 0xF0, 0x91,
-0x28, 0x30, 0xE1, 0x02, 0x7F, 0x01, 0x90, 0x92,
-0x2D, 0xEF, 0xF0, 0x91, 0x28, 0x30, 0xE2, 0x02,
-0x7F, 0x01, 0x90, 0x92, 0x2E, 0xEF, 0xF0, 0x22,
-0x90, 0xFD, 0x78, 0xE0, 0x7F, 0x00, 0x22, 0x90,
-0xFD, 0x70, 0xE0, 0x7F, 0x00, 0x22, 0xEE, 0xF0,
-0x90, 0xFD, 0x80, 0xE0, 0x22, 0x90, 0x92, 0x03,
-0xE0, 0x54, 0xFE, 0xD1, 0x95, 0x90, 0x92, 0x0A,
-0x12, 0x9E, 0x2B, 0x90, 0x92, 0x25, 0xF0, 0xA3,
-0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x00, 0x00, 0xE0,
-0x54, 0xFB, 0xFD, 0xE4, 0xFF, 0xF1, 0x42, 0x44,
-0x04, 0xFD, 0x7F, 0x01, 0x12, 0x7B, 0x3E, 0x90,
-0x01, 0x98, 0x74, 0x80, 0xF0, 0xA3, 0x74, 0x88,
-0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x80, 0xF0,
-0x22, 0x12, 0x7C, 0x4E, 0x90, 0x84, 0xC5, 0xEF,
-0xF0, 0x91, 0xAD, 0x90, 0x01, 0x64, 0x74, 0x01,
-0xF0, 0x90, 0x04, 0x23, 0xE0, 0x44, 0x80, 0xF0,
-0x90, 0x00, 0x17, 0xE0, 0x54, 0xFC, 0x44, 0x04,
-0xFD, 0x7F, 0x17, 0x12, 0x7B, 0x3E, 0x90, 0x00,
-0x38, 0xE0, 0x44, 0x40, 0xFD, 0x7F, 0x38, 0x12,
-0x7B, 0x3E, 0x02, 0x68, 0xE2, 0x12, 0x75, 0xB6,
-0x12, 0x75, 0x58, 0x12, 0xB9, 0x1D, 0x12, 0xB9,
-0x44, 0xE4, 0xF5, 0x40, 0xF5, 0x41, 0xF5, 0x42,
-0x75, 0x43, 0x80, 0xAD, 0x40, 0x7F, 0x50, 0x12,
-0x7B, 0x3E, 0xAD, 0x41, 0x7F, 0x51, 0x12, 0x7B,
-0x3E, 0xAD, 0x42, 0x7F, 0x52, 0x12, 0x7B, 0x3E,
-0xAD, 0x43, 0x7F, 0x53, 0x02, 0x7B, 0x3E, 0xE4,
-0x90, 0x93, 0x71, 0xF0, 0xA3, 0xF0, 0x12, 0xBF,
-0x1E, 0xEF, 0x64, 0x01, 0x60, 0x3B, 0xC3, 0x90,
-0x93, 0x72, 0xE0, 0x94, 0x88, 0x90, 0x93, 0x71,
-0xE0, 0x94, 0x13, 0x40, 0x0F, 0x90, 0x01, 0xC1,
-0xE0, 0x44, 0x10, 0xF0, 0x90, 0x01, 0xC7, 0x74,
-0xFD, 0xF0, 0x80, 0x1D, 0x90, 0x93, 0x71, 0xB1,
-0xF4, 0xD1, 0x9C, 0xD3, 0x90, 0x93, 0x72, 0xE0,
-0x94, 0x32, 0x90, 0x93, 0x71, 0xE0, 0x94, 0x00,
-0x40, 0xC4, 0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE3,
-0xBD, 0x90, 0x01, 0xC7, 0x74, 0xFE, 0xF0, 0x22,
-0x7E, 0x00, 0x7F, 0xAC, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x85, 0x79, 0xC1, 0x12, 0x06, 0xDE, 0x90,
-0x85, 0xC4, 0x74, 0x02, 0xF0, 0x90, 0x85, 0xCB,
-0x14, 0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x0A, 0xF0,
-0x90, 0x85, 0xD1, 0xE4, 0xF0, 0xA3, 0x74, 0x02,
-0xB1, 0xDE, 0xF1, 0x91, 0xE4, 0xFD, 0xFF, 0x12,
-0x57, 0x82, 0x7D, 0x0C, 0x7F, 0x02, 0x12, 0x57,
-0x82, 0x12, 0xA4, 0x05, 0x90, 0x84, 0xC5, 0xE0,
-0xFF, 0xB4, 0x01, 0x08, 0x90, 0x85, 0xD0, 0x74,
-0xDD, 0xF0, 0x80, 0x0F, 0xEF, 0x90, 0x85, 0xD0,
-0xB4, 0x03, 0x05, 0x74, 0xD4, 0xF0, 0x80, 0x03,
-0x74, 0x40, 0xF0, 0x7F, 0x2C, 0x12, 0x7B, 0x51,
-0xEF, 0x54, 0x0F, 0xFF, 0xBF, 0x05, 0x08, 0x90,
-0x85, 0xFB, 0x74, 0x02, 0xF0, 0x80, 0x05, 0xE4,
-0x90, 0x85, 0xFB, 0xF0, 0x90, 0x86, 0x6D, 0x74,
-0x02, 0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0xE0,
-0x54, 0x01, 0x44, 0x28, 0xF0, 0xA3, 0x74, 0x07,
-0xB1, 0xDE, 0xE4, 0x90, 0x85, 0xD7, 0xF0, 0xA3,
-0xF0, 0x7F, 0x01, 0x12, 0x69, 0x33, 0x90, 0x06,
-0x04, 0xE0, 0x54, 0x7F, 0xF0, 0x90, 0x06, 0x0A,
-0xE0, 0x54, 0xF8, 0xF0, 0x90, 0x05, 0x22, 0xE4,
-0xF0, 0x90, 0x86, 0x71, 0xF0, 0x22, 0xF0, 0x90,
-0x85, 0xFB, 0xE0, 0x24, 0x04, 0x90, 0x85, 0xDD,
-0xF0, 0xA3, 0x74, 0x0A, 0xF0, 0x22, 0xE4, 0xFD,
-0xFF, 0x02, 0x6E, 0x5F, 0xE4, 0x75, 0xF0, 0x01,
-0x02, 0x07, 0x0A, 0x90, 0x92, 0x0E, 0xE0, 0xFD,
-0x7C, 0x00, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x12, 0x03, 0x82, 0xED, 0x4C, 0x70, 0x05, 0x90,
-0x92, 0x1B, 0x80, 0x2A, 0xED, 0x64, 0x01, 0x4C,
-0x70, 0x05, 0x90, 0x92, 0x1C, 0x80, 0x1F, 0xED,
-0x64, 0x02, 0x4C, 0x70, 0x05, 0x90, 0x92, 0x1D,
-0x80, 0x14, 0xED, 0x64, 0x03, 0x4C, 0x70, 0x05,
-0x90, 0x92, 0x1E, 0x80, 0x09, 0xED, 0x64, 0x04,
-0x4C, 0x70, 0x0C, 0x90, 0x92, 0x1F, 0xE0, 0xFF,
-0xF1, 0x64, 0x90, 0x92, 0x0F, 0xB1, 0xF4, 0x22,
-0x90, 0x94, 0xD3, 0xEF, 0xD1, 0x95, 0x90, 0x01,
-0x09, 0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02, 0x7F,
-0x01, 0x90, 0x94, 0xD3, 0xE0, 0x6F, 0x60, 0x34,
-0xC3, 0x90, 0x94, 0xD5, 0xE0, 0x94, 0x88, 0x90,
-0x94, 0xD4, 0xE0, 0x94, 0x13, 0x40, 0x08, 0x90,
-0x01, 0xC0, 0xE0, 0x44, 0x10, 0xF0, 0x22, 0x90,
-0x94, 0xD4, 0xB1, 0xF4, 0xD1, 0x9C, 0xD3, 0x90,
-0x94, 0xD5, 0xE0, 0x94, 0x32, 0x90, 0x94, 0xD4,
-0xE0, 0x94, 0x00, 0x40, 0xC1, 0x90, 0x01, 0xC6,
-0xE0, 0x30, 0xE0, 0xBA, 0x22, 0xF0, 0xE4, 0xA3,
-0xF0, 0xA3, 0xF0, 0x22, 0x7F, 0x14, 0x7E, 0x00,
-0x02, 0x7C, 0x9F, 0x12, 0xC0, 0x63, 0x7F, 0x08,
-0x12, 0x7B, 0x51, 0xEF, 0x54, 0xEF, 0xFD, 0x7F,
-0x08, 0x12, 0x7B, 0x3E, 0xE4, 0xFF, 0xD1, 0x48,
-0x7D, 0x35, 0x7F, 0x27, 0x12, 0x7B, 0x3E, 0x90,
-0x85, 0xC2, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD1, 0xD7,
-0xD1, 0xA3, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
-0x85, 0xC2, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x85,
-0xD0, 0xE0, 0xFD, 0x7F, 0x93, 0x12, 0x7B, 0x3E,
-0x90, 0x85, 0xC6, 0xE0, 0x60, 0x12, 0x90, 0x01,
-0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74, 0x10, 0xF0,
-0x80, 0x06, 0x90, 0x01, 0x2F, 0x74, 0x90, 0xF0,
-0x7F, 0x08, 0x12, 0x7B, 0x51, 0xEF, 0x44, 0x10,
-0xFD, 0x7F, 0x08, 0x12, 0x7B, 0x3E, 0x7F, 0x01,
-0xD1, 0x48, 0x7D, 0x34, 0x7F, 0x27, 0x12, 0x7B,
-0x3E, 0x7F, 0x90, 0xF1, 0x52, 0x7F, 0x90, 0x12,
-0x7B, 0x3E, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C,
-0x9F, 0x90, 0x85, 0xC8, 0xE0, 0xFF, 0x60, 0x03,
-0xB4, 0x08, 0x0E, 0x12, 0xC2, 0x37, 0xBF, 0x01,
-0x08, 0xD1, 0xC7, 0x90, 0x01, 0xE5, 0xE0, 0x04,
-0xF0, 0x22, 0x12, 0x7B, 0x3E, 0x90, 0x01, 0x01,
-0xE0, 0x22, 0x25, 0xE0, 0x25, 0xE0, 0xFE, 0xEF,
-0x4E, 0x22, 0x12, 0x7B, 0x51, 0xEF, 0x44, 0x01,
-0xFD, 0x22, 0x90, 0x01, 0xE4, 0x74, 0x04, 0xF0,
-0xA3, 0xE4, 0xF0, 0x22, 0x90, 0x04, 0x24, 0xEF,
-0xF0, 0x90, 0x04, 0x57, 0xF0, 0x22, 0x90, 0x85,
-0xC1, 0xE0, 0x30, 0xE0, 0x02, 0xF1, 0x29, 0x22,
-0xE4, 0x90, 0x84, 0xC1, 0x12, 0x9E, 0x2B, 0x90,
-0x92, 0x01, 0xF0, 0x22, 0x90, 0x01, 0x94, 0xE0,
-0x44, 0x01, 0xF0, 0x90, 0x01, 0xC7, 0xE4, 0xF0,
-0x22, 0x90, 0x92, 0x79, 0x74, 0x04, 0xF0, 0x14,
-0xF0, 0xA3, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74,
-0x64, 0xF0, 0xA3, 0x74, 0x05, 0xF0, 0xA3, 0xF0,
-0x22, 0x90, 0x84, 0xA1, 0x74, 0x02, 0xF0, 0xA3,
-0x74, 0x9A, 0xF0, 0xA3, 0x74, 0x26, 0xF0, 0x90,
-0x84, 0xA7, 0x74, 0x80, 0xF0, 0xA3, 0x74, 0x03,
-0xF0, 0x22, 0x90, 0x89, 0x16, 0xE0, 0x54, 0x7F,
-0xF0, 0x54, 0xBF, 0xF0, 0x54, 0xDF, 0xF0, 0x54,
-0xF0, 0xF0, 0xE4, 0x90, 0x89, 0x18, 0xF0, 0x90,
-0x89, 0x16, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0x90,
-0x01, 0xCC, 0xE0, 0x54, 0x0F, 0x90, 0x93, 0x33,
-0xF0, 0x90, 0x93, 0x33, 0xE0, 0xFD, 0x70, 0x03,
-0x02, 0xB0, 0xE2, 0x90, 0x85, 0x1D, 0xE0, 0xFF,
-0x70, 0x06, 0xA3, 0xE0, 0x64, 0x09, 0x60, 0x0A,
-0xEF, 0x14, 0xFF, 0x90, 0x85, 0x1E, 0xE0, 0xB5,
-0x07, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F, 0x00,
-0xEF, 0x60, 0x08, 0x90, 0x01, 0xC1, 0xE0, 0x44,
-0x01, 0xF0, 0x22, 0x90, 0x94, 0xD9, 0xE0, 0x31,
-0xEC, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
-0xD8, 0xF9, 0xFF, 0xEF, 0x5D, 0x70, 0x02, 0x01,
-0xC5, 0xE4, 0x90, 0x93, 0x34, 0xF0, 0x90, 0x93,
-0x34, 0xE0, 0xF9, 0xC3, 0x94, 0x04, 0x50, 0x34,
-0x11, 0xE4, 0xA4, 0xFF, 0xE9, 0xFD, 0x7C, 0x00,
-0x2F, 0xFF, 0xEC, 0x35, 0xF0, 0xFE, 0x74, 0xD0,
-0x11, 0xFA, 0x90, 0x84, 0xCD, 0x11, 0xEC, 0xEF,
-0x11, 0xE3, 0xA4, 0x2D, 0xFF, 0xEC, 0x35, 0xF0,
-0xFE, 0x74, 0xF0, 0x11, 0xFA, 0x90, 0x84, 0xD1,
-0x11, 0xEC, 0xEF, 0xF0, 0x90, 0x93, 0x34, 0xE0,
-0x04, 0xF0, 0x80, 0xC2, 0x90, 0x93, 0x33, 0xE0,
-0xFF, 0x90, 0x94, 0xD9, 0xE0, 0xFE, 0x74, 0x01,
-0xA8, 0x06, 0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8,
-0xFC, 0xF4, 0x5F, 0x90, 0x93, 0x33, 0xF0, 0x90,
-0x94, 0xD9, 0xE0, 0xFF, 0x74, 0x01, 0xA8, 0x07,
-0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x90,
-0x01, 0xCC, 0xF0, 0x90, 0x94, 0xD9, 0xE0, 0x04,
-0xF0, 0xE0, 0x54, 0x03, 0xF0, 0x90, 0x85, 0x1E,
-0x31, 0xDC, 0xB4, 0x0A, 0x02, 0x7F, 0x01, 0xEF,
-0x70, 0x03, 0x02, 0xAF, 0xE9, 0xE4, 0x90, 0x85,
-0x1E, 0xF0, 0x02, 0xAF, 0xE9, 0x90, 0x01, 0xC0,
-0xE0, 0x44, 0x02, 0xF0, 0x90, 0x94, 0xD9, 0xE0,
-0x44, 0x80, 0x90, 0x00, 0x8A, 0x11, 0xE3, 0x90,
-0x01, 0xD0, 0x12, 0x05, 0x28, 0xE0, 0x90, 0x01,
-0xC3, 0xF0, 0x22, 0xF0, 0x90, 0x94, 0xD9, 0xE0,
-0x75, 0xF0, 0x04, 0x22, 0x12, 0x05, 0x28, 0xE5,
-0x82, 0x29, 0xF5, 0x82, 0xE4, 0x35, 0x83, 0xF5,
-0x83, 0x22, 0x2F, 0xF5, 0x82, 0x74, 0x01, 0x3E,
-0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x85, 0x1E, 0xE0,
-0x75, 0xF0, 0x08, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xDB, 0xEF, 0xF0,
-0x12, 0x8F, 0xB1, 0x30, 0xE6, 0x3A, 0x7F, 0x8D,
-0x12, 0x7B, 0x51, 0xEF, 0x64, 0x01, 0x70, 0x30,
-0x90, 0x94, 0xDC, 0xF0, 0x90, 0x94, 0xDC, 0xE0,
-0xFD, 0x90, 0x94, 0xDB, 0xE0, 0x12, 0x91, 0x79,
-0xE5, 0x82, 0x2D, 0x11, 0xF2, 0xE0, 0xFB, 0xE4,
-0xFF, 0x12, 0x8C, 0x78, 0x90, 0x94, 0xDC, 0xE0,
-0x04, 0xF0, 0xE0, 0xC3, 0x94, 0x10, 0x40, 0xDC,
-0x12, 0x8F, 0xB1, 0x30, 0xE0, 0x02, 0x31, 0xE3,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x94, 0x3E,
-0xEF, 0xF0, 0x90, 0x04, 0x7E, 0xE0, 0xFF, 0xA3,
-0xE0, 0x90, 0x94, 0x4E, 0xF0, 0xE0, 0xFE, 0x6F,
-0x60, 0x65, 0x90, 0x94, 0x3F, 0x74, 0x03, 0xF0,
-0x90, 0x94, 0x4D, 0x74, 0x08, 0xF0, 0xEE, 0x04,
-0x54, 0x0F, 0xFF, 0xE4, 0xFE, 0xEF, 0x75, 0xF0,
-0x08, 0xA4, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34,
-0x80, 0xF5, 0x83, 0xE5, 0x82, 0x2E, 0x11, 0xF2,
-0xE0, 0xFD, 0x74, 0x41, 0x2E, 0xF5, 0x82, 0xE4,
-0x34, 0x94, 0xF5, 0x83, 0xED, 0xF0, 0x0E, 0xEE,
-0xB4, 0x08, 0xDA, 0x7B, 0x01, 0x7A, 0x94, 0x79,
-0x3F, 0x12, 0x5E, 0x10, 0x90, 0x94, 0x4E, 0xE0,
-0x04, 0x54, 0x0F, 0xFF, 0xF0, 0xBF, 0x0F, 0x02,
-0xE4, 0xF0, 0x90, 0x94, 0x4E, 0xE0, 0x90, 0x04,
-0x7F, 0xF0, 0x90, 0x94, 0x3E, 0xE0, 0x7F, 0x04,
-0x70, 0x02, 0x80, 0x21, 0x12, 0x87, 0xDB, 0x22,
-0xE4, 0xFF, 0x80, 0x81, 0xE0, 0x04, 0xF0, 0xE0,
-0x7F, 0x00, 0x22, 0xE4, 0xFD, 0x7F, 0x8D, 0x02,
-0x7B, 0x3E, 0x54, 0x07, 0xFF, 0x74, 0x01, 0x7E,
-0x00, 0xA8, 0x07, 0x08, 0x22, 0x8F, 0x0D, 0x7F,
-0x02, 0x12, 0x86, 0x27, 0x90, 0x84, 0xC1, 0xE0,
-0x45, 0x0D, 0xF0, 0x22, 0x12, 0x40, 0xB9, 0x7F,
-0x02, 0x80, 0xEA, 0x90, 0x92, 0x03, 0xE0, 0x30,
-0xE0, 0x04, 0x7F, 0x20, 0x31, 0xF5, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x92,
-0x3F, 0xE0, 0xFE, 0x13, 0x13, 0x54, 0x3F, 0x30,
-0xE0, 0x1E, 0x90, 0x94, 0x9D, 0x74, 0x1E, 0xF0,
-0x90, 0x94, 0xAB, 0x74, 0x01, 0xF0, 0x90, 0x94,
-0x9F, 0xEF, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79,
-0x9D, 0x12, 0x5E, 0x10, 0x7F, 0x04, 0x31, 0xF5,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0xA6, 0x61,
-0xB1, 0x49, 0x7F, 0x01, 0x80, 0xC1, 0xC0, 0xE0,
-0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0,
-0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0,
-0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x56,
-0xF0, 0x74, 0xB2, 0xA3, 0xF0, 0x12, 0x75, 0x28,
-0xE5, 0x56, 0x30, 0xE1, 0x03, 0x12, 0xA5, 0xC7,
-0xE5, 0x56, 0x30, 0xE2, 0x02, 0x51, 0xE6, 0xE5,
-0x56, 0x30, 0xE4, 0x02, 0x51, 0xE1, 0xE5, 0x57,
-0x30, 0xE0, 0x02, 0x91, 0x07, 0xE5, 0x59, 0x30,
-0xE1, 0x04, 0x7F, 0x04, 0x31, 0xF5, 0xE5, 0x59,
-0x30, 0xE4, 0x02, 0x51, 0x4D, 0xE5, 0x59, 0x30,
-0xE5, 0x02, 0x71, 0x24, 0xE5, 0x59, 0x30, 0xE6,
-0x02, 0x71, 0x54, 0x74, 0x56, 0x04, 0x90, 0x01,
-0xC4, 0xF0, 0x74, 0xB2, 0xA3, 0xF0, 0xD0, 0x07,
-0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0,
-0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0,
-0x32, 0xF1, 0x06, 0x02, 0x5F, 0xE9, 0x90, 0x85,
-0xC5, 0xE0, 0x60, 0x10, 0x90, 0x06, 0x92, 0xE0,
-0x30, 0xE1, 0x05, 0x12, 0x6B, 0x98, 0x80, 0x04,
-0xD1, 0xFE, 0x71, 0x4A, 0x90, 0x89, 0x16, 0xE0,
-0xFF, 0x12, 0x8C, 0xB8, 0x30, 0xE0, 0x1C, 0xEF,
-0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x03, 0x12, 0xBE,
-0xE2, 0x90, 0x89, 0x17, 0xE0, 0x30, 0xE0, 0x0B,
-0x12, 0xC5, 0x55, 0x20, 0xE0, 0x02, 0x7D, 0x01,
-0x12, 0x54, 0x9F, 0x22, 0x90, 0x85, 0xC1, 0xE0,
-0xFF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0,
-0x18, 0xEF, 0x54, 0xBF, 0x71, 0x7D, 0x30, 0xE0,
-0x06, 0xE0, 0x44, 0x01, 0xF0, 0x80, 0x08, 0xE0,
-0x54, 0xFE, 0x71, 0x86, 0x74, 0x04, 0xF0, 0x71,
-0x4A, 0x22, 0x90, 0x85, 0xC7, 0xE0, 0xFF, 0x7D,
-0x01, 0x02, 0x8C, 0xCC, 0x90, 0x85, 0xC1, 0xE0,
-0xFF, 0x12, 0x8C, 0xB8, 0x30, 0xE0, 0x1D, 0xEF,
-0x54, 0x7F, 0x71, 0x7D, 0x30, 0xE1, 0x06, 0xE0,
-0x44, 0x02, 0xF0, 0x80, 0x07, 0xE0, 0x54, 0xFD,
-0x71, 0x86, 0x04, 0xF0, 0x90, 0x85, 0xC5, 0xE0,
-0x60, 0x02, 0x71, 0x4A, 0x22, 0xF0, 0x90, 0x04,
-0xE0, 0xE0, 0x90, 0x85, 0xC2, 0x22, 0xF0, 0x90,
-0x01, 0xB9, 0x74, 0x01, 0xF0, 0x90, 0x01, 0xB8,
-0x22, 0xE4, 0xFF, 0x12, 0x77, 0x39, 0xBF, 0x01,
-0x0F, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x09, 0x71,
-0xA9, 0xF0, 0x54, 0x07, 0x70, 0x02, 0x71, 0x4A,
-0x22, 0x90, 0x85, 0xC9, 0xE0, 0x54, 0xFE, 0x22,
-0xE4, 0xF5, 0x74, 0x90, 0x06, 0xA9, 0xE0, 0xF5,
-0x74, 0x54, 0xC0, 0x70, 0x08, 0x71, 0xA9, 0xF0,
-0x54, 0xFD, 0xF0, 0x80, 0x85, 0xE5, 0x74, 0x30,
-0xE6, 0x1F, 0x90, 0x85, 0xC5, 0xE0, 0x64, 0x01,
-0x70, 0x1A, 0x90, 0x85, 0xC9, 0xE0, 0x44, 0x01,
-0x12, 0x8F, 0xD2, 0x64, 0x02, 0x60, 0x05, 0x12,
-0x77, 0x61, 0x80, 0x08, 0x12, 0x79, 0x41, 0x80,
-0x03, 0x71, 0xA9, 0xF0, 0xE5, 0x74, 0x90, 0x85,
-0xC9, 0x30, 0xE7, 0x0E, 0xE0, 0x44, 0x02, 0x12,
-0xA4, 0x14, 0x90, 0x85, 0xC1, 0xE0, 0x44, 0x04,
-0xF0, 0x22, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x12,
-0xC0, 0x1E, 0x90, 0x94, 0x4F, 0xEF, 0xF0, 0x30,
-0xE0, 0x05, 0x7D, 0x01, 0xE4, 0x80, 0x02, 0xE4,
-0xFD, 0xFF, 0x12, 0x57, 0x82, 0x90, 0x94, 0x4F,
-0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01, 0x2F, 0xE0,
-0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80, 0x06, 0x90,
-0x01, 0x2F, 0x74, 0x80, 0xF0, 0xD1, 0xD9, 0x02,
-0x51, 0x7D, 0x12, 0xA6, 0x48, 0x60, 0x02, 0xA1,
-0x2C, 0x90, 0x85, 0xC5, 0xE0, 0x70, 0x02, 0xA1,
-0x2C, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x92, 0x44,
-0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x92, 0x45,
-0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x92, 0x46,
-0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x92, 0x47,
-0xF0, 0xF1, 0xE8, 0xF0, 0x90, 0x85, 0xC9, 0xE0,
-0x54, 0xEC, 0xF0, 0xB1, 0x35, 0x24, 0xFD, 0x50,
-0x02, 0x80, 0x02, 0x71, 0xB0, 0xB1, 0x35, 0x64,
-0x01, 0x70, 0x30, 0x90, 0x06, 0xAB, 0xE0, 0x90,
-0x85, 0xCC, 0xF0, 0x90, 0x06, 0xA9, 0xE0, 0x30,
-0xE5, 0x05, 0xA3, 0xE0, 0xFF, 0x80, 0x05, 0x90,
-0x85, 0xCB, 0xE0, 0xFF, 0x90, 0x85, 0xCB, 0xEF,
-0xF0, 0xA3, 0xE0, 0xFF, 0x70, 0x08, 0x90, 0x85,
-0xCB, 0xE0, 0xFE, 0xFF, 0x80, 0x00, 0x90, 0x85,
-0xCC, 0xEF, 0xF0, 0xB1, 0x50, 0xE4, 0x90, 0x85,
-0xCE, 0xF0, 0xF1, 0x19, 0x90, 0x85, 0xC2, 0x12,
-0xA5, 0xBF, 0x30, 0xE0, 0x60, 0xEF, 0xC4, 0x13,
-0x13, 0x54, 0x03, 0x20, 0xE0, 0x27, 0xB1, 0x2D,
-0x6F, 0x70, 0x52, 0xEF, 0x60, 0x4F, 0x90, 0x85,
-0xC2, 0xE0, 0x44, 0x40, 0xF0, 0xD1, 0xF6, 0xB1,
-0x3E, 0x12, 0x7B, 0xFD, 0xD1, 0xE7, 0x7D, 0x02,
-0x7F, 0x02, 0x12, 0x7C, 0x41, 0x90, 0x85, 0xCC,
-0xE0, 0x14, 0xF0, 0x80, 0x30, 0x90, 0x85, 0xC3,
-0xE0, 0xC4, 0x54, 0x0F, 0x64, 0x01, 0x70, 0x25,
-0xB1, 0x2D, 0xFE, 0x6F, 0x60, 0x1F, 0x90, 0x05,
-0x73, 0xE0, 0xFF, 0xEE, 0x6F, 0x60, 0x16, 0xF1,
-0x0F, 0x30, 0xE0, 0x11, 0xEF, 0x54, 0xBF, 0xB1,
-0x3E, 0x12, 0x7B, 0xBF, 0x7D, 0x01, 0x7F, 0x02,
-0x12, 0x7C, 0xA9, 0xB1, 0x49, 0x90, 0x85, 0xC2,
-0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90, 0x85, 0xCB,
-0xE0, 0xFF, 0xA3, 0xE0, 0x22, 0x90, 0x85, 0xC3,
-0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x22, 0xF0, 0x90,
-0x01, 0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F, 0x03,
-0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C, 0xA9,
-0xE4, 0x90, 0x94, 0x3E, 0xF0, 0xA3, 0xF0, 0xA3,
-0xF0, 0x90, 0x92, 0x48, 0x12, 0x86, 0xDE, 0x90,
-0x92, 0x44, 0x12, 0x86, 0xEA, 0xC3, 0x12, 0x04,
-0xB4, 0x40, 0x46, 0x90, 0x85, 0xC1, 0xE0, 0x90,
-0x92, 0x48, 0x30, 0xE0, 0x0F, 0xD1, 0xBB, 0x90,
-0x85, 0xFB, 0xE0, 0x24, 0x04, 0x2F, 0xFF, 0x90,
-0x92, 0x79, 0x80, 0x05, 0xD1, 0xBB, 0x90, 0x92,
-0x7A, 0xE0, 0xFE, 0xC3, 0xEF, 0x9E, 0x90, 0x94,
-0x3F, 0xF0, 0x90, 0x94, 0x3F, 0xE0, 0xFF, 0xC3,
-0x94, 0x2D, 0x50, 0x15, 0x74, 0x4C, 0x2F, 0xD1,
-0xEE, 0xE0, 0x04, 0xF0, 0x90, 0x85, 0xDB, 0xE0,
-0x04, 0xF0, 0xE0, 0xFD, 0x7F, 0xFE, 0x12, 0x7B,
-0x3E, 0x90, 0x85, 0xDB, 0xE0, 0xFF, 0xD3, 0x90,
-0x92, 0x7C, 0xE0, 0x9F, 0x90, 0x92, 0x7B, 0xE0,
-0x94, 0x00, 0x40, 0x02, 0xC1, 0x87, 0xD1, 0x99,
-0xD1, 0x90, 0x50, 0x1C, 0xD1, 0xA3, 0x90, 0x94,
-0x40, 0xE0, 0xD3, 0x9F, 0x40, 0x0A, 0x90, 0x94,
-0x3E, 0xE0, 0x90, 0x94, 0x41, 0xF0, 0x80, 0x08,
-0x90, 0x94, 0x3E, 0xE0, 0x04, 0xF0, 0x80, 0xE0,
-0xD1, 0x99, 0xD1, 0x90, 0x50, 0x2C, 0xD1, 0xA3,
-0xC3, 0x90, 0x92, 0x7C, 0xE0, 0x9F, 0xFF, 0x90,
-0x92, 0x7B, 0xE0, 0x94, 0x00, 0xFE, 0x90, 0x94,
-0x40, 0xE0, 0xD3, 0x9F, 0xE4, 0x9E, 0x40, 0x0A,
-0x90, 0x94, 0x3E, 0xE0, 0x90, 0x94, 0x42, 0xF0,
-0x80, 0x08, 0x90, 0x94, 0x3E, 0xE0, 0x04, 0xF0,
-0x80, 0xD0, 0x90, 0x94, 0x41, 0xE0, 0x90, 0x85,
-0xE0, 0xF0, 0x90, 0x94, 0x42, 0xE0, 0x90, 0x85,
-0xE1, 0xD1, 0x88, 0x94, 0x0A, 0x40, 0x0A, 0xEF,
-0x24, 0xF6, 0x90, 0x85, 0xD8, 0xF0, 0xE4, 0x80,
-0x09, 0xE4, 0x90, 0x85, 0xD8, 0xD1, 0x88, 0x74,
-0x0A, 0x9F, 0x90, 0x85, 0xD7, 0xF0, 0x90, 0x85,
-0xE0, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90,
-0x85, 0xDE, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x30,
-0xE0, 0x05, 0x90, 0x92, 0x79, 0x80, 0x03, 0x90,
-0x92, 0x7A, 0xE0, 0xFF, 0x90, 0x85, 0xDE, 0xE0,
-0x2F, 0x04, 0xF0, 0x90, 0x85, 0xDE, 0xE0, 0xC3,
-0x94, 0x0A, 0x50, 0x03, 0x74, 0x0A, 0xF0, 0x90,
-0x85, 0xDE, 0xE0, 0x24, 0x02, 0xD1, 0xD8, 0x12,
-0x51, 0x7D, 0xE4, 0xFF, 0x12, 0x69, 0x33, 0x22,
-0xF0, 0x90, 0x85, 0xE0, 0xE0, 0xFF, 0xC3, 0x22,
-0x90, 0x94, 0x3E, 0xE0, 0xFF, 0xC3, 0x94, 0x2D,
-0x22, 0xE4, 0x90, 0x94, 0x40, 0xF0, 0x90, 0x94,
-0x3E, 0xF0, 0x22, 0x74, 0x4C, 0x2F, 0xF5, 0x82,
-0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0xFF, 0x90,
-0x94, 0x40, 0xE0, 0x2F, 0xF0, 0x90, 0x92, 0x7D,
-0xE0, 0xFF, 0x22, 0x12, 0x86, 0xEA, 0x90, 0x92,
-0x44, 0x12, 0x86, 0xDE, 0x12, 0x86, 0xB6, 0x78,
-0x0A, 0x12, 0x04, 0xC5, 0x90, 0x85, 0xDD, 0xE0,
-0xFE, 0xC3, 0x74, 0x0A, 0x9E, 0x2F, 0xFF, 0x22,
-0xF0, 0x90, 0x85, 0xD7, 0xE0, 0xFF, 0xA3, 0xE0,
-0xFD, 0x90, 0x85, 0xDE, 0xE0, 0xFB, 0x22, 0x7D,
-0x01, 0x7F, 0x02, 0x02, 0x7C, 0x41, 0xF5, 0x82,
-0xE4, 0x34, 0x92, 0xF5, 0x83, 0x22, 0x90, 0x85,
-0xCB, 0xE0, 0x90, 0x05, 0x73, 0x22, 0x90, 0x85,
-0xC1, 0xE0, 0x54, 0xF7, 0xF0, 0x22, 0x90, 0x01,
-0xC7, 0x74, 0x66, 0xF0, 0xE4, 0xFF, 0x22, 0x90,
-0x85, 0xC2, 0xE0, 0xFF, 0x13, 0x13, 0x54, 0x3F,
-0x22, 0x90, 0x85, 0xD1, 0xA3, 0xE0, 0x90, 0x05,
-0x58, 0xF0, 0x22, 0xAC, 0x07, 0x90, 0x92, 0x3F,
-0xE0, 0xF9, 0x30, 0xE0, 0x02, 0xE1, 0xD5, 0x90,
-0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x16, 0x90, 0x85,
-0xFB, 0xE0, 0x24, 0x04, 0x90, 0x85, 0xDA, 0xF0,
-0x90, 0x85, 0xFB, 0xE0, 0x24, 0x03, 0x90, 0x85,
-0xD9, 0xF0, 0x80, 0x0D, 0x90, 0x85, 0xDA, 0x74,
-0x02, 0xF0, 0x90, 0x85, 0xD9, 0x14, 0xF0, 0x0B,
-0x0B, 0x90, 0x85, 0xD9, 0xE0, 0xFA, 0x90, 0x85,
-0xD8, 0xE0, 0xD3, 0x9A, 0x50, 0x0E, 0x90, 0x85,
-0xCD, 0xEB, 0xF0, 0x90, 0x85, 0xDA, 0xE0, 0xC3,
-0x9D, 0x2C, 0x80, 0x11, 0xC3, 0xED, 0x9A, 0x2B,
-0x90, 0x85, 0xCD, 0xF0, 0x90, 0x85, 0xD9, 0xE0,
-0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x85, 0xDD,
-0xF0, 0x90, 0x85, 0xDA, 0xE0, 0xFF, 0x24, 0x0A,
-0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x85, 0xDD, 0xF1,
-0xDD, 0x40, 0x04, 0xEF, 0x24, 0x0A, 0xF0, 0x90,
-0x85, 0xDD, 0xE0, 0xFF, 0x24, 0x23, 0xFD, 0xE4,
-0x33, 0xFC, 0x90, 0x85, 0xCD, 0xF1, 0xDD, 0x40,
-0x04, 0xEF, 0x24, 0x23, 0xF0, 0x90, 0x85, 0xDD,
-0xE0, 0xFF, 0x7E, 0x00, 0x90, 0x85, 0xD1, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x05, 0x58, 0xE0,
-0x6F, 0x70, 0x01, 0xE4, 0x60, 0x02, 0xF1, 0x19,
-0xE9, 0x54, 0xFD, 0x80, 0x03, 0xE9, 0x44, 0x02,
-0x90, 0x92, 0x3F, 0xF0, 0x22, 0xE0, 0xD3, 0x9D,
-0xEC, 0x64, 0x80, 0xF8, 0x74, 0x80, 0x98, 0x22,
-0x90, 0x01, 0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C,
-0x74, 0x02, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x85, 0x1E, 0xE0, 0xFF, 0x90,
-0x85, 0x1D, 0xE0, 0xB5, 0x07, 0x04, 0x7F, 0x01,
-0x80, 0x02, 0x7F, 0x00, 0xEF, 0x70, 0x48, 0x90,
-0x85, 0x1D, 0xE0, 0xFE, 0x75, 0xF0, 0x08, 0x90,
-0x84, 0xCD, 0x12, 0x05, 0x28, 0xE0, 0xFD, 0xEE,
-0x75, 0xF0, 0x08, 0xA4, 0x24, 0xCE, 0xF9, 0x74,
-0x84, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0xAF, 0x05,
-0x12, 0x89, 0x08, 0x90, 0x85, 0x1D, 0x12, 0xB1,
-0xDC, 0xB4, 0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x60,
-0x05, 0xE4, 0x90, 0x85, 0x1D, 0xF0, 0x7D, 0x68,
-0x7F, 0xFE, 0x12, 0x7B, 0x3E, 0x12, 0x40, 0xB9,
-0x90, 0x84, 0xC1, 0xE0, 0x44, 0x02, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x85, 0xB5, 0xE0,
-0xFF, 0x70, 0x06, 0xA3, 0xE0, 0x64, 0x09, 0x60,
-0x0A, 0xEF, 0x14, 0xFF, 0x90, 0x85, 0xB6, 0xE0,
-0xB5, 0x07, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F,
-0x00, 0xEF, 0x60, 0x08, 0x90, 0x01, 0xC1, 0xE0,
-0x44, 0x02, 0xF0, 0x22, 0xC0, 0x01, 0x90, 0x85,
-0xB6, 0xE0, 0x75, 0xF0, 0x0F, 0xA4, 0x24, 0x1F,
-0xF9, 0x74, 0x85, 0x35, 0xF0, 0xA8, 0x01, 0xFC,
-0x7D, 0x01, 0xD0, 0x01, 0x7E, 0x00, 0x7F, 0x0F,
-0x12, 0x02, 0xD0, 0x7D, 0xCC, 0x7F, 0xFE, 0x12,
-0x7B, 0x3E, 0x90, 0x85, 0xB6, 0x12, 0xB1, 0xDC,
-0xB4, 0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x60, 0x05,
-0xE4, 0x90, 0x85, 0xB6, 0xF0, 0x22, 0xE4, 0xFC,
-0xED, 0x2C, 0x24, 0x00, 0x11, 0xFC, 0xE4, 0xF0,
-0x0C, 0xEC, 0xB4, 0x18, 0xF3, 0x11, 0xF9, 0xEF,
-0xF0, 0xEE, 0x54, 0x3F, 0xFF, 0x31, 0x04, 0x31,
-0x0F, 0x54, 0xF0, 0xF0, 0x74, 0x03, 0x2D, 0xF5,
-0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x44,
-0x80, 0xF0, 0x74, 0x0B, 0x2D, 0xF5, 0x82, 0xE4,
-0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x44, 0x10, 0xF0,
-0x22, 0x74, 0x00, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
-0xFB, 0xF5, 0x83, 0x22, 0x74, 0x01, 0x2D, 0xF5,
-0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83, 0x22, 0xEF,
-0xF0, 0x74, 0x02, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
-0xFB, 0xF5, 0x83, 0xE0, 0x22, 0x75, 0x48, 0x12,
-0xE4, 0xF5, 0x49, 0x75, 0x4A, 0x87, 0x75, 0x4B,
-0x33, 0xF5, 0x50, 0x90, 0x01, 0x30, 0xE5, 0x48,
-0xF0, 0xA3, 0xE5, 0x49, 0xF0, 0xA3, 0xE5, 0x4A,
-0xF0, 0xA3, 0xE5, 0x4B, 0xF0, 0x90, 0x01, 0x20,
-0xE5, 0x50, 0xF0, 0x22, 0x75, 0x52, 0x06, 0x75,
-0x53, 0x01, 0x75, 0x54, 0x03, 0x75, 0x55, 0x62,
-0x90, 0x01, 0x38, 0xE5, 0x52, 0xF0, 0xA3, 0xE5,
-0x53, 0xF0, 0xA3, 0xE5, 0x54, 0xF0, 0xA3, 0xE5,
-0x55, 0xF0, 0x22, 0x7D, 0x02, 0x90, 0x01, 0xC4,
-0x74, 0x63, 0xF0, 0x74, 0xB9, 0xA3, 0xF0, 0x90,
-0x92, 0x30, 0xE0, 0xFF, 0xED, 0xC3, 0x9F, 0x50,
-0x18, 0xED, 0x25, 0xE0, 0x24, 0x81, 0xF8, 0xE6,
-0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8, 0x74, 0x08,
-0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22, 0x0D, 0x80,
-0xDE, 0x7F, 0x01, 0x22, 0xE4, 0x90, 0x93, 0x9F,
-0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x93, 0x9F,
-0xE0, 0x64, 0x01, 0xF0, 0x90, 0x92, 0x3C, 0xE0,
-0x70, 0x18, 0x90, 0x92, 0x39, 0xE0, 0x70, 0x12,
-0xA3, 0xE0, 0x70, 0x0E, 0x90, 0x93, 0x9F, 0xE0,
-0x24, 0x94, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xB9,
-0xA3, 0xF0, 0x12, 0x7C, 0x66, 0xBF, 0x01, 0x03,
-0x12, 0x5B, 0x25, 0x90, 0x85, 0xC5, 0xE0, 0x60,
-0x0F, 0x90, 0x85, 0xC8, 0xE0, 0xFF, 0x90, 0x85,
-0xC7, 0xE0, 0x6F, 0x60, 0x03, 0x12, 0xB3, 0x4A,
-0xC2, 0xAF, 0x31, 0x63, 0xBF, 0x01, 0x03, 0x12,
-0xAF, 0x6E, 0xD2, 0xAF, 0x31, 0xF6, 0x12, 0x8F,
-0xFA, 0x12, 0x84, 0x4D, 0x80, 0xA7, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x92, 0x39,
-0xE0, 0x60, 0x25, 0x7F, 0x54, 0x7E, 0x09, 0x12,
-0x70, 0x61, 0x51, 0x9E, 0xEF, 0x44, 0xFE, 0xFF,
-0xEE, 0x44, 0x03, 0xFE, 0xED, 0x44, 0x04, 0xFD,
-0xEC, 0x51, 0x9E, 0x90, 0x91, 0x66, 0x12, 0x04,
-0xEB, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x71, 0x18,
-0x90, 0x92, 0x34, 0xE0, 0x70, 0x24, 0x90, 0x07,
-0xCC, 0xE0, 0x30, 0xE0, 0x1D, 0xE4, 0xF0, 0x90,
-0x93, 0xA6, 0x74, 0x22, 0xF0, 0x90, 0x93, 0xB4,
-0x74, 0x01, 0xF0, 0x90, 0x93, 0xA8, 0x74, 0x03,
-0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xA6, 0x12,
-0x87, 0xD6, 0x90, 0x92, 0x3C, 0xE0, 0xFF, 0x70,
-0x0A, 0x90, 0x92, 0x39, 0xE0, 0x70, 0x04, 0xA3,
-0xE0, 0x60, 0x15, 0x90, 0x00, 0x1F, 0xE0, 0x54,
-0xF0, 0xF0, 0x90, 0x01, 0xC5, 0x74, 0xEA, 0xF0,
-0xA3, 0x74, 0xEF, 0xF0, 0xA3, 0x74, 0xFD, 0xF0,
-0xEF, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x07,
-0xF0, 0x90, 0x92, 0x39, 0xE0, 0x60, 0x06, 0x90,
-0x01, 0xC4, 0x74, 0x01, 0xF0, 0x90, 0x92, 0x3A,
-0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x02,
-0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93,
-0xA2, 0x12, 0x04, 0xEB, 0x90, 0x93, 0xA2, 0x02,
-0x86, 0xDE, 0xE4, 0xFB, 0xFA, 0xFD, 0x7F, 0x01,
-0x12, 0x86, 0x4E, 0x90, 0x93, 0xB5, 0xEF, 0xF0,
-0x60, 0xF0, 0x90, 0x84, 0xC1, 0xE0, 0xFF, 0x70,
-0x04, 0xA3, 0xE0, 0x60, 0xE5, 0xC2, 0xAF, 0xEF,
-0x30, 0xE0, 0x0F, 0x90, 0x84, 0xC1, 0xE0, 0x54,
-0xFE, 0xF0, 0xE4, 0xFF, 0x12, 0x2D, 0xBD, 0x12,
-0x91, 0x86, 0x71, 0x05, 0x30, 0xE1, 0x06, 0x54,
-0xFD, 0xF0, 0x12, 0x60, 0x5D, 0x71, 0x05, 0x30,
-0xE2, 0x06, 0x54, 0xFB, 0xF0, 0x12, 0x6A, 0x6D,
-0x71, 0x05, 0x30, 0xE5, 0x0C, 0x54, 0xDF, 0xF0,
-0x12, 0x6F, 0x22, 0xBF, 0x01, 0x03, 0x12, 0x99,
-0x0B, 0xD2, 0xAF, 0x80, 0xB5, 0xD2, 0xAF, 0xC2,
-0xAF, 0x90, 0x84, 0xC1, 0xE0, 0xFF, 0x22, 0x32,
-0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82,
-0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0,
-0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4,
-0x74, 0x10, 0xF0, 0x74, 0xBB, 0xA3, 0xF0, 0x12,
-0x6C, 0xBC, 0x74, 0x10, 0x04, 0x90, 0x01, 0xC4,
-0xF0, 0x74, 0xBB, 0xA3, 0xF0, 0xD0, 0x07, 0xD0,
-0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0,
-0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32,
-0x32, 0xC0, 0xE0, 0xC0, 0x83, 0xC0, 0x82, 0xC0,
-0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x05, 0xC0, 0x07,
-0x7D, 0x61, 0x90, 0x01, 0xC4, 0xED, 0xF0, 0x74,
-0xBB, 0xFF, 0xA3, 0xF0, 0xED, 0x04, 0x90, 0x01,
-0xC4, 0xF0, 0xA3, 0xEF, 0xF0, 0xD0, 0x07, 0xD0,
-0x05, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
-0xE0, 0x32, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x02,
-0x60, 0x03, 0x12, 0xB4, 0x3A, 0x22, 0xE4, 0xFF,
-0x12, 0x77, 0x39, 0xBF, 0x01, 0x13, 0x90, 0x85,
-0xC5, 0xE0, 0x60, 0x0D, 0x12, 0x8F, 0xD3, 0x64,
-0x02, 0x60, 0x03, 0x02, 0x77, 0x61, 0x12, 0x79,
-0x41, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x02,
-0x71, 0xC3, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x64,
-0x01, 0x70, 0x1E, 0x12, 0x8F, 0xD3, 0x60, 0x0C,
-0xE4, 0xFD, 0x7F, 0x0C, 0x12, 0x8C, 0xCC, 0x71,
-0xEA, 0x02, 0x6B, 0x98, 0x90, 0x85, 0xC8, 0xE0,
-0x70, 0x07, 0x7D, 0x01, 0x7F, 0x04, 0x12, 0x8C,
-0xCC, 0x22, 0xE4, 0xFD, 0xFF, 0x02, 0x9F, 0x6E,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12,
-0x9F, 0x7B, 0x7F, 0x02, 0x12, 0x7B, 0x51, 0xEF,
-0x54, 0xFE, 0xFD, 0x7F, 0x02, 0x12, 0x7B, 0x3E,
-0x90, 0x01, 0x00, 0x74, 0x3F, 0xF0, 0xA3, 0xE0,
-0x54, 0xFD, 0xF0, 0x90, 0x05, 0x53, 0xE0, 0x44,
-0x20, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
-0x05, 0x22, 0xED, 0xF0, 0x90, 0x92, 0x01, 0xEB,
-0xF0, 0x22, 0x12, 0x02, 0xF6, 0x90, 0x94, 0x64,
-0xF0, 0x22, 0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00,
-0x90, 0x89, 0x1B, 0x12, 0x86, 0xFF, 0x7B, 0xFF,
-0x7A, 0x82, 0x79, 0x00, 0x90, 0x89, 0x1E, 0x12,
-0x86, 0xFF, 0x7A, 0x82, 0x79, 0x3F, 0x90, 0x89,
-0x21, 0x12, 0x86, 0xFF, 0x7A, 0x82, 0x79, 0xE1,
-0x90, 0x89, 0x27, 0x12, 0x86, 0xFF, 0x7A, 0x82,
-0x79, 0xF5, 0x90, 0x89, 0x2A, 0x12, 0x86, 0xFF,
-0x7A, 0x83, 0x79, 0x1D, 0x90, 0x89, 0x2D, 0x12,
-0x86, 0xFF, 0x7A, 0x83, 0x79, 0x31, 0x90, 0x89,
-0x33, 0x12, 0x86, 0xFF, 0x7A, 0x83, 0x79, 0x59,
-0x90, 0x89, 0x36, 0x12, 0x86, 0xFF, 0x7A, 0x83,
-0x79, 0x81, 0x90, 0x89, 0x39, 0x12, 0x86, 0xFF,
-0xE4, 0x90, 0x94, 0x75, 0xF0, 0x90, 0x94, 0x64,
-0xF0, 0x90, 0x93, 0x71, 0xF0, 0x90, 0x93, 0x71,
-0xE0, 0xFF, 0xC3, 0x94, 0x05, 0x50, 0x10, 0x74,
-0x86, 0x2F, 0x12, 0x95, 0xD2, 0xE4, 0xF0, 0x90,
-0x93, 0x71, 0xE0, 0x04, 0xF0, 0x80, 0xE6, 0x22,
-0x90, 0x93, 0xC2, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
-0xA3, 0xED, 0xF0, 0xEB, 0x75, 0xF0, 0x06, 0xA4,
-0xFF, 0x90, 0x89, 0x21, 0x12, 0x86, 0xF6, 0xE9,
-0x2F, 0xF9, 0xEA, 0x35, 0xF0, 0xFA, 0x90, 0x93,
-0xCA, 0x12, 0x86, 0xFF, 0x90, 0x93, 0xC4, 0xE0,
-0xB1, 0x9C, 0xF5, 0x83, 0xE0, 0xFF, 0xA3, 0xE0,
-0x90, 0x93, 0xC7, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0,
-0xE4, 0xA3, 0xF0, 0x90, 0x93, 0xCA, 0x12, 0x86,
-0xF6, 0x90, 0x93, 0xC9, 0xE0, 0xFF, 0xF5, 0x82,
-0x12, 0x9E, 0x61, 0xFD, 0x7C, 0x00, 0x90, 0x93,
-0xC4, 0xE0, 0x75, 0xF0, 0x12, 0x90, 0x89, 0x44,
-0x12, 0x05, 0x28, 0x75, 0xF0, 0x02, 0xEF, 0x12,
-0x05, 0x28, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90,
-0x93, 0xC6, 0xE0, 0xFB, 0xEF, 0xA8, 0x03, 0x08,
-0x80, 0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8,
-0xF9, 0xB1, 0x94, 0xEE, 0x8F, 0xF0, 0x12, 0x07,
-0x0A, 0x90, 0x93, 0xC9, 0xE0, 0x04, 0xF0, 0xE0,
-0xB4, 0x05, 0xB0, 0x90, 0x93, 0xCA, 0x12, 0x86,
-0xF6, 0x90, 0x00, 0x05, 0x12, 0x03, 0x0F, 0xFD,
-0x7C, 0x00, 0x90, 0x93, 0xC6, 0xE0, 0xFF, 0x90,
-0x93, 0xC2, 0xE0, 0xFE, 0xA3, 0xE0, 0xA8, 0x07,
-0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
-0xD8, 0xF9, 0xB1, 0x94, 0x12, 0x96, 0xD7, 0x40,
-0x08, 0xED, 0x9F, 0xFF, 0xEC, 0x9E, 0xFE, 0x80,
-0x04, 0x7E, 0x00, 0x7F, 0x00, 0x90, 0x93, 0xC7,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93, 0xC7,
-0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x93, 0xC4,
-0xE0, 0x02, 0x95, 0xFC, 0xFF, 0x12, 0x03, 0x70,
-0x90, 0x93, 0xC7, 0x22, 0x25, 0xE0, 0x24, 0x7B,
-0xF5, 0x82, 0xE4, 0x34, 0x8F, 0x22, 0xAA, 0x07,
-0xA9, 0x05, 0xEA, 0x12, 0x91, 0x79, 0xE0, 0xF5,
-0x6D, 0x54, 0x7F, 0xF5, 0x6F, 0x75, 0xF0, 0x12,
-0xEA, 0x90, 0x89, 0x3D, 0x12, 0x05, 0x28, 0xE0,
-0x90, 0x93, 0xC3, 0xF0, 0x75, 0xF0, 0x12, 0xEA,
-0x12, 0x97, 0xCE, 0xFF, 0xEA, 0x12, 0x90, 0xED,
-0xE0, 0x54, 0x03, 0xF5, 0x6E, 0xE5, 0x6F, 0x90,
-0x83, 0x1D, 0x93, 0xFD, 0xEA, 0xB1, 0x9C, 0xF5,
-0x83, 0xE4, 0xF0, 0xA3, 0xED, 0xF0, 0x75, 0xF0,
-0x12, 0xEA, 0x12, 0x8B, 0x46, 0xFE, 0xC4, 0x54,
-0x03, 0x90, 0x93, 0xC2, 0xF0, 0x74, 0xCC, 0x2A,
-0xD1, 0x5F, 0xE5, 0x6F, 0xF0, 0x74, 0x4C, 0x2A,
-0xD1, 0x67, 0xE5, 0x6E, 0xF0, 0xE5, 0x6F, 0xD3,
-0x9F, 0x40, 0x04, 0x8F, 0x6F, 0x8F, 0x6D, 0x89,
-0x70, 0xE4, 0xFF, 0xEF, 0xC3, 0x95, 0x70, 0x50,
-0x33, 0xE5, 0x6D, 0x30, 0xE7, 0x09, 0x85, 0x6F,
-0x6D, 0x19, 0xE9, 0x70, 0x24, 0x80, 0x25, 0x90,
-0x93, 0xC3, 0xE0, 0xFD, 0xE5, 0x6F, 0xD3, 0x9D,
-0x40, 0x0F, 0xAB, 0x02, 0x90, 0x93, 0xC7, 0xE9,
-0xF0, 0xAF, 0x6F, 0xD1, 0x6F, 0x8F, 0x6D, 0x80,
-0x0B, 0x90, 0x93, 0xC3, 0xE0, 0xF5, 0x6D, 0x80,
-0x03, 0x0F, 0x80, 0xC7, 0xAF, 0x02, 0x90, 0x91,
-0x0B, 0xE5, 0x6E, 0xF0, 0xE4, 0xFB, 0xAD, 0x6D,
-0x02, 0x27, 0x3D, 0x74, 0xCC, 0x25, 0x6D, 0xF5,
-0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0x22, 0xE4,
-0xF5, 0x72, 0xEF, 0x14, 0xF5, 0x71, 0xED, 0xFF,
-0xE5, 0x71, 0xF5, 0x82, 0x33, 0x95, 0xE0, 0xF5,
-0x83, 0xC3, 0xE5, 0x82, 0x9F, 0x74, 0x80, 0xF8,
-0x65, 0x83, 0x98, 0x40, 0x52, 0xE5, 0x71, 0x78,
-0x03, 0xA2, 0xE7, 0x13, 0xD8, 0xFB, 0xFF, 0x33,
-0x95, 0xE0, 0xFE, 0xEB, 0x12, 0x8F, 0xFC, 0xE5,
-0x82, 0x2F, 0xF5, 0x82, 0xE5, 0x83, 0x3E, 0xF5,
-0x83, 0xE0, 0xF5, 0x82, 0x75, 0x83, 0x00, 0xE5,
-0x71, 0x12, 0xB1, 0xEA, 0x80, 0x05, 0xC3, 0x33,
-0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEE, 0x55,
-0x83, 0xFE, 0xEF, 0x55, 0x82, 0x4E, 0x60, 0x13,
-0x85, 0x71, 0x73, 0x05, 0x72, 0x90, 0x93, 0xC7,
-0xE0, 0x65, 0x72, 0x60, 0x0A, 0xE5, 0x73, 0xD3,
-0x9D, 0x40, 0x04, 0x15, 0x71, 0x80, 0x97, 0xAF,
-0x73, 0x22, 0xE4, 0x90, 0x94, 0x51, 0xF0, 0x90,
-0x94, 0x4F, 0x74, 0x14, 0xF0, 0x90, 0x94, 0x5D,
-0x74, 0x01, 0xF0, 0xFB, 0x7A, 0x94, 0x79, 0x4F,
-0x12, 0x5E, 0x10, 0x7F, 0x04, 0x02, 0x87, 0xDB,
-0x90, 0x01, 0x9A, 0xE0, 0x54, 0xC0, 0x44, 0x0B,
-0xF0, 0x7F, 0x0A, 0x7E, 0x00, 0x12, 0x7C, 0x9F,
-0x90, 0x01, 0x98, 0xE0, 0x54, 0xC0, 0x7F, 0x00,
-0xB4, 0x40, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x01,
-0x98, 0xE4, 0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x11,
-0xF0, 0xA3, 0xE4, 0xF0, 0x7F, 0x0A, 0xFE, 0x12,
-0x7C, 0x9F, 0x90, 0x01, 0x99, 0xE0, 0x54, 0x30,
-0xFF, 0x64, 0x10, 0x60, 0x04, 0xEF, 0xB4, 0x20,
-0x03, 0x7F, 0x01, 0x22, 0x7F, 0x00, 0x22, 0x90,
-0x01, 0xCF, 0xE0, 0x90, 0x94, 0x3E, 0xF0, 0xE0,
-0xFF, 0x30, 0xE0, 0x07, 0x90, 0x01, 0xCF, 0xE0,
-0x54, 0xFE, 0xF0, 0xEF, 0x30, 0xE5, 0x23, 0x90,
-0x01, 0xCF, 0xE0, 0x54, 0xDF, 0xF0, 0x90, 0x01,
-0x34, 0x74, 0x20, 0xF0, 0xE4, 0xF5, 0xA8, 0xF5,
-0xE8, 0x12, 0x75, 0xB6, 0x90, 0x00, 0x03, 0xE0,
-0x54, 0xFB, 0xFD, 0x7F, 0x03, 0x12, 0x7B, 0x3E,
-0x80, 0xFE, 0x22, 0xE4, 0xF5, 0x74, 0xF5, 0x75,
-0xF5, 0x76, 0xF1, 0x93, 0xFF, 0xBF, 0x03, 0x02,
-0xF1, 0x9A, 0x22, 0x90, 0x01, 0x02, 0xE0, 0x54,
-0x03, 0x22, 0x90, 0x05, 0x21, 0xE0, 0x54, 0x7F,
-0xF0, 0x22, 0xF1, 0x93, 0xFF, 0xBF, 0x03, 0x02,
-0xF1, 0x9A, 0x22, 0xE4, 0xFF, 0x02, 0x2D, 0xBD,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x94, 0x8B, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12,
-0x70, 0x61, 0x90, 0x94, 0x95, 0x12, 0x04, 0xEB,
-0x90, 0x94, 0x8D, 0x12, 0x86, 0xDE, 0x12, 0x04,
-0xA7, 0x90, 0x94, 0x95, 0x12, 0x86, 0xEA, 0x12,
-0x86, 0xC4, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x94, 0x8D, 0x12, 0x86, 0xDE,
-0x90, 0x94, 0x91, 0x12, 0x86, 0xEA, 0x12, 0x86,
-0xC4, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x86, 0xD1, 0x90, 0x94, 0x99, 0x12,
-0x04, 0xEB, 0x90, 0x94, 0x99, 0x12, 0x86, 0xDE,
-0x90, 0x91, 0x66, 0x12, 0x04, 0xEB, 0x90, 0x94,
-0x8B, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x12, 0x71,
-0x18, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4, 0x90,
-0x94, 0x51, 0xF0, 0xA3, 0xF0, 0x7F, 0x83, 0x12,
-0x7B, 0x51, 0x90, 0x94, 0x50, 0xEF, 0xF0, 0x7F,
-0x83, 0x12, 0x7B, 0x51, 0xAE, 0x07, 0x90, 0x94,
-0x50, 0xE0, 0xFF, 0xB5, 0x06, 0x01, 0x22, 0xC3,
-0x90, 0x94, 0x52, 0xE0, 0x94, 0x64, 0x90, 0x94,
-0x51, 0xE0, 0x94, 0x00, 0x40, 0x0D, 0x90, 0x01,
-0xC0, 0xE0, 0x44, 0x40, 0xF0, 0x90, 0x94, 0x50,
-0xE0, 0xFF, 0x22, 0x90, 0x94, 0x51, 0x12, 0xAD,
-0xF4, 0x80, 0xC2, 0x90, 0x01, 0xC4, 0x74, 0x63,
-0xF0, 0x74, 0xC0, 0xA3, 0xF0, 0x7F, 0x90, 0x12,
-0x7B, 0x51, 0xEF, 0x20, 0xE0, 0xF7, 0x74, 0x63,
-0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xC0, 0xA3,
-0xF0, 0x22, 0x12, 0x98, 0xFA, 0x90, 0x85, 0xB7,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x02, 0x86, 0xE0,
-0x44, 0x04, 0xF0, 0x90, 0x92, 0x03, 0xE0, 0x44,
-0x01, 0xF0, 0x7D, 0x08, 0xE4, 0xFF, 0x12, 0x7C,
-0xA9, 0x90, 0x05, 0x52, 0xE0, 0x54, 0x07, 0x04,
-0x90, 0x92, 0x0E, 0x12, 0xAE, 0x95, 0x90, 0x04,
-0x22, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0x90, 0x92,
-0x03, 0xE0, 0x54, 0xFE, 0xF0, 0x7D, 0x08, 0xE4,
-0xFF, 0x12, 0x7C, 0x41, 0xE4, 0x90, 0x92, 0x0F,
-0xF0, 0xA3, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x94, 0x5E, 0xEF, 0xF0,
-0xA3, 0xED, 0xF0, 0x90, 0x84, 0xC3, 0xE0, 0x04,
-0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x2B, 0x90,
-0x05, 0x22, 0xE0, 0x90, 0x94, 0x62, 0xF0, 0x7D,
-0x26, 0x7F, 0xFF, 0x12, 0x9F, 0x79, 0xEF, 0x64,
-0x01, 0x70, 0x09, 0x31, 0x45, 0x7D, 0x01, 0x12,
-0x3A, 0xC2, 0x31, 0x50, 0x90, 0x94, 0x62, 0xE0,
-0xFF, 0x7D, 0x27, 0x12, 0x9F, 0x6E, 0x31, 0x3D,
-0x80, 0x11, 0x31, 0x3D, 0x31, 0x45, 0x90, 0x94,
-0xCC, 0x74, 0x0A, 0xF0, 0x7D, 0x01, 0x12, 0x9E,
-0x67, 0x31, 0x50, 0x12, 0x9F, 0xD1, 0x90, 0x84,
-0xBF, 0xA3, 0xE0, 0x24, 0x7F, 0xF5, 0x82, 0xE4,
-0x34, 0x82, 0xF5, 0x83, 0x74, 0x01, 0xF0, 0xFF,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x94, 0x5E,
-0xE0, 0xFF, 0x02, 0x5C, 0xA3, 0x90, 0x84, 0xC8,
-0xE0, 0xFF, 0x90, 0x94, 0x5F, 0xE0, 0xFB, 0x22,
-0x90, 0x94, 0x60, 0xEE, 0xF0, 0xFC, 0xA3, 0xEF,
-0xF0, 0xFD, 0x90, 0x94, 0x5E, 0xE0, 0xFF, 0x12,
-0x65, 0x61, 0x90, 0x94, 0x60, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0x02, 0x50, 0xD7, 0x90, 0x94, 0xD6,
-0x12, 0x86, 0xFF, 0x12, 0x71, 0x54, 0x90, 0x85,
-0xC5, 0xE0, 0xFF, 0x12, 0x60, 0xD0, 0x90, 0x85,
-0xC5, 0xE0, 0x60, 0x16, 0x90, 0x94, 0xD6, 0x12,
-0x8E, 0x89, 0x54, 0x0F, 0xFF, 0x12, 0x8C, 0xAE,
-0xFD, 0x12, 0x6A, 0xB8, 0x12, 0xB6, 0xD9, 0x12,
-0x51, 0x7D, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x12, 0x7A, 0x29, 0xEF, 0x64, 0x01,
-0x60, 0x05, 0x75, 0x0F, 0x01, 0x80, 0x75, 0x90,
-0x85, 0xC9, 0xE0, 0xFF, 0x54, 0x03, 0x60, 0x05,
-0x75, 0x0F, 0x02, 0x80, 0x67, 0x90, 0x85, 0xC7,
-0xE0, 0xFE, 0xE4, 0xC3, 0x9E, 0x50, 0x05, 0x75,
-0x0F, 0x04, 0x80, 0x58, 0xEF, 0x30, 0xE2, 0x05,
-0x75, 0x0F, 0x08, 0x80, 0x4F, 0x90, 0x85, 0xC9,
-0xE0, 0x30, 0xE4, 0x05, 0x75, 0x0F, 0x10, 0x80,
-0x43, 0x90, 0x85, 0xC2, 0xE0, 0x13, 0x13, 0x54,
-0x3F, 0x20, 0xE0, 0x05, 0x75, 0x0F, 0x20, 0x80,
-0x33, 0x90, 0x86, 0x71, 0xE0, 0x60, 0x05, 0x75,
-0x0F, 0x80, 0x80, 0x28, 0x90, 0x06, 0x62, 0xE0,
-0x30, 0xE1, 0x05, 0x75, 0x0F, 0x11, 0x80, 0x1C,
-0x90, 0x06, 0x62, 0xE0, 0x30, 0xE0, 0x0C, 0xE0,
-0x54, 0xFC, 0xFF, 0xBF, 0x80, 0x05, 0x75, 0x0F,
-0x12, 0x80, 0x09, 0x90, 0x01, 0xB8, 0xE4, 0xF0,
-0x7F, 0x01, 0x80, 0x0E, 0x90, 0x01, 0xB9, 0x74,
-0x04, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x0F, 0xF0,
-0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
-0x02, 0x87, 0xE0, 0x60, 0x02, 0x80, 0x08, 0x90,
-0x01, 0x00, 0xE0, 0x64, 0x3F, 0x60, 0x05, 0x75,
-0x61, 0x01, 0x80, 0x28, 0x90, 0x02, 0x96, 0xE0,
-0x60, 0x05, 0x75, 0x61, 0x10, 0x80, 0x1D, 0x90,
-0x02, 0x86, 0xE0, 0x20, 0xE1, 0x02, 0x80, 0x07,
-0x90, 0x02, 0x86, 0xE0, 0x30, 0xE3, 0x05, 0x75,
-0x61, 0x04, 0x80, 0x08, 0x90, 0x01, 0xB8, 0xE4,
-0xF0, 0x7F, 0x01, 0x22, 0x90, 0x01, 0xB9, 0x74,
-0x08, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x61, 0xF0,
-0x7F, 0x00, 0x22, 0x51, 0xB4, 0x9F, 0x40, 0x2B,
-0x90, 0x85, 0xDF, 0xE0, 0x04, 0xF0, 0x90, 0x92,
-0x7E, 0xE0, 0xFF, 0x90, 0x85, 0xDF, 0xE0, 0xD3,
-0x9F, 0x50, 0x18, 0x90, 0x85, 0xD7, 0xE0, 0x04,
-0x12, 0xA4, 0x8A, 0x90, 0x85, 0xDE, 0xF0, 0xFB,
-0x90, 0x85, 0xD7, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD,
-0x12, 0x51, 0x7D, 0x22, 0x90, 0x86, 0x6D, 0xE0,
-0xFF, 0x90, 0x85, 0xCE, 0xE0, 0xD3, 0x22, 0xE4,
-0xFE, 0x74, 0x4C, 0x2E, 0x12, 0xB6, 0xEE, 0xE4,
-0xF0, 0x0E, 0xEE, 0xB4, 0x2D, 0xF3, 0xE4, 0x90,
-0x85, 0xDC, 0xF0, 0x90, 0x85, 0xDB, 0xF0, 0x90,
-0x85, 0xDF, 0xF0, 0xEF, 0xB4, 0x01, 0x07, 0xA3,
-0x74, 0x2D, 0xF0, 0xE4, 0xA3, 0xF0, 0x22, 0x90,
-0x92, 0x29, 0xE0, 0x30, 0xE0, 0x34, 0xC4, 0x13,
-0x54, 0x07, 0x30, 0xE0, 0x2D, 0x90, 0x94, 0xE1,
-0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94, 0xC8, 0x40,
-0x21, 0x90, 0x92, 0x29, 0xE0, 0x54, 0xDF, 0xF0,
-0xE4, 0x90, 0x94, 0xE1, 0xF0, 0x90, 0x92, 0x29,
-0xE0, 0x13, 0x30, 0xE0, 0x0D, 0x90, 0x85, 0xC1,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x85, 0xD0, 0x74,
-0xD0, 0xF0, 0x22, 0x90, 0x94, 0x63, 0xEF, 0xF0,
-0x90, 0x84, 0xC5, 0xE0, 0xB4, 0x02, 0x12, 0x90,
-0x94, 0x63, 0xE0, 0xFF, 0x64, 0x01, 0x60, 0x25,
-0x90, 0x01, 0x4D, 0xE0, 0x64, 0x80, 0xF0, 0x80,
-0x19, 0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x7F,
-0x64, 0x7E, 0x00, 0x12, 0x7C, 0x9F, 0x90, 0x06,
-0x90, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x94, 0x63,
-0xE0, 0xFF, 0x12, 0x2A, 0x87, 0x22, 0x90, 0x94,
-0xAD, 0xED, 0xF0, 0x90, 0x94, 0xAC, 0xEF, 0xF0,
-0x12, 0x7B, 0x2A, 0x90, 0x94, 0xBA, 0xEF, 0xF0,
-0xE0, 0xFD, 0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xE0, 0xFE, 0x74, 0x00, 0x2D,
-0x91, 0x94, 0x12, 0x99, 0x02, 0x54, 0x3F, 0x90,
-0x94, 0xB7, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x90,
-0x94, 0xB6, 0xF0, 0x91, 0xB4, 0x50, 0x09, 0x91,
-0xDA, 0x91, 0x91, 0xE4, 0x91, 0x9C, 0x80, 0xF3,
-0x90, 0x94, 0xB8, 0xE0, 0x24, 0xF8, 0xFB, 0x90,
-0x94, 0xB7, 0xE0, 0x34, 0xFF, 0xFA, 0x90, 0x94,
-0xAD, 0xE0, 0xFF, 0x90, 0x8A, 0xF5, 0xE4, 0xF0,
-0xA3, 0xEF, 0xF0, 0xA3, 0x74, 0x01, 0xF0, 0x7D,
-0x0A, 0x7C, 0x00, 0x7F, 0x10, 0x7E, 0x00, 0x12,
-0x6D, 0xDB, 0x90, 0x88, 0xD2, 0xE0, 0xFF, 0x90,
-0x94, 0xAC, 0xE0, 0xFD, 0xD3, 0x9F, 0x40, 0x36,
-0x90, 0x88, 0xD2, 0xE0, 0xFC, 0x91, 0xBD, 0xCE,
-0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0x91, 0xD0,
-0xEC, 0xFF, 0xC3, 0xED, 0x91, 0xC6, 0xC3, 0x33,
-0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24, 0x28, 0xFF,
-0xE4, 0x3E, 0xFE, 0x91, 0xAC, 0xFD, 0x90, 0x94,
-0xAD, 0xE0, 0xFC, 0xC3, 0xED, 0x9C, 0x91, 0xA4,
-0x7D, 0x38, 0x7C, 0x00, 0x80, 0x37, 0x90, 0x94,
-0xAC, 0xE0, 0xFD, 0x91, 0xBD, 0xCE, 0xC3, 0x13,
-0xCE, 0x13, 0xD8, 0xF9, 0x91, 0xD0, 0xED, 0xFF,
-0x90, 0x88, 0xD2, 0xE0, 0xC3, 0x91, 0xC6, 0xC3,
-0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24, 0x38,
-0xFD, 0xE4, 0x3E, 0xFC, 0x91, 0xAC, 0xFF, 0x90,
-0x94, 0xAD, 0xE0, 0xFE, 0xC3, 0xEF, 0x9E, 0x91,
-0xA4, 0x7F, 0x28, 0x7E, 0x00, 0x12, 0x72, 0x06,
-0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00, 0x90, 0x8B,
-0x26, 0x12, 0x86, 0xFF, 0x0B, 0x7A, 0x94, 0x79,
-0xAE, 0x90, 0x8B, 0x29, 0x12, 0x86, 0xFF, 0x90,
-0x8B, 0x2C, 0x74, 0x08, 0xF0, 0x7A, 0x87, 0x79,
-0x84, 0x12, 0x55, 0xCC, 0xE4, 0x90, 0x94, 0xB6,
-0xF0, 0x91, 0xB4, 0x50, 0x1B, 0x91, 0xDA, 0x90,
-0x94, 0xB6, 0xE0, 0x24, 0xAE, 0xF5, 0x82, 0xE4,
-0x34, 0x94, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x94,
-0xB9, 0x91, 0x91, 0xEF, 0x91, 0x9C, 0x80, 0xE1,
-0x22, 0xE0, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0x22, 0xF0, 0x90, 0x94, 0xB6,
-0xE0, 0x04, 0xF0, 0x22, 0xFB, 0x90, 0x8A, 0xEC,
-0x74, 0x08, 0xF0, 0x22, 0x90, 0x94, 0xB7, 0xA3,
-0xE0, 0x24, 0xF8, 0x22, 0x90, 0x94, 0xB6, 0xE0,
-0xFF, 0xC3, 0x94, 0x08, 0x22, 0x75, 0xF0, 0x80,
-0xA4, 0xAE, 0xF0, 0x78, 0x03, 0x22, 0x9F, 0xFF,
-0xE4, 0x94, 0x00, 0xFE, 0xEF, 0x78, 0x07, 0x22,
-0xFF, 0x90, 0x8A, 0xED, 0xEE, 0xF0, 0xA3, 0xEF,
-0xF0, 0x22, 0x90, 0x94, 0xBA, 0xE0, 0xFD, 0x90,
-0x94, 0xB8, 0xE0, 0x2D, 0xFD, 0x90, 0x94, 0xB7,
-0xE0, 0x34, 0x00, 0xCD, 0x24, 0x20, 0xCD, 0x34,
-0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F, 0xFF, 0xEE,
-0x3C, 0xFE, 0x90, 0x94, 0xAC, 0xE0, 0xFD, 0x12,
-0x7B, 0xAE, 0x90, 0x94, 0xB9, 0xEF, 0xF0, 0x22,
-0x90, 0x05, 0x63, 0xE0, 0x90, 0x92, 0x48, 0xF0,
-0x90, 0x05, 0x62, 0xE0, 0x90, 0x92, 0x49, 0xF0,
-0x90, 0x05, 0x61, 0xE0, 0x90, 0x92, 0x4A, 0xF0,
-0x90, 0x05, 0x60, 0xE0, 0x90, 0x92, 0x4B, 0xF0,
-0x90, 0x92, 0x3F, 0xE0, 0x44, 0x01, 0xF0, 0x22,
-0x90, 0x94, 0xC3, 0xE0, 0xFF, 0x90, 0x94, 0xCC,
-0x74, 0x0C, 0xF0, 0xE4, 0xFB, 0x7D, 0x01, 0x12,
-0x9E, 0x67, 0x90, 0x94, 0xC6, 0xEE, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x94, 0xC4, 0xE0, 0xFC, 0xA3,
-0xE0, 0xFD, 0x02, 0x77, 0xD8, 0x90, 0x89, 0x16,
-0xE0, 0xFE, 0x54, 0x0F, 0xFF, 0xEE, 0xC4, 0x13,
-0x13, 0x54, 0x03, 0x7D, 0x00, 0x22, 0xE5, 0x64,
-0x25, 0xE0, 0x24, 0xF5, 0xF5, 0x82, 0xE4, 0x34,
-0x82, 0xF5, 0x83, 0x22, 0x75, 0xF0, 0x03, 0xA4,
-0x24, 0x0A, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0x22, 0x75, 0xF0, 0x03, 0xA4, 0x24, 0xC8,
-0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0x22,
-0x54, 0xFB, 0xF0, 0x90, 0x85, 0xC9, 0xE0, 0x54,
-0xFD, 0xF0, 0x54, 0x07, 0x22, 0xF5, 0x82, 0xE4,
-0x34, 0x8F, 0xF5, 0x83, 0xE0, 0xFD, 0x22, 0x74,
-0xBC, 0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8F,
-0x22, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0xE0, 0x22, 0x90, 0x85, 0xC9, 0xE0, 0x44, 0x10,
-0xF0, 0x22, 0x4F, 0xFF, 0xF0, 0x12, 0x02, 0xF6,
-0xFE, 0x22, 0x12, 0x3D
-};
-u4Byte ArrayLength_MP_8188F_FW_AP = 17900;
-
-
-void
-ODM_ReadFirmware_MP_8188F_FW_AP(
-	IN   PDM_ODM_T    pDM_Odm,
-	OUT  u1Byte       *pFirmware,
-	OUT  u4Byte       *pFirmwareSize
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	*((SIZE_PTR *)pFirmware) = (SIZE_PTR)Array_MP_8188F_FW_AP;
-#else
-	ODM_MoveMemory(pDM_Odm, pFirmware, Array_MP_8188F_FW_AP, ArrayLength_MP_8188F_FW_AP);
-#endif
-	*pFirmwareSize = ArrayLength_MP_8188F_FW_AP;
-}
-
-
-#endif /* #if (defined(CONFIG_AP_WOWLAN)||(DM_ODM_SUPPORT_TYPE & (ODM_AP)) */
-
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN)) || (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-
-
-u1Byte Array_MP_8188F_FW_NIC[] = {
-0xF1, 0x88, 0x10, 0x00, 0x04, 0x00, 0x00, 0x00,
-0x08, 0x22, 0x17, 0x36, 0xFC, 0x51, 0x02, 0x00,
-0xBC, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x02, 0x87, 0x7D, 0x02, 0xC8, 0x55, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xB5, 0x27, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC8, 0xA7, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC8, 0x56, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC2, 0x21, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC8, 0xA6, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x02, 0x88, 0x18, 0x02, 0x8A, 0xD9, 0x02, 0x80,
-0x86, 0x02, 0x80, 0x89, 0x02, 0xA9, 0x59, 0x02,
-0xA3, 0x0C, 0x02, 0xB6, 0x62, 0x02, 0x80, 0x95,
-0x02, 0x80, 0x98, 0x02, 0x80, 0x9B, 0x02, 0x80,
-0x9E, 0x02, 0x80, 0xA1, 0x02, 0x80, 0xA4, 0x02,
-0x80, 0xA7, 0x02, 0x80, 0xAA, 0x02, 0x80, 0xAD,
-0x02, 0x80, 0xB0, 0x02, 0xA0, 0x3D, 0x02, 0x80,
-0xB6, 0x02, 0x80, 0xB9, 0x02, 0xB3, 0x1B, 0x02,
-0xB8, 0xCD, 0x02, 0xB8, 0x52, 0x02, 0xB7, 0xF9,
-0x02, 0xB1, 0x62, 0x02, 0xB3, 0x7C, 0x02, 0x80,
-0xCE, 0x02, 0x80, 0xD1, 0x02, 0x80, 0xD4, 0x02,
-0x80, 0xD7, 0x00, 0x00, 0x00, 0x02, 0x80, 0xDD,
-0x02, 0x80, 0xE0, 0x02, 0x80, 0xE3, 0x02, 0x80,
-0xE6, 0x02, 0x80, 0xE9, 0x02, 0x80, 0xEC, 0x02,
-0x80, 0xEF, 0x02, 0x80, 0xF2, 0x02, 0x80, 0xF5,
-0x02, 0x80, 0xF8, 0x02, 0x80, 0xFB, 0x02, 0x80,
-0xFE, 0x02, 0x81, 0x01, 0x02, 0x81, 0x04, 0x02,
-0x81, 0x07, 0x02, 0x81, 0x0A, 0x02, 0x81, 0x0D,
-0x02, 0x81, 0x10, 0x02, 0x81, 0x13, 0x02, 0x81,
-0x16, 0x02, 0x81, 0x19, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x02, 0xBF, 0x8B, 0x02,
-0xC9, 0x2D, 0x02, 0x96, 0xEE, 0x02, 0x98, 0xE3,
-0x02, 0x81, 0x40, 0x02, 0xA4, 0x6B, 0x02, 0xCD,
-0xF1, 0x02, 0x81, 0x49, 0x02, 0x81, 0x4C, 0x02,
-0x81, 0x4F, 0x02, 0x81, 0x52, 0x02, 0x81, 0x55,
-0x02, 0x81, 0x58, 0x02, 0x81, 0x5B, 0x02, 0x99,
-0xF8, 0x02, 0x81, 0x61, 0x02, 0x81, 0x64, 0x02,
-0xC6, 0xB7, 0x02, 0xCF, 0xE8, 0x02, 0xD0, 0x1D,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x15, 0xF0, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0x15,
-0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x05, 0xF0,
-0xFF, 0x0F, 0x00, 0x00, 0x00, 0x05, 0xF0, 0x0F,
-0x00, 0x00, 0x00, 0x00, 0x10, 0xF0, 0xFF, 0x0F,
-0x00, 0x00, 0x00, 0x10, 0xF0, 0x0F, 0x00, 0x00,
-0x00, 0x00, 0xF5, 0x0F, 0x00, 0x00, 0x00, 0x00,
-0x00, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x0D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0A,
-0x08, 0x03, 0x03, 0x00, 0x04, 0x09, 0x07, 0x03,
-0x03, 0x00, 0x04, 0x08, 0x06, 0x03, 0x02, 0x00,
-0x04, 0x08, 0x05, 0x03, 0x01, 0x00, 0x04, 0x0D,
-0x0A, 0x07, 0x05, 0x00, 0x08, 0x0C, 0x0A, 0x07,
-0x04, 0x00, 0x08, 0x0B, 0x0A, 0x06, 0x05, 0x00,
-0x08, 0x0B, 0x0A, 0x05, 0x03, 0x00, 0x08, 0x0B,
-0x0A, 0x03, 0x02, 0x00, 0x08, 0x14, 0x12, 0x0C,
-0x04, 0x00, 0x10, 0x14, 0x12, 0x09, 0x04, 0x00,
-0x10, 0x24, 0x22, 0x1C, 0x12, 0x00, 0x20, 0x24,
-0x22, 0x18, 0x0C, 0x00, 0x20, 0x24, 0x22, 0x14,
-0x06, 0x00, 0x20, 0x24, 0x22, 0x0F, 0x04, 0x00,
-0x20, 0x24, 0x21, 0x0A, 0x04, 0x00, 0x20, 0x23,
-0x21, 0x0C, 0x04, 0x00, 0x20, 0x23, 0x1F, 0x0A,
-0x04, 0x00, 0x20, 0x22, 0x1F, 0x0F, 0x04, 0x00,
-0x20, 0x21, 0x1F, 0x16, 0x0C, 0x00, 0x20, 0x31,
-0x2F, 0x20, 0x14, 0x00, 0x30, 0x31, 0x2F, 0x18,
-0x10, 0x00, 0x30, 0x31, 0x2C, 0x18, 0x0C, 0x00,
-0x30, 0x31, 0x2A, 0x14, 0x0C, 0x00, 0x30, 0x31,
-0x28, 0x14, 0x00, 0x00, 0x30, 0x31, 0x24, 0x14,
-0x00, 0x00, 0x30, 0x31, 0x1E, 0x14, 0x00, 0x00,
-0x30, 0x02, 0x02, 0x03, 0x04, 0x04, 0x08, 0x09,
-0x09, 0x0C, 0x0E, 0x10, 0x12, 0x02, 0x09, 0x0B,
-0x0E, 0x0D, 0x0F, 0x10, 0x12, 0x00, 0x04, 0x00,
-0x04, 0x00, 0x08, 0x00, 0x10, 0x00, 0x23, 0x00,
-0x2D, 0x00, 0x50, 0x00, 0x91, 0x00, 0xC3, 0x01,
-0x27, 0x01, 0x31, 0x01, 0x5E, 0x00, 0x8C, 0x00,
-0xC8, 0x00, 0xDC, 0x01, 0x5E, 0x01, 0x68, 0x01,
-0x9A, 0x01, 0xCC, 0x01, 0xEA, 0x02, 0x02, 0x04,
-0x08, 0x0C, 0x12, 0x18, 0x24, 0x30, 0x48, 0x60,
-0x6C, 0x14, 0x28, 0x32, 0x50, 0x78, 0xA0, 0xC8,
-0xE6, 0x01, 0x01, 0x01, 0x02, 0x01, 0x01, 0x02,
-0x02, 0x03, 0x03, 0x04, 0x04, 0x02, 0x04, 0x06,
-0x07, 0x07, 0x08, 0x08, 0x08, 0x01, 0x01, 0x01,
-0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
-0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x02,
-0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
-0x02, 0x03, 0x03, 0x04, 0x05, 0x01, 0x02, 0x03,
-0x04, 0x05, 0x06, 0x07, 0x08, 0x03, 0x03, 0x03,
-0x02, 0x03, 0x03, 0x03, 0x03, 0x03, 0x02, 0x02,
-0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02,
-0x02, 0x19, 0x06, 0x04, 0x02, 0x00, 0x18, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0xC2, 0xAF, 0x80, 0xFE, 0x32, 0x12, 0x84, 0x04,
-0x85, 0xD0, 0x0B, 0x75, 0xD0, 0x08, 0xAA, 0xE0,
-0xC2, 0x8C, 0xE5, 0x8A, 0x24, 0x67, 0xF5, 0x8A,
-0xE5, 0x8C, 0x34, 0x79, 0xF5, 0x8C, 0xD2, 0x8C,
-0xEC, 0x24, 0x87, 0xF8, 0xE6, 0xBC, 0x02, 0x02,
-0x74, 0xFF, 0xC3, 0x95, 0x81, 0xB4, 0x40, 0x00,
-0x40, 0xCE, 0x79, 0x03, 0x78, 0x80, 0x16, 0xE6,
-0x08, 0x70, 0x0B, 0xC2, 0xAF, 0xE6, 0x30, 0xE1,
-0x03, 0x44, 0x18, 0xF6, 0xD2, 0xAF, 0x08, 0xD9,
-0xED, 0xEA, 0x8B, 0xD0, 0x22, 0xE5, 0x0C, 0xFF,
-0x23, 0x24, 0x81, 0xF8, 0x0F, 0x08, 0x08, 0xBF,
-0x03, 0x04, 0x7F, 0x00, 0x78, 0x81, 0xE6, 0x30,
-0xE4, 0xF2, 0x00, 0xE5, 0x0C, 0xC3, 0x9F, 0x50,
-0x20, 0x05, 0x0C, 0x74, 0x86, 0x25, 0x0C, 0xF8,
-0xE6, 0xFD, 0xA6, 0x81, 0x08, 0xE6, 0xAE, 0x0C,
-0xBE, 0x02, 0x02, 0x74, 0xFF, 0xCD, 0xF8, 0xE8,
-0x6D, 0x60, 0xE0, 0x08, 0xE6, 0xC0, 0xE0, 0x80,
-0xF6, 0xE5, 0x0C, 0xD3, 0x9F, 0x40, 0x27, 0xE5,
-0x0C, 0x24, 0x87, 0xF8, 0xE6, 0xAE, 0x0C, 0xBE,
-0x02, 0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xCD,
-0xF8, 0xE5, 0x81, 0x6D, 0x60, 0x06, 0xD0, 0xE0,
-0xF6, 0x18, 0x80, 0xF5, 0xE5, 0x0C, 0x24, 0x86,
-0xC8, 0xF6, 0x15, 0x0C, 0x80, 0xD3, 0xE5, 0x0C,
-0x23, 0x24, 0x81, 0xF8, 0x7F, 0x04, 0xC2, 0xAF,
-0xE6, 0x30, 0xE0, 0x03, 0x10, 0xE2, 0x0C, 0x7F,
-0x00, 0x30, 0xE1, 0x07, 0x30, 0xE3, 0x04, 0x7F,
-0x08, 0x54, 0xF4, 0x54, 0x7C, 0xC6, 0xD2, 0xAF,
-0x54, 0x80, 0x42, 0x07, 0x22, 0x78, 0x86, 0xA6,
-0x81, 0x74, 0x02, 0x60, 0x06, 0xFF, 0x08, 0x76,
-0xFF, 0xDF, 0xFB, 0x7F, 0x03, 0xE4, 0x78, 0x80,
-0xF6, 0x08, 0xF6, 0x08, 0xDF, 0xFA, 0x78, 0x81,
-0x76, 0x30, 0x90, 0x88, 0x0D, 0x74, 0x01, 0x93,
-0xC0, 0xE0, 0xE4, 0x93, 0xC0, 0xE0, 0x43, 0x89,
-0x01, 0x75, 0x8A, 0x60, 0x75, 0x8C, 0x79, 0xD2,
-0x8C, 0xD2, 0xAF, 0x22, 0x02, 0xEF, 0xD3, 0x94,
-0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0x74, 0x81,
-0x2F, 0x2F, 0xF8, 0xE6, 0x20, 0xE5, 0xF4, 0xC2,
-0xAF, 0xE6, 0x44, 0x30, 0xF6, 0xD2, 0xAF, 0xAE,
-0x0C, 0xEE, 0xC3, 0x9F, 0x50, 0x21, 0x0E, 0x74,
-0x86, 0x2E, 0xF8, 0xE6, 0xF9, 0x08, 0xE6, 0x18,
-0xBE, 0x02, 0x02, 0x74, 0xFF, 0xFD, 0xED, 0x69,
-0x60, 0x09, 0x09, 0xE7, 0x19, 0x19, 0xF7, 0x09,
-0x09, 0x80, 0xF3, 0x16, 0x16, 0x80, 0xDA, 0xEE,
-0xD3, 0x9F, 0x40, 0x04, 0x05, 0x81, 0x05, 0x81,
-0xEE, 0xD3, 0x9F, 0x40, 0x22, 0x74, 0x86, 0x2E,
-0xF8, 0x08, 0xE6, 0xF9, 0xEE, 0xB5, 0x0C, 0x02,
-0xA9, 0x81, 0x18, 0x06, 0x06, 0xE6, 0xFD, 0xED,
-0x69, 0x60, 0x09, 0x19, 0x19, 0xE7, 0x09, 0x09,
-0xF7, 0x19, 0x80, 0xF3, 0x1E, 0x80, 0xD9, 0xEF,
-0x24, 0x86, 0xF8, 0xE6, 0x04, 0xF8, 0xEF, 0x2F,
-0x04, 0x90, 0x88, 0x0D, 0x93, 0xF6, 0x08, 0xEF,
-0x2F, 0x93, 0xF6, 0x7F, 0x00, 0x22, 0xEF, 0xD3,
-0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0xEF,
-0x23, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE5, 0xF4,
-0xC2, 0xAF, 0xE6, 0x54, 0x8C, 0xF6, 0xD2, 0xAF,
-0xE5, 0x0C, 0xB5, 0x07, 0x0A, 0x74, 0x86, 0x2F,
-0xF8, 0xE6, 0xF5, 0x81, 0x02, 0x84, 0x4D, 0x50,
-0x2E, 0x74, 0x87, 0x2F, 0xF8, 0xE6, 0xBF, 0x02,
-0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xF9, 0x74,
-0x86, 0x2F, 0xF8, 0xFB, 0xE6, 0xFC, 0xE9, 0x6C,
-0x60, 0x08, 0xA8, 0x05, 0xE7, 0xF6, 0x1D, 0x19,
-0x80, 0xF4, 0xA8, 0x03, 0xA6, 0x05, 0x1F, 0xE5,
-0x0C, 0xB5, 0x07, 0xE3, 0x7F, 0x00, 0x22, 0x74,
-0x87, 0x2F, 0xF8, 0xE6, 0xFD, 0x18, 0x86, 0x01,
-0x0F, 0x74, 0x86, 0x2F, 0xF8, 0xA6, 0x01, 0x08,
-0x86, 0x04, 0xE5, 0x0C, 0xB5, 0x07, 0x02, 0xAC,
-0x81, 0xED, 0x6C, 0x60, 0x08, 0x0D, 0x09, 0xA8,
-0x05, 0xE6, 0xF7, 0x80, 0xF4, 0xE5, 0x0C, 0xB5,
-0x07, 0xDE, 0x89, 0x81, 0x7F, 0x00, 0x22, 0xEF,
-0xD3, 0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22,
-0xEF, 0x23, 0x24, 0x81, 0xF8, 0xC2, 0xAF, 0xE6,
-0x30, 0xE5, 0x05, 0x30, 0xE0, 0x02, 0xD2, 0xE4,
-0xD2, 0xE2, 0xC6, 0xD2, 0xAF, 0x7F, 0x00, 0x30,
-0xE2, 0x01, 0x0F, 0x02, 0x84, 0x4C, 0x8F, 0xF0,
-0xE4, 0xFF, 0xFE, 0xE5, 0x0C, 0x23, 0x24, 0x80,
-0xF8, 0xC2, 0xA9, 0x30, 0xF7, 0x0D, 0x7F, 0x08,
-0xE6, 0x60, 0x0B, 0x2D, 0xF6, 0x60, 0x30, 0x50,
-0x2E, 0x80, 0x07, 0x30, 0xF1, 0x06, 0xED, 0xF6,
-0x60, 0x25, 0x7E, 0x02, 0x08, 0x30, 0xF0, 0x10,
-0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x23, 0x0E, 0x30,
-0xE2, 0x0C, 0xD2, 0xAF, 0x7F, 0x04, 0x80, 0x12,
-0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x13, 0x54, 0xEC,
-0x4E, 0xF6, 0xD2, 0xAF, 0x02, 0x84, 0x4D, 0x7F,
-0x08, 0x08, 0xEF, 0x44, 0x83, 0xF4, 0xC2, 0xAF,
-0x56, 0xC6, 0xD2, 0xAF, 0x54, 0x80, 0x4F, 0xFF,
-0x22, 0xEF, 0x2B, 0xFF, 0xEE, 0x3A, 0xFE, 0xED,
-0x39, 0xFD, 0xEC, 0x38, 0xFC, 0x22, 0xC3, 0xEF,
-0x9B, 0xFF, 0xEE, 0x9A, 0xFE, 0xED, 0x99, 0xFD,
-0xEC, 0x98, 0xFC, 0x22, 0xE8, 0x8F, 0xF0, 0xA4,
-0xCC, 0x8B, 0xF0, 0xA4, 0x2C, 0xFC, 0xE9, 0x8E,
-0xF0, 0xA4, 0x2C, 0xFC, 0x8A, 0xF0, 0xED, 0xA4,
-0x2C, 0xFC, 0xEA, 0x8E, 0xF0, 0xA4, 0xCD, 0xA8,
-0xF0, 0x8B, 0xF0, 0xA4, 0x2D, 0xCC, 0x38, 0x25,
-0xF0, 0xFD, 0xE9, 0x8F, 0xF0, 0xA4, 0x2C, 0xCD,
-0x35, 0xF0, 0xFC, 0xEB, 0x8E, 0xF0, 0xA4, 0xFE,
-0xA9, 0xF0, 0xEB, 0x8F, 0xF0, 0xA4, 0xCF, 0xC5,
-0xF0, 0x2E, 0xCD, 0x39, 0xFE, 0xE4, 0x3C, 0xFC,
-0xEA, 0xA4, 0x2D, 0xCE, 0x35, 0xF0, 0xFD, 0xE4,
-0x3C, 0xFC, 0x22, 0xEF, 0x5B, 0xFF, 0xEE, 0x5A,
-0xFE, 0xED, 0x59, 0xFD, 0xEC, 0x58, 0xFC, 0x22,
-0xEF, 0x4B, 0xFF, 0xEE, 0x4A, 0xFE, 0xED, 0x49,
-0xFD, 0xEC, 0x48, 0xFC, 0x22, 0xE0, 0xFC, 0xA3,
-0xE0, 0xFD, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x22, 0xE0, 0xF8, 0xA3, 0xE0, 0xF9, 0xA3, 0xE0,
-0xFA, 0xA3, 0xE0, 0xFB, 0x22, 0xE0, 0xFB, 0xA3,
-0xE0, 0xFA, 0xA3, 0xE0, 0xF9, 0x22, 0xEB, 0xF0,
-0xA3, 0xEA, 0xF0, 0xA3, 0xE9, 0xF0, 0x22, 0xD0,
-0x83, 0xD0, 0x82, 0xF8, 0xE4, 0x93, 0x70, 0x12,
-0x74, 0x01, 0x93, 0x70, 0x0D, 0xA3, 0xA3, 0x93,
-0xF8, 0x74, 0x01, 0x93, 0xF5, 0x82, 0x88, 0x83,
-0xE4, 0x73, 0x74, 0x02, 0x93, 0x68, 0x60, 0xEF,
-0xA3, 0xA3, 0xA3, 0x80, 0xDF, 0x02, 0x87, 0xBB,
-0x02, 0x84, 0xDD, 0xE4, 0x93, 0xA3, 0xF8, 0xE4,
-0x93, 0xA3, 0x40, 0x03, 0xF6, 0x80, 0x01, 0xF2,
-0x08, 0xDF, 0xF4, 0x80, 0x29, 0xE4, 0x93, 0xA3,
-0xF8, 0x54, 0x07, 0x24, 0x0C, 0xC8, 0xC3, 0x33,
-0xC4, 0x54, 0x0F, 0x44, 0x20, 0xC8, 0x83, 0x40,
-0x04, 0xF4, 0x56, 0x80, 0x01, 0x46, 0xF6, 0xDF,
-0xE4, 0x80, 0x0B, 0x01, 0x02, 0x04, 0x08, 0x10,
-0x20, 0x40, 0x80, 0x90, 0x88, 0x00, 0xE4, 0x7E,
-0x01, 0x93, 0x60, 0xBC, 0xA3, 0xFF, 0x54, 0x3F,
-0x30, 0xE5, 0x09, 0x54, 0x1F, 0xFE, 0xE4, 0x93,
-0xA3, 0x60, 0x01, 0x0E, 0xCF, 0x54, 0xC0, 0x25,
-0xE0, 0x60, 0xA8, 0x40, 0xB8, 0xE4, 0x93, 0xA3,
-0xFA, 0xE4, 0x93, 0xA3, 0xF8, 0xE4, 0x93, 0xA3,
-0xC8, 0xC5, 0x82, 0xC8, 0xCA, 0xC5, 0x83, 0xCA,
-0xF0, 0xA3, 0xC8, 0xC5, 0x82, 0xC8, 0xCA, 0xC5,
-0x83, 0xCA, 0xDF, 0xE9, 0xDE, 0xE7, 0x80, 0xBE,
-0x41, 0x95, 0x11, 0x00, 0x41, 0x95, 0x12, 0x00,
-0x41, 0x95, 0x19, 0x00, 0x00, 0xBB, 0x20, 0xC0,
-0x66, 0xC8, 0x01, 0x12, 0x5E, 0x10, 0x7F, 0x04,
-0x90, 0x95, 0x17, 0xEF, 0xF0, 0x7F, 0x02, 0x12,
-0x86, 0x27, 0x90, 0x84, 0xC1, 0xE0, 0xFF, 0x90,
-0x95, 0x17, 0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x84,
-0xC1, 0xF0, 0x22, 0x90, 0x93, 0xFB, 0xEF, 0xF0,
-0x51, 0x7E, 0x7F, 0xF4, 0x7E, 0x00, 0x12, 0x64,
-0x37, 0xBF, 0x01, 0x08, 0x90, 0x94, 0x1A, 0xE0,
-0x90, 0x94, 0x1C, 0xF0, 0x51, 0x7E, 0x7F, 0xF5,
-0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08,
-0x90, 0x94, 0x1A, 0xE0, 0x90, 0x94, 0x1D, 0xF0,
-0x51, 0x7E, 0x7F, 0xF6, 0x7E, 0x00, 0x12, 0x64,
-0x37, 0xBF, 0x01, 0x08, 0x90, 0x94, 0x1A, 0xE0,
-0x90, 0x94, 0x1E, 0xF0, 0x51, 0x7E, 0x7F, 0xF7,
-0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08,
-0x90, 0x94, 0x1A, 0xE0, 0x90, 0x94, 0x1F, 0xF0,
-0x51, 0x7E, 0x7F, 0xF8, 0x7E, 0x00, 0x12, 0x64,
-0x37, 0xBF, 0x01, 0x08, 0x90, 0x94, 0x1A, 0xE0,
-0x90, 0x94, 0x20, 0xF0, 0x51, 0x7E, 0x12, 0xBF,
-0x6C, 0xBF, 0x01, 0x08, 0x90, 0x94, 0x1A, 0xE0,
-0x90, 0x94, 0x21, 0xF0, 0x51, 0x7E, 0x51, 0x85,
-0x70, 0x52, 0x90, 0x94, 0x1A, 0xE0, 0x90, 0x94,
-0x22, 0xF0, 0x54, 0x07, 0x60, 0x08, 0x90, 0x94,
-0x1A, 0xE0, 0x54, 0xE0, 0x70, 0x3E, 0x7B, 0x01,
-0x7A, 0x94, 0x79, 0x1B, 0x7F, 0xFA, 0x51, 0x87,
-0x70, 0x32, 0x90, 0x94, 0x1A, 0xE0, 0xFC, 0x54,
-0x07, 0x70, 0x12, 0x90, 0x94, 0x22, 0xE0, 0xFE,
-0x90, 0x94, 0x1B, 0xE0, 0x54, 0x07, 0xFD, 0xEE,
-0x4D, 0x90, 0x94, 0x22, 0xF0, 0xEC, 0x54, 0xE0,
-0x70, 0x12, 0x90, 0x94, 0x22, 0xE0, 0xFF, 0x90,
-0x94, 0x1B, 0xE0, 0x54, 0xE0, 0xFE, 0xEF, 0x4E,
-0x90, 0x94, 0x22, 0xF0, 0x51, 0x7E, 0x7F, 0xFD,
-0x51, 0x87, 0x70, 0x47, 0x90, 0x94, 0x1A, 0xE0,
-0xFE, 0x54, 0xCC, 0x90, 0x94, 0x23, 0xF0, 0xEE,
-0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90, 0x94, 0x1A,
-0xE0, 0x54, 0xC0, 0x70, 0x2E, 0xEF, 0x70, 0x12,
-0x90, 0x94, 0x23, 0xE0, 0xFF, 0x90, 0x94, 0x1A,
-0xE0, 0x54, 0x03, 0x12, 0xD1, 0xCA, 0x90, 0x94,
-0x23, 0xF0, 0x90, 0x94, 0x1A, 0xE0, 0xFF, 0x54,
-0xC0, 0x70, 0x10, 0x90, 0x94, 0x23, 0xE0, 0xFE,
-0xEF, 0x54, 0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF,
-0xEE, 0x4F, 0xF0, 0x51, 0x7E, 0x7F, 0xF0, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x94, 0x1A, 0xE0, 0x90, 0x94, 0x24, 0xF0, 0x51,
-0x7E, 0x7F, 0xF1, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x94, 0x1A, 0xE0, 0x90,
-0x94, 0x25, 0xF0, 0x51, 0x7E, 0x7F, 0xF2, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x94, 0x1A, 0xE0, 0x90, 0x94, 0x26, 0xF0, 0x51,
-0x7E, 0x7F, 0xF3, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x94, 0x1A, 0xE0, 0x90,
-0x94, 0x27, 0xF0, 0x51, 0x7E, 0x7F, 0xFC, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x94, 0x1A, 0xE0, 0x90, 0x94, 0x28, 0xF0, 0x90,
-0x93, 0xFC, 0x74, 0x19, 0xF0, 0x90, 0x94, 0x0A,
-0x74, 0x08, 0xF0, 0x90, 0x94, 0x1C, 0xE0, 0x90,
-0x93, 0xFE, 0xF0, 0x90, 0x94, 0x1D, 0xE0, 0x90,
-0x93, 0xFF, 0xF0, 0x90, 0x94, 0x1E, 0xE0, 0x90,
-0x94, 0x00, 0xF0, 0x90, 0x94, 0x1F, 0xE0, 0x90,
-0x94, 0x01, 0xF0, 0x90, 0x94, 0x20, 0xE0, 0x90,
-0x94, 0x02, 0xF0, 0x90, 0x94, 0x21, 0xE0, 0x90,
-0x94, 0x03, 0xF0, 0x90, 0x94, 0x22, 0xE0, 0x90,
-0x94, 0x04, 0xF0, 0x90, 0x94, 0x23, 0xE0, 0x90,
-0x94, 0x05, 0xF0, 0x90, 0x94, 0x0B, 0x74, 0x1A,
-0xF0, 0x90, 0x94, 0x19, 0x74, 0x05, 0xF0, 0x90,
-0x94, 0x24, 0xE0, 0x90, 0x94, 0x0D, 0xF0, 0x90,
-0x94, 0x25, 0xE0, 0x90, 0x94, 0x0E, 0xF0, 0x90,
-0x94, 0x26, 0xE0, 0x90, 0x94, 0x0F, 0xF0, 0x90,
-0x94, 0x27, 0xE0, 0x90, 0x94, 0x10, 0xF0, 0x90,
-0x94, 0x28, 0xE0, 0x90, 0x94, 0x11, 0xF0, 0x90,
-0x93, 0xFB, 0xE0, 0xB4, 0x01, 0x16, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0xFC, 0x12, 0x5E, 0x10, 0x7B,
-0x01, 0x7A, 0x94, 0x79, 0x0B, 0x12, 0x5E, 0x10,
-0x7F, 0x04, 0x01, 0x18, 0x75, 0x1B, 0x01, 0x75,
-0x1C, 0x93, 0x75, 0x1D, 0xFC, 0x75, 0x1E, 0x0A,
-0x7B, 0x01, 0x7A, 0x01, 0x79, 0xA0, 0x12, 0x6A,
-0x21, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x94, 0x75,
-0x1D, 0x0D, 0x75, 0x1E, 0x05, 0x7B, 0x01, 0x7A,
-0x01, 0x79, 0xAA, 0x02, 0x6A, 0x21, 0x7B, 0x01,
-0x7A, 0x94, 0x79, 0x1A, 0x22, 0x7F, 0xFB, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xEF, 0x64, 0x01, 0x22,
-0x12, 0xA0, 0x37, 0x12, 0x02, 0xF6, 0xFF, 0xF1,
-0x73, 0xFE, 0x54, 0x03, 0xFD, 0xEE, 0x13, 0x13,
-0x54, 0x07, 0xFB, 0xC0, 0x03, 0xF1, 0x58, 0xF1,
-0xF3, 0x12, 0xD0, 0x6A, 0xD0, 0x03, 0x12, 0xA9,
-0x59, 0xF1, 0x58, 0xF1, 0x73, 0x71, 0xBE, 0x90,
-0x93, 0xC6, 0x74, 0x10, 0xF0, 0x90, 0x93, 0xD4,
-0x74, 0x07, 0xF0, 0xF1, 0x58, 0x12, 0x02, 0xF6,
-0x90, 0x93, 0xC8, 0xF0, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0xC6, 0x12, 0x5E, 0x10, 0x7F, 0x04, 0x01,
-0x18, 0x90, 0x93, 0xC0, 0x12, 0x87, 0x4E, 0x90,
-0x93, 0xBF, 0xEF, 0xF0, 0x12, 0x87, 0x57, 0x8B,
-0x33, 0x00, 0x8B, 0x37, 0x01, 0x8B, 0x3C, 0x06,
-0x8B, 0x4D, 0x10, 0x8B, 0x52, 0x11, 0x8B, 0x57,
-0x12, 0x8B, 0x5C, 0x14, 0x8B, 0xA9, 0x15, 0x8B,
-0x61, 0x16, 0x8B, 0x65, 0x18, 0x8B, 0x6A, 0x19,
-0x8B, 0x6F, 0x1C, 0x8B, 0x73, 0x20, 0x8B, 0x78,
-0x24, 0x8B, 0x7D, 0x25, 0x8B, 0x82, 0x27, 0x8B,
-0x87, 0x40, 0x8B, 0x8C, 0x42, 0x8B, 0xA9, 0x47,
-0x8B, 0x91, 0x49, 0x8B, 0x96, 0xC3, 0x8B, 0x41,
-0xC6, 0x8B, 0x41, 0xC7, 0x8B, 0x41, 0xC8, 0x00,
-0x00, 0x8B, 0x9A, 0x71, 0xAA, 0xE1, 0xF9, 0x71,
-0xAA, 0x02, 0x98, 0x09, 0x71, 0xAA, 0x02, 0xB9,
-0x3F, 0x90, 0x93, 0xBF, 0xE0, 0xFF, 0xA3, 0x12,
-0x87, 0x45, 0x02, 0xB9, 0xDA, 0x71, 0xAA, 0x02,
-0x9F, 0xFF, 0x71, 0xAA, 0x02, 0x91, 0x0F, 0x71,
-0xAA, 0x02, 0xB0, 0x32, 0x71, 0xAA, 0x02, 0xB1,
-0x0C, 0x71, 0xAA, 0xE1, 0xCA, 0x71, 0xAA, 0x02,
-0xA8, 0x01, 0x71, 0xAA, 0x02, 0xAF, 0xED, 0x71,
-0xAA, 0x41, 0x90, 0x71, 0xAA, 0x02, 0x90, 0x3F,
-0x71, 0xAA, 0x02, 0xA4, 0xB6, 0x71, 0xAA, 0x02,
-0xB1, 0x1B, 0x71, 0xAA, 0x02, 0xB1, 0x23, 0x71,
-0xAA, 0x02, 0xA0, 0x3D, 0x71, 0xAA, 0x02, 0x4E,
-0x29, 0x71, 0xAA, 0x02, 0xCA, 0xE1, 0x71, 0xAA,
-0xE1, 0xB5, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x01,
-0xF0, 0x90, 0x93, 0xBF, 0xE0, 0x90, 0x01, 0xC2,
-0xF0, 0x22, 0x90, 0x93, 0xC0, 0x02, 0x87, 0x45,
-0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x38, 0xF5, 0x82,
-0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0xFE, 0x54,
-0x03, 0xFF, 0xEE, 0x13, 0x13, 0x54, 0x07, 0xFD,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x95, 0x15, 0xED, 0xF0, 0xE4, 0xA3, 0xF0, 0xEF,
-0x14, 0x60, 0x02, 0x81, 0xAF, 0x90, 0x06, 0x03,
-0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x95, 0x15, 0xE0,
-0xFB, 0xC4, 0x33, 0x54, 0xE0, 0xFE, 0x90, 0x04,
-0x42, 0xE0, 0x54, 0x9F, 0x4E, 0xFE, 0xF0, 0xE4,
-0xFD, 0x12, 0xCD, 0x05, 0x90, 0x95, 0x16, 0xEF,
-0xF0, 0x90, 0x04, 0x83, 0xF0, 0x90, 0x94, 0xD3,
-0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x01, 0x90,
-0x94, 0xD7, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
-0x01, 0xB1, 0x82, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x00, 0x01, 0x90, 0x94, 0xD7, 0x12, 0x04, 0xF7,
-0x00, 0x00, 0x00, 0x01, 0x7F, 0x00, 0x7E, 0x09,
-0xB1, 0x86, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
-0x10, 0x90, 0x95, 0x15, 0xB1, 0xA5, 0xEF, 0x54,
-0x03, 0xFF, 0xE4, 0x78, 0x01, 0x12, 0x04, 0xC5,
-0x78, 0x04, 0xF1, 0x64, 0x7F, 0x00, 0x7E, 0x0A,
-0xB1, 0x86, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C,
-0x00, 0x90, 0x95, 0x15, 0xB1, 0xA5, 0xEF, 0x54,
-0x03, 0xFF, 0xE4, 0x78, 0x0A, 0xF1, 0x64, 0x7F,
-0x00, 0x7E, 0x0D, 0xB1, 0x86, 0x12, 0x04, 0xF7,
-0x0C, 0x00, 0x00, 0x00, 0x90, 0x95, 0x16, 0xB1,
-0xA5, 0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x1A,
-0xF1, 0x64, 0x7F, 0x18, 0xB1, 0x84, 0x12, 0x04,
-0xF7, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x94, 0xD7,
-0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x00, 0xB1,
-0x18, 0x90, 0x94, 0xC1, 0x12, 0x04, 0xF7, 0x00,
-0x00, 0x0C, 0x00, 0x90, 0x94, 0xC5, 0x12, 0x04,
-0xF7, 0x00, 0x00, 0x04, 0x00, 0x80, 0x5B, 0x90,
-0x06, 0x03, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x94,
-0xD3, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x01,
-0x90, 0x94, 0xD7, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x00, 0x00, 0xB1, 0x82, 0x12, 0x04, 0xF7, 0x00,
-0x00, 0x00, 0x01, 0x90, 0x94, 0xD7, 0x12, 0x04,
-0xF7, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x00, 0x7E,
-0x09, 0xB1, 0x86, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x0C, 0x00, 0x90, 0x94, 0xD7, 0x12, 0x04, 0xF7,
-0x00, 0x00, 0x0C, 0x00, 0xB1, 0x18, 0x90, 0x94,
-0xC1, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00,
-0x90, 0x94, 0xC5, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x0C, 0x00, 0x7D, 0x18, 0x7C, 0x00, 0xE4, 0xFF,
-0x12, 0xA9, 0xD2, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x7F, 0x84, 0x7E, 0x08, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xD1, 0xEE, 0xF0,
-0xA3, 0xEF, 0xF0, 0x12, 0x70, 0x61, 0x90, 0x94,
-0xDB, 0x12, 0x04, 0xEB, 0x90, 0x94, 0xD3, 0x12,
-0x87, 0x2D, 0x12, 0x04, 0xA7, 0x90, 0x94, 0xDB,
-0xF1, 0x5E, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x94, 0xD3, 0x12, 0x87, 0x2D,
-0x90, 0x94, 0xD7, 0xF1, 0x5E, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x20,
-0x90, 0x94, 0xDF, 0x12, 0x04, 0xEB, 0x90, 0x94,
-0xDF, 0x12, 0x87, 0x2D, 0x90, 0x91, 0x66, 0x12,
-0x04, 0xEB, 0x90, 0x94, 0xD1, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0x12, 0x71, 0x18, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x7F, 0x00, 0x7E, 0x08, 0xB1, 0x1C,
-0x90, 0x94, 0xD3, 0x22, 0x90, 0x05, 0x61, 0xE0,
-0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0x78, 0x08, 0x12,
-0x04, 0xD8, 0xA8, 0x04, 0xA9, 0x05, 0xAA, 0x06,
-0xAB, 0x07, 0x90, 0x05, 0x60, 0xE0, 0xFF, 0xE4,
-0xFC, 0xFD, 0xFE, 0x22, 0x90, 0x92, 0x0A, 0xE0,
-0x20, 0xE0, 0x02, 0xE1, 0x49, 0x90, 0x92, 0xB6,
-0xE0, 0x04, 0xF0, 0x12, 0x94, 0x0E, 0x04, 0xFF,
-0x90, 0x94, 0x6F, 0xF0, 0x90, 0x92, 0x0B, 0xE0,
-0xB5, 0x07, 0x05, 0xE4, 0x90, 0x94, 0x6F, 0xF0,
-0x90, 0x92, 0xB4, 0xE0, 0xFF, 0x60, 0x17, 0x90,
-0x94, 0x6F, 0xF1, 0x7C, 0xE0, 0xC3, 0x9F, 0x90,
-0x91, 0x6F, 0x12, 0xAF, 0x91, 0xFB, 0xFD, 0x7F,
-0x50, 0x7E, 0x01, 0x12, 0x61, 0x41, 0x90, 0x94,
-0x6F, 0xE0, 0xFF, 0xF1, 0xA6, 0x54, 0x07, 0xFE,
-0x64, 0x02, 0x60, 0x03, 0xEE, 0x70, 0x11, 0xEF,
-0xF1, 0x7D, 0xE0, 0x24, 0xFC, 0xFF, 0xE4, 0x90,
-0x91, 0x6E, 0xF0, 0xA3, 0xEF, 0x12, 0xC6, 0x20,
-0x90, 0x92, 0x0A, 0xE0, 0xF1, 0xA2, 0x54, 0x07,
-0xFF, 0x14, 0x60, 0x0F, 0x14, 0x60, 0x07, 0x14,
-0x60, 0x09, 0x24, 0x03, 0x70, 0x0B, 0x12, 0xCC,
-0x5E, 0x80, 0x03, 0x12, 0x97, 0xEE, 0x12, 0x94,
-0x17, 0x90, 0x92, 0xB3, 0xE0, 0xFF, 0x90, 0x92,
-0xB6, 0xE0, 0xD3, 0x9F, 0x40, 0x02, 0xE1, 0x49,
-0xB1, 0x8C, 0x12, 0x87, 0x20, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05, 0x62,
-0xB1, 0xA5, 0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0,
-0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0xA3, 0xB1, 0xA5, 0x78, 0x18, 0x12,
-0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0x12, 0x87, 0x20, 0x90, 0x94, 0x70,
-0x12, 0x04, 0xEB, 0x90, 0x05, 0x65, 0xB1, 0xA5,
-0x12, 0xAE, 0x80, 0x90, 0x05, 0x64, 0xB1, 0xA5,
-0x12, 0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x05, 0x66, 0xB1, 0xA5,
-0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x20,
-0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0xA3, 0xB1, 0xA5, 0x78, 0x18, 0x12, 0x04, 0xD8,
-0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
-0x12, 0x87, 0x20, 0x90, 0x94, 0x74, 0x12, 0x04,
-0xEB, 0x90, 0x94, 0x6F, 0xF1, 0x7C, 0xB1, 0xA5,
-0x12, 0xAF, 0xA6, 0x90, 0x94, 0x70, 0x12, 0x87,
-0x39, 0x12, 0x86, 0xA9, 0x90, 0x94, 0x78, 0x12,
-0x04, 0xEB, 0x90, 0x94, 0x70, 0x12, 0x87, 0x2D,
-0x90, 0x94, 0x78, 0x12, 0xAF, 0x9F, 0x50, 0x11,
-0xF1, 0x4C, 0x12, 0xB9, 0x37, 0xE4, 0x3D, 0xFD,
-0xE4, 0x3C, 0xFC, 0x90, 0x94, 0x74, 0x12, 0x04,
-0xEB, 0xF1, 0x4C, 0x12, 0xAF, 0xB7, 0xF1, 0x4A,
-0x12, 0xAF, 0xC0, 0xF1, 0x4A, 0x12, 0xAF, 0xC9,
-0xF1, 0x4A, 0x90, 0x05, 0x88, 0xEF, 0xF0, 0x90,
-0x94, 0x78, 0x12, 0x87, 0x2D, 0x12, 0xAF, 0xD2,
-0xEF, 0xF0, 0x90, 0x94, 0x78, 0x12, 0x87, 0x2D,
-0x12, 0xAF, 0xDB, 0xEF, 0xF0, 0x90, 0x94, 0x78,
-0x12, 0x87, 0x2D, 0x12, 0xAF, 0xE4, 0xEF, 0xF0,
-0x90, 0x94, 0x78, 0x12, 0x87, 0x2D, 0x12, 0xD1,
-0x1F, 0x22, 0xEF, 0xF0, 0x90, 0x94, 0x74, 0x02,
-0x87, 0x2D, 0x24, 0x03, 0xFF, 0xE4, 0x33, 0xFE,
-0x90, 0x93, 0xC3, 0x02, 0x87, 0x45, 0x12, 0x87,
-0x39, 0x02, 0x87, 0x13, 0x12, 0x04, 0xD8, 0x90,
-0x94, 0xD7, 0x02, 0x04, 0xEB, 0xAB, 0x5B, 0xAA,
-0x5C, 0xA9, 0x5D, 0x90, 0x00, 0x01, 0x02, 0x03,
-0x0F, 0x90, 0x94, 0x7E, 0xE0, 0x75, 0xF0, 0x1B,
-0xA4, 0x24, 0x39, 0xF5, 0x82, 0xE4, 0x34, 0x92,
-0xF5, 0x83, 0x22, 0xF1, 0x8F, 0xA1, 0xAC, 0x90,
-0x92, 0x09, 0xE0, 0x30, 0xE0, 0x0B, 0x12, 0xAF,
-0x8A, 0xE4, 0x90, 0x92, 0x0C, 0xF0, 0x12, 0xC5,
-0xF1, 0x22, 0xC3, 0x13, 0x54, 0x07, 0x75, 0xF0,
-0x1B, 0xA4, 0x24, 0x3A, 0xF5, 0x82, 0xE4, 0x34,
-0x92, 0xF5, 0x83, 0xE0, 0x22, 0x12, 0x02, 0xF6,
-0xFF, 0x90, 0x92, 0xBC, 0xF0, 0xBF, 0x01, 0x09,
-0x7F, 0x01, 0x11, 0x33, 0xE4, 0x90, 0x92, 0xBC,
-0xF0, 0x22, 0x12, 0xAF, 0xAE, 0x90, 0x92, 0x3C,
-0xF0, 0xF1, 0x73, 0x90, 0x92, 0x3D, 0xF1, 0xF2,
-0x90, 0x92, 0x57, 0xF0, 0x12, 0x91, 0x09, 0x90,
-0x92, 0x58, 0xF0, 0x12, 0x97, 0xE7, 0x90, 0x92,
-0x72, 0x12, 0x97, 0xF5, 0x90, 0x92, 0x73, 0xF0,
-0x22, 0x4F, 0xF0, 0x90, 0x00, 0x02, 0x02, 0x03,
-0x0F, 0x90, 0x02, 0x09, 0xE0, 0xF5, 0x5B, 0x12,
-0x02, 0xF6, 0x25, 0x5B, 0x90, 0x84, 0xC6, 0xF0,
-0x12, 0x8F, 0x73, 0x25, 0x5B, 0x90, 0x84, 0xC7,
-0x12, 0x8F, 0xF2, 0x25, 0x5B, 0x90, 0x84, 0xC8,
-0xF0, 0x31, 0x09, 0x25, 0x5B, 0x90, 0x84, 0xC9,
-0xF0, 0xF1, 0xE7, 0x25, 0x5B, 0x90, 0x84, 0xCA,
-0xF1, 0xF5, 0x25, 0x5B, 0x90, 0x84, 0xCB, 0xF0,
-0x11, 0x39, 0x25, 0x5B, 0x90, 0x84, 0xCC, 0xF0,
-0x22, 0x90, 0x00, 0x06, 0x02, 0x03, 0x0F, 0x12,
-0xA0, 0x37, 0x12, 0x02, 0xF6, 0xFF, 0x54, 0x7F,
-0x90, 0x85, 0xC5, 0xF0, 0xEF, 0x12, 0xA3, 0x01,
-0xA3, 0xF0, 0x12, 0x8F, 0x73, 0xFD, 0x54, 0xF0,
-0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x85, 0xC3, 0xE0,
-0x54, 0xF0, 0x4F, 0xF0, 0x31, 0x09, 0xFC, 0x54,
-0x01, 0x25, 0xE0, 0xFF, 0x90, 0x85, 0xC1, 0xE0,
-0x54, 0xFD, 0x4F, 0xF0, 0xEC, 0x54, 0x04, 0xFF,
-0x90, 0x92, 0xC9, 0xE0, 0x54, 0xFB, 0x4F, 0xF0,
-0xED, 0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFF, 0x12,
-0xB7, 0xDC, 0x12, 0x8F, 0xF1, 0x90, 0x85, 0xC4,
-0xF0, 0x11, 0x39, 0x30, 0xE0, 0x50, 0xC3, 0x13,
-0x54, 0x07, 0xFF, 0xC3, 0x94, 0x04, 0x90, 0x85,
-0xD8, 0x50, 0x04, 0xEF, 0xF0, 0x80, 0x27, 0x74,
-0x03, 0xF0, 0x12, 0x8F, 0x58, 0xE9, 0x24, 0x06,
-0x12, 0xA7, 0xEE, 0xFF, 0x74, 0x03, 0x24, 0xFD,
-0xFE, 0xEF, 0xC4, 0x54, 0x0F, 0xFD, 0xEF, 0x54,
-0x0F, 0xFF, 0xED, 0x2E, 0x54, 0x0F, 0xFE, 0xC4,
-0x54, 0xF0, 0x4F, 0x12, 0x03, 0x3C, 0x12, 0x8F,
-0x58, 0x11, 0x39, 0xC4, 0x54, 0x0F, 0xFF, 0xC3,
-0x94, 0x04, 0x90, 0x85, 0xCD, 0x50, 0x05, 0x74,
-0x04, 0xF0, 0x80, 0x02, 0xEF, 0xF0, 0x12, 0x8F,
-0x58, 0xF1, 0xE7, 0xFD, 0x7F, 0x02, 0x12, 0x57,
-0x82, 0x12, 0x8F, 0x58, 0x12, 0x71, 0xCB, 0x12,
-0xC2, 0xD4, 0xF0, 0x90, 0x85, 0xC5, 0x12, 0xD1,
-0x6E, 0x12, 0xB7, 0xDB, 0x90, 0x01, 0xBE, 0xF0,
-0x22, 0x90, 0x00, 0x03, 0x02, 0x03, 0x0F, 0x12,
-0xAF, 0xAE, 0xC4, 0x54, 0x0F, 0xFF, 0xBF, 0x0F,
-0x15, 0x90, 0x92, 0x09, 0xE0, 0x54, 0xFE, 0xF0,
-0x12, 0xAF, 0x8A, 0x12, 0x98, 0xD7, 0x54, 0x0F,
-0xFF, 0x51, 0xC7, 0x02, 0xBC, 0x2F, 0x12, 0x8F,
-0x6D, 0x12, 0xD1, 0xF1, 0xF1, 0xFC, 0xF5, 0x83,
-0xEF, 0x12, 0x8F, 0xF2, 0x54, 0x03, 0xFF, 0x51,
-0xB7, 0x54, 0xFC, 0x12, 0x8F, 0xF1, 0x54, 0x1C,
-0xFF, 0xEE, 0x54, 0x0F, 0xFE, 0x51, 0xB8, 0x54,
-0xE3, 0x12, 0x8F, 0xF1, 0x54, 0xE0, 0xFF, 0xEE,
-0x51, 0xB8, 0x54, 0x1F, 0x4F, 0xF0, 0xF1, 0xE7,
-0xFF, 0x12, 0x02, 0xF6, 0x54, 0x0F, 0xFD, 0xE4,
-0xFB, 0x51, 0xAE, 0xF1, 0xF6, 0xFF, 0x12, 0x02,
-0xF6, 0x54, 0x0F, 0xFD, 0x7B, 0x01, 0x51, 0xAE,
-0x31, 0x09, 0x33, 0x33, 0x33, 0x54, 0xF8, 0x12,
-0xD1, 0xF1, 0xFD, 0x75, 0xF0, 0x0E, 0xA4, 0x24,
-0x16, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
-0xEF, 0xF0, 0x31, 0x09, 0xC4, 0x13, 0x54, 0x07,
-0xFF, 0xED, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x17,
-0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xEF,
-0xF0, 0xEE, 0xC4, 0x54, 0x0F, 0xFF, 0x14, 0x6D,
-0x70, 0x21, 0x90, 0x92, 0x0B, 0xEF, 0xF0, 0x11,
-0x39, 0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFF, 0x90,
-0x92, 0x0A, 0xE0, 0x54, 0x0F, 0x4F, 0xF0, 0x54,
-0xF1, 0xF0, 0x90, 0x92, 0x09, 0xE0, 0x44, 0x01,
-0x12, 0xD1, 0x23, 0x22, 0x8F, 0x5E, 0x8D, 0x5F,
-0xAE, 0x03, 0x74, 0x1F, 0xC3, 0x95, 0x5E, 0x40,
-0x0A, 0x51, 0xA6, 0xE4, 0xFD, 0x51, 0x9E, 0x24,
-0xD4, 0x80, 0x31, 0x74, 0x3F, 0xC3, 0x95, 0x5E,
-0x40, 0x0A, 0x51, 0xA6, 0x7D, 0x20, 0x51, 0x9C,
-0x24, 0x88, 0x80, 0x20, 0x74, 0x5F, 0xC3, 0x95,
-0x5E, 0x40, 0x0A, 0x51, 0xA6, 0x7D, 0x40, 0x51,
-0x9C, 0x24, 0xD0, 0x80, 0x0F, 0x74, 0x7F, 0xC3,
-0x95, 0x5E, 0x40, 0x20, 0x51, 0xA6, 0x7D, 0x60,
-0x51, 0x9C, 0x24, 0x84, 0xFD, 0xE4, 0x34, 0x04,
-0xFC, 0xE5, 0x5F, 0x12, 0xD1, 0x13, 0xF5, 0x83,
-0x75, 0xF0, 0x03, 0xEE, 0x12, 0x05, 0x28, 0xEC,
-0xF0, 0xA3, 0xED, 0xF0, 0x22, 0xC3, 0xEF, 0x9D,
-0xF5, 0x60, 0xC3, 0x94, 0x08, 0x50, 0x1C, 0xE4,
-0xF5, 0x61, 0x71, 0x9F, 0xC0, 0x83, 0xC0, 0x82,
-0x90, 0x93, 0xC7, 0xE0, 0xD0, 0x82, 0xD0, 0x83,
-0x75, 0xF0, 0x03, 0x12, 0x05, 0x28, 0xE5, 0x60,
-0xF0, 0x80, 0x3E, 0xE5, 0x60, 0xC3, 0x94, 0x10,
-0x50, 0x09, 0x75, 0x61, 0x01, 0xE5, 0x60, 0x24,
-0xF8, 0x80, 0x17, 0xE5, 0x60, 0xC3, 0x94, 0x18,
-0x50, 0x09, 0x75, 0x61, 0x02, 0xE5, 0x60, 0x24,
-0xF0, 0x80, 0x07, 0x75, 0x61, 0x03, 0xE5, 0x60,
-0x24, 0xE8, 0xFF, 0x71, 0x9F, 0xC0, 0x83, 0xC0,
-0x82, 0x90, 0x93, 0xC7, 0xE0, 0xD0, 0x82, 0xD0,
-0x83, 0x75, 0xF0, 0x03, 0x12, 0x05, 0x28, 0xEF,
-0xF0, 0xAF, 0x61, 0x22, 0xAF, 0x5E, 0x51, 0x35,
-0x90, 0x93, 0xC3, 0xEF, 0xF0, 0x22, 0x90, 0x93,
-0xC7, 0xEE, 0xF0, 0xAB, 0x5F, 0x22, 0x31, 0xD4,
-0xAB, 0x5B, 0xAA, 0x5C, 0xA9, 0x5D, 0x22, 0xED,
-0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x0E, 0xF5, 0x82,
-0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0x22, 0x8F,
-0x5E, 0xD1, 0xE6, 0xE5, 0x5E, 0xF1, 0xFD, 0xF5,
-0x83, 0xE0, 0xFC, 0xE5, 0x5E, 0x51, 0xB8, 0x12,
-0xD0, 0x5A, 0xAF, 0x04, 0x12, 0xA9, 0x59, 0xE5,
-0x5E, 0x51, 0xB8, 0x12, 0x8B, 0xBE, 0xE5, 0x5E,
-0x12, 0xAA, 0xE3, 0xFD, 0xB1, 0x92, 0xB1, 0x82,
-0xAD, 0x5E, 0x7F, 0x01, 0x80, 0x00, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xF9,
-0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0xE4, 0xA3, 0xF0,
-0x90, 0x94, 0xFB, 0xE0, 0xFF, 0xC3, 0x94, 0x03,
-0x40, 0x02, 0x61, 0x9A, 0x90, 0x94, 0xFA, 0xE0,
-0xFE, 0x12, 0xD1, 0x13, 0xF5, 0x83, 0x75, 0xF0,
-0x03, 0xEF, 0x12, 0xD1, 0x7B, 0xE0, 0x90, 0x94,
-0xFC, 0xF0, 0x90, 0x94, 0xF9, 0xE0, 0xFC, 0xB4,
-0x02, 0x20, 0x90, 0x94, 0xFC, 0xE0, 0xFD, 0xEE,
-0x71, 0xA0, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x94,
-0xFB, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0x12, 0xB2,
-0x7B, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4D,
-0x80, 0x20, 0xEC, 0xB4, 0x01, 0x20, 0x12, 0xD1,
-0x9D, 0x71, 0xA0, 0xC0, 0x83, 0xC0, 0x82, 0x90,
-0x94, 0xFB, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0x12,
-0xB2, 0x7B, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xF4, 0x5F, 0x90, 0x94, 0xFC, 0xF0, 0x12, 0xD1,
-0x9D, 0x12, 0xD1, 0x13, 0xF5, 0x83, 0xC0, 0x83,
-0xC0, 0x82, 0x90, 0x94, 0xFB, 0xE0, 0xD0, 0x82,
-0xD0, 0x83, 0x75, 0xF0, 0x03, 0x12, 0xD1, 0x7B,
-0xEF, 0xF0, 0x90, 0x94, 0xFB, 0xE0, 0x04, 0xF0,
-0x61, 0x08, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEB,
-0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x11, 0xF5, 0x82,
-0xE4, 0x34, 0x92, 0xF5, 0x83, 0x22, 0x12, 0xD0,
-0xA7, 0xB5, 0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0,
-0x12, 0xC5, 0xF1, 0xE4, 0x90, 0x92, 0x0C, 0xF0,
-0xD1, 0xEE, 0x12, 0xD0, 0xBE, 0xF1, 0xFC, 0xF5,
-0x83, 0xE0, 0xFA, 0x51, 0xB7, 0xFC, 0x54, 0x03,
-0xFD, 0xEC, 0x13, 0x13, 0x54, 0x07, 0xFB, 0xEE,
-0x12, 0xD0, 0x69, 0xAF, 0x02, 0x12, 0xA9, 0x59,
-0x91, 0x0E, 0x51, 0xB8, 0x12, 0x8B, 0xBE, 0x91,
-0x0E, 0xFF, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x18,
-0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0,
-0x04, 0xF0, 0x12, 0xAA, 0xE2, 0xFD, 0xB1, 0x92,
-0xE4, 0xFB, 0xFD, 0x91, 0x0A, 0xFD, 0x7F, 0x01,
-0x41, 0xF6, 0x7F, 0xFF, 0xB1, 0x87, 0x90, 0x92,
-0x0A, 0xE0, 0xC3, 0x13, 0x54, 0x07, 0x22, 0xE4,
-0x90, 0x94, 0x7F, 0xF0, 0x90, 0x92, 0x0A, 0xE0,
-0xFF, 0x20, 0xE0, 0x02, 0xA1, 0x81, 0x12, 0x8F,
-0xA2, 0x54, 0x07, 0x90, 0x94, 0x7C, 0xF0, 0x60,
-0x07, 0xE0, 0x64, 0x02, 0x60, 0x02, 0xA1, 0x25,
-0x90, 0x92, 0x0C, 0xE0, 0x70, 0x2E, 0x12, 0xD1,
-0xB0, 0x7B, 0x4E, 0x7D, 0x6F, 0x91, 0x0A, 0xF1,
-0xD9, 0xE0, 0xFF, 0x7E, 0x00, 0x7B, 0x04, 0x7D,
-0x01, 0xB1, 0x92, 0xBF, 0x01, 0x0D, 0xF1, 0x5A,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x92, 0x0C, 0x74,
-0x01, 0xF0, 0x22, 0x90, 0x94, 0x7D, 0xE0, 0xFD,
-0x7B, 0x4F, 0x81, 0xFD, 0x90, 0x92, 0x0C, 0xE0,
-0x64, 0x01, 0x60, 0x02, 0xA1, 0x16, 0x91, 0x0E,
-0xFF, 0x12, 0x8F, 0xA6, 0xFE, 0xC4, 0x54, 0x0F,
-0x30, 0xE0, 0x02, 0xA1, 0x14, 0xEF, 0xF1, 0x62,
-0xE0, 0xFF, 0x30, 0xE0, 0x08, 0x90, 0x94, 0x7F,
-0x74, 0x01, 0xF0, 0x80, 0x17, 0xEF, 0xC3, 0x13,
-0x20, 0xE0, 0x11, 0x90, 0x94, 0x7F, 0x74, 0x01,
-0xF0, 0x12, 0xD1, 0xB0, 0x7B, 0x50, 0x7D, 0x6F,
-0x7F, 0xFF, 0xB1, 0x87, 0x90, 0x94, 0x7F, 0xE0,
-0x60, 0x64, 0x90, 0x92, 0xBB, 0xE0, 0xFF, 0x90,
-0x92, 0xBA, 0xE0, 0x6F, 0x60, 0x43, 0xE0, 0x04,
-0xF0, 0xE0, 0xD3, 0x94, 0x01, 0x40, 0x08, 0x90,
-0x94, 0x80, 0x74, 0x04, 0xF0, 0x80, 0x05, 0xE4,
-0x90, 0x94, 0x80, 0xF0, 0x91, 0x0E, 0xF1, 0xD9,
-0xE0, 0xFF, 0x7E, 0x00, 0x90, 0x94, 0x80, 0xE0,
-0xFB, 0x7D, 0x01, 0xB1, 0x92, 0xBF, 0x01, 0x0E,
-0x12, 0xD1, 0x57, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F,
-0x58, 0x7E, 0x01, 0x02, 0x61, 0x41, 0x90, 0x94,
-0x7D, 0xE0, 0xFD, 0x7B, 0x51, 0xE4, 0xFF, 0xA1,
-0x87, 0xE4, 0x90, 0x92, 0xBA, 0xF1, 0xED, 0x90,
-0x92, 0x0A, 0xE0, 0xFF, 0xF1, 0x5E, 0xE0, 0x54,
-0xFB, 0xF0, 0x80, 0x02, 0xF1, 0xEE, 0x90, 0x92,
-0x0C, 0xE0, 0x64, 0x05, 0x70, 0x63, 0xD1, 0x37,
-0xEF, 0x70, 0x5E, 0x80, 0x57, 0x90, 0x94, 0x7C,
-0xE0, 0xFF, 0x64, 0x03, 0x60, 0x05, 0xEF, 0x64,
-0x01, 0x70, 0x4E, 0x90, 0x92, 0x0C, 0xE0, 0x64,
-0x05, 0x70, 0x46, 0x90, 0x94, 0x7C, 0xE0, 0x64,
-0x01, 0x70, 0x2C, 0x12, 0x8F, 0x79, 0xE0, 0xD3,
-0x94, 0x1F, 0x90, 0x92, 0x0A, 0xE0, 0x40, 0x0A,
-0xF1, 0xD6, 0xE0, 0xFF, 0x7D, 0x00, 0x7C, 0x7C,
-0x80, 0x12, 0xC3, 0xF1, 0xD6, 0xE0, 0xFB, 0x12,
-0x8F, 0x79, 0xE0, 0x7D, 0x00, 0x25, 0xE0, 0x25,
-0xE0, 0xFC, 0xAF, 0x03, 0x12, 0x98, 0xEE, 0x91,
-0x0E, 0xFD, 0x7F, 0x02, 0x12, 0xAA, 0x52, 0xD1,
-0x37, 0xEF, 0x70, 0x05, 0x7F, 0x06, 0x12, 0xAA,
-0xF7, 0x22, 0xE4, 0xFB, 0xFD, 0x7F, 0xFF, 0x90,
-0x05, 0x22, 0xED, 0xF0, 0x90, 0x92, 0x01, 0xEB,
-0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x94, 0xF2, 0xEE, 0xF0, 0xA3, 0x12,
-0xB1, 0x03, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x27,
-0x90, 0x05, 0x22, 0xE0, 0x90, 0x94, 0xF8, 0xF0,
-0x7B, 0x14, 0xD1, 0xE8, 0xEF, 0x64, 0x01, 0x70,
-0x05, 0x12, 0xD0, 0x71, 0x80, 0x04, 0x7F, 0x00,
-0x80, 0x15, 0x90, 0x94, 0xF8, 0xE0, 0xFD, 0x7B,
-0x15, 0xE4, 0xFF, 0xB1, 0x87, 0x80, 0x03, 0x12,
-0xD0, 0x71, 0x12, 0x9F, 0xF8, 0x7F, 0x01, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x92, 0x09, 0xE0,
-0x30, 0xE0, 0x53, 0x90, 0x92, 0x0C, 0xE0, 0x70,
-0x25, 0x7B, 0x16, 0x7D, 0x6F, 0xD1, 0xEA, 0x91,
-0x0E, 0x12, 0xAA, 0xE3, 0x7D, 0x01, 0xB1, 0x92,
-0x91, 0x0E, 0x12, 0xC5, 0x01, 0xE0, 0x44, 0x01,
-0xF0, 0x12, 0xD1, 0x57, 0x12, 0xC6, 0x20, 0x90,
-0x92, 0x0C, 0x74, 0x01, 0xF0, 0x22, 0x90, 0x92,
-0x0C, 0xE0, 0x64, 0x01, 0x70, 0x1E, 0x91, 0x0E,
-0x12, 0xC5, 0x00, 0xE0, 0x30, 0xE0, 0x15, 0x12,
-0xAA, 0xE2, 0x7D, 0x01, 0xB1, 0x92, 0x12, 0xD1,
-0x57, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54, 0x7E,
-0x01, 0x02, 0x61, 0x41, 0x71, 0xAE, 0x22, 0xD1,
-0xEE, 0xEF, 0x70, 0x02, 0xFF, 0x22, 0x91, 0x0E,
-0x90, 0x92, 0x88, 0xF0, 0x12, 0xD0, 0xA7, 0xB5,
-0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0, 0x91, 0x0E,
-0xF5, 0x77, 0xE4, 0x90, 0x92, 0x0C, 0xF0, 0xE5,
-0x77, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x3B, 0xF5,
-0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0x30,
-0xE0, 0x27, 0xF1, 0x4E, 0xE0, 0x24, 0x8B, 0xF5,
-0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0xFF,
-0x12, 0xAA, 0xD2, 0xEF, 0xF1, 0x4D, 0xE0, 0x04,
-0xF1, 0x4D, 0xE0, 0xFF, 0x90, 0x92, 0x8A, 0xE0,
-0xFE, 0xEF, 0xB5, 0x06, 0x04, 0xF1, 0x4E, 0xE4,
-0xF0, 0x12, 0xAA, 0xD2, 0xE0, 0xFC, 0x90, 0x92,
-0x88, 0xE0, 0x12, 0xAA, 0xD4, 0xE0, 0x6C, 0x60,
-0x0F, 0xE5, 0x77, 0x12, 0xD0, 0x4C, 0xAF, 0x04,
-0x12, 0xA9, 0x59, 0xE5, 0x77, 0x12, 0x8B, 0xB0,
-0xE5, 0x77, 0x12, 0x8F, 0xA6, 0x54, 0x07, 0xFF,
-0x60, 0x03, 0xBF, 0x02, 0x0E, 0xE5, 0x77, 0xF1,
-0xD9, 0xE0, 0xFF, 0x7E, 0x00, 0x7B, 0x04, 0xE4,
-0xFD, 0xB1, 0x92, 0xAD, 0x77, 0x7F, 0x01, 0x12,
-0xAA, 0x52, 0x90, 0x92, 0x89, 0xE0, 0xC3, 0x13,
-0x54, 0x03, 0xFF, 0xBF, 0x02, 0x05, 0xE4, 0xFF,
-0x12, 0xAA, 0xF7, 0x7F, 0x01, 0x22, 0x7B, 0x17,
-0x7D, 0xFF, 0x7F, 0xFF, 0xB1, 0x87, 0xE4, 0x90,
-0x95, 0x05, 0xF0, 0xA3, 0xF0, 0x90, 0x05, 0x22,
-0xE0, 0x90, 0x95, 0x07, 0xF0, 0x7D, 0x47, 0x7F,
-0xFF, 0x12, 0x98, 0xE3, 0x90, 0x05, 0xF8, 0xE0,
-0x70, 0x15, 0xA3, 0xE0, 0x70, 0x11, 0xA3, 0xE0,
-0x70, 0x0D, 0xA3, 0xE0, 0x70, 0x09, 0x12, 0xD1,
-0xE9, 0x12, 0x98, 0xE3, 0x7F, 0x01, 0x22, 0xD3,
-0x90, 0x95, 0x06, 0xE0, 0x94, 0xE8, 0x90, 0x95,
-0x05, 0xE0, 0x94, 0x03, 0x40, 0x10, 0x90, 0x01,
-0xC0, 0xE0, 0x44, 0x20, 0xF0, 0x12, 0xD1, 0xE9,
-0x12, 0x98, 0xE3, 0x7F, 0x00, 0x22, 0x7F, 0x32,
-0x7E, 0x00, 0x12, 0x7C, 0x9F, 0x90, 0x95, 0x05,
-0x12, 0xBD, 0xFF, 0x80, 0xB7, 0xF0, 0x74, 0xAE,
-0x25, 0x77, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5,
-0x83, 0x22, 0x90, 0x92, 0x0A, 0xE0, 0xC3, 0x13,
-0x54, 0x07, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x3E,
-0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0x22,
-0xE4, 0x90, 0x94, 0x6F, 0xF0, 0x90, 0x92, 0x0A,
-0xE0, 0x30, 0xE0, 0x59, 0xC3, 0x13, 0x54, 0x07,
-0xFF, 0xF1, 0x62, 0xE0, 0xFE, 0x30, 0xE0, 0x4D,
-0xEF, 0xF1, 0x62, 0xEE, 0x54, 0xFE, 0xF0, 0xEF,
-0xF1, 0x62, 0x12, 0xC4, 0xB9, 0x30, 0xE0, 0x11,
-0x90, 0x92, 0x0A, 0xE0, 0xFE, 0xF1, 0x5E, 0xEF,
-0x54, 0xFB, 0xF0, 0x90, 0x94, 0x6F, 0x74, 0x01,
-0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x30, 0xE1, 0x1D,
-0xF1, 0xEE, 0xF1, 0x5A, 0xE0, 0x44, 0x02, 0xF0,
-0xE4, 0x90, 0x92, 0xBA, 0xF0, 0x91, 0x0E, 0xFD,
-0x7F, 0x02, 0x12, 0xAA, 0x52, 0x90, 0x94, 0x6F,
-0xE0, 0x60, 0x0A, 0x81, 0x17, 0xF1, 0x5A, 0xE0,
-0x54, 0xFD, 0xF0, 0xB1, 0x82, 0x22, 0x13, 0x54,
-0x07, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x40, 0xF5,
-0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0x22, 0x90,
-0x00, 0x04, 0x02, 0x03, 0x0F, 0xF0, 0x90, 0x92,
-0x0C, 0x74, 0x05, 0xF0, 0x22, 0xF0, 0x90, 0x00,
-0x05, 0x02, 0x03, 0x0F, 0xFD, 0x75, 0xF0, 0x0E,
-0xA4, 0x24, 0x0D, 0xF5, 0x82, 0xE4, 0x34, 0x92,
-0x22, 0x8B, 0x5B, 0x8A, 0x5C, 0x89, 0x5D, 0x90,
-0x92, 0xBD, 0xE0, 0x70, 0x10, 0x12, 0x02, 0xF6,
-0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x06, 0x90,
-0x92, 0xC3, 0x74, 0x01, 0xF0, 0x90, 0x92, 0xBF,
-0xE0, 0x70, 0x0F, 0x11, 0xD7, 0xC4, 0x54, 0x0F,
-0xFF, 0xBF, 0x05, 0x06, 0x90, 0x92, 0xC4, 0x74,
-0x01, 0xF0, 0x12, 0x8F, 0x6D, 0xFF, 0xF5, 0x5F,
-0x12, 0x02, 0xF6, 0xFE, 0xC3, 0x13, 0x30, 0xE0,
-0x07, 0x12, 0x8F, 0xF3, 0xF5, 0x60, 0x80, 0x02,
-0x8F, 0x60, 0x85, 0x5F, 0x5E, 0xE5, 0x5E, 0xD3,
-0x95, 0x60, 0x50, 0x28, 0x11, 0xD7, 0x54, 0x01,
-0xFD, 0xAF, 0x5E, 0x12, 0x6E, 0x5F, 0xAF, 0x5E,
-0x12, 0x77, 0x39, 0xEF, 0xAF, 0x5E, 0x70, 0x04,
-0x11, 0x9F, 0x80, 0x02, 0xF1, 0xE0, 0x90, 0x92,
-0xC4, 0xE0, 0x60, 0x04, 0xAF, 0x5E, 0x11, 0x9F,
-0x05, 0x5E, 0x80, 0xD1, 0xE5, 0x5F, 0x70, 0x16,
-0xFF, 0x12, 0x77, 0x39, 0xEF, 0x70, 0x0F, 0x12,
-0xBF, 0x8B, 0x12, 0x79, 0x61, 0x12, 0xC6, 0xA5,
-0x54, 0xBF, 0xF0, 0x54, 0x7F, 0xF0, 0x22, 0x7D,
-0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x93, 0xC3, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
-0x7D, 0x44, 0x7F, 0x6F, 0x51, 0x81, 0x90, 0x93,
-0xC4, 0xE0, 0x90, 0x93, 0xC3, 0xB4, 0x01, 0x09,
-0xE0, 0x51, 0xBC, 0xE0, 0x44, 0x04, 0xF0, 0x80,
-0x07, 0xE0, 0x51, 0xBC, 0xE0, 0x54, 0xFB, 0xF0,
-0x11, 0xE0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xAB,
-0x5B, 0xAA, 0x5C, 0xA9, 0x5D, 0x02, 0x02, 0xF6,
-0xE4, 0xFD, 0xFF, 0x90, 0x05, 0x22, 0xEF, 0xF0,
-0x90, 0x92, 0x01, 0xED, 0xF0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0x81,
-0xEF, 0xF0, 0xA3, 0xEC, 0xF0, 0xA3, 0xED, 0xF0,
-0x90, 0x04, 0x1D, 0xE0, 0x60, 0x1C, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x94, 0x86, 0xF0, 0x7D, 0x36,
-0x51, 0x7F, 0xBF, 0x01, 0x02, 0x31, 0xD4, 0x90,
-0x94, 0x86, 0xE0, 0xFF, 0x7D, 0x37, 0x11, 0xE3,
-0x80, 0x02, 0x31, 0xD4, 0x90, 0x05, 0x22, 0xE0,
-0x54, 0x6F, 0xFF, 0x7D, 0x38, 0x11, 0xE3, 0xF1,
-0xF8, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xFE,
-0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x94, 0xFD,
-0xEF, 0xF0, 0xE4, 0xFD, 0xFC, 0x12, 0x7B, 0x2A,
-0x7C, 0x00, 0xAD, 0x07, 0x90, 0x94, 0xFD, 0xE0,
-0x90, 0x04, 0x25, 0xF0, 0x90, 0x94, 0xFE, 0xE0,
-0x60, 0x05, 0x51, 0xAC, 0x44, 0x80, 0xF0, 0xAF,
-0x05, 0x74, 0x20, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xE0, 0x54, 0xC0, 0xF0, 0x51,
-0xAC, 0x54, 0xC0, 0xF0, 0x90, 0x95, 0x00, 0xE0,
-0xFF, 0xAE, 0x05, 0x74, 0x18, 0x2E, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x51,
-0x8E, 0xF5, 0x83, 0xE0, 0x20, 0xE1, 0x17, 0x54,
-0x01, 0xFF, 0x90, 0x94, 0xFF, 0xE0, 0x25, 0xE0,
-0x25, 0xE0, 0xFB, 0xEF, 0x44, 0x02, 0x4B, 0xFF,
-0x51, 0x8E, 0xF5, 0x83, 0xEF, 0xF0, 0xAF, 0x05,
-0x74, 0x11, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
-0xF5, 0x83, 0x74, 0xFF, 0xF0, 0x74, 0x29, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
-0x54, 0xF7, 0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x94, 0x81, 0xE0,
-0xFF, 0x90, 0x95, 0x00, 0x74, 0x0C, 0xF0, 0xE4,
-0xFB, 0x7D, 0x01, 0x31, 0x36, 0x90, 0x94, 0x84,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x94, 0x82,
-0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0x02, 0x77, 0xD8,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x94, 0x92, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0x90,
-0x84, 0xC3, 0xE0, 0x04, 0xF0, 0x90, 0x04, 0x1D,
-0xE0, 0x60, 0x35, 0x90, 0x05, 0x22, 0xE0, 0x90,
-0x94, 0x96, 0xF0, 0x7D, 0x26, 0x51, 0x7F, 0xEF,
-0x64, 0x01, 0x70, 0x17, 0x51, 0x97, 0xFB, 0x7D,
-0x01, 0x12, 0x3A, 0xC2, 0x12, 0xD0, 0xFC, 0x20,
-0xE0, 0x09, 0x90, 0x92, 0x09, 0xE0, 0x20, 0xE0,
-0x02, 0x51, 0xA1, 0x90, 0x94, 0x96, 0xE0, 0xFF,
-0x7D, 0x27, 0x11, 0xE3, 0x51, 0x86, 0x80, 0x1E,
-0x51, 0x86, 0x51, 0x97, 0xFB, 0x90, 0x95, 0x00,
-0x74, 0x0A, 0xF0, 0x7D, 0x01, 0x31, 0x36, 0x12,
-0xD0, 0xFC, 0x20, 0xE0, 0x09, 0x90, 0x92, 0x09,
-0xE0, 0x20, 0xE0, 0x02, 0x51, 0xA1, 0xF1, 0xF8,
-0x90, 0x84, 0xBF, 0xA3, 0xE0, 0x24, 0x7F, 0xF5,
-0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0x74, 0x01,
-0xF0, 0xFF, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7F,
-0xFF, 0x11, 0xE3, 0x02, 0x96, 0xEE, 0x90, 0x94,
-0x92, 0xE0, 0xFF, 0x02, 0x5C, 0xA3, 0x74, 0x12,
-0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0x22, 0x90,
-0x84, 0xC8, 0xE0, 0xFF, 0x90, 0x94, 0x93, 0xE0,
-0x22, 0x90, 0x94, 0x94, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x02, 0x50, 0xD7, 0x74, 0x21, 0x2F, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22,
-0xE0, 0xFD, 0xE5, 0x76, 0xC4, 0x54, 0xF0, 0x24,
-0x05, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
-0x22, 0x8D, 0x76, 0xEF, 0x30, 0xE6, 0x1A, 0x71,
-0x48, 0x51, 0xB8, 0xE0, 0x54, 0x03, 0x90, 0x91,
-0x0B, 0xF0, 0xE4, 0xFB, 0xAF, 0x76, 0x12, 0x27,
-0x3D, 0x71, 0x3B, 0xD1, 0x5D, 0x74, 0x01, 0x80,
-0x49, 0xD1, 0x64, 0x04, 0xF0, 0xD1, 0x64, 0x64,
-0x02, 0x70, 0x1E, 0x74, 0xA9, 0x25, 0x76, 0xF1,
-0x41, 0xE0, 0xFD, 0xF4, 0x60, 0x02, 0x80, 0x04,
-0x71, 0x48, 0xE0, 0xFD, 0x51, 0xBA, 0x12, 0xD1,
-0x3B, 0x71, 0x48, 0xD1, 0x5D, 0x74, 0x02, 0x80,
-0x21, 0xD1, 0x64, 0xD3, 0x94, 0x03, 0x40, 0x0D,
-0xAF, 0x76, 0x12, 0x6D, 0x94, 0x71, 0x3B, 0xD1,
-0x5D, 0x74, 0x03, 0x80, 0x0D, 0x71, 0x48, 0x51,
-0xB8, 0x12, 0xD1, 0x3B, 0x71, 0x48, 0xD1, 0x5D,
-0x74, 0x02, 0xF0, 0xAB, 0x76, 0xE4, 0xFD, 0xFF,
-0x02, 0x52, 0xC3, 0x74, 0xBC, 0x25, 0x76, 0xF5,
-0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0xE4, 0xF0,
-0xE5, 0x76, 0xC4, 0x54, 0xF0, 0x24, 0x00, 0xF5,
-0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x90,
-0x04, 0x85, 0xE0, 0xF5, 0x6B, 0x90, 0x94, 0xA8,
-0xE0, 0x04, 0xF0, 0xE4, 0xF5, 0x63, 0x90, 0x85,
-0xBB, 0xE0, 0xFF, 0xE5, 0x63, 0xC3, 0x9F, 0x40,
-0x02, 0xC1, 0x44, 0xE5, 0x63, 0x71, 0x4A, 0xE0,
-0xF5, 0x6D, 0x12, 0xD1, 0x87, 0xE0, 0x65, 0x6D,
-0x60, 0x16, 0x90, 0x8A, 0x71, 0xE5, 0x6D, 0xF0,
-0xE4, 0xA3, 0xF0, 0xAB, 0x63, 0xFD, 0xFF, 0x12,
-0x52, 0xC3, 0x12, 0xD1, 0x87, 0xE5, 0x6D, 0xF0,
-0x90, 0x04, 0xA0, 0xE0, 0x64, 0x01, 0x70, 0x4C,
-0xA3, 0xE0, 0x65, 0x63, 0x70, 0x46, 0xA3, 0xE0,
-0xF5, 0x64, 0xA3, 0xE0, 0x90, 0x94, 0x45, 0xF0,
-0xE5, 0x63, 0x71, 0x4A, 0xE0, 0x65, 0x64, 0x70,
-0x02, 0xC1, 0x40, 0xE5, 0x63, 0x71, 0x4A, 0xE5,
-0x64, 0xF0, 0xE5, 0x63, 0x51, 0xBC, 0xE0, 0x54,
-0xFC, 0xFF, 0x90, 0x94, 0x45, 0xE0, 0x54, 0x03,
-0x4F, 0xFF, 0xE5, 0x63, 0x51, 0xBC, 0xEF, 0xF0,
-0x90, 0x8A, 0x71, 0xE5, 0x64, 0xF0, 0xA3, 0x74,
-0xFF, 0xF0, 0xAB, 0x63, 0xE4, 0xFD, 0xFF, 0x12,
-0x52, 0xC3, 0xC1, 0x40, 0xAF, 0x63, 0x12, 0x77,
-0x39, 0xEF, 0x70, 0x02, 0xC1, 0x40, 0x75, 0xF0,
-0x12, 0xE5, 0x63, 0x12, 0xA1, 0x8F, 0x12, 0xA3,
-0x01, 0x30, 0xE0, 0x02, 0xC1, 0x40, 0xE5, 0x63,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x24, 0x75, 0x12,
-0xB3, 0x11, 0x7C, 0x00, 0xE5, 0x63, 0x12, 0xB2,
-0x90, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
-0xD8, 0xF9, 0xFF, 0xEE, 0x5C, 0xFE, 0xEF, 0x5D,
-0x4E, 0x60, 0x02, 0xC1, 0x40, 0xF1, 0xD5, 0xE0,
-0xFE, 0xA3, 0xE0, 0x4E, 0x70, 0x07, 0xF1, 0xCA,
-0xE0, 0x70, 0x02, 0xC1, 0x40, 0xE5, 0x63, 0x75,
-0xF0, 0x12, 0xA4, 0x24, 0x44, 0xF9, 0x74, 0x89,
-0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x90, 0x94, 0x40,
-0x12, 0x87, 0x4E, 0x90, 0x00, 0x02, 0x12, 0x04,
-0x18, 0xFF, 0x12, 0x03, 0xED, 0x2F, 0xFF, 0x12,
-0xD1, 0xE1, 0xFF, 0x12, 0xD1, 0xB9, 0x90, 0x00,
-0x08, 0x12, 0x04, 0x18, 0x2F, 0xF5, 0x6C, 0xF1,
-0xD5, 0xE0, 0xF5, 0x68, 0xA3, 0xE0, 0xF5, 0x69,
-0xF1, 0xCA, 0xE0, 0xFF, 0x90, 0x94, 0x43, 0xE4,
-0xF0, 0xA3, 0xEF, 0xF0, 0xE5, 0x63, 0x71, 0x4A,
-0xE0, 0xF5, 0x64, 0x54, 0x80, 0xFF, 0xE5, 0x64,
-0x54, 0x7F, 0xF5, 0x65, 0x75, 0xF0, 0x12, 0xE5,
-0x63, 0x12, 0xB5, 0x17, 0xFE, 0xE5, 0x65, 0xD3,
-0x9E, 0x40, 0x07, 0x8E, 0x65, 0xE5, 0x65, 0x4F,
-0xF5, 0x64, 0x74, 0x7C, 0x25, 0x63, 0xF5, 0x82,
-0xE4, 0x34, 0x90, 0xF5, 0x83, 0xE0, 0xC3, 0x94,
-0x05, 0x40, 0x02, 0xC1, 0x3D, 0xE5, 0x65, 0x90,
-0x82, 0xE1, 0x93, 0xF5, 0x6A, 0xEF, 0x60, 0x04,
-0x05, 0x6A, 0x05, 0x6A, 0xE5, 0x65, 0xC3, 0x94,
-0x0C, 0x40, 0x21, 0x74, 0x98, 0x25, 0x63, 0xF5,
-0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0xFF,
-0x54, 0x7F, 0xFE, 0xEF, 0x30, 0xE7, 0x06, 0xE5,
-0x6A, 0x2E, 0xFF, 0x80, 0x05, 0xC3, 0xE5, 0x6A,
-0x9E, 0xFF, 0x8F, 0x6A, 0xE5, 0x6A, 0xD3, 0x94,
-0x1A, 0xAF, 0x6A, 0x40, 0x02, 0x7F, 0x1A, 0x8F,
-0x6A, 0xE5, 0x64, 0x90, 0x83, 0x59, 0x93, 0xFF,
-0xD3, 0x90, 0x94, 0x44, 0xE0, 0x9F, 0x90, 0x94,
-0x43, 0xE0, 0x94, 0x00, 0x40, 0x02, 0xA1, 0xFD,
-0xC3, 0xE5, 0x69, 0x94, 0x0A, 0xE5, 0x68, 0x94,
-0x00, 0x40, 0x02, 0xA1, 0xB8, 0xD1, 0x45, 0xE0,
-0xC3, 0x94, 0x01, 0x40, 0x05, 0xD1, 0x45, 0xE0,
-0x14, 0xF0, 0x90, 0x94, 0x40, 0x12, 0x87, 0x45,
-0x90, 0x00, 0x08, 0x12, 0x04, 0x18, 0xFF, 0x90,
-0x94, 0x44, 0xE0, 0x2F, 0xFF, 0x90, 0x94, 0x43,
-0xE0, 0x35, 0xF0, 0xFE, 0x12, 0xD1, 0xB9, 0xEE,
-0x35, 0xF0, 0xFE, 0x12, 0xD1, 0xE1, 0xFD, 0xEE,
-0x35, 0xF0, 0xFC, 0xE5, 0x68, 0xC3, 0x13, 0xFE,
-0xE5, 0x69, 0x13, 0xFF, 0xD3, 0xED, 0x9F, 0xEC,
-0x9E, 0x40, 0x0D, 0xE5, 0x63, 0x94, 0x05, 0x50,
-0x05, 0xD1, 0x45, 0x74, 0x03, 0xF0, 0xA1, 0xFD,
-0x90, 0x94, 0x40, 0x12, 0x87, 0x45, 0x12, 0x03,
-0xED, 0x65, 0x6C, 0x70, 0x02, 0xE5, 0xF0, 0x70,
-0x2A, 0xE5, 0x63, 0xC3, 0x94, 0x05, 0x50, 0x0A,
-0xD1, 0x45, 0xE0, 0xD3, 0x94, 0x00, 0x40, 0x02,
-0x80, 0x07, 0xE5, 0x6C, 0xC3, 0x94, 0x03, 0x50,
-0x08, 0x7D, 0x06, 0xAF, 0x63, 0xF1, 0x6F, 0xC1,
-0x40, 0xE4, 0xFD, 0xAF, 0x63, 0xD1, 0x71, 0xF1,
-0x6B, 0xC1, 0x3D, 0x12, 0xD1, 0xD2, 0xC1, 0x3D,
-0xD1, 0x45, 0xE4, 0xF0, 0x90, 0x94, 0x4A, 0x74,
-0x02, 0xF0, 0xAB, 0x6A, 0xAD, 0x63, 0xAF, 0x69,
-0xAE, 0x68, 0x12, 0xCB, 0x6F, 0x8E, 0x66, 0x8F,
-0x67, 0x12, 0xD1, 0x49, 0xC3, 0x74, 0x01, 0x93,
-0x95, 0x67, 0xE4, 0x93, 0x95, 0x66, 0x50, 0x0C,
-0xD1, 0x51, 0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x63,
-0xD1, 0x71, 0x80, 0x51, 0x12, 0xD1, 0xD9, 0xC3,
-0xE5, 0x67, 0x9F, 0xE5, 0x66, 0x94, 0x00, 0x50,
-0x0D, 0xD1, 0x51, 0xE4, 0xF0, 0x7D, 0x01, 0xAF,
-0x63, 0x12, 0xB4, 0x58, 0x80, 0x37, 0xF1, 0x6B,
-0xD1, 0x51, 0xE0, 0x04, 0xF0, 0xE5, 0x65, 0x90,
-0x83, 0x6D, 0x93, 0xFF, 0xD1, 0x51, 0xE0, 0xC3,
-0x9F, 0x40, 0x22, 0xD1, 0x51, 0xE4, 0xF0, 0x12,
-0xD1, 0xD9, 0x12, 0xD1, 0x49, 0x74, 0x01, 0x93,
-0x2F, 0xFF, 0xE4, 0x93, 0x34, 0x00, 0xC3, 0x13,
-0xFE, 0xEF, 0x13, 0xFF, 0xE5, 0x63, 0xF1, 0x5F,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0xD1, 0xD2,
-0x05, 0x63, 0x61, 0x66, 0x22, 0x74, 0xB9, 0x25,
-0x63, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0x22, 0x74, 0xAC, 0x25, 0x63, 0xF5, 0x82, 0xE4,
-0x34, 0x8F, 0xF5, 0x83, 0x22, 0xE0, 0x90, 0x8A,
-0x71, 0xF0, 0xA3, 0x22, 0x74, 0xBC, 0x25, 0x76,
-0xF5, 0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0xE0,
-0x22, 0x8F, 0x6E, 0x8D, 0x6F, 0xEF, 0x71, 0x4A,
-0xE0, 0xFD, 0x54, 0x7F, 0xF5, 0x70, 0xED, 0x54,
-0x80, 0xF5, 0x71, 0x75, 0xF0, 0x12, 0xEF, 0x12,
-0xB5, 0x17, 0xF5, 0x73, 0x75, 0xF0, 0x12, 0xEF,
-0x12, 0xA1, 0x8F, 0xC4, 0x54, 0x03, 0xF5, 0x74,
-0xF1, 0x3D, 0x74, 0xFF, 0xF0, 0xF1, 0x49, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0xE5, 0x71, 0x4D, 0xFF,
-0x12, 0xB5, 0x0B, 0xEF, 0xF0, 0xE5, 0x6E, 0x51,
-0xBC, 0xE0, 0x54, 0x03, 0xF5, 0x72, 0x74, 0x4C,
-0x25, 0x6E, 0x12, 0xB5, 0x1F, 0xE5, 0x72, 0xF0,
-0xE5, 0x70, 0x65, 0x73, 0x70, 0x27, 0x75, 0xF0,
-0x12, 0xE5, 0x6E, 0x12, 0xA2, 0xEE, 0xC4, 0x13,
-0x54, 0x07, 0x30, 0xE0, 0x0B, 0xE5, 0x71, 0x70,
-0x07, 0xE5, 0x70, 0x44, 0x80, 0xFD, 0x80, 0x50,
-0xF1, 0x49, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x7D,
-0x07, 0xAF, 0x6E, 0xE1, 0x6F, 0xE5, 0x70, 0xC3,
-0x95, 0x73, 0x50, 0x35, 0xAB, 0x6E, 0xAD, 0x73,
-0xAF, 0x70, 0x12, 0x72, 0xEA, 0xAD, 0x07, 0xE5,
-0x70, 0xC3, 0x94, 0x0C, 0x40, 0x2A, 0x75, 0xF0,
-0x12, 0xE5, 0x6E, 0x12, 0xA2, 0xEE, 0xFE, 0xC4,
-0x13, 0x54, 0x07, 0x30, 0xE0, 0x1A, 0xE5, 0x6F,
-0x60, 0x16, 0xE5, 0x71, 0x70, 0x12, 0xE5, 0x70,
-0x44, 0x80, 0xFD, 0xF1, 0x3D, 0xEF, 0xF0, 0x80,
-0x07, 0x12, 0xB5, 0x0B, 0xE5, 0x73, 0xF0, 0xFD,
-0x90, 0x91, 0x0B, 0xE5, 0x72, 0xF0, 0xAB, 0x6F,
-0xAF, 0x6E, 0x02, 0x27, 0x3D, 0x74, 0xA9, 0x25,
-0x6E, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0x22, 0xE5, 0x70, 0x25, 0xE0, 0x24, 0xF5, 0xF5,
-0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0xE4, 0x93,
-0xFE, 0x74, 0x01, 0x93, 0xFF, 0xE5, 0x6E, 0x25,
-0xE0, 0x24, 0x7B, 0xF5, 0x82, 0xE4, 0x34, 0x8F,
-0xF5, 0x83, 0x22, 0x7D, 0x07, 0xAF, 0x63, 0xED,
-0x30, 0xE0, 0x22, 0x75, 0xF0, 0x12, 0xEF, 0x90,
-0x89, 0x44, 0xF1, 0xBE, 0x90, 0x89, 0x46, 0xF1,
-0xBE, 0x90, 0x89, 0x48, 0xF1, 0xBE, 0x90, 0x89,
-0x4A, 0xF1, 0xBE, 0x90, 0x89, 0x4C, 0x12, 0x05,
-0x28, 0xE4, 0xF0, 0xA3, 0xF0, 0xED, 0x30, 0xE1,
-0x0A, 0x75, 0xF0, 0x12, 0xEF, 0xF1, 0xDA, 0xE4,
-0xF0, 0xA3, 0xF0, 0xED, 0x30, 0xE2, 0x08, 0x75,
-0xF0, 0x12, 0xEF, 0xF1, 0xCF, 0xE4, 0xF0, 0x12,
-0xD1, 0x60, 0xE0, 0x54, 0xBF, 0x44, 0x80, 0xFE,
-0x12, 0xD1, 0x60, 0xEE, 0xF0, 0x22, 0x12, 0x05,
-0x28, 0xE4, 0xF0, 0xA3, 0xF0, 0x75, 0xF0, 0x12,
-0xEF, 0x22, 0x75, 0xF0, 0x12, 0xE5, 0x63, 0x90,
-0x89, 0x42, 0x02, 0x05, 0x28, 0x75, 0xF0, 0x12,
-0xE5, 0x63, 0x90, 0x89, 0x40, 0x02, 0x05, 0x28,
-0xE4, 0xFD, 0x01, 0xA1, 0x7D, 0x1F, 0x7F, 0x6F,
-0x11, 0xE3, 0x90, 0x05, 0x27, 0xE0, 0x54, 0xBF,
-0xF0, 0x90, 0x85, 0xBF, 0x74, 0x04, 0xF0, 0x22,
-0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0, 0x22, 0x11,
-0x37, 0x90, 0x04, 0x24, 0xE0, 0xF5, 0x5B, 0xE4,
-0xFF, 0x12, 0x8F, 0x58, 0x11, 0x2A, 0x75, 0xF0,
-0x0E, 0xA4, 0x24, 0x19, 0xF5, 0x82, 0xE4, 0x34,
-0x92, 0xF5, 0x83, 0xEE, 0xF0, 0x11, 0x2A, 0x12,
-0x97, 0xD9, 0xEE, 0xF0, 0x0F, 0xEF, 0xB4, 0x03,
-0xE0, 0x22, 0x8F, 0x82, 0x75, 0x83, 0x00, 0x12,
-0x03, 0x0F, 0x25, 0x5B, 0xFE, 0xEF, 0x22, 0x90,
-0x93, 0xC3, 0x02, 0x87, 0x4E, 0x11, 0x37, 0x12,
-0x8F, 0x58, 0x12, 0x02, 0xF6, 0x54, 0x7F, 0xFD,
-0x12, 0x8F, 0x73, 0xFE, 0x54, 0x1F, 0x90, 0x93,
-0xC7, 0x51, 0xFD, 0x90, 0x93, 0xC6, 0x12, 0x8F,
-0xF2, 0xFE, 0x54, 0x03, 0xFC, 0xEE, 0x54, 0x30,
-0xC4, 0x54, 0x0F, 0x90, 0x93, 0xC9, 0x12, 0x8F,
-0xF2, 0xFE, 0x54, 0x40, 0xC4, 0x13, 0x13, 0x54,
-0x03, 0x90, 0x93, 0xC8, 0x51, 0xFD, 0xFF, 0x12,
-0x8F, 0xF3, 0xFB, 0x54, 0x08, 0x13, 0x13, 0x13,
-0x54, 0x1F, 0x90, 0x93, 0xCB, 0xF0, 0xFA, 0xEB,
-0x54, 0x04, 0x13, 0x13, 0x54, 0x3F, 0xA3, 0xF0,
-0xEF, 0x54, 0x01, 0xC4, 0x33, 0x33, 0x33, 0x54,
-0x80, 0x31, 0x8A, 0x54, 0x7F, 0x4F, 0xF0, 0x90,
-0x93, 0xC8, 0xE0, 0x54, 0x01, 0xC4, 0x33, 0x33,
-0x54, 0xC0, 0x31, 0x8A, 0x54, 0xBF, 0x4F, 0xF0,
-0xEA, 0x60, 0x02, 0x21, 0x89, 0x90, 0x93, 0xC7,
-0xE0, 0x54, 0x1F, 0x51, 0xE9, 0x54, 0xE0, 0x4F,
-0xF0, 0xEC, 0x54, 0x03, 0x31, 0x8A, 0x54, 0xFC,
-0x4F, 0xF0, 0xEC, 0x54, 0x03, 0x25, 0xE0, 0x25,
-0xE0, 0x31, 0x8A, 0x54, 0xF3, 0x4F, 0xF0, 0x90,
-0x93, 0xC6, 0xE0, 0x54, 0x01, 0xC4, 0x33, 0x54,
-0xE0, 0x51, 0xE9, 0x54, 0xDF, 0x4F, 0xF0, 0x90,
-0x93, 0xC9, 0xE0, 0x54, 0x03, 0xC4, 0x54, 0xF0,
-0x31, 0x8A, 0x54, 0xCF, 0x4F, 0xF1, 0x24, 0xE0,
-0x54, 0xFB, 0xF1, 0x24, 0xC0, 0x83, 0xC0, 0x82,
-0xE0, 0xFF, 0x90, 0x93, 0xCC, 0xE0, 0x12, 0xD1,
-0xCA, 0xD0, 0x82, 0xD0, 0x83, 0xF0, 0x90, 0x92,
-0xC3, 0xE0, 0x60, 0x31, 0x12, 0x8F, 0x58, 0xE9,
-0x24, 0x03, 0xF1, 0xEE, 0x54, 0x1F, 0x12, 0x03,
-0x3C, 0x90, 0x93, 0xCA, 0x74, 0x01, 0xF0, 0x90,
-0x93, 0xCA, 0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50,
-0x14, 0xEF, 0x12, 0x8F, 0x52, 0x8F, 0x82, 0x8E,
-0x83, 0xE4, 0x12, 0x03, 0x4E, 0x90, 0x93, 0xCA,
-0xE0, 0x04, 0xF0, 0x80, 0xE2, 0x90, 0x92, 0xC1,
-0xE0, 0x54, 0x07, 0xFF, 0xBF, 0x05, 0x0A, 0xEC,
-0xB4, 0x01, 0x06, 0x90, 0x92, 0xC6, 0x74, 0x01,
-0xF0, 0xE4, 0x90, 0x93, 0xCA, 0xF0, 0x90, 0x93,
-0xCA, 0xE0, 0xFC, 0x12, 0x8F, 0x52, 0x8F, 0x82,
-0x8E, 0x83, 0x12, 0x03, 0x0F, 0xFF, 0xED, 0xF1,
-0xF5, 0xF5, 0x83, 0xE5, 0x82, 0x2C, 0xF1, 0x36,
-0xEF, 0xF0, 0x90, 0x93, 0xCA, 0xE0, 0x04, 0xF0,
-0xE0, 0xB4, 0x04, 0xDA, 0xAF, 0x05, 0x12, 0x17,
-0x8E, 0x22, 0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90,
-0x89, 0x3F, 0x12, 0x05, 0x28, 0xE0, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD1, 0x14,
-0x20, 0xE6, 0x02, 0x41, 0xB0, 0x90, 0x00, 0x8C,
-0xE0, 0x90, 0x95, 0x08, 0xF0, 0x7F, 0x8D, 0x12,
-0x7B, 0x51, 0x90, 0x95, 0x09, 0xEF, 0xF0, 0x90,
-0x00, 0x8E, 0xE0, 0x90, 0x95, 0x0A, 0xF0, 0x90,
-0x95, 0x09, 0xE0, 0x24, 0xFC, 0x60, 0x0F, 0x24,
-0x03, 0x60, 0x02, 0x41, 0xA9, 0x90, 0x95, 0x08,
-0xE0, 0xFF, 0xD1, 0x1B, 0x41, 0xA9, 0x90, 0x95,
-0x08, 0xE0, 0x24, 0xDC, 0xF5, 0x82, 0xE4, 0x34,
-0x8F, 0x51, 0xF6, 0xFF, 0x51, 0xE2, 0x75, 0xF0,
-0x12, 0x31, 0x8F, 0x13, 0x13, 0x54, 0x03, 0xFB,
-0x0D, 0xE4, 0xFF, 0x51, 0xE2, 0x75, 0xF0, 0x12,
-0x31, 0x8F, 0x71, 0x01, 0xFB, 0x0D, 0xE4, 0xFF,
-0x51, 0xE2, 0x75, 0xF0, 0x12, 0x31, 0x8F, 0xC4,
-0x54, 0x03, 0xFB, 0x0D, 0xE4, 0xFF, 0x51, 0xE2,
-0x75, 0xF0, 0x12, 0x12, 0xB5, 0x17, 0xFB, 0xE4,
-0xFD, 0x0F, 0x51, 0xE2, 0x75, 0xF0, 0x12, 0x90,
-0x89, 0x3D, 0x12, 0x05, 0x28, 0x51, 0xDF, 0x75,
-0xF0, 0x12, 0x51, 0xEE, 0xC4, 0x13, 0x54, 0x01,
-0xFB, 0x0D, 0x7F, 0x01, 0x51, 0xE2, 0x75, 0xF0,
-0x12, 0x51, 0xEE, 0x54, 0x1F, 0x51, 0xE0, 0xF1,
-0xF5, 0x51, 0xF6, 0x0F, 0x51, 0xE2, 0x75, 0xF0,
-0x08, 0xA4, 0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34,
-0x82, 0x51, 0xDD, 0x75, 0xF0, 0x08, 0xA4, 0x24,
-0x02, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0x51, 0xDD,
-0x75, 0xF0, 0x08, 0xA4, 0x24, 0x03, 0xF5, 0x82,
-0xE4, 0x34, 0x82, 0x51, 0xDD, 0x75, 0xF0, 0x08,
-0xA4, 0x24, 0x04, 0xF5, 0x82, 0xE4, 0x34, 0x82,
-0x51, 0xF6, 0x0F, 0x51, 0xE2, 0x75, 0xF0, 0x08,
-0xA4, 0x24, 0x05, 0xF5, 0x82, 0xE4, 0x34, 0x82,
-0x51, 0xDD, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x06,
-0xF5, 0x82, 0xE4, 0x34, 0x82, 0x51, 0xDD, 0x75,
-0xF0, 0x08, 0xA4, 0x24, 0x07, 0xF5, 0x82, 0xE4,
-0x34, 0x82, 0xF5, 0x83, 0xE0, 0xFB, 0x0D, 0x51,
-0xB5, 0xD1, 0x14, 0x30, 0xE0, 0x02, 0xF1, 0xD2,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF, 0x70, 0x04,
-0x74, 0xF0, 0x80, 0x16, 0xEF, 0xB4, 0x01, 0x04,
-0x74, 0xF4, 0x80, 0x0E, 0xEF, 0xB4, 0x02, 0x04,
-0x74, 0xF8, 0x80, 0x06, 0xEF, 0xB4, 0x03, 0x0C,
-0x74, 0xFC, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x02,
-0xF5, 0x83, 0xEB, 0xF0, 0x22, 0xF5, 0x83, 0xE0,
-0xFB, 0x0D, 0x51, 0xB5, 0x90, 0x95, 0x08, 0xE0,
-0x22, 0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90, 0x89,
-0x3E, 0x12, 0x05, 0x28, 0xE0, 0x22, 0xF5, 0x83,
-0xE0, 0xFB, 0xE4, 0xFD, 0x22, 0xF0, 0xEE, 0x54,
-0x80, 0xC4, 0x13, 0x13, 0x13, 0x54, 0x01, 0x22,
-0x7D, 0x01, 0x7F, 0x04, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x1B, 0xED, 0xF0,
-0x90, 0x85, 0xC1, 0xE0, 0xFE, 0xC4, 0x13, 0x13,
-0x54, 0x03, 0x30, 0xE0, 0x02, 0x81, 0x66, 0xEE,
-0x71, 0x01, 0x30, 0xE0, 0x02, 0x81, 0x66, 0x90,
-0x85, 0xC8, 0xE0, 0xFE, 0x6F, 0x70, 0x02, 0x81,
-0x66, 0xEF, 0x70, 0x02, 0x61, 0xD1, 0x24, 0xFE,
-0x70, 0x02, 0x81, 0x0E, 0x24, 0xFE, 0x60, 0x4D,
-0x24, 0xFC, 0x70, 0x02, 0x81, 0x4D, 0x24, 0xFC,
-0x60, 0x02, 0x81, 0x5F, 0xEE, 0xB4, 0x0E, 0x03,
-0x12, 0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0, 0x70,
-0x05, 0x7F, 0x01, 0x12, 0x79, 0x80, 0x90, 0x85,
-0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x73, 0x8E,
-0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x04, 0x0F, 0x90,
-0x95, 0x1B, 0xE0, 0xFF, 0x60, 0x05, 0x12, 0x6D,
-0x4C, 0x80, 0x03, 0x12, 0x79, 0x61, 0x90, 0x85,
-0xC8, 0xE0, 0x64, 0x08, 0x60, 0x02, 0x81, 0x5F,
-0x12, 0x7A, 0xB9, 0x81, 0x5F, 0x90, 0x85, 0xC8,
-0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79, 0x80,
-0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12,
-0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E,
-0x08, 0x91, 0x6B, 0xBF, 0x01, 0x03, 0x12, 0x74,
-0x93, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x0C, 0x60,
-0x02, 0x81, 0x5F, 0x91, 0x6B, 0xEF, 0x64, 0x01,
-0x60, 0x02, 0x81, 0x5F, 0x12, 0x70, 0x9E, 0x81,
-0x5F, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E, 0x08,
-0x91, 0x6B, 0xBF, 0x01, 0x03, 0x12, 0x74, 0x93,
-0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12,
-0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0C,
-0x08, 0x91, 0x6B, 0xBF, 0x01, 0x03, 0x12, 0x70,
-0x9E, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x04, 0x70,
-0x5E, 0x12, 0xCD, 0xF1, 0xEF, 0x64, 0x01, 0x70,
-0x56, 0x12, 0x77, 0xFE, 0x80, 0x51, 0x90, 0x85,
-0xC8, 0xE0, 0xB4, 0x0E, 0x08, 0x91, 0x6B, 0xBF,
-0x01, 0x03, 0x12, 0x74, 0x93, 0x90, 0x85, 0xC8,
-0xE0, 0xB4, 0x06, 0x03, 0x12, 0x73, 0x8E, 0x90,
-0x85, 0xC8, 0xE0, 0xB4, 0x0C, 0x08, 0x91, 0x6B,
-0xBF, 0x01, 0x03, 0x12, 0x70, 0x9E, 0x90, 0x85,
-0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79,
-0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x04, 0x17,
-0x12, 0x79, 0xF3, 0x80, 0x12, 0x90, 0x85, 0xC8,
-0xE0, 0xB4, 0x0C, 0x0B, 0x12, 0xC3, 0x4E, 0x54,
-0x3F, 0x30, 0xE0, 0x03, 0x12, 0x7A, 0x8A, 0x90,
-0x85, 0xC8, 0x12, 0xD1, 0x6E, 0xF0, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x12, 0x7A, 0x29, 0xEF, 0x64, 0x01,
-0x60, 0x05, 0x75, 0x0F, 0x01, 0x80, 0x24, 0x90,
-0x85, 0xC1, 0xE0, 0x13, 0x13, 0x13, 0x54, 0x1F,
-0x30, 0xE0, 0x05, 0x75, 0x0F, 0x02, 0x80, 0x13,
-0x90, 0x85, 0xC7, 0xE0, 0xD3, 0x94, 0x04, 0x40,
-0x05, 0x75, 0x0F, 0x08, 0x80, 0x05, 0x12, 0xBF,
-0x73, 0x80, 0x0E, 0x90, 0x01, 0xB9, 0x74, 0x02,
-0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x0F, 0xF0, 0x7F,
-0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x8B, 0x5B, 0x8A,
-0x5C, 0x89, 0x5D, 0x90, 0x05, 0x27, 0xE0, 0xF5,
-0x5E, 0x8B, 0x1B, 0x8A, 0x1C, 0x89, 0x1D, 0x75,
-0x1E, 0x01, 0x7B, 0x01, 0x7A, 0x85, 0x79, 0xBC,
-0x12, 0x6A, 0x21, 0x12, 0x98, 0xD7, 0xFF, 0xC3,
-0x13, 0x20, 0xE0, 0x02, 0xA1, 0x6B, 0x90, 0x85,
-0xBC, 0xE0, 0x30, 0xE0, 0x6C, 0xD1, 0x69, 0x75,
-0x5E, 0x21, 0xD1, 0x79, 0x30, 0xE0, 0x05, 0x12,
-0xD1, 0x2B, 0x80, 0x0D, 0xE4, 0x90, 0x85, 0xBD,
-0xF0, 0xA3, 0xF0, 0x7D, 0x40, 0xFF, 0x12, 0x7C,
-0x41, 0xD1, 0x70, 0x54, 0x1F, 0x30, 0xE0, 0x03,
-0x43, 0x5E, 0x12, 0xEF, 0xC4, 0x54, 0x0F, 0x30,
-0xE0, 0x03, 0x43, 0x5E, 0x14, 0x90, 0x85, 0xBC,
-0xE0, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x03,
-0x43, 0x5E, 0x80, 0xF1, 0xE2, 0x20, 0xE0, 0x03,
-0x43, 0x5E, 0x40, 0xD1, 0x0D, 0x90, 0x85, 0xBF,
-0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0xC9, 0x5E,
-0xD1, 0x82, 0x30, 0xE0, 0x04, 0x7F, 0x04, 0x80,
-0x0B, 0xD1, 0x8D, 0xEF, 0x60, 0x04, 0x7F, 0x01,
-0x80, 0x02, 0x7F, 0x02, 0x12, 0xC9, 0x5E, 0x80,
-0x7E, 0xD1, 0x0A, 0x90, 0x85, 0xBF, 0xE0, 0x64,
-0x04, 0x60, 0x02, 0xC1, 0x05, 0xFF, 0x12, 0xC9,
-0x5E, 0xC1, 0x05, 0x90, 0x85, 0xBC, 0xE0, 0x30,
-0xE0, 0x6D, 0xD1, 0x69, 0x43, 0x5E, 0x31, 0xD1,
-0x79, 0x30, 0xE0, 0x05, 0x12, 0xD1, 0x2B, 0x80,
-0x07, 0x7D, 0x40, 0xE4, 0xFF, 0x12, 0x7C, 0x41,
-0xD1, 0x70, 0x54, 0x1F, 0x30, 0xE0, 0x03, 0x43,
-0x5E, 0x02, 0xEF, 0xC4, 0x54, 0x0F, 0x30, 0xE0,
-0x03, 0x43, 0x5E, 0x04, 0xD1, 0x0D, 0xD1, 0x82,
-0x30, 0xE0, 0x0A, 0xF1, 0x6C, 0x60, 0x30, 0xE4,
-0xFD, 0x7F, 0x02, 0x80, 0x1E, 0x12, 0xCA, 0xC2,
-0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x02, 0x18, 0x12,
-0x7A, 0xA2, 0xD1, 0x8D, 0xBF, 0x01, 0x09, 0x90,
-0x85, 0xC7, 0xE0, 0xFF, 0x7D, 0x01, 0x80, 0x03,
-0xE4, 0xFD, 0xFF, 0x71, 0x0C, 0x80, 0x08, 0x90,
-0x85, 0xC8, 0xE0, 0x90, 0x85, 0xC0, 0xF0, 0x90,
-0x05, 0x40, 0x74, 0x22, 0xF0, 0x80, 0x26, 0xD1,
-0x0A, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x02, 0x06,
-0x7D, 0x01, 0x7F, 0x04, 0x80, 0x0B, 0x90, 0x85,
-0xC0, 0xE0, 0xB4, 0x08, 0x06, 0x7D, 0x01, 0x7F,
-0x0C, 0x71, 0x0C, 0xF1, 0xD9, 0x90, 0x85, 0xC7,
-0xF1, 0xCC, 0x12, 0xCD, 0x91, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x75, 0x5E, 0x01, 0x90, 0x05, 0x27,
-0xE5, 0x5E, 0xF0, 0x22, 0x7F, 0x8F, 0x12, 0x7B,
-0x51, 0xEF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x95, 0x13, 0xEF, 0xF0, 0xD1,
-0x14, 0x30, 0xE6, 0x38, 0x7F, 0x8D, 0x12, 0x7B,
-0x51, 0xEF, 0x64, 0x01, 0x70, 0x2E, 0x90, 0x95,
-0x14, 0xF0, 0x90, 0x95, 0x14, 0xE0, 0xFD, 0x90,
-0x95, 0x13, 0xE0, 0x12, 0x9B, 0x4A, 0xE5, 0x82,
-0x2D, 0xF1, 0x36, 0xE0, 0xFB, 0xE4, 0xFF, 0x51,
-0xB5, 0x90, 0x95, 0x14, 0xE0, 0x04, 0xF0, 0xE0,
-0xC3, 0x94, 0x10, 0x40, 0xDD, 0xD1, 0x14, 0x30,
-0xE0, 0x02, 0xF1, 0xD2, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x7D, 0x03, 0x7F, 0x02, 0x02, 0x7B, 0xFD,
-0x90, 0x85, 0xBC, 0xE0, 0xFF, 0x13, 0x13, 0x13,
-0x22, 0x90, 0x85, 0xBC, 0xE0, 0x13, 0x13, 0x54,
-0x3F, 0x22, 0x90, 0x85, 0xBC, 0xE0, 0xFF, 0xC4,
-0x13, 0x13, 0x54, 0x03, 0x22, 0x90, 0x05, 0x43,
-0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02, 0x7F, 0x01,
-0x22, 0xE4, 0xF5, 0x75, 0x90, 0x85, 0xC5, 0xE0,
-0x60, 0x6F, 0x12, 0xC4, 0x67, 0x70, 0x6A, 0x12,
-0xC7, 0xC0, 0x75, 0x75, 0x01, 0x90, 0x85, 0xBC,
-0xE0, 0x30, 0xE0, 0x11, 0x90, 0x85, 0xC0, 0xE0,
-0xB4, 0x02, 0x03, 0xE4, 0xF5, 0x75, 0xD1, 0x8D,
-0xEF, 0x70, 0x02, 0xF5, 0x75, 0xE5, 0x75, 0x60,
-0x48, 0x90, 0x85, 0xC8, 0xE0, 0x20, 0xE2, 0x02,
-0x71, 0x08, 0x90, 0x85, 0xC9, 0xE0, 0x44, 0x10,
-0xF0, 0x90, 0x85, 0xCE, 0xE0, 0x60, 0x04, 0x64,
-0x01, 0x70, 0x17, 0xE4, 0x90, 0x91, 0x6E, 0xF0,
-0x90, 0x85, 0xCE, 0xE0, 0xF1, 0x12, 0x90, 0x91,
-0x6F, 0x12, 0xC6, 0x20, 0x90, 0x85, 0xCE, 0xE0,
-0x80, 0x11, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0xF1,
-0x19, 0xF1, 0x12, 0x90, 0x91, 0x6F, 0x12, 0xC6,
-0x20, 0xF1, 0x19, 0xF1, 0x12, 0x90, 0x85, 0xDE,
-0xF0, 0x22, 0xFF, 0x90, 0x85, 0xCD, 0xE0, 0x2F,
-0x22, 0x90, 0x85, 0xCE, 0xE0, 0x75, 0xF0, 0x03,
-0xA4, 0x24, 0xFE, 0x22, 0xF0, 0x74, 0xCC, 0x2D,
-0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83, 0x22,
-0x12, 0x05, 0x28, 0xE5, 0x82, 0x29, 0xF5, 0x82,
-0xE4, 0x35, 0x83, 0xF5, 0x83, 0x22, 0xAE, 0x07,
-0xD1, 0x8D, 0xBF, 0x01, 0x0E, 0xF1, 0xE2, 0x20,
-0xE0, 0x09, 0xAF, 0x06, 0x7D, 0x01, 0x71, 0x0C,
-0x7F, 0x01, 0x22, 0x7F, 0x00, 0x22, 0xD1, 0x82,
-0x30, 0xE0, 0x0A, 0xF1, 0x6C, 0x60, 0x06, 0x7D,
-0x01, 0x7F, 0x02, 0x71, 0x0C, 0xF1, 0x6C, 0x60,
-0x02, 0xF1, 0x73, 0x22, 0x90, 0x85, 0xC0, 0xE0,
-0x64, 0x02, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x64,
-0x02, 0x60, 0x10, 0x12, 0xB7, 0xDC, 0x60, 0x0B,
-0x12, 0x7A, 0x29, 0xEF, 0x70, 0x05, 0xFD, 0x7F,
-0x0C, 0x71, 0x0C, 0x22, 0x90, 0x85, 0xC5, 0xE0,
-0x64, 0x01, 0x70, 0x19, 0x12, 0xB7, 0xDC, 0x60,
-0x0C, 0xE4, 0xFD, 0x7F, 0x0C, 0x71, 0x0C, 0x12,
-0x98, 0xE0, 0x02, 0x6B, 0x98, 0x90, 0x85, 0xC8,
-0xE0, 0x70, 0x02, 0x71, 0x08, 0x22, 0x90, 0x85,
-0xC5, 0xE0, 0x70, 0x07, 0x90, 0x85, 0xBC, 0xE0,
-0x30, 0xE0, 0x10, 0x90, 0x85, 0xBC, 0xE0, 0x30,
-0xE0, 0x07, 0xD1, 0x8D, 0xBF, 0x01, 0x04, 0x80,
-0xAA, 0xF1, 0x8C, 0x22, 0xE0, 0xFF, 0x7D, 0x01,
-0x61, 0x0C, 0xE4, 0xFD, 0x7F, 0x8D, 0x02, 0x7B,
-0x3E, 0x12, 0x7A, 0x29, 0xEF, 0x70, 0x02, 0xF1,
-0x8C, 0x22, 0x90, 0x85, 0xBC, 0xE0, 0xC4, 0x13,
-0x13, 0x54, 0x03, 0x22, 0x21, 0x97, 0xF9, 0xE4,
-0x3A, 0xFA, 0x02, 0x02, 0xF6, 0x75, 0xF0, 0x08,
-0xA4, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x82,
-0x22, 0xF1, 0xAE, 0xFF, 0x54, 0x0F, 0xF5, 0x5E,
-0xEF, 0xC4, 0x54, 0x0F, 0x64, 0x0F, 0x70, 0x3B,
-0x90, 0x92, 0x0A, 0xE0, 0x54, 0xFE, 0xFF, 0xF0,
-0xE5, 0x5E, 0x54, 0x07, 0x25, 0xE0, 0xFE, 0xEF,
-0x54, 0xF1, 0x4E, 0xF0, 0x12, 0x97, 0xE7, 0xC4,
-0x13, 0x54, 0x07, 0x90, 0x92, 0xBB, 0x20, 0xE0,
-0x05, 0x74, 0x06, 0xF0, 0x80, 0x03, 0x74, 0x01,
-0xF0, 0xF1, 0x8A, 0xAF, 0x5E, 0x31, 0x03, 0xBF,
-0x01, 0x05, 0xE4, 0xFD, 0xFF, 0x51, 0x52, 0x7F,
-0x02, 0x21, 0x00, 0xE5, 0x5E, 0x75, 0xF0, 0x1B,
-0xA4, 0x24, 0x37, 0xF9, 0x74, 0x92, 0x35, 0xF0,
-0xFA, 0x7B, 0x01, 0xC0, 0x02, 0xC0, 0x01, 0xE5,
-0x5D, 0x24, 0x01, 0xF9, 0xE4, 0x35, 0x5C, 0x85,
-0x5B, 0x1B, 0xF5, 0x1C, 0x89, 0x1D, 0x75, 0x1E,
-0x04, 0xD0, 0x01, 0xD0, 0x02, 0x12, 0x6A, 0x21,
-0xE5, 0x5E, 0x12, 0x8F, 0xA6, 0x54, 0xF7, 0xF0,
-0x12, 0x98, 0xD7, 0xC4, 0x54, 0x0F, 0x14, 0x65,
-0x5E, 0x70, 0x77, 0x90, 0x85, 0xC5, 0xE0, 0x70,
-0x07, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x04,
-0x7F, 0x05, 0x80, 0x64, 0x12, 0x98, 0xD7, 0xC4,
-0x54, 0x0F, 0x90, 0x92, 0x0B, 0xF0, 0x12, 0x90,
-0x39, 0xFC, 0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFE,
-0x90, 0x92, 0x0A, 0xE0, 0x54, 0x0F, 0x4E, 0xF0,
-0xEC, 0x54, 0x60, 0xC4, 0x54, 0x0F, 0xFF, 0x90,
-0x92, 0x89, 0xE0, 0x54, 0xF9, 0x4F, 0xF0, 0x90,
-0x92, 0x0A, 0xE0, 0x54, 0xF1, 0xF0, 0x90, 0x05,
-0x58, 0x74, 0x02, 0xF0, 0x90, 0x92, 0xB1, 0xE0,
-0x90, 0x92, 0xB5, 0x30, 0xE0, 0x0B, 0xE0, 0x54,
-0xFE, 0xF0, 0x54, 0xC1, 0x44, 0x02, 0xF0, 0x80,
-0x07, 0xE0, 0x44, 0x01, 0xF0, 0x54, 0xC1, 0xF0,
-0x90, 0x92, 0xB5, 0xE0, 0x54, 0xBF, 0xF0, 0x90,
-0x92, 0x0A, 0xE0, 0x44, 0x01, 0xF0, 0x7F, 0x03,
-0x51, 0xF7, 0x22, 0x8F, 0x5F, 0x90, 0x05, 0x22,
-0xE0, 0x90, 0x93, 0xC3, 0xF0, 0x12, 0x96, 0xE6,
-0xEF, 0x64, 0x01, 0x70, 0x35, 0xE5, 0x5F, 0x51,
-0xD4, 0xE0, 0xFC, 0xE5, 0x5F, 0x12, 0xD0, 0x4C,
-0xAF, 0x04, 0x31, 0x59, 0xE5, 0x5F, 0x12, 0x8B,
-0xB0, 0xE5, 0x5F, 0x12, 0x8F, 0xA6, 0x54, 0x07,
-0xFF, 0x60, 0x03, 0xBF, 0x02, 0x0B, 0xE5, 0x5F,
-0x12, 0x97, 0xD9, 0x51, 0xF0, 0xFD, 0x12, 0x95,
-0x92, 0xAD, 0x5F, 0x7F, 0x01, 0x51, 0x52, 0x7F,
-0x01, 0x22, 0x90, 0x93, 0xC3, 0xE0, 0xFD, 0x7B,
-0x49, 0xE4, 0xFF, 0x12, 0x95, 0x87, 0x7F, 0x00,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x95, 0x01, 0xEF, 0xF0, 0xED, 0x64, 0x01,
-0x70, 0x2E, 0xEB, 0xB4, 0x01, 0x07, 0xE0, 0x24,
-0x02, 0xF5, 0x0E, 0x80, 0x08, 0x90, 0x95, 0x01,
-0xE0, 0x24, 0xFE, 0xF5, 0x0E, 0x90, 0x94, 0xC1,
-0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0xFF, 0xAF,
-0x0E, 0x31, 0xC3, 0x51, 0x4A, 0x12, 0x04, 0xF7,
-0x00, 0x00, 0x00, 0xFF, 0xAF, 0x0E, 0x80, 0x20,
-0x90, 0x94, 0xC1, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x00, 0xFF, 0x90, 0x95, 0x01, 0x12, 0x8D, 0xA5,
-0x31, 0xC7, 0x51, 0x4A, 0x12, 0x04, 0xF7, 0x00,
-0x00, 0x00, 0xFF, 0x90, 0x95, 0x01, 0xE0, 0xFF,
-0x31, 0xC3, 0x7F, 0x01, 0x31, 0xD2, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xE4, 0xFC, 0xFD, 0xFE, 0x90,
-0x94, 0xC5, 0x12, 0x04, 0xEB, 0x7D, 0x18, 0x7C,
-0x00, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x94, 0xBF, 0xEC, 0xF0, 0xA3, 0xED,
-0xF0, 0x90, 0x94, 0xBE, 0xEF, 0xF0, 0xA3, 0xA3,
-0xE0, 0xFD, 0x12, 0x7B, 0xE0, 0x90, 0x94, 0xC9,
-0x12, 0x04, 0xEB, 0x90, 0x94, 0xC1, 0x12, 0x87,
-0x2D, 0x12, 0x04, 0xA7, 0x90, 0x94, 0xC9, 0x12,
-0x8F, 0x5E, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x94, 0xC1, 0x12, 0x87, 0x2D,
-0x90, 0x94, 0xC5, 0x12, 0x8F, 0x5E, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87,
-0x20, 0x90, 0x94, 0xCD, 0x12, 0x04, 0xEB, 0x90,
-0x94, 0xBF, 0xA3, 0xE0, 0xFD, 0xC0, 0x05, 0x90,
-0x94, 0xCD, 0x12, 0x87, 0x2D, 0x90, 0x8D, 0x9D,
-0x12, 0x04, 0xEB, 0x90, 0x94, 0xBE, 0xE0, 0xFF,
-0xD0, 0x05, 0x12, 0x78, 0xDD, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xE4, 0xFF, 0x31, 0xD2, 0x90, 0x94,
-0xC1, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x94, 0x82, 0xED, 0xF0, 0x90, 0x94,
-0x81, 0xEF, 0xF0, 0x64, 0x02, 0x70, 0x24, 0x90,
-0x05, 0x22, 0xE0, 0x90, 0x94, 0x83, 0xF0, 0x7B,
-0x4A, 0x7D, 0x6F, 0x12, 0x96, 0xEA, 0xBF, 0x01,
-0x07, 0x90, 0x04, 0xD4, 0x74, 0xFF, 0x80, 0x48,
-0x90, 0x94, 0x83, 0xE0, 0xFD, 0x7B, 0x46, 0x31,
-0x51, 0x80, 0x42, 0x90, 0x94, 0x81, 0xE0, 0x64,
-0x01, 0x70, 0x31, 0x12, 0x95, 0x83, 0x90, 0x94,
-0x82, 0xE0, 0xFF, 0x75, 0xF0, 0x1B, 0xA4, 0x24,
-0x3C, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
-0xE0, 0xF4, 0x90, 0x04, 0xD4, 0xF0, 0xEF, 0x75,
-0xF0, 0x1B, 0xA4, 0x24, 0x3D, 0xF5, 0x82, 0xE4,
-0x34, 0x92, 0xF5, 0x83, 0xE0, 0xF4, 0x90, 0x04,
-0xD5, 0xF0, 0x80, 0x07, 0x90, 0x04, 0xD4, 0xE4,
-0xF0, 0xA3, 0xF0, 0x7F, 0x01, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xE5, 0x77, 0x75, 0xF0, 0x1B, 0xA4,
-0x24, 0x37, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5,
-0x83, 0x22, 0xEF, 0x75, 0xF0, 0x0E, 0xA4, 0x24,
-0x19, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
-0xE0, 0xFF, 0x7E, 0x00, 0xE4, 0xFB, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xAD, 0x07,
-0x90, 0x05, 0x63, 0xE0, 0xFE, 0x90, 0x05, 0x62,
-0xE0, 0x7A, 0x00, 0x24, 0x00, 0xFF, 0xEA, 0x3E,
-0x90, 0x94, 0x90, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
-0x05, 0x61, 0xE0, 0xFE, 0x90, 0x05, 0x60, 0xE0,
-0x24, 0x00, 0xFF, 0xEA, 0x3E, 0xFE, 0xED, 0xB4,
-0x08, 0x0A, 0x90, 0x05, 0x58, 0xE0, 0xFC, 0x2F,
-0xFF, 0xEA, 0x3E, 0xFE, 0x90, 0x94, 0x81, 0x74,
-0x17, 0xF0, 0x90, 0x94, 0x8F, 0x74, 0x06, 0xF0,
-0x90, 0x94, 0x83, 0xED, 0xF0, 0x90, 0x92, 0x0A,
-0xE0, 0xFD, 0xC3, 0x13, 0x54, 0x07, 0x51, 0xD4,
-0xE0, 0x90, 0x94, 0x84, 0xF0, 0xA3, 0xEF, 0xF0,
-0xEE, 0xA3, 0xF0, 0x90, 0x94, 0x90, 0xE0, 0xFE,
-0xA3, 0xE0, 0x90, 0x94, 0x87, 0xF0, 0xEE, 0xA3,
-0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x81, 0x12,
-0x88, 0x13, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
-0x92, 0x0A, 0xE0, 0xFF, 0x20, 0xE0, 0x02, 0xC1,
-0x4D, 0x90, 0x92, 0xB5, 0xE0, 0xFE, 0x20, 0xE0,
-0x02, 0x81, 0xBB, 0x90, 0x92, 0xB3, 0xE0, 0xFD,
-0x90, 0x92, 0xB6, 0xE0, 0xD3, 0x9D, 0x50, 0x02,
-0x81, 0xBB, 0x90, 0x05, 0x58, 0xE0, 0x90, 0x94,
-0x5D, 0xF0, 0xEF, 0x12, 0x8F, 0xA3, 0x54, 0x07,
-0xFF, 0x64, 0x02, 0x60, 0x03, 0xEF, 0x70, 0x23,
-0xEE, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x20, 0xE0,
-0x1A, 0x90, 0x92, 0xB5, 0xE0, 0x44, 0x40, 0xF1,
-0x91, 0x90, 0x94, 0x5D, 0xE0, 0xFF, 0x90, 0x92,
-0xB2, 0xE0, 0x2F, 0x24, 0xFD, 0x90, 0x91, 0x6F,
-0x12, 0xC6, 0x20, 0x12, 0x8D, 0x8C, 0x12, 0x87,
-0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x90, 0x05, 0x62, 0x12, 0x8D, 0xA5, 0x78,
-0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x20, 0xC0,
-0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3,
-0x12, 0x8D, 0xA5, 0x78, 0x18, 0x12, 0x04, 0xD8,
-0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
-0x12, 0x87, 0x20, 0x90, 0x94, 0x51, 0x12, 0x04,
-0xEB, 0x90, 0x05, 0x65, 0x12, 0x8D, 0xA5, 0xD1,
-0x80, 0x90, 0x05, 0x64, 0x12, 0x8D, 0xA5, 0x12,
-0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x05, 0x66, 0x12, 0x8D, 0xA5,
-0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x20,
-0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0xA3, 0x12, 0x8D, 0xA5, 0x78, 0x18, 0x12, 0x04,
-0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x87, 0x20, 0xD1, 0x7A, 0x90, 0x92,
-0xB2, 0xE0, 0xFB, 0xE4, 0xFA, 0xF9, 0xF8, 0x90,
-0x94, 0x5D, 0x12, 0x8D, 0xA5, 0x12, 0x86, 0xA9,
-0xE4, 0xFB, 0x7A, 0x04, 0x12, 0x86, 0xC4, 0xD1,
-0x67, 0x12, 0x86, 0xA9, 0x90, 0x94, 0x59, 0xD1,
-0x5E, 0x90, 0x94, 0x59, 0xF1, 0x9F, 0x50, 0x04,
-0xD1, 0x50, 0xD1, 0x6D, 0xD1, 0x50, 0xF1, 0xB7,
-0xD1, 0x4E, 0xF1, 0xC0, 0xD1, 0x4E, 0xF1, 0xC9,
-0xD1, 0x4E, 0x90, 0x05, 0x88, 0xD1, 0x56, 0xF1,
-0xD2, 0xD1, 0x56, 0xF1, 0xDB, 0xD1, 0x56, 0xF1,
-0xE4, 0xD1, 0x56, 0x12, 0xD1, 0x1F, 0xE4, 0x90,
-0x92, 0xB6, 0xF0, 0x90, 0x92, 0xB1, 0xE0, 0x20,
-0xE0, 0x02, 0xC1, 0x4D, 0x90, 0x92, 0xB5, 0xE0,
-0xFF, 0xC3, 0x13, 0xFE, 0x54, 0x1F, 0x70, 0x02,
-0xC1, 0x4D, 0xEF, 0x54, 0xC1, 0xFF, 0xEE, 0x14,
-0x54, 0x1F, 0xFE, 0x25, 0xE0, 0x4F, 0xF0, 0xE0,
-0xC3, 0x13, 0x54, 0x1F, 0x60, 0x02, 0xC1, 0x4D,
-0x90, 0x05, 0x22, 0xE0, 0x44, 0x40, 0xFD, 0x7B,
-0x58, 0x7F, 0x40, 0x12, 0x95, 0x87, 0x90, 0x05,
-0x50, 0xE0, 0x54, 0xF7, 0xF0, 0x90, 0x05, 0x69,
-0x12, 0x8D, 0xA5, 0xD1, 0x80, 0x90, 0x05, 0x68,
-0x12, 0x8D, 0xA5, 0x12, 0x87, 0x20, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05,
-0x6A, 0x12, 0x8D, 0xA5, 0x78, 0x10, 0x12, 0x04,
-0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0xA3, 0x12, 0x8D, 0xA5,
-0x78, 0x18, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x20,
-0x90, 0x94, 0x51, 0xD1, 0x5E, 0x90, 0x94, 0x59,
-0x12, 0x04, 0xEB, 0x90, 0x05, 0x6D, 0x12, 0x8D,
-0xA5, 0xD1, 0x80, 0x90, 0x05, 0x6C, 0x12, 0x8D,
-0xA5, 0x12, 0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05, 0x6E, 0x12,
-0x8D, 0xA5, 0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0,
-0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0xA3, 0x12, 0x8D, 0xA5, 0x78, 0x18,
-0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x87, 0x20, 0xD1, 0x7A,
-0xD1, 0x67, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
-0xC0, 0x03, 0x90, 0x92, 0xB1, 0xE0, 0xC3, 0x13,
-0x54, 0x7F, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0xF1,
-0xA6, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x86, 0xA9, 0x90, 0x94, 0x51, 0x12,
-0x04, 0xEB, 0xD1, 0x58, 0xD1, 0x67, 0xC3, 0x12,
-0x04, 0xB4, 0x50, 0x04, 0xD1, 0x50, 0xD1, 0x6D,
-0xD1, 0x50, 0x78, 0x18, 0x12, 0x04, 0xC5, 0x90,
-0x05, 0x67, 0xD1, 0x4E, 0x78, 0x10, 0x12, 0x04,
-0xC5, 0x90, 0x05, 0x66, 0xD1, 0x4E, 0x78, 0x08,
-0x12, 0x04, 0xC5, 0x90, 0x05, 0x65, 0xD1, 0x4E,
-0x90, 0x05, 0x64, 0xEF, 0xF0, 0xD1, 0x61, 0x78,
-0x18, 0x12, 0x04, 0xC5, 0x90, 0x05, 0x63, 0xEF,
-0xF0, 0xD1, 0x61, 0x78, 0x10, 0x12, 0x04, 0xC5,
-0x90, 0x05, 0x62, 0xEF, 0xF0, 0xD1, 0x61, 0x78,
-0x08, 0x12, 0x04, 0xC5, 0x90, 0x05, 0x61, 0xEF,
-0xF0, 0xD1, 0x61, 0x90, 0x05, 0x60, 0xEF, 0xF0,
-0x90, 0x05, 0x50, 0xE0, 0x44, 0x08, 0xF0, 0x90,
-0x05, 0x22, 0xE0, 0x54, 0xBF, 0xFD, 0x7B, 0x59,
-0x7F, 0x40, 0x12, 0x95, 0x87, 0x7F, 0x08, 0x51,
-0xF7, 0x90, 0x92, 0xB5, 0xE0, 0x54, 0xC1, 0x44,
-0x28, 0xF0, 0x44, 0x01, 0xF0, 0x22, 0xEF, 0xF0,
-0x90, 0x94, 0x55, 0x02, 0x87, 0x2D, 0xEF, 0xF0,
-0x90, 0x94, 0x59, 0x02, 0x87, 0x2D, 0x12, 0x04,
-0xEB, 0x90, 0x94, 0x51, 0x02, 0x87, 0x2D, 0x90,
-0x94, 0x51, 0x02, 0x87, 0x39, 0xEF, 0x24, 0x01,
-0xFF, 0xE4, 0x3E, 0xFE, 0xE4, 0x3D, 0xFD, 0xE4,
-0x3C, 0xFC, 0x90, 0x94, 0x55, 0x02, 0x04, 0xEB,
-0x78, 0x08, 0x12, 0x04, 0xD8, 0xA8, 0x04, 0xA9,
-0x05, 0xAA, 0x06, 0xAB, 0x07, 0x22, 0x90, 0x85,
-0xBC, 0xE0, 0x30, 0xE0, 0x10, 0xA3, 0x74, 0x01,
-0xF0, 0x90, 0x85, 0xBC, 0xE0, 0xFF, 0xC3, 0x13,
-0x30, 0xE0, 0x02, 0xD1, 0xAE, 0x12, 0xA6, 0x99,
-0xE4, 0xFF, 0xD1, 0xC9, 0x61, 0x77, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0xA6, 0x8D,
-0xBF, 0x01, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F,
-0x02, 0x12, 0xC9, 0x5E, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x92, 0xC9, 0xE0, 0xFE, 0x13, 0x13, 0x54,
-0x3F, 0x30, 0xE0, 0x1F, 0x90, 0x94, 0xE3, 0x74,
-0x1E, 0xF0, 0x90, 0x94, 0xF1, 0x74, 0x01, 0xF0,
-0x90, 0x94, 0xE5, 0xEF, 0xF0, 0x7B, 0x01, 0x7A,
-0x94, 0x79, 0xE3, 0x12, 0x5E, 0x10, 0x7F, 0x04,
-0x12, 0xB6, 0x62, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x12, 0xC5, 0x8A, 0xF1, 0x7A, 0x7F, 0x01, 0xD1,
-0xC9, 0x90, 0x92, 0x04, 0xE0, 0x30, 0xE0, 0x14,
-0xF1, 0x81, 0x90, 0x92, 0x07, 0xE0, 0x60, 0x05,
-0x14, 0xF0, 0x02, 0x7A, 0x8A, 0x12, 0xB1, 0x58,
-0xE4, 0xFF, 0xF1, 0x25, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0xEF, 0x64, 0x01, 0x70,
-0x1A, 0xF1, 0x72, 0x60, 0x09, 0xF1, 0x6B, 0x12,
-0x7B, 0xFD, 0xF1, 0x81, 0x80, 0x08, 0xF1, 0x6B,
-0x12, 0x7B, 0xBF, 0x12, 0xB7, 0x2F, 0x12, 0x7A,
-0x8A, 0x80, 0x17, 0xF1, 0x72, 0x60, 0x07, 0xF1,
-0x6B, 0x12, 0x7B, 0xFD, 0x80, 0x05, 0xF1, 0x6B,
-0x12, 0x7B, 0xBF, 0xF1, 0x7A, 0xF1, 0x98, 0x12,
-0x7A, 0xB9, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0,
-0x90, 0x01, 0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F,
-0x03, 0x22, 0x90, 0x92, 0x06, 0xE0, 0x90, 0x01,
-0x3F, 0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C,
-0xA9, 0x90, 0x92, 0x06, 0xE0, 0x90, 0x05, 0x73,
-0xF0, 0x22, 0x7D, 0x20, 0xE4, 0xFF, 0x02, 0x7B,
-0xBF, 0xF0, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x22,
-0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0xA9, 0x12,
-0x87, 0x39, 0xD3, 0x02, 0x04, 0xB4, 0xFB, 0x7A,
-0x04, 0xF9, 0xF8, 0x02, 0x86, 0xC4, 0x8B, 0x5B,
-0x8A, 0x5C, 0x89, 0x5D, 0x02, 0x02, 0xF6, 0x78,
-0x18, 0x12, 0x04, 0xC5, 0x90, 0x05, 0x8B, 0x22,
-0x78, 0x10, 0x12, 0x04, 0xC5, 0x90, 0x05, 0x8A,
-0x22, 0x78, 0x08, 0x12, 0x04, 0xC5, 0x90, 0x05,
-0x89, 0x22, 0x78, 0x18, 0x12, 0x04, 0xC5, 0x90,
-0x05, 0x87, 0x22, 0x78, 0x10, 0x12, 0x04, 0xC5,
-0x90, 0x05, 0x86, 0x22, 0x78, 0x08, 0x12, 0x04,
-0xC5, 0x90, 0x05, 0x85, 0x22, 0xF1, 0xAE, 0xFF,
-0x54, 0x01, 0xFE, 0x90, 0x92, 0xB1, 0x12, 0xB1,
-0x50, 0x54, 0xFE, 0xFF, 0xEE, 0x54, 0x01, 0x4F,
-0xF0, 0x12, 0x8F, 0x73, 0x90, 0x92, 0xB2, 0x12,
-0x8F, 0xF2, 0x90, 0x92, 0xB3, 0xF0, 0xE4, 0xA3,
-0xF0, 0x90, 0x92, 0xB3, 0xE0, 0xFF, 0xB4, 0x64,
-0x05, 0x74, 0x01, 0xF0, 0x80, 0x0A, 0xEF, 0xB4,
-0x96, 0x06, 0x90, 0x92, 0xB3, 0x74, 0x03, 0xF0,
-0x90, 0x92, 0xB3, 0xE0, 0x04, 0x90, 0x92, 0xB6,
-0xF0, 0x22, 0x12, 0x02, 0xF6, 0xFF, 0x90, 0x92,
-0x03, 0xF0, 0xBF, 0x01, 0x07, 0x11, 0x45, 0xE4,
-0x90, 0x92, 0x03, 0xF0, 0x22, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0xC3, 0x7F, 0xEF, 0x7E, 0x00, 0x12,
-0x64, 0x37, 0xBF, 0x01, 0x06, 0x90, 0x93, 0xC3,
-0xE0, 0xA3, 0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0xC3, 0x7F, 0xEE, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x93, 0xC3, 0xE0, 0x90,
-0x93, 0xC5, 0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0xC3, 0x7F, 0xED, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x93, 0xC3, 0xE0, 0x90,
-0x93, 0xC6, 0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0xC3, 0x7F, 0xEC, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x93, 0xC3, 0xE0, 0x90,
-0x93, 0xC7, 0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0xC3, 0x7F, 0xEB, 0x7E, 0x00, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x08, 0x90, 0x93, 0xC3, 0xE0, 0x90,
-0x93, 0xC8, 0xF0, 0x90, 0x93, 0xC4, 0xE0, 0xFF,
-0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFB, 0xA3, 0xE0,
-0x90, 0x93, 0xCC, 0xF0, 0x90, 0x93, 0xC8, 0xE0,
-0x90, 0x93, 0xCD, 0xF0, 0x90, 0x93, 0xCE, 0x74,
-0x12, 0xF0, 0x90, 0x93, 0xDC, 0x74, 0x05, 0xF0,
-0x90, 0x93, 0xD0, 0x31, 0x03, 0x90, 0x93, 0xCC,
-0xE0, 0x90, 0x93, 0xD3, 0xF0, 0x90, 0x93, 0xCD,
-0xE0, 0x90, 0x93, 0xD4, 0xF0, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0xCE, 0x12, 0x5E, 0x10, 0x7F, 0x04,
-0x02, 0x88, 0x18, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
-0xA3, 0xEB, 0xF0, 0x22, 0x12, 0x02, 0xF6, 0x54,
-0x01, 0xFF, 0x90, 0x92, 0xC8, 0xE0, 0x54, 0xFE,
-0x4F, 0xF0, 0x22, 0x12, 0x02, 0xF6, 0x90, 0x86,
-0x71, 0xF0, 0x22, 0x12, 0x02, 0xF6, 0xFF, 0x54,
-0x01, 0xFE, 0x90, 0x92, 0x04, 0x31, 0x50, 0x54,
-0x02, 0xFF, 0xEE, 0x54, 0xFD, 0x4F, 0xF0, 0x12,
-0x8F, 0x73, 0x90, 0x92, 0x05, 0x12, 0x8F, 0xF2,
-0x90, 0x92, 0x06, 0xF0, 0x31, 0x58, 0x90, 0x92,
-0x04, 0xE0, 0x54, 0x01, 0xFF, 0x02, 0xAF, 0x25,
-0xE0, 0x54, 0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x22,
-0x90, 0x92, 0x05, 0xE0, 0x14, 0x90, 0x92, 0x07,
-0xF0, 0x22, 0x90, 0x01, 0xCC, 0xE0, 0x54, 0x0F,
-0x90, 0x93, 0xBD, 0xF0, 0x90, 0x93, 0xBD, 0xE0,
-0xFD, 0x70, 0x02, 0x41, 0x5F, 0x90, 0x85, 0x1D,
-0xE0, 0xFF, 0x70, 0x06, 0xA3, 0xE0, 0x64, 0x09,
-0x60, 0x0A, 0xEF, 0x14, 0xFF, 0x90, 0x85, 0x1E,
-0xE0, 0xB5, 0x07, 0x04, 0x7F, 0x01, 0x80, 0x02,
-0x7F, 0x00, 0xEF, 0x60, 0x08, 0x90, 0x01, 0xC1,
-0xE0, 0x44, 0x01, 0xF0, 0x22, 0x90, 0x95, 0x11,
-0xE0, 0x51, 0x92, 0x80, 0x05, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEF, 0x5D, 0x70,
-0x02, 0x41, 0x42, 0xE4, 0x90, 0x93, 0xBE, 0xF0,
-0x90, 0x93, 0xBE, 0xE0, 0xF9, 0xC3, 0x94, 0x04,
-0x50, 0x36, 0x51, 0x61, 0xA4, 0xFF, 0xE9, 0xFD,
-0x7C, 0x00, 0x2F, 0xFF, 0xEC, 0x35, 0xF0, 0xFE,
-0x74, 0xD0, 0x51, 0x69, 0x90, 0x84, 0xCD, 0x12,
-0xA7, 0x30, 0xEF, 0x51, 0x60, 0xA4, 0x2D, 0xFF,
-0xEC, 0x35, 0xF0, 0xFE, 0x74, 0xF0, 0x51, 0x69,
-0x90, 0x84, 0xD1, 0x12, 0xA7, 0x30, 0xEF, 0xF0,
-0x90, 0x93, 0xBE, 0xE0, 0x04, 0xF0, 0x80, 0xC0,
-0x90, 0x93, 0xBD, 0xE0, 0xFF, 0x90, 0x95, 0x11,
-0x51, 0x81, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xF4, 0x5F, 0x90, 0x93, 0xBD, 0xF0, 0x90, 0x95,
-0x11, 0xE0, 0xFF, 0x74, 0x01, 0xA8, 0x07, 0x08,
-0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x90, 0x01,
-0xCC, 0xF0, 0x90, 0x95, 0x11, 0xE0, 0x04, 0xF0,
-0xE0, 0x54, 0x03, 0xF0, 0x90, 0x85, 0x1E, 0x51,
-0x89, 0xB4, 0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x70,
-0x02, 0x21, 0x6C, 0xE4, 0x90, 0x85, 0x1E, 0xF0,
-0x21, 0x6C, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x02,
-0xF0, 0x90, 0x95, 0x11, 0xE0, 0x44, 0x80, 0x90,
-0x00, 0x8A, 0x51, 0x60, 0x90, 0x01, 0xD0, 0x12,
-0x05, 0x28, 0xE0, 0x90, 0x01, 0xC3, 0xF0, 0x22,
-0xF0, 0x90, 0x95, 0x11, 0xE0, 0x75, 0xF0, 0x04,
-0x22, 0x2F, 0xF5, 0x82, 0x74, 0x01, 0x3E, 0xF5,
-0x83, 0xE0, 0xFF, 0x90, 0x85, 0x1E, 0xE0, 0x75,
-0xF0, 0x08, 0x22, 0x75, 0xF0, 0x03, 0x12, 0x05,
-0x28, 0xE0, 0xFE, 0x74, 0x01, 0xA8, 0x06, 0x08,
-0x22, 0xE0, 0x04, 0xF0, 0xE0, 0x7F, 0x00, 0x22,
-0x54, 0x07, 0xFF, 0x74, 0x01, 0x7E, 0x00, 0xA8,
-0x07, 0x08, 0x22, 0xE4, 0xF5, 0x75, 0x90, 0x85,
-0xBB, 0xE0, 0xFF, 0xE5, 0x75, 0xC3, 0x9F, 0x50,
-0x65, 0xAF, 0x75, 0x12, 0x77, 0x39, 0xEF, 0x60,
-0x59, 0xE5, 0x75, 0x13, 0x13, 0x13, 0x54, 0x1F,
-0xFF, 0xE5, 0x75, 0x54, 0x07, 0xFE, 0x74, 0x75,
-0x2F, 0x71, 0x11, 0xAF, 0x06, 0x51, 0x93, 0x80,
-0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
-0xFF, 0xEF, 0x5D, 0x60, 0x35, 0xE5, 0x75, 0xC4,
-0x54, 0xF0, 0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34,
-0x81, 0xF5, 0x83, 0xE0, 0x20, 0xE7, 0x02, 0x80,
-0x13, 0xE5, 0x75, 0xC4, 0x54, 0xF0, 0x24, 0x02,
-0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0,
-0xFF, 0x20, 0xE7, 0x09, 0x90, 0x01, 0xC1, 0xE0,
-0x44, 0x20, 0xF0, 0x80, 0x05, 0xAD, 0x75, 0x12,
-0x9A, 0xC9, 0x05, 0x75, 0x80, 0x90, 0x22, 0x80,
-0x8A, 0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83,
-0xE0, 0xFD, 0x22, 0x90, 0x85, 0xB5, 0xE0, 0xFF,
-0x70, 0x06, 0xA3, 0xE0, 0x64, 0x09, 0x60, 0x0A,
-0xEF, 0x14, 0xFF, 0x90, 0x85, 0xB6, 0xE0, 0xB5,
-0x07, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F, 0x00,
-0xEF, 0x60, 0x08, 0x90, 0x01, 0xC1, 0xE0, 0x44,
-0x02, 0xF0, 0x22, 0xC0, 0x01, 0x90, 0x85, 0xB6,
-0xE0, 0x75, 0xF0, 0x0F, 0xA4, 0x24, 0x1F, 0xF9,
-0x74, 0x85, 0x35, 0xF0, 0xA8, 0x01, 0xFC, 0x7D,
-0x01, 0xD0, 0x01, 0x7E, 0x00, 0x7F, 0x0F, 0x12,
-0x02, 0xD0, 0x7D, 0xCC, 0x7F, 0xFE, 0x12, 0x7B,
-0x3E, 0x90, 0x85, 0xB6, 0x51, 0x89, 0xB4, 0x0A,
-0x02, 0x7F, 0x01, 0xEF, 0x60, 0x05, 0xE4, 0x90,
-0x85, 0xB6, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x85, 0x1E, 0xE0, 0xFF,
-0x90, 0x85, 0x1D, 0xE0, 0xB5, 0x07, 0x04, 0x7F,
-0x01, 0x80, 0x02, 0x7F, 0x00, 0xEF, 0x70, 0x47,
-0x90, 0x85, 0x1D, 0xE0, 0xFE, 0x75, 0xF0, 0x08,
-0x90, 0x84, 0xCD, 0x12, 0x05, 0x28, 0xE0, 0xFD,
-0xEE, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0xCE, 0xF9,
-0x74, 0x84, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0xAF,
-0x05, 0x12, 0x8A, 0xD9, 0x90, 0x85, 0x1D, 0x51,
-0x89, 0xB4, 0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x60,
-0x05, 0xE4, 0x90, 0x85, 0x1D, 0xF0, 0x7D, 0x68,
-0x7F, 0xFE, 0x12, 0x7B, 0x3E, 0x12, 0x40, 0xB9,
-0x90, 0x84, 0xC1, 0xE0, 0x44, 0x02, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0xE4, 0xF5, 0x73, 0xEF,
-0x14, 0xF5, 0x72, 0xED, 0xFF, 0xE5, 0x72, 0xF5,
-0x82, 0x33, 0x95, 0xE0, 0xF5, 0x83, 0xC3, 0xE5,
-0x82, 0x9F, 0x74, 0x80, 0xF8, 0x65, 0x83, 0x98,
-0x40, 0x53, 0xE5, 0x72, 0x78, 0x03, 0xA2, 0xE7,
-0x13, 0xD8, 0xFB, 0xFF, 0x33, 0x95, 0xE0, 0xFE,
-0xEB, 0x12, 0xA7, 0xF5, 0xF5, 0x83, 0xE5, 0x82,
-0x2F, 0xF5, 0x82, 0xE5, 0x83, 0x3E, 0xF5, 0x83,
-0xE0, 0xF5, 0x82, 0x75, 0x83, 0x00, 0xE5, 0x72,
-0x51, 0x90, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
-0xCE, 0xD8, 0xF9, 0xFF, 0xEE, 0x55, 0x83, 0xFE,
-0xEF, 0x55, 0x82, 0x4E, 0x60, 0x13, 0x85, 0x72,
-0x74, 0x05, 0x73, 0x90, 0x94, 0x4B, 0xE0, 0x65,
-0x73, 0x60, 0x0A, 0xE5, 0x74, 0xD3, 0x9D, 0x40,
-0x04, 0x15, 0x72, 0x80, 0x96, 0xAF, 0x74, 0x22,
-0xAA, 0x07, 0xA9, 0x05, 0xEA, 0x12, 0x9B, 0x4A,
-0xE0, 0xF5, 0x6E, 0x54, 0x7F, 0xF5, 0x70, 0x75,
-0xF0, 0x12, 0xEA, 0x90, 0x89, 0x3D, 0x12, 0x05,
-0x28, 0xE0, 0x90, 0x94, 0x47, 0xF0, 0x75, 0xF0,
-0x12, 0xEA, 0xB1, 0x17, 0xFF, 0xEA, 0x12, 0x9A,
-0xBC, 0xE0, 0x54, 0x03, 0xF5, 0x6F, 0xE5, 0x70,
-0x90, 0x83, 0x1D, 0x93, 0xFD, 0xEA, 0x12, 0x9F,
-0x5F, 0xE4, 0xF0, 0xA3, 0xED, 0xF0, 0x75, 0xF0,
-0x12, 0xEA, 0x12, 0xA1, 0x8F, 0xFE, 0xC4, 0x54,
-0x03, 0x90, 0x94, 0x46, 0xF0, 0x74, 0xCC, 0x2A,
-0xB1, 0x0F, 0xE5, 0x70, 0xF0, 0x74, 0x4C, 0x2A,
-0xB1, 0x1F, 0xE5, 0x6F, 0xF0, 0xE5, 0x70, 0xD3,
-0x9F, 0x40, 0x04, 0x8F, 0x70, 0x8F, 0x6E, 0x89,
-0x71, 0xE4, 0xFF, 0xEF, 0xC3, 0x95, 0x71, 0x50,
-0x33, 0xE5, 0x6E, 0x30, 0xE7, 0x09, 0x85, 0x70,
-0x6E, 0x19, 0xE9, 0x70, 0x24, 0x80, 0x25, 0x90,
-0x94, 0x47, 0xE0, 0xFD, 0xE5, 0x70, 0xD3, 0x9D,
-0x40, 0x0F, 0xAB, 0x02, 0x90, 0x94, 0x4B, 0xE9,
-0xF0, 0xAF, 0x70, 0x71, 0xE4, 0x8F, 0x6E, 0x80,
-0x0B, 0x90, 0x94, 0x47, 0xE0, 0xF5, 0x6E, 0x80,
-0x03, 0x0F, 0x80, 0xC7, 0xAF, 0x02, 0x90, 0x91,
-0x0B, 0xE5, 0x6F, 0xF0, 0xE4, 0xFB, 0xAD, 0x6E,
-0x02, 0x27, 0x3D, 0x74, 0xCC, 0x25, 0x6E, 0xF5,
-0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0x22, 0x90,
-0x89, 0x3C, 0x12, 0x05, 0x28, 0xE0, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0x22, 0xC0,
-0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0,
-0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01,
-0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74,
-0x27, 0xF0, 0x74, 0xB5, 0xA3, 0xF0, 0x12, 0x71,
-0x90, 0xE5, 0x4C, 0x30, 0xE1, 0x02, 0xB1, 0xDF,
-0xE5, 0x4C, 0x30, 0xE4, 0x02, 0xD1, 0x5D, 0xE5,
-0x4C, 0x30, 0xE5, 0x03, 0x12, 0xCC, 0xC9, 0xE5,
-0x4C, 0x30, 0xE6, 0x03, 0x12, 0xC8, 0xD8, 0xE5,
-0x4E, 0x30, 0xE0, 0x03, 0x12, 0xAE, 0x8E, 0xE5,
-0x4E, 0x30, 0xE1, 0x02, 0xD1, 0x71, 0xE5, 0x4E,
-0x30, 0xE2, 0x03, 0x12, 0xC7, 0x9E, 0xE5, 0x4E,
-0x30, 0xE3, 0x02, 0xF1, 0x3D, 0xE5, 0x4E, 0x30,
-0xE4, 0x03, 0x12, 0xC1, 0x8D, 0xE5, 0x4E, 0x30,
-0xE5, 0x02, 0xF1, 0x71, 0xE5, 0x4E, 0x30, 0xE6,
-0x02, 0xF1, 0x51, 0xE5, 0x4F, 0x30, 0xE1, 0x03,
-0x12, 0xA7, 0xAE, 0xE5, 0x4F, 0x30, 0xE4, 0x02,
-0xF1, 0xE3, 0xE5, 0x4F, 0x30, 0xE5, 0x02, 0x71,
-0x0F, 0x74, 0x27, 0x04, 0x90, 0x01, 0xC4, 0xF0,
-0x74, 0xB5, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
-0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
-0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0xE4,
-0xFF, 0x90, 0x94, 0x51, 0xEF, 0xF0, 0x90, 0x04,
-0x7E, 0xE0, 0xFF, 0xA3, 0xE0, 0x90, 0x94, 0x61,
-0xF0, 0xE0, 0xFE, 0x6F, 0x60, 0x66, 0x90, 0x94,
-0x52, 0x74, 0x03, 0xF0, 0x90, 0x94, 0x60, 0x74,
-0x08, 0xF0, 0xEE, 0x04, 0x54, 0x0F, 0xFF, 0xE4,
-0xFE, 0xEF, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x00,
-0xF5, 0x82, 0xE4, 0x34, 0x80, 0xF5, 0x83, 0xE5,
-0x82, 0x2E, 0x12, 0xA7, 0x36, 0xE0, 0xFD, 0x74,
-0x54, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0xED, 0xF0, 0x0E, 0xEE, 0xB4, 0x08, 0xD9,
-0x7B, 0x01, 0x7A, 0x94, 0x79, 0x52, 0x12, 0x5E,
-0x10, 0x90, 0x94, 0x61, 0xE0, 0x04, 0x54, 0x0F,
-0xFF, 0xF0, 0xBF, 0x0F, 0x02, 0xE4, 0xF0, 0x90,
-0x94, 0x61, 0xE0, 0x90, 0x04, 0x7F, 0xF0, 0x90,
-0x94, 0x51, 0xE0, 0x7F, 0x04, 0x70, 0x02, 0x80,
-0x09, 0x12, 0x88, 0x18, 0x22, 0x12, 0x40, 0xB9,
-0x7F, 0x02, 0x8F, 0x0D, 0x7F, 0x02, 0x12, 0x86,
-0x27, 0x90, 0x84, 0xC1, 0xE0, 0x45, 0x0D, 0xF0,
-0x22, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x06,
-0x90, 0x85, 0xBE, 0x74, 0x01, 0xF0, 0x90, 0x85,
-0xC5, 0xE0, 0x70, 0x02, 0xE1, 0x1A, 0x90, 0x85,
-0xDC, 0xE0, 0x04, 0xF0, 0x12, 0x8D, 0x8C, 0x12,
-0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x05, 0x62, 0x12, 0x8D, 0xA5,
-0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x20,
-0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0xA3, 0x12, 0x8D, 0xA5, 0x78, 0x18, 0x12, 0x04,
-0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x87, 0x20, 0x90, 0x85, 0xFC, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x92, 0xC9, 0xE0,
-0x54, 0xFE, 0xF0, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
-0x0D, 0x12, 0xC7, 0x7D, 0x12, 0x51, 0x7D, 0x90,
-0x92, 0xC9, 0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x85,
-0xC2, 0xE0, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x30,
-0xE0, 0x09, 0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4,
-0x02, 0xF1, 0x2F, 0x90, 0x95, 0x18, 0xE0, 0x04,
-0xF0, 0xE0, 0xC3, 0x94, 0x80, 0x40, 0x0B, 0x90,
-0x01, 0x98, 0xE0, 0x54, 0xFE, 0xF0, 0xE0, 0x44,
-0x01, 0xF0, 0x7F, 0x01, 0xD1, 0x62, 0x90, 0x92,
-0x04, 0xE0, 0x30, 0xE0, 0x09, 0x90, 0x01, 0x3B,
-0xE0, 0x30, 0xE4, 0x02, 0xF1, 0x2F, 0x22, 0x7D,
-0x02, 0x7F, 0x02, 0x12, 0x7C, 0x41, 0x7D, 0x01,
-0x7F, 0x02, 0x02, 0x7C, 0x41, 0x12, 0xC4, 0x67,
-0x70, 0x0E, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x08,
-0x12, 0xC4, 0x80, 0xF1, 0xEB, 0x12, 0xC6, 0x20,
-0x22, 0xE4, 0xFF, 0x12, 0x77, 0x39, 0xBF, 0x01,
-0x0F, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x09, 0xF1,
-0x69, 0x54, 0x07, 0x70, 0x03, 0x12, 0xC1, 0x7B,
-0x22, 0x90, 0x85, 0xC9, 0xE0, 0x54, 0xFE, 0xF0,
-0x22, 0xE4, 0xFF, 0x12, 0x77, 0x39, 0xBF, 0x01,
-0x12, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x0C, 0xF1,
-0xDC, 0x64, 0x02, 0x60, 0x03, 0x02, 0x77, 0x61,
-0x12, 0x79, 0x41, 0x22, 0xE4, 0xF5, 0x75, 0x90,
-0x06, 0xA9, 0xE0, 0xF5, 0x75, 0x54, 0xC0, 0x70,
-0x08, 0xF1, 0x69, 0x54, 0xFD, 0xF0, 0x02, 0xC1,
-0x7B, 0xE5, 0x75, 0x30, 0xE6, 0x18, 0x90, 0x85,
-0xC5, 0xE0, 0x64, 0x01, 0x70, 0x12, 0xF1, 0xD5,
-0x64, 0x02, 0x60, 0x05, 0x12, 0x77, 0x61, 0x80,
-0x07, 0x12, 0x79, 0x41, 0x80, 0x02, 0xF1, 0x69,
-0xE5, 0x75, 0x90, 0x85, 0xC9, 0x30, 0xE7, 0x08,
-0xF1, 0xE8, 0x12, 0xC6, 0x20, 0x02, 0xC6, 0x9D,
-0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90, 0x85, 0xC9,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x85, 0xC3, 0xE0,
-0x54, 0x0F, 0x22, 0xE4, 0xFF, 0x02, 0x2D, 0xBD,
-0xE0, 0x44, 0x02, 0xF0, 0xE4, 0x90, 0x91, 0x6E,
-0xF0, 0x90, 0x86, 0x6E, 0xE0, 0x90, 0x91, 0x6F,
-0x22, 0xE4, 0xFC, 0xED, 0x2C, 0x24, 0x00, 0x11,
-0x4A, 0xE4, 0xF0, 0x0C, 0xEC, 0xB4, 0x18, 0xF3,
-0x74, 0x00, 0x2D, 0x11, 0x4A, 0xEF, 0xF0, 0xEE,
-0x54, 0x3F, 0xFF, 0x74, 0x01, 0x2D, 0xF5, 0x82,
-0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xEF, 0xF0, 0x74,
-0x02, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5,
-0x83, 0xE0, 0x54, 0xF0, 0xF0, 0x74, 0x03, 0x2D,
-0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0,
-0x44, 0x80, 0xF0, 0x74, 0x0B, 0x2D, 0xF5, 0x82,
-0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x44, 0x10,
-0xF0, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5,
-0x83, 0x22, 0x90, 0x93, 0xF3, 0xEF, 0xF0, 0xA3,
-0x12, 0x87, 0x4E, 0x90, 0x95, 0x12, 0xE0, 0xFE,
-0x04, 0xF0, 0x90, 0x00, 0x01, 0xEE, 0x12, 0x03,
-0x4E, 0x74, 0x00, 0x2F, 0xF9, 0xE4, 0x34, 0xFB,
-0xFA, 0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02, 0xC0,
-0x01, 0x90, 0x93, 0xF4, 0x12, 0x87, 0x45, 0x8B,
-0x1B, 0x8A, 0x1C, 0x89, 0x1D, 0x75, 0x1E, 0x02,
-0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03, 0x12, 0x6A,
-0x21, 0x90, 0x93, 0xF3, 0xE0, 0x24, 0x02, 0xF9,
-0xE4, 0x34, 0xFB, 0xFA, 0x7B, 0x01, 0xC0, 0x03,
-0xC0, 0x02, 0xC0, 0x01, 0xA3, 0x12, 0x87, 0x45,
-0xE9, 0x24, 0x02, 0xF9, 0xE4, 0x3A, 0x8B, 0x1B,
-0xF5, 0x1C, 0x89, 0x1D, 0x90, 0x93, 0xF4, 0x11,
-0xC4, 0xF5, 0x1E, 0xD0, 0x01, 0xD0, 0x02, 0xD0,
-0x03, 0x02, 0x6A, 0x21, 0x12, 0x87, 0x45, 0x90,
-0x00, 0x0E, 0x02, 0x03, 0x0F, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x93, 0xF7, 0x12,
-0x87, 0x4E, 0x7F, 0x96, 0x7E, 0x02, 0x12, 0x66,
-0x80, 0xEF, 0x60, 0x4E, 0x90, 0x01, 0x17, 0xE0,
-0xFE, 0x90, 0x01, 0x16, 0xE0, 0x7C, 0x00, 0x24,
-0x00, 0xFF, 0xEC, 0x3E, 0xFE, 0x31, 0x37, 0x90,
-0x93, 0xFA, 0xEF, 0xF0, 0xEE, 0xFF, 0x90, 0xFD,
-0x11, 0xF0, 0x90, 0x93, 0xFA, 0xE0, 0xFD, 0x90,
-0x02, 0x94, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93,
-0xF7, 0x11, 0xC4, 0x24, 0x02, 0xFF, 0xE4, 0x33,
-0xFE, 0x12, 0x5A, 0xA5, 0x90, 0x93, 0xFA, 0xE0,
-0x24, 0x18, 0xFF, 0x90, 0x93, 0xF7, 0x12, 0x87,
-0x45, 0x12, 0x56, 0xF4, 0x90, 0x02, 0x96, 0x74,
-0x01, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF,
-0x24, 0x01, 0xFF, 0xE4, 0x3E, 0xFE, 0x22, 0x12,
-0x02, 0xF6, 0x64, 0x01, 0x60, 0x02, 0x21, 0xD0,
-0x90, 0x93, 0xE2, 0xF0, 0x90, 0x93, 0xE2, 0xE0,
-0xFF, 0xC3, 0x94, 0x10, 0x50, 0x27, 0xEF, 0x31,
-0xD1, 0x7A, 0x93, 0x79, 0xE1, 0x12, 0x64, 0x37,
-0xBF, 0x01, 0x12, 0x90, 0x93, 0xE1, 0xE0, 0xFF,
-0xA3, 0xE0, 0x24, 0xE3, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x93, 0xE2,
-0xE0, 0x04, 0xF0, 0x80, 0xCF, 0x75, 0x1B, 0x01,
-0x75, 0x1C, 0x93, 0x75, 0x1D, 0xE3, 0x75, 0x1E,
-0x08, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xC5, 0x12,
-0x6A, 0x21, 0x90, 0x93, 0xC3, 0x74, 0x24, 0xF0,
-0x90, 0x93, 0xD1, 0x74, 0x08, 0xF0, 0x75, 0x1B,
-0x01, 0x75, 0x1C, 0x93, 0x75, 0x1D, 0xEB, 0xF5,
-0x1E, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xD4, 0x12,
-0x6A, 0x21, 0x90, 0x93, 0xD2, 0x74, 0x25, 0xF0,
-0x90, 0x93, 0xE0, 0x74, 0x08, 0xF0, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0xC3, 0x12, 0x5E, 0x10, 0x7B,
-0x01, 0x7A, 0x93, 0x79, 0xD2, 0x12, 0x88, 0x13,
-0x22, 0x24, 0xDE, 0xFF, 0xE4, 0x33, 0xFE, 0x7B,
-0x01, 0x22, 0x12, 0xA0, 0x37, 0x12, 0x02, 0xF6,
-0x64, 0x01, 0x60, 0x02, 0x41, 0x6E, 0xEF, 0x24,
-0x39, 0x60, 0x12, 0x14, 0x60, 0x19, 0x24, 0x02,
-0x70, 0x1F, 0xE4, 0x90, 0x93, 0xC9, 0xF0, 0xA3,
-0x74, 0x06, 0xF0, 0x80, 0x14, 0x90, 0x93, 0xC9,
-0x74, 0x06, 0xF0, 0xA3, 0xF0, 0x80, 0x0A, 0x90,
-0x93, 0xC9, 0x74, 0x0C, 0xF0, 0xA3, 0x74, 0x04,
-0xF0, 0x51, 0x81, 0xF0, 0x51, 0x6F, 0x40, 0x1C,
-0x90, 0x93, 0xC7, 0xE0, 0x31, 0xD1, 0x7A, 0x93,
-0x79, 0xC6, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x07,
-0x90, 0x93, 0xC6, 0xE0, 0xF4, 0x70, 0x3F, 0x51,
-0x77, 0xF0, 0x80, 0xE0, 0x51, 0x81, 0xF0, 0x51,
-0x6F, 0x40, 0x33, 0x90, 0x93, 0xC7, 0xE0, 0xFD,
-0x7C, 0x00, 0x24, 0xDE, 0xFF, 0xEC, 0x33, 0xFE,
-0xED, 0x24, 0x01, 0xFD, 0xEC, 0x33, 0xFC, 0x90,
-0x93, 0xC9, 0xE0, 0xFB, 0xC3, 0xED, 0x9B, 0xFD,
-0xEC, 0x94, 0x00, 0xFC, 0x12, 0x8F, 0x58, 0x8D,
-0x82, 0x8C, 0x83, 0x12, 0x03, 0x0F, 0xFD, 0x51,
-0x91, 0x51, 0x77, 0xF0, 0x80, 0xC9, 0x22, 0x90,
-0x93, 0xC8, 0xE0, 0xD3, 0x94, 0x00, 0x22, 0x90,
-0x93, 0xC7, 0xE0, 0x04, 0xF0, 0xA3, 0xE0, 0x14,
-0x22, 0x90, 0x93, 0xC9, 0xE0, 0x90, 0x93, 0xC7,
-0xF0, 0x90, 0x93, 0xCA, 0xE0, 0x90, 0x93, 0xC8,
-0x22, 0x8E, 0x5B, 0x8F, 0x5C, 0x8D, 0x5D, 0xE4,
-0x90, 0x93, 0xCB, 0xF0, 0x90, 0x00, 0x37, 0xE0,
-0x44, 0x80, 0xFD, 0x7F, 0x37, 0x12, 0x7B, 0x3E,
-0x7D, 0x69, 0x7F, 0xCF, 0x12, 0x7B, 0x3E, 0xE5,
-0x5C, 0xFD, 0x7F, 0x31, 0x12, 0x7B, 0x3E, 0xE5,
-0x5B, 0x54, 0x03, 0xFF, 0x90, 0x00, 0x32, 0xE0,
-0x54, 0xFC, 0x4F, 0xFD, 0x7F, 0x32, 0x12, 0x7B,
-0x3E, 0xAD, 0x5D, 0x7F, 0x30, 0x12, 0x7B, 0x3E,
-0x90, 0x00, 0x33, 0xE0, 0x44, 0x80, 0xFD, 0x7F,
-0x33, 0x12, 0x7B, 0x3E, 0x90, 0x00, 0x33, 0xE0,
-0x30, 0xE7, 0x09, 0x71, 0x08, 0x50, 0x05, 0xE0,
-0x04, 0xF0, 0x80, 0xF0, 0xE4, 0xFD, 0x7F, 0xCF,
-0x12, 0x7B, 0x3E, 0x90, 0x00, 0x37, 0xE0, 0x54,
-0x7F, 0xFD, 0x7F, 0x37, 0x12, 0x7B, 0x3E, 0x71,
-0x08, 0x7F, 0x00, 0x50, 0x02, 0x7F, 0x01, 0x22,
-0x90, 0x93, 0xCB, 0xE0, 0xC3, 0x94, 0x64, 0x22,
-0xE4, 0x90, 0x84, 0xC1, 0xF0, 0xA3, 0xF0, 0xA3,
-0xF0, 0xA3, 0xF0, 0x90, 0x92, 0x01, 0xF0, 0x22,
-0x90, 0x00, 0x80, 0xE0, 0x44, 0x80, 0xFD, 0x7F,
-0x80, 0x12, 0x7B, 0x3E, 0x12, 0xC7, 0xE8, 0x12,
-0xCC, 0x75, 0x12, 0x7B, 0x9C, 0x91, 0x43, 0x71,
-0x10, 0x7F, 0x01, 0x12, 0x85, 0x15, 0x90, 0x92,
-0x08, 0x74, 0x02, 0xF0, 0xFF, 0x12, 0x85, 0x15,
-0x90, 0x92, 0x08, 0xE0, 0x04, 0xF0, 0x91, 0x68,
-0x91, 0x1D, 0x90, 0x01, 0xCC, 0x74, 0x0F, 0xF0,
-0x90, 0x00, 0x80, 0xE0, 0x44, 0x40, 0xFD, 0x7F,
-0x80, 0x12, 0x7B, 0x3E, 0x75, 0x20, 0xFF, 0x12,
-0x7C, 0xCD, 0x90, 0x01, 0xA0, 0xE0, 0xB4, 0xFD,
-0x05, 0xE4, 0xFF, 0x12, 0x88, 0x33, 0x91, 0xCD,
-0x90, 0x00, 0x81, 0xE0, 0x44, 0x04, 0xFD, 0x7F,
-0x81, 0x12, 0x7B, 0x3E, 0x12, 0xC0, 0x2B, 0x71,
-0x8E, 0xE4, 0xFF, 0x02, 0x85, 0x9E, 0x7E, 0x00,
-0x7F, 0x0B, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x92,
-0x79, 0xBD, 0x12, 0x06, 0xDE, 0x91, 0x16, 0xF1,
-0x6C, 0xBF, 0x01, 0x1C, 0x90, 0x93, 0xFB, 0xE0,
-0xFE, 0x54, 0x01, 0x90, 0x92, 0xBD, 0xF0, 0xEE,
-0x54, 0x04, 0x90, 0x92, 0xBF, 0xF0, 0x90, 0x93,
-0xFB, 0xE0, 0x54, 0x08, 0x90, 0x92, 0xBE, 0xF0,
-0x91, 0x16, 0x12, 0x8A, 0x85, 0x70, 0x34, 0x90,
-0x93, 0xFB, 0xE0, 0x54, 0x07, 0x70, 0x14, 0x7B,
-0x01, 0x7A, 0x93, 0x79, 0xFC, 0x7F, 0xFA, 0xFE,
-0x12, 0x64, 0x37, 0xBF, 0x01, 0x0F, 0x90, 0x93,
-0xFC, 0x80, 0x03, 0x90, 0x93, 0xFB, 0xE0, 0x54,
-0x07, 0x90, 0x92, 0xC1, 0xF0, 0x90, 0x93, 0xFB,
-0xE0, 0x54, 0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90,
-0x92, 0xC0, 0xF0, 0x91, 0x16, 0x7F, 0xFD, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x0E, 0x90,
-0x93, 0xFB, 0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54,
-0x3F, 0x90, 0x92, 0xC2, 0xF0, 0x22, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0xFB, 0x22, 0xB1, 0xF9, 0x12,
-0x7B, 0xEF, 0x12, 0x3C, 0x03, 0x12, 0xCA, 0xE9,
-0x12, 0xCD, 0x91, 0xB1, 0x1E, 0x91, 0x3E, 0x7E,
-0x00, 0x7F, 0xB3, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
-0x92, 0x79, 0x09, 0x02, 0x06, 0xDE, 0xB1, 0xEC,
-0x02, 0x06, 0xDE, 0x90, 0x00, 0x00, 0xE0, 0x54,
-0xFB, 0xFD, 0xE4, 0xFF, 0xF1, 0x7B, 0x44, 0x04,
-0xFD, 0x7F, 0x01, 0x12, 0x7B, 0x3E, 0x90, 0x01,
-0x98, 0x74, 0x80, 0xF0, 0xA3, 0x74, 0x88, 0xF0,
-0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x80, 0xF0, 0x22,
-0x12, 0x7C, 0x4E, 0x90, 0x84, 0xC5, 0xEF, 0xF0,
-0x91, 0x9C, 0x90, 0x01, 0x64, 0x74, 0x01, 0xF0,
-0x90, 0x04, 0x23, 0xE0, 0x44, 0x80, 0xF0, 0x90,
-0x00, 0x17, 0xE0, 0x54, 0xFC, 0x44, 0x04, 0xFD,
-0x7F, 0x17, 0x12, 0x7B, 0x3E, 0x90, 0x00, 0x38,
-0xE0, 0x44, 0x40, 0xFD, 0x7F, 0x38, 0x12, 0x7B,
-0x3E, 0x02, 0x68, 0xE2, 0x12, 0x75, 0xB6, 0x12,
-0x75, 0x58, 0xF1, 0xE5, 0x12, 0xC0, 0x0C, 0xE4,
-0xF5, 0x40, 0xF5, 0x41, 0xF5, 0x42, 0x75, 0x43,
-0x80, 0xAD, 0x40, 0x7F, 0x50, 0x12, 0x7B, 0x3E,
-0xAD, 0x41, 0x7F, 0x51, 0x12, 0x7B, 0x3E, 0xAD,
-0x42, 0x7F, 0x52, 0x12, 0x7B, 0x3E, 0xAD, 0x43,
-0x7F, 0x53, 0x02, 0x7B, 0x3E, 0xE4, 0x90, 0x93,
-0xFB, 0xF0, 0xA3, 0xF0, 0x12, 0xCC, 0xA0, 0xEF,
-0x64, 0x01, 0x60, 0x3B, 0xC3, 0x90, 0x93, 0xFC,
-0xE0, 0x94, 0x88, 0x90, 0x93, 0xFB, 0xE0, 0x94,
-0x13, 0x40, 0x0F, 0x90, 0x01, 0xC1, 0xE0, 0x44,
-0x10, 0xF0, 0x90, 0x01, 0xC7, 0x74, 0xFD, 0xF0,
-0x80, 0x1D, 0x90, 0x93, 0xFB, 0xB1, 0xFF, 0xD1,
-0x57, 0xD3, 0x90, 0x93, 0xFC, 0xE0, 0x94, 0x32,
-0x90, 0x93, 0xFB, 0xE0, 0x94, 0x00, 0x40, 0xC4,
-0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE3, 0xBD, 0x90,
-0x01, 0xC7, 0x74, 0xFE, 0xF0, 0x22, 0x7E, 0x00,
-0x7F, 0xAC, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x85,
-0x79, 0xC1, 0x12, 0x06, 0xDE, 0xB1, 0xEC, 0x12,
-0x06, 0xDE, 0x90, 0x85, 0xC4, 0x74, 0x02, 0xF0,
-0x90, 0x85, 0xCB, 0x14, 0xF0, 0xA3, 0xF0, 0xA3,
-0x74, 0x0A, 0xF0, 0x90, 0x85, 0xD1, 0xE4, 0xF0,
-0xA3, 0x74, 0x02, 0xB1, 0xDC, 0x12, 0xCE, 0x89,
-0xE4, 0xFD, 0xFF, 0x12, 0x57, 0x82, 0x7D, 0x0C,
-0x7F, 0x02, 0x12, 0x57, 0x82, 0x7D, 0x0C, 0x7F,
-0x01, 0x12, 0x57, 0x82, 0x90, 0x84, 0xC5, 0xE0,
-0xFF, 0xB4, 0x01, 0x08, 0x90, 0x85, 0xD0, 0x74,
-0xDD, 0xF0, 0x80, 0x0F, 0xEF, 0x90, 0x85, 0xD0,
-0xB4, 0x03, 0x05, 0x74, 0xD4, 0xF0, 0x80, 0x03,
-0x74, 0x40, 0xF0, 0x7F, 0x2C, 0x12, 0x7B, 0x51,
-0xEF, 0x54, 0x0F, 0xFF, 0xBF, 0x05, 0x08, 0x90,
-0x85, 0xFB, 0x74, 0x02, 0xF0, 0x80, 0x05, 0xE4,
-0x90, 0x85, 0xFB, 0xF0, 0x90, 0x86, 0x6D, 0x74,
-0x02, 0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0xE0,
-0x54, 0x01, 0x44, 0x28, 0xF0, 0xA3, 0x74, 0x07,
-0xB1, 0xDC, 0xE4, 0x90, 0x85, 0xD7, 0xF0, 0xA3,
-0xF0, 0x7F, 0x01, 0x12, 0x69, 0x33, 0x90, 0x05,
-0x58, 0x74, 0x02, 0xF0, 0x90, 0x06, 0x04, 0xE0,
-0x54, 0x7F, 0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x54,
-0xF8, 0xF0, 0x90, 0x05, 0x22, 0xE4, 0xF0, 0x90,
-0x86, 0x71, 0xF0, 0x22, 0xF0, 0x90, 0x85, 0xFB,
-0xE0, 0x24, 0x04, 0x90, 0x85, 0xDD, 0xF0, 0xA3,
-0x74, 0x0A, 0xF0, 0x22, 0x7E, 0x00, 0x7F, 0x04,
-0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x04,
-0x22, 0xE4, 0xFD, 0xFF, 0x02, 0x6E, 0x5F, 0xE4,
-0x75, 0xF0, 0x01, 0x02, 0x07, 0x0A, 0x90, 0x95,
-0x0B, 0xEF, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0,
-0x90, 0x01, 0x09, 0xE0, 0x7F, 0x00, 0x30, 0xE7,
-0x02, 0x7F, 0x01, 0x90, 0x95, 0x0B, 0xE0, 0x6F,
-0x60, 0x34, 0xC3, 0x90, 0x95, 0x0D, 0xE0, 0x94,
-0x88, 0x90, 0x95, 0x0C, 0xE0, 0x94, 0x13, 0x40,
-0x08, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x10, 0xF0,
-0x22, 0x90, 0x95, 0x0C, 0xB1, 0xFF, 0xD1, 0x57,
-0xD3, 0x90, 0x95, 0x0D, 0xE0, 0x94, 0x32, 0x90,
-0x95, 0x0C, 0xE0, 0x94, 0x00, 0x40, 0xC1, 0x90,
-0x01, 0xC6, 0xE0, 0x30, 0xE0, 0xBA, 0x22, 0x7F,
-0x14, 0x7E, 0x00, 0x02, 0x7C, 0x9F, 0x12, 0xCD,
-0x72, 0x7F, 0x08, 0x12, 0x7B, 0x51, 0xEF, 0x54,
-0xEF, 0xFD, 0x7F, 0x08, 0x12, 0x7B, 0x3E, 0xE4,
-0xFF, 0xD1, 0x06, 0x7D, 0x35, 0x7F, 0x27, 0x12,
-0x7B, 0x3E, 0x90, 0x85, 0xC2, 0xE0, 0x54, 0xEF,
-0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0xD1, 0x92, 0xD1, 0x5E, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x90, 0x85, 0xC2, 0xE0, 0x44, 0x10,
-0xF0, 0x90, 0x85, 0xD0, 0xE0, 0xFD, 0x7F, 0x93,
-0x12, 0x7B, 0x3E, 0x90, 0x85, 0xC6, 0xE0, 0x60,
-0x12, 0x90, 0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x05,
-0x74, 0x10, 0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F,
-0x74, 0x90, 0xF0, 0x7F, 0x08, 0x12, 0x7B, 0x51,
-0xEF, 0x44, 0x10, 0xFD, 0x7F, 0x08, 0x12, 0x7B,
-0x3E, 0x7F, 0x01, 0xD1, 0x06, 0x7D, 0x34, 0x7F,
-0x27, 0x12, 0x7B, 0x3E, 0x7F, 0x90, 0xF1, 0x83,
-0x7F, 0x90, 0x12, 0x7B, 0x3E, 0x7F, 0x14, 0x7E,
-0x00, 0x02, 0x7C, 0x9F, 0x90, 0x85, 0xC8, 0xE0,
-0xFF, 0x60, 0x03, 0xB4, 0x08, 0x0D, 0xF1, 0x1D,
-0xBF, 0x01, 0x08, 0xD1, 0x82, 0x90, 0x01, 0xE5,
-0xE0, 0x04, 0xF0, 0x22, 0x90, 0x85, 0xC1, 0xE0,
-0x30, 0xE0, 0x19, 0x90, 0x85, 0xBC, 0xE0, 0xFF,
-0x30, 0xE0, 0x0F, 0xC3, 0x13, 0x30, 0xE0, 0x08,
-0x12, 0xCD, 0xB3, 0xBF, 0x01, 0x06, 0x80, 0x02,
-0x80, 0x00, 0xD1, 0xE4, 0x22, 0x90, 0x92, 0x04,
-0xE0, 0xC3, 0x13, 0x20, 0xE0, 0x35, 0x90, 0x02,
-0x87, 0xE0, 0x60, 0x02, 0x80, 0x08, 0x90, 0x01,
-0x00, 0xE0, 0x64, 0x3F, 0x60, 0x05, 0x75, 0x62,
-0x01, 0x80, 0x22, 0x90, 0x02, 0x96, 0xE0, 0x60,
-0x05, 0x75, 0x62, 0x10, 0x80, 0x17, 0x90, 0x02,
-0x86, 0xE0, 0x20, 0xE1, 0x02, 0x80, 0x07, 0x90,
-0x02, 0x86, 0xE0, 0x30, 0xE3, 0x05, 0x75, 0x62,
-0x04, 0x80, 0x02, 0x80, 0x16, 0x90, 0x01, 0xB9,
-0x74, 0x08, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x62,
-0xF0, 0x7F, 0x00, 0x22, 0x7F, 0xF9, 0x7E, 0x00,
-0x02, 0x64, 0x37, 0x90, 0x01, 0xB8, 0xE4, 0xF0,
-0x7F, 0x01, 0x22, 0x12, 0x7B, 0x3E, 0x90, 0x01,
-0x01, 0xE0, 0x22, 0x12, 0x7B, 0x51, 0xEF, 0x44,
-0x01, 0xFD, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x7F, 0x02, 0xF1, 0x83, 0x7F, 0x02,
-0xF1, 0x7B, 0x44, 0x02, 0xF0, 0x90, 0x01, 0x00,
-0x74, 0xFF, 0xF0, 0x90, 0x06, 0xB7, 0x74, 0x09,
-0xF0, 0x90, 0x06, 0xB4, 0x74, 0x86, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0xF1, 0x8B, 0x12, 0xCA,
-0xA8, 0x74, 0x01, 0xF0, 0x22, 0xF1, 0xB4, 0x90,
-0x05, 0x27, 0xE0, 0x54, 0xBF, 0xF0, 0xE4, 0x90,
-0x85, 0xBF, 0xF0, 0x22, 0xF1, 0xD0, 0x80, 0xEF,
-0xE4, 0xFD, 0xFF, 0x12, 0x98, 0xE3, 0x12, 0xCA,
-0xC2, 0x90, 0x85, 0xBF, 0x74, 0x01, 0xF0, 0x22,
-0x12, 0xCA, 0xA2, 0x80, 0xDA, 0x75, 0x48, 0x12,
-0xE4, 0xF5, 0x49, 0x75, 0x4A, 0x07, 0x75, 0x4B,
-0x32, 0xF5, 0x50, 0x90, 0x01, 0x30, 0xE5, 0x48,
-0xF0, 0xA3, 0xE5, 0x49, 0xF0, 0xA3, 0xE5, 0x4A,
-0xF0, 0xA3, 0xE5, 0x4B, 0xF0, 0x90, 0x01, 0x20,
-0xE5, 0x50, 0xF0, 0x22, 0x75, 0x52, 0x06, 0x75,
-0x53, 0x01, 0x75, 0x54, 0x03, 0x75, 0x55, 0x62,
-0x90, 0x01, 0x38, 0xE5, 0x52, 0xF0, 0xA3, 0xE5,
-0x53, 0xF0, 0xA3, 0xE5, 0x54, 0xF0, 0xA3, 0xE5,
-0x55, 0xF0, 0x22, 0x90, 0x01, 0xE4, 0x74, 0x04,
-0xF0, 0xA3, 0xE4, 0xF0, 0x22, 0x7D, 0x02, 0x90,
-0x01, 0xC4, 0x74, 0x35, 0xF0, 0x74, 0xC0, 0xA3,
-0xF0, 0x90, 0x92, 0x08, 0xE0, 0xFF, 0xED, 0xC3,
-0x9F, 0x50, 0x18, 0xED, 0x25, 0xE0, 0x24, 0x81,
-0xF8, 0xE6, 0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8,
-0x74, 0x08, 0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22,
-0x0D, 0x80, 0xDE, 0x7F, 0x01, 0x22, 0xE4, 0x90,
-0x94, 0x29, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90,
-0x94, 0x29, 0xE0, 0x64, 0x01, 0xF0, 0x90, 0x92,
-0xC6, 0xE0, 0x70, 0x18, 0x90, 0x92, 0xC3, 0xE0,
-0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E, 0x90, 0x94,
-0x29, 0xE0, 0x24, 0x66, 0x90, 0x01, 0xC4, 0xF0,
-0x74, 0xC0, 0xA3, 0xF0, 0x12, 0x7C, 0x66, 0xBF,
-0x01, 0x03, 0x12, 0x5B, 0x25, 0x90, 0x85, 0xC5,
-0xE0, 0x60, 0x0E, 0x90, 0x85, 0xC8, 0xE0, 0xFF,
-0x90, 0x85, 0xC7, 0xE0, 0x6F, 0x60, 0x02, 0x31,
-0x7B, 0xC2, 0xAF, 0x11, 0x35, 0xBF, 0x01, 0x03,
-0x12, 0xBE, 0xFC, 0xD2, 0xAF, 0x11, 0xC7, 0x12,
-0xA7, 0xEC, 0x12, 0x84, 0x4D, 0x80, 0xA8, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x92,
-0xC3, 0xE0, 0x60, 0x25, 0x7F, 0x54, 0x7E, 0x09,
-0x12, 0x70, 0x61, 0x31, 0x6F, 0xEF, 0x44, 0xFE,
-0xFF, 0xEE, 0x44, 0x03, 0xFE, 0xED, 0x44, 0x04,
-0xFD, 0xEC, 0x31, 0x6F, 0x90, 0x91, 0x66, 0x12,
-0x04, 0xEB, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x71,
-0x18, 0x90, 0x92, 0xBE, 0xE0, 0x70, 0x24, 0x90,
-0x07, 0xCC, 0xE0, 0x30, 0xE0, 0x1D, 0xE4, 0xF0,
-0x90, 0x94, 0x30, 0x74, 0x22, 0xF0, 0x90, 0x94,
-0x3E, 0x74, 0x01, 0xF0, 0x90, 0x94, 0x32, 0x74,
-0x03, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x30,
-0x12, 0x88, 0x13, 0x90, 0x92, 0xC6, 0xE0, 0xFF,
-0x70, 0x0A, 0x90, 0x92, 0xC3, 0xE0, 0x70, 0x04,
-0xA3, 0xE0, 0x60, 0x15, 0x90, 0x00, 0x1F, 0xE0,
-0x54, 0xF0, 0xF0, 0x90, 0x01, 0xC5, 0x74, 0xEA,
-0xF0, 0xA3, 0x74, 0xEF, 0xF0, 0xA3, 0x74, 0xFD,
-0xF0, 0xEF, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74,
-0x07, 0xF0, 0x90, 0x92, 0xC3, 0xE0, 0x60, 0x06,
-0x90, 0x01, 0xC4, 0x74, 0x01, 0xF0, 0x90, 0x92,
-0xC4, 0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74,
-0x02, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
-0x94, 0x2C, 0x12, 0x04, 0xEB, 0x90, 0x94, 0x2C,
-0x02, 0x87, 0x2D, 0x90, 0x85, 0xBC, 0xE0, 0x90,
-0x85, 0xC7, 0x30, 0xE0, 0x05, 0xE0, 0xFF, 0x02,
-0xA7, 0x3E, 0x02, 0xA7, 0xCC, 0x91, 0x67, 0x70,
-0x15, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x0F, 0x91,
-0x80, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x91, 0xAE,
-0x54, 0x07, 0x70, 0x02, 0x31, 0x7B, 0x22, 0x90,
-0x85, 0xC5, 0xE0, 0x60, 0x10, 0x90, 0x06, 0x92,
-0xE0, 0x30, 0xE1, 0x05, 0x12, 0x6B, 0x98, 0x80,
-0x04, 0xD1, 0xA5, 0x31, 0x7B, 0x90, 0x92, 0x0C,
-0xE0, 0xB4, 0x01, 0x03, 0x12, 0x94, 0x17, 0x22,
-0x90, 0x85, 0xC1, 0x12, 0xA6, 0x85, 0x30, 0xE0,
-0x19, 0xEF, 0x54, 0xBF, 0x51, 0xCB, 0x30, 0xE0,
-0x06, 0xE0, 0x44, 0x01, 0xF0, 0x80, 0x09, 0xE0,
-0x54, 0xFE, 0xF0, 0x51, 0xD4, 0x74, 0x04, 0xF0,
-0x31, 0x7B, 0x22, 0x90, 0x85, 0xC1, 0xE0, 0xFF,
-0x12, 0xA3, 0x01, 0x30, 0xE0, 0x1E, 0xEF, 0x54,
-0x7F, 0x51, 0xCB, 0x30, 0xE1, 0x06, 0xE0, 0x44,
-0x02, 0xF0, 0x80, 0x08, 0xE0, 0x54, 0xFD, 0xF0,
-0x51, 0xD4, 0x04, 0xF0, 0x90, 0x85, 0xC5, 0xE0,
-0x60, 0x02, 0x31, 0x7B, 0x90, 0x04, 0xE0, 0xE0,
-0x30, 0xE1, 0x05, 0x91, 0xD9, 0x12, 0x97, 0x70,
-0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0,
-0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00,
-0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01,
-0xC4, 0x74, 0x21, 0xF0, 0x74, 0xC2, 0xA3, 0xF0,
-0x12, 0x75, 0x28, 0xE5, 0x56, 0x30, 0xE0, 0x02,
-0xF1, 0x8B, 0xE5, 0x56, 0x30, 0xE1, 0x02, 0x51,
-0xDE, 0xE5, 0x56, 0x30, 0xE2, 0x02, 0x31, 0xA7,
-0xE5, 0x56, 0x30, 0xE5, 0x03, 0x12, 0x8F, 0x8B,
-0xE5, 0x57, 0x30, 0xE0, 0x02, 0xB1, 0x0F, 0xE5,
-0x58, 0x30, 0xE1, 0x02, 0xB1, 0x42, 0xE5, 0x58,
-0x30, 0xE0, 0x03, 0x12, 0xC8, 0xE5, 0xE5, 0x58,
-0x30, 0xE4, 0x02, 0xD1, 0x9C, 0xE5, 0x59, 0x30,
-0xE1, 0x05, 0x7F, 0x04, 0x12, 0xB6, 0x62, 0xE5,
-0x59, 0x30, 0xE4, 0x03, 0x12, 0xAF, 0x00, 0xE5,
-0x59, 0x30, 0xE5, 0x02, 0x31, 0xC8, 0xE5, 0x59,
-0x30, 0xE6, 0x02, 0x31, 0xEB, 0x74, 0x21, 0x04,
-0x90, 0x01, 0xC4, 0xF0, 0x74, 0xC2, 0xA3, 0xF0,
-0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
-0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
-0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
-0xD0, 0xE0, 0x32, 0xF0, 0x90, 0x04, 0xE0, 0xE0,
-0x90, 0x85, 0xC2, 0x22, 0x90, 0x01, 0xB9, 0x74,
-0x01, 0xF0, 0x90, 0x01, 0xB8, 0x22, 0x90, 0x85,
-0xC5, 0xE0, 0x60, 0x02, 0x51, 0xEC, 0x12, 0x95,
-0xDC, 0x02, 0x94, 0x17, 0x71, 0x4E, 0x13, 0x54,
-0x1F, 0x30, 0xE0, 0x0B, 0xEF, 0xC4, 0x13, 0x13,
-0x54, 0x03, 0x30, 0xE0, 0x02, 0x91, 0x79, 0x90,
-0x85, 0xC1, 0x91, 0xB9, 0x30, 0xE0, 0x09, 0xEF,
-0x91, 0xAE, 0x54, 0x07, 0x70, 0x37, 0x80, 0x33,
-0x91, 0xC0, 0x40, 0x2F, 0x91, 0x67, 0x70, 0x2D,
-0x12, 0xB7, 0xDC, 0x70, 0x05, 0x12, 0x70, 0xDB,
-0x80, 0x24, 0x12, 0x70, 0xDB, 0x90, 0x85, 0xCF,
-0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94, 0x02, 0x40,
-0x09, 0x71, 0x46, 0xE4, 0x90, 0x85, 0xCF, 0xF0,
-0x80, 0x03, 0x12, 0x79, 0x41, 0xE4, 0x90, 0x85,
-0xCE, 0xF0, 0x22, 0x31, 0x7B, 0x22, 0x90, 0x85,
-0xC2, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0x90, 0x85,
-0xC2, 0xE0, 0xFF, 0x13, 0x13, 0x22, 0x91, 0x67,
-0x60, 0x02, 0x81, 0x4B, 0x90, 0x85, 0xC5, 0xE0,
-0x70, 0x02, 0x81, 0x4B, 0x90, 0x05, 0x63, 0xE0,
-0x90, 0x92, 0xCE, 0xF0, 0x90, 0x05, 0x62, 0xE0,
-0x90, 0x92, 0xCF, 0xF0, 0x90, 0x05, 0x61, 0xE0,
-0x90, 0x92, 0xD0, 0xF0, 0x90, 0x05, 0x60, 0xE0,
-0x90, 0x92, 0xD1, 0xF0, 0x91, 0x80, 0xF0, 0x90,
-0x85, 0xC9, 0xE0, 0x54, 0xEC, 0xF0, 0x91, 0x70,
-0x24, 0xFD, 0x50, 0x02, 0x80, 0x0E, 0x90, 0x85,
-0xBC, 0xE0, 0x30, 0xE0, 0x04, 0xD1, 0x2B, 0x80,
-0x03, 0x12, 0xB7, 0x8C, 0x91, 0x70, 0x64, 0x01,
-0x70, 0x30, 0x90, 0x06, 0xAB, 0xE0, 0x90, 0x85,
-0xCC, 0xF0, 0x90, 0x06, 0xA9, 0xE0, 0x30, 0xE5,
-0x05, 0xA3, 0xE0, 0xFF, 0x80, 0x05, 0x90, 0x85,
-0xCB, 0xE0, 0xFF, 0x90, 0x85, 0xCB, 0xEF, 0xF0,
-0xA3, 0xE0, 0xFF, 0x70, 0x08, 0x90, 0x85, 0xCB,
-0xE0, 0xFE, 0xFF, 0x80, 0x00, 0x90, 0x85, 0xCC,
-0xEF, 0xF0, 0x12, 0xCE, 0xA1, 0xE4, 0x90, 0x85,
-0xCE, 0xF0, 0xD1, 0xAD, 0x71, 0x4E, 0x13, 0x54,
-0x1F, 0x30, 0xE0, 0x5D, 0xEF, 0xC4, 0x13, 0x13,
-0x54, 0x03, 0x20, 0xE0, 0x24, 0x91, 0x5F, 0x6F,
-0x70, 0x4F, 0xEF, 0x60, 0x4C, 0x90, 0x85, 0xC2,
-0xE0, 0x44, 0x40, 0xF0, 0xB1, 0xE9, 0x12, 0xAF,
-0x67, 0x12, 0x7B, 0xFD, 0x12, 0xB7, 0x36, 0x91,
-0x79, 0x90, 0x85, 0xCC, 0xE0, 0x14, 0xF0, 0x80,
-0x30, 0x90, 0x85, 0xC3, 0xE0, 0xC4, 0x54, 0x0F,
-0x64, 0x01, 0x70, 0x25, 0x91, 0x5F, 0xFE, 0x6F,
-0x60, 0x1F, 0x90, 0x05, 0x73, 0xE0, 0xFF, 0xEE,
-0x6F, 0x60, 0x16, 0x71, 0x4E, 0x54, 0x3F, 0x30,
-0xE0, 0x0F, 0xEF, 0x54, 0xBF, 0x12, 0xAF, 0x67,
-0x12, 0x7B, 0xBF, 0x12, 0xAF, 0x98, 0x12, 0xAF,
-0x7A, 0x91, 0x57, 0x90, 0x85, 0xBC, 0xE0, 0xC3,
-0x13, 0x20, 0xE0, 0x02, 0x91, 0x57, 0x22, 0x90,
-0x85, 0xC2, 0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90,
-0x85, 0xCB, 0xE0, 0xFF, 0xA3, 0xE0, 0x22, 0xE4,
-0xFF, 0x12, 0x77, 0x39, 0xEF, 0x64, 0x01, 0x22,
-0x90, 0x85, 0xC3, 0xE0, 0xFF, 0xC4, 0x54, 0x0F,
-0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C, 0x41,
-0x90, 0x01, 0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C,
-0x74, 0x02, 0x22, 0x90, 0x01, 0x57, 0xE0, 0x60,
-0x1C, 0x91, 0x83, 0xF0, 0x90, 0x85, 0xC1, 0x91,
-0xB9, 0x30, 0xE0, 0x03, 0xEF, 0x80, 0x0F, 0x91,
-0xC0, 0x40, 0x0A, 0xE4, 0xFF, 0x12, 0x77, 0x39,
-0xBF, 0x01, 0x02, 0x71, 0x46, 0x22, 0x54, 0xFB,
-0xF0, 0x90, 0x85, 0xC9, 0xE0, 0x54, 0xFD, 0xF0,
-0x22, 0xE0, 0xFF, 0x13, 0x13, 0x54, 0x3F, 0x22,
-0x90, 0x85, 0xCE, 0xE0, 0x04, 0xF0, 0x90, 0x85,
-0xC9, 0xE0, 0x54, 0xEF, 0xF0, 0x90, 0x86, 0x6D,
-0xE0, 0xFF, 0x90, 0x85, 0xCE, 0xE0, 0xD3, 0x9F,
-0x22, 0x90, 0x92, 0x09, 0xE0, 0x30, 0xE0, 0x1F,
-0xA3, 0xE0, 0xC3, 0x13, 0x54, 0x07, 0xB1, 0x00,
-0xE0, 0xFE, 0x30, 0xE0, 0x12, 0xEF, 0xB1, 0x01,
-0xEE, 0x54, 0xFE, 0x12, 0x97, 0xED, 0x12, 0x94,
-0x0E, 0xFD, 0x7F, 0x02, 0x12, 0x92, 0xF6, 0x22,
-0xFF, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x15, 0xF5,
-0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0x22, 0x12,
-0xCD, 0x2D, 0x90, 0x94, 0x6F, 0xEF, 0xF0, 0x30,
-0xE0, 0x05, 0x7D, 0x01, 0xE4, 0x80, 0x02, 0xE4,
-0xFD, 0xFF, 0x12, 0x57, 0x82, 0x90, 0x94, 0x6F,
-0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01, 0x2F, 0xE0,
-0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80, 0x06, 0x90,
-0x01, 0x2F, 0x74, 0x80, 0xF0, 0xF1, 0x7D, 0x02,
-0x51, 0x7D, 0x90, 0x85, 0xBC, 0xE0, 0xFF, 0x30,
-0xE0, 0x3F, 0x90, 0x85, 0xC0, 0xE0, 0x7E, 0x00,
-0xB4, 0x02, 0x02, 0x7E, 0x01, 0x90, 0x85, 0xBF,
-0xE0, 0x7D, 0x00, 0xB4, 0x04, 0x02, 0x7D, 0x01,
-0xED, 0x4E, 0x70, 0x25, 0xEF, 0xC3, 0x13, 0x30,
-0xE0, 0x03, 0x02, 0xAE, 0xAE, 0x91, 0x8B, 0x90,
-0x85, 0xC0, 0xE0, 0xB4, 0x0C, 0x06, 0xE4, 0xFD,
-0x7F, 0x08, 0x80, 0x0A, 0x90, 0x85, 0xC0, 0xE0,
-0xB4, 0x04, 0x06, 0xE4, 0xFD, 0xFF, 0x12, 0xA3,
-0x0C, 0x22, 0xE4, 0x90, 0x94, 0x6F, 0xF0, 0x90,
-0x85, 0xC5, 0xE0, 0x60, 0x53, 0x91, 0x67, 0x70,
-0x4F, 0xB1, 0xE9, 0xF0, 0xF1, 0xC0, 0x90, 0x94,
-0x6F, 0x74, 0x01, 0xF0, 0xE4, 0x90, 0x85, 0xCC,
-0xF0, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x16,
-0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x02, 0x05, 0xE4,
-0x90, 0x94, 0x6F, 0xF0, 0x12, 0xA6, 0x8D, 0xEF,
-0x70, 0x04, 0x90, 0x94, 0x6F, 0xF0, 0x90, 0x94,
-0x6F, 0xE0, 0x60, 0x1C, 0x90, 0x85, 0xC8, 0xE0,
-0x20, 0xE2, 0x03, 0x12, 0xA3, 0x08, 0x90, 0x85,
-0xC9, 0xE0, 0x44, 0x10, 0x12, 0xAF, 0x91, 0x90,
-0x85, 0xCD, 0xE0, 0x90, 0x91, 0x6F, 0xD1, 0x20,
-0x22, 0x90, 0x85, 0xCB, 0xE0, 0x90, 0x05, 0x73,
-0x22, 0x90, 0x92, 0x0A, 0xE0, 0xC3, 0x13, 0x54,
-0x07, 0xFF, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x17,
-0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0,
-0xFE, 0xEF, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x16,
-0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0,
-0x90, 0x91, 0x6F, 0xF0, 0x90, 0x91, 0x6E, 0xEE,
-0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54, 0x7E, 0x01,
-0x02, 0x61, 0x41, 0x90, 0x06, 0xA9, 0xE0, 0x90,
-0x94, 0x51, 0xF0, 0xE0, 0xFD, 0x54, 0xC0, 0x70,
-0x05, 0x12, 0xB7, 0x69, 0x80, 0x5A, 0xED, 0x30,
-0xE6, 0x41, 0x90, 0x85, 0xC5, 0xE0, 0x64, 0x02,
-0x70, 0x28, 0x90, 0x85, 0xC1, 0xE0, 0xFF, 0xC3,
-0x13, 0x20, 0xE0, 0x09, 0x90, 0x85, 0xC9, 0xE0,
-0x44, 0x01, 0xF0, 0x80, 0x1C, 0x12, 0xB7, 0xDC,
-0x64, 0x01, 0x70, 0x22, 0x90, 0x85, 0xC9, 0xE0,
-0x44, 0x04, 0xF0, 0x7F, 0x01, 0x12, 0x62, 0x8E,
-0x80, 0x14, 0x12, 0xB7, 0xD5, 0x64, 0x02, 0x60,
-0x05, 0x12, 0x77, 0x61, 0x80, 0x08, 0x12, 0x79,
-0x41, 0x80, 0x03, 0x12, 0xB7, 0x69, 0x90, 0x94,
-0x51, 0xE0, 0x90, 0x85, 0xC9, 0x30, 0xE7, 0x07,
-0x12, 0xB7, 0xE8, 0xD1, 0x20, 0x80, 0x06, 0xE0,
-0x54, 0xFD, 0xF0, 0x22, 0x22, 0x90, 0x85, 0xC1,
-0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90, 0x85, 0xC1,
-0xE0, 0x54, 0xF7, 0xF0, 0x22, 0x90, 0x85, 0xD1,
-0xA3, 0xE0, 0x90, 0x05, 0x58, 0xF0, 0x22, 0xAC,
-0x07, 0x90, 0x92, 0xC9, 0xE0, 0xF9, 0x30, 0xE0,
-0x02, 0xE1, 0x6B, 0x90, 0x85, 0xC1, 0xE0, 0x30,
-0xE0, 0x16, 0x90, 0x85, 0xFB, 0xE0, 0x24, 0x04,
-0x90, 0x85, 0xDA, 0xF0, 0x90, 0x85, 0xFB, 0xE0,
-0x24, 0x03, 0x90, 0x85, 0xD9, 0xF0, 0x80, 0x0D,
-0x90, 0x85, 0xDA, 0x74, 0x02, 0xF0, 0x90, 0x85,
-0xD9, 0x14, 0xF0, 0x0B, 0x0B, 0x90, 0x85, 0xD9,
-0xE0, 0xFA, 0x90, 0x85, 0xD8, 0xE0, 0xD3, 0x9A,
-0x50, 0x0E, 0x90, 0x85, 0xCD, 0xEB, 0xF0, 0x90,
-0x85, 0xDA, 0xE0, 0xC3, 0x9D, 0x2C, 0x80, 0x11,
-0xC3, 0xED, 0x9A, 0x2B, 0x90, 0x85, 0xCD, 0xF0,
-0x90, 0x85, 0xD9, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3,
-0x9F, 0x90, 0x85, 0xDD, 0xF0, 0x90, 0x85, 0xDA,
-0xE0, 0xFF, 0x24, 0x0A, 0xFD, 0xE4, 0x33, 0xFC,
-0x90, 0x85, 0xDD, 0xF1, 0x73, 0x98, 0x40, 0x04,
-0xEF, 0x24, 0x0A, 0xF0, 0x90, 0x85, 0xDD, 0xE0,
-0xFF, 0x24, 0x23, 0xFD, 0xE4, 0x33, 0xFC, 0x90,
-0x85, 0xCD, 0xF1, 0x73, 0x98, 0x40, 0x04, 0xEF,
-0x24, 0x23, 0xF0, 0x90, 0x85, 0xDD, 0xE0, 0xFF,
-0x7E, 0x00, 0x90, 0x85, 0xD1, 0xEE, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x05, 0x58, 0xE0, 0x6F, 0x70,
-0x01, 0xE4, 0x60, 0x02, 0xD1, 0xAD, 0xE9, 0x54,
-0xFD, 0x80, 0x03, 0xE9, 0x44, 0x02, 0x90, 0x92,
-0xC9, 0xF0, 0x22, 0xE0, 0xD3, 0x9D, 0xEC, 0x64,
-0x80, 0xF8, 0x74, 0x80, 0x22, 0x90, 0x85, 0xD7,
-0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x85, 0xDE,
-0xE0, 0xFB, 0x22, 0x90, 0x92, 0x0A, 0xE0, 0x30,
-0xE0, 0x0B, 0x90, 0x92, 0xB4, 0xE0, 0x60, 0x05,
-0x7F, 0x07, 0x12, 0xAA, 0xF7, 0x22, 0x90, 0x85,
-0xBC, 0xE0, 0xFF, 0x30, 0xE0, 0x05, 0x12, 0xA7,
-0x6C, 0x60, 0x14, 0x90, 0x85, 0xC5, 0xE0, 0x70,
-0x04, 0xEF, 0x30, 0xE0, 0x0A, 0x90, 0x85, 0xC8,
-0xE0, 0x64, 0x02, 0x60, 0x02, 0x71, 0x56, 0x22,
-0x90, 0x05, 0x63, 0xE0, 0x90, 0x92, 0xD2, 0xF0,
-0x90, 0x05, 0x62, 0xE0, 0x90, 0x92, 0xD3, 0xF0,
-0x90, 0x05, 0x61, 0xE0, 0x90, 0x92, 0xD4, 0xF0,
-0x90, 0x05, 0x60, 0xE0, 0x90, 0x92, 0xD5, 0xF0,
-0x90, 0x92, 0xC9, 0xE0, 0x44, 0x01, 0xF0, 0x22,
-0x90, 0x84, 0xA1, 0x74, 0x02, 0xF0, 0xA3, 0x74,
-0x9A, 0xF0, 0xA3, 0x74, 0x26, 0xF0, 0x90, 0x84,
-0xA7, 0x74, 0x80, 0xF0, 0xA3, 0x74, 0x03, 0xF0,
-0x22, 0xE4, 0xFB, 0xFA, 0xFD, 0x7F, 0x01, 0x12,
-0x86, 0x4E, 0x90, 0x94, 0x3F, 0xEF, 0xF0, 0x60,
-0xF0, 0x90, 0x84, 0xC1, 0xE0, 0xFF, 0x70, 0x04,
-0xA3, 0xE0, 0x60, 0xE5, 0xC2, 0xAF, 0xEF, 0x30,
-0xE0, 0x0F, 0x90, 0x84, 0xC1, 0xE0, 0x54, 0xFE,
-0xF0, 0xE4, 0xFF, 0x12, 0x2D, 0xBD, 0x12, 0x9B,
-0x57, 0x11, 0x4B, 0x30, 0xE1, 0x06, 0x54, 0xFD,
-0xF0, 0x12, 0x60, 0x5D, 0x11, 0x4B, 0x30, 0xE2,
-0x06, 0x54, 0xFB, 0xF0, 0x12, 0x6A, 0x6D, 0xD2,
-0xAF, 0x80, 0xC6, 0xD2, 0xAF, 0xC2, 0xAF, 0x90,
-0x84, 0xC1, 0xE0, 0xFF, 0x22, 0x32, 0xC0, 0xE0,
-0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0,
-0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0,
-0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x56,
-0xF0, 0x74, 0xC8, 0xA3, 0xF0, 0x12, 0x6C, 0xBC,
-0x74, 0x56, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74,
-0xC8, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0,
-0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0,
-0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x32, 0xC0,
-0xE0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
-0xD0, 0x00, 0xC0, 0x05, 0xC0, 0x07, 0x7D, 0xA7,
-0x90, 0x01, 0xC4, 0xED, 0xF0, 0x74, 0xC8, 0xFF,
-0xA3, 0xF0, 0xED, 0x04, 0x90, 0x01, 0xC4, 0xF0,
-0xA3, 0xEF, 0xF0, 0xD0, 0x07, 0xD0, 0x05, 0xD0,
-0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xE0, 0x32,
-0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x05, 0xE4,
-0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x85, 0xBC,
-0xE0, 0xFF, 0x30, 0xE0, 0x3F, 0x90, 0x85, 0xC0,
-0xE0, 0x7E, 0x00, 0xB4, 0x02, 0x02, 0x7E, 0x01,
-0x90, 0x85, 0xBF, 0xE0, 0x7D, 0x00, 0xB4, 0x04,
-0x02, 0x7D, 0x01, 0xED, 0x4E, 0x70, 0x25, 0xEF,
-0xC3, 0x13, 0x30, 0xE0, 0x03, 0x02, 0xAE, 0xAE,
-0x12, 0xA7, 0x56, 0x90, 0x85, 0xC0, 0xE0, 0xB4,
-0x08, 0x06, 0xE4, 0xFD, 0x7F, 0x0C, 0x80, 0x09,
-0x90, 0x85, 0xC0, 0xE0, 0x70, 0x06, 0xFD, 0x7F,
-0x04, 0x12, 0xA3, 0x0C, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x96, 0xEE, 0x7F,
-0x02, 0x12, 0x7B, 0x51, 0xEF, 0x54, 0xFE, 0xFD,
-0x7F, 0x02, 0x12, 0x7B, 0x3E, 0x90, 0x01, 0x00,
-0x74, 0x3F, 0xF0, 0xA3, 0xE0, 0x54, 0xFD, 0xF0,
-0x90, 0x05, 0x53, 0xE0, 0x44, 0x20, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x41, 0x77, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x85, 0xBF,
-0xE0, 0x90, 0x95, 0x1A, 0xF0, 0x6F, 0x70, 0x02,
-0x41, 0x6B, 0xEF, 0x14, 0x60, 0x46, 0x14, 0x60,
-0x72, 0x14, 0x70, 0x02, 0x41, 0x16, 0x14, 0x70,
-0x02, 0x41, 0x41, 0x24, 0x04, 0x60, 0x02, 0x41,
-0x6B, 0x90, 0x95, 0x1A, 0xE0, 0xB4, 0x04, 0x05,
-0x12, 0xBF, 0xCC, 0x41, 0x6B, 0x90, 0x95, 0x1A,
-0xE0, 0xB4, 0x02, 0x05, 0x12, 0xBF, 0xBD, 0x41,
-0x6B, 0x90, 0x95, 0x1A, 0xE0, 0xB4, 0x03, 0x05,
-0x12, 0xBF, 0xE0, 0x41, 0x6B, 0x90, 0x95, 0x1A,
-0xE0, 0x64, 0x01, 0x60, 0x02, 0x41, 0x6B, 0x12,
-0xBF, 0xBF, 0x41, 0x6B, 0x90, 0x95, 0x1A, 0xE0,
-0xB4, 0x04, 0x05, 0x12, 0xBF, 0xD0, 0x41, 0x6B,
-0x90, 0x95, 0x1A, 0xE0, 0xB4, 0x02, 0x05, 0x12,
-0xBF, 0xB4, 0x41, 0x6B, 0x90, 0x95, 0x1A, 0xE0,
-0xB4, 0x03, 0x04, 0x51, 0xA2, 0x41, 0x6B, 0x90,
-0x95, 0x1A, 0xE0, 0x60, 0x02, 0x41, 0x6B, 0x51,
-0x8F, 0x41, 0x6B, 0x90, 0x95, 0x1A, 0xE0, 0xB4,
-0x04, 0x04, 0x51, 0x80, 0x80, 0x75, 0x90, 0x95,
-0x1A, 0xE0, 0xB4, 0x01, 0x04, 0x51, 0x70, 0x80,
-0x6A, 0x90, 0x95, 0x1A, 0xE0, 0xB4, 0x03, 0x04,
-0x31, 0x5C, 0x80, 0x5F, 0x90, 0x95, 0x1A, 0xE0,
-0x70, 0x59, 0x51, 0x86, 0x80, 0x55, 0x90, 0x95,
-0x1A, 0xE0, 0xB4, 0x04, 0x04, 0x51, 0xB2, 0x80,
-0x4A, 0x90, 0x95, 0x1A, 0xE0, 0xB4, 0x01, 0x04,
-0x51, 0x98, 0x80, 0x3F, 0x90, 0x95, 0x1A, 0xE0,
-0xB4, 0x02, 0x04, 0x51, 0xD7, 0x80, 0x34, 0x90,
-0x95, 0x1A, 0xE0, 0x70, 0x2E, 0x51, 0x96, 0x80,
-0x2A, 0x90, 0x95, 0x1A, 0xE0, 0xB4, 0x03, 0x04,
-0x51, 0xCA, 0x80, 0x1F, 0x90, 0x95, 0x1A, 0xE0,
-0xB4, 0x01, 0x05, 0x12, 0x9F, 0xE4, 0x80, 0x13,
-0x90, 0x95, 0x1A, 0xE0, 0xB4, 0x02, 0x04, 0x51,
-0xCF, 0x80, 0x08, 0x90, 0x95, 0x1A, 0xE0, 0x70,
-0x02, 0x51, 0x8A, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x7D, 0x20, 0x7F, 0xFF, 0x12, 0x98, 0xE3, 0x31,
-0x2D, 0x90, 0x85, 0xBF, 0x74, 0x02, 0xF0, 0x22,
-0x51, 0xC2, 0x7D, 0x23, 0x80, 0xEC, 0x51, 0x8F,
-0x80, 0xE6, 0x51, 0x8F, 0x02, 0x9F, 0xE4, 0x90,
-0x85, 0xBF, 0x74, 0x01, 0xF0, 0x22, 0x51, 0x8F,
-0x7D, 0x21, 0x7F, 0xFF, 0x51, 0xAB, 0x74, 0x03,
-0xF0, 0x22, 0x51, 0xA8, 0x74, 0x01, 0xF0, 0x22,
-0xE4, 0xFD, 0xFF, 0x12, 0x98, 0xE3, 0x90, 0x85,
-0xBF, 0x22, 0x7D, 0x22, 0x7F, 0xFF, 0x12, 0x98,
-0xE3, 0x51, 0xC2, 0x90, 0x85, 0xBF, 0x74, 0x03,
-0xF0, 0x22, 0x90, 0x05, 0x27, 0xE0, 0x44, 0x40,
-0xF0, 0x22, 0x7D, 0x25, 0x02, 0x9F, 0xE6, 0x12,
-0xBF, 0x8B, 0x7D, 0x24, 0x02, 0x9F, 0xE6, 0x12,
-0xBF, 0x8B, 0x90, 0x85, 0xBF, 0x74, 0x03, 0xF0,
-0x22, 0x12, 0x02, 0xF6, 0x90, 0x94, 0x97, 0xF0,
-0x22, 0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00, 0x90,
-0x89, 0x1B, 0x12, 0x87, 0x4E, 0x7B, 0xFF, 0x7A,
-0x82, 0x79, 0x00, 0x90, 0x89, 0x1E, 0x12, 0x87,
-0x4E, 0x7A, 0x82, 0x79, 0x3F, 0x90, 0x89, 0x21,
-0x12, 0x87, 0x4E, 0x7A, 0x82, 0x79, 0xE1, 0x90,
-0x89, 0x27, 0x12, 0x87, 0x4E, 0x7A, 0x82, 0x79,
-0xF5, 0x90, 0x89, 0x2A, 0x12, 0x87, 0x4E, 0x7A,
-0x83, 0x79, 0x1D, 0x90, 0x89, 0x2D, 0x12, 0x87,
-0x4E, 0x7A, 0x83, 0x79, 0x31, 0x90, 0x89, 0x33,
-0x12, 0x87, 0x4E, 0x7A, 0x83, 0x79, 0x59, 0x90,
-0x89, 0x36, 0x12, 0x87, 0x4E, 0x7A, 0x83, 0x79,
-0x81, 0x90, 0x89, 0x39, 0x12, 0x87, 0x4E, 0xE4,
-0x90, 0x94, 0xA8, 0xF0, 0x90, 0x94, 0x97, 0xF0,
-0x90, 0x93, 0xFB, 0xF0, 0x90, 0x93, 0xFB, 0xE0,
-0xFF, 0xC3, 0x94, 0x05, 0x50, 0x10, 0x74, 0xB9,
-0x2F, 0x12, 0x9E, 0x49, 0xE4, 0xF0, 0x90, 0x93,
-0xFB, 0xE0, 0x04, 0xF0, 0x80, 0xE6, 0x22, 0x90,
-0x94, 0x46, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xA3,
-0xED, 0xF0, 0xEB, 0x75, 0xF0, 0x06, 0xA4, 0xFF,
-0x90, 0x89, 0x21, 0x12, 0x87, 0x45, 0xE9, 0x2F,
-0xF9, 0xEA, 0x35, 0xF0, 0xFA, 0x90, 0x94, 0x4E,
-0x12, 0x87, 0x4E, 0x90, 0x94, 0x48, 0xE0, 0x12,
-0x9F, 0x5F, 0xE0, 0xFF, 0xA3, 0xE0, 0x90, 0x94,
-0x4B, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0xA3,
-0xF0, 0x90, 0x94, 0x4E, 0x12, 0x87, 0x45, 0x90,
-0x94, 0x4D, 0xE0, 0xFF, 0xF5, 0x82, 0x75, 0x83,
-0x00, 0x12, 0x03, 0x0F, 0xFD, 0x7C, 0x00, 0x90,
-0x94, 0x48, 0xE0, 0x75, 0xF0, 0x12, 0x90, 0x89,
-0x44, 0x12, 0x05, 0x28, 0x75, 0xF0, 0x02, 0xEF,
-0x12, 0x05, 0x28, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x90, 0x94, 0x4A, 0xE0, 0xFB, 0xEF, 0xA8, 0x03,
-0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
-0xD8, 0xF9, 0x91, 0x56, 0xEE, 0x8F, 0xF0, 0x12,
-0x07, 0x0A, 0x90, 0x94, 0x4D, 0xE0, 0x04, 0xF0,
-0xE0, 0xB4, 0x05, 0xAD, 0x90, 0x94, 0x4E, 0x12,
-0x87, 0x45, 0x12, 0x97, 0xF6, 0xFD, 0x7C, 0x00,
-0x90, 0x94, 0x4A, 0xE0, 0xFF, 0x90, 0x94, 0x46,
-0xE0, 0xFE, 0xA3, 0xE0, 0xA8, 0x07, 0x08, 0x80,
-0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9,
-0x91, 0x56, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xD3,
-0x9F, 0xEC, 0x9E, 0x40, 0x08, 0xED, 0x9F, 0xFF,
-0xEC, 0x9E, 0xFE, 0x80, 0x04, 0x7E, 0x00, 0x7F,
-0x00, 0x90, 0x94, 0x4B, 0xEE, 0xF0, 0xA3, 0xEF,
-0xF0, 0x90, 0x94, 0x4B, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x90, 0x94, 0x48, 0xE0, 0x12, 0x9F, 0x5F,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xFF, 0x12,
-0x03, 0x70, 0x90, 0x94, 0x4B, 0x22, 0x12, 0x97,
-0x5A, 0xE0, 0x20, 0xE0, 0x08, 0xC3, 0x13, 0x30,
-0xE0, 0x0A, 0x02, 0x97, 0xEE, 0x12, 0x97, 0x5A,
-0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90, 0x01, 0x94,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x01, 0xC7, 0xE4,
-0xF0, 0x22, 0x90, 0x01, 0x9A, 0xE0, 0x54, 0xC0,
-0x44, 0x0B, 0xF0, 0x7F, 0x0A, 0x7E, 0x00, 0x12,
-0x7C, 0x9F, 0x90, 0x01, 0x98, 0xE0, 0x54, 0xC0,
-0x7F, 0x00, 0xB4, 0x40, 0x02, 0x7F, 0x01, 0x22,
-0x90, 0x01, 0x98, 0xE4, 0xF0, 0xA3, 0xF0, 0xA3,
-0x74, 0x11, 0xF0, 0xA3, 0xE4, 0xF0, 0x7F, 0x0A,
-0xFE, 0x12, 0x7C, 0x9F, 0x90, 0x01, 0x99, 0xE0,
-0x54, 0x30, 0xFF, 0x64, 0x10, 0x60, 0x04, 0xEF,
-0xB4, 0x20, 0x03, 0x7F, 0x01, 0x22, 0x7F, 0x00,
-0x22, 0x90, 0x01, 0xCF, 0xE0, 0x90, 0x94, 0x51,
-0xF0, 0xE0, 0xFF, 0x30, 0xE0, 0x07, 0x90, 0x01,
-0xCF, 0xE0, 0x54, 0xFE, 0xF0, 0xEF, 0x30, 0xE5,
-0x23, 0x90, 0x01, 0xCF, 0xE0, 0x54, 0xDF, 0xF0,
-0x90, 0x01, 0x34, 0x74, 0x20, 0xF0, 0xE4, 0xF5,
-0xA8, 0xF5, 0xE8, 0x12, 0x75, 0xB6, 0x90, 0x00,
-0x03, 0xE0, 0x54, 0xFB, 0xFD, 0x7F, 0x03, 0x12,
-0x7B, 0x3E, 0x80, 0xFE, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0xFE, 0xFD, 0xEF,
-0xB4, 0x01, 0x0D, 0xEB, 0xB4, 0x02, 0x03, 0x0D,
-0x80, 0x06, 0xEB, 0xB4, 0x01, 0x02, 0x7D, 0x02,
-0xAF, 0x06, 0xEF, 0xC4, 0x54, 0xF0, 0x4D, 0xFF,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4, 0x90, 0x94,
-0x71, 0xF0, 0xA3, 0xF0, 0x7F, 0x83, 0x12, 0x7B,
-0x51, 0x90, 0x94, 0x70, 0xEF, 0xF0, 0x7F, 0x83,
-0x12, 0x7B, 0x51, 0xAE, 0x07, 0x90, 0x94, 0x70,
-0xE0, 0xFF, 0xB5, 0x06, 0x01, 0x22, 0xC3, 0x90,
-0x94, 0x72, 0xE0, 0x94, 0x64, 0x90, 0x94, 0x71,
-0xE0, 0x94, 0x00, 0x40, 0x0D, 0x90, 0x01, 0xC0,
-0xE0, 0x44, 0x40, 0xF0, 0x90, 0x94, 0x70, 0xE0,
-0xFF, 0x22, 0x90, 0x94, 0x71, 0x12, 0xBD, 0xFF,
-0x80, 0xC2, 0x90, 0x01, 0xC4, 0x74, 0x72, 0xF0,
-0x74, 0xCD, 0xA3, 0xF0, 0x7F, 0x90, 0x12, 0x7B,
-0x51, 0xEF, 0x20, 0xE0, 0xF7, 0x74, 0x72, 0x04,
-0x90, 0x01, 0xC4, 0xF0, 0x74, 0xCD, 0xA3, 0xF0,
-0x22, 0x7E, 0x00, 0x7F, 0x01, 0x7D, 0x00, 0x7B,
-0x01, 0x7A, 0x85, 0x79, 0xBC, 0x12, 0x06, 0xDE,
-0x90, 0x85, 0xBC, 0xE0, 0x54, 0xFD, 0xF0, 0xE4,
-0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0x74,
-0x0C, 0xF0, 0x22, 0x90, 0x85, 0xBF, 0xE0, 0x64,
-0x02, 0x7F, 0x01, 0x60, 0x02, 0x7F, 0x00, 0x22,
-0x90, 0x95, 0x0E, 0x12, 0x87, 0x4E, 0x12, 0x71,
-0x54, 0x90, 0x85, 0xC5, 0xE0, 0xFF, 0x12, 0x60,
-0xD0, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x19, 0x90,
-0x95, 0x0E, 0x12, 0x87, 0x45, 0x12, 0x8F, 0x73,
-0x54, 0x0F, 0xFF, 0x12, 0x8F, 0xF3, 0xFD, 0x12,
-0x6A, 0xB8, 0x12, 0xC7, 0x7D, 0x12, 0x51, 0x7D,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x12, 0x7A, 0x29, 0xEF, 0x64, 0x01, 0x60, 0x05,
-0x75, 0x10, 0x01, 0x80, 0x71, 0x90, 0x85, 0xC9,
-0xE0, 0xFF, 0x54, 0x03, 0x60, 0x05, 0x75, 0x10,
-0x02, 0x80, 0x63, 0x90, 0x85, 0xC7, 0xE0, 0xFE,
-0xE4, 0xC3, 0x9E, 0x50, 0x05, 0x75, 0x10, 0x04,
-0x80, 0x54, 0xEF, 0x30, 0xE2, 0x05, 0x75, 0x10,
-0x08, 0x80, 0x4B, 0x90, 0x85, 0xC9, 0xE0, 0x30,
-0xE4, 0x05, 0x75, 0x10, 0x10, 0x80, 0x3F, 0x90,
-0x85, 0xC2, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x20,
-0xE0, 0x05, 0x75, 0x10, 0x20, 0x80, 0x2F, 0x90,
-0x86, 0x71, 0xE0, 0x60, 0x05, 0x75, 0x10, 0x80,
-0x80, 0x24, 0x90, 0x06, 0x62, 0xE0, 0x30, 0xE1,
-0x05, 0x75, 0x10, 0x11, 0x80, 0x18, 0x90, 0x06,
-0x62, 0xE0, 0x30, 0xE0, 0x0C, 0xE0, 0x54, 0xFC,
-0xFF, 0xBF, 0x80, 0x05, 0x75, 0x10, 0x12, 0x80,
-0x05, 0x12, 0xBF, 0x73, 0x80, 0x0E, 0x90, 0x01,
-0xB9, 0x74, 0x04, 0xF0, 0x90, 0x01, 0xB8, 0xE5,
-0x10, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x90, 0x93, 0x03, 0x74, 0x04, 0xF0, 0x14,
-0xF0, 0xA3, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74,
-0x64, 0xF0, 0xA3, 0x74, 0x05, 0xF0, 0xA3, 0xF0,
-0x22, 0xE4, 0x90, 0x94, 0x51, 0xF0, 0xA3, 0xF0,
-0xA3, 0xF0, 0x90, 0x92, 0xD2, 0x12, 0x87, 0x2D,
-0x90, 0x92, 0xCE, 0x12, 0x87, 0x39, 0xC3, 0x12,
-0x04, 0xB4, 0x40, 0x49, 0x90, 0x85, 0xC1, 0xE0,
-0x90, 0x92, 0xD2, 0x30, 0xE0, 0x10, 0x12, 0xD0,
-0xC8, 0x90, 0x85, 0xFB, 0xE0, 0x24, 0x04, 0x2F,
-0xFF, 0x90, 0x93, 0x03, 0x80, 0x06, 0x12, 0xD0,
-0xC8, 0x90, 0x93, 0x04, 0xE0, 0xFE, 0xC3, 0xEF,
-0x9E, 0x90, 0x94, 0x52, 0xF0, 0x90, 0x94, 0x52,
-0xE0, 0xFF, 0xC3, 0x94, 0x2D, 0x50, 0x16, 0x74,
-0xD6, 0x2F, 0x12, 0xD0, 0x44, 0xE0, 0x04, 0xF0,
-0x90, 0x85, 0xDB, 0xE0, 0x04, 0xF0, 0xE0, 0xFD,
-0x7F, 0xFE, 0x12, 0x7B, 0x3E, 0x90, 0x85, 0xDB,
-0xE0, 0xFF, 0xD3, 0x90, 0x93, 0x06, 0xE0, 0x9F,
-0x90, 0x93, 0x05, 0xE0, 0x94, 0x00, 0x40, 0x02,
-0xE1, 0xE7, 0x12, 0xD1, 0x93, 0x12, 0xD1, 0xA7,
-0x50, 0x1E, 0x12, 0xD0, 0xE5, 0xFF, 0x90, 0x94,
-0x53, 0xE0, 0xD3, 0x9F, 0x40, 0x0A, 0x90, 0x94,
-0x51, 0xE0, 0x90, 0x94, 0x54, 0xF0, 0x80, 0x08,
-0x90, 0x94, 0x51, 0xE0, 0x04, 0xF0, 0x80, 0xDD,
-0x12, 0xD1, 0x93, 0x12, 0xD1, 0xA7, 0x50, 0x2E,
-0x12, 0xD0, 0xE5, 0xFF, 0xC3, 0x90, 0x93, 0x06,
-0xE0, 0x9F, 0xFF, 0x90, 0x93, 0x05, 0xE0, 0x94,
-0x00, 0xFE, 0x90, 0x94, 0x53, 0xE0, 0xD3, 0x9F,
-0xE4, 0x9E, 0x40, 0x0A, 0x90, 0x94, 0x51, 0xE0,
-0x90, 0x94, 0x55, 0xF0, 0x80, 0x08, 0x90, 0x94,
-0x51, 0xE0, 0x04, 0xF0, 0x80, 0xCD, 0x90, 0x94,
-0x54, 0xE0, 0x90, 0x85, 0xE0, 0xF0, 0x90, 0x94,
-0x55, 0xE0, 0x90, 0x85, 0xE1, 0x12, 0xD1, 0xC2,
-0x94, 0x0A, 0x40, 0x0A, 0xEF, 0x24, 0xF6, 0x90,
-0x85, 0xD8, 0xF0, 0xE4, 0x80, 0x0A, 0xE4, 0x90,
-0x85, 0xD8, 0x12, 0xD1, 0xC2, 0x74, 0x0A, 0x9F,
-0x90, 0x85, 0xD7, 0xF0, 0x90, 0x85, 0xE0, 0xE0,
-0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x85, 0xDE,
-0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x05,
-0x90, 0x93, 0x03, 0x80, 0x03, 0x90, 0x93, 0x04,
-0xE0, 0xFF, 0x90, 0x85, 0xDE, 0xE0, 0x2F, 0x04,
-0xF0, 0x90, 0x85, 0xDE, 0xE0, 0xC3, 0x94, 0x0A,
-0x50, 0x03, 0x74, 0x0A, 0xF0, 0x90, 0x85, 0xDE,
-0xE0, 0x24, 0x02, 0xF0, 0x12, 0xC7, 0x7D, 0x12,
-0x51, 0x7D, 0xE4, 0xFF, 0x12, 0x69, 0x33, 0x22,
-0x12, 0xC4, 0xCD, 0x40, 0x2F, 0x90, 0x85, 0xDF,
-0xE0, 0x04, 0xF0, 0x90, 0x93, 0x08, 0xE0, 0xFF,
-0x90, 0x85, 0xDF, 0xE0, 0xD3, 0x9F, 0x50, 0x1C,
-0x90, 0x85, 0xD7, 0xE0, 0x04, 0xF0, 0x12, 0xA7,
-0x19, 0x12, 0xA7, 0x12, 0x90, 0x85, 0xDE, 0xF0,
-0xFB, 0x90, 0x85, 0xD7, 0xE0, 0xFF, 0xA3, 0xE0,
-0xFD, 0x12, 0x51, 0x7D, 0x22, 0xE4, 0xFE, 0x74,
-0xD6, 0x2E, 0x11, 0x44, 0xE4, 0xF0, 0x0E, 0xEE,
-0xB4, 0x2D, 0xF4, 0xE4, 0x90, 0x85, 0xDC, 0xF0,
-0x90, 0x85, 0xDB, 0xF0, 0x90, 0x85, 0xDF, 0xF0,
-0xEF, 0xB4, 0x01, 0x07, 0xA3, 0x74, 0x2D, 0xF0,
-0xE4, 0xA3, 0xF0, 0x22, 0xF5, 0x82, 0xE4, 0x34,
-0x92, 0xF5, 0x83, 0x22, 0x75, 0xF0, 0x1B, 0xA4,
-0x24, 0x38, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5,
-0x83, 0xE0, 0xFE, 0x54, 0x03, 0xFD, 0xEE, 0x13,
-0x13, 0x54, 0x07, 0xFB, 0x90, 0x92, 0x0A, 0xE0,
-0xFE, 0xC4, 0x54, 0x0F, 0x90, 0x95, 0x04, 0xF0,
-0x22, 0x90, 0x94, 0xF2, 0xA3, 0xE0, 0xFF, 0x90,
-0x95, 0x00, 0x74, 0x03, 0xF0, 0x7B, 0x06, 0x7D,
-0x01, 0x12, 0x99, 0x36, 0x90, 0x94, 0xF6, 0xEE,
-0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x94,
-0xF5, 0xE0, 0xFF, 0x74, 0x10, 0x2D, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
-0x94, 0xF4, 0xE0, 0xFF, 0x02, 0x65, 0x61, 0x90,
-0x92, 0x0A, 0xE0, 0xFF, 0xC3, 0x13, 0xFE, 0xEF,
-0x54, 0xF1, 0xFF, 0xEE, 0x04, 0x54, 0x07, 0x25,
-0xE0, 0x4F, 0xF0, 0xA3, 0xE0, 0xFF, 0x90, 0x92,
-0x0A, 0xE0, 0xFE, 0xC3, 0x13, 0x54, 0x07, 0x22,
-0x12, 0x87, 0x39, 0x90, 0x92, 0xCE, 0x12, 0x87,
-0x2D, 0x12, 0x86, 0xB6, 0x78, 0x0A, 0x12, 0x04,
-0xC5, 0x90, 0x85, 0xDD, 0xE0, 0xFE, 0xC3, 0x74,
-0x0A, 0x9E, 0x2F, 0xFF, 0x22, 0x74, 0xD6, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0,
-0xFF, 0x90, 0x94, 0x53, 0xE0, 0x2F, 0xF0, 0x90,
-0x93, 0x07, 0xE0, 0x22, 0x90, 0x94, 0x94, 0xEE,
-0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x94,
-0x92, 0xE0, 0xFF, 0x12, 0x65, 0x61, 0x90, 0x92,
-0x0A, 0xE0, 0x22, 0x75, 0xF0, 0x0E, 0xA4, 0x24,
-0x0F, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0x22, 0x90,
-0x05, 0x84, 0xEF, 0xF0, 0x7D, 0x20, 0xE4, 0xFF,
-0x02, 0x7B, 0xFD, 0x90, 0x01, 0x34, 0x74, 0x40,
-0xF0, 0xFD, 0xE4, 0xFF, 0x12, 0x7C, 0xA9, 0x43,
-0x5E, 0x08, 0x22, 0xE0, 0x54, 0x03, 0x90, 0x91,
-0x0B, 0xF0, 0x7B, 0x01, 0xAF, 0x76, 0x02, 0x27,
-0x3D, 0xE5, 0x65, 0x25, 0xE0, 0x24, 0xF5, 0xF5,
-0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0x22, 0xE4,
-0x90, 0x91, 0x6E, 0xF0, 0xA3, 0x74, 0x03, 0x22,
-0xEF, 0xC4, 0x54, 0xF0, 0x24, 0x03, 0xF5, 0x82,
-0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0xE0, 0x90,
-0x01, 0xBA, 0xF0, 0x90, 0x85, 0xC7, 0xE0, 0x90,
-0x01, 0xBB, 0x22, 0x12, 0x05, 0x28, 0xE0, 0xFC,
-0xA3, 0xE0, 0xF5, 0x82, 0x8C, 0x83, 0x22, 0x74,
-0xBC, 0x25, 0x63, 0xF5, 0x82, 0xE4, 0x34, 0x8F,
-0xF5, 0x83, 0x22, 0xE4, 0x90, 0x94, 0x53, 0xF0,
-0x90, 0x94, 0x51, 0xF0, 0x22, 0x90, 0x94, 0xFC,
-0xE0, 0xFF, 0x90, 0x94, 0xFA, 0xE0, 0x22, 0x90,
-0x94, 0x51, 0xE0, 0xFF, 0xC3, 0x94, 0x2D, 0x22,
-0x90, 0x05, 0x22, 0xE0, 0x90, 0x94, 0x7D, 0xF0,
-0x22, 0x90, 0x00, 0x06, 0x12, 0x04, 0x18, 0x2F,
-0xFF, 0x22, 0xF0, 0x90, 0x85, 0xE0, 0xE0, 0xFF,
-0xC3, 0x22, 0x25, 0xE0, 0x25, 0xE0, 0xFE, 0xEF,
-0x4E, 0x22, 0x7D, 0x01, 0xAF, 0x63, 0x02, 0x65,
-0xC2, 0xE5, 0x65, 0x90, 0x83, 0x1D, 0x93, 0xFF,
-0x22, 0x90, 0x00, 0x04, 0x12, 0x04, 0x18, 0x2F,
-0x22, 0x90, 0x95, 0x07, 0xE0, 0xFF, 0x7D, 0x48,
-0x22, 0xFF, 0x12, 0x02, 0xF6, 0xFE, 0x54, 0x0F,
-0x22, 0x00, 0x69, 0x2A
-};
-u4Byte ArrayLength_MP_8188F_FW_NIC = 21020;
-
-
-void
-ODM_ReadFirmware_MP_8188F_FW_NIC(
-	IN   PDM_ODM_T    pDM_Odm,
-	OUT  u1Byte       *pFirmware,
-	OUT  u4Byte       *pFirmwareSize
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	*((SIZE_PTR *)pFirmware) = (SIZE_PTR)Array_MP_8188F_FW_NIC;
-#else
-	ODM_MoveMemory(pDM_Odm, pFirmware, Array_MP_8188F_FW_NIC, ArrayLength_MP_8188F_FW_NIC);
-#endif
-	*pFirmwareSize = ArrayLength_MP_8188F_FW_NIC;
-}
-
-
-u1Byte Array_MP_8188F_FW_WoWLAN[] = {
-0xF1, 0x88, 0x30, 0x00, 0x04, 0x00, 0x00, 0x00,
-0x08, 0x22, 0x17, 0x37, 0xAA, 0x59, 0x02, 0x00,
-0xBC, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x02, 0x86, 0xA9, 0x02, 0xC7, 0xDF, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC0, 0xEC, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC8, 0x31, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC7, 0xE0, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC5, 0xFB, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC8, 0x30, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x02, 0x87, 0xBC, 0x02, 0x89, 0xD6, 0x02, 0x80,
-0x86, 0x02, 0x80, 0x89, 0x02, 0xCA, 0xE8, 0x02,
-0x93, 0x74, 0x02, 0xC0, 0xCA, 0x02, 0x80, 0x95,
-0x02, 0x80, 0x98, 0x02, 0x80, 0x9B, 0x02, 0x80,
-0x9E, 0x02, 0x80, 0xA1, 0x02, 0x80, 0xA4, 0x02,
-0x80, 0xA7, 0x02, 0x80, 0xAA, 0x02, 0x80, 0xAD,
-0x02, 0x80, 0xB0, 0x02, 0x80, 0xB3, 0x02, 0x80,
-0xB6, 0x02, 0x80, 0xB9, 0x02, 0x92, 0x99, 0x02,
-0xB9, 0x23, 0x02, 0xB8, 0xA5, 0x02, 0xB8, 0x43,
-0x02, 0x90, 0xA4, 0x02, 0xB7, 0xDA, 0x02, 0x80,
-0xCE, 0x02, 0x80, 0xD1, 0x02, 0xCE, 0x1B, 0x02,
-0x80, 0xD7, 0x00, 0x00, 0x00, 0x02, 0x80, 0xDD,
-0x02, 0x80, 0xE0, 0x02, 0x80, 0xE3, 0x02, 0xA2,
-0x9D, 0x02, 0xD1, 0xD1, 0x02, 0x80, 0xEC, 0x02,
-0x80, 0xEF, 0x02, 0x80, 0xF2, 0x02, 0x80, 0xF5,
-0x02, 0x80, 0xF8, 0x02, 0x80, 0xFB, 0x02, 0xA0,
-0xE3, 0x02, 0x81, 0x01, 0x02, 0xA4, 0x0D, 0x02,
-0x81, 0x07, 0x02, 0xD5, 0x76, 0x02, 0x81, 0x0D,
-0x02, 0x81, 0x10, 0x02, 0x88, 0x1F, 0x02, 0x9D,
-0x88, 0x02, 0x81, 0x19, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x02, 0xAE, 0xE5, 0x02,
-0xAE, 0x70, 0x02, 0xA3, 0xB7, 0x02, 0xA0, 0xD8,
-0x02, 0x81, 0x40, 0x02, 0x94, 0xD5, 0x02, 0xCC,
-0xC2, 0x02, 0x81, 0x49, 0x02, 0x81, 0x4C, 0x02,
-0x81, 0x4F, 0x02, 0x81, 0x52, 0x02, 0x81, 0x55,
-0x02, 0x81, 0x58, 0x02, 0x81, 0x5B, 0x02, 0xCD,
-0x59, 0x02, 0x81, 0x61, 0x02, 0x81, 0x64, 0x02,
-0xCE, 0xED, 0x02, 0xD1, 0x8E, 0x02, 0xD1, 0x67,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0xC2, 0xAF, 0x80, 0xFE, 0x32, 0x12, 0x84, 0x04,
-0x85, 0xD0, 0x0B, 0x75, 0xD0, 0x08, 0xAA, 0xE0,
-0xC2, 0x8C, 0xE5, 0x8A, 0x24, 0x67, 0xF5, 0x8A,
-0xE5, 0x8C, 0x34, 0x79, 0xF5, 0x8C, 0xD2, 0x8C,
-0xEC, 0x24, 0x87, 0xF8, 0xE6, 0xBC, 0x02, 0x02,
-0x74, 0xFF, 0xC3, 0x95, 0x81, 0xB4, 0x40, 0x00,
-0x40, 0xCE, 0x79, 0x03, 0x78, 0x80, 0x16, 0xE6,
-0x08, 0x70, 0x0B, 0xC2, 0xAF, 0xE6, 0x30, 0xE1,
-0x03, 0x44, 0x18, 0xF6, 0xD2, 0xAF, 0x08, 0xD9,
-0xED, 0xEA, 0x8B, 0xD0, 0x22, 0xE5, 0x0C, 0xFF,
-0x23, 0x24, 0x81, 0xF8, 0x0F, 0x08, 0x08, 0xBF,
-0x03, 0x04, 0x7F, 0x00, 0x78, 0x81, 0xE6, 0x30,
-0xE4, 0xF2, 0x00, 0xE5, 0x0C, 0xC3, 0x9F, 0x50,
-0x20, 0x05, 0x0C, 0x74, 0x86, 0x25, 0x0C, 0xF8,
-0xE6, 0xFD, 0xA6, 0x81, 0x08, 0xE6, 0xAE, 0x0C,
-0xBE, 0x02, 0x02, 0x74, 0xFF, 0xCD, 0xF8, 0xE8,
-0x6D, 0x60, 0xE0, 0x08, 0xE6, 0xC0, 0xE0, 0x80,
-0xF6, 0xE5, 0x0C, 0xD3, 0x9F, 0x40, 0x27, 0xE5,
-0x0C, 0x24, 0x87, 0xF8, 0xE6, 0xAE, 0x0C, 0xBE,
-0x02, 0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xCD,
-0xF8, 0xE5, 0x81, 0x6D, 0x60, 0x06, 0xD0, 0xE0,
-0xF6, 0x18, 0x80, 0xF5, 0xE5, 0x0C, 0x24, 0x86,
-0xC8, 0xF6, 0x15, 0x0C, 0x80, 0xD3, 0xE5, 0x0C,
-0x23, 0x24, 0x81, 0xF8, 0x7F, 0x04, 0xC2, 0xAF,
-0xE6, 0x30, 0xE0, 0x03, 0x10, 0xE2, 0x0C, 0x7F,
-0x00, 0x30, 0xE1, 0x07, 0x30, 0xE3, 0x04, 0x7F,
-0x08, 0x54, 0xF4, 0x54, 0x7C, 0xC6, 0xD2, 0xAF,
-0x54, 0x80, 0x42, 0x07, 0x22, 0x78, 0x86, 0xA6,
-0x81, 0x74, 0x02, 0x60, 0x06, 0xFF, 0x08, 0x76,
-0xFF, 0xDF, 0xFB, 0x7F, 0x03, 0xE4, 0x78, 0x80,
-0xF6, 0x08, 0xF6, 0x08, 0xDF, 0xFA, 0x78, 0x81,
-0x76, 0x30, 0x90, 0x87, 0xB1, 0x74, 0x01, 0x93,
-0xC0, 0xE0, 0xE4, 0x93, 0xC0, 0xE0, 0x43, 0x89,
-0x01, 0x75, 0x8A, 0x60, 0x75, 0x8C, 0x79, 0xD2,
-0x8C, 0xD2, 0xAF, 0x22, 0x02, 0xEF, 0xD3, 0x94,
-0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0x74, 0x81,
-0x2F, 0x2F, 0xF8, 0xE6, 0x20, 0xE5, 0xF4, 0xC2,
-0xAF, 0xE6, 0x44, 0x30, 0xF6, 0xD2, 0xAF, 0xAE,
-0x0C, 0xEE, 0xC3, 0x9F, 0x50, 0x21, 0x0E, 0x74,
-0x86, 0x2E, 0xF8, 0xE6, 0xF9, 0x08, 0xE6, 0x18,
-0xBE, 0x02, 0x02, 0x74, 0xFF, 0xFD, 0xED, 0x69,
-0x60, 0x09, 0x09, 0xE7, 0x19, 0x19, 0xF7, 0x09,
-0x09, 0x80, 0xF3, 0x16, 0x16, 0x80, 0xDA, 0xEE,
-0xD3, 0x9F, 0x40, 0x04, 0x05, 0x81, 0x05, 0x81,
-0xEE, 0xD3, 0x9F, 0x40, 0x22, 0x74, 0x86, 0x2E,
-0xF8, 0x08, 0xE6, 0xF9, 0xEE, 0xB5, 0x0C, 0x02,
-0xA9, 0x81, 0x18, 0x06, 0x06, 0xE6, 0xFD, 0xED,
-0x69, 0x60, 0x09, 0x19, 0x19, 0xE7, 0x09, 0x09,
-0xF7, 0x19, 0x80, 0xF3, 0x1E, 0x80, 0xD9, 0xEF,
-0x24, 0x86, 0xF8, 0xE6, 0x04, 0xF8, 0xEF, 0x2F,
-0x04, 0x90, 0x87, 0xB1, 0x93, 0xF6, 0x08, 0xEF,
-0x2F, 0x93, 0xF6, 0x7F, 0x00, 0x22, 0xEF, 0xD3,
-0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0xEF,
-0x23, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE5, 0xF4,
-0xC2, 0xAF, 0xE6, 0x54, 0x8C, 0xF6, 0xD2, 0xAF,
-0xE5, 0x0C, 0xB5, 0x07, 0x0A, 0x74, 0x86, 0x2F,
-0xF8, 0xE6, 0xF5, 0x81, 0x02, 0x84, 0x4D, 0x50,
-0x2E, 0x74, 0x87, 0x2F, 0xF8, 0xE6, 0xBF, 0x02,
-0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xF9, 0x74,
-0x86, 0x2F, 0xF8, 0xFB, 0xE6, 0xFC, 0xE9, 0x6C,
-0x60, 0x08, 0xA8, 0x05, 0xE7, 0xF6, 0x1D, 0x19,
-0x80, 0xF4, 0xA8, 0x03, 0xA6, 0x05, 0x1F, 0xE5,
-0x0C, 0xB5, 0x07, 0xE3, 0x7F, 0x00, 0x22, 0x74,
-0x87, 0x2F, 0xF8, 0xE6, 0xFD, 0x18, 0x86, 0x01,
-0x0F, 0x74, 0x86, 0x2F, 0xF8, 0xA6, 0x01, 0x08,
-0x86, 0x04, 0xE5, 0x0C, 0xB5, 0x07, 0x02, 0xAC,
-0x81, 0xED, 0x6C, 0x60, 0x08, 0x0D, 0x09, 0xA8,
-0x05, 0xE6, 0xF7, 0x80, 0xF4, 0xE5, 0x0C, 0xB5,
-0x07, 0xDE, 0x89, 0x81, 0x7F, 0x00, 0x22, 0xEF,
-0xD3, 0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22,
-0xEF, 0x23, 0x24, 0x81, 0xF8, 0xC2, 0xAF, 0xE6,
-0x30, 0xE5, 0x05, 0x30, 0xE0, 0x02, 0xD2, 0xE4,
-0xD2, 0xE2, 0xC6, 0xD2, 0xAF, 0x7F, 0x00, 0x30,
-0xE2, 0x01, 0x0F, 0x02, 0x84, 0x4C, 0x8F, 0xF0,
-0xE4, 0xFF, 0xFE, 0xE5, 0x0C, 0x23, 0x24, 0x80,
-0xF8, 0xC2, 0xA9, 0x30, 0xF7, 0x0D, 0x7F, 0x08,
-0xE6, 0x60, 0x0B, 0x2D, 0xF6, 0x60, 0x30, 0x50,
-0x2E, 0x80, 0x07, 0x30, 0xF1, 0x06, 0xED, 0xF6,
-0x60, 0x25, 0x7E, 0x02, 0x08, 0x30, 0xF0, 0x10,
-0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x23, 0x0E, 0x30,
-0xE2, 0x0C, 0xD2, 0xAF, 0x7F, 0x04, 0x80, 0x12,
-0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x13, 0x54, 0xEC,
-0x4E, 0xF6, 0xD2, 0xAF, 0x02, 0x84, 0x4D, 0x7F,
-0x08, 0x08, 0xEF, 0x44, 0x83, 0xF4, 0xC2, 0xAF,
-0x56, 0xC6, 0xD2, 0xAF, 0x54, 0x80, 0x4F, 0xFF,
-0x22, 0x02, 0x86, 0xE7, 0x02, 0x84, 0xDD, 0xE4,
-0x93, 0xA3, 0xF8, 0xE4, 0x93, 0xA3, 0x40, 0x03,
-0xF6, 0x80, 0x01, 0xF2, 0x08, 0xDF, 0xF4, 0x80,
-0x29, 0xE4, 0x93, 0xA3, 0xF8, 0x54, 0x07, 0x24,
-0x0C, 0xC8, 0xC3, 0x33, 0xC4, 0x54, 0x0F, 0x44,
-0x20, 0xC8, 0x83, 0x40, 0x04, 0xF4, 0x56, 0x80,
-0x01, 0x46, 0xF6, 0xDF, 0xE4, 0x80, 0x0B, 0x01,
-0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x90,
-0x87, 0xA4, 0xE4, 0x7E, 0x01, 0x93, 0x60, 0xBC,
-0xA3, 0xFF, 0x54, 0x3F, 0x30, 0xE5, 0x09, 0x54,
-0x1F, 0xFE, 0xE4, 0x93, 0xA3, 0x60, 0x01, 0x0E,
-0xCF, 0x54, 0xC0, 0x25, 0xE0, 0x60, 0xA8, 0x40,
-0xB8, 0xE4, 0x93, 0xA3, 0xFA, 0xE4, 0x93, 0xA3,
-0xF8, 0xE4, 0x93, 0xA3, 0xC8, 0xC5, 0x82, 0xC8,
-0xCA, 0xC5, 0x83, 0xCA, 0xF0, 0xA3, 0xC8, 0xC5,
-0x82, 0xC8, 0xCA, 0xC5, 0x83, 0xCA, 0xDF, 0xE9,
-0xDE, 0xE7, 0x80, 0xBE, 0xC3, 0xEF, 0x9B, 0xFF,
-0xEE, 0x9A, 0xFE, 0xED, 0x99, 0xFD, 0xEC, 0x98,
-0xFC, 0x22, 0xEF, 0x5B, 0xFF, 0xEE, 0x5A, 0xFE,
-0xED, 0x59, 0xFD, 0xEC, 0x58, 0xFC, 0x22, 0xEF,
-0x4B, 0xFF, 0xEE, 0x4A, 0xFE, 0xED, 0x49, 0xFD,
-0xEC, 0x48, 0xFC, 0x22, 0xE0, 0xFC, 0xA3, 0xE0,
-0xFD, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0xE0, 0xF8, 0xA3, 0xE0, 0xF9, 0xA3, 0xE0, 0xFA,
-0xA3, 0xE0, 0xFB, 0x22, 0xE0, 0xFB, 0xA3, 0xE0,
-0xFA, 0xA3, 0xE0, 0xF9, 0x22, 0xEB, 0xF0, 0xA3,
-0xEA, 0xF0, 0xA3, 0xE9, 0xF0, 0x22, 0xD0, 0x83,
-0xD0, 0x82, 0xF8, 0xE4, 0x93, 0x70, 0x12, 0x74,
-0x01, 0x93, 0x70, 0x0D, 0xA3, 0xA3, 0x93, 0xF8,
-0x74, 0x01, 0x93, 0xF5, 0x82, 0x88, 0x83, 0xE4,
-0x73, 0x74, 0x02, 0x93, 0x68, 0x60, 0xEF, 0xA3,
-0xA3, 0xA3, 0x80, 0xDF, 0x41, 0x96, 0x60, 0x00,
-0x41, 0x96, 0x61, 0x00, 0x41, 0x96, 0x68, 0x00,
-0x00, 0xB3, 0x53, 0x92, 0xFA, 0xC0, 0x75, 0x12,
-0x5E, 0x10, 0x7F, 0x04, 0x90, 0x96, 0x66, 0xEF,
-0xF0, 0x7F, 0x02, 0xD1, 0x27, 0x90, 0x84, 0xC1,
-0xE0, 0xFF, 0x90, 0x96, 0x66, 0xE0, 0xFE, 0xEF,
-0x4E, 0x90, 0x84, 0xC1, 0xF0, 0x22, 0x90, 0x02,
-0x09, 0xE0, 0xF5, 0x0D, 0x12, 0x02, 0xF6, 0x25,
-0x0D, 0x90, 0x84, 0xC6, 0xF0, 0x90, 0x00, 0x01,
-0x12, 0x03, 0x0F, 0x25, 0x0D, 0x90, 0x84, 0xC7,
-0x12, 0x8D, 0xC2, 0x25, 0x0D, 0x90, 0x84, 0xC8,
-0x12, 0x8E, 0x90, 0x25, 0x0D, 0x90, 0x84, 0xC9,
-0xF1, 0x7A, 0x25, 0x0D, 0x90, 0x84, 0xCA, 0x12,
-0xD8, 0x71, 0x25, 0x0D, 0x90, 0x84, 0xCB, 0x11,
-0x18, 0x25, 0x0D, 0x90, 0x84, 0xCC, 0xF0, 0x22,
-0xF0, 0x90, 0x00, 0x06, 0x02, 0x03, 0x0F, 0x90,
-0x94, 0xB0, 0x12, 0x87, 0x75, 0x12, 0xCE, 0x0C,
-0xE0, 0xFF, 0x64, 0x04, 0x70, 0x11, 0x31, 0x03,
-0x12, 0x02, 0xF6, 0x90, 0x94, 0xB3, 0xF0, 0x90,
-0x00, 0x01, 0x12, 0x03, 0x0F, 0x80, 0x10, 0xEF,
-0x64, 0x02, 0x70, 0x2E, 0x31, 0x03, 0xB1, 0xC3,
-0x90, 0x94, 0xB3, 0xF0, 0x12, 0x02, 0xF6, 0x90,
-0x94, 0xB4, 0xF1, 0x7A, 0x90, 0x94, 0xB5, 0x12,
-0xD8, 0x71, 0x90, 0x94, 0xB6, 0x11, 0x18, 0x90,
-0x94, 0xB7, 0xF0, 0x90, 0x00, 0x07, 0x12, 0x03,
-0x0F, 0x90, 0x94, 0xB8, 0xD1, 0x90, 0x90, 0x94,
-0xBB, 0xF0, 0xED, 0x70, 0x19, 0xFE, 0x31, 0x09,
-0xE0, 0xB4, 0xFF, 0x06, 0x31, 0x09, 0xE4, 0xF0,
-0x80, 0x07, 0x31, 0x09, 0xE0, 0x04, 0xF0, 0x80,
-0x05, 0x0E, 0xEE, 0xB4, 0x06, 0xE8, 0xEF, 0xB4,
-0x04, 0x14, 0x90, 0x94, 0xB3, 0x31, 0x01, 0xEF,
-0x12, 0x03, 0x3C, 0x11, 0xFE, 0x12, 0xD9, 0x59,
-0x90, 0x00, 0x02, 0xE4, 0x80, 0x1E, 0xEF, 0xB4,
-0x02, 0x1D, 0x11, 0xFE, 0xEF, 0x12, 0x03, 0x3C,
-0x90, 0x94, 0xB4, 0xE0, 0x44, 0x20, 0x54, 0x7F,
-0x31, 0x02, 0x12, 0xD9, 0x59, 0x90, 0x94, 0xB3,
-0xE0, 0x90, 0x00, 0x02, 0x12, 0x03, 0x4E, 0x31,
-0x03, 0xE9, 0x24, 0x03, 0x12, 0xD9, 0x60, 0x44,
-0x20, 0x12, 0x03, 0x3C, 0x90, 0x94, 0xB5, 0x31,
-0x01, 0x90, 0x00, 0x04, 0xEF, 0x12, 0x03, 0x4E,
-0x90, 0x94, 0xB6, 0xE0, 0x90, 0x00, 0x05, 0x12,
-0x03, 0x4E, 0x90, 0x94, 0xB7, 0xE0, 0x90, 0x00,
-0x06, 0x12, 0x03, 0x4E, 0x90, 0x94, 0xB8, 0xE0,
-0x90, 0x00, 0x07, 0x02, 0x03, 0x4E, 0x90, 0x94,
-0xB4, 0xE0, 0xFF, 0x90, 0x94, 0xB0, 0x02, 0x87,
-0x6C, 0x74, 0xB3, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0x94, 0xF5, 0x83, 0x22, 0x12, 0xAA, 0xC3, 0xFF,
-0x54, 0x7F, 0x90, 0x85, 0xC5, 0xF0, 0xEF, 0x12,
-0x9F, 0x8F, 0xA3, 0xF0, 0x90, 0x00, 0x01, 0x12,
-0x03, 0x0F, 0xFD, 0x54, 0xF0, 0xC4, 0x54, 0x0F,
-0xFF, 0x90, 0x85, 0xC3, 0xE0, 0x54, 0xF0, 0x4F,
-0xD1, 0x90, 0xFC, 0x54, 0x01, 0x25, 0xE0, 0xFF,
-0x90, 0x85, 0xC1, 0xE0, 0x54, 0xFD, 0x4F, 0xF0,
-0xEC, 0x54, 0x04, 0xFF, 0x90, 0x94, 0xFF, 0xE0,
-0x54, 0xFB, 0x4F, 0xF0, 0xED, 0x54, 0x0F, 0xC4,
-0x54, 0xF0, 0xFF, 0x12, 0xC2, 0xBE, 0xB1, 0xC1,
-0x90, 0x85, 0xC4, 0x11, 0x18, 0x30, 0xE0, 0x4D,
-0xC3, 0x13, 0x54, 0x07, 0xFF, 0xC3, 0x94, 0x04,
-0x90, 0x85, 0xD8, 0x50, 0x04, 0xEF, 0xF0, 0x80,
-0x25, 0x74, 0x03, 0x51, 0xB7, 0xE9, 0x24, 0x06,
-0x12, 0xD9, 0x60, 0xFF, 0x74, 0x03, 0x24, 0xFD,
-0xFE, 0xEF, 0xC4, 0x54, 0x0F, 0xFD, 0xEF, 0x54,
-0x0F, 0xFF, 0xED, 0x2E, 0x54, 0x0F, 0xFE, 0xC4,
-0x54, 0xF0, 0x4F, 0x12, 0x03, 0x3C, 0x51, 0xB8,
-0x11, 0x19, 0xC4, 0x54, 0x0F, 0xFF, 0xC3, 0x94,
-0x04, 0x90, 0x85, 0xCD, 0x50, 0x05, 0x74, 0x04,
-0xF0, 0x80, 0x02, 0xEF, 0xF0, 0x51, 0xB8, 0xF1,
-0x7B, 0xFD, 0x7F, 0x02, 0x12, 0x57, 0x82, 0x51,
-0xB8, 0x12, 0x71, 0xCB, 0x12, 0xC7, 0x6D, 0xF0,
-0x90, 0x85, 0xC5, 0x12, 0xD8, 0x1A, 0x12, 0xC2,
-0xBD, 0x90, 0x01, 0xBE, 0xF0, 0x22, 0x90, 0x92,
-0x04, 0x12, 0x87, 0x75, 0x90, 0x92, 0x03, 0xEF,
-0xF0, 0x12, 0x87, 0x7E, 0x8A, 0x30, 0x00, 0x8A,
-0x35, 0x01, 0x8A, 0x3A, 0x03, 0x8A, 0x3F, 0x04,
-0x8A, 0x44, 0x06, 0x8A, 0x55, 0x10, 0x8A, 0x5A,
-0x11, 0x8A, 0x5E, 0x12, 0x8A, 0x63, 0x14, 0x8A,
-0x68, 0x1C, 0x8A, 0x6C, 0x20, 0x8A, 0x70, 0x24,
-0x8A, 0x75, 0x25, 0x8A, 0x7A, 0x27, 0x8A, 0x84,
-0x80, 0x8A, 0x7F, 0x81, 0x8A, 0x88, 0x82, 0x8A,
-0x8D, 0x83, 0x8A, 0x92, 0x84, 0x8A, 0x97, 0x88,
-0x8A, 0x9C, 0xC3, 0x8A, 0x49, 0xC6, 0x8A, 0x49,
-0xC7, 0x8A, 0x49, 0xC8, 0x00, 0x00, 0x8A, 0xA1,
-0x51, 0xB1, 0x02, 0x87, 0xD6, 0x51, 0xB1, 0x02,
-0x9F, 0xF7, 0x51, 0xB1, 0x02, 0x78, 0x94, 0x51,
-0xB1, 0x02, 0x6B, 0x03, 0x51, 0xB1, 0x02, 0xA8,
-0xFB, 0x90, 0x92, 0x03, 0xE0, 0xFF, 0xA3, 0x12,
-0x87, 0x6C, 0x02, 0xA9, 0x92, 0x51, 0xB1, 0x02,
-0xA7, 0xFF, 0x51, 0xB1, 0xA1, 0xC9, 0x51, 0xB1,
-0x02, 0xA8, 0x31, 0x51, 0xB1, 0x02, 0xAA, 0xCC,
-0x51, 0xB1, 0x80, 0x52, 0x51, 0xB1, 0x21, 0x14,
-0x51, 0xB1, 0x02, 0x95, 0x1D, 0x51, 0xB1, 0x02,
-0xAA, 0xDB, 0x51, 0xB1, 0x02, 0xAA, 0xE3, 0x51,
-0xB1, 0x02, 0xBA, 0xF3, 0x51, 0xB1, 0x81, 0xD4,
-0x51, 0xB1, 0x02, 0x7A, 0xFE, 0x51, 0xB1, 0x02,
-0x6F, 0x63, 0x51, 0xB1, 0x02, 0x6F, 0xA4, 0x51,
-0xB1, 0x02, 0xD5, 0x3C, 0x51, 0xB1, 0x02, 0xB0,
-0x1F, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x01, 0xF0,
-0x90, 0x92, 0x03, 0xE0, 0x90, 0x01, 0xC2, 0xF0,
-0x22, 0x90, 0x92, 0x04, 0x02, 0x87, 0x6C, 0xF0,
-0x90, 0x92, 0x07, 0x02, 0x87, 0x6C, 0x12, 0xAA,
-0xC3, 0xFF, 0x90, 0x00, 0x01, 0x12, 0x03, 0x0F,
-0x12, 0xD8, 0xA0, 0xC0, 0x03, 0x51, 0xB8, 0xB1,
-0xC3, 0x12, 0xD8, 0x99, 0xD0, 0x03, 0x12, 0xCA,
-0xE8, 0x51, 0xB8, 0x90, 0x00, 0x01, 0x12, 0x03,
-0x0F, 0x71, 0x05, 0x90, 0x92, 0x0A, 0x74, 0x10,
-0xF0, 0x90, 0x92, 0x18, 0x74, 0x07, 0x51, 0xB7,
-0x12, 0x02, 0xF6, 0x90, 0x92, 0x0C, 0xF0, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x0A, 0x12, 0x5E, 0x10,
-0x7F, 0x04, 0x02, 0x87, 0xBC, 0xFE, 0x54, 0x03,
-0xFF, 0xEE, 0x13, 0x13, 0x54, 0x07, 0xFD, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96,
-0x64, 0xED, 0xF0, 0xE4, 0xA3, 0xF0, 0xEF, 0x14,
-0x60, 0x02, 0x61, 0xF1, 0x90, 0x06, 0x03, 0xE0,
-0x54, 0xFB, 0xF0, 0x90, 0x96, 0x64, 0xE0, 0xFB,
-0xC4, 0x33, 0x54, 0xE0, 0xFE, 0x90, 0x04, 0x42,
-0xE0, 0x54, 0x9F, 0x4E, 0xFE, 0xF0, 0xE4, 0xFD,
-0x12, 0xCB, 0x76, 0x90, 0x96, 0x65, 0xEF, 0xF0,
-0x90, 0x04, 0x83, 0xF0, 0x90, 0x96, 0x1C, 0x12,
-0x04, 0xF7, 0x00, 0x00, 0x00, 0x01, 0x90, 0x96,
-0x20, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x01,
-0x91, 0xC0, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
-0x01, 0x90, 0x96, 0x20, 0x12, 0x04, 0xF7, 0x00,
-0x00, 0x00, 0x01, 0x7F, 0x00, 0x7E, 0x09, 0x91,
-0xC4, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x10,
-0x91, 0xCA, 0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78,
-0x01, 0x12, 0x04, 0xC5, 0x78, 0x04, 0x12, 0xD8,
-0x01, 0x7F, 0x00, 0x7E, 0x0A, 0x91, 0xC4, 0x12,
-0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00, 0x91, 0xCA,
-0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x0A, 0x12,
-0xD8, 0x01, 0x7F, 0x00, 0x7E, 0x0D, 0x91, 0xC4,
-0x12, 0x04, 0xF7, 0x0C, 0x00, 0x00, 0x00, 0x90,
-0x96, 0x65, 0x91, 0xCD, 0xEF, 0x54, 0x03, 0xFF,
-0xE4, 0x78, 0x1A, 0x12, 0xD8, 0x01, 0x7F, 0x18,
-0x91, 0xC2, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C,
-0x00, 0x90, 0x96, 0x20, 0x12, 0x04, 0xF7, 0x00,
-0x00, 0x00, 0x00, 0x12, 0xD8, 0x8D, 0x12, 0x04,
-0xF7, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x96, 0x0E,
-0x12, 0x04, 0xF7, 0x00, 0x00, 0x04, 0x00, 0x80,
-0x59, 0x90, 0x06, 0x03, 0xE0, 0x44, 0x04, 0xF0,
-0x90, 0x96, 0x1C, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x00, 0x01, 0x90, 0x96, 0x20, 0x12, 0x04, 0xF7,
-0x00, 0x00, 0x00, 0x00, 0x91, 0xC0, 0x12, 0x04,
-0xF7, 0x00, 0x00, 0x00, 0x01, 0x90, 0x96, 0x20,
-0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x00, 0x7F,
-0x00, 0x7E, 0x09, 0x91, 0xC4, 0x12, 0x04, 0xF7,
-0x00, 0x00, 0x0C, 0x00, 0x90, 0x96, 0x20, 0x12,
-0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00, 0x12, 0xD8,
-0x8D, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00,
-0x90, 0x96, 0x0E, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x0C, 0x00, 0x7D, 0x18, 0x7C, 0x00, 0xE4, 0xFF,
-0x12, 0xCA, 0x72, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x96, 0x1A, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12,
-0x70, 0x61, 0x90, 0x96, 0x24, 0x12, 0x04, 0xEB,
-0x90, 0x96, 0x1C, 0x12, 0x87, 0x54, 0x12, 0x04,
-0xA7, 0x90, 0x96, 0x24, 0x12, 0xCB, 0x70, 0xC0,
-0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90,
-0x96, 0x1C, 0x12, 0x87, 0x54, 0x90, 0x96, 0x20,
-0x12, 0xCB, 0x70, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x87, 0x47, 0x90, 0x96,
-0x28, 0x12, 0x04, 0xEB, 0x90, 0x96, 0x28, 0x12,
-0x87, 0x54, 0x90, 0x91, 0x66, 0x12, 0x04, 0xEB,
-0x90, 0x96, 0x1A, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x12, 0x71, 0x18, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x7F, 0x00, 0x7E, 0x08, 0x91, 0x58, 0x90, 0x96,
-0x1C, 0x22, 0x90, 0x96, 0x64, 0xE0, 0xFF, 0xE4,
-0xFC, 0xFD, 0xFE, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x12, 0xAA, 0xC3, 0x20, 0xE0,
-0x05, 0x12, 0xD4, 0x81, 0xA1, 0xBC, 0x51, 0xB8,
-0x12, 0xD8, 0x27, 0x90, 0x86, 0x75, 0x12, 0xBB,
-0xAD, 0x12, 0xD9, 0x1B, 0x90, 0x86, 0x75, 0x12,
-0xBB, 0xC2, 0x12, 0xBB, 0xBB, 0x12, 0xD9, 0x09,
-0x90, 0x86, 0x75, 0x12, 0xD8, 0xDD, 0x12, 0xBB,
-0xBB, 0x12, 0xD9, 0x12, 0x90, 0x86, 0x75, 0x12,
-0xD8, 0xD3, 0xF0, 0x90, 0x00, 0x01, 0x12, 0x03,
-0x0F, 0x54, 0x80, 0xFF, 0x90, 0x86, 0x76, 0xE0,
-0x54, 0x7F, 0x4F, 0xF0, 0x12, 0xD9, 0x7F, 0x30,
-0xE0, 0x07, 0x90, 0x06, 0x90, 0xE0, 0x44, 0x04,
-0xF0, 0x51, 0xB8, 0x12, 0x02, 0xF6, 0x13, 0x13,
-0x13, 0x54, 0x1F, 0x30, 0xE0, 0x07, 0x90, 0x06,
-0x90, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x84, 0xC5,
-0xE0, 0xB4, 0x02, 0x0A, 0x90, 0x86, 0x76, 0xE0,
-0x12, 0x9F, 0x8F, 0x20, 0xE0, 0x43, 0x90, 0x00,
-0x01, 0x12, 0x03, 0x0F, 0x54, 0x7F, 0xFF, 0x90,
-0x86, 0x76, 0xE0, 0x54, 0x80, 0xB1, 0xC1, 0x90,
-0x86, 0x77, 0xD1, 0x90, 0xFF, 0x54, 0x01, 0xFE,
-0x90, 0x86, 0x78, 0x12, 0xBD, 0x70, 0xEF, 0x54,
-0xFE, 0xFF, 0xEE, 0x54, 0x01, 0x4F, 0xF0, 0x90,
-0x86, 0x76, 0xE0, 0x54, 0x7F, 0xFF, 0x90, 0x86,
-0x75, 0xE0, 0xFE, 0xC4, 0x13, 0x54, 0x07, 0x7D,
-0x00, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0x12, 0x54,
-0x9F, 0x90, 0x84, 0xC5, 0xE0, 0xB4, 0x01, 0x07,
-0x90, 0xFE, 0x10, 0xE0, 0x44, 0x04, 0xF0, 0x90,
-0x87, 0x4A, 0x74, 0x05, 0xF0, 0x7E, 0x00, 0x7F,
-0x08, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x87, 0x79,
-0x95, 0x12, 0x06, 0xDE, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x4F, 0xF0, 0x90, 0x00, 0x02, 0x02, 0x03,
-0x0F, 0x12, 0xD8, 0xF9, 0x12, 0xD9, 0x9F, 0xBF,
-0x0F, 0x17, 0x90, 0x94, 0xC4, 0xE0, 0x54, 0xFE,
-0xF0, 0x12, 0xC7, 0xC0, 0xD1, 0x99, 0x12, 0x02,
-0xF6, 0x54, 0x0F, 0xFF, 0xF1, 0x92, 0x02, 0xC9,
-0x94, 0xD1, 0x99, 0x12, 0xBD, 0x77, 0x12, 0x02,
-0xF6, 0xFE, 0x54, 0x0F, 0x12, 0xD7, 0xC4, 0xEF,
-0xB1, 0xC2, 0x54, 0x03, 0xFF, 0xED, 0xF1, 0x83,
-0x54, 0xFC, 0xB1, 0xC1, 0x54, 0x1C, 0xFF, 0xEE,
-0x54, 0x0F, 0xFE, 0xF1, 0x83, 0x54, 0xE3, 0xB1,
-0xC1, 0x54, 0xE0, 0xFF, 0xEE, 0xF1, 0x83, 0x54,
-0x1F, 0x4F, 0xF1, 0x7A, 0x12, 0xD9, 0x51, 0xE4,
-0xFB, 0xD1, 0x97, 0x12, 0xD8, 0x72, 0x12, 0xD9,
-0x51, 0x7B, 0x01, 0xD1, 0x97, 0xD1, 0x91, 0x33,
-0x33, 0x33, 0x54, 0xF8, 0xFF, 0x12, 0x02, 0xF6,
-0xFE, 0x54, 0x0F, 0xFD, 0x75, 0xF0, 0x0E, 0xA4,
-0x24, 0xD1, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0xEF, 0xD1, 0x90, 0xC4, 0x13, 0x54, 0x07,
-0xFF, 0xED, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0xD2,
-0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xEF,
-0xF0, 0xEE, 0xC4, 0x54, 0x0F, 0xFF, 0x14, 0x6D,
-0x70, 0x25, 0x90, 0x94, 0xC6, 0xEF, 0x11, 0x18,
-0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFF, 0x90, 0x94,
-0xC5, 0xE0, 0x54, 0x0F, 0x4F, 0xF0, 0x54, 0xF1,
-0xF0, 0x90, 0x94, 0xC4, 0xE0, 0x44, 0x01, 0xF0,
-0x7D, 0x20, 0xE4, 0xFF, 0x12, 0x7B, 0xFD, 0x22,
-0xF0, 0x90, 0x00, 0x03, 0x02, 0x03, 0x0F, 0xD1,
-0xA0, 0xAB, 0x0D, 0xAA, 0x0E, 0xA9, 0x0F, 0x22,
-0x8F, 0x10, 0x8D, 0x11, 0xAE, 0x03, 0x74, 0x1F,
-0xC3, 0x95, 0x10, 0x40, 0x0A, 0xF1, 0x72, 0xE4,
-0xFD, 0xF1, 0x6A, 0x24, 0xD4, 0x80, 0x31, 0x74,
-0x3F, 0xC3, 0x95, 0x10, 0x40, 0x0A, 0xF1, 0x72,
-0x7D, 0x20, 0xF1, 0x68, 0x24, 0x88, 0x80, 0x20,
-0x74, 0x5F, 0xC3, 0x95, 0x10, 0x40, 0x0A, 0xF1,
-0x72, 0x7D, 0x40, 0xF1, 0x68, 0x24, 0xD0, 0x80,
-0x0F, 0x74, 0x7F, 0xC3, 0x95, 0x10, 0x40, 0x1E,
-0xF1, 0x72, 0x7D, 0x60, 0xF1, 0x68, 0x24, 0x84,
-0xFD, 0xE4, 0x34, 0x04, 0xFC, 0xE5, 0x11, 0x12,
-0x90, 0x96, 0x75, 0xF0, 0x03, 0xEE, 0x12, 0x05,
-0x28, 0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x22, 0xC3,
-0xEF, 0x9D, 0xF5, 0x12, 0xC3, 0x94, 0x08, 0x50,
-0x1D, 0xE4, 0xF5, 0x13, 0x12, 0x90, 0x7B, 0xC0,
-0x83, 0xC0, 0x82, 0x90, 0x92, 0x0B, 0xE0, 0xD0,
-0x82, 0xD0, 0x83, 0x75, 0xF0, 0x03, 0x12, 0x05,
-0x28, 0xE5, 0x12, 0xF0, 0x80, 0x3F, 0xE5, 0x12,
-0xC3, 0x94, 0x10, 0x50, 0x09, 0x75, 0x13, 0x01,
-0xE5, 0x12, 0x24, 0xF8, 0x80, 0x17, 0xE5, 0x12,
-0xC3, 0x94, 0x18, 0x50, 0x09, 0x75, 0x13, 0x02,
-0xE5, 0x12, 0x24, 0xF0, 0x80, 0x07, 0x75, 0x13,
-0x03, 0xE5, 0x12, 0x24, 0xE8, 0xFF, 0x12, 0x90,
-0x7B, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x92, 0x0B,
-0xE0, 0xD0, 0x82, 0xD0, 0x83, 0x75, 0xF0, 0x03,
-0x12, 0x05, 0x28, 0xEF, 0xF0, 0xAF, 0x13, 0x22,
-0xAF, 0x10, 0xD1, 0xFF, 0x90, 0x92, 0x07, 0xEF,
-0xF0, 0x22, 0x90, 0x92, 0x0B, 0xEE, 0xF0, 0xAB,
-0x11, 0x22, 0xF0, 0x90, 0x00, 0x04, 0x02, 0x03,
-0x0F, 0xE5, 0x10, 0x75, 0xF0, 0x0E, 0xA4, 0x24,
-0xC9, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0xE0, 0x22, 0x8F, 0x10, 0x7B, 0x17, 0x12, 0xBF,
-0x87, 0xE5, 0x10, 0x12, 0xD7, 0xC5, 0xE0, 0xFC,
-0xF1, 0x81, 0x12, 0xD8, 0xA0, 0x90, 0x94, 0xC5,
-0xE0, 0xFE, 0x12, 0xD8, 0x98, 0xAF, 0x04, 0x12,
-0xCA, 0xE8, 0xF1, 0x81, 0x71, 0x05, 0xE5, 0x10,
-0x12, 0xBF, 0x6A, 0x12, 0xBE, 0x87, 0xAD, 0x10,
-0x7F, 0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x96, 0x48, 0xEF, 0xF0, 0xA3, 0xED,
-0xF0, 0xE4, 0xA3, 0xF0, 0x90, 0x96, 0x4A, 0xE0,
-0xFF, 0xC3, 0x94, 0x03, 0x40, 0x03, 0x02, 0x90,
-0x5E, 0x90, 0x96, 0x49, 0xE0, 0xFE, 0x12, 0x90,
-0x96, 0x75, 0xF0, 0x03, 0xEF, 0x12, 0x90, 0x8A,
-0xE0, 0x90, 0x96, 0x4B, 0xF0, 0x90, 0x96, 0x48,
-0xE0, 0xFC, 0xB4, 0x02, 0x1F, 0x90, 0x96, 0x4B,
-0xE0, 0xFD, 0xEE, 0x11, 0x7C, 0xC0, 0x83, 0xC0,
-0x82, 0x90, 0x96, 0x4A, 0xE0, 0xD0, 0x82, 0xD0,
-0x83, 0x11, 0x6D, 0x80, 0x02, 0xC3, 0x33, 0xD8,
-0xFC, 0x4D, 0x80, 0x1E, 0xEC, 0xB4, 0x01, 0x1E,
-0x11, 0x63, 0x11, 0x7C, 0xC0, 0x83, 0xC0, 0x82,
-0x90, 0x96, 0x4A, 0xE0, 0xD0, 0x82, 0xD0, 0x83,
-0x11, 0x6D, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xF4, 0x5F, 0x90, 0x96, 0x4B, 0xF0, 0x11, 0x63,
-0x11, 0x96, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x96,
-0x4A, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0x75, 0xF0,
-0x03, 0x11, 0x8A, 0xEF, 0xF0, 0x90, 0x96, 0x4A,
-0xE0, 0x04, 0xF0, 0x02, 0x8F, 0xD4, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x96, 0x4B, 0xE0, 0xFF,
-0x90, 0x96, 0x49, 0xE0, 0x22, 0x75, 0xF0, 0x03,
-0x12, 0x05, 0x28, 0xE0, 0xFE, 0x74, 0x01, 0xA8,
-0x06, 0x08, 0x22, 0xEB, 0x75, 0xF0, 0x0E, 0xA4,
-0x24, 0xCC, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0x22, 0x12, 0x05, 0x28, 0xE0, 0xFC, 0xA3,
-0xE0, 0xF5, 0x82, 0x8C, 0x83, 0x22, 0x75, 0xF0,
-0x0E, 0xA4, 0x24, 0xCA, 0xF5, 0x82, 0xE4, 0x34,
-0x94, 0xF5, 0x83, 0x22, 0x90, 0x01, 0xCC, 0xE0,
-0x54, 0x0F, 0x90, 0x92, 0x01, 0xF0, 0x90, 0x92,
-0x01, 0xE0, 0xFD, 0x70, 0x02, 0x21, 0x9B, 0x90,
-0x85, 0x1D, 0xE0, 0xFF, 0x70, 0x06, 0xA3, 0xE0,
-0x64, 0x09, 0x60, 0x0A, 0xEF, 0x14, 0xFF, 0x90,
-0x85, 0x1E, 0xE0, 0xB5, 0x07, 0x04, 0x7F, 0x01,
-0x80, 0x02, 0x7F, 0x00, 0xEF, 0x60, 0x08, 0x90,
-0x01, 0xC1, 0xE0, 0x44, 0x01, 0xF0, 0x22, 0x31,
-0xA5, 0x7E, 0x00, 0xA8, 0x07, 0x08, 0x80, 0x05,
-0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF,
-0xEF, 0x5D, 0x70, 0x02, 0x21, 0x7E, 0xE4, 0x90,
-0x92, 0x02, 0xF0, 0x90, 0x92, 0x02, 0xE0, 0xF9,
-0xC3, 0x94, 0x04, 0x50, 0x34, 0x31, 0x9D, 0xA4,
-0xFF, 0xE9, 0xFD, 0x7C, 0x00, 0x2F, 0xFF, 0xEC,
-0x35, 0xF0, 0xFE, 0x74, 0xD0, 0x31, 0xBB, 0x90,
-0x84, 0xCD, 0x31, 0xAD, 0xEF, 0x31, 0x9C, 0xA4,
-0x2D, 0xFF, 0xEC, 0x35, 0xF0, 0xFE, 0x74, 0xF0,
-0x31, 0xBB, 0x90, 0x84, 0xD1, 0x31, 0xAD, 0xEF,
-0xF0, 0x90, 0x92, 0x02, 0xE0, 0x04, 0xF0, 0x80,
-0xC2, 0x90, 0x92, 0x01, 0xE0, 0xFF, 0x90, 0x96,
-0x60, 0x11, 0x73, 0x80, 0x02, 0xC3, 0x33, 0xD8,
-0xFC, 0xF4, 0x5F, 0x90, 0x92, 0x01, 0xF0, 0x31,
-0xA5, 0xA8, 0x07, 0x08, 0x80, 0x02, 0xC3, 0x33,
-0xD8, 0xFC, 0x90, 0x01, 0xCC, 0xF0, 0x90, 0x96,
-0x60, 0xE0, 0x04, 0xF0, 0xE0, 0x54, 0x03, 0xF0,
-0x90, 0x85, 0x1E, 0x51, 0x6A, 0xB4, 0x0A, 0x02,
-0x7F, 0x01, 0xEF, 0x70, 0x02, 0x01, 0xAE, 0xE4,
-0x90, 0x85, 0x1E, 0xF0, 0x01, 0xAE, 0x90, 0x01,
-0xC0, 0xE0, 0x44, 0x02, 0xF0, 0x90, 0x96, 0x60,
-0xE0, 0x44, 0x80, 0x90, 0x00, 0x8A, 0x31, 0x9C,
-0x90, 0x01, 0xD0, 0x12, 0x05, 0x28, 0xE0, 0x90,
-0x01, 0xC3, 0xF0, 0x22, 0xF0, 0x90, 0x96, 0x60,
-0xE0, 0x75, 0xF0, 0x04, 0x22, 0x90, 0x96, 0x60,
-0xE0, 0xFF, 0x74, 0x01, 0x22, 0x12, 0x05, 0x28,
-0xE5, 0x82, 0x29, 0xF5, 0x82, 0xE4, 0x35, 0x83,
-0xF5, 0x83, 0x22, 0x2F, 0xF5, 0x82, 0x74, 0x01,
-0x3E, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x85, 0x1E,
-0xE0, 0x75, 0xF0, 0x08, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x62, 0xEF,
-0xF0, 0x51, 0x24, 0x30, 0xE6, 0x41, 0x7F, 0x8D,
-0x12, 0x7B, 0x51, 0xEF, 0x64, 0x01, 0x70, 0x37,
-0x90, 0x96, 0x63, 0xF0, 0x90, 0x96, 0x63, 0xE0,
-0xFD, 0x90, 0x96, 0x62, 0xE0, 0xC4, 0x54, 0xF0,
-0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
-0x83, 0xE5, 0x82, 0x2D, 0x31, 0xB3, 0xE0, 0xFB,
-0xE4, 0xFF, 0x51, 0x71, 0x90, 0x96, 0x63, 0xE0,
-0x04, 0xF0, 0xE0, 0xC3, 0x94, 0x10, 0x40, 0xD4,
-0x51, 0x24, 0x30, 0xE0, 0x02, 0x51, 0x61, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x7F, 0x8F, 0x12, 0x7B,
-0x51, 0xEF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x51, 0x24, 0x30, 0xE6, 0x25, 0x90,
-0x00, 0x8C, 0xE0, 0x90, 0x96, 0x57, 0xF0, 0x7F,
-0x8D, 0x12, 0x7B, 0x51, 0x90, 0x96, 0x58, 0xEF,
-0xF0, 0x90, 0x00, 0x8E, 0xE0, 0x90, 0x96, 0x59,
-0xF0, 0x90, 0x96, 0x58, 0xE0, 0x51, 0x24, 0x30,
-0xE0, 0x02, 0x51, 0x61, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xE4, 0xFD, 0x7F, 0x8D, 0x02, 0x7B, 0x3E,
-0x80, 0xC1, 0xE0, 0x04, 0xF0, 0xE0, 0x7F, 0x00,
-0x22, 0xEF, 0x70, 0x04, 0x74, 0xF0, 0x80, 0x16,
-0xEF, 0xB4, 0x01, 0x04, 0x74, 0xF4, 0x80, 0x0E,
-0xEF, 0xB4, 0x02, 0x04, 0x74, 0xF8, 0x80, 0x06,
-0xEF, 0xB4, 0x03, 0x0C, 0x74, 0xFC, 0x2D, 0xF5,
-0x82, 0xE4, 0x34, 0x02, 0xF5, 0x83, 0xEB, 0xF0,
-0x22, 0x90, 0x85, 0xB5, 0xE0, 0xFF, 0x70, 0x06,
-0xA3, 0xE0, 0x64, 0x09, 0x60, 0x0A, 0xEF, 0x14,
-0xFF, 0x90, 0x85, 0xB6, 0xE0, 0xB5, 0x07, 0x04,
-0x7F, 0x01, 0x80, 0x02, 0x7F, 0x00, 0xEF, 0x60,
-0x08, 0x90, 0x01, 0xC1, 0xE0, 0x44, 0x02, 0xF0,
-0x22, 0xC0, 0x01, 0x90, 0x85, 0xB6, 0xE0, 0x75,
-0xF0, 0x0F, 0xA4, 0x24, 0x1F, 0xF9, 0x74, 0x85,
-0x35, 0xF0, 0xA8, 0x01, 0xFC, 0x7D, 0x01, 0xD0,
-0x01, 0x7E, 0x00, 0x7F, 0x0F, 0x12, 0x02, 0xD0,
-0x7D, 0xCC, 0x7F, 0xFE, 0x12, 0x7B, 0x3E, 0x90,
-0x85, 0xB6, 0x51, 0x6A, 0xB4, 0x0A, 0x02, 0x7F,
-0x01, 0xEF, 0x60, 0x05, 0xE4, 0x90, 0x85, 0xB6,
-0xF0, 0x22, 0xE4, 0x90, 0x92, 0x6D, 0xF0, 0xA3,
-0xF0, 0xA3, 0xF0, 0x90, 0x92, 0x6D, 0xE0, 0x64,
-0x01, 0xF0, 0x90, 0x94, 0xFC, 0xE0, 0x70, 0x18,
-0x90, 0x94, 0xF9, 0xE0, 0x70, 0x12, 0xA3, 0xE0,
-0x70, 0x0E, 0x90, 0x92, 0x6D, 0xE0, 0x24, 0xFA,
-0x90, 0x01, 0xC4, 0xF0, 0x74, 0x92, 0xA3, 0xF0,
-0x12, 0x7C, 0x66, 0xBF, 0x01, 0x03, 0x12, 0x5B,
-0x25, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x0E, 0x90,
-0x85, 0xC8, 0xE0, 0xFF, 0x90, 0x85, 0xC7, 0xE0,
-0x6F, 0x60, 0x02, 0x71, 0x5C, 0xC2, 0xAF, 0x12,
-0xC0, 0x2B, 0xBF, 0x01, 0x03, 0x12, 0xCC, 0x14,
-0xD2, 0xAF, 0x12, 0xC8, 0xE0, 0x51, 0x68, 0x12,
-0x84, 0x4D, 0x80, 0xA7, 0x90, 0x85, 0xBC, 0xE0,
-0x90, 0x85, 0xC7, 0x30, 0xE0, 0x04, 0xE0, 0xFF,
-0xC1, 0xB1, 0xE0, 0xFF, 0x7D, 0x01, 0x80, 0x04,
-0x7D, 0x01, 0x7F, 0x04, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x6A, 0xED, 0xF0,
-0x90, 0x85, 0xC1, 0xE0, 0xFE, 0xC4, 0x13, 0x13,
-0x54, 0x03, 0x30, 0xE0, 0x02, 0x81, 0xD0, 0xEE,
-0x12, 0x9F, 0x8F, 0x30, 0xE0, 0x02, 0x81, 0xD0,
-0x90, 0x85, 0xC8, 0xE0, 0xFE, 0x6F, 0x70, 0x02,
-0x81, 0xD0, 0xEF, 0x70, 0x02, 0x81, 0x3A, 0x24,
-0xFE, 0x70, 0x02, 0x81, 0x77, 0x24, 0xFE, 0x60,
-0x4D, 0x24, 0xFC, 0x70, 0x02, 0x81, 0xB6, 0x24,
-0xFC, 0x60, 0x02, 0x81, 0xC9, 0xEE, 0xB4, 0x0E,
-0x03, 0x12, 0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0,
-0x70, 0x05, 0x7F, 0x01, 0x12, 0x79, 0x80, 0x90,
-0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x73,
-0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x04, 0x0F,
-0x90, 0x96, 0x6A, 0xE0, 0xFF, 0x60, 0x05, 0x12,
-0x6D, 0x4C, 0x80, 0x03, 0x12, 0x79, 0x61, 0x90,
-0x85, 0xC8, 0xE0, 0x64, 0x08, 0x60, 0x02, 0x81,
-0xC9, 0x12, 0x7A, 0xB9, 0x81, 0xC9, 0x90, 0x85,
-0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79,
-0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03,
-0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
-0x0E, 0x08, 0x91, 0xD5, 0xBF, 0x01, 0x03, 0x12,
-0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x0C,
-0x60, 0x02, 0x81, 0xC9, 0x91, 0xD5, 0xEF, 0x64,
-0x01, 0x60, 0x02, 0x81, 0xC9, 0x12, 0x70, 0x9E,
-0x81, 0xC9, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E,
-0x08, 0x91, 0xD5, 0xBF, 0x01, 0x03, 0x12, 0x74,
-0x93, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03,
-0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
-0x0C, 0x08, 0x91, 0xD5, 0xBF, 0x01, 0x03, 0x12,
-0x70, 0x9E, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x04,
-0x70, 0x5F, 0x12, 0xCC, 0xC2, 0xEF, 0x64, 0x01,
-0x70, 0x57, 0x12, 0x77, 0xFE, 0x80, 0x52, 0x90,
-0x85, 0xC8, 0xE0, 0xB4, 0x0E, 0x08, 0x91, 0xD5,
-0xBF, 0x01, 0x03, 0x12, 0x74, 0x93, 0x90, 0x85,
-0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x73, 0x8E,
-0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0C, 0x08, 0x91,
-0xD5, 0xBF, 0x01, 0x03, 0x12, 0x70, 0x9E, 0x90,
-0x85, 0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12,
-0x79, 0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x04,
-0x18, 0x12, 0x79, 0xF3, 0x80, 0x13, 0x90, 0x85,
-0xC8, 0xE0, 0xB4, 0x0C, 0x0C, 0x90, 0x85, 0xC2,
-0x12, 0xC4, 0x27, 0x30, 0xE0, 0x03, 0x12, 0x7A,
-0x8A, 0x90, 0x85, 0xC8, 0x12, 0xD8, 0x1A, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x7A, 0x29, 0xEF,
-0x64, 0x01, 0x60, 0x05, 0x75, 0x5B, 0x01, 0x80,
-0x21, 0x90, 0x85, 0xC1, 0x12, 0x9F, 0x37, 0x30,
-0xE0, 0x05, 0x75, 0x5B, 0x02, 0x80, 0x13, 0x90,
-0x85, 0xC7, 0xE0, 0xD3, 0x94, 0x04, 0x40, 0x05,
-0x75, 0x5B, 0x08, 0x80, 0x05, 0x12, 0xCC, 0xBA,
-0x80, 0x0E, 0x90, 0x01, 0xB9, 0x74, 0x02, 0xF0,
-0x90, 0x01, 0xB8, 0xE5, 0x5B, 0xF0, 0x7F, 0x00,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x12, 0xD8, 0xF9, 0x90,
-0x05, 0x27, 0xE0, 0xF5, 0x10, 0x12, 0xB9, 0x1C,
-0x75, 0x1E, 0x01, 0x7B, 0x01, 0x7A, 0x85, 0x79,
-0xBC, 0x12, 0x6A, 0x21, 0x12, 0x8E, 0x99, 0x12,
-0x02, 0xF6, 0xFF, 0xC3, 0x13, 0x20, 0xE0, 0x02,
-0xA1, 0xD5, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0,
-0x72, 0xD1, 0x81, 0x75, 0x10, 0x21, 0xD1, 0x91,
-0x30, 0xE0, 0x05, 0x12, 0xD8, 0x0A, 0x80, 0x0D,
-0xE4, 0x90, 0x85, 0xBD, 0xF0, 0xA3, 0xF0, 0x7D,
-0x40, 0xFF, 0x12, 0x7C, 0x41, 0x90, 0x85, 0xBC,
-0xD1, 0x9D, 0x30, 0xE0, 0x03, 0x43, 0x10, 0x12,
-0xEF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x03, 0x43,
-0x10, 0x14, 0x90, 0x85, 0xBC, 0xE0, 0xC4, 0x13,
-0x54, 0x07, 0x30, 0xE0, 0x03, 0x43, 0x10, 0x80,
-0x90, 0x85, 0xBC, 0xF1, 0xF8, 0x20, 0xE0, 0x03,
-0x43, 0x10, 0x40, 0xD1, 0x7A, 0x90, 0x85, 0xBF,
-0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0xAD, 0x43,
-0xD1, 0x88, 0x54, 0x03, 0x30, 0xE0, 0x04, 0x7F,
-0x04, 0x80, 0x0B, 0xD1, 0xA5, 0xEF, 0x60, 0x04,
-0x7F, 0x01, 0x80, 0x02, 0x7F, 0x02, 0x12, 0xAD,
-0x43, 0xC1, 0x44, 0xD1, 0x77, 0x90, 0x85, 0xBF,
-0xE0, 0x64, 0x04, 0x60, 0x02, 0xC1, 0x72, 0xFF,
-0x12, 0xAD, 0x43, 0xC1, 0x72, 0x90, 0x85, 0xBC,
-0xE0, 0x30, 0xE0, 0x70, 0xD1, 0x81, 0x43, 0x10,
-0x31, 0xD1, 0x91, 0x30, 0xE0, 0x05, 0x12, 0xD8,
-0x0A, 0x80, 0x07, 0x7D, 0x40, 0xE4, 0xFF, 0x12,
-0x7C, 0x41, 0x90, 0x85, 0xBC, 0xD1, 0x9D, 0x30,
-0xE0, 0x03, 0x43, 0x10, 0x02, 0xEF, 0xC4, 0x54,
-0x0F, 0x30, 0xE0, 0x03, 0x43, 0x10, 0x04, 0xD1,
-0x7A, 0xD1, 0x88, 0x54, 0x03, 0x30, 0xE0, 0x0A,
-0xF1, 0x71, 0x60, 0x30, 0xE4, 0xFD, 0x7F, 0x02,
-0x80, 0x1E, 0x12, 0xD7, 0xE9, 0x90, 0x85, 0xC0,
-0xE0, 0xB4, 0x02, 0x18, 0x12, 0x7A, 0xA2, 0xD1,
-0xA5, 0xBF, 0x01, 0x09, 0x90, 0x85, 0xC7, 0xE0,
-0xFF, 0x7D, 0x01, 0x80, 0x03, 0xE4, 0xFD, 0xFF,
-0x71, 0x74, 0x80, 0x08, 0x90, 0x85, 0xC8, 0xE0,
-0x90, 0x85, 0xC0, 0xF0, 0x90, 0x05, 0x40, 0x74,
-0x22, 0xF0, 0x80, 0x26, 0xD1, 0x77, 0x90, 0x85,
-0xC0, 0xE0, 0xB4, 0x02, 0x06, 0x7D, 0x01, 0x7F,
-0x04, 0x80, 0x0B, 0x90, 0x85, 0xC0, 0xE0, 0xB4,
-0x08, 0x06, 0x7D, 0x01, 0x7F, 0x0C, 0x71, 0x74,
-0xF1, 0xEC, 0x90, 0x85, 0xC7, 0x71, 0x6A, 0x12,
-0xB4, 0xD6, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x75,
-0x10, 0x01, 0x90, 0x05, 0x27, 0xE5, 0x10, 0xF0,
-0x22, 0x7D, 0x03, 0x7F, 0x02, 0x02, 0x7B, 0xFD,
-0x90, 0x85, 0xBC, 0xE0, 0xFF, 0xC4, 0x13, 0x13,
-0x22, 0x90, 0x85, 0xBC, 0xE0, 0x13, 0x13, 0x54,
-0x3F, 0x22, 0x90, 0x85, 0xC2, 0xE0, 0xFF, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x22, 0x90, 0x05, 0x43,
-0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02, 0x7F, 0x01,
-0x22, 0xAE, 0x07, 0xD1, 0xA5, 0xBF, 0x01, 0x11,
-0x90, 0x85, 0xBC, 0xF1, 0xF8, 0x20, 0xE0, 0x09,
-0xAF, 0x06, 0x7D, 0x01, 0x71, 0x74, 0x7F, 0x01,
-0x22, 0x7F, 0x00, 0x22, 0xE4, 0xF5, 0x15, 0x90,
-0x85, 0xC5, 0xE0, 0x60, 0x71, 0x12, 0xC3, 0x25,
-0x70, 0x6C, 0x12, 0xD7, 0x78, 0xF0, 0x75, 0x15,
-0x01, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x11,
-0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x02, 0x03, 0xE4,
-0xF5, 0x15, 0xD1, 0xA5, 0xEF, 0x70, 0x02, 0xF5,
-0x15, 0xE5, 0x15, 0x60, 0x49, 0x90, 0x85, 0xC8,
-0xE0, 0x20, 0xE2, 0x02, 0x71, 0x70, 0x12, 0xC7,
-0xCF, 0x90, 0x85, 0xCE, 0xE0, 0x60, 0x04, 0x64,
-0x01, 0x70, 0x17, 0xE4, 0x90, 0x91, 0x6E, 0xF0,
-0x90, 0x85, 0xCE, 0xE0, 0xF1, 0x52, 0x90, 0x91,
-0x6F, 0x12, 0xC2, 0x3E, 0x90, 0x85, 0xCE, 0xE0,
-0x80, 0x16, 0xE4, 0x90, 0x91, 0x6E, 0xF1, 0x47,
-0x90, 0x91, 0x6F, 0x12, 0xC2, 0x3E, 0x90, 0x85,
-0xCE, 0xE0, 0x75, 0xF0, 0x03, 0xA4, 0x24, 0xFE,
-0xF1, 0x52, 0x90, 0x85, 0xDE, 0xF0, 0x22, 0xF0,
-0x90, 0x85, 0xCE, 0xE0, 0x75, 0xF0, 0x03, 0xA4,
-0x24, 0xFE, 0xFF, 0x90, 0x85, 0xCD, 0xE0, 0x2F,
-0x22, 0xD1, 0x88, 0x54, 0x03, 0x30, 0xE0, 0x0A,
-0xF1, 0x71, 0x60, 0x06, 0x7D, 0x01, 0x7F, 0x02,
-0x71, 0x74, 0xF1, 0x71, 0x60, 0x02, 0xF1, 0x78,
-0x22, 0x90, 0x85, 0xC0, 0xE0, 0x64, 0x02, 0x22,
-0x90, 0x85, 0xC5, 0xE0, 0x64, 0x02, 0x60, 0x10,
-0x12, 0xC2, 0xBE, 0x60, 0x0B, 0x12, 0x7A, 0x29,
-0xEF, 0x70, 0x05, 0xFD, 0x7F, 0x0C, 0x71, 0x74,
-0x22, 0x90, 0x85, 0xC5, 0xE0, 0x64, 0x01, 0x70,
-0x18, 0x12, 0xC2, 0xBE, 0x60, 0x0B, 0xE4, 0xFD,
-0x7F, 0x0C, 0x71, 0x74, 0xF1, 0xD0, 0x02, 0x6B,
-0x98, 0x90, 0x85, 0xC8, 0xE0, 0x70, 0x02, 0x71,
-0x70, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x70, 0x07,
-0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x10, 0x90,
-0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x07, 0xD1, 0xA5,
-0xBF, 0x01, 0x04, 0x80, 0xAB, 0xF1, 0x91, 0x22,
-0xE4, 0xFD, 0xFF, 0x02, 0xA0, 0xD8, 0xF1, 0xD0,
-0x90, 0x85, 0xBF, 0x74, 0x01, 0xF0, 0x22, 0x12,
-0xA0, 0xD2, 0x80, 0xF4, 0xE4, 0xFD, 0xFF, 0x12,
-0xD7, 0xE6, 0x80, 0xEC, 0x12, 0x7A, 0x29, 0xEF,
-0x70, 0x02, 0xF1, 0x91, 0x22, 0x90, 0x86, 0x72,
-0xE0, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x22, 0x90,
-0x92, 0x86, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0xF1,
-0xAD, 0xE4, 0x90, 0x92, 0x88, 0xF0, 0xFD, 0x12,
-0x55, 0x36, 0xEF, 0x54, 0x0C, 0x64, 0x08, 0x70,
-0x74, 0x11, 0x93, 0xA3, 0xE0, 0xF1, 0x2C, 0x64,
-0x88, 0x70, 0x6A, 0x11, 0x93, 0xA3, 0xE0, 0x24,
-0x07, 0xFD, 0x12, 0x55, 0x36, 0xEF, 0x64, 0x8E,
-0x70, 0x5B, 0x90, 0x92, 0x88, 0x04, 0xF0, 0x11,
-0x93, 0xF1, 0x53, 0x04, 0xFD, 0x12, 0x55, 0x36,
-0xEF, 0x64, 0x03, 0x70, 0x48, 0x11, 0x93, 0xF1,
-0x53, 0xF1, 0x2C, 0x30, 0xE3, 0x07, 0x90, 0x01,
-0xC7, 0x74, 0x01, 0x80, 0x36, 0x90, 0x86, 0x72,
-0xF1, 0x37, 0x30, 0xE0, 0x20, 0x90, 0x88, 0xCC,
-0xE0, 0x64, 0x02, 0x70, 0x0E, 0xF1, 0x34, 0x30,
-0xE0, 0x02, 0x80, 0x07, 0x90, 0x01, 0xC7, 0x74,
-0x02, 0x80, 0x18, 0x11, 0x93, 0xA3, 0xE0, 0xFD,
-0x12, 0x25, 0x7C, 0x80, 0x10, 0x90, 0x86, 0x75,
-0x12, 0x97, 0xF8, 0x30, 0xE0, 0x07, 0x90, 0x01,
-0xC7, 0x74, 0x02, 0x71, 0x86, 0x90, 0x92, 0x88,
-0xE0, 0xFF, 0x22, 0x90, 0x92, 0x84, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0xE4, 0x90, 0x95, 0xFC, 0xF0,
-0xA3, 0xF0, 0xA3, 0x74, 0x08, 0xF0, 0xA3, 0xF0,
-0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x96, 0x04,
-0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x01, 0xC4,
-0x74, 0x9C, 0xF0, 0x74, 0x98, 0xA3, 0xF0, 0x90,
-0x01, 0x1F, 0xE0, 0xFE, 0x90, 0x01, 0x1E, 0x12,
-0xB9, 0x8C, 0xF1, 0x9D, 0x90, 0x02, 0x87, 0xE0,
-0x90, 0x95, 0xFB, 0xF0, 0x90, 0x86, 0x72, 0xE0,
-0x20, 0xE0, 0x02, 0x61, 0x6C, 0xE4, 0x90, 0x95,
-0xFA, 0xF0, 0x90, 0x95, 0xFB, 0xE0, 0xFF, 0x90,
-0x95, 0xFA, 0xE0, 0xC3, 0x9F, 0x40, 0x02, 0x61,
-0x6C, 0x12, 0xD9, 0x36, 0xEC, 0xFF, 0x90, 0xFD,
-0x11, 0xF0, 0x90, 0x96, 0x04, 0xEF, 0xF0, 0x12,
-0xB8, 0x80, 0xE0, 0xFE, 0x12, 0xB8, 0x75, 0x12,
-0xD9, 0x00, 0x54, 0x3F, 0xFE, 0x90, 0x95, 0xF5,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x96, 0x00, 0xEE,
-0xF0, 0xA3, 0x12, 0xB8, 0x97, 0x54, 0x0F, 0x33,
-0x33, 0x33, 0x54, 0xF8, 0xFF, 0x12, 0xB8, 0x8B,
-0x54, 0x03, 0xFE, 0xEF, 0x24, 0x18, 0x2E, 0xFF,
-0x90, 0x96, 0x05, 0xF0, 0x90, 0x95, 0xF4, 0xE0,
-0x2F, 0xFF, 0x90, 0x95, 0xF3, 0xE0, 0x34, 0x00,
-0xFE, 0x90, 0x95, 0xF7, 0x12, 0xD8, 0xE7, 0xC0,
-0x07, 0x71, 0x7D, 0x7D, 0x01, 0x12, 0x55, 0x36,
-0xC0, 0x07, 0x71, 0x7D, 0x7D, 0x04, 0x12, 0x55,
-0x36, 0xAB, 0x07, 0xD0, 0x05, 0xD0, 0x07, 0x12,
-0x5D, 0x98, 0x90, 0x95, 0xFC, 0xEF, 0x71, 0x7C,
-0xE4, 0xFD, 0x12, 0x55, 0x36, 0xEF, 0x54, 0xFC,
-0x90, 0x95, 0xF9, 0xF0, 0x90, 0x96, 0x05, 0xE0,
-0xFF, 0x90, 0x95, 0xF5, 0xE4, 0x8F, 0xF0, 0x12,
-0x07, 0x0A, 0x12, 0xD9, 0x3F, 0x12, 0x7A, 0xD0,
-0x90, 0x95, 0xF5, 0xEE, 0xF0, 0xA3, 0xEF, 0xF1,
-0x3E, 0x7D, 0x0F, 0x12, 0x55, 0x36, 0xAD, 0x07,
-0xEF, 0x30, 0xE6, 0x08, 0x71, 0x87, 0x90, 0x01,
-0xC7, 0x74, 0x22, 0xF0, 0xED, 0x30, 0xE7, 0x08,
-0x71, 0x87, 0x90, 0x01, 0xC7, 0x74, 0x21, 0xF0,
-0xED, 0x30, 0xE5, 0x13, 0x71, 0x87, 0x90, 0x01,
-0xC7, 0x74, 0x23, 0xF1, 0x3E, 0x7D, 0x10, 0x12,
-0x55, 0x36, 0x90, 0x95, 0xF1, 0xEF, 0xF0, 0x12,
-0xD9, 0x3F, 0x90, 0x95, 0xF3, 0xEE, 0x8F, 0xF0,
-0x12, 0x07, 0x0A, 0x90, 0x85, 0xB7, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x12, 0xD9, 0x36, 0xD3, 0x9F,
-0xEC, 0x9E, 0x40, 0x16, 0x90, 0x85, 0xB8, 0xE0,
-0x24, 0x01, 0xFF, 0x90, 0x85, 0xB7, 0xE0, 0x34,
-0x00, 0xFE, 0xC3, 0xED, 0x9F, 0xFF, 0xEC, 0x9E,
-0xF1, 0x9D, 0x90, 0x95, 0xF9, 0xE0, 0x24, 0x40,
-0x60, 0x04, 0x24, 0x20, 0x70, 0x2B, 0x90, 0x86,
-0x75, 0xE0, 0xFF, 0xF1, 0x8F, 0x20, 0xE0, 0x02,
-0x61, 0x00, 0x90, 0x86, 0x87, 0xE0, 0x04, 0x71,
-0x7C, 0x12, 0x59, 0x20, 0xEF, 0x70, 0x02, 0x61,
-0x00, 0x90, 0x95, 0xF9, 0xE0, 0xFF, 0x12, 0x7B,
-0x77, 0x90, 0x86, 0x88, 0xE0, 0x04, 0xF0, 0x61,
-0x00, 0x12, 0x97, 0xF5, 0x30, 0xE0, 0x5B, 0x90,
-0x95, 0xFC, 0xE0, 0xFF, 0x90, 0x95, 0xF8, 0xE0,
-0x2F, 0xFF, 0x90, 0x95, 0xF7, 0xE0, 0x34, 0x00,
-0xCF, 0x24, 0x08, 0xCF, 0x34, 0x00, 0xFE, 0x90,
-0x96, 0x02, 0x12, 0xD8, 0xE7, 0xEF, 0x64, 0x45,
-0x70, 0x38, 0x71, 0x8F, 0xF1, 0xB6, 0xEF, 0x64,
-0x01, 0x70, 0x2F, 0x71, 0x8F, 0xF1, 0x5E, 0xEF,
-0x64, 0x01, 0x70, 0x26, 0x90, 0x96, 0x06, 0x04,
-0xF0, 0x71, 0x8F, 0xA3, 0xE0, 0xFD, 0x12, 0xD4,
-0x13, 0xEF, 0x70, 0x0E, 0x90, 0x96, 0x04, 0xE0,
-0xFD, 0x90, 0xFD, 0x11, 0xF0, 0x71, 0x8F, 0x12,
-0xD3, 0xD8, 0x90, 0x96, 0x04, 0xE0, 0x90, 0xFD,
-0x11, 0xF0, 0x71, 0x7D, 0x12, 0x59, 0x20, 0xEF,
-0x60, 0x18, 0x71, 0x7D, 0x90, 0x95, 0xFC, 0xE0,
-0xFD, 0x90, 0x95, 0xFF, 0xE0, 0xFB, 0x12, 0x97,
-0xFF, 0xEF, 0x60, 0x06, 0x90, 0x96, 0x06, 0x74,
-0x01, 0xF0, 0x90, 0x86, 0x72, 0xE0, 0xC3, 0x13,
-0x30, 0xE0, 0x13, 0x71, 0x7D, 0x90, 0x95, 0xFC,
-0xE0, 0xFD, 0x12, 0xD2, 0x29, 0xEF, 0x60, 0x06,
-0x90, 0x96, 0x06, 0x74, 0x01, 0xF0, 0xF1, 0xF0,
-0x54, 0x3F, 0x30, 0xE0, 0x09, 0x71, 0x7D, 0x90,
-0x95, 0xFC, 0xE0, 0xFD, 0x71, 0x98, 0x90, 0x86,
-0x72, 0xE0, 0xFF, 0xF1, 0x8F, 0x30, 0xE0, 0x10,
-0x90, 0x96, 0x06, 0xE0, 0x70, 0x0A, 0x71, 0x7D,
-0x90, 0x95, 0xFC, 0xE0, 0xFD, 0x12, 0x4A, 0x3F,
-0x12, 0x79, 0x00, 0xBF, 0x01, 0x11, 0x12, 0xD9,
-0x2D, 0x30, 0xE0, 0x06, 0x90, 0x01, 0x3F, 0x74,
-0x04, 0xF0, 0x7F, 0x01, 0x12, 0x5F, 0xE9, 0x12,
-0x7A, 0xE7, 0xEF, 0x64, 0x01, 0x70, 0x36, 0x90,
-0x86, 0x89, 0xE0, 0x04, 0xF0, 0x12, 0x6F, 0xE5,
-0xAD, 0x07, 0xEF, 0x64, 0x01, 0x60, 0x1F, 0x71,
-0x87, 0xED, 0xB4, 0x02, 0x08, 0x90, 0x01, 0xC7,
-0x74, 0x42, 0xF0, 0x80, 0x0A, 0xED, 0xB4, 0x04,
-0x06, 0x90, 0x01, 0xC7, 0x74, 0x43, 0xF0, 0x7F,
-0x01, 0x12, 0x5F, 0xE9, 0x80, 0x1E, 0xF1, 0x3F,
-0x12, 0x7C, 0x0B, 0x80, 0x0F, 0x12, 0xD9, 0x2D,
-0x20, 0xE0, 0x11, 0x90, 0x86, 0x72, 0xE0, 0x54,
-0xFE, 0xF0, 0x80, 0x08, 0x90, 0x95, 0xFA, 0xE0,
-0x04, 0xF0, 0x01, 0xEA, 0x74, 0x9C, 0x04, 0x90,
-0x01, 0xC4, 0xF0, 0x74, 0x98, 0xA3, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90, 0x95, 0xF7,
-0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0xF0, 0x90,
-0x86, 0x7A, 0xE0, 0x44, 0x01, 0xF0, 0x22, 0x90,
-0x96, 0x02, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0x12, 0xD3, 0xCC, 0x78, 0x87, 0x7C, 0x92, 0x7D,
-0x01, 0x7B, 0xFF, 0x7A, 0x82, 0x79, 0x0E, 0x12,
-0xD3, 0xAA, 0x12, 0xD3, 0xC3, 0x7A, 0x82, 0x79,
-0x14, 0xF1, 0x96, 0x78, 0x9D, 0x7C, 0x92, 0x7D,
-0x01, 0x7B, 0xFF, 0x7A, 0x82, 0x79, 0x24, 0xF1,
-0x96, 0xE4, 0x90, 0x92, 0xB0, 0xF0, 0x11, 0x93,
-0xA3, 0xE0, 0xFD, 0x12, 0x74, 0x2C, 0xEF, 0x64,
-0x01, 0x60, 0x02, 0xA1, 0x5D, 0xF1, 0x13, 0xCF,
-0x24, 0x0E, 0xCF, 0x34, 0x00, 0xB1, 0x82, 0xEF,
-0x64, 0x3A, 0x60, 0x02, 0xA1, 0x5D, 0xF1, 0x13,
-0xCF, 0x24, 0x30, 0xCF, 0x34, 0x00, 0xB1, 0x82,
-0xEF, 0x64, 0x87, 0x60, 0x02, 0xA1, 0x5D, 0x90,
-0x92, 0xB0, 0x04, 0xF0, 0xE4, 0x90, 0x92, 0xAD,
-0xF0, 0xF1, 0x25, 0x94, 0x10, 0x50, 0x19, 0x12,
-0xD3, 0x9E, 0xF1, 0x1E, 0xCD, 0x24, 0x38, 0xB1,
-0x77, 0x90, 0x92, 0xAD, 0xE0, 0x24, 0x9D, 0xF5,
-0x82, 0xE4, 0x34, 0x92, 0xF1, 0x48, 0x80, 0xE1,
-0xE4, 0x90, 0x92, 0xAE, 0xF0, 0x90, 0x92, 0xAE,
-0xE0, 0xFF, 0xC3, 0x94, 0x02, 0x40, 0x02, 0xA1,
-0x5D, 0x75, 0xF0, 0x38, 0xEF, 0xF1, 0xA5, 0x20,
-0xE0, 0x02, 0xA1, 0x5D, 0xE4, 0x90, 0x92, 0xAF,
-0xF0, 0x12, 0xD9, 0x48, 0x90, 0x86, 0xAB, 0x12,
-0x05, 0x28, 0xE0, 0xFE, 0x90, 0x92, 0xAF, 0xE0,
-0xC3, 0x9E, 0x40, 0x02, 0xA1, 0x55, 0xEF, 0x75,
-0xF0, 0x38, 0xA4, 0x24, 0xC2, 0xF9, 0x74, 0x86,
-0x35, 0xF0, 0xFA, 0x7B, 0x01, 0xE0, 0x75, 0xF0,
-0x10, 0xA4, 0x29, 0xF9, 0xEA, 0x35, 0xF0, 0xFA,
-0x78, 0x9D, 0x7C, 0x92, 0x12, 0xD8, 0x82, 0x60,
-0x02, 0xA1, 0x46, 0x90, 0x06, 0x33, 0xE0, 0x44,
-0x01, 0x54, 0xFB, 0xF0, 0xE4, 0x90, 0x92, 0xAD,
-0xF0, 0xF1, 0x25, 0x94, 0x06, 0x50, 0x14, 0x12,
-0xD3, 0x9E, 0xF1, 0x1E, 0xCD, 0x24, 0x4A, 0xB1,
-0x77, 0x90, 0x92, 0xAD, 0x12, 0xD3, 0xBA, 0xF1,
-0x48, 0x80, 0xE6, 0xE4, 0x90, 0x92, 0xAD, 0xF0,
-0xF1, 0x25, 0x94, 0x10, 0x50, 0x0C, 0xB1, 0x63,
-0x90, 0x92, 0xAD, 0x12, 0xD3, 0xB1, 0xF1, 0x48,
-0x80, 0xEE, 0x12, 0xD9, 0x48, 0xF1, 0xA5, 0xFE,
-0xC3, 0x13, 0x30, 0xE0, 0x2C, 0xEF, 0x75, 0xF0,
-0x38, 0xA4, 0x24, 0xB2, 0xF9, 0x74, 0x86, 0x35,
-0xF0, 0xFA, 0x7B, 0x01, 0x78, 0x8D, 0x7C, 0x92,
-0x12, 0xD8, 0x82, 0x70, 0x70, 0x90, 0x88, 0xCC,
-0xE0, 0xB4, 0x02, 0x0B, 0x90, 0x86, 0x73, 0x12,
-0x96, 0x9D, 0x20, 0xE0, 0x1D, 0x80, 0x12, 0x80,
-0x19, 0x90, 0x88, 0xCC, 0xE0, 0xB4, 0x02, 0x12,
-0x90, 0x86, 0x73, 0x12, 0x96, 0x9D, 0x20, 0xE0,
-0x09, 0x90, 0x01, 0xC7, 0x74, 0x0A, 0x71, 0x86,
-0x80, 0x53, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x87,
-0x90, 0x8B, 0xE6, 0x12, 0x87, 0x75, 0x7A, 0x92,
-0x79, 0x9D, 0x90, 0x8B, 0xE9, 0x12, 0x87, 0x75,
-0x90, 0x92, 0xAE, 0xE0, 0x75, 0xF0, 0x38, 0xA4,
-0x24, 0xAC, 0xF9, 0x74, 0x86, 0x35, 0xF0, 0xFA,
-0x90, 0x8B, 0xEC, 0x12, 0x87, 0x75, 0xE4, 0x90,
-0x8B, 0xEF, 0xF0, 0xA3, 0xF0, 0x7A, 0x92, 0x79,
-0x8D, 0x12, 0x19, 0xBB, 0x80, 0x07, 0x90, 0x06,
-0x33, 0xE0, 0x44, 0x05, 0xF0, 0x90, 0x92, 0xAF,
-0xE0, 0x04, 0xF0, 0x81, 0x41, 0x90, 0x92, 0xAE,
-0xE0, 0x04, 0xF0, 0x81, 0x25, 0x90, 0x92, 0xB0,
-0xE0, 0xFF, 0x22, 0x90, 0x92, 0x86, 0xE0, 0xFD,
-0x90, 0x92, 0x85, 0xE0, 0x2D, 0xFD, 0x90, 0x92,
-0x84, 0xE0, 0x34, 0x00, 0xCD, 0x24, 0x10, 0xCD,
-0x34, 0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F, 0xFF,
-0xEE, 0x3C, 0xFE, 0xE4, 0xFD, 0x02, 0x55, 0x36,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x06, 0x31, 0xE0, 0x54, 0xEF, 0x44, 0x08, 0xF0,
-0xED, 0x2F, 0xFF, 0xE4, 0x3E, 0xFE, 0x7C, 0x00,
-0xEF, 0x24, 0x08, 0xFF, 0xEC, 0x3E, 0x90, 0x93,
-0x42, 0xF0, 0xA3, 0xEF, 0xF0, 0x7E, 0x00, 0x7F,
-0x83, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x87, 0x79,
-0x8C, 0x12, 0x06, 0xDE, 0x90, 0x93, 0x43, 0xE0,
-0x24, 0x01, 0xD1, 0xF2, 0xB1, 0x82, 0x90, 0x87,
-0x8D, 0xD1, 0xFA, 0x24, 0x04, 0xD1, 0xF2, 0xB1,
-0x82, 0x90, 0x87, 0x90, 0xD1, 0xFA, 0x24, 0x05,
-0xD1, 0xF2, 0xB1, 0x82, 0x90, 0x87, 0x91, 0xD1,
-0xFA, 0x24, 0x06, 0xD1, 0xF2, 0xB1, 0x82, 0x90,
-0x87, 0x92, 0xD1, 0xFA, 0x24, 0x07, 0xD1, 0xF2,
-0xB1, 0x82, 0x90, 0x87, 0x93, 0xD1, 0xFA, 0x24,
-0x08, 0xD1, 0xF2, 0xB1, 0x82, 0x90, 0x87, 0x94,
-0xEF, 0xF0, 0xE4, 0x90, 0x93, 0x41, 0xF0, 0xF1,
-0x0C, 0x94, 0x08, 0x50, 0x1C, 0x90, 0x93, 0x43,
-0xE0, 0x24, 0x09, 0xFD, 0x90, 0x93, 0x42, 0xE0,
-0xB1, 0x78, 0x90, 0x93, 0x41, 0xE0, 0x24, 0x95,
-0xF5, 0x82, 0xE4, 0x34, 0x87, 0xF1, 0x01, 0x80,
-0xDE, 0xE4, 0x90, 0x93, 0x41, 0xF0, 0xF1, 0x0C,
-0x94, 0x02, 0x50, 0x1C, 0x90, 0x93, 0x43, 0xE0,
-0x24, 0x61, 0xFD, 0x90, 0x93, 0x42, 0xE0, 0xB1,
-0x78, 0x90, 0x93, 0x41, 0xE0, 0x24, 0xED, 0xF5,
-0x82, 0xE4, 0x34, 0x87, 0xF1, 0x01, 0x80, 0xDE,
-0xE4, 0x90, 0x93, 0x41, 0xF0, 0xF1, 0x0C, 0x94,
-0x10, 0x50, 0x1C, 0x90, 0x93, 0x43, 0xE0, 0x24,
-0x31, 0xFD, 0x90, 0x93, 0x42, 0xE0, 0xB1, 0x78,
-0x90, 0x93, 0x41, 0xE0, 0x24, 0xBD, 0xF5, 0x82,
-0xE4, 0x34, 0x87, 0xF1, 0x01, 0x80, 0xDE, 0xE4,
-0x90, 0x93, 0x41, 0xF0, 0x90, 0x87, 0xEE, 0xE0,
-0xFF, 0x90, 0x93, 0x41, 0xE0, 0xFE, 0xC3, 0x9F,
-0x50, 0x1F, 0x90, 0x93, 0x43, 0xE0, 0x24, 0x63,
-0xFD, 0xD1, 0xF3, 0xFC, 0xEE, 0x7E, 0x00, 0x2D,
-0xB1, 0x7F, 0x90, 0x93, 0x41, 0xE0, 0x24, 0x3F,
-0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF1, 0x01, 0x80,
-0xD3, 0x90, 0x87, 0x91, 0x12, 0xD7, 0x14, 0x90,
-0x93, 0x3F, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x30,
-0xE3, 0x0D, 0x90, 0x01, 0xC7, 0x74, 0x03, 0xF0,
-0x7F, 0x01, 0x12, 0x5F, 0xE9, 0x80, 0x20, 0x7E,
-0x00, 0x90, 0x93, 0x40, 0xE0, 0x54, 0x07, 0xFF,
-0x64, 0x01, 0x60, 0x05, 0xEF, 0x64, 0x02, 0x70,
-0x0E, 0xE4, 0xFD, 0x12, 0x77, 0xB1, 0x90, 0x06,
-0x31, 0xE0, 0x54, 0xF7, 0x44, 0x10, 0xF0, 0x12,
-0xCE, 0x0C, 0xE4, 0xF0, 0xFF, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xFF, 0x90, 0x93, 0x42, 0xE0, 0x34,
-0x00, 0x22, 0xEF, 0xF0, 0x90, 0x93, 0x43, 0xE0,
-0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x93, 0x41,
-0xE0, 0x04, 0xF0, 0x22, 0x90, 0x93, 0x41, 0xE0,
-0xFF, 0xC3, 0x22, 0x90, 0x92, 0x86, 0xE0, 0xFF,
-0x90, 0x92, 0x85, 0xE0, 0x2F, 0xFF, 0x90, 0x92,
-0x84, 0xE0, 0x34, 0x00, 0x22, 0x90, 0x92, 0xAD,
-0xE0, 0xFF, 0xC3, 0x22, 0x24, 0x06, 0xFD, 0x12,
-0x55, 0x36, 0xEF, 0x22, 0x90, 0x86, 0x73, 0xE0,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x22, 0xF0, 0x90,
-0x95, 0xF3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x92, 0xAD, 0xE0,
-0x04, 0xF0, 0x22, 0x90, 0x92, 0x87, 0xE0, 0xFD,
-0x90, 0x92, 0x86, 0xE0, 0x2D, 0x22, 0xF1, 0xAD,
-0x24, 0x16, 0xFF, 0xE4, 0x3E, 0xB1, 0x82, 0x90,
-0x88, 0x86, 0xA3, 0xE0, 0xB5, 0x07, 0x1A, 0x90,
-0x92, 0x85, 0xE0, 0x24, 0x16, 0xF1, 0x1D, 0xFE,
-0x7D, 0x01, 0x12, 0x55, 0x36, 0xEF, 0xFD, 0x90,
-0x88, 0x86, 0xE0, 0x6D, 0x70, 0x01, 0xE4, 0x60,
-0x03, 0x7F, 0x00, 0x22, 0x7F, 0x01, 0x22, 0xC4,
-0x13, 0x13, 0x13, 0x54, 0x01, 0x22, 0x7E, 0x00,
-0x7F, 0x10, 0x02, 0x02, 0xD0, 0x90, 0x95, 0xF3,
-0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x90, 0x86, 0xAA,
-0x12, 0x05, 0x28, 0xE0, 0x22, 0x90, 0x92, 0x84,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xF1, 0xAD,
-0xE4, 0xA3, 0xF0, 0x90, 0x92, 0x86, 0xE0, 0xFD,
-0xC3, 0x94, 0x04, 0x50, 0x28, 0x90, 0x92, 0x85,
-0xE0, 0x24, 0x10, 0xF1, 0x1D, 0xFE, 0x12, 0x55,
-0x36, 0x90, 0x92, 0x86, 0xE0, 0x24, 0x82, 0xF5,
-0x82, 0xE4, 0x34, 0x88, 0xF5, 0x83, 0xE0, 0x6F,
-0x60, 0x03, 0x7F, 0x00, 0x22, 0x90, 0x92, 0x86,
-0xE0, 0x04, 0xF0, 0x80, 0xCE, 0x7F, 0x01, 0x22,
-0x90, 0x86, 0x72, 0xE0, 0x13, 0x13, 0x22, 0x12,
-0xD8, 0xF9, 0x90, 0x94, 0xF3, 0xE0, 0x70, 0x0C,
-0x12, 0xD9, 0x7F, 0x30, 0xE0, 0x06, 0x90, 0x94,
-0xF9, 0x74, 0x01, 0xF0, 0x90, 0x94, 0xF5, 0xE0,
-0x70, 0x0F, 0x12, 0x8E, 0x99, 0x12, 0xD9, 0x9F,
-0xBF, 0x05, 0x06, 0x90, 0x94, 0xFA, 0x74, 0x01,
-0xF0, 0x12, 0x8E, 0x99, 0x12, 0xBD, 0x77, 0xF5,
-0x11, 0x12, 0x02, 0xF6, 0xFE, 0xC3, 0x13, 0x30,
-0xE0, 0x07, 0x12, 0x8D, 0xC3, 0xF5, 0x12, 0x80,
-0x02, 0x8F, 0x12, 0x85, 0x11, 0x10, 0xE5, 0x10,
-0xD3, 0x95, 0x12, 0x50, 0x2C, 0x12, 0x8E, 0x99,
-0x12, 0x02, 0xF6, 0x54, 0x01, 0xFD, 0xAF, 0x10,
-0x12, 0x6E, 0x5F, 0xAF, 0x10, 0x12, 0x77, 0x39,
-0xEF, 0xAF, 0x10, 0x70, 0x04, 0x11, 0x8C, 0x80,
-0x02, 0xF1, 0xE7, 0x90, 0x94, 0xFA, 0xE0, 0x60,
-0x04, 0xAF, 0x10, 0x11, 0x8C, 0x05, 0x10, 0x80,
-0xCD, 0xE5, 0x11, 0x70, 0x16, 0xFF, 0x12, 0x77,
-0x39, 0xEF, 0x70, 0x0F, 0x12, 0xAE, 0xE5, 0x12,
-0x79, 0x61, 0x12, 0xC7, 0xD7, 0x54, 0xBF, 0xF0,
-0x54, 0x7F, 0xF0, 0x22, 0x7D, 0x01, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x92, 0x07,
-0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0x7D, 0x44, 0x7F,
-0x6F, 0x11, 0xD8, 0x71, 0xB7, 0x90, 0x92, 0x08,
-0xE0, 0x90, 0x92, 0x07, 0xB4, 0x01, 0x07, 0x11,
-0xC3, 0x44, 0x04, 0xF0, 0x80, 0x05, 0x11, 0xC3,
-0x54, 0xFB, 0xF0, 0x12, 0x97, 0xD0, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xE0, 0xC4, 0x54, 0xF0, 0x24,
-0x05, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
-0xE0, 0x22, 0x12, 0xAE, 0xE5, 0xE4, 0xFD, 0xFF,
-0x90, 0x05, 0x22, 0xEF, 0xF0, 0x90, 0x94, 0xBC,
-0xED, 0xF0, 0x22, 0x90, 0x92, 0xDE, 0x12, 0x87,
-0x75, 0x90, 0x92, 0xE1, 0xED, 0xF0, 0x90, 0x84,
-0xBF, 0xA3, 0xE0, 0x24, 0x63, 0xF9, 0xE4, 0x34,
-0x82, 0x71, 0xA4, 0x75, 0x1E, 0x06, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0x0E, 0x12, 0x6A, 0x21, 0x90,
-0x84, 0xBF, 0xA3, 0xE0, 0x24, 0x69, 0xF9, 0xE4,
-0x34, 0x82, 0x71, 0xA4, 0x75, 0x1E, 0x10, 0x7B,
-0x01, 0x7A, 0x93, 0x79, 0x14, 0x12, 0x6A, 0x21,
-0x12, 0xD8, 0x4D, 0x71, 0xA4, 0x75, 0x1E, 0x06,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x24, 0x12, 0xCE,
-0x09, 0xE0, 0x90, 0x93, 0x2A, 0xF0, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x92, 0xE5, 0xF0, 0x90, 0x04,
-0x1D, 0xE0, 0x60, 0x09, 0x7D, 0x39, 0x71, 0xB3,
-0xBF, 0x01, 0x10, 0x80, 0x00, 0x90, 0x88, 0xD0,
-0x12, 0xD8, 0xF0, 0x90, 0x92, 0xE2, 0xEE, 0xF0,
-0xA3, 0xEF, 0xF0, 0x90, 0x92, 0xE2, 0x12, 0xD7,
-0x1C, 0x90, 0x92, 0xE4, 0xEF, 0xF0, 0x90, 0x92,
-0xE2, 0xF1, 0xC7, 0x90, 0x93, 0x2A, 0xE0, 0xFD,
-0x12, 0x52, 0x21, 0x90, 0x92, 0xE1, 0xE0, 0x70,
-0x64, 0xF1, 0x8C, 0xC0, 0x03, 0x8B, 0x1B, 0x75,
-0x1C, 0x93, 0x75, 0x1D, 0x0E, 0x75, 0x1E, 0x06,
-0xD0, 0x03, 0x51, 0x90, 0xF1, 0xBD, 0xC0, 0x03,
-0xC0, 0x02, 0xC0, 0x01, 0x90, 0x92, 0xDE, 0x12,
-0xB9, 0x19, 0x75, 0x1E, 0x10, 0xD0, 0x01, 0xD0,
-0x02, 0xD0, 0x03, 0x51, 0x90, 0xF1, 0x8F, 0xC0,
-0x03, 0x12, 0xD8, 0x41, 0xD0, 0x03, 0x51, 0x90,
-0x24, 0x60, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B,
-0x01, 0xC0, 0x03, 0x12, 0xD8, 0x41, 0xD0, 0x03,
-0x51, 0x90, 0x24, 0x72, 0xF9, 0xE4, 0x34, 0xFC,
-0xFA, 0x7B, 0x01, 0xC0, 0x03, 0x8B, 0x1B, 0x75,
-0x1C, 0x93, 0x75, 0x1D, 0x24, 0x75, 0x1E, 0x06,
-0xD0, 0x03, 0x12, 0x6A, 0x21, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x14, 0x90, 0x8C, 0x20, 0x12, 0x87,
-0x75, 0x90, 0x8C, 0x23, 0x12, 0x04, 0xF7, 0x00,
-0x00, 0x00, 0x20, 0x90, 0x8C, 0x27, 0x74, 0x3A,
-0xF0, 0x90, 0x92, 0xDE, 0x12, 0x87, 0x6C, 0x12,
-0x70, 0x23, 0x51, 0x93, 0x24, 0x30, 0xF9, 0xE4,
-0x34, 0xFC, 0x71, 0xA4, 0x75, 0x1E, 0x28, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0xE6, 0x51, 0x90, 0x12,
-0xD8, 0xAB, 0xC0, 0x03, 0x8B, 0x1B, 0x75, 0x1C,
-0x87, 0x75, 0x1D, 0x1A, 0x75, 0x1E, 0x28, 0xD0,
-0x03, 0x12, 0x6A, 0x21, 0x90, 0x92, 0xE4, 0xE0,
-0xFF, 0x90, 0x92, 0xE3, 0xE0, 0x2F, 0xFF, 0x90,
-0x92, 0xE2, 0xE0, 0x34, 0x00, 0xCF, 0x24, 0x30,
-0xFD, 0xE4, 0x3F, 0xFC, 0x90, 0x88, 0xD0, 0xE0,
-0xFB, 0x7F, 0x3A, 0x12, 0x15, 0x44, 0x51, 0x93,
-0x12, 0xD8, 0xAB, 0xC0, 0x03, 0x8B, 0x1B, 0x75,
-0x1C, 0x92, 0x75, 0x1D, 0xE6, 0x75, 0x1E, 0x28,
-0xD0, 0x03, 0x12, 0x6A, 0x21, 0x90, 0x88, 0xCC,
-0xE0, 0xB4, 0x02, 0x0D, 0x90, 0x88, 0xD0, 0xE0,
-0xFF, 0x90, 0x92, 0xE4, 0xE0, 0xFD, 0x12, 0xBB,
-0xDA, 0x90, 0x06, 0x33, 0xE0, 0x44, 0x02, 0xF0,
-0x90, 0x92, 0xE5, 0xE0, 0xFF, 0x7D, 0x3A, 0x11,
-0xD8, 0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0, 0x22,
-0x12, 0x6A, 0x21, 0x90, 0x92, 0xE2, 0xA3, 0xE0,
-0xFF, 0xA3, 0xE0, 0x2F, 0x22, 0x90, 0x92, 0xC0,
-0x12, 0x87, 0x75, 0x90, 0x92, 0xC3, 0xED, 0xF0,
-0x12, 0xD8, 0x4D, 0x71, 0xA4, 0x75, 0x1E, 0x06,
-0x7B, 0x01, 0x7A, 0x92, 0x79, 0xC9, 0x12, 0xCE,
-0x09, 0xE0, 0x90, 0x92, 0xC8, 0xF0, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x92, 0xC7, 0xF0, 0x90, 0x04,
-0x1D, 0xE0, 0x60, 0x09, 0x7D, 0x33, 0x71, 0xB3,
-0xBF, 0x01, 0x10, 0x80, 0x00, 0x90, 0x88, 0xCF,
-0x12, 0xD8, 0xF0, 0x90, 0x92, 0xC4, 0xEE, 0xF0,
-0xA3, 0xEF, 0xF0, 0x90, 0x92, 0xC4, 0x12, 0xD7,
-0x1C, 0x90, 0x92, 0xC6, 0xEF, 0xF0, 0x90, 0x92,
-0xC4, 0xF1, 0xC7, 0x90, 0x92, 0xC8, 0xE0, 0xFD,
-0x12, 0x52, 0x21, 0x90, 0x92, 0xC3, 0xE0, 0x70,
-0x32, 0xF1, 0x8C, 0xC0, 0x03, 0x12, 0xD8, 0x59,
-0xD0, 0x03, 0x71, 0xAC, 0x51, 0x96, 0x12, 0xD8,
-0xB5, 0xC0, 0x03, 0x12, 0xD8, 0x59, 0xD0, 0x03,
-0x71, 0xAC, 0x51, 0x96, 0xF1, 0xBD, 0xC0, 0x03,
-0xC0, 0x02, 0xC0, 0x01, 0x90, 0x92, 0xC0, 0x12,
-0xB9, 0x19, 0x75, 0x1E, 0x04, 0xD0, 0x01, 0xD0,
-0x02, 0x80, 0x42, 0x90, 0x92, 0xC3, 0xE0, 0x64,
-0x01, 0x70, 0x3F, 0xF1, 0x8C, 0xC0, 0x03, 0x8B,
-0x1B, 0x75, 0x1C, 0x86, 0x75, 0x1D, 0x96, 0x75,
-0x1E, 0x06, 0xD0, 0x03, 0x71, 0xAC, 0x51, 0x96,
-0x12, 0xD8, 0xB5, 0xC0, 0x03, 0x8B, 0x1B, 0x75,
-0x1C, 0x86, 0x75, 0x1D, 0xA0, 0x75, 0x1E, 0x06,
-0xD0, 0x03, 0x71, 0xAC, 0x51, 0x96, 0xF1, 0xBD,
-0xC0, 0x03, 0x8B, 0x1B, 0x75, 0x1C, 0x86, 0x75,
-0x1D, 0xA6, 0x75, 0x1E, 0x04, 0xD0, 0x03, 0x12,
-0x6A, 0x21, 0x90, 0x88, 0xCC, 0xE0, 0xB4, 0x02,
-0x0D, 0x90, 0x88, 0xCF, 0xE0, 0xFF, 0x90, 0x92,
-0xC6, 0xE0, 0xFD, 0x12, 0xBB, 0xDA, 0x90, 0x06,
-0x30, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x92, 0xC7,
-0xE0, 0xFF, 0x7D, 0x34, 0x41, 0x87, 0x24, 0x00,
-0xF9, 0xE4, 0x34, 0xFC, 0x75, 0x1B, 0x01, 0xF5,
-0x1C, 0x89, 0x1D, 0x22, 0x12, 0x6A, 0x21, 0x90,
-0x92, 0xC4, 0x22, 0x7F, 0xFF, 0x11, 0xD8, 0xE4,
-0x90, 0x96, 0x54, 0xF0, 0xA3, 0xF0, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x96, 0x56, 0xF0, 0x7D, 0x47,
-0x7F, 0xFF, 0x11, 0xD8, 0x90, 0x05, 0xF8, 0xE0,
-0x70, 0x11, 0xA3, 0xE0, 0x70, 0x0D, 0xA3, 0xE0,
-0x70, 0x09, 0xA3, 0xE0, 0x70, 0x05, 0xF1, 0x83,
-0x7F, 0x01, 0x22, 0xD3, 0x90, 0x96, 0x55, 0xE0,
-0x94, 0xE8, 0x90, 0x96, 0x54, 0xE0, 0x94, 0x03,
-0x40, 0x0C, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x20,
-0xF0, 0xF1, 0x83, 0x7F, 0x00, 0x22, 0x7F, 0x32,
-0x7E, 0x00, 0x12, 0x7C, 0x9F, 0x90, 0x96, 0x54,
-0x12, 0xB6, 0xB2, 0x80, 0xBF, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x93, 0xFD, 0x12,
-0xD3, 0xCF, 0x90, 0x94, 0x15, 0x74, 0x18, 0xF0,
-0x7E, 0x00, 0x7F, 0x80, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x94, 0x79, 0x1D, 0x12, 0x06, 0xDE, 0x90,
-0x01, 0xC4, 0x74, 0x20, 0xF0, 0x74, 0x07, 0xA3,
-0xF0, 0x90, 0x88, 0xD1, 0xE0, 0xFF, 0x12, 0x7B,
-0x2A, 0x90, 0x94, 0x14, 0xEF, 0xF0, 0xF9, 0xE0,
-0xFE, 0x24, 0x29, 0x12, 0xBD, 0x7F, 0x74, 0x41,
-0xF0, 0xEE, 0x24, 0x28, 0xFD, 0xE4, 0x33, 0xFC,
-0x90, 0x94, 0x15, 0xE0, 0x7A, 0x00, 0x2D, 0xFE,
-0xEA, 0x3C, 0x90, 0x94, 0x19, 0xF0, 0xA3, 0xCE,
-0xF0, 0x74, 0x28, 0x29, 0xF1, 0xCB, 0x90, 0x93,
-0xFF, 0xE0, 0xFD, 0x12, 0x52, 0x21, 0xF1, 0xD3,
-0x90, 0x94, 0x19, 0xE0, 0xFF, 0xA3, 0xE0, 0x90,
-0x94, 0x17, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
-0x94, 0x1D, 0x74, 0x01, 0xF0, 0xA3, 0x74, 0x03,
-0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0x74, 0x5F, 0xF0,
-0x90, 0x94, 0x19, 0xE4, 0x75, 0xF0, 0x04, 0x12,
-0x07, 0x0A, 0x90, 0x87, 0x90, 0xE0, 0xFF, 0x7E,
-0x02, 0xB4, 0xFE, 0x02, 0x7E, 0xFE, 0x90, 0x94,
-0x19, 0xA3, 0xE0, 0xFD, 0x24, 0x00, 0xF1, 0x33,
-0xEE, 0xF0, 0xF1, 0x30, 0xE0, 0x90, 0x94, 0x21,
-0xF0, 0x90, 0x94, 0x19, 0x12, 0xB6, 0xB2, 0x90,
-0x88, 0x25, 0xE0, 0x90, 0x93, 0xFD, 0xB4, 0x01,
-0x0B, 0xE0, 0x44, 0x03, 0xFC, 0xA3, 0xE0, 0x44,
-0x10, 0xFD, 0x80, 0x09, 0xE0, 0x44, 0x03, 0xFC,
-0xA3, 0xE0, 0x44, 0x20, 0xFD, 0x90, 0x94, 0x1B,
-0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x93, 0xFD,
-0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01, 0x90,
-0x94, 0x19, 0x70, 0x19, 0xA3, 0xE0, 0xFE, 0x24,
-0x00, 0xF1, 0x33, 0x12, 0xBB, 0xCC, 0x74, 0x01,
-0xF0, 0x90, 0x94, 0x22, 0x74, 0x03, 0xF0, 0xA3,
-0x74, 0x01, 0xF0, 0x80, 0x15, 0xA3, 0xE0, 0xFE,
-0x24, 0x00, 0xF1, 0x33, 0x12, 0xBB, 0xCC, 0x74,
-0x02, 0xF0, 0x90, 0x94, 0x22, 0x04, 0xF0, 0xA3,
-0x14, 0xF0, 0x12, 0xD8, 0x78, 0xEF, 0x64, 0xFE,
-0x90, 0x94, 0x19, 0x70, 0x21, 0xA3, 0xE0, 0x24,
-0x00, 0x12, 0xD5, 0x34, 0xC0, 0x03, 0x8B, 0x1B,
-0x12, 0xD8, 0xC9, 0xD0, 0x03, 0x12, 0xB7, 0xBB,
-0x12, 0xD8, 0xC9, 0x7B, 0x01, 0x7A, 0x94, 0x79,
-0x24, 0x12, 0x6A, 0x21, 0x80, 0x22, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x24, 0x00, 0xF5, 0x82, 0x74,
-0xFC, 0x3E, 0xF5, 0x83, 0xE4, 0xF0, 0x74, 0x01,
-0x2F, 0xF5, 0x82, 0x74, 0xFC, 0x3E, 0xF5, 0x83,
-0xE4, 0xF0, 0x90, 0x94, 0x24, 0xF0, 0xA3, 0xF0,
-0x12, 0xD8, 0x78, 0xE4, 0x90, 0x94, 0x16, 0xF0,
-0x12, 0xD7, 0xF1, 0xFE, 0x90, 0x94, 0x19, 0xA3,
-0xE0, 0xFD, 0xEF, 0x2D, 0x24, 0x00, 0xF1, 0x33,
-0xEE, 0xF0, 0x12, 0xD7, 0xF1, 0xFE, 0x74, 0x26,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0xEE, 0xF1, 0xB5, 0xE0, 0xB4, 0x08, 0xD9, 0xF1,
-0xDD, 0x90, 0x94, 0x19, 0xE4, 0x75, 0xF0, 0x20,
-0x12, 0x07, 0x0A, 0x90, 0x94, 0x19, 0xE4, 0x75,
-0xF0, 0x10, 0x12, 0x07, 0x0A, 0xF1, 0xD3, 0xE4,
-0x90, 0x94, 0xA0, 0xF0, 0xE4, 0x90, 0x94, 0x16,
-0xF0, 0x12, 0xD9, 0x24, 0x50, 0x12, 0x12, 0xD7,
-0xD3, 0xF1, 0xAE, 0x12, 0xD8, 0xBF, 0xE0, 0x24,
-0x00, 0xF1, 0x33, 0xE4, 0xF1, 0xB5, 0x80, 0xE9,
-0x12, 0xD2, 0x22, 0x90, 0x06, 0x31, 0xE0, 0x54,
-0xFB, 0xF0, 0x90, 0x88, 0xD2, 0x12, 0xBD, 0x2B,
-0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0x12,
-0xBD, 0x21, 0xED, 0xFF, 0x90, 0x88, 0xD1, 0x12,
-0xBD, 0x36, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
-0xF9, 0xFF, 0x90, 0x94, 0x15, 0xE0, 0x7C, 0x00,
-0x2F, 0xFF, 0xEC, 0x3E, 0xCF, 0x24, 0x38, 0xCF,
-0x34, 0x00, 0xFE, 0x90, 0x8A, 0xEC, 0x74, 0x10,
-0xF0, 0x7B, 0x63, 0xE4, 0xFD, 0x12, 0x72, 0x06,
-0x90, 0x93, 0xFD, 0xE0, 0x70, 0x04, 0xA3, 0xE0,
-0x64, 0x01, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x1D,
-0x70, 0x17, 0x90, 0x8B, 0x1C, 0x12, 0xD9, 0x77,
-0x90, 0x8B, 0x1F, 0x12, 0x87, 0x75, 0x90, 0x8B,
-0x22, 0x12, 0xD9, 0x6F, 0x12, 0x6E, 0xE1, 0x80,
-0x15, 0x90, 0x8B, 0x12, 0x12, 0xD9, 0x77, 0x90,
-0x8B, 0x15, 0x12, 0x87, 0x75, 0x90, 0x8B, 0x18,
-0x12, 0xD9, 0x6F, 0x12, 0x6E, 0xA0, 0x90, 0x94,
-0xA0, 0xE0, 0x04, 0xF0, 0x90, 0x06, 0x31, 0xE0,
-0x30, 0xE2, 0x07, 0x12, 0xD9, 0x67, 0x50, 0x02,
-0xA1, 0xC4, 0x12, 0xD9, 0x67, 0x40, 0x0A, 0x90,
-0x06, 0x35, 0xE0, 0x44, 0x20, 0x90, 0x06, 0x34,
-0xF0, 0xE4, 0x90, 0x94, 0x16, 0xF0, 0x12, 0xD9,
-0x24, 0x50, 0x24, 0x12, 0xD7, 0xD3, 0xF1, 0xAE,
-0x12, 0xD8, 0xBF, 0x90, 0x94, 0x16, 0xE0, 0x24,
-0x00, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0xE0, 0xFF, 0x90, 0x94, 0x14, 0xE0, 0x24, 0x00,
-0xF1, 0x33, 0xEF, 0xF1, 0xB5, 0x80, 0xD7, 0x90,
-0x93, 0xFD, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64,
-0x01, 0x70, 0x0F, 0x90, 0x88, 0xD1, 0xE0, 0xFF,
-0x90, 0x94, 0x15, 0xE0, 0x24, 0x08, 0xFD, 0x12,
-0xBB, 0xDA, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x20,
-0x90, 0x05, 0x22, 0xE0, 0x90, 0x94, 0x9F, 0xF0,
-0x7D, 0x1D, 0x71, 0xB3, 0xBF, 0x01, 0x06, 0xF1,
-0x99, 0x90, 0x04, 0x25, 0xF0, 0x90, 0x94, 0x9F,
-0xE0, 0xFF, 0x7D, 0x1E, 0x11, 0xD8, 0x80, 0x06,
-0xF1, 0x99, 0x90, 0x04, 0x25, 0xF0, 0x90, 0x85,
-0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79,
-0x80, 0x7F, 0x28, 0x7E, 0x00, 0x12, 0x7C, 0x9F,
-0x51, 0x89, 0x74, 0x20, 0x04, 0x90, 0x01, 0xC4,
-0xF0, 0x74, 0x07, 0xA3, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xF0, 0xE0, 0xFD, 0x24, 0x01, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFE,
-0x74, 0x00, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
-0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x96, 0x42, 0xEF, 0xF0, 0xA3,
-0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x04, 0x1D,
-0xE0, 0x60, 0x1D, 0x90, 0x05, 0x22, 0xE0, 0x90,
-0x96, 0x47, 0xF0, 0x7D, 0x36, 0x71, 0xB3, 0xBF,
-0x01, 0x03, 0x12, 0xD7, 0x9F, 0x90, 0x96, 0x47,
-0xE0, 0xFF, 0x7D, 0x37, 0x11, 0xD8, 0x80, 0x03,
-0x12, 0xD7, 0x9F, 0x90, 0x05, 0x22, 0xE0, 0x54,
-0x6F, 0xFF, 0x7D, 0x38, 0x51, 0x87, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x96, 0x56, 0xE0, 0xFF,
-0x7D, 0x48, 0x01, 0xD8, 0xA3, 0xA3, 0xE0, 0x24,
-0x38, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01,
-0x22, 0x90, 0x88, 0xD1, 0xE0, 0xFF, 0x90, 0x96,
-0x4F, 0x74, 0x08, 0xF0, 0x7B, 0x18, 0x7D, 0x01,
-0x12, 0xBD, 0x87, 0x90, 0x94, 0x14, 0xEF, 0xF0,
-0x90, 0x88, 0xD1, 0xE0, 0x22, 0xF0, 0x90, 0x94,
-0x16, 0xE0, 0x04, 0xF0, 0x22, 0x24, 0x48, 0xF9,
-0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0x22, 0xA3,
-0xE0, 0x24, 0x28, 0xF9, 0xE4, 0x34, 0xFC, 0xFA,
-0x7B, 0x01, 0x22, 0x90, 0x94, 0x19, 0xE4, 0x75,
-0xF0, 0x08, 0x12, 0x07, 0x0A, 0x90, 0x94, 0x19,
-0xE4, 0x75, 0xF0, 0x08, 0x02, 0x07, 0x0A, 0xE4,
-0xFD, 0x01, 0x8E, 0x7D, 0x1F, 0x7F, 0x6F, 0x11,
-0xD8, 0x90, 0x05, 0x27, 0xE0, 0x54, 0xBF, 0xF0,
-0x90, 0x85, 0xBF, 0x74, 0x04, 0xF0, 0x22, 0x90,
-0x92, 0x07, 0x12, 0x87, 0x75, 0x90, 0x04, 0x24,
-0xE0, 0xF5, 0x0D, 0xE4, 0xFF, 0x12, 0x8A, 0xB8,
-0x8F, 0x82, 0x75, 0x83, 0x00, 0x12, 0x03, 0x0F,
-0x25, 0x0D, 0xFE, 0xEF, 0x75, 0xF0, 0x0E, 0xA4,
-0x24, 0xD4, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0xEE, 0xF0, 0x0F, 0xEF, 0xB4, 0x03, 0xDD,
-0x22, 0x12, 0x02, 0xF6, 0xFF, 0x90, 0x94, 0xBE,
-0xF0, 0xBF, 0x01, 0x07, 0x11, 0x44, 0xE4, 0x90,
-0x94, 0xBE, 0xF0, 0x22, 0x11, 0xF4, 0x7F, 0xEF,
-0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x06,
-0x90, 0x92, 0x07, 0xE0, 0xA3, 0xF0, 0x11, 0xF4,
-0x7F, 0xEE, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
-0x01, 0x08, 0x90, 0x92, 0x07, 0xE0, 0x90, 0x92,
-0x09, 0xF0, 0x11, 0xF4, 0x7F, 0xED, 0x7E, 0x00,
-0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x92,
-0x07, 0xE0, 0x90, 0x92, 0x0A, 0xF0, 0x11, 0xF4,
-0x7F, 0xEC, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
-0x01, 0x08, 0x90, 0x92, 0x07, 0xE0, 0x90, 0x92,
-0x0B, 0xF0, 0x11, 0xF4, 0x7F, 0xEB, 0x7E, 0x00,
-0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x92,
-0x07, 0xE0, 0x90, 0x92, 0x0C, 0xF0, 0x90, 0x92,
-0x08, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0xA3, 0xE0,
-0xFB, 0xA3, 0xE0, 0x90, 0x92, 0x10, 0xF0, 0x90,
-0x92, 0x0C, 0xE0, 0x90, 0x92, 0x11, 0xF0, 0x90,
-0x92, 0x12, 0x74, 0x12, 0xF0, 0x90, 0x92, 0x20,
-0x74, 0x05, 0xF0, 0x90, 0x92, 0x14, 0xEF, 0xF0,
-0xA3, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x92,
-0x10, 0xE0, 0x90, 0x92, 0x17, 0xF0, 0x90, 0x92,
-0x11, 0xE0, 0x90, 0x92, 0x18, 0xF0, 0x7B, 0x01,
-0x7A, 0x92, 0x79, 0x12, 0x12, 0x5E, 0x10, 0x7F,
-0x04, 0x02, 0x87, 0xBC, 0x7B, 0x01, 0x7A, 0x92,
-0x79, 0x07, 0x22, 0x12, 0x02, 0xF6, 0x64, 0x01,
-0x60, 0x02, 0x21, 0x88, 0x90, 0x92, 0x26, 0xF0,
-0x90, 0x92, 0x26, 0xE0, 0xFF, 0xC3, 0x94, 0x10,
-0x50, 0x27, 0xEF, 0x31, 0x89, 0x7A, 0x92, 0x79,
-0x25, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x12, 0x90,
-0x92, 0x25, 0xE0, 0xFF, 0xA3, 0xE0, 0x24, 0x27,
-0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xEF,
-0xF0, 0x90, 0x92, 0x26, 0xE0, 0x04, 0xF0, 0x80,
-0xCF, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x92, 0x75,
-0x1D, 0x27, 0x75, 0x1E, 0x08, 0x7B, 0x01, 0x7A,
-0x92, 0x79, 0x09, 0x12, 0x6A, 0x21, 0x90, 0x92,
-0x07, 0x74, 0x24, 0xF0, 0x90, 0x92, 0x15, 0x74,
-0x08, 0xF0, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x92,
-0x75, 0x1D, 0x2F, 0xF5, 0x1E, 0x7B, 0x01, 0x7A,
-0x92, 0x79, 0x18, 0x12, 0x6A, 0x21, 0x90, 0x92,
-0x16, 0x74, 0x25, 0xF0, 0x90, 0x92, 0x24, 0x74,
-0x08, 0xF0, 0x11, 0xF4, 0x12, 0x5E, 0x10, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x16, 0x12, 0x87, 0xB7,
-0x22, 0x24, 0xDE, 0xFF, 0xE4, 0x33, 0xFE, 0x7B,
-0x01, 0x22, 0x51, 0xC3, 0x64, 0x01, 0x60, 0x02,
-0x41, 0x20, 0xEF, 0x24, 0x39, 0x60, 0x12, 0x14,
-0x60, 0x19, 0x24, 0x02, 0x70, 0x1F, 0xE4, 0x90,
-0x92, 0x0D, 0xF0, 0xA3, 0x74, 0x06, 0xF0, 0x80,
-0x14, 0x90, 0x92, 0x0D, 0x74, 0x06, 0xF0, 0xA3,
-0xF0, 0x80, 0x0A, 0x90, 0x92, 0x0D, 0x74, 0x0C,
-0xF0, 0xA3, 0x74, 0x04, 0xF0, 0x51, 0x34, 0xF0,
-0x51, 0x21, 0x40, 0x1B, 0x90, 0x92, 0x0B, 0xE0,
-0x31, 0x89, 0x7A, 0x92, 0x79, 0x0A, 0x12, 0x64,
-0x37, 0xBF, 0x01, 0x07, 0x90, 0x92, 0x0A, 0xE0,
-0xF4, 0x70, 0x3D, 0x51, 0x29, 0x80, 0xE1, 0x51,
-0x34, 0xF0, 0x51, 0x21, 0x40, 0x32, 0x90, 0x92,
-0x0B, 0xE0, 0xFD, 0x7C, 0x00, 0x24, 0xDE, 0xFF,
-0xEC, 0x33, 0xFE, 0xED, 0x24, 0x01, 0xFD, 0xEC,
-0x33, 0xFC, 0x90, 0x92, 0x0D, 0xE0, 0xFB, 0xC3,
-0xED, 0x9B, 0xFD, 0xEC, 0x94, 0x00, 0xFC, 0x12,
-0x8A, 0xB8, 0x8D, 0x82, 0x8C, 0x83, 0x12, 0x03,
-0x0F, 0xFD, 0x51, 0x44, 0x51, 0x29, 0x80, 0xCA,
-0x22, 0x90, 0x92, 0x0C, 0xE0, 0xD3, 0x94, 0x00,
-0x22, 0x90, 0x92, 0x0B, 0xE0, 0x04, 0xF0, 0xA3,
-0xE0, 0x14, 0xF0, 0x22, 0x90, 0x92, 0x0D, 0xE0,
-0x90, 0x92, 0x0B, 0xF0, 0x90, 0x92, 0x0E, 0xE0,
-0x90, 0x92, 0x0C, 0x22, 0x8E, 0x0D, 0x8F, 0x0E,
-0x8D, 0x0F, 0xE4, 0x90, 0x92, 0x0F, 0xF0, 0x90,
-0x00, 0x37, 0xE0, 0x44, 0x80, 0xFD, 0x7F, 0x37,
-0x12, 0x7B, 0x3E, 0x7D, 0x69, 0x7F, 0xCF, 0x12,
-0x7B, 0x3E, 0xE5, 0x0E, 0xFD, 0x7F, 0x31, 0x12,
-0x7B, 0x3E, 0xE5, 0x0D, 0x54, 0x03, 0xFF, 0x90,
-0x00, 0x32, 0xE0, 0x54, 0xFC, 0x4F, 0xFD, 0x7F,
-0x32, 0x12, 0x7B, 0x3E, 0xAD, 0x0F, 0x7F, 0x30,
-0x12, 0x7B, 0x3E, 0x90, 0x00, 0x33, 0xE0, 0x44,
-0x80, 0xFD, 0x7F, 0x33, 0x12, 0x7B, 0x3E, 0x90,
-0x00, 0x33, 0xE0, 0x30, 0xE7, 0x09, 0x51, 0xBB,
-0x50, 0x05, 0xE0, 0x04, 0xF0, 0x80, 0xF0, 0xE4,
-0xFD, 0x7F, 0xCF, 0x12, 0x7B, 0x3E, 0x90, 0x00,
-0x37, 0xE0, 0x54, 0x7F, 0xFD, 0x7F, 0x37, 0x12,
-0x7B, 0x3E, 0x51, 0xBB, 0x7F, 0x00, 0x50, 0x02,
-0x7F, 0x01, 0x22, 0x90, 0x92, 0x0F, 0xE0, 0xC3,
-0x94, 0x64, 0x22, 0x90, 0x92, 0x07, 0x12, 0x87,
-0x75, 0x02, 0x02, 0xF6, 0x12, 0x02, 0xF6, 0x54,
-0x01, 0xFF, 0x90, 0x94, 0xFE, 0xE0, 0x54, 0xFE,
-0x4F, 0xF0, 0x22, 0x12, 0x02, 0xF6, 0x90, 0x86,
-0x71, 0xF0, 0x22, 0x12, 0xD8, 0x27, 0x90, 0x94,
-0xBF, 0x12, 0xBD, 0x70, 0xEF, 0x54, 0x02, 0xFF,
-0xEE, 0x54, 0xFD, 0x4F, 0xF0, 0x90, 0x00, 0x01,
-0x12, 0x03, 0x0F, 0x90, 0x94, 0xC0, 0x12, 0x8D,
-0xC2, 0x90, 0x94, 0xC1, 0xF0, 0x91, 0xBC, 0x90,
-0x94, 0xBF, 0xE0, 0x54, 0x01, 0xFF, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xEF, 0x64, 0x01,
-0x70, 0x19, 0x71, 0x5A, 0x60, 0x09, 0x71, 0x53,
-0x12, 0x7B, 0xFD, 0x91, 0xB3, 0x80, 0x07, 0x71,
-0x53, 0x12, 0x7B, 0xBF, 0x91, 0xC6, 0x12, 0x7A,
-0x8A, 0x80, 0x17, 0x71, 0x5A, 0x60, 0x07, 0x71,
-0x53, 0x12, 0x7B, 0xFD, 0x80, 0x05, 0x71, 0x53,
-0x12, 0x7B, 0xBF, 0x91, 0x81, 0x91, 0x88, 0x12,
-0x7A, 0xB9, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0,
-0x90, 0x01, 0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F,
-0x03, 0x22, 0x90, 0x94, 0xC1, 0xE0, 0x90, 0x01,
-0x3F, 0x22, 0x12, 0xC3, 0x25, 0x60, 0x02, 0x81,
-0x5C, 0x90, 0x85, 0xC5, 0xE0, 0x70, 0x02, 0x81,
-0x5C, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x95, 0x04,
-0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x95, 0x05,
-0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x95, 0x06,
-0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x95, 0x07,
-0xF0, 0x12, 0xC3, 0xEE, 0xF0, 0x90, 0x85, 0xC9,
-0xE0, 0x54, 0xEC, 0xF0, 0x91, 0x78, 0x24, 0xFD,
-0x50, 0x02, 0x80, 0x0F, 0x90, 0x85, 0xBC, 0xE0,
-0x30, 0xE0, 0x05, 0x12, 0xC2, 0x49, 0x80, 0x03,
-0x12, 0xC1, 0xC6, 0x91, 0x78, 0x64, 0x01, 0x70,
-0x30, 0x90, 0x06, 0xAB, 0xE0, 0x90, 0x85, 0xCC,
-0xF0, 0x90, 0x06, 0xA9, 0xE0, 0x30, 0xE5, 0x05,
-0xA3, 0xE0, 0xFF, 0x80, 0x05, 0x90, 0x85, 0xCB,
-0xE0, 0xFF, 0x90, 0x85, 0xCB, 0xEF, 0xF0, 0xA3,
-0xE0, 0xFF, 0x70, 0x08, 0x90, 0x85, 0xCB, 0xE0,
-0xFE, 0xFF, 0x80, 0x00, 0x90, 0x85, 0xCC, 0xEF,
-0xF0, 0x12, 0xCF, 0xD4, 0xE4, 0x90, 0x85, 0xCE,
-0xF0, 0x12, 0xCF, 0xB2, 0x12, 0x96, 0x9A, 0x30,
-0xE0, 0x60, 0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03,
-0x20, 0xE0, 0x28, 0x91, 0x70, 0x6F, 0x70, 0x52,
-0xEF, 0x60, 0x4F, 0x90, 0x85, 0xC2, 0xE0, 0x44,
-0x40, 0xF0, 0x12, 0xC7, 0xC7, 0x71, 0x4F, 0x12,
-0x7B, 0xFD, 0x91, 0xCD, 0x7D, 0x02, 0x7F, 0x02,
-0x12, 0x7C, 0x41, 0x90, 0x85, 0xCC, 0xE0, 0x14,
-0xF0, 0x80, 0x2F, 0x90, 0x85, 0xC3, 0xE0, 0xC4,
-0x54, 0x0F, 0x64, 0x01, 0x70, 0x24, 0x91, 0x70,
-0xFE, 0x6F, 0x60, 0x1E, 0x90, 0x05, 0x73, 0xE0,
-0xFF, 0xEE, 0x6F, 0x60, 0x15, 0x90, 0x85, 0xC2,
-0x12, 0xC4, 0x27, 0x30, 0xE0, 0x0C, 0xEF, 0x54,
-0xBF, 0x71, 0x4F, 0x12, 0x7B, 0xBF, 0x91, 0x88,
-0x91, 0x81, 0x91, 0x68, 0x90, 0x85, 0xBC, 0xE0,
-0xC3, 0x13, 0x20, 0xE0, 0x02, 0x91, 0x68, 0x22,
-0x90, 0x85, 0xC2, 0xE0, 0x44, 0x04, 0xF0, 0x22,
-0x90, 0x85, 0xCB, 0xE0, 0xFF, 0xA3, 0xE0, 0x22,
-0x90, 0x85, 0xC3, 0xE0, 0xFF, 0xC4, 0x54, 0x0F,
-0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C, 0xA9,
-0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0xA9, 0x12,
-0xC3, 0x8F, 0x91, 0x81, 0x7F, 0x01, 0x91, 0xD4,
-0x90, 0x94, 0xBF, 0xE0, 0x30, 0xE0, 0x13, 0x91,
-0xB3, 0x90, 0x94, 0xC2, 0xE0, 0x60, 0x05, 0x14,
-0xF0, 0x02, 0x7A, 0x8A, 0x91, 0xBC, 0xE4, 0xFF,
-0x71, 0x0E, 0x22, 0x90, 0x94, 0xC1, 0xE0, 0x90,
-0x05, 0x73, 0xF0, 0x22, 0x90, 0x94, 0xC0, 0xE0,
-0x14, 0x90, 0x94, 0xC2, 0xF0, 0x22, 0x7D, 0x02,
-0x7F, 0x02, 0x12, 0x7C, 0x41, 0x7D, 0x01, 0x7F,
-0x02, 0x02, 0x7C, 0x41, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xFF, 0xE0, 0xFE,
-0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x1F, 0x90,
-0x96, 0x2C, 0x74, 0x1E, 0xF0, 0x90, 0x96, 0x3A,
-0x74, 0x01, 0xF0, 0x90, 0x96, 0x2E, 0xEF, 0xF0,
-0x7B, 0x01, 0x7A, 0x96, 0x79, 0x2C, 0x12, 0x5E,
-0x10, 0x7F, 0x04, 0x12, 0xC0, 0xCA, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x85, 0xBC, 0xE0, 0x30,
-0xE0, 0x10, 0xA3, 0x74, 0x01, 0xF0, 0x90, 0x85,
-0xBC, 0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x02,
-0xB1, 0x29, 0x12, 0x96, 0xCC, 0xE4, 0xFF, 0x80,
-0xAB, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x12, 0x96, 0xA5, 0xBF, 0x01, 0x04, 0x7F, 0x01,
-0x80, 0x02, 0x7F, 0x02, 0xB1, 0x43, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x85, 0xBF, 0xE0, 0x90, 0x96,
-0x69, 0xF0, 0x6F, 0x70, 0x02, 0xC1, 0x4E, 0xEF,
-0x14, 0x60, 0x42, 0x14, 0x60, 0x6F, 0x14, 0x70,
-0x02, 0xA1, 0xF8, 0x14, 0x70, 0x02, 0xC1, 0x23,
-0x24, 0x04, 0x60, 0x02, 0xC1, 0x4E, 0x90, 0x96,
-0x69, 0xE0, 0xB4, 0x04, 0x04, 0xD1, 0xC4, 0xC1,
-0x4E, 0x90, 0x96, 0x69, 0xE0, 0xB4, 0x02, 0x04,
-0xD1, 0xD4, 0xC1, 0x4E, 0x90, 0x96, 0x69, 0xE0,
-0xB4, 0x03, 0x04, 0xD1, 0xD9, 0xC1, 0x4E, 0x90,
-0x96, 0x69, 0xE0, 0x64, 0x01, 0x60, 0x02, 0xC1,
-0x4E, 0xD1, 0xC7, 0xC1, 0x4E, 0x90, 0x96, 0x69,
-0xE0, 0xB4, 0x04, 0x05, 0x12, 0x97, 0xE4, 0xC1,
-0x4E, 0x90, 0x96, 0x69, 0xE0, 0xB4, 0x02, 0x05,
-0x12, 0x97, 0xDF, 0xC1, 0x4E, 0x90, 0x96, 0x69,
-0xE0, 0xB4, 0x03, 0x05, 0x12, 0x97, 0xD6, 0xC1,
-0x4E, 0x90, 0x96, 0x69, 0xE0, 0x60, 0x02, 0xC1,
-0x4E, 0xD1, 0x9F, 0xC1, 0x4E, 0x90, 0x96, 0x69,
-0xE0, 0xB4, 0x04, 0x04, 0xD1, 0x69, 0x80, 0x76,
-0x90, 0x96, 0x69, 0xE0, 0xB4, 0x01, 0x04, 0xD1,
-0x55, 0x80, 0x6B, 0x90, 0x96, 0x69, 0xE0, 0xB4,
-0x03, 0x04, 0xD1, 0x53, 0x80, 0x60, 0x90, 0x96,
-0x69, 0xE0, 0x70, 0x5A, 0xD1, 0x65, 0x80, 0x56,
-0x90, 0x96, 0x69, 0xE0, 0xB4, 0x04, 0x04, 0xD1,
-0xB6, 0x80, 0x4B, 0x90, 0x96, 0x69, 0xE0, 0xB4,
-0x01, 0x04, 0xD1, 0xA4, 0x80, 0x40, 0x90, 0x96,
-0x69, 0xE0, 0xB4, 0x02, 0x04, 0xD1, 0xB2, 0x80,
-0x35, 0x90, 0x96, 0x69, 0xE0, 0x70, 0x2F, 0xD1,
-0xA2, 0x80, 0x2B, 0x90, 0x96, 0x69, 0xE0, 0xB4,
-0x03, 0x05, 0x12, 0xCC, 0x02, 0x80, 0x1F, 0x90,
-0x96, 0x69, 0xE0, 0xB4, 0x01, 0x05, 0x12, 0xA7,
-0xEB, 0x80, 0x13, 0x90, 0x96, 0x69, 0xE0, 0xB4,
-0x02, 0x04, 0xD1, 0xDE, 0x80, 0x08, 0x90, 0x96,
-0x69, 0xE0, 0x70, 0x02, 0xD1, 0xBF, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x80, 0x07, 0x7D, 0x20, 0x7F,
-0xFF, 0x12, 0xA0, 0xD8, 0xD1, 0x70, 0x90, 0x85,
-0xBF, 0x74, 0x02, 0xF0, 0x22, 0xD1, 0x9F, 0x80,
-0xEC, 0x12, 0xD7, 0xE9, 0x7D, 0x23, 0x80, 0xE7,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12,
-0xA3, 0xB7, 0x7F, 0x02, 0x12, 0x7B, 0x51, 0xEF,
-0x54, 0xFE, 0xFD, 0x7F, 0x02, 0x12, 0x7B, 0x3E,
-0x90, 0x01, 0x00, 0x74, 0x3F, 0xF0, 0xA3, 0xE0,
-0x54, 0xFD, 0xF0, 0x90, 0x05, 0x53, 0xE0, 0x44,
-0x20, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x02,
-0x97, 0xD8, 0xD1, 0x9F, 0x7D, 0x21, 0x7F, 0xFF,
-0x12, 0xA0, 0xD8, 0x90, 0x85, 0xBF, 0x74, 0x03,
-0xF0, 0x22, 0xD1, 0xE5, 0x80, 0xF5, 0x7D, 0x22,
-0x7F, 0xFF, 0x12, 0xD7, 0xE6, 0x80, 0xEC, 0xD1,
-0x9F, 0x02, 0xA7, 0xEB, 0x12, 0x97, 0xE4, 0x90,
-0x05, 0x27, 0xE0, 0x54, 0xBF, 0xF0, 0xE4, 0x90,
-0x85, 0xBF, 0xF0, 0x22, 0x12, 0x97, 0xDF, 0x80,
-0xEE, 0x12, 0x97, 0xD6, 0x80, 0xE9, 0xD1, 0xE5,
-0x7D, 0x24, 0x02, 0xA7, 0xED, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x7F, 0x02, 0x12, 0xD9,
-0x97, 0x7F, 0x02, 0x12, 0xD9, 0x8F, 0x44, 0x02,
-0xF0, 0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x90,
-0x06, 0xB7, 0x74, 0x09, 0xF0, 0x90, 0x06, 0xB4,
-0x74, 0x86, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xEF, 0x60, 0x48, 0x90, 0x88, 0xCE, 0xE0, 0xFF,
-0x60, 0x03, 0x12, 0x7B, 0x8A, 0x90, 0x01, 0xC7,
-0xE4, 0xF0, 0x12, 0xB9, 0x84, 0x90, 0x85, 0xB7,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x06, 0x09, 0xE0,
-0x54, 0xFE, 0xF0, 0x7D, 0x35, 0x7F, 0xFF, 0x12,
-0xA0, 0xD8, 0xD1, 0x70, 0x90, 0x02, 0x86, 0xE0,
-0x44, 0x04, 0xF0, 0x12, 0x72, 0x79, 0x12, 0xD5,
-0x64, 0x12, 0xA0, 0xD2, 0x12, 0x76, 0xE6, 0x90,
-0x01, 0x34, 0x74, 0x08, 0xF0, 0xFD, 0xE4, 0xFF,
-0x02, 0x7C, 0xA9, 0x7D, 0x08, 0xE4, 0xFF, 0x12,
-0x7C, 0x41, 0x90, 0x06, 0x90, 0xE0, 0x54, 0xF0,
-0xF0, 0x90, 0x02, 0x86, 0xE0, 0x54, 0xFB, 0xF0,
-0x12, 0xD4, 0x81, 0x12, 0xD5, 0x65, 0x7E, 0x00,
-0x7F, 0x24, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x86,
-0x79, 0x72, 0x12, 0x06, 0xDE, 0x90, 0x06, 0x90,
-0xE0, 0x44, 0x20, 0xF0, 0x12, 0xD4, 0x6E, 0x12,
-0xB3, 0xD5, 0x90, 0x84, 0xC5, 0xE0, 0xFF, 0x64,
-0x02, 0x70, 0x2C, 0x12, 0xD8, 0x3A, 0x30, 0xE0,
-0x02, 0x7E, 0x01, 0x90, 0x86, 0x90, 0x12, 0xD8,
-0x38, 0x30, 0xE1, 0x02, 0x7E, 0x01, 0x90, 0x86,
-0x8E, 0x12, 0xD8, 0x38, 0x30, 0xE2, 0x02, 0x7E,
-0x01, 0x90, 0x86, 0x8F, 0xEE, 0xF0, 0x90, 0xFD,
-0x80, 0xE0, 0x90, 0x02, 0xFB, 0xF0, 0x22, 0xEF,
-0x64, 0x01, 0x70, 0x20, 0x12, 0xD8, 0x31, 0x30,
-0xE0, 0x02, 0x7F, 0x01, 0x90, 0x86, 0x90, 0x12,
-0xD8, 0x2F, 0x30, 0xE1, 0x02, 0x7F, 0x01, 0x90,
-0x86, 0x8E, 0x12, 0xD8, 0x2F, 0x30, 0xE2, 0x02,
-0x7F, 0x01, 0x80, 0x24, 0x90, 0x84, 0xC5, 0xE0,
-0x64, 0x03, 0x70, 0x21, 0x12, 0xB0, 0x18, 0x30,
-0xE0, 0x02, 0x7F, 0x01, 0x90, 0x86, 0x90, 0x11,
-0x16, 0x30, 0xE1, 0x02, 0x7F, 0x01, 0x90, 0x86,
-0x8E, 0x11, 0x16, 0x30, 0xE2, 0x02, 0x7F, 0x01,
-0x90, 0x86, 0x8F, 0xEF, 0xF0, 0x22, 0xEF, 0xF0,
-0x90, 0xFD, 0x78, 0xE0, 0x7F, 0x00, 0x22, 0x12,
-0x02, 0xF6, 0xFF, 0x90, 0x94, 0xF2, 0xF0, 0xBF,
-0x01, 0x09, 0x7F, 0x01, 0x11, 0x34, 0xE4, 0x90,
-0x94, 0xF2, 0xF0, 0x22, 0x90, 0x92, 0x3F, 0xEF,
-0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F,
-0xF4, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
-0x08, 0x90, 0x92, 0x5E, 0xE0, 0x90, 0x92, 0x60,
-0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F,
-0xF5, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
-0x08, 0x90, 0x92, 0x5E, 0xE0, 0x90, 0x92, 0x61,
-0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F,
-0xF6, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
-0x08, 0x90, 0x92, 0x5E, 0xE0, 0x90, 0x92, 0x62,
-0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F,
-0xF7, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
-0x08, 0x90, 0x92, 0x5E, 0xE0, 0x90, 0x92, 0x63,
-0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F,
-0xF8, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
-0x08, 0x90, 0x92, 0x5E, 0xE0, 0x90, 0x92, 0x64,
-0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5E, 0x71,
-0x4C, 0xBF, 0x01, 0x08, 0x90, 0x92, 0x5E, 0xE0,
-0x90, 0x92, 0x65, 0xF0, 0x7B, 0x01, 0x7A, 0x92,
-0x79, 0x5E, 0x51, 0xB3, 0x70, 0x52, 0x90, 0x92,
-0x5E, 0xE0, 0x90, 0x92, 0x66, 0xF0, 0x54, 0x07,
-0x60, 0x08, 0x90, 0x92, 0x5E, 0xE0, 0x54, 0xE0,
-0x70, 0x3E, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5F,
-0x7F, 0xFA, 0x51, 0xB5, 0x70, 0x32, 0x90, 0x92,
-0x5E, 0xE0, 0xFC, 0x54, 0x07, 0x70, 0x12, 0x90,
-0x92, 0x66, 0xE0, 0xFE, 0x90, 0x92, 0x5F, 0xE0,
-0x54, 0x07, 0xFD, 0xEE, 0x4D, 0x90, 0x92, 0x66,
-0xF0, 0xEC, 0x54, 0xE0, 0x70, 0x12, 0x90, 0x92,
-0x66, 0xE0, 0xFF, 0x90, 0x92, 0x5F, 0xE0, 0x54,
-0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x92, 0x66, 0xF0,
-0x7B, 0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F, 0xFD,
-0x51, 0xB5, 0x70, 0x4B, 0x90, 0x92, 0x5E, 0xE0,
-0xFE, 0x54, 0xCC, 0x90, 0x92, 0x67, 0xF0, 0xEE,
-0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90, 0x92, 0x5E,
-0xE0, 0x54, 0xC0, 0x70, 0x32, 0xEF, 0x70, 0x16,
-0x90, 0x92, 0x67, 0xE0, 0xFF, 0x90, 0x92, 0x5E,
-0xE0, 0x54, 0x03, 0x25, 0xE0, 0x25, 0xE0, 0xFE,
-0xEF, 0x4E, 0x90, 0x92, 0x67, 0xF0, 0x90, 0x92,
-0x5E, 0xE0, 0xFF, 0x54, 0xC0, 0x70, 0x10, 0x90,
-0x92, 0x67, 0xE0, 0xFE, 0xEF, 0x54, 0x30, 0x25,
-0xE0, 0x25, 0xE0, 0xFF, 0xEE, 0x4F, 0xF0, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F, 0xF0, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x92, 0x5E, 0xE0, 0x90, 0x92, 0x68, 0xF0, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F, 0xF1, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x92, 0x5E, 0xE0, 0x90, 0x92, 0x69, 0xF0, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F, 0xF2, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x92, 0x5E, 0xE0, 0x90, 0x92, 0x6A, 0xF0, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F, 0xF3, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x92, 0x5E, 0xE0, 0x90, 0x92, 0x6B, 0xF0, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x5E, 0x7F, 0xFC, 0x7E,
-0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
-0x92, 0x5E, 0xE0, 0x90, 0x92, 0x6C, 0xF0, 0x90,
-0x92, 0x40, 0x74, 0x19, 0xF0, 0x90, 0x92, 0x4E,
-0x74, 0x08, 0xF0, 0x90, 0x92, 0x60, 0xE0, 0x90,
-0x92, 0x42, 0xF0, 0x90, 0x92, 0x61, 0xE0, 0x90,
-0x92, 0x43, 0xF0, 0x90, 0x92, 0x62, 0xE0, 0x90,
-0x92, 0x44, 0xF0, 0x90, 0x92, 0x63, 0xE0, 0x90,
-0x92, 0x45, 0xF0, 0x90, 0x92, 0x64, 0xE0, 0x90,
-0x92, 0x46, 0xF0, 0x90, 0x92, 0x65, 0xE0, 0x90,
-0x92, 0x47, 0xF0, 0x90, 0x92, 0x66, 0xE0, 0x90,
-0x92, 0x48, 0xF0, 0x90, 0x92, 0x67, 0xE0, 0x90,
-0x92, 0x49, 0xF0, 0x90, 0x92, 0x4F, 0x74, 0x1A,
-0xF0, 0x90, 0x92, 0x5D, 0x74, 0x05, 0xF0, 0x90,
-0x92, 0x68, 0xE0, 0x90, 0x92, 0x51, 0xF0, 0x90,
-0x92, 0x69, 0xE0, 0x90, 0x92, 0x52, 0xF0, 0x90,
-0x92, 0x6A, 0xE0, 0x90, 0x92, 0x53, 0xF0, 0x90,
-0x92, 0x6B, 0xE0, 0x90, 0x92, 0x54, 0xF0, 0x90,
-0x92, 0x6C, 0xE0, 0x90, 0x92, 0x55, 0xF0, 0x90,
-0x92, 0x3F, 0xE0, 0xB4, 0x01, 0x17, 0x7B, 0x01,
-0x7A, 0x92, 0x79, 0x40, 0x12, 0x5E, 0x10, 0x7B,
-0x01, 0x7A, 0x92, 0x79, 0x4F, 0x12, 0x5E, 0x10,
-0x7F, 0x04, 0x02, 0x87, 0xBC, 0x75, 0x1B, 0x01,
-0x75, 0x1C, 0x92, 0x75, 0x1D, 0x40, 0x75, 0x1E,
-0x0A, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xA0, 0xF1,
-0xBB, 0x75, 0x1C, 0x92, 0x75, 0x1D, 0x51, 0x75,
-0x1E, 0x05, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xAA,
-0x02, 0x6A, 0x21, 0x7F, 0xFB, 0x7E, 0x00, 0x12,
-0x64, 0x37, 0xEF, 0x64, 0x01, 0x22, 0x7E, 0x00,
-0x7F, 0x0B, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x94,
-0x79, 0xF3, 0x12, 0x06, 0xDE, 0x71, 0x45, 0x71,
-0x4C, 0xBF, 0x01, 0x1C, 0x90, 0x92, 0x3F, 0xE0,
-0xFE, 0x54, 0x01, 0x90, 0x94, 0xF3, 0xF0, 0xEE,
-0x54, 0x04, 0x90, 0x94, 0xF5, 0xF0, 0x90, 0x92,
-0x3F, 0xE0, 0x54, 0x08, 0x90, 0x94, 0xF4, 0xF0,
-0x71, 0x45, 0x51, 0xB3, 0x70, 0x34, 0x90, 0x92,
-0x3F, 0xE0, 0x54, 0x07, 0x70, 0x14, 0x7B, 0x01,
-0x7A, 0x92, 0x79, 0x40, 0x7F, 0xFA, 0xFE, 0x12,
-0x64, 0x37, 0xBF, 0x01, 0x0F, 0x90, 0x92, 0x40,
-0x80, 0x03, 0x90, 0x92, 0x3F, 0xE0, 0x54, 0x07,
-0x90, 0x94, 0xF7, 0xF0, 0x90, 0x92, 0x3F, 0xE0,
-0x54, 0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90, 0x94,
-0xF6, 0xF0, 0x71, 0x45, 0x7F, 0xFD, 0x7E, 0x00,
-0x12, 0x64, 0x37, 0xBF, 0x01, 0x0E, 0x90, 0x92,
-0x3F, 0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F,
-0x90, 0x94, 0xF8, 0xF0, 0x22, 0x7B, 0x01, 0x7A,
-0x92, 0x79, 0x3F, 0x22, 0x7F, 0xF9, 0x7E, 0x00,
-0x02, 0x64, 0x37, 0x90, 0x00, 0x80, 0xE0, 0x44,
-0x80, 0xFD, 0x7F, 0x80, 0x12, 0x7B, 0x3E, 0x12,
-0xC0, 0x5C, 0x12, 0xC9, 0xA3, 0x12, 0x7B, 0x9C,
-0x91, 0xF4, 0x71, 0xC0, 0x7F, 0x01, 0x12, 0x85,
-0x15, 0x90, 0x94, 0xC3, 0x74, 0x02, 0xF0, 0xFF,
-0x12, 0x85, 0x15, 0x90, 0x94, 0xC3, 0xE0, 0x04,
-0xF0, 0xB1, 0x1A, 0x91, 0x9D, 0x90, 0x01, 0xCC,
-0x74, 0x0F, 0xF0, 0x90, 0x00, 0x80, 0xE0, 0x44,
-0x40, 0xFD, 0x7F, 0x80, 0x12, 0x7B, 0x3E, 0x75,
-0x20, 0xFF, 0x12, 0x7C, 0xCD, 0x90, 0x01, 0xA0,
-0xE0, 0xB4, 0xFD, 0x04, 0xE4, 0xFF, 0x11, 0x34,
-0xB1, 0x80, 0x90, 0x00, 0x81, 0xE0, 0x44, 0x04,
-0xFD, 0x7F, 0x81, 0x12, 0x7B, 0x3E, 0x12, 0xC0,
-0x21, 0x51, 0xBE, 0xE4, 0xFF, 0x02, 0x85, 0x9E,
-0xE4, 0x90, 0x84, 0xC1, 0x71, 0xCD, 0x90, 0x94,
-0xBC, 0xF0, 0x22, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
-0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0xF1, 0xD2, 0xE4,
-0x90, 0x88, 0xD8, 0x71, 0xCD, 0x90, 0x88, 0x76,
-0x71, 0xCB, 0xA3, 0x71, 0xCB, 0x90, 0x88, 0x88,
-0xF0, 0xA3, 0xF0, 0x90, 0x88, 0xCA, 0xF0, 0xA3,
-0xF0, 0x22, 0x90, 0x93, 0xF3, 0xEF, 0xF0, 0xA3,
-0xED, 0xF0, 0xA3, 0x12, 0x87, 0x75, 0x91, 0x97,
-0x8B, 0x1B, 0x8A, 0x1C, 0x91, 0x80, 0x24, 0x02,
-0x91, 0x6B, 0x91, 0x97, 0xE9, 0x24, 0x04, 0x91,
-0x79, 0x24, 0x03, 0x91, 0x6B, 0x91, 0x97, 0xE9,
-0x24, 0x08, 0x91, 0x79, 0x24, 0x04, 0x91, 0x6B,
-0x91, 0x97, 0xE9, 0x24, 0x0C, 0x91, 0x79, 0x24,
-0x05, 0x91, 0x6B, 0x90, 0x93, 0xF4, 0xE0, 0xFD,
-0xB4, 0x02, 0x08, 0x90, 0x93, 0xF3, 0xE0, 0x44,
-0x48, 0x80, 0x0A, 0xED, 0xB4, 0x04, 0x0A, 0x90,
-0x93, 0xF3, 0xE0, 0x44, 0x50, 0x90, 0x93, 0xF9,
-0xF0, 0x90, 0x93, 0xFA, 0x74, 0x80, 0xF0, 0xA3,
-0x74, 0xFF, 0xF0, 0xA3, 0xF0, 0x91, 0x8E, 0x91,
-0x6B, 0x90, 0x93, 0xF9, 0x74, 0xFF, 0x71, 0xCD,
-0x91, 0x8E, 0x04, 0x91, 0x6B, 0x90, 0x06, 0x72,
-0xE4, 0xF0, 0x22, 0xFF, 0x90, 0x93, 0xF8, 0xF0,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0xF9, 0x02, 0x67,
-0x8D, 0xF9, 0xE4, 0x3A, 0x8B, 0x1B, 0xF5, 0x1C,
-0x89, 0x1D, 0x75, 0x1E, 0x04, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0xF9, 0x12, 0x6A, 0x21, 0x90, 0x93,
-0xF3, 0xE0, 0x75, 0xF0, 0x08, 0xA4, 0x22, 0x90,
-0x93, 0xF5, 0x02, 0x87, 0x6C, 0xD1, 0xAC, 0x12,
-0x7B, 0xEF, 0x91, 0xD6, 0xB1, 0xD1, 0x91, 0xD1,
-0x12, 0xAF, 0x76, 0x12, 0x7B, 0x64, 0x12, 0x78,
-0xB9, 0x12, 0xC9, 0x94, 0x90, 0x89, 0x16, 0xE0,
-0x54, 0x7F, 0xF0, 0x54, 0xBF, 0xF0, 0x54, 0xDF,
-0xF0, 0x54, 0xF0, 0xF0, 0xE4, 0x90, 0x89, 0x18,
-0xF0, 0x90, 0x89, 0x16, 0xE0, 0x54, 0xEF, 0xF0,
-0x22, 0xD1, 0x9F, 0x02, 0x06, 0xDE, 0x7E, 0x00,
-0x7F, 0x01, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x85,
-0x79, 0xBC, 0x12, 0x06, 0xDE, 0x90, 0x85, 0xBC,
-0xE0, 0x54, 0xFD, 0xF0, 0xE4, 0x71, 0xCE, 0xA3,
-0x74, 0x0C, 0xF0, 0x22, 0x90, 0x00, 0x00, 0xE0,
-0x54, 0xFB, 0xFD, 0xE4, 0xFF, 0x12, 0xD9, 0x8F,
-0x44, 0x04, 0xFD, 0x7F, 0x01, 0x12, 0x7B, 0x3E,
-0x90, 0x01, 0x98, 0x74, 0x80, 0xF0, 0xA3, 0x74,
-0x88, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x80,
-0xF0, 0x22, 0x12, 0x7C, 0x4E, 0x90, 0x84, 0xC5,
-0xEF, 0xF0, 0xB1, 0x4E, 0x90, 0x01, 0x64, 0x74,
-0x01, 0xF0, 0x90, 0x04, 0x23, 0xE0, 0x44, 0x80,
-0xF0, 0x90, 0x00, 0x17, 0xE0, 0x54, 0xFC, 0x44,
-0x04, 0xFD, 0x7F, 0x17, 0x12, 0x7B, 0x3E, 0x90,
-0x00, 0x38, 0xE0, 0x44, 0x40, 0xFD, 0x7F, 0x38,
-0x12, 0x7B, 0x3E, 0x02, 0x68, 0xE2, 0x12, 0x75,
-0xB6, 0x12, 0x75, 0x58, 0x12, 0xBF, 0xDB, 0x12,
-0xC0, 0x02, 0xE4, 0xF5, 0x40, 0xF5, 0x41, 0xF5,
-0x42, 0x75, 0x43, 0x80, 0xAD, 0x40, 0x7F, 0x50,
-0x12, 0x7B, 0x3E, 0xAD, 0x41, 0x7F, 0x51, 0x12,
-0x7B, 0x3E, 0xAD, 0x42, 0x7F, 0x52, 0x12, 0x7B,
-0x3E, 0xAD, 0x43, 0x7F, 0x53, 0x02, 0x7B, 0x3E,
-0xE4, 0x90, 0x92, 0x3F, 0xF0, 0xA3, 0xF0, 0x12,
-0xC9, 0xCE, 0xEF, 0x64, 0x01, 0x60, 0x3B, 0xC3,
-0x90, 0x92, 0x40, 0xE0, 0x94, 0x88, 0x90, 0x92,
-0x3F, 0xE0, 0x94, 0x13, 0x40, 0x0F, 0x90, 0x01,
-0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x01, 0xC7,
-0x74, 0xFD, 0xF0, 0x80, 0x1D, 0x90, 0x92, 0x3F,
-0xD1, 0xB2, 0xF1, 0x2D, 0xD3, 0x90, 0x92, 0x40,
-0xE0, 0x94, 0x32, 0x90, 0x92, 0x3F, 0xE0, 0x94,
-0x00, 0x40, 0xC4, 0x90, 0x01, 0xC6, 0xE0, 0x30,
-0xE3, 0xBD, 0x90, 0x01, 0xC7, 0x74, 0xFE, 0xF0,
-0x22, 0x7E, 0x00, 0x7F, 0xAC, 0x7D, 0x00, 0x7B,
-0x01, 0x7A, 0x85, 0x79, 0xC1, 0x12, 0x06, 0xDE,
-0xD1, 0x9F, 0x12, 0x06, 0xDE, 0x90, 0x85, 0xC4,
-0x74, 0x02, 0xF0, 0x90, 0x85, 0xCB, 0x14, 0xF0,
-0xA3, 0xF0, 0xA3, 0x74, 0x0A, 0xF0, 0x90, 0x85,
-0xD1, 0xE4, 0xF0, 0xA3, 0x74, 0x02, 0xD1, 0x8F,
-0x12, 0xCF, 0xBC, 0xE4, 0xFD, 0xFF, 0x12, 0x57,
-0x82, 0x7D, 0x0C, 0x7F, 0x02, 0x12, 0x57, 0x82,
-0x7D, 0x0C, 0x7F, 0x01, 0x12, 0x57, 0x82, 0x90,
-0x84, 0xC5, 0xE0, 0xFF, 0xB4, 0x01, 0x08, 0x90,
-0x85, 0xD0, 0x74, 0xDD, 0xF0, 0x80, 0x0F, 0xEF,
-0x90, 0x85, 0xD0, 0xB4, 0x03, 0x05, 0x74, 0xD4,
-0xF0, 0x80, 0x03, 0x74, 0x40, 0xF0, 0x7F, 0x2C,
-0x12, 0x7B, 0x51, 0xEF, 0x54, 0x0F, 0xFF, 0xBF,
-0x05, 0x08, 0x90, 0x85, 0xFB, 0x74, 0x02, 0xF0,
-0x80, 0x05, 0xE4, 0x90, 0x85, 0xFB, 0xF0, 0x90,
-0x86, 0x6D, 0x74, 0x03, 0xF0, 0xA3, 0x74, 0x0F,
-0xF0, 0xA3, 0xE0, 0x54, 0x01, 0x44, 0x28, 0xF0,
-0xA3, 0x74, 0x07, 0xD1, 0x8F, 0xE4, 0x90, 0x85,
-0xD7, 0xF0, 0xA3, 0xF0, 0x7F, 0x01, 0x12, 0x69,
-0x33, 0x90, 0x05, 0x58, 0x74, 0x02, 0xF0, 0x90,
-0x06, 0x04, 0xE0, 0x54, 0x7F, 0xF0, 0x90, 0x06,
-0x0A, 0xE0, 0x54, 0xF8, 0xF0, 0x90, 0x05, 0x22,
-0xE4, 0xF0, 0x90, 0x86, 0x71, 0xF0, 0x22, 0xF0,
-0x90, 0x85, 0xFB, 0xE0, 0x24, 0x04, 0x90, 0x85,
-0xDD, 0xF0, 0xA3, 0x74, 0x0A, 0xF0, 0x22, 0x7E,
-0x00, 0x7F, 0x04, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
-0x94, 0x79, 0xBF, 0x22, 0xE4, 0xFD, 0xFF, 0x02,
-0x6E, 0x5F, 0xE4, 0x75, 0xF0, 0x01, 0x02, 0x07,
-0x0A, 0xAD, 0x07, 0x90, 0x88, 0x80, 0xD1, 0xB2,
-0x90, 0x88, 0x80, 0xE0, 0xFF, 0xAE, 0x05, 0x74,
-0x04, 0x2E, 0xF1, 0xCA, 0xEF, 0xF0, 0x90, 0x88,
-0x80, 0xA3, 0xE0, 0xFF, 0x74, 0x05, 0x2E, 0xF1,
-0xC2, 0xEF, 0xF0, 0x22, 0x90, 0x96, 0x5A, 0xEF,
-0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x01,
-0x09, 0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02, 0x7F,
-0x01, 0x90, 0x96, 0x5A, 0xE0, 0x6F, 0x60, 0x34,
-0xC3, 0x90, 0x96, 0x5C, 0xE0, 0x94, 0x88, 0x90,
-0x96, 0x5B, 0xE0, 0x94, 0x13, 0x40, 0x08, 0x90,
-0x01, 0xC0, 0xE0, 0x44, 0x10, 0xF0, 0x22, 0x90,
-0x96, 0x5B, 0xD1, 0xB2, 0xF1, 0x2D, 0xD3, 0x90,
-0x96, 0x5C, 0xE0, 0x94, 0x32, 0x90, 0x96, 0x5B,
-0xE0, 0x94, 0x00, 0x40, 0xC1, 0x90, 0x01, 0xC6,
-0xE0, 0x30, 0xE0, 0xBA, 0x22, 0x7F, 0x14, 0x7E,
-0x00, 0x02, 0x7C, 0x9F, 0x12, 0xCB, 0xE3, 0x7F,
-0x08, 0x12, 0x7B, 0x51, 0xEF, 0x54, 0xEF, 0xFD,
-0x7F, 0x08, 0x12, 0x7B, 0x3E, 0xE4, 0xFF, 0xD1,
-0xDC, 0x7D, 0x35, 0x7F, 0x27, 0x12, 0x7B, 0x3E,
-0x90, 0x85, 0xC2, 0xE0, 0x54, 0xEF, 0xF0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xF1,
-0x68, 0xF1, 0x34, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x90, 0x85, 0xC2, 0xE0, 0x44, 0x10, 0xF0, 0x90,
-0x85, 0xD0, 0xE0, 0xFD, 0x7F, 0x93, 0x12, 0x7B,
-0x3E, 0x90, 0x85, 0xC6, 0xE0, 0x60, 0x12, 0x90,
-0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74, 0x10,
-0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F, 0x74, 0x90,
-0xF0, 0x7F, 0x08, 0x12, 0x7B, 0x51, 0xEF, 0x44,
-0x10, 0xFD, 0x7F, 0x08, 0x12, 0x7B, 0x3E, 0x7F,
-0x01, 0xD1, 0xDC, 0x7D, 0x34, 0x7F, 0x27, 0x12,
-0x7B, 0x3E, 0x7F, 0x90, 0x12, 0xD9, 0x97, 0x7F,
-0x90, 0x12, 0x7B, 0x3E, 0x7F, 0x14, 0x7E, 0x00,
-0x02, 0x7C, 0x9F, 0x12, 0x6A, 0x21, 0x75, 0x1B,
-0x01, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0x22, 0x90, 0x86, 0x72, 0xE0, 0x54, 0xBF,
-0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x85, 0x1E, 0xE0, 0xFF, 0x90, 0x85,
-0x1D, 0xE0, 0xB5, 0x07, 0x04, 0x7F, 0x01, 0x80,
-0x02, 0x7F, 0x00, 0xEF, 0x70, 0x48, 0x90, 0x85,
-0x1D, 0xE0, 0xFE, 0x75, 0xF0, 0x08, 0x90, 0x84,
-0xCD, 0x12, 0x05, 0x28, 0xE0, 0xFD, 0xEE, 0x75,
-0xF0, 0x08, 0xA4, 0x24, 0xCE, 0xF9, 0x74, 0x84,
-0x35, 0xF0, 0xFA, 0x7B, 0x01, 0xAF, 0x05, 0x12,
-0x89, 0xD6, 0x90, 0x85, 0x1D, 0x12, 0x92, 0x6A,
-0xB4, 0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x60, 0x05,
-0xE4, 0x90, 0x85, 0x1D, 0xF0, 0x7D, 0x68, 0x7F,
-0xFE, 0x12, 0x7B, 0x3E, 0x12, 0x40, 0xB9, 0x90,
-0x84, 0xC1, 0xE0, 0x44, 0x02, 0xF0, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xE4, 0xFC, 0xED, 0x2C, 0x24,
-0x00, 0x11, 0x78, 0xE4, 0xF0, 0x0C, 0xEC, 0xB4,
-0x18, 0xF3, 0x11, 0x75, 0xEF, 0xF0, 0xEE, 0x54,
-0x3F, 0xFF, 0x11, 0x80, 0x11, 0x97, 0x54, 0xF0,
-0xF0, 0x11, 0x8B, 0x44, 0x80, 0xF0, 0x74, 0x0B,
-0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83,
-0xE0, 0x44, 0x10, 0xF0, 0x22, 0x74, 0x00, 0x2D,
-0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83, 0x22,
-0x74, 0x01, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB,
-0xF5, 0x83, 0x22, 0x74, 0x03, 0x2D, 0xF5, 0x82,
-0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x22, 0xEF,
-0xF0, 0x74, 0x02, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
-0xFB, 0xF5, 0x83, 0xE0, 0x22, 0x90, 0x92, 0x37,
-0xEF, 0xF0, 0xA3, 0x12, 0x87, 0x75, 0x90, 0x96,
-0x61, 0xE0, 0xFE, 0x04, 0xF0, 0x90, 0x00, 0x01,
-0xEE, 0x12, 0x03, 0x4E, 0x74, 0x00, 0x2F, 0xF9,
-0xE4, 0x34, 0xFB, 0xFA, 0x7B, 0x01, 0xC0, 0x03,
-0xC0, 0x02, 0xC0, 0x01, 0x90, 0x92, 0x38, 0x31,
-0x19, 0x75, 0x1E, 0x02, 0xD0, 0x01, 0xD0, 0x02,
-0xD0, 0x03, 0x12, 0x6A, 0x21, 0x90, 0x92, 0x37,
-0xE0, 0x24, 0x02, 0xF9, 0xE4, 0x34, 0xFB, 0xFA,
-0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01,
-0xA3, 0x12, 0x87, 0x6C, 0xE9, 0x24, 0x02, 0xF9,
-0xE4, 0x3A, 0x8B, 0x1B, 0xF5, 0x1C, 0x89, 0x1D,
-0x90, 0x92, 0x38, 0x31, 0x10, 0xF5, 0x1E, 0xD0,
-0x01, 0xD0, 0x02, 0xD0, 0x03, 0x02, 0x6A, 0x21,
-0x12, 0x87, 0x6C, 0x90, 0x00, 0x0E, 0x02, 0x03,
-0x0F, 0x12, 0x87, 0x6C, 0x8B, 0x1B, 0x8A, 0x1C,
-0x89, 0x1D, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x92, 0x3B, 0x12, 0x87, 0x75,
-0x7F, 0x96, 0x7E, 0x02, 0x12, 0x66, 0x80, 0xEF,
-0x60, 0x45, 0x31, 0x84, 0xFE, 0xEF, 0x24, 0x01,
-0xFF, 0xE4, 0x3E, 0xFE, 0x90, 0x92, 0x3E, 0xEF,
-0xF0, 0xEE, 0xFF, 0x90, 0xFD, 0x11, 0xF0, 0x90,
-0x92, 0x3E, 0xE0, 0xFD, 0x90, 0x02, 0x94, 0xF0,
-0xA3, 0xEF, 0xF0, 0x90, 0x92, 0x3B, 0x31, 0x10,
-0x24, 0x02, 0xFF, 0xE4, 0x33, 0xFE, 0x12, 0x5A,
-0xA5, 0x90, 0x92, 0x3E, 0xE0, 0x24, 0x18, 0xFF,
-0x90, 0x92, 0x3B, 0x12, 0x87, 0x6C, 0x12, 0x56,
-0xF4, 0x90, 0x02, 0x96, 0x74, 0x01, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x01, 0x17, 0xE0,
-0xFE, 0x90, 0x01, 0x16, 0xE0, 0x7C, 0x00, 0x24,
-0x00, 0xFF, 0xEC, 0x3E, 0x22, 0x90, 0x88, 0xD9,
-0x51, 0x3D, 0xE0, 0xFE, 0x24, 0x28, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFF, 0x74,
-0x29, 0x2E, 0xB1, 0x7F, 0xE0, 0xFD, 0x90, 0x92,
-0x07, 0xE0, 0x24, 0x2C, 0x12, 0xD7, 0x39, 0x90,
-0x92, 0x07, 0xE0, 0x2F, 0x24, 0x30, 0xA3, 0xF0,
-0xE0, 0xFD, 0x24, 0x04, 0x12, 0xB7, 0xCA, 0xE0,
-0xFE, 0x74, 0x05, 0x2D, 0x12, 0xB7, 0xC2, 0x31,
-0x8C, 0x90, 0x88, 0x80, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x92, 0x08, 0xE0, 0x24, 0x0C, 0xF9, 0xE4,
-0x34, 0xFC, 0x12, 0xA3, 0xA4, 0x75, 0x1E, 0x04,
-0x7B, 0x01, 0x7A, 0x88, 0x79, 0x82, 0x12, 0x6A,
-0x21, 0x90, 0x92, 0x08, 0xE0, 0x24, 0x14, 0x12,
-0xA7, 0x22, 0x31, 0x8C, 0x90, 0x88, 0x86, 0xF0,
-0xA3, 0xEF, 0xF0, 0x90, 0x88, 0xDA, 0x51, 0x3D,
-0x90, 0x88, 0x7C, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x4E, 0x60, 0x12, 0x90, 0x92, 0x07, 0xE0, 0x12,
-0xA3, 0x9E, 0x8F, 0x1E, 0x7B, 0x01, 0x7A, 0x88,
-0x79, 0x8A, 0x12, 0x6A, 0x21, 0x90, 0x88, 0xDB,
-0x51, 0x3D, 0x12, 0xA3, 0x9E, 0x90, 0x88, 0x7E,
-0xA3, 0xE0, 0xF5, 0x1E, 0x7B, 0x01, 0x7A, 0x88,
-0x79, 0xAA, 0x02, 0x6A, 0x21, 0xE0, 0xFF, 0x12,
-0x7B, 0x2A, 0x90, 0x92, 0x07, 0xEF, 0xF0, 0x22,
-0xEF, 0x60, 0x04, 0x51, 0x50, 0x31, 0x95, 0x22,
-0xE4, 0xFD, 0xFC, 0x90, 0x88, 0xD8, 0xE0, 0xFF,
-0xF1, 0xD3, 0xAB, 0x05, 0x74, 0x01, 0x2B, 0x71,
-0xD2, 0xE0, 0xFE, 0x74, 0x00, 0x2B, 0x12, 0xA7,
-0x33, 0x12, 0xD9, 0x00, 0x90, 0x88, 0x76, 0xF0,
-0xA3, 0xEF, 0xF0, 0x74, 0x03, 0x2B, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFE, 0x74,
-0x02, 0x2B, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0x51,
-0xEA, 0x90, 0x88, 0x78, 0xF0, 0xA3, 0xEF, 0xF0,
-0x74, 0x05, 0x2B, 0x12, 0xB7, 0xC2, 0xE0, 0xFE,
-0x74, 0x04, 0x2B, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
-0x51, 0xEA, 0x90, 0x88, 0x7A, 0xF0, 0xA3, 0xEF,
-0xF0, 0x74, 0x07, 0x2B, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xE0, 0xFE, 0x74, 0x06, 0x2B,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0x51, 0xEA, 0x90,
-0x88, 0x7C, 0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x09,
-0x2B, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0xFE, 0x74, 0x08, 0x2B, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x24, 0x00, 0xFF,
-0xEC, 0x3E, 0x90, 0x88, 0x7E, 0xF0, 0xA3, 0xEF,
-0xF0, 0x22, 0xF5, 0x83, 0xE0, 0x24, 0x00, 0xFF,
-0xEA, 0x3E, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x12, 0xD8, 0x27, 0x90, 0x86, 0x72,
-0x71, 0xAD, 0x12, 0xD9, 0x1B, 0x90, 0x86, 0x72,
-0x71, 0xC2, 0x71, 0xBB, 0x12, 0xD9, 0x09, 0x90,
-0x86, 0x72, 0x12, 0xD8, 0xDD, 0x71, 0xBB, 0x12,
-0xD9, 0x12, 0x90, 0x86, 0x72, 0x12, 0xD8, 0xD3,
-0x12, 0x8D, 0xC2, 0x54, 0x01, 0xFF, 0x90, 0x86,
-0x74, 0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0xB1, 0x77,
-0x54, 0x01, 0xFE, 0x90, 0x86, 0x73, 0xB1, 0x70,
-0xEF, 0x54, 0x04, 0xFF, 0xEE, 0x54, 0xFB, 0x4F,
-0xFF, 0xF0, 0x90, 0x00, 0x01, 0x12, 0x03, 0x0F,
-0x71, 0xC4, 0x90, 0x86, 0x73, 0xF0, 0x90, 0x86,
-0x72, 0xE0, 0xC3, 0x13, 0x54, 0x01, 0xFF, 0x12,
-0x7C, 0x72, 0x12, 0x9F, 0xF0, 0x54, 0x01, 0xFF,
-0x12, 0x7C, 0x7E, 0x12, 0x9F, 0x34, 0x30, 0xE0,
-0x1F, 0x90, 0x86, 0x72, 0x12, 0x96, 0x9D, 0x20,
-0xE0, 0x0E, 0xEF, 0xC3, 0x13, 0x20, 0xE0, 0x08,
-0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x04,
-0x7F, 0x01, 0x80, 0x0B, 0x7F, 0x00, 0x80, 0x07,
-0x12, 0x9F, 0xF0, 0x13, 0x54, 0x01, 0xFF, 0x12,
-0x66, 0xDA, 0x90, 0x86, 0x72, 0xE0, 0xC4, 0x13,
-0x13, 0x54, 0x01, 0xFF, 0x51, 0x48, 0x90, 0x86,
-0x72, 0xE0, 0x54, 0x01, 0xFF, 0x12, 0xAF, 0x10,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE0, 0x54, 0xFE,
-0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x02, 0xFF, 0xEE,
-0x54, 0xFD, 0x4F, 0xFF, 0xF0, 0x12, 0x02, 0xF6,
-0xFE, 0x22, 0xF0, 0xEE, 0x54, 0x08, 0xFE, 0xEF,
-0x54, 0xF7, 0x4E, 0x22, 0x74, 0x03, 0xF0, 0x74,
-0x01, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0x22, 0x90, 0x94, 0xA2, 0xED, 0xF0, 0x90,
-0x94, 0xA1, 0xEF, 0xF0, 0x12, 0x7B, 0x2A, 0x90,
-0x94, 0xAF, 0xEF, 0x12, 0xA7, 0x22, 0x31, 0x8C,
-0x54, 0x3F, 0x90, 0x94, 0xAC, 0xF0, 0xA3, 0xEF,
-0xF0, 0xE4, 0x90, 0x94, 0xAB, 0xF0, 0xB1, 0x18,
-0x50, 0x0D, 0xB1, 0x42, 0xE0, 0x24, 0x00, 0x12,
-0xA7, 0x33, 0xE4, 0xB1, 0x00, 0x80, 0xEF, 0x90,
-0x94, 0xAD, 0xE0, 0x24, 0xF8, 0xFB, 0x90, 0x94,
-0xAC, 0xE0, 0x34, 0xFF, 0xFA, 0x90, 0x94, 0xA2,
-0xE0, 0xFF, 0x90, 0x8A, 0xF5, 0xE4, 0xF0, 0xA3,
-0xEF, 0xF0, 0xA3, 0x74, 0x01, 0xF0, 0x7D, 0x0A,
-0x7C, 0x00, 0x7F, 0x10, 0x7E, 0x00, 0x12, 0x6D,
-0xDB, 0x90, 0x88, 0xD2, 0xE0, 0xFF, 0x90, 0x94,
-0xA1, 0xE0, 0xFD, 0xD3, 0x9F, 0x40, 0x36, 0x90,
-0x88, 0xD2, 0xE0, 0xFC, 0xB1, 0x2D, 0xCE, 0xC3,
-0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xB1, 0x21, 0xEC,
-0xFF, 0xC3, 0xED, 0xB1, 0x38, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0x24, 0x28, 0xFF, 0xE4,
-0x3E, 0xFE, 0xB1, 0x10, 0xFD, 0x90, 0x94, 0xA2,
-0xE0, 0xFC, 0xC3, 0xED, 0x9C, 0xB1, 0x08, 0x7D,
-0x38, 0x7C, 0x00, 0x80, 0x33, 0x90, 0x94, 0xA1,
-0xB1, 0x2B, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8,
-0xF9, 0xB1, 0x21, 0xED, 0xFF, 0x90, 0x88, 0xD2,
-0xB1, 0x36, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
-0xF9, 0x24, 0x38, 0xFD, 0xE4, 0x3E, 0xFC, 0xB1,
-0x10, 0xFF, 0x90, 0x94, 0xA2, 0xE0, 0xFE, 0xC3,
-0xEF, 0x9E, 0xB1, 0x08, 0x7F, 0x28, 0x7E, 0x00,
-0x12, 0x72, 0x06, 0x7B, 0x00, 0x7A, 0x00, 0x79,
-0x00, 0x90, 0x8B, 0x26, 0x12, 0x87, 0x75, 0x0B,
-0x7A, 0x94, 0x79, 0xA3, 0x90, 0x8B, 0x29, 0x12,
-0x87, 0x75, 0x90, 0x8B, 0x2C, 0x74, 0x08, 0xF0,
-0x7A, 0x87, 0x79, 0x84, 0x12, 0x55, 0xCC, 0xE4,
-0x90, 0x94, 0xAB, 0xF0, 0xB1, 0x18, 0x50, 0x1F,
-0xB1, 0x42, 0x90, 0x94, 0xAB, 0xE0, 0x24, 0xA3,
-0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0,
-0xFF, 0x90, 0x94, 0xAE, 0xE0, 0x24, 0x00, 0x12,
-0xA7, 0x33, 0xEF, 0xB1, 0x00, 0x80, 0xDD, 0x22,
-0xF0, 0x90, 0x94, 0xAB, 0xE0, 0x04, 0xF0, 0x22,
-0xFB, 0x90, 0x8A, 0xEC, 0x74, 0x08, 0xF0, 0x22,
-0x90, 0x94, 0xAC, 0xA3, 0xE0, 0x24, 0xF8, 0x22,
-0x90, 0x94, 0xAB, 0xE0, 0xFF, 0xC3, 0x94, 0x08,
-0x22, 0xFF, 0x90, 0x8A, 0xED, 0xEE, 0xF0, 0xA3,
-0xEF, 0xF0, 0x22, 0xE0, 0xFD, 0x75, 0xF0, 0x80,
-0xA4, 0xAE, 0xF0, 0x78, 0x03, 0x22, 0xE0, 0xC3,
-0x9F, 0xFF, 0xE4, 0x94, 0x00, 0xFE, 0xEF, 0x78,
-0x07, 0x22, 0x90, 0x94, 0xAF, 0xE0, 0xFD, 0x90,
-0x94, 0xAD, 0xE0, 0x2D, 0xFD, 0x90, 0x94, 0xAC,
-0xE0, 0x34, 0x00, 0xCD, 0x24, 0x20, 0xCD, 0x34,
-0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F, 0xFF, 0xEE,
-0x3C, 0xFE, 0x90, 0x94, 0xA1, 0xE0, 0xFD, 0x12,
-0x7B, 0xAE, 0x90, 0x94, 0xAE, 0xEF, 0xF0, 0x22,
-0xE0, 0x54, 0xFE, 0x4E, 0xFE, 0xF0, 0x22, 0x90,
-0x00, 0x01, 0x12, 0x03, 0x0F, 0xFF, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96,
-0x4D, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x96,
-0x4C, 0xEF, 0xF0, 0xE4, 0xFD, 0xFC, 0xF1, 0xD3,
-0x90, 0x96, 0x4C, 0xE0, 0x90, 0x04, 0x25, 0xF0,
-0x90, 0x96, 0x4D, 0xE0, 0x60, 0x06, 0x12, 0xD8,
-0x65, 0x44, 0x80, 0xF0, 0xAF, 0x05, 0x74, 0x20,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0x54, 0xC0, 0xF0, 0x12, 0xD8, 0x65, 0x54,
-0xC0, 0xF0, 0x90, 0x96, 0x4F, 0xE0, 0xFF, 0xAE,
-0x05, 0x74, 0x18, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00, 0x8B,
-0xE0, 0xD3, 0x94, 0x03, 0x74, 0x10, 0x2E, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x74, 0x04,
-0xF0, 0x74, 0x12, 0x2E, 0x12, 0xD9, 0x87, 0xE0,
-0x20, 0xE1, 0x19, 0x54, 0x01, 0xFF, 0x90, 0x96,
-0x4E, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0xFB, 0xEF,
-0x44, 0x02, 0x4B, 0xFF, 0x74, 0x12, 0x2D, 0x12,
-0xD9, 0x87, 0xEF, 0xF0, 0xAF, 0x05, 0x74, 0x11,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0x74, 0xFF, 0xF0, 0x74, 0x29, 0x2F, 0xB1, 0x7F,
-0xE0, 0x54, 0xF7, 0xF0, 0xAE, 0x04, 0xAF, 0x05,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x3B, 0x12,
-0xD3, 0xCF, 0xA3, 0xEB, 0xF0, 0x90, 0x04, 0x1D,
-0xE0, 0x60, 0x2B, 0x90, 0x05, 0x22, 0xE0, 0x90,
-0x96, 0x41, 0xF0, 0x7B, 0x14, 0xF1, 0x87, 0xEF,
-0x64, 0x01, 0x70, 0x09, 0x12, 0xD7, 0x45, 0xFF,
-0x12, 0x65, 0x61, 0x80, 0x04, 0x7F, 0x00, 0x80,
-0x19, 0x90, 0x96, 0x41, 0xE0, 0xFD, 0x7B, 0x15,
-0xE4, 0xFF, 0xD1, 0x8F, 0x80, 0x07, 0x12, 0xD7,
-0x45, 0xFF, 0x12, 0x65, 0x61, 0x12, 0xA2, 0x89,
-0x7F, 0x01, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xFD,
-0xD1, 0x35, 0xE4, 0xFB, 0xFD, 0x7F, 0xFF, 0x90,
-0x05, 0x22, 0xED, 0xF0, 0x90, 0x94, 0xBC, 0xEB,
-0xF0, 0x22, 0x90, 0x94, 0xC4, 0xE0, 0x30, 0xE0,
-0x4E, 0x90, 0x94, 0xC7, 0xE0, 0x70, 0x22, 0x7B,
-0x16, 0x7D, 0x6F, 0xF1, 0x89, 0xF1, 0x60, 0xF1,
-0x6A, 0x7D, 0x01, 0xD1, 0x35, 0xF1, 0x60, 0xF1,
-0x9A, 0xE0, 0x44, 0x01, 0xF0, 0xF1, 0x7E, 0x12,
-0xC2, 0x3E, 0x90, 0x94, 0xC7, 0x74, 0x01, 0xF0,
-0x22, 0x90, 0x94, 0xC7, 0xE0, 0x64, 0x01, 0x70,
-0x1C, 0xF1, 0x60, 0xFF, 0xF1, 0x9A, 0xE0, 0x30,
-0xE0, 0x13, 0xF1, 0x69, 0x7D, 0x01, 0xD1, 0x35,
-0xF1, 0x7E, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54,
-0x7E, 0x01, 0x02, 0x61, 0x41, 0xD1, 0xF0, 0x22,
-0x90, 0x94, 0xC5, 0xE0, 0xFF, 0xC3, 0x13, 0xFE,
-0xEF, 0x54, 0xF1, 0xFF, 0xEE, 0x04, 0x54, 0x07,
-0x25, 0xE0, 0x4F, 0xF0, 0xA3, 0xE0, 0xFF, 0xF1,
-0x90, 0xB5, 0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0,
-0x12, 0xC2, 0x0F, 0xE4, 0x90, 0x94, 0xC7, 0xF0,
-0x12, 0xA3, 0xB7, 0xF1, 0x90, 0x12, 0xD7, 0xC4,
-0xE0, 0xFA, 0xED, 0x12, 0x8F, 0x83, 0xFC, 0x54,
-0x03, 0xFD, 0xEC, 0x13, 0x13, 0x54, 0x07, 0xFB,
-0xEE, 0x12, 0xD8, 0x98, 0xAF, 0x02, 0x12, 0xCA,
-0xE8, 0xF1, 0x60, 0x12, 0x8F, 0x83, 0x12, 0x8B,
-0x05, 0xF1, 0x60, 0xFF, 0x75, 0xF0, 0x0E, 0xA4,
-0x24, 0xD3, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
-0x83, 0xE0, 0x04, 0xF0, 0xF1, 0x69, 0xD1, 0x87,
-0xF1, 0x60, 0xFD, 0x7F, 0x01, 0x02, 0x8F, 0xC2,
-0x90, 0x94, 0xC5, 0xE0, 0xC3, 0x13, 0x54, 0x07,
-0x22, 0xEF, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0xD4,
-0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0,
-0xFF, 0x7E, 0x00, 0xE4, 0xFB, 0x22, 0xE4, 0x90,
-0x91, 0x6E, 0xF0, 0xA3, 0x74, 0x03, 0x22, 0x7D,
-0xFF, 0x7F, 0xFF, 0xD1, 0x8F, 0x02, 0xA3, 0xB7,
-0x90, 0x94, 0xC5, 0xE0, 0xFE, 0xC3, 0x13, 0x54,
-0x07, 0x22, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0xD0,
-0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22,
-0x90, 0x94, 0xC4, 0xE0, 0x30, 0xE0, 0x23, 0xA3,
-0xE0, 0xC3, 0x13, 0x54, 0x07, 0xFF, 0xF1, 0x9A,
-0xE0, 0xFE, 0x30, 0xE0, 0x15, 0xEF, 0xF1, 0x9A,
-0xEE, 0x54, 0xFE, 0xF0, 0x90, 0x94, 0xC7, 0x74,
-0x05, 0xF0, 0xF1, 0x60, 0xFD, 0x7F, 0x02, 0x12,
-0x8F, 0xC2, 0x22, 0x12, 0x7B, 0x2A, 0x7C, 0x00,
-0xAD, 0x07, 0x22, 0x75, 0x48, 0x10, 0xE4, 0xF5,
-0x49, 0x75, 0x4A, 0x07, 0x75, 0x4B, 0x02, 0xF5,
-0x50, 0x90, 0x01, 0x30, 0xE5, 0x48, 0xF0, 0xA3,
-0xE5, 0x49, 0xF0, 0xA3, 0xE5, 0x4A, 0xF0, 0xA3,
-0xE5, 0x4B, 0xF0, 0x90, 0x01, 0x20, 0xE5, 0x50,
-0xF0, 0x22, 0x75, 0x52, 0x06, 0x75, 0x53, 0x01,
-0x75, 0x54, 0x03, 0x75, 0x55, 0x62, 0x90, 0x01,
-0x38, 0xE5, 0x52, 0xF0, 0xA3, 0xE5, 0x53, 0xF0,
-0xA3, 0xE5, 0x54, 0xF0, 0xA3, 0xE5, 0x55, 0xF0,
-0x22, 0x90, 0x01, 0xE4, 0x74, 0x04, 0xF0, 0xA3,
-0xE4, 0xF0, 0x22, 0x7D, 0x02, 0x90, 0x01, 0xC4,
-0x74, 0x2B, 0xF0, 0x74, 0xC0, 0xA3, 0xF0, 0x90,
-0x94, 0xC3, 0xE0, 0xFF, 0xED, 0xC3, 0x9F, 0x50,
-0x18, 0xED, 0x25, 0xE0, 0x24, 0x81, 0xF8, 0xE6,
-0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8, 0x74, 0x08,
-0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22, 0x0D, 0x80,
-0xDE, 0x7F, 0x01, 0x22, 0x90, 0x84, 0xA1, 0x74,
-0x02, 0xF0, 0xA3, 0x74, 0x9A, 0xF0, 0xA3, 0x74,
-0x26, 0xF0, 0x90, 0x84, 0xA7, 0x74, 0x80, 0xF0,
-0xA3, 0x74, 0x03, 0xF0, 0x22, 0xE4, 0xFB, 0xFA,
-0xFD, 0x7F, 0x01, 0x12, 0x86, 0x4E, 0x90, 0x92,
-0x83, 0xEF, 0xF0, 0x60, 0xF0, 0x90, 0x84, 0xC1,
-0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0, 0x60, 0xE5,
-0xC2, 0xAF, 0xEF, 0x30, 0xE1, 0x0A, 0x90, 0x84,
-0xC1, 0xE0, 0x54, 0xFD, 0xF0, 0x12, 0x60, 0x5D,
-0x11, 0xC0, 0x30, 0xE2, 0x06, 0x54, 0xFB, 0xF0,
-0x12, 0x6A, 0x6D, 0x11, 0xC0, 0x30, 0xE4, 0x0C,
-0x54, 0xEF, 0xF0, 0x12, 0x6F, 0x22, 0xBF, 0x01,
-0x03, 0x12, 0x98, 0x9C, 0xD2, 0xAF, 0x80, 0xC5,
-0xD2, 0xAF, 0xC2, 0xAF, 0x90, 0x84, 0xC1, 0xE0,
-0xFF, 0x22, 0x8F, 0x16, 0x7F, 0x02, 0x12, 0x86,
-0x27, 0x90, 0x84, 0xC1, 0xE0, 0x45, 0x16, 0xF0,
-0x22, 0x12, 0x40, 0xB9, 0x7F, 0x02, 0x80, 0xEA,
-0x90, 0x86, 0x72, 0xE0, 0x30, 0xE0, 0x04, 0x7F,
-0x10, 0x11, 0xCA, 0x22, 0xC0, 0xE0, 0xC0, 0xF0,
-0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0,
-0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0,
-0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x90, 0x01, 0xC4, 0x74, 0xEC, 0xF0, 0x74,
-0xC0, 0xA3, 0xF0, 0x12, 0x71, 0x90, 0xE5, 0x4C,
-0x30, 0xE3, 0x02, 0x11, 0xE0, 0xE5, 0x4C, 0x30,
-0xE4, 0x02, 0x11, 0xD9, 0xE5, 0x4C, 0x30, 0xE5,
-0x03, 0x12, 0xC9, 0xF7, 0xE5, 0x4C, 0x30, 0xE6,
-0x03, 0x12, 0xC8, 0x62, 0xE5, 0x4E, 0x30, 0xE0,
-0x03, 0x12, 0xAD, 0x0B, 0xE5, 0x4E, 0x30, 0xE1,
-0x02, 0x91, 0x47, 0xE5, 0x4E, 0x30, 0xE2, 0x03,
-0x12, 0xC8, 0x6F, 0xE5, 0x4E, 0x30, 0xE3, 0x02,
-0x31, 0x95, 0xE5, 0x4E, 0x30, 0xE4, 0x02, 0x71,
-0x0A, 0xE5, 0x4E, 0x30, 0xE5, 0x02, 0x51, 0xEF,
-0xE5, 0x4E, 0x30, 0xE6, 0x02, 0x31, 0xA6, 0xE5,
-0x4F, 0x30, 0xE1, 0x03, 0x12, 0x97, 0xB2, 0x74,
-0xEC, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xC0,
-0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05,
-0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83,
-0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x71, 0x25, 0x70,
-0x0C, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x06, 0x71,
-0xEE, 0x51, 0xC8, 0x51, 0x3E, 0x22, 0xE4, 0xFF,
-0x12, 0x77, 0x39, 0xBF, 0x01, 0x10, 0x90, 0x85,
-0xC5, 0xE0, 0x60, 0x0A, 0x31, 0xBF, 0xF0, 0x54,
-0x07, 0x70, 0x03, 0x12, 0x93, 0x5C, 0x22, 0x90,
-0x85, 0xC9, 0xE0, 0x54, 0xFE, 0x22, 0xE4, 0xF5,
-0x15, 0x90, 0x06, 0xA9, 0xE0, 0xF5, 0x15, 0x54,
-0xC0, 0x70, 0x09, 0x31, 0xBF, 0xF0, 0x54, 0xFD,
-0xF0, 0x02, 0x93, 0x5C, 0xE5, 0x15, 0x30, 0xE6,
-0x18, 0x90, 0x85, 0xC5, 0xE0, 0x64, 0x01, 0x70,
-0x13, 0x51, 0xB7, 0x64, 0x02, 0x60, 0x05, 0x12,
-0x77, 0x61, 0x80, 0x08, 0x12, 0x79, 0x41, 0x80,
-0x03, 0x31, 0xBF, 0xF0, 0xE5, 0x15, 0x90, 0x85,
-0xC9, 0x30, 0xE7, 0x06, 0x51, 0xC5, 0x51, 0x3E,
-0x41, 0xD6, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90,
-0x94, 0xC5, 0xE0, 0xC3, 0x13, 0x54, 0x07, 0xFF,
-0x75, 0xF0, 0x0E, 0xA4, 0x24, 0xD2, 0xF5, 0x82,
-0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0xFE, 0xEF,
-0x75, 0xF0, 0x0E, 0xA4, 0x24, 0xD1, 0xF5, 0x82,
-0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0x90, 0x91,
-0x6F, 0xF0, 0x90, 0x91, 0x6E, 0xEE, 0xF0, 0xE4,
-0xFB, 0xFD, 0x7F, 0x54, 0x7E, 0x01, 0x02, 0x61,
-0x41, 0x90, 0x06, 0xA9, 0xE0, 0x90, 0x92, 0xB1,
-0xF0, 0xE0, 0xFD, 0x54, 0xC0, 0x70, 0x05, 0x31,
-0xBF, 0xF0, 0x80, 0x57, 0xED, 0x30, 0xE6, 0x3F,
-0x90, 0x85, 0xC5, 0xE0, 0x64, 0x02, 0x70, 0x27,
-0x90, 0x85, 0xC1, 0xE0, 0xFF, 0xC3, 0x13, 0x20,
-0xE0, 0x09, 0x90, 0x85, 0xC9, 0xE0, 0x44, 0x01,
-0xF0, 0x80, 0x1A, 0x51, 0xBE, 0x64, 0x01, 0x70,
-0x21, 0x90, 0x85, 0xC9, 0xE0, 0x44, 0x04, 0xF0,
-0x7F, 0x01, 0x12, 0x62, 0x8E, 0x80, 0x13, 0x51,
-0xB7, 0x64, 0x02, 0x60, 0x05, 0x12, 0x77, 0x61,
-0x80, 0x08, 0x12, 0x79, 0x41, 0x80, 0x03, 0x31,
-0xBF, 0xF0, 0x90, 0x92, 0xB1, 0xE0, 0x90, 0x85,
-0xC9, 0x30, 0xE7, 0x06, 0x51, 0xC5, 0x51, 0x3E,
-0x80, 0x24, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90,
-0x85, 0xC9, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x85,
-0xC3, 0xE0, 0x54, 0x0F, 0x22, 0xE0, 0x44, 0x02,
-0xF0, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x90, 0x86,
-0x6E, 0xE0, 0x90, 0x91, 0x6F, 0x22, 0x90, 0x85,
-0xC1, 0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90, 0x94,
-0xC4, 0xE0, 0x30, 0xE0, 0x09, 0xF1, 0xC0, 0xE4,
-0x90, 0x94, 0xC7, 0xF0, 0x51, 0x0F, 0x22, 0xE4,
-0xFF, 0x12, 0x77, 0x39, 0xBF, 0x01, 0x12, 0x90,
-0x85, 0xC5, 0xE0, 0x60, 0x0C, 0x51, 0xBE, 0x64,
-0x02, 0x60, 0x03, 0x02, 0x77, 0x61, 0x12, 0x79,
-0x41, 0x22, 0x71, 0x25, 0x70, 0x16, 0x90, 0x85,
-0xC5, 0xE0, 0x60, 0x10, 0x71, 0xEE, 0xF0, 0x90,
-0x85, 0xC1, 0xE0, 0x91, 0x19, 0x54, 0x07, 0x70,
-0x03, 0x12, 0x93, 0x5C, 0x22, 0xE4, 0xFF, 0x12,
-0x77, 0x39, 0xEF, 0x64, 0x01, 0x22, 0x12, 0x96,
-0x9A, 0x30, 0xE0, 0x10, 0xEF, 0xC4, 0x13, 0x13,
-0x54, 0x03, 0x30, 0xE0, 0x07, 0x7D, 0x02, 0x7F,
-0x02, 0x12, 0x7C, 0x41, 0x91, 0x24, 0x30, 0xE0,
-0x08, 0x91, 0x18, 0x54, 0x07, 0x70, 0x37, 0x80,
-0x32, 0x91, 0x2E, 0x40, 0x2E, 0x71, 0x25, 0x70,
-0x2D, 0x51, 0xBE, 0x70, 0x05, 0x12, 0x70, 0xDB,
-0x80, 0x25, 0x12, 0x70, 0xDB, 0x90, 0x85, 0xCF,
-0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94, 0x02, 0x40,
-0x09, 0x71, 0x87, 0xE4, 0x90, 0x85, 0xCF, 0xF0,
-0x80, 0x03, 0x12, 0x79, 0x41, 0xE4, 0x90, 0x85,
-0xCE, 0xF0, 0x22, 0x12, 0x93, 0x5C, 0x22, 0x90,
-0x85, 0xC2, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0xE4,
-0x90, 0x92, 0xB6, 0xF0, 0x90, 0x85, 0xC5, 0xE0,
-0x60, 0x53, 0x71, 0x25, 0x70, 0x4F, 0xF1, 0xC7,
-0xF0, 0x12, 0xD7, 0x78, 0xF0, 0x90, 0x92, 0xB6,
-0x74, 0x01, 0xF0, 0xE4, 0x90, 0x85, 0xCC, 0xF0,
-0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x16, 0x90,
-0x85, 0xC0, 0xE0, 0xB4, 0x02, 0x05, 0xE4, 0x90,
-0x92, 0xB6, 0xF0, 0x12, 0x96, 0xA5, 0xEF, 0x70,
-0x04, 0x90, 0x92, 0xB6, 0xF0, 0x90, 0x92, 0xB6,
-0xE0, 0x60, 0x1A, 0x90, 0x85, 0xC8, 0xE0, 0x20,
-0xE2, 0x03, 0x12, 0x93, 0x70, 0xF1, 0xCF, 0xE4,
-0x90, 0x91, 0x6E, 0xF0, 0x90, 0x85, 0xCD, 0xE0,
-0x90, 0x91, 0x6F, 0x51, 0x3E, 0x22, 0x90, 0x01,
-0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x02,
-0x22, 0x90, 0x01, 0x57, 0xE0, 0x60, 0x18, 0x71,
-0xF1, 0xF0, 0x91, 0x24, 0x30, 0xE0, 0x02, 0x80,
-0x0F, 0x91, 0x2E, 0x40, 0x0A, 0xE4, 0xFF, 0x12,
-0x77, 0x39, 0xBF, 0x01, 0x02, 0x71, 0x87, 0x22,
-0xEF, 0x54, 0xFB, 0xF0, 0x90, 0x85, 0xC9, 0xE0,
-0x54, 0xFD, 0xF0, 0x22, 0x90, 0x85, 0xC1, 0xE0,
-0xFF, 0x13, 0x13, 0x54, 0x3F, 0x22, 0x90, 0x85,
-0xCE, 0xE0, 0x04, 0xF0, 0x90, 0x85, 0xC9, 0xE0,
-0x54, 0xEF, 0xF0, 0x90, 0x86, 0x6D, 0xE0, 0xFF,
-0x90, 0x85, 0xCE, 0xE0, 0xD3, 0x9F, 0x22, 0x90,
-0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x06, 0x90, 0x85,
-0xBE, 0x74, 0x01, 0xF0, 0x90, 0x85, 0xC5, 0xE0,
-0x70, 0x02, 0xA1, 0x00, 0x90, 0x85, 0xDC, 0xE0,
-0x04, 0xF0, 0x90, 0x05, 0x61, 0x12, 0x8C, 0xCD,
-0x78, 0x08, 0x12, 0x04, 0xD8, 0xA8, 0x04, 0xA9,
-0x05, 0xAA, 0x06, 0xAB, 0x07, 0x90, 0x05, 0x60,
-0x12, 0x8C, 0xCD, 0x12, 0x87, 0x47, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05,
-0x62, 0x12, 0x8C, 0xCD, 0x78, 0x10, 0x12, 0x04,
-0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x87, 0x47, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0xA3, 0x12, 0x8C, 0xCD,
-0x78, 0x18, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x47,
-0x90, 0x85, 0xFC, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x94, 0xFF, 0xE0, 0x54, 0xFE, 0xF0, 0xE0,
-0xC3, 0x13, 0x30, 0xE0, 0x0C, 0xF1, 0x1C, 0x12,
-0x51, 0x7D, 0x90, 0x94, 0xFF, 0xE0, 0x54, 0xFD,
-0xF0, 0x12, 0x96, 0x9A, 0x30, 0xE0, 0x0A, 0x90,
-0x01, 0x3B, 0xE0, 0x30, 0xE4, 0x03, 0x12, 0xAC,
-0xC6, 0x90, 0x96, 0x67, 0xE0, 0x04, 0xF0, 0xE0,
-0xC3, 0x94, 0x80, 0x40, 0x0B, 0x90, 0x01, 0x98,
-0xE0, 0x54, 0xFE, 0xF0, 0xE0, 0x44, 0x01, 0xF0,
-0x12, 0x5D, 0x1F, 0x12, 0x6E, 0x1D, 0xE4, 0x90,
-0x88, 0xE0, 0xF0, 0x12, 0xD1, 0xBF, 0x12, 0x97,
-0xF5, 0x30, 0xE0, 0x51, 0x90, 0x88, 0x76, 0xE0,
-0xFE, 0xA3, 0xE0, 0xFF, 0x7C, 0x00, 0x7D, 0x64,
-0x12, 0x03, 0x82, 0x90, 0x88, 0xCA, 0xE0, 0x6E,
-0x70, 0x03, 0xA3, 0xE0, 0x6F, 0x60, 0x0A, 0x90,
-0x88, 0xCA, 0xE4, 0x75, 0xF0, 0x01, 0x02, 0x07,
-0x0A, 0x90, 0x88, 0x7A, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x90, 0x88, 0x88, 0xE0, 0xB5, 0x06, 0x14,
-0xA3, 0xE0, 0xB5, 0x07, 0x0F, 0xEF, 0x4E, 0x60,
-0x0B, 0x90, 0x01, 0xC7, 0x74, 0x31, 0xF0, 0x7F,
-0x01, 0x02, 0x5F, 0xE9, 0xB1, 0x66, 0xE4, 0x90,
-0x88, 0xCA, 0xF0, 0xA3, 0xF0, 0x22, 0xE4, 0x90,
-0x92, 0xB4, 0xF0, 0xA3, 0xF0, 0x90, 0x06, 0x32,
-0xE0, 0x44, 0x20, 0xF0, 0x12, 0x75, 0xE4, 0xEF,
-0x64, 0x01, 0x70, 0x73, 0x90, 0x88, 0xD9, 0xE0,
-0xFF, 0x90, 0x96, 0x4F, 0x74, 0x0A, 0xF0, 0x7B,
-0x08, 0x7D, 0x01, 0x12, 0xBD, 0x87, 0x90, 0x92,
-0xB1, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x92,
-0xB1, 0x12, 0xD7, 0x1C, 0x90, 0x92, 0xB3, 0xEF,
-0xF0, 0x90, 0x92, 0xB1, 0x12, 0xA7, 0xC7, 0xE4,
-0xFD, 0x12, 0x52, 0x21, 0x90, 0x92, 0xB3, 0xE0,
-0xFF, 0x90, 0x92, 0xB2, 0xE0, 0x2F, 0xFF, 0x90,
-0x92, 0xB1, 0xE0, 0x34, 0x00, 0xCF, 0x24, 0x30,
-0xCF, 0x34, 0x00, 0xFE, 0x90, 0x92, 0xB4, 0xF0,
-0xA3, 0xEF, 0xF0, 0x12, 0xB6, 0xB9, 0xB1, 0xF0,
-0x90, 0x88, 0xD9, 0xE0, 0xFB, 0xE4, 0xFF, 0x12,
-0x15, 0x44, 0xB1, 0xF0, 0x90, 0x88, 0xD5, 0xE0,
-0xFB, 0x7F, 0x11, 0x12, 0x15, 0x44, 0x12, 0xA2,
-0x89, 0x90, 0x88, 0x88, 0x12, 0xB6, 0xB2, 0x22,
-0x90, 0x92, 0xB4, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD,
-0x22, 0x41, 0xDE, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0,
-0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
-0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
-0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0x90, 0x01, 0xC4, 0x74, 0xFB, 0xF0, 0x74, 0xC5,
-0xA3, 0xF0, 0x12, 0x75, 0x28, 0xE5, 0x56, 0x30,
-0xE1, 0x02, 0xD1, 0x9C, 0xE5, 0x56, 0x30, 0xE2,
-0x02, 0xD1, 0xA7, 0xE5, 0x56, 0x30, 0xE5, 0x02,
-0xB1, 0xF9, 0xE5, 0x57, 0x30, 0xE0, 0x02, 0xD1,
-0xE9, 0xE5, 0x58, 0x30, 0xE1, 0x02, 0xF1, 0x77,
-0xE5, 0x58, 0x30, 0xE0, 0x03, 0x12, 0xC8, 0x98,
-0xE5, 0x58, 0x30, 0xE4, 0x02, 0xF1, 0xBF, 0xE5,
-0x59, 0x30, 0xE1, 0x04, 0x7F, 0x04, 0x11, 0xCA,
-0xE5, 0x59, 0x30, 0xE4, 0x03, 0x12, 0xAC, 0x8F,
-0xE5, 0x59, 0x30, 0xE5, 0x02, 0xD1, 0xBD, 0xE5,
-0x59, 0x30, 0xE6, 0x02, 0xF1, 0x2A, 0x74, 0xFB,
-0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xC5, 0xA3,
-0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0,
-0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
-0xF0, 0xD0, 0xE0, 0x32, 0x90, 0x85, 0xC5, 0xE0,
-0x60, 0x02, 0x71, 0x2E, 0x02, 0xBE, 0x9A, 0x90,
-0x85, 0xC5, 0xE0, 0x60, 0x0F, 0x90, 0x06, 0x92,
-0xE0, 0x30, 0xE1, 0x03, 0x02, 0x6B, 0x98, 0xF1,
-0xD7, 0x12, 0x93, 0x5C, 0x22, 0x90, 0x85, 0xC1,
-0xE0, 0xFF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x30,
-0xE0, 0x1A, 0xEF, 0x54, 0xBF, 0xF1, 0x64, 0x30,
-0xE0, 0x06, 0xE0, 0x44, 0x01, 0xF0, 0x80, 0x09,
-0xE0, 0x54, 0xFE, 0xF0, 0xF1, 0x6D, 0x74, 0x04,
-0xF0, 0x12, 0x93, 0x5C, 0xE4, 0xFF, 0x02, 0x68,
-0x8F, 0x12, 0xCB, 0x9E, 0x90, 0x92, 0xB6, 0xEF,
-0xF0, 0x30, 0xE0, 0x05, 0x7D, 0x01, 0xE4, 0x80,
-0x02, 0xE4, 0xFD, 0xFF, 0x12, 0x57, 0x82, 0x90,
-0x92, 0xB6, 0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01,
-0x2F, 0xE0, 0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80,
-0x06, 0x90, 0x01, 0x2F, 0x74, 0x80, 0xF0, 0xF1,
-0x1C, 0x02, 0x51, 0x7D, 0x90, 0x85, 0xD7, 0xE0,
-0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x85, 0xDE, 0xE0,
-0xFB, 0x22, 0x90, 0x85, 0xC1, 0xE0, 0xFF, 0x12,
-0x9F, 0x8F, 0x30, 0xE0, 0x1F, 0xEF, 0x54, 0x7F,
-0xF1, 0x64, 0x30, 0xE1, 0x06, 0xE0, 0x44, 0x02,
-0xF0, 0x80, 0x08, 0xE0, 0x54, 0xFD, 0xF0, 0xF1,
-0x6D, 0x04, 0xF0, 0x90, 0x85, 0xC5, 0xE0, 0x60,
-0x03, 0x12, 0x93, 0x5C, 0x7F, 0x01, 0x12, 0x68,
-0x8F, 0x90, 0x04, 0xE0, 0xE0, 0x30, 0xE1, 0x03,
-0x12, 0xBF, 0xA8, 0x22, 0xF0, 0x90, 0x04, 0xE0,
-0xE0, 0x90, 0x85, 0xC2, 0x22, 0x90, 0x01, 0xB9,
-0x74, 0x01, 0xF0, 0x90, 0x01, 0xB8, 0x22, 0x90,
-0x85, 0xBC, 0xE0, 0xFF, 0x30, 0xE0, 0x3F, 0x90,
-0x85, 0xC0, 0xE0, 0x7E, 0x00, 0xB4, 0x02, 0x02,
-0x7E, 0x01, 0x90, 0x85, 0xBF, 0xE0, 0x7D, 0x00,
-0xB4, 0x04, 0x02, 0x7D, 0x01, 0xED, 0x4E, 0x70,
-0x25, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x03, 0x02,
-0xAD, 0x29, 0x71, 0xF9, 0x90, 0x85, 0xC0, 0xE0,
-0xB4, 0x0C, 0x06, 0xE4, 0xFD, 0x7F, 0x08, 0x80,
-0x0A, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x04, 0x06,
-0xE4, 0xFD, 0xFF, 0x12, 0x93, 0x74, 0x22, 0x22,
-0x7D, 0x20, 0xE4, 0xFF, 0x02, 0x7B, 0xBF, 0x90,
-0x85, 0xCB, 0xE0, 0x90, 0x05, 0x73, 0x22, 0x90,
-0x85, 0xC9, 0xE0, 0x44, 0x10, 0xF0, 0x22, 0x90,
-0x85, 0xC1, 0xE0, 0x54, 0xF7, 0xF0, 0x22, 0x32,
-0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82,
-0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0,
-0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4,
-0x74, 0xE0, 0xF0, 0x74, 0xC7, 0xA3, 0xF0, 0x12,
-0x6C, 0xBC, 0x74, 0xE0, 0x04, 0x90, 0x01, 0xC4,
-0xF0, 0x74, 0xC7, 0xA3, 0xF0, 0xD0, 0x07, 0xD0,
-0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0,
-0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32,
-0x32, 0xC0, 0xE0, 0xC0, 0x83, 0xC0, 0x82, 0xC0,
-0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x05, 0xC0, 0x07,
-0x7D, 0x31, 0x90, 0x01, 0xC4, 0xED, 0xF0, 0x74,
-0xC8, 0xFF, 0xA3, 0xF0, 0xED, 0x04, 0x90, 0x01,
-0xC4, 0xF0, 0xA3, 0xEF, 0xF0, 0xD0, 0x07, 0xD0,
-0x05, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
-0xE0, 0x32, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0,
-0x05, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x90,
-0x88, 0xE7, 0xE0, 0x04, 0xF0, 0x90, 0x85, 0xBC,
-0xE0, 0xFF, 0x30, 0xE0, 0x05, 0x12, 0x97, 0x71,
-0x60, 0x15, 0x90, 0x85, 0xC5, 0xE0, 0x70, 0x04,
-0xEF, 0x30, 0xE0, 0x0B, 0x90, 0x85, 0xC8, 0xE0,
-0x64, 0x02, 0x60, 0x03, 0x12, 0xAB, 0x62, 0x22,
-0x90, 0x85, 0xBC, 0xE0, 0xFF, 0x30, 0xE0, 0x3F,
-0x90, 0x85, 0xC0, 0xE0, 0x7E, 0x00, 0xB4, 0x02,
-0x02, 0x7E, 0x01, 0x90, 0x85, 0xBF, 0xE0, 0x7D,
-0x00, 0xB4, 0x04, 0x02, 0x7D, 0x01, 0xED, 0x4E,
-0x70, 0x25, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x03,
-0x02, 0xAD, 0x29, 0x12, 0x97, 0x59, 0x90, 0x85,
-0xC0, 0xE0, 0xB4, 0x08, 0x06, 0xE4, 0xFD, 0x7F,
-0x0C, 0x80, 0x09, 0x90, 0x85, 0xC0, 0xE0, 0x70,
-0x06, 0xFD, 0x7F, 0x04, 0x12, 0x93, 0x74, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x94, 0xF9, 0xE0, 0x60, 0x25, 0x7F, 0x54, 0x7E,
-0x09, 0x12, 0x70, 0x61, 0x31, 0x88, 0xEF, 0x44,
-0xFE, 0xFF, 0xEE, 0x44, 0x03, 0xFE, 0xED, 0x44,
-0x04, 0xFD, 0xEC, 0x31, 0x88, 0x90, 0x91, 0x66,
-0x12, 0x04, 0xEB, 0x7F, 0x54, 0x7E, 0x09, 0x12,
-0x71, 0x18, 0x90, 0x94, 0xF4, 0xE0, 0x70, 0x24,
-0x90, 0x07, 0xCC, 0xE0, 0x30, 0xE0, 0x1D, 0xE4,
-0xF0, 0x90, 0x92, 0x74, 0x74, 0x22, 0xF0, 0x90,
-0x92, 0x82, 0x74, 0x01, 0xF0, 0x90, 0x92, 0x76,
-0x74, 0x03, 0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79,
-0x74, 0x12, 0x87, 0xB7, 0x90, 0x94, 0xFC, 0xE0,
-0xFF, 0x70, 0x0A, 0x90, 0x94, 0xF9, 0xE0, 0x70,
-0x04, 0xA3, 0xE0, 0x60, 0x15, 0x90, 0x00, 0x1F,
-0xE0, 0x54, 0xF0, 0xF0, 0x90, 0x01, 0xC5, 0x74,
-0xEA, 0xF0, 0xA3, 0x74, 0xEF, 0xF0, 0xA3, 0x74,
-0xFD, 0xF0, 0xEF, 0x60, 0x06, 0x90, 0x01, 0xC4,
-0x74, 0x07, 0xF0, 0x90, 0x94, 0xF9, 0xE0, 0x60,
-0x06, 0x90, 0x01, 0xC4, 0x74, 0x01, 0xF0, 0x90,
-0x94, 0xFA, 0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4,
-0x74, 0x02, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x90, 0x92, 0x70, 0x12, 0x04, 0xEB, 0x90, 0x92,
-0x70, 0x02, 0x87, 0x54, 0x7E, 0x00, 0x7F, 0x2E,
-0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0xC4,
-0x02, 0x06, 0xDE, 0x90, 0x01, 0x94, 0xE0, 0x44,
-0x01, 0xF0, 0x90, 0x01, 0xC7, 0xE4, 0xF0, 0x22,
-0x90, 0x01, 0x9A, 0xE0, 0x54, 0xC0, 0x44, 0x0B,
-0xF0, 0x7F, 0x0A, 0x7E, 0x00, 0x12, 0x7C, 0x9F,
-0x90, 0x01, 0x98, 0xE0, 0x54, 0xC0, 0x7F, 0x00,
-0xB4, 0x40, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x01,
-0x98, 0xE4, 0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x11,
-0xF0, 0xA3, 0xE4, 0xF0, 0x7F, 0x0A, 0xFE, 0x12,
-0x7C, 0x9F, 0x90, 0x01, 0x99, 0xE0, 0x54, 0x30,
-0xFF, 0x64, 0x10, 0x60, 0x04, 0xEF, 0xB4, 0x20,
-0x03, 0x7F, 0x01, 0x22, 0x7F, 0x00, 0x22, 0x90,
-0x01, 0xCF, 0xE0, 0x90, 0x92, 0xB1, 0xF0, 0xE0,
-0xFF, 0x30, 0xE0, 0x07, 0x90, 0x01, 0xCF, 0xE0,
-0x54, 0xFE, 0xF0, 0xEF, 0x30, 0xE5, 0x23, 0x90,
-0x01, 0xCF, 0xE0, 0x54, 0xDF, 0xF0, 0x90, 0x01,
-0x34, 0x74, 0x20, 0xF0, 0xE4, 0xF5, 0xA8, 0xF5,
-0xE8, 0x12, 0x75, 0xB6, 0x90, 0x00, 0x03, 0xE0,
-0x54, 0xFB, 0xFD, 0x7F, 0x03, 0x12, 0x7B, 0x3E,
-0x80, 0xFE, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x1A,
-0x90, 0x05, 0x22, 0xE0, 0x54, 0x90, 0x60, 0x07,
-0x90, 0x01, 0xC0, 0xE0, 0x44, 0x08, 0xF0, 0x90,
-0x01, 0xC6, 0xE0, 0x30, 0xE1, 0xE4, 0x7F, 0x00,
-0x80, 0x02, 0x7F, 0x01, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xC3, 0xEE, 0x94, 0x01, 0x40, 0x0A, 0x0D,
-0xED, 0x13, 0x90, 0xFD, 0x10, 0xF0, 0xE4, 0x2F,
-0xFF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x96, 0x08, 0xEC, 0xF0, 0xA3, 0xED,
-0xF0, 0x90, 0x96, 0x07, 0xEF, 0xF0, 0xA3, 0xA3,
-0xE0, 0xFD, 0x12, 0x7B, 0xE0, 0x90, 0x96, 0x12,
-0x12, 0x04, 0xEB, 0x90, 0x96, 0x0A, 0x12, 0x87,
-0x54, 0x12, 0x04, 0xA7, 0x90, 0x96, 0x12, 0x71,
-0x70, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x90, 0x96, 0x0A, 0x12, 0x87, 0x54, 0x90,
-0x96, 0x0E, 0x71, 0x70, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x47, 0x90,
-0x96, 0x16, 0x12, 0x04, 0xEB, 0x90, 0x96, 0x08,
-0xA3, 0xE0, 0xFD, 0xC0, 0x05, 0x90, 0x96, 0x16,
-0x12, 0x87, 0x54, 0x90, 0x8D, 0x9D, 0x12, 0x04,
-0xEB, 0x90, 0x96, 0x07, 0xE0, 0xFF, 0xD0, 0x05,
-0x12, 0x78, 0xDD, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x96, 0x50, 0xEF, 0xF0, 0xED, 0x64, 0x01, 0x70,
-0x30, 0xEB, 0xB4, 0x01, 0x07, 0xE0, 0x24, 0x02,
-0xF5, 0x17, 0x80, 0x08, 0x90, 0x96, 0x50, 0xE0,
-0x24, 0xFE, 0xF5, 0x17, 0x90, 0x96, 0x0A, 0x12,
-0x04, 0xF7, 0x00, 0x00, 0x00, 0xFF, 0xAF, 0x17,
-0xE4, 0xFC, 0xFD, 0xFE, 0x71, 0x5E, 0x12, 0x04,
-0xF7, 0x00, 0x00, 0x00, 0xFF, 0xAF, 0x17, 0x80,
-0x1E, 0x90, 0x96, 0x0A, 0x12, 0x04, 0xF7, 0x00,
-0x00, 0x00, 0xFF, 0x90, 0x96, 0x50, 0x12, 0x8C,
-0xCD, 0x71, 0x5E, 0x12, 0x04, 0xF7, 0x00, 0x00,
-0x00, 0xFF, 0x90, 0x96, 0x50, 0xE0, 0xFF, 0xE4,
-0xFC, 0xFD, 0xFE, 0x90, 0x96, 0x0E, 0x12, 0x04,
-0xEB, 0x7D, 0x18, 0x7C, 0x00, 0x7F, 0x01, 0x51,
-0x72, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x96,
-0x0E, 0x12, 0x04, 0xEB, 0x7D, 0x18, 0x7C, 0x00,
-0xE4, 0xFF, 0x51, 0x72, 0x90, 0x96, 0x0A, 0x22,
-0x12, 0x87, 0x60, 0x02, 0x87, 0x3A, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0xFE, 0xFD,
-0xEF, 0xB4, 0x01, 0x0D, 0xEB, 0xB4, 0x02, 0x03,
-0x0D, 0x80, 0x06, 0xEB, 0xB4, 0x01, 0x02, 0x7D,
-0x02, 0xAF, 0x06, 0xEF, 0xC4, 0x54, 0xF0, 0x4D,
-0xFF, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4, 0x90,
-0x92, 0xB8, 0xF0, 0xA3, 0xF0, 0x7F, 0x83, 0x12,
-0x7B, 0x51, 0x90, 0x92, 0xB7, 0xEF, 0xF0, 0x7F,
-0x83, 0x12, 0x7B, 0x51, 0xAE, 0x07, 0x90, 0x92,
-0xB7, 0xE0, 0xFF, 0xB5, 0x06, 0x01, 0x22, 0xC3,
-0x90, 0x92, 0xB9, 0xE0, 0x94, 0x64, 0x90, 0x92,
-0xB8, 0xE0, 0x94, 0x00, 0x40, 0x0D, 0x90, 0x01,
-0xC0, 0xE0, 0x44, 0x40, 0xF0, 0x90, 0x92, 0xB7,
-0xE0, 0xFF, 0x22, 0x90, 0x92, 0xB8, 0x12, 0xB6,
-0xB2, 0x80, 0xC2, 0x90, 0x01, 0xC4, 0x74, 0xE3,
-0xF0, 0x74, 0xCB, 0xA3, 0xF0, 0x7F, 0x90, 0x12,
-0x7B, 0x51, 0xEF, 0x20, 0xE0, 0xF7, 0x74, 0xE3,
-0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xCB, 0xA3,
-0xF0, 0x22, 0x7D, 0x25, 0x02, 0xA7, 0xED, 0x90,
-0x85, 0xBF, 0xE0, 0x64, 0x02, 0x7F, 0x01, 0x60,
-0x02, 0x7F, 0x00, 0x22, 0x90, 0x85, 0xC1, 0xE0,
-0x30, 0xE0, 0x18, 0x90, 0x85, 0xBC, 0xE0, 0xFF,
-0x30, 0xE0, 0x0E, 0xC3, 0x13, 0x30, 0xE0, 0x07,
-0x91, 0x07, 0xBF, 0x01, 0x06, 0x80, 0x02, 0x80,
-0x00, 0x91, 0x34, 0x22, 0x90, 0x85, 0xC8, 0xE0,
-0xFF, 0x60, 0x03, 0xB4, 0x08, 0x0E, 0x91, 0x4D,
-0xBF, 0x01, 0x09, 0x12, 0xB7, 0x58, 0x90, 0x01,
-0xE5, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x94, 0xBF,
-0xE0, 0xC3, 0x13, 0x20, 0xE0, 0x48, 0x90, 0x02,
-0x87, 0xE0, 0x60, 0x02, 0x80, 0x08, 0x90, 0x01,
-0x00, 0xE0, 0x64, 0x3F, 0x60, 0x05, 0x75, 0x14,
-0x01, 0x80, 0x40, 0x90, 0x86, 0x72, 0xE0, 0x30,
-0xE0, 0x0B, 0x90, 0x02, 0x82, 0xE0, 0x60, 0x05,
-0x75, 0x14, 0x02, 0x80, 0x2E, 0x90, 0x86, 0x7A,
-0xE0, 0x30, 0xE0, 0x05, 0x75, 0x14, 0x08, 0x80,
-0x22, 0x90, 0x02, 0x86, 0xE0, 0x20, 0xE1, 0x02,
-0x80, 0x07, 0x90, 0x02, 0x86, 0xE0, 0x30, 0xE3,
-0x05, 0x75, 0x14, 0x04, 0x80, 0x0D, 0x90, 0x04,
-0x1D, 0xE0, 0x60, 0x05, 0x75, 0x14, 0x40, 0x80,
-0x02, 0x80, 0x0F, 0x90, 0x01, 0xB9, 0x74, 0x08,
-0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x14, 0xF0, 0x7F,
-0x00, 0x22, 0x90, 0x01, 0xB8, 0xE4, 0xF0, 0x7F,
-0x01, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x12, 0x7A, 0x29, 0xEF, 0x64, 0x01, 0x60,
-0x05, 0x75, 0x5C, 0x01, 0x80, 0x70, 0x90, 0x85,
-0xC9, 0xE0, 0xFF, 0x54, 0x03, 0x60, 0x05, 0x75,
-0x5C, 0x02, 0x80, 0x62, 0x90, 0x85, 0xC7, 0xE0,
-0xFE, 0xE4, 0xC3, 0x9E, 0x50, 0x05, 0x75, 0x5C,
-0x04, 0x80, 0x53, 0xEF, 0x30, 0xE2, 0x05, 0x75,
-0x5C, 0x08, 0x80, 0x4A, 0x90, 0x85, 0xC9, 0xE0,
-0x30, 0xE4, 0x05, 0x75, 0x5C, 0x10, 0x80, 0x3E,
-0x90, 0x85, 0xC2, 0xE0, 0x13, 0x13, 0x54, 0x3F,
-0x20, 0xE0, 0x05, 0x75, 0x5C, 0x20, 0x80, 0x2E,
-0x90, 0x86, 0x71, 0xE0, 0x60, 0x05, 0x75, 0x5C,
-0x80, 0x80, 0x23, 0x90, 0x06, 0x62, 0xE0, 0x30,
-0xE1, 0x05, 0x75, 0x5C, 0x11, 0x80, 0x17, 0x90,
-0x06, 0x62, 0xE0, 0x30, 0xE0, 0x0C, 0xE0, 0x54,
-0xFC, 0xFF, 0xBF, 0x80, 0x05, 0x75, 0x5C, 0x12,
-0x80, 0x04, 0x91, 0xBA, 0x80, 0x0E, 0x90, 0x01,
-0xB9, 0x74, 0x04, 0xF0, 0x90, 0x01, 0xB8, 0xE5,
-0x5C, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x92, 0xBA, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
-0x90, 0x84, 0xC3, 0xE0, 0x04, 0xF0, 0x90, 0x04,
-0x1D, 0xE0, 0x60, 0x35, 0x90, 0x05, 0x22, 0xE0,
-0x90, 0x92, 0xBE, 0xF0, 0x7D, 0x26, 0x12, 0xA3,
-0xB3, 0xEF, 0x64, 0x01, 0x70, 0x15, 0xB1, 0xE7,
-0x7D, 0x01, 0x12, 0x3A, 0xC2, 0xB1, 0xF2, 0x20,
-0xE0, 0x09, 0x90, 0x94, 0xC4, 0xE0, 0x20, 0xE0,
-0x02, 0xB1, 0xDC, 0x90, 0x92, 0xBE, 0xE0, 0xFF,
-0x7D, 0x27, 0x12, 0xA0, 0xD8, 0xB1, 0xD4, 0x80,
-0x1D, 0xB1, 0xD4, 0xB1, 0xE7, 0x90, 0x96, 0x4F,
-0x74, 0x0A, 0xF0, 0x7D, 0x01, 0x12, 0xBD, 0x87,
-0xB1, 0xF2, 0x20, 0xE0, 0x09, 0x90, 0x94, 0xC4,
-0xE0, 0x20, 0xE0, 0x02, 0xB1, 0xDC, 0x12, 0xA2,
-0x89, 0xD1, 0x0C, 0x74, 0x01, 0xF0, 0xFF, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x92, 0xBA, 0xE0,
-0xFF, 0x02, 0x5C, 0xA3, 0x90, 0x92, 0xBC, 0xE0,
-0xFE, 0xA3, 0xE0, 0xFF, 0x02, 0x50, 0xD7, 0x90,
-0x84, 0xC8, 0xE0, 0xFF, 0x90, 0x92, 0xBB, 0xE0,
-0xFB, 0x22, 0x90, 0x92, 0xBC, 0xEE, 0xF0, 0xFC,
-0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x92, 0xBA, 0xE0,
-0xFF, 0x12, 0x65, 0x61, 0x90, 0x94, 0xC5, 0xE0,
-0x22, 0x12, 0x6A, 0x21, 0x90, 0x84, 0xBF, 0xA3,
-0xE0, 0x24, 0x7F, 0xF5, 0x82, 0xE4, 0x34, 0x82,
-0xF5, 0x83, 0x22, 0x90, 0x93, 0x3A, 0xEE, 0xF0,
-0xA3, 0xEF, 0xF0, 0xE4, 0x90, 0x93, 0x3E, 0xF0,
-0x7D, 0x09, 0x12, 0x55, 0x36, 0xEF, 0x64, 0x06,
-0x70, 0x2A, 0xD1, 0xB0, 0x7D, 0x14, 0x12, 0x55,
-0x36, 0xEF, 0x70, 0x20, 0xD1, 0xB0, 0x7D, 0x15,
-0x12, 0x55, 0x36, 0xEF, 0x64, 0x50, 0x70, 0x14,
-0xD1, 0xB0, 0x7D, 0x21, 0x12, 0x55, 0x36, 0xEF,
-0x20, 0xE0, 0x03, 0x30, 0xE2, 0x06, 0x90, 0x93,
-0x3E, 0x74, 0x01, 0xF0, 0x90, 0x86, 0x73, 0xE0,
-0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x3F, 0xD1,
-0xB0, 0x7D, 0x09, 0x12, 0x55, 0x36, 0xEF, 0x64,
-0x11, 0x70, 0x33, 0x90, 0x93, 0x3B, 0xE0, 0x24,
-0x14, 0xFF, 0x90, 0x93, 0x3A, 0xE0, 0x34, 0x00,
-0xFE, 0x90, 0x93, 0x3C, 0xF0, 0xA3, 0xEF, 0xF0,
-0x7D, 0x02, 0x12, 0x55, 0x36, 0xEF, 0x70, 0x16,
-0x90, 0x93, 0x3C, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x7D, 0x03, 0x12, 0x55, 0x36, 0xBF, 0x89, 0x06,
-0x90, 0x93, 0x3E, 0x74, 0x01, 0xF0, 0x90, 0x93,
-0x3E, 0xE0, 0xFF, 0xD1, 0x0C, 0xEF, 0xF0, 0x22,
-0x90, 0x93, 0x3A, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x22, 0x90, 0x96, 0x5D, 0x12, 0x87, 0x75, 0x12,
-0x71, 0x54, 0x90, 0x85, 0xC5, 0xE0, 0xFF, 0x12,
-0x60, 0xD0, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x1C,
-0x90, 0x96, 0x5D, 0x12, 0x87, 0x6C, 0x90, 0x00,
-0x01, 0x12, 0x03, 0x0F, 0x54, 0x0F, 0xFF, 0x12,
-0x8D, 0xC3, 0xFD, 0x12, 0x6A, 0xB8, 0x12, 0xC7,
-0x1C, 0x12, 0x51, 0x7D, 0x22, 0xAC, 0x07, 0x90,
-0x94, 0xFF, 0xE0, 0xF9, 0x30, 0xE0, 0x02, 0xE1,
-0x9F, 0x90, 0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x16,
-0x90, 0x85, 0xFB, 0xE0, 0x24, 0x04, 0x90, 0x85,
-0xDA, 0xF0, 0x90, 0x85, 0xFB, 0xE0, 0x24, 0x03,
-0x90, 0x85, 0xD9, 0xF0, 0x80, 0x0D, 0x90, 0x85,
-0xDA, 0x74, 0x02, 0xF0, 0x90, 0x85, 0xD9, 0x14,
-0xF0, 0x0B, 0x0B, 0x90, 0x85, 0xD9, 0xE0, 0xFA,
-0x90, 0x85, 0xD8, 0xE0, 0xD3, 0x9A, 0x50, 0x0E,
-0x90, 0x85, 0xCD, 0xEB, 0xF0, 0x90, 0x85, 0xDA,
-0xE0, 0xC3, 0x9D, 0x2C, 0x80, 0x11, 0xC3, 0xED,
-0x9A, 0x2B, 0x90, 0x85, 0xCD, 0xF0, 0x90, 0x85,
-0xD9, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90,
-0x85, 0xDD, 0xF0, 0x90, 0x85, 0xDA, 0xE0, 0xFF,
-0x24, 0x0A, 0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x85,
-0xDD, 0xF1, 0xA7, 0x40, 0x04, 0xEF, 0x24, 0x0A,
-0xF0, 0x90, 0x85, 0xDD, 0xE0, 0xFF, 0x24, 0x23,
-0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x85, 0xCD, 0xF1,
-0xA7, 0x40, 0x04, 0xEF, 0x24, 0x23, 0xF0, 0x90,
-0x85, 0xDD, 0xE0, 0xFF, 0x7E, 0x00, 0x90, 0x85,
-0xD1, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x05,
-0x58, 0xE0, 0x6F, 0x70, 0x01, 0xE4, 0x60, 0x02,
-0xF1, 0xB2, 0xE9, 0x54, 0xFD, 0x80, 0x03, 0xE9,
-0x44, 0x02, 0x90, 0x94, 0xFF, 0xF0, 0x22, 0xE0,
-0xD3, 0x9D, 0xEC, 0x64, 0x80, 0xF8, 0x74, 0x80,
-0x98, 0x22, 0x90, 0x85, 0xD1, 0xA3, 0xE0, 0x90,
-0x05, 0x58, 0xF0, 0x22, 0x90, 0x95, 0x39, 0x74,
-0x04, 0xF0, 0x14, 0xF0, 0xA3, 0xF0, 0xA3, 0xE4,
-0xF0, 0xA3, 0x74, 0x64, 0xF0, 0xA3, 0x74, 0x05,
-0xF0, 0xA3, 0xF0, 0x22, 0xE4, 0x90, 0x92, 0xB1,
-0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x95, 0x08,
-0x12, 0x87, 0x54, 0x90, 0x95, 0x04, 0x12, 0x87,
-0x60, 0xC3, 0x12, 0x04, 0xB4, 0x40, 0x47, 0x90,
-0x85, 0xC1, 0xE0, 0x90, 0x95, 0x08, 0x30, 0xE0,
-0x10, 0x12, 0xD1, 0x42, 0x90, 0x85, 0xFB, 0xE0,
-0x24, 0x04, 0x2F, 0xFF, 0x90, 0x95, 0x39, 0x80,
-0x05, 0x31, 0x42, 0x90, 0x95, 0x3A, 0xE0, 0xFE,
-0xC3, 0xEF, 0x9E, 0x90, 0x92, 0xB2, 0xF0, 0x90,
-0x92, 0xB2, 0xE0, 0xFF, 0xC3, 0x94, 0x2D, 0x50,
-0x15, 0x74, 0x0C, 0x2F, 0x31, 0x5F, 0xE0, 0x04,
-0xF0, 0x90, 0x85, 0xDB, 0xE0, 0x04, 0xF0, 0xE0,
-0xFD, 0x7F, 0xFE, 0x12, 0x7B, 0x3E, 0x90, 0x85,
-0xDB, 0xE0, 0xFF, 0xD3, 0x90, 0x95, 0x3C, 0xE0,
-0x9F, 0x90, 0x95, 0x3B, 0xE0, 0x94, 0x00, 0x40,
-0x02, 0x21, 0x0E, 0x31, 0x20, 0x31, 0x17, 0x50,
-0x1C, 0x31, 0x2A, 0x90, 0x92, 0xB3, 0xE0, 0xD3,
-0x9F, 0x40, 0x0A, 0x90, 0x92, 0xB1, 0xE0, 0x90,
-0x92, 0xB4, 0xF0, 0x80, 0x08, 0x90, 0x92, 0xB1,
-0xE0, 0x04, 0xF0, 0x80, 0xE0, 0x31, 0x20, 0x31,
-0x17, 0x50, 0x2C, 0x31, 0x2A, 0xC3, 0x90, 0x95,
-0x3C, 0xE0, 0x9F, 0xFF, 0x90, 0x95, 0x3B, 0xE0,
-0x94, 0x00, 0xFE, 0x90, 0x92, 0xB3, 0xE0, 0xD3,
-0x9F, 0xE4, 0x9E, 0x40, 0x0A, 0x90, 0x92, 0xB1,
-0xE0, 0x90, 0x92, 0xB5, 0xF0, 0x80, 0x08, 0x90,
-0x92, 0xB1, 0xE0, 0x04, 0xF0, 0x80, 0xD0, 0x90,
-0x92, 0xB4, 0xE0, 0x90, 0x85, 0xE0, 0xF0, 0x90,
-0x92, 0xB5, 0xE0, 0x90, 0x85, 0xE1, 0x31, 0x0F,
-0x94, 0x0A, 0x40, 0x0A, 0xEF, 0x24, 0xF6, 0x90,
-0x85, 0xD8, 0xF0, 0xE4, 0x80, 0x09, 0xE4, 0x90,
-0x85, 0xD8, 0x31, 0x0F, 0x74, 0x0A, 0x9F, 0x90,
-0x85, 0xD7, 0xF0, 0x90, 0x85, 0xE0, 0xE0, 0xFF,
-0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x85, 0xDE, 0xF0,
-0x90, 0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x05, 0x90,
-0x95, 0x39, 0x80, 0x03, 0x90, 0x95, 0x3A, 0xE0,
-0xFF, 0x90, 0x85, 0xDE, 0xE0, 0x2F, 0x04, 0xF0,
-0x90, 0x85, 0xDE, 0xE0, 0xC3, 0x94, 0x0A, 0x50,
-0x03, 0x74, 0x0A, 0xF0, 0x90, 0x85, 0xDE, 0xE0,
-0x24, 0x02, 0xF0, 0x12, 0xC7, 0x1C, 0x12, 0x51,
-0x7D, 0xE4, 0xFF, 0x12, 0x69, 0x33, 0x22, 0xF0,
-0x90, 0x85, 0xE0, 0xE0, 0xFF, 0xC3, 0x22, 0x90,
-0x92, 0xB1, 0xE0, 0xFF, 0xC3, 0x94, 0x2D, 0x22,
-0xE4, 0x90, 0x92, 0xB3, 0xF0, 0x90, 0x92, 0xB1,
-0xF0, 0x22, 0x74, 0x0C, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0x95, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x92,
-0xB3, 0xE0, 0x2F, 0xF0, 0x90, 0x95, 0x3D, 0xE0,
-0xFF, 0x22, 0x12, 0x87, 0x60, 0x90, 0x95, 0x04,
-0x12, 0x87, 0x54, 0x12, 0x87, 0x2C, 0x78, 0x0A,
-0x12, 0x04, 0xC5, 0x90, 0x85, 0xDD, 0xE0, 0xFE,
-0xC3, 0x74, 0x0A, 0x9E, 0x2F, 0xFF, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0x22, 0xE4,
-0xFE, 0x74, 0x0C, 0x2E, 0x31, 0x5F, 0xE4, 0xF0,
-0x0E, 0xEE, 0xB4, 0x2D, 0xF4, 0xE4, 0x90, 0x85,
-0xDC, 0xF0, 0x90, 0x85, 0xDB, 0xF0, 0x90, 0x85,
-0xDF, 0xF0, 0xEF, 0xB4, 0x01, 0x07, 0xA3, 0x74,
-0x2D, 0xF0, 0xE4, 0xA3, 0xF0, 0x22, 0x12, 0xC4,
-0x3B, 0x40, 0x2B, 0x90, 0x85, 0xDF, 0xE0, 0x04,
-0xF0, 0x90, 0x95, 0x3E, 0xE0, 0xFF, 0x90, 0x85,
-0xDF, 0xE0, 0xD3, 0x9F, 0x50, 0x18, 0x90, 0x85,
-0xD7, 0xE0, 0x04, 0x12, 0x97, 0x47, 0x90, 0x85,
-0xDE, 0xF0, 0xFB, 0x90, 0x85, 0xD7, 0xE0, 0xFF,
-0xA3, 0xE0, 0xFD, 0x12, 0x51, 0x7D, 0x22, 0x90,
-0x94, 0xBF, 0xE0, 0x30, 0xE0, 0x0A, 0x90, 0x01,
-0x3B, 0xE0, 0x30, 0xE4, 0x03, 0x12, 0xAC, 0xC6,
-0x22, 0x90, 0x92, 0xBF, 0xEF, 0xF0, 0x90, 0x84,
-0xC5, 0xE0, 0x64, 0x02, 0x70, 0x23, 0x90, 0x92,
-0xBF, 0xE0, 0xFD, 0x64, 0x01, 0x70, 0x31, 0x12,
-0x9B, 0x87, 0x90, 0x86, 0x76, 0xE0, 0x12, 0x9F,
-0x8F, 0x30, 0xE0, 0x09, 0x90, 0x01, 0x4D, 0xE0,
-0x64, 0x80, 0xF0, 0x80, 0x1B, 0xAF, 0x05, 0x80,
-0x14, 0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x51,
-0x22, 0x90, 0x06, 0x90, 0xE0, 0x44, 0x01, 0xF0,
-0x90, 0x92, 0xBF, 0xE0, 0xFF, 0x12, 0x2A, 0x87,
-0x90, 0x88, 0xE1, 0xE0, 0x54, 0xFE, 0xF0, 0x02,
-0xB7, 0xD2, 0x7F, 0x64, 0x7E, 0x00, 0x02, 0x7C,
-0x9F, 0x71, 0xCC, 0x71, 0xC3, 0x7A, 0x82, 0x79,
-0x00, 0x71, 0xAA, 0x78, 0x93, 0x7C, 0x92, 0x7D,
-0x01, 0x7B, 0xFF, 0x7A, 0x82, 0x79, 0x06, 0x71,
-0x97, 0x78, 0x97, 0x7C, 0x92, 0x7D, 0x01, 0x7B,
-0xFF, 0x7A, 0x82, 0x79, 0x0A, 0x71, 0x97, 0xE4,
-0x90, 0x92, 0x9C, 0xF0, 0x12, 0x9F, 0x13, 0xCF,
-0x24, 0x06, 0xCF, 0x34, 0x00, 0x12, 0x9D, 0x82,
-0xEF, 0x64, 0x08, 0x60, 0x02, 0x61, 0x7F, 0x12,
-0x9F, 0x13, 0xCF, 0x24, 0x07, 0xCF, 0x34, 0x00,
-0x12, 0x9D, 0x82, 0xEF, 0x64, 0x06, 0x60, 0x02,
-0x61, 0x7F, 0x90, 0x92, 0x9C, 0x04, 0xF0, 0xE4,
-0x90, 0x92, 0x9B, 0xF0, 0x71, 0x85, 0x94, 0x06,
-0x50, 0x17, 0x90, 0x92, 0x85, 0xE0, 0x24, 0x0A,
-0xFD, 0x90, 0x92, 0x84, 0xE0, 0x12, 0x9D, 0x78,
-0x90, 0x92, 0x9B, 0x71, 0xBA, 0x71, 0x8C, 0x80,
-0xE3, 0x78, 0x87, 0x7C, 0x92, 0x7D, 0x01, 0x7B,
-0x01, 0x7A, 0x86, 0x79, 0x81, 0x7E, 0x00, 0x7F,
-0x06, 0x12, 0x06, 0xBA, 0xEF, 0x60, 0x02, 0x61,
-0x7F, 0x90, 0x92, 0x9B, 0xF0, 0x71, 0x85, 0x94,
-0x04, 0x50, 0x1A, 0x71, 0x9E, 0x12, 0x9F, 0x1E,
-0xCD, 0x24, 0x20, 0x12, 0x9D, 0x77, 0x90, 0x92,
-0x9B, 0xE0, 0x24, 0x97, 0xF5, 0x82, 0xE4, 0x34,
-0x92, 0x71, 0x8C, 0x80, 0xE0, 0x78, 0x97, 0x7C,
-0x92, 0x7D, 0x01, 0x7B, 0x01, 0x7A, 0x86, 0x79,
-0x9C, 0x7E, 0x00, 0x7F, 0x04, 0x12, 0x06, 0xBA,
-0xEF, 0x60, 0x02, 0x61, 0x76, 0x90, 0x06, 0x30,
-0xE0, 0x44, 0x01, 0x54, 0xDF, 0xF0, 0x90, 0x86,
-0x74, 0xE0, 0x30, 0xE0, 0x02, 0x80, 0x0D, 0x90,
-0x88, 0xCC, 0xE0, 0xB4, 0x02, 0x10, 0x12, 0x9F,
-0x34, 0x20, 0xE0, 0x0A, 0x90, 0x01, 0xC7, 0x74,
-0x09, 0x12, 0x9B, 0x86, 0x80, 0x61, 0xE4, 0x90,
-0x92, 0x9B, 0xF0, 0x71, 0x85, 0x94, 0x06, 0x50,
-0x0C, 0x12, 0x9D, 0x63, 0x90, 0x92, 0x9B, 0x71,
-0xB1, 0x71, 0x8C, 0x80, 0xEE, 0xE4, 0x90, 0x92,
-0x9B, 0xF0, 0x71, 0x85, 0x94, 0x04, 0x50, 0x1A,
-0x71, 0x9E, 0x12, 0x9F, 0x1E, 0xCD, 0x24, 0x16,
-0x12, 0x9D, 0x77, 0x90, 0x92, 0x9B, 0xE0, 0x24,
-0x93, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0x71, 0x8C,
-0x80, 0xE0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x8D,
-0x90, 0x91, 0x17, 0x12, 0x87, 0x75, 0xE4, 0x90,
-0x91, 0x1A, 0xF0, 0xA3, 0xF0, 0x7A, 0x92, 0x79,
-0x93, 0x12, 0x36, 0xA9, 0x80, 0x09, 0x90, 0x06,
-0x30, 0xE0, 0x44, 0x21, 0x54, 0xEF, 0xF0, 0x90,
-0x92, 0x9C, 0xE0, 0xFF, 0x22, 0x90, 0x92, 0x9B,
-0xE0, 0xFF, 0xC3, 0x22, 0xF5, 0x83, 0xEF, 0xF0,
-0x90, 0x92, 0x9B, 0xE0, 0x04, 0xF0, 0x22, 0x7E,
-0x00, 0x7F, 0x04, 0x02, 0x02, 0xD0, 0x90, 0x92,
-0x86, 0xE0, 0xFD, 0x90, 0x92, 0x85, 0xE0, 0x2D,
-0xFD, 0x22, 0x7E, 0x00, 0x7F, 0x06, 0x02, 0x02,
-0xD0, 0xE0, 0x24, 0x8D, 0xF5, 0x82, 0xE4, 0x34,
-0x92, 0x22, 0xE0, 0x24, 0x87, 0xF5, 0x82, 0xE4,
-0x34, 0x92, 0x22, 0x78, 0x8D, 0x7C, 0x92, 0x7D,
-0x01, 0x7B, 0xFF, 0x22, 0x90, 0x92, 0x84, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0x22,
-0x71, 0xCC, 0xE4, 0xA3, 0xF0, 0x91, 0x59, 0x50,
-0x1A, 0x12, 0x98, 0x93, 0x91, 0x62, 0x24, 0xAA,
-0xF5, 0x82, 0xE4, 0x34, 0x88, 0xF5, 0x83, 0xE0,
-0xB5, 0x07, 0x1D, 0x90, 0x92, 0x87, 0xE0, 0x04,
-0xF0, 0x80, 0xE2, 0x90, 0x06, 0x32, 0xE0, 0x44,
-0x80, 0xF0, 0x90, 0x01, 0xC7, 0x74, 0x30, 0xF0,
-0x7F, 0x01, 0x12, 0x5F, 0xE9, 0x7F, 0x01, 0x22,
-0x7F, 0x00, 0x22, 0x71, 0xCC, 0x90, 0x88, 0x7C,
-0xE0, 0x70, 0x02, 0xA3, 0xE0, 0x60, 0x26, 0xE4,
-0x90, 0x92, 0x87, 0xF0, 0x91, 0x59, 0x50, 0x20,
-0x12, 0x98, 0x93, 0x91, 0x62, 0x24, 0x8A, 0xF5,
-0x82, 0xE4, 0x34, 0x88, 0xF5, 0x83, 0xE0, 0x6F,
-0x60, 0x03, 0x7F, 0x00, 0x22, 0x90, 0x92, 0x87,
-0xE0, 0x04, 0xF0, 0x80, 0xDF, 0x7F, 0x00, 0x22,
-0x90, 0x06, 0x32, 0xE0, 0x44, 0x40, 0xF0, 0xE4,
-0x90, 0x88, 0x88, 0xF0, 0xA3, 0xF0, 0x7F, 0x01,
-0x22, 0x90, 0x92, 0x87, 0xE0, 0xFD, 0xC3, 0x94,
-0x02, 0x22, 0xED, 0x24, 0x1C, 0xFD, 0x12, 0x55,
-0x36, 0x90, 0x92, 0x87, 0xE0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0xFD, 0x7F,
-0x8F, 0x12, 0x7B, 0x3E, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x91, 0x6E, 0x90, 0x95, 0xF2, 0xE0, 0xFF,
-0x91, 0xAB, 0x90, 0x01, 0x3F, 0x74, 0x04, 0xF0,
-0x90, 0x84, 0xC5, 0xE0, 0xFF, 0xB4, 0x01, 0x07,
-0x90, 0xFD, 0x00, 0xE0, 0x54, 0xEF, 0xF0, 0xEF,
-0xB4, 0x01, 0x07, 0x90, 0xFE, 0x10, 0xE0, 0x54,
-0xFB, 0xF0, 0x22, 0x90, 0x92, 0x0A, 0xEF, 0xF0,
-0xE4, 0xFF, 0x74, 0x42, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0x87, 0xF5, 0x83, 0xE0, 0xFE, 0x74, 0x84,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x04, 0xF5, 0x83,
-0xEE, 0xF0, 0x0F, 0xEF, 0xB4, 0x08, 0xE3, 0x90,
-0x87, 0x4A, 0xE0, 0xFF, 0x90, 0x04, 0x8C, 0xF0,
-0x90, 0x95, 0xEF, 0xEF, 0xF0, 0x90, 0x88, 0xCD,
-0xE0, 0x90, 0x95, 0xF0, 0xF0, 0x75, 0x1B, 0x01,
-0x75, 0x1C, 0x87, 0x75, 0x1D, 0x42, 0x75, 0x1E,
-0x08, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0xBF, 0x12,
-0xB7, 0xBB, 0x75, 0x1C, 0x87, 0x75, 0x1D, 0x95,
-0x75, 0x1E, 0x08, 0x7B, 0x01, 0x7A, 0x95, 0x79,
-0xC7, 0x12, 0x6A, 0x21, 0x90, 0x95, 0xF2, 0xE0,
-0x60, 0x21, 0x90, 0x92, 0x0A, 0xE0, 0xFF, 0x12,
-0x7B, 0x2A, 0x7E, 0x00, 0x74, 0x00, 0x2F, 0xB1,
-0x34, 0xC0, 0x03, 0x8B, 0x1B, 0x75, 0x1C, 0x95,
-0x75, 0x1D, 0xBF, 0x75, 0x1E, 0x33, 0xD0, 0x03,
-0x12, 0x6A, 0x21, 0x22, 0xF9, 0xE4, 0x34, 0xFC,
-0xFA, 0x7B, 0x01, 0x22, 0x90, 0x92, 0x07, 0x12,
-0x87, 0x75, 0x90, 0x02, 0x09, 0xE0, 0xFD, 0x12,
-0x8A, 0xB8, 0x12, 0x02, 0xF6, 0xFE, 0xAF, 0x05,
-0xED, 0x2E, 0x90, 0x88, 0xDC, 0x12, 0x8A, 0xB7,
-0x12, 0xBD, 0x77, 0xAE, 0x05, 0xED, 0x2F, 0x90,
-0x95, 0xF2, 0xF0, 0x22, 0x22, 0x90, 0x86, 0x72,
-0xE0, 0xFF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x30,
-0xE0, 0x03, 0x12, 0xB3, 0xD5, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x93, 0x44,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x88, 0xCD,
-0xE0, 0xFF, 0xB4, 0x02, 0x07, 0xD1, 0xE7, 0x74,
-0x08, 0xF0, 0x80, 0x09, 0xEF, 0xB4, 0x04, 0x05,
-0xD1, 0xE7, 0x74, 0x10, 0xF0, 0x90, 0x93, 0x44,
-0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x64, 0x02, 0x4E,
-0x60, 0x08, 0xEF, 0x64, 0x01, 0x4E, 0x60, 0x02,
-0xC1, 0xDA, 0x90, 0x87, 0x8D, 0xE0, 0xFF, 0x64,
-0xFE, 0x70, 0x02, 0xC1, 0xDA, 0xEF, 0x64, 0x02,
-0x60, 0x07, 0xEF, 0x64, 0x03, 0x60, 0x02, 0xC1,
-0xDA, 0x90, 0x87, 0xED, 0xF1, 0x14, 0x90, 0x93,
-0xD1, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x7E, 0x00,
-0x7F, 0x28, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x67, 0x12, 0x06, 0xDE, 0x7E, 0x00, 0x7F,
-0x40, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0x8F, 0x12, 0x06, 0xDE, 0x90, 0x93, 0x44, 0xE0,
-0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01, 0x70, 0x4F,
-0x75, 0x1B, 0x01, 0x75, 0x1C, 0x87, 0x75, 0x1D,
-0xBD, 0x75, 0x1E, 0x10, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0xD3, 0x12, 0xB7, 0xBB, 0x75, 0x1C, 0x87,
-0x75, 0x1D, 0x5C, 0x75, 0x1E, 0x10, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0xE3, 0x12, 0x6A, 0x21, 0xD1,
-0xF8, 0x74, 0x20, 0xF1, 0x02, 0x79, 0x3F, 0x90,
-0x8B, 0x33, 0xD1, 0xDF, 0x90, 0x8B, 0x36, 0xD1,
-0xEF, 0x90, 0x8B, 0x39, 0xF0, 0x7A, 0x93, 0x79,
-0xD3, 0x12, 0x50, 0x30, 0x75, 0x1B, 0x01, 0x75,
-0x1C, 0x93, 0x75, 0x1D, 0x8F, 0x80, 0x26, 0xD1,
-0xF8, 0x74, 0x10, 0xF1, 0x02, 0x79, 0x3F, 0x90,
-0x8A, 0xFB, 0xD1, 0xDF, 0x90, 0x8A, 0xFE, 0xD1,
-0xEF, 0x90, 0x8B, 0x01, 0xF0, 0x7A, 0x87, 0x79,
-0x5C, 0x12, 0x64, 0xFF, 0x75, 0x1B, 0x01, 0x75,
-0x1C, 0x93, 0x75, 0x1D, 0x97, 0x75, 0x1E, 0x28,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x67, 0x12, 0x6A,
-0x21, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x93, 0x75,
-0x1D, 0x6F, 0x75, 0x1E, 0x20, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x46, 0x12, 0x6A, 0x21, 0x90, 0x93,
-0x6D, 0xE0, 0x54, 0x03, 0x90, 0x93, 0x66, 0xF0,
-0xC3, 0x94, 0x04, 0x50, 0x1C, 0xE0, 0x90, 0x87,
-0x4A, 0xF0, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x93,
-0x75, 0x1D, 0x46, 0x75, 0x1E, 0x20, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0xCF, 0x12, 0x6A, 0x21, 0x80,
-0x06, 0x90, 0x87, 0x4A, 0x74, 0x05, 0xF0, 0x90,
-0x93, 0x66, 0xE0, 0xFF, 0x90, 0x88, 0xCD, 0xE0,
-0xFD, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x46, 0x12,
-0xB3, 0xF2, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12,
-0x87, 0x75, 0x7A, 0x93, 0x79, 0x8F, 0x22, 0x90,
-0x93, 0xCF, 0x74, 0x80, 0xF0, 0xA3, 0x22, 0x12,
-0x87, 0x75, 0x90, 0x93, 0xD1, 0xA3, 0xE0, 0x22,
-0x90, 0x93, 0xD1, 0xA3, 0xE0, 0xFB, 0x90, 0x8A,
-0xEC, 0x22, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0,
-0xFD, 0xFC, 0xFF, 0xFE, 0x12, 0x72, 0x06, 0x7B,
-0x01, 0x7A, 0x95, 0x22, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFD, 0xED, 0xFF, 0x22, 0xA3, 0xE0, 0xFE, 0x24,
-0x28, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0xFF, 0x74, 0x29, 0x2E, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFD, 0x74, 0x2C,
-0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0xFB, 0x02, 0x5D, 0x98, 0x90, 0x96, 0x3B,
-0xA3, 0xE0, 0xFF, 0x90, 0x96, 0x4F, 0x74, 0x03,
-0xF0, 0x7B, 0x06, 0x7D, 0x01, 0x12, 0xBD, 0x87,
-0x90, 0x96, 0x3F, 0xEE, 0xF0, 0xFC, 0xA3, 0xEF,
-0xF0, 0xFD, 0x90, 0x96, 0x3E, 0xE0, 0xFF, 0x74,
-0x10, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xEF, 0xF0, 0x90, 0x96, 0x3D, 0xE0, 0x22,
-0x90, 0x05, 0x63, 0xE0, 0x90, 0x95, 0x08, 0xF0,
-0x90, 0x05, 0x62, 0xE0, 0x90, 0x95, 0x09, 0xF0,
-0x90, 0x05, 0x61, 0xE0, 0x90, 0x95, 0x0A, 0xF0,
-0x90, 0x05, 0x60, 0xE0, 0x90, 0x95, 0x0B, 0xF0,
-0x90, 0x94, 0xFF, 0xE0, 0x44, 0x01, 0x22, 0x90,
-0x96, 0x42, 0xE0, 0xFF, 0x90, 0x96, 0x4F, 0x74,
-0x0C, 0xF0, 0xE4, 0xFB, 0x7D, 0x01, 0x12, 0xBD,
-0x87, 0x90, 0x96, 0x45, 0xEE, 0xF0, 0xA3, 0xEF,
-0xF0, 0x90, 0x96, 0x43, 0xE0, 0xFC, 0xA3, 0xE0,
-0xFD, 0x02, 0x77, 0xD8, 0xFD, 0x75, 0xF0, 0x0E,
-0xA4, 0x24, 0xC8, 0xF5, 0x82, 0xE4, 0x34, 0x94,
-0xF5, 0x83, 0x22, 0x90, 0x94, 0x1A, 0xE0, 0x2F,
-0xFF, 0x90, 0x94, 0x19, 0xE0, 0x34, 0x00, 0xFE,
-0x90, 0x94, 0x9D, 0xF0, 0xA3, 0x22, 0x12, 0xA0,
-0xD8, 0x90, 0x05, 0x27, 0xE0, 0x44, 0x40, 0xF0,
-0x22, 0x90, 0x94, 0x16, 0xE0, 0xFF, 0x24, 0x95,
-0xF5, 0x82, 0xE4, 0x34, 0x87, 0xF5, 0x83, 0xE0,
-0x22, 0x12, 0x04, 0xD8, 0x90, 0x96, 0x20, 0x02,
-0x04, 0xEB, 0x90, 0x01, 0x34, 0x74, 0x40, 0xF0,
-0xFD, 0xE4, 0xFF, 0x12, 0x7C, 0xA9, 0x43, 0x10,
-0x08, 0x22, 0xE0, 0x90, 0x01, 0xBA, 0xF0, 0x90,
-0x85, 0xC7, 0xE0, 0x90, 0x01, 0xBB, 0x22, 0x12,
-0x02, 0xF6, 0xFF, 0x54, 0x01, 0xFE, 0x22, 0xEF,
-0xF0, 0x90, 0xFD, 0x70, 0xE0, 0x7F, 0x00, 0x22,
-0xEE, 0xF0, 0x90, 0xFD, 0x80, 0xE0, 0x7E, 0x00,
-0x22, 0x8B, 0x1B, 0x75, 0x1C, 0x93, 0x75, 0x1D,
-0x14, 0x75, 0x1E, 0x10, 0x22, 0x90, 0x84, 0xBF,
-0xA3, 0xE0, 0x24, 0x79, 0xF9, 0xE4, 0x34, 0x82,
-0x22, 0x8B, 0x1B, 0x75, 0x1C, 0x92, 0x75, 0x1D,
-0xC9, 0x75, 0x1E, 0x06, 0x22, 0x74, 0x21, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
-0x22, 0xF0, 0x90, 0x00, 0x05, 0x02, 0x03, 0x0F,
-0x90, 0x94, 0x19, 0xE4, 0x75, 0xF0, 0x02, 0x02,
-0x07, 0x0A, 0x7D, 0x01, 0x7E, 0x00, 0x7F, 0x10,
-0x12, 0x06, 0xBA, 0xEF, 0x22, 0x7F, 0x84, 0x7E,
-0x08, 0x12, 0x8C, 0x58, 0x90, 0x96, 0x0A, 0x22,
-0xC4, 0x54, 0x0F, 0x90, 0x96, 0x53, 0xF0, 0x22,
-0xFE, 0x54, 0x03, 0xFD, 0xEE, 0x13, 0x13, 0x54,
-0x07, 0xFB, 0x22, 0x24, 0x30, 0xF9, 0xE4, 0x34,
-0xFC, 0xFA, 0x7B, 0x01, 0x22, 0x24, 0x42, 0xF9,
-0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0x22, 0xFD,
-0x12, 0x7B, 0xAE, 0x90, 0x94, 0x14, 0xEF, 0xF0,
-0x22, 0x75, 0x1C, 0x87, 0x75, 0x1D, 0x93, 0x75,
-0x1E, 0x02, 0x22, 0xF0, 0xEE, 0x54, 0x80, 0xFE,
-0xEF, 0x54, 0x7F, 0x4E, 0x22, 0xF0, 0xEE, 0x54,
-0x20, 0xFE, 0xEF, 0x54, 0xDF, 0x4E, 0x22, 0xF0,
-0xA3, 0xEF, 0xF0, 0xE4, 0xFD, 0x02, 0x55, 0x36,
-0xE0, 0xFF, 0x7B, 0x18, 0x7D, 0x01, 0x02, 0x3A,
-0xC2, 0x8B, 0x0D, 0x8A, 0x0E, 0x89, 0x0F, 0x22,
-0xE0, 0x7A, 0x00, 0x24, 0x00, 0xFF, 0xEA, 0x3E,
-0x22, 0x54, 0x10, 0xFD, 0xEF, 0x54, 0xEF, 0x4D,
-0xFF, 0x22, 0x54, 0x40, 0xFD, 0xEF, 0x54, 0xBF,
-0x4D, 0xFF, 0x22, 0x54, 0x04, 0xFD, 0xEF, 0x54,
-0xFB, 0x4D, 0xFF, 0x22, 0x90, 0x94, 0x16, 0xE0,
-0xFF, 0xC3, 0x94, 0x10, 0x22, 0x90, 0x86, 0x74,
-0xE0, 0xC4, 0x13, 0x54, 0x07, 0x22, 0x90, 0x95,
-0xF3, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0x22, 0x90,
-0x95, 0xF5, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0x90, 0x92, 0xAE, 0xE0, 0xFF, 0x75, 0xF0, 0x38,
-0x22, 0xFF, 0x12, 0x02, 0xF6, 0x54, 0x0F, 0xFD,
-0x22, 0x90, 0x00, 0x01, 0xEF, 0x02, 0x03, 0x4E,
-0xF9, 0xE4, 0x3A, 0xFA, 0x02, 0x02, 0xF6, 0x90,
-0x94, 0xA0, 0xE0, 0xC3, 0x94, 0x0A, 0x22, 0x74,
-0x10, 0xF0, 0x7A, 0x87, 0x79, 0x4C, 0x22, 0x12,
-0x87, 0x75, 0x7A, 0x94, 0x79, 0x00, 0x22, 0x12,
-0x02, 0xF6, 0x13, 0x13, 0x54, 0x3F, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0x12,
-0x7B, 0x3E, 0x90, 0x01, 0x01, 0xE0, 0x22, 0x12,
-0x7B, 0x51, 0xEF, 0x44, 0x01, 0xFD, 0x22, 0x12,
-0x02, 0xF6, 0xC4, 0x54, 0x0F, 0xFF, 0x22, 0x00,
-0x8D, 0xAD
-};
-u4Byte ArrayLength_MP_8188F_FW_WoWLAN = 22986;
-
-
-void
-ODM_ReadFirmware_MP_8188F_FW_WoWLAN(
-	IN   PDM_ODM_T    pDM_Odm,
-	OUT  u1Byte       *pFirmware,
-	OUT  u4Byte       *pFirmwareSize
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	*((SIZE_PTR *)pFirmware) = (SIZE_PTR)Array_MP_8188F_FW_WoWLAN;
-#else
-	ODM_MoveMemory(pDM_Odm, pFirmware, Array_MP_8188F_FW_WoWLAN, ArrayLength_MP_8188F_FW_WoWLAN);
-#endif
-	*pFirmwareSize = ArrayLength_MP_8188F_FW_WoWLAN;
-}
-
-
-
-#endif /* end of (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))*/
-
-
-#endif /* end of HWIMG_SUPPORT*/
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_fw.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_fw.h
deleted file mode 100644
index 2778653e4adf..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_fw.h
+++ /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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.16*/
-#if (RTL8188F_SUPPORT == 1)
-#ifndef __INC_MP_FW_HW_IMG_8188F_H
-#define __INC_MP_FW_HW_IMG_8188F_H
-
-
-/******************************************************************************
-*                           FW_AP.TXT
-******************************************************************************/
-
-void
-ODM_ReadFirmware_MP_8188F_FW_AP(
-	IN   PDM_ODM_T    pDM_Odm,
-	OUT  u1Byte       *pFirmware,
-	OUT  u4Byte       *pFirmwareSize
-);
-
-/******************************************************************************
-*                           FW_NIC.TXT
-******************************************************************************/
-
-void
-ODM_ReadFirmware_MP_8188F_FW_NIC(
-	IN   PDM_ODM_T    pDM_Odm,
-	OUT  u1Byte       *pFirmware,
-	OUT  u4Byte       *pFirmwareSize
-);
-
-/******************************************************************************
-*                           FW_WoWLAN.TXT
-******************************************************************************/
-
-void
-ODM_ReadFirmware_MP_8188F_FW_WoWLAN(
-	IN   PDM_ODM_T    pDM_Odm,
-	OUT  u1Byte       *pFirmware,
-	OUT  u4Byte       *pFirmwareSize
-);
-
-#endif
-#endif /* end of HWIMG_SUPPORT*/
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.c
index 291b87168080..d30a8486e3ff 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.c
@@ -1,293 +1,294 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.26*/
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (RTL8188F_SUPPORT == 1)
-static BOOLEAN
-CheckPositive(
-	IN  PDM_ODM_T     pDM_Odm,
-	IN  const u4Byte  Condition1,
-	IN  const u4Byte  Condition2,
-	IN	const u4Byte  Condition3,
-	IN	const u4Byte  Condition4
-)
-{
-	u1Byte    _BoardType = ((pDM_Odm->BoardType & BIT4) >> 4) << 0 | /* _GLNA*/
-				((pDM_Odm->BoardType & BIT3) >> 3) << 1 | /* _GPA*/ 
-				((pDM_Odm->BoardType & BIT7) >> 7) << 2 | /* _ALNA*/
-				((pDM_Odm->BoardType & BIT6) >> 6) << 3 | /* _APA */
-				((pDM_Odm->BoardType & BIT2) >> 2) << 4 | /* _BT*/  
-				((pDM_Odm->BoardType & BIT1) >> 1) << 5;  /* _NGFF*/  
-
-	u4Byte	cond1   = Condition1, cond2 = Condition2, cond3 = Condition3, cond4 = Condition4;
-
-	u1Byte	cut_version_for_para   = (pDM_Odm->CutVersion == ODM_CUT_A) ? 15 : pDM_Odm->CutVersion;
-	u1Byte	pkg_type_for_para   = (pDM_Odm->PackageType == 0) ? 15 : pDM_Odm->PackageType;
-
-	u4Byte    driver1 = cut_version_for_para       << 24 | 
-				(pDM_Odm->SupportInterface & 0xF0) << 16 | 
-				pDM_Odm->SupportPlatform  << 16 | 
-				pkg_type_for_para      << 12 | 
-				(pDM_Odm->SupportInterface & 0x0F) << 8  |
-				_BoardType;
-
-	u4Byte    driver2 = (pDM_Odm->TypeGLNA & 0xFF) <<  0 |  
-				(pDM_Odm->TypeGPA & 0xFF)  <<  8 | 
-				(pDM_Odm->TypeALNA & 0xFF) << 16 | 
-				(pDM_Odm->TypeAPA & 0xFF)  << 24; 
-
-u4Byte    driver3 = 0;
-
-	u4Byte    driver4 = (pDM_Odm->TypeGLNA & 0xFF00) >>  8 |
-				(pDM_Odm->TypeGPA & 0xFF00) |
-				(pDM_Odm->TypeALNA & 0xFF00) << 8 |
-				(pDM_Odm->TypeAPA & 0xFF00)  << 16;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("===> CheckPositive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("===> CheckPositive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("	(Platform, Interface) = (0x%X, 0x%X)\n", pDM_Odm->SupportPlatform, pDM_Odm->SupportInterface));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("	(Board, Package) = (0x%X, 0x%X)\n", pDM_Odm->BoardType, pDM_Odm->PackageType));
-
-
-	/*============== Value Defined Check ===============*/
-	/*QFN Type [15:12] and Cut Version [27:24] need to do value check*/
-	
-	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
-		return FALSE;
-	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
-		return FALSE;
-
-	/*=============== Bit Defined Check ================*/
-	/* We don't care [31:28] */
-
-	cond1   &= 0x00FF0FFF; 
-	driver1 &= 0x00FF0FFF; 
-
-	if ((cond1 & driver1) == cond1) {
-		u4Byte bitMask = 0;
-
-		if ((cond1 & 0x0F) == 0) /* BoardType is DONTCARE*/
-			return TRUE;
-
-		if ((cond1 & BIT0) != 0) /*GLNA*/
-			bitMask |= 0x000000FF;
-		if ((cond1 & BIT1) != 0) /*GPA*/
-			bitMask |= 0x0000FF00;
-		if ((cond1 & BIT2) != 0) /*ALNA*/
-			bitMask |= 0x00FF0000;
-		if ((cond1 & BIT3) != 0) /*APA*/
-			bitMask |= 0xFF000000;
-
-		if (((cond2 & bitMask) == (driver2 & bitMask)) && ((cond4 & bitMask) == (driver4 & bitMask)))  /* BoardType of each RF path is matched*/
-			return TRUE;
-		else
-			return FALSE;
-	} else
-		return FALSE;
-}
-static BOOLEAN
-CheckNegative(
-	IN  PDM_ODM_T     pDM_Odm,
-	IN  const u4Byte  Condition1,
-	IN  const u4Byte  Condition2
-)
-{
-	return TRUE;
-}
-
-/******************************************************************************
-*                           MAC_REG.TXT
-******************************************************************************/
-
-u4Byte Array_MP_8188F_MAC_REG[] = { 
-		0x024, 0x000000DF,
-		0x025, 0x00000007,
-		0x02B, 0x0000001C,
-		0x283, 0x00000020,
-		0x421, 0x0000000F,
-		0x428, 0x0000000A,
-		0x429, 0x00000010,
-		0x430, 0x00000000,
-		0x431, 0x00000000,
-		0x432, 0x00000000,
-		0x433, 0x00000001,
-		0x434, 0x00000004,
-		0x435, 0x00000005,
-		0x436, 0x00000007,
-		0x437, 0x00000008,
-		0x43C, 0x00000004,
-		0x43D, 0x00000005,
-		0x43E, 0x00000007,
-		0x43F, 0x00000008,
-		0x440, 0x0000005D,
-		0x441, 0x00000001,
-		0x442, 0x00000000,
-		0x444, 0x00000010,
-		0x445, 0x00000000,
-		0x446, 0x00000000,
-		0x447, 0x00000000,
-		0x448, 0x00000000,
-		0x449, 0x000000F0,
-		0x44A, 0x0000000F,
-		0x44B, 0x0000003E,
-		0x44C, 0x00000010,
-		0x44D, 0x00000000,
-		0x44E, 0x00000000,
-		0x44F, 0x00000000,
-		0x450, 0x00000000,
-		0x451, 0x000000F0,
-		0x452, 0x0000000F,
-		0x453, 0x00000000,
-		0x456, 0x0000005E,
-		0x460, 0x00000044,
-		0x461, 0x00000044,
-		0x4BC, 0x000000C0,
-		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,
-		0x516, 0x0000000A,
-		0x525, 0x0000004F,
-		0x550, 0x00000010,
-		0x551, 0x00000010,
-		0x559, 0x00000002,
-		0x55C, 0x00000028,
-		0x55D, 0x000000FF,
-		0x605, 0x00000030,
-		0x608, 0x0000000E,
-		0x609, 0x0000002A,
-		0x620, 0x000000FF,
-		0x621, 0x000000FF,
-		0x622, 0x000000FF,
-		0x623, 0x000000FF,
-		0x624, 0x000000FF,
-		0x625, 0x000000FF,
-		0x626, 0x000000FF,
-		0x627, 0x000000FF,
-		0x638, 0x00000028,
-		0x63C, 0x0000000A,
-		0x63D, 0x0000000A,
-		0x63E, 0x0000000E,
-		0x63F, 0x0000000E,
-		0x640, 0x00000040,
-		0x642, 0x00000040,
-		0x643, 0x00000000,
-		0x652, 0x000000C8,
-		0x66E, 0x00000005,
-		0x700, 0x00000021,
-		0x701, 0x00000043,
-		0x702, 0x00000065,
-		0x703, 0x00000087,
-		0x708, 0x00000021,
-		0x709, 0x00000043,
-		0x70A, 0x00000065,
-		0x70B, 0x00000087,
-
-};
-
-void
-ODM_ReadAndConfig_MP_8188F_MAC_REG(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-	u4Byte     i         = 0;
-	u1Byte     cCond;
-	BOOLEAN bMatched = TRUE, bSkipped = FALSE;
-	u4Byte     ArrayLen    = sizeof(Array_MP_8188F_MAC_REG)/sizeof(u4Byte);
-	pu4Byte    Array       = Array_MP_8188F_MAC_REG;
-	
-	u4Byte	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_8188F_MAC_REG\n"));
-
-	while ((i + 1) < ArrayLen) {
-		v1 = Array[i];
-		v2 = Array[i + 1];
-
-		if (v1 & (BIT31 | BIT30)) {/*positive & negative condition*/
-			if (v1 & BIT31) {/* positive condition*/
-				cCond  = (u1Byte)((v1 & (BIT29|BIT28)) >> 28);
-				if (cCond == COND_ENDIF) {/*end*/
-					bMatched = TRUE;
-					bSkipped = FALSE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ENDIF\n"));
-				} else if (cCond == COND_ELSE) { /*else*/
-					bMatched = bSkipped?FALSE:TRUE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ELSE\n"));
-				} else {/*if , else if*/
-					pre_v1 = v1;
-					pre_v2 = v2;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IF or ELSE IF\n"));
-				}
-			} else if (v1 & BIT30) { /*negative condition*/
-				if (bSkipped == FALSE) {
-					if (CheckPositive(pDM_Odm, pre_v1, pre_v2, v1, v2)) {
-						bMatched = TRUE;
-						bSkipped = TRUE;
-					} else {
-						bMatched = FALSE;
-						bSkipped = FALSE;
-					}
-				} else
-					bMatched = FALSE;
-			}
-		} else {
-			if (bMatched)
-				odm_ConfigMAC_8188F(pDM_Odm, v1, (u1Byte)v2);
-		}
-		i = i + 2;
-	}
-}
-
-u4Byte
-ODM_GetVersion_MP_8188F_MAC_REG(void)
-{
-	   return 36;
-}
-
-#endif /* end of HWIMG_SUPPORT*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: 3.5.2*/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8188F_SUPPORT == 1)
+static boolean
+check_positive(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2,
+	const u32	condition3,
+	const u32	condition4
+)
+{
+	u8	_board_type = ((dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
+			((dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
+			((dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
+			((dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
+			((dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
+			((dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
+			((dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
+
+	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
+
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
+
+	u32	driver1 = cut_version_for_para << 24 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
+			pkg_type_for_para << 12 |
+			(dm->support_interface & 0x0F) << 8  |
+			_board_type;
+
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
+
+	u32	driver3 = 0;
+
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Platform, Interface) = (0x%X, 0x%X)\n", dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Board, Package) = (0x%X, 0x%X)\n", dm->board_type, dm->package_type);
+
+
+	/*============== value Defined Check ===============*/
+	/*QFN type [15:12] and cut version [27:24] need to do value check*/
+
+	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
+		return false;
+	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
+		return false;
+
+	/*=============== Bit Defined Check ================*/
+	/* We don't care [31:28] */
+
+	cond1 &= 0x00FF0FFF;
+	driver1 &= 0x00FF0FFF;
+
+	if ((cond1 & driver1) == cond1) {
+		u32	bit_mask = 0;
+
+		if ((cond1 & 0x0F) == 0) /* board_type is DONTCARE*/
+			return true;
+
+		if ((cond1 & BIT(0)) != 0) /*GLNA*/
+			bit_mask |= 0x000000FF;
+		if ((cond1 & BIT(1)) != 0) /*GPA*/
+			bit_mask |= 0x0000FF00;
+		if ((cond1 & BIT(2)) != 0) /*ALNA*/
+			bit_mask |= 0x00FF0000;
+		if ((cond1 & BIT(3)) != 0) /*APA*/
+			bit_mask |= 0xFF000000;
+
+		if (((cond2 & bit_mask) == (driver2 & bit_mask)) && ((cond4 & bit_mask) == (driver4 & bit_mask)))  /* board_type of each RF path is matched*/
+			return true;
+		else
+			return false;
+	} else
+		return false;
+}
+static boolean
+check_negative(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2
+)
+{
+	return true;
+}
+
+/******************************************************************************
+*                           mac_reg.TXT
+******************************************************************************/
+
+u32 array_mp_8188f_mac_reg[] = {
+		0x024, 0x000000DF,
+		0x025, 0x00000007,
+		0x02B, 0x0000001C,
+		0x283, 0x00000020,
+		0x421, 0x0000000F,
+		0x428, 0x0000000A,
+		0x429, 0x00000010,
+		0x430, 0x00000000,
+		0x431, 0x00000000,
+		0x432, 0x00000000,
+		0x433, 0x00000001,
+		0x434, 0x00000002,
+		0x435, 0x00000003,
+		0x436, 0x00000005,
+		0x437, 0x00000007,
+		0x438, 0x00000000,
+		0x439, 0x00000000,
+		0x43A, 0x00000000,
+		0x43B, 0x00000001,
+		0x43C, 0x00000002,
+		0x43D, 0x00000003,
+		0x43E, 0x00000005,
+		0x43F, 0x00000007,
+		0x440, 0x0000005D,
+		0x441, 0x00000001,
+		0x442, 0x00000000,
+		0x444, 0x00000010,
+		0x445, 0x00000000,
+		0x446, 0x00000000,
+		0x447, 0x00000000,
+		0x448, 0x00000000,
+		0x449, 0x000000F0,
+		0x44A, 0x0000000F,
+		0x44B, 0x0000003E,
+		0x44C, 0x00000010,
+		0x44D, 0x00000000,
+		0x44E, 0x00000000,
+		0x44F, 0x00000000,
+		0x450, 0x00000000,
+		0x451, 0x000000F0,
+		0x452, 0x0000000F,
+		0x453, 0x00000000,
+		0x456, 0x0000005E,
+		0x460, 0x00000044,
+		0x461, 0x00000044,
+		0x4BC, 0x000000C0,
+		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,
+		0x516, 0x0000000A,
+		0x525, 0x0000004F,
+		0x550, 0x00000010,
+		0x551, 0x00000010,
+		0x559, 0x00000002,
+		0x55C, 0x00000028,
+		0x55D, 0x000000FF,
+		0x605, 0x00000030,
+		0x608, 0x0000000E,
+		0x609, 0x0000002A,
+		0x620, 0x000000FF,
+		0x621, 0x000000FF,
+		0x622, 0x000000FF,
+		0x623, 0x000000FF,
+		0x624, 0x000000FF,
+		0x625, 0x000000FF,
+		0x626, 0x000000FF,
+		0x627, 0x000000FF,
+		0x638, 0x00000028,
+		0x63C, 0x0000000A,
+		0x63D, 0x0000000A,
+		0x63E, 0x0000000E,
+		0x63F, 0x0000000E,
+		0x640, 0x00000040,
+		0x642, 0x00000040,
+		0x643, 0x00000000,
+		0x652, 0x000000C8,
+		0x66E, 0x00000005,
+		0x700, 0x00000021,
+		0x701, 0x00000043,
+		0x702, 0x00000065,
+		0x703, 0x00000087,
+		0x708, 0x00000021,
+		0x709, 0x00000043,
+		0x70A, 0x00000065,
+		0x70B, 0x00000087,
+
+};
+
+void
+odm_read_and_config_mp_8188f_mac_reg(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8188f_mac_reg)/sizeof(u32);
+	u32	*array = array_mp_8188f_mac_reg;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8188f_mac_reg\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_mac_8188f(dm, v1, (u8)v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8188f_mac_reg(void)
+{
+		return 38;
+}
+
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.h
index 05a7855317ad..e3c4ab5485b0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_mac.h
@@ -1,39 +1,35 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.26*/
-#if (RTL8188F_SUPPORT == 1)
-#ifndef __INC_MP_MAC_HW_IMG_8188F_H
-#define __INC_MP_MAC_HW_IMG_8188F_H
-
-
-/******************************************************************************
-*                           MAC_REG.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_MAC_REG(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_MAC_REG(void);
-
-#endif
-#endif /* end of HWIMG_SUPPORT*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: 3.5.2*/
+#if (RTL8188F_SUPPORT == 1)
+#ifndef __INC_MP_MAC_HW_IMG_8188F_H
+#define __INC_MP_MAC_HW_IMG_8188F_H
+
+
+/******************************************************************************
+*                           mac_reg.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_mac_reg(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_mac_reg(void);
+
+#endif
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.c
index 1f377b40d428..9415c86f1b78 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.c
@@ -1,1164 +1,1195 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.26*/
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (RTL8188F_SUPPORT == 1)
-static BOOLEAN
-CheckPositive(
-	IN  PDM_ODM_T     pDM_Odm,
-	IN  const u4Byte  Condition1,
-	IN  const u4Byte  Condition2,
-	IN	const u4Byte  Condition3,
-	IN	const u4Byte  Condition4
-)
-{
-	u1Byte    _BoardType = ((pDM_Odm->BoardType & BIT4) >> 4) << 0 | /* _GLNA*/
-				((pDM_Odm->BoardType & BIT3) >> 3) << 1 | /* _GPA*/ 
-				((pDM_Odm->BoardType & BIT7) >> 7) << 2 | /* _ALNA*/
-				((pDM_Odm->BoardType & BIT6) >> 6) << 3 | /* _APA */
-				((pDM_Odm->BoardType & BIT2) >> 2) << 4 | /* _BT*/  
-				((pDM_Odm->BoardType & BIT1) >> 1) << 5;  /* _NGFF*/  
-
-	u4Byte	cond1   = Condition1, cond2 = Condition2, cond3 = Condition3, cond4 = Condition4;
-
-	u1Byte	cut_version_for_para   = (pDM_Odm->CutVersion == ODM_CUT_A) ? 15 : pDM_Odm->CutVersion;
-	u1Byte	pkg_type_for_para   = (pDM_Odm->PackageType == 0) ? 15 : pDM_Odm->PackageType;
-
-	u4Byte    driver1 = cut_version_for_para       << 24 | 
-				(pDM_Odm->SupportInterface & 0xF0) << 16 | 
-				pDM_Odm->SupportPlatform  << 16 | 
-				pkg_type_for_para      << 12 | 
-				(pDM_Odm->SupportInterface & 0x0F) << 8  |
-				_BoardType;
-
-	u4Byte    driver2 = (pDM_Odm->TypeGLNA & 0xFF) <<  0 |  
-				(pDM_Odm->TypeGPA & 0xFF)  <<  8 | 
-				(pDM_Odm->TypeALNA & 0xFF) << 16 | 
-				(pDM_Odm->TypeAPA & 0xFF)  << 24; 
-
-u4Byte    driver3 = 0;
-
-	u4Byte    driver4 = (pDM_Odm->TypeGLNA & 0xFF00) >>  8 |
-				(pDM_Odm->TypeGPA & 0xFF00) |
-				(pDM_Odm->TypeALNA & 0xFF00) << 8 |
-				(pDM_Odm->TypeAPA & 0xFF00)  << 16;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("===> CheckPositive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("===> CheckPositive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("	(Platform, Interface) = (0x%X, 0x%X)\n", pDM_Odm->SupportPlatform, pDM_Odm->SupportInterface));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_TRACE, 
-	("	(Board, Package) = (0x%X, 0x%X)\n", pDM_Odm->BoardType, pDM_Odm->PackageType));
-
-
-	/*============== Value Defined Check ===============*/
-	/*QFN Type [15:12] and Cut Version [27:24] need to do value check*/
-	
-	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
-		return FALSE;
-	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
-		return FALSE;
-
-	/*=============== Bit Defined Check ================*/
-	/* We don't care [31:28] */
-
-	cond1   &= 0x00FF0FFF; 
-	driver1 &= 0x00FF0FFF; 
-
-	if ((cond1 & driver1) == cond1) {
-		u4Byte bitMask = 0;
-
-		if ((cond1 & 0x0F) == 0) /* BoardType is DONTCARE*/
-			return TRUE;
-
-		if ((cond1 & BIT0) != 0) /*GLNA*/
-			bitMask |= 0x000000FF;
-		if ((cond1 & BIT1) != 0) /*GPA*/
-			bitMask |= 0x0000FF00;
-		if ((cond1 & BIT2) != 0) /*ALNA*/
-			bitMask |= 0x00FF0000;
-		if ((cond1 & BIT3) != 0) /*APA*/
-			bitMask |= 0xFF000000;
-
-		if (((cond2 & bitMask) == (driver2 & bitMask)) && ((cond4 & bitMask) == (driver4 & bitMask)))  /* BoardType of each RF path is matched*/
-			return TRUE;
-		else
-			return FALSE;
-	} else
-		return FALSE;
-}
-static BOOLEAN
-CheckNegative(
-	IN  PDM_ODM_T     pDM_Odm,
-	IN  const u4Byte  Condition1,
-	IN  const u4Byte  Condition2
-)
-{
-	return TRUE;
-}
-
-/******************************************************************************
-*                           RadioA.TXT
-******************************************************************************/
-
-u4Byte Array_MP_8188F_RadioA[] = { 
-		0x000, 0x00030000,
-		0x008, 0x00008400,
-		0x018, 0x00000407,
-		0x019, 0x00000012,
-	0x80000400,	0x00000000,	0x40000000,	0x00000000,
-		0x01B, 0x00000C6C,
-	0xA0000000,	0x00000000,
-		0x01B, 0x00001C6C,
-	0xB0000000,	0x00000000,
-		0x01E, 0x00080009,
-		0x01F, 0x00000880,
-		0x02F, 0x0001A060,
-		0x03F, 0x00028000,
-		0x042, 0x000060C0,
-		0x057, 0x000D0000,
-		0x058, 0x000C0160,
-		0x067, 0x00001552,
-		0x083, 0x00000000,
-		0x0B0, 0x000FF9F0,
-		0x0B1, 0x00022218,
-		0x0B2, 0x00034C00,
-		0x0B4, 0x0004484B,
-		0x0B5, 0x0000112A,
-		0x0B6, 0x0000053E,
-		0x0B7, 0x00010408,
-		0x0B8, 0x00010200,
-		0x0B9, 0x00080001,
-		0x0BA, 0x00040001,
-		0x0BB, 0x00000400,
-		0x0BF, 0x000C0000,
-		0x0C2, 0x00002400,
-		0x0C3, 0x00000009,
-		0x0C4, 0x00040C91,
-		0x0C5, 0x00099999,
-		0x0C6, 0x000000A3,
-		0x0C7, 0x0008F820,
-		0x0C8, 0x00076C06,
-		0x0C9, 0x00000000,
-		0x0CA, 0x00080000,
-		0x0DF, 0x00000180,
-		0x0EF, 0x000001A0,
-	0x8f000000,	0x00000000,	0x40000000,	0x00000000,
-		0x051, 0x000E8333,
-	0xA0000000,	0x00000000,
-		0x051, 0x000E8231,
-	0xB0000000,	0x00000000,
-	0x80000400,	0x00000000,	0x40000000,	0x00000000,
-		0x052, 0x000FAC88,
-	0x9f000000,	0x00000000,	0x40000000,	0x00000000,
-		0x052, 0x000FAC2C,
-	0xA0000000,	0x00000000,
-		0x052, 0x000FAC2F,
-	0xB0000000,	0x00000000,
-	0x8f000000,	0x00000000,	0x40000000,	0x00000000,
-		0x053, 0x00000103,
-	0xA0000000,	0x00000000,
-		0x053, 0x000001C1,
-	0xB0000000,	0x00000000,
-		0x054, 0x00055007,
-		0x056, 0x000517F0,
-	0x8f000000,	0x00000000,	0x40000000,	0x00000000,
-		0x035, 0x00000099,
-		0x035, 0x00000199,
-		0x035, 0x00000299,
-		0x036, 0x00000064,
-		0x036, 0x00008064,
-		0x036, 0x00010064,
-		0x036, 0x00018064,
-	0xA0000000,	0x00000000,
-		0x035, 0x00000090,
-		0x035, 0x00000190,
-		0x035, 0x00000290,
-		0x036, 0x00001064,
-		0x036, 0x00009064,
-		0x036, 0x00011064,
-		0x036, 0x00019064,
-	0xB0000000,	0x00000000,
-		0x018, 0x00000C07,
-		0x05A, 0x00048000,
-		0x019, 0x000739D0,
-	0x80000400,	0x00000000,	0x40000000,	0x00000000,
-		0x034, 0x0000ADD2,
-		0x034, 0x00009DCF,
-		0x034, 0x00008CF2,
-		0x034, 0x00007CEF,
-		0x034, 0x00006CEC,
-		0x034, 0x00005CE9,
-		0x034, 0x00004CCE,
-		0x034, 0x00003CCB,
-		0x034, 0x00002CC8,
-		0x034, 0x00001C4B,
-		0x034, 0x00000C48,
-	0x9f000000,	0x00000000,	0x40000000,	0x00000000,
-		0x034, 0x0000ADD6,
-		0x034, 0x00009DD3,
-		0x034, 0x00008CF4,
-		0x034, 0x00007CF1,
-		0x034, 0x00006CEE,
-		0x034, 0x00005CEB,
-		0x034, 0x00004CCE,
-		0x034, 0x00003CCB,
-		0x034, 0x00002CC8,
-		0x034, 0x00001C4B,
-		0x034, 0x00000C48,
-	0xA0000000,	0x00000000,
-		0x034, 0x0000ADD2,
-		0x034, 0x00009DD0,
-		0x034, 0x00008CF2,
-		0x034, 0x00007CEF,
-		0x034, 0x00006CEC,
-		0x034, 0x00005CD1,
-		0x034, 0x00004CCE,
-		0x034, 0x00003CCB,
-		0x034, 0x00002CC8,
-		0x034, 0x00001C4B,
-		0x034, 0x00000C48,
-	0xB0000000,	0x00000000,
-		0x000, 0x00030159,
-		0x084, 0x00048000,
-		0x086, 0x0000002A,
-		0x087, 0x00000025,
-		0x08E, 0x00065540,
-		0x08F, 0x00088000,
-		0x0EF, 0x000020A0,
-		0x03B, 0x000F0F00,
-		0x03B, 0x000E0B00,
-		0x03B, 0x000D0900,
-		0x03B, 0x000C0700,
-		0x03B, 0x000B0600,
-		0x03B, 0x000A0400,
-		0x03B, 0x00090200,
-		0x03B, 0x00080000,
-		0x03B, 0x0007BF00,
-		0x03B, 0x00060B00,
-		0x03B, 0x0005C900,
-		0x03B, 0x00040700,
-		0x03B, 0x00030600,
-		0x03B, 0x0002D500,
-		0x03B, 0x00010200,
-		0x03B, 0x0000E000,
-		0x0EF, 0x000000A0,
-		0x0EF, 0x00000010,
-		0x03B, 0x0000C0A8,
-		0x03B, 0x00010400,
-		0x0EF, 0x00000000,
-		0x0EF, 0x00080000,
-		0x030, 0x00010000,
-		0x031, 0x0000000F,
-		0x032, 0x00007EFE,
-		0x0EF, 0x00000000,
-		0x000, 0x00010159,
-		0x018, 0x0000FC07,
-		0xFFE, 0x00000000,
-		0xFFE, 0x00000000,
-		0x01F, 0x00080003,
-		0xFFE, 0x00000000,
-		0xFFE, 0x00000000,
-		0x01E, 0x00000001,
-		0x01F, 0x00080000,
-		0x000, 0x00033D95,
-
-};
-
-void
-ODM_ReadAndConfig_MP_8188F_RadioA(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-	u4Byte     i         = 0;
-	u1Byte     cCond;
-	BOOLEAN bMatched = TRUE, bSkipped = FALSE;
-	u4Byte     ArrayLen    = sizeof(Array_MP_8188F_RadioA)/sizeof(u4Byte);
-	pu4Byte    Array       = Array_MP_8188F_RadioA;
-	
-	u4Byte	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_8188F_RadioA\n"));
-
-	while ((i + 1) < ArrayLen) {
-		v1 = Array[i];
-		v2 = Array[i + 1];
-
-		if (v1 & (BIT31 | BIT30)) {/*positive & negative condition*/
-			if (v1 & BIT31) {/* positive condition*/
-				cCond  = (u1Byte)((v1 & (BIT29|BIT28)) >> 28);
-				if (cCond == COND_ENDIF) {/*end*/
-					bMatched = TRUE;
-					bSkipped = FALSE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ENDIF\n"));
-				} else if (cCond == COND_ELSE) { /*else*/
-					bMatched = bSkipped?FALSE:TRUE;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("ELSE\n"));
-				} else {/*if , else if*/
-					pre_v1 = v1;
-					pre_v2 = v2;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IF or ELSE IF\n"));
-				}
-			} else if (v1 & BIT30) { /*negative condition*/
-				if (bSkipped == FALSE) {
-					if (CheckPositive(pDM_Odm, pre_v1, pre_v2, v1, v2)) {
-						bMatched = TRUE;
-						bSkipped = TRUE;
-					} else {
-						bMatched = FALSE;
-						bSkipped = FALSE;
-					}
-				} else
-					bMatched = FALSE;
-			}
-		} else {
-			if (bMatched)
-				odm_ConfigRF_RadioA_8188F(pDM_Odm, v1, v2);
-		}
-		i = i + 2;
-	}
-}
-
-u4Byte
-ODM_GetVersion_MP_8188F_RadioA(void)
-{
-	   return 36;
-}
-
-/******************************************************************************
-*                           TxPowerTrack_AP.TXT
-******************************************************************************/
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-u1Byte gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_AP_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_AP_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_AP_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_AP_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-};
-u1Byte gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_AP_8188F[]    = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11};
-u1Byte gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_AP_8188F[]    = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
-u1Byte gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_AP_8188F[]    = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 8, 9, 9, 9, 10, 10, 10, 10, 11, 11};
-u1Byte gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_AP_8188F[]    = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_AP_8188F[] = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_AP_8188F[] = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_AP_8188F[] = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 8, 9, 9, 9, 10, 10, 10, 10, 11, 11};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_AP_8188F[] = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
-#endif
-
-void
-ODM_ReadAndConfig_MP_8188F_TxPowerTrack_AP(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	PODM_RF_CAL_T  pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_MP_8188F\n"));
-
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P, gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N, gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P, gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N, gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P, gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N, gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P, gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N, gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE);
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P, gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N, gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P, gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N, gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_AP_8188F, DELTA_SWINGIDX_SIZE*3);
-#endif
-}
-
-/******************************************************************************
-*                           TxPowerTrack_SDIO.TXT
-******************************************************************************/
-
-#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
-u1Byte gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_SDIO_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_SDIO_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_SDIO_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_SDIO_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-};
-u1Byte gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_SDIO_8188F[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 3, 3, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
-u1Byte gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_SDIO_8188F[]    = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 7, 8, 8, 8, 8};
-u1Byte gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_SDIO_8188F[]    = {0, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 15, 16, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
-u1Byte gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_SDIO_8188F[]    = {0, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_SDIO_8188F[] = {0, 1, 2, 2, 3, 3, 3, 4, 4, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_SDIO_8188F[] = {0, 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 5, 6, 6, 6, 6, 7, 7};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_SDIO_8188F[] = {0, 1, 2, 3, 4, 6, 7, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_SDIO_8188F[] = {0, 0, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 12, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14};
-#endif
-
-void
-ODM_ReadAndConfig_MP_8188F_TxPowerTrack_SDIO(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
-	PODM_RF_CAL_T  pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_MP_8188F\n"));
-
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P, gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N, gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P, gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N, gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P, gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N, gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P, gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N, gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE);
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P, gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N, gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P, gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N, gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_SDIO_8188F, DELTA_SWINGIDX_SIZE*3);
-#endif
-}
-
-/******************************************************************************
-*                           TxPowerTrack_USB.TXT
-******************************************************************************/
-
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-u1Byte gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_USB_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_USB_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_USB_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
-};
-u1Byte gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_USB_8188F[][DELTA_SWINGIDX_SIZE] = {
-	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
-};
-u1Byte gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_USB_8188F[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 3, 3, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
-u1Byte gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_USB_8188F[]    = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 7, 8, 8, 8, 8};
-u1Byte gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_USB_8188F[]    = {0, 1, 1, 2, 3, 4, 4, 4, 5, 6, 7, 8, 8, 9, 10, 11, 12, 13, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
-u1Byte gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_USB_8188F[]    = {0, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_USB_8188F[] = {0, 1, 2, 2, 3, 3, 3, 4, 4, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_USB_8188F[] = {0, 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 5, 6, 6, 6, 6, 7, 7};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_USB_8188F[] = {0, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 14, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16};
-u1Byte gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_USB_8188F[] = {0, 0, 1, 2, 2, 3, 3, 4, 6, 6, 7, 8, 8, 10, 10, 11, 13, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
-#endif
-
-void
-ODM_ReadAndConfig_MP_8188F_TxPowerTrack_USB(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-	PODM_RF_CAL_T  pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_MP_8188F\n"));
-
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P, gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N, gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P, gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N, gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P, gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N, gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P, gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N, gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE);
-
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_P, gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GA_N, gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_P, gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE*3);
-	ODM_MoveMemory(pDM_Odm, pRFCalibrateInfo->DeltaSwingTableIdx_5GB_N, gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_USB_8188F, DELTA_SWINGIDX_SIZE*3);
-#endif
-}
-
-/******************************************************************************
-*                           TXPWR_LMT.TXT
-******************************************************************************/
-
-const char *Array_MP_8188F_TXPWR_LMT[] = { 
-	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "01", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "02", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "03", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "04", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "05", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "06", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "07", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "08", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "09", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "10", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "11", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "12", "30", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "12", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "13", "26", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "26", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "13", "32",
-	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63", 
-	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63", 
-	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "28", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "28", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "30", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "30", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "30", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "30", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "30", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "30", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "28", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "28", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "24", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "16", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "30",
-	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63", 
-	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63", 
-	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
-	"FCC", "2.4G", "20M", "HT", "1T", "01", "28", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "01", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "02", "28", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "02", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "03", "30", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "03", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "04", "30", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "04", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "05", "30", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "05", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "06", "30", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "06", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "07", "30", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "07", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "08", "30", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "08", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "09", "28", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "09", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "10", "28", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "10", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "11", "28", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "11", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "12", "24", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "12", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "13", "16", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30", 
-	"MKK", "2.4G", "20M", "HT", "1T", "13", "30",
-	"FCC", "2.4G", "20M", "HT", "1T", "14", "63", 
-	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63", 
-	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
-	"FCC", "2.4G", "20M", "HT", "2T", "01", "28", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "01", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "02", "28", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "02", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "03", "30", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "03", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "04", "30", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "04", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "05", "30", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "05", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "06", "30", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "06", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "07", "30", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "07", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "08", "30", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "08", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "09", "28", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "09", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "10", "28", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "10", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "11", "28", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "11", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "12", "63", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "12", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "13", "63", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "13", "30", 
-	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
-	"FCC", "2.4G", "20M", "HT", "2T", "14", "63", 
-	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63", 
-	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
-	"FCC", "2.4G", "40M", "HT", "1T", "01", "63", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63", 
-	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
-	"FCC", "2.4G", "40M", "HT", "1T", "02", "63", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63", 
-	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
-	"FCC", "2.4G", "40M", "HT", "1T", "03", "26", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "03", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "03", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "04", "26", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "04", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "04", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "05", "26", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "05", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "05", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "06", "26", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "06", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "06", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "07", "26", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "07", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "07", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "08", "26", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "08", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "08", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "09", "26", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "09", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "09", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "10", "24", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "10", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "10", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "11", "10", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "11", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "11", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "12", "63", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "12", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "12", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "13", "63", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "13", "26", 
-	"MKK", "2.4G", "40M", "HT", "1T", "13", "26",
-	"FCC", "2.4G", "40M", "HT", "1T", "14", "63", 
-	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63", 
-	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
-	"FCC", "2.4G", "40M", "HT", "2T", "01", "63", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63", 
-	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
-	"FCC", "2.4G", "40M", "HT", "2T", "02", "63", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63", 
-	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
-	"FCC", "2.4G", "40M", "HT", "2T", "03", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "03", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "03", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "04", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "04", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "04", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "05", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "05", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "05", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "06", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "06", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "06", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "07", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "07", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "07", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "08", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "08", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "08", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "09", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "09", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "09", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "10", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "10", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "10", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "11", "26", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "11", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "11", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "12", "63", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "12", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "12", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "13", "63", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "13", "26", 
-	"MKK", "2.4G", "40M", "HT", "2T", "13", "26",
-	"FCC", "2.4G", "40M", "HT", "2T", "14", "63", 
-	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63", 
-	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
-	"FCC", "5G", "20M", "OFDM", "1T", "36", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "36", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "40", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "40", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "44", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "44", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "48", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "48", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "52", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "52", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "56", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "56", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "60", "32", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "60", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "64", "28", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "64", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "100", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "114", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "114", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "114", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "108", "32", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "112", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "116", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "120", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "124", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "128", "32", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "132", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "136", "30", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "140", "28", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
-	"FCC", "5G", "20M", "OFDM", "1T", "149", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "149", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
-	"FCC", "5G", "20M", "OFDM", "1T", "153", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "153", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
-	"FCC", "5G", "20M", "OFDM", "1T", "157", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "157", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
-	"FCC", "5G", "20M", "OFDM", "1T", "161", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "161", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
-	"FCC", "5G", "20M", "OFDM", "1T", "165", "34", 
-	"ETSI", "5G", "20M", "OFDM", "1T", "165", "32", 
-	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
-	"FCC", "5G", "20M", "HT", "1T", "36", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "36", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "36", "32",
-	"FCC", "5G", "20M", "HT", "1T", "40", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "40", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "40", "32",
-	"FCC", "5G", "20M", "HT", "1T", "44", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "44", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "44", "32",
-	"FCC", "5G", "20M", "HT", "1T", "48", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "48", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "48", "32",
-	"FCC", "5G", "20M", "HT", "1T", "52", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "52", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "52", "32",
-	"FCC", "5G", "20M", "HT", "1T", "56", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "56", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "56", "32",
-	"FCC", "5G", "20M", "HT", "1T", "60", "32", 
-	"ETSI", "5G", "20M", "HT", "1T", "60", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "60", "32",
-	"FCC", "5G", "20M", "HT", "1T", "64", "28", 
-	"ETSI", "5G", "20M", "HT", "1T", "64", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "64", "32",
-	"FCC", "5G", "20M", "HT", "1T", "100", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "100", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "100", "32",
-	"FCC", "5G", "20M", "HT", "1T", "114", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "114", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "114", "32",
-	"FCC", "5G", "20M", "HT", "1T", "108", "32", 
-	"ETSI", "5G", "20M", "HT", "1T", "108", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "108", "32",
-	"FCC", "5G", "20M", "HT", "1T", "112", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "112", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "112", "32",
-	"FCC", "5G", "20M", "HT", "1T", "116", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "116", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "116", "32",
-	"FCC", "5G", "20M", "HT", "1T", "120", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "120", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "120", "32",
-	"FCC", "5G", "20M", "HT", "1T", "124", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "124", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "124", "32",
-	"FCC", "5G", "20M", "HT", "1T", "128", "32", 
-	"ETSI", "5G", "20M", "HT", "1T", "128", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "128", "32",
-	"FCC", "5G", "20M", "HT", "1T", "132", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "132", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "132", "32",
-	"FCC", "5G", "20M", "HT", "1T", "136", "30", 
-	"ETSI", "5G", "20M", "HT", "1T", "136", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "136", "32",
-	"FCC", "5G", "20M", "HT", "1T", "140", "28", 
-	"ETSI", "5G", "20M", "HT", "1T", "140", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "140", "32",
-	"FCC", "5G", "20M", "HT", "1T", "149", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "149", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "149", "63",
-	"FCC", "5G", "20M", "HT", "1T", "153", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "153", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "153", "63",
-	"FCC", "5G", "20M", "HT", "1T", "157", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "157", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "157", "63",
-	"FCC", "5G", "20M", "HT", "1T", "161", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "161", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "161", "63",
-	"FCC", "5G", "20M", "HT", "1T", "165", "34", 
-	"ETSI", "5G", "20M", "HT", "1T", "165", "32", 
-	"MKK", "5G", "20M", "HT", "1T", "165", "63",
-	"FCC", "5G", "20M", "HT", "2T", "36", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "36", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "36", "30",
-	"FCC", "5G", "20M", "HT", "2T", "40", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "40", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "40", "30",
-	"FCC", "5G", "20M", "HT", "2T", "44", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "44", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "44", "30",
-	"FCC", "5G", "20M", "HT", "2T", "48", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "48", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "48", "30",
-	"FCC", "5G", "20M", "HT", "2T", "52", "34", 
-	"ETSI", "5G", "20M", "HT", "2T", "52", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "52", "30",
-	"FCC", "5G", "20M", "HT", "2T", "56", "32", 
-	"ETSI", "5G", "20M", "HT", "2T", "56", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "56", "30",
-	"FCC", "5G", "20M", "HT", "2T", "60", "30", 
-	"ETSI", "5G", "20M", "HT", "2T", "60", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "60", "30",
-	"FCC", "5G", "20M", "HT", "2T", "64", "26", 
-	"ETSI", "5G", "20M", "HT", "2T", "64", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "64", "30",
-	"FCC", "5G", "20M", "HT", "2T", "100", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "100", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "100", "30",
-	"FCC", "5G", "20M", "HT", "2T", "114", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "114", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "114", "30",
-	"FCC", "5G", "20M", "HT", "2T", "108", "30", 
-	"ETSI", "5G", "20M", "HT", "2T", "108", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "108", "30",
-	"FCC", "5G", "20M", "HT", "2T", "112", "32", 
-	"ETSI", "5G", "20M", "HT", "2T", "112", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "112", "30",
-	"FCC", "5G", "20M", "HT", "2T", "116", "32", 
-	"ETSI", "5G", "20M", "HT", "2T", "116", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "116", "30",
-	"FCC", "5G", "20M", "HT", "2T", "120", "34", 
-	"ETSI", "5G", "20M", "HT", "2T", "120", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "120", "30",
-	"FCC", "5G", "20M", "HT", "2T", "124", "32", 
-	"ETSI", "5G", "20M", "HT", "2T", "124", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "124", "30",
-	"FCC", "5G", "20M", "HT", "2T", "128", "30", 
-	"ETSI", "5G", "20M", "HT", "2T", "128", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "128", "30",
-	"FCC", "5G", "20M", "HT", "2T", "132", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "132", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "132", "30",
-	"FCC", "5G", "20M", "HT", "2T", "136", "28", 
-	"ETSI", "5G", "20M", "HT", "2T", "136", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "136", "30",
-	"FCC", "5G", "20M", "HT", "2T", "140", "26", 
-	"ETSI", "5G", "20M", "HT", "2T", "140", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "140", "30",
-	"FCC", "5G", "20M", "HT", "2T", "149", "34", 
-	"ETSI", "5G", "20M", "HT", "2T", "149", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "149", "63",
-	"FCC", "5G", "20M", "HT", "2T", "153", "34", 
-	"ETSI", "5G", "20M", "HT", "2T", "153", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "153", "63",
-	"FCC", "5G", "20M", "HT", "2T", "157", "34", 
-	"ETSI", "5G", "20M", "HT", "2T", "157", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "157", "63",
-	"FCC", "5G", "20M", "HT", "2T", "161", "34", 
-	"ETSI", "5G", "20M", "HT", "2T", "161", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "161", "63",
-	"FCC", "5G", "20M", "HT", "2T", "165", "34", 
-	"ETSI", "5G", "20M", "HT", "2T", "165", "30", 
-	"MKK", "5G", "20M", "HT", "2T", "165", "63",
-	"FCC", "5G", "40M", "HT", "1T", "38", "30", 
-	"ETSI", "5G", "40M", "HT", "1T", "38", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "38", "32",
-	"FCC", "5G", "40M", "HT", "1T", "46", "30", 
-	"ETSI", "5G", "40M", "HT", "1T", "46", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "46", "32",
-	"FCC", "5G", "40M", "HT", "1T", "54", "32", 
-	"ETSI", "5G", "40M", "HT", "1T", "54", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "54", "32",
-	"FCC", "5G", "40M", "HT", "1T", "62", "32", 
-	"ETSI", "5G", "40M", "HT", "1T", "62", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "62", "32",
-	"FCC", "5G", "40M", "HT", "1T", "102", "28", 
-	"ETSI", "5G", "40M", "HT", "1T", "102", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "102", "32",
-	"FCC", "5G", "40M", "HT", "1T", "110", "32", 
-	"ETSI", "5G", "40M", "HT", "1T", "110", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "110", "32",
-	"FCC", "5G", "40M", "HT", "1T", "118", "34", 
-	"ETSI", "5G", "40M", "HT", "1T", "118", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "118", "32",
-	"FCC", "5G", "40M", "HT", "1T", "126", "34", 
-	"ETSI", "5G", "40M", "HT", "1T", "126", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "126", "32",
-	"FCC", "5G", "40M", "HT", "1T", "134", "32", 
-	"ETSI", "5G", "40M", "HT", "1T", "134", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "134", "32",
-	"FCC", "5G", "40M", "HT", "1T", "151", "34", 
-	"ETSI", "5G", "40M", "HT", "1T", "151", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "151", "63",
-	"FCC", "5G", "40M", "HT", "1T", "159", "34", 
-	"ETSI", "5G", "40M", "HT", "1T", "159", "32", 
-	"MKK", "5G", "40M", "HT", "1T", "159", "63",
-	"FCC", "5G", "40M", "HT", "2T", "38", "28", 
-	"ETSI", "5G", "40M", "HT", "2T", "38", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "38", "30",
-	"FCC", "5G", "40M", "HT", "2T", "46", "28", 
-	"ETSI", "5G", "40M", "HT", "2T", "46", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "46", "30",
-	"FCC", "5G", "40M", "HT", "2T", "54", "30", 
-	"ETSI", "5G", "40M", "HT", "2T", "54", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "54", "30",
-	"FCC", "5G", "40M", "HT", "2T", "62", "30", 
-	"ETSI", "5G", "40M", "HT", "2T", "62", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "62", "30",
-	"FCC", "5G", "40M", "HT", "2T", "102", "26", 
-	"ETSI", "5G", "40M", "HT", "2T", "102", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "102", "30",
-	"FCC", "5G", "40M", "HT", "2T", "110", "30", 
-	"ETSI", "5G", "40M", "HT", "2T", "110", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "110", "30",
-	"FCC", "5G", "40M", "HT", "2T", "118", "34", 
-	"ETSI", "5G", "40M", "HT", "2T", "118", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "118", "30",
-	"FCC", "5G", "40M", "HT", "2T", "126", "32", 
-	"ETSI", "5G", "40M", "HT", "2T", "126", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "126", "30",
-	"FCC", "5G", "40M", "HT", "2T", "134", "30", 
-	"ETSI", "5G", "40M", "HT", "2T", "134", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "134", "30",
-	"FCC", "5G", "40M", "HT", "2T", "151", "34", 
-	"ETSI", "5G", "40M", "HT", "2T", "151", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "151", "63",
-	"FCC", "5G", "40M", "HT", "2T", "159", "34", 
-	"ETSI", "5G", "40M", "HT", "2T", "159", "30", 
-	"MKK", "5G", "40M", "HT", "2T", "159", "63",
-	"FCC", "5G", "80M", "VHT", "1T", "42", "30", 
-	"ETSI", "5G", "80M", "VHT", "1T", "42", "32", 
-	"MKK", "5G", "80M", "VHT", "1T", "42", "32",
-	"FCC", "5G", "80M", "VHT", "1T", "58", "28", 
-	"ETSI", "5G", "80M", "VHT", "1T", "58", "32", 
-	"MKK", "5G", "80M", "VHT", "1T", "58", "32",
-	"FCC", "5G", "80M", "VHT", "1T", "106", "30", 
-	"ETSI", "5G", "80M", "VHT", "1T", "106", "32", 
-	"MKK", "5G", "80M", "VHT", "1T", "106", "32",
-	"FCC", "5G", "80M", "VHT", "1T", "122", "34", 
-	"ETSI", "5G", "80M", "VHT", "1T", "122", "32", 
-	"MKK", "5G", "80M", "VHT", "1T", "122", "32",
-	"FCC", "5G", "80M", "VHT", "1T", "155", "34", 
-	"ETSI", "5G", "80M", "VHT", "1T", "155", "32", 
-	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
-	"FCC", "5G", "80M", "VHT", "2T", "42", "28", 
-	"ETSI", "5G", "80M", "VHT", "2T", "42", "30", 
-	"MKK", "5G", "80M", "VHT", "2T", "42", "30",
-	"FCC", "5G", "80M", "VHT", "2T", "58", "26", 
-	"ETSI", "5G", "80M", "VHT", "2T", "58", "30", 
-	"MKK", "5G", "80M", "VHT", "2T", "58", "30",
-	"FCC", "5G", "80M", "VHT", "2T", "106", "28", 
-	"ETSI", "5G", "80M", "VHT", "2T", "106", "30", 
-	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
-	"FCC", "5G", "80M", "VHT", "2T", "122", "32", 
-	"ETSI", "5G", "80M", "VHT", "2T", "122", "30", 
-	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
-	"FCC", "5G", "80M", "VHT", "2T", "155", "34", 
-	"ETSI", "5G", "80M", "VHT", "2T", "155", "30", 
-	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
-};
-
-void
-ODM_ReadAndConfig_MP_8188F_TXPWR_LMT(
-	IN   PDM_ODM_T  pDM_Odm
-)
-{
-	u4Byte     i           = 0;
-#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
-	u4Byte     ArrayLen    = sizeof(Array_MP_8188F_TXPWR_LMT)/sizeof(u1Byte);
-	pu1Byte    Array      = (pu1Byte)Array_MP_8188F_TXPWR_LMT;
-#else
-	u4Byte     ArrayLen    = sizeof(Array_MP_8188F_TXPWR_LMT)/sizeof(pu1Byte);
-	pu1Byte    *Array      = (pu1Byte *)Array_MP_8188F_TXPWR_LMT;
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-
-	PlatformZeroMemory(pHalData->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
-	pHalData->nLinesReadPwrLmt = ArrayLen/7;
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ReadAndConfig_MP_8188F_TXPWR_LMT\n"));
-
-	for (i = 0; i < ArrayLen; i += 7) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
-		u1Byte regulation = Array[i];
-		u1Byte band = Array[i+1];
-		u1Byte bandwidth = Array[i+2];
-		u1Byte rate = Array[i+3];
-		u1Byte rfPath = Array[i+4];
-		u1Byte chnl = Array[i+5];
-		u1Byte val = Array[i+6];
-#else
-		pu1Byte regulation = Array[i];
-		pu1Byte band = Array[i+1];
-		pu1Byte bandwidth = Array[i+2];
-		pu1Byte rate = Array[i+3];
-		pu1Byte rfPath = Array[i+4];
-		pu1Byte chnl = Array[i+5];
-		pu1Byte val = Array[i+6];
-#endif
-	
-		odm_ConfigBB_TXPWR_LMT_8188F(pDM_Odm, regulation, band, bandwidth, rate, rfPath, chnl, val);
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		rsprintf((char *)pHalData->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
-			regulation, band, bandwidth, rate, rfPath, chnl, val);
-#endif
-	}
-
-}
-
-#endif /* end of HWIMG_SUPPORT*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: 3.5.2*/
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (RTL8188F_SUPPORT == 1)
+static boolean
+check_positive(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2,
+	const u32	condition3,
+	const u32	condition4
+)
+{
+	u8	_board_type = ((dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
+			((dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
+			((dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
+			((dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
+			((dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
+			((dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
+			((dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
+
+	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
+
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
+
+	u32	driver1 = cut_version_for_para << 24 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
+			pkg_type_for_para << 12 |
+			(dm->support_interface & 0x0F) << 8  |
+			_board_type;
+
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
+
+	u32	driver3 = 0;
+
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Platform, Interface) = (0x%X, 0x%X)\n", dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+	"	(Board, Package) = (0x%X, 0x%X)\n", dm->board_type, dm->package_type);
+
+
+	/*============== value Defined Check ===============*/
+	/*QFN type [15:12] and cut version [27:24] need to do value check*/
+
+	if (((cond1 & 0x0000F000) != 0) && ((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
+		return false;
+	if (((cond1 & 0x0F000000) != 0) && ((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
+		return false;
+
+	/*=============== Bit Defined Check ================*/
+	/* We don't care [31:28] */
+
+	cond1 &= 0x00FF0FFF;
+	driver1 &= 0x00FF0FFF;
+
+	if ((cond1 & driver1) == cond1) {
+		u32	bit_mask = 0;
+
+		if ((cond1 & 0x0F) == 0) /* board_type is DONTCARE*/
+			return true;
+
+		if ((cond1 & BIT(0)) != 0) /*GLNA*/
+			bit_mask |= 0x000000FF;
+		if ((cond1 & BIT(1)) != 0) /*GPA*/
+			bit_mask |= 0x0000FF00;
+		if ((cond1 & BIT(2)) != 0) /*ALNA*/
+			bit_mask |= 0x00FF0000;
+		if ((cond1 & BIT(3)) != 0) /*APA*/
+			bit_mask |= 0xFF000000;
+
+		if (((cond2 & bit_mask) == (driver2 & bit_mask)) && ((cond4 & bit_mask) == (driver4 & bit_mask)))  /* board_type of each RF path is matched*/
+			return true;
+		else
+			return false;
+	} else
+		return false;
+}
+static boolean
+check_negative(
+	struct dm_struct *dm,
+	const u32	condition1,
+	const u32	condition2
+)
+{
+	return true;
+}
+
+/******************************************************************************
+*                           radioa.TXT
+******************************************************************************/
+
+u32 array_mp_8188f_radioa[] = {
+		0x000, 0x00030000,
+		0x008, 0x00008400,
+		0x018, 0x00000407,
+		0x019, 0x00000012,
+	0x80000400,	0x00000000,	0x40000000,	0x00000000,
+		0x01B, 0x00000C6C,
+	0xA0000000,	0x00000000,
+		0x01B, 0x00001C6C,
+	0xB0000000,	0x00000000,
+		0x01E, 0x00080009,
+		0x01F, 0x00000880,
+		0x02F, 0x0001A060,
+		0x03F, 0x00028000,
+		0x042, 0x000060C0,
+		0x057, 0x000D0000,
+		0x058, 0x000C0160,
+		0x067, 0x00001552,
+		0x083, 0x00000000,
+		0x0B0, 0x000FF9F0,
+		0x0B1, 0x00022218,
+		0x0B2, 0x00034C00,
+	0x8c000400,	0x00000000,	0x40000000,	0x00000000,
+		0x0B4, 0x0004486B,
+	0x9c000000,	0x00000000,	0x40000000,	0x00000000,
+		0x0B4, 0x0004486B,
+	0xA0000000,	0x00000000,
+		0x0B4, 0x0004484B,
+	0xB0000000,	0x00000000,
+		0x0B5, 0x0000112A,
+		0x0B6, 0x0000053E,
+		0x0B7, 0x00010408,
+	0x8c000400,	0x00000000,	0x40000000,	0x00000000,
+		0x0B8, 0x000100AF,
+	0x9c000000,	0x00000000,	0x40000000,	0x00000000,
+		0x0B8, 0x000100AF,
+	0xA0000000,	0x00000000,
+		0x0B8, 0x00010200,
+	0xB0000000,	0x00000000,
+		0x0B9, 0x00080001,
+		0x0BA, 0x00040001,
+		0x0BB, 0x00000400,
+		0x0BF, 0x000C0000,
+		0x0C2, 0x00002400,
+		0x0C3, 0x00000009,
+		0x0C4, 0x00040C91,
+		0x0C5, 0x00099999,
+		0x0C6, 0x000000A3,
+		0x0C7, 0x0008F820,
+		0x0C8, 0x00076C06,
+		0x0C9, 0x00000000,
+		0x0CA, 0x00080000,
+		0x0DF, 0x00000180,
+		0x0EF, 0x000001A0,
+	0x8f000000,	0x00000000,	0x40000000,	0x00000000,
+		0x051, 0x000E8333,
+	0xA0000000,	0x00000000,
+		0x051, 0x000E8231,
+	0xB0000000,	0x00000000,
+	0x80000400,	0x00000000,	0x40000000,	0x00000000,
+		0x052, 0x000FAC88,
+	0x9f000000,	0x00000000,	0x40000000,	0x00000000,
+		0x052, 0x000FAC2C,
+	0xA0000000,	0x00000000,
+		0x052, 0x000FAC2F,
+	0xB0000000,	0x00000000,
+	0x8f000000,	0x00000000,	0x40000000,	0x00000000,
+		0x053, 0x00000103,
+	0xA0000000,	0x00000000,
+		0x053, 0x000001C1,
+	0xB0000000,	0x00000000,
+		0x054, 0x00055007,
+		0x056, 0x000517F0,
+	0x8f000000,	0x00000000,	0x40000000,	0x00000000,
+		0x035, 0x00000099,
+		0x035, 0x00000199,
+		0x035, 0x00000299,
+	0xA0000000,	0x00000000,
+		0x035, 0x00000090,
+		0x035, 0x00000190,
+		0x035, 0x00000290,
+	0xB0000000,	0x00000000,
+	0x8b000000,	0x00000000,	0x40000000,	0x00000000,
+		0x05F, 0x00023500,
+	0x9c000400,	0x00000000,	0x40000000,	0x00000000,
+		0x05F, 0x00023504,
+	0x9c000000,	0x00000000,	0x40000000,	0x00000000,
+		0x05F, 0x00023504,
+	0xA0000000,	0x00000000,
+		0x05F, 0x000FFFFF,
+	0xB0000000,	0x00000000,
+	0x8f000000,	0x00000000,	0x40000000,	0x00000000,
+		0x036, 0x00000064,
+		0x036, 0x00008064,
+		0x036, 0x00010064,
+		0x036, 0x00018064,
+	0x9c000400,	0x00000000,	0x40000000,	0x00000000,
+		0x036, 0x00001068,
+		0x036, 0x00009068,
+		0x036, 0x00011068,
+		0x036, 0x00019068,
+	0x9c000000,	0x00000000,	0x40000000,	0x00000000,
+		0x036, 0x00001068,
+		0x036, 0x00009068,
+		0x036, 0x00011068,
+		0x036, 0x00019068,
+	0xA0000000,	0x00000000,
+		0x036, 0x00001064,
+		0x036, 0x00009064,
+		0x036, 0x00011064,
+		0x036, 0x00019064,
+	0xB0000000,	0x00000000,
+		0x018, 0x00000C07,
+		0x05A, 0x00048000,
+		0x019, 0x000739D0,
+	0x80000400,	0x00000000,	0x40000000,	0x00000000,
+		0x034, 0x0000ADD2,
+		0x034, 0x00009DCF,
+		0x034, 0x00008CF2,
+		0x034, 0x00007CEF,
+		0x034, 0x00006CEC,
+		0x034, 0x00005CE9,
+		0x034, 0x00004CCE,
+		0x034, 0x00003CCB,
+		0x034, 0x00002CC8,
+		0x034, 0x00001C4B,
+		0x034, 0x00000C48,
+	0x9f000000,	0x00000000,	0x40000000,	0x00000000,
+		0x034, 0x0000ADD6,
+		0x034, 0x00009DD3,
+		0x034, 0x00008CF4,
+		0x034, 0x00007CF1,
+		0x034, 0x00006CEE,
+		0x034, 0x00005CEB,
+		0x034, 0x00004CCE,
+		0x034, 0x00003CCB,
+		0x034, 0x00002CC8,
+		0x034, 0x00001C4B,
+		0x034, 0x00000C48,
+	0xA0000000,	0x00000000,
+		0x034, 0x0000ADD2,
+		0x034, 0x00009DD0,
+		0x034, 0x00008CF2,
+		0x034, 0x00007CEF,
+		0x034, 0x00006CEC,
+		0x034, 0x00005CD1,
+		0x034, 0x00004CCE,
+		0x034, 0x00003CCB,
+		0x034, 0x00002CC8,
+		0x034, 0x00001C4B,
+		0x034, 0x00000C48,
+	0xB0000000,	0x00000000,
+		0x000, 0x00030159,
+		0x084, 0x00048000,
+		0x086, 0x0000002A,
+		0x087, 0x00000025,
+		0x08E, 0x00065540,
+		0x08F, 0x00088000,
+		0x0EF, 0x000020A0,
+		0x03B, 0x000F0F00,
+		0x03B, 0x000E0B00,
+		0x03B, 0x000D0900,
+		0x03B, 0x000C0700,
+		0x03B, 0x000B0600,
+		0x03B, 0x000A0400,
+		0x03B, 0x00090200,
+		0x03B, 0x00080000,
+		0x03B, 0x0007BF00,
+		0x03B, 0x00060B00,
+		0x03B, 0x0005C900,
+		0x03B, 0x00040700,
+		0x03B, 0x00030600,
+		0x03B, 0x0002D500,
+		0x03B, 0x00010200,
+		0x03B, 0x0000E000,
+		0x0EF, 0x000000A0,
+		0x0EF, 0x00000010,
+		0x03B, 0x0000C0A8,
+		0x03B, 0x00010400,
+		0x0EF, 0x00000000,
+		0x0EF, 0x00080000,
+		0x030, 0x00010000,
+		0x031, 0x0000000F,
+		0x032, 0x00007EFE,
+		0x0EF, 0x00000000,
+		0x000, 0x00010159,
+		0x018, 0x0000FC07,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0x01F, 0x00080003,
+		0xFFE, 0x00000000,
+		0xFFE, 0x00000000,
+		0x01E, 0x00000001,
+		0x01F, 0x00080000,
+		0x000, 0x00033D95,
+
+};
+
+void
+odm_read_and_config_mp_8188f_radioa(
+	struct	dm_struct *dm
+)
+{
+	u32	i = 0;
+	u8	c_cond;
+	boolean	is_matched = true, is_skipped = false;
+	u32	array_len = sizeof(array_mp_8188f_radioa)/sizeof(u32);
+	u32	*array = array_mp_8188f_radioa;
+
+	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8188f_radioa\n");
+
+	while ((i + 1) < array_len) {
+		v1 = array[i];
+		v2 = array[i + 1];
+
+		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
+			if (v1 & BIT(31)) {/* positive condition*/
+				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				if (c_cond == COND_ENDIF) {/*end*/
+					is_matched = true;
+					is_skipped = false;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
+				} else if (c_cond == COND_ELSE) { /*else*/
+					is_matched = is_skipped?false:true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
+				} else {/*if , else if*/
+					pre_v1 = v1;
+					pre_v2 = v2;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
+				}
+			} else if (v1 & BIT(30)) { /*negative condition*/
+				if (is_skipped == false) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
+						is_matched = true;
+						is_skipped = true;
+					} else {
+						is_matched = false;
+						is_skipped = false;
+					}
+				} else
+					is_matched = false;
+			}
+		} else {
+			if (is_matched)
+				odm_config_rf_radio_a_8188f(dm, v1, v2);
+		}
+		i = i + 2;
+	}
+}
+
+u32
+odm_get_version_mp_8188f_radioa(void)
+{
+		return 38;
+}
+
+/******************************************************************************
+*                           txpowertrack_ap.TXT
+******************************************************************************/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+u8 g_delta_swing_table_idx_mp_5gb_n_txpowertrack_ap_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 g_delta_swing_table_idx_mp_5gb_p_txpowertrack_ap_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+};
+u8 g_delta_swing_table_idx_mp_5ga_n_txpowertrack_ap_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 g_delta_swing_table_idx_mp_5ga_p_txpowertrack_ap_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+};
+u8 g_delta_swing_table_idx_mp_2gb_n_txpowertrack_ap_8188f[]    = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11};
+u8 g_delta_swing_table_idx_mp_2gb_p_txpowertrack_ap_8188f[]    = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
+u8 g_delta_swing_table_idx_mp_2ga_n_txpowertrack_ap_8188f[]    = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 8, 9, 9, 9, 10, 10, 10, 10, 11, 11};
+u8 g_delta_swing_table_idx_mp_2ga_p_txpowertrack_ap_8188f[]    = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
+u8 g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_ap_8188f[] = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11};
+u8 g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_ap_8188f[] = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
+u8 g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_ap_8188f[] = {0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 8, 9, 9, 9, 10, 10, 10, 10, 11, 11};
+u8 g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_ap_8188f[] = {0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9};
+#endif
+
+void
+odm_read_and_config_mp_8188f_txpowertrack_ap(
+	struct dm_struct	 *dm
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	struct dm_rf_calibration_struct  *cali_info = &(dm->rf_calibrate_info);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8188f\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_ap_8188f, DELTA_SWINGIDX_SIZE*3);
+#endif
+}
+
+/******************************************************************************
+*                           txpowertrack_sdio.TXT
+******************************************************************************/
+
+#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
+u8 g_delta_swing_table_idx_mp_5gb_n_txpowertrack_sdio_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 g_delta_swing_table_idx_mp_5gb_p_txpowertrack_sdio_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+};
+u8 g_delta_swing_table_idx_mp_5ga_n_txpowertrack_sdio_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 g_delta_swing_table_idx_mp_5ga_p_txpowertrack_sdio_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+};
+u8 g_delta_swing_table_idx_mp_2gb_n_txpowertrack_sdio_8188f[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 3, 3, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
+u8 g_delta_swing_table_idx_mp_2gb_p_txpowertrack_sdio_8188f[]    = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 7, 8, 8, 8, 8};
+u8 g_delta_swing_table_idx_mp_2ga_n_txpowertrack_sdio_8188f[]    = {0, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 15, 16, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 g_delta_swing_table_idx_mp_2ga_p_txpowertrack_sdio_8188f[]    = {0, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
+u8 g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_sdio_8188f[] = {0, 1, 2, 2, 3, 3, 3, 4, 4, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
+u8 g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_sdio_8188f[] = {0, 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 5, 6, 6, 6, 6, 7, 7};
+u8 g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_sdio_8188f[] = {0, 1, 2, 3, 4, 6, 7, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 16, 16, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18};
+u8 g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_sdio_8188f[] = {0, 0, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 12, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14};
+#endif
+
+void
+odm_read_and_config_mp_8188f_txpowertrack_sdio(
+	struct dm_struct	 *dm
+)
+{
+#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	struct dm_rf_calibration_struct  *cali_info = &(dm->rf_calibrate_info);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8188f\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_sdio_8188f, DELTA_SWINGIDX_SIZE*3);
+#endif
+}
+
+/******************************************************************************
+*                           txpowertrack_usb.TXT
+******************************************************************************/
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+u8 g_delta_swing_table_idx_mp_5gb_n_txpowertrack_usb_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 g_delta_swing_table_idx_mp_5gb_p_txpowertrack_usb_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+};
+u8 g_delta_swing_table_idx_mp_5ga_n_txpowertrack_usb_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 16, 17, 17, 17, 17, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+	{0, 1, 2, 3, 3, 5, 5, 6, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 18, 18, 18},
+};
+u8 g_delta_swing_table_idx_mp_5ga_p_txpowertrack_usb_8188f[][DELTA_SWINGIDX_SIZE] = {
+	{0, 1, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+	{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15},
+};
+u8 g_delta_swing_table_idx_mp_2gb_n_txpowertrack_usb_8188f[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 3, 3, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
+u8 g_delta_swing_table_idx_mp_2gb_p_txpowertrack_usb_8188f[]    = {0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 7, 8, 8, 8, 8};
+u8 g_delta_swing_table_idx_mp_2ga_n_txpowertrack_usb_8188f[]    = {0, 1, 1, 2, 3, 4, 4, 4, 5, 6, 7, 8, 8, 9, 10, 11, 12, 13, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
+u8 g_delta_swing_table_idx_mp_2ga_p_txpowertrack_usb_8188f[]    = {0, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 13, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
+u8 g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_usb_8188f[] = {0, 1, 2, 2, 3, 3, 3, 4, 4, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9};
+u8 g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_usb_8188f[] = {0, 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 5, 6, 6, 6, 6, 7, 7};
+u8 g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_usb_8188f[] = {0, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 13, 14, 14, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16};
+u8 g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_usb_8188f[] = {0, 0, 1, 2, 2, 3, 3, 4, 6, 6, 7, 8, 8, 10, 10, 11, 13, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15};
+#endif
+
+void
+odm_read_and_config_mp_8188f_txpowertrack_usb(
+	struct dm_struct	 *dm
+)
+{
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	struct dm_rf_calibration_struct  *cali_info = &(dm->rf_calibrate_info);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8188f\n");
+
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE);
+
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_usb_8188f, DELTA_SWINGIDX_SIZE*3);
+#endif
+}
+
+/******************************************************************************
+*                           txpwr_lmt.TXT
+******************************************************************************/
+
+const char *array_mp_8188f_txpwr_lmt[] = {
+	"FCC", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "01", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "01", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "02", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "02", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "03", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "03", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "04", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "04", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "05", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "05", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "06", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "06", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "07", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "07", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "08", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "08", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "09", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "09", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "10", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "10", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "11", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "11", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "12", "30",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "12", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "12", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "13", "26",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "13", "26",
+	"MKK", "2.4G", "20M", "CCK", "1T", "13", "32",
+	"FCC", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "CCK", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "CCK", "1T", "14", "32",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "01", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "02", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "09", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "10", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "12", "24",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "13", "16",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "13", "30",
+	"FCC", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "OFDM", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "1T", "01", "28",
+	"ETSI", "2.4G", "20M", "HT", "1T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "1T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "05", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "06", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "07", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "1T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "09", "28",
+	"ETSI", "2.4G", "20M", "HT", "1T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "1T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "11", "28",
+	"ETSI", "2.4G", "20M", "HT", "1T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "12", "24",
+	"ETSI", "2.4G", "20M", "HT", "1T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "13", "16",
+	"ETSI", "2.4G", "20M", "HT", "1T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "1T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "20M", "HT", "2T", "01", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "01", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "01", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "02", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "02", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "02", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "03", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "03", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "03", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "04", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "04", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "04", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "05", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "05", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "05", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "06", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "06", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "06", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "07", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "07", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "07", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "08", "30",
+	"ETSI", "2.4G", "20M", "HT", "2T", "08", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "08", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "09", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "09", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "09", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "10", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "10", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "10", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "11", "28",
+	"ETSI", "2.4G", "20M", "HT", "2T", "11", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "11", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "12", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "12", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "13", "30",
+	"MKK", "2.4G", "20M", "HT", "2T", "13", "30",
+	"FCC", "2.4G", "20M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "20M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "20M", "HT", "2T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "1T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "03", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "03", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "04", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "04", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "05", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "05", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "06", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "06", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "06", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "07", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "07", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "08", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "08", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "1T", "09", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "09", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "10", "24",
+	"ETSI", "2.4G", "40M", "HT", "1T", "10", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "10", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "11", "10",
+	"ETSI", "2.4G", "40M", "HT", "1T", "11", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "11", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "12", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "12", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "13", "26",
+	"MKK", "2.4G", "40M", "HT", "1T", "13", "26",
+	"FCC", "2.4G", "40M", "HT", "1T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "1T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "1T", "14", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "01", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "01", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "01", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "02", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "02", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "02", "63",
+	"FCC", "2.4G", "40M", "HT", "2T", "03", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "03", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "03", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "04", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "04", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "04", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "05", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "05", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "05", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "06", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "06", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "06", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "07", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "07", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "07", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "08", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "08", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "08", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "09", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "09", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "09", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "10", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "10", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "10", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "11", "26",
+	"ETSI", "2.4G", "40M", "HT", "2T", "11", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "11", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "12", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "12", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "12", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "13", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "13", "26",
+	"MKK", "2.4G", "40M", "HT", "2T", "13", "26",
+	"FCC", "2.4G", "40M", "HT", "2T", "14", "63",
+	"ETSI", "2.4G", "40M", "HT", "2T", "14", "63",
+	"MKK", "2.4G", "40M", "HT", "2T", "14", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "36", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "36", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "36", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "40", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "40", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "40", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "44", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "44", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "44", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "48", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "48", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "48", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "52", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "52", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "52", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "56", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "56", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "56", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "60", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "60", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "60", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "64", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "64", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "64", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "100", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "100", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "100", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "114", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "114", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "114", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "108", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "108", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "108", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "112", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "112", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "112", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "116", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "116", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "116", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "120", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "120", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "120", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "124", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "124", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "124", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "128", "32",
+	"ETSI", "5G", "20M", "OFDM", "1T", "128", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "128", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "132", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "132", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "132", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "136", "30",
+	"ETSI", "5G", "20M", "OFDM", "1T", "136", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "136", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "140", "28",
+	"ETSI", "5G", "20M", "OFDM", "1T", "140", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "140", "32",
+	"FCC", "5G", "20M", "OFDM", "1T", "149", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "149", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "149", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "153", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "153", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "153", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "157", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "157", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "157", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "161", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "161", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "161", "63",
+	"FCC", "5G", "20M", "OFDM", "1T", "165", "34",
+	"ETSI", "5G", "20M", "OFDM", "1T", "165", "32",
+	"MKK", "5G", "20M", "OFDM", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "1T", "36", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "36", "32",
+	"MKK", "5G", "20M", "HT", "1T", "36", "32",
+	"FCC", "5G", "20M", "HT", "1T", "40", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "40", "32",
+	"MKK", "5G", "20M", "HT", "1T", "40", "32",
+	"FCC", "5G", "20M", "HT", "1T", "44", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "44", "32",
+	"MKK", "5G", "20M", "HT", "1T", "44", "32",
+	"FCC", "5G", "20M", "HT", "1T", "48", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "48", "32",
+	"MKK", "5G", "20M", "HT", "1T", "48", "32",
+	"FCC", "5G", "20M", "HT", "1T", "52", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "52", "32",
+	"MKK", "5G", "20M", "HT", "1T", "52", "32",
+	"FCC", "5G", "20M", "HT", "1T", "56", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "56", "32",
+	"MKK", "5G", "20M", "HT", "1T", "56", "32",
+	"FCC", "5G", "20M", "HT", "1T", "60", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "60", "32",
+	"MKK", "5G", "20M", "HT", "1T", "60", "32",
+	"FCC", "5G", "20M", "HT", "1T", "64", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "64", "32",
+	"MKK", "5G", "20M", "HT", "1T", "64", "32",
+	"FCC", "5G", "20M", "HT", "1T", "100", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "100", "32",
+	"MKK", "5G", "20M", "HT", "1T", "100", "32",
+	"FCC", "5G", "20M", "HT", "1T", "114", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "114", "32",
+	"MKK", "5G", "20M", "HT", "1T", "114", "32",
+	"FCC", "5G", "20M", "HT", "1T", "108", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "108", "32",
+	"MKK", "5G", "20M", "HT", "1T", "108", "32",
+	"FCC", "5G", "20M", "HT", "1T", "112", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "112", "32",
+	"MKK", "5G", "20M", "HT", "1T", "112", "32",
+	"FCC", "5G", "20M", "HT", "1T", "116", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "116", "32",
+	"MKK", "5G", "20M", "HT", "1T", "116", "32",
+	"FCC", "5G", "20M", "HT", "1T", "120", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "120", "32",
+	"MKK", "5G", "20M", "HT", "1T", "120", "32",
+	"FCC", "5G", "20M", "HT", "1T", "124", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "124", "32",
+	"MKK", "5G", "20M", "HT", "1T", "124", "32",
+	"FCC", "5G", "20M", "HT", "1T", "128", "32",
+	"ETSI", "5G", "20M", "HT", "1T", "128", "32",
+	"MKK", "5G", "20M", "HT", "1T", "128", "32",
+	"FCC", "5G", "20M", "HT", "1T", "132", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "132", "32",
+	"MKK", "5G", "20M", "HT", "1T", "132", "32",
+	"FCC", "5G", "20M", "HT", "1T", "136", "30",
+	"ETSI", "5G", "20M", "HT", "1T", "136", "32",
+	"MKK", "5G", "20M", "HT", "1T", "136", "32",
+	"FCC", "5G", "20M", "HT", "1T", "140", "28",
+	"ETSI", "5G", "20M", "HT", "1T", "140", "32",
+	"MKK", "5G", "20M", "HT", "1T", "140", "32",
+	"FCC", "5G", "20M", "HT", "1T", "149", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "149", "32",
+	"MKK", "5G", "20M", "HT", "1T", "149", "63",
+	"FCC", "5G", "20M", "HT", "1T", "153", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "153", "32",
+	"MKK", "5G", "20M", "HT", "1T", "153", "63",
+	"FCC", "5G", "20M", "HT", "1T", "157", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "157", "32",
+	"MKK", "5G", "20M", "HT", "1T", "157", "63",
+	"FCC", "5G", "20M", "HT", "1T", "161", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "161", "32",
+	"MKK", "5G", "20M", "HT", "1T", "161", "63",
+	"FCC", "5G", "20M", "HT", "1T", "165", "34",
+	"ETSI", "5G", "20M", "HT", "1T", "165", "32",
+	"MKK", "5G", "20M", "HT", "1T", "165", "63",
+	"FCC", "5G", "20M", "HT", "2T", "36", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "36", "30",
+	"MKK", "5G", "20M", "HT", "2T", "36", "30",
+	"FCC", "5G", "20M", "HT", "2T", "40", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "40", "30",
+	"MKK", "5G", "20M", "HT", "2T", "40", "30",
+	"FCC", "5G", "20M", "HT", "2T", "44", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "44", "30",
+	"MKK", "5G", "20M", "HT", "2T", "44", "30",
+	"FCC", "5G", "20M", "HT", "2T", "48", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "48", "30",
+	"MKK", "5G", "20M", "HT", "2T", "48", "30",
+	"FCC", "5G", "20M", "HT", "2T", "52", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "52", "30",
+	"MKK", "5G", "20M", "HT", "2T", "52", "30",
+	"FCC", "5G", "20M", "HT", "2T", "56", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "56", "30",
+	"MKK", "5G", "20M", "HT", "2T", "56", "30",
+	"FCC", "5G", "20M", "HT", "2T", "60", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "60", "30",
+	"MKK", "5G", "20M", "HT", "2T", "60", "30",
+	"FCC", "5G", "20M", "HT", "2T", "64", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "64", "30",
+	"MKK", "5G", "20M", "HT", "2T", "64", "30",
+	"FCC", "5G", "20M", "HT", "2T", "100", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "100", "30",
+	"MKK", "5G", "20M", "HT", "2T", "100", "30",
+	"FCC", "5G", "20M", "HT", "2T", "114", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "114", "30",
+	"MKK", "5G", "20M", "HT", "2T", "114", "30",
+	"FCC", "5G", "20M", "HT", "2T", "108", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "108", "30",
+	"MKK", "5G", "20M", "HT", "2T", "108", "30",
+	"FCC", "5G", "20M", "HT", "2T", "112", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "112", "30",
+	"MKK", "5G", "20M", "HT", "2T", "112", "30",
+	"FCC", "5G", "20M", "HT", "2T", "116", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "116", "30",
+	"MKK", "5G", "20M", "HT", "2T", "116", "30",
+	"FCC", "5G", "20M", "HT", "2T", "120", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "120", "30",
+	"MKK", "5G", "20M", "HT", "2T", "120", "30",
+	"FCC", "5G", "20M", "HT", "2T", "124", "32",
+	"ETSI", "5G", "20M", "HT", "2T", "124", "30",
+	"MKK", "5G", "20M", "HT", "2T", "124", "30",
+	"FCC", "5G", "20M", "HT", "2T", "128", "30",
+	"ETSI", "5G", "20M", "HT", "2T", "128", "30",
+	"MKK", "5G", "20M", "HT", "2T", "128", "30",
+	"FCC", "5G", "20M", "HT", "2T", "132", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "132", "30",
+	"MKK", "5G", "20M", "HT", "2T", "132", "30",
+	"FCC", "5G", "20M", "HT", "2T", "136", "28",
+	"ETSI", "5G", "20M", "HT", "2T", "136", "30",
+	"MKK", "5G", "20M", "HT", "2T", "136", "30",
+	"FCC", "5G", "20M", "HT", "2T", "140", "26",
+	"ETSI", "5G", "20M", "HT", "2T", "140", "30",
+	"MKK", "5G", "20M", "HT", "2T", "140", "30",
+	"FCC", "5G", "20M", "HT", "2T", "149", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "149", "30",
+	"MKK", "5G", "20M", "HT", "2T", "149", "63",
+	"FCC", "5G", "20M", "HT", "2T", "153", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "153", "30",
+	"MKK", "5G", "20M", "HT", "2T", "153", "63",
+	"FCC", "5G", "20M", "HT", "2T", "157", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "157", "30",
+	"MKK", "5G", "20M", "HT", "2T", "157", "63",
+	"FCC", "5G", "20M", "HT", "2T", "161", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "161", "30",
+	"MKK", "5G", "20M", "HT", "2T", "161", "63",
+	"FCC", "5G", "20M", "HT", "2T", "165", "34",
+	"ETSI", "5G", "20M", "HT", "2T", "165", "30",
+	"MKK", "5G", "20M", "HT", "2T", "165", "63",
+	"FCC", "5G", "40M", "HT", "1T", "38", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "38", "32",
+	"MKK", "5G", "40M", "HT", "1T", "38", "32",
+	"FCC", "5G", "40M", "HT", "1T", "46", "30",
+	"ETSI", "5G", "40M", "HT", "1T", "46", "32",
+	"MKK", "5G", "40M", "HT", "1T", "46", "32",
+	"FCC", "5G", "40M", "HT", "1T", "54", "32",
+	"ETSI", "5G", "40M", "HT", "1T", "54", "32",
+	"MKK", "5G", "40M", "HT", "1T", "54", "32",
+	"FCC", "5G", "40M", "HT", "1T", "62", "32",
+	"ETSI", "5G", "40M", "HT", "1T", "62", "32",
+	"MKK", "5G", "40M", "HT", "1T", "62", "32",
+	"FCC", "5G", "40M", "HT", "1T", "102", "28",
+	"ETSI", "5G", "40M", "HT", "1T", "102", "32",
+	"MKK", "5G", "40M", "HT", "1T", "102", "32",
+	"FCC", "5G", "40M", "HT", "1T", "110", "32",
+	"ETSI", "5G", "40M", "HT", "1T", "110", "32",
+	"MKK", "5G", "40M", "HT", "1T", "110", "32",
+	"FCC", "5G", "40M", "HT", "1T", "118", "34",
+	"ETSI", "5G", "40M", "HT", "1T", "118", "32",
+	"MKK", "5G", "40M", "HT", "1T", "118", "32",
+	"FCC", "5G", "40M", "HT", "1T", "126", "34",
+	"ETSI", "5G", "40M", "HT", "1T", "126", "32",
+	"MKK", "5G", "40M", "HT", "1T", "126", "32",
+	"FCC", "5G", "40M", "HT", "1T", "134", "32",
+	"ETSI", "5G", "40M", "HT", "1T", "134", "32",
+	"MKK", "5G", "40M", "HT", "1T", "134", "32",
+	"FCC", "5G", "40M", "HT", "1T", "151", "34",
+	"ETSI", "5G", "40M", "HT", "1T", "151", "32",
+	"MKK", "5G", "40M", "HT", "1T", "151", "63",
+	"FCC", "5G", "40M", "HT", "1T", "159", "34",
+	"ETSI", "5G", "40M", "HT", "1T", "159", "32",
+	"MKK", "5G", "40M", "HT", "1T", "159", "63",
+	"FCC", "5G", "40M", "HT", "2T", "38", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "38", "30",
+	"MKK", "5G", "40M", "HT", "2T", "38", "30",
+	"FCC", "5G", "40M", "HT", "2T", "46", "28",
+	"ETSI", "5G", "40M", "HT", "2T", "46", "30",
+	"MKK", "5G", "40M", "HT", "2T", "46", "30",
+	"FCC", "5G", "40M", "HT", "2T", "54", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "54", "30",
+	"MKK", "5G", "40M", "HT", "2T", "54", "30",
+	"FCC", "5G", "40M", "HT", "2T", "62", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "62", "30",
+	"MKK", "5G", "40M", "HT", "2T", "62", "30",
+	"FCC", "5G", "40M", "HT", "2T", "102", "26",
+	"ETSI", "5G", "40M", "HT", "2T", "102", "30",
+	"MKK", "5G", "40M", "HT", "2T", "102", "30",
+	"FCC", "5G", "40M", "HT", "2T", "110", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "110", "30",
+	"MKK", "5G", "40M", "HT", "2T", "110", "30",
+	"FCC", "5G", "40M", "HT", "2T", "118", "34",
+	"ETSI", "5G", "40M", "HT", "2T", "118", "30",
+	"MKK", "5G", "40M", "HT", "2T", "118", "30",
+	"FCC", "5G", "40M", "HT", "2T", "126", "32",
+	"ETSI", "5G", "40M", "HT", "2T", "126", "30",
+	"MKK", "5G", "40M", "HT", "2T", "126", "30",
+	"FCC", "5G", "40M", "HT", "2T", "134", "30",
+	"ETSI", "5G", "40M", "HT", "2T", "134", "30",
+	"MKK", "5G", "40M", "HT", "2T", "134", "30",
+	"FCC", "5G", "40M", "HT", "2T", "151", "34",
+	"ETSI", "5G", "40M", "HT", "2T", "151", "30",
+	"MKK", "5G", "40M", "HT", "2T", "151", "63",
+	"FCC", "5G", "40M", "HT", "2T", "159", "34",
+	"ETSI", "5G", "40M", "HT", "2T", "159", "30",
+	"MKK", "5G", "40M", "HT", "2T", "159", "63",
+	"FCC", "5G", "80M", "VHT", "1T", "42", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "42", "32",
+	"MKK", "5G", "80M", "VHT", "1T", "42", "32",
+	"FCC", "5G", "80M", "VHT", "1T", "58", "28",
+	"ETSI", "5G", "80M", "VHT", "1T", "58", "32",
+	"MKK", "5G", "80M", "VHT", "1T", "58", "32",
+	"FCC", "5G", "80M", "VHT", "1T", "106", "30",
+	"ETSI", "5G", "80M", "VHT", "1T", "106", "32",
+	"MKK", "5G", "80M", "VHT", "1T", "106", "32",
+	"FCC", "5G", "80M", "VHT", "1T", "122", "34",
+	"ETSI", "5G", "80M", "VHT", "1T", "122", "32",
+	"MKK", "5G", "80M", "VHT", "1T", "122", "32",
+	"FCC", "5G", "80M", "VHT", "1T", "155", "34",
+	"ETSI", "5G", "80M", "VHT", "1T", "155", "32",
+	"MKK", "5G", "80M", "VHT", "1T", "155", "63",
+	"FCC", "5G", "80M", "VHT", "2T", "42", "28",
+	"ETSI", "5G", "80M", "VHT", "2T", "42", "30",
+	"MKK", "5G", "80M", "VHT", "2T", "42", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "58", "26",
+	"ETSI", "5G", "80M", "VHT", "2T", "58", "30",
+	"MKK", "5G", "80M", "VHT", "2T", "58", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "106", "28",
+	"ETSI", "5G", "80M", "VHT", "2T", "106", "30",
+	"MKK", "5G", "80M", "VHT", "2T", "106", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "122", "32",
+	"ETSI", "5G", "80M", "VHT", "2T", "122", "30",
+	"MKK", "5G", "80M", "VHT", "2T", "122", "30",
+	"FCC", "5G", "80M", "VHT", "2T", "155", "34",
+	"ETSI", "5G", "80M", "VHT", "2T", "155", "30",
+	"MKK", "5G", "80M", "VHT", "2T", "155", "63"
+};
+
+void
+odm_read_and_config_mp_8188f_txpwr_lmt(
+	struct dm_struct	*dm
+)
+{
+	u32	i = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	u32	array_len = sizeof(array_mp_8188f_txpwr_lmt)/sizeof(u8);
+	u8	*array = (u8 *)array_mp_8188f_txpwr_lmt;
+#else
+	u32	array_len = sizeof(array_mp_8188f_txpwr_lmt)/sizeof(u8 *);
+	u8	**array = (u8 **)array_mp_8188f_txpwr_lmt;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len/7;
+#endif
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_read_and_config_mp_8188f_txpwr_lmt\n");
+
+	for (i = 0; i < array_len; i += 7) {
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		u8	regulation = array[i];
+		u8	band = array[i+1];
+		u8	bandwidth = array[i+2];
+		u8	rate = array[i+3];
+		u8	rf_path = array[i+4];
+		u8	chnl = array[i+5];
+		u8	val = array[i+6];
+#else
+		u8	*regulation = array[i];
+		u8	*band = array[i+1];
+		u8	*bandwidth = array[i+2];
+		u8	*rate = array[i+3];
+		u8	*rf_path = array[i+4];
+		u8	*chnl = array[i+5];
+		u8	*val = array[i+6];
+#endif
+
+		odm_config_bb_txpwr_lmt_8188f(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		regulation, band, bandwidth, rate, rf_path, chnl, val);
+#endif
+	}
+
+}
+
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.h
index d972a9cb2ea0..1e9fa016ad93 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halhwimg8188f_rf.h
@@ -1,79 +1,75 @@
-/****************************************************************************** 
-* 
-* 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. 
-* 
-* You should have received a copy of the GNU General Public License along with 
-* this program; if not, write to the Free Software Foundation, Inc., 
-* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA 
-* 
-* 
-******************************************************************************/
-
-/*Image2HeaderVersion: 2.26*/
-#if (RTL8188F_SUPPORT == 1)
-#ifndef __INC_MP_RF_HW_IMG_8188F_H
-#define __INC_MP_RF_HW_IMG_8188F_H
-
-
-/******************************************************************************
-*                           RadioA.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_RadioA(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_RadioA(void);
-
-/******************************************************************************
-*                           TxPowerTrack_AP.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_TxPowerTrack_AP(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_TxPowerTrack_AP(void);
-
-/******************************************************************************
-*                           TxPowerTrack_SDIO.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_TxPowerTrack_SDIO(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_TxPowerTrack_SDIO(void);
-
-/******************************************************************************
-*                           TxPowerTrack_USB.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_TxPowerTrack_USB(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_TxPowerTrack_USB(void);
-
-/******************************************************************************
-*                           TXPWR_LMT.TXT
-******************************************************************************/
-
-void
-ODM_ReadAndConfig_MP_8188F_TXPWR_LMT(/* TC: Test Chip, MP: MP Chip*/
-	IN   PDM_ODM_T  pDM_Odm
-);
-u4Byte ODM_GetVersion_MP_8188F_TXPWR_LMT(void);
-
-#endif
-#endif /* end of HWIMG_SUPPORT*/
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/*Image2HeaderVersion: 3.5.2*/
+#if (RTL8188F_SUPPORT == 1)
+#ifndef __INC_MP_RF_HW_IMG_8188F_H
+#define __INC_MP_RF_HW_IMG_8188F_H
+
+
+/******************************************************************************
+*                           radioa.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_radioa(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_radioa(void);
+
+/******************************************************************************
+*                           txpowertrack_ap.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_txpowertrack_ap(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_txpowertrack_ap(void);
+
+/******************************************************************************
+*                           txpowertrack_sdio.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_txpowertrack_sdio(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_txpowertrack_sdio(void);
+
+/******************************************************************************
+*                           txpowertrack_usb.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_txpowertrack_usb(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_txpowertrack_usb(void);
+
+/******************************************************************************
+*                           txpwr_lmt.TXT
+******************************************************************************/
+
+void
+odm_read_and_config_mp_8188f_txpwr_lmt(/* tc: Test Chip, mp: mp Chip*/
+	struct	dm_struct *dm
+);
+u32	odm_get_version_mp_8188f_txpwr_lmt(void);
+
+#endif
+#endif /* end of HWIMG_SUPPORT*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halphyrf_8188f.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halphyrf_8188f.c
deleted file mode 100644
index 34b826c65baa..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halphyrf_8188f.c
+++ /dev/null
@@ -1,3907 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#define		bMaskH3Bytes				0xffffff00
-
-//#define SUCCESS 0
-//#define FAIL -1
-
-
-/*---------------------------Define Local Constant---------------------------*/
-// 2010/04/25 MH Define the max tx power tracking tx agc power.
-#define	ODM_TXPWRTRACK_MAX_IDX8188F		6
-
-// MACRO definition for pRFCalibrateInfo->TxIQC_8188F[0]
-#define 	PATH_S0                         1 // RF_PATH_B
-#define     IDX_0xC94                       0
-#define     IDX_0xC80                       1
-#define     IDX_0xC4C                       2
-#define     IDX_0xC14                       0
-#define     IDX_0xCA0                       1
-#define     KEY                             0
-#define     VAL                             1
-
-// MACRO definition for pRFCalibrateInfo->TxIQC_8188F[1]
-#define 	PATH_S1                         0 // RF_PATH_A
-#define     IDX_0xC9C                       0
-#define     IDX_0xC88                       1
-#define     IDX_0xC4C                       2
-#define     IDX_0xC1C                       0
-#define     IDX_0xC78                       1
-
-
-
-/*---------------------------Define Local Constant---------------------------*/
-
-
-//3============================================================
-//3 Tx Power Tracking
-//3============================================================
-
-
-void setIqkMatrix_8188F(
-	PDM_ODM_T pDM_Odm,
-	s1Byte OFDM_index,
-	u1Byte RFPath,
-	s4Byte IqkResult_X,
-	s4Byte IqkResult_Y
-)
-{
-	s4Byte ele_A = 0, ele_D, ele_C = 0, value32;
-
-	if (OFDM_index >= OFDM_TABLE_SIZE)
-		OFDM_index = OFDM_TABLE_SIZE - 1;
-	else if (OFDM_index < 0)
-		OFDM_index = 0;
-
-	ele_D = (OFDMSwingTable_New[OFDM_index] & 0xFFC00000) >> 22;
-
-	//new element A = element D x X
-	if ((IqkResult_X != 0) && (*(pDM_Odm->pBandType) == ODM_BAND_2_4G)) {
-		if ((IqkResult_X & 0x00000200) != 0)    //consider minus
-			IqkResult_X = IqkResult_X | 0xFFFFFC00;
-		ele_A = ((IqkResult_X * ele_D) >> 8) & 0x000003FF;
-
-		//new element C = element D x Y
-		if ((IqkResult_Y & 0x00000200) != 0)
-			IqkResult_Y = IqkResult_Y | 0xFFFFFC00;
-		ele_C = ((IqkResult_Y * ele_D) >> 8) & 0x000003FF;
-
-		if (RFPath == ODM_RF_PATH_A)
-			switch (RFPath) {
-			case ODM_RF_PATH_A:
-				//wirte new elements A, C, D to regC80 and regC94, element B is always 0
-				value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
-				ODM_SetBBReg(pDM_Odm, rOFDM0_XATxIQImbalance, bMaskDWord, value32);
-
-				value32 = (ele_C & 0x000003C0) >> 6;
-				ODM_SetBBReg(pDM_Odm, rOFDM0_XCTxAFE, bMaskH4Bits, value32);
-
-				value32 = ((IqkResult_X * ele_D) >> 7) & 0x01;
-				ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, BIT24, value32);
-				break;
-			case ODM_RF_PATH_B:
-				//wirte new elements A, C, D to regC88 and regC9C, element B is always 0
-				value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
-				ODM_SetBBReg(pDM_Odm, rOFDM0_XBTxIQImbalance, bMaskDWord, value32);
-
-				value32 = (ele_C & 0x000003C0) >> 6;
-				ODM_SetBBReg(pDM_Odm, rOFDM0_XDTxAFE, bMaskH4Bits, value32);
-
-				value32 = ((IqkResult_X * ele_D) >> 7) & 0x01;
-				ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, BIT28, value32);
-
-				break;
-			default:
-				break;
-			}
-	} else {
-		switch (RFPath) {
-		case ODM_RF_PATH_A:
-			ODM_SetBBReg(pDM_Odm, rOFDM0_XATxIQImbalance, bMaskDWord, OFDMSwingTable_New[OFDM_index]);
-			ODM_SetBBReg(pDM_Odm, rOFDM0_XCTxAFE, bMaskH4Bits, 0x00);
-			ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, BIT24, 0x00);
-			break;
-
-		case ODM_RF_PATH_B:
-			ODM_SetBBReg(pDM_Odm, rOFDM0_XBTxIQImbalance, bMaskDWord, OFDMSwingTable_New[OFDM_index]);
-			ODM_SetBBReg(pDM_Odm, rOFDM0_XDTxAFE, bMaskH4Bits, 0x00);
-			ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, BIT28, 0x00);
-			break;
-
-		default:
-			break;
-		}
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("TxPwrTracking path B: X = 0x%x, Y = 0x%x ele_A = 0x%x ele_C = 0x%x ele_D = 0x%x 0xeb4 = 0x%x 0xebc = 0x%x\n",
-				 (u4Byte)IqkResult_X, (u4Byte)IqkResult_Y, (u4Byte)ele_A, (u4Byte)ele_C, (u4Byte)ele_D, (u4Byte)IqkResult_X, (u4Byte)IqkResult_Y));
-}
-
-void DoIQK_8188F(
-	PVOID pDM_VOID,
-	u1Byte DeltaThermalIndex,
-	u1Byte ThermalValue,
-	u1Byte Threshold
-)
-{
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER Adapter = pDM_Odm->Adapter;
-#if(DM_ODM_SUPPORT_TYPE  & ODM_WIN)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
-#endif
-#if(DM_ODM_SUPPORT_TYPE  & ODM_CE)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
-#endif
-#endif
-
-	ODM_ResetIQKResult(pDM_Odm);
-
-#if(DM_ODM_SUPPORT_TYPE  & ODM_WIN)
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-#if USE_WORKITEM
-	PlatformAcquireMutex(&pHalData->mxChnlBwControl);
-#else
-	PlatformAcquireSpinLock(Adapter, RT_CHANNEL_AND_BANDWIDTH_SPINLOCK);
-#endif
-#elif((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-	PlatformAcquireMutex(&pHalData->mxChnlBwControl);
-#endif
-#endif
-
-
-	pDM_Odm->RFCalibrateInfo.ThermalValue_IQK = ThermalValue;
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	PHY_IQCalibrate_8188F(pDM_Odm, FALSE, FALSE);
-#else
-	PHY_IQCalibrate_8188F(Adapter, FALSE, FALSE);
-#endif
-
-#if(DM_ODM_SUPPORT_TYPE  & ODM_WIN)
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-#if USE_WORKITEM
-	PlatformReleaseMutex(&pHalData->mxChnlBwControl);
-#else
-	PlatformReleaseSpinLock(Adapter, RT_CHANNEL_AND_BANDWIDTH_SPINLOCK);
-#endif
-#elif((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-	PlatformReleaseMutex(&pHalData->mxChnlBwControl);
-#endif
-#endif
-}
-
-/*-----------------------------------------------------------------------------
- * Function:	odm_TxPwrTrackSetPwr88E()
- *
- * Overview:	88E change all channel tx power accordign to flag.
- *				OFDM & CCK are all different.
- *
- * Input:		NONE
- *
- * Output:		NONE
- *
- * Return:		NONE
- *
- * Revised History:
- *	When		Who		Remark
- *	04/23/2012	MHC		Create Version 0.
- *
- *---------------------------------------------------------------------------*/
-VOID
-ODM_TxPwrTrackSetPwr_8188F(
-	IN PVOID pDM_VOID,
-	PWRTRACK_METHOD Method,
-	u1Byte RFPath,
-	u1Byte ChannelMappedIndex
-)
-{
-	PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER Adapter = pDM_Odm->Adapter;
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
-	u1Byte PwrTrackingLimit_OFDM = 32; 
-	u1Byte PwrTrackingLimit_CCK = CCK_TABLE_SIZE_88F-1;   //-2dB
-	u1Byte TxRate = 0xFF;
-	s1Byte Final_OFDM_Swing_Index = 0;
-	s1Byte Final_CCK_Swing_Index = 0;
-//	u1Byte	i = 0;
-	PODM_RF_CAL_T pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-#if 0
-#if (MP_DRIVER==1)
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
-	PMPT_CONTEXT pMptCtx = &(Adapter->MptCtx);
-	TxRate = MptToMgntRate(pMptCtx->MptRateIndex);
-#else
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
-	PMGNT_INFO pMgntInfo = &(Adapter->MgntInfo);
-	if (!pMgntInfo->ForcedDataRate) { //auto rate
-		if (pDM_Odm->TxRate != 0xFF)
-			TxRate = HwRateToMRate8812(pDM_Odm->TxRate);
-	} else   //force rate
-		TxRate = (u1Byte) pMgntInfo->ForcedDataRate;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("===>ODM_TxPwrTrackSetPwr8188F\n"));
-
-	if (TxRate != 0xFF) {
-		//2 CCK
-		if (((TxRate >= MGN_1M) && (TxRate <= MGN_5_5M)) || (TxRate == MGN_11M))
-			PwrTrackingLimit_CCK = CCK_TABLE_SIZE_88F-1;  //-2dB
-		//2 OFDM
-		else if ((TxRate >= MGN_6M) && (TxRate <= MGN_48M))
-			PwrTrackingLimit_OFDM = 36; //+3dB
-		else if (TxRate == MGN_54M)
-			PwrTrackingLimit_OFDM = 34; //+2dB
-
-		//2 HT
-		else if ((TxRate >= MGN_MCS0) && (TxRate <= MGN_MCS2)) //QPSK/BPSK
-			PwrTrackingLimit_OFDM = 38; //+4dB
-		else if ((TxRate >= MGN_MCS3) && (TxRate <= MGN_MCS4)) //16QAM
-			PwrTrackingLimit_OFDM = 36; //+3dB
-		else if ((TxRate >= MGN_MCS5) && (TxRate <= MGN_MCS7)) //64QAM
-			PwrTrackingLimit_OFDM = 34; //+2dB
-
-		else
-			PwrTrackingLimit_OFDM = pRFCalibrateInfo->DefaultOfdmIndex;   //Default OFDM index = 30
-	}
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("TxRate=0x%x, PwrTrackingLimit=%d\n", TxRate, PwrTrackingLimit_OFDM));
-
-	RT_TRACE(COMP_CMD, DBG_LOUD, ("Method=%d\n", Method));
-
-	if (Method == TXAGC) 
-	{
-		//u1Byte	rf = 0;
-#if (MP_DRIVER == 1)
-		u4Byte pwr = 0, TxAGC = 0;
-#endif
-		PADAPTER Adapter = pDM_Odm->Adapter;
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("odm_TxPwrTrackSetPwr8188F CH=%d\n", *(pDM_Odm->pChannel)));
-
-		pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath] = pRFCalibrateInfo->Absolute_OFDMSwingIdx[RFPath];
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-
-	#if (MP_DRIVER == 1)
-		if ( (pDM_Odm->mp_mode) == 1) {
-			pwr = PHY_QueryBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte1);  
-			pwr += pDM_Odm->RFCalibrateInfo.PowerIndexOffset[ODM_RF_PATH_A];
-			PHY_SetBBReg(Adapter, rTxAGC_A_CCK1_Mcs32, bMaskByte1, pwr);              //CCK 1M
-
-			if (pwr>0x3F)
-				pwr=0x3F;              //add by Mingzhi.Guo 2015-04-10
-			else if(pwr <= 0)
-				pwr=0;
-			
-			TxAGC = (pwr<<16)|(pwr<<8)|(pwr);
-			
-			PHY_SetBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, 0xffffff00, TxAGC);              //CCK 2~11M
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ODM_TxPwrTrackSetPwr8188F: CCK Tx-rf(A) Power = 0x%x\n", TxAGC));
-
-			pwr = PHY_QueryBBReg(Adapter, rTxAGC_A_Rate18_06, 0xFF);
-			pwr += (pRFCalibrateInfo->BbSwingIdxOfdm[ODM_RF_PATH_A] - pRFCalibrateInfo->BbSwingIdxOfdmBase[ODM_RF_PATH_A]);
-			TxAGC |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate18_06, bMaskDWord, TxAGC);
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate54_24, bMaskDWord, TxAGC);
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskDWord, TxAGC);
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskDWord, TxAGC);
-		//	PHY_SetBBReg(Adapter, rTxAGC_A_Mcs11_Mcs08, bMaskDWord, TxAGC);
-		//	PHY_SetBBReg(Adapter, rTxAGC_A_Mcs15_Mcs12, bMaskDWord, TxAGC);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ODM_TxPwrTrackSetPwr8188F: OFDM Tx-rf(A) Power = 0x%x\n", TxAGC));
-		} else
-#endif
-		{
-			//PHY_SetTxPowerLevelByPath8188F(Adapter, pHalData->CurrentChannel, ODM_RF_PATH_A);
-			//PHY_SetTxPowerLevel8188F(pDM_Odm->Adapter, *pDM_Odm->pChannel);
-			pRFCalibrateInfo->Modify_TxAGC_Flag_PathA = TRUE;
-			pRFCalibrateInfo->Modify_TxAGC_Flag_PathA_CCK = TRUE;
-
-			if (RFPath == ODM_RF_PATH_A) {
-				PHY_SetTxPowerIndexByRateSection(Adapter, ODM_RF_PATH_A, pHalData->CurrentChannel, CCK);
-				PHY_SetTxPowerIndexByRateSection(Adapter, ODM_RF_PATH_A, pHalData->CurrentChannel, OFDM);
-				PHY_SetTxPowerIndexByRateSection(Adapter, ODM_RF_PATH_A, pHalData->CurrentChannel, HT_MCS0_MCS7);
-			}
-		}
-
-#endif
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-		//PHY_RF6052SetCCKTxPower(pDM_Odm->priv, *(pDM_Odm->pChannel));
-		//PHY_RF6052SetOFDMTxPower(pDM_Odm->priv, *(pDM_Odm->pChannel));
-#endif
-
-	} else if (Method == BBSWING) {
-		Final_OFDM_Swing_Index = pRFCalibrateInfo->DefaultOfdmIndex + pRFCalibrateInfo->Absolute_OFDMSwingIdx[RFPath];
-		Final_CCK_Swing_Index = pRFCalibrateInfo->DefaultCckIndex + pRFCalibrateInfo->Absolute_OFDMSwingIdx[RFPath];
-
-		// Adjust BB swing by OFDM IQ matrix
-		if (Final_OFDM_Swing_Index >= PwrTrackingLimit_OFDM)
-			Final_OFDM_Swing_Index = PwrTrackingLimit_OFDM;
-		else if (Final_OFDM_Swing_Index <= 0)
-			Final_OFDM_Swing_Index = 0;
-
-		if (Final_CCK_Swing_Index >= CCK_TABLE_SIZE_88F)
-			Final_CCK_Swing_Index = CCK_TABLE_SIZE_88F - 1;
-		else if ((s1Byte)pRFCalibrateInfo->BbSwingIdxCck < 0)
-			Final_CCK_Swing_Index = 0;
-		
-		if (RFPath == ODM_RF_PATH_A)
-		{
-			
-			setIqkMatrix_8188F(pDM_Odm, Final_OFDM_Swing_Index, ODM_RF_PATH_A, 
-				pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][0],
-				pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][1]);	
-			if (!pRFCalibrateInfo->bCCKinCH14) {
-				ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][0]);
-				ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][1]);
-				ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][2]);
-				ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][3]);
-				ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][4]);
-				ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][5]);
-				ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][6]);
-				ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][7]);		
-				ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][8]);
-				ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][9]);
-				ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][10]);
-				ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][11]);
-				ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][12]);
-				ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][13]);
-				ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][14]);
-				ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][15]);
-			} else {
-				ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][0]);
-				ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][1]);
-				ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][2]);
-				ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][3]);
-				ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][4]);
-				ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][5]);
-				ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][6]);
-				ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][7]);		
-				ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][8]);
-				ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][9]);
-				ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][10]);
-				ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][11]);
-				ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][12]);
-				ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][13]);
-				ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][14]);
-				ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][15]);
-			}				
-		}
-		
-	}
-	else if (Method == MIX_MODE)
-	{
-	#if (MP_DRIVER == 1)
-		//u4Byte 	pwr = 0, TxAGC = 0;
-		u4Byte	TxAGC=0;              //add by Mingzhi.Guo 2015-04-10
-		s4Byte    pwr=0;
-	#endif
-		RT_TRACE(COMP_CMD, DBG_LOUD, ("Method is MIX_MODE ====> \n"));
-		ODM_RT_TRACE(pDM_Odm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("pRFCalibrateInfo->DefaultOfdmIndex=%d,  pRFCalibrateInfo->DefaultCCKIndex=%d, pRFCalibrateInfo->Absolute_OFDMSwingIdx[RFPath]=%d, RF_Path = %d\n",
-				pRFCalibrateInfo->DefaultOfdmIndex, pRFCalibrateInfo->DefaultCckIndex, pRFCalibrateInfo->Absolute_OFDMSwingIdx[RFPath],RFPath ));
-
-		Final_OFDM_Swing_Index = pRFCalibrateInfo->DefaultOfdmIndex + pRFCalibrateInfo->Absolute_OFDMSwingIdx[RFPath];
-		Final_CCK_Swing_Index = pRFCalibrateInfo->DefaultCckIndex + pRFCalibrateInfo->Absolute_OFDMSwingIdx[RFPath];
-		if (RFPath == ODM_RF_PATH_A) {
-			if (Final_OFDM_Swing_Index > PwrTrackingLimit_OFDM) {     //BBSwing higher then Limit
-				pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index - PwrTrackingLimit_OFDM;
-
-				setIqkMatrix_8188F(pDM_Odm, PwrTrackingLimit_OFDM, RFPath,
-								   pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][0],
-								   pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][1]);
-
-				pRFCalibrateInfo->Modify_TxAGC_Flag_PathA = TRUE;
-
-				//Set TxAGC Page C{};
-				
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							 ("******Path_A Over BBSwing Limit , PwrTrackingLimit = %d , Remnant TxAGC Value = %d\n",
-							  PwrTrackingLimit_OFDM, pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath]));
-				} else if (Final_OFDM_Swing_Index < pRFCalibrateInfo->DefaultOfdmIndex) {
-					pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index - pRFCalibrateInfo->DefaultOfdmIndex; 
-					setIqkMatrix_8188F(pDM_Odm, pRFCalibrateInfo->DefaultOfdmIndex, ODM_RF_PATH_A, 
-						 pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][0],
-						 pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][1]);		
-
-					pRFCalibrateInfo->Modify_TxAGC_Flag_PathA = TRUE;
-				/* Set TxAGC Page C{}; */
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							 ("******Path_A Lower then BBSwing lower bound  28 , Remnant TxAGC Value = %d\n",
-							  pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath]));
-			}
-
-			/*
-				else if (Final_OFDM_Swing_Index < 0)
-				{
-					pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath] = Final_OFDM_Swing_Index ; 
-					setIqkMatrix_8188F(pDM_Odm, 0, ODM_RF_PATH_A, 
-						 pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][0],
-						 pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][1]);		
-
-					pRFCalibrateInfo->Modify_TxAGC_Flag_PathA=TRUE;
-				//Set TxAGC Page C{};
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							 ("******Path_A Lower then BBSwing lower bound  0 , Remnant TxAGC Value = %d\n",
-							  pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath]));
-			}
-			*/
-			else {
-				setIqkMatrix_8188F(pDM_Odm, Final_OFDM_Swing_Index, ODM_RF_PATH_A,
-								   pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][0],
-								   pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[ChannelMappedIndex].Value[0][1]);
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							 ("******Path_A Compensate with BBSwing , Final_OFDM_Swing_Index = %d\n", Final_OFDM_Swing_Index));
-
-				if (pRFCalibrateInfo->Modify_TxAGC_Flag_PathA) {  //If TxAGC has changed, reset TxAGC again
-					pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath] = 0; 
-				}
-				}
-	#if (MP_DRIVER == 1) && (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-					if ( (pDM_Odm->mp_mode) == 1) {
-						pwr = PHY_QueryBBReg(Adapter, rTxAGC_A_Rate18_06, 0xFF);
-						pwr += (pRFCalibrateInfo->Remnant_OFDMSwingIdx[ODM_RF_PATH_A] - pRFCalibrateInfo->Modify_TxAGC_Value_OFDM);
-
-						if (pwr>0x3F)					pwr=0x3F;               //add by Mingzhi.Guo 2015-04-10
-						else if(pwr<0)				pwr=0;
-						
-						if (pwr == 0x32 || pwr == 0x33) 
-							pwr = 0x34; /*8188F TXAGC skip index 32&33 to avoid bad TX EVM, suggested  by RF_Jayden*/					
-						
-						TxAGC |= ((pwr<<24)|(pwr<<16)|(pwr<<8)|pwr);
-						PHY_SetBBReg(Adapter, rTxAGC_A_Rate18_06, bMaskDWord, TxAGC);
-						PHY_SetBBReg(Adapter, rTxAGC_A_Rate54_24, bMaskDWord, TxAGC);
-						PHY_SetBBReg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskDWord, TxAGC);
-						PHY_SetBBReg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskDWord, TxAGC);
-						//PHY_SetBBReg(Adapter, rTxAGC_A_Mcs11_Mcs08, bMaskDWord, TxAGC);
-						//PHY_SetBBReg(Adapter, rTxAGC_A_Mcs15_Mcs12, bMaskDWord, TxAGC);
-						ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ODM_TxPwrTrackSetPwr8188F: OFDM Tx-rf(A) Power = 0x%x\n", TxAGC));
-
-						
-					}
-					else
-	#endif
-					{
-					//Set TxAGC Page C{};
-						PHY_SetTxPowerIndexByRateSection(Adapter, ODM_RF_PATH_A, pHalData->CurrentChannel, OFDM );
-						PHY_SetTxPowerIndexByRateSection(Adapter, ODM_RF_PATH_A, pHalData->CurrentChannel, HT_MCS0_MCS7 );
-					}
-					pRFCalibrateInfo->Modify_TxAGC_Value_OFDM=pRFCalibrateInfo->Remnant_OFDMSwingIdx[ODM_RF_PATH_A] ;        //add by Mingzhi.Guo
-
-
-				//MIX mode: CCK
-				if(Final_CCK_Swing_Index > PwrTrackingLimit_CCK)
-				{
-					pRFCalibrateInfo->Remnant_CCKSwingIdx = Final_CCK_Swing_Index - PwrTrackingLimit_CCK;
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A CCK Over Limit , PwrTrackingLimit_CCK = %d , pRFCalibrateInfo->Remnant_CCKSwingIdx  = %d\n", PwrTrackingLimit_CCK, pRFCalibrateInfo->Remnant_CCKSwingIdx));
-					if (!pRFCalibrateInfo->bCCKinCH14) {
-						ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][0]);
-						ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][1]);
-						ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][2]);
-						ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][3]);
-						ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][4]);
-						ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][5]);
-						ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][6]);
-						ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][7]);		
-						ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][8]);				
-						ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][9]);
-						ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][10]);
-						ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][11]);
-						ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][12]);
-						ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][13]);
-						ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][14]);
-						ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch1_Ch13_88F[PwrTrackingLimit_CCK][15]);
-					} else {
-						ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][0]);
-						ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][1]);
-						ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][2]);
-						ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][3]);
-						ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][4]);
-						ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][5]);
-						ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][6]);
-						ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][7]);		
-						ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][8]);				
-						ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][9]);
-						ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][10]);
-						ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][11]);
-						ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][12]);
-						ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][13]);
-						ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][14]);
-						ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch14_88F[PwrTrackingLimit_CCK][15]);
-					}
-
-					pRFCalibrateInfo->Modify_TxAGC_Flag_PathA_CCK = TRUE;
-
-				}
-				else if(Final_CCK_Swing_Index < 0)    // Lowest CCK Index = 0
-				{
-					pRFCalibrateInfo->Remnant_CCKSwingIdx = Final_CCK_Swing_Index;
-
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A CCK Under Limit , PwrTrackingLimit_CCK = %d , pRFCalibrateInfo->Remnant_CCKSwingIdx  = %d\n", 0, pRFCalibrateInfo->Remnant_CCKSwingIdx));
-					if (!pRFCalibrateInfo->bCCKinCH14) {
-						ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch1_Ch13_88F[0][0]);
-						ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch1_Ch13_88F[0][1]);
-						ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch1_Ch13_88F[0][2]);
-						ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch1_Ch13_88F[0][3]);
-						ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch1_Ch13_88F[0][4]);
-						ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch1_Ch13_88F[0][5]);
-						ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch1_Ch13_88F[0][6]);
-						ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch1_Ch13_88F[0][7]);		
-						ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch1_Ch13_88F[0][8]);				
-						ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch1_Ch13_88F[0][9]);
-						ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch1_Ch13_88F[0][10]);
-						ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch1_Ch13_88F[0][11]);
-						ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch1_Ch13_88F[0][12]);
-						ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch1_Ch13_88F[0][13]);
-						ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch1_Ch13_88F[0][14]);
-						ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch1_Ch13_88F[0][15]);
-					} else {
-						ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch14_88F[0][0]);
-						ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch14_88F[0][1]);
-						ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch14_88F[0][2]);
-						ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch14_88F[0][3]);
-						ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch14_88F[0][4]);
-						ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch14_88F[0][5]);
-						ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch14_88F[0][6]);
-						ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch14_88F[0][7]);		
-						ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch14_88F[0][8]);				
-						ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch14_88F[0][9]);
-						ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch14_88F[0][10]);
-						ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch14_88F[0][11]);
-						ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch14_88F[0][12]);
-						ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch14_88F[0][13]);
-						ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch14_88F[0][14]);
-						ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch14_88F[0][15]);
-					}
-					pRFCalibrateInfo->Modify_TxAGC_Flag_PathA_CCK = TRUE;
-
-				}
-				
-				else {
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A CCK Compensate with BBSwing , Final_CCK_Swing_Index = %d\n", Final_CCK_Swing_Index));	
-					if (!pRFCalibrateInfo->bCCKinCH14) {
-						ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][0]);
-						ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][1]);
-						ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][2]);
-						ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][3]);
-						ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][4]);
-						ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][5]);
-						ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][6]);
-						ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][7]);		
-						ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][8]);				
-						ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][9]);
-						ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][10]);
-						ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][11]);
-						ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][12]);
-						ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][13]);
-						ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][14]);
-						ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch1_Ch13_88F[Final_CCK_Swing_Index][15]); 
-					} else {
-						ODM_Write1Byte(pDM_Odm, 0xa22, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][0]);
-						ODM_Write1Byte(pDM_Odm, 0xa23, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][1]);
-						ODM_Write1Byte(pDM_Odm, 0xa24, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][2]);
-						ODM_Write1Byte(pDM_Odm, 0xa25, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][3]);
-						ODM_Write1Byte(pDM_Odm, 0xa26, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][4]);
-						ODM_Write1Byte(pDM_Odm, 0xa27, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][5]);
-						ODM_Write1Byte(pDM_Odm, 0xa28, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][6]);
-						ODM_Write1Byte(pDM_Odm, 0xa29, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][7]);		
-						ODM_Write1Byte(pDM_Odm, 0xa9a, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][8]);				
-						ODM_Write1Byte(pDM_Odm, 0xa9b, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][9]);
-						ODM_Write1Byte(pDM_Odm, 0xa9c, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][10]);
-						ODM_Write1Byte(pDM_Odm, 0xa9d, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][11]);
-						ODM_Write1Byte(pDM_Odm, 0xaa0, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][12]);
-						ODM_Write1Byte(pDM_Odm, 0xaa1, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][13]);
-						ODM_Write1Byte(pDM_Odm, 0xaa2, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][14]);
-						ODM_Write1Byte(pDM_Odm, 0xaa3, CCKSwingTable_Ch14_88F[Final_CCK_Swing_Index][15]);	
-					}
-	
-					pRFCalibrateInfo->Modify_TxAGC_Flag_PathA_CCK=FALSE;
-					pRFCalibrateInfo->Remnant_CCKSwingIdx = 0;     
-
-				}
-	#if (MP_DRIVER == 1) && (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-				if ( (pDM_Odm->mp_mode) == 1) {
-					pwr = PHY_QueryBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte1);  
-					pwr +=pRFCalibrateInfo->Remnant_CCKSwingIdx-pRFCalibrateInfo->Modify_TxAGC_Value_CCK;
-	
-					if (pwr>0x3F)					pwr=0x3F;               //add by Mingzhi.Guo 2015-04-10
-					else if(pwr<0)				pwr=0;
-
-					PHY_SetBBReg(Adapter, rTxAGC_A_CCK1_Mcs32, bMaskByte1, pwr);              //CCK 1M
-					TxAGC = (pwr<<16)|(pwr<<8)|(pwr);
-					PHY_SetBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, 0xffffff00, TxAGC);              //CCK 2~11M
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ODM_TxPwrTrackSetPwr8188F: CCK Tx-rf(A) Power = 0x%x\n", TxAGC));
-				}
-				else
-	#endif
-				{
-					//Set TxAGC Page C{};
-					PHY_SetTxPowerIndexByRateSection(Adapter, ODM_RF_PATH_A, pHalData->CurrentChannel, CCK );
-				}
-				pRFCalibrateInfo->Modify_TxAGC_Value_CCK = pRFCalibrateInfo->Remnant_CCKSwingIdx;
-			
-		}
-	} 
-		else
-		return;
-} // odm_TxPwrTrackSetPwr8188F
-
-
-VOID
-GetDeltaSwingTable_8188F(
-	IN PVOID pDM_VOID,
-	OUT pu1Byte *TemperatureUP_A,
-	OUT pu1Byte *TemperatureDOWN_A,
-	OUT pu1Byte *TemperatureUP_B,
-	OUT pu1Byte *TemperatureDOWN_B
-)
-{
-	PDM_ODM_T			pDM_Odm	= (PDM_ODM_T)pDM_VOID;
-	PADAPTER			Adapter		= pDM_Odm->Adapter;
-	PHAL_DATA_TYPE	pHalData	= GET_HAL_DATA(Adapter);
-	PODM_RF_CAL_T		pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-	u1Byte				TxRate			= 0xFF;
-	u1Byte				channel			= pHalData->CurrentChannel;
-
-	if (pDM_Odm->mp_mode == TRUE) {
-		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-			#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-				#if (MP_DRIVER == 1)
-					PMPT_CONTEXT pMptCtx = &(Adapter->MptCtx);
-						
-					TxRate = MptToMgntRate(pMptCtx->MptRateIndex);
-				#endif
-			#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-				PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.MptCtx);
-					
-				TxRate = MptToMgntRate(pMptCtx->MptRateIndex);
-			#endif	
-		#endif
-	} else {
-		u2Byte	rate	 = *(pDM_Odm->pForcedDataRate);
-		
-		if (!rate) { /*auto rate*/
-			if (rate != 0xFF) {
-				#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-					TxRate = Adapter->HalFunc.GetHwRateFromMRateHandler(pDM_Odm->TxRate);
-				#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-					if (pDM_Odm->number_linked_client != 0)
-						TxRate = HwRateToMRate(pDM_Odm->TxRate);
-				#endif
-			}
-		} else { /*force rate*/
-			TxRate = (u1Byte)rate;
-		}
-	}
-		
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("Power Tracking TxRate=0x%X\n", TxRate));
-
-
-	RT_TRACE(COMP_CMD, DBG_LOUD, ("GetDeltaSwingTable_8188F ====> channel is %d\n", channel));
-	
-	if ( 1 <= channel && channel <= 14) {
-		if (IS_CCK_RATE(TxRate)) {
-			*TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_P;
-			*TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKA_N;
-			*TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_P;
-			*TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GCCKB_N;
-		} else {
-			*TemperatureUP_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GA_P;
-			*TemperatureDOWN_A = pRFCalibrateInfo->DeltaSwingTableIdx_2GA_N;
-			*TemperatureUP_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GB_P;
-			*TemperatureDOWN_B = pRFCalibrateInfo->DeltaSwingTableIdx_2GB_N;
-		}
-	} else {
-		*TemperatureUP_A = (pu1Byte)DeltaSwingTableIdx_2GA_P_8188E;
-		*TemperatureDOWN_A = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E;
-		*TemperatureUP_B = (pu1Byte)DeltaSwingTableIdx_2GA_P_8188E;
-		*TemperatureDOWN_B = (pu1Byte)DeltaSwingTableIdx_2GA_N_8188E;
-	}
-
-	return;
-}
-
-
-void ConfigureTxpowerTrack_8188F(
-	PTXPWRTRACK_CFG pConfig
-)
-{
-	RT_TRACE(COMP_CMD, DBG_LOUD, ("ConfigureTxpowerTrack_8188F ====> \n"));
-	pConfig->SwingTableSize_CCK = CCK_TABLE_SIZE_88F;
-	pConfig->SwingTableSize_OFDM = OFDM_TABLE_SIZE;
-	pConfig->Threshold_IQK = IQK_THRESHOLD;
-	pConfig->AverageThermalNum = AVG_THERMAL_NUM_8188F;
-	pConfig->RfPathCount = MAX_PATH_NUM_8188F;
-	pConfig->ThermalRegAddr = RF_T_METER_8188F;
-	
-	pConfig->ODM_TxPwrTrackSetPwr = ODM_TxPwrTrackSetPwr_8188F;
-	pConfig->DoIQK = DoIQK_8188F;
-	pConfig->PHY_LCCalibrate = PHY_LCCalibrate_8188F;
-	pConfig->GetDeltaSwingTable = GetDeltaSwingTable_8188F;
-}
-
-//1 7.	IQK
-#define MAX_TOLERANCE		5
-#define IQK_DELAY_TIME		1		//ms
-
-u1Byte          //bit0 = 1 => Tx OK, bit1 = 1 => Rx OK
-phy_PathA_IQK_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN configPathB
-)
-{
-	u4Byte regEAC, regE94, regE9C/*, regEA4*/;
-	u1Byte result = 0x00;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A IQK!\n"));
-
-	//  enable path A PA in TXIQK mode
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_RCK_OS, bRFRegOffsetMask, 0x20000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G1, bRFRegOffsetMask, 0x0000f);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G2, bRFRegOffsetMask, 0x07ff7);   //0x07f77
-	//PA,PAD gain adjust
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xdf, bRFRegOffsetMask, 0x980);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x56, bRFRegOffsetMask, 0x5102a); //0x5111e0
-
-
-	//enter IQK mode
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-
-
-	//1 Tx IQK
-	//path-A IQK setting
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path-A IQK setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x18008c1c);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x38008c1c);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_PI_A, bMaskDWord, 0x821403ff);    //0x821403e0
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_PI_A, bMaskDWord, 0x28160000);
-
-	//LO calibration setting
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("LO calibration setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Rsp, bMaskDWord, 0x00462911);
-
-	//One shot, path A LOK & IQK
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("One shot, path A LOK & IQK!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf9000000);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf8000000);
-
-	// delay x ms
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F));
-//PlatformStallExecution(IQK_DELAY_TIME_8188F*1000);
-	ODM_delay_ms(IQK_DELAY_TIME_8188F);
-
-	//reload RF 0xdf
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xdf, bRFRegOffsetMask, 0x180);
-
-	//save LOK result
-	pDM_Odm->RFCalibrateInfo.LOK_Result = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x8, bRFRegOffsetMask);
-
-	// Check failed
-	regEAC = ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_A_2, bMaskDWord);
-	regE94 = ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord);
-	regE9C = ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeac = 0x%x\n", regEAC));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe94 = 0x%x, 0xe9c = 0x%x\n", regE94, regE9C));
-	//monitor image power before & after IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
-				 ODM_GetBBReg(pDM_Odm, 0xe90, bMaskDWord), ODM_GetBBReg(pDM_Odm, 0xe98, bMaskDWord)));
-
-	if (!(regEAC & BIT28) &&
-		(((regE94 & 0x03FF0000) >> 16) != 0x142) &&
-		(((regE9C & 0x03FF0000) >> 16) != 0x42))
-		result |= 0x01;
-
-	return result;
-
-
-}
-
-u1Byte          //bit0 = 1 => Tx OK, bit1 = 1 => Rx OK
-phy_PathA_RxIQK8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN configPathB
-)
-{
-	u4Byte regEAC, regE94, regE9C, regEA4, u4tmp;
-	u1Byte result = 0x00;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A Rx IQK!\n"));
-
-	//1 Get TXIMR setting
-	//modify RXIQK mode table
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path-A Rx IQK modify RXIQK mode table!\n"));
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_RCK_OS, bRFRegOffsetMask, 0x30000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G1, bRFRegOffsetMask, 0x0000f);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G2, bRFRegOffsetMask, 0xf1173);   //0xf117b
-
-	//PA,PAD gain adjust
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xdf, bRFRegOffsetMask, 0x980);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x56, bRFRegOffsetMask, 0x5102a); //0x510f0
-
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-
-	//IQK setting
-	ODM_SetBBReg(pDM_Odm, rTx_IQK, bMaskDWord, 0x01007c00);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK, bMaskDWord, 0x01004800);
-
-	//path-A IQK setting
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x10008c1c);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x30008c1c);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_PI_A, bMaskDWord, 0x82160fff);    //0x821603e0
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_PI_A, bMaskDWord, 0x28160000);
-
-	//LO calibration setting
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("LO calibration setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Rsp, bMaskDWord, 0x00462911);
-
-	//One shot, path A LOK & IQK
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("One shot, path A LOK & IQK!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf9000000);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf8000000);
-
-	// delay x ms
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F));
-//PlatformStallExecution(IQK_DELAY_TIME_8188F*1000);
-	ODM_delay_ms(IQK_DELAY_TIME_8188F);
-
-
-	//reload RF 0xdf
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xdf, bRFRegOffsetMask, 0x180);
-
-
-
-	// Check failed
-	regEAC = ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_A_2, bMaskDWord);
-	regE94 = ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord);
-	regE9C = ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeac = 0x%x\n", regEAC));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe94 = 0x%x, 0xe9c = 0x%x\n", regE94, regE9C));
-	//monitor image power before & after IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
-				 ODM_GetBBReg(pDM_Odm, 0xe90, bMaskDWord), ODM_GetBBReg(pDM_Odm, 0xe98, bMaskDWord)));
-
-	if (!(regEAC & BIT28) &&
-		(((regE94 & 0x03FF0000) >> 16) != 0x142) &&
-		(((regE9C & 0x03FF0000) >> 16) != 0x42))
-		result |= 0x01;
-	else                            //if Tx not OK, ignore Rx
-		return result;
-
-	u4tmp = 0x80007C00 | (regE94 & 0x3FF0000) | ((regE9C & 0x3FF0000) >> 16);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK, bMaskDWord, u4tmp);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe40 = 0x%x u4tmp = 0x%x\n", ODM_GetBBReg(pDM_Odm, rTx_IQK, bMaskDWord), u4tmp));
-
-
-	//1 RX IQK
-	//modify RXIQK mode table
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path-A Rx IQK modify RXIQK mode table 2!\n"));
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);                 // 0xEF[19]   = 0x1
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_RCK_OS, bRFRegOffsetMask, 0x30000);  // 0x30[19:0] = 0x18000
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G1, bRFRegOffsetMask, 0x0000f); // 0x31[19:0] = 0x0000f
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G2, bRFRegOffsetMask, 0xf7ff2); // 0x32[19:0] = 0xf7ffa
-
-	//PA,PAD gain adjust
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xdf, bRFRegOffsetMask, 0x980);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x56, bRFRegOffsetMask, 0x51000); //0x51000
-
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-
-	//IQK setting
-	ODM_SetBBReg(pDM_Odm, rRx_IQK, bMaskDWord, 0x01004800);
-
-	//path-A IQK setting
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x30008c1c);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x10008c1c);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_PI_A, bMaskDWord, 0x82160000);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_PI_A, bMaskDWord, 0x281613ff);    //0x281603e0
-
-
-	//LO calibration setting
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("LO calibration setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Rsp, bMaskDWord, 0x0046a911);
-
-	//One shot, path A LOK & IQK
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("One shot, path A LOK & IQK!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf9000000);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf8000000);
-
-	// delay x ms
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F));
-//PlatformStallExecution(IQK_DELAY_TIME_8188F*1000);
-	ODM_delay_ms(IQK_DELAY_TIME_8188F);
-
-	//reload RF 0xdf
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xdf, bRFRegOffsetMask, 0x180);
-
-	//reload LOK value
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x8, bRFRegOffsetMask, pDM_Odm->RFCalibrateInfo.LOK_Result);
-
-	// Check failed
-	regEAC = ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_A_2, bMaskDWord);
-	regEA4 = ODM_GetBBReg(pDM_Odm, rRx_Power_Before_IQK_A_2, bMaskDWord);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeac = 0x%x\n", regEAC));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xea4 = 0x%x, 0xeac = 0x%x\n", regEA4, regEAC));
-	//monitor image power before & after IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xea0(before IQK)= 0x%x, 0xea8(afer IQK) = 0x%x\n",
-				 ODM_GetBBReg(pDM_Odm, 0xea0, bMaskDWord), ODM_GetBBReg(pDM_Odm, 0xea8, bMaskDWord)));
-
-
-	if (!(regEAC & BIT27) &&     //if Tx is OK, check whether Rx is OK
-		(((regEA4 & 0x03FF0000) >> 16) != 0x132) &&
-		(((regEAC & 0x03FF0000) >> 16) != 0x36))
-		result |= 0x02;
-	else
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A Rx IQK fail!!\n"));
-
-	return result;
-
-
-}
-
-u1Byte              //bit0 = 1 => Tx OK, bit1 = 1 => Rx OK
-phy_PathB_IQK_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm
-#else
-	IN PADAPTER pAdapter
-#endif
-)
-{
-	u4Byte regEAC, regE94, regE9C/*, regEC4, regECC*/;
-	u1Byte result = 0x00;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B IQK!\n"));
-
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	//switch to path B
-	ODM_SetBBReg(pDM_Odm, 0x948, bMaskDWord, 0x00000080);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xb0, bRFRegOffsetMask, 0xefff0);
-	//  in TXIQK mode
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, bRFRegOffsetMask, 0x800a0 );
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_RCK_OS, bRFRegOffsetMask, 0x20000 );
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G1, bRFRegOffsetMask, 0x0003f );
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G2, bRFRegOffsetMask, 0xc7f87 );
-//  enable path B PA in TXIQK mode
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xed, bRFRegOffsetMask, 0x00020 );
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x43, bRFRegOffsetMask, 0x40fc1 );
-
-
-	//1 Tx IQK
-	//path-A IQK setting
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path-B IQK setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x18008c1c);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x38008c1c);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_PI_A, bMaskDWord, 0x82140102);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_PI_A, bMaskDWord, 0x28160000);
-
-	//LO calibration setting
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("LO calibration setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Rsp, bMaskDWord, 0x00462911);
-
-
-	//enter IQK mode
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-
-	//One shot, path B LOK & IQK
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("One shot, path B LOK & IQK!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf9000000);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Pts, bMaskDWord, 0xf8000000);
-
-	// delay x ms
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Delay %d ms for One shot, path B LOK & IQK.\n", IQK_DELAY_TIME_8188F));
-//PlatformStallExecution(IQK_DELAY_TIME_8188F*1000);
-	ODM_delay_ms(IQK_DELAY_TIME_8188F);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0x948 = 0x%x\n", ODM_GetBBReg(pDM_Odm, 0x948, bMaskDWord)));
-
-
-	// Check failed
-	regEAC = ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_A_2, bMaskDWord);
-	regE94 = ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord);
-	regE9C = ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeac = 0x%x\n", regEAC));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe94 = 0x%x, 0xe9c = 0x%x\n", regE94, regE9C));
-	//monitor image power before & after IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
-				 ODM_GetBBReg(pDM_Odm, 0xe90, bMaskDWord), ODM_GetBBReg(pDM_Odm, 0xe98, bMaskDWord)));
-
-
-	if (!(regEAC & BIT28) &&
-		(((regE94 & 0x03FF0000) >> 16) != 0x142) &&
-		(((regE9C & 0x03FF0000) >> 16) != 0x42))
-		result |= 0x01;
-	else
-		return result;
-#if 0
-	if (!(regEAC & BIT30) &&
-		(((regEC4 & 0x03FF0000) >> 16) != 0x132) &&
-		(((regECC & 0x03FF0000) >> 16) != 0x36))
-		result |= 0x02;
-	else
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B Rx IQK fail!!\n"));
-
-#endif
-	return result;
-}
-
-
-
-u1Byte          //bit0 = 1 => Tx OK, bit1 = 1 => Rx OK
-phy_PathB_RxIQK8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN configPathB
-)
-{
-	u4Byte regEAC, regEB4, regEBC, regECC, regEC4, u4tmp;
-	u1Byte result = 0x00;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B Rx IQK!\n"));
-
-	//1 Get TXIMR setting
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Get RXIQK TXIMR!\n"));
-	//modify RXIQK mode table
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path-A Rx IQK modify RXIQK mode table!\n"));
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, bRFRegOffsetMask, 0x800a0 );
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_RCK_OS, bRFRegOffsetMask, 0x30000 );
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G1, bRFRegOffsetMask, 0x0000f );
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G2, bRFRegOffsetMask, 0xf117B );
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-
-	//IQK setting
-	ODM_SetBBReg(pDM_Odm, rTx_IQK, bMaskDWord, 0x01007c00);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK, bMaskDWord, 0x81004800);
-
-	//path-B IQK setting
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_B, bMaskDWord, 0x10008c1c);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_B, bMaskDWord, 0x30008c1c);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_PI_B, bMaskDWord, 0x82130804);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_PI_B, bMaskDWord, 0x68130000);
-
-	//LO calibration setting
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("LO calibration setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Rsp, bMaskDWord, 0x0046a911);
-
-	//One shot, path B LOK & IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("One shot, path B LOK & IQK!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Cont, bMaskDWord, 0x00000002);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Cont, bMaskDWord, 0x00000000);
-
-	// delay x ms
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F));
-	//PlatformStallExecution(IQK_DELAY_TIME_8188F*1000);
-	ODM_delay_ms(IQK_DELAY_TIME_8188F);
-
-
-	// Check failed
-	regEAC = ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_A_2, bMaskDWord);
-	regEB4 = ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_B, bMaskDWord);
-	regEBC = ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_B, bMaskDWord);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeac = 0x%x\n", regEAC));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeb4 = 0x%x, 0xebc = 0x%x\n", regEB4, regEBC));
-	//monitor image power before & after IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeb0(before IQK)= 0x%x, 0xeb8(afer IQK) = 0x%x\n",
-				 ODM_GetBBReg(pDM_Odm, 0xeb0, bMaskDWord), ODM_GetBBReg(pDM_Odm, 0xeb8, bMaskDWord)));
-
-
-	if (!(regEAC & BIT31) &&
-		(((regEB4 & 0x03FF0000) >> 16) != 0x142) &&
-		(((regEBC & 0x03FF0000) >> 16) != 0x42))
-		result |= 0x01;
-	else                            //if Tx not OK, ignore Rx
-		return result;
-
-	u4tmp = 0x80007C00 | (regEB4 & 0x3FF0000) | ((regEBC & 0x3FF0000) >> 16);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK, bMaskDWord, u4tmp);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xe40 = 0x%x u4tmp = 0x%x\n", ODM_GetBBReg(pDM_Odm, rTx_IQK, bMaskDWord), u4tmp));
-
-
-	//1 RX IQK
-	//modify RXIQK mode table
-//	ODM_RT_TRACE(pDM_Odm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path-A Rx IQK modify RXIQK mode table 2!\n"));
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, bRFRegOffsetMask, 0x800a0 );
-
-	//<20121009, Kordan> RF Mode = 3
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);	               // 0xEF[19]   = 0x1
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_RCK_OS, bRFRegOffsetMask, 0x18000 );  // 0x30[19:0] = 0x18000
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G1, bRFRegOffsetMask, 0x0000f ); // 0x31[19:0] = 0x0000f
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXPA_G2, bRFRegOffsetMask, 0xf7ffa ); // 0x32[19:0] = 0xf7ffa
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);	               // 0xEF[19]   = 0x0
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-
-	//IQK setting
-	ODM_SetBBReg(pDM_Odm, rRx_IQK, bMaskDWord, 0x01004800);
-
-	//path-B IQK setting
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_B, bMaskDWord, 0x30008c1c);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_B, bMaskDWord, 0x10008c1c);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_PI_B, bMaskDWord, 0x82130c05);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_PI_B, bMaskDWord, 0x68130c05);
-
-	//LO calibration setting
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("LO calibration setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Rsp, bMaskDWord, 0x0046a911);
-
-	//One shot, path B LOK & IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("One shot, path B LOK & IQK!\n"));
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Cont, bMaskDWord, 0x00000002);
-	ODM_SetBBReg(pDM_Odm, rIQK_AGC_Cont, bMaskDWord, 0x00000000);
-
-	// delay x ms
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Delay %d ms for One shot, path A LOK & IQK.\n", IQK_DELAY_TIME_8188F));
-	//PlatformStallExecution(IQK_DELAY_TIME_8188F*1000);
-	ODM_delay_ms(IQK_DELAY_TIME_8188F);
-
-	// Check failed
-	regEAC = ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_A_2, bMaskDWord);
-	regEC4 = ODM_GetBBReg(pDM_Odm, rRx_Power_Before_IQK_B_2, bMaskDWord);;
-	regECC = ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_B_2, bMaskDWord);
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xeac = 0x%x\n", regEAC));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xec4 = 0x%x, 0xecc = 0x%x\n", regEC4, regECC));
-	//monitor image power before & after IQK
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xec0(before IQK)= 0x%x, 0xec8(afer IQK) = 0x%x\n",
-				 ODM_GetBBReg(pDM_Odm, 0xec0, bMaskDWord), ODM_GetBBReg(pDM_Odm, 0xec8, bMaskDWord)));
-
-	//	PA/PAD controlled by 0x0
-	//leave IQK mode
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-//	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0xdf, bRFRegOffsetMask, 0x180 );
-
-
-
-#if 0
-	if (!(regEAC & BIT31) &&
-		(((regEB4 & 0x03FF0000) >> 16) != 0x142) &&
-		(((regEBC & 0x03FF0000) >> 16) != 0x42))
-		result |= 0x01;
-	else                            //if Tx not OK, ignore Rx
-		return result;
-#endif
-
-	if (!(regEAC & BIT30) &&     //if Tx is OK, check whether Rx is OK
-		(((regEC4 & 0x03FF0000) >> 16) != 0x132) &&
-		(((regECC & 0x03FF0000) >> 16) != 0x36))
-		result |= 0x02;
-	else
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B Rx IQK fail!!\n"));
-
-	return result;
-
-
-}
-
-
-VOID
-_PHY_PathAFillIQKMatrix8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN bIQKOK,
-	IN s4Byte result[][8],
-	IN u1Byte final_candidate,
-	IN BOOLEAN bTxOnly
-)
-{
-	u4Byte Oldval_0, X, TX0_A, reg;
-	s4Byte Y, TX0_C;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	PODM_RF_CAL_T pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A IQ Calibration %s !\n", (bIQKOK) ? "Success" : "Failed"));
-
-	if (final_candidate == 0xFF)
-		return;
-
-	else if (bIQKOK) {
-		Oldval_0 = (ODM_GetBBReg(pDM_Odm, rOFDM0_XATxIQImbalance, bMaskDWord) >> 22) & 0x3FF;
-
-		X = result[final_candidate][0];
-		if ((X & 0x00000200) != 0)
-			X = X | 0xFFFFFC00;
-		TX0_A = (X * Oldval_0) >> 8;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("X = 0x%x, TX0_A = 0x%x, Oldval_0 0x%x\n", X, TX0_A, Oldval_0));
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XATxIQImbalance, 0x3FF, TX0_A);
-
-		ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, BIT(31), ((X * Oldval_0 >> 7) & 0x1));
-
-		Y = result[final_candidate][1];
-		if ((Y & 0x00000200) != 0)
-			Y = Y | 0xFFFFFC00;
-
-		//2 Tx IQC
-		TX0_C = (Y * Oldval_0) >> 8;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Y = 0x%x, TX = 0x%x\n", Y, TX0_C));
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XCTxAFE, 0xF0000000, ((TX0_C & 0x3C0) >> 6));
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S1][IDX_0xC94][KEY] = rOFDM0_XCTxAFE;
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S1][IDX_0xC94][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XCTxAFE, bMaskDWord);
-
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XATxIQImbalance, 0x003F0000, (TX0_C & 0x3F));
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S1][IDX_0xC80][KEY] = rOFDM0_XATxIQImbalance;
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S1][IDX_0xC80][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XATxIQImbalance, bMaskDWord);
-
-		ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, BIT(29), ((Y * Oldval_0 >> 7) & 0x1));
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S1][IDX_0xC4C][KEY] = rOFDM0_ECCAThreshold;
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S1][IDX_0xC4C][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, bMaskDWord);
-
-		if (bTxOnly) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("_PHY_PathAFillIQKMatrix8188F only Tx OK\n"));
-
-			// <20130226, Kordan> Saving RxIQC, otherwise not initialized.
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xCA0][KEY] = rOFDM0_RxIQExtAnta;
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xCA0][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_RxIQExtAnta, bMaskDWord);
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xC14][KEY] = rOFDM0_XARxIQImbalance;
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xC14][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XARxIQImbalance, bMaskDWord);
-			return;
-		}
-
-		reg = result[final_candidate][2];
-#if (DM_ODM_SUPPORT_TYPE==ODM_AP)
-		if (RTL_ABS(reg, 0x100) >= 16)
-			reg = 0x100;
-#endif
-
-		//2 Rx IQC
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XARxIQImbalance, 0x3FF, reg);
-		reg = result[final_candidate][3] & 0x3F;
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XARxIQImbalance, 0xFC00, reg);
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xC14][KEY] = rOFDM0_XARxIQImbalance;
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xC14][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XARxIQImbalance, bMaskDWord);
-
-		reg = (result[final_candidate][3] >> 6) & 0xF;
-		ODM_SetBBReg(pDM_Odm, rOFDM0_RxIQExtAnta, 0xF0000000, reg);
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xCA0][KEY] = rOFDM0_RxIQExtAnta;
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S1][IDX_0xCA0][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_RxIQExtAnta, bMaskDWord);
-
-	}
-}
-
-VOID
-_PHY_PathBFillIQKMatrix8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN bIQKOK,
-	IN s4Byte result[][8],
-	IN u1Byte final_candidate,
-	IN BOOLEAN bTxOnly         //do Tx only
-)
-{
-	u4Byte Oldval_1, X, TX1_A, reg;
-	s4Byte Y, TX1_C;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	PODM_RF_CAL_T pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B IQ Calibration %s !\n", (bIQKOK) ? "Success" : "Failed"));
-
-	if (final_candidate == 0xFF)
-		return;
-
-	else if (bIQKOK) {
-		Oldval_1 = (ODM_GetBBReg(pDM_Odm, rOFDM0_XBTxIQImbalance, bMaskDWord) >> 22) & 0x3FF;
-
-		X = result[final_candidate][4];
-		if ((X & 0x00000200) != 0)
-			X = X | 0xFFFFFC00;
-		TX1_A = (X * Oldval_1) >> 8;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("X = 0x%x, TX1_A = 0x%x\n", X, TX1_A));
-
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XBTxIQImbalance, 0x3FF, TX1_A);
-
-		ODM_SetBBReg(pDM_Odm, 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;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Y = 0x%x, TX1_C = 0x%x\n", Y, TX1_C));
-
-		//2 Tx IQC
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XDTxAFE, 0xF0000000, ((TX1_C & 0x3C0) >> 6));
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S0][IDX_0xC9C][KEY] = rOFDM0_XDTxAFE;
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S0][IDX_0xC9C][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XDTxAFE, bMaskDWord);
-
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XBTxIQImbalance, 0x003F0000, (TX1_C & 0x3F));
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S0][IDX_0xC88][KEY] = rOFDM0_XBTxIQImbalance;
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S0][IDX_0xC88][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XBTxIQImbalance, bMaskDWord);
-
-		ODM_SetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, BIT(25), ((Y * Oldval_1 >> 7) & 0x1));
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S0][IDX_0xC4C][KEY] = rOFDM0_ECCAThreshold;
-		pRFCalibrateInfo->TxIQC_8723B[PATH_S0][IDX_0xC4C][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_ECCAThreshold, bMaskDWord);
-
-		if (bTxOnly) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("_PHY_PathBFillIQKMatrix8188F only Tx OK\n"));
-
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC1C][KEY] = rOFDM0_XBRxIQImbalance;
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC1C][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XBRxIQImbalance, bMaskDWord);
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC78][KEY] = rOFDM0_AGCRSSITable;
-			pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC78][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_AGCRSSITable, bMaskDWord);
-			return;
-		}
-
-		//2 Rx IQC
-		reg = result[final_candidate][6];
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XBRxIQImbalance, 0x3FF, reg);
-		reg = result[final_candidate][7] & 0x3F;
-		ODM_SetBBReg(pDM_Odm, rOFDM0_XBRxIQImbalance, 0xFC00, reg);
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC1C][KEY] = rOFDM0_XBRxIQImbalance;
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC1C][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_XBRxIQImbalance, bMaskDWord);
-
-		reg = (result[final_candidate][7] >> 6) & 0xF;
-		ODM_SetBBReg(pDM_Odm, rOFDM0_AGCRSSITable, 0x0000F000, reg);
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC78][KEY] = rOFDM0_AGCRSSITable;
-		pRFCalibrateInfo->RxIQC_8723B[PATH_S0][IDX_0xC78][VAL] = ODM_GetBBReg(pDM_Odm, rOFDM0_AGCRSSITable, bMaskDWord);
-	}
-}
-
-//
-// 2011/07/26 MH Add an API for testing IQK fail case.
-//
-// MP Already declare in odm.c
-#if !(DM_ODM_SUPPORT_TYPE & ODM_WIN)
-BOOLEAN
-ODM_CheckPowerStatus(
-	IN PADAPTER Adapter)
-{
-	/*
-		HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-		PDM_ODM_T			pDM_Odm = &pHalData->DM_OutSrc;
-		RT_RF_POWER_STATE 	rtState;
-		PMGNT_INFO			pMgntInfo	= &(Adapter->MgntInfo);
-
-		// 2011/07/27 MH We are not testing ready~~!! We may fail to get correct value when init sequence.
-		if (pMgntInfo->init_adpt_in_progress == TRUE)
-		{
-			ODM_RT_TRACE(pDM_Odm,COMP_INIT, DBG_LOUD, ("ODM_CheckPowerStatus Return TRUE, due to initadapter"));
-			return	TRUE;
-		}
-
-		//
-		//	2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK.
-		//
-		Adapter->HalFunc.GetHwRegHandler(Adapter, HW_VAR_RF_STATE, (pu1Byte)(&rtState));
-		if(Adapter->bDriverStopped || Adapter->bDriverIsGoingToPnpSetPowerSleep || rtState == eRfOff)
-		{
-			ODM_RT_TRACE(pDM_Odm,COMP_INIT, DBG_LOUD, ("ODM_CheckPowerStatus Return FALSE, due to %d/%d/%d\n",
-			Adapter->bDriverStopped, Adapter->bDriverIsGoingToPnpSetPowerSleep, rtState));
-			return	FALSE;
-		}
-	*/
-	return TRUE;
-}
-#endif
-
-VOID
-_PHY_SaveADDARegisters8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN pu4Byte ADDAReg,
-	IN pu4Byte ADDABackup,
-	IN u4Byte RegisterNum
-)
-{
-	u4Byte i;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-
-	if (ODM_CheckPowerStatus(pAdapter) == FALSE)
-		return;
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Save ADDA parameters.\n"));
-	for (i = 0; i < RegisterNum; i++)
-		ADDABackup[i] = ODM_GetBBReg(pDM_Odm, ADDAReg[i], bMaskDWord);
-}
-
-
-VOID
-_PHY_SaveMACRegisters8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN pu4Byte MACReg,
-	IN pu4Byte MACBackup
-)
-{
-	u4Byte i;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Save MAC parameters.\n"));
-	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
-		MACBackup[i] = ODM_Read1Byte(pDM_Odm, MACReg[i]);
-	MACBackup[i] = ODM_Read4Byte(pDM_Odm, MACReg[i]);
-
-}
-
-
-VOID
-_PHY_ReloadADDARegisters8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN pu4Byte ADDAReg,
-	IN pu4Byte ADDABackup,
-	IN u4Byte RegiesterNum
-)
-{
-	u4Byte i;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Reload ADDA power saving parameters !\n"));
-	for (i = 0; i < RegiesterNum; i++)
-		ODM_SetBBReg(pDM_Odm, ADDAReg[i], bMaskDWord, ADDABackup[i]);
-}
-
-VOID
-_PHY_ReloadMACRegisters8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN pu4Byte MACReg,
-	IN pu4Byte MACBackup
-)
-{
-	u4Byte i;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Reload MAC parameters !\n"));
-	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
-		ODM_Write1Byte(pDM_Odm, MACReg[i], (u1Byte)MACBackup[i]);
-	ODM_Write4Byte(pDM_Odm, MACReg[i], MACBackup[i]);
-}
-
-
-VOID
-_PHY_PathADDAOn8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN pu4Byte ADDAReg,
-	IN BOOLEAN isPathAOn,
-	IN BOOLEAN is2T
-)
-{
-	u4Byte pathOn;
-	u4Byte i;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("ADDA ON.\n"));
-
-	pathOn = isPathAOn ? 0x03c00014 : 0x03c00014;
-	if (FALSE == is2T) {
-		pathOn = 0x03c00014;
-		ODM_SetBBReg(pDM_Odm, ADDAReg[0], bMaskDWord, 0x03c00014);
-	} else
-		ODM_SetBBReg(pDM_Odm, ADDAReg[0], bMaskDWord, pathOn);
-
-	for (i = 1; i < IQK_ADDA_REG_NUM; i++)
-		ODM_SetBBReg(pDM_Odm, ADDAReg[i], bMaskDWord, pathOn);
-
-}
-
-VOID
-_PHY_MACSettingCalibration8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN pu4Byte MACReg,
-	IN pu4Byte MACBackup
-)
-{
-	u4Byte i = 0;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("MAC settings for Calibration.\n"));
-
-#if 0
-	ODM_Write1Byte(pDM_Odm, MACReg[i], 0x3F);
-
-	for (i = 1; i < (IQK_MAC_REG_NUM - 1); i++)
-		ODM_Write1Byte(pDM_Odm, MACReg[i], (u1Byte)(MACBackup[i] & (~BIT3)));
-	ODM_Write1Byte(pDM_Odm, MACReg[i], (u1Byte)(MACBackup[i] & (~BIT5)));
-#else
-
-	ODM_SetBBReg(pDM_Odm, 0x520, 0x00ff0000, 0xff);
-#endif
-}
-
-VOID
-_PHY_PathAStandBy8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm
-#else
-	IN PADAPTER pAdapter
-#endif
-)
-{
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path-A standby mode!\n"));
-
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-//Allen
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_AC, bMaskDWord, 0x10000);
-	//ODM_SetBBReg(pDM_Odm, 0x840, bMaskDWord, 0x00010000);
-//
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-}
-
-VOID
-_PHY_PIModeSwitch8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN PIMode
-)
-{
-	u4Byte mode;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("BB Switch to %s mode!\n", (PIMode ? "PI" : "SI")));
-
-	mode = PIMode ? 0x01000100 : 0x01000000;
-	ODM_SetBBReg(pDM_Odm, rFPGA0_XA_HSSIParameter1, bMaskDWord, mode);
-	ODM_SetBBReg(pDM_Odm, rFPGA0_XB_HSSIParameter1, bMaskDWord, mode);
-}
-
-BOOLEAN
-phy_SimularityCompare_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN s4Byte result[][8],
-	IN u1Byte c1,
-	IN u1Byte c2
-)
-{
-	u4Byte i, j, diff, SimularityBitMap, bound = 0;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if DBG
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-#endif
-	u1Byte final_candidate[2] = { 0xFF, 0xFF };  //for path A and path B
-	BOOLEAN bResult = TRUE;
-//#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-//	BOOLEAN		is2T = IS_92C_SERIAL( pHalData->VersionID);
-//#else
-	BOOLEAN is2T = TRUE;
-//#endif
-
-	s4Byte tmp1 = 0, tmp2 = 0;
-
-	if (is2T)
-		bound = 8;
-	else
-		bound = 4;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("===> IQK:phy_SimularityCompare_8192E c1 %d c2 %d!!!\n", c1, c2));
-
-
-	SimularityBitMap = 0;
-
-	for (i = 0; i < bound; i++) {
-
-		if ((i == 1) || (i == 3) || (i == 5) || (i == 7)) {
-			if ((result[c1][i] & 0x00000200) != 0)
-				tmp1 = result[c1][i] | 0xFFFFFC00;
-			else
-				tmp1 = result[c1][i];
-
-			if ((result[c2][i] & 0x00000200) != 0)
-				tmp2 = result[c2][i] | 0xFFFFFC00;
-			else
-				tmp2 = result[c2][i];
-		} else {
-			tmp1 = result[c1][i];
-			tmp2 = result[c2][i];
-		}
-
-		diff = (tmp1 > tmp2) ? (tmp1 - tmp2) : (tmp2 - tmp1);
-
-		if (diff > MAX_TOLERANCE) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:differnece overflow %d index %d compare1 0x%x compare2 0x%x!!!\n", diff, i, result[c1][i], result[c2][i]));
-
-			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);
-		}
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:phy_SimularityCompare_8192E SimularityBitMap   %x !!!\n", SimularityBitMap));
-
-	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 & 0x03)) {       //path A TX OK
-			for (i = 0; i < 2; i++) result[3][i] = result[c1][i];
-		}
-
-		if (!(SimularityBitMap & 0x0c)) {       //path A RX OK
-			for (i = 2; i < 4; i++) result[3][i] = result[c1][i];
-		}
-
-		if (!(SimularityBitMap & 0x30)) { //path B TX OK
-			for (i = 4; i < 6; i++) result[3][i] = result[c1][i];
-
-		}
-
-		if (!(SimularityBitMap & 0xc0)) { //path B RX OK
-			for (i = 6; i < 8; i++) result[3][i] = result[c1][i];
-		}
-		return FALSE;
-	}
-}
-
-
-
-VOID
-phy_IQCalibrate_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN s4Byte result[][8],
-	IN u1Byte t,
-	IN BOOLEAN is2T
-)
-{
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-	u4Byte i;
-	u1Byte PathAOK, PathBOK;
-	u1Byte tmp0xc50 = (u1Byte)ODM_GetBBReg(pDM_Odm, 0xC50, bMaskByte0);
-	u1Byte tmp0xc58 = (u1Byte)ODM_GetBBReg(pDM_Odm, 0xC58, bMaskByte0);
-	u4Byte 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
-	};
-	u4Byte IQK_MAC_REG[IQK_MAC_REG_NUM] = {
-		REG_TXPAUSE, REG_BCN_CTRL,
-		REG_BCN_CTRL_1, REG_GPIO_MUXCFG
-	};
-
-	//since 92C & 92D have the different define in IQK_BB_REG
-	u4Byte 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
-	};
-
-	u4Byte Path_SEL_BB, Path_SEL_RF;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	u4Byte retryCount = 2;
-#else
-#if MP_DRIVER
-	const u4Byte retryCount = 9;
-#else
-	const u4Byte retryCount = 2;
-#endif
-#endif
-
-	// Note: IQ calibration must be performed after loading
-	// 		PHY_REG.txt , and radio_a, radio_b.txt
-
-	//u4Byte bbvalue;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#ifdef MP_TEST
-	if (pDM_Odm->priv->pshare->rf_ft_var.mp_specific)
-		retryCount = 9;
-#endif
-#endif
-
-
-	if (t == 0) {
-//	 	 bbvalue = ODM_GetBBReg(pDM_Odm, rFPGA0_RFMOD, bMaskDWord);
-//			RT_DISP(FINIT, INIT_IQK, ("phy_IQCalibrate_8188F()==>0x%08x\n",bbvalue));
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQ Calibration for %s for %d times\n", (is2T ? "2T2R" : "1T1R"), t));
-
-		// Save ADDA parameters, turn Path A ADDA on
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		_PHY_SaveADDARegisters8188F(pAdapter, ADDA_REG, pDM_Odm->RFCalibrateInfo.ADDA_backup, IQK_ADDA_REG_NUM);
-		_PHY_SaveMACRegisters8188F(pAdapter, IQK_MAC_REG, pDM_Odm->RFCalibrateInfo.IQK_MAC_backup);
-		_PHY_SaveADDARegisters8188F(pAdapter, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup, IQK_BB_REG_NUM);
-#else
-		_PHY_SaveADDARegisters8188F(pDM_Odm, ADDA_REG, pDM_Odm->RFCalibrateInfo.ADDA_backup, IQK_ADDA_REG_NUM);
-		_PHY_SaveMACRegisters8188F(pDM_Odm, IQK_MAC_REG, pDM_Odm->RFCalibrateInfo.IQK_MAC_backup);
-		_PHY_SaveADDARegisters8188F(pDM_Odm, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup, IQK_BB_REG_NUM);
-#endif
-	}
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQ Calibration for %s for %d times\n", (is2T ? "2T2R" : "1T1R"), t));
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-	_PHY_PathADDAOn8188F(pAdapter, ADDA_REG, TRUE, is2T);
-#else
-	_PHY_PathADDAOn8188F(pDM_Odm, ADDA_REG, TRUE, is2T);
-#endif
-
-
-	if (t == 0)
-		pDM_Odm->RFCalibrateInfo.bRfPiEnable = (u1Byte)ODM_GetBBReg(pDM_Odm, rFPGA0_XA_HSSIParameter1, BIT(8));
-
-#if 0
-	if (!pDM_Odm->RFCalibrateInfo.bRfPiEnable) {
-		// Switch BB to PI mode to do IQ Calibration.
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		_PHY_PIModeSwitch8188F(pAdapter, TRUE);
-#else
-		_PHY_PIModeSwitch8188F(pDM_Odm, TRUE);
-#endif
-	}
-#endif
-
-	//save RF path
-	Path_SEL_BB = ODM_GetBBReg(pDM_Odm, 0x948, bMaskDWord);
-	Path_SEL_RF = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xb0, 0xfffff);
-
-
-	//BB setting
-	/*ODM_SetBBReg(pDM_Odm, rFPGA0_RFMOD, BIT24, 0x00);*/
-	ODM_SetBBReg(pDM_Odm, rOFDM0_TRxPathEnable, bMaskDWord, 0x03a05600);
-	ODM_SetBBReg(pDM_Odm, rOFDM0_TRMuxPar, bMaskDWord, 0x000800e4);
-	ODM_SetBBReg(pDM_Odm, rFPGA0_XCD_RFInterfaceSW, bMaskDWord, 0x25204000);
-
-	//external switch control
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_XAB_RFInterfaceSW, BIT10, 0x01);
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_XAB_RFInterfaceSW, BIT26, 0x01);
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_XA_RFInterfaceOE, BIT10, 0x00);
-//	ODM_SetBBReg(pDM_Odm, rFPGA0_XB_RFInterfaceOE, BIT10, 0x00);
-
-
-	if (is2T) {
-		//Allen
-		//	ODM_SetBBReg(pDM_Odm, rFPGA0_XA_LSSIParameter, bMaskDWord, 0x00010000);
-		//	ODM_SetBBReg(pDM_Odm, rFPGA0_XB_LSSIParameter, bMaskDWord, 0x00010000);
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bMaskDWord, 0x10000);
-	}
-
-	//MAC settings
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_MACSettingCalibration8188F(pAdapter, IQK_MAC_REG, pDM_Odm->RFCalibrateInfo.IQK_MAC_backup);
-#else
-	_PHY_MACSettingCalibration8188F(pDM_Odm, IQK_MAC_REG, pDM_Odm->RFCalibrateInfo.IQK_MAC_backup);
-#endif
-
-
-	//Page B init
-	//AP or IQK
-//	ODM_SetBBReg(pDM_Odm, rConfig_AntA, bMaskDWord, 0x0f600000);
-
-	if (is2T) {
-//		ODM_SetBBReg(pDM_Odm, rConfig_AntB, bMaskDWord, 0x0f600000);
-	}
-
-	// IQ calibration setting
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK setting!\n"));
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x808000);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK, bMaskDWord, 0x01007c00);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK, bMaskDWord, 0x01004800);
-
-	for (i = 0; i < retryCount; i++) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		PathAOK = phy_PathA_IQK_8188F(pAdapter, is2T);
-#else
-		PathAOK = phy_PathA_IQK_8188F(pDM_Odm, is2T);
-#endif
-//		if(PathAOK == 0x03){
-		if (PathAOK == 0x01) { //Path A Tx IQK Success
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-			pDM_Odm->RFCalibrateInfo.TxLOK[ODM_RF_PATH_A] = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x8, bRFRegOffsetMask);
-
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A Tx IQK Success!!\n"));
-			result[t][0] = (ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord) & 0x3FF0000) >> 16;
-			result[t][1] = (ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord) & 0x3FF0000) >> 16;
-			break;
-		}
-#if 0
-		else if (i == (retryCount - 1) && PathAOK == 0x01) { //Tx IQK OK
-			RT_DISP(FINIT, INIT_IQK, ("Path A IQK Only  Tx Success!!\n"));
-
-			result[t][0] = (ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord) & 0x3FF0000) >> 16;
-			result[t][1] = (ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord) & 0x3FF0000) >> 16;
-		}
-#endif
-	}
-
-//bypass RXQIK
-#if 1
-
-	for (i = 0; i < retryCount; i++) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		PathAOK = phy_PathA_RxIQK8188F(pAdapter, is2T);
-#else
-		PathAOK = phy_PathA_RxIQK8188F(pDM_Odm, is2T);
-#endif
-		if (PathAOK == 0x03) {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A Rx IQK Success!!\n"));
-//				result[t][0] = (ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord)&0x3FF0000)>>16;
-//				result[t][1] = (ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord)&0x3FF0000)>>16;
-			result[t][2] = (ODM_GetBBReg(pDM_Odm, rRx_Power_Before_IQK_A_2, bMaskDWord) & 0x3FF0000) >> 16;
-			result[t][3] = (ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_A_2, bMaskDWord) & 0x3FF0000) >> 16;
-			break;
-		} else
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A Rx IQK Fail!!\n"));
-	}
-#endif
-
-
-	if (0x00 == PathAOK)
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path A IQK failed!!\n"));
-
-	if (is2T) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		_PHY_PathAStandBy8188F(pAdapter);
-
-		// Turn Path B ADDA on
-		_PHY_PathADDAOn8188F(pAdapter, ADDA_REG, FALSE, is2T);
-#else
-		_PHY_PathAStandBy8188F(pDM_Odm);
-
-		// Turn Path B ADDA on
-		_PHY_PathADDAOn8188F(pDM_Odm, ADDA_REG, FALSE, is2T);
-#endif
-//Allen
-		for (i = 0; i < retryCount; i++) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			PathBOK = phy_PathB_IQK_8188F(pAdapter);
-#else
-			PathBOK = phy_PathB_IQK_8188F(pDM_Odm);
-#endif
-//		if(PathBOK == 0x03){
-			if (PathBOK == 0x01) { //Path B Tx IQK Success
-				ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-				pDM_Odm->RFCalibrateInfo.TxLOK[ODM_RF_PATH_B] = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x8, bRFRegOffsetMask);
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B Tx IQK Success!!\n"));
-				result[t][4] = (ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord) & 0x3FF0000) >> 16;
-				result[t][5] = (ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord) & 0x3FF0000) >> 16;
-				break;
-			}
-#if 0
-			else if (i == (retryCount - 1) && PathAOK == 0x01) { //Tx IQK OK
-				RT_DISP(FINIT, INIT_IQK, ("Path B IQK Only  Tx Success!!\n"));
-
-				result[t][0] = (ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_B, bMaskDWord) & 0x3FF0000) >> 16;
-				result[t][1] = (ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_B, bMaskDWord) & 0x3FF0000) >> 16;
-			}
-#endif
-		}
-
-//bypass RXQIK
-#if 0
-
-		for (i = 0; i < retryCount; i++) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			PathBOK = phy_PathB_RxIQK8188F(pAdapter, is2T);
-#else
-			PathBOK = phy_PathB_RxIQK8188F(pDM_Odm, is2T);
-#endif
-			if (PathBOK == 0x03) {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B Rx IQK Success!!\n"));
-//				result[t][0] = (ODM_GetBBReg(pDM_Odm, rTx_Power_Before_IQK_A, bMaskDWord)&0x3FF0000)>>16;
-//				result[t][1] = (ODM_GetBBReg(pDM_Odm, rTx_Power_After_IQK_A, bMaskDWord)&0x3FF0000)>>16;
-				result[t][6] = (ODM_GetBBReg(pDM_Odm, rRx_Power_Before_IQK_B_2, bMaskDWord) & 0x3FF0000) >> 16;
-				result[t][7] = (ODM_GetBBReg(pDM_Odm, rRx_Power_After_IQK_B_2, bMaskDWord) & 0x3FF0000) >> 16;
-				break;
-			} else
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B Rx IQK Fail!!\n"));
-		}
-
-#endif
-
-////////Allen end /////////
-		if (0x00 == PathBOK)
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Path B IQK failed!!\n"));
-	}
-
-	//Back to BB mode, load original value
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:Back to BB mode, load original value!\n"));
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0);
-
-	if (t != 0) {
-		if (!pDM_Odm->RFCalibrateInfo.bRfPiEnable) {
-			// Switch back BB to SI mode after finish IQ Calibration.
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			_PHY_PIModeSwitch8188F(pAdapter, FALSE);
-#else
-			_PHY_PIModeSwitch8188F(pDM_Odm, FALSE);
-#endif
-		}
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-		// Reload ADDA power saving parameters
-		_PHY_ReloadADDARegisters8188F(pAdapter, ADDA_REG, pDM_Odm->RFCalibrateInfo.ADDA_backup, IQK_ADDA_REG_NUM);
-
-		// Reload MAC parameters
-		_PHY_ReloadMACRegisters8188F(pAdapter, IQK_MAC_REG, pDM_Odm->RFCalibrateInfo.IQK_MAC_backup);
-
-		_PHY_ReloadADDARegisters8188F(pAdapter, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup, IQK_BB_REG_NUM);
-#else
-		// Reload ADDA power saving parameters
-		_PHY_ReloadADDARegisters8188F(pDM_Odm, ADDA_REG, pDM_Odm->RFCalibrateInfo.ADDA_backup, IQK_ADDA_REG_NUM);
-
-		// Reload MAC parameters
-		_PHY_ReloadMACRegisters8188F(pDM_Odm, IQK_MAC_REG, pDM_Odm->RFCalibrateInfo.IQK_MAC_backup);
-
-		_PHY_ReloadADDARegisters8188F(pDM_Odm, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup, IQK_BB_REG_NUM);
-#endif
-
-
-		//Reload RF path
-		ODM_SetBBReg(pDM_Odm, 0x948, bMaskDWord, Path_SEL_BB);
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xb0, 0xfffff, Path_SEL_RF);
-
-		//Allen initial gain 0xc50
-		// Restore RX initial gain
-		ODM_SetBBReg(pDM_Odm, 0xc50, bMaskByte0, 0x50);
-		ODM_SetBBReg(pDM_Odm, 0xc50, bMaskByte0, tmp0xc50);
-		if (is2T) {
-			ODM_SetBBReg(pDM_Odm, 0xc58, bMaskByte0, 0x50);
-			ODM_SetBBReg(pDM_Odm, 0xc58, bMaskByte0, tmp0xc58);
-		}
-
-		//load 0xe30 IQC default value
-		ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x01008c00);
-		ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x01008c00);
-
-	}
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_IQCalibrate_8188F() <==\n"));
-
-}
-
-
-VOID
-phy_LCCalibrate_8188F(
-	IN PDM_ODM_T pDM_Odm,
-	IN BOOLEAN is2T
-)
-{
-	u1Byte tmpReg;
-	u4Byte RF_Amode = 0, RF_Bmode = 0, LC_Cal, cnt;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	PADAPTER pAdapter = pDM_Odm->Adapter;
-#endif
-
-	/*Check continuous TX and Packet TX*/
-	tmpReg = ODM_Read1Byte(pDM_Odm, 0xd03);
-
-	if ((tmpReg & 0x70) != 0)			/*Deal with contisuous TX case*/
-		ODM_Write1Byte(pDM_Odm, 0xd03, tmpReg & 0x8F);	/*disable all continuous TX*/
-	else							/* Deal with Packet TX case*/
-		ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0xFF);			/* block all queues*/
-
-
-	/*backup RF0x18*/
-	LC_Cal = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
-
-	/*Start LCK*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask, LC_Cal|0x08000);
-
-	for (cnt = 0; cnt < 100; cnt++) {
-		if (ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, 0x8000) != 0x1)
-		break;	
-		ODM_delay_ms(10);
-	}
-
-	/*Recover channel number*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask, LC_Cal);	
-
-
-	/*Restore original situation*/
-	if ((tmpReg&0x70) != 0) {
-		/*Deal with contisuous TX case*/
-		ODM_Write1Byte(pDM_Odm, 0xd03, tmpReg);
-	} else { 
-		/* Deal with Packet TX case*/
-		ODM_Write1Byte(pDM_Odm, REG_TXPAUSE, 0x00);
-	}
-
-}
-
-//Analog Pre-distortion calibration
-#define		APK_BB_REG_NUM	8
-#define		APK_CURVE_REG_NUM 4
-#define		PATH_NUM		2
-
-VOID
-phy_APCalibrate_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PADAPTER pAdapter,
-#else
-	IN PDM_ODM_T pDM_Odm,
-	IN PADAPTER pAdapter,
-#endif
-	IN s1Byte delta,
-	IN BOOLEAN is2T
-)
-{
-#if 0
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP) && (DBG != 0)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-
-#if MP_DRIVER == 1
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	u4Byte regD[PATH_NUM];
-#endif
-	u4Byte tmpReg, index, offset, apkbound;
-	u1Byte path, i;
-	u1Byte pathbound = PATH_NUM;
-	u4Byte BB_backup[APK_BB_REG_NUM];
-	u4Byte BB_REG[APK_BB_REG_NUM] = {
-		rFPGA1_TxBlock, rOFDM0_TRxPathEnable,
-		rFPGA0_RFMOD, rOFDM0_TRMuxPar,
-		rFPGA0_XCD_RFInterfaceSW, rFPGA0_XAB_RFInterfaceSW,
-		rFPGA0_XA_RFInterfaceOE, rFPGA0_XB_RFInterfaceOE
-	};
-	u4Byte BB_AP_MODE[APK_BB_REG_NUM] = {
-		0x00000020, 0x00a05430, 0x02040000,
-		0x000800e4, 0x00204000
-	};
-	u4Byte BB_normal_AP_MODE[APK_BB_REG_NUM] = {
-		0x00000020, 0x00a05430, 0x02040000,
-		0x000800e4, 0x22204000
-	};
-
-	u4Byte AFE_backup[IQK_ADDA_REG_NUM];
-	u4Byte AFE_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
-	};
-
-	u4Byte MAC_backup[IQK_MAC_REG_NUM];
-	u4Byte MAC_REG[IQK_MAC_REG_NUM] = {
-		REG_TXPAUSE, REG_BCN_CTRL,
-		REG_BCN_CTRL_1, REG_GPIO_MUXCFG
-	};
-
-	u4Byte APK_RF_init_value[PATH_NUM][APK_BB_REG_NUM] = {
-		{0x0852c, 0x1852c, 0x5852c, 0x1852c, 0x5852c},
-		{0x2852e, 0x0852e, 0x3852e, 0x0852e, 0x0852e}
-	};
-
-	u4Byte APK_normal_RF_init_value[PATH_NUM][APK_BB_REG_NUM] = {
-		{0x0852c, 0x0a52c, 0x3a52c, 0x5a52c, 0x5a52c},  //path settings equal to path b settings
-		{0x0852c, 0x0a52c, 0x5a52c, 0x5a52c, 0x5a52c}
-	};
-
-	u4Byte APK_RF_value_0[PATH_NUM][APK_BB_REG_NUM] = {
-		{0x52019, 0x52014, 0x52013, 0x5200f, 0x5208d},
-		{0x5201a, 0x52019, 0x52016, 0x52033, 0x52050}
-	};
-
-	u4Byte APK_normal_RF_value_0[PATH_NUM][APK_BB_REG_NUM] = {
-		{0x52019, 0x52017, 0x52010, 0x5200d, 0x5206a},  //path settings equal to path b settings
-		{0x52019, 0x52017, 0x52010, 0x5200d, 0x5206a}
-	};
-
-	u4Byte AFE_on_off[PATH_NUM] = {
-		0x04db25a4, 0x0b1b25a4
-	};    //path A on path B off / path A off path B on
-
-	u4Byte APK_offset[PATH_NUM] = {
-		rConfig_AntA, rConfig_AntB
-	};
-
-	u4Byte APK_normal_offset[PATH_NUM] = {
-		rConfig_Pmpd_AntA, rConfig_Pmpd_AntB
-	};
-
-	u4Byte APK_value[PATH_NUM] = {
-		0x92fc0000, 0x12fc0000
-	};
-
-	u4Byte APK_normal_value[PATH_NUM] = {
-		0x92680000, 0x12680000
-	};
-
-	s1Byte APK_delta_mapping[APK_BB_REG_NUM][13] = {
-		{ -4, -3, -2, -2, -1, -1, 0, 1, 2, 3, 4, 5, 6},
-		{ -4, -3, -2, -2, -1, -1, 0, 1, 2, 3, 4, 5, 6},
-		{ -6, -4, -2, -2, -1, -1, 0, 1, 2, 3, 4, 5, 6},
-		{ -1, -1, -1, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6},
-		{ -11, -9, -7, -5, -3, -1, 0, 0, 0, 0, 0, 0, 0}
-	};
-
-	u4Byte APK_normal_setting_value_1[13] = {
-		0x01017018, 0xf7ed8f84, 0x1b1a1816, 0x2522201e, 0x322e2b28,
-		0x433f3a36, 0x5b544e49, 0x7b726a62, 0xa69a8f84, 0xdfcfc0b3,
-		0x12680000, 0x00880000, 0x00880000
-	};
-
-	u4Byte APK_normal_setting_value_2[16] = {
-		0x01c7021d, 0x01670183, 0x01000123, 0x00bf00e2, 0x008d00a3,
-		0x0068007b, 0x004d0059, 0x003a0042, 0x002b0031, 0x001f0025,
-		0x0017001b, 0x00110014, 0x000c000f, 0x0009000b, 0x00070008,
-		0x00050006
-	};
-
-	u4Byte APK_result[PATH_NUM][APK_BB_REG_NUM];   //val_1_1a, val_1_2a, val_2a, val_3a, val_4a
-//	u4Byte			AP_curve[PATH_NUM][APK_CURVE_REG_NUM];
-
-	s4Byte BB_offset, delta_V, delta_offset;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx);
-#else
-	PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx);
-#endif
-	pMptCtx->APK_bound[0] = 45;
-	pMptCtx->APK_bound[1] = 52;
-
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("==>phy_APCalibrate_8188F() delta %d\n", delta));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("AP Calibration for %s\n", (is2T ? "2T2R" : "1T1R")));
-#if MP_DRIVER == 1
-	if (!is2T)
-		pathbound = 1;
-#endif
-	//2 FOR NORMAL CHIP SETTINGS
-
-// Temporarily do not allow normal driver to do the following settings because these offset
-// and value will cause RF internal PA to be unpredictably disabled by HW, such that RF Tx signal
-// will disappear after disable/enable card many times on 88CU. RF SD and DD have not find the
-// root cause, so we remove these actions temporarily. Added by tynli and SD3 Allen. 2010.05.31.
-#if MP_DRIVER != 1
-	return;
-//#endif
-#else
-	//settings adjust for normal chip
-	for (index = 0; index < PATH_NUM; index ++) {
-		APK_offset[index] = APK_normal_offset[index];
-		APK_value[index] = APK_normal_value[index];
-		AFE_on_off[index] = 0x6fdb25a4;
-	}
-
-	for (index = 0; index < APK_BB_REG_NUM; index ++) {
-		for (path = 0; path < pathbound; path++) {
-			APK_RF_init_value[path][index] = APK_normal_RF_init_value[path][index];
-			APK_RF_value_0[path][index] = APK_normal_RF_value_0[path][index];
-		}
-		BB_AP_MODE[index] = BB_normal_AP_MODE[index];
-	}
-
-	apkbound = 6;
-
-	//save BB default value
-	for (index = 0; index < APK_BB_REG_NUM; index++) {
-		if (index == 0)     //skip
-			continue;
-		BB_backup[index] = ODM_GetBBReg(pDM_Odm, BB_REG[index], bMaskDWord);
-	}
-
-	//save MAC default value
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_SaveMACRegisters8188F(pAdapter, MAC_REG, MAC_backup);
-
-	//save AFE default value
-	_PHY_SaveADDARegisters8188F(pAdapter, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-#else
-	_PHY_SaveMACRegisters8188F(pDM_Odm, MAC_REG, MAC_backup);
-
-	//save AFE default value
-	_PHY_SaveADDARegisters8188F(pDM_Odm, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-#endif
-
-	for (path = 0; path < pathbound; path++) {
-
-
-		if (path == ODM_RF_PATH_A) {
-			//path A APK
-			//load APK setting
-			//path-A
-			offset = rPdp_AntA;
-			for (index = 0; index < 11; index ++) {
-				ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", offset, ODM_GetBBReg(pDM_Odm, offset, bMaskDWord)));
-
-				offset += 0x04;
-			}
-
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x12680000);
-
-			offset = rConfig_AntA;
-			for (; index < 13; index ++) {
-				ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", offset, ODM_GetBBReg(pDM_Odm, offset, bMaskDWord)));
-
-				offset += 0x04;
-			}
-
-			//page-B1
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x400000);
-
-			//path A
-			offset = rPdp_AntA;
-			for (index = 0; index < 16; index++) {
-				ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, APK_normal_setting_value_2[index]);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", offset, ODM_GetBBReg(pDM_Odm, offset, bMaskDWord)));
-
-				offset += 0x04;
-			}
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-		} else if (path == ODM_RF_PATH_B) {
-			//path B APK
-			//load APK setting
-			//path-B
-			offset = rPdp_AntB;
-			for (index = 0; index < 10; index ++) {
-				ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", offset, ODM_GetBBReg(pDM_Odm, offset, bMaskDWord)));
-
-				offset += 0x04;
-			}
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x12680000);
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			PHY_SetBBReg(pAdapter, rConfig_Pmpd_AntB, bMaskDWord, 0x12680000);
-#else
-			PHY_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x12680000);
-#endif
-
-			offset = rConfig_AntA;
-			index = 11;
-			for (; index < 13; index ++) { //offset 0xb68, 0xb6c
-				ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, APK_normal_setting_value_1[index]);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", offset, ODM_GetBBReg(pDM_Odm, offset, bMaskDWord)));
-
-				offset += 0x04;
-			}
-
-			//page-B1
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x400000);
-
-			//path B
-			offset = 0xb60;
-			for (index = 0; index < 16; index++) {
-				ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, APK_normal_setting_value_2[index]);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", offset, ODM_GetBBReg(pDM_Odm, offset, bMaskDWord)));
-
-				offset += 0x04;
-			}
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0);
-		}
-
-		//save RF default value
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		regD[path] = PHY_QueryRFReg(pAdapter, path, RF_TXBIAS_A, bMaskDWord);
-#else
-		regD[path] = ODM_GetRFReg(pDM_Odm, path, RF_TXBIAS_A, bMaskDWord);
-#endif
-
-		//Path A AFE all on, path B AFE All off or vise versa
-		for (index = 0; index < IQK_ADDA_REG_NUM; index++)
-			ODM_SetBBReg(pDM_Odm, AFE_REG[index], bMaskDWord, AFE_on_off[path]);
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0xe70 %x\n", ODM_GetBBReg(pDM_Odm, rRx_Wait_CCA, bMaskDWord)));
-
-		//BB to AP mode
-		if (path == 0) {
-			for (index = 0; index < APK_BB_REG_NUM; index++) {
-
-				if (index == 0)     //skip
-					continue;
-				else if (index < 5)
-					ODM_SetBBReg(pDM_Odm, BB_REG[index], bMaskDWord, BB_AP_MODE[index]);
-				else if (BB_REG[index] == 0x870)
-					ODM_SetBBReg(pDM_Odm, BB_REG[index], bMaskDWord, BB_backup[index] | BIT10 | BIT26);
-				else
-					ODM_SetBBReg(pDM_Odm, BB_REG[index], BIT10, 0x0);
-			}
-
-			ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x01008c00);
-			ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x01008c00);
-		} else {      //path B
-			ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_B, bMaskDWord, 0x01008c00);
-			ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_B, bMaskDWord, 0x01008c00);
-
-		}
-
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x800 %x\n", ODM_GetBBReg(pDM_Odm, 0x800, bMaskDWord)));
-
-		//MAC settings
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		_PHY_MACSettingCalibration8188F(pAdapter, MAC_REG, MAC_backup);
-#else
-		_PHY_MACSettingCalibration8188F(pDM_Odm, MAC_REG, MAC_backup);
-#endif
-
-		if (path == ODM_RF_PATH_A)  //Path B to standby mode
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bMaskDWord, 0x10000);
-		else {          //Path A to standby mode
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_AC, bMaskDWord, 0x10000);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_MODE1, bMaskDWord, 0x1000f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_MODE2, bMaskDWord, 0x20103);
-		}
-
-		delta_offset = ((delta + 14) / 2);
-		if (delta_offset < 0)
-			delta_offset = 0;
-		else if (delta_offset > 12)
-			delta_offset = 12;
-
-		//AP calibration
-		for (index = 0; index < APK_BB_REG_NUM; index++) {
-			if (index != 1) //only DO PA11+PAD01001, AP RF setting
-				continue;
-
-			tmpReg = APK_RF_init_value[path][index];
-#if 1
-			if (!pDM_Odm->RFCalibrateInfo.bAPKThermalMeterIgnore) {
-				BB_offset = (tmpReg & 0xF0000) >> 16;
-
-				if (!(tmpReg & BIT15))  //sign bit 0
-					BB_offset = -BB_offset;
-
-				delta_V = APK_delta_mapping[index][delta_offset];
-
-				BB_offset += delta_V;
-
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() APK index %d tmpReg 0x%x delta_V %d delta_offset %d\n", index, tmpReg, delta_V, delta_offset));
-
-				if (BB_offset < 0) {
-					tmpReg = tmpReg & (~BIT15);
-					BB_offset = -BB_offset;
-				} else
-					tmpReg = tmpReg | BIT15;
-				tmpReg = (tmpReg & 0xFFF0FFFF) | (BB_offset << 16);
-			}
-#endif
-
-			ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, RF_IPA_A, bMaskDWord, 0x8992e);
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0xc %x\n", PHY_QueryRFReg(pAdapter, path, RF_IPA_A, bMaskDWord)));
-			ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, RF_AC, bMaskDWord, APK_RF_value_0[path][index]);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x0 %x\n", PHY_QueryRFReg(pAdapter, path, RF_AC, bMaskDWord)));
-			ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, RF_TXBIAS_A, bMaskDWord, tmpReg);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0xd %x\n", PHY_QueryRFReg(pAdapter, path, RF_TXBIAS_A, bMaskDWord)));
-#else
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0xc %x\n", ODM_GetRFReg(pDM_Odm, path, RF_IPA_A, bMaskDWord)));
-			ODM_SetRFReg(pDM_Odm, path, RF_AC, bMaskDWord, APK_RF_value_0[path][index]);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x0 %x\n", ODM_GetRFReg(pDM_Odm, path, RF_AC, bMaskDWord)));
-			ODM_SetRFReg(pDM_Odm, path, RF_TXBIAS_A, bMaskDWord, tmpReg);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0xd %x\n", ODM_GetRFReg(pDM_Odm, path, RF_TXBIAS_A, bMaskDWord)));
-#endif
-
-			// PA11+PAD01111, one shot
-			i = 0;
-			do {
-				ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x800000);
-				{
-					ODM_SetBBReg(pDM_Odm, APK_offset[path], bMaskDWord, APK_value[0]);
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", APK_offset[path], ODM_GetBBReg(pDM_Odm, APK_offset[path], bMaskDWord)));
-					ODM_delay_ms(3);
-					ODM_SetBBReg(pDM_Odm, APK_offset[path], bMaskDWord, APK_value[1]);
-					ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0x%x value 0x%x\n", APK_offset[path], ODM_GetBBReg(pDM_Odm, APK_offset[path], bMaskDWord)));
-
-					ODM_delay_ms(20);
-				}
-				ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-
-				if (path == ODM_RF_PATH_A)
-					tmpReg = ODM_GetBBReg(pDM_Odm, rAPK, 0x03E00000);
-				else
-					tmpReg = ODM_GetBBReg(pDM_Odm, rAPK, 0xF8000000);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_APCalibrate_8188F() offset 0xbd8[25:21] %x\n", tmpReg));
-
-
-				i++;
-			} while (tmpReg > apkbound && i < 4);
-
-			APK_result[path][index] = tmpReg;
-		}
-	}
-
-	//reload MAC default value
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_ReloadMACRegisters8188F(pAdapter, MAC_REG, MAC_backup);
-#else
-	_PHY_ReloadMACRegisters8188F(pDM_Odm, MAC_REG, MAC_backup);
-#endif
-
-	//reload BB default value
-	for (index = 0; index < APK_BB_REG_NUM; index++) {
-
-		if (index == 0)     //skip
-			continue;
-		ODM_SetBBReg(pDM_Odm, BB_REG[index], bMaskDWord, BB_backup[index]);
-	}
-
-	//reload AFE default value
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_ReloadADDARegisters8188F(pAdapter, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-#else
-	_PHY_ReloadADDARegisters8188F(pDM_Odm, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-#endif
-
-	//reload RF path default value
-	for (path = 0; path < pathbound; path++) {
-		ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, 0xd, bMaskDWord, regD[path]);
-		if (path == ODM_RF_PATH_B) {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_MODE1, bMaskDWord, 0x1000f);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_MODE2, bMaskDWord, 0x20101);
-		}
-
-		//note no index == 0
-		if (APK_result[path][1] > 6)
-			APK_result[path][1] = 6;
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("apk path %d result %d 0x%x \t", path, 1, APK_result[path][1]));
-	}
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("\n"));
-
-
-	for (path = 0; path < pathbound; path++) {
-		ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, 0x3, bMaskDWord,
-					 ((APK_result[path][1] << 15) | (APK_result[path][1] << 10) | (APK_result[path][1] << 5) | APK_result[path][1]));
-		if (path == ODM_RF_PATH_A)
-			ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, 0x4, bMaskDWord,
-						 ((APK_result[path][1] << 15) | (APK_result[path][1] << 10) | (0x00 << 5) | 0x05));
-		else
-			ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, 0x4, bMaskDWord,
-						 ((APK_result[path][1] << 15) | (APK_result[path][1] << 10) | (0x02 << 5) | 0x05));
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		if (!IS_HARDWARE_TYPE_8723A(pAdapter))
-			ODM_SetRFReg(pDM_Odm, (ODM_RF_RADIO_PATH_E)path, RF_BS_PA_APSET_G9_G11, bMaskDWord,
-						 ((0x08 << 15) | (0x08 << 10) | (0x08 << 5) | 0x08));
-#endif
-	}
-
-	pDM_Odm->RFCalibrateInfo.bAPKdone = TRUE;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("<==phy_APCalibrate_8188F()\n"));
-#endif //MP_DRIVER != 1
-#endif
-}
-
-
-
-#define		DP_BB_REG_NUM		7
-#define		DP_RF_REG_NUM		1
-#define		DP_RETRY_LIMIT		10
-#define		DP_PATH_NUM		2
-#define		DP_DPK_NUM			3
-#define		DP_DPK_VALUE_NUM	2
-
-
-
-
-VOID
-PHY_IQCalibrate_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN bReCovery,
-	IN BOOLEAN bRestore
-)
-{
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#else  // (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-
-#if (MP_DRIVER == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx);
-#else// (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx);
-#endif
-#endif//(MP_DRIVER == 1)
-#endif
-
-	s4Byte result[4][8];   //last is final result
-	u1Byte i, final_candidate, Indexforchannel;
-	BOOLEAN bPathAOK, bPathBOK;
-#if DBG
-	s4Byte RegE94, RegE9C, RegEA4, RegEAC, RegEB4, RegEBC, RegEC4, RegECC, RegTmp = 0;
-#else
-	s4Byte RegE94, RegEA4, RegEB4, RegEC4, RegTmp = 0;
-#endif
-	BOOLEAN is12simular, is13simular, is23simular;
-#if MP_DRIVER == 1
-	BOOLEAN bStartContTx = FALSE;
-#endif
-	BOOLEAN bSingleTone = FALSE, bCarrierSuppression = FALSE;
-	u4Byte 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
-	};
-	u4Byte Path_SEL_BB = 0, Path_SEL_RF = 0;
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE) )
-	if (ODM_CheckPowerStatus(pAdapter) == FALSE)
-		return;
-#else
-	prtl8192cd_priv priv = pDM_Odm->priv;
-
-#ifdef MP_TEST
-	if (priv->pshare->rf_ft_var.mp_specific) {
-		if ((OPMODE & WIFI_MP_CTX_PACKET) || (OPMODE & WIFI_MP_CTX_ST))
-			return;
-	}
-#endif
-
-	if (priv->pshare->IQK_88E_done)
-		bReCovery = 1;
-	priv->pshare->IQK_88E_done = 1;
-
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (!(pDM_Odm->SupportAbility & ODM_RF_CALIBRATION))
-		return;
-#endif
-
-#if MP_DRIVER == 1
-	bStartContTx = pMptCtx->bStartContTx;
-	bSingleTone = pMptCtx->bSingleTone;
-	bCarrierSuppression = pMptCtx->bCarrierSuppression;
-#endif
-
-	// 20120213<Kordan> Turn on when continuous Tx to pass lab testing. (required by Edlu)
-	if (bSingleTone || bCarrierSuppression)
-		return;
-
-#if DISABLE_BB_RF
-	return;
-#endif
-
-	if (bRestore) {
-		u4Byte offset, data;
-		u1Byte path, bResult = SUCCESS;
-		PODM_RF_CAL_T pRFCalibrateInfo = &(pDM_Odm->RFCalibrateInfo);
-
-		//#define 	PATH_S0                         1 // RF_PATH_B
-		//#define 	PATH_S1                         0 // RF_PATH_A
-
-		path = (ODM_GetBBReg(pDM_Odm, rS0S1_PathSwitch, bMaskByte0) == 0x00) ? ODM_RF_PATH_A : ODM_RF_PATH_B;
-		//Restore TX IQK
-		for (i = 0; i < 3; ++i) {
-			offset = pRFCalibrateInfo->TxIQC_8723B[path][i][0];
-			data = pRFCalibrateInfo->TxIQC_8723B[path][i][1];
-			if ((offset == 0) || (data == 0)) {
-				bResult = FAIL;
-				break;
-			}
-			RT_TRACE(COMP_MP, DBG_TRACE, ("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data));
-			ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, data);
-		}
-		//Restore RX IQK
-		for (i = 0; i < 2; ++i) {
-			offset = pRFCalibrateInfo->RxIQC_8723B[path][i][0];
-			data = pRFCalibrateInfo->RxIQC_8723B[path][i][1];
-			if ((offset == 0) || (data == 0)) {
-				bResult = FAIL;
-				break;
-			}
-			RT_TRACE(COMP_MP, DBG_TRACE, ("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data));
-			ODM_SetBBReg(pDM_Odm, offset, bMaskDWord, data);
-		}
-
-		if (pDM_Odm->RFCalibrateInfo.TxLOK[ODM_RF_PATH_A] == 0) {
-			bResult = FAIL;
-		} else {
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_TXM_IDAC, bRFRegOffsetMask, pDM_Odm->RFCalibrateInfo.TxLOK[ODM_RF_PATH_A]);
-			ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_TXM_IDAC, bRFRegOffsetMask, pDM_Odm->RFCalibrateInfo.TxLOK[ODM_RF_PATH_B]);
-		}
-
-		if (bResult == SUCCESS)
-			return;
-
-	}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_AP))
-	if (bReCovery)
-#else//for ODM_WIN
-	if (bReCovery && (!pAdapter->bInHctTest))  //YJ,add for PowerTest,120405
-#endif
-	{
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD, ("PHY_IQCalibrate_8188F: Return due to bReCovery!\n"));
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		_PHY_ReloadADDARegisters8188F(pAdapter, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup_recover, 9);
-#else
-		_PHY_ReloadADDARegisters8188F(pDM_Odm, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup_recover, 9);
-#endif
-		return;
-	}
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:Start!!!\n"));
-
-
-	// Save RF Path
-	Path_SEL_BB = ODM_GetBBReg(pDM_Odm, 0x948, bMaskDWord);
-	Path_SEL_RF = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xb0, 0xfffff);
-
-
-	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 !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-
-		phy_IQCalibrate_8188F(pAdapter, result, i, FALSE);
-
-#else
-		phy_IQCalibrate_8188F(pDM_Odm, result, i, FALSE);
-#endif
-
-
-		if (i == 1) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			is12simular = phy_SimularityCompare_8188F(pAdapter, result, 0, 1);
-#else
-			is12simular = phy_SimularityCompare_8188F(pDM_Odm, result, 0, 1);
-#endif
-			if (is12simular) {
-				final_candidate = 0;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: is12simular final_candidate is %x\n", final_candidate));
-				break;
-			}
-		}
-
-		if (i == 2) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			is13simular = phy_SimularityCompare_8188F(pAdapter, result, 0, 2);
-#else
-			is13simular = phy_SimularityCompare_8188F(pDM_Odm, result, 0, 2);
-#endif
-			if (is13simular) {
-				final_candidate = 0;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: is13simular final_candidate is %x\n", final_candidate));
-
-				break;
-			}
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			is23simular = phy_SimularityCompare_8188F(pAdapter, result, 1, 2);
-#else
-			is23simular = phy_SimularityCompare_8188F(pDM_Odm, result, 1, 2);
-#endif
-			if (is23simular) {
-				final_candidate = 1;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: is23simular final_candidate is %x\n", final_candidate));
-			} else {
-				for (i = 0; i < 8; i++) RegTmp += result[3][i];
-
-				if (RegTmp != 0)
-					final_candidate = 3;
-				else
-					final_candidate = 0xFF;
-			}
-		}
-	}
-//	RT_TRACE(COMP_INIT,DBG_LOUD,("Release Mutex in IQCalibrate\n"));
-
-	for (i = 0; i < 4; i++) {
-		RegE94 = result[i][0];
-		RegEA4 = result[i][2];
-		RegEB4 = result[i][4];
-		RegEC4 = result[i][6];
-#if DBG
-		RegE9C = result[i][1];
-		RegEAC = result[i][3];
-		RegEBC = result[i][5];
-		RegECC = result[i][7];
-#endif
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: RegE94=%04x RegE9C=%04x RegEA4=%04x RegEAC=%04x RegEB4=%04x RegEBC=%04x RegEC4=%04x RegECC=%04x\n",
-					 RegE94, RegE9C, RegEA4, RegEAC, RegEB4, RegEBC, RegEC4, RegECC));
-	}
-
-	if (final_candidate != 0xff) {
-		pDM_Odm->RFCalibrateInfo.RegE94 = result[final_candidate][0];
-		pDM_Odm->RFCalibrateInfo.RegE9C = result[final_candidate][1];
-		pDM_Odm->RFCalibrateInfo.RegEB4 = result[final_candidate][4];
-		pDM_Odm->RFCalibrateInfo.RegEBC = result[final_candidate][5];
-
-		RegE94 = result[final_candidate][0];
-		RegEA4 = result[final_candidate][2];
-		RegEB4 = result[final_candidate][4];
-		RegEC4 = result[final_candidate][6];
-#if DBG
-		RegE9C = result[final_candidate][1];
-		RegEAC = result[final_candidate][3];
-		RegEBC = result[final_candidate][5];
-		RegECC = result[final_candidate][7];
-#endif
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: final_candidate is %x\n", final_candidate));
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: RegE94=%04x RegE9C=%04x RegEA4=%04x RegEAC=%04x RegEB4=%04x RegEBC=%04x RegEC4=%04x RegECC=%04x\n",
-					 RegE94, RegE9C, RegEA4, RegEAC, RegEB4, RegEBC, RegEC4, RegECC));
-		bPathAOK = bPathBOK = TRUE;
-	} else {
-		ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: FAIL use default value\n"));
-
-		pDM_Odm->RFCalibrateInfo.RegE94 = pDM_Odm->RFCalibrateInfo.RegEB4 = 0x100;  //X default value
-		pDM_Odm->RFCalibrateInfo.RegE9C = pDM_Odm->RFCalibrateInfo.RegEBC = 0x0;        //Y default value
-	}
-
-#if MP_DRIVER == 1
-	if ((pMptCtx->MptRfPath == ODM_RF_PATH_A) || ((pDM_Odm->mp_mode) == 0))
-#endif
-	{
-		if (RegE94 != 0) {
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			_PHY_PathAFillIQKMatrix8188F(pAdapter, bPathAOK, result, final_candidate, (RegEA4 == 0));
-#else
-			_PHY_PathAFillIQKMatrix8188F(pDM_Odm, bPathAOK, result, final_candidate, (RegEA4 == 0));
-#endif
-		}
-	}
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if MP_DRIVER == 1
-	if ((pMptCtx->MptRfPath == ODM_RF_PATH_A) || ((pDM_Odm->mp_mode) == 0))
-#endif
-	{
-		if (RegEB4 != 0)
-			_PHY_PathBFillIQKMatrix8188F(pAdapter, bPathBOK, result, final_candidate, (RegEC4 == 0));
-	}
-#endif
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	Indexforchannel = ODM_GetRightChnlPlaceforIQK(pHalData->CurrentChannel);
-#else
-	Indexforchannel = 0;
-#endif
-
-//To Fix BSOD when final_candidate is 0xff
-//by sherry 20120321
-	if (final_candidate < 4) {
-		for (i = 0; i < IQK_Matrix_REG_NUM; i++) pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[Indexforchannel].Value[0][i] = result[final_candidate][i];
-		pDM_Odm->RFCalibrateInfo.IQKMatrixRegSetting[Indexforchannel].bIQKDone = TRUE;
-	}
-	//RT_DISP(FINIT, INIT_IQK, ("\nIQK OK Indexforchannel %d.\n", Indexforchannel));
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("\nIQK OK Indexforchannel %d.\n", Indexforchannel));
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-	_PHY_SaveADDARegisters8188F(pAdapter, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup_recover, 9);
-#else
-	_PHY_SaveADDARegisters8188F(pDM_Odm, IQK_BB_REG_92C, pDM_Odm->RFCalibrateInfo.IQK_BB_backup_recover, IQK_BB_REG_NUM);
-#endif
-
-	// Restore RF Path
-	ODM_SetBBReg(pDM_Odm, 0x948, bMaskDWord, Path_SEL_BB);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0xb0, 0xfffff, Path_SEL_RF);
-
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK finished 8188F\n"));
-
-
-}
-
-
-VOID
-PHY_LCCalibrate_8188F(
-	PVOID pDM_VOID
-)
-{
-#if MP_DRIVER == 1
-	BOOLEAN bStartContTx = FALSE;
-#endif
-	BOOLEAN bSingleTone = FALSE, bCarrierSuppression = FALSE;
-	u4Byte timeout = 2000, timecount = 0;
-
-	PDM_ODM_T pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if MP_DRIVER == 1
-	PADAPTER pAdapter = pDM_Odm->Adapter;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PMPT_CONTEXT pMptCtx = &(pAdapter->MptCtx);
-#else// (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.MptCtx);
-#endif
-#endif
-#endif
-
-#if MP_DRIVER == 1
-	bStartContTx = pMptCtx->bStartContTx;
-	bSingleTone = pMptCtx->bSingleTone;
-	bCarrierSuppression = pMptCtx->bCarrierSuppression;
-#endif
-
-
-#if DISABLE_BB_RF
-	return;
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (!(pDM_Odm->SupportAbility & ODM_RF_CALIBRATION))
-		return;
-#endif
-	// 20120213<Kordan> Turn on when continuous Tx to pass lab testing. (required by Edlu)
-	if (bSingleTone || bCarrierSuppression)
-		return;
-
-	while (*(pDM_Odm->pbScanInProcess) && timecount < timeout) {
-		ODM_delay_ms(50);
-		timecount += 50;
-	}
-
-	pDM_Odm->RFCalibrateInfo.bLCKInProgress = TRUE;
-
-
-	phy_LCCalibrate_8188F(pDM_Odm, FALSE);
-
-
-	pDM_Odm->RFCalibrateInfo.bLCKInProgress = FALSE;
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("LCK:Finish!!!interface %d 8188F\n", pDM_Odm->InterfaceIndex));
-
-}
-
-VOID
-PHY_APCalibrate_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN s1Byte delta
-)
-{
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if DBG
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-#endif
-#if DISABLE_BB_RF
-	return;
-#endif
-
-	return;
-#if 0
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (!(pDM_Odm->SupportAbility & ODM_RF_CALIBRATION))
-		return;
-#endif
-
-#if FOR_BRAZIL_PRETEST != 1
-	if (pDM_Odm->RFCalibrateInfo.bAPKdone)
-#endif
-		return;
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	if (IS_2T2R(pHalData->VersionID))
-		phy_APCalibrate_8188F(pAdapter, delta, TRUE);
-	else
-#endif
-	{
-		// For 88C 1T1R
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		phy_APCalibrate_8188F(pAdapter, delta, FALSE);
-#else
-		phy_APCalibrate_8188F(pDM_Odm, delta, FALSE);
-#endif
-	}
-#endif
-}
-
-VOID phy_SetRFPathSwitch_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN bMain,
-	IN BOOLEAN is2T
-)
-{
-
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-
-	if (bMain)   // Left antenna
-		ODM_SetBBReg(pDM_Odm, 0x92C, bMaskDWord, 0x1);
-	else
-		ODM_SetBBReg(pDM_Odm, 0x92C, bMaskDWord, 0x2);
-}
-
-VOID PHY_SetRFPathSwitch_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN bMain
-)
-{
-
-#if DISABLE_BB_RF
-	return;
-#endif
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	phy_SetRFPathSwitch_8188F(pAdapter, bMain, TRUE);
-#endif
-
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-//digital predistortion
-VOID
-phy_DigitalPredistortion8188F(
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PADAPTER pAdapter,
-#else
-	IN PDM_ODM_T pDM_Odm,
-#endif
-	IN BOOLEAN is2T
-)
-{
-#if (RT_PLATFORM == PLATFORM_WINDOWS)
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-
-	u4Byte tmpReg, tmpReg2, index, i;
-	u1Byte path, pathbound = PATH_NUM;
-	u4Byte AFE_backup[IQK_ADDA_REG_NUM];
-	u4Byte AFE_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
-	};
-
-	u4Byte BB_backup[DP_BB_REG_NUM];
-	u4Byte BB_REG[DP_BB_REG_NUM] = {
-		rOFDM0_TRxPathEnable, rFPGA0_RFMOD,
-		rOFDM0_TRMuxPar, rFPGA0_XCD_RFInterfaceSW,
-		rFPGA0_XAB_RFInterfaceSW, rFPGA0_XA_RFInterfaceOE,
-		rFPGA0_XB_RFInterfaceOE
-	};
-	u4Byte BB_settings[DP_BB_REG_NUM] = {
-		0x00a05430, 0x02040000, 0x000800e4, 0x22208000,
-		0x0, 0x0, 0x0
-	};
-
-	u4Byte RF_backup[DP_PATH_NUM][DP_RF_REG_NUM];
-	u4Byte RF_REG[DP_RF_REG_NUM] = {
-		RF_TXBIAS_A
-	};
-
-	u4Byte MAC_backup[IQK_MAC_REG_NUM];
-	u4Byte MAC_REG[IQK_MAC_REG_NUM] = {
-		REG_TXPAUSE, REG_BCN_CTRL,
-		REG_BCN_CTRL_1, REG_GPIO_MUXCFG
-	};
-
-	u4Byte Tx_AGC[DP_DPK_NUM][DP_DPK_VALUE_NUM] = {
-		{ 0x1e1e1e1e, 0x03901e1e },
-		{ 0x18181818, 0x03901818 },
-		{ 0x0e0e0e0e, 0x03900e0e }
-	};
-
-	u4Byte AFE_on_off[PATH_NUM] = {
-		0x04db25a4, 0x0b1b25a4
-	};    //path A on path B off / path A off path B on
-
-	u1Byte RetryCount = 0;
-
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("==>phy_DigitalPredistortion8188F()\n"));
-
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("phy_DigitalPredistortion8188F for %s\n", (is2T ? "2T2R" : "1T1R")));
-
-	//save BB default value
-	for (index = 0; index < DP_BB_REG_NUM; index++) BB_backup[index] = ODM_GetBBReg(pDM_Odm, BB_REG[index], bMaskDWord);
-
-	//save MAC default value
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_SaveMACRegisters8188F(pAdapter, BB_REG, MAC_backup);
-#else
-	_PHY_SaveMACRegisters8188F(pDM_Odm, BB_REG, MAC_backup);
-#endif
-
-	//save RF default value
-	for (path = 0; path < DP_PATH_NUM; path++) {
-		for (index = 0; index < DP_RF_REG_NUM; index++)
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			RF_backup[path][index] = PHY_QueryRFReg(pAdapter, path, RF_REG[index], bMaskDWord);
-#else
-			RF_backup[path][index] = ODM_GetRFReg(pAdapter, path, RF_REG[index], bMaskDWord);
-#endif
-	}
-
-	//save AFE default value
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_SaveADDARegisters8188F(pAdapter, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-#else
-	_PHY_SaveADDARegisters8188F(pDM_Odm, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-#endif
-
-	//Path A/B AFE all on
-	for (index = 0; index < IQK_ADDA_REG_NUM; index++) ODM_SetBBReg(pDM_Odm, AFE_REG[index], bMaskDWord, 0x6fdb25a4);
-
-	//BB register setting
-	for (index = 0; index < DP_BB_REG_NUM; index++) {
-		if (index < 4)
-			ODM_SetBBReg(pDM_Odm, BB_REG[index], bMaskDWord, BB_settings[index]);
-		else if (index == 4)
-			ODM_SetBBReg(pDM_Odm, BB_REG[index], bMaskDWord, BB_backup[index] | BIT10 | BIT26);
-		else
-			ODM_SetBBReg(pDM_Odm, BB_REG[index], BIT10, 0x00);
-	}
-
-	//MAC register setting
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_MACSettingCalibration8188F(pAdapter, MAC_REG, MAC_backup);
-#else
-	_PHY_MACSettingCalibration8188F(pDM_Odm, MAC_REG, MAC_backup);
-#endif
-
-	//PAGE-E IQC setting
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_A, bMaskDWord, 0x01008c00);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_A, bMaskDWord, 0x01008c00);
-	ODM_SetBBReg(pDM_Odm, rTx_IQK_Tone_B, bMaskDWord, 0x01008c00);
-	ODM_SetBBReg(pDM_Odm, rRx_IQK_Tone_B, bMaskDWord, 0x01008c00);
-
-	//path_A DPK
-	//Path B to standby mode
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bMaskDWord, 0x10000);
-
-	// PA gain = 11 & PAD1 => tx_agc 1f ~11
-	// PA gain = 11 & PAD2 => tx_agc 10~0e
-	// PA gain = 01 => tx_agc 0b~0d
-	// PA gain = 00 => tx_agc 0a~00
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x400000);
-	ODM_SetBBReg(pDM_Odm, 0xbc0, bMaskDWord, 0x0005361f);
-	ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-
-	//do inner loopback DPK 3 times
-	for (i = 0; i < 3; i++) {
-		//PA gain = 11 & PAD2 => tx_agc = 0x0f/0x0c/0x07
-		for (index = 0; index < 3; index++) ODM_SetBBReg(pDM_Odm, 0xe00 + index * 4, bMaskDWord, Tx_AGC[i][0]);
-		ODM_SetBBReg(pDM_Odm, 0xe00 + index * 4, bMaskDWord, Tx_AGC[i][1]);
-		for (index = 0; index < 4; index++) ODM_SetBBReg(pDM_Odm, 0xe10 + index * 4, bMaskDWord, Tx_AGC[i][0]);
-
-		// PAGE_B for Path-A inner loopback DPK setting
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA, bMaskDWord, 0x02097098);
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA_4, bMaskDWord, 0xf76d9f84);
-		ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x0004ab87);
-		ODM_SetBBReg(pDM_Odm, rConfig_AntA, bMaskDWord, 0x00880000);
-
-		//----send one shot signal----//
-		// Path A
-		ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x80047788);
-		ODM_delay_ms(1);
-		ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x00047788);
-		ODM_delay_ms(50);
-	}
-
-	//PA gain = 11 => tx_agc = 1a
-	for (index = 0; index < 3; index++) ODM_SetBBReg(pDM_Odm, 0xe00 + index * 4, bMaskDWord, 0x34343434);
-	ODM_SetBBReg(pDM_Odm, 0xe08 + index * 4, bMaskDWord, 0x03903434);
-	for (index = 0; index < 4; index++) ODM_SetBBReg(pDM_Odm, 0xe10 + index * 4, bMaskDWord, 0x34343434);
-
-	//====================================
-	// PAGE_B for Path-A DPK setting
-	//====================================
-	// open inner loopback @ b00[19]:10 od 0xb00 0x01097018
-	ODM_SetBBReg(pDM_Odm, rPdp_AntA, bMaskDWord, 0x02017098);
-	ODM_SetBBReg(pDM_Odm, rPdp_AntA_4, bMaskDWord, 0xf76d9f84);
-	ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x0004ab87);
-	ODM_SetBBReg(pDM_Odm, rConfig_AntA, bMaskDWord, 0x00880000);
-
-	//rf_lpbk_setup
-	//1.rf 00:5205a, rf 0d:0e52c
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x0c, bMaskDWord, 0x8992b);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x0d, bMaskDWord, 0x0e52c);
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, 0x00, bMaskDWord, 0x5205a);
-
-	//----send one shot signal----//
-	// Path A
-	ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x800477c0);
-	ODM_delay_ms(1);
-	ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x000477c0);
-	ODM_delay_ms(50);
-
-	while (RetryCount < DP_RETRY_LIMIT && !pDM_Odm->RFCalibrateInfo.bDPPathAOK) {
-		//----read back measurement results----//
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA, bMaskDWord, 0x0c297018);
-		tmpReg = ODM_GetBBReg(pDM_Odm, 0xbe0, bMaskDWord);
-		ODM_delay_ms(10);
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA, bMaskDWord, 0x0c29701f);
-		tmpReg2 = ODM_GetBBReg(pDM_Odm, 0xbe8, bMaskDWord);
-		ODM_delay_ms(10);
-
-		tmpReg = (tmpReg & bMaskHWord) >> 16;
-		tmpReg2 = (tmpReg2 & bMaskHWord) >> 16;
-		if (tmpReg < 0xf0 || tmpReg > 0x105 || tmpReg2 > 0xff) {
-			ODM_SetBBReg(pDM_Odm, rPdp_AntA, bMaskDWord, 0x02017098);
-
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x800000);
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-			ODM_delay_ms(1);
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x800477c0);
-			ODM_delay_ms(1);
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x000477c0);
-			ODM_delay_ms(50);
-			RetryCount++;
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path A DPK RetryCount %d 0xbe0[31:16] %x 0xbe8[31:16] %x\n", RetryCount, tmpReg, tmpReg2));
-		} else {
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path A DPK Sucess\n"));
-			pDM_Odm->RFCalibrateInfo.bDPPathAOK = TRUE;
-			break;
-		}
-	}
-	RetryCount = 0;
-
-	//DPP path A
-	if (pDM_Odm->RFCalibrateInfo.bDPPathAOK) {
-		// DP settings
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA, bMaskDWord, 0x01017098);
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA_4, bMaskDWord, 0x776d9f84);
-		ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntA, bMaskDWord, 0x0004ab87);
-		ODM_SetBBReg(pDM_Odm, rConfig_AntA, bMaskDWord, 0x00880000);
-		ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x400000);
-
-		for (i = rPdp_AntA; i <= 0xb3c; i += 4) {
-			ODM_SetBBReg(pDM_Odm, i, bMaskDWord, 0x40004000);
-			ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path A ofsset = 0x%x\n", i));
-		}
-
-		//pwsf
-		ODM_SetBBReg(pDM_Odm, 0xb40, bMaskDWord, 0x40404040);
-		ODM_SetBBReg(pDM_Odm, 0xb44, bMaskDWord, 0x28324040);
-		ODM_SetBBReg(pDM_Odm, 0xb48, bMaskDWord, 0x10141920);
-
-		for (i = 0xb4c; i <= 0xb5c; i += 4)
-			ODM_SetBBReg(pDM_Odm, i, bMaskDWord, 0x0c0c0c0c);
-
-		//TX_AGC boundary
-		ODM_SetBBReg(pDM_Odm, 0xbc0, bMaskDWord, 0x0005361f);
-		ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-	} else {
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA, bMaskDWord, 0x00000000);
-		ODM_SetBBReg(pDM_Odm, rPdp_AntA_4, bMaskDWord, 0x00000000);
-	}
-
-	//DPK path B
-	if (is2T) {
-		//Path A to standby mode
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_AC, bMaskDWord, 0x10000);
-
-		// LUTs => tx_agc
-		// PA gain = 11 & PAD1, => tx_agc 1f ~11
-		// PA gain = 11 & PAD2, => tx_agc 10 ~0e
-		// PA gain = 01 => tx_agc 0b ~0d
-		// PA gain = 00 => tx_agc 0a ~00
-		ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x400000);
-		ODM_SetBBReg(pDM_Odm, 0xbc4, bMaskDWord, 0x0005361f);
-		ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-
-		//do inner loopback DPK 3 times
-		for (i = 0; i < 3; i++) {
-			//PA gain = 11 & PAD2 => tx_agc = 0x0f/0x0c/0x07
-			for (index = 0; index < 4; index++) ODM_SetBBReg(pDM_Odm, 0x830 + index * 4, bMaskDWord, Tx_AGC[i][0]);
-			for (index = 0; index < 2; index++) ODM_SetBBReg(pDM_Odm, 0x848 + index * 4, bMaskDWord, Tx_AGC[i][0]);
-			for (index = 0; index < 2; index++) ODM_SetBBReg(pDM_Odm, 0x868 + index * 4, bMaskDWord, Tx_AGC[i][0]);
-
-			// PAGE_B for Path-A inner loopback DPK setting
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB, bMaskDWord, 0x02097098);
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB_4, bMaskDWord, 0xf76d9f84);
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x0004ab87);
-			ODM_SetBBReg(pDM_Odm, rConfig_AntB, bMaskDWord, 0x00880000);
-
-			//----send one shot signal----//
-			// Path B
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x80047788);
-			ODM_delay_ms(1);
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x00047788);
-			ODM_delay_ms(50);
-		}
-
-		// PA gain = 11 => tx_agc = 1a
-		for (index = 0; index < 4; index++) ODM_SetBBReg(pDM_Odm, 0x830 + index * 4, bMaskDWord, 0x34343434);
-		for (index = 0; index < 2; index++) ODM_SetBBReg(pDM_Odm, 0x848 + index * 4, bMaskDWord, 0x34343434);
-		for (index = 0; index < 2; index++) ODM_SetBBReg(pDM_Odm, 0x868 + index * 4, bMaskDWord, 0x34343434);
-
-		// PAGE_B for Path-B DPK setting
-		ODM_SetBBReg(pDM_Odm, rPdp_AntB, bMaskDWord, 0x02017098);
-		ODM_SetBBReg(pDM_Odm, rPdp_AntB_4, bMaskDWord, 0xf76d9f84);
-		ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x0004ab87);
-		ODM_SetBBReg(pDM_Odm, rConfig_AntB, bMaskDWord, 0x00880000);
-
-		// RF lpbk switches on
-		ODM_SetBBReg(pDM_Odm, 0x840, bMaskDWord, 0x0101000f);
-		ODM_SetBBReg(pDM_Odm, 0x840, bMaskDWord, 0x01120103);
-
-		//Path-B RF lpbk
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x0c, bMaskDWord, 0x8992b);
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, 0x0d, bMaskDWord, 0x0e52c);
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_AC, bMaskDWord, 0x5205a);
-
-		//----send one shot signal----//
-		ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x800477c0);
-		ODM_delay_ms(1);
-		ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x000477c0);
-		ODM_delay_ms(50);
-
-		while (RetryCount < DP_RETRY_LIMIT && !pDM_Odm->RFCalibrateInfo.bDPPathBOK) {
-			//----read back measurement results----//
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB, bMaskDWord, 0x0c297018);
-			tmpReg = ODM_GetBBReg(pDM_Odm, 0xbf0, bMaskDWord);
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB, bMaskDWord, 0x0c29701f);
-			tmpReg2 = ODM_GetBBReg(pDM_Odm, 0xbf8, bMaskDWord);
-
-			tmpReg = (tmpReg & bMaskHWord) >> 16;
-			tmpReg2 = (tmpReg2 & bMaskHWord) >> 16;
-
-			if (tmpReg < 0xf0 || tmpReg > 0x105 || tmpReg2 > 0xff) {
-				ODM_SetBBReg(pDM_Odm, rPdp_AntB, bMaskDWord, 0x02017098);
-
-				ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x800000);
-				ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-				ODM_delay_ms(1);
-				ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x800477c0);
-				ODM_delay_ms(1);
-				ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x000477c0);
-				ODM_delay_ms(50);
-				RetryCount++;
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path B DPK RetryCount %d 0xbf0[31:16] %x, 0xbf8[31:16] %x\n", RetryCount , tmpReg, tmpReg2));
-			} else {
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path B DPK Success\n"));
-				pDM_Odm->RFCalibrateInfo.bDPPathBOK = TRUE;
-				break;
-			}
-		}
-
-		//DPP path B
-		if (pDM_Odm->RFCalibrateInfo.bDPPathBOK) {
-			// DP setting
-			// LUT by SRAM
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB, bMaskDWord, 0x01017098);
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB_4, bMaskDWord, 0x776d9f84);
-			ODM_SetBBReg(pDM_Odm, rConfig_Pmpd_AntB, bMaskDWord, 0x0004ab87);
-			ODM_SetBBReg(pDM_Odm, rConfig_AntB, bMaskDWord, 0x00880000);
-
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x400000);
-			for (i = 0xb60; i <= 0xb9c; i += 4) {
-				ODM_SetBBReg(pDM_Odm, i, bMaskDWord, 0x40004000);
-				ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path B ofsset = 0x%x\n", i));
-			}
-
-			// PWSF
-			ODM_SetBBReg(pDM_Odm, 0xba0, bMaskDWord, 0x40404040);
-			ODM_SetBBReg(pDM_Odm, 0xba4, bMaskDWord, 0x28324050);
-			ODM_SetBBReg(pDM_Odm, 0xba8, bMaskDWord, 0x0c141920);
-
-			for (i = 0xbac; i <= 0xbbc; i += 4)
-				ODM_SetBBReg(pDM_Odm, i, bMaskDWord, 0x0c0c0c0c);
-
-			// tx_agc boundary
-			ODM_SetBBReg(pDM_Odm, 0xbc4, bMaskDWord, 0x0005361f);
-			ODM_SetBBReg(pDM_Odm, rFPGA0_IQK, bMaskH3Bytes, 0x000000);
-
-		} else {
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, rPdp_AntB_4, bMaskDWord, 0x00000000);
-		}
-	}
-
-	//reload BB default value
-	for (index = 0; index < DP_BB_REG_NUM; index++) ODM_SetBBReg(pDM_Odm, BB_REG[index], bMaskDWord, BB_backup[index]);
-
-	//reload RF default value
-	for (path = 0; path < DP_PATH_NUM; path++) {
-		for (i = 0; i < DP_RF_REG_NUM; i++)
-			ODM_SetRFReg(pDM_Odm, path, RF_REG[i], bMaskDWord, RF_backup[path][i]);
-	}
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_MODE1, bMaskDWord, 0x1000f);    //standby mode
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_MODE2, bMaskDWord, 0x20101);        //RF lpbk switches off
-
-	//reload AFE default value
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_PHY_ReloadADDARegisters8188F(pAdapter, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-
-	//reload MAC default value
-	_PHY_ReloadMACRegisters8188F(pAdapter, MAC_REG, MAC_backup);
-#else
-	_PHY_ReloadADDARegisters8188F(pDM_Odm, AFE_REG, AFE_backup, IQK_ADDA_REG_NUM);
-
-	//reload MAC default value
-	_PHY_ReloadMACRegisters8188F(pDM_Odm, MAC_REG, MAC_backup);
-#endif
-
-	pDM_Odm->RFCalibrateInfo.bDPdone = TRUE;
-	ODM_RT_TRACE(pDM_Odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("<==phy_DigitalPredistortion8188F()\n"));
-#endif
-}
-
-VOID
-PHY_DigitalPredistortion_8188F(
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PADAPTER pAdapter
-#else
-	IN PDM_ODM_T pDM_Odm
-#endif
-)
-{
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-#if DISABLE_BB_RF
-	return;
-#endif
-
-	return;
-
-	if (pDM_Odm->RFCalibrateInfo.bDPdone)
-		return;
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-	if (IS_92C_SERIAL(pHalData->VersionID))
-		phy_DigitalPredistortion8188F(pAdapter, TRUE);
-	else
-#endif
-	{
-		// For 88C 1T1R
-		phy_DigitalPredistortion8188F(pAdapter, FALSE);
-	}
-}
-
-
-
-//return value TRUE => Main; FALSE => Aux
-
-BOOLEAN phy_QueryRFPathSwitch_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm,
-#else
-	IN PADAPTER pAdapter,
-#endif
-	IN BOOLEAN is2T
-)
-{
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-#endif
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T pDM_Odm = &pHalData->DM_OutSrc;
-#endif
-#endif
-
-
-	if (ODM_GetBBReg(pDM_Odm, 0x92C, bMaskDWord) == 0x01)
-		return TRUE;
-	else
-		return FALSE;
-
-}
-
-
-
-//return value TRUE => Main; FALSE => Aux
-BOOLEAN PHY_QueryRFPathSwitch_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T pDM_Odm
-#else
-	IN PADAPTER pAdapter
-#endif
-)
-{
-	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
-
-#if DISABLE_BB_RF
-	return TRUE;
-#endif
-
-#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	return phy_QueryRFPathSwitch_8188F(pAdapter, FALSE);
-#else
-	return phy_QueryRFPathSwitch_8188F(pDM_Odm, FALSE);
-#endif
-
-}
-#endif
-
-u32 phy_psd_log2base(u32 val)
-{
-	u8	i, j;
-	u32	tmp, tmp2, val_integerdb = 0, tindex, shiftcount = 0;
-	u32	result, val_fractiondb = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
-									174, 151, 132, 115, 100, 86,
-									74, 62, 51, 42, 32, 23, 15, 7, 0};
-
-	if (val == 0)
-		return 0;
-
-	tmp = val;
-	while (1) {
-		if (tmp == 1)
-			break;
-
-		else {
-			tmp = (tmp >> 1);
-			shiftcount++;
-		}
-	}
-
-	val_integerdb = shiftcount+1;
-	tmp2 = 1;
-
-	for (j = 1; j <= val_integerdb; j++)
-		tmp2 = tmp2 * 2;
-
-	tmp = (val * 100) / tmp2;
-	tindex = tmp / 5;
-
-	if (tindex > 20)
-		tindex = 20;
-
-	val_fractiondb = table_fraction[tindex];
-
-	result = val_integerdb * 100 - val_fractiondb;
-
-	return result;
-
-
-}
-
-#define RFREGOFFSETMASK bRFRegOffsetMask
-#define MASKH3BYTES bMaskH3Bytes
-#define MASKDWORD bMaskDWord
-
-#define REG_FPGA0_XCD_SWITCH_CONTROL rFPGA0_XCD_SwitchControl
-#define REG_BLUE_TOOTH	rBlue_Tooth
-#define REG_RX_WAIT_CCA	rRx_Wait_CCA
-#define REG_TX_CCK_RFON rTx_CCK_RFON
-#define REG_TX_CCK_BBON rTx_CCK_BBON
-#define REG_TX_OFDM_RFON rTx_OFDM_RFON
-#define REG_TX_OFDM_BBON rTx_OFDM_BBON
-#define REG_TX_TO_RX rTx_To_Rx
-#define REG_TX_TO_TX rTx_To_Tx
-#define REG_RX_CCK rRx_CCK
-#define REG_RX_OFDM rRx_OFDM
-#define REG_RX_WAIT_RIFS rRx_Wait_RIFS
-#define REG_RX_TO_RX rRx_TO_Rx
-#define REG_STANDBY rStandby
-#define REG_SLEEP rSleep
-#define REG_PMPD_ANAEN rPMPD_ANAEN
-#define REG_OFDM_0_TRX_PATH_ENABLE rOFDM0_TRxPathEnable
-#define REG_OFDM_0_TR_MUX_PAR rOFDM0_TRMuxPar
-#define REG_FPGA0_XCD_RF_INTERFACE_SW rFPGA0_XCD_RFInterfaceSW
-#define REG_CONFIG_ANT_A rConfig_AntA
-#define REG_CONFIG_ANT_B rConfig_AntB
-#define REG_FPGA0_XAB_RF_INTERFACE_SW rFPGA0_XAB_RFInterfaceSW
-#define REG_FPGA0_XA_RF_INTERFACE_OE rFPGA0_XA_RFInterfaceOE
-#define REG_FPGA0_XB_RF_INTERFACE_OE rFPGA0_XB_RFInterfaceOE
-#define REG_FPGA0_RFMOD rFPGA0_RFMOD
-#define REG_FPGA0_IQK rFPGA0_IQK
-#define REG_TX_IQK rTx_IQK
-#define REG_RX_IQK rRx_IQK
-#define REG_TX_IQK_TONE_A rTx_IQK_Tone_A
-#define REG_RX_IQK_TONE_A rRx_IQK_Tone_A
-#define REG_TX_IQK_PI_A rTx_IQK_PI_A
-#define REG_RX_IQK_PI_A rRx_IQK_PI_A
-#define REG_IQK_AGC_RSP rIQK_AGC_Rsp
-#define REG_IQK_AGC_PTS rIQK_AGC_Pts
-
-#define _phy_save_adda_registers8188f(odm, adda_reg, adda_backup, register_num) \
-	_PHY_SaveADDARegisters8188F(odm->Adapter, adda_reg, adda_backup, register_num)
-
-#define _phy_save_mac_registers8188f(odm, mac_reg, mac_backup) \
-	_PHY_SaveMACRegisters8188F(odm->Adapter, mac_reg, mac_backup)
-
-#define _phy_path_adda_on8188f(odm, adda_reg, is_path_a_on, is2T) \
-	_PHY_PathADDAOn8188F(odm->Adapter, adda_reg, is_path_a_on, is2T)
-
-#define _phy_reload_adda_registers8188f(odm, adda_reg, adda_backup, regiester_num) \
-	_PHY_ReloadADDARegisters8188F(odm->Adapter, adda_reg, adda_backup, regiester_num)
-
-#define _phy_reload_mac_registers8188f(odm, mac_reg, mac_backup) \
-	_PHY_ReloadMACRegisters8188F(odm->Adapter, mac_reg, mac_backup)
-
-#define odm_get_rf_reg(odm, e_rf_path, reg_addr, bit_mask) \
-	ODM_GetRFReg(odm, e_rf_path, reg_addr, bit_mask)
-
-#define odm_set_rf_reg(odm, e_rf_path, reg_addr, bit_mask, data) \
-	ODM_SetRFReg(odm, e_rf_path, reg_addr, bit_mask, data)
-
-#define odm_get_bb_reg(odm, reg_addr, bit_mask) \
-	ODM_GetBBReg(odm, reg_addr, bit_mask)
-
-#define odm_set_bb_reg(odm, reg_addr, bit_mask, data) \
-	ODM_SetBBReg(odm, reg_addr, bit_mask, data)
-
-void phy_active_large_power_detection_8188f(
-	DM_ODM_T *p_dm_odm
-)
-{
-	u8	i = 1, j = 0, retrycnt = 2;
-	u32	threshold_psd = 56, tmp_psd = 0, tmp_psd_db = 0, rf_mode;
-
-	u32 ADDA_REG[IQK_ADDA_REG_NUM] = {
-		REG_FPGA0_XCD_SWITCH_CONTROL, REG_BLUE_TOOTH,
-		REG_RX_WAIT_CCA, REG_TX_CCK_RFON,
-		REG_TX_CCK_BBON, REG_TX_OFDM_RFON,
-		REG_TX_OFDM_BBON, REG_TX_TO_RX,
-		REG_TX_TO_TX, REG_RX_CCK,
-		REG_RX_OFDM, REG_RX_WAIT_RIFS,
-		REG_RX_TO_RX, REG_STANDBY,
-		REG_SLEEP, REG_PMPD_ANAEN
-	};
-	u32 IQK_MAC_REG[IQK_MAC_REG_NUM] = {
-		REG_TXPAUSE, REG_BCN_CTRL,
-		REG_BCN_CTRL_1, REG_GPIO_MUXCFG
-	};
-
-	/* since 92C & 92D have the different define in IQK_BB_REG */
-	u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
-		REG_OFDM_0_TRX_PATH_ENABLE, REG_OFDM_0_TR_MUX_PAR,
-		REG_FPGA0_XCD_RF_INTERFACE_SW, REG_CONFIG_ANT_A, REG_CONFIG_ANT_B,
-		REG_FPGA0_XAB_RF_INTERFACE_SW, REG_FPGA0_XA_RF_INTERFACE_OE,
-		REG_FPGA0_XB_RF_INTERFACE_OE, REG_FPGA0_RFMOD
-	};
-
-	BOOLEAN goout = FALSE;
-
-	_phy_save_adda_registers8188f(p_dm_odm, ADDA_REG, p_dm_odm->RFCalibrateInfo.ADDA_backup, IQK_ADDA_REG_NUM);
-	_phy_save_mac_registers8188f(p_dm_odm, IQK_MAC_REG, p_dm_odm->RFCalibrateInfo.IQK_MAC_backup);
-	_phy_save_adda_registers8188f(p_dm_odm, IQK_BB_REG_92C, p_dm_odm->RFCalibrateInfo.IQK_BB_backup, IQK_BB_REG_NUM);
-
-	_phy_path_adda_on8188f(p_dm_odm, ADDA_REG, TRUE, FALSE);
-
-	rf_mode = odm_get_rf_reg(p_dm_odm, RF_PATH_A, 0x0, RFREGOFFSETMASK);
-	/*ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]Original RF mode = 0x%x\n", odm_get_rf_reg(p_dm_odm, ODM_RF_PATH_A, 0x0, RFREGOFFSETMASK)));*/
-
-	do {
-		switch (i) {
-		case 1: /*initial setting*/
-			ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]Loopback test Start!!\n"));
-			odm_set_bb_reg(p_dm_odm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
-			odm_set_rf_reg(p_dm_odm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm_odm, RF_PATH_A, RF_RCK_OS, RFREGOFFSETMASK, 0x28000);
-			odm_set_rf_reg(p_dm_odm, RF_PATH_A, RF_TXPA_G1, RFREGOFFSETMASK, 0x0000f);
-			odm_set_rf_reg(p_dm_odm, RF_PATH_A, RF_TXPA_G2, RFREGOFFSETMASK, 0x3fffe);
-			odm_set_rf_reg(p_dm_odm, RF_PATH_A, RF_DBG_LP_RX2, 0x00800, 0x1);
-			odm_set_rf_reg(p_dm_odm, RF_PATH_A, 0x56, 0x00fff, 0x67);
-
-			odm_set_bb_reg(p_dm_odm, REG_OFDM_0_TRX_PATH_ENABLE, MASKDWORD, 0x03a05600);
-			odm_set_bb_reg(p_dm_odm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800e4);
-			odm_set_bb_reg(p_dm_odm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x25204000);
-
-			odm_set_bb_reg(p_dm_odm, REG_FPGA0_IQK, MASKH3BYTES, 0x808000);
-			odm_set_bb_reg(p_dm_odm, REG_TX_IQK, MASKDWORD, 0x80007C00);	/*set two tone*/
-			odm_set_bb_reg(p_dm_odm, REG_RX_IQK, MASKDWORD, 0x01004800);
-			odm_set_bb_reg(p_dm_odm, REG_TX_IQK_TONE_A, MASKDWORD, 0x30008c1c);
-			odm_set_bb_reg(p_dm_odm, REG_RX_IQK_TONE_A, MASKDWORD, 0x10009c1c);
-			odm_set_bb_reg(p_dm_odm, REG_TX_IQK_PI_A, MASKDWORD, 0x82160000);
-			odm_set_bb_reg(p_dm_odm, REG_RX_IQK_PI_A, MASKDWORD, 0x2815200f);
-			odm_set_bb_reg(p_dm_odm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a910);
-
-			odm_set_bb_reg(p_dm_odm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
-			odm_set_bb_reg(p_dm_odm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
-			ODM_delay_ms(IQK_DELAY_TIME_8188F);
-
-			if (odm_get_bb_reg(p_dm_odm, 0xea0, MASKDWORD) <= 0xa) {
-
-				ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]Skip Activation due to abnormal 0xea0 value (0x%x)\n", odm_get_bb_reg(p_dm_odm, 0xea0, MASKDWORD)));
-				goout = TRUE;
-				break;
-
-			} else {
-				tmp_psd = 3 * (phy_psd_log2base(odm_get_bb_reg(p_dm_odm, 0xea0, MASKDWORD)));
-				tmp_psd_db = tmp_psd / 100;
-
-				ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]0xea0 = 0x%x, tmp_PSD_dB = %d, (criterion = %d)\n", odm_get_bb_reg(p_dm_odm, 0xea0, MASKDWORD), tmp_psd_db, threshold_psd));
-
-				i = 2;
-				break;
-			}
-
-		case 2: /*check PSD*/
-			if (tmp_psd_db < threshold_psd) {
-
-				if (j < retrycnt) {
-					ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]Activation Start!!\n"));
-					odm_set_bb_reg(p_dm_odm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
-					odm_set_bb_reg(p_dm_odm, 0x88c, BIT(20)|BIT(21), 0x3);
-					odm_set_rf_reg(p_dm_odm, RF_PATH_A, 0x58, 0x2, 0x1);
-					/*ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]RF mode before set = %x\n", odm_get_rf_reg(p_dm_odm, ODM_RF_PATH_A, 0x0, RFREGOFFSETMASK)));*/
-					odm_set_rf_reg(p_dm_odm, RF_PATH_A, 0x0, 0xf001f, 0x2001f);
-					ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]set RF 0x0 = %x\n", odm_get_rf_reg(p_dm_odm, RF_PATH_A, 0x0, RFREGOFFSETMASK)));
-					ODM_delay_ms(200);
-					odm_set_rf_reg(p_dm_odm, RF_PATH_A, 0x0, RFREGOFFSETMASK, rf_mode);
-					odm_set_rf_reg(p_dm_odm, RF_PATH_A, 0x58, 0x2, 0x0);
-					odm_set_bb_reg(p_dm_odm, 0x88c, BIT(20)|BIT(21), 0x0);
-					ODM_delay_ms(100);
-					i = 1;
-					j++;
-					break;
-
-					} else {
-						ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]Activation fail!!!\n"));
-						goout = TRUE;
-						break;
-					}
-				} else {
-					ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]No need Activation!!!\n"));
-					goout = TRUE;
-					break;
-				}
-
-		}
-	} while (!goout);
-
-		odm_set_bb_reg(p_dm_odm, REG_TX_IQK, MASKDWORD, 0x01007C00);
-		odm_set_bb_reg(p_dm_odm, REG_FPGA0_IQK, MASKH3BYTES, 0x000000);
-		odm_set_rf_reg(p_dm_odm, RF_PATH_A, RF_DBG_LP_RX2, 0x00800, 0x0);
-		odm_set_rf_reg(p_dm_odm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);
-		odm_set_rf_reg(p_dm_odm, RF_PATH_A, 0x0, RFREGOFFSETMASK, rf_mode);
-		ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]Reload RF mode = 0x%x\n", odm_get_rf_reg(p_dm_odm, RF_PATH_A, 0x0, RFREGOFFSETMASK)));
-
-		_phy_reload_adda_registers8188f(p_dm_odm, ADDA_REG, p_dm_odm->RFCalibrateInfo.ADDA_backup, IQK_ADDA_REG_NUM);
-		_phy_reload_mac_registers8188f(p_dm_odm, IQK_MAC_REG, p_dm_odm->RFCalibrateInfo.IQK_MAC_backup);
-		_phy_reload_adda_registers8188f(p_dm_odm, IQK_BB_REG_92C, p_dm_odm->RFCalibrateInfo.IQK_BB_backup, IQK_BB_REG_NUM);
-
-		ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[Act_Large_PWR]Activation process finish!!!\n"));
-
-}
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halphyrf_8188f.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halphyrf_8188f.h
deleted file mode 100644
index 325ed42b67d1..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/halphyrf_8188f.h
+++ /dev/null
@@ -1,138 +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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef __HAL_PHY_RF_8188F_H__
-#define __HAL_PHY_RF_8188F_H__
-
-
-/*--------------------------Define Parameters-------------------------------*/
-#define	IQK_DELAY_TIME_8188F		25		/* ms */
-#define	IQK_DEFERRED_TIME_8188F		4
-#define	index_mapping_NUM_8188F		15
-#define	AVG_THERMAL_NUM_8188F		4
-#define	RF_T_METER_8188F			0x42
-
-
-void ConfigureTxpowerTrack_8188F(
-	PTXPWRTRACK_CFG	pConfig
-	);
-
-void DoIQK_8188F(
-	PVOID		pDM_VOID,
-	u1Byte 		DeltaThermalIndex,
-	u1Byte		ThermalValue,	
-	u1Byte 		Threshold
-	);
-
-VOID
-ODM_TxPwrTrackSetPwr_8188F(
-	IN	PVOID		pDM_VOID,
-	PWRTRACK_METHOD 	Method,
-	u1Byte 				RFPath,
-	u1Byte 				ChannelMappedIndex
-	);
-
-//1 7.	IQK
-
-void	
-PHY_IQCalibrate_8188F(	
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm,
-#else
-	IN PADAPTER	Adapter,
-#endif
-	IN	BOOLEAN 	bReCovery,
-	IN	BOOLEAN 	bRestore);
-
-
-//
-// LC calibrate
-//
-void	
-PHY_LCCalibrate_8188F(
-	IN	PVOID		pDM_VOID
-);
-
-//
-// AP calibrate
-//
-void	
-PHY_APCalibrate_8188F(		
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm,
-#else
-	IN	PADAPTER	pAdapter,
-#endif
-							IN 	s1Byte		delta);
-void	
-PHY_DigitalPredistortion_8188F(		IN	PADAPTER	pAdapter);
-
-
-VOID
-_PHY_SaveADDARegisters_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm,
-#else
-	IN	PADAPTER	pAdapter,
-#endif
-	IN	pu4Byte		ADDAReg,
-	IN	pu4Byte		ADDABackup,
-	IN	u4Byte		RegisterNum
-	);
-
-VOID
-_PHY_PathADDAOn_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm,
-#else
-	IN	PADAPTER	pAdapter,
-#endif
-	IN	pu4Byte		ADDAReg,
-	IN	BOOLEAN		isPathAOn,
-	IN	BOOLEAN		is2T
-	);
-
-VOID
-_PHY_MACSettingCalibration_8188F(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm,
-#else
-	IN	PADAPTER	pAdapter,
-#endif
-	IN	pu4Byte		MACReg,
-	IN	pu4Byte		MACBackup	
-	);
-
-
-VOID
-_PHY_PathAStandBy(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	IN PDM_ODM_T		pDM_Odm
-#else
-	IN	PADAPTER	pAdapter
-#endif
-	);
-
-void phy_active_large_power_detection_8188f(
-	DM_ODM_T *p_dm_odm
-);
-								
-#endif	// #ifndef __HAL_PHY_RF_8188E_H__								
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.c
index e7c8716ce4df..275f854106e5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,223 +12,212 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
-#if (RTL8188F_SUPPORT == 1)  
+#if (RTL8188F_SUPPORT == 1)
 
 void
-odm_ConfigRFReg_8188F(
-	IN 	PDM_ODM_T 				pDM_Odm,
-	IN 	u4Byte 					Addr,
-	IN 	u4Byte 					Data,
-	IN  ODM_RF_RADIO_PATH_E     RF_PATH,
-	IN	u4Byte				    RegAddr
-	)
+odm_config_rf_reg_8188f(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data,
+	enum rf_path     RF_PATH,
+	u32				    reg_addr
+)
 {
-    if(Addr == 0xfe || Addr == 0xffe)
-	{ 					  
-		#ifdef CONFIG_LONG_DELAY_ISSUE
+	if (addr == 0xfe || addr == 0xffe) {
+#ifdef CONFIG_LONG_DELAY_ISSUE
 		ODM_sleep_ms(50);
-		#else		
+#else
 		ODM_delay_ms(50);
-		#endif
-	}
-	else
-	{
-		ODM_SetRFReg(pDM_Odm, RF_PATH, RegAddr, bRFRegOffsetMask, Data);
-		// Add 1us delay between BB/RF register setting.
+#endif
+	} else {
+		odm_set_rf_reg(dm, RF_PATH, reg_addr, RFREGOFFSETMASK, data);
+		/* Add 1us delay between BB/RF register setting. */
 		ODM_delay_us(1);
 
-		//For disable/enable test in high temperature, the B6 value will fail to fill. Suggestion by BB Stanley, 2013.06.25.
-		if(Addr == 0xb6)
-		{
-			u4Byte getvalue=0;
-			u1Byte	count =0;
-			getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);	
+		/* For disable/enable test in high temperature, the B6 value will fail to fill. Suggestion by BB Stanley, 2013.06.25. */
+		if (addr == 0xb6) {
+			u32 getvalue = 0;
+			u8	count = 0;
+			getvalue = odm_get_rf_reg(dm, RF_PATH, addr, MASKDWORD);
 
 			ODM_delay_us(1);
-			
-			while((getvalue>>8)!=(Data>>8))
-			{
+
+			while ((getvalue >> 8) != (data >> 8)) {
 				count++;
-				ODM_SetRFReg(pDM_Odm, RF_PATH, RegAddr, bRFRegOffsetMask, Data);
+				odm_set_rf_reg(dm, RF_PATH, reg_addr, RFREGOFFSETMASK, data);
 				ODM_delay_us(1);
-				getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [B6] getvalue 0x%x, Data 0x%x, count %d\n", getvalue, Data,count));			
-				if(count>5)
+				getvalue = odm_get_rf_reg(dm, RF_PATH, addr, MASKDWORD);
+				PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_rf_with_header_file: [B6] getvalue 0x%x, data 0x%x, count %d\n", getvalue, data, count);
+				if (count > 5)
 					break;
 			}
 		}
 
-		if(Addr == 0xb2)
-		{
-			u4Byte getvalue=0;
-			u1Byte	count =0;
-			getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);	
+		if (addr == 0xb2) {
+			u32 getvalue = 0;
+			u8	count = 0;
+			getvalue = odm_get_rf_reg(dm, RF_PATH, addr, MASKDWORD);
 
 			ODM_delay_us(1);
-			
-			while(getvalue!=Data)
-			{
+
+			while (getvalue != data) {
 				count++;
-				ODM_SetRFReg(pDM_Odm, RF_PATH, RegAddr, bRFRegOffsetMask, Data);
+				odm_set_rf_reg(dm, RF_PATH, reg_addr, RFREGOFFSETMASK, data);
 				ODM_delay_us(1);
-				//Do LCK againg 
-				ODM_SetRFReg(pDM_Odm, RF_PATH, 0x18, bRFRegOffsetMask, 0x0fc07);
+				/* Do LCK againg */
+				odm_set_rf_reg(dm, RF_PATH, 0x18, RFREGOFFSETMASK, 0x0fc07);
 				ODM_delay_us(1);
-				getvalue = ODM_GetRFReg(pDM_Odm, RF_PATH, Addr, bMaskDWord);
-				ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [B2] getvalue 0x%x, Data 0x%x, count %d\n", getvalue, Data,count));			
-				if(count>5)
+				getvalue = odm_get_rf_reg(dm, RF_PATH, addr, MASKDWORD);
+				PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_rf_with_header_file: [B2] getvalue 0x%x, data 0x%x, count %d\n", getvalue, data, count);
+				if (count > 5)
 					break;
 			}
-		}			
-	}	
+		}
+	}
 }
 
 
-void 
-odm_ConfigRF_RadioA_8188F(
-	IN 	PDM_ODM_T 				pDM_Odm,
-	IN 	u4Byte 					Addr,
-	IN 	u4Byte 					Data
-	)
+void
+odm_config_rf_radio_a_8188f(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+)
 {
-	u4Byte  content = 0x1000; // RF_Content: radioa_txt
-	u4Byte	maskforPhySet= (u4Byte)(content&0xE000);
+	u32  content = 0x1000; /* RF_Content: radioa_txt */
+	u32	maskfor_phy_set = (u32)(content & 0xE000);
 
-    odm_ConfigRFReg_8188F(pDM_Odm, Addr, Data, ODM_RF_PATH_A, Addr|maskforPhySet);
+	odm_config_rf_reg_8188f(dm, addr, data, RF_PATH_A, addr | maskfor_phy_set);
 
-    ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [RadioA] %08X %08X\n", Addr, Data));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_rf_with_header_file: [RadioA] %08X %08X\n", addr, data);
 }
 
-void 
-odm_ConfigRF_RadioB_8188F(
-	IN 	PDM_ODM_T 				pDM_Odm,
-	IN 	u4Byte 					Addr,
-	IN 	u4Byte 					Data
-	)
+void
+odm_config_rf_radio_b_8188f(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+)
 {
-	u4Byte  content = 0x1001; // RF_Content: radiob_txt
-	u4Byte	maskforPhySet= (u4Byte)(content&0xE000);
+	u32  content = 0x1001; /* RF_Content: radiob_txt */
+	u32	maskfor_phy_set = (u32)(content & 0xE000);
+
+	odm_config_rf_reg_8188f(dm, addr, data, RF_PATH_B, addr | maskfor_phy_set);
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_rf_with_header_file: [RadioB] %08X %08X\n", addr, data);
 
-    odm_ConfigRFReg_8188F(pDM_Odm, Addr, Data, ODM_RF_PATH_B, Addr|maskforPhySet);
-	
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigRFWithHeaderFile: [RadioB] %08X %08X\n", Addr, Data));
-    
 }
 
-void 
-odm_ConfigMAC_8188F(
- 	IN 	PDM_ODM_T 	pDM_Odm,
- 	IN 	u4Byte 		Addr,
- 	IN 	u1Byte 		Data
- 	)
+void
+odm_config_mac_8188f(
+	struct dm_struct	*dm,
+	u32		addr,
+	u8		data
+)
 {
-	ODM_Write1Byte(pDM_Odm, Addr, Data);
-    ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigMACWithHeaderFile: [MAC_REG] %08X %08X\n", Addr, Data));
+	odm_write_1byte(dm, addr, data);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_mac_with_header_file: [MAC_REG] %08X %08X\n", addr, data);
 }
 
-void 
-odm_ConfigBB_AGC_8188F(
-    IN 	PDM_ODM_T 	pDM_Odm,
-    IN 	u4Byte 		Addr,
-    IN 	u4Byte 		Bitmask,
-    IN 	u4Byte 		Data
-    )
+void
+odm_config_bb_agc_8188f(
+	struct dm_struct	*dm,
+	u32		addr,
+	u32		bitmask,
+	u32		data
+)
 {
-	ODM_SetBBReg(pDM_Odm, Addr, Bitmask, Data);		
-	// Add 1us delay between BB/RF register setting.
+	odm_set_bb_reg(dm, addr, bitmask, data);
+	/* Add 1us delay between BB/RF register setting. */
 	ODM_delay_us(1);
 
-    ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigBBWithHeaderFile: [AGC_TAB] %08X %08X\n", Addr, Data));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_bb_with_header_file: [AGC_TAB] %08X %08X\n", addr, data);
 }
 
 void
-odm_ConfigBB_PHY_REG_PG_8188F(
-	IN 	PDM_ODM_T 	pDM_Odm,
-	IN	u4Byte		Band,
-	IN	u4Byte		RfPath,
-	IN	u4Byte		TxNum,
-    IN 	u4Byte 		Addr,
-    IN 	u4Byte 		Bitmask,
-    IN 	u4Byte 		Data
-    )
-
-{    
-	if (Addr == 0xfe || Addr == 0xffe)
-		#ifdef CONFIG_LONG_DELAY_ISSUE
+odm_config_bb_phy_reg_pg_8188f(
+	struct dm_struct	*dm,
+	u32		band,
+	u32		rf_path,
+	u32		tx_num,
+	u32		addr,
+	u32		bitmask,
+	u32		data
+)
+
+{
+	if (addr == 0xfe || addr == 0xffe)
+#ifdef CONFIG_LONG_DELAY_ISSUE
 		ODM_sleep_ms(50);
-		#else		
+#else
 		ODM_delay_ms(50);
-		#endif
-    else 
-    {
-#if	!(DM_ODM_SUPPORT_TYPE&ODM_AP)
-	    PHY_StoreTxPowerByRate(pDM_Odm->Adapter, Band, RfPath, TxNum, Addr, Bitmask, Data);
 #endif
-    }
-	ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_LOUD, ("===> ODM_ConfigBBWithHeaderFile: [PHY_REG] %08X %08X %08X\n", Addr, Bitmask, Data));
+	else {
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE)
+		phy_store_tx_power_by_rate(dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		PHY_StoreTxPowerByRate((PADAPTER)dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
+#endif
+	}
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_bb_with_header_file: [PHY_REG] %08X %08X %08X\n", addr, bitmask, data);
 }
 
-void 
-odm_ConfigBB_PHY_8188F(
-	IN 	PDM_ODM_T 	pDM_Odm,
-    IN 	u4Byte 		Addr,
-    IN 	u4Byte 		Bitmask,
-    IN 	u4Byte 		Data
-    )
-{    
-	if (Addr == 0xfe)
-		#ifdef CONFIG_LONG_DELAY_ISSUE
+void
+odm_config_bb_phy_8188f(
+	struct dm_struct	*dm,
+	u32		addr,
+	u32		bitmask,
+	u32		data
+)
+{
+	if (addr == 0xfe)
+#ifdef CONFIG_LONG_DELAY_ISSUE
 		ODM_sleep_ms(50);
-		#else		
+#else
 		ODM_delay_ms(50);
-		#endif
-	else if (Addr == 0xfd)
+#endif
+	else if (addr == 0xfd)
 		ODM_delay_ms(5);
-	else if (Addr == 0xfc)
+	else if (addr == 0xfc)
 		ODM_delay_ms(1);
-	else if (Addr == 0xfb)
+	else if (addr == 0xfb)
 		ODM_delay_us(50);
-	else if (Addr == 0xfa)
+	else if (addr == 0xfa)
 		ODM_delay_us(5);
-	else if (Addr == 0xf9)
+	else if (addr == 0xf9)
 		ODM_delay_us(1);
-	else 
-	{
-		ODM_SetBBReg(pDM_Odm, Addr, Bitmask, Data);		
-	}
-	
-	// Add 1us delay between BB/RF register setting.
+	else
+		odm_set_bb_reg(dm, addr, bitmask, data);
+
+	/* Add 1us delay between BB/RF register setting. */
 	ODM_delay_us(1);
-    ODM_RT_TRACE(pDM_Odm,ODM_COMP_INIT, ODM_DBG_TRACE, ("===> ODM_ConfigBBWithHeaderFile: [PHY_REG] %08X %08X\n", Addr, Data));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> odm_config_bb_with_header_file: [PHY_REG] %08X %08X\n", addr, data);
 }
 
 void
-odm_ConfigBB_TXPWR_LMT_8188F(
-	IN	PDM_ODM_T	pDM_Odm,
-	IN	pu1Byte		Regulation,
-	IN	pu1Byte		Band,
-	IN	pu1Byte		Bandwidth,
-	IN	pu1Byte		RateSection,
-	IN	pu1Byte		RfPath,
-	IN	pu1Byte 	Channel,
-	IN	pu1Byte		PowerLimit
-	)
-{	
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		PHY_SetTxPowerLimit(pDM_Odm, Regulation, Band,
-			Bandwidth, RateSection, RfPath, Channel, PowerLimit);
+odm_config_bb_txpwr_lmt_8188f(
+	struct dm_struct	*dm,
+	u8		*regulation,
+	u8		*band,
+	u8		*bandwidth,
+	u8		*rate_section,
+	u8		*rf_path,
+	u8	*channel,
+	u8		*power_limit
+)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	phy_set_tx_power_limit(dm, regulation, band,
+		       bandwidth, rate_section, rf_path, channel, power_limit);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PHY_SetTxPowerLimit(dm, regulation, band,
+		       bandwidth, rate_section, rf_path, channel, power_limit);
 #endif
 }
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.h
index 106e6ab90a7f..a3781a929d38 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_regconfig8188f.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,86 +12,80 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __INC_ODM_REGCONFIG_H_8188F
 #define __INC_ODM_REGCONFIG_H_8188F
- 
+
 #if (RTL8188F_SUPPORT == 1)
 
 void
-odm_ConfigRFReg_8188F(
-	IN 	PDM_ODM_T 				pDM_Odm,
-	IN 	u4Byte 					Addr,
-	IN 	u4Byte 					Data,
-	IN  ODM_RF_RADIO_PATH_E     RF_PATH,
-	IN	u4Byte				    RegAddr
-	);
+odm_config_rf_reg_8188f(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data,
+	enum rf_path     RF_PATH,
+	u32				    reg_addr
+);
 
-void 
-odm_ConfigRF_RadioA_8188F(
-	IN 	PDM_ODM_T 				pDM_Odm,
-	IN 	u4Byte 					Addr,
-	IN 	u4Byte 					Data
-	);
+void
+odm_config_rf_radio_a_8188f(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+);
 
-void 
-odm_ConfigRF_RadioB_8188F(
-	IN 	PDM_ODM_T 				pDM_Odm,
-	IN 	u4Byte 					Addr,
-	IN 	u4Byte 					Data
-	);
+void
+odm_config_rf_radio_b_8188f(
+	struct dm_struct				*dm,
+	u32					addr,
+	u32					data
+);
 
-void 
-odm_ConfigMAC_8188F(
- 	IN 	PDM_ODM_T 	pDM_Odm,
- 	IN 	u4Byte 		Addr,
- 	IN 	u1Byte 		Data
- 	);
+void
+odm_config_mac_8188f(
+	struct dm_struct	*dm,
+	u32		addr,
+	u8		data
+);
 
-void 
-odm_ConfigBB_AGC_8188F(
-    IN 	PDM_ODM_T 	pDM_Odm,
-    IN 	u4Byte 		Addr,
-    IN 	u4Byte 		Bitmask,
-    IN 	u4Byte 		Data
-    );
+void
+odm_config_bb_agc_8188f(
+	struct dm_struct	*dm,
+	u32		addr,
+	u32		bitmask,
+	u32		data
+);
 
 void
-odm_ConfigBB_PHY_REG_PG_8188F(
-	IN 	PDM_ODM_T 	pDM_Odm,
-	IN	u4Byte		Band,
-	IN	u4Byte		RfPath,
-	IN	u4Byte		TxNum,
-    IN 	u4Byte 		Addr,
-    IN 	u4Byte 		Bitmask,
-    IN 	u4Byte 		Data
-    );
+odm_config_bb_phy_reg_pg_8188f(
+	struct dm_struct	*dm,
+	u32		band,
+	u32		rf_path,
+	u32		tx_num,
+	u32		addr,
+	u32		bitmask,
+	u32		data
+);
 
-void 
-odm_ConfigBB_PHY_8188F(
-	IN 	PDM_ODM_T 	pDM_Odm,
-    IN 	u4Byte 		Addr,
-    IN 	u4Byte 		Bitmask,
-    IN 	u4Byte 		Data
-    );
+void
+odm_config_bb_phy_8188f(
+	struct dm_struct	*dm,
+	u32		addr,
+	u32		bitmask,
+	u32		data
+);
 
 void
-odm_ConfigBB_TXPWR_LMT_8188F(
-	IN 	PDM_ODM_T 	pDM_Odm,
-	IN	pu1Byte		Regulation,
-	IN	pu1Byte		Band,
-	IN	pu1Byte		Bandwidth,
-	IN	pu1Byte		RateSection,
-	IN	pu1Byte		RfPath,
-	IN	pu1Byte 	Channel,
-	IN	pu1Byte		PowerLimit
-    );
+odm_config_bb_txpwr_lmt_8188f(
+	struct dm_struct	*dm,
+	u8		*regulation,
+	u8		*band,
+	u8		*bandwidth,
+	u8		*rate_section,
+	u8		*rf_path,
+	u8	*channel,
+	u8		*power_limit
+);
 
 #endif
-#endif // end of SUPPORT
-
+#endif /* end of SUPPORT */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.c
index 2fcbab4e41bd..512d633446eb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,31 +12,25 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
-//============================================================
-// include files
-//============================================================
+/* ************************************************************
+ * include files
+ * ************************************************************ */
 
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
 #if (RTL8188F_SUPPORT == 1)
 
- s1Byte
+s8
 odm_CCKRSSI_8188F(
-	IN		u1Byte	LNA_idx,
-	IN		u1Byte	VGA_idx
-	)
+	u8	LNA_idx,
+	u8	VGA_idx
+)
 {
-	s1Byte	rx_pwr_all=0x00;
-	switch(LNA_idx)
-	{
+	s8	rx_pwr_all = 0x00;
+	switch (LNA_idx) {
 	case 7:
 		if (VGA_idx <= 27)
 			rx_pwr_all = -100 + 2 * (27 - VGA_idx);
@@ -60,13 +55,4 @@ odm_CCKRSSI_8188F(
 	}
 	return	rx_pwr_all;
 }
-
-#endif		// end if RTL8188F 
-
-
-
-
-
-
-
-
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.h
index 714b78a09a8f..f0d7984f7d24 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/phydm_rtl8188f.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef	__ODM_RTL8188F_H__
 #define __ODM_RTL8188F_H__
 
-s1Byte
+s8
 odm_CCKRSSI_8188F(
-	IN		u1Byte	LNA_idx,
-	IN		u1Byte	VGA_idx
-	);
+	u8	LNA_idx,
+	u8	VGA_idx
+);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/version_rtl8188f.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/version_rtl8188f.h
index bcf778cfba8c..1ab38c07b21a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/version_rtl8188f.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/rtl8188f/version_rtl8188f.h
@@ -1,11 +1,35 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-/*RTL8188F PHY Parameters*/
-/* 
-[Caution] 
-  Since 01/Aug/2015, the commit rules will be simplified. 
-  You do not need to fill up the version.h anymore, 
-  only the maintenance supervisor fills it before formal release.
-*/
-#define	RELEASE_DATE_8188F		20170601
-#define	COMMIT_BY_8188F			"BB_David"
-#define	RELEASE_VERSION_8188F		36
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+/*RTL8188F PHY Parameters*/
+/* 
+[Caution] 
+  Since 01/Aug/2015, the commit rules will be simplified. 
+  You do not need to fill up the version.h anymore, 
+  only the maintenance supervisor fills it before formal release.
+*/
+#define	RELEASE_DATE_8188F		20171204
+#define	COMMIT_BY_8188F			"BB_David"
+#define	RELEASE_VERSION_8188F		38
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.c
index 535a6ff7ef81..b3fe9f364829 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.c
@@ -1,552 +1,553 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for TXBF mechanism
-//
-//============================================================
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-/*Beamforming halcomtxbf API create by YuChen 2015/05*/
-
-VOID
-halComTxbf_beamformInit(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->SupportICType & ODM_RTL8822B)
-		HalTxbf8822B_Init(pDM_Odm);
-}
-
-/*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
-VOID
-halComTxbf_ConfigGtab(
-	IN PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-
-	if (pDM_Odm->SupportICType & ODM_RTL8822B)
-		HalTxbf8822B_ConfigGtab(pDM_Odm);
-}
-
-VOID
-phydm_beamformSetSoundingEnter(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (PlatformIsWorkItemScheduled(&(pTxbfInfo->Txbf_EnterWorkItem)) == FALSE)
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_EnterWorkItem));
-#else
-	halComTxbf_EnterWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID
-phydm_beamformSetSoundingLeave(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (PlatformIsWorkItemScheduled(&(pTxbfInfo->Txbf_LeaveWorkItem)) == FALSE)
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_LeaveWorkItem));
-#else
-	halComTxbf_LeaveWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID
-phydm_beamformSetSoundingRate(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (PlatformIsWorkItemScheduled(&(pTxbfInfo->Txbf_RateWorkItem)) == FALSE)
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_RateWorkItem));
-#else
-	halComTxbf_RateWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID
-phydm_beamformSetSoundingStatus(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (PlatformIsWorkItemScheduled(&(pTxbfInfo->Txbf_StatusWorkItem)) == FALSE)
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_StatusWorkItem));
-#else
-	halComTxbf_StatusWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID
-phydm_beamformSetSoundingFwNdpa(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (*pDM_Odm->pbFwDwRsvdPageInProgress)
-		ODM_SetTimer(pDM_Odm, &(pTxbfInfo->Txbf_FwNdpaTimer), 5);
-	else
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_FwNdpaWorkItem));
-#else
-	halComTxbf_FwNdpaWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID
-phydm_beamformSetSoundingClk(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (PlatformIsWorkItemScheduled(&(pTxbfInfo->Txbf_ClkWorkItem)) == FALSE)
-			PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_ClkWorkItem));
-#elif(DM_ODM_SUPPORT_TYPE == ODM_CE)
-	PADAPTER	padapter = pDM_Odm->Adapter;
-
-	rtw_run_in_thread_cmd(padapter, halComTxbf_ClkWorkItemCallback, padapter);
-#else
-	halComTxbf_ClkWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID
-phydm_beamformSetResetTxPath(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (PlatformIsWorkItemScheduled(&(pTxbfInfo->Txbf_ResetTxPathWorkItem)) == FALSE)
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_ResetTxPathWorkItem));
-#else
-	halComTxbf_ResetTxPathWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID
-phydm_beamformSetGetTxRate(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	if (PlatformIsWorkItemScheduled(&(pTxbfInfo->Txbf_GetTxRateWorkItem)) == FALSE)
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_GetTxRateWorkItem));
-#else
-	halComTxbf_GetTxRateWorkItemCallback(pDM_Odm);
-#endif
-}
-
-VOID 
-halComTxbf_EnterWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-	u1Byte			Idx = pTxbfInfo->TXBFIdx;
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-	
-	if (pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8821))
-		HalTxbfJaguar_Enter(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8192E)
-		HalTxbf8192E_Enter(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		HalTxbf8814A_Enter(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8821B)
-		HalTxbf8821B_Enter(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8822B)
-		HalTxbf8822B_Enter(pDM_Odm, Idx);
-}
-
-VOID 
-halComTxbf_LeaveWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	u1Byte			Idx = pTxbfInfo->TXBFIdx;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8821))
-		HalTxbfJaguar_Leave(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8192E)
-		HalTxbf8192E_Leave(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		HalTxbf8814A_Leave(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8821B)
-		HalTxbf8821B_Leave(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8822B)
-		HalTxbf8822B_Leave(pDM_Odm, Idx);
-}
-
-
-VOID 
-halComTxbf_FwNdpaWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-	u1Byte	Idx = pTxbfInfo->NdpaIdx;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8821))
-		HalTxbfJaguar_FwTxBF(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8192E)
-		HalTxbf8192E_FwTxBF(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		HalTxbf8814A_FwTxBF(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8821B)
-		HalTxbf8821B_FwTxBF(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8822B)
-		HalTxbf8822B_FwTxBF(pDM_Odm, Idx);
-}
-
-VOID
-halComTxbf_ClkWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pDM_Odm->SupportICType & ODM_RTL8812)
-		HalTxbfJaguar_Clk_8812A(pDM_Odm);
-}
-
-
-
-VOID
-halComTxbf_RateWorkItemCallback(	
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-	u1Byte			BW = pTxbfInfo->BW;
-	u1Byte			Rate = pTxbfInfo->Rate;	
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pDM_Odm->SupportICType & ODM_RTL8812)
-		HalTxbf8812A_setNDPArate(pDM_Odm, BW, Rate);
-	else if (pDM_Odm->SupportICType & ODM_RTL8192E)
-		HalTxbf8192E_setNDPArate(pDM_Odm, BW, Rate);
-	else if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		HalTxbf8814A_setNDPArate(pDM_Odm, BW, Rate);
-	
-}
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID 
-halComTxbf_FwNdpaTimerCallback(
-	IN	PRT_TIMER		pTimer
-	)
-{
-
-	PADAPTER		Adapter = (PADAPTER)pTimer->Adapter;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (*pDM_Odm->pbFwDwRsvdPageInProgress)
-		ODM_SetTimer(pDM_Odm, &(pTxbfInfo->Txbf_FwNdpaTimer), 5);
-	else
-		PlatformScheduleWorkItem(&(pTxbfInfo->Txbf_FwNdpaWorkItem));
-}
-#endif
-
-
-VOID
-halComTxbf_StatusWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	u1Byte			Idx = pTxbfInfo->TXBFIdx;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pDM_Odm->SupportICType & (ODM_RTL8812|ODM_RTL8821))
-		HalTxbfJaguar_Status(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8192E)
-		HalTxbf8192E_Status(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		HalTxbf8814A_Status(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8821B)
-		HalTxbf8821B_Status(pDM_Odm, Idx);
-	else if (pDM_Odm->SupportICType & ODM_RTL8822B)
-		HalTxbf8822B_Status(pDM_Odm, Idx);
-}
-
-VOID
-halComTxbf_ResetTxPathWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	u1Byte			Idx = pTxbfInfo->TXBFIdx;
-
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		HalTxbf8814A_ResetTxPath(pDM_Odm, Idx);
-	
-}
-
-VOID
-halComTxbf_GetTxRateWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-#else
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#endif
-	
-	if (pDM_Odm->SupportICType & ODM_RTL8814A)
-		HalTxbf8814A_GetTxRate(pDM_Odm);
-}
-
-
-BOOLEAN
-HalComTxbf_Set(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte			setType,
-	IN	PVOID			pInBuf
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PBOOLEAN		pBoolean=(PBOOLEAN)pInBuf;
-	pu1Byte			pU1Tmp=(pu1Byte)pInBuf;
-	pu4Byte			pU4Tmp=(pu4Byte)pInBuf;
-	PHAL_TXBF_INFO	pTxbfInfo = &pDM_Odm->BeamformingInfo.TxbfInfo;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] setType = 0x%X\n", __func__, setType));
-	
-	switch(setType){
-	case TXBF_SET_SOUNDING_ENTER:
-	pTxbfInfo->TXBFIdx = *pU1Tmp;
-	phydm_beamformSetSoundingEnter(pDM_Odm);
-	break;
-
-	case TXBF_SET_SOUNDING_LEAVE:
-	pTxbfInfo->TXBFIdx = *pU1Tmp;
-	phydm_beamformSetSoundingLeave(pDM_Odm);
-	break;
-
-	case TXBF_SET_SOUNDING_RATE:
-	pTxbfInfo->BW = pU1Tmp[0];
-	pTxbfInfo->Rate = pU1Tmp[1];
-	phydm_beamformSetSoundingRate(pDM_Odm);
-	break;
-
-	case TXBF_SET_SOUNDING_STATUS:
-	pTxbfInfo->TXBFIdx = *pU1Tmp;
-	phydm_beamformSetSoundingStatus(pDM_Odm);
-	break;
-
-	case TXBF_SET_SOUNDING_FW_NDPA:
-	pTxbfInfo->NdpaIdx = *pU1Tmp;
-	phydm_beamformSetSoundingFwNdpa(pDM_Odm);
-	break;
-
-	case TXBF_SET_SOUNDING_CLK:
-	phydm_beamformSetSoundingClk(pDM_Odm);
-	break;
-		
-	case TXBF_SET_TX_PATH_RESET:
-	pTxbfInfo->TXBFIdx = *pU1Tmp;
-	phydm_beamformSetResetTxPath(pDM_Odm);
-	break;
-
-	case TXBF_SET_GET_TX_RATE:
-	phydm_beamformSetGetTxRate(pDM_Odm);
-	break;
-	
-	}
-
-	return TRUE;
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-BOOLEAN
-HalComTxbf_Get(
-	IN 	PADAPTER		Adapter,
-	IN	u1Byte			getType,
-	OUT	PVOID			pOutBuf
-	)
-{
-	PHAL_DATA_TYPE		pHalData=GET_HAL_DATA(Adapter);
-	PDM_ODM_T			pDM_Odm = &pHalData->DM_OutSrc;
-	PBOOLEAN			pBoolean=(PBOOLEAN)pOutBuf;
-	ps4Byte				pS4Tmp=(ps4Byte)pOutBuf;
-	pu4Byte				pU4Tmp=(pu4Byte)pOutBuf;
-	pu1Byte				pU1Tmp=(pu1Byte)pOutBuf;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (getType == TXBF_GET_EXPLICIT_BEAMFORMEE) {
-		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(Adapter))
-			*pBoolean = FALSE;
-		else if (/*IS_HARDWARE_TYPE_8822B(Adapter)	||*/
-				IS_HARDWARE_TYPE_8821B(Adapter) 	||
-				IS_HARDWARE_TYPE_8192E(Adapter) 	||
-				IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(Adapter))
-			*pBoolean = TRUE;
-		else
-			*pBoolean = FALSE;
-	} else if (getType == TXBF_GET_EXPLICIT_BEAMFORMER) {
-		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(Adapter))
-			*pBoolean = FALSE;		
-		else	if (/*IS_HARDWARE_TYPE_8822B(Adapter)	||*/
-				IS_HARDWARE_TYPE_8821B(Adapter) 	||
-				IS_HARDWARE_TYPE_8192E(Adapter) 	||
-				IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(Adapter)) {
-			if(pHalData->RF_Type == RF_2T2R || pHalData->RF_Type == RF_3T3R)
-				*pBoolean = TRUE;
-			else
-				*pBoolean = FALSE;
-		} else
-			*pBoolean = FALSE;
-	} else if (getType == TXBF_GET_MU_MIMO_STA) {
-#if (RTL8822B_SUPPORT == 1)
-		if (/*pDM_Odm->SupportICType & (ODM_RTL8822B)*/
-			IS_HARDWARE_TYPE_8822B(Adapter))
-			*pBoolean = TRUE;
-		else
-#endif
-			*pBoolean = FALSE;
-
-
-	} else if (getType == TXBF_GET_MU_MIMO_AP) {
-#if (RTL8822B_SUPPORT == 1)	
-		if (/*pDM_Odm->SupportICType & (ODM_RTL8822B)*/
-			IS_HARDWARE_TYPE_8822B(Adapter))
-			*pBoolean = TRUE;
-		else
-#endif
-			*pBoolean = FALSE;
-	}
-	
-	return TRUE;
-}	
-#endif
-
-
-#endif 
-
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 TXBF mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+/*Beamforming halcomtxbf API create by YuChen 2015/05*/
+
+void
+hal_com_txbf_beamform_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	boolean		is_iqgen_setting_ok = false;
+
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		is_iqgen_setting_ok = phydm_beamforming_set_iqgen_8814A(dm);
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] is_iqgen_setting_ok = %d\n", __func__, is_iqgen_setting_ok);
+	}
+}
+
+/*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
+void
+hal_com_txbf_config_gtab(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_config_gtab(dm);
+}
+
+void
+phydm_beamform_set_sounding_enter(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_enter_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_enter_work_item));
+#else
+	hal_com_txbf_enter_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_leave(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_leave_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_leave_work_item));
+#else
+	hal_com_txbf_leave_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_rate(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_rate_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_rate_work_item));
+#else
+	hal_com_txbf_rate_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_status(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_status_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_status_work_item));
+#else
+	hal_com_txbf_status_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_fw_ndpa(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (*dm->is_fw_dw_rsvd_page_in_progress)
+		odm_set_timer(dm, &(p_txbf_info->txbf_fw_ndpa_timer), 5);
+	else
+		odm_schedule_work_item(&(p_txbf_info->txbf_fw_ndpa_work_item));
+#else
+	hal_com_txbf_fw_ndpa_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_sounding_clk(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_clk_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_clk_work_item));
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	void	*padapter = dm->adapter;
+
+	rtw_run_in_thread_cmd(padapter, hal_com_txbf_clk_work_item_callback, dm);
+#else
+	hal_com_txbf_clk_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_reset_tx_path(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_reset_tx_path_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_reset_tx_path_work_item));
+#else
+	hal_com_txbf_reset_tx_path_work_item_callback(dm);
+#endif
+}
+
+void
+phydm_beamform_set_get_tx_rate(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_get_tx_rate_work_item)) == false)
+		odm_schedule_work_item(&(p_txbf_info->txbf_get_tx_rate_work_item));
+#else
+	hal_com_txbf_get_tx_rate_work_item_callback(dm);
+#endif
+}
+
+void
+hal_com_txbf_enter_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8			idx = p_txbf_info->txbf_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_enter(dm, idx);
+}
+
+void
+hal_com_txbf_leave_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	u8			idx = p_txbf_info->txbf_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_leave(dm, idx);
+}
+
+
+void
+hal_com_txbf_fw_ndpa_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8	idx = p_txbf_info->ndpa_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_fw_txbf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_fw_tx_bf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_fw_txbf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_fw_txbf(dm, idx);
+}
+
+void
+hal_com_txbf_clk_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & ODM_RTL8812)
+		hal_txbf_jaguar_clk_8812a(dm);
+}
+
+
+
+void
+hal_com_txbf_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8			BW = p_txbf_info->BW;
+	u8			rate = p_txbf_info->rate;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & ODM_RTL8812)
+		hal_txbf_8812a_set_ndpa_rate(dm, BW, rate);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_set_ndpa_rate(dm, BW, rate);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_set_ndpa_rate(dm, BW, rate);
+
+}
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+hal_com_txbf_fw_ndpa_timer_callback(
+	struct phydm_timer_list		*timer
+)
+{
+
+	void		*adapter = (void *)timer->Adapter;
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (*dm->is_fw_dw_rsvd_page_in_progress)
+		odm_set_timer(dm, &(p_txbf_info->txbf_fw_ndpa_timer), 5);
+	else
+		odm_schedule_work_item(&(p_txbf_info->txbf_fw_ndpa_work_item));
+}
+#endif
+
+
+void
+hal_com_txbf_status_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	u8			idx = p_txbf_info->txbf_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_status(dm, idx);
+}
+
+void
+hal_com_txbf_reset_tx_path_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	u8			idx = p_txbf_info->txbf_idx;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_reset_tx_path(dm, idx);
+
+}
+
+void
+hal_com_txbf_get_tx_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+#else
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_get_tx_rate(dm);
+}
+
+
+boolean
+hal_com_txbf_set(
+	void			*dm_void,
+	u8			set_type,
+	void			*p_in_buf
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			*p_u1_tmp = (u8 *)p_in_buf;
+	struct _HAL_TXBF_INFO	*p_txbf_info = &dm->beamforming_info.txbf_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] set_type = 0x%X\n", __func__, set_type);
+
+	switch (set_type) {
+	case TXBF_SET_SOUNDING_ENTER:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_enter(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_LEAVE:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_leave(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_RATE:
+		p_txbf_info->BW = p_u1_tmp[0];
+		p_txbf_info->rate = p_u1_tmp[1];
+		phydm_beamform_set_sounding_rate(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_STATUS:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_status(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_FW_NDPA:
+		p_txbf_info->ndpa_idx = *p_u1_tmp;
+		phydm_beamform_set_sounding_fw_ndpa(dm);
+		break;
+
+	case TXBF_SET_SOUNDING_CLK:
+		phydm_beamform_set_sounding_clk(dm);
+		break;
+
+	case TXBF_SET_TX_PATH_RESET:
+		p_txbf_info->txbf_idx = *p_u1_tmp;
+		phydm_beamform_set_reset_tx_path(dm);
+		break;
+
+	case TXBF_SET_GET_TX_RATE:
+		phydm_beamform_set_get_tx_rate(dm);
+		break;
+
+	}
+
+	return true;
+}
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+boolean
+hal_com_txbf_get(
+	void		*adapter,
+	u8			get_type,
+	void			*p_out_buf
+)
+{
+	PHAL_DATA_TYPE		hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct			*dm = &hal_data->DM_OutSrc;
+	boolean			*p_boolean = (boolean *)p_out_buf;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (get_type == TXBF_GET_EXPLICIT_BEAMFORMEE) {
+		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(adapter))
+			*p_boolean = false;
+		else if (/*IS_HARDWARE_TYPE_8822B(adapter)	||*/
+			IS_HARDWARE_TYPE_8821B(adapter)	||
+			IS_HARDWARE_TYPE_8192E(adapter)	||
+			IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
+			*p_boolean = true;
+		else
+			*p_boolean = false;
+	} else if (get_type == TXBF_GET_EXPLICIT_BEAMFORMER) {
+		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(adapter))
+			*p_boolean = false;
+		else	if (/*IS_HARDWARE_TYPE_8822B(adapter)	||*/
+			IS_HARDWARE_TYPE_8821B(adapter)	||
+			IS_HARDWARE_TYPE_8192E(adapter)	||
+			IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter)) {
+			if (hal_data->RF_Type == RF_2T2R || hal_data->RF_Type == RF_3T3R)
+				*p_boolean = true;
+			else
+				*p_boolean = false;
+		} else
+			*p_boolean = false;
+	} else if (get_type == TXBF_GET_MU_MIMO_STA) {
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+		if (IS_HARDWARE_TYPE_8822B(adapter) || IS_HARDWARE_TYPE_8821C(adapter))
+			*p_boolean = true;
+		else
+#endif
+			*p_boolean = false;
+
+
+	} else if (get_type == TXBF_GET_MU_MIMO_AP) {
+#if (RTL8822B_SUPPORT == 1)
+		if (IS_HARDWARE_TYPE_8822B(adapter))
+			*p_boolean = true;
+		else
+#endif
+			*p_boolean = false;
+	}
+
+	return true;
+}
+#endif
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.h
index 610bec3ff0e5..e18110a6ca8e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/halcomtxbf.h
@@ -1,182 +1,204 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __HAL_COM_TXBF_H__
-#define __HAL_COM_TXBF_H__
-
-/*
-typedef	BOOLEAN
-(*TXBF_GET)(
-	IN	PVOID			pAdapter,
-	IN	u1Byte			getType,
-	OUT	PVOID			pOutBuf
-	);
-
-typedef	BOOLEAN
-(*TXBF_SET)(
-	IN	PVOID			pAdapter,
-	IN	u1Byte			setType,
-	OUT	PVOID			pInBuf
-	);
-*/
-#define TxBF_Nr(a, b) ((a > b) ? (b) : (a))
-
-typedef enum _TXBF_SET_TYPE{
-	TXBF_SET_SOUNDING_ENTER,
-	TXBF_SET_SOUNDING_LEAVE,
-	TXBF_SET_SOUNDING_RATE,
-	TXBF_SET_SOUNDING_STATUS,
-	TXBF_SET_SOUNDING_FW_NDPA,
-	TXBF_SET_SOUNDING_CLK,
-	TXBF_SET_TX_PATH_RESET,
-	TXBF_SET_GET_TX_RATE
-}TXBF_SET_TYPE,*PTXBF_SET_TYPE;
-
-
-typedef enum _TXBF_GET_TYPE{
-	TXBF_GET_EXPLICIT_BEAMFORMEE,
-	TXBF_GET_EXPLICIT_BEAMFORMER,
-	TXBF_GET_MU_MIMO_STA,
-	TXBF_GET_MU_MIMO_AP
-}TXBF_GET_TYPE,*PTXBF_GET_TYPE;
-
-
-
-//2 HAL TXBF related
-typedef struct _HAL_TXBF_INFO {
-	u1Byte				TXBFIdx;
-	u1Byte				NdpaIdx;
-	u1Byte				BW;
-	u1Byte				Rate;
-
-	RT_TIMER			Txbf_FwNdpaTimer;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)	
-	RT_WORK_ITEM		Txbf_EnterWorkItem;  
-	RT_WORK_ITEM		Txbf_LeaveWorkItem;
-	RT_WORK_ITEM		Txbf_FwNdpaWorkItem;
-	RT_WORK_ITEM		Txbf_ClkWorkItem;
-	RT_WORK_ITEM		Txbf_StatusWorkItem;
-	RT_WORK_ITEM		Txbf_RateWorkItem;
-	RT_WORK_ITEM		Txbf_ResetTxPathWorkItem;
-	RT_WORK_ITEM		Txbf_GetTxRateWorkItem;
-#endif
-
-} HAL_TXBF_INFO, *PHAL_TXBF_INFO;
-
-#if (BEAMFORMING_SUPPORT == 1)
-
-VOID
-halComTxbf_beamformInit(
-	IN PVOID			pDM_VOID
-	);
-
-VOID
-halComTxbf_ConfigGtab(
-	IN PVOID			pDM_VOID
-	);
-
-VOID 
-halComTxbf_EnterWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-VOID 
-halComTxbf_LeaveWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-VOID 
-halComTxbf_FwNdpaWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-VOID
-halComTxbf_ClkWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-VOID
-halComTxbf_ResetTxPathWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-VOID
-halComTxbf_GetTxRateWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-VOID
-halComTxbf_RateWorkItemCallback(	
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-VOID 
-halComTxbf_FwNdpaTimerCallback(
-	IN	PRT_TIMER		pTimer
-	);
-
-VOID
-halComTxbf_StatusWorkItemCallback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	PADAPTER		Adapter
-#else
-	IN PVOID			pDM_VOID
-#endif
-	);
-
-BOOLEAN
-HalComTxbf_Set(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte			setType,
-	IN	PVOID			pInBuf
-	);
-
-BOOLEAN
-HalComTxbf_Get(
-	IN	PADAPTER		Adapter,
-	IN	u1Byte			getType,
-	OUT	PVOID			pOutBuf
-	);
-
-#else
-#define halComTxbf_beamformInit(pDM_VOID)					NULL
-#define halComTxbf_ConfigGtab(pDM_VOID)				NULL
-#define halComTxbf_EnterWorkItemCallback(_Adapter)		NULL
-#define halComTxbf_LeaveWorkItemCallback(_Adapter)		NULL
-#define halComTxbf_FwNdpaWorkItemCallback(_Adapter)		NULL
-#define halComTxbf_ClkWorkItemCallback(_Adapter)			NULL
-#define halComTxbf_RateWorkItemCallback(_Adapter)		NULL
-#define halComTxbf_FwNdpaTimerCallback(_Adapter)		NULL
-#define halComTxbf_StatusWorkItemCallback(_Adapter)		NULL
-#define HalComTxbf_Get(_Adapter, _getType, _pOutBuf)
-
-#endif
-							
-#endif	// #ifndef __HAL_COM_TXBF_H__								
-
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_COM_TXBF_H__
+#define __HAL_COM_TXBF_H__
+
+/*
+typedef	bool
+(*TXBF_GET)(
+	void*			adapter,
+	u8			get_type,
+	void*			p_out_buf
+	);
+
+typedef	bool
+(*TXBF_SET)(
+	void*			adapter,
+	u8			set_type,
+	void*			p_in_buf
+	);
+*/
+
+enum txbf_set_type {
+	TXBF_SET_SOUNDING_ENTER,
+	TXBF_SET_SOUNDING_LEAVE,
+	TXBF_SET_SOUNDING_RATE,
+	TXBF_SET_SOUNDING_STATUS,
+	TXBF_SET_SOUNDING_FW_NDPA,
+	TXBF_SET_SOUNDING_CLK,
+	TXBF_SET_TX_PATH_RESET,
+	TXBF_SET_GET_TX_RATE
+};
+
+
+enum txbf_get_type {
+	TXBF_GET_EXPLICIT_BEAMFORMEE,
+	TXBF_GET_EXPLICIT_BEAMFORMER,
+	TXBF_GET_MU_MIMO_STA,
+	TXBF_GET_MU_MIMO_AP
+};
+
+
+
+/* 2 HAL TXBF related */
+struct _HAL_TXBF_INFO {
+	u8				txbf_idx;
+	u8				ndpa_idx;
+	u8				BW;
+	u8				rate;
+
+	struct phydm_timer_list			txbf_fw_ndpa_timer;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_WORK_ITEM		txbf_enter_work_item;
+	RT_WORK_ITEM		txbf_leave_work_item;
+	RT_WORK_ITEM		txbf_fw_ndpa_work_item;
+	RT_WORK_ITEM		txbf_clk_work_item;
+	RT_WORK_ITEM		txbf_status_work_item;
+	RT_WORK_ITEM		txbf_rate_work_item;
+	RT_WORK_ITEM		txbf_reset_tx_path_work_item;
+	RT_WORK_ITEM		txbf_get_tx_rate_work_item;
+#endif
+
+};
+
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_com_txbf_beamform_init(
+	void			*dm_void
+);
+
+void
+hal_com_txbf_config_gtab(
+	void			*dm_void
+);
+
+void
+hal_com_txbf_enter_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_leave_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_fw_ndpa_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_clk_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_reset_tx_path_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_get_tx_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_rate_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+void
+hal_com_txbf_fw_ndpa_timer_callback(
+	struct phydm_timer_list		*timer
+);
+
+void
+hal_com_txbf_status_work_item_callback(
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void		*adapter
+#else
+	void			*dm_void
+#endif
+);
+
+boolean
+hal_com_txbf_set(
+	void			*dm_void,
+	u8			set_type,
+	void			*p_in_buf
+);
+
+boolean
+hal_com_txbf_get(
+	void		*adapter,
+	u8			get_type,
+	void			*p_out_buf
+);
+
+#else
+#define hal_com_txbf_beamform_init(dm_void)					NULL
+#define hal_com_txbf_config_gtab(dm_void)				NULL
+#define hal_com_txbf_enter_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_leave_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_fw_ndpa_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_clk_work_item_callback(_adapter)			NULL
+#define hal_com_txbf_rate_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_fw_ndpa_timer_callback(_adapter)		NULL
+#define hal_com_txbf_status_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_get(_adapter, _get_type, _pout_buf)
+
+#endif
+
+#endif	/*  #ifndef __HAL_COM_TXBF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.c
index 311f91e3ad36..fdb234de5078 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.c
@@ -1,393 +1,402 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for 8192E TXBF mechanism
-//
-//============================================================
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8192E_SUPPORT == 1)
-
-VOID
-HalTxbf8192E_setNDPArate(
-	IN PVOID			pDM_VOID,
-	IN u1Byte	BW,
-	IN u1Byte	Rate
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	ODM_Write1Byte(pDM_Odm, REG_NDPA_OPT_CTRL_8192E,  (Rate << 2 | BW));	
-
-}
-
-VOID
-halTxbf8192E_RfMode(
-	IN PVOID			pDM_VOID,
-	IN PRT_BEAMFORMING_INFO	pBeamInfo
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	BOOLEAN				bSelfBeamformer = FALSE;
-	BOOLEAN				bSelfBeamformee = FALSE;
-	BEAMFORMING_CAP	BeamformCap = BEAMFORMING_CAP_NONE;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pDM_Odm->RFType == ODM_1T1R)
-		return;
-
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, 0x80000, 0x1); /*RF Mode table write enable*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_WE_LUT, 0x80000, 0x1); /*RF Mode table write enable*/
-	
-	if (pBeamInfo->beamformee_su_cnt > 0) {
-		/*Path_A*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableAddr, 0xfffff, 0x18000);	/*Select RX mode  0x30=0x18000*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData0, 0xfffff, 0x0000f);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
-		/*Path_B*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableAddr, 0xfffff, 0x18000);	/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData0, 0xfffff, 0x0000f);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData1, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
-	} else {
-		/*Path_A*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableAddr, 0xfffff, 0x18000);	/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData0, 0xfffff, 0x0000f);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
-		/*Path_B*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableAddr, 0xfffff, 0x18000);	/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData0, 0xfffff, 0x0000f);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData1, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
-	}
-
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);	/*RF Mode table write disable*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_WE_LUT, 0x80000, 0x0);	/*RF Mode table write disable*/
-
-	if (pBeamInfo->beamformee_su_cnt > 0) {
-		ODM_SetBBReg(pDM_Odm, rFPGA1_TxInfo, bMaskDWord, 0x83321333);
-		ODM_SetBBReg(pDM_Odm, rCCK0_AFESetting, bMaskByte3, 0xc1);
-	} else
-		ODM_SetBBReg(pDM_Odm, rFPGA1_TxInfo, bMaskDWord, 0x81121313);
-}
-
-
-
-VOID
-halTxbf8192E_FwTxBFCmd(
-	IN PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	Idx, Period0 = 0, Period1 = 0;
-	u1Byte	PageNum0 = 0xFF, PageNum1 = 0xFF;
-	u1Byte	u1TxBFParm[3] = {0};
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-		if (pBeamInfo->BeamformeeEntry[Idx].BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (Idx == 0) {
-				if (pBeamInfo->BeamformeeEntry[Idx].bSound)
-					PageNum0 = 0xFE;
-				else
-					PageNum0 = 0xFF; //stop sounding
-				Period0 = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			} else if (Idx == 1) {
-				if (pBeamInfo->BeamformeeEntry[Idx].bSound)
-					PageNum1 = 0xFE;
-				else
-					PageNum1 = 0xFF; //stop sounding
-				Period1 = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			}
-		}
-	}
-
-	u1TxBFParm[0] = PageNum0;
-	u1TxBFParm[1] = PageNum1;
-	u1TxBFParm[2] = (Period1 << 4) | Period0;
-	ODM_FillH2CCmd(pDM_Odm, PHYDM_H2C_TXBF, 3, u1TxBFParm);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, 
-		("[%s] PageNum0 = %d Period0 = %d, PageNum1 = %d Period1 %d\n", __func__, PageNum0, Period0, PageNum1, Period1));
-}
-
-
-VOID
-halTxbf8192E_DownloadNDPA(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			u1bTmp = 0, tmpReg422 = 0, Head_Page;
-	u1Byte			BcnValidReg = 0, count = 0, DLBcnCount = 0;
-	BOOLEAN			bSendBeacon = FALSE;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-	u1Byte			TxPageBndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;	
-	/*default reseved 1 page for the IC type which is undefined.*/
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*pDM_Odm->pbFwDwRsvdPageInProgress = TRUE;
-#endif
-	if (Idx == 0)
-		Head_Page = 0xFE;
-	else
-		Head_Page = 0xFE;
-
-	Adapter->HalFunc.GetHalDefVarHandler(Adapter, HAL_DEF_TX_PAGE_BOUNDARY, (pu1Byte)&TxPageBndy);
-
-	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1bTmp = ODM_Read1Byte(pDM_Odm, REG_CR_8192E+1);
-	ODM_Write1Byte(pDM_Odm,  REG_CR_8192E+1, (u1bTmp | BIT0));
-
-	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmpReg422 = ODM_Read1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8192E+2);
-	ODM_Write1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8192E+2,  tmpReg422 & (~BIT6));
-
-	if (tmpReg422 & BIT6) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_WARNING, ("%s There is an Adapter is sending beacon.\n", __func__));
-		bSendBeacon = TRUE;
-	}
-
-	/*TDECTRL[15:8] 0x209[7:0] = 0xFE/0xFD	NDPA Head for TXDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_DWBCN0_CTRL_8192E+1, Head_Page);
-
-	do {
-		/*Clear beacon valid check bit.*/
-		BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_DWBCN0_CTRL_8192E+2);
-		ODM_Write1Byte(pDM_Odm, REG_DWBCN0_CTRL_8192E+2, (BcnValidReg | BIT0));
-
-		// download NDPA rsvd page.
-		Beamforming_SendHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->SoundBW, BEACON_QUEUE);
-
-#if(DEV_BUS_TYPE == RT_PCI_INTERFACE)
-		u1bTmp = ODM_Read1Byte(pDM_Odm, REG_MGQ_TXBD_NUM_8192E+3);
-		count = 0;
-		while ((count < 20) && (u1bTmp & BIT4)) {
-			count++;
-			ODM_delay_us(10);
-			u1bTmp = ODM_Read1Byte(pDM_Odm, REG_MGQ_TXBD_NUM_8192E+3);
-		}
-		ODM_Write1Byte(pDM_Odm, REG_MGQ_TXBD_NUM_8192E+3, u1bTmp | BIT4);
-#endif
-
-		/*check rsvd page download OK.*/
-		BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_DWBCN0_CTRL_8192E+2);
-		count = 0;
-		while (!(BcnValidReg & BIT0) && count < 20) {
-			count++;
-			ODM_delay_us(10);
-			BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_DWBCN0_CTRL_8192E+2);
-		}
-		DLBcnCount++;
-	} while (!(BcnValidReg & BIT0) && DLBcnCount < 5);
-
-	if (!(BcnValidReg & BIT0))
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_WARNING, ("%s Download RSVD page failed!\n", __func__));
-
-	/*TDECTRL[15:8] 0x209[7:0] = 0xF9	Beacon Head for TXDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_DWBCN0_CTRL_8192E+1, TxPageBndy);
-
-	/*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 (bSendBeacon)
-		ODM_Write1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8192E+2, tmpReg422);
-
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1bTmp = ODM_Read1Byte(pDM_Odm, REG_CR_8192E+1);
-	ODM_Write1Byte(pDM_Odm, REG_CR_8192E+1, (u1bTmp & (~BIT0)));
-
-	pBeamEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSED;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*pDM_Odm->pbFwDwRsvdPageInProgress = FALSE;
-#endif
-}
-
-
-VOID
-HalTxbf8192E_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				BFerBFeeIdx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					i = 0;
-	u1Byte					BFerIdx = (BFerBFeeIdx & 0xF0) >> 4;
-	u1Byte					BFeeIdx = (BFerBFeeIdx & 0xF);
-	u4Byte					CSI_Param;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	u2Byte					STAid = 0;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	halTxbf8192E_RfMode(pDM_Odm, pBeamformingInfo);
-
-	if (pDM_Odm->RFType == ODM_2T2R)
-		ODM_Write4Byte(pDM_Odm, 0xd80, 0x00000000);		/*Nc =2*/
-
-	if ((pBeamformingInfo->beamformer_su_cnt > 0) && (BFerIdx < BEAMFORMER_ENTRY_NUM)) {
-		BeamformerEntry = pBeamformingInfo->BeamformerEntry[BFerIdx];
-
-		/*Sounding protocol control*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8192E, 0xCB);
-
-		/*MAC address/Partial AID of Beamformer*/
-		if (BFerIdx == 0) {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_ASSOCIATED_BFMER0_INFO_8192E+i), BeamformerEntry.MacAddr[i]);
-		} else {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_ASSOCIATED_BFMER1_INFO_8192E+i), BeamformerEntry.MacAddr[i]);
-		}
-
-		/*CSI report parameters of Beamformer Default use Nc = 2*/
-		CSI_Param = 0x03090309;
-
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8192E, CSI_Param);
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW40_8192E, CSI_Param);
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW80_8192E, CSI_Param);
-
-		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8192E+3, 0x50);
-
-	}
-
-	if ((pBeamformingInfo->beamformee_su_cnt > 0) && (BFeeIdx < BEAMFORMEE_ENTRY_NUM)) {
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[BFeeIdx];
-
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-			STAid = BeamformeeEntry.MacId;
-		else
-			STAid = BeamformeeEntry.P_AID;
-
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s], STAid=0x%X\n", __func__, STAid));
-
-		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
-		if (BFeeIdx == 0) {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8192E, STAid);
-			ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8192E+3, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8192E+3) | BIT4 | BIT6 | BIT7);
-		} else
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8192E+2, STAid | BIT12 | BIT14 | BIT15);
-
-		/*CSI report parameters of Beamformee*/
-		if (BFeeIdx == 0) {
-			/*Get BIT24 & BIT25*/
-			u1Byte tmp = ODM_Read1Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8192E+3) & 0x3;
-			
-			ODM_Write1Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8192E+3, tmp | 0x60);
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8192E, STAid | BIT9);
-		} else {
-			/*Set BIT25*/
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, STAid | 0xE200);
-		}
-			phydm_Beamforming_Notify(pDM_Odm);
-
-	}
-}
-
-
-VOID
-HalTxbf8192E_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	halTxbf8192E_RfMode(pDM_Odm, pBeamInfo);
-
-	/*	Clear P_AID of Beamformee
-	* 	Clear MAC addresss of Beamformer
-	*	Clear Associated Bfmee Sel
-	*/
-	if (pBeamInfo->BeamformCap == BEAMFORMING_CAP_NONE)
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8192E, 0xC8);
-
-	if (Idx == 0) {
-		ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8192E, 0);
-		ODM_Write4Byte(pDM_Odm, REG_ASSOCIATED_BFMER0_INFO_8192E, 0);
-		ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMER0_INFO_8192E+4, 0);
-		ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8192E, 0);
-	} else {
-		ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8192E+2, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8192E+2) & 0xF000);
-		ODM_Write4Byte(pDM_Odm, REG_ASSOCIATED_BFMER1_INFO_8192E, 0);
-		ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMER1_INFO_8192E+4, 0);
-		ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, ODM_Read2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8192E+2) & 0x60);
-	}
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Idx %d\n", __func__, Idx));
-}
-
-
-VOID
-HalTxbf8192E_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte					BeamCtrlVal;
-	u4Byte					BeamCtrlReg;
-	PRT_BEAMFORMING_INFO	pBeamInfo =  &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformEntry = pBeamInfo->BeamformeeEntry[Idx];
-
-	if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-		BeamCtrlVal = BeamformEntry.MacId;
-	else
-		BeamCtrlVal = BeamformEntry.P_AID;
-
-	if (Idx == 0)
-		BeamCtrlReg = REG_TXBF_CTRL_8192E;
-	else {
-		BeamCtrlReg = REG_TXBF_CTRL_8192E+2;
-		BeamCtrlVal |= BIT12 | BIT14 | BIT15;
-	}
-
-	if (BeamformEntry.BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-		if (BeamformEntry.SoundBW == CHANNEL_WIDTH_20)
-			BeamCtrlVal |= BIT9;
-		else if (BeamformEntry.SoundBW == CHANNEL_WIDTH_40)
-			BeamCtrlVal |= BIT10;
-	} else
-		BeamCtrlVal &= ~(BIT9 | BIT10 | BIT11);
-
-	ODM_Write2Byte(pDM_Odm, BeamCtrlReg, BeamCtrlVal);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Idx %d BeamCtrlReg %x BeamCtrlVal %x\n", __func__, Idx, BeamCtrlReg, BeamCtrlVal));
-}
-
-
-VOID
-HalTxbf8192E_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pBeamEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		halTxbf8192E_DownloadNDPA(pDM_Odm, Idx);
-
-	halTxbf8192E_FwTxBFCmd(pDM_Odm);
-}
-
-#endif	/* #if (RTL8192E_SUPPORT == 1)*/
-
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8192E TXBF mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (RTL8192E_SUPPORT == 1)
+
+void
+hal_txbf_8192e_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8192E, (rate << 2 | BW));
+
+}
+
+void
+hal_txbf_8192e_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
+
+	if (beam_info->beamformee_su_cnt > 0) {
+		/*Path_A*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*Select RX mode  0x30=0x18000*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
+		/*Path_B*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
+	} else {
+		/*Path_A*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
+		/*Path_B*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
+	}
+
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+
+	if (beam_info->beamformee_su_cnt > 0) {
+		odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x83321333);
+		odm_set_bb_reg(dm, 0xa04, MASKBYTE3, 0xc1);
+	} else
+		odm_set_bb_reg(dm, 0x90c, MASKDWORD, 0x81121313);
+}
+
+
+
+void
+hal_txbf_8192e_fw_txbf_cmd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	idx, period0 = 0, period1 = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (idx == 0) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum0 = 0xFE;
+				else
+					PageNum0 = 0xFF; /* stop sounding */
+				period0 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (idx == 1) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum1 = 0xFE;
+				else
+					PageNum1 = 0xFF; /* stop sounding */
+				period1 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = (period1 << 4) | period0;
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	PHYDM_DBG(dm, DBG_TXBF,
+		"[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n", __func__, PageNum0, period0, PageNum1, period1);
+}
+
+
+void
+hal_txbf_8192e_download_ndpa(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			u1b_tmp = 0, tmp_reg422 = 0, head_page;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	boolean			is_send_beacon = false;
+	u8			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;
+	/*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
+#endif
+	if (idx == 0)
+		head_page = 0xFE;
+	else
+		head_page = 0xFE;
+
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8192E+1);
+	odm_write_1byte(dm,  REG_CR_8192E+1, (u1b_tmp | BIT(0)));
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8192E+2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8192E+2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s There is an adapter is sending beacon.\n", __func__);
+		is_send_beacon = true;
+	}
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xFE/0xFD	NDPA Head for TXDMA*/
+	odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E+1, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E+2);
+		odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E+2, (bcn_valid_reg | BIT(0)));
+
+		/* download NDPA rsvd page. */
+		beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		u1b_tmp = odm_read_1byte(dm, REG_MGQ_TXBD_NUM_8192E+3);
+		count = 0;
+		while ((count < 20) && (u1b_tmp & BIT(4))) {
+			count++;
+			ODM_delay_us(10);
+			u1b_tmp = odm_read_1byte(dm, REG_MGQ_TXBD_NUM_8192E+3);
+		}
+		odm_write_1byte(dm, REG_MGQ_TXBD_NUM_8192E+3, u1b_tmp | BIT(4));
+#endif
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E+2);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(0)) && count < 20) {
+			count++;
+			ODM_delay_us(10);
+			bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E+2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(0)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(0)))
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n", __func__);
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xF9	Beacon Head for TXDMA*/
+	odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E+1, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8192E+2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8192E+1);
+	odm_write_1byte(dm, REG_CR_8192E+1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
+#endif
+}
+
+
+void
+hal_txbf_8192e_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	u32					csi_param;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	u16					sta_id = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	hal_txbf_8192e_rf_mode(dm, beamforming_info);
+
+	if (dm->rf_type == RF_2T2R)
+		odm_write_4byte(dm, 0xd80, 0x00000000);		/*nc =2*/
+
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E, 0xCB);
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (bfer_idx == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8192E+i), beamformer_entry.mac_addr[i]);
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8192E+i), beamformer_entry.mac_addr[i]);
+		}
+
+		/*CSI report parameters of Beamformer Default use nc = 2*/
+		csi_param = 0x03090309;
+
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW20_8192E, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW40_8192E, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW80_8192E, csi_param);
+
+		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E+3, 0x50);
+
+	}
+
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = beamformee_entry.mac_id;
+		else
+			sta_id = beamformee_entry.p_aid;
+
+		PHYDM_DBG(dm, DBG_TXBF, "[%s], sta_id=0x%X\n", __func__, sta_id);
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (bfee_idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8192E, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8192E+3, odm_read_1byte(dm, REG_TXBF_CTRL_8192E+3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8192E+2, sta_id | BIT(12) | BIT(14) | BIT(15));
+
+		/*CSI report parameters of Beamformee*/
+		if (bfee_idx == 0) {
+			/*Get BIT24 & BIT25*/
+			u8 tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+3) & 0x3;
+
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E, sta_id | BIT(9));
+		} else {
+			/*Set BIT25*/
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, sta_id | 0xE200);
+		}
+		phydm_beamforming_notify(dm);
+
+	}
+}
+
+
+void
+hal_txbf_8192e_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	hal_txbf_8192e_rf_mode(dm, beam_info);
+
+	/*	Clear P_AID of Beamformee
+	*	Clear MAC addresss of Beamformer
+	*	Clear Associated Bfmee Sel
+	*/
+	if (beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E, 0xC8);
+
+	if (idx == 0) {
+		odm_write_2byte(dm, REG_TXBF_CTRL_8192E, 0);
+		odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8192E, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8192E+4, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E, 0);
+	} else {
+		odm_write_2byte(dm, REG_TXBF_CTRL_8192E+2, odm_read_1byte(dm, REG_TXBF_CTRL_8192E+2) & 0xF000);
+		odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8192E, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8192E+4, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2) & 0x60);
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] idx %d\n", __func__, idx);
+}
+
+
+void
+hal_txbf_8192e_status(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beam_info =  &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamform_entry = beam_info->beamformee_entry[idx];
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+		beam_ctrl_val = beamform_entry.mac_id;
+	else
+		beam_ctrl_val = beamform_entry.p_aid;
+
+	if (idx == 0)
+		beam_ctrl_reg = REG_TXBF_CTRL_8192E;
+	else {
+		beam_ctrl_reg = REG_TXBF_CTRL_8192E+2;
+		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+	}
+
+	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (beam_info->apply_v_matrix == true)) {
+		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
+			beam_ctrl_val |= BIT(9);
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
+			beam_ctrl_val |= BIT(10);
+	} else
+		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] idx %d beam_ctrl_reg %x beam_ctrl_val %x\n", __func__, idx, beam_ctrl_reg, beam_ctrl_val);
+}
+
+
+void
+hal_txbf_8192e_fw_tx_bf(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_8192e_download_ndpa(dm, idx);
+
+	hal_txbf_8192e_fw_txbf_cmd(dm);
+}
+
+#endif	/* #if (RTL8192E_SUPPORT == 1)*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.h
index 64c4af860041..68ea2d68a649 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8192e.h
@@ -1,53 +1,85 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __HAL_TXBF_8192E_H__
-#define __HAL_TXBF_8192E_H__
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8192E_SUPPORT == 1)
-VOID
-HalTxbf8192E_setNDPArate(
-	IN PVOID			pDM_VOID,
-	IN u1Byte	BW,
-	IN u1Byte	Rate
-);
-
-VOID
-HalTxbf8192E_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8192E_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8192E_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8192E_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-	);
-#else
-
-#define HalTxbf8192E_setNDPArate(pDM_VOID, BW, Rate)
-#define HalTxbf8192E_Enter(pDM_VOID, Idx)
-#define HalTxbf8192E_Leave(pDM_VOID, Idx)
-#define HalTxbf8192E_Status(pDM_VOID, Idx)
-#define HalTxbf8192E_FwTxBF(pDM_VOID, Idx)
-
-#endif
-
-#endif
-
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_8192E_H__
+#define __HAL_TXBF_8192E_H__
+
+#if (RTL8192E_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_txbf_8192e_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+);
+
+void
+hal_txbf_8192e_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8192e_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8192e_status(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8192e_fw_tx_bf(
+	void			*dm_void,
+	u8				idx
+);
+#else
+
+#define hal_txbf_8192e_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8192e_enter(dm_void, idx)
+#define hal_txbf_8192e_leave(dm_void, idx)
+#define hal_txbf_8192e_status(dm_void, idx)
+#define hal_txbf_8192e_fw_tx_bf(dm_void, idx)
+
+#endif
+
+#else
+
+#define hal_txbf_8192e_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8192e_enter(dm_void, idx)
+#define hal_txbf_8192e_leave(dm_void, idx)
+#define hal_txbf_8192e_status(dm_void, idx)
+#define hal_txbf_8192e_fw_tx_bf(dm_void, idx)
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.c
index b47270312b01..bc7ac3776a30 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.c
@@ -1,654 +1,721 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for 8814A TXBF mechanism
-//
-//============================================================
-
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8814A_SUPPORT == 1)
-
-VOID
-HalTxbf8814A_setNDPArate(
-	IN PVOID			pDM_VOID,
-	IN u1Byte	BW,
-	IN u1Byte	Rate
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	ODM_Write1Byte(pDM_Odm, REG_NDPA_OPT_CTRL_8814A, BW);
-	ODM_Write1Byte(pDM_Odm, REG_NDPA_RATE_8814A, (u1Byte) Rate);
-
-}
-
-#define PHYDM_MEMORY_MAP_BUF_READ	0x8000
-#define PHYDM_CTRL_INFO_PAGE			0x660
-
-VOID
-phydm_DataRate_8814A(
-	IN	PDM_ODM_T			pDM_Odm,
-	IN	u1Byte				macId,	
-	OUT	pu4Byte				data,
-	IN	u1Byte				dataLen
-	)
-{
-	u1Byte	i = 0;
-	u2Byte	XReadDataAddr = 0;
-
-	ODM_Write2Byte(pDM_Odm, REG_PKTBUF_DBG_CTRL_8814A, PHYDM_CTRL_INFO_PAGE);
-	XReadDataAddr = PHYDM_MEMORY_MAP_BUF_READ + macId*32; /*Ctrl Info: 32Bytes for each macid(n)*/
-	
-	if ((XReadDataAddr < PHYDM_MEMORY_MAP_BUF_READ) || (XReadDataAddr > 0x8FFF)) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("XReadDataAddr(0x%x) is not correct!\n", XReadDataAddr));
-		return;	
-	}
-	
-	/* Read data */
-	for (i = 0; i < dataLen; i++)
-		*(data+i) = ODM_Read2Byte(pDM_Odm, XReadDataAddr+i);	
-	
-}
-
-VOID
-HalTxbf8814A_GetTxRate(
-	IN PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pEntry;
-	u4Byte	TxRptData = 0;
-	u1Byte	DataRate = 0xFF;
-
-	pEntry = &(pBeamInfo->BeamformeeEntry[pBeamInfo->BeamformeeCurIdx]);
-	
-	phydm_DataRate_8814A(pDM_Odm, (u1Byte)pEntry->MacId, &TxRptData, 1);
-	DataRate = (u1Byte)TxRptData;
-	DataRate &= bMask7bits;   /*Bit7 indicates SGI*/
-
-	pDM_Odm->TxBfDataRate = DataRate;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] pDM_Odm->TxBfDataRate = 0x%x\n", __func__, pDM_Odm->TxBfDataRate));
-}
-
-VOID
-HalTxbf8814A_ResetTxPath(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	u1Byte	Nr_index = 0;
-
-	if (idx < BEAMFORMEE_ENTRY_NUM)
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[idx];
-	else
-		return;
-
-	if ((pDM_Odm->LastUSBHub) != (*pDM_Odm->HubUsbMode)) {
-		Nr_index = TxBF_Nr(halTxbf8814A_GetNtx(pDM_Odm), BeamformeeEntry.CompSteeringNumofBFer);
-
-		if (idx == 0) {
-			switch (Nr_index) {
-			case 0:
-			break;
-
-			case 1:			/*Nsts = 2	BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF0, bMaskByte3LowNibble | bMaskL3Bytes, 0x9366);		/*tx2path, BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x936);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x9360);
-			break;
-
-			case 2:			/*Nsts = 3	BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF0, bMaskByte3LowNibble | bMaskL3Bytes, 0x93e93ee);	/*tx3path, BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93e);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93e93e0);
-			break;
-
-			default:			/*Nr>3, same as Case 3*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF0, bMaskByte3LowNibble | bMaskL3Bytes, 0x93f93ff);	/*tx4path, ABCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93f);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskDWord, 0x93f93f0);
-			break;
-			}
-		} else	{
-			switch (Nr_index) {
-			case 0:
-				break;
-
-			case 1:			/*Nsts = 2	BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, bMaskByte3LowNibble | bMaskL3Bytes, 0x9366);		/*tx2path, BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x936);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x9360);
-			break;
-
-			case 2:			/*Nsts = 3	BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, bMaskByte3LowNibble | bMaskL3Bytes, 0x93e93ee);	/*tx3path, BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93e);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93e93e0);
-			break;
-
-			default:			/*Nr>3, same as Case 3*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, bMaskByte3LowNibble | bMaskL3Bytes, 0x93f93ff);	/*tx4path, ABCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93f);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93f93f0);
-			break;
-			}
-		}
-
-		pDM_Odm->LastUSBHub = *pDM_Odm->HubUsbMode;
-	} else
-		return;
-#endif
-}
-
-
-u1Byte
-halTxbf8814A_GetNtx(
-	IN PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			Ntx = 0;
-
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-	if (pDM_Odm->SupportInterface == ODM_ITRF_USB) {
-		if (*pDM_Odm->HubUsbMode == 2) {/*USB3.0*/
-			if (pDM_Odm->RFType == ODM_4T4R)
-				Ntx = 3;
-			else if (pDM_Odm->RFType == ODM_3T3R)
-				Ntx = 2;
-			else
-				Ntx = 1;
-		} else if (*pDM_Odm->HubUsbMode == 1)	/*USB 2.0 always 2Tx*/
-			Ntx = 1;
-		else
-			Ntx = 1;
-	} else
-#endif
-	{
-		if (pDM_Odm->RFType == ODM_4T4R)
-			Ntx = 3;
-		else if (pDM_Odm->RFType == ODM_3T3R)
-			Ntx = 2;
-		else
-			Ntx = 1;
-	}
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Ntx = %d\n", __func__, Ntx));
-	return Ntx;
-}
-
-u1Byte
-halTxbf8814A_GetNrx(
-	IN PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			Nrx = 0;
-
-	if (pDM_Odm->RFType == ODM_4T4R)
-		Nrx = 3;
-	else if (pDM_Odm->RFType == ODM_3T3R)
-		Nrx = 2;
-	else if (pDM_Odm->RFType == ODM_2T2R)
-		Nrx = 1;
-	else if (pDM_Odm->RFType == ODM_2T3R)
-		Nrx = 2;
-	else if (pDM_Odm->RFType == ODM_2T4R)
-		Nrx = 3;
-	else if (pDM_Odm->RFType == ODM_1T1R)
-		Nrx = 0;
-	else if (pDM_Odm->RFType == ODM_1T2R)
-		Nrx = 1;
-	else
-		Nrx = 0;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Nrx = %d\n", __func__, Nrx));
-	return Nrx;
-}
-
-VOID
-halTxbf8814A_RfMode(
-	IN PVOID			pDM_VOID,
-	IN	PRT_BEAMFORMING_INFO	pBeamformingInfo,
-	IN	u1Byte					idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte				i, Nr_index = 0;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-
-	if (idx < BEAMFORMEE_ENTRY_NUM)
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[idx];
-	else
-		return;
-
-	Nr_index = TxBF_Nr(halTxbf8814A_GetNtx(pDM_Odm), BeamformeeEntry.CompSteeringNumofBFer);
-
-	if (pDM_Odm->RFType == ODM_1T1R)
-		return;
-
-	for (i = ODM_RF_PATH_A; i < MAX_RF_PATH; i++) {
-		ODM_SetRFReg(pDM_Odm, i, RF_WeLut_Jaguar, 0x80000, 0x1);
-		/*RF Mode table write enable*/
-	}
-
-	if (pBeamformingInfo->beamformee_su_cnt > 0) {
-		for (i = ODM_RF_PATH_A; i < MAX_RF_PATH; i++) {
-			ODM_SetRFReg(pDM_Odm, i, RF_ModeTableAddr, 0xfffff, 0x18000);
-			/*Select RX mode*/
-			ODM_SetRFReg(pDM_Odm, i, RF_ModeTableData0, 0xfffff, 0xBE77F);
-			/*Set Table data*/
-			ODM_SetRFReg(pDM_Odm, i, RF_ModeTableData1, 0xfffff, 0x226BF);
-			/*Enable TXIQGEN in RX mode*/
-		}
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0xE26BF);
-		/*Enable TXIQGEN in RX mode*/
-	}
-
-	for (i = ODM_RF_PATH_A; i < MAX_RF_PATH; i++) {
-		ODM_SetRFReg(pDM_Odm, i, RF_WeLut_Jaguar, 0x80000, 0x0);
-		/*RF Mode table write disable*/
-	}
-
-	if (pBeamformingInfo->beamformee_su_cnt > 0) {
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-		pDM_Odm->LastUSBHub = *pDM_Odm->HubUsbMode;
-#endif
-
-		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
-		ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, BIT28 | BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
-
-		if (idx == 0) {
-			switch (Nr_index) {
-			case 0:
-				break;
-
-			case 1:			/*Nsts = 2	BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF0, bMaskByte3LowNibble | bMaskL3Bytes, 0x9366);		/*tx2path, BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x936);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x9360);
-			break;
-
-			case 2:			/*Nsts = 3	BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF0, bMaskByte3LowNibble | bMaskL3Bytes, 0x93e93ee);	/*tx3path, BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93e);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93e93e0);
-			break;
-
-			default:			/*Nr>3, same as Case 3*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF0, bMaskByte3LowNibble | bMaskL3Bytes, 0x93f93ff);	/*tx4path, ABCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93f);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskDWord, 0x93f93f0);
-			break;
-			}
-		} else {
-			switch (Nr_index) {
-			case 0:
-			break;
-
-			case 1:			/*Nsts = 2	BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, bMaskByte3LowNibble | bMaskL3Bytes, 0x9366);		/*tx2path, BC*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x936);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x9360);
-			break;
-
-			case 2:			/*Nsts = 3	BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, bMaskByte3LowNibble | bMaskL3Bytes, 0x93e93ee);	/*tx3path, BCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93e);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93e93e0);
-			break;
-
-			default:			/*Nr>3, same as Case 3*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, bMaskByte3LowNibble | bMaskL3Bytes, 0x93f93ff);	/*tx4path, ABCD*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x93f);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93f93f0);
-			break;
-			}
-		}
-	}
-
-	if ((pBeamformingInfo->beamformee_su_cnt == 0) && (pBeamformingInfo->beamformer_su_cnt == 0)) {
-		ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, bMaskByte3 | bMaskByte2HighNibble, 0x932);	/*set TxPath selection for 8814a BFer bug refine*/
-		ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93e9360);
-	}
-}
-#if 0
-VOID
-halTxbf8814A_DownloadNDPA(
-	IN	PADAPTER			Adapter,
-	IN	u1Byte				Idx
-)
-{
-	u1Byte			u1bTmp = 0, tmpReg422 = 0;
-	u1Byte			BcnValidReg = 0, count = 0, DLBcnCount = 0;
-	u2Byte			Head_Page = 0x7FE;
-	BOOLEAN			bSendBeacon = FALSE;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u2Byte			TxPageBndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
-	PRT_BEAMFORMING_INFO	pBeamInfo = GET_BEAMFORM_INFO(Adapter);
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-
-	pHalData->bFwDwRsvdPageInProgress = TRUE;
-	Adapter->HalFunc.GetHalDefVarHandler(Adapter, HAL_DEF_TX_PAGE_BOUNDARY, (pu2Byte)&TxPageBndy);
-
-	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1bTmp = PlatformEFIORead1Byte(Adapter, REG_CR_8814A + 1);
-	PlatformEFIOWrite1Byte(Adapter,  REG_CR_8814A + 1, (u1bTmp | BIT0));
-
-
-	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmpReg422 = PlatformEFIORead1Byte(Adapter, REG_FWHW_TXQ_CTRL_8814A + 2);
-	PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL_8814A + 2,  tmpReg422 & (~BIT6));
-
-	if (tmpReg422 & BIT6) {
-		RT_TRACE(COMP_INIT, DBG_LOUD, ("SetBeamformDownloadNDPA_8814A(): There is an Adapter is sending beacon.\n"));
-		bSendBeacon = TRUE;
-	}
-
-	/*0x204[11:0]	Beacon Head for TXDMA*/
-	PlatformEFIOWrite2Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A, Head_Page);
-
-	do {
-		/*Clear beacon valid check bit.*/
-		BcnValidReg = PlatformEFIORead1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
-		PlatformEFIOWrite1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A + 1, (BcnValidReg | BIT7));
-
-		/*download NDPA rsvd page.*/
-		if (pBeamEntry->BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)
-			Beamforming_SendVHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->AID, pBeamEntry->SoundBW, BEACON_QUEUE);
-		else
-			Beamforming_SendHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->SoundBW, BEACON_QUEUE);
-
-		/*check rsvd page download OK.*/
-		BcnValidReg = PlatformEFIORead1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
-		count = 0;
-		while (!(BcnValidReg & BIT7) && count < 20) {
-			count++;
-			delay_us(10);
-			BcnValidReg = PlatformEFIORead1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A + 2);
-		}
-		DLBcnCount++;
-	} while (!(BcnValidReg & BIT7) && DLBcnCount < 5);
-
-	if (!(BcnValidReg & BIT0))
-		RT_DISP(FBEAM, FBEAM_ERROR, ("%s Download RSVD page failed!\n", __func__));
-
-	/*0x204[11:0]	Beacon Head for TXDMA*/
-	PlatformEFIOWrite2Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A, TxPageBndy);
-
-	/*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 (bSendBeacon)
-		PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL_8814A + 2, tmpReg422);
-
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1bTmp = PlatformEFIORead1Byte(Adapter, REG_CR_8814A + 1);
-	PlatformEFIOWrite1Byte(Adapter, REG_CR_8814A + 1, (u1bTmp & (~BIT0)));
-
-	pBeamEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSED;
-
-	pHalData->bFwDwRsvdPageInProgress = FALSE;
-}
-
-VOID
-halTxbf8814A_FwTxBFCmd(
-	IN	PADAPTER	Adapter
-)
-{
-	u1Byte	Idx, Period = 0;
-	u1Byte	PageNum0 = 0xFF, PageNum1 = 0xFF;
-	u1Byte	u1TxBFParm[3] = {0};
-
-	PMGNT_INFO				pMgntInfo = &(Adapter->MgntInfo);
-	PRT_BEAMFORMING_INFO	pBeamInfo = GET_BEAMFORM_INFO(Adapter);
-
-	for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-		if (pBeamInfo->BeamformeeEntry[Idx].bUsed && pBeamInfo->BeamformeeEntry[Idx].BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (pBeamInfo->BeamformeeEntry[Idx].bSound) {
-				PageNum0 = 0xFE;
-				PageNum1 = 0x07;
-				Period = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			} else if (PageNum0 == 0xFF) {
-				PageNum0 = 0xFF; /*stop sounding*/
-				PageNum1 = 0x0F;
-			}
-		}
-	}
-
-	u1TxBFParm[0] = PageNum0;
-	u1TxBFParm[1] = PageNum1;
-	u1TxBFParm[2] = Period;
-	FillH2CCmd(Adapter, PHYDM_H2C_TXBF, 3, u1TxBFParm);
-
-	RT_DISP(FBEAM, FBEAM_FUN, ("@%s End, PageNum0 = 0x%x, PageNum1 = 0x%x Period = %d", __func__, PageNum0, PageNum1, Period));
-}
-#endif
-VOID
-HalTxbf8814A_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				BFerBFeeIdx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					i = 0;
-	u1Byte					BFerIdx = (BFerBFeeIdx & 0xF0) >> 4;
-	u1Byte					BFeeIdx = (BFerBFeeIdx & 0xF);
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	u2Byte					STAid = 0, CSI_Param = 0;
-	u1Byte					Nc_index = 0, Nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] BFerIdx=%d, BFeeIdx=%d\n", __func__, BFerIdx, BFeeIdx));
-	ODM_SetMACReg(pDM_Odm, REG_SND_PTCL_CTRL_8814A, bMaskByte1 | bMaskByte2, 0x0202);
-
-	if ((pBeamformingInfo->beamformer_su_cnt > 0) && (BFerIdx < BEAMFORMER_ENTRY_NUM)) {
-		BeamformerEntry = pBeamformingInfo->BeamformerEntry[BFerIdx];
-		/*Sounding protocol control*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8814A, 0xDB);
-
-		/*MAC address/Partial AID of Beamformer*/
-		if (BFerIdx == 0) {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_ASSOCIATED_BFMER0_INFO_8814A + i), BeamformerEntry.MacAddr[i]);
-		} else {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_ASSOCIATED_BFMER1_INFO_8814A + i), BeamformerEntry.MacAddr[i]);
-		}
-
-		/*CSI report parameters of Beamformer*/
-		Nc_index = halTxbf8814A_GetNrx(pDM_Odm);	/*for 8814A Nrx = 3(4 Ant), min=0(1 Ant)*/
-		Nr_index = BeamformerEntry.NumofSoundingDim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so Nr_index don't care*/
-
-		grouping = 0;
-
-		/*for ac = 1, for n = 3*/
-		if (BeamformerEntry.BeamformEntryCap & BEAMFORMEE_CAP_VHT_SU)
-			codebookinfo = 1;
-		else if (BeamformerEntry.BeamformEntryCap & BEAMFORMEE_CAP_HT_EXPLICIT)
-			codebookinfo = 3;
-
-		coefficientsize = 3;
-
-		CSI_Param = (u2Byte)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (Nr_index << 3) | (Nc_index));
-
-		if (BFerIdx == 0)
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8814A, CSI_Param);
-		else
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8814A + 2, CSI_Param);
-		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8814A + 3, 0x40);
-
-	}
-
-	if ((pBeamformingInfo->beamformee_su_cnt > 0) && (BFeeIdx < BEAMFORMEE_ENTRY_NUM)) {
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[BFeeIdx];
-
-		halTxbf8814A_RfMode(pDM_Odm, pBeamformingInfo, BFeeIdx);
-
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-			STAid = BeamformeeEntry.MacId;
-		else
-			STAid = BeamformeeEntry.P_AID;
-
-		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
-		if (BFeeIdx == 0) {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8814A, STAid);
-			ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8814A + 3, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8814A + 3) | BIT4 | BIT6 | BIT7);
-		} else
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8814A + 2, STAid | BIT14 | BIT15 | BIT12);
-
-		/*CSI report parameters of Beamformee*/
-		if (BFeeIdx == 0) {
-			/*Get BIT24 & BIT25*/
-			u1Byte	tmp = ODM_Read1Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3) & 0x3;
-
-			ODM_Write1Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3, tmp | 0x60);
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8814A, STAid | BIT9);
-		} else
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, STAid | 0xE200);	/*Set BIT25*/
-
-		phydm_Beamforming_Notify(pDM_Odm);
-	}
-
-}
-
-
-VOID
-HalTxbf8814A_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-
-	if (Idx < BEAMFORMER_ENTRY_NUM) {
-		BeamformerEntry = pBeamformingInfo->BeamformerEntry[Idx];
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[Idx];
-	} else
-		return;
-
-	/*Clear P_AID of Beamformee*/
-	/*Clear MAC address of Beamformer*/
-	/*Clear Associated Bfmee Sel*/
-
-	if (BeamformerEntry.BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8814A, 0xD8);
-		if (Idx == 0) {
-			ODM_Write4Byte(pDM_Odm, REG_ASSOCIATED_BFMER0_INFO_8814A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMER0_INFO_8814A + 4, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8814A, 0);
-		} else {
-			ODM_Write4Byte(pDM_Odm, REG_ASSOCIATED_BFMER1_INFO_8814A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMER1_INFO_8814A + 4, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8814A + 2, 0);
-		}
-	}
-
-	if (BeamformeeEntry.BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		halTxbf8814A_RfMode(pDM_Odm, pBeamformingInfo, Idx);
-		if (Idx == 0) {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8814A, 0x0);
-			ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8814A + 3, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8814A + 3) | BIT4 | BIT6 | BIT7);
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8814A, 0);
-		} else {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8814A + 2, 0x0 | BIT14 | BIT15 | BIT12);
-
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, ODM_Read2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2) & 0x60);
-		}
-	}
-}
-
-VOID
-HalTxbf8814A_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte					BeamCtrlVal, tmpVal;
-	u4Byte					BeamCtrlReg;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformEntry;
-
-	if (Idx < BEAMFORMEE_ENTRY_NUM)
-		BeamformEntry = pBeamformingInfo->BeamformeeEntry[Idx];
-	else
-		return;
-
-	if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-		BeamCtrlVal = BeamformEntry.MacId;
-	else
-		BeamCtrlVal = BeamformEntry.P_AID;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("@%s, BeamformEntry.BeamformEntryState = %d", __func__, BeamformEntry.BeamformEntryState));
-
-	if (Idx == 0)
-		BeamCtrlReg = REG_TXBF_CTRL_8814A;
-	else {
-		BeamCtrlReg = REG_TXBF_CTRL_8814A + 2;
-		BeamCtrlVal |= BIT12 | BIT14 | BIT15;
-	}
-
-	if (BeamformEntry.BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-		if (BeamformEntry.SoundBW == CHANNEL_WIDTH_20)
-			BeamCtrlVal |= BIT9;
-		else if (BeamformEntry.SoundBW == CHANNEL_WIDTH_40)
-			BeamCtrlVal |= (BIT9 | BIT10);
-		else if (BeamformEntry.SoundBW == CHANNEL_WIDTH_80)
-			BeamCtrlVal |= (BIT9 | BIT10 | BIT11);
-	} else {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("@%s, Don't apply Vmatrix",  __func__));
-		BeamCtrlVal &= ~(BIT9 | BIT10 | BIT11);
-	}
-
-	ODM_Write2Byte(pDM_Odm, BeamCtrlReg, BeamCtrlVal);
-	/*disable NDP packet use beamforming */
-	tmpVal = ODM_Read2Byte(pDM_Odm, REG_TXBF_CTRL_8814A);
-	ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8814A, tmpVal | BIT15);
-
-}
-
-
-
-
-
-VOID
-HalTxbf8814A_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-)
-{
-#if 0
-	PRT_BEAMFORMING_INFO 	pBeamInfo = GET_BEAMFORM_INFO(Adapter);
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-
-	if (pBeamEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		halTxbf8814A_DownloadNDPA(Adapter, Idx);
-
-	halTxbf8814A_FwTxBFCmd(Adapter);
-#endif
-}
-
-#endif	/* (RTL8814A_SUPPORT == 1)*/
-
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8814A TXBF mechanism
+ *
+ * ************************************************************ */
+
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (RTL8814A_SUPPORT == 1)
+
+boolean
+phydm_beamforming_set_iqgen_8814A(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	u16 counter = 0;
+	u32 rf_mode[4];
+
+	for (i = RF_PATH_A ; i < MAX_RF_PATH ; i++)
+		odm_set_rf_reg(dm, i, RF_WE_LUT, 0x80000, 0x1);	/*RF mode table write enable*/
+
+	while (1) {
+		counter++;
+		for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
+			odm_set_rf_reg(dm, i, RF_RCK_OS, 0xfffff, 0x18000);	/*Select Rx mode*/
+
+		ODM_delay_us(2);
+
+		for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
+			rf_mode[i] = odm_get_rf_reg(dm, i, RF_RCK_OS, 0xfffff);
+
+		if ((rf_mode[0] == 0x18000) && (rf_mode[1] == 0x18000) && (rf_mode[2] == 0x18000) && (rf_mode[3] == 0x18000))
+			break;
+		else if (counter == 100) {
+			PHYDM_DBG(dm, DBG_TXBF, "iqgen setting fail:8814A\n");
+			return false;
+		}
+	}
+
+	for (i = RF_PATH_A ; i < MAX_RF_PATH ; i++) {
+		odm_set_rf_reg(dm, i, RF_TXPA_G1, 0xfffff, 0xBE77F); /*Set Table data*/
+		odm_set_rf_reg(dm, i, RF_TXPA_G2, 0xfffff, 0x226BF); /*Enable TXIQGEN in Rx mode*/
+	}
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, 0xfffff, 0xE26BF); /*Enable TXIQGEN in Rx mode*/
+
+	for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
+		odm_set_rf_reg(dm, i, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+
+	return true;
+
+}
+
+
+
+void
+hal_txbf_8814a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8814A, BW);
+	odm_write_1byte(dm, REG_NDPA_RATE_8814A, (u8) rate);
+
+}
+#if 0
+#define PHYDM_MEMORY_MAP_BUF_READ	0x8000
+#define PHYDM_CTRL_INFO_PAGE			0x660
+
+void
+phydm_data_rate_8814a(
+	struct dm_struct			*dm,
+	u8				mac_id,
+	u32				*data,
+	u8				data_len
+)
+{
+	u8	i = 0;
+	u16	x_read_data_addr = 0;
+
+	odm_write_2byte(dm, REG_PKTBUF_DBG_CTRL_8814A, PHYDM_CTRL_INFO_PAGE);
+	x_read_data_addr = PHYDM_MEMORY_MAP_BUF_READ + mac_id * 32; /*Ctrl Info: 32Bytes for each macid(n)*/
+
+	if ((x_read_data_addr < PHYDM_MEMORY_MAP_BUF_READ) || (x_read_data_addr > 0x8FFF)) {
+		PHYDM_DBG(dm, DBG_TXBF, "x_read_data_addr(0x%x) is not correct!\n", x_read_data_addr);
+		return;
+	}
+
+	/* Read data */
+	for (i = 0; i < data_len; i++)
+		*(data + i) = odm_read_2byte(dm, x_read_data_addr + i);
+
+}
+#endif
+
+void
+hal_txbf_8814a_get_tx_rate(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
+	struct ra_table	*ra_tab = &dm->dm_ra_table;
+	struct cmn_sta_info			*sta = NULL;
+	u8	data_rate = 0xFF;
+	u8	macid = 0;
+
+	entry = &(beam_info->beamformee_entry[beam_info->beamformee_cur_idx]);
+	macid = (u8)entry->mac_id;
+
+	sta = dm->phydm_sta_info[macid];
+	
+	if (is_sta_active(sta)) {
+		
+		data_rate = (sta->ra_info.curr_tx_rate) & 0x7f;	/*Bit7 indicates SGI*/
+		beam_info->tx_bf_data_rate = data_rate;
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] dm->tx_bf_data_rate = 0x%x\n", __func__, beam_info->tx_bf_data_rate);
+}
+
+void
+hal_txbf_8814a_reset_tx_path(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	u8	nr_index = 0, tx_ss = 0;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	if ((beamforming_info->last_usb_hub) != (*dm->hub_usb_mode)) {
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), beamformee_entry.comp_steering_num_of_bfer);
+
+		if (*dm->hub_usb_mode == 2) {
+			if (dm->rf_type == RF_4T4R)
+				tx_ss = 0xf;
+			else if (dm->rf_type == RF_3T3R)
+				tx_ss = 0xe;
+			else
+				tx_ss = 0x6;
+		} else if (*dm->hub_usb_mode == 1)	/*USB 2.0 always 2Tx*/
+			tx_ss = 0x6;
+		else
+			tx_ss = 0x6;
+
+		if (tx_ss == 0xf) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
+		} else if (tx_ss == 0xe) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
+		} else if (tx_ss == 0x6) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
+		}
+
+		if (idx == 0) {
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+				break;
+			}
+		} else	{
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+				break;
+			}
+		}
+
+		beamforming_info->last_usb_hub = *dm->hub_usb_mode;
+	} else
+		return;
+#endif
+}
+
+
+u8
+hal_txbf_8814a_get_ntx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		ntx = 0, tx_ss = 3;
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	tx_ss = *dm->hub_usb_mode;
+#endif
+	if (tx_ss == 3 || tx_ss == 2) {
+		if (dm->rf_type == RF_4T4R)
+			ntx = 3;
+		else if (dm->rf_type == RF_3T3R)
+			ntx = 2;
+		else
+			ntx = 1;
+	} else if (tx_ss == 1)	/*USB 2.0 always 2Tx*/
+		ntx = 1;
+	else
+		ntx = 1;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ntx = %d\n", __func__, ntx);
+	return ntx;
+}
+
+u8
+hal_txbf_8814a_get_nrx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			nrx = 0;
+
+	if (dm->rf_type == RF_4T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_3T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T2R)
+		nrx = 1;
+	else if (dm->rf_type == RF_2T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_1T1R)
+		nrx = 0;
+	else if (dm->rf_type == RF_1T2R)
+		nrx = 1;
+	else
+		nrx = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] nrx = %d\n", __func__, nrx);
+	return nrx;
+}
+
+void
+hal_txbf_8814a_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beamforming_info,
+	u8					idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8				nr_index = 0;
+	u8				tx_ss = 3;		/*default use 3 Tx*/
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), beamformee_entry.comp_steering_num_of_bfer);
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	if (beamforming_info->beamformee_su_cnt > 0) {
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+		beamforming_info->last_usb_hub = *dm->hub_usb_mode;
+		tx_ss = *dm->hub_usb_mode;
+#endif
+		if (tx_ss == 3 || tx_ss == 2) {
+			if (dm->rf_type == RF_4T4R)
+				tx_ss = 0xf;
+			else if (dm->rf_type == RF_3T3R)
+				tx_ss = 0xe;
+			else
+				tx_ss = 0x6;
+		} else if (tx_ss == 1)	/*USB 2.0 always 2Tx*/
+			tx_ss = 0x6;
+		else
+			tx_ss = 0x6;
+
+		if (tx_ss == 0xf) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
+		} else if (tx_ss == 0xe) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
+		} else if (tx_ss == 0x6) {
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
+		}
+
+		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT(28) | BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT30, 0x1);			/*if Nsts > Nc don't apply V matrix*/
+
+		if (idx == 0) {
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+
+				break;
+			}
+		} else {
+			switch (nr_index) {
+			case 0:
+				break;
+
+			case 1:			/*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+				break;
+
+			case 2:			/*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+				break;
+
+			default:			/*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+				break;
+			}
+		}
+	}
+
+	if ((beamforming_info->beamformee_su_cnt == 0) && (beamforming_info->beamformer_su_cnt == 0)) {
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x932);	/*set tx_path selection for 8814a BFer bug refine*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e9360);
+	}
+}
+#if 0
+void
+hal_txbf_8814a_download_ndpa(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			u1b_tmp = 0, tmp_reg422 = 0;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	u16			head_page = 0x7FE;
+	boolean			is_send_beacon = false;
+	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+	void		*adapter = dm->adapter;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
+#endif
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8814A + 1);
+	odm_write_1byte(dm,  REG_CR_8814A + 1, (u1b_tmp | BIT(0)));
+
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s: There is an adapter is sending beacon.\n", __func__);
+		is_send_beacon = true;
+	}
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	odm_write_2byte(dm, REG_FIFOPAGE_CTRL_2_8814A, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		odm_write_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1, (bcn_valid_reg | BIT(7)));
+
+		/*download NDPA rsvd page.*/
+		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
+		else
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(7)) && count < 20) {
+			count++;
+			ODM_delay_ms(10);
+			bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(7)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(7)))
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n", __func__);
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	odm_write_2byte(dm, REG_FIFOPAGE_CTRL_2_8814A, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8814A + 1);
+	odm_write_1byte(dm, REG_CR_8814A + 1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
+#endif
+}
+
+void
+hal_txbf_8814a_fw_txbf_cmd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	idx, period = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beam_info->beamformee_entry[idx].is_sound) {
+				PageNum0 = 0xFE;
+				PageNum1 = 0x07;
+				period = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (PageNum0 == 0xFF) {
+				PageNum0 = 0xFF; /*stop sounding*/
+				PageNum1 = 0x0F;
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = period;
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	PHYDM_DBG(dm, DBG_TXBF,
+		"[%s] PageNum0 = %d, PageNum1 = %d period = %d\n", __func__, PageNum0, PageNum1, period);
+}
+#endif
+void
+hal_txbf_8814a_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	u16					sta_id = 0, csi_param = 0;
+	u8					nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] bfer_idx=%d, bfee_idx=%d\n", __func__, bfer_idx, bfee_idx);
+	odm_set_mac_reg(dm, REG_SND_PTCL_CTRL_8814A, MASKBYTE1 | MASKBYTE2, 0x0202);
+
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A, 0xDB);
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (bfer_idx == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8814A + i), beamformer_entry.mac_addr[i]);
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8814A + i), beamformer_entry.mac_addr[i]);
+		}
+
+		/*CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8814a_get_nrx(dm);	/*for 8814A nrx = 3(4 ant), min=0(1 ant)*/
+		nr_index = beamformer_entry.num_of_sounding_dim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+
+		grouping = 0;
+
+		/*for ac = 1, for n = 3*/
+		if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU)
+			codebookinfo = 1;
+		else if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
+			codebookinfo = 3;
+
+		coefficientsize = 3;
+
+		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
+
+		if (bfer_idx == 0)
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A, csi_param);
+		else
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, csi_param);
+		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A + 3, 0x40);
+
+	}
+
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
+
+		hal_txbf_8814a_rf_mode(dm, beamforming_info, bfee_idx);
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = beamformee_entry.mac_id;
+		else
+			sta_id = beamformee_entry.p_aid;
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (bfee_idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
+
+		/*CSI report parameters of Beamformee*/
+		if (bfee_idx == 0) {
+			/*Get BIT24 & BIT25*/
+			u8	tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3) & 0x3;
+
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A, sta_id | BIT(9));
+		} else
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, sta_id | 0xE200);	/*Set BIT25*/
+
+		phydm_beamforming_notify(dm);
+	}
+
+}
+
+
+void
+hal_txbf_8814a_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = beamforming_info->beamformer_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	} else
+		return;
+
+	/*Clear P_AID of Beamformee*/
+	/*Clear MAC address of Beamformer*/
+	/*Clear Associated Bfmee Sel*/
+
+	if (beamformer_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A, 0xD8);
+		if (idx == 0) {
+			odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8814A, 0);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8814A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A, 0);
+		} else {
+			odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8814A, 0);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8814A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, 0);
+		}
+	}
+
+	if (beamformee_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		hal_txbf_8814a_rf_mode(dm, beamforming_info, idx);
+		if (idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A, 0x0);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A, 0);
+		} else {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
+
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2) & 0x60);
+		}
+	}
+}
+
+void
+hal_txbf_8814a_status(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val, tmp_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamform_entry;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamform_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+		beam_ctrl_val = beamform_entry.mac_id;
+	else
+		beam_ctrl_val = beamform_entry.p_aid;
+
+	PHYDM_DBG(dm, DBG_TXBF, "@%s, beamform_entry.beamform_entry_state = %d", __func__, beamform_entry.beamform_entry_state);
+
+	if (idx == 0)
+		beam_ctrl_reg = REG_TXBF_CTRL_8814A;
+	else {
+		beam_ctrl_reg = REG_TXBF_CTRL_8814A + 2;
+		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+	}
+
+	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (beamforming_info->apply_v_matrix == true)) {
+		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
+			beam_ctrl_val |= BIT(9);
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
+			beam_ctrl_val |= (BIT(9) | BIT(10));
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_80)
+			beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
+	} else {
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, Don't apply Vmatrix",  __func__);
+		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+	}
+
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+	/*disable NDP packet use beamforming */
+	tmp_val = odm_read_2byte(dm, REG_TXBF_CTRL_8814A);
+	odm_write_2byte(dm, REG_TXBF_CTRL_8814A, tmp_val | BIT(15));
+
+}
+
+
+
+
+
+void
+hal_txbf_8814a_fw_txbf(
+	void			*dm_void,
+	u8				idx
+)
+{
+#if 0
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_8814a_download_ndpa(dm, idx);
+
+	hal_txbf_8814a_fw_txbf_cmd(dm);
+#endif
+}
+
+#endif	/* (RTL8814A_SUPPORT == 1)*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.h
index e13d33cc53b9..6d648bef6046 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8814a.h
@@ -1,71 +1,114 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __HAL_TXBF_8814A_H__
-#define __HAL_TXBF_8814A_H__
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8814A_SUPPORT == 1)
-VOID
-HalTxbf8814A_setNDPArate(
-	IN PVOID			pDM_VOID,
-	IN u1Byte	BW,
-	IN u1Byte	Rate
-);
-
-u1Byte
-halTxbf8814A_GetNtx(
-	IN PVOID			pDM_VOID
-	);
-
-VOID
-HalTxbf8814A_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8814A_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8814A_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-VOID
-HalTxbf8814A_ResetTxPath(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8814A_GetTxRate(
-	IN PVOID			pDM_VOID
-	);
-
-VOID
-HalTxbf8814A_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-	);
-#else
-
-#define HalTxbf8814A_setNDPArate(pDM_VOID,	BW,	Rate)
-#define halTxbf8814A_GetNtx(pDM_VOID) 0
-#define HalTxbf8814A_Enter(pDM_VOID, Idx)
-#define HalTxbf8814A_Leave(pDM_VOID, Idx)
-#define HalTxbf8814A_Status(pDM_VOID, Idx)
-#define HalTxbf8814A_ResetTxPath(pDM_VOID,	Idx)
-#define HalTxbf8814A_GetTxRate(pDM_VOID)
-#define HalTxbf8814A_FwTxBF(pDM_VOID,	Idx)
-#endif
-
-#endif
-
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_8814A_H__
+#define __HAL_TXBF_8814A_H__
+
+#if (RTL8814A_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+boolean
+phydm_beamforming_set_iqgen_8814A(
+	void			*dm_void
+);
+
+void
+hal_txbf_8814a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+);
+
+u8
+hal_txbf_8814a_get_ntx(
+	void			*dm_void
+);
+
+void
+hal_txbf_8814a_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8814a_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8814a_status(
+	void			*dm_void,
+	u8				idx
+);
+
+void
+hal_txbf_8814a_reset_tx_path(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8814a_get_tx_rate(
+	void			*dm_void
+);
+
+void
+hal_txbf_8814a_fw_txbf(
+	void			*dm_void,
+	u8				idx
+);
+
+#else
+
+#define hal_txbf_8814a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_8814a_get_ntx(dm_void) 0
+#define hal_txbf_8814a_enter(dm_void, idx)
+#define hal_txbf_8814a_leave(dm_void, idx)
+#define hal_txbf_8814a_status(dm_void, idx)
+#define hal_txbf_8814a_reset_tx_path(dm_void,	idx)
+#define hal_txbf_8814a_get_tx_rate(dm_void)
+#define hal_txbf_8814a_fw_txbf(dm_void,	idx)
+#define phydm_beamforming_set_iqgen_8814A(dm_void)	0
+
+#endif
+
+#else
+
+#define hal_txbf_8814a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_8814a_get_ntx(dm_void) 0
+#define hal_txbf_8814a_enter(dm_void, idx)
+#define hal_txbf_8814a_leave(dm_void, idx)
+#define hal_txbf_8814a_status(dm_void, idx)
+#define hal_txbf_8814a_reset_tx_path(dm_void,	idx)
+#define hal_txbf_8814a_get_tx_rate(dm_void)
+#define hal_txbf_8814a_fw_txbf(dm_void,	idx)
+#define phydm_beamforming_set_iqgen_8814A(dm_void)	0
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8821b.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8821b.c
deleted file mode 100644
index e7e85c07196d..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8821b.c
+++ /dev/null
@@ -1,401 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-/*============================================================*/
-/*Description:*/
-/*This file is for 8812/8821/8811 TXBF mechanism*/
-/*============================================================*/
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8821B_SUPPORT == 1)
-
-VOID
-halTxbf8821B_RfMode(
-	IN PVOID			pDM_VOID,
-	IN PRT_BEAMFORMING_INFO	pBeamInfo
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	if (pDM_Odm->RFType == ODM_1T1R)
-		return;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] set TxIQGen\n", __func__));
-
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WeLut_Jaguar, 0x80000, 0x1);	/*RF Mode table write enable*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_WeLut_Jaguar, 0x80000, 0x1);	/*RF Mode table write enable*/
-
-	if (pBeamInfo->beamformee_su_cnt > 0) {
-		/*Path_A*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
-		/*Path_B*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData1, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
-	} else {
-		/*Path_A*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
-		/*Path_B*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData1, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
-	}
-
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WeLut_Jaguar, 0x80000, 0x0);	/*RF Mode table write disable*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_WeLut_Jaguar, 0x80000, 0x0);	/*RF Mode table write disable*/
-
-	if (pBeamInfo->beamformee_su_cnt > 0)
-		ODM_SetBBReg(pDM_Odm, rTxPath_Jaguar, bMaskByte1, 0x33);
-	else
-		ODM_SetBBReg(pDM_Odm, rTxPath_Jaguar, bMaskByte1, 0x11);
-}
-
-#if 0
-VOID
-halTxbf8821B_DownloadNDPA(
-	IN PDM_ODM_T			pDM_Odm,
-	IN	u1Byte				Idx
-)
-{
-	u1Byte			u1bTmp = 0, tmpReg422 = 0, Head_Page;
-	u1Byte			BcnValidReg = 0, count = 0, DLBcnCount = 0;
-	BOOLEAN			bSendBeacon = FALSE;
-	u1Byte			TxPageBndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;	/*default reseved 1 page for the IC type which is undefined.*/
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(pDM_Odm->Adapter);
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-
-	pHalData->bFwDwRsvdPageInProgress = TRUE;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (Idx == 0)
-		Head_Page = 0xFE;
-	else
-		Head_Page = 0xFE;
-
-	Adapter->HalFunc.GetHalDefVarHandler(Adapter, HAL_DEF_TX_PAGE_BOUNDARY, (pu1Byte)&TxPageBndy);
-
-	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1bTmp = ODM_Read1Byte(pDM_Odm, REG_CR_8821B + 1);
-	ODM_Write1Byte(pDM_Odm,  REG_CR_8821B + 1, (u1bTmp | BIT0));
-
-
-	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmpReg422 = ODM_Read1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8821B + 2);
-	ODM_Write1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8821B + 2,  tmpReg422 & (~BIT6));
-
-	if (tmpReg422 & BIT6) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("SetBeamformDownloadNDPA_8812(): There is an Adapter is sending beacon.\n"));
-		bSendBeacon = TRUE;
-	}
-
-	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_TDECTRL_8812A + 1, Head_Page);
-
-	do {
-		/*Clear beacon valid check bit.*/
-		BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_TDECTRL_8812A + 2);
-		ODM_Write1Byte(pDM_Odm, REG_TDECTRL_8812A + 2, (BcnValidReg | BIT0));
-
-		/*download NDPA rsvd page.*/
-		if (pBeamEntry->BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)
-			Beamforming_SendVHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->AID, pBeamEntry->SoundBW, BEACON_QUEUE);
-		else
-			Beamforming_SendHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->SoundBW, BEACON_QUEUE);
-
-		/*check rsvd page download OK.*/
-		BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_TDECTRL_8812A + 2);
-		count = 0;
-		while (!(BcnValidReg & BIT0) && count < 20) {
-			count++;
-			ODM_delay_ms(10);
-			BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_TDECTRL_8812A + 2);
-		}
-		DLBcnCount++;
-	} while (!(BcnValidReg & BIT0) && DLBcnCount < 5);
-
-	if (!(BcnValidReg & BIT0))
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Download RSVD page failed!\n", __func__));
-
-	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_TDECTRL_8812A + 1, TxPageBndy);
-
-	/*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 (bSendBeacon)
-		ODM_Write1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8821B + 2, tmpReg422);
-
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1bTmp = ODM_Read1Byte(pDM_Odm, REG_CR_8821B + 1);
-	ODM_Write1Byte(pDM_Odm, REG_CR_8821B + 1, (u1bTmp & (~BIT0)));
-
-	pBeamEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSED;
-
-	pHalData->bFwDwRsvdPageInProgress = FALSE;
-}
-
-
-VOID
-halTxbf8821B_FwTxBFCmd(
-	IN PDM_ODM_T			pDM_Odm
-)
-{
-	u1Byte	Idx, Period0 = 0, Period1 = 0;
-	u1Byte	PageNum0 = 0xFF, PageNum1 = 0xFF;
-	u1Byte	u1TxBFParm[3] = {0};
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-		/*Modified by David*/
-		if (pBeamInfo->BeamformeeEntry[Idx].bUsed && pBeamInfo->BeamformeeEntry[Idx].BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (Idx == 0) {
-				if (pBeamInfo->BeamformeeEntry[Idx].bSound)
-					PageNum0 = 0xFE;
-				else
-					PageNum0 = 0xFF; /*stop sounding*/
-				Period0 = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			} else if (Idx == 1) {
-				if (pBeamInfo->BeamformeeEntry[Idx].bSound)
-					PageNum1 = 0xFE;
-				else
-					PageNum1 = 0xFF; /*stop sounding*/
-				Period1 = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			}
-		}
-	}
-
-	u1TxBFParm[0] = PageNum0;
-	u1TxBFParm[1] = PageNum1;
-	u1TxBFParm[2] = (Period1 << 4) | Period0;
-	FillH2CCmd(Adapter, PHYDM_H2C_TXBF, 3, u1TxBFParm);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, 
-		("[%s] PageNum0 = %d Period0 = %d, PageNum1 = %d Period1 %d\n", __func__, PageNum0, Period0, PageNum1, Period1));
-}
-
-#endif
-VOID
-HalTxbf8821B_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				BFerBFeeIdx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					i = 0;
-	u1Byte					BFerIdx = (BFerBFeeIdx & 0xF0) >> 4;
-	u1Byte					BFeeIdx = (BFerBFeeIdx & 0xF);
-	u4Byte					CSI_Param;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	u2Byte					STAid = 0;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]Start!\n", __func__));
-
-	halTxbf8821B_RfMode(pDM_Odm, pBeamformingInfo);
-
-	if (pDM_Odm->RFType == ODM_2T2R)
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CSI_CONTENT_VALUE, bMaskDWord, 0x00000000);	/*Nc =2*/
-	else
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CSI_CONTENT_VALUE, bMaskDWord, 0x01081008);	/*Nc =1*/
-
-	if ((pBeamformingInfo->beamformer_su_cnt > 0) && (BFerIdx < BEAMFORMER_ENTRY_NUM)) {
-		BeamformerEntry = pBeamformingInfo->BeamformerEntry[BFerIdx];
-
-		/*Sounding protocol control*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8821B, 0xCB);
-
-		/*MAC address/Partial AID of Beamformer*/
-		if (BFerIdx == 0) {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_BFMER0_INFO_8812A + i), BeamformerEntry.MacAddr[i]);
-			/*CSI report use legacy ofdm so don't need to fill P_AID. */
-			/*PlatformEFIOWrite2Byte(Adapter, REG_BFMER0_INFO_8821B+6, BeamformEntry.P_AID); */
-		} else {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_BFMER1_INFO_8812A + i), BeamformerEntry.MacAddr[i]);
-			/*CSI report use legacy ofdm so don't need to fill P_AID.*/
-			/*PlatformEFIOWrite2Byte(Adapter, REG_BFMER1_INFO_8821B+6, BeamformEntry.P_AID);*/
-		}
-
-		/*CSI report parameters of Beamformee*/
-		if (BeamformerEntry.BeamformEntryCap & BEAMFORMEE_CAP_VHT_SU) {
-			if (pDM_Odm->RFType == ODM_2T2R)
-				CSI_Param = 0x01090109;
-			else
-				CSI_Param = 0x01080108;
-		} else {
-			if (pDM_Odm->RFType == ODM_2T2R)
-				CSI_Param = 0x03090309;
-			else
-				CSI_Param = 0x03080308;
-		}
-
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8821B, CSI_Param);
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW40_8821B, CSI_Param);
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW80_8821B, CSI_Param);
-
-		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8821B + 3, 0x50);
-	}
-
-
-	if ((pBeamformingInfo->beamformee_su_cnt > 0) && (BFeeIdx < BEAMFORMEE_ENTRY_NUM)) {
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[BFeeIdx];
-
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-			STAid = BeamformeeEntry.MacId;
-		else
-			STAid = BeamformeeEntry.P_AID;
-
-		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
-		if (BFeeIdx == 0) {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8821B, STAid);
-			ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8821B + 3, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8821B + 3) | BIT4 | BIT6 | BIT7);
-		} else
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8821B + 2, STAid | BIT12 | BIT14 | BIT15);
-
-		/*CSI report parameters of Beamformee*/
-		if (BFeeIdx == 0) {
-			/*Get BIT24 & BIT25*/
-			u1Byte	tmp = ODM_Read1Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 3) & 0x3;
-
-			ODM_Write1Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 3, tmp | 0x60);
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A, STAid | BIT9);
-		} else {
-			/*Set BIT25*/
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 2, STAid | 0xE200);
-		}
-			phydm_Beamforming_Notify(pDM_Odm);
-	}
-}
-
-
-VOID
-HalTxbf8821B_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	
-	if (Idx < BEAMFORMER_ENTRY_NUM) {
-		BeamformerEntry = pBeamformingInfo->BeamformerEntry[Idx];
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[Idx];
-	} else
-		return;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]Start!, IDx = %d\n", __func__, Idx));
-
-	/*Clear P_AID of Beamformee*/
-	/*Clear MAC address of Beamformer*/
-	/*Clear Associated Bfmee Sel*/
-	
-	if (BeamformerEntry.BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8821B, 0xC8);
-		if (Idx == 0) {
-			ODM_Write4Byte(pDM_Odm, REG_BFMER0_INFO_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_BFMER0_INFO_8812A + 4, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8821B, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW40_8821B, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW80_8821B, 0);
-		} else {
-			ODM_Write4Byte(pDM_Odm, REG_BFMER1_INFO_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_BFMER1_INFO_8812A + 4, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8821B, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW40_8821B, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW80_8821B, 0);
-		}
-	}
-
-	if (BeamformeeEntry.BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		halTxbf8821B_RfMode(pDM_Odm, pBeamformingInfo);
-		if (Idx == 0) {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8821B, 0x0);
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A, 0);
-		} else {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8821B + 2, ODM_Read2Byte(pDM_Odm, REG_TXBF_CTRL_8821B + 2) & 0xF000);
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 2, ODM_Read2Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 2) & 0x60);
-		}
-	}
-	
-}
-
-
-VOID
-HalTxbf8821B_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte					BeamCtrlVal;
-	u4Byte					BeamCtrlReg;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformEntry = pBeamInfo->BeamformeeEntry[Idx];
-
-	if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-		BeamCtrlVal = BeamformEntry.MacId;
-	else
-		BeamCtrlVal = BeamformEntry.P_AID;
-
-	if (Idx == 0)
-		BeamCtrlReg = REG_TXBF_CTRL_8821B;
-	else {
-		BeamCtrlReg = REG_TXBF_CTRL_8821B + 2;
-		BeamCtrlVal |= BIT12 | BIT14 | BIT15;
-	}
-
-	if (BeamformEntry.BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-		if (BeamformEntry.SoundBW == CHANNEL_WIDTH_20)
-			BeamCtrlVal |= BIT9;
-		else if (BeamformEntry.SoundBW == CHANNEL_WIDTH_40)
-			BeamCtrlVal |= BIT10;
-		else if (BeamformEntry.SoundBW == CHANNEL_WIDTH_80)
-			BeamCtrlVal |= BIT11;
-	} else
-		BeamCtrlVal &= ~(BIT9 | BIT10 | BIT11);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] BeamCtrlVal = 0x%x!\n", __func__, BeamCtrlVal));
-
-	ODM_Write2Byte(pDM_Odm, BeamCtrlReg, BeamCtrlVal);
-}
-
-
-
-VOID
-HalTxbf8821B_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-#if 0
-	if (pBeamEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		halTxbf8821B_DownloadNDPA(pDM_Odm, Idx);
-
-	halTxbf8821B_FwTxBFCmd(pDM_Odm);
-#endif
-}
-
-#endif
-
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8821b.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8821b.h
deleted file mode 100644
index f54b7fca17f3..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8821b.h
+++ /dev/null
@@ -1,44 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __HAL_TXBF_8821B_H__
-#define __HAL_TXBF_8821B_H__
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8821B_SUPPORT == 1)
-VOID
-HalTxbf8821B_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8821B_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8821B_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8821B_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-	);
-
-#else
-#define HalTxbf8821B_Enter(pDM_VOID, Idx)
-#define HalTxbf8821B_Leave(pDM_VOID, Idx)
-#define HalTxbf8821B_Status(pDM_VOID, Idx)
-#define HalTxbf8821B_FwTxBF(pDM_VOID, Idx)
-#endif
-
-
-#endif
-
-#endif	// #ifndef __HAL_TXBF_8821B_H__								
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.c
index 5a97a4a22aa4..d3350134366d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.c
@@ -1,1100 +1,1113 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-/*============================================================*/
-/* Description:                                               */
-/*                                                            */
-/* This file is for 8814A TXBF mechanism                      */
-/*                                                            */
-/*============================================================*/
-
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8822B_SUPPORT == 1)
-
-#if 0
-VOID
-HalTxbf8814A_GetBeamformcap(
-	IN PADAPTER	Adapter
-)
-{
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T			pDM_Odm = &pHalData->DM_OutSrc;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = GET_BEAMFORM_INFO(Adapter);
-	BEAMFORMING_CAP	BeamformCap = BEAMFORMING_CAP_NONE;
-
-	BeamformCap = phydm_Beamforming_GetBeamCap(pDM_Odm, pBeamformingInfo);
-
-	if (BeamformCap == pBeamformingInfo->BeamformCap)
-		return;
-	else 
-		pBeamformingInfo->BeamformCap = BeamformCap;
-
-}
-
-VOID
-HalTxbf8814A_GetTxRate(
-	IN	PADAPTER			Adapter
-)
-{
-
-	HAL_DATA_TYPE				*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T					pDM_Odm = &pHalData->DM_OutSrc;
-	PRT_BEAMFORMING_INFO			pBeamInfo = GET_BEAMFORM_INFO(Adapter);
-	PRT_BEAMFORMEE_ENTRY	pEntry;
-	u4Byte		TxRptData = 0;
-	u1Byte		DataRate = 0xFF;
-
-	pEntry = &(pBeamInfo->BeamformeeEntry[pBeamInfo->BeamformeeCurIdx]);
-
-	ReadSdramData_8814A(Adapter, (u1Byte)pEntry->MacId, LOC_8814A_CTRL_INFO, &TxRptData, 1);
-	DataRate = (u1Byte)TxRptData;
-	DataRate &= bMask7bits;   /*Bit7 indicates SGI*/
-	
-	pDM_Odm->TxBfDataRate = DataRate;
-
-}
-
-VOID
-HalTxbf8814A_ResetTxPath(
-	IN	PADAPTER			Adapter,
-	IN	u1Byte				idx
-)
-{
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter); 
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc; 
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = GET_BEAMFORM_INFO(Adapter);
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	u1Byte	Nr_index = 0;
-	
-	if (idx < BEAMFORMEE_ENTRY_NUM)
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[idx];
-	else
-		return;
-	
-	if ((pDM_Odm->LastUSBHub) != (RT_GetHubUSBMode(Adapter))) {	
-		Nr_index = TxBF_Nr(halTxbf8814A_GetNtx(Adapter), BeamformeeEntry.CompSteeringNumofBFer);
-
-		if (idx == 0) {
-			switch (Nr_index) {			
-			case 0:	
-			break;
-
-			case 1:			/*Nsts = 2	BC*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT3|BIT2|BIT1|BIT0, 0x6);		/*1ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT7|BIT6|BIT5|BIT4, 0x6);		/*2ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, 0x0000ff00, 0x10);				/*BC*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, BIT23|BIT22|BIT21|BIT20, 0x6);	/*set TxPath selection for 8814a BFer bug refine*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, bMaskByte3, 0x10);				/*if Bfer enable, always use 3Tx for all Spatial stream*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x1060);
-			break;
-
-			case 2:			/*Nsts = 3	BCD*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT3|BIT2|BIT1|BIT0, 0xe);		/*1ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT7|BIT6|BIT5|BIT4, 0xe);		/*2ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, 0x0000ff00, 0x90);				/*BCD*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT19|BIT18|BIT17|BIT16, 0xe);	/*3ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, 0xff00000, 0x90);					/*bcd*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, BIT23|BIT22|BIT21|BIT20, 0xe);	/*set TxPath selection for 8814a BFer bug refine*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, bMaskByte3, 0x90);				/*if Bfer enable, always use 3Tx for all Spatial stream*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x90e90e0);
-			break;
-			
-			default:			/*Nr>3, same as Case 3*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT3|BIT2|BIT1|BIT0, 0xf);		/*1ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT7|BIT6|BIT5|BIT4, 0xf);		/*2ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, 0x0000ff00, 0x93);				/*BC*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, BIT19|BIT18|BIT17|BIT16, 0xf);	/*3ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF0, 0xff00000, 0x93);					/*bcd*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, BIT23|BIT22|BIT21|BIT20, 0xf);	/*set TxPath selection for 8814a BFer bug refine*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, bMaskByte3, 0x93);				/*if Bfer enable, always use 3Tx for all Spatial stream*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93f93f0);
-			break;
-			}
-		} else	{
-			switch (Nr_index) {
-			case 0:	
-			break;
-
-			case 1:			/*Nsts = 2	BC*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT3|BIT2|BIT1|BIT0, 0x6);		/*1ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT7|BIT6|BIT5|BIT4, 0x6);		/*2ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, 0x0000ff00, 0x10);				/*BC*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, BIT23|BIT22|BIT21|BIT20, 0x6);	/*set TxPath selection for 8814a BFer bug refine*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, bMaskByte3, 0x10);				/*if Bfer enable, always use 3Tx for all Spatial stream*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x1060);
-			break;
-
-			case 2:			/*Nsts = 3	BCD*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT3|BIT2|BIT1|BIT0, 0xe);		/*1ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT7|BIT6|BIT5|BIT4, 0xe);		/*2ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, 0x0000ff00, 0x90);				/*BC*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT19|BIT18|BIT17|BIT16, 0xe);	/*3ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, 0xff00000, 0x90);					/*bcd*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, BIT23|BIT22|BIT21|BIT20, 0xe);	/*set TxPath selection for 8814a BFer bug refine*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, bMaskByte3, 0x90);				/*if Bfer enable, always use 3Tx for all Spatial stream*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x90e90e0);
-			break;
-			
-			default:			/*Nr>3, same as Case 3*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT3|BIT2|BIT1|BIT0, 0xf);		/*1ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT7|BIT6|BIT5|BIT4, 0xf);		/*2ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, 0x0000ff00, 0x93);				/*BC*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, BIT19|BIT18|BIT17|BIT16, 0xf);	/*3ss*/
-			PHY_SetBBReg(Adapter, REG_BB_TXBF_ANT_SET_BF1, 0xff00000, 0x93);					/*bcd*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, BIT23|BIT22|BIT21|BIT20, 0xf);	/*set TxPath selection for 8814a BFer bug refine*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_1, bMaskByte3, 0x93);				/*if Bfer enable, always use 3Tx for all Spatial stream*/
-			PHY_SetBBReg(Adapter, REG_BB_TX_PATH_SEL_2, bMaskDWord, 0x93f93f0);
-			break;
-		
-			}
-		}
-
-			pDM_Odm->LastUSBHub = RT_GetHubUSBMode(Adapter);
-	}
-	else
-		return;
-#endif
-}
-#endif
-
-u1Byte
-halTxbf8822B_GetNtx(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			Ntx = 0;
-
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-	if (pDM_Odm->SupportInterface == ODM_ITRF_USB) {
-		if (*pDM_Odm->HubUsbMode == 2) {/*USB3.0*/
-			if (pDM_Odm->RFType == ODM_4T4R)
-				Ntx = 3;
-			else if (pDM_Odm->RFType == ODM_3T3R)
-				Ntx = 2;
-			else
-				Ntx = 1;
-		} else if (*pDM_Odm->HubUsbMode == 1)	/*USB 2.0 always 2Tx*/
-			Ntx = 1;
-		else
-			Ntx = 1;
-	} else
-#endif
-	{
-		if (pDM_Odm->RFType == ODM_4T4R)
-			Ntx = 3;
-		else if (pDM_Odm->RFType == ODM_3T3R)
-			Ntx = 2;
-		else
-			Ntx = 1;
-	}
-
-	return Ntx;
-
-}
-
-u1Byte
-halTxbf8822B_GetNrx(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			Nrx = 0;
-
-	if (pDM_Odm->RFType == ODM_4T4R)
-		Nrx = 3;
-	else if (pDM_Odm->RFType == ODM_3T3R)
-		Nrx = 2;
-	else if (pDM_Odm->RFType == ODM_2T2R)
-		Nrx = 1;
-	else if (pDM_Odm->RFType == ODM_2T3R)
-		Nrx = 2;
-	else if (pDM_Odm->RFType == ODM_2T4R)
-		Nrx = 3;
-	else if (pDM_Odm->RFType == ODM_1T1R)
-		Nrx = 0;
-	else if (pDM_Odm->RFType == ODM_1T2R)
-		Nrx = 1;
-	else
-		Nrx = 0;
-
-	return Nrx;
-	
-}
-
-/***************SU & MU BFee Entry********************/
-VOID
-halTxbf8822B_RfMode(
-	IN PVOID			pDM_VOID,
-	IN	PRT_BEAMFORMING_INFO	pBeamformingInfo,
-	IN	u1Byte					idx
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte				i, Nr_index = 0;
-	BOOLEAN				bSelfBeamformer = FALSE;
-	BOOLEAN				bSelfBeamformee = FALSE;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-
-	if (idx < BEAMFORMEE_ENTRY_NUM)
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[idx];
-	else
-		return;
-
-	if (pDM_Odm->RFType == ODM_1T1R)
-		return;
-
-	for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_B; i++) {
-		ODM_SetRFReg(pDM_Odm, i, RF_WeLut_Jaguar, 0x80000, 0x1);
-		/*RF Mode table write enable*/
-	}
-
-	if ((pBeamformingInfo->beamformee_su_cnt > 0) || (pBeamformingInfo->beamformee_mu_cnt > 0)) {
-		for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_B; i++) {
-			ODM_SetRFReg(pDM_Odm, i, RF_ModeTableAddr, 0xfffff, 0x18000);
-			/*Select RX mode*/
-			ODM_SetRFReg(pDM_Odm, i, RF_ModeTableData0, 0xfffff, 0xBE77F);
-			/*Set Table data*/
-			ODM_SetRFReg(pDM_Odm, i, RF_ModeTableData1, 0xfffff, 0x226BF);
-			/*Enable TXIQGEN in RX mode*/
-		}
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0xE26BF);
-		/*Enable TXIQGEN in RX mode*/
-	}
-
-	for (i = ODM_RF_PATH_A; i < ODM_RF_PATH_B; i++) {
-		ODM_SetRFReg(pDM_Odm, i, RF_WeLut_Jaguar, 0x80000, 0x0);
-		/*RF Mode table write disable*/
-	}
-
-	if (pBeamformingInfo->beamformee_su_cnt > 0) {
-
-		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
-		ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, BIT28|BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
-		
-		if (idx == 0) {
-			/*Nsts = 2	AB*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF0, 0xffff, 0x0433);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, 0xfff00000, 0x043);
-			/*ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x430);*/
-
-		} else {/*IDX =1*/
-			ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, 0xffff, 0x0433);
-			ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, 0xfff00000, 0x043);
-			/*ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x430;*/
-		}
-	} else {
-		ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, 0xfff00000, 0x1); /*1SS by path-A*/
-		ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_2, bMaskLWord, 0x430); /*2SS by path-A,B*/
-	}
-	
-	if (pBeamformingInfo->beamformee_mu_cnt > 0) {
-		/*MU STAs share the common setting*/
-		ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, BIT31, 1);
-		ODM_SetBBReg(pDM_Odm, REG_BB_TXBF_ANT_SET_BF1, 0xffff, 0x0433);
-		ODM_SetBBReg(pDM_Odm, REG_BB_TX_PATH_SEL_1, 0xfff00000, 0x043);
-	}
-
-}
-#if 0
-VOID
-halTxbf8822B_DownloadNDPA(
-	IN	PADAPTER			Adapter,
-	IN	u1Byte				Idx
-	)
-{
-	u1Byte			u1bTmp = 0, tmpReg422 = 0;
-	u1Byte			BcnValidReg = 0, count = 0, DLBcnCount = 0;
-	u2Byte			Head_Page = 0x7FE;
-	BOOLEAN			bSendBeacon = FALSE;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u2Byte			TxPageBndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
-	PRT_BEAMFORMING_INFO	pBeamInfo = GET_BEAMFORM_INFO(Adapter);
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry+Idx;
-
-	pHalData->bFwDwRsvdPageInProgress = TRUE;
-	Adapter->HalFunc.GetHalDefVarHandler(Adapter, HAL_DEF_TX_PAGE_BOUNDARY, (pu2Byte)&TxPageBndy);
-	
-	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1bTmp = PlatformEFIORead1Byte(Adapter, REG_CR_8814A+1);
-	PlatformEFIOWrite1Byte(Adapter,  REG_CR_8814A+1, (u1bTmp|BIT0));
-
-
-	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmpReg422 = PlatformEFIORead1Byte(Adapter, REG_FWHW_TXQ_CTRL_8814A+2);
-	PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL_8814A+2,  tmpReg422&(~BIT6));
-
-	if (tmpReg422 & BIT6) {
-		RT_TRACE(COMP_INIT, DBG_LOUD, ("SetBeamformDownloadNDPA_8814A(): There is an Adapter is sending beacon.\n"));
-		bSendBeacon = TRUE;
-	}
-
-	/*0x204[11:0]	Beacon Head for TXDMA*/
-	PlatformEFIOWrite2Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A, Head_Page);
-	
-	do {		
-		/*Clear beacon valid check bit.*/
-		BcnValidReg = PlatformEFIORead1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A+1);
-		PlatformEFIOWrite1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A+1, (BcnValidReg|BIT7));
-		
-		/*download NDPA rsvd page.*/
-		if (pBeamEntry->BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)
-			Beamforming_SendVHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->AID, pBeamEntry->SoundBW, BEACON_QUEUE);
-		else 
-			Beamforming_SendHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->SoundBW, BEACON_QUEUE);
-	
-		/*check rsvd page download OK.*/
-		BcnValidReg = PlatformEFIORead1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
-		count = 0;
-		while (!(BcnValidReg & BIT7) && count < 20) {
-			count++;
-			delay_us(10);
-			BcnValidReg = PlatformEFIORead1Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A+2);
-		}
-		DLBcnCount++;
-	} while (!(BcnValidReg & BIT7) && DLBcnCount < 5);
-	
-	if (!(BcnValidReg & BIT0))
-		RT_DISP(FBEAM, FBEAM_ERROR, ("%s Download RSVD page failed!\n", __func__));
-
-	/*0x204[11:0]	Beacon Head for TXDMA*/
-	PlatformEFIOWrite2Byte(Adapter, REG_FIFOPAGE_CTRL_2_8814A, TxPageBndy);
-
-	/*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 (bSendBeacon)
-		PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL_8814A+2, tmpReg422);
-
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1bTmp = PlatformEFIORead1Byte(Adapter, REG_CR_8814A+1);
-	PlatformEFIOWrite1Byte(Adapter, REG_CR_8814A+1, (u1bTmp&(~BIT0)));
-
-	pBeamEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSED;
-
-	pHalData->bFwDwRsvdPageInProgress = FALSE;
-}
-
-VOID
-halTxbf8822B_FwTxBFCmd(
-	IN	PADAPTER	Adapter
-	)
-{
-	u1Byte	Idx, Period = 0;
-	u1Byte	PageNum0 = 0xFF, PageNum1 = 0xFF;
-	u1Byte	u1TxBFParm[3] = {0};
-
-	PMGNT_INFO				pMgntInfo = &(Adapter->MgntInfo);
-	PRT_BEAMFORMING_INFO	pBeamInfo = GET_BEAMFORM_INFO(Adapter);
-
-	for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-		if (pBeamInfo->BeamformeeEntry[Idx].bUsed && pBeamInfo->BeamformeeEntry[Idx].BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (pBeamInfo->BeamformeeEntry[Idx].bSound) {
-				PageNum0 = 0xFE;
-				PageNum1 = 0x07;
-				Period = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			} else if (PageNum0 == 0xFF) {
-				PageNum0 = 0xFF; /*stop sounding*/
-				PageNum1 = 0x0F;
-			}
-		}
-	}
-
-	u1TxBFParm[0] = PageNum0;
-	u1TxBFParm[1] = PageNum1;
-	u1TxBFParm[2] = Period;
-	FillH2CCmd(Adapter, PHYDM_H2C_TXBF, 3, u1TxBFParm);
-	
-	RT_DISP(FBEAM, FBEAM_FUN, ("@%s End, PageNum0 = 0x%x, PageNum1 = 0x%x Period = %d", __func__, PageNum0, PageNum1, Period));
-}
-#endif
-
-VOID
-HalTxbf8822B_Init(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte		u1bTmp;
-	PRT_BEAMFORMING_INFO		pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-
-	ODM_SetBBReg(pDM_Odm, 0x14c0 , BIT16, 1); /*Enable P1 aggr new packet according to P0 transfer time*/
-	ODM_SetBBReg(pDM_Odm, 0x14c0 , BIT15|BIT14|BIT13|BIT12, 1); /*MU Retry Limit*/
-	ODM_SetBBReg(pDM_Odm, 0x14c0 , BIT7, 0); /*Disable Tx MU-MIMO until sounding done*/	
-	ODM_SetBBReg(pDM_Odm, 0x14c0 , 0x3F, 0); /* Clear validity of MU STAs */
-	ODM_Write1Byte(pDM_Odm, 0x167c , 0x70); /*MU-MIMO Option as default value*/
-	ODM_Write2Byte(pDM_Odm, 0x1680 , 0); /*MU-MIMO Control as default value*/
-
-	/* Set MU NDPA rate & BW source */
-	/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
-	u1bTmp = ODM_Read1Byte(pDM_Odm, 0x42C);
-	ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8822B, (u1bTmp|BIT6));
-	/* 0x45F[7:0] = 0x10 (Rate=OFDM_6M, BW20) */
-	ODM_Write1Byte(pDM_Odm, REG_NDPA_OPT_CTRL_8822B, 0x10);
-
-	/* Init HW variable */
-	pBeamformingInfo->RegMUTxCtrl = ODM_Read4Byte(pDM_Odm, 0x14c0);
-}
-
-VOID
-HalTxbf8822B_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				BFerBFeeIdx
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					i = 0;
-	u1Byte					BFerIdx = (BFerBFeeIdx & 0xF0)>>4;
-	u1Byte					BFeeIdx = (BFerBFeeIdx & 0xF);
-	u2Byte					CSI_Param = 0;
-	PRT_BEAMFORMING_INFO		pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamformeeEntry;
-	PRT_BEAMFORMER_ENTRY	pBeamformerEntry;
-	u2Byte					value16, STAid = 0;
-	u1Byte					Nc_index = 0, Nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
-	u4Byte					gid_valid, user_position_l, user_position_h;
-	u4Byte					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
-	u1Byte					u1bTmp;
-	u4Byte					u4bTmp;
-	
-	RT_DISP(FBEAM, FBEAM_FUN, ("%s: BFerBFeeIdx=%d, BFerIdx=%d, BFeeIdx=%d\n", __func__, BFerBFeeIdx, BFerIdx, BFeeIdx));
-
-	/*************SU BFer Entry Init*************/
-	if ((pBeamformingInfo->beamformer_su_cnt > 0) && (BFerIdx < BEAMFORMER_ENTRY_NUM)) {
-		pBeamformerEntry = &pBeamformingInfo->BeamformerEntry[BFerIdx];
-		pBeamformerEntry->is_mu_ap = FALSE;
-		/*Sounding protocol control*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8822B, 0xDB);	
-	
-		
-		for (i = 0; i < MAX_BEAMFORMER_SU; i++) {
-			if ((pBeamformingInfo->beamformer_su_reg_maping & BIT(i)) == 0) {
-				pBeamformingInfo->beamformer_su_reg_maping |= BIT(i);
-				pBeamformerEntry->su_reg_index = i;
-				break;
-			}
-		}
-		
-		/*MAC address/Partial AID of Beamformer*/
-		if (pBeamformerEntry->su_reg_index == 0) {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_ASSOCIATED_BFMER0_INFO_8822B+i), pBeamformerEntry->MacAddr[i]);
-		} else {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_ASSOCIATED_BFMER1_INFO_8822B+i), pBeamformerEntry->MacAddr[i]);
-		}
-
-		/*CSI report parameters of Beamformer*/
-		Nc_index = halTxbf8822B_GetNrx(pDM_Odm);	/*for 8814A Nrx = 3(4 Ant), min=0(1 Ant)*/
-		Nr_index = pBeamformerEntry->NumofSoundingDim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so Nr_index don't care*/
-		
-		grouping = 0;
-
-		/*for ac = 1, for n = 3*/
-		if (pBeamformerEntry->BeamformEntryCap & BEAMFORMEE_CAP_VHT_SU)
-			codebookinfo = 1;	
-		else if (pBeamformerEntry->BeamformEntryCap & BEAMFORMEE_CAP_HT_EXPLICIT)
-			codebookinfo = 3;	
-
-		coefficientsize = 3;
-
-		CSI_Param = (u2Byte)((coefficientsize<<10)|(codebookinfo<<8)|(grouping<<6)|(Nr_index<<3)|(Nc_index));
-
-		if (BFerIdx == 0)
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8822B, CSI_Param);
-		else
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8822B+2, CSI_Param);
-		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8814A+3, 0x70);
-	
-	}
-
-	/*************SU BFee Entry Init*************/
-	if ((pBeamformingInfo->beamformee_su_cnt > 0) && (BFeeIdx < BEAMFORMEE_ENTRY_NUM)) {
-		pBeamformeeEntry = &pBeamformingInfo->BeamformeeEntry[BFeeIdx];
-		pBeamformeeEntry->is_mu_sta = FALSE;
-		halTxbf8822B_RfMode(pDM_Odm, pBeamformingInfo, BFeeIdx);
-		
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-			STAid = pBeamformeeEntry->MacId;
-		else 
-			STAid = pBeamformeeEntry->P_AID;
-
-		for (i = 0; i < MAX_BEAMFORMEE_SU; i++) {
-			if ((pBeamformingInfo->beamformee_su_reg_maping & BIT(i)) == 0) {
-				pBeamformingInfo->beamformee_su_reg_maping |= BIT(i);
-				pBeamformeeEntry->su_reg_index = i;
-				break;
-			}
-		}
-		
-		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
-		if (pBeamformeeEntry->su_reg_index == 0) {	
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8822B, STAid);	
-			ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8822B+3, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8822B+3)|BIT4|BIT6|BIT7);
-		} else {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8822B+2, STAid | BIT14 | BIT15 | BIT12);
-		}	
-
-		/*CSI report parameters of Beamformee*/
-		if (pBeamformeeEntry->su_reg_index == 0) {
-			/*Get BIT24 & BIT25*/
-			u1Byte	tmp = ODM_Read1Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8822B+3) & 0x3;
-			
-			ODM_Write1Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3, tmp | 0x60);
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8822B, STAid | BIT9);
-		} else		
-			ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8822B+2, STAid | 0xE200);	/*Set BIT25*/
-			
-			phydm_Beamforming_Notify(pDM_Odm);
-	}
-
-	/*************MU BFer Entry Init*************/
-	if ((pBeamformingInfo->beamformer_mu_cnt > 0) && (BFerIdx < BEAMFORMER_ENTRY_NUM)) {
-		pBeamformerEntry = &pBeamformingInfo->BeamformerEntry[BFerIdx];
-		pBeamformingInfo->mu_ap_index = BFerIdx;
-		pBeamformerEntry->is_mu_ap = TRUE;
-		for (i = 0; i < 8; i++)
-			pBeamformerEntry->gid_valid[i] = 0;
-		for (i = 0; i < 16; i++)
-			pBeamformerEntry->user_position[i] = 0;
-		
-		/*Sounding protocol control*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8822B, 0xDB);	
-		
-		/* MAC address */
-		for (i = 0; i < 6 ; i++)
-			ODM_Write1Byte(pDM_Odm, (REG_ASSOCIATED_BFMER0_INFO_8822B+i), pBeamformerEntry->MacAddr[i]);
-
-		/* Set partial AID */
-		ODM_Write2Byte(pDM_Odm, (REG_ASSOCIATED_BFMER0_INFO_8822B+6), pBeamformerEntry->P_AID);
-
-		/* Fill our AID to 0x1680[11:0] and [13:12] = 2b'00, BF report segment select to 3895 bytes*/
-		u1bTmp = ODM_Read1Byte(pDM_Odm, 0x1680);
-		u1bTmp = (pBeamformerEntry->AID)&0xFFF;
-		ODM_Write1Byte(pDM_Odm, 0x1680, u1bTmp);
-
-		/* Set 80us for leaving ndp_rx_standby_state */
-		ODM_Write1Byte(pDM_Odm, 0x71B, 0x50);
-		
-		/* Set 0x6A0[14] = 1 to accept action_no_ack */
-		u1bTmp = ODM_Read1Byte(pDM_Odm, REG_RXFLTMAP0_8822B+1);
-		u1bTmp |= 0x40;
-		ODM_Write1Byte(pDM_Odm, REG_RXFLTMAP0_8822B+1, u1bTmp);
-		/* Set 0x6A2[5:4] = 1 to NDPA and BF report poll */
-		u1bTmp = ODM_Read1Byte(pDM_Odm, REG_RXFLTMAP1_8822B);
-		u1bTmp |= 0x30;
-		ODM_Write1Byte(pDM_Odm, REG_RXFLTMAP1_8822B, u1bTmp);
-		
-		/*CSI report parameters of Beamformer*/
-		Nc_index = halTxbf8822B_GetNrx(pDM_Odm);	/* Depend on RF type */
-		Nr_index = 1;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so Nr_index don't care*/
-		grouping = 0; /*no grouping*/
-		codebookinfo = 1; /*7 bit for psi, 9 bit for phi*/
-		coefficientsize = 0; /*This is nothing really matter*/ 
-		CSI_Param = (u2Byte)((coefficientsize<<10)|(codebookinfo<<8)|(grouping<<6)|(Nr_index<<3)|(Nc_index));
-		ODM_Write2Byte(pDM_Odm, 0x6F4, CSI_Param);
-
-	}
-	

-	/*************MU BFee Entry Init*************/
-	if ((pBeamformingInfo->beamformee_mu_cnt > 0) && (BFeeIdx < BEAMFORMEE_ENTRY_NUM)) {
-		pBeamformeeEntry = &pBeamformingInfo->BeamformeeEntry[BFeeIdx];
-		pBeamformeeEntry->is_mu_sta = TRUE;
-		for (i = 0; i < MAX_BEAMFORMEE_MU; i++) {
-			if ((pBeamformingInfo->beamformee_mu_reg_maping & BIT(i)) == 0) {
-				pBeamformingInfo->beamformee_mu_reg_maping |= BIT(i);
-				pBeamformeeEntry->mu_reg_index = i;
-				break;
-			}
-		}
-
-		if (pBeamformeeEntry->mu_reg_index == 0xFF) {
-			/* There is no valid bit in beamformee_mu_reg_maping */
-			RT_DISP(FBEAM, FBEAM_FUN, ("%s: ERROR! There is no valid bit in beamformee_mu_reg_maping!\n", __func__));
-			return;
-		}
-		
-		/*User position table*/
-		switch (pBeamformeeEntry->mu_reg_index) {
-		case 0:
-			gid_valid = 0x7fe;
-			user_position_l = 0x111110;
-			user_position_h = 0x0;
-			break;
-		case 1:
-			gid_valid = 0x7f806;
-			user_position_l = 0x11000004;
-			user_position_h = 0x11;
-			break;
-		case 2:
-			gid_valid = 0x1f81818;
-			user_position_l = 0x400040;
-			user_position_h = 0x11100;
-			break;
-		case 3:
-			gid_valid = 0x1e186060;
-			user_position_l = 0x4000400;
-			user_position_h = 0x1100040;
-			break;
-		case 4:
-			gid_valid = 0x66618180;
-			user_position_l = 0x40004000;
-			user_position_h = 0x10040400;
-			break;
-		case 5:
-			gid_valid = 0x79860600;
-			user_position_l = 0x40000;
-			user_position_h = 0x4404004;
-			break;
-		}
-
-		for (i = 0; i < 8; i++) {
-			if (i < 4) {
-				pBeamformeeEntry->gid_valid[i] = (u1Byte)(gid_valid & 0xFF);
-				gid_valid = (gid_valid >> 8);
-			} else
-				pBeamformeeEntry->gid_valid[i] = 0;
-		}
-		for (i = 0; i < 16; i++) {
-			if (i < 4) {
-				pBeamformeeEntry->user_position[i] = (u1Byte)(user_position_l & 0xFF);
-				user_position_l = user_position_l >> 8;
-			} else if (i < 8) {
-				pBeamformeeEntry->user_position[i] = (u1Byte)(user_position_h & 0xFF);
-				user_position_h = user_position_h >> 8;
-			} else
-				pBeamformeeEntry->user_position[i] = 0;
-		}
-
-		/*Sounding protocol control*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8822B, 0xDB);	
-
-		/*select MU STA table*/
-		pBeamformingInfo->RegMUTxCtrl &= ~(BIT8|BIT9|BIT10);
-		pBeamformingInfo->RegMUTxCtrl |= (pBeamformeeEntry->mu_reg_index << 8)&(BIT8|BIT9|BIT10);
-		ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);	
-		
-		ODM_SetBBReg(pDM_Odm, 0x14c4 , bMaskDWord, 0); /*Reset gid_valid table*/
-		ODM_SetBBReg(pDM_Odm, 0x14c8 , bMaskDWord, user_position_l);
-		ODM_SetBBReg(pDM_Odm, 0x14cc , bMaskDWord, user_position_h);
-
-		/*set validity of MU STAs*/		
-		pBeamformingInfo->RegMUTxCtrl &= 0xFFFFFFC0;
-		pBeamformingInfo->RegMUTxCtrl |= pBeamformingInfo->beamformee_mu_reg_maping&0x3F;
-		ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);	
-
-		value16 = ODM_Read2Byte(pDM_Odm, mu_reg[pBeamformeeEntry->mu_reg_index]);
-		value16 &= 0xFE00; /*Clear PAID*/
-		value16 |= BIT9; /*Enable MU BFee*/
-		value16 |= pBeamformeeEntry->P_AID;
-		ODM_Write2Byte(pDM_Odm, mu_reg[pBeamformeeEntry->mu_reg_index] , value16);
-		
-		/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
-		u1bTmp = ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8822B+3);
-		u1bTmp |= 0xD0; /* Set bit 28, 30, 31 to 3b'111*/
-		ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8822B+3, u1bTmp);
-		/* Set NDPA to 6M*/
-		ODM_Write1Byte(pDM_Odm, REG_NDPA_RATE_8822B, 0x4); /* 6M */
-
-		u1bTmp = ODM_Read1Byte(pDM_Odm, REG_NDPA_OPT_CTRL_8822B);
-		u1bTmp &= 0xFC; /* Clear bit 0, 1*/
-		ODM_Write1Byte(pDM_Odm, REG_NDPA_OPT_CTRL_8822B, u1bTmp);
-
-		u4bTmp = ODM_Read4Byte(pDM_Odm, REG_SND_PTCL_CTRL_8822B);
-		u4bTmp = ((u4bTmp & 0xFF0000FF) | 0x020200); /* Set [23:8] to 0x0202 */
-		ODM_Write4Byte(pDM_Odm, REG_SND_PTCL_CTRL_8822B, u4bTmp);	
-
-		/* Set 0x6A0[14] = 1 to accept action_no_ack */
-		u1bTmp = ODM_Read1Byte(pDM_Odm, REG_RXFLTMAP0_8822B+1);
-		u1bTmp |= 0x40;
-		ODM_Write1Byte(pDM_Odm, REG_RXFLTMAP0_8822B+1, u1bTmp);
-		/* End of MAC registers setting */
-		
-		halTxbf8822B_RfMode(pDM_Odm, pBeamformingInfo, BFeeIdx);
-#if (SUPPORT_MU_BF == 1)
-		/*Special for plugfest*/
-		delay_ms(50); /* wait for 4-way handshake ending*/
-		SendSWVHTGIDMgntFrame(pDM_Odm, pBeamformeeEntry->MacAddr, BFeeIdx);
-#endif		
-
-		phydm_Beamforming_Notify(pDM_Odm);
-
-	}
-
-}
-
-
-VOID
-HalTxbf8822B_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMER_ENTRY	pBeamformerEntry; 
-	PRT_BEAMFORMEE_ENTRY	pBeamformeeEntry;
-	u4Byte					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
-
-	if (Idx < BEAMFORMER_ENTRY_NUM) {
-		pBeamformerEntry = &pBeamformingInfo->BeamformerEntry[Idx];
-		pBeamformeeEntry = &pBeamformingInfo->BeamformeeEntry[Idx];
-	} else
-		return;
-
-	/*Clear P_AID of Beamformee*/
-	/*Clear MAC address of Beamformer*/
-	/*Clear Associated Bfmee Sel*/
-
-	if (pBeamformerEntry->BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8822B, 0xD8);	
-		if (pBeamformerEntry->is_mu_ap == 0) { /*SU BFer */
-			if (pBeamformerEntry->su_reg_index == 0) {	
-				ODM_Write4Byte(pDM_Odm, REG_ASSOCIATED_BFMER0_INFO_8822B, 0);
-				ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMER0_INFO_8822B+4, 0);
-				ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8822B, 0);
-			} else {
-				ODM_Write4Byte(pDM_Odm, REG_ASSOCIATED_BFMER1_INFO_8822B, 0);
-				ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMER1_INFO_8822B+4, 0);
-				ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8822B+2, 0);
-			}
-			pBeamformingInfo->beamformer_su_reg_maping &= ~(BIT(pBeamformerEntry->su_reg_index));
-			pBeamformerEntry->su_reg_index = 0xFF;
-		} else { /*MU BFer */
-			/*set validity of MU STA0 and MU STA1*/
-			pBeamformingInfo->RegMUTxCtrl &= 0xFFFFFFC0;
-			ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);
-			
-			ODM_Memory_Set(pDM_Odm, pBeamformerEntry->gid_valid, 0, 8);
-			ODM_Memory_Set(pDM_Odm, pBeamformerEntry->user_position, 0, 16);
-			pBeamformerEntry->is_mu_ap = FALSE;
-		}
-	}
-
-	if (pBeamformeeEntry->BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		halTxbf8822B_RfMode(pDM_Odm, pBeamformingInfo, Idx);
-		if (pBeamformeeEntry->is_mu_sta == 0) { /*SU BFee*/
-			if (pBeamformeeEntry->su_reg_index == 0) {	
-				ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8822B, 0x0);	
-				ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8822B+3, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8822B+3)|BIT4|BIT6|BIT7);
-				ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8822B, 0);
-			} else {
-				ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8822B+2, 0x0 | BIT14 | BIT15 | BIT12);
-
-				ODM_Write2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8822B+2, 
-				ODM_Read2Byte(pDM_Odm, REG_ASSOCIATED_BFMEE_SEL_8822B+2) & 0x60);
-			}
-			pBeamformingInfo->beamformee_su_reg_maping &= ~(BIT(pBeamformeeEntry->su_reg_index));
-			pBeamformeeEntry->su_reg_index = 0xFF;
-		} else { /*MU BFee */
-			/*Disable sending NDPA & BF-rpt-poll to this BFee*/
-			ODM_Write2Byte(pDM_Odm, mu_reg[pBeamformeeEntry->mu_reg_index] , 0);
-			/*set validity of MU STA*/
-			pBeamformingInfo->RegMUTxCtrl &= ~(BIT(pBeamformeeEntry->mu_reg_index));
-			ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);
-			
-			
-			pBeamformeeEntry->is_mu_sta = FALSE;
-			pBeamformingInfo->beamformee_mu_reg_maping &= ~(BIT(pBeamformeeEntry->mu_reg_index));
-			pBeamformeeEntry->mu_reg_index = 0xFF;
-		}
-	}
-}
-
-
-/***********SU & MU BFee Entry Only when souding done****************/
-VOID
-HalTxbf8822B_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte					BeamCtrlVal, tmpVal;
-	u4Byte					BeamCtrlReg;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry;
-	BOOLEAN	is_mu_sounding = pBeamformingInfo->is_mu_sounding, is_bitmap_ready = FALSE;
-	u16 bitmap;
-	u8 idx, gid, i;
-	u8 id1, id0;
-	u32 gid_valid[6] = {0};
-	u32 user_position_lsb[6] = {0};
-	u32 user_position_msb[6] = {0};
-	u32 value32;
-
-	if (Idx < BEAMFORMEE_ENTRY_NUM)
-		pBeamformEntry = &pBeamformingInfo->BeamformeeEntry[Idx];
-	else
-		return;
-	
-	/*SU sounding done */
-	if (is_mu_sounding == FALSE) {
-
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-			BeamCtrlVal = pBeamformEntry->MacId;
-		else 
-			BeamCtrlVal = pBeamformEntry->P_AID;
-
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("@%s, BeamformEntry.BeamformEntryState = %d", __func__, pBeamformEntry->BeamformEntryState));
-
-		if (pBeamformEntry->su_reg_index == 0) {
-			BeamCtrlReg = REG_TXBF_CTRL_8822B;
-		} else {
-			BeamCtrlReg = REG_TXBF_CTRL_8822B+2;
-			BeamCtrlVal |= BIT12|BIT14|BIT15;
-		}
-
-		if (pBeamformEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (pBeamformEntry->SoundBW == CHANNEL_WIDTH_20)
-				BeamCtrlVal |= BIT9;
-			else if (pBeamformEntry->SoundBW == CHANNEL_WIDTH_40)
-				BeamCtrlVal |= (BIT9|BIT10);
-			else if (pBeamformEntry->SoundBW == CHANNEL_WIDTH_80)
-				BeamCtrlVal |= (BIT9|BIT10|BIT11);		
-		} else {
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("@%s, Don't apply Vmatrix",  __func__));
-			BeamCtrlVal &= ~(BIT9|BIT10|BIT11);
-		}
-
-		ODM_Write2Byte(pDM_Odm, BeamCtrlReg, BeamCtrlVal);
-		/*disable NDP packet use beamforming */
-		tmpVal = ODM_Read2Byte(pDM_Odm, REG_TXBF_CTRL_8822B);
-		ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8822B, tmpVal|BIT15);
-	} else {
-		/*MU sounding done */
-		if (pBeamformEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			/*value32 = ODM_GetBBReg(pDM_Odm, 0xF4C, 0xFFFF0000);*/
-			value32 = 1;
-			
-			is_bitmap_ready = (BOOLEAN)((value32 & BIT15) >> 15);
-			bitmap = (u16)(value32 & 0x3FFF);
-		
-			for (idx = 0; idx < 15; idx++) {
-				if (idx < 5) {/*bit0~4*/
-					id0 = 0;
-					id1 = (u8)(idx + 1);
-				} else if (idx < 9) { /*bit5~8*/
-					id0 = 1;
-					id1 = (u8)(idx - 3);
-				} else if (idx < 12) { /*bit9~11*/
-					id0 = 2;
-					id1 = (u8)(idx - 6);
-				} else if (idx < 14) { /*bit12~13*/	
-					id0 = 3;
-					id1 = (u8)(idx - 8);
-				} else { /*bit14*/
-					id0 = 4;
-					id1 = (u8)(idx - 9);
-				}
-				if (bitmap & BIT(idx)) {
-					/*Pair 1*/
-					gid = (idx << 1) + 1;
-					gid_valid[id0] |= (BIT(gid));
-					gid_valid[id1] |= (BIT(gid));
-					/*Pair 2*/
-					gid += 1;
-					gid_valid[id0] |= (BIT(gid));
-					gid_valid[id1] |= (BIT(gid));
-				} else {
-					/*Pair 1*/
-					gid = (idx << 1) + 1;
-					gid_valid[id0] &= ~(BIT(gid));
-					gid_valid[id1] &= ~(BIT(gid));
-					/*Pair 2*/
-					gid += 1;
-					gid_valid[id0] &= ~(BIT(gid));
-					gid_valid[id1] &= ~(BIT(gid));
-				}
-			}
-
-			for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-				pBeamformEntry = &pBeamformingInfo->BeamformeeEntry[i];
-				if ((pBeamformEntry->is_mu_sta) && (pBeamformEntry->mu_reg_index < 6)) {
-					value32 = gid_valid[pBeamformEntry->mu_reg_index];
-					for (idx = 0; idx < 4; idx++) {
-						pBeamformEntry->gid_valid[idx] = (u8)(value32 & 0xFF);
-						value32 = (value32 >> 8);
-					}
-				}
-			}
-
-			for (idx = 0; idx < 6; idx++) {
-				pBeamformingInfo->RegMUTxCtrl |= ~(BIT8|BIT9|BIT10);
-				pBeamformingInfo->RegMUTxCtrl |= ((idx<<8)&(BIT8|BIT9|BIT10));
-				ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);
-				ODM_SetMACReg(pDM_Odm, 0x14C4, bMaskDWord, gid_valid[idx]); /*set MU STA gid valid table*/
-			}
-
-			/*Enable TxMU PPDU*/
-			pBeamformingInfo->RegMUTxCtrl |= BIT7;
-			ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);
-		}
-	}
-}
-
-/*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
-VOID
-HalTxbf8822B_ConfigGtab(
-	IN PVOID			pDM_VOID
-	)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMER_ENTRY	pBeamformerEntry = NULL;
-	u4Byte		gid_valid = 0, user_position_l = 0, user_position_h = 0, i;
-
-	if (pBeamformingInfo->mu_ap_index < BEAMFORMER_ENTRY_NUM)
-		pBeamformerEntry = &pBeamformingInfo->BeamformerEntry[pBeamformingInfo->mu_ap_index];
-	else
-		return;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s==>\n", __func__));
-
-	/*For GID 0~31*/
-	for (i = 0; i < 4; i++)
-		gid_valid |= (pBeamformerEntry->gid_valid[i] << (i<<3));
-	for (i = 0; i < 8; i++) {
-		if (i < 4)
-			user_position_l |= (pBeamformerEntry->user_position[i] << (i << 3));
-		else
-			user_position_h |= (pBeamformerEntry->user_position[i] << ((i - 4)<<3));
-	}
-	/*select MU STA0 table*/
-	pBeamformingInfo->RegMUTxCtrl &= ~(BIT8|BIT9|BIT10);
-	ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);
-	ODM_SetBBReg(pDM_Odm, 0x14c4, bMaskDWord, gid_valid); 
-	ODM_SetBBReg(pDM_Odm, 0x14c8, bMaskDWord, user_position_l);
-	ODM_SetBBReg(pDM_Odm, 0x14cc, bMaskDWord, user_position_h);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: STA0: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
-		__func__, gid_valid, user_position_l, user_position_h));
-
-	gid_valid = 0;
-	user_position_l = 0;
-	user_position_h = 0;
-
-	/*For GID 32~64*/
-	for (i = 4; i < 8; i++)
-		gid_valid |= (pBeamformerEntry->gid_valid[i] << ((i - 4)<<3));
-	for (i = 8; i < 16; i++) {
-		if (i < 4)
-			user_position_l |= (pBeamformerEntry->user_position[i] << ((i - 8) << 3));
-		else
-			user_position_h |= (pBeamformerEntry->user_position[i] << ((i - 12) << 3));
-	}
-	/*select MU STA1 table*/
-	pBeamformingInfo->RegMUTxCtrl &= ~(BIT8|BIT9|BIT10);
-	pBeamformingInfo->RegMUTxCtrl |= BIT8;
-	ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);
-	ODM_SetBBReg(pDM_Odm, 0x14c4, bMaskDWord, gid_valid); 
-	ODM_SetBBReg(pDM_Odm, 0x14c8, bMaskDWord, user_position_l);
-	ODM_SetBBReg(pDM_Odm, 0x14cc, bMaskDWord, user_position_h);
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s: STA1: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
-		__func__, gid_valid, user_position_l, user_position_h));
-
-	/* Set validity of MU STA0 and MU STA1*/
-	pBeamformingInfo->RegMUTxCtrl &= 0xFFFFFFC0;
-	pBeamformingInfo->RegMUTxCtrl |= 0x3; /* STA0, STA1*/
-	ODM_Write4Byte(pDM_Odm, 0x14c0, pBeamformingInfo->RegMUTxCtrl);
-	
-}
-
-
-
-#if 0
-/*This function translate the bitmap to GTAB*/
-VOID
-haltxbf8822b_gtab_translation(
-	IN PDM_ODM_T			pDM_Odm
-) 
-{
-	u8 idx, gid;
-	u8 id1, id0;
-	u32 gid_valid[6] = {0};
-	u32 user_position_lsb[6] = {0};
-	u32 user_position_msb[6] = {0};
-	
-	for (idx = 0; idx < 15; idx++) {
-		if (idx < 5) {/*bit0~4*/
-			id0 = 0;
-			id1 = (u8)(idx + 1);
-		} else if (idx < 9) { /*bit5~8*/
-			id0 = 1;
-			id1 = (u8)(idx - 3);
-		} else if (idx < 12) { /*bit9~11*/
-			id0 = 2;
-			id1 = (u8)(idx - 6);
-		} else if (idx < 14) { /*bit12~13*/	
-			id0 = 3;
-			id1 = (u8)(idx - 8);
-		} else { /*bit14*/
-			id0 = 4;
-			id1 = (u8)(idx - 9);
-		}
-
-		/*Pair 1*/
-		gid = (idx << 1) + 1;
-		gid_valid[id0] |= (1 << gid);
-		gid_valid[id1] |= (1 << gid);
-		if (gid < 16) {
-			/*user_position_lsb[id0] |= (0 << (gid << 1));*/
-			user_position_lsb[id1] |= (1 << (gid << 1));
-		} else {
-			/*user_position_msb[id0] |= (0 << ((gid - 16) << 1));*/
-			user_position_msb[id1] |= (1 << ((gid - 16) << 1));
-		}
-		
-		/*Pair 2*/
-		gid += 1;
-		gid_valid[id0] |= (1 << gid);
-		gid_valid[id1] |= (1 << gid);
-		if (gid < 16) {
-			user_position_lsb[id0] |= (1 << (gid << 1));
-			/*user_position_lsb[id1] |= (0 << (gid << 1));*/
-		} else {
-			user_position_msb[id0] |= (1 << ((gid - 16) << 1));
-			/*user_position_msb[id1] |= (0 << ((gid - 16) << 1));*/
-		}
-
-	}
-
-
-	for (idx = 0; idx < 6; idx++) {
-		/*DbgPrint("gid_valid[%d] = 0x%x\n", idx, gid_valid[idx]);
-		DbgPrint("user_position[%d] = 0x%x   %x\n", idx, user_position_msb[idx], user_position_lsb[idx]);*/
-	}
-}
-#endif
-
-VOID
-HalTxbf8822B_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-	)
-{
-#if 0
-	PRT_BEAMFORMING_INFO	pBeamInfo = GET_BEAMFORM_INFO(Adapter);
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry+Idx;
-
-	if (pBeamEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		halTxbf8822B_DownloadNDPA(Adapter, Idx);
-
-	halTxbf8822B_FwTxBFCmd(Adapter);
-#endif
-}
-
-#else	/* (RTL8822B_SUPPORT == 1)*/
-
-#endif	/* (RTL8822B_SUPPORT == 1)*/
-
-#endif /*(BEAMFORMING_SUPPORT == 1)*/
-
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8814A TXBF mechanism                     */
+/*                                                           */
+/*============================================================*/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (RTL8822B_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+u8
+hal_txbf_8822b_get_ntx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			ntx = 0;
+
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (dm->support_interface == ODM_ITRF_USB) {
+		if (*dm->hub_usb_mode == 2) {/*USB3.0*/
+			if (dm->rf_type == RF_4T4R)
+				ntx = 3;
+			else if (dm->rf_type == RF_3T3R)
+				ntx = 2;
+			else
+				ntx = 1;
+		} else if (*dm->hub_usb_mode == 1)	/*USB 2.0 always 2Tx*/
+			ntx = 1;
+		else
+			ntx = 1;
+	} else
+#endif
+	{
+		if (dm->rf_type == RF_4T4R)
+			ntx = 3;
+		else if (dm->rf_type == RF_3T3R)
+			ntx = 2;
+		else
+			ntx = 1;
+	}
+
+	return ntx;
+
+}
+
+u8
+hal_txbf_8822b_get_nrx(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			nrx = 0;
+
+	if (dm->rf_type == RF_4T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_3T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T2R)
+		nrx = 1;
+	else if (dm->rf_type == RF_2T3R)
+		nrx = 2;
+	else if (dm->rf_type == RF_2T4R)
+		nrx = 3;
+	else if (dm->rf_type == RF_1T1R)
+		nrx = 0;
+	else if (dm->rf_type == RF_1T2R)
+		nrx = 1;
+	else
+		nrx = 0;
+
+	return nrx;
+
+}
+
+/***************SU & MU BFee Entry********************/
+void
+hal_txbf_8822b_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beamforming_info,
+	u8					idx
+)
+{
+#if 0
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8				i, nr_index = 0;
+	boolean				is_self_beamformer = false;
+	boolean				is_self_beamformee = false;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMEE_ENTRY_NUM)
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	else
+		return;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	for (i = RF_PATH_A; i < RF_PATH_B; i++) {
+		odm_set_rf_reg(dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x1);
+		/*RF mode table write enable*/
+	}
+
+	if ((beamforming_info->beamformee_su_cnt > 0) || (beamforming_info->beamformee_mu_cnt > 0)) {
+		for (i = RF_PATH_A; i < RF_PATH_B; i++) {
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_addr, 0xfffff, 0x18000);
+			/*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_data0, 0xfffff, 0xBE77F);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_data1, 0xfffff, 0x226BF);
+			/*Enable TXIQGEN in RX mode*/
+		}
+		odm_set_rf_reg(dm, RF_PATH_A, rf_mode_table_data1, 0xfffff, 0xE26BF);
+		/*Enable TXIQGEN in RX mode*/
+	}
+
+	for (i = RF_PATH_A; i < RF_PATH_B; i++) {
+		odm_set_rf_reg(dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x0);
+		/*RF mode table write disable*/
+	}
+
+	if (beamforming_info->beamformee_su_cnt > 0) {
+
+		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
+
+		if (idx == 0) {
+			/*Nsts = 2	AB*/
+			odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8822B, 0xffff, 0x0433);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+			/*odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430);*/
+
+		} else {/*IDX =1*/
+			odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+			/*odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430;*/
+		}
+	} else {
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*1SS by path-A*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*2SS by path-A,B*/
+	}
+
+	if (beamforming_info->beamformee_mu_cnt > 0) {
+		/*MU STAs share the common setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1);
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+	}
+#endif
+}
+#if 0
+void
+hal_txbf_8822b_download_ndpa(
+	void			*adapter,
+	u8				idx
+)
+{
+	u8			u1b_tmp = 0, tmp_reg422 = 0;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	u16			head_page = 0x7FE;
+	boolean			is_send_beacon = false;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	hal_data->is_fw_dw_rsvd_page_in_progress = true;
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = platform_efio_read_1byte(adapter, REG_CR_8814A + 1);
+	platform_efio_write_1byte(adapter,  REG_CR_8814A + 1, (u1b_tmp | BIT(0)));
+
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = platform_efio_read_1byte(adapter, REG_FWHW_TXQ_CTRL_8814A + 2);
+	platform_efio_write_1byte(adapter, REG_FWHW_TXQ_CTRL_8814A + 2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		RT_TRACE(COMP_INIT, DBG_LOUD, ("SetBeamformDownloadNDPA_8814A(): There is an adapter is sending beacon.\n"));
+		is_send_beacon = true;
+	}
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	platform_efio_write_2byte(adapter, REG_FIFOPAGE_CTRL_2_8814A, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		platform_efio_write_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1, (bcn_valid_reg | BIT(7)));
+
+		/*download NDPA rsvd page.*/
+		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
+		else
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(7)) && count < 20) {
+			count++;
+			delay_us(10);
+			bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(7)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(0)))
+		RT_DISP(FBEAM, FBEAM_ERROR, ("%s Download RSVD page failed!\n", __func__));
+
+	/*0x204[11:0]	Beacon Head for TXDMA*/
+	platform_efio_write_2byte(adapter, REG_FIFOPAGE_CTRL_2_8814A, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		platform_efio_write_1byte(adapter, REG_FWHW_TXQ_CTRL_8814A + 2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = platform_efio_read_1byte(adapter, REG_CR_8814A + 1);
+	platform_efio_write_1byte(adapter, REG_CR_8814A + 1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+
+	hal_data->is_fw_dw_rsvd_page_in_progress = false;
+}
+
+void
+hal_txbf_8822b_fw_txbf_cmd(
+	void	*adapter
+)
+{
+	u8	idx, period = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+
+	PMGNT_INFO				mgnt_info = &(adapter->MgntInfo);
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beam_info->beamformee_entry[idx].is_sound) {
+				PageNum0 = 0xFE;
+				PageNum1 = 0x07;
+				period = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (PageNum0 == 0xFF) {
+				PageNum0 = 0xFF; /*stop sounding*/
+				PageNum1 = 0x0F;
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = period;
+	fill_h2c_cmd(adapter, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	RT_DISP(FBEAM, FBEAM_FUN, ("@%s End, PageNum0 = 0x%x, PageNum1 = 0x%x period = %d", __func__, PageNum0, PageNum1, period));
+}
+#endif
+
+#if 0
+void
+hal_txbf_8822b_init(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		u1b_tmp;
+	struct _RT_BEAMFORMING_INFO		*beamforming_info = &dm->beamforming_info;
+	void				*adapter = dm->adapter;
+
+	odm_set_bb_reg(dm, 0x14c0, BIT(16), 1); /*Enable P1 aggr new packet according to P0 transfer time*/
+	odm_set_bb_reg(dm, 0x14c0, BIT(15) | BIT14 | BIT13 | BIT12, 10); /*MU Retry Limit*/
+	odm_set_bb_reg(dm, 0x14c0, BIT(7), 0); /*Disable Tx MU-MIMO until sounding done*/
+	odm_set_bb_reg(dm, 0x14c0, 0x3F, 0); /* Clear validity of MU STAs */
+	odm_write_1byte(dm, 0x167c, 0x70); /*MU-MIMO Option as default value*/
+	odm_write_2byte(dm, 0x1680, 0); /*MU-MIMO Control as default value*/
+
+	/* Set MU NDPA rate & BW source */
+	/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+	u1b_tmp = odm_read_1byte(dm, 0x42C);
+	odm_write_1byte(dm, REG_TXBF_CTRL_8822B, (u1b_tmp | BIT(6)));
+	/* 0x45F[7:0] = 0x10 (rate=OFDM_6M, BW20) */
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8822B, 0x10);
+
+	/*Temp Settings*/
+	odm_set_bb_reg(dm, 0x6DC, 0x3F000000, 4); /*STA2's CSI rate is fixed at 6M*/
+	odm_set_bb_reg(dm, 0x1C94, MASKDWORD, 0xAFFFAFFF); /*Grouping bitmap parameters*/
+
+	/* Init HW variable */
+	beamforming_info->reg_mu_tx_ctrl = odm_read_4byte(dm, 0x14c0);
+
+	if (dm->rf_type == RF_2T2R) { /*2T2R*/
+		PHYDM_DBG(dm, DBG_TXBF, "%s: rf_type is 2T2R\n", __func__);
+		config_phydm_trx_mode_8822b(dm, (enum bb_path)3, (enum bb_path)3, true);/*Tx2path*/
+	}
+
+#if (OMNIPEEK_SNIFFER_ENABLED == 1)
+	/* Config HW to receive packet on the user position from registry for sniffer mode. */
+	/* odm_set_bb_reg(dm, 0xB00, BIT(9), 1);*/ /* For A-cut only. RegB00[9] = 1 (enable PMAC Rx) */
+	odm_set_bb_reg(dm, 0xB54, BIT(30), 1); /* RegB54[30] = 1 (force user position) */
+	odm_set_bb_reg(dm, 0xB54, (BIT(29) | BIT28), adapter->MgntInfo.sniff_user_position); /* RegB54[29:28] = user position (0~3) */
+	PHYDM_DBG(dm, DBG_TXBF, "Set adapter->MgntInfo.sniff_user_position=%#X\n", adapter->MgntInfo.sniff_user_position);
+#endif
+}
+#endif
+
+void
+hal_txbf_8822b_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	u16					csi_param = 0;
+	struct _RT_BEAMFORMING_INFO		*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	*beamformer_entry;
+	u16					value16, sta_id = 0;
+	u8					nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
+	u32					gid_valid, user_position_l, user_position_h;
+	u32					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
+	u8					u1b_tmp;
+	u32					u4b_tmp;
+
+	RT_DISP(FBEAM, FBEAM_FUN, ("%s: bfer_bfee_idx=%d, bfer_idx=%d, bfee_idx=%d\n", __func__, bfer_bfee_idx, bfer_idx, bfee_idx));
+
+	/*************SU BFer Entry Init*************/
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = &beamforming_info->beamformer_entry[bfer_idx];
+		beamformer_entry->is_mu_ap = false;
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+
+		for (i = 0; i < MAX_BEAMFORMER_SU; i++) {
+			if ((beamforming_info->beamformer_su_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformer_su_reg_maping |= BIT(i);
+				beamformer_entry->su_reg_index = i;
+				break;
+			}
+		}
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (beamformer_entry->su_reg_index == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), beamformer_entry->mac_addr[i]);
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8822B + i), beamformer_entry->mac_addr[i]);
+		}
+
+		/*CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8822b_get_nrx(dm);	/*for 8814A nrx = 3(4 ant), min=0(1 ant)*/
+		nr_index = beamformer_entry->num_of_sounding_dim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+
+		grouping = 0;
+
+		/*for ac = 1, for n = 3*/
+		if (beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU)
+			codebookinfo = 1;
+		else if (beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
+			codebookinfo = 3;
+
+		coefficientsize = 3;
+
+		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
+
+		if (bfer_idx == 0)
+			odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, csi_param);
+		else
+			odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, csi_param);
+		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B + 3, 0x70);
+
+	}
+
+	/*************SU BFee Entry Init*************/
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		p_beamformee_entry = &beamforming_info->beamformee_entry[bfee_idx];
+		p_beamformee_entry->is_mu_sta = false;
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, bfee_idx);
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = p_beamformee_entry->mac_id;
+		else
+			sta_id = p_beamformee_entry->p_aid;
+
+		for (i = 0; i < MAX_BEAMFORMEE_SU; i++) {
+			if ((beamforming_info->beamformee_su_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformee_su_reg_maping |= BIT(i);
+				p_beamformee_entry->su_reg_index = i;
+				break;
+			}
+		}
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (p_beamformee_entry->su_reg_index == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8822B, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8822B + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
+
+		/*CSI report parameters of Beamformee*/
+		if (p_beamformee_entry->su_reg_index == 0) {
+			/*Get BIT24 & BIT25*/
+			u8	tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3) & 0x3;
+
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B, sta_id | BIT(9));
+		} else
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2, sta_id | 0xE200);	/*Set BIT25*/
+
+		phydm_beamforming_notify(dm);
+	}
+
+	/*************MU BFer Entry Init*************/
+	if ((beamforming_info->beamformer_mu_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = &beamforming_info->beamformer_entry[bfer_idx];
+		beamforming_info->mu_ap_index = bfer_idx;
+		beamformer_entry->is_mu_ap = true;
+		for (i = 0; i < 8; i++)
+			beamformer_entry->gid_valid[i] = 0;
+		for (i = 0; i < 16; i++)
+			beamformer_entry->user_position[i] = 0;
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+		/* MAC address */
+		for (i = 0; i < 6 ; i++)
+			odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), beamformer_entry->mac_addr[i]);
+
+		/* Set partial AID */
+		odm_write_2byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + 6), beamformer_entry->p_aid);
+
+		/* Fill our AID to 0x1680[11:0] and [13:12] = 2b'00, BF report segment select to 3895 bytes*/
+		u1b_tmp = odm_read_1byte(dm, 0x1680);
+		u1b_tmp = (beamformer_entry->p_aid) & 0xFFF;
+		odm_write_1byte(dm, 0x1680, u1b_tmp);
+
+		/* Set 80us for leaving ndp_rx_standby_state */
+		odm_write_1byte(dm, 0x71B, 0x50);
+
+		/* Set 0x6A0[14] = 1 to accept action_no_ack */
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP0_8822B + 1);
+		u1b_tmp |= 0x40;
+		odm_write_1byte(dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
+		/* Set 0x6A2[5:4] = 1 to NDPA and BF report poll */
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP1_8822B);
+		u1b_tmp |= 0x30;
+		odm_write_1byte(dm, REG_RXFLTMAP1_8822B, u1b_tmp);
+
+		/*CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8822b_get_nrx(dm);	/* Depend on RF type */
+		nr_index = 1;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+		grouping = 0; /*no grouping*/
+		codebookinfo = 1; /*7 bit for psi, 9 bit for phi*/
+		coefficientsize = 0; /*This is nothing really matter*/
+		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
+		odm_write_2byte(dm, 0x6F4, csi_param);
+
+		/*for B-cut*/
+		odm_set_bb_reg(dm, 0x6A0, BIT(20), 0);
+		odm_set_bb_reg(dm, 0x688, BIT(20), 0);
+
+	}
+
+	/*************MU BFee Entry Init*************/
+	if ((beamforming_info->beamformee_mu_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		p_beamformee_entry = &beamforming_info->beamformee_entry[bfee_idx];
+		p_beamformee_entry->is_mu_sta = true;
+		for (i = 0; i < MAX_BEAMFORMEE_MU; i++) {
+			if ((beamforming_info->beamformee_mu_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformee_mu_reg_maping |= BIT(i);
+				p_beamformee_entry->mu_reg_index = i;
+				break;
+			}
+		}
+
+		if (p_beamformee_entry->mu_reg_index == 0xFF) {
+			/* There is no valid bit in beamformee_mu_reg_maping */
+			RT_DISP(FBEAM, FBEAM_FUN, ("%s: ERROR! There is no valid bit in beamformee_mu_reg_maping!\n", __func__));
+			return;
+		}
+
+		/*User position table*/
+		switch (p_beamformee_entry->mu_reg_index) {
+		case 0:
+			gid_valid = 0x7fe;
+			user_position_l = 0x111110;
+			user_position_h = 0x0;
+			break;
+		case 1:
+			gid_valid = 0x7f806;
+			user_position_l = 0x11000004;
+			user_position_h = 0x11;
+			break;
+		case 2:
+			gid_valid = 0x1f81818;
+			user_position_l = 0x400040;
+			user_position_h = 0x11100;
+			break;
+		case 3:
+			gid_valid = 0x1e186060;
+			user_position_l = 0x4000400;
+			user_position_h = 0x1100040;
+			break;
+		case 4:
+			gid_valid = 0x66618180;
+			user_position_l = 0x40004000;
+			user_position_h = 0x10040400;
+			break;
+		case 5:
+			gid_valid = 0x79860600;
+			user_position_l = 0x40000;
+			user_position_h = 0x4404004;
+			break;
+		}
+
+		for (i = 0; i < 8; i++) {
+			if (i < 4) {
+				p_beamformee_entry->gid_valid[i] = (u8)(gid_valid & 0xFF);
+				gid_valid = (gid_valid >> 8);
+			} else
+				p_beamformee_entry->gid_valid[i] = 0;
+		}
+		for (i = 0; i < 16; i++) {
+			if (i < 4)
+				p_beamformee_entry->user_position[i] = (u8)((user_position_l >> (i * 8)) & 0xFF);
+			else if (i < 8)
+				p_beamformee_entry->user_position[i] = (u8)((user_position_h >> ((i - 4) * 8)) & 0xFF);
+			else
+				p_beamformee_entry->user_position[i] = 0;
+		}
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+
+		/*select MU STA table*/
+		beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+		beamforming_info->reg_mu_tx_ctrl |= (p_beamformee_entry->mu_reg_index << 8) & (BIT(8) | BIT(9) | BIT(10));
+		odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+		odm_set_bb_reg(dm, 0x14c4, MASKDWORD, 0); /*Reset gid_valid table*/
+		odm_set_bb_reg(dm, 0x14c8, MASKDWORD, user_position_l);
+		odm_set_bb_reg(dm, 0x14cc, MASKDWORD, user_position_h);
+
+		/*set validity of MU STAs*/
+		beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+		beamforming_info->reg_mu_tx_ctrl |= beamforming_info->beamformee_mu_reg_maping & 0x3F;
+		odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, reg_mu_tx_ctrl = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+			__func__, beamforming_info->reg_mu_tx_ctrl, user_position_l, user_position_h);
+
+		value16 = odm_read_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index]);
+		value16 &= 0xFE00; /*Clear PAID*/
+		value16 |= BIT(9); /*Enable MU BFee*/
+		value16 |= p_beamformee_entry->p_aid;
+		odm_write_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index], value16);
+
+		/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+		u1b_tmp = odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3);
+		u1b_tmp |= 0xD0; /* Set bit 28, 30, 31 to 3b'111*/
+		odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, u1b_tmp);
+		/* Set NDPA to 6M*/
+		odm_write_1byte(dm, REG_NDPA_RATE_8822B, 0x4);
+
+		u1b_tmp = odm_read_1byte(dm, REG_NDPA_OPT_CTRL_8822B);
+		u1b_tmp &= 0xFC; /* Clear bit 0, 1*/
+		odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8822B, u1b_tmp);
+
+		u4b_tmp = odm_read_4byte(dm, REG_SND_PTCL_CTRL_8822B);
+		u4b_tmp = ((u4b_tmp & 0xFF0000FF) | 0x020200); /* Set [23:8] to 0x0202*/
+		odm_write_4byte(dm, REG_SND_PTCL_CTRL_8822B, u4b_tmp);
+
+		/* Set 0x6A0[14] = 1 to accept action_no_ack */
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP0_8822B + 1);
+		u1b_tmp |= 0x40;
+		odm_write_1byte(dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
+		/* End of MAC registers setting */
+
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, bfee_idx);
+#if (SUPPORT_MU_BF == 1)
+		/*Special for plugfest*/
+		delay_ms(50); /* wait for 4-way handshake ending*/
+		send_sw_vht_gid_mgnt_frame(dm, p_beamformee_entry->mac_addr, bfee_idx);
+#endif
+
+		phydm_beamforming_notify(dm);
+#if 1
+		{
+			u32 ctrl_info_offset, index;
+			/*Set Ctrl Info*/
+			odm_write_2byte(dm, 0x140, 0x660);
+			ctrl_info_offset = 0x8000 + 32 * p_beamformee_entry->mac_id;
+			/*Reset Ctrl Info*/
+			for (index = 0; index < 8; index++)
+				odm_write_4byte(dm, ctrl_info_offset + index * 4, 0);
+
+			odm_write_4byte(dm, ctrl_info_offset, (p_beamformee_entry->mu_reg_index + 1) << 16);
+			odm_write_1byte(dm, 0x81, 0x80); /*RPTBUF ready*/
+
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, mac_id = %d, ctrl_info_offset = 0x%x, mu_reg_index = %x\n",
+				__func__, p_beamformee_entry->mac_id, ctrl_info_offset, p_beamformee_entry->mu_reg_index);
+		}
+#endif
+	}
+
+}
+
+
+void
+hal_txbf_8822b_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	*beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beamformee_entry;
+	u32					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
+
+	if (idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = &beamforming_info->beamformer_entry[idx];
+		p_beamformee_entry = &beamforming_info->beamformee_entry[idx];
+	} else
+		return;
+
+	/*Clear P_AID of Beamformee*/
+	/*Clear MAC address of Beamformer*/
+	/*Clear Associated Bfmee Sel*/
+
+	if (beamformer_entry->beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xD8);
+		if (beamformer_entry->is_mu_ap == 0) { /*SU BFer */
+			if (beamformer_entry->su_reg_index == 0) {
+				odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8822B, 0);
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8822B + 4, 0);
+				odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, 0);
+			} else {
+				odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8822B, 0);
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8822B + 4, 0);
+				odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, 0);
+			}
+			beamforming_info->beamformer_su_reg_maping &= ~(BIT(beamformer_entry->su_reg_index));
+			beamformer_entry->su_reg_index = 0xFF;
+		} else { /*MU BFer */
+			/*set validity of MU STA0 and MU STA1*/
+			beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+			odm_memory_set(dm, beamformer_entry->gid_valid, 0, 8);
+			odm_memory_set(dm, beamformer_entry->user_position, 0, 16);
+			beamformer_entry->is_mu_ap = false;
+		}
+	}
+
+	if (p_beamformee_entry->beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, idx);
+		if (p_beamformee_entry->is_mu_sta == 0) { /*SU BFee*/
+			if (p_beamformee_entry->su_reg_index == 0) {
+				odm_write_2byte(dm, REG_TXBF_CTRL_8822B, 0x0);
+				odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B, 0);
+			} else {
+				odm_write_2byte(dm, REG_TXBF_CTRL_8822B + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
+
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2,
+					odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2) & 0x60);
+			}
+			beamforming_info->beamformee_su_reg_maping &= ~(BIT(p_beamformee_entry->su_reg_index));
+			p_beamformee_entry->su_reg_index = 0xFF;
+		} else { /*MU BFee */
+			/*Disable sending NDPA & BF-rpt-poll to this BFee*/
+			odm_write_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index], 0);
+			/*set validity of MU STA*/
+			beamforming_info->reg_mu_tx_ctrl &= ~(BIT(p_beamformee_entry->mu_reg_index));
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+
+			p_beamformee_entry->is_mu_sta = false;
+			beamforming_info->beamformee_mu_reg_maping &= ~(BIT(p_beamformee_entry->mu_reg_index));
+			p_beamformee_entry->mu_reg_index = 0xFF;
+		}
+	}
+}
+
+
+/***********SU & MU BFee Entry Only when souding done****************/
+void
+hal_txbf_8822b_status(
+	void			*dm_void,
+	u8				beamform_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val, tmp_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry;
+	boolean	is_mu_sounding = beamforming_info->is_mu_sounding, is_bitmap_ready = false;
+	u16 bitmap;
+	u8 idx, gid, i;
+	u8 id1, id0;
+	u32 gid_valid[6] = {0};
+	u32 value32;
+	boolean is_sounding_success[6] = {false};
+
+	if (beamform_idx < BEAMFORMEE_ENTRY_NUM)
+		beamform_entry = &beamforming_info->beamformee_entry[beamform_idx];
+	else
+		return;
+
+	/*SU sounding done */
+	if (is_mu_sounding == false) {
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			beam_ctrl_val = beamform_entry->mac_id;
+		else
+			beam_ctrl_val = beamform_entry->p_aid;
+
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, beamform_entry.beamform_entry_state = %d", __func__, beamform_entry->beamform_entry_state);
+
+		if (beamform_entry->su_reg_index == 0)
+			beam_ctrl_reg = REG_TXBF_CTRL_8822B;
+		else {
+			beam_ctrl_reg = REG_TXBF_CTRL_8822B + 2;
+			beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+		}
+
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beamform_entry->sound_bw == CHANNEL_WIDTH_20)
+				beam_ctrl_val |= BIT(9);
+			else if (beamform_entry->sound_bw == CHANNEL_WIDTH_40)
+				beam_ctrl_val |= (BIT(9) | BIT(10));
+			else if (beamform_entry->sound_bw == CHANNEL_WIDTH_80)
+				beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
+		} else {
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, Don't apply Vmatrix",  __func__);
+			beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+		}
+
+		odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+		/*disable NDP packet use beamforming */
+		tmp_val = odm_read_2byte(dm, REG_TXBF_CTRL_8822B);
+		odm_write_2byte(dm, REG_TXBF_CTRL_8822B, tmp_val | BIT(15));
+	} else {
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, MU Sounding Done\n",  __func__);
+		/*MU sounding done */
+		if (1) { /* (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) { */
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, BEAMFORMING_ENTRY_STATE_PROGRESSED\n",  __func__);
+
+			value32 = odm_get_bb_reg(dm, 0x1684, MASKDWORD);
+			is_sounding_success[0] = (value32 & BIT(10)) ? 1 : 0;
+			is_sounding_success[1] = (value32 & BIT(26)) ? 1 : 0;
+			value32 = odm_get_bb_reg(dm, 0x1688, MASKDWORD);
+			is_sounding_success[2] = (value32 & BIT(10)) ? 1 : 0;
+			is_sounding_success[3] = (value32 & BIT(26)) ? 1 : 0;
+			value32 = odm_get_bb_reg(dm, 0x168C, MASKDWORD);
+			is_sounding_success[4] = (value32 & BIT(10)) ? 1 : 0;
+			is_sounding_success[5] = (value32 & BIT(26)) ? 1 : 0;
+
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, is_sounding_success STA1:%d,  STA2:%d, STA3:%d, STA4:%d, STA5:%d, STA6:%d\n",
+				__func__, is_sounding_success[0], is_sounding_success[1], is_sounding_success[2], is_sounding_success[3], is_sounding_success[4], is_sounding_success[5]);
+
+			value32 = odm_get_bb_reg(dm, 0xF4C, 0xFFFF0000);
+			/* odm_set_bb_reg(dm, 0x19E0, MASKHWORD, 0xFFFF);Let MAC ignore bitmap */
+
+			is_bitmap_ready = (boolean)((value32 & BIT(15)) >> 15);
+			bitmap = (u16)(value32 & 0x3FFF);
+
+			for (idx = 0; idx < 15; idx++) {
+				if (idx < 5) {/*bit0~4*/
+					id0 = 0;
+					id1 = (u8)(idx + 1);
+				} else if (idx < 9) { /*bit5~8*/
+					id0 = 1;
+					id1 = (u8)(idx - 3);
+				} else if (idx < 12) { /*bit9~11*/
+					id0 = 2;
+					id1 = (u8)(idx - 6);
+				} else if (idx < 14) { /*bit12~13*/
+					id0 = 3;
+					id1 = (u8)(idx - 8);
+				} else { /*bit14*/
+					id0 = 4;
+					id1 = (u8)(idx - 9);
+				}
+				if (bitmap & BIT(idx)) {
+					/*Pair 1*/
+					gid = (idx << 1) + 1;
+					gid_valid[id0] |= (BIT(gid));
+					gid_valid[id1] |= (BIT(gid));
+					/*Pair 2*/
+					gid += 1;
+					gid_valid[id0] |= (BIT(gid));
+					gid_valid[id1] |= (BIT(gid));
+				} else {
+					/*Pair 1*/
+					gid = (idx << 1) + 1;
+					gid_valid[id0] &= ~(BIT(gid));
+					gid_valid[id1] &= ~(BIT(gid));
+					/*Pair 2*/
+					gid += 1;
+					gid_valid[id0] &= ~(BIT(gid));
+					gid_valid[id1] &= ~(BIT(gid));
+				}
+			}
+
+			for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+				beamform_entry = &beamforming_info->beamformee_entry[i];
+				if ((beamform_entry->is_mu_sta) && (beamform_entry->mu_reg_index < 6)) {
+					value32 = gid_valid[beamform_entry->mu_reg_index];
+					for (idx = 0; idx < 4; idx++) {
+						beamform_entry->gid_valid[idx] = (u8)(value32 & 0xFF);
+						value32 = (value32 >> 8);
+					}
+				}
+			}
+
+			for (idx = 0; idx < 6; idx++) {
+				beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+				beamforming_info->reg_mu_tx_ctrl |= ((idx << 8) & (BIT(8) | BIT(9) | BIT(10)));
+				odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+				odm_set_mac_reg(dm, 0x14C4, MASKDWORD, gid_valid[idx]); /*set MU STA gid valid table*/
+			}
+
+			/*Enable TxMU PPDU*/
+			if (beamforming_info->dbg_disable_mu_tx == false)
+				beamforming_info->reg_mu_tx_ctrl |= BIT(7);
+			else
+				beamforming_info->reg_mu_tx_ctrl &= ~BIT(7);
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+		}
+	}
+}
+
+/*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
+void
+hal_txbf_8822b_config_gtab(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	*beamformer_entry = NULL;
+	u32		gid_valid = 0, user_position_l = 0, user_position_h = 0, i;
+
+	if (beamforming_info->mu_ap_index < BEAMFORMER_ENTRY_NUM)
+		beamformer_entry = &beamforming_info->beamformer_entry[beamforming_info->mu_ap_index];
+	else
+		return;
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s==>\n", __func__);
+
+	/*For GID 0~31*/
+	for (i = 0; i < 4; i++)
+		gid_valid |= (beamformer_entry->gid_valid[i] << (i << 3));
+	for (i = 0; i < 8; i++) {
+		if (i < 4)
+			user_position_l |= (beamformer_entry->user_position[i] << (i << 3));
+		else
+			user_position_h |= (beamformer_entry->user_position[i] << ((i - 4) << 3));
+	}
+	/*select MU STA0 table*/
+	beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+	odm_set_bb_reg(dm, 0x14c4, MASKDWORD, gid_valid);
+	odm_set_bb_reg(dm, 0x14c8, MASKDWORD, user_position_l);
+	odm_set_bb_reg(dm, 0x14cc, MASKDWORD, user_position_h);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s: STA0: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+			__func__, gid_valid, user_position_l, user_position_h);
+
+	gid_valid = 0;
+	user_position_l = 0;
+	user_position_h = 0;
+
+	/*For GID 32~64*/
+	for (i = 4; i < 8; i++)
+		gid_valid |= (beamformer_entry->gid_valid[i] << ((i - 4) << 3));
+	for (i = 8; i < 16; i++) {
+		if (i < 4)
+			user_position_l |= (beamformer_entry->user_position[i] << ((i - 8) << 3));
+		else
+			user_position_h |= (beamformer_entry->user_position[i] << ((i - 12) << 3));
+	}
+	/*select MU STA1 table*/
+	beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+	beamforming_info->reg_mu_tx_ctrl |= BIT(8);
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+	odm_set_bb_reg(dm, 0x14c4, MASKDWORD, gid_valid);
+	odm_set_bb_reg(dm, 0x14c8, MASKDWORD, user_position_l);
+	odm_set_bb_reg(dm, 0x14cc, MASKDWORD, user_position_h);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s: STA1: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+			__func__, gid_valid, user_position_l, user_position_h);
+
+	/* Set validity of MU STA0 and MU STA1*/
+	beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+	beamforming_info->reg_mu_tx_ctrl |= 0x3; /* STA0, STA1*/
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+}
+
+
+
+#if 0
+/*This function translate the bitmap to GTAB*/
+void
+haltxbf8822b_gtab_translation(
+	struct dm_struct			*dm
+)
+{
+	u8 idx, gid;
+	u8 id1, id0;
+	u32 gid_valid[6] = {0};
+	u32 user_position_lsb[6] = {0};
+	u32 user_position_msb[6] = {0};
+
+	for (idx = 0; idx < 15; idx++) {
+		if (idx < 5) {/*bit0~4*/
+			id0 = 0;
+			id1 = (u8)(idx + 1);
+		} else if (idx < 9) { /*bit5~8*/
+			id0 = 1;
+			id1 = (u8)(idx - 3);
+		} else if (idx < 12) { /*bit9~11*/
+			id0 = 2;
+			id1 = (u8)(idx - 6);
+		} else if (idx < 14) { /*bit12~13*/
+			id0 = 3;
+			id1 = (u8)(idx - 8);
+		} else { /*bit14*/
+			id0 = 4;
+			id1 = (u8)(idx - 9);
+		}
+
+		/*Pair 1*/
+		gid = (idx << 1) + 1;
+		gid_valid[id0] |= (1 << gid);
+		gid_valid[id1] |= (1 << gid);
+		if (gid < 16) {
+			/*user_position_lsb[id0] |= (0 << (gid << 1));*/
+			user_position_lsb[id1] |= (1 << (gid << 1));
+		} else {
+			/*user_position_msb[id0] |= (0 << ((gid - 16) << 1));*/
+			user_position_msb[id1] |= (1 << ((gid - 16) << 1));
+		}
+
+		/*Pair 2*/
+		gid += 1;
+		gid_valid[id0] |= (1 << gid);
+		gid_valid[id1] |= (1 << gid);
+		if (gid < 16) {
+			user_position_lsb[id0] |= (1 << (gid << 1));
+			/*user_position_lsb[id1] |= (0 << (gid << 1));*/
+		} else {
+			user_position_msb[id0] |= (1 << ((gid - 16) << 1));
+			/*user_position_msb[id1] |= (0 << ((gid - 16) << 1));*/
+		}
+
+	}
+
+
+	for (idx = 0; idx < 6; idx++) {
+		/*dbg_print("gid_valid[%d] = 0x%x\n", idx, gid_valid[idx]);
+		dbg_print("user_position[%d] = 0x%x   %x\n", idx, user_position_msb[idx], user_position_lsb[idx]);*/
+	}
+}
+#endif
+
+void
+hal_txbf_8822b_fw_txbf(
+	void			*dm_void,
+	u8				idx
+)
+{
+#if 0
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_8822b_download_ndpa(adapter, idx);
+
+	hal_txbf_8822b_fw_txbf_cmd(adapter);
+#endif
+}
+
+#endif
+
+#if (defined(CONFIG_BB_TXBF_API))
+/*this function is only used for BFer*/
+void
+phydm_8822btxbf_rfmode(
+	void		*dm_void,
+	u8	su_bfee_cnt,
+	u8	mu_bfee_cnt
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		i;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	if ((su_bfee_cnt > 0) || (mu_bfee_cnt > 0)) {
+		for (i = RF_PATH_A; i <= RF_PATH_B; i++) {
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x1); /*RF mode table write enable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x33, 0xF, 3); /*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3E, 0xfffff, 0x00036); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0x3F, 0xfffff, 0x5AFCE); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, 0xEF, BIT(19), 0x0); /*RF mode table write disable*/
+		}
+	}
+
+	odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(30), 1);			/*if Nsts > Nc, don't apply V matrix*/
+
+	if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2);	/*enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1);			/*ignore user since 8822B only 2Tx*/
+		
+
+		/*Nsts = 2	AB*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+
+	} else {
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x0);	/*enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 0);			/*ignore user since 8822B only 2Tx*/
+
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*1SS by path-A*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*2SS by path-A,B*/
+	}
+
+}
+
+
+/*this function is for BFer bug workaround*/
+void
+phydm_8822b_sutxbfer_workaroud(
+	void		*dm_void,
+	boolean	enable_su_bfer,
+	u8	nc,
+	u8	nr,
+	u8	ng,
+	u8	CB,
+	u8	BW,
+	boolean	is_vht
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (enable_su_bfer) {
+		odm_set_bb_reg(dm, 0x19f8, BIT(22) | BIT(21) | BIT(20), 0x1);
+		odm_set_bb_reg(dm, 0x19f8, BIT(25) | BIT(24) | BIT(23), 0x0);
+		odm_set_bb_reg(dm, 0x19f8, BIT(16), 0x1);
+
+		if (is_vht)
+			odm_set_bb_reg(dm, 0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x1f);
+		else
+			odm_set_bb_reg(dm, 0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x22);
+
+		odm_set_bb_reg(dm, 0x19f0, BIT(7) | BIT(6), nc);
+		odm_set_bb_reg(dm, 0x19f0, BIT(9) | BIT(8), nr);
+		odm_set_bb_reg(dm, 0x19f0, BIT(11) | BIT(10), ng);
+		odm_set_bb_reg(dm, 0x19f0, BIT(13) | BIT(12), CB);
+
+		odm_set_bb_reg(dm, 0xb58, BIT(3) | BIT(2), BW);
+		odm_set_bb_reg(dm, 0xb58, BIT(7) | BIT(6) | BIT(5) | BIT(4), 0x0);
+		odm_set_bb_reg(dm, 0xb58, BIT(9) | BIT(8), BW);
+		odm_set_bb_reg(dm, 0xb58, BIT(13) | BIT(12) | BIT(11) | BIT(10), 0x0);
+	} else
+		odm_set_bb_reg(dm, 0x19f8, BIT(16), 0x0);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] enable_su_bfer = %d, is_vht = %d\n", __func__, enable_su_bfer, is_vht);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] nc = %d, nr = %d, ng = %d, CB = %d, BW = %d\n", __func__, nc, nr, ng, CB, BW);
+
+
+}
+#endif
+#endif	/* (RTL8822B_SUPPORT == 1)*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.h
index 8709d3e14814..157843dd4160 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbf8822b.h
@@ -1,54 +1,104 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __HAL_TXBF_8822B_H__
-#define __HAL_TXBF_8822B_H__
-#if (BEAMFORMING_SUPPORT == 1)
-#if (RTL8822B_SUPPORT == 1)
-
-VOID
-HalTxbf8822B_Init(
-	IN PVOID			pDM_VOID
-	);
-
-VOID
-HalTxbf8822B_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8822B_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbf8822B_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-VOID
-HalTxbf8822B_ConfigGtab(
-	IN PVOID			pDM_VOID
-	);
-
-VOID
-HalTxbf8822B_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-	);
-#else
-#define HalTxbf8822B_Init(pDM_VOID)		
-#define HalTxbf8822B_Enter(pDM_VOID, Idx)
-#define HalTxbf8822B_Leave(pDM_VOID, Idx)
-#define HalTxbf8822B_Status(pDM_VOID, Idx)
-#define HalTxbf8822B_FwTxBF(pDM_VOID, Idx)
-#define HalTxbf8822B_ConfigGtab(pDM_VOID)
-#endif
-
-
-#endif
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_8822B_H__
+#define __HAL_TXBF_8822B_H__
+
+#if (RTL8822B_SUPPORT == 1)
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_txbf_8822b_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8822b_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_8822b_status(
+	void			*dm_void,
+	u8				beamform_idx
+);
+
+void
+hal_txbf_8822b_config_gtab(
+	void			*dm_void
+);
+
+void
+hal_txbf_8822b_fw_txbf(
+	void			*dm_void,
+	u8				idx
+);
+#else
+#define hal_txbf_8822b_enter(dm_void, idx)
+#define hal_txbf_8822b_leave(dm_void, idx)
+#define hal_txbf_8822b_status(dm_void, idx)
+#define hal_txbf_8822b_fw_txbf(dm_void, idx)
+#define hal_txbf_8822b_config_gtab(dm_void)
+
+#endif
+
+#if (defined(CONFIG_BB_TXBF_API))
+void
+phydm_8822btxbf_rfmode(
+	void		*dm_void,
+	u8	su_bfee_cnt,
+	u8	mu_bfee_cnt
+);
+
+void
+phydm_8822b_sutxbfer_workaroud(
+	void		*dm_void,
+	boolean	enable_su_bfer,
+	u8	nc,
+	u8	nr,
+	u8	ng,
+	u8	CB,
+	u8	BW,
+	boolean	is_vht
+);
+
+#else
+#define phydm_8822btxbf_rfmode(dm_void, su_bfee_cnt, mu_bfee_cnt)
+#define phydm_8822b_sutxbfer_workaroud(dm_void, enable_su_bfer, nc, nr, ng, CB, BW, is_vht)
+#endif
+
+#else
+#define hal_txbf_8822b_enter(dm_void, idx)
+#define hal_txbf_8822b_leave(dm_void, idx)
+#define hal_txbf_8822b_status(dm_void, idx)
+#define hal_txbf_8822b_fw_txbf(dm_void, idx)
+#define hal_txbf_8822b_config_gtab(dm_void)
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.c
index 5b80cd141165..e1abfd496e8f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.c
@@ -1,1385 +1,1521 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for TXBF interface mechanism
-//
-//============================================================
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-Beamforming_GidPAid(
-	PADAPTER	Adapter,
-	PRT_TCB		pTcb
-)
-{
-	u1Byte		Idx = 0;
-	u1Byte		RA[6] ={0};
-	pu1Byte		pHeader = GET_FRAME_OF_FIRST_FRAG(Adapter, pTcb);
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T				pDM_Odm = &pHalData->DM_OutSrc;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-
-	if (Adapter->HardwareType < HARDWARE_TYPE_RTL8192EE)
-		return;
-	else if (IS_WIRELESS_MODE_N(Adapter) == FALSE)
-		return;
-
-#if (SUPPORT_MU_BF == 1)
-	if (pTcb->TxBFPktType == RT_BF_PKT_TYPE_BROADCAST_NDPA) { /* MU NDPA */
-#else
-	if (0) {
-#endif
-		/* Fill G_ID and P_AID */
-		pTcb->G_ID = 63;
-		if (pBeamInfo->FirstMUBFeeIndex < BEAMFORMEE_ENTRY_NUM) {
-			pTcb->P_AID = pBeamInfo->BeamformeeEntry[pBeamInfo->FirstMUBFeeIndex].P_AID;			
-			RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, pTcb->G_ID, pTcb->P_AID));
-		}
-	} else {
-		GET_80211_HDR_ADDRESS1(pHeader, &RA);
-
-		// VHT SU PPDU carrying one or more group addressed MPDUs or
-		// Transmitting a VHT NDP intended for multiple recipients
-		if (MacAddr_isBcst(RA) || MacAddr_isMulticast(RA)	|| pTcb->macId == MAC_ID_STATIC_FOR_BROADCAST_MULTICAST) {
-			pTcb->G_ID = 63;
-			pTcb->P_AID = 0;
-		} else if (ACTING_AS_AP(Adapter)) {
-			u2Byte	AID = (u2Byte) (MacIdGetOwnerAssociatedClientAID(Adapter, pTcb->macId) & 0x1ff);		/*AID[0:8]*/
-	
-			/*RT_DISP(FBEAM, FBEAM_FUN, ("@%s  pTcb->macId=0x%X, AID=0x%X\n", __func__, pTcb->macId, AID));*/
-			pTcb->G_ID = 63;
-
-			if (AID == 0)		/*A PPDU sent by an AP to a non associated STA*/
-				pTcb->P_AID = 0;
-			else {				/*Sent by an AP and addressed to a STA associated with that AP*/
-				u2Byte	BSSID = 0;
-				GET_80211_HDR_ADDRESS2(pHeader, &RA);
-				BSSID = ((RA[5] & 0xf0) >> 4) ^ (RA[5] & 0xf);	/*BSSID[44:47] xor BSSID[40:43]*/
-				pTcb->P_AID = (AID + BSSID *32) & 0x1ff;		/*(dec(A) + dec(B)*32) mod 512*/
-			}
-		} else if (ACTING_AS_IBSS(Adapter)) {
-			pTcb->G_ID = 63;
-			/*P_AID for infrasturcture mode; MACID for ad-hoc mode. */
-			pTcb->P_AID = pTcb->macId;
-		} else if (MgntLinkStatusQuery(Adapter)) {				/*Addressed to AP*/
-			pTcb->G_ID = 0;
-			GET_80211_HDR_ADDRESS1(pHeader, &RA);
-			pTcb->P_AID =  RA[5];							/*RA[39:47]*/
-			pTcb->P_AID = (pTcb->P_AID << 1) | (RA[4] >> 7 );
-		} else {
-			pTcb->G_ID = 63;
-			pTcb->P_AID = 0;
-		}
-		/*RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, pTcb->G_ID, pTcb->P_AID));*/
-	}
-}
-
-
-RT_STATUS
-Beamforming_GetReportFrame(
-	IN	PADAPTER		Adapter,
-	IN	PRT_RFD			pRfd,
-	IN	POCTET_STRING	pPduOS
-	)
-{
-	HAL_DATA_TYPE				*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T					pDM_Odm = &pHalData->DM_OutSrc;
-	PRT_BEAMFORMEE_ENTRY		pBeamformEntry = NULL;
-	pu1Byte						pMIMOCtrlField, pCSIReport, pCSIMatrix;
-	u1Byte						Idx, Nc, Nr, CH_W;
-	u2Byte						CSIMatrixLen = 0;
-
-	ACT_PKT_TYPE				pktType = ACT_PKT_TYPE_UNKNOWN;
-
-	//Memory comparison to see if CSI report is the same with previous one
-	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, Frame_Addr2(*pPduOS), &Idx);
-
-	if (pBeamformEntry == NULL) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("Beamforming_GetReportFrame: Cannot find entry by addr\n"));
-		return RT_STATUS_FAILURE;
-	}
-
-	pktType = PacketGetActionFrameType(pPduOS);
-	
-	//-@ Modified by David
-	if (pktType == ACT_PKT_VHT_COMPRESSED_BEAMFORMING) {
-		pMIMOCtrlField = pPduOS->Octet + 26; 
-		Nc = ((*pMIMOCtrlField) & 0x7) + 1;
-		Nr = (((*pMIMOCtrlField) & 0x38) >> 3) + 1;
-		CH_W =  (((*pMIMOCtrlField) & 0xC0) >> 6);
-		pCSIMatrix = pMIMOCtrlField + 3 + Nc; //24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(Nc=2)
-		CSIMatrixLen = pPduOS->Length  - 26 -3 -Nc;
-	} else if (pktType == ACT_PKT_HT_COMPRESSED_BEAMFORMING) {
-		pMIMOCtrlField = pPduOS->Octet + 26; 
-		Nc = ((*pMIMOCtrlField) & 0x3) + 1;
-		Nr =  (((*pMIMOCtrlField) & 0xC) >> 2) + 1;
-		CH_W =  (((*pMIMOCtrlField) & 0x10) >> 4);
-		pCSIMatrix = pMIMOCtrlField + 6 + Nr;	//24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(Nc=2)
-		CSIMatrixLen = pPduOS->Length  - 26 -6 -Nr;
-	} else
-		return RT_STATUS_SUCCESS;	
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] idx=%d, pkt type=%d, Nc=%d, Nr=%d, CH_W=%d\n", __func__, Idx, pktType, Nc, Nr, CH_W));		
-
-	return RT_STATUS_SUCCESS;
-}
-
-
-VOID
-ConstructHTNDPAPacket(
-	PADAPTER		Adapter,
-	pu1Byte			RA,
-	pu1Byte			Buffer,
-	pu4Byte			pLength,
-	CHANNEL_WIDTH	BW
-	)
-{
-	u2Byte					Duration= 0;
-	PMGNT_INFO				pMgntInfo = &(Adapter->MgntInfo);
-	OCTET_STRING			pNDPAFrame,ActionContent;
-	u1Byte					ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
-
-	PlatformZeroMemory(Buffer, 32);
-
-	SET_80211_HDR_FRAME_CONTROL(Buffer,0);
-
-	SET_80211_HDR_ORDER(Buffer, 1);
-	SET_80211_HDR_TYPE_AND_SUBTYPE(Buffer,Type_Action_No_Ack);
-
-	SET_80211_HDR_ADDRESS1(Buffer, RA);
-	SET_80211_HDR_ADDRESS2(Buffer, Adapter->CurrentAddress);
-	SET_80211_HDR_ADDRESS3(Buffer, pMgntInfo->Bssid);
-
-	Duration = 2*aSifsTime + 40;
-	
-	if (BW == CHANNEL_WIDTH_40)
-		Duration+= 87;
-	else	
-		Duration+= 180;
-
-	SET_80211_HDR_DURATION(Buffer, Duration);
-
-	//HT control field
-	SET_HT_CTRL_CSI_STEERING(Buffer+sMacHdrLng, 3);
-	SET_HT_CTRL_NDP_ANNOUNCEMENT(Buffer+sMacHdrLng, 1);
-	
-	FillOctetString(pNDPAFrame, Buffer, sMacHdrLng+sHTCLng);
-
-	FillOctetString(ActionContent, ActionHdr, 4);
-	PacketAppendData(&pNDPAFrame, ActionContent);	
-
-	*pLength = 32;
-}
-
-
-
-
-BOOLEAN
-SendFWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	PRT_TCB 				pTcb;
-	PRT_TX_LOCAL_BUFFER 	pBuf;
-	BOOLEAN 				ret = TRUE;
-	u4Byte					BufLen;
-	pu1Byte					BufAddr;
-	u1Byte					DescLen = 0, Idx = 0, NDPTxRate;
-	PADAPTER				pDefAdapter = GetDefaultAdapter(Adapter);
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(Adapter);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pBeamformEntry == NULL)
-		return FALSE;
-
-	NDPTxRate = Beamforming_GetHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-	PlatformAcquireSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (MgntGetFWBuffer(pDefAdapter, &pTcb, &pBuf)) {
-#if(DEV_BUS_TYPE != RT_PCI_INTERFACE)
-		DescLen = Adapter->HWDescHeadLength - pHalData->USBALLDummyLength;
-#endif
-		BufAddr = pBuf->Buffer.VirtualAddress + DescLen;
-
-		ConstructHTNDPAPacket(
-				Adapter, 
-				RA,
-				BufAddr, 
-				&BufLen,
-				BW
-				);
-
-		pTcb->PacketLength = BufLen + DescLen;
-
-		pTcb->bTxEnableSwCalcDur = TRUE;
-		
-		pTcb->BWOfPacket = BW;
-
-		if(ACTING_AS_IBSS(Adapter) || ACTING_AS_AP(Adapter))
-			pTcb->G_ID = 63;
-
-		pTcb->P_AID = pBeamformEntry->P_AID;
-		pTcb->DataRate = NDPTxRate;	/*rate of NDP decide by Nr*/
-
-		Adapter->HalFunc.CmdSendPacketHandler(Adapter, pTcb, pBuf, pTcb->PacketLength, DESC_PACKET_TYPE_NORMAL, FALSE);
-	} else
-		ret = FALSE;
-
-	PlatformReleaseSpinLock(Adapter, RT_TX_SPINLOCK);
-	
-	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", pBuf->Buffer.VirtualAddress, pTcb->PacketLength);
-
-	return ret;
-}
-
-
-BOOLEAN
-SendSWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	PRT_TCB					pTcb;
-	PRT_TX_LOCAL_BUFFER		pBuf;
-	BOOLEAN					ret = TRUE;
-	u1Byte					Idx = 0, NDPTxRate = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	NDPTxRate = Beamforming_GetHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-	
-	PlatformAcquireSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (MgntGetBuffer(Adapter, &pTcb, &pBuf)) {
-		ConstructHTNDPAPacket(
-				Adapter, 
-				RA,
-				pBuf->Buffer.VirtualAddress, 
-				&pTcb->PacketLength,
-				BW
-				);
-
-		pTcb->bTxEnableSwCalcDur = TRUE;
-
-		pTcb->BWOfPacket = BW;
-
-		MgntSendPacket(Adapter, pTcb, pBuf, pTcb->PacketLength, NORMAL_QUEUE, NDPTxRate);
-	} else
-		ret = FALSE;
-	
-	PlatformReleaseSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", pBuf->Buffer.VirtualAddress, pTcb->PacketLength);
-
-	return ret;
-}
-
-
-
-VOID
-ConstructVHTNDPAPacket(
-	IN PDM_ODM_T	pDM_Odm,
-	pu1Byte			RA,
-	u2Byte			AID,
-	pu1Byte			Buffer,
-	pu4Byte			pLength,
-	CHANNEL_WIDTH	BW
-	)
-{
-	u2Byte					Duration= 0;
-	u1Byte					Sequence = 0;
-	pu1Byte					pNDPAFrame = Buffer;
-	RT_NDPA_STA_INFO		STAInfo;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	u1Byte	Idx = 0;
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-	// Frame control.
-	SET_80211_HDR_FRAME_CONTROL(pNDPAFrame, 0);
-	SET_80211_HDR_TYPE_AND_SUBTYPE(pNDPAFrame, Type_NDPA);
-
-	SET_80211_HDR_ADDRESS1(pNDPAFrame, RA);
-	SET_80211_HDR_ADDRESS2(pNDPAFrame, pBeamformEntry->MyMacAddr);
-
-	Duration = 2*aSifsTime + 44;
-	
-	if (BW == CHANNEL_WIDTH_80)
-		Duration += 40;
-	else if(BW == CHANNEL_WIDTH_40)
-		Duration+= 87;
-	else	
-		Duration+= 180;
-
-	SET_80211_HDR_DURATION(pNDPAFrame, Duration);
-
-	Sequence = *(pDM_Odm->pSoundingSeq) << 2;
-	ODM_MoveMemory(pDM_Odm, pNDPAFrame+16, &Sequence, 1);
-
-	if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS) || phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_AP) == FALSE)
-		AID = 0;
-
-	STAInfo.AID = AID;
-	STAInfo.FeedbackType = 0;
-	STAInfo.NcIndex = 0;
-	
-	ODM_MoveMemory(pDM_Odm, pNDPAFrame+17, (pu1Byte)&STAInfo, 2);
-
-	*pLength = 19;
-}
-
-
-BOOLEAN
-SendFWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	PRT_TCB					pTcb;
-	PRT_TX_LOCAL_BUFFER		pBuf;
-	BOOLEAN					ret = TRUE;
-	u4Byte					BufLen;
-	pu1Byte					BufAddr;
-	u1Byte					DescLen = 0, Idx = 0, NDPTxRate = 0;
-	PADAPTER				pDefAdapter = GetDefaultAdapter(Adapter);
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(Adapter);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry =phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pBeamformEntry == NULL)
-		return FALSE;
-
-	NDPTxRate = Beamforming_GetVHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-	
-	PlatformAcquireSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (MgntGetFWBuffer(pDefAdapter, &pTcb, &pBuf)) {
-#if(DEV_BUS_TYPE != RT_PCI_INTERFACE)
-		DescLen = Adapter->HWDescHeadLength - pHalData->USBALLDummyLength;
-#endif
-		BufAddr = pBuf->Buffer.VirtualAddress + DescLen;
-
-		ConstructVHTNDPAPacket(
-				pDM_Odm, 
-				RA,
-				AID,
-				BufAddr, 
-				&BufLen,
-				BW
-				);
-		
-		pTcb->PacketLength = BufLen + DescLen;
-
-		pTcb->bTxEnableSwCalcDur = TRUE;
-		
-		pTcb->BWOfPacket = BW;
-
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS) || phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_AP))
-			pTcb->G_ID = 63;
-
-		pTcb->P_AID = pBeamformEntry->P_AID;
-		pTcb->DataRate = NDPTxRate;	/*decide by Nr*/
-
-		Adapter->HalFunc.CmdSendPacketHandler(Adapter, pTcb, pBuf, pTcb->PacketLength, DESC_PACKET_TYPE_NORMAL, FALSE);
-	} else
-		ret = FALSE;
-	
-	PlatformReleaseSpinLock(Adapter, RT_TX_SPINLOCK);	
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] End, ret=%d\n", __func__, ret));
-
-	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", pBuf->Buffer.VirtualAddress, pTcb->PacketLength);
-
-	return ret;
-}
-
-
-
-BOOLEAN
-SendSWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	PRT_TCB					pTcb;
-	PRT_TX_LOCAL_BUFFER		pBuf;
-	BOOLEAN					ret = TRUE;
-	u1Byte					Idx = 0, NDPTxRate = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	NDPTxRate = Beamforming_GetVHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-
-	PlatformAcquireSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (MgntGetBuffer(Adapter, &pTcb, &pBuf)) {
-		ConstructVHTNDPAPacket(
-				pDM_Odm, 
-				RA,
-				AID,
-				pBuf->Buffer.VirtualAddress, 
-				&pTcb->PacketLength,
-				BW
-				);
-
-		pTcb->bTxEnableSwCalcDur = TRUE;
-		pTcb->BWOfPacket = BW;
-
-		/*rate of NDP decide by Nr*/
-		MgntSendPacket(Adapter, pTcb, pBuf, pTcb->PacketLength, NORMAL_QUEUE, NDPTxRate);
-	} else
-		ret = FALSE;
-	
-	PlatformReleaseSpinLock(Adapter, RT_TX_SPINLOCK);	
-
-	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", pBuf->Buffer.VirtualAddress, pTcb->PacketLength);
-
-	return ret;
-}
-
-#ifdef SUPPORT_MU_BF
-#if (SUPPORT_MU_BF == 1)
-/*
-// Description: On VHT GID management frame by an MU beamformee.
-//
-// 2015.05.20. Created by tynli.
-*/
-RT_STATUS
-Beamforming_GetVHTGIDMgntFrame(
-	IN	PADAPTER		Adapter,
-	IN	PRT_RFD			pRfd,
-	IN	POCTET_STRING	pPduOS
-	)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
-	RT_STATUS		rtStatus = RT_STATUS_SUCCESS;
-	pu1Byte			pBuffer = NULL;
-	pu1Byte			pRaddr = NULL;
-	u1Byte			MemStatus[8] = {0}, UserPos[16] = {0};
-	u1Byte			idx;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMER_ENTRY	pBeamformEntry = &pBeamInfo->BeamformerEntry[pBeamInfo->mu_ap_index];
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] On VHT GID mgnt frame!\n", __func__));		
-
-	/* Check length*/
-	if (pPduOS->Length < (FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY+16)) {	
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("Beamforming_GetVHTGIDMgntFrame(): Invalid length (%d)\n", pPduOS->Length));
-		return RT_STATUS_INVALID_LENGTH;
-	}
-
-	/* Check RA*/
-	pRaddr = (pu1Byte)(pPduOS->Octet)+4;
-	if (!eqMacAddr(pRaddr, Adapter->CurrentAddress)) {		
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("Beamforming_GetVHTGIDMgntFrame(): Drop because of RA error.\n"));
-		return RT_STATUS_PKT_DROP;
-	}
-
-	RT_DISP_DATA(FBEAM, FBEAM_DATA, "On VHT GID Mgnt Frame ==>:\n", pPduOS->Octet, pPduOS->Length);
-
-	/*Parsing Membership Status Array*/
-	pBuffer = pPduOS->Octet + FRAME_OFFSET_VHT_GID_MGNT_MEMBERSHIP_STATUS_ARRAY;
-	for (idx = 0; idx < 8; idx++) {
-		MemStatus[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(pBuffer+idx);
-		pBeamformEntry->gid_valid[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(pBuffer+idx);
-	}
-
-	RT_DISP_DATA(FBEAM, FBEAM_DATA, "MemStatus: ", MemStatus, 8);
-
-	/* Parsing User Position Array*/
-	pBuffer = pPduOS->Octet + FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY;
-	for (idx = 0; idx < 16; idx++) {
-		UserPos[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(pBuffer+idx);
-		pBeamformEntry->user_position[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(pBuffer+idx);
-	}
-
-	RT_DISP_DATA(FBEAM, FBEAM_DATA, "UserPos: ", UserPos, 16);
-
-	/* Group ID detail printed*/
-	{
-		u1Byte	i, j;
-		u1Byte	tmpVal;
-		u2Byte	tmpVal2;
-
-		for (i = 0; i < 8; i++) {
-			tmpVal = MemStatus[i];
-			tmpVal2 = ((UserPos[i*2 + 1] << 8) & 0xFF00) + (UserPos[i * 2] & 0xFF);
-			for (j = 0; j < 8; j++) {
-				if ((tmpVal >> j) & BIT0) {
-					ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("Use Group ID (%d), User Position (%d)\n",
-						(i*8+j), (tmpVal2 >> 2 * j)&0x3));
-				}
-			}
-		}
-	}
-
-	/* Indicate GID frame to IHV service. */
-	{
-		u1Byte	Indibuffer[24] = {0};
-		u1Byte	Indioffset = 0;
-			
-		PlatformMoveMemory(Indibuffer + Indioffset, pBeamformEntry->gid_valid, 8);
-		Indioffset += 8;
-		PlatformMoveMemory(Indibuffer + Indioffset, pBeamformEntry->user_position, 16);
-		Indioffset += 16;
-
-		PlatformIndicateCustomStatus(
-			Adapter,
-			RT_CUSTOM_EVENT_VHT_RECV_GID_MGNT_FRAME,
-			RT_CUSTOM_INDI_TARGET_IHV,
-			Indibuffer,
-			Indioffset);
-	}
-
-	/* Config HW GID table */
-	halComTxbf_ConfigGtab(pDM_Odm);
-
-	return rtStatus;
-}
-
-/*
-// Description: Construct VHT Group ID (GID) management frame.
-//
-// 2015.05.20. Created by tynli.
-*/
-VOID
-ConstructVHTGIDMgntFrame(
-	IN	PDM_ODM_T		pDM_Odm,
-	IN	pu1Byte			RA,
-	IN	PRT_BEAMFORMEE_ENTRY	pBeamformEntry,
-	OUT	pu1Byte			Buffer,
-	OUT	pu4Byte			pLength
-	
-)
-{
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PADAPTER				Adapter = pBeamInfo->SourceAdapter;
-	OCTET_STRING		osFTMFrame, tmp;
-
-	FillOctetString(osFTMFrame, Buffer, 0);
-	*pLength = 0;
-
-	ConstructMaFrameHdr(
-					Adapter, 
-					RA, 
-					ACT_CAT_VHT, 
-					ACT_VHT_GROUPID_MANAGEMENT, 
-					&osFTMFrame);
-
-	/* Membership Status Array*/
-	FillOctetString(tmp, pBeamformEntry->gid_valid, 8);
-	PacketAppendData(&osFTMFrame, tmp);
-
-	/* User Position Array*/
-	FillOctetString(tmp, pBeamformEntry->user_position, 16);
-	PacketAppendData(&osFTMFrame, tmp);
-
-	*pLength = osFTMFrame.Length;
-
-	RT_DISP_DATA(FBEAM, FBEAM_DATA, "ConstructVHTGIDMgntFrame():\n", Buffer, *pLength);
-}
-
-BOOLEAN
-SendSWVHTGIDMgntFrame(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u1Byte			Idx
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_TCB					pTcb;
-	PRT_TX_LOCAL_BUFFER		pBuf;
-	BOOLEAN					ret = TRUE;
-	u1Byte					DataRate = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = &pBeamInfo->BeamformeeEntry[Idx];
-	PADAPTER				Adapter = pBeamInfo->SourceAdapter;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-	
-	PlatformAcquireSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (MgntGetBuffer(Adapter, &pTcb, &pBuf)) {
-		ConstructVHTGIDMgntFrame(
-				pDM_Odm, 
-				RA,
-				pBeamformEntry,
-				pBuf->Buffer.VirtualAddress, 
-				&pTcb->PacketLength
-				);
-
-		pTcb->BWOfPacket = CHANNEL_WIDTH_20;
-		DataRate = MGN_6M;
-		MgntSendPacket(Adapter, pTcb, pBuf, pTcb->PacketLength, NORMAL_QUEUE, DataRate);
-	} else
-		ret = FALSE;
-	
-	PlatformReleaseSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", pBuf->Buffer.VirtualAddress, pTcb->PacketLength);
-
-	return ret;
-}
-
-
-/*
-// Description: Construct VHT beamforming report poll.
-//
-// 2015.05.20. Created by tynli.
-*/
-VOID
-ConstructVHTBFReportPoll(
-	IN	PDM_ODM_T		pDM_Odm,
-	IN	pu1Byte			RA,
-	OUT	pu1Byte			Buffer,
-	OUT	pu4Byte			pLength
-)
-{
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PADAPTER				Adapter = pBeamInfo->SourceAdapter;
-	pu1Byte			pBFRptPoll = Buffer;
-	
-	/* Frame control*/
-	SET_80211_HDR_FRAME_CONTROL(pBFRptPoll, 0);
-	SET_80211_HDR_TYPE_AND_SUBTYPE(pBFRptPoll, Type_Beamforming_Report_Poll);
-
-	/* Duration*/	
-	SET_80211_HDR_DURATION(pBFRptPoll, 100);
-
-	/* RA*/
-	SET_VHT_BF_REPORT_POLL_RA(pBFRptPoll, RA);
-
-	/* TA*/
-	SET_VHT_BF_REPORT_POLL_TA(pBFRptPoll, Adapter->CurrentAddress);
-
-	/* Feedback Segment Retransmission Bitmap*/
-	SET_VHT_BF_REPORT_POLL_FEEDBACK_SEG_RETRAN_BITMAP(pBFRptPoll, 0xFF);
-
-	*pLength = 17;
-
-	RT_DISP_DATA(FBEAM, FBEAM_DATA, "ConstructVHTBFReportPoll():\n", Buffer, *pLength);
-
-}
-
-BOOLEAN
-SendSWVHTBFReportPoll(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	BOOLEAN			bFinalPoll
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_TCB					pTcb;
-	PRT_TX_LOCAL_BUFFER		pBuf;
-	BOOLEAN					ret = TRUE;
-	u1Byte					Idx = 0, DataRate = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-	PADAPTER				Adapter = pBeamInfo->SourceAdapter;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	PlatformAcquireSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (MgntGetBuffer(Adapter, &pTcb, &pBuf)) {
-		ConstructVHTBFReportPoll(
-				pDM_Odm, 
-				RA,
-				pBuf->Buffer.VirtualAddress, 
-				&pTcb->PacketLength
-				);
-
-		pTcb->bTxEnableSwCalcDur = TRUE; /* <tynli_note> need?*/
-		pTcb->BWOfPacket = CHANNEL_WIDTH_20;
-
-		if (bFinalPoll)
-			pTcb->TxBFPktType = RT_BF_PKT_TYPE_FINAL_BF_REPORT_POLL;
-		else
-			pTcb->TxBFPktType = RT_BF_PKT_TYPE_BF_REPORT_POLL;
-		
-		DataRate = MGN_6M;	/* Legacy OFDM rate*/
-		MgntSendPacket(Adapter, pTcb, pBuf, pTcb->PacketLength, NORMAL_QUEUE, DataRate);
-	} else
-		ret = FALSE;
-	
-	PlatformReleaseSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "SendSWVHTBFReportPoll():\n", pBuf->Buffer.VirtualAddress, pTcb->PacketLength);
-
-	return ret;
-
-}
-
-
-/*
-// Description: Construct VHT MU NDPA packet.
-//	<Note> We should combine this function with ConstructVHTNDPAPacket() in the future.
-//
-// 2015.05.21. Created by tynli.
-*/
-VOID
-ConstructVHTMUNDPAPacket(
-	IN PDM_ODM_T		pDM_Odm,
-	IN CHANNEL_WIDTH	BW,
-	OUT pu1Byte			Buffer,
-	OUT pu4Byte			pLength
-	)
-{	
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PADAPTER				Adapter = pBeamInfo->SourceAdapter;
-	u2Byte					Duration = 0;
-	u1Byte					Sequence = 0;
-	pu1Byte					pNDPAFrame = Buffer;
-	RT_NDPA_STA_INFO		STAInfo;
-	u1Byte					idx;
-	u1Byte					DestAddr[6] = {0};
-	PRT_BEAMFORMEE_ENTRY	pEntry = NULL;
-
-	/* Fill the first MU BFee entry (STA1) MAC addr to destination address then
-	     HW will change A1 to broadcast addr. 2015.05.28. Suggested by SD1 Chunchu. */
-	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {		
-		pEntry = &(pBeamInfo->BeamformeeEntry[idx]);
-		if (pEntry->is_mu_sta) {
-			cpMacAddr(DestAddr, pEntry->MacAddr);
-			break;
-		}
-	}
-	if (pEntry == NULL)
-		return;
-
-	/* Frame control.*/
-	SET_80211_HDR_FRAME_CONTROL(pNDPAFrame, 0);
-	SET_80211_HDR_TYPE_AND_SUBTYPE(pNDPAFrame, Type_NDPA);
-
-	SET_80211_HDR_ADDRESS1(pNDPAFrame, DestAddr);
-	SET_80211_HDR_ADDRESS2(pNDPAFrame, pEntry->MyMacAddr);
-
-	/*--------------------------------------------*/
-	/* <Note> Need to modify "Duration" to MU consideration. */
-	Duration = 2*aSifsTime + 44;
-	
-	if (BW == CHANNEL_WIDTH_80)
-		Duration += 40;
-	else if(BW == CHANNEL_WIDTH_40)
-		Duration+= 87;
-	else	
-		Duration+= 180;
-	/*--------------------------------------------*/
-
-	SET_80211_HDR_DURATION(pNDPAFrame, Duration);
-
-	Sequence = *(pDM_Odm->pSoundingSeq) << 2;
-	ODM_MoveMemory(pDM_Odm, pNDPAFrame + 16, &Sequence, 1);
-
-	*pLength = 17;
-
-	/* Construct STA info. for multiple STAs*/
-	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {		
-		pEntry = &(pBeamInfo->BeamformeeEntry[idx]);
-		if (pEntry->is_mu_sta) {
-			STAInfo.AID = pEntry->AID;
-			STAInfo.FeedbackType = 1; /* 1'b1: MU*/
-			STAInfo.NcIndex = 0;
-
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Get BeamformeeEntry idx(%d), AID =%d\n", __func__, idx, pEntry->AID));
-			
-			ODM_MoveMemory(pDM_Odm, pNDPAFrame+(*pLength), (pu1Byte)&STAInfo, 2);
-			*pLength += 2;
-		}
-	}
-
-}
-
-BOOLEAN
-SendSWVHTMUNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_TCB					pTcb;
-	PRT_TX_LOCAL_BUFFER		pBuf;
-	BOOLEAN					ret = TRUE;
-	u1Byte					NDPTxRate = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PADAPTER				Adapter = pBeamInfo->SourceAdapter;
-
-	NDPTxRate = MGN_VHT2SS_MCS0;
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-
-	PlatformAcquireSpinLock(Adapter, RT_TX_SPINLOCK);
-
-	if (MgntGetBuffer(Adapter, &pTcb, &pBuf)) {
-		ConstructVHTMUNDPAPacket(
-				pDM_Odm,
-				BW,
-				pBuf->Buffer.VirtualAddress, 
-				&pTcb->PacketLength
-				);
-
-		pTcb->bTxEnableSwCalcDur = TRUE;
-		pTcb->BWOfPacket = BW;
-		pTcb->TxBFPktType = RT_BF_PKT_TYPE_BROADCAST_NDPA;
-
-		/*rate of NDP decide by Nr*/
-		MgntSendPacket(Adapter, pTcb, pBuf, pTcb->PacketLength, NORMAL_QUEUE, NDPTxRate);
-	} else
-		ret = FALSE;
-	
-	PlatformReleaseSpinLock(Adapter, RT_TX_SPINLOCK);	
-
-	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", pBuf->Buffer.VirtualAddress, pTcb->PacketLength);
-
-	return ret;
-}
-
-#endif	/*#if (SUPPORT_MU_BF == 1)*/
-#endif	/*#ifdef SUPPORT_MU_BF*/
-
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-u4Byte
-Beamforming_GetReportFrame(
-	IN	PVOID			pDM_VOID,
-	union recv_frame *precv_frame
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u4Byte					ret = _SUCCESS;
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = NULL;
-	pu1Byte					pframe = precv_frame->u.hdr.rx_data;
-	u4Byte					frame_len = precv_frame->u.hdr.len;
-	pu1Byte					TA;
-	u1Byte					Idx, offset;
-	
-	/*DBG_871X("beamforming_get_report_frame\n");*/
-
-	/*Memory comparison to see if CSI report is the same with previous one*/
-	TA = GetAddr2Ptr(pframe);
-	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, TA, &Idx);
-	if(pBeamformEntry->BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)
-		offset = 31;		/*24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)*/
-	else if(pBeamformEntry->BeamformEntryCap & BEAMFORMER_CAP_HT_EXPLICIT)
-		offset = 34;		/*24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)*/
-	else
-		return ret;
-
-	/*DBG_871X("%s MacId %d offset=%d\n", __FUNCTION__, pBeamformEntry->mac_id, offset);*/
-	
-	return ret;
-}
-
-
-BOOLEAN
-SendFWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u1Byte	ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
-	u1Byte	*pframe;
-	u2Byte	*fctrl;
-	u2Byte	duration = 0;
-	u1Byte	aSifsTime = 0, NDPTxRate = 0, Idx = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-	
-	if (pmgntframe == NULL) {
-		DBG_871X("%s, alloc mgnt frame fail\n", __func__);
-		return _FALSE;
-	}
-
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(Adapter, pattrib);
-
-	pattrib->qsel = QSLT_BEACON;
-	NDPTxRate = Beamforming_GetHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-	pattrib->rate = NDPTxRate;
-	pattrib->bwmode = BW;
-	pattrib->order = 1;
-	pattrib->subtype = WIFI_ACTION_NOACK;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr*)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetOrderBit(pframe);
-	SetFrameSubType(pframe, WIFI_ACTION_NOACK);
-
-	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, pBeamformEntry->MyMacAddr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	if( pmlmeext->cur_wireless_mode == WIRELESS_11B)
-		aSifsTime = 10;
-	else
-		aSifsTime = 16;
-
-	duration = 2*aSifsTime + 40;
-	
-	if(BW == CHANNEL_WIDTH_40)
-		duration+= 87;
-	else	
-		duration+= 180;
-
-	SetDuration(pframe, duration);
-
-	//HT control field
-	SET_HT_CTRL_CSI_STEERING(pframe+24, 3);
-	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe+24, 1);
-
-	_rtw_memcpy(pframe+28, ActionHdr, 4);
-
-	pattrib->pktlen = 32;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-
-	return _TRUE;
-}
-
-
-BOOLEAN
-SendSWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u1Byte	ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
-	pu1Byte	pframe;
-	pu2Byte	fctrl;
-	u2Byte	duration = 0;
-	u1Byte	aSifsTime = 0, NDPTxRate = 0, Idx = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	NDPTxRate = Beamforming_GetHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	
-	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-	
-	if (pmgntframe == NULL) {
-		DBG_871X("%s, alloc mgnt frame fail\n", __func__);
-		return _FALSE;
-	}
-
-	/*update attribute*/
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(Adapter, pattrib);
-	pattrib->qsel = QSLT_MGNT;
-	pattrib->rate = NDPTxRate;
-	pattrib->bwmode = BW;
-	pattrib->order = 1;
-	pattrib->subtype = WIFI_ACTION_NOACK;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetOrderBit(pframe);
-	SetFrameSubType(pframe, WIFI_ACTION_NOACK);
-
-	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, pBeamformEntry->MyMacAddr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
-		aSifsTime = 10;
-	else
-		aSifsTime = 16;
-
-	duration = 2*aSifsTime + 40;
-	
-	if (BW == CHANNEL_WIDTH_40)
-		duration += 87;
-	else	
-		duration += 180;
-
-	SetDuration(pframe, duration);
-
-	/*HT control field*/
-	SET_HT_CTRL_CSI_STEERING(pframe+24, 3);
-	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe+24, 1);
-
-	_rtw_memcpy(pframe+28, ActionHdr, 4);
-
-	pattrib->pktlen = 32;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-
-	return _TRUE;
-}
-
-
-BOOLEAN
-SendFWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv		*pmlmepriv = &(Adapter->mlmepriv);
-	pu1Byte	pframe;
-	pu2Byte	fctrl;
-	u2Byte	duration = 0;
-	u1Byte	sequence = 0, aSifsTime = 0, NDPTxRate= 0, Idx = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-	RT_NDPA_STA_INFO	sta_info;
-
-	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-	
-	if (pmgntframe == NULL) {
-		DBG_871X("%s, alloc mgnt frame fail\n", __func__);
-		return _FALSE;
-	}
-
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	_rtw_memcpy(pattrib->ra, RA, ETH_ALEN);
-	update_mgntframe_attrib(Adapter, pattrib);
-
-	pattrib->qsel = QSLT_BEACON;
-	NDPTxRate = Beamforming_GetVHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-	pattrib->rate = NDPTxRate;
-	pattrib->bwmode = BW;
-	pattrib->subtype = WIFI_NDPA;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr*)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetFrameSubType(pframe, WIFI_NDPA);
-
-	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, pBeamformEntry->MyMacAddr, ETH_ALEN);
-
-	if (IsSupported5G(pmlmeext->cur_wireless_mode) || IsSupportedHT(pmlmeext->cur_wireless_mode))
-		aSifsTime = 16;
-	else
-		aSifsTime = 10;
-
-	duration = 2*aSifsTime + 44;
-	
-	if(BW == CHANNEL_WIDTH_80)
-		duration += 40;
-	else if(BW == CHANNEL_WIDTH_40)
-		duration+= 87;
-	else	
-		duration+= 180;
-
-	SetDuration(pframe, duration);
-
-	sequence = pBeamInfo->SoundingSequence<< 2;
-	if (pBeamInfo->SoundingSequence >= 0x3f)
-		pBeamInfo->SoundingSequence = 0;
-	else
-		pBeamInfo->SoundingSequence++;
-
-	_rtw_memcpy(pframe+16, &sequence,1);
-
-	if (((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE))
-		AID = 0;		
-
-	sta_info.AID = AID;
-	sta_info.FeedbackType = 0;
-	sta_info.NcIndex= 0;
-	
-	_rtw_memcpy(pframe+17, (u8 *)&sta_info, 2);
-
-	pattrib->pktlen = 19;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-
-	return _TRUE;
-}
-
-
-
-BOOLEAN
-SendSWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	)
-{
-	PDM_ODM_T				pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER				Adapter = pDM_Odm->Adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(Adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv		*pmlmepriv = &(Adapter->mlmepriv);
-	RT_NDPA_STA_INFO	ndpa_sta_info;
-	u1Byte	NDPTxRate = 0, sequence = 0, aSifsTime = 0, Idx = 0;
-	pu1Byte	pframe;
-	pu2Byte	fctrl;
-	u2Byte	duration = 0;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &(pDM_Odm->BeamformingInfo);
-	PRT_BEAMFORMEE_ENTRY	pBeamformEntry = phydm_Beamforming_GetBFeeEntryByAddr(pDM_Odm, RA, &Idx);
-
-	NDPTxRate = Beamforming_GetVHTNDPTxRate(pDM_Odm, pBeamformEntry->CompSteeringNumofBFer);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] NDPTxRate =%d\n", __func__, NDPTxRate));
-
-	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-	
-	if (pmgntframe == NULL) {
-		DBG_871X("%s, alloc mgnt frame fail\n", __func__);
-		return _FALSE;
-	}
-	
-	/*update attribute*/
-	pattrib = &pmgntframe->attrib;
-	_rtw_memcpy(pattrib->ra, RA, ETH_ALEN);
-	update_mgntframe_attrib(Adapter, pattrib);
-	pattrib->qsel = QSLT_MGNT;
-	pattrib->rate = NDPTxRate;
-	pattrib->bwmode = BW;
-	pattrib->subtype = WIFI_NDPA;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-
-	SetFrameSubType(pframe, WIFI_NDPA);
-
-	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, pBeamformEntry->MyMacAddr, ETH_ALEN);
-
-	if (IsSupported5G(pmlmeext->cur_wireless_mode) || IsSupportedHT(pmlmeext->cur_wireless_mode))
-		aSifsTime = 16;
-	else
-		aSifsTime = 10;
-
-	duration = 2*aSifsTime + 44;
-	
-	if (BW == CHANNEL_WIDTH_80)
-		duration += 40;
-	else if (BW == CHANNEL_WIDTH_40)
-		duration += 87;
-	else	
-		duration += 180;
-
-	SetDuration(pframe, duration);
-	
-	sequence = pBeamInfo->SoundingSequence << 2;
-	if (pBeamInfo->SoundingSequence >= 0x3f)
-		pBeamInfo->SoundingSequence = 0;
-	else
-		pBeamInfo->SoundingSequence++;
-
-	_rtw_memcpy(pframe+16, &sequence, 1);
-	if (((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE))
-		AID = 0;		
-
-	ndpa_sta_info.AID = AID;
-	ndpa_sta_info.FeedbackType = 0;
-	ndpa_sta_info.NcIndex = 0;
-	
-	_rtw_memcpy(pframe+17, (u8 *)&ndpa_sta_info, 2);
-
-	pattrib->pktlen = 19;
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	dump_mgntframe(Adapter, pmgntframe);
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] [%d]\n", __func__, __LINE__));
-	
-	return _TRUE;
-}
-
-
-#endif
-
-
-VOID
-Beamforming_GetNDPAFrame(
-	IN	PVOID			pDM_VOID,
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	OCTET_STRING	pduOS
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	union recv_frame *precv_frame
-#endif
-)
-{
-	PDM_ODM_T					pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PADAPTER					Adapter = pDM_Odm->Adapter;
-	pu1Byte						TA ;
-	u1Byte						Idx, Sequence;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	pu1Byte						pNDPAFrame = pduOS.Octet;
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	pu1Byte						pNDPAFrame = precv_frame->u.hdr.rx_data;
-#endif
-	PRT_BEAMFORMER_ENTRY		pBeamformerEntry = NULL;		/*Modified By Jeffery @2014-10-29*/
-	
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "Beamforming_GetNDPAFrame\n", pduOS.Octet, pduOS.Length);
-	if (IsCtrlNDPA(pNDPAFrame) == FALSE)
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (GetFrameSubType(pNDPAFrame) != WIFI_NDPA)
-#endif
-		return;
-	else if (!(pDM_Odm->SupportICType & (ODM_RTL8812 | ODM_RTL8821))) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] not 8812 or 8821A, return\n", __func__));
-		return;
-	}
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	TA = Frame_Addr2(pduOS);
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	TA = GetAddr2Ptr(pNDPAFrame);
-#endif
-	/*Remove signaling TA. */
-	TA[0] = TA[0] & 0xFE;
-    
-	pBeamformerEntry = phydm_Beamforming_GetBFerEntryByAddr(pDM_Odm, TA, &Idx);		// Modified By Jeffery @2014-10-29
-
-	/*Break options for Clock Reset*/    
-	if (pBeamformerEntry == NULL)
-		return;
-	else if (!(pBeamformerEntry->BeamformEntryCap & BEAMFORMEE_CAP_VHT_SU))
-		return;
-	/*LogSuccess: As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is NO LONGER needed !2015-04-10, Jeffery*/
-	/*ClockResetTimes: While BFer entry always doesn't receive our CSI, clock will reset again and again.So ClockResetTimes is limited to 5 times.2015-04-13, Jeffery*/
-	else if ((pBeamformerEntry->LogSuccess == 1) || (pBeamformerEntry->ClockResetTimes == 5)) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] LogSeq=%d, PreLogSeq=%d, LogRetryCnt=%d, LogSuccess=%d, ClockResetTimes=%d, clock reset is no longer needed.\n", 
-			__func__, pBeamformerEntry->LogSeq, pBeamformerEntry->PreLogSeq, pBeamformerEntry->LogRetryCnt, pBeamformerEntry->LogSuccess, pBeamformerEntry->ClockResetTimes));
-
-        return;
-	}
-
-	Sequence = (pNDPAFrame[16]) >> 2;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start, Sequence=%d, LogSeq=%d, PreLogSeq=%d, LogRetryCnt=%d, ClockResetTimes=%d, LogSuccess=%d\n", 
-		__func__, Sequence, pBeamformerEntry->LogSeq, pBeamformerEntry->PreLogSeq, pBeamformerEntry->LogRetryCnt, pBeamformerEntry->ClockResetTimes, pBeamformerEntry->LogSuccess));
-
-	if ((pBeamformerEntry->LogSeq != 0) && (pBeamformerEntry->PreLogSeq != 0)) {
-		/*Success condition*/
-		if ((pBeamformerEntry->LogSeq != Sequence) && (pBeamformerEntry->PreLogSeq != pBeamformerEntry->LogSeq)) {
-			/* break option for clcok reset, 2015-03-30, Jeffery */
-			pBeamformerEntry->LogRetryCnt = 0;
-			/*As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is no longer needed.*/
-			/*That is, LogSuccess is NOT needed to be reset to zero, 2015-04-13, Jeffery*/
-			pBeamformerEntry->LogSuccess = 1;
-
-		} else {/*Fail condition*/
-
-			if (pBeamformerEntry->LogRetryCnt == 5) {
-				pBeamformerEntry->ClockResetTimes++;
-				pBeamformerEntry->LogRetryCnt = 0;
-
-			ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Clock Reset!!! ClockResetTimes=%d\n", 
-				__func__, pBeamformerEntry->ClockResetTimes));
-			HalComTxbf_Set(pDM_Odm, TXBF_SET_SOUNDING_CLK, NULL);
-
-			} else
-				pBeamformerEntry->LogRetryCnt++;
-		}
-	}
-
-	/*Update LogSeq & PreLogSeq*/
-	pBeamformerEntry->PreLogSeq = pBeamformerEntry->LogSeq;
-	pBeamformerEntry->LogSeq = Sequence;
-	
-}
-
-
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 TXBF interface mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void
+beamforming_gid_paid(
+	void	*adapter,
+	PRT_TCB		tcb
+)
+{
+	u8		RA[6] = {0};
+	u8		*p_header = GET_FRAME_OF_FIRST_FRAG((PADAPTER)adapter, tcb);
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct				*dm = &hal_data->DM_OutSrc;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+
+	if (((PADAPTER)adapter)->HardwareType < HARDWARE_TYPE_RTL8192EE)
+		return;
+	else if (IS_WIRELESS_MODE_N((PADAPTER)adapter) == false)
+		return;
+
+#if (SUPPORT_MU_BF == 1)
+	if (tcb->tx_bf_pkt_type == RT_BF_PKT_TYPE_BROADCAST_NDPA) { /* MU NDPA */
+#else
+	if (0) {
+#endif
+		/* Fill G_ID and P_AID */
+		tcb->G_ID = 63;
+		if (beam_info->first_mu_bfee_index < BEAMFORMEE_ENTRY_NUM) {
+			tcb->P_AID = beam_info->beamformee_entry[beam_info->first_mu_bfee_index].p_aid;
+			RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, tcb->G_ID, tcb->P_AID));
+		}
+	} else {
+		GET_80211_HDR_ADDRESS1(p_header, &RA);
+
+		/* VHT SU PPDU carrying one or more group addressed MPDUs or */
+		/* Transmitting a VHT NDP intended for multiple recipients */
+		if (MacAddr_isBcst(RA) || MacAddr_isMulticast(RA)	|| tcb->macId == MAC_ID_STATIC_FOR_BROADCAST_MULTICAST) {
+			tcb->G_ID = 63;
+			tcb->P_AID = 0;
+		} else if (ACTING_AS_AP((PADAPTER)adapter)) {
+			u16	AID = (u16)(MacIdGetOwnerAssociatedClientAID((PADAPTER)adapter, tcb->macId) & 0x1ff);		/*AID[0:8]*/
+
+			/*RT_DISP(FBEAM, FBEAM_FUN, ("@%s  tcb->mac_id=0x%X, AID=0x%X\n", __func__, tcb->mac_id, AID));*/
+			tcb->G_ID = 63;
+
+			if (AID == 0)		/*A PPDU sent by an AP to a non associated STA*/
+				tcb->P_AID = 0;
+			else {				/*Sent by an AP and addressed to a STA associated with that AP*/
+				u16	BSSID = 0;
+				GET_80211_HDR_ADDRESS2(p_header, &RA);
+				BSSID = ((RA[5] & 0xf0) >> 4) ^ (RA[5] & 0xf);	/*BSSID[44:47] xor BSSID[40:43]*/
+				tcb->P_AID = (AID + BSSID * 32) & 0x1ff;		/*(dec(A) + dec(B)*32) mod 512*/
+			}
+		} else if (ACTING_AS_IBSS(((PADAPTER)adapter))) {
+			tcb->G_ID = 63;
+			/*P_AID for infrasturcture mode; MACID for ad-hoc mode. */
+			tcb->P_AID = tcb->macId;
+		} else if (MgntLinkStatusQuery((PADAPTER)adapter)) {				/*Addressed to AP*/
+			tcb->G_ID = 0;
+			GET_80211_HDR_ADDRESS1(p_header, &RA);
+			tcb->P_AID =  RA[5];							/*RA[39:47]*/
+			tcb->P_AID = (tcb->P_AID << 1) | (RA[4] >> 7);
+		} else {
+			tcb->G_ID = 63;
+			tcb->P_AID = 0;
+		}
+		/*RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, tcb->G_ID, tcb->P_AID));*/
+	}
+}
+
+
+enum rt_status
+beamforming_get_report_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+)
+{
+	HAL_DATA_TYPE				*hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct					*dm = &hal_data->DM_OutSrc;
+	struct _RT_BEAMFORMEE_ENTRY		*beamform_entry = NULL;
+	u8						*p_mimo_ctrl_field, p_csi_matrix;
+	u8						idx, nc, nr, CH_W;
+	u16						csi_matrix_len = 0;
+
+	ACT_PKT_TYPE				pkt_type = ACT_PKT_TYPE_UNKNOWN;
+
+	/* Memory comparison to see if CSI report is the same with previous one */
+	beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, Frame_Addr2(*p_pdu_os), &idx);
+
+	if (beamform_entry == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "beamforming_get_report_frame: Cannot find entry by addr\n");
+		return RT_STATUS_FAILURE;
+	}
+
+	pkt_type = PacketGetActionFrameType(p_pdu_os);
+
+	/* -@ Modified by David */
+	if (pkt_type == ACT_PKT_VHT_COMPRESSED_BEAMFORMING) {
+		p_mimo_ctrl_field = p_pdu_os->Octet + 26;
+		nc = ((*p_mimo_ctrl_field) & 0x7) + 1;
+		nr = (((*p_mimo_ctrl_field) & 0x38) >> 3) + 1;
+		CH_W = (((*p_mimo_ctrl_field) & 0xC0) >> 6);
+		/*p_csi_matrix = p_mimo_ctrl_field + 3 + nc;*/ /* 24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(nc=2) */
+		csi_matrix_len = p_pdu_os->Length  - 26 - 3 - nc;
+	} else if (pkt_type == ACT_PKT_HT_COMPRESSED_BEAMFORMING) {
+		p_mimo_ctrl_field = p_pdu_os->Octet + 26;
+		nc = ((*p_mimo_ctrl_field) & 0x3) + 1;
+		nr = (((*p_mimo_ctrl_field) & 0xC) >> 2) + 1;
+		CH_W = (((*p_mimo_ctrl_field) & 0x10) >> 4);
+		/*p_csi_matrix = p_mimo_ctrl_field + 6 + nr;*/	/* 24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(nc=2) */
+		csi_matrix_len = p_pdu_os->Length  - 26 - 6 - nr;
+	} else
+		return RT_STATUS_SUCCESS;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] idx=%d, pkt type=%d, nc=%d, nr=%d, CH_W=%d\n", __func__, idx, pkt_type, nc, nr, CH_W);
+
+	return RT_STATUS_SUCCESS;
+}
+
+
+void
+construct_ht_ndpa_packet(
+	// 2017/11 MH PHYDM compile. But why need to use windows maco? 
+	// For all linux code, it should be useless?
+	//void				*adapter = dm->adapter;
+	ADAPTER				*adapter,
+	//void		*adapter,
+	u8			*RA,
+	u8			*buffer,
+	u32			*p_length,
+	enum channel_width	BW
+)
+{
+	u16					duration = 0;
+	PMGNT_INFO				mgnt_info = &(((PADAPTER)adapter)->MgntInfo);
+	//PMGNT_INFO				mgnt_info = &((MGNT_INFO)(((PADAPTER)adapter)->MgntInfo));
+	OCTET_STRING			p_ndpa_frame, action_content;
+	u8					action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+
+	PlatformZeroMemory(buffer, 32);
+
+	SET_80211_HDR_FRAME_CONTROL(buffer, 0);
+
+	SET_80211_HDR_ORDER(buffer, 1);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(buffer, Type_Action_No_Ack);
+
+	SET_80211_HDR_ADDRESS1(buffer, RA);
+	SET_80211_HDR_ADDRESS2(buffer, ((PADAPTER)adapter)->CurrentAddress);
+	SET_80211_HDR_ADDRESS3(buffer, ((PMGNT_INFO)mgnt_info)->Bssid);
+
+	duration = 2 * a_SifsTime + 40;
+
+	if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	SET_80211_HDR_DURATION(buffer, duration);
+
+	/* HT control field */
+	SET_HT_CTRL_CSI_STEERING(buffer + sMacHdrLng, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(buffer + sMacHdrLng, 1);
+
+	FillOctetString(p_ndpa_frame, buffer, sMacHdrLng + sHTCLng);
+
+	FillOctetString(action_content, action_hdr, 4);
+	PacketAppendData(&p_ndpa_frame, action_content);
+
+	*p_length = 32;
+}
+
+
+
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER            adapter = (PADAPTER)dm->adapter;
+	PRT_TCB				tcb;
+	PRT_TX_LOCAL_BUFFER	p_buf;
+	boolean				ret = true;
+	u32					buf_len;
+	u8					*buf_addr;
+	u8					desc_len = 0, idx = 0, ndp_tx_rate;
+	void				*p_def_adapter = GetDefaultAdapter((adapter));
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA((adapter));
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beamform_entry == NULL)
+		return false;
+
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetFWBuffer((PADAPTER)p_def_adapter, &tcb, &p_buf)) {
+#if (DEV_BUS_TYPE != RT_PCI_INTERFACE)
+		desc_len = ((PADAPTER)adapter)->HWDescHeadLength - hal_data->USBALLDummyLength;
+#endif
+		buf_addr = p_buf->Buffer.VirtualAddress + desc_len;
+
+		construct_ht_ndpa_packet(
+			adapter,
+			RA,
+			buf_addr,
+			&buf_len,
+			BW
+		);
+
+		tcb->PacketLength = buf_len + desc_len;
+
+		tcb->bTxEnableSwCalcDur = true;
+
+		tcb->BWOfPacket = BW;
+
+		if (ACTING_AS_IBSS((adapter)) || ACTING_AS_AP((adapter)))
+			tcb->G_ID = 63;
+
+		tcb->P_AID = beamform_entry->p_aid;
+		tcb->DataRate = ndp_tx_rate;	/*rate of NDP decide by nr*/
+
+		adapter->HalFunc.CmdSendPacketHandler(adapter, tcb, p_buf, tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER				adapter = (PADAPTER)dm->adapter;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					idx = 0, ndp_tx_rate = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_ht_ndpa_packet(
+			adapter,
+			RA,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength,
+			BW
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+
+		tcb->BWOfPacket = BW;
+
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+
+void
+construct_vht_ndpa_packet(
+	struct dm_struct	*dm,
+	u8			*RA,
+	u16			AID,
+	u8			*buffer,
+	u32			*p_length,
+	enum channel_width	BW
+)
+{
+	u16					duration = 0;
+	u8					sequence = 0;
+	u8					*p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO		sta_info;
+	// 2017/11 MH PHYDM compile. But why need to use windows maco? 
+	// For all linux code, it should be useless?
+	//void				*adapter = dm->adapter;
+	ADAPTER				*adapter = (PADAPTER)(dm->adapter);
+	u8	idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	/* Frame control. */
+	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
+
+	SET_80211_HDR_ADDRESS1(p_ndpa_frame, RA);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, beamform_entry->my_mac_addr);
+
+	// 2017/11 MH PHYDM compile. But why need to use windows maco? 
+	// For all linux code, it should be useless?	
+	duration = 2 * a_SifsTime + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
+
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss) || phydm_acting_determine(dm, phydm_acting_as_ap) == false)
+		AID = 0;
+
+	sta_info.aid = AID;
+	sta_info.feedback_type = 0;
+	sta_info.nc_index = 0;
+
+	odm_move_memory(dm, p_ndpa_frame + 17, (u8 *)&sta_info, 2);
+
+	*p_length = 19;
+}
+
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER              adapter = (PADAPTER)dm->adapter;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u32					buf_len;
+	u8					*buf_addr;
+	u8					desc_len = 0, idx = 0, ndp_tx_rate = 0;
+	void				*p_def_adapter = GetDefaultAdapter((adapter));
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA((adapter));
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beamform_entry == NULL)
+		return false;
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetFWBuffer((PADAPTER)p_def_adapter, &tcb, &p_buf)) {
+#if (DEV_BUS_TYPE != RT_PCI_INTERFACE)
+		desc_len = adapter->HWDescHeadLength - hal_data->USBALLDummyLength;
+#endif
+		buf_addr = p_buf->Buffer.VirtualAddress + desc_len;
+
+		construct_vht_ndpa_packet(
+			dm,
+			RA,
+			AID,
+			buf_addr,
+			&buf_len,
+			BW
+		);
+
+		tcb->PacketLength = buf_len + desc_len;
+
+		tcb->bTxEnableSwCalcDur = true;
+
+		tcb->BWOfPacket = BW;
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss) || phydm_acting_determine(dm, phydm_acting_as_ap))
+			tcb->G_ID = 63;
+
+		tcb->P_AID = beamform_entry->p_aid;
+		tcb->DataRate = ndp_tx_rate;	/*decide by nr*/
+
+		adapter->HalFunc.CmdSendPacketHandler(adapter, tcb, p_buf, tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End, ret=%d\n", __func__, ret);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PADAPTER                adapter = (PADAPTER)dm->adapter;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					idx = 0, ndp_tx_rate = 0;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_ndpa_packet(
+			dm,
+			RA,
+			AID,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength,
+			BW
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+
+		/*rate of NDP decide by nr*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+/*
+ * Description: On VHT GID management frame by an MU beamformee.
+ *
+ * 2015.05.20. Created by tynli.
+ */
+enum rt_status
+beamforming_get_vht_gid_mgnt_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+)
+{
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
+	enum rt_status		rt_status = RT_STATUS_SUCCESS;
+	u8			*p_buffer = NULL;
+	u8			*p_raddr = NULL;
+	u8			mem_status[8] = {0}, user_pos[16] = {0};
+	u8			idx;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMER_ENTRY	*beamform_entry = &beam_info->beamformer_entry[beam_info->mu_ap_index];
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] On VHT GID mgnt frame!\n", __func__);
+
+	/* Check length*/
+	if (p_pdu_os->length < (FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY + 16)) {
+		PHYDM_DBG(dm, DBG_TXBF, "beamforming_get_vht_gid_mgnt_frame(): Invalid length (%d)\n", p_pdu_os->length);
+		return RT_STATUS_INVALID_LENGTH;
+	}
+
+	/* Check RA*/
+	p_raddr = (u8 *)(p_pdu_os->Octet) + 4;
+	if (!eq_mac_addr(p_raddr, adapter->CurrentAddress)) {
+		PHYDM_DBG(dm, DBG_TXBF, "beamforming_get_vht_gid_mgnt_frame(): Drop because of RA error.\n");
+		return RT_STATUS_PKT_DROP;
+	}
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "On VHT GID Mgnt Frame ==>:\n", p_pdu_os->Octet, p_pdu_os->length);
+
+	/*Parsing Membership status array*/
+	p_buffer = p_pdu_os->Octet + FRAME_OFFSET_VHT_GID_MGNT_MEMBERSHIP_STATUS_ARRAY;
+	for (idx = 0; idx < 8; idx++) {
+		mem_status[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(p_buffer + idx);
+		beamform_entry->gid_valid[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(p_buffer + idx);
+	}
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "mem_status: ", mem_status, 8);
+
+	/* Parsing User Position array*/
+	p_buffer = p_pdu_os->Octet + FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY;
+	for (idx = 0; idx < 16; idx++) {
+		user_pos[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(p_buffer + idx);
+		beamform_entry->user_position[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(p_buffer + idx);
+	}
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "user_pos: ", user_pos, 16);
+
+	/* Group ID detail printed*/
+	{
+		u8	i, j;
+		u8	tmp_val;
+		u16	tmp_val2;
+
+		for (i = 0; i < 8; i++) {
+			tmp_val = mem_status[i];
+			tmp_val2 = ((user_pos[i * 2 + 1] << 8) & 0xFF00) + (user_pos[i * 2] & 0xFF);
+			for (j = 0; j < 8; j++) {
+				if ((tmp_val >> j) & BIT(0)) {
+					PHYDM_DBG(dm, DBG_TXBF, "Use Group ID (%d), User Position (%d)\n",
+						(i * 8 + j), (tmp_val2 >> 2 * j) & 0x3);
+				}
+			}
+		}
+	}
+
+	/* Indicate GID frame to IHV service. */
+	{
+		u8	indibuffer[24] = {0};
+		u8	indioffset = 0;
+
+		PlatformMoveMemory(indibuffer + indioffset, beamform_entry->gid_valid, 8);
+		indioffset += 8;
+		PlatformMoveMemory(indibuffer + indioffset, beamform_entry->user_position, 16);
+		indioffset += 16;
+
+		PlatformIndicateCustomStatus(
+			adapter,
+			RT_CUSTOM_EVENT_VHT_RECV_GID_MGNT_FRAME,
+			RT_CUSTOM_INDI_TARGET_IHV,
+			indibuffer,
+			indioffset);
+	}
+
+	/* Config HW GID table */
+	hal_com_txbf_config_gtab(dm);
+
+	return rt_status;
+}
+
+/*
+ * Description: Construct VHT Group ID (GID) management frame.
+ *
+ * 2015.05.20. Created by tynli.
+ */
+void
+construct_vht_gid_mgnt_frame(
+	struct dm_struct		*dm,
+	u8			*RA,
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry,
+	u8			*buffer,
+	u32			*p_length
+
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	OCTET_STRING		os_ftm_frame, tmp;
+
+	FillOctetString(os_ftm_frame, buffer, 0);
+	*p_length = 0;
+
+	ConstructMaFrameHdr(
+		adapter,
+		RA,
+		ACT_CAT_VHT,
+		ACT_VHT_GROUPID_MANAGEMENT,
+		&os_ftm_frame);
+
+	/* Membership status array*/
+	FillOctetString(tmp, beamform_entry->gid_valid, 8);
+	PacketAppendData(&os_ftm_frame, tmp);
+
+	/* User Position array*/
+	FillOctetString(tmp, beamform_entry->user_position, 16);
+	PacketAppendData(&os_ftm_frame, tmp);
+
+	*p_length = os_ftm_frame.length;
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "construct_vht_gid_mgnt_frame():\n", buffer, *p_length);
+}
+
+boolean
+send_sw_vht_gid_mgnt_frame(
+	void			*dm_void,
+	u8			*RA,
+	u8			idx
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					data_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = &beam_info->beamformee_entry[idx];
+	void				*adapter = beam_info->source_adapter;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_gid_mgnt_frame(
+			dm,
+			RA,
+			beamform_entry,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bw_of_packet = CHANNEL_WIDTH_20;
+		data_rate = MGN_6M;
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, data_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+/*
+ * Description: Construct VHT beamforming report poll.
+ *
+ * 2015.05.20. Created by tynli.
+ */
+void
+construct_vht_bf_report_poll(
+	struct dm_struct		*dm,
+	u8			*RA,
+	u8			*buffer,
+	u32			*p_length
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	u8			*p_bf_rpt_poll = buffer;
+
+	/* Frame control*/
+	SET_80211_HDR_FRAME_CONTROL(p_bf_rpt_poll, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_bf_rpt_poll, Type_Beamforming_Report_Poll);
+
+	/* duration*/
+	SET_80211_HDR_DURATION(p_bf_rpt_poll, 100);
+
+	/* RA*/
+	SET_VHT_BF_REPORT_POLL_RA(p_bf_rpt_poll, RA);
+
+	/* TA*/
+	SET_VHT_BF_REPORT_POLL_TA(p_bf_rpt_poll, adapter->CurrentAddress);
+
+	/* Feedback Segment Retransmission Bitmap*/
+	SET_VHT_BF_REPORT_POLL_FEEDBACK_SEG_RETRAN_BITMAP(p_bf_rpt_poll, 0xFF);
+
+	*p_length = 17;
+
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "construct_vht_bf_report_poll():\n", buffer, *p_length);
+
+}
+
+boolean
+send_sw_vht_bf_report_poll(
+	void			*dm_void,
+	u8			*RA,
+	boolean			is_final_poll
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					idx = 0, data_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	void				*adapter = beam_info->source_adapter;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_bf_report_poll(
+			dm,
+			RA,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bTxEnableSwCalcDur = true; /* <tynli_note> need?*/
+		tcb->BWOfPacket = CHANNEL_WIDTH_20;
+
+		if (is_final_poll)
+			tcb->TxBFPktType = RT_BF_PKT_TYPE_FINAL_BF_REPORT_POLL;
+		else
+			tcb->TxBFPktType = RT_BF_PKT_TYPE_BF_REPORT_POLL;
+
+		data_rate = MGN_6M;	/* Legacy OFDM rate*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, data_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "send_sw_vht_bf_report_poll():\n", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+
+}
+
+
+/*
+ * Description: Construct VHT MU NDPA packet.
+ *	<Note> We should combine this function with construct_vht_ndpa_packet() in the future.
+ *
+ * 2015.05.21. Created by tynli.
+ */
+void
+construct_vht_mu_ndpa_packet(
+	struct dm_struct		*dm,
+	enum channel_width	BW,
+	u8			*buffer,
+	u32			*p_length
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	u16					duration = 0;
+	u8					sequence = 0;
+	u8					*p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO		sta_info;
+	u8					idx;
+	u8					dest_addr[6] = {0};
+	struct _RT_BEAMFORMEE_ENTRY	*entry = NULL;
+
+	/* Fill the first MU BFee entry (STA1) MAC addr to destination address then
+	     HW will change A1 to broadcast addr. 2015.05.28. Suggested by SD1 Chunchu. */
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			cp_mac_addr(dest_addr, entry->mac_addr);
+			break;
+		}
+	}
+	if (entry == NULL)
+		return;
+
+	/* Frame control.*/
+	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
+
+	SET_80211_HDR_ADDRESS1(p_ndpa_frame, dest_addr);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, entry->my_mac_addr);
+
+	/*--------------------------------------------*/
+	/* <Note> Need to modify "duration" to MU consideration. */
+	duration = 2 * a_SifsTime + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+	/*--------------------------------------------*/
+
+	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
+
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
+
+	*p_length = 17;
+
+	/* Construct STA info. for multiple STAs*/
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			sta_info.aid = entry->AID;
+			sta_info.feedback_type = 1; /* 1'b1: MU*/
+			sta_info.nc_index = 0;
+
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] Get beamformee_entry idx(%d), AID =%d\n", __func__, idx, entry->AID);
+
+			odm_move_memory(dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
+			*p_length += 2;
+		}
+	}
+
+}
+
+boolean
+send_sw_vht_mu_ndpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					ndp_tx_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+
+	ndp_tx_rate = MGN_VHT2SS_MCS0;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		construct_vht_mu_ndpa_packet(
+			dm,
+			BW,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+		tcb->TxBFPktType = RT_BF_PKT_TYPE_BROADCAST_NDPA;
+
+		/*rate of NDP decide by nr*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+void
+dbg_construct_vht_mundpa_packet(
+	struct dm_struct		*dm,
+	enum channel_width	BW,
+	u8			*buffer,
+	u32			*p_length
+)
+{
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+	u16					duration = 0;
+	u8					sequence = 0;
+	u8					*p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO		sta_info;
+	u8					idx;
+	u8					dest_addr[6] = {0};
+	struct _RT_BEAMFORMEE_ENTRY	*entry = NULL;
+
+	boolean	is_STA1 = false;
+
+
+	/* Fill the first MU BFee entry (STA1) MAC addr to destination address then
+	     HW will change A1 to broadcast addr. 2015.05.28. Suggested by SD1 Chunchu. */
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			if (is_STA1 == false) {
+				is_STA1 = true;
+				continue;
+			} else {
+				cp_mac_addr(dest_addr, entry->mac_addr);
+				break;
+			}
+		}
+	}
+
+	/* Frame control.*/
+	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
+	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
+
+	SET_80211_HDR_ADDRESS1(p_ndpa_frame, dest_addr);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, dm->CurrentAddress);
+
+	/*--------------------------------------------*/
+	/* <Note> Need to modify "duration" to MU consideration. */
+	duration = 2 * a_SifsTime + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+	/*--------------------------------------------*/
+
+	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
+
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
+
+	*p_length = 17;
+
+	/*STA2's STA Info*/
+	sta_info.aid = entry->aid;
+	sta_info.feedback_type = 1; /* 1'b1: MU */
+	sta_info.nc_index = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Get beamformee_entry idx(%d), AID =%d\n", __func__, idx, entry->aid);
+
+	odm_move_memory(dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
+	*p_length += 2;
+
+}
+
+boolean
+dbg_send_sw_vht_mundpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	PRT_TCB					tcb;
+	PRT_TX_LOCAL_BUFFER		p_buf;
+	boolean					ret = true;
+	u8					ndp_tx_rate = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	void				*adapter = beam_info->source_adapter;
+
+	ndp_tx_rate = MGN_VHT2SS_MCS0;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
+		dbg_construct_vht_mundpa_packet(
+			dm,
+			BW,
+			p_buf->Buffer.VirtualAddress,
+			&tcb->PacketLength
+		);
+
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+		tcb->TxBFPktType = RT_BF_PKT_TYPE_UNICAST_NDPA;
+
+		/*rate of NDP decide by nr*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+	} else
+		ret = false;
+
+	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
+
+	if (ret)
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
+
+	return ret;
+}
+
+
+#endif	/*#if (SUPPORT_MU_BF == 1)*/
+#endif	/*#ifdef SUPPORT_MU_BF*/
+
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+u32
+beamforming_get_report_frame(
+	void			*dm_void,
+	union recv_frame *precv_frame
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	u32					ret = _SUCCESS;
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = NULL;
+	u8					*pframe = precv_frame->u.hdr.rx_data;
+	u32					frame_len = precv_frame->u.hdr.len;
+	u8					*TA;
+	u8					idx, offset;
+
+
+	/*Memory comparison to see if CSI report is the same with previous one*/
+	TA = get_addr2_ptr(pframe);
+	beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, TA, &idx);
+	if (beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+		offset = 31;		/*24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
+	else if (beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+		offset = 34;		/*24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
+	else
+		return ret;
+
+
+	return ret;
+}
+
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+
+	pattrib->qsel = QSLT_BEACON;
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->order = 1;
+	pattrib->subtype = WIFI_ACTION_NOACK;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_order_bit(pframe);
+	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
+		a_sifs_time = 10;
+	else
+		a_sifs_time = 16;
+
+	duration = 2 * a_sifs_time + 40;
+
+	if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	/* HT control field */
+	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
+
+	_rtw_memcpy(pframe + 28, action_hdr, 4);
+
+	pattrib->pktlen = 32;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return true;
+}
+
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+	pattrib->qsel = QSLT_MGNT;
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->order = 1;
+	pattrib->subtype = WIFI_ACTION_NOACK;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_order_bit(pframe);
+	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
+		a_sifs_time = 10;
+	else
+		a_sifs_time = 16;
+
+	duration = 2 * a_sifs_time + 40;
+
+	if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	/*HT control field*/
+	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
+	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
+
+	_rtw_memcpy(pframe + 28, action_hdr, 4);
+
+	pattrib->pktlen = 32;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return true;
+}
+
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	u8	sequence = 0, a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	struct _RT_NDPA_STA_INFO	sta_info;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	_rtw_memcpy(pattrib->ra, RA, ETH_ALEN);
+	update_mgntframe_attrib(adapter, pattrib);
+
+	pattrib->qsel = QSLT_BEACON;
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->subtype = WIFI_NDPA;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_frame_sub_type(pframe, WIFI_NDPA);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		a_sifs_time = 16;
+	else
+		a_sifs_time = 10;
+
+	duration = 2 * a_sifs_time + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	sequence = beam_info->sounding_sequence << 2;
+	if (beam_info->sounding_sequence >= 0x3f)
+		beam_info->sounding_sequence = 0;
+	else
+		beam_info->sounding_sequence++;
+
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		AID = 0;
+
+	sta_info.aid = AID;
+	sta_info.feedback_type = 0;
+	sta_info.nc_index = 0;
+
+	_rtw_memcpy(pframe + 17, (u8 *)&sta_info, 2);
+
+	pattrib->pktlen = 19;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+
+	return true;
+}
+
+
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+)
+{
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER			*adapter = dm->adapter;
+	struct xmit_frame		*pmgntframe;
+	struct pkt_attrib		*pattrib;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
+	struct _RT_NDPA_STA_INFO	ndpa_sta_info;
+	u8	ndp_tx_rate = 0, sequence = 0, a_sifs_time = 0, idx = 0;
+	u8	*pframe;
+	u16	*fctrl;
+	u16	duration = 0;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY	*beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate);
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+
+	if (pmgntframe == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n", __func__);
+		return false;
+	}
+
+	/*update attribute*/
+	pattrib = &pmgntframe->attrib;
+	_rtw_memcpy(pattrib->ra, RA, ETH_ALEN);
+	update_mgntframe_attrib(adapter, pattrib);
+	pattrib->qsel = QSLT_MGNT;
+	pattrib->rate = ndp_tx_rate;
+	pattrib->bwmode = BW;
+	pattrib->subtype = WIFI_NDPA;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	set_frame_sub_type(pframe, WIFI_NDPA);
+
+	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
+		a_sifs_time = 16;
+	else
+		a_sifs_time = 10;
+
+	duration = 2 * a_sifs_time + 44;
+
+	if (BW == CHANNEL_WIDTH_80)
+		duration += 40;
+	else if (BW == CHANNEL_WIDTH_40)
+		duration += 87;
+	else
+		duration += 180;
+
+	set_duration(pframe, duration);
+
+	sequence = beam_info->sounding_sequence << 2;
+	if (beam_info->sounding_sequence >= 0x3f)
+		beam_info->sounding_sequence = 0;
+	else
+		beam_info->sounding_sequence++;
+
+	_rtw_memcpy(pframe + 16, &sequence, 1);
+	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
+		AID = 0;
+
+	ndpa_sta_info.aid = AID;
+	ndpa_sta_info.feedback_type = 0;
+	ndpa_sta_info.nc_index = 0;
+
+	_rtw_memcpy(pframe + 17, (u8 *)&ndpa_sta_info, 2);
+
+	pattrib->pktlen = 19;
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	dump_mgntframe(adapter, pmgntframe);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] [%d]\n", __func__, __LINE__);
+
+	return true;
+}
+
+
+#endif
+
+
+void
+beamforming_get_ndpa_frame(
+	void			*dm_void,
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	OCTET_STRING	pdu_os
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	union recv_frame *precv_frame
+#endif
+)
+{
+	struct dm_struct					*dm = (struct dm_struct *)dm_void;
+	u8						*TA ;
+	u8						idx, sequence;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	u8						*p_ndpa_frame = pdu_os.Octet;
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	u8						*p_ndpa_frame = precv_frame->u.hdr.rx_data;
+#endif
+	struct _RT_BEAMFORMER_ENTRY		*beamformer_entry = NULL;		/*Modified By Jeffery @2014-10-29*/
+
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "beamforming_get_ndpa_frame\n", pdu_os.Octet, pdu_os.Length);
+	if (IsCtrlNDPA(p_ndpa_frame) == false)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (get_frame_sub_type(p_ndpa_frame) != WIFI_NDPA)
+#endif
+		return;
+	else if (!(dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] not 8812 or 8821A, return\n", __func__);
+		return;
+	}
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	TA = Frame_Addr2(pdu_os);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	TA = get_addr2_ptr(p_ndpa_frame);
+#endif
+	/*Remove signaling TA. */
+	TA[0] = TA[0] & 0xFE;
+
+	beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, TA, &idx);		/* Modified By Jeffery @2014-10-29 */
+
+	/*Break options for Clock Reset*/
+	if (beamformer_entry == NULL)
+		return;
+	else if (!(beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU))
+		return;
+	/*log_success: As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is NO LONGER needed !2015-04-10, Jeffery*/
+	/*clock_reset_times: While BFer entry always doesn't receive our CSI, clock will reset again and again.So clock_reset_times is limited to 5 times.2015-04-13, Jeffery*/
+	else if ((beamformer_entry->log_success == 1) || (beamformer_entry->clock_reset_times == 5)) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, log_success=%d, clock_reset_times=%d, clock reset is no longer needed.\n",
+			__func__, beamformer_entry->log_seq, beamformer_entry->pre_log_seq, beamformer_entry->log_retry_cnt, beamformer_entry->log_success, beamformer_entry->clock_reset_times);
+
+		return;
+	}
+
+	sequence = (p_ndpa_frame[16]) >> 2;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start, sequence=%d, log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, clock_reset_times=%d, log_success=%d\n",
+		__func__, sequence, beamformer_entry->log_seq, beamformer_entry->pre_log_seq, beamformer_entry->log_retry_cnt, beamformer_entry->clock_reset_times, beamformer_entry->log_success);
+
+	if ((beamformer_entry->log_seq != 0) && (beamformer_entry->pre_log_seq != 0)) {
+		/*Success condition*/
+		if ((beamformer_entry->log_seq != sequence) && (beamformer_entry->pre_log_seq != beamformer_entry->log_seq)) {
+			/* break option for clcok reset, 2015-03-30, Jeffery */
+			beamformer_entry->log_retry_cnt = 0;
+			/*As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is no longer needed.*/
+			/*That is, log_success is NOT needed to be reset to zero, 2015-04-13, Jeffery*/
+			beamformer_entry->log_success = 1;
+
+		} else {/*Fail condition*/
+
+			if (beamformer_entry->log_retry_cnt == 5) {
+				beamformer_entry->clock_reset_times++;
+				beamformer_entry->log_retry_cnt = 0;
+
+				PHYDM_DBG(dm, DBG_TXBF, "[%s] Clock Reset!!! clock_reset_times=%d\n",
+					__func__, beamformer_entry->clock_reset_times);
+				hal_com_txbf_set(dm, TXBF_SET_SOUNDING_CLK, NULL);
+
+			} else
+				beamformer_entry->log_retry_cnt++;
+		}
+	}
+
+	/*Update log_seq & pre_log_seq*/
+	beamformer_entry->pre_log_seq = beamformer_entry->log_seq;
+	beamformer_entry->log_seq = sequence;
+
+}
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.h
index 35ad3cf20c44..025048f308a2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfinterface.h
@@ -1,159 +1,190 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __HAL_TXBF_INTERFACE_H__
-#define __HAL_TXBF_INTERFACE_H__
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-VOID
-Beamforming_GidPAid(
-	PADAPTER	Adapter,
-	PRT_TCB		pTcb
-	);
-
-RT_STATUS
-Beamforming_GetReportFrame(
-	IN	PADAPTER		Adapter,
-	IN	PRT_RFD			pRfd,
-	IN	POCTET_STRING	pPduOS
-	);
-
-VOID
-Beamforming_GetNDPAFrame(
-	IN	PVOID			pDM_VOID,
-	IN	OCTET_STRING	pduOS
-	);
-
-BOOLEAN
-SendFWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	);
-
-BOOLEAN
-SendFWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	);
-
-BOOLEAN
-SendSWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	);
-
-BOOLEAN
-SendSWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	);
-
-#ifdef SUPPORT_MU_BF
-#if (SUPPORT_MU_BF == 1)
-RT_STATUS
-Beamforming_GetVHTGIDMgntFrame(
-	IN	PADAPTER		Adapter,
-	IN	PRT_RFD			pRfd,
-	IN	POCTET_STRING	pPduOS
-	);
-
-BOOLEAN
-SendSWVHTGIDMgntFrame(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u1Byte			Idx
-	);
-
-BOOLEAN
-SendSWVHTBFReportPoll(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	BOOLEAN			bFinalPoll
-	);
-
-BOOLEAN
-SendSWVHTMUNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	CHANNEL_WIDTH	BW
-	);
-#else
-#define Beamforming_GetVHTGIDMgntFrame(Adapter, pRfd, pPduOS) RT_STATUS_FAILURE
-#define SendSWVHTGIDMgntFrame(pDM_VOID, RA)
-#define SendSWVHTBFReportPoll(pDM_VOID, RA, bFinalPoll)
-#define SendSWVHTMUNDPAPacket(pDM_VOID, BW)
-#endif
-#endif
-
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-u4Byte
-Beamforming_GetReportFrame(
-	IN	PVOID			pDM_VOID,
-	union recv_frame *precv_frame
-	);
-
-BOOLEAN
-SendFWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	);
-
-BOOLEAN
-SendSWHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	CHANNEL_WIDTH	BW
-	);
-
-BOOLEAN
-SendFWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	);
-
-BOOLEAN
-SendSWVHTNDPAPacket(
-	IN	PVOID			pDM_VOID,
-	IN	pu1Byte			RA,
-	IN	u2Byte			AID,
-	IN	CHANNEL_WIDTH	BW
-	);
-#endif
-
-VOID
-Beamforming_GetNDPAFrame(
-	IN	PVOID			pDM_VOID,
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	IN	OCTET_STRING	pduOS
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	union recv_frame *precv_frame
-#endif
-);
-
-#else
-#define Beamforming_GetNDPAFrame(pDM_Odm, _PduOS)
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#define Beamforming_GetReportFrame(Adapter, precv_frame)		RT_STATUS_FAILURE
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#define Beamforming_GetReportFrame(Adapter, pRfd, pPduOS)		RT_STATUS_FAILURE
-#define Beamforming_GetVHTGIDMgntFrame(Adapter, pRfd, pPduOS) RT_STATUS_FAILURE
-#endif
-#define SendFWHTNDPAPacket(pDM_VOID, RA, BW)
-#define SendSWHTNDPAPacket(pDM_VOID, RA, BW)
-#define SendFWVHTNDPAPacket(pDM_VOID, RA, AID, BW)
-#define SendSWVHTNDPAPacket(pDM_VOID, RA,	AID, BW)
-#define SendSWVHTGIDMgntFrame(pDM_VOID, RA, idx)
-#define SendSWVHTBFReportPoll(pDM_VOID, RA, bFinalPoll)
-#define SendSWVHTMUNDPAPacket(pDM_VOID, BW)
-#endif
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_INTERFACE_H__
+#define __HAL_TXBF_INTERFACE_H__
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+#define a_SifsTime					((IS_WIRELESS_MODE_5G(adapter)|| IS_WIRELESS_MODE_N_24G(adapter))? 16 : 10)
+
+void
+beamforming_gid_paid(
+	void	*adapter,
+	PRT_TCB		tcb
+);
+
+enum rt_status
+beamforming_get_report_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+);
+
+void
+beamforming_get_ndpa_frame(
+	void			*dm_void,
+	OCTET_STRING	pdu_os
+);
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+#if (SUPPORT_MU_BF == 1)
+enum rt_status
+beamforming_get_vht_gid_mgnt_frame(
+	void		*adapter,
+	PRT_RFD			rfd,
+	POCTET_STRING	p_pdu_os
+);
+
+boolean
+send_sw_vht_gid_mgnt_frame(
+	void			*dm_void,
+	u8			*RA,
+	u8			idx
+);
+
+boolean
+send_sw_vht_bf_report_poll(
+	void			*dm_void,
+	u8			*RA,
+	boolean			is_final_poll
+);
+
+boolean
+send_sw_vht_mu_ndpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+);
+#else
+#define beamforming_get_vht_gid_mgnt_frame(adapter, rfd, p_pdu_os) RT_STATUS_FAILURE
+#define send_sw_vht_gid_mgnt_frame(dm_void, RA)
+#define send_sw_vht_bf_report_poll(dm_void, RA, is_final_poll)
+#define send_sw_vht_mu_ndpa_packet(dm_void, BW)
+#endif
+
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+
+u32
+beamforming_get_report_frame(
+	void			*dm_void,
+	union recv_frame *precv_frame
+);
+
+boolean
+send_fw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_ht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	enum channel_width	BW
+);
+
+boolean
+send_fw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+
+boolean
+send_sw_vht_ndpa_packet(
+	void			*dm_void,
+	u8			*RA,
+	u16			AID,
+	enum channel_width	BW
+);
+#endif
+
+void
+beamforming_get_ndpa_frame(
+	void			*dm_void,
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	OCTET_STRING	pdu_os
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	union recv_frame *precv_frame
+#endif
+);
+
+boolean
+dbg_send_sw_vht_mundpa_packet(
+	void			*dm_void,
+	enum channel_width	BW
+);
+
+#else
+#define beamforming_get_ndpa_frame(dm, _pdu_os)
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	#define beamforming_get_report_frame(adapter, precv_frame)		RT_STATUS_FAILURE
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	#define beamforming_get_report_frame(adapter, rfd, p_pdu_os)		RT_STATUS_FAILURE
+	#define beamforming_get_vht_gid_mgnt_frame(adapter, rfd, p_pdu_os) RT_STATUS_FAILURE
+#endif
+#define send_fw_ht_ndpa_packet(dm_void, RA, BW)
+#define send_sw_ht_ndpa_packet(dm_void, RA, BW)
+#define send_fw_vht_ndpa_packet(dm_void, RA, AID, BW)
+#define send_sw_vht_ndpa_packet(dm_void, RA,	AID, BW)
+#define send_sw_vht_gid_mgnt_frame(dm_void, RA, idx)
+#define send_sw_vht_bf_report_poll(dm_void, RA, is_final_poll)
+#define send_sw_vht_mu_ndpa_packet(dm_void, BW)
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.c
index 404953f976f5..b45fc6be3a1d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.c
@@ -1,528 +1,541 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-//============================================================
-// Description:
-//
-// This file is for 8812/8821/8811 TXBF mechanism
-//
-//============================================================
-#include "mp_precomp.h"
-#include "../phydm_precomp.h"
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-VOID
-HalTxbf8812A_setNDPArate(
-	IN PVOID			pDM_VOID,
-	IN u1Byte	BW,
-	IN u1Byte	Rate
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	ODM_Write1Byte(pDM_Odm, REG_NDPA_OPT_CTRL_8812A,  (Rate << 2 | BW));	
-
-}
-
-VOID
-halTxbfJaguar_RfMode(
-	IN PVOID			pDM_VOID,
-	IN PRT_BEAMFORMING_INFO	pBeamInfo
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	
-	if (pDM_Odm->RFType == ODM_1T1R)
-		return;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] set TxIQGen\n", __func__));
-
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WeLut_Jaguar, 0x80000, 0x1);	/*RF Mode table write enable*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_WeLut_Jaguar, 0x80000, 0x1);	/*RF Mode table write enable*/
-
-	if (pBeamInfo->beamformee_su_cnt > 0) {
-		// Paath_A
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
-		// Path_B
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData1, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
-	} else {
-		// Paath_A
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_ModeTableData1, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
-		// Path_B
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableAddr, 0x78000, 0x3);		/*Select RX mode*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData0, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_ModeTableData1, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
-	}
-
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_WeLut_Jaguar, 0x80000, 0x0);	/*RF Mode table write disable*/
-	ODM_SetRFReg(pDM_Odm, ODM_RF_PATH_B, RF_WeLut_Jaguar, 0x80000, 0x0);	/*RF Mode table write disable*/
-
-	if (pBeamInfo->beamformee_su_cnt > 0)
-		ODM_SetBBReg(pDM_Odm, rTxPath_Jaguar, bMaskByte1, 0x33);
-	else
-		ODM_SetBBReg(pDM_Odm, rTxPath_Jaguar, bMaskByte1, 0x11);
-}
-
-
-VOID
-halTxbfJaguar_DownloadNDPA(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte			u1bTmp = 0, tmpReg422 = 0, Head_Page;
-	u1Byte			BcnValidReg = 0, count = 0, DLBcnCount = 0;
-	BOOLEAN			bSendBeacon = FALSE;
-	u1Byte			TxPageBndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;	/*default reseved 1 page for the IC type which is undefined.*/
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-	PADAPTER		Adapter = pDM_Odm->Adapter;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*pDM_Odm->pbFwDwRsvdPageInProgress = TRUE;
-#endif
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (Idx == 0)
-		Head_Page = 0xFE;
-	else
-		Head_Page = 0xFE;
-
-	Adapter->HalFunc.GetHalDefVarHandler(Adapter, HAL_DEF_TX_PAGE_BOUNDARY, (pu1Byte)&TxPageBndy);
-
-	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1bTmp = ODM_Read1Byte(pDM_Odm, REG_CR_8812A + 1);
-	ODM_Write1Byte(pDM_Odm,  REG_CR_8812A + 1, (u1bTmp | BIT0));
-
-
-	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmpReg422 = ODM_Read1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8812A + 2);
-	ODM_Write1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8812A + 2,  tmpReg422 & (~BIT6));
-
-	if (tmpReg422 & BIT6) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("SetBeamformDownloadNDPA_8812(): There is an Adapter is sending beacon.\n"));
-		bSendBeacon = TRUE;
-	}
-
-	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_TDECTRL_8812A + 1, Head_Page);
-
-	do {
-		/*Clear beacon valid check bit.*/
-		BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_TDECTRL_8812A + 2);
-		ODM_Write1Byte(pDM_Odm, REG_TDECTRL_8812A + 2, (BcnValidReg | BIT0));
-
-		/*download NDPA rsvd page.*/
-		if (pBeamEntry->BeamformEntryCap & BEAMFORMER_CAP_VHT_SU)
-			Beamforming_SendVHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->AID, pBeamEntry->SoundBW, BEACON_QUEUE);
-		else
-			Beamforming_SendHTNDPAPacket(pDM_Odm, pBeamEntry->MacAddr, pBeamEntry->SoundBW, BEACON_QUEUE);
-
-		/*check rsvd page download OK.*/
-		BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_TDECTRL_8812A + 2);
-		count = 0;
-		while (!(BcnValidReg & BIT0) && count < 20) {
-			count++;
-			ODM_delay_ms(10);
-			BcnValidReg = ODM_Read1Byte(pDM_Odm, REG_TDECTRL_8812A + 2);
-		}
-		DLBcnCount++;
-	} while (!(BcnValidReg & BIT0) && DLBcnCount < 5);
-
-	if (!(BcnValidReg & BIT0))
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("%s Download RSVD page failed!\n", __func__));
-
-	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_TDECTRL_8812A + 1, TxPageBndy);
-
-	/*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 (bSendBeacon)
-		ODM_Write1Byte(pDM_Odm, REG_FWHW_TXQ_CTRL_8812A + 2, tmpReg422);
-
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1bTmp = ODM_Read1Byte(pDM_Odm, REG_CR_8812A + 1);
-	ODM_Write1Byte(pDM_Odm, REG_CR_8812A + 1, (u1bTmp & (~BIT0)));
-
-	pBeamEntry->BeamformEntryState = BEAMFORMING_ENTRY_STATE_PROGRESSED;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*pDM_Odm->pbFwDwRsvdPageInProgress = FALSE;
-#endif
-}
-
-
-VOID
-halTxbfJaguar_FwTxBFCmd(
-	IN PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte	Idx, Period0 = 0, Period1 = 0;
-	u1Byte	PageNum0 = 0xFF, PageNum1 = 0xFF;
-	u1Byte	u1TxBFParm[3] = {0};
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	for (Idx = 0; Idx < BEAMFORMEE_ENTRY_NUM; Idx++) {
-		/*Modified by David*/
-		if (pBeamInfo->BeamformeeEntry[Idx].bUsed && pBeamInfo->BeamformeeEntry[Idx].BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (Idx == 0) {
-				if (pBeamInfo->BeamformeeEntry[Idx].bSound)
-					PageNum0 = 0xFE;
-				else
-					PageNum0 = 0xFF; /*stop sounding*/
-				Period0 = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			} else if (Idx == 1) {
-				if (pBeamInfo->BeamformeeEntry[Idx].bSound)
-					PageNum1 = 0xFE;
-				else
-					PageNum1 = 0xFF; /*stop sounding*/
-				Period1 = (u1Byte)(pBeamInfo->BeamformeeEntry[Idx].SoundPeriod);
-			}
-		}
-	}
-
-	u1TxBFParm[0] = PageNum0;
-	u1TxBFParm[1] = PageNum1;
-	u1TxBFParm[2] = (Period1 << 4) | Period0;
-	ODM_FillH2CCmd(pDM_Odm, PHYDM_H2C_TXBF, 3, u1TxBFParm);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, 
-		("[%s] PageNum0 = %d Period0 = %d, PageNum1 = %d Period1 %d\n", __func__, PageNum0, Period0, PageNum1, Period1));
-}
-
-
-VOID
-HalTxbfJaguar_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				BFerBFeeIdx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u1Byte					i = 0;
-	u1Byte					BFerIdx = (BFerBFeeIdx & 0xF0) >> 4;
-	u1Byte					BFeeIdx = (BFerBFeeIdx & 0xF);
-	u4Byte					CSI_Param;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	u2Byte					STAid = 0;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]Start!\n", __func__));
-
-	halTxbfJaguar_RfMode(pDM_Odm, pBeamformingInfo);
-
-	if (pDM_Odm->RFType == ODM_2T2R)
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CSI_CONTENT_VALUE, bMaskDWord, 0x00000000);	/*Nc =2*/
-	else
-		ODM_SetBBReg(pDM_Odm, ODM_REG_CSI_CONTENT_VALUE, bMaskDWord, 0x01081008);	/*Nc =1*/
-
-	if ((pBeamformingInfo->beamformer_su_cnt > 0) && (BFerIdx < BEAMFORMER_ENTRY_NUM)) {
-		BeamformerEntry = pBeamformingInfo->BeamformerEntry[BFerIdx];
-
-		/*Sounding protocol control*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8812A, 0xCB);
-
-		/*MAC address/Partial AID of Beamformer*/
-		if (BFerIdx == 0) {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_BFMER0_INFO_8812A + i), BeamformerEntry.MacAddr[i]);
-			/*CSI report use legacy ofdm so don't need to fill P_AID. */
-			/*PlatformEFIOWrite2Byte(Adapter, REG_BFMER0_INFO_8812A+6, BeamformEntry.P_AID); */
-		} else {
-			for (i = 0; i < 6 ; i++)
-				ODM_Write1Byte(pDM_Odm, (REG_BFMER1_INFO_8812A + i), BeamformerEntry.MacAddr[i]);
-			/*CSI report use legacy ofdm so don't need to fill P_AID.*/
-			/*PlatformEFIOWrite2Byte(Adapter, REG_BFMER1_INFO_8812A+6, BeamformEntry.P_AID);*/
-		}
-
-		/*CSI report parameters of Beamformee*/
-		if (BeamformerEntry.BeamformEntryCap & BEAMFORMEE_CAP_VHT_SU) {
-			if (pDM_Odm->RFType == ODM_2T2R)
-				CSI_Param = 0x01090109;
-			else
-				CSI_Param = 0x01080108;
-		} else {
-			if (pDM_Odm->RFType == ODM_2T2R)
-				CSI_Param = 0x03090309;
-			else
-				CSI_Param = 0x03080308;
-		}
-
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8812A, CSI_Param);
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW40_8812A, CSI_Param);
-		ODM_Write4Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW80_8812A, CSI_Param);
-
-		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8812A + 3, 0x50);
-	}
-
-
-	if ((pBeamformingInfo->beamformee_su_cnt > 0) && (BFeeIdx < BEAMFORMEE_ENTRY_NUM)) {
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[BFeeIdx];
-
-		if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-			STAid = BeamformeeEntry.MacId;
-		else
-			STAid = BeamformeeEntry.P_AID;
-
-		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
-		if (BFeeIdx == 0) {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8812A, STAid);
-			ODM_Write1Byte(pDM_Odm, REG_TXBF_CTRL_8812A + 3, ODM_Read1Byte(pDM_Odm, REG_TXBF_CTRL_8812A + 3) | BIT4 | BIT6 | BIT7);
-		} else
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8812A + 2, STAid | BIT12 | BIT14 | BIT15);
-
-		/*CSI report parameters of Beamformee*/
-		if (BFeeIdx == 0) {
-			/*Get BIT24 & BIT25*/
-			u1Byte	tmp = ODM_Read1Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 3) & 0x3;
-
-			ODM_Write1Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 3, tmp | 0x60);
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A, STAid | BIT9);
-		} else {
-			/*Set BIT25*/
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 2, STAid | 0xE200);
-		}
-			phydm_Beamforming_Notify(pDM_Odm);
-	}
-}
-
-
-VOID
-HalTxbfJaguar_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamformingInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMER_ENTRY	BeamformerEntry;
-	RT_BEAMFORMEE_ENTRY	BeamformeeEntry;
-	
-	if (Idx < BEAMFORMER_ENTRY_NUM) {
-		BeamformerEntry = pBeamformingInfo->BeamformerEntry[Idx];
-		BeamformeeEntry = pBeamformingInfo->BeamformeeEntry[Idx];
-	} else
-		return;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s]Start!, IDx = %d\n", __func__, Idx));
-
-	/*Clear P_AID of Beamformee*/
-	/*Clear MAC address of Beamformer*/
-	/*Clear Associated Bfmee Sel*/
-	
-	if (BeamformerEntry.BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8812A, 0xC8);
-		if (Idx == 0) {
-			ODM_Write4Byte(pDM_Odm, REG_BFMER0_INFO_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_BFMER0_INFO_8812A + 4, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
-		} else {
-			ODM_Write4Byte(pDM_Odm, REG_BFMER1_INFO_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_BFMER1_INFO_8812A + 4, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
-			ODM_Write2Byte(pDM_Odm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
-		}
-	}
-
-	if (BeamformeeEntry.BeamformEntryCap == BEAMFORMING_CAP_NONE) {
-		halTxbfJaguar_RfMode(pDM_Odm, pBeamformingInfo);
-		if (Idx == 0) {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8812A, 0x0);
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A, 0);
-		} else {
-			ODM_Write2Byte(pDM_Odm, REG_TXBF_CTRL_8812A + 2, ODM_Read2Byte(pDM_Odm, REG_TXBF_CTRL_8812A + 2) & 0xF000);
-			ODM_Write2Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 2, ODM_Read2Byte(pDM_Odm, REG_BFMEE_SEL_8812A + 2) & 0x60);
-		}
-	}
-	
-}
-
-
-VOID
-HalTxbfJaguar_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte					BeamCtrlVal;
-	u4Byte					BeamCtrlReg;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	RT_BEAMFORMEE_ENTRY	BeamformEntry = pBeamInfo->BeamformeeEntry[Idx];
-
-	if (phydm_actingDetermine(pDM_Odm, PhyDM_ACTING_AS_IBSS))
-		BeamCtrlVal = BeamformEntry.MacId;
-	else
-		BeamCtrlVal = BeamformEntry.P_AID;
-
-	if (Idx == 0)
-		BeamCtrlReg = REG_TXBF_CTRL_8812A;
-	else {
-		BeamCtrlReg = REG_TXBF_CTRL_8812A + 2;
-		BeamCtrlVal |= BIT12 | BIT14 | BIT15;
-	}
-
-	if (BeamformEntry.BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-		if (BeamformEntry.SoundBW == CHANNEL_WIDTH_20)
-			BeamCtrlVal |= BIT9;
-		else if (BeamformEntry.SoundBW == CHANNEL_WIDTH_40)
-			BeamCtrlVal |= (BIT9 | BIT10);
-		else if (BeamformEntry.SoundBW == CHANNEL_WIDTH_80)
-			BeamCtrlVal |= (BIT9 | BIT10 | BIT11);
-	} else
-		BeamCtrlVal &= ~(BIT9 | BIT10 | BIT11);
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] BeamCtrlVal = 0x%x!\n", __func__, BeamCtrlVal));
-
-	ODM_Write2Byte(pDM_Odm, BeamCtrlReg, BeamCtrlVal);
-}
-
-
-
-VOID
-HalTxbfJaguar_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-	PRT_BEAMFORMEE_ENTRY	pBeamEntry = pBeamInfo->BeamformeeEntry + Idx;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pBeamEntry->BeamformEntryState == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		halTxbfJaguar_DownloadNDPA(pDM_Odm, Idx);
-
-	halTxbfJaguar_FwTxBFCmd(pDM_Odm);
-}
-
-
-VOID
-HalTxbfJaguar_Patch(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Operation
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	PRT_BEAMFORMING_INFO	pBeamInfo = &pDM_Odm->BeamformingInfo;
-
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (pBeamInfo->BeamformCap == BEAMFORMING_CAP_NONE)
-		return;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (Operation == SCAN_OPT_BACKUP_BAND0)
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8812A, 0xC8);
-	else if (Operation == SCAN_OPT_RESTORE)
-		ODM_Write1Byte(pDM_Odm, REG_SND_PTCL_CTRL_8812A, 0xCB);
-#endif
-}
-
-VOID
-HalTxbfJaguar_Clk_8812A(
-	IN PVOID			pDM_VOID
-)
-{
-	PDM_ODM_T	pDM_Odm = (PDM_ODM_T)pDM_VOID;
-	u2Byte	u2btmp;
-	u1Byte	Count = 0, u1btmp;
-	PADAPTER	Adapter = pDM_Odm->Adapter;
-	
-	ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] Start!\n", __func__));
-
-	if (*(pDM_Odm->pbScanInProcess)) {
-		ODM_RT_TRACE(pDM_Odm, PHYDM_COMP_TXBF, ODM_DBG_LOUD, ("[%s] return by Scan\n", __func__));
-		return;
-	}
-#if DEV_BUS_TYPE == RT_PCI_INTERFACE	
-	/*Stop PCIe TxDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_PCIE_CTRL_REG_8812A + 1, 0xFE);
-#endif
-
-	/*Stop Usb TxDMA*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	RT_DISABLE_FUNC(Adapter, DF_TX_BIT);
-	PlatformReturnAllPendingTxPackets(Adapter);
-#else
-	rtw_write_port_cancel(Adapter);
-#endif
-
-	/*Wait TXFF empty*/
-	for (Count = 0; Count < 100; Count++) {
-		u2btmp = ODM_Read2Byte(pDM_Odm, REG_TXPKT_EMPTY_8812A);
-		u2btmp = u2btmp & 0xfff;
-		if (u2btmp != 0xfff) {
-			ODM_delay_ms(10);
-			continue;
-		} else
-			break;
-	}
-
-	/*TX pause*/
-	ODM_Write1Byte(pDM_Odm, REG_TXPAUSE_8812A, 0xFF);
-
-	/*Wait TX State Machine OK*/
-	for (Count = 0; Count < 100; Count++) {
-		if (ODM_Read4Byte(pDM_Odm, REG_SCH_TXCMD_8812A) != 0)
-			continue;
-		else
-			break;
-	}
-
-
-	/*Stop RX DMA path*/
-	u1btmp = ODM_Read1Byte(pDM_Odm, REG_RXDMA_CONTROL_8812A);
-	ODM_Write1Byte(pDM_Odm, REG_RXDMA_CONTROL_8812A, u1btmp | BIT2);
-
-	for (Count = 0; Count < 100; Count++) {
-		u1btmp = ODM_Read1Byte(pDM_Odm, REG_RXDMA_CONTROL_8812A);
-		if (u1btmp & BIT1)
-			break;
-		else
-			ODM_delay_ms(10);
-	}
-
-	/*Disable clock*/
-	ODM_Write1Byte(pDM_Odm, REG_SYS_CLKR_8812A + 1, 0xf0);
-	/*Disable 320M*/
-	ODM_Write1Byte(pDM_Odm, REG_AFE_PLL_CTRL_8812A + 3, 0x8);
-	/*Enable 320M*/
-	ODM_Write1Byte(pDM_Odm, REG_AFE_PLL_CTRL_8812A + 3, 0xa);
-	/*Enable clock*/
-	ODM_Write1Byte(pDM_Odm, REG_SYS_CLKR_8812A + 1, 0xfc);
-
-
-	/*Release Tx pause*/
-	ODM_Write1Byte(pDM_Odm, REG_TXPAUSE_8812A, 0);
-
-	/*Enable RX DMA path*/
-	u1btmp = ODM_Read1Byte(pDM_Odm, REG_RXDMA_CONTROL_8812A);
-	ODM_Write1Byte(pDM_Odm, REG_RXDMA_CONTROL_8812A, u1btmp & (~BIT2));
-#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	/*Enable PCIe TxDMA*/
-	ODM_Write1Byte(pDM_Odm, REG_PCIE_CTRL_REG_8812A + 1, 0);
-#endif
-	/*Start Usb TxDMA*/
-	RT_ENABLE_FUNC(Adapter, DF_TX_BIT);
-}
-
-#endif
-
-
-
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 8812/8821/8811 TXBF mechanism
+ *
+ * ************************************************************ */
+#include "mp_precomp.h"
+#include "../phydm_precomp.h"
+
+#if (BEAMFORMING_SUPPORT == 1)
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+void
+hal_txbf_8812a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8812A, (rate << 2 | BW));
+
+}
+
+void
+hal_txbf_jaguar_rf_mode(
+	void			*dm_void,
+	struct _RT_BEAMFORMING_INFO	*beam_info
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] set TxIQGen\n", __func__);
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x1);	/*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x1);	/*RF mode table write enable*/
+
+	if (beam_info->beamformee_su_cnt > 0) {
+		/* Paath_A */
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
+		/* Path_B */
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
+	} else {
+		/* Paath_A */
+		odm_set_rf_reg(dm, RF_PATH_A, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, 0x32, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
+		/* Path_B */
+		odm_set_rf_reg(dm, RF_PATH_B, 0x30, 0x78000, 0x3);		/*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, 0x32, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
+	}
+
+	odm_set_rf_reg(dm, RF_PATH_A, 0xef, 0x80000, 0x0);	/*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_B, 0xef, 0x80000, 0x0);	/*RF mode table write disable*/
+
+	if (beam_info->beamformee_su_cnt > 0)
+		odm_set_bb_reg(dm, 0x80c, MASKBYTE1, 0x33);
+	else
+		odm_set_bb_reg(dm, 0x80c, MASKBYTE1, 0x11);
+}
+
+
+void
+hal_txbf_jaguar_download_ndpa(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8			u1b_tmp = 0, tmp_reg422 = 0, head_page;
+	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	boolean			is_send_beacon = false;
+	u8			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;	/*default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+	void		*adapter = dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
+#endif
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (idx == 0)
+		head_page = 0xFE;
+	else
+		head_page = 0xFE;
+
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
+
+	/*Set REG_CR bit 8. DMA beacon by SW.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8812A + 1);
+	odm_write_1byte(dm,  REG_CR_8812A + 1, (u1b_tmp | BIT(0)));
+
+
+	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2,  tmp_reg422 & (~BIT(6)));
+
+	if (tmp_reg422 & BIT(6)) {
+		PHYDM_DBG(dm, DBG_TXBF, "SetBeamformDownloadNDPA_8812(): There is an adapter is sending beacon.\n");
+		is_send_beacon = true;
+	}
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
+	odm_write_1byte(dm, REG_TDECTRL_8812A + 1, head_page);
+
+	do {
+		/*Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
+		odm_write_1byte(dm, REG_TDECTRL_8812A + 2, (bcn_valid_reg | BIT(0)));
+
+		/*download NDPA rsvd page.*/
+		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->aid, p_beam_entry->sound_bw, BEACON_QUEUE);
+		else
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+
+		/*check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
+		count = 0;
+		while (!(bcn_valid_reg & BIT(0)) && count < 20) {
+			count++;
+			ODM_delay_ms(10);
+			bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
+		}
+		dl_bcn_count++;
+	} while (!(bcn_valid_reg & BIT(0)) && dl_bcn_count < 5);
+
+	if (!(bcn_valid_reg & BIT(0)))
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n", __func__);
+
+	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
+	odm_write_1byte(dm, REG_TDECTRL_8812A + 1, tx_page_bndy);
+
+	/*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 (is_send_beacon)
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2, tmp_reg422);
+
+	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8812A + 1);
+	odm_write_1byte(dm, REG_CR_8812A + 1, (u1b_tmp & (~BIT(0))));
+
+	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
+#endif
+}
+
+
+void
+hal_txbf_jaguar_fw_txbf_cmd(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8	idx, period0 = 0, period1 = 0;
+	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8	u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		/*Modified by David*/
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (idx == 0) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum0 = 0xFE;
+				else
+					PageNum0 = 0xFF; /*stop sounding*/
+				period0 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			} else if (idx == 1) {
+				if (beam_info->beamformee_entry[idx].is_sound)
+					PageNum1 = 0xFE;
+				else
+					PageNum1 = 0xFF; /*stop sounding*/
+				period1 = (u8)(beam_info->beamformee_entry[idx].sound_period);
+			}
+		}
+	}
+
+	u1_tx_bf_parm[0] = PageNum0;
+	u1_tx_bf_parm[1] = PageNum1;
+	u1_tx_bf_parm[2] = (period1 << 4) | period0;
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+
+	PHYDM_DBG(dm, DBG_TXBF,
+		"[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n", __func__, PageNum0, period0, PageNum1, period1);
+}
+
+
+void
+hal_txbf_jaguar_enter(
+	void			*dm_void,
+	u8				bfer_bfee_idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8					i = 0;
+	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8					bfee_idx = (bfer_bfee_idx & 0xF);
+	u32					csi_param;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	u16					sta_id = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]Start!\n", __func__);
+
+	hal_txbf_jaguar_rf_mode(dm, beamforming_info);
+
+	if (dm->rf_type == RF_2T2R)
+		odm_set_bb_reg(dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x00000000);	/*nc =2*/
+	else
+		odm_set_bb_reg(dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x01081008);	/*nc =1*/
+
+	if ((beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
+
+		/*Sounding protocol control*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
+
+		/*MAC address/Partial AID of Beamformer*/
+		if (bfer_idx == 0) {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_BFMER0_INFO_8812A + i), beamformer_entry.mac_addr[i]);
+			/*CSI report use legacy ofdm so don't need to fill P_AID. */
+			/*platform_efio_write_2byte(adapter, REG_BFMER0_INFO_8812A+6, beamform_entry.P_AID); */
+		} else {
+			for (i = 0; i < 6 ; i++)
+				odm_write_1byte(dm, (REG_BFMER1_INFO_8812A + i), beamformer_entry.mac_addr[i]);
+			/*CSI report use legacy ofdm so don't need to fill P_AID.*/
+			/*platform_efio_write_2byte(adapter, REG_BFMER1_INFO_8812A+6, beamform_entry.P_AID);*/
+		}
+
+		/*CSI report parameters of Beamformee*/
+		if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU) {
+			if (dm->rf_type == RF_2T2R)
+				csi_param = 0x01090109;
+			else
+				csi_param = 0x01080108;
+		} else {
+			if (dm->rf_type == RF_2T2R)
+				csi_param = 0x03090309;
+			else
+				csi_param = 0x03080308;
+		}
+
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, csi_param);
+
+		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A + 3, 0x50);
+	}
+
+
+	if ((beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			sta_id = beamformee_entry.mac_id;
+		else
+			sta_id = beamformee_entry.p_aid;
+
+		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
+		if (bfee_idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8812A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8812A + 3) | BIT(4) | BIT(6) | BIT(7));
+		} else
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A + 2, sta_id | BIT(12) | BIT(14) | BIT(15));
+
+		/*CSI report parameters of Beamformee*/
+		if (bfee_idx == 0) {
+			/*Get BIT24 & BIT25*/
+			u8	tmp = odm_read_1byte(dm, REG_BFMEE_SEL_8812A + 3) & 0x3;
+
+			odm_write_1byte(dm, REG_BFMEE_SEL_8812A + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A, sta_id | BIT(9));
+		} else {
+			/*Set BIT25*/
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A + 2, sta_id | 0xE200);
+		}
+		phydm_beamforming_notify(dm);
+	}
+}
+
+
+void
+hal_txbf_jaguar_leave(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+
+	if (idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = beamforming_info->beamformer_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
+	} else
+		return;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]Start!, IDx = %d\n", __func__, idx);
+
+	/*Clear P_AID of Beamformee*/
+	/*Clear MAC address of Beamformer*/
+	/*Clear Associated Bfmee Sel*/
+
+	if (beamformer_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
+		if (idx == 0) {
+			odm_write_4byte(dm, REG_BFMER0_INFO_8812A, 0);
+			odm_write_2byte(dm, REG_BFMER0_INFO_8812A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
+		} else {
+			odm_write_4byte(dm, REG_BFMER1_INFO_8812A, 0);
+			odm_write_2byte(dm, REG_BFMER1_INFO_8812A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
+		}
+	}
+
+	if (beamformee_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		hal_txbf_jaguar_rf_mode(dm, beamforming_info);
+		if (idx == 0) {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A, 0x0);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A, 0);
+		} else {
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A + 2, odm_read_2byte(dm, REG_TXBF_CTRL_8812A + 2) & 0xF000);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A + 2, odm_read_2byte(dm, REG_BFMEE_SEL_8812A + 2) & 0x60);
+		}
+	}
+
+}
+
+
+void
+hal_txbf_jaguar_status(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16					beam_ctrl_val;
+	u32					beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	beamform_entry = beam_info->beamformee_entry[idx];
+
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+		beam_ctrl_val = beamform_entry.mac_id;
+	else
+		beam_ctrl_val = beamform_entry.p_aid;
+
+	if (idx == 0)
+		beam_ctrl_reg = REG_TXBF_CTRL_8812A;
+	else {
+		beam_ctrl_reg = REG_TXBF_CTRL_8812A + 2;
+		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
+	}
+
+	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (beam_info->apply_v_matrix == true)) {
+		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
+			beam_ctrl_val |= BIT(9);
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
+			beam_ctrl_val |= (BIT(9) | BIT(10));
+		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_80)
+			beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
+	} else
+		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] beam_ctrl_val = 0x%x!\n", __func__, beam_ctrl_val);
+
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+}
+
+
+
+void
+hal_txbf_jaguar_fw_txbf(
+	void			*dm_void,
+	u8				idx
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+		hal_txbf_jaguar_download_ndpa(dm, idx);
+
+	hal_txbf_jaguar_fw_txbf_cmd(dm);
+}
+
+
+void
+hal_txbf_jaguar_patch(
+	void			*dm_void,
+	u8				operation
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
+		return;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (operation == SCAN_OPT_BACKUP_BAND0)
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
+	else if (operation == SCAN_OPT_RESTORE)
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
+#endif
+}
+
+void
+hal_txbf_jaguar_clk_8812a(
+	void			*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u16	u2btmp;
+	u8	count = 0, u1btmp;
+	void	*adapter = dm->adapter;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (*(dm->is_scan_in_process)) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] return by Scan\n", __func__);
+		return;
+	}
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	/*Stop PCIe TxDMA*/
+	odm_write_1byte(dm, REG_PCIE_CTRL_REG_8812A + 1, 0xFE);
+#endif
+
+	/*Stop Usb TxDMA*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	RT_DISABLE_FUNC((PADAPTER)adapter, DF_TX_BIT);
+	PlatformReturnAllPendingTxPackets((PADAPTER)adapter);
+#else
+	rtw_write_port_cancel(adapter);
+#endif
+
+	/*Wait TXFF empty*/
+	for (count = 0; count < 100; count++) {
+		u2btmp = odm_read_2byte(dm, REG_TXPKT_EMPTY_8812A);
+		u2btmp = u2btmp & 0xfff;
+		if (u2btmp != 0xfff) {
+			ODM_delay_ms(10);
+			continue;
+		} else
+			break;
+	}
+
+	/*TX pause*/
+	odm_write_1byte(dm, REG_TXPAUSE_8812A, 0xFF);
+
+	/*Wait TX state Machine OK*/
+	for (count = 0; count < 100; count++) {
+		if (odm_read_4byte(dm, REG_SCH_TXCMD_8812A) != 0)
+			continue;
+		else
+			break;
+	}
+
+
+	/*Stop RX DMA path*/
+	u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+	odm_write_1byte(dm, REG_RXDMA_CONTROL_8812A, u1btmp | BIT(2));
+
+	for (count = 0; count < 100; count++) {
+		u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+		if (u1btmp & BIT(1))
+			break;
+		else
+			ODM_delay_ms(10);
+	}
+
+	/*Disable clock*/
+	odm_write_1byte(dm, REG_SYS_CLKR_8812A + 1, 0xf0);
+	/*Disable 320M*/
+	odm_write_1byte(dm, REG_AFE_PLL_CTRL_8812A + 3, 0x8);
+	/*Enable 320M*/
+	odm_write_1byte(dm, REG_AFE_PLL_CTRL_8812A + 3, 0xa);
+	/*Enable clock*/
+	odm_write_1byte(dm, REG_SYS_CLKR_8812A + 1, 0xfc);
+
+
+	/*Release Tx pause*/
+	odm_write_1byte(dm, REG_TXPAUSE_8812A, 0);
+
+	/*Enable RX DMA path*/
+	u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+	odm_write_1byte(dm, REG_RXDMA_CONTROL_8812A, u1btmp & (~BIT(2)));
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	/*Enable PCIe TxDMA*/
+	odm_write_1byte(dm, REG_PCIE_CTRL_REG_8812A + 1, 0);
+#endif
+	/*Start Usb TxDMA*/
+	RT_ENABLE_FUNC((PADAPTER)adapter, DF_TX_BIT);
+}
+
+#endif
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.h
index 3879a4f637ac..be3c0ee74688 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/haltxbfjaguar.h
@@ -1,68 +1,99 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __HAL_TXBF_JAGUAR_H__
-#define __HAL_TXBF_JAGUAR_H__
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-VOID
-HalTxbf8812A_setNDPArate(
-	IN PVOID			pDM_VOID,
-	IN u1Byte	BW,
-	IN u1Byte	Rate
-);
-
-
-VOID
-HalTxbfJaguar_Enter(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbfJaguar_Leave(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbfJaguar_Status(
-	IN PVOID			pDM_VOID,
-	IN u1Byte				Idx
-	);
-
-
-VOID
-HalTxbfJaguar_FwTxBF(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Idx
-	);
-
-
-VOID
-HalTxbfJaguar_Patch(
-	IN PVOID			pDM_VOID,
-	IN	u1Byte				Operation
-	);
-
-
-VOID
-HalTxbfJaguar_Clk_8812A(
-	IN PVOID			pDM_VOID
-	);
-
-#else
-
-#define HalTxbf8812A_setNDPArate(pDM_VOID,	BW,	Rate)
-#define HalTxbfJaguar_Enter(pDM_VOID, Idx)
-#define HalTxbfJaguar_Leave(pDM_VOID, Idx)
-#define HalTxbfJaguar_Status(pDM_VOID, Idx)
-#define HalTxbfJaguar_FwTxBF(pDM_VOID,	Idx)
-#define HalTxbfJaguar_Patch(pDM_VOID, Operation)
-#define HalTxbfJaguar_Clk_8812A(pDM_VOID)
-#endif
-
-#endif				
-#endif	// #ifndef __HAL_TXBF_JAGUAR_H__								
-
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef __HAL_TXBF_JAGUAR_H__
+#define __HAL_TXBF_JAGUAR_H__
+#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
+#if (BEAMFORMING_SUPPORT == 1)
+
+void
+hal_txbf_8812a_set_ndpa_rate(
+	void			*dm_void,
+	u8	BW,
+	u8	rate
+);
+
+
+void
+hal_txbf_jaguar_enter(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_leave(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_status(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_fw_txbf(
+	void			*dm_void,
+	u8				idx
+);
+
+
+void
+hal_txbf_jaguar_patch(
+	void			*dm_void,
+	u8				operation
+);
+
+
+void
+hal_txbf_jaguar_clk_8812a(
+	void			*dm_void
+);
+#else
+
+#define hal_txbf_8812a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_jaguar_enter(dm_void, idx)
+#define hal_txbf_jaguar_leave(dm_void, idx)
+#define hal_txbf_jaguar_status(dm_void, idx)
+#define hal_txbf_jaguar_fw_txbf(dm_void,	idx)
+#define hal_txbf_jaguar_patch(dm_void, operation)
+#define hal_txbf_jaguar_clk_8812a(dm_void)
+#endif
+#else
+
+#define hal_txbf_8812a_set_ndpa_rate(dm_void,	BW,	rate)
+#define hal_txbf_jaguar_enter(dm_void, idx)
+#define hal_txbf_jaguar_leave(dm_void, idx)
+#define hal_txbf_jaguar_status(dm_void, idx)
+#define hal_txbf_jaguar_fw_txbf(dm_void,	idx)
+#define hal_txbf_jaguar_patch(dm_void, operation)
+#define hal_txbf_jaguar_clk_8812a(dm_void)
+#endif
+
+#endif	/*  #ifndef __HAL_TXBF_JAGUAR_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/phydm_hal_txbf_api.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/phydm_hal_txbf_api.c
new file mode 100644
index 000000000000..45c7e5a8b3b1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/phydm_hal_txbf_api.c
@@ -0,0 +1,203 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (defined(CONFIG_BB_TXBF_API))
+#if (RTL8822B_SUPPORT == 1)
+/*Add by YuChen for 8822B MU-MIMO API*/
+
+/*this function is only used for BFer*/
+u8
+phydm_get_ndpa_rate(
+	void		*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8		ndpa_rate = ODM_RATE6M;
+
+	if (dm->rssi_min >= 30)	/*link RSSI > 30%*/
+		ndpa_rate = ODM_RATE24M;
+	else if (dm->rssi_min <= 25)
+		ndpa_rate = ODM_RATE6M;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndpa_rate = 0x%x\n", __func__, ndpa_rate);
+
+	return ndpa_rate;
+
+}
+
+/*this function is only used for BFer*/
+u8
+phydm_get_beamforming_sounding_info(
+	void		*dm_void,
+	u16	*troughput,
+	u8	total_bfee_num,
+	u8	*tx_rate
+)
+{
+	u8	idx = 0;
+	u8	soundingdecision = 0xff;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	for (idx = 0; idx < total_bfee_num; idx++) {
+		if (dm->support_ic_type & (ODM_RTL8814A)) {
+			if (((tx_rate[idx] >= ODM_RATEVHTSS3MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS3MCS9)))
+				soundingdecision = soundingdecision & ~(1 << idx);
+		} else if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8822C | ODM_RTL8812)) {
+			if (((tx_rate[idx] >= ODM_RATEVHTSS2MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS2MCS9)))
+				soundingdecision = soundingdecision & ~(1 << idx);
+		} else if (dm->support_ic_type & (ODM_RTL8814B)) {
+			if (((tx_rate[idx] >= ODM_RATEVHTSS4MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS4MCS9)))
+				soundingdecision = soundingdecision & ~(1 << idx);
+		}
+	}
+
+	for (idx = 0; idx < total_bfee_num; idx++) {
+		if (troughput[idx] <= 10)
+			soundingdecision = soundingdecision & ~(1 << idx);
+	}
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] soundingdecision = 0x%x\n", __func__, soundingdecision);
+
+	return soundingdecision;
+
+}
+
+/*this function is only used for BFer*/
+u8
+phydm_get_mu_bfee_snding_decision(
+	void		*dm_void,
+	u16	throughput
+)
+{
+	u8	snding_score = 0;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	/*throughput unit is Mbps*/
+	if (throughput >= 500)
+		snding_score = 100;
+	else if (throughput >= 450)
+		snding_score = 90;
+	else if (throughput >= 400)
+		snding_score = 80;
+	else if (throughput >= 350)
+		snding_score = 70;
+	else if (throughput >= 300)
+		snding_score = 60;
+	else if (throughput >= 250)
+		snding_score = 50;
+	else if (throughput >= 200)
+		snding_score = 40;
+	else if (throughput >= 150)
+		snding_score = 30;
+	else if (throughput >= 100)
+		snding_score = 20;
+	else if (throughput >= 50)
+		snding_score = 10;
+	else
+		snding_score = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] snding_score = 0x%x\n", __func__, snding_score);
+
+	return snding_score;
+
+}
+
+
+#endif
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+u8
+beamforming_get_htndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 nr_index = 0;
+	u8 ndp_tx_rate;
+	/*Find nr*/
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), comp_steering_num_of_bfer);
+	else
+#endif
+		nr_index = tx_bf_nr(1, comp_steering_num_of_bfer);
+
+	switch (nr_index) {
+	case 1:
+		ndp_tx_rate = ODM_MGN_MCS8;
+		break;
+
+	case 2:
+		ndp_tx_rate = ODM_MGN_MCS16;
+		break;
+
+	case 3:
+		ndp_tx_rate = ODM_MGN_MCS24;
+		break;
+
+	default:
+		ndp_tx_rate = ODM_MGN_MCS8;
+		break;
+	}
+
+	return ndp_tx_rate;
+
+}
+
+u8
+beamforming_get_vht_ndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 nr_index = 0;
+	u8 ndp_tx_rate;
+	/*Find nr*/
+#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8814A)
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), comp_steering_num_of_bfer);
+	else
+#endif
+		nr_index = tx_bf_nr(1, comp_steering_num_of_bfer);
+
+	switch (nr_index) {
+	case 1:
+		ndp_tx_rate = ODM_MGN_VHT2SS_MCS0;
+		break;
+
+	case 2:
+		ndp_tx_rate = ODM_MGN_VHT3SS_MCS0;
+		break;
+
+	case 3:
+		ndp_tx_rate = ODM_MGN_VHT4SS_MCS0;
+		break;
+
+	default:
+		ndp_tx_rate = ODM_MGN_VHT2SS_MCS0;
+		break;
+	}
+
+	return ndp_tx_rate;
+
+}
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/phydm_hal_txbf_api.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/phydm_hal_txbf_api.h
new file mode 100644
index 000000000000..b04dc2818d9c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/phydm/txbf/phydm_hal_txbf_api.h
@@ -0,0 +1,76 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#ifndef	__PHYDM_HAL_TXBF_API_H__
+#define __PHYDM_HAL_TXBF_API_H__
+
+#if (defined(CONFIG_BB_TXBF_API))
+
+#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#define tx_bf_nr(a, b) ((a > b) ? (b) : (a))
+
+u8
+beamforming_get_htndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+);
+
+u8
+beamforming_get_vht_ndp_tx_rate(
+	void	*dm_void,
+	u8	comp_steering_num_of_bfer
+);
+
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+u8
+phydm_get_beamforming_sounding_info(
+	void		*dm_void,
+	u16	*troughput,
+	u8	total_bfee_num,
+	u8	*tx_rate
+);
+
+u8
+phydm_get_ndpa_rate(
+	void		*dm_void
+);
+
+u8
+phydm_get_mu_bfee_snding_decision(
+	void		*dm_void,
+	u16	throughput
+);
+
+#else
+#define phydm_get_beamforming_sounding_info(dm_void, troughput, total_bfee_num, tx_rate) 0
+#define phydm_get_ndpa_rate(dm_void)
+#define phydm_get_mu_bfee_snding_decision(dm_void, troughput)
+
+#endif
+
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/Hal8188FPwrSeq.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/Hal8188FPwrSeq.c
index 13f210a6fdfe..2e7579cf9118 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/Hal8188FPwrSeq.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/Hal8188FPwrSeq.c
@@ -1,20 +1,19 @@
 /* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) Semiconductor - 2017 Realtek Corporation.
+ *
+ * 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:
-	Hal8188FPwrSeq.c
-
-Abstract:
-	This file includes all kinds of Power Action event for RTL8188F and corresponding hardware configurtions which are released from HW SD.
-
-Major Change History:
-	When                   What
-	-------------------    ---------------
-	2014-08-18             Create.
-
---*/
 
 #include "Hal8188FPwrSeq.h"
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/hal8188f_fw.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/hal8188f_fw.c
new file mode 100644
index 000000000000..3d8009e824f0
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/hal8188f_fw.c
@@ -0,0 +1,7862 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+*
+* Copyright(c) 2012 - 2017 Realtek Corporation.
+*
+* 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.
+*
+******************************************************************************/
+
+#ifdef CONFIG_RTL8188F
+
+#include "drv_types.h"
+
+#ifdef LOAD_FW_HEADER_FROM_DRIVER
+
+#if (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))
+
+u8 array_mp_8188f_fw_ap[] = {
+0xF1, 0x88, 0x20, 0x00, 0x0E, 0x00, 0x00, 0x00,
+0x06, 0x07, 0x17, 0x19, 0xBE, 0x44, 0x02, 0x00,
+0x01, 0x68, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x02, 0x87, 0x2E, 0x02, 0xAB, 0x4B, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0x9B, 0x0B, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xAF, 0xA5, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xAB, 0x4C, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xAB, 0x9C, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xAF, 0xA4, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x02, 0x87, 0xD3, 0x02, 0x89, 0x04, 0x02, 0x80,
+0x86, 0x02, 0x80, 0x89, 0x02, 0x80, 0x8C, 0x02,
+0x8C, 0xD7, 0x02, 0x9D, 0xAC, 0x02, 0x80, 0x95,
+0x02, 0x80, 0x98, 0x02, 0x80, 0x9B, 0x02, 0x80,
+0x9E, 0x02, 0x80, 0xA1, 0x02, 0x80, 0xA4, 0x02,
+0x80, 0xA7, 0x02, 0x80, 0xAA, 0x02, 0x80, 0xAD,
+0x02, 0x80, 0xB0, 0x02, 0x89, 0xEB, 0x02, 0x80,
+0xB6, 0x02, 0x80, 0xB9, 0x02, 0x80, 0xBC, 0x02,
+0x80, 0xBF, 0x02, 0x80, 0xC2, 0x02, 0x80, 0xC5,
+0x02, 0x80, 0xC8, 0x02, 0x80, 0xCB, 0x02, 0x80,
+0xCE, 0x02, 0x80, 0xD1, 0x02, 0x80, 0xD4, 0x02,
+0x80, 0xD7, 0x00, 0x00, 0x00, 0x02, 0x80, 0xDD,
+0x02, 0x80, 0xE0, 0x02, 0x80, 0xE3, 0x02, 0x80,
+0xE6, 0x02, 0xC2, 0xC5, 0x02, 0x80, 0xEC, 0x02,
+0x80, 0xEF, 0x02, 0x80, 0xF2, 0x02, 0x80, 0xF5,
+0x02, 0x80, 0xF8, 0x02, 0x80, 0xFB, 0x02, 0x80,
+0xFE, 0x02, 0x81, 0x01, 0x02, 0x81, 0x04, 0x02,
+0x81, 0x07, 0x02, 0x81, 0x0A, 0x02, 0x81, 0x0D,
+0x02, 0x81, 0x10, 0x02, 0x81, 0x13, 0x02, 0x81,
+0x16, 0x02, 0x81, 0x19, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x02, 0x95, 0xFE, 0x02,
+0xAF, 0xF2, 0x02, 0x90, 0xF1, 0x02, 0x90, 0xE4,
+0x02, 0x81, 0x40, 0x02, 0x8E, 0x39, 0x02, 0xBF,
+0x2C, 0x02, 0x81, 0x49, 0x02, 0x81, 0x4C, 0x02,
+0x81, 0x4F, 0x02, 0x81, 0x52, 0x02, 0x81, 0x55,
+0x02, 0x81, 0x58, 0x02, 0x81, 0x5B, 0x02, 0x91,
+0x93, 0x02, 0x81, 0x61, 0x02, 0x81, 0x64, 0x02,
+0xBF, 0xC8, 0x02, 0xAF, 0x2E, 0x02, 0xC2, 0x41,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x15, 0xF0, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0x15,
+0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x05, 0xF0,
+0xFF, 0x0F, 0x00, 0x00, 0x00, 0x05, 0xF0, 0x0F,
+0x00, 0x00, 0x00, 0x00, 0x10, 0xF0, 0xFF, 0x0F,
+0x00, 0x00, 0x00, 0x10, 0xF0, 0x0F, 0x00, 0x00,
+0x00, 0x00, 0xF5, 0x0F, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x0D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0A,
+0x08, 0x03, 0x03, 0x00, 0x04, 0x09, 0x07, 0x03,
+0x03, 0x00, 0x04, 0x08, 0x06, 0x03, 0x02, 0x00,
+0x04, 0x08, 0x05, 0x03, 0x01, 0x00, 0x04, 0x0D,
+0x0A, 0x07, 0x05, 0x00, 0x08, 0x0C, 0x0A, 0x07,
+0x04, 0x00, 0x08, 0x0B, 0x0A, 0x06, 0x05, 0x00,
+0x08, 0x0B, 0x0A, 0x05, 0x03, 0x00, 0x08, 0x0B,
+0x0A, 0x03, 0x02, 0x00, 0x08, 0x14, 0x12, 0x0C,
+0x04, 0x00, 0x10, 0x14, 0x12, 0x09, 0x04, 0x00,
+0x10, 0x24, 0x22, 0x1C, 0x12, 0x00, 0x20, 0x24,
+0x22, 0x18, 0x0C, 0x00, 0x20, 0x24, 0x22, 0x14,
+0x06, 0x00, 0x20, 0x24, 0x22, 0x0F, 0x04, 0x00,
+0x20, 0x24, 0x21, 0x0A, 0x04, 0x00, 0x20, 0x23,
+0x21, 0x0C, 0x04, 0x00, 0x20, 0x23, 0x1F, 0x0A,
+0x04, 0x00, 0x20, 0x22, 0x1F, 0x0F, 0x04, 0x00,
+0x20, 0x21, 0x1F, 0x16, 0x0C, 0x00, 0x20, 0x31,
+0x2F, 0x20, 0x14, 0x00, 0x30, 0x31, 0x2F, 0x18,
+0x10, 0x00, 0x30, 0x31, 0x2C, 0x18, 0x0C, 0x00,
+0x30, 0x31, 0x2A, 0x14, 0x0C, 0x00, 0x30, 0x31,
+0x28, 0x14, 0x00, 0x00, 0x30, 0x31, 0x24, 0x14,
+0x00, 0x00, 0x30, 0x31, 0x1E, 0x14, 0x00, 0x00,
+0x30, 0x02, 0x02, 0x03, 0x04, 0x04, 0x08, 0x09,
+0x09, 0x0C, 0x0E, 0x10, 0x12, 0x02, 0x09, 0x0B,
+0x0E, 0x0D, 0x0F, 0x10, 0x12, 0x00, 0x04, 0x00,
+0x04, 0x00, 0x08, 0x00, 0x10, 0x00, 0x23, 0x00,
+0x2D, 0x00, 0x50, 0x00, 0x91, 0x00, 0xC3, 0x01,
+0x27, 0x01, 0x31, 0x01, 0x5E, 0x00, 0x8C, 0x00,
+0xC8, 0x00, 0xDC, 0x01, 0x5E, 0x01, 0x68, 0x01,
+0x9A, 0x01, 0xCC, 0x01, 0xEA, 0x02, 0x02, 0x04,
+0x08, 0x0C, 0x12, 0x18, 0x24, 0x30, 0x48, 0x60,
+0x6C, 0x14, 0x28, 0x32, 0x50, 0x78, 0xA0, 0xC8,
+0xE6, 0x01, 0x01, 0x01, 0x02, 0x01, 0x01, 0x02,
+0x02, 0x03, 0x03, 0x04, 0x04, 0x02, 0x04, 0x06,
+0x07, 0x07, 0x08, 0x08, 0x08, 0x01, 0x01, 0x01,
+0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
+0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x02,
+0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
+0x02, 0x03, 0x03, 0x04, 0x05, 0x01, 0x02, 0x03,
+0x04, 0x05, 0x06, 0x07, 0x08, 0x03, 0x03, 0x03,
+0x02, 0x03, 0x03, 0x03, 0x03, 0x03, 0x02, 0x02,
+0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02,
+0x02, 0x19, 0x06, 0x04, 0x02, 0x00, 0x18, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xC2, 0xAF, 0x80, 0xFE, 0x32, 0x12, 0x84, 0x04,
+0x85, 0xD0, 0x0B, 0x75, 0xD0, 0x08, 0xAA, 0xE0,
+0xC2, 0x8C, 0xE5, 0x8A, 0x24, 0x67, 0xF5, 0x8A,
+0xE5, 0x8C, 0x34, 0x79, 0xF5, 0x8C, 0xD2, 0x8C,
+0xEC, 0x24, 0x87, 0xF8, 0xE6, 0xBC, 0x02, 0x02,
+0x74, 0xFF, 0xC3, 0x95, 0x81, 0xB4, 0x40, 0x00,
+0x40, 0xCE, 0x79, 0x03, 0x78, 0x80, 0x16, 0xE6,
+0x08, 0x70, 0x0B, 0xC2, 0xAF, 0xE6, 0x30, 0xE1,
+0x03, 0x44, 0x18, 0xF6, 0xD2, 0xAF, 0x08, 0xD9,
+0xED, 0xEA, 0x8B, 0xD0, 0x22, 0xE5, 0x0C, 0xFF,
+0x23, 0x24, 0x81, 0xF8, 0x0F, 0x08, 0x08, 0xBF,
+0x03, 0x04, 0x7F, 0x00, 0x78, 0x81, 0xE6, 0x30,
+0xE4, 0xF2, 0x00, 0xE5, 0x0C, 0xC3, 0x9F, 0x50,
+0x20, 0x05, 0x0C, 0x74, 0x86, 0x25, 0x0C, 0xF8,
+0xE6, 0xFD, 0xA6, 0x81, 0x08, 0xE6, 0xAE, 0x0C,
+0xBE, 0x02, 0x02, 0x74, 0xFF, 0xCD, 0xF8, 0xE8,
+0x6D, 0x60, 0xE0, 0x08, 0xE6, 0xC0, 0xE0, 0x80,
+0xF6, 0xE5, 0x0C, 0xD3, 0x9F, 0x40, 0x27, 0xE5,
+0x0C, 0x24, 0x87, 0xF8, 0xE6, 0xAE, 0x0C, 0xBE,
+0x02, 0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xCD,
+0xF8, 0xE5, 0x81, 0x6D, 0x60, 0x06, 0xD0, 0xE0,
+0xF6, 0x18, 0x80, 0xF5, 0xE5, 0x0C, 0x24, 0x86,
+0xC8, 0xF6, 0x15, 0x0C, 0x80, 0xD3, 0xE5, 0x0C,
+0x23, 0x24, 0x81, 0xF8, 0x7F, 0x04, 0xC2, 0xAF,
+0xE6, 0x30, 0xE0, 0x03, 0x10, 0xE2, 0x0C, 0x7F,
+0x00, 0x30, 0xE1, 0x07, 0x30, 0xE3, 0x04, 0x7F,
+0x08, 0x54, 0xF4, 0x54, 0x7C, 0xC6, 0xD2, 0xAF,
+0x54, 0x80, 0x42, 0x07, 0x22, 0x78, 0x86, 0xA6,
+0x81, 0x74, 0x02, 0x60, 0x06, 0xFF, 0x08, 0x76,
+0xFF, 0xDF, 0xFB, 0x7F, 0x03, 0xE4, 0x78, 0x80,
+0xF6, 0x08, 0xF6, 0x08, 0xDF, 0xFA, 0x78, 0x81,
+0x76, 0x30, 0x90, 0x87, 0xC8, 0x74, 0x01, 0x93,
+0xC0, 0xE0, 0xE4, 0x93, 0xC0, 0xE0, 0x43, 0x89,
+0x01, 0x75, 0x8A, 0x60, 0x75, 0x8C, 0x79, 0xD2,
+0x8C, 0xD2, 0xAF, 0x22, 0x02, 0xEF, 0xD3, 0x94,
+0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0x74, 0x81,
+0x2F, 0x2F, 0xF8, 0xE6, 0x20, 0xE5, 0xF4, 0xC2,
+0xAF, 0xE6, 0x44, 0x30, 0xF6, 0xD2, 0xAF, 0xAE,
+0x0C, 0xEE, 0xC3, 0x9F, 0x50, 0x21, 0x0E, 0x74,
+0x86, 0x2E, 0xF8, 0xE6, 0xF9, 0x08, 0xE6, 0x18,
+0xBE, 0x02, 0x02, 0x74, 0xFF, 0xFD, 0xED, 0x69,
+0x60, 0x09, 0x09, 0xE7, 0x19, 0x19, 0xF7, 0x09,
+0x09, 0x80, 0xF3, 0x16, 0x16, 0x80, 0xDA, 0xEE,
+0xD3, 0x9F, 0x40, 0x04, 0x05, 0x81, 0x05, 0x81,
+0xEE, 0xD3, 0x9F, 0x40, 0x22, 0x74, 0x86, 0x2E,
+0xF8, 0x08, 0xE6, 0xF9, 0xEE, 0xB5, 0x0C, 0x02,
+0xA9, 0x81, 0x18, 0x06, 0x06, 0xE6, 0xFD, 0xED,
+0x69, 0x60, 0x09, 0x19, 0x19, 0xE7, 0x09, 0x09,
+0xF7, 0x19, 0x80, 0xF3, 0x1E, 0x80, 0xD9, 0xEF,
+0x24, 0x86, 0xF8, 0xE6, 0x04, 0xF8, 0xEF, 0x2F,
+0x04, 0x90, 0x87, 0xC8, 0x93, 0xF6, 0x08, 0xEF,
+0x2F, 0x93, 0xF6, 0x7F, 0x00, 0x22, 0xEF, 0xD3,
+0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0xEF,
+0x23, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE5, 0xF4,
+0xC2, 0xAF, 0xE6, 0x54, 0x8C, 0xF6, 0xD2, 0xAF,
+0xE5, 0x0C, 0xB5, 0x07, 0x0A, 0x74, 0x86, 0x2F,
+0xF8, 0xE6, 0xF5, 0x81, 0x02, 0x84, 0x4D, 0x50,
+0x2E, 0x74, 0x87, 0x2F, 0xF8, 0xE6, 0xBF, 0x02,
+0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xF9, 0x74,
+0x86, 0x2F, 0xF8, 0xFB, 0xE6, 0xFC, 0xE9, 0x6C,
+0x60, 0x08, 0xA8, 0x05, 0xE7, 0xF6, 0x1D, 0x19,
+0x80, 0xF4, 0xA8, 0x03, 0xA6, 0x05, 0x1F, 0xE5,
+0x0C, 0xB5, 0x07, 0xE3, 0x7F, 0x00, 0x22, 0x74,
+0x87, 0x2F, 0xF8, 0xE6, 0xFD, 0x18, 0x86, 0x01,
+0x0F, 0x74, 0x86, 0x2F, 0xF8, 0xA6, 0x01, 0x08,
+0x86, 0x04, 0xE5, 0x0C, 0xB5, 0x07, 0x02, 0xAC,
+0x81, 0xED, 0x6C, 0x60, 0x08, 0x0D, 0x09, 0xA8,
+0x05, 0xE6, 0xF7, 0x80, 0xF4, 0xE5, 0x0C, 0xB5,
+0x07, 0xDE, 0x89, 0x81, 0x7F, 0x00, 0x22, 0xEF,
+0xD3, 0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22,
+0xEF, 0x23, 0x24, 0x81, 0xF8, 0xC2, 0xAF, 0xE6,
+0x30, 0xE5, 0x05, 0x30, 0xE0, 0x02, 0xD2, 0xE4,
+0xD2, 0xE2, 0xC6, 0xD2, 0xAF, 0x7F, 0x00, 0x30,
+0xE2, 0x01, 0x0F, 0x02, 0x84, 0x4C, 0x8F, 0xF0,
+0xE4, 0xFF, 0xFE, 0xE5, 0x0C, 0x23, 0x24, 0x80,
+0xF8, 0xC2, 0xA9, 0x30, 0xF7, 0x0D, 0x7F, 0x08,
+0xE6, 0x60, 0x0B, 0x2D, 0xF6, 0x60, 0x30, 0x50,
+0x2E, 0x80, 0x07, 0x30, 0xF1, 0x06, 0xED, 0xF6,
+0x60, 0x25, 0x7E, 0x02, 0x08, 0x30, 0xF0, 0x10,
+0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x23, 0x0E, 0x30,
+0xE2, 0x0C, 0xD2, 0xAF, 0x7F, 0x04, 0x80, 0x12,
+0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x13, 0x54, 0xEC,
+0x4E, 0xF6, 0xD2, 0xAF, 0x02, 0x84, 0x4D, 0x7F,
+0x08, 0x08, 0xEF, 0x44, 0x83, 0xF4, 0xC2, 0xAF,
+0x56, 0xC6, 0xD2, 0xAF, 0x54, 0x80, 0x4F, 0xFF,
+0x22, 0xEF, 0x2B, 0xFF, 0xEE, 0x3A, 0xFE, 0xED,
+0x39, 0xFD, 0xEC, 0x38, 0xFC, 0x22, 0xC3, 0xEF,
+0x9B, 0xFF, 0xEE, 0x9A, 0xFE, 0xED, 0x99, 0xFD,
+0xEC, 0x98, 0xFC, 0x22, 0xEF, 0x5B, 0xFF, 0xEE,
+0x5A, 0xFE, 0xED, 0x59, 0xFD, 0xEC, 0x58, 0xFC,
+0x22, 0xEF, 0x4B, 0xFF, 0xEE, 0x4A, 0xFE, 0xED,
+0x49, 0xFD, 0xEC, 0x48, 0xFC, 0x22, 0xE0, 0xFC,
+0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x22, 0xE0, 0xF8, 0xA3, 0xE0, 0xF9, 0xA3,
+0xE0, 0xFA, 0xA3, 0xE0, 0xFB, 0x22, 0xE0, 0xFB,
+0xA3, 0xE0, 0xFA, 0xA3, 0xE0, 0xF9, 0x22, 0xEB,
+0xF0, 0xA3, 0xEA, 0xF0, 0xA3, 0xE9, 0xF0, 0x22,
+0xD0, 0x83, 0xD0, 0x82, 0xF8, 0xE4, 0x93, 0x70,
+0x12, 0x74, 0x01, 0x93, 0x70, 0x0D, 0xA3, 0xA3,
+0x93, 0xF8, 0x74, 0x01, 0x93, 0xF5, 0x82, 0x88,
+0x83, 0xE4, 0x73, 0x74, 0x02, 0x93, 0x68, 0x60,
+0xEF, 0xA3, 0xA3, 0xA3, 0x80, 0xDF, 0x02, 0x87,
+0x6C, 0x02, 0x84, 0xDD, 0xE4, 0x93, 0xA3, 0xF8,
+0xE4, 0x93, 0xA3, 0x40, 0x03, 0xF6, 0x80, 0x01,
+0xF2, 0x08, 0xDF, 0xF4, 0x80, 0x29, 0xE4, 0x93,
+0xA3, 0xF8, 0x54, 0x07, 0x24, 0x0C, 0xC8, 0xC3,
+0x33, 0xC4, 0x54, 0x0F, 0x44, 0x20, 0xC8, 0x83,
+0x40, 0x04, 0xF4, 0x56, 0x80, 0x01, 0x46, 0xF6,
+0xDF, 0xE4, 0x80, 0x0B, 0x01, 0x02, 0x04, 0x08,
+0x10, 0x20, 0x40, 0x80, 0x90, 0x87, 0xB1, 0xE4,
+0x7E, 0x01, 0x93, 0x60, 0xBC, 0xA3, 0xFF, 0x54,
+0x3F, 0x30, 0xE5, 0x09, 0x54, 0x1F, 0xFE, 0xE4,
+0x93, 0xA3, 0x60, 0x01, 0x0E, 0xCF, 0x54, 0xC0,
+0x25, 0xE0, 0x60, 0xA8, 0x40, 0xB8, 0xE4, 0x93,
+0xA3, 0xFA, 0xE4, 0x93, 0xA3, 0xF8, 0xE4, 0x93,
+0xA3, 0xC8, 0xC5, 0x82, 0xC8, 0xCA, 0xC5, 0x83,
+0xCA, 0xF0, 0xA3, 0xC8, 0xC5, 0x82, 0xC8, 0xCA,
+0xC5, 0x83, 0xCA, 0xDF, 0xE9, 0xDE, 0xE7, 0x80,
+0xBE, 0x41, 0x95, 0x26, 0x00, 0x44, 0x95, 0x08,
+0x41, 0x4E, 0x59, 0x00, 0x44, 0x95, 0x04, 0x61,
+0x6E, 0x79, 0x00, 0x41, 0x95, 0x28, 0x00, 0x00,
+0xA3, 0x39, 0xA8, 0x6D, 0xAA, 0xE6, 0x12, 0x5E,
+0x10, 0x7F, 0x04, 0x90, 0x95, 0x24, 0xEF, 0xF0,
+0x7F, 0x02, 0xD1, 0x27, 0x90, 0x84, 0xC1, 0xE0,
+0xFF, 0x90, 0x95, 0x24, 0xE0, 0xFE, 0xEF, 0x4E,
+0x90, 0x84, 0xC1, 0xF0, 0x22, 0x90, 0x02, 0x09,
+0xE0, 0xF5, 0x5B, 0x12, 0x02, 0xF6, 0x25, 0x5B,
+0x90, 0x84, 0xC6, 0xF0, 0x12, 0x8F, 0x12, 0x25,
+0x5B, 0x90, 0x84, 0xC7, 0x91, 0xB4, 0x25, 0x5B,
+0x90, 0x84, 0xC8, 0xF0, 0x90, 0x00, 0x03, 0x12,
+0x03, 0x0F, 0x25, 0x5B, 0x90, 0x84, 0xC9, 0xF0,
+0x90, 0x00, 0x04, 0x12, 0x03, 0x0F, 0x25, 0x5B,
+0x90, 0x84, 0xCA, 0xF0, 0x90, 0x00, 0x05, 0x12,
+0x03, 0x0F, 0x25, 0x5B, 0x90, 0x84, 0xCB, 0x11,
+0x38, 0x25, 0x5B, 0x90, 0x84, 0xCC, 0xF0, 0x22,
+0xF0, 0x90, 0x00, 0x06, 0x02, 0x03, 0x0F, 0xF1,
+0xE4, 0xFF, 0x54, 0x7F, 0x90, 0x85, 0xC5, 0xF0,
+0xEF, 0x91, 0xBF, 0xA3, 0xF0, 0xF1, 0x12, 0xFD,
+0x54, 0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x85,
+0xC3, 0xE0, 0x54, 0xF0, 0x4F, 0xF0, 0x90, 0x00,
+0x03, 0x12, 0x03, 0x0F, 0xFC, 0x54, 0x01, 0x25,
+0xE0, 0xFF, 0x90, 0x85, 0xC1, 0xE0, 0x54, 0xFD,
+0x4F, 0xF0, 0xEC, 0x54, 0x04, 0xFF, 0x90, 0x92,
+0x41, 0xE0, 0x54, 0xFB, 0x4F, 0xF0, 0xED, 0x54,
+0x0F, 0xC4, 0x54, 0xF0, 0xFF, 0xF1, 0xDD, 0x91,
+0xB3, 0x90, 0x85, 0xC4, 0x11, 0x38, 0x30, 0xE0,
+0x4D, 0xC3, 0x13, 0x54, 0x07, 0xFF, 0xC3, 0x94,
+0x04, 0x90, 0x85, 0xD8, 0x50, 0x04, 0xEF, 0xF0,
+0x80, 0x25, 0x74, 0x03, 0xF0, 0x31, 0xE5, 0xE9,
+0x24, 0x06, 0xF1, 0xD5, 0xFF, 0x74, 0x03, 0x24,
+0xFD, 0xFE, 0xEF, 0xC4, 0x54, 0x0F, 0xFD, 0xEF,
+0x54, 0x0F, 0xFF, 0xED, 0x2E, 0x54, 0x0F, 0xFE,
+0xC4, 0x54, 0xF0, 0x4F, 0x12, 0x03, 0x3C, 0x31,
+0xE5, 0x11, 0x39, 0xC4, 0x54, 0x0F, 0xFF, 0xC3,
+0x94, 0x04, 0x90, 0x85, 0xCD, 0x50, 0x05, 0x74,
+0x04, 0xF0, 0x80, 0x02, 0xEF, 0xF0, 0x31, 0xE5,
+0x90, 0x00, 0x04, 0x12, 0x03, 0x0F, 0xFD, 0x7F,
+0x02, 0x12, 0x57, 0x82, 0x31, 0xE5, 0x12, 0x71,
+0xCB, 0x12, 0xAD, 0xB3, 0xF0, 0x90, 0x85, 0xC5,
+0xF1, 0xED, 0x90, 0x01, 0xBB, 0xF1, 0xDC, 0x90,
+0x01, 0xBE, 0xF0, 0x22, 0x90, 0x93, 0x64, 0x12,
+0x86, 0xFF, 0x90, 0x93, 0x63, 0xEF, 0xF0, 0x12,
+0x87, 0x08, 0x89, 0x5E, 0x00, 0x89, 0x63, 0x01,
+0x89, 0x68, 0x06, 0x89, 0x79, 0x08, 0x89, 0x7D,
+0x09, 0x89, 0x82, 0x0A, 0x89, 0x87, 0x12, 0x89,
+0x8C, 0x13, 0x89, 0x90, 0x14, 0x89, 0x95, 0x20,
+0x89, 0x99, 0x25, 0x89, 0x9E, 0x26, 0x89, 0xA3,
+0x40, 0x89, 0xA7, 0x42, 0x89, 0xAC, 0x43, 0x89,
+0xB1, 0x44, 0x89, 0xD8, 0x47, 0x89, 0xB6, 0x49,
+0x89, 0xBB, 0xC2, 0x89, 0xC0, 0xC3, 0x89, 0xC5,
+0xC4, 0x89, 0x6D, 0xC6, 0x89, 0x6D, 0xC7, 0x89,
+0x6D, 0xC8, 0x00, 0x00, 0x89, 0xC9, 0x31, 0xD9,
+0x02, 0x87, 0xED, 0x31, 0xD9, 0x02, 0x90, 0x07,
+0x31, 0xD9, 0x02, 0x98, 0xE8, 0x90, 0x93, 0x63,
+0xE0, 0xFF, 0xA3, 0x12, 0x86, 0xF6, 0x02, 0x99,
+0x7F, 0x31, 0xD9, 0xE1, 0x18, 0x31, 0xD9, 0x02,
+0x97, 0xF7, 0x31, 0xD9, 0x02, 0x98, 0x06, 0x31,
+0xD9, 0x02, 0x98, 0x1E, 0x31, 0xD9, 0xC1, 0x9A,
+0x31, 0xD9, 0x02, 0x9A, 0xB0, 0x31, 0xD9, 0x01,
+0x3F, 0x31, 0xD9, 0x02, 0x9A, 0xBF, 0x31, 0xD9,
+0x02, 0x96, 0x3F, 0x31, 0xD9, 0x80, 0x44, 0x31,
+0xD9, 0x02, 0x4E, 0x29, 0x31, 0xD9, 0x02, 0x28,
+0xE6, 0x31, 0xD9, 0x02, 0x62, 0xFC, 0x31, 0xD9,
+0x02, 0xB0, 0x41, 0x31, 0xD9, 0x02, 0x9A, 0xC7,
+0x31, 0xD9, 0x02, 0x9F, 0xEF, 0x31, 0xD9, 0xE1,
+0xC2, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x01, 0xF0,
+0x90, 0x93, 0x63, 0xE0, 0x90, 0x01, 0xC2, 0xF0,
+0x22, 0x90, 0x93, 0x64, 0x02, 0x86, 0xF6, 0x90,
+0x93, 0x67, 0x12, 0x86, 0xFF, 0x90, 0x93, 0x67,
+0x02, 0x86, 0xF6, 0x31, 0xDF, 0x12, 0x02, 0xF6,
+0x54, 0x7F, 0xFD, 0xF1, 0x12, 0xFE, 0x54, 0x1F,
+0x90, 0x93, 0x6B, 0x91, 0xBB, 0x90, 0x93, 0x6A,
+0x91, 0xB4, 0xFE, 0x54, 0x03, 0xFC, 0xEE, 0x54,
+0x30, 0xC4, 0x54, 0x0F, 0x90, 0x93, 0x6D, 0x91,
+0xB4, 0xFE, 0x54, 0x40, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x90, 0x93, 0x6C, 0x91, 0xBB, 0xFF, 0x91,
+0xB5, 0xFB, 0x54, 0x08, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x90, 0x93, 0x6F, 0xF0, 0xFA, 0xEB, 0x54,
+0x04, 0x13, 0x13, 0x54, 0x3F, 0xA3, 0xF0, 0xEF,
+0x54, 0x01, 0xC4, 0x33, 0x33, 0x33, 0x54, 0x80,
+0x71, 0x40, 0x54, 0x7F, 0x4F, 0xF0, 0x90, 0x93,
+0x6C, 0xE0, 0x54, 0x01, 0xC4, 0x33, 0x33, 0x54,
+0xC0, 0x71, 0x40, 0x54, 0xBF, 0x4F, 0xF0, 0xEA,
+0x70, 0x0D, 0xEC, 0x54, 0x03, 0x25, 0xE0, 0x25,
+0xE0, 0x71, 0x40, 0x54, 0xF3, 0x4F, 0xF0, 0x90,
+0x93, 0x6B, 0xE0, 0x54, 0x1F, 0x91, 0xC6, 0x54,
+0xE0, 0x4F, 0xF0, 0xEC, 0x54, 0x03, 0x71, 0x40,
+0x54, 0xFC, 0x4F, 0xF0, 0x90, 0x93, 0x6A, 0xE0,
+0x54, 0x01, 0xC4, 0x33, 0x54, 0xE0, 0x91, 0xC6,
+0x54, 0xDF, 0x4F, 0xF0, 0x90, 0x93, 0x6D, 0xE0,
+0x54, 0x03, 0xC4, 0x54, 0xF0, 0x71, 0x40, 0x54,
+0xCF, 0x4F, 0x12, 0xC4, 0xAA, 0xF5, 0x83, 0xE0,
+0x54, 0xFB, 0x12, 0xC4, 0xAA, 0xF5, 0x83, 0xC0,
+0x83, 0xC0, 0x82, 0xE0, 0xFF, 0x90, 0x93, 0x70,
+0xE0, 0x12, 0xA7, 0xE4, 0xD0, 0x82, 0xD0, 0x83,
+0xF0, 0x90, 0x92, 0x3B, 0xE0, 0x60, 0x35, 0x31,
+0xE5, 0xE9, 0x24, 0x03, 0xF1, 0xD5, 0x54, 0x1F,
+0x12, 0x03, 0x3C, 0x90, 0x93, 0x6E, 0x74, 0x01,
+0xF0, 0x90, 0x93, 0x6E, 0xE0, 0xFF, 0xC3, 0x94,
+0x04, 0x50, 0x19, 0xEF, 0x24, 0x03, 0xFF, 0xE4,
+0x33, 0xFE, 0x31, 0xE5, 0x8F, 0x82, 0x8E, 0x83,
+0xE4, 0x12, 0x03, 0x4E, 0x90, 0x93, 0x6E, 0xE0,
+0x04, 0xF0, 0x80, 0xDD, 0x90, 0x92, 0x39, 0xE0,
+0x54, 0x07, 0xFF, 0xBF, 0x05, 0x0A, 0xEC, 0xB4,
+0x01, 0x06, 0x90, 0x92, 0x3E, 0x74, 0x01, 0xF0,
+0xE4, 0x90, 0x93, 0x6E, 0xF0, 0x90, 0x93, 0x6E,
+0xE0, 0xFC, 0x24, 0x03, 0xFF, 0xE4, 0x33, 0xFE,
+0x31, 0xE5, 0x8F, 0x82, 0x8E, 0x83, 0x12, 0x03,
+0x0F, 0xFF, 0xED, 0xF1, 0xF9, 0xE5, 0x82, 0x2C,
+0xF5, 0x82, 0xE4, 0x35, 0x83, 0xF5, 0x83, 0xEF,
+0xF0, 0x90, 0x93, 0x6E, 0xE0, 0x04, 0xF0, 0xE0,
+0xB4, 0x04, 0xD2, 0xAF, 0x05, 0x02, 0x17, 0x8E,
+0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90, 0x89, 0x3F,
+0x12, 0x05, 0x28, 0xE0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x7F, 0x8F, 0x12, 0x7B,
+0x51, 0xEF, 0x20, 0xE6, 0x02, 0x81, 0x7A, 0x90,
+0x00, 0x8C, 0xE0, 0x90, 0x95, 0x19, 0xF0, 0x7F,
+0x8D, 0x12, 0x7B, 0x51, 0x90, 0x95, 0x1A, 0xEF,
+0xF0, 0x90, 0x00, 0x8E, 0xE0, 0x90, 0x95, 0x1B,
+0xF0, 0x90, 0x95, 0x1A, 0xE0, 0x24, 0xFC, 0x60,
+0x10, 0x24, 0x03, 0x60, 0x02, 0x81, 0x6E, 0x90,
+0x95, 0x19, 0xE0, 0xFF, 0x12, 0xB8, 0x01, 0x81,
+0x6E, 0x90, 0x95, 0x19, 0xE0, 0x24, 0xDC, 0xF5,
+0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83, 0xE0, 0xFB,
+0xE4, 0xFD, 0xFF, 0x91, 0xAC, 0x75, 0xF0, 0x12,
+0x71, 0x45, 0x13, 0x13, 0x54, 0x03, 0xFB, 0x0D,
+0xE4, 0xFF, 0x91, 0xAC, 0x75, 0xF0, 0x12, 0x71,
+0x45, 0x91, 0xBF, 0xFB, 0x0D, 0xE4, 0xFF, 0x91,
+0xAC, 0x75, 0xF0, 0x12, 0x71, 0x45, 0xC4, 0x54,
+0x03, 0xFB, 0x0D, 0xE4, 0xFF, 0x91, 0xAC, 0x75,
+0xF0, 0x12, 0x12, 0xB6, 0xAE, 0xFB, 0xE4, 0xFD,
+0x0F, 0x91, 0xAC, 0x75, 0xF0, 0x12, 0x90, 0x89,
+0x3D, 0x12, 0x05, 0x28, 0x91, 0xA9, 0x75, 0xF0,
+0x12, 0x91, 0xCB, 0xC4, 0x13, 0x54, 0x01, 0xFB,
+0x0D, 0x7F, 0x01, 0x91, 0xAC, 0x75, 0xF0, 0x12,
+0x91, 0xCB, 0x54, 0x1F, 0x91, 0xAA, 0xF1, 0xF9,
+0xE0, 0xFB, 0xE4, 0xFD, 0x0F, 0x91, 0xAC, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x01, 0xF5, 0x82, 0xE4,
+0x34, 0x82, 0x91, 0xA7, 0x75, 0xF0, 0x08, 0xA4,
+0x24, 0x02, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0x91,
+0xA7, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x03, 0xF5,
+0x82, 0xE4, 0x34, 0x82, 0x91, 0xA7, 0x75, 0xF0,
+0x08, 0xA4, 0x24, 0x04, 0xF5, 0x82, 0xE4, 0x34,
+0x82, 0xF5, 0x83, 0xE0, 0xFB, 0xE4, 0xFD, 0x0F,
+0x91, 0xAC, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x05,
+0xF5, 0x82, 0xE4, 0x34, 0x82, 0x91, 0xA7, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x06, 0xF5, 0x82, 0xE4,
+0x34, 0x82, 0x91, 0xA7, 0x75, 0xF0, 0x08, 0xA4,
+0x24, 0x07, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5,
+0x83, 0xE0, 0xFB, 0x0D, 0x91, 0x7F, 0x7F, 0x8F,
+0x12, 0x7B, 0x51, 0xEF, 0x30, 0xE0, 0x03, 0x12,
+0xB8, 0x57, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF,
+0x70, 0x04, 0x74, 0xF0, 0x80, 0x16, 0xEF, 0xB4,
+0x01, 0x04, 0x74, 0xF4, 0x80, 0x0E, 0xEF, 0xB4,
+0x02, 0x04, 0x74, 0xF8, 0x80, 0x06, 0xEF, 0xB4,
+0x03, 0x0C, 0x74, 0xFC, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0x02, 0xF5, 0x83, 0xEB, 0xF0, 0x22, 0xF5,
+0x83, 0xE0, 0xFB, 0x0D, 0x91, 0x7F, 0x90, 0x95,
+0x19, 0xE0, 0x22, 0x4F, 0xF0, 0x90, 0x00, 0x02,
+0x02, 0x03, 0x0F, 0xF0, 0xEE, 0x54, 0x80, 0xC4,
+0x13, 0x13, 0x13, 0x54, 0x01, 0x22, 0xFF, 0x75,
+0xF0, 0x12, 0xED, 0x90, 0x89, 0x3E, 0x12, 0x05,
+0x28, 0xE0, 0x22, 0xE4, 0xFD, 0x7F, 0x0C, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95,
+0x27, 0xED, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0xFE,
+0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
+0xC1, 0x34, 0xEE, 0x91, 0xBF, 0x30, 0xE0, 0x02,
+0xC1, 0x34, 0x90, 0x85, 0xC8, 0xE0, 0xFE, 0x6F,
+0x70, 0x02, 0xC1, 0x34, 0xEF, 0x70, 0x02, 0xA1,
+0x9C, 0x24, 0xFE, 0x70, 0x02, 0xA1, 0xD9, 0x24,
+0xFE, 0x60, 0x4D, 0x24, 0xFC, 0x70, 0x02, 0xC1,
+0x18, 0x24, 0xFC, 0x60, 0x02, 0xC1, 0x2B, 0xEE,
+0xB4, 0x0E, 0x03, 0x12, 0x74, 0x93, 0x90, 0x85,
+0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79,
+0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03,
+0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
+0x04, 0x0F, 0x90, 0x95, 0x27, 0xE0, 0xFF, 0x60,
+0x05, 0x12, 0x6D, 0x4C, 0x80, 0x03, 0x12, 0x79,
+0x61, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x08, 0x60,
+0x02, 0xC1, 0x2B, 0x12, 0x7A, 0xB9, 0xC1, 0x2B,
+0x90, 0x85, 0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01,
+0x12, 0x79, 0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
+0x06, 0x03, 0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8,
+0xE0, 0xB4, 0x0E, 0x08, 0xD1, 0x39, 0xBF, 0x01,
+0x03, 0x12, 0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0,
+0x64, 0x0C, 0x60, 0x02, 0xC1, 0x2B, 0xD1, 0x39,
+0xEF, 0x64, 0x01, 0x60, 0x02, 0xC1, 0x2B, 0x12,
+0x70, 0x9E, 0xC1, 0x2B, 0x90, 0x85, 0xC8, 0xE0,
+0xB4, 0x0E, 0x08, 0xD1, 0x39, 0xBF, 0x01, 0x03,
+0x12, 0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
+0x06, 0x03, 0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8,
+0xE0, 0xB4, 0x0C, 0x08, 0xD1, 0x39, 0xBF, 0x01,
+0x03, 0x12, 0x70, 0x9E, 0x90, 0x85, 0xC8, 0xE0,
+0x64, 0x04, 0x70, 0x5F, 0x12, 0xBF, 0x2C, 0xEF,
+0x64, 0x01, 0x70, 0x57, 0x12, 0x77, 0xFE, 0x80,
+0x52, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E, 0x08,
+0xD1, 0x39, 0xBF, 0x01, 0x03, 0x12, 0x74, 0x93,
+0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12,
+0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0C,
+0x08, 0xD1, 0x39, 0xBF, 0x01, 0x03, 0x12, 0x70,
+0x9E, 0x90, 0x85, 0xC8, 0xE0, 0x70, 0x05, 0x7F,
+0x01, 0x12, 0x79, 0x80, 0x90, 0x85, 0xC8, 0xE0,
+0xB4, 0x04, 0x18, 0x12, 0x79, 0xF3, 0x80, 0x13,
+0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0C, 0x0C, 0x90,
+0x85, 0xC2, 0x12, 0x9F, 0xD9, 0x30, 0xE0, 0x03,
+0x12, 0x7A, 0x8A, 0x90, 0x85, 0xC8, 0xF1, 0xED,
+0x90, 0x01, 0xBB, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x12, 0x7A, 0x29, 0xEF, 0x64, 0x01, 0x60, 0x05,
+0x75, 0x0E, 0x01, 0x80, 0x3A, 0x90, 0x85, 0xC1,
+0xE0, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0,
+0x05, 0x75, 0x0E, 0x02, 0x80, 0x29, 0x90, 0x85,
+0xC7, 0xE0, 0xD3, 0x94, 0x04, 0x40, 0x05, 0x75,
+0x0E, 0x08, 0x80, 0x1B, 0x90, 0x92, 0x2A, 0xE0,
+0x30, 0xE0, 0x0B, 0xC4, 0x54, 0x0F, 0x30, 0xE0,
+0x05, 0x75, 0x0E, 0x11, 0x80, 0x09, 0x90, 0x01,
+0xB8, 0xE4, 0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90,
+0x01, 0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8,
+0xE5, 0x0E, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x12, 0x02, 0xF6, 0xFF, 0x54, 0x80,
+0xFE, 0x90, 0x89, 0x16, 0xE0, 0x54, 0x7F, 0x4E,
+0xFE, 0xF0, 0xEF, 0x54, 0x40, 0xFF, 0xEE, 0x54,
+0xBF, 0x12, 0xC4, 0xB4, 0x54, 0x20, 0xFD, 0xEF,
+0x54, 0xDF, 0x4D, 0xFF, 0x90, 0x89, 0x16, 0xF0,
+0xEE, 0x54, 0x10, 0xFE, 0xEF, 0x54, 0xEF, 0x4E,
+0xFF, 0xF0, 0x12, 0x02, 0xF6, 0x54, 0x0F, 0xFE,
+0xEF, 0x54, 0xF0, 0x4E, 0x90, 0x89, 0x16, 0xF0,
+0xF1, 0x12, 0xFF, 0x54, 0x7F, 0x90, 0x89, 0x18,
+0xF0, 0xEF, 0x91, 0xBD, 0xFF, 0x90, 0x89, 0x17,
+0xE0, 0x54, 0xFE, 0x91, 0xB3, 0x90, 0x89, 0x19,
+0xF0, 0x90, 0x00, 0x03, 0x12, 0x03, 0x0F, 0x54,
+0x01, 0x25, 0xE0, 0xFF, 0x90, 0x89, 0x17, 0xE0,
+0x54, 0xFD, 0x4F, 0xF0, 0x12, 0xAE, 0x73, 0x20,
+0xE0, 0x02, 0x7D, 0x01, 0x02, 0x54, 0x9F, 0x12,
+0x86, 0xF6, 0x90, 0x00, 0x01, 0x02, 0x03, 0x0F,
+0xF1, 0xE4, 0x30, 0xE0, 0x14, 0x12, 0xB9, 0x15,
+0x90, 0x84, 0xC5, 0xE0, 0x64, 0x01, 0x70, 0x28,
+0x90, 0xFE, 0x10, 0xE0, 0x44, 0x04, 0xF0, 0x80,
+0x1F, 0x90, 0x92, 0x26, 0xE0, 0x60, 0x16, 0x7D,
+0x10, 0xE4, 0xFF, 0x12, 0x7B, 0xBF, 0x90, 0x01,
+0x3C, 0xE0, 0x30, 0xE4, 0x03, 0x74, 0x10, 0xF0,
+0x90, 0x01, 0x63, 0xE4, 0xF0, 0x12, 0xBE, 0xFF,
+0x31, 0xE5, 0xF1, 0x12, 0x90, 0x92, 0x04, 0x91,
+0xB4, 0x90, 0x92, 0x05, 0xF0, 0x90, 0x92, 0x04,
+0xE0, 0x54, 0x01, 0x90, 0x92, 0x12, 0xF0, 0x90,
+0x92, 0x04, 0xE0, 0x54, 0x02, 0x90, 0x92, 0x13,
+0xF0, 0x90, 0x92, 0x04, 0xE0, 0x54, 0x04, 0x90,
+0x92, 0x14, 0xF0, 0x90, 0x92, 0x04, 0xE0, 0x54,
+0x08, 0x90, 0x92, 0x15, 0xF0, 0x90, 0x92, 0x04,
+0xE0, 0x54, 0x10, 0x90, 0x92, 0x16, 0xF0, 0x90,
+0x92, 0x05, 0xE0, 0x54, 0x01, 0x90, 0x92, 0x17,
+0xF0, 0x90, 0x92, 0x05, 0xE0, 0x54, 0x02, 0x90,
+0x92, 0x18, 0xF0, 0x90, 0x92, 0x05, 0xE0, 0x54,
+0x04, 0x90, 0x92, 0x19, 0xF0, 0x90, 0x92, 0x05,
+0xE0, 0x54, 0x08, 0x90, 0x92, 0x1A, 0xF0, 0x90,
+0x92, 0x05, 0xE0, 0x54, 0x10, 0x90, 0x92, 0x1B,
+0xF0, 0x22, 0x12, 0x02, 0xF6, 0x90, 0x92, 0x26,
+0xF0, 0xF1, 0x12, 0x90, 0x92, 0x27, 0x91, 0xB4,
+0x90, 0x92, 0x28, 0xF0, 0x22, 0xF9, 0xE4, 0x3A,
+0xFA, 0x02, 0x02, 0xF6, 0xF0, 0x90, 0x85, 0xC3,
+0xE0, 0x54, 0x0F, 0x22, 0x90, 0x93, 0x67, 0x12,
+0x86, 0xFF, 0x02, 0x02, 0xF6, 0xE0, 0x90, 0x01,
+0xBA, 0xF0, 0x90, 0x85, 0xC7, 0xE0, 0x22, 0x61,
+0x4D, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x00, 0xF5,
+0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0x22, 0x8B,
+0x5B, 0x8A, 0x5C, 0x89, 0x5D, 0x90, 0x92, 0x35,
+0xE0, 0x70, 0x10, 0x12, 0x02, 0xF6, 0x13, 0x13,
+0x54, 0x3F, 0x30, 0xE0, 0x06, 0x90, 0x92, 0x3B,
+0x74, 0x01, 0xF0, 0x90, 0x92, 0x37, 0xE0, 0x70,
+0x0F, 0x71, 0x19, 0xC4, 0x54, 0x0F, 0xFF, 0xBF,
+0x05, 0x06, 0x90, 0x92, 0x3C, 0x74, 0x01, 0xF0,
+0xAB, 0x5B, 0xAA, 0x5C, 0xA9, 0x5D, 0x12, 0x8F,
+0x12, 0xFF, 0xF5, 0x5F, 0x12, 0x02, 0xF6, 0xFE,
+0xC3, 0x13, 0x30, 0xE0, 0x07, 0x12, 0x8C, 0xB5,
+0xF5, 0x60, 0x80, 0x02, 0x8F, 0x60, 0x85, 0x5F,
+0x5E, 0xE5, 0x5E, 0xD3, 0x95, 0x60, 0x50, 0x28,
+0x71, 0x19, 0x54, 0x01, 0xFD, 0xAF, 0x5E, 0x12,
+0x6E, 0x5F, 0xAF, 0x5E, 0x12, 0x77, 0x39, 0xEF,
+0xAF, 0x5E, 0x70, 0x04, 0x11, 0xA2, 0x80, 0x02,
+0xF1, 0xA0, 0x90, 0x92, 0x3C, 0xE0, 0x60, 0x04,
+0xAF, 0x5E, 0x11, 0xA2, 0x05, 0x5E, 0x80, 0xD1,
+0xE5, 0x5F, 0x70, 0x15, 0xFF, 0x12, 0x77, 0x39,
+0xEF, 0x70, 0x0E, 0xB1, 0xFE, 0x12, 0x79, 0x61,
+0x12, 0xAE, 0x3D, 0x54, 0xBF, 0xF0, 0x54, 0x7F,
+0xF0, 0x22, 0x7D, 0x01, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x93, 0x67, 0xEF, 0xF0,
+0xA3, 0xED, 0xF0, 0x7D, 0x44, 0x7F, 0x6F, 0x11,
+0xEF, 0x90, 0x93, 0x68, 0xE0, 0x90, 0x93, 0x67,
+0xB4, 0x01, 0x09, 0xE0, 0x71, 0x3A, 0xE0, 0x44,
+0x04, 0xF0, 0x80, 0x07, 0xE0, 0x71, 0x3A, 0xE0,
+0x54, 0xFB, 0xF0, 0xE4, 0xFD, 0xFF, 0x11, 0xE4,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x95, 0x18,
+0xE0, 0xFF, 0x7D, 0x48, 0x90, 0x05, 0x22, 0xEF,
+0xF0, 0x90, 0x92, 0x01, 0xED, 0xF0, 0x22, 0x11,
+0xE4, 0xE4, 0x90, 0x95, 0x16, 0xF0, 0xA3, 0xF0,
+0x90, 0x05, 0x22, 0xE0, 0x90, 0x95, 0x18, 0xF0,
+0x7D, 0x47, 0x7F, 0xFF, 0x11, 0xE4, 0x90, 0x05,
+0xF8, 0xE0, 0x70, 0x11, 0xA3, 0xE0, 0x70, 0x0D,
+0xA3, 0xE0, 0x70, 0x09, 0xA3, 0xE0, 0x70, 0x05,
+0x11, 0xDD, 0x7F, 0x01, 0x22, 0xD3, 0x90, 0x95,
+0x17, 0xE0, 0x94, 0xE8, 0x90, 0x95, 0x16, 0xE0,
+0x94, 0x03, 0x40, 0x0C, 0x90, 0x01, 0xC0, 0xE0,
+0x44, 0x20, 0xF0, 0x11, 0xDD, 0x7F, 0x00, 0x22,
+0x7F, 0x32, 0x7E, 0x00, 0x12, 0x7C, 0x9F, 0x90,
+0x95, 0x16, 0x12, 0xA7, 0x08, 0x80, 0xBF, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95,
+0x0C, 0xEF, 0xF0, 0xA3, 0xEC, 0xF0, 0xA3, 0xED,
+0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x20, 0x90,
+0x05, 0x22, 0xE0, 0x90, 0x95, 0x11, 0xF0, 0x7D,
+0x36, 0x7F, 0xFF, 0x11, 0xE4, 0x11, 0xF1, 0xBF,
+0x01, 0x02, 0x51, 0xED, 0x90, 0x95, 0x11, 0xE0,
+0xFF, 0x7D, 0x37, 0x11, 0xE4, 0x80, 0x02, 0x51,
+0xED, 0x90, 0x05, 0x22, 0xE0, 0x54, 0x6F, 0xFF,
+0x7D, 0x38, 0x11, 0xE4, 0xF1, 0xA4, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x94, 0x59, 0xEF, 0xF0, 0xA3,
+0xED, 0xF0, 0x90, 0x84, 0xC3, 0xE0, 0x04, 0xF0,
+0x90, 0x04, 0x1D, 0xE0, 0x60, 0x2B, 0x90, 0x05,
+0x22, 0xE0, 0x90, 0x94, 0x5D, 0xF0, 0x7D, 0x26,
+0x7F, 0xFF, 0x11, 0xEF, 0xEF, 0x64, 0x01, 0x70,
+0x0B, 0x71, 0x22, 0x7D, 0x01, 0x12, 0x3A, 0xC2,
+0x51, 0xA6, 0xEE, 0xF0, 0x90, 0x94, 0x5D, 0xE0,
+0xFF, 0x7D, 0x27, 0x11, 0xE4, 0x71, 0x11, 0x80,
+0x12, 0x71, 0x11, 0x71, 0x22, 0x90, 0x95, 0x15,
+0x74, 0x0A, 0xF0, 0x7D, 0x01, 0x51, 0x04, 0x51,
+0xA6, 0xEE, 0xF0, 0xF1, 0xA4, 0x90, 0x84, 0xBF,
+0xA3, 0xE0, 0x24, 0x7F, 0xF5, 0x82, 0xE4, 0x34,
+0x82, 0xF5, 0x83, 0x74, 0x01, 0xF0, 0xFF, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x13, 0xED, 0xF0,
+0xA3, 0xEB, 0xF0, 0x90, 0x95, 0x12, 0xEF, 0xF0,
+0xE4, 0xFD, 0xFC, 0x12, 0x7B, 0x2A, 0x7C, 0x00,
+0xAD, 0x07, 0x90, 0x95, 0x12, 0xE0, 0x90, 0x04,
+0x25, 0xF0, 0x90, 0x95, 0x13, 0xE0, 0x60, 0x06,
+0x71, 0x2D, 0xE0, 0x44, 0x80, 0xF0, 0xAF, 0x05,
+0x74, 0x20, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0xE0, 0x54, 0xC0, 0xF0, 0x71, 0x2D,
+0xE0, 0x54, 0xC0, 0xF0, 0x90, 0x95, 0x15, 0xE0,
+0xFF, 0xAE, 0x05, 0x74, 0x18, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x74,
+0x12, 0x2E, 0x51, 0xE5, 0xE0, 0x20, 0xE1, 0x18,
+0x54, 0x01, 0xFF, 0x90, 0x95, 0x14, 0xE0, 0x25,
+0xE0, 0x25, 0xE0, 0xFB, 0xEF, 0x44, 0x02, 0x4B,
+0xFF, 0x74, 0x12, 0x2E, 0x51, 0xE5, 0xEF, 0xF0,
+0xAF, 0x05, 0x74, 0x11, 0x2F, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0x74, 0xFF, 0xF0, 0x74,
+0x29, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0x54, 0xF7, 0xF0, 0xAE, 0x04, 0xAF,
+0x05, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x94,
+0x5B, 0xEE, 0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD,
+0x90, 0x94, 0x59, 0xE0, 0xFF, 0x12, 0x65, 0x61,
+0x90, 0x94, 0x5B, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0x12, 0x50, 0xD7, 0x90, 0x94, 0x5B, 0xA3, 0xE0,
+0xFF, 0x24, 0x12, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0xE0, 0x54, 0x01, 0xFE, 0x90, 0x94,
+0x5A, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0x44, 0x02,
+0x4E, 0xFE, 0x74, 0x12, 0x2F, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0x22, 0x90, 0x95, 0x0C,
+0xE0, 0xFF, 0x90, 0x95, 0x15, 0x74, 0x0C, 0xF0,
+0xE4, 0xFB, 0x7D, 0x01, 0x51, 0x04, 0x90, 0x95,
+0x0F, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x95,
+0x0D, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0x02, 0x77,
+0xD8, 0x90, 0x94, 0x59, 0xE0, 0xFF, 0x02, 0x5C,
+0xA3, 0xAB, 0x5B, 0xAA, 0x5C, 0xA9, 0x5D, 0x02,
+0x02, 0xF6, 0x90, 0x84, 0xC8, 0xE0, 0xFF, 0x90,
+0x94, 0x5A, 0xE0, 0xFB, 0x22, 0x74, 0x21, 0x2F,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22,
+0xE5, 0x62, 0xC4, 0x54, 0xF0, 0x24, 0x05, 0xF5,
+0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x8D,
+0x76, 0xEF, 0x30, 0xE6, 0x19, 0xE5, 0x76, 0x91,
+0x1B, 0xE0, 0xFD, 0xE5, 0x76, 0x71, 0x3A, 0xB1,
+0x7A, 0xE4, 0xFB, 0xAF, 0x76, 0x12, 0x27, 0x3D,
+0x91, 0x0D, 0xE4, 0xF0, 0x80, 0x47, 0x91, 0x0D,
+0xE0, 0x04, 0xF0, 0x91, 0x0D, 0xE0, 0x64, 0x02,
+0x70, 0x15, 0x74, 0x9F, 0x25, 0x76, 0x91, 0xF0,
+0xE0, 0xFD, 0xF4, 0x60, 0x02, 0x80, 0x21, 0xE5,
+0x76, 0x91, 0x1B, 0xE0, 0xFD, 0x80, 0x19, 0x91,
+0x0D, 0xE0, 0xD3, 0x94, 0x03, 0x40, 0x0B, 0xAF,
+0x76, 0x12, 0x6D, 0x94, 0x91, 0x0D, 0xE4, 0xF0,
+0x80, 0x13, 0xE5, 0x76, 0x91, 0x1B, 0xE0, 0xFD,
+0xE5, 0x76, 0x71, 0x3A, 0xB1, 0x7A, 0x7B, 0x01,
+0xAF, 0x76, 0x12, 0x27, 0x3D, 0xE5, 0x76, 0x91,
+0x1B, 0xE0, 0xFD, 0x90, 0x94, 0xB7, 0x74, 0x05,
+0xF0, 0xE4, 0xFB, 0xAF, 0x76, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xBA, 0xED,
+0xF0, 0xA3, 0xEF, 0xF0, 0xA3, 0xEB, 0xF0, 0x90,
+0x94, 0xB7, 0xE0, 0x90, 0x94, 0xBD, 0xF0, 0xE4,
+0xA3, 0xF0, 0xEF, 0x12, 0xB7, 0x6E, 0xA3, 0xE0,
+0x90, 0x94, 0xBF, 0xF0, 0x74, 0x4C, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0xE0, 0x90,
+0x94, 0xC0, 0xF0, 0x90, 0x94, 0xB8, 0x74, 0x0C,
+0xF0, 0x90, 0x94, 0xC6, 0x74, 0x07, 0xF0, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0xB8, 0x12, 0x87, 0xCE,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x74, 0xBC, 0x25,
+0x76, 0xF5, 0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83,
+0x22, 0xE5, 0x62, 0xC4, 0x54, 0xF0, 0x24, 0x00,
+0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22,
+0x8F, 0x6E, 0x8D, 0x6F, 0xEF, 0x91, 0x1B, 0xE0,
+0xFD, 0x54, 0x7F, 0xF5, 0x70, 0xED, 0x54, 0x80,
+0xF5, 0x71, 0x75, 0xF0, 0x12, 0xEF, 0x12, 0xB6,
+0xAE, 0xF5, 0x73, 0x75, 0xF0, 0x12, 0xEF, 0x12,
+0x8B, 0x45, 0xC4, 0x54, 0x03, 0xF5, 0x74, 0x91,
+0xEC, 0x74, 0xFF, 0xF0, 0x91, 0xF8, 0xE5, 0x71,
+0x4D, 0xFF, 0xB1, 0x8A, 0xEF, 0xF0, 0xE5, 0x6E,
+0x71, 0x3A, 0xE0, 0x54, 0x03, 0xF5, 0x72, 0x74,
+0x4C, 0x25, 0x6E, 0xF5, 0x82, 0xE4, 0x34, 0x90,
+0xF5, 0x83, 0xE5, 0x72, 0xF0, 0xE5, 0x70, 0x65,
+0x73, 0x70, 0x22, 0x75, 0xF0, 0x12, 0xE5, 0x6E,
+0x12, 0x8C, 0xCB, 0xC4, 0x13, 0x54, 0x07, 0x30,
+0xE0, 0x0B, 0xE5, 0x71, 0x70, 0x07, 0xE5, 0x70,
+0x44, 0x80, 0xFD, 0x80, 0x4A, 0x91, 0xF8, 0x7D,
+0x07, 0xAF, 0x6E, 0xA1, 0x23, 0xE5, 0x70, 0xC3,
+0x95, 0x73, 0x50, 0x35, 0xAB, 0x6E, 0xAD, 0x73,
+0xAF, 0x70, 0x12, 0x72, 0xEA, 0xAD, 0x07, 0xE5,
+0x70, 0xC3, 0x94, 0x0C, 0x40, 0x29, 0x75, 0xF0,
+0x12, 0xE5, 0x6E, 0x12, 0x8C, 0xCB, 0xFE, 0xC4,
+0x13, 0x54, 0x07, 0x30, 0xE0, 0x19, 0xE5, 0x6F,
+0x60, 0x15, 0xE5, 0x71, 0x70, 0x11, 0xE5, 0x70,
+0x44, 0x80, 0xFD, 0x91, 0xEC, 0xEF, 0xF0, 0x80,
+0x06, 0xB1, 0x8A, 0xE5, 0x73, 0xF0, 0xFD, 0x90,
+0x91, 0x0B, 0xE5, 0x72, 0xF0, 0xAB, 0x6F, 0xAF,
+0x6E, 0x02, 0x27, 0x3D, 0x74, 0x9F, 0x25, 0x6E,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22,
+0xE5, 0x70, 0x25, 0xE0, 0x24, 0xF5, 0xF5, 0x82,
+0xE4, 0x34, 0x82, 0xF5, 0x83, 0xE4, 0x93, 0xFE,
+0x74, 0x01, 0x93, 0xFF, 0xE5, 0x6E, 0x25, 0xE0,
+0x24, 0x7B, 0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5,
+0x83, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x7D,
+0x07, 0xAF, 0x62, 0xED, 0x30, 0xE0, 0x1D, 0x75,
+0xF0, 0x12, 0xEF, 0x90, 0x89, 0x44, 0xB1, 0x6E,
+0x90, 0x89, 0x46, 0xB1, 0x6E, 0x90, 0x89, 0x48,
+0xB1, 0x6E, 0x90, 0x89, 0x4A, 0xB1, 0x6E, 0x90,
+0x89, 0x4C, 0xB1, 0x82, 0xED, 0x30, 0xE1, 0x09,
+0x75, 0xF0, 0x12, 0xEF, 0x90, 0x89, 0x40, 0xB1,
+0x82, 0xED, 0x30, 0xE2, 0x0C, 0x75, 0xF0, 0x12,
+0xEF, 0x90, 0x89, 0x42, 0x12, 0x05, 0x28, 0xE4,
+0xF0, 0xB1, 0x96, 0xE0, 0x54, 0xBF, 0x44, 0x80,
+0xFE, 0xB1, 0x96, 0xEE, 0xF0, 0x22, 0x12, 0x05,
+0x28, 0xE4, 0xF0, 0xA3, 0xF0, 0x75, 0xF0, 0x12,
+0xEF, 0x22, 0xE0, 0x54, 0x03, 0x90, 0x91, 0x0B,
+0xF0, 0x22, 0x12, 0x05, 0x28, 0xE4, 0xF0, 0xA3,
+0xF0, 0x22, 0x74, 0xCC, 0x25, 0x6E, 0xF5, 0x82,
+0xE4, 0x34, 0x90, 0xF5, 0x83, 0x22, 0xEF, 0xC4,
+0x54, 0xF0, 0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34,
+0x81, 0xF5, 0x83, 0x22, 0x90, 0x92, 0x2A, 0xE0,
+0x30, 0xE0, 0x45, 0xC4, 0x54, 0x0F, 0x20, 0xE0,
+0x0E, 0xF1, 0xE3, 0xF1, 0x20, 0xE4, 0xB1, 0xF1,
+0x30, 0xE0, 0x02, 0xF1, 0x08, 0xE1, 0x0F, 0x90,
+0x92, 0x2A, 0xE0, 0xC4, 0x54, 0x0F, 0x30, 0xE0,
+0x27, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x90, 0x92,
+0x2D, 0xF1, 0x20, 0x90, 0x92, 0x2A, 0xE0, 0x54,
+0xEF, 0xF0, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x07,
+0x7D, 0x04, 0x7F, 0x01, 0x02, 0x57, 0x82, 0x7D,
+0x31, 0x7F, 0xFF, 0x11, 0xE4, 0x12, 0xAF, 0xF2,
+0x22, 0xFD, 0xFF, 0x11, 0xE4, 0xB1, 0xFE, 0x90,
+0x92, 0x2A, 0xE0, 0xC3, 0x13, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x7F, 0x02, 0x12,
+0xAA, 0x05, 0x7F, 0x02, 0x12, 0xA7, 0xDC, 0x44,
+0x02, 0xF0, 0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0,
+0x90, 0x06, 0xB7, 0x74, 0x09, 0xF0, 0x90, 0x06,
+0xB4, 0x74, 0x86, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x92, 0x2A, 0xE0, 0x30, 0xE0, 0x0E,
+0x90, 0x01, 0x57, 0xE4, 0xF0, 0xB1, 0xF1, 0x30,
+0xE0, 0x02, 0xF1, 0x08, 0xF1, 0x0F, 0x22, 0x12,
+0x8F, 0xE4, 0xFF, 0x54, 0x01, 0xFE, 0x90, 0x92,
+0x2A, 0xE0, 0x54, 0xFE, 0x4E, 0xFE, 0xF0, 0xEF,
+0x54, 0x02, 0xFF, 0xEE, 0x54, 0xFD, 0x12, 0xC4,
+0xB4, 0x54, 0x04, 0xFD, 0xEF, 0x54, 0xFB, 0x4D,
+0xFF, 0x90, 0x92, 0x2A, 0xF0, 0xEE, 0x54, 0x08,
+0xFE, 0xEF, 0x54, 0xF7, 0x4E, 0xF0, 0x90, 0x05,
+0x52, 0xE0, 0x54, 0x07, 0xFF, 0x90, 0x93, 0x67,
+0x60, 0x13, 0x12, 0x8F, 0x0F, 0xFD, 0x90, 0x05,
+0x56, 0xE0, 0xC3, 0x9D, 0x90, 0x92, 0x2C, 0xF0,
+0xA3, 0xED, 0xF0, 0x80, 0x23, 0x12, 0x8F, 0x0F,
+0xFB, 0xFF, 0x90, 0x05, 0x54, 0xE0, 0xC3, 0x9F,
+0xFF, 0xE4, 0x94, 0x00, 0xFE, 0x7C, 0x00, 0x7D,
+0x05, 0x12, 0x03, 0x82, 0x90, 0x92, 0x2C, 0xEF,
+0xF0, 0xEB, 0x75, 0xF0, 0x05, 0x84, 0xA3, 0xF0,
+0x12, 0x89, 0xE5, 0x12, 0x02, 0xF6, 0x20, 0xE0,
+0x0E, 0xB1, 0xFE, 0xE4, 0xFD, 0xFF, 0x11, 0xE4,
+0x90, 0x01, 0x57, 0xE4, 0xF0, 0x80, 0x04, 0xF1,
+0x08, 0xF1, 0x0F, 0xF1, 0xEC, 0x20, 0xE0, 0x04,
+0xEF, 0x44, 0x20, 0xF0, 0xB1, 0xF7, 0x30, 0xE0,
+0x17, 0x90, 0x85, 0xC5, 0x74, 0x01, 0xF0, 0xE4,
+0x90, 0x85, 0xC7, 0xF0, 0x90, 0x85, 0xC2, 0xE0,
+0x44, 0x04, 0x12, 0xAE, 0x64, 0x02, 0x51, 0x7D,
+0xE4, 0x90, 0x85, 0xC5, 0xF0, 0x90, 0x85, 0xC7,
+0x74, 0x0C, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x54,
+0xFE, 0xF0, 0xA3, 0xE0, 0x54, 0xFB, 0xF0, 0x22,
+0x7D, 0x0C, 0x7F, 0x01, 0x02, 0x57, 0x82, 0x90,
+0x92, 0x2A, 0xE0, 0x44, 0x10, 0xF0, 0x22, 0xF0,
+0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x90, 0x86, 0x6E,
+0xE0, 0x90, 0x91, 0x6F, 0xF0, 0xE4, 0xFB, 0xFD,
+0x7F, 0x54, 0x7E, 0x01, 0x02, 0x61, 0x41, 0xE4,
+0xF5, 0x75, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x55,
+0x12, 0x9F, 0x80, 0x70, 0x50, 0x12, 0xAE, 0xA9,
+0x75, 0x75, 0x01, 0xE5, 0x75, 0x60, 0x46, 0x90,
+0x85, 0xC8, 0xE0, 0x20, 0xE2, 0x07, 0x7D, 0x01,
+0x7F, 0x04, 0x12, 0x8C, 0xD7, 0x12, 0xAE, 0x35,
+0x90, 0x85, 0xCE, 0xE0, 0x60, 0x04, 0x64, 0x01,
+0x70, 0x13, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x90,
+0x85, 0xCE, 0xE0, 0xF1, 0x99, 0xF1, 0x21, 0x90,
+0x85, 0xCE, 0xE0, 0x80, 0x12, 0xE4, 0x90, 0x91,
+0x6E, 0xF1, 0x8E, 0xF1, 0x21, 0x90, 0x85, 0xCE,
+0xE0, 0x75, 0xF0, 0x03, 0xA4, 0x24, 0xFE, 0xF1,
+0x99, 0x90, 0x85, 0xDE, 0xF0, 0x22, 0xF0, 0x90,
+0x85, 0xCE, 0xE0, 0x75, 0xF0, 0x03, 0xA4, 0x24,
+0xFE, 0xFF, 0x90, 0x85, 0xCD, 0xE0, 0x2F, 0x22,
+0xE4, 0xFD, 0x01, 0xA4, 0x90, 0x04, 0x1F, 0x74,
+0x20, 0xF0, 0x22, 0xF1, 0x2F, 0xE4, 0xFF, 0x12,
+0xAC, 0x33, 0x90, 0x92, 0x03, 0xE0, 0x30, 0xE0,
+0x03, 0x12, 0xA7, 0x0F, 0xC1, 0x29, 0x90, 0x92,
+0x2A, 0xE0, 0x30, 0xE0, 0x06, 0xF1, 0xE3, 0xF1,
+0x20, 0xF1, 0x0F, 0x90, 0x84, 0xC5, 0xE0, 0xB4,
+0x01, 0x10, 0xF1, 0xEC, 0x20, 0xE0, 0x0B, 0xEF,
+0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x03, 0x12,
+0xC2, 0x89, 0x22, 0xE4, 0x90, 0x91, 0x6E, 0xF0,
+0x90, 0x92, 0x2C, 0x22, 0x90, 0x92, 0x2A, 0xE0,
+0xFF, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x22, 0x12,
+0x89, 0xDF, 0x12, 0x98, 0x14, 0x7B, 0x01, 0x7A,
+0x92, 0x79, 0x1C, 0x02, 0x6A, 0x21, 0x12, 0x89,
+0xDF, 0x11, 0x14, 0x7B, 0x01, 0x7A, 0x92, 0x79,
+0x21, 0x02, 0x6A, 0x21, 0x8B, 0x1B, 0x8A, 0x1C,
+0x89, 0x1D, 0x75, 0x1E, 0x05, 0x22, 0x12, 0x02,
+0xF6, 0xFF, 0x90, 0x92, 0x29, 0xF0, 0xBF, 0x01,
+0x07, 0x11, 0x31, 0xE4, 0x90, 0x92, 0x29, 0xF0,
+0x22, 0x11, 0xE1, 0x7F, 0xEF, 0x7E, 0x00, 0x12,
+0x64, 0x37, 0xBF, 0x01, 0x06, 0x90, 0x93, 0x67,
+0xE0, 0xA3, 0xF0, 0x11, 0xE1, 0x7F, 0xEE, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x93, 0x67, 0xE0, 0x90, 0x93, 0x69, 0xF0, 0x11,
+0xE1, 0x7F, 0xED, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x93, 0x67, 0xE0, 0x90,
+0x93, 0x6A, 0xF0, 0x11, 0xE1, 0x7F, 0xEC, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x93, 0x67, 0xE0, 0x90, 0x93, 0x6B, 0xF0, 0x11,
+0xE1, 0x7F, 0xEB, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x93, 0x67, 0xE0, 0x90,
+0x93, 0x6C, 0xF0, 0x90, 0x93, 0x68, 0xE0, 0xFF,
+0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFB, 0xA3, 0xE0,
+0x90, 0x93, 0x70, 0xF0, 0x90, 0x93, 0x6C, 0xE0,
+0x90, 0x93, 0x71, 0xF0, 0x90, 0x93, 0x72, 0x74,
+0x12, 0xF0, 0x90, 0x93, 0x80, 0x74, 0x05, 0xF0,
+0x90, 0x93, 0x74, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
+0xA3, 0xEB, 0xF0, 0x90, 0x93, 0x70, 0xE0, 0x90,
+0x93, 0x77, 0xF0, 0x90, 0x93, 0x71, 0xE0, 0x90,
+0x93, 0x78, 0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79,
+0x72, 0x12, 0x5E, 0x10, 0x7F, 0x04, 0x02, 0x87,
+0xD3, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x67, 0x22,
+0x12, 0x02, 0xF6, 0x64, 0x01, 0x60, 0x02, 0x21,
+0x75, 0x90, 0x93, 0x86, 0xF0, 0x90, 0x93, 0x86,
+0xE0, 0xFF, 0xC3, 0x94, 0x10, 0x50, 0x27, 0xEF,
+0x31, 0x76, 0x7A, 0x93, 0x79, 0x85, 0x12, 0x64,
+0x37, 0xBF, 0x01, 0x12, 0x90, 0x93, 0x85, 0xE0,
+0xFF, 0xA3, 0xE0, 0x24, 0x87, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x93,
+0x86, 0xE0, 0x04, 0xF0, 0x80, 0xCF, 0x75, 0x1B,
+0x01, 0x75, 0x1C, 0x93, 0x75, 0x1D, 0x87, 0x75,
+0x1E, 0x08, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x69,
+0x12, 0x6A, 0x21, 0x90, 0x93, 0x67, 0x74, 0x24,
+0xF0, 0x90, 0x93, 0x75, 0x74, 0x08, 0xF0, 0x75,
+0x1B, 0x01, 0x75, 0x1C, 0x93, 0x75, 0x1D, 0x8F,
+0xF5, 0x1E, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x78,
+0x12, 0x6A, 0x21, 0x90, 0x93, 0x76, 0x74, 0x25,
+0xF0, 0x90, 0x93, 0x84, 0x74, 0x08, 0xF0, 0x11,
+0xE1, 0x12, 0x5E, 0x10, 0x7B, 0x01, 0x7A, 0x93,
+0x79, 0x76, 0x12, 0x87, 0xCE, 0x22, 0x24, 0xDE,
+0xFF, 0xE4, 0x33, 0xFE, 0x7B, 0x01, 0x22, 0x12,
+0x8F, 0xE4, 0x64, 0x01, 0x60, 0x02, 0x41, 0x0C,
+0xEF, 0x24, 0x39, 0x60, 0x12, 0x14, 0x60, 0x19,
+0x24, 0x02, 0x70, 0x1F, 0xE4, 0x90, 0x93, 0x6D,
+0xF0, 0xA3, 0x74, 0x06, 0xF0, 0x80, 0x14, 0x90,
+0x93, 0x6D, 0x74, 0x06, 0xF0, 0xA3, 0xF0, 0x80,
+0x0A, 0x90, 0x93, 0x6D, 0x74, 0x0C, 0xF0, 0xA3,
+0x74, 0x04, 0xF0, 0x51, 0x20, 0x51, 0x0D, 0x40,
+0x1B, 0x90, 0x93, 0x6B, 0xE0, 0x31, 0x76, 0x7A,
+0x93, 0x79, 0x6A, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x07, 0x90, 0x93, 0x6A, 0xE0, 0xF4, 0x70, 0x3C,
+0x51, 0x15, 0x80, 0xE1, 0x51, 0x20, 0x51, 0x0D,
+0x40, 0x32, 0x90, 0x93, 0x6B, 0xE0, 0xFD, 0x7C,
+0x00, 0x24, 0xDE, 0xFF, 0xEC, 0x33, 0xFE, 0xED,
+0x24, 0x01, 0xFD, 0xEC, 0x33, 0xFC, 0x90, 0x93,
+0x6D, 0xE0, 0xFB, 0xC3, 0xED, 0x9B, 0xFD, 0xEC,
+0x94, 0x00, 0xFC, 0x12, 0x89, 0xE5, 0x8D, 0x82,
+0x8C, 0x83, 0x12, 0x03, 0x0F, 0xFD, 0x51, 0x31,
+0x51, 0x15, 0x80, 0xCA, 0x22, 0x90, 0x93, 0x6C,
+0xE0, 0xD3, 0x94, 0x00, 0x22, 0x90, 0x93, 0x6B,
+0xE0, 0x04, 0xF0, 0xA3, 0xE0, 0x14, 0xF0, 0x22,
+0x90, 0x93, 0x6D, 0xE0, 0x90, 0x93, 0x6B, 0xF0,
+0x90, 0x93, 0x6E, 0xE0, 0x90, 0x93, 0x6C, 0xF0,
+0x22, 0x8E, 0x5B, 0x8F, 0x5C, 0x8D, 0x5D, 0xE4,
+0x90, 0x93, 0x6F, 0xF0, 0x90, 0x00, 0x37, 0xE0,
+0x44, 0x80, 0xFD, 0x7F, 0x37, 0x12, 0x7B, 0x3E,
+0x7D, 0x69, 0x7F, 0xCF, 0x12, 0x7B, 0x3E, 0xE5,
+0x5C, 0xFD, 0x7F, 0x31, 0x12, 0x7B, 0x3E, 0xE5,
+0x5B, 0x54, 0x03, 0xFF, 0x90, 0x00, 0x32, 0xE0,
+0x54, 0xFC, 0x4F, 0xFD, 0x7F, 0x32, 0x12, 0x7B,
+0x3E, 0xAD, 0x5D, 0x7F, 0x30, 0x12, 0x7B, 0x3E,
+0x90, 0x00, 0x33, 0xE0, 0x44, 0x80, 0xFD, 0x7F,
+0x33, 0x12, 0x7B, 0x3E, 0x90, 0x00, 0x33, 0xE0,
+0x30, 0xE7, 0x09, 0x51, 0xA8, 0x50, 0x05, 0xE0,
+0x04, 0xF0, 0x80, 0xF0, 0xE4, 0xFD, 0x7F, 0xCF,
+0x12, 0x7B, 0x3E, 0x90, 0x00, 0x37, 0xE0, 0x54,
+0x7F, 0xFD, 0x7F, 0x37, 0x12, 0x7B, 0x3E, 0x51,
+0xA8, 0x7F, 0x00, 0x50, 0x02, 0x7F, 0x01, 0x22,
+0x90, 0x93, 0x6F, 0xE0, 0xC3, 0x94, 0x64, 0x22,
+0x12, 0x02, 0xF6, 0x54, 0x01, 0xFF, 0x90, 0x92,
+0x40, 0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x22, 0x12,
+0x02, 0xF6, 0x90, 0x86, 0x71, 0xF0, 0x22, 0x12,
+0x02, 0xF6, 0x90, 0x92, 0x33, 0xF0, 0x70, 0x03,
+0x51, 0xD4, 0xF0, 0x22, 0x90, 0x05, 0x21, 0xE0,
+0x54, 0x7F, 0x22, 0x71, 0x04, 0xFF, 0xBF, 0x03,
+0x0A, 0x90, 0x92, 0x33, 0xE0, 0xB4, 0x01, 0x03,
+0x51, 0xD4, 0xF0, 0x22, 0xE4, 0xF5, 0x75, 0xF5,
+0x76, 0xF5, 0x77, 0x71, 0x04, 0xFF, 0xBF, 0x03,
+0x0A, 0x90, 0x92, 0x33, 0xE0, 0xB4, 0x01, 0x03,
+0x51, 0xD4, 0xF0, 0x22, 0x90, 0x01, 0x02, 0xE0,
+0x54, 0x03, 0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x01, 0xC4, 0x74, 0x0B, 0xF0, 0x74, 0x9B,
+0xA3, 0xF0, 0x12, 0x71, 0x90, 0xE5, 0x4C, 0x30,
+0xE1, 0x02, 0xB1, 0x2A, 0xE5, 0x4C, 0x30, 0xE3,
+0x02, 0xB1, 0xD0, 0xE5, 0x4C, 0x30, 0xE4, 0x02,
+0xB1, 0xA7, 0xE5, 0x4C, 0x30, 0xE5, 0x03, 0x12,
+0xB8, 0xBA, 0xE5, 0x4E, 0x30, 0xE0, 0x03, 0x12,
+0x97, 0xAB, 0xE5, 0x4E, 0x30, 0xE1, 0x02, 0x71,
+0xCE, 0xE5, 0x4E, 0x30, 0xE2, 0x02, 0xB1, 0xC5,
+0xE5, 0x4E, 0x30, 0xE3, 0x02, 0xB1, 0xDC, 0xE5,
+0x4E, 0x30, 0xE4, 0x02, 0xF1, 0x9C, 0xE5, 0x4E,
+0x30, 0xE5, 0x03, 0x12, 0xAF, 0xD6, 0xE5, 0x4E,
+0x30, 0xE6, 0x02, 0xB1, 0xF3, 0xE5, 0x4E, 0x30,
+0xE7, 0x02, 0x51, 0xEC, 0xE5, 0x4F, 0x30, 0xE0,
+0x02, 0x51, 0xDB, 0xE5, 0x4F, 0x30, 0xE1, 0x02,
+0xB1, 0xBB, 0xE5, 0x4F, 0x30, 0xE4, 0x02, 0xF1,
+0xD4, 0xE5, 0x4F, 0x30, 0xE5, 0x02, 0x91, 0xB4,
+0x74, 0x0B, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74,
+0x9B, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0,
+0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0,
+0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x90, 0x85,
+0xC5, 0xE0, 0x70, 0x02, 0x81, 0x93, 0x90, 0x85,
+0xDC, 0xE0, 0x04, 0xF0, 0x90, 0x05, 0x61, 0xE0,
+0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0x78, 0x08, 0x12,
+0x04, 0xD8, 0xA8, 0x04, 0xA9, 0x05, 0xAA, 0x06,
+0xAB, 0x07, 0x90, 0x05, 0x60, 0xE0, 0xFF, 0xE4,
+0xFC, 0xFD, 0xFE, 0x12, 0x86, 0xD1, 0xC0, 0x04,
+0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05,
+0x62, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0x78,
+0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0xD1, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3,
+0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0x78, 0x18,
+0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0x12, 0x86, 0xD1, 0x90, 0x85,
+0xFC, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x92,
+0x41, 0xE0, 0x54, 0xFE, 0xF0, 0xE0, 0xC3, 0x13,
+0x30, 0xE0, 0x0D, 0x12, 0xAE, 0x65, 0x12, 0x51,
+0x7D, 0x90, 0x92, 0x41, 0xE0, 0x54, 0xFD, 0xF0,
+0x90, 0x85, 0xC2, 0xE0, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x30, 0xE0, 0x10, 0x90, 0x01, 0x3B, 0xE0,
+0x30, 0xE4, 0x09, 0x7D, 0x02, 0x7F, 0x02, 0x12,
+0x7C, 0x41, 0xF1, 0x71, 0x90, 0x95, 0x25, 0xE0,
+0x04, 0xF0, 0xE0, 0xC3, 0x94, 0x80, 0x40, 0x0B,
+0x90, 0x01, 0x98, 0xE0, 0x54, 0xFE, 0xF0, 0xE0,
+0x44, 0x01, 0xF0, 0x71, 0x04, 0xFF, 0xBF, 0x03,
+0x14, 0x90, 0x92, 0x33, 0xE0, 0xB4, 0x01, 0x0D,
+0x90, 0x01, 0xB8, 0xE0, 0x04, 0xF0, 0x90, 0x05,
+0x21, 0xE0, 0x44, 0x80, 0xF0, 0x7F, 0x01, 0xB1,
+0xAC, 0x02, 0x97, 0xBE, 0xE4, 0xF5, 0x75, 0x90,
+0x85, 0xBB, 0xE0, 0xFF, 0xE5, 0x75, 0xC3, 0x9F,
+0x50, 0x67, 0xAF, 0x75, 0x12, 0x77, 0x39, 0xEF,
+0x60, 0x5B, 0xE5, 0x75, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0xFF, 0xE5, 0x75, 0x54, 0x07, 0xFE, 0x74,
+0x75, 0x2F, 0x12, 0xB7, 0x7A, 0xAF, 0x06, 0x12,
+0xB7, 0x87, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0xFF, 0xEF, 0x5D, 0x60, 0x35,
+0xE5, 0x75, 0xC4, 0x54, 0xF0, 0x24, 0x01, 0xF5,
+0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0, 0x20,
+0xE7, 0x02, 0x80, 0x13, 0xE5, 0x75, 0xC4, 0x54,
+0xF0, 0x24, 0x02, 0xF5, 0x82, 0xE4, 0x34, 0x81,
+0xF5, 0x83, 0xE0, 0xFF, 0x20, 0xE7, 0x09, 0x90,
+0x01, 0xC1, 0xE0, 0x44, 0x20, 0xF0, 0x80, 0x05,
+0xAD, 0x75, 0x12, 0x93, 0x47, 0x05, 0x75, 0x80,
+0x8E, 0x22, 0xE4, 0xFF, 0x90, 0x94, 0x39, 0xEF,
+0xF0, 0x90, 0x04, 0x7E, 0xE0, 0xFF, 0xA3, 0xE0,
+0x90, 0x94, 0x49, 0xF0, 0xE0, 0xFE, 0x6F, 0x60,
+0x65, 0x90, 0x94, 0x3A, 0x74, 0x03, 0xF0, 0x90,
+0x94, 0x48, 0x74, 0x08, 0xF0, 0xEE, 0x04, 0x54,
+0x0F, 0xFF, 0xE4, 0xFE, 0xEF, 0x75, 0xF0, 0x08,
+0xA4, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x80,
+0xF5, 0x83, 0xE5, 0x82, 0x2E, 0x12, 0xB8, 0x5E,
+0xFD, 0x74, 0x3C, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0x94, 0xF5, 0x83, 0xED, 0xF0, 0x0E, 0xEE, 0xB4,
+0x08, 0xDA, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x3A,
+0x12, 0x5E, 0x10, 0x90, 0x94, 0x49, 0xE0, 0x04,
+0x54, 0x0F, 0xFF, 0xF0, 0xBF, 0x0F, 0x02, 0xE4,
+0xF0, 0x90, 0x94, 0x49, 0xE0, 0x90, 0x04, 0x7F,
+0xF0, 0x90, 0x94, 0x39, 0xE0, 0x7F, 0x04, 0x70,
+0x02, 0x80, 0x09, 0x12, 0x87, 0xD3, 0x22, 0x12,
+0x40, 0xB9, 0x7F, 0x02, 0x8F, 0x0D, 0x7F, 0x02,
+0x12, 0x86, 0x27, 0x90, 0x84, 0xC1, 0xE0, 0x45,
+0x0D, 0xF0, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x60,
+0x03, 0x12, 0xC2, 0x68, 0x22, 0x90, 0x85, 0xC8,
+0xE0, 0x64, 0x02, 0x60, 0x02, 0xD1, 0x69, 0x22,
+0x90, 0x92, 0x03, 0xE0, 0x30, 0xE0, 0x04, 0x7F,
+0x20, 0xB1, 0xAC, 0x22, 0xF1, 0x80, 0x70, 0x12,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x0C, 0x90, 0x85,
+0xC9, 0xE0, 0x20, 0xE4, 0x05, 0xF1, 0xBE, 0x12,
+0x97, 0x17, 0x22, 0xE4, 0xFF, 0x12, 0x77, 0x39,
+0xBF, 0x01, 0x0F, 0x90, 0x85, 0xC5, 0xE0, 0x60,
+0x09, 0xD1, 0x0B, 0xF0, 0x54, 0x07, 0x70, 0x02,
+0xF1, 0x92, 0x22, 0x90, 0x85, 0xC9, 0xE0, 0x54,
+0xFE, 0x22, 0xE4, 0xF5, 0x75, 0x90, 0x06, 0xA9,
+0xE0, 0xF5, 0x75, 0x54, 0xC0, 0x70, 0x08, 0xD1,
+0x0B, 0xF0, 0x54, 0xFD, 0xF0, 0xE1, 0x92, 0xE5,
+0x75, 0x30, 0xE6, 0x1F, 0x90, 0x85, 0xC5, 0xE0,
+0x64, 0x01, 0x70, 0x1A, 0x90, 0x85, 0xC9, 0xE0,
+0x44, 0x01, 0x12, 0x8F, 0xDC, 0x64, 0x02, 0x60,
+0x05, 0x12, 0x77, 0x61, 0x80, 0x08, 0x12, 0xAE,
+0xFE, 0x80, 0x03, 0xD1, 0x0B, 0xF0, 0xE5, 0x75,
+0x90, 0x85, 0xC9, 0x30, 0xE7, 0x0E, 0xE0, 0x44,
+0x02, 0x12, 0x97, 0x17, 0x90, 0x85, 0xC1, 0xE0,
+0x44, 0x04, 0xF0, 0x22, 0xE0, 0x54, 0xFD, 0xF0,
+0x22, 0xE4, 0x90, 0x94, 0x39, 0xF0, 0xF1, 0x81,
+0x60, 0x02, 0xE1, 0x70, 0x90, 0x85, 0xC5, 0xE0,
+0x70, 0x02, 0xE1, 0x70, 0x90, 0x05, 0x63, 0xE0,
+0x90, 0x92, 0x46, 0xF0, 0x90, 0x05, 0x62, 0xE0,
+0x90, 0x92, 0x47, 0xF0, 0x90, 0x05, 0x61, 0xE0,
+0x90, 0x92, 0x48, 0xF0, 0x90, 0x05, 0x60, 0xE0,
+0x90, 0x92, 0x49, 0xF0, 0xF1, 0xBE, 0xF0, 0x90,
+0x85, 0xC9, 0xE0, 0x54, 0xEC, 0xF0, 0xF1, 0x89,
+0x24, 0xFD, 0x50, 0x02, 0x80, 0x02, 0xD1, 0x12,
+0xF1, 0x89, 0x64, 0x01, 0x70, 0x3A, 0x90, 0x06,
+0xAB, 0xE0, 0x90, 0x85, 0xCC, 0xF0, 0x90, 0x06,
+0xA9, 0xE0, 0x30, 0xE5, 0x06, 0xA3, 0xE0, 0x90,
+0x94, 0x39, 0xF0, 0x90, 0x94, 0x39, 0xE0, 0xFF,
+0x60, 0x02, 0x80, 0x05, 0x90, 0x85, 0xCB, 0xE0,
+0xFF, 0x90, 0x85, 0xCB, 0xEF, 0xF0, 0xA3, 0xE0,
+0xFF, 0x70, 0x08, 0x90, 0x85, 0xCB, 0xE0, 0xFE,
+0xFF, 0x80, 0x00, 0x90, 0x85, 0xCC, 0xEF, 0xF0,
+0x12, 0xC0, 0xB0, 0xE4, 0x90, 0x85, 0xCE, 0xF0,
+0xA3, 0xF0, 0x12, 0xC0, 0x8E, 0x90, 0x85, 0xC2,
+0x12, 0x97, 0xEF, 0x30, 0xE0, 0x63, 0xEF, 0xC4,
+0x13, 0x13, 0x54, 0x03, 0x20, 0xE0, 0x27, 0xF1,
+0x78, 0x6F, 0x70, 0x55, 0xEF, 0x60, 0x52, 0x90,
+0x85, 0xC2, 0xE0, 0x44, 0x40, 0xF0, 0xF1, 0xE7,
+0xF1, 0xC9, 0x12, 0x7B, 0xFD, 0xF1, 0x71, 0x7D,
+0x02, 0x7F, 0x02, 0x12, 0x7C, 0x41, 0x90, 0x85,
+0xCC, 0xE0, 0x14, 0xF0, 0x80, 0x33, 0x90, 0x85,
+0xC3, 0xE0, 0xC4, 0x54, 0x0F, 0x64, 0x01, 0x70,
+0x28, 0xF1, 0x78, 0xFE, 0x6F, 0x60, 0x22, 0x90,
+0x05, 0x73, 0xE0, 0xFF, 0xEE, 0x6F, 0x60, 0x19,
+0x90, 0x85, 0xC2, 0xF1, 0xD9, 0x30, 0xE0, 0x11,
+0xEF, 0x54, 0xBF, 0xF1, 0xC9, 0x12, 0x7B, 0xBF,
+0x7D, 0x01, 0x7F, 0x02, 0x12, 0x7C, 0xA9, 0xF1,
+0xE0, 0x90, 0x85, 0xC2, 0xE0, 0x44, 0x04, 0xF0,
+0x22, 0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0x41,
+0x90, 0x85, 0xCB, 0xE0, 0xFF, 0xA3, 0xE0, 0x22,
+0xE4, 0xFF, 0x12, 0x77, 0x39, 0xEF, 0x64, 0x01,
+0x22, 0x90, 0x85, 0xC3, 0xE0, 0xFF, 0xC4, 0x54,
+0x0F, 0x22, 0x90, 0x85, 0xC7, 0xE0, 0xFF, 0x7D,
+0x01, 0x02, 0x8C, 0xD7, 0xF1, 0x80, 0x70, 0x1D,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x17, 0x90, 0x85,
+0xC9, 0xE0, 0x20, 0xE4, 0x10, 0xF1, 0xBE, 0xF0,
+0x90, 0x85, 0xC1, 0xE0, 0x12, 0xAE, 0x59, 0x54,
+0x07, 0x70, 0x02, 0xF1, 0x92, 0x22, 0x90, 0x01,
+0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x02,
+0x22, 0xF0, 0x90, 0x01, 0x3F, 0x74, 0x10, 0xF0,
+0xFD, 0x7F, 0x03, 0x22, 0xE4, 0xFF, 0x02, 0x2D,
+0xBD, 0xE0, 0xFF, 0x13, 0x13, 0x54, 0x3F, 0x22,
+0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C, 0xA9, 0x90,
+0x85, 0xCB, 0xE0, 0x90, 0x05, 0x73, 0x22, 0x12,
+0x02, 0xF6, 0xFF, 0x90, 0x92, 0x34, 0xF0, 0xBF,
+0x01, 0x0A, 0x7F, 0x01, 0x12, 0xA0, 0x05, 0xE4,
+0x90, 0x92, 0x34, 0xF0, 0x22, 0x90, 0x94, 0x5F,
+0xEF, 0xF0, 0x51, 0x4F, 0x7F, 0xF4, 0x7E, 0x00,
+0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x94,
+0x7E, 0xE0, 0x90, 0x94, 0x80, 0xF0, 0x51, 0x4F,
+0x7F, 0xF5, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x08, 0x90, 0x94, 0x7E, 0xE0, 0x90, 0x94,
+0x81, 0xF0, 0x51, 0x4F, 0x7F, 0xF6, 0x7E, 0x00,
+0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x94,
+0x7E, 0xE0, 0x90, 0x94, 0x82, 0xF0, 0x51, 0x4F,
+0x7F, 0xF7, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x08, 0x90, 0x94, 0x7E, 0xE0, 0x90, 0x94,
+0x83, 0xF0, 0x51, 0x4F, 0x7F, 0xF8, 0x7E, 0x00,
+0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x94,
+0x7E, 0xE0, 0x90, 0x94, 0x84, 0xF0, 0x51, 0x4F,
+0x71, 0xB0, 0xBF, 0x01, 0x08, 0x90, 0x94, 0x7E,
+0xE0, 0x90, 0x94, 0x85, 0xF0, 0x51, 0x4F, 0x51,
+0x56, 0x70, 0x52, 0x90, 0x94, 0x7E, 0xE0, 0x90,
+0x94, 0x86, 0xF0, 0x54, 0x07, 0x60, 0x08, 0x90,
+0x94, 0x7E, 0xE0, 0x54, 0xE0, 0x70, 0x3E, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0x7F, 0x7F, 0xFA, 0x51,
+0x58, 0x70, 0x32, 0x90, 0x94, 0x7E, 0xE0, 0xFC,
+0x54, 0x07, 0x70, 0x12, 0x90, 0x94, 0x86, 0xE0,
+0xFE, 0x90, 0x94, 0x7F, 0xE0, 0x54, 0x07, 0xFD,
+0xEE, 0x4D, 0x90, 0x94, 0x86, 0xF0, 0xEC, 0x54,
+0xE0, 0x70, 0x12, 0x90, 0x94, 0x86, 0xE0, 0xFF,
+0x90, 0x94, 0x7F, 0xE0, 0x54, 0xE0, 0xFE, 0xEF,
+0x4E, 0x90, 0x94, 0x86, 0xF0, 0x51, 0x4F, 0x7F,
+0xFD, 0x51, 0x58, 0x70, 0x46, 0x90, 0x94, 0x7E,
+0xE0, 0xFE, 0x54, 0xCC, 0x90, 0x94, 0x87, 0xF0,
+0xEE, 0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90, 0x94,
+0x7E, 0xE0, 0x54, 0xC0, 0x70, 0x2D, 0xEF, 0x70,
+0x11, 0x90, 0x94, 0x87, 0xE0, 0xFF, 0x90, 0x94,
+0x7E, 0xE0, 0x54, 0x03, 0xF1, 0xE4, 0x90, 0x94,
+0x87, 0xF0, 0x90, 0x94, 0x7E, 0xE0, 0xFF, 0x54,
+0xC0, 0x70, 0x10, 0x90, 0x94, 0x87, 0xE0, 0xFE,
+0xEF, 0x54, 0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF,
+0xEE, 0x4F, 0xF0, 0x51, 0x4F, 0x7F, 0xF0, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x94, 0x7E, 0xE0, 0x90, 0x94, 0x88, 0xF0, 0x51,
+0x4F, 0x7F, 0xF1, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x94, 0x7E, 0xE0, 0x90,
+0x94, 0x89, 0xF0, 0x51, 0x4F, 0x7F, 0xF2, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x94, 0x7E, 0xE0, 0x90, 0x94, 0x8A, 0xF0, 0x51,
+0x4F, 0x7F, 0xF3, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x94, 0x7E, 0xE0, 0x90,
+0x94, 0x8B, 0xF0, 0x51, 0x4F, 0x7F, 0xFC, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x94, 0x7E, 0xE0, 0x90, 0x94, 0x8C, 0xF0, 0x90,
+0x94, 0x60, 0x74, 0x19, 0xF0, 0x90, 0x94, 0x6E,
+0x74, 0x08, 0xF0, 0x90, 0x94, 0x80, 0xE0, 0x90,
+0x94, 0x62, 0xF0, 0x90, 0x94, 0x81, 0xE0, 0x90,
+0x94, 0x63, 0xF0, 0x90, 0x94, 0x82, 0xE0, 0x90,
+0x94, 0x64, 0xF0, 0x90, 0x94, 0x83, 0xE0, 0x90,
+0x94, 0x65, 0xF0, 0x90, 0x94, 0x84, 0xE0, 0x90,
+0x94, 0x66, 0xF0, 0x90, 0x94, 0x85, 0xE0, 0x90,
+0x94, 0x67, 0xF0, 0x90, 0x94, 0x86, 0xE0, 0x90,
+0x94, 0x68, 0xF0, 0x90, 0x94, 0x87, 0xE0, 0x90,
+0x94, 0x69, 0xF0, 0x90, 0x94, 0x6F, 0x74, 0x1A,
+0xF0, 0x90, 0x94, 0x7D, 0x74, 0x05, 0xF0, 0x90,
+0x94, 0x88, 0xE0, 0x90, 0x94, 0x71, 0xF0, 0x90,
+0x94, 0x89, 0xE0, 0x90, 0x94, 0x72, 0xF0, 0x90,
+0x94, 0x8A, 0xE0, 0x90, 0x94, 0x73, 0xF0, 0x90,
+0x94, 0x8B, 0xE0, 0x90, 0x94, 0x74, 0xF0, 0x90,
+0x94, 0x8C, 0xE0, 0x90, 0x94, 0x75, 0xF0, 0x90,
+0x94, 0x5F, 0xE0, 0xB4, 0x01, 0x17, 0x7B, 0x01,
+0x7A, 0x94, 0x79, 0x60, 0x12, 0x5E, 0x10, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0x6F, 0x12, 0x5E, 0x10,
+0x7F, 0x04, 0x02, 0x87, 0xD3, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x94, 0x75, 0x1D, 0x60, 0x75, 0x1E,
+0x0A, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xA0, 0x12,
+0x6A, 0x21, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x94,
+0x75, 0x1D, 0x71, 0x75, 0x1E, 0x05, 0x7B, 0x01,
+0x7A, 0x01, 0x79, 0xAA, 0x02, 0x6A, 0x21, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0x7E, 0x22, 0x7F, 0xFB,
+0x7E, 0x00, 0x12, 0x64, 0x37, 0xEF, 0x64, 0x01,
+0x22, 0x7E, 0x00, 0x7F, 0x0B, 0x7D, 0x00, 0x7B,
+0x01, 0x7A, 0x92, 0x79, 0x35, 0x12, 0x06, 0xDE,
+0x51, 0xE8, 0x71, 0xB0, 0xBF, 0x01, 0x1C, 0x90,
+0x93, 0x97, 0xE0, 0xFE, 0x54, 0x01, 0x90, 0x92,
+0x35, 0xF0, 0xEE, 0x54, 0x04, 0x90, 0x92, 0x37,
+0xF0, 0x90, 0x93, 0x97, 0xE0, 0x54, 0x08, 0x90,
+0x92, 0x36, 0xF0, 0x51, 0xE8, 0x51, 0x56, 0x70,
+0x34, 0x90, 0x93, 0x97, 0xE0, 0x54, 0x07, 0x70,
+0x14, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x98, 0x7F,
+0xFA, 0xFE, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x0F,
+0x90, 0x93, 0x98, 0x80, 0x03, 0x90, 0x93, 0x97,
+0xE0, 0x54, 0x07, 0x90, 0x92, 0x39, 0xF0, 0x90,
+0x93, 0x97, 0xE0, 0x54, 0xE0, 0xC4, 0x13, 0x54,
+0x07, 0x90, 0x92, 0x38, 0xF0, 0x51, 0xE8, 0x7F,
+0xFD, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x0E, 0x90, 0x93, 0x97, 0xE0, 0x54, 0x0C, 0x13,
+0x13, 0x54, 0x3F, 0x90, 0x92, 0x3A, 0xF0, 0x22,
+0x7B, 0x01, 0x7A, 0x93, 0x79, 0x97, 0x22, 0x51,
+0xE8, 0x7F, 0xF9, 0x51, 0x58, 0x70, 0x3F, 0x90,
+0x93, 0x97, 0xE0, 0x54, 0xF0, 0x70, 0x0D, 0x51,
+0xE8, 0x7F, 0xFC, 0xFE, 0x12, 0x64, 0x37, 0xEF,
+0x70, 0x02, 0xFF, 0x22, 0x90, 0x93, 0x97, 0xE0,
+0x54, 0xF0, 0xC4, 0x54, 0x0F, 0xF0, 0xE0, 0x24,
+0xFA, 0x60, 0x03, 0x04, 0x70, 0x08, 0x90, 0x93,
+0x98, 0x74, 0x01, 0xF0, 0x80, 0x05, 0xE4, 0x90,
+0x93, 0x98, 0xF0, 0x90, 0x93, 0x98, 0xE0, 0x7F,
+0x00, 0x70, 0x02, 0x7F, 0x01, 0x22, 0x7F, 0x00,
+0x22, 0x90, 0x00, 0x80, 0xE0, 0x44, 0x80, 0xFD,
+0x7F, 0x80, 0x12, 0x7B, 0x3E, 0x12, 0xAA, 0xC9,
+0x12, 0xB8, 0x84, 0x12, 0x7B, 0x9C, 0x91, 0xD6,
+0x71, 0xB7, 0x7F, 0x01, 0x12, 0x85, 0x15, 0x90,
+0x92, 0x32, 0x74, 0x02, 0xF0, 0xFF, 0x12, 0x85,
+0x15, 0x90, 0x92, 0x32, 0xE0, 0x04, 0xF0, 0x91,
+0xFB, 0x71, 0xF1, 0x90, 0x01, 0xCC, 0x74, 0x0F,
+0xF0, 0x51, 0xEF, 0xEF, 0x70, 0x02, 0x71, 0xD4,
+0x90, 0x00, 0x80, 0xE0, 0x44, 0x40, 0xFD, 0x7F,
+0x80, 0x12, 0x7B, 0x3E, 0x75, 0x20, 0xFF, 0x12,
+0x7C, 0xCD, 0x53, 0xA8, 0xFE, 0x90, 0x01, 0xA0,
+0xE0, 0xB4, 0xFD, 0x04, 0xE4, 0xFF, 0x11, 0x05,
+0xB1, 0x67, 0x90, 0x00, 0x81, 0xE0, 0x44, 0x04,
+0xFD, 0x7F, 0x81, 0x12, 0x7B, 0x3E, 0x12, 0xA8,
+0x32, 0x51, 0x61, 0xE4, 0xFF, 0x02, 0x85, 0x9E,
+0x7F, 0xF9, 0x7E, 0x00, 0x02, 0x64, 0x37, 0xE4,
+0x90, 0x84, 0xC1, 0x71, 0xCC, 0x90, 0x92, 0x01,
+0xF0, 0x22, 0xE4, 0x90, 0x93, 0xBC, 0xF0, 0x90,
+0x94, 0x27, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3,
+0xF0, 0xA3, 0xF0, 0x22, 0xE4, 0x90, 0x93, 0x97,
+0xF0, 0xC2, 0xAF, 0x12, 0xAF, 0xF2, 0x90, 0x93,
+0x97, 0xE0, 0x64, 0x01, 0xF0, 0x24, 0xD4, 0x90,
+0x01, 0xC4, 0xF0, 0x74, 0xA3, 0xA3, 0xF0, 0x80,
+0xEA, 0xF1, 0x02, 0x12, 0x7B, 0xEF, 0x12, 0x3C,
+0x03, 0xB1, 0xB8, 0xD1, 0x3E, 0x91, 0x0B, 0x91,
+0xB9, 0x12, 0xB8, 0x67, 0x90, 0x92, 0x33, 0x74,
+0x01, 0xF0, 0x22, 0x90, 0x92, 0x2A, 0xE0, 0x54,
+0xFE, 0xF0, 0x54, 0xFD, 0xF0, 0x54, 0xEF, 0xF0,
+0x44, 0x08, 0xF0, 0x90, 0x84, 0xC5, 0xE0, 0xFF,
+0x64, 0x02, 0x70, 0x2D, 0x90, 0xFD, 0x80, 0xE0,
+0x7E, 0x00, 0x30, 0xE0, 0x02, 0x7E, 0x01, 0x90,
+0x92, 0x30, 0x91, 0xB2, 0x7E, 0x00, 0x30, 0xE1,
+0x02, 0x7E, 0x01, 0x90, 0x92, 0x2E, 0x91, 0xB2,
+0x7E, 0x00, 0x30, 0xE2, 0x02, 0x7E, 0x01, 0x90,
+0x92, 0x2F, 0x91, 0xB2, 0x90, 0x02, 0xFB, 0xF0,
+0x22, 0xEF, 0x64, 0x01, 0x70, 0x21, 0x91, 0xAB,
+0x30, 0xE0, 0x02, 0x7F, 0x01, 0x90, 0x92, 0x30,
+0xEF, 0xF0, 0x91, 0xAB, 0x30, 0xE1, 0x02, 0x7F,
+0x01, 0x90, 0x92, 0x2E, 0xEF, 0xF0, 0x91, 0xAB,
+0x30, 0xE2, 0x02, 0x7F, 0x01, 0x80, 0x27, 0x90,
+0x84, 0xC5, 0xE0, 0x64, 0x03, 0x70, 0x24, 0x91,
+0xA4, 0x30, 0xE0, 0x02, 0x7F, 0x01, 0x90, 0x92,
+0x30, 0xEF, 0xF0, 0x91, 0xA4, 0x30, 0xE1, 0x02,
+0x7F, 0x01, 0x90, 0x92, 0x2E, 0xEF, 0xF0, 0x91,
+0xA4, 0x30, 0xE2, 0x02, 0x7F, 0x01, 0x90, 0x92,
+0x2F, 0xEF, 0xF0, 0x22, 0x90, 0xFD, 0x78, 0xE0,
+0x7F, 0x00, 0x22, 0x90, 0xFD, 0x70, 0xE0, 0x7F,
+0x00, 0x22, 0xEE, 0xF0, 0x90, 0xFD, 0x80, 0xE0,
+0x22, 0x90, 0x92, 0x03, 0xE0, 0x54, 0xFE, 0xF1,
+0xAA, 0x90, 0x92, 0x0A, 0xF0, 0xA3, 0xF0, 0xA3,
+0xF0, 0x90, 0x92, 0x0E, 0xF0, 0x90, 0x92, 0x26,
+0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x00,
+0x00, 0xE0, 0x54, 0xFB, 0xFD, 0xE4, 0xFF, 0xF1,
+0xDC, 0x44, 0x04, 0xFD, 0x7F, 0x01, 0x12, 0x7B,
+0x3E, 0x90, 0x01, 0x98, 0x74, 0x80, 0xF0, 0xA3,
+0x74, 0x88, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74,
+0x80, 0xF0, 0x22, 0x12, 0x7C, 0x4E, 0x90, 0x84,
+0xC5, 0xEF, 0xF0, 0xB1, 0x2F, 0x90, 0x01, 0x64,
+0x74, 0x01, 0xF0, 0x90, 0x04, 0x23, 0xE0, 0x44,
+0x80, 0xF0, 0x90, 0x00, 0x17, 0xE0, 0x54, 0xFC,
+0x44, 0x04, 0xFD, 0x7F, 0x17, 0x12, 0x7B, 0x3E,
+0x90, 0x00, 0x38, 0xE0, 0x44, 0x40, 0xFD, 0x7F,
+0x38, 0x12, 0x7B, 0x3E, 0x02, 0x68, 0xE2, 0x90,
+0x00, 0x08, 0xE0, 0x54, 0xEF, 0xF0, 0x12, 0x75,
+0xB6, 0x12, 0x75, 0x58, 0xF1, 0xEC, 0x12, 0xA8,
+0x13, 0xE4, 0xF5, 0x40, 0xF5, 0x41, 0xF5, 0x42,
+0x75, 0x43, 0x80, 0xAD, 0x40, 0x7F, 0x50, 0x12,
+0x7B, 0x3E, 0xAD, 0x41, 0x7F, 0x51, 0x12, 0x7B,
+0x3E, 0xAD, 0x42, 0x7F, 0x52, 0x12, 0x7B, 0x3E,
+0xAD, 0x43, 0x7F, 0x53, 0x02, 0x7B, 0x3E, 0xE4,
+0x90, 0x93, 0x97, 0xF0, 0xA3, 0xF0, 0x12, 0xB8,
+0x91, 0xEF, 0x64, 0x01, 0x60, 0x3B, 0xC3, 0x90,
+0x93, 0x98, 0xE0, 0x94, 0x88, 0x90, 0x93, 0x97,
+0xE0, 0x94, 0x13, 0x40, 0x0F, 0x90, 0x01, 0xC1,
+0xE0, 0x44, 0x10, 0xF0, 0x90, 0x01, 0xC7, 0x74,
+0xFD, 0xF0, 0x80, 0x1D, 0x90, 0x93, 0x97, 0xF1,
+0x08, 0xF1, 0xB1, 0xD3, 0x90, 0x93, 0x98, 0xE0,
+0x94, 0x32, 0x90, 0x93, 0x97, 0xE0, 0x94, 0x00,
+0x40, 0xC4, 0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE3,
+0xBD, 0x90, 0x01, 0xC7, 0x74, 0xFE, 0xF0, 0x22,
+0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00, 0x90, 0x89,
+0x1B, 0x12, 0x86, 0xFF, 0x7B, 0xFF, 0x7A, 0x82,
+0x79, 0x00, 0x90, 0x89, 0x1E, 0x12, 0x86, 0xFF,
+0x7A, 0x82, 0x79, 0x3F, 0x90, 0x89, 0x21, 0x12,
+0x86, 0xFF, 0x7A, 0x82, 0x79, 0xE1, 0x90, 0x89,
+0x27, 0x12, 0x86, 0xFF, 0x7A, 0x82, 0x79, 0xF5,
+0x90, 0x89, 0x2A, 0x12, 0x86, 0xFF, 0x7A, 0x83,
+0x79, 0x1D, 0x90, 0x89, 0x2D, 0x12, 0x86, 0xFF,
+0x7A, 0x83, 0x79, 0x31, 0x90, 0x89, 0x33, 0x12,
+0x86, 0xFF, 0x7A, 0x83, 0x79, 0x59, 0x90, 0x89,
+0x36, 0x12, 0x86, 0xFF, 0x7A, 0x83, 0x79, 0x81,
+0x90, 0x89, 0x39, 0x12, 0x86, 0xFF, 0xE4, 0x90,
+0x94, 0x9E, 0xF0, 0x90, 0x94, 0x8D, 0xF0, 0x90,
+0x93, 0x97, 0xF0, 0x90, 0x93, 0x97, 0xE0, 0xFF,
+0xC3, 0x94, 0x05, 0x50, 0x10, 0x74, 0xAF, 0x2F,
+0x12, 0xB5, 0x68, 0xE4, 0xF0, 0x90, 0x93, 0x97,
+0xE0, 0x04, 0xF0, 0x80, 0xE6, 0x22, 0x7E, 0x00,
+0x7F, 0xAC, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x85,
+0x79, 0xC1, 0x12, 0x06, 0xDE, 0xE4, 0x90, 0x92,
+0x81, 0xF0, 0x90, 0x85, 0xC4, 0x74, 0x02, 0xF0,
+0x90, 0x85, 0xCB, 0x14, 0xF0, 0xA3, 0xF0, 0xA3,
+0x74, 0x0A, 0xF0, 0x90, 0x85, 0xD1, 0xE4, 0xF0,
+0xA3, 0x74, 0x02, 0xD1, 0xF2, 0x12, 0xC0, 0x98,
+0xE4, 0xFD, 0xFF, 0x12, 0x57, 0x82, 0x7D, 0x0C,
+0x7F, 0x02, 0x12, 0x57, 0x82, 0x12, 0x97, 0x08,
+0x90, 0x84, 0xC5, 0xE0, 0xFF, 0xB4, 0x01, 0x08,
+0x90, 0x85, 0xD0, 0x74, 0xDD, 0xF0, 0x80, 0x0F,
+0xEF, 0x90, 0x85, 0xD0, 0xB4, 0x03, 0x05, 0x74,
+0xD4, 0xF0, 0x80, 0x03, 0x74, 0x40, 0xF0, 0x7F,
+0x2C, 0x12, 0x7B, 0x51, 0xEF, 0x54, 0x0F, 0xFF,
+0xBF, 0x05, 0x08, 0x90, 0x85, 0xFB, 0x74, 0x02,
+0xF0, 0x80, 0x05, 0xE4, 0x90, 0x85, 0xFB, 0xF0,
+0x90, 0x86, 0x6D, 0x74, 0x02, 0xF0, 0xA3, 0x74,
+0x0F, 0xF0, 0xA3, 0xE0, 0x54, 0x01, 0x44, 0x28,
+0xF0, 0xA3, 0x74, 0x07, 0xD1, 0xF2, 0xE4, 0x90,
+0x85, 0xD7, 0xF0, 0xA3, 0xF0, 0x7F, 0x01, 0x12,
+0x69, 0x33, 0x90, 0x06, 0x04, 0xE0, 0x54, 0x7F,
+0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x54, 0xF8, 0xF0,
+0x90, 0x05, 0x22, 0xE4, 0xF0, 0x90, 0x86, 0x71,
+0xF0, 0x22, 0xF0, 0x90, 0x85, 0xFB, 0xE0, 0x24,
+0x04, 0x90, 0x85, 0xDD, 0xF0, 0xA3, 0x74, 0x0A,
+0xF0, 0x22, 0xE4, 0xFD, 0xFF, 0x02, 0x6E, 0x5F,
+0xE4, 0x75, 0xF0, 0x01, 0x02, 0x07, 0x0A, 0x90,
+0x92, 0x0F, 0xE0, 0xFD, 0x7C, 0x00, 0xA3, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x12, 0x03, 0x82, 0xED,
+0x4C, 0x70, 0x05, 0x90, 0x92, 0x1C, 0x80, 0x2A,
+0xED, 0x64, 0x01, 0x4C, 0x70, 0x05, 0x90, 0x92,
+0x1D, 0x80, 0x1F, 0xED, 0x64, 0x02, 0x4C, 0x70,
+0x05, 0x90, 0x92, 0x1E, 0x80, 0x14, 0xED, 0x64,
+0x03, 0x4C, 0x70, 0x05, 0x90, 0x92, 0x1F, 0x80,
+0x09, 0xED, 0x64, 0x04, 0x4C, 0x70, 0x0D, 0x90,
+0x92, 0x20, 0xE0, 0xFF, 0x12, 0xBF, 0x22, 0x90,
+0x92, 0x10, 0xF1, 0x08, 0x22, 0x90, 0x95, 0x1C,
+0xEF, 0xF1, 0xAA, 0x90, 0x01, 0x09, 0xE0, 0x7F,
+0x00, 0x30, 0xE7, 0x02, 0x7F, 0x01, 0x90, 0x95,
+0x1C, 0xE0, 0x6F, 0x60, 0x34, 0xC3, 0x90, 0x95,
+0x1E, 0xE0, 0x94, 0x88, 0x90, 0x95, 0x1D, 0xE0,
+0x94, 0x13, 0x40, 0x08, 0x90, 0x01, 0xC0, 0xE0,
+0x44, 0x10, 0xF0, 0x22, 0x90, 0x95, 0x1D, 0xF1,
+0x08, 0xF1, 0xB1, 0xD3, 0x90, 0x95, 0x1E, 0xE0,
+0x94, 0x32, 0x90, 0x95, 0x1D, 0xE0, 0x94, 0x00,
+0x40, 0xC1, 0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE0,
+0xBA, 0x22, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0,
+0x22, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C, 0x9F,
+0x12, 0xB8, 0xF6, 0x7F, 0x08, 0x12, 0x7B, 0x51,
+0xEF, 0x54, 0xEF, 0xFD, 0x7F, 0x08, 0x12, 0x7B,
+0x3E, 0xE4, 0xFF, 0xF1, 0x5D, 0x7D, 0x35, 0x7F,
+0x27, 0x12, 0x7B, 0x3E, 0x90, 0x85, 0xC2, 0xE0,
+0x54, 0xEF, 0xF0, 0x22, 0x12, 0x7B, 0x3E, 0x90,
+0x01, 0x01, 0xE0, 0x22, 0x25, 0xE0, 0x25, 0xE0,
+0xFE, 0xEF, 0x4E, 0x22, 0x75, 0x48, 0x12, 0xE4,
+0xF5, 0x49, 0x75, 0x4A, 0x87, 0x75, 0x4B, 0x33,
+0xF5, 0x50, 0x90, 0x01, 0x30, 0xE5, 0x48, 0xF0,
+0xA3, 0xE5, 0x49, 0xF0, 0xA3, 0xE5, 0x4A, 0xF0,
+0xA3, 0xE5, 0x4B, 0xF0, 0x90, 0x01, 0x20, 0xE5,
+0x50, 0xF0, 0x22, 0x75, 0x52, 0x06, 0x75, 0x53,
+0x01, 0x75, 0x54, 0x03, 0x75, 0x55, 0x62, 0x90,
+0x01, 0x38, 0xE5, 0x52, 0xF0, 0xA3, 0xE5, 0x53,
+0xF0, 0xA3, 0xE5, 0x54, 0xF0, 0xA3, 0xE5, 0x55,
+0xF0, 0x22, 0x90, 0x01, 0xE4, 0x74, 0x0E, 0xF0,
+0xA3, 0xE4, 0xF0, 0x22, 0x7D, 0x02, 0x90, 0x01,
+0xC4, 0x74, 0x3C, 0xF0, 0x74, 0xA8, 0xA3, 0xF0,
+0x90, 0x92, 0x32, 0xE0, 0xFF, 0xED, 0xC3, 0x9F,
+0x50, 0x18, 0xED, 0x25, 0xE0, 0x24, 0x81, 0xF8,
+0xE6, 0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8, 0x74,
+0x08, 0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22, 0x0D,
+0x80, 0xDE, 0x7F, 0x01, 0x22, 0xE4, 0x90, 0x93,
+0x99, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x93,
+0x99, 0xE0, 0x64, 0x01, 0xF0, 0x90, 0x92, 0x3E,
+0xE0, 0x70, 0x18, 0x90, 0x92, 0x3B, 0xE0, 0x70,
+0x12, 0xA3, 0xE0, 0x70, 0x0E, 0x90, 0x93, 0x99,
+0xE0, 0x24, 0x6D, 0x90, 0x01, 0xC4, 0xF0, 0x74,
+0xA8, 0xA3, 0xF0, 0x12, 0x7C, 0x66, 0xBF, 0x01,
+0x03, 0x12, 0x5B, 0x25, 0x90, 0x85, 0xC5, 0xE0,
+0x60, 0x0F, 0x90, 0x85, 0xC8, 0xE0, 0xFF, 0x90,
+0x85, 0xC7, 0xE0, 0x6F, 0x60, 0x03, 0x12, 0x9F,
+0x92, 0xC2, 0xAF, 0x11, 0x3C, 0xBF, 0x01, 0x02,
+0x11, 0xCE, 0xD2, 0xAF, 0x31, 0x54, 0x12, 0x8F,
+0xF7, 0x12, 0x84, 0x4D, 0x80, 0xA8, 0x90, 0x85,
+0xC1, 0xE0, 0x30, 0xE0, 0x02, 0x11, 0xD8, 0x22,
+0x90, 0x85, 0xC8, 0xE0, 0xFF, 0x60, 0x03, 0xB4,
+0x08, 0x0D, 0x51, 0x16, 0xBF, 0x01, 0x08, 0x11,
+0xF0, 0x90, 0x01, 0xE5, 0xE0, 0x04, 0xF0, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x31,
+0x01, 0x12, 0xA7, 0xB8, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x85, 0xC2, 0xE0, 0x44, 0x10, 0xF0,
+0x90, 0x85, 0xD0, 0xE0, 0xFD, 0x7F, 0x93, 0x12,
+0x7B, 0x3E, 0x90, 0x85, 0xC6, 0xE0, 0x60, 0x12,
+0x90, 0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74,
+0x10, 0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F, 0x74,
+0x90, 0xF0, 0x7F, 0x08, 0x12, 0x7B, 0x51, 0xEF,
+0x44, 0x10, 0xFD, 0x7F, 0x08, 0x12, 0x7B, 0x3E,
+0x7F, 0x01, 0x12, 0xA7, 0x5D, 0x7D, 0x34, 0x7F,
+0x27, 0x12, 0x7B, 0x3E, 0x7F, 0x90, 0x51, 0x05,
+0x7F, 0x90, 0x12, 0x7B, 0x3E, 0x7F, 0x14, 0x7E,
+0x00, 0x02, 0x7C, 0x9F, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x92, 0x3B, 0xE0, 0x60,
+0x24, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x70, 0x61,
+0x31, 0xFB, 0x12, 0x86, 0xDE, 0xEF, 0x44, 0xFE,
+0xFF, 0xEE, 0x44, 0x03, 0xFE, 0xED, 0x44, 0x04,
+0xFD, 0xEC, 0x31, 0xFB, 0x51, 0x0D, 0x7F, 0x54,
+0x7E, 0x09, 0x12, 0x71, 0x18, 0x90, 0x92, 0x36,
+0xE0, 0x70, 0x24, 0x90, 0x07, 0xCC, 0xE0, 0x30,
+0xE0, 0x1D, 0xE4, 0xF0, 0x90, 0x93, 0xA0, 0x74,
+0x22, 0xF0, 0x90, 0x93, 0xAE, 0x74, 0x01, 0xF0,
+0x90, 0x93, 0xA2, 0x74, 0x03, 0xF0, 0x7B, 0x01,
+0x7A, 0x93, 0x79, 0xA0, 0x12, 0x87, 0xCE, 0x90,
+0x92, 0x3E, 0xE0, 0xFF, 0x70, 0x0A, 0x90, 0x92,
+0x3B, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x60, 0x15,
+0x90, 0x00, 0x1F, 0xE0, 0x54, 0xF0, 0xF0, 0x90,
+0x01, 0xC5, 0x74, 0xEA, 0xF0, 0xA3, 0x74, 0xEF,
+0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0xEF, 0x60, 0x06,
+0x90, 0x01, 0xC4, 0x74, 0x07, 0xF0, 0x90, 0x92,
+0x3B, 0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74,
+0x01, 0xF0, 0x90, 0x92, 0x3C, 0xE0, 0x60, 0x06,
+0x90, 0x01, 0xC4, 0x74, 0x02, 0xF0, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x93, 0x9C, 0x12, 0x04,
+0xEB, 0x90, 0x93, 0x9C, 0x22, 0x12, 0x7B, 0x51,
+0xEF, 0x44, 0x01, 0xFD, 0x22, 0x12, 0x86, 0xDE,
+0x90, 0x91, 0x66, 0x02, 0x04, 0xEB, 0x90, 0x02,
+0x87, 0xE0, 0x60, 0x02, 0x80, 0x08, 0x90, 0x01,
+0x00, 0xE0, 0x64, 0x3F, 0x60, 0x05, 0x75, 0x61,
+0x01, 0x80, 0x28, 0x90, 0x02, 0x96, 0xE0, 0x60,
+0x05, 0x75, 0x61, 0x10, 0x80, 0x1D, 0x90, 0x02,
+0x86, 0xE0, 0x20, 0xE1, 0x02, 0x80, 0x07, 0x90,
+0x02, 0x86, 0xE0, 0x30, 0xE3, 0x05, 0x75, 0x61,
+0x04, 0x80, 0x08, 0x90, 0x01, 0xB8, 0xE4, 0xF0,
+0x7F, 0x01, 0x22, 0x90, 0x01, 0xB9, 0x74, 0x08,
+0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x61, 0xF0, 0x7F,
+0x00, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x94, 0xC7, 0xEE, 0xF0, 0xA3, 0xEF,
+0xF0, 0x12, 0x70, 0x61, 0x90, 0x94, 0xD1, 0x12,
+0x04, 0xEB, 0x90, 0x94, 0xC9, 0x12, 0x86, 0xDE,
+0x12, 0x04, 0xA7, 0x90, 0x94, 0xD1, 0x12, 0x86,
+0xEA, 0x12, 0x86, 0xC4, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x94, 0xC9, 0x12,
+0x86, 0xDE, 0x90, 0x94, 0xCD, 0x12, 0x86, 0xEA,
+0x12, 0x86, 0xC4, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0x12, 0x86, 0xD1, 0x90, 0x94,
+0xD5, 0x12, 0x04, 0xEB, 0x90, 0x94, 0xD5, 0x51,
+0x0D, 0x90, 0x94, 0xC7, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x12, 0x71, 0x18, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x84, 0xA1, 0x74, 0x02, 0xF0, 0xA3,
+0x74, 0x9A, 0xF0, 0xA3, 0x74, 0x26, 0xF0, 0x90,
+0x84, 0xA6, 0x74, 0x04, 0xF0, 0xA3, 0x74, 0x80,
+0xF0, 0xA3, 0x74, 0x03, 0xF0, 0x22, 0xE4, 0xFB,
+0xFA, 0xFD, 0x7F, 0x01, 0x12, 0x86, 0x4E, 0x90,
+0x93, 0xAF, 0xEF, 0xF0, 0x60, 0xF0, 0x90, 0x84,
+0xC1, 0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0, 0x60,
+0xE5, 0xC2, 0xAF, 0xEF, 0x30, 0xE0, 0x0F, 0x90,
+0x84, 0xC1, 0xE0, 0x54, 0xFE, 0xF0, 0xE4, 0xFF,
+0x12, 0x2D, 0xBD, 0x12, 0xB1, 0x1D, 0x71, 0x41,
+0x30, 0xE1, 0x06, 0x54, 0xFD, 0xF0, 0x12, 0x60,
+0x5D, 0x71, 0x41, 0x30, 0xE2, 0x06, 0x54, 0xFB,
+0xF0, 0x12, 0x6A, 0x6D, 0x71, 0x41, 0x30, 0xE5,
+0x0C, 0x54, 0xDF, 0xF0, 0x12, 0x6F, 0x22, 0xBF,
+0x01, 0x03, 0x12, 0xB9, 0x59, 0xD2, 0xAF, 0x80,
+0xB5, 0xD2, 0xAF, 0xC2, 0xAF, 0x90, 0x84, 0xC1,
+0xE0, 0xFF, 0x22, 0x32, 0xC0, 0xE0, 0xC0, 0xF0,
+0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0,
+0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0,
+0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0x90, 0x01, 0xC4, 0x74, 0x4C, 0xF0, 0x74,
+0xAB, 0xA3, 0xF0, 0x12, 0x6C, 0xBC, 0x74, 0x4C,
+0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xAB, 0xA3,
+0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0,
+0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
+0xF0, 0xD0, 0xE0, 0x32, 0xC0, 0xE0, 0xC0, 0xF0,
+0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0,
+0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0,
+0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0x90, 0x01, 0xC4, 0x74, 0x9C, 0xF0, 0x74,
+0xAB, 0xA3, 0xF0, 0x12, 0x75, 0x28, 0xE5, 0x56,
+0x30, 0xE1, 0x02, 0x91, 0x6A, 0xE5, 0x56, 0x30,
+0xE2, 0x02, 0x91, 0x75, 0xE5, 0x56, 0x30, 0xE4,
+0x02, 0x91, 0x27, 0xE5, 0x57, 0x30, 0xE0, 0x02,
+0x91, 0xDC, 0xE5, 0x59, 0x30, 0xE1, 0x05, 0x7F,
+0x04, 0x12, 0x9D, 0xAC, 0xE5, 0x59, 0x30, 0xE4,
+0x02, 0x91, 0x2C, 0xE5, 0x59, 0x30, 0xE5, 0x02,
+0xB1, 0x5B, 0xE5, 0x59, 0x30, 0xE6, 0x02, 0x91,
+0xB2, 0x74, 0x9C, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xAB, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
+0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
+0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0xD1,
+0x45, 0x02, 0x5F, 0xE9, 0xB1, 0x1B, 0x12, 0x9F,
+0xE0, 0x7F, 0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x92, 0x41, 0xE0, 0xFE, 0x13,
+0x13, 0x54, 0x3F, 0x30, 0xE0, 0x1F, 0x90, 0x94,
+0xD9, 0x74, 0x1E, 0xF0, 0x90, 0x94, 0xE7, 0x74,
+0x01, 0xF0, 0x90, 0x94, 0xDB, 0xEF, 0xF0, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0xD9, 0x12, 0x5E, 0x10,
+0x7F, 0x04, 0x12, 0x9D, 0xAC, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x02,
+0xB1, 0xBD, 0x02, 0x95, 0xA4, 0x90, 0x85, 0xC5,
+0xE0, 0x60, 0x11, 0x90, 0x06, 0x92, 0xE0, 0x30,
+0xE1, 0x05, 0x12, 0x6B, 0x98, 0x80, 0x05, 0xD1,
+0x3D, 0x12, 0x9F, 0x92, 0x90, 0x89, 0x16, 0xE0,
+0xFF, 0x12, 0x8C, 0xBF, 0x30, 0xE0, 0x1A, 0xEF,
+0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x02, 0xD1, 0x84,
+0x90, 0x89, 0x17, 0xE0, 0x30, 0xE0, 0x0A, 0xD1,
+0x73, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0x12, 0x54,
+0x9F, 0x22, 0x90, 0x85, 0xC1, 0xE0, 0xFF, 0x12,
+0x8C, 0xBF, 0x30, 0xE0, 0x1E, 0xEF, 0x54, 0x7F,
+0xB1, 0xA9, 0x30, 0xE1, 0x06, 0xE0, 0x44, 0x02,
+0xF0, 0x80, 0x07, 0xE0, 0x54, 0xFD, 0xB1, 0xB2,
+0x04, 0xF0, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x03,
+0x12, 0x9F, 0x92, 0x22, 0xF1, 0x5F, 0x90, 0x94,
+0x4A, 0xEF, 0xF0, 0x20, 0xE0, 0x06, 0x90, 0x01,
+0x3D, 0x74, 0x01, 0xF0, 0x90, 0x94, 0x4A, 0xE0,
+0x30, 0xE0, 0x05, 0x7D, 0x01, 0xE4, 0x80, 0x02,
+0xE4, 0xFD, 0xFF, 0x12, 0x57, 0x82, 0x90, 0x94,
+0x4A, 0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01, 0x2F,
+0xE0, 0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80, 0x06,
+0x90, 0x01, 0x2F, 0x74, 0x80, 0xF0, 0xD1, 0x65,
+0x02, 0x51, 0x7D, 0xE4, 0x90, 0x94, 0x4A, 0xF0,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x34, 0x12, 0x9F,
+0x80, 0x70, 0x2F, 0x12, 0x9F, 0xE7, 0xF0, 0xD1,
+0xA9, 0x90, 0x94, 0x4A, 0x74, 0x01, 0xF0, 0xE4,
+0x90, 0x85, 0xCC, 0xF0, 0x04, 0x60, 0x1B, 0x90,
+0x85, 0xC8, 0xE0, 0x20, 0xE2, 0x07, 0x7D, 0x01,
+0x7F, 0x04, 0x12, 0x8C, 0xD7, 0xD1, 0x35, 0xE4,
+0x90, 0x91, 0x6E, 0xF0, 0x90, 0x85, 0xCD, 0x12,
+0x97, 0x20, 0x22, 0x90, 0x92, 0x81, 0xE0, 0xB4,
+0x01, 0x20, 0xE4, 0xF0, 0x90, 0x01, 0x5B, 0xF0,
+0x90, 0x91, 0x6E, 0xF0, 0x90, 0x86, 0x6F, 0xE0,
+0xC3, 0x13, 0x54, 0x7F, 0x90, 0x91, 0x6F, 0xF0,
+0xE4, 0xFB, 0xFD, 0x7F, 0x58, 0x7E, 0x01, 0x12,
+0x61, 0x41, 0x90, 0x85, 0xC1, 0xE0, 0xFF, 0xC4,
+0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x19, 0xEF,
+0x54, 0xBF, 0xB1, 0xA9, 0x30, 0xE0, 0x06, 0xE0,
+0x44, 0x01, 0xF0, 0x80, 0x08, 0xE0, 0x54, 0xFE,
+0xB1, 0xB2, 0x74, 0x04, 0xF0, 0x12, 0x9F, 0x92,
+0x22, 0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x90, 0x85,
+0xC2, 0x22, 0xF0, 0x90, 0x01, 0xB9, 0x74, 0x01,
+0xF0, 0x90, 0x01, 0xB8, 0x22, 0x90, 0x85, 0xC2,
+0x12, 0x97, 0xEF, 0x30, 0xE0, 0x10, 0xEF, 0xC4,
+0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x07, 0x7D,
+0x02, 0x7F, 0x02, 0x12, 0x7C, 0x41, 0x90, 0x85,
+0xC1, 0x12, 0x9F, 0xD9, 0x30, 0xE0, 0x09, 0xEF,
+0xD1, 0x59, 0x54, 0x07, 0x70, 0x46, 0x80, 0x41,
+0x90, 0x85, 0xCE, 0xE0, 0x04, 0xF0, 0x90, 0x85,
+0xC9, 0xE0, 0x54, 0xEF, 0xF0, 0xD1, 0x4E, 0x9F,
+0x40, 0x2F, 0x12, 0x9F, 0x80, 0x70, 0x2D, 0x12,
+0x8F, 0xDD, 0x70, 0x05, 0x12, 0x70, 0xDB, 0x80,
+0x24, 0x12, 0x70, 0xDB, 0x90, 0x85, 0xCF, 0xE0,
+0x04, 0xF0, 0xE0, 0xD3, 0x94, 0x02, 0x40, 0x09,
+0xD1, 0x2D, 0xE4, 0x90, 0x85, 0xCF, 0xF0, 0x80,
+0x02, 0xD1, 0xFE, 0xE4, 0x90, 0x85, 0xCE, 0xF0,
+0x22, 0x12, 0x9F, 0x92, 0x22, 0x90, 0x85, 0xC2,
+0xE0, 0x54, 0xFB, 0xF0, 0x22, 0x90, 0x85, 0xC9,
+0xE0, 0x44, 0x10, 0xF0, 0x22, 0x90, 0x85, 0xC1,
+0xE0, 0x54, 0xF7, 0xF0, 0x22, 0x90, 0x01, 0xC7,
+0x74, 0x66, 0xF0, 0xE4, 0xFF, 0x22, 0x90, 0x86,
+0x6D, 0xE0, 0xFF, 0x90, 0x85, 0xCE, 0xE0, 0xD3,
+0x22, 0x54, 0xFB, 0xF0, 0x90, 0x85, 0xC9, 0xE0,
+0x54, 0xFD, 0xF0, 0x22, 0xF0, 0x90, 0x85, 0xD7,
+0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x85, 0xDE,
+0xE0, 0xFB, 0x22, 0x90, 0x89, 0x16, 0xE0, 0xFE,
+0x54, 0x0F, 0xFF, 0xEE, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x7D, 0x00, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0xE4, 0x90, 0x94, 0x4C, 0xF0,
+0x90, 0x94, 0x4A, 0x74, 0x14, 0xF0, 0x90, 0x94,
+0x58, 0x74, 0x01, 0xF0, 0xFB, 0x7A, 0x94, 0x79,
+0x4A, 0x12, 0x87, 0xCE, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x92, 0x4A,
+0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x92, 0x4B,
+0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x92, 0x4C,
+0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x92, 0x4D,
+0xF0, 0x90, 0x92, 0x41, 0xE0, 0x44, 0x01, 0xF0,
+0x22, 0x90, 0x95, 0x1F, 0x12, 0x86, 0xFF, 0x12,
+0x71, 0x54, 0x90, 0x85, 0xC5, 0xE0, 0xFF, 0x12,
+0x60, 0xD0, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x15,
+0x90, 0x95, 0x1F, 0x12, 0x8F, 0x0F, 0x54, 0x0F,
+0xFF, 0x12, 0x8C, 0xB5, 0xFD, 0x12, 0x6A, 0xB8,
+0xD1, 0x65, 0x12, 0x51, 0x7D, 0x22, 0x90, 0x92,
+0x81, 0x74, 0x01, 0xF0, 0x90, 0x06, 0x92, 0x04,
+0xF0, 0x90, 0x01, 0x3C, 0x74, 0x04, 0xF0, 0x90,
+0x85, 0xC1, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x85,
+0xC8, 0xE0, 0x64, 0x0C, 0x60, 0x09, 0x12, 0x8C,
+0xD3, 0xE4, 0xFD, 0xFF, 0x12, 0x90, 0xE4, 0x7D,
+0x08, 0xE4, 0xFF, 0x02, 0x49, 0x6F, 0xD1, 0x4E,
+0x9F, 0x40, 0x2B, 0x90, 0x85, 0xDF, 0xE0, 0x04,
+0xF0, 0x90, 0x92, 0x80, 0xE0, 0xFF, 0x90, 0x85,
+0xDF, 0xE0, 0xD3, 0x9F, 0x50, 0x18, 0x90, 0x85,
+0xD7, 0xE0, 0x04, 0x12, 0x97, 0x8E, 0x90, 0x85,
+0xDE, 0xF0, 0xFB, 0x90, 0x85, 0xD7, 0xE0, 0xFF,
+0xA3, 0xE0, 0xFD, 0x12, 0x51, 0x7D, 0x22, 0xE4,
+0x90, 0x94, 0x4C, 0xF0, 0xA3, 0xF0, 0x7F, 0x83,
+0x12, 0x7B, 0x51, 0x90, 0x94, 0x4B, 0xEF, 0xF0,
+0x7F, 0x83, 0x12, 0x7B, 0x51, 0xAE, 0x07, 0x90,
+0x94, 0x4B, 0xE0, 0xFF, 0xB5, 0x06, 0x01, 0x22,
+0xC3, 0x90, 0x94, 0x4D, 0xE0, 0x94, 0x64, 0x90,
+0x94, 0x4C, 0xE0, 0x94, 0x00, 0x40, 0x0D, 0x90,
+0x01, 0xC0, 0xE0, 0x44, 0x40, 0xF0, 0x90, 0x94,
+0x4B, 0xE0, 0xFF, 0x22, 0x90, 0x94, 0x4C, 0x12,
+0xA7, 0x08, 0x80, 0xC2, 0x32, 0xC0, 0xE0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x05, 0xC0, 0x07, 0x7D, 0xA5, 0x90, 0x01,
+0xC4, 0xED, 0xF0, 0x74, 0xAF, 0xFF, 0xA3, 0xF0,
+0xED, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0xA3, 0xEF,
+0xF0, 0xD0, 0x07, 0xD0, 0x05, 0xD0, 0xD0, 0xD0,
+0x82, 0xD0, 0x83, 0xD0, 0xE0, 0x32, 0xE4, 0xFF,
+0x12, 0x77, 0x39, 0xBF, 0x01, 0x13, 0x90, 0x85,
+0xC5, 0xE0, 0x60, 0x0D, 0x12, 0x8F, 0xDD, 0x64,
+0x02, 0x60, 0x03, 0x02, 0x77, 0x61, 0x12, 0x79,
+0x41, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x12, 0x90, 0xF1, 0x90, 0x06, 0xB7, 0x74,
+0x11, 0xF0, 0x7F, 0x03, 0x7E, 0x00, 0x12, 0x7C,
+0x9F, 0x90, 0x06, 0xB4, 0xE0, 0x54, 0x0F, 0x70,
+0xF1, 0x7F, 0x02, 0x12, 0x7B, 0x51, 0xEF, 0x54,
+0xFE, 0xFD, 0x7F, 0x02, 0x12, 0x7B, 0x3E, 0x90,
+0x01, 0x00, 0x74, 0x3F, 0xF0, 0xA3, 0xE0, 0x54,
+0xFD, 0xF0, 0x90, 0x05, 0x53, 0xE0, 0x44, 0x20,
+0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x05,
+0x22, 0xED, 0xF0, 0x90, 0x92, 0x01, 0xEB, 0xF0,
+0x22, 0x12, 0x02, 0xF6, 0x90, 0x94, 0x8D, 0xF0,
+0x22, 0x90, 0x93, 0xBC, 0xEE, 0xF0, 0xA3, 0xEF,
+0xF0, 0xA3, 0xED, 0xF0, 0xEB, 0x75, 0xF0, 0x06,
+0xA4, 0xFF, 0x90, 0x89, 0x21, 0x12, 0x86, 0xF6,
+0xE9, 0x2F, 0xF9, 0xEA, 0x35, 0xF0, 0xFA, 0x90,
+0x93, 0xC4, 0x12, 0x86, 0xFF, 0x90, 0x93, 0xBE,
+0xE0, 0xF1, 0x6E, 0xE0, 0xFF, 0xA3, 0xE0, 0x90,
+0x93, 0xC1, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4,
+0xA3, 0xF0, 0x90, 0x93, 0xC4, 0x12, 0x86, 0xF6,
+0x90, 0x93, 0xC3, 0xE0, 0xFF, 0xF5, 0x82, 0xD1,
+0x00, 0xFD, 0x7C, 0x00, 0x90, 0x93, 0xBE, 0xE0,
+0x75, 0xF0, 0x12, 0x90, 0x89, 0x44, 0x12, 0x05,
+0x28, 0x75, 0xF0, 0x02, 0xEF, 0x12, 0x05, 0x28,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x93, 0xC0,
+0xE0, 0xFB, 0xEF, 0xA8, 0x03, 0x08, 0x80, 0x05,
+0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xB1,
+0xA9, 0xD1, 0x3D, 0x90, 0x93, 0xC3, 0xE0, 0x04,
+0xF0, 0xE0, 0xB4, 0x05, 0xB5, 0x90, 0x93, 0xC4,
+0x12, 0x86, 0xF6, 0x90, 0x00, 0x05, 0x12, 0x03,
+0x0F, 0xFD, 0x7C, 0x00, 0x90, 0x93, 0xC0, 0xE0,
+0xFF, 0x90, 0x93, 0xBC, 0xE0, 0xFE, 0xA3, 0xE0,
+0xA8, 0x07, 0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13,
+0xCE, 0x13, 0xD8, 0xF9, 0xB1, 0xA9, 0xB1, 0x72,
+0x40, 0x08, 0xED, 0x9F, 0xFF, 0xEC, 0x9E, 0xFE,
+0x80, 0x04, 0x7E, 0x00, 0x7F, 0x00, 0x90, 0x93,
+0xC1, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93,
+0xC1, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x93,
+0xBE, 0xE0, 0x02, 0x95, 0x0E, 0x90, 0x04, 0x85,
+0xE0, 0xF5, 0x6B, 0x90, 0x94, 0x9E, 0xE0, 0x04,
+0xF0, 0xE4, 0xF5, 0x62, 0x90, 0x85, 0xBB, 0xE0,
+0xFF, 0xE5, 0x62, 0xC3, 0x9F, 0x40, 0x02, 0xA1,
+0x63, 0x12, 0x94, 0x19, 0xE0, 0xF5, 0x6D, 0xB1,
+0xF1, 0xF5, 0x83, 0xE0, 0x65, 0x6D, 0x60, 0x16,
+0x90, 0x94, 0xB7, 0x74, 0x06, 0xF0, 0xE4, 0xFB,
+0xAD, 0x6D, 0xAF, 0x62, 0x12, 0x93, 0xBD, 0xB1,
+0xF1, 0xF5, 0x83, 0xE5, 0x6D, 0xF0, 0x90, 0x04,
+0xA0, 0xE0, 0x64, 0x01, 0x70, 0x45, 0xA3, 0xE0,
+0x65, 0x62, 0x70, 0x3F, 0xA3, 0xE0, 0xF5, 0x63,
+0xA3, 0xE0, 0x90, 0x93, 0xBB, 0xF0, 0x12, 0x94,
+0x19, 0xE0, 0x65, 0x63, 0x70, 0x02, 0xA1, 0x5F,
+0x12, 0x94, 0x19, 0xE5, 0x63, 0xF0, 0x12, 0x93,
+0x38, 0xE0, 0x54, 0xFC, 0xFF, 0x90, 0x93, 0xBB,
+0xE0, 0x54, 0x03, 0x4F, 0xFF, 0x12, 0x93, 0x38,
+0xEF, 0xF0, 0x90, 0x94, 0xB7, 0x74, 0x07, 0xF0,
+0xE4, 0xFB, 0xAD, 0x63, 0xAF, 0x62, 0x12, 0x93,
+0xBD, 0xA1, 0x5F, 0x75, 0xF0, 0x12, 0xE5, 0x62,
+0x90, 0x89, 0x42, 0x12, 0x05, 0x28, 0xE0, 0xFF,
+0x90, 0x93, 0xB3, 0xE4, 0xF0, 0xA3, 0xEF, 0xF0,
+0x75, 0xF0, 0x12, 0xE5, 0x62, 0x90, 0x89, 0x40,
+0x12, 0x05, 0x28, 0xE0, 0xF5, 0x68, 0xA3, 0xE0,
+0xF5, 0x69, 0xE5, 0x62, 0x75, 0xF0, 0x12, 0xA4,
+0x24, 0x44, 0xF9, 0x74, 0x89, 0x35, 0xF0, 0xFA,
+0x7B, 0x01, 0x90, 0x93, 0xB0, 0x12, 0x86, 0xFF,
+0xB1, 0x91, 0xFF, 0x12, 0x03, 0xED, 0x2F, 0xFF,
+0xB1, 0xA3, 0x2F, 0xFF, 0xB1, 0x7F, 0x2F, 0xFF,
+0xB1, 0x9D, 0x2F, 0xF5, 0x6C, 0x12, 0x94, 0x19,
+0xE0, 0xF5, 0x63, 0x54, 0x80, 0xF5, 0x65, 0xE5,
+0x63, 0x54, 0x7F, 0xF5, 0x64, 0x75, 0xF0, 0x12,
+0xE5, 0x62, 0x90, 0x89, 0x43, 0x12, 0x05, 0x28,
+0xE0, 0x64, 0x01, 0x60, 0x02, 0x61, 0x87, 0x90,
+0x93, 0xB0, 0x12, 0x86, 0xF6, 0xB1, 0x91, 0xFF,
+0xAE, 0xF0, 0x12, 0x03, 0xED, 0x2F, 0xFF, 0xE5,
+0xF0, 0x3E, 0xFE, 0xB1, 0xA3, 0x2F, 0xFF, 0xEE,
+0xB1, 0x7C, 0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xFE,
+0xB1, 0x9D, 0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0x90,
+0x93, 0xB5, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x03,
+0xED, 0xFF, 0xC3, 0x90, 0x93, 0xB6, 0xE0, 0x9F,
+0xFE, 0x90, 0x93, 0xB5, 0xE0, 0x95, 0xF0, 0x90,
+0x93, 0xB7, 0xF0, 0xA3, 0xCE, 0xF0, 0xB1, 0x7F,
+0xFD, 0xAC, 0xF0, 0x25, 0xE0, 0xFF, 0xEC, 0x33,
+0xFE, 0xEF, 0x2D, 0xFD, 0xEE, 0x3C, 0xFC, 0xB1,
+0xA3, 0x25, 0xE0, 0xFF, 0xE5, 0xF0, 0x33, 0xFE,
+0xB1, 0x91, 0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xCF,
+0x2D, 0xFD, 0xEF, 0x3C, 0xFC, 0xB1, 0x97, 0xAE,
+0xF0, 0x78, 0x02, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
+0xD8, 0xF9, 0x2D, 0xFF, 0xEC, 0x3E, 0x90, 0x93,
+0xB9, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93, 0xB3,
+0xB1, 0xBD, 0x24, 0x0C, 0xF5, 0x82, 0xE4, 0x34,
+0x90, 0xB1, 0x70, 0x50, 0x07, 0x90, 0x93, 0xB3,
+0xB1, 0xB1, 0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF,
+0xE5, 0x62, 0x25, 0xE0, 0x24, 0x0C, 0xF5, 0x82,
+0xE4, 0x34, 0x90, 0x12, 0x95, 0x17, 0x90, 0x93,
+0xB5, 0xB1, 0xBD, 0x24, 0x2C, 0xF5, 0x82, 0xE4,
+0x34, 0x90, 0xB1, 0x70, 0x50, 0x07, 0x90, 0x93,
+0xB5, 0xB1, 0xB1, 0x80, 0x04, 0x7E, 0xFF, 0x7F,
+0xFF, 0xE5, 0x62, 0x25, 0xE0, 0x24, 0x2C, 0xF5,
+0x82, 0xE4, 0x34, 0x90, 0x12, 0x95, 0x17, 0x90,
+0x93, 0xB9, 0xB1, 0xBD, 0x24, 0x5C, 0xF5, 0x82,
+0xE4, 0x34, 0x90, 0xB1, 0x70, 0x50, 0x07, 0x90,
+0x93, 0xB9, 0xB1, 0xB1, 0x80, 0x04, 0x7E, 0xFF,
+0x7F, 0xFF, 0xE5, 0x62, 0x25, 0xE0, 0x24, 0x5C,
+0xF5, 0x82, 0xE4, 0x34, 0x90, 0x12, 0x95, 0x17,
+0xC3, 0x74, 0xFF, 0x95, 0x69, 0xFF, 0x74, 0xFF,
+0x95, 0x68, 0xFE, 0xB1, 0xE7, 0x34, 0x90, 0xB1,
+0x70, 0x50, 0x0A, 0xE5, 0x69, 0x2D, 0xFF, 0xE5,
+0x68, 0x3C, 0xFE, 0x80, 0x04, 0x7E, 0xFF, 0x7F,
+0xFF, 0xB1, 0xE7, 0x34, 0x90, 0x12, 0x95, 0x17,
+0xB1, 0xDF, 0xFB, 0xC3, 0x74, 0xFF, 0x9B, 0xFF,
+0x74, 0xFF, 0x9E, 0xFE, 0x74, 0xFF, 0x94, 0x00,
+0xFD, 0x74, 0xFF, 0x94, 0x00, 0xFC, 0x90, 0x8F,
+0x77, 0x12, 0x86, 0xEA, 0xD3, 0x12, 0x04, 0xB4,
+0x50, 0x11, 0xB1, 0xDF, 0xFF, 0xE4, 0xFC, 0xFD,
+0x90, 0x8F, 0x77, 0x12, 0x86, 0xEA, 0x12, 0x86,
+0xA9, 0x80, 0x06, 0x74, 0xFF, 0xFF, 0xFE, 0xFD,
+0xFC, 0x90, 0x8F, 0x77, 0x12, 0x04, 0xEB, 0xAF,
+0x62, 0x12, 0x77, 0x39, 0xEF, 0x70, 0x02, 0xA1,
+0x5F, 0x75, 0xF0, 0x12, 0xE5, 0x62, 0x12, 0x8B,
+0x45, 0x12, 0x8C, 0xBF, 0x30, 0xE0, 0x02, 0xA1,
+0x5F, 0xE5, 0x62, 0x13, 0x13, 0x13, 0x54, 0x1F,
+0x24, 0x75, 0xF1, 0x7A, 0x7C, 0x00, 0xE5, 0x62,
+0xF1, 0x84, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0xFF, 0xEE, 0x5C, 0xFE, 0xEF,
+0x5D, 0x4E, 0x60, 0x02, 0xA1, 0x5F, 0xE5, 0x69,
+0x45, 0x68, 0x70, 0x0C, 0x90, 0x93, 0xB3, 0xE0,
+0x70, 0x02, 0xA3, 0xE0, 0x70, 0x02, 0xA1, 0x5F,
+0x75, 0xF0, 0x12, 0xE5, 0x62, 0xD1, 0xAE, 0xFF,
+0xE5, 0x64, 0xD3, 0x9F, 0x40, 0x08, 0x8F, 0x64,
+0xE5, 0x64, 0x45, 0x65, 0xF5, 0x63, 0x74, 0x7C,
+0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x90, 0xF5,
+0x83, 0xE0, 0xC3, 0x94, 0x05, 0x40, 0x02, 0xA1,
+0x5D, 0xE5, 0x64, 0x90, 0x82, 0xE1, 0x93, 0xF5,
+0x6A, 0xE5, 0x65, 0x60, 0x04, 0x05, 0x6A, 0x05,
+0x6A, 0xE5, 0x64, 0xC3, 0x94, 0x0C, 0x40, 0x21,
+0x74, 0x8E, 0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34,
+0x94, 0xF5, 0x83, 0xE0, 0xFF, 0x54, 0x7F, 0xFE,
+0xEF, 0x30, 0xE7, 0x06, 0xE5, 0x6A, 0x2E, 0xFF,
+0x80, 0x05, 0xC3, 0xE5, 0x6A, 0x9E, 0xFF, 0x8F,
+0x6A, 0xE5, 0x6A, 0xD3, 0x94, 0x1A, 0xAF, 0x6A,
+0x40, 0x02, 0x7F, 0x1A, 0x8F, 0x6A, 0xE5, 0x63,
+0x90, 0x83, 0x59, 0x93, 0xFF, 0xD3, 0x90, 0x93,
+0xB4, 0xE0, 0x9F, 0x90, 0x93, 0xB3, 0xE0, 0x94,
+0x00, 0x40, 0x02, 0xA1, 0x23, 0xC3, 0xE5, 0x69,
+0x94, 0x0A, 0xE5, 0x68, 0x94, 0x00, 0x50, 0x78,
+0xB1, 0x64, 0xE0, 0xC3, 0x94, 0x01, 0x40, 0x05,
+0xB1, 0x64, 0xE0, 0x14, 0xF0, 0xB1, 0x97, 0xFF,
+0x90, 0x93, 0xB4, 0xE0, 0x2F, 0xFF, 0x90, 0x93,
+0xB3, 0xE0, 0xB1, 0x7C, 0x2F, 0xFD, 0xEE, 0x35,
+0xF0, 0xFC, 0xE5, 0x68, 0xC3, 0x13, 0xFE, 0xE5,
+0x69, 0x13, 0xFF, 0xD3, 0xED, 0x9F, 0xEC, 0x9E,
+0x40, 0x0D, 0xE5, 0x62, 0x94, 0x05, 0x50, 0x05,
+0xB1, 0x64, 0x74, 0x02, 0xF0, 0x80, 0x7C, 0x90,
+0x93, 0xB0, 0x12, 0x86, 0xF6, 0x12, 0x03, 0xED,
+0x65, 0x6C, 0x70, 0x02, 0xE5, 0xF0, 0x70, 0x24,
+0xE5, 0x62, 0xC3, 0x94, 0x05, 0x50, 0x11, 0xB1,
+0x64, 0xE0, 0xD3, 0x94, 0x00, 0x40, 0x09, 0x7D,
+0x06, 0xAF, 0x62, 0x12, 0x95, 0x23, 0xA1, 0x5F,
+0xE4, 0xFD, 0xAF, 0x62, 0x12, 0x94, 0x28, 0x12,
+0x95, 0x1F, 0xA1, 0x5D, 0xB1, 0xD0, 0x80, 0x7D,
+0xB1, 0x64, 0xE4, 0xF0, 0x90, 0x93, 0xC0, 0x74,
+0x02, 0xF0, 0xAB, 0x6A, 0xAD, 0x62, 0xAF, 0x69,
+0xAE, 0x68, 0x11, 0x49, 0x8E, 0x66, 0x8F, 0x67,
+0xD1, 0x06, 0xC3, 0x74, 0x01, 0x93, 0x95, 0x67,
+0xE4, 0x93, 0x95, 0x66, 0x50, 0x0D, 0xB1, 0x85,
+0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x62, 0x12, 0x94,
+0x28, 0x80, 0x4A, 0xB1, 0xD7, 0xC3, 0xE5, 0x67,
+0x9F, 0xE5, 0x66, 0x94, 0x00, 0x50, 0x0C, 0xB1,
+0x85, 0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x62, 0xD1,
+0xB6, 0x80, 0x32, 0x12, 0x95, 0x1F, 0xB1, 0x85,
+0xE0, 0x04, 0xF0, 0xE5, 0x64, 0x90, 0x83, 0x6D,
+0x93, 0xFF, 0xB1, 0x85, 0xE0, 0xC3, 0x9F, 0x40,
+0x1C, 0xB1, 0x85, 0xE4, 0xF0, 0xB1, 0xD7, 0xD1,
+0x06, 0x74, 0x01, 0x93, 0x2F, 0xFF, 0xE4, 0x93,
+0x34, 0x00, 0xC3, 0x13, 0xFE, 0xEF, 0x13, 0xFF,
+0xE5, 0x62, 0x12, 0x95, 0x0E, 0xB1, 0xD0, 0x05,
+0x62, 0x21, 0x2C, 0x22, 0x74, 0xAF, 0x25, 0x62,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22,
+0xF5, 0x83, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xD3,
+0x9F, 0xEC, 0x9E, 0x22, 0x35, 0xF0, 0xFE, 0x90,
+0x00, 0x06, 0x02, 0x04, 0x18, 0x74, 0xAC, 0x25,
+0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83,
+0x22, 0x90, 0x00, 0x02, 0x02, 0x04, 0x18, 0x90,
+0x93, 0xB0, 0x12, 0x86, 0xF6, 0x90, 0x00, 0x08,
+0x02, 0x04, 0x18, 0x90, 0x00, 0x04, 0x02, 0x04,
+0x18, 0xFF, 0x12, 0x03, 0x70, 0x90, 0x93, 0xC1,
+0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xED, 0x2F,
+0xFF, 0xEC, 0x3E, 0xFE, 0x22, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0xC3, 0x74, 0xFF, 0x9F, 0xFF, 0x74,
+0xFF, 0x9E, 0xFE, 0xE5, 0x62, 0x25, 0xE0, 0x22,
+0x7D, 0x01, 0xAF, 0x62, 0x02, 0x65, 0xC2, 0xE5,
+0x64, 0x90, 0x83, 0x1D, 0x93, 0xFF, 0x22, 0x90,
+0x93, 0xB7, 0xE0, 0xFE, 0xA3, 0xE0, 0x22, 0xE5,
+0x62, 0x25, 0xE0, 0x24, 0x8C, 0xF5, 0x82, 0xE4,
+0x22, 0x74, 0xBC, 0x25, 0x62, 0xF5, 0x82, 0xE4,
+0x34, 0x8F, 0x22, 0x12, 0x86, 0xF6, 0x8F, 0x82,
+0x75, 0x83, 0x00, 0x02, 0x03, 0x0F, 0xE5, 0x64,
+0x25, 0xE0, 0x24, 0xF5, 0xF5, 0x82, 0xE4, 0x34,
+0x82, 0xF5, 0x83, 0x22, 0x90, 0x94, 0x32, 0x12,
+0x86, 0xFF, 0xE4, 0xFF, 0x90, 0x94, 0x38, 0xE0,
+0xFE, 0xEF, 0xC3, 0x9E, 0x50, 0x14, 0x90, 0x94,
+0x35, 0xB1, 0xFB, 0xFE, 0x90, 0x94, 0x32, 0xB1,
+0xFB, 0x6E, 0x60, 0x03, 0x7F, 0x00, 0x22, 0x0F,
+0x80, 0xE2, 0x7F, 0x01, 0x22, 0xEE, 0x8F, 0xF0,
+0x02, 0x07, 0x0A, 0x90, 0x94, 0xFE, 0x12, 0x86,
+0xFF, 0x90, 0x94, 0xFA, 0x12, 0x86, 0xF6, 0x90,
+0x95, 0x01, 0x12, 0x86, 0xFF, 0x90, 0x94, 0xFD,
+0xE0, 0x24, 0xFF, 0xFF, 0xE4, 0x34, 0xFF, 0xFE,
+0x90, 0x94, 0xFF, 0x8F, 0xF0, 0x12, 0x07, 0x0A,
+0x90, 0x95, 0x02, 0xD1, 0x3D, 0x90, 0x94, 0xFD,
+0xE0, 0xD3, 0x94, 0x00, 0x40, 0x2E, 0x90, 0x95,
+0x01, 0x12, 0x86, 0xF6, 0x12, 0x02, 0xF6, 0xFF,
+0x90, 0x94, 0xFE, 0x12, 0x86, 0xF6, 0x12, 0x02,
+0xF6, 0xFE, 0x6F, 0x60, 0x05, 0xC3, 0xEE, 0x9F,
+0xFF, 0x22, 0x90, 0x94, 0xFF, 0xD1, 0xA7, 0x90,
+0x95, 0x02, 0xD1, 0xA7, 0x90, 0x94, 0xFD, 0xE0,
+0x14, 0xF0, 0x80, 0xC9, 0x7F, 0x00, 0x22, 0x74,
+0xFF, 0xF5, 0xF0, 0x02, 0x07, 0x0A, 0x90, 0x89,
+0x3C, 0x12, 0x05, 0x28, 0xE0, 0x22, 0xAA, 0x07,
+0xA9, 0x05, 0xEA, 0x12, 0x94, 0x1B, 0xE0, 0xF5,
+0x6E, 0x54, 0x7F, 0xF5, 0x70, 0x75, 0xF0, 0x12,
+0xEA, 0x90, 0x89, 0x3D, 0x12, 0x05, 0x28, 0xE0,
+0x90, 0x93, 0xBD, 0xF0, 0x75, 0xF0, 0x12, 0xEA,
+0xD1, 0xAE, 0xFF, 0xEA, 0x12, 0x93, 0x3A, 0xE0,
+0x54, 0x03, 0xF5, 0x6F, 0xE5, 0x70, 0x90, 0x83,
+0x1D, 0x93, 0xFD, 0xEA, 0xF1, 0x6E, 0xE4, 0xF0,
+0xA3, 0xED, 0xF0, 0x75, 0xF0, 0x12, 0xEA, 0x12,
+0x8B, 0x45, 0xFE, 0xC4, 0x54, 0x03, 0x90, 0x93,
+0xBC, 0xF0, 0x74, 0xCC, 0x2A, 0x12, 0x95, 0x8E,
+0xE5, 0x70, 0xF0, 0x74, 0x4C, 0x2A, 0xF5, 0x82,
+0xE4, 0x34, 0x90, 0xF5, 0x83, 0xE5, 0x6F, 0xF0,
+0xE5, 0x70, 0xD3, 0x9F, 0x40, 0x04, 0x8F, 0x70,
+0x8F, 0x6E, 0x89, 0x71, 0xE4, 0xFF, 0xEF, 0xC3,
+0x95, 0x71, 0x50, 0x33, 0xE5, 0x6E, 0x30, 0xE7,
+0x09, 0x85, 0x70, 0x6E, 0x19, 0xE9, 0x70, 0x24,
+0x80, 0x25, 0x90, 0x93, 0xBD, 0xE0, 0xFD, 0xE5,
+0x70, 0xD3, 0x9D, 0x40, 0x0F, 0xAB, 0x02, 0x90,
+0x93, 0xC1, 0xE9, 0xF0, 0xAF, 0x70, 0xF1, 0x8F,
+0x8F, 0x6E, 0x80, 0x0B, 0x90, 0x93, 0xBD, 0xE0,
+0xF5, 0x6E, 0x80, 0x03, 0x0F, 0x80, 0xC7, 0xAF,
+0x02, 0x90, 0x91, 0x0B, 0xE5, 0x6F, 0xF0, 0xE4,
+0xFB, 0xAD, 0x6E, 0x02, 0x27, 0x3D, 0x25, 0xE0,
+0x24, 0x7B, 0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5,
+0x83, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5,
+0x83, 0xE0, 0xFD, 0x22, 0x54, 0x07, 0xFF, 0x74,
+0x01, 0x7E, 0x00, 0xA8, 0x07, 0x08, 0x22, 0xE4,
+0xF5, 0x73, 0xEF, 0x14, 0xF5, 0x72, 0xED, 0xFF,
+0xE5, 0x72, 0xF5, 0x82, 0x33, 0x95, 0xE0, 0xF5,
+0x83, 0xC3, 0xE5, 0x82, 0x9F, 0x74, 0x80, 0xF8,
+0x65, 0x83, 0x98, 0x40, 0x51, 0xE5, 0x72, 0x78,
+0x03, 0xA2, 0xE7, 0x13, 0xD8, 0xFB, 0xFF, 0x33,
+0x95, 0xE0, 0xFE, 0xEB, 0x12, 0x8F, 0xF9, 0xE5,
+0x82, 0x2F, 0xF5, 0x82, 0xE5, 0x83, 0x3E, 0xF5,
+0x83, 0xE0, 0xF5, 0x82, 0x75, 0x83, 0x00, 0xE5,
+0x72, 0xF1, 0x84, 0x80, 0x05, 0xC3, 0x33, 0xCE,
+0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEE, 0x55, 0x83,
+0xFE, 0xEF, 0x55, 0x82, 0x4E, 0x60, 0x13, 0x85,
+0x72, 0x74, 0x05, 0x73, 0x90, 0x93, 0xC1, 0xE0,
+0x65, 0x73, 0x60, 0x0A, 0xE5, 0x74, 0xD3, 0x9D,
+0x40, 0x04, 0x15, 0x72, 0x80, 0x98, 0xAF, 0x74,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x95, 0x22, 0xEF, 0xF0, 0x7F, 0x8F, 0x12,
+0x7B, 0x51, 0xEF, 0x30, 0xE6, 0x3C, 0x7F, 0x8D,
+0x12, 0x7B, 0x51, 0xEF, 0x64, 0x01, 0x70, 0x32,
+0x90, 0x95, 0x23, 0xF0, 0x90, 0x95, 0x23, 0xE0,
+0xFD, 0x90, 0x95, 0x22, 0xE0, 0x12, 0x94, 0x1B,
+0xE5, 0x82, 0x2D, 0x11, 0x5E, 0xFB, 0xE4, 0xFF,
+0x12, 0x8C, 0x7F, 0x90, 0x95, 0x23, 0xE0, 0x04,
+0xF0, 0xE0, 0xC3, 0x94, 0x10, 0x40, 0xDD, 0x7F,
+0x8F, 0x12, 0x7B, 0x51, 0xEF, 0x30, 0xE0, 0x02,
+0x11, 0x57, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4,
+0xFD, 0x7F, 0x8D, 0x02, 0x7B, 0x3E, 0xF5, 0x82,
+0xE4, 0x35, 0x83, 0xF5, 0x83, 0xE0, 0x22, 0x90,
+0x89, 0x16, 0xE0, 0x54, 0x7F, 0xF0, 0x54, 0xBF,
+0xF0, 0x54, 0xDF, 0xF0, 0x54, 0xF0, 0xF0, 0xE4,
+0x90, 0x89, 0x18, 0xF0, 0x90, 0x89, 0x16, 0xE0,
+0x54, 0xEF, 0xF0, 0x22, 0x90, 0x01, 0x94, 0xE0,
+0x44, 0x01, 0xF0, 0x90, 0x01, 0xC7, 0xE4, 0xF0,
+0x22, 0x90, 0x01, 0x98, 0xE4, 0xF0, 0xA3, 0xF0,
+0xA3, 0x74, 0x11, 0xF0, 0xA3, 0xE4, 0xF0, 0x7F,
+0x0A, 0xFE, 0x12, 0x7C, 0x9F, 0x90, 0x01, 0x99,
+0xE0, 0x54, 0x30, 0xFF, 0x64, 0x10, 0x60, 0x04,
+0xEF, 0xB4, 0x20, 0x03, 0x7F, 0x01, 0x22, 0x7F,
+0x00, 0x22, 0x90, 0x01, 0xCF, 0xE0, 0x90, 0x94,
+0x39, 0xF0, 0xE0, 0xFF, 0x30, 0xE0, 0x07, 0x90,
+0x01, 0xCF, 0xE0, 0x54, 0xFE, 0xF0, 0xEF, 0x30,
+0xE5, 0x23, 0x90, 0x01, 0xCF, 0xE0, 0x54, 0xDF,
+0xF0, 0x90, 0x01, 0x34, 0x74, 0x20, 0xF0, 0xE4,
+0xF5, 0xA8, 0xF5, 0xE8, 0x12, 0x75, 0xB6, 0x90,
+0x00, 0x03, 0xE0, 0x54, 0xFB, 0xFD, 0x7F, 0x03,
+0x12, 0x7B, 0x3E, 0x80, 0xFE, 0x22, 0x90, 0x01,
+0xC4, 0x74, 0xF6, 0xF0, 0x74, 0xB8, 0xA3, 0xF0,
+0x7F, 0x90, 0x12, 0x7B, 0x51, 0xEF, 0x20, 0xE0,
+0xF7, 0x74, 0xF6, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xB8, 0xA3, 0xF0, 0x22, 0x90, 0x01, 0x17,
+0xE0, 0xFE, 0x90, 0x01, 0x16, 0x31, 0x50, 0x90,
+0x85, 0xB7, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x02,
+0x86, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x92, 0x03,
+0xE0, 0x44, 0x01, 0xF0, 0x7D, 0x08, 0xE4, 0xFF,
+0x12, 0x7C, 0xA9, 0x90, 0x05, 0x52, 0xE0, 0x54,
+0x07, 0x04, 0x90, 0x92, 0x0F, 0x12, 0xA7, 0xAA,
+0x90, 0x04, 0x22, 0xE0, 0x54, 0xEF, 0xF0, 0x22,
+0xE0, 0x7C, 0x00, 0x24, 0x00, 0xFF, 0xEC, 0x3E,
+0x22, 0x90, 0x92, 0x21, 0xE0, 0x90, 0x94, 0x13,
+0xF0, 0x90, 0x92, 0x22, 0xE0, 0x90, 0x94, 0x14,
+0xF0, 0x90, 0x92, 0x23, 0xE0, 0x90, 0x94, 0x15,
+0xF0, 0x90, 0x92, 0x24, 0xE0, 0x90, 0x94, 0x16,
+0xF0, 0x90, 0x92, 0x25, 0xE0, 0x90, 0x94, 0x17,
+0xF0, 0x90, 0x92, 0x12, 0xE0, 0x90, 0x94, 0x18,
+0xF0, 0x90, 0x92, 0x13, 0xE0, 0x90, 0x94, 0x19,
+0xF0, 0x90, 0x92, 0x14, 0xE0, 0x90, 0x94, 0x1A,
+0xF0, 0x90, 0x92, 0x15, 0xE0, 0x90, 0x94, 0x1B,
+0xF0, 0x90, 0x92, 0x16, 0xE0, 0x90, 0x94, 0x1C,
+0xF0, 0x90, 0x92, 0x17, 0xE0, 0x90, 0x94, 0x1D,
+0xF0, 0x90, 0x92, 0x18, 0xE0, 0x90, 0x94, 0x1E,
+0xF0, 0x90, 0x92, 0x19, 0xE0, 0x90, 0x94, 0x1F,
+0xF0, 0x90, 0x92, 0x1A, 0xE0, 0x90, 0x94, 0x20,
+0xF0, 0x90, 0x92, 0x1B, 0xE0, 0x90, 0x94, 0x21,
+0xF0, 0x12, 0xA3, 0xC2, 0x90, 0x93, 0xBB, 0xF0,
+0xD1, 0x45, 0x50, 0x04, 0xD1, 0x52, 0x80, 0xF8,
+0x90, 0x92, 0x03, 0xE0, 0xC4, 0x13, 0x54, 0x07,
+0x30, 0xE0, 0x12, 0x90, 0x01, 0x02, 0xE0, 0x54,
+0x0C, 0xFF, 0xBF, 0x08, 0x08, 0x90, 0x94, 0x31,
+0x74, 0x01, 0xF0, 0x80, 0x05, 0xE4, 0x90, 0x94,
+0x31, 0xF0, 0x90, 0x01, 0x1F, 0xE0, 0xFE, 0x90,
+0x01, 0x1E, 0x31, 0x50, 0x90, 0x93, 0xB0, 0xF0,
+0xA3, 0xD1, 0xB6, 0xD1, 0x45, 0x50, 0x4A, 0xD1,
+0x7F, 0x90, 0x93, 0xBB, 0xE0, 0xFE, 0x24, 0x22,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xD1, 0x97, 0xE0,
+0x24, 0x4D, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0xFF, 0x74, 0xBD, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0xD1, 0x97, 0xE0, 0x24, 0x4E,
+0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0xEE,
+0xD1, 0xF1, 0x12, 0x86, 0xFF, 0xD1, 0x9B, 0xE0,
+0x24, 0x38, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0xEE,
+0xD1, 0xE3, 0x12, 0x86, 0xFF, 0xD1, 0x5F, 0x80,
+0xB2, 0x90, 0x02, 0x87, 0xE0, 0x70, 0x02, 0xC1,
+0x37, 0x90, 0x92, 0x03, 0xE0, 0x20, 0xE0, 0x02,
+0xC1, 0x37, 0xE4, 0x90, 0x94, 0x2C, 0x12, 0xA3,
+0xCA, 0x90, 0x93, 0xB0, 0xE0, 0xFF, 0xA3, 0xE0,
+0xA3, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93,
+0xB2, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xEC, 0x90,
+0xFD, 0x11, 0xF0, 0x74, 0x01, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0xFE, 0x74,
+0x00, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5,
+0x83, 0xE0, 0x7A, 0x00, 0x24, 0x00, 0xFF, 0xEA,
+0x3E, 0x54, 0x3F, 0x90, 0x93, 0xB4, 0xF0, 0xA3,
+0xEF, 0xF0, 0x74, 0x02, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x54, 0x0F, 0x33,
+0x33, 0x33, 0x54, 0xF8, 0x90, 0x93, 0xB7, 0xF0,
+0xFC, 0x74, 0x07, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
+0xFB, 0xF5, 0x83, 0xE0, 0x54, 0xC0, 0x90, 0x93,
+0xB9, 0xF0, 0xEC, 0x24, 0x18, 0x90, 0x93, 0xB6,
+0xF0, 0xFD, 0x90, 0x93, 0xB2, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x12, 0x55, 0x36, 0xEF, 0x54, 0xFC,
+0x90, 0x93, 0xB8, 0xF0, 0x90, 0x93, 0xB7, 0xE0,
+0x24, 0x18, 0xFF, 0xE4, 0x33, 0x90, 0x93, 0xB4,
+0x8F, 0xF0, 0x12, 0x07, 0x0A, 0x90, 0x93, 0xB4,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x12, 0x7A, 0xD0,
+0x90, 0x93, 0xB0, 0x12, 0xB6, 0x3D, 0x90, 0x85,
+0xB7, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x93,
+0xB0, 0x12, 0xB5, 0x72, 0x40, 0x1B, 0x90, 0x85,
+0xB8, 0xE0, 0x24, 0x01, 0xFF, 0x90, 0x85, 0xB7,
+0xE0, 0x34, 0x00, 0xFE, 0xC3, 0xED, 0x9F, 0xFF,
+0xEC, 0x9E, 0x90, 0x93, 0xB0, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0x93, 0xB8, 0xE0, 0x24, 0xC0, 0x60,
+0x02, 0xA1, 0x33, 0xD1, 0x38, 0x24, 0x18, 0xFD,
+0x12, 0x55, 0x36, 0xEF, 0x60, 0x02, 0xA1, 0x26,
+0xD1, 0x38, 0x24, 0x19, 0xFD, 0x12, 0x55, 0x36,
+0x90, 0x93, 0xD1, 0xD1, 0xBE, 0x90, 0x93, 0xD1,
+0xE0, 0xFF, 0x90, 0x93, 0xBA, 0xE0, 0xFD, 0xC3,
+0x9F, 0x50, 0x12, 0xD1, 0x38, 0x24, 0x1A, 0xD1,
+0xD8, 0xE0, 0x24, 0xD2, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xD1, 0x74, 0x80, 0xE0, 0x90, 0x93, 0xD1,
+0xE0, 0x70, 0x02, 0x81, 0x57, 0xE4, 0x90, 0x93,
+0xBB, 0xF0, 0xD1, 0x45, 0x40, 0x02, 0x81, 0x3F,
+0xD1, 0x7F, 0x90, 0x93, 0xBB, 0xE0, 0xFF, 0x24,
+0xBD, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
+0xE0, 0xFE, 0x90, 0x93, 0xD1, 0xE0, 0xFD, 0xEE,
+0x6D, 0x70, 0x1E, 0xEF, 0xD1, 0xF1, 0x12, 0x86,
+0xF6, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01, 0xD1,
+0xA6, 0xED, 0xF0, 0xD0, 0x01, 0xD0, 0x02, 0xD0,
+0x03, 0x12, 0xB6, 0x14, 0xEF, 0x60, 0x02, 0x80,
+0x49, 0x90, 0x93, 0xD1, 0xE0, 0x64, 0x03, 0x70,
+0x50, 0xD1, 0xA6, 0x74, 0x03, 0xF0, 0x7A, 0x95,
+0x79, 0x08, 0x12, 0xB6, 0x14, 0xEF, 0x70, 0x0F,
+0xD1, 0xA6, 0x74, 0x03, 0xF0, 0x7A, 0x95, 0x79,
+0x04, 0x12, 0xB6, 0x14, 0xEF, 0x60, 0x2A, 0x90,
+0x93, 0xBB, 0xE0, 0xFF, 0x24, 0x1D, 0xF5, 0x82,
+0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0x60, 0x02,
+0x80, 0x0B, 0x90, 0x93, 0xBB, 0xE0, 0xFF, 0x24,
+0x18, 0xD1, 0xCF, 0x60, 0x05, 0x74, 0x2C, 0x2F,
+0x80, 0x15, 0xD1, 0x66, 0x74, 0x01, 0xF0, 0x80,
+0x12, 0x90, 0x93, 0xBB, 0xE0, 0x24, 0x2C, 0x80,
+0x06, 0x90, 0x93, 0xBB, 0xE0, 0x24, 0x2C, 0xD1,
+0x6C, 0xE4, 0xF0, 0xD1, 0x5F, 0x61, 0x9A, 0x90,
+0x94, 0x2C, 0xE0, 0x70, 0x4F, 0xA3, 0xE0, 0x70,
+0x4B, 0xA3, 0xE0, 0x70, 0x47, 0xA3, 0xE0, 0x70,
+0x43, 0xA3, 0xE0, 0x70, 0x3F, 0xA1, 0x26, 0xE4,
+0x90, 0x93, 0xBB, 0xF0, 0xD1, 0x45, 0x50, 0x1C,
+0x74, 0x18, 0x2E, 0xD1, 0xCF, 0x60, 0x09, 0x74,
+0x2C, 0x2E, 0xD1, 0x6C, 0xE4, 0xF0, 0x80, 0x08,
+0x74, 0x2C, 0x2E, 0xD1, 0x6C, 0x74, 0x01, 0xF0,
+0xD1, 0x5F, 0x80, 0xE0, 0x90, 0x94, 0x2C, 0xE0,
+0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E, 0xA3, 0xE0,
+0x70, 0x0A, 0xA3, 0xE0, 0x70, 0x06, 0xA3, 0xE0,
+0x70, 0x02, 0xA1, 0x26, 0xE4, 0x90, 0x93, 0xBB,
+0xF0, 0xD1, 0x45, 0x40, 0x02, 0xA1, 0x26, 0xD1,
+0x7F, 0xD1, 0x66, 0xE0, 0x60, 0x7C, 0x90, 0x92,
+0x2A, 0xE0, 0x30, 0xE0, 0x06, 0xC4, 0x54, 0x0F,
+0x30, 0xE0, 0x6F, 0xE4, 0xFF, 0xFE, 0x90, 0x04,
+0x1D, 0xE0, 0x60, 0x10, 0xD3, 0xEF, 0x94, 0xE8,
+0xEE, 0x94, 0x03, 0x50, 0x07, 0x0F, 0xBF, 0x00,
+0x01, 0x0E, 0x80, 0xEA, 0x90, 0x04, 0x1D, 0xE0,
+0x70, 0x50, 0x90, 0x93, 0xBB, 0xE0, 0x24, 0x13,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0,
+0xFF, 0x90, 0x95, 0x15, 0x74, 0x06, 0xF0, 0x7B,
+0x08, 0x7D, 0x01, 0x12, 0x92, 0x04, 0x90, 0x93,
+0xB4, 0xEE, 0xF0, 0xA3, 0xD1, 0xBE, 0xD1, 0x8E,
+0x50, 0x21, 0xD1, 0x38, 0x24, 0x0A, 0xFC, 0xED,
+0x2C, 0xFD, 0x12, 0x55, 0x36, 0x90, 0x93, 0xB4,
+0xA3, 0xE0, 0xFE, 0x90, 0x93, 0xBA, 0xE0, 0x2E,
+0x24, 0x2C, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xD1,
+0x74, 0x80, 0xDB, 0x12, 0x97, 0xA4, 0x90, 0x06,
+0x35, 0xF0, 0xD1, 0x5F, 0x81, 0x99, 0xD1, 0xC6,
+0x12, 0x7C, 0x0B, 0x90, 0x06, 0x36, 0x74, 0xDD,
+0xF0, 0x41, 0x61, 0x90, 0x93, 0xB9, 0xE0, 0x60,
+0x02, 0xC1, 0x30, 0xD1, 0x38, 0x24, 0x16, 0xFD,
+0x12, 0x55, 0x36, 0x90, 0x06, 0x34, 0xEF, 0xF0,
+0xD1, 0x38, 0x24, 0x17, 0xFD, 0x12, 0x55, 0x36,
+0x90, 0x06, 0x37, 0xD1, 0xB6, 0xD1, 0x45, 0x50,
+0x40, 0xD1, 0x7F, 0xE4, 0x90, 0x93, 0xBA, 0xF0,
+0xD1, 0x8E, 0x50, 0x31, 0xD1, 0x38, 0x24, 0x04,
+0x2D, 0xFD, 0x12, 0x55, 0x36, 0x90, 0x93, 0xBB,
+0xE0, 0xFE, 0xD1, 0xE3, 0x12, 0x86, 0xF6, 0x90,
+0x93, 0xBA, 0xE0, 0xF5, 0x82, 0x12, 0xB6, 0x00,
+0x6F, 0x60, 0x0E, 0x74, 0x27, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE4, 0xF0, 0x80,
+0x04, 0xD1, 0x78, 0x80, 0xCB, 0xD1, 0x5F, 0x80,
+0xBC, 0x90, 0x94, 0x27, 0xE0, 0x64, 0x01, 0x60,
+0x17, 0xA3, 0xE0, 0x64, 0x01, 0x60, 0x11, 0xA3,
+0xE0, 0x64, 0x01, 0x60, 0x0B, 0xA3, 0xE0, 0x64,
+0x01, 0x60, 0x05, 0xA3, 0xE0, 0xB4, 0x01, 0x06,
+0x90, 0x93, 0xBC, 0x74, 0x01, 0xF0, 0x90, 0x92,
+0x03, 0xE0, 0xFF, 0xC4, 0x13, 0x54, 0x07, 0x30,
+0xE0, 0x3F, 0x90, 0x01, 0x02, 0xE0, 0x54, 0x0C,
+0x64, 0x08, 0x70, 0x28, 0x90, 0x93, 0xBA, 0xF0,
+0xD1, 0x8E, 0x50, 0x20, 0xD1, 0x38, 0x24, 0x04,
+0xD1, 0xD8, 0xE0, 0xFE, 0xE4, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x07, 0xF5, 0x83, 0xE0, 0x6F, 0x60,
+0x07, 0xE4, 0x90, 0x94, 0x31, 0xF0, 0x80, 0x04,
+0xD1, 0x78, 0x80, 0xDC, 0x90, 0x94, 0x31, 0xE0,
+0xB4, 0x01, 0x06, 0x90, 0x93, 0xBC, 0x74, 0x01,
+0xF0, 0x90, 0x93, 0xBC, 0xE0, 0xB4, 0x01, 0x11,
+0xD1, 0xFF, 0x90, 0x92, 0x0D, 0xE0, 0x44, 0x01,
+0xF0, 0x12, 0xAE, 0x45, 0x12, 0x5F, 0xE9, 0x41,
+0x61, 0x12, 0xA3, 0xC2, 0x90, 0x93, 0xBB, 0xF0,
+0xD1, 0x45, 0x50, 0x04, 0xD1, 0x52, 0x80, 0xF8,
+0xD1, 0xC6, 0x12, 0x7C, 0x0B, 0x41, 0x61, 0x22,
+0x90, 0x93, 0xB2, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0x90, 0x93, 0xB6, 0xE0, 0x22, 0x90, 0x92, 0x0F,
+0xE0, 0xFF, 0x90, 0x93, 0xBB, 0xE0, 0xFE, 0xC3,
+0x9F, 0x22, 0x74, 0x27, 0x2E, 0xF5, 0x82, 0xE4,
+0x34, 0x94, 0xF5, 0x83, 0x74, 0x01, 0xF0, 0x90,
+0x93, 0xBB, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x93,
+0xBB, 0xE0, 0x24, 0x2C, 0xF5, 0x82, 0xE4, 0x34,
+0x94, 0xF5, 0x83, 0x22, 0xF5, 0x83, 0xEF, 0xF0,
+0x90, 0x93, 0xBA, 0xE0, 0x04, 0xF0, 0x22, 0x74,
+0x13, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
+0x83, 0xE0, 0xFF, 0x02, 0x7B, 0x2A, 0x90, 0x93,
+0xBA, 0xE0, 0xFD, 0xC3, 0x94, 0x06, 0x22, 0xF5,
+0x83, 0xEF, 0xF0, 0x74, 0x22, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22, 0x7B, 0x01,
+0x7A, 0x93, 0x79, 0xD2, 0x90, 0x94, 0x35, 0x12,
+0x86, 0xFF, 0x90, 0x94, 0x38, 0x22, 0xEF, 0xF0,
+0xE4, 0x90, 0x93, 0xBB, 0xF0, 0x22, 0xEF, 0xF0,
+0xE4, 0x90, 0x93, 0xBA, 0xF0, 0x22, 0x90, 0x93,
+0xB0, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0xF5,
+0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0x22,
+0xFC, 0xED, 0x2C, 0xFD, 0x12, 0x55, 0x36, 0x90,
+0x93, 0xBA, 0x22, 0x75, 0xF0, 0x03, 0xA4, 0x24,
+0x04, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
+0x22, 0x75, 0xF0, 0x03, 0xA4, 0x24, 0xC2, 0xF5,
+0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x92,
+0x03, 0xE0, 0xFE, 0xEE, 0x54, 0xFE, 0xF0, 0x7D,
+0x08, 0xE4, 0xFF, 0x12, 0x7C, 0x41, 0xE4, 0x90,
+0x92, 0x10, 0xF0, 0xA3, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x04, 0x24, 0xEF, 0xF0, 0x90,
+0x04, 0x57, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x12, 0x7A, 0x29, 0xEF, 0x64,
+0x01, 0x60, 0x05, 0x75, 0x0F, 0x01, 0x80, 0x75,
+0x90, 0x85, 0xC9, 0xE0, 0xFF, 0x54, 0x03, 0x60,
+0x05, 0x75, 0x0F, 0x02, 0x80, 0x67, 0x90, 0x85,
+0xC7, 0xE0, 0xFE, 0xE4, 0xC3, 0x9E, 0x50, 0x05,
+0x75, 0x0F, 0x04, 0x80, 0x58, 0xEF, 0x30, 0xE2,
+0x05, 0x75, 0x0F, 0x08, 0x80, 0x4F, 0x90, 0x85,
+0xC9, 0xE0, 0x30, 0xE4, 0x05, 0x75, 0x0F, 0x10,
+0x80, 0x43, 0x90, 0x85, 0xC2, 0xE0, 0x13, 0x13,
+0x54, 0x3F, 0x20, 0xE0, 0x05, 0x75, 0x0F, 0x20,
+0x80, 0x33, 0x90, 0x86, 0x71, 0xE0, 0x60, 0x05,
+0x75, 0x0F, 0x80, 0x80, 0x28, 0x90, 0x06, 0x62,
+0xE0, 0x30, 0xE1, 0x05, 0x75, 0x0F, 0x11, 0x80,
+0x1C, 0x90, 0x06, 0x62, 0xE0, 0x30, 0xE0, 0x0C,
+0xE0, 0x54, 0xFC, 0xFF, 0xBF, 0x80, 0x05, 0x75,
+0x0F, 0x12, 0x80, 0x09, 0x90, 0x01, 0xB8, 0xE4,
+0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90, 0x01, 0xB9,
+0x74, 0x04, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x0F,
+0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0xAC, 0x07, 0x90, 0x92, 0x41, 0xE0, 0xF9, 0x30,
+0xE0, 0x03, 0x02, 0xC0, 0x7B, 0x90, 0x85, 0xC1,
+0xE0, 0x30, 0xE0, 0x16, 0x90, 0x85, 0xFB, 0xE0,
+0x24, 0x04, 0x90, 0x85, 0xDA, 0xF0, 0x90, 0x85,
+0xFB, 0xE0, 0x24, 0x03, 0x90, 0x85, 0xD9, 0xF0,
+0x80, 0x0D, 0x90, 0x85, 0xDA, 0x74, 0x02, 0xF0,
+0x90, 0x85, 0xD9, 0x14, 0xF0, 0x0B, 0x0B, 0x90,
+0x85, 0xD9, 0xE0, 0xFA, 0x90, 0x85, 0xD8, 0xE0,
+0xD3, 0x9A, 0x50, 0x0E, 0x90, 0x85, 0xCD, 0xEB,
+0xF0, 0x90, 0x85, 0xDA, 0xE0, 0xC3, 0x9D, 0x2C,
+0x80, 0x11, 0xC3, 0xED, 0x9A, 0x2B, 0x90, 0x85,
+0xCD, 0xF0, 0x90, 0x85, 0xD9, 0xE0, 0xFF, 0xA3,
+0xE0, 0xC3, 0x9F, 0x90, 0x85, 0xDD, 0xF0, 0x90,
+0x85, 0xDA, 0xE0, 0xFF, 0x24, 0x0A, 0xFD, 0xE4,
+0x33, 0xFC, 0x90, 0x85, 0xDD, 0x11, 0x83, 0x40,
+0x04, 0xEF, 0x24, 0x0A, 0xF0, 0x90, 0x85, 0xDD,
+0xE0, 0xFF, 0x24, 0x23, 0xFD, 0xE4, 0x33, 0xFC,
+0x90, 0x85, 0xCD, 0x11, 0x83, 0x40, 0x04, 0xEF,
+0x24, 0x23, 0xF0, 0x90, 0x85, 0xDD, 0xE0, 0xFF,
+0x7E, 0x00, 0x90, 0x85, 0xD1, 0xEE, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x05, 0x58, 0xE0, 0x6F, 0x70,
+0x01, 0xE4, 0x60, 0x02, 0x11, 0x8E, 0xE9, 0x54,
+0xFD, 0x80, 0x03, 0xE9, 0x44, 0x02, 0x90, 0x92,
+0x41, 0xF0, 0x22, 0xE0, 0xD3, 0x9D, 0xEC, 0x64,
+0x80, 0xF8, 0x74, 0x80, 0x98, 0x22, 0x90, 0x85,
+0xD1, 0xA3, 0xE0, 0x90, 0x05, 0x58, 0xF0, 0x22,
+0x90, 0x92, 0x7B, 0x74, 0x04, 0xF0, 0x14, 0xF0,
+0xA3, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x64,
+0xF0, 0xA3, 0x74, 0x05, 0xF0, 0xA3, 0xF0, 0x22,
+0xE4, 0x90, 0x94, 0x3A, 0xF0, 0xA3, 0xF0, 0xA3,
+0xF0, 0x90, 0x92, 0x4A, 0x12, 0x86, 0xDE, 0x90,
+0x92, 0x46, 0x12, 0x86, 0xEA, 0xC3, 0x12, 0x04,
+0xB4, 0x40, 0x46, 0x90, 0x85, 0xC1, 0xE0, 0x90,
+0x92, 0x4A, 0x30, 0xE0, 0x0F, 0x51, 0x1C, 0x90,
+0x85, 0xFB, 0xE0, 0x24, 0x04, 0x2F, 0xFF, 0x90,
+0x92, 0x7B, 0x80, 0x05, 0x51, 0x1C, 0x90, 0x92,
+0x7C, 0xE0, 0xFE, 0xC3, 0xEF, 0x9E, 0x90, 0x94,
+0x3B, 0xF0, 0x90, 0x94, 0x3B, 0xE0, 0xFF, 0xC3,
+0x94, 0x2D, 0x50, 0x15, 0x74, 0x4E, 0x2F, 0x51,
+0x39, 0xE0, 0x04, 0xF0, 0x90, 0x85, 0xDB, 0xE0,
+0x04, 0xF0, 0xE0, 0xFD, 0x7F, 0xFE, 0x12, 0x7B,
+0x3E, 0x90, 0x85, 0xDB, 0xE0, 0xFF, 0xD3, 0x90,
+0x92, 0x7E, 0xE0, 0x9F, 0x90, 0x92, 0x7D, 0xE0,
+0x94, 0x00, 0x40, 0x02, 0x21, 0xE8, 0x31, 0xFA,
+0x31, 0xF1, 0x50, 0x1C, 0x51, 0x04, 0x90, 0x94,
+0x3C, 0xE0, 0xD3, 0x9F, 0x40, 0x0A, 0x90, 0x94,
+0x3A, 0xE0, 0x90, 0x94, 0x3D, 0xF0, 0x80, 0x08,
+0x90, 0x94, 0x3A, 0xE0, 0x04, 0xF0, 0x80, 0xE0,
+0x31, 0xFA, 0x31, 0xF1, 0x50, 0x2C, 0x51, 0x04,
+0xC3, 0x90, 0x92, 0x7E, 0xE0, 0x9F, 0xFF, 0x90,
+0x92, 0x7D, 0xE0, 0x94, 0x00, 0xFE, 0x90, 0x94,
+0x3C, 0xE0, 0xD3, 0x9F, 0xE4, 0x9E, 0x40, 0x0A,
+0x90, 0x94, 0x3A, 0xE0, 0x90, 0x94, 0x3E, 0xF0,
+0x80, 0x08, 0x90, 0x94, 0x3A, 0xE0, 0x04, 0xF0,
+0x80, 0xD0, 0x90, 0x94, 0x3D, 0xE0, 0x90, 0x85,
+0xE0, 0xF0, 0x90, 0x94, 0x3E, 0xE0, 0x90, 0x85,
+0xE1, 0x31, 0xE9, 0x94, 0x0A, 0x40, 0x0A, 0xEF,
+0x24, 0xF6, 0x90, 0x85, 0xD8, 0xF0, 0xE4, 0x80,
+0x09, 0xE4, 0x90, 0x85, 0xD8, 0x31, 0xE9, 0x74,
+0x0A, 0x9F, 0x90, 0x85, 0xD7, 0xF0, 0x90, 0x85,
+0xE0, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90,
+0x85, 0xDE, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x30,
+0xE0, 0x05, 0x90, 0x92, 0x7B, 0x80, 0x03, 0x90,
+0x92, 0x7C, 0xE0, 0xFF, 0x90, 0x85, 0xDE, 0xE0,
+0x2F, 0x04, 0xF0, 0x90, 0x85, 0xDE, 0xE0, 0xC3,
+0x94, 0x0A, 0x50, 0x03, 0x74, 0x0A, 0xF0, 0x90,
+0x85, 0xDE, 0xE0, 0x24, 0x02, 0x12, 0xAE, 0x64,
+0x12, 0x51, 0x7D, 0xE4, 0xFF, 0x12, 0x69, 0x33,
+0x22, 0xF0, 0x90, 0x85, 0xE0, 0xE0, 0xFF, 0xC3,
+0x22, 0x90, 0x94, 0x3A, 0xE0, 0xFF, 0xC3, 0x94,
+0x2D, 0x22, 0xE4, 0x90, 0x94, 0x3C, 0xF0, 0x90,
+0x94, 0x3A, 0xF0, 0x22, 0x74, 0x4E, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0xFF,
+0x90, 0x94, 0x3C, 0xE0, 0x2F, 0xF0, 0x90, 0x92,
+0x7F, 0xE0, 0xFF, 0x22, 0x12, 0x86, 0xEA, 0x90,
+0x92, 0x46, 0x12, 0x86, 0xDE, 0x12, 0x86, 0xB6,
+0x78, 0x0A, 0x12, 0x04, 0xC5, 0x90, 0x85, 0xDD,
+0xE0, 0xFE, 0xC3, 0x74, 0x0A, 0x9E, 0x2F, 0xFF,
+0x22, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
+0x22, 0xE4, 0xFE, 0x74, 0x4E, 0x2E, 0x51, 0x39,
+0xE4, 0xF0, 0x0E, 0xEE, 0xB4, 0x2D, 0xF4, 0xE4,
+0x90, 0x85, 0xDC, 0xF0, 0x90, 0x85, 0xDB, 0xF0,
+0x90, 0x85, 0xDF, 0xF0, 0xEF, 0xB4, 0x01, 0x07,
+0xA3, 0x74, 0x2D, 0xF0, 0xE4, 0xA3, 0xF0, 0x22,
+0x90, 0x85, 0xC5, 0xE0, 0x64, 0x01, 0x70, 0x18,
+0x12, 0x8F, 0xDD, 0x60, 0x06, 0x12, 0x8C, 0xD3,
+0x02, 0x6B, 0x98, 0x90, 0x85, 0xC8, 0xE0, 0x70,
+0x07, 0x7D, 0x01, 0x7F, 0x04, 0x12, 0x8C, 0xD7,
+0x22, 0x90, 0x92, 0x2A, 0xE0, 0x30, 0xE0, 0x34,
+0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x2D, 0x90,
+0x95, 0x28, 0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94,
+0xC8, 0x40, 0x21, 0x90, 0x92, 0x2A, 0xE0, 0x54,
+0xDF, 0xF0, 0xE4, 0x90, 0x95, 0x28, 0xF0, 0x90,
+0x92, 0x2A, 0xE0, 0x13, 0x30, 0xE0, 0x0D, 0x90,
+0x85, 0xC1, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x85,
+0xD0, 0x74, 0xD0, 0xF0, 0x22, 0x90, 0x94, 0x5E,
+0xEF, 0xF0, 0x90, 0x84, 0xC5, 0xE0, 0xB4, 0x02,
+0x12, 0x90, 0x94, 0x5E, 0xE0, 0xFF, 0x64, 0x01,
+0x60, 0x25, 0x90, 0x01, 0x4D, 0xE0, 0x64, 0x80,
+0xF0, 0x80, 0x19, 0x90, 0x01, 0x00, 0x74, 0xFF,
+0xF0, 0x7F, 0x64, 0x7E, 0x00, 0x12, 0x7C, 0x9F,
+0x90, 0x06, 0x90, 0xE0, 0x44, 0x01, 0xF0, 0x90,
+0x94, 0x5E, 0xE0, 0xFF, 0x12, 0x2A, 0x87, 0x22,
+0x90, 0x94, 0xE9, 0xED, 0xF0, 0x90, 0x94, 0xE8,
+0xEF, 0xF0, 0x12, 0x7B, 0x2A, 0x90, 0x94, 0xF6,
+0xEF, 0xF0, 0xE0, 0xFD, 0x24, 0x01, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFE, 0x74,
+0x00, 0x2D, 0x91, 0x36, 0x12, 0xB9, 0x50, 0x54,
+0x3F, 0x90, 0x94, 0xF3, 0xF0, 0xA3, 0xEF, 0xF0,
+0xE4, 0x90, 0x94, 0xF2, 0xF0, 0x91, 0x56, 0x50,
+0x09, 0x91, 0x7C, 0x91, 0x33, 0xE4, 0x91, 0x3E,
+0x80, 0xF3, 0x90, 0x94, 0xF4, 0xE0, 0x24, 0xF8,
+0xFB, 0x90, 0x94, 0xF3, 0xE0, 0x34, 0xFF, 0xFA,
+0x90, 0x94, 0xE9, 0xE0, 0xFF, 0x90, 0x8A, 0xF5,
+0xE4, 0xF0, 0xA3, 0xEF, 0xF0, 0xA3, 0x74, 0x01,
+0xF0, 0x7D, 0x0A, 0x7C, 0x00, 0x7F, 0x10, 0x7E,
+0x00, 0x12, 0x6D, 0xDB, 0x90, 0x88, 0xD2, 0xE0,
+0xFF, 0x90, 0x94, 0xE8, 0xE0, 0xFD, 0xD3, 0x9F,
+0x40, 0x36, 0x90, 0x88, 0xD2, 0xE0, 0xFC, 0x91,
+0x5F, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9,
+0x91, 0x72, 0xEC, 0xFF, 0xC3, 0xED, 0x91, 0x68,
+0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24,
+0x28, 0xFF, 0xE4, 0x3E, 0xFE, 0x91, 0x4E, 0xFD,
+0x90, 0x94, 0xE9, 0xE0, 0xFC, 0xC3, 0xED, 0x9C,
+0x91, 0x46, 0x7D, 0x38, 0x7C, 0x00, 0x80, 0x37,
+0x90, 0x94, 0xE8, 0xE0, 0xFD, 0x91, 0x5F, 0xCE,
+0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0x91, 0x72,
+0xED, 0xFF, 0x90, 0x88, 0xD2, 0xE0, 0xC3, 0x91,
+0x68, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
+0x24, 0x38, 0xFD, 0xE4, 0x3E, 0xFC, 0x91, 0x4E,
+0xFF, 0x90, 0x94, 0xE9, 0xE0, 0xFE, 0xC3, 0xEF,
+0x9E, 0x91, 0x46, 0x7F, 0x28, 0x7E, 0x00, 0x12,
+0x72, 0x06, 0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00,
+0x90, 0x8B, 0x26, 0x12, 0x86, 0xFF, 0x0B, 0x7A,
+0x94, 0x79, 0xEA, 0x90, 0x8B, 0x29, 0x12, 0x86,
+0xFF, 0x90, 0x8B, 0x2C, 0x74, 0x08, 0xF0, 0x7A,
+0x87, 0x79, 0x84, 0x12, 0x55, 0xCC, 0xE4, 0x90,
+0x94, 0xF2, 0xF0, 0x91, 0x56, 0x50, 0x1B, 0x91,
+0x7C, 0x90, 0x94, 0xF2, 0xE0, 0x24, 0xEA, 0xF5,
+0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0xFF,
+0x90, 0x94, 0xF5, 0x91, 0x33, 0xEF, 0x91, 0x3E,
+0x80, 0xE1, 0x22, 0xE0, 0x24, 0x00, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0xF0, 0x90,
+0x94, 0xF2, 0xE0, 0x04, 0xF0, 0x22, 0xFB, 0x90,
+0x8A, 0xEC, 0x74, 0x08, 0xF0, 0x22, 0x90, 0x94,
+0xF3, 0xA3, 0xE0, 0x24, 0xF8, 0x22, 0x90, 0x94,
+0xF2, 0xE0, 0xFF, 0xC3, 0x94, 0x08, 0x22, 0x75,
+0xF0, 0x80, 0xA4, 0xAE, 0xF0, 0x78, 0x03, 0x22,
+0x9F, 0xFF, 0xE4, 0x94, 0x00, 0xFE, 0xEF, 0x78,
+0x07, 0x22, 0xFF, 0x90, 0x8A, 0xED, 0xEE, 0xF0,
+0xA3, 0xEF, 0xF0, 0x22, 0x90, 0x94, 0xF6, 0xE0,
+0xFD, 0x90, 0x94, 0xF4, 0xE0, 0x2D, 0xFD, 0x90,
+0x94, 0xF3, 0xE0, 0x34, 0x00, 0xCD, 0x24, 0x20,
+0xCD, 0x34, 0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F,
+0xFF, 0xEE, 0x3C, 0xFE, 0x90, 0x94, 0xE8, 0xE0,
+0xFD, 0x12, 0x7B, 0xAE, 0x90, 0x94, 0xF5, 0xEF,
+0xF0, 0x22, 0xF0, 0x74, 0xCC, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0x8F, 0x22, 0x4F, 0xFF, 0xF0, 0x12,
+0x02, 0xF6, 0xFE, 0x22, 0xBD, 0xA5
+};
+
+u32 array_length_mp_8188f_fw_ap = 17630;
+
+#endif /*defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP))*/
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN)) || (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+
+u8 array_mp_8188f_fw_nic[] = {
+0xF1, 0x88, 0x10, 0x00, 0x0E, 0x00, 0x00, 0x00,
+0x06, 0x07, 0x17, 0x18, 0x32, 0x4F, 0x02, 0x00,
+0x01, 0x68, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x02, 0x87, 0x7D, 0x02, 0xBC, 0x04, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xAD, 0x12, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xBF, 0xD9, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xBC, 0x05, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xBC, 0x55, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xBF, 0xD8, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x02, 0x88, 0x0B, 0x02, 0x88, 0x6E, 0x02, 0x80,
+0x86, 0x02, 0x80, 0x89, 0x02, 0xC9, 0xAD, 0x02,
+0xA2, 0x07, 0x02, 0xAF, 0xC2, 0x02, 0x80, 0x95,
+0x02, 0x80, 0x98, 0x02, 0x80, 0x9B, 0x02, 0x80,
+0x9E, 0x02, 0x80, 0xA1, 0x02, 0x80, 0xA4, 0x02,
+0x80, 0xA7, 0x02, 0x80, 0xAA, 0x02, 0x80, 0xAD,
+0x02, 0x80, 0xB0, 0x02, 0x8D, 0x7A, 0x02, 0x80,
+0xB6, 0x02, 0x80, 0xB9, 0x02, 0x80, 0xBC, 0x02,
+0x80, 0xBF, 0x02, 0x80, 0xC2, 0x02, 0x80, 0xC5,
+0x02, 0x80, 0xC8, 0x02, 0x80, 0xCB, 0x02, 0x80,
+0xCE, 0x02, 0x80, 0xD1, 0x02, 0x80, 0xD4, 0x02,
+0x80, 0xD7, 0x00, 0x00, 0x00, 0x02, 0x80, 0xDD,
+0x02, 0x80, 0xE0, 0x02, 0x80, 0xE3, 0x02, 0x80,
+0xE6, 0x02, 0x80, 0xE9, 0x02, 0x80, 0xEC, 0x02,
+0x80, 0xEF, 0x02, 0x80, 0xF2, 0x02, 0x80, 0xF5,
+0x02, 0x80, 0xF8, 0x02, 0x80, 0xFB, 0x02, 0x80,
+0xFE, 0x02, 0x81, 0x01, 0x02, 0x81, 0x04, 0x02,
+0x81, 0x07, 0x02, 0x81, 0x0A, 0x02, 0x81, 0x0D,
+0x02, 0x81, 0x10, 0x02, 0x81, 0x13, 0x02, 0x81,
+0x16, 0x02, 0x81, 0x19, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x02, 0xC0, 0x79, 0x02,
+0xA7, 0x7D, 0x02, 0x96, 0x87, 0x02, 0x98, 0xDA,
+0x02, 0x81, 0x40, 0x02, 0xA3, 0x67, 0x02, 0xCA,
+0xB7, 0x02, 0x81, 0x49, 0x02, 0x81, 0x4C, 0x02,
+0x81, 0x4F, 0x02, 0x81, 0x52, 0x02, 0x81, 0x55,
+0x02, 0x81, 0x58, 0x02, 0x81, 0x5B, 0x02, 0x99,
+0xEF, 0x02, 0x81, 0x61, 0x02, 0x81, 0x64, 0x02,
+0xCB, 0xA5, 0x02, 0xAF, 0xF6, 0x02, 0xCE, 0x21,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x15, 0xF0, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0x15,
+0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x05, 0xF0,
+0xFF, 0x0F, 0x00, 0x00, 0x00, 0x05, 0xF0, 0x0F,
+0x00, 0x00, 0x00, 0x00, 0x10, 0xF0, 0xFF, 0x0F,
+0x00, 0x00, 0x00, 0x10, 0xF0, 0x0F, 0x00, 0x00,
+0x00, 0x00, 0xF5, 0x0F, 0x00, 0x00, 0x00, 0x00,
+0x00, 0xF0, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x0D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0A,
+0x08, 0x03, 0x03, 0x00, 0x04, 0x09, 0x07, 0x03,
+0x03, 0x00, 0x04, 0x08, 0x06, 0x03, 0x02, 0x00,
+0x04, 0x08, 0x05, 0x03, 0x01, 0x00, 0x04, 0x0D,
+0x0A, 0x07, 0x05, 0x00, 0x08, 0x0C, 0x0A, 0x07,
+0x04, 0x00, 0x08, 0x0B, 0x0A, 0x06, 0x05, 0x00,
+0x08, 0x0B, 0x0A, 0x05, 0x03, 0x00, 0x08, 0x0B,
+0x0A, 0x03, 0x02, 0x00, 0x08, 0x14, 0x12, 0x0C,
+0x04, 0x00, 0x10, 0x14, 0x12, 0x09, 0x04, 0x00,
+0x10, 0x24, 0x22, 0x1C, 0x12, 0x00, 0x20, 0x24,
+0x22, 0x18, 0x0C, 0x00, 0x20, 0x24, 0x22, 0x14,
+0x06, 0x00, 0x20, 0x24, 0x22, 0x0F, 0x04, 0x00,
+0x20, 0x24, 0x21, 0x0A, 0x04, 0x00, 0x20, 0x23,
+0x21, 0x0C, 0x04, 0x00, 0x20, 0x23, 0x1F, 0x0A,
+0x04, 0x00, 0x20, 0x22, 0x1F, 0x0F, 0x04, 0x00,
+0x20, 0x21, 0x1F, 0x16, 0x0C, 0x00, 0x20, 0x31,
+0x2F, 0x20, 0x14, 0x00, 0x30, 0x31, 0x2F, 0x18,
+0x10, 0x00, 0x30, 0x31, 0x2C, 0x18, 0x0C, 0x00,
+0x30, 0x31, 0x2A, 0x14, 0x0C, 0x00, 0x30, 0x31,
+0x28, 0x14, 0x00, 0x00, 0x30, 0x31, 0x24, 0x14,
+0x00, 0x00, 0x30, 0x31, 0x1E, 0x14, 0x00, 0x00,
+0x30, 0x02, 0x02, 0x03, 0x04, 0x04, 0x08, 0x09,
+0x09, 0x0C, 0x0E, 0x10, 0x12, 0x02, 0x09, 0x0B,
+0x0E, 0x0D, 0x0F, 0x10, 0x12, 0x00, 0x04, 0x00,
+0x04, 0x00, 0x08, 0x00, 0x10, 0x00, 0x23, 0x00,
+0x2D, 0x00, 0x50, 0x00, 0x91, 0x00, 0xC3, 0x01,
+0x27, 0x01, 0x31, 0x01, 0x5E, 0x00, 0x8C, 0x00,
+0xC8, 0x00, 0xDC, 0x01, 0x5E, 0x01, 0x68, 0x01,
+0x9A, 0x01, 0xCC, 0x01, 0xEA, 0x02, 0x02, 0x04,
+0x08, 0x0C, 0x12, 0x18, 0x24, 0x30, 0x48, 0x60,
+0x6C, 0x14, 0x28, 0x32, 0x50, 0x78, 0xA0, 0xC8,
+0xE6, 0x01, 0x01, 0x01, 0x02, 0x01, 0x01, 0x02,
+0x02, 0x03, 0x03, 0x04, 0x04, 0x02, 0x04, 0x06,
+0x07, 0x07, 0x08, 0x08, 0x08, 0x01, 0x01, 0x01,
+0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
+0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x02,
+0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02,
+0x02, 0x03, 0x03, 0x04, 0x05, 0x01, 0x02, 0x03,
+0x04, 0x05, 0x06, 0x07, 0x08, 0x03, 0x03, 0x03,
+0x02, 0x03, 0x03, 0x03, 0x03, 0x03, 0x02, 0x02,
+0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02,
+0x02, 0x19, 0x06, 0x04, 0x02, 0x00, 0x18, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xC2, 0xAF, 0x80, 0xFE, 0x32, 0x12, 0x84, 0x04,
+0x85, 0xD0, 0x0B, 0x75, 0xD0, 0x08, 0xAA, 0xE0,
+0xC2, 0x8C, 0xE5, 0x8A, 0x24, 0x67, 0xF5, 0x8A,
+0xE5, 0x8C, 0x34, 0x79, 0xF5, 0x8C, 0xD2, 0x8C,
+0xEC, 0x24, 0x87, 0xF8, 0xE6, 0xBC, 0x02, 0x02,
+0x74, 0xFF, 0xC3, 0x95, 0x81, 0xB4, 0x40, 0x00,
+0x40, 0xCE, 0x79, 0x03, 0x78, 0x80, 0x16, 0xE6,
+0x08, 0x70, 0x0B, 0xC2, 0xAF, 0xE6, 0x30, 0xE1,
+0x03, 0x44, 0x18, 0xF6, 0xD2, 0xAF, 0x08, 0xD9,
+0xED, 0xEA, 0x8B, 0xD0, 0x22, 0xE5, 0x0C, 0xFF,
+0x23, 0x24, 0x81, 0xF8, 0x0F, 0x08, 0x08, 0xBF,
+0x03, 0x04, 0x7F, 0x00, 0x78, 0x81, 0xE6, 0x30,
+0xE4, 0xF2, 0x00, 0xE5, 0x0C, 0xC3, 0x9F, 0x50,
+0x20, 0x05, 0x0C, 0x74, 0x86, 0x25, 0x0C, 0xF8,
+0xE6, 0xFD, 0xA6, 0x81, 0x08, 0xE6, 0xAE, 0x0C,
+0xBE, 0x02, 0x02, 0x74, 0xFF, 0xCD, 0xF8, 0xE8,
+0x6D, 0x60, 0xE0, 0x08, 0xE6, 0xC0, 0xE0, 0x80,
+0xF6, 0xE5, 0x0C, 0xD3, 0x9F, 0x40, 0x27, 0xE5,
+0x0C, 0x24, 0x87, 0xF8, 0xE6, 0xAE, 0x0C, 0xBE,
+0x02, 0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xCD,
+0xF8, 0xE5, 0x81, 0x6D, 0x60, 0x06, 0xD0, 0xE0,
+0xF6, 0x18, 0x80, 0xF5, 0xE5, 0x0C, 0x24, 0x86,
+0xC8, 0xF6, 0x15, 0x0C, 0x80, 0xD3, 0xE5, 0x0C,
+0x23, 0x24, 0x81, 0xF8, 0x7F, 0x04, 0xC2, 0xAF,
+0xE6, 0x30, 0xE0, 0x03, 0x10, 0xE2, 0x0C, 0x7F,
+0x00, 0x30, 0xE1, 0x07, 0x30, 0xE3, 0x04, 0x7F,
+0x08, 0x54, 0xF4, 0x54, 0x7C, 0xC6, 0xD2, 0xAF,
+0x54, 0x80, 0x42, 0x07, 0x22, 0x78, 0x86, 0xA6,
+0x81, 0x74, 0x02, 0x60, 0x06, 0xFF, 0x08, 0x76,
+0xFF, 0xDF, 0xFB, 0x7F, 0x03, 0xE4, 0x78, 0x80,
+0xF6, 0x08, 0xF6, 0x08, 0xDF, 0xFA, 0x78, 0x81,
+0x76, 0x30, 0x90, 0x88, 0x00, 0x74, 0x01, 0x93,
+0xC0, 0xE0, 0xE4, 0x93, 0xC0, 0xE0, 0x43, 0x89,
+0x01, 0x75, 0x8A, 0x60, 0x75, 0x8C, 0x79, 0xD2,
+0x8C, 0xD2, 0xAF, 0x22, 0x02, 0xEF, 0xD3, 0x94,
+0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0x74, 0x81,
+0x2F, 0x2F, 0xF8, 0xE6, 0x20, 0xE5, 0xF4, 0xC2,
+0xAF, 0xE6, 0x44, 0x30, 0xF6, 0xD2, 0xAF, 0xAE,
+0x0C, 0xEE, 0xC3, 0x9F, 0x50, 0x21, 0x0E, 0x74,
+0x86, 0x2E, 0xF8, 0xE6, 0xF9, 0x08, 0xE6, 0x18,
+0xBE, 0x02, 0x02, 0x74, 0xFF, 0xFD, 0xED, 0x69,
+0x60, 0x09, 0x09, 0xE7, 0x19, 0x19, 0xF7, 0x09,
+0x09, 0x80, 0xF3, 0x16, 0x16, 0x80, 0xDA, 0xEE,
+0xD3, 0x9F, 0x40, 0x04, 0x05, 0x81, 0x05, 0x81,
+0xEE, 0xD3, 0x9F, 0x40, 0x22, 0x74, 0x86, 0x2E,
+0xF8, 0x08, 0xE6, 0xF9, 0xEE, 0xB5, 0x0C, 0x02,
+0xA9, 0x81, 0x18, 0x06, 0x06, 0xE6, 0xFD, 0xED,
+0x69, 0x60, 0x09, 0x19, 0x19, 0xE7, 0x09, 0x09,
+0xF7, 0x19, 0x80, 0xF3, 0x1E, 0x80, 0xD9, 0xEF,
+0x24, 0x86, 0xF8, 0xE6, 0x04, 0xF8, 0xEF, 0x2F,
+0x04, 0x90, 0x88, 0x00, 0x93, 0xF6, 0x08, 0xEF,
+0x2F, 0x93, 0xF6, 0x7F, 0x00, 0x22, 0xEF, 0xD3,
+0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0xEF,
+0x23, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE5, 0xF4,
+0xC2, 0xAF, 0xE6, 0x54, 0x8C, 0xF6, 0xD2, 0xAF,
+0xE5, 0x0C, 0xB5, 0x07, 0x0A, 0x74, 0x86, 0x2F,
+0xF8, 0xE6, 0xF5, 0x81, 0x02, 0x84, 0x4D, 0x50,
+0x2E, 0x74, 0x87, 0x2F, 0xF8, 0xE6, 0xBF, 0x02,
+0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xF9, 0x74,
+0x86, 0x2F, 0xF8, 0xFB, 0xE6, 0xFC, 0xE9, 0x6C,
+0x60, 0x08, 0xA8, 0x05, 0xE7, 0xF6, 0x1D, 0x19,
+0x80, 0xF4, 0xA8, 0x03, 0xA6, 0x05, 0x1F, 0xE5,
+0x0C, 0xB5, 0x07, 0xE3, 0x7F, 0x00, 0x22, 0x74,
+0x87, 0x2F, 0xF8, 0xE6, 0xFD, 0x18, 0x86, 0x01,
+0x0F, 0x74, 0x86, 0x2F, 0xF8, 0xA6, 0x01, 0x08,
+0x86, 0x04, 0xE5, 0x0C, 0xB5, 0x07, 0x02, 0xAC,
+0x81, 0xED, 0x6C, 0x60, 0x08, 0x0D, 0x09, 0xA8,
+0x05, 0xE6, 0xF7, 0x80, 0xF4, 0xE5, 0x0C, 0xB5,
+0x07, 0xDE, 0x89, 0x81, 0x7F, 0x00, 0x22, 0xEF,
+0xD3, 0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22,
+0xEF, 0x23, 0x24, 0x81, 0xF8, 0xC2, 0xAF, 0xE6,
+0x30, 0xE5, 0x05, 0x30, 0xE0, 0x02, 0xD2, 0xE4,
+0xD2, 0xE2, 0xC6, 0xD2, 0xAF, 0x7F, 0x00, 0x30,
+0xE2, 0x01, 0x0F, 0x02, 0x84, 0x4C, 0x8F, 0xF0,
+0xE4, 0xFF, 0xFE, 0xE5, 0x0C, 0x23, 0x24, 0x80,
+0xF8, 0xC2, 0xA9, 0x30, 0xF7, 0x0D, 0x7F, 0x08,
+0xE6, 0x60, 0x0B, 0x2D, 0xF6, 0x60, 0x30, 0x50,
+0x2E, 0x80, 0x07, 0x30, 0xF1, 0x06, 0xED, 0xF6,
+0x60, 0x25, 0x7E, 0x02, 0x08, 0x30, 0xF0, 0x10,
+0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x23, 0x0E, 0x30,
+0xE2, 0x0C, 0xD2, 0xAF, 0x7F, 0x04, 0x80, 0x12,
+0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x13, 0x54, 0xEC,
+0x4E, 0xF6, 0xD2, 0xAF, 0x02, 0x84, 0x4D, 0x7F,
+0x08, 0x08, 0xEF, 0x44, 0x83, 0xF4, 0xC2, 0xAF,
+0x56, 0xC6, 0xD2, 0xAF, 0x54, 0x80, 0x4F, 0xFF,
+0x22, 0xEF, 0x2B, 0xFF, 0xEE, 0x3A, 0xFE, 0xED,
+0x39, 0xFD, 0xEC, 0x38, 0xFC, 0x22, 0xC3, 0xEF,
+0x9B, 0xFF, 0xEE, 0x9A, 0xFE, 0xED, 0x99, 0xFD,
+0xEC, 0x98, 0xFC, 0x22, 0xE8, 0x8F, 0xF0, 0xA4,
+0xCC, 0x8B, 0xF0, 0xA4, 0x2C, 0xFC, 0xE9, 0x8E,
+0xF0, 0xA4, 0x2C, 0xFC, 0x8A, 0xF0, 0xED, 0xA4,
+0x2C, 0xFC, 0xEA, 0x8E, 0xF0, 0xA4, 0xCD, 0xA8,
+0xF0, 0x8B, 0xF0, 0xA4, 0x2D, 0xCC, 0x38, 0x25,
+0xF0, 0xFD, 0xE9, 0x8F, 0xF0, 0xA4, 0x2C, 0xCD,
+0x35, 0xF0, 0xFC, 0xEB, 0x8E, 0xF0, 0xA4, 0xFE,
+0xA9, 0xF0, 0xEB, 0x8F, 0xF0, 0xA4, 0xCF, 0xC5,
+0xF0, 0x2E, 0xCD, 0x39, 0xFE, 0xE4, 0x3C, 0xFC,
+0xEA, 0xA4, 0x2D, 0xCE, 0x35, 0xF0, 0xFD, 0xE4,
+0x3C, 0xFC, 0x22, 0xEF, 0x5B, 0xFF, 0xEE, 0x5A,
+0xFE, 0xED, 0x59, 0xFD, 0xEC, 0x58, 0xFC, 0x22,
+0xEF, 0x4B, 0xFF, 0xEE, 0x4A, 0xFE, 0xED, 0x49,
+0xFD, 0xEC, 0x48, 0xFC, 0x22, 0xE0, 0xFC, 0xA3,
+0xE0, 0xFD, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0x22, 0xE0, 0xF8, 0xA3, 0xE0, 0xF9, 0xA3, 0xE0,
+0xFA, 0xA3, 0xE0, 0xFB, 0x22, 0xE0, 0xFB, 0xA3,
+0xE0, 0xFA, 0xA3, 0xE0, 0xF9, 0x22, 0xEB, 0xF0,
+0xA3, 0xEA, 0xF0, 0xA3, 0xE9, 0xF0, 0x22, 0xD0,
+0x83, 0xD0, 0x82, 0xF8, 0xE4, 0x93, 0x70, 0x12,
+0x74, 0x01, 0x93, 0x70, 0x0D, 0xA3, 0xA3, 0x93,
+0xF8, 0x74, 0x01, 0x93, 0xF5, 0x82, 0x88, 0x83,
+0xE4, 0x73, 0x74, 0x02, 0x93, 0x68, 0x60, 0xEF,
+0xA3, 0xA3, 0xA3, 0x80, 0xDF, 0x02, 0x87, 0xBB,
+0x02, 0x84, 0xDD, 0xE4, 0x93, 0xA3, 0xF8, 0xE4,
+0x93, 0xA3, 0x40, 0x03, 0xF6, 0x80, 0x01, 0xF2,
+0x08, 0xDF, 0xF4, 0x80, 0x29, 0xE4, 0x93, 0xA3,
+0xF8, 0x54, 0x07, 0x24, 0x0C, 0xC8, 0xC3, 0x33,
+0xC4, 0x54, 0x0F, 0x44, 0x20, 0xC8, 0x83, 0x40,
+0x04, 0xF4, 0x56, 0x80, 0x01, 0x46, 0xF6, 0xDF,
+0xE4, 0x80, 0x0B, 0x01, 0x02, 0x04, 0x08, 0x10,
+0x20, 0x40, 0x80, 0x90, 0x88, 0x06, 0xE4, 0x7E,
+0x01, 0x93, 0x60, 0xBC, 0xA3, 0xFF, 0x54, 0x3F,
+0x30, 0xE5, 0x09, 0x54, 0x1F, 0xFE, 0xE4, 0x93,
+0xA3, 0x60, 0x01, 0x0E, 0xCF, 0x54, 0xC0, 0x25,
+0xE0, 0x60, 0xA8, 0x40, 0xB8, 0xE4, 0x93, 0xA3,
+0xFA, 0xE4, 0x93, 0xA3, 0xF8, 0xE4, 0x93, 0xA3,
+0xC8, 0xC5, 0x82, 0xC8, 0xCA, 0xC5, 0x83, 0xCA,
+0xF0, 0xA3, 0xC8, 0xC5, 0x82, 0xC8, 0xCA, 0xC5,
+0x83, 0xCA, 0xDF, 0xE9, 0xDE, 0xE7, 0x80, 0xBE,
+0xB4, 0x8D, 0xB9, 0xB7, 0xBB, 0xAF, 0x41, 0x95,
+0x4C, 0x00, 0x00, 0x90, 0x95, 0x4A, 0xEF, 0xF0,
+0x7F, 0x02, 0x12, 0x86, 0x27, 0x90, 0x84, 0xC1,
+0xE0, 0xFF, 0x90, 0x95, 0x4A, 0xE0, 0xFE, 0xEF,
+0x4E, 0x90, 0x84, 0xC1, 0xF0, 0x22, 0xF1, 0x9E,
+0x12, 0x02, 0xF6, 0xFF, 0xF1, 0x98, 0xFE, 0x54,
+0x03, 0xFD, 0xEE, 0x13, 0x13, 0x54, 0x07, 0xFB,
+0xC0, 0x03, 0xB1, 0x74, 0xD1, 0xCF, 0x12, 0x97,
+0xAA, 0xD0, 0x03, 0x12, 0xC9, 0xAD, 0xB1, 0x74,
+0xF1, 0x98, 0x31, 0x58, 0x90, 0x93, 0xF8, 0x74,
+0x10, 0xF0, 0x90, 0x94, 0x06, 0x74, 0x07, 0xF0,
+0xB1, 0x74, 0x12, 0x02, 0xF6, 0x90, 0x93, 0xFA,
+0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xF8, 0x12,
+0x5E, 0x10, 0x7F, 0x04, 0x80, 0x9D, 0x90, 0x93,
+0xF2, 0x12, 0x87, 0x4E, 0x90, 0x93, 0xF1, 0xEF,
+0xF0, 0x12, 0x87, 0x57, 0x88, 0xC8, 0x00, 0x88,
+0xCD, 0x01, 0x88, 0xD2, 0x06, 0x88, 0xE3, 0x10,
+0x88, 0xE8, 0x11, 0x88, 0xED, 0x12, 0x88, 0xF2,
+0x14, 0x88, 0xF7, 0x16, 0x88, 0xFB, 0x18, 0x89,
+0x00, 0x19, 0x89, 0x05, 0x1C, 0x89, 0x09, 0x20,
+0x89, 0x0D, 0x24, 0x89, 0x12, 0x25, 0x89, 0x17,
+0x27, 0x89, 0x1C, 0x40, 0x89, 0x20, 0x42, 0x89,
+0x25, 0x43, 0x89, 0x43, 0x47, 0x89, 0x2A, 0x49,
+0x89, 0x2F, 0xC3, 0x88, 0xD7, 0xC6, 0x88, 0xD7,
+0xC7, 0x88, 0xD7, 0xC8, 0x00, 0x00, 0x89, 0x34,
+0x31, 0x44, 0x02, 0x90, 0x00, 0x31, 0x44, 0x02,
+0x97, 0xFE, 0x31, 0x44, 0x02, 0xB7, 0xDD, 0x90,
+0x93, 0xF1, 0xE0, 0xFF, 0xA3, 0x12, 0x87, 0x45,
+0x02, 0xB8, 0x7F, 0x31, 0x44, 0x02, 0x9F, 0xF6,
+0x31, 0x44, 0x02, 0x90, 0x47, 0x31, 0x44, 0x02,
+0xB0, 0x26, 0x31, 0x44, 0x02, 0xB1, 0x00, 0x31,
+0x44, 0xE1, 0xC8, 0x31, 0x44, 0x02, 0xA0, 0x31,
+0x31, 0x44, 0x02, 0xA7, 0xF5, 0x31, 0x44, 0x01,
+0x26, 0x31, 0x44, 0xC1, 0xD5, 0x31, 0x44, 0x02,
+0xA3, 0xC4, 0x31, 0x44, 0x02, 0xB1, 0x0F, 0x31,
+0x44, 0x02, 0xA8, 0x9C, 0x31, 0x44, 0xA1, 0x7A,
+0x31, 0x44, 0x02, 0x4E, 0x29, 0x31, 0x44, 0x02,
+0x28, 0xE6, 0x31, 0x44, 0x02, 0xC1, 0x48, 0x31,
+0x44, 0x02, 0xB1, 0x17, 0x90, 0x01, 0xC0, 0xE0,
+0x44, 0x01, 0xF0, 0x90, 0x93, 0xF1, 0xE0, 0x90,
+0x01, 0xC2, 0xF0, 0x22, 0x90, 0x93, 0xF2, 0x02,
+0x87, 0x45, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x38,
+0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0,
+0xFE, 0x54, 0x03, 0xFF, 0xEE, 0x13, 0x13, 0x54,
+0x07, 0xFD, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x95, 0x48, 0xED, 0xF0, 0xE4, 0xA3,
+0xF0, 0xEF, 0x14, 0x60, 0x02, 0x41, 0x40, 0x90,
+0x06, 0x03, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x95,
+0x48, 0xE0, 0xFB, 0xC4, 0x33, 0x54, 0xE0, 0xFE,
+0x90, 0x04, 0x42, 0xE0, 0x54, 0x9F, 0x4E, 0xFE,
+0xF0, 0xE4, 0xFD, 0x12, 0xCA, 0x2E, 0x90, 0x95,
+0x49, 0xEF, 0xF0, 0x90, 0x04, 0x83, 0xF0, 0x90,
+0x94, 0xF4, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
+0x01, 0x90, 0x94, 0xF8, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x00, 0x01, 0x71, 0x0C, 0x12, 0x04, 0xF7,
+0x00, 0x00, 0x00, 0x01, 0x90, 0x94, 0xF8, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x00, 0x01, 0x7F, 0x00,
+0x7E, 0x09, 0x71, 0x10, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x00, 0x10, 0x71, 0x16, 0xEF, 0x54, 0x03,
+0xFF, 0xE4, 0x78, 0x01, 0x12, 0x04, 0xC5, 0x78,
+0x04, 0xF1, 0xAA, 0x7F, 0x00, 0x7E, 0x0A, 0x71,
+0x10, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00,
+0x71, 0x16, 0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78,
+0x0A, 0xF1, 0xAA, 0x7F, 0x00, 0x7E, 0x0D, 0x71,
+0x10, 0x12, 0x04, 0xF7, 0x0C, 0x00, 0x00, 0x00,
+0x90, 0x95, 0x49, 0x71, 0x19, 0xEF, 0x54, 0x03,
+0xFF, 0xE4, 0x78, 0x1A, 0xF1, 0xAA, 0x7F, 0x18,
+0x71, 0x0E, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C,
+0x00, 0x90, 0x94, 0xF8, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x00, 0x00, 0xF1, 0xBE, 0x12, 0x04, 0xF7,
+0x00, 0x00, 0x0C, 0x00, 0x90, 0x94, 0xE6, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x04, 0x00, 0x80, 0x58,
+0x90, 0x06, 0x03, 0xE0, 0x44, 0x04, 0xF0, 0x90,
+0x94, 0xF4, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
+0x01, 0x90, 0x94, 0xF8, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x00, 0x00, 0x71, 0x0C, 0x12, 0x04, 0xF7,
+0x00, 0x00, 0x00, 0x01, 0x90, 0x94, 0xF8, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x00,
+0x7E, 0x09, 0x71, 0x10, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x0C, 0x00, 0x90, 0x94, 0xF8, 0x12, 0x04,
+0xF7, 0x00, 0x00, 0x0C, 0x00, 0xF1, 0xBE, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x94,
+0xE6, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00,
+0x7D, 0x18, 0x7C, 0x00, 0xE4, 0xFF, 0x12, 0xC9,
+0x35, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xF2,
+0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x70, 0x61,
+0x90, 0x94, 0xFC, 0x12, 0x04, 0xEB, 0x90, 0x94,
+0xF4, 0x12, 0x87, 0x2D, 0x12, 0x04, 0xA7, 0x90,
+0x94, 0xFC, 0xF1, 0xA4, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x94, 0xF4, 0x12,
+0x87, 0x2D, 0x90, 0x94, 0xF8, 0xF1, 0xA4, 0xD0,
+0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
+0x87, 0x20, 0x90, 0x95, 0x00, 0x12, 0x04, 0xEB,
+0x90, 0x95, 0x00, 0x12, 0x87, 0x2D, 0x90, 0x91,
+0x66, 0x12, 0x04, 0xEB, 0x90, 0x94, 0xF2, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x12, 0x71, 0x18, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x7F, 0x00, 0x7E, 0x08,
+0x51, 0xA6, 0x90, 0x94, 0xF4, 0x22, 0x90, 0x95,
+0x48, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0x22,
+0x90, 0x92, 0x0A, 0xE0, 0x20, 0xE0, 0x02, 0xA1,
+0x5D, 0xC3, 0x13, 0x54, 0x07, 0x60, 0x02, 0xA1,
+0x5D, 0x90, 0x92, 0xB5, 0xE0, 0x30, 0xE0, 0x5C,
+0x12, 0xBE, 0xF1, 0x40, 0x57, 0x90, 0x92, 0xBC,
+0xE0, 0x30, 0xE0, 0x23, 0x54, 0xFE, 0xF0, 0x90,
+0x92, 0xBE, 0xE0, 0x90, 0x92, 0xB2, 0xF0, 0x90,
+0x92, 0xC1, 0xE0, 0x90, 0x92, 0xB3, 0xF0, 0x90,
+0x92, 0xBF, 0xE0, 0x90, 0x92, 0x39, 0xF0, 0x90,
+0x92, 0xC0, 0xE0, 0x90, 0x92, 0x54, 0xF0, 0x90,
+0x05, 0x58, 0xE0, 0x90, 0x94, 0x61, 0x12, 0x93,
+0x35, 0x12, 0x97, 0xD7, 0x54, 0x07, 0xFF, 0x64,
+0x02, 0x60, 0x03, 0xEF, 0x70, 0x0B, 0x12, 0xCE,
+0xB3, 0x24, 0xFD, 0x90, 0x91, 0x6F, 0x12, 0xA1,
+0x7B, 0x12, 0xCE, 0xB3, 0x12, 0xBE, 0xD3, 0xE4,
+0x90, 0x92, 0xB6, 0xF0, 0x90, 0x92, 0xB1, 0xE0,
+0x20, 0xE0, 0x02, 0xA1, 0x5D, 0x90, 0x92, 0xB5,
+0xE0, 0xFF, 0xC3, 0x13, 0xFE, 0x54, 0x1F, 0x70,
+0x02, 0xA1, 0x5D, 0xEF, 0x54, 0xC1, 0xFF, 0xEE,
+0x14, 0x54, 0x1F, 0xFE, 0x25, 0xE0, 0x4F, 0xF0,
+0xE0, 0xC3, 0x13, 0x54, 0x1F, 0x60, 0x02, 0xA1,
+0x5D, 0x90, 0x92, 0xBD, 0xE0, 0x30, 0xE0, 0x17,
+0x54, 0xFE, 0xF0, 0x90, 0x92, 0xBC, 0xE0, 0x44,
+0x01, 0xF0, 0xA3, 0xE0, 0x54, 0xFE, 0xFF, 0x90,
+0x92, 0xB1, 0xE0, 0x54, 0x01, 0x4F, 0xF0, 0x90,
+0x05, 0x22, 0xE0, 0x44, 0x40, 0xFD, 0x7B, 0x58,
+0x7F, 0x40, 0x12, 0x94, 0x99, 0x90, 0x05, 0x50,
+0xE0, 0x54, 0xF7, 0xF0, 0x90, 0x05, 0x69, 0x71,
+0x19, 0x12, 0xCE, 0xA5, 0x90, 0x05, 0x68, 0x71,
+0x19, 0x12, 0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05, 0x6A, 0x71,
+0x19, 0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03,
+0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87,
+0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0xA3, 0x71, 0x19, 0x78, 0x18, 0x12, 0x04,
+0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x87, 0x20, 0x90, 0x94, 0x55, 0x12,
+0x04, 0xEB, 0xB1, 0x60, 0x90, 0x94, 0x5D, 0x12,
+0x04, 0xEB, 0x90, 0x05, 0x6D, 0x71, 0x19, 0x12,
+0xCE, 0xA5, 0x90, 0x05, 0x6C, 0x71, 0x19, 0x12,
+0x87, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x05, 0x6E, 0x71, 0x19, 0x78,
+0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x87, 0x20, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3,
+0x71, 0x19, 0x78, 0x18, 0x12, 0x04, 0xD8, 0xD0,
+0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
+0x87, 0x20, 0x90, 0x94, 0x59, 0x12, 0x04, 0xEB,
+0x90, 0x94, 0x55, 0x12, 0x87, 0x39, 0xC0, 0x00,
+0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0x90, 0x92,
+0xB1, 0xE0, 0xC3, 0x13, 0x54, 0x7F, 0xFF, 0xE4,
+0xFC, 0xFD, 0xFE, 0xFB, 0x7A, 0x04, 0xF9, 0xF8,
+0x12, 0x86, 0xC4, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0x12, 0x86, 0xA9, 0x90, 0x94,
+0x55, 0x12, 0x04, 0xEB, 0x90, 0x94, 0x5D, 0x12,
+0x87, 0x2D, 0x90, 0x94, 0x55, 0x12, 0xCE, 0x12,
+0x50, 0x15, 0xB1, 0x68, 0xEF, 0x24, 0x01, 0xFF,
+0xE4, 0x3E, 0xFE, 0xE4, 0x3D, 0xFD, 0xE4, 0x3C,
+0xFC, 0x90, 0x94, 0x59, 0x12, 0x04, 0xEB, 0xB1,
+0x68, 0x78, 0x18, 0x12, 0x04, 0xC5, 0x90, 0x05,
+0x67, 0xB1, 0x66, 0x78, 0x10, 0x12, 0x04, 0xC5,
+0x90, 0x05, 0x66, 0xB1, 0x66, 0x78, 0x08, 0x12,
+0x04, 0xC5, 0x90, 0x05, 0x65, 0xB1, 0x66, 0x90,
+0x05, 0x64, 0xB1, 0x5E, 0x78, 0x18, 0x12, 0x04,
+0xC5, 0x90, 0x05, 0x63, 0xB1, 0x5E, 0x78, 0x10,
+0x12, 0x04, 0xC5, 0x90, 0x05, 0x62, 0xB1, 0x5E,
+0x78, 0x08, 0x12, 0x04, 0xC5, 0x90, 0x05, 0x61,
+0xB1, 0x5E, 0x90, 0x05, 0x60, 0xEF, 0xF0, 0x90,
+0x05, 0x50, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x05,
+0x22, 0xE0, 0x54, 0xBF, 0xFD, 0x7B, 0x59, 0x7F,
+0x40, 0x12, 0x94, 0x99, 0x7F, 0x08, 0x12, 0xC8,
+0x4A, 0x90, 0x92, 0xB5, 0xE0, 0x54, 0xC1, 0x44,
+0x28, 0xF0, 0x44, 0x01, 0xF0, 0x22, 0xEF, 0xF0,
+0x90, 0x94, 0x55, 0x02, 0x87, 0x2D, 0xEF, 0xF0,
+0x90, 0x94, 0x59, 0x02, 0x87, 0x2D, 0x24, 0x03,
+0xFF, 0xE4, 0x33, 0xFE, 0x90, 0x93, 0xF5, 0x02,
+0x87, 0x45, 0xF1, 0x9E, 0xB1, 0x74, 0x12, 0x02,
+0xF6, 0x54, 0x7F, 0xFD, 0xF1, 0x98, 0xFE, 0x54,
+0x1F, 0x90, 0x93, 0xF9, 0xF1, 0xB3, 0x90, 0x93,
+0xF8, 0xD1, 0xCE, 0xFE, 0x54, 0x03, 0xFC, 0xEE,
+0x54, 0x30, 0xC4, 0x54, 0x0F, 0x90, 0x93, 0xFB,
+0xD1, 0xCE, 0xFE, 0x54, 0x40, 0xC4, 0x13, 0x13,
+0x54, 0x03, 0x90, 0x93, 0xFA, 0xF1, 0xB3, 0xFF,
+0xD1, 0xCF, 0xFB, 0x54, 0x08, 0x13, 0x13, 0x13,
+0x54, 0x1F, 0x90, 0x93, 0xFD, 0xF0, 0xFA, 0xEB,
+0x54, 0x04, 0x13, 0x13, 0x54, 0x3F, 0xA3, 0xF0,
+0xEF, 0x54, 0x01, 0xC4, 0x33, 0x33, 0x33, 0x54,
+0x80, 0xD1, 0xC0, 0x54, 0x7F, 0x4F, 0xF0, 0x90,
+0x93, 0xFA, 0xE0, 0x54, 0x01, 0xC4, 0x33, 0x33,
+0x54, 0xC0, 0xD1, 0xC0, 0x54, 0xBF, 0x4F, 0xF0,
+0xEA, 0x70, 0x0D, 0xEC, 0x54, 0x03, 0x25, 0xE0,
+0x25, 0xE0, 0xD1, 0xC0, 0x54, 0xF3, 0x4F, 0xF0,
+0x90, 0x93, 0xF9, 0xE0, 0x54, 0x1F, 0x12, 0x9C,
+0xFC, 0x54, 0xE0, 0x4F, 0xF0, 0xEC, 0x54, 0x03,
+0xD1, 0xC0, 0x54, 0xFC, 0x4F, 0xF0, 0x90, 0x93,
+0xF8, 0xE0, 0x54, 0x01, 0xC4, 0x33, 0x54, 0xE0,
+0x12, 0x9C, 0xFC, 0x54, 0xDF, 0x4F, 0xF0, 0x90,
+0x93, 0xFB, 0xE0, 0x54, 0x03, 0xC4, 0x54, 0xF0,
+0xD1, 0xC0, 0x54, 0xCF, 0x4F, 0x12, 0xCE, 0xE1,
+0xE0, 0x54, 0xFB, 0x12, 0xCE, 0xE1, 0xC0, 0x83,
+0xC0, 0x82, 0xE0, 0xFF, 0x90, 0x93, 0xFE, 0xE0,
+0x12, 0xB7, 0xAE, 0xD0, 0x82, 0xD0, 0x83, 0xF0,
+0x90, 0x92, 0xC9, 0xE0, 0x60, 0x2F, 0xB1, 0x74,
+0xE9, 0x24, 0x03, 0xF1, 0xF9, 0x54, 0x1F, 0x12,
+0x03, 0x3C, 0x90, 0x93, 0xFC, 0x74, 0x01, 0xF0,
+0x90, 0x93, 0xFC, 0xE0, 0xFF, 0xC3, 0x94, 0x04,
+0x50, 0x13, 0xEF, 0xB1, 0x6E, 0x8F, 0x82, 0x8E,
+0x83, 0xE4, 0x12, 0x03, 0x4E, 0x90, 0x93, 0xFC,
+0xE0, 0x04, 0xF0, 0x80, 0xE3, 0x90, 0x92, 0xC7,
+0xE0, 0x54, 0x07, 0xFF, 0xBF, 0x05, 0x0A, 0xEC,
+0xB4, 0x01, 0x06, 0x90, 0x92, 0xCC, 0x74, 0x01,
+0xF0, 0xE4, 0x90, 0x93, 0xFC, 0xF0, 0x90, 0x93,
+0xFC, 0xE0, 0xFC, 0xB1, 0x6E, 0x8F, 0x82, 0x8E,
+0x83, 0x12, 0x03, 0x0F, 0xFF, 0xED, 0x12, 0xC8,
+0x3C, 0xE5, 0x82, 0x2C, 0x12, 0xCE, 0xD9, 0xEF,
+0xF0, 0x90, 0x93, 0xFC, 0xE0, 0x04, 0xF0, 0xE0,
+0xB4, 0x04, 0xDB, 0xAF, 0x05, 0x02, 0x17, 0x8E,
+0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90, 0x89, 0x3F,
+0x12, 0x05, 0x28, 0xE0, 0x22, 0x4F, 0xF0, 0x90,
+0x00, 0x02, 0x02, 0x03, 0x0F, 0xF1, 0x9E, 0x12,
+0x02, 0xF6, 0xFF, 0x54, 0x7F, 0x90, 0x85, 0xC5,
+0xF0, 0xEF, 0xF1, 0xB7, 0xA3, 0xF1, 0x97, 0xFD,
+0x54, 0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x85,
+0xC3, 0xE0, 0x54, 0xF0, 0x4F, 0xF0, 0x12, 0x90,
+0x41, 0xFC, 0x54, 0x01, 0x25, 0xE0, 0xFF, 0x90,
+0x85, 0xC1, 0xE0, 0x54, 0xFD, 0x4F, 0xF0, 0xEC,
+0x54, 0x04, 0xFF, 0x90, 0x92, 0xCF, 0xE0, 0x54,
+0xFB, 0x4F, 0xF0, 0xED, 0x54, 0x0F, 0xC4, 0x54,
+0xF0, 0xFF, 0x12, 0xAB, 0x94, 0xD1, 0xCD, 0x90,
+0x85, 0xC4, 0xF0, 0xF1, 0xF3, 0x30, 0xE0, 0x4D,
+0xC3, 0x13, 0x54, 0x07, 0xFF, 0xC3, 0x94, 0x04,
+0x90, 0x85, 0xD8, 0x50, 0x04, 0xEF, 0xF0, 0x80,
+0x25, 0x74, 0x03, 0xF0, 0xB1, 0x74, 0xE9, 0x24,
+0x06, 0xF1, 0xF9, 0xFF, 0x74, 0x03, 0x24, 0xFD,
+0xFE, 0xEF, 0xC4, 0x54, 0x0F, 0xFD, 0xEF, 0x54,
+0x0F, 0xFF, 0xED, 0x2E, 0x54, 0x0F, 0xFE, 0xC4,
+0x54, 0xF0, 0x4F, 0x12, 0x03, 0x3C, 0xB1, 0x74,
+0xF1, 0xF3, 0xC4, 0x54, 0x0F, 0xFF, 0xC3, 0x94,
+0x04, 0x90, 0x85, 0xCD, 0x50, 0x05, 0x74, 0x04,
+0xF0, 0x80, 0x02, 0xEF, 0xF0, 0xB1, 0x74, 0xF1,
+0xED, 0xFD, 0x7F, 0x02, 0x12, 0x57, 0x82, 0xB1,
+0x74, 0x12, 0x71, 0xCB, 0x12, 0xBE, 0xC9, 0xF0,
+0x90, 0x85, 0xC5, 0x12, 0xCE, 0xCC, 0x12, 0xAB,
+0x93, 0x90, 0x01, 0xBE, 0xF0, 0x22, 0x4F, 0xF0,
+0x90, 0x00, 0x01, 0x02, 0x03, 0x0F, 0x90, 0x93,
+0xF5, 0x02, 0x87, 0x4E, 0x12, 0x87, 0x39, 0x02,
+0x87, 0x13, 0x12, 0x04, 0xD8, 0x90, 0x94, 0xF8,
+0x02, 0x04, 0xEB, 0xF0, 0xEE, 0x54, 0x80, 0xC4,
+0x13, 0x13, 0x13, 0x54, 0x01, 0x22, 0x7F, 0x84,
+0x7E, 0x08, 0x51, 0xA6, 0x90, 0x94, 0xE2, 0x22,
+0x12, 0xCE, 0xC3, 0x90, 0x92, 0x3C, 0xF1, 0x97,
+0x90, 0x92, 0x3D, 0xD1, 0xCE, 0x90, 0x92, 0x57,
+0xF0, 0x12, 0x90, 0x41, 0x90, 0x92, 0x58, 0xF0,
+0xF1, 0xED, 0x90, 0x92, 0x72, 0x12, 0x97, 0xE6,
+0x90, 0x92, 0x73, 0xF0, 0x22, 0x90, 0x00, 0x04,
+0x02, 0x03, 0x0F, 0x90, 0x00, 0x06, 0x02, 0x03,
+0x0F, 0xF9, 0xE4, 0x3A, 0xFA, 0x02, 0x02, 0xF6,
+0x90, 0x02, 0x09, 0xE0, 0xF5, 0x5B, 0x12, 0x02,
+0xF6, 0x25, 0x5B, 0x90, 0x84, 0xC6, 0x12, 0x8F,
+0x97, 0x25, 0x5B, 0x90, 0x84, 0xC7, 0x12, 0x8E,
+0xCE, 0x25, 0x5B, 0x90, 0x84, 0xC8, 0xF0, 0x11,
+0x41, 0x25, 0x5B, 0x90, 0x84, 0xC9, 0xF0, 0x12,
+0x8F, 0xED, 0x25, 0x5B, 0x90, 0x84, 0xCA, 0xF1,
+0xE6, 0x25, 0x5B, 0x90, 0x84, 0xCB, 0xF0, 0x12,
+0x8F, 0xF3, 0x25, 0x5B, 0x90, 0x84, 0xCC, 0xF0,
+0x22, 0x90, 0x00, 0x03, 0x02, 0x03, 0x0F, 0x12,
+0xCE, 0xC3, 0xC4, 0x54, 0x0F, 0xFF, 0xBF, 0x0F,
+0x15, 0x90, 0x92, 0x09, 0xE0, 0x54, 0xFE, 0xF0,
+0x12, 0xA1, 0x34, 0x12, 0x98, 0xCE, 0x54, 0x0F,
+0xFF, 0x31, 0xF4, 0x02, 0xB5, 0x1C, 0x31, 0xDD,
+0x12, 0x8F, 0x98, 0x12, 0xCE, 0xFF, 0xF1, 0xBB,
+0xEF, 0x12, 0x8E, 0xCE, 0x54, 0x03, 0xFF, 0x31,
+0xE4, 0x54, 0xFC, 0x12, 0x8E, 0xCD, 0x54, 0x1C,
+0xFF, 0xEE, 0x54, 0x0F, 0xFE, 0x31, 0xE5, 0x54,
+0xE3, 0x12, 0x8E, 0xCD, 0x54, 0xE0, 0xFF, 0xEE,
+0x31, 0xE5, 0x54, 0x1F, 0x4F, 0xF0, 0x12, 0x8F,
+0xED, 0xF1, 0xED, 0xE4, 0xFB, 0x31, 0x0C, 0x31,
+0xDD, 0xF1, 0xE7, 0xF1, 0xED, 0x7B, 0x01, 0x31,
+0x0C, 0x31, 0xDD, 0x11, 0x41, 0x33, 0x33, 0x33,
+0x54, 0xF8, 0x12, 0xCE, 0xFF, 0x75, 0xF0, 0x0E,
+0xA4, 0x24, 0x16, 0xF5, 0x82, 0xE4, 0x34, 0x92,
+0xF5, 0x83, 0xEF, 0xF0, 0x11, 0x41, 0xC4, 0x13,
+0x54, 0x07, 0xFF, 0xED, 0x75, 0xF0, 0x0E, 0xA4,
+0x24, 0x17, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5,
+0x83, 0xEF, 0xF0, 0xEE, 0xC4, 0x54, 0x0F, 0xFF,
+0x14, 0x6D, 0x70, 0x27, 0x90, 0x92, 0x0B, 0xEF,
+0xF0, 0x12, 0x8F, 0xF3, 0x54, 0x0F, 0xC4, 0x54,
+0xF0, 0xFF, 0x90, 0x92, 0x0A, 0xE0, 0x54, 0x0F,
+0x4F, 0xF0, 0x54, 0xF1, 0xF0, 0x90, 0x92, 0x09,
+0xE0, 0x44, 0x01, 0xF0, 0x7D, 0x20, 0xE4, 0xFF,
+0x12, 0x7B, 0xFD, 0x22, 0x8F, 0x5E, 0x8D, 0x5F,
+0xAE, 0x03, 0x74, 0x1F, 0xC3, 0x95, 0x5E, 0x40,
+0x0A, 0x31, 0xD5, 0xE4, 0xFD, 0x31, 0xCD, 0x24,
+0xD4, 0x80, 0x31, 0x74, 0x3F, 0xC3, 0x95, 0x5E,
+0x40, 0x0A, 0x31, 0xD5, 0x7D, 0x20, 0x31, 0xCB,
+0x24, 0x88, 0x80, 0x20, 0x74, 0x5F, 0xC3, 0x95,
+0x5E, 0x40, 0x0A, 0x31, 0xD5, 0x7D, 0x40, 0x31,
+0xCB, 0x24, 0xD0, 0x80, 0x0F, 0x74, 0x7F, 0xC3,
+0x95, 0x5E, 0x40, 0x1D, 0x31, 0xD5, 0x7D, 0x60,
+0x31, 0xCB, 0x24, 0x84, 0xFD, 0xE4, 0x34, 0x04,
+0xFC, 0xE5, 0x5F, 0xF1, 0xC9, 0x75, 0xF0, 0x03,
+0xEE, 0x12, 0x05, 0x28, 0xEC, 0xF0, 0xA3, 0xED,
+0xF0, 0x22, 0xC3, 0xEF, 0x9D, 0xF5, 0x60, 0xC3,
+0x94, 0x08, 0x50, 0x19, 0xE4, 0xF5, 0x61, 0xEB,
+0x51, 0xCF, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x93,
+0xF9, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0x51, 0xC9,
+0xE5, 0x60, 0xF0, 0x80, 0x3B, 0xE5, 0x60, 0xC3,
+0x94, 0x10, 0x50, 0x09, 0x75, 0x61, 0x01, 0xE5,
+0x60, 0x24, 0xF8, 0x80, 0x17, 0xE5, 0x60, 0xC3,
+0x94, 0x18, 0x50, 0x09, 0x75, 0x61, 0x02, 0xE5,
+0x60, 0x24, 0xF0, 0x80, 0x07, 0x75, 0x61, 0x03,
+0xE5, 0x60, 0x24, 0xE8, 0xFF, 0xEB, 0x51, 0xCF,
+0xC0, 0x83, 0xC0, 0x82, 0x90, 0x93, 0xF9, 0xE0,
+0xD0, 0x82, 0xD0, 0x83, 0x51, 0xC9, 0xEF, 0xF0,
+0xAF, 0x61, 0x22, 0xAF, 0x5E, 0x31, 0x6A, 0x90,
+0x93, 0xF5, 0xEF, 0xF0, 0x22, 0x90, 0x93, 0xF9,
+0xEE, 0xF0, 0xAB, 0x5F, 0x22, 0xAB, 0x5B, 0xAA,
+0x5C, 0xA9, 0x5D, 0x22, 0xED, 0x75, 0xF0, 0x0E,
+0xA4, 0x24, 0x0E, 0xF5, 0x82, 0xE4, 0x34, 0x92,
+0xF5, 0x83, 0xE0, 0x22, 0x8F, 0x5E, 0x7B, 0x17,
+0x7D, 0xFF, 0xF1, 0x86, 0xE5, 0x5E, 0xF1, 0xBB,
+0xE0, 0xFC, 0xE5, 0x5E, 0x31, 0xE5, 0xF1, 0x9A,
+0xAF, 0x04, 0x12, 0xC9, 0xAD, 0xE5, 0x5E, 0x31,
+0xE5, 0x12, 0x89, 0x58, 0xE5, 0x5E, 0xF1, 0x41,
+0x91, 0x91, 0xAD, 0x5E, 0x7F, 0x01, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x2B,
+0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0xE4, 0xA3, 0xF0,
+0x90, 0x95, 0x2D, 0xE0, 0xFF, 0xC3, 0x94, 0x03,
+0x40, 0x02, 0x41, 0xC4, 0x90, 0x95, 0x2C, 0xE0,
+0xFE, 0xF1, 0xC9, 0x75, 0xF0, 0x03, 0xEF, 0x12,
+0x05, 0x28, 0x12, 0xCE, 0xED, 0xE0, 0x90, 0x95,
+0x2E, 0xF0, 0x90, 0x95, 0x2B, 0xE0, 0xFC, 0xB4,
+0x02, 0x22, 0x90, 0x95, 0x2E, 0xE0, 0xFD, 0xEE,
+0x51, 0xCF, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x95,
+0x2D, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0x51, 0xC9,
+0x12, 0xCF, 0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8,
+0xFC, 0x4D, 0x80, 0x23, 0xEC, 0xB4, 0x01, 0x23,
+0x12, 0xCE, 0xF6, 0xE0, 0x51, 0xCF, 0xC0, 0x83,
+0xC0, 0x82, 0x90, 0x95, 0x2D, 0xE0, 0xD0, 0x82,
+0xD0, 0x83, 0x51, 0xC9, 0x12, 0xCF, 0x08, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0x90,
+0x95, 0x2E, 0xF0, 0x12, 0xCE, 0xF6, 0xE0, 0xF1,
+0xC9, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x95, 0x2D,
+0xE0, 0xD0, 0x82, 0xD0, 0x83, 0x51, 0xC9, 0x12,
+0xCE, 0xED, 0xEF, 0xF0, 0x90, 0x95, 0x2D, 0xE0,
+0x04, 0xF0, 0x41, 0x30, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x75, 0xF0, 0x03, 0x02, 0x05, 0x28, 0x75,
+0xF0, 0x0E, 0xA4, 0x24, 0x11, 0xF5, 0x82, 0xE4,
+0x34, 0x92, 0xF5, 0x83, 0x22, 0xF1, 0x65, 0xB5,
+0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0, 0x12, 0xA1,
+0x4C, 0xE4, 0x90, 0x92, 0x0C, 0xF0, 0xD1, 0x87,
+0xF1, 0x7C, 0xFD, 0xF1, 0xBB, 0xE0, 0xFA, 0x31,
+0xE4, 0xFC, 0x54, 0x03, 0xFD, 0xEC, 0x13, 0x13,
+0x54, 0x07, 0xFB, 0xEE, 0xF1, 0xA9, 0xAF, 0x02,
+0x12, 0xC9, 0xAD, 0x71, 0x36, 0x31, 0xE5, 0x12,
+0x89, 0x58, 0x71, 0x36, 0xFF, 0x75, 0xF0, 0x0E,
+0xA4, 0x24, 0x18, 0xF5, 0x82, 0xE4, 0x34, 0x92,
+0xF5, 0x83, 0xE0, 0x04, 0xF0, 0xF1, 0x40, 0x91,
+0x91, 0x71, 0x36, 0xFD, 0x7F, 0x01, 0x41, 0x1E,
+0x90, 0x92, 0x0C, 0x74, 0x05, 0xF0, 0x90, 0x92,
+0x0A, 0xE0, 0xC3, 0x13, 0x54, 0x07, 0x22, 0xE4,
+0x90, 0x94, 0x66, 0xF0, 0x90, 0x92, 0x0A, 0xE0,
+0x30, 0xE0, 0x55, 0xC3, 0x13, 0x54, 0x07, 0xFF,
+0x71, 0xA1, 0xE0, 0xFE, 0x30, 0xE0, 0x49, 0xEF,
+0x71, 0xA1, 0xEE, 0x54, 0xFE, 0xF0, 0xEF, 0x71,
+0xA1, 0xE0, 0xFF, 0x13, 0x13, 0x54, 0x3F, 0x30,
+0xE0, 0x0A, 0xF1, 0x7C, 0x71, 0xA1, 0xEF, 0x54,
+0xFB, 0x12, 0xCF, 0x18, 0x90, 0x04, 0xE0, 0xE0,
+0x30, 0xE1, 0x1B, 0x71, 0x30, 0x71, 0xA1, 0xE0,
+0x44, 0x02, 0xF0, 0xE4, 0x90, 0x92, 0xBA, 0x71,
+0x35, 0xFD, 0x7F, 0x02, 0xB1, 0xF6, 0x90, 0x94,
+0x66, 0xE0, 0x60, 0x0C, 0x80, 0x19, 0x71, 0x36,
+0x71, 0xA1, 0xE0, 0x54, 0xFD, 0xF0, 0x91, 0x94,
+0x22, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x3E, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0x22, 0xE4,
+0x90, 0x94, 0x6B, 0xF0, 0x90, 0x92, 0x0A, 0xE0,
+0x20, 0xE0, 0x02, 0x81, 0x90, 0xC3, 0x13, 0x54,
+0x07, 0xF1, 0xD7, 0x54, 0x07, 0x90, 0x94, 0x68,
+0xF0, 0x60, 0x05, 0xE0, 0x64, 0x02, 0x70, 0x5D,
+0x90, 0x92, 0x0C, 0xE0, 0x70, 0x37, 0x90, 0x05,
+0x22, 0xE0, 0x90, 0x94, 0x69, 0xF0, 0x7B, 0x4E,
+0x7D, 0x6F, 0xE4, 0xFF, 0x91, 0x99, 0x71, 0x36,
+0xF1, 0x34, 0xF1, 0xF5, 0x7D, 0x01, 0x91, 0xA4,
+0xBF, 0x01, 0x0F, 0x71, 0x36, 0x71, 0xA1, 0xE0,
+0x44, 0x01, 0xF0, 0x90, 0x92, 0x0C, 0x74, 0x01,
+0xF0, 0x22, 0x90, 0x94, 0x69, 0xE0, 0xFD, 0x7B,
+0x4F, 0xE4, 0xFF, 0x81, 0x99, 0x90, 0x92, 0x0C,
+0xE0, 0xB4, 0x01, 0x03, 0x74, 0x05, 0xF0, 0x71,
+0x36, 0xFD, 0x7F, 0x02, 0xB1, 0xF6, 0x90, 0x92,
+0x0C, 0xE0, 0x64, 0x05, 0x70, 0x6A, 0xB1, 0x52,
+0xEF, 0x70, 0x65, 0x80, 0x5E, 0x90, 0x94, 0x68,
+0xE0, 0xFF, 0x64, 0x03, 0x60, 0x05, 0xEF, 0x64,
+0x01, 0x70, 0x55, 0x90, 0x92, 0x0C, 0xE0, 0x64,
+0x05, 0x70, 0x4D, 0x90, 0x94, 0x68, 0xE0, 0x64,
+0x01, 0x70, 0x34, 0x90, 0x94, 0x6A, 0x12, 0xBD,
+0xC0, 0xD3, 0x94, 0x1F, 0x90, 0x92, 0x0A, 0xE0,
+0x40, 0x0C, 0xF1, 0x31, 0xF5, 0x83, 0xE0, 0xFF,
+0x7D, 0x00, 0x7C, 0x7C, 0x80, 0x16, 0xC3, 0xF1,
+0x31, 0xF5, 0x83, 0xE0, 0xFB, 0x90, 0x94, 0x6A,
+0x12, 0xBD, 0xC0, 0x7D, 0x00, 0x25, 0xE0, 0x25,
+0xE0, 0xFC, 0xAF, 0x03, 0x12, 0x98, 0xE5, 0x71,
+0x36, 0xFD, 0x7F, 0x02, 0xB1, 0xF6, 0xB1, 0x52,
+0xEF, 0x70, 0x05, 0x7F, 0x06, 0x12, 0xC8, 0x4A,
+0x22, 0xFD, 0x91, 0xA4, 0xE4, 0xFB, 0xFD, 0x7F,
+0xFF, 0x90, 0x05, 0x22, 0xED, 0xF0, 0x90, 0x92,
+0x01, 0xEB, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x24, 0xEE, 0xF0,
+0xA3, 0x12, 0xB0, 0xF7, 0x90, 0x04, 0x1D, 0xE0,
+0x60, 0x27, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x95,
+0x2A, 0xF0, 0x7B, 0x14, 0xD1, 0x81, 0xEF, 0x64,
+0x01, 0x70, 0x05, 0x12, 0xCE, 0x48, 0x80, 0x04,
+0x7F, 0x00, 0x80, 0x18, 0x90, 0x95, 0x2A, 0xE0,
+0xFD, 0x7B, 0x15, 0xE4, 0xFF, 0x91, 0x99, 0x80,
+0x03, 0x12, 0xCE, 0x48, 0x90, 0x04, 0x1F, 0x74,
+0x20, 0xF0, 0x7F, 0x01, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x92, 0x09, 0xE0, 0x30, 0xE0, 0x59,
+0x90, 0x92, 0x0C, 0xE0, 0x70, 0x26, 0x7B, 0x16,
+0x7D, 0x6F, 0xF1, 0x86, 0x71, 0x36, 0xF1, 0x41,
+0x7D, 0x01, 0x91, 0xA4, 0x71, 0x36, 0x12, 0xBE,
+0x34, 0xE0, 0x44, 0x01, 0x12, 0xBD, 0xD0, 0xA3,
+0x74, 0x03, 0x12, 0xA1, 0x7B, 0x90, 0x92, 0x0C,
+0x74, 0x01, 0xF0, 0x22, 0x90, 0x92, 0x0C, 0xE0,
+0x64, 0x01, 0x70, 0x23, 0x71, 0x36, 0xFF, 0x12,
+0xBE, 0x34, 0xE0, 0x30, 0xE0, 0x19, 0xF1, 0x40,
+0x7D, 0x01, 0x91, 0xA4, 0xE4, 0x90, 0x91, 0x6E,
+0xF0, 0xA3, 0x74, 0x03, 0xF0, 0xE4, 0xFB, 0xFD,
+0x7F, 0x54, 0x7E, 0x01, 0x02, 0x61, 0x41, 0x51,
+0xDD, 0x22, 0xD1, 0x87, 0xEF, 0x70, 0x02, 0xFF,
+0x22, 0x71, 0x36, 0x90, 0x92, 0x88, 0xF0, 0xF1,
+0x65, 0xB5, 0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0,
+0x71, 0x36, 0xF5, 0x78, 0xE4, 0x90, 0x92, 0x0C,
+0xF0, 0xE5, 0x78, 0x75, 0xF0, 0x1B, 0xA4, 0x24,
+0x3B, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
+0xE0, 0x30, 0xE0, 0x26, 0xD1, 0x75, 0xE0, 0x24,
+0x8B, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
+0xE0, 0xFF, 0xF1, 0x55, 0xEF, 0xD1, 0x74, 0xE0,
+0x04, 0xD1, 0x74, 0xE0, 0xFF, 0x90, 0x92, 0x8A,
+0xE0, 0xFE, 0xEF, 0xB5, 0x06, 0x04, 0xD1, 0x75,
+0xE4, 0xF0, 0xF1, 0x55, 0xE0, 0xFC, 0x90, 0x92,
+0x88, 0xE0, 0xF1, 0x57, 0xE0, 0x6C, 0x60, 0x0E,
+0xE5, 0x78, 0xF1, 0x8C, 0xAF, 0x04, 0x12, 0xC9,
+0xAD, 0xE5, 0x78, 0x12, 0x89, 0x4A, 0xE5, 0x78,
+0xF1, 0xD7, 0x54, 0x07, 0xFF, 0x60, 0x03, 0xBF,
+0x02, 0x0A, 0xE5, 0x78, 0xF1, 0x34, 0xF1, 0xF5,
+0xE4, 0xFD, 0x91, 0xA4, 0xAD, 0x78, 0x7F, 0x01,
+0xB1, 0xF6, 0x90, 0x92, 0x89, 0xE0, 0xC3, 0x13,
+0x54, 0x03, 0xFF, 0xBF, 0x02, 0x05, 0xE4, 0xFF,
+0x12, 0xC8, 0x4A, 0x7F, 0x01, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x3E,
+0xED, 0xF0, 0x90, 0x95, 0x3D, 0xEF, 0xF0, 0x64,
+0x02, 0x70, 0x23, 0x90, 0x05, 0x22, 0xE0, 0x90,
+0x95, 0x3F, 0xF0, 0x7B, 0x4A, 0x7D, 0x6F, 0xD1,
+0x83, 0xBF, 0x01, 0x07, 0x90, 0x04, 0xD4, 0x74,
+0xFF, 0x80, 0x47, 0x90, 0x95, 0x3F, 0xE0, 0xFD,
+0x7B, 0x46, 0xF1, 0x2A, 0x80, 0x41, 0x90, 0x95,
+0x3D, 0xE0, 0x64, 0x01, 0x70, 0x30, 0x91, 0x95,
+0x90, 0x95, 0x3E, 0xE0, 0xFF, 0x75, 0xF0, 0x1B,
+0xA4, 0x24, 0x3C, 0xF5, 0x82, 0xE4, 0x34, 0x92,
+0xF5, 0x83, 0xE0, 0xF4, 0x90, 0x04, 0xD4, 0xF0,
+0xEF, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x3D, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0xF4,
+0x90, 0x04, 0xD5, 0xF0, 0x80, 0x07, 0x90, 0x04,
+0xD4, 0xE4, 0xF0, 0xA3, 0xF0, 0x7F, 0x01, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x74, 0xAE, 0x25,
+0x78, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
+0x22, 0x7D, 0xFF, 0xE4, 0xFF, 0x91, 0x99, 0xE4,
+0x90, 0x95, 0x37, 0xF0, 0xA3, 0xF0, 0x90, 0x05,
+0x22, 0xE0, 0x90, 0x95, 0x39, 0xF0, 0x7D, 0x47,
+0x7F, 0xFF, 0x12, 0x98, 0xDA, 0x90, 0x05, 0xF8,
+0xE0, 0x70, 0x11, 0xA3, 0xE0, 0x70, 0x0D, 0xA3,
+0xE0, 0x70, 0x09, 0xA3, 0xE0, 0x70, 0x05, 0xF1,
+0xB1, 0x7F, 0x01, 0x22, 0xD3, 0x90, 0x95, 0x38,
+0xE0, 0x94, 0xE8, 0x90, 0x95, 0x37, 0xE0, 0x94,
+0x03, 0x40, 0x0C, 0x90, 0x01, 0xC0, 0xE0, 0x44,
+0x20, 0xF0, 0xF1, 0xB1, 0x7F, 0x00, 0x22, 0x7F,
+0x32, 0x7E, 0x00, 0x12, 0x7C, 0x9F, 0x90, 0x95,
+0x37, 0x12, 0xB6, 0xF9, 0x80, 0xBF, 0x8F, 0x5F,
+0x90, 0x05, 0x22, 0xE0, 0x90, 0x93, 0xF5, 0xF0,
+0x7B, 0x17, 0xD1, 0x81, 0xEF, 0x64, 0x01, 0x70,
+0x32, 0xE5, 0x5F, 0xF1, 0x57, 0xE0, 0xFC, 0xE5,
+0x5F, 0xF1, 0x8C, 0xAF, 0x04, 0x12, 0xC9, 0xAD,
+0xE5, 0x5F, 0x12, 0x89, 0x4A, 0xE5, 0x5F, 0xF1,
+0xD7, 0x54, 0x07, 0xFF, 0x60, 0x03, 0xBF, 0x02,
+0x09, 0xE5, 0x5F, 0xF1, 0x34, 0xF1, 0x4C, 0xFD,
+0x91, 0xA4, 0xAD, 0x5F, 0x7F, 0x01, 0xB1, 0xF6,
+0x7F, 0x01, 0x22, 0x90, 0x93, 0xF5, 0xE0, 0xFD,
+0x7B, 0x49, 0xE4, 0xFF, 0x91, 0x99, 0x7F, 0x00,
+0x22, 0x13, 0x54, 0x07, 0x75, 0xF0, 0x1B, 0xA4,
+0x24, 0x40, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0x22,
+0xEF, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x19, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0xFF,
+0x7E, 0x00, 0xE4, 0xFB, 0x22, 0xE5, 0x78, 0x75,
+0xF0, 0x1B, 0xA4, 0x24, 0x37, 0xF5, 0x82, 0xE4,
+0x34, 0x92, 0xF5, 0x83, 0x22, 0x90, 0x92, 0x0A,
+0xE0, 0xFF, 0xC3, 0x13, 0xFE, 0xEF, 0x54, 0xF1,
+0xFF, 0xEE, 0x04, 0x54, 0x07, 0x25, 0xE0, 0x4F,
+0xF0, 0xA3, 0xE0, 0xFF, 0x90, 0x92, 0x0A, 0xE0,
+0xFE, 0xC3, 0x13, 0x54, 0x07, 0x22, 0x7F, 0xFF,
+0x91, 0x99, 0xC1, 0x87, 0x75, 0xF0, 0x1B, 0xA4,
+0x24, 0x38, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5,
+0x83, 0xE0, 0xFE, 0x54, 0x03, 0xFD, 0xEE, 0x13,
+0x13, 0x54, 0x07, 0xFB, 0x90, 0x92, 0x0A, 0xE0,
+0xFE, 0xC4, 0x54, 0x0F, 0x90, 0x95, 0x36, 0xF0,
+0x22, 0x90, 0x95, 0x39, 0xE0, 0xFF, 0x7D, 0x48,
+0x02, 0x98, 0xDA, 0x75, 0xF0, 0x0E, 0xA4, 0x24,
+0x0D, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
+0x22, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x0F, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0x22, 0x75,
+0xF0, 0x1B, 0xA4, 0x24, 0x3A, 0xF5, 0x82, 0xE4,
+0x34, 0x92, 0xF5, 0x83, 0xE0, 0x22, 0xF0, 0x90,
+0x00, 0x05, 0x02, 0x03, 0x0F, 0xFF, 0x12, 0x02,
+0xF6, 0x54, 0x0F, 0xFD, 0x22, 0xF5, 0x83, 0xE0,
+0xFF, 0x7E, 0x00, 0x7B, 0x04, 0x22, 0x8B, 0x5B,
+0x8A, 0x5C, 0x89, 0x5D, 0x90, 0x92, 0xC3, 0xE0,
+0x70, 0x10, 0x12, 0x02, 0xF6, 0x13, 0x13, 0x54,
+0x3F, 0x30, 0xE0, 0x06, 0x90, 0x92, 0xC9, 0x74,
+0x01, 0xF0, 0x90, 0x92, 0xC5, 0xE0, 0x70, 0x0F,
+0x11, 0xCE, 0xC4, 0x54, 0x0F, 0xFF, 0xBF, 0x05,
+0x06, 0x90, 0x92, 0xCA, 0x74, 0x01, 0xF0, 0x12,
+0x91, 0xDD, 0x12, 0x8F, 0x98, 0xFF, 0xF5, 0x5F,
+0x12, 0x02, 0xF6, 0xFE, 0xC3, 0x13, 0x30, 0xE0,
+0x07, 0x12, 0x8E, 0xCF, 0xF5, 0x60, 0x80, 0x02,
+0x8F, 0x60, 0x85, 0x5F, 0x5E, 0xE5, 0x5E, 0xD3,
+0x95, 0x60, 0x50, 0x28, 0x11, 0xCE, 0x54, 0x01,
+0xFD, 0xAF, 0x5E, 0x12, 0x6E, 0x5F, 0xAF, 0x5E,
+0x12, 0x77, 0x39, 0xEF, 0xAF, 0x5E, 0x70, 0x04,
+0x11, 0x97, 0x80, 0x02, 0xF1, 0xDE, 0x90, 0x92,
+0xCA, 0xE0, 0x60, 0x04, 0xAF, 0x5E, 0x11, 0x97,
+0x05, 0x5E, 0x80, 0xD1, 0xE5, 0x5F, 0x70, 0x16,
+0xFF, 0x12, 0x77, 0x39, 0xEF, 0x70, 0x0F, 0x12,
+0xC0, 0x79, 0x12, 0x79, 0x61, 0x12, 0xBE, 0xE9,
+0x54, 0xBF, 0xF0, 0x54, 0x7F, 0xF0, 0x22, 0x7D,
+0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x93, 0xF5, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
+0x7D, 0x44, 0x7F, 0x6F, 0x51, 0x78, 0x90, 0x93,
+0xF6, 0xE0, 0x90, 0x93, 0xF5, 0xB4, 0x01, 0x08,
+0x51, 0xA7, 0xE0, 0x44, 0x04, 0xF0, 0x80, 0x06,
+0x51, 0xA7, 0xE0, 0x54, 0xFB, 0xF0, 0x11, 0xD7,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0xAB, 0x5B,
+0xAA, 0x5C, 0xA9, 0x5D, 0x02, 0x02, 0xF6, 0xE4,
+0xFD, 0xFF, 0x90, 0x05, 0x22, 0xEF, 0xF0, 0x90,
+0x92, 0x01, 0xED, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0x6C, 0xEF,
+0xF0, 0xA3, 0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x90,
+0x04, 0x1D, 0xE0, 0x60, 0x1C, 0x90, 0x05, 0x22,
+0xE0, 0x90, 0x94, 0x71, 0xF0, 0x7D, 0x36, 0x51,
+0x76, 0xBF, 0x01, 0x02, 0x31, 0xCB, 0x90, 0x94,
+0x71, 0xE0, 0xFF, 0x7D, 0x37, 0x11, 0xDA, 0x80,
+0x02, 0x31, 0xCB, 0x90, 0x05, 0x22, 0xE0, 0x54,
+0x6F, 0xFF, 0x7D, 0x38, 0x11, 0xDA, 0x90, 0x04,
+0x1F, 0x74, 0x20, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x95, 0x30, 0xED, 0xF0, 0xA3, 0xEB, 0xF0,
+0x90, 0x95, 0x2F, 0xEF, 0xF0, 0xE4, 0xFD, 0xFC,
+0x12, 0x7B, 0x2A, 0x7C, 0x00, 0xAD, 0x07, 0x90,
+0x95, 0x2F, 0xE0, 0x90, 0x04, 0x25, 0xF0, 0x90,
+0x95, 0x30, 0xE0, 0x60, 0x05, 0x51, 0x9B, 0x44,
+0x80, 0xF0, 0xAF, 0x05, 0x74, 0x20, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x54,
+0xC0, 0xF0, 0x51, 0x9B, 0x54, 0xC0, 0xF0, 0x90,
+0x95, 0x32, 0xE0, 0xFF, 0xAE, 0x05, 0x74, 0x18,
+0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xEF, 0xF0, 0x51, 0x85, 0xE0, 0x20, 0xE1, 0x15,
+0x54, 0x01, 0xFF, 0x90, 0x95, 0x31, 0xE0, 0x25,
+0xE0, 0x25, 0xE0, 0xFB, 0xEF, 0x44, 0x02, 0x4B,
+0xFF, 0x51, 0x85, 0xEF, 0xF0, 0xAF, 0x05, 0x74,
+0x11, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0x74, 0xFF, 0xF0, 0x74, 0x29, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x54,
+0xF7, 0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x94, 0x6C, 0xE0, 0xFF,
+0x90, 0x95, 0x32, 0x74, 0x0C, 0xF0, 0xE4, 0xFB,
+0x7D, 0x01, 0x31, 0x31, 0x90, 0x94, 0x6F, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x94, 0x6D, 0xE0,
+0xFC, 0xA3, 0xE0, 0xFD, 0x02, 0x77, 0xD8, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94,
+0x72, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x84,
+0xC3, 0xE0, 0x04, 0xF0, 0x90, 0x04, 0x1D, 0xE0,
+0x60, 0x33, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x94,
+0x76, 0xF0, 0x7D, 0x26, 0x51, 0x76, 0xEF, 0x64,
+0x01, 0x70, 0x15, 0x51, 0x90, 0x7D, 0x01, 0x12,
+0x3A, 0xC2, 0xD1, 0xCE, 0x20, 0xE0, 0x09, 0x90,
+0x92, 0x09, 0xE0, 0x20, 0xE0, 0x02, 0xD1, 0xE5,
+0x90, 0x94, 0x76, 0xE0, 0xFF, 0x7D, 0x27, 0x11,
+0xDA, 0x51, 0x7D, 0x80, 0x1C, 0x51, 0x7D, 0x51,
+0x90, 0x90, 0x95, 0x32, 0x74, 0x0A, 0xF0, 0x7D,
+0x01, 0x31, 0x31, 0xD1, 0xCE, 0x20, 0xE0, 0x09,
+0x90, 0x92, 0x09, 0xE0, 0x20, 0xE0, 0x02, 0xD1,
+0xE5, 0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0, 0x90,
+0x84, 0xBF, 0xA3, 0xE0, 0x24, 0x7F, 0xF5, 0x82,
+0xE4, 0x34, 0x82, 0xF5, 0x83, 0x74, 0x01, 0xF0,
+0xFF, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7F, 0xFF,
+0x11, 0xDA, 0x02, 0x96, 0x87, 0x90, 0x94, 0x72,
+0xE0, 0xFF, 0x02, 0x5C, 0xA3, 0x74, 0x12, 0x2E,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22,
+0x90, 0x84, 0xC8, 0xE0, 0xFF, 0x90, 0x94, 0x73,
+0xE0, 0xFB, 0x22, 0x74, 0x21, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22, 0xE0,
+0xC4, 0x54, 0xF0, 0x24, 0x05, 0xF5, 0x82, 0xE4,
+0x34, 0x81, 0xF5, 0x83, 0x22, 0x8D, 0x77, 0xEF,
+0x30, 0xE6, 0x19, 0xE5, 0x77, 0x71, 0x89, 0xE0,
+0xFD, 0xE5, 0x77, 0x51, 0xA8, 0x91, 0xE0, 0xE4,
+0xFB, 0xAF, 0x77, 0x12, 0x27, 0x3D, 0x71, 0x7B,
+0xE4, 0xF0, 0x80, 0x47, 0x71, 0x7B, 0xE0, 0x04,
+0xF0, 0x71, 0x7B, 0xE0, 0x64, 0x02, 0x70, 0x15,
+0x74, 0xB7, 0x25, 0x77, 0x91, 0x56, 0xE0, 0xFD,
+0xF4, 0x60, 0x02, 0x80, 0x21, 0xE5, 0x77, 0x71,
+0x89, 0xE0, 0xFD, 0x80, 0x19, 0x71, 0x7B, 0xE0,
+0xD3, 0x94, 0x03, 0x40, 0x0B, 0xAF, 0x77, 0x12,
+0x6D, 0x94, 0x71, 0x7B, 0xE4, 0xF0, 0x80, 0x13,
+0xE5, 0x77, 0x71, 0x89, 0xE0, 0xFD, 0xE5, 0x77,
+0x51, 0xA8, 0x91, 0xE0, 0x7B, 0x01, 0xAF, 0x77,
+0x12, 0x27, 0x3D, 0xE5, 0x77, 0x71, 0x89, 0xE0,
+0xFD, 0x90, 0x94, 0xCF, 0x74, 0x05, 0xF0, 0xE4,
+0xFB, 0xAF, 0x77, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x94, 0xD2, 0xED, 0xF0, 0xA3,
+0xEF, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x94, 0xCF,
+0xE0, 0x90, 0x94, 0xD5, 0xF0, 0xE4, 0xA3, 0xF0,
+0xEF, 0x12, 0xC7, 0xBD, 0xA3, 0xE0, 0x90, 0x94,
+0xD7, 0xF0, 0x74, 0x4C, 0x2F, 0xF1, 0xD6, 0xE0,
+0x90, 0x94, 0xD8, 0xF0, 0x90, 0x94, 0xD0, 0x74,
+0x0C, 0xF0, 0x90, 0x94, 0xDE, 0x74, 0x07, 0xF0,
+0x7B, 0x01, 0x7A, 0x94, 0x79, 0xD0, 0x12, 0x5E,
+0x10, 0x7F, 0x04, 0x12, 0x88, 0x0B, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x74, 0xBC, 0x25, 0x77, 0xF5,
+0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0x22, 0xE5,
+0x63, 0xC4, 0x54, 0xF0, 0x24, 0x00, 0xF5, 0x82,
+0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x8F, 0x6F,
+0x8D, 0x70, 0xEF, 0x71, 0x89, 0xE0, 0xFD, 0x54,
+0x7F, 0xF5, 0x71, 0xED, 0x54, 0x80, 0xF5, 0x72,
+0x75, 0xF0, 0x12, 0xEF, 0xF1, 0xCE, 0xF5, 0x74,
+0x75, 0xF0, 0x12, 0xEF, 0x12, 0x8E, 0xC5, 0xC4,
+0x54, 0x03, 0xF5, 0x75, 0x91, 0x52, 0x74, 0xFF,
+0xF0, 0x91, 0x5E, 0xE5, 0x72, 0x4D, 0xFF, 0x91,
+0xF0, 0xEF, 0xF0, 0xE5, 0x6F, 0x51, 0xA8, 0xE0,
+0x54, 0x03, 0xF5, 0x73, 0x74, 0x4C, 0x25, 0x6F,
+0xF1, 0xD6, 0xE5, 0x73, 0xF0, 0xE5, 0x71, 0x65,
+0x74, 0x70, 0x21, 0x75, 0xF0, 0x12, 0xE5, 0x6F,
+0xB1, 0x01, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0,
+0x0B, 0xE5, 0x72, 0x70, 0x07, 0xE5, 0x71, 0x44,
+0x80, 0xFD, 0x80, 0x49, 0x91, 0x5E, 0x7D, 0x07,
+0xAF, 0x6F, 0x81, 0x89, 0xE5, 0x71, 0xC3, 0x95,
+0x74, 0x50, 0x34, 0xAB, 0x6F, 0xAD, 0x74, 0xAF,
+0x71, 0x12, 0x72, 0xEA, 0xAD, 0x07, 0xE5, 0x71,
+0xC3, 0x94, 0x0C, 0x40, 0x28, 0x75, 0xF0, 0x12,
+0xE5, 0x6F, 0xB1, 0x01, 0xFE, 0xC4, 0x13, 0x54,
+0x07, 0x30, 0xE0, 0x19, 0xE5, 0x70, 0x60, 0x15,
+0xE5, 0x72, 0x70, 0x11, 0xE5, 0x71, 0x44, 0x80,
+0xFD, 0x91, 0x52, 0xEF, 0xF0, 0x80, 0x06, 0x91,
+0xF0, 0xE5, 0x74, 0xF0, 0xFD, 0x90, 0x91, 0x0B,
+0xE5, 0x73, 0xF0, 0xAB, 0x70, 0xAF, 0x6F, 0x02,
+0x27, 0x3D, 0x74, 0xB7, 0x25, 0x6F, 0xF5, 0x82,
+0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22, 0xE5, 0x71,
+0x25, 0xE0, 0x24, 0xF5, 0xF5, 0x82, 0xE4, 0x34,
+0x82, 0xF5, 0x83, 0xE4, 0x93, 0xFE, 0x74, 0x01,
+0x93, 0xFF, 0xE5, 0x6F, 0x25, 0xE0, 0x24, 0x7B,
+0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x7D, 0x07, 0xAF,
+0x63, 0xED, 0x30, 0xE0, 0x1D, 0x75, 0xF0, 0x12,
+0xEF, 0x90, 0x89, 0x44, 0x91, 0xD4, 0x90, 0x89,
+0x46, 0x91, 0xD4, 0x90, 0x89, 0x48, 0x91, 0xD4,
+0x90, 0x89, 0x4A, 0x91, 0xD4, 0x90, 0x89, 0x4C,
+0x91, 0xE8, 0xED, 0x30, 0xE1, 0x09, 0x75, 0xF0,
+0x12, 0xEF, 0x90, 0x89, 0x40, 0x91, 0xE8, 0xED,
+0x30, 0xE2, 0x0C, 0x75, 0xF0, 0x12, 0xEF, 0x90,
+0x89, 0x42, 0x12, 0x05, 0x28, 0xE4, 0xF0, 0xD1,
+0xC0, 0xE0, 0x54, 0xBF, 0x44, 0x80, 0xFE, 0xD1,
+0xC0, 0xEE, 0xF0, 0x22, 0x12, 0x05, 0x28, 0xE4,
+0xF0, 0xA3, 0xF0, 0x75, 0xF0, 0x12, 0xEF, 0x22,
+0xE0, 0x54, 0x03, 0x90, 0x91, 0x0B, 0xF0, 0x22,
+0x12, 0x05, 0x28, 0xE4, 0xF0, 0xA3, 0xF0, 0x22,
+0x74, 0xCC, 0x25, 0x6F, 0xF5, 0x82, 0xE4, 0x34,
+0x90, 0xF5, 0x83, 0x22, 0xFF, 0x75, 0xF0, 0x12,
+0xED, 0x90, 0x89, 0x3E, 0x12, 0x05, 0x28, 0xE0,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0xD1, 0xB9, 0x20, 0xE6, 0x02, 0xC1, 0x31, 0x90,
+0x00, 0x8C, 0xE0, 0x90, 0x95, 0x3A, 0xF0, 0x7F,
+0x8D, 0x12, 0x7B, 0x51, 0x90, 0x95, 0x3B, 0xEF,
+0xF0, 0x90, 0x00, 0x8E, 0xE0, 0x90, 0x95, 0x3C,
+0xF0, 0x90, 0x95, 0x3B, 0xE0, 0x24, 0xFC, 0x60,
+0x0F, 0x24, 0x03, 0x60, 0x02, 0xC1, 0x29, 0x90,
+0x95, 0x3A, 0xE0, 0xFF, 0xD1, 0x6A, 0xC1, 0x29,
+0x90, 0x95, 0x3A, 0xE0, 0x24, 0xDC, 0xF5, 0x82,
+0xE4, 0x34, 0x8F, 0xF5, 0x83, 0xE0, 0xFB, 0xE4,
+0xFD, 0xFF, 0xD1, 0x63, 0x75, 0xF0, 0x12, 0x12,
+0x8E, 0xC5, 0x13, 0x13, 0x54, 0x03, 0xFB, 0x0D,
+0xE4, 0xFF, 0xD1, 0x63, 0x75, 0xF0, 0x12, 0x12,
+0x8E, 0xC5, 0x12, 0x8F, 0xB7, 0xFB, 0x0D, 0xE4,
+0xFF, 0xD1, 0x63, 0x75, 0xF0, 0x12, 0x12, 0x8E,
+0xC5, 0xC4, 0x54, 0x03, 0xFB, 0x0D, 0xE4, 0xFF,
+0xD1, 0x63, 0x75, 0xF0, 0x12, 0xF1, 0xCE, 0xFB,
+0xE4, 0xFD, 0x0F, 0xD1, 0x63, 0x75, 0xF0, 0x12,
+0x90, 0x89, 0x3D, 0x12, 0x05, 0x28, 0xD1, 0x60,
+0x75, 0xF0, 0x12, 0xB1, 0x01, 0xC4, 0x13, 0x54,
+0x01, 0xFB, 0x0D, 0x7F, 0x01, 0xD1, 0x63, 0x75,
+0xF0, 0x12, 0xB1, 0x01, 0x54, 0x1F, 0xD1, 0x61,
+0x12, 0xC8, 0x3C, 0xE0, 0xFB, 0xE4, 0xFD, 0x0F,
+0xD1, 0x63, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x01,
+0xF5, 0x82, 0xE4, 0x34, 0x82, 0xD1, 0x5E, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x02, 0xF5, 0x82, 0xE4,
+0x34, 0x82, 0xD1, 0x5E, 0x75, 0xF0, 0x08, 0xA4,
+0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xD1,
+0x5E, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x04, 0xF5,
+0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0xE0, 0xFB,
+0xE4, 0xFD, 0x0F, 0xD1, 0x63, 0x75, 0xF0, 0x08,
+0xA4, 0x24, 0x05, 0xF5, 0x82, 0xE4, 0x34, 0x82,
+0xD1, 0x5E, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x06,
+0xF5, 0x82, 0xE4, 0x34, 0x82, 0xD1, 0x5E, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x07, 0xF5, 0x82, 0xE4,
+0x34, 0x82, 0xF5, 0x83, 0xE0, 0xFB, 0x0D, 0xD1,
+0x36, 0xD1, 0xB9, 0x30, 0xE0, 0x03, 0x12, 0xCF,
+0x28, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF, 0x70,
+0x04, 0x74, 0xF0, 0x80, 0x16, 0xEF, 0xB4, 0x01,
+0x04, 0x74, 0xF4, 0x80, 0x0E, 0xEF, 0xB4, 0x02,
+0x04, 0x74, 0xF8, 0x80, 0x06, 0xEF, 0xB4, 0x03,
+0x0C, 0x74, 0xFC, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
+0x02, 0xF5, 0x83, 0xEB, 0xF0, 0x22, 0xF5, 0x83,
+0xE0, 0xFB, 0x0D, 0xD1, 0x36, 0x90, 0x95, 0x3A,
+0xE0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x95, 0x46, 0xEF, 0xF0, 0xD1, 0xB9,
+0x30, 0xE6, 0x39, 0x7F, 0x8D, 0x12, 0x7B, 0x51,
+0xEF, 0x64, 0x01, 0x70, 0x2F, 0x90, 0x95, 0x47,
+0xF0, 0x90, 0x95, 0x47, 0xE0, 0xFD, 0x90, 0x95,
+0x46, 0xE0, 0x71, 0x89, 0xE5, 0x82, 0x2D, 0x12,
+0xCE, 0xD9, 0xE0, 0xFB, 0xE4, 0xFF, 0xD1, 0x36,
+0x90, 0x95, 0x47, 0xE0, 0x04, 0xF0, 0xE0, 0xC3,
+0x94, 0x10, 0x40, 0xDD, 0xD1, 0xB9, 0x30, 0xE0,
+0x03, 0x12, 0xCF, 0x28, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x7F, 0x8F, 0x12, 0x7B, 0x51, 0xEF, 0x22,
+0xEF, 0xC4, 0x54, 0xF0, 0x24, 0x03, 0xF5, 0x82,
+0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x90, 0x94,
+0x74, 0xEE, 0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD,
+0x90, 0x94, 0x72, 0xE0, 0xFF, 0x12, 0x65, 0x61,
+0x90, 0x92, 0x0A, 0xE0, 0x22, 0x90, 0x94, 0x74,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x12, 0x50, 0xD7,
+0x90, 0x94, 0x74, 0xA3, 0xE0, 0xFF, 0x24, 0x12,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
+0x54, 0x01, 0xFE, 0x90, 0x94, 0x73, 0xE0, 0x25,
+0xE0, 0x25, 0xE0, 0x44, 0x02, 0x4E, 0xFE, 0x74,
+0x12, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xEE, 0xF0, 0x22, 0xAA, 0x07, 0xA9, 0x05,
+0xEA, 0x71, 0x89, 0xE0, 0xF5, 0x6F, 0x54, 0x7F,
+0xF5, 0x71, 0x75, 0xF0, 0x12, 0xEA, 0x90, 0x89,
+0x3D, 0x12, 0x05, 0x28, 0xE0, 0x90, 0x94, 0x4B,
+0xF0, 0x75, 0xF0, 0x12, 0xEA, 0xF1, 0xCE, 0xFF,
+0xEA, 0x51, 0xA8, 0xE0, 0x54, 0x03, 0xF5, 0x70,
+0xE5, 0x71, 0x90, 0x83, 0x1D, 0x93, 0xFD, 0xEA,
+0x12, 0xC7, 0xBD, 0xE4, 0xF0, 0xA3, 0xED, 0xF0,
+0x75, 0xF0, 0x12, 0xEA, 0x12, 0x8E, 0xC5, 0xFE,
+0xC4, 0x54, 0x03, 0x90, 0x94, 0x4A, 0xF0, 0x74,
+0xCC, 0x2A, 0x91, 0xF4, 0xE5, 0x71, 0xF0, 0x74,
+0x4C, 0x2A, 0xF1, 0xD6, 0xE5, 0x70, 0xF0, 0xE5,
+0x71, 0xD3, 0x9F, 0x40, 0x04, 0x8F, 0x71, 0x8F,
+0x6F, 0x89, 0x72, 0xE4, 0xFF, 0xEF, 0xC3, 0x95,
+0x72, 0x50, 0x34, 0xE5, 0x6F, 0x30, 0xE7, 0x09,
+0x85, 0x71, 0x6F, 0x19, 0xE9, 0x70, 0x25, 0x80,
+0x26, 0x90, 0x94, 0x4B, 0xE0, 0xFD, 0xE5, 0x71,
+0xD3, 0x9D, 0x40, 0x10, 0xAB, 0x02, 0x90, 0x94,
+0x4F, 0xE9, 0xF0, 0xAF, 0x71, 0x12, 0xC7, 0xC9,
+0x8F, 0x6F, 0x80, 0x0B, 0x90, 0x94, 0x4B, 0xE0,
+0xF5, 0x6F, 0x80, 0x03, 0x0F, 0x80, 0xC6, 0xAF,
+0x02, 0x90, 0x91, 0x0B, 0xE5, 0x70, 0xF0, 0xE4,
+0xFB, 0xAD, 0x6F, 0x02, 0x27, 0x3D, 0x90, 0x89,
+0x3C, 0x12, 0x05, 0x28, 0xE0, 0x22, 0xF5, 0x82,
+0xE4, 0x34, 0x90, 0xF5, 0x83, 0x22, 0xE4, 0xFD,
+0x01, 0x99, 0x7D, 0x1F, 0x7F, 0x6F, 0x11, 0xDA,
+0x90, 0x05, 0x27, 0xE0, 0x54, 0xBF, 0xF0, 0x90,
+0x85, 0xBF, 0x74, 0x04, 0xF0, 0x22, 0x12, 0x8F,
+0x9E, 0x90, 0x04, 0x24, 0xE0, 0xF5, 0x5B, 0xE4,
+0xFF, 0x12, 0x8D, 0x74, 0x11, 0x24, 0x75, 0xF0,
+0x0E, 0xA4, 0x24, 0x19, 0xF5, 0x82, 0xE4, 0x34,
+0x92, 0xF5, 0x83, 0xEE, 0xF0, 0x11, 0x24, 0x12,
+0x97, 0x34, 0xF5, 0x83, 0xEE, 0xF0, 0x0F, 0xEF,
+0xB4, 0x03, 0xDE, 0x22, 0x8F, 0x82, 0x75, 0x83,
+0x00, 0x12, 0x03, 0x0F, 0x25, 0x5B, 0xFE, 0xEF,
+0x22, 0x12, 0xCE, 0xC3, 0xFF, 0x54, 0x0F, 0xF5,
+0x5E, 0xEF, 0xC4, 0x54, 0x0F, 0x64, 0x0F, 0x70,
+0x3D, 0x90, 0x92, 0x0A, 0xE0, 0x54, 0xFE, 0xFF,
+0xF0, 0xE5, 0x5E, 0x54, 0x07, 0x25, 0xE0, 0xFE,
+0xEF, 0x54, 0xF1, 0x4E, 0xF0, 0x12, 0x8F, 0xED,
+0xC4, 0x13, 0x54, 0x07, 0x90, 0x92, 0xBB, 0x20,
+0xE0, 0x05, 0x74, 0x06, 0xF0, 0x80, 0x03, 0x74,
+0x01, 0xF0, 0x31, 0x34, 0xAF, 0x5E, 0x12, 0x96,
+0xDE, 0xBF, 0x01, 0x06, 0xE4, 0xFD, 0xFF, 0x12,
+0x95, 0xF6, 0x7F, 0x02, 0x21, 0x30, 0xE5, 0x5E,
+0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x37, 0xF9, 0x74,
+0x92, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0xC0, 0x02,
+0xC0, 0x01, 0xE5, 0x5D, 0x24, 0x01, 0xF9, 0xE4,
+0x35, 0x5C, 0x85, 0x5B, 0x1B, 0xF5, 0x1C, 0x89,
+0x1D, 0x75, 0x1E, 0x04, 0xD0, 0x01, 0xD0, 0x02,
+0x12, 0x6A, 0x21, 0xE5, 0x5E, 0x12, 0x97, 0xD7,
+0x54, 0xF7, 0x12, 0x98, 0xCD, 0xC4, 0x54, 0x0F,
+0x14, 0x65, 0x5E, 0x70, 0x76, 0x90, 0x85, 0xC5,
+0xE0, 0x70, 0x07, 0x90, 0x85, 0xBC, 0xE0, 0x30,
+0xE0, 0x04, 0x7F, 0x05, 0x80, 0x62, 0x12, 0x98,
+0xCE, 0xC4, 0x54, 0x0F, 0x90, 0x92, 0x0B, 0xF0,
+0x12, 0x8F, 0xF3, 0xFC, 0x54, 0x0F, 0xC4, 0x54,
+0xF0, 0xFE, 0x90, 0x92, 0x0A, 0xE0, 0x54, 0x0F,
+0x4E, 0xF0, 0xEC, 0x54, 0x60, 0xC4, 0x54, 0x0F,
+0xFF, 0x90, 0x92, 0x89, 0xE0, 0x54, 0xF9, 0x4F,
+0xF0, 0x90, 0x92, 0x0A, 0xE0, 0x54, 0xF1, 0xF0,
+0x90, 0x05, 0x58, 0x74, 0x02, 0xF0, 0x90, 0x92,
+0xB1, 0xE0, 0x90, 0x92, 0xB5, 0x30, 0xE0, 0x0B,
+0xE0, 0x54, 0xFE, 0xF0, 0x54, 0xC1, 0x44, 0x02,
+0xF0, 0x80, 0x07, 0xE0, 0x44, 0x01, 0xF0, 0x54,
+0xC1, 0xF0, 0x90, 0x92, 0x0A, 0xE0, 0x44, 0x01,
+0xF0, 0xE4, 0x90, 0x92, 0x0C, 0xF0, 0x7F, 0x03,
+0x12, 0xC8, 0x4A, 0x22, 0x7D, 0x20, 0xE4, 0xFF,
+0x02, 0x7B, 0xBF, 0x90, 0x92, 0x09, 0xE0, 0x30,
+0xE0, 0x09, 0x31, 0x34, 0xE4, 0x90, 0x92, 0x0C,
+0xF0, 0x31, 0x4C, 0x22, 0x90, 0x92, 0x0A, 0xE0,
+0xC3, 0x13, 0x54, 0x07, 0xFF, 0x75, 0xF0, 0x0E,
+0xA4, 0x24, 0x17, 0xF5, 0x82, 0xE4, 0x34, 0x92,
+0xF5, 0x83, 0xE0, 0xFE, 0xEF, 0x75, 0xF0, 0x0E,
+0xA4, 0x24, 0x16, 0xF5, 0x82, 0xE4, 0x34, 0x92,
+0xF5, 0x83, 0xE0, 0x90, 0x91, 0x6F, 0xF0, 0x90,
+0x91, 0x6E, 0xEE, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F,
+0x54, 0x7E, 0x01, 0x02, 0x61, 0x41, 0xE4, 0xF5,
+0x76, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x73, 0x12,
+0xAC, 0x4B, 0x70, 0x6E, 0x12, 0xCE, 0x7E, 0xF0,
+0x75, 0x76, 0x01, 0x90, 0x85, 0xBC, 0xE0, 0x30,
+0xE0, 0x11, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x02,
+0x03, 0xE4, 0xF5, 0x76, 0xD1, 0x37, 0xEF, 0x70,
+0x02, 0xF5, 0x76, 0xE5, 0x76, 0x60, 0x4B, 0x90,
+0x85, 0xC8, 0xE0, 0x20, 0xE2, 0x02, 0x51, 0x03,
+0x90, 0x85, 0xC9, 0xE0, 0x44, 0x10, 0xF0, 0x90,
+0x85, 0xCE, 0xE0, 0x60, 0x04, 0x64, 0x01, 0x70,
+0x16, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x90, 0x85,
+0xCE, 0xE0, 0x71, 0xBD, 0x90, 0x91, 0x6F, 0x31,
+0x7B, 0x90, 0x85, 0xCE, 0xE0, 0x80, 0x15, 0xE4,
+0x90, 0x91, 0x6E, 0x71, 0xB2, 0x90, 0x91, 0x6F,
+0x31, 0x7B, 0x90, 0x85, 0xCE, 0xE0, 0x75, 0xF0,
+0x03, 0xA4, 0x24, 0xFE, 0x71, 0xBD, 0x90, 0x85,
+0xDE, 0xF0, 0x22, 0x7D, 0x01, 0x7F, 0x04, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95,
+0x4E, 0xED, 0xF0, 0x90, 0x85, 0xC1, 0xE0, 0xFE,
+0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
+0x61, 0x62, 0xEE, 0x12, 0x8F, 0xB7, 0x30, 0xE0,
+0x02, 0x61, 0x62, 0x90, 0x85, 0xC8, 0xE0, 0xFE,
+0x6F, 0x70, 0x02, 0x61, 0x62, 0xEF, 0x70, 0x02,
+0x41, 0xCD, 0x24, 0xFE, 0x70, 0x02, 0x61, 0x0A,
+0x24, 0xFE, 0x60, 0x4D, 0x24, 0xFC, 0x70, 0x02,
+0x61, 0x49, 0x24, 0xFC, 0x60, 0x02, 0x61, 0x5B,
+0xEE, 0xB4, 0x0E, 0x03, 0x12, 0x74, 0x93, 0x90,
+0x85, 0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12,
+0x79, 0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06,
+0x03, 0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0,
+0xB4, 0x04, 0x0F, 0x90, 0x95, 0x4E, 0xE0, 0xFF,
+0x60, 0x05, 0x12, 0x6D, 0x4C, 0x80, 0x03, 0x12,
+0x79, 0x61, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x08,
+0x60, 0x02, 0x61, 0x5B, 0x12, 0x7A, 0xB9, 0x61,
+0x5B, 0x90, 0x85, 0xC8, 0xE0, 0x70, 0x05, 0x7F,
+0x01, 0x12, 0x79, 0x80, 0x90, 0x85, 0xC8, 0xE0,
+0xB4, 0x06, 0x03, 0x12, 0x73, 0x8E, 0x90, 0x85,
+0xC8, 0xE0, 0xB4, 0x0E, 0x08, 0x71, 0x67, 0xBF,
+0x01, 0x03, 0x12, 0x74, 0x93, 0x90, 0x85, 0xC8,
+0xE0, 0x64, 0x0C, 0x60, 0x02, 0x61, 0x5B, 0x71,
+0x67, 0xEF, 0x64, 0x01, 0x60, 0x02, 0x61, 0x5B,
+0x12, 0x70, 0x9E, 0x61, 0x5B, 0x90, 0x85, 0xC8,
+0xE0, 0xB4, 0x0E, 0x08, 0x71, 0x67, 0xBF, 0x01,
+0x03, 0x12, 0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0,
+0xB4, 0x06, 0x03, 0x12, 0x73, 0x8E, 0x90, 0x85,
+0xC8, 0xE0, 0xB4, 0x0C, 0x08, 0x71, 0x67, 0xBF,
+0x01, 0x03, 0x12, 0x70, 0x9E, 0x90, 0x85, 0xC8,
+0xE0, 0x64, 0x04, 0x70, 0x5E, 0x12, 0xCA, 0xB7,
+0xEF, 0x64, 0x01, 0x70, 0x56, 0x12, 0x77, 0xFE,
+0x80, 0x51, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E,
+0x08, 0x71, 0x67, 0xBF, 0x01, 0x03, 0x12, 0x74,
+0x93, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03,
+0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
+0x0C, 0x08, 0x71, 0x67, 0xBF, 0x01, 0x03, 0x12,
+0x70, 0x9E, 0x90, 0x85, 0xC8, 0xE0, 0x70, 0x05,
+0x7F, 0x01, 0x12, 0x79, 0x80, 0x90, 0x85, 0xC8,
+0xE0, 0xB4, 0x04, 0x17, 0x12, 0x79, 0xF3, 0x80,
+0x12, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0C, 0x0B,
+0x12, 0xAA, 0x28, 0x54, 0x3F, 0x30, 0xE0, 0x03,
+0x12, 0x7A, 0x8A, 0x90, 0x85, 0xC8, 0x12, 0xCE,
+0xCC, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x7A,
+0x29, 0xEF, 0x64, 0x01, 0x60, 0x05, 0x75, 0x0F,
+0x01, 0x80, 0x24, 0x90, 0x85, 0xC1, 0xE0, 0x13,
+0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x05, 0x75,
+0x0F, 0x02, 0x80, 0x13, 0x90, 0x85, 0xC7, 0xE0,
+0xD3, 0x94, 0x04, 0x40, 0x05, 0x75, 0x0F, 0x08,
+0x80, 0x05, 0x12, 0xCB, 0x4E, 0x80, 0x0E, 0x90,
+0x01, 0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8,
+0xE5, 0x0F, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xF0, 0x90, 0x85, 0xCE, 0xE0, 0x75,
+0xF0, 0x03, 0xA4, 0x24, 0xFE, 0xFF, 0x90, 0x85,
+0xCD, 0xE0, 0x2F, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x8B, 0x5B, 0x8A, 0x5C, 0x89,
+0x5D, 0x90, 0x05, 0x27, 0xE0, 0xF5, 0x5E, 0x8B,
+0x1B, 0x8A, 0x1C, 0x89, 0x1D, 0x75, 0x1E, 0x01,
+0x7B, 0x01, 0x7A, 0x85, 0x79, 0xBC, 0x12, 0x6A,
+0x21, 0x12, 0x98, 0xCE, 0xFF, 0xC3, 0x13, 0x20,
+0xE0, 0x02, 0x81, 0x78, 0x90, 0x85, 0xBC, 0xE0,
+0x30, 0xE0, 0x6C, 0xD1, 0xA0, 0x75, 0x5E, 0x21,
+0xD1, 0xB0, 0x30, 0xE0, 0x04, 0xD1, 0xC4, 0x80,
+0x0D, 0xE4, 0x90, 0x85, 0xBD, 0xF0, 0xA3, 0xF0,
+0x7D, 0x40, 0xFF, 0x12, 0x7C, 0x41, 0xD1, 0xA7,
+0x54, 0x1F, 0x30, 0xE0, 0x03, 0x43, 0x5E, 0x12,
+0xEF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x03, 0x43,
+0x5E, 0x14, 0x90, 0x85, 0xBC, 0xE0, 0xC4, 0x13,
+0x54, 0x07, 0x30, 0xE0, 0x03, 0x43, 0x5E, 0x80,
+0x12, 0xCF, 0x20, 0x54, 0x03, 0x20, 0xE0, 0x03,
+0x43, 0x5E, 0x40, 0xB1, 0x1A, 0x90, 0x85, 0xBF,
+0xE0, 0x70, 0x04, 0x7F, 0x01, 0xB1, 0x21, 0xD1,
+0xB9, 0x30, 0xE0, 0x04, 0x7F, 0x04, 0x80, 0x0B,
+0xD1, 0x37, 0xEF, 0x60, 0x04, 0x7F, 0x01, 0x80,
+0x02, 0x7F, 0x02, 0xB1, 0x21, 0x80, 0x7B, 0xB1,
+0x17, 0x90, 0x85, 0xBF, 0xE0, 0x64, 0x04, 0x60,
+0x02, 0xA1, 0x12, 0xFF, 0xB1, 0x21, 0xA1, 0x12,
+0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x6B, 0xD1,
+0xA0, 0x43, 0x5E, 0x31, 0xD1, 0xB0, 0x30, 0xE0,
+0x04, 0xD1, 0xC4, 0x80, 0x07, 0x7D, 0x40, 0xE4,
+0xFF, 0x12, 0x7C, 0x41, 0xD1, 0xA7, 0x54, 0x1F,
+0x30, 0xE0, 0x03, 0x43, 0x5E, 0x02, 0xEF, 0xC4,
+0x54, 0x0F, 0x30, 0xE0, 0x03, 0x43, 0x5E, 0x04,
+0xB1, 0x1A, 0xD1, 0xB9, 0x30, 0xE0, 0x0A, 0xD1,
+0xEB, 0x60, 0x2F, 0xE4, 0xFD, 0x7F, 0x02, 0x80,
+0x1D, 0xF1, 0xED, 0x90, 0x85, 0xC0, 0xE0, 0xB4,
+0x02, 0x18, 0x12, 0x7A, 0xA2, 0xD1, 0x37, 0xBF,
+0x01, 0x09, 0x90, 0x85, 0xC7, 0xE0, 0xFF, 0x7D,
+0x01, 0x80, 0x03, 0xE4, 0xFD, 0xFF, 0x51, 0x07,
+0x80, 0x08, 0x90, 0x85, 0xC8, 0xE0, 0x90, 0x85,
+0xC0, 0xF0, 0x90, 0x05, 0x40, 0x74, 0x22, 0xF0,
+0x80, 0x28, 0xB1, 0x17, 0x90, 0x85, 0xC0, 0xE0,
+0xB4, 0x02, 0x06, 0x7D, 0x01, 0x7F, 0x04, 0x80,
+0x0B, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x08, 0x06,
+0x7D, 0x01, 0x7F, 0x0C, 0x51, 0x07, 0x12, 0xCA,
+0xAD, 0x90, 0x85, 0xC7, 0x12, 0xAC, 0x09, 0x12,
+0xCA, 0x75, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x75,
+0x5E, 0x01, 0x90, 0x05, 0x27, 0xE5, 0x5E, 0xF0,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x85, 0xBF, 0xE0, 0x90, 0x95, 0x4D, 0xF0,
+0x6F, 0x70, 0x02, 0xC1, 0x32, 0xEF, 0x14, 0x60,
+0x46, 0x14, 0x60, 0x72, 0x14, 0x70, 0x02, 0xA1,
+0xD9, 0x14, 0x70, 0x02, 0xC1, 0x06, 0x24, 0x04,
+0x60, 0x02, 0xC1, 0x32, 0x90, 0x95, 0x4D, 0xE0,
+0xB4, 0x04, 0x05, 0x12, 0xC0, 0xBA, 0xC1, 0x32,
+0x90, 0x95, 0x4D, 0xE0, 0xB4, 0x02, 0x05, 0x12,
+0xC0, 0xAB, 0xC1, 0x32, 0x90, 0x95, 0x4D, 0xE0,
+0xB4, 0x03, 0x05, 0x12, 0xC0, 0xBE, 0xC1, 0x32,
+0x90, 0x95, 0x4D, 0xE0, 0x64, 0x01, 0x60, 0x02,
+0xC1, 0x32, 0x12, 0xC0, 0xAD, 0xC1, 0x32, 0x90,
+0x95, 0x4D, 0xE0, 0xB4, 0x04, 0x05, 0x12, 0xC0,
+0xE5, 0xC1, 0x32, 0x90, 0x95, 0x4D, 0xE0, 0xB4,
+0x02, 0x05, 0x12, 0xC0, 0xA3, 0xC1, 0x32, 0x90,
+0x95, 0x4D, 0xE0, 0xB4, 0x03, 0x04, 0xF1, 0xE4,
+0xC1, 0x32, 0x90, 0x95, 0x4D, 0xE0, 0x60, 0x02,
+0xC1, 0x32, 0xF1, 0xCB, 0xC1, 0x32, 0x90, 0x95,
+0x4D, 0xE0, 0xB4, 0x04, 0x04, 0xF1, 0xC1, 0x80,
+0x79, 0x90, 0x95, 0x4D, 0xE0, 0xB4, 0x01, 0x04,
+0xF1, 0x6B, 0x80, 0x6E, 0x90, 0x95, 0x4D, 0xE0,
+0xB4, 0x03, 0x04, 0xF1, 0x7B, 0x80, 0x63, 0x90,
+0x95, 0x4D, 0xE0, 0x70, 0x5D, 0xF1, 0xC7, 0x80,
+0x59, 0x90, 0x95, 0x4D, 0xE0, 0xB4, 0x04, 0x05,
+0x12, 0xCA, 0x97, 0x80, 0x4D, 0x90, 0x95, 0x4D,
+0xE0, 0xB4, 0x01, 0x04, 0xF1, 0xD9, 0x80, 0x42,
+0x90, 0x95, 0x4D, 0xE0, 0xB4, 0x02, 0x05, 0x12,
+0xC0, 0xD2, 0x80, 0x36, 0x90, 0x95, 0x4D, 0xE0,
+0x70, 0x30, 0xF1, 0xD7, 0x80, 0x2C, 0x90, 0x95,
+0x4D, 0xE0, 0xB4, 0x03, 0x05, 0x12, 0xCA, 0xA8,
+0x80, 0x20, 0x90, 0x95, 0x4D, 0xE0, 0xB4, 0x01,
+0x05, 0x12, 0x9F, 0xE2, 0x80, 0x14, 0x90, 0x95,
+0x4D, 0xE0, 0xB4, 0x02, 0x05, 0x12, 0xC0, 0xC3,
+0x80, 0x08, 0x90, 0x95, 0x4D, 0xE0, 0x70, 0x02,
+0xF1, 0xD2, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
+0x05, 0x43, 0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02,
+0x7F, 0x01, 0x22, 0xE4, 0x90, 0x94, 0x66, 0xF0,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x51, 0x12, 0xAC,
+0x4B, 0x70, 0x4C, 0x12, 0xCF, 0x10, 0xF0, 0x12,
+0xCE, 0x7E, 0x12, 0xCF, 0x18, 0xE4, 0x90, 0x85,
+0xCC, 0xF0, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0,
+0x15, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x02, 0x05,
+0xE4, 0x90, 0x94, 0x66, 0xF0, 0xD1, 0x37, 0xEF,
+0x70, 0x04, 0x90, 0x94, 0x66, 0xF0, 0x90, 0x94,
+0x66, 0xE0, 0x60, 0x1B, 0x90, 0x85, 0xC8, 0xE0,
+0x20, 0xE2, 0x02, 0x51, 0x03, 0x90, 0x85, 0xC9,
+0xE0, 0x44, 0x10, 0x12, 0xBD, 0xD0, 0x90, 0x85,
+0xCD, 0xE0, 0x90, 0x91, 0x6F, 0x31, 0x7B, 0x22,
+0x7D, 0x03, 0x7F, 0x02, 0x02, 0x7B, 0xFD, 0x90,
+0x85, 0xBC, 0xE0, 0xFF, 0x13, 0x13, 0x13, 0x22,
+0x90, 0x85, 0xBC, 0xE0, 0x13, 0x13, 0x54, 0x3F,
+0x22, 0x90, 0x85, 0xBC, 0xE0, 0xFF, 0xC4, 0x13,
+0x13, 0x54, 0x03, 0x22, 0x90, 0x01, 0x34, 0x74,
+0x40, 0xF0, 0xFD, 0xE4, 0xFF, 0x12, 0x7C, 0xA9,
+0x43, 0x5E, 0x08, 0x22, 0xD1, 0xB9, 0x30, 0xE0,
+0x0A, 0xD1, 0xEB, 0x60, 0x06, 0x7D, 0x01, 0x7F,
+0x02, 0x51, 0x07, 0xD1, 0xEB, 0x60, 0x03, 0x12,
+0xAC, 0xDF, 0x22, 0x90, 0x85, 0xC0, 0xE0, 0x64,
+0x02, 0x22, 0xAE, 0x07, 0xD1, 0x37, 0xBF, 0x01,
+0x11, 0x12, 0xCF, 0x20, 0x54, 0x03, 0x20, 0xE0,
+0x09, 0xAF, 0x06, 0x7D, 0x01, 0x51, 0x07, 0x7F,
+0x01, 0x22, 0x7F, 0x00, 0x22, 0x90, 0x85, 0xBC,
+0xE0, 0xFF, 0x30, 0xE0, 0x3C, 0x90, 0x85, 0xC0,
+0xE0, 0x7E, 0x00, 0xB4, 0x02, 0x02, 0x7E, 0x01,
+0x90, 0x85, 0xBF, 0xE0, 0x7D, 0x00, 0xB4, 0x04,
+0x02, 0x7D, 0x01, 0xED, 0x4E, 0x70, 0x22, 0xEF,
+0xC3, 0x13, 0x30, 0xE0, 0x02, 0x80, 0x1B, 0xD1,
+0xD4, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x08, 0x06,
+0xE4, 0xFD, 0x7F, 0x0C, 0x80, 0x09, 0x90, 0x85,
+0xC0, 0xE0, 0x70, 0x05, 0xFD, 0x7F, 0x04, 0x51,
+0x07, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0xD1, 0x37, 0xBF, 0x01, 0x04, 0x7F, 0x01,
+0x80, 0x02, 0x7F, 0x02, 0xB1, 0x21, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x7D, 0x20, 0x7F, 0xFF, 0x12,
+0x98, 0xDA, 0xF1, 0x7D, 0x90, 0x85, 0xBF, 0x74,
+0x02, 0xF0, 0x22, 0x80, 0xF5, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x96, 0x87, 0x90,
+0x06, 0xB7, 0x74, 0x11, 0xF0, 0x7F, 0x03, 0x7E,
+0x00, 0x12, 0x7C, 0x9F, 0x90, 0x06, 0xB4, 0xE0,
+0x54, 0x0F, 0x70, 0xF1, 0x7F, 0x02, 0x12, 0x7B,
+0x51, 0xEF, 0x54, 0xFE, 0xFD, 0x7F, 0x02, 0x12,
+0x7B, 0x3E, 0x90, 0x01, 0x00, 0x74, 0x3F, 0xF0,
+0xA3, 0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x05, 0x53,
+0xE0, 0x44, 0x20, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xF1, 0xED, 0x7D, 0x23, 0x80, 0xA6, 0xF1,
+0xCB, 0x80, 0xA0, 0x90, 0x85, 0xBF, 0x74, 0x01,
+0xF0, 0x22, 0xF1, 0xCB, 0x02, 0x9F, 0xE2, 0xF1,
+0xCB, 0x7D, 0x21, 0x7F, 0xFF, 0x12, 0xC0, 0xDE,
+0x74, 0x03, 0xF0, 0x22, 0x12, 0xC0, 0xDB, 0x74,
+0x01, 0xF0, 0x22, 0x21, 0x3B, 0x90, 0x05, 0x27,
+0xE0, 0x44, 0x40, 0xF0, 0x22, 0x8B, 0x5B, 0x8A,
+0x5C, 0x89, 0x5D, 0x90, 0x92, 0xBC, 0xE0, 0x54,
+0xFE, 0x12, 0x97, 0xE6, 0xFC, 0x30, 0xE0, 0x43,
+0x90, 0x92, 0xBD, 0xE0, 0x44, 0x01, 0xFE, 0xF0,
+0x12, 0x02, 0xF6, 0x54, 0xFE, 0xFD, 0xEE, 0x54,
+0x01, 0x4D, 0x90, 0x92, 0xBD, 0x12, 0x8F, 0x97,
+0x90, 0x92, 0xBE, 0xF0, 0xEC, 0xC3, 0x13, 0x54,
+0x7F, 0xFF, 0xA3, 0x12, 0x8E, 0xCE, 0xFE, 0xC3,
+0x9F, 0x90, 0x92, 0xC0, 0xF0, 0xA3, 0xEE, 0xF0,
+0xBE, 0x64, 0x04, 0x74, 0x01, 0xF0, 0x22, 0x90,
+0x92, 0xC1, 0xE0, 0x64, 0x96, 0x70, 0x4C, 0x74,
+0x03, 0xF0, 0x22, 0x90, 0x92, 0xBD, 0xE0, 0x54,
+0xFE, 0x12, 0x98, 0xCD, 0xFF, 0x54, 0x01, 0xFE,
+0x90, 0x92, 0xB1, 0x11, 0x94, 0x54, 0xFE, 0xFF,
+0xEE, 0x54, 0x01, 0x12, 0x8F, 0x96, 0x90, 0x92,
+0xB2, 0x12, 0x8E, 0xCE, 0x90, 0x92, 0xB3, 0xF0,
+0xE4, 0xA3, 0xF0, 0x90, 0x92, 0xB3, 0xE0, 0xFF,
+0xB4, 0x64, 0x05, 0x74, 0x01, 0xF0, 0x80, 0x0A,
+0xEF, 0xB4, 0x96, 0x06, 0x90, 0x92, 0xB3, 0x74,
+0x03, 0xF0, 0x90, 0x92, 0xB3, 0xE0, 0x04, 0x90,
+0x92, 0xB6, 0xF0, 0x22, 0xE0, 0x54, 0xFE, 0x4E,
+0xFE, 0xF0, 0xEF, 0x22, 0x12, 0x02, 0xF6, 0xFF,
+0x54, 0x01, 0xFE, 0x90, 0x92, 0x04, 0x11, 0x94,
+0x54, 0x02, 0xFF, 0xEE, 0x54, 0xFD, 0x12, 0x8F,
+0x96, 0x90, 0x92, 0x05, 0x12, 0x8E, 0xCE, 0x90,
+0x92, 0x06, 0xF0, 0x51, 0x85, 0xF0, 0x90, 0x92,
+0x04, 0xE0, 0x54, 0x01, 0xFF, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0xEF, 0x64, 0x01, 0x70,
+0x19, 0x31, 0x11, 0x60, 0x09, 0x31, 0x0A, 0x12,
+0x7B, 0xFD, 0x51, 0x7C, 0x80, 0x07, 0x31, 0x0A,
+0x12, 0x7B, 0xBF, 0x51, 0x8E, 0x12, 0x7A, 0x8A,
+0x80, 0x17, 0x31, 0x11, 0x60, 0x07, 0x31, 0x0A,
+0x12, 0x7B, 0xFD, 0x80, 0x05, 0x31, 0x0A, 0x12,
+0x7B, 0xBF, 0x51, 0x49, 0x51, 0x50, 0x12, 0x7A,
+0xB9, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90,
+0x01, 0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F, 0x03,
+0x22, 0x90, 0x92, 0x06, 0xE0, 0x90, 0x01, 0x3F,
+0x22, 0xE4, 0x90, 0x94, 0x55, 0xF0, 0x91, 0x4C,
+0x60, 0x02, 0x41, 0x1C, 0x90, 0x85, 0xC5, 0xE0,
+0x70, 0x02, 0x41, 0x1C, 0x90, 0x05, 0x63, 0xE0,
+0x90, 0x92, 0xD4, 0xF0, 0x90, 0x05, 0x62, 0xE0,
+0x90, 0x92, 0xD5, 0xF0, 0x90, 0x05, 0x61, 0xE0,
+0x90, 0x92, 0xD6, 0xF0, 0x90, 0x05, 0x60, 0xE0,
+0x90, 0x92, 0xD7, 0xF0, 0x91, 0x75, 0xF0, 0x90,
+0x85, 0xC9, 0xE0, 0x54, 0xEC, 0xF0, 0x51, 0x40,
+0x24, 0xFD, 0x50, 0x02, 0x80, 0x0D, 0x90, 0x85,
+0xBC, 0xE0, 0x30, 0xE0, 0x04, 0x71, 0x20, 0x80,
+0x02, 0x51, 0xD2, 0x51, 0x40, 0x64, 0x01, 0x70,
+0x3A, 0x90, 0x06, 0xAB, 0xE0, 0x90, 0x85, 0xCC,
+0xF0, 0x90, 0x06, 0xA9, 0xE0, 0x30, 0xE5, 0x06,
+0xA3, 0xE0, 0x90, 0x94, 0x55, 0xF0, 0x90, 0x94,
+0x55, 0xE0, 0xFF, 0x60, 0x02, 0x80, 0x05, 0x90,
+0x85, 0xCB, 0xE0, 0xFF, 0x90, 0x85, 0xCB, 0xEF,
+0xF0, 0xA3, 0xE0, 0xFF, 0x70, 0x08, 0x90, 0x85,
+0xCB, 0xE0, 0xFE, 0xFF, 0x80, 0x00, 0x90, 0x85,
+0xCC, 0xEF, 0xF0, 0x12, 0xCC, 0x8C, 0xE4, 0x90,
+0x85, 0xCE, 0xF0, 0xA3, 0xF0, 0x12, 0xCC, 0x6B,
+0xF0, 0x51, 0x28, 0x13, 0x54, 0x1F, 0x30, 0xE0,
+0x59, 0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x20,
+0xE0, 0x23, 0x51, 0x38, 0x6F, 0x70, 0x4B, 0xEF,
+0x60, 0x48, 0x90, 0x85, 0xC2, 0xE0, 0x44, 0x40,
+0xF0, 0x12, 0xCF, 0x10, 0x31, 0x06, 0x12, 0x7B,
+0xFD, 0x51, 0x95, 0x91, 0x3C, 0x90, 0x85, 0xCC,
+0xE0, 0x14, 0xF0, 0x80, 0x2D, 0x90, 0x85, 0xC3,
+0xE0, 0xC4, 0x54, 0x0F, 0x64, 0x01, 0x70, 0x22,
+0x51, 0x38, 0xFE, 0x6F, 0x60, 0x1C, 0x90, 0x05,
+0x73, 0xE0, 0xFF, 0xEE, 0x6F, 0x60, 0x13, 0x51,
+0x28, 0x54, 0x3F, 0x30, 0xE0, 0x0C, 0xEF, 0x54,
+0xBF, 0x31, 0x06, 0x12, 0x7B, 0xBF, 0x51, 0x50,
+0x51, 0x49, 0x51, 0x30, 0x90, 0x85, 0xBC, 0xE0,
+0xC3, 0x13, 0x20, 0xE0, 0x02, 0x51, 0x30, 0x22,
+0x90, 0x85, 0xC2, 0xE0, 0xFF, 0x13, 0x13, 0x22,
+0x90, 0x85, 0xC2, 0xE0, 0x44, 0x04, 0xF0, 0x22,
+0x90, 0x85, 0xCB, 0xE0, 0xFF, 0xA3, 0xE0, 0x22,
+0x90, 0x85, 0xC3, 0xE0, 0xFF, 0xC4, 0x54, 0x0F,
+0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C, 0xA9,
+0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0xA9, 0x12,
+0xA6, 0x43, 0x51, 0x49, 0x7F, 0x01, 0x51, 0x9C,
+0x90, 0x92, 0x04, 0xE0, 0x30, 0xE0, 0x14, 0x51,
+0x7C, 0x90, 0x92, 0x07, 0xE0, 0x60, 0x05, 0x14,
+0xF0, 0x02, 0x7A, 0x8A, 0x51, 0x85, 0xF0, 0xE4,
+0xFF, 0x11, 0xC5, 0x22, 0x90, 0x92, 0x06, 0xE0,
+0x90, 0x05, 0x73, 0xF0, 0x22, 0x90, 0x92, 0x05,
+0xE0, 0x14, 0x90, 0x92, 0x07, 0x22, 0x7D, 0x02,
+0x7F, 0x02, 0x12, 0x7C, 0x41, 0x7D, 0x01, 0x7F,
+0x02, 0x02, 0x7C, 0x41, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x92, 0xCF, 0xE0, 0xFE,
+0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x1E, 0x90,
+0x95, 0x15, 0x74, 0x1E, 0xF0, 0x90, 0x95, 0x23,
+0x74, 0x01, 0xF0, 0x90, 0x95, 0x17, 0xEF, 0xF0,
+0x7B, 0x01, 0x7A, 0x95, 0x79, 0x15, 0x12, 0x5E,
+0x10, 0x7F, 0x04, 0xF1, 0xC2, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xE4, 0xF5, 0x76, 0x90, 0x06, 0xA9,
+0xE0, 0xF5, 0x76, 0x54, 0xC0, 0x70, 0x07, 0x71,
+0x18, 0x54, 0xFD, 0xF0, 0x61, 0xFA, 0xE5, 0x76,
+0x30, 0xE6, 0x17, 0x90, 0x85, 0xC5, 0xE0, 0x64,
+0x01, 0x70, 0x11, 0x71, 0x8D, 0x64, 0x02, 0x60,
+0x05, 0x12, 0x77, 0x61, 0x80, 0x06, 0x91, 0x10,
+0x80, 0x02, 0x71, 0x18, 0xE5, 0x76, 0x90, 0x85,
+0xC9, 0x30, 0xE7, 0x07, 0x91, 0x99, 0x12, 0xA1,
+0x7B, 0x81, 0x43, 0xE0, 0x54, 0xFD, 0xF0, 0x22,
+0x90, 0x85, 0xC9, 0xE0, 0x54, 0xFE, 0xF0, 0x22,
+0x90, 0x06, 0xA9, 0xE0, 0x90, 0x94, 0x56, 0xF0,
+0xE0, 0xFD, 0x54, 0xC0, 0x70, 0x04, 0x71, 0x18,
+0x80, 0x57, 0xED, 0x30, 0xE6, 0x3F, 0x90, 0x85,
+0xC5, 0xE0, 0x64, 0x02, 0x70, 0x27, 0x90, 0x85,
+0xC1, 0xE0, 0xFF, 0xC3, 0x13, 0x20, 0xE0, 0x09,
+0x90, 0x85, 0xC9, 0xE0, 0x44, 0x01, 0xF0, 0x80,
+0x1A, 0x71, 0x94, 0x64, 0x01, 0x70, 0x20, 0x90,
+0x85, 0xC9, 0xE0, 0x44, 0x04, 0xF0, 0x7F, 0x01,
+0x12, 0x62, 0x8E, 0x80, 0x12, 0x71, 0x8D, 0x64,
+0x02, 0x60, 0x05, 0x12, 0x77, 0x61, 0x80, 0x07,
+0x12, 0x79, 0x41, 0x80, 0x02, 0x71, 0x18, 0x90,
+0x94, 0x56, 0xE0, 0x90, 0x85, 0xC9, 0x30, 0xE7,
+0x07, 0x91, 0x99, 0x12, 0xA1, 0x7B, 0x81, 0x43,
+0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90, 0x85, 0xC9,
+0xE0, 0x44, 0x01, 0xF0, 0x90, 0x85, 0xC3, 0xE0,
+0x54, 0x0F, 0x22, 0x51, 0x28, 0x13, 0x54, 0x1F,
+0x30, 0xE0, 0x0B, 0xEF, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x30, 0xE0, 0x02, 0x91, 0x3C, 0x91, 0xD7,
+0x54, 0x3F, 0x30, 0xE0, 0x09, 0xEF, 0x91, 0xCC,
+0x54, 0x07, 0x70, 0x35, 0x80, 0x31, 0xF1, 0xDD,
+0x40, 0x2D, 0x91, 0x4B, 0x70, 0x2B, 0x71, 0x94,
+0x70, 0x05, 0x12, 0x70, 0xDB, 0x80, 0x23, 0x12,
+0x70, 0xDB, 0x90, 0x85, 0xCF, 0xE0, 0x04, 0xF0,
+0xE0, 0xD3, 0x94, 0x02, 0x40, 0x09, 0x71, 0xF2,
+0xE4, 0x90, 0x85, 0xCF, 0xF0, 0x80, 0x02, 0x91,
+0x10, 0xE4, 0x90, 0x85, 0xCE, 0xF0, 0x22, 0x71,
+0xFA, 0x22, 0x90, 0x85, 0xC2, 0xE0, 0x54, 0xFB,
+0xF0, 0x22, 0x90, 0x85, 0xBC, 0xE0, 0x90, 0x85,
+0xC7, 0x30, 0xE0, 0x05, 0xE0, 0xFF, 0x02, 0xA6,
+0xF2, 0xE0, 0xFF, 0x7D, 0x01, 0x02, 0xA2, 0x07,
+0x90, 0x93, 0x0F, 0x74, 0x01, 0xF0, 0x90, 0x06,
+0x92, 0x04, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x04,
+0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x44, 0x08, 0xF0,
+0x90, 0x85, 0xC8, 0xE0, 0x64, 0x0C, 0x60, 0x05,
+0x91, 0xF4, 0x12, 0x98, 0xD7, 0x7D, 0x08, 0xE4,
+0xFF, 0x02, 0x49, 0x6F, 0x7D, 0x02, 0x7F, 0x02,
+0x02, 0x7C, 0x41, 0x90, 0x85, 0xC1, 0xE0, 0x44,
+0x04, 0xF0, 0x22, 0xE4, 0xFF, 0x12, 0x77, 0x39,
+0xEF, 0x64, 0x01, 0x22, 0x91, 0x4B, 0x70, 0x1C,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x16, 0x90, 0x85,
+0xC9, 0xE0, 0x20, 0xE4, 0x0F, 0x91, 0x75, 0xF0,
+0x90, 0x85, 0xC1, 0xE0, 0x91, 0xCC, 0x54, 0x07,
+0x70, 0x02, 0x71, 0xFA, 0x22, 0x90, 0x01, 0x57,
+0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x02, 0x22,
+0x91, 0x4B, 0x70, 0x14, 0x90, 0x85, 0xC5, 0xE0,
+0x60, 0x0E, 0x90, 0x85, 0xC9, 0xE0, 0x20, 0xE4,
+0x07, 0x91, 0x75, 0x91, 0x9C, 0x12, 0xA1, 0x7B,
+0x22, 0xE0, 0x44, 0x02, 0xF0, 0xE4, 0x90, 0x91,
+0x6E, 0xF0, 0x90, 0x86, 0x6E, 0xE0, 0x90, 0x91,
+0x6F, 0x22, 0x90, 0x01, 0x57, 0xE0, 0x60, 0x1B,
+0x91, 0x78, 0xF0, 0x91, 0xD7, 0x54, 0x3F, 0x30,
+0xE0, 0x03, 0xEF, 0x80, 0x0F, 0xF1, 0xDD, 0x40,
+0x0A, 0xE4, 0xFF, 0x12, 0x77, 0x39, 0xBF, 0x01,
+0x02, 0x71, 0xF2, 0x22, 0x54, 0xFB, 0xF0, 0x90,
+0x85, 0xC9, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90,
+0x85, 0xC1, 0xE0, 0xFF, 0x13, 0x13, 0x22, 0x90,
+0x85, 0xC5, 0xE0, 0x64, 0x02, 0x60, 0x0C, 0x71,
+0x94, 0x60, 0x08, 0x12, 0x7A, 0x29, 0xEF, 0x70,
+0x02, 0x91, 0xF5, 0x22, 0xE4, 0xFD, 0x7F, 0x0C,
+0x02, 0xA2, 0x07, 0xE4, 0xFF, 0x12, 0x77, 0x39,
+0xBF, 0x01, 0x0E, 0x90, 0x85, 0xC5, 0xE0, 0x60,
+0x08, 0x71, 0x18, 0x54, 0x07, 0x70, 0x02, 0x71,
+0xFA, 0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83,
+0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0,
+0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90,
+0x01, 0xC4, 0x74, 0x12, 0xF0, 0x74, 0xAD, 0xA3,
+0xF0, 0x12, 0x71, 0x90, 0xE5, 0x4C, 0x30, 0xE1,
+0x02, 0xF1, 0x44, 0xE5, 0x4C, 0x30, 0xE4, 0x02,
+0xF1, 0xD1, 0xE5, 0x4C, 0x30, 0xE5, 0x03, 0x12,
+0xC8, 0xF9, 0xE5, 0x4C, 0x30, 0xE6, 0x03, 0x12,
+0xC0, 0x0A, 0xE5, 0x4E, 0x30, 0xE0, 0x03, 0x12,
+0xC0, 0x17, 0xE5, 0x4E, 0x30, 0xE1, 0x02, 0xD1,
+0x03, 0xE5, 0x4E, 0x30, 0xE2, 0x03, 0x12, 0xC0,
+0x3A, 0xE5, 0x4E, 0x30, 0xE3, 0x02, 0x91, 0x80,
+0xE5, 0x4E, 0x30, 0xE4, 0x02, 0x91, 0x54, 0xE5,
+0x4E, 0x30, 0xE5, 0x03, 0x12, 0xC0, 0x5D, 0xE5,
+0x4E, 0x30, 0xE6, 0x02, 0x91, 0xFB, 0xE5, 0x4F,
+0x30, 0xE1, 0x02, 0xB1, 0xC9, 0xE5, 0x4F, 0x30,
+0xE4, 0x02, 0xF1, 0xD8, 0xE5, 0x4F, 0x30, 0xE5,
+0x02, 0xD1, 0xCD, 0x74, 0x12, 0x04, 0x90, 0x01,
+0xC4, 0xF0, 0x74, 0xAD, 0xA3, 0xF0, 0xD0, 0x07,
+0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03,
+0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0,
+0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0,
+0x32, 0x90, 0x85, 0xC5, 0xE0, 0x70, 0x07, 0x90,
+0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x11, 0x90, 0x85,
+0xBC, 0xE0, 0x30, 0xE0, 0x08, 0x12, 0xA6, 0x37,
+0xBF, 0x01, 0x04, 0x81, 0xDF, 0xB1, 0xE8, 0x22,
+0x90, 0x85, 0xC5, 0xE0, 0x64, 0x01, 0x70, 0x12,
+0x71, 0x94, 0x60, 0x05, 0x91, 0xF4, 0x02, 0x6B,
+0x98, 0x90, 0x85, 0xC8, 0xE0, 0x70, 0x03, 0x12,
+0xA2, 0x03, 0x22, 0x90, 0x85, 0xBC, 0xE0, 0x30,
+0xE0, 0x06, 0x90, 0x85, 0xBE, 0x74, 0x01, 0xF0,
+0x90, 0x85, 0xC5, 0xE0, 0x70, 0x02, 0xC1, 0xB8,
+0x90, 0x85, 0xDC, 0xE0, 0x04, 0xF0, 0x90, 0x05,
+0x61, 0x12, 0x8B, 0x19, 0x12, 0xCE, 0xA5, 0x90,
+0x05, 0x60, 0x12, 0x8B, 0x19, 0x12, 0x87, 0x20,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x05, 0x62, 0x12, 0x8B, 0x19, 0x78, 0x10,
+0x12, 0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0x12, 0x87, 0x20, 0xC0, 0x04,
+0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3, 0x12,
+0x8B, 0x19, 0x78, 0x18, 0x12, 0x04, 0xD8, 0xD0,
+0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
+0x87, 0x20, 0x90, 0x85, 0xFC, 0xEE, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x92, 0xCF, 0xE0, 0x54, 0xFE,
+0xF0, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x0D, 0x12,
+0xBE, 0xFD, 0x12, 0x51, 0x7D, 0x90, 0x92, 0xCF,
+0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x85, 0xC2, 0xE0,
+0x13, 0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x09,
+0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4, 0x02, 0x51,
+0x8E, 0x90, 0x95, 0x4B, 0xE0, 0x04, 0xF0, 0xE0,
+0xC3, 0x94, 0x80, 0x40, 0x0B, 0x90, 0x01, 0x98,
+0xE0, 0x54, 0xFE, 0xF0, 0xE0, 0x44, 0x01, 0xF0,
+0x7F, 0x01, 0xF1, 0xC2, 0x90, 0x92, 0x04, 0xE0,
+0x30, 0xE0, 0x09, 0x90, 0x01, 0x3B, 0xE0, 0x30,
+0xE4, 0x02, 0x51, 0x8E, 0x22, 0xE4, 0xF5, 0x76,
+0x90, 0x85, 0xBB, 0xE0, 0xFF, 0xE5, 0x76, 0xC3,
+0x9F, 0x50, 0x68, 0xAF, 0x76, 0x12, 0x77, 0x39,
+0xEF, 0x60, 0x5C, 0xE5, 0x76, 0x13, 0x13, 0x13,
+0x54, 0x1F, 0xFF, 0xE5, 0x76, 0x54, 0x07, 0xFE,
+0x74, 0x75, 0x2F, 0x12, 0xC7, 0xA9, 0xFD, 0xAF,
+0x06, 0x12, 0xC7, 0xB5, 0x80, 0x05, 0xC3, 0x33,
+0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEF, 0x5D,
+0x60, 0x35, 0xE5, 0x76, 0xC4, 0x54, 0xF0, 0x24,
+0x01, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
+0xE0, 0x20, 0xE7, 0x02, 0x80, 0x13, 0xE5, 0x76,
+0xC4, 0x54, 0xF0, 0x24, 0x02, 0xF5, 0x82, 0xE4,
+0x34, 0x81, 0xF5, 0x83, 0xE0, 0xFF, 0x20, 0xE7,
+0x09, 0x90, 0x01, 0xC1, 0xE0, 0x44, 0x20, 0xF0,
+0x80, 0x05, 0xAD, 0x76, 0x12, 0x9A, 0xB5, 0x05,
+0x76, 0x80, 0x8D, 0x22, 0xE4, 0xFF, 0x90, 0x94,
+0x55, 0xEF, 0xF0, 0x90, 0x04, 0x7E, 0xE0, 0xFF,
+0xA3, 0xE0, 0x90, 0x94, 0x65, 0xF0, 0xE0, 0xFE,
+0x6F, 0x60, 0x66, 0x90, 0x94, 0x56, 0x74, 0x03,
+0xF0, 0x90, 0x94, 0x64, 0x74, 0x08, 0xF0, 0xEE,
+0x04, 0x54, 0x0F, 0xFF, 0xE4, 0xFE, 0xEF, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x00, 0xF5, 0x82, 0xE4,
+0x34, 0x80, 0xF5, 0x83, 0xE5, 0x82, 0x2E, 0x12,
+0xCE, 0xD9, 0xE0, 0xFD, 0x74, 0x58, 0x2E, 0xF5,
+0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xED, 0xF0,
+0x0E, 0xEE, 0xB4, 0x08, 0xD9, 0x7B, 0x01, 0x7A,
+0x94, 0x79, 0x56, 0x12, 0x5E, 0x10, 0x90, 0x94,
+0x65, 0xE0, 0x04, 0x54, 0x0F, 0xFF, 0xF0, 0xBF,
+0x0F, 0x02, 0xE4, 0xF0, 0x90, 0x94, 0x65, 0xE0,
+0x90, 0x04, 0x7F, 0xF0, 0x90, 0x94, 0x55, 0xE0,
+0x7F, 0x04, 0x70, 0x02, 0x80, 0x04, 0x12, 0x88,
+0x0B, 0x22, 0x8F, 0x0D, 0x7F, 0x02, 0x12, 0x86,
+0x27, 0x90, 0x84, 0xC1, 0xE0, 0x45, 0x0D, 0xF0,
+0x22, 0x12, 0x40, 0xB9, 0x7F, 0x02, 0x80, 0xEA,
+0xE4, 0xFF, 0x02, 0x2D, 0xBD, 0x90, 0x85, 0xCE,
+0xE0, 0x04, 0xF0, 0x90, 0x85, 0xC9, 0xE0, 0x54,
+0xEF, 0xF0, 0x90, 0x86, 0x6D, 0xE0, 0xFF, 0x90,
+0x85, 0xCE, 0xE0, 0xD3, 0x9F, 0x22, 0xF1, 0xEA,
+0x40, 0x2B, 0x90, 0x85, 0xDF, 0xE0, 0x04, 0xF0,
+0x90, 0x93, 0x0E, 0xE0, 0xFF, 0x90, 0x85, 0xDF,
+0xE0, 0xD3, 0x9F, 0x50, 0x18, 0x90, 0x85, 0xD7,
+0xE0, 0x04, 0x12, 0xA3, 0xB2, 0x90, 0x85, 0xDE,
+0xF0, 0xFB, 0x90, 0x85, 0xD7, 0xE0, 0xFF, 0xA3,
+0xE0, 0xFD, 0x12, 0x51, 0x7D, 0x22, 0x12, 0x02,
+0xF6, 0xFF, 0x90, 0x92, 0x03, 0xF0, 0xBF, 0x01,
+0x07, 0x11, 0x39, 0xE4, 0x90, 0x92, 0x03, 0xF0,
+0x22, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xF5, 0x7F,
+0xEF, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x06, 0x90, 0x93, 0xF5, 0xE0, 0xA3, 0xF0, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0xF5, 0x7F, 0xEE, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x93, 0xF5, 0xE0, 0x90, 0x93, 0xF7, 0xF0, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0xF5, 0x7F, 0xED, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x93, 0xF5, 0xE0, 0x90, 0x93, 0xF8, 0xF0, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0xF5, 0x7F, 0xEC, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x93, 0xF5, 0xE0, 0x90, 0x93, 0xF9, 0xF0, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0xF5, 0x7F, 0xEB, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x93, 0xF5, 0xE0, 0x90, 0x93, 0xFA, 0xF0, 0x90,
+0x93, 0xF6, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0xA3,
+0xE0, 0xFB, 0xA3, 0xE0, 0x90, 0x93, 0xFE, 0xF0,
+0x90, 0x93, 0xFA, 0xE0, 0x90, 0x93, 0xFF, 0xF0,
+0x90, 0x94, 0x00, 0x74, 0x12, 0xF0, 0x90, 0x94,
+0x0E, 0x74, 0x05, 0xF0, 0x90, 0x94, 0x02, 0x11,
+0xF7, 0x90, 0x93, 0xFE, 0xE0, 0x90, 0x94, 0x05,
+0xF0, 0x90, 0x93, 0xFF, 0xE0, 0x90, 0x94, 0x06,
+0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x00, 0x12,
+0x5E, 0x10, 0x7F, 0x04, 0x02, 0x88, 0x0B, 0xEF,
+0xF0, 0xA3, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x22,
+0x12, 0x02, 0xF6, 0x54, 0x01, 0xFF, 0x90, 0x92,
+0xCE, 0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x22, 0x12,
+0x02, 0xF6, 0x90, 0x86, 0x71, 0xF0, 0x22, 0x12,
+0x02, 0xF6, 0xFF, 0x90, 0x92, 0xC2, 0xF0, 0xBF,
+0x01, 0x09, 0x7F, 0x01, 0x31, 0x2C, 0xE4, 0x90,
+0x92, 0xC2, 0xF0, 0x22, 0x90, 0x94, 0x77, 0xEF,
+0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96, 0x7F,
+0xF4, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94, 0x98,
+0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96, 0x7F,
+0xF5, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94, 0x99,
+0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96, 0x7F,
+0xF6, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94, 0x9A,
+0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96, 0x7F,
+0xF7, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94, 0x9B,
+0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96, 0x7F,
+0xF8, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94, 0x9C,
+0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96, 0xB1,
+0x03, 0xBF, 0x01, 0x08, 0x90, 0x94, 0x96, 0xE0,
+0x90, 0x94, 0x9D, 0xF0, 0x7B, 0x01, 0x7A, 0x94,
+0x79, 0x96, 0x71, 0xAA, 0x70, 0x52, 0x90, 0x94,
+0x96, 0xE0, 0x90, 0x94, 0x9E, 0xF0, 0x54, 0x07,
+0x60, 0x08, 0x90, 0x94, 0x96, 0xE0, 0x54, 0xE0,
+0x70, 0x3E, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x97,
+0x7F, 0xFA, 0x71, 0xAC, 0x70, 0x32, 0x90, 0x94,
+0x96, 0xE0, 0xFC, 0x54, 0x07, 0x70, 0x12, 0x90,
+0x94, 0x9E, 0xE0, 0xFE, 0x90, 0x94, 0x97, 0xE0,
+0x54, 0x07, 0xFD, 0xEE, 0x4D, 0x90, 0x94, 0x9E,
+0xF0, 0xEC, 0x54, 0xE0, 0x70, 0x12, 0x90, 0x94,
+0x9E, 0xE0, 0xFF, 0x90, 0x94, 0x97, 0xE0, 0x54,
+0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x94, 0x9E, 0xF0,
+0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96, 0x7F, 0xFD,
+0x71, 0xAC, 0x70, 0x46, 0x90, 0x94, 0x96, 0xE0,
+0xFE, 0x54, 0xCC, 0x90, 0x94, 0x9F, 0xF0, 0xEE,
+0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90, 0x94, 0x96,
+0xE0, 0x54, 0xC0, 0x70, 0x2D, 0xEF, 0x70, 0x11,
+0x90, 0x94, 0x9F, 0xE0, 0xFF, 0x90, 0x94, 0x96,
+0xE0, 0x54, 0x03, 0xF1, 0xAE, 0x90, 0x94, 0x9F,
+0xF0, 0x90, 0x94, 0x96, 0xE0, 0xFF, 0x54, 0xC0,
+0x70, 0x10, 0x90, 0x94, 0x9F, 0xE0, 0xFE, 0xEF,
+0x54, 0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF, 0xEE,
+0x4F, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96,
+0x7F, 0xF0, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94,
+0xA0, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96,
+0x7F, 0xF1, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94,
+0xA1, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96,
+0x7F, 0xF2, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94,
+0xA2, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96,
+0x7F, 0xF3, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94,
+0xA3, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x96,
+0x7F, 0xFC, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x08, 0x90, 0x94, 0x96, 0xE0, 0x90, 0x94,
+0xA4, 0xF0, 0x90, 0x94, 0x78, 0x74, 0x19, 0xF0,
+0x90, 0x94, 0x86, 0x74, 0x08, 0xF0, 0x90, 0x94,
+0x98, 0xE0, 0x90, 0x94, 0x7A, 0xF0, 0x90, 0x94,
+0x99, 0xE0, 0x90, 0x94, 0x7B, 0xF0, 0x90, 0x94,
+0x9A, 0xE0, 0x90, 0x94, 0x7C, 0xF0, 0x90, 0x94,
+0x9B, 0xE0, 0x90, 0x94, 0x7D, 0xF0, 0x90, 0x94,
+0x9C, 0xE0, 0x90, 0x94, 0x7E, 0xF0, 0x90, 0x94,
+0x9D, 0xE0, 0x90, 0x94, 0x7F, 0xF0, 0x90, 0x94,
+0x9E, 0xE0, 0x90, 0x94, 0x80, 0xF0, 0x90, 0x94,
+0x9F, 0xE0, 0x90, 0x94, 0x81, 0xF0, 0x90, 0x94,
+0x87, 0x74, 0x1A, 0xF0, 0x90, 0x94, 0x95, 0x74,
+0x05, 0xF0, 0x90, 0x94, 0xA0, 0xE0, 0x90, 0x94,
+0x89, 0xF0, 0x90, 0x94, 0xA1, 0xE0, 0x90, 0x94,
+0x8A, 0xF0, 0x90, 0x94, 0xA2, 0xE0, 0x90, 0x94,
+0x8B, 0xF0, 0x90, 0x94, 0xA3, 0xE0, 0x90, 0x94,
+0x8C, 0xF0, 0x90, 0x94, 0xA4, 0xE0, 0x90, 0x94,
+0x8D, 0xF0, 0x90, 0x94, 0x77, 0xE0, 0xB4, 0x01,
+0x17, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x78, 0x12,
+0x5E, 0x10, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x87,
+0x12, 0x5E, 0x10, 0x7F, 0x04, 0x02, 0x88, 0x0B,
+0x75, 0x1B, 0x01, 0x75, 0x1C, 0x94, 0x75, 0x1D,
+0x78, 0x75, 0x1E, 0x0A, 0x7B, 0x01, 0x7A, 0x01,
+0x79, 0xA0, 0x12, 0x6A, 0x21, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x94, 0x75, 0x1D, 0x89, 0x75, 0x1E,
+0x05, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xAA, 0x02,
+0x6A, 0x21, 0x7F, 0xFB, 0x7E, 0x00, 0x12, 0x64,
+0x37, 0xEF, 0x64, 0x01, 0x22, 0x7E, 0x00, 0x7F,
+0x0B, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x92, 0x79,
+0xC3, 0x12, 0x06, 0xDE, 0x91, 0x3C, 0xB1, 0x03,
+0xBF, 0x01, 0x1C, 0x90, 0x94, 0x25, 0xE0, 0xFE,
+0x54, 0x01, 0x90, 0x92, 0xC3, 0xF0, 0xEE, 0x54,
+0x04, 0x90, 0x92, 0xC5, 0xF0, 0x90, 0x94, 0x25,
+0xE0, 0x54, 0x08, 0x90, 0x92, 0xC4, 0xF0, 0x91,
+0x3C, 0x71, 0xAA, 0x70, 0x34, 0x90, 0x94, 0x25,
+0xE0, 0x54, 0x07, 0x70, 0x14, 0x7B, 0x01, 0x7A,
+0x94, 0x79, 0x26, 0x7F, 0xFA, 0xFE, 0x12, 0x64,
+0x37, 0xBF, 0x01, 0x0F, 0x90, 0x94, 0x26, 0x80,
+0x03, 0x90, 0x94, 0x25, 0xE0, 0x54, 0x07, 0x90,
+0x92, 0xC7, 0xF0, 0x90, 0x94, 0x25, 0xE0, 0x54,
+0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90, 0x92, 0xC6,
+0xF0, 0x91, 0x3C, 0x7F, 0xFD, 0x7E, 0x00, 0x12,
+0x64, 0x37, 0xBF, 0x01, 0x0E, 0x90, 0x94, 0x25,
+0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F, 0x90,
+0x92, 0xC8, 0xF0, 0x22, 0x7B, 0x01, 0x7A, 0x94,
+0x79, 0x25, 0x22, 0x91, 0x3C, 0x7F, 0xF9, 0x71,
+0xAC, 0x70, 0x3F, 0x90, 0x94, 0x25, 0xE0, 0x54,
+0xF0, 0x70, 0x0D, 0x91, 0x3C, 0x7F, 0xFC, 0xFE,
+0x12, 0x64, 0x37, 0xEF, 0x70, 0x02, 0xFF, 0x22,
+0x90, 0x94, 0x25, 0xE0, 0x54, 0xF0, 0xC4, 0x54,
+0x0F, 0xF0, 0xE0, 0x24, 0xFA, 0x60, 0x03, 0x04,
+0x70, 0x08, 0x90, 0x94, 0x26, 0x74, 0x01, 0xF0,
+0x80, 0x05, 0xE4, 0x90, 0x94, 0x26, 0xF0, 0x90,
+0x94, 0x26, 0xE0, 0x7F, 0x00, 0x70, 0x02, 0x7F,
+0x01, 0x22, 0x7F, 0x00, 0x22, 0x90, 0x00, 0x80,
+0xE0, 0x44, 0x80, 0xFD, 0x7F, 0x80, 0x12, 0x7B,
+0x3E, 0x12, 0xBB, 0x75, 0xF1, 0xC0, 0x12, 0x7B,
+0x9C, 0xB1, 0x30, 0xF1, 0xCD, 0x7F, 0x01, 0x12,
+0x85, 0x15, 0x90, 0x92, 0x08, 0x74, 0x02, 0xF0,
+0xFF, 0x12, 0x85, 0x15, 0x90, 0x92, 0x08, 0xE0,
+0x04, 0xF0, 0xB1, 0x55, 0xB1, 0x0A, 0x90, 0x01,
+0xCC, 0x74, 0x0F, 0xF0, 0x91, 0x43, 0xEF, 0x70,
+0x03, 0x12, 0xBB, 0x92, 0x90, 0x00, 0x80, 0xE0,
+0x44, 0x40, 0xFD, 0x7F, 0x80, 0x12, 0x7B, 0x3E,
+0x75, 0x20, 0xFF, 0x12, 0x7C, 0xCD, 0x53, 0xA8,
+0xFE, 0x90, 0x01, 0xA0, 0xE0, 0xB4, 0xFD, 0x04,
+0xE4, 0xFF, 0x31, 0x2C, 0xB1, 0xC2, 0x90, 0x00,
+0x81, 0xE0, 0x44, 0x04, 0xFD, 0x7F, 0x81, 0x12,
+0x7B, 0x3E, 0xF1, 0xB6, 0x71, 0xB5, 0xE4, 0xFF,
+0x02, 0x85, 0x9E, 0x7F, 0xF9, 0x7E, 0x00, 0x02,
+0x64, 0x37, 0xD1, 0xF3, 0x12, 0x7B, 0xEF, 0x12,
+0x3C, 0x03, 0x12, 0xC1, 0x50, 0x12, 0xCA, 0x75,
+0xD1, 0x13, 0xB1, 0x2B, 0x7E, 0x00, 0x7F, 0xB9,
+0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x09,
+0x02, 0x06, 0xDE, 0xD1, 0xE6, 0x02, 0x06, 0xDE,
+0x90, 0x00, 0x00, 0xE0, 0x54, 0xFB, 0xFD, 0xE4,
+0xFF, 0xF1, 0xA6, 0x44, 0x04, 0xFD, 0x7F, 0x01,
+0x12, 0x7B, 0x3E, 0x90, 0x01, 0x98, 0x74, 0x80,
+0xF0, 0xA3, 0x74, 0x88, 0xF0, 0xA3, 0xE4, 0xF0,
+0xA3, 0x74, 0x80, 0xF0, 0x22, 0x12, 0x7C, 0x4E,
+0x90, 0x84, 0xC5, 0xEF, 0xF0, 0xB1, 0x89, 0x90,
+0x01, 0x64, 0x74, 0x01, 0xF0, 0x90, 0x04, 0x23,
+0xE0, 0x44, 0x80, 0xF0, 0x90, 0x00, 0x17, 0xE0,
+0x54, 0xFC, 0x44, 0x04, 0xFD, 0x7F, 0x17, 0x12,
+0x7B, 0x3E, 0x90, 0x00, 0x38, 0xE0, 0x44, 0x40,
+0xFD, 0x7F, 0x38, 0x12, 0x7B, 0x3E, 0x02, 0x68,
+0xE2, 0x90, 0x00, 0x08, 0xE0, 0x54, 0xEF, 0xF0,
+0x12, 0x75, 0xB6, 0x12, 0x75, 0x58, 0x12, 0xBB,
+0x2F, 0x12, 0xBB, 0x56, 0xE4, 0xF5, 0x40, 0xF5,
+0x41, 0xF5, 0x42, 0x75, 0x43, 0x80, 0xAD, 0x40,
+0x7F, 0x50, 0x12, 0x7B, 0x3E, 0xAD, 0x41, 0x7F,
+0x51, 0x12, 0x7B, 0x3E, 0xAD, 0x42, 0x7F, 0x52,
+0x12, 0x7B, 0x3E, 0xAD, 0x43, 0x7F, 0x53, 0x02,
+0x7B, 0x3E, 0xE4, 0x90, 0x94, 0x25, 0xF0, 0xA3,
+0xF0, 0x12, 0xC8, 0xD0, 0xEF, 0x64, 0x01, 0x60,
+0x3B, 0xC3, 0x90, 0x94, 0x26, 0xE0, 0x94, 0x88,
+0x90, 0x94, 0x25, 0xE0, 0x94, 0x13, 0x40, 0x0F,
+0x90, 0x01, 0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90,
+0x01, 0xC7, 0x74, 0xFD, 0xF0, 0x80, 0x1D, 0x90,
+0x94, 0x25, 0xD1, 0xF9, 0xF1, 0x51, 0xD3, 0x90,
+0x94, 0x26, 0xE0, 0x94, 0x32, 0x90, 0x94, 0x25,
+0xE0, 0x94, 0x00, 0x40, 0xC4, 0x90, 0x01, 0xC6,
+0xE0, 0x30, 0xE3, 0xBD, 0x90, 0x01, 0xC7, 0x74,
+0xFE, 0xF0, 0x22, 0x7E, 0x00, 0x7F, 0xAC, 0x7D,
+0x00, 0x7B, 0x01, 0x7A, 0x85, 0x79, 0xC1, 0x12,
+0x06, 0xDE, 0xD1, 0xE6, 0x12, 0x06, 0xDE, 0xE4,
+0x90, 0x93, 0x0F, 0xF0, 0x90, 0x85, 0xC4, 0x74,
+0x02, 0xF0, 0x90, 0x85, 0xCB, 0x14, 0xF0, 0xA3,
+0xF0, 0xA3, 0x74, 0x0A, 0xF0, 0x90, 0x85, 0xD1,
+0xE4, 0xF0, 0xA3, 0x74, 0x02, 0xD1, 0xD6, 0x12,
+0xCC, 0x74, 0xE4, 0xFD, 0xFF, 0x12, 0x57, 0x82,
+0x7D, 0x0C, 0x7F, 0x02, 0x12, 0x57, 0x82, 0x7D,
+0x0C, 0x7F, 0x01, 0x12, 0x57, 0x82, 0x90, 0x84,
+0xC5, 0xE0, 0xFF, 0xB4, 0x01, 0x08, 0x90, 0x85,
+0xD0, 0x74, 0xDD, 0xF0, 0x80, 0x0F, 0xEF, 0x90,
+0x85, 0xD0, 0xB4, 0x03, 0x05, 0x74, 0xD4, 0xF0,
+0x80, 0x03, 0x74, 0x40, 0xF0, 0x7F, 0x2C, 0x12,
+0x7B, 0x51, 0xEF, 0x54, 0x0F, 0xFF, 0xBF, 0x05,
+0x08, 0x90, 0x85, 0xFB, 0x74, 0x02, 0xF0, 0x80,
+0x05, 0xE4, 0x90, 0x85, 0xFB, 0xF0, 0x90, 0x86,
+0x6D, 0x74, 0x02, 0xF0, 0xA3, 0x74, 0x0F, 0xF0,
+0xA3, 0xE0, 0x54, 0x01, 0x44, 0x28, 0xF0, 0xA3,
+0x74, 0x07, 0xD1, 0xD6, 0xE4, 0x90, 0x85, 0xD7,
+0xF0, 0xA3, 0xF0, 0x7F, 0x01, 0x12, 0x69, 0x33,
+0x90, 0x05, 0x58, 0x74, 0x02, 0xF0, 0x90, 0x06,
+0x04, 0xE0, 0x54, 0x7F, 0xF0, 0x90, 0x06, 0x0A,
+0xE0, 0x54, 0xF8, 0xF0, 0x90, 0x05, 0x22, 0xE4,
+0xF0, 0x90, 0x86, 0x71, 0xF0, 0x22, 0xF0, 0x90,
+0x85, 0xFB, 0xE0, 0x24, 0x04, 0x90, 0x85, 0xDD,
+0xF0, 0xA3, 0x74, 0x0A, 0xF0, 0x22, 0x7E, 0x00,
+0x7F, 0x04, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x92,
+0x79, 0x04, 0x22, 0xE4, 0xFD, 0xFF, 0x02, 0x6E,
+0x5F, 0xE4, 0x75, 0xF0, 0x01, 0x02, 0x07, 0x0A,
+0x90, 0x95, 0x40, 0xEF, 0xF0, 0xE4, 0xA3, 0xF0,
+0xA3, 0xF0, 0x90, 0x01, 0x09, 0xE0, 0x7F, 0x00,
+0x30, 0xE7, 0x02, 0x7F, 0x01, 0x90, 0x95, 0x40,
+0xE0, 0x6F, 0x60, 0x34, 0xC3, 0x90, 0x95, 0x42,
+0xE0, 0x94, 0x88, 0x90, 0x95, 0x41, 0xE0, 0x94,
+0x13, 0x40, 0x08, 0x90, 0x01, 0xC0, 0xE0, 0x44,
+0x10, 0xF0, 0x22, 0x90, 0x95, 0x41, 0xD1, 0xF9,
+0xF1, 0x51, 0xD3, 0x90, 0x95, 0x42, 0xE0, 0x94,
+0x32, 0x90, 0x95, 0x41, 0xE0, 0x94, 0x00, 0x40,
+0xC1, 0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE0, 0xBA,
+0x22, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C, 0x9F,
+0x12, 0xCA, 0x56, 0x7F, 0x08, 0x12, 0x7B, 0x51,
+0xEF, 0x54, 0xEF, 0xFD, 0x7F, 0x08, 0x12, 0x7B,
+0x3E, 0xE4, 0xFF, 0xF1, 0x00, 0x7D, 0x35, 0x7F,
+0x27, 0x12, 0x7B, 0x3E, 0x90, 0x85, 0xC2, 0xE0,
+0x54, 0xEF, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x12, 0xC0, 0xF5, 0xF1, 0x58,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x85, 0xC8,
+0xE0, 0xFF, 0x60, 0x03, 0xB4, 0x08, 0x0E, 0x12,
+0xCB, 0x56, 0xBF, 0x01, 0x08, 0xF1, 0x7C, 0x90,
+0x01, 0xE5, 0xE0, 0x04, 0xF0, 0x22, 0x12, 0x7B,
+0x3E, 0x90, 0x01, 0x01, 0xE0, 0x22, 0x25, 0xE0,
+0x25, 0xE0, 0xFE, 0xEF, 0x4E, 0x22, 0x90, 0x01,
+0xE4, 0x74, 0x0E, 0xF0, 0xA3, 0xE4, 0xF0, 0x22,
+0x90, 0x01, 0x94, 0xE0, 0x44, 0x01, 0xF0, 0x90,
+0x01, 0xC7, 0xE4, 0xF0, 0x22, 0xE4, 0x90, 0x84,
+0xC1, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
+0x90, 0x92, 0x01, 0xF0, 0x22, 0x12, 0x02, 0xF6,
+0x64, 0x01, 0x60, 0x03, 0x02, 0xB8, 0x75, 0x90,
+0x94, 0x14, 0xF0, 0x90, 0x94, 0x14, 0xE0, 0xFF,
+0xC3, 0x94, 0x10, 0x50, 0x28, 0xEF, 0x12, 0xB8,
+0x76, 0x7A, 0x94, 0x79, 0x13, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x12, 0x90, 0x94, 0x13, 0xE0, 0xFF,
+0xA3, 0xE0, 0x24, 0x15, 0xF5, 0x82, 0xE4, 0x34,
+0x94, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x94, 0x14,
+0xE0, 0x04, 0xF0, 0x80, 0xCE, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x94, 0x75, 0x1D, 0x15, 0x75, 0x1E,
+0x08, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xF7, 0x12,
+0x6A, 0x21, 0x90, 0x93, 0xF5, 0x74, 0x24, 0xF0,
+0x90, 0x94, 0x03, 0x74, 0x08, 0xF0, 0x75, 0x1B,
+0x01, 0x75, 0x1C, 0x94, 0x75, 0x1D, 0x1D, 0xF5,
+0x1E, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x06, 0x12,
+0x6A, 0x21, 0x90, 0x94, 0x04, 0x74, 0x25, 0xF0,
+0x90, 0x94, 0x12, 0x74, 0x08, 0xF0, 0x7B, 0x01,
+0x7A, 0x93, 0x79, 0xF5, 0x12, 0x5E, 0x10, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0x04, 0x12, 0x5E, 0x10,
+0x7F, 0x04, 0x12, 0x88, 0x0B, 0x22, 0x24, 0xDE,
+0xFF, 0xE4, 0x33, 0xFE, 0x7B, 0x01, 0x22, 0x12,
+0x8F, 0x9E, 0x12, 0x02, 0xF6, 0x64, 0x01, 0x60,
+0x02, 0x21, 0x11, 0xEF, 0x24, 0x39, 0x60, 0x12,
+0x14, 0x60, 0x19, 0x24, 0x02, 0x70, 0x1F, 0xE4,
+0x90, 0x93, 0xFB, 0xF0, 0xA3, 0x74, 0x06, 0xF0,
+0x80, 0x14, 0x90, 0x93, 0xFB, 0x74, 0x06, 0xF0,
+0xA3, 0xF0, 0x80, 0x0A, 0x90, 0x93, 0xFB, 0x74,
+0x0C, 0xF0, 0xA3, 0x74, 0x04, 0xF0, 0x31, 0x25,
+0xF0, 0x31, 0x12, 0x40, 0x1B, 0x90, 0x93, 0xF9,
+0xE0, 0x11, 0x76, 0x7A, 0x93, 0x79, 0xF8, 0x12,
+0x64, 0x37, 0xBF, 0x01, 0x07, 0x90, 0x93, 0xF8,
+0xE0, 0xF4, 0x70, 0x3D, 0x31, 0x1A, 0x80, 0xE1,
+0x31, 0x25, 0xF0, 0x31, 0x12, 0x40, 0x32, 0x90,
+0x93, 0xF9, 0xE0, 0xFD, 0x7C, 0x00, 0x24, 0xDE,
+0xFF, 0xEC, 0x33, 0xFE, 0xED, 0x24, 0x01, 0xFD,
+0xEC, 0x33, 0xFC, 0x90, 0x93, 0xFB, 0xE0, 0xFB,
+0xC3, 0xED, 0x9B, 0xFD, 0xEC, 0x94, 0x00, 0xFC,
+0x12, 0x8D, 0x74, 0x8D, 0x82, 0x8C, 0x83, 0x12,
+0x03, 0x0F, 0xFD, 0x31, 0x35, 0x31, 0x1A, 0x80,
+0xCA, 0x22, 0x90, 0x93, 0xFA, 0xE0, 0xD3, 0x94,
+0x00, 0x22, 0x90, 0x93, 0xF9, 0xE0, 0x04, 0xF0,
+0xA3, 0xE0, 0x14, 0xF0, 0x22, 0x90, 0x93, 0xFB,
+0xE0, 0x90, 0x93, 0xF9, 0xF0, 0x90, 0x93, 0xFC,
+0xE0, 0x90, 0x93, 0xFA, 0x22, 0x8E, 0x5B, 0x8F,
+0x5C, 0x8D, 0x5D, 0xE4, 0x90, 0x93, 0xFD, 0xF0,
+0x90, 0x00, 0x37, 0xE0, 0x44, 0x80, 0xFD, 0x7F,
+0x37, 0x12, 0x7B, 0x3E, 0x7D, 0x69, 0x7F, 0xCF,
+0x12, 0x7B, 0x3E, 0xE5, 0x5C, 0xFD, 0x7F, 0x31,
+0x12, 0x7B, 0x3E, 0xE5, 0x5B, 0x54, 0x03, 0xFF,
+0x90, 0x00, 0x32, 0xE0, 0x54, 0xFC, 0x4F, 0xFD,
+0x7F, 0x32, 0x12, 0x7B, 0x3E, 0xAD, 0x5D, 0x7F,
+0x30, 0x12, 0x7B, 0x3E, 0x90, 0x00, 0x33, 0xE0,
+0x44, 0x80, 0xFD, 0x7F, 0x33, 0x12, 0x7B, 0x3E,
+0x90, 0x00, 0x33, 0xE0, 0x30, 0xE7, 0x09, 0x31,
+0xAC, 0x50, 0x05, 0xE0, 0x04, 0xF0, 0x80, 0xF0,
+0xE4, 0xFD, 0x7F, 0xCF, 0x12, 0x7B, 0x3E, 0x90,
+0x00, 0x37, 0xE0, 0x54, 0x7F, 0xFD, 0x7F, 0x37,
+0x12, 0x7B, 0x3E, 0x31, 0xAC, 0x7F, 0x00, 0x50,
+0x02, 0x7F, 0x01, 0x22, 0x90, 0x93, 0xFD, 0xE0,
+0xC3, 0x94, 0x64, 0x22, 0x02, 0x9D, 0x09, 0xE4,
+0x90, 0x94, 0x27, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
+0x90, 0x94, 0x27, 0xE0, 0x64, 0x01, 0xF0, 0x90,
+0x92, 0xCC, 0xE0, 0x70, 0x18, 0x90, 0x92, 0xC9,
+0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E, 0x90,
+0x94, 0x27, 0xE0, 0x24, 0xB7, 0x90, 0x01, 0xC4,
+0xF0, 0x74, 0xB9, 0xA3, 0xF0, 0x12, 0x7C, 0x66,
+0xBF, 0x01, 0x03, 0x12, 0x5B, 0x25, 0x90, 0x85,
+0xC5, 0xE0, 0x60, 0x0F, 0x90, 0x85, 0xC8, 0xE0,
+0xFF, 0x90, 0x85, 0xC7, 0xE0, 0x6F, 0x60, 0x03,
+0x12, 0xAB, 0xFA, 0xC2, 0xAF, 0x51, 0xFE, 0xBF,
+0x01, 0x02, 0x51, 0x17, 0xD2, 0xAF, 0x51, 0x38,
+0x31, 0xB4, 0x12, 0x84, 0x4D, 0x80, 0xA9, 0x90,
+0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x19, 0x90, 0x85,
+0xBC, 0xE0, 0xFF, 0x30, 0xE0, 0x0E, 0xC3, 0x13,
+0x30, 0xE0, 0x07, 0x51, 0xF1, 0xBF, 0x01, 0x07,
+0x80, 0x02, 0x80, 0x00, 0x12, 0xB7, 0x8D, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x92, 0xC9, 0xE0, 0x60, 0x25, 0x7F, 0x54, 0x7E,
+0x09, 0x12, 0x70, 0x61, 0x51, 0xE5, 0xEF, 0x44,
+0xFE, 0xFF, 0xEE, 0x44, 0x03, 0xFE, 0xED, 0x44,
+0x04, 0xFD, 0xEC, 0x51, 0xE5, 0x90, 0x91, 0x66,
+0x12, 0x04, 0xEB, 0x7F, 0x54, 0x7E, 0x09, 0x12,
+0x71, 0x18, 0x90, 0x92, 0xC4, 0xE0, 0x70, 0x29,
+0x90, 0x07, 0xCC, 0xE0, 0x30, 0xE0, 0x22, 0xE4,
+0xF0, 0x90, 0x94, 0x2E, 0x74, 0x22, 0xF0, 0x90,
+0x94, 0x3C, 0x74, 0x01, 0xF0, 0x90, 0x94, 0x30,
+0x74, 0x03, 0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79,
+0x2E, 0x12, 0x5E, 0x10, 0x7F, 0x04, 0x12, 0x88,
+0x0B, 0x90, 0x92, 0xCC, 0xE0, 0xFF, 0x70, 0x0A,
+0x90, 0x92, 0xC9, 0xE0, 0x70, 0x04, 0xA3, 0xE0,
+0x60, 0x15, 0x90, 0x00, 0x1F, 0xE0, 0x54, 0xF0,
+0xF0, 0x90, 0x01, 0xC5, 0x74, 0xEA, 0xF0, 0xA3,
+0x74, 0xEF, 0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0xEF,
+0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x07, 0xF0,
+0x90, 0x92, 0xC9, 0xE0, 0x60, 0x06, 0x90, 0x01,
+0xC4, 0x74, 0x01, 0xF0, 0x90, 0x92, 0xCA, 0xE0,
+0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x02, 0xF0,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x94, 0x2A,
+0x12, 0x04, 0xEB, 0x90, 0x94, 0x2A, 0x02, 0x87,
+0x2D, 0x90, 0x85, 0xBF, 0xE0, 0x64, 0x02, 0x7F,
+0x01, 0x60, 0x02, 0x7F, 0x00, 0x22, 0x7D, 0x02,
+0x90, 0x01, 0xC4, 0x74, 0xFE, 0xF0, 0x74, 0xBA,
+0xA3, 0xF0, 0x90, 0x92, 0x08, 0xE0, 0xFF, 0xED,
+0xC3, 0x9F, 0x50, 0x18, 0xED, 0x25, 0xE0, 0x24,
+0x81, 0xF8, 0xE6, 0x30, 0xE4, 0x0B, 0x90, 0x01,
+0xB8, 0x74, 0x08, 0xF0, 0xA3, 0xF0, 0x7F, 0x00,
+0x22, 0x0D, 0x80, 0xDE, 0x7F, 0x01, 0x22, 0x75,
+0x48, 0x12, 0xE4, 0xF5, 0x49, 0x75, 0x4A, 0x07,
+0x75, 0x4B, 0x32, 0xF5, 0x50, 0x90, 0x01, 0x30,
+0xE5, 0x48, 0xF0, 0xA3, 0xE5, 0x49, 0xF0, 0xA3,
+0xE5, 0x4A, 0xF0, 0xA3, 0xE5, 0x4B, 0xF0, 0x90,
+0x01, 0x20, 0xE5, 0x50, 0xF0, 0x22, 0x75, 0x52,
+0x06, 0x75, 0x53, 0x01, 0x75, 0x54, 0x03, 0x75,
+0x55, 0x62, 0x90, 0x01, 0x38, 0xE5, 0x52, 0xF0,
+0xA3, 0xE5, 0x53, 0xF0, 0xA3, 0xE5, 0x54, 0xF0,
+0xA3, 0xE5, 0x55, 0xF0, 0x22, 0x90, 0x84, 0xA1,
+0x74, 0x02, 0xF0, 0xA3, 0x74, 0x9A, 0xF0, 0xA3,
+0x74, 0x26, 0xF0, 0x90, 0x84, 0xA6, 0x74, 0x04,
+0xF0, 0xA3, 0x74, 0x80, 0xF0, 0xA3, 0x74, 0x03,
+0xF0, 0x22, 0xE4, 0x90, 0x94, 0x25, 0xF0, 0xC2,
+0xAF, 0x12, 0xA7, 0x7D, 0x90, 0x94, 0x25, 0xE0,
+0x64, 0x01, 0xF0, 0x24, 0x92, 0x90, 0x01, 0xC4,
+0xF0, 0x74, 0xBB, 0xA3, 0xF0, 0x80, 0xEA, 0xE4,
+0xFB, 0xFA, 0xFD, 0x7F, 0x01, 0x12, 0x86, 0x4E,
+0x90, 0x94, 0x3D, 0xEF, 0xF0, 0x60, 0xF0, 0x90,
+0x84, 0xC1, 0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0,
+0x60, 0xE5, 0xC2, 0xAF, 0xEF, 0x30, 0xE0, 0x0F,
+0x90, 0x84, 0xC1, 0xE0, 0x54, 0xFE, 0xF0, 0xE4,
+0xFF, 0x12, 0x2D, 0xBD, 0x12, 0xC2, 0xB3, 0x71,
+0xFB, 0xFF, 0x30, 0xE1, 0x06, 0x54, 0xFD, 0xF0,
+0x12, 0x60, 0x5D, 0x71, 0xFB, 0xFF, 0x30, 0xE2,
+0x06, 0x54, 0xFB, 0xF0, 0x12, 0x6A, 0x6D, 0xD2,
+0xAF, 0x80, 0xC4, 0xD2, 0xAF, 0xC2, 0xAF, 0x90,
+0x84, 0xC1, 0xE0, 0x22, 0x32, 0xC0, 0xE0, 0xC0,
+0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
+0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
+0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x05, 0xF0,
+0x74, 0xBC, 0xA3, 0xF0, 0x12, 0x6C, 0xBC, 0x74,
+0x05, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xBC,
+0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05,
+0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
+0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83,
+0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0xC0, 0xE0, 0xC0,
+0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
+0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
+0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x55, 0xF0,
+0x74, 0xBC, 0xA3, 0xF0, 0x12, 0x75, 0x28, 0xE5,
+0x56, 0x30, 0xE0, 0x02, 0x91, 0xFF, 0xE5, 0x56,
+0x30, 0xE1, 0x02, 0xF1, 0x0B, 0xE5, 0x56, 0x30,
+0xE2, 0x02, 0xB1, 0x12, 0xE5, 0x56, 0x30, 0xE5,
+0x03, 0x12, 0xA7, 0xEB, 0xE5, 0x57, 0x30, 0xE0,
+0x02, 0xD1, 0x42, 0xE5, 0x58, 0x30, 0xE1, 0x02,
+0xF1, 0x8F, 0xE5, 0x58, 0x30, 0xE0, 0x03, 0x12,
+0xA7, 0x0D, 0xE5, 0x58, 0x30, 0xE4, 0x02, 0xD1,
+0xE1, 0xE5, 0x59, 0x30, 0xE1, 0x05, 0x7F, 0x04,
+0x12, 0xAF, 0xC2, 0xE5, 0x59, 0x30, 0xE4, 0x03,
+0x12, 0xAA, 0x57, 0xE5, 0x59, 0x30, 0xE5, 0x02,
+0xD1, 0x81, 0xE5, 0x59, 0x30, 0xE6, 0x02, 0xB1,
+0xD7, 0x74, 0x55, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xBC, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
+0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
+0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x90,
+0x92, 0x0A, 0xE0, 0x30, 0xE0, 0x0B, 0x90, 0x92,
+0xB4, 0xE0, 0x60, 0x05, 0x7F, 0x07, 0x12, 0xC8,
+0x4A, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x11,
+0x90, 0x06, 0x92, 0xE0, 0x30, 0xE1, 0x05, 0x12,
+0x6B, 0x98, 0x80, 0x05, 0xD1, 0xE9, 0x12, 0xAB,
+0xFA, 0x90, 0x92, 0x0A, 0xE0, 0x20, 0xE0, 0x02,
+0xA1, 0xBC, 0x90, 0x92, 0xB6, 0xE0, 0x04, 0x12,
+0x93, 0x35, 0x04, 0xFF, 0x90, 0x94, 0x66, 0xF0,
+0x90, 0x92, 0x0B, 0xE0, 0xB5, 0x07, 0x05, 0xE4,
+0x90, 0x94, 0x66, 0xF0, 0x90, 0x92, 0xB4, 0xE0,
+0xFF, 0x60, 0x12, 0xB1, 0xBD, 0xC3, 0x9F, 0x90,
+0x91, 0x6F, 0xB1, 0xD0, 0xFB, 0xFD, 0x7F, 0x50,
+0x7E, 0x01, 0x12, 0x61, 0x41, 0x90, 0x94, 0x66,
+0xE0, 0x12, 0x97, 0xD7, 0x54, 0x07, 0x90, 0x94,
+0x67, 0x12, 0x93, 0x35, 0x12, 0x97, 0xD7, 0x54,
+0x07, 0xFF, 0x14, 0x60, 0x0E, 0x14, 0x60, 0x07,
+0x14, 0x60, 0x08, 0x24, 0x03, 0x70, 0x0D, 0xD1,
+0xE2, 0x80, 0x06, 0x90, 0x92, 0x0C, 0x74, 0x05,
+0xF0, 0x12, 0x93, 0xAF, 0xD1, 0xF1, 0x50, 0x24,
+0x90, 0x94, 0x67, 0xE0, 0xFF, 0x64, 0x02, 0x60,
+0x03, 0xEF, 0x70, 0x0F, 0xB1, 0xBD, 0x24, 0xFC,
+0xFF, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0xA3, 0xEF,
+0x12, 0xA1, 0x7B, 0xB1, 0xBD, 0x90, 0x91, 0x6F,
+0xB1, 0xD0, 0xD1, 0xD8, 0x22, 0x90, 0x94, 0x66,
+0xE0, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x39, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0, 0x22,
+0xF0, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x22, 0x90,
+0x85, 0xC1, 0xE0, 0xFF, 0x12, 0x8F, 0xB7, 0x30,
+0xE0, 0x1F, 0xEF, 0x54, 0x7F, 0xD1, 0xC0, 0x30,
+0xE1, 0x06, 0xE0, 0x44, 0x02, 0xF0, 0x80, 0x08,
+0xE0, 0x54, 0xFD, 0xF0, 0xD1, 0xC9, 0x04, 0xF0,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x03, 0x12, 0xAB,
+0xFA, 0x90, 0x04, 0xE0, 0xE0, 0x30, 0xE1, 0x05,
+0xD1, 0x0E, 0x12, 0x93, 0x3F, 0x22, 0x90, 0x92,
+0x09, 0xE0, 0x30, 0xE0, 0x1E, 0xA3, 0xE0, 0xC3,
+0x13, 0x54, 0x07, 0xFF, 0xD1, 0x34, 0xE0, 0xFE,
+0x30, 0xE0, 0x10, 0xEF, 0xD1, 0x34, 0xEE, 0x54,
+0xFE, 0xF0, 0x12, 0x93, 0x30, 0xFD, 0x7F, 0x02,
+0x12, 0x92, 0x1E, 0x22, 0x75, 0xF0, 0x0E, 0xA4,
+0x24, 0x15, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5,
+0x83, 0x22, 0xF1, 0x4A, 0x90, 0x94, 0x66, 0xEF,
+0xF0, 0x20, 0xE0, 0x06, 0x90, 0x01, 0x3D, 0x74,
+0x01, 0xF0, 0x90, 0x94, 0x66, 0xE0, 0x30, 0xE0,
+0x05, 0x7D, 0x01, 0xE4, 0x80, 0x02, 0xE4, 0xFD,
+0xFF, 0x12, 0x57, 0x82, 0x90, 0x94, 0x66, 0xE0,
+0x30, 0xE6, 0x11, 0x90, 0x01, 0x2F, 0xE0, 0x30,
+0xE7, 0x04, 0xE4, 0xF0, 0x80, 0x06, 0x90, 0x01,
+0x2F, 0x74, 0x80, 0xF0, 0xD1, 0xFD, 0x02, 0x51,
+0x7D, 0x90, 0x93, 0x0F, 0xE0, 0xB4, 0x01, 0x14,
+0xE4, 0xF0, 0x90, 0x01, 0x5B, 0xF0, 0x90, 0x91,
+0x6E, 0xF0, 0x90, 0x86, 0x6F, 0xE0, 0xC3, 0x13,
+0x54, 0x7F, 0xD1, 0xD3, 0x90, 0x85, 0xC1, 0x12,
+0xA6, 0xBC, 0x30, 0xE0, 0x1A, 0xEF, 0x54, 0xBF,
+0xD1, 0xC0, 0x30, 0xE0, 0x06, 0xE0, 0x44, 0x01,
+0xF0, 0x80, 0x09, 0xE0, 0x54, 0xFE, 0xF0, 0xD1,
+0xC9, 0x74, 0x04, 0xF0, 0x12, 0xAB, 0xFA, 0x22,
+0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x90, 0x85, 0xC2,
+0x22, 0x90, 0x01, 0xB9, 0x74, 0x01, 0xF0, 0x90,
+0x01, 0xB8, 0x22, 0x90, 0x91, 0x6F, 0xF0, 0xE4,
+0xFB, 0xFD, 0x7F, 0x58, 0x7E, 0x01, 0x02, 0x61,
+0x41, 0x22, 0x90, 0x92, 0x0C, 0x74, 0x05, 0xF0,
+0x22, 0x90, 0x85, 0xC1, 0xE0, 0x54, 0xF7, 0xF0,
+0x22, 0x90, 0x92, 0xB3, 0xE0, 0xFF, 0x90, 0x92,
+0xB6, 0xE0, 0xD3, 0x9F, 0x22, 0x90, 0x85, 0xD7,
+0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x85, 0xDE,
+0xE0, 0xFB, 0x22, 0x90, 0x85, 0xC5, 0xE0, 0x60,
+0x03, 0x12, 0xAB, 0x9B, 0x12, 0x94, 0xF1, 0x02,
+0x93, 0xAF, 0x90, 0x95, 0x43, 0x12, 0x87, 0x4E,
+0x12, 0x71, 0x54, 0x90, 0x85, 0xC5, 0xE0, 0xFF,
+0x12, 0x60, 0xD0, 0x90, 0x85, 0xC5, 0xE0, 0x60,
+0x18, 0x90, 0x95, 0x43, 0x12, 0x87, 0x45, 0x12,
+0x8F, 0x98, 0x54, 0x0F, 0xFF, 0x12, 0x8E, 0xCF,
+0xFD, 0x12, 0x6A, 0xB8, 0xD1, 0xFD, 0x12, 0x51,
+0x7D, 0x22, 0xE4, 0x90, 0x94, 0x68, 0xF0, 0xA3,
+0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x51, 0x90, 0x94,
+0x67, 0xEF, 0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x51,
+0xAE, 0x07, 0x90, 0x94, 0x67, 0xE0, 0xFF, 0xB5,
+0x06, 0x01, 0x22, 0xC3, 0x90, 0x94, 0x69, 0xE0,
+0x94, 0x64, 0x90, 0x94, 0x68, 0xE0, 0x94, 0x00,
+0x40, 0x0D, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x40,
+0xF0, 0x90, 0x94, 0x67, 0xE0, 0xFF, 0x22, 0x90,
+0x94, 0x68, 0x12, 0xB6, 0xF9, 0x80, 0xC2, 0x90,
+0x85, 0xBC, 0xE0, 0xFF, 0x30, 0xE0, 0x40, 0x90,
+0x85, 0xC0, 0xE0, 0x7E, 0x00, 0xB4, 0x02, 0x02,
+0x7E, 0x01, 0x90, 0x85, 0xBF, 0xE0, 0x7D, 0x00,
+0xB4, 0x04, 0x02, 0x7D, 0x01, 0xED, 0x4E, 0x70,
+0x26, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x03, 0x02,
+0xA7, 0x52, 0x12, 0xAC, 0xAA, 0x90, 0x85, 0xC0,
+0xE0, 0xB4, 0x0C, 0x06, 0xE4, 0xFD, 0x7F, 0x08,
+0x80, 0x0A, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x04,
+0x06, 0xE4, 0xFD, 0xFF, 0x12, 0xA2, 0x07, 0x22,
+0x32, 0xC0, 0xE0, 0xC0, 0x83, 0xC0, 0x82, 0xC0,
+0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x05, 0xC0, 0x07,
+0x7D, 0xD9, 0x90, 0x01, 0xC4, 0xED, 0xF0, 0x74,
+0xBF, 0xFF, 0xA3, 0xF0, 0xED, 0x04, 0x90, 0x01,
+0xC4, 0xF0, 0xA3, 0xEF, 0xF0, 0xD0, 0x07, 0xD0,
+0x05, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
+0xE0, 0x32, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0,
+0x05, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x90,
+0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x11, 0xA3, 0x74,
+0x01, 0xF0, 0x90, 0x85, 0xBC, 0xE0, 0xFF, 0xC3,
+0x13, 0x30, 0xE0, 0x03, 0x12, 0xA7, 0x52, 0x12,
+0xA1, 0x86, 0xE4, 0xFF, 0x12, 0xAA, 0x9C, 0x02,
+0x8B, 0x20, 0x90, 0x85, 0xBC, 0xE0, 0xFF, 0x30,
+0xE0, 0x05, 0x12, 0xA6, 0xEB, 0x60, 0x15, 0x90,
+0x85, 0xC5, 0xE0, 0x70, 0x04, 0xEF, 0x30, 0xE0,
+0x0B, 0x90, 0x85, 0xC8, 0xE0, 0x64, 0x02, 0x60,
+0x03, 0x12, 0xA9, 0x19, 0x22, 0xE4, 0xFF, 0x12,
+0x77, 0x39, 0xBF, 0x01, 0x13, 0x90, 0x85, 0xC5,
+0xE0, 0x60, 0x0D, 0x12, 0xAB, 0x94, 0x64, 0x02,
+0x60, 0x03, 0x02, 0x77, 0x61, 0x12, 0x79, 0x41,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x7F, 0x02, 0x11, 0xCA, 0x7F, 0x02, 0x12, 0xB7,
+0xA6, 0x44, 0x02, 0xF0, 0x90, 0x01, 0x00, 0x74,
+0xFF, 0xF0, 0x90, 0x06, 0xB7, 0x74, 0x09, 0xF0,
+0x90, 0x06, 0xB4, 0x74, 0x86, 0xF0, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x11, 0x79, 0x11, 0xDB, 0x74,
+0x01, 0xF0, 0x22, 0x11, 0xA3, 0x90, 0x05, 0x27,
+0xE0, 0x54, 0xBF, 0xF0, 0xE4, 0x90, 0x85, 0xBF,
+0xF0, 0x22, 0x11, 0xE5, 0x80, 0xEF, 0x12, 0xA7,
+0xE4, 0x80, 0xEA, 0x11, 0x79, 0x7D, 0x24, 0x02,
+0x9F, 0xE4, 0x12, 0x7B, 0x51, 0xEF, 0x44, 0x01,
+0xFD, 0x22, 0x11, 0x79, 0x90, 0x85, 0xBF, 0x74,
+0x03, 0xF0, 0x22, 0xE4, 0xFD, 0xFF, 0x12, 0x98,
+0xDA, 0x90, 0x85, 0xBF, 0x22, 0xE4, 0xFD, 0xFF,
+0x12, 0x98, 0xDA, 0x12, 0xA7, 0xED, 0x90, 0x85,
+0xBF, 0x74, 0x01, 0xF0, 0x22, 0x90, 0x85, 0xC2,
+0xE0, 0x44, 0x10, 0xF0, 0x90, 0x85, 0xD0, 0xE0,
+0xFD, 0x7F, 0x93, 0x12, 0x7B, 0x3E, 0x90, 0x85,
+0xC6, 0xE0, 0x60, 0x12, 0x90, 0x01, 0x2F, 0xE0,
+0x30, 0xE7, 0x05, 0x74, 0x10, 0xF0, 0x80, 0x06,
+0x90, 0x01, 0x2F, 0x74, 0x90, 0xF0, 0x7F, 0x08,
+0x12, 0x7B, 0x51, 0xEF, 0x44, 0x10, 0xFD, 0x7F,
+0x08, 0x12, 0x7B, 0x3E, 0x7F, 0x01, 0x12, 0xB7,
+0x00, 0x7D, 0x34, 0x7F, 0x27, 0x12, 0x7B, 0x3E,
+0x7F, 0x90, 0x11, 0xCA, 0x7F, 0x90, 0x12, 0x7B,
+0x3E, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C, 0x9F,
+0x12, 0x02, 0xF6, 0x90, 0x94, 0xA5, 0xF0, 0x22,
+0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00, 0x90, 0x89,
+0x1B, 0x12, 0x87, 0x4E, 0x7B, 0xFF, 0x7A, 0x82,
+0x79, 0x00, 0x90, 0x89, 0x1E, 0x12, 0x87, 0x4E,
+0x7A, 0x82, 0x79, 0x3F, 0x90, 0x89, 0x21, 0x12,
+0x87, 0x4E, 0x7A, 0x82, 0x79, 0xE1, 0x90, 0x89,
+0x27, 0x12, 0x87, 0x4E, 0x7A, 0x82, 0x79, 0xF5,
+0x90, 0x89, 0x2A, 0x12, 0x87, 0x4E, 0x7A, 0x83,
+0x79, 0x1D, 0x90, 0x89, 0x2D, 0x12, 0x87, 0x4E,
+0x7A, 0x83, 0x79, 0x31, 0x90, 0x89, 0x33, 0x12,
+0x87, 0x4E, 0x7A, 0x83, 0x79, 0x59, 0x90, 0x89,
+0x36, 0x12, 0x87, 0x4E, 0x7A, 0x83, 0x79, 0x81,
+0x90, 0x89, 0x39, 0x12, 0x87, 0x4E, 0xE4, 0x90,
+0x94, 0xB6, 0xF0, 0x90, 0x94, 0xA5, 0xF0, 0x90,
+0x94, 0x25, 0xF0, 0x90, 0x94, 0x25, 0xE0, 0xFF,
+0xC3, 0x94, 0x05, 0x50, 0x14, 0x74, 0xC7, 0x2F,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE4,
+0xF0, 0x90, 0x94, 0x25, 0xE0, 0x04, 0xF0, 0x80,
+0xE2, 0x22, 0x90, 0x94, 0x4A, 0xEE, 0xF0, 0xA3,
+0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0xEB, 0x75, 0xF0,
+0x06, 0xA4, 0xFF, 0x90, 0x89, 0x21, 0x12, 0x87,
+0x45, 0xE9, 0x2F, 0xF9, 0xEA, 0x35, 0xF0, 0xFA,
+0x90, 0x94, 0x52, 0x12, 0x87, 0x4E, 0x90, 0x94,
+0x4C, 0xE0, 0xF1, 0xBD, 0xE0, 0xFF, 0xA3, 0xE0,
+0x90, 0x94, 0x4F, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0,
+0xE4, 0xA3, 0xF0, 0x90, 0x94, 0x52, 0x12, 0x87,
+0x45, 0x90, 0x94, 0x51, 0xE0, 0xFF, 0xF5, 0x82,
+0x75, 0x83, 0x00, 0x12, 0x03, 0x0F, 0xFD, 0x7C,
+0x00, 0x90, 0x94, 0x4C, 0xE0, 0x75, 0xF0, 0x12,
+0x90, 0x89, 0x44, 0x12, 0x05, 0x28, 0x75, 0xF0,
+0x02, 0xEF, 0x12, 0x05, 0x28, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x90, 0x94, 0x4E, 0xE0, 0xFB, 0xEF,
+0xA8, 0x03, 0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13,
+0xCE, 0x13, 0xD8, 0xF9, 0xF1, 0x1C, 0xEE, 0x8F,
+0xF0, 0x12, 0x07, 0x0A, 0x90, 0x94, 0x51, 0xE0,
+0x04, 0xF0, 0xE0, 0xB4, 0x05, 0xAD, 0x90, 0x94,
+0x52, 0x12, 0x87, 0x45, 0x12, 0x97, 0xE7, 0xFD,
+0x7C, 0x00, 0x90, 0x94, 0x4E, 0xE0, 0xFF, 0x90,
+0x94, 0x4A, 0xE0, 0xFE, 0xA3, 0xE0, 0xA8, 0x07,
+0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
+0xD8, 0xF9, 0xF1, 0x1C, 0xD1, 0xFD, 0x40, 0x08,
+0xED, 0x9F, 0xFF, 0xEC, 0x9E, 0xFE, 0x80, 0x04,
+0x7E, 0x00, 0x7F, 0x00, 0x90, 0x94, 0x4F, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x94, 0x4F, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x94, 0x4C, 0xE0,
+0x02, 0x9C, 0x74, 0x90, 0x04, 0x85, 0xE0, 0xF5,
+0x6C, 0x90, 0x94, 0xB6, 0xE0, 0x04, 0xF0, 0xE4,
+0xF5, 0x63, 0x90, 0x85, 0xBB, 0xE0, 0xFF, 0xE5,
+0x63, 0xC3, 0x9F, 0x40, 0x02, 0xC1, 0xE4, 0x12,
+0x9B, 0x87, 0xE0, 0xF5, 0x6E, 0xF1, 0x8F, 0xE0,
+0x65, 0x6E, 0x60, 0x14, 0x90, 0x94, 0xCF, 0x74,
+0x06, 0xF0, 0xE4, 0xFB, 0xAD, 0x6E, 0xAF, 0x63,
+0x12, 0x9B, 0x2B, 0xF1, 0x8F, 0xE5, 0x6E, 0xF0,
+0x90, 0x04, 0xA0, 0xE0, 0x64, 0x01, 0x70, 0x49,
+0xA3, 0xE0, 0x65, 0x63, 0x70, 0x43, 0xA3, 0xE0,
+0xF5, 0x64, 0xA3, 0xE0, 0x90, 0x94, 0x49, 0xF0,
+0x12, 0x9B, 0x87, 0xE0, 0x65, 0x64, 0x70, 0x02,
+0xC1, 0xE0, 0x12, 0x9B, 0x87, 0xE5, 0x64, 0xF0,
+0xE5, 0x63, 0x12, 0x9A, 0xA8, 0xE0, 0x54, 0xFC,
+0xFF, 0x90, 0x94, 0x49, 0xE0, 0x54, 0x03, 0x4F,
+0xFF, 0xE5, 0x63, 0x12, 0x9A, 0xA8, 0xEF, 0xF0,
+0x90, 0x94, 0xCF, 0x74, 0x07, 0xF0, 0xE4, 0xFB,
+0xAD, 0x64, 0xAF, 0x63, 0x12, 0x9B, 0x2B, 0xC1,
+0xE0, 0x75, 0xF0, 0x12, 0xE5, 0x63, 0x90, 0x89,
+0x42, 0x12, 0x05, 0x28, 0xE0, 0xFF, 0x90, 0x94,
+0x41, 0xE4, 0xF0, 0xA3, 0xEF, 0xF0, 0x75, 0xF0,
+0x12, 0xE5, 0x63, 0x90, 0x89, 0x40, 0x12, 0x05,
+0x28, 0xE0, 0xF5, 0x69, 0xA3, 0xE0, 0xF5, 0x6A,
+0xE5, 0x63, 0x75, 0xF0, 0x12, 0xA4, 0x24, 0x44,
+0xF9, 0x74, 0x89, 0x35, 0xF0, 0xFA, 0x7B, 0x01,
+0x90, 0x94, 0x3E, 0x12, 0x87, 0x4E, 0xF1, 0x72,
+0x12, 0x03, 0xED, 0x2F, 0xFF, 0xF1, 0x7A, 0xF1,
+0x16, 0x2F, 0xFF, 0xF1, 0x0D, 0x2F, 0xF5, 0x6D,
+0x12, 0x9B, 0x87, 0xE0, 0xF5, 0x64, 0x54, 0x80,
+0xF5, 0x66, 0xE5, 0x64, 0x54, 0x7F, 0xF5, 0x65,
+0x75, 0xF0, 0x12, 0xE5, 0x63, 0x90, 0x89, 0x43,
+0x12, 0x05, 0x28, 0xE0, 0x64, 0x01, 0x60, 0x02,
+0x81, 0xFB, 0xF1, 0x07, 0xF1, 0x72, 0xAE, 0xF0,
+0x12, 0x03, 0xED, 0x2F, 0xFF, 0xE5, 0xF0, 0x3E,
+0xFE, 0xF1, 0x7A, 0xEE, 0xF1, 0x13, 0x2F, 0xFF,
+0xEE, 0x35, 0xF0, 0xFE, 0xF1, 0x0D, 0x2F, 0xFF,
+0xEE, 0x35, 0xF0, 0x90, 0x94, 0x43, 0xF0, 0xA3,
+0xEF, 0xF0, 0x12, 0x03, 0xED, 0xFF, 0xC3, 0x90,
+0x94, 0x44, 0xE0, 0x9F, 0xFE, 0x90, 0x94, 0x43,
+0xE0, 0x95, 0xF0, 0x90, 0x94, 0x45, 0xF0, 0xA3,
+0xCE, 0xF0, 0xF1, 0x16, 0xFD, 0xAC, 0xF0, 0x25,
+0xE0, 0xFF, 0xEC, 0x33, 0xFE, 0xEF, 0x2D, 0xFD,
+0xEE, 0x3C, 0xFC, 0x90, 0x00, 0x04, 0x12, 0x04,
+0x18, 0x25, 0xE0, 0xFF, 0xE5, 0xF0, 0x33, 0xFE,
+0x90, 0x00, 0x02, 0x12, 0x04, 0x18, 0x2F, 0xFF,
+0xEE, 0x35, 0xF0, 0xCF, 0x2D, 0xFD, 0xEF, 0x3C,
+0xFC, 0xF1, 0x07, 0xF1, 0x0D, 0xAE, 0xF0, 0x78,
+0x02, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
+0x2D, 0xFF, 0xEC, 0x3E, 0x90, 0x94, 0x47, 0xF0,
+0xA3, 0xEF, 0xF0, 0x90, 0x94, 0x41, 0xF1, 0x30,
+0xF1, 0x4A, 0xD1, 0xFB, 0x50, 0x07, 0x90, 0x94,
+0x41, 0xF1, 0x24, 0x80, 0x04, 0x7E, 0xFF, 0x7F,
+0xFF, 0xE5, 0x63, 0x25, 0xE0, 0xF1, 0x4A, 0x12,
+0x9C, 0x7D, 0x90, 0x94, 0x43, 0xF1, 0x30, 0xF1,
+0x52, 0xD1, 0xFB, 0x50, 0x07, 0x90, 0x94, 0x43,
+0xF1, 0x24, 0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF,
+0xE5, 0x63, 0x25, 0xE0, 0xF1, 0x52, 0x12, 0x9C,
+0x7D, 0x90, 0x94, 0x47, 0xF1, 0x30, 0xF1, 0x5A,
+0xD1, 0xFB, 0x50, 0x07, 0x90, 0x94, 0x47, 0xF1,
+0x24, 0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5,
+0x63, 0x25, 0xE0, 0xF1, 0x5A, 0x12, 0x9C, 0x7D,
+0xC3, 0x74, 0xFF, 0x95, 0x6A, 0xFF, 0x74, 0xFF,
+0x95, 0x69, 0xFE, 0xF1, 0x83, 0xD1, 0xFB, 0x50,
+0x0A, 0xE5, 0x6A, 0x2D, 0xFF, 0xE5, 0x69, 0x3C,
+0xFE, 0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xF1,
+0x83, 0x12, 0x9C, 0x7D, 0xF1, 0x6A, 0xFB, 0xC3,
+0x74, 0xFF, 0x9B, 0xFF, 0x74, 0xFF, 0x9E, 0xFE,
+0x74, 0xFF, 0x94, 0x00, 0xFD, 0x74, 0xFF, 0x94,
+0x00, 0xFC, 0x90, 0x8F, 0x77, 0x12, 0x87, 0x39,
+0xD3, 0x12, 0x04, 0xB4, 0x50, 0x11, 0xF1, 0x6A,
+0xFF, 0xE4, 0xFC, 0xFD, 0x90, 0x8F, 0x77, 0x12,
+0x87, 0x39, 0x12, 0x86, 0xA9, 0x80, 0x06, 0x74,
+0xFF, 0xFF, 0xFE, 0xFD, 0xFC, 0x90, 0x8F, 0x77,
+0x12, 0x04, 0xEB, 0xAF, 0x63, 0x12, 0x77, 0x39,
+0xEF, 0x70, 0x02, 0xC1, 0xE0, 0x75, 0xF0, 0x12,
+0xE5, 0x63, 0x12, 0x8E, 0xC5, 0x12, 0x8F, 0xB7,
+0x30, 0xE0, 0x02, 0xC1, 0xE0, 0xE5, 0x63, 0x13,
+0x13, 0x13, 0x54, 0x1F, 0x24, 0x75, 0xF1, 0xA9,
+0xFD, 0x7C, 0x00, 0xE5, 0x63, 0xF1, 0xB2, 0x80,
+0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
+0xFF, 0xEE, 0x5C, 0xFE, 0xEF, 0x5D, 0x4E, 0x60,
+0x02, 0xC1, 0xE0, 0xE5, 0x6A, 0x45, 0x69, 0x70,
+0x0C, 0x90, 0x94, 0x41, 0xE0, 0x70, 0x02, 0xA3,
+0xE0, 0x70, 0x02, 0xC1, 0xE0, 0x75, 0xF0, 0x12,
+0xE5, 0x63, 0x12, 0x9F, 0xCE, 0xFF, 0xE5, 0x65,
+0xD3, 0x9F, 0x40, 0x08, 0x8F, 0x65, 0xE5, 0x65,
+0x45, 0x66, 0xF5, 0x64, 0x74, 0x7C, 0x25, 0x63,
+0xF5, 0x82, 0xE4, 0x34, 0x90, 0xF5, 0x83, 0xE0,
+0xC3, 0x94, 0x05, 0x40, 0x02, 0xC1, 0xDE, 0xE5,
+0x65, 0x90, 0x82, 0xE1, 0x93, 0xF5, 0x6B, 0xE5,
+0x66, 0x60, 0x04, 0x05, 0x6B, 0x05, 0x6B, 0xE5,
+0x65, 0xC3, 0x94, 0x0C, 0x40, 0x21, 0x74, 0xA6,
+0x25, 0x63, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
+0x83, 0xE0, 0xFF, 0x54, 0x7F, 0xFE, 0xEF, 0x30,
+0xE7, 0x06, 0xE5, 0x6B, 0x2E, 0xFF, 0x80, 0x05,
+0xC3, 0xE5, 0x6B, 0x9E, 0xFF, 0x8F, 0x6B, 0xE5,
+0x6B, 0xD3, 0x94, 0x1A, 0xAF, 0x6B, 0x40, 0x02,
+0x7F, 0x1A, 0x8F, 0x6B, 0xE5, 0x64, 0x90, 0x83,
+0x59, 0x93, 0xFF, 0xD3, 0x90, 0x94, 0x42, 0xE0,
+0x9F, 0x90, 0x94, 0x41, 0xE0, 0x94, 0x00, 0x40,
+0x02, 0xC1, 0xA3, 0xC3, 0xE5, 0x6A, 0x94, 0x0A,
+0xE5, 0x69, 0x94, 0x00, 0x40, 0x02, 0xC1, 0x5E,
+0xD1, 0xE5, 0xF5, 0x83, 0xE0, 0xC3, 0x94, 0x01,
+0x40, 0x07, 0xD1, 0xE5, 0xF5, 0x83, 0xE0, 0x14,
+0xF0, 0xF1, 0x07, 0xF1, 0x0D, 0xFF, 0x90, 0x94,
+0x42, 0xE0, 0x2F, 0xFF, 0x90, 0x94, 0x41, 0xE0,
+0xF1, 0x13, 0x2F, 0xFD, 0xEE, 0x35, 0xF0, 0xFC,
+0xE5, 0x69, 0xC3, 0x13, 0xFE, 0xE5, 0x6A, 0x13,
+0xFF, 0xD3, 0xED, 0x9F, 0xEC, 0x9E, 0x40, 0x0F,
+0xE5, 0x63, 0x94, 0x05, 0x50, 0x07, 0xD1, 0xE5,
+0xF5, 0x83, 0x74, 0x02, 0xF0, 0x80, 0x7C, 0xF1,
+0x07, 0x12, 0x03, 0xED, 0x65, 0x6D, 0x70, 0x02,
+0xE5, 0xF0, 0x70, 0x26, 0xE5, 0x63, 0xC3, 0x94,
+0x05, 0x50, 0x13, 0xD1, 0xE5, 0xF5, 0x83, 0xE0,
+0xD3, 0x94, 0x00, 0x40, 0x09, 0x7D, 0x06, 0xAF,
+0x63, 0x12, 0x9C, 0x89, 0xC1, 0xE0, 0xE4, 0xFD,
+0xAF, 0x63, 0x12, 0x9B, 0x96, 0x12, 0x9C, 0x85,
+0xC1, 0xDE, 0xF1, 0x43, 0xC1, 0xDE, 0xD1, 0xE5,
+0xF5, 0x83, 0xE4, 0xF0, 0x90, 0x94, 0x4E, 0x74,
+0x02, 0xF0, 0xAB, 0x6B, 0xAD, 0x63, 0xAF, 0x6A,
+0xAE, 0x69, 0x31, 0xDA, 0x8E, 0x67, 0x8F, 0x68,
+0xF1, 0x9B, 0xC3, 0x74, 0x01, 0x93, 0x95, 0x68,
+0xE4, 0x93, 0x95, 0x67, 0x50, 0x0D, 0xD1, 0xEF,
+0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x63, 0x12, 0x9B,
+0x96, 0x80, 0x4B, 0xF1, 0x62, 0xC3, 0xE5, 0x68,
+0x9F, 0xE5, 0x67, 0x94, 0x00, 0x50, 0x0D, 0xD1,
+0xEF, 0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x63, 0x12,
+0x9F, 0x1C, 0x80, 0x32, 0x12, 0x9C, 0x85, 0xD1,
+0xEF, 0xE0, 0x04, 0xF0, 0xE5, 0x65, 0x90, 0x83,
+0x6D, 0x93, 0xFF, 0xD1, 0xEF, 0xE0, 0xC3, 0x9F,
+0x40, 0x1C, 0xD1, 0xEF, 0xE4, 0xF0, 0xF1, 0x62,
+0xF1, 0x9B, 0x74, 0x01, 0x93, 0x2F, 0xFF, 0xE4,
+0x93, 0x34, 0x00, 0xC3, 0x13, 0xFE, 0xEF, 0x13,
+0xFF, 0xE5, 0x63, 0x12, 0x9C, 0x74, 0xF1, 0x43,
+0x05, 0x63, 0x41, 0xC2, 0x22, 0x74, 0xC7, 0x25,
+0x63, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0x22, 0x74,
+0xAC, 0x25, 0x63, 0xF5, 0x82, 0xE4, 0x34, 0x8F,
+0xF5, 0x83, 0x22, 0xF5, 0x83, 0xE0, 0xFC, 0xA3,
+0xE0, 0xFD, 0xD3, 0x9F, 0xEC, 0x9E, 0x22, 0x90,
+0x94, 0x3E, 0x02, 0x87, 0x45, 0x90, 0x00, 0x08,
+0x02, 0x04, 0x18, 0x35, 0xF0, 0xFE, 0x90, 0x00,
+0x06, 0x02, 0x04, 0x18, 0xFF, 0x12, 0x03, 0x70,
+0x90, 0x94, 0x4F, 0x22, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0xED, 0x2F, 0xFF, 0xEC, 0x3E, 0xFE, 0x22,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xC3, 0x74, 0xFF,
+0x9F, 0xFF, 0x74, 0xFF, 0x9E, 0xFE, 0xE5, 0x63,
+0x25, 0xE0, 0x22, 0x7D, 0x01, 0xAF, 0x63, 0x02,
+0x65, 0xC2, 0x24, 0x0C, 0xF5, 0x82, 0xE4, 0x34,
+0x90, 0x22, 0x24, 0x2C, 0xF5, 0x82, 0xE4, 0x34,
+0x90, 0x22, 0x24, 0x5C, 0xF5, 0x82, 0xE4, 0x34,
+0x90, 0x22, 0xE5, 0x65, 0x90, 0x83, 0x1D, 0x93,
+0xFF, 0x22, 0x90, 0x94, 0x45, 0xE0, 0xFE, 0xA3,
+0xE0, 0x22, 0x90, 0x00, 0x02, 0x12, 0x04, 0x18,
+0xFF, 0x22, 0x90, 0x00, 0x04, 0x12, 0x04, 0x18,
+0x2F, 0xFF, 0x22, 0xE5, 0x63, 0x25, 0xE0, 0x24,
+0x8C, 0xF5, 0x82, 0xE4, 0x34, 0x90, 0x22, 0x74,
+0xBC, 0x25, 0x63, 0xF5, 0x82, 0xE4, 0x34, 0x8F,
+0xF5, 0x83, 0x22, 0xE5, 0x65, 0x25, 0xE0, 0x24,
+0xF5, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83,
+0x22, 0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83,
+0xE0, 0x22, 0x54, 0x07, 0xFF, 0x74, 0x01, 0x7E,
+0x00, 0xA8, 0x07, 0x08, 0x22, 0x25, 0xE0, 0x24,
+0x7B, 0xF5, 0x82, 0xE4, 0x34, 0x8F, 0xF5, 0x83,
+0x22, 0xE4, 0xF5, 0x74, 0xEF, 0x14, 0xF5, 0x73,
+0xED, 0xFF, 0xE5, 0x73, 0xF5, 0x82, 0x33, 0x95,
+0xE0, 0xF5, 0x83, 0xC3, 0xE5, 0x82, 0x9F, 0x74,
+0x80, 0xF8, 0x65, 0x83, 0x98, 0x40, 0x52, 0xE5,
+0x73, 0x78, 0x03, 0xA2, 0xE7, 0x13, 0xD8, 0xFB,
+0xFF, 0x33, 0x95, 0xE0, 0xFE, 0xEB, 0x12, 0xC8,
+0x3C, 0xE5, 0x82, 0x2F, 0xF5, 0x82, 0xE5, 0x83,
+0x3E, 0xF5, 0x83, 0xE0, 0xF5, 0x82, 0x75, 0x83,
+0x00, 0xE5, 0x73, 0x12, 0xC7, 0xB2, 0x80, 0x05,
+0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF,
+0xEE, 0x55, 0x83, 0xFE, 0xEF, 0x55, 0x82, 0x4E,
+0x60, 0x13, 0x85, 0x73, 0x75, 0x05, 0x74, 0x90,
+0x94, 0x4F, 0xE0, 0x65, 0x74, 0x60, 0x0A, 0xE5,
+0x75, 0xD3, 0x9D, 0x40, 0x04, 0x15, 0x73, 0x80,
+0x97, 0xAF, 0x75, 0x22, 0x75, 0xF0, 0x08, 0xA4,
+0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5,
+0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0xAD, 0x07, 0x90, 0x05, 0x63, 0xE0, 0xFE,
+0x90, 0x05, 0x62, 0xE0, 0x7A, 0x00, 0x24, 0x00,
+0xFF, 0xEA, 0x3E, 0x90, 0x95, 0x13, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x05, 0x61, 0xE0, 0xFE, 0x90,
+0x05, 0x60, 0xE0, 0x24, 0x00, 0xFF, 0xEA, 0x3E,
+0xFE, 0xED, 0xB4, 0x08, 0x0A, 0x90, 0x05, 0x58,
+0xE0, 0xFC, 0x2F, 0xFF, 0xEA, 0x3E, 0xFE, 0x90,
+0x95, 0x04, 0x74, 0x17, 0xF0, 0x90, 0x95, 0x12,
+0x74, 0x06, 0xF0, 0x90, 0x95, 0x06, 0xED, 0xF0,
+0x90, 0x92, 0x0A, 0xE0, 0xFD, 0xC3, 0x13, 0x54,
+0x07, 0x12, 0x97, 0x57, 0xE0, 0x90, 0x95, 0x07,
+0xF0, 0xA3, 0xEF, 0xF0, 0xEE, 0xA3, 0xF0, 0x90,
+0x95, 0x13, 0xE0, 0xFE, 0xA3, 0xE0, 0x90, 0x95,
+0x0A, 0xF0, 0xEE, 0xA3, 0xF0, 0x7B, 0x01, 0x7A,
+0x95, 0x79, 0x04, 0x12, 0x5E, 0x10, 0x7F, 0x04,
+0x12, 0x88, 0x0B, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0x90, 0x01, 0x98, 0xE4, 0xF0, 0xA3, 0xF0, 0xA3,
+0x74, 0x11, 0xF0, 0xA3, 0xE4, 0xF0, 0x7F, 0x0A,
+0xFE, 0x12, 0x7C, 0x9F, 0x90, 0x01, 0x99, 0xE0,
+0x54, 0x30, 0xFF, 0x64, 0x10, 0x60, 0x04, 0xEF,
+0xB4, 0x20, 0x03, 0x7F, 0x01, 0x22, 0x7F, 0x00,
+0x22, 0x90, 0x01, 0xCF, 0xE0, 0x90, 0x94, 0x55,
+0xF0, 0xE0, 0xFF, 0x30, 0xE0, 0x07, 0x90, 0x01,
+0xCF, 0xE0, 0x54, 0xFE, 0xF0, 0xEF, 0x30, 0xE5,
+0x23, 0x90, 0x01, 0xCF, 0xE0, 0x54, 0xDF, 0xF0,
+0x90, 0x01, 0x34, 0x74, 0x20, 0xF0, 0xE4, 0xF5,
+0xA8, 0xF5, 0xE8, 0x12, 0x75, 0xB6, 0x90, 0x00,
+0x03, 0xE0, 0x54, 0xFB, 0xFD, 0x7F, 0x03, 0x12,
+0x7B, 0x3E, 0x80, 0xFE, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xE0, 0xEC,
+0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x94, 0xDF, 0xEF,
+0xF0, 0xA3, 0xA3, 0xE0, 0xFD, 0x12, 0x7B, 0xE0,
+0x90, 0x94, 0xEA, 0x12, 0x04, 0xEB, 0x90, 0x94,
+0xE2, 0x12, 0x87, 0x2D, 0x12, 0x04, 0xA7, 0x90,
+0x94, 0xEA, 0x12, 0x8F, 0xA4, 0xC0, 0x04, 0xC0,
+0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x94, 0xE2,
+0x12, 0x87, 0x2D, 0x90, 0x94, 0xE6, 0x12, 0x8F,
+0xA4, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x87, 0x20, 0x90, 0x94, 0xEE, 0x12,
+0x04, 0xEB, 0x90, 0x94, 0xE0, 0xA3, 0xE0, 0xFD,
+0xC0, 0x05, 0x90, 0x94, 0xEE, 0x12, 0x87, 0x2D,
+0x90, 0x8D, 0x9D, 0x12, 0x04, 0xEB, 0x90, 0x94,
+0xDF, 0xE0, 0xFF, 0xD0, 0x05, 0x12, 0x78, 0xDD,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x33, 0xEF,
+0xF0, 0xED, 0x64, 0x01, 0x70, 0x2E, 0xEB, 0xB4,
+0x01, 0x07, 0xE0, 0x24, 0x02, 0xF5, 0x0E, 0x80,
+0x08, 0x90, 0x95, 0x33, 0xE0, 0x24, 0xFE, 0xF5,
+0x0E, 0x90, 0x94, 0xE2, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x00, 0xFF, 0xAF, 0x0E, 0x51, 0x1F, 0x51,
+0x17, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0xFF,
+0xAF, 0x0E, 0x80, 0x20, 0x90, 0x94, 0xE2, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x00, 0xFF, 0x90, 0x95,
+0x33, 0x12, 0x8B, 0x19, 0x51, 0x23, 0x51, 0x17,
+0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0xFF, 0x90,
+0x95, 0x33, 0xE0, 0xFF, 0x51, 0x1F, 0x7F, 0x01,
+0x31, 0x35, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4,
+0xFF, 0x31, 0x35, 0x90, 0x94, 0xE2, 0x22, 0xE4,
+0xFC, 0xFD, 0xFE, 0x90, 0x94, 0xE6, 0x12, 0x04,
+0xEB, 0x7D, 0x18, 0x7C, 0x00, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0xFE, 0xFD,
+0xEF, 0xB4, 0x01, 0x0D, 0xEB, 0xB4, 0x02, 0x03,
+0x0D, 0x80, 0x06, 0xEB, 0xB4, 0x01, 0x02, 0x7D,
+0x02, 0xAF, 0x06, 0xEF, 0xC4, 0x54, 0xF0, 0x4D,
+0xFF, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x01,
+0xC4, 0x74, 0x56, 0xF0, 0x74, 0xCA, 0xA3, 0xF0,
+0x7F, 0x90, 0x12, 0x7B, 0x51, 0xEF, 0x20, 0xE0,
+0xF7, 0x74, 0x56, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xCA, 0xA3, 0xF0, 0x22, 0x7E, 0x00, 0x7F,
+0x01, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x85, 0x79,
+0xBC, 0x12, 0x06, 0xDE, 0x90, 0x85, 0xBC, 0xE0,
+0x54, 0xFD, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0,
+0xA3, 0xF0, 0xA3, 0x74, 0x0C, 0xF0, 0x22, 0x7D,
+0x22, 0x7F, 0xFF, 0x12, 0x98, 0xDA, 0x12, 0xA7,
+0xED, 0x90, 0x85, 0xBF, 0x74, 0x03, 0xF0, 0x22,
+0x7D, 0x25, 0x02, 0x9F, 0xE4, 0x12, 0x7A, 0x29,
+0xEF, 0x70, 0x03, 0x12, 0xAD, 0xE8, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x7A,
+0x29, 0xEF, 0x64, 0x01, 0x60, 0x05, 0x75, 0x10,
+0x01, 0x80, 0x70, 0x90, 0x85, 0xC9, 0xE0, 0xFF,
+0x54, 0x03, 0x60, 0x05, 0x75, 0x10, 0x02, 0x80,
+0x62, 0x90, 0x85, 0xC7, 0xE0, 0xFE, 0xE4, 0xC3,
+0x9E, 0x50, 0x05, 0x75, 0x10, 0x04, 0x80, 0x53,
+0xEF, 0x30, 0xE2, 0x05, 0x75, 0x10, 0x08, 0x80,
+0x4A, 0x90, 0x85, 0xC9, 0xE0, 0x30, 0xE4, 0x05,
+0x75, 0x10, 0x10, 0x80, 0x3E, 0x90, 0x85, 0xC2,
+0xE0, 0x13, 0x13, 0x54, 0x3F, 0x20, 0xE0, 0x05,
+0x75, 0x10, 0x20, 0x80, 0x2E, 0x90, 0x86, 0x71,
+0xE0, 0x60, 0x05, 0x75, 0x10, 0x80, 0x80, 0x23,
+0x90, 0x06, 0x62, 0xE0, 0x30, 0xE1, 0x05, 0x75,
+0x10, 0x11, 0x80, 0x17, 0x90, 0x06, 0x62, 0xE0,
+0x30, 0xE0, 0x0C, 0xE0, 0x54, 0xFC, 0xFF, 0xBF,
+0x80, 0x05, 0x75, 0x10, 0x12, 0x80, 0x04, 0x71,
+0x4E, 0x80, 0x0E, 0x90, 0x01, 0xB9, 0x74, 0x04,
+0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x10, 0xF0, 0x7F,
+0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x01,
+0xB8, 0xE4, 0xF0, 0x7F, 0x01, 0x22, 0x90, 0x92,
+0x04, 0xE0, 0xC3, 0x13, 0x20, 0xE0, 0x35, 0x90,
+0x02, 0x87, 0xE0, 0x60, 0x02, 0x80, 0x08, 0x90,
+0x01, 0x00, 0xE0, 0x64, 0x3F, 0x60, 0x05, 0x75,
+0x62, 0x01, 0x80, 0x22, 0x90, 0x02, 0x96, 0xE0,
+0x60, 0x05, 0x75, 0x62, 0x10, 0x80, 0x17, 0x90,
+0x02, 0x86, 0xE0, 0x20, 0xE1, 0x02, 0x80, 0x07,
+0x90, 0x02, 0x86, 0xE0, 0x30, 0xE3, 0x05, 0x75,
+0x62, 0x04, 0x80, 0x02, 0x80, 0xB8, 0x90, 0x01,
+0xB9, 0x74, 0x08, 0xF0, 0x90, 0x01, 0xB8, 0xE5,
+0x62, 0xF0, 0x7F, 0x00, 0x22, 0xAC, 0x07, 0x90,
+0x92, 0xCF, 0xE0, 0xF9, 0x30, 0xE0, 0x02, 0x81,
+0x58, 0x90, 0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x16,
+0x90, 0x85, 0xFB, 0xE0, 0x24, 0x04, 0x90, 0x85,
+0xDA, 0xF0, 0x90, 0x85, 0xFB, 0xE0, 0x24, 0x03,
+0x90, 0x85, 0xD9, 0xF0, 0x80, 0x0D, 0x90, 0x85,
+0xDA, 0x74, 0x02, 0xF0, 0x90, 0x85, 0xD9, 0x14,
+0xF0, 0x0B, 0x0B, 0x90, 0x85, 0xD9, 0xE0, 0xFA,
+0x90, 0x85, 0xD8, 0xE0, 0xD3, 0x9A, 0x50, 0x0E,
+0x90, 0x85, 0xCD, 0xEB, 0xF0, 0x90, 0x85, 0xDA,
+0xE0, 0xC3, 0x9D, 0x2C, 0x80, 0x11, 0xC3, 0xED,
+0x9A, 0x2B, 0x90, 0x85, 0xCD, 0xF0, 0x90, 0x85,
+0xD9, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90,
+0x85, 0xDD, 0xF0, 0x90, 0x85, 0xDA, 0xE0, 0xFF,
+0x24, 0x0A, 0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x85,
+0xDD, 0x91, 0x60, 0x40, 0x04, 0xEF, 0x24, 0x0A,
+0xF0, 0x90, 0x85, 0xDD, 0xE0, 0xFF, 0x24, 0x23,
+0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x85, 0xCD, 0x91,
+0x60, 0x40, 0x04, 0xEF, 0x24, 0x23, 0xF0, 0x90,
+0x85, 0xDD, 0xE0, 0xFF, 0x7E, 0x00, 0x90, 0x85,
+0xD1, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x05,
+0x58, 0xE0, 0x6F, 0x70, 0x01, 0xE4, 0x60, 0x03,
+0x91, 0x6B, 0xF0, 0xE9, 0x54, 0xFD, 0x80, 0x03,
+0xE9, 0x44, 0x02, 0x90, 0x92, 0xCF, 0xF0, 0x22,
+0xE0, 0xD3, 0x9D, 0xEC, 0x64, 0x80, 0xF8, 0x74,
+0x80, 0x98, 0x22, 0x90, 0x85, 0xD1, 0xA3, 0xE0,
+0x90, 0x05, 0x58, 0x22, 0x90, 0x93, 0x09, 0x74,
+0x04, 0xF0, 0x14, 0xF0, 0xA3, 0xF0, 0xA3, 0xE4,
+0xF0, 0xA3, 0x74, 0x64, 0xF0, 0xA3, 0x74, 0x05,
+0xF0, 0xA3, 0xF0, 0x22, 0xE4, 0x90, 0x94, 0x56,
+0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x92, 0xD8,
+0x12, 0x87, 0x2D, 0x90, 0x92, 0xD4, 0xD1, 0x12,
+0x40, 0x46, 0x90, 0x85, 0xC1, 0xE0, 0x90, 0x92,
+0xD8, 0x30, 0xE0, 0x0F, 0xB1, 0xF5, 0x90, 0x85,
+0xFB, 0xE0, 0x24, 0x04, 0x2F, 0xFF, 0x90, 0x93,
+0x09, 0x80, 0x05, 0xB1, 0xF5, 0x90, 0x93, 0x0A,
+0xE0, 0xFE, 0xC3, 0xEF, 0x9E, 0x90, 0x94, 0x57,
+0xF0, 0x90, 0x94, 0x57, 0xE0, 0xFF, 0xC3, 0x94,
+0x2D, 0x50, 0x15, 0x74, 0xDC, 0x2F, 0xD1, 0x19,
+0xE0, 0x04, 0xF0, 0x90, 0x85, 0xDB, 0xE0, 0x04,
+0xF0, 0xE0, 0xFD, 0x7F, 0xFE, 0x12, 0x7B, 0x3E,
+0x90, 0x85, 0xDB, 0xE0, 0xFF, 0xD3, 0x90, 0x93,
+0x0C, 0xE0, 0x9F, 0x90, 0x93, 0x0B, 0xE0, 0x94,
+0x00, 0x40, 0x02, 0xA1, 0xC2, 0xB1, 0xD4, 0xF0,
+0xB1, 0xCB, 0x50, 0x1C, 0xB1, 0xDD, 0x90, 0x94,
+0x58, 0xE0, 0xD3, 0x9F, 0x40, 0x0A, 0x90, 0x94,
+0x56, 0xE0, 0x90, 0x94, 0x59, 0xF0, 0x80, 0x08,
+0x90, 0x94, 0x56, 0xE0, 0x04, 0xF0, 0x80, 0xE0,
+0xB1, 0xD4, 0xF0, 0xB1, 0xCB, 0x50, 0x2C, 0xB1,
+0xDD, 0xC3, 0x90, 0x93, 0x0C, 0xE0, 0x9F, 0xFF,
+0x90, 0x93, 0x0B, 0xE0, 0x94, 0x00, 0xFE, 0x90,
+0x94, 0x58, 0xE0, 0xD3, 0x9F, 0xE4, 0x9E, 0x40,
+0x0A, 0x90, 0x94, 0x56, 0xE0, 0x90, 0x94, 0x5A,
+0xF0, 0x80, 0x08, 0x90, 0x94, 0x56, 0xE0, 0x04,
+0xF0, 0x80, 0xD0, 0x90, 0x94, 0x59, 0xE0, 0x90,
+0x85, 0xE0, 0xF0, 0x90, 0x94, 0x5A, 0xE0, 0x90,
+0x85, 0xE1, 0xB1, 0xC3, 0x94, 0x0A, 0x40, 0x0A,
+0xEF, 0x24, 0xF6, 0x90, 0x85, 0xD8, 0xF0, 0xE4,
+0x80, 0x09, 0xE4, 0x90, 0x85, 0xD8, 0xB1, 0xC3,
+0x74, 0x0A, 0x9F, 0x90, 0x85, 0xD7, 0xF0, 0x90,
+0x85, 0xE0, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F,
+0x90, 0x85, 0xDE, 0xF0, 0x90, 0x85, 0xC1, 0xE0,
+0x30, 0xE0, 0x05, 0x90, 0x93, 0x09, 0x80, 0x03,
+0x90, 0x93, 0x0A, 0xE0, 0xFF, 0x90, 0x85, 0xDE,
+0xE0, 0x2F, 0x04, 0xF0, 0x90, 0x85, 0xDE, 0xE0,
+0xC3, 0x94, 0x0A, 0x50, 0x03, 0x74, 0x0A, 0xF0,
+0x90, 0x85, 0xDE, 0xE0, 0x24, 0x02, 0xF0, 0x12,
+0xBE, 0xFD, 0x12, 0x51, 0x7D, 0xE4, 0xFF, 0x12,
+0x69, 0x33, 0x22, 0xF0, 0x90, 0x85, 0xE0, 0xE0,
+0xFF, 0xC3, 0x22, 0x90, 0x94, 0x56, 0xE0, 0xFF,
+0xC3, 0x94, 0x2D, 0x22, 0xE4, 0x90, 0x94, 0x58,
+0xF0, 0x90, 0x94, 0x56, 0x22, 0x74, 0xDC, 0x2F,
+0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83, 0xE0,
+0xFF, 0x90, 0x94, 0x58, 0xE0, 0x2F, 0xF0, 0x90,
+0x93, 0x0D, 0xE0, 0xFF, 0x22, 0x12, 0x87, 0x39,
+0x90, 0x92, 0xD4, 0x12, 0x87, 0x2D, 0x12, 0x86,
+0xB6, 0x78, 0x0A, 0x12, 0x04, 0xC5, 0x90, 0x85,
+0xDD, 0xE0, 0xFE, 0xC3, 0x74, 0x0A, 0x9E, 0x2F,
+0xFF, 0x22, 0x12, 0x87, 0x39, 0xC3, 0x02, 0x04,
+0xB4, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xF5, 0x83,
+0x22, 0xE4, 0xFE, 0x74, 0xDC, 0x2E, 0xD1, 0x19,
+0xE4, 0xF0, 0x0E, 0xEE, 0xB4, 0x2D, 0xF4, 0xE4,
+0x90, 0x85, 0xDC, 0xF0, 0x90, 0x85, 0xDB, 0xF0,
+0x90, 0x85, 0xDF, 0xF0, 0xEF, 0xB4, 0x01, 0x07,
+0xA3, 0x74, 0x2D, 0xF0, 0xE4, 0xA3, 0xF0, 0x22,
+0x90, 0x95, 0x24, 0xA3, 0xE0, 0xFF, 0x90, 0x95,
+0x32, 0x74, 0x03, 0xF0, 0x7B, 0x06, 0x7D, 0x01,
+0x12, 0x99, 0x31, 0x90, 0x95, 0x28, 0xEE, 0xF0,
+0xFC, 0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x95, 0x27,
+0xE0, 0xFF, 0x74, 0x10, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x95,
+0x26, 0xE0, 0xFF, 0x02, 0x65, 0x61, 0x90, 0x05,
+0x63, 0xE0, 0x90, 0x92, 0xD8, 0xF0, 0x90, 0x05,
+0x62, 0xE0, 0x90, 0x92, 0xD9, 0xF0, 0x90, 0x05,
+0x61, 0xE0, 0x90, 0x92, 0xDA, 0xF0, 0x90, 0x05,
+0x60, 0xE0, 0x90, 0x92, 0xDB, 0xF0, 0x90, 0x92,
+0xCF, 0xE0, 0x44, 0x01, 0x22, 0x78, 0x08, 0x12,
+0x04, 0xD8, 0xA8, 0x04, 0xA9, 0x05, 0xAA, 0x06,
+0xAB, 0x07, 0x22, 0xE4, 0x90, 0x91, 0x6E, 0xF0,
+0x90, 0x94, 0x61, 0xE0, 0xFF, 0x90, 0x92, 0xB2,
+0xE0, 0x2F, 0x22, 0x8B, 0x5B, 0x8A, 0x5C, 0x89,
+0x5D, 0x02, 0x02, 0xF6, 0xE0, 0x90, 0x01, 0xBA,
+0xF0, 0x90, 0x85, 0xC7, 0xE0, 0x90, 0x01, 0xBB,
+0x22, 0xF5, 0x82, 0xE4, 0x35, 0x83, 0xF5, 0x83,
+0x22, 0xF0, 0x74, 0xCC, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0x8F, 0xF5, 0x83, 0x22, 0xE0, 0xFC, 0xA3,
+0xE0, 0xF5, 0x82, 0x8C, 0x83, 0x22, 0x90, 0x95,
+0x2E, 0xE0, 0xFF, 0x90, 0x95, 0x2C, 0x22, 0xFF,
+0x12, 0x02, 0xF6, 0xFE, 0x54, 0x0F, 0xFD, 0x22,
+0xE0, 0xFE, 0x74, 0x01, 0xA8, 0x06, 0x08, 0x22,
+0x90, 0x85, 0xCB, 0xE0, 0x90, 0x05, 0x73, 0x22,
+0xF0, 0x90, 0x94, 0x66, 0x74, 0x01, 0xF0, 0x22,
+0x90, 0x85, 0xBC, 0xE0, 0xC4, 0x13, 0x13, 0x22,
+0xE4, 0xFD, 0x7F, 0x8D, 0x02, 0x7B, 0x3E, 0x00,
+0xC3, 0x84
+};
+
+u32 array_length_mp_8188f_fw_nic = 20306;
+
+#ifdef CONFIG_WOWLAN
+
+u8 array_mp_8188f_fw_wowlan[] = {
+0xF1, 0x88, 0x30, 0x00, 0x0E, 0x00, 0x00, 0x00,
+0x06, 0x07, 0x17, 0x19, 0xB2, 0x5F, 0x02, 0x00,
+0x01, 0x68, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x02, 0x85, 0xA9, 0x02, 0xC0, 0x4A, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xBE, 0x3A, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xC7, 0xCD, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xC0, 0x4B, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xC0, 0x9B, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xC7, 0xCC, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x02, 0x86, 0xB4, 0x02, 0x98, 0x2D, 0x02, 0x80,
+0x86, 0x02, 0x80, 0x89, 0x02, 0x87, 0x26, 0x02,
+0xA9, 0x8D, 0x02, 0xBE, 0xE9, 0x02, 0x80, 0x95,
+0x02, 0x80, 0x98, 0x02, 0x80, 0x9B, 0x02, 0x80,
+0x9E, 0x02, 0x80, 0xA1, 0x02, 0x80, 0xA4, 0x02,
+0x80, 0xA7, 0x02, 0x80, 0xAA, 0x02, 0x80, 0xAD,
+0x02, 0x80, 0xB0, 0x02, 0x80, 0xB3, 0x02, 0x80,
+0xB6, 0x02, 0x80, 0xB9, 0x02, 0x80, 0xBC, 0x02,
+0x80, 0xBF, 0x02, 0x80, 0xC2, 0x02, 0x80, 0xC5,
+0x02, 0x80, 0xC8, 0x02, 0x80, 0xCB, 0x02, 0x80,
+0xCE, 0x02, 0x80, 0xD1, 0x02, 0xD6, 0xCC, 0x02,
+0x80, 0xD7, 0x00, 0x00, 0x00, 0x02, 0x80, 0xDD,
+0x02, 0x80, 0xE0, 0x02, 0x80, 0xE3, 0x02, 0x92,
+0xCE, 0x02, 0xD0, 0x0C, 0x02, 0x80, 0xEC, 0x02,
+0x80, 0xEF, 0x02, 0x80, 0xF2, 0x02, 0x80, 0xF5,
+0x02, 0x80, 0xF8, 0x02, 0x80, 0xFB, 0x02, 0x90,
+0xF6, 0x02, 0x81, 0x01, 0x02, 0x94, 0x37, 0x02,
+0x81, 0x07, 0x02, 0xDA, 0xFE, 0x02, 0x81, 0x0D,
+0x02, 0x81, 0x10, 0x02, 0xDD, 0x53, 0x02, 0xA3,
+0x03, 0x02, 0x81, 0x19, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x02, 0xBB, 0x52, 0x02,
+0xB7, 0x7A, 0x02, 0x93, 0xE2, 0x02, 0x90, 0xEB,
+0x02, 0x81, 0x40, 0x02, 0xAA, 0xEE, 0x02, 0xCB,
+0x96, 0x02, 0x81, 0x49, 0x02, 0x81, 0x4C, 0x02,
+0x81, 0x4F, 0x02, 0x81, 0x52, 0x02, 0x81, 0x55,
+0x02, 0x81, 0x58, 0x02, 0x81, 0x5B, 0x02, 0xC3,
+0xED, 0x02, 0x81, 0x61, 0x02, 0x81, 0x64, 0x02,
+0xCC, 0xC5, 0x02, 0xCF, 0x4F, 0x02, 0xCF, 0x28,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xC2, 0xAF, 0x80, 0xFE, 0x32, 0x12, 0x83, 0x04,
+0x85, 0xD0, 0x0B, 0x75, 0xD0, 0x08, 0xAA, 0xE0,
+0xC2, 0x8C, 0xE5, 0x8A, 0x24, 0x67, 0xF5, 0x8A,
+0xE5, 0x8C, 0x34, 0x79, 0xF5, 0x8C, 0xD2, 0x8C,
+0xEC, 0x24, 0x87, 0xF8, 0xE6, 0xBC, 0x02, 0x02,
+0x74, 0xFF, 0xC3, 0x95, 0x81, 0xB4, 0x40, 0x00,
+0x40, 0xCE, 0x79, 0x03, 0x78, 0x80, 0x16, 0xE6,
+0x08, 0x70, 0x0B, 0xC2, 0xAF, 0xE6, 0x30, 0xE1,
+0x03, 0x44, 0x18, 0xF6, 0xD2, 0xAF, 0x08, 0xD9,
+0xED, 0xEA, 0x8B, 0xD0, 0x22, 0xE5, 0x0C, 0xFF,
+0x23, 0x24, 0x81, 0xF8, 0x0F, 0x08, 0x08, 0xBF,
+0x03, 0x04, 0x7F, 0x00, 0x78, 0x81, 0xE6, 0x30,
+0xE4, 0xF2, 0x00, 0xE5, 0x0C, 0xC3, 0x9F, 0x50,
+0x20, 0x05, 0x0C, 0x74, 0x86, 0x25, 0x0C, 0xF8,
+0xE6, 0xFD, 0xA6, 0x81, 0x08, 0xE6, 0xAE, 0x0C,
+0xBE, 0x02, 0x02, 0x74, 0xFF, 0xCD, 0xF8, 0xE8,
+0x6D, 0x60, 0xE0, 0x08, 0xE6, 0xC0, 0xE0, 0x80,
+0xF6, 0xE5, 0x0C, 0xD3, 0x9F, 0x40, 0x27, 0xE5,
+0x0C, 0x24, 0x87, 0xF8, 0xE6, 0xAE, 0x0C, 0xBE,
+0x02, 0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xCD,
+0xF8, 0xE5, 0x81, 0x6D, 0x60, 0x06, 0xD0, 0xE0,
+0xF6, 0x18, 0x80, 0xF5, 0xE5, 0x0C, 0x24, 0x86,
+0xC8, 0xF6, 0x15, 0x0C, 0x80, 0xD3, 0xE5, 0x0C,
+0x23, 0x24, 0x81, 0xF8, 0x7F, 0x04, 0xC2, 0xAF,
+0xE6, 0x30, 0xE0, 0x03, 0x10, 0xE2, 0x0C, 0x7F,
+0x00, 0x30, 0xE1, 0x07, 0x30, 0xE3, 0x04, 0x7F,
+0x08, 0x54, 0xF4, 0x54, 0x7C, 0xC6, 0xD2, 0xAF,
+0x54, 0x80, 0x42, 0x07, 0x22, 0x78, 0x86, 0xA6,
+0x81, 0x74, 0x02, 0x60, 0x06, 0xFF, 0x08, 0x76,
+0xFF, 0xDF, 0xFB, 0x7F, 0x03, 0xE4, 0x78, 0x80,
+0xF6, 0x08, 0xF6, 0x08, 0xDF, 0xFA, 0x78, 0x81,
+0x76, 0x30, 0x90, 0x86, 0xA4, 0x74, 0x01, 0x93,
+0xC0, 0xE0, 0xE4, 0x93, 0xC0, 0xE0, 0x43, 0x89,
+0x01, 0x75, 0x8A, 0x60, 0x75, 0x8C, 0x79, 0xD2,
+0x8C, 0xD2, 0xAF, 0x22, 0x02, 0xEF, 0xD3, 0x94,
+0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0x74, 0x81,
+0x2F, 0x2F, 0xF8, 0xE6, 0x20, 0xE5, 0xF4, 0xC2,
+0xAF, 0xE6, 0x44, 0x30, 0xF6, 0xD2, 0xAF, 0xAE,
+0x0C, 0xEE, 0xC3, 0x9F, 0x50, 0x21, 0x0E, 0x74,
+0x86, 0x2E, 0xF8, 0xE6, 0xF9, 0x08, 0xE6, 0x18,
+0xBE, 0x02, 0x02, 0x74, 0xFF, 0xFD, 0xED, 0x69,
+0x60, 0x09, 0x09, 0xE7, 0x19, 0x19, 0xF7, 0x09,
+0x09, 0x80, 0xF3, 0x16, 0x16, 0x80, 0xDA, 0xEE,
+0xD3, 0x9F, 0x40, 0x04, 0x05, 0x81, 0x05, 0x81,
+0xEE, 0xD3, 0x9F, 0x40, 0x22, 0x74, 0x86, 0x2E,
+0xF8, 0x08, 0xE6, 0xF9, 0xEE, 0xB5, 0x0C, 0x02,
+0xA9, 0x81, 0x18, 0x06, 0x06, 0xE6, 0xFD, 0xED,
+0x69, 0x60, 0x09, 0x19, 0x19, 0xE7, 0x09, 0x09,
+0xF7, 0x19, 0x80, 0xF3, 0x1E, 0x80, 0xD9, 0xEF,
+0x24, 0x86, 0xF8, 0xE6, 0x04, 0xF8, 0xEF, 0x2F,
+0x04, 0x90, 0x86, 0xA4, 0x93, 0xF6, 0x08, 0xEF,
+0x2F, 0x93, 0xF6, 0x7F, 0x00, 0x22, 0xEF, 0xD3,
+0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22, 0xEF,
+0x23, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE5, 0xF4,
+0xC2, 0xAF, 0xE6, 0x54, 0x8C, 0xF6, 0xD2, 0xAF,
+0xE5, 0x0C, 0xB5, 0x07, 0x0A, 0x74, 0x86, 0x2F,
+0xF8, 0xE6, 0xF5, 0x81, 0x02, 0x83, 0x4D, 0x50,
+0x2E, 0x74, 0x87, 0x2F, 0xF8, 0xE6, 0xBF, 0x02,
+0x02, 0x74, 0xFF, 0xFD, 0x18, 0xE6, 0xF9, 0x74,
+0x86, 0x2F, 0xF8, 0xFB, 0xE6, 0xFC, 0xE9, 0x6C,
+0x60, 0x08, 0xA8, 0x05, 0xE7, 0xF6, 0x1D, 0x19,
+0x80, 0xF4, 0xA8, 0x03, 0xA6, 0x05, 0x1F, 0xE5,
+0x0C, 0xB5, 0x07, 0xE3, 0x7F, 0x00, 0x22, 0x74,
+0x87, 0x2F, 0xF8, 0xE6, 0xFD, 0x18, 0x86, 0x01,
+0x0F, 0x74, 0x86, 0x2F, 0xF8, 0xA6, 0x01, 0x08,
+0x86, 0x04, 0xE5, 0x0C, 0xB5, 0x07, 0x02, 0xAC,
+0x81, 0xED, 0x6C, 0x60, 0x08, 0x0D, 0x09, 0xA8,
+0x05, 0xE6, 0xF7, 0x80, 0xF4, 0xE5, 0x0C, 0xB5,
+0x07, 0xDE, 0x89, 0x81, 0x7F, 0x00, 0x22, 0xEF,
+0xD3, 0x94, 0x02, 0x40, 0x03, 0x7F, 0xFF, 0x22,
+0xEF, 0x23, 0x24, 0x81, 0xF8, 0xC2, 0xAF, 0xE6,
+0x30, 0xE5, 0x05, 0x30, 0xE0, 0x02, 0xD2, 0xE4,
+0xD2, 0xE2, 0xC6, 0xD2, 0xAF, 0x7F, 0x00, 0x30,
+0xE2, 0x01, 0x0F, 0x02, 0x83, 0x4C, 0x8F, 0xF0,
+0xE4, 0xFF, 0xFE, 0xE5, 0x0C, 0x23, 0x24, 0x80,
+0xF8, 0xC2, 0xA9, 0x30, 0xF7, 0x0D, 0x7F, 0x08,
+0xE6, 0x60, 0x0B, 0x2D, 0xF6, 0x60, 0x30, 0x50,
+0x2E, 0x80, 0x07, 0x30, 0xF1, 0x06, 0xED, 0xF6,
+0x60, 0x25, 0x7E, 0x02, 0x08, 0x30, 0xF0, 0x10,
+0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x23, 0x0E, 0x30,
+0xE2, 0x0C, 0xD2, 0xAF, 0x7F, 0x04, 0x80, 0x12,
+0xC2, 0xAF, 0xE6, 0x10, 0xE7, 0x13, 0x54, 0xEC,
+0x4E, 0xF6, 0xD2, 0xAF, 0x02, 0x83, 0x4D, 0x7F,
+0x08, 0x08, 0xEF, 0x44, 0x83, 0xF4, 0xC2, 0xAF,
+0x56, 0xC6, 0xD2, 0xAF, 0x54, 0x80, 0x4F, 0xFF,
+0x22, 0x02, 0x85, 0xE7, 0x02, 0x83, 0xDD, 0xE4,
+0x93, 0xA3, 0xF8, 0xE4, 0x93, 0xA3, 0x40, 0x03,
+0xF6, 0x80, 0x01, 0xF2, 0x08, 0xDF, 0xF4, 0x80,
+0x29, 0xE4, 0x93, 0xA3, 0xF8, 0x54, 0x07, 0x24,
+0x0C, 0xC8, 0xC3, 0x33, 0xC4, 0x54, 0x0F, 0x44,
+0x20, 0xC8, 0x83, 0x40, 0x04, 0xF4, 0x56, 0x80,
+0x01, 0x46, 0xF6, 0xDF, 0xE4, 0x80, 0x0B, 0x01,
+0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x90,
+0x86, 0xAA, 0xE4, 0x7E, 0x01, 0x93, 0x60, 0xBC,
+0xA3, 0xFF, 0x54, 0x3F, 0x30, 0xE5, 0x09, 0x54,
+0x1F, 0xFE, 0xE4, 0x93, 0xA3, 0x60, 0x01, 0x0E,
+0xCF, 0x54, 0xC0, 0x25, 0xE0, 0x60, 0xA8, 0x40,
+0xB8, 0xE4, 0x93, 0xA3, 0xFA, 0xE4, 0x93, 0xA3,
+0xF8, 0xE4, 0x93, 0xA3, 0xC8, 0xC5, 0x82, 0xC8,
+0xCA, 0xC5, 0x83, 0xCA, 0xF0, 0xA3, 0xC8, 0xC5,
+0x82, 0xC8, 0xCA, 0xC5, 0x83, 0xCA, 0xDF, 0xE9,
+0xDE, 0xE7, 0x80, 0xBE, 0xC3, 0xEF, 0x9B, 0xFF,
+0xEE, 0x9A, 0xFE, 0xED, 0x99, 0xFD, 0xEC, 0x98,
+0xFC, 0x22, 0xEF, 0x5B, 0xFF, 0xEE, 0x5A, 0xFE,
+0xED, 0x59, 0xFD, 0xEC, 0x58, 0xFC, 0x22, 0xEF,
+0x4B, 0xFF, 0xEE, 0x4A, 0xFE, 0xED, 0x49, 0xFD,
+0xEC, 0x48, 0xFC, 0x22, 0xE0, 0xFC, 0xA3, 0xE0,
+0xFD, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
+0xE0, 0xF8, 0xA3, 0xE0, 0xF9, 0xA3, 0xE0, 0xFA,
+0xA3, 0xE0, 0xFB, 0x22, 0xE0, 0xFB, 0xA3, 0xE0,
+0xFA, 0xA3, 0xE0, 0xF9, 0x22, 0xEB, 0xF0, 0xA3,
+0xEA, 0xF0, 0xA3, 0xE9, 0xF0, 0x22, 0xD0, 0x83,
+0xD0, 0x82, 0xF8, 0xE4, 0x93, 0x70, 0x12, 0x74,
+0x01, 0x93, 0x70, 0x0D, 0xA3, 0xA3, 0x93, 0xF8,
+0x74, 0x01, 0x93, 0xF5, 0x82, 0x88, 0x83, 0xE4,
+0x73, 0x74, 0x02, 0x93, 0x68, 0x60, 0xEF, 0xA3,
+0xA3, 0xA3, 0x80, 0xDF, 0xB3, 0x87, 0xB9, 0x24,
+0xBF, 0xF5, 0x41, 0x96, 0x97, 0x00, 0x00, 0x12,
+0x5E, 0x10, 0x7F, 0x04, 0x90, 0x96, 0x95, 0xEF,
+0xF0, 0x7F, 0x02, 0xB1, 0x27, 0x90, 0x84, 0xC1,
+0xE0, 0xFF, 0x90, 0x96, 0x95, 0xE0, 0xFE, 0xEF,
+0x4E, 0x90, 0x84, 0xC1, 0xF0, 0x22, 0xF1, 0xB0,
+0x12, 0x02, 0xF6, 0xFF, 0xF1, 0x20, 0x12, 0xDE,
+0xC7, 0xC0, 0x03, 0x90, 0x92, 0x05, 0xD1, 0x6C,
+0xF1, 0xE2, 0xF1, 0xE9, 0xD0, 0x03, 0xF1, 0x26,
+0x90, 0x92, 0x05, 0xF1, 0x1E, 0x12, 0xC7, 0xB5,
+0x12, 0x8D, 0xAD, 0x90, 0x92, 0x08, 0x74, 0x10,
+0xF0, 0x90, 0x92, 0x16, 0x74, 0x07, 0xF0, 0x90,
+0x92, 0x05, 0xD1, 0x6C, 0x12, 0x02, 0xF6, 0x90,
+0x92, 0x0A, 0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79,
+0x08, 0x12, 0x5E, 0x10, 0x7F, 0x04, 0x80, 0x9C,
+0x12, 0x03, 0x3C, 0x90, 0x96, 0x65, 0xD1, 0x6C,
+0x90, 0x00, 0x01, 0x02, 0x03, 0x0F, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x81,
+0xEF, 0xF0, 0xED, 0x64, 0x01, 0x70, 0x30, 0xEB,
+0xB4, 0x01, 0x07, 0xE0, 0x24, 0x02, 0xF5, 0x17,
+0x80, 0x08, 0x90, 0x96, 0x81, 0xE0, 0x24, 0xFE,
+0xF5, 0x17, 0x90, 0x96, 0x18, 0x12, 0x04, 0xF7,
+0x00, 0x00, 0x00, 0xFF, 0xAF, 0x17, 0xE4, 0xFC,
+0xFD, 0xFE, 0xF1, 0x9D, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x00, 0xFF, 0xAF, 0x17, 0x80, 0x1E, 0x90,
+0x96, 0x18, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
+0xFF, 0x90, 0x96, 0x81, 0x12, 0x8F, 0xA2, 0xF1,
+0x9D, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0xFF,
+0x90, 0x96, 0x81, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD,
+0xFE, 0x90, 0x96, 0x1C, 0x12, 0x04, 0xEB, 0x7D,
+0x18, 0x7C, 0x00, 0x7F, 0x01, 0x12, 0xC9, 0x10,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x96, 0x1C,
+0x12, 0x04, 0xEB, 0x7D, 0x18, 0x7C, 0x00, 0xE4,
+0xFF, 0x12, 0xC9, 0x10, 0x90, 0x96, 0x18, 0x22,
+0x90, 0x92, 0x05, 0xC1, 0x75, 0xF1, 0xB0, 0x90,
+0x02, 0x09, 0xE0, 0xFD, 0x90, 0x92, 0x05, 0xF1,
+0xF0, 0xAF, 0x05, 0xED, 0x2E, 0x90, 0x88, 0xDC,
+0xF0, 0x90, 0x92, 0x05, 0xF1, 0x1E, 0xFF, 0xED,
+0x2F, 0x90, 0x95, 0xC9, 0xF1, 0xE1, 0xFF, 0xAE,
+0x05, 0xED, 0x2F, 0x90, 0x95, 0xCA, 0xF0, 0x22,
+0x4F, 0xF0, 0x90, 0x00, 0x02, 0x02, 0x03, 0x0F,
+0xC4, 0x54, 0x0F, 0x90, 0x96, 0x84, 0xF0, 0x22,
+0xD1, 0x6C, 0x12, 0x02, 0xF6, 0xFE, 0x22, 0x90,
+0x02, 0x09, 0xE0, 0xF5, 0x0D, 0x12, 0x02, 0xF6,
+0x25, 0x0D, 0x90, 0x84, 0xC6, 0xF0, 0x12, 0x87,
+0x20, 0x25, 0x0D, 0x90, 0x84, 0xC7, 0x12, 0x87,
+0xE1, 0x25, 0x0D, 0x90, 0x84, 0xC8, 0x11, 0x36,
+0x25, 0x0D, 0x90, 0x84, 0xC9, 0xF0, 0x71, 0xC6,
+0x25, 0x0D, 0x90, 0x84, 0xCA, 0xF0, 0x71, 0xCC,
+0x25, 0x0D, 0x90, 0x84, 0xCB, 0x71, 0xD2, 0x25,
+0x0D, 0x90, 0x84, 0xCC, 0xF0, 0x22, 0xF0, 0x90,
+0x00, 0x03, 0x02, 0x03, 0x0F, 0x90, 0x96, 0x58,
+0x12, 0x86, 0x75, 0x90, 0x96, 0x61, 0xE0, 0xFF,
+0x64, 0x04, 0x70, 0x52, 0x11, 0xF9, 0x12, 0x02,
+0xF6, 0xFE, 0x31, 0x03, 0xEE, 0x12, 0x03, 0x3C,
+0x90, 0x96, 0x58, 0x12, 0x87, 0x1E, 0xFE, 0x31,
+0x03, 0x90, 0x00, 0x01, 0x11, 0xF5, 0x71, 0xC6,
+0xFE, 0x31, 0x03, 0x90, 0x00, 0x02, 0x11, 0xF5,
+0x71, 0xCC, 0xFE, 0x31, 0x03, 0x90, 0x00, 0x03,
+0x11, 0xF5, 0x71, 0xD3, 0xFE, 0x31, 0x03, 0x90,
+0x00, 0x04, 0x11, 0xF5, 0x90, 0x00, 0x07, 0x12,
+0x03, 0x0F, 0xFE, 0x31, 0x03, 0x90, 0x00, 0x05,
+0x11, 0xF5, 0x11, 0x37, 0xFE, 0x90, 0x96, 0x5E,
+0x12, 0x86, 0x6C, 0xEE, 0x80, 0x53, 0xEF, 0x64,
+0x02, 0x70, 0x51, 0x11, 0xF9, 0x90, 0x00, 0x02,
+0x11, 0xFF, 0xEF, 0x12, 0x03, 0x3C, 0x11, 0xF9,
+0x12, 0x02, 0xF6, 0x31, 0x02, 0x90, 0x00, 0x01,
+0xEF, 0x11, 0xF6, 0x90, 0x00, 0x04, 0x11, 0xFF,
+0x90, 0x00, 0x02, 0xEF, 0x11, 0xF6, 0x90, 0x00,
+0x05, 0x11, 0xFF, 0x90, 0x00, 0x03, 0xEF, 0x11,
+0xF6, 0x90, 0x00, 0x06, 0x11, 0xFF, 0x90, 0x00,
+0x04, 0xEF, 0x11, 0xF6, 0x90, 0x00, 0x07, 0x11,
+0xFF, 0x90, 0x00, 0x05, 0xEF, 0x11, 0xF6, 0x11,
+0x37, 0xFF, 0x90, 0x96, 0x5E, 0x12, 0x86, 0x6C,
+0xEF, 0x12, 0x03, 0x3C, 0x22, 0xEE, 0x12, 0x03,
+0x4E, 0x90, 0x96, 0x58, 0x02, 0x86, 0x6C, 0x12,
+0x03, 0x0F, 0xFF, 0x90, 0x96, 0x5B, 0x02, 0x86,
+0x6C, 0x90, 0x96, 0x62, 0x12, 0x86, 0x75, 0x90,
+0x96, 0x6B, 0xE0, 0xFF, 0xB4, 0x04, 0x1A, 0x31,
+0x9D, 0x12, 0x02, 0xF6, 0x31, 0x92, 0xEE, 0x12,
+0x87, 0x18, 0x31, 0x92, 0x90, 0x00, 0x01, 0xEE,
+0x12, 0x03, 0x4E, 0x90, 0x00, 0x02, 0xE4, 0x80,
+0x25, 0xEF, 0x64, 0x02, 0x70, 0x23, 0x12, 0x87,
+0x1B, 0xFF, 0x31, 0x93, 0xEF, 0x12, 0x87, 0x18,
+0x44, 0x20, 0x54, 0x7F, 0xFF, 0x31, 0x93, 0x90,
+0x00, 0x01, 0x31, 0x99, 0x12, 0x02, 0xF6, 0xFF,
+0x31, 0x93, 0x90, 0x00, 0x02, 0xEF, 0x12, 0x03,
+0x4E, 0x31, 0x93, 0xE9, 0x24, 0x03, 0xF1, 0xCC,
+0x44, 0x20, 0x12, 0x03, 0x3C, 0x31, 0x9D, 0x12,
+0x87, 0xE2, 0xFF, 0x31, 0x93, 0x90, 0x00, 0x04,
+0x31, 0x99, 0x11, 0x37, 0xFF, 0x31, 0x93, 0x90,
+0x00, 0x05, 0x31, 0x99, 0x71, 0xC6, 0xFF, 0x31,
+0x93, 0x90, 0x00, 0x06, 0x31, 0x99, 0x71, 0xCC,
+0xFF, 0x31, 0x93, 0x90, 0x00, 0x07, 0xEF, 0x02,
+0x03, 0x4E, 0xFE, 0x90, 0x96, 0x62, 0x02, 0x86,
+0x6C, 0xEF, 0x12, 0x03, 0x4E, 0x90, 0x96, 0x65,
+0x02, 0x86, 0x6C, 0x90, 0x92, 0x5E, 0x12, 0x86,
+0x75, 0xF1, 0x96, 0x7A, 0x92, 0x79, 0x65, 0x12,
+0x06, 0xDE, 0xF1, 0x96, 0x7A, 0x92, 0x79, 0x6D,
+0x12, 0x06, 0xDE, 0x7B, 0x01, 0x7A, 0x92, 0x79,
+0x65, 0xF1, 0x80, 0x7A, 0x92, 0x79, 0x76, 0x51,
+0x21, 0x90, 0x96, 0x61, 0xF1, 0x86, 0x11, 0x3D,
+0x7B, 0x01, 0x7A, 0x92, 0x79, 0x6D, 0xF1, 0x80,
+0x7A, 0x92, 0x79, 0x75, 0x51, 0x21, 0x90, 0x96,
+0x61, 0xF0, 0x90, 0x92, 0x61, 0x12, 0x86, 0x6C,
+0x11, 0x3D, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x65,
+0x12, 0xD9, 0x20, 0x74, 0x08, 0xF0, 0x7A, 0x92,
+0x79, 0x6D, 0x12, 0xD9, 0x2A, 0x40, 0x1F, 0x7B,
+0x01, 0x7A, 0x92, 0x79, 0x6D, 0x90, 0x96, 0x65,
+0x12, 0x86, 0x75, 0x7A, 0x92, 0x79, 0x75, 0x90,
+0x96, 0x68, 0x51, 0x24, 0x90, 0x96, 0x6B, 0xF1,
+0x86, 0x31, 0x09, 0x7F, 0x01, 0x22, 0x7F, 0x00,
+0x22, 0x90, 0x96, 0x5E, 0x12, 0x86, 0x75, 0x90,
+0x92, 0x64, 0xE0, 0x22, 0x12, 0xDF, 0x14, 0x12,
+0xDF, 0xA7, 0xBF, 0x0F, 0x17, 0x90, 0x94, 0x6B,
+0xE0, 0x54, 0xFE, 0xF0, 0x12, 0xC7, 0x7A, 0x51,
+0xEC, 0x12, 0x02, 0xF6, 0x54, 0x0F, 0xFF, 0x91,
+0xBA, 0x02, 0xC8, 0x50, 0x51, 0xEC, 0x12, 0x87,
+0x20, 0xF1, 0xEB, 0xF1, 0xFA, 0xEF, 0x12, 0x87,
+0xE1, 0x54, 0x03, 0xFF, 0xED, 0x91, 0xAB, 0x54,
+0xFC, 0x12, 0x87, 0xE0, 0x54, 0x1C, 0xFF, 0xEE,
+0x54, 0x0F, 0xFE, 0x91, 0xAB, 0x54, 0xE3, 0x12,
+0x87, 0xE0, 0x54, 0xE0, 0xFF, 0xEE, 0x91, 0xAB,
+0x54, 0x1F, 0x4F, 0xF0, 0x71, 0xC6, 0xF1, 0xDB,
+0xE4, 0xFB, 0x51, 0xEA, 0x71, 0xCC, 0xF1, 0xDB,
+0x7B, 0x01, 0x51, 0xEA, 0x11, 0x37, 0x33, 0x33,
+0x33, 0x54, 0xF8, 0xF1, 0xEB, 0xFD, 0x75, 0xF0,
+0x0E, 0xA4, 0x24, 0x78, 0xF5, 0x82, 0xE4, 0x34,
+0x94, 0xF5, 0x83, 0xEF, 0x11, 0x36, 0xC4, 0x13,
+0x54, 0x07, 0xFF, 0xED, 0x75, 0xF0, 0x0E, 0xA4,
+0x24, 0x79, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
+0x83, 0xEF, 0xF0, 0xEE, 0xC4, 0x54, 0x0F, 0xFF,
+0x14, 0x6D, 0x70, 0x25, 0x90, 0x94, 0x6D, 0xEF,
+0x71, 0xD2, 0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFF,
+0x90, 0x94, 0x6C, 0xE0, 0x54, 0x0F, 0x4F, 0xF0,
+0x54, 0xF1, 0xF0, 0x90, 0x94, 0x6B, 0xE0, 0x44,
+0x01, 0xF0, 0x7D, 0x20, 0xE4, 0xFF, 0x12, 0x7B,
+0xFD, 0x22, 0x51, 0xF3, 0xAB, 0x0D, 0xAA, 0x0E,
+0xA9, 0x0F, 0x22, 0x8F, 0x10, 0x8D, 0x11, 0xAE,
+0x03, 0x74, 0x1F, 0xC3, 0x95, 0x10, 0x40, 0x0A,
+0x71, 0xBE, 0xE4, 0xFD, 0x71, 0xB6, 0x24, 0xD4,
+0x80, 0x31, 0x74, 0x3F, 0xC3, 0x95, 0x10, 0x40,
+0x0A, 0x71, 0xBE, 0x7D, 0x20, 0x71, 0xB4, 0x24,
+0x88, 0x80, 0x20, 0x74, 0x5F, 0xC3, 0x95, 0x10,
+0x40, 0x0A, 0x71, 0xBE, 0x7D, 0x40, 0x71, 0xB4,
+0x24, 0xD0, 0x80, 0x0F, 0x74, 0x7F, 0xC3, 0x95,
+0x10, 0x40, 0x21, 0x71, 0xBE, 0x7D, 0x60, 0x71,
+0xB4, 0x24, 0x84, 0xFD, 0xE4, 0x34, 0x04, 0xFC,
+0xE5, 0x11, 0xF1, 0x70, 0x34, 0x94, 0xF5, 0x83,
+0x75, 0xF0, 0x03, 0xEE, 0x12, 0x05, 0x28, 0xEC,
+0xF0, 0xA3, 0xED, 0xF0, 0x22, 0xC3, 0xEF, 0x9D,
+0xF5, 0x12, 0xC3, 0x94, 0x08, 0x50, 0x18, 0xE4,
+0xF5, 0x13, 0xF1, 0x61, 0xC0, 0x83, 0xC0, 0x82,
+0x90, 0x92, 0x09, 0xE0, 0xD0, 0x82, 0xD0, 0x83,
+0xB1, 0xA7, 0xE5, 0x12, 0xF0, 0x80, 0x3A, 0xE5,
+0x12, 0xC3, 0x94, 0x10, 0x50, 0x09, 0x75, 0x13,
+0x01, 0xE5, 0x12, 0x24, 0xF8, 0x80, 0x17, 0xE5,
+0x12, 0xC3, 0x94, 0x18, 0x50, 0x09, 0x75, 0x13,
+0x02, 0xE5, 0x12, 0x24, 0xF0, 0x80, 0x07, 0x75,
+0x13, 0x03, 0xE5, 0x12, 0x24, 0xE8, 0xFF, 0xF1,
+0x61, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x92, 0x09,
+0xE0, 0xD0, 0x82, 0xD0, 0x83, 0xB1, 0xA7, 0xEF,
+0xF0, 0xAF, 0x13, 0x22, 0xAF, 0x10, 0x71, 0x55,
+0x90, 0x92, 0x05, 0xEF, 0xF0, 0x22, 0x90, 0x92,
+0x09, 0xEE, 0xF0, 0xAB, 0x11, 0x22, 0x90, 0x00,
+0x04, 0x02, 0x03, 0x0F, 0x90, 0x00, 0x05, 0x02,
+0x03, 0x0F, 0xF0, 0x90, 0x00, 0x06, 0x02, 0x03,
+0x0F, 0x12, 0x87, 0xB0, 0x12, 0x02, 0xF6, 0xFF,
+0x54, 0x7F, 0x90, 0x85, 0xC5, 0xF0, 0xEF, 0xF1,
+0xF3, 0xA3, 0xF0, 0x12, 0x87, 0x20, 0xFD, 0x54,
+0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x85, 0xC3,
+0xE0, 0x54, 0xF0, 0x4F, 0x11, 0x36, 0xFC, 0x54,
+0x01, 0x25, 0xE0, 0xFF, 0x90, 0x85, 0xC1, 0xE0,
+0x54, 0xFD, 0x4F, 0xF0, 0xEC, 0x54, 0x04, 0xFF,
+0x90, 0x94, 0xA6, 0xE0, 0x54, 0xFB, 0x4F, 0xF0,
+0xED, 0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFF, 0xF1,
+0xD4, 0x12, 0x87, 0xE0, 0x90, 0x85, 0xC4, 0x71,
+0xD2, 0x30, 0xE0, 0x55, 0xC3, 0x13, 0x54, 0x07,
+0xFF, 0xC3, 0x94, 0x04, 0x90, 0x85, 0xD8, 0x50,
+0x04, 0xEF, 0xF0, 0x80, 0x29, 0x74, 0x03, 0xF0,
+0x90, 0x92, 0x05, 0x12, 0x86, 0x6C, 0xE9, 0x24,
+0x06, 0xF1, 0xCC, 0xFF, 0x74, 0x03, 0x24, 0xFD,
+0xFE, 0xEF, 0xC4, 0x54, 0x0F, 0xFD, 0xEF, 0x54,
+0x0F, 0xFF, 0xED, 0x2E, 0x54, 0x0F, 0xFE, 0xC4,
+0x54, 0xF0, 0x4F, 0x12, 0x03, 0x3C, 0x90, 0x92,
+0x05, 0x12, 0x86, 0x6C, 0x71, 0xD3, 0xC4, 0x54,
+0x0F, 0xFF, 0xC3, 0x94, 0x04, 0x90, 0x85, 0xCD,
+0x50, 0x05, 0x74, 0x04, 0xF0, 0x80, 0x02, 0xEF,
+0xF0, 0x90, 0x92, 0x05, 0x12, 0x86, 0x6C, 0x71,
+0xC6, 0xFD, 0x7F, 0x02, 0x12, 0x57, 0x82, 0x90,
+0x92, 0x05, 0x12, 0x86, 0x6C, 0x12, 0x71, 0xCB,
+0x12, 0xC5, 0xAF, 0xF0, 0x90, 0x85, 0xC5, 0x12,
+0xDE, 0xA5, 0xF1, 0xD3, 0x90, 0x01, 0xBE, 0xF0,
+0x22, 0xE5, 0x10, 0x75, 0xF0, 0x0E, 0xA4, 0x24,
+0x70, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
+0xE0, 0x22, 0x8F, 0x10, 0x7B, 0x17, 0x7D, 0xFF,
+0x7F, 0xFF, 0xF1, 0xB3, 0xE5, 0x10, 0xF1, 0xFB,
+0xE0, 0xFC, 0x91, 0xA9, 0x12, 0xDE, 0xC7, 0x90,
+0x94, 0x6C, 0xE0, 0xFE, 0x12, 0x87, 0xE8, 0xAF,
+0x04, 0x12, 0x87, 0x26, 0x91, 0xA9, 0x12, 0xC7,
+0xB5, 0xB1, 0xAD, 0xE5, 0x10, 0x12, 0xC2, 0x7D,
+0xF1, 0xB8, 0xAD, 0x10, 0x7F, 0x01, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x79,
+0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0xE4, 0xA3, 0xF0,
+0x90, 0x96, 0x7B, 0xE0, 0xFF, 0xC3, 0x94, 0x03,
+0x40, 0x02, 0xA1, 0xA2, 0x90, 0x96, 0x7A, 0xE0,
+0xFE, 0xF1, 0x70, 0x34, 0x94, 0xF5, 0x83, 0x75,
+0xF0, 0x03, 0xEF, 0x12, 0x05, 0x28, 0xE0, 0xFC,
+0xA3, 0xE0, 0xF5, 0x82, 0x8C, 0x83, 0xE0, 0x90,
+0x96, 0x7C, 0xF0, 0x90, 0x96, 0x79, 0xE0, 0xFC,
+0xB4, 0x02, 0x21, 0x90, 0x96, 0x7C, 0xE0, 0xFD,
+0xEE, 0xF1, 0x62, 0xC0, 0x83, 0xC0, 0x82, 0x90,
+0x96, 0x7B, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0xB1,
+0xA7, 0xF1, 0xE3, 0x80, 0x02, 0xC3, 0x33, 0xD8,
+0xFC, 0x4D, 0x80, 0x21, 0xEC, 0xB4, 0x01, 0x21,
+0x12, 0xDF, 0x0A, 0xF1, 0x62, 0xC0, 0x83, 0xC0,
+0x82, 0x90, 0x96, 0x7B, 0xE0, 0xD0, 0x82, 0xD0,
+0x83, 0xB1, 0xA7, 0xF1, 0xE3, 0x80, 0x02, 0xC3,
+0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0x90, 0x96, 0x7C,
+0xF0, 0x12, 0xDF, 0x0A, 0xF1, 0x70, 0x34, 0x94,
+0xF5, 0x83, 0xC0, 0x83, 0xC0, 0x82, 0x90, 0x96,
+0x7B, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0xB1, 0xA7,
+0xE0, 0xFC, 0xA3, 0xE0, 0xF5, 0x82, 0x8C, 0x83,
+0xEF, 0xF0, 0x90, 0x96, 0x7B, 0xE0, 0x04, 0xF0,
+0xA1, 0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x75,
+0xF0, 0x03, 0x02, 0x05, 0x28, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x93, 0xED,
+0xF0, 0xE4, 0xA3, 0xF0, 0xEF, 0x14, 0x60, 0x02,
+0xC1, 0x8B, 0x90, 0x06, 0x03, 0xE0, 0x54, 0xFB,
+0xF0, 0x90, 0x96, 0x93, 0xE0, 0xFB, 0xC4, 0x33,
+0x54, 0xE0, 0xFE, 0x90, 0x04, 0x42, 0xE0, 0x54,
+0x9F, 0x4E, 0xFE, 0xF0, 0xE4, 0xFD, 0x12, 0xC9,
+0x88, 0x90, 0x96, 0x94, 0xEF, 0xF0, 0x90, 0x04,
+0x83, 0xF0, 0x90, 0x96, 0x2A, 0x12, 0x04, 0xF7,
+0x00, 0x00, 0x00, 0x01, 0x90, 0x96, 0x2E, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x00, 0x01, 0xD1, 0xF1,
+0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x01, 0x90,
+0x96, 0x2E, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
+0x01, 0x7F, 0x00, 0x7E, 0x09, 0xD1, 0xF5, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x00, 0x10, 0xF1, 0x9F,
+0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x01, 0x12,
+0x04, 0xC5, 0x78, 0x04, 0xF1, 0x8D, 0x7F, 0x00,
+0x7E, 0x0A, 0xD1, 0xF5, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x0C, 0x00, 0xF1, 0x9F, 0xEF, 0x54, 0x03,
+0xFF, 0xE4, 0x78, 0x0A, 0xF1, 0x8D, 0x7F, 0x00,
+0x7E, 0x0D, 0xD1, 0xF5, 0x12, 0x04, 0xF7, 0x0C,
+0x00, 0x00, 0x00, 0x90, 0x96, 0x94, 0xF1, 0xA2,
+0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x1A, 0xF1,
+0x8D, 0x7F, 0x18, 0xD1, 0xF3, 0x12, 0x04, 0xF7,
+0x00, 0x00, 0x0C, 0x00, 0x90, 0x96, 0x2E, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x00, 0x00, 0xF1, 0xA9,
+0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00, 0x90,
+0x96, 0x1C, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x04,
+0x00, 0x80, 0x58, 0x90, 0x06, 0x03, 0xE0, 0x44,
+0x04, 0xF0, 0x90, 0x96, 0x2A, 0x12, 0x04, 0xF7,
+0x00, 0x00, 0x00, 0x01, 0x90, 0x96, 0x2E, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x00, 0x00, 0xD1, 0xF1,
+0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x01, 0x90,
+0x96, 0x2E, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00,
+0x00, 0x7F, 0x00, 0x7E, 0x09, 0xD1, 0xF5, 0x12,
+0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x96,
+0x2E, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C, 0x00,
+0xF1, 0xA9, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x0C,
+0x00, 0x90, 0x96, 0x1C, 0x12, 0x04, 0xF7, 0x00,
+0x00, 0x0C, 0x00, 0x7D, 0x18, 0x7C, 0x00, 0xE4,
+0xFF, 0x12, 0xC9, 0x10, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x7F, 0x00, 0x7E, 0x08, 0xD1, 0xFB, 0x90,
+0x96, 0x2A, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x96, 0x28, 0xEE, 0xF0, 0xA3,
+0xEF, 0xF0, 0x12, 0x70, 0x61, 0x90, 0x96, 0x32,
+0x12, 0x04, 0xEB, 0x90, 0x96, 0x2A, 0x12, 0x86,
+0x54, 0x12, 0x04, 0xA7, 0x90, 0x96, 0x32, 0xF1,
+0x7A, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0x90, 0x96, 0x2A, 0x12, 0x86, 0x54, 0x90,
+0x96, 0x2E, 0xF1, 0x7A, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x47, 0x90,
+0x96, 0x36, 0x12, 0x04, 0xEB, 0x90, 0x96, 0x36,
+0x12, 0x86, 0x54, 0x90, 0x91, 0x66, 0x12, 0x04,
+0xEB, 0x90, 0x96, 0x28, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x12, 0x71, 0x18, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xEB, 0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x73,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22,
+0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x71, 0xF5, 0x82,
+0xE4, 0x22, 0x12, 0x86, 0x60, 0x02, 0x86, 0x3A,
+0x90, 0x96, 0x5B, 0x02, 0x86, 0x75, 0xF0, 0x90,
+0x92, 0x5E, 0x02, 0x86, 0x6C, 0x12, 0x04, 0xD8,
+0x90, 0x96, 0x2E, 0x02, 0x04, 0xEB, 0x7E, 0x00,
+0x7F, 0x08, 0x7D, 0x00, 0x7B, 0x01, 0x22, 0x90,
+0x96, 0x93, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE,
+0x22, 0x7F, 0x84, 0x7E, 0x08, 0xD1, 0xFB, 0x90,
+0x96, 0x18, 0x22, 0xF1, 0xC1, 0x02, 0x93, 0xE2,
+0xFD, 0x12, 0xC1, 0xB3, 0xE4, 0xFB, 0xFD, 0x7F,
+0xFF, 0x90, 0x05, 0x22, 0xED, 0xF0, 0x90, 0x94,
+0x63, 0xEB, 0xF0, 0x22, 0xF9, 0xE4, 0x3A, 0xFA,
+0x02, 0x02, 0xF6, 0xF0, 0x90, 0x85, 0xC3, 0xE0,
+0x54, 0x0F, 0x22, 0xFF, 0x12, 0x02, 0xF6, 0x54,
+0x0F, 0xFD, 0x22, 0xE0, 0xFE, 0x74, 0x01, 0xA8,
+0x06, 0x08, 0x22, 0xFF, 0x12, 0x02, 0xF6, 0xFE,
+0x54, 0x0F, 0x22, 0xC4, 0x13, 0x13, 0x13, 0x54,
+0x01, 0x22, 0xFD, 0x75, 0xF0, 0x0E, 0xA4, 0x24,
+0x6F, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
+0x22, 0x12, 0xDF, 0x14, 0x90, 0x94, 0x9A, 0xE0,
+0x70, 0x0C, 0x12, 0xDF, 0x72, 0x30, 0xE0, 0x06,
+0x90, 0x94, 0xA0, 0x74, 0x01, 0xF0, 0x90, 0x94,
+0x9C, 0xE0, 0x70, 0x0F, 0x12, 0x8A, 0xEC, 0x12,
+0xDF, 0xA7, 0xBF, 0x05, 0x06, 0x90, 0x94, 0xA1,
+0x74, 0x01, 0xF0, 0x12, 0x8A, 0xEC, 0x12, 0x87,
+0x20, 0xFF, 0xF5, 0x11, 0x12, 0x02, 0xF6, 0xFE,
+0xC3, 0x13, 0x30, 0xE0, 0x07, 0x12, 0x87, 0xE2,
+0xF5, 0x12, 0x80, 0x02, 0x8F, 0x12, 0x85, 0x11,
+0x10, 0xE5, 0x10, 0xD3, 0x95, 0x12, 0x50, 0x2C,
+0x12, 0x8A, 0xEC, 0x12, 0x02, 0xF6, 0x54, 0x01,
+0xFD, 0xAF, 0x10, 0x12, 0x6E, 0x5F, 0xAF, 0x10,
+0x12, 0x77, 0x39, 0xEF, 0xAF, 0x10, 0x70, 0x04,
+0x11, 0x9F, 0x80, 0x02, 0xF1, 0xE0, 0x90, 0x94,
+0xA1, 0xE0, 0x60, 0x04, 0xAF, 0x10, 0x11, 0x9F,
+0x05, 0x10, 0x80, 0xCD, 0xE5, 0x11, 0x70, 0x16,
+0xFF, 0x12, 0x77, 0x39, 0xEF, 0x70, 0x0F, 0x12,
+0xBB, 0x52, 0x12, 0x79, 0x61, 0x12, 0xDF, 0x9F,
+0x54, 0xBF, 0xF0, 0x54, 0x7F, 0xF0, 0x22, 0x7D,
+0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x92, 0x05, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
+0x7D, 0x44, 0x7F, 0x6F, 0x11, 0xEB, 0x71, 0xE2,
+0x90, 0x92, 0x06, 0xE0, 0x90, 0x92, 0x05, 0xB4,
+0x01, 0x07, 0x11, 0xD6, 0x44, 0x04, 0xF0, 0x80,
+0x05, 0x11, 0xD6, 0x54, 0xFB, 0xF0, 0x12, 0xCC,
+0xBF, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE0, 0xC4,
+0x54, 0xF0, 0x24, 0x05, 0xF5, 0x82, 0xE4, 0x34,
+0x81, 0xF5, 0x83, 0xE0, 0x22, 0x12, 0xBB, 0x52,
+0xE4, 0xFD, 0xFF, 0x90, 0x05, 0x22, 0xEF, 0xF0,
+0x90, 0x94, 0x63, 0xED, 0xF0, 0x22, 0x90, 0x92,
+0xA3, 0x12, 0x86, 0x75, 0x90, 0x92, 0xA6, 0xED,
+0xF0, 0x90, 0x84, 0xBF, 0xA3, 0xE0, 0x24, 0x63,
+0xF9, 0xE4, 0x34, 0x82, 0x51, 0xC6, 0x75, 0x1E,
+0x06, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0xD3, 0x12,
+0x6A, 0x21, 0x90, 0x84, 0xBF, 0xA3, 0xE0, 0x24,
+0x69, 0xF9, 0xE4, 0x34, 0x82, 0x51, 0xC6, 0x75,
+0x1E, 0x10, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0xD9,
+0x12, 0x6A, 0x21, 0x12, 0xDE, 0xF9, 0x34, 0x82,
+0x51, 0xC6, 0x75, 0x1E, 0x06, 0x7B, 0x01, 0x7A,
+0x92, 0x79, 0xE9, 0x12, 0xD7, 0x6A, 0xE0, 0x90,
+0x92, 0xEF, 0xF0, 0x90, 0x05, 0x22, 0xE0, 0x90,
+0x92, 0xAA, 0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60,
+0x09, 0x7D, 0x39, 0x71, 0xDE, 0xBF, 0x01, 0x10,
+0x80, 0x00, 0x90, 0x88, 0xD0, 0x12, 0xDE, 0xF0,
+0x90, 0x92, 0xA7, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
+0x90, 0x92, 0xA7, 0x12, 0xDD, 0xFE, 0x90, 0x92,
+0xA9, 0xEF, 0xF0, 0x90, 0x92, 0xA7, 0x12, 0xC7,
+0xAB, 0x7B, 0x01, 0x90, 0x92, 0xEF, 0xE0, 0xFD,
+0x12, 0x52, 0x21, 0x90, 0x92, 0xA6, 0xE0, 0x70,
+0x71, 0xF1, 0xA4, 0xC0, 0x03, 0x8B, 0x1B, 0x75,
+0x1C, 0x92, 0x75, 0x1D, 0xD3, 0x75, 0x1E, 0x06,
+0xD0, 0x03, 0x51, 0xB5, 0xE0, 0xF1, 0xC1, 0xC0,
+0x03, 0xC0, 0x02, 0xC0, 0x01, 0x90, 0x92, 0xA3,
+0x12, 0xD9, 0x16, 0x75, 0x1E, 0x10, 0xD0, 0x01,
+0xD0, 0x02, 0xD0, 0x03, 0x51, 0xB5, 0xE0, 0x2F,
+0xF1, 0xA7, 0xC0, 0x03, 0x12, 0xDF, 0x24, 0x75,
+0x1E, 0x10, 0xD0, 0x03, 0x51, 0xB5, 0xE0, 0x2F,
+0x24, 0x60, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B,
+0x01, 0xC0, 0x03, 0x12, 0xDF, 0x24, 0x75, 0x1E,
+0x10, 0xD0, 0x03, 0x51, 0xB5, 0xE0, 0x2F, 0x24,
+0x72, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01,
+0xC0, 0x03, 0x8B, 0x1B, 0x75, 0x1C, 0x92, 0x75,
+0x1D, 0xE9, 0x75, 0x1E, 0x06, 0xD0, 0x03, 0x12,
+0x6A, 0x21, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0xD9,
+0x90, 0x8C, 0x20, 0x12, 0x86, 0x75, 0x90, 0x8C,
+0x23, 0x12, 0x04, 0xF7, 0x00, 0x00, 0x00, 0x20,
+0x90, 0x8C, 0x27, 0x74, 0x3A, 0xF0, 0x90, 0x92,
+0xA3, 0x12, 0x86, 0x6C, 0x12, 0x70, 0x23, 0x51,
+0xB8, 0xF1, 0xB8, 0x51, 0xC6, 0x75, 0x1E, 0x28,
+0x7B, 0x01, 0x7A, 0x92, 0x79, 0xAB, 0x51, 0xB5,
+0xF1, 0xB8, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0x8B,
+0x1B, 0x75, 0x1C, 0x87, 0x75, 0x1D, 0x1A, 0x75,
+0x1E, 0x28, 0xD0, 0x03, 0x12, 0x6A, 0x21, 0x90,
+0x92, 0xA9, 0xE0, 0xFF, 0x90, 0x92, 0xA8, 0xE0,
+0x2F, 0xFF, 0x90, 0x92, 0xA7, 0xE0, 0x34, 0x00,
+0xCF, 0x24, 0x30, 0xFD, 0xE4, 0x3F, 0xFC, 0x90,
+0x88, 0xD0, 0xE0, 0xFB, 0x7F, 0x3A, 0x12, 0x15,
+0x44, 0x51, 0xB8, 0xF1, 0xB8, 0xFA, 0x7B, 0x01,
+0xC0, 0x03, 0x8B, 0x1B, 0x75, 0x1C, 0x92, 0x75,
+0x1D, 0xAB, 0x75, 0x1E, 0x28, 0xD0, 0x03, 0x12,
+0x6A, 0x21, 0x90, 0x88, 0xCC, 0xE0, 0xB4, 0x02,
+0x0D, 0x90, 0x88, 0xD0, 0xE0, 0xFF, 0x90, 0x92,
+0xA9, 0xE0, 0xFD, 0x12, 0xD0, 0x6C, 0x90, 0x06,
+0x33, 0xE0, 0x44, 0x02, 0xF0, 0x90, 0x92, 0xAA,
+0xE0, 0xFF, 0x7D, 0x3A, 0x11, 0xEB, 0x90, 0x04,
+0x1F, 0x74, 0x20, 0xF0, 0x22, 0x12, 0x6A, 0x21,
+0x90, 0x92, 0xA7, 0xA3, 0xE0, 0xFF, 0xA3, 0x22,
+0x24, 0x00, 0xF9, 0xE4, 0x34, 0xFC, 0x75, 0x1B,
+0x01, 0xF5, 0x1C, 0x89, 0x1D, 0x22, 0x90, 0x92,
+0x94, 0x12, 0x86, 0x75, 0x90, 0x92, 0x97, 0xED,
+0xF0, 0x12, 0xDE, 0xF9, 0x34, 0x82, 0x51, 0xC6,
+0x75, 0x1E, 0x06, 0x7B, 0x01, 0x7A, 0x92, 0x79,
+0x9D, 0x12, 0xD7, 0x6A, 0xE0, 0x90, 0x92, 0x9C,
+0xF0, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x92, 0x9B,
+0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x09, 0x7D,
+0x33, 0x71, 0xDE, 0xBF, 0x01, 0x10, 0x80, 0x00,
+0x90, 0x88, 0xCF, 0x12, 0xDE, 0xF0, 0x90, 0x92,
+0x98, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x92,
+0x98, 0x12, 0xDD, 0xFE, 0x90, 0x92, 0x9A, 0xEF,
+0xF0, 0x90, 0x92, 0x98, 0x12, 0xC7, 0xAB, 0x7B,
+0x01, 0x90, 0x92, 0x9C, 0xE0, 0xFD, 0x12, 0x52,
+0x21, 0x90, 0x92, 0x97, 0xE0, 0x70, 0x34, 0xF1,
+0xA4, 0xC0, 0x03, 0x12, 0xDF, 0x51, 0x75, 0x1E,
+0x06, 0xD0, 0x03, 0x71, 0xD2, 0x12, 0xDE, 0xB2,
+0xC0, 0x03, 0x12, 0xDF, 0x51, 0x75, 0x1E, 0x06,
+0xD0, 0x03, 0x71, 0xD2, 0xF1, 0xC1, 0xC0, 0x03,
+0xC0, 0x02, 0xC0, 0x01, 0x90, 0x92, 0x94, 0x12,
+0xD9, 0x16, 0x75, 0x1E, 0x04, 0xD0, 0x01, 0xD0,
+0x02, 0x80, 0x3E, 0x90, 0x92, 0x97, 0xE0, 0x64,
+0x01, 0x70, 0x3B, 0xF1, 0xA4, 0xC0, 0x03, 0x8B,
+0x1B, 0x75, 0x1C, 0x86, 0x75, 0x1D, 0x96, 0x75,
+0x1E, 0x06, 0xD0, 0x03, 0x71, 0xD2, 0x12, 0xDE,
+0xB2, 0xC0, 0x03, 0x8B, 0x1B, 0x75, 0x1C, 0x86,
+0x75, 0x1D, 0xA0, 0x75, 0x1E, 0x06, 0xD0, 0x03,
+0x71, 0xD2, 0xF1, 0xC1, 0xC0, 0x03, 0x8B, 0x1B,
+0x75, 0x1C, 0x86, 0x75, 0x1D, 0xA6, 0x75, 0x1E,
+0x04, 0xD0, 0x03, 0x12, 0x6A, 0x21, 0x90, 0x88,
+0xCC, 0xE0, 0xB4, 0x02, 0x0D, 0x90, 0x88, 0xCF,
+0xE0, 0xFF, 0x90, 0x92, 0x9A, 0xE0, 0xFD, 0x12,
+0xD0, 0x6C, 0x90, 0x06, 0x30, 0xE0, 0x44, 0x10,
+0xF0, 0x90, 0x92, 0x9B, 0xE0, 0xFF, 0x7D, 0x34,
+0x41, 0xAC, 0x12, 0x6A, 0x21, 0x90, 0x92, 0x98,
+0xA3, 0xE0, 0xFF, 0xA3, 0xE0, 0x22, 0x7F, 0xFF,
+0x11, 0xEB, 0xE4, 0x90, 0x96, 0x85, 0xF0, 0xA3,
+0xF0, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x96, 0x87,
+0xF0, 0x7D, 0x47, 0x7F, 0xFF, 0x11, 0xEB, 0x90,
+0x05, 0xF8, 0xE0, 0x70, 0x11, 0xA3, 0xE0, 0x70,
+0x0D, 0xA3, 0xE0, 0x70, 0x09, 0xA3, 0xE0, 0x70,
+0x05, 0xF1, 0x9B, 0x7F, 0x01, 0x22, 0xD3, 0x90,
+0x96, 0x86, 0xE0, 0x94, 0xE8, 0x90, 0x96, 0x85,
+0xE0, 0x94, 0x03, 0x40, 0x0C, 0x90, 0x01, 0xC0,
+0xE0, 0x44, 0x20, 0xF0, 0xF1, 0x9B, 0x7F, 0x00,
+0x22, 0x7F, 0x32, 0x7E, 0x00, 0x12, 0x7C, 0x9F,
+0x90, 0x96, 0x85, 0xF1, 0xF4, 0x80, 0xC0, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x93,
+0xB3, 0x12, 0xC7, 0xC3, 0x90, 0x93, 0xCB, 0x74,
+0x18, 0xF0, 0x7E, 0x00, 0x7F, 0x80, 0x7D, 0x00,
+0x7B, 0x01, 0x7A, 0x93, 0x79, 0xD3, 0x12, 0x06,
+0xDE, 0x90, 0x01, 0xC4, 0x74, 0x20, 0xF0, 0x74,
+0x07, 0xA3, 0xF0, 0x90, 0x88, 0xD1, 0xE0, 0xFF,
+0x12, 0x7B, 0x2A, 0x90, 0x93, 0xCA, 0xEF, 0xF0,
+0xF9, 0xE0, 0xFE, 0x24, 0x29, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0x74, 0x41, 0xF0, 0xEE,
+0x24, 0x28, 0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x93,
+0xCB, 0xE0, 0x7A, 0x00, 0x2D, 0xFE, 0xEA, 0x3C,
+0x90, 0x93, 0xCF, 0xF0, 0xA3, 0xCE, 0xF0, 0x74,
+0x28, 0x29, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B,
+0x01, 0x90, 0x93, 0xB5, 0xE0, 0xFD, 0x12, 0x52,
+0x21, 0xF1, 0xCC, 0x90, 0x93, 0xCF, 0xE0, 0xFF,
+0xA3, 0xE0, 0x90, 0x93, 0xCD, 0xCF, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x93, 0xD3, 0x74, 0x01, 0xF0,
+0xA3, 0x74, 0x03, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3,
+0x74, 0x5F, 0xF0, 0x90, 0x93, 0xCF, 0xE4, 0x75,
+0xF0, 0x04, 0x12, 0x07, 0x0A, 0x90, 0x87, 0x90,
+0xE0, 0xFF, 0x7E, 0x02, 0xB4, 0xFE, 0x02, 0x7E,
+0xFE, 0x90, 0x93, 0xCF, 0xA3, 0xE0, 0xFD, 0xF1,
+0x49, 0xEE, 0xF0, 0x74, 0x00, 0x2D, 0xF1, 0x4B,
+0xE0, 0x90, 0x93, 0xD7, 0xF0, 0x90, 0x93, 0xCF,
+0xF1, 0xF4, 0x90, 0x88, 0x25, 0xE0, 0x90, 0x93,
+0xB3, 0xB4, 0x01, 0x0B, 0xE0, 0x44, 0x03, 0xFC,
+0xA3, 0xE0, 0x44, 0x10, 0xFD, 0x80, 0x09, 0xE0,
+0x44, 0x03, 0xFC, 0xA3, 0xE0, 0x44, 0x20, 0xFD,
+0x90, 0x93, 0xD1, 0xEC, 0xF0, 0xA3, 0xED, 0xF0,
+0x90, 0x93, 0xB3, 0xE0, 0x70, 0x04, 0xA3, 0xE0,
+0x64, 0x01, 0x90, 0x93, 0xCF, 0x70, 0x1B, 0xA3,
+0xE0, 0xFE, 0xF1, 0x49, 0x12, 0xDE, 0xD2, 0x34,
+0xFC, 0xF5, 0x83, 0x74, 0x01, 0xF0, 0x90, 0x93,
+0xD8, 0x74, 0x03, 0xF0, 0xA3, 0x74, 0x01, 0xF0,
+0x80, 0x17, 0xA3, 0xE0, 0xFE, 0xF1, 0x49, 0x12,
+0xDE, 0xD2, 0x34, 0xFC, 0xF5, 0x83, 0x74, 0x02,
+0xF0, 0x90, 0x93, 0xD8, 0x04, 0xF0, 0xA3, 0x14,
+0xF0, 0x12, 0xDE, 0xBD, 0xEF, 0x64, 0xFE, 0x90,
+0x93, 0xCF, 0x70, 0x21, 0xA3, 0xE0, 0x24, 0x00,
+0x12, 0xD4, 0xD7, 0xC0, 0x03, 0x8B, 0x1B, 0x12,
+0xDE, 0xDC, 0xD0, 0x03, 0x12, 0xB7, 0xC4, 0x12,
+0xDE, 0xDC, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xDA,
+0x12, 0x6A, 0x21, 0x80, 0x22, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x24, 0x00, 0xF5, 0x82, 0x74, 0xFC,
+0x3E, 0xF5, 0x83, 0xE4, 0xF0, 0x74, 0x01, 0x2F,
+0xF5, 0x82, 0x74, 0xFC, 0x3E, 0xF5, 0x83, 0xE4,
+0xF0, 0x90, 0x93, 0xDA, 0xF0, 0xA3, 0xF0, 0x12,
+0xDE, 0xBD, 0xE4, 0x90, 0x93, 0xCC, 0xF0, 0x12,
+0xDE, 0x85, 0xFE, 0x90, 0x93, 0xCF, 0xA3, 0xE0,
+0xFD, 0xEF, 0x2D, 0xF1, 0x49, 0xEE, 0xF0, 0x12,
+0xDE, 0x85, 0xFE, 0x74, 0xDC, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEE, 0xF1, 0xB1,
+0xF0, 0xE0, 0xB4, 0x08, 0xDA, 0xF1, 0xD6, 0x90,
+0x93, 0xCF, 0xE4, 0x75, 0xF0, 0x20, 0x12, 0x07,
+0x0A, 0x90, 0x93, 0xCF, 0xE4, 0x75, 0xF0, 0x10,
+0x12, 0x07, 0x0A, 0xF1, 0xCC, 0xE4, 0x90, 0x94,
+0x56, 0xF0, 0xE4, 0x90, 0x93, 0xCC, 0xF0, 0x12,
+0xDF, 0x1B, 0x50, 0x0B, 0x12, 0xDE, 0x4F, 0xF1,
+0x46, 0xE4, 0xF1, 0xB1, 0xF0, 0x80, 0xF0, 0x12,
+0xD0, 0x65, 0x90, 0x06, 0x31, 0xE0, 0x54, 0xFB,
+0xF0, 0x90, 0x88, 0xD2, 0x12, 0xD1, 0xC5, 0xCE,
+0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0x12, 0xD1,
+0xBB, 0xED, 0xFF, 0x90, 0x88, 0xD1, 0x12, 0xD1,
+0xD0, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
+0xFF, 0x90, 0x93, 0xCB, 0xE0, 0x7C, 0x00, 0x2F,
+0xFF, 0xEC, 0x3E, 0xCF, 0x24, 0x38, 0xCF, 0x34,
+0x00, 0xFE, 0x90, 0x8A, 0xEC, 0x74, 0x10, 0xF0,
+0x7B, 0x63, 0xE4, 0xFD, 0x12, 0x72, 0x06, 0x90,
+0x93, 0xB3, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64,
+0x01, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xD3, 0x70,
+0x17, 0x90, 0x8B, 0x1C, 0x12, 0xDF, 0x6A, 0x90,
+0x8B, 0x1F, 0x12, 0x86, 0x75, 0x90, 0x8B, 0x22,
+0x12, 0xDF, 0x62, 0x12, 0x6E, 0xE1, 0x80, 0x15,
+0x90, 0x8B, 0x12, 0x12, 0xDF, 0x6A, 0x90, 0x8B,
+0x15, 0x12, 0x86, 0x75, 0x90, 0x8B, 0x18, 0x12,
+0xDF, 0x62, 0x12, 0x6E, 0xA0, 0x90, 0x94, 0x56,
+0xE0, 0x04, 0xF0, 0x90, 0x06, 0x31, 0xE0, 0x30,
+0xE2, 0x07, 0x12, 0xDF, 0x5A, 0x50, 0x02, 0xA1,
+0xFA, 0x12, 0xDF, 0x5A, 0x40, 0x0A, 0x90, 0x06,
+0x35, 0xE0, 0x44, 0x20, 0x90, 0x06, 0x34, 0xF0,
+0xE4, 0x90, 0x93, 0xCC, 0xF0, 0x12, 0xDF, 0x1B,
+0x50, 0x1F, 0x12, 0xDE, 0x4F, 0xEF, 0xF0, 0x90,
+0x93, 0xCC, 0xE0, 0x24, 0xB6, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x93,
+0xCA, 0xF1, 0x48, 0xEF, 0xF1, 0xB1, 0xF0, 0x80,
+0xDC, 0x90, 0x93, 0xB3, 0xE0, 0x70, 0x04, 0xA3,
+0xE0, 0x64, 0x01, 0x70, 0x0F, 0x90, 0x88, 0xD1,
+0xE0, 0xFF, 0x90, 0x93, 0xCB, 0xE0, 0x24, 0x08,
+0xFD, 0x12, 0xD0, 0x6C, 0x90, 0x04, 0x1D, 0xE0,
+0x60, 0x1D, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x94,
+0x55, 0xF0, 0x7D, 0x1D, 0x71, 0xDE, 0xBF, 0x01,
+0x03, 0x12, 0xC4, 0xCF, 0x90, 0x94, 0x55, 0xE0,
+0xFF, 0x7D, 0x1E, 0x11, 0xEB, 0x80, 0x03, 0x12,
+0xC4, 0xCF, 0x90, 0x85, 0xC8, 0xE0, 0x70, 0x05,
+0x7F, 0x01, 0x12, 0x79, 0x80, 0x7F, 0x28, 0x7E,
+0x00, 0x12, 0x7C, 0x9F, 0x51, 0xAE, 0x74, 0x20,
+0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0x07, 0xA3,
+0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF, 0xF0,
+0xE0, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x96, 0x73, 0xEF, 0xF0, 0xA3,
+0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x04, 0x1D,
+0xE0, 0x60, 0x1D, 0x90, 0x05, 0x22, 0xE0, 0x90,
+0x96, 0x78, 0xF0, 0x7D, 0x36, 0x71, 0xDE, 0xBF,
+0x01, 0x03, 0x12, 0xC4, 0xEE, 0x90, 0x96, 0x78,
+0xE0, 0xFF, 0x7D, 0x37, 0x11, 0xEB, 0x80, 0x03,
+0x12, 0xC4, 0xEE, 0x90, 0x05, 0x22, 0xE0, 0x54,
+0x6F, 0xFF, 0x7D, 0x38, 0x51, 0xAC, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x96, 0x87, 0xE0, 0xFF,
+0x7D, 0x48, 0x01, 0xEB, 0xA3, 0xA3, 0xE0, 0x24,
+0x38, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01,
+0x22, 0xF0, 0x90, 0x93, 0xCC, 0xE0, 0x04, 0x22,
+0xE0, 0x2F, 0x24, 0x30, 0xF9, 0xE4, 0x34, 0xFC,
+0x22, 0x2F, 0x24, 0x48, 0xF9, 0xE4, 0x34, 0xFC,
+0xFA, 0x7B, 0x01, 0x22, 0x90, 0x93, 0xCF, 0xE4,
+0x75, 0xF0, 0x08, 0x12, 0x07, 0x0A, 0x90, 0x93,
+0xCF, 0xE4, 0x75, 0xF0, 0x08, 0x02, 0x07, 0x0A,
+0xE4, 0xFD, 0x01, 0xA1, 0x7D, 0x20, 0x7F, 0xFF,
+0x11, 0xEB, 0x12, 0xB7, 0x7A, 0x90, 0x85, 0xBF,
+0x74, 0x02, 0xF0, 0x22, 0xE4, 0x75, 0xF0, 0x01,
+0x02, 0x07, 0x0A, 0x12, 0x87, 0xB0, 0x90, 0x04,
+0x24, 0xE0, 0xF5, 0x0D, 0xE4, 0xFF, 0x90, 0x92,
+0x05, 0x12, 0x86, 0x6C, 0x8F, 0x82, 0x75, 0x83,
+0x00, 0x12, 0x03, 0x0F, 0x25, 0x0D, 0xFE, 0xEF,
+0x75, 0xF0, 0x0E, 0xA4, 0x24, 0x7B, 0xF5, 0x82,
+0xE4, 0x34, 0x94, 0xF5, 0x83, 0xEE, 0xF0, 0x0F,
+0xEF, 0xB4, 0x03, 0xDA, 0x22, 0x90, 0x92, 0x02,
+0x12, 0x86, 0x75, 0x90, 0x92, 0x01, 0xEF, 0xF0,
+0x12, 0x86, 0x7E, 0x98, 0x87, 0x00, 0x98, 0x90,
+0x01, 0x98, 0x99, 0x03, 0x98, 0xA2, 0x04, 0x98,
+0xAB, 0x06, 0x98, 0xC0, 0x10, 0x98, 0xC9, 0x11,
+0x98, 0xD2, 0x12, 0x98, 0xDA, 0x14, 0x98, 0xE3,
+0x1C, 0x98, 0xEC, 0x20, 0x98, 0xF5, 0x24, 0x98,
+0xFE, 0x25, 0x99, 0x07, 0x27, 0x99, 0x18, 0x80,
+0x99, 0x10, 0x81, 0x99, 0x20, 0x82, 0x99, 0x29,
+0x83, 0x99, 0x32, 0x84, 0x99, 0x3B, 0x88, 0x99,
+0x44, 0xC3, 0x98, 0xB4, 0xC6, 0x98, 0xB4, 0xC7,
+0x98, 0xB4, 0xC8, 0x00, 0x00, 0x99, 0x4D, 0x90,
+0x92, 0x02, 0x12, 0x86, 0x6C, 0x02, 0x87, 0xF7,
+0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x02, 0x90,
+0x09, 0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x02,
+0x78, 0x94, 0x90, 0x92, 0x02, 0x12, 0x86, 0x6C,
+0x02, 0x6B, 0x03, 0x90, 0x92, 0x02, 0x12, 0x86,
+0x6C, 0x02, 0xA0, 0xC6, 0x90, 0x92, 0x01, 0xE0,
+0xFF, 0xA3, 0x12, 0x86, 0x6C, 0x02, 0xA1, 0x5D,
+0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x02, 0x97,
+0xFB, 0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x02,
+0x8A, 0x2C, 0x90, 0x92, 0x02, 0x12, 0x86, 0x6C,
+0xE1, 0xFC, 0x90, 0x92, 0x02, 0x12, 0x86, 0x6C,
+0x02, 0xA8, 0x1A, 0x90, 0x92, 0x02, 0x12, 0x86,
+0x6C, 0x02, 0x86, 0xCE, 0x90, 0x92, 0x02, 0x12,
+0x86, 0x6C, 0x02, 0x8B, 0xD9, 0x90, 0x92, 0x02,
+0x12, 0x86, 0x6C, 0x02, 0xA8, 0x29, 0x90, 0x92,
+0x02, 0x12, 0x86, 0x6C, 0x02, 0xAF, 0xEA, 0x90,
+0x92, 0x02, 0x12, 0x86, 0x6C, 0x02, 0xAF, 0xF2,
+0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x80, 0x45,
+0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x41, 0x3F,
+0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x02, 0x7A,
+0xFE, 0x90, 0x92, 0x02, 0x12, 0x86, 0x6C, 0x02,
+0x6F, 0x63, 0x90, 0x92, 0x02, 0x12, 0x86, 0x6C,
+0x02, 0x6F, 0xA4, 0x90, 0x92, 0x02, 0x12, 0x86,
+0x6C, 0x02, 0x87, 0xB5, 0x90, 0x92, 0x02, 0x12,
+0x86, 0x6C, 0x02, 0xB0, 0x35, 0x90, 0x01, 0xC0,
+0xE0, 0x44, 0x01, 0xF0, 0x90, 0x92, 0x01, 0xE0,
+0x90, 0x01, 0xC2, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x87, 0xB0, 0x12,
+0xB0, 0x27, 0x90, 0x86, 0x72, 0x51, 0x2A, 0xF1,
+0xCE, 0x90, 0x86, 0x72, 0x71, 0x30, 0x51, 0x38,
+0xF1, 0xB6, 0xFF, 0x90, 0x86, 0x72, 0x12, 0xDE,
+0xE6, 0x51, 0x38, 0xF1, 0xBE, 0xFF, 0x90, 0x86,
+0x72, 0xF1, 0xF2, 0x12, 0x87, 0xE1, 0x54, 0x01,
+0xFF, 0x90, 0x86, 0x74, 0xE0, 0x54, 0xFE, 0x4F,
+0xF0, 0x12, 0x87, 0x20, 0xFF, 0x54, 0x01, 0xFE,
+0x90, 0x86, 0x73, 0xF1, 0xAF, 0xEF, 0x54, 0x04,
+0xFF, 0xEE, 0x54, 0xFB, 0x4F, 0xFF, 0xF0, 0x12,
+0x87, 0x20, 0x71, 0x32, 0x90, 0x86, 0x73, 0xF0,
+0x90, 0x92, 0x05, 0x12, 0x87, 0x1E, 0x54, 0x40,
+0x90, 0x94, 0xE7, 0x12, 0x88, 0x36, 0x54, 0x03,
+0x90, 0x94, 0xE8, 0xF0, 0x90, 0x86, 0x72, 0xE0,
+0xC3, 0x13, 0x54, 0x01, 0xFF, 0x12, 0x7C, 0x72,
+0x71, 0x3A, 0x54, 0x01, 0xFF, 0x12, 0x7C, 0x7E,
+0x12, 0xD9, 0xDB, 0x30, 0xE0, 0x1F, 0x90, 0x86,
+0x72, 0x12, 0xAC, 0x65, 0x20, 0xE0, 0x0E, 0xEF,
+0xC3, 0x13, 0x20, 0xE0, 0x08, 0xE0, 0x13, 0x13,
+0x54, 0x3F, 0x30, 0xE0, 0x04, 0x7F, 0x01, 0x80,
+0x0A, 0x7F, 0x00, 0x80, 0x06, 0x71, 0x3A, 0x13,
+0x54, 0x01, 0xFF, 0x12, 0x66, 0xDA, 0x90, 0x86,
+0x72, 0xE0, 0xC4, 0x13, 0x13, 0x54, 0x01, 0xFF,
+0x12, 0xD4, 0xDF, 0x90, 0x86, 0x72, 0xE0, 0x54,
+0x01, 0xFF, 0x12, 0xB6, 0xF9, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xE0, 0x54, 0xFE, 0x4E, 0xFE, 0xF0,
+0xEF, 0x54, 0x02, 0xFF, 0xEE, 0x54, 0xFD, 0x4F,
+0xFF, 0xF0, 0x12, 0x02, 0xF6, 0xFE, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x87,
+0xB0, 0x12, 0x02, 0xF6, 0x20, 0xE0, 0x05, 0x12,
+0xD4, 0xAD, 0x61, 0x2B, 0x12, 0xB0, 0x27, 0x90,
+0x86, 0x75, 0x51, 0x2A, 0xF1, 0xCE, 0x90, 0x86,
+0x75, 0x71, 0x30, 0x51, 0x38, 0xF1, 0xB6, 0xFF,
+0x90, 0x86, 0x75, 0x12, 0xDE, 0xE6, 0x51, 0x38,
+0xF1, 0xBE, 0xFF, 0x90, 0x86, 0x75, 0xF1, 0xF2,
+0xF0, 0x12, 0x87, 0x20, 0x54, 0x80, 0xFF, 0x90,
+0x86, 0x76, 0xE0, 0x54, 0x7F, 0x4F, 0xF0, 0x12,
+0xDF, 0x72, 0x30, 0xE0, 0x07, 0x90, 0x06, 0x90,
+0xE0, 0x44, 0x04, 0xF0, 0x90, 0x92, 0x05, 0x12,
+0x86, 0x6C, 0x12, 0x02, 0xF6, 0x13, 0x13, 0x13,
+0x54, 0x1F, 0x30, 0xE0, 0x07, 0x90, 0x06, 0x90,
+0xE0, 0x44, 0x08, 0xF0, 0x90, 0x84, 0xC5, 0xE0,
+0xB4, 0x02, 0x0A, 0x90, 0x86, 0x76, 0xE0, 0x12,
+0x8F, 0xF3, 0x20, 0xE0, 0x41, 0x12, 0x87, 0x20,
+0x54, 0x7F, 0xFF, 0x90, 0x86, 0x76, 0xE0, 0x54,
+0x80, 0x12, 0x87, 0xE0, 0x90, 0x86, 0x77, 0x12,
+0x88, 0x36, 0xFF, 0x54, 0x01, 0xFE, 0x90, 0x86,
+0x78, 0xF1, 0xAF, 0xEF, 0x54, 0xFE, 0xFF, 0xEE,
+0x54, 0x01, 0x4F, 0xF0, 0x90, 0x86, 0x76, 0xE0,
+0x54, 0x7F, 0xFF, 0x90, 0x86, 0x75, 0xE0, 0xFE,
+0xC4, 0x13, 0x54, 0x07, 0x7D, 0x00, 0x20, 0xE0,
+0x02, 0x7D, 0x01, 0x12, 0x54, 0x9F, 0x90, 0x84,
+0xC5, 0xE0, 0xB4, 0x01, 0x07, 0x90, 0xFE, 0x10,
+0xE0, 0x44, 0x04, 0xF0, 0x7E, 0x00, 0x7F, 0x60,
+0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x69,
+0x12, 0x06, 0xDE, 0x90, 0x95, 0x99, 0x74, 0x05,
+0xF0, 0x12, 0x8F, 0x96, 0x7A, 0x87, 0x79, 0x95,
+0x12, 0x06, 0xDE, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0xF0, 0xEE, 0x54, 0x08, 0xFE, 0xEF, 0x54, 0xF7,
+0x4E, 0x22, 0x90, 0x86, 0x72, 0xE0, 0x13, 0x13,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0xE4, 0x90, 0x96, 0x03, 0xF0, 0xA3, 0x74, 0x08,
+0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x96,
+0x09, 0xF0, 0xA3, 0xF0, 0x90, 0x96, 0x13, 0xF0,
+0xA3, 0xF0, 0x90, 0x01, 0xC4, 0x74, 0x41, 0xF0,
+0x74, 0x9B, 0xA3, 0xF0, 0x90, 0x01, 0x1F, 0xE0,
+0xFE, 0x90, 0x01, 0x1E, 0xD1, 0xEC, 0xEC, 0x3E,
+0xF1, 0xC6, 0x90, 0x02, 0x87, 0xE0, 0x90, 0x96,
+0x01, 0xF0, 0x90, 0x86, 0x72, 0xE0, 0x20, 0xE0,
+0x02, 0xC1, 0xA8, 0xE4, 0x90, 0x96, 0x00, 0xF0,
+0x90, 0x96, 0x01, 0xE0, 0xFF, 0x90, 0x96, 0x00,
+0xE0, 0xC3, 0x9F, 0x40, 0x02, 0xC1, 0xA8, 0xF1,
+0xE0, 0xEC, 0xFF, 0x90, 0xFD, 0x11, 0xF0, 0x90,
+0x96, 0x09, 0xEF, 0xF0, 0x74, 0x01, 0x2D, 0xF5,
+0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0xFE,
+0x74, 0x00, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB,
+0xF5, 0x83, 0x12, 0xD2, 0xAC, 0x54, 0x3F, 0xFE,
+0x90, 0x95, 0xFB, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
+0x96, 0x05, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x74,
+0x02, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5,
+0x83, 0xE0, 0x54, 0x0F, 0x33, 0x33, 0x33, 0x54,
+0xF8, 0xFF, 0x74, 0x03, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x54, 0x03, 0xFE,
+0xEF, 0x24, 0x18, 0x2E, 0xFF, 0x90, 0x96, 0x0A,
+0xF0, 0x90, 0x95, 0xFA, 0xE0, 0x2F, 0xFF, 0x90,
+0x95, 0xF9, 0xE0, 0x34, 0x00, 0xFE, 0x90, 0x95,
+0xFD, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0xFD, 0x12,
+0x55, 0x36, 0xC0, 0x07, 0xD1, 0xB9, 0x7D, 0x01,
+0x12, 0x55, 0x36, 0xC0, 0x07, 0xD1, 0xB9, 0x7D,
+0x04, 0x12, 0x55, 0x36, 0xAB, 0x07, 0xD0, 0x05,
+0xD0, 0x07, 0x12, 0x5D, 0x98, 0x90, 0x96, 0x02,
+0xEF, 0xD1, 0xB8, 0xD1, 0xE5, 0x54, 0xFC, 0x90,
+0x95, 0xFF, 0xF0, 0x90, 0x96, 0x0A, 0xE0, 0xFF,
+0x90, 0x95, 0xFB, 0xE4, 0x8F, 0xF0, 0x12, 0x07,
+0x0A, 0xF1, 0xE9, 0x12, 0x7A, 0xD0, 0x90, 0x95,
+0xFB, 0xEE, 0xF0, 0xA3, 0xEF, 0xD1, 0xD3, 0x7D,
+0x0F, 0x12, 0x55, 0x36, 0xAD, 0x07, 0xEF, 0x30,
+0xE6, 0x08, 0xD1, 0xC2, 0x90, 0x01, 0xC7, 0x74,
+0x22, 0xF0, 0xED, 0x30, 0xE7, 0x08, 0xD1, 0xC2,
+0x90, 0x01, 0xC7, 0x74, 0x21, 0xF0, 0xED, 0x30,
+0xE5, 0x13, 0xD1, 0xC2, 0x90, 0x01, 0xC7, 0x74,
+0x23, 0xD1, 0xD3, 0x7D, 0x10, 0x12, 0x55, 0x36,
+0x90, 0x95, 0x9B, 0xEF, 0xF0, 0xF1, 0xE9, 0x90,
+0x95, 0xF9, 0xEE, 0x8F, 0xF0, 0x12, 0x07, 0x0A,
+0x90, 0x85, 0xB7, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0xF1, 0xE0, 0xD3, 0x9F, 0xEC, 0x9E, 0x40, 0x16,
+0x90, 0x85, 0xB8, 0xE0, 0x24, 0x01, 0xFF, 0x90,
+0x85, 0xB7, 0xE0, 0x34, 0x00, 0xFE, 0xC3, 0xED,
+0x9F, 0xFF, 0xEC, 0x9E, 0xF1, 0xC6, 0x90, 0x95,
+0xFF, 0xE0, 0x24, 0xF8, 0x60, 0x3A, 0x24, 0x80,
+0x60, 0x36, 0x24, 0xC8, 0x60, 0x06, 0x24, 0x20,
+0x60, 0x02, 0xC1, 0x1B, 0x90, 0x86, 0x75, 0xE0,
+0xFF, 0x12, 0x8F, 0xF3, 0x20, 0xE0, 0x02, 0xC1,
+0x1B, 0x90, 0x86, 0x87, 0xE0, 0x04, 0xD1, 0xB8,
+0x12, 0x59, 0x20, 0xEF, 0x70, 0x02, 0xC1, 0x1B,
+0x90, 0x95, 0xFF, 0xE0, 0xFF, 0x12, 0x7B, 0x77,
+0x90, 0x86, 0x88, 0xE0, 0x04, 0xF0, 0xC1, 0x1B,
+0x12, 0xDE, 0x95, 0xFF, 0x12, 0x58, 0x98, 0xAC,
+0x07, 0xD1, 0xB9, 0x90, 0x96, 0x02, 0xE0, 0xFD,
+0xAB, 0x04, 0xC0, 0x03, 0x7B, 0x01, 0x7A, 0x96,
+0x79, 0x0B, 0x90, 0x92, 0x52, 0x12, 0x86, 0x75,
+0xD0, 0x03, 0x12, 0xA2, 0x98, 0xD1, 0xB9, 0x12,
+0x59, 0x20, 0x90, 0x96, 0x14, 0xEF, 0xF0, 0x7B,
+0x01, 0x7A, 0x96, 0x79, 0x0B, 0x12, 0xDE, 0x95,
+0xFD, 0x90, 0x92, 0x52, 0xEF, 0xF0, 0x12, 0xD7,
+0x7C, 0xEF, 0x70, 0x02, 0xC1, 0x1B, 0x12, 0xAF,
+0xE0, 0x30, 0xE0, 0x5F, 0x90, 0x96, 0x02, 0xE0,
+0xFF, 0x90, 0x95, 0xFE, 0xE0, 0x2F, 0xFF, 0x90,
+0x95, 0xFD, 0xE0, 0x34, 0x00, 0xCF, 0x24, 0x08,
+0xCF, 0x34, 0x00, 0xFE, 0x90, 0x96, 0x07, 0xF0,
+0xA3, 0xEF, 0xF0, 0xD1, 0xE5, 0x64, 0x45, 0x70,
+0x3A, 0xD1, 0xCA, 0x12, 0xDA, 0xC3, 0xEF, 0x64,
+0x01, 0x70, 0x30, 0xD1, 0xCA, 0x12, 0xDA, 0x90,
+0xEF, 0x64, 0x01, 0x70, 0x26, 0x90, 0x96, 0x13,
+0x04, 0xF0, 0xD1, 0xCA, 0xA3, 0xE0, 0xFD, 0x12,
+0xDA, 0x2C, 0xEF, 0x70, 0x0E, 0x90, 0x96, 0x09,
+0xE0, 0xFD, 0x90, 0xFD, 0x11, 0xF0, 0xD1, 0xCA,
+0x12, 0xD9, 0xF0, 0x90, 0x96, 0x09, 0xE0, 0x90,
+0xFD, 0x11, 0xF0, 0xD1, 0xB9, 0x12, 0x59, 0x20,
+0xEF, 0x60, 0x18, 0xD1, 0xB9, 0x90, 0x96, 0x02,
+0xE0, 0xFD, 0x90, 0x96, 0x04, 0xE0, 0xFB, 0x12,
+0xD9, 0x34, 0xEF, 0x60, 0x06, 0x90, 0x96, 0x13,
+0x74, 0x01, 0xF0, 0x90, 0x86, 0x72, 0xE0, 0xC3,
+0x13, 0x30, 0xE0, 0x13, 0xD1, 0xB9, 0x90, 0x96,
+0x02, 0xE0, 0xFD, 0x12, 0xA4, 0x8F, 0xEF, 0x60,
+0x06, 0x90, 0x96, 0x13, 0x74, 0x01, 0xF0, 0x71,
+0x3A, 0x54, 0x3F, 0x30, 0xE0, 0x0A, 0xD1, 0xB9,
+0x90, 0x96, 0x02, 0xE0, 0xFD, 0x12, 0xA6, 0x39,
+0x90, 0x86, 0x72, 0xE0, 0xFF, 0x12, 0x8F, 0xF3,
+0x30, 0xE0, 0x10, 0x90, 0x96, 0x13, 0xE0, 0x70,
+0x0A, 0xD1, 0xB9, 0x90, 0x96, 0x02, 0xE0, 0xFD,
+0x12, 0x4A, 0x3F, 0x12, 0x79, 0x00, 0xEF, 0x64,
+0x01, 0x70, 0x31, 0x90, 0x94, 0xE7, 0xE0, 0x60,
+0x1B, 0xD1, 0xB9, 0x90, 0x96, 0x02, 0xE0, 0xFD,
+0x12, 0xD5, 0x06, 0xBF, 0x01, 0x0E, 0x90, 0x86,
+0x7A, 0xE0, 0x54, 0xFE, 0xF0, 0x90, 0x01, 0xC7,
+0xE4, 0xF0, 0x80, 0x10, 0xF1, 0xD7, 0x30, 0xE0,
+0x06, 0x90, 0x01, 0x3F, 0x74, 0x04, 0xF0, 0x7F,
+0x01, 0x12, 0x5F, 0xE9, 0x12, 0x7A, 0xE7, 0xEF,
+0x64, 0x01, 0x70, 0x36, 0x90, 0x86, 0x89, 0xE0,
+0x04, 0xF0, 0x12, 0x6F, 0xE5, 0xAD, 0x07, 0xEF,
+0x64, 0x01, 0x60, 0x1F, 0xD1, 0xC2, 0xED, 0xB4,
+0x02, 0x08, 0x90, 0x01, 0xC7, 0x74, 0x42, 0xF0,
+0x80, 0x0A, 0xED, 0xB4, 0x04, 0x06, 0x90, 0x01,
+0xC7, 0x74, 0x43, 0xF0, 0x7F, 0x01, 0x12, 0x5F,
+0xE9, 0x80, 0x1D, 0xD1, 0xD4, 0x12, 0x7C, 0x0B,
+0x80, 0x0E, 0xF1, 0xD7, 0x20, 0xE0, 0x11, 0x90,
+0x86, 0x72, 0xE0, 0x54, 0xFE, 0xF0, 0x80, 0x08,
+0x90, 0x96, 0x00, 0xE0, 0x04, 0xF0, 0x61, 0x90,
+0x74, 0x41, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74,
+0x9B, 0xA3, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0xF0, 0x90, 0x95, 0xFD, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x22, 0x90, 0x86, 0x7A, 0xE0, 0x44, 0x01,
+0xF0, 0x22, 0x90, 0x96, 0x07, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x22, 0xF0, 0x90, 0x95, 0xF9, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0x90, 0x92, 0x53,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xE4, 0xFD, 0x12,
+0x55, 0x36, 0xEF, 0x22, 0xE0, 0x7C, 0x00, 0x24,
+0x00, 0xFF, 0x22, 0x90, 0x88, 0xD9, 0xF1, 0xA4,
+0xE0, 0xFE, 0x12, 0xD4, 0xE8, 0xFF, 0x74, 0x29,
+0x2E, 0x12, 0xC7, 0x99, 0xFD, 0x90, 0x92, 0x08,
+0xE0, 0x24, 0x2C, 0x12, 0xDE, 0x1B, 0x90, 0x92,
+0x08, 0xE0, 0x2F, 0x24, 0x30, 0xA3, 0xF0, 0xE0,
+0xFD, 0x24, 0x04, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0xE0, 0xFE, 0x74, 0x05, 0x2D, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xD1, 0xEC,
+0xEC, 0x3E, 0x90, 0x88, 0x80, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0x92, 0x09, 0xE0, 0x24, 0x0C, 0xF9,
+0xE4, 0x34, 0xFC, 0x12, 0x92, 0xC6, 0x75, 0x1E,
+0x04, 0x7B, 0x01, 0x7A, 0x88, 0x79, 0x82, 0x12,
+0x6A, 0x21, 0x90, 0x92, 0x09, 0xE0, 0x24, 0x14,
+0x12, 0xD2, 0x04, 0x2D, 0x12, 0x97, 0x4B, 0xD1,
+0xEC, 0xEC, 0x3E, 0x90, 0x88, 0x86, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x88, 0xDA, 0xF1, 0xA4, 0x90,
+0x88, 0x7C, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x4E,
+0x60, 0x12, 0x90, 0x92, 0x08, 0xE0, 0x12, 0x92,
+0xC0, 0x8F, 0x1E, 0x7B, 0x01, 0x7A, 0x88, 0x79,
+0x8A, 0x12, 0x6A, 0x21, 0x90, 0x88, 0xDB, 0xF1,
+0xA4, 0x12, 0x92, 0xC0, 0x90, 0x88, 0x7E, 0xA3,
+0xE0, 0xF5, 0x1E, 0x7B, 0x01, 0x7A, 0x88, 0x79,
+0xAA, 0x02, 0x6A, 0x21, 0xE0, 0xFF, 0x12, 0x7B,
+0x2A, 0x90, 0x92, 0x08, 0xEF, 0xF0, 0x22, 0xE0,
+0x54, 0xFE, 0x4E, 0xFE, 0xF0, 0x22, 0x54, 0x10,
+0xFD, 0xEF, 0x54, 0xEF, 0x4D, 0x22, 0x54, 0x40,
+0xFD, 0xEF, 0x54, 0xBF, 0x4D, 0x22, 0x90, 0x95,
+0xF9, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x54, 0x04,
+0xFD, 0xEF, 0x54, 0xFB, 0x4D, 0xFF, 0x22, 0x90,
+0x86, 0x74, 0xE0, 0xC4, 0x13, 0x54, 0x07, 0x22,
+0x90, 0x95, 0xF9, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD,
+0x22, 0x90, 0x95, 0xFB, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x22, 0xF0, 0xEE, 0x54, 0x80, 0xFE, 0xEF,
+0x54, 0x7F, 0x4E, 0x22, 0x12, 0x02, 0xF6, 0xFF,
+0x90, 0x94, 0x65, 0xF0, 0xBF, 0x01, 0x07, 0x11,
+0x0F, 0xE4, 0x90, 0x94, 0x65, 0xF0, 0x22, 0x11,
+0xBF, 0x7F, 0xEF, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x06, 0x90, 0x92, 0x05, 0xE0, 0xA3,
+0xF0, 0x11, 0xBF, 0x7F, 0xEE, 0x7E, 0x00, 0x12,
+0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x92, 0x05,
+0xE0, 0x90, 0x92, 0x07, 0xF0, 0x11, 0xBF, 0x7F,
+0xED, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x08, 0x90, 0x92, 0x05, 0xE0, 0x90, 0x92, 0x08,
+0xF0, 0x11, 0xBF, 0x7F, 0xEC, 0x7E, 0x00, 0x12,
+0x64, 0x37, 0xBF, 0x01, 0x08, 0x90, 0x92, 0x05,
+0xE0, 0x90, 0x92, 0x09, 0xF0, 0x11, 0xBF, 0x7F,
+0xEB, 0x7E, 0x00, 0x12, 0x64, 0x37, 0xBF, 0x01,
+0x08, 0x90, 0x92, 0x05, 0xE0, 0x90, 0x92, 0x0A,
+0xF0, 0x90, 0x92, 0x06, 0xE0, 0xFF, 0xA3, 0xE0,
+0xFD, 0xA3, 0xE0, 0xFB, 0xA3, 0xE0, 0x90, 0x92,
+0x0E, 0xF0, 0x90, 0x92, 0x0A, 0xE0, 0x90, 0x92,
+0x0F, 0xF0, 0x90, 0x92, 0x10, 0x74, 0x12, 0xF0,
+0x90, 0x92, 0x1E, 0x74, 0x05, 0xF0, 0x90, 0x92,
+0x12, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0xA3, 0xEB,
+0xF0, 0x90, 0x92, 0x0E, 0xE0, 0x90, 0x92, 0x15,
+0xF0, 0x90, 0x92, 0x0F, 0xE0, 0x90, 0x92, 0x16,
+0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x10, 0x12,
+0x5E, 0x10, 0x7F, 0x04, 0x02, 0x86, 0xB4, 0x7B,
+0x01, 0x7A, 0x92, 0x79, 0x05, 0x22, 0x12, 0x02,
+0xF6, 0x64, 0x01, 0x60, 0x02, 0x21, 0x53, 0x90,
+0x92, 0x24, 0xF0, 0x90, 0x92, 0x24, 0xE0, 0xFF,
+0xC3, 0x94, 0x10, 0x50, 0x27, 0xEF, 0x31, 0x54,
+0x7A, 0x92, 0x79, 0x23, 0x12, 0x64, 0x37, 0xBF,
+0x01, 0x12, 0x90, 0x92, 0x23, 0xE0, 0xFF, 0xA3,
+0xE0, 0x24, 0x25, 0xF5, 0x82, 0xE4, 0x34, 0x92,
+0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x92, 0x24, 0xE0,
+0x04, 0xF0, 0x80, 0xCF, 0x75, 0x1B, 0x01, 0x75,
+0x1C, 0x92, 0x75, 0x1D, 0x25, 0x75, 0x1E, 0x08,
+0x7B, 0x01, 0x7A, 0x92, 0x79, 0x07, 0x12, 0x6A,
+0x21, 0x90, 0x92, 0x05, 0x74, 0x24, 0xF0, 0x90,
+0x92, 0x13, 0x74, 0x08, 0xF0, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x92, 0x75, 0x1D, 0x2D, 0xF5, 0x1E,
+0x7B, 0x01, 0x7A, 0x92, 0x79, 0x16, 0x12, 0x6A,
+0x21, 0x90, 0x92, 0x14, 0x74, 0x25, 0xF0, 0x90,
+0x92, 0x22, 0x74, 0x08, 0xF0, 0x11, 0xBF, 0x12,
+0x5E, 0x10, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x14,
+0x12, 0x86, 0xAF, 0x22, 0x24, 0xDE, 0xFF, 0xE4,
+0x33, 0xFE, 0x7B, 0x01, 0x22, 0x12, 0x87, 0xB0,
+0x12, 0x02, 0xF6, 0x64, 0x01, 0x60, 0x02, 0x21,
+0xEB, 0xEF, 0x24, 0x39, 0x60, 0x12, 0x14, 0x60,
+0x19, 0x24, 0x02, 0x70, 0x1F, 0xE4, 0x90, 0x92,
+0x0B, 0xF0, 0xA3, 0x74, 0x06, 0xF0, 0x80, 0x14,
+0x90, 0x92, 0x0B, 0x74, 0x06, 0xF0, 0xA3, 0xF0,
+0x80, 0x0A, 0x90, 0x92, 0x0B, 0x74, 0x0C, 0xF0,
+0xA3, 0x74, 0x04, 0xF0, 0x31, 0xFF, 0xF0, 0x31,
+0xEC, 0x40, 0x1B, 0x90, 0x92, 0x09, 0xE0, 0x31,
+0x54, 0x7A, 0x92, 0x79, 0x08, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x07, 0x90, 0x92, 0x08, 0xE0, 0xF4,
+0x70, 0x39, 0x31, 0xF4, 0x80, 0xE1, 0x31, 0xFF,
+0xF0, 0x31, 0xEC, 0x40, 0x2E, 0x90, 0x92, 0x09,
+0xE0, 0xFD, 0x7C, 0x00, 0x24, 0xDE, 0xFF, 0xEC,
+0x33, 0xFE, 0xED, 0x24, 0x01, 0xFD, 0xEC, 0x33,
+0xFC, 0x90, 0x92, 0x0B, 0xE0, 0x51, 0x8E, 0x90,
+0x92, 0x05, 0x12, 0x86, 0x6C, 0x8D, 0x82, 0x8C,
+0x83, 0x12, 0x03, 0x0F, 0xFD, 0x51, 0x0F, 0x31,
+0xF4, 0x80, 0xCE, 0x22, 0x90, 0x92, 0x0A, 0xE0,
+0xD3, 0x94, 0x00, 0x22, 0x90, 0x92, 0x09, 0xE0,
+0x04, 0xF0, 0xA3, 0xE0, 0x14, 0xF0, 0x22, 0x90,
+0x92, 0x0B, 0xE0, 0x90, 0x92, 0x09, 0xF0, 0x90,
+0x92, 0x0C, 0xE0, 0x90, 0x92, 0x0A, 0x22, 0x8E,
+0x0D, 0x8F, 0x0E, 0x8D, 0x0F, 0xE4, 0x90, 0x92,
+0x0D, 0xF0, 0x90, 0x00, 0x37, 0xE0, 0x44, 0x80,
+0xFD, 0x7F, 0x37, 0x12, 0x7B, 0x3E, 0x7D, 0x69,
+0x7F, 0xCF, 0x12, 0x7B, 0x3E, 0xE5, 0x0E, 0xFD,
+0x7F, 0x31, 0x12, 0x7B, 0x3E, 0xE5, 0x0D, 0x54,
+0x03, 0xFF, 0x90, 0x00, 0x32, 0xE0, 0x54, 0xFC,
+0x4F, 0xFD, 0x7F, 0x32, 0x12, 0x7B, 0x3E, 0xAD,
+0x0F, 0x7F, 0x30, 0x12, 0x7B, 0x3E, 0x90, 0x00,
+0x33, 0xE0, 0x44, 0x80, 0xFD, 0x7F, 0x33, 0x12,
+0x7B, 0x3E, 0x90, 0x00, 0x33, 0xE0, 0x30, 0xE7,
+0x09, 0x51, 0x86, 0x50, 0x05, 0xE0, 0x04, 0xF0,
+0x80, 0xF0, 0xE4, 0xFD, 0x7F, 0xCF, 0x12, 0x7B,
+0x3E, 0x90, 0x00, 0x37, 0xE0, 0x54, 0x7F, 0xFD,
+0x7F, 0x37, 0x12, 0x7B, 0x3E, 0x51, 0x86, 0x7F,
+0x00, 0x50, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x92,
+0x0D, 0xE0, 0xC3, 0x94, 0x64, 0x22, 0xFB, 0xC3,
+0xED, 0x9B, 0xFD, 0xEC, 0x94, 0x00, 0xFC, 0x22,
+0x12, 0xC7, 0xC0, 0xA3, 0xEB, 0xF0, 0xE4, 0x90,
+0x92, 0x55, 0xF0, 0xF0, 0x90, 0x92, 0x51, 0xE0,
+0xFF, 0x90, 0x92, 0x55, 0xE0, 0xFE, 0xC3, 0x9F,
+0x50, 0x2B, 0xD1, 0x28, 0x2D, 0xFD, 0xB1, 0xFD,
+0xFC, 0xEF, 0x51, 0x8E, 0xEE, 0x7E, 0x00, 0x2D,
+0x51, 0xFA, 0x90, 0x92, 0x52, 0x12, 0x86, 0x6C,
+0x90, 0x92, 0x55, 0xE0, 0xF5, 0x82, 0x75, 0x83,
+0x00, 0xEF, 0x12, 0x03, 0x4E, 0x90, 0x92, 0x55,
+0xE0, 0x04, 0xF0, 0x80, 0xC7, 0x22, 0x90, 0x92,
+0x50, 0xE0, 0xFD, 0x90, 0x92, 0x4F, 0xE0, 0x2D,
+0xFD, 0x90, 0x92, 0x4E, 0xE0, 0x34, 0x00, 0xCD,
+0x24, 0x10, 0xCD, 0x34, 0x00, 0xFC, 0x7E, 0x00,
+0xED, 0x2F, 0xFF, 0xEE, 0x3C, 0xFE, 0xE4, 0xFD,
+0x02, 0x55, 0x36, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x06, 0x31, 0xE0, 0x54, 0xEF,
+0x44, 0x08, 0xF0, 0xED, 0x2F, 0xFF, 0xE4, 0x3E,
+0xFE, 0x7C, 0x00, 0xEF, 0x24, 0x08, 0xFF, 0xEC,
+0x3E, 0x90, 0x92, 0xF8, 0xF0, 0xA3, 0xEF, 0xF0,
+0x7E, 0x00, 0x7F, 0x83, 0x7D, 0x00, 0x7B, 0x01,
+0x7A, 0x87, 0x79, 0x8C, 0x12, 0x06, 0xDE, 0x90,
+0x92, 0xF9, 0xE0, 0x24, 0x01, 0xFF, 0x90, 0x92,
+0xF8, 0xE0, 0x34, 0x00, 0x51, 0xFD, 0x90, 0x87,
+0x8D, 0xB1, 0xEB, 0x24, 0x04, 0xFF, 0x90, 0x92,
+0xF8, 0xE0, 0x34, 0x00, 0x51, 0xFD, 0x90, 0x87,
+0x90, 0xB1, 0xEB, 0x24, 0x05, 0xFF, 0x90, 0x92,
+0xF8, 0xE0, 0x34, 0x00, 0x51, 0xFD, 0x90, 0x87,
+0x91, 0xB1, 0xEB, 0x24, 0x06, 0xFF, 0x90, 0x92,
+0xF8, 0xE0, 0x34, 0x00, 0x51, 0xFD, 0x90, 0x87,
+0x92, 0xB1, 0xEB, 0x24, 0x07, 0xFF, 0x90, 0x92,
+0xF8, 0xE0, 0x34, 0x00, 0x51, 0xFD, 0x90, 0x87,
+0x93, 0xB1, 0xEB, 0x24, 0x08, 0xFF, 0x90, 0x92,
+0xF8, 0xE0, 0x34, 0x00, 0x51, 0xFD, 0x90, 0x87,
+0x94, 0xEF, 0xF0, 0xE4, 0x90, 0x92, 0xF7, 0xF0,
+0xD1, 0x21, 0x94, 0x08, 0x50, 0x1C, 0x90, 0x92,
+0xF9, 0xE0, 0x24, 0x09, 0xFD, 0x90, 0x92, 0xF8,
+0xE0, 0x51, 0xF3, 0x90, 0x92, 0xF7, 0xE0, 0x24,
+0x95, 0xF5, 0x82, 0xE4, 0x34, 0x87, 0xD1, 0x0B,
+0x80, 0xDE, 0xE4, 0x90, 0x92, 0xF7, 0xF0, 0xD1,
+0x21, 0x94, 0x02, 0x50, 0x1C, 0x90, 0x92, 0xF9,
+0xE0, 0x24, 0x61, 0xFD, 0x90, 0x92, 0xF8, 0xE0,
+0x51, 0xF3, 0x90, 0x92, 0xF7, 0xE0, 0x24, 0xED,
+0xF5, 0x82, 0xE4, 0x34, 0x87, 0xD1, 0x0B, 0x80,
+0xDE, 0xE4, 0x90, 0x92, 0xF7, 0xF0, 0xD1, 0x21,
+0x94, 0x10, 0x50, 0x1C, 0x90, 0x92, 0xF9, 0xE0,
+0x24, 0x31, 0xFD, 0x90, 0x92, 0xF8, 0xE0, 0x51,
+0xF3, 0x90, 0x92, 0xF7, 0xE0, 0x24, 0xBD, 0xF5,
+0x82, 0xE4, 0x34, 0x87, 0xD1, 0x0B, 0x80, 0xDE,
+0xE4, 0x90, 0x92, 0xF7, 0xF0, 0x90, 0x87, 0xEE,
+0xE0, 0xFF, 0x90, 0x92, 0xF7, 0xE0, 0xFE, 0xC3,
+0x9F, 0x50, 0x23, 0x90, 0x92, 0xF9, 0xE0, 0x24,
+0x63, 0xFD, 0x90, 0x92, 0xF8, 0xE0, 0x34, 0x00,
+0xFC, 0xEE, 0x7E, 0x00, 0x2D, 0x51, 0xFA, 0x90,
+0x92, 0xF7, 0xE0, 0x24, 0xE9, 0xF5, 0x82, 0xE4,
+0x34, 0x94, 0xD1, 0x0B, 0x80, 0xCF, 0x90, 0x87,
+0x91, 0x12, 0xDD, 0x4B, 0x90, 0x92, 0xF5, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x30, 0xE3, 0x0D, 0x90,
+0x01, 0xC7, 0x74, 0x03, 0xF0, 0x7F, 0x01, 0x12,
+0x5F, 0xE9, 0x80, 0x20, 0x7E, 0x00, 0x90, 0x92,
+0xF6, 0xE0, 0x54, 0x07, 0xFF, 0x64, 0x01, 0x60,
+0x05, 0xEF, 0x64, 0x02, 0x70, 0x0E, 0xE4, 0xFD,
+0x12, 0x77, 0xB1, 0x90, 0x06, 0x31, 0xE0, 0x54,
+0xF7, 0x44, 0x10, 0xF0, 0x12, 0xD7, 0x6D, 0xE4,
+0xF0, 0xFF, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12,
+0xC7, 0xC0, 0x12, 0xDF, 0x48, 0x7A, 0x82, 0x79,
+0x00, 0x12, 0xDF, 0x89, 0x78, 0x5D, 0x7C, 0x92,
+0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x82, 0x79, 0x06,
+0xD1, 0x32, 0x78, 0x61, 0x7C, 0x92, 0x7D, 0x01,
+0x7B, 0xFF, 0x7A, 0x82, 0x79, 0x0A, 0xD1, 0x32,
+0xE4, 0x90, 0x92, 0x66, 0xF0, 0xB1, 0xF2, 0xCF,
+0x24, 0x06, 0xCF, 0x34, 0x00, 0x51, 0xFD, 0xEF,
+0x64, 0x08, 0x60, 0x02, 0xA1, 0xE5, 0xB1, 0xF2,
+0xCF, 0x24, 0x07, 0xCF, 0x34, 0x00, 0x51, 0xFD,
+0xEF, 0x64, 0x06, 0x60, 0x02, 0xA1, 0xE5, 0x90,
+0x92, 0x66, 0x04, 0xF0, 0xE4, 0x90, 0x92, 0x65,
+0xF0, 0xD1, 0x04, 0x94, 0x06, 0x50, 0x17, 0x90,
+0x92, 0x4F, 0xE0, 0x24, 0x0A, 0xFD, 0x90, 0x92,
+0x4E, 0xE0, 0x51, 0xF3, 0x90, 0x92, 0x65, 0x12,
+0xDF, 0x3F, 0xD1, 0x16, 0x80, 0xE3, 0x78, 0x51,
+0x7C, 0x92, 0x7D, 0x01, 0x7B, 0x01, 0x7A, 0x86,
+0x79, 0x81, 0x7E, 0x00, 0x7F, 0x06, 0x12, 0x06,
+0xBA, 0xEF, 0x60, 0x02, 0xA1, 0xE5, 0x90, 0x92,
+0x65, 0xF0, 0xD1, 0x04, 0x94, 0x04, 0x50, 0x1A,
+0xD1, 0x28, 0x2D, 0xFD, 0xB1, 0xFD, 0xCD, 0x24,
+0x20, 0x51, 0xF2, 0x90, 0x92, 0x65, 0xE0, 0x24,
+0x61, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0xD1, 0x16,
+0x80, 0xE0, 0x78, 0x61, 0x7C, 0x92, 0x7D, 0x01,
+0x7B, 0x01, 0x7A, 0x86, 0x79, 0x9C, 0x7E, 0x00,
+0x7F, 0x04, 0x12, 0x06, 0xBA, 0xEF, 0x60, 0x02,
+0xA1, 0xDC, 0x90, 0x06, 0x30, 0xE0, 0x44, 0x01,
+0x54, 0xDF, 0xF0, 0x90, 0x86, 0x74, 0xE0, 0x30,
+0xE0, 0x02, 0x80, 0x0D, 0x90, 0x88, 0xCC, 0xE0,
+0xB4, 0x02, 0x11, 0x12, 0xD9, 0xDB, 0x20, 0xE0,
+0x0B, 0x90, 0x01, 0xC7, 0x74, 0x09, 0xF0, 0x12,
+0x9E, 0xC2, 0x80, 0x61, 0xE4, 0x90, 0x92, 0x65,
+0xF0, 0xD1, 0x04, 0x94, 0x06, 0x50, 0x0C, 0x51,
+0xDE, 0x90, 0x92, 0x65, 0x12, 0xDF, 0x36, 0xD1,
+0x16, 0x80, 0xEE, 0xE4, 0x90, 0x92, 0x65, 0xF0,
+0xD1, 0x04, 0x94, 0x04, 0x50, 0x1A, 0xD1, 0x28,
+0x2D, 0xFD, 0xB1, 0xFD, 0xCD, 0x24, 0x16, 0x51,
+0xF2, 0x90, 0x92, 0x65, 0xE0, 0x24, 0x5D, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0xD1, 0x16, 0x80, 0xE0,
+0x7B, 0x01, 0x7A, 0x92, 0x79, 0x57, 0x90, 0x91,
+0x17, 0x12, 0x86, 0x75, 0xE4, 0x90, 0x91, 0x1A,
+0xF0, 0xA3, 0xF0, 0x7A, 0x92, 0x79, 0x5D, 0x12,
+0x36, 0xA9, 0x80, 0x09, 0x90, 0x06, 0x30, 0xE0,
+0x44, 0x21, 0x54, 0xEF, 0xF0, 0x90, 0x92, 0x66,
+0xE0, 0xFF, 0x22, 0xEF, 0xF0, 0x90, 0x92, 0xF9,
+0xE0, 0x22, 0x90, 0x92, 0x50, 0xE0, 0xFF, 0x90,
+0x92, 0x4F, 0xE0, 0x2F, 0xFF, 0x90, 0x92, 0x4E,
+0xE0, 0x34, 0x00, 0x22, 0x90, 0x92, 0x65, 0xE0,
+0xFF, 0xC3, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
+0x92, 0xF7, 0xE0, 0x04, 0xF0, 0x22, 0xF5, 0x83,
+0xEF, 0xF0, 0x90, 0x92, 0x65, 0xE0, 0x04, 0xF0,
+0x22, 0x90, 0x92, 0xF7, 0xE0, 0xFF, 0xC3, 0x22,
+0x90, 0x92, 0x50, 0xE0, 0xFD, 0x90, 0x92, 0x4F,
+0xE0, 0x22, 0x7E, 0x00, 0x7F, 0x04, 0x02, 0x02,
+0xD0, 0x12, 0xC7, 0xC0, 0x78, 0x51, 0x7C, 0x92,
+0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x82, 0x79, 0x0E,
+0x12, 0xDF, 0x89, 0x12, 0xDF, 0x48, 0x7A, 0x82,
+0x79, 0x14, 0x12, 0xDF, 0x82, 0x78, 0x67, 0x7C,
+0x92, 0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x82, 0x79,
+0x24, 0x12, 0xDF, 0x82, 0xE4, 0x90, 0x92, 0x7A,
+0x12, 0xD9, 0xC9, 0xA3, 0xE0, 0xFD, 0x12, 0x74,
+0x2C, 0xEF, 0x64, 0x01, 0x60, 0x03, 0x02, 0xA8,
+0x14, 0xB1, 0xF2, 0xCF, 0x24, 0x0E, 0xCF, 0x34,
+0x00, 0x51, 0xFD, 0xEF, 0x64, 0x3A, 0x60, 0x03,
+0x02, 0xA8, 0x14, 0xB1, 0xF2, 0xCF, 0x24, 0x30,
+0xCF, 0x34, 0x00, 0x51, 0xFD, 0xEF, 0x64, 0x87,
+0x60, 0x03, 0x02, 0xA8, 0x14, 0x90, 0x92, 0x7A,
+0x04, 0xF0, 0xE4, 0x90, 0x92, 0x77, 0xF0, 0x12,
+0xDF, 0x03, 0x94, 0x10, 0x50, 0x1B, 0xD1, 0x28,
+0x2D, 0xFD, 0xB1, 0xFD, 0xCD, 0x24, 0x38, 0x51,
+0xF2, 0x90, 0x92, 0x77, 0xE0, 0x24, 0x67, 0xF5,
+0x82, 0xE4, 0x34, 0x92, 0x12, 0xDE, 0x7A, 0x80,
+0xDE, 0xE4, 0x90, 0x92, 0x78, 0xF0, 0x90, 0x92,
+0x78, 0xE0, 0xFF, 0xC3, 0x94, 0x02, 0x40, 0x03,
+0x02, 0xA8, 0x14, 0x75, 0xF0, 0x38, 0xEF, 0x12,
+0xDF, 0x7A, 0x20, 0xE0, 0x03, 0x02, 0xA8, 0x14,
+0xE4, 0x90, 0x92, 0x79, 0xF0, 0x12, 0xDF, 0x2D,
+0x90, 0x86, 0xAB, 0x12, 0x05, 0x28, 0xE0, 0xFE,
+0x90, 0x92, 0x79, 0xE0, 0xC3, 0x9E, 0x40, 0x03,
+0x02, 0xA8, 0x0B, 0xEF, 0x75, 0xF0, 0x38, 0xA4,
+0x24, 0xC2, 0xF9, 0x74, 0x86, 0x35, 0xF0, 0xFA,
+0x7B, 0x01, 0xE0, 0x75, 0xF0, 0x10, 0xA4, 0x29,
+0xF9, 0xEA, 0x35, 0xF0, 0xFA, 0x78, 0x67, 0x7C,
+0x92, 0x12, 0xDD, 0x40, 0x60, 0x02, 0xE1, 0xFB,
+0x90, 0x06, 0x33, 0xE0, 0x44, 0x01, 0x54, 0xFB,
+0xF0, 0xE4, 0x90, 0x92, 0x77, 0xF0, 0x12, 0xDF,
+0x03, 0x94, 0x06, 0x50, 0x16, 0xD1, 0x28, 0x2D,
+0xFD, 0xB1, 0xFD, 0xCD, 0x24, 0x4A, 0x51, 0xF2,
+0x90, 0x92, 0x77, 0x12, 0xDF, 0x3F, 0x12, 0xDE,
+0x7A, 0x80, 0xE3, 0xE4, 0x90, 0x92, 0x77, 0xF0,
+0x12, 0xDF, 0x03, 0x94, 0x10, 0x50, 0x0D, 0x51,
+0xDE, 0x90, 0x92, 0x77, 0x12, 0xDF, 0x36, 0x12,
+0xDE, 0x7A, 0x80, 0xEC, 0x12, 0xDF, 0x2D, 0x12,
+0xDF, 0x7A, 0xFE, 0xC3, 0x13, 0x30, 0xE0, 0x2C,
+0xEF, 0x75, 0xF0, 0x38, 0xA4, 0x24, 0xB2, 0xF9,
+0x74, 0x86, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x78,
+0x57, 0x7C, 0x92, 0x12, 0xDD, 0x40, 0x70, 0x72,
+0x90, 0x88, 0xCC, 0xE0, 0xB4, 0x02, 0x0B, 0x90,
+0x86, 0x73, 0x12, 0xAC, 0x65, 0x20, 0xE0, 0x1F,
+0x80, 0x12, 0x80, 0x1B, 0x90, 0x88, 0xCC, 0xE0,
+0xB4, 0x02, 0x14, 0x90, 0x86, 0x73, 0x12, 0xAC,
+0x65, 0x20, 0xE0, 0x0B, 0x90, 0x01, 0xC7, 0x74,
+0x0A, 0xF0, 0x12, 0x9E, 0xC2, 0x80, 0x55, 0x7B,
+0x01, 0x7A, 0x92, 0x79, 0x51, 0x90, 0x8B, 0xE6,
+0x12, 0x86, 0x75, 0x7A, 0x92, 0x79, 0x67, 0x90,
+0x8B, 0xE9, 0x12, 0x86, 0x75, 0x90, 0x92, 0x78,
+0xE0, 0x75, 0xF0, 0x38, 0xA4, 0x24, 0xAC, 0xF9,
+0x74, 0x86, 0x35, 0xF0, 0xFA, 0x90, 0x8B, 0xEC,
+0x12, 0x86, 0x75, 0xE4, 0x90, 0x8B, 0xEF, 0xF0,
+0xA3, 0xF0, 0x7A, 0x92, 0x79, 0x57, 0x12, 0x19,
+0xBB, 0x80, 0x07, 0x90, 0x06, 0x33, 0xE0, 0x44,
+0x05, 0xF0, 0x90, 0x92, 0x79, 0xE0, 0x04, 0xF0,
+0x02, 0xA6, 0xED, 0x90, 0x92, 0x78, 0xE0, 0x04,
+0xF0, 0x02, 0xA6, 0xCE, 0x90, 0x92, 0x7A, 0xE0,
+0xFF, 0x22, 0x12, 0x02, 0xF6, 0x54, 0x01, 0xFF,
+0x90, 0x94, 0xA5, 0xE0, 0x54, 0xFE, 0x4F, 0xF0,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x12, 0xDF, 0x14, 0x90, 0x05, 0x27, 0xE0, 0xF5,
+0x10, 0x12, 0xD9, 0x19, 0x75, 0x1E, 0x01, 0x7B,
+0x01, 0x7A, 0x85, 0x79, 0xBC, 0x12, 0x6A, 0x21,
+0x12, 0x8A, 0xEC, 0x12, 0x02, 0xF6, 0xFF, 0xC3,
+0x13, 0x20, 0xE0, 0x02, 0x01, 0xDD, 0x90, 0x85,
+0xBC, 0xE0, 0x30, 0xE0, 0x6F, 0x91, 0x49, 0x75,
+0x10, 0x21, 0x91, 0x59, 0x30, 0xE0, 0x04, 0xB1,
+0x00, 0x80, 0x0D, 0xE4, 0x90, 0x85, 0xBD, 0xF0,
+0xA3, 0xF0, 0x7D, 0x40, 0xFF, 0x12, 0x7C, 0x41,
+0x90, 0x85, 0xBC, 0x91, 0x65, 0x30, 0xE0, 0x03,
+0x43, 0x10, 0x12, 0xEF, 0xC4, 0x54, 0x0F, 0x30,
+0xE0, 0x03, 0x43, 0x10, 0x14, 0x90, 0x85, 0xBC,
+0xE0, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x03,
+0x43, 0x10, 0x80, 0x90, 0x85, 0xBC, 0xF1, 0xE3,
+0x20, 0xE0, 0x03, 0x43, 0x10, 0x40, 0x31, 0x82,
+0x90, 0x85, 0xBF, 0xE0, 0x70, 0x04, 0x7F, 0x01,
+0x71, 0x3A, 0x91, 0x50, 0x54, 0x03, 0x30, 0xE0,
+0x04, 0x7F, 0x04, 0x80, 0x0B, 0x91, 0x6D, 0xEF,
+0x60, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F, 0x02,
+0x71, 0x3A, 0x80, 0x7F, 0x31, 0x7F, 0x90, 0x85,
+0xBF, 0xE0, 0x64, 0x04, 0x60, 0x02, 0x21, 0x7A,
+0xFF, 0x71, 0x3A, 0x21, 0x7A, 0x90, 0x85, 0xBC,
+0xE0, 0x30, 0xE0, 0x6F, 0x91, 0x49, 0x43, 0x10,
+0x31, 0x91, 0x59, 0x30, 0xE0, 0x04, 0xB1, 0x00,
+0x80, 0x07, 0x7D, 0x40, 0xE4, 0xFF, 0x12, 0x7C,
+0x41, 0x90, 0x85, 0xBC, 0x91, 0x65, 0x30, 0xE0,
+0x03, 0x43, 0x10, 0x02, 0xEF, 0xC4, 0x54, 0x0F,
+0x30, 0xE0, 0x03, 0x43, 0x10, 0x04, 0x31, 0x82,
+0x91, 0x50, 0x54, 0x03, 0x30, 0xE0, 0x0A, 0xB1,
+0x29, 0x60, 0x30, 0xE4, 0xFD, 0x7F, 0x02, 0x80,
+0x1E, 0x12, 0xDE, 0x72, 0x90, 0x85, 0xC0, 0xE0,
+0xB4, 0x02, 0x18, 0x12, 0x7A, 0xA2, 0x91, 0x6D,
+0xBF, 0x01, 0x09, 0x90, 0x85, 0xC7, 0xE0, 0xFF,
+0x7D, 0x01, 0x80, 0x03, 0xE4, 0xFD, 0xFF, 0x31,
+0x8D, 0x80, 0x08, 0x90, 0x85, 0xC8, 0xE0, 0x90,
+0x85, 0xC0, 0xF0, 0x90, 0x05, 0x40, 0x74, 0x22,
+0xF0, 0x80, 0x27, 0x31, 0x7F, 0x90, 0x85, 0xC0,
+0xE0, 0xB4, 0x02, 0x06, 0x7D, 0x01, 0x7F, 0x04,
+0x80, 0x0B, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x08,
+0x06, 0x7D, 0x01, 0x7F, 0x0C, 0x31, 0x8D, 0x12,
+0xCA, 0x2C, 0x90, 0x85, 0xC7, 0xF1, 0xB4, 0x12,
+0xB5, 0xF7, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x75,
+0x10, 0x01, 0x90, 0x05, 0x27, 0xE5, 0x10, 0xF0,
+0x22, 0xE4, 0xFD, 0x7F, 0x0C, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x99, 0xED,
+0xF0, 0x90, 0x85, 0xC1, 0xE0, 0xFE, 0xC4, 0x13,
+0x13, 0x54, 0x03, 0x30, 0xE0, 0x02, 0x41, 0xE9,
+0xEE, 0x12, 0x8F, 0xF3, 0x30, 0xE0, 0x02, 0x41,
+0xE9, 0x90, 0x85, 0xC8, 0xE0, 0xFE, 0x6F, 0x70,
+0x02, 0x41, 0xE9, 0xEF, 0x70, 0x02, 0x41, 0x53,
+0x24, 0xFE, 0x70, 0x02, 0x41, 0x90, 0x24, 0xFE,
+0x60, 0x4D, 0x24, 0xFC, 0x70, 0x02, 0x41, 0xCF,
+0x24, 0xFC, 0x60, 0x02, 0x41, 0xE2, 0xEE, 0xB4,
+0x0E, 0x03, 0x12, 0x74, 0x93, 0x90, 0x85, 0xC8,
+0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x79, 0x80,
+0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12,
+0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x04,
+0x0F, 0x90, 0x96, 0x99, 0xE0, 0xFF, 0x60, 0x05,
+0x12, 0x6D, 0x4C, 0x80, 0x03, 0x12, 0x79, 0x61,
+0x90, 0x85, 0xC8, 0xE0, 0x64, 0x08, 0x60, 0x02,
+0x41, 0xE2, 0x12, 0x7A, 0xB9, 0x41, 0xE2, 0x90,
+0x85, 0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12,
+0x79, 0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06,
+0x03, 0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0,
+0xB4, 0x0E, 0x08, 0x51, 0xEE, 0xBF, 0x01, 0x03,
+0x12, 0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0, 0x64,
+0x0C, 0x60, 0x02, 0x41, 0xE2, 0x51, 0xEE, 0xEF,
+0x64, 0x01, 0x60, 0x02, 0x41, 0xE2, 0x12, 0x70,
+0x9E, 0x41, 0xE2, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
+0x0E, 0x08, 0x51, 0xEE, 0xBF, 0x01, 0x03, 0x12,
+0x74, 0x93, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x06,
+0x03, 0x12, 0x73, 0x8E, 0x90, 0x85, 0xC8, 0xE0,
+0xB4, 0x0C, 0x08, 0x51, 0xEE, 0xBF, 0x01, 0x03,
+0x12, 0x70, 0x9E, 0x90, 0x85, 0xC8, 0xE0, 0x64,
+0x04, 0x70, 0x5F, 0x12, 0xCB, 0x96, 0xEF, 0x64,
+0x01, 0x70, 0x57, 0x12, 0x77, 0xFE, 0x80, 0x52,
+0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0E, 0x08, 0x51,
+0xEE, 0xBF, 0x01, 0x03, 0x12, 0x74, 0x93, 0x90,
+0x85, 0xC8, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x73,
+0x8E, 0x90, 0x85, 0xC8, 0xE0, 0xB4, 0x0C, 0x08,
+0x51, 0xEE, 0xBF, 0x01, 0x03, 0x12, 0x70, 0x9E,
+0x90, 0x85, 0xC8, 0xE0, 0x70, 0x05, 0x7F, 0x01,
+0x12, 0x79, 0x80, 0x90, 0x85, 0xC8, 0xE0, 0xB4,
+0x04, 0x18, 0x12, 0x79, 0xF3, 0x80, 0x13, 0x90,
+0x85, 0xC8, 0xE0, 0xB4, 0x0C, 0x0C, 0x90, 0x85,
+0xC2, 0x12, 0xBF, 0xAC, 0x30, 0xE0, 0x03, 0x12,
+0x7A, 0x8A, 0x90, 0x85, 0xC8, 0x12, 0xDE, 0xA5,
+0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x7A, 0x29,
+0xEF, 0x64, 0x01, 0x60, 0x05, 0x75, 0x5B, 0x01,
+0x80, 0x25, 0x90, 0x85, 0xC1, 0x12, 0xD9, 0xDE,
+0x30, 0xE0, 0x05, 0x75, 0x5B, 0x02, 0x80, 0x17,
+0x90, 0x85, 0xC7, 0xE0, 0xD3, 0x94, 0x04, 0x40,
+0x05, 0x75, 0x5B, 0x08, 0x80, 0x09, 0x90, 0x01,
+0xB8, 0xE4, 0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90,
+0x01, 0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8,
+0xE5, 0x5B, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x85, 0xBF, 0xE0, 0x90, 0x96, 0x98,
+0xF0, 0x6F, 0x70, 0x02, 0x81, 0x44, 0xEF, 0x14,
+0x60, 0x42, 0x14, 0x60, 0x6C, 0x14, 0x70, 0x02,
+0x61, 0xEE, 0x14, 0x70, 0x02, 0x81, 0x19, 0x24,
+0x04, 0x60, 0x02, 0x81, 0x44, 0x90, 0x96, 0x98,
+0xE0, 0xB4, 0x04, 0x04, 0xF1, 0x98, 0x81, 0x44,
+0x90, 0x96, 0x98, 0xE0, 0xB4, 0x02, 0x04, 0xF1,
+0xA7, 0x81, 0x44, 0x90, 0x96, 0x98, 0xE0, 0xB4,
+0x03, 0x04, 0xF1, 0xAB, 0x81, 0x44, 0x90, 0x96,
+0x98, 0xE0, 0x64, 0x01, 0x60, 0x02, 0x81, 0x44,
+0xF1, 0x9A, 0x81, 0x44, 0x90, 0x96, 0x98, 0xE0,
+0xB4, 0x04, 0x04, 0xF1, 0x72, 0x81, 0x44, 0x90,
+0x96, 0x98, 0xE0, 0xB4, 0x02, 0x04, 0xF1, 0x68,
+0x81, 0x44, 0x90, 0x96, 0x98, 0xE0, 0xB4, 0x03,
+0x04, 0xF1, 0x6D, 0x81, 0x44, 0x90, 0x96, 0x98,
+0xE0, 0x60, 0x02, 0x81, 0x44, 0xF1, 0x61, 0x81,
+0x44, 0x90, 0x96, 0x98, 0xE0, 0xB4, 0x04, 0x05,
+0x12, 0xB7, 0xD2, 0x80, 0x77, 0x90, 0x96, 0x98,
+0xE0, 0xB4, 0x01, 0x05, 0x12, 0x97, 0xE4, 0x80,
+0x6B, 0x90, 0x96, 0x98, 0xE0, 0xB4, 0x03, 0x04,
+0xF1, 0xDD, 0x80, 0x60, 0x90, 0x96, 0x98, 0xE0,
+0x70, 0x5A, 0xF1, 0x83, 0x80, 0x56, 0x90, 0x96,
+0x98, 0xE0, 0xB4, 0x04, 0x04, 0xF1, 0xD4, 0x80,
+0x4B, 0x90, 0x96, 0x98, 0xE0, 0xB4, 0x01, 0x04,
+0xF1, 0x8A, 0x80, 0x40, 0x90, 0x96, 0x98, 0xE0,
+0xB4, 0x02, 0x04, 0xF1, 0xAF, 0x80, 0x35, 0x90,
+0x96, 0x98, 0xE0, 0x70, 0x2F, 0xF1, 0x88, 0x80,
+0x2B, 0x90, 0x96, 0x98, 0xE0, 0xB4, 0x03, 0x05,
+0x12, 0xCA, 0x14, 0x80, 0x1F, 0x90, 0x96, 0x98,
+0xE0, 0xB4, 0x01, 0x04, 0xF1, 0x7C, 0x80, 0x14,
+0x90, 0x96, 0x98, 0xE0, 0xB4, 0x02, 0x05, 0x12,
+0xBB, 0x76, 0x80, 0x08, 0x90, 0x96, 0x98, 0xE0,
+0x70, 0x02, 0xF1, 0x7A, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x7D, 0x03, 0x7F, 0x02, 0x02, 0x7B, 0xFD,
+0x90, 0x85, 0xBC, 0xE0, 0xFF, 0xC4, 0x13, 0x13,
+0x22, 0x90, 0x85, 0xBC, 0xE0, 0x13, 0x13, 0x54,
+0x3F, 0x22, 0x90, 0x85, 0xC2, 0xE0, 0xFF, 0x13,
+0x13, 0x13, 0x54, 0x1F, 0x22, 0x90, 0x05, 0x43,
+0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02, 0x7F, 0x01,
+0x22, 0xE4, 0xF5, 0x15, 0x90, 0x85, 0xC5, 0xE0,
+0x60, 0x6A, 0xF1, 0xC2, 0x70, 0x66, 0x12, 0xDE,
+0x27, 0x75, 0x15, 0x01, 0x90, 0x85, 0xBC, 0xE0,
+0x30, 0xE0, 0x11, 0x90, 0x85, 0xC0, 0xE0, 0xB4,
+0x02, 0x03, 0xE4, 0xF5, 0x15, 0x91, 0x6D, 0xEF,
+0x70, 0x02, 0xF5, 0x15, 0xE5, 0x15, 0x60, 0x44,
+0x90, 0x85, 0xC8, 0xE0, 0x20, 0xE2, 0x06, 0x7D,
+0x01, 0x7F, 0x04, 0x31, 0x8D, 0xF1, 0xBA, 0x90,
+0x85, 0xCE, 0xE0, 0x60, 0x04, 0x64, 0x01, 0x70,
+0x16, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0x90, 0x85,
+0xCE, 0xE0, 0x91, 0xED, 0x90, 0x91, 0x6F, 0xB1,
+0x7A, 0x90, 0x85, 0xCE, 0xE0, 0x80, 0x0F, 0xE4,
+0x90, 0x91, 0x6E, 0x91, 0xF4, 0x91, 0xED, 0x90,
+0x91, 0x6F, 0xB1, 0x7A, 0x91, 0xF5, 0x91, 0xED,
+0x90, 0x85, 0xDE, 0xF0, 0x22, 0xFF, 0x90, 0x85,
+0xCD, 0xE0, 0x2F, 0x22, 0xF0, 0x90, 0x85, 0xCE,
+0xE0, 0x75, 0xF0, 0x03, 0xA4, 0x24, 0xFE, 0x22,
+0x90, 0x01, 0x34, 0x74, 0x40, 0xF0, 0xFD, 0xE4,
+0xFF, 0x12, 0x7C, 0xA9, 0x43, 0x10, 0x08, 0x22,
+0x91, 0x50, 0x54, 0x03, 0x30, 0xE0, 0x0A, 0xB1,
+0x29, 0x60, 0x06, 0x7D, 0x01, 0x7F, 0x02, 0x31,
+0x8D, 0xB1, 0x29, 0x60, 0x03, 0x12, 0xCA, 0x56,
+0x22, 0x90, 0x85, 0xC0, 0xE0, 0x64, 0x02, 0x22,
+0xAE, 0x07, 0x91, 0x6D, 0xBF, 0x01, 0x11, 0x90,
+0x85, 0xBC, 0xF1, 0xE3, 0x20, 0xE0, 0x09, 0xAF,
+0x06, 0x7D, 0x01, 0x31, 0x8D, 0x7F, 0x01, 0x22,
+0x7F, 0x00, 0x22, 0x90, 0x94, 0x6C, 0xE0, 0xC3,
+0x13, 0x54, 0x07, 0xFF, 0x75, 0xF0, 0x0E, 0xA4,
+0x24, 0x79, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
+0x83, 0xE0, 0xFE, 0xEF, 0x75, 0xF0, 0x0E, 0xA4,
+0x24, 0x78, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5,
+0x83, 0xE0, 0x90, 0x91, 0x6F, 0xF0, 0x90, 0x91,
+0x6E, 0xEE, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54,
+0x7E, 0x01, 0x02, 0x61, 0x41, 0xE4, 0x90, 0x92,
+0x8A, 0xF0, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x55,
+0xF1, 0xC2, 0x70, 0x51, 0x12, 0xDF, 0x97, 0xF0,
+0x12, 0xDE, 0x27, 0x90, 0x92, 0x8A, 0x74, 0x01,
+0xF0, 0xE4, 0x90, 0x85, 0xCC, 0xF0, 0x90, 0x85,
+0xBC, 0xE0, 0x30, 0xE0, 0x15, 0x90, 0x85, 0xC0,
+0xE0, 0xB4, 0x02, 0x05, 0xE4, 0x90, 0x92, 0x8A,
+0xF0, 0x91, 0x6D, 0xEF, 0x70, 0x04, 0x90, 0x92,
+0x8A, 0xF0, 0x90, 0x92, 0x8A, 0xE0, 0x60, 0x1D,
+0x90, 0x85, 0xC8, 0xE0, 0x20, 0xE2, 0x06, 0x7D,
+0x01, 0x7F, 0x04, 0x31, 0x8D, 0xF1, 0xBA, 0xE4,
+0x90, 0x91, 0x6E, 0xF0, 0x90, 0x85, 0xCD, 0xE0,
+0x90, 0x91, 0x6F, 0xB1, 0x7A, 0x22, 0x90, 0x85,
+0xBC, 0xE0, 0xFF, 0x30, 0xE0, 0x3C, 0x90, 0x85,
+0xC0, 0xE0, 0x7E, 0x00, 0xB4, 0x02, 0x02, 0x7E,
+0x01, 0x90, 0x85, 0xBF, 0xE0, 0x7D, 0x00, 0xB4,
+0x04, 0x02, 0x7D, 0x01, 0xED, 0x4E, 0x70, 0x22,
+0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x02, 0x80, 0x1B,
+0xB1, 0x10, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x08,
+0x06, 0xE4, 0xFD, 0x7F, 0x0C, 0x80, 0x09, 0x90,
+0x85, 0xC0, 0xE0, 0x70, 0x05, 0xFD, 0x7F, 0x04,
+0x31, 0x8D, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x91, 0x6D, 0xBF, 0x01, 0x04, 0x7F,
+0x01, 0x80, 0x02, 0x7F, 0x02, 0x71, 0x3A, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x85, 0xBC, 0xE0,
+0x30, 0xE0, 0x10, 0xA3, 0x74, 0x01, 0xF0, 0x90,
+0x85, 0xBC, 0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0,
+0x02, 0xD1, 0x2B, 0x91, 0x79, 0xE4, 0xFF, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94,
+0xA6, 0xE0, 0xFE, 0x13, 0x13, 0x54, 0x3F, 0x30,
+0xE0, 0x1F, 0x90, 0x96, 0x3A, 0x74, 0x1E, 0xF0,
+0x90, 0x96, 0x48, 0x74, 0x01, 0xF0, 0x90, 0x96,
+0x3C, 0xEF, 0xF0, 0x7B, 0x01, 0x7A, 0x96, 0x79,
+0x3A, 0x12, 0x5E, 0x10, 0x7F, 0x04, 0x12, 0xBE,
+0xE9, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xB1, 0x85,
+0x7D, 0x02, 0x7F, 0x02, 0x12, 0x7C, 0xA9, 0x7F,
+0x01, 0xD1, 0x5F, 0x90, 0x94, 0x66, 0xE0, 0x30,
+0xE0, 0x14, 0xF1, 0xCB, 0x90, 0x94, 0x69, 0xE0,
+0x60, 0x05, 0x14, 0xF0, 0x02, 0x7A, 0x8A, 0x12,
+0xB0, 0x1D, 0xE4, 0xFF, 0xF1, 0x06, 0x22, 0x90,
+0x85, 0xBC, 0xE0, 0xFF, 0x30, 0xE0, 0x3E, 0x90,
+0x85, 0xC0, 0xE0, 0x7E, 0x00, 0xB4, 0x02, 0x02,
+0x7E, 0x01, 0x90, 0x85, 0xBF, 0xE0, 0x7D, 0x00,
+0xB4, 0x04, 0x02, 0x7D, 0x01, 0xED, 0x4E, 0x70,
+0x24, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x02, 0xC1,
+0x2B, 0x12, 0xBF, 0x25, 0x90, 0x85, 0xC0, 0xE0,
+0xB4, 0x0C, 0x06, 0xE4, 0xFD, 0x7F, 0x08, 0x80,
+0x0A, 0x90, 0x85, 0xC0, 0xE0, 0xB4, 0x04, 0x05,
+0xE4, 0xFD, 0xFF, 0x31, 0x8D, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xEF, 0x64, 0x01,
+0x70, 0x1A, 0xF1, 0x59, 0x60, 0x09, 0xF1, 0x52,
+0x12, 0x7B, 0xFD, 0xF1, 0xCB, 0x80, 0x08, 0xF1,
+0x52, 0x12, 0x7B, 0xBF, 0x12, 0xCF, 0x94, 0x12,
+0x7A, 0x8A, 0x80, 0x1D, 0xF1, 0x59, 0x60, 0x07,
+0xF1, 0x52, 0x12, 0x7B, 0xFD, 0x80, 0x05, 0xF1,
+0x52, 0x12, 0x7B, 0xBF, 0x7D, 0x02, 0x7F, 0x02,
+0x12, 0x7C, 0xA9, 0x12, 0xDF, 0x90, 0x12, 0x7A,
+0xB9, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90,
+0x01, 0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F, 0x03,
+0x22, 0x90, 0x94, 0x68, 0xE0, 0x90, 0x01, 0x3F,
+0x22, 0x90, 0x85, 0xBF, 0x74, 0x01, 0xF0, 0x22,
+0x12, 0x90, 0xE5, 0x80, 0xF4, 0x12, 0xCC, 0xBF,
+0x80, 0xEF, 0xE4, 0xFD, 0xFF, 0x12, 0xDE, 0x6F,
+0x80, 0xE7, 0xF1, 0x61, 0x7D, 0x1F, 0x12, 0xCA,
+0x1A, 0xF0, 0x22, 0xF1, 0x61, 0x02, 0x97, 0xE4,
+0xF1, 0x61, 0x7D, 0x21, 0x7F, 0xFF, 0x12, 0x90,
+0xEB, 0x90, 0x85, 0xBF, 0x74, 0x03, 0xF0, 0x22,
+0xF1, 0x72, 0x90, 0x05, 0x27, 0xE0, 0x54, 0xBF,
+0xF0, 0xE4, 0x90, 0x85, 0xBF, 0xF0, 0x22, 0xF1,
+0x68, 0x80, 0xEF, 0xF1, 0x6D, 0x80, 0xEB, 0x12,
+0xBB, 0x52, 0x80, 0xDD, 0xE0, 0xFF, 0x7D, 0x01,
+0x21, 0x8D, 0x90, 0x85, 0xC9, 0xE0, 0x44, 0x10,
+0xF0, 0x22, 0xE4, 0xFF, 0x12, 0x77, 0x39, 0xEF,
+0x64, 0x01, 0x22, 0x90, 0x94, 0x68, 0xE0, 0x90,
+0x05, 0x73, 0xF0, 0x22, 0x7D, 0x22, 0x7F, 0xFF,
+0x12, 0xDE, 0x6F, 0x80, 0xB4, 0x02, 0x97, 0xEA,
+0x90, 0x86, 0x72, 0xE0, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x22, 0x12, 0x02, 0xF6, 0x90, 0x86, 0x71,
+0xF0, 0x22, 0x12, 0xB0, 0x2D, 0x90, 0x94, 0x66,
+0x12, 0x9F, 0xAF, 0xEF, 0x54, 0x02, 0xFF, 0xEE,
+0x54, 0xFD, 0x4F, 0xF0, 0x12, 0x87, 0x20, 0x90,
+0x94, 0x67, 0x12, 0x87, 0xE1, 0x90, 0x94, 0x68,
+0xF0, 0x11, 0x1D, 0x90, 0x94, 0x66, 0xE0, 0x54,
+0x01, 0xFF, 0x02, 0xAF, 0x06, 0x90, 0x94, 0x67,
+0xE0, 0x14, 0x90, 0x94, 0x69, 0xF0, 0x22, 0x90,
+0x92, 0x05, 0x12, 0x86, 0x6C, 0x12, 0x02, 0xF6,
+0xFF, 0x54, 0x01, 0xFE, 0x22, 0x12, 0x02, 0xF6,
+0xFF, 0x90, 0x94, 0x99, 0xF0, 0xBF, 0x01, 0x09,
+0x7F, 0x01, 0x11, 0x4A, 0xE4, 0x90, 0x94, 0x99,
+0xF0, 0x22, 0x90, 0x95, 0xCB, 0xEF, 0xF0, 0x51,
+0x9B, 0x7F, 0xF4, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0xEA, 0xE0, 0x90,
+0x95, 0xEC, 0xF0, 0x51, 0x9B, 0x7F, 0xF5, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x95, 0xEA, 0xE0, 0x90, 0x95, 0xED, 0xF0, 0x51,
+0x9B, 0x7F, 0xF6, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0xEA, 0xE0, 0x90,
+0x95, 0xEE, 0xF0, 0x51, 0x9B, 0x7F, 0xF7, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x95, 0xEA, 0xE0, 0x90, 0x95, 0xEF, 0xF0, 0x51,
+0x9B, 0x7F, 0xF8, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0xEA, 0xE0, 0x90,
+0x95, 0xF0, 0xF0, 0x51, 0x9B, 0x71, 0xFE, 0xBF,
+0x01, 0x08, 0x90, 0x95, 0xEA, 0xE0, 0x90, 0x95,
+0xF1, 0xF0, 0x51, 0x9B, 0x51, 0xA2, 0x64, 0x01,
+0x70, 0x54, 0x90, 0x95, 0xEA, 0xE0, 0x90, 0x95,
+0xF2, 0xF0, 0x54, 0x07, 0x60, 0x08, 0x90, 0x95,
+0xEA, 0xE0, 0x54, 0xE0, 0x70, 0x40, 0x7B, 0x01,
+0x7A, 0x95, 0x79, 0xEB, 0x7F, 0xFA, 0x51, 0xA4,
+0x64, 0x01, 0x70, 0x32, 0x90, 0x95, 0xEA, 0xE0,
+0xFC, 0x54, 0x07, 0x70, 0x12, 0x90, 0x95, 0xF2,
+0xE0, 0xFE, 0x90, 0x95, 0xEB, 0xE0, 0x54, 0x07,
+0xFD, 0xEE, 0x4D, 0x90, 0x95, 0xF2, 0xF0, 0xEC,
+0x54, 0xE0, 0x70, 0x12, 0x90, 0x95, 0xF2, 0xE0,
+0xFF, 0x90, 0x95, 0xEB, 0xE0, 0x54, 0xE0, 0xFE,
+0xEF, 0x4E, 0x90, 0x95, 0xF2, 0xF0, 0x51, 0x9B,
+0x7F, 0xFD, 0x51, 0xA4, 0x64, 0x01, 0x70, 0x4B,
+0x90, 0x95, 0xEA, 0xE0, 0xFE, 0x54, 0xCC, 0x90,
+0x95, 0xF3, 0xF0, 0xEE, 0x54, 0x0C, 0xFF, 0x60,
+0x08, 0x90, 0x95, 0xEA, 0xE0, 0x54, 0xC0, 0x70,
+0x32, 0xEF, 0x70, 0x16, 0x90, 0x95, 0xF3, 0xE0,
+0xFF, 0x90, 0x95, 0xEA, 0xE0, 0x54, 0x03, 0x25,
+0xE0, 0x25, 0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x95,
+0xF3, 0xF0, 0x90, 0x95, 0xEA, 0xE0, 0xFF, 0x54,
+0xC0, 0x70, 0x10, 0x90, 0x95, 0xF3, 0xE0, 0xFE,
+0xEF, 0x54, 0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF,
+0xEE, 0x4F, 0xF0, 0x51, 0x9B, 0x7F, 0xF0, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x95, 0xEA, 0xE0, 0x90, 0x95, 0xF4, 0xF0, 0x51,
+0x9B, 0x7F, 0xF1, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0xEA, 0xE0, 0x90,
+0x95, 0xF5, 0xF0, 0x51, 0x9B, 0x7F, 0xF2, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x95, 0xEA, 0xE0, 0x90, 0x95, 0xF6, 0xF0, 0x51,
+0x9B, 0x7F, 0xF3, 0x7E, 0x00, 0x12, 0x64, 0x37,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0xEA, 0xE0, 0x90,
+0x95, 0xF7, 0xF0, 0x51, 0x9B, 0x7F, 0xFC, 0x7E,
+0x00, 0x12, 0x64, 0x37, 0xBF, 0x01, 0x08, 0x90,
+0x95, 0xEA, 0xE0, 0x90, 0x95, 0xF8, 0xF0, 0x90,
+0x95, 0xCC, 0x74, 0x19, 0xF0, 0x90, 0x95, 0xDA,
+0x74, 0x08, 0xF0, 0x90, 0x95, 0xEC, 0xE0, 0x90,
+0x95, 0xCE, 0xF0, 0x90, 0x95, 0xED, 0xE0, 0x90,
+0x95, 0xCF, 0xF0, 0x90, 0x95, 0xEE, 0xE0, 0x90,
+0x95, 0xD0, 0xF0, 0x90, 0x95, 0xEF, 0xE0, 0x90,
+0x95, 0xD1, 0xF0, 0x90, 0x95, 0xF0, 0xE0, 0x90,
+0x95, 0xD2, 0xF0, 0x90, 0x95, 0xF1, 0xE0, 0x90,
+0x95, 0xD3, 0xF0, 0x90, 0x95, 0xF2, 0xE0, 0x90,
+0x95, 0xD4, 0xF0, 0x90, 0x95, 0xF3, 0xE0, 0x90,
+0x95, 0xD5, 0xF0, 0x90, 0x95, 0xDB, 0x74, 0x1A,
+0xF0, 0x90, 0x95, 0xE9, 0x74, 0x05, 0xF0, 0x90,
+0x95, 0xF4, 0xE0, 0x90, 0x95, 0xDD, 0xF0, 0x90,
+0x95, 0xF5, 0xE0, 0x90, 0x95, 0xDE, 0xF0, 0x90,
+0x95, 0xF6, 0xE0, 0x90, 0x95, 0xDF, 0xF0, 0x90,
+0x95, 0xF7, 0xE0, 0x90, 0x95, 0xE0, 0xF0, 0x90,
+0x95, 0xF8, 0xE0, 0x90, 0x95, 0xE1, 0xF0, 0x90,
+0x95, 0xCB, 0xE0, 0xB4, 0x01, 0x17, 0x7B, 0x01,
+0x7A, 0x95, 0x79, 0xCC, 0x12, 0x5E, 0x10, 0x7B,
+0x01, 0x7A, 0x95, 0x79, 0xDB, 0x12, 0x5E, 0x10,
+0x7F, 0x04, 0x02, 0x86, 0xB4, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x95, 0x75, 0x1D, 0xCC, 0x75, 0x1E,
+0x0A, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xA0, 0xF1,
+0xC4, 0x75, 0x1C, 0x95, 0x75, 0x1D, 0xDD, 0x75,
+0x1E, 0x05, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xAA,
+0x02, 0x6A, 0x21, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0xEA, 0x22, 0x7F, 0xFB, 0x7E, 0x00, 0x12, 0x64,
+0x37, 0xEF, 0x22, 0x7E, 0x00, 0x7F, 0x0B, 0x7D,
+0x00, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x9A, 0x12,
+0x06, 0xDE, 0x71, 0x34, 0x71, 0xFE, 0xBF, 0x01,
+0x1C, 0x90, 0x92, 0x35, 0xE0, 0xFE, 0x54, 0x01,
+0x90, 0x94, 0x9A, 0xF0, 0xEE, 0x54, 0x04, 0x90,
+0x94, 0x9C, 0xF0, 0x90, 0x92, 0x35, 0xE0, 0x54,
+0x08, 0x90, 0x94, 0x9B, 0xF0, 0x71, 0x34, 0x51,
+0xA2, 0x64, 0x01, 0x70, 0x34, 0x90, 0x92, 0x35,
+0xE0, 0x54, 0x07, 0x70, 0x14, 0x7B, 0x01, 0x7A,
+0x92, 0x79, 0x36, 0x7F, 0xFA, 0xFE, 0x12, 0x64,
+0x37, 0xBF, 0x01, 0x0F, 0x90, 0x92, 0x36, 0x80,
+0x03, 0x90, 0x92, 0x35, 0xE0, 0x54, 0x07, 0x90,
+0x94, 0x9E, 0xF0, 0x90, 0x92, 0x35, 0xE0, 0x54,
+0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90, 0x94, 0x9D,
+0xF0, 0x71, 0x34, 0x7F, 0xFD, 0x7E, 0x00, 0x12,
+0x64, 0x37, 0xBF, 0x01, 0x0E, 0x90, 0x92, 0x35,
+0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F, 0x90,
+0x94, 0x9F, 0xF0, 0x22, 0x7B, 0x01, 0x7A, 0x92,
+0x79, 0x35, 0x22, 0x71, 0x34, 0x7F, 0xF9, 0x51,
+0xA4, 0x64, 0x01, 0x70, 0x3F, 0x90, 0x92, 0x35,
+0xE0, 0x54, 0xF0, 0x70, 0x0D, 0x71, 0x34, 0x7F,
+0xFC, 0xFE, 0x12, 0x64, 0x37, 0xEF, 0x70, 0x02,
+0xFF, 0x22, 0x90, 0x92, 0x35, 0xE0, 0x54, 0xF0,
+0xC4, 0x54, 0x0F, 0xF0, 0xE0, 0x24, 0xFA, 0x60,
+0x03, 0x04, 0x70, 0x08, 0x90, 0x92, 0x36, 0x74,
+0x01, 0xF0, 0x80, 0x05, 0xE4, 0x90, 0x92, 0x36,
+0xF0, 0x90, 0x92, 0x36, 0xE0, 0x7F, 0x00, 0x70,
+0x02, 0x7F, 0x01, 0x22, 0x7F, 0x00, 0x22, 0x90,
+0x00, 0x80, 0xE0, 0x44, 0x80, 0xFD, 0x7F, 0x80,
+0x12, 0x7B, 0x3E, 0x12, 0xBF, 0xD8, 0x12, 0xC8,
+0x5F, 0x12, 0x7B, 0x9C, 0xD1, 0x14, 0x91, 0x05,
+0x7F, 0x01, 0x12, 0x84, 0x15, 0x90, 0x94, 0x6A,
+0x74, 0x02, 0xF0, 0xFF, 0x12, 0x84, 0x15, 0x90,
+0x94, 0x6A, 0xE0, 0x04, 0xF0, 0xD1, 0x3A, 0xB1,
+0xA1, 0x90, 0x01, 0xCC, 0x74, 0x0F, 0xF0, 0x71,
+0x3B, 0xEF, 0x70, 0x02, 0xB1, 0xDB, 0x90, 0x00,
+0x80, 0xE0, 0x44, 0x40, 0xFD, 0x7F, 0x80, 0x12,
+0x7B, 0x3E, 0x75, 0x20, 0xFF, 0x12, 0x7C, 0xCD,
+0x53, 0xA8, 0xFE, 0x90, 0x01, 0xA0, 0xE0, 0xB4,
+0xFD, 0x04, 0xE4, 0xFF, 0x11, 0x4A, 0xD1, 0xA7,
+0x90, 0x00, 0x81, 0xE0, 0x44, 0x04, 0xFD, 0x7F,
+0x81, 0x12, 0x7B, 0x3E, 0x12, 0xB8, 0xE9, 0x51,
+0xAB, 0xE4, 0xFF, 0x02, 0x84, 0x9E, 0x7F, 0xF9,
+0x7E, 0x00, 0x02, 0x64, 0x37, 0xE4, 0x90, 0x84,
+0xC1, 0x91, 0x12, 0xF0, 0x90, 0x94, 0x63, 0xF0,
+0x22, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3,
+0x22, 0x12, 0xD0, 0x5D, 0xE4, 0x90, 0x88, 0xD8,
+0x91, 0x12, 0xF0, 0x90, 0x88, 0x76, 0xF0, 0x91,
+0x11, 0xF0, 0x91, 0x11, 0xF0, 0xA3, 0xF0, 0x90,
+0x88, 0x88, 0xF0, 0xA3, 0xF0, 0x90, 0x88, 0xCA,
+0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x93, 0xA9, 0xEF,
+0xF0, 0xA3, 0xED, 0xF0, 0xA3, 0x12, 0x86, 0x75,
+0x91, 0xE2, 0x8B, 0x1B, 0x8A, 0x1C, 0x91, 0xCB,
+0x24, 0x02, 0x91, 0xB6, 0x91, 0xE2, 0xE9, 0x24,
+0x04, 0x91, 0xC4, 0x24, 0x03, 0x91, 0xB6, 0x91,
+0xE2, 0xE9, 0x24, 0x08, 0x91, 0xC4, 0x24, 0x04,
+0x91, 0xB6, 0x91, 0xE2, 0xE9, 0x24, 0x0C, 0x91,
+0xC4, 0x24, 0x05, 0x91, 0xB6, 0x90, 0x93, 0xAA,
+0xE0, 0xFD, 0xB4, 0x02, 0x08, 0x90, 0x93, 0xA9,
+0xE0, 0x44, 0x48, 0x80, 0x0A, 0xED, 0xB4, 0x04,
+0x0A, 0x90, 0x93, 0xA9, 0xE0, 0x44, 0x50, 0x90,
+0x93, 0xAF, 0xF0, 0x90, 0x93, 0xB0, 0x74, 0x80,
+0xF0, 0xA3, 0x74, 0xFF, 0xF0, 0xA3, 0xF0, 0x91,
+0xD9, 0x91, 0xB6, 0x90, 0x93, 0xAF, 0x74, 0xFF,
+0x91, 0x12, 0xF0, 0x91, 0xD9, 0x04, 0x91, 0xB6,
+0x90, 0x06, 0x72, 0xE4, 0xF0, 0x22, 0xFF, 0x90,
+0x93, 0xAE, 0xF0, 0x7B, 0x01, 0x7A, 0x93, 0x79,
+0xAF, 0x02, 0x67, 0x8D, 0xF9, 0xE4, 0x3A, 0x8B,
+0x1B, 0xF5, 0x1C, 0x89, 0x1D, 0x75, 0x1E, 0x04,
+0x7B, 0x01, 0x7A, 0x93, 0x79, 0xAF, 0x12, 0x6A,
+0x21, 0x90, 0x93, 0xA9, 0xE0, 0x75, 0xF0, 0x08,
+0xA4, 0x22, 0x90, 0x93, 0xAB, 0x02, 0x86, 0x6C,
+0x7E, 0x00, 0x7F, 0x24, 0x7D, 0x00, 0x7B, 0x01,
+0x7A, 0x86, 0x79, 0x72, 0x12, 0x06, 0xDE, 0x90,
+0x06, 0x90, 0xE0, 0x54, 0xDF, 0xF0, 0x12, 0xD4,
+0xF3, 0x91, 0x19, 0x90, 0x84, 0xC5, 0xE0, 0xFF,
+0x64, 0x02, 0x70, 0x2D, 0x90, 0xFD, 0x80, 0xE0,
+0x7E, 0x00, 0x30, 0xE0, 0x02, 0x7E, 0x01, 0x90,
+0x86, 0x90, 0xB1, 0x9A, 0x7E, 0x00, 0x30, 0xE1,
+0x02, 0x7E, 0x01, 0x90, 0x86, 0x8E, 0xB1, 0x9A,
+0x7E, 0x00, 0x30, 0xE2, 0x02, 0x7E, 0x01, 0x90,
+0x86, 0x8F, 0xB1, 0x9A, 0x90, 0x02, 0xFB, 0xF0,
+0x22, 0xEF, 0x64, 0x01, 0x70, 0x21, 0xB1, 0x93,
+0x30, 0xE0, 0x02, 0x7F, 0x01, 0x90, 0x86, 0x90,
+0xEF, 0xF0, 0xB1, 0x93, 0x30, 0xE1, 0x02, 0x7F,
+0x01, 0x90, 0x86, 0x8E, 0xEF, 0xF0, 0xB1, 0x93,
+0x30, 0xE2, 0x02, 0x7F, 0x01, 0x80, 0x27, 0x90,
+0x84, 0xC5, 0xE0, 0x64, 0x03, 0x70, 0x24, 0xB1,
+0x8C, 0x30, 0xE0, 0x02, 0x7F, 0x01, 0x90, 0x86,
+0x90, 0xEF, 0xF0, 0xB1, 0x8C, 0x30, 0xE1, 0x02,
+0x7F, 0x01, 0x90, 0x86, 0x8E, 0xEF, 0xF0, 0xB1,
+0x8C, 0x30, 0xE2, 0x02, 0x7F, 0x01, 0x90, 0x86,
+0x8F, 0xEF, 0xF0, 0x22, 0x90, 0xFD, 0x78, 0xE0,
+0x7F, 0x00, 0x22, 0x90, 0xFD, 0x70, 0xE0, 0x7F,
+0x00, 0x22, 0xEE, 0xF0, 0x90, 0xFD, 0x80, 0xE0,
+0x22, 0xF1, 0xBE, 0x12, 0x7B, 0xEF, 0xB1, 0xF7,
+0x12, 0xCA, 0x70, 0xB1, 0xD5, 0x91, 0xE8, 0x12,
+0x7B, 0x64, 0x12, 0x78, 0xB9, 0x12, 0xC8, 0x50,
+0x90, 0x89, 0x16, 0xE0, 0x54, 0x7F, 0xF0, 0x54,
+0xBF, 0xF0, 0x54, 0xDF, 0xF0, 0x54, 0xF0, 0xF0,
+0xE4, 0x90, 0x89, 0x18, 0xF0, 0x90, 0x89, 0x16,
+0xE0, 0x54, 0xEF, 0xF0, 0x22, 0x12, 0xCB, 0x42,
+0x02, 0x06, 0xDE, 0xE4, 0x90, 0x92, 0x35, 0xF0,
+0xC2, 0xAF, 0xF1, 0x7A, 0x90, 0x92, 0x35, 0xE0,
+0x64, 0x01, 0xF0, 0x24, 0xDB, 0x90, 0x01, 0xC4,
+0xF0, 0x74, 0xB5, 0xA3, 0xF0, 0x80, 0xEB, 0x7E,
+0x00, 0x7F, 0x01, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
+0x85, 0x79, 0xBC, 0x12, 0x06, 0xDE, 0x90, 0x85,
+0xBC, 0xE0, 0x54, 0xFD, 0xF0, 0xE4, 0x91, 0x11,
+0x74, 0x0C, 0xF0, 0x22, 0x90, 0x00, 0x00, 0xE0,
+0x54, 0xFB, 0xFD, 0xE4, 0xFF, 0x12, 0xBB, 0x87,
+0x44, 0x04, 0xFD, 0x7F, 0x01, 0x12, 0x7B, 0x3E,
+0x90, 0x01, 0x98, 0x74, 0x80, 0xF0, 0xA3, 0x74,
+0x88, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x80,
+0xF0, 0x22, 0x12, 0x7C, 0x4E, 0x90, 0x84, 0xC5,
+0xEF, 0xF0, 0xD1, 0x6E, 0x90, 0x01, 0x64, 0x74,
+0x01, 0xF0, 0x90, 0x04, 0x23, 0xE0, 0x44, 0x80,
+0xF0, 0x90, 0x00, 0x17, 0xE0, 0x54, 0xFC, 0x44,
+0x04, 0xFD, 0x7F, 0x17, 0x12, 0x7B, 0x3E, 0x90,
+0x00, 0x38, 0xE0, 0x44, 0x40, 0xFD, 0x7F, 0x38,
+0x12, 0x7B, 0x3E, 0x02, 0x68, 0xE2, 0x90, 0x00,
+0x08, 0xE0, 0x54, 0xEF, 0xF0, 0x12, 0x75, 0xB6,
+0x12, 0x75, 0x58, 0x12, 0xB8, 0xA3, 0x12, 0xB8,
+0xCA, 0xE4, 0xF5, 0x40, 0xF5, 0x41, 0xF5, 0x42,
+0x75, 0x43, 0x80, 0xAD, 0x40, 0x7F, 0x50, 0x12,
+0x7B, 0x3E, 0xAD, 0x41, 0x7F, 0x51, 0x12, 0x7B,
+0x3E, 0xAD, 0x42, 0x7F, 0x52, 0x12, 0x7B, 0x3E,
+0xAD, 0x43, 0x7F, 0x53, 0x02, 0x7B, 0x3E, 0xE4,
+0x90, 0x92, 0x35, 0xF0, 0xA3, 0xF0, 0x12, 0xC8,
+0x6C, 0xEF, 0x64, 0x01, 0x60, 0x3C, 0xC3, 0x90,
+0x92, 0x36, 0xE0, 0x94, 0x88, 0x90, 0x92, 0x35,
+0xE0, 0x94, 0x13, 0x40, 0x0F, 0x90, 0x01, 0xC1,
+0xE0, 0x44, 0x10, 0xF0, 0x90, 0x01, 0xC7, 0x74,
+0xFD, 0xF0, 0x80, 0x1E, 0x90, 0x92, 0x35, 0x12,
+0x97, 0xF4, 0xF1, 0xCB, 0xD3, 0x90, 0x92, 0x36,
+0xE0, 0x94, 0x32, 0x90, 0x92, 0x35, 0xE0, 0x94,
+0x00, 0x40, 0xC3, 0x90, 0x01, 0xC6, 0xE0, 0x30,
+0xE3, 0xBC, 0x90, 0x01, 0xC7, 0x74, 0xFE, 0xF0,
+0x22, 0xEF, 0x60, 0x51, 0x90, 0x88, 0xCE, 0xE0,
+0xFF, 0x60, 0x03, 0x12, 0xD2, 0xBE, 0x90, 0x01,
+0xC7, 0xE4, 0xF0, 0x90, 0x01, 0x17, 0xE0, 0xFE,
+0x90, 0x01, 0x16, 0x12, 0x9E, 0xEC, 0xEC, 0x3E,
+0x90, 0x85, 0xB7, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
+0x06, 0x09, 0xE0, 0x54, 0xFE, 0xF0, 0x7D, 0x35,
+0x7F, 0xFF, 0x12, 0x90, 0xEB, 0xF1, 0x7A, 0x90,
+0x02, 0x86, 0xE0, 0x44, 0x04, 0xF0, 0x12, 0x72,
+0x79, 0xF1, 0x69, 0x12, 0x90, 0xE5, 0x12, 0x76,
+0xE6, 0x90, 0x01, 0x34, 0x74, 0x08, 0xF0, 0xFD,
+0xE4, 0xFF, 0x02, 0x7C, 0xA9, 0x7D, 0x08, 0xE4,
+0xFF, 0x12, 0x7C, 0x41, 0x90, 0x06, 0x90, 0xE0,
+0x54, 0xF0, 0xF0, 0x90, 0x02, 0x86, 0xE0, 0x54,
+0xFB, 0xF0, 0x12, 0xD4, 0xAD, 0xF1, 0x6A, 0x81,
+0xE8, 0x22, 0x90, 0x86, 0x72, 0xE0, 0xFF, 0xC4,
+0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02, 0x91,
+0x19, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x12, 0x93, 0xE2, 0x90, 0x06, 0xB7, 0x74,
+0x11, 0xF0, 0x7F, 0x03, 0x7E, 0x00, 0x12, 0x7C,
+0x9F, 0x90, 0x06, 0xB4, 0xE0, 0x54, 0x0F, 0x70,
+0xF1, 0x7F, 0x02, 0x12, 0x7B, 0x51, 0xEF, 0x54,
+0xFE, 0xFD, 0x7F, 0x02, 0x12, 0x7B, 0x3E, 0x90,
+0x01, 0x00, 0x74, 0x3F, 0xF0, 0xA3, 0xE0, 0x54,
+0xFD, 0xF0, 0x90, 0x05, 0x53, 0xE0, 0x44, 0x20,
+0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4, 0xFD,
+0xFF, 0x02, 0x6E, 0x5F, 0x12, 0x6A, 0x21, 0x75,
+0x1B, 0x01, 0x22, 0x7F, 0x14, 0x7E, 0x00, 0x02,
+0x7C, 0x9F, 0x12, 0xDE, 0x72, 0x7D, 0x23, 0x02,
+0x97, 0xE6, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x12, 0xB8, 0x11, 0x30, 0xE6, 0x25, 0x90,
+0x00, 0x8C, 0xE0, 0x90, 0x96, 0x88, 0xF0, 0x7F,
+0x8D, 0x12, 0x7B, 0x51, 0x90, 0x96, 0x89, 0xEF,
+0xF0, 0x90, 0x00, 0x8E, 0xE0, 0x90, 0x96, 0x8A,
+0xF0, 0x90, 0x96, 0x89, 0xE0, 0x11, 0x11, 0x30,
+0xE0, 0x02, 0x11, 0x74, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x7F, 0x8F, 0x12, 0x7B, 0x51, 0xEF, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x96, 0x91, 0xEF, 0xF0, 0x11, 0x11, 0x30, 0xE6,
+0x46, 0x7F, 0x8D, 0x12, 0x7B, 0x51, 0xEF, 0x64,
+0x01, 0x70, 0x3C, 0x90, 0x96, 0x92, 0xF0, 0x90,
+0x96, 0x92, 0xE0, 0xFD, 0x90, 0x96, 0x91, 0xE0,
+0xC4, 0x54, 0xF0, 0x24, 0x00, 0xF5, 0x82, 0xE4,
+0x34, 0x81, 0xF5, 0x83, 0xE5, 0x82, 0x2D, 0xF5,
+0x82, 0xE4, 0x35, 0x83, 0xF5, 0x83, 0xE0, 0xFB,
+0xE4, 0xFF, 0x11, 0x7B, 0x90, 0x96, 0x92, 0xE0,
+0x04, 0xF0, 0xE0, 0xC3, 0x94, 0x10, 0x40, 0xCF,
+0x11, 0x11, 0x30, 0xE0, 0x02, 0x11, 0x74, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0xE4, 0xFD, 0x7F, 0x8D,
+0x02, 0x7B, 0x3E, 0xEF, 0x70, 0x04, 0x74, 0xF0,
+0x80, 0x16, 0xEF, 0xB4, 0x01, 0x04, 0x74, 0xF4,
+0x80, 0x0E, 0xEF, 0xB4, 0x02, 0x04, 0x74, 0xF8,
+0x80, 0x06, 0xEF, 0xB4, 0x03, 0x0C, 0x74, 0xFC,
+0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x02, 0xF5, 0x83,
+0xEB, 0xF0, 0x22, 0x75, 0x48, 0x10, 0xE4, 0xF5,
+0x49, 0x75, 0x4A, 0x07, 0x75, 0x4B, 0x02, 0xF5,
+0x50, 0x90, 0x01, 0x30, 0xE5, 0x48, 0xF0, 0xA3,
+0xE5, 0x49, 0xF0, 0xA3, 0xE5, 0x4A, 0xF0, 0xA3,
+0xE5, 0x4B, 0xF0, 0x90, 0x01, 0x20, 0xE5, 0x50,
+0xF0, 0x22, 0x75, 0x52, 0x06, 0x75, 0x53, 0x01,
+0x75, 0x54, 0x03, 0x75, 0x55, 0x62, 0x90, 0x01,
+0x38, 0xE5, 0x52, 0xF0, 0xA3, 0xE5, 0x53, 0xF0,
+0xA3, 0xE5, 0x54, 0xF0, 0xA3, 0xE5, 0x55, 0xF0,
+0x22, 0x90, 0x01, 0xE4, 0x74, 0x0E, 0xF0, 0xA3,
+0xE4, 0xF0, 0x22, 0x7D, 0x02, 0x90, 0x01, 0xC4,
+0x74, 0xF3, 0xF0, 0x74, 0xB8, 0xA3, 0xF0, 0x90,
+0x94, 0x6A, 0xE0, 0xFF, 0xED, 0xC3, 0x9F, 0x50,
+0x18, 0xED, 0x25, 0xE0, 0x24, 0x81, 0xF8, 0xE6,
+0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8, 0x74, 0x08,
+0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22, 0x0D, 0x80,
+0xDE, 0x7F, 0x01, 0x22, 0xE4, 0x90, 0x92, 0x37,
+0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x92, 0x37,
+0xE0, 0x64, 0x01, 0xF0, 0x90, 0x94, 0xA3, 0xE0,
+0x70, 0x18, 0x90, 0x94, 0xA0, 0xE0, 0x70, 0x12,
+0xA3, 0xE0, 0x70, 0x0E, 0x90, 0x92, 0x37, 0xE0,
+0x24, 0x24, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xB9,
+0xA3, 0xF0, 0x12, 0x7C, 0x66, 0xBF, 0x01, 0x03,
+0x12, 0x5B, 0x25, 0x90, 0x85, 0xC5, 0xE0, 0x60,
+0x0E, 0x90, 0x85, 0xC8, 0xE0, 0xFF, 0x90, 0x85,
+0xC7, 0xE0, 0x6F, 0x60, 0x02, 0x71, 0x9C, 0xC2,
+0xAF, 0x11, 0xF3, 0xBF, 0x01, 0x02, 0x31, 0x84,
+0xD2, 0xAF, 0x51, 0x96, 0x12, 0xB7, 0xDA, 0x12,
+0x83, 0x4D, 0x80, 0xA9, 0x90, 0x85, 0xC1, 0xE0,
+0x30, 0xE0, 0x18, 0x90, 0x85, 0xBC, 0xE0, 0xFF,
+0x30, 0xE0, 0x0E, 0xC3, 0x13, 0x30, 0xE0, 0x07,
+0x71, 0x8F, 0xBF, 0x01, 0x06, 0x80, 0x02, 0x80,
+0x00, 0x31, 0xA4, 0x22, 0x90, 0x85, 0xC8, 0xE0,
+0xFF, 0x60, 0x03, 0xB4, 0x08, 0x0E, 0x12, 0xCC,
+0x32, 0xBF, 0x01, 0x08, 0x31, 0xBD, 0x90, 0x01,
+0xE5, 0xE0, 0x04, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x31, 0xF1, 0x31, 0xCD,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0xC9, 0xF5,
+0x7F, 0x08, 0x12, 0x7B, 0x51, 0xEF, 0x54, 0xEF,
+0xFD, 0x7F, 0x08, 0x12, 0x7B, 0x3E, 0xE4, 0xFF,
+0x51, 0x43, 0x7D, 0x35, 0x7F, 0x27, 0x12, 0x7B,
+0x3E, 0x90, 0x85, 0xC2, 0xE0, 0x54, 0xEF, 0xF0,
+0x22, 0x90, 0x85, 0xC2, 0xE0, 0x44, 0x10, 0xF0,
+0x90, 0x85, 0xD0, 0xE0, 0xFD, 0x7F, 0x93, 0x12,
+0x7B, 0x3E, 0x90, 0x85, 0xC6, 0xE0, 0x60, 0x12,
+0x90, 0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74,
+0x10, 0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F, 0x74,
+0x90, 0xF0, 0x7F, 0x08, 0x12, 0x7B, 0x51, 0xEF,
+0x44, 0x10, 0xFD, 0x7F, 0x08, 0x12, 0x7B, 0x3E,
+0x7F, 0x01, 0x51, 0x43, 0x7D, 0x34, 0x7F, 0x27,
+0x12, 0x7B, 0x3E, 0x7F, 0x90, 0x71, 0x4A, 0x7F,
+0x90, 0x12, 0x7B, 0x3E, 0x7F, 0x14, 0x7E, 0x00,
+0x02, 0x7C, 0x9F, 0x90, 0x96, 0x8B, 0xEF, 0xF0,
+0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x01, 0x09,
+0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02, 0x7F, 0x01,
+0x90, 0x96, 0x8B, 0xE0, 0x6F, 0x60, 0x36, 0xC3,
+0x90, 0x96, 0x8D, 0xE0, 0x94, 0x88, 0x90, 0x96,
+0x8C, 0xE0, 0x94, 0x13, 0x40, 0x08, 0x90, 0x01,
+0xC0, 0xE0, 0x44, 0x10, 0xF0, 0x22, 0x90, 0x96,
+0x8C, 0x12, 0x97, 0xF4, 0x12, 0xB7, 0xCB, 0xD3,
+0x90, 0x96, 0x8D, 0xE0, 0x94, 0x32, 0x90, 0x96,
+0x8C, 0xE0, 0x94, 0x00, 0x40, 0xBF, 0x90, 0x01,
+0xC6, 0xE0, 0x30, 0xE0, 0xB8, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x94, 0xA0,
+0xE0, 0x60, 0x25, 0x7F, 0x54, 0x7E, 0x09, 0x12,
+0x70, 0x61, 0x71, 0x3E, 0xEF, 0x44, 0xFE, 0xFF,
+0xEE, 0x44, 0x03, 0xFE, 0xED, 0x44, 0x04, 0xFD,
+0xEC, 0x71, 0x3E, 0x90, 0x91, 0x66, 0x12, 0x04,
+0xEB, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x71, 0x18,
+0x90, 0x94, 0x9B, 0xE0, 0x70, 0x24, 0x90, 0x07,
+0xCC, 0xE0, 0x30, 0xE0, 0x1D, 0xE4, 0xF0, 0x90,
+0x92, 0x3E, 0x74, 0x22, 0xF0, 0x90, 0x92, 0x4C,
+0x74, 0x01, 0xF0, 0x90, 0x92, 0x40, 0x74, 0x03,
+0xF0, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x3E, 0x12,
+0x86, 0xAF, 0x90, 0x94, 0xA3, 0xE0, 0xFF, 0x70,
+0x0A, 0x90, 0x94, 0xA0, 0xE0, 0x70, 0x04, 0xA3,
+0xE0, 0x60, 0x15, 0x90, 0x00, 0x1F, 0xE0, 0x54,
+0xF0, 0xF0, 0x90, 0x01, 0xC5, 0x74, 0xEA, 0xF0,
+0xA3, 0x74, 0xEF, 0xF0, 0xA3, 0x74, 0xFD, 0xF0,
+0xEF, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x07,
+0xF0, 0x90, 0x94, 0xA0, 0xE0, 0x60, 0x06, 0x90,
+0x01, 0xC4, 0x74, 0x01, 0xF0, 0x90, 0x94, 0xA1,
+0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x02,
+0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x92,
+0x3A, 0x12, 0x04, 0xEB, 0x90, 0x92, 0x3A, 0x02,
+0x86, 0x54, 0x12, 0x7B, 0x51, 0xEF, 0x44, 0x01,
+0xFD, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x7F, 0x02, 0x71, 0x4A, 0x7F, 0x02, 0x71,
+0x87, 0x44, 0x02, 0x71, 0x7F, 0x90, 0x06, 0xB7,
+0x74, 0x09, 0xF0, 0x90, 0x06, 0xB4, 0x74, 0x86,
+0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x71, 0x52,
+0x7D, 0x24, 0x12, 0xCA, 0x1A, 0xF0, 0x22, 0xF0,
+0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x22, 0x12,
+0x7B, 0x3E, 0x90, 0x01, 0x01, 0xE0, 0x22, 0x90,
+0x85, 0xBF, 0xE0, 0x64, 0x02, 0x7F, 0x01, 0x60,
+0x02, 0x7F, 0x00, 0x22, 0x90, 0x85, 0xBC, 0xE0,
+0x90, 0x85, 0xC7, 0x30, 0xE0, 0x05, 0xE0, 0xFF,
+0x02, 0xAD, 0x30, 0x02, 0xAF, 0xB4, 0x90, 0x85,
+0xC5, 0xE0, 0x60, 0x0F, 0x90, 0x06, 0x92, 0xE0,
+0x30, 0xE1, 0x03, 0x02, 0x6B, 0x98, 0x12, 0xDF,
+0x9F, 0x71, 0x9C, 0x22, 0xE4, 0xFF, 0x12, 0x77,
+0x39, 0xBF, 0x01, 0x0F, 0x90, 0x85, 0xC5, 0xE0,
+0x60, 0x09, 0x71, 0xDC, 0xF0, 0x54, 0x07, 0x70,
+0x02, 0x71, 0x9C, 0x22, 0x90, 0x85, 0xC9, 0xE0,
+0x54, 0xFE, 0x22, 0xE4, 0xF5, 0x15, 0x90, 0x06,
+0xA9, 0xE0, 0xF5, 0x15, 0x54, 0xC0, 0x70, 0x08,
+0x71, 0xDC, 0xF0, 0x54, 0xFD, 0xF0, 0x80, 0xA4,
+0xE5, 0x15, 0x30, 0xE6, 0x1B, 0x90, 0x85, 0xC5,
+0xE0, 0x64, 0x01, 0x70, 0x16, 0x91, 0x9E, 0x12,
+0x8F, 0xD3, 0x64, 0x02, 0x60, 0x05, 0x12, 0x77,
+0x61, 0x80, 0x08, 0x12, 0xCC, 0x93, 0x80, 0x03,
+0x71, 0xDC, 0xF0, 0xE5, 0x15, 0x90, 0x85, 0xC9,
+0x30, 0xE7, 0x07, 0xB1, 0xE2, 0x12, 0xAD, 0x7A,
+0xA1, 0xDA, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90,
+0x06, 0xA9, 0xE0, 0x90, 0x92, 0x85, 0xF0, 0xE0,
+0xFD, 0x54, 0xC0, 0x70, 0x05, 0x71, 0xDC, 0xF0,
+0x80, 0x58, 0xED, 0x30, 0xE6, 0x3F, 0x90, 0x85,
+0xC5, 0xE0, 0x64, 0x02, 0x70, 0x24, 0x90, 0x85,
+0xC1, 0xE0, 0xFF, 0xC3, 0x13, 0x20, 0xE0, 0x05,
+0x91, 0x9E, 0xF0, 0x80, 0x1E, 0x12, 0x8F, 0xD4,
+0x64, 0x01, 0x70, 0x24, 0x90, 0x85, 0xC9, 0xE0,
+0x44, 0x04, 0xF0, 0x7F, 0x01, 0x12, 0x62, 0x8E,
+0x80, 0x16, 0x91, 0x9E, 0x12, 0x8F, 0xD3, 0x64,
+0x02, 0x60, 0x05, 0x12, 0x77, 0x61, 0x80, 0x08,
+0x12, 0x79, 0x41, 0x80, 0x03, 0x71, 0xDC, 0xF0,
+0x90, 0x92, 0x85, 0xE0, 0x90, 0x85, 0xC9, 0x30,
+0xE7, 0x07, 0xB1, 0xE2, 0x12, 0xAD, 0x7A, 0xA1,
+0xDA, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90, 0x85,
+0xC9, 0xE0, 0x44, 0x01, 0x22, 0xE4, 0x90, 0x92,
+0x84, 0xF0, 0x12, 0xAF, 0xC3, 0x60, 0x02, 0xA1,
+0xB5, 0x90, 0x85, 0xC5, 0xE0, 0x70, 0x02, 0xA1,
+0xB5, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x94, 0xAB,
+0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x94, 0xAC,
+0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x94, 0xAD,
+0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x94, 0xAE,
+0xF0, 0xD1, 0x0D, 0xF0, 0x90, 0x85, 0xC9, 0xE0,
+0x54, 0xEC, 0xF0, 0xB1, 0xD1, 0x24, 0xFD, 0x50,
+0x02, 0x80, 0x0D, 0x90, 0x85, 0xBC, 0xE0, 0x30,
+0xE0, 0x04, 0x91, 0x2F, 0x80, 0x02, 0x71, 0xE3,
+0xB1, 0xD1, 0x64, 0x01, 0x70, 0x3A, 0x90, 0x06,
+0xAB, 0xE0, 0x90, 0x85, 0xCC, 0xF0, 0x90, 0x06,
+0xA9, 0xE0, 0x30, 0xE5, 0x06, 0xA3, 0xE0, 0x90,
+0x92, 0x84, 0xF0, 0x90, 0x92, 0x84, 0xE0, 0xFF,
+0x60, 0x02, 0x80, 0x05, 0x90, 0x85, 0xCB, 0xE0,
+0xFF, 0x90, 0x85, 0xCB, 0xEF, 0xF0, 0xA3, 0xE0,
+0xFF, 0x70, 0x08, 0x90, 0x85, 0xCB, 0xE0, 0xFE,
+0xFF, 0x80, 0x00, 0x90, 0x85, 0xCC, 0xEF, 0xF0,
+0x12, 0xCD, 0x94, 0xE4, 0x90, 0x85, 0xCE, 0xF0,
+0xA3, 0xF0, 0x12, 0xCD, 0x8A, 0x12, 0xAC, 0x62,
+0x30, 0xE0, 0x68, 0xEF, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x20, 0xE0, 0x2A, 0xB1, 0xC9, 0x6F, 0x70,
+0x5A, 0xEF, 0x60, 0x57, 0x90, 0x85, 0xC2, 0xE0,
+0x44, 0x40, 0xF0, 0x12, 0xDF, 0x97, 0x12, 0xAF,
+0x4E, 0x12, 0x7B, 0xFD, 0x12, 0xCF, 0x9B, 0x7D,
+0x02, 0x7F, 0x02, 0x12, 0x7C, 0x41, 0x90, 0x85,
+0xCC, 0xE0, 0x14, 0xF0, 0x80, 0x35, 0x90, 0x85,
+0xC3, 0xE0, 0xC4, 0x54, 0x0F, 0x64, 0x01, 0x70,
+0x2A, 0xB1, 0xC9, 0xFE, 0x6F, 0x60, 0x24, 0x90,
+0x05, 0x73, 0xE0, 0xFF, 0xEE, 0x6F, 0x60, 0x1B,
+0x90, 0x85, 0xC2, 0xF1, 0xAC, 0x30, 0xE0, 0x13,
+0xEF, 0x54, 0xBF, 0x12, 0xAF, 0x4E, 0x12, 0x7B,
+0xBF, 0x12, 0xDF, 0x90, 0x7D, 0x02, 0x7F, 0x02,
+0x12, 0x7C, 0xA9, 0xB1, 0xC1, 0x90, 0x85, 0xBC,
+0xE0, 0xC3, 0x13, 0x20, 0xE0, 0x02, 0xB1, 0xC1,
+0x22, 0x90, 0x85, 0xC2, 0xE0, 0x44, 0x04, 0xF0,
+0x22, 0x90, 0x85, 0xCB, 0xE0, 0xFF, 0xA3, 0xE0,
+0x22, 0x90, 0x85, 0xC3, 0xE0, 0xFF, 0xC4, 0x54,
+0x0F, 0x22, 0x90, 0x85, 0xC1, 0xE0, 0x44, 0x04,
+0xF0, 0x22, 0xE0, 0x44, 0x02, 0xF0, 0xE4, 0x90,
+0x91, 0x6E, 0xF0, 0x90, 0x86, 0x6E, 0xE0, 0x90,
+0x91, 0x6F, 0x22, 0x12, 0xAF, 0xC2, 0x70, 0x14,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x0E, 0x90, 0x85,
+0xC9, 0xE0, 0x20, 0xE4, 0x07, 0xD1, 0x0D, 0xB1,
+0xE5, 0x12, 0xAD, 0x7A, 0x22, 0x90, 0x01, 0x57,
+0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x02, 0x22,
+0x12, 0xAF, 0xC2, 0x70, 0x1C, 0x90, 0x85, 0xC5,
+0xE0, 0x60, 0x16, 0x90, 0x85, 0xC9, 0xE0, 0x20,
+0xE4, 0x0F, 0xD1, 0x0D, 0xF0, 0x90, 0x85, 0xC1,
+0xE0, 0xF1, 0xB4, 0x54, 0x07, 0x70, 0x02, 0x71,
+0x9C, 0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83,
+0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0,
+0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90,
+0x01, 0xC4, 0x74, 0x3A, 0xF0, 0x74, 0xBE, 0xA3,
+0xF0, 0x12, 0x71, 0x90, 0xE5, 0x4C, 0x30, 0xE3,
+0x02, 0xD1, 0xF8, 0xE5, 0x4C, 0x30, 0xE4, 0x02,
+0xD1, 0xE4, 0xE5, 0x4C, 0x30, 0xE5, 0x03, 0x12,
+0xC8, 0x95, 0xE5, 0x4C, 0x30, 0xE6, 0x03, 0x12,
+0xC7, 0xFE, 0xE5, 0x4E, 0x30, 0xE0, 0x03, 0x12,
+0xAE, 0x44, 0xE5, 0x4E, 0x30, 0xE1, 0x03, 0x12,
+0xC6, 0x4C, 0xE5, 0x4E, 0x30, 0xE2, 0x03, 0x12,
+0xC8, 0x0B, 0xE5, 0x4E, 0x30, 0xE3, 0x02, 0xB1,
+0xF3, 0xE5, 0x4E, 0x30, 0xE4, 0x02, 0xD1, 0x18,
+0xE5, 0x4E, 0x30, 0xE5, 0x03, 0x12, 0xC8, 0x34,
+0xE5, 0x4E, 0x30, 0xE6, 0x02, 0x71, 0xC4, 0xE5,
+0x4F, 0x30, 0xE1, 0x02, 0xF1, 0x04, 0x74, 0x3A,
+0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xBE, 0xA3,
+0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0,
+0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
+0xF0, 0xD0, 0xE0, 0x32, 0x12, 0x40, 0xB9, 0x7F,
+0x02, 0x8F, 0x16, 0x7F, 0x02, 0x12, 0x85, 0x27,
+0x90, 0x84, 0xC1, 0xE0, 0x45, 0x16, 0xF0, 0x22,
+0x90, 0x86, 0x72, 0xE0, 0x30, 0xE0, 0x04, 0x7F,
+0x10, 0xD1, 0xE9, 0x22, 0x90, 0x85, 0xC5, 0xE0,
+0x70, 0x07, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0,
+0x13, 0x90, 0x85, 0xBC, 0xE0, 0x30, 0xE0, 0x09,
+0x12, 0xAC, 0x6D, 0xBF, 0x01, 0x06, 0x02, 0xCA,
+0x56, 0x12, 0xCA, 0x35, 0x22, 0x90, 0x01, 0x57,
+0xE0, 0x60, 0x19, 0xD1, 0x10, 0xF0, 0xF1, 0xA9,
+0x30, 0xE0, 0x02, 0x80, 0x7E, 0xF1, 0xBF, 0x40,
+0x0B, 0xE4, 0xFF, 0x12, 0x77, 0x39, 0xBF, 0x01,
+0x03, 0xF1, 0x45, 0xF0, 0x22, 0x90, 0x85, 0xC2,
+0xE0, 0x54, 0xFB, 0x22, 0x12, 0xAC, 0x62, 0x30,
+0xE0, 0x10, 0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03,
+0x30, 0xE0, 0x07, 0x7D, 0x02, 0x7F, 0x02, 0x12,
+0x7C, 0x41, 0xF1, 0xA9, 0x30, 0xE0, 0x08, 0xF1,
+0xB3, 0x54, 0x07, 0x70, 0x3B, 0x80, 0x37, 0xF1,
+0xBF, 0x40, 0x33, 0x12, 0xAF, 0xC2, 0x70, 0x30,
+0x12, 0x8F, 0xD4, 0x70, 0x07, 0x12, 0x70, 0xDB,
+0xF1, 0x45, 0xF0, 0x22, 0x12, 0x70, 0xDB, 0x90,
+0x85, 0xCF, 0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94,
+0x02, 0x40, 0x0A, 0xF1, 0x45, 0xF0, 0xE4, 0x90,
+0x85, 0xCF, 0xF0, 0x80, 0x03, 0x12, 0xCC, 0x93,
+0xE4, 0x90, 0x85, 0xCE, 0xF0, 0x22, 0x71, 0x9C,
+0x22, 0x90, 0x85, 0xC1, 0xE0, 0xFF, 0x13, 0x13,
+0x54, 0x3F, 0x22, 0xEF, 0x54, 0xFB, 0xF0, 0x90,
+0x85, 0xC9, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90,
+0x85, 0xCE, 0xE0, 0x04, 0xF0, 0x90, 0x85, 0xC9,
+0xE0, 0x54, 0xEF, 0xF0, 0x90, 0x86, 0x6D, 0xE0,
+0xFF, 0x90, 0x85, 0xCE, 0xE0, 0xD3, 0x9F, 0x22,
+0x90, 0x84, 0xA1, 0x74, 0x02, 0xF0, 0xA3, 0x74,
+0x9A, 0xF0, 0xA3, 0x74, 0x26, 0xF0, 0x90, 0x84,
+0xA6, 0x74, 0x04, 0xF0, 0xA3, 0x74, 0x80, 0xF0,
+0xA3, 0x74, 0x03, 0xF0, 0x22, 0xE4, 0xFB, 0xFA,
+0xFD, 0x7F, 0x01, 0x12, 0x85, 0x4E, 0x90, 0x92,
+0x4D, 0xEF, 0xF0, 0x60, 0xF0, 0x90, 0x84, 0xC1,
+0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0, 0x60, 0xE5,
+0xC2, 0xAF, 0xEF, 0x30, 0xE1, 0x0A, 0x90, 0x84,
+0xC1, 0xE0, 0x54, 0xFD, 0xF0, 0x12, 0x60, 0x5D,
+0x11, 0x40, 0x30, 0xE2, 0x06, 0x54, 0xFB, 0xF0,
+0x12, 0x6A, 0x6D, 0x11, 0x40, 0x30, 0xE4, 0x0C,
+0x54, 0xEF, 0xF0, 0x12, 0x6F, 0x22, 0xBF, 0x01,
+0x03, 0x12, 0x9B, 0x41, 0xD2, 0xAF, 0x80, 0xC5,
+0xD2, 0xAF, 0xC2, 0xAF, 0x90, 0x84, 0xC1, 0xE0,
+0xFF, 0x22, 0x32, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x01, 0xC4, 0x74, 0x4B, 0xF0, 0x74, 0xC0,
+0xA3, 0xF0, 0x12, 0x6C, 0xBC, 0x74, 0x4B, 0x04,
+0x90, 0x01, 0xC4, 0xF0, 0x74, 0xC0, 0xA3, 0xF0,
+0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
+0xD0, 0xE0, 0x32, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x01, 0xC4, 0x74, 0x9B, 0xF0, 0x74, 0xC0,
+0xA3, 0xF0, 0x12, 0x75, 0x28, 0xE5, 0x56, 0x30,
+0xE1, 0x02, 0x31, 0x51, 0xE5, 0x56, 0x30, 0xE2,
+0x03, 0x12, 0xBB, 0xAE, 0xE5, 0x56, 0x30, 0xE5,
+0x02, 0x31, 0x3F, 0xE5, 0x57, 0x30, 0xE0, 0x02,
+0xB1, 0x12, 0xE5, 0x58, 0x30, 0xE1, 0x03, 0x12,
+0xAE, 0xBF, 0xE5, 0x58, 0x30, 0xE0, 0x03, 0x12,
+0xAD, 0xE6, 0xE5, 0x58, 0x30, 0xE4, 0x02, 0xF1,
+0x79, 0xE5, 0x59, 0x30, 0xE1, 0x05, 0x7F, 0x04,
+0x12, 0xBE, 0xE9, 0xE5, 0x59, 0x30, 0xE4, 0x03,
+0x12, 0xAE, 0x96, 0xE5, 0x59, 0x30, 0xE5, 0x02,
+0xB1, 0x53, 0xE5, 0x59, 0x30, 0xE6, 0x02, 0x91,
+0x96, 0x74, 0x9B, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xC0, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
+0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
+0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x90,
+0x94, 0x6B, 0xE0, 0x30, 0xE0, 0x0A, 0xF1, 0x7A,
+0xE4, 0x90, 0x94, 0x6E, 0xF0, 0x12, 0xAD, 0x4B,
+0x22, 0x90, 0x85, 0xC5, 0xE0, 0x60, 0x03, 0x12,
+0xBF, 0x4C, 0x90, 0x94, 0x6B, 0xE0, 0x30, 0xE0,
+0x51, 0x90, 0x94, 0x6E, 0xE0, 0x70, 0x25, 0x7B,
+0x16, 0x7D, 0x6F, 0x7F, 0xFF, 0x12, 0x8F, 0xB3,
+0x51, 0x73, 0x51, 0x7D, 0x7D, 0x01, 0x31, 0xB3,
+0x51, 0x73, 0x71, 0x85, 0xE0, 0x44, 0x01, 0xF0,
+0x71, 0x61, 0x12, 0xAD, 0x7A, 0x90, 0x94, 0x6E,
+0x74, 0x01, 0xF0, 0x22, 0x90, 0x94, 0x6E, 0xE0,
+0x64, 0x01, 0x70, 0x1C, 0x90, 0x94, 0x6C, 0x71,
+0x7F, 0xE0, 0x30, 0xE0, 0x13, 0x51, 0x7C, 0x7D,
+0x01, 0x31, 0xB3, 0x71, 0x61, 0xF0, 0xE4, 0xFB,
+0xFD, 0x7F, 0x54, 0x7E, 0x01, 0x02, 0x61, 0x41,
+0x51, 0x00, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x96, 0x6C, 0xF1, 0xC3, 0xA3,
+0xEB, 0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x2C,
+0x90, 0x05, 0x22, 0xE0, 0x90, 0x96, 0x72, 0xF0,
+0x7B, 0x14, 0x7D, 0xFF, 0xE4, 0xFF, 0x12, 0x8F,
+0xB3, 0xEF, 0x64, 0x01, 0x70, 0x04, 0x71, 0x2C,
+0x80, 0x04, 0x7F, 0x00, 0x80, 0x15, 0x90, 0x96,
+0x72, 0xE0, 0xFD, 0x7B, 0x15, 0xE4, 0xFF, 0x12,
+0x8F, 0xC1, 0x80, 0x02, 0x71, 0x2C, 0x12, 0x92,
+0xAE, 0x7F, 0x01, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0x90, 0x94, 0x6C, 0xE0, 0xFF, 0xC3, 0x13, 0xFE,
+0xEF, 0x54, 0xF1, 0xFF, 0xEE, 0x04, 0x54, 0x07,
+0x25, 0xE0, 0x4F, 0xF0, 0xA3, 0xE0, 0xFF, 0x71,
+0x6A, 0xB5, 0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0,
+0x12, 0xAD, 0x4B, 0xE4, 0x90, 0x94, 0x6E, 0xF0,
+0x12, 0x93, 0xE2, 0x71, 0x6A, 0x12, 0x8F, 0xFA,
+0xE0, 0xFA, 0xED, 0x12, 0x8C, 0xAB, 0xFC, 0x54,
+0x03, 0xFD, 0xEC, 0x13, 0x13, 0x54, 0x07, 0xFB,
+0xEE, 0x12, 0x87, 0xE8, 0xAF, 0x02, 0x12, 0x87,
+0x26, 0x51, 0x73, 0x12, 0x8C, 0xAB, 0xF1, 0xB5,
+0x12, 0x8D, 0xAD, 0x51, 0x73, 0xFF, 0x75, 0xF0,
+0x0E, 0xA4, 0x24, 0x7A, 0xF5, 0x82, 0xE4, 0x34,
+0x94, 0xF5, 0x83, 0xE0, 0x04, 0xF0, 0x51, 0x7C,
+0x12, 0x8F, 0xB8, 0x51, 0x73, 0xFD, 0x7F, 0x01,
+0x02, 0x8C, 0xEE, 0x90, 0x94, 0x6C, 0xE0, 0xC3,
+0x13, 0x54, 0x07, 0x22, 0xEF, 0x75, 0xF0, 0x0E,
+0xA4, 0x24, 0x7B, 0xF5, 0x82, 0xE4, 0x34, 0x94,
+0xF5, 0x83, 0xE0, 0xFF, 0x7E, 0x00, 0xE4, 0xFB,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x96, 0x7E, 0xED, 0xF0, 0xA3, 0xEB, 0xF0,
+0x90, 0x96, 0x7D, 0xEF, 0xF0, 0xE4, 0xFD, 0xFC,
+0xF1, 0x89, 0x90, 0x96, 0x7D, 0xE0, 0x90, 0x04,
+0x25, 0xF0, 0x90, 0x96, 0x7E, 0xE0, 0x60, 0x06,
+0x71, 0x74, 0xE0, 0x44, 0x80, 0xF0, 0xAF, 0x05,
+0x74, 0x20, 0x2F, 0xF1, 0xA2, 0x54, 0xC0, 0xF0,
+0x71, 0x74, 0xE0, 0x54, 0xC0, 0xF0, 0x90, 0x96,
+0x80, 0xE0, 0xFF, 0xAE, 0x05, 0x74, 0x18, 0x2E,
+0xF1, 0x91, 0xEF, 0xF0, 0x90, 0x00, 0x8B, 0xE0,
+0xD3, 0x94, 0x03, 0x74, 0x10, 0x2E, 0xF1, 0x81,
+0x74, 0x04, 0xF0, 0x74, 0x12, 0x2E, 0x71, 0xE5,
+0xE0, 0x20, 0xE1, 0x18, 0x54, 0x01, 0xFF, 0x90,
+0x96, 0x7F, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0xFB,
+0xEF, 0x44, 0x02, 0x4B, 0xFF, 0x74, 0x12, 0x2D,
+0x71, 0xE5, 0xEF, 0xF0, 0xAF, 0x05, 0x74, 0x11,
+0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0x74, 0xFF, 0xF0, 0x74, 0x29, 0x2F, 0xF1, 0x99,
+0x54, 0xF7, 0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x96, 0x6C, 0xA3,
+0xE0, 0xFF, 0x90, 0x96, 0x80, 0x74, 0x03, 0xF0,
+0x7B, 0x06, 0x7D, 0x01, 0x51, 0x91, 0x90, 0x96,
+0x70, 0xEE, 0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD,
+0x90, 0x96, 0x6F, 0xE0, 0xFF, 0x74, 0x10, 0x2D,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xEF,
+0xF0, 0x90, 0x96, 0x6E, 0xE0, 0xFF, 0x02, 0x65,
+0x61, 0xE4, 0x90, 0x91, 0x6E, 0xF0, 0xA3, 0x74,
+0x03, 0x22, 0x90, 0x94, 0x6C, 0xE0, 0xFE, 0xC3,
+0x13, 0x54, 0x07, 0x22, 0x74, 0x21, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0xE0,
+0xC3, 0x13, 0x54, 0x07, 0xFF, 0x75, 0xF0, 0x0E,
+0xA4, 0x24, 0x77, 0xF5, 0x82, 0xE4, 0x34, 0x94,
+0xF5, 0x83, 0x22, 0x90, 0x94, 0x6B, 0xE0, 0x30,
+0xE0, 0x1D, 0xA3, 0x71, 0x7F, 0xE0, 0xFE, 0x30,
+0xE0, 0x15, 0xEF, 0x71, 0x85, 0xEE, 0x54, 0xFE,
+0xF0, 0x90, 0x94, 0x6E, 0x74, 0x05, 0xF0, 0x51,
+0x73, 0xFD, 0x7F, 0x02, 0x12, 0x8C, 0xEE, 0x22,
+0x90, 0x92, 0x90, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0x12, 0x50, 0xD7, 0x90, 0x92, 0x90, 0xA3, 0xE0,
+0xFF, 0x24, 0x12, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0xE0, 0x54, 0x01, 0xFE, 0x90, 0x92,
+0x8F, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0x44, 0x02,
+0x4E, 0xFE, 0x74, 0x12, 0x2F, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x92, 0x8E, 0xEF,
+0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x84, 0xC3, 0xE0,
+0x04, 0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x37,
+0x90, 0x05, 0x22, 0xE0, 0x90, 0x92, 0x92, 0xF0,
+0x7D, 0x26, 0x12, 0x93, 0xDE, 0xEF, 0x64, 0x01,
+0x70, 0x17, 0x91, 0x74, 0x7D, 0x01, 0x12, 0x3A,
+0xC2, 0x91, 0x7F, 0x20, 0xE0, 0x0B, 0x90, 0x94,
+0x6B, 0xE0, 0x20, 0xE0, 0x04, 0x71, 0xB8, 0xEE,
+0xF0, 0x90, 0x92, 0x92, 0xE0, 0xFF, 0x7D, 0x27,
+0x12, 0x90, 0xEB, 0x91, 0x6C, 0x80, 0x1E, 0x91,
+0x6C, 0x91, 0x74, 0x90, 0x96, 0x80, 0x74, 0x0A,
+0xF0, 0x7D, 0x01, 0x51, 0x91, 0x91, 0x7F, 0x20,
+0xE0, 0x0B, 0x90, 0x94, 0x6B, 0xE0, 0x20, 0xE0,
+0x04, 0x71, 0xB8, 0xEE, 0xF0, 0x12, 0x92, 0xAE,
+0x12, 0xD7, 0x6D, 0x74, 0x01, 0xF0, 0xFF, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x92, 0x8E, 0xE0,
+0xFF, 0x02, 0x5C, 0xA3, 0x90, 0x84, 0xC8, 0xE0,
+0xFF, 0x90, 0x92, 0x8F, 0xE0, 0xFB, 0x22, 0x90,
+0x92, 0x90, 0xEE, 0xF0, 0xFC, 0xA3, 0xEF, 0xF0,
+0xFD, 0x90, 0x92, 0x8E, 0xE0, 0xFF, 0x12, 0x65,
+0x61, 0x90, 0x94, 0x6C, 0xE0, 0x22, 0x90, 0x85,
+0xC1, 0xE0, 0xFF, 0x12, 0x8F, 0xF3, 0x30, 0xE0,
+0x1F, 0xEF, 0x54, 0x7F, 0xB1, 0xA6, 0x30, 0xE1,
+0x06, 0xE0, 0x44, 0x02, 0xF0, 0x80, 0x08, 0xE0,
+0x54, 0xFD, 0xF0, 0xB1, 0xAF, 0x04, 0xF0, 0x90,
+0x85, 0xC5, 0xE0, 0x60, 0x03, 0x12, 0xBB, 0x9C,
+0x7F, 0x01, 0x12, 0x68, 0x8F, 0x90, 0x04, 0xE0,
+0xE0, 0x30, 0xE1, 0x02, 0x71, 0x93, 0x22, 0x90,
+0x88, 0xD1, 0xE0, 0xFF, 0x90, 0x96, 0x80, 0x74,
+0x08, 0xF0, 0x7B, 0x18, 0x7D, 0x01, 0x51, 0x91,
+0x90, 0x93, 0xCA, 0xEF, 0xF0, 0x90, 0x88, 0xD1,
+0xE0, 0x90, 0x04, 0x25, 0xF0, 0x22, 0x90, 0x96,
+0x73, 0xE0, 0xFF, 0x90, 0x96, 0x80, 0x74, 0x0C,
+0xF0, 0xE4, 0xFB, 0x7D, 0x01, 0x51, 0x91, 0x90,
+0x96, 0x76, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
+0x96, 0x74, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0x02,
+0x77, 0xD8, 0x12, 0xC9, 0xB0, 0x90, 0x92, 0x8A,
+0xEF, 0xF0, 0x20, 0xE0, 0x06, 0x90, 0x01, 0x3D,
+0x74, 0x01, 0xF0, 0x90, 0x92, 0x8A, 0xE0, 0x30,
+0xE0, 0x05, 0x7D, 0x01, 0xE4, 0x80, 0x02, 0xE4,
+0xFD, 0xFF, 0x12, 0x57, 0x82, 0x90, 0x92, 0x8A,
+0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01, 0x2F, 0xE0,
+0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80, 0x06, 0x90,
+0x01, 0x2F, 0x74, 0x80, 0xF0, 0xF1, 0x6C, 0xFB,
+0x02, 0x51, 0x7D, 0x90, 0x94, 0xE6, 0xE0, 0xB4,
+0x01, 0x20, 0xE4, 0xF0, 0x90, 0x01, 0x5B, 0xF0,
+0x90, 0x91, 0x6E, 0xF0, 0x90, 0x86, 0x6F, 0xE0,
+0xC3, 0x13, 0x54, 0x7F, 0x90, 0x91, 0x6F, 0xF0,
+0xE4, 0xFB, 0xFD, 0x7F, 0x58, 0x7E, 0x01, 0x12,
+0x61, 0x41, 0x90, 0x85, 0xC1, 0xE0, 0xFF, 0xC4,
+0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x1A, 0xEF,
+0x54, 0xBF, 0xB1, 0xA6, 0x30, 0xE0, 0x06, 0xE0,
+0x44, 0x01, 0xF0, 0x80, 0x09, 0xE0, 0x54, 0xFE,
+0xF0, 0xB1, 0xAF, 0x74, 0x04, 0xF0, 0x12, 0xBB,
+0x9C, 0xE4, 0xFF, 0x02, 0x68, 0x8F, 0xF0, 0x90,
+0x04, 0xE0, 0xE0, 0x90, 0x85, 0xC2, 0x22, 0x90,
+0x01, 0xB9, 0x74, 0x01, 0xF0, 0x90, 0x01, 0xB8,
+0x22, 0xE4, 0x90, 0x92, 0x87, 0xF0, 0xA3, 0xF0,
+0x90, 0x06, 0x32, 0xE0, 0x44, 0x20, 0xF0, 0x12,
+0x75, 0xE4, 0xEF, 0x64, 0x01, 0x70, 0x73, 0x90,
+0x88, 0xD9, 0xE0, 0xFF, 0x90, 0x96, 0x80, 0x74,
+0x0A, 0xF0, 0x7B, 0x08, 0x7D, 0x01, 0x51, 0x91,
+0x90, 0x92, 0x84, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
+0x90, 0x92, 0x84, 0x12, 0xDD, 0xFE, 0x90, 0x92,
+0x86, 0xEF, 0xF0, 0x90, 0x92, 0x84, 0xF1, 0xAB,
+0x7B, 0x01, 0xE4, 0xFD, 0x12, 0x52, 0x21, 0x90,
+0x92, 0x86, 0xE0, 0xFF, 0x90, 0x92, 0x85, 0xE0,
+0x2F, 0xFF, 0x90, 0x92, 0x84, 0xE0, 0x34, 0x00,
+0xCF, 0x24, 0x30, 0xCF, 0x34, 0x00, 0xFE, 0x90,
+0x92, 0x87, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0xDD,
+0xD0, 0xD1, 0x43, 0x90, 0x88, 0xD9, 0xE0, 0xFB,
+0xE4, 0xFF, 0x12, 0x15, 0x44, 0xD1, 0x43, 0x90,
+0x88, 0xD5, 0xE0, 0xFB, 0x7F, 0x11, 0x12, 0x15,
+0x44, 0x12, 0x92, 0xAE, 0x90, 0x88, 0x88, 0x12,
+0x97, 0xF4, 0x22, 0x90, 0x92, 0x87, 0xE0, 0xFC,
+0xA3, 0xE0, 0xFD, 0x22, 0x90, 0x85, 0xBC, 0xE0,
+0x30, 0xE0, 0x06, 0x90, 0x85, 0xBE, 0x74, 0x01,
+0xF0, 0x90, 0x85, 0xC5, 0xE0, 0x70, 0x02, 0xE1,
+0x06, 0x90, 0x85, 0xDC, 0xE0, 0x04, 0xF0, 0x90,
+0x05, 0x61, 0x12, 0x8F, 0xA2, 0x78, 0x08, 0x12,
+0x04, 0xD8, 0xA8, 0x04, 0xA9, 0x05, 0xAA, 0x06,
+0xAB, 0x07, 0x90, 0x05, 0x60, 0x12, 0x8F, 0xA2,
+0x12, 0x86, 0x47, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
+0x06, 0xC0, 0x07, 0x90, 0x05, 0x62, 0x12, 0x8F,
+0xA2, 0x78, 0x10, 0x12, 0x04, 0xD8, 0xD0, 0x03,
+0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86,
+0x47, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0xA3, 0x12, 0x8F, 0xA2, 0x78, 0x18, 0x12,
+0x04, 0xD8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
+0xD0, 0x00, 0x12, 0x86, 0x47, 0x90, 0x85, 0xFC,
+0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x94, 0xA6,
+0xE0, 0x54, 0xFE, 0xF0, 0xE0, 0xC3, 0x13, 0x30,
+0xE0, 0x0D, 0xF1, 0x6C, 0xFB, 0x12, 0x51, 0x7D,
+0x90, 0x94, 0xA6, 0xE0, 0x54, 0xFD, 0xF0, 0x12,
+0xAC, 0x62, 0x30, 0xE0, 0x0A, 0x90, 0x01, 0x3B,
+0xE0, 0x30, 0xE4, 0x03, 0x12, 0xCF, 0x94, 0x90,
+0x96, 0x96, 0xE0, 0x04, 0xF0, 0xE0, 0xC3, 0x94,
+0x80, 0x40, 0x0B, 0x90, 0x01, 0x98, 0xE0, 0x54,
+0xFE, 0xF0, 0xE0, 0x44, 0x01, 0xF0, 0x12, 0x5D,
+0x1F, 0x12, 0x6E, 0x1D, 0xE4, 0x90, 0x88, 0xE0,
+0xF0, 0x12, 0xCF, 0x83, 0x12, 0xAF, 0xE0, 0x30,
+0xE0, 0x51, 0x90, 0x88, 0x76, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x7C, 0x00, 0x7D, 0x64, 0x12, 0x03,
+0x82, 0x90, 0x88, 0xCA, 0xE0, 0x6E, 0x70, 0x03,
+0xA3, 0xE0, 0x6F, 0x60, 0x0A, 0x90, 0x88, 0xCA,
+0xE4, 0x75, 0xF0, 0x01, 0x02, 0x07, 0x0A, 0x90,
+0x88, 0x7A, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90,
+0x88, 0x88, 0xE0, 0xB5, 0x06, 0x14, 0xA3, 0xE0,
+0xB5, 0x07, 0x0F, 0xEF, 0x4E, 0x60, 0x0B, 0x90,
+0x01, 0xC7, 0x74, 0x31, 0xF0, 0x7F, 0x01, 0x02,
+0x5F, 0xE9, 0xB1, 0xB9, 0xE4, 0x90, 0x88, 0xCA,
+0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x85, 0xD7, 0xE0,
+0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x85, 0xDE, 0xE0,
+0x22, 0x22, 0x7D, 0x20, 0xE4, 0xFF, 0x02, 0x7B,
+0xBF, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0x22, 0x12, 0x7B, 0x2A, 0x7C, 0x00, 0xAD, 0x07,
+0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xE0, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0x22, 0xA3, 0xE0, 0x24, 0x28, 0xF9,
+0xE4, 0x34, 0xFC, 0xFA, 0x22, 0xFE, 0x54, 0x03,
+0xFF, 0xEE, 0x13, 0x13, 0x54, 0x07, 0xFD, 0x22,
+0x90, 0x92, 0x4E, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
+0xA3, 0xED, 0xF0, 0x22, 0x32, 0xC0, 0xE0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x05, 0xC0, 0x07, 0x7D, 0xCD, 0x90, 0x01,
+0xC4, 0xED, 0xF0, 0x74, 0xC7, 0xFF, 0xA3, 0xF0,
+0xED, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0xA3, 0xEF,
+0xF0, 0xD0, 0x07, 0xD0, 0x05, 0xD0, 0xD0, 0xD0,
+0x82, 0xD0, 0x83, 0xD0, 0xE0, 0x32, 0x90, 0x85,
+0xBC, 0xE0, 0x30, 0xE0, 0x05, 0xE4, 0xA3, 0xF0,
+0xA3, 0xF0, 0x22, 0x90, 0x88, 0xE7, 0xE0, 0x04,
+0xF0, 0x90, 0x85, 0xBC, 0xE0, 0xFF, 0x30, 0xE0,
+0x05, 0x12, 0xAD, 0x29, 0x60, 0x15, 0x90, 0x85,
+0xC5, 0xE0, 0x70, 0x04, 0xEF, 0x30, 0xE0, 0x0B,
+0x90, 0x85, 0xC8, 0xE0, 0x64, 0x02, 0x60, 0x03,
+0x12, 0xBC, 0xA5, 0x22, 0xE4, 0xFF, 0x12, 0x77,
+0x39, 0xBF, 0x01, 0x13, 0x90, 0x85, 0xC5, 0xE0,
+0x60, 0x0D, 0x12, 0x8F, 0xD4, 0x64, 0x02, 0x60,
+0x03, 0x02, 0x77, 0x61, 0x12, 0x79, 0x41, 0x22,
+0x7E, 0x00, 0x7F, 0x2E, 0x7D, 0x00, 0x7B, 0x01,
+0x7A, 0x94, 0x79, 0x6B, 0x02, 0x06, 0xDE, 0x90,
+0x01, 0x94, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x01,
+0xC7, 0xE4, 0xF0, 0x22, 0x90, 0x01, 0x98, 0xE4,
+0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x11, 0xF0, 0xA3,
+0xE4, 0xF0, 0x7F, 0x0A, 0xFE, 0x12, 0x7C, 0x9F,
+0x90, 0x01, 0x99, 0xE0, 0x54, 0x30, 0xFF, 0x64,
+0x10, 0x60, 0x04, 0xEF, 0xB4, 0x20, 0x03, 0x7F,
+0x01, 0x22, 0x7F, 0x00, 0x22, 0x90, 0x01, 0xCF,
+0xE0, 0x90, 0x92, 0x84, 0xF0, 0xE0, 0xFF, 0x30,
+0xE0, 0x07, 0x90, 0x01, 0xCF, 0xE0, 0x54, 0xFE,
+0xF0, 0xEF, 0x30, 0xE5, 0x23, 0x90, 0x01, 0xCF,
+0xE0, 0x54, 0xDF, 0xF0, 0x90, 0x01, 0x34, 0x74,
+0x20, 0xF0, 0xE4, 0xF5, 0xA8, 0xF5, 0xE8, 0x12,
+0x75, 0xB6, 0x90, 0x00, 0x03, 0xE0, 0x54, 0xFB,
+0xFD, 0x7F, 0x03, 0x12, 0x7B, 0x3E, 0x80, 0xFE,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x04, 0x1D, 0xE0, 0x60, 0x1A, 0x90, 0x05,
+0x22, 0xE0, 0x54, 0x90, 0x60, 0x07, 0x90, 0x01,
+0xC0, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x01, 0xC6,
+0xE0, 0x30, 0xE1, 0xE4, 0x7F, 0x00, 0x80, 0x02,
+0x7F, 0x01, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xC3,
+0xEE, 0x94, 0x01, 0x40, 0x0A, 0x0D, 0xED, 0x13,
+0x90, 0xFD, 0x10, 0xF0, 0xE4, 0x2F, 0xFF, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x96, 0x16, 0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x90,
+0x96, 0x15, 0xEF, 0xF0, 0xA3, 0xA3, 0xE0, 0xFD,
+0x12, 0x7B, 0xE0, 0x90, 0x96, 0x20, 0x12, 0x04,
+0xEB, 0x90, 0x96, 0x18, 0x12, 0x86, 0x54, 0x12,
+0x04, 0xA7, 0x90, 0x96, 0x20, 0x12, 0x8F, 0x7A,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x96, 0x18, 0x12, 0x86, 0x54, 0x90, 0x96,
+0x1C, 0x12, 0x8F, 0x7A, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x47, 0x90,
+0x96, 0x24, 0x12, 0x04, 0xEB, 0x90, 0x96, 0x16,
+0xA3, 0xE0, 0xFD, 0xC0, 0x05, 0x90, 0x96, 0x24,
+0x12, 0x86, 0x54, 0x90, 0x8D, 0x9D, 0x12, 0x04,
+0xEB, 0x90, 0x96, 0x15, 0xE0, 0xFF, 0xD0, 0x05,
+0x12, 0x78, 0xDD, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4,
+0xFE, 0xFD, 0xEF, 0xB4, 0x01, 0x0D, 0xEB, 0xB4,
+0x02, 0x03, 0x0D, 0x80, 0x06, 0xEB, 0xB4, 0x01,
+0x02, 0x7D, 0x02, 0xAF, 0x06, 0xEF, 0xC4, 0x54,
+0xF0, 0x4D, 0xFF, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0xE4, 0x90, 0x92, 0x8C, 0xF0, 0xA3, 0xF0, 0x7F,
+0x83, 0x12, 0x7B, 0x51, 0x90, 0x92, 0x8B, 0xEF,
+0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x51, 0xAE, 0x07,
+0x90, 0x92, 0x8B, 0xE0, 0xFF, 0xB5, 0x06, 0x01,
+0x22, 0xC3, 0x90, 0x92, 0x8D, 0xE0, 0x94, 0x64,
+0x90, 0x92, 0x8C, 0xE0, 0x94, 0x00, 0x40, 0x0D,
+0x90, 0x01, 0xC0, 0xE0, 0x44, 0x40, 0xF0, 0x90,
+0x92, 0x8B, 0xE0, 0xFF, 0x22, 0x90, 0x92, 0x8C,
+0x12, 0x97, 0xF4, 0x80, 0xC2, 0x90, 0x01, 0xC4,
+0x74, 0xF5, 0xF0, 0x74, 0xC9, 0xA3, 0xF0, 0x7F,
+0x90, 0x12, 0x7B, 0x51, 0xEF, 0x20, 0xE0, 0xF7,
+0x74, 0xF5, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74,
+0xC9, 0xA3, 0xF0, 0x22, 0x7D, 0x25, 0x51, 0x1A,
+0xF0, 0x22, 0x7F, 0x6F, 0x12, 0x90, 0xEB, 0x90,
+0x05, 0x27, 0xE0, 0x54, 0xBF, 0xF0, 0x90, 0x85,
+0xBF, 0x74, 0x04, 0x22, 0x12, 0x7A, 0x29, 0xEF,
+0x70, 0x02, 0x51, 0x35, 0x22, 0x90, 0x85, 0xC5,
+0xE0, 0x64, 0x01, 0x70, 0x18, 0x12, 0x8F, 0xD4,
+0x60, 0x06, 0x12, 0xA9, 0x89, 0x02, 0x6B, 0x98,
+0x90, 0x85, 0xC8, 0xE0, 0x70, 0x07, 0x7D, 0x01,
+0x7F, 0x04, 0x12, 0xA9, 0x8D, 0x22, 0x90, 0x85,
+0xC5, 0xE0, 0x64, 0x02, 0x60, 0x11, 0x12, 0x8F,
+0xD4, 0x60, 0x0C, 0x12, 0x7A, 0x29, 0xEF, 0x70,
+0x06, 0xFD, 0x7F, 0x0C, 0x12, 0xA9, 0x8D, 0x22,
+0x7E, 0x00, 0x7F, 0xAC, 0x7D, 0x00, 0x7B, 0x01,
+0x7A, 0x85, 0x79, 0xC1, 0x12, 0x06, 0xDE, 0x71,
+0x42, 0x12, 0x06, 0xDE, 0xE4, 0x90, 0x94, 0xE6,
+0xF0, 0x90, 0x85, 0xC4, 0x74, 0x02, 0xF0, 0x90,
+0x85, 0xCB, 0x14, 0xF0, 0xA3, 0xF0, 0xA3, 0x74,
+0x0A, 0xF0, 0x90, 0x85, 0xD1, 0xE4, 0xF0, 0xA3,
+0x74, 0x02, 0x71, 0x32, 0x71, 0x4F, 0xE4, 0xFD,
+0xFF, 0x12, 0x57, 0x82, 0x7D, 0x0C, 0x7F, 0x02,
+0x12, 0x57, 0x82, 0x7D, 0x0C, 0x7F, 0x01, 0x12,
+0x57, 0x82, 0x90, 0x84, 0xC5, 0xE0, 0xFF, 0xB4,
+0x01, 0x08, 0x90, 0x85, 0xD0, 0x74, 0xDD, 0xF0,
+0x80, 0x0F, 0xEF, 0x90, 0x85, 0xD0, 0xB4, 0x03,
+0x05, 0x74, 0xD4, 0xF0, 0x80, 0x03, 0x74, 0x40,
+0xF0, 0x7F, 0x2C, 0x12, 0x7B, 0x51, 0xEF, 0x54,
+0x0F, 0xFF, 0xBF, 0x05, 0x08, 0x90, 0x85, 0xFB,
+0x74, 0x02, 0xF0, 0x80, 0x05, 0xE4, 0x90, 0x85,
+0xFB, 0xF0, 0x90, 0x86, 0x6D, 0x74, 0x03, 0xF0,
+0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0xE0, 0x54, 0x01,
+0x44, 0x28, 0xF0, 0xA3, 0x74, 0x07, 0x71, 0x32,
+0xE4, 0x90, 0x85, 0xD7, 0xF0, 0xA3, 0xF0, 0x7F,
+0x01, 0x12, 0x69, 0x33, 0x90, 0x05, 0x58, 0x74,
+0x02, 0xF0, 0x90, 0x06, 0x04, 0xE0, 0x54, 0x7F,
+0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x54, 0xF8, 0xF0,
+0x90, 0x05, 0x22, 0xE4, 0xF0, 0x90, 0x86, 0x71,
+0xF0, 0x22, 0xF0, 0x90, 0x85, 0xFB, 0xE0, 0x24,
+0x04, 0x90, 0x85, 0xDD, 0xF0, 0xA3, 0x74, 0x0A,
+0xF0, 0x22, 0x7E, 0x00, 0x7F, 0x04, 0x7D, 0x00,
+0x7B, 0x01, 0x7A, 0x94, 0x79, 0x66, 0x22, 0x90,
+0x94, 0xE0, 0x74, 0x04, 0xF0, 0x14, 0xF0, 0xA3,
+0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x64, 0xF0,
+0xA3, 0x74, 0x05, 0xF0, 0xA3, 0xF0, 0x22, 0x90,
+0x96, 0x8E, 0x12, 0x86, 0x75, 0x12, 0x71, 0x54,
+0x90, 0x85, 0xC5, 0xE0, 0xFF, 0x12, 0x60, 0xD0,
+0x90, 0x85, 0xC5, 0xE0, 0x60, 0x17, 0x90, 0x96,
+0x8E, 0x12, 0x87, 0x1E, 0x54, 0x0F, 0xFF, 0x12,
+0x87, 0xE2, 0xFD, 0x12, 0x6A, 0xB8, 0x12, 0xC7,
+0x6C, 0xFB, 0x12, 0x51, 0x7D, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x7A, 0x29,
+0xEF, 0x64, 0x01, 0x60, 0x05, 0x75, 0x5C, 0x01,
+0x80, 0x75, 0x90, 0x85, 0xC9, 0xE0, 0xFF, 0x54,
+0x03, 0x60, 0x05, 0x75, 0x5C, 0x02, 0x80, 0x67,
+0x90, 0x85, 0xC7, 0xE0, 0xFE, 0xE4, 0xC3, 0x9E,
+0x50, 0x05, 0x75, 0x5C, 0x04, 0x80, 0x58, 0xEF,
+0x30, 0xE2, 0x05, 0x75, 0x5C, 0x08, 0x80, 0x4F,
+0x90, 0x85, 0xC9, 0xE0, 0x30, 0xE4, 0x05, 0x75,
+0x5C, 0x10, 0x80, 0x43, 0x90, 0x85, 0xC2, 0xE0,
+0x13, 0x13, 0x54, 0x3F, 0x20, 0xE0, 0x05, 0x75,
+0x5C, 0x20, 0x80, 0x33, 0x90, 0x86, 0x71, 0xE0,
+0x60, 0x05, 0x75, 0x5C, 0x80, 0x80, 0x28, 0x90,
+0x06, 0x62, 0xE0, 0x30, 0xE1, 0x05, 0x75, 0x5C,
+0x11, 0x80, 0x1C, 0x90, 0x06, 0x62, 0xE0, 0x30,
+0xE0, 0x0C, 0xE0, 0x54, 0xFC, 0xFF, 0xBF, 0x80,
+0x05, 0x75, 0x5C, 0x12, 0x80, 0x09, 0x90, 0x01,
+0xB8, 0xE4, 0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90,
+0x01, 0xB9, 0x74, 0x04, 0xF0, 0x90, 0x01, 0xB8,
+0xE5, 0x5C, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x94, 0x66, 0xE0, 0xC3, 0x13,
+0x20, 0xE0, 0x36, 0x90, 0x02, 0x87, 0xE0, 0x60,
+0x02, 0x80, 0x08, 0x90, 0x01, 0x00, 0xE0, 0x64,
+0x3F, 0x60, 0x05, 0x75, 0x14, 0x01, 0x80, 0x34,
+0x90, 0x86, 0x7A, 0xE0, 0x30, 0xE0, 0x05, 0x75,
+0x14, 0x08, 0x80, 0x28, 0x90, 0x02, 0x86, 0xE0,
+0x20, 0xE1, 0x02, 0x80, 0x07, 0x90, 0x02, 0x86,
+0xE0, 0x30, 0xE3, 0x05, 0x75, 0x14, 0x04, 0x80,
+0x13, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x05, 0x75,
+0x14, 0x40, 0x80, 0x08, 0x90, 0x01, 0xB8, 0xE4,
+0xF0, 0x7F, 0x01, 0x22, 0x90, 0x01, 0xB9, 0x74,
+0x08, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x14, 0xF0,
+0x7F, 0x00, 0x22, 0x90, 0x94, 0xE6, 0x74, 0x01,
+0xF0, 0x90, 0x06, 0x92, 0x04, 0xF0, 0x90, 0x01,
+0x3C, 0x74, 0x04, 0xF0, 0x90, 0x85, 0xC1, 0xE0,
+0x44, 0x08, 0xF0, 0x90, 0x85, 0xC8, 0xE0, 0x64,
+0x0C, 0x60, 0x05, 0x12, 0xA9, 0x89, 0x91, 0xBF,
+0x7D, 0x08, 0xE4, 0xFF, 0x02, 0x49, 0x6F, 0xE4,
+0xFD, 0xFF, 0x02, 0x90, 0xEB, 0xAC, 0x07, 0x90,
+0x94, 0xA6, 0xE0, 0xF9, 0x30, 0xE0, 0x02, 0xA1,
+0x77, 0x90, 0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x16,
+0x90, 0x85, 0xFB, 0xE0, 0x24, 0x04, 0x90, 0x85,
+0xDA, 0xF0, 0x90, 0x85, 0xFB, 0xE0, 0x24, 0x03,
+0x90, 0x85, 0xD9, 0xF0, 0x80, 0x0D, 0x90, 0x85,
+0xDA, 0x74, 0x02, 0xF0, 0x90, 0x85, 0xD9, 0x14,
+0xF0, 0x0B, 0x0B, 0x90, 0x85, 0xD9, 0xE0, 0xFA,
+0x90, 0x85, 0xD8, 0xE0, 0xD3, 0x9A, 0x50, 0x0E,
+0x90, 0x85, 0xCD, 0xEB, 0xF0, 0x90, 0x85, 0xDA,
+0xE0, 0xC3, 0x9D, 0x2C, 0x80, 0x11, 0xC3, 0xED,
+0x9A, 0x2B, 0x90, 0x85, 0xCD, 0xF0, 0x90, 0x85,
+0xD9, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90,
+0x85, 0xDD, 0xF0, 0x90, 0x85, 0xDA, 0xE0, 0xFF,
+0x24, 0x0A, 0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x85,
+0xDD, 0xB1, 0x7F, 0x40, 0x04, 0xEF, 0x24, 0x0A,
+0xF0, 0x90, 0x85, 0xDD, 0xE0, 0xFF, 0x24, 0x23,
+0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x85, 0xCD, 0xB1,
+0x7F, 0x40, 0x04, 0xEF, 0x24, 0x23, 0xF0, 0x90,
+0x85, 0xDD, 0xE0, 0xFF, 0x7E, 0x00, 0x90, 0x85,
+0xD1, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x05,
+0x58, 0xE0, 0x6F, 0x70, 0x01, 0xE4, 0x60, 0x02,
+0xB1, 0x8A, 0xE9, 0x54, 0xFD, 0x80, 0x03, 0xE9,
+0x44, 0x02, 0x90, 0x94, 0xA6, 0xF0, 0x22, 0xE0,
+0xD3, 0x9D, 0xEC, 0x64, 0x80, 0xF8, 0x74, 0x80,
+0x98, 0x22, 0x90, 0x85, 0xD1, 0xA3, 0xE0, 0x90,
+0x05, 0x58, 0xF0, 0x22, 0xE4, 0x90, 0x92, 0x85,
+0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x94, 0xAF,
+0x12, 0x86, 0x54, 0x90, 0x94, 0xAB, 0x12, 0x86,
+0x60, 0xC3, 0x12, 0x04, 0xB4, 0x40, 0x46, 0x90,
+0x85, 0xC1, 0xE0, 0x90, 0x94, 0xAF, 0x30, 0xE0,
+0x0F, 0xF1, 0x03, 0x90, 0x85, 0xFB, 0xE0, 0x24,
+0x04, 0x2F, 0xFF, 0x90, 0x94, 0xE0, 0x80, 0x05,
+0xF1, 0x03, 0x90, 0x94, 0xE1, 0xE0, 0xFE, 0xC3,
+0xEF, 0x9E, 0x90, 0x92, 0x86, 0xF0, 0x90, 0x92,
+0x86, 0xE0, 0xFF, 0xC3, 0x94, 0x2D, 0x50, 0x15,
+0x74, 0xB3, 0x2F, 0xF1, 0x20, 0xE0, 0x04, 0xF0,
+0x90, 0x85, 0xDB, 0xE0, 0x04, 0xF0, 0xE0, 0xFD,
+0x7F, 0xFE, 0x12, 0x7B, 0x3E, 0x90, 0x85, 0xDB,
+0xE0, 0xFF, 0xD3, 0x90, 0x94, 0xE3, 0xE0, 0x9F,
+0x90, 0x94, 0xE2, 0xE0, 0x94, 0x00, 0x40, 0x02,
+0xC1, 0xD0, 0xD1, 0xE2, 0xD1, 0xD9, 0x50, 0x1D,
+0xD1, 0xEC, 0xFF, 0x90, 0x92, 0x87, 0xE0, 0xD3,
+0x9F, 0x40, 0x0A, 0x90, 0x92, 0x85, 0xE0, 0x90,
+0x92, 0x88, 0xF0, 0x80, 0x08, 0x90, 0x92, 0x85,
+0xE0, 0x04, 0xF0, 0x80, 0xDF, 0xD1, 0xE2, 0xD1,
+0xD9, 0x50, 0x2D, 0xD1, 0xEC, 0xFF, 0xC3, 0x90,
+0x94, 0xE3, 0xE0, 0x9F, 0xFF, 0x90, 0x94, 0xE2,
+0xE0, 0x94, 0x00, 0xFE, 0x90, 0x92, 0x87, 0xE0,
+0xD3, 0x9F, 0xE4, 0x9E, 0x40, 0x0A, 0x90, 0x92,
+0x85, 0xE0, 0x90, 0x92, 0x89, 0xF0, 0x80, 0x08,
+0x90, 0x92, 0x85, 0xE0, 0x04, 0xF0, 0x80, 0xCF,
+0x90, 0x92, 0x88, 0xE0, 0x90, 0x85, 0xE0, 0xF0,
+0x90, 0x92, 0x89, 0xE0, 0x90, 0x85, 0xE1, 0xD1,
+0xD1, 0x94, 0x0A, 0x40, 0x0A, 0xEF, 0x24, 0xF6,
+0x90, 0x85, 0xD8, 0xF0, 0xE4, 0x80, 0x09, 0xE4,
+0x90, 0x85, 0xD8, 0xD1, 0xD1, 0x74, 0x0A, 0x9F,
+0x90, 0x85, 0xD7, 0xF0, 0x90, 0x85, 0xE0, 0xE0,
+0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x85, 0xDE,
+0xF0, 0x90, 0x85, 0xC1, 0xE0, 0x30, 0xE0, 0x05,
+0x90, 0x94, 0xE0, 0x80, 0x03, 0x90, 0x94, 0xE1,
+0xE0, 0xFF, 0x90, 0x85, 0xDE, 0xE0, 0x2F, 0x04,
+0xF0, 0x90, 0x85, 0xDE, 0xE0, 0xC3, 0x94, 0x0A,
+0x50, 0x03, 0x74, 0x0A, 0xF0, 0x90, 0x85, 0xDE,
+0xE0, 0x24, 0x02, 0xF0, 0x12, 0xC7, 0x6C, 0xFB,
+0x12, 0x51, 0x7D, 0xE4, 0xFF, 0x12, 0x69, 0x33,
+0x22, 0xF0, 0x90, 0x85, 0xE0, 0xE0, 0xFF, 0xC3,
+0x22, 0x90, 0x92, 0x85, 0xE0, 0xFF, 0xC3, 0x94,
+0x2D, 0x22, 0xE4, 0x90, 0x92, 0x87, 0xF0, 0x90,
+0x92, 0x85, 0xF0, 0x22, 0x74, 0xB3, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0xFF,
+0x90, 0x92, 0x87, 0xE0, 0x2F, 0xF0, 0x90, 0x94,
+0xE4, 0xE0, 0x22, 0x12, 0x86, 0x60, 0x90, 0x94,
+0xAB, 0x12, 0x86, 0x54, 0x12, 0x86, 0x2C, 0x78,
+0x0A, 0x12, 0x04, 0xC5, 0x90, 0x85, 0xDD, 0xE0,
+0xFE, 0xC3, 0x74, 0x0A, 0x9E, 0x2F, 0xFF, 0x22,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22,
+0xE4, 0xFE, 0x74, 0xB3, 0x2E, 0xF1, 0x20, 0xE4,
+0xF0, 0x0E, 0xEE, 0xB4, 0x2D, 0xF4, 0xE4, 0x90,
+0x85, 0xDC, 0xF0, 0x90, 0x85, 0xDB, 0xF0, 0x90,
+0x85, 0xDF, 0xF0, 0xEF, 0xB4, 0x01, 0x07, 0xA3,
+0x74, 0x2D, 0xF0, 0xE4, 0xA3, 0xF0, 0x22, 0x12,
+0xBF, 0xCC, 0x40, 0x2E, 0x90, 0x85, 0xDF, 0xE0,
+0x04, 0xF0, 0x90, 0x94, 0xE5, 0xE0, 0xFF, 0x90,
+0x85, 0xDF, 0xE0, 0xD3, 0x9F, 0x50, 0x1B, 0x90,
+0x85, 0xD7, 0xE0, 0x04, 0x12, 0xAC, 0xF4, 0x12,
+0xAC, 0xED, 0x90, 0x85, 0xDE, 0xF0, 0xFB, 0x90,
+0x85, 0xD7, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0x12,
+0x51, 0x7D, 0x22, 0x90, 0x94, 0x66, 0xE0, 0x30,
+0xE0, 0x09, 0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4,
+0x02, 0xF1, 0x94, 0x22, 0x7D, 0x02, 0x7F, 0x02,
+0x12, 0x7C, 0x41, 0x7D, 0x01, 0x7F, 0x02, 0x02,
+0x7C, 0x41, 0x90, 0x92, 0x7E, 0x12, 0x86, 0x75,
+0x90, 0x92, 0x7A, 0x12, 0x86, 0x6C, 0x90, 0x92,
+0x81, 0x12, 0xD9, 0x23, 0xE0, 0x24, 0xFF, 0xFF,
+0xE4, 0x34, 0xFF, 0xFE, 0x90, 0x92, 0x7F, 0x8F,
+0xF0, 0x12, 0x07, 0x0A, 0x90, 0x92, 0x82, 0xEE,
+0x8F, 0xF0, 0x12, 0x07, 0x0A, 0x90, 0x92, 0x7D,
+0xE0, 0xD3, 0x94, 0x00, 0x40, 0x2C, 0x90, 0x92,
+0x81, 0x12, 0x86, 0x6C, 0x12, 0x02, 0xF6, 0xFF,
+0x90, 0x92, 0x7E, 0x12, 0x87, 0xF0, 0x6F, 0x60,
+0x05, 0xC3, 0xEE, 0x9F, 0xFF, 0x22, 0x90, 0x92,
+0x7F, 0x12, 0xD0, 0x05, 0x90, 0x92, 0x82, 0x12,
+0xD0, 0x05, 0x90, 0x92, 0x7D, 0xE0, 0x14, 0xF0,
+0x80, 0xCB, 0x7F, 0x00, 0x22, 0x74, 0xFF, 0xF5,
+0xF0, 0x02, 0x07, 0x0A, 0x90, 0x92, 0x93, 0xEF,
+0xF0, 0x90, 0x84, 0xC5, 0xE0, 0x64, 0x02, 0x70,
+0x23, 0x90, 0x92, 0x93, 0xE0, 0xFD, 0x64, 0x01,
+0x70, 0x34, 0x12, 0x9E, 0xC2, 0x90, 0x86, 0x76,
+0xE0, 0x12, 0x8F, 0xF3, 0x30, 0xE0, 0x09, 0x90,
+0x01, 0x4D, 0xE0, 0x64, 0x80, 0xF0, 0x80, 0x1E,
+0xAF, 0x05, 0x80, 0x17, 0x90, 0x06, 0x90, 0xE0,
+0x44, 0x20, 0x12, 0xBB, 0x7F, 0x11, 0x65, 0x90,
+0x06, 0x90, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x92,
+0x93, 0xE0, 0xFF, 0x12, 0x2A, 0x87, 0x90, 0x88,
+0xE1, 0xE0, 0x54, 0xFE, 0xF0, 0x90, 0x86, 0x72,
+0xE0, 0x54, 0xBF, 0xF0, 0x22, 0x7F, 0x64, 0x7E,
+0x00, 0x02, 0x7C, 0x9F, 0x90, 0x96, 0x4A, 0xED,
+0xF0, 0x90, 0x96, 0x49, 0xEF, 0xF0, 0x12, 0x7B,
+0x2A, 0x90, 0x96, 0x57, 0xEF, 0x51, 0x04, 0x2D,
+0x12, 0x97, 0x4B, 0x12, 0x9E, 0xEC, 0xEC, 0x3E,
+0x54, 0x3F, 0x90, 0x96, 0x54, 0xF0, 0xA3, 0xEF,
+0xF0, 0xE4, 0x90, 0x96, 0x53, 0xF0, 0x31, 0xB2,
+0x50, 0x0D, 0x31, 0xDC, 0x90, 0x96, 0x56, 0x12,
+0x97, 0x46, 0xE4, 0x31, 0x9A, 0x80, 0xEF, 0x90,
+0x96, 0x55, 0xE0, 0x24, 0xF8, 0xFB, 0x90, 0x96,
+0x54, 0xE0, 0x34, 0xFF, 0xFA, 0x90, 0x96, 0x4A,
+0xE0, 0xFF, 0x90, 0x8A, 0xF5, 0xE4, 0xF0, 0xA3,
+0xEF, 0xF0, 0xA3, 0x74, 0x01, 0xF0, 0x7D, 0x0A,
+0x7C, 0x00, 0x7F, 0x10, 0x7E, 0x00, 0x12, 0x6D,
+0xDB, 0x90, 0x88, 0xD2, 0xE0, 0xFF, 0x90, 0x96,
+0x49, 0xE0, 0xFD, 0xD3, 0x9F, 0x40, 0x36, 0x90,
+0x88, 0xD2, 0xE0, 0xFC, 0x31, 0xC7, 0xCE, 0xC3,
+0x13, 0xCE, 0x13, 0xD8, 0xF9, 0x31, 0xBB, 0xEC,
+0xFF, 0xC3, 0xED, 0x31, 0xD2, 0xC3, 0x33, 0xCE,
+0x33, 0xCE, 0xD8, 0xF9, 0x24, 0x28, 0xFF, 0xE4,
+0x3E, 0xFE, 0x31, 0xAA, 0xFD, 0x90, 0x96, 0x4A,
+0xE0, 0xFC, 0xC3, 0xED, 0x9C, 0x31, 0xA2, 0x7D,
+0x38, 0x7C, 0x00, 0x80, 0x33, 0x90, 0x96, 0x49,
+0x31, 0xC5, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8,
+0xF9, 0x31, 0xBB, 0xED, 0xFF, 0x90, 0x88, 0xD2,
+0x31, 0xD0, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
+0xF9, 0x24, 0x38, 0xFD, 0xE4, 0x3E, 0xFC, 0x31,
+0xAA, 0xFF, 0x90, 0x96, 0x4A, 0xE0, 0xFE, 0xC3,
+0xEF, 0x9E, 0x31, 0xA2, 0x7F, 0x28, 0x7E, 0x00,
+0x12, 0x72, 0x06, 0x7B, 0x00, 0x7A, 0x00, 0x79,
+0x00, 0x90, 0x8B, 0x26, 0x12, 0x86, 0x75, 0x0B,
+0x7A, 0x96, 0x79, 0x4B, 0x90, 0x8B, 0x29, 0x12,
+0x86, 0x75, 0x90, 0x8B, 0x2C, 0x74, 0x08, 0xF0,
+0x7A, 0x87, 0x79, 0x84, 0x12, 0x55, 0xCC, 0xE4,
+0x90, 0x96, 0x53, 0xF0, 0x31, 0xB2, 0x50, 0x21,
+0x31, 0xDC, 0x90, 0x96, 0x56, 0xEF, 0xF0, 0x90,
+0x96, 0x53, 0xE0, 0x24, 0x4B, 0xF5, 0x82, 0xE4,
+0x34, 0x96, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x96,
+0x56, 0x12, 0x97, 0x48, 0xEF, 0x31, 0x9A, 0x80,
+0xDB, 0x22, 0xF0, 0x90, 0x96, 0x53, 0xE0, 0x04,
+0xF0, 0x22, 0xFB, 0x90, 0x8A, 0xEC, 0x74, 0x08,
+0xF0, 0x22, 0x90, 0x96, 0x54, 0xA3, 0xE0, 0x24,
+0xF8, 0x22, 0x90, 0x96, 0x53, 0xE0, 0xFF, 0xC3,
+0x94, 0x08, 0x22, 0xFF, 0x90, 0x8A, 0xED, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xE0, 0xFD, 0x75,
+0xF0, 0x80, 0xA4, 0xAE, 0xF0, 0x78, 0x03, 0x22,
+0xE0, 0xC3, 0x9F, 0xFF, 0xE4, 0x94, 0x00, 0xFE,
+0xEF, 0x78, 0x07, 0x22, 0x90, 0x96, 0x57, 0xE0,
+0xFD, 0x90, 0x96, 0x55, 0xE0, 0x2D, 0xFD, 0x90,
+0x96, 0x54, 0xE0, 0x34, 0x00, 0xCD, 0x24, 0x20,
+0xCD, 0x34, 0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F,
+0xFF, 0xEE, 0x3C, 0xFE, 0x90, 0x96, 0x49, 0xE0,
+0xFD, 0x02, 0x7B, 0xAE, 0xF0, 0xE0, 0xFD, 0x24,
+0x01, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xE0, 0xFE, 0x74, 0x00, 0x22, 0xE4, 0xFD, 0xFC,
+0x90, 0x88, 0xD8, 0xE0, 0xFF, 0x12, 0xC7, 0x89,
+0xAB, 0x05, 0x74, 0x01, 0x2B, 0x51, 0x09, 0x2B,
+0x12, 0x97, 0x4B, 0x51, 0xAC, 0x90, 0x88, 0x76,
+0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x03, 0x2B, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFE,
+0x74, 0x02, 0x2B, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0x51, 0xA3, 0x90, 0x88, 0x78, 0xF0, 0xA3, 0xEF,
+0xF0, 0x74, 0x05, 0x2B, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xE0, 0xFE, 0x74, 0x04, 0x2B,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0x51, 0xA3, 0x90,
+0x88, 0x7A, 0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x07,
+0x2B, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xE0, 0xFE, 0x74, 0x06, 0x2B, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0x51, 0xA3, 0x90, 0x88, 0x7C, 0xF0,
+0xA3, 0xEF, 0xF0, 0x74, 0x09, 0x2B, 0x71, 0xCC,
+0xFE, 0x74, 0x08, 0x2B, 0x51, 0xB5, 0x24, 0x00,
+0xFF, 0xEC, 0x3E, 0x90, 0x88, 0x7E, 0xF0, 0xA3,
+0xEF, 0xF0, 0x22, 0xF5, 0x83, 0xE0, 0x24, 0x00,
+0xFF, 0xEA, 0x3E, 0x22, 0xE0, 0x7A, 0x00, 0x24,
+0x00, 0xFF, 0xEA, 0x3E, 0x22, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22, 0x12, 0x7B,
+0x2A, 0x7E, 0x00, 0xE4, 0xFD, 0xEF, 0x2D, 0x12,
+0x97, 0x49, 0xE0, 0xFC, 0x74, 0x42, 0x2D, 0x91,
+0x21, 0xEC, 0xF0, 0x0D, 0xED, 0xB4, 0x08, 0xED,
+0xAC, 0x07, 0x74, 0x08, 0x2C, 0x51, 0xB5, 0x64,
+0xDD, 0x60, 0x02, 0x61, 0x79, 0x74, 0x09, 0x2C,
+0x71, 0xCC, 0xFC, 0x30, 0xE0, 0x1C, 0xE4, 0xFD,
+0xEF, 0x2D, 0x24, 0x10, 0x12, 0xC7, 0x81, 0xE0,
+0xFB, 0x74, 0xA1, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
+0x95, 0xF5, 0x83, 0xEB, 0xF0, 0x0D, 0xED, 0xB4,
+0x08, 0xE6, 0xEC, 0x30, 0xE1, 0x6B, 0x74, 0x0A,
+0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xE0, 0x90, 0x95, 0x99, 0xF0, 0xE4, 0xFD, 0xA9,
+0x07, 0xE9, 0x2D, 0xFC, 0x24, 0x18, 0x12, 0xC7,
+0x91, 0xE0, 0xFB, 0x74, 0xA9, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0x95, 0xF5, 0x83, 0xEB, 0xF0, 0x74,
+0x20, 0x2C, 0x12, 0xC7, 0xA2, 0xFC, 0x74, 0xB1,
+0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83,
+0xEC, 0xF0, 0xE9, 0x2D, 0xFC, 0x91, 0xE8, 0xFB,
+0x74, 0xB9, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xF5, 0x83, 0xEB, 0xF0, 0x74, 0x30, 0x2C, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFC,
+0x74, 0xC1, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xF5, 0x83, 0xEC, 0xF0, 0x0D, 0xED, 0xB4, 0x08,
+0xA6, 0x90, 0x95, 0x99, 0xE0, 0xFF, 0x7B, 0x01,
+0x7A, 0x95, 0x79, 0x79, 0x90, 0x92, 0x08, 0xEF,
+0xF0, 0xA3, 0x12, 0x86, 0x75, 0xE4, 0x90, 0x92,
+0x0C, 0xF0, 0xF0, 0x90, 0x92, 0x0C, 0xE0, 0xFF,
+0xC3, 0x94, 0x04, 0x50, 0x2E, 0xEF, 0x75, 0xF0,
+0x04, 0xA4, 0xFF, 0x90, 0x92, 0x09, 0x12, 0x86,
+0x6C, 0xE9, 0x2F, 0xF9, 0xEA, 0x35, 0xF0, 0xFA,
+0x90, 0x92, 0x08, 0xE0, 0x75, 0xF0, 0x08, 0xA4,
+0x24, 0x02, 0xFF, 0x90, 0x92, 0x0C, 0xE0, 0x2F,
+0xFF, 0x71, 0xD5, 0x90, 0x92, 0x0C, 0xE0, 0x04,
+0xF0, 0x80, 0xC8, 0x22, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xE0, 0x22, 0x90, 0x92, 0x0D,
+0x12, 0x86, 0x75, 0x90, 0x06, 0x70, 0xEF, 0xF0,
+0xA3, 0xE4, 0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x80,
+0xF0, 0x7F, 0x01, 0x7E, 0x00, 0x12, 0x7C, 0x9F,
+0x90, 0x06, 0x78, 0x91, 0x19, 0xEF, 0x12, 0x03,
+0x3C, 0x90, 0x06, 0x79, 0x91, 0x19, 0x90, 0x00,
+0x01, 0xEF, 0x12, 0x03, 0x4E, 0x90, 0x06, 0x7A,
+0xE0, 0x90, 0x00, 0x02, 0x12, 0x03, 0x4E, 0x90,
+0x06, 0x7B, 0xE0, 0x90, 0x00, 0x03, 0x02, 0x03,
+0x4E, 0xE0, 0xFF, 0x90, 0x92, 0x0D, 0x02, 0x86,
+0x6C, 0xF5, 0x82, 0xE4, 0x34, 0x87, 0xF5, 0x83,
+0x22, 0x90, 0x92, 0x08, 0xEF, 0xF0, 0xE4, 0xFF,
+0x74, 0x42, 0x2F, 0x91, 0x21, 0xE0, 0xFE, 0x74,
+0x84, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x04, 0xF5,
+0x83, 0xEE, 0xF0, 0x0F, 0xEF, 0xB4, 0x08, 0xE8,
+0x90, 0x95, 0x99, 0xE0, 0x90, 0x04, 0x8C, 0xF0,
+0x90, 0x95, 0x9C, 0x74, 0x01, 0xF0, 0x90, 0x88,
+0xCD, 0xE0, 0x90, 0x95, 0x9A, 0xF0, 0x75, 0x1B,
+0x01, 0x75, 0x1C, 0x87, 0x75, 0x1D, 0x42, 0x75,
+0x1E, 0x08, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x69,
+0x12, 0xB7, 0xC4, 0x75, 0x1C, 0x87, 0x75, 0x1D,
+0x95, 0x75, 0x1E, 0x08, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x71, 0x12, 0x6A, 0x21, 0x90, 0x95, 0xC9,
+0xE0, 0x60, 0x21, 0x90, 0x92, 0x08, 0xE0, 0xFF,
+0x12, 0x7B, 0x2A, 0x7E, 0x00, 0x74, 0x00, 0x2F,
+0x91, 0xD7, 0xC0, 0x03, 0x8B, 0x1B, 0x75, 0x1C,
+0x95, 0x75, 0x1D, 0x69, 0x75, 0x1E, 0x60, 0xD0,
+0x03, 0x12, 0x6A, 0x21, 0x22, 0x91, 0xF3, 0x90,
+0x95, 0xC9, 0xE0, 0xFF, 0x91, 0x29, 0x90, 0x01,
+0x3F, 0x74, 0x04, 0xF0, 0x90, 0x84, 0xC5, 0xE0,
+0xFF, 0xB4, 0x01, 0x07, 0x90, 0xFD, 0x00, 0xE0,
+0x54, 0xEF, 0xF0, 0xEF, 0xB4, 0x01, 0x07, 0x90,
+0xFE, 0x10, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0xF9,
+0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0x22, 0xEF,
+0x60, 0x05, 0x51, 0x15, 0x12, 0x9E, 0xF3, 0x22,
+0x24, 0x28, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0xE4, 0xFD, 0x7F, 0x8F, 0x12, 0x7B,
+0x3E, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0xC7,
+0xC0, 0x90, 0x95, 0xCA, 0xE0, 0xFF, 0x12, 0x7B,
+0x2A, 0x90, 0x92, 0x51, 0xE4, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0xFD, 0x10, 0xE0, 0x90, 0x92, 0x51,
+0x75, 0xF0, 0x00, 0x12, 0x07, 0x0A, 0xE4, 0x90,
+0x92, 0x5B, 0xF0, 0x90, 0x94, 0xE8, 0xE0, 0xFF,
+0x90, 0x92, 0x5B, 0xE0, 0xC3, 0x9F, 0x40, 0x02,
+0xC1, 0xA1, 0x90, 0x92, 0x4F, 0xE0, 0x24, 0x04,
+0xFE, 0x12, 0xA5, 0xFD, 0x90, 0x92, 0x53, 0xF0,
+0xA3, 0xCE, 0xF0, 0x90, 0x92, 0x52, 0xE0, 0x24,
+0x01, 0xFF, 0x90, 0x92, 0x51, 0xD1, 0xB2, 0xEF,
+0x7F, 0x00, 0xFE, 0xC0, 0x06, 0xC0, 0x07, 0x90,
+0x92, 0x51, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x12,
+0x7A, 0x42, 0xEF, 0xFD, 0xD0, 0xE0, 0x2D, 0xFF,
+0xD0, 0xE0, 0x34, 0x00, 0xFE, 0x90, 0x92, 0x55,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x92, 0x52, 0xE0,
+0x24, 0x02, 0xFD, 0x90, 0x92, 0x51, 0xE0, 0x34,
+0x00, 0xFC, 0x90, 0x92, 0x59, 0xF0, 0xA3, 0xED,
+0xF0, 0x2F, 0xFF, 0xEC, 0x3E, 0x90, 0x92, 0x57,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x92, 0x5E, 0x74,
+0x01, 0xF0, 0xE4, 0x90, 0x92, 0x5D, 0xF0, 0x90,
+0x92, 0x5D, 0xE0, 0xFF, 0xFD, 0xD3, 0x90, 0x92,
+0x56, 0xE0, 0x9D, 0x90, 0x92, 0x55, 0xE0, 0x94,
+0x00, 0x50, 0x02, 0xC1, 0x6B, 0xEF, 0xB4, 0x12,
+0x10, 0x12, 0xA5, 0xF2, 0xCF, 0x24, 0x06, 0xCF,
+0x34, 0x00, 0x90, 0x92, 0x53, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0x92, 0x5D, 0xE0, 0x75, 0xF0, 0x02,
+0xA4, 0xFD, 0xAC, 0xF0, 0xAE, 0x04, 0x78, 0x03,
+0xCE, 0xA2, 0xE7, 0x13, 0xCE, 0x13, 0xD8, 0xF8,
+0xFF, 0xED, 0x54, 0x07, 0x90, 0x92, 0x5C, 0xF0,
+0xD1, 0xC2, 0xD1, 0xB2, 0x90, 0x92, 0x5F, 0xEF,
+0xF0, 0xFD, 0x90, 0x92, 0x5C, 0xE0, 0xD1, 0xB9,
+0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
+0xF9, 0xFF, 0xEF, 0x5D, 0x6F, 0x70, 0x01, 0xEE,
+0x70, 0x14, 0xD1, 0xA4, 0xEF, 0x54, 0x0F, 0xFF,
+0xC0, 0x07, 0x12, 0x9E, 0xDD, 0x54, 0x0F, 0xD0,
+0x07, 0x6F, 0x60, 0x02, 0x80, 0x30, 0x90, 0x92,
+0x5C, 0xE0, 0x04, 0xD1, 0xB9, 0x80, 0x05, 0xC3,
+0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90,
+0x92, 0x5F, 0xE0, 0xFD, 0xEF, 0x5D, 0x6F, 0x70,
+0x01, 0xEE, 0x70, 0x19, 0xD1, 0xA4, 0xEF, 0x54,
+0xF0, 0xFF, 0xC0, 0x07, 0x12, 0x9E, 0xDD, 0x54,
+0xF0, 0xD0, 0x07, 0x6F, 0x60, 0x07, 0xE4, 0x90,
+0x92, 0x5E, 0xF0, 0x80, 0x0E, 0x90, 0x92, 0x53,
+0x12, 0x97, 0xF4, 0x90, 0x92, 0x5D, 0xE0, 0x04,
+0xF0, 0xA1, 0xA7, 0x90, 0x92, 0x5E, 0xE0, 0xB4,
+0x01, 0x03, 0x7F, 0x01, 0x22, 0x90, 0x92, 0x56,
+0xE0, 0x24, 0x03, 0xFF, 0x90, 0x92, 0x55, 0xE0,
+0x34, 0x00, 0xFE, 0xEF, 0x78, 0x02, 0xCE, 0xC3,
+0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xFF, 0xD1, 0xC2,
+0xE0, 0x3E, 0x90, 0x92, 0x51, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0x92, 0x5B, 0xE0, 0x04, 0xF0, 0xA1,
+0x2B, 0x7F, 0x00, 0x22, 0x90, 0x92, 0x5D, 0xE0,
+0xFF, 0x90, 0x92, 0x5A, 0xE0, 0x2F, 0xFF, 0x90,
+0x92, 0x59, 0xE0, 0x34, 0x00, 0xFE, 0x02, 0x7A,
+0x42, 0xFF, 0x74, 0x01, 0x7E, 0x00, 0xA8, 0x07,
+0x08, 0x22, 0x90, 0x92, 0x58, 0xE0, 0x2F, 0xFF,
+0x90, 0x92, 0x57, 0x22, 0x90, 0x92, 0xF0, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x90, 0x92, 0xF4,
+0xF0, 0x7D, 0x09, 0x12, 0x55, 0x36, 0xEF, 0x64,
+0x06, 0x70, 0x2A, 0xF1, 0x61, 0x7D, 0x14, 0x12,
+0x55, 0x36, 0xEF, 0x70, 0x20, 0xF1, 0x61, 0x7D,
+0x15, 0x12, 0x55, 0x36, 0xEF, 0x64, 0x50, 0x70,
+0x14, 0xF1, 0x61, 0x7D, 0x21, 0x12, 0x55, 0x36,
+0xEF, 0x20, 0xE0, 0x03, 0x30, 0xE2, 0x06, 0x90,
+0x92, 0xF4, 0x74, 0x01, 0xF0, 0x90, 0x86, 0x73,
+0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x3F,
+0xF1, 0x61, 0x7D, 0x09, 0x12, 0x55, 0x36, 0xEF,
+0x64, 0x11, 0x70, 0x33, 0x90, 0x92, 0xF1, 0xE0,
+0x24, 0x14, 0xFF, 0x90, 0x92, 0xF0, 0xE0, 0x34,
+0x00, 0xFE, 0x90, 0x92, 0xF2, 0xF0, 0xA3, 0xEF,
+0xF0, 0x7D, 0x02, 0x12, 0x55, 0x36, 0xEF, 0x70,
+0x16, 0x90, 0x92, 0xF2, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x7D, 0x03, 0x12, 0x55, 0x36, 0xBF, 0x89,
+0x06, 0x90, 0x92, 0xF4, 0x74, 0x01, 0xF0, 0x90,
+0x92, 0xF4, 0xE0, 0xFF, 0xF1, 0x6D, 0xEF, 0xF0,
+0x22, 0x90, 0x92, 0xF0, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x22, 0x12, 0x6A, 0x21, 0x90, 0x84, 0xBF,
+0xA3, 0xE0, 0x24, 0x7F, 0xF5, 0x82, 0xE4, 0x34,
+0x82, 0xF5, 0x83, 0x22, 0x90, 0x92, 0x4E, 0x12,
+0x86, 0x75, 0x90, 0x92, 0x51, 0xED, 0xF0, 0xE4,
+0x90, 0x92, 0x53, 0xF0, 0xA3, 0xF0, 0xA3, 0x04,
+0xF0, 0x7E, 0x00, 0x7F, 0x08, 0x7D, 0x00, 0xFB,
+0x7A, 0x92, 0x79, 0x56, 0x12, 0x06, 0xDE, 0x90,
+0x92, 0x51, 0xE0, 0x20, 0xE0, 0x1B, 0xA3, 0xE0,
+0xB4, 0x01, 0x13, 0x90, 0x88, 0xCC, 0xE0, 0x90,
+0x87, 0x4B, 0xF0, 0x75, 0x1B, 0x01, 0x75, 0x1C,
+0x95, 0x75, 0x1D, 0xA1, 0x80, 0x46, 0x7F, 0x00,
+0x22, 0x90, 0x88, 0xCD, 0xE0, 0x90, 0x87, 0x4B,
+0xF0, 0x90, 0x95, 0x99, 0xE0, 0x14, 0x60, 0x15,
+0x14, 0x60, 0x1D, 0x14, 0x60, 0x25, 0x24, 0x03,
+0x70, 0x32, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x95,
+0x75, 0x1D, 0xA9, 0x80, 0x1F, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x95, 0x75, 0x1D, 0xB1, 0x80, 0x14,
+0x75, 0x1B, 0x01, 0x75, 0x1C, 0x95, 0x75, 0x1D,
+0xB9, 0x80, 0x09, 0x75, 0x1B, 0x01, 0x75, 0x1C,
+0x95, 0x75, 0x1D, 0xC1, 0x75, 0x1E, 0x08, 0x11,
+0x9A, 0x12, 0x6A, 0x21, 0x90, 0x87, 0x4B, 0xE0,
+0x24, 0xFE, 0x60, 0x16, 0x24, 0xFE, 0x60, 0x12,
+0x14, 0x60, 0x07, 0x14, 0x60, 0x04, 0x24, 0x05,
+0x70, 0x1C, 0x11, 0xA1, 0x11, 0x9A, 0x11, 0xAD,
+0x80, 0x0F, 0x11, 0xA1, 0x90, 0x87, 0x4B, 0xE0,
+0x90, 0x92, 0x64, 0xF0, 0x11, 0x9A, 0x12, 0x89,
+0xA3, 0x90, 0x92, 0x55, 0xEF, 0xF0, 0x90, 0x92,
+0x55, 0xE0, 0x60, 0x41, 0x90, 0x92, 0x51, 0xE0,
+0x20, 0xE0, 0x08, 0x11, 0x8B, 0x7A, 0x95, 0x79,
+0xA1, 0x80, 0x2F, 0x90, 0x95, 0x99, 0xE0, 0x14,
+0x60, 0x12, 0x14, 0x60, 0x17, 0x14, 0x60, 0x1C,
+0x24, 0x03, 0x70, 0x21, 0x11, 0x8B, 0x7A, 0x95,
+0x79, 0xA9, 0x80, 0x16, 0x11, 0x8B, 0x7A, 0x95,
+0x79, 0xB1, 0x80, 0x0E, 0x11, 0x8B, 0x7A, 0x95,
+0x79, 0xB9, 0x80, 0x06, 0x11, 0x8B, 0x7A, 0x95,
+0x79, 0xC1, 0x12, 0x6A, 0x21, 0x90, 0x92, 0x55,
+0xE0, 0xFF, 0x22, 0x75, 0x1B, 0x01, 0x75, 0x1C,
+0x92, 0x75, 0x1D, 0x56, 0x75, 0x1E, 0x08, 0x7B,
+0x01, 0x22, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x56,
+0x22, 0x90, 0x92, 0x4E, 0x12, 0x86, 0x6C, 0x90,
+0x92, 0x61, 0x02, 0x86, 0x75, 0x90, 0x92, 0x5E,
+0x12, 0x86, 0x75, 0x90, 0x92, 0x61, 0x12, 0x86,
+0x6C, 0x12, 0x88, 0x37, 0x90, 0x92, 0x6A, 0x12,
+0x8F, 0x86, 0x12, 0x88, 0x37, 0x90, 0x92, 0x6B,
+0xF0, 0x90, 0x92, 0x61, 0x31, 0x16, 0x75, 0x1E,
+0x03, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x64, 0x12,
+0x6A, 0x21, 0x90, 0x92, 0x5E, 0x31, 0x16, 0x75,
+0x1E, 0x03, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0x67,
+0x12, 0x6A, 0x21, 0x7B, 0x01, 0x7A, 0x92, 0x79,
+0x67, 0x31, 0x20, 0x74, 0x03, 0xF0, 0x7A, 0x92,
+0x79, 0x64, 0x31, 0x2A, 0x40, 0x15, 0x75, 0x1B,
+0x01, 0x75, 0x1C, 0x92, 0x75, 0x1D, 0x64, 0x75,
+0x1E, 0x03, 0x12, 0x8F, 0x87, 0x12, 0x6A, 0x21,
+0x7F, 0x01, 0x22, 0x7F, 0x00, 0x22, 0x12, 0x86,
+0x6C, 0x8B, 0x1B, 0x8A, 0x1C, 0x89, 0x1D, 0x22,
+0x90, 0x92, 0x7A, 0x12, 0x86, 0x75, 0x90, 0x92,
+0x7D, 0x22, 0x12, 0xCF, 0xA2, 0xD3, 0xEF, 0x64,
+0x80, 0x94, 0x80, 0x22, 0x90, 0x92, 0x50, 0xED,
+0xF0, 0xA3, 0xEB, 0xF0, 0x51, 0x87, 0xE4, 0x90,
+0x92, 0x52, 0xF0, 0xFD, 0x12, 0x55, 0x36, 0xEF,
+0x54, 0x0C, 0x64, 0x08, 0x70, 0x75, 0x31, 0xCA,
+0xA3, 0xE0, 0x31, 0xD3, 0x64, 0x88, 0x70, 0x6B,
+0x31, 0xCA, 0xA3, 0xE0, 0x24, 0x07, 0xFD, 0x12,
+0x55, 0x36, 0xEF, 0x64, 0x8E, 0x70, 0x5C, 0x90,
+0x92, 0x52, 0x04, 0x31, 0xC9, 0x31, 0xE5, 0x04,
+0xFD, 0x12, 0x55, 0x36, 0xEF, 0x64, 0x03, 0x70,
+0x4A, 0x31, 0xCA, 0x31, 0xE5, 0x31, 0xD3, 0x30,
+0xE3, 0x07, 0x90, 0x01, 0xC7, 0x74, 0x01, 0x80,
+0x36, 0x90, 0x86, 0x72, 0x31, 0xDE, 0x30, 0xE0,
+0x20, 0x90, 0x88, 0xCC, 0xE0, 0x64, 0x02, 0x70,
+0x0E, 0x31, 0xDB, 0x30, 0xE0, 0x02, 0x80, 0x07,
+0x90, 0x01, 0xC7, 0x74, 0x02, 0x80, 0x18, 0x31,
+0xCA, 0xA3, 0xE0, 0xFD, 0x12, 0x25, 0x7C, 0x80,
+0x12, 0x90, 0x86, 0x75, 0x12, 0xAF, 0xE3, 0x30,
+0xE0, 0x09, 0x90, 0x01, 0xC7, 0x74, 0x02, 0xF0,
+0x12, 0x9E, 0xC2, 0x90, 0x92, 0x52, 0xE0, 0xFF,
+0x22, 0xF0, 0x90, 0x92, 0x4E, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x22, 0x24, 0x06, 0xFD, 0x12, 0x55,
+0x36, 0xEF, 0x22, 0x90, 0x86, 0x73, 0xE0, 0x13,
+0x13, 0x13, 0x54, 0x1F, 0x22, 0x90, 0x92, 0x51,
+0xE0, 0xFD, 0x90, 0x92, 0x50, 0xE0, 0x2D, 0x22,
+0x12, 0xC7, 0xC0, 0xE4, 0xA3, 0xF0, 0x51, 0x73,
+0x50, 0x1A, 0x31, 0xCA, 0x51, 0x7C, 0xE0, 0x24,
+0xAA, 0xF5, 0x82, 0xE4, 0x34, 0x88, 0xF5, 0x83,
+0xE0, 0xB5, 0x07, 0x1D, 0x90, 0x92, 0x51, 0xE0,
+0x04, 0xF0, 0x80, 0xE2, 0x90, 0x06, 0x32, 0xE0,
+0x44, 0x80, 0xF0, 0x90, 0x01, 0xC7, 0x74, 0x30,
+0xF0, 0x7F, 0x01, 0x12, 0x5F, 0xE9, 0x7F, 0x01,
+0x22, 0x7F, 0x00, 0x22, 0x12, 0xC7, 0xC0, 0x90,
+0x88, 0x7C, 0xE0, 0x70, 0x02, 0xA3, 0xE0, 0x60,
+0x26, 0xE4, 0x90, 0x92, 0x51, 0xF0, 0x51, 0x73,
+0x50, 0x20, 0x31, 0xCA, 0x51, 0x7C, 0xE0, 0x24,
+0x8A, 0xF5, 0x82, 0xE4, 0x34, 0x88, 0xF5, 0x83,
+0xE0, 0x6F, 0x60, 0x03, 0x7F, 0x00, 0x22, 0x90,
+0x92, 0x51, 0xE0, 0x04, 0xF0, 0x80, 0xDF, 0x7F,
+0x00, 0x22, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x40,
+0xF0, 0xE4, 0x90, 0x88, 0x88, 0xF0, 0xA3, 0xF0,
+0x7F, 0x01, 0x22, 0x90, 0x92, 0x51, 0xE0, 0xFD,
+0xC3, 0x94, 0x02, 0x22, 0xED, 0x24, 0x1C, 0xFD,
+0x12, 0x55, 0x36, 0x90, 0x92, 0x51, 0x22, 0x90,
+0x92, 0x4E, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22,
+0x51, 0x87, 0x24, 0x16, 0xFF, 0xE4, 0x3E, 0x12,
+0xA2, 0xFD, 0x90, 0x88, 0x86, 0xA3, 0xE0, 0xB5,
+0x07, 0x1B, 0x90, 0x92, 0x4F, 0xE0, 0x24, 0x16,
+0x12, 0xA5, 0xFC, 0xFE, 0x7D, 0x01, 0x12, 0x55,
+0x36, 0xEF, 0xFD, 0x90, 0x88, 0x86, 0xE0, 0x6D,
+0x70, 0x01, 0xE4, 0x60, 0x03, 0x7F, 0x00, 0x22,
+0x7F, 0x01, 0x22, 0x51, 0x87, 0xE4, 0xA3, 0xF0,
+0x90, 0x92, 0x50, 0xE0, 0xFD, 0xC3, 0x94, 0x04,
+0x50, 0x29, 0x90, 0x92, 0x4F, 0xE0, 0x24, 0x10,
+0x12, 0xA5, 0xFC, 0xFE, 0x12, 0x55, 0x36, 0x90,
+0x92, 0x50, 0xE0, 0x24, 0x82, 0xF5, 0x82, 0xE4,
+0x34, 0x88, 0xF5, 0x83, 0xE0, 0x6F, 0x60, 0x03,
+0x7F, 0x00, 0x22, 0x90, 0x92, 0x50, 0xE0, 0x04,
+0xF0, 0x80, 0xCD, 0x7F, 0x01, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x92, 0xFA,
+0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x88, 0xCD,
+0xE0, 0xFF, 0xB4, 0x02, 0x07, 0xB1, 0x03, 0x74,
+0x08, 0xF0, 0x80, 0x09, 0xEF, 0xB4, 0x04, 0x05,
+0xB1, 0x03, 0x74, 0x10, 0xF0, 0x90, 0x92, 0xFA,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x64, 0x02, 0x4E,
+0x60, 0x08, 0xEF, 0x64, 0x01, 0x4E, 0x60, 0x02,
+0x81, 0xCF, 0x90, 0x87, 0xED, 0xB1, 0x4B, 0x90,
+0x93, 0x87, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x7E,
+0x00, 0x7F, 0x28, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
+0x93, 0x79, 0x1D, 0x12, 0x06, 0xDE, 0x7E, 0x00,
+0x7F, 0x40, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x93,
+0x79, 0x45, 0x12, 0x06, 0xDE, 0x90, 0x92, 0xFA,
+0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01, 0x70,
+0x4F, 0x75, 0x1B, 0x01, 0x75, 0x1C, 0x87, 0x75,
+0x1D, 0xBD, 0x75, 0x1E, 0x10, 0x7B, 0x01, 0x7A,
+0x93, 0x79, 0x89, 0x12, 0xB7, 0xC4, 0x75, 0x1C,
+0x87, 0x75, 0x1D, 0x5C, 0x75, 0x1E, 0x10, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0x99, 0x12, 0x6A, 0x21,
+0xB1, 0x14, 0x74, 0x20, 0xB1, 0x2E, 0x79, 0xE9,
+0x90, 0x8B, 0x33, 0x91, 0xFB, 0x90, 0x8B, 0x36,
+0xB1, 0x0B, 0x90, 0x8B, 0x39, 0xF0, 0x7A, 0x93,
+0x79, 0x89, 0x12, 0x50, 0x30, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x93, 0x75, 0x1D, 0x45, 0x80, 0x26,
+0xB1, 0x14, 0x74, 0x10, 0xB1, 0x2E, 0x79, 0xE9,
+0x90, 0x8A, 0xFB, 0x91, 0xFB, 0x90, 0x8A, 0xFE,
+0xB1, 0x0B, 0x90, 0x8B, 0x01, 0xF0, 0x7A, 0x87,
+0x79, 0x5C, 0x12, 0x64, 0xFF, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x93, 0x75, 0x1D, 0x4D, 0x75, 0x1E,
+0x28, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x1D, 0x12,
+0x6A, 0x21, 0x90, 0x87, 0x90, 0xE0, 0x64, 0xFE,
+0x70, 0x1A, 0x90, 0x87, 0x92, 0xE0, 0x54, 0x30,
+0xFF, 0xC4, 0x54, 0x0F, 0x91, 0xF3, 0x75, 0x1C,
+0x93, 0x75, 0x1D, 0x1D, 0xB1, 0x1E, 0xE0, 0x44,
+0x10, 0xF0, 0x80, 0x31, 0x90, 0x87, 0x90, 0xE0,
+0xFF, 0x64, 0x02, 0x60, 0x05, 0xEF, 0x64, 0x03,
+0x70, 0x16, 0x90, 0x93, 0x23, 0xE0, 0x54, 0x03,
+0x91, 0xF3, 0x75, 0x1C, 0x93, 0x75, 0x1D, 0x25,
+0xB1, 0x1E, 0xE0, 0x44, 0x20, 0xF0, 0x80, 0x0D,
+0x90, 0x93, 0x1C, 0x74, 0x05, 0xF0, 0x90, 0x06,
+0x33, 0xE0, 0x44, 0x40, 0xF0, 0x78, 0x79, 0x7C,
+0x95, 0x7D, 0x01, 0x7B, 0x01, 0x7A, 0x92, 0x79,
+0xFC, 0xB1, 0x42, 0x70, 0x09, 0x90, 0x06, 0x33,
+0xE0, 0x44, 0x08, 0xF0, 0x80, 0x71, 0x90, 0x93,
+0x1C, 0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50, 0x61,
+0x90, 0x95, 0x99, 0xEF, 0xF0, 0x75, 0x1B, 0x01,
+0x75, 0x1C, 0x92, 0x75, 0x1D, 0xFC, 0x75, 0x1E,
+0x20, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x79, 0x12,
+0x6A, 0x21, 0x90, 0x93, 0x1C, 0xE0, 0xFF, 0x90,
+0x88, 0xCD, 0xE0, 0xFD, 0x7B, 0x01, 0x7A, 0x92,
+0x79, 0xFC, 0x12, 0xB4, 0x3C, 0x90, 0x95, 0x99,
+0xE0, 0x14, 0x60, 0x12, 0x14, 0x60, 0x17, 0x14,
+0x60, 0x1C, 0x24, 0x03, 0x70, 0x29, 0x91, 0xD4,
+0x7A, 0x95, 0x79, 0xA9, 0x80, 0x16, 0x91, 0xD4,
+0x7A, 0x95, 0x79, 0xB1, 0x80, 0x0E, 0x91, 0xD4,
+0x7A, 0x95, 0x79, 0xB9, 0x80, 0x06, 0x91, 0xD4,
+0x7A, 0x95, 0x79, 0xC1, 0x12, 0x89, 0x09, 0x80,
+0x06, 0x90, 0x95, 0x99, 0x74, 0x05, 0xF0, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x7B, 0x01, 0x7A, 0x87,
+0x79, 0xCD, 0x90, 0x96, 0x65, 0x12, 0x86, 0x75,
+0x7A, 0x93, 0x79, 0x1C, 0x90, 0x96, 0x68, 0x12,
+0x86, 0x75, 0x90, 0x88, 0xCD, 0xE0, 0x90, 0x96,
+0x6B, 0xF0, 0x22, 0x90, 0x93, 0x1C, 0xF0, 0x75,
+0x1B, 0x01, 0x22, 0x12, 0x86, 0x75, 0x7A, 0x93,
+0x79, 0x45, 0x22, 0x90, 0x93, 0x85, 0x74, 0x80,
+0xF0, 0xA3, 0x22, 0x12, 0x86, 0x75, 0x90, 0x93,
+0x87, 0xA3, 0xE0, 0x22, 0x90, 0x93, 0x87, 0xA3,
+0xE0, 0xFB, 0x90, 0x8A, 0xEC, 0x22, 0x75, 0x1E,
+0x20, 0x7B, 0x01, 0x7A, 0x92, 0x79, 0xFC, 0x12,
+0x6A, 0x21, 0x90, 0x06, 0x33, 0x22, 0xF0, 0xE4,
+0xA3, 0xF0, 0xA3, 0xF0, 0xFD, 0xFC, 0xFF, 0xFE,
+0x12, 0x72, 0x06, 0x7B, 0x01, 0x7A, 0x94, 0x22,
+0x7D, 0x01, 0x7E, 0x00, 0x7F, 0x10, 0x12, 0x06,
+0xBA, 0xEF, 0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFD,
+0xED, 0xFF, 0x22, 0x90, 0x94, 0x57, 0x12, 0x86,
+0x75, 0x12, 0xD7, 0x6D, 0xE0, 0xFC, 0xC0, 0x03,
+0xC0, 0x02, 0xC0, 0x01, 0x7B, 0x01, 0x7A, 0x94,
+0x79, 0x5A, 0x12, 0x8F, 0x80, 0x7A, 0x94, 0x79,
+0x62, 0x90, 0x96, 0x5E, 0x12, 0x86, 0x75, 0x90,
+0x96, 0x61, 0xEC, 0xF0, 0xD0, 0x01, 0xD0, 0x02,
+0xD0, 0x03, 0x12, 0x88, 0x3D, 0xED, 0x70, 0x19,
+0xFF, 0xB1, 0xC5, 0xE0, 0xB4, 0xFF, 0x06, 0xB1,
+0xC5, 0xE4, 0xF0, 0x80, 0x07, 0xB1, 0xC5, 0xE0,
+0x04, 0xF0, 0x80, 0x05, 0x0F, 0xEF, 0xB4, 0x06,
+0xE8, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0x5A, 0x90,
+0x96, 0x65, 0x12, 0x86, 0x75, 0x7A, 0x94, 0x79,
+0x62, 0x90, 0x96, 0x68, 0x12, 0x86, 0x75, 0x90,
+0x96, 0x6B, 0xEC, 0xF0, 0x90, 0x94, 0x57, 0x12,
+0x86, 0x6C, 0x02, 0x89, 0x09, 0x74, 0x5A, 0x2F,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22,
+0xAD, 0x07, 0x90, 0x88, 0x80, 0x12, 0x97, 0xF4,
+0x90, 0x88, 0x80, 0xE0, 0xFF, 0xAE, 0x05, 0x74,
+0x04, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xEF, 0xF0, 0x90, 0x88, 0x80, 0xA3, 0xE0,
+0xFF, 0x74, 0x05, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x22, 0xA3, 0xE0,
+0xFE, 0x24, 0x28, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0xE0, 0xFF, 0x74, 0x29, 0x2E, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFD,
+0x74, 0x2C, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0xE0, 0xFB, 0x02, 0x5D, 0x98, 0x90,
+0x05, 0x63, 0xE0, 0x90, 0x94, 0xAF, 0xF0, 0x90,
+0x05, 0x62, 0xE0, 0x90, 0x94, 0xB0, 0xF0, 0x90,
+0x05, 0x61, 0xE0, 0x90, 0x94, 0xB1, 0xF0, 0x90,
+0x05, 0x60, 0xE0, 0x90, 0x94, 0xB2, 0xF0, 0x90,
+0x94, 0xA6, 0xE0, 0x44, 0x01, 0xF0, 0x22, 0x90,
+0x93, 0xD0, 0xE0, 0x2F, 0xFF, 0x90, 0x93, 0xCF,
+0xE0, 0x34, 0x00, 0xFE, 0x90, 0x94, 0x53, 0xF0,
+0xA3, 0xEF, 0xF0, 0x90, 0x88, 0xD1, 0xE0, 0xFD,
+0x12, 0x7B, 0xAE, 0x90, 0x93, 0xCA, 0x22, 0x12,
+0x90, 0xEB, 0x90, 0x05, 0x27, 0xE0, 0x44, 0x40,
+0xF0, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x92,
+0x77, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x93, 0xCC,
+0xE0, 0xFF, 0x24, 0x95, 0xF5, 0x82, 0xE4, 0x34,
+0x87, 0xF5, 0x83, 0xE0, 0x22, 0x90, 0x95, 0xFD,
+0xA3, 0xE0, 0x24, 0x04, 0xF5, 0x82, 0xE4, 0x34,
+0xFB, 0xF5, 0x83, 0xE0, 0x22, 0xE0, 0x90, 0x01,
+0xBA, 0xF0, 0x90, 0x85, 0xC7, 0xE0, 0x90, 0x01,
+0xBB, 0x22, 0x2F, 0x24, 0x42, 0xF9, 0xE4, 0x34,
+0xFC, 0xFA, 0x7B, 0x01, 0x22, 0x90, 0x93, 0xCF,
+0xE4, 0x75, 0xF0, 0x02, 0x02, 0x07, 0x0A, 0xFE,
+0x54, 0x03, 0xFD, 0xEE, 0x13, 0x13, 0x54, 0x07,
+0xFB, 0x22, 0x74, 0x03, 0xF0, 0x74, 0x01, 0x2E,
+0xF5, 0x82, 0xE4, 0x22, 0x75, 0x1C, 0x87, 0x75,
+0x1D, 0x93, 0x75, 0x1E, 0x02, 0x22, 0xF0, 0xEE,
+0x54, 0x20, 0xFE, 0xEF, 0x54, 0xDF, 0x4E, 0x22,
+0xE0, 0xFF, 0x7B, 0x18, 0x7D, 0x01, 0x02, 0x3A,
+0xC2, 0x90, 0x84, 0xBF, 0xA3, 0xE0, 0x24, 0x79,
+0xF9, 0xE4, 0x22, 0x90, 0x92, 0x77, 0xE0, 0xFF,
+0xC3, 0x22, 0x90, 0x96, 0x7C, 0xE0, 0xFF, 0x90,
+0x96, 0x7A, 0xE0, 0x22, 0x8B, 0x0D, 0x8A, 0x0E,
+0x89, 0x0F, 0x22, 0x90, 0x93, 0xCC, 0xE0, 0xFF,
+0xC3, 0x94, 0x10, 0x22, 0x8B, 0x1B, 0x75, 0x1C,
+0x92, 0x75, 0x1D, 0xD9, 0x22, 0x90, 0x92, 0x78,
+0xE0, 0xFF, 0x75, 0xF0, 0x38, 0x22, 0xE0, 0x24,
+0x57, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0x22, 0xE0,
+0x24, 0x51, 0xF5, 0x82, 0xE4, 0x34, 0x92, 0x22,
+0x78, 0x57, 0x7C, 0x92, 0x7D, 0x01, 0x7B, 0xFF,
+0x22, 0x8B, 0x1B, 0x75, 0x1C, 0x92, 0x75, 0x1D,
+0x9D, 0x22, 0x90, 0x94, 0x56, 0xE0, 0xC3, 0x94,
+0x0A, 0x22, 0x74, 0x10, 0xF0, 0x7A, 0x87, 0x79,
+0x4C, 0x22, 0x12, 0x86, 0x75, 0x7A, 0x93, 0x79,
+0xB6, 0x22, 0x12, 0x02, 0xF6, 0x13, 0x13, 0x54,
+0x3F, 0x22, 0x90, 0x86, 0xAA, 0x12, 0x05, 0x28,
+0xE0, 0x22, 0x7E, 0x00, 0x7F, 0x10, 0x02, 0x02,
+0xD0, 0x7E, 0x00, 0x7F, 0x06, 0x02, 0x02, 0xD0,
+0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0xA9, 0x90,
+0x85, 0xCB, 0xE0, 0x90, 0x05, 0x73, 0x22, 0x90,
+0x85, 0xC1, 0xE0, 0x54, 0xF7, 0xF0, 0x22, 0x12,
+0x02, 0xF6, 0xC4, 0x54, 0x0F, 0xFF, 0x22, 0x00,
+0x5D, 0x1A
+};
+
+u32 array_length_mp_8188f_fw_wowlan = 24530;
+
+#endif /*CONFIG_WOWLAN*/
+
+#endif
+
+#endif /* end of LOAD_FW_HEADER_FROM_DRIVER */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/hal8188f_fw.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/hal8188f_fw.h
new file mode 100644
index 000000000000..bdc08c40c208
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/hal8188f_fw.h
@@ -0,0 +1,41 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+*
+* Copyright(c) 2012 - 2017 Realtek Corporation.
+*
+* 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.
+*
+******************************************************************************/
+
+#ifdef CONFIG_RTL8188F
+
+#ifndef _FW_HEADER_8188F_H
+#define _FW_HEADER_8188F_H
+
+#ifdef LOAD_FW_HEADER_FROM_DRIVER
+#if (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))
+extern u8 array_mp_8188f_fw_ap[17630];
+extern u32 array_length_mp_8188f_fw_ap;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN)) || (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+extern u8 array_mp_8188f_fw_nic[20306];
+extern u32 array_length_mp_8188f_fw_nic;
+#ifdef CONFIG_WOWLAN
+extern u8 array_mp_8188f_fw_wowlan[24530];
+extern u32 array_length_mp_8188f_fw_wowlan;
+#endif /*CONFIG_WOWLAN*/
+#endif
+#endif /* end of LOAD_FW_HEADER_FROM_DRIVER */
+
+#endif
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_cmd.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_cmd.c
index 1ccb2532d1f4..3d5804d46cee 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_cmd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_cmd.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTL8188F_CMD_C_
 
 #include <rtl8188f_hal.h>
@@ -31,11 +27,11 @@
 static u8 _is_fw_read_cmd_down(_adapter *padapter, u8 msgbox_num)
 {
 	u8	read_down = _FALSE;
-	int 	retry_cnts = 100;
+	int	retry_cnts = 100;
 
 	u8 valid;
 
-	/*DBG_8192C(" _is_fw_read_cmd_down ,reg_1cc(%x),msg_box(%d)...\n",rtw_read8(padapter,REG_HMETFR),msgbox_num); */
+	/*RTW_INFO(" _is_fw_read_cmd_down ,reg_1cc(%x),msg_box(%d)...\n",rtw_read8(padapter,REG_HMETFR),msgbox_num); */
 
 	do {
 		valid = rtw_read8(padapter, REG_HMETFR) & BIT(msgbox_num);
@@ -53,7 +49,7 @@ static u8 _is_fw_read_cmd_down(_adapter *padapter, u8 msgbox_num)
 /*****************************************
 * H2C Msg format :
 *| 31 - 8		|7-5	| 4 - 0	|
-*| h2c_msg 	|Class	|CMD_ID	|
+*| h2c_msg	|Class	|CMD_ID	|
 *| 31-0						|
 *| Ext msg					|
 *
@@ -61,6 +57,7 @@ static u8 _is_fw_read_cmd_down(_adapter *padapter, u8 msgbox_num)
 s32 FillH2CCmd8188F(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)
 {
 	u8 h2c_box_num;
+	u8 h2c[RTL8188F_MAX_CMD_LEN + 1] = {0};
 	u32	msgbox_addr;
 	u32 msgbox_ex_addr = 0;
 	PHAL_DATA_TYPE pHalData;
@@ -69,18 +66,17 @@ s32 FillH2CCmd8188F(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)
 	s32 ret = _FAIL;
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-	_func_enter_;
 
 	padapter = GET_PRIMARY_ADAPTER(padapter);
 	pHalData = GET_HAL_DATA(padapter);
 #ifdef DBG_CHECK_FW_PS_STATE
 #ifdef DBG_CHECK_FW_PS_STATE_H2C
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
-		DBG_871X("%s: h2c doesn't leave 32k ElementID=%02x\n", __func__, ElementID);
+		RTW_INFO("%s: h2c doesn't leave 32k ElementID=%02x\n", __func__, ElementID);
 		pdbgpriv->dbg_h2c_leave32k_fail_cnt++;
 	}
 
-	/*DBG_871X("H2C ElementID=%02x , pHalData->LastHMEBoxNum=%02x\n", ElementID, pHalData->LastHMEBoxNum); */
+	/*RTW_INFO("H2C ElementID=%02x , pHalData->LastHMEBoxNum=%02x\n", ElementID, pHalData->LastHMEBoxNum); */
 #endif /*DBG_CHECK_FW_PS_STATE_H2C */
 #endif /*DBG_CHECK_FW_PS_STATE */
 	_enter_critical_mutex(&(adapter_to_dvobj(padapter)->h2c_fwcmd_mutex), NULL);
@@ -92,41 +88,37 @@ s32 FillH2CCmd8188F(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)
 	if (rtw_is_surprise_removed(padapter))
 		goto exit;
 
+	h2c[0] = ElementID;
+	_rtw_memcpy(h2c + 1, pCmdBuffer, CmdLen);
+
 	/*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_8192C(" fw read cmd failed...\n");
+			RTW_INFO(" fw read cmd failed...\n");
 #ifdef DBG_CHECK_FW_PS_STATE
-			DBG_871X("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n", rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
-					 , rtw_read32(padapter, 0x1c8), rtw_read32(padapter, 0x1cc));
+			RTW_INFO("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n", rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
+				, rtw_read32(padapter, 0x1c8), rtw_read32(padapter, 0x1cc));
 #endif /*DBG_CHECK_FW_PS_STATE */
-			/*DBG_8192C(" 0x1c0: 0x%8x\n", rtw_read32(padapter, 0x1c0)); */
-			/*DBG_8192C(" 0x1c4: 0x%8x\n", rtw_read32(padapter, 0x1c4)); */
+			/*RTW_INFO(" 0x1c0: 0x%8x\n", rtw_read32(padapter, 0x1c0)); */
+			/*RTW_INFO(" 0x1c4: 0x%8x\n", rtw_read32(padapter, 0x1c4)); */
 			goto exit;
 		}
 
-		if (CmdLen <= 3)
-			_rtw_memcpy((u8 *)(&h2c_cmd) + 1, pCmdBuffer, CmdLen);
-		else {
-			_rtw_memcpy((u8 *)(&h2c_cmd) + 1, pCmdBuffer, 3);
-			_rtw_memcpy((u8 *)(&h2c_cmd_ex), pCmdBuffer + 3, CmdLen - 3);
-			/**(u8*)(&h2c_cmd) |= BIT(7); */
-		}
-
-		*(u8 *)(&h2c_cmd) |= ElementID;
+		/* Write Ext command (byte 4~7) */
+		msgbox_ex_addr = REG_HMEBOX_EXT0_8188F + (h2c_box_num * RTL8188F_EX_MESSAGE_BOX_SIZE);
+		_rtw_memcpy((u8 *)(&h2c_cmd_ex), h2c + 4, RTL8188F_EX_MESSAGE_BOX_SIZE);
+		h2c_cmd_ex = le32_to_cpu(h2c_cmd_ex);
+		rtw_write32(padapter, msgbox_ex_addr, h2c_cmd_ex);
 
-		if (CmdLen > 3) {
-			msgbox_ex_addr = REG_HMEBOX_EXT0_8188F + (h2c_box_num * RTL8188F_EX_MESSAGE_BOX_SIZE);
-			h2c_cmd_ex = le32_to_cpu(h2c_cmd_ex);
-			rtw_write32(padapter, msgbox_ex_addr, h2c_cmd_ex);
-		}
-		msgbox_addr = REG_HMEBOX_0 + (h2c_box_num * MESSAGE_BOX_SIZE);
+		/* Write command (byte 0~3) */
+		msgbox_addr = REG_HMEBOX_0_8188F + (h2c_box_num * MESSAGE_BOX_SIZE);
+		_rtw_memcpy((u8 *)(&h2c_cmd), h2c, 4);
 		h2c_cmd = le32_to_cpu(h2c_cmd);
 		rtw_write32(padapter, msgbox_addr, h2c_cmd);
 
-		/*DBG_8192C("MSG_BOX:%d, CmdLen(%d), CmdID(0x%x), reg:0x%x =>h2c_cmd:0x%.8x, reg:0x%x =>h2c_cmd_ex:0x%.8x\n" */
+		/*RTW_INFO("MSG_BOX:%d, CmdLen(%d), CmdID(0x%x), reg:0x%x =>h2c_cmd:0x%.8x, reg:0x%x =>h2c_cmd_ex:0x%.8x\n" */
 		/*	,pHalData->LastHMEBoxNum , CmdLen, ElementID, msgbox_addr, h2c_cmd, msgbox_ex_addr, h2c_cmd_ex); */
 
 		pHalData->LastHMEBoxNum = (h2c_box_num + 1) % MAX_H2C_BOX_NUMS;
@@ -139,227 +131,10 @@ exit:
 
 	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->h2c_fwcmd_mutex), NULL);
 
-	_func_exit_;
 
 	return ret;
 }
 
-static void ConstructBeacon(_adapter *padapter, u8 *pframe, u32 *pLength)
-{
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16					*fctrl;
-	u32					rate_len, pktlen;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network);
-	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-
-
-	/*DBG_871X("%s\n", __func__); */
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-
-	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
-
-	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
-	/*pmlmeext->mgnt_seq++; */
-	SetFrameSubType(pframe, WIFI_BEACON);
-
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-
-	/*timestamp will be inserted by hardware */
-	pframe += 8;
-	pktlen += 8;
-
-	/* beacon interval: 2 bytes */
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
-
-	pframe += 2;
-	pktlen += 2;
-
-	/* capability info: 2 bytes */
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
-
-	pframe += 2;
-	pktlen += 2;
-
-	if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
-		/*DBG_871X("ie len=%d\n", cur_network->IELength); */
-		pktlen += cur_network->IELength - sizeof(NDIS_802_11_FIXED_IEs);
-		_rtw_memcpy(pframe, cur_network->IEs + sizeof(NDIS_802_11_FIXED_IEs), pktlen);
-
-		goto _ConstructBeacon;
-	}
-
-	/*below for ad-hoc mode */
-
-	/* SSID */
-	pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pktlen);
-
-	/* supported rates... */
-	rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
-	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pktlen);
-
-	/* DS parameter set */
-	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *) &(cur_network->Configuration.DSConfig), &pktlen);
-
-	if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
-		u32 ATIMWindow;
-		/* IBSS Parameter Set... */
-		/*ATIMWindow = cur->Configuration.ATIMWindow; */
-		ATIMWindow = 0;
-		pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pktlen);
-	}
-
-
-	/*todo: ERP IE */
-
-
-	/* EXTERNDED SUPPORTED RATE */
-	if (rate_len > 8)
-		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pktlen);
-
-
-	/*todo:HT for adhoc */
-
-_ConstructBeacon:
-
-	if ((pktlen + TXDESC_SIZE) > 512) {
-		DBG_871X("beacon frame too large\n");
-		return;
-	}
-
-	*pLength = pktlen;
-
-	/*DBG_871X("%s bcn_sz=%d\n", __func__, pktlen); */
-
-}
-
-static void ConstructPSPoll(_adapter *padapter, u8 *pframe, u32 *pLength)
-{
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16					*fctrl;
-	u32					pktlen;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	/*DBG_871X("%s\n", __func__); */
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	/* Frame control. */
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-	SetPwrMgt(fctrl);
-	SetFrameSubType(pframe, WIFI_PSPOLL);
-
-	/* AID. */
-	SetDuration(pframe, (pmlmeinfo->aid | 0xc000));
-
-	/* BSSID. */
-	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	/* TA. */
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-
-	*pLength = 16;
-}
-
-static void ConstructNullFunctionData(
-	PADAPTER padapter,
-	u8		*pframe,
-	u32		*pLength,
-	u8		*StaAddr,
-	u8		bQoS,
-	u8		AC,
-	u8		bEosp,
-	u8		bForcePowerSave)
-{
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16						*fctrl;
-	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);
-
-
-	/*DBG_871X("%s:%d\n", __func__, bForcePowerSave); */
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-	if (bForcePowerSave)
-		SetPwrMgt(fctrl);
-
-	switch (cur_network->network.InfrastructureMode) {
-	case Ndis802_11Infrastructure:
-		SetToDs(fctrl);
-		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, StaAddr, ETH_ALEN);
-		break;
-	case Ndis802_11APMode:
-		SetFrDs(fctrl);
-		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr2, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
-		break;
-	case Ndis802_11IBSS:
-	default:
-		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-		break;
-	}
-
-	SetSeqNum(pwlanhdr, 0);
-
-	if (bQoS == _TRUE) {
-		struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
-
-		SetFrameSubType(pframe, WIFI_QOS_DATA_NULL);
-
-		pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos *)pframe;
-		SetPriority(&pwlanqoshdr->qc, AC);
-		SetEOSP(&pwlanqoshdr->qc, bEosp);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-	} else {
-		SetFrameSubType(pframe, WIFI_DATA_NULL);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-	}
-
-	*pLength = pktlen;
-}
-
-/* To check if reserved page content is destroyed by beacon because beacon is too large. */
-/* 2010.06.23. Added by tynli. */
-VOID
-CheckFwRsvdPageContent(
-	IN	PADAPTER		Adapter
-)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u32	MaxBcnPageNum;
-
-	if (pHalData->FwRsvdPageStartOffset != 0) {
-		/*MaxBcnPageNum = PageNum_128(pMgntInfo->MaxBeaconSize);
-		RT_ASSERT((MaxBcnPageNum <= pHalData->FwRsvdPageStartOffset),
-			("CheckFwRsvdPageContent(): The reserved page content has been"\
-			"destroyed by beacon!!! MaxBcnPageNum(%d) FwRsvdPageStartOffset(%d)\n!",
-			MaxBcnPageNum, pHalData->FwRsvdPageStartOffset));*/
-	}
-}
-
 /* */
 /* Description: Get the reserved page number in Tx packet buffer. */
 /* Retrun value: the page number. */
@@ -383,10 +158,10 @@ static void rtl8188f_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpag
 {
 	u8 u1H2CRsvdPageParm[H2C_RSVDPAGE_LOC_LEN] = {0};
 
-	DBG_871X("8188FRsvdPageLoc: ProbeRsp=%d PsPoll=%d Null=%d QoSNull=%d BTNull=%d\n",
-			 rsvdpageloc->LocProbeRsp, rsvdpageloc->LocPsPoll,
-			 rsvdpageloc->LocNullData, rsvdpageloc->LocQosNull,
-			 rsvdpageloc->LocBTQosNull);
+	RTW_INFO("8188FRsvdPageLoc: ProbeRsp=%d PsPoll=%d Null=%d QoSNull=%d BTNull=%d\n",
+		 rsvdpageloc->LocProbeRsp, rsvdpageloc->LocPsPoll,
+		 rsvdpageloc->LocNullData, rsvdpageloc->LocQosNull,
+		 rsvdpageloc->LocBTQosNull);
 
 	SET_8188F_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(u1H2CRsvdPageParm, rsvdpageloc->LocProbeRsp);
 	SET_8188F_H2CCMD_RSVDPAGE_LOC_PSPOLL(u1H2CRsvdPageParm, rsvdpageloc->LocPsPoll);
@@ -394,7 +169,7 @@ static void rtl8188f_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpag
 	SET_8188F_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocQosNull);
 	SET_8188F_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocBTQosNull);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CRsvdPageParm:", u1H2CRsvdPageParm, H2C_RSVDPAGE_LOC_LEN);
+	RTW_DBG_DUMP("u1H2CRsvdPageParm:", u1H2CRsvdPageParm, H2C_RSVDPAGE_LOC_LEN);
 	FillH2CCmd8188F(padapter, H2C_8188F_RSVD_PAGE, H2C_RSVDPAGE_LOC_LEN, u1H2CRsvdPageParm);
 }
 
@@ -406,11 +181,11 @@ static void rtl8188f_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsv
 #ifdef CONFIG_WOWLAN
 	u8 u1H2CAoacRsvdPageParm[H2C_AOAC_RSVDPAGE_LOC_LEN] = {0};
 
-	DBG_871X("8188FAOACRsvdPageLoc: RWC=%d ArpRsp=%d NbrAdv=%d GtkRsp=%d GtkInfo=%d ProbeReq=%d NetworkList=%d\n",
-			 rsvdpageloc->LocRemoteCtrlInfo, rsvdpageloc->LocArpRsp,
-			 rsvdpageloc->LocNbrAdv, rsvdpageloc->LocGTKRsp,
-			 rsvdpageloc->LocGTKInfo, rsvdpageloc->LocProbeReq,
-			 rsvdpageloc->LocNetList);
+	RTW_INFO("8188FAOACRsvdPageLoc: RWC=%d ArpRsp=%d NbrAdv=%d GtkRsp=%d GtkInfo=%d ProbeReq=%d NetworkList=%d\n",
+		 rsvdpageloc->LocRemoteCtrlInfo, rsvdpageloc->LocArpRsp,
+		 rsvdpageloc->LocNbrAdv, rsvdpageloc->LocGTKRsp,
+		 rsvdpageloc->LocGTKInfo, rsvdpageloc->LocProbeReq,
+		 rsvdpageloc->LocNetList);
 
 	if (check_fwstate(pmlmepriv, _FW_LINKED)) {
 		SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocRemoteCtrlInfo);
@@ -421,12 +196,12 @@ static void rtl8188f_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsv
 #ifdef CONFIG_GTK_OL
 		SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKEXTMEM);
 #endif /* CONFIG_GTK_OL */
-		RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CAoacRsvdPageParm:", u1H2CAoacRsvdPageParm, H2C_AOAC_RSVDPAGE_LOC_LEN);
+		RTW_DBG_DUMP("u1H2CAoacRsvdPageParm:", u1H2CAoacRsvdPageParm, H2C_AOAC_RSVDPAGE_LOC_LEN);
 		FillH2CCmd8188F(padapter, H2C_8188F_AOAC_RSVD_PAGE, H2C_AOAC_RSVDPAGE_LOC_LEN, u1H2CAoacRsvdPageParm);
 	} else {
 #ifdef CONFIG_PNO_SUPPORT
-		if (!pwrpriv->pno_in_resume) {
-			DBG_871X("NLO_INFO=%d\n", rsvdpageloc->LocPNOInfo);
+		if (!pwrpriv->wowlan_in_resume) {
+			RTW_INFO("NLO_INFO=%d\n", rsvdpageloc->LocPNOInfo);
 			_rtw_memset(&u1H2CAoacRsvdPageParm, 0, sizeof(u1H2CAoacRsvdPageParm));
 			SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocPNOInfo);
 			FillH2CCmd8188F(padapter, H2C_AOAC_RSVDPAGE3, H2C_AOAC_RSVDPAGE_LOC_LEN, u1H2CAoacRsvdPageParm);
@@ -448,13 +223,13 @@ static void rtl8188f_set_FwKeepAlive_cmd(PADAPTER padapter, u8 benable, u8 pkt_t
 	u8 check_period = 5;
 #endif
 
-	DBG_871X("%s(): benable = %d\n", __func__, benable);
+	RTW_INFO("%s(): benable = %d\n", __func__, benable);
 	SET_8188F_H2CCMD_KEEPALIVE_PARM_ENABLE(u1H2CKeepAliveParm, benable);
 	SET_8188F_H2CCMD_KEEPALIVE_PARM_ADOPT(u1H2CKeepAliveParm, adopt);
 	SET_8188F_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(u1H2CKeepAliveParm, pkt_type);
 	SET_8188F_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(u1H2CKeepAliveParm, check_period);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CKeepAliveParm:", u1H2CKeepAliveParm, H2C_KEEP_ALIVE_CTRL_LEN);
+	RTW_DBG_DUMP("u1H2CKeepAliveParm:", u1H2CKeepAliveParm, H2C_KEEP_ALIVE_CTRL_LEN);
 
 	FillH2CCmd8188F(padapter, H2C_8188F_KEEP_ALIVE, H2C_KEEP_ALIVE_CTRL_LEN, u1H2CKeepAliveParm);
 }
@@ -464,55 +239,17 @@ static void rtl8188f_set_FwDisconDecision_cmd(PADAPTER padapter, u8 benable)
 	u8 u1H2CDisconDecisionParm[H2C_DISCON_DECISION_LEN] = {0};
 	u8 adopt = 1, check_period = 10, trypkt_num = 0;
 
-	DBG_871X("%s(): benable = %d\n", __func__, benable);
+	RTW_INFO("%s(): benable = %d\n", __func__, benable);
 	SET_8188F_H2CCMD_DISCONDECISION_PARM_ENABLE(u1H2CDisconDecisionParm, benable);
 	SET_8188F_H2CCMD_DISCONDECISION_PARM_ADOPT(u1H2CDisconDecisionParm, adopt);
 	SET_8188F_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(u1H2CDisconDecisionParm, check_period);
 	SET_8188F_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(u1H2CDisconDecisionParm, trypkt_num);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CDisconDecisionParm:", u1H2CDisconDecisionParm, H2C_DISCON_DECISION_LEN);
+	RTW_DBG_DUMP("u1H2CDisconDecisionParm:", u1H2CDisconDecisionParm, H2C_DISCON_DECISION_LEN);
 
 	FillH2CCmd8188F(padapter, H2C_8188F_DISCON_DECISION, H2C_DISCON_DECISION_LEN, u1H2CDisconDecisionParm);
 }
 
-void rtl8188f_set_FwMacIdConfig_cmd(_adapter *padapter, u8 mac_id, u8 raid, u8 bw, u8 sgi, u32 mask)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	u8 u1H2CMacIdConfigParm[H2C_MACID_CFG_LEN] = {0};
-
-	DBG_871X("%s(): mac_id=%d raid=0x%x bw=%d mask=0x%x\n", __func__, mac_id, raid, bw, mask);
-
-	_func_enter_;
-
-	SET_8188F_H2CCMD_MACID_CFG_MACID(u1H2CMacIdConfigParm, mac_id);
-	SET_8188F_H2CCMD_MACID_CFG_RAID(u1H2CMacIdConfigParm, raid);
-	SET_8188F_H2CCMD_MACID_CFG_SGI_EN(u1H2CMacIdConfigParm, (sgi) ? 1 : 0);
-	SET_8188F_H2CCMD_MACID_CFG_BW(u1H2CMacIdConfigParm, bw);
-
-	/*DisableTXPowerTraining */
-	if (pHalData->bDisableTXPowerTraining) {
-		SET_8188F_H2CCMD_MACID_CFG_DISPT(u1H2CMacIdConfigParm, 1);
-		DBG_871X("%s,Disable PWT by driver\n", __func__);
-	} else {
-		PDM_ODM_T	pDM_OutSrc = &pHalData->odmpriv;
-
-		if (pDM_OutSrc->bDisablePowerTraining) {
-			SET_8188F_H2CCMD_MACID_CFG_DISPT(u1H2CMacIdConfigParm, 1);
-			DBG_871X("%s,Disable PWT by DM\n", __func__);
-		}
-	}
-
-	SET_8188F_H2CCMD_MACID_CFG_RATE_MASK0(u1H2CMacIdConfigParm, (u8)(mask & 0x000000ff));
-	SET_8188F_H2CCMD_MACID_CFG_RATE_MASK1(u1H2CMacIdConfigParm, (u8)((mask & 0x0000ff00) >> 8));
-	SET_8188F_H2CCMD_MACID_CFG_RATE_MASK2(u1H2CMacIdConfigParm, (u8)((mask & 0x00ff0000) >> 16));
-	SET_8188F_H2CCMD_MACID_CFG_RATE_MASK3(u1H2CMacIdConfigParm, (u8)((mask & 0xff000000) >> 24));
-
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CMacIdConfigParm:", u1H2CMacIdConfigParm, H2C_MACID_CFG_LEN);
-	FillH2CCmd8188F(padapter, H2C_8188F_MACID_CFG, H2C_MACID_CFG_LEN, u1H2CMacIdConfigParm);
-
-	_func_exit_;
-}
-
 void rtl8188f_set_FwRssiSetting_cmd(_adapter *padapter, u8 *param)
 {
 	u8 u1H2CRssiSettingParm[H2C_RSSI_SETTING_LEN] = {0};
@@ -520,18 +257,16 @@ void rtl8188f_set_FwRssiSetting_cmd(_adapter *padapter, u8 *param)
 	u8 rssi = *(param + 2);
 	u8 uldl_state = 0;
 
-	_func_enter_;
-	/*DBG_871X("%s(): param=%.2x-%.2x-%.2x\n", __func__, *param, *(param+1), *(param+2)); */
-	/*DBG_871X("%s(): mac_id=%d rssi=%d\n", __func__, mac_id, rssi); */
+	/*RTW_INFO("%s(): param=%.2x-%.2x-%.2x\n", __func__, *param, *(param+1), *(param+2)); */
+	/*RTW_INFO("%s(): mac_id=%d rssi=%d\n", __func__, mac_id, rssi); */
 
 	SET_8188F_H2CCMD_RSSI_SETTING_MACID(u1H2CRssiSettingParm, mac_id);
 	SET_8188F_H2CCMD_RSSI_SETTING_RSSI(u1H2CRssiSettingParm, rssi);
 	SET_8188F_H2CCMD_RSSI_SETTING_ULDL_STATE(u1H2CRssiSettingParm, uldl_state);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_notice_, "u1H2CRssiSettingParm:", u1H2CRssiSettingParm, H2C_RSSI_SETTING_LEN);
+	RTW_DBG_DUMP("u1H2CRssiSettingParm:", u1H2CRssiSettingParm, H2C_RSSI_SETTING_LEN);
 	FillH2CCmd8188F(padapter, H2C_8188F_RSSI_SETTING, H2C_RSSI_SETTING_LEN, u1H2CRssiSettingParm);
 
-	_func_exit_;
 }
 
 void rtl8188f_set_FwAPReqRPT_cmd(PADAPTER padapter, u32 need_ack)
@@ -539,12 +274,12 @@ void rtl8188f_set_FwAPReqRPT_cmd(PADAPTER padapter, u32 need_ack)
 	u8 u1H2CApReqRptParm[H2C_AP_REQ_TXRPT_LEN] = {0};
 	u8 macid1 = 1, macid2 = 0;
 
-	DBG_871X("%s(): need_ack = %d\n", __func__, need_ack);
+	RTW_INFO("%s(): need_ack = %d\n", __func__, need_ack);
 
 	SET_8188F_H2CCMD_APREQRPT_PARM_MACID1(u1H2CApReqRptParm, macid1);
 	SET_8188F_H2CCMD_APREQRPT_PARM_MACID2(u1H2CApReqRptParm, macid2);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CApReqRptParm:", u1H2CApReqRptParm, H2C_AP_REQ_TXRPT_LEN);
+	RTW_DBG_DUMP("u1H2CApReqRptParm:", u1H2CApReqRptParm, H2C_AP_REQ_TXRPT_LEN);
 	FillH2CCmd8188F(padapter, H2C_8188F_AP_REQ_TXRPT, H2C_AP_REQ_TXRPT_LEN, u1H2CApReqRptParm);
 }
 
@@ -559,8 +294,8 @@ void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 #ifdef CONFIG_P2P
 	struct wifidirect_info *wdinfo = &(padapter->wdinfo);
 #endif /* CONFIG_P2P */
+	u8 allQueueUAPSD = 0;
 
-	_func_enter_;
 
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 	if (psmode == PS_MODE_DTIM)
@@ -569,9 +304,9 @@ void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 
 
 	if (pwrpriv->dtim > 0)
-		DBG_871X("%s(): FW LPS mode = %d, SmartPS=%d, dtim=%d\n", __func__, psmode, pwrpriv->smart_ps, pwrpriv->dtim);
+		RTW_INFO("%s(): FW LPS mode = %d, SmartPS=%d, dtim=%d\n", __func__, psmode, pwrpriv->smart_ps, pwrpriv->dtim);
 	else
-		DBG_871X("%s(): FW LPS mode = %d, SmartPS=%d\n", __func__, psmode, pwrpriv->smart_ps);
+		RTW_INFO("%s(): FW LPS mode = %d, SmartPS=%d\n", __func__, psmode, pwrpriv->smart_ps);
 
 	if (psmode == PS_MODE_MIN) {
 		rlbm = 0;
@@ -635,7 +370,7 @@ void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 	SET_8188F_H2CCMD_PWRMODE_PARM_SMART_PS(u1H2CPwrModeParm, smart_ps);
 	SET_8188F_H2CCMD_PWRMODE_PARM_RLBM(u1H2CPwrModeParm, rlbm);
 	SET_8188F_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(u1H2CPwrModeParm, awake_intvl);
-	SET_8188F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(u1H2CPwrModeParm, padapter->registrypriv.uapsd_enable);
+	SET_8188F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(u1H2CPwrModeParm, allQueueUAPSD);
 	SET_8188F_H2CCMD_PWRMODE_PARM_PWR_STATE(u1H2CPwrModeParm, PowerState);
 	SET_8188F_H2CCMD_PWRMODE_PARM_BYTE5(u1H2CPwrModeParm, byte5);
 #ifdef CONFIG_LPS_LCLK
@@ -651,12 +386,12 @@ void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 			pmlmeext->DrvBcnEarly = 0xff;
 			pmlmeext->DrvBcnTimeOut = 0xff;
 
-			/*DBG_871X("%s(): bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt); */
+			/*RTW_INFO("%s(): bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt); */
 
 			for (i = 0; i < 9; i++) {
 				pmlmeext->bcn_delay_ratio[i] = (pmlmeext->bcn_delay_cnt[i] * 100) / pmlmeext->bcn_cnt;
 
-				/*DBG_871X("%s(): bcn_delay_cnt[%d]=%d, bcn_delay_ratio[%d] = %d\n", __func__, i, pmlmeext->bcn_delay_cnt[i] */
+				/*RTW_INFO("%s(): bcn_delay_cnt[%d]=%d, bcn_delay_ratio[%d] = %d\n", __func__, i, pmlmeext->bcn_delay_cnt[i] */
 				/*	,i ,pmlmeext->bcn_delay_ratio[i]); */
 
 				ratio_20_delay += pmlmeext->bcn_delay_ratio[i];
@@ -664,12 +399,12 @@ void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 
 				if (ratio_20_delay > 20 && pmlmeext->DrvBcnEarly == 0xff) {
 					pmlmeext->DrvBcnEarly = i;
-					/*DBG_871X("%s(): DrvBcnEarly = %d\n", __func__, pmlmeext->DrvBcnEarly); */
+					/*RTW_INFO("%s(): DrvBcnEarly = %d\n", __func__, pmlmeext->DrvBcnEarly); */
 				}
 
 				if (ratio_80_delay > 80 && pmlmeext->DrvBcnTimeOut == 0xff) {
 					pmlmeext->DrvBcnTimeOut = i;
-					/*DBG_871X("%s(): DrvBcnTimeOut = %d\n", __func__, pmlmeext->DrvBcnTimeOut); */
+					/*RTW_INFO("%s(): DrvBcnTimeOut = %d\n", __func__, pmlmeext->DrvBcnTimeOut); */
 				}
 
 				/*reset adaptive_early_32k cnt */
@@ -679,11 +414,11 @@ void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 			}
 
 			pmlmeext->bcn_cnt = 0;
-			pmlmeext ->adaptive_tsf_done = _TRUE;
+			pmlmeext->adaptive_tsf_done = _TRUE;
 
 		} else {
-			/*DBG_871X("%s(): DrvBcnEarly = %d\n", __func__, pmlmeext->DrvBcnEarly); */
-			/*DBG_871X("%s(): DrvBcnTimeOut = %d\n", __func__, pmlmeext->DrvBcnTimeOut); */
+			/*RTW_INFO("%s(): DrvBcnEarly = %d\n", __func__, pmlmeext->DrvBcnEarly); */
+			/*RTW_INFO("%s(): DrvBcnTimeOut = %d\n", __func__, pmlmeext->DrvBcnTimeOut); */
 		}
 
 		/* offload to FW if fw version > v15.10
@@ -701,12 +436,30 @@ void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 	rtw_btcoex_RecordPwrMode(padapter, u1H2CPwrModeParm, H2C_PWRMODE_LEN);
 #endif /* CONFIG_BT_COEXIST */
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CPwrModeParm:", u1H2CPwrModeParm, H2C_PWRMODE_LEN);
+	RTW_DBG_DUMP("u1H2CPwrModeParm:", u1H2CPwrModeParm, H2C_PWRMODE_LEN);
 
 	FillH2CCmd8188F(padapter, H2C_8188F_SET_PWR_MODE, H2C_PWRMODE_LEN, u1H2CPwrModeParm);
-	_func_exit_;
 }
 
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8188f_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable)
+{
+	u8	u1H2CSetPwrMode[H2C_PWRMODE_LEN] = {0};
+
+	SET_8188F_H2CCMD_PWRMODE_PARM_MODE(u1H2CSetPwrMode, 1);
+	SET_8188F_H2CCMD_PWRMODE_PARM_RLBM(u1H2CSetPwrMode, 1);
+	SET_8188F_H2CCMD_PWRMODE_PARM_SMART_PS(u1H2CSetPwrMode, 0);
+	SET_8188F_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(u1H2CSetPwrMode, 0);
+	SET_8188F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(u1H2CSetPwrMode, 0);
+	SET_8188F_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(u1H2CSetPwrMode, enable);
+	SET_8188F_H2CCMD_PWRMODE_PARM_PWR_STATE(u1H2CSetPwrMode, 0x0C);
+	SET_8188F_H2CCMD_PWRMODE_PARM_BYTE5(u1H2CSetPwrMode, 0);
+	FillH2CCmd8188F(padapter, H2C_8188F_SET_PWR_MODE, sizeof(u1H2CSetPwrMode), u1H2CSetPwrMode);
+}
+#endif
+#endif
+
 void rtl8188f_set_FwPsTuneParam_cmd(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
@@ -716,8 +469,7 @@ void rtl8188f_set_FwPsTuneParam_cmd(PADAPTER padapter)
 	u8 ps_timeout = 20;  /*ms //Keep awake when tx */
 	u8 dtim_period = 3;
 
-	_func_enter_;
-	/*DBG_871X("%s(): FW LPS mode = %d\n", __func__, psmode); */
+	/*RTW_INFO("%s(): FW LPS mode = %d\n", __func__, psmode); */
 
 	SET_8188F_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(u1H2CPsTuneParm, bcn_to_limit);
 	SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(u1H2CPsTuneParm, dtim_timeout);
@@ -725,19 +477,17 @@ void rtl8188f_set_FwPsTuneParam_cmd(PADAPTER padapter)
 	SET_8188F_H2CCMD_PSTUNE_PARM_ADOPT(u1H2CPsTuneParm, 1);
 	SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(u1H2CPsTuneParm, dtim_period);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CPsTuneParm:", u1H2CPsTuneParm, H2C_PSTUNEPARAM_LEN);
+	RTW_DBG_DUMP("u1H2CPsTuneParm:", u1H2CPsTuneParm, H2C_PSTUNEPARAM_LEN);
 
 	FillH2CCmd8188F(padapter, H2C_8188F_PS_TUNING_PARA, H2C_PSTUNEPARAM_LEN, u1H2CPsTuneParm);
-	_func_exit_;
 }
 
 void rtl8188f_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param)
 {
 	u8 u1H2CBtMpOperParm[H2C_BTMP_OPER_LEN] = {0};
 
-	_func_enter_;
 
-	DBG_8192C("%s: idx=%d ver=%d reqnum=%d param1=0x%02x param2=0x%02x\n", __func__, idx, ver, reqnum, param[0], param[1]);
+	RTW_INFO("%s: idx=%d ver=%d reqnum=%d param1=0x%02x param2=0x%02x\n", __func__, idx, ver, reqnum, param[0], param[1]);
 
 	SET_8188F_H2CCMD_BT_MPOPER_VER(u1H2CBtMpOperParm, ver);
 	SET_8188F_H2CCMD_BT_MPOPER_REQNUM(u1H2CBtMpOperParm, reqnum);
@@ -746,21 +496,20 @@ void rtl8188f_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u
 	SET_8188F_H2CCMD_BT_MPOPER_PARAM2(u1H2CBtMpOperParm, param[1]);
 	SET_8188F_H2CCMD_BT_MPOPER_PARAM3(u1H2CBtMpOperParm, param[2]);
 
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_always_, "u1H2CBtMpOperParm:", u1H2CBtMpOperParm, H2C_BTMP_OPER_LEN);
+	RTW_DBG_DUMP("u1H2CBtMpOperParm:", u1H2CBtMpOperParm, H2C_BTMP_OPER_LEN);
 
 	FillH2CCmd8188F(padapter, H2C_8188F_BT_MP_OPER, H2C_BTMP_OPER_LEN, u1H2CBtMpOperParm);
-	_func_exit_;
 }
 
 void rtl8188f_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param)
 {
 	/*u8 cmd_param; //BIT0:enable, BIT1:NoConnect32k */
 
-	DBG_871X("%s()\n", __func__);
+	RTW_INFO("%s()\n", __func__);
 
 	cmd_param = cmd_param;
 
-	FillH2CCmd8188F(padapter, H2C_8188F_FWLPS_IN_IPS_, 1, &cmd_param);
+	FillH2CCmd8188F(padapter, H2C_8188F_INACTIVE_PS_, 1, &cmd_param);
 
 }
 
@@ -783,14 +532,13 @@ void rtl8188f_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 	u32 poll = 0;
 	u8 val8;
 
-	_func_enter_;
 
-	DBG_8192C("+" FUNC_ADPT_FMT ": iface_type=%d mstatus(%x)\n",
-			  FUNC_ADPT_ARG(padapter), get_iface_type(padapter), mstatus);
+	RTW_INFO("+" FUNC_ADPT_FMT ": hw_port=%d mstatus(%x)\n",
+		 FUNC_ADPT_ARG(padapter), get_hw_port(padapter), mstatus);
 
 	if (mstatus == RT_MEDIA_CONNECT) {
 		BOOLEAN bRecover = _FALSE;
-		u8 v8;
+		u8 v8, RegFwHwTxQCtrl;
 
 		/* We should set AID, correct TSF, HW seq enable before set JoinBssReport to Fw in 88/92C. */
 		/* Suggested by filen. Added by tynli. */
@@ -810,12 +558,13 @@ void rtl8188f_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 		rtw_write8(padapter, REG_BCN_CTRL, val8);
 
 		/* Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame. */
-		if (pHalData->RegFwHwTxQCtrl & BIT(6))
+		RegFwHwTxQCtrl = rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2);
+		if (RegFwHwTxQCtrl & BIT(6))
 			bRecover = _TRUE;
 
 		/* To tell Hw the packet is not a real beacon frame. */
-		rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, pHalData->RegFwHwTxQCtrl & ~BIT(6));
-		pHalData->RegFwHwTxQCtrl &= ~BIT(6);
+		RegFwHwTxQCtrl &= ~BIT(6);
+		rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, RegFwHwTxQCtrl);
 
 		/* Clear beacon valid check bit. */
 		rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
@@ -833,20 +582,20 @@ void rtl8188f_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 				/* check rsvd page download OK. */
 				rtw_hal_get_hwreg(padapter, HW_VAR_BCN_VALID, (u8 *)(&bcn_valid));
 				poll++;
-			} while (!bcn_valid && (poll%10) != 0 && !RTW_CANNOT_RUN(padapter));
-					
+			} while (!bcn_valid && (poll % 10) != 0 && !RTW_CANNOT_RUN(padapter));
+
 		} while (!bcn_valid && DLBcnCount <= 100 && !RTW_CANNOT_RUN(padapter));
-		
+
 		if (RTW_CANNOT_RUN(padapter))
 			;
 		else if (!bcn_valid)
-			DBG_871X(ADPT_FMT": 1 DL RSVD page failed! DLBcnCount:%u, poll:%u\n",
-					 ADPT_ARG(padapter) , DLBcnCount, poll);
+			RTW_INFO(ADPT_FMT": 1 DL RSVD page failed! DLBcnCount:%u, poll:%u\n",
+				 ADPT_ARG(padapter) , DLBcnCount, poll);
 		else {
 			struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 			pwrctl->fw_psmode_iface_id = padapter->iface_id;
-			DBG_871X(ADPT_FMT": 1 DL RSVD page success! DLBcnCount:%u, poll:%u\n",
-					 ADPT_ARG(padapter), DLBcnCount, poll);
+			RTW_INFO(ADPT_FMT": 1 DL RSVD page success! DLBcnCount:%u, poll:%u\n",
+				 ADPT_ARG(padapter), DLBcnCount, poll);
 		}
 
 		/* 2010.05.11. Added by tynli. */
@@ -861,8 +610,8 @@ void rtl8188f_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 		/* the beacon cannot be sent by HW. */
 		/* 2010.06.23. Added by tynli. */
 		if (bRecover) {
-			rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, pHalData->RegFwHwTxQCtrl | BIT(6));
-			pHalData->RegFwHwTxQCtrl |= BIT(6);
+			RegFwHwTxQCtrl |= BIT(6);
+			rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, RegFwHwTxQCtrl);
 		}
 
 		/* Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
@@ -871,7 +620,6 @@ void rtl8188f_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 		rtw_write8(padapter, REG_CR + 1, v8);
 	}
 
-	_func_exit_;
 }
 
 void rtl8188f_set_rssi_cmd(_adapter *padapter, u8 *param)
@@ -889,44 +637,6 @@ void rtl8188f_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus)
 		rtl8188f_download_rsvd_page(padapter, RT_MEDIA_CONNECT);
 }
 
-/*arg[0] = macid */
-/*arg[1] = raid */
-/*arg[2] = shortGIrate */
-/*arg[3] = init_rate */
-void rtl8188f_Add_RateATid(PADAPTER pAdapter, u64 rate_bitmap, u8 *arg, u8 rssi_level)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	struct dvobj_priv *dvobj = adapter_to_dvobj(pAdapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	struct sta_info	*psta = NULL;
-	u8 mac_id = arg[0];
-	u8 raid = arg[1];
-	u8 shortGI = arg[2];
-	u8 bw;
-	u32 bitmap = (u32) rate_bitmap;
-	u32 mask = bitmap & 0x0FFFFFFF;
-
-	if (mac_id < macid_ctl->num)
-		psta = macid_ctl->sta[mac_id];
-	if (psta == NULL) {
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" macid:%u, sta is NULL\n"
-			, FUNC_ADPT_ARG(pAdapter), mac_id);
-		return;
-	}
-
-	bw = rtw_get_tx_bw_mode(pAdapter, psta);
-
-	if (rssi_level != DM_RATR_STA_INIT)
-		mask = ODM_Get_Rate_Bitmap(&pHalData->odmpriv, mac_id, mask, rssi_level);
-
-	DBG_871X("%s(): mac_id=%d raid=0x%x bw=%d mask=0x%x\n", __func__, mac_id, raid, bw, mask);
-	rtl8188f_set_FwMacIdConfig_cmd(pAdapter, mac_id, raid, bw, shortGI, mask);
-
-	rtw_macid_ctl_set_bw(macid_ctl, mac_id, bw);
-	rtw_macid_ctl_set_rate_bmp0(macid_ctl, mac_id, mask);
-	rtw_update_tx_rate_bmp(adapter_to_dvobj(pAdapter));
-}
-
 #if 0
 void rtl8188f_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack)
 {
@@ -935,68 +645,6 @@ void rtl8188f_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack)
 #endif
 
 #ifdef CONFIG_BT_COEXIST
-static void ConstructBtNullFunctionData(
-	PADAPTER padapter,
-	u8 *pframe,
-	u32 *pLength,
-	u8 *StaAddr,
-	u8 bQoS,
-	u8 AC,
-	u8 bEosp,
-	u8 bForcePowerSave)
-{
-	struct rtw_ieee80211_hdr *pwlanhdr;
-	u16 *fctrl;
-	u32 pktlen;
-	struct mlme_ext_priv *pmlmeext;
-	struct mlme_ext_info *pmlmeinfo;
-	u8 bssid[ETH_ALEN];
-
-
-	DBG_871X("+" FUNC_ADPT_FMT ": qos=%d eosp=%d ps=%d\n",
-			 FUNC_ADPT_ARG(padapter), bQoS, bEosp, bForcePowerSave);
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-	pmlmeext = &padapter->mlmeextpriv;
-	pmlmeinfo = &pmlmeext->mlmext_info;
-
-	if (NULL == StaAddr) {
-		_rtw_memcpy(bssid, myid(&padapter->eeprompriv), ETH_ALEN);
-		StaAddr = bssid;
-	}
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*fctrl = 0;
-	if (bForcePowerSave)
-		SetPwrMgt(fctrl);
-
-	SetFrDs(fctrl);
-	_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, myid(&padapter->eeprompriv), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, myid(&padapter->eeprompriv), ETH_ALEN);
-
-	SetDuration(pwlanhdr, 0);
-	SetSeqNum(pwlanhdr, 0);
-
-	if (bQoS == _TRUE) {
-		struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
-
-		SetFrameSubType(pframe, WIFI_QOS_DATA_NULL);
-
-		pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos *)pframe;
-		SetPriority(&pwlanqoshdr->qc, AC);
-		SetEOSP(&pwlanqoshdr->qc, bEosp);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-	} else {
-		SetFrameSubType(pframe, WIFI_DATA_NULL);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-	}
-
-	*pLength = pktlen;
-}
-
 static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
@@ -1015,7 +663,7 @@ static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
 	RSVDPAGE_LOC RsvdPageLoc;
 
 
-	/*DBG_8192C("+" FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(padapter)); */
+	/*RTW_INFO("+" FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(padapter)); */
 
 	pHalData = GET_HAL_DATA(padapter);
 	pxmitpriv = &padapter->xmitpriv;
@@ -1030,7 +678,7 @@ static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
 
 	pcmdframe = rtw_alloc_cmdxmitframe(pxmitpriv);
 	if (pcmdframe == NULL) {
-		DBG_8192C("%s: alloc ReservedPagePacket fail!\n", __func__);
+		RTW_INFO("%s: alloc ReservedPagePacket fail!\n", __func__);
 		return;
 	}
 
@@ -1039,7 +687,8 @@ static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
 
 	/*3 (1) beacon */
 	BufIndex = TxDescOffset;
-	ConstructBeacon(padapter, &ReservedPagePacket[BufIndex], &BeaconLength);
+	rtw_hal_construct_beacon(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. */
@@ -1059,11 +708,11 @@ static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
 
 	/*3 (6) BT Qos null data */
 	RsvdPageLoc.LocBTQosNull = TotalPageNum;
-	ConstructBtNullFunctionData(
+	rtw_hal_construct_NullFunctionData(
 		padapter,
 		&ReservedPagePacket[BufIndex],
 		&BTQosNullLength,
-		NULL,
+		get_my_bssid(&pmlmeinfo->network),
 		_TRUE, 0, 0, _FALSE);
 	rtl8188f_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex - TxDescLen], BTQosNullLength, _FALSE, _TRUE, _FALSE);
 
@@ -1073,8 +722,8 @@ static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
 
 	TotalPacketLen = BufIndex + BTQosNullLength;
 	if (TotalPacketLen > MaxRsvdPageBufSize) {
-		DBG_8192C(FUNC_ADPT_FMT ": ERROR: The rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
-				  FUNC_ADPT_ARG(padapter), TotalPacketLen, MaxRsvdPageBufSize);
+		RTW_INFO(FUNC_ADPT_FMT ": ERROR: The rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
+			FUNC_ADPT_ARG(padapter), TotalPacketLen, MaxRsvdPageBufSize);
 		goto error;
 	}
 
@@ -1089,7 +738,7 @@ static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
 	dump_mgntframe_and_wait(padapter, pcmdframe, 100);
 #endif
 
-	/*DBG_8192C(FUNC_ADPT_FMT ": Set RSVD page location to Fw, TotalPacketLen(%d), TotalPageNum(%d)\n", */
+	/*RTW_INFO(FUNC_ADPT_FMT ": Set RSVD page location to Fw, TotalPacketLen(%d), TotalPageNum(%d)\n", */
 	/*	FUNC_ADPT_ARG(padapter), TotalPacketLen, TotalPageNum); */
 	rtl8188f_set_FwRsvdPage_cmd(padapter, &RsvdPageLoc);
 	rtl8188f_set_FwAoacRsvdPage_cmd(padapter, &RsvdPageLoc);
@@ -1109,18 +758,18 @@ void rtl8188f_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter)
 	u8 bcn_valid = _FALSE;
 	u8 DLBcnCount = 0;
 	u32 poll = 0;
-	u8 val8;
+	u8 val8, RegFwHwTxQCtrl;
 
 
-	DBG_8192C("+" FUNC_ADPT_FMT ": iface_type=%d fw_state=0x%08X\n",
-			  FUNC_ADPT_ARG(padapter), get_iface_type(padapter), get_fwstate(&padapter->mlmepriv));
+	RTW_INFO("+" FUNC_ADPT_FMT ": hw_port=%d fw_state=0x%08X\n",
+		FUNC_ADPT_ARG(padapter), get_hw_port(padapter), get_fwstate(&padapter->mlmepriv));
 
-#ifdef CONFIG_DEBUG
+#ifdef CONFIG_RTW_DEBUG
 	if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _FALSE) {
-		DBG_8192C(FUNC_ADPT_FMT ": [WARNING] not in AP mode!!\n",
-				  FUNC_ADPT_ARG(padapter));
+		RTW_INFO(FUNC_ADPT_FMT ": [WARNING] not in AP mode!!\n",
+			 FUNC_ADPT_ARG(padapter));
 	}
-#endif /* CONFIG_DEBUG */
+#endif /* CONFIG_RTW_DEBUG */
 
 	pHalData = GET_HAL_DATA(padapter);
 	pmlmeext = &padapter->mlmeextpriv;
@@ -1144,12 +793,13 @@ void rtl8188f_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter)
 	rtw_write8(padapter, REG_BCN_CTRL, val8);
 
 	/* Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame. */
-	if (pHalData->RegFwHwTxQCtrl & BIT(6))
+	RegFwHwTxQCtrl = rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2);
+	if (RegFwHwTxQCtrl & BIT(6))
 		bRecover = _TRUE;
 
 	/* To tell Hw the packet is not a real beacon frame. */
-	pHalData->RegFwHwTxQCtrl &= ~BIT(6);
-	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, pHalData->RegFwHwTxQCtrl);
+	RegFwHwTxQCtrl &= ~BIT(6);
+	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, RegFwHwTxQCtrl);
 
 	/* Clear beacon valid check bit. */
 	rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
@@ -1168,19 +818,19 @@ void rtl8188f_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter)
 			poll++;
 		} while (!bcn_valid && (poll % 10) != 0 && !RTW_CANNOT_RUN(padapter));
 	} while (!bcn_valid && (DLBcnCount <= 100) && !RTW_CANNOT_RUN(padapter));
-	
+
 	if (_TRUE == bcn_valid) {
 		struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 		pwrctl->fw_psmode_iface_id = padapter->iface_id;
-		DBG_8192C(ADPT_FMT": DL RSVD page success! DLBcnCount:%d, poll:%d\n",
-				  ADPT_ARG(padapter), DLBcnCount, poll);
+		RTW_INFO(ADPT_FMT": DL RSVD page success! DLBcnCount:%d, poll:%d\n",
+			 ADPT_ARG(padapter), DLBcnCount, poll);
 	} else {
-		DBG_871X(ADPT_FMT": DL RSVD page fail! DLBcnCount:%d, poll:%d\n",
-			ADPT_ARG(padapter), DLBcnCount, poll);
-		DBG_871X(ADPT_FMT": DL RSVD page fail! bSurpriseRemoved=%s\n",
-			ADPT_ARG(padapter), rtw_is_surprise_removed(padapter)?"True":"False");
-		DBG_871X(ADPT_FMT": DL RSVD page fail! bDriverStopped=%s\n",
-			ADPT_ARG(padapter), rtw_is_drv_stopped(padapter)?"True":"False");
+		RTW_INFO(ADPT_FMT": DL RSVD page fail! DLBcnCount:%d, poll:%d\n",
+			 ADPT_ARG(padapter), DLBcnCount, poll);
+		RTW_INFO(ADPT_FMT": DL RSVD page fail! bSurpriseRemoved=%s\n",
+			ADPT_ARG(padapter), rtw_is_surprise_removed(padapter) ? "True" : "False");
+		RTW_INFO(ADPT_FMT": DL RSVD page fail! bDriverStopped=%s\n",
+			ADPT_ARG(padapter), rtw_is_drv_stopped(padapter) ? "True" : "False");
 	}
 
 	/* 2010.05.11. Added by tynli. */
@@ -1195,8 +845,8 @@ void rtl8188f_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter)
 	/* the beacon cannot be sent by HW. */
 	/* 2010.06.23. Added by tynli. */
 	if (bRecover) {
-		pHalData->RegFwHwTxQCtrl |= BIT(6);
-		rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, pHalData->RegFwHwTxQCtrl);
+		RegFwHwTxQCtrl |= BIT(6);
+		rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, RegFwHwTxQCtrl);
 	}
 
 	/* Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
@@ -1215,16 +865,15 @@ void rtl8188f_set_p2p_ps_offload_cmd(_adapter *padapter, u8 p2p_ps_state)
 	struct P2P_PS_Offload_t	*p2p_ps_offload = (struct P2P_PS_Offload_t *)(&pHalData->p2p_ps_offload);
 	u8	i;
 
-	_func_enter_;
 
 #if 1
 	switch (p2p_ps_state) {
 	case P2P_PS_DISABLE:
-		DBG_8192C("P2P_PS_DISABLE\n");
+		RTW_INFO("P2P_PS_DISABLE\n");
 		_rtw_memset(p2p_ps_offload, 0 , 1);
 		break;
 	case P2P_PS_ENABLE:
-		DBG_8192C("P2P_PS_ENABLE\n");
+		RTW_INFO("P2P_PS_ENABLE\n");
 		/* update CTWindow value. */
 		if (pwdinfo->ctwindow > 0) {
 			p2p_ps_offload->CTWindow_En = 1;
@@ -1241,16 +890,16 @@ void rtl8188f_set_p2p_ps_offload_cmd(_adapter *padapter, u8 p2p_ps_state)
 				p2p_ps_offload->NoA1_En = 1;
 
 			/* config P2P NoA Descriptor Register */
-			/*DBG_8192C("%s(): noa_duration = %x\n",__func__,pwdinfo->noa_duration[i]); */
+			/*RTW_INFO("%s(): noa_duration = %x\n",__func__,pwdinfo->noa_duration[i]); */
 			rtw_write32(padapter, REG_NOA_DESC_DURATION, pwdinfo->noa_duration[i]);
 
-			/*DBG_8192C("%s(): noa_interval = %x\n",__func__,pwdinfo->noa_interval[i]); */
+			/*RTW_INFO("%s(): noa_interval = %x\n",__func__,pwdinfo->noa_interval[i]); */
 			rtw_write32(padapter, REG_NOA_DESC_INTERVAL, pwdinfo->noa_interval[i]);
 
-			/*DBG_8192C("%s(): start_time = %x\n",__func__,pwdinfo->noa_start_time[i]); */
+			/*RTW_INFO("%s(): start_time = %x\n",__func__,pwdinfo->noa_start_time[i]); */
 			rtw_write32(padapter, REG_NOA_DESC_START, pwdinfo->noa_start_time[i]);
 
-			/*DBG_8192C("%s(): noa_count = %x\n",__func__,pwdinfo->noa_count[i]); */
+			/*RTW_INFO("%s(): noa_count = %x\n",__func__,pwdinfo->noa_count[i]); */
 			rtw_write8(padapter, REG_NOA_DESC_COUNT, pwdinfo->noa_count[i]);
 		}
 
@@ -1270,11 +919,11 @@ void rtl8188f_set_p2p_ps_offload_cmd(_adapter *padapter, u8 p2p_ps_state)
 		}
 		break;
 	case P2P_PS_SCAN:
-		DBG_8192C("P2P_PS_SCAN\n");
+		RTW_INFO("P2P_PS_SCAN\n");
 		p2p_ps_offload->discovery = 1;
 		break;
 	case P2P_PS_SCAN_DONE:
-		DBG_8192C("P2P_PS_SCAN_DONE\n");
+		RTW_INFO("P2P_PS_SCAN_DONE\n");
 		p2p_ps_offload->discovery = 0;
 		pwdinfo->p2p_ps_state = P2P_PS_ENABLE;
 		break;
@@ -1285,34 +934,7 @@ void rtl8188f_set_p2p_ps_offload_cmd(_adapter *padapter, u8 p2p_ps_state)
 	FillH2CCmd8188F(padapter, H2C_8188F_P2P_PS_OFFLOAD, 1, (u8 *)p2p_ps_offload);
 #endif
 
-	_func_exit_;
 
 }
 #endif /*CONFIG_P2P */
 
-
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-/*
-	ask FW to Reset sync register at Beacon early interrupt
-*/
-u8 rtl8188f_reset_tsf(_adapter *padapter, u8 reset_port)
-{
-	u8	buf[2];
-	u8	res = _SUCCESS;
-
-	_func_enter_;
-	if (IFACE_PORT0 == reset_port) {
-		buf[0] = 0x1;
-		buf[1] = 0;
-
-	} else {
-		buf[0] = 0x0;
-		buf[1] = 0x1;
-	}
-	FillH2CCmd8188F(padapter, H2C_8188F_RESET_TSF, 2, buf);
-	_func_exit_;
-
-	return res;
-}
-#endif	/* CONFIG_TSF_RESET_OFFLOAD */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_dm.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_dm.c
index ca5c0ab27ec3..b2e09e94b9e0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_dm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_dm.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 /*============================================================ */
 /* Description: */
 /* */
@@ -52,34 +48,14 @@ dm_CheckProtection(
 
 	if (Adapter->TxStats.CurrentInitTxRate <= RateThreshold) {
 		pMgntInfo->bDmDisableProtect = TRUE;
-		DbgPrint("Forced disable protect: %x\n", Adapter->TxStats.CurrentInitTxRate);
+		dbg_print("Forced disable protect: %x\n", Adapter->TxStats.CurrentInitTxRate);
 	} else {
 		pMgntInfo->bDmDisableProtect = FALSE;
-		DbgPrint("Enable protect: %x\n", Adapter->TxStats.CurrentInitTxRate);
+		dbg_print("Enable protect: %x\n", Adapter->TxStats.CurrentInitTxRate);
 	}
 #endif
 }
 
-static VOID
-dm_CheckStatistics(
-	IN	PADAPTER	Adapter
-)
-{
-#if 0
-	if (!Adapter->MgntInfo.bMediaConnect)
-		return;
-
-	/*2008.12.10 tynli Add for getting Current_Tx_Rate_Reg flexibly. */
-	rtw_hal_get_hwreg(Adapter, HW_VAR_INIT_TX_RATE, (pu1Byte)(&Adapter->TxStats.CurrentInitTxRate));
-
-	/* Calculate current Tx Rate(Successful transmited!!) */
-
-	/* Calculate current Rx Rate(Successful received!!) */
-
-	/*for tx tx retry count */
-	rtw_hal_get_hwreg(Adapter, HW_VAR_RETRY_COUNT, (pu1Byte)(&Adapter->TxStats.NumTxRetryCount));
-#endif
-}
 #ifdef CONFIG_SUPPORT_HW_WPS_PBC
 static void dm_CheckPbcGPIO(_adapter *padapter)
 {
@@ -110,7 +86,6 @@ static void dm_CheckPbcGPIO(_adapter *padapter)
 		bPbcPressed = _TRUE;
 #else
 	tmp1byte = rtw_read8(padapter, GPIO_IN);
-	/*RT_TRACE(COMP_IO, DBG_TRACE, ("dm_CheckPbcGPIO - %x\n", tmp1byte)); */
 
 	if (tmp1byte == 0xff || padapter->init_adpt_in_progress)
 		return;
@@ -122,7 +97,7 @@ static void dm_CheckPbcGPIO(_adapter *padapter)
 	if (_TRUE == bPbcPressed) {
 		/* Here we only set bPbcPressed to true */
 		/* After trigger PBC, the variable will be set to false */
-		DBG_8192C("CheckPbcGPIO - PBC is pressed\n");
+		RTW_INFO("CheckPbcGPIO - PBC is pressed\n");
 		rtw_request_wps_pbc_event(padapter);
 	}
 }
@@ -160,8 +135,8 @@ dm_InterruptMigration(
 	/* when interrupt migration is set before. 2010.03.05. */
 	/* */
 	if (!Adapter->registrypriv.wifi_spec &&
-		(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) &&
-		pmlmepriv->LinkDetectInfo.bHigherBusyTraffic) {
+	    (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) &&
+	    pmlmepriv->LinkDetectInfo.bHigherBusyTraffic) {
 		IntMtToSet = _TRUE;
 
 		/* To check whether we should disable Tx interrupt or not. */
@@ -171,7 +146,7 @@ dm_InterruptMigration(
 
 	/*Update current settings. */
 	if (bCurrentIntMt != IntMtToSet) {
-		DBG_8192C("%s(): Update interrupt migration(%d)\n", __func__, IntMtToSet);
+		RTW_INFO("%s(): Update interrupt migration(%d)\n", __func__, IntMtToSet);
 		if (IntMtToSet) {
 			/* */
 			/* <Roger_Notes> Set interrupt migration timer and corresponging Tx/Rx counter. */
@@ -189,7 +164,7 @@ dm_InterruptMigration(
 
 #if 0 /* mask */
 	if (bCurrentACIntDisable != ACIntToSet) {
-		DBG_8192C("%s(): Update AC interrupt(%d)\n", __func__, ACIntToSet);
+		RTW_INFO("%s(): Update AC interrupt(%d)\n", __func__, ACIntToSet);
 		if (ACIntToSet) { /* Disable four ACs interrupts. */
 			/* */
 			/* <Roger_Notes> Disable VO, VI, BE and BK four AC interrupts to gain more efficient CPU utilization. */
@@ -232,80 +207,19 @@ dm_InitGPIOSetting(
 static void Init_ODM_ComInfo_8188f(PADAPTER	Adapter)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-	u32 SupportAbility = 0;
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 	u8	cut_ver, fab_ver;
 
 	Init_ODM_ComInfo(Adapter);
 
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_PACKAGE_TYPE, pHalData->PackageType);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_PACKAGE_TYPE, pHalData->PackageType);
 
 	fab_ver = ODM_TSMC;
-	cut_ver = GET_CVID_CUT_VERSION(pHalData->VersionID);
-
-	DBG_871X("%s(): fab_ver=%d cut_ver=%d\n", __func__, fab_ver, cut_ver);
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_FAB_VER, fab_ver);
-	ODM_CmnInfoInit(pDM_Odm, ODM_CMNINFO_CUT_VER, cut_ver);
-
-#ifdef CONFIG_DISABLE_ODM
-	SupportAbility = 0;
-#else
-	SupportAbility =	ODM_RF_CALIBRATION		|
-						ODM_RF_TX_PWR_TRACK	/*| */
-						;
-	/*if(pHalData->AntDivCfg) */
-	/*	pdmpriv->InitODMFlag |= ODM_BB_ANT_DIV; */
-#endif
-
-	ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_ABILITY, SupportAbility);
-}
-
-static void Update_ODM_ComInfo_8188f(PADAPTER	Adapter)
-{
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-	u32 SupportAbility = 0;
-
-	SupportAbility = 0
-			 | ODM_BB_DIG
-			 | ODM_BB_RA_MASK
-			 | ODM_BB_DYNAMIC_TXPWR
-			 | ODM_BB_FA_CNT
-			 | ODM_BB_RSSI_MONITOR
-			 | ODM_BB_CCK_PD
-			 /* | ODM_BB_PWR_SAVE */
-			 | ODM_BB_CFO_TRACKING
-			 | ODM_MAC_EDCA_TURBO
-			 | ODM_RF_TX_PWR_TRACK
-			 | ODM_RF_CALIBRATION
-			 | ODM_BB_NHM_CNT
-			 /*| ODM_BB_PWR_TRAIN */
-			 ;
-
-	if (rtw_odm_adaptivity_needed(Adapter) == _TRUE) {
-		rtw_odm_adaptivity_config_msg(RTW_DBGDUMP, Adapter);
-		SupportAbility |= ODM_BB_ADAPTIVITY;
-	}
-
-#ifdef CONFIG_ANTENNA_DIVERSITY
-	if (pHalData->AntDivCfg)
-		SupportAbility |= ODM_BB_ANT_DIV;
-#endif
-
-#if (MP_DRIVER==1)
-	if (Adapter->registrypriv.mp_mode == 1) {
-		SupportAbility = 0
-						 | ODM_RF_CALIBRATION
-						 | ODM_RF_TX_PWR_TRACK
-						 ;
-	}
-#endif/*(MP_DRIVER==1) */
-
-#ifdef CONFIG_DISABLE_ODM
-	SupportAbility = 0;
-#endif/*CONFIG_DISABLE_ODM */
+	cut_ver = GET_CVID_CUT_VERSION(pHalData->version_id);
 
-	ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_ABILITY, SupportAbility);
+	RTW_INFO("%s(): fab_ver=%d cut_ver=%d\n", __func__, fab_ver, cut_ver);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_FAB_VER, fab_ver);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_CUT_VER, cut_ver);
 }
 
 void
@@ -314,95 +228,14 @@ rtl8188f_InitHalDm(
 )
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
-
-	u8	i;
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 #ifdef CONFIG_USB_HCI
 	dm_InitGPIOSetting(Adapter);
 #endif
-
-	pHalData->DM_Type = DM_Type_ByDriver;
-
-	Update_ODM_ComInfo_8188f(Adapter);
-
-	ODM_DMInit(pDM_Odm);
-
+	rtw_phydm_init(Adapter);
 }
 
-#if 0 /* function never used */
-static void
-FindMinimumRSSI_8188f(
-	IN	PADAPTER	pAdapter
-)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	struct mlme_priv	*pmlmepriv = &pAdapter->mlmepriv;
-
-	/*1 1.Determine the minimum RSSI */
-
-
-#ifdef CONFIG_CONCURRENT_MODE
-	/*	FindMinimumRSSI()	per-adapter */
-	{
-		PADAPTER pbuddy_adapter = pAdapter->pbuddy_adapter;
-		PHAL_DATA_TYPE	pbuddy_HalData = GET_HAL_DATA(pbuddy_adapter);
-		struct dm_priv *pbuddy_dmpriv = &pbuddy_HalData->dmpriv;
-
-		if ((pHalData->EntryMinUndecoratedSmoothedPWDB != 0) &&
-			(pbuddy_dmpriv->EntryMinUndecoratedSmoothedPWDB != 0)) {
-
-			if (pHalData->EntryMinUndecoratedSmoothedPWDB > pbuddy_dmpriv->EntryMinUndecoratedSmoothedPWDB)
-				pHalData->EntryMinUndecoratedSmoothedPWDB = pbuddy_dmpriv->EntryMinUndecoratedSmoothedPWDB;
-		} else {
-			if (pHalData->EntryMinUndecoratedSmoothedPWDB == 0)
-				pHalData->EntryMinUndecoratedSmoothedPWDB = pbuddy_dmpriv->EntryMinUndecoratedSmoothedPWDB;
-
-		}
-#if 0
-		if ((pHalData->UndecoratedSmoothedPWDB != (-1)) &&
-			(pbuddy_dmpriv->UndecoratedSmoothedPWDB != (-1))) {
-
-			if ((pHalData->UndecoratedSmoothedPWDB > pbuddy_dmpriv->UndecoratedSmoothedPWDB) &&
-				(pbuddy_dmpriv->UndecoratedSmoothedPWDB != 0))
-				pHalData->UndecoratedSmoothedPWDB = pbuddy_dmpriv->UndecoratedSmoothedPWDB;
-		} else {
-			if ((pHalData->UndecoratedSmoothedPWDB == (-1)) && (pbuddy_dmpriv->UndecoratedSmoothedPWDB != 0))
-				pHalData->UndecoratedSmoothedPWDB = pbuddy_dmpriv->UndecoratedSmoothedPWDB;
-		}
-#endif
-	}
-#endif
-
-	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) &&
-		(pHalData->EntryMinUndecoratedSmoothedPWDB == 0)) {
-		pHalData->MinUndecoratedPWDBForDM = 0;
-		/*ODM_RT_TRACE(pDM_Odm,COMP_BB_POWERSAVING, DBG_LOUD, ("Not connected to any\n")); */
-	}
-	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {	/* Default port */
-#if 0
-		if ((check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) ||
-			(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
-			(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)) {
-			pHalData->MinUndecoratedPWDBForDM = pHalData->EntryMinUndecoratedSmoothedPWDB;
-			/*ODM_RT_TRACE(pDM_Odm,COMP_BB_POWERSAVING, DBG_LOUD, ("AP Client PWDB = 0x%x\n", pHalData->MinUndecoratedPWDBForDM)); */
-		} else { /*for STA mode */
-			pHalData->MinUndecoratedPWDBForDM = pHalData->UndecoratedSmoothedPWDB;
-			/*ODM_RT_TRACE(pDM_Odm,COMP_BB_POWERSAVING, DBG_LOUD, ("STA Default Port PWDB = 0x%x\n", pHalData->MinUndecoratedPWDBForDM)); */
-		}
-#else
-		pHalData->MinUndecoratedPWDBForDM = pHalData->EntryMinUndecoratedSmoothedPWDB;
-#endif
-	} else { /* associated entry pwdb */
-		pHalData->MinUndecoratedPWDBForDM = pHalData->EntryMinUndecoratedSmoothedPWDB;
-		/*ODM_RT_TRACE(pDM_Odm,COMP_BB_POWERSAVING, DBG_LOUD, ("AP Ext Port or disconnect PWDB = 0x%x\n", pHalData->MinUndecoratedPWDBForDM)); */
-	}
-
-	/*odm_FindMinimumRSSI_Dmsp(pAdapter); */
-	/*DBG_8192C("%s=>MinUndecoratedPWDBForDM(%d)\n",__func__,pHalData->MinUndecoratedPWDBForDM); */
-	/*ODM_RT_TRACE(pDM_Odm,COMP_DIG, DBG_LOUD, ("MinUndecoratedPWDBForDM =%d\n",pHalData->MinUndecoratedPWDBForDM)); */
-}
-#endif
 
 VOID
 rtl8188f_HalDmWatchDog(
@@ -410,23 +243,20 @@ rtl8188f_HalDmWatchDog(
 )
 {
 	BOOLEAN		bFwCurrentInPSMode = _FALSE;
-	BOOLEAN		bFwPSAwake = _TRUE;
+	u8 bFwPSAwake = _TRUE;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
 
-#ifdef CONFIG_CONCURRENT_MODE
-	PADAPTER pbuddy_adapter = Adapter->pbuddy_adapter;
-#endif /*CONFIG_CONCURRENT_MODE */
-
+#ifdef CONFIG_MP_INCLUDED
 	if (Adapter->registrypriv.mp_mode == 1 && Adapter->mppriv.mp_dm == 0) /* for MP power tracking */
 		return;
-
+#endif
 
 	if (!rtw_is_hw_init_completed(Adapter))
 		goto skip_dm;
 
 #ifdef CONFIG_LPS
 	bFwCurrentInPSMode = adapter_to_pwrctl(Adapter)->bFwCurrentInPSMode;
-	rtw_hal_get_hwreg(Adapter, HW_VAR_FWLPS_RF_ON, (u8 *)(&bFwPSAwake));
+	rtw_hal_get_hwreg(Adapter, HW_VAR_FWLPS_RF_ON, &bFwPSAwake);
 #endif
 
 #ifdef CONFIG_P2P
@@ -437,11 +267,8 @@ rtl8188f_HalDmWatchDog(
 #endif /*CONFIG_P2P */
 
 	if ((rtw_is_hw_init_completed(Adapter))
-		&& ((!bFwCurrentInPSMode) && bFwPSAwake)) {
-		/* */
-		/* Calculate Tx/Rx statistics. */
-		/* */
-		dm_CheckStatistics(Adapter);
+	    && ((!bFwCurrentInPSMode) && bFwPSAwake)) {
+
 		rtw_hal_check_rxfifo_full(Adapter);
 		/* */
 		/* Dynamically switch RTS/CTS protection. */
@@ -458,39 +285,10 @@ rtl8188f_HalDmWatchDog(
 #endif
 	}
 
-	/*ODM */
-	if (rtw_is_hw_init_completed(Adapter)) {
-		u8	bLinked = _FALSE;
-		u8	bsta_state = _FALSE;
-		u8	bBtDisabled = _TRUE;
-
-		if (rtw_linked_check(Adapter)) {
-			bLinked = _TRUE;
-			if (check_fwstate(&Adapter->mlmepriv, WIFI_STATION_STATE))
-				bsta_state = _TRUE;
-		}
-
-#ifdef CONFIG_CONCURRENT_MODE
-		if (pbuddy_adapter && rtw_linked_check(pbuddy_adapter)) {
-			bLinked = _TRUE;
-			if (pbuddy_adapter && check_fwstate(&pbuddy_adapter->mlmepriv, WIFI_STATION_STATE))
-				bsta_state = _TRUE;
-		}
-#endif /*CONFIG_CONCURRENT_MODE */
-
-		ODM_CmnInfoUpdate(&pHalData->odmpriv , ODM_CMNINFO_LINK, bLinked);
-		ODM_CmnInfoUpdate(&pHalData->odmpriv , ODM_CMNINFO_STATION_STATE, bsta_state);
-
-		/*FindMinimumRSSI_8188f(Adapter); */
-		/*ODM_CmnInfoUpdate(&pHalData->odmpriv ,ODM_CMNINFO_RSSI_MIN, pHalData->MinUndecoratedPWDBForDM); */
-
-#ifdef CONFIG_BT_COEXIST
-		bBtDisabled = rtw_btcoex_IsBtDisabled(Adapter);
-#endif /* CONFIG_BT_COEXIST */
-		ODM_CmnInfoUpdate(&pHalData->odmpriv, ODM_CMNINFO_BT_ENABLED, ((bBtDisabled == _TRUE) ? _FALSE : _TRUE));
-
-		ODM_DMWatchdog(&pHalData->odmpriv);
-	}
+#ifdef CONFIG_DISABLE_ODM
+	goto skip_dm;
+#endif
+	rtw_phydm_watchdog(Adapter);
 
 skip_dm:
 
@@ -507,115 +305,20 @@ skip_dm:
 	return;
 }
 
-void rtl8188f_hal_dm_in_lps(PADAPTER padapter)
-{
-	u32	PWDB_rssi = 0;
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	pDIG_T	pDM_DigTable = &pDM_Odm->DM_DigTable;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta = NULL;
-
-	DBG_871X("%s, RSSI_Min=%d\n", __func__, pDM_Odm->RSSI_Min);
-
-	/*update IGI */
-	ODM_Write_DIG(pDM_Odm, pDM_Odm->RSSI_Min);
-
-
-	/*set rssi to fw */
-	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
-	if (psta && (psta->rssi_stat.UndecoratedSmoothedPWDB > 0)) {
-		PWDB_rssi = (psta->mac_id | (psta->rssi_stat.UndecoratedSmoothedPWDB << 16));
-
-		rtl8188f_set_rssi_cmd(padapter, (u8 *)&PWDB_rssi);
-	}
-
-}
-
-void rtl8188f_HalDmWatchDog_in_LPS(IN	PADAPTER	Adapter)
-{
-	u8	bLinked = _FALSE;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct mlme_priv 	*pmlmepriv = &Adapter->mlmepriv;
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	pDIG_T	pDM_DigTable = &pDM_Odm->DM_DigTable;
-	struct sta_priv *pstapriv = &Adapter->stapriv;
-	struct sta_info *psta = NULL;
-#ifdef CONFIG_CONCURRENT_MODE
-	PADAPTER pbuddy_adapter = Adapter->pbuddy_adapter;
-#endif /*CONFIG_CONCURRENT_MODE */
-
-	if (!rtw_is_hw_init_completed(Adapter))
-		goto skip_lps_dm;
-
-
-	if (rtw_linked_check(Adapter))
-		bLinked = _TRUE;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (pbuddy_adapter && rtw_linked_check(pbuddy_adapter))
-		bLinked = _TRUE;
-#endif /*CONFIG_CONCURRENT_MODE */
-
-	ODM_CmnInfoUpdate(&pHalData->odmpriv , ODM_CMNINFO_LINK, bLinked);
-
-	if (bLinked == _FALSE)
-		goto skip_lps_dm;
-
-	if (!(pDM_Odm->SupportAbility & ODM_BB_RSSI_MONITOR))
-		goto skip_lps_dm;
-
-
-	/*ODM_DMWatchdog(&pHalData->odmpriv); */
-	/*Do DIG by RSSI In LPS-32K */
-
-	/*.1 Find MIN-RSSI */
-	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
-	if (psta == NULL)
-		goto skip_lps_dm;
-
-	pHalData->EntryMinUndecoratedSmoothedPWDB = psta->rssi_stat.UndecoratedSmoothedPWDB;
-
-	DBG_871X("CurIGValue=%d, EntryMinUndecoratedSmoothedPWDB = %d\n", pDM_DigTable->CurIGValue, pHalData->EntryMinUndecoratedSmoothedPWDB);
-
-	if (pHalData->EntryMinUndecoratedSmoothedPWDB <= 0)
-		goto skip_lps_dm;
-
-	pHalData->MinUndecoratedPWDBForDM = pHalData->EntryMinUndecoratedSmoothedPWDB;
-
-	pDM_Odm->RSSI_Min = pHalData->MinUndecoratedPWDBForDM;
-
-	/*if(pDM_DigTable->CurIGValue != pDM_Odm->RSSI_Min) */
-	if ((pDM_DigTable->CurIGValue > pDM_Odm->RSSI_Min + 5) ||
-		(pDM_DigTable->CurIGValue < pDM_Odm->RSSI_Min - 5))
-
-	{
-#ifdef CONFIG_LPS
-		rtw_dm_in_lps_wk_cmd(Adapter);
-#endif
-	}
-
-
-skip_lps_dm:
-
-	return;
-
-}
-
 void rtl8188f_init_dm_priv(IN PADAPTER Adapter)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T 		podmpriv = &pHalData->odmpriv;
+	struct dm_struct		*podmpriv = &pHalData->odmpriv;
 	Init_ODM_ComInfo_8188f(Adapter);
-	ODM_InitAllTimers(podmpriv);
+	odm_init_all_timers(podmpriv);
+
 }
 
 void rtl8188f_deinit_dm_priv(IN PADAPTER Adapter)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T 		podmpriv = &pHalData->odmpriv;
-	ODM_CancelAllTimers(podmpriv);
+	struct dm_struct		*podmpriv = &pHalData->odmpriv;
 
-}
+	odm_cancel_all_timers(podmpriv);
 
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_hal_init.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_hal_init.c
index d8b7b631ebe6..af5c7becf7eb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_hal_init.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_hal_init.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,19 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _HAL_INIT_C_
 
 #include <rtl8188f_hal.h>
 #include "hal_com_h2c.h"
+#include "hal8188f_fw.h"
 
 #if 0 /* FW tx packet write */
-#define FW_DOWNLOAD_SIZE_8188F 8192
+	#define FW_DOWNLOAD_SIZE_8188F 8192
 #endif
 
 static VOID
@@ -50,7 +47,7 @@ _FWDownloadEnable(
 			rtw_msleep_os(1);
 		} while (count++ < 100);
 		if (count > 0)
-			DBG_871X("%s: !!!!!!!!Write 0x80 Fail!: count = %d\n", __func__, count);
+			RTW_INFO("%s: !!!!!!!!Write 0x80 Fail!: count = %d\n", __func__, count);
 
 		/* 8051 reset */
 		tmp = rtw_read8(padapter, REG_MCUFWDL + 2);
@@ -84,7 +81,7 @@ _BlockWrite(
 #endif
 
 #ifdef CONFIG_USB_HCI
-	blockSize_p1 = 254;
+	blockSize_p1 = 196; /* the same as 8188e */
 #endif
 
 	/*printk("====>%s %d\n", __func__, __LINE__); */
@@ -93,11 +90,7 @@ _BlockWrite(
 	blockCount_p1 = buffSize / blockSize_p1;
 	remainSize_p1 = buffSize % blockSize_p1;
 
-	if (blockCount_p1) {
-		RT_TRACE(_module_hal_init_c_, _drv_notice_,
-				 ("_BlockWrite: [P1] buffSize(%d) blockSize_p1(%d) blockCount_p1(%d) remainSize_p1(%d)\n",
-				  buffSize, blockSize_p1, blockCount_p1, remainSize_p1));
-	}
+
 
 	for (i = 0; i < blockCount_p1; i++) {
 #ifdef CONFIG_USB_HCI
@@ -124,7 +117,7 @@ _BlockWrite(
 		case 1:
 			remainFW[0] = *(p);
 			ret = rtw_write32(padapter, (FW_8188F_START_ADDRESS + blockCount_p1 * blockSize_p1),
-							  le32_to_cpu(*(u32 *)remainFW));
+					  le32_to_cpu(*(u32 *)remainFW));
 		}
 		return ret;
 	}
@@ -137,11 +130,7 @@ _BlockWrite(
 		blockCount_p2 = remainSize_p1 / blockSize_p2;
 		remainSize_p2 = remainSize_p1 % blockSize_p2;
 
-		if (blockCount_p2) {
-			RT_TRACE(_module_hal_init_c_, _drv_notice_,
-					 ("_BlockWrite: [P2] buffSize_p2(%d) blockSize_p2(%d) blockCount_p2(%d) remainSize_p2(%d)\n",
-					  (buffSize - offset), blockSize_p2 , blockCount_p2, remainSize_p2));
-		}
+
 
 #ifdef CONFIG_USB_HCI
 		for (i = 0; i < blockCount_p2; i++) {
@@ -159,9 +148,6 @@ _BlockWrite(
 
 		blockCount_p3 = remainSize_p2 / blockSize_p3;
 
-		RT_TRACE(_module_hal_init_c_, _drv_notice_,
-				 ("_BlockWrite: [P3] buffSize_p3(%d) blockSize_p3(%d) blockCount_p3(%d)\n",
-				  (buffSize - offset), blockSize_p3, blockCount_p3));
 
 		for (i = 0; i < blockCount_p3; i++) {
 			ret = rtw_write8(padapter, (FW_8188F_START_ADDRESS + offset + i), *(bufferPtr + offset + i));
@@ -255,7 +241,6 @@ _WriteFW(
 			goto exit;
 		}
 	}
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("_WriteFW Done- for Normal chip.\n"));
 
 exit:
 	return ret;
@@ -297,14 +282,14 @@ void _8051Reset8188(PADAPTER padapter)
 	cpu_rst |= BIT(2);
 	rtw_write8(padapter, REG_SYS_FUNC_EN + 1, cpu_rst);
 
-	DBG_8192C("%s: Finish\n", __func__);
+	RTW_INFO("%s: Finish\n", __func__);
 }
 
 static s32 polling_fwdl_chksum(_adapter *adapter, u32 min_cnt, u32 timeout_ms)
 {
 	s32 ret = _FAIL;
 	u32 value32;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 	u32 cnt = 0;
 
 	/* polling CheckSum report */
@@ -325,8 +310,8 @@ static s32 polling_fwdl_chksum(_adapter *adapter, u32 min_cnt, u32 timeout_ms)
 	ret = _SUCCESS;
 
 exit:
-	DBG_871X("%s: Checksum report %s! (%u, %dms), REG_MCUFWDL:0x%08x\n", __func__
-			 , (ret == _SUCCESS) ? "OK" : "Fail", cnt, rtw_get_passing_time_ms(start), value32);
+	RTW_INFO("%s: Checksum report %s! (%u, %dms), REG_MCUFWDL:0x%08x\n", __func__
+		, (ret == _SUCCESS) ? "OK" : "Fail", cnt, rtw_get_passing_time_ms(start), value32);
 
 	return ret;
 }
@@ -335,7 +320,7 @@ static s32 _FWFreeToGo(_adapter *adapter, u32 min_cnt, u32 timeout_ms)
 {
 	s32 ret = _FAIL;
 	u32	value32;
-	u32 start = rtw_get_current_time();
+	systime start = rtw_get_current_time();
 	u32 cnt = 0;
 	u32 value_to_check = 0;
 	u32 value_expected = (MCUFWDL_RDY | FWDL_ChkSum_rpt | WINTINI_RDY | RAM_DL_SEL);
@@ -366,8 +351,8 @@ static s32 _FWFreeToGo(_adapter *adapter, u32 min_cnt, u32 timeout_ms)
 	ret = _SUCCESS;
 
 exit:
-	DBG_871X("%s: Polling FW ready %s! (%u, %dms), REG_MCUFWDL:0x%08x\n", __func__
-			 , (ret == _SUCCESS) ? "OK" : "Fail", cnt, rtw_get_passing_time_ms(start), value32);
+	RTW_INFO("%s: Polling FW ready %s! (%u, %dms), REG_MCUFWDL:0x%08x\n", __func__
+		, (ret == _SUCCESS) ? "OK" : "Fail", cnt, rtw_get_passing_time_ms(start), value32);
 
 	return ret;
 }
@@ -381,9 +366,9 @@ void rtl8188f_FirmwareSelfReset(PADAPTER padapter)
 	u8	Delay = 100;
 
 	if (!(IS_FW_81xxC(padapter) &&
-		  ((pHalData->FirmwareVersion < 0x21) ||
-		   (pHalData->FirmwareVersion == 0x21 &&
-			pHalData->FirmwareSubVersion < 0x01)))) { /* after 88C Fw v33.1 */
+	      ((pHalData->firmware_version < 0x21) ||
+	       (pHalData->firmware_version == 0x21 &&
+		pHalData->firmware_sub_version < 0x01)))) { /* after 88C Fw v33.1 */
 		/*0x1cf=0x20. Inform 8051 to reset. 2009.12.25. tynli_test */
 		rtw_write8(padapter, REG_HMETFR + 3, 0x20);
 
@@ -395,10 +380,8 @@ void rtl8188f_FirmwareSelfReset(PADAPTER padapter)
 			rtw_udelay_os(50);
 			u1bTmp = rtw_read8(padapter, REG_SYS_FUNC_EN + 1);
 		}
-		RT_TRACE(_module_hal_init_c_, _drv_notice_, ("-%s: 8051 reset success (%d)\n", __func__, Delay));
 
 		if (Delay == 0) {
-			RT_TRACE(_module_hal_init_c_, _drv_notice_, ("%s: Force 8051 reset!!!\n", __func__));
 			/*force firmware reset */
 			u1bTmp = rtw_read8(padapter, REG_SYS_FUNC_EN + 1);
 			rtw_write8(padapter, REG_SYS_FUNC_EN + 1, u1bTmp & (~BIT2));
@@ -407,12 +390,12 @@ void rtl8188f_FirmwareSelfReset(PADAPTER padapter)
 }
 
 #ifdef CONFIG_FILE_FWIMG
-extern char *rtw_fw_file_path;
-extern char *rtw_fw_wow_file_path;
-#ifdef CONFIG_MP_INCLUDED
-extern char *rtw_fw_mp_bt_file_path;
-#endif /* CONFIG_MP_INCLUDED */
-u8 FwBuffer[FW_8188F_SIZE];
+	extern char *rtw_fw_file_path;
+	extern char *rtw_fw_wow_file_path;
+	#ifdef CONFIG_MP_INCLUDED
+		extern char *rtw_fw_mp_bt_file_path;
+	#endif /* CONFIG_MP_INCLUDED */
+	u8 FwBuffer[FW_8188F_SIZE];
 #endif /* CONFIG_FILE_FWIMG */
 
 #ifdef CONFIG_MP_INCLUDED
@@ -433,7 +416,7 @@ int _WriteBTFWtoTxPktBuf8188F(
 	pu1Byte				FwbufferPtr = (pu1Byte)buffer;
 	/*PRT_TCB			pTcb, ptempTcb; */
 	/*PRT_TX_LOCAL_BUFFER pBuf; */
-	BOOLEAN				bRecover = _FALSE;
+
 	pu1Byte				ReservedPagePacket = NULL;
 	pu1Byte				pGenBufReservedPagePacket = NULL;
 	u4Byte				TotalPktLen, txpktbuf_bndy;
@@ -456,8 +439,8 @@ int _WriteBTFWtoTxPktBuf8188F(
 #endif
 
 	if ((TotalPktLen + TXDESC_OFFSET) > MAX_CMDBUF_SZ) {
-		DBG_871X(" WARNING %s => Total packet len = %d > MAX_CMDBUF_SZ:%d\n"
-				 , __func__, (TotalPktLen + TXDESC_OFFSET), MAX_CMDBUF_SZ);
+		RTW_INFO(" WARNING %s => Total packet len = %d > MAX_CMDBUF_SZ:%d\n"
+			, __func__, (TotalPktLen + TXDESC_OFFSET), MAX_CMDBUF_SZ);
 		return _FAIL;
 	}
 
@@ -486,8 +469,6 @@ int _WriteBTFWtoTxPktBuf8188F(
 #else
 	/* Remove for temparaily because of the code on v2002 is not sync to MERGE_TMEP for USB/SDIO. */
 	/* De not remove this part on MERGE_TEMP. by tynli. */
-	/*pHalData->RegCR_1 |= (BIT0); */
-	/*PlatformEFIOWrite1Byte(Adapter,  REG_CR+1, pHalData->RegCR_1); */
 #endif
 
 	/* Disable Hw protection for a time which revserd for Hw sending beacon. */
@@ -505,10 +486,8 @@ int _WriteBTFWtoTxPktBuf8188F(
 	PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2,  tmpReg422 & (~BIT6));
 #else
 	/* 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;
-	PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2, (pHalData->RegFwHwTxQCtrl & (~BIT(6))));
-	pHalData->RegFwHwTxQCtrl &= (~ BIT(6));
+	PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2,
+		PlatformEFIORead1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2) & (~BIT6));
 #endif
 
 	/*--------------------------------------------------------- */
@@ -518,7 +497,7 @@ int _WriteBTFWtoTxPktBuf8188F(
 	txpktbuf_bndy = 10; /* rsvd page start address should be an even value. */
 	rtStatus =	InitLLTTable8188FS(Adapter, txpktbuf_bndy);
 	if (RT_STATUS_SUCCESS != rtStatus) {
-		DBG_8192C("_CheckWLANFwPatchBTFwReady_8188F(): Failed to init LLT!\n");
+		RTW_INFO("_CheckWLANFwPatchBTFwReady_8188F(): Failed to init LLT!\n");
 		return RT_STATUS_FAILURE;
 	}
 
@@ -537,13 +516,9 @@ int _WriteBTFWtoTxPktBuf8188F(
 		PlatformEFIOWrite1Byte(Adapter, REG_TDECTRL + 2, BcnValidReg & (~BIT(0)));
 
 		/*BT patch is big, we should set 0x209 < 0x40 suggested from Gimmy */
-		RT_TRACE(_module_mp_, _drv_info_, ("0x209:%x\n",
-										   PlatformEFIORead1Byte(Adapter, REG_TDECTRL + 1))); /*209 < 0x40 */
 
 		PlatformEFIOWrite1Byte(Adapter, REG_TDECTRL + 1, (0x90 - 0x20 * (times - 1)));
-		DBG_871X("0x209:0x%x\n", PlatformEFIORead1Byte(Adapter, REG_TDECTRL + 1));
-		RT_TRACE(_module_mp_, _drv_info_, ("0x209:%x\n",
-										   PlatformEFIORead1Byte(Adapter, REG_TDECTRL + 1)));
+		RTW_INFO("0x209:0x%x\n", PlatformEFIORead1Byte(Adapter, REG_TDECTRL + 1));
 
 #if 0
 		/* Acquice TX spin lock before GetFwBuf and send the packet to prevent system deadlock. */
@@ -575,7 +550,7 @@ int _WriteBTFWtoTxPktBuf8188F(
 		/*pmgntframe->buf_addr = ReservedPagePacket; */
 
 		_rtw_memcpy((u8 *)(pmgntframe->buf_addr + txdesc_offset), ReservedPagePacket, FwBufLen);
-		DBG_871X("[%d]===>TotalPktLen + TXDESC_OFFSET TotalPacketLen:%d\n", DLBcnCount, (FwBufLen + txdesc_offset));
+		RTW_INFO("[%d]===>TotalPktLen + TXDESC_OFFSET TotalPacketLen:%d\n", DLBcnCount, (FwBufLen + txdesc_offset));
 
 #ifdef CONFIG_PCI_HCI
 		dump_mgntframe(Adapter, pmgntframe);
@@ -592,10 +567,9 @@ int _WriteBTFWtoTxPktBuf8188F(
 			/*PlatformSleepUs(10); */
 			rtw_msleep_os(1);
 			BcnValidReg = PlatformEFIORead1Byte(Adapter, REG_TDECTRL + 2);
-			RT_TRACE(_module_mp_, _drv_notice_, ("Poll 0x20A = %x\n", BcnValidReg));
 		}
 		DLBcnCount++;
-		/*DBG_871X("##0x208:%08x,0x210=%08x\n",PlatformEFIORead4Byte(Adapter, REG_TDECTRL),PlatformEFIORead4Byte(Adapter, 0x210)); */
+		/*RTW_INFO("##0x208:%08x,0x210=%08x\n",PlatformEFIORead4Byte(Adapter, REG_TDECTRL),PlatformEFIORead4Byte(Adapter, 0x210)); */
 
 		PlatformEFIOWrite1Byte(Adapter, REG_TDECTRL + 2, BcnValidReg);
 
@@ -604,13 +578,13 @@ int _WriteBTFWtoTxPktBuf8188F(
 
 #endif
 	if (DLBcnCount >= 5) {
-		DBG_871X(" check rsvd page download OK DLBcnCount =%d\n", DLBcnCount);
+		RTW_INFO(" check rsvd page download OK DLBcnCount =%d\n", DLBcnCount);
 		rtStatus = _FAIL;
 		goto exit;
 	}
 
 	if (!(BcnValidReg & BIT(0))) {
-		DBG_871X("_WriteFWtoTxPktBuf(): 1 Download RSVD page failed!\n");
+		RTW_INFO("_WriteFWtoTxPktBuf(): 1 Download RSVD page failed!\n");
 		rtStatus = _FAIL;
 		goto exit;
 	}
@@ -628,7 +602,7 @@ int _WriteBTFWtoTxPktBuf8188F(
 exit:
 
 	if (pGenBufReservedPagePacket) {
-		DBG_871X("_WriteBTFWtoTxPktBuf8188F => rtw_mfree pGenBufReservedPagePacket!\n");
+		RTW_INFO("_WriteBTFWtoTxPktBuf8188F => rtw_mfree pGenBufReservedPagePacket!\n");
 		rtw_mfree((u8 *)pGenBufReservedPagePacket, TotalPktLen);
 	}
 	return rtStatus;
@@ -652,7 +626,6 @@ SetFwBTFwPatchCmd(
 	u8 addr2 = 0x10;
 	u8 addr3 = 0x80;
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("SetFwBTFwPatchCmd(): FwSize = %d\n", FwSize));
 
 	SET_8188F_H2CCMD_BT_FW_PATCH_SIZE(u1BTFwPatchParm, FwSize);
 	SET_8188F_H2CCMD_BT_FW_PATCH_ADDR0(u1BTFwPatchParm, addr0);
@@ -662,7 +635,6 @@ SetFwBTFwPatchCmd(
 
 	FillH2CCmd8188F(Adapter, H2C_8188F_BT_FW_PATCH, H2C_BT_FW_PATCH_LEN, u1BTFwPatchParm);
 
-	RT_TRACE(_module_mp_, _drv_notice_, ("<----SetFwBTFwPatchCmd(): FwSize = %d\n", FwSize));
 }
 
 void
@@ -673,11 +645,8 @@ SetFwBTPwrCmd(
 {
 	u1Byte		u1BTPwrIdxParm[H2C_FORCE_BT_TXPWR_LEN] = {0};
 
-	RT_TRACE(_module_mp_, _drv_info_, ("SetFwBTPwrCmd(): idx = %d\n", PwrIdx));
 	SET_8188F_H2CCMD_BT_PWR_IDX(u1BTPwrIdxParm, PwrIdx);
 
-	RT_TRACE(_module_mp_, _drv_info_, ("SetFwBTPwrCmd(): %x %x %x\n",
-									   u1BTPwrIdxParm[0], u1BTPwrIdxParm[1], u1BTPwrIdxParm[2]));
 
 	FillH2CCmd8188F(Adapter, H2C_8188F_FORCE_BT_TXPWR, H2C_FORCE_BT_TXPWR_LEN, u1BTPwrIdxParm);
 }
@@ -689,7 +658,8 @@ SetFwBTPwrCmd(
 /* */
 int
 _CheckWLANFwPatchBTFwReady(
-	IN	PADAPTER			Adapter
+	PADAPTER Adapter,
+	BOOLEAN bRecover
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
@@ -708,18 +678,11 @@ _CheckWLANFwPatchBTFwReady(
 		}
 
 		count++;
-		RT_TRACE(_module_mp_, _drv_info_, ("0x88=%x, wait for 50 ms (%d) times.\n",
-										   u1bTmp, count));
 		rtw_msleep_os(50); /* 50ms */
 	} while (!((u1bTmp & BIT6) || (u1bTmp & BIT7)) && count < 50);
 
-	RT_TRACE(_module_mp_, _drv_notice_,
-			 ("_CheckWLANFwPatchBTFwReady(): Polling ready bit 0x88[7] for %d times.\n", count));
 
-	if (count >= 50) {
-		RT_TRACE(_module_mp_, _drv_notice_,
-				 ("_CheckWLANFwPatchBTFwReady(): Polling ready bit 0x88[7] FAIL!!\n"));
-	}
+
 
 	/*--------------------------------------------------------- */
 	/* Reset beacon setting to the initial value. */
@@ -740,13 +703,12 @@ _CheckWLANFwPatchBTFwReady(
 	/* 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 0/*(DEV_BUS_TYPE == RT_PCI_INTERFACE) */
-	u1bTmp = PlatformEFIORead1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2);
-	PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2, (u1bTmp | BIT6));
-#else
-	PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2, (pHalData->RegFwHwTxQCtrl | BIT(6)));
-	pHalData->RegFwHwTxQCtrl |= BIT(6);
-#endif
+
+	if (bRecover) {
+		u1bTmp = PlatformEFIORead1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2);
+		PlatformEFIOWrite1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2, (u1bTmp | BIT6));
+	}
+
 
 	/* Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
 	u1bTmp = PlatformEFIORead1Byte(Adapter, REG_CR_8188F + 1);
@@ -763,7 +725,7 @@ int ReservedPage_Compare(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware, u32 BTPatc
 
 	myBTFwBuffer = rtw_zmalloc(BTPatchSize);
 	if (myBTFwBuffer == NULL) {
-		DBG_871X("%s can't be executed due to the failed malloc.\n", __func__);
+		RTW_INFO("%s can't be executed due to the failed malloc.\n", __func__);
 		Adapter->mppriv.bTxBufCkFail = _TRUE;
 		return _FALSE;
 	}
@@ -789,7 +751,7 @@ int ReservedPage_Compare(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware, u32 BTPatc
 				break;
 			}
 			count++;
-			DBG_871X("0x140=%x, wait for 10 ms (%d) times.\n", u1bTmp, count);
+			RTW_INFO("0x140=%x, wait for 10 ms (%d) times.\n", u1bTmp, count);
 			rtw_msleep_os(10); /* 10ms */
 		} while (!(u1bTmp & BIT(23)) && count < 50);
 
@@ -817,7 +779,7 @@ int ReservedPage_Compare(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware, u32 BTPatc
 			break;
 		}
 		count++;
-		DBG_871X("0x140=%x, wait for 10 ms (%d) times.\n", u1bTmp, count);
+		RTW_INFO("0x140=%x, wait for 10 ms (%d) times.\n", u1bTmp, count);
 		rtw_msleep_os(10); /* 10ms */
 	} while (!(u1bTmp & BIT(23)) && count < 50);
 
@@ -827,7 +789,7 @@ int ReservedPage_Compare(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware, u32 BTPatc
 
 	for (i = 0; i < BTPatchSize; i++) {
 		if (myBTFwBuffer[i] != pFirmware->szFwBuffer[i]) {
-			DBG_871X(" In direct myBTFwBuffer[%d]=%x , pFirmware->szFwBuffer=%x\n", i, myBTFwBuffer[i], pFirmware->szFwBuffer[i]);
+			RTW_INFO(" In direct myBTFwBuffer[%d]=%x , pFirmware->szFwBuffer=%x\n", i, myBTFwBuffer[i], pFirmware->szFwBuffer[i]);
 			Adapter->mppriv.bTxBufCkFail = _TRUE;
 			break;
 		}
@@ -858,6 +820,8 @@ s32 FirmwareDownloadBT(PADAPTER padapter, PRT_MP_FIRMWARE pFirmware)
 	u32 BTFirmwareLen;
 	u8 download_time;
 	s8 i;
+	u8 RegFwHwTxQCtrl = 0;
+	BOOLEAN bRecover = _FALSE;
 
 
 	rtStatus = _SUCCESS;
@@ -868,13 +832,13 @@ s32 FirmwareDownloadBT(PADAPTER padapter, PRT_MP_FIRMWARE pFirmware)
 	/* Patch BT Fw. Download BT RAM code to Tx packet buffer. */
 	/* */
 	if (padapter->bBTFWReady) {
-		DBG_8192C("%s: BT Firmware is ready!!\n", __func__);
+		RTW_INFO("%s: BT Firmware is ready!!\n", __func__);
 		return _FAIL;
 	}
 
 #ifdef CONFIG_FILE_FWIMG
 	if (rtw_is_file_readable(rtw_fw_mp_bt_file_path) == _TRUE) {
-		DBG_8192C("%s: acquire MP BT FW from file:%s\n", __func__, rtw_fw_mp_bt_file_path);
+		RTW_INFO("%s: acquire MP BT FW from file:%s\n", __func__, rtw_fw_mp_bt_file_path);
 
 		rtStatus = rtw_retrieve_from_file(rtw_fw_mp_bt_file_path, FwBuffer, FW_8188F_SIZE);
 		BTFirmwareLen = rtStatus >= 0 ? rtStatus : 0;
@@ -883,7 +847,7 @@ s32 FirmwareDownloadBT(PADAPTER padapter, PRT_MP_FIRMWARE pFirmware)
 #endif /* CONFIG_FILE_FWIMG */
 	{
 #ifdef CONFIG_EMBEDDED_FWIMG
-		DBG_8192C("%s: Download MP BT FW from header\n", __func__);
+		RTW_INFO("%s: Download MP BT FW from header\n", __func__);
 
 		pBTFirmwareBuf = (u8 *)Rtl8188FFwBTImgArray;
 		BTFirmwareLen = Rtl8188FFwBTImgArrayLength;
@@ -892,26 +856,30 @@ s32 FirmwareDownloadBT(PADAPTER padapter, PRT_MP_FIRMWARE pFirmware)
 #endif /* CONFIG_EMBEDDED_FWIMG */
 	}
 
-	DBG_8192C("%s: MP BT Firmware size=%d\n", __func__, BTFirmwareLen);
+	RTW_INFO("%s: MP BT Firmware size=%d\n", __func__, BTFirmwareLen);
 
 	/* for h2c cam here should be set to  true */
-	padapter->bFWReady = _TRUE;
+	GET_HAL_DATA(padapter)->bFWReady = _TRUE;
 
 	download_time = (BTFirmwareLen + 4095) / 4096;
-	DBG_8192C("%s: download_time is %d\n", __func__, download_time);
+	RTW_INFO("%s: download_time is %d\n", __func__, download_time);
+	RegFwHwTxQCtrl = rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2);
+
+	if (RegFwHwTxQCtrl & BIT(6))
+		bRecover = _TRUE;
 
 	/* Download BT patch Fw. */
 	for (i = (download_time - 1); i >= 0; i--) {
 		if (i == (download_time - 1)) {
 			rtStatus = _WriteBTFWtoTxPktBuf8188F(padapter, pBTFirmwareBuf + (4096 * i), (BTFirmwareLen - (4096 * i)), 1);
-			DBG_8192C("%s: start %d, len %d, time 1\n", __func__, 4096 * i, BTFirmwareLen - (4096 * i));
+			RTW_INFO("%s: start %d, len %d, time 1\n", __func__, 4096 * i, BTFirmwareLen - (4096 * i));
 		} else {
 			rtStatus = _WriteBTFWtoTxPktBuf8188F(padapter, pBTFirmwareBuf + (4096 * i), 4096, (download_time - i));
-			DBG_8192C("%s: start %d, len 4096, time %d\n", __func__, 4096 * i, download_time - i);
+			RTW_INFO("%s: start %d, len 4096, time %d\n", __func__, 4096 * i, download_time - i);
 		}
 
 		if (rtStatus != _SUCCESS) {
-			DBG_8192C("%s: BT Firmware download to Tx packet buffer fail!\n", __func__);
+			RTW_INFO("%s: BT Firmware download to Tx packet buffer fail!\n", __func__);
 			padapter->bBTFWReady = _FALSE;
 			return rtStatus;
 		}
@@ -921,9 +889,9 @@ s32 FirmwareDownloadBT(PADAPTER padapter, PRT_MP_FIRMWARE pFirmware)
 
 	padapter->bBTFWReady = _TRUE;
 	SetFwBTFwPatchCmd(padapter, (u16)BTFirmwareLen);
-	rtStatus = _CheckWLANFwPatchBTFwReady(padapter);
+	rtStatus = _CheckWLANFwPatchBTFwReady(padapter, bRecover);
 
-	DBG_8192C("<===%s: return %s!\n", __func__, rtStatus == _SUCCESS ? "SUCCESS" : "FAIL");
+	RTW_INFO("<===%s: return %s!\n", __func__, rtStatus == _SUCCESS ? "SUCCESS" : "FAIL");
 
 	return rtStatus;
 }
@@ -977,7 +945,7 @@ u8 send_fw_packet(PADAPTER padapter, u8 *pRam_code, u32 length)
 	pTx_data_buffer = rtw_zmalloc(modify_ram_size);
 
 	if (NULL == pTx_data_buffer) {
-		DBG_871X("Allocate buffer fail!!\n");
+		RTW_INFO("Allocate buffer fail!!\n");
 		return _FALSE;
 	}
 
@@ -1030,7 +998,7 @@ u8 send_fw_packet(PADAPTER padapter, u8 *pRam_code, u32 length)
 	rtw_sctx_init(&sctx_tmp, 10);
 	xmit_buf_tmp.sctx = &sctx_tmp;
 	if (rtw_write_port(padapter, pdvobjpriv->Queue2Pipe[BCN_QUEUE_INX], xmit_buf_tmp.len, (u8 *)&xmit_buf_tmp) == _FAIL) {
-		DBG_871X("rtw_write_port fail\n");
+		RTW_INFO("rtw_write_port fail\n");
 		return _FAIL;
 	}
 #endif
@@ -1039,7 +1007,7 @@ u8 send_fw_packet(PADAPTER padapter, u8 *pRam_code, u32 length)
 	counter = 100;
 	do {
 		if (0 == counter) {
-			DBG_871X("DMA time out!!\n");
+			RTW_INFO("DMA time out!!\n");
 			return _FALSE;
 		}
 		value8 = rtw_read8(padapter, REG_DWBCN0_CTRL_8188F + 2);
@@ -1078,7 +1046,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 {
 	s32	rtStatus = _SUCCESS;
 	u8 write_fw = 0;
-	u32 fwdl_start_time;
+	systime fwdl_start_time;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 	u8			*FwImage;
 	u32			FwImageLen;
@@ -1100,10 +1068,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("+%s\n", __func__));
-#ifdef CONFIG_WOWLAN
-	RT_TRACE(_module_hal_init_c_, _drv_notice_, ("+%s, bUsedWoWLANFw:%d\n", __func__, bUsedWoWLANFw));
-#endif
+
 	pFirmware = (PRT_FIRMWARE_8188F)rtw_zmalloc(sizeof(RT_FIRMWARE_8188F));
 
 	if (!pFirmware) {
@@ -1123,7 +1088,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 		tmp_ps = rtw_read8(padapter, 0xa0);
 		tmp_ps &= 0x03;
 		if (tmp_ps != 0x01) {
-			DBG_871X(FUNC_ADPT_FMT" tmp_ps=%x\n", FUNC_ADPT_ARG(padapter), tmp_ps);
+			RTW_INFO(FUNC_ADPT_FMT" tmp_ps=%x\n", FUNC_ADPT_ARG(padapter), tmp_ps);
 			pdbgpriv->dbg_downloadfw_pwr_state_cnt++;
 		}
 	}
@@ -1145,7 +1110,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 
 #ifdef CONFIG_FILE_FWIMG
 	if (rtw_is_file_readable(fwfilepath) == _TRUE) {
-		DBG_8192C("%s acquire FW from file:%s\n", __func__, fwfilepath);
+		RTW_INFO("%s acquire FW from file:%s\n", __func__, fwfilepath);
 		pFirmware->eFWSource = FW_SOURCE_IMG_FILE;
 	} else
 #endif /* CONFIG_FILE_FWIMG */
@@ -1167,37 +1132,34 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 		break;
 
 	case FW_SOURCE_HEADER_FILE:
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 		if (bUsedWoWLANFw) {
-			if (!pwrpriv->wowlan_ap_mode) {
-				ODM_ConfigFWWithHeaderFile(&pHalData->odmpriv,
-										   CONFIG_FW_WoWLAN,
-										   (u8 *)&pFirmware->szFwBuffer,
-										   &pFirmware->ulFwLength);
-
-				DBG_8192C(" ===> %s fw: %s, size: %d\n",
-						  __func__, "WoWLAN",
-						  pFirmware->ulFwLength);
-			} else {
-				ODM_ConfigFWWithHeaderFile(&pHalData->odmpriv,
-										   CONFIG_FW_AP,
-										   (u8 *)&pFirmware->szFwBuffer,
-										   &pFirmware->ulFwLength);
-
-				DBG_8192C(" ===> %s fw: %s, size: %d\n",
-						  __func__, "AP_WoWLAN",
-						  pFirmware->ulFwLength);
+	#ifdef CONFIG_WOWLAN
+			if (pwrpriv->wowlan_mode) {
+				pFirmware->szFwBuffer = array_mp_8188f_fw_wowlan;
+				pFirmware->ulFwLength = array_length_mp_8188f_fw_wowlan;
+
+				RTW_INFO(" ===> %s fw: %s, size: %d\n",
+					 __func__, "WoWLAN",
+					 pFirmware->ulFwLength);
 			}
-		} else
-#endif /* CONFIG_WOWLAN */
-		{
-			ODM_ConfigFWWithHeaderFile(&pHalData->odmpriv
-				/* , CONFIG_FW_WoWLAN functions of NIC is included in WoWLAN */
-				, CONFIG_FW_NIC /* functions of NIC is separated from WoWLAN starting from V0200 */
-				, (u8 *)&pFirmware->szFwBuffer
-				, &pFirmware->ulFwLength
-			);
-			DBG_8192C("%s fw: %s, size: %d\n", __func__
+	#endif /* CONFIG_WOWLAN */
+
+	#ifdef CONFIG_AP_WOWLAN
+			if (pwrpriv->wowlan_ap_mode) {
+				pFirmware->szFwBuffer = array_mp_8188f_fw_ap;
+				pFirmware->ulFwLength = array_length_mp_8188f_fw_ap;
+
+				RTW_INFO(" ===> %s fw: %s, size: %d\n",
+					 __func__, "AP_WoWLAN",
+					 pFirmware->ulFwLength);
+			}
+	#endif /* CONFIG_AP_WOWLAN */
+		} else {
+			/* CONFIG_FW_WoWLAN functions of NIC is included in WoWLAN */
+			/* functions of NIC is separated from WoWLAN starting from V0200 */
+			pFirmware->szFwBuffer = array_mp_8188f_fw_nic;
+			pFirmware->ulFwLength = array_length_mp_8188f_fw_nic;
+			RTW_INFO("%s fw: %s, size: %d\n", __func__
 				/*, "FW_WoWLAN" */
 				, "FW_NIC"
 				, pFirmware->ulFwLength);
@@ -1205,9 +1167,9 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 		break;
 	}
 
-	if (pFirmware->ulFwLength > FW_8188F_SIZE) {
+	if ((pFirmware->ulFwLength - 32) > FW_8188F_SIZE) {
 		rtStatus = _FAIL;
-		DBG_871X_LEVEL(_drv_emerg_, "Firmware size:%u exceed %u\n", pFirmware->ulFwLength, FW_8188F_SIZE);
+		RTW_ERR("Firmware size:%u exceed %u\n", pFirmware->ulFwLength, FW_8188F_SIZE);
 		goto exit;
 	}
 
@@ -1217,16 +1179,16 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 	/* To Check Fw header. Added by tynli. 2009.12.04. */
 	pFwHdr = (PRT_8188F_FIRMWARE_HDR)pFirmwareBuf;
 
-	pHalData->FirmwareVersion =  le16_to_cpu(pFwHdr->Version);
-	pHalData->FirmwareSubVersion = le16_to_cpu(pFwHdr->Subversion);
+	pHalData->firmware_version =  le16_to_cpu(pFwHdr->Version);
+	pHalData->firmware_sub_version = le16_to_cpu(pFwHdr->Subversion);
 	pHalData->FirmwareSignature = le16_to_cpu(pFwHdr->Signature);
 
-	DBG_871X("%s: fw_ver=%x fw_subver=%04x sig=0x%x, Month=%02x, Date=%02x, Hour=%02x, Minute=%02x\n",
-			 __func__, pHalData->FirmwareVersion, pHalData->FirmwareSubVersion, pHalData->FirmwareSignature
-			 , pFwHdr->Month, pFwHdr->Date, pFwHdr->Hour, pFwHdr->Minute);
+	RTW_INFO("%s: fw_ver=%x fw_subver=%04x sig=0x%x, Month=%02x, Date=%02x, Hour=%02x, Minute=%02x\n",
+		__func__, pHalData->firmware_version, pHalData->firmware_sub_version, pHalData->FirmwareSignature
+		 , pFwHdr->Month, pFwHdr->Date, pFwHdr->Hour, pFwHdr->Minute);
 
 	if (IS_FW_HEADER_EXIST_8188F(pFwHdr)) {
-		DBG_871X("%s(): Shift for fw header!\n", __func__);
+		RTW_INFO("%s(): Shift for fw header!\n", __func__);
 		/* Shift 32 bytes for FW header */
 		pFirmwareBuf = pFirmwareBuf + 32;
 		FirmwareLen = FirmwareLen - 32;
@@ -1235,7 +1197,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 	fwdl_start_time = rtw_get_current_time();
 
 #if 1
-	DBG_871X("%s by IO write!\n", __func__);
+	RTW_INFO("%s by IO write!\n", __func__);
 
 	/*
 	* Suggested by Filen. If 8051 is running in RAM code, driver should inform Fw to reset by itself,
@@ -1249,7 +1211,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 	_FWDownloadEnable(padapter, _TRUE);
 
 	while (!RTW_CANNOT_IO(padapter)
-		   && (write_fw++ < 3 || rtw_get_passing_time_ms(fwdl_start_time) < 500)) {
+	       && (write_fw++ < 3 || rtw_get_passing_time_ms(fwdl_start_time) < 500)) {
 		/* reset FWDL chksum */
 		rtw_write8(padapter, REG_MCUFWDL, rtw_read8(padapter, REG_MCUFWDL) | FWDL_ChkSum_rpt);
 
@@ -1262,7 +1224,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 			break;
 	}
 #else
-	DBG_871X("%s by Tx pkt write!\n", __func__);
+	RTW_INFO("%s by Tx pkt write!\n", __func__);
 
 	if ((rtw_read8(padapter, REG_MCUFWDL) & MCUFWDL_RDY) == 0) {
 		/* DLFW use HIQ only */
@@ -1308,7 +1270,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 			rtw_write8(padapter, REG_MCUFWDL + 1, rtw_read8(padapter, REG_MCUFWDL + 1) | BIT(5));
 
 			if (_FALSE == send_fw_packet(padapter, pFirmwareBuf + mem_offset, send_pkt_size)) {
-				DBG_871X("%s: Send FW fail !\n", __func__);
+				RTW_INFO("%s: Send FW fail !\n", __func__);
 				rtStatus = _FAIL;
 				goto DLFW_FAIL;
 			}
@@ -1318,7 +1280,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 			pkt_size_tmp -= send_pkt_size;
 		}
 	} else {
-		DBG_871X("%s: Download FW fail since MCUFWDL_RDY is not set!\n", __func__);
+		RTW_INFO("%s: Download FW fail since MCUFWDL_RDY is not set!\n", __func__);
 		rtStatus = _FAIL;
 		goto DLFW_FAIL;
 	}
@@ -1330,7 +1292,7 @@ s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)
 	if (_SUCCESS != rtStatus)
 		goto DLFW_FAIL;
 
-	DBG_871X("%s: DLFW OK !\n", __func__);
+	RTW_INFO("%s: DLFW OK !\n", __func__);
 
 DLFW_FAIL:
 	if (rtStatus == _FAIL) {
@@ -1340,11 +1302,11 @@ DLFW_FAIL:
 		rtw_write8(padapter, REG_MCUFWDL, value8);
 	}
 
-	DBG_871X("%s %s. write_fw:%u, %dms\n"
-			 , __func__, (rtStatus == _SUCCESS) ? "success" : "fail"
-			 , write_fw
-			 , rtw_get_passing_time_ms(fwdl_start_time)
-			);
+	RTW_INFO("%s %s. write_fw:%u, %dms\n"
+		 , __func__, (rtStatus == _SUCCESS) ? "success" : "fail"
+		 , write_fw
+		 , rtw_get_passing_time_ms(fwdl_start_time)
+		);
 
 exit:
 	if (pFirmware)
@@ -1352,7 +1314,7 @@ exit:
 
 	rtl8188f_InitializeFirmwareVars(padapter);
 
-	DBG_871X(" <=== %s()\n", __func__);
+	RTW_INFO(" <=== %s()\n", __func__);
 
 	return rtStatus;
 }
@@ -1391,7 +1353,7 @@ hal_EfuseSwitchToBank(
 #endif
 
 
-	DBG_8192C("%s: Efuse switch bank to %d\n", __func__, bank);
+	RTW_INFO("%s: Efuse switch bank to %d\n", __func__, bank);
 	if (bPseudoTest) {
 #ifdef HAL_EFUSE_MEMORY
 		pEfuseHal->fakeEfuseBank = bank;
@@ -1617,11 +1579,11 @@ Hal_EfusePowerSwitch(
 			} while (1);
 
 			if (count >= 100) {
-				DBG_8192C(FUNC_ADPT_FMT ": Leave SDIO local register suspend fail! Local 0x86=%#X\n",
-						  FUNC_ADPT_ARG(padapter), tempval);
+				RTW_INFO(FUNC_ADPT_FMT ": Leave SDIO local register suspend fail! Local 0x86=%#X\n",
+					 FUNC_ADPT_ARG(padapter), tempval);
 			} else {
-				DBG_8192C(FUNC_ADPT_FMT ": Leave SDIO local register suspend OK! Local 0x86=%#X\n",
-						  FUNC_ADPT_ARG(padapter), tempval);
+				RTW_INFO(FUNC_ADPT_FMT ": Leave SDIO local register suspend OK! Local 0x86=%#X\n",
+					 FUNC_ADPT_ARG(padapter), tempval);
 			}
 		}
 #endif /* CONFIG_SDIO_HCI */
@@ -1678,32 +1640,32 @@ hal_ReadEFuse_WiFi(
 	u16	i, total, used;
 	u8	efuse_usage = 0;
 
-	/*DBG_871X("YJ: ====>%s():_offset=%d _size_byte=%d bPseudoTest=%d\n", __func__, _offset, _size_byte, bPseudoTest); */
+	/*RTW_INFO("YJ: ====>%s():_offset=%d _size_byte=%d bPseudoTest=%d\n", __func__, _offset, _size_byte, bPseudoTest); */
 	/* */
 	/* Do NOT excess total size of EFuse table. Added by Roger, 2008.11.10. */
 	/* */
 	if ((_offset + _size_byte) > EFUSE_MAX_MAP_LEN) {
-		DBG_8192C("%s: Invalid offset(%#x) with read bytes(%#x)!!\n", __func__, _offset, _size_byte);
+		RTW_INFO("%s: Invalid offset(%#x) with read bytes(%#x)!!\n", __func__, _offset, _size_byte);
 		return;
 	}
 
 	efuseTbl = (u8 *)rtw_malloc(EFUSE_MAX_MAP_LEN);
 	if (efuseTbl == NULL) {
-		DBG_8192C("%s: alloc efuseTbl fail!\n", __func__);
+		RTW_INFO("%s: alloc efuseTbl fail!\n", __func__);
 		return;
 	}
 	/* 0xff will be efuse default value instead of 0x00. */
 	_rtw_memset(efuseTbl, 0xFF, EFUSE_MAX_MAP_LEN);
 
 
-#ifdef CONFIG_DEBUG
+#ifdef CONFIG_RTW_DEBUG
 	if (0) {
 		for (i = 0; i < 256; i++)
 			/*ReadEFuseByte(padapter, i, &efuseTbl[i], _FALSE); */
 			efuse_OneByteRead(padapter, i, &efuseTbl[i], _FALSE);
-		DBG_871X("Efuse Content:\n");
+		RTW_INFO("Efuse Content:\n");
 		for (i = 0; i < 256; i++)
-			printk("%02X%s", efuseTbl[i], (((i + 1) % 16) == 0)?"\n":" ");
+			printk("%02X%s", efuseTbl[i], (((i + 1) % 16) == 0) ? "\n" : " ");
 	}
 #endif
 
@@ -1715,19 +1677,19 @@ hal_ReadEFuse_WiFi(
 		/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest); */
 		efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
 		if (efuseHeader == 0xFF) {
-			DBG_8192C("%s: data end at address=%#x\n", __func__, eFuse_Addr - 1);
+			RTW_INFO("%s: data end at address=%#x\n", __func__, eFuse_Addr - 1);
 			break;
 		}
-		/*DBG_8192C("%s: efuse[0x%X]=0x%02X\n", __func__, eFuse_Addr-1, efuseHeader); */
+		/*RTW_INFO("%s: efuse[0x%X]=0x%02X\n", __func__, eFuse_Addr-1, efuseHeader); */
 
 		/* Check PG header for section num. */
 		if (EXT_HEADER(efuseHeader)) {	/*extended header */
 			offset = GET_HDR_OFFSET_2_0(efuseHeader);
-			/*DBG_8192C("%s: extended header offset=0x%X\n", __func__, offset); */
+			/*RTW_INFO("%s: extended header offset=0x%X\n", __func__, offset); */
 
 			/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest); */
 			efuse_OneByteRead(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest);
-			/*DBG_8192C("%s: efuse[0x%X]=0x%02X\n", __func__, eFuse_Addr-1, efuseExtHdr); */
+			/*RTW_INFO("%s: efuse[0x%X]=0x%02X\n", __func__, eFuse_Addr-1, efuseExtHdr); */
 			if (ALL_WORDS_DISABLED(efuseExtHdr))
 				continue;
 
@@ -1737,12 +1699,12 @@ hal_ReadEFuse_WiFi(
 			offset = ((efuseHeader >> 4) & 0x0f);
 			wden = (efuseHeader & 0x0f);
 		}
-		/*DBG_8192C("%s: Offset=%d Worden=0x%X\n", __func__, offset, wden); */
+		/*RTW_INFO("%s: Offset=%d Worden=0x%X\n", __func__, offset, wden); */
 
 		if (offset < EFUSE_MAX_SECTION_8188F) {
 			u16 addr;
 			/* Get word enable value from PG header */
-			/*DBG_8192C("%s: Offset=%d Worden=0x%X\n", __func__, offset, wden); */
+			/*RTW_INFO("%s: Offset=%d Worden=0x%X\n", __func__, offset, wden); */
 
 			addr = offset * PGPKT_DATA_SIZE;
 			for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
@@ -1751,19 +1713,19 @@ hal_ReadEFuse_WiFi(
 					efuseData = 0;
 					/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
 					efuse_OneByteRead(padapter, eFuse_Addr++, &efuseData, bPseudoTest);
-					/*DBG_8192C("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr-1, efuseData); */
+					/*RTW_INFO("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr-1, efuseData); */
 					efuseTbl[addr] = efuseData;
 
 					efuseData = 0;
 					/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
 					efuse_OneByteRead(padapter, eFuse_Addr++, &efuseData, bPseudoTest);
-					/*DBG_8192C("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr-1, efuseData); */
+					/*RTW_INFO("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr-1, efuseData); */
 					efuseTbl[addr + 1] = efuseData;
 				}
 				addr += 2;
 			}
 		} else {
-			DBG_8192C(KERN_ERR "%s: offset(%d) is illegal!!\n", __func__, offset);
+			RTW_ERR("%s: offset(%d) is illegal!!\n", __func__, offset);
 			eFuse_Addr += Efuse_CalculateWordCnts(wden) * 2;
 		}
 	}
@@ -1821,13 +1783,13 @@ hal_ReadEFuse_BT(
 	/* Do NOT excess total size of EFuse table. Added by Roger, 2008.11.10. */
 	/* */
 	if ((_offset + _size_byte) > EFUSE_BT_MAP_LEN) {
-		DBG_8192C("%s: Invalid offset(%#x) with read bytes(%#x)!!\n", __func__, _offset, _size_byte);
+		RTW_INFO("%s: Invalid offset(%#x) with read bytes(%#x)!!\n", __func__, _offset, _size_byte);
 		return;
 	}
 
 	efuseTbl = rtw_malloc(EFUSE_BT_MAP_LEN);
 	if (efuseTbl == NULL) {
-		DBG_8192C("%s: efuseTbl malloc fail!\n", __func__);
+		RTW_INFO("%s: efuseTbl malloc fail!\n", __func__);
 		return;
 	}
 	/* 0xff will be efuse default value instead of 0x00. */
@@ -1838,7 +1800,7 @@ hal_ReadEFuse_BT(
 
 	for (bank = 1; bank < 3; bank++) { /* 8188F Max bake 0~2 */
 		if (hal_EfuseSwitchToBank(padapter, bank, bPseudoTest) == _FALSE) {
-			DBG_8192C("%s: hal_EfuseSwitchToBank Fail!!\n", __func__);
+			RTW_INFO("%s: hal_EfuseSwitchToBank Fail!!\n", __func__);
 			goto exit;
 		}
 
@@ -1847,17 +1809,18 @@ hal_ReadEFuse_BT(
 		while (AVAILABLE_EFUSE_ADDR(eFuse_Addr)) {
 			/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest); */
 			efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
-			if (efuseHeader == 0xFF) break;
-			DBG_8192C("%s: efuse[%#X]=0x%02x (header)\n", __func__, (((bank - 1)*EFUSE_REAL_CONTENT_LEN_8188F) + eFuse_Addr - 1), efuseHeader);
+			if (efuseHeader == 0xFF)
+				break;
+			RTW_INFO("%s: efuse[%#X]=0x%02x (header)\n", __func__, (((bank - 1) * EFUSE_REAL_CONTENT_LEN_8188F) + eFuse_Addr - 1), efuseHeader);
 
 			/* Check PG header for section num. */
 			if (EXT_HEADER(efuseHeader)) {	/*extended header */
 				offset = GET_HDR_OFFSET_2_0(efuseHeader);
-				DBG_8192C("%s: extended header offset_2_0=0x%X\n", __func__, offset);
+				RTW_INFO("%s: extended header offset_2_0=0x%X\n", __func__, offset);
 
 				/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest); */
 				efuse_OneByteRead(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest);
-				DBG_8192C("%s: efuse[%#X]=0x%02x (ext header)\n", __func__, (((bank - 1)*EFUSE_REAL_CONTENT_LEN_8188F) + eFuse_Addr - 1), efuseExtHdr);
+				RTW_INFO("%s: efuse[%#X]=0x%02x (ext header)\n", __func__, (((bank - 1) * EFUSE_REAL_CONTENT_LEN_8188F) + eFuse_Addr - 1), efuseExtHdr);
 				if (ALL_WORDS_DISABLED(efuseExtHdr))
 					continue;
 
@@ -1872,7 +1835,7 @@ hal_ReadEFuse_BT(
 				u16 addr;
 
 				/* Get word enable value from PG header */
-				DBG_8192C("%s: Offset=%d Worden=%#X\n", __func__, offset, wden);
+				RTW_INFO("%s: Offset=%d Worden=%#X\n", __func__, offset, wden);
 
 				addr = offset * PGPKT_DATA_SIZE;
 				for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
@@ -1881,25 +1844,25 @@ hal_ReadEFuse_BT(
 						efuseData = 0;
 						/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
 						efuse_OneByteRead(padapter, eFuse_Addr++, &efuseData, bPseudoTest);
-						DBG_8192C("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr - 1, efuseData);
+						RTW_INFO("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr - 1, efuseData);
 						efuseTbl[addr] = efuseData;
 
 						efuseData = 0;
 						/*ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
 						efuse_OneByteRead(padapter, eFuse_Addr++, &efuseData, bPseudoTest);
-						DBG_8192C("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr - 1, efuseData);
+						RTW_INFO("%s: efuse[%#X]=0x%02X\n", __func__, eFuse_Addr - 1, efuseData);
 						efuseTbl[addr + 1] = efuseData;
 					}
 					addr += 2;
 				}
 			} else {
-				DBG_8192C("%s: offset(%d) is illegal!!\n", __func__, offset);
+				RTW_INFO("%s: offset(%d) is illegal!!\n", __func__, offset);
 				eFuse_Addr += Efuse_CalculateWordCnts(wden) * 2;
 			}
 		}
 
 		if ((eFuse_Addr - 1) < total) {
-			DBG_8192C("%s: bank(%d) data end at %#x\n", __func__, bank, eFuse_Addr - 1);
+			RTW_INFO("%s: bank(%d) data end at %#x\n", __func__, bank, eFuse_Addr - 1);
 			break;
 		}
 	}
@@ -1916,7 +1879,7 @@ hal_ReadEFuse_BT(
 	/* */
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, &total, bPseudoTest);
 	used = (EFUSE_BT_REAL_BANK_CONTENT_LEN * (bank - 1)) + eFuse_Addr - 1;
-	DBG_8192C("%s: bank(%d) data end at %#x ,used =%d\n", __func__, bank, eFuse_Addr - 1, used);
+	RTW_INFO("%s: bank(%d) data end at %#x ,used =%d\n", __func__, bank, eFuse_Addr - 1, used);
 	efuse_usage = (u8)((used * 100) / total);
 	if (bPseudoTest) {
 #ifdef HAL_EFUSE_MEMORY
@@ -1974,15 +1937,15 @@ hal_EfuseGetCurrentSize_WiFi(
 	} else
 		rtw_hal_get_hwreg(padapter, HW_VAR_EFUSE_BYTES, (u8 *)&efuse_addr);
 	start_addr = efuse_addr;
-	DBG_8192C("%s: start_efuse_addr=0x%X\n", __func__, efuse_addr);
+	RTW_INFO("%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, bPseudoTest);
 
 #if 0 /* for debug test */
 	efuse_OneByteRead(padapter, 0x1FF, &efuse_data, bPseudoTest);
-	DBG_8192C(FUNC_ADPT_FMT ": efuse raw 0x1FF=0x%02X\n",
-			  FUNC_ADPT_ARG(padapter), efuse_data);
+	RTW_INFO(FUNC_ADPT_FMT ": efuse raw 0x1FF=0x%02X\n",
+		 FUNC_ADPT_ARG(padapter), efuse_data);
 	efuse_data = 0xFF;
 #endif /* for debug test */
 
@@ -1990,19 +1953,20 @@ hal_EfuseGetCurrentSize_WiFi(
 	while (AVAILABLE_EFUSE_ADDR(efuse_addr)) {
 #if 1
 		if (efuse_OneByteRead(padapter, efuse_addr, &efuse_data, bPseudoTest) == _FALSE) {
-			DBG_8192C(KERN_ERR "%s: efuse_OneByteRead Fail! addr=0x%X !!\n", __func__, efuse_addr);
+			RTW_ERR("%s: efuse_OneByteRead Fail! addr=0x%X !!\n", __func__, efuse_addr);
 			goto error;
 		}
 #else
 		ReadEFuseByte(padapter, efuse_addr, &efuse_data, bPseudoTest);
 #endif
 
-		if (efuse_data == 0xFF) break;
+		if (efuse_data == 0xFF)
+			break;
 
 		if ((start_addr != 0) && (efuse_addr == start_addr)) {
 			count++;
-			DBG_8192C(FUNC_ADPT_FMT ": [WARNING] efuse raw 0x%X=0x%02X not 0xFF!!(%d times)\n",
-					  FUNC_ADPT_ARG(padapter), efuse_addr, efuse_data, count);
+			RTW_INFO(FUNC_ADPT_FMT ": [WARNING] efuse raw 0x%X=0x%02X not 0xFF!!(%d times)\n",
+				FUNC_ADPT_ARG(padapter), efuse_addr, efuse_data, count);
 
 			efuse_data = 0xFF;
 			if (count < 4) {
@@ -2054,7 +2018,7 @@ error:
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, &efuse_addr, bPseudoTest);
 
 exit:
-	DBG_8192C("%s: CurrentSize=%d\n", __func__, efuse_addr);
+	RTW_INFO("%s: CurrentSize=%d\n", __func__, efuse_addr);
 
 	return efuse_addr;
 }
@@ -2090,13 +2054,13 @@ hal_EfuseGetCurrentSize_BT(
 	efuse_addr = (u16)((btusedbytes % EFUSE_BT_REAL_BANK_CONTENT_LEN));
 	startBank = (u8)(1 + (btusedbytes / EFUSE_BT_REAL_BANK_CONTENT_LEN));
 
-	DBG_8192C("%s: start from bank=%d addr=0x%X\n", __func__, startBank, efuse_addr);
+	RTW_INFO("%s: start from bank=%d addr=0x%X\n", __func__, startBank, efuse_addr);
 
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_AVAILABLE_EFUSE_BYTES_BANK, &retU2, bPseudoTest);
 
 	for (bank = startBank; bank < 3; bank++) {
 		if (hal_EfuseSwitchToBank(padapter, bank, bPseudoTest) == _FALSE) {
-			DBG_8192C(KERN_ERR "%s: switch bank(%d) Fail!!\n", __func__, bank);
+			RTW_ERR("%s: switch bank(%d) Fail!!\n", __func__, bank);
 			/*bank = EFUSE_MAX_BANK; */
 			break;
 		}
@@ -2108,19 +2072,20 @@ hal_EfuseGetCurrentSize_BT(
 
 		while (AVAILABLE_EFUSE_ADDR(efuse_addr)) {
 			if (efuse_OneByteRead(padapter, efuse_addr, &efuse_data, bPseudoTest) == _FALSE) {
-				DBG_8192C(KERN_ERR "%s: efuse_OneByteRead Fail! addr=0x%X !!\n", __func__, efuse_addr);
+				RTW_ERR("%s: efuse_OneByteRead Fail! addr=0x%X !!\n", __func__, efuse_addr);
 				/*bank = EFUSE_MAX_BANK; */
 				break;
 			}
-			DBG_8192C("%s: efuse_OneByteRead ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __func__, efuse_addr, efuse_data, bank);
+			RTW_INFO("%s: efuse_OneByteRead ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __func__, efuse_addr, efuse_data, bank);
 
-			if (efuse_data == 0xFF) break;
+			if (efuse_data == 0xFF)
+				break;
 
 			if (EXT_HEADER(efuse_data)) {
 				hoffset = GET_HDR_OFFSET_2_0(efuse_data);
 				efuse_addr++;
 				efuse_OneByteRead(padapter, efuse_addr, &efuse_data, bPseudoTest);
-				DBG_8192C("%s: efuse_OneByteRead EXT_HEADER ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __func__, efuse_addr, efuse_data, bank);
+				RTW_INFO("%s: efuse_OneByteRead EXT_HEADER ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __func__, efuse_addr, efuse_data, bank);
 
 				if (ALL_WORDS_DISABLED(efuse_data)) {
 					efuse_addr++;
@@ -2135,8 +2100,8 @@ hal_EfuseGetCurrentSize_BT(
 				hworden =  efuse_data & 0x0F;
 			}
 
-			DBG_8192C(FUNC_ADPT_FMT": Offset=%d Worden=%#X\n",
-					  FUNC_ADPT_ARG(padapter), hoffset, hworden);
+			RTW_INFO(FUNC_ADPT_FMT": Offset=%d Worden=%#X\n",
+				 FUNC_ADPT_ARG(padapter), hoffset, hworden);
 
 			word_cnts = Efuse_CalculateWordCnts(hworden);
 			/*read next header */
@@ -2144,8 +2109,8 @@ hal_EfuseGetCurrentSize_BT(
 		}
 #else
 		while (bContinual &&
-			   efuse_OneByteRead(padapter, efuse_addr , &efuse_data, bPseudoTest) &&
-			   AVAILABLE_EFUSE_ADDR(efuse_addr)) {
+		       efuse_OneByteRead(padapter, efuse_addr , &efuse_data, bPseudoTest) &&
+		       AVAILABLE_EFUSE_ADDR(efuse_addr)) {
 			if (efuse_data != 0xFF) {
 				if ((efuse_data & 0x1F) == 0x0F) {	/*extended header */
 					hoffset = efuse_data;
@@ -2198,7 +2163,7 @@ hal_EfuseGetCurrentSize_BT(
 	}
 #endif
 
-	DBG_8192C("%s: CurrentSize=%d\n", __func__, retU2);
+	RTW_INFO("%s: CurrentSize=%d\n", __func__, retU2);
 	return retU2;
 }
 
@@ -2232,17 +2197,17 @@ Hal_EfuseWordEnableDataWrite(
 	u8	tmpdata[PGPKT_DATA_SIZE];
 
 
-	/*DBG_8192C("%s: efuse_addr=%#x word_en=%#x\n", __func__, efuse_addr, word_en); */
+	/*RTW_INFO("%s: efuse_addr=%#x word_en=%#x\n", __func__, efuse_addr, word_en); */
 	_rtw_memset(tmpdata, 0xFF, PGPKT_DATA_SIZE);
 
 	if (!(word_en & BIT(0))) {
 		tmpaddr = start_addr;
 		efuse_OneByteWrite(padapter, start_addr++, data[0], bPseudoTest);
 		efuse_OneByteWrite(padapter, start_addr++, data[1], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 0);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 0);
 		efuse_OneByteRead(padapter, tmpaddr, &tmpdata[0], bPseudoTest);
 		efuse_OneByteRead(padapter, tmpaddr + 1, &tmpdata[1], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 1);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 1);
 		if ((data[0] != tmpdata[0]) || (data[1] != tmpdata[1]))
 			badworden &= (~BIT(0));
 	}
@@ -2250,10 +2215,10 @@ Hal_EfuseWordEnableDataWrite(
 		tmpaddr = start_addr;
 		efuse_OneByteWrite(padapter, start_addr++, data[2], bPseudoTest);
 		efuse_OneByteWrite(padapter, start_addr++, data[3], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 0);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 0);
 		efuse_OneByteRead(padapter, tmpaddr, &tmpdata[2], bPseudoTest);
 		efuse_OneByteRead(padapter, tmpaddr + 1, &tmpdata[3], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 1);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 1);
 		if ((data[2] != tmpdata[2]) || (data[3] != tmpdata[3]))
 			badworden &= (~BIT(1));
 	}
@@ -2261,10 +2226,10 @@ Hal_EfuseWordEnableDataWrite(
 		tmpaddr = start_addr;
 		efuse_OneByteWrite(padapter, start_addr++, data[4], bPseudoTest);
 		efuse_OneByteWrite(padapter, start_addr++, data[5], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 0);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 0);
 		efuse_OneByteRead(padapter, tmpaddr, &tmpdata[4], bPseudoTest);
 		efuse_OneByteRead(padapter, tmpaddr + 1, &tmpdata[5], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 1);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 1);
 		if ((data[4] != tmpdata[4]) || (data[5] != tmpdata[5]))
 			badworden &= (~BIT(2));
 	}
@@ -2272,10 +2237,10 @@ Hal_EfuseWordEnableDataWrite(
 		tmpaddr = start_addr;
 		efuse_OneByteWrite(padapter, start_addr++, data[6], bPseudoTest);
 		efuse_OneByteWrite(padapter, start_addr++, data[7], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 0);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 0);
 		efuse_OneByteRead(padapter, tmpaddr, &tmpdata[6], bPseudoTest);
 		efuse_OneByteRead(padapter, tmpaddr + 1, &tmpdata[7], bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 1);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 1);
 		if ((data[6] != tmpdata[6]) || (data[7] != tmpdata[7]))
 			badworden &= (~BIT(3));
 	}
@@ -2304,7 +2269,7 @@ Hal_EfusePgPacketRead(
 
 	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAX_SECTION, &max_section, bPseudoTest);
 	if (offset > max_section) {
-		DBG_8192C("%s: Packet offset(%d) is illegal(>%d)!\n", __func__, offset, max_section);
+		RTW_INFO("%s: Packet offset(%d) is illegal(>%d)!\n", __func__, offset, max_section);
 		return _FALSE;
 	}
 
@@ -2322,13 +2287,14 @@ Hal_EfusePgPacketRead(
 			break;
 		}
 
-		if (efuse_data == 0xFF) break;
+		if (efuse_data == 0xFF)
+			break;
 
 		if (EXT_HEADER(efuse_data)) {
 			hoffset = GET_HDR_OFFSET_2_0(efuse_data);
 			efuse_OneByteRead(padapter, efuse_addr++, &efuse_data, bPseudoTest);
 			if (ALL_WORDS_DISABLED(efuse_data)) {
-				DBG_8192C("%s: Error!! All words disabled!\n", __func__);
+				RTW_INFO("%s: Error!! All words disabled!\n", __func__);
 				continue;
 			}
 
@@ -2345,12 +2311,12 @@ Hal_EfusePgPacketRead(
 				if (!(hworden & (0x01 << i))) {
 					/*ReadEFuseByte(padapter, efuse_addr++, &efuse_data, bPseudoTest); */
 					efuse_OneByteRead(padapter, efuse_addr++, &efuse_data, bPseudoTest);
-					/*DBG_8192C("%s: efuse[%#X]=0x%02X\n", __func__, efuse_addr+tmpidx, efuse_data); */
+					/*RTW_INFO("%s: efuse[%#X]=0x%02X\n", __func__, efuse_addr+tmpidx, efuse_data); */
 					data[i * 2] = efuse_data;
 
 					/*ReadEFuseByte(padapter, efuse_addr++, &efuse_data, bPseudoTest); */
 					efuse_OneByteRead(padapter, efuse_addr++, &efuse_data, bPseudoTest);
-					/*DBG_8192C("%s: efuse[%#X]=0x%02X\n", __func__, efuse_addr+tmpidx, efuse_data); */
+					/*RTW_INFO("%s: efuse[%#X]=0x%02X\n", __func__, efuse_addr+tmpidx, efuse_data); */
 					data[(i * 2) + 1] = efuse_data;
 				}
 			}
@@ -2374,11 +2340,11 @@ hal_EfusePgCheckAvailableAddr(
 
 
 	EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, &max_available, bPseudoTest);
-	/*DBG_8192C("%s: max_available=%d\n", __func__, max_available); */
+	/*RTW_INFO("%s: max_available=%d\n", __func__, max_available); */
 
 	current_size = Efuse_GetCurrentSize(pAdapter, efuseType, bPseudoTest);
 	if (current_size >= max_available) {
-		DBG_8192C("%s: Error!! current_size(%d)>max_available(%d)\n", __func__, current_size, max_available);
+		RTW_INFO("%s: Error!! current_size(%d)>max_available(%d)\n", __func__, current_size, max_available);
 		return _FALSE;
 	}
 	return _TRUE;
@@ -2386,7 +2352,7 @@ hal_EfusePgCheckAvailableAddr(
 
 static void
 hal_EfuseConstructPGPkt(
-	u8 				offset,
+	u8				offset,
 	u8				word_en,
 	u8				*pData,
 	PPGPKT_STRUCT	pTargetPkt)
@@ -2410,19 +2376,19 @@ wordEnMatched(
 
 	/* check if the same words are enabled both target and current PG packet */
 	if (((pTargetPkt->word_en & BIT(0)) == 0) &&
-		((pCurPkt->word_en & BIT(0)) == 0)) {
+	    ((pCurPkt->word_en & BIT(0)) == 0)) {
 		match_word_en &= ~BIT(0);				/* enable word 0 */
 	}
 	if (((pTargetPkt->word_en & BIT(1)) == 0) &&
-		((pCurPkt->word_en & BIT(1)) == 0)) {
+	    ((pCurPkt->word_en & BIT(1)) == 0)) {
 		match_word_en &= ~BIT(1);				/* enable word 1 */
 	}
 	if (((pTargetPkt->word_en & BIT(2)) == 0) &&
-		((pCurPkt->word_en & BIT(2)) == 0)) {
+	    ((pCurPkt->word_en & BIT(2)) == 0)) {
 		match_word_en &= ~BIT(2);				/* enable word 2 */
 	}
 	if (((pTargetPkt->word_en & BIT(3)) == 0) &&
-		((pCurPkt->word_en & BIT(3)) == 0)) {
+	    ((pCurPkt->word_en & BIT(3)) == 0)) {
 		match_word_en &= ~BIT(3);				/* enable word 3 */
 	}
 
@@ -2446,7 +2412,7 @@ hal_EfuseCheckIfDatafollowed(
 
 	for (i = 0; i < (word_cnts * 2); i++) {
 		if (efuse_OneByteRead(pAdapter, (startAddr + i) , &efuse_data, bPseudoTest) == _FALSE) {
-			DBG_8192C("%s: efuse_OneByteRead FAIL!!\n", __func__);
+			RTW_INFO("%s: efuse_OneByteRead FAIL!!\n", __func__);
 			bRet = _TRUE;
 			break;
 		}
@@ -2504,21 +2470,21 @@ hal_EfusePartialWriteCheck(
 			rtw_hal_get_hwreg(padapter, HW_VAR_EFUSE_BT_BYTES, (u8 *)&startAddr);
 	}
 	startAddr %= efuse_max;
-	DBG_8192C("%s: startAddr=%#X\n", __func__, startAddr);
+	RTW_INFO("%s: startAddr=%#X\n", __func__, startAddr);
 
 	while (1) {
 		if (startAddr >= efuse_max_available_len) {
 			bRet = _FALSE;
-			DBG_8192C("%s: startAddr(%d) >= efuse_max_available_len(%d)\n",
-					  __func__, startAddr, efuse_max_available_len);
+			RTW_INFO("%s: startAddr(%d) >= efuse_max_available_len(%d)\n",
+				 __func__, startAddr, efuse_max_available_len);
 			break;
 		}
 
 		if (efuse_OneByteRead(padapter, startAddr, &efuse_data, bPseudoTest) && (efuse_data != 0xFF)) {
 #if 1
 			bRet = _FALSE;
-			DBG_8192C("%s: Something Wrong! last bytes(%#X=0x%02X) is not 0xFF\n",
-					  __func__, startAddr, efuse_data);
+			RTW_INFO("%s: Something Wrong! last bytes(%#X=0x%02X) is not 0xFF\n",
+				 __func__, startAddr, efuse_data);
 			break;
 #else
 			if (EXT_HEADER(efuse_data)) {
@@ -2526,7 +2492,7 @@ hal_EfusePartialWriteCheck(
 				startAddr++;
 				efuse_OneByteRead(padapter, startAddr, &efuse_data, bPseudoTest);
 				if (ALL_WORDS_DISABLED(efuse_data)) {
-					DBG_8192C("%s: Error condition, all words disabled!", __func__);
+					RTW_INFO("%s: Error condition, all words disabled!", __func__);
 					bRet = _FALSE;
 					break;
 				} else {
@@ -2543,9 +2509,9 @@ hal_EfusePartialWriteCheck(
 			/* if same header is found but no data followed */
 			/* write some part of data followed by the header. */
 			if ((curPkt.offset == pTargetPkt->offset) &&
-				(hal_EfuseCheckIfDatafollowed(padapter, curPkt.word_cnts, startAddr + 1, bPseudoTest) == _FALSE) &&
-				wordEnMatched(pTargetPkt, &curPkt, &matched_wden) == _TRUE) {
-				DBG_8192C("%s: Need to partial write data by the previous wrote header\n", __func__);
+			    (hal_EfuseCheckIfDatafollowed(padapter, curPkt.word_cnts, startAddr + 1, bPseudoTest) == _FALSE) &&
+			    wordEnMatched(pTargetPkt, &curPkt, &matched_wden) == _TRUE) {
+				RTW_INFO("%s: Need to partial write data by the previous wrote header\n", __func__);
 				/* Here to write partial data */
 				badworden = Efuse_WordEnableDataWrite(padapter, startAddr + 1, matched_wden, pTargetPkt->data, bPseudoTest);
 				if (badworden != 0x0F) {
@@ -2575,7 +2541,7 @@ hal_EfusePartialWriteCheck(
 		} else {
 			/* not used header, 0xff */
 			*pAddr = startAddr;
-			/*DBG_8192C("%s: Started from unused header offset=%d\n", __func__, startAddr)); */
+			/*RTW_INFO("%s: Started from unused header offset=%d\n", __func__, startAddr)); */
 			bRet = _TRUE;
 			break;
 		}
@@ -2603,7 +2569,7 @@ hal_EfuseFixHeaderProcess(
 		badworden = Hal_EfuseWordEnableDataWrite(pAdapter, efuse_addr+1, pFixPkt->word_en, originaldata, bPseudoTest);
 
 		if (badworden != 0xf) {
-		
+
 			PgWriteSuccess = Efuse_PgPacketWrite(pAdapter, pFixPkt->offset, badworden, originaldata, bPseudoTest);
 			if (!PgWriteSuccess)
 				return FALSE;
@@ -2634,27 +2600,25 @@ hal_EfusePgPacketWrite1ByteHeader(
 	u8	repeatcnt = 0;
 
 
-	/*DBG_8192C("%s\n", __func__); */
+	/*	RTW_INFO("%s\n", __FUNCTION__); */
 	pg_header = ((pTargetPkt->offset << 4) & 0xf0) | pTargetPkt->word_en;
-	if (IS_HARDWARE_TYPE_8723BE(pAdapter))
-		efuse_OneByteWrite(pAdapter, 0x1FF, 00, FALSE); /* increase current */
 
 	efuse_OneByteWrite(pAdapter, efuse_addr, pg_header, bPseudoTest);
 
-	PHY_SetMacReg(pAdapter, EFUSE_TEST, BIT26, 0); 
+	phy_set_mac_reg(pAdapter, EFUSE_TEST, BIT26, 0);
 
-		efuse_OneByteRead(pAdapter, efuse_addr, &tmp_header, bPseudoTest);
+	efuse_OneByteRead(pAdapter, efuse_addr, &tmp_header, bPseudoTest);
 
-	PHY_SetMacReg(pAdapter, EFUSE_TEST, BIT26, 1);
+	phy_set_mac_reg(pAdapter, EFUSE_TEST, BIT26, 1);
 
 	while (tmp_header == 0xFF || pg_header != tmp_header) {
 		if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
-				DBG_8192C("retry %d times fail!!\n", repeatcnt);
+				RTW_ERR("retry %d times fail!!\n", repeatcnt);
 			return _FALSE;
 		}
 		efuse_OneByteWrite(pAdapter,efuse_addr, pg_header, bPseudoTest);
 		efuse_OneByteRead(pAdapter,efuse_addr, &tmp_header, bPseudoTest);
-		DBG_8192C("===>%s: Keep %d-th retrying,pg_header = 0x%X tmp_header = 0x%X\n", __func__,repeatcnt, pg_header, tmp_header);
+		RTW_ERR("===>%s: Keep %d-th retrying,pg_header = 0x%X tmp_header = 0x%X\n", __FUNCTION__,repeatcnt, pg_header, tmp_header);
 	}
 
 	if (pg_header == tmp_header)
@@ -2662,8 +2626,8 @@ hal_EfusePgPacketWrite1ByteHeader(
 	else {
 		PGPKT_STRUCT	fixPkt;
 
-		DBG_8192C(" pg_header(0x%X) != tmp_header(0x%X)\n", pg_header, tmp_header);
-		DBG_8192C("Error condition for fixed PG packet, need to cover the existed data: (Addr, Data) = (0x%X, 0x%X)\n",
+		RTW_ERR(" pg_header(0x%X) != tmp_header(0x%X)\n", pg_header, tmp_header);
+		RTW_ERR("Error condition for fixed PG packet, need to cover the existed data: (Addr, Data) = (0x%X, 0x%X)\n",
 						efuse_addr, tmp_header);
 		fixPkt.offset = (tmp_header>>4) & 0x0F;
 		fixPkt.word_en = tmp_header & 0x0F;
@@ -2690,26 +2654,26 @@ hal_EfusePgPacketWrite2ByteHeader(
 	u8	repeatcnt = 0;
 
 
-	/*DBG_8192C("%s\n", __func__); */
+	/*	RTW_INFO("%s\n", __FUNCTION__); */
 	EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_AVAILABLE_EFUSE_BYTES_BANK, &efuse_max_available_len, bPseudoTest);
 
 	efuse_addr = *pAddr;
 
 	if (efuse_addr >= efuse_max_available_len) {
-		DBG_8192C("%s: addr(%d) over avaliable(%d)!!\n", __func__, efuse_addr, efuse_max_available_len);
+		RTW_INFO("%s: addr(%d) over avaliable(%d)!!\n", __FUNCTION__, efuse_addr, efuse_max_available_len);
 		return _FALSE;
 	}
 
 	while (efuse_addr < efuse_max_available_len) {
 	pg_header = ((pTargetPkt->offset & 0x07) << 5) | 0x0F;
 		efuse_OneByteWrite(padapter, efuse_addr, pg_header, bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 0);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 0);
 		efuse_OneByteRead(padapter, efuse_addr, &tmp_header, bPseudoTest);
-		PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 1);
+		phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 1);
 
 		while (tmp_header == 0xFF || pg_header != tmp_header) {
 		if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
-				DBG_8192C("%s, Repeat over limit for pg_header!!\n", __func__);
+				RTW_INFO("%s, Repeat over limit for pg_header!!\n", __FUNCTION__);
 			return _FALSE;
 		}
 
@@ -2724,13 +2688,13 @@ hal_EfusePgPacketWrite2ByteHeader(
 	pg_header = ((pTargetPkt->offset & 0x78) << 1) | pTargetPkt->word_en;
 
 		efuse_OneByteWrite(padapter, efuse_addr, pg_header, bPseudoTest);
-			PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 0);
+			phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 0);
 		efuse_OneByteRead(padapter, efuse_addr, &tmp_header, bPseudoTest);
-			PHY_SetMacReg(padapter, EFUSE_TEST, BIT26, 1);
+			phy_set_mac_reg(padapter, EFUSE_TEST, BIT26, 1);
 
 			while (tmp_header == 0xFF || pg_header != tmp_header) {
 		if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
-					DBG_8192C("%s, Repeat over limit for ext_header!!\n", __func__);
+					RTW_INFO("%s, Repeat over limit for ext_header!!\n", __FUNCTION__);
 			return _FALSE;
 		}
 
@@ -2740,7 +2704,7 @@ hal_EfusePgPacketWrite2ByteHeader(
 
 			if ((tmp_header & 0x0F) == 0x0F) {
 				if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
-					DBG_8192C("Repeat over limit for word_en!!\n");
+					RTW_INFO("Repeat over limit for word_en!!\n");
 					return _FALSE;
 				} else {
 					efuse_addr++;
@@ -2748,8 +2712,8 @@ hal_EfusePgPacketWrite2ByteHeader(
 				}
 			} else if (pg_header != tmp_header) {
 				PGPKT_STRUCT	fixPkt;
-				DBG_8192C("Error, efuse_PgPacketWrite2ByteHeader(), offset PG fail, need to cover the existed data!!\n");
-				DBG_8192C("Error condition for offset PG fail, need to cover the existed data\n");
+				RTW_ERR("Error, efuse_PgPacketWrite2ByteHeader(), offset PG fail, need to cover the existed data!!\n");
+				RTW_ERR("Error condition for offset PG fail, need to cover the existed data\n");
 				fixPkt.offset = ((pg_header_temp & 0xE0) >> 5) | ((tmp_header & 0xF0) >> 1);
 				fixPkt.word_en = tmp_header & 0x0F;
 				fixPkt.word_cnts = Efuse_CalculateWordCnts(fixPkt.word_en);
@@ -2805,8 +2769,8 @@ hal_EfusePgPacketWriteData(
 			RTW_INFO("%s: OK!!\n", __FUNCTION__);
 			return _TRUE;
 		} else {	/* Reorganize other pg packet */
-			DBG_8192C ("Error, efuse_PgPacketWriteData(), wirte data fail!!\n");
-			DBG_8192C ("efuse_PgPacketWriteData Fail!!\n");
+			RTW_ERR ("Error, efuse_PgPacketWriteData(), wirte data fail!!\n");
+			RTW_ERR ("efuse_PgPacketWriteData Fail!!\n");
 			PgWriteSuccess = Efuse_PgPacketWrite(pAdapter, pTargetPkt->offset, badworden, pTargetPkt->data, bPseudoTest);
 			if (!PgWriteSuccess)
 				return FALSE;
@@ -2820,7 +2784,7 @@ hal_EfusePgPacketWriteData(
 static s32
 Hal_EfusePgPacketWrite(
 	PADAPTER	padapter,
-	u8 			offset,
+	u8			offset,
 	u8			word_en,
 	u8			*pData,
 	u8			bPseudoTest)
@@ -2849,7 +2813,7 @@ Hal_EfusePgPacketWrite(
 static u8
 Hal_EfusePgPacketWrite_BT(
 	PADAPTER	pAdapter,
-	u8 			offset,
+	u8			offset,
 	u8			word_en,
 	u8			*pData,
 	u8			bPseudoTest)
@@ -2884,31 +2848,31 @@ static void rtl8188f_read_chip_version(PADAPTER padapter)
 	pHalData = GET_HAL_DATA(padapter);
 
 	value32 = rtw_read32(padapter, REG_SYS_CFG);
-	pHalData->VersionID.ICType = CHIP_8188F;
-	pHalData->VersionID.ChipType = ((value32 & RTL_ID) ? TEST_CHIP : NORMAL_CHIP);
-	pHalData->VersionID.RFType = RF_TYPE_1T1R;
+	pHalData->version_id.ICType = CHIP_8188F;
+	pHalData->version_id.ChipType = ((value32 & RTL_ID) ? TEST_CHIP : NORMAL_CHIP);
+	pHalData->version_id.RFType = RF_TYPE_1T1R;
 
 	tmpvdr = (value32 & EXT_VENDOR_ID) >> EXT_VENDOR_ID_SHIFT;
 	if (tmpvdr == 0x00)
-		pHalData->VersionID.VendorType = CHIP_VENDOR_TSMC;
+		pHalData->version_id.VendorType = CHIP_VENDOR_TSMC;
 	else if (tmpvdr == 0x01)
-		pHalData->VersionID.VendorType = CHIP_VENDOR_SMIC;
+		pHalData->version_id.VendorType = CHIP_VENDOR_SMIC;
 	else if (tmpvdr == 0x02)
-		pHalData->VersionID.VendorType = CHIP_VENDOR_UMC;
+		pHalData->version_id.VendorType = CHIP_VENDOR_UMC;
 
-	pHalData->VersionID.CUTVersion = (value32 & CHIP_VER_RTL_MASK) >> CHIP_VER_RTL_SHIFT; /* IC version (CUT) */
+	pHalData->version_id.CUTVersion = (value32 & CHIP_VER_RTL_MASK) >> CHIP_VER_RTL_SHIFT; /* IC version (CUT) */
 
-	#if 0
+#if 0
 	/* For regulator mode. by tynli. 2011.01.14 */
 	pHalData->RegulatorMode = ((value32 & SPS_SEL) ? RT_LDO_REGULATOR : RT_SWITCHING_REGULATOR);
-	#endif
+#endif
 
-	#if 0
+#if 0
 	value32 = rtw_read32(padapter, REG_GPIO_OUTSTS);
-	pHalData->VersionID.ROMVer = ((value32 & RF_RL_ID) >> 20);	/* ROM code version. */
-	#endif
+	pHalData->version_id.ROMVer = ((value32 & RF_RL_ID) >> 20);	/* ROM code version. */
+#endif
 
-	#if 0
+#if 0
 	/* For multi-function consideration. Added by Roger, 2010.10.06. */
 	pHalData->MultiFunc = RT_MULTI_FUNC_NONE;
 	value32 = rtw_read32(padapter, REG_MULTI_FUNC_CTRL);
@@ -2916,20 +2880,20 @@ static void rtl8188f_read_chip_version(PADAPTER padapter)
 	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);
-	#endif
+#endif
 
 	rtw_hal_config_rftype(padapter);
 
 #if 0 /* mark for chage to use efuse */
-	if (IS_B_CUT(pHalData->VersionID) || IS_C_CUT(pHalData->VersionID)) {
-		MSG_8192C(" IS_B/C_CUT SWR up 1 level !!!!!!!!!!!!!!!!!\n");
-		PHY_SetMacReg(padapter, 0x14, BIT23 | BIT22 | BIT21 | BIT20, 0x5); /* MAC reg 0x14[23:20] = 4b'0101 (SWR 1.220V) */
-	} else if (IS_D_CUT(pHalData->VersionID))
-		MSG_8192C(" IS_D_CUT SKIP SWR !!!!!!!!!!!!!!!!!\n");
+	if (IS_B_CUT(pHalData->version_id) || IS_C_CUT(pHalData->version_id)) {
+		RTW_INFO(" IS_B/C_CUT SWR up 1 level !!!!!!!!!!!!!!!!!\n");
+		phy_set_mac_reg(padapter, 0x14, BIT23 | BIT22 | BIT21 | BIT20, 0x5); /* MAC reg 0x14[23:20] = 4b'0101 (SWR 1.220V) */
+	} else if (IS_D_CUT(pHalData->version_id))
+		RTW_INFO(" IS_D_CUT SKIP SWR !!!!!!!!!!!!!!!!!\n");
 #endif /* mark for chage to use efuse */
 
 #if 1
-	dump_chip_info(pHalData->VersionID);
+	dump_chip_info(pHalData->version_id);
 #endif
 
 }
@@ -2950,8 +2914,14 @@ void rtl8188f_InitBeaconParameters(PADAPTER padapter)
 #endif
 	rtw_write16(padapter, REG_BCN_CTRL, val16);
 
-	/* TODO: Remove these magic number */
-	rtw_write16(padapter, REG_TBTT_PROHIBIT, 0x6404);/* ms */
+	/* TBTT setup time */
+	rtw_write8(padapter, REG_TBTT_PROHIBIT, TBTT_PROHIBIT_SETUP_TIME);
+
+	/* TBTT hold time: 0x540[19:8] */
+	rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME_STOP_BCN & 0xFF);
+	rtw_write8(padapter, REG_TBTT_PROHIBIT + 2,
+		(rtw_read8(padapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME_STOP_BCN >> 8));
+
 	/* 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)
@@ -2962,11 +2932,6 @@ void rtl8188f_InitBeaconParameters(PADAPTER padapter)
 	/* beacause test chip does not contension before sending beacon. by tynli. 2009.11.03 */
 	rtw_write16(padapter, REG_BCNTCFG, 0x660F);
 
-	pHalData->RegBcnCtrlVal = rtw_read8(padapter, REG_BCN_CTRL);
-	pHalData->RegTxPause = rtw_read8(padapter, REG_TXPAUSE);
-	pHalData->RegFwHwTxQCtrl = rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2);
-	pHalData->RegReg542 = rtw_read8(padapter, REG_TBTT_PROHIBIT + 2);
-	pHalData->RegCR_1 = rtw_read8(padapter, REG_CR + 1);
 }
 
 void rtl8188f_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode)
@@ -2993,7 +2958,7 @@ void _InitBurstPktLen_8188FS(PADAPTER Adapter)
 
 	/* ARFB table 9 for 11ac 5G 2SS */
 	rtw_write32(Adapter, REG_ARFR0_8188F, 0x00000010);
-	if (IS_NORMAL_CHIP(pHalData->VersionID))
+	if (IS_NORMAL_CHIP(pHalData->version_id))
 		rtw_write32(Adapter, REG_ARFR0_8188F + 4, 0xfffff000);
 	else
 		rtw_write32(Adapter, REG_ARFR0_8188F + 4, 0x3e0ff000);
@@ -3003,41 +2968,6 @@ void _InitBurstPktLen_8188FS(PADAPTER Adapter)
 	rtw_write32(Adapter, REG_ARFR1_8188F + 4, 0x003ff000);
 }
 
-static void ResumeTxBeacon(PADAPTER padapter)
-{
-	PHAL_DATA_TYPE 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);
-	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, pHalData->RegFwHwTxQCtrl);
-	rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, 0xff);
-	pHalData->RegReg542 |= BIT(0);
-	rtw_write8(padapter, REG_TBTT_PROHIBIT + 2, pHalData->RegReg542);
-}
-
-static void StopTxBeacon(PADAPTER padapter)
-{
-	PHAL_DATA_TYPE 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);
-	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, pHalData->RegFwHwTxQCtrl);
-	rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, 0x64);
-	pHalData->RegReg542 &= ~BIT(0);
-	rtw_write8(padapter, REG_TBTT_PROHIBIT + 2, pHalData->RegReg542);
-
-	CheckFwRsvdPageContent(padapter);  /* 2010.06.23. Added by tynli. */
-}
 
 static void _BeaconFunctionEnable(PADAPTER padapter, u8 Enable, u8 Linked)
 {
@@ -3069,7 +2999,7 @@ static void rtl8188f_SetBeaconRelatedRegisters(PADAPTER padapter)
 
 	bcn_ctrl_reg = REG_BCN_CTRL;
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1)
+	if (padapter->hw_port == HW_PORT1)
 		bcn_ctrl_reg = REG_BCN_CTRL_1;
 #endif
 
@@ -3098,7 +3028,7 @@ static void rtl8188f_SetBeaconRelatedRegisters(PADAPTER padapter)
 	rtw_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) {
+	if (check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE | WIFI_AP_STATE | WIFI_MESH_STATE) == _TRUE) {
 		rtw_write8(padapter, REG_RXTSF_OFFSET_CCK, 0x50);
 		rtw_write8(padapter, REG_RXTSF_OFFSET_OFDM, 0x50);
 	}
@@ -3114,10 +3044,10 @@ static void rtl8188f_SetBeaconRelatedRegisters(PADAPTER padapter)
 void hal_notch_filter_8188f(_adapter *adapter, bool enable)
 {
 	if (enable) {
-		DBG_871X("Enable notch filter\n");
+		RTW_INFO("Enable notch filter\n");
 		rtw_write8(adapter, rOFDM0_RxDSP + 1, rtw_read8(adapter, rOFDM0_RxDSP + 1) | BIT1);
 	} else {
-		DBG_871X("Disable notch filter\n");
+		RTW_INFO("Disable notch filter\n");
 		rtw_write8(adapter, rOFDM0_RxDSP + 1, rtw_read8(adapter, rOFDM0_RxDSP + 1) & ~BIT1);
 	}
 }
@@ -3125,7 +3055,7 @@ void hal_notch_filter_8188f(_adapter *adapter, bool enable)
 u8 rtl8188f_MRateIdxToARFRId(PADAPTER padapter, u8 rate_idx)
 {
 	u8 ret = 0;
-	RT_RF_TYPE_DEF_E rftype = (RT_RF_TYPE_DEF_E)GET_RF_TYPE(padapter);
+	enum rf_type rftype = (enum rf_type)GET_RF_TYPE(padapter);
 	switch (rate_idx) {
 
 	case RATR_INX_WIRELESS_NGB:
@@ -3183,68 +3113,6 @@ u8 rtl8188f_MRateIdxToARFRId(PADAPTER padapter, u8 rate_idx)
 	return ret;
 }
 
-void UpdateHalRAMask8188F(PADAPTER padapter, u32 mac_id, u8 rssi_level)
-{
-	u32	mask, rate_bitmap;
-	u8	shortGIrate = _FALSE;
-	struct sta_info	*psta = NULL;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	u8 bw;
-
-	if (mac_id < macid_ctl->num)
-		psta = macid_ctl->sta[mac_id];
-	if (psta == NULL) {
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" macid:%u, sta is NULL\n"
-			, FUNC_ADPT_ARG(padapter), mac_id);
-		return;
-	}
-
-	bw = rtw_get_tx_bw_mode(padapter, psta);
-	shortGIrate = query_ra_short_GI(psta, bw);
-
-	mask = psta->ra_mask;
-
-	rate_bitmap = 0xffffffff;
-	rate_bitmap = ODM_Get_Rate_Bitmap(&pHalData->odmpriv, mac_id, mask, rssi_level);
-	DBG_871X("%s => mac_id:%d, networkType:0x%02x, mask:0x%08x\n\t ==> rssi_level:%d, rate_bitmap:0x%08x\n",
-			 __func__, mac_id, psta->wireless_mode, mask, rssi_level, rate_bitmap);
-
-	mask &= rate_bitmap;
-
-#ifdef CONFIG_BT_COEXIST
-	rate_bitmap = rtw_btcoex_GetRaMask(padapter);
-	mask &= ~rate_bitmap;
-#endif /* CONFIG_BT_COEXIST */
-
-#ifdef CONFIG_CMCC_TEST
-#ifdef CONFIG_BT_COEXIST
-	if (pmlmeext->cur_wireless_mode & WIRELESS_11G) {
-		if (mac_id == 0) {
-			DBG_871X("CMCC_BT update raid entry, mask=0x%x\n", mask);
-			/*mask &=0xffffffc0; //disable CCK & <12M OFDM rate for 11G mode for CMCC */
-			mask &= 0xffffff00; /*disable CCK & <24M OFDM rate for 11G mode for CMCC */
-			DBG_871X("CMCC_BT update raid entry, mask=0x%x\n", mask);
-		}
-	}
-#endif
-#endif
-
-	if (pHalData->fw_ractrl == _TRUE)
-		rtl8188f_set_FwMacIdConfig_cmd(padapter, mac_id, psta->raid, bw, shortGIrate, mask);
-
-	/*set correct initial date rate for each mac_id */
-	pHalData->INIDATA_RATE[mac_id] = psta->init_rate;
-	DBG_871X("%s(): mac_id=%d raid=0x%x bw=%d mask=0x%x init_rate=0x%x\n", __func__, mac_id, psta->raid, bw, mask, psta->init_rate);
-
-	rtw_macid_ctl_set_bw(macid_ctl, mac_id, bw);
-	rtw_macid_ctl_set_rate_bmp0(macid_ctl, mac_id, mask);
-	rtw_update_tx_rate_bmp(adapter_to_dvobj(padapter));
-}
-
 /* */
 /* 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 */
@@ -3325,28 +3193,14 @@ void rtl8188f_fill_fake_txdesc(
 
 void rtl8188f_InitAntenna_Selection(PADAPTER padapter)
 {
-	PHAL_DATA_TYPE pHalData;
-	u8 val;
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
+	if (pHalData->AntDivCfg == 0)
+		return;
 
-	pHalData = GET_HAL_DATA(padapter);
-#if 0
-	val = rtw_read8(padapter, REG_LEDCFG2);
-	/* Let 8051 take control antenna setting */
-	val |= BIT(7); /* DPDT_SEL_EN, 0x4C[23] */
-	rtw_write8(padapter, REG_LEDCFG2, val);
-#else
-	/* TODO: <20130114, Kordan> The following setting is only for DPDT and Fixed board type. */
-	/* TODO:  A better solution is configure it according EFUSE during the run-time. */
-	PHY_SetMacReg(padapter, 0x64, BIT20, 0x0);			/*0x66[4]=0 */
-	PHY_SetMacReg(padapter, 0x64, BIT24, 0x0);			/*0x66[8]=0 */
-	PHY_SetMacReg(padapter, 0x40, BIT4, 0x0);			/*0x40[4]=0 */
-	PHY_SetMacReg(padapter, 0x40, BIT3, 0x1);			/*0x40[3]=1 */
-	PHY_SetMacReg(padapter, 0x4C, BIT24, 0x1);			/*0x4C[24:23]=10 */
-	PHY_SetMacReg(padapter, 0x4C, BIT23, 0x0);			/*0x4C[24:23]=10 */
-	PHY_SetBBReg(padapter, 0x944, BIT1 | BIT0, 0x3);	/*0x944[1:0]=11 */
-	PHY_SetBBReg(padapter, 0x930, bMaskByte0, 0x77);	/*0x930[7:0]=77 */
-	PHY_SetMacReg(padapter, 0x38, BIT11, 0x1);			/*0x38[11]=1 */
+	/* LED(GPIO4) disable for AntDiv */
+	phy_set_mac_reg(padapter, 0x4C, BIT21, 0x0);
 #endif
 }
 
@@ -3384,21 +3238,29 @@ void init_hal_spec_8188f(_adapter *adapter)
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 
 	hal_spec->ic_name = "rtl8188f";
-	hal_spec->macid_num = MACID_NUM_8188F;
-	hal_spec->sec_cam_ent_num = SEC_CAM_ENT_NUM_8188F;
+	hal_spec->macid_num = 16;
+	hal_spec->sec_cam_ent_num = 16;
 	hal_spec->sec_cap = 0;
-	hal_spec->rfpath_num = 1;
+	hal_spec->rfpath_num_2g = 1;
+	hal_spec->rfpath_num_5g = 0;
 	hal_spec->max_tx_cnt = 1;
-	hal_spec->nss_num = NSS_NUM_8188F;
-	hal_spec->band_cap = BAND_CAP_8188F;
-	hal_spec->bw_cap = BW_CAP_8188F;
-	hal_spec->proto_cap = PROTO_CAP_8188F;
+	hal_spec->tx_nss_num = 1;
+	hal_spec->rx_nss_num = 1;
+	hal_spec->band_cap = BAND_CAP_2G;
+	hal_spec->bw_cap = BW_CAP_20M | BW_CAP_40M;
+	hal_spec->port_num = 2;
+	hal_spec->proto_cap = PROTO_CAP_11B | PROTO_CAP_11G | PROTO_CAP_11N;
 
 	hal_spec->wl_func = 0
-						| WL_FUNC_P2P
-						| WL_FUNC_MIRACAST
-						| WL_FUNC_TDLS
-						;
+			    | WL_FUNC_P2P
+			    | WL_FUNC_MIRACAST
+			    | WL_FUNC_TDLS
+			    ;
+
+	hal_spec->pg_txpwr_saddr = 0x10;
+
+	rtw_macid_ctl_init_sleep_reg(adapter_to_macidctl(adapter)
+		, REG_MACID_SLEEP, 0, 0, 0);
 }
 
 void rtl8188f_init_default_value(PADAPTER padapter)
@@ -3416,59 +3278,55 @@ void rtl8188f_init_default_value(PADAPTER padapter)
 
 	/*init phydm default value */
 	pHalData->bIQKInitialized = _FALSE;
-	pHalData->odmpriv.RFCalibrateInfo.TM_Trigger = 0;/*for IQK */
-	pHalData->odmpriv.RFCalibrateInfo.ThermalValue_HP_index = 0;
-	for (i = 0; i < HP_THERMAL_NUM; i++)
-		pHalData->odmpriv.RFCalibrateInfo.ThermalValue_HP[i] = 0;
 
 #if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
 	pHalData->IntrMask[0] = (u32)(
-								/* IMR_ROK				| */
-								/* IMR_RDU				| */
-								/* IMR_VODOK			| */
-								/* IMR_VIDOK			| */
-								/* IMR_BEDOK			| */
-								/* IMR_BKDOK			| */
-								/* IMR_MGNTDOK			| */
-								/* IMR_HIGHDOK			| */
-								/* IMR_CPWM				| */
-								/* IMR_CPWM2			| */
-								/* IMR_C2HCMD			| */
-								/* IMR_HISR1_IND_INT	| */
-								/* IMR_ATIMEND			| */
-								/* IMR_BCNDMAINT_E		| */
-								/* IMR_HSISR_IND_ON_INT	| */
-								/* IMR_BCNDOK0			| */
-								/* IMR_BCNDMAINT0		| */
-								/* IMR_TSF_BIT32_TOGGLE	| */
-								/* IMR_TXBCN0OK			| */
-								/* IMR_TXBCN0ERR		| */
-								/* IMR_GTINT3			| */
-								/* IMR_GTINT4			| */
-								/* IMR_TXCCK			| */
-								0);
+					/* IMR_ROK				| */
+					/* IMR_RDU				| */
+					/* IMR_VODOK			| */
+					/* IMR_VIDOK			| */
+					/* IMR_BEDOK			| */
+					/* IMR_BKDOK			| */
+					/* IMR_MGNTDOK			| */
+					/* IMR_HIGHDOK			| */
+					/* IMR_CPWM				| */
+					/* IMR_CPWM2			| */
+					/* IMR_C2HCMD			| */
+					/* IMR_HISR1_IND_INT	| */
+					/* IMR_ATIMEND			| */
+					/* IMR_BCNDMAINT_E		| */
+					/* IMR_HSISR_IND_ON_INT	| */
+					/* IMR_BCNDOK0			| */
+					/* IMR_BCNDMAINT0		| */
+					/* IMR_TSF_BIT32_TOGGLE	| */
+					/* IMR_TXBCN0OK			| */
+					/* IMR_TXBCN0ERR		| */
+					/* IMR_GTINT3			| */
+					/* IMR_GTINT4			| */
+					/* IMR_TXCCK			| */
+					0);
 
 	pHalData->IntrMask[1] = (u32)(
-								/* IMR_RXFOVW			| */
-								/* IMR_TXFOVW			| */
-								/* IMR_RXERR			| */
-								/* IMR_TXERR			| */
-								/* IMR_ATIMEND_E		| */
-								/* IMR_BCNDOK1			| */
-								/* IMR_BCNDOK2			| */
-								/* IMR_BCNDOK3			| */
-								/* IMR_BCNDOK4			| */
-								/* IMR_BCNDOK5			| */
-								/* IMR_BCNDOK6			| */
-								/* IMR_BCNDOK7			| */
-								/* IMR_BCNDMAINT1		| */
-								/* IMR_BCNDMAINT2		| */
-								/* IMR_BCNDMAINT3		| */
-								/* IMR_BCNDMAINT4		| */
-								/* IMR_BCNDMAINT5		| */
-								/* IMR_BCNDMAINT6		| */
-								/* IMR_BCNDMAINT7		| */
-								0);
+					/* IMR_RXFOVW			| */
+					/* IMR_TXFOVW			| */
+					/* IMR_RXERR			| */
+					/* IMR_TXERR			| */
+					/* IMR_ATIMEND_E		| */
+					/* IMR_BCNDOK1			| */
+					/* IMR_BCNDOK2			| */
+					/* IMR_BCNDOK3			| */
+					/* IMR_BCNDOK4			| */
+					/* IMR_BCNDOK5			| */
+					/* IMR_BCNDOK6			| */
+					/* IMR_BCNDOK7			| */
+					/* IMR_BCNDMAINT1		| */
+					/* IMR_BCNDMAINT2		| */
+					/* IMR_BCNDMAINT3		| */
+					/* IMR_BCNDMAINT4		| */
+					/* IMR_BCNDMAINT5		| */
+					/* IMR_BCNDMAINT6		| */
+					/* IMR_BCNDMAINT7		| */
+					0);
 #endif
 
 	/* init Efuse variables */
@@ -3501,7 +3359,7 @@ u8 GetEEPROMSize8188F(PADAPTER padapter)
 	/* 6: EEPROM used is 93C46, 4: boot from E-Fuse. */
 	size = (cr & BOOT_FROM_EEPROM) ? 6 : 4;
 
-	MSG_8192C("EEPROM type is %s\n", size == 4 ? "E-FUSE" : "93C46");
+	RTW_INFO("EEPROM type is %s\n", size == 4 ? "E-FUSE" : "93C46");
 
 	return size;
 }
@@ -3513,7 +3371,8 @@ u8 GetEEPROMSize8188F(PADAPTER padapter)
 /*------------------------------------------------------------------------- */
 s32 rtl8188f_InitLLTTable(PADAPTER padapter)
 {
-	u32 start, passing_time;
+	systime start;
+	u32 passing_time;
 	u32 val32;
 	s32 ret;
 
@@ -3535,8 +3394,8 @@ s32 rtl8188f_InitLLTTable(PADAPTER padapter)
 
 		passing_time = rtw_get_passing_time_ms(start);
 		if (passing_time > 1000) {
-			DBG_8192C("%s: FAIL!! REG_AUTO_LLT(0x%X)=%08x\n",
-					  __func__, REG_AUTO_LLT, val32);
+			RTW_INFO("%s: FAIL!! REG_AUTO_LLT(0x%X)=%08x\n",
+				 __func__, REG_AUTO_LLT, val32);
 			break;
 		}
 
@@ -3581,7 +3440,6 @@ void _DisableGPIO(PADAPTER	padapter)
 	/*3. Disable LED0 & 1 */
 	rtw_write16(padapter, REG_LEDCFG0, 0x8080);
 
-	/*RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Disable GPIO and LED.\n")); */
 } /*end of _DisableGPIO() */
 
 void _DisableRFAFEAndResetBB8188F(PADAPTER padapter)
@@ -3593,11 +3451,11 @@ void _DisableRFAFEAndResetBB8188F(PADAPTER padapter)
 	 * 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 eRFPath = 0, value8 = 0;
+	enum rf_path eRFPath = RF_PATH_A, value8 = 0;
 
 	rtw_write8(padapter, REG_TXPAUSE, 0xFF);
 
-	PHY_SetRFReg(padapter, (RF_PATH)eRFPath, 0x0, bMaskByte0, 0x0);
+	phy_set_rf_reg(padapter, eRFPath, 0x0, bMaskByte0, 0x0);
 
 	value8 |= APSDOFF;
 	rtw_write8(padapter, REG_APSD_CTRL, value8);/*0x40 */
@@ -3613,7 +3471,6 @@ void _DisableRFAFEAndResetBB8188F(PADAPTER padapter)
 
 	/* 2010/08/12 MH We need to set BB/GLBAL reset to save power for SS mode. */
 
-	/*RT_TRACE(COMP_INIT, DBG_LOUD, ("======> RF off and reset BB.\n")); */
 }
 
 void _DisableRFAFEAndResetBB(PADAPTER padapter)
@@ -3625,7 +3482,7 @@ void _ResetDigitalProcedure1_8188F(PADAPTER padapter, BOOLEAN bWithoutHWSM)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
-	if (IS_FW_81xxC(padapter) && (pHalData->FirmwareVersion <= 0x20)) {
+	if (IS_FW_81xxC(padapter) && (pHalData->firmware_version <= 0x20)) {
 #if 0
 		/*
 		 * f.	SYS_FUNC_EN 0x03[7:0]=0x54		reset MAC register, DCORE
@@ -3668,7 +3525,7 @@ void _ResetDigitalProcedure1_8188F(PADAPTER padapter, BOOLEAN bWithoutHWSM)
 				/*IF fw in RAM code, do reset */
 
 
-				if (padapter->bFWReady) {
+				if (pHalData->bFWReady) {
 					/* 2010/08/25 MH According to RD alfred's suggestion, we need to disable other */
 					/* HRCV INT to influence 8051 reset. */
 					rtw_write8(padapter, REG_FWIMR, 0x20);
@@ -3694,14 +3551,8 @@ void _ResetDigitalProcedure1_8188F(PADAPTER padapter, BOOLEAN bWithoutHWSM)
 						rtw_write8(padapter, REG_SYS_FUNC_EN + 1, 0x50);	/*Reset MAC and Enable 8051 */
 						rtw_mdelay_os(10);
 					}
-					/*else */
-					/*	RT_TRACE(COMP_INIT, DBG_LOUD, ("=====> 8051 reset success (%d) .\n",retry_cnts)); */
 				}
 			}
-			/*else */
-			/*{ */
-			/*	RT_TRACE(COMP_INIT, DBG_LOUD, ("=====> 8051 in ROM.\n")); */
-			/*} */
 			rtw_write8(padapter, REG_SYS_FUNC_EN + 1, 0x54);	/*Reset MAC and Enable 8051 */
 			rtw_write8(padapter, REG_MCUFWDL, 0);
 		}
@@ -3731,7 +3582,6 @@ void _ResetDigitalProcedure1_8188F(PADAPTER padapter, BOOLEAN bWithoutHWSM)
 		/* Disable all RF/BB power */
 		rtw_write8(padapter, REG_RF_CTRL, 0x00);
 	}
-	/*RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Reset Digital.\n")); */
 
 }
 
@@ -3774,7 +3624,6 @@ void _DisableAnalog(PADAPTER padapter, BOOLEAN bWithoutHWSM)
 		value8 = rtw_read8(padapter, REG_LDOV12D_CTRL);
 		value8 &= (~LDV12_EN);
 		rtw_write8(padapter, REG_LDOV12D_CTRL, value8);
-		/*RT_TRACE(COMP_INIT, DBG_LOUD, (" REG_LDOV12D_CTRL Reg0x21:0x%02x.\n",value8)); */
 	}
 
 	/*
@@ -3803,7 +3652,6 @@ void _DisableAnalog(PADAPTER padapter, BOOLEAN bWithoutHWSM)
 		rtw_write8(padapter, 0xfe10, 0x19);
 #endif
 
-	/*RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Disable Analog Reg0x04:0x%04x.\n",value16)); */
 }
 
 /* HW Auto state machine */
@@ -3826,7 +3674,6 @@ s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU)
 	/*  ==== Disable analog sequence === */
 	_DisableAnalog(padapter, _FALSE);
 
-	RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("======> Card disable finished.\n"));
 
 	return rtStatus;
 }
@@ -3837,7 +3684,6 @@ s32 CardDisableWithoutHWSM(PADAPTER padapter)
 	s32 rtStatus = _SUCCESS;
 
 
-	/*RT_TRACE(COMP_INIT, DBG_LOUD, ("======> Card Disable Without HWSM .\n")); */
 	if (RTW_CANNOT_RUN(padapter))
 		return rtStatus;
 
@@ -3856,7 +3702,6 @@ s32 CardDisableWithoutHWSM(PADAPTER padapter)
 	/*  ==== Disable analog sequence === */
 	_DisableAnalog(padapter, _TRUE);
 
-	/*RT_TRACE(COMP_INIT, DBG_LOUD, ("<====== Card Disable Without HWSM .\n")); */
 	return rtStatus;
 }
 #endif /* CONFIG_USB_HCI || CONFIG_SDIO_HCI || CONFIG_GSPI_HCI */
@@ -3887,7 +3732,6 @@ Hal_InitPGData(
 		}
 	} else {
 		/*autoload fail */
-		RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("AutoLoad Fail reported from CR9346!!\n"));
 		/*pHalData->AutoloadFailFlag = _TRUE; */
 		/*update to default value 0xFF */
 		if (_FALSE == pHalData->EepromOrEfuse)
@@ -3898,7 +3742,7 @@ Hal_InitPGData(
 #ifdef CONFIG_EFUSE_CONFIG_FILE
 	if (check_phy_efuse_tx_power_info_valid(padapter) == _FALSE) {
 		if (Hal_readPGDataFromConfigFile(padapter) != _SUCCESS)
-			DBG_871X_LEVEL(_drv_err_, "invalid phy efuse and read from file fail, will use driver default!!\n");
+			RTW_ERR("invalid phy efuse and read from file fail, will use driver default!!\n");
 	}
 #endif
 }
@@ -3916,12 +3760,11 @@ Hal_EfuseParseIDCode(
 	/* Checl 0x8129 again for making sure autoload status!! */
 	EEPROMId = le16_to_cpu(*((u16 *)hwinfo));
 	if (EEPROMId != RTL_EEPROM_ID) {
-		DBG_8192C("EEPROM ID(%#x) is invalid!!\n", EEPROMId);
+		RTW_INFO("EEPROM ID(%#x) is invalid!!\n", EEPROMId);
 		pHalData->bautoload_fail_flag = _TRUE;
 	} else
 		pHalData->bautoload_fail_flag = _FALSE;
 
-	RT_TRACE(_module_hal_init_c_, _drv_notice_, ("EEPROM ID=0x%04x\n", EEPROMId));
 }
 
 static void
@@ -3941,8 +3784,6 @@ Hal_EEValueCheck(
 		if (*pIn <= 63)
 			*pOut = *pIn;
 		else {
-			RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("EETYPE_TX_PWR, value=%d is invalid, set to default=0x%x\n",
-					 *pIn, EEPROM_Default_TxPowerLevel));
 			*pOut = EEPROM_Default_TxPowerLevel;
 		}
 	}
@@ -3954,7 +3795,7 @@ Hal_EEValueCheck(
 
 void
 Hal_EfuseParseTxPowerInfo_8188F(
-	IN	PADAPTER 		padapter,
+	IN	PADAPTER		padapter,
 	IN	u8			*PROMContent,
 	IN	BOOLEAN			AutoLoadFail
 )
@@ -3971,7 +3812,6 @@ Hal_EfuseParseTxPowerInfo_8188F(
 			pHalData->EEPROMRegulatory = (EEPROM_DEFAULT_BOARD_OPTION & 0x7);	/*bit0~2 */
 	} else
 		pHalData->EEPROMRegulatory = 0;
-	RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("EEPROMRegulatory = 0x%x\n", pHalData->EEPROMRegulatory));
 }
 
 VOID
@@ -3983,13 +3823,10 @@ Hal_EfuseParseEEPROMVer_8188F(
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
-	/*RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("%s(): AutoLoadFail = %d\n", __func__, AutoLoadFail)); */
 	if (!AutoLoadFail)
 		pHalData->EEPROMVersion = hwinfo[EEPROM_VERSION_8188F];
 	else
 		pHalData->EEPROMVersion = 1;
-	RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("Hal_EfuseParseEEPROMVer(), EEVer = %d\n",
-			 pHalData->EEPROMVersion));
 }
 
 #if 0 /* Do not need for rtl8188f */
@@ -3997,15 +3834,15 @@ VOID
 Hal_EfuseParseVoltage_8188F(
 	IN	PADAPTER		pAdapter,
 	IN	u8			*hwinfo,
-	IN	BOOLEAN 	AutoLoadFail
+	IN	BOOLEAN	AutoLoadFail
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 
 	/*_rtw_memcpy(pEEPROM->adjuseVoltageVal, &hwinfo[EEPROM_Voltage_ADDR_8188F], 1); */
-	DBG_871X("%s hwinfo[EEPROM_Voltage_ADDR_8188F] =%02x\n", __func__, hwinfo[EEPROM_Voltage_ADDR_8188F]);
+	RTW_INFO("%s hwinfo[EEPROM_Voltage_ADDR_8188F] =%02x\n", __func__, hwinfo[EEPROM_Voltage_ADDR_8188F]);
 	pHalData->adjuseVoltageVal = (hwinfo[EEPROM_Voltage_ADDR_8188F] & 0xf0) >> 4;
-	DBG_871X("%s pHalData->adjuseVoltageVal =%x\n", __func__, pHalData->adjuseVoltageVal);
+	RTW_INFO("%s pHalData->adjuseVoltageVal =%x\n", __func__, pHalData->adjuseVoltageVal);
 }
 #endif
 
@@ -4016,7 +3853,7 @@ Hal_EfuseParseChnlPlan_8188F(
 	IN	BOOLEAN			AutoLoadFail
 )
 {
-	padapter->mlmepriv.ChannelPlan = hal_com_config_channel_plan(
+	hal_com_config_channel_plan(
 		padapter
 		, hwinfo ? &hwinfo[EEPROM_COUNTRY_CODE_8188F] : NULL
 		, hwinfo ? hwinfo[EEPROM_ChannelPlan_8188F] : 0xFF
@@ -4036,18 +3873,16 @@ Hal_EfuseParseCustomerID_8188F(
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
-	/*RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("%s(): AutoLoadFail = %d\n", __func__, AutoLoadFail)); */
 	if (!AutoLoadFail)
 		pHalData->EEPROMCustomerID = hwinfo[EEPROM_CustomID_8188F];
 	else
 		pHalData->EEPROMCustomerID = 0;
-	RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("EEPROM Customer ID: 0x%2x\n", pHalData->EEPROMCustomerID));
 }
 
 VOID
 Hal_EfuseParsePowerSavingMode_8188F(
 	IN	PADAPTER		padapter,
-	IN	u8				 *hwinfo,
+	IN	u8				*hwinfo,
 	IN	BOOLEAN			AutoLoadFail
 )
 {
@@ -4073,11 +3908,11 @@ Hal_EfuseParsePowerSavingMode_8188F(
 		pwrctl->bSupportRemoteWakeup = (hwinfo[EEPROM_USB_OPTIONAL_FUNCTION0_8188FU] & BIT1) ? _TRUE : _FALSE;
 #endif /* CONFIG_USB_HCI */
 
-		DBG_871X("%s...bHWPwrPindetect(%x)-bHWPowerdown(%x) ,bSupportRemoteWakeup(%x)\n"
-				 , __FUNCTION__, pwrctl->bHWPwrPindetect, pwrctl->bHWPowerdown, pwrctl->bSupportRemoteWakeup);
+		RTW_INFO("%s...bHWPwrPindetect(%x)-bHWPowerdown(%x) ,bSupportRemoteWakeup(%x)\n"
+			, __FUNCTION__, pwrctl->bHWPwrPindetect, pwrctl->bHWPowerdown, pwrctl->bSupportRemoteWakeup);
 
-		DBG_871X("### PS params=>  power_mgnt(%x),usbss_enable(%x) ###\n"
-				 , padapter->registrypriv.power_mgnt, padapter->registrypriv.usbss_enable);
+		RTW_INFO("### PS params=>  power_mgnt(%x),usbss_enable(%x) ###\n"
+			, padapter->registrypriv.power_mgnt, padapter->registrypriv.usbss_enable);
 
 	}
 }
@@ -4085,7 +3920,7 @@ Hal_EfuseParsePowerSavingMode_8188F(
 VOID
 Hal_EfuseParseAntennaDiversity_8188F(
 	IN	PADAPTER		pAdapter,
-	IN	u8				 *hwinfo,
+	IN	u8				*hwinfo,
 	IN	BOOLEAN			AutoLoadFail
 )
 {
@@ -4093,53 +3928,56 @@ Hal_EfuseParseAntennaDiversity_8188F(
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(pAdapter);
 	struct registry_priv	*registry_par = &pAdapter->registrypriv;
 
-	if (pHalData->EEPROMBluetoothAntNum == Ant_x1)
-		pHalData->AntDivCfg = 0;
-	else {
-		if (registry_par->antdiv_cfg == 2) /* 0:OFF , 1:ON, 2:By EFUSE */
+	/* default:rtw_antdiv_cfg, 0:OFF, 1:ON, 2:By EFUSE */
+	if (registry_par->antdiv_cfg == 2) {
+		if (0x01 == hwinfo[EEPROM_RF_ANTENNA_OPT_8188F])
 			pHalData->AntDivCfg = 1;
 		else
-			pHalData->AntDivCfg = registry_par->antdiv_cfg;
-	}
+			pHalData->AntDivCfg = 0;
+	} else if (registry_par->antdiv_cfg == 1)
+		pHalData->AntDivCfg = 1;
+	else
+		pHalData->AntDivCfg = 0;
 
 	/* If TRxAntDivType is AUTO in advanced setting, use EFUSE value instead. */
+	/* default:rtw_antdiv_type */
 	if (registry_par->antdiv_type == 0) {
+#if 0
 		pHalData->TRxAntDivType = hwinfo[EEPROM_RFE_OPTION_8188F];
 		if (pHalData->TRxAntDivType == 0xFF)
-			pHalData->TRxAntDivType = S0S1_SW_ANTDIV;/*GetRegAntDivType(pAdapter); */
-		else if (pHalData->TRxAntDivType == 0x10)
-			pHalData->TRxAntDivType = S0S1_SW_ANTDIV; /*intrnal switch S0S1 */
-		else if (pHalData->TRxAntDivType == 0x11)
-			pHalData->TRxAntDivType = S0S1_SW_ANTDIV; /*intrnal switch S0S1 */
+			pHalData->TRxAntDivType = S0S1_SW_ANTDIV;
 		else
-			DBG_8192C("%s: efuse[0x%x]=0x%02x is unknown type\n",
-					  __func__, EEPROM_RFE_OPTION_8188F, pHalData->TRxAntDivType);
+			RTW_INFO("%s: efuse[0x%x]=0x%02x is unknown type\n",
+				__func__, EEPROM_RFE_OPTION_8188F, pHalData->TRxAntDivType);
+#else
+		/* 8188F only intrnal switch S0S1 */
+		pHalData->TRxAntDivType = S0S1_SW_ANTDIV;
+#endif
 	} else {
-		pHalData->TRxAntDivType = registry_par->antdiv_type;/*GetRegAntDivType(pAdapter); */
+		/* 8188F only intrnal switch S0S1 */
+		pHalData->TRxAntDivType = S0S1_SW_ANTDIV;
 	}
 
-	DBG_8192C("%s: AntDivCfg=%d, AntDivType=%d\n",
-			  __func__, pHalData->AntDivCfg, pHalData->TRxAntDivType);
+	RTW_INFO("%s: AntDivCfg=%d, AntDivType=%d\n",
+		 __func__, pHalData->AntDivCfg, pHalData->TRxAntDivType);
 #endif
 }
 
 VOID
 Hal_EfuseParseXtal_8188F(
 	IN	PADAPTER		pAdapter,
-	IN	u8			 *hwinfo,
+	IN	u8			*hwinfo,
 	IN	BOOLEAN		AutoLoadFail
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 
-	/*RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("%s(): AutoLoadFail = %d\n", __func__, AutoLoadFail)); */
 	if (!AutoLoadFail) {
-		pHalData->CrystalCap = hwinfo[EEPROM_XTAL_8188F];
-		if (pHalData->CrystalCap == 0xFF)
-			pHalData->CrystalCap = EEPROM_Default_CrystalCap_8188F;	   /*what value should 8812 set? */
+		pHalData->crystal_cap = hwinfo[EEPROM_XTAL_8188F];
+		if (pHalData->crystal_cap == 0xFF)
+			pHalData->crystal_cap = EEPROM_Default_CrystalCap_8188F;	   /*what value should 8812 set? */
 	} else
-		pHalData->CrystalCap = EEPROM_Default_CrystalCap_8188F;
-	RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("EEPROM CrystalCap: 0x%2x\n", pHalData->CrystalCap));
+		pHalData->crystal_cap = EEPROM_Default_CrystalCap_8188F;
 }
 
 
@@ -4152,37 +3990,36 @@ Hal_EfuseParseThermalMeter_8188F(
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 
-	/*RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("%s(): AutoLoadFail = %d\n", __func__, AutoLoadFail)); */
 	/* */
 	/* ThermalMeter from EEPROM */
 	/* */
 	if (_FALSE == AutoLoadFail)
-		pHalData->EEPROMThermalMeter = PROMContent[EEPROM_THERMAL_METER_8188F];
+		pHalData->eeprom_thermal_meter = PROMContent[EEPROM_THERMAL_METER_8188F];
 	else
-		pHalData->EEPROMThermalMeter = EEPROM_Default_ThermalMeter_8188F;
+		pHalData->eeprom_thermal_meter = EEPROM_Default_ThermalMeter_8188F;
 
-	if ((pHalData->EEPROMThermalMeter == 0xff) || (_TRUE == AutoLoadFail)) {
-		pHalData->odmpriv.RFCalibrateInfo.bAPKThermalMeterIgnore = _TRUE;
-		pHalData->EEPROMThermalMeter = EEPROM_Default_ThermalMeter_8188F;
+	if ((pHalData->eeprom_thermal_meter == 0xff) || (_TRUE == AutoLoadFail)) {
+		pHalData->odmpriv.rf_calibrate_info.is_apk_thermal_meter_ignore = _TRUE;
+		pHalData->eeprom_thermal_meter = EEPROM_Default_ThermalMeter_8188F;
 	}
 
-	RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("EEPROM ThermalMeter=0x%x\n", pHalData->EEPROMThermalMeter));
 }
 
+
 void Hal_EfuseParseKFreeData_8188F(
 	IN		PADAPTER		Adapter,
 	IN		u8				*PROMContent,
-	IN		BOOLEAN 		AutoloadFail)
+	IN		BOOLEAN		AutoloadFail)
 {
-#ifdef CONFIG_RF_GAIN_OFFSET
+#ifdef CONFIG_RF_POWER_TRIM
 #define THERMAL_K_MEAN_OFFSET_8188F 5 /* 8188F FT thermal K mean value has +5 offset, it's special case */
 
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
 	struct kfree_data_t *kfree_data = &pHalData->kfree_data;
 	u8 pg_pwrtrim = 0xFF, pg_therm = 0xFF;
 
-	pg_pwrtrim = EFUSE_Read1Byte(Adapter, PPG_BB_GAIN_2G_TXA_OFFSET_8188F);
-	pg_therm = EFUSE_Read1Byte(Adapter, PPG_THERMAL_OFFSET_8188F);
+	efuse_OneByteRead(Adapter, PPG_BB_GAIN_2G_TXA_OFFSET_8188F, &pg_pwrtrim, _FALSE);
+	efuse_OneByteRead(Adapter, PPG_THERMAL_OFFSET_8188F ,&pg_therm ,_FALSE);
 
 	if (pg_pwrtrim != 0xFF) {
 		kfree_data->bb_gain[BB_GAIN_2G][RF_PATH_A]
@@ -4198,15 +4035,15 @@ void Hal_EfuseParseKFreeData_8188F(
 	}
 
 	if (kfree_data->flag & KFREE_FLAG_THERMAL_K_ON)
-		pHalData->EEPROMThermalMeter -= kfree_data->thermal;
+		pHalData->eeprom_thermal_meter -= kfree_data->thermal;
 
-	DBG_871X("kfree flag:%u\n", kfree_data->flag);
+	RTW_INFO("kfree Pwr Trim flag:%u\n", kfree_data->flag);
 	if (kfree_data->flag & KFREE_FLAG_ON)
-		DBG_871X("bb_gain:%d\n", kfree_data->bb_gain[BB_GAIN_2G][RF_PATH_A]);
+		RTW_INFO("bb_gain:%d\n", kfree_data->bb_gain[BB_GAIN_2G][RF_PATH_A]);
 	if (kfree_data->flag & KFREE_FLAG_THERMAL_K_ON)
-		DBG_871X("thermal:%d\n", kfree_data->thermal);
+		RTW_INFO("thermal:%d\n", kfree_data->thermal);
 
-#endif /*CONFIG_RF_GAIN_OFFSET */
+#endif /*CONFIG_RF_POWER_TRIM */
 }
 
 u8
@@ -4218,16 +4055,16 @@ BWMapping_8188F(
 	u8	BWSettingOfDesc = 0;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
 
-	/*DBG_871X("BWMapping pHalData->CurrentChannelBW %d, pattrib->bwmode %d\n",pHalData->CurrentChannelBW,pattrib->bwmode); */
+	/*RTW_INFO("BWMapping pHalData->current_channel_bw %d, pattrib->bwmode %d\n",pHalData->current_channel_bw,pattrib->bwmode); */
 
-	if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_80) {
+	if (pHalData->current_channel_bw == CHANNEL_WIDTH_80) {
 		if (pattrib->bwmode == CHANNEL_WIDTH_80)
 			BWSettingOfDesc = 2;
 		else if (pattrib->bwmode == CHANNEL_WIDTH_40)
 			BWSettingOfDesc = 1;
 		else
 			BWSettingOfDesc = 0;
-	} else if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_40) {
+	} else if (pHalData->current_channel_bw == CHANNEL_WIDTH_40) {
 		if ((pattrib->bwmode == CHANNEL_WIDTH_40) || (pattrib->bwmode == CHANNEL_WIDTH_80))
 			BWSettingOfDesc = 1;
 		else
@@ -4246,9 +4083,9 @@ u8	SCMapping_8188F(PADAPTER Adapter, struct pkt_attrib *pattrib)
 	u8	SCSettingOfDesc = 0;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
 
-	/*DBG_871X("SCMapping: pHalData->CurrentChannelBW %d, pHalData->nCur80MhzPrimeSC %d, pHalData->nCur40MhzPrimeSC %d\n",pHalData->CurrentChannelBW,pHalData->nCur80MhzPrimeSC,pHalData->nCur40MhzPrimeSC); */
+	/*RTW_INFO("SCMapping: pHalData->current_channel_bw %d, pHalData->nCur80MhzPrimeSC %d, pHalData->nCur40MhzPrimeSC %d\n",pHalData->current_channel_bw,pHalData->nCur80MhzPrimeSC,pHalData->nCur40MhzPrimeSC); */
 
-	if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_80) {
+	if (pHalData->current_channel_bw == CHANNEL_WIDTH_80) {
 		if (pattrib->bwmode == CHANNEL_WIDTH_80)
 			SCSettingOfDesc = VHT_DATA_SC_DONOT_CARE;
 		else if (pattrib->bwmode == CHANNEL_WIDTH_40) {
@@ -4257,7 +4094,7 @@ u8	SCMapping_8188F(PADAPTER Adapter, struct pkt_attrib *pattrib)
 			else if (pHalData->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER)
 				SCSettingOfDesc = VHT_DATA_SC_40_UPPER_OF_80MHZ;
 			else
-				DBG_871X("SCMapping: DONOT CARE Mode Setting\n");
+				RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
 		} else {
 			if ((pHalData->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER) && (pHalData->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER))
 				SCSettingOfDesc = VHT_DATA_SC_20_LOWEST_OF_80MHZ;
@@ -4268,10 +4105,10 @@ u8	SCMapping_8188F(PADAPTER Adapter, struct pkt_attrib *pattrib)
 			else if ((pHalData->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER) && (pHalData->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER))
 				SCSettingOfDesc = VHT_DATA_SC_20_UPPERST_OF_80MHZ;
 			else
-				DBG_871X("SCMapping: DONOT CARE Mode Setting\n");
+				RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
 		}
-	} else if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_40) {
-		/*DBG_871X("SCMapping: HT Case: pHalData->CurrentChannelBW %d, pHalData->nCur40MhzPrimeSC %d\n",pHalData->CurrentChannelBW,pHalData->nCur40MhzPrimeSC); */
+	} else if (pHalData->current_channel_bw == CHANNEL_WIDTH_40) {
+		/*RTW_INFO("SCMapping: HT Case: pHalData->current_channel_bw %d, pHalData->nCur40MhzPrimeSC %d\n",pHalData->current_channel_bw,pHalData->nCur40MhzPrimeSC); */
 
 		if (pattrib->bwmode == CHANNEL_WIDTH_40)
 			SCSettingOfDesc = VHT_DATA_SC_DONOT_CARE;
@@ -4289,6 +4126,17 @@ u8	SCMapping_8188F(PADAPTER Adapter, struct pkt_attrib *pattrib)
 	return SCSettingOfDesc;
 }
 
+#if defined(CONFIG_CONCURRENT_MODE)
+void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc)
+{
+	if ((pattrib->encrypt > 0) && (!pattrib->bswenc)
+	    && (pattrib->bmc_camid != INVALID_SEC_MAC_CAM_ID)) {
+
+		SET_TX_DESC_EN_DESC_ID_8188F(ptxdesc, 1);
+		SET_TX_DESC_MACID_8188F(ptxdesc, pattrib->bmc_camid);
+	}
+}
+#endif
 
 static u8 fill_txdesc_sectype(struct pkt_attrib *pattrib)
 {
@@ -4322,7 +4170,7 @@ static u8 fill_txdesc_sectype(struct pkt_attrib *pattrib)
 
 static void fill_txdesc_vcs_8188f(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc)
 {
-	/*DBG_8192C("cvs_mode=%d\n", pattrib->vcs_mode); */
+	/*RTW_INFO("cvs_mode=%d\n", pattrib->vcs_mode); */
 
 	SET_TX_DESC_HW_RTS_ENABLE_8188F(ptxdesc, 0);
 
@@ -4357,7 +4205,7 @@ static void fill_txdesc_vcs_8188f(PADAPTER padapter, struct pkt_attrib *pattrib,
 
 static void fill_txdesc_phy_8188f(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc)
 {
-	/*DBG_8192C("bwmode=%d, ch_off=%d\n", pattrib->bwmode, pattrib->ch_offset); */
+	/*RTW_INFO("bwmode=%d, ch_off=%d\n", pattrib->bwmode, pattrib->ch_offset); */
 
 	if (pattrib->ht_en) {
 		SET_TX_DESC_DATA_BW_8188F(ptxdesc, BWMapping_8188F(padapter, pattrib));
@@ -4395,6 +4243,10 @@ static void rtl8188f_fill_default_txdesc(
 		SET_TX_DESC_SEQ_8188F(pbuf, pattrib->seqnum);
 
 		SET_TX_DESC_SEC_TYPE_8188F(pbuf, fill_txdesc_sectype(pattrib));
+#if defined(CONFIG_CONCURRENT_MODE)
+		if (bmcst)
+			fill_txdesc_force_bmc_camid(pattrib, pbuf);
+#endif
 		fill_txdesc_vcs_8188f(padapter, pattrib, pbuf);
 
 #ifdef CONFIG_P2P
@@ -4405,12 +4257,12 @@ static void rtl8188f_fill_default_txdesc(
 #endif
 
 		if ((pattrib->ether_type != 0x888e) &&
-			(pattrib->ether_type != 0x0806) &&
-			(pattrib->ether_type != 0x88B4) &&
-			(pattrib->dhcp_pkt != 1) &&
-			(drv_userate != 1)
+		    (pattrib->ether_type != 0x0806) &&
+		    (pattrib->ether_type != 0x88B4) &&
+		    (pattrib->dhcp_pkt != 1) &&
+		    (drv_userate != 1)
 #ifdef CONFIG_AUTO_AP_MODE
-			&& (pattrib->pctrl != _TRUE)
+		    && (pattrib->pctrl != _TRUE)
 #endif
 		   ) {
 			/* Non EAP & ARP & DHCP type data packet */
@@ -4434,7 +4286,11 @@ static void rtl8188f_fill_default_txdesc(
 
 				SET_TX_DESC_TX_RATE_8188F(pbuf, pHalData->INIDATA_RATE[pattrib->mac_id] & 0x7F);
 			}
-
+			if (bmcst) {
+				SET_TX_DESC_USE_RATE_8188F(pbuf, 1);
+				SET_TX_DESC_TX_RATE_8188F(pbuf, MRateToHwRate(pattrib->rate));
+				SET_TX_DESC_DISABLE_FB_8188F(pbuf, 1);
+			}
 			/* modify data rate by iwpriv */
 			if (padapter->fix_rate != 0xFF) {
 				SET_TX_DESC_USE_RATE_8188F(pbuf, 1);
@@ -4465,8 +4321,8 @@ static void rtl8188f_fill_default_txdesc(
 				SET_TX_DESC_DATA_SHORT_8188F(pbuf, 1);
 			SET_TX_DESC_TX_RATE_8188F(pbuf, MRateToHwRate(pmlmeext->tx_rate));
 
-			DBG_8192C(FUNC_ADPT_FMT ": SP Packet(0x%04X) rate=0x%x\n",
-					  FUNC_ADPT_ARG(padapter), pattrib->ether_type, MRateToHwRate(pmlmeext->tx_rate));
+			RTW_INFO(FUNC_ADPT_FMT ": SP Packet(0x%04X) rate=0x%x\n",
+				FUNC_ADPT_ARG(padapter), pattrib->ether_type, MRateToHwRate(pmlmeext->tx_rate));
 		}
 
 #if defined(CONFIG_USB_TX_AGGREGATION) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
@@ -4478,7 +4334,7 @@ static void rtl8188f_fill_default_txdesc(
 		/* CCX-TXRPT ack for xmit mgmt frames. */
 		if (pxmitframe->ack_report) {
 #ifdef DBG_CCX
-			DBG_8192C("%s set spe_rpt\n", __func__);
+			RTW_INFO("%s set spe_rpt\n", __func__);
 #endif
 			SET_TX_DESC_SPE_RPT_8188F(pbuf, 1);
 			SET_TX_DESC_SW_DEFINE_8188F(pbuf, (u8)(GET_PRIMARY_ADAPTER(padapter)->xmitpriv.seq_no));
@@ -4486,7 +4342,6 @@ static void rtl8188f_fill_default_txdesc(
 #endif /* CONFIG_XMIT_ACK */
 #endif
 	} else if (pxmitframe->frame_tag == MGNT_FRAMETAG) {
-		/* RT_TRACE(_module_hal_xmit_c_, _drv_notice_, ("%s: MGNT_FRAMETAG\n", __func__)); */
 
 		SET_TX_DESC_MACID_8188F(pbuf, pattrib->mac_id);
 		SET_TX_DESC_QUEUE_SEL_8188F(pbuf, pattrib->qsel);
@@ -4505,36 +4360,26 @@ static void rtl8188f_fill_default_txdesc(
 			SET_TX_DESC_DATA_RETRY_LIMIT_8188F(pbuf, 12);
 		}
 
-#ifdef CONFIG_INTEL_PROXIM
-		if ((padapter->proximity.proxim_on == _TRUE) && (pattrib->intel_proxim == _TRUE)) {
-			DBG_871X("\n %s pattrib->rate=%d\n", __func__, pattrib->rate);
-			SET_TX_DESC_TX_RATE_8188F(pbuf, pattrib->rate);
-		} else
-#endif
-		{
-			SET_TX_DESC_TX_RATE_8188F(pbuf, MRateToHwRate(pmlmeext->tx_rate));
-		}
+		SET_TX_DESC_TX_RATE_8188F(pbuf, MRateToHwRate(pattrib->rate));
 
 #ifdef CONFIG_XMIT_ACK
 		/* CCX-TXRPT ack for xmit mgmt frames. */
 		if (pxmitframe->ack_report) {
 #ifdef DBG_CCX
-			DBG_8192C("%s set spe_rpt\n", __func__);
+			RTW_INFO("%s set spe_rpt\n", __func__);
 #endif
 			SET_TX_DESC_SPE_RPT_8188F(pbuf, 1);
 			SET_TX_DESC_SW_DEFINE_8188F(pbuf, (u8)(GET_PRIMARY_ADAPTER(padapter)->xmitpriv.seq_no));
 		}
 #endif /* CONFIG_XMIT_ACK */
-	} else if (pxmitframe->frame_tag == TXAGG_FRAMETAG)
-		RT_TRACE(_module_hal_xmit_c_, _drv_warning_, ("%s: TXAGG_FRAMETAG\n", __func__));
+	} else if (pxmitframe->frame_tag == TXAGG_FRAMETAG) {
+	}
 #ifdef CONFIG_MP_INCLUDED
 	else if (pxmitframe->frame_tag == MP_FRAMETAG) {
-		RT_TRACE(_module_hal_xmit_c_, _drv_notice_, ("%s: MP_FRAMETAG\n", __func__));
 		fill_txdesc_for_mp(padapter, pbuf);
 	}
 #endif
 	else {
-		RT_TRACE(_module_hal_xmit_c_, _drv_warning_, ("%s: frame_tag=0x%x\n", __func__, pxmitframe->frame_tag));
 
 		SET_TX_DESC_MACID_8188F(pbuf, pattrib->mac_id);
 		SET_TX_DESC_RATE_ID_8188F(pbuf, pattrib->raid);
@@ -4580,6 +4425,11 @@ static void rtl8188f_fill_default_txdesc(
 	/* 2010.06.23. Added by tynli. */
 	if (!pattrib->qos_en)
 		SET_TX_DESC_HWSEQ_EN_8188F(pbuf, 1);
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	if (!bmcst && pattrib->psta)
+		odm_set_tx_ant_by_tx_info(adapter_to_phydm(padapter), pbuf, pattrib->psta->cmn.mac_id);
+#endif
 }
 
 /*
@@ -4591,42 +4441,16 @@ static void rtl8188f_fill_default_txdesc(
  */
 void rtl8188f_update_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf)
 {
-	PADAPTER padapter = pxmitframe->padapter;
 	rtl8188f_fill_default_txdesc(pxmitframe, pbuf);
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-	ODM_SetTxAntByTxInfo(&GET_HAL_DATA(padapter)->odmpriv, pbuf, pxmitframe->attrib.mac_id);
-#endif /* CONFIG_ANTENNA_DIVERSITY */
-
 #if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 	rtl8188f_cal_txdesc_chksum((struct tx_desc *)pbuf);
 #endif
 }
 
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-int reset_tsf(PADAPTER Adapter, u8 reset_port)
-{
-	u8 reset_cnt_before = 0, reset_cnt_after = 0, loop_cnt = 0;
-	u32 reg_reset_tsf_cnt = (IFACE_PORT0 == reset_port) ?
-							REG_FW_RESET_TSF_CNT_0 : REG_FW_RESET_TSF_CNT_1;
-
-	rtw_scan_abort(Adapter->pbuddy_adapter);	/*	site survey will cause reset_tsf fail	*/
-	reset_cnt_after = reset_cnt_before = rtw_read8(Adapter, reg_reset_tsf_cnt);
-	rtl8188f_reset_tsf(Adapter, reset_port);
-
-	while ((reset_cnt_after == reset_cnt_before) && (loop_cnt < 10)) {
-		rtw_msleep_os(100);
-		loop_cnt++;
-		reset_cnt_after = rtw_read8(Adapter, reg_reset_tsf_cnt);
-	}
-
-	return (loop_cnt >= 10) ? _FAIL : _TRUE;
-}
-#endif /* CONFIG_TSF_RESET_OFFLOAD */
-
 static void hw_var_set_monitor(PADAPTER Adapter, u8 variable, u8 *val)
 {
-	u32	value_rcr, rcr_bits;
+	u32	rcr_bits;
 	u16	value_rxfltmap2;
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
 	struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
@@ -4647,12 +4471,11 @@ static void hw_var_set_monitor(PADAPTER Adapter, u8 variable, u8 *val)
 		rcr_bits |= (RCR_ACRC32 | RCR_AICV);
 #endif
 
+		rtw_hal_get_hwreg(Adapter, HW_VAR_RCR, (u8 *)&pHalData->rcr_backup);
+		rtw_hal_set_hwreg(Adapter, HW_VAR_RCR, (u8 *)&rcr_bits);
+
 		/* Receive all data frames */
 		value_rxfltmap2 = 0xFFFF;
-
-		value_rcr = rcr_bits;
-		rtw_write32(Adapter, REG_RCR, value_rcr);
-
 		rtw_write16(Adapter, REG_RXFLTMAP2, value_rxfltmap2);
 
 #if 0
@@ -4674,8 +4497,9 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 
 	if (isMonitor == _TRUE) {
-		/* reset RCR */
-		rtw_write32(padapter, REG_RCR, pHalData->ReceiveConfig);
+		/* reset RCR from backup */
+		rtw_hal_set_hwreg(padapter, HW_VAR_RCR, (u8 *)&pHalData->rcr_backup);
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_ACTION_NONE);
 		isMonitor = _FALSE;
 	}
 
@@ -4687,9 +4511,11 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 		hw_var_set_monitor(padapter, variable, val);
 		return;
 	}
+	rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, adapter_mac_addr(padapter)); /* set mac addr to mac register */
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1) {
+	if (padapter->hw_port == HW_PORT1) {
+
 		/* disable Port1 TSF update */
 		val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
 		val8 |= DIS_TSF_UDT;
@@ -4697,11 +4523,11 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 		Set_MSR(padapter, mode);
 
-		DBG_871X("#### %s()-%d iface_type(%d) mode=%d ####\n",
-				 __func__, __LINE__, padapter->iface_type, mode);
+		RTW_INFO("#### %s()-%d hw_port(%d) mode=%d ####\n",
+			 __func__, __LINE__, padapter->hw_port, mode);
 
 		if ((mode == _HW_STATE_STATION_) || (mode == _HW_STATE_NOLINK_)) {
-			if (!check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE)) {
+			if (!rtw_mi_get_ap_num(padapter) && !rtw_mi_get_mesh_num(padapter)) {
 				StopTxBeacon(padapter);
 #ifdef CONFIG_PCI_HCI
 				UpdateInterruptMask8188FE(padapter, 0, 0, RT_BCN_INT_MASKS, 0);
@@ -4723,7 +4549,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			/* disable atim wnd and disable beacon function */
 			rtw_write8(padapter, REG_BCN_CTRL_1, DIS_TSF_UDT | DIS_ATIM);
-		} else if ((mode == _HW_STATE_ADHOC_) /*|| (mode == _HW_STATE_AP_)*/) {
+		} else if (mode == _HW_STATE_ADHOC_) {
 			ResumeTxBeacon(padapter);
 			rtw_write8(padapter, REG_BCN_CTRL_1, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_BCNQ_SUB);
 		} else if (mode == _HW_STATE_AP_) {
@@ -4732,7 +4558,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 #else /* !CONFIG_PCI_HCI */
 #ifdef CONFIG_INTERRUPT_BASED_TXBCN
 
-#ifdef  CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
+#ifdef CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
 			UpdateInterruptMask8188FU(padapter, _TRUE, IMR_BCNDMAINT0_8188F, 0);
 #endif /* CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT */
 
@@ -4747,10 +4573,6 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			rtw_write8(padapter, REG_BCN_CTRL_1, DIS_TSF_UDT | DIS_BCNQ_SUB);
 
-			/* Set RCR */
-			/*rtw_write32(padapter, REG_RCR, 0x70002a8e);//CBSSID_DATA must set to 0 */
-			/*rtw_write32(padapter, REG_RCR, 0x7000228e);//CBSSID_DATA must set to 0 */
-			rtw_write32(padapter, REG_RCR, 0x7000208e);/*CBSSID_DATA must set to 0,reject ICV_ERR packet */
 			/* enable to rx data frame */
 			rtw_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
 			/* enable to rx ps-poll */
@@ -4762,7 +4584,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 			/*rtw_write8(padapter, REG_BCN_MAX_ERR, 0xFF); */
 			rtw_write8(padapter, REG_ATIMWND_1, 0x0a); /* 10ms for port1 */
 			rtw_write16(padapter, REG_BCNTCFG, 0x00);
-			rtw_write16(padapter, REG_TBTT_PROHIBIT, 0xff04);
+
 			rtw_write16(padapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
 
 			/* reset TSF2 */
@@ -4778,9 +4600,9 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			/* select BCN on port 1 */
 			rtw_write8(padapter, REG_CCK_CHECK_8188F,
-					   (rtw_read8(padapter, REG_CCK_CHECK_8188F) | BIT_BCN_PORT_SEL));
+				(rtw_read8(padapter, REG_CCK_CHECK_8188F) | BIT_BCN_PORT_SEL));
 
-			if (check_buddy_fwstate(padapter, WIFI_FW_NULL_STATE)) {
+			if (!rtw_mi_buddy_check_fwstate(padapter, WIFI_FW_ASSOC_SUCCESS)) {
 				val8 = rtw_read8(padapter, REG_BCN_CTRL);
 				val8 &= ~EN_BCN_FUNCTION;
 				rtw_write8(padapter, REG_BCN_CTRL, val8);
@@ -4795,16 +4617,19 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 #ifdef CONFIG_TSF_RESET_OFFLOAD
 			/* Reset TSF for STA+AP concurrent mode */
-			if (check_buddy_fwstate(padapter, (WIFI_STATION_STATE | WIFI_ASOC_STATE))) {
-				if (reset_tsf(padapter, IFACE_PORT1) == _FALSE)
-					DBG_871X("ERROR! %s()-%d: Reset port1 TSF fail\n",
-							 __func__, __LINE__);
+			if (rtw_mi_buddy_check_fwstate(padapter, (WIFI_STATION_STATE | WIFI_ASOC_STATE))) {
+				if (rtw_hal_reset_tsf(padapter, HW_PORT1) == _FAIL)
+					RTW_INFO("ERROR! %s()-%d: Reset port1 TSF fail\n",
+						 __func__, __LINE__);
 			}
 #endif /* CONFIG_TSF_RESET_OFFLOAD */
 		}
 	} else /*else for port0 */
 #endif /* CONFIG_CONCURRENT_MODE */
 	{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM /*For Port0 - MBSS CAM*/
+		hw_var_set_opmode_mbid(padapter, mode);
+#else
 		/* disable Port0 TSF update */
 		val8 = rtw_read8(padapter, REG_BCN_CTRL);
 		val8 |= DIS_TSF_UDT;
@@ -4812,15 +4637,15 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 		/* set net_type */
 		Set_MSR(padapter, mode);
-		DBG_871X("#### %s() -%d iface_type(0) mode = %d ####\n", __func__, __LINE__, mode);
+		RTW_INFO("#### %s() -%d hw_port(0) mode = %d ####\n", __func__, __LINE__, mode);
 
 		if ((mode == _HW_STATE_STATION_) || (mode == _HW_STATE_NOLINK_)) {
 #ifdef CONFIG_CONCURRENT_MODE
-			if (!check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE)) {
+			if (!rtw_mi_get_ap_num(padapter) && !rtw_mi_get_mesh_num(padapter))
 				/* suspect code indent for conditional statements */
-#else
-			{
 #endif /* CONFIG_CONCURRENT_MODE */
+			{
+
 				StopTxBeacon(padapter);
 #ifdef CONFIG_PCI_HCI
 				UpdateInterruptMask8188FE(padapter, 0, 0, RT_BCN_INT_MASKS, 0);
@@ -4842,7 +4667,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 			/* disable atim wnd */
 			rtw_write8(padapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_ATIM);
 			/*rtw_write8(padapter,REG_BCN_CTRL, 0x18); */
-		} else if ((mode == _HW_STATE_ADHOC_) /*|| (mode == _HW_STATE_AP_)*/) {
+		} else if (mode == _HW_STATE_ADHOC_) {
 			ResumeTxBeacon(padapter);
 			rtw_write8(padapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_BCNQ_SUB);
 		} else if (mode == _HW_STATE_AP_) {
@@ -4865,10 +4690,6 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			rtw_write8(padapter, REG_BCN_CTRL, DIS_TSF_UDT | DIS_BCNQ_SUB);
 
-			/*Set RCR */
-			/*rtw_write32(padapter, REG_RCR, 0x70002a8e);//CBSSID_DATA must set to 0 */
-			/*rtw_write32(padapter, REG_RCR, 0x7000228e);//CBSSID_DATA must set to 0 */
-			rtw_write32(padapter, REG_RCR, 0x7000208e);/*CBSSID_DATA must set to 0,reject ICV_ERR packet */
 			/*enable to rx data frame */
 			rtw_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
 			/*enable to rx ps-poll */
@@ -4878,9 +4699,9 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 			rtw_write8(padapter, REG_BCNDMATIM, 0x02); /* 2ms */
 
 			/*rtw_write8(padapter, REG_BCN_MAX_ERR, 0xFF); */
-			rtw_write8(padapter, REG_ATIMWND, 0x0a); /* 10ms */
+			rtw_write8(padapter, REG_ATIMWND, 0x0c); /* 12ms */
 			rtw_write16(padapter, REG_BCNTCFG, 0x00);
-			rtw_write16(padapter, REG_TBTT_PROHIBIT, 0xff04);
+
 			rtw_write16(padapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
 
 			/*reset TSF */
@@ -4896,10 +4717,10 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			/* select BCN on port 0 */
 			rtw_write8(padapter, REG_CCK_CHECK_8188F,
-					   (rtw_read8(padapter, REG_CCK_CHECK_8188F) & ~BIT_BCN_PORT_SEL));
+				(rtw_read8(padapter, REG_CCK_CHECK_8188F) & ~BIT_BCN_PORT_SEL));
 
 #ifdef CONFIG_CONCURRENT_MODE
-			if (check_buddy_fwstate(padapter, WIFI_FW_NULL_STATE)) {
+			if (!rtw_mi_buddy_check_fwstate(padapter, WIFI_FW_ASSOC_SUCCESS))  {
 				val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
 				val8 &= ~EN_BCN_FUNCTION;
 				rtw_write8(padapter, REG_BCN_CTRL_1, val8);
@@ -4912,50 +4733,15 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 			rtw_write8(padapter, REG_BCN_CTRL_1, val8);
 #ifdef CONFIG_TSF_RESET_OFFLOAD
 			/* Reset TSF for STA+AP concurrent mode */
-			if (check_buddy_fwstate(padapter, (WIFI_STATION_STATE | WIFI_ASOC_STATE))) {
-				if (reset_tsf(padapter, IFACE_PORT0) == _FALSE)
-					DBG_871X("ERROR! %s()-%d: Reset port0 TSF fail\n",
-							 __func__, __LINE__);
+			if (rtw_mi_buddy_check_fwstate(padapter, (WIFI_STATION_STATE | WIFI_ASOC_STATE))) {
+				if (rtw_hal_reset_tsf(padapter, HW_PORT0) == _FAIL)
+					RTW_INFO("ERROR! %s()-%d: Reset port0 TSF fail\n",
+						 __func__, __LINE__);
 			}
 #endif	/* CONFIG_TSF_RESET_OFFLOAD */
 		}
-	}
-}
-
-static void hw_var_set_macaddr(PADAPTER padapter, u8 variable, u8 *val)
-{
-	u8 idx = 0;
-	u32 reg_macid;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1)
-		reg_macid = REG_MACID1;
-	else
-#endif
-	{
-		reg_macid = REG_MACID;
-	}
-
-	for (idx = 0; idx < 6; idx++)
-		rtw_write8(GET_PRIMARY_ADAPTER(padapter), (reg_macid + idx), val[idx]);
-}
-
-static void hw_var_set_bssid(PADAPTER padapter, u8 variable, u8 *val)
-{
-	u8	idx = 0;
-	u32 reg_bssid;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1)
-		reg_bssid = REG_BSSID1;
-	else
 #endif
-	{
-		reg_bssid = REG_BSSID;
 	}
-
-	for (idx = 0; idx < 6; idx++)
-		rtw_write8(padapter, (reg_bssid + idx), val[idx]);
 }
 
 static void hw_var_set_bcn_func(PADAPTER padapter, u8 variable, u8 *val)
@@ -4963,13 +4749,11 @@ static void hw_var_set_bcn_func(PADAPTER padapter, u8 variable, u8 *val)
 	u32 bcn_ctrl_reg;
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1)
+	if (padapter->hw_port == HW_PORT1)
 		bcn_ctrl_reg = REG_BCN_CTRL_1;
 	else
 #endif
-	{
 		bcn_ctrl_reg = REG_BCN_CTRL;
-	}
 
 	if (*(u8 *)val)
 		rtw_write8(padapter, bcn_ctrl_reg, (EN_BCN_FUNCTION | EN_TXBCN_RPT));
@@ -4986,128 +4770,18 @@ static void hw_var_set_bcn_func(PADAPTER padapter, u8 variable, u8 *val)
 	}
 }
 
-static void hw_var_set_correct_tsf(PADAPTER padapter, u8 variable, u8 *val)
-{
-	u8 val8;
-	u64	tsf;
-	struct mlme_ext_priv *pmlmeext;
-	struct mlme_ext_info *pmlmeinfo;
-
-
-	pmlmeext = &padapter->mlmeextpriv;
-	pmlmeinfo = &pmlmeext->mlmext_info;
-
-	tsf = pmlmeext->TSFValue - rtw_modular64(pmlmeext->TSFValue, (pmlmeinfo->bcn_interval * 1024)) - 1024; /*us */
-
-	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) ||
-		((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
-		StopTxBeacon(padapter);
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1) {
-		/* disable related TSF function */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
-		val8 &= ~EN_BCN_FUNCTION;
-		rtw_write8(padapter, REG_BCN_CTRL_1, val8);
-
-		rtw_write32(padapter, REG_TSFTR1, tsf);
-		rtw_write32(padapter, REG_TSFTR1 + 4, tsf >> 32);
-
-
-		/* enable related TSF function */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
-		val8 |= EN_BCN_FUNCTION;
-		rtw_write8(padapter, REG_BCN_CTRL_1, val8);
-
-		/* Update buddy port's TSF if it is SoftAP for beacon TX issue! */
-		if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE
-			&& check_buddy_fwstate(padapter, WIFI_AP_STATE)
-		   ) {
-			/* disable related TSF function */
-			val8 = rtw_read8(padapter, REG_BCN_CTRL);
-			val8 &= ~EN_BCN_FUNCTION;
-			rtw_write8(padapter, REG_BCN_CTRL, val8);
-
-			rtw_write32(padapter, REG_TSFTR, tsf);
-			rtw_write32(padapter, REG_TSFTR + 4, tsf >> 32);
-
-			/* enable related TSF function */
-			val8 = rtw_read8(padapter, REG_BCN_CTRL);
-			val8 |= EN_BCN_FUNCTION;
-			rtw_write8(padapter, REG_BCN_CTRL, val8);
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-			/* Update buddy port's TSF(TBTT) if it is SoftAP for beacon TX issue! */
-			if (reset_tsf(padapter, IFACE_PORT0) == _FALSE)
-				DBG_871X("ERROR! %s()-%d: Reset port0 TSF fail\n",
-						 __func__, __LINE__);
-
-#endif /* CONFIG_TSF_RESET_OFFLOAD */
-		}
-	} else
-#endif /* CONFIG_CONCURRENT_MODE */
-	{
-		/* disable related TSF function */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL);
-		val8 &= ~EN_BCN_FUNCTION;
-		rtw_write8(padapter, REG_BCN_CTRL, val8);
-
-		rtw_write32(padapter, REG_TSFTR, tsf);
-		rtw_write32(padapter, REG_TSFTR + 4, tsf >> 32);
-
-		/* enable related TSF function */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL);
-		val8 |= EN_BCN_FUNCTION;
-		rtw_write8(padapter, REG_BCN_CTRL, val8);
-
-#ifdef CONFIG_CONCURRENT_MODE
-		/* Update buddy port's TSF if it is SoftAP for beacon TX issue! */
-		if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE
-			&& check_buddy_fwstate(padapter, WIFI_AP_STATE)) {
-			/* disable related TSF function */
-			val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
-			val8 &= ~EN_BCN_FUNCTION;
-			rtw_write8(padapter, REG_BCN_CTRL_1, val8);
-
-			rtw_write32(padapter, REG_TSFTR1, tsf);
-			rtw_write32(padapter, REG_TSFTR1 + 4, tsf >> 32);
-
-			/* enable related TSF function */
-			val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
-			val8 |= EN_BCN_FUNCTION;
-			rtw_write8(padapter, REG_BCN_CTRL_1, val8);
-
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-			/* Update buddy port's TSF if it is SoftAP for beacon TX issue! */
-			if (reset_tsf(padapter, IFACE_PORT1) == _FALSE) {
-				DBG_871X("ERROR! %s()-%d: Reset port1 TSF fail\n",
-						 __func__, __LINE__);
-			}
-#endif /* CONFIG_TSF_RESET_OFFLOAD */
-		}
-#endif /* CONFIG_CONCURRENT_MODE */
-	}
-
-	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)
-		|| ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
-		ResumeTxBeacon(padapter);
-}
-
 static void hw_var_set_mlme_disconnect(PADAPTER padapter, u8 variable, u8 *val)
 {
 	u8 val8;
 
+	/* reject all data frames */
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_mlmeinfo_state(padapter, _HW_STATE_NOLINK_))
+	if (rtw_mi_check_status(padapter, MI_LINKED) == _FALSE)
 #endif
-	{
-		/* Set RCR to not to receive data frame when NO LINK state */
-		/*rtw_write32(padapter, REG_RCR, rtw_read32(padapter, REG_RCR) & ~RCR_ADF); */
-		/* reject all data frames */
 		rtw_write16(padapter, REG_RXFLTMAP2, 0);
-	}
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1) {
+	if (padapter->hw_port == HW_PORT1) {
 		/* reset TSF1 */
 		rtw_write8(padapter, REG_DUAL_TSF_RST, BIT(1));
 
@@ -5133,207 +4807,40 @@ static void hw_var_set_mlme_disconnect(PADAPTER padapter, u8 variable, u8 *val)
 	}
 }
 
-static void hw_var_set_mlme_sitesurvey(PADAPTER padapter, u8 variable, u8 *val)
+static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
 {
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	u32	value_rcr, rcr_clear_bit, reg_bcn_ctl;
-	u16	value_rxfltmap2;
 	u8 val8;
+	u16 val16;
+	u32 val32;
+	u8 RetryLimit;
+	u8 type;
 	PHAL_DATA_TYPE pHalData;
 	struct mlme_priv *pmlmepriv;
-	u8 ap_num;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	u32 buddy_reg_bcn_ctl;
-#endif
 
+	RetryLimit = RL_VAL_STA;
+	type = *(u8 *)val;
 	pHalData = GET_HAL_DATA(padapter);
 	pmlmepriv = &padapter->mlmepriv;
 
 #ifdef CONFIG_CONCURRENT_MODE
-
-	if (padapter->iface_type == IFACE_PORT1) {
-		reg_bcn_ctl = REG_BCN_CTRL_1;
-		buddy_reg_bcn_ctl = REG_BCN_CTRL;
-	} else {
-		reg_bcn_ctl = REG_BCN_CTRL;
-		buddy_reg_bcn_ctl = REG_BCN_CTRL_1;
-	}
-#else
-	reg_bcn_ctl = REG_BCN_CTRL;
-#endif
-
-	rtw_dev_iface_status(padapter, NULL, NULL, NULL, &ap_num, NULL);
-
-#ifdef CONFIG_FIND_BEST_CHANNEL
-	rcr_clear_bit = (RCR_CBSSID_BCN | RCR_CBSSID_DATA);
-
-	/* Receive all data frames */
-	value_rxfltmap2 = 0xFFFF;
-#else /* CONFIG_FIND_BEST_CHANNEL */
-
-	rcr_clear_bit = RCR_CBSSID_BCN;
-
-	/* config RCR to receive different BSSID & not to receive data frame */
-	value_rxfltmap2 = 0;
-
-#endif /* CONFIG_FIND_BEST_CHANNEL */
-
-	if ((check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-#ifdef CONFIG_CONCURRENT_MODE
-		|| (check_buddy_fwstate(padapter, WIFI_AP_STATE) == _TRUE)
-#endif
-	   )
-		rcr_clear_bit = RCR_CBSSID_BCN;
-#ifdef CONFIG_TDLS
-	/* TDLS will clear RCR_CBSSID_DATA bit for connection. */
-	else if (padapter->tdlsinfo.link_established == _TRUE)
-		rcr_clear_bit = RCR_CBSSID_BCN;
-#endif /* CONFIG_TDLS */
-
-	value_rcr = rtw_read32(padapter, REG_RCR);
-
-	if (*((u8 *)val)) {
-		/* under sitesurvey */
-	     /*
-		* 1. configure REG_RXFLTMAP2
-		* 2. disable TSF update &  buddy TSF update to avoid updating wrong TSF due to clear RCR_CBSSID_BCN
-		* 3. config RCR to receive different BSSID BCN or probe rsp
-		*/
-
-		rtw_write16(padapter, REG_RXFLTMAP2, value_rxfltmap2);
-
-		if (rtw_linked_check(padapter) &&
-			check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE) {
-			/* disable update TSF */
-			rtw_write8(padapter, reg_bcn_ctl, rtw_read8(padapter, reg_bcn_ctl)|DIS_TSF_UDT);
-			padapter->mlmeextpriv.en_hw_update_tsf = _FALSE;
-		}
-
-#ifdef CONFIG_CONCURRENT_MODE
-		if (rtw_linked_check(padapter->pbuddy_adapter) &&
-			check_fwstate(&padapter->pbuddy_adapter->mlmepriv, WIFI_AP_STATE) != _TRUE) {
-			/* disable update buddy TSF to avoid updating wrong TSF due to clear RCR_CBSSID_BCN */
-			rtw_write8(padapter->pbuddy_adapter, buddy_reg_bcn_ctl,
-				rtw_read8(padapter->pbuddy_adapter, buddy_reg_bcn_ctl)|DIS_TSF_UDT);
-			padapter->pbuddy_adapter->mlmeextpriv.en_hw_update_tsf = _FALSE;
-		}
-#endif
-		value_rcr &= ~(rcr_clear_bit);
-		rtw_write32(padapter, REG_RCR, value_rcr);
-
-		/* Save orignal RRSR setting. */
-		pHalData->RegRRSR = rtw_read16(padapter, REG_RRSR);
-
-		if (ap_num)
-			StopTxBeacon(padapter);
-	} else {
-	     /*
-		* 1. enable rx data frame
-		* 2. config RCR not to receive different BSSID BCN or probe rsp
-		* 3. doesn't enable TSF update &  buddy TSF right now to avoid HW conflict
-		*	 so, we enable TSF update when rx first BCN after sitesurvey done
-		*/
-
-		/* sitesurvey done */
-		if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE))
-#ifdef CONFIG_CONCURRENT_MODE
-			|| check_buddy_fwstate(padapter, (_FW_LINKED | WIFI_AP_STATE))
-#endif
-		   ) {
-			/* enable to rx data frame */
-			rtw_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
-		}
-
-		value_rcr |= rcr_clear_bit;
-		rtw_write32(padapter, REG_RCR, value_rcr);
-
-		if (rtw_linked_check(padapter) &&
-			check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
-			padapter->mlmeextpriv.en_hw_update_tsf = _TRUE;
-
-#ifdef CONFIG_CONCURRENT_MODE
-		if (rtw_linked_check(padapter->pbuddy_adapter) &&
-			check_fwstate(&padapter->pbuddy_adapter->mlmepriv, WIFI_AP_STATE) != _TRUE)
-			/* disable update buddy TSF to avoid updating wrong TSF due to clear RCR_CBSSID_BCN */
-			padapter->pbuddy_adapter->mlmeextpriv.en_hw_update_tsf = _TRUE;
-#endif
-
-		/* Restore orignal RRSR setting. */
-		rtw_write16(padapter, REG_RRSR, pHalData->RegRRSR);
-
-		if (ap_num) {
-			int i;
-			_adapter *iface;
-
-			ResumeTxBeacon(padapter);
-			for (i = 0; i < dvobj->iface_nums; i++) {
-				iface = dvobj->padapters[i];
-				if (!iface)
-					continue;
-
-				if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE
-					&& check_fwstate(&iface->mlmepriv, WIFI_ASOC_STATE) == _TRUE
-				) {
-					iface->mlmepriv.update_bcn = _TRUE;
-					#ifndef CONFIG_INTERRUPT_BASED_TXBCN
-					#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-					tx_beacon_hdl(iface, NULL);
-					#endif
-					#endif
-					
-				}
-			}
-		}
-	}
-}
-
-static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
-{
-	u8 val8;
-	u16 val16;
-	u32 val32;
-	u8 RetryLimit;
-	u8 type;
-	PHAL_DATA_TYPE pHalData;
-	struct mlme_priv *pmlmepriv;
-
-	RetryLimit = 0x30;
-	type = *(u8 *)val;
-	pHalData = GET_HAL_DATA(padapter);
-	pmlmepriv = &padapter->mlmepriv;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (type == 0) {
-		/* prepare to join */
-		if (check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE) &&
-			check_buddy_fwstate(padapter, _FW_LINKED))
-			StopTxBeacon(padapter);
+	if (type == 0) {
+		/* prepare to join */
+		if (rtw_mi_get_ap_num(padapter) || rtw_mi_get_mesh_num(padapter))
+			StopTxBeacon(padapter);
 
 		/* enable to rx data frame.Accept all data frame */
 		rtw_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
 
-		if (check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE)) {
-			val32 = rtw_read32(padapter, REG_RCR);
-			val32 |= RCR_CBSSID_BCN;
-			rtw_write32(padapter, REG_RCR, val32);
-		} else {
-			val32 = rtw_read32(padapter, REG_RCR);
-			val32 |= RCR_CBSSID_DATA | RCR_CBSSID_BCN;
-			rtw_write32(padapter, REG_RCR, val32);
-		}
-
 		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-			RetryLimit = (pHalData->CustomerID == RT_CID_CCX) ? 7 : 48;
+			RetryLimit = (pHalData->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
 		else   /* Ad-hoc Mode */
-			RetryLimit = 0x7;
+			RetryLimit = RL_VAL_AP;
 	} else if (type == 1) {
 		/* joinbss_event call back when join res < 0 */
-		if (check_buddy_mlmeinfo_state(padapter, _HW_STATE_NOLINK_))
+		if (rtw_mi_check_status(padapter, MI_LINKED) == _FALSE)
 			rtw_write16(padapter, REG_RXFLTMAP2, 0x00);
 
-		if (check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE) &&
-			check_buddy_fwstate(padapter, _FW_LINKED)) {
+		if (rtw_mi_get_ap_num(padapter) || rtw_mi_get_mesh_num(padapter)) {
 			ResumeTxBeacon(padapter);
 
 			/* reset TSF 1/2 after ResumeTxBeacon */
@@ -5341,9 +4848,12 @@ static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
 		}
 	} else if (type == 2) {
 		/* sta add event call back */
-
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		/*if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) && (rtw_mi_get_assoced_sta_num(Adapter) == 1))
+			rtw_write8(Adapter, REG_BCN_CTRL, rtw_read8(Adapter, REG_BCN_CTRL)&(~DIS_TSF_UDT));*/
+#else
 		/* enable update TSF */
-		if (padapter->iface_type == IFACE_PORT1) {
+		if (padapter->hw_port == HW_PORT1) {
 			val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
 			val8 &= ~DIS_TSF_UDT;
 			rtw_write8(padapter, REG_BCN_CTRL_1, val8);
@@ -5352,14 +4862,13 @@ static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
 			val8 &= ~DIS_TSF_UDT;
 			rtw_write8(padapter, REG_BCN_CTRL, val8);
 		}
-
+#endif/*CONFIG_MI_WITH_MBSSID_CAM*/
 		if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
 			rtw_write8(padapter, 0x542 , 0x02);
-			RetryLimit = 0x7;
+			RetryLimit = RL_VAL_AP;
 		}
 
-		if (check_buddy_mlmeinfo_state(padapter, WIFI_FW_AP_STATE) &&
-			check_buddy_fwstate(padapter, _FW_LINKED)) {
+		if (rtw_mi_get_ap_num(padapter) || rtw_mi_get_mesh_num(padapter)) {
 			ResumeTxBeacon(padapter);
 
 			/* reset TSF 1/2 after ResumeTxBeacon */
@@ -5372,20 +4881,12 @@ static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
 #else /* !CONFIG_CONCURRENT_MODE */
 	if (type == 0) { /* prepare to join */
 		/*enable to rx data frame.Accept all data frame */
-		/*rtw_write32(padapter, REG_RCR, rtw_read32(padapter, REG_RCR)|RCR_ADF); */
 		rtw_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
 
-		val32 = rtw_read32(padapter, REG_RCR);
-		if (padapter->in_cta_test)
-			val32 &= ~(RCR_CBSSID_DATA | RCR_CBSSID_BCN);/*| RCR_ADF */
-		else
-			val32 |= RCR_CBSSID_DATA | RCR_CBSSID_BCN;
-		rtw_write32(padapter, REG_RCR, val32);
-
 		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-			RetryLimit = (pHalData->CustomerID == RT_CID_CCX) ? 7 : 48;
+			RetryLimit = (pHalData->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
 		else   /* Ad-hoc Mode */
-			RetryLimit = 0x7;
+			RetryLimit = RL_VAL_AP;
 	} else if (type == 1)   /*joinbss_event call back when join res < 0 */
 		rtw_write16(padapter, REG_RXFLTMAP2, 0x00);
 	else if (type == 2) { /*sta add event call back */
@@ -5395,7 +4896,7 @@ static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
 		rtw_write8(padapter, REG_BCN_CTRL, val8);
 
 		if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE))
-			RetryLimit = 0x7;
+			RetryLimit = RL_VAL_AP;
 	}
 
 	val16 = (RetryLimit << RETRY_LIMIT_SHORT_SHIFT) | (RetryLimit << RETRY_LIMIT_LONG_SHIFT);
@@ -5403,41 +4904,6 @@ static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
 #endif /* !CONFIG_CONCURRENT_MODE */
 }
 
-static void hw_var_set_hw_update_tsf(PADAPTER padapter)
-{
-
-	u16 reg_bcn_ctl;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->iface_type == IFACE_PORT1)
-		reg_bcn_ctl = REG_BCN_CTRL_1;
-	else
-		reg_bcn_ctl = REG_BCN_CTRL;
-#else
-	reg_bcn_ctl = REG_BCN_CTRL;
-#endif
-
-	if (!pmlmeext->en_hw_update_tsf)
-		return;
-
-	/* check REG_RCR bit is set */
-	if (!(rtw_read32(padapter, REG_RCR) & RCR_CBSSID_BCN)) {
-		pmlmeext->en_hw_update_tsf = _FALSE;
-		return;
-	}
-
-
-	/* enable hw update tsf function for non-AP */
-	if (rtw_linked_check(padapter) &&
-		check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
-		/* enable update buddy TSF */
-		rtw_write8(padapter, reg_bcn_ctl, rtw_read8(padapter, reg_bcn_ctl)&(~DIS_TSF_UDT));
-
-	pmlmeext->en_hw_update_tsf = _FALSE;
-}
-
 void CCX_FwC2HTxRpt_8188f(PADAPTER padapter, u8 *pdata, u8 len)
 {
 	u8 seq_no;
@@ -5445,7 +4911,7 @@ void CCX_FwC2HTxRpt_8188f(PADAPTER padapter, u8 *pdata, u8 len)
 #define	GET_8188F_C2H_TX_RPT_LIFE_TIME_OVER(_Header)	LE_BITS_TO_1BYTE((_Header + 0), 6, 1)
 #define	GET_8188F_C2H_TX_RPT_RETRY_OVER(_Header)	LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
 
-	/*DBG_871X("%s, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x\n", __func__, */
+	/*RTW_INFO("%s, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x\n", __func__, */
 	/*		*pdata, *(pdata+1), *(pdata+2), *(pdata+3), *(pdata+4), *(pdata+5), *(pdata+6), *(pdata+7)); */
 
 	seq_no = *(pdata + 6);
@@ -5455,7 +4921,7 @@ void CCX_FwC2HTxRpt_8188f(PADAPTER padapter, u8 *pdata, u8 len)
 		rtw_ack_tx_done(&padapter->xmitpriv, RTW_SCTX_DONE_CCX_PKT_FAIL);
 	/*
 		else if(seq_no != padapter->xmitpriv.seq_no) {
-			DBG_871X("tx_seq_no=%d, rpt_seq_no=%d\n", padapter->xmitpriv.seq_no, seq_no);
+			RTW_INFO("tx_seq_no=%d, rpt_seq_no=%d\n", padapter->xmitpriv.seq_no, seq_no);
 			rtw_ack_tx_done(&padapter->xmitpriv, RTW_SCTX_DONE_CCX_PKT_FAIL);
 		}
 	*/
@@ -5464,330 +4930,22 @@ void CCX_FwC2HTxRpt_8188f(PADAPTER padapter, u8 *pdata, u8 len)
 #endif
 }
 
-#ifdef CONFIG_FW_C2H_DEBUG
-/*
- * C2H RX package original is 128.
- * If enable CONFIG_FW_C2H_DEBUG, it should increase to 256.
- * C2H FW debug message:
- * without aggregate:
- * {C2H CmdID, Seq, SubID, Len, Content[0~n]}
- * Content[0~n] = { 'a' , 'b' , 'c' ,..., 'z' , '\n'}
- *
- * with aggregate:
- * {C2H CmdID, Seq, SubID, Len, Content[0~n]}
- * Content[0~n] = { 'a' , 'b' , 'c' ,..., 'z', '\n' , Extend C2H pkt 2...}
- * Extend C2H pkt 2 = {C2H CmdID, Seq, SubID, Len, Content = { 'a' , 'b' , 'c' ,..., 'z' , '\n'}}
- *
- * Author: Isaac
- */
-void Debug_FwC2H_8188f(PADAPTER padapter, u8 *pdata, u8 len)
-{
-	int i = 0;
-	int cnt = 0, total_length = 0;
-	u8 buf[128] = {0};
-	u8 more_data = _FALSE;
-	u8 *nextdata = NULL;
-	u8 test = 0;
-
-	u8 data_len;
-	u8 seq_no;
-
-	nextdata = pdata;
-#if 0
-	for (i = 0; i < len; i++) {
-		printk("%02x ", pdata[i]);
-		if ((i + 1) % 8 == 0)
-			printk("\n");
-	}
-	printk("\n");
-#endif
-	do {
-		data_len = *(nextdata + 1);
-		seq_no = *(nextdata + 2);
-
-		for (i = 0; i < data_len - 2; i++) {
-			cnt += sprintf((buf + cnt), "%c", nextdata[3 + i]);
-
-			if (nextdata[3 + i] == 0x0a && nextdata[4 + i] == 0xff)
-				more_data = _TRUE;
-			else if (nextdata[3 + i] == 0x0a && nextdata[4 + i] != 0xff)
-				more_data = _FALSE;
-		}
-
-		DBG_871X("[RTKFW, SEQ=%d]: %s", seq_no, buf);
-		data_len += 3;
-		total_length += data_len;
-
-		if (more_data == _TRUE) {
-			_rtw_memset(buf, '\0', 128);
-			cnt = 0;
-			nextdata = (pdata + total_length);
-		}
-	} while (more_data == _TRUE);
-}
-#endif /*CONFIG_FW_C2H_DEBUG */
-
-s32 c2h_id_filter_ccx_8188f(u8 *buf)
+static s32 c2h_handler_8188f(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
 {
-	struct c2h_evt_hdr_88xx *c2h_evt = (struct c2h_evt_hdr_88xx *)buf;
-	s32 ret = _FALSE;
-	if (c2h_evt->id == C2H_CCX_TX_RPT)
-		ret = _TRUE;
-
-	return ret;
-}
-
-
-s32 c2h_handler_8188f(PADAPTER padapter, u8 *buf)
-{
-	struct c2h_evt_hdr_88xx *pC2hEvent = (struct c2h_evt_hdr_88xx *)buf;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	s32 ret = _SUCCESS;
-	u8 index = 0;
-
-	if (pC2hEvent == NULL) {
-		DBG_8192C("%s(): pC2hEventis NULL\n", __func__);
-		ret = _FAIL;
-		goto exit;
-	}
-
-	switch (pC2hEvent->id) {
-	case C2H_DBG: {
-		RT_TRACE(_module_hal_init_c_, _drv_info_, ("c2h_handler_8188f: %s\n", pC2hEvent->payload));
-	}
-	break;
 
+	switch (id) {
 	case C2H_CCX_TX_RPT:
-		/*CCX_FwC2HTxRpt(padapter, QueueID, pC2hEvent->payload); */
-		break;
-
-#ifdef CONFIG_BT_COEXIST
-	case C2H_BT_INFO:
-		rtw_btcoex_BtInfoNotify(padapter, pC2hEvent->plen, pC2hEvent->payload);
-		break;
-#endif
-
-/*
-#ifdef CONFIG_MP_INCLUDED
-	case C2H_BT_MP_INFO:
-		DBG_8192C(" %s, C2H_BT_MP_INFO pC2hEvent->plen=%d\n", __func__, pC2hEvent->plen);
-		MPTBT_FwC2hBtMpCtrl(padapter, pC2hEvent->payload, pC2hEvent->plen);
+		CCX_FwC2HTxRpt_8188f(adapter, payload, plen);
 		break;
-#endif
-*/
 	default:
+		ret = _FAIL;
 		break;
 	}
-
-	/* Clear event to notify FW we have read the command. */
-	/* Note: */
-	/*	If this field isn't clear, the FW won't update the next command message. */
-	/*rtw_write8(padapter, REG_C2HEVT_CLEAR, C2H_EVT_HOST_CLOSE); */
 exit:
 	return ret;
 }
 
-static void process_c2h_event(PADAPTER padapter, PC2H_EVT_HDR pC2hEvent, u8 *c2hBuf)
-{
-	u8				index = 0;
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	PDM_ODM_T			pDM_Odm = &pHalData->odmpriv;
-
-	if (c2hBuf == NULL) {
-		DBG_8192C("%s c2hbuff is NULL\n", __func__);
-		return;
-	}
-
-	switch (pC2hEvent->CmdID) {
-	case C2H_CCX_TX_RPT:
-		CCX_FwC2HTxRpt_8188f(padapter, c2hBuf, pC2hEvent->CmdLen);
-		break;
-
-#ifdef CONFIG_RTW_CUSTOMER_STR
-	case C2H_CUSTOMER_STR_RPT:
-		c2h_customer_str_rpt_hdl(padapter, c2hBuf, pC2hEvent->CmdLen);
-		break;
-	case C2H_CUSTOMER_STR_RPT_2:
-		c2h_customer_str_rpt_2_hdl(padapter, c2hBuf, pC2hEvent->CmdLen);
-		break;
-#endif
-
-#ifdef CONFIG_BT_COEXIST
-	case C2H_BT_INFO:
-		rtw_btcoex_BtInfoNotify(padapter, pC2hEvent->CmdLen, c2hBuf);
-		break;
-#endif
-
-/*
-#ifdef CONFIG_MP_INCLUDED
-	case C2H_BT_MP_INFO:
-		MPTBT_FwC2hBtMpCtrl(padapter, c2hBuf, pC2hEvent->CmdLen);
-		break;
-#endif
-*/
-#ifdef CONFIG_FW_C2H_DEBUG
-	case C2H_EXTEND:
-		Debug_FwC2H_8188f(padapter, c2hBuf, pC2hEvent->CmdLen);
-	break;
-#endif /* CONFIG_FW_C2H_DEBUG */
-
-	default:
-		if (!(phydm_c2H_content_parsing(pDM_Odm, pC2hEvent->CmdID, pC2hEvent->CmdLen, c2hBuf))) 
-			RT_TRACE(_module_hal_init_c_, _drv_info_, ("%s: [WARNING] unknown C2H(0x%02x)\n", __func__, c2hCmdId));
-		
-		break;
-		
-	}
-
-#ifndef CONFIG_C2H_PACKET_EN
-	/* Clear event to notify FW we have read the command. */
-	/* Note: */
-	/*	If this field isn't clear, the FW won't update the next command message. */
-	rtw_write8(padapter, REG_C2HEVT_CLEAR, C2H_EVT_HOST_CLOSE);
-#endif
-}
-
-#ifdef CONFIG_C2H_PACKET_EN
-
-static void C2HPacketHandler_8188F(PADAPTER padapter, u8 *pbuffer, u16 length)
-{
-	C2H_EVT_HDR 	C2hEvent;
-	u8 *tmpBuf = NULL;
-#ifdef CONFIG_WOWLAN
-	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-
-	if (pwrpriv->wowlan_mode == _TRUE) {
-		DBG_871X("%s(): return because wowolan_mode==TRUE! CMDID=%d\n", __func__, pbuffer[0]);
-		return;
-	}
-#endif
-	C2hEvent.CmdID = pbuffer[0];
-	C2hEvent.CmdSeq = pbuffer[1];
-	C2hEvent.CmdLen = length - 2;
-	tmpBuf = pbuffer + 2;
-
-	/*DBG_871X("%s C2hEvent.CmdID:%x C2hEvent.CmdLen:%x C2hEvent.CmdSeq:%x\n", */
-	/*		__func__, C2hEvent.CmdID, C2hEvent.CmdLen, C2hEvent.CmdSeq); */
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_notice_, "C2HPacketHandler_8188F(): Command Content:\n", tmpBuf, C2hEvent.CmdLen);
-
-	process_c2h_event(padapter, &C2hEvent, tmpBuf);
-	/*c2h_handler_8188f(padapter,&C2hEvent); */
-	return;
-}
-
-void rtl8188f_c2h_packet_handler(PADAPTER padapter, u8 *pbuf, u16 length)
-{
-	C2H_EVT_HDR C2hEvent;
-	u8 *pdata;
-
-
-	if (length == 0)
-		return;
-
-	C2hEvent.CmdID = pbuf[0];
-	C2hEvent.CmdSeq = pbuf[1];
-	C2hEvent.CmdLen = length - 2;
-	pdata = pbuf + 2;
-
-	DBG_8192C("%s: C2H, ID=%d seq=%d len=%d\n",
-			  __func__, C2hEvent.CmdID, C2hEvent.CmdSeq, C2hEvent.CmdLen);
-
-	switch (C2hEvent.CmdID) {
-	case C2H_CCX_TX_RPT:
-#ifdef CONFIG_FW_C2H_DEBUG
-	case C2H_EXTEND:
-#endif /* CONFIG_FW_C2H_DEBUG */
-		process_c2h_event(padapter, &C2hEvent, pdata);
-		break;
-
-	default:
-		rtw_c2h_packet_wk_cmd(padapter, pbuf, length);
-		break;
-	}
-}
-
-#else /* !CONFIG_C2H_PACKET_EN */
-/* */
-/*C2H event format: */
-/* Field    TRIGGER     CONTENT    CMD_SEQ    CMD_LEN  CMD_ID */
-/* BITS    [127:120]   [119:16]    [15:8]     [7:4]    [3:0] */
-/*2009.10.08. by tynli. */
-static void C2HCommandHandler(PADAPTER padapter)
-{
-	C2H_EVT_HDR 	C2hEvent;
-#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-
-	u8				*tmpBuf = NULL;
-	u8				index = 0;
-	u8				bCmdMsgReady = _FALSE;
-	u8				U1bTmp = 0;
-	/*u8				QueueID = 0; */
-
-	_rtw_memset(&C2hEvent, 0, sizeof(C2H_EVT_HDR));
-
-	C2hEvent.CmdID = rtw_read8(padapter, REG_C2HEVT_CMD_ID_8188F);
-	C2hEvent.CmdLen = rtw_read8(padapter, REG_C2HEVT_CMD_LEN_8188F);
-	C2hEvent.CmdSeq = rtw_read8(padapter, REG_C2HEVT_CMD_ID_8188F + 1);
-
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_info_, "C2HCommandHandler(): ",
-				  &C2hEvent , sizeof(C2hEvent));
-
-	U1bTmp = rtw_read8(padapter, REG_C2HEVT_CLEAR);
-	DBG_871X("%s C2hEvent.CmdID:%x C2hEvent.CmdLen:%x C2hEvent.CmdSeq:%x\n",
-			 __func__, C2hEvent.CmdID, C2hEvent.CmdLen, C2hEvent.CmdSeq);
-
-	if (U1bTmp == C2H_EVT_HOST_CLOSE) {
-		/* Not ready. */
-		return;
-	} else if (U1bTmp == C2H_EVT_FW_CLOSE)
-		bCmdMsgReady = _TRUE;
-	else {
-		/* Not a valid value, reset the clear event. */
-		goto exit;
-	}
-
-	if (C2hEvent.CmdLen == 0)
-		goto exit;
-	tmpBuf = rtw_zmalloc(C2hEvent.CmdLen);
-	if (tmpBuf == NULL)
-		goto exit;
-
-	/* Read the content */
-	for (index = 0; index < C2hEvent.CmdLen; index++)
-		tmpBuf[index] = rtw_read8(padapter, REG_C2HEVT_CMD_ID_8188F + 2 + index);
-
-	RT_PRINT_DATA(_module_hal_init_c_, _drv_notice_, "C2HCommandHandler(): Command Content:\n", tmpBuf, C2hEvent.CmdLen);
-
-	/*process_c2h_event(padapter,&C2hEvent, tmpBuf); */
-	c2h_handler_8188f(padapter, &C2hEvent);
-	if (tmpBuf)
-		rtw_mfree(tmpBuf, C2hEvent.CmdLen);
-#endif /* CONFIG_SDIO_HCI || CONFIG_GSPI_HCI */
-
-#ifdef CONFIG_USB_HCI
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-
-	_rtw_memset(&C2hEvent, 0, sizeof(C2H_EVT_HDR));
-	C2hEvent.CmdID = pHalData->C2hArray[USB_C2H_CMDID_OFFSET] & 0xF;
-	C2hEvent.CmdLen = (pHalData->C2hArray[USB_C2H_CMDID_OFFSET] & 0xF0) >> 4;
-	C2hEvent.CmdSeq = pHalData->C2hArray[USB_C2H_SEQ_OFFSET];
-	c2h_handler_8188f(padapter, (u8 *)&C2hEvent);
-	/*process_c2h_event(padapter,&C2hEvent,&pHalData->C2hArray[USB_C2H_EVENT_OFFSET]); */
-#endif /* CONFIG_USB_HCI */
-
-	/*REG_C2HEVT_CLEAR have done in process_c2h_event */
-	return;
-exit:
-	rtw_write8(padapter, REG_C2HEVT_CLEAR, C2H_EVT_HOST_CLOSE);
-	return;
-}
-
-#endif /* !CONFIG_C2H_PACKET_EN */
-
 void rtl8188f_set_pll_ref_clk_sel(_adapter *adapter, u8 sel)
 {
 	u8 value8;
@@ -5804,8 +4962,8 @@ void rtl8188f_set_pll_ref_clk_sel(_adapter *adapter, u8 sel)
 			rtw_write16(adapter, REG_RSV_CTRL_8188F, value16);
 		}
 
-		DBG_871X_LEVEL(_drv_always_, "switch pll_ref_clk_sel from 0x%x to 0x%x\n"
-			, (value8 & 0x0F), (sel & 0x0F));
+		RTW_PRINT("switch pll_ref_clk_sel from 0x%x to 0x%x\n"
+			  , (value8 & 0x0F), (sel & 0x0F));
 		value8 = (value8 & 0xF0) | (sel & 0x0F);
 		rtw_write8(adapter, REG_MAC_PLL_CTRL_EXT_8188F, value8);
 
@@ -5816,40 +4974,21 @@ void rtl8188f_set_pll_ref_clk_sel(_adapter *adapter, u8 sel)
 	}
 }
 
-void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
+u8 SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	u8 ret = _SUCCESS;
 	u8 val8;
 	u16 val16;
 	u32 val32;
 
-	_func_enter_;
 
 	switch (variable) {
-	case HW_VAR_MEDIA_STATUS:
-		val8 = rtw_read8(padapter, MSR) & 0x0c;
-		val8 |= *val;
-		rtw_write8(padapter, MSR, val8);
-		break;
-
-	case HW_VAR_MEDIA_STATUS1:
-		val8 = rtw_read8(padapter, MSR) & 0x03;
-		val8 |= *val << 2;
-		rtw_write8(padapter, MSR, val8);
-		break;
 
 	case HW_VAR_SET_OPMODE:
 		hw_var_set_opmode(padapter, variable, val);
 		break;
 
-	case HW_VAR_MAC_ADDR:
-		hw_var_set_macaddr(padapter, variable, val);
-		break;
-
-	case HW_VAR_BSSID:
-		hw_var_set_bssid(padapter, variable, val);
-		break;
-
 	case HW_VAR_BASIC_RATE: {
 		struct mlme_ext_info *mlmext_info = &padapter->mlmeextpriv.mlmext_info;
 		u16 input_b = 0, masked = 0, ioted = 0, BrateCfg = 0;
@@ -5879,7 +5018,7 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 
 		pHalData->BasicRateSet = BrateCfg;
 
-		DBG_8192C("HW_VAR_BASIC_RATE: %#x -> %#x -> %#x\n", input_b, masked, ioted);
+		RTW_INFO("HW_VAR_BASIC_RATE: %#x->%#x->%#x\n", input_b, masked, ioted);
 
 		/* Set RRSR rate table. */
 		rtw_write16(padapter, REG_RRSR, BrateCfg);
@@ -5895,71 +5034,49 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		hw_var_set_bcn_func(padapter, variable, val);
 		break;
 
-	case HW_VAR_CORRECT_TSF:
-		hw_var_set_correct_tsf(padapter, variable, val);
-		break;
-
-	case HW_VAR_CHECK_BSSID: {
-		u32 val32;
-
-		val32 = rtw_read32(padapter, REG_RCR);
-		if (*val)
-			val32 |= RCR_CBSSID_DATA | RCR_CBSSID_BCN;
-		else
-			val32 &= ~(RCR_CBSSID_DATA | RCR_CBSSID_BCN);
-		rtw_write32(padapter, REG_RCR, val32);
-	}
-	break;
-
 	case HW_VAR_MLME_DISCONNECT:
 		hw_var_set_mlme_disconnect(padapter, variable, val);
 		break;
 
-	case HW_VAR_MLME_SITESURVEY:
-		hw_var_set_mlme_sitesurvey(padapter, variable,  val);
-
-#ifdef CONFIG_BT_COEXIST
-		rtw_btcoex_ScanNotify(padapter, *val ? _TRUE : _FALSE);
-#endif /* CONFIG_BT_COEXIST */
-		break;
-
 	case HW_VAR_MLME_JOIN:
 		hw_var_set_mlme_join(padapter, variable, val);
 
 #ifdef CONFIG_BT_COEXIST
 		switch (*val) {
 		case 0:
-			/* prepare to join */
+			/* Notify coex. mechanism before join */
 			rtw_btcoex_ConnectNotify(padapter, _TRUE);
 			break;
 		case 1:
-			/* joinbss_event callback when join res < 0 */
-			rtw_btcoex_ConnectNotify(padapter, _FALSE);
-			break;
 		case 2:
-			/* sta add event callback */
-			/*rtw_btcoex_MediaStatusNotify(padapter, RT_MEDIA_CONNECT); */
+			/* Notify coex. mechanism after join, whether successful or failed */
+			rtw_btcoex_ConnectNotify(padapter, _FALSE);
 			break;
 		}
 #endif /* CONFIG_BT_COEXIST */
 		break;
 
-	case HW_VAR_ON_RCR_AM:
-		val32 = rtw_read32(padapter, REG_RCR);
-		val32 |= RCR_AM;
-		rtw_write32(padapter, REG_RCR, val32);
-		DBG_8192C("%s, %d, RCR= %x\n", __func__, __LINE__, rtw_read32(padapter, REG_RCR));
-		break;
+	case HW_VAR_BEACON_INTERVAL:
+		{
+			u16 bcn_interval = *((u16 *)val);
 
-	case HW_VAR_OFF_RCR_AM:
-		val32 = rtw_read32(padapter, REG_RCR);
-		val32 &= ~RCR_AM;
-		rtw_write32(padapter, REG_RCR, val32);
-		DBG_8192C("%s, %d, RCR= %x\n", __func__, __LINE__, rtw_read32(padapter, REG_RCR));
-		break;
+			#ifdef CONFIG_SWTIMER_BASED_TXBCN
+			bcn_interval = rtw_hal_bcn_interval_adjust(padapter, bcn_interval);
+			#endif
 
-	case HW_VAR_BEACON_INTERVAL:
-		rtw_write16(padapter, REG_BCN_INTERVAL, *((u16 *)val));
+			rtw_write16(padapter, REG_BCN_INTERVAL, bcn_interval);
+			#ifdef CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
+			{
+				struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+				struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+				if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+					RTW_INFO("%s==> bcn_interval:%d, eraly_int:%d\n", __func__, bcn_interval, bcn_interval >> 1);
+					rtw_write8(padapter, REG_DRVERLYINT, bcn_interval >> 1);
+				}
+			}
+			#endif/* CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT */
+		}
 		break;
 
 	case HW_VAR_SLOT_TIME:
@@ -6023,9 +5140,7 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 			ulCommand = ulCommand | CAM_POLLINIG | CAM_WRITE;
 			/* write content 0 is equall to mark invalid */
 			rtw_write32(padapter, WCAMI, ulContent);  /*delay_ms(40); */
-			/*RT_TRACE(COMP_SEC, DBG_LOUD, ("CAM_empty_entry(): WRITE A4: %lx\n",ulContent)); */
 			rtw_write32(padapter, RWCAM, ulCommand);  /*delay_ms(40); */
-			/*RT_TRACE(COMP_SEC, DBG_LOUD, ("CAM_empty_entry(): WRITE A0: %lx\n",ulCommand)); */
 		}
 	}
 	break;
@@ -6043,7 +5158,7 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		break;
 
 	case HW_VAR_AC_PARAM_BE:
-		pHalData->AcParam_BE = ((u32 *)(val))[0];
+		pHalData->ac_param_be = ((u32 *)(val))[0];
 		rtw_write32(padapter, REG_EDCA_BE_PARAM, *((u32 *)val));
 		break;
 
@@ -6058,17 +5173,17 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		if (ctrl != 0) {
 			hwctrl |= AcmHw_HwEn;
 
-			if (ctrl & BIT(1)) /* BE */
+			if (ctrl & BIT(3)) /* BE */
 				hwctrl |= AcmHw_BeqEn;
 
 			if (ctrl & BIT(2)) /* VI */
 				hwctrl |= AcmHw_ViqEn;
 
-			if (ctrl & BIT(3)) /* VO */
+			if (ctrl & BIT(1)) /* VO */
 				hwctrl |= AcmHw_VoqEn;
 		}
 
-		DBG_8192C("[HW_VAR_ACM_CTRL] Write 0x%02X\n", hwctrl);
+		RTW_INFO("[HW_VAR_ACM_CTRL] Write 0x%02X\n", hwctrl);
 		rtw_write8(padapter, REG_ACMHWCTRL, hwctrl);
 	}
 	break;
@@ -6094,11 +5209,6 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 	case HW_VAR_H2C_FW_PWRMODE: {
 		u8 psmode = *val;
 
-		/* 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 (psmode != PS_MODE_ACTIVE)
-			ODM_RF_Saving(&pHalData->odmpriv, _TRUE);
-
 		/*if (psmode != PS_MODE_ACTIVE)	{ */
 		/*	rtl8188f_set_lowpwr_lps_cmd(padapter, _TRUE); */
 		/*} else { */
@@ -6120,32 +5230,6 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		rtl8188f_set_p2p_ps_offload_cmd(padapter, *val);
 		break;
 #endif /*CONFIG_P2P */
-#ifdef CONFIG_TDLS
-	case HW_VAR_TDLS_WRCR:
-		rtw_write32(padapter, REG_RCR, rtw_read32(padapter, REG_RCR) & (~RCR_CBSSID_DATA));
-		break;
-	case HW_VAR_TDLS_RS_RCR:
-		rtw_write32(padapter, REG_RCR, rtw_read32(padapter, REG_RCR) | (RCR_CBSSID_DATA));
-		break;
-#endif /*CONFIG_TDLS */
-		
-#ifdef CONFIG_ANTENNA_DIVERSITY
-	case HW_VAR_ANTENNA_DIVERSITY_SELECT: 
-		{
-			u8	Optimum_antenna = (*(u8 *)val);
-			u8	Ant;
-			/*switch antenna to Optimum_antenna*/
-			/*DBG_8192C("==> HW_VAR_ANTENNA_DIVERSITY_SELECT , Ant_(%s)\n",(Optimum_antenna==2)?"A":"B");*/
-			if (pHalData->CurAntenna !=  Optimum_antenna) {					
-				Ant = (Optimum_antenna == 2) ? MAIN_ANT : AUX_ANT;
-				ODM_UpdateRxIdleAnt(&pHalData->odmpriv, Ant);
-					
-				pHalData->CurAntenna = Optimum_antenna;
-				/*DBG_8192C("==> HW_VAR_ANTENNA_DIVERSITY_SELECT , Ant_(%s)\n",(Optimum_antenna==2)?"A":"B");*/
-			}
-		}
-	break;
-#endif
 
 	case HW_VAR_EFUSE_USAGE:
 		pHalData->EfuseUsedPercentage = *val;
@@ -6193,10 +5277,10 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 				if (val32)
 					break;
 
-				DBG_871X("%s: [HW_VAR_FIFO_CLEARN_UP] val=%x times:%d\n", __func__, val32, trycnt);
+				RTW_INFO("%s: [HW_VAR_FIFO_CLEARN_UP] val=%x times:%d\n", __func__, val32, trycnt);
 			} while (--trycnt);
 			if (trycnt == 0)
-				DBG_8192C("[HW_VAR_FIFO_CLEARN_UP] Stop RX DMA failed......\n");
+				RTW_INFO("[HW_VAR_FIFO_CLEARN_UP] Stop RX DMA failed......\n");
 
 			/* RQPN Load 0 */
 			rtw_write16(padapter, REG_RQPN_NPQ, 0);
@@ -6224,39 +5308,33 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 			reg_200 = rtw_read32(padapter, 0x200);
 			reg_204 = rtw_read32(padapter, 0x204);
 			if (reg_200 != reg_204) {
-				/*DBG_871X("packet in tx packet buffer - 0x204=%x, 0x200=%x (%d)\n", rtw_read32(padapter, 0x204), rtw_read32(padapter, 0x200), i); */
+				/*RTW_INFO("packet in tx packet buffer - 0x204=%x, 0x200=%x (%d)\n", rtw_read32(padapter, 0x204), rtw_read32(padapter, 0x200), i); */
 				rtw_msleep_os(10);
 			} else {
-				DBG_871X("[HW_VAR_CHECK_TXBUF] no packet in tx packet buffer (%d)\n", i);
+				RTW_INFO("[HW_VAR_CHECK_TXBUF] no packet in tx packet buffer (%d)\n", i);
 				break;
 			}
 		}
 
 		if (reg_200 != reg_204)
-			DBG_871X("packets in tx buffer - 0x204=%x, 0x200=%x\n", reg_204, reg_200);
+			RTW_INFO("packets in tx buffer - 0x204=%x, 0x200=%x\n", reg_204, reg_200);
 
-		RetryLimit = 0x30;
+		RetryLimit = RL_VAL_STA;
 		val16 = RetryLimit << RETRY_LIMIT_SHORT_SHIFT | RetryLimit << RETRY_LIMIT_LONG_SHIFT;
 		rtw_write16(padapter, REG_RL, val16);
 	}
 	break;
 #endif /* CONFIG_CONCURRENT_MODE */
 
-	case HW_VAR_APFM_ON_MAC:
-		pHalData->bMacPwrCtrlOn = *val;
-		DBG_871X("%s: bMacPwrCtrlOn=%d\n", __func__, pHalData->bMacPwrCtrlOn);
-		break;
-
 	case HW_VAR_HCI_SUS_STATE:
 		pHalData->hci_sus_state = *val;
-		DBG_871X("%s: hci_sus_state=%u\n", __func__, pHalData->hci_sus_state);
+		RTW_INFO("%s: hci_sus_state=%u\n", __func__, pHalData->hci_sus_state);
 		break;
 
 	case HW_VAR_NAV_UPPER: {
 		u32 usNavUpper = *((u32 *)val);
 
 		if (usNavUpper > HAL_NAV_UPPER_UNIT_8188F * 0xFF) {
-			RT_TRACE(_module_hal_init_c_, _drv_notice_, ("The setting value (0x%08X us) of NAV_UPPER is larger than (%d * 0xFF)!!!\n", usNavUpper, HAL_NAV_UPPER_UNIT_8188F));
 			break;
 		}
 
@@ -6267,15 +5345,9 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 	}
 	break;
 
-#ifndef CONFIG_C2H_PACKET_EN
-	case HW_VAR_C2H_HANDLE:
-		C2HCommandHandler(padapter);
-		break;
-#endif
-
 	case HW_VAR_BCN_VALID:
 #ifdef CONFIG_CONCURRENT_MODE
-		if (padapter->iface_type == IFACE_PORT1) {
+		if (padapter->hw_port == HW_PORT1) {
 			val8 = rtw_read8(padapter,  REG_DWBCN1_CTRL_8188F + 2);
 			val8 |= BIT(0);
 			rtw_write8(padapter, REG_DWBCN1_CTRL_8188F + 2, val8);
@@ -6291,7 +5363,7 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 
 	case HW_VAR_DL_BCN_SEL:
 #ifdef CONFIG_CONCURRENT_MODE
-		if (padapter->iface_type == IFACE_PORT1) {
+		if (padapter->hw_port == HW_PORT1) {
 			/* SW_BCN_SEL - Port1 */
 			val8 = rtw_read8(padapter, REG_DWBCN1_CTRL_8188F + 2);
 			val8 |= BIT(4);
@@ -6306,13 +5378,6 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		}
 		break;
 
-	case HW_VAR_DO_IQK:
-		if (*val)
-			pHalData->bNeedIQK = _TRUE;
-		else
-			pHalData->bNeedIQK = _FALSE;
-		break;
-
 	case HW_VAR_DL_RSVD_PAGE:
 #ifdef CONFIG_BT_COEXIST
 		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
@@ -6324,75 +5389,6 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		}
 		break;
 
-	case HW_VAR_MACID_SLEEP: {
-		/* TODO: 16 MACID? */
-		u32 reg_macid_sleep;
-		u8 bit_shift;
-		u8 id = *(u8 *)val;
-
-		if (id < 32) {
-			reg_macid_sleep = REG_MACID_SLEEP;
-			bit_shift = id;
-		} else if (id < 64) {
-			reg_macid_sleep = REG_MACID_SLEEP_1;
-			bit_shift = id - 32;
-		} else if (id < 96) {
-			reg_macid_sleep = REG_MACID_SLEEP_2;
-			bit_shift = id - 64;
-		} else if (id < 128) {
-			reg_macid_sleep = REG_MACID_SLEEP_3;
-			bit_shift = id - 96;
-		} else {
-			rtw_warn_on(1);
-			break;
-		}
-
-		val32 = rtw_read32(padapter, reg_macid_sleep);
-		DBG_8192C(FUNC_ADPT_FMT ": [HW_VAR_MACID_SLEEP] macid=%d, org reg_0x%03x=0x%08X\n",
-				  FUNC_ADPT_ARG(padapter), id, reg_macid_sleep, val32);
-
-		if (val32 & BIT(bit_shift))
-			break;
-
-		val32 |= BIT(bit_shift);
-		rtw_write32(padapter, reg_macid_sleep, val32);
-	}
-	break;
-
-	case HW_VAR_MACID_WAKEUP: {
-		/* TODO: 16 MACID? */
-		u32 reg_macid_sleep;
-		u8 bit_shift;
-		u8 id = *(u8 *)val;
-
-		if (id < 32) {
-			reg_macid_sleep = REG_MACID_SLEEP;
-			bit_shift = id;
-		} else if (id < 64) {
-			reg_macid_sleep = REG_MACID_SLEEP_1;
-			bit_shift = id - 32;
-		} else if (id < 96) {
-			reg_macid_sleep = REG_MACID_SLEEP_2;
-			bit_shift = id - 64;
-		} else if (id < 128) {
-			reg_macid_sleep = REG_MACID_SLEEP_3;
-			bit_shift = id - 96;
-		} else {
-			rtw_warn_on(1);
-			break;
-		}
-
-		val32 = rtw_read32(padapter, reg_macid_sleep);
-		DBG_8192C(FUNC_ADPT_FMT ": [HW_VAR_MACID_WAKEUP] macid=%d, org reg_0x%03x=0x%08X\n",
-				  FUNC_ADPT_ARG(padapter), id, reg_macid_sleep, val32);
-
-		if (!(val32 & BIT(bit_shift)))
-			break;
-
-		val32 &= ~BIT(bit_shift);
-		rtw_write32(padapter, reg_macid_sleep, val32);
-	}
-	break;
 #ifdef CONFIG_GPIO_WAKEUP
 	case HW_SET_GPIO_WL_CTRL: {
 		u8 enable = *val;
@@ -6405,49 +5401,51 @@ void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 			value |= BIT(6);
 			rtw_write8(padapter, 0x4e, value);
 		}
-		DBG_871X("%s: set WL control, 0x4E=0x%02X\n",
-				 __func__, rtw_read8(padapter, 0x4e));
+		RTW_INFO("%s: set WL control, 0x4E=0x%02X\n",
+			 __func__, rtw_read8(padapter, 0x4e));
 	}
 	break;
 #endif
-	case HW_VAR_EN_HW_UPDATE_TSF:
-		hw_var_set_hw_update_tsf(padapter);
+#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
+	case HW_VAR_TDLS_BCN_EARLY_C2H_RPT:
+		rtl8188f_set_BcnEarly_C2H_Rpt_cmd(padapter, *val);
 		break;
+#endif
 	default:
-		SetHwReg(padapter, variable, val);
+		ret = SetHwReg(padapter, variable, val);
 		break;
 	}
 
-	_func_exit_;
+	return ret;
 }
 
 struct qinfo_8188f {
-	u32 head: 8;
-	u32 pkt_num: 7;
-	u32 tail: 8;
-	u32 ac: 2;
-	u32 macid: 7;
+	u32 head:8;
+	u32 pkt_num:7;
+	u32 tail:8;
+	u32 ac:2;
+	u32 macid:7;
 };
 
 struct bcn_qinfo_8188f {
-	u16 head: 8;
-	u16 pkt_num: 8;
+	u16 head:8;
+	u16 pkt_num:8;
 };
 
 void dump_qinfo_8188f(void *sel, struct qinfo_8188f *info, const char *tag)
 {
 	/*if (info->pkt_num) */
-	DBG_871X_SEL_NL(sel, "%shead:0x%02x, tail:0x%02x, pkt_num:%u, macid:%u, ac:%u\n"
-					, tag ? tag : "", info->head, info->tail, info->pkt_num, info->macid, info->ac
-				   );
+	RTW_PRINT_SEL(sel, "%shead:0x%02x, tail:0x%02x, pkt_num:%u, macid:%u, ac:%u\n"
+		, tag ? tag : "", info->head, info->tail, info->pkt_num, info->macid, info->ac
+		     );
 }
 
 void dump_bcn_qinfo_8188f(void *sel, struct bcn_qinfo_8188f *info, const char *tag)
 {
 	/*if (info->pkt_num) */
-	DBG_871X_SEL_NL(sel, "%shead:0x%02x, pkt_num:%u\n"
-					, tag ? tag : "", info->head, info->pkt_num
-				   );
+	RTW_PRINT_SEL(sel, "%shead:0x%02x, pkt_num:%u\n"
+		      , tag ? tag : "", info->head, info->pkt_num
+		     );
 }
 
 void dump_mac_qinfo_8188f(void *sel, _adapter *adapter)
@@ -6489,6 +5487,70 @@ void dump_mac_qinfo_8188f(void *sel, _adapter *adapter)
 	dump_bcn_qinfo_8188f(sel, (struct bcn_qinfo_8188f *)&bcn_q_info, "BCN ");
 }
 
+static void dump_mac_txfifo_8188f(void *sel, _adapter *adapter)
+{
+	u32 rqpn, rqpn_npq;
+	u32 hpq, lpq, npq, epq, pubq;
+
+	rqpn = rtw_read32(adapter, REG_FIFOPAGE);
+	rqpn_npq = rtw_read32(adapter, REG_RQPN_NPQ);
+
+	hpq = (rqpn & 0xFF);
+	lpq = ((rqpn & 0xFF00)>>8);
+	pubq = ((rqpn & 0xFF0000)>>16);
+	npq = ((rqpn_npq & 0xFF00)>>8);
+	epq = ((rqpn_npq & 0xFF000000)>>24);
+
+	RTW_PRINT_SEL(sel, "Tx: available page num: ");
+	if ((hpq == 0xEA) && (hpq == lpq) && (hpq == pubq))
+		RTW_PRINT_SEL(sel, "N/A (reg val = 0xea)\n");
+	else
+		RTW_PRINT_SEL(sel, "HPQ: %d, LPQ: %d, NPQ: %d, EPQ: %d, PUBQ: %d\n"
+			 , hpq, lpq, npq, epq, pubq);
+}
+
+void rtl8188f_read_wmmedca_reg(PADAPTER adapter, u16 *vo_params, u16 *vi_params, u16 *be_params, u16 *bk_params)
+{
+	u8 vo_reg_params[4];
+	u8 vi_reg_params[4];
+	u8 be_reg_params[4];
+	u8 bk_reg_params[4];
+
+	GetHwReg8188F(adapter, HW_VAR_AC_PARAM_VO, vo_reg_params);
+	GetHwReg8188F(adapter, HW_VAR_AC_PARAM_VI, vi_reg_params);
+	GetHwReg8188F(adapter, HW_VAR_AC_PARAM_BE, be_reg_params);
+	GetHwReg8188F(adapter, HW_VAR_AC_PARAM_BK, bk_reg_params);
+
+	vo_params[0] = vo_reg_params[0];
+	vo_params[1] = vo_reg_params[1] & 0x0F;
+	vo_params[2] = (vo_reg_params[1] & 0xF0) >> 4;
+	vo_params[3] = ((vo_reg_params[3] << 8) | (vo_reg_params[2])) * 32;
+
+	vi_params[0] = vi_reg_params[0];
+	vi_params[1] = vi_reg_params[1] & 0x0F;
+	vi_params[2] = (vi_reg_params[1] & 0xF0) >> 4;
+	vi_params[3] = ((vi_reg_params[3] << 8) | (vi_reg_params[2])) * 32;
+
+	be_params[0] = be_reg_params[0];
+	be_params[1] = be_reg_params[1] & 0x0F;
+	be_params[2] = (be_reg_params[1] & 0xF0) >> 4;
+	be_params[3] = ((be_reg_params[3] << 8) | (be_reg_params[2])) * 32;
+
+	bk_params[0] = bk_reg_params[0];
+	bk_params[1] = bk_reg_params[1] & 0x0F;
+	bk_params[2] = (bk_reg_params[1] & 0xF0) >> 4;
+	bk_params[3] = ((bk_reg_params[3] << 8) | (bk_reg_params[2])) * 32;
+
+	vo_params[1] = (1 << vo_params[1]) - 1;
+	vo_params[2] = (1 << vo_params[2]) - 1;
+	vi_params[1] = (1 << vi_params[1]) - 1;
+	vi_params[2] = (1 << vi_params[2]) - 1;
+	be_params[1] = (1 << be_params[1]) - 1;
+	be_params[2] = (1 << be_params[2]) - 1;
+	bk_params[1] = (1 << bk_params[1]) - 1;
+	bk_params[2] = (1 << bk_params[2]) - 1;
+}
+
 void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
@@ -6504,7 +5566,7 @@ void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 
 	case HW_VAR_BCN_VALID:
 #ifdef CONFIG_CONCURRENT_MODE
-		if (padapter->iface_type == IFACE_PORT1) {
+		if (padapter->hw_port == HW_PORT1) {
 			val8 = rtw_read8(padapter, REG_DWBCN1_CTRL_8188F + 2);
 			*val = (BIT(0) & val8) ? _TRUE : _FALSE;
 		} else
@@ -6516,31 +5578,37 @@ void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		}
 		break;
 
-	case HW_VAR_FWLPS_RF_ON: {
-		/* When we halt NIC, we should check if FW LPS is leave. */
-		u32 valRCR;
+	case HW_VAR_AC_PARAM_VO:
+		val32 = rtw_read32(padapter, REG_EDCA_VO_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
 
-		if ((rtw_is_surprise_removed(padapter)) ||
-			(adapter_to_pwrctl(padapter)->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. */
-			*val = _TRUE;
-		} else {
-			valRCR = rtw_read32(padapter, REG_RCR);
-			valRCR &= 0x00070000;
-			if (valRCR)
-				*val = _FALSE;
-			else
-				*val = _TRUE;
-		}
-	}
-	break;
+	case HW_VAR_AC_PARAM_VI:
+		val32 = rtw_read32(padapter, REG_EDCA_VI_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-	case HW_VAR_CURRENT_ANTENNA:
-		*val = pHalData->CurAntenna;
+	case HW_VAR_AC_PARAM_BE:
+		val32 = rtw_read32(padapter, REG_EDCA_BE_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
+	case HW_VAR_AC_PARAM_BK:
+		val32 = rtw_read32(padapter, REG_EDCA_BK_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
 		break;
-#endif
 
 	case HW_VAR_EFUSE_USAGE:
 		*val = pHalData->EfuseUsedPercentage;
@@ -6564,9 +5632,6 @@ void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 #endif
 		break;
 
-	case HW_VAR_APFM_ON_MAC:
-		*val = pHalData->bMacPwrCtrlOn;
-		break;
 	case HW_VAR_HCI_SUS_STATE:
 		*val = pHalData->hci_sus_state;
 		break;
@@ -6574,6 +5639,10 @@ void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 		val16 = rtw_read16(padapter, REG_TXPKT_EMPTY);
 		*val = (val16 & BIT(10)) ? _TRUE : _FALSE;
 		break;
+	case HW_VAR_CHK_MGQ_CPU_EMPTY:
+		val16 = rtw_read16(padapter, REG_TXPKT_EMPTY);
+		*val = (val16 & BIT(8)) ? _TRUE : _FALSE;
+		break;
 #ifdef CONFIG_WOWLAN
 	case HW_VAR_RPWM_TOG:
 		*val = rtw_read8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1) & BIT7;
@@ -6590,6 +5659,9 @@ void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val)
 	case HW_VAR_DUMP_MAC_QUEUE_INFO:
 		dump_mac_qinfo_8188f(val, padapter);
 		break;
+	case HW_VAR_DUMP_MAC_TXFIFO:
+		dump_mac_txfifo_8188f(val, padapter);
+		break;
 	default:
 		GetHwReg(padapter, variable, val);
 		break;
@@ -6618,26 +5690,90 @@ u8 SetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval)
 	return bResult;
 }
 
-#ifdef CONFIG_C2H_PACKET_EN
-void SetHwRegWithBuf8188F(PADAPTER padapter, u8 variable, u8 *pbuf, int len)
+void hal_ra_info_dump(_adapter *padapter , void *sel)
 {
-	PHAL_DATA_TYPE pHalData;
+	int i;
+	u8 mac_id;
+	u32 cmd;
+	u32 ra_info1, ra_info2, bw_set;
+	u32 rate_mask1, rate_mask2;
+	u8 curr_tx_rate, curr_tx_sgi, hight_rate, lowest_rate;
+	HAL_DATA_TYPE *HalData = GET_HAL_DATA(padapter);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
 
-	_func_enter_;
+	for (i = 0; i < macid_ctl->num; i++) {
 
-	pHalData = GET_HAL_DATA(padapter);
+		if (rtw_macid_is_used(macid_ctl, i) && !rtw_macid_is_bmc(macid_ctl, i)) {
 
-	switch (variable) {
-	case HW_VAR_C2H_HANDLE:
-		C2HPacketHandler_8188F(padapter, pbuf, len);
-		break;
+			mac_id = (u8) i;
+			_RTW_PRINT_SEL(sel , "============ RA status check  Mac_id:%d ===================\n", mac_id);
 
-	default:
-		break;
+			cmd = 0x40000100 | mac_id;
+			rtw_write32(padapter, REG_HMEBOX_DBG_2_8188F, cmd);
+			rtw_msleep_os(10);
+			ra_info1 = rtw_read32(padapter, 0x2F0);
+			curr_tx_rate = ra_info1 & 0x7F;
+			curr_tx_sgi = (ra_info1 >> 7) & 0x01;
+
+			_RTW_PRINT_SEL(sel , "[ ra_info1:0x%08x ] =>cur_tx_rate= %s,cur_sgi:%d\n" , ra_info1 , HDATA_RATE(curr_tx_rate), curr_tx_sgi);
+			_RTW_PRINT_SEL(sel , "[ ra_info1:0x%08x ] => PWRSTS = 0x%02x\n", ra_info1, (ra_info1 >> 8)  & 0x07);
+
+			cmd = 0x40000400 | mac_id;
+			rtw_write32(padapter, REG_HMEBOX_DBG_2_8188F, cmd);
+			rtw_msleep_os(10);
+			ra_info1 = rtw_read32(padapter, 0x2F0);
+			ra_info2 = rtw_read32(padapter, 0x2F4);
+			rate_mask1 = rtw_read32(padapter, 0x2F8);
+			rate_mask2 = rtw_read32(padapter, 0x2FC);
+			hight_rate = ra_info2 & 0xFF;
+			lowest_rate = (ra_info2 >> 8)  & 0xFF;
+			bw_set = (ra_info1 >> 8)  & 0xFF;
+
+			_RTW_PRINT_SEL(sel , "[ ra_info1:0x%08x ] => VHT_EN=0x%02x, ", ra_info1, (ra_info1 >> 24) & 0xFF);
+
+			switch (bw_set) {
+
+			case CHANNEL_WIDTH_20:
+				_RTW_PRINT_SEL(sel , "BW_setting=20M\n");
+				break;
+
+			case CHANNEL_WIDTH_40:
+				_RTW_PRINT_SEL(sel , "BW_setting=40M\n");
+				break;
+
+			case CHANNEL_WIDTH_80:
+				_RTW_PRINT_SEL(sel , "BW_setting=80M\n");
+				break;
+
+			case CHANNEL_WIDTH_160:
+				_RTW_PRINT_SEL(sel , "BW_setting=160M\n");
+				break;
+
+			default:
+				_RTW_PRINT_SEL(sel , "BW_setting=0x%02x\n", bw_set);
+				break;
+
+			}
+
+			_RTW_PRINT_SEL(sel , "[ ra_info1:0x%08x ] =>RSSI=%d,  DISRA=0x%02x\n",
+				       ra_info1,
+				       ra_info1 & 0xFF,
+				       (ra_info1 >> 16) & 0xFF);
+
+			_RTW_PRINT_SEL(sel , "[ ra_info2:0x%08x ] =>hight_rate=%s, lowest_rate=%s, SGI=0x%02x, RateID=%d\n",
+				       ra_info2,
+				       HDATA_RATE(hight_rate),
+				       HDATA_RATE(lowest_rate),
+				       (ra_info2 >> 16) & 0xFF,
+				       (ra_info2 >> 24) & 0xFF);
+
+			_RTW_PRINT_SEL(sel , "rate_mask2=0x%08x, rate_mask1=0x%08x\n", rate_mask2, rate_mask1);
+
+
+		}
 	}
-	_func_exit_;
 }
-#endif /* CONFIG_C2H_PACKET_EN */
 
 /*
  *	Description:
@@ -6685,55 +5821,9 @@ u8 GetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval)
 		*((u8 *)pval) = _FALSE;
 		break;
 
-	case HW_DEF_RA_INFO_DUMP: {
-		u8 mac_id = *(u8 *)pval;
-		u32 cmd;
-		u32 ra_info1, ra_info2;
-		u32 rate_mask1, rate_mask2;
-		u8 curr_tx_rate, curr_tx_sgi, hight_rate, lowest_rate;
-
-		DBG_8192C("============ RA status check  Mac_id:%d ===================\n", mac_id);
-
-		cmd = 0x40000100 | mac_id;
-		rtw_write32(padapter, REG_HMEBOX_DBG_2_8188F, cmd);
-		rtw_msleep_os(10);
-		ra_info1 = rtw_read32(padapter, 0x2F0);
-		curr_tx_rate = ra_info1 & 0x7F;
-		curr_tx_sgi = (ra_info1 >> 7) & 0x01;
-		DBG_8192C("[ ra_info1:0x%08x ] =>cur_tx_rate= %s,cur_sgi:%d, PWRSTS = 0x%02x\n",
-				  ra_info1,
-				  HDATA_RATE(curr_tx_rate),
-				  curr_tx_sgi,
-				  (ra_info1 >> 8)  & 0x07);
-
-		cmd = 0x40000400 | mac_id;
-		rtw_write32(padapter, REG_HMEBOX_DBG_2_8188F, cmd);
-		rtw_msleep_os(10);
-		ra_info1 = rtw_read32(padapter, 0x2F0);
-		ra_info2 = rtw_read32(padapter, 0x2F4);
-		rate_mask1 = rtw_read32(padapter, 0x2F8);
-		rate_mask2 = rtw_read32(padapter, 0x2FC);
-		hight_rate = ra_info2 & 0xFF;
-		lowest_rate = (ra_info2 >> 8)  & 0xFF;
-
-		DBG_8192C("[ ra_info1:0x%08x ] =>RSSI=%d, BW_setting=0x%02x, DISRA=0x%02x, VHT_EN=0x%02x\n",
-				  ra_info1,
-				  ra_info1 & 0xFF,
-				  (ra_info1 >> 8)  & 0xFF,
-				  (ra_info1 >> 16) & 0xFF,
-				  (ra_info1 >> 24) & 0xFF);
-
-		DBG_8192C("[ ra_info2:0x%08x ] =>hight_rate=%s, lowest_rate=%s, SGI=0x%02x, RateID=%d\n",
-				  ra_info2,
-				  HDATA_RATE(hight_rate),
-				  HDATA_RATE(lowest_rate),
-				  (ra_info2 >> 16) & 0xFF,
-				  (ra_info2 >> 24) & 0xFF);
-
-		DBG_8192C("rate_mask2=0x%08x, rate_mask1=0x%08x\n", rate_mask2, rate_mask1);
-
-	}
-	break;
+	case HW_DEF_RA_INFO_DUMP:
+		hal_ra_info_dump(padapter, pval);
+		break;
 
 	case HAL_DEF_TX_PAGE_BOUNDARY:
 		if (!padapter->registrypriv.wifi_spec)
@@ -6741,10 +5831,6 @@ u8 GetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval)
 		else
 			*(u8 *)pval = WMM_NORMAL_TX_PAGE_BOUNDARY_8188F;
 		break;
-
-	case HAL_DEF_MACID_SLEEP:
-		*(u8 *)pval = _TRUE; /* support macid sleep */
-		break;
 	case HAL_DEF_TX_PAGE_SIZE:
 		*((u32 *)pval) = PAGE_SIZE_128;
 		break;
@@ -6769,7 +5855,7 @@ u8 GetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval)
 void Hal_DetectWoWMode(PADAPTER pAdapter)
 {
 	adapter_to_pwrctl(pAdapter)->bSupportRemoteWakeup = _TRUE;
-	DBG_871X("%s\n", __func__);
+	RTW_INFO("%s\n", __func__);
 }
 #endif /*CONFIG_WOWLAN */
 
@@ -6779,9 +5865,14 @@ void rtl8188f_start_thread(_adapter *padapter)
 #ifndef CONFIG_SDIO_TX_TASKLET
 	struct xmit_priv *xmitpriv = &padapter->xmitpriv;
 
-	xmitpriv->SdioXmitThread = kthread_run(rtl8188fs_xmit_thread, padapter, "RTWHALXT");
-	if (IS_ERR(xmitpriv->SdioXmitThread))
-		RT_TRACE(_module_hal_xmit_c_, _drv_err_, ("%s: start rtl8188fs_xmit_thread FAIL!!\n", __func__));
+	if (xmitpriv->SdioXmitThread == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT " start RTWHALXT\n", FUNC_ADPT_ARG(padapter));
+		xmitpriv->SdioXmitThread = kthread_run(rtl8188fs_xmit_thread, padapter, "RTWHALXT");
+		if (IS_ERR(xmitpriv->SdioXmitThread)) {
+			RTW_ERR("%s: start rtl8188fs_xmit_thread FAIL!!\n", __func__);
+			xmitpriv->SdioXmitThread = NULL;
+		}
+	}
 #endif
 #endif
 }
@@ -6795,8 +5886,8 @@ void rtl8188f_stop_thread(_adapter *padapter)
 	/* stop xmit_buf_thread */
 	if (xmitpriv->SdioXmitThread) {
 		_rtw_up_sema(&xmitpriv->SdioXmitSema);
-		_rtw_down_sema(&xmitpriv->SdioXmitTerminateSema);
-		xmitpriv->SdioXmitThread = 0;
+		rtw_thread_stop(xmitpriv->SdioXmitThread);
+		xmitpriv->SdioXmitThread = NULL;
 	}
 #endif
 #endif
@@ -6806,7 +5897,7 @@ void rtl8188f_stop_thread(_adapter *padapter)
 extern void check_bt_status_work(void *data);
 void rtl8188fs_init_checkbthang_workqueue(_adapter *adapter)
 {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
 	adapter->priv_checkbt_wq = alloc_workqueue("sdio_wq", 0, 0);
 #else
 	adapter->priv_checkbt_wq = create_workqueue("sdio_wq");
@@ -6844,26 +5935,17 @@ void rtl8188f_set_hal_ops(struct hal_ops *pHalFunc)
 
 	pHalFunc->read_chip_version = &rtl8188f_read_chip_version;
 
-	pHalFunc->UpdateRAMaskHandler = &UpdateHalRAMask8188F;
 	pHalFunc->set_chnl_bw_handler = &PHY_SetSwChnlBWMode8188F;
 
 	pHalFunc->set_tx_power_level_handler = &PHY_SetTxPowerLevel8188F;
 	pHalFunc->get_tx_power_level_handler = &PHY_GetTxPowerLevel8188F;
 
+	pHalFunc->set_tx_power_index_handler = PHY_SetTxPowerIndex_8188F;
 	pHalFunc->get_tx_power_index_handler = &PHY_GetTxPowerIndex_8188F;
 
 	pHalFunc->hal_dm_watchdog = &rtl8188f_HalDmWatchDog;
-#ifdef CONFIG_LPS_LCLK_WD_TIMER
-	pHalFunc->hal_dm_watchdog_in_lps = &rtl8188f_HalDmWatchDog_in_LPS;
-#endif /* CONFIG_LPS_LCLK_WD_TIMER */
-
-#ifdef CONFIG_C2H_PACKET_EN
-	pHalFunc->SetHwRegHandlerWithBuf = &SetHwRegWithBuf8188F;
-#endif /* CONFIG_C2H_PACKET_EN */
-
 	pHalFunc->SetBeaconRelatedRegistersHandler = &rtl8188f_SetBeaconRelatedRegisters;
 
-	pHalFunc->Add_RateATid = &rtl8188f_Add_RateATid;
 
 	pHalFunc->run_thread = &rtl8188f_start_thread;
 	pHalFunc->cancel_thread = &rtl8188f_stop_thread;
@@ -6873,6 +5955,8 @@ void rtl8188f_set_hal_ops(struct hal_ops *pHalFunc)
 	pHalFunc->read_rfreg = &PHY_QueryRFReg_8188F;
 	pHalFunc->write_rfreg = &PHY_SetRFReg_8188F;
 
+	pHalFunc->read_wmmedca_reg = &rtl8188f_read_wmmedca_reg;
+
 	/* Efuse related function */
 	pHalFunc->BTEfusePowerSwitch = &Hal_BT_EfusePowerSwitch;
 	pHalFunc->EfusePowerSwitch = &Hal_EfusePowerSwitch;
@@ -6902,7 +5986,6 @@ void rtl8188f_set_hal_ops(struct hal_ops *pHalFunc)
 	pHalFunc->hal_notch_filter = &hal_notch_filter_8188f;
 
 	pHalFunc->c2h_handler = c2h_handler_8188f;
-	pHalFunc->c2h_id_filter_ccx = c2h_id_filter_ccx_8188f;
 
 	pHalFunc->fill_h2c_cmd = &FillH2CCmd8188F;
 	pHalFunc->fill_fake_txdesc = &rtl8188f_fill_fake_txdesc;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_phycfg.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_phycfg.c
index 06c70adf2134..e4fdd8183706 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_phycfg.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_phycfg.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTL8188F_PHYCFG_C_
 
 #include <rtl8188f_hal.h>
@@ -70,7 +66,7 @@ phy_CalculateBitShift(
 			break;
 	}
 
-	return (i);
+	return i;
 }
 
 
@@ -102,13 +98,12 @@ PHY_QueryBBReg_8188F(
 	return 0;
 #endif
 
-	/*RT_TRACE(COMP_RF, DBG_TRACE, ("--->PHY_QueryBBReg(): RegAddr(%#lx), BitMask(%#lx)\n", RegAddr, BitMask)); */
 
 	OriginalValue = rtw_read32(Adapter, RegAddr);
 	BitShift = phy_CalculateBitShift(BitMask);
 	ReturnValue = (OriginalValue & BitMask) >> BitShift;
 
-	return (ReturnValue);
+	return ReturnValue;
 
 }
 
@@ -147,7 +142,6 @@ PHY_SetBBReg_8188F(
 	return;
 #endif
 
-	/*RT_TRACE(COMP_RF, DBG_TRACE, ("--->PHY_SetBBReg(): RegAddr(%#lx), BitMask(%#lx), Data(%#lx)\n", RegAddr, BitMask, Data)); */
 
 	if (BitMask != bMaskDWord) { /*if not "double word" write */
 		OriginalValue = rtw_read32(Adapter, RegAddr);
@@ -182,12 +176,12 @@ PHY_SetBBReg_8188F(
 static	u32
 phy_FwRFSerialRead(
 	IN	PADAPTER			Adapter,
-	IN	RF_PATH			eRFPath,
+	IN	enum rf_path			eRFPath,
 	IN	u32				Offset)
 {
 	u32		retValue = 0;
 	/*RT_ASSERT(FALSE,("deprecate!\n")); */
-	return	(retValue);
+	return retValue;
 
 }	/* phy_FwRFSerialRead */
 
@@ -211,7 +205,7 @@ phy_FwRFSerialRead(
 static	VOID
 phy_FwRFSerialWrite(
 	IN	PADAPTER			Adapter,
-	IN	RF_PATH			eRFPath,
+	IN	enum rf_path			eRFPath,
 	IN	u32				Offset,
 	IN	u32				Data)
 {
@@ -221,7 +215,7 @@ phy_FwRFSerialWrite(
 static	u32
 phy_RFSerialRead_8188F(
 	IN	PADAPTER			Adapter,
-	IN	RF_PATH			eRFPath,
+	IN	enum rf_path			eRFPath,
 	IN	u32				Offset
 )
 {
@@ -243,18 +237,18 @@ phy_RFSerialRead_8188F(
 	NewOffset = Offset;
 
 	if (eRFPath == RF_PATH_A) {
-		tmplong2 = PHY_QueryBBReg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord);
+		tmplong2 = phy_query_bb_reg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord);
 		tmplong2 = (tmplong2 & (~bLSSIReadAddress)) | (NewOffset << 23) | bLSSIReadEdge;	/*T65 RF */
-		PHY_SetBBReg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 & (~bLSSIReadEdge));
+		phy_set_bb_reg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 & (~bLSSIReadEdge));
 	} else {
-		tmplong2 = PHY_QueryBBReg(Adapter, rFPGA0_XB_HSSIParameter2 | MaskforPhySet, bMaskDWord);
+		tmplong2 = phy_query_bb_reg(Adapter, rFPGA0_XB_HSSIParameter2 | MaskforPhySet, bMaskDWord);
 		tmplong2 = (tmplong2 & (~bLSSIReadAddress)) | (NewOffset << 23) | bLSSIReadEdge;	/*T65 RF */
-		PHY_SetBBReg(Adapter, rFPGA0_XB_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 & (~bLSSIReadEdge));
+		phy_set_bb_reg(Adapter, rFPGA0_XB_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 & (~bLSSIReadEdge));
 	}
 
-	tmplong2 = PHY_QueryBBReg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord);
-	PHY_SetBBReg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 & (~bLSSIReadEdge));
-	PHY_SetBBReg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 | bLSSIReadEdge);
+	tmplong2 = phy_query_bb_reg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord);
+	phy_set_bb_reg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 & (~bLSSIReadEdge));
+	phy_set_bb_reg(Adapter, rFPGA0_XA_HSSIParameter2 | MaskforPhySet, bMaskDWord, tmplong2 | bLSSIReadEdge);
 
 	rtw_udelay_os(10);
 
@@ -263,18 +257,18 @@ phy_RFSerialRead_8188F(
 	rtw_udelay_os(10);
 
 	if (eRFPath == RF_PATH_A)
-		RfPiEnable = (u1Byte)PHY_QueryBBReg(Adapter, rFPGA0_XA_HSSIParameter1 | MaskforPhySet, BIT8);
+		RfPiEnable = (u1Byte)phy_query_bb_reg(Adapter, rFPGA0_XA_HSSIParameter1 | MaskforPhySet, BIT8);
 	else if (eRFPath == RF_PATH_B)
-		RfPiEnable = (u1Byte)PHY_QueryBBReg(Adapter, rFPGA0_XB_HSSIParameter1 | MaskforPhySet, BIT8);
+		RfPiEnable = (u1Byte)phy_query_bb_reg(Adapter, rFPGA0_XB_HSSIParameter1 | MaskforPhySet, BIT8);
 
 	if (RfPiEnable) {
 		/* Read from BBreg8b8, 12 bits for 8190, 20bits for T65 RF */
-		retValue = PHY_QueryBBReg(Adapter, pPhyReg->rfLSSIReadBackPi | MaskforPhySet, bLSSIReadBackData);
+		retValue = phy_query_bb_reg(Adapter, pPhyReg->rfLSSIReadBackPi | MaskforPhySet, bLSSIReadBackData);
 
 		/*RT_DISP(FINIT, INIT_RF, ("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 | MaskforPhySet, bLSSIReadBackData);
+		retValue = phy_query_bb_reg(Adapter, pPhyReg->rfLSSIReadBack | MaskforPhySet, bLSSIReadBackData);
 
 		/*RT_DISP(FINIT, INIT_RF,("Readback from RF-SI : 0x%x\n", retValue)); */
 	}
@@ -290,7 +284,7 @@ phy_RFSerialRead_8188F(
  *
  * Input:
  *		PADAPTER		Adapter,
- *			RF_PATH		RFPath,				Radio path of A/B/C/D
+			enum rf_path		RFPath,				Radio path of A/B/C/D
  *			u4Byte			Offset,			The target address to be read
  *			u4Byte			Data			The new register Data in the target bit position
  *											of the target to be read
@@ -304,7 +298,7 @@ phy_RFSerialRead_8188F(
  *			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
+ * 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
@@ -329,7 +323,7 @@ phy_RFSerialRead_8188F(
 static	VOID
 phy_RFSerialWrite_8188F(
 	IN	PADAPTER			Adapter,
-	IN	RF_PATH			eRFPath,
+	IN	enum rf_path			eRFPath,
 	IN	u32				Offset,
 	IN	u32				Data
 )
@@ -360,7 +354,7 @@ phy_RFSerialWrite_8188F(
 	/* */
 	/* Write Operation */
 	/* */
-	PHY_SetBBReg(Adapter, pPhyReg->rf3wireOffset, bMaskDWord, DataAndAddr);
+	phy_set_bb_reg(Adapter, pPhyReg->rf3wireOffset, bMaskDWord, DataAndAddr);
 	/*RTPRINT(FPHY, PHY_RFW, ("RFW-%d Addr[0x%lx]=0x%lx\n", eRFPath, pPhyReg->rf3wireOffset, DataAndAddr)); */
 
 }
@@ -373,7 +367,7 @@ phy_RFSerialWrite_8188F(
  *
  * Input:
  *		PADAPTER	Adapter,
- *		RF_PATH	eRFPath,		Radio path of A/B/C/D
+		enum rf_path	eRFPath,		Radio path of A/B/C/D
  *		u4Byte	RegAddr,		The target address to be read
  *		u4Byte	BitMask			The target bit position in the target address
  *										to be read
@@ -385,7 +379,7 @@ phy_RFSerialWrite_8188F(
 u32
 PHY_QueryRFReg_8188F(
 	IN	PADAPTER			Adapter,
-	IN	u8			eRFPath,
+	IN	enum rf_path			eRFPath,
 	IN	u32				RegAddr,
 	IN	u32				BitMask
 )
@@ -401,7 +395,7 @@ PHY_QueryRFReg_8188F(
 	BitShift =  phy_CalculateBitShift(BitMask);
 	Readback_Value = (Original_Value & BitMask) >> BitShift;
 
-	return (Readback_Value);
+	return Readback_Value;
 }
 
 /**
@@ -411,7 +405,7 @@ PHY_QueryRFReg_8188F(
 *
 * Input:
 *			PADAPTER		Adapter,
-*			RF_PATH			eRFPath,		Radio path of A/B/C/D
+			enum rf_path			eRFPath,		Radio path of A/B/C/D
 *			u4Byte			RegAddr,		The target address to be modified
 *			u4Byte			BitMask			The target bit position in the target address
 *											to be modified
@@ -425,7 +419,7 @@ PHY_QueryRFReg_8188F(
 VOID
 PHY_SetRFReg_8188F(
 	IN	PADAPTER			Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path				eRFPath,
 	IN	u32				RegAddr,
 	IN	u32				BitMask,
 	IN	u32				Data
@@ -483,7 +477,7 @@ s32 PHY_MACConfig8188F(PADAPTER Adapter)
 #endif
 	{
 #ifdef CONFIG_EMBEDDED_FWIMG
-		ODM_ConfigMACWithHeaderFile(&pHalData->odmpriv);
+		odm_config_mac_with_header_file(&pHalData->odmpriv);
 		rtStatus = _SUCCESS;
 #endif/*CONFIG_EMBEDDED_FWIMG */
 	}
@@ -511,28 +505,28 @@ phy_InitBBRFRegisterDefinition(
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
 
 	/* RF Interface Sowrtware Control */
-	pHalData->PHYRegDef[ODM_RF_PATH_A].rfintfs = rFPGA0_XAB_RFInterfaceSW; /* 16 LSBs if read 32-bit from 0x870 */
-	pHalData->PHYRegDef[ODM_RF_PATH_B].rfintfs = rFPGA0_XAB_RFInterfaceSW; /* 16 MSBs if read 32-bit from 0x870 (16-bit for 0x872) */
+	pHalData->PHYRegDef[RF_PATH_A].rfintfs = rFPGA0_XAB_RFInterfaceSW; /* 16 LSBs if read 32-bit from 0x870 */
+	pHalData->PHYRegDef[RF_PATH_B].rfintfs = rFPGA0_XAB_RFInterfaceSW; /* 16 MSBs if read 32-bit from 0x870 (16-bit for 0x872) */
 
 	/* RF Interface Output (and Enable) */
-	pHalData->PHYRegDef[ODM_RF_PATH_A].rfintfo = rFPGA0_XA_RFInterfaceOE; /* 16 LSBs if read 32-bit from 0x860 */
-	pHalData->PHYRegDef[ODM_RF_PATH_B].rfintfo = rFPGA0_XB_RFInterfaceOE; /* 16 LSBs if read 32-bit from 0x864 */
+	pHalData->PHYRegDef[RF_PATH_A].rfintfo = rFPGA0_XA_RFInterfaceOE; /* 16 LSBs if read 32-bit from 0x860 */
+	pHalData->PHYRegDef[RF_PATH_B].rfintfo = rFPGA0_XB_RFInterfaceOE; /* 16 LSBs if read 32-bit from 0x864 */
 
 	/* RF Interface (Output and)  Enable */
-	pHalData->PHYRegDef[ODM_RF_PATH_A].rfintfe = rFPGA0_XA_RFInterfaceOE; /* 16 MSBs if read 32-bit from 0x860 (16-bit for 0x862) */
-	pHalData->PHYRegDef[ODM_RF_PATH_B].rfintfe = rFPGA0_XB_RFInterfaceOE; /* 16 MSBs if read 32-bit from 0x864 (16-bit for 0x866) */
+	pHalData->PHYRegDef[RF_PATH_A].rfintfe = rFPGA0_XA_RFInterfaceOE; /* 16 MSBs if read 32-bit from 0x860 (16-bit for 0x862) */
+	pHalData->PHYRegDef[RF_PATH_B].rfintfe = rFPGA0_XB_RFInterfaceOE; /* 16 MSBs if read 32-bit from 0x864 (16-bit for 0x866) */
 
-	pHalData->PHYRegDef[ODM_RF_PATH_A].rf3wireOffset = rFPGA0_XA_LSSIParameter; /*LSSI Parameter */
-	pHalData->PHYRegDef[ODM_RF_PATH_B].rf3wireOffset = rFPGA0_XB_LSSIParameter;
+	pHalData->PHYRegDef[RF_PATH_A].rf3wireOffset = rFPGA0_XA_LSSIParameter; /*LSSI Parameter */
+	pHalData->PHYRegDef[RF_PATH_B].rf3wireOffset = rFPGA0_XB_LSSIParameter;
 
-	pHalData->PHYRegDef[ODM_RF_PATH_A].rfHSSIPara2 = rFPGA0_XA_HSSIParameter2;  /*wire control parameter2 */
-	pHalData->PHYRegDef[ODM_RF_PATH_B].rfHSSIPara2 = rFPGA0_XB_HSSIParameter2;  /*wire control parameter2 */
+	pHalData->PHYRegDef[RF_PATH_A].rfHSSIPara2 = rFPGA0_XA_HSSIParameter2;  /*wire control parameter2 */
+	pHalData->PHYRegDef[RF_PATH_B].rfHSSIPara2 = rFPGA0_XB_HSSIParameter2;  /*wire control parameter2 */
 
 	/* Tranceiver Readback LSSI/HSPI mode */
-	pHalData->PHYRegDef[ODM_RF_PATH_A].rfLSSIReadBack = rFPGA0_XA_LSSIReadBack;
-	pHalData->PHYRegDef[ODM_RF_PATH_B].rfLSSIReadBack = rFPGA0_XB_LSSIReadBack;
-	pHalData->PHYRegDef[ODM_RF_PATH_A].rfLSSIReadBackPi = TransceiverA_HSPI_Readback;
-	pHalData->PHYRegDef[ODM_RF_PATH_B].rfLSSIReadBackPi = TransceiverB_HSPI_Readback;
+	pHalData->PHYRegDef[RF_PATH_A].rfLSSIReadBack = rFPGA0_XA_LSSIReadBack;
+	pHalData->PHYRegDef[RF_PATH_B].rfLSSIReadBack = rFPGA0_XB_LSSIReadBack;
+	pHalData->PHYRegDef[RF_PATH_A].rfLSSIReadBackPi = TransceiverA_HSPI_Readback;
+	pHalData->PHYRegDef[RF_PATH_B].rfLSSIReadBackPi = TransceiverB_HSPI_Readback;
 
 }
 
@@ -552,13 +546,13 @@ phy_BB8188f_Config_ParaFile(
 #endif
 	{
 #ifdef CONFIG_EMBEDDED_FWIMG
-		if (HAL_STATUS_SUCCESS != ODM_ConfigBBWithHeaderFile(&pHalData->odmpriv, CONFIG_BB_PHY_REG))
+		if (HAL_STATUS_SUCCESS != odm_config_bb_with_header_file(&pHalData->odmpriv, CONFIG_BB_PHY_REG))
 			rtStatus = _FAIL;
 #endif
 	}
 
 	if (rtStatus != _SUCCESS) {
-		DBG_8192C("%s():Write BB Reg Fail!!", __func__);
+		RTW_INFO("%s():Write BB Reg Fail!!", __func__);
 		goto phy_BB8190_Config_ParaFile_Fail;
 	}
 
@@ -572,13 +566,13 @@ phy_BB8188f_Config_ParaFile(
 #endif
 		{
 #ifdef CONFIG_EMBEDDED_FWIMG
-			if (HAL_STATUS_SUCCESS != ODM_ConfigBBWithHeaderFile(&pHalData->odmpriv, CONFIG_BB_PHY_REG_MP))
+			if (HAL_STATUS_SUCCESS != odm_config_bb_with_header_file(&pHalData->odmpriv, CONFIG_BB_PHY_REG_MP))
 				rtStatus = _FAIL;
 #endif
 		}
 
 		if (rtStatus != _SUCCESS) {
-			DBG_8192C("%s():Write BB Reg MP Fail!!", __func__);
+			RTW_INFO("%s():Write BB Reg MP Fail!!", __func__);
 			goto phy_BB8190_Config_ParaFile_Fail;
 		}
 	}
@@ -592,13 +586,13 @@ phy_BB8188f_Config_ParaFile(
 #endif
 	{
 #ifdef CONFIG_EMBEDDED_FWIMG
-		if (HAL_STATUS_SUCCESS != ODM_ConfigBBWithHeaderFile(&pHalData->odmpriv, CONFIG_BB_AGC_TAB))
+		if (HAL_STATUS_SUCCESS != odm_config_bb_with_header_file(&pHalData->odmpriv, CONFIG_BB_AGC_TAB))
 			rtStatus = _FAIL;
 #endif
 	}
 
 	if (rtStatus != _SUCCESS) {
-		DBG_8192C("%s():AGC Table Fail\n", __func__);
+		RTW_INFO("%s():AGC Table Fail\n", __func__);
 		goto phy_BB8190_Config_ParaFile_Fail;
 	}
 
@@ -615,7 +609,7 @@ PHY_BBConfig8188F(
 {
 	int	rtStatus = _SUCCESS;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u32	RegVal;
+	u16	RegVal;
 	u8	TmpU1B = 0;
 	u8	value8;
 
@@ -623,13 +617,14 @@ PHY_BBConfig8188F(
 
 	/* Enable BB and RF */
 	RegVal = rtw_read16(Adapter, REG_SYS_FUNC_EN);
-	rtw_write16(Adapter, REG_SYS_FUNC_EN, (u16)(RegVal | BIT13 | BIT0 | BIT1));
+	RegVal |= BIT13 | FEN_BB_GLB_RSTn | FEN_BBRSTB;
+	rtw_write16(Adapter, REG_SYS_FUNC_EN, RegVal);
 
-#if 0   /* TODO: [BB]. reg 948 is only use for bt_coex  */
+#if 0   /* TODO: [BB]. reg 948 is only use for bt_coex */
 #ifdef CONFIG_USB_HCI
 	rtw_write32(Adapter, 0x948, 0x0);	/* USB use Antenna S0 */
 #else
-	if (pHalData->ant_path == ODM_RF_PATH_A)
+	if (pHalData->ant_path == RF_PATH_A)
 		rtw_write32(Adapter, 0x948, 0x280);
 	else
 		rtw_write32(Adapter, 0x948, 0x0);
@@ -640,7 +635,7 @@ PHY_BBConfig8188F(
 
 	rtw_usleep_os(10);
 
-	PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1, 0xfffff, 0x780);
+	phy_set_rf_reg(Adapter, RF_PATH_A, 0x1, 0xfffff, 0x780);
 
 #if 0
 	/* 20090923 Joseph: Advised by Steven and Jenyu. Power sequence before init RF. */
@@ -648,13 +643,10 @@ PHY_BBConfig8188F(
 	rtw_write8(Adapter, REG_AFE_PLL_CTRL + 1, 0xdb);
 #endif
 
-	/* rtw_write8(Adapter, REG_SYS_FUNC_EN, FEN_PPLL|FEN_PCIEA|FEN_DIO_PCIE|FEN_BB_GLB_RSTn|FEN_BBRSTB); */
-	rtw_write8(Adapter, REG_SYS_FUNC_EN, FEN_USBD | FEN_USBA | FEN_BB_GLB_RSTn | FEN_BBRSTB);
-
 	/* Config BB and AGC */
 	rtStatus = phy_BB8188f_Config_ParaFile(Adapter);
 
-	hal_set_crystal_cap(Adapter, pHalData->CrystalCap);
+	hal_set_crystal_cap(Adapter, pHalData->crystal_cap);
 
 	return rtStatus;
 }
@@ -677,20 +669,20 @@ PHY_BB8188F_Config_1T(
 )
 {
 	/* BB OFDM RX Path_A */
-	PHY_SetBBReg(Adapter, rRxPath_Jaguar, bRxPath_Jaguar, 0x11);
+	phy_set_bb_reg(Adapter, rRxPath_Jaguar, bRxPath_Jaguar, 0x11);
 	/* BB OFDM TX Path_A */
-	PHY_SetBBReg(Adapter, rTxPath_Jaguar, bMaskLWord, 0x1111);
+	phy_set_bb_reg(Adapter, rTxPath_Jaguar, bMaskLWord, 0x1111);
 	/* BB CCK R/Rx Path_A */
-	PHY_SetBBReg(Adapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
+	phy_set_bb_reg(Adapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
 	/* MCS support */
-	PHY_SetBBReg(Adapter, 0x8bc, 0xc0000060, 0x4);
+	phy_set_bb_reg(Adapter, 0x8bc, 0xc0000060, 0x4);
 	/* RF Path_B HSSI OFF */
-	PHY_SetBBReg(Adapter, 0xe00, 0xf, 0x4);
+	phy_set_bb_reg(Adapter, 0xe00, 0xf, 0x4);
 	/* RF Path_B Power Down */
-	PHY_SetBBReg(Adapter, 0xe90, bMaskDWord, 0);
+	phy_set_bb_reg(Adapter, 0xe90, bMaskDWord, 0);
 	/* ADDA Path_B OFF */
-	PHY_SetBBReg(Adapter, 0xe60, bMaskDWord, 0);
-	PHY_SetBBReg(Adapter, 0xe64, bMaskDWord, 0);
+	phy_set_bb_reg(Adapter, 0xe60, bMaskDWord, 0);
+	phy_set_bb_reg(Adapter, 0xe64, bMaskDWord, 0);
 }
 #endif
 
@@ -717,9 +709,9 @@ PHY_RFConfig8188F(
  *
  * Overview:    This function read RF parameters from general file format, and do RF 3-wire
  *
- * Input:      	PADAPTER			Adapter
- *			ps1Byte 				pFileName
- *			RF_PATH				eRFPath
+ * Input:	PADAPTER			Adapter
+ *			ps1Byte				pFileName
+ *			enum rf_path				eRFPath
  *
  * Output:      NONE
  *
@@ -731,50 +723,12 @@ int
 PHY_ConfigRFWithParaFile_8188F(
 	IN	PADAPTER		Adapter,
 	IN	u8				*pFileName,
-	RF_PATH				eRFPath
+	enum rf_path				eRFPath
 )
 {
 	return _SUCCESS;
 }
 
-/***************************************** */
-/*-----------------------------------------------------------------------------
- * Function:    PHY_ConfigRFWithHeaderFile()
- *
- * Overview:    This function read RF parameters from general file format, and do RF 3-wire
- *
- * Input:      	PADAPTER			Adapter
- *			ps1Byte 				pFileName
- *			RF_PATH				eRFPath
- *
- * Output:      NONE
- *
- * Return:      RT_STATUS_SUCCESS: configuration file exist
- *
- * Note:		Delay may be required for RF configuration
- *---------------------------------------------------------------------------*/
-void phy_PowerIndexCheck8188F(
-	IN	PADAPTER		Adapter,
-	IN	u8			channel,
-	IN OUT u8		*cckPowerLevel,
-	IN OUT u8		*ofdmPowerLevel,
-	IN OUT u8		*BW20PowerLevel,
-	IN OUT u8		*BW40PowerLevel
-)
-{
-
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-
-	pHalData->CurrentCckTxPwrIdx = cckPowerLevel[0];
-	pHalData->CurrentOfdm24GTxPwrIdx = ofdmPowerLevel[0];
-	pHalData->CurrentBW2024GTxPwrIdx = BW20PowerLevel[0];
-	pHalData->CurrentBW4024GTxPwrIdx = BW40PowerLevel[0];
-
-	RT_TRACE(_module_hal_init_c_, _drv_info_,
-			 ("PHY_SetTxPowerLevel8188F(): CurrentCckTxPwrIdx : 0x%x,CurrentOfdm24GTxPwrIdx: 0x%x\n",
-			  pHalData->CurrentCckTxPwrIdx, pHalData->CurrentOfdm24GTxPwrIdx));
-}
-
 /**************************************************************************************************************
  *   Description:
  *       The low-level interface to set TxAGC , called by both MP and Normal Driver.
@@ -786,97 +740,88 @@ VOID
 PHY_SetTxPowerIndex_8188F(
 	IN	PADAPTER			Adapter,
 	IN	u32					PowerIndex,
-	IN	u8					RFPath,
+	IN	enum rf_path			RFPath,
 	IN	u8					Rate
 )
 {
-	if (RFPath == ODM_RF_PATH_A || RFPath == ODM_RF_PATH_B) {
+	if (RFPath == RF_PATH_A || RFPath == RF_PATH_B) {
 		switch (Rate) {
 		case MGN_1M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_CCK1_Mcs32,      bMaskByte1, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_CCK1_Mcs32,      bMaskByte1, PowerIndex);
 			break;
 		case MGN_2M:
-			PHY_SetBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte1, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte1, PowerIndex);
 			break;
 		case MGN_5_5M:
-			PHY_SetBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte2, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte2, PowerIndex);
 			break;
 		case MGN_11M:
-			PHY_SetBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte3, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte3, PowerIndex);
 			break;
 
 		case MGN_6M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate18_06, bMaskByte0, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate18_06, bMaskByte0, PowerIndex);
 			break;
 		case MGN_9M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate18_06, bMaskByte1, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate18_06, bMaskByte1, PowerIndex);
 			break;
 		case MGN_12M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate18_06, bMaskByte2, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate18_06, bMaskByte2, PowerIndex);
 			break;
 		case MGN_18M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate18_06, bMaskByte3, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate18_06, bMaskByte3, PowerIndex);
 			break;
 
 		case MGN_24M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate54_24, bMaskByte0, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate54_24, bMaskByte0, PowerIndex);
 			break;
 		case MGN_36M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate54_24, bMaskByte1, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate54_24, bMaskByte1, PowerIndex);
 			break;
 		case MGN_48M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate54_24, bMaskByte2, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate54_24, bMaskByte2, PowerIndex);
 			break;
 		case MGN_54M:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Rate54_24, bMaskByte3, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Rate54_24, bMaskByte3, PowerIndex);
 			break;
 
 		case MGN_MCS0:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte0, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte0, PowerIndex);
 			break;
 		case MGN_MCS1:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte1, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte1, PowerIndex);
 			break;
 		case MGN_MCS2:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte2, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte2, PowerIndex);
 			break;
 		case MGN_MCS3:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte3, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs03_Mcs00, bMaskByte3, PowerIndex);
 			break;
 
 		case MGN_MCS4:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte0, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte0, PowerIndex);
 			break;
 		case MGN_MCS5:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte1, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte1, PowerIndex);
 			break;
 		case MGN_MCS6:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte2, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte2, PowerIndex);
 			break;
 		case MGN_MCS7:
-			PHY_SetBBReg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte3, PowerIndex);
+			phy_set_bb_reg(Adapter, rTxAGC_A_Mcs07_Mcs04, bMaskByte3, PowerIndex);
 			break;
 
 		default:
-			DBG_871X("Invalid Rate!!\n");
+			RTW_INFO("Invalid Rate!!\n");
 			break;
 		}
-	} else
-		RT_TRACE(_module_hal_init_c_, _drv_err_, ("Invalid RFPath!!\n"));
-}
-
-u8
-phy_GetCurrentTxNum_8188F(
-	IN	PADAPTER		pAdapter
-)
-{
-	return RF_TX_NUM_NONIMPLEMENT;
+	}
 }
 
 u8
 PHY_GetTxPowerIndex_8188F(
 	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
+	IN	enum rf_path			RFPath,
 	IN	u8					Rate,
 	IN	u8					BandWidth,
 	IN	u8					Channel,
@@ -884,18 +829,20 @@ PHY_GetTxPowerIndex_8188F(
 )
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
-	u8 base_idx = 0, power_idx = 0;
+	s16 power_idx;
+	u8 base_idx = 0;
 	s8 by_rate_diff = 0, limit = 0, tpt_offset = 0, extra_bias = 0;
 	BOOLEAN bIn24G = _FALSE;
 
-	base_idx = PHY_GetTxPowerIndexBase(pAdapter, RFPath, Rate, BandWidth, Channel, &bIn24G);
+	base_idx = PHY_GetTxPowerIndexBase(pAdapter, RFPath, Rate, RF_1TX, BandWidth, Channel, &bIn24G);
 
-	by_rate_diff = PHY_GetTxPowerByRate(pAdapter, BAND_ON_2_4G, ODM_RF_PATH_A, RF_1TX, Rate);
-	limit = PHY_GetTxPowerLimit(pAdapter, pAdapter->registrypriv.RegPwrTblSel, (u8)(!bIn24G), pHalData->CurrentChannelBW, RFPath, Rate, pHalData->CurrentChannel);
+	by_rate_diff = PHY_GetTxPowerByRate(pAdapter, BAND_ON_2_4G, RF_PATH_A, Rate);
+	limit = PHY_GetTxPowerLimit(pAdapter, NULL, (u8)(!bIn24G), pHalData->current_channel_bw, RFPath, Rate, RF_1TX, pHalData->current_channel);
 
 	tpt_offset = PHY_GetTxPowerTrackingOffset(pAdapter, RFPath, Rate);
 
 	if (tic) {
+		tic->ntx_idx = RF_1TX;
 		tic->base = base_idx;
 		tic->by_rate = by_rate_diff;
 		tic->limit = limit;
@@ -906,7 +853,9 @@ PHY_GetTxPowerIndex_8188F(
 	by_rate_diff = by_rate_diff > limit ? limit : by_rate_diff;
 	power_idx = base_idx + by_rate_diff + tpt_offset + extra_bias;
 
-	if (power_idx > MAX_POWER_INDEX)
+	if (power_idx < 0)
+		power_idx = 0;
+	else if (power_idx > MAX_POWER_INDEX)
 		power_idx = MAX_POWER_INDEX;
 
 	return power_idx;
@@ -919,20 +868,21 @@ PHY_SetTxPowerLevel8188F(
 )
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
-	pFAT_T			pDM_FatTable = &pDM_Odm->DM_FatTable;
-	u8				RFPath = ODM_RF_PATH_A;
+	u8				cur_antenna;
+	enum rf_path		RFPath = RF_PATH_A;
+
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	rtw_hal_get_odm_var(Adapter, HAL_ODM_ANTDIV_SELECT, &cur_antenna, NULL);
 
 	if (pHalData->AntDivCfg)  /* antenna diversity Enable */
-		RFPath = ((pDM_FatTable->RxIdleAnt == MAIN_ANT) ? ODM_RF_PATH_A : ODM_RF_PATH_B);
+		RFPath = ((cur_antenna == MAIN_ANT) ? RF_PATH_A : RF_PATH_B);
 	else   /* antenna diversity disable */
+#endif
 		RFPath = pHalData->ant_path;
 
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("==>PHY_SetTxPowerLevel8188F()\n"));
 
-	PHY_SetTxPowerLevelByPath(Adapter, Channel, RFPath);
+	phy_set_tx_power_level_by_path(Adapter, Channel, RFPath);
 
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("<==PHY_SetTxPowerLevel8188F()\n"));
 }
 
 VOID
@@ -944,7 +894,6 @@ PHY_GetTxPowerLevel8188F(
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
 	s32				TxPwrDbm = 13;
 #if 0
-	RT_TRACE(COMP_TXAGC, DBG_LOUD, ("PHY_GetTxPowerLevel8188F(): TxPowerLevel: %#x\n", TxPwrDbm));
 
 	if (pMgntInfo->ClientConfigPwrInDbm != UNSPECIFIED_PWR_DBM)
 		*powerlevel = pMgntInfo->ClientConfigPwrInDbm;
@@ -972,13 +921,18 @@ phy_SpurCalibration_8188F(
 	/* add for notch */
 	u4Byte				wlan_channel, CurrentChannel, Is40MHz;
 	HAL_DATA_TYPE		*pHalData	= GET_HAL_DATA(pAdapter);
-	PDM_ODM_T		pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
+
+#ifdef CONFIG_AUTO_NOTCH_FILTER
+	odm_set_bb_reg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0x1F);
+	odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
+#endif
 
 	/* check threshold */
 	if (threshold <= 0x0)
 		threshold = 0x16;
 
-	/* DBG_8192C("===> phy_SpurCalibration_8188F: Channel = %d\n", ToChannel); */
+	/* RTW_INFO("===> phy_SpurCalibration_8188F: Channel = %d\n", ToChannel); */
 
 	if (ToChannel == 5)
 		idx = 0;
@@ -997,117 +951,133 @@ phy_SpurCalibration_8188F(
 	else
 		idx = 10;
 
-	reg948 = PHY_QueryBBReg(pAdapter, rS0S1_PathSwitch, bMaskDWord);
+	reg948 = phy_query_bb_reg(pAdapter, rS0S1_PathSwitch, bMaskDWord);
 	if ((reg948 & BIT6) == 0x0)
 		bSW_Ctrl = TRUE;
 	else
 		bHW_Ctrl = TRUE;
 
 	if (bHW_Ctrl)
-		bHW_Ctrl_S1 = (PHY_QueryBBReg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT5 | BIT4 | BIT3) == 0x1) ? TRUE : FALSE;
+		bHW_Ctrl_S1 = (phy_query_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT5 | BIT4 | BIT3) == 0x1) ? TRUE : FALSE;
 	else if (bSW_Ctrl)
 		bSW_Ctrl_S1 = ((reg948 & BIT9) == 0x0) ? TRUE : FALSE;
 
 	/* If wlan at S1 (both HW control & SW control) and current channel=5,6,7,8,13,14 */
 	if ((bHW_Ctrl_S1 || bSW_Ctrl_S1) && (idx <= 6)) {
-		initial_gain = (u1Byte)(ODM_GetBBReg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskByte0) & 0x7f);
-		PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, BIT24, 0); /* Disable CCK block */
-		ODM_Write_DIG(pDM_Odm, 0x30);
-		PHY_SetBBReg(pAdapter, rFPGA0_AnalogParameter4, bMaskDWord, 0xccf000c0);		/* disable 3-wire */
+		initial_gain = (u1Byte)(odm_get_bb_reg(pDM_Odm, rOFDM0_XAAGCCore1, bMaskByte0) & 0x7f);
+		phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, BIT24, 0); /* Disable CCK block */
+		odm_write_dig(pDM_Odm, 0x30);
+		phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, bMaskDWord, 0xccf000c0);		/* disable 3-wire */
 
-		PHY_SetBBReg(pAdapter, rFPGA0_PSDFunction, bMaskDWord, freq[idx]);				/* Setup PSD */
-		PHY_SetBBReg(pAdapter, rFPGA0_PSDFunction, bMaskDWord, 0x400000 | freq[idx]); /* Start PSD */
+		phy_set_bb_reg(pAdapter, rFPGA0_PSDFunction, bMaskDWord, freq[idx]);				/* Setup PSD */
+		phy_set_bb_reg(pAdapter, rFPGA0_PSDFunction, bMaskDWord, 0x400000 | freq[idx]); /* Start PSD */
 
 		rtw_msleep_os(30);
 
-		if (PHY_QueryBBReg(pAdapter, rFPGA0_PSDReport, bMaskDWord) >= threshold)
+		if (phy_query_bb_reg(pAdapter, rFPGA0_PSDReport, bMaskDWord) >= threshold)
 			b_doNotch = TRUE;
 
-		PHY_SetBBReg(pAdapter, rFPGA0_PSDFunction, bMaskDWord, freq[idx]); /* turn off PSD */
+		phy_set_bb_reg(pAdapter, rFPGA0_PSDFunction, bMaskDWord, freq[idx]); /* turn off PSD */
 
-		PHY_SetBBReg(pAdapter, rFPGA0_AnalogParameter4, bMaskDWord, 0xccc000c0);	/* enable 3-wire */
-		PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, BIT24, 1); /* Enable CCK block */
-		ODM_Write_DIG(pDM_Odm, initial_gain);
+		phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, bMaskDWord, 0xccc000c0);	/* enable 3-wire */
+		phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, BIT24, 1); /* Enable CCK block */
+		odm_write_dig(pDM_Odm, initial_gain);
 	}
 
 	/* --- Notch Filter --- Asked by Rock */
 	if (b_doNotch) {
-		CurrentChannel = ODM_GetRFReg(pDM_Odm, ODM_RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
+		CurrentChannel = odm_get_rf_reg(pDM_Odm, RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
 		wlan_channel   = CurrentChannel & 0x0f;							/*Get center frequency */
 
 		switch (wlan_channel) {											/*Set notch filter */
 		case 5:
 		case 13:
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0xB);
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
-			ODM_SetBBReg(pDM_Odm, 0xD40, bMaskDWord, 0x06000000);
-			ODM_SetBBReg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0xB);
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
+#endif
+			odm_set_bb_reg(pDM_Odm, 0xD40, bMaskDWord, 0x06000000);
+			odm_set_bb_reg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
 			break;
 		case 6:
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0x4);
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
-			ODM_SetBBReg(pDM_Odm, 0xD40, bMaskDWord, 0x00000600);
-			ODM_SetBBReg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0x4);
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
+#endif
+			odm_set_bb_reg(pDM_Odm, 0xD40, bMaskDWord, 0x00000600);
+			odm_set_bb_reg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
 			break;
 		case 7:
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0x3);
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
-			ODM_SetBBReg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD4C, bMaskDWord, 0x06000000);
-			ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0x3);
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
+#endif
+			odm_set_bb_reg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD4C, bMaskDWord, 0x06000000);
+			odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
 			break;
 		case 8:
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0xA);
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
-			ODM_SetBBReg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000380);
-			ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0xA);
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
+#endif
+			odm_set_bb_reg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000380);
+			odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
 			break;
 		case 11:
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT28|BIT27|BIT26|BIT25|BIT24, 0x19);
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x1);						//enable notch filter
-			ODM_SetBBReg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD44, bMaskDWord, 0x04000000);
-			ODM_SetBBReg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x1);                    	//enable CSI mask
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT28|BIT27|BIT26|BIT25|BIT24, 0x19);
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x1);						/*enable notch filter*/
+#endif
+			odm_set_bb_reg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD44, bMaskDWord, 0x04000000);
+			odm_set_bb_reg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD4C, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x1);                    /*enable CSI mask*/
 			break;
 		case 14:
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0x5);
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
-			ODM_SetBBReg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
-			ODM_SetBBReg(pDM_Odm, 0xD4C, bMaskDWord, 0x00180000);
-			ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT28 | BIT27 | BIT26 | BIT25 | BIT24, 0x5);
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x1);				/*enable notch filter */
+#endif
+			odm_set_bb_reg(pDM_Odm, 0xD40, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD44, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD48, bMaskDWord, 0x00000000);
+			odm_set_bb_reg(pDM_Odm, 0xD4C, bMaskDWord, 0x00180000);
+			odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x1);				/*enable CSI mask */
 			break;
 		default:
-			ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x0);				/*disable notch filter */
-			ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x0);				/*disable CSI mask	function */
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+			odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x0);				/*disable notch filter */
+#endif
+			odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x0);				/*disable CSI mask	function */
 			break;
 		} /*switch(wlan_channel) */
 		return;
 	}
 
-	ODM_SetBBReg(pDM_Odm, 0xC40, BIT9, 0x0);                     /*disable notch filter */
-	ODM_SetBBReg(pDM_Odm, 0xD2C, BIT28, 0x0);                    /*disable CSI mask */
+#ifndef CONFIG_AUTO_NOTCH_FILTER
+	odm_set_bb_reg(pDM_Odm, 0xC40, BIT9, 0x0);                     /*disable notch filter */
+#endif
+	odm_set_bb_reg(pDM_Odm, 0xD2C, BIT28, 0x0);                    /*disable CSI mask */
 
 }
 
 VOID
 phy_SetRegBW_8188F(
 	IN	PADAPTER		Adapter,
-	CHANNEL_WIDTH 	CurrentBW
+	enum channel_width	CurrentBW
 )
 {
 	u16	RegRfMod_BW, u2tmp = 0;
@@ -1129,7 +1099,7 @@ phy_SetRegBW_8188F(
 		break;
 
 	default:
-		DBG_871X("phy_PostSetBWMode8188F():	unknown Bandwidth: %#X\n", CurrentBW);
+		RTW_INFO("phy_PostSetBWMode8188F():	unknown Bandwidth: %#X\n", CurrentBW);
 		break;
 	}
 }
@@ -1142,15 +1112,12 @@ phy_GetSecondaryChnl_8188F(
 	u8	SCSettingOf40 = 0, SCSettingOf20 = 0;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
 
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("SCMapping: VHT Case: pHalData->CurrentChannelBW %d, pHalData->nCur80MhzPrimeSC %d, pHalData->nCur40MhzPrimeSC %d\n", pHalData->CurrentChannelBW,
-			 pHalData->nCur80MhzPrimeSC, pHalData->nCur40MhzPrimeSC));
-	if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_80) {
+	if (pHalData->current_channel_bw == CHANNEL_WIDTH_80) {
 		if (pHalData->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER)
 			SCSettingOf40 = VHT_DATA_SC_40_LOWER_OF_80MHZ;
 		else if (pHalData->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER)
 			SCSettingOf40 = VHT_DATA_SC_40_UPPER_OF_80MHZ;
-		else
-			RT_TRACE(_module_hal_init_c_, _drv_err_, ("SCMapping: Not Correct Primary40MHz Setting\n"));
+
 
 		if ((pHalData->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER) && (pHalData->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER))
 			SCSettingOf20 = VHT_DATA_SC_20_LOWEST_OF_80MHZ;
@@ -1160,21 +1127,17 @@ phy_GetSecondaryChnl_8188F(
 			SCSettingOf20 = VHT_DATA_SC_20_UPPER_OF_80MHZ;
 		else if ((pHalData->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER) && (pHalData->nCur80MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER))
 			SCSettingOf20 = VHT_DATA_SC_20_UPPERST_OF_80MHZ;
-		else
-			RT_TRACE(_module_hal_init_c_, _drv_err_, ("SCMapping: Not Correct Primary40MHz Setting\n"));
-	} else if (pHalData->CurrentChannelBW == CHANNEL_WIDTH_40) {
-		RT_TRACE(_module_hal_init_c_, _drv_info_, ("SCMapping: VHT Case: pHalData->CurrentChannelBW %d, pHalData->nCur40MhzPrimeSC %d\n", pHalData->CurrentChannelBW, pHalData->nCur40MhzPrimeSC));
+
+	} else if (pHalData->current_channel_bw == CHANNEL_WIDTH_40) {
 
 		if (pHalData->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_UPPER)
 			SCSettingOf20 = VHT_DATA_SC_20_UPPER_OF_80MHZ;
 		else if (pHalData->nCur40MhzPrimeSC == HAL_PRIME_CHNL_OFFSET_LOWER)
 			SCSettingOf20 = VHT_DATA_SC_20_LOWER_OF_80MHZ;
-		else
-			RT_TRACE(_module_hal_init_c_, _drv_err_, ("SCMapping: Not Correct Primary40MHz Setting\n"));
+
 	}
 
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("SCMapping: SC Value %x\n", ((SCSettingOf40 << 4) | SCSettingOf20)));
-	return ((SCSettingOf40 << 4) | SCSettingOf20);
+	return (SCSettingOf40 << 4) | SCSettingOf20;
 }
 
 VOID
@@ -1185,9 +1148,9 @@ phy_PostSetBwMode8188F(
 	u1Byte			SubChnlNum = 0;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
 
-	/* DBG_8192C("===>%s: CurrentChannelBW = %s Mhz\n", __func__, pHalData->CurrentChannelBW?"40":"20"); */
+	/* RTW_INFO("===>%s: current_channel_bw = %s Mhz\n", __func__, pHalData->current_channel_bw?"40":"20"); */
 
-	switch (pHalData->CurrentChannelBW) {
+	switch (pHalData->current_channel_bw) {
 	case CHANNEL_WIDTH_20:
 		/*
 		0x800[0]=1'b0
@@ -1200,15 +1163,15 @@ phy_PostSetBwMode8188F(
 		0x954[19]=1'b0
 		0x954[23:20]=3
 		*/
-		PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT0, 0x0);
-		PHY_SetBBReg(Adapter, rFPGA1_RFMOD, BIT0, 0x0);
-		PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT10 | BIT9 | BIT8, 0x7);			/* RXADC CLK */
-		PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT14 | BIT13 | BIT12, 0x5);		/* TXDAC CLK */
-		PHY_SetBBReg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT31 | BIT30, 0x0);		/* small BW */
-		PHY_SetBBReg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT29 | BIT28, 0x1);		/* adc buffer clk(TBD) */
-		PHY_SetBBReg(Adapter, rOFDM0_XARxAFE, BIT29 | BIT28, 0x1);				/* adc buffer clk(TBD) */
-		PHY_SetBBReg(Adapter, BBrx_DFIR, BIT19, 0x0);							/* OFDM RX DFIR */
-		PHY_SetBBReg(Adapter, BBrx_DFIR, BIT23 | BIT22 | BIT21 | BIT20, 0x3);	/* OFDM RX DFIR */
+		phy_set_bb_reg(Adapter, rFPGA0_RFMOD, BIT0, 0x0);
+		phy_set_bb_reg(Adapter, rFPGA1_RFMOD, BIT0, 0x0);
+		phy_set_bb_reg(Adapter, rFPGA0_RFMOD, BIT10 | BIT9 | BIT8, 0x7);			/* RXADC CLK */
+		phy_set_bb_reg(Adapter, rFPGA0_RFMOD, BIT14 | BIT13 | BIT12, 0x5);		/* TXDAC CLK */
+		phy_set_bb_reg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT31 | BIT30, 0x0);		/* small BW */
+		phy_set_bb_reg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT29 | BIT28, 0x1);		/* adc buffer clk(TBD) */
+		phy_set_bb_reg(Adapter, rOFDM0_XARxAFE, BIT29 | BIT28, 0x1);				/* adc buffer clk(TBD) */
+		phy_set_bb_reg(Adapter, BBrx_DFIR, BIT19, 0x0);							/* OFDM RX DFIR */
+		phy_set_bb_reg(Adapter, BBrx_DFIR, BIT23 | BIT22 | BIT21 | BIT20, 0x3);	/* OFDM RX DFIR */
 		break;
 
 	case CHANNEL_WIDTH_40:
@@ -1228,34 +1191,32 @@ phy_PostSetBwMode8188F(
 		0x483[3:0]=1/2
 		0x440[22:21]=2'b00
 		*/
-		PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT0, 0x1);
-		PHY_SetBBReg(Adapter, rFPGA1_RFMOD, BIT0, 0x1);
-		PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT10 | BIT9 | BIT8, 0x7);			/* RXADC CLK */
-		PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT14 | BIT13 | BIT12, 0x5);		/* TXDAC CLK */
-		PHY_SetBBReg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT31 | BIT30, 0x0);		/* small BW */
-		PHY_SetBBReg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT29 | BIT28, 0x1);		/* adc buffer clk(TBD) */
-		PHY_SetBBReg(Adapter, rOFDM0_XARxAFE, BIT29 | BIT28, 0x1);				/* adc buffer clk(TBD) */
-		PHY_SetBBReg(Adapter, BBrx_DFIR, BIT19, 0x0);							/* OFDM RX DFIR */
-		PHY_SetBBReg(Adapter, BBrx_DFIR, BIT23 | BIT22 | BIT21 | BIT20, 0x6);	/* OFDM RX DFIR */
-
-		PHY_SetBBReg(Adapter, rCCK0_System, BIT4, (pHalData->nCur40MhzPrimeSC >> 1)); /* primary channel (CCK RXSC) */
+		phy_set_bb_reg(Adapter, rFPGA0_RFMOD, BIT0, 0x1);
+		phy_set_bb_reg(Adapter, rFPGA1_RFMOD, BIT0, 0x1);
+		phy_set_bb_reg(Adapter, rFPGA0_RFMOD, BIT10 | BIT9 | BIT8, 0x7);			/* RXADC CLK */
+		phy_set_bb_reg(Adapter, rFPGA0_RFMOD, BIT14 | BIT13 | BIT12, 0x5);		/* TXDAC CLK */
+		phy_set_bb_reg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT31 | BIT30, 0x0);		/* small BW */
+		phy_set_bb_reg(Adapter, rOFDM0_TxPseudoNoiseWgt, BIT29 | BIT28, 0x1);		/* adc buffer clk(TBD) */
+		phy_set_bb_reg(Adapter, rOFDM0_XARxAFE, BIT29 | BIT28, 0x1);				/* adc buffer clk(TBD) */
+		phy_set_bb_reg(Adapter, BBrx_DFIR, BIT19, 0x0);							/* OFDM RX DFIR */
+		phy_set_bb_reg(Adapter, BBrx_DFIR, BIT23 | BIT22 | BIT21 | BIT20, 0x6);	/* OFDM RX DFIR */
+
+		phy_set_bb_reg(Adapter, rCCK0_System, BIT4, (pHalData->nCur40MhzPrimeSC >> 1)); /* primary channel (CCK RXSC) */
 
 		SubChnlNum = phy_GetSecondaryChnl_8188F(Adapter);
-		PHY_SetMacReg(Adapter, REG_DATA_SC_8188F, BIT3 | BIT2 | BIT1 | BIT0, SubChnlNum);	/* txsc_20 */
-		PHY_SetMacReg(Adapter, REG_RRSR_8188F, BIT22 | BIT21, 0x0);							/* RRSR_RSC */
+		phy_set_mac_reg(Adapter, REG_DATA_SC_8188F, BIT3 | BIT2 | BIT1 | BIT0, SubChnlNum);	/* txsc_20 */
+		phy_set_mac_reg(Adapter, REG_RRSR_8188F, BIT22 | BIT21, 0x0);							/* RRSR_RSC */
 
 		if (0)
-			DBG_871X("%s: REG_DATA_SC_8188F(%d) nCur40MhzPrimeSC(%d)\n", __func__, SubChnlNum, pHalData->nCur40MhzPrimeSC);
+			RTW_INFO("%s: REG_DATA_SC_8188F(%d) nCur40MhzPrimeSC(%d)\n", __func__, SubChnlNum, pHalData->nCur40MhzPrimeSC);
 		break;
 
 	default:
-		RT_TRACE(COMP_DBG, DBG_LOUD, ("phy_SetBWMode8188F(): unknown Bandwidth: %#X\n"\
-									  , pHalData->CurrentChannelBW));
 		break;
 	}
 
 	/*3<3>Set RF related register */
-	PHY_RF6052SetBandwidth8188F(Adapter, pHalData->CurrentChannelBW);
+	PHY_RF6052SetBandwidth8188F(Adapter, pHalData->current_channel_bw);
 }
 
 VOID
@@ -1264,23 +1225,22 @@ phy_SwChnl8188F(
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u8				channelToSW = pHalData->CurrentChannel;
+	u8				channelToSW = pHalData->current_channel;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PDM_ODM_T		pDM_Odm = &pHalData->DM_OutSrc;
+	struct dm_struct		*pDM_Odm = &pHalData->DM_OutSrc;
 #else  /* (DM_ODM_SUPPORT_TYPE == ODM_CE) */
-	PDM_ODM_T		pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 #endif
 
 	if (pHalData->rf_chip == RF_PSEUDO_11N) {
-		/*RT_TRACE(COMP_MLME,DBG_LOUD,("phy_SwChnl8188F: return for PSEUDO\n")); */
 		return;
 	}
 
 	pHalData->RfRegChnlVal[0] = ((pHalData->RfRegChnlVal[0] & 0xfffff00) | channelToSW);
-	PHY_SetRFReg(pAdapter, ODM_RF_PATH_A, RF_CHNLBW, 0x3FF, pHalData->RfRegChnlVal[0]);
-	/* PHY_SetRFReg(pAdapter, ODM_RF_PATH_B, RF_CHNLBW, 0x3FF, pHalData->RfRegChnlVal[0] ); */
+	phy_set_rf_reg(pAdapter, RF_PATH_A, RF_CHNLBW, 0x3FF, pHalData->RfRegChnlVal[0]);
+	/* phy_set_rf_reg(pAdapter, RF_PATH_B, RF_CHNLBW, 0x3FF, pHalData->RfRegChnlVal[0] ); */
 
-	/* DBG_8192C("===>phy_SwChnl8188F: Channel = %d\n", channelToSW); */
+	/* RTW_INFO("===>phy_SwChnl8188F: Channel = %d\n", channelToSW); */
 
 	phy_SpurCalibration_8188F(pAdapter, channelToSW, 0x16);
 }
@@ -1292,14 +1252,13 @@ phy_SwChnlAndSetBwMode8188F(
 {
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
 
-	/*RT_TRACE(COMP_SCAN, DBG_LOUD, ("phy_SwChnlAndSetBwMode8188F(): bSwChnl %d, bSetChnlBW %d\n", pHalData->bSwChnl, pHalData->bSetChnlBW)); */
 	if (Adapter->bNotifyChannelChange) {
-		DBG_871X("[%s] bSwChnl=%d, ch=%d, bSetChnlBW=%d, bw=%d\n",
-				 __func__,
-				 pHalData->bSwChnl,
-				 pHalData->CurrentChannel,
-				 pHalData->bSetChnlBW,
-				 pHalData->CurrentChannelBW);
+		RTW_INFO("[%s] bSwChnl=%d, ch=%d, bSetChnlBW=%d, bw=%d\n",
+			 __func__,
+			 pHalData->bSwChnl,
+			 pHalData->current_channel,
+			 pHalData->bSetChnlBW,
+			 pHalData->current_channel_bw);
 	}
 
 	if (RTW_CANNOT_RUN(Adapter))
@@ -1315,7 +1274,17 @@ phy_SwChnlAndSetBwMode8188F(
 		pHalData->bSetChnlBW = _FALSE;
 	}
 
-	PHY_SetTxPowerLevel8188F(Adapter, pHalData->CurrentChannel);
+	if (pHalData->bNeedIQK == _TRUE) {
+		if (pHalData->neediqk_24g == _TRUE) {
+
+			halrf_iqk_trigger(&pHalData->odmpriv, _FALSE);
+			pHalData->bIQKInitialized = _TRUE;
+			pHalData->neediqk_24g = _FALSE;
+		}
+		pHalData->bNeedIQK = _FALSE;
+	}
+
+	PHY_SetTxPowerLevel8188F(Adapter, pHalData->current_channel);
 }
 
 VOID
@@ -1324,7 +1293,7 @@ PHY_HandleSwChnlAndSetBW8188F(
 	IN	BOOLEAN				bSwitchChannel,
 	IN	BOOLEAN				bSetBandWidth,
 	IN	u8					ChannelNum,
-	IN	CHANNEL_WIDTH	ChnlWidth,
+	IN	enum channel_width	ChnlWidth,
 	IN	EXTCHNL_OFFSET	ExtChnlOffsetOf40MHz,
 	IN	EXTCHNL_OFFSET	ExtChnlOffsetOf80MHz,
 	IN	u8					CenterFrequencyIndex1
@@ -1332,25 +1301,25 @@ PHY_HandleSwChnlAndSetBW8188F(
 {
 	/*static BOOLEAN		bInitialzed = _FALSE; */
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(Adapter);
-	u8					tmpChannel = pHalData->CurrentChannel;
-	CHANNEL_WIDTH		tmpBW = pHalData->CurrentChannelBW;
+	u8					tmpChannel = pHalData->current_channel;
+	enum channel_width	tmpBW = pHalData->current_channel_bw;
 	u8					tmpnCur40MhzPrimeSC = pHalData->nCur40MhzPrimeSC;
 	u8					tmpnCur80MhzPrimeSC = pHalData->nCur80MhzPrimeSC;
 	u8					tmpCenterFrequencyIndex1 = pHalData->CurrentCenterFrequencyIndex1;
 	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
 
-	/* DBG_871X("=> PHY_HandleSwChnlAndSetBW8188F: bSwitchChannel %d, bSetBandWidth %d\n", bSwitchChannel, bSetBandWidth); */
-	/* DBG_871X("=> %s: ChnlWidth %d\n", __func__, ChnlWidth); */
+	/* RTW_INFO("=> PHY_HandleSwChnlAndSetBW8188F: bSwitchChannel %d, bSetBandWidth %d\n", bSwitchChannel, bSetBandWidth); */
+	/* RTW_INFO("=> %s: ChnlWidth %d\n", __func__, ChnlWidth); */
 
 	/*check is swchnl or setbw */
 	if (!bSwitchChannel && !bSetBandWidth) {
-		DBG_871X("PHY_HandleSwChnlAndSetBW8188F:  not switch channel and not set bandwidth\n");
+		RTW_INFO("PHY_HandleSwChnlAndSetBW8188F:  not switch channel and not set bandwidth\n");
 		return;
 	}
 
 	/*skip change for channel or bandwidth is the same */
 	if (bSwitchChannel) {
-		/*if(pHalData->CurrentChannel != ChannelNum) */
+		/*if(pHalData->current_channel != ChannelNum) */
 		{
 			if (HAL_IsLegalChannel(Adapter, ChannelNum))
 				pHalData->bSwChnl = _TRUE;
@@ -1362,7 +1331,7 @@ PHY_HandleSwChnlAndSetBW8188F(
 		if (bInitialzed == _FALSE) {
 			bInitialzed = _TRUE;
 			pHalData->bSetChnlBW = _TRUE;
-		} else if ((pHalData->CurrentChannelBW != ChnlWidth) || (pHalData->nCur40MhzPrimeSC != ExtChnlOffsetOf40MHz) || (pHalData->CurrentCenterFrequencyIndex1 != CenterFrequencyIndex1))
+		} else if ((pHalData->current_channel_bw != ChnlWidth) || (pHalData->nCur40MhzPrimeSC != ExtChnlOffsetOf40MHz) || (pHalData->CurrentCenterFrequencyIndex1 != CenterFrequencyIndex1))
 			pHalData->bSetChnlBW = _TRUE;
 #else
 		pHalData->bSetChnlBW = _TRUE;
@@ -1370,19 +1339,19 @@ PHY_HandleSwChnlAndSetBW8188F(
 	}
 
 	if (!pHalData->bSetChnlBW && !pHalData->bSwChnl) {
-		/* DBG_871X("<= PHY_HandleSwChnlAndSetBW8188F: bSwChnl %d, bSetChnlBW %d\n", pHalData->bSwChnl, pHalData->bSetChnlBW); */
+		/* RTW_INFO("<= PHY_HandleSwChnlAndSetBW8188F: bSwChnl %d, bSetChnlBW %d\n", pHalData->bSwChnl, pHalData->bSetChnlBW); */
 		return;
 	}
 
 
 	if (pHalData->bSwChnl) {
-		pHalData->CurrentChannel = ChannelNum;
+		pHalData->current_channel = ChannelNum;
 		pHalData->CurrentCenterFrequencyIndex1 = ChannelNum;
 	}
 
 
 	if (pHalData->bSetChnlBW) {
-		pHalData->CurrentChannelBW = ChnlWidth;
+		pHalData->current_channel_bw = ChnlWidth;
 #if 0
 		if (ExtChnlOffsetOf40MHz == EXTCHNL_OFFSET_LOWER)
 			pHalData->nCur40MhzPrimeSC = HAL_PRIME_CHNL_OFFSET_UPPER;
@@ -1410,22 +1379,22 @@ PHY_HandleSwChnlAndSetBW8188F(
 		phy_SwChnlAndSetBwMode8188F(Adapter);
 	else {
 		if (pHalData->bSwChnl) {
-			pHalData->CurrentChannel = tmpChannel;
+			pHalData->current_channel = tmpChannel;
 			pHalData->CurrentCenterFrequencyIndex1 = tmpChannel;
 		}
 		if (pHalData->bSetChnlBW) {
-			pHalData->CurrentChannelBW = tmpBW;
+			pHalData->current_channel_bw = tmpBW;
 			pHalData->nCur40MhzPrimeSC = tmpnCur40MhzPrimeSC;
 			pHalData->nCur80MhzPrimeSC = tmpnCur80MhzPrimeSC;
 			pHalData->CurrentCenterFrequencyIndex1 = tmpCenterFrequencyIndex1;
 		}
 	}
 
-	/*DBG_871X("Channel %d ChannelBW %d ",pHalData->CurrentChannel, pHalData->CurrentChannelBW); */
-	/*DBG_871X("40MhzPrimeSC %d 80MhzPrimeSC %d ",pHalData->nCur40MhzPrimeSC, pHalData->nCur80MhzPrimeSC); */
-	/*DBG_871X("CenterFrequencyIndex1 %d\n",pHalData->CurrentCenterFrequencyIndex1); */
+	/*RTW_INFO("Channel %d ChannelBW %d ",pHalData->current_channel, pHalData->current_channel_bw); */
+	/*RTW_INFO("40MhzPrimeSC %d 80MhzPrimeSC %d ",pHalData->nCur40MhzPrimeSC, pHalData->nCur80MhzPrimeSC); */
+	/*RTW_INFO("CenterFrequencyIndex1 %d\n",pHalData->CurrentCenterFrequencyIndex1); */
 
-	/*DBG_871X("<= PHY_HandleSwChnlAndSetBW8188F: bSwChnl %d, bSetChnlBW %d\n",pHalData->bSwChnl,pHalData->bSetChnlBW); */
+	/*RTW_INFO("<= PHY_HandleSwChnlAndSetBW8188F: bSwChnl %d, bSetChnlBW %d\n",pHalData->bSwChnl,pHalData->bSetChnlBW); */
 
 }
 
@@ -1433,16 +1402,16 @@ VOID
 PHY_SetSwChnlBWMode8188F(
 	IN	PADAPTER			Adapter,
 	IN	u8					channel,
-	IN	CHANNEL_WIDTH	Bandwidth,
+	IN	enum channel_width	Bandwidth,
 	IN	u8					Offset40,
 	IN	u8					Offset80
 )
 {
-	/*DBG_871X("%s()===>\n",__func__); */
+	/*RTW_INFO("%s()===>\n",__func__); */
 
 	PHY_HandleSwChnlAndSetBW8188F(Adapter, _TRUE, _TRUE, channel, Bandwidth, Offset40, Offset80, channel);
 
-	/*DBG_871X("<==%s()\n",__func__); */
+	/*RTW_INFO("<==%s()\n",__func__); */
 }
 
 static VOID
@@ -1450,13 +1419,10 @@ _PHY_DumpRFReg_8188F(IN	PADAPTER	pAdapter)
 {
 	u32 rfRegValue, rfRegOffset;
 
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("_PHY_DumpRFReg_8188F()====>\n"));
 
 	for (rfRegOffset = 0x00; rfRegOffset <= 0x30; rfRegOffset++) {
 		rfRegValue = PHY_QueryRFReg_8188F(pAdapter, RF_PATH_A, rfRegOffset, bMaskDWord);
-		RT_TRACE(_module_hal_init_c_, _drv_info_, (" 0x%02x = 0x%08x\n", rfRegOffset, rfRegValue));
 	}
-	RT_TRACE(_module_hal_init_c_, _drv_info_, ("<===== _PHY_DumpRFReg_8188F()\n"));
 }
 
 /* Set CCK and OFDM Block "ON" */
@@ -1466,7 +1432,7 @@ void BBTurnOnBlock_8188F(_adapter *adapter)
 	return;
 #endif
 
-	PHY_SetBBReg(adapter, rFPGA0_RFMOD, bCCKEn, 0x1);
-	PHY_SetBBReg(adapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
+	phy_set_bb_reg(adapter, rFPGA0_RFMOD, bCCKEn, 0x1);
+	phy_set_bb_reg(adapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
 }
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rf6052.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rf6052.c
index 60c3d440d31f..6ffa40590db2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rf6052.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rf6052.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 /******************************************************************************
  *
  *
@@ -34,7 +30,7 @@
  * Data			Who		Remark
  *
  * 09/25/2008	MHC		Create initial version.
- * 11/05/2008 	MHC		Add API for tw power setting.
+ * 11/05/2008	MHC		Add API for tw power setting.
  *
  *
 ******************************************************************************/
@@ -50,9 +46,11 @@
 
 
 /*------------------------Define local variable------------------------------*/
+#ifdef CONFIG_RF_SHADOW_RW
 /* 2008/11/20 MH For Debug only, RF */
 /*static	RF_SHADOW_T	RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG] = {0}; */
 static	RF_SHADOW_T	RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
+#endif /*CONFIG_RF_SHADOW_RW*/
 /*------------------------Define local variable------------------------------*/
 
 /*-----------------------------------------------------------------------------
@@ -72,7 +70,7 @@ static	RF_SHADOW_T	RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
 VOID
 PHY_RF6052SetBandwidth8188F(
 	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH		Bandwidth)	/*20M or 40M */
+	IN	enum channel_width		Bandwidth)	/*20M or 40M */
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
 
@@ -87,17 +85,17 @@ PHY_RF6052SetBandwidth8188F(
 		RF_A_reg 0x1b=0x01c6c (for USB)
 		*/
 		pHalData->RfRegChnlVal[0] = ((pHalData->RfRegChnlVal[0] & 0xfffff3ff) | BIT10 | BIT11);
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x18, bRFRegOffsetMask, pHalData->RfRegChnlVal[0]); /* RF TRX_BW */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x18, bRFRegOffsetMask, pHalData->RfRegChnlVal[0]); /* RF TRX_BW */
 
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x87, bRFRegOffsetMask, 0x00065); /* FILTER BW&RC Corner (ACPR) */
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1C, bRFRegOffsetMask, 0x00000); /* FILTER BW&RC Corner (ACPR) */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x87, bRFRegOffsetMask, 0x00065); /* FILTER BW&RC Corner (ACPR) */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x1C, bRFRegOffsetMask, 0x00000); /* FILTER BW&RC Corner (ACPR) */
 
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0xDF, bRFRegOffsetMask, 0x00140); /* RC Corner */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0xDF, bRFRegOffsetMask, 0x00140); /* RC Corner */
 #ifdef CONFIG_SDIO_HCI
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x00C6C); /* RC Corner */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x00C6C); /* RC Corner */
 #endif /* CONFIG_SDIO_HCI */
 #ifdef CONFIG_USB_HCI
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x01C6C); /* RC Corner */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x01C6C); /* RC Corner */
 #endif
 		break;
 
@@ -112,23 +110,22 @@ PHY_RF6052SetBandwidth8188F(
 		RF_A_reg 0x1b=0x01c6c (for USB)
 		*/
 		pHalData->RfRegChnlVal[0] = ((pHalData->RfRegChnlVal[0] & 0xfffff3ff) | BIT10);
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x18, bRFRegOffsetMask, pHalData->RfRegChnlVal[0]); /* RF TRX_BW */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x18, bRFRegOffsetMask, pHalData->RfRegChnlVal[0]); /* RF TRX_BW */
 
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x87, bRFRegOffsetMask, 0x00025); /* FILTER BW&RC Corner (ACPR) */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x87, bRFRegOffsetMask, 0x00025); /* FILTER BW&RC Corner (ACPR) */
 #ifdef CONFIG_SDIO_HCI
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1C, bRFRegOffsetMask, 0x00800); /* FILTER BW&RC Corner (ACPR) */
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0xDF, bRFRegOffsetMask, 0x00140); /* RC Corner */
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x00C6C); /* RC Corner */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x1C, bRFRegOffsetMask, 0x00800); /* FILTER BW&RC Corner (ACPR) */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0xDF, bRFRegOffsetMask, 0x00140); /* RC Corner */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x00C6C); /* RC Corner */
 #endif /* CONFIG_SDIO_HCI */
 #ifdef CONFIG_USB_HCI
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1C, bRFRegOffsetMask, 0x01000); /* FILTER BW&RC Corner (ACPR) */
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0xDF, bRFRegOffsetMask, 0x00140); /* RC Corner */
-		PHY_SetRFReg(Adapter, ODM_RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x01C6C); /* RC Corner */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x1C, bRFRegOffsetMask, 0x01000); /* FILTER BW&RC Corner (ACPR) */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0xDF, bRFRegOffsetMask, 0x00140); /* RC Corner */
+		phy_set_rf_reg(Adapter, RF_PATH_A, 0x1B, bRFRegOffsetMask, 0x01C6C); /* RC Corner */
 #endif
 		break;
 
 	default:
-		/*RT_TRACE(COMP_DBG, DBG_LOUD, ("PHY_SetRF8225Bandwidth(): unknown Bandwidth: %#X\n",Bandwidth )); */
 		break;
 	}
 
@@ -153,7 +150,7 @@ phy_RF6052_Config_ParaFile(
 )
 {
 	u32					u4RegValue = 0;
-	u8					eRFPath;
+	enum rf_path			eRFPath;
 	BB_REGISTER_DEFINITION_T	*pPhyReg;
 
 	int					rtStatus = _SUCCESS;
@@ -163,7 +160,7 @@ phy_RF6052_Config_ParaFile(
 	/*3// <2> Initialize RF */
 	/*3//----------------------------------------------------------------- */
 	/*for(eRFPath = RF_PATH_A; eRFPath <pHalData->NumTotalRFPath; eRFPath++) */
-	for (eRFPath = 0; eRFPath < pHalData->NumTotalRFPath; eRFPath++) {
+	for (eRFPath = RF_PATH_A; eRFPath < pHalData->NumTotalRFPath; eRFPath++) {
 
 		pPhyReg = &pHalData->PHYRegDef[eRFPath];
 
@@ -171,27 +168,30 @@ phy_RF6052_Config_ParaFile(
 		switch (eRFPath) {
 		case RF_PATH_A:
 		case RF_PATH_C:
-			u4RegValue = PHY_QueryBBReg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV);
+			u4RegValue = phy_query_bb_reg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV);
 			break;
-		case RF_PATH_B :
+		case RF_PATH_B:
 		case RF_PATH_D:
-			u4RegValue = PHY_QueryBBReg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV << 16);
+			u4RegValue = phy_query_bb_reg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV << 16);
+			break;
+		default:
+			RTW_ERR("Invalid rf_path:%d\n", eRFPath);
 			break;
 		}
 
 		/*----Set RF_ENV enable----*/
-		PHY_SetBBReg(Adapter, pPhyReg->rfintfe, bRFSI_RFENV << 16, 0x1);
+		phy_set_bb_reg(Adapter, pPhyReg->rfintfe, bRFSI_RFENV << 16, 0x1);
 		rtw_udelay_os(1);/*PlatformStallExecution(1); */
 
 		/*----Set RF_ENV output high----*/
-		PHY_SetBBReg(Adapter, pPhyReg->rfintfo, bRFSI_RFENV, 0x1);
+		phy_set_bb_reg(Adapter, pPhyReg->rfintfo, bRFSI_RFENV, 0x1);
 		rtw_udelay_os(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 */
+		phy_set_bb_reg(Adapter, pPhyReg->rfHSSIPara2, b3WireAddressLength, 0x0);	/* Set 1 to 4 bits for 8255 */
 		rtw_udelay_os(1);/*PlatformStallExecution(1); */
 
-		PHY_SetBBReg(Adapter, pPhyReg->rfHSSIPara2, b3WireDataLength, 0x0);	/* Set 0 to 12  bits for 8255 */
+		phy_set_bb_reg(Adapter, pPhyReg->rfHSSIPara2, b3WireDataLength, 0x0);	/* Set 0 to 12  bits for 8255 */
 		rtw_udelay_os(1);/*PlatformStallExecution(1); */
 
 		/*----Initialize RF fom connfiguration file----*/
@@ -202,7 +202,7 @@ phy_RF6052_Config_ParaFile(
 #endif
 			{
 #ifdef CONFIG_EMBEDDED_FWIMG
-				if (HAL_STATUS_FAILURE == ODM_ConfigRFWithHeaderFile(&pHalData->odmpriv, CONFIG_RF_RADIO, (ODM_RF_RADIO_PATH_E)eRFPath))
+				if (odm_config_rf_with_header_file(&pHalData->odmpriv, CONFIG_RF_RADIO, eRFPath) == HAL_STATUS_FAILURE)
 					rtStatus = _FAIL;
 #endif
 			}
@@ -213,7 +213,7 @@ phy_RF6052_Config_ParaFile(
 #endif
 			{
 #ifdef CONFIG_EMBEDDED_FWIMG
-				if (HAL_STATUS_FAILURE == ODM_ConfigRFWithHeaderFile(&pHalData->odmpriv, CONFIG_RF_RADIO, (ODM_RF_RADIO_PATH_E)eRFPath))
+				if (odm_config_rf_with_header_file(&pHalData->odmpriv, CONFIG_RF_RADIO, eRFPath) == HAL_STATUS_FAILURE)
 					rtStatus = _FAIL;
 #endif
 			}
@@ -222,22 +222,27 @@ phy_RF6052_Config_ParaFile(
 			break;
 		case RF_PATH_D:
 			break;
+		default:
+			RTW_ERR("Invalid rf_path:%d\n", eRFPath);
+			break;
 		}
 
 		/*----Restore RFENV control type----*/;
 		switch (eRFPath) {
 		case RF_PATH_A:
 		case RF_PATH_C:
-			PHY_SetBBReg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV, u4RegValue);
+			phy_set_bb_reg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV, u4RegValue);
 			break;
-		case RF_PATH_B :
+		case RF_PATH_B:
 		case RF_PATH_D:
-			PHY_SetBBReg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV << 16, u4RegValue);
+			phy_set_bb_reg(Adapter, pPhyReg->rfintfs, bRFSI_RFENV << 16, u4RegValue);
+			break;
+		default:
+			RTW_ERR("Invalid rf_path:%d\n", eRFPath);
 			break;
 		}
 
 		if (rtStatus != _SUCCESS) {
-			/*RT_TRACE(COMP_FPGA, DBG_LOUD, ("phy_RF6052_Config_ParaFile():Radio[%d] Fail!!", eRFPath)); */
 			goto phy_RF6052_Config_ParaFile_Fail;
 		}
 
@@ -252,11 +257,10 @@ phy_RF6052_Config_ParaFile(
 #endif
 	{
 #ifdef CONFIG_EMBEDDED_FWIMG
-		ODM_ConfigRFWithTxPwrTrackHeaderFile(&pHalData->odmpriv);
+		odm_config_rf_with_tx_pwr_track_header_file(&pHalData->odmpriv);
 #endif
 	}
 
-	/*RT_TRACE(COMP_INIT, DBG_LOUD, ("<---phy_RF6052_Config_ParaFile()\n")); */
 	return rtStatus;
 
 phy_RF6052_Config_ParaFile_Fail:
@@ -289,4 +293,3 @@ PHY_RF6052_Config8188F(
 }
 
 /* End of HalRf6052.c */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rxdesc.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rxdesc.c
index de910607eaf3..f780819ebf70 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rxdesc.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_rxdesc.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTL8188F_REDESC_C_
 
 #include <rtl8188f_hal.h>
@@ -66,4 +62,3 @@ void rtl8188f_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc)
 		/* pattrib->tsfl=(u8)GET_RX_STATUS_DESC_TSFL_8188F(pdesc); */
 	}
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_sreset.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_sreset.c
index e7f7e3bf745f..30274591dc78 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_sreset.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/rtl8188f_sreset.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTL8188F_SRESET_C_
 
 #include <rtl8188f_hal.h>
@@ -28,20 +24,20 @@ void rtl8188f_sreset_xmit_status_check(_adapter *padapter)
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
 
-	unsigned long current_time;
+	systime current_time;
 	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
 	unsigned int diff_time;
 	u32 txdma_status;
 
 	txdma_status = rtw_read32(padapter, REG_TXDMA_STATUS);
 	if (txdma_status != 0x00 && txdma_status != 0xeaeaeaea) {
-		DBG_871X("%s REG_TXDMA_STATUS:0x%08x\n", __func__, txdma_status);
+		RTW_INFO("%s REG_TXDMA_STATUS:0x%08x\n", __func__, txdma_status);
 		rtw_hal_sreset_reset(padapter);
 	}
 
 #ifdef CONFIG_USB_HCI
 	/*total xmit irp = 4 */
-	/*DBG_8192C("==>%s free_xmitbuf_cnt(%d),txirp_cnt(%d)\n",__func__,pxmitpriv->free_xmitbuf_cnt,pxmitpriv->txirp_cnt); */
+	/*RTW_INFO("==>%s free_xmitbuf_cnt(%d),txirp_cnt(%d)\n",__func__,pxmitpriv->free_xmitbuf_cnt,pxmitpriv->txirp_cnt); */
 	/*if(pxmitpriv->txirp_cnt == NR_XMITBUFF+1) */
 	current_time = rtw_get_current_time();
 
@@ -59,8 +55,8 @@ void rtl8188f_sreset_xmit_status_check(_adapter *padapter)
 
 					/*padapter->Wifi_Error_Status = WIFI_TX_HANG; */
 					ability = rtw_phydm_ability_get(padapter);
-					DBG_871X("%s tx hang %s\n", __func__,
-							 (ability & ODM_BB_ADAPTIVITY) ? "ODM_BB_ADAPTIVITY" : "");
+					RTW_INFO("%s tx hang %s\n", __func__,
+						(ability & ODM_BB_ADAPTIVITY) ? "ODM_BB_ADAPTIVITY" : "");
 
 					if (!(ability & ODM_BB_ADAPTIVITY))
 						rtw_hal_sreset_reset(padapter);
@@ -89,11 +85,11 @@ void rtl8188f_sreset_linked_status_check(_adapter *padapter)
 	reg824 = rtw_read32(padapter, 0x824);
 	reg800 = rtw_read32(padapter, 0x800);
 	if (((regc50 & 0xFFFFFF00) != 0x69543400) ||
-		((regc58 & 0xFFFFFF00) != 0x69543400) ||
-		(((reg824 & 0xFFFFFF00) != 0x00390000) && (((reg824 & 0xFFFFFF00) != 0x80390000))) ||
-		(((reg800 & 0xFFFFFF00) != 0x03040000) && ((reg800 & 0xFFFFFF00) != 0x83040000))) {
-		DBG_8192C("%s regc50:0x%08x, regc58:0x%08x, reg824:0x%08x, reg800:0x%08x,\n", __func__,
-				  regc50, regc58, reg824, reg800);
+	    ((regc58 & 0xFFFFFF00) != 0x69543400) ||
+	    (((reg824 & 0xFFFFFF00) != 0x00390000) && (((reg824 & 0xFFFFFF00) != 0x80390000))) ||
+	    (((reg800 & 0xFFFFFF00) != 0x03040000) && ((reg800 & 0xFFFFFF00) != 0x83040000))) {
+		RTW_INFO("%s regc50:0x%08x, regc58:0x%08x, reg824:0x%08x, reg800:0x%08x,\n", __func__,
+			 regc50, regc58, reg824, reg800);
 		rtw_hal_sreset_reset(padapter);
 	}
 #endif
@@ -106,4 +102,3 @@ void rtl8188f_sreset_linked_status_check(_adapter *padapter)
 }
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_led.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_led.c
index 1bf9f81e7470..ae60e2b5f753 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_led.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_led.c
@@ -1,127 +1,124 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#define _RTL8188FS_LED_C_
-
-#include "rtl8188f_hal.h"
-
-//================================================================================
-// LED object.
-//================================================================================
-
-
-//================================================================================
-//	Prototype of protected function.
-//================================================================================
-
-//================================================================================
-// LED_819xUsb routines.
-//================================================================================
-
-//
-//	Description:
-//		Turn on LED according to LedPin specified.
-//
-void
-SwLedOn_8188FS(
-	_adapter			*padapter,
-	PLED_SDIO		pLed
-)
-{
-	u8	LedCfg;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-
-	if (RTW_CANNOT_RUN(padapter))
-		return;
-
-	pLed->bLedOn = _TRUE;
-
-}
-
-
-//
-//	Description:
-//		Turn off LED according to LedPin specified.
-//
-void
-SwLedOff_8188FS(
-	_adapter			*padapter,
-	PLED_SDIO		pLed
-)
-{
-	u8	LedCfg;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-
-	if (RTW_CANNOT_RUN(padapter))
-		goto exit;
-
-exit:
-	pLed->bLedOn = _FALSE;
-
-}
-
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
-
-//================================================================================
-// Default LED behavior.
-//================================================================================
-
-//
-//	Description:
-//		Initialize all LED_871x objects.
-//
-void
-rtl8188fs_InitSwLeds(
-	_adapter	*padapter
-	)
-{
-#if 0
-	struct led_priv *pledpriv = &(padapter->ledpriv);
-
-	pledpriv->LedControlHandler = LedControlSDIO;
-
-	pledpriv->SwLedOn = SwLedOn_8188FS;
-	pledpriv->SwLedOff = SwLedOff_8188FS;
-	
-	InitLed871x(padapter, &(pledpriv->SwLed0), LED_PIN_LED0);
-
-	InitLed871x(padapter,&(pledpriv->SwLed1), LED_PIN_LED1);
-#endif
-}
-
-
-//
-//	Description:
-//		DeInitialize all LED_819xUsb objects.
-//
-void
-rtl8188fs_DeInitSwLeds(
-	_adapter	*padapter
-	)
-{
-#if 0
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
-
-	DeInitLed871x( &(ledpriv->SwLed0) );
-	DeInitLed871x( &(ledpriv->SwLed1) );
-#endif
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8188FS_LED_C_
+
+#include "rtl8188f_hal.h"
+#ifdef CONFIG_RTW_SW_LED
+
+/* ********************************************************************************
+ * LED object.
+ * ******************************************************************************** */
+
+
+/* ********************************************************************************
+ *	Prototype of protected function.
+ * ******************************************************************************** */
+
+/* ********************************************************************************
+ * LED_819xUsb routines.
+ * ******************************************************************************** */
+
+/*
+ *	Description:
+ *		Turn on LED according to LedPin specified.
+ *   */
+void
+SwLedOn_8188FS(
+	_adapter			*padapter,
+	PLED_SDIO		pLed
+)
+{
+	u8	LedCfg;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	if (RTW_CANNOT_RUN(padapter))
+		return;
+
+	pLed->bLedOn = _TRUE;
+
+}
+
+
+/*
+ *	Description:
+ *		Turn off LED according to LedPin specified.
+ *   */
+void
+SwLedOff_8188FS(
+	_adapter			*padapter,
+	PLED_SDIO		pLed
+)
+{
+	u8	LedCfg;
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	if (RTW_CANNOT_RUN(padapter))
+		goto exit;
+
+exit:
+	pLed->bLedOn = _FALSE;
+
+}
+
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+
+/* ********************************************************************************
+ * Default LED behavior.
+ * ******************************************************************************** */
+
+/*
+ *	Description:
+ *		Initialize all LED_871x objects.
+ *   */
+void
+rtl8188fs_InitSwLeds(
+	_adapter	*padapter
+)
+{
+#if 0
+	struct led_priv *pledpriv = adapter_to_led(padapter);
+
+	pledpriv->LedControlHandler = LedControlSDIO;
+
+	pledpriv->SwLedOn = SwLedOn_8188FS;
+	pledpriv->SwLedOff = SwLedOff_8188FS;
+
+	InitLed871x(padapter, &(pledpriv->SwLed0), LED_PIN_LED0);
+
+	InitLed871x(padapter, &(pledpriv->SwLed1), LED_PIN_LED1);
+#endif
+}
+
+
+/*
+ *	Description:
+ *		DeInitialize all LED_819xUsb objects.
+ *   */
+void
+rtl8188fs_DeInitSwLeds(
+	_adapter	*padapter
+)
+{
+#if 0
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
+
+	DeInitLed871x(&(ledpriv->SwLed0));
+	DeInitLed871x(&(ledpriv->SwLed1));
+#endif
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_recv.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_recv.c
index c94ba542743f..142601f28aaf 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_recv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_recv.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTL8188FS_RECV_C_
 
 #include <rtl8188f_hal.h>
@@ -31,114 +27,11 @@ static s32 initrecvbuf(struct recv_buf *precvbuf, PADAPTER padapter)
 
 	return _SUCCESS;
 }
-
 static void freerecvbuf(struct recv_buf *precvbuf)
 {
 	_rtw_spinlock_free(&precvbuf->recvbuf_lock);
 }
 
-static s32 pre_recv_entry(union recv_frame *precvframe, struct recv_buf	*precvbuf, u8 *pphy_status)
-{
-	s32 ret=_SUCCESS;
-#ifdef CONFIG_CONCURRENT_MODE
-	u8 *secondary_myid, *paddr1;
-	union recv_frame	*precvframe_if2 = NULL;
-	_adapter *primary_padapter = precvframe->u.hdr.adapter;
-	_adapter *secondary_padapter = primary_padapter->pbuddy_adapter;
-	struct recv_priv *precvpriv = &primary_padapter->recvpriv;
-	_queue *pfree_recv_queue = &precvpriv->free_recv_queue;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(primary_padapter);
-
-	if(!secondary_padapter)
-		return ret;
-
-	paddr1 = GetAddr1Ptr(precvframe->u.hdr.rx_data);
-
-	if(IS_MCAST(paddr1) == _FALSE)//unicast packets
-	{
-		secondary_myid = adapter_mac_addr(secondary_padapter);
-
-		if(_rtw_memcmp(paddr1, secondary_myid, ETH_ALEN))
-		{
-			//change to secondary interface
-			precvframe->u.hdr.adapter = secondary_padapter;
-		}
-
-		//ret = recv_entry(precvframe);
-
-	}
-	else // Handle BC/MC Packets
-	{
-		//clone/copy to if2
-		_pkt	 *pkt_copy = NULL;
-		struct rx_pkt_attrib *pattrib = NULL;
-
-		precvframe_if2 = rtw_alloc_recvframe(pfree_recv_queue);
-
-		if(!precvframe_if2)
-			return _FAIL;
-
-		precvframe_if2->u.hdr.adapter = secondary_padapter;
-		_rtw_memcpy(&precvframe_if2->u.hdr.attrib, &precvframe->u.hdr.attrib, sizeof(struct rx_pkt_attrib));
-		pattrib = &precvframe_if2->u.hdr.attrib;
-
-		//driver need to set skb len for skb_copy().
-		//If skb->len is zero, skb_copy() will not copy data from original skb.
-		skb_put(precvframe->u.hdr.pkt, pattrib->pkt_len);
-
-		pkt_copy = rtw_skb_copy( precvframe->u.hdr.pkt);
-		if (pkt_copy == NULL)
-		{
-			if((pattrib->mfrag == 1)&&(pattrib->frag_num == 0))
-			{
-				DBG_8192C("pre_recv_entry(): rtw_skb_copy fail , drop frag frame \n");
-				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
-				return ret;
-			}
-
-			pkt_copy = rtw_skb_clone( precvframe->u.hdr.pkt);
-			if(pkt_copy == NULL)
-			{
-				DBG_8192C("pre_recv_entry(): rtw_skb_clone fail , drop frame\n");
-				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
-				return ret;
-			}
-		}
-
-		pkt_copy->dev = secondary_padapter->pnetdev;
-
-		precvframe_if2->u.hdr.pkt = pkt_copy;
-		precvframe_if2->u.hdr.rx_head = pkt_copy->head;
-		precvframe_if2->u.hdr.rx_data = pkt_copy->data;
-		precvframe_if2->u.hdr.rx_tail = skb_tail_pointer(pkt_copy);
-		precvframe_if2->u.hdr.rx_end = skb_end_pointer(pkt_copy);
-		precvframe_if2->u.hdr.len = pkt_copy->len;
-
-		//recvframe_put(precvframe_if2, pattrib->pkt_len);
-
-		if ( pHalData->ReceiveConfig & RCR_APPFCS)
-			recvframe_pull_tail(precvframe_if2, IEEE80211_FCS_LEN);
-
-		if (pattrib->physt)
-			rx_query_phy_status(precvframe_if2, pphy_status);
-
-		if(rtw_recv_entry(precvframe_if2) != _SUCCESS)
-		{
-			RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,
-				("recvbuf2recvframe: rtw_recv_entry(precvframe) != _SUCCESS\n"));
-		}
-	}
-
-	if (precvframe->u.hdr.attrib.physt)
-		rx_query_phy_status(precvframe, pphy_status);
-
-	ret = rtw_recv_entry(precvframe);
-#endif
-
-	return ret;
-
-}
-
 #ifdef CONFIG_SDIO_RX_COPY
 s32 rtl8188fs_recv_hdl(_adapter *padapter)
 {
@@ -149,39 +42,53 @@ s32 rtl8188fs_recv_hdl(_adapter *padapter)
 	struct recv_frame_hdr	*phdr;
 	struct rx_pkt_attrib	*pattrib;
 	u8	*ptr;
-	u32 pkt_len, pkt_offset, skb_len, alloc_sz;
-	_pkt *pkt_copy = NULL;
-	u8 shift_sz = 0, rx_report_sz = 0;
+	u32 pkt_len, pkt_offset;
+	u8	rx_report_sz = 0;
+	s32 ret = _SUCCESS;
 
 	pHalData = GET_HAL_DATA(padapter);
 	precvpriv = &padapter->recvpriv;
 
+	rx_bh_tk_set_stage(precvpriv, RX_BH_STG_HDL_ENTER);
+
 	do {
 		precvbuf = rtw_dequeue_recvbuf(&precvpriv->recv_buf_pending_queue);
-		if (NULL == precvbuf)
+		if (precvbuf == NULL) {
+			rx_bh_tk_set_buf(precvpriv, NULL, NULL, 0);
 			break;
+		}
+
+		rx_bh_tk_set_stage(precvpriv, RX_BH_STG_NEW_BUF);
+		rx_bh_tk_set_buf(precvpriv, precvbuf, precvbuf->pdata, precvbuf->ptail - precvbuf->pdata);
 
 		ptr = precvbuf->pdata;
 
 		while (ptr < precvbuf->ptail) {
+			rx_bh_tk_set_buf_pos(precvpriv, ptr);
+
 			precvframe = rtw_alloc_recvframe(&precvpriv->free_recv_queue);
 			if (precvframe == NULL) {
 				RTW_INFO("%s: no enough recv frame!\n", __FUNCTION__);
 				rtw_enqueue_recvbuf_to_head(precvbuf, &precvpriv->recv_buf_pending_queue);
-				return RTW_RFRAME_UNAVAIL;
+				ret = RTW_RFRAME_UNAVAIL;
+				goto exit;
 			}
 
+			rx_bh_tk_set_stage(precvpriv, RX_BH_STG_NEW_FRAME);
+			rx_bh_tk_set_frame(precvpriv, precvframe);
+
 			/* rx desc parsing */
 			rtl8188f_query_rx_desc_status(precvframe, ptr);
 
 			pattrib = &precvframe->u.hdr.attrib;
 
 			/* fix Hardware RX data error, drop whole recv_buffer */
-			if ((!(pHalData->ReceiveConfig & RCR_ACRC32)) && pattrib->crc_err) {
+			if (!rtw_hal_rcr_check(padapter, RCR_ACRC32) && pattrib->crc_err) {
 #if !(MP_DRIVER == 1)
 				RTW_INFO("%s()-%d: RX Warning! rx CRC ERROR !!\n", __FUNCTION__, __LINE__);
 #endif
 				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
+				rx_bh_tk_set_frame(precvpriv, NULL);
 				break;
 			}
 
@@ -191,6 +98,7 @@ s32 rtl8188fs_recv_hdl(_adapter *padapter)
 			if ((ptr + pkt_offset) > precvbuf->ptail) {
 				RTW_INFO("%s()-%d: : next pkt len(%p,%d) exceed ptail(%p)!\n", __FUNCTION__, __LINE__, ptr, pkt_offset, precvbuf->ptail);
 				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
+				rx_bh_tk_set_frame(precvpriv, NULL);
 				break;
 			}
 
@@ -207,130 +115,62 @@ s32 rtl8188fs_recv_hdl(_adapter *padapter)
 					RTW_INFO("%s: crc_err=%d icv_err=%d, skip!\n", __FUNCTION__, pattrib->crc_err, pattrib->icv_err);
 				}
 				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
+				rx_bh_tk_set_frame(precvpriv, NULL);
 			} else {
-				//	Modified by Albert 20101213
-				//	For 8 bytes IP header alignment.
-				if (pattrib->qos)	//	Qos data, wireless lan header length is 26
-				{
-					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 = rtw_skb_alloc(alloc_sz);
-
-				if (pkt_copy)
-				{
-					pkt_copy->dev = padapter->pnetdev;
-					precvframe->u.hdr.pkt = pkt_copy;
-					skb_reserve( pkt_copy, 8 - ((SIZE_PTR)( pkt_copy->data ) & 7 ));//force pkt_copy->data at 8-byte alignment address
-					skb_reserve( pkt_copy, shift_sz );//force ip_hdr at 8-byte alignment address according to shift_sz.
-					_rtw_memcpy(pkt_copy->data, (ptr + rx_report_sz + pattrib->shift_sz), skb_len);
-					precvframe->u.hdr.rx_head = pkt_copy->head;
-					precvframe->u.hdr.rx_data = precvframe->u.hdr.rx_tail = pkt_copy->data;
-					precvframe->u.hdr.rx_end = skb_end_pointer(pkt_copy);
-				}
-				else
-				{
-					if((pattrib->mfrag == 1)&&(pattrib->frag_num == 0))
-					{
-						DBG_8192C("%s: alloc_skb fail, drop frag frame\n", __FUNCTION__);
-						rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
-						break;
-					}
-
-					precvframe->u.hdr.pkt = rtw_skb_clone(precvbuf->pskb);
-					if(precvframe->u.hdr.pkt)
-					{
-						_pkt	*pkt_clone = precvframe->u.hdr.pkt;
+#ifdef CONFIG_RX_PACKET_APPEND_FCS
+				if (check_fwstate(&padapter->mlmepriv, WIFI_MONITOR_STATE) == _FALSE)
+					if ((pattrib->pkt_rpt_type == NORMAL_RX) && rtw_hal_rcr_check(padapter, RCR_APPFCS))
+						pattrib->pkt_len -= IEEE80211_FCS_LEN;
+#endif
 
-						pkt_clone->data = ptr + rx_report_sz + pattrib->shift_sz;
-						skb_reset_tail_pointer(pkt_clone);
-						precvframe->u.hdr.rx_head = precvframe->u.hdr.rx_data = precvframe->u.hdr.rx_tail
-							= pkt_clone->data;
-						precvframe->u.hdr.rx_end =	pkt_clone->data + skb_len;
-					}
-					else
-					{
-						DBG_8192C("%s: rtw_skb_clone fail\n", __FUNCTION__);
-						rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
-						break;
-					}
+				if (rtw_os_alloc_recvframe(padapter, precvframe,
+					(ptr + rx_report_sz + pattrib->shift_sz), precvbuf->pskb) == _FAIL) {
+					rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
+					rx_bh_tk_set_frame(precvpriv, NULL);
+					break;
 				}
-
-				recvframe_put(precvframe, skb_len);
+				recvframe_put(precvframe, pattrib->pkt_len);
 				/*recvframe_pull(precvframe, drvinfo_sz + RXDESC_SIZE); */
 
-				if (pHalData->ReceiveConfig & RCR_APPFCS)
-					recvframe_pull_tail(precvframe, IEEE80211_FCS_LEN);
-
 				/* move to drv info position */
 				ptr += RXDESC_SIZE;
 
 				/* update drv info */
-				if (pHalData->ReceiveConfig & RCR_APP_BA_SSN) {
+				if (rtw_hal_rcr_check(padapter, RCR_APP_BA_SSN)) {
 					/* rtl8188s_update_bassn(padapter, pdrvinfo); */
 					ptr += 4;
 				}
 
 				if (pattrib->pkt_rpt_type == NORMAL_RX) {
+					rx_bh_tk_set_stage(precvpriv, RX_BH_STG_NORMAL_RX);
+
 					/* skip the rx packet with abnormal length */
 					if (pattrib->pkt_len < 14 || pattrib->pkt_len > 8192) {
 						RTW_INFO("skip abnormal rx packet(%d)\n", pattrib->pkt_len);
 						rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
+						rx_bh_tk_set_stage(precvpriv, RX_BH_STG_NORMAL_RX_END);
+						rx_bh_tk_set_frame(precvpriv, NULL);
 						break;
 					}
 
-#ifdef CONFIG_CONCURRENT_MODE
-					if (rtw_buddy_adapter_up(padapter))
-					{
-						if (pre_recv_entry(precvframe, precvbuf, ptr) != _SUCCESS) {
-							RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,
-								("recvbuf2recvframe: recv_entry(precvframe) != _SUCCESS\n"));
-						}
-					}
-					else
-#endif
-					{
-						if (pattrib->physt)
-							rx_query_phy_status(precvframe, ptr);
+					pre_recv_entry(precvframe, pattrib->physt ? ptr : NULL);
 
-						if (rtw_recv_entry(precvframe) != _SUCCESS) {
-							RT_TRACE(_module_rtl871x_recv_c_, _drv_dump_, ("%s: rtw_recv_entry(precvframe) != _SUCCESS\n",__FUNCTION__));
-						}
-					}
-				}
-				else {
-#ifdef CONFIG_C2H_PACKET_EN
+					rx_bh_tk_set_stage(precvpriv, RX_BH_STG_NORMAL_RX_END);
+					rx_bh_tk_set_frame(precvpriv, NULL);
+
+				} else {
+#ifdef CONFIG_FW_C2H_PKT
 					if (pattrib->pkt_rpt_type == C2H_PACKET) {
-						rtl8188f_c2h_packet_handler(padapter, precvframe->u.hdr.rx_data, pattrib->pkt_len);
-					}
-					else {
+						rx_bh_tk_set_stage(precvpriv, RX_BH_STG_C2H);
+						rtw_hal_c2h_pkt_pre_hdl(padapter, precvframe->u.hdr.rx_data, pattrib->pkt_len);
+						rx_bh_tk_set_stage(precvpriv, RX_BH_STG_C2H_END);
+					} else {
 						RTW_INFO("%s: [WARNNING] RX type(%d) not be handled!\n",
 							__FUNCTION__, pattrib->pkt_rpt_type);
 					}
 #endif
 					rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
+					rx_bh_tk_set_frame(precvpriv, NULL);
 				}
 			}
 
@@ -338,13 +178,14 @@ s32 rtl8188fs_recv_hdl(_adapter *padapter)
 			precvbuf->pdata += pkt_offset;
 			ptr = precvbuf->pdata;
 			precvframe = NULL;
-			pkt_copy = NULL;
 		}
 
 		rtw_enqueue_recvbuf(precvbuf, &precvpriv->free_recv_buf_queue);
 	} while (1);
 
-	return _SUCCESS;
+exit:
+	rx_bh_tk_set_stage(precvpriv, RX_BH_STG_HDL_EXIT);
+	return ret;
 }
 
 static void rtl8188fs_recv_tasklet(void *priv)
@@ -368,14 +209,13 @@ static void rtl8188fs_recv_tasklet(void *priv)
 	PADAPTER				padapter;
 	PHAL_DATA_TYPE			pHalData;
 	struct recv_priv		*precvpriv;
-	struct recv_buf 		*precvbuf;
+	struct recv_buf		*precvbuf;
 	union recv_frame		*precvframe;
 	struct recv_frame_hdr	*phdr;
 	struct rx_pkt_attrib	*pattrib;
-	u8			*ptr;
+	u8		*ptr;
 	_pkt		*ppkt;
-	u32 		pkt_offset;
-	_irqL		irql;
+	u32		pkt_offset;
 
 
 	padapter = (PADAPTER)priv;
@@ -384,19 +224,18 @@ static void rtl8188fs_recv_tasklet(void *priv)
 
 	do {
 		precvbuf = rtw_dequeue_recvbuf(&precvpriv->recv_buf_pending_queue);
-		if (NULL == precvbuf) break;
+		if (NULL == precvbuf)
+			break;
 
 		ptr = precvbuf->pdata;
 
-		while (ptr < precvbuf->ptail)
-		{
+		while (ptr < precvbuf->ptail) {
 			precvframe = rtw_alloc_recvframe(&precvpriv->free_recv_queue);
 			if (precvframe == NULL) {
-				RT_TRACE(_module_rtl871x_recv_c_, _drv_err_, ("rtl8188fs_recv_tasklet: no enough recv frame!\n"));
 				rtw_enqueue_recvbuf_to_head(precvbuf, &precvpriv->recv_buf_pending_queue);
 
-				// The case of can't allocte recvframe should be temporary,
-				// schedule again and hope recvframe is available next time.
+				/* The case of can't allocte recvframe should be temporary, */
+				/* schedule again and hope recvframe is available next time. */
 #ifdef PLATFORM_LINUX
 				tasklet_schedule(&precvpriv->recv_tasklet);
 #endif
@@ -413,75 +252,66 @@ static void rtl8188fs_recv_tasklet(void *priv)
 				int i, len = 64;
 				u8 *pptr = ptr;
 
-				if((*(pptr + RXDESC_SIZE + pattrib->drvinfo_sz) != 0x80) && (*(pptr + RXDESC_SIZE + pattrib->drvinfo_sz) != 0x40))
-				{
-					DBG_871X("##############RxDESC############### \n");
-					for(i=0; i<32;i=i+16)
-						DBG_871X("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(pptr+i),
-						*(pptr+i+1), *(pptr+i+2) ,*(pptr+i+3) ,*(pptr+i+4),*(pptr+i+5), *(pptr+i+6), *(pptr+i+7), *(pptr+i+8), *(pptr+i+9), *(pptr+i+10),
-						 *(pptr+i+11), *(pptr+i+12), *(pptr+i+13), *(pptr+i+14), *(pptr+i+15));
-					
-					if(pattrib->pkt_len < 100)
+				if ((*(pptr + RXDESC_SIZE + pattrib->drvinfo_sz) != 0x80) && (*(pptr + RXDESC_SIZE + pattrib->drvinfo_sz) != 0x40)) {
+					RTW_INFO("##############RxDESC###############\n");
+					for (i = 0; i < 32; i = i + 16)
+						RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(pptr + i),
+							*(pptr + i + 1), *(pptr + i + 2) , *(pptr + i + 3) , *(pptr + i + 4), *(pptr + i + 5), *(pptr + i + 6), *(pptr + i + 7), *(pptr + i + 8),
+							*(pptr + i + 9), *(pptr + i + 10),
+							*(pptr + i + 11), *(pptr + i + 12), *(pptr + i + 13), *(pptr + i + 14), *(pptr + i + 15));
+
+					if (pattrib->pkt_len < 100)
 						len = pattrib->pkt_len;
 					pptr = ptr + RXDESC_SIZE + pattrib->drvinfo_sz;
-					DBG_871X("##############Len=%d############### \n", pattrib->pkt_len);
-					for(i=0; i<len;i=i+16)
-						DBG_871X("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(pptr+i),
-						*(pptr+i+1), *(pptr+i+2) ,*(pptr+i+3) ,*(pptr+i+4),*(pptr+i+5), *(pptr+i+6), *(pptr+i+7), *(pptr+i+8), *(pptr+i+9), *(pptr+i+10),
-						 *(pptr+i+11), *(pptr+i+12), *(pptr+i+13), *(pptr+i+14), *(pptr+i+15));
-					DBG_871X("############################# \n");
+					RTW_INFO("##############Len=%d###############\n", pattrib->pkt_len);
+					for (i = 0; i < len; i = i + 16)
+						RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(pptr + i),
+							*(pptr + i + 1), *(pptr + i + 2) , *(pptr + i + 3) , *(pptr + i + 4), *(pptr + i + 5), *(pptr + i + 6), *(pptr + i + 7), *(pptr + i + 8),
+							*(pptr + i + 9), *(pptr + i + 10),
+							*(pptr + i + 11), *(pptr + i + 12), *(pptr + i + 13), *(pptr + i + 14), *(pptr + i + 15));
+					RTW_INFO("#############################\n");
 				}
 			}
 #endif
 
-			// fix Hardware RX data error, drop whole recv_buffer
-			if ((!(pHalData->ReceiveConfig & RCR_ACRC32)) && pattrib->crc_err)
-			{
-				DBG_8192C("%s()-%d: RX Warning! rx CRC ERROR !!\n", __FUNCTION__, __LINE__);
+			/* fix Hardware RX data error, drop whole recv_buffer */
+			if (!rtw_hal_rcr_check(padapter, RCR_ACRC32) && pattrib->crc_err) {
+				RTW_INFO("%s()-%d: RX Warning! rx CRC ERROR !!\n", __FUNCTION__, __LINE__);
 				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
 				break;
 			}
 
 			pkt_offset = RXDESC_SIZE + pattrib->drvinfo_sz + pattrib->pkt_len;
-#if 0 // reduce check to speed up
+#if 0 /* reduce check to speed up */
 			if ((ptr + pkt_offset) > precvbuf->ptail) {
-				RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-						("%s: next pkt len(%p,%d) exceed ptail(%p)!\n",
-						__FUNCTION__, ptr, pkt_offset, precvbuf->ptail));
 				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
 				break;
 			}
 #endif
 
-			if ((pattrib->crc_err) || (pattrib->icv_err))
-			{
+			if ((pattrib->crc_err) || (pattrib->icv_err)) {
 #ifdef CONFIG_MP_INCLUDED
-				if (padapter->registrypriv.mp_mode == 1)
-				{
-					if ((check_fwstate(&padapter->mlmepriv, WIFI_MP_STATE) == _TRUE))//&&(padapter->mppriv.check_mp_pkt == 0))
-					{
+				if (padapter->registrypriv.mp_mode == 1) {
+					if ((check_fwstate(&padapter->mlmepriv, WIFI_MP_STATE) == _TRUE)) { /* &&(padapter->mppriv.check_mp_pkt == 0)) */
 						if (pattrib->crc_err == 1)
 							padapter->mppriv.rx_crcerrpktcount++;
 					}
-				}
-				else
+				} else
 #endif
 				{
-					DBG_8192C("%s: crc_err=%d icv_err=%d, skip!\n", __FUNCTION__, pattrib->crc_err, pattrib->icv_err);
+					RTW_INFO("%s: crc_err=%d icv_err=%d, skip!\n", __FUNCTION__, pattrib->crc_err, pattrib->icv_err);
 				}
 				rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
-			}
-			else
-			{
+			} else {
 				ppkt = rtw_skb_clone(precvbuf->pskb);
 				if (ppkt == NULL) {
-					DBG_8192C("%s: no enough memory to allocate SKB!\n", __FUNCTION__);
+					RTW_INFO("%s: no enough memory to allocate SKB!\n", __FUNCTION__);
 					rtw_free_recvframe(precvframe, &precvpriv->free_recv_queue);
 					rtw_enqueue_recvbuf_to_head(precvbuf, &precvpriv->recv_buf_pending_queue);
 
-					// The case of can't allocte skb is serious and may never be recovered,
-					// once bDriverStopped is enable, this task should be stopped.
-					if (padapter->bDriverStopped == _FALSE) {
+					/* The case of can't allocte skb is serious and may never be recovered, */
+					/* once bDriverStopped is enable, this task should be stopped. */
+					if (!rtw_is_drv_stopped(padapter)) {
 #ifdef PLATFORM_LINUX
 						tasklet_schedule(&precvpriv->recv_tasklet);
 #endif
@@ -497,46 +327,35 @@ static void rtl8188fs_recv_tasklet(void *priv)
 				phdr->rx_end = precvbuf->pend;
 				recvframe_put(precvframe, pkt_offset);
 				recvframe_pull(precvframe, RXDESC_SIZE + pattrib->drvinfo_sz);
-				if (pHalData->ReceiveConfig & RCR_APPFCS)
-					recvframe_pull_tail(precvframe, IEEE80211_FCS_LEN);
+				skb_pull(ppkt, RXDESC_SIZE + pattrib->drvinfo_sz);
+
+#ifdef CONFIG_RX_PACKET_APPEND_FCS
+				if (check_fwstate(&padapter->mlmepriv, WIFI_MONITOR_STATE) == _FALSE) {
+					if ((pattrib->pkt_rpt_type == NORMAL_RX) && rtw_hal_rcr_check(padapter, RCR_APPFCS)) {
+						recvframe_pull_tail(precvframe, IEEE80211_FCS_LEN);
+						pattrib->pkt_len -= IEEE80211_FCS_LEN;
+						ppkt->len = pattrib->pkt_len;
+					}
+				}
+#endif
 
-				// move to drv info position
+				/* move to drv info position */
 				ptr += RXDESC_SIZE;
 
-				// update drv info
-				if (pHalData->ReceiveConfig & RCR_APP_BA_SSN) {
-					//rtl8188s_update_bassn(padapter, pdrvinfo);
+				/* update drv info */
+				if (rtw_hal_rcr_check(padapter, RCR_APP_BA_SSN)) {
+					/* rtl8188s_update_bassn(padapter, pdrvinfo); */
 					ptr += 4;
 				}
 
-				if (pattrib->pkt_rpt_type == NORMAL_RX) {
-#ifdef CONFIG_CONCURRENT_MODE
-					if (rtw_buddy_adapter_up(padapter))
-					{
-						if (pre_recv_entry(precvframe, precvbuf, ptr) != _SUCCESS) {
-							RT_TRACE(_module_rtl871x_recv_c_,_drv_err_,
-								("recvbuf2recvframe: recv_entry(precvframe) != _SUCCESS\n"));
-						}
-					}
-					else
-#endif
-					{
-						if (pattrib->physt)
-							rx_query_phy_status(precvframe, ptr);
-
-						if (rtw_recv_entry(precvframe) != _SUCCESS)
-						{
-							RT_TRACE(_module_rtl871x_recv_c_, _drv_info_, ("rtl8188fs_recv_tasklet: rtw_recv_entry(precvframe) != _SUCCESS\n"));
-						}
-					}
-				}
+				if (pattrib->pkt_rpt_type == NORMAL_RX)
+					pre_recv_entry(precvframe, pattrib->physt ? ptr : NULL);
 				else {
-#ifdef CONFIG_C2H_PACKET_EN
-					if (pattrib->pkt_rpt_type == C2H_PACKET) {
-						rtl8188f_c2h_packet_handler(padapter, precvframe->u.hdr.rx_data, pattrib->pkt_len);
-					}
+#ifdef CONFIG_FW_C2H_PKT
+					if (pattrib->pkt_rpt_type == C2H_PACKET)
+						rtw_hal_c2h_pkt_pre_hdl(padapter, precvframe->u.hdr.rx_data, pattrib->pkt_len);
 					else {
-						DBG_8192C("%s: [WARNNING] RX type(%d) not be handled!\n",
+						RTW_INFO("%s: [WARNNING] RX type(%d) not be handled!\n",
 							__FUNCTION__, pattrib->pkt_rpt_type);
 					}
 #endif
@@ -573,7 +392,7 @@ s32 rtl8188fs_init_recv_priv(PADAPTER padapter)
 	res = _SUCCESS;
 	precvpriv = &padapter->recvpriv;
 
-	//3 1. init recv buffer
+	/* 3 1. init recv buffer */
 	_rtw_init_queue(&precvpriv->free_recv_buf_queue);
 	_rtw_init_queue(&precvpriv->recv_buf_pending_queue);
 
@@ -581,16 +400,15 @@ s32 rtl8188fs_init_recv_priv(PADAPTER padapter)
 	precvpriv->pallocated_recv_buf = rtw_zmalloc(n);
 	if (precvpriv->pallocated_recv_buf == NULL) {
 		res = _FAIL;
-		RT_TRACE(_module_rtl871x_recv_c_, _drv_err_, ("alloc recv_buf fail!\n"));
+		RTW_ERR("alloc recv_buf fail!\n");
 		goto exit;
 	}
 
-	precvpriv->precv_buf = (u8*)N_BYTE_ALIGMENT((SIZE_PTR)(precvpriv->pallocated_recv_buf), 4);
+	precvpriv->precv_buf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(precvpriv->pallocated_recv_buf), 4);
 
-	// init each recv buffer
-	precvbuf = (struct recv_buf*)precvpriv->precv_buf;
-	for (i = 0; i < NR_RECVBUFF; i++)
-	{
+	/* init each recv buffer */
+	precvbuf = (struct recv_buf *)precvpriv->precv_buf;
+	for (i = 0; i < NR_RECVBUFF; i++) {
 		res = initrecvbuf(precvbuf, padapter);
 		if (res == _FAIL)
 			break;
@@ -603,23 +421,21 @@ s32 rtl8188fs_init_recv_priv(PADAPTER padapter)
 
 #ifdef CONFIG_SDIO_RX_COPY
 		if (precvbuf->pskb == NULL) {
-			SIZE_PTR tmpaddr=0;
-			SIZE_PTR alignment=0;
+			SIZE_PTR tmpaddr = 0;
+			SIZE_PTR alignment = 0;
 
 			precvbuf->pskb = rtw_skb_alloc(MAX_RECVBUF_SZ + RECVBUFF_ALIGN_SZ);
 
-			if(precvbuf->pskb)
-			{
+			if (precvbuf->pskb) {
 				precvbuf->pskb->dev = padapter->pnetdev;
 
 				tmpaddr = (SIZE_PTR)precvbuf->pskb->data;
-				alignment = tmpaddr & (RECVBUFF_ALIGN_SZ-1);
+				alignment = tmpaddr & (RECVBUFF_ALIGN_SZ - 1);
 				skb_reserve(precvbuf->pskb, (RECVBUFF_ALIGN_SZ - alignment));
 			}
 
-			if (precvbuf->pskb == NULL) {
-				DBG_871X("%s: alloc_skb fail!\n", __FUNCTION__);
-			}
+			if (precvbuf->pskb == NULL)
+				RTW_INFO("%s: alloc_skb fail!\n", __FUNCTION__);
 		}
 #endif
 
@@ -632,22 +448,21 @@ s32 rtl8188fs_init_recv_priv(PADAPTER padapter)
 	if (res == _FAIL)
 		goto initbuferror;
 
-	//3 2. init tasklet
+	/* 3 2. init tasklet */
 #ifdef PLATFORM_LINUX
 	tasklet_init(&precvpriv->recv_tasklet,
-	     (void(*)(unsigned long))rtl8188fs_recv_tasklet,
-	     (unsigned long)padapter);
+		     (void(*)(unsigned long))rtl8188fs_recv_tasklet,
+		     (unsigned long)padapter);
 #endif
 
 	goto exit;
 
 initbuferror:
-	precvbuf = (struct recv_buf*)precvpriv->precv_buf;
+	precvbuf = (struct recv_buf *)precvpriv->precv_buf;
 	if (precvbuf) {
 		n = precvpriv->free_recv_buf_queue_cnt;
 		precvpriv->free_recv_buf_queue_cnt = 0;
-		for (i = 0; i < n ; i++)
-		{
+		for (i = 0; i < n ; i++) {
 			rtw_list_delete(&precvbuf->list);
 			rtw_os_recvbuf_resource_free(padapter, precvbuf);
 			freerecvbuf(precvbuf);
@@ -681,18 +496,17 @@ void rtl8188fs_free_recv_priv(PADAPTER padapter)
 
 	precvpriv = &padapter->recvpriv;
 
-	//3 1. kill tasklet
+	/* 3 1. kill tasklet */
 #ifdef PLATFORM_LINUX
 	tasklet_kill(&precvpriv->recv_tasklet);
 #endif
 
-	//3 2. free all recv buffers
-	precvbuf = (struct recv_buf*)precvpriv->precv_buf;
+	/* 3 2. free all recv buffers */
+	precvbuf = (struct recv_buf *)precvpriv->precv_buf;
 	if (precvbuf) {
 		n = NR_RECVBUFF;
 		precvpriv->free_recv_buf_queue_cnt = 0;
-		for (i = 0; i < n ; i++)
-		{
+		for (i = 0; i < n ; i++) {
 			rtw_list_delete(&precvbuf->list);
 			rtw_os_recvbuf_resource_free(padapter, precvbuf);
 			freerecvbuf(precvbuf);
@@ -707,4 +521,3 @@ void rtl8188fs_free_recv_priv(PADAPTER padapter)
 		precvpriv->pallocated_recv_buf = NULL;
 	}
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_xmit.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_xmit.c
index 7c5daa1a9175..3fd36e9eab45 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_xmit.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/rtl8189fs_xmit.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RTL8188FS_XMIT_C_
 
 #include <rtl8188f_hal.h>
@@ -26,34 +22,33 @@ static u8 rtw_sdio_wait_enough_TxOQT_space(PADAPTER padapter, u8 agg_num)
 	u32 n = 0;
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
 
-	while (pHalData->SdioTxOQTFreeSpace < agg_num) 
-	{
+	while (pHalData->SdioTxOQTFreeSpace < agg_num) {
 		if (RTW_CANNOT_RUN(padapter)) {
-			DBG_871X("%s: bSurpriseRemoved or bDriverStopped (wait TxOQT)\n", __func__);
+			RTW_INFO("%s: bSurpriseRemoved or bDriverStopped (wait TxOQT)\n", __func__);
 			return _FALSE;
 		}
 
 		HalQueryTxOQTBufferStatus8188FSdio(padapter);
-		
+
 		if ((++n % 60) == 0) {
-			if ((n % 300) == 0) {			
-				DBG_871X("%s(%d): QOT free space(%d), agg_num: %d\n",
- 				__func__, n, pHalData->SdioTxOQTFreeSpace, agg_num);
-			}	
+			if ((n % 300) == 0) {
+				RTW_INFO("%s(%d): QOT free space(%d), agg_num: %d\n",
+					__func__, n, pHalData->SdioTxOQTFreeSpace, agg_num);
+			}
 			rtw_msleep_os(1);
-			//yield();
+			/* yield(); */
 		}
 	}
 
 	pHalData->SdioTxOQTFreeSpace -= agg_num;
-	
-	//if (n > 1)
-	//	++priv->pshare->nr_out_of_txoqt_space;
+
+	/* if (n > 1) */
+	/*	++priv->pshare->nr_out_of_txoqt_space; */
 
 	return _TRUE;
 }
 
-static s32 rtl8188fs_dequeue_writeport(PADAPTER padapter)
+s32 _dequeue_writeport(PADAPTER padapter)
 {
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
@@ -67,36 +62,33 @@ static s32 rtl8188fs_dequeue_writeport(PADAPTER padapter)
 	u32	polling_num = 0;
 #endif
 
-	if (rtw_xmit_ac_blocked(padapter) == _TRUE)
-		pxmitbuf = dequeue_pending_xmitbuf_under_survey(pxmitpriv);
-	else
-		pxmitbuf = dequeue_pending_xmitbuf(pxmitpriv);
+	pxmitbuf = select_and_dequeue_pending_xmitbuf(padapter);
 
 	if (pxmitbuf == NULL)
 		return _TRUE;
 
 	deviceId = ffaddr2deviceId(pdvobjpriv, pxmitbuf->ff_hwaddr);
 
-	// translate fifo addr to queue index
+	/* translate fifo addr to queue index */
 	switch (deviceId) {
-		case WLAN_TX_HIQ_DEVICE_ID:
-				PageIdx = HI_QUEUE_IDX;
-				break;
+	case WLAN_TX_HIQ_DEVICE_ID:
+		PageIdx = HI_QUEUE_IDX;
+		break;
 
-		case WLAN_TX_MIQ_DEVICE_ID:
-				PageIdx = MID_QUEUE_IDX;
-				break;
+	case WLAN_TX_MIQ_DEVICE_ID:
+		PageIdx = MID_QUEUE_IDX;
+		break;
 
-		case WLAN_TX_LOQ_DEVICE_ID:
-				PageIdx = LOW_QUEUE_IDX;
-				break;
+	case WLAN_TX_LOQ_DEVICE_ID:
+		PageIdx = LOW_QUEUE_IDX;
+		break;
 	}
 
 query_free_page:
 	/* check if hardware tx fifo page is enough */
 	if (_FALSE == rtw_hal_sdio_query_tx_freepage(padapter, PageIdx, pxmitbuf->pg_num)) {
 		if (RTW_CANNOT_RUN(padapter)) {
-			DBG_871X("%s: bDriverStopped(%d) bSurpriseRemoved(%d)!\n"
+			RTW_INFO("%s: bDriverStopped(%d) bSurpriseRemoved(%d)!\n"
 				, __func__
 				, rtw_is_drv_stopped(padapter)
 				, rtw_is_surprise_removed(padapter));
@@ -104,7 +96,7 @@ query_free_page:
 		}
 #ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT
 		if (!bUpdatePageNum) {
-			// Total number of page is NOT available, so update current FIFO status
+			/* Total number of page is NOT available, so update current FIFO status */
 			HalQueryTxBufferStatus8188FSdio(padapter);
 			bUpdatePageNum = _TRUE;
 			goto query_free_page;
@@ -113,82 +105,73 @@ query_free_page:
 			enqueue_pending_xmitbuf_to_head(pxmitpriv, pxmitbuf);
 			return _TRUE;
 		}
-#else //CONFIG_SDIO_TX_ENABLE_AVAL_INT
+#else /* CONFIG_SDIO_TX_ENABLE_AVAL_INT */
 		polling_num++;
 		if ((polling_num % 10) == 0) {
-			//DBG_871X("%s: FIFO starvation!(%d) len=%d agg=%d page=(R)%d(A)%d\n",
-			//	__func__, polling_num, pxmitbuf->len, pxmitbuf->agg_num, pframe->pg_num, freePage[PageIdx] + freePage[PUBLIC_QUEUE_IDX]);
+			/* RTW_INFO("%s: FIFO starvation!(%d) len=%d agg=%d page=(R)%d(A)%d\n", */
+			/*	__func__, polling_num, pxmitbuf->len, pxmitbuf->agg_num, pframe->pg_num, freePage[PageIdx] + freePage[PUBLIC_QUEUE_IDX]); */
+			enqueue_pending_xmitbuf_to_head(pxmitpriv, pxmitbuf);
 			rtw_usleep_os(50);
+			return _FALSE;
 		}
 
-		// Total number of page is NOT available, so update current FIFO status
+		/* Total number of page is NOT available, so update current FIFO status */
 		HalQueryTxBufferStatus8188FSdio(padapter);
 		goto query_free_page;
-#endif //CONFIG_SDIO_TX_ENABLE_AVAL_INT
+#endif /* CONFIG_SDIO_TX_ENABLE_AVAL_INT */
 	}
 
-	if (rtw_sdio_wait_enough_TxOQT_space(padapter, pxmitbuf->agg_num) == _FALSE) 
-	{
+	if (rtw_sdio_wait_enough_TxOQT_space(padapter, pxmitbuf->agg_num) == _FALSE)
 		goto free_xmitbuf;
-	}
 
 #ifdef CONFIG_CHECK_LEAVE_LPS
 	traffic_check_for_leave_lps(padapter, _TRUE, pxmitbuf->agg_num);
-#endif 
+#endif
 
 	rtw_write_port(padapter, deviceId, pxmitbuf->len, (u8 *)pxmitbuf);
 
 	rtw_hal_sdio_update_tx_freepage(padapter, PageIdx, pxmitbuf->pg_num);
 
 free_xmitbuf:
-	//rtw_free_xmitframe(pxmitpriv, pframe);
-	//pxmitbuf->priv_data = NULL;
+	/* rtw_free_xmitframe(pxmitpriv, pframe); */
+	/* pxmitbuf->priv_data = NULL; */
 	rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
 
-#if 0 // improve TX/RX throughput balance
-{
-	PSDIO_DATA psdio;
-	struct sdio_func *func;
-	static u8 i = 0;
-	u32 sdio_hisr;
-	u8 j;
-
-	psdio = &adapter_to_dvobj(padapter)->intf_data;
-	func = psdio->func;
-
-	if (i == 2)
+#if 0 /* improve TX/RX throughput balance */
 	{
-		j = 0;
-		while (j < 10)
-		{
-			sdio_hisr = SdioLocalCmd52Read1Byte(padapter, SDIO_REG_HISR);
-			sdio_hisr &= GET_HAL_DATA(padapter)->sdio_himr;
-			if (sdio_hisr & SDIO_HISR_RX_REQUEST)
-			{
-				sdio_claim_host(func);
-				sd_int_hdl(GET_PRIMARY_ADAPTER(padapter));
-				sdio_release_host(func);
-			}
-			else
-			{
-				break;
+		PSDIO_DATA psdio;
+		struct sdio_func *func;
+		static u8 i = 0;
+		u32 sdio_hisr;
+		u8 j;
+
+		psdio = &adapter_to_dvobj(padapter)->intf_data;
+		func = psdio->func;
+
+		if (i == 2) {
+			j = 0;
+			while (j < 10) {
+				sdio_hisr = SdioLocalCmd52Read1Byte(padapter, SDIO_REG_HISR);
+				sdio_hisr &= GET_HAL_DATA(padapter)->sdio_himr;
+				if (sdio_hisr & SDIO_HISR_RX_REQUEST) {
+					sdio_claim_host(func);
+					sd_int_hdl(GET_PRIMARY_ADAPTER(padapter));
+					sdio_release_host(func);
+				} else
+					break;
+				j++;
 			}
-			j++;
-		}
-		i = 0;
+			i = 0;
+		} else
+			i++;
 	}
-	else
-	{
-		i++;
-	}
-}
 #endif
 
 #ifdef CONFIG_SDIO_TX_TASKLET
 	tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
 #endif
 
-	return _FAIL;
+	return _FALSE;
 }
 
 /*
@@ -202,51 +185,37 @@ free_xmitbuf:
 s32 rtl8188fs_xmit_buf_handler(PADAPTER padapter)
 {
 	struct xmit_priv *pxmitpriv;
-	u8	queue_empty, queue_pending;
+	u8	queue_empty;
 	s32	ret;
 
 	pxmitpriv = &padapter->xmitpriv;
 
 	ret = _rtw_down_sema(&pxmitpriv->xmit_sema);
 	if (_FAIL == ret) {
-		DBG_871X_LEVEL(_drv_emerg_, "%s: down SdioXmitBufSema fail!\n", __FUNCTION__);
+		RTW_ERR("%s: down SdioXmitBufSema fail!\n", __FUNCTION__);
 		return _FAIL;
 	}
 
 	if (RTW_CANNOT_RUN(padapter)) {
-		RT_TRACE(_module_hal_xmit_c_, _drv_err_
-			, ("%s: bDriverStopped(%s) bSurpriseRemoved(%s)!\n"
-			, __func__
-			, rtw_is_drv_stopped(padapter)?"True":"False"
-			, rtw_is_surprise_removed(padapter)?"True":"False"));
+		RTW_DBG(FUNC_ADPT_FMT "- bDriverStopped(%s) bSurpriseRemoved(%s)\n",
+			FUNC_ADPT_ARG(padapter),
+			rtw_is_drv_stopped(padapter) ? "True" : "False",
+			rtw_is_surprise_removed(padapter) ? "True" : "False");
 		return _FAIL;
 	}
 
-	queue_pending = check_pending_xmitbuf(pxmitpriv);
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if(rtw_buddy_adapter_up(padapter))
-		queue_pending |= check_pending_xmitbuf(&padapter->pbuddy_adapter->xmitpriv);
-#endif
-
-	if(queue_pending == _FALSE)
+	if (rtw_mi_check_pending_xmitbuf(padapter) == 0)
 		return _SUCCESS;
 
 #ifdef CONFIG_LPS_LCLK
 	ret = rtw_register_tx_alive(padapter);
-	if (ret != _SUCCESS) {
+	if (ret != _SUCCESS)
 		return _SUCCESS;
-	}
 #endif
 
 	do {
-		queue_empty = rtl8188fs_dequeue_writeport(padapter);
-//	dump secondary adapter xmitbuf
-#ifdef CONFIG_CONCURRENT_MODE
-		if(rtw_buddy_adapter_up(padapter))
-			queue_empty &= rtl8188fs_dequeue_writeport(padapter->pbuddy_adapter);
-#endif
-	} while ( !queue_empty);
+		queue_empty = rtw_mi_dequeue_writeport(padapter);
+	} while (!queue_empty);
 
 #ifdef CONFIG_LPS_LCLK
 	rtw_unregister_tx_alive(padapter);
@@ -267,7 +236,7 @@ s32 rtl8188fs_xmit_buf_handler(PADAPTER padapter)
 static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 {
 	s32 err, ret;
-	u32 k=0;
+	u32 k = 0;
 	struct hw_xmit *hwxmits, *phwxmit;
 	u8 no_res, idx, hwentry;
 	_irqL irql;
@@ -279,9 +248,9 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 	u32 txlen, max_xmit_len, page_size;
 	u8 txdesc_size = TXDESC_SIZE;
 	int inx[4];
-	u8 pre_qsel=0xFF,next_qsel=0xFF;
+	u8 pre_qsel = 0xFF, next_qsel = 0xFF;
 	u8 single_sta_in_queue = _FALSE;
-	
+
 	err = 0;
 	no_res = _FALSE;
 	hwxmits = pxmitpriv->hwxmits;
@@ -294,18 +263,20 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 	rtw_hal_get_def_var(padapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
 
 	if (padapter->registrypriv.wifi_spec == 1) {
-		for(idx=0; idx<4; idx++)
+		for (idx = 0; idx < 4; idx++)
 			inx[idx] = pxmitpriv->wmm_para_seq[idx];
 	} else {
-		inx[0] = 0; inx[1] = 1; inx[2] = 2; inx[3] = 3;
+		inx[0] = 0;
+		inx[1] = 1;
+		inx[2] = 2;
+		inx[3] = 3;
 	}
 
-	// 0(VO), 1(VI), 2(BE), 3(BK)
-	for (idx = 0; idx < hwentry; idx++)
-	{
+	/* 0(VO), 1(VI), 2(BE), 3(BK) */
+	for (idx = 0; idx < hwentry; idx++) {
 		phwxmit = hwxmits + inx[idx];
-	
-		if((check_pending_xmitbuf(pxmitpriv) == _TRUE) && (padapter->mlmepriv.LinkDetectInfo.bHigherBusyTxTraffic == _TRUE)) {
+
+		if ((check_pending_xmitbuf(pxmitpriv) == _TRUE) && (padapter->mlmepriv.LinkDetectInfo.bHigherBusyTxTraffic == _TRUE)) {
 			if ((phwxmit->accnt > 0) && (phwxmit->accnt < 5)) {
 				err = -2;
 				break;
@@ -315,50 +286,45 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 		max_xmit_len = rtw_hal_get_sdio_tx_max_length(padapter, inx[idx]);
 
 		_enter_critical_bh(&pxmitpriv->lock, &irql);
-		
+
 		sta_phead = get_list_head(phwxmit->sta_queue);
 		sta_plist = get_next(sta_phead);
-		//because stop_sta_xmit may delete sta_plist at any time
-		//so we should add lock here, or while loop can not exit
+		/* because stop_sta_xmit may delete sta_plist at any time */
+		/* so we should add lock here, or while loop can not exit */
 
 		single_sta_in_queue = rtw_end_of_queue_search(sta_phead, get_next(sta_plist));
 
-		while (rtw_end_of_queue_search(sta_phead, sta_plist) == _FALSE)
-		{
+		while (rtw_end_of_queue_search(sta_phead, sta_plist) == _FALSE) {
 			ptxservq = LIST_CONTAINOR(sta_plist, struct tx_servq, tx_pending);
 			sta_plist = get_next(sta_plist);
 
 #ifdef DBG_XMIT_BUF
-			DBG_871X("%s idx:%d hwxmit_pkt_num:%d ptxservq_pkt_num:%d\n", __func__, idx, phwxmit->accnt, ptxservq->qcnt);
-			DBG_871X("%s free_xmit_extbuf_cnt=%d free_xmitbuf_cnt=%d free_xmitframe_cnt=%d \n",
-				       	__func__, pxmitpriv->free_xmit_extbuf_cnt, pxmitpriv->free_xmitbuf_cnt,
-					pxmitpriv->free_xmitframe_cnt);
+			RTW_INFO("%s idx:%d hwxmit_pkt_num:%d ptxservq_pkt_num:%d\n", __func__, idx, phwxmit->accnt, ptxservq->qcnt);
+			RTW_INFO("%s free_xmit_extbuf_cnt=%d free_xmitbuf_cnt=%d free_xmitframe_cnt=%d\n",
+				__func__, pxmitpriv->free_xmit_extbuf_cnt, pxmitpriv->free_xmitbuf_cnt,
+				 pxmitpriv->free_xmitframe_cnt);
 #endif
 			pframe_queue = &ptxservq->sta_pending;
 
 			frame_phead = get_list_head(pframe_queue);
 
-			while (rtw_is_list_empty(frame_phead) == _FALSE)
-			{
+			while (rtw_is_list_empty(frame_phead) == _FALSE) {
 				frame_plist = get_next(frame_phead);
 				pxmitframe = LIST_CONTAINOR(frame_plist, struct xmit_frame, list);
-				
-				// check xmit_buf size enough or not
+
+				/* check xmit_buf size enough or not */
 				txlen = txdesc_size + rtw_wlan_pkt_size(pxmitframe);
 				next_qsel = pxmitframe->attrib.qsel;
 				if ((NULL == pxmitbuf)
 					|| (pxmitbuf->pg_num + PageNum(txlen, page_size) > PageNum(max_xmit_len, page_size))
-					|| (k >= (rtw_hal_sdio_max_txoqt_free_space(padapter)-1))
-					|| ((k!=0) && (_FAIL == rtw_hal_busagg_qsel_check(padapter,pre_qsel,next_qsel)))
-				)
-				{
-					if (pxmitbuf)
-					{
-						//pxmitbuf->priv_data will be NULL, and will crash here
-						if (pxmitbuf->len > 0 && pxmitbuf->priv_data)
-						{
+					|| (k >= (rtw_hal_sdio_max_txoqt_free_space(padapter) - 1))
+					|| ((k != 0) && (_FAIL == rtw_hal_busagg_qsel_check(padapter, pre_qsel, next_qsel)))
+				) {
+					if (pxmitbuf) {
+						/* pxmitbuf->priv_data will be NULL, and will crash here */
+						if (pxmitbuf->len > 0 && pxmitbuf->priv_data) {
 							struct xmit_frame *pframe;
-							pframe = (struct xmit_frame*)pxmitbuf->priv_data;
+							pframe = (struct xmit_frame *)pxmitbuf->priv_data;
 							pframe->agg_num = k;
 							pxmitbuf->agg_num = k;
 							rtl8188f_update_txdesc(pframe, pframe->buf_addr);
@@ -366,46 +332,40 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 							pxmitbuf->priv_data = NULL;
 							enqueue_pending_xmitbuf(pxmitpriv, pxmitbuf);
 
-							//can not yield under lock
-							//rtw_yield_os();
+							/* can not yield under lock */
+							/* rtw_yield_os(); */
 							if (single_sta_in_queue == _FALSE) {
 								/* break the loop in case there is more than one sta in this ac queue */
 								pxmitbuf = NULL;
 								err = -3;
 								break;
 							}
-							
-						} else {
+
+						} else
 							rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
-						}
 					}
 
 					pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
 					if (pxmitbuf == NULL) {
 #ifdef DBG_XMIT_BUF
-						DBG_871X_LEVEL(_drv_err_, "%s: xmit_buf is not enough!\n", __FUNCTION__);
+						RTW_ERR("%s: xmit_buf is not enough!\n", __FUNCTION__);
 #endif
 						err = -2;
 #ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT
-	#ifdef CONFIG_CONCURRENT_MODE
-						if (padapter->adapter_type > PRIMARY_ADAPTER)
-							_rtw_up_sema(&(padapter->pbuddy_adapter->xmitpriv.xmit_sema));
-						else
-	#endif
-							_rtw_up_sema(&(pxmitpriv->xmit_sema));
+						_rtw_up_sema(&(GET_PRIMARY_ADAPTER(padapter)->xmitpriv.xmit_sema));
 #endif
 						break;
 					}
 					k = 0;
 				}
 
-				// ok to send, remove frame from queue
+				/* ok to send, remove frame from queue */
 #ifdef CONFIG_AP_MODE
-				if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE) {
+				if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
 					if ((pxmitframe->attrib.psta->state & WIFI_SLEEP_STATE) &&
-						(pxmitframe->attrib.triggered == 0)) {
-						DBG_871X("%s: one not triggered pkt in queue when this STA sleep,"
-								" break and goto next sta\n", __func__);
+					    (pxmitframe->attrib.triggered == 0)) {
+						RTW_INFO("%s: one not triggered pkt in queue when this STA sleep,"
+							" break and goto next sta\n", __func__);
 						break;
 					}
 				}
@@ -416,17 +376,17 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 
 				if (k == 0) {
 					pxmitbuf->ff_hwaddr = rtw_get_ff_hwaddr(pxmitframe);
-					pxmitbuf->priv_data = (u8*)pxmitframe;
+					pxmitbuf->priv_data = (u8 *)pxmitframe;
 				}
 
-				// coalesce the xmitframe to xmitbuf
+				/* coalesce the xmitframe to xmitbuf */
 				pxmitframe->pxmitbuf = pxmitbuf;
 				pxmitframe->buf_addr = pxmitbuf->ptail;
 
 				ret = rtw_xmitframe_coalesce(padapter, pxmitframe->pkt, pxmitframe);
 				if (ret == _FAIL) {
-					DBG_871X_LEVEL(_drv_err_, "%s: coalesce FAIL!", __FUNCTION__);
-					// Todo: error handler
+					RTW_ERR("%s: coalesce FAIL!", __FUNCTION__);
+					/* Todo: error handler */
 				} else {
 					k++;
 					if (k != 1)
@@ -434,11 +394,11 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 					rtw_count_tx_stats(padapter, pxmitframe, pxmitframe->attrib.last_txcmdsz);
 					pre_qsel = pxmitframe->attrib.qsel;
 					txlen = txdesc_size + pxmitframe->attrib.last_txcmdsz;
-					pxmitframe->pg_num = (txlen + 127)/128;
-					pxmitbuf->pg_num += (txlen + 127)/128;
-				    //if (k != 1)
-					//	((struct xmit_frame*)pxmitbuf->priv_data)->pg_num += pxmitframe->pg_num;
-					pxmitbuf->ptail += _RND(txlen, 8); // round to 8 bytes alignment
+					pxmitframe->pg_num = (txlen + 127) / 128;
+					pxmitbuf->pg_num += (txlen + 127) / 128;
+					/* if (k != 1) */
+					/*	((struct xmit_frame*)pxmitbuf->priv_data)->pg_num += pxmitframe->pg_num; */
+					pxmitbuf->ptail += _RND(txlen, 8); /* round to 8 bytes alignment */
 					pxmitbuf->len = _RND(pxmitbuf->len, 8) + txlen;
 				}
 
@@ -452,21 +412,20 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 			else if (err == -3) {
 				/* Re-arrange the order of stations in this ac queue to balance the service for these stations */
 				rtw_list_delete(&ptxservq->tx_pending);
-				rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(phwxmit->sta_queue));			
+				rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(phwxmit->sta_queue));
 			}
 
-			if (err) break;
+			if (err)
+				break;
 		}
 		_exit_critical_bh(&pxmitpriv->lock, &irql);
-		
-		// dump xmit_buf to hw tx fifo
-		if (pxmitbuf)
-		{
-			RT_TRACE(_module_hal_xmit_c_, _drv_info_, ("pxmitbuf->len=%d enqueue\n",pxmitbuf->len));
+
+		/* dump xmit_buf to hw tx fifo */
+		if (pxmitbuf) {
 
 			if (pxmitbuf->len > 0) {
 				struct xmit_frame *pframe;
-				pframe = (struct xmit_frame*)pxmitbuf->priv_data;
+				pframe = (struct xmit_frame *)pxmitbuf->priv_data;
 				pframe->agg_num = k;
 				pxmitbuf->agg_num = k;
 				rtl8188f_update_txdesc(pframe, pframe->buf_addr);
@@ -474,13 +433,12 @@ static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)
 				pxmitbuf->priv_data = NULL;
 				enqueue_pending_xmitbuf(pxmitpriv, pxmitbuf);
 				rtw_yield_os();
-			}
-			else
+			} else
 				rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
 			pxmitbuf = NULL;
 		}
-		
-		if (err == -2) 
+
+		if (err == -2)
 			break;
 	}
 
@@ -507,37 +465,35 @@ s32 rtl8188fs_xmit_handler(PADAPTER padapter)
 wait:
 	ret = _rtw_down_sema(&pxmitpriv->SdioXmitSema);
 	if (_FAIL == ret) {
-		DBG_871X_LEVEL(_drv_emerg_, "%s: down sema fail!\n", __FUNCTION__);
+		RTW_ERR("%s: down sema fail!\n", __FUNCTION__);
 		return _FAIL;
 	}
 
 next:
 	if (RTW_CANNOT_RUN(padapter)) {
-		RT_TRACE(_module_hal_xmit_c_, _drv_notice_
-			, ("%s: bDriverStopped(%s) bSurpriseRemoved(%s)\n"
-			, __func__
-			, rtw_is_drv_stopped(padapter)?"True":"False"
-			, rtw_is_surprise_removed(padapter)?"True":"False"));
+		RTW_DBG(FUNC_ADPT_FMT "- bDriverStopped(%s) bSurpriseRemoved(%s)\n",
+			FUNC_ADPT_ARG(padapter),
+			rtw_is_drv_stopped(padapter) ? "True" : "False",
+			rtw_is_surprise_removed(padapter) ? "True" : "False");
 		return _FAIL;
 	}
 
 	_enter_critical_bh(&pxmitpriv->lock, &irql);
 	ret = rtw_txframes_pending(padapter);
 	_exit_critical_bh(&pxmitpriv->lock, &irql);
-	if (ret == 0) {
+	if (ret == 0)
 		return _SUCCESS;
-	}
 
-	// dequeue frame and write to hardware
+	/* dequeue frame and write to hardware */
 
 	ret = xmit_xmitframes(padapter, pxmitpriv);
 	if (ret == -2) {
-		//here sleep 1ms will cause big TP loss of TX
-		//from 50+ to 40+
-		if(padapter->registrypriv.wifi_spec)
+		/* here sleep 1ms will cause big TP loss of TX */
+		/* from 50+ to 40+ */
+		if (padapter->registrypriv.wifi_spec)
 			rtw_msleep_os(1);
 		else
-#ifdef CONFIG_REDUCE_TX_CPU_LOADING 
+#ifdef CONFIG_REDUCE_TX_CPU_LOADING
 			rtw_msleep_os(1);
 #else
 			rtw_yield_os();
@@ -549,7 +505,7 @@ next:
 	ret = rtw_txframes_pending(padapter);
 	_exit_critical_bh(&pxmitpriv->lock, &irql);
 	if (ret == 1) {
-#ifdef CONFIG_REDUCE_TX_CPU_LOADING 
+#ifdef CONFIG_REDUCE_TX_CPU_LOADING
 		rtw_msleep_os(1);
 #endif
 		goto next;
@@ -573,24 +529,18 @@ thread_return rtl8188fs_xmit_thread(thread_context context)
 	rtw_sprintf(thread_name, 20, "%s-"ADPT_FMT, thread_name, ADPT_ARG(padapter));
 	thread_enter(thread_name);
 
-	DBG_871X("start "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-
-	// For now, no one would down sema to check thread is running,
-	// so mark this temporary, Lucas@20130820
-//	_rtw_up_sema(&pxmitpriv->SdioXmitTerminateSema);
+	RTW_INFO("start "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
 
 	do {
 		ret = rtl8188fs_xmit_handler(padapter);
-		if (signal_pending(current)) {
-			flush_signals(current);
-		}
+		flush_signals_thread();
 	} while (_SUCCESS == ret);
 
-	_rtw_up_sema(&pxmitpriv->SdioXmitTerminateSema);
+	RTW_INFO(FUNC_ADPT_FMT " Exit\n", FUNC_ADPT_ARG(padapter));
 
-	RT_TRACE(_module_hal_xmit_c_, _drv_notice_, ("-%s\n", __FUNCTION__));
+	rtw_thread_wait_stop();
+	return 0;
 
-	thread_exit();
 }
 
 s32 rtl8188fs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe)
@@ -603,7 +553,6 @@ s32 rtl8188fs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe)
 	u8 *pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
 	u8 txdesc_size = TXDESC_SIZE;
 
-	RT_TRACE(_module_hal_xmit_c_, _drv_info_, ("+%s\n", __FUNCTION__));
 
 	pattrib = &pmgntframe->attrib;
 	pxmitbuf = pmgntframe->pxmitbuf;
@@ -611,8 +560,8 @@ s32 rtl8188fs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe)
 	rtl8188f_update_txdesc(pmgntframe, pmgntframe->buf_addr);
 
 	pxmitbuf->len = txdesc_size + pattrib->last_txcmdsz;
-	//pmgntframe->pg_num = (pxmitbuf->len + 127)/128; // 128 is tx page size
-	pxmitbuf->pg_num = (pxmitbuf->len + 127)/128; // 128 is tx page size
+	/* pmgntframe->pg_num = (pxmitbuf->len + 127)/128; // 128 is tx page size */
+	pxmitbuf->pg_num = (pxmitbuf->len + 127) / 128; /* 128 is tx page size */
 	pxmitbuf->ptail = pmgntframe->buf_addr + pxmitbuf->len;
 	pxmitbuf->ff_hwaddr = rtw_get_ff_hwaddr(pmgntframe);
 
@@ -622,18 +571,14 @@ s32 rtl8188fs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe)
 
 	pxmitbuf->priv_data = NULL;
 
-	if(GetFrameSubType(pframe)==WIFI_BEACON) //dump beacon directly
-	{
+	if (get_frame_sub_type(pframe) == WIFI_BEACON) { /* dump beacon directly */
 		ret = rtw_write_port(padapter, pdvobjpriv->Queue2Pipe[pxmitbuf->ff_hwaddr], pxmitbuf->len, (u8 *)pxmitbuf);
 		if (ret != _SUCCESS)
 			rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_WRITE_PORT_ERR);
 
 		rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
-	}
-	else
-	{
+	} else
 		enqueue_pending_xmitbuf(pxmitpriv, pxmitbuf);
-	}
 
 	return ret;
 }
@@ -658,10 +603,9 @@ s32 rtl8188fs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe)
 
 #ifdef CONFIG_80211N_HT
 	if ((pxmitframe->frame_tag == DATA_FRAMETAG) &&
-		(pxmitframe->attrib.ether_type != 0x0806) &&
-		(pxmitframe->attrib.ether_type != 0x888e) &&
-		(pxmitframe->attrib.dhcp_pkt != 1))
-	{
+	    (pxmitframe->attrib.ether_type != 0x0806) &&
+	    (pxmitframe->attrib.ether_type != 0x888e) &&
+	    (pxmitframe->attrib.dhcp_pkt != 1)) {
 		if (padapter->mlmepriv.LinkDetectInfo.bBusyTraffic == _TRUE)
 			rtw_issue_addbareq_cmd(padapter, pxmitframe);
 	}
@@ -671,7 +615,6 @@ s32 rtl8188fs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe)
 	err = rtw_xmitframe_enqueue(padapter, pxmitframe);
 	_exit_critical_bh(&pxmitpriv->lock, &irql);
 	if (err != _SUCCESS) {
-		RT_TRACE(_module_hal_xmit_c_, _drv_err_, ("rtl8188fs_hal_xmit: enqueue xmitframe fail\n"));
 		rtw_free_xmitframe(pxmitpriv, pxmitframe);
 
 		pxmitpriv->tx_drop++;
@@ -685,26 +628,24 @@ s32 rtl8188fs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe)
 
 s32	rtl8188fs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
-	struct xmit_priv 	*pxmitpriv = &padapter->xmitpriv;
+	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
 	s32 err;
-	
-	if ((err=rtw_xmitframe_enqueue(padapter, pxmitframe)) != _SUCCESS) 
-	{
+
+	err = rtw_xmitframe_enqueue(padapter, pxmitframe);
+	if (err != _SUCCESS) {
 		rtw_free_xmitframe(pxmitpriv, pxmitframe);
 
-		pxmitpriv->tx_drop++;					
-	}
-	else
-	{
+		pxmitpriv->tx_drop++;
+	} else {
 #ifdef CONFIG_SDIO_TX_TASKLET
-		tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);					
+		tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
 #else
 		_rtw_up_sema(&pxmitpriv->SdioXmitSema);
 #endif
 	}
-	
+
 	return err;
-	
+
 }
 
 /*
@@ -723,7 +664,6 @@ s32 rtl8188fs_init_xmit_priv(PADAPTER padapter)
 
 	_rtw_spinlock_init(&phal->SdioTxFIFOFreePageLock);
 	_rtw_init_sema(&xmitpriv->SdioXmitSema, 0);
-	_rtw_init_sema(&xmitpriv->SdioXmitTerminateSema, 0);
 
 	return _SUCCESS;
 }
@@ -746,27 +686,24 @@ void rtl8188fs_free_xmit_priv(PADAPTER padapter)
 	_rtw_init_listhead(&tmplist);
 
 	_enter_critical_bh(&pqueue->lock, &irql);
-	if (_rtw_queue_empty(pqueue) == _FALSE)
-	{
-		// Insert tmplist to end of queue, and delete phead
-		// then tmplist become head of queue.
+	if (_rtw_queue_empty(pqueue) == _FALSE) {
+		/* Insert tmplist to end of queue, and delete phead */
+		/* then tmplist become head of queue. */
 		rtw_list_insert_tail(&tmplist, phead);
 		rtw_list_delete(phead);
 	}
 	_exit_critical_bh(&pqueue->lock, &irql);
 
 	phead = &tmplist;
-	while (rtw_is_list_empty(phead) == _FALSE)
-	{
+	while (rtw_is_list_empty(phead) == _FALSE) {
 		plist = get_next(phead);
 		rtw_list_delete(plist);
 
 		pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
-		rtw_free_xmitframe(pxmitpriv, (struct xmit_frame*)pxmitbuf->priv_data);
+		rtw_free_xmitframe(pxmitpriv, (struct xmit_frame *)pxmitbuf->priv_data);
 		pxmitbuf->priv_data = NULL;
 		rtw_free_xmitbuf(pxmitpriv, pxmitbuf);
 	}
 
 	_rtw_spinlock_free(&phal->SdioTxFIFOFreePageLock);
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_halinit.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_halinit.c
index fd9353ecde0d..6741122a4ba8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_halinit.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_halinit.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _SDIO_HALINIT_C_
 
 #include <rtl8188f_hal.h>
@@ -40,8 +36,8 @@ static u8 CardEnable(PADAPTER padapter)
 	if (bMacPwrCtrlOn == _FALSE) {
 		u8 hci_sus_state;
 
-		// RSV_CTRL 0x1C[7:0] = 0x00
-		// unlock ISO/CLK/Power control register
+		/* RSV_CTRL 0x1C[7:0] = 0x00 */
+		/* unlock ISO/CLK/Power control register */
 		rtw_write8(padapter, REG_RSV_CTRL, 0x0);
 
 		hci_sus_state = HCI_SUS_LEAVING;
@@ -62,94 +58,6 @@ static u8 CardEnable(PADAPTER padapter)
 	return ret;
 }
 
-/*
- * Description:
- *	Call this function to make sure power on successfully
- *
- * Return:
- *	_SUCCESS	enable success
- *	_FAIL	enable fail
- */
-static int PowerOnCheck(PADAPTER padapter)
-{
-	u32	val_offset0, val_offset1, val_offset2, val_offset3;
-	u32 val_mix = 0;
-	u32 res = 0;
-	u8	ret = _FAIL;
-	int index = 0;
-
-	val_offset0 = rtw_read8(padapter, REG_CR);
-	val_offset1 = rtw_read8(padapter, REG_CR+1);
-	val_offset2 = rtw_read8(padapter, REG_CR+2);
-	val_offset3 = rtw_read8(padapter, REG_CR+3);
-
-	if (val_offset0 == 0xEA || val_offset1 == 0xEA ||
-			val_offset2 == 0xEA || val_offset3 ==0xEA) {
-		DBG_871X("%s: power on fail, do Power on again\n", __func__);
-		return ret;
-	}
-
-	val_mix = val_offset3 << 24 | val_mix;
-	val_mix = val_offset2 << 16 | val_mix;
-	val_mix = val_offset1 << 8 | val_mix;
-	val_mix = val_offset0 | val_mix;
-
-	res = rtw_read32(padapter, REG_CR);
-
-	DBG_871X("%s: val_mix:0x%08x, res:0x%08x\n", __func__, val_mix, res);
-
-	while(index < 100) {
-		if (res == val_mix) {
-			DBG_871X("%s: 0x100 the result of cmd52 and cmd53 is the same.\n", __func__);
-			ret = _SUCCESS;
-			break;
-		} else {
-			DBG_871X("%s: 0x100 cmd52 and cmd53 is not the same(index:%d).\n", __func__, index);
-			res = rtw_read32(padapter, REG_CR);
-			index ++;
-			ret = _FAIL;
-		}
-	}
-
-	if (ret) {
-		index = 0;
-		while(index < 100) {
-			rtw_write32(padapter, 0x1B8, 0x12345678);
-			res = rtw_read32(padapter, 0x1B8);
-			if (res == 0x12345678) {
-				DBG_871X("%s: 0x1B8 test Pass.\n", __func__);
-				ret = _SUCCESS;
-				break;
-			} else {
-				index ++;
-				DBG_871X("%s: 0x1B8 test Fail(index: %d).\n", __func__, index);
-				ret = _FAIL;
-			}
-		}
-	} else {
-		DBG_871X("%s: fail at cmd52, cmd53.\n", __func__);
-	}
-
-	if (ret == _FAIL) {
-		DBG_871X_LEVEL(_drv_err_, "Dump MAC Page0 register:\n");
-		/* Dump Page0 for check cystal*/
-		for (index = 0 ; index < 0xff ; index++) {
-			if(index%16==0)
-				printk("0x%02x ",index);
-
-			printk("%02x ", rtw_read8(padapter, index)); 
-
-			if(index%16==15)
-				printk("\n");
-			else if(index%8==7)
-				printk("\t");
-		}
-		printk("\n");
-	}
-
-	return ret;
-}
-
 static u32 _InitPowerOn_8188FS(PADAPTER padapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
@@ -158,8 +66,8 @@ static u32 _InitPowerOn_8188FS(PADAPTER padapter)
 	u16 value16;
 	u32 value32;
 	u8 ret;
-	u8 pwron_chk_cnt=0;
-//	u8 bMacPwrCtrlOn;
+	u8 pwron_chk_cnt = 0;
+	/*	u8 bMacPwrCtrlOn; */
 
 _init_power_on:
 
@@ -168,93 +76,67 @@ _init_power_on:
 		rtl8188f_set_pll_ref_clk_sel(padapter, regsty->pll_ref_clk_sel);
 
 #ifdef CONFIG_EXT_CLK
-	// Use external crystal(XTAL)
-	value8 = rtw_read8(padapter, REG_PAD_CTRL1_8188F+2);
+	/* Use external crystal(XTAL) */
+	value8 = rtw_read8(padapter, REG_PAD_CTRL1_8188F + 2);
 	value8 |=  BIT(7);
-	rtw_write8(padapter, REG_PAD_CTRL1_8188F+2, value8);
+	rtw_write8(padapter, REG_PAD_CTRL1_8188F + 2, value8);
 
-	// CLK_REQ High active or Low Active
-	// Request GPIO polarity:
-	// 0: low active
-	// 1: high active
-	value8 = rtw_read8(padapter, REG_MULTI_FUNC_CTRL+1);
+	/* CLK_REQ High active or Low Active */
+	/* Request GPIO polarity: */
+	/* 0: low active */
+	/* 1: high active */
+	value8 = rtw_read8(padapter, REG_MULTI_FUNC_CTRL + 1);
 	value8 |= BIT(5);
-	rtw_write8(padapter, REG_MULTI_FUNC_CTRL+1, value8);
-#endif // CONFIG_EXT_CLK
+	rtw_write8(padapter, REG_MULTI_FUNC_CTRL + 1, value8);
+#endif /* CONFIG_EXT_CLK */
 
-	// only cmd52 can be used before power on(card enable)
+	/* only cmd52 can be used before power on(card enable) */
 	ret = CardEnable(padapter);
 	if (ret == _FALSE) {
-		RT_TRACE(_module_hci_hal_init_c_, _drv_emerg_,
-				("%s: run power on flow fail\n", __FUNCTION__));
 		return _FAIL;
 	}
 
 	rtw_write8(padapter, REG_CR, 0x00);
-	// Enable MAC DMA/WMAC/SCHEDULE/SEC block
+	/* Enable MAC DMA/WMAC/SCHEDULE/SEC block */
 	value16 = rtw_read16(padapter, REG_CR);
 	value16 |= (HCI_TXDMA_EN | HCI_RXDMA_EN | TXDMA_EN | RXDMA_EN
-				| PROTOCOL_EN | SCHEDULE_EN | ENSEC | CALTMR_EN);
+		    | PROTOCOL_EN | SCHEDULE_EN | ENSEC | CALTMR_EN);
 	rtw_write16(padapter, REG_CR, value16);
 
 
-	//PowerOnCheck()
-	ret = PowerOnCheck(padapter);
-	pwron_chk_cnt++;	
-	if (_FAIL == ret ) {	
+	/* PowerOnCheck() */
+	ret = sdio_power_on_check(padapter);
+	pwron_chk_cnt++;
+	if (_FAIL == ret) {
 		if (pwron_chk_cnt > 1) {
-			DBG_871X("Failed to init Power On!\n");
+			RTW_INFO("Failed to init Power On!\n");
 			return _FAIL;
 		}
-		DBG_871X("Power on Fail! do it again\n");
+		RTW_INFO("Power on Fail! do it again\n");
 		goto _init_power_on;
 	}
 
-#ifdef CONFIG_BT_COEXIST
-	rtw_btcoex_PowerOnSetting(padapter);
-
-	// external switch to S1
-	// 0x38[11] = 0x1
-	// 0x4c[23] = 0x1
-	// 0x64[0] = 0
-	value16 = rtw_read16(padapter, REG_PWR_DATA);
-	// Switch the control of EESK, EECS to RFC for DPDT or Antenna switch
-	value16 |= BIT(11); // BIT_EEPRPAD_RFE_CTRL_EN
-	rtw_write16(padapter, REG_PWR_DATA, value16);
-//	DBG_8192C("%s: REG_PWR_DATA(0x%x)=0x%04X\n", __FUNCTION__, REG_PWR_DATA, rtw_read16(padapter, REG_PWR_DATA));
-
-	value32 = rtw_read32(padapter, REG_LEDCFG0);
-	value32 |= BIT(23); // DPDT_SEL_EN, 1 for SW control
-	rtw_write32(padapter, REG_LEDCFG0, value32);
-//	DBG_8192C("%s: REG_LEDCFG0(0x%x)=0x%08X\n", __FUNCTION__, REG_LEDCFG0, rtw_read32(padapter, REG_LEDCFG0));
-
-	value8 = rtw_read8(padapter, REG_PAD_CTRL1_8188F);
-	value8 &= ~BIT(0); // BIT_SW_DPDT_SEL_DATA, DPDT_SEL default configuration
-	rtw_write8(padapter, REG_PAD_CTRL1_8188F, value8);
-//	DBG_8192C("%s: REG_PAD_CTRL1(0x%x)=0x%02X\n", __FUNCTION__, REG_PAD_CTRL1_8188F, rtw_read8(padapter, REG_PAD_CTRL1_8188F));
-#endif // CONFIG_BT_COEXIST
-
 	return _SUCCESS;
 }
 
-//Tx Page FIFO threshold
+/* Tx Page FIFO threshold */
 static void _init_available_page_threshold(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ)
 {
 	u16	HQ_threshold, NQ_threshold, LQ_threshold;
 
 	HQ_threshold = (numPubQ + numHQ + 1) >> 1;
-	HQ_threshold |= (HQ_threshold<<8);
+	HQ_threshold |= (HQ_threshold << 8);
 
 	NQ_threshold = (numPubQ + numNQ + 1) >> 1;
-	NQ_threshold |= (NQ_threshold<<8);
+	NQ_threshold |= (NQ_threshold << 8);
 
 	LQ_threshold = (numPubQ + numLQ + 1) >> 1;
-	LQ_threshold |= (LQ_threshold<<8);
+	LQ_threshold |= (LQ_threshold << 8);
 
 	rtw_write16(padapter, 0x218, HQ_threshold);
 	rtw_write16(padapter, 0x21A, NQ_threshold);
 	rtw_write16(padapter, 0x21C, LQ_threshold);
-	DBG_8192C("%s(): Enable Tx FIFO Page Threshold H:0x%x,N:0x%x,L:0x%x\n", __FUNCTION__, HQ_threshold, NQ_threshold, LQ_threshold);
+	RTW_INFO("%s(): Enable Tx FIFO Page Threshold H:0x%x,N:0x%x,L:0x%x\n", __FUNCTION__, HQ_threshold, NQ_threshold, LQ_threshold);
 }
 
 static void _InitQueueReservedPage(PADAPTER padapter)
@@ -271,26 +153,21 @@ static void _InitQueueReservedPage(PADAPTER padapter)
 	BOOLEAN			bWiFiConfig	= pregistrypriv->wifi_spec;
 
 	if (pHalData->OutEpQueueSel & TX_SELE_HQ)
-	{
 		numHQ = bWiFiConfig ? WMM_NORMAL_PAGE_NUM_HPQ_8188F : NORMAL_PAGE_NUM_HPQ_8188F;
-	}
 
 	if (pHalData->OutEpQueueSel & TX_SELE_LQ)
-	{
 		numLQ = bWiFiConfig ? WMM_NORMAL_PAGE_NUM_LPQ_8188F : NORMAL_PAGE_NUM_LPQ_8188F;
-	}
 
-	// NOTE: This step shall be proceed before writting REG_RQPN.
-	if (pHalData->OutEpQueueSel & TX_SELE_NQ) {
+	/* NOTE: This step shall be proceed before writting REG_RQPN. */
+	if (pHalData->OutEpQueueSel & TX_SELE_NQ)
 		numNQ = bWiFiConfig ? WMM_NORMAL_PAGE_NUM_NPQ_8188F : NORMAL_PAGE_NUM_NPQ_8188F;
-	}
 
 	numPubQ = TX_TOTAL_PAGE_NUMBER_8188F - numHQ - numLQ - numNQ;
 
 	value8 = (u8)_NPQ(numNQ);
 	rtw_write8(padapter, REG_RQPN_NPQ, value8);
 
-	// TX DMA
+	/* TX DMA */
 	value32 = _HPQ(numHQ) | _LPQ(numLQ) | _PUBQ(numPubQ) | LD_RQPN;
 	rtw_write32(padapter, REG_RQPN, value32);
 
@@ -306,15 +183,15 @@ static void _InitTxBufferBoundary(PADAPTER padapter)
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 #ifdef CONFIG_CONCURRENT_MODE
 	u8 val8;
-#endif // CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_CONCURRENT_MODE */
 
-	//u16	txdmactrl;
+	/* u16	txdmactrl; */
 	u8	txpktbuf_bndy;
 
-	if (!pregistrypriv->wifi_spec) {
+	if (!pregistrypriv->wifi_spec)
 		txpktbuf_bndy = TX_PAGE_BOUNDARY_8188F;
-	} else {
-		//for WMM
+	else {
+		/* for WMM */
 		txpktbuf_bndy = WMM_NORMAL_TX_PAGE_BOUNDARY_8188F;
 	}
 
@@ -322,17 +199,17 @@ static void _InitTxBufferBoundary(PADAPTER padapter)
 	rtw_write8(padapter, REG_TXPKTBUF_MGQ_BDNY_8188F, txpktbuf_bndy);
 	rtw_write8(padapter, REG_TXPKTBUF_WMAC_LBK_BF_HD_8188F, txpktbuf_bndy);
 	rtw_write8(padapter, REG_TRXFF_BNDY, txpktbuf_bndy);
-	rtw_write8(padapter, REG_TDECTRL+1, txpktbuf_bndy);
+	rtw_write8(padapter, REG_TDECTRL + 1, txpktbuf_bndy);
 
 #ifdef CONFIG_CONCURRENT_MODE
 	val8 = txpktbuf_bndy + BCNQ_PAGE_NUM_8188F + WOWLAN_PAGE_NUM_8188F;
 	rtw_write8(padapter, REG_BCNQ1_BDNY, val8);
-	rtw_write8(padapter, REG_DWBCN1_CTRL_8188F+1, val8); // BCN1_HEAD
+	rtw_write8(padapter, REG_DWBCN1_CTRL_8188F + 1, val8); /* BCN1_HEAD */
 
-	val8 = rtw_read8(padapter, REG_DWBCN1_CTRL_8188F+2);
-	val8 |= BIT(1); // BIT1- BIT_SW_BCN_SEL_EN
-	rtw_write8(padapter, REG_DWBCN1_CTRL_8188F+2, val8);
-#endif // CONFIG_CONCURRENT_MODE
+	val8 = rtw_read8(padapter, REG_DWBCN1_CTRL_8188F + 2);
+	val8 |= BIT(1); /* BIT1- BIT_SW_BCN_SEL_EN */
+	rtw_write8(padapter, REG_DWBCN1_CTRL_8188F + 2, val8);
+#endif /* CONFIG_CONCURRENT_MODE */
 }
 
 static VOID
@@ -344,13 +221,13 @@ _InitNormalChipRegPriority(
 	IN	u16		voQ,
 	IN	u16		mgtQ,
 	IN	u16		hiQ
-	)
+)
 {
 	u16 value16		= (rtw_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);
+	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);
 
 	rtw_write16(Adapter, REG_TRXDMA_CTRL, value16);
 }
@@ -358,79 +235,76 @@ _InitNormalChipRegPriority(
 static VOID
 _InitNormalChipOneOutEpPriority(
 	IN	PADAPTER Adapter
-	)
+)
 {
 	HAL_DATA_TYPE	*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;
+	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
-								);
+				   value,
+				   value,
+				   value,
+				   value,
+				   value,
+				   value
+				  );
 
 }
 
 static VOID
 _InitNormalChipTwoOutEpPriority(
 	IN	PADAPTER Adapter
-	)
+)
 {
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(Adapter);
 	struct registry_priv *pregistrypriv = &Adapter->registrypriv;
-	u16			beQ,bkQ,viQ,voQ,mgtQ,hiQ;
+	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;
+	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 ){
+	if (!pregistrypriv->wifi_spec) {
 		beQ		= valueLow;
 		bkQ		= valueLow;
 		viQ		= valueHi;
 		voQ		= valueHi;
 		mgtQ	= valueHi;
 		hiQ		= valueHi;
-	}
-	else{//for WMM ,CONFIG_OUT_EP_WIFI_MODE
+	} else { /* for WMM ,CONFIG_OUT_EP_WIFI_MODE */
 		beQ		= valueLow;
 		bkQ		= valueHi;
 		viQ		= valueHi;
@@ -439,58 +313,56 @@ _InitNormalChipTwoOutEpPriority(
 		hiQ		= valueHi;
 	}
 
-	_InitNormalChipRegPriority(Adapter,beQ,bkQ,viQ,voQ,mgtQ,hiQ);
+	_InitNormalChipRegPriority(Adapter, beQ, bkQ, viQ, voQ, mgtQ, hiQ);
 
 }
 
 static VOID
 _InitNormalChipThreeOutEpPriority(
 	IN	PADAPTER padapter
-	)
+)
 {
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	u16			beQ, bkQ, viQ, voQ, mgtQ, hiQ;
 
-	if (!pregistrypriv->wifi_spec){// typical setting
+	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
+		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;
+		bkQ		= QUEUE_NORMAL;
+		viQ		= QUEUE_NORMAL;
+		voQ		= QUEUE_HIGH;
+		mgtQ	= QUEUE_HIGH;
+		hiQ		= QUEUE_HIGH;
 	}
-	_InitNormalChipRegPriority(padapter,beQ,bkQ,viQ,voQ,mgtQ,hiQ);
+	_InitNormalChipRegPriority(padapter, beQ, bkQ, viQ, voQ, mgtQ, hiQ);
 }
 
 static VOID
 _InitNormalChipQueuePriority(
 	IN	PADAPTER Adapter
-	)
+)
 {
 	HAL_DATA_TYPE	*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;
+	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;
 	}
 
 
@@ -503,7 +375,7 @@ static void _InitQueuePriority(PADAPTER padapter)
 
 static void _InitPageBoundary(PADAPTER padapter)
 {
-	// RX Page Boundary
+	/* RX Page Boundary */
 	u16 rxff_bndy = RX_DMA_BOUNDARY_8188F;
 
 	rtw_write16(padapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
@@ -511,7 +383,7 @@ static void _InitPageBoundary(PADAPTER padapter)
 
 static void _InitTransferPageSize(PADAPTER padapter)
 {
-	// Tx page size is always 128.
+	/* Tx page size is always 128. */
 
 	u8 value8;
 	value8 = _PSRX(PBP_128) | _PSTX(PBP_128);
@@ -529,8 +401,8 @@ void _InitNetworkType(PADAPTER padapter)
 
 	value32 = rtw_read32(padapter, REG_CR);
 
-	// TODO: use the other function to set network type
-//	value32 = (value32 & ~MASK_NETTYPE) | _NETTYPE(NT_LINK_AD_HOC);
+	/* TODO: use the other function to set network type
+	*	value32 = (value32 & ~MASK_NETTYPE) | _NETTYPE(NT_LINK_AD_HOC); */
 	value32 = (value32 & ~MASK_NETTYPE) | _NETTYPE(NT_LINK_AP);
 
 	rtw_write32(padapter, REG_CR, value32);
@@ -540,36 +412,37 @@ void _InitWMACSetting(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
 	u16 value16;
-
+	u32 rcr;
 
 	pHalData = GET_HAL_DATA(padapter);
 
-	pHalData->ReceiveConfig = 0;
-	pHalData->ReceiveConfig |= RCR_APM | RCR_AM | RCR_AB;
-	pHalData->ReceiveConfig |= RCR_CBSSID_DATA | RCR_CBSSID_BCN | RCR_AMF;
-	pHalData->ReceiveConfig |= RCR_HTC_LOC_CTRL;
-	pHalData->ReceiveConfig |= RCR_APP_PHYST_RXFF | RCR_APP_ICV | RCR_APP_MIC;
-#ifdef CONFIG_MAC_LOOPBACK_DRIVER
-	pHalData->ReceiveConfig |= RCR_AAP;
-	pHalData->ReceiveConfig |= RCR_ADD3 | RCR_APWRMGT | RCR_ACRC32 | RCR_ADF;
-#endif
-	rtw_write32(padapter, REG_RCR, pHalData->ReceiveConfig);
+	rcr = 0
+		| RCR_APM | RCR_AM | RCR_AB
+		| RCR_CBSSID_DATA | RCR_CBSSID_BCN | RCR_AMF
+		| RCR_HTC_LOC_CTRL
+		| RCR_APP_PHYST_RXFF | RCR_APP_ICV | RCR_APP_MIC
+		#ifdef CONFIG_MAC_LOOPBACK_DRIVER
+		| RCR_AAP
+		| RCR_ADD3 | RCR_APWRMGT | RCR_ACRC32 | RCR_ADF
+		#endif
+		;
+	rtw_hal_set_hwreg(padapter, HW_VAR_RCR, (u8 *)&rcr);
 
-	// Accept all multicast address
+	/* Accept all multicast address */
 	rtw_write32(padapter, REG_MAR, 0xFFFFFFFF);
 	rtw_write32(padapter, REG_MAR + 4, 0xFFFFFFFF);
 
-	// Accept all data frames
+	/* Accept all data frames */
 	value16 = 0xFFFF;
 	rtw_write16(padapter, 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 gurantee AP mode can rx ps-poll.
+	/* 2010.09.08 hpfan */
+	/* Since ADF is removed from RCR, ps-poll will not be indicate to driver, */
+	/* RxFilterMap should mask ps-poll to gurantee AP mode can rx ps-poll. */
 	value16 = 0x400;
 	rtw_write16(padapter, REG_RXFLTMAP1, value16);
 
-	// Accept all management frames
+	/* Accept all management frames */
 	value16 = 0xFFFF;
 	rtw_write16(padapter, REG_RXFLTMAP0, value16);
 }
@@ -579,37 +452,37 @@ void _InitAdaptiveCtrl(PADAPTER padapter)
 	u16	value16;
 	u32	value32;
 
-	// Response Rate Set
+	/* Response Rate Set */
 	value32 = rtw_read32(padapter, REG_RRSR);
 	value32 &= ~RATE_BITMAP_ALL;
 	value32 |= RATE_RRSR_CCK_ONLY_1M;
 	rtw_write32(padapter, REG_RRSR, value32);
 
-	// CF-END Threshold
-	//m_spIoBase->rtw_write8(REG_CFEND_TH, 0x1);
+	/* CF-END Threshold */
+	/* m_spIoBase->rtw_write8(REG_CFEND_TH, 0x1); */
 
-	// SIFS (used in NAV)
+	/* SIFS (used in NAV) */
 	value16 = _SPEC_SIFS_CCK(0x10) | _SPEC_SIFS_OFDM(0x10);
 	rtw_write16(padapter, REG_SPEC_SIFS, value16);
 
-	// Retry Limit
-	value16 = _LRL(0x30) | _SRL(0x30);
+	/* Retry Limit */
+	value16 = _LRL(RL_VAL_STA) | _SRL(RL_VAL_STA);
 	rtw_write16(padapter, REG_RL, value16);
 }
 
 void _InitEDCA(PADAPTER padapter)
 {
-	// Set Spec SIFS (used in NAV)
+	/* Set Spec SIFS (used in NAV) */
 	rtw_write16(padapter, REG_SPEC_SIFS, 0x100a);
 	rtw_write16(padapter, REG_MAC_SPEC_SIFS, 0x100a);
 
-	// Set SIFS for CCK
+	/* Set SIFS for CCK */
 	rtw_write16(padapter, REG_SIFS_CTX, 0x100a);
 
-	// Set SIFS for OFDM
+	/* Set SIFS for OFDM */
 	rtw_write16(padapter, REG_SIFS_TRX, 0x100a);
 
-	// TXOP
+	/* TXOP */
 	rtw_write32(padapter, REG_EDCA_BE_PARAM, 0x005EA42B);
 	rtw_write32(padapter, REG_EDCA_BK_PARAM, 0x0000A44F);
 	rtw_write32(padapter, REG_EDCA_VI_PARAM, 0x005EA324);
@@ -619,16 +492,6 @@ void _InitEDCA(PADAPTER padapter)
 	rtw_write8(padapter, REG_USTIME_TSF_8188F, 0x28);
 }
 
-void _InitRateFallback(PADAPTER padapter)
-{
-	// Set Data Auto Rate Fallback Retry Count register.
-	rtw_write32(padapter, REG_DARFRC, 0x00000000);
-	rtw_write32(padapter, REG_DARFRC+4, 0x10080404);
-	rtw_write32(padapter, REG_RARFRC, 0x04030201);
-	rtw_write32(padapter, REG_RARFRC+4, 0x08070605);
-
-}
-
 void _InitRetryFunction(PADAPTER padapter)
 {
 	u8	value8;
@@ -637,7 +500,7 @@ void _InitRetryFunction(PADAPTER padapter)
 	value8 |= EN_AMPDU_RTY_NEW;
 	rtw_write8(padapter, REG_FWHW_TXQ_CTRL, value8);
 
-	// Set ACK timeout
+	/* Set ACK timeout */
 	rtw_write8(padapter, REG_ACKTO, 0x40);
 }
 
@@ -650,8 +513,8 @@ static void HalRxAggr8188FSdio(PADAPTER padapter)
 	dma_len_th = 0x0f;
 
 	if (dma_len_th * 1024 > MAX_RECVBUF_SZ) {
-		DBG_871X_LEVEL(_drv_always_, "Reduce RXDMA_AGG_LEN_TH from %u to %u\n"
-			, dma_len_th, MAX_RECVBUF_SZ / 1024);
+		RTW_PRINT("Reduce RXDMA_AGG_LEN_TH from %u to %u\n"
+			  , dma_len_th, MAX_RECVBUF_SZ / 1024);
 		dma_len_th = MAX_RECVBUF_SZ / 1024;
 	}
 
@@ -663,8 +526,8 @@ void sdio_AggSettingRxUpdate(PADAPTER padapter)
 	HAL_DATA_TYPE *pHalData;
 	u8 valueDMA;
 	u8 valueRxAggCtrl = 0;
-	u8 aggBurstNum = 3;  //0:1, 1:2, 2:3, 3:4
-	u8 aggBurstSize = 0;  //0:1K, 1:512Byte, 2:256Byte...
+	u8 aggBurstNum = 3;  /* 0:1, 1:2, 2:3, 3:4 */
+	u8 aggBurstSize = 0;  /* 0:1K, 1:512Byte, 2:256Byte... */
 
 	pHalData = GET_HAL_DATA(padapter);
 
@@ -673,19 +536,19 @@ void sdio_AggSettingRxUpdate(PADAPTER padapter)
 	rtw_write8(padapter, REG_TRXDMA_CTRL, valueDMA);
 
 	valueRxAggCtrl |= RXDMA_AGG_MODE_EN;
-	valueRxAggCtrl |= ((aggBurstNum<<2) & 0x0C);
-	valueRxAggCtrl |= ((aggBurstSize<<4) & 0x30);  
-	rtw_write8(padapter, REG_RXDMA_MODE_CTRL_8188F, valueRxAggCtrl);//RxAggLowThresh = 4*1K
+	valueRxAggCtrl |= ((aggBurstNum << 2) & 0x0C);
+	valueRxAggCtrl |= ((aggBurstSize << 4) & 0x30);
+	rtw_write8(padapter, REG_RXDMA_MODE_CTRL_8188F, valueRxAggCtrl);/* RxAggLowThresh = 4*1K */
 }
 
 void _initSdioAggregationSetting(PADAPTER padapter)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
-	// Tx aggregation setting
-//	sdio_AggSettingTxUpdate(padapter);
+	/* Tx aggregation setting
+	*	sdio_AggSettingTxUpdate(padapter); */
 
-	// Rx aggregation setting
+	/* Rx aggregation setting */
 	HalRxAggr8188FSdio(padapter);
 
 	sdio_AggSettingRxUpdate(padapter);
@@ -703,13 +566,10 @@ static void _RXAggrSwitch(PADAPTER padapter, u8 enable)
 	valueDMA = rtw_read8(padapter, REG_TRXDMA_CTRL);
 	valueRxAggCtrl = rtw_read8(padapter, REG_RXDMA_MODE_CTRL_8188F);
 
-	if (_TRUE == enable)
-	{
+	if (_TRUE == enable) {
 		valueDMA |= RXDMA_AGG_EN;
 		valueRxAggCtrl |= RXDMA_AGG_MODE_EN;
-	}
-	else
-	{
+	} else {
 		valueDMA &= ~RXDMA_AGG_EN;
 		valueRxAggCtrl &= ~RXDMA_AGG_MODE_EN;
 	}
@@ -718,92 +578,16 @@ static void _RXAggrSwitch(PADAPTER padapter, u8 enable)
 	rtw_write8(padapter, REG_RXDMA_MODE_CTRL_8188F, valueRxAggCtrl);
 }
 
-void _InitOperationMode(PADAPTER padapter)
-{
-	PHAL_DATA_TYPE pHalData;
-	struct mlme_ext_priv *pmlmeext;
-	u8				regBwOpMode = 0;
-	u32				regRATR = 0, regRRSR = 0;
-	u8				MinSpaceCfg = 0;
-
-
-	pHalData = GET_HAL_DATA(padapter);
-	pmlmeext = &padapter->mlmeextpriv;
-
-	//1 This part need to modified according to the rate set we filtered!!
-	//
-	// Set RRSR, RATR, and REG_BWOPMODE registers
-	//
-	switch(pmlmeext->cur_wireless_mode)
-	{
-		case WIRELESS_MODE_B:
-			regBwOpMode = BW_OPMODE_20MHZ;
-			regRATR = RATE_ALL_CCK;
-			regRRSR = RATE_ALL_CCK;
-			break;
-		case WIRELESS_MODE_A:
-//			RT_ASSERT(FALSE,("Error wireless a mode\n"));
-#if 0
-			regBwOpMode = BW_OPMODE_5G |BW_OPMODE_20MHZ;
-			regRATR = RATE_ALL_OFDM_AG;
-			regRRSR = RATE_ALL_OFDM_AG;
-#endif
-			break;
-		case WIRELESS_MODE_G:
-			regBwOpMode = BW_OPMODE_20MHZ;
-			regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
-			regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
-			break;
-		case WIRELESS_MODE_AUTO:
-#if 0
-			if (padapter->bInHctTest)
-			{
-				regBwOpMode = BW_OPMODE_20MHZ;
-				regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
-				regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
-			}
-			else
-#endif
-			{
-				regBwOpMode = BW_OPMODE_20MHZ;
-				regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG | RATE_ALL_OFDM_1SS | RATE_ALL_OFDM_2SS;
-				regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
-			}
-			break;
-		case WIRELESS_MODE_N_24G:
-			// It support CCK rate by default.
-			// CCK rate will be filtered out only when associated AP does not support it.
-			regBwOpMode = BW_OPMODE_20MHZ;
-			regRATR = RATE_ALL_CCK | RATE_ALL_OFDM_AG | RATE_ALL_OFDM_1SS | RATE_ALL_OFDM_2SS;
-			regRRSR = RATE_ALL_CCK | RATE_ALL_OFDM_AG;
-			break;
-		case WIRELESS_MODE_N_5G:
-//			RT_ASSERT(FALSE,("Error wireless mode"));
-#if 0
-			regBwOpMode = BW_OPMODE_5G;
-			regRATR = RATE_ALL_OFDM_AG | RATE_ALL_OFDM_1SS | RATE_ALL_OFDM_2SS;
-			regRRSR = RATE_ALL_OFDM_AG;
-#endif
-			break;
-
-		default: //for MacOSX compiler warning.
-			break;
-	}
-
-	rtw_write8(padapter, REG_BWOPMODE, regBwOpMode);
-
-}
-
 void _InitInterrupt(PADAPTER padapter)
 {
-	//
-	// Initialize and enable SDIO Host Interrupt.
-	//
+	/*  */
+	/* Initialize and enable SDIO Host Interrupt. */
+	/*  */
 	InitInterrupt8188FSdio(padapter);
 
-	//
-	// Initialize system Host Interrupt.
-	//
+	/*  */
+	/* Initialize system Host Interrupt. */
+	/*  */
 	InitSysInterrupt8188FSdio(padapter);
 }
 
@@ -825,12 +609,12 @@ static void _InitRFType(PADAPTER padapter)
 #endif
 	pHalData->rf_chip	= RF_6052;
 
-	MSG_8192C("Set RF Chip ID to RF_6052 and RF type to %d.\n", pHalData->rf_type);
+	RTW_INFO("Set RF Chip ID to RF_6052 and RF type to %d.\n", pHalData->rf_type);
 }
 
 static void _RfPowerSave(PADAPTER padapter)
 {
-//YJ,TODO
+	/* YJ,TODO */
 }
 
 static void _InitAntenna_Selection(PADAPTER padapter)
@@ -843,23 +627,19 @@ static void _InitPABias(PADAPTER padapter)
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
 	u8			pa_setting;
 
-	//FIXED PA current issue
-	//efuse_one_byte_read(padapter, 0x1FA, &pa_setting);
-	pa_setting = EFUSE_Read1Byte(padapter, 0x1FA);
+	/* FIXED PA current issue */
+	/* efuse_one_byte_read(padapter, 0x1FA, &pa_setting); */
+	efuse_OneByteRead(padapter, 0x1FA, &pa_setting, _FALSE);
 
-	//RT_TRACE(COMP_INIT, DBG_LOUD, ("_InitPABias 0x1FA 0x%x \n",pa_setting));
 
-	if(!(pa_setting & BIT0))
-	{
-		PHY_SetRFReg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0x0F406);
-		PHY_SetRFReg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0x4F406);
-		PHY_SetRFReg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0x8F406);
-		PHY_SetRFReg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0xCF406);
-		//RT_TRACE(COMP_INIT, DBG_LOUD, ("PA BIAS path A\n"));
+	if (!(pa_setting & BIT0)) {
+		phy_set_rf_reg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0x0F406);
+		phy_set_rf_reg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0x4F406);
+		phy_set_rf_reg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0x8F406);
+		phy_set_rf_reg(padapter, RF_PATH_A, 0x15, 0x0FFFFF, 0xCF406);
 	}
 
-	if(!(pa_setting & BIT4))
-	{
+	if (!(pa_setting & BIT4)) {
 		pa_setting = rtw_read8(padapter, 0x16);
 		pa_setting &= 0x0F;
 		rtw_write8(padapter, 0x16, pa_setting | 0x80);
@@ -867,9 +647,9 @@ static void _InitPABias(PADAPTER padapter)
 	}
 }
 
-//
-// 2010/08/09 MH Add for power down check.
-//
+/*
+ * 2010/08/09 MH Add for power down check.
+ *   */
 static BOOLEAN HalDetectPwrDownMode(PADAPTER Adapter)
 {
 	u8 tmpvalue;
@@ -879,20 +659,16 @@ static BOOLEAN HalDetectPwrDownMode(PADAPTER Adapter)
 
 	EFUSE_ShadowRead(Adapter, 1, 0x7B/*EEPROM_RF_OPT3_92C*/, (u32 *)&tmpvalue);
 
-	// 2010/08/25 MH INF priority > PDN Efuse value.
-	if(tmpvalue & BIT4 && pwrctrlpriv->reg_pdnmode)
-	{
+	/* 2010/08/25 MH INF priority > PDN Efuse value. */
+	if (tmpvalue & BIT4 && pwrctrlpriv->reg_pdnmode)
 		pHalData->pwrdown = _TRUE;
-	}
 	else
-	{
 		pHalData->pwrdown = _FALSE;
-	}
 
-	DBG_8192C("HalDetectPwrDownMode(): PDN=%d\n", pHalData->pwrdown);
+	RTW_INFO("HalDetectPwrDownMode(): PDN=%d\n", pHalData->pwrdown);
 
 	return pHalData->pwrdown;
-}	// HalDetectPwrDownMode
+}	/* HalDetectPwrDownMode */
 
 static u32 rtl8188fs_hal_init(PADAPTER padapter)
 {
@@ -917,26 +693,25 @@ static u32 rtl8188fs_hal_init(PADAPTER padapter)
 	pregistrypriv = &padapter->registrypriv;
 
 #ifdef CONFIG_SWLPS_IN_IPS
-	if (adapter_to_pwrctl(padapter)->bips_processing == _TRUE)
-	{
+	if (adapter_to_pwrctl(padapter)->bips_processing == _TRUE) {
 		u8 val8, bMacPwrCtrlOn = _TRUE;
 
-		DBG_871X("%s: run LPS flow in IPS\n", __FUNCTION__);
+		RTW_INFO("%s: run LPS flow in IPS\n", __FUNCTION__);
 
-		//ser rpwm
-		val8 = rtw_read8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1);
+		/* ser rpwm */
+		val8 = rtw_read8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1);
 		val8 &= 0x80;
-		val8 += 0x80;	
-		val8 |= BIT(6);		
-		rtw_write8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1, val8);
-		
+		val8 += 0x80;
+		val8 |= BIT(6);
+		rtw_write8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1, val8);
+
 		adapter_to_pwrctl(padapter)->tog = (val8 + 0x80) & 0x80;
-		
-		rtw_mdelay_os(5); //wait set rpwm already
-		
+
+		rtw_mdelay_os(5); /* wait set rpwm already */
+
 		ret = HalPwrSeqCmdParsing(padapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, rtl8188F_leave_swlps_flow);
 		if (ret == _FALSE) {
-			DBG_8192C("%s: run LPS flow in IPS fail!\n", __FUNCTION__);
+			RTW_INFO("%s: run LPS flow in IPS fail!\n", __FUNCTION__);
 			return _FAIL;
 		}
 
@@ -949,94 +724,85 @@ static u32 rtl8188fs_hal_init(PADAPTER padapter)
 	}
 #elif defined(CONFIG_FWLPS_IN_IPS)
 	if (adapter_to_pwrctl(padapter)->bips_processing == _TRUE && psrtpriv->silent_reset_inprogress == _FALSE
-		&& adapter_to_pwrctl(padapter)->pre_ips_type == 0)
-	{
-		u32 start_time;
+	    && adapter_to_pwrctl(padapter)->pre_ips_type == 0) {
+		systime start_time;
 		u8 cpwm_orig, cpwm_now;
 		u8 val8, bMacPwrCtrlOn = _TRUE;
 
-		DBG_871X("%s: Leaving IPS in FWLPS state\n", __FUNCTION__);
+		RTW_INFO("%s: Leaving IPS in FWLPS state\n", __FUNCTION__);
 
-		//for polling cpwm
+		/* for polling cpwm */
 		cpwm_orig = 0;
 		rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_orig);
 
-		//ser rpwm
-		val8 = rtw_read8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1);
+		/* ser rpwm */
+		val8 = rtw_read8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1);
 		val8 &= 0x80;
-		val8 += 0x80;	
-		val8 |= BIT(6);		
-		rtw_write8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1, val8);
-		DBG_871X("%s: write rpwm=%02x\n", __FUNCTION__, val8);
+		val8 += 0x80;
+		val8 |= BIT(6);
+		rtw_write8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1, val8);
+		RTW_INFO("%s: write rpwm=%02x\n", __FUNCTION__, val8);
 		adapter_to_pwrctl(padapter)->tog = (val8 + 0x80) & 0x80;
 
-		//do polling cpwm
-		start_time = rtw_get_current_time();		
+		/* do polling cpwm */
+		start_time = rtw_get_current_time();
 		do {
 
 			rtw_mdelay_os(1);
-			
+
 			rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_now);
-			if ((cpwm_orig ^ cpwm_now) & 0x80)
-			{		
-#ifdef DBG_CHECK_FW_PS_STATE				
-				DBG_871X("%s: polling cpwm ok when leaving IPS in FWLPS state, cpwm_orig=%02x, cpwm_now=%02x, 0x100=0x%x \n"
-				, __FUNCTION__, cpwm_orig, cpwm_now, rtw_read8(padapter, REG_CR));
-#endif //DBG_CHECK_FW_PS_STATE
+			if ((cpwm_orig ^ cpwm_now) & 0x80) {
+#ifdef DBG_CHECK_FW_PS_STATE
+				RTW_INFO("%s: polling cpwm ok when leaving IPS in FWLPS state, cpwm_orig=%02x, cpwm_now=%02x, 0x100=0x%x\n"
+					, __FUNCTION__, cpwm_orig, cpwm_now, rtw_read8(padapter, REG_CR));
+#endif /* DBG_CHECK_FW_PS_STATE */
 				break;
 			}
 
-			if (rtw_get_passing_time_ms(start_time) > 100)
-			{
-				DBG_871X("%s: polling cpwm timeout when leaving IPS in FWLPS state\n", __FUNCTION__);
+			if (rtw_get_passing_time_ms(start_time) > 100) {
+				RTW_INFO("%s: polling cpwm timeout when leaving IPS in FWLPS state\n", __FUNCTION__);
 				break;
-			}			
+			}
 		} while (1);
 
 		rtl8188f_set_FwPwrModeInIPS_cmd(padapter, 0);
 
-		rtw_hal_set_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);		
+		rtw_hal_set_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
 
 
 #ifdef DBG_CHECK_FW_PS_STATE
-		if(rtw_fw_ps_state(padapter) == _FAIL)
-		{
-			DBG_871X("after hal init, fw ps state in 32k\n");
+		if (rtw_fw_ps_state(padapter) == _FAIL) {
+			RTW_INFO("after hal init, fw ps state in 32k\n");
 			pdbgpriv->dbg_ips_drvopen_fail_cnt++;
 		}
-#endif //DBG_CHECK_FW_PS_STATE
+#endif /* DBG_CHECK_FW_PS_STATE */
 		return _SUCCESS;
-	}	
-#endif //CONFIG_SWLPS_IN_IPS
+	}
+#endif /* CONFIG_SWLPS_IN_IPS */
 
-	// Disable Interrupt first.
-//	rtw_hal_disable_interrupt(padapter);
+	/* Disable Interrupt first.
+	*	rtw_hal_disable_interrupt(padapter); */
 
-	if(rtw_read8(padapter, REG_MCUFWDL) == 0xc6) {
-		DBG_871X("FW exist before power on!!\n");
-	} else {
-		DBG_871X("FW does not exist before power on!!\n");
-	}
+	if (rtw_read8(padapter, REG_MCUFWDL) == 0xc6)
+		RTW_INFO("FW exist before power on!!\n");
+	else
+		RTW_INFO("FW does not exist before power on!!\n");
 
-	if(rtw_fw_ps_state(padapter) == _FAIL)
-	{
-		DBG_871X("check fw_ps_state fail before PowerOn!\n");
+	if (rtw_fw_ps_state(padapter) == _FAIL) {
+		RTW_INFO("check fw_ps_state fail before PowerOn!\n");
 		pdbgpriv->dbg_ips_drvopen_fail_cnt++;
 	}
-	
+
 	ret = rtw_hal_power_on(padapter);
 	if (_FAIL == ret) {
-		RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("Failed to init Power On!\n"));
 		return _FAIL;
 	}
-	DBG_871X("Power on ok!\n");
-	
-	if(rtw_fw_ps_state(padapter) == _FAIL)
-	{
-		DBG_871X("check fw_ps_state fail after PowerOn!\n");
+	RTW_INFO("Power on ok!\n");
+
+	if (rtw_fw_ps_state(padapter) == _FAIL) {
+		RTW_INFO("check fw_ps_state fail after PowerOn!\n");
 		pdbgpriv->dbg_ips_drvopen_fail_cnt++;
-	}	
-	
+	}
 
 	rtw_write8(padapter, REG_EARLY_MODE_CONTROL, 0);
 
@@ -1044,126 +810,116 @@ static u32 rtl8188fs_hal_init(PADAPTER padapter)
 		#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
 		|| padapter->registrypriv.mp_customer_str
 		#endif
-	) {
+	){
 		ret = rtl8188f_FirmwareDownload(padapter, _FALSE);
 		if (ret != _SUCCESS) {
-			RT_TRACE(_module_hci_hal_init_c_, _drv_err_, ("%s: Download Firmware failed!!\n", __FUNCTION__));
-			padapter->bFWReady = _FALSE;
+			pHalData->bFWReady = _FALSE;
 			pHalData->fw_ractrl = _FALSE;
 			return ret;
 		} else {
-			RT_TRACE(_module_hci_hal_init_c_, _drv_notice_, ("rtl8188fs_hal_init(): Download Firmware Success!!\n"));
-			padapter->bFWReady = _TRUE;
+			pHalData->bFWReady = _TRUE;
 			pHalData->fw_ractrl = _TRUE;
 		}
 	}
 
-//	SIC_Init(padapter);
+	/*	SIC_Init(padapter); */
 
-	if (pwrctrlpriv->reg_rfoff == _TRUE) {
+	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.
+	/* 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(padapter);
 
-	// Set RF type for BB/RF configuration
+	/* Set RF type for BB/RF configuration */
 	_InitRFType(padapter);
 
-	// Save target channel
-	// <Roger_Notes> Current Channel will be updated again later.
-	pHalData->CurrentChannel = 6;
+	/* Save target channel */
+	/* <Roger_Notes> Current Channel will be updated again later. */
+	pHalData->current_channel = 6;
 
 #if (HAL_MAC_ENABLE == 1)
 	ret = PHY_MACConfig8188F(padapter);
-	if(ret != _SUCCESS){
-		RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("Initializepadapter8192CSdio(): Fail to configure MAC!!\n"));
+	if (ret != _SUCCESS) {
 		return ret;
 	}
 #endif
-	//
-	//d. Initialize BB related configurations.
-	//
+	/*  */
+	/* d. Initialize BB related configurations. */
+	/*  */
 #if (HAL_BB_ENABLE == 1)
 	ret = PHY_BBConfig8188F(padapter);
-	if(ret != _SUCCESS){
-		RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("Initializepadapter8192CSdio(): Fail to configure BB!!\n"));
+	if (ret != _SUCCESS) {
 		return ret;
 	}
 #endif
 
-	// If RF is on, we need to init RF. Otherwise, skip the procedure.
-	// We need to follow SU method to change the RF cfg.txt. Default disable RF TX/RX mode.
-	//if(pHalData->eRFPowerState == eRfOn)
+	/* If RF is on, we need to init RF. Otherwise, skip the procedure. */
+	/* We need to follow SU method to change the RF cfg.txt. Default disable RF TX/RX mode. */
+	/* if(pHalData->eRFPowerState == eRfOn) */
 	{
 #if (HAL_RF_ENABLE == 1)
 		ret = PHY_RFConfig8188F(padapter);
-		if(ret != _SUCCESS){
-			RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("Initializepadapter8192CSdio(): Fail to configure RF!!\n"));
+		if (ret != _SUCCESS) {
 			return ret;
 		}
 #endif
 	}
 
-	//
-	// Joseph Note: Keep RfRegChnlVal for later use.
-	//
-	pHalData->RfRegChnlVal[0] = PHY_QueryRFReg(padapter, (RF_PATH)0, RF_CHNLBW, bRFRegOffsetMask);
-	pHalData->RfRegChnlVal[1] = PHY_QueryRFReg(padapter, (RF_PATH)1, RF_CHNLBW, bRFRegOffsetMask);
+	/*  */
+	/* Joseph Note: Keep RfRegChnlVal for later use. */
+	/*  */
+	pHalData->RfRegChnlVal[0] = phy_query_rf_reg(padapter, RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask);
+	pHalData->RfRegChnlVal[1] = phy_query_rf_reg(padapter, RF_PATH_B, RF_CHNLBW, bRFRegOffsetMask);
 
-	
-	//if (!pHalData->bMACFuncEnable) {
-		_InitQueueReservedPage(padapter);
-		_InitTxBufferBoundary(padapter);
 
-		// init LLT after tx buffer boundary is defined
-		ret = rtl8188f_InitLLTTable(padapter);
-		if (_SUCCESS != ret)
-		{
-			DBG_8192C("%s: Failed to init LLT Table!\n", __FUNCTION__);
-			return _FAIL;
-		}
-	//}
+	/* if (!pHalData->bMACFuncEnable) { */
+	_InitQueueReservedPage(padapter);
+	_InitTxBufferBoundary(padapter);
+
+	/* init LLT after tx buffer boundary is defined */
+	ret = rtl8188f_InitLLTTable(padapter);
+	if (_SUCCESS != ret) {
+		RTW_INFO("%s: Failed to init LLT Table!\n", __FUNCTION__);
+		return _FAIL;
+	}
+	/* } */
 	_InitQueuePriority(padapter);
 	_InitPageBoundary(padapter);
 	_InitTransferPageSize(padapter);
 
-	// Get Rx PHY status in order to report RSSI and others.
+	/* Get Rx PHY status in order to report RSSI and others. */
 	_InitDriverInfoSize(padapter, DRVINFO_SZ);
-	hal_init_macaddr(padapter);
 	_InitNetworkType(padapter);
 	_InitWMACSetting(padapter);
 	_InitAdaptiveCtrl(padapter);
 	_InitEDCA(padapter);
-	//_InitRateFallback(padapter);
 	_InitRetryFunction(padapter);
 	_initSdioAggregationSetting(padapter);
-	_InitOperationMode(padapter);
 	rtl8188f_InitBeaconParameters(padapter);
 	rtl8188f_InitBeaconMaxError(padapter, _TRUE);
 	_InitInterrupt(padapter);
 	_InitBurstPktLen_8188FS(padapter);
 
-	//YJ,TODO
-	rtw_write8(padapter, REG_SECONDARY_CCA_CTRL_8188F, 0x3);	// CCA 
-	rtw_write8(padapter, 0x976, 0);	// hpfan_todo: 2nd CCA related
+	/* YJ,TODO */
+	rtw_write8(padapter, REG_SECONDARY_CCA_CTRL_8188F, 0x3);	/* CCA */
+	rtw_write8(padapter, 0x976, 0);	/* hpfan_todo: 2nd CCA related */
 
 #if defined(CONFIG_CONCURRENT_MODE) || defined(CONFIG_TX_MCAST2UNI)
 
 #ifdef CONFIG_CHECK_AC_LIFETIME
-	// Enable lifetime check for the four ACs
+	/* Enable lifetime check for the four ACs */
 	rtw_write8(padapter, REG_LIFETIME_CTRL, rtw_read8(padapter, REG_LIFETIME_CTRL) | 0x0F);
-#endif	// CONFIG_CHECK_AC_LIFETIME
+#endif /* CONFIG_CHECK_AC_LIFETIME */
 
 #ifdef CONFIG_TX_MCAST2UNI
-	rtw_write16(padapter, REG_PKT_VO_VI_LIFE_TIME, 0x0400);	// unit: 256us. 256ms
-	rtw_write16(padapter, REG_PKT_BE_BK_LIFE_TIME, 0x0400);	// unit: 256us. 256ms
-#else	// CONFIG_TX_MCAST2UNI
-	rtw_write16(padapter, REG_PKT_VO_VI_LIFE_TIME, 0x3000);	// unit: 256us. 3s
-	rtw_write16(padapter, REG_PKT_BE_BK_LIFE_TIME, 0x3000);	// unit: 256us. 3s
-#endif	// CONFIG_TX_MCAST2UNI
-#endif	// CONFIG_CONCURRENT_MODE || CONFIG_TX_MCAST2UNI
+	rtw_write16(padapter, REG_PKT_VO_VI_LIFE_TIME, 0x0400);	/* unit: 256us. 256ms */
+	rtw_write16(padapter, REG_PKT_BE_BK_LIFE_TIME, 0x0400);	/* unit: 256us. 256ms */
+#else	/* CONFIG_TX_MCAST2UNI */
+	rtw_write16(padapter, REG_PKT_VO_VI_LIFE_TIME, 0x3000);	/* unit: 256us. 3s */
+	rtw_write16(padapter, REG_PKT_BE_BK_LIFE_TIME, 0x3000);	/* unit: 256us. 3s */
+#endif /* CONFIG_TX_MCAST2UNI */
+#endif /* CONFIG_CONCURRENT_MODE || CONFIG_TX_MCAST2UNI */
 
 
 	invalidate_cam_all(padapter);
@@ -1173,31 +929,26 @@ static u32 rtl8188fs_hal_init(PADAPTER padapter)
 	rtw_hal_set_chnl_bw(padapter, padapter->registrypriv.channel,
 		CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE, HAL_PRIME_CHNL_OFFSET_DONT_CARE);
 
-	// Record original value for template. This is arough data, we can only use the data
-	// for power adjust. The value can not be adjustde according to different power!!!
-//	pHalData->OriginalCckTxPwrIdx = pHalData->CurrentCckTxPwrIdx;
-//	pHalData->OriginalOfdm24GTxPwrIdx = pHalData->CurrentOfdm24GTxPwrIdx;
-
 	rtl8188f_InitAntenna_Selection(padapter);
 
-	//
-	// Disable BAR, suggested by Scott
-	// 2010.04.09 add by hpfan
-	//
+	/*  */
+	/* Disable BAR, suggested by Scott */
+	/* 2010.04.09 add by hpfan */
+	/*  */
 	rtw_write32(padapter, REG_BAR_MODE_CTRL, 0x0201ffff);
 
-	// HW SEQ CTRL
-	// set 0x0 to 0xFF by tynli. Default enable HW SEQ NUM.
+	/* HW SEQ CTRL */
+	/* set 0x0 to 0xFF by tynli. Default enable HW SEQ NUM. */
 	rtw_write8(padapter, REG_HWSEQ_CTRL, 0xFF);
 
 
 #ifdef CONFIG_MAC_LOOPBACK_DRIVER
 	u1bTmp = rtw_read8(padapter, REG_SYS_FUNC_EN);
-	u1bTmp &= ~(FEN_BBRSTB|FEN_BB_GLB_RSTn);
-	rtw_write8(padapter, REG_SYS_FUNC_EN,u1bTmp);
+	u1bTmp &= ~(FEN_BBRSTB | FEN_BB_GLB_RSTn);
+	rtw_write8(padapter, REG_SYS_FUNC_EN, u1bTmp);
 
 	rtw_write8(padapter, REG_RD_CTRL, 0x0F);
-	rtw_write8(padapter, REG_RD_CTRL+1, 0xCF);
+	rtw_write8(padapter, REG_RD_CTRL + 1, 0xCF);
 	rtw_write8(padapter, REG_TXPKTBUF_WMAC_LBK_BF_HD_8188F, 0x80);
 	rtw_write32(padapter, REG_CR, 0x0b0202ff);
 #endif
@@ -1208,66 +959,64 @@ static u32 rtl8188fs_hal_init(PADAPTER padapter)
 	* Only clear necessary bits 0x0[2:0] and 0x2[15:0] and keep 0x0[15:3]
 	* 2015.03.19.
 	*/
-	u4Tmp = rtw_read32(padapter, SDIO_LOCAL_BASE|SDIO_REG_TX_CTRL);
+	u4Tmp = rtw_read32(padapter, SDIO_LOCAL_BASE | SDIO_REG_TX_CTRL);
 	#if 0
 	u4Tmp &= 0xFFFFFFF8;
 	#else
 	u4Tmp &= 0x0000FFF8;
 	#endif
-	rtw_write32(padapter, SDIO_LOCAL_BASE|SDIO_REG_TX_CTRL, u4Tmp);
+	rtw_write32(padapter, SDIO_LOCAL_BASE | SDIO_REG_TX_CTRL, u4Tmp);
 
 	_RfPowerSave(padapter);
-	
+
 	rtl8188f_InitHalDm(padapter);
 
-	//DbgPrint("pHalData->DefaultTxPwrDbm = %d\n", pHalData->DefaultTxPwrDbm);
+	/* DbgPrint("pHalData->DefaultTxPwrDbm = %d\n", pHalData->DefaultTxPwrDbm); */
 
-//	if(pHalData->SwBeaconType < HAL92CSDIO_DEFAULT_BEACON_TYPE) // The lowest Beacon Type that HW can support
-//		pHalData->SwBeaconType = HAL92CSDIO_DEFAULT_BEACON_TYPE;
+	/* if(pHalData->SwBeaconType < HAL92CSDIO_DEFAULT_BEACON_TYPE) */ /* The lowest Beacon Type that HW can support */
+	/*		pHalData->SwBeaconType = HAL92CSDIO_DEFAULT_BEACON_TYPE; */
 
-	//
-	// Update current Tx FIFO page status.
-	//
+	/*  */
+	/* Update current Tx FIFO page status. */
+	/*  */
 	HalQueryTxBufferStatus8188FSdio(padapter);
 	HalQueryTxOQTBufferStatus8188FSdio(padapter);
 	pHalData->SdioTxOQTMaxFreeSpace = pHalData->SdioTxOQTFreeSpace;
 
-	// Enable MACTXEN/MACRXEN block
+	/* Enable MACTXEN/MACRXEN block */
 	u1bTmp = rtw_read8(padapter, REG_CR);
 	u1bTmp |= (MACTXEN | MACRXEN);
 	rtw_write8(padapter, REG_CR, u1bTmp);
 
-	rtw_hal_set_hwreg(padapter, HW_VAR_NAV_UPPER, (u8*)&NavUpper);
+	rtw_hal_set_hwreg(padapter, HW_VAR_NAV_UPPER, (u8 *)&NavUpper);
 
 #ifdef CONFIG_XMIT_ACK
-	//ack for xmit mgmt frames.
-	rtw_write32(padapter, REG_FWHW_TXQ_CTRL, rtw_read32(padapter, REG_FWHW_TXQ_CTRL)|BIT(12));
-#endif //CONFIG_XMIT_ACK	
+	/* ack for xmit mgmt frames. */
+	rtw_write32(padapter, REG_FWHW_TXQ_CTRL, rtw_read32(padapter, REG_FWHW_TXQ_CTRL) | BIT(12));
+#endif /* CONFIG_XMIT_ACK	 */
 
-//	pHalData->PreRpwmVal = SdioLocalCmd52Read1Byte(padapter, SDIO_REG_HRPWM1) & 0x80;
+	/*	pHalData->PreRpwmVal = SdioLocalCmd52Read1Byte(padapter, SDIO_REG_HRPWM1) & 0x80; */
 
 #if (MP_DRIVER == 1)
-	if (padapter->registrypriv.mp_mode == 1)
-	{
-		padapter->mppriv.channel = pHalData->CurrentChannel;
+	if (padapter->registrypriv.mp_mode == 1) {
+		padapter->mppriv.channel = pHalData->current_channel;
 		MPT_InitializeAdapter(padapter, padapter->mppriv.channel);
-	}
-	else
-#endif //#if (MP_DRIVER == 1)
+	} else
+#endif /* #if (MP_DRIVER == 1) */
 	{
 		pwrctrlpriv->rf_pwrstate = rf_on;
 
-		if(pwrctrlpriv->rf_pwrstate == rf_on)
-		{
+		if (pwrctrlpriv->rf_pwrstate == rf_on) {
 			struct pwrctrl_priv *pwrpriv;
-			u32 start_time;
+			systime start_time;
 			u8 restore_iqk_rst;
 			u8 b2Ant;
 			u8 h2cCmdBuf;
 
 			pwrpriv = adapter_to_pwrctl(padapter);
 
-			PHY_LCCalibrate_8188F(&pHalData->odmpriv);
+			/*phy_lc_calibrate_8188f(&pHalData->odmpriv);*/
+			halrf_lck_trigger(&pHalData->odmpriv);
 
 			#ifdef CONFIG_BT_COEXIST
 			/* Inform WiFi FW that it is the beginning of IQK */
@@ -1282,33 +1031,29 @@ static u32 rtl8188fs_hal_init(PADAPTER padapter)
 				rtw_msleep_os(50);
 			} while (rtw_get_passing_time_ms(start_time) <= 400);
 			#endif
-
-			restore_iqk_rst = (pwrpriv->bips_processing==_TRUE)?_TRUE:_FALSE;
-			PHY_IQCalibrate_8188F(padapter, _FALSE, restore_iqk_rst);
-			pHalData->bIQKInitialized = _TRUE;
-
+			
+			pHalData->neediqk_24g = _TRUE;
 			#ifdef CONFIG_BT_COEXIST
 			/* Inform WiFi FW that it is the finish of IQK */
 			h2cCmdBuf = 0;
 			FillH2CCmd8188F(padapter, H2C_8188F_BT_WLAN_CALIBRATION, 1, &h2cCmdBuf);
 			#endif
 
-			ODM_TXPowerTrackingCheck(&pHalData->odmpriv);
+			odm_txpowertracking_check(&pHalData->odmpriv);
 		}
 	}
 
 
-	RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("-%s\n", __FUNCTION__));
 
 	return _SUCCESS;
 }
 
-//
-// Description:
-//	RTL8188e card disable power sequence v003 which suggested by Scott.
-//
-// First created by tynli. 2011.01.28.
-//
+/*
+ * Description:
+ *	RTL8188e card disable power sequence v003 which suggested by Scott.
+ *
+ * First created by tynli. 2011.01.28.
+ *   */
 static void CardDisableRTL8188FSdio(PADAPTER padapter)
 {
 	u8		u1bTmp;
@@ -1318,40 +1063,39 @@ static void CardDisableRTL8188FSdio(PADAPTER padapter)
 	u8 hci_sus_state;
 	u8		ret = _FAIL;
 
-	// Run LPS WL RFOFF flow
+	/* Run LPS WL RFOFF flow */
 	ret = HalPwrSeqCmdParsing(padapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, rtl8188F_enter_lps_flow);
-	if (ret == _FAIL) {
-		DBG_8192C(KERN_ERR "%s: run RF OFF flow fail!\n", __func__);
-	}
+	if (ret == _FAIL)
+		RTW_ERR("%s: run RF OFF flow fail!\n", __func__);
 
-	//	==== Reset digital sequence   ======
+	/*	==== Reset digital sequence   ====== */
 
 	u1bTmp = rtw_read8(padapter, REG_MCUFWDL);
-	if ((u1bTmp & RAM_DL_SEL) && padapter->bFWReady) //8051 RAM code
+	if ((u1bTmp & RAM_DL_SEL) && GET_HAL_DATA(padapter)->bFWReady) /* 8051 RAM code */
 		rtl8188f_FirmwareSelfReset(padapter);
 
-	// Reset MCU 0x2[10]=0. Suggested by Filen. 2011.01.26. by tynli.
-	u1bTmp = rtw_read8(padapter, REG_SYS_FUNC_EN+1);
-	u1bTmp &= ~BIT(2);	// 0x2[10], FEN_CPUEN
-	rtw_write8(padapter, REG_SYS_FUNC_EN+1, u1bTmp);
+	/* Reset MCU 0x2[10]=0. Suggested by Filen. 2011.01.26. by tynli. */
+	u1bTmp = rtw_read8(padapter, REG_SYS_FUNC_EN + 1);
+	u1bTmp &= ~BIT(2);	/* 0x2[10], FEN_CPUEN */
+	rtw_write8(padapter, REG_SYS_FUNC_EN + 1, u1bTmp);
 
-	// MCUFWDL 0x80[1:0]=0
-	// reset MCU ready status
+	/* MCUFWDL 0x80[1:0]=0 */
+	/* reset MCU ready status */
 	rtw_write8(padapter, REG_MCUFWDL, 0);
 
-	// Reset MCU IO Wrapper, added by Roger, 2011.08.30
+	/* Reset MCU IO Wrapper, added by Roger, 2011.08.30 */
 
-//derek mod for reg 0x1d
-//	u1bTmp = rtw_read8(padapter, REG_RSV_CTRL+1);
-//	u1bTmp &= ~BIT(0);
-//	rtw_write8(padapter, REG_RSV_CTRL+1, u1bTmp);
-//	u1bTmp = rtw_read8(padapter, REG_RSV_CTRL+1);
-//	u1bTmp |= BIT(0);
-//	rtw_write8(padapter, REG_RSV_CTRL+1, u1bTmp);
+	/* derek mod for reg 0x1d
+	 *	u1bTmp = rtw_read8(padapter, REG_RSV_CTRL+1);
+	 *	u1bTmp &= ~BIT(0);
+	 *	rtw_write8(padapter, REG_RSV_CTRL+1, u1bTmp);
+	 *	u1bTmp = rtw_read8(padapter, REG_RSV_CTRL+1);
+	 *	u1bTmp |= BIT(0);
+	 *	rtw_write8(padapter, REG_RSV_CTRL+1, u1bTmp); */
 
-	//	==== Reset digital sequence end ======
-	
-	bMacPwrCtrlOn = _FALSE;	// Disable CMD53 R/W
+	/*	==== Reset digital sequence end ====== */
+
+	bMacPwrCtrlOn = _FALSE;	/* Disable CMD53 R/W */
 	ret = _FALSE;
 	rtw_hal_set_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
 	hci_sus_state = HCI_SUS_ENTERING;
@@ -1360,20 +1104,20 @@ static void CardDisableRTL8188FSdio(PADAPTER padapter)
 	if (ret == _FALSE) {
 		hci_sus_state = HCI_SUS_ERR;
 		rtw_hal_set_hwreg(padapter, HW_VAR_HCI_SUS_STATE, &hci_sus_state);
-		DBG_8192C(KERN_ERR "%s: run CARD DISABLE flow fail!\n", __func__);
+		RTW_ERR("%s: run CARD DISABLE flow fail!\n", __func__);
 	} else {
 		hci_sus_state = HCI_SUS_ENTER;
 		rtw_hal_set_hwreg(padapter, HW_VAR_HCI_SUS_STATE, &hci_sus_state);
 	}
 
-	padapter->bFWReady = _FALSE;
+	GET_HAL_DATA(padapter)->bFWReady = _FALSE;
 }
 
 static u32 rtl8188fs_hal_deinit(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-        struct dvobj_priv *psdpriv = padapter->dvobj;
+	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 
 #ifdef CONFIG_MP_INCLUDED
@@ -1382,116 +1126,101 @@ static u32 rtl8188fs_hal_deinit(PADAPTER padapter)
 #endif
 
 	if (rtw_is_hw_init_completed(padapter)) {
-#ifdef CONFIG_SWLPS_IN_IPS				
-		if (adapter_to_pwrctl(padapter)->bips_processing == _TRUE)
-		{
+#ifdef CONFIG_SWLPS_IN_IPS
+		if (adapter_to_pwrctl(padapter)->bips_processing == _TRUE) {
 			u8	bMacPwrCtrlOn;
 			u8 ret =  _TRUE;
 
-			DBG_871X("%s: run LPS flow in IPS\n", __FUNCTION__);
+			RTW_INFO("%s: run LPS flow in IPS\n", __FUNCTION__);
 
 			rtw_write32(padapter, 0x130, 0x0);
 			rtw_write32(padapter, 0x138, 0x100);
 			rtw_write8(padapter, 0x13d, 0x1);
 
 
-			bMacPwrCtrlOn = _FALSE;	// Disable CMD53 R/W	
+			bMacPwrCtrlOn = _FALSE;	/* Disable CMD53 R/W	 */
 			rtw_hal_set_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
-			
+
 			ret = HalPwrSeqCmdParsing(padapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, rtl8188F_enter_swlps_flow);
 			if (ret == _FALSE) {
-				DBG_8192C("%s: run LPS flow in IPS fail!\n", __FUNCTION__);
+				RTW_INFO("%s: run LPS flow in IPS fail!\n", __FUNCTION__);
 				return _FAIL;
 			}
-		}
-		else
+		} else
 #elif defined(CONFIG_FWLPS_IN_IPS)
-		if (adapter_to_pwrctl(padapter)->bips_processing == _TRUE && psrtpriv->silent_reset_inprogress == _FALSE)
-		{
-			if(padapter->netif_up == _TRUE)
-			{
-				int cnt=0;
+		if (adapter_to_pwrctl(padapter)->bips_processing == _TRUE && psrtpriv->silent_reset_inprogress == _FALSE) {
+			if (padapter->netif_up == _TRUE) {
+				int cnt = 0;
 				u8 val8 = 0;
-			
-				DBG_871X("%s: issue H2C to FW when entering IPS\n", __FUNCTION__);
-			
-				rtl8188f_set_FwPwrModeInIPS_cmd(padapter, 0x3);
-				//poll 0x1cc to make sure H2C command already finished by FW; MAC_0x1cc=0 means H2C done by FW.
-				do{
+
+				RTW_INFO("%s: issue H2C to FW when entering IPS\n", __FUNCTION__);
+
+				rtl8188f_set_FwPwrModeInIPS_cmd(padapter, 0x1);
+				/* poll 0x1cc to make sure H2C command already finished by FW; MAC_0x1cc=0 means H2C done by FW. */
+				do {
 					val8 = rtw_read8(padapter, REG_HMETFR);
 					cnt++;
-					DBG_871X("%s  polling REG_HMETFR=0x%x, cnt=%d \n", __FUNCTION__, val8, cnt);
+					RTW_INFO("%s  polling REG_HMETFR=0x%x, cnt=%d\n", __FUNCTION__, val8, cnt);
 					rtw_mdelay_os(10);
-				}while(cnt<100 && (val8!=0));
-				//H2C done, enter 32k
-				if(val8 == 0)
-				{
-					//ser rpwm to enter 32k
-					val8 = rtw_read8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1);
+				} while (cnt < 100 && (val8 != 0));
+				/* H2C done, enter 32k */
+				if (val8 == 0) {
+					/* ser rpwm to enter 32k */
+					val8 = rtw_read8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1);
 					val8 += 0x80;
 					val8 |= BIT(0);
-					rtw_write8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1, val8);
-					DBG_871X("%s: write rpwm=%02x\n", __FUNCTION__, val8);
+					rtw_write8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1, val8);
+					RTW_INFO("%s: write rpwm=%02x\n", __FUNCTION__, val8);
 					adapter_to_pwrctl(padapter)->tog = (val8 + 0x80) & 0x80;
 					cnt = val8 = 0;
-					do{
+					do {
 						val8 = rtw_read8(padapter, REG_CR);
 						cnt++;
-						DBG_871X("%s  polling 0x100=0x%x, cnt=%d \n", __FUNCTION__, val8, cnt);			
+						RTW_INFO("%s  polling 0x100=0x%x, cnt=%d\n", __FUNCTION__, val8, cnt);
 						rtw_mdelay_os(10);
-					}while(cnt<100 && (val8!=0xEA));
+					} while (cnt < 100 && (val8 != 0xEA));
 #ifdef DBG_CHECK_FW_PS_STATE
-				if(val8 != 0xEA)
-					DBG_871X("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n", rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
-					, rtw_read32(padapter, 0x1c8), rtw_read32(padapter, 0x1cc));
-#endif //DBG_CHECK_FW_PS_STATE
-				}
-				else
-				{
-					DBG_871X("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n", rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
-					, rtw_read32(padapter, 0x1c8), rtw_read32(padapter, 0x1cc));
+					if (val8 != 0xEA)
+						RTW_INFO("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n", rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
+							, rtw_read32(padapter, 0x1c8), rtw_read32(padapter, 0x1cc));
+#endif /* DBG_CHECK_FW_PS_STATE */
+				} else {
+					RTW_INFO("MAC_1C0=%08x, MAC_1C4=%08x, MAC_1C8=%08x, MAC_1CC=%08x\n", rtw_read32(padapter, 0x1c0), rtw_read32(padapter, 0x1c4)
+						, rtw_read32(padapter, 0x1c8), rtw_read32(padapter, 0x1cc));
 				}
-			
-				DBG_871X("polling done when entering IPS, check result : 0x100=0x%x, cnt=%d, MAC_1cc=0x%02x\n"
-				, rtw_read8(padapter, REG_CR), cnt, rtw_read8(padapter, REG_HMETFR));
+
+				RTW_INFO("polling done when entering IPS, check result : 0x100=0x%x, cnt=%d, MAC_1cc=0x%02x\n"
+					, rtw_read8(padapter, REG_CR), cnt, rtw_read8(padapter, REG_HMETFR));
 
 				adapter_to_pwrctl(padapter)->pre_ips_type = 0;
-				
-			}
-			else
-			{
+
+			} else {
 				pdbgpriv->dbg_carddisable_cnt++;
 #ifdef DBG_CHECK_FW_PS_STATE
-				if(rtw_fw_ps_state(padapter) == _FAIL)
-				{
-					DBG_871X("card disable should leave 32k\n");
+				if (rtw_fw_ps_state(padapter) == _FAIL) {
+					RTW_INFO("card disable should leave 32k\n");
 					pdbgpriv->dbg_carddisable_error_cnt++;
 				}
-#endif //DBG_CHECK_FW_PS_STATE
+#endif /* DBG_CHECK_FW_PS_STATE */
 				rtw_hal_power_off(padapter);
 
 				adapter_to_pwrctl(padapter)->pre_ips_type = 1;
 			}
-			
-		}
-		else
-#endif //CONFIG_SWLPS_IN_IPS
+
+		} else
+#endif /* CONFIG_SWLPS_IN_IPS */
 		{
 			pdbgpriv->dbg_carddisable_cnt++;
 #ifdef DBG_CHECK_FW_PS_STATE
-			if(rtw_fw_ps_state(padapter) == _FAIL)
-			{
-				DBG_871X("card disable should leave 32k\n");
+			if (rtw_fw_ps_state(padapter) == _FAIL) {
+				RTW_INFO("card disable should leave 32k\n");
 				pdbgpriv->dbg_carddisable_error_cnt++;
 			}
-#endif //DBG_CHECK_FW_PS_STATE
+#endif /* DBG_CHECK_FW_PS_STATE */
 			rtw_hal_power_off(padapter);
 		}
-	}
-	else
-	{
+	} else
 		pdbgpriv->dbg_deinit_fail_cnt++;
-	}
 
 	return _SUCCESS;
 }
@@ -1504,7 +1233,7 @@ static void rtl8188fs_init_default_value(PADAPTER padapter)
 
 	rtl8188f_init_default_value(padapter);
 
-	// interface related variable
+	/* interface related variable */
 	pHalData->SdioRxFIFOCnt = 0;
 }
 
@@ -1525,42 +1254,42 @@ static void rtl8188fs_interface_configure(PADAPTER padapter)
 	else
 		pHalData->OutEpNumber = SDIO_MAX_TX_QUEUE;
 
-	switch(pHalData->OutEpNumber){
-		case 3:
-			pHalData->OutEpQueueSel=TX_SELE_HQ| TX_SELE_LQ|TX_SELE_NQ;
-			break;
-		case 2:
-			pHalData->OutEpQueueSel=TX_SELE_HQ| TX_SELE_NQ;
-			break;
-		case 1:
-			pHalData->OutEpQueueSel=TX_SELE_HQ;
-			break;
-		default:
-			break;
+	switch (pHalData->OutEpNumber) {
+	case 3:
+		pHalData->OutEpQueueSel = TX_SELE_HQ | TX_SELE_LQ | TX_SELE_NQ;
+		break;
+	case 2:
+		pHalData->OutEpQueueSel = TX_SELE_HQ | TX_SELE_NQ;
+		break;
+	case 1:
+		pHalData->OutEpQueueSel = TX_SELE_HQ;
+		break;
+	default:
+		break;
 	}
 
 	Hal_MappingOutPipe(padapter, pHalData->OutEpNumber);
 }
 
-//
-//	Description:
-//		We should set Efuse cell selection to WiFi cell in default.
-//
-//	Assumption:
-//		PASSIVE_LEVEL
-//
-//	Added by Roger, 2010.11.23.
-//
+/*
+ *	Description:
+ *		We should set Efuse cell selection to WiFi cell in default.
+ *
+ *	Assumption:
+ *		PASSIVE_LEVEL
+ *
+ *	Added by Roger, 2010.11.23.
+ *   */
 static void
 _EfuseCellSel(
 	IN	PADAPTER	padapter
-	)
+)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
 	u32			value32;
 
-	//if(INCLUDE_MULTI_FUNC_BT(padapter))
+	/* if(INCLUDE_MULTI_FUNC_BT(padapter)) */
 	{
 		value32 = rtw_read32(padapter, EFUSE_TEST);
 		value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_WIFI_SEL_0);
@@ -1571,7 +1300,7 @@ _EfuseCellSel(
 static VOID
 _ReadRFType(
 	IN	PADAPTER	Adapter
-	)
+)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
 
@@ -1582,22 +1311,21 @@ _ReadRFType(
 #endif
 }
 
-static VOID
+static u8
 _ReadEfuseInfo8188FS(
 	IN PADAPTER			padapter
-	)
+)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
-	u8*			hwinfo = NULL;
-
-	RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("====>_ReadEfuseInfo8188FS()\n"));
+	u8			*hwinfo = NULL;
+	u8 ret = _FAIL;
 
-	//
-	// This part read and parse the eeprom/efuse content
-	//
+	/*  */
+	/* This part read and parse the eeprom/efuse content */
+	/*  */
 
 	if (sizeof(pHalData->efuse_eeprom_data) < HWSET_MAX_SIZE_8188F)
-		DBG_871X("[WARNING] size of efuse_eeprom_data is less than HWSET_MAX_SIZE_8188F!\n");
+		RTW_INFO("[WARNING] size of efuse_eeprom_data is less than HWSET_MAX_SIZE_8188F!\n");
 
 	hwinfo = pHalData->efuse_eeprom_data;
 
@@ -1607,131 +1335,140 @@ _ReadEfuseInfo8188FS(
 	Hal_EfuseParseEEPROMVer_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
 	hal_config_macaddr(padapter, pHalData->bautoload_fail_flag);
 	Hal_EfuseParseTxPowerInfo_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
-	//Hal_EfuseParseBoardType_8188FS(padapter, hwinfo, pHalData->bautoload_fail_flag);
+	/* Hal_EfuseParseBoardType_8188FS(padapter, hwinfo, pHalData->bautoload_fail_flag); */
 
-	//
-	// Read Bluetooth co-exist and initialize
-	//
-	//Hal_EfuseParseBTCoexistInfo_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
+	/*  */
+	/* Read Bluetooth co-exist and initialize */
+	/*  */
+	/* Hal_EfuseParseBTCoexistInfo_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag); */
 	Hal_EfuseParseChnlPlan_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
 	Hal_EfuseParseXtal_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
 	Hal_EfuseParseThermalMeter_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
 	Hal_EfuseParseAntennaDiversity_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
 	Hal_EfuseParseCustomerID_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
-	
-	//Hal_EfuseParseVoltage_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
-	
+
+	/* Hal_EfuseParseVoltage_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag); */
+
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 	Hal_DetectWoWMode(padapter);
 #endif
 
 	Hal_EfuseParseKFreeData_8188F(padapter, hwinfo, pHalData->bautoload_fail_flag);
-	hal_read_mac_hidden_rpt(padapter);
 
-	RT_TRACE(_module_hci_hal_init_c_, _drv_info_, ("<==== _ReadEfuseInfo8188FS()\n"));
+#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
+	if (hal_read_mac_hidden_rpt(padapter) != _SUCCESS)
+		goto exit;
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
 }
 
-static void _ReadPROMContent(
-	IN PADAPTER 		padapter
-	)
+static u8 _ReadPROMContent(
+	IN PADAPTER		padapter
+)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 	u8			eeValue;
+	u8 ret = _FAIL;
 
 	eeValue = rtw_read8(padapter, REG_9346CR);
-	// To check system boot selection.
+	/* To check system boot selection. */
 	pHalData->EepromOrEfuse = (eeValue & BOOT_FROM_EEPROM) ? _TRUE : _FALSE;
 	pHalData->bautoload_fail_flag = (eeValue & EEPROM_EN) ? _FALSE : _TRUE;
 
-	RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-		 ("%s: 9346CR=0x%02X, Boot from %s, Autoload %s\n",
-		  __FUNCTION__, eeValue,
-		  (pHalData->EepromOrEfuse ? "EEPROM" : "EFUSE"),
-		  (pHalData->bautoload_fail_flag ? "Fail" : "OK")));
 
-//	pHalData->EEType = IS_BOOT_FROM_EEPROM(Adapter) ? EEPROM_93C46 : EEPROM_BOOT_EFUSE;
+	/*	pHalData->EEType = IS_BOOT_FROM_EEPROM(Adapter) ? EEPROM_93C46 : EEPROM_BOOT_EFUSE; */
+
+	if (_ReadEfuseInfo8188FS(padapter) != _SUCCESS)
+		goto exit;
 
-	_ReadEfuseInfo8188FS(padapter);
+	ret = _SUCCESS;
+
+exit:
+	return ret;
 }
 
-//
-//	Description:
-//		Read HW adapter information by E-Fuse or EEPROM according CR9346 reported.
-//
-//	Assumption:
-//		PASSIVE_LEVEL (SDIO interface)
-//
-//
-static void ReadAdapterInfo8188FS(PADAPTER padapter)
+/*
+ *	Description:
+ *		Read HW adapter information by E-Fuse or EEPROM according CR9346 reported.
+ *
+ *	Assumption:
+ *		PASSIVE_LEVEL (SDIO interface)
+ *
+ *   */
+static u8 ReadAdapterInfo8188FS(PADAPTER padapter)
 {
+	u8 ret = _FAIL;
+
 	/* Read EEPROM size before call any EEPROM function */
 	padapter->EepromAddressSize = GetEEPROMSize8188F(padapter);
 
 	_EfuseCellSel(padapter);
 	_ReadRFType(padapter);
-	_ReadPROMContent(padapter);
+	if (_ReadPROMContent(padapter) != _SUCCESS)
+		goto exit;
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
 }
 
 /*
  * If variable not handled here,
  * some variables will be processed in SetHwReg8188F()
  */
-void SetHwReg8188FS(PADAPTER padapter, u8 variable, u8 *val)
+u8 SetHwReg8188FS(PADAPTER padapter, u8 variable, u8 *val)
 {
 	PHAL_DATA_TYPE pHalData;
+	u8 ret = _SUCCESS;
 	u8 val8;
 
-_func_enter_;
 
 	pHalData = GET_HAL_DATA(padapter);
 
-	switch (variable)
+	switch (variable) {
+	case HW_VAR_SET_RPWM:
+		/* rpwm value only use BIT0(clock bit) ,BIT6(Ack bit), and BIT7(Toggle bit) */
+		/* BIT0 value - 1: 32k, 0:40MHz. */
+		/* BIT6 value - 1: report cpwm value after success set, 0:do not report. */
+		/* BIT7 value - Toggle bit change. */
 	{
-		case HW_VAR_SET_RPWM:
-			// rpwm value only use BIT0(clock bit) ,BIT6(Ack bit), and BIT7(Toggle bit)
-			// BIT0 value - 1: 32k, 0:40MHz.
-			// BIT6 value - 1: report cpwm value after success set, 0:do not report.
-			// BIT7 value - Toggle bit change.
-			{
-				val8 = *val;
-				val8 &= 0xC1;
-				rtw_write8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HRPWM1, val8);
-			}
-			break;
-		case HW_VAR_SET_REQ_FW_PS:
-			//1. driver write 0x8f[4]=1  //request fw ps state (only can write bit4)
-			{
-				u8 req_fw_ps=0;
-				req_fw_ps = rtw_read8(padapter, 0x8f);
-				req_fw_ps |= 0x10;
-				rtw_write8(padapter, 0x8f, req_fw_ps);
-			}
-			break;
-		case HW_VAR_RXDMA_AGG_PG_TH:
-			val8 = *val;
-
-			// TH=1 => invalidate RX DMA aggregation
-			// TH=0 => validate RX DMA aggregation, use init value.
-			if (val8 == 0)
-			{
-				// enable RXDMA aggregation
-				//_RXAggrSwitch(padapter, _TRUE);
-			}
-			else
-			{
-				// disable RXDMA aggregation
-				//_RXAggrSwitch(padapter, _FALSE);
-			}
-			break;
-		case HW_VAR_DM_IN_LPS:
-			rtl8188f_hal_dm_in_lps(padapter);
-			break;
-		default:
-			SetHwReg8188F(padapter, variable, val);
-			break;
+		val8 = *val;
+		val8 &= 0xC1;
+		rtw_write8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HRPWM1, val8);
+	}
+		break;
+	case HW_VAR_SET_REQ_FW_PS: {
+		/* driver write 0x8f[4]=1, request fw ps state */
+		u8 req_fw_ps = 0;
+		req_fw_ps = rtw_read8(padapter, 0x8f);
+		req_fw_ps |= 0x10;
+		rtw_write8(padapter, 0x8f, req_fw_ps);
+	}
+		break;
+	case HW_VAR_RXDMA_AGG_PG_TH:
+		val8 = *val;
+
+		/* TH=1 => invalidate RX DMA aggregation */
+		/* TH=0 => validate RX DMA aggregation, use init value. */
+		if (val8 == 0) {
+			/* enable RXDMA aggregation */
+			/* _RXAggrSwitch(padapter, _TRUE); */
+		} else {
+			/* disable RXDMA aggregation */
+			/* _RXAggrSwitch(padapter, _FALSE); */
+		}
+		break;
+	default:
+		ret = SetHwReg8188F(padapter, variable, val);
+		break;
 	}
 
-_func_exit_;
+	return ret;
 }
 
 /*
@@ -1742,86 +1479,76 @@ void GetHwReg8188FS(PADAPTER padapter, u8 variable, u8 *val)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 
-_func_enter_;
 
-	switch (variable)
-	{
-		case HW_VAR_CPWM:
-			*val = rtw_read8(padapter, SDIO_LOCAL_BASE|SDIO_REG_HCPWM1_8188F);
-			break;
-
-		case HW_VAR_FW_PS_STATE:
-			{
-				//3. read dword 0x88               //driver read fw ps state
-				*((u16*)val) = rtw_read16(padapter, 0x88);
-			}
-			break;
-		default:
-			GetHwReg8188F(padapter, variable, val);
-			break;
+	switch (variable) {
+	case HW_VAR_CPWM:
+		*val = rtw_read8(padapter, SDIO_LOCAL_BASE | SDIO_REG_HCPWM1_8188F);
+		break;
+
+	case HW_VAR_FW_PS_STATE: {
+		/* read dword 0x88, driver read fw ps state */
+		*((u16 *)val) = rtw_read16(padapter, 0x88);
+	}
+		break;
+	default:
+		GetHwReg8188F(padapter, variable, val);
+		break;
 	}
 
-_func_exit_;
 }
 
-//
-//	Description:
-//		Query setting of specified variable.
-//
+/*
+ *	Description:
+ *		Query setting of specified variable.
+ *   */
 u8
 GetHalDefVar8188FSDIO(
 	IN	PADAPTER				Adapter,
 	IN	HAL_DEF_VARIABLE		eVariable,
 	IN	PVOID					pValue
-	)
+)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
 	u8			bResult = _SUCCESS;
 
-	switch(eVariable)
-	{
-		case HAL_DEF_IS_SUPPORT_ANT_DIV:
+	switch (eVariable) {
+	case HAL_DEF_IS_SUPPORT_ANT_DIV:
 #ifdef CONFIG_ANTENNA_DIVERSITY
-			*((u8 *)pValue) = _FALSE;
+		*((u8 *)pValue) = _FALSE;
 #endif
-			break;
-		case HAL_DEF_CURRENT_ANTENNA:
-#ifdef CONFIG_ANTENNA_DIVERSITY
-			*(( u8*)pValue) = pHalData->CurAntenna;
-#endif
-			break;
-		case HW_VAR_MAX_RX_AMPDU_FACTOR:
-			// Stanley@BB.SD3 suggests 16K can get stable performance
-			// coding by Lucas@20130730
-			*(HT_CAP_AMPDU_FACTOR*)pValue = MAX_AMPDU_FACTOR_16K;
-			break;
-		default:
-			bResult = GetHalDefVar8188F(Adapter, eVariable, pValue);
-			break;
+		break;
+
+	case HW_VAR_MAX_RX_AMPDU_FACTOR:
+		/* Stanley@BB.SD3 suggests 16K can get stable performance */
+		/* coding by Lucas@20130730 */
+		*(HT_CAP_AMPDU_FACTOR *)pValue = MAX_AMPDU_FACTOR_16K;
+		break;
+	default:
+		bResult = GetHalDefVar8188F(Adapter, eVariable, pValue);
+		break;
 	}
 
 	return bResult;
 }
 
-//
-//	Description:
-//		Change default setting of specified variable.
-//
+/*
+ *	Description:
+ *		Change default setting of specified variable.
+ *   */
 u8
 SetHalDefVar8188FSDIO(
 	IN	PADAPTER				Adapter,
 	IN	HAL_DEF_VARIABLE		eVariable,
 	IN	PVOID					pValue
-	)
+)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
 	u8			bResult = _SUCCESS;
 
-	switch(eVariable)
-	{
-		default:
-			bResult = SetHalDefVar8188F(Adapter, eVariable, pValue);
-			break;
+	switch (eVariable) {
+	default:
+		bResult = SetHalDefVar8188F(Adapter, eVariable, pValue);
+		break;
 	}
 
 	return bResult;
@@ -1829,9 +1556,8 @@ SetHalDefVar8188FSDIO(
 
 void rtl8188fs_set_hal_ops(PADAPTER padapter)
 {
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 
-_func_enter_;
 
 	rtl8188f_set_hal_ops(pHalFunc);
 
@@ -1849,10 +1575,10 @@ _func_enter_;
 #ifdef CONFIG_RECV_THREAD_MODE
 	pHalFunc->recv_hdl = rtl8188fs_recv_hdl;
 #endif
-
+#ifdef CONFIG_RTW_SW_LED
 	pHalFunc->InitSwLeds = &rtl8188fs_InitSwLeds;
 	pHalFunc->DeInitSwLeds = &rtl8188fs_DeInitSwLeds;
-
+#endif
 	pHalFunc->init_default_value = &rtl8188fs_init_default_value;
 	pHalFunc->intf_chip_configure = &rtl8188fs_interface_configure;
 	pHalFunc->read_adapter_info = &ReadAdapterInfo8188FS;
@@ -1864,10 +1590,10 @@ _func_enter_;
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 	pHalFunc->clear_interrupt = &ClearInterrupt8188FSdio;
 #endif
-	pHalFunc->SetHwRegHandler = &SetHwReg8188FS;
+	pHalFunc->set_hw_reg_handler = &SetHwReg8188FS;
 	pHalFunc->GetHwRegHandler = &GetHwReg8188FS;
-	pHalFunc->GetHalDefVarHandler = &GetHalDefVar8188FSDIO;
- 	pHalFunc->SetHalDefVarHandler = &SetHalDefVar8188FSDIO;
+	pHalFunc->get_hal_def_var_handler = &GetHalDefVar8188FSDIO;
+	pHalFunc->SetHalDefVarHandler = &SetHalDefVar8188FSDIO;
 
 	pHalFunc->hal_xmit = &rtl8188fs_hal_xmit;
 	pHalFunc->mgnt_xmit = &rtl8188fs_mgnt_xmit;
@@ -1884,7 +1610,4 @@ _func_enter_;
 	pHalFunc->hal_checke_bt_hang = &rtl8188fs_hal_check_bt_hang;
 #endif
 
-_func_exit_;
 }
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_ops.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_ops.c
index 780bd144711f..6aa3c76415a8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_ops.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/hal/rtl8188f/sdio/sdio_ops.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,16 +12,12 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
+ *****************************************************************************/
 #define _SDIO_OPS_C_
 
 #include <rtl8188f_hal.h>
 
-//#define SDIO_DEBUG_IO 1
+/* #define SDIO_DEBUG_IO 1 */
 #define CONFIG_RTW_SDIO_REG_FORCE_CMD52 0
 
 #define SDIO_LOCAL_CMD_ADDR(addr) ((SDIO_LOCAL_DEVICE_ID << 13) | ((addr) & SDIO_LOCAL_MSK))
@@ -31,47 +28,46 @@
 #define WLAN_TXEXQ_CMD_ADDR(r4_cnt) ((WLAN_TX_EXQ_DEVICE_ID << 13) | ((r4_cnt) & WLAN_FIFO_MSK))
 #define WLAN_RX0FF_CMD_ADDR(seq) ((WLAN_RX0FF_DEVICE_ID << 13) | ((seq) & WLAN_RX0FF_MSK))
 
-//
-// Description:
-//	The following mapping is for SDIO host local register space.
-//
-// Creadted by Roger, 2011.01.31.
-//
+/*
+ * Description:
+ *	The following mapping is for SDIO host local register space.
+ *
+ * Creadted by Roger, 2011.01.31.
+ *   */
 static void HalSdioGetCmdAddr8188FSdio(
 	IN	PADAPTER			padapter,
-	IN 	u8				DeviceID,
+	IN	u8				DeviceID,
 	IN	u32				Addr,
-	OUT	u32*				pCmdAddr
-	)
+	OUT	u32				*pCmdAddr
+)
 {
-	switch (DeviceID)
-	{
-		case SDIO_LOCAL_DEVICE_ID:
-			*pCmdAddr = ((SDIO_LOCAL_DEVICE_ID << 13) | (Addr & SDIO_LOCAL_MSK));
-			break;
+	switch (DeviceID) {
+	case SDIO_LOCAL_DEVICE_ID:
+		*pCmdAddr = ((SDIO_LOCAL_DEVICE_ID << 13) | (Addr & SDIO_LOCAL_MSK));
+		break;
 
-		case WLAN_IOREG_DEVICE_ID:
-			*pCmdAddr = ((WLAN_IOREG_DEVICE_ID << 13) | (Addr & WLAN_IOREG_MSK));
-			break;
+	case WLAN_IOREG_DEVICE_ID:
+		*pCmdAddr = ((WLAN_IOREG_DEVICE_ID << 13) | (Addr & WLAN_IOREG_MSK));
+		break;
 
-		case WLAN_TX_HIQ_DEVICE_ID:
-			*pCmdAddr = ((WLAN_TX_HIQ_DEVICE_ID << 13) | (Addr & WLAN_FIFO_MSK));
-			break;
+	case WLAN_TX_HIQ_DEVICE_ID:
+		*pCmdAddr = ((WLAN_TX_HIQ_DEVICE_ID << 13) | (Addr & WLAN_FIFO_MSK));
+		break;
 
-		case WLAN_TX_MIQ_DEVICE_ID:
-			*pCmdAddr = ((WLAN_TX_MIQ_DEVICE_ID << 13) | (Addr & WLAN_FIFO_MSK));
-			break;
+	case WLAN_TX_MIQ_DEVICE_ID:
+		*pCmdAddr = ((WLAN_TX_MIQ_DEVICE_ID << 13) | (Addr & WLAN_FIFO_MSK));
+		break;
 
-		case WLAN_TX_LOQ_DEVICE_ID:
-			*pCmdAddr = ((WLAN_TX_LOQ_DEVICE_ID << 13) | (Addr & WLAN_FIFO_MSK));
-			break;
+	case WLAN_TX_LOQ_DEVICE_ID:
+		*pCmdAddr = ((WLAN_TX_LOQ_DEVICE_ID << 13) | (Addr & WLAN_FIFO_MSK));
+		break;
 
-		case WLAN_RX0FF_DEVICE_ID:
-			*pCmdAddr = ((WLAN_RX0FF_DEVICE_ID << 13) | (Addr & WLAN_RX0FF_MSK));
-			break;
+	case WLAN_RX0FF_DEVICE_ID:
+		*pCmdAddr = ((WLAN_RX0FF_DEVICE_ID << 13) | (Addr & WLAN_RX0FF_MSK));
+		break;
 
-		default:
-			break;
+	default:
+		break;
 	}
 }
 
@@ -82,40 +78,39 @@ static u8 get_deviceid(u32 addr)
 
 
 	pseudoId = (u16)(addr >> 16);
-	switch (pseudoId)
-	{
-		case 0x1025:
-			devideId = SDIO_LOCAL_DEVICE_ID;
-			break;
-
-		case 0x1026:
-			devideId = WLAN_IOREG_DEVICE_ID;
-			break;
-
-//		case 0x1027:
-//			devideId = SDIO_FIRMWARE_FIFO;
-//			break;
-
-		case 0x1031:
-			devideId = WLAN_TX_HIQ_DEVICE_ID;
-			break;
-
-		case 0x1032:
-			devideId = WLAN_TX_MIQ_DEVICE_ID;
-			break;
-
-		case 0x1033:
-			devideId = WLAN_TX_LOQ_DEVICE_ID;
-			break;
-
-		case 0x1034:
-			devideId = WLAN_RX0FF_DEVICE_ID;
-			break;
-
-		default:
-//			devideId = (u8)((addr >> 13) & 0xF);
-			devideId = WLAN_IOREG_DEVICE_ID;
-			break;
+	switch (pseudoId) {
+	case 0x1025:
+		devideId = SDIO_LOCAL_DEVICE_ID;
+		break;
+
+	case 0x1026:
+		devideId = WLAN_IOREG_DEVICE_ID;
+		break;
+
+	/*		case 0x1027:
+	 *			devideId = SDIO_FIRMWARE_FIFO;
+	 *			break; */
+
+	case 0x1031:
+		devideId = WLAN_TX_HIQ_DEVICE_ID;
+		break;
+
+	case 0x1032:
+		devideId = WLAN_TX_MIQ_DEVICE_ID;
+		break;
+
+	case 0x1033:
+		devideId = WLAN_TX_LOQ_DEVICE_ID;
+		break;
+
+	case 0x1034:
+		devideId = WLAN_RX0FF_DEVICE_ID;
+		break;
+
+	default:
+		/*			devideId = (u8)((addr >> 13) & 0xF); */
+		devideId = WLAN_IOREG_DEVICE_ID;
+		break;
 	}
 
 	return devideId;
@@ -135,32 +130,33 @@ static u32 _cvrt2ftaddr(const u32 addr, u8 *pdeviceId, u16 *poffset)
 	deviceId = get_deviceid(addr);
 	offset = 0;
 
-	switch (deviceId)
-	{
-		case SDIO_LOCAL_DEVICE_ID:
-			offset = addr & SDIO_LOCAL_MSK;
-			break;
-
-		case WLAN_TX_HIQ_DEVICE_ID:
-		case WLAN_TX_MIQ_DEVICE_ID:
-		case WLAN_TX_LOQ_DEVICE_ID:
-			offset = addr & WLAN_FIFO_MSK;
-			break;
-
-		case WLAN_RX0FF_DEVICE_ID:
-			offset = addr & WLAN_RX0FF_MSK;
-			break;
-
-		case WLAN_IOREG_DEVICE_ID:
-		default:
-			deviceId = WLAN_IOREG_DEVICE_ID;
-			offset = addr & WLAN_IOREG_MSK;
-			break;
+	switch (deviceId) {
+	case SDIO_LOCAL_DEVICE_ID:
+		offset = addr & SDIO_LOCAL_MSK;
+		break;
+
+	case WLAN_TX_HIQ_DEVICE_ID:
+	case WLAN_TX_MIQ_DEVICE_ID:
+	case WLAN_TX_LOQ_DEVICE_ID:
+		offset = addr & WLAN_FIFO_MSK;
+		break;
+
+	case WLAN_RX0FF_DEVICE_ID:
+		offset = addr & WLAN_RX0FF_MSK;
+		break;
+
+	case WLAN_IOREG_DEVICE_ID:
+	default:
+		deviceId = WLAN_IOREG_DEVICE_ID;
+		offset = addr & WLAN_IOREG_MSK;
+		break;
 	}
 	ftaddr = (deviceId << 13) | offset;
 
-	if (pdeviceId) *pdeviceId = deviceId;
-	if (poffset) *poffset = offset;
+	if (pdeviceId)
+		*pdeviceId = deviceId;
+	if (poffset)
+		*poffset = offset;
 
 	return ftaddr;
 }
@@ -180,7 +176,8 @@ static bool sdio_chk_hci_resume(struct intf_hdl *pintfhdl)
 	u8 hci_sus_state;
 	u8 sus_ctl, sus_ctl_ori = 0xEA;
 	u8 do_leave = 0;
-	u32 start = 0, end = 0, poll_cnt = 0;
+	systime start = 0, end = 0;
+	u32 poll_cnt = 0;
 	u8 timeout = 0;
 	u8 sr = 0;
 	s32 err = 0;
@@ -230,19 +227,19 @@ static bool sdio_chk_hci_resume(struct intf_hdl *pintfhdl)
 exit:
 
 	if (DBG_SDIO_CHK_HCI_RESUME) {
-		DBG_871X(FUNC_ADPT_FMT" hci_sus_state:%u, sus_ctl:0x%02x(0x%02x), do_leave:%u, to:%u, err:%u\n"
+		RTW_INFO(FUNC_ADPT_FMT" hci_sus_state:%u, sus_ctl:0x%02x(0x%02x), do_leave:%u, to:%u, err:%u\n"
 			, FUNC_ADPT_ARG(adapter), hci_sus_state, sus_ctl, sus_ctl_ori, do_leave, timeout, err);
 		if (start != 0 || end != 0) {
-			DBG_871X(FUNC_ADPT_FMT" polling %d ms, cnt:%u\n"
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms, cnt:%u\n"
 				, FUNC_ADPT_ARG(adapter), rtw_get_time_interval_ms(start, end), poll_cnt);
 		}
 	}
 
 	if (timeout) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" timeout(err:%d) sus_ctl:0x%02x\n"
+		RTW_ERR(FUNC_ADPT_FMT" timeout(err:%d) sus_ctl:0x%02x\n"
 			, FUNC_ADPT_ARG(adapter), err, sus_ctl);
 	} else if (err) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" err:%d\n"
+		RTW_ERR(FUNC_ADPT_FMT" err:%d\n"
 			, FUNC_ADPT_ARG(adapter), err);
 	}
 
@@ -257,7 +254,8 @@ void sdio_chk_hci_suspend(struct intf_hdl *pintfhdl)
 	_adapter *adapter = pintfhdl->padapter;
 	u8 hci_sus_state;
 	u8 sus_ctl, sus_ctl_ori = 0xEA;
-	u32 start = 0, end = 0, poll_cnt = 0;
+	systime start = 0, end = 0;
+	u32 poll_cnt = 0;
 	u8 timeout = 0;
 	u8 sr = 0;
 	s32 err = 0;
@@ -281,7 +279,7 @@ void sdio_chk_hci_suspend(struct intf_hdl *pintfhdl)
 	if (err)
 		goto exit;
 
-	#if SDIO_CHK_HCI_SUSPEND_POLLING
+#if SDIO_CHK_HCI_SUSPEND_POLLING
 	/* polling for HCI_RESUME_PWR_RDY cleared */
 	start = rtw_get_current_time();
 	while (1) {
@@ -302,29 +300,29 @@ void sdio_chk_hci_suspend(struct intf_hdl *pintfhdl)
 		}
 	}
 	end = rtw_get_current_time();
-	#endif /* SDIO_CHK_HCI_SUSPEND_POLLING */
+#endif /* SDIO_CHK_HCI_SUSPEND_POLLING */
 
 exit:
 
 	if (DBG_SDIO_CHK_HCI_RESUME) {
-		DBG_871X(FUNC_ADPT_FMT" hci_sus_state:%u, sus_ctl:0x%02x(0x%02x), to:%u, err:%u\n"
+		RTW_INFO(FUNC_ADPT_FMT" hci_sus_state:%u, sus_ctl:0x%02x(0x%02x), to:%u, err:%u\n"
 			, FUNC_ADPT_ARG(adapter), hci_sus_state, sus_ctl, sus_ctl_ori, timeout, err);
 		if (start != 0 || end != 0) {
-			DBG_871X(FUNC_ADPT_FMT" polling %d ms, cnt:%u\n"
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms, cnt:%u\n"
 				, FUNC_ADPT_ARG(adapter), rtw_get_time_interval_ms(start, end), poll_cnt);
 		}
 	}
 
-	#if SDIO_CHK_HCI_SUSPEND_POLLING
+#if SDIO_CHK_HCI_SUSPEND_POLLING
 	if (timeout) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" timeout(err:%d) sus_ctl:0x%02x\n"
+		RTW_ERR(FUNC_ADPT_FMT" timeout(err:%d) sus_ctl:0x%02x\n"
 			, FUNC_ADPT_ARG(adapter), err, sus_ctl);
 	} else
-	#endif
-	if (err) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" err:%d\n"
-			, FUNC_ADPT_ARG(adapter), err);
-	}
+#endif
+		if (err) {
+			RTW_ERR(FUNC_ADPT_FMT" err:%d\n"
+				, FUNC_ADPT_ARG(adapter), err);
+		}
 
 no_hdl:
 	return;
@@ -370,7 +368,7 @@ u16 sdio_read16(struct intf_hdl *pintfhdl, u32 addr)
 		sus_leave = sdio_chk_hci_resume(pintfhdl);
 
 	val = 0;
-	sd_cmd52_read(pintfhdl, ftaddr, 2, (u8*)&val);
+	sd_cmd52_read(pintfhdl, ftaddr, 2, (u8 *)&val);
 	val = le16_to_cpu(val);
 
 	if (sus_leave == _TRUE)
@@ -390,7 +388,6 @@ u32 sdio_read32(struct intf_hdl *pintfhdl, u32 addr)
 	u32 val;
 	s32 err;
 
-_func_enter_;
 
 	padapter = pintfhdl->padapter;
 	ftaddr = _cvrt2ftaddr(addr, &deviceId, &offset);
@@ -411,7 +408,7 @@ _func_enter_;
 			sus_leave = sdio_chk_hci_resume(pintfhdl);
 
 		val = 0;
-		err = sd_cmd52_read(pintfhdl, ftaddr, 4, (u8*)&val);
+		err = sd_cmd52_read(pintfhdl, ftaddr, 4, (u8 *)&val);
 
 		if (sus_leave == _TRUE)
 			sdio_chk_hci_suspend(pintfhdl);
@@ -424,21 +421,21 @@ _func_enter_;
 #ifdef SDIO_DEBUG_IO
 		}
 
-		DBG_8192C(KERN_ERR "%s: Mac Power off, Read FAIL(%d)! addr=0x%x\n", __func__, err, addr);
+		RTW_ERR("%s: Mac Power off, Read FAIL(%d)! addr=0x%x\n", __func__, err, addr);
 		return SDIO_ERR_VAL32;
 #endif
 	}
 
-	// 4 bytes alignment
+	/* 4 bytes alignment */
 	shift = ftaddr & 0x3;
-	if (shift == 0) {
+	if (shift == 0)
 		val = sd_read32(pintfhdl, ftaddr, NULL);
-	} else {
+	else {
 		u8 *ptmpbuf;
 
-		ptmpbuf = (u8*)rtw_malloc(8);
+		ptmpbuf = (u8 *)rtw_malloc(8);
 		if (NULL == ptmpbuf) {
-			DBG_8192C(KERN_ERR "%s: Allocate memory FAIL!(size=8) addr=0x%x\n", __func__, addr);
+			RTW_ERR("%s: Allocate memory FAIL!(size=8) addr=0x%x\n", __func__, addr);
 			return SDIO_ERR_VAL32;
 		}
 
@@ -446,13 +443,12 @@ _func_enter_;
 		err = sd_read(pintfhdl, ftaddr, 8, ptmpbuf);
 		if (err)
 			return SDIO_ERR_VAL32;
-		_rtw_memcpy(&val, ptmpbuf+shift, 4);
+		_rtw_memcpy(&val, ptmpbuf + shift, 4);
 		val = le32_to_cpu(val);
 
 		rtw_mfree(ptmpbuf, 8);
 	}
 
-_func_exit_;
 
 	return val;
 }
@@ -467,7 +463,6 @@ s32 sdio_readN(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pbuf)
 	u8 shift;
 	s32 err;
 
-_func_enter_;
 
 	padapter = pintfhdl->padapter;
 	err = 0;
@@ -496,25 +491,25 @@ _func_enter_;
 		return err;
 	}
 
-	// 4 bytes alignment
+	/* 4 bytes alignment */
 	shift = ftaddr & 0x3;
-	if (shift == 0) {
+	if (shift == 0)
 		err = sd_read(pintfhdl, ftaddr, cnt, pbuf);
-	} else {
+	else {
 		u8 *ptmpbuf;
 		u32 n;
 
 		ftaddr &= ~(u16)0x3;
 		n = cnt + shift;
 		ptmpbuf = rtw_malloc(n);
-		if (NULL == ptmpbuf) return -1;
+		if (NULL == ptmpbuf)
+			return -1;
 		err = sd_read(pintfhdl, ftaddr, n, ptmpbuf);
 		if (!err)
-			_rtw_memcpy(pbuf, ptmpbuf+shift, cnt);
+			_rtw_memcpy(pbuf, ptmpbuf + shift, cnt);
 		rtw_mfree(ptmpbuf, n);
 	}
 
-_func_exit_;
 
 	return err;
 }
@@ -555,7 +550,7 @@ s32 sdio_write16(struct intf_hdl *pintfhdl, u32 addr, u16 val)
 		sus_leave = sdio_chk_hci_resume(pintfhdl);
 
 	val = cpu_to_le16(val);
-	err = sd_cmd52_write(pintfhdl, ftaddr, 2, (u8*)&val);
+	err = sd_cmd52_write(pintfhdl, ftaddr, 2, (u8 *)&val);
 
 	if (sus_leave == _TRUE)
 		sdio_chk_hci_suspend(pintfhdl);
@@ -573,7 +568,6 @@ s32 sdio_write32(struct intf_hdl *pintfhdl, u32 addr, u32 val)
 	u8 shift;
 	s32 err;
 
-_func_enter_;
 
 	padapter = pintfhdl->padapter;
 	err = 0;
@@ -596,7 +590,7 @@ _func_enter_;
 			sus_leave = sdio_chk_hci_resume(pintfhdl);
 
 		val = cpu_to_le32(val);
-		err = sd_cmd52_write(pintfhdl, ftaddr, 4, (u8*)&val);
+		err = sd_cmd52_write(pintfhdl, ftaddr, 4, (u8 *)&val);
 
 		if (sus_leave == _TRUE)
 			sdio_chk_hci_suspend(pintfhdl);
@@ -604,26 +598,24 @@ _func_enter_;
 		return err;
 	}
 
-	// 4 bytes alignment
+	/* 4 bytes alignment */
 	shift = ftaddr & 0x3;
 #if 1
 	if (shift == 0)
-	{
 		sd_write32(pintfhdl, ftaddr, val, &err);
-	}
-	else
-	{
+	else {
 		val = cpu_to_le32(val);
-		err = sd_cmd52_write(pintfhdl, ftaddr, 4, (u8*)&val);
+		err = sd_cmd52_write(pintfhdl, ftaddr, 4, (u8 *)&val);
 	}
 #else
-	if (shift == 0) {
+	if (shift == 0)
 		sd_write32(pintfhdl, ftaddr, val, &err);
-	} else {
+	else {
 		u8 *ptmpbuf;
 
-		ptmpbuf = (u8*)rtw_malloc(8);
-		if (NULL == ptmpbuf) return (-1);
+		ptmpbuf = (u8 *)rtw_malloc(8);
+		if (NULL == ptmpbuf)
+			return -1;
 
 		ftaddr &= ~(u16)0x3;
 		err = sd_read(pintfhdl, ftaddr, 8, ptmpbuf);
@@ -632,19 +624,18 @@ _func_enter_;
 			return err;
 		}
 		val = cpu_to_le32(val);
-		_rtw_memcpy(ptmpbuf+shift, &val, 4);
+		_rtw_memcpy(ptmpbuf + shift, &val, 4);
 		err = sd_write(pintfhdl, ftaddr, 8, ptmpbuf);
 
 		rtw_mfree(ptmpbuf, 8);
 	}
 #endif
 
-_func_exit_;
 
 	return err;
 }
 
-s32 sdio_writeN(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8* pbuf)
+s32 sdio_writeN(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pbuf)
 {
 	PADAPTER padapter;
 	u8 bMacPwrCtrlOn;
@@ -654,7 +645,6 @@ s32 sdio_writeN(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8* pbuf)
 	u8 shift;
 	s32 err;
 
-_func_enter_;
 
 	padapter = pintfhdl->padapter;
 	err = 0;
@@ -684,27 +674,27 @@ _func_enter_;
 	}
 
 	shift = ftaddr & 0x3;
-	if (shift == 0) {
+	if (shift == 0)
 		err = sd_write(pintfhdl, ftaddr, cnt, pbuf);
-	} else {
+	else {
 		u8 *ptmpbuf;
 		u32 n;
 
 		ftaddr &= ~(u16)0x3;
 		n = cnt + shift;
 		ptmpbuf = rtw_malloc(n);
-		if (NULL == ptmpbuf) return -1;
+		if (NULL == ptmpbuf)
+			return -1;
 		err = sd_read(pintfhdl, ftaddr, 4, ptmpbuf);
 		if (err) {
 			rtw_mfree(ptmpbuf, n);
 			return err;
 		}
-		_rtw_memcpy(ptmpbuf+shift, pbuf, cnt);
+		_rtw_memcpy(ptmpbuf + shift, pbuf, cnt);
 		err = sd_write(pintfhdl, ftaddr, n, ptmpbuf);
 		rtw_mfree(ptmpbuf, n);
 	}
 
-_func_exit_;
 
 	return err;
 }
@@ -714,10 +704,8 @@ u8 sdio_f0_read8(struct intf_hdl *pintfhdl, u32 addr)
 	u32 ftaddr;
 	u8 val;
 
-_func_enter_;
 	val = sd_f0_read8(pintfhdl, addr, NULL);
 
-_func_exit_;
 
 	return val;
 }
@@ -726,20 +714,16 @@ void sdio_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem)
 {
 	s32 err;
 
-_func_enter_;
 
 	err = sdio_readN(pintfhdl, addr, cnt, rmem);
 
-_func_exit_;
 }
 
 void sdio_write_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem)
 {
-_func_enter_;
 
 	sdio_writeN(pintfhdl, addr, cnt, wmem);
 
-_func_exit_;
 }
 
 /*
@@ -765,7 +749,6 @@ static u32 sdio_read_port(
 	u8 *mem)
 {
 	PADAPTER padapter;
-	PSDIO_DATA psdio;
 	PHAL_DATA_TYPE phal;
 	u32 oldcnt;
 #ifdef SDIO_DYNAMIC_ALLOC_MEM
@@ -775,28 +758,25 @@ static u32 sdio_read_port(
 
 
 	padapter = pintfhdl->padapter;
-	psdio = &adapter_to_dvobj(padapter)->intf_data;
 	phal = GET_HAL_DATA(padapter);
 
 	HalSdioGetCmdAddr8188FSdio(padapter, addr, phal->SdioRxFIFOCnt++, &addr);
 
 	oldcnt = cnt;
-	if (cnt > psdio->block_transfer_len)
-		cnt = _RND(cnt, psdio->block_transfer_len);
-//	cnt = sdio_align_size(cnt);
+	cnt = rtw_sdio_cmd53_align_size(adapter_to_dvobj(padapter), cnt);
 
 	if (oldcnt != cnt) {
 #ifdef SDIO_DYNAMIC_ALLOC_MEM
 		oldmem = mem;
 		mem = rtw_malloc(cnt);
 		if (mem == NULL) {
-			DBG_8192C(KERN_WARNING "%s: allocate memory %d bytes fail!\n", __func__, cnt);
+			RTW_WARN("%s: allocate memory %d bytes fail!\n", __func__, cnt);
 			mem = oldmem;
 			oldmem == NULL;
 		}
 #else
-		// in this case, caller should gurante the buffer is big enough
-		// to receive data after alignment
+		/* in this case, caller should gurante the buffer is big enough */
+		/* to receive data after alignment */
 #endif
 	}
 
@@ -809,7 +789,8 @@ static u32 sdio_read_port(
 	}
 #endif
 
-	if (err) return _FAIL;
+	if (err)
+		return _FAIL;
 	return _SUCCESS;
 }
 
@@ -836,31 +817,28 @@ static u32 sdio_write_port(
 	u8 *mem)
 {
 	PADAPTER padapter;
-	PSDIO_DATA psdio;
 	s32 err;
 	struct xmit_buf *xmitbuf = (struct xmit_buf *)mem;
 
 	padapter = pintfhdl->padapter;
-	psdio = &adapter_to_dvobj(padapter)->intf_data;
 
 	if (!rtw_is_hw_init_completed(padapter)) {
-		DBG_871X("%s [addr=0x%x cnt=%d] padapter->hw_init_completed == _FALSE\n",__func__,addr,cnt);
+		RTW_INFO("%s [addr=0x%x cnt=%d] padapter->hw_init_completed == _FALSE\n", __func__, addr, cnt);
 		return _FAIL;
 	}
 
 	cnt = _RND4(cnt);
 	HalSdioGetCmdAddr8188FSdio(padapter, addr, cnt >> 2, &addr);
 
-	if (cnt > psdio->block_transfer_len)
-		cnt = _RND(cnt, psdio->block_transfer_len);
-//	cnt = sdio_align_size(cnt);
+	cnt = rtw_sdio_cmd53_align_size(adapter_to_dvobj(padapter), cnt);
 
 	err = sd_write(pintfhdl, addr, cnt, xmitbuf->pdata);
 
 	rtw_sctx_done_err(&xmitbuf->sctx,
-		err ? RTW_SCTX_DONE_WRITE_PORT_ERR : RTW_SCTX_DONE_SUCCESS);
+		  err ? RTW_SCTX_DONE_WRITE_PORT_ERR : RTW_SCTX_DONE_SUCCESS);
 
-	if (err) return _FAIL;
+	if (err)
+		return _FAIL;
 	return _SUCCESS;
 }
 
@@ -873,14 +851,14 @@ s32 _sdio_local_read(
 	u32			cnt,
 	u8			*pbuf)
 {
-	struct intf_hdl * pintfhdl;
+	struct intf_hdl *pintfhdl;
 	u8 bMacPwrCtrlOn;
 	s32 err;
 	u8 *ptmpbuf;
 	u32 n;
 
 
-	pintfhdl=&padapter->iopriv.intf;
+	pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 
@@ -894,9 +872,9 @@ s32 _sdio_local_read(
 	}
 
 	n = RND4(cnt);
-	ptmpbuf = (u8*)rtw_malloc(n);
+	ptmpbuf = (u8 *)rtw_malloc(n);
 	if (!ptmpbuf)
-		return (-1);
+		return -1;
 
 	err = _sd_read(pintfhdl, addr, n, ptmpbuf);
 	if (!err)
@@ -917,13 +895,13 @@ s32 sdio_local_read(
 	u32			cnt,
 	u8			*pbuf)
 {
-	struct intf_hdl * pintfhdl;
+	struct intf_hdl *pintfhdl;
 	u8 bMacPwrCtrlOn;
 	s32 err;
 	u8 *ptmpbuf;
 	u32 n;
 
-	pintfhdl=&padapter->iopriv.intf;
+	pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 
@@ -940,9 +918,9 @@ s32 sdio_local_read(
 	}
 
 	n = RND4(cnt);
-	ptmpbuf = (u8*)rtw_malloc(n);
+	ptmpbuf = (u8 *)rtw_malloc(n);
 	if (!ptmpbuf)
-		return (-1);
+		return -1;
 
 	err = sd_read(pintfhdl, addr, n, ptmpbuf);
 	if (!err)
@@ -963,18 +941,18 @@ s32 _sdio_local_write(
 	u32			cnt,
 	u8			*pbuf)
 {
-	struct intf_hdl * pintfhdl;
+	struct intf_hdl *pintfhdl;
 	u8 bMacPwrCtrlOn;
 	s32 err;
 	u8 *ptmpbuf;
 
-	if(addr & 0x3)
-		DBG_8192C("%s, address must be 4 bytes alignment\n", __FUNCTION__);
+	if (addr & 0x3)
+		RTW_INFO("%s, address must be 4 bytes alignment\n", __FUNCTION__);
 
-	if(cnt  & 0x3)
-		DBG_8192C("%s, size must be the multiple of 4 \n", __FUNCTION__);
+	if (cnt  & 0x3)
+		RTW_INFO("%s, size must be the multiple of 4\n", __FUNCTION__);
 
-	pintfhdl=&padapter->iopriv.intf;
+	pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 
@@ -990,9 +968,9 @@ s32 _sdio_local_write(
 		return err;
 	}
 
-	ptmpbuf = (u8*)rtw_malloc(cnt);
+	ptmpbuf = (u8 *)rtw_malloc(cnt);
 	if (!ptmpbuf)
-		return (-1);
+		return -1;
 
 	_rtw_memcpy(ptmpbuf, pbuf, cnt);
 
@@ -1013,18 +991,18 @@ s32 sdio_local_write(
 	u32		cnt,
 	u8		*pbuf)
 {
-	struct intf_hdl * pintfhdl;
+	struct intf_hdl *pintfhdl;
 	u8 bMacPwrCtrlOn;
 	s32 err;
 	u8 *ptmpbuf;
 
-	if(addr & 0x3)
-		DBG_8192C("%s, address must be 4 bytes alignment\n", __FUNCTION__);
+	if (addr & 0x3)
+		RTW_INFO("%s, address must be 4 bytes alignment\n", __FUNCTION__);
 
-	if(cnt  & 0x3)
-		DBG_8192C("%s, size must be the multiple of 4 \n", __FUNCTION__);
+	if (cnt  & 0x3)
+		RTW_INFO("%s, size must be the multiple of 4\n", __FUNCTION__);
 
-	pintfhdl=&padapter->iopriv.intf;
+	pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 
@@ -1040,9 +1018,9 @@ s32 sdio_local_write(
 		return err;
 	}
 
-	ptmpbuf = (u8*)rtw_malloc(cnt);
+	ptmpbuf = (u8 *)rtw_malloc(cnt);
 	if (!ptmpbuf)
-		return (-1);
+		return -1;
 
 	_rtw_memcpy(ptmpbuf, pbuf, cnt);
 
@@ -1055,9 +1033,9 @@ s32 sdio_local_write(
 }
 
 u8 SdioLocalCmd52Read1Byte(PADAPTER padapter, u32 addr)
-{	
+{
 	u8 val = 0;
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 	sd_cmd52_read(pintfhdl, addr, 1, &val);
@@ -1066,12 +1044,12 @@ u8 SdioLocalCmd52Read1Byte(PADAPTER padapter, u32 addr)
 }
 
 u16 SdioLocalCmd52Read2Byte(PADAPTER padapter, u32 addr)
-{	
+{
 	u16 val = 0;
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
-	sd_cmd52_read(pintfhdl, addr, 2, (u8*)&val);
+	sd_cmd52_read(pintfhdl, addr, 2, (u8 *)&val);
 
 	val = le16_to_cpu(val);
 
@@ -1079,12 +1057,12 @@ u16 SdioLocalCmd52Read2Byte(PADAPTER padapter, u32 addr)
 }
 
 u32 SdioLocalCmd52Read4Byte(PADAPTER padapter, u32 addr)
-{	
+{
 	u32 val = 0;
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
-	sd_cmd52_read(pintfhdl, addr, 4, (u8*)&val);
+	sd_cmd52_read(pintfhdl, addr, 4, (u8 *)&val);
 
 	val = le32_to_cpu(val);
 
@@ -1093,10 +1071,10 @@ u32 SdioLocalCmd52Read4Byte(PADAPTER padapter, u32 addr)
 
 u32 SdioLocalCmd53Read4Byte(PADAPTER padapter, u32 addr)
 {
-	
+
 	u8 bMacPwrCtrlOn;
 	u32 val = 0;
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 	bMacPwrCtrlOn = _FALSE;
@@ -1107,10 +1085,9 @@ u32 SdioLocalCmd53Read4Byte(PADAPTER padapter, u32 addr)
 		#endif
 		|| CONFIG_RTW_SDIO_REG_FORCE_CMD52
 	) {
-		sd_cmd52_read(pintfhdl, addr, 4, (u8*)&val);
+		sd_cmd52_read(pintfhdl, addr, 4, (u8 *)&val);
 		val = le32_to_cpu(val);
-	}
-	else
+	} else
 		val = sd_read32(pintfhdl, addr, NULL);
 
 	return val;
@@ -1118,7 +1095,7 @@ u32 SdioLocalCmd53Read4Byte(PADAPTER padapter, u32 addr)
 
 void SdioLocalCmd52Write1Byte(PADAPTER padapter, u32 addr, u8 v)
 {
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 	sd_cmd52_write(pintfhdl, addr, 1, &v);
@@ -1126,19 +1103,19 @@ void SdioLocalCmd52Write1Byte(PADAPTER padapter, u32 addr, u8 v)
 
 void SdioLocalCmd52Write2Byte(PADAPTER padapter, u32 addr, u16 v)
 {
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 	v = cpu_to_le16(v);
-	sd_cmd52_write(pintfhdl, addr, 2, (u8*)&v);
+	sd_cmd52_write(pintfhdl, addr, 2, (u8 *)&v);
 }
 
 void SdioLocalCmd52Write4Byte(PADAPTER padapter, u32 addr, u32 v)
 {
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 	HalSdioGetCmdAddr8188FSdio(padapter, SDIO_LOCAL_DEVICE_ID, addr, &addr);
 	v = cpu_to_le32(v);
-	sd_cmd52_write(pintfhdl, addr, 4, (u8*)&v);
+	sd_cmd52_write(pintfhdl, addr, 4, (u8 *)&v);
 }
 
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
@@ -1151,13 +1128,13 @@ void SdioLocalCmd52Write4Byte(PADAPTER padapter, u32 addr, u32 v)
 #endif
 
 static s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v)
-{	
+{
 	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 	_mutex *mutex = &adapter_to_dvobj(padapter)->sd_indirect_access_mutex;
 
 	u8 val[4] = {0};
 	u8 cmd[4] = {0}; /* mapping to indirect access register, little endien */
-	u32 start = 0, end = 0;
+	systime start = 0, end = 0;
 	u8 timeout = 0;
 	u8 sr = 0;
 	s32 err = 0;
@@ -1175,7 +1152,7 @@ static s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 	_enter_critical_mutex(mutex, NULL);
 
 	if (DBG_SDIO_INDIRECT_ACCESS)
-		DBG_871X(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
 
 	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG_8188F), 3, cmd);
 	if (err)
@@ -1185,7 +1162,7 @@ static s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 	SET_INDIRECT_REG_READ(cmd);
 
 	if (DBG_SDIO_INDIRECT_ACCESS)
-		DBG_871X(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
 
 	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG_8188F + 2), 1, cmd + 2);
 	if (err)
@@ -1200,7 +1177,7 @@ static s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 		}
 
 		err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG_8188F + 2), 1, cmd + 2);
-		
+
 		if (!err && GET_INDIRECT_REG_RDY(cmd))
 			break;
 
@@ -1223,11 +1200,11 @@ static s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 
 	if (DBG_SDIO_INDIRECT_ACCESS) {
 		if (size == 1)
-			DBG_871X(FUNC_ADPT_FMT" val:0x%02x\n", FUNC_ADPT_ARG(padapter), *((u8 *)(val)));
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%02x\n", FUNC_ADPT_ARG(padapter), *((u8 *)(val)));
 		else if (size == 2)
-			DBG_871X(FUNC_ADPT_FMT" val:0x%04x\n", FUNC_ADPT_ARG(padapter), *((u16 *)(val)));
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%04x\n", FUNC_ADPT_ARG(padapter), *((u16 *)(val)));
 		else if (size == 4)
-			DBG_871X(FUNC_ADPT_FMT" val:0x%08x\n", FUNC_ADPT_ARG(padapter), *((u32 *)(val)));
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%08x\n", FUNC_ADPT_ARG(padapter), *((u32 *)(val)));
 	}
 
 exit:
@@ -1235,21 +1212,21 @@ exit:
 	_exit_critical_mutex(mutex, NULL);
 
 	if (DBG_SDIO_INDIRECT_ACCESS) {
-		DBG_871X(FUNC_ADPT_FMT" addr:0x%0x size:%u, cmd:%02x %02x %02x %02x, to:%u, err:%u\n"
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%0x size:%u, cmd:%02x %02x %02x %02x, to:%u, err:%u\n"
 			, FUNC_ADPT_ARG(padapter), addr, size, cmd[0], cmd[1], cmd[2], cmd[3], timeout, err);
 		if (start != 0 || end != 0) {
-			DBG_871X(FUNC_ADPT_FMT" polling %d ms\n"
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms\n"
 				, FUNC_ADPT_ARG(padapter), rtw_get_time_interval_ms(start, end));
 		}
 	}
 
 	if (timeout) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" addr:0x%0x timeout(err:%d), cmd\n"
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x timeout(err:%d), cmd\n"
 			, FUNC_ADPT_ARG(padapter), addr, err);
 		if (!err)
 			err = -1; /* just for return value */
 	} else if (err) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" addr:0x%0x err:%d\n"
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x err:%d\n"
 			, FUNC_ADPT_ARG(padapter), addr, err);
 	} else if (sr) {
 		/* just for return value */
@@ -1263,13 +1240,13 @@ exit:
 }
 
 static s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v)
-{	
+{
 	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 	_mutex *mutex = &adapter_to_dvobj(padapter)->sd_indirect_access_mutex;
 
 	u8 val[4] = {0};
 	u8 cmd[4] = {0}; /* mapping to indirect access register, little endien */
-	u32 start = 0, end = 0;
+	systime start = 0, end = 0;
 	u8 timeout = 0;
 	u8 sr = 0;
 	s32 err = 0;
@@ -1287,7 +1264,7 @@ static s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 	_enter_critical_mutex(mutex, NULL);
 
 	if (DBG_SDIO_INDIRECT_ACCESS)
-		DBG_871X(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
 
 	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG_8188F), 3, cmd);
 	if (err)
@@ -1298,11 +1275,11 @@ static s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 
 	if (DBG_SDIO_INDIRECT_ACCESS) {
 		if (size == 1)
-			DBG_871X(FUNC_ADPT_FMT" val:0x%02x\n", FUNC_ADPT_ARG(padapter), *((u8 *)(val)));
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%02x\n", FUNC_ADPT_ARG(padapter), *((u8 *)(val)));
 		else if (size == 2)
-			DBG_871X(FUNC_ADPT_FMT" val:0x%04x\n", FUNC_ADPT_ARG(padapter), *((u16 *)(val)));
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%04x\n", FUNC_ADPT_ARG(padapter), *((u16 *)(val)));
 		else if (size == 4)
-			DBG_871X(FUNC_ADPT_FMT" val:0x%08x\n", FUNC_ADPT_ARG(padapter), *((u32 *)(val)));
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%08x\n", FUNC_ADPT_ARG(padapter), *((u32 *)(val)));
 	}
 
 	if (size == 2)
@@ -1318,7 +1295,7 @@ static s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 	SET_INDIRECT_REG_WRITE(cmd);
 
 	if (DBG_SDIO_INDIRECT_ACCESS)
-		DBG_871X(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
 
 	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG_8188F + 2), 1, cmd + 2);
 	if (err)
@@ -1333,7 +1310,7 @@ static s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v)
 		}
 
 		err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG_8188F + 2), 1, cmd + 2);
-		
+
 		if (!err && GET_INDIRECT_REG_RDY(cmd))
 			break;
 
@@ -1352,21 +1329,21 @@ exit:
 	_exit_critical_mutex(mutex, NULL);
 
 	if (DBG_SDIO_INDIRECT_ACCESS) {
-		DBG_871X(FUNC_ADPT_FMT" addr:0x%0x size:%u, cmd:%02x %02x %02x %02x, to:%u, err:%u\n"
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%0x size:%u, cmd:%02x %02x %02x %02x, to:%u, err:%u\n"
 			, FUNC_ADPT_ARG(padapter), addr, size, cmd[0], cmd[1], cmd[2], cmd[3], timeout, err);
 		if (start != 0 || end != 0) {
-			DBG_871X(FUNC_ADPT_FMT" polling %d ms\n"
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms\n"
 				, FUNC_ADPT_ARG(padapter), rtw_get_time_interval_ms(start, end));
 		}
 	}
 
 	if (timeout) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" addr:0x%0x timeout(err:%d), cmd\n"
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x timeout(err:%d), cmd\n"
 			, FUNC_ADPT_ARG(padapter), addr, err);
 		if (!err)
 			err = -1; /* just for return value */
 	} else if (err) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" addr:0x%0x err:%d\n"
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x err:%d\n"
 			, FUNC_ADPT_ARG(padapter), addr, err);
 	} else if (sr) {
 		/* just for return value */
@@ -1425,7 +1402,6 @@ s32 sdio_iwrite32(struct intf_hdl *pintfhdl, u32 addr, u32 val)
 
 void sdio_set_intf_ops(_adapter *padapter, struct _io_ops *pops)
 {
-_func_enter_;
 
 	pops->_read8 = &sdio_read8;
 	pops->_read16 = &sdio_read16;
@@ -1451,165 +1427,8 @@ _func_enter_;
 	pops->_sd_iwrite32 = sdio_iwrite32;
 #endif
 
-_func_exit_;
-}
-
-#if 0
-void
-DumpLoggedInterruptHistory8188Sdio(
-	PADAPTER		padapter
-)
-{
-	HAL_DATA_TYPE	*pHalData=GET_HAL_DATA(padapter);
-	u4Byte				DebugLevel = DBG_LOUD;
-
-	if (DBG_Var.DbgPrintIsr == 0)
-		return;
-
-	DBG_ChkDrvResource(padapter);
-
-
-	if(pHalData->InterruptLog.nISR_RX_REQUEST)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# RX_REQUEST[%ld]\t\n", pHalData->InterruptLog.nISR_RX_REQUEST));
-
-	if(pHalData->InterruptLog.nISR_AVAL)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# AVAL[%ld]\t\n", pHalData->InterruptLog.nISR_AVAL));
-
-	if(pHalData->InterruptLog.nISR_TXERR)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# TXERR[%ld]\t\n", pHalData->InterruptLog.nISR_TXERR));
-
-	if(pHalData->InterruptLog.nISR_RXERR)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# RXERR[%ld]\t\n", pHalData->InterruptLog.nISR_RXERR));
-
-	if(pHalData->InterruptLog.nISR_TXFOVW)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# TXFOVW[%ld]\t\n", pHalData->InterruptLog.nISR_TXFOVW));
-
-	if(pHalData->InterruptLog.nISR_RXFOVW)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# RXFOVW[%ld]\t\n", pHalData->InterruptLog.nISR_RXFOVW));
-
-	if(pHalData->InterruptLog.nISR_TXBCNOK)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# TXBCNOK[%ld]\t\n", pHalData->InterruptLog.nISR_TXBCNOK));
-
-	if(pHalData->InterruptLog.nISR_TXBCNERR)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# TXBCNERR[%ld]\t\n", pHalData->InterruptLog.nISR_TXBCNERR));
-
-	if(pHalData->InterruptLog.nISR_BCNERLY_INT)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# BCNERLY_INT[%ld]\t\n", pHalData->InterruptLog.nISR_BCNERLY_INT));
-
-	if(pHalData->InterruptLog.nISR_C2HCMD)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# C2HCMD[%ld]\t\n", pHalData->InterruptLog.nISR_C2HCMD));
-
-	if(pHalData->InterruptLog.nISR_CPWM1)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# CPWM1L[%ld]\t\n", pHalData->InterruptLog.nISR_CPWM1));
-
-	if(pHalData->InterruptLog.nISR_CPWM2)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# CPWM2[%ld]\t\n", pHalData->InterruptLog.nISR_CPWM2));
-
-	if(pHalData->InterruptLog.nISR_HSISR_IND)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# HSISR_IND[%ld]\t\n", pHalData->InterruptLog.nISR_HSISR_IND));
-
-	if(pHalData->InterruptLog.nISR_GTINT3_IND)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# GTINT3_IND[%ld]\t\n", pHalData->InterruptLog.nISR_GTINT3_IND));
-
-	if(pHalData->InterruptLog.nISR_GTINT4_IND)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# GTINT4_IND[%ld]\t\n", pHalData->InterruptLog.nISR_GTINT4_IND));
-
-	if(pHalData->InterruptLog.nISR_PSTIMEOUT)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# PSTIMEOUT[%ld]\t\n", pHalData->InterruptLog.nISR_PSTIMEOUT));
-
-	if(pHalData->InterruptLog.nISR_OCPINT)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# OCPINT[%ld]\t\n", pHalData->InterruptLog.nISR_OCPINT));
-
-	if(pHalData->InterruptLog.nISR_ATIMEND)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# ATIMEND[%ld]\t\n", pHalData->InterruptLog.nISR_ATIMEND));
-
-	if(pHalData->InterruptLog.nISR_ATIMEND_E)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# ATIMEND_E[%ld]\t\n", pHalData->InterruptLog.nISR_ATIMEND_E));
-
-	if(pHalData->InterruptLog.nISR_CTWEND)
-		RT_TRACE(COMP_SEND|COMP_RECV, DebugLevel, ("# CTWEND[%ld]\t\n", pHalData->InterruptLog.nISR_CTWEND));
 }
 
-void
-LogInterruptHistory8188Sdio(
-	PADAPTER			padapter,
-	PRT_ISR_CONTENT	pIsrContent
-)
-{
-	HAL_DATA_TYPE	*pHalData=GET_HAL_DATA(padapter);
-
-	if((pHalData->IntrMask[0] & SDIO_HIMR_RX_REQUEST_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_RX_REQUEST))
-		pHalData->InterruptLog.nISR_RX_REQUEST ++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_AVAL_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_AVAL))
-		pHalData->InterruptLog.nISR_AVAL++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_TXERR_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_TXERR))
-		pHalData->InterruptLog.nISR_TXERR++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_RXERR_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_RXERR))
-		pHalData->InterruptLog.nISR_RXERR++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_TXFOVW_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_TXFOVW))
-		pHalData->InterruptLog.nISR_TXFOVW++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_RXFOVW_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_RXFOVW))
-		pHalData->InterruptLog.nISR_RXFOVW++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_TXBCNOK_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_TXBCNOK))
-		pHalData->InterruptLog.nISR_TXBCNOK++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_TXBCNERR_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_TXBCNERR))
-		pHalData->InterruptLog.nISR_TXBCNERR++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_BCNERLY_INT_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_BCNERLY_INT))
-		pHalData->InterruptLog.nISR_BCNERLY_INT ++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_C2HCMD_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_C2HCMD))
-		pHalData->InterruptLog.nISR_C2HCMD++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_CPWM1_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_CPWM1))
-		pHalData->InterruptLog.nISR_CPWM1++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_CPWM2_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_CPWM2))
-		pHalData->InterruptLog.nISR_CPWM2++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_HSISR_IND_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_HSISR_IND))
-		pHalData->InterruptLog.nISR_HSISR_IND++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_GTINT3_IND_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_GTINT3_IND))
-		pHalData->InterruptLog.nISR_GTINT3_IND++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_GTINT4_IND_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_GTINT4_IND))
-		pHalData->InterruptLog.nISR_GTINT4_IND++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_PSTIMEOUT_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_PSTIMEOUT))
-		pHalData->InterruptLog.nISR_PSTIMEOUT++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_OCPINT_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_OCPINT))
-		pHalData->InterruptLog.nISR_OCPINT++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_ATIMEND_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_ATIMEND))
-		pHalData->InterruptLog.nISR_ATIMEND++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_ATIMEND_E_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_ATIMEND_E))
-		pHalData->InterruptLog.nISR_ATIMEND_E++;
-	if((pHalData->IntrMask[0] & SDIO_HIMR_CTWEND_MSK) &&
-		(pIsrContent->IntArray[0] & SDIO_HISR_CTWEND))
-		pHalData->InterruptLog.nISR_CTWEND++;
-
-}
-
-void
-DumpHardwareProfile8188Sdio(
-	IN	PADAPTER		padapter
-)
-{
-	DumpLoggedInterruptHistory8188Sdio(padapter);
-}
-#endif
-
 static s32 ReadInterrupt8188FSdio(PADAPTER padapter, u32 *phisr)
 {
 	u32 hisr, himr;
@@ -1621,10 +1440,9 @@ static s32 ReadInterrupt8188FSdio(PADAPTER padapter, u32 *phisr)
 
 	himr = GET_HAL_DATA(padapter)->sdio_himr;
 
-	// decide how many bytes need to be read
+	/* decide how many bytes need to be read */
 	hisr_len = 0;
-	while (himr)
-	{
+	while (himr) {
 		hisr_len++;
 		himr >>= 8;
 	}
@@ -1640,15 +1458,15 @@ static s32 ReadInterrupt8188FSdio(PADAPTER padapter, u32 *phisr)
 	return _TRUE;
 }
 
-//
-//	Description:
-//		Initialize SDIO Host Interrupt Mask configuration variables for future use.
-//
-//	Assumption:
-//		Using SDIO Local register ONLY for configuration.
-//
-//	Created by Roger, 2011.02.11.
-//
+/*
+ *	Description:
+ *		Initialize SDIO Host Interrupt Mask configuration variables for future use.
+ *
+ *	Assumption:
+ *		Using SDIO Local register ONLY for configuration.
+ *
+ *	Created by Roger, 2011.02.11.
+ *   */
 void InitInterrupt8188FSdio(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
@@ -1688,12 +1506,12 @@ void InitInterrupt8188FSdio(PADAPTER padapter)
 		;
 }
 
-//
-//	Description:
-//		Initialize System Host Interrupt Mask configuration variables for future use.
-//
-//	Created by Roger, 2011.08.03.
-//
+/*
+ *	Description:
+ *		Initialize System Host Interrupt Mask configuration variables for future use.
+ *
+ *	Created by Roger, 2011.08.03.
+ *   */
 void InitSysInterrupt8188FSdio(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
@@ -1701,25 +1519,25 @@ void InitSysInterrupt8188FSdio(PADAPTER padapter)
 
 	pHalData = GET_HAL_DATA(padapter);
 
-	pHalData->SysIntrMask = (			\
-//							HSIMR_GPIO12_0_INT_EN			|
-//							HSIMR_SPS_OCP_INT_EN			|
-//							HSIMR_RON_INT_EN				|
-//							HSIMR_PDNINT_EN				|
-//							HSIMR_GPIO9_INT_EN				|
-							0);
+	pHalData->SysIntrMask = (\
+				 /*							HSIMR_GPIO12_0_INT_EN			|
+				  *							HSIMR_SPS_OCP_INT_EN			|
+				  *							HSIMR_RON_INT_EN				|
+				  *							HSIMR_PDNINT_EN				|
+				  *							HSIMR_GPIO9_INT_EN				| */
+				 0);
 }
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-//
-//	Description:
-//		Clear corresponding SDIO Host ISR interrupt service.
-//
-//	Assumption:
-//		Using SDIO Local register ONLY for configuration.
-//
-//	Created by Roger, 2011.02.11.
-//
+/*
+ *	Description:
+ *		Clear corresponding SDIO Host ISR interrupt service.
+ *
+ *	Assumption:
+ *		Using SDIO Local register ONLY for configuration.
+ *
+ *	Created by Roger, 2011.02.11.
+ *   */
 void ClearInterrupt8188FSdio(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
@@ -1732,11 +1550,10 @@ void ClearInterrupt8188FSdio(PADAPTER padapter)
 	pHalData = GET_HAL_DATA(padapter);
 	clear = rtw_zmalloc(4);
 
-	// Clear corresponding HISR Content if needed
-	*(u32*)clear = cpu_to_le32(pHalData->sdio_hisr & MASK_SDIO_HISR_CLEAR);
-	if (*(u32*)clear)
-	{
-		// Perform write one clear operation
+	/* Clear corresponding HISR Content if needed */
+	*(u32 *)clear = cpu_to_le32(pHalData->sdio_hisr & MASK_SDIO_HISR_CLEAR);
+	if (*(u32 *)clear) {
+		/* Perform write one clear operation */
 		sdio_local_write(padapter, SDIO_REG_HISR, 4, clear);
 	}
 
@@ -1744,13 +1561,13 @@ void ClearInterrupt8188FSdio(PADAPTER padapter)
 }
 #endif
 
-//
-//	Description:
-//		Clear corresponding system Host ISR interrupt service.
-//
-//
-//	Created by Roger, 2011.02.11.
-//
+/*
+ *	Description:
+ *		Clear corresponding system Host ISR interrupt service.
+ *
+ *
+ *	Created by Roger, 2011.02.11.
+ *   */
 void ClearSysInterrupt8188FSdio(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
@@ -1762,25 +1579,24 @@ void ClearSysInterrupt8188FSdio(PADAPTER padapter)
 
 	pHalData = GET_HAL_DATA(padapter);
 
-	// Clear corresponding HISR Content if needed
+	/* Clear corresponding HISR Content if needed */
 	clear = pHalData->SysIntrStatus & MASK_HSISR_CLEAR;
-	if (clear)
-	{
-		// Perform write one clear operation
+	if (clear) {
+		/* Perform write one clear operation */
 		rtw_write32(padapter, REG_HSISR, clear);
 	}
 }
 
-//
-//	Description:
-//		Enalbe SDIO Host Interrupt Mask configuration on SDIO local domain.
-//
-//	Assumption:
-//		1. Using SDIO Local register ONLY for configuration.
-//		2. PASSIVE LEVEL
-//
-//	Created by Roger, 2011.02.11.
-//
+/*
+ *	Description:
+ *		Enalbe SDIO Host Interrupt Mask configuration on SDIO local domain.
+ *
+ *	Assumption:
+ *		1. Using SDIO Local register ONLY for configuration.
+ *		2. PASSIVE LEVEL
+ *
+ *	Created by Roger, 2011.02.11.
+ *   */
 void EnableInterrupt8188FSdio(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE pHalData;
@@ -1789,58 +1605,54 @@ void EnableInterrupt8188FSdio(PADAPTER padapter)
 	pHalData = GET_HAL_DATA(padapter);
 
 	himr = cpu_to_le32(pHalData->sdio_himr);
-	sdio_local_write(padapter, SDIO_REG_HIMR, 4, (u8*)&himr);
+	sdio_local_write(padapter, SDIO_REG_HIMR, 4, (u8 *)&himr);
 
-	RT_TRACE(_module_hci_ops_c_, _drv_notice_,
-		("%s: enable SDIO HIMR=0x%08X\n", __FUNCTION__, pHalData->sdio_himr));
 
-	// Update current system IMR settings
+	/* Update current system IMR settings */
 	himr = rtw_read32(padapter, REG_HSIMR);
-	rtw_write32(padapter, REG_HSIMR, himr|pHalData->SysIntrMask);
+	rtw_write32(padapter, REG_HSIMR, himr | pHalData->SysIntrMask);
 
-	RT_TRACE(_module_hci_ops_c_, _drv_notice_,
-		("%s: enable HSIMR=0x%08X\n", __FUNCTION__, pHalData->SysIntrMask));
 
-	//
-	// <Roger_Notes> There are some C2H CMDs have been sent before system interrupt is enabled, e.g., C2H, CPWM.
-	// So we need to clear all C2H events that FW has notified, otherwise FW won't schedule any commands anymore.
-	// 2011.10.19.
-	//
+	/*  */
+	/* <Roger_Notes> There are some C2H CMDs have been sent before system interrupt is enabled, e.g., C2H, CPWM. */
+	/* So we need to clear all C2H events that FW has notified, otherwise FW won't schedule any commands anymore. */
+	/* 2011.10.19. */
+	/*  */
 	rtw_write8(padapter, REG_C2HEVT_CLEAR, C2H_EVT_HOST_CLOSE);
 }
 
-//
-//	Description:
-//		Disable SDIO Host IMR configuration to mask unnecessary interrupt service.
-//
-//	Assumption:
-//		Using SDIO Local register ONLY for configuration.
-//
-//	Created by Roger, 2011.02.11.
-//
+/*
+ *	Description:
+ *		Disable SDIO Host IMR configuration to mask unnecessary interrupt service.
+ *
+ *	Assumption:
+ *		Using SDIO Local register ONLY for configuration.
+ *
+ *	Created by Roger, 2011.02.11.
+ *   */
 void DisableInterrupt8188FSdio(PADAPTER padapter)
 {
 	u32 himr;
 
 	himr = cpu_to_le32(SDIO_HIMR_DISABLED);
-	sdio_local_write(padapter, SDIO_REG_HIMR, 4, (u8*)&himr);
+	sdio_local_write(padapter, SDIO_REG_HIMR, 4, (u8 *)&himr);
 
 }
 
-//
-//	Description:
-//		Using 0x100 to check the power status of FW.
-//
-//	Assumption:
-//		Using SDIO Local register ONLY for configuration.
-//
-//	Created by Isaac, 2013.09.10.
-//
+/*
+ *	Description:
+ *		Using 0x100 to check the power status of FW.
+ *
+ *	Assumption:
+ *		Using SDIO Local register ONLY for configuration.
+ *
+ *	Created by Isaac, 2013.09.10.
+ *   */
 u8 CheckIPSStatus(PADAPTER padapter)
 {
-	DBG_871X("%s(): Read 0x100=0x%02x 0x86=0x%02x\n", __func__,
-		rtw_read8(padapter, 0x100),rtw_read8(padapter, 0x86));
-	
+	RTW_INFO("%s(): Read 0x100=0x%02x 0x86=0x%02x\n", __func__,
+		 rtw_read8(padapter, 0x100), rtw_read8(padapter, 0x86));
+
 	if (rtw_read8(padapter, 0x100) == 0xEA)
 		return _TRUE;
 	else
@@ -1852,26 +1664,26 @@ void DisableInterruptButCpwm28188FSdio(PADAPTER padapter)
 {
 	u32 himr, tmp;
 
-	sdio_local_read(padapter, SDIO_REG_HIMR, 4, (u8*)&tmp);
-	DBG_871X("DisableInterruptButCpwm28188FSdio(): Read SDIO_REG_HIMR: 0x%08x\n", tmp);
-	
-	himr = cpu_to_le32(SDIO_HIMR_DISABLED)|SDIO_HIMR_CPWM2_MSK;
-	sdio_local_write(padapter, SDIO_REG_HIMR, 4, (u8*)&himr);
+	sdio_local_read(padapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
+	RTW_INFO("DisableInterruptButCpwm28188FSdio(): Read SDIO_REG_HIMR: 0x%08x\n", tmp);
+
+	himr = cpu_to_le32(SDIO_HIMR_DISABLED) | SDIO_HIMR_CPWM2_MSK;
+	sdio_local_write(padapter, SDIO_REG_HIMR, 4, (u8 *)&himr);
 
-	sdio_local_read(padapter, SDIO_REG_HIMR, 4, (u8*)&tmp);
-	DBG_871X("DisableInterruptButCpwm28188FSdio(): Read again SDIO_REG_HIMR: 0x%08x\n", tmp);
+	sdio_local_read(padapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
+	RTW_INFO("DisableInterruptButCpwm28188FSdio(): Read again SDIO_REG_HIMR: 0x%08x\n", tmp);
 }
-#endif //CONFIG_WOWLAN
-//
-//	Description:
-//		Update SDIO Host Interrupt Mask configuration on SDIO local domain.
-//
-//	Assumption:
-//		1. Using SDIO Local register ONLY for configuration.
-//		2. PASSIVE LEVEL
-//
-//	Created by Roger, 2011.02.11.
-//
+#endif /* CONFIG_WOWLAN
+ *
+ *	Description:
+ *		Update SDIO Host Interrupt Mask configuration on SDIO local domain.
+ *
+ *	Assumption:
+ *		1. Using SDIO Local register ONLY for configuration.
+ *		2. PASSIVE LEVEL
+ *
+ *	Created by Roger, 2011.02.11.
+ *   */
 void UpdateInterruptMask8188FSdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR)
 {
 	HAL_DATA_TYPE *pHalData;
@@ -1897,23 +1709,22 @@ static void sd_recv_loopback(PADAPTER padapter, u32 size)
 
 
 	readsize = size;
-	DBG_8192C("%s: read size=%d\n", __func__, readsize);
-	allocsize = _RND(readsize, adapter_to_dvobj(padapter)->intf_data.block_transfer_len);
+	RTW_INFO("%s: read size=%d\n", __func__, readsize);
+	allocsize = _RND(readsize, rtw_sdio_get_block_size(adapter_to_dvobj(padapter)));
 
 	ploopback = padapter->ploopback;
 	if (ploopback) {
 		ploopback->rxsize = readsize;
 		preadbuf = ploopback->rxbuf;
-	}
-	else {
+	} else {
 		preadbuf = rtw_malloc(allocsize);
 		if (preadbuf == NULL) {
-			DBG_8192C("%s: malloc fail size=%d\n", __func__, allocsize);
+			RTW_INFO("%s: malloc fail size=%d\n", __func__, allocsize);
 			return;
 		}
 	}
 
-//	rtw_read_port(padapter, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf);
+	/*	rtw_read_port(padapter, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf); */
 	sdio_read_port(&padapter->iopriv.intf, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf);
 
 	if (ploopback)
@@ -1921,17 +1732,19 @@ static void sd_recv_loopback(PADAPTER padapter, u32 size)
 	else {
 		u32 i;
 
-		DBG_8192C("%s: drop pkt\n", __func__);
-		for (i = 0; i < readsize; i+=4) {
-			DBG_8192C("%08X", *(u32*)(preadbuf + i));
-			if ((i+4) & 0x1F) printk(" ");
-			else printk("\n");
+		RTW_INFO("%s: drop pkt\n", __func__);
+		for (i = 0; i < readsize; i += 4) {
+			RTW_INFO("%08X", *(u32 *)(preadbuf + i));
+			if ((i + 4) & 0x1F)
+				printk(" ");
+			else
+				printk("\n");
 		}
 		printk("\n");
 		rtw_mfree(preadbuf, allocsize);
 	}
 }
-#endif // CONFIG_MAC_LOOPBACK_DRIVER
+#endif /* CONFIG_MAC_LOOPBACK_DRIVER */
 
 #ifdef CONFIG_SDIO_RX_COPY
 static u32 sd_recv_rxfifo(PADAPTER padapter, u32 size, struct recv_buf **recvbuf_ret)
@@ -1943,7 +1756,7 @@ static u32 sd_recv_rxfifo(PADAPTER padapter, u32 size, struct recv_buf **recvbuf
 #if CONFIG_TEST_RBUF_UNAVAIL
 #define TEST_RBUF_UNAVAIL_CYCLE_MS (10 * 1000)
 #define TEST_RBUF_UNAVAIL_TIME_MS (50)
-	static u32 test_start = 0;
+	static systime test_start = 0;
 #endif
 	u32 readsize, ret;
 	u8 *preadbuf;
@@ -1967,29 +1780,30 @@ static u32 sd_recv_rxfifo(PADAPTER padapter, u32 size, struct recv_buf **recvbuf
 #if 0
 	readsize = size;
 #else
-	// Patch for some SDIO Host 4 bytes issue
-	// ex. RK3188
+	/* Patch for some SDIO Host 4 bytes issue */
+	/* ex. RK3188 */
 	readsize = RND4(size);
 #endif
 
 	if (readsize > MAX_RECVBUF_SZ) {
-		DBG_871X(FUNC_ADPT_FMT" %u\n", FUNC_ADPT_ARG(padapter), readsize);
+		RTW_INFO(FUNC_ADPT_FMT" %u\n", FUNC_ADPT_ARG(padapter), readsize);
 		rtw_warn_on(readsize > MAX_RECVBUF_SZ);
 	}
 
-	//3 1. alloc recvbuf
+	/* 3 1. alloc recvbuf */
 	precvpriv = &padapter->recvpriv;
 	precvbuf = rtw_dequeue_recvbuf(&precvpriv->free_recv_buf_queue);
 	if (precvbuf == NULL) {
-		RTW_INFO("%s: recvbuf unavailable\n", __func__);
+		if (0)
+			RTW_INFO("%s: recvbuf unavailable\n", __func__);
 		ret = RTW_RBUF_UNAVAIL;
 		goto exit;
 	}
 
-	//3 2. alloc skb
+	/* 3 2. alloc skb */
 	if (precvbuf->pskb == NULL) {
-		SIZE_PTR tmpaddr=0;
-		SIZE_PTR alignment=0;
+		SIZE_PTR tmpaddr = 0;
+		SIZE_PTR alignment = 0;
 
 		precvbuf->pskb = rtw_skb_alloc(MAX_RECVBUF_SZ + RECVBUFF_ALIGN_SZ);
 		if (precvbuf->pskb == NULL) {
@@ -2006,16 +1820,16 @@ static u32 sd_recv_rxfifo(PADAPTER padapter, u32 size, struct recv_buf **recvbuf
 		skb_reserve(precvbuf->pskb, (RECVBUFF_ALIGN_SZ - alignment));
 	}
 
-	//3 3. read data from rxfifo
+	/* 3 3. read data from rxfifo */
 	preadbuf = precvbuf->pskb->data;
-//	rtw_read_port(padapter, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf);
+	/*	rtw_read_port(padapter, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf); */
 	ret = sdio_read_port(&padapter->iopriv.intf, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf);
 	if (ret == _FAIL) {
 		rtw_enqueue_recvbuf(precvbuf, &precvpriv->free_recv_buf_queue);
 		goto exit;
 	}
 
-	//3 4. init recvbuf
+	/* 3 4. init recvbuf */
 	precvbuf->len = size;
 	precvbuf->phead = precvbuf->pskb->head;
 	precvbuf->pdata = precvbuf->pskb->data;
@@ -2028,59 +1842,53 @@ static u32 sd_recv_rxfifo(PADAPTER padapter, u32 size, struct recv_buf **recvbuf
 exit:
 	return ret;
 }
-#else // !CONFIG_SDIO_RX_COPY
-static struct recv_buf* sd_recv_rxfifo(PADAPTER padapter, u32 size)
+#else /* !CONFIG_SDIO_RX_COPY */
+static struct recv_buf *sd_recv_rxfifo(PADAPTER padapter, u32 size)
 {
-	u32 sdioblksize, readsize, allocsize, ret;
+	u32 readsize, allocsize, ret;
 	u8 *preadbuf;
 	_pkt *ppkt;
 	struct recv_priv *precvpriv;
 	struct recv_buf	*precvbuf;
 
 
-	sdioblksize = adapter_to_dvobj(padapter)->intf_data.block_transfer_len;
 #if 0
 	readsize = size;
 #else
-	// Patch for some SDIO Host 4 bytes issue
-	// ex. RK3188
+	/* Patch for some SDIO Host 4 bytes issue */
+	/* ex. RK3188 */
 	readsize = RND4(size);
 #endif
 
-	//3 1. alloc skb
-	// align to block size
-	if (readsize > sdioblksize)
-		allocsize = _RND(readsize, sdioblksize);
-	else
-		allocsize = readsize;
+	/* 3 1. alloc skb */
+	/* align to block size */
+	allocsize = rtw_sdio_cmd53_align_size(adapter_to_dvobj(padapter), readsize);
 
 	ppkt = rtw_skb_alloc(allocsize);
 
 	if (ppkt == NULL) {
-		RT_TRACE(_module_hci_ops_os_c_, _drv_err_, ("%s: alloc_skb fail! alloc=%d read=%d\n", __FUNCTION__, allocsize, readsize));
 		return NULL;
 	}
 
-	//3 2. read data from rxfifo
+	/* 3 2. read data from rxfifo */
 	preadbuf = skb_put(ppkt, size);
-//	rtw_read_port(padapter, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf);
+	/*	rtw_read_port(padapter, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf); */
 	ret = sdio_read_port(&padapter->iopriv.intf, WLAN_RX0FF_DEVICE_ID, readsize, preadbuf);
 	if (ret == _FAIL) {
 		rtw_skb_free(ppkt);
-		RT_TRACE(_module_hci_ops_os_c_, _drv_err_, ("%s: read port FAIL!\n", __FUNCTION__));
 		return NULL;
 	}
 
-	//3 3. alloc recvbuf
+	/* 3 3. alloc recvbuf */
 	precvpriv = &padapter->recvpriv;
 	precvbuf = rtw_dequeue_recvbuf(&precvpriv->free_recv_buf_queue);
 	if (precvbuf == NULL) {
 		rtw_skb_free(ppkt);
-		DBG_871X_LEVEL(_drv_err_, "%s: alloc recvbuf FAIL!\n", __FUNCTION__);
+		RTW_ERR("%s: alloc recvbuf FAIL!\n", __FUNCTION__);
 		return NULL;
 	}
 
-	//3 4. init recvbuf
+	/* 3 4. init recvbuf */
 	precvbuf->pskb = ppkt;
 
 	precvbuf->len = ppkt->len;
@@ -2092,7 +1900,7 @@ static struct recv_buf* sd_recv_rxfifo(PADAPTER padapter, u32 size)
 
 	return precvbuf;
 }
-#endif // !CONFIG_SDIO_RX_COPY
+#endif /* !CONFIG_SDIO_RX_COPY */
 
 static void sd_rxhandler(PADAPTER padapter, struct recv_buf *precvbuf)
 {
@@ -2103,7 +1911,7 @@ static void sd_rxhandler(PADAPTER padapter, struct recv_buf *precvbuf)
 	precvpriv = &padapter->recvpriv;
 	ppending_queue = &precvpriv->recv_buf_pending_queue;
 
-	//3 1. enqueue recvbuf
+	/* 3 1. enqueue recvbuf */
 	rtw_enqueue_recvbuf(precvbuf, ppending_queue);
 
 	/* 3 2. trigger recv hdl */
@@ -2212,7 +2020,7 @@ void sd_int_dpc(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE phal;
 	struct dvobj_priv *dvobj;
-	struct intf_hdl * pintfhdl=&padapter->iopriv.intf;
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
 	struct pwrctrl_priv *pwrctl;
 
 
@@ -2221,101 +2029,70 @@ void sd_int_dpc(PADAPTER padapter)
 	pwrctl = dvobj_to_pwrctl(dvobj);
 
 #ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT
-	if (phal->sdio_hisr & SDIO_HISR_AVAL)
-	{
-		//_irqL irql;
+	if (phal->sdio_hisr & SDIO_HISR_AVAL) {
+		/* _irqL irql; */
 		u8	freepage[4];
 
 		_sdio_local_read(padapter, SDIO_REG_FREE_TXPG, 4, freepage);
-		//_enter_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql);
-		//_rtw_memcpy(phal->SdioTxFIFOFreePage, freepage, 4);
-		//_exit_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql);
-		//DBG_871X("SDIO_HISR_AVAL, Tx Free Page = 0x%x%x%x%x\n",
-		//	freepage[0],
-		//	freepage[1],
-		//	freepage[2],
-		//	freepage[3]);
+		/* _enter_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql); */
+		/* _rtw_memcpy(phal->SdioTxFIFOFreePage, freepage, 4); */
+		/* _exit_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql); */
+		/* RTW_INFO("SDIO_HISR_AVAL, Tx Free Page = 0x%x%x%x%x\n", */
+		/*	freepage[0], */
+		/*	freepage[1], */
+		/*	freepage[2], */
+		/*	freepage[3]); */
 		_rtw_up_sema(&(padapter->xmitpriv.xmit_sema));
 	}
 #endif
-	if (phal->sdio_hisr & SDIO_HISR_CPWM1)
-	{
+	if (phal->sdio_hisr & SDIO_HISR_CPWM1) {
 		struct reportpwrstate_parm report;
 
 #ifdef CONFIG_LPS_RPWM_TIMER
-		u8 bcancelled;
-		_cancel_timer(&(pwrctl->pwr_rpwm_timer), &bcancelled);
-#endif // CONFIG_LPS_RPWM_TIMER
+		_cancel_timer_ex(&(pwrctl->pwr_rpwm_timer));
+#endif /* CONFIG_LPS_RPWM_TIMER */
 
 		report.state = SdioLocalCmd52Read1Byte(padapter, SDIO_REG_HCPWM1_8188F);
 
 #ifdef CONFIG_LPS_LCLK
-		//cpwm_int_hdl(padapter, &report);
+		/* cpwm_int_hdl(padapter, &report); */
 		_set_workitem(&(pwrctl->cpwm_event));
 #endif
 	}
 
-	if (phal->sdio_hisr & SDIO_HISR_TXERR)
-	{
+	if (phal->sdio_hisr & SDIO_HISR_TXERR) {
 		u8 *status;
 		u32 addr;
 
 		status = rtw_malloc(4);
-		if (status)
-		{
+		if (status) {
 			addr = REG_TXDMA_STATUS;
 			HalSdioGetCmdAddr8188FSdio(padapter, WLAN_IOREG_DEVICE_ID, addr, &addr);
 			_sd_read(pintfhdl, addr, 4, status);
 			_sd_write(pintfhdl, addr, 4, status);
-			DBG_8192C("%s: SDIO_HISR_TXERR (0x%08x)\n", __func__, le32_to_cpu(*(u32*)status));
+			RTW_INFO("%s: SDIO_HISR_TXERR (0x%08x)\n", __func__, le32_to_cpu(*(u32 *)status));
 			rtw_mfree(status, 4);
-		} else {
-			DBG_8192C("%s: SDIO_HISR_TXERR, but can't allocate memory to read status!\n", __func__);
-		}
+		} else
+			RTW_INFO("%s: SDIO_HISR_TXERR, but can't allocate memory to read status!\n", __func__);
 	}
 
 	if (phal->sdio_hisr & SDIO_HISR_TXBCNOK)
-	{
-		DBG_8192C("%s: SDIO_HISR_TXBCNOK\n", __func__);
-	}
+		RTW_INFO("%s: SDIO_HISR_TXBCNOK\n", __func__);
 
 	if (phal->sdio_hisr & SDIO_HISR_TXBCNERR)
-	{
-		DBG_8192C("%s: SDIO_HISR_TXBCNERR\n", __func__);
-	}
-#ifndef CONFIG_C2H_PACKET_EN
-	if (phal->sdio_hisr & SDIO_HISR_C2HCMD)
-	{
-		struct c2h_evt_hdr_88xx *c2h_evt;
-
-		DBG_8192C("%s: C2H Command\n", __func__);
-		if ((c2h_evt = (struct c2h_evt_hdr_88xx*)rtw_zmalloc(16)) != NULL) {
-			if (rtw_hal_c2h_evt_read(padapter, (u8 *)c2h_evt) == _SUCCESS) {
-				if (c2h_id_filter_ccx_8188f((u8 *)c2h_evt)) {
-					/* Handle CCX report here */
-					rtw_hal_c2h_handler(padapter, (u8 *)c2h_evt);
-					rtw_mfree((u8*)c2h_evt, 16);
-				} else {
-					rtw_c2h_wk_cmd(padapter, (u8 *)c2h_evt);
-				}
-			}
-		} else {
-			/* Error handling for malloc fail */
-			if (rtw_cbuf_push(padapter->evtpriv.c2h_queue, (void*)NULL) != _SUCCESS)
-				DBG_871X("%s rtw_cbuf_push fail\n", __func__);
-			_set_workitem(&padapter->evtpriv.c2h_wk);
-		}
+		RTW_INFO("%s: SDIO_HISR_TXBCNERR\n", __func__);
+
+#ifdef CONFIG_FW_C2H_REG
+	if (phal->sdio_hisr & SDIO_HISR_C2HCMD) {
+		RTW_INFO("%s: C2H Command\n", __func__);
+		sd_c2h_hisr_hdl(padapter);
 	}
-#endif	
+#endif
 
 	if (phal->sdio_hisr & SDIO_HISR_RXFOVW)
-	{
-		DBG_8192C("%s: Rx Overflow\n", __func__);
-	}
+		RTW_INFO("%s: Rx Overflow\n", __func__);
 	if (phal->sdio_hisr & SDIO_HISR_RXERR)
-	{
-		DBG_8192C("%s: Rx Error\n", __func__);
-	}
+		RTW_INFO("%s: Rx Error\n", __func__);
 
 	if (phal->sdio_hisr & SDIO_HISR_RX_REQUEST) {
 		phal->sdio_hisr ^= SDIO_HISR_RX_REQUEST;
@@ -2352,10 +2129,8 @@ void sd_int_hdl(PADAPTER padapter)
 	phal->SdioRxFIFOSize = le16_to_cpu(*(u16 *)&data[4]);
 	#endif
 
-	if (phal->sdio_hisr & phal->sdio_himr)
-	{
+	if (phal->sdio_hisr & phal->sdio_himr) {
 		u32 v32;
-
 		#if DBG_SD_INT_HISR_HIMR
 		static u32 match_cnt = 0;
 
@@ -2366,7 +2141,7 @@ void sd_int_hdl(PADAPTER padapter)
 
 		phal->sdio_hisr &= phal->sdio_himr;
 
-		// clear HISR
+		/* clear HISR */
 		v32 = phal->sdio_hisr & MASK_SDIO_HISR_CLEAR;
 		if (v32) {
 			#if CMD52_ACCESS_HISR_RX_REQ_LEN
@@ -2390,48 +2165,41 @@ void sd_int_hdl(PADAPTER padapter)
 	#endif
 }
 
-//
-//	Description:
-//		Query SDIO Local register to query current the number of Free TxPacketBuffer page.
-//
-//	Assumption:
-//		1. Running at PASSIVE_LEVEL
-//		2. RT_TX_SPINLOCK is NOT acquired.
-//
-//	Created by Roger, 2011.01.28.
-//
+/*
+ *	Description:
+ *		Query SDIO Local register to query current the number of Free TxPacketBuffer page.
+ *
+ *	Assumption:
+ *		1. Running at PASSIVE_LEVEL
+ *		2. RT_TX_SPINLOCK is NOT acquired.
+ *
+ *	Created by Roger, 2011.01.28.
+ *   */
 u8 HalQueryTxBufferStatus8188FSdio(PADAPTER padapter)
 {
 	/* TODO: EXQ */
 	PHAL_DATA_TYPE phal;
 	u1Byte NumOfFreePage[8];
-	//_irqL irql;
+	/* _irqL irql; */
 
 	phal = GET_HAL_DATA(padapter);
 
 	sdio_local_read(padapter, SDIO_REG_FREE_TXPG, 8, NumOfFreePage);
 
-	//_enter_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql);
+	/* _enter_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql); */
 	phal->SdioTxFIFOFreePage[HI_QUEUE_IDX] = NumOfFreePage[0];
 	phal->SdioTxFIFOFreePage[MID_QUEUE_IDX]  = NumOfFreePage[2];
 	phal->SdioTxFIFOFreePage[LOW_QUEUE_IDX] = NumOfFreePage[4];
 	phal->SdioTxFIFOFreePage[PUBLIC_QUEUE_IDX] = NumOfFreePage[6];
-	RT_TRACE(_module_hci_ops_c_, _drv_notice_,
-			("%s: Free page for HIQ(%#x),MIDQ(%#x),LOWQ(%#x),PUBQ(%#x)\n",
-			__FUNCTION__,
-			phal->SdioTxFIFOFreePage[HI_QUEUE_IDX],
-			phal->SdioTxFIFOFreePage[MID_QUEUE_IDX],
-			phal->SdioTxFIFOFreePage[LOW_QUEUE_IDX],
-			phal->SdioTxFIFOFreePage[PUBLIC_QUEUE_IDX]));
-	//_exit_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql);
+	/* _exit_critical_bh(&phal->SdioTxFIFOFreePageLock, &irql); */
 
 	return _TRUE;
 }
 
-//
-//	Description:
-//		Query SDIO Local register to get the current number of TX OQT Free Space.
-//
+/*
+ *	Description:
+ *		Query SDIO Local register to get the current number of TX OQT Free Space.
+ *   */
 u8 HalQueryTxOQTBufferStatus8188FSdio(PADAPTER padapter)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
@@ -2439,20 +2207,19 @@ u8 HalQueryTxOQTBufferStatus8188FSdio(PADAPTER padapter)
 	return _TRUE;
 }
 
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) 
-u8 RecvOnePkt(PADAPTER padapter, u32 size)
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+u8 RecvOnePkt(PADAPTER padapter)
 {
 	struct recv_buf *precvbuf;
 	struct dvobj_priv *psddev;
 	PSDIO_DATA psdio_data;
 	struct sdio_func *func;
-
+	u32 tmp = 0;
+	u16 len = 0;
 	u8 res = _FALSE;
 
-	DBG_871X("+%s: size: %d+\n", __func__, size);
-
 	if (padapter == NULL) {
-		DBG_871X(KERN_ERR "%s: padapter is NULL!\n", __func__);
+		RTW_ERR("%s: padapter is NULL!\n", __func__);
 		return _FALSE;
 	}
 
@@ -2460,20 +2227,24 @@ u8 RecvOnePkt(PADAPTER padapter, u32 size)
 	psdio_data = &psddev->intf_data;
 	func = psdio_data->func;
 
-	if(size) {
+	/* If RX_DMA is not idle, receive one pkt from DMA */
+	res = sdio_local_read(padapter,
+			  SDIO_REG_RX0_REQ_LEN, 4, (u8 *)&tmp);
+	len = le16_to_cpu(tmp);
+	RTW_INFO("+%s: size: %d+\n", __func__, len);
+
+	if (len) {
 		sdio_claim_host(func);
-		sd_recv_rxfifo(padapter, size, &precvbuf);
+		sd_recv_rxfifo(padapter, len, &precvbuf);
 		if (precvbuf) {
-			//printk("Completed Recv One Pkt.\n");
+			/* printk("Completed Recv One Pkt.\n"); */
 			sd_rxhandler(padapter, precvbuf);
 			res = _TRUE;
-		}else{
+		} else
 			res = _FALSE;
-		}
 		sdio_release_host(func);
 	}
-	DBG_871X("-%s-\n", __func__);
+	RTW_INFO("-%s-\n", __func__);
 	return res;
 }
-#endif //CONFIG_WOWLAN
-
+#endif /* CONFIG_WOWLAN */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/ifcfg-wlan0 b/drivers/net/wireless/rockchip_wlan/rtl8189fs/ifcfg-wlan0
old mode 100644
new mode 100755
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyCfg.h
index cbe8dcb621f9..4b69372108a7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyCfg.h
@@ -1,274 +1,261 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8188EPHYCFG_H__
-#define __INC_HAL8188EPHYCFG_H__
-
-
-/*--------------------------Define Parameters-------------------------------*/
-#define LOOP_LIMIT				5
-#define MAX_STALL_TIME			50		//us
-#define AntennaDiversityValue		0x80	//(Adapter->bSoftwareAntennaDiversity ? 0x00:0x80)
-#define MAX_TXPWR_IDX_NMODE_92S	63
-#define Reset_Cnt_Limit			3
-
-#ifdef CONFIG_PCI_HCI
-#define MAX_AGGR_NUM	0x0B
-#else
-#define MAX_AGGR_NUM	0x07
-#endif // CONFIG_PCI_HCI
-
-
-/*--------------------------Define Parameters-------------------------------*/
-
-
-/*------------------------------Define structure----------------------------*/ 
-
-#define	MAX_TX_COUNT_8188E			1
-
-/* BB/RF related */
-
-
-/*------------------------------Define structure----------------------------*/ 
-
-
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export global variable----------------------------*/
-
-
-/*------------------------Export Marco Definition---------------------------*/
-/*------------------------Export Marco Definition---------------------------*/
-
-
-/*--------------------------Exported Function prototype---------------------*/
-//
-// BB and RF register read/write
-//
-u32	PHY_QueryBBReg8188E(	IN	PADAPTER	Adapter,
-								IN	u32		RegAddr,
-								IN	u32		BitMask	);
-void	PHY_SetBBReg8188E(	IN	PADAPTER	Adapter,
-								IN	u32		RegAddr,
-								IN	u32		BitMask,
-								IN	u32		Data	);
-u32	PHY_QueryRFReg8188E(	IN	PADAPTER	Adapter,
-								IN	u8				eRFPath,
-								IN	u32				RegAddr,
-								IN	u32				BitMask	);
-void	PHY_SetRFReg8188E(	IN	PADAPTER		Adapter,
-								IN	u8				eRFPath,
-								IN	u32				RegAddr,
-								IN	u32				BitMask,
-								IN	u32				Data	);
-
-//
-// Initialization related function
-//
-/* MAC/BB/RF HAL config */
-int	PHY_MACConfig8188E(IN	PADAPTER	Adapter	);
-int	PHY_BBConfig8188E(IN	PADAPTER	Adapter	);
-int	PHY_RFConfig8188E(IN	PADAPTER	Adapter	);
-
-/* RF config */
-int	rtl8188e_PHY_ConfigRFWithParaFile(IN PADAPTER Adapter, IN u8 * pFileName, u8 eRFPath);
-
-//
-// RF Power setting
-//
-//extern	BOOLEAN	PHY_SetRFPowerState(IN	PADAPTER			Adapter, 
-//									IN	RT_RF_POWER_STATE	eRFPowerState);
-
-//
-// BB TX Power R/W
-//
-void	PHY_GetTxPowerLevel8188E(	IN	PADAPTER		Adapter,
-											OUT s32*    		powerlevel	);
-void	PHY_SetTxPowerLevel8188E(	IN	PADAPTER		Adapter,
-											IN	u8			channel	);
-BOOLEAN	PHY_UpdateTxPowerDbm8188E(	IN	PADAPTER	Adapter,
-											IN	int		powerInDbm	);
-
-VOID
-PHY_SetTxPowerIndex_8188E(
-	IN	PADAPTER			Adapter,
-	IN	u32					PowerIndex,
-	IN	u8					RFPath,	
-	IN	u8					Rate
-	);
-
-u8
-PHY_GetTxPowerIndex_8188E(
-	IN	PADAPTER		pAdapter,
-	IN	u8				RFPath,
-	IN	u8				Rate,	
-	IN	CHANNEL_WIDTH	BandWidth,	
-	IN	u8				Channel
-	);
-
-//
-// Switch bandwidth for 8192S
-//
-//extern	void	PHY_SetBWModeCallback8192C(	IN	PRT_TIMER		pTimer	);
-void	PHY_SetBWMode8188E(	IN	PADAPTER			pAdapter,
-									IN	CHANNEL_WIDTH	ChnlWidth,
-									IN	unsigned char	Offset	);
-
-//
-// Set FW CMD IO for 8192S.
-//
-//extern	BOOLEAN HalSetIO8192C(	IN	PADAPTER			Adapter,
-//									IN	IO_TYPE				IOType);
-
-//
-// Set A2 entry to fw for 8192S
-//
-extern	void FillA2Entry8192C(		IN	PADAPTER			Adapter,
-										IN	u8				index,
-										IN	u8*				val);
-
-
-//
-// channel switch related funciton
-//
-//extern	void	PHY_SwChnlCallback8192C(	IN	PRT_TIMER		pTimer	);
-void	PHY_SwChnl8188E(	IN	PADAPTER		pAdapter,
-									IN	u8			channel	);
-
-VOID
-PHY_SetSwChnlBWMode8188E(
-	IN	PADAPTER			Adapter,
-	IN	u8					channel,
-	IN	CHANNEL_WIDTH	Bandwidth,
-	IN	u8					Offset40,
-	IN	u8					Offset80
-);
-
-//
-// BB/MAC/RF other monitor API
-//
-void	PHY_SetMonitorMode8192C(IN	PADAPTER	pAdapter,
-										IN	BOOLEAN		bEnableMonitorMode	);
-
-BOOLEAN	PHY_CheckIsLegalRfPath8192C(IN	PADAPTER	pAdapter,
-											IN	u32		eRFPath	);
-
-VOID PHY_SetRFPathSwitch_8188E(IN	PADAPTER	pAdapter, IN	BOOLEAN		bMain);
-
-extern	VOID
-PHY_SwitchEphyParameter(
-	IN	PADAPTER			Adapter
-	);
-
-extern	VOID
-PHY_EnableHostClkReq(
-	IN	PADAPTER			Adapter
-	);
-
-BOOLEAN
-SetAntennaConfig92C(
-	IN	PADAPTER	Adapter,
-	IN	u8		DefaultAnt	
-	);
-
-VOID
-storePwrIndexDiffRateOffset(
-	IN	PADAPTER	Adapter,
-	IN	u32		RegAddr,
-	IN	u32		BitMask,
-	IN	u32		Data
-	);
-/*--------------------------Exported Function prototype---------------------*/
-
-//
-// Initialization related function
-//
-/* MAC/BB/RF HAL config */
-//extern s32 PHY_MACConfig8723(PADAPTER padapter);
-//s32 PHY_BBConfig8723(PADAPTER padapter);
-//s32 PHY_RFConfig8723(PADAPTER padapter);
-
-
-
-//==================================================================
-// Note: If SIC_ENABLE under PCIE, because of the slow operation
-//	you should 
-//	2) "#define RTL8723_FPGA_VERIFICATION	1"				in Precomp.h.WlanE.Windows
-//	3) "#define RTL8190_Download_Firmware_From_Header	0"	in Precomp.h.WlanE.Windows if needed.
-//
-#if (RTL8188E_SUPPORT == 1) && (RTL8188E_FPGA_TRUE_PHY_VERIFICATION == 1)
-#define	SIC_ENABLE				1
-#define	SIC_HW_SUPPORT		1
-#else
-#define	SIC_ENABLE				0
-#define	SIC_HW_SUPPORT		0
-#endif
-//==================================================================
-
-
-#define	SIC_MAX_POLL_CNT		5
-
-#if(SIC_HW_SUPPORT == 1)
-#define	SIC_CMD_READY			0
-#define	SIC_CMD_PREWRITE		0x1
-#if(RTL8188E_SUPPORT == 1)
-#define	SIC_CMD_WRITE			0x40
-#define	SIC_CMD_PREREAD		0x2
-#define	SIC_CMD_READ			0x80
-#define	SIC_CMD_INIT			0xf0
-#define	SIC_INIT_VAL			0xff
-
-#define	SIC_INIT_REG			0x1b7
-#define	SIC_CMD_REG			0x1EB		// 1byte
-#define	SIC_ADDR_REG			0x1E8		// 1b4~1b5, 2 bytes
-#define	SIC_DATA_REG			0x1EC		// 1b0~1b3
-#else
-#define	SIC_CMD_WRITE			0x11
-#define	SIC_CMD_PREREAD		0x2
-#define	SIC_CMD_READ			0x12
-#define	SIC_CMD_INIT			0x1f
-#define	SIC_INIT_VAL			0xff
-
-#define	SIC_INIT_REG			0x1b7
-#define	SIC_CMD_REG			0x1b6		// 1byte
-#define	SIC_ADDR_REG			0x1b4		// 1b4~1b5, 2 bytes
-#define	SIC_DATA_REG			0x1b0		// 1b0~1b3
-#endif
-#else
-#define	SIC_CMD_READY			0
-#define	SIC_CMD_WRITE			1
-#define	SIC_CMD_READ			2
-
-#if(RTL8188E_SUPPORT == 1)
-#define	SIC_CMD_REG			0x1EB		// 1byte
-#define	SIC_ADDR_REG			0x1E8		// 1b9~1ba, 2 bytes
-#define	SIC_DATA_REG			0x1EC		// 1bc~1bf
-#else
-#define	SIC_CMD_REG			0x1b8		// 1byte
-#define	SIC_ADDR_REG			0x1b9		// 1b9~1ba, 2 bytes
-#define	SIC_DATA_REG			0x1bc		// 1bc~1bf
-#endif
-#endif
-
-#if(SIC_ENABLE == 1)
-VOID SIC_Init(IN PADAPTER Adapter);
-#endif
-
-
-#endif	// __INC_HAL8192CPHYCFG_H
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8188EPHYCFG_H__
+#define __INC_HAL8188EPHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue		0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+#define	MAX_TX_COUNT_8188E			1
+
+/* BB/RF related */
+
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/*
+ * BB and RF register read/write
+ *   */
+u32	PHY_QueryBBReg8188E(IN	PADAPTER	Adapter,
+			    IN	u32		RegAddr,
+			    IN	u32		BitMask);
+void	PHY_SetBBReg8188E(IN	PADAPTER	Adapter,
+			  IN	u32		RegAddr,
+			  IN	u32		BitMask,
+			  IN	u32		Data);
+u32	PHY_QueryRFReg8188E(IN	PADAPTER	Adapter,
+			    IN	enum rf_path		eRFPath,
+			    IN	u32				RegAddr,
+			    IN	u32				BitMask);
+void	PHY_SetRFReg8188E(IN	PADAPTER		Adapter,
+			  IN	enum rf_path		eRFPath,
+			  IN	u32				RegAddr,
+			  IN	u32				BitMask,
+			  IN	u32				Data);
+
+/*
+ * Initialization related function
+ */
+/* MAC/BB/RF HAL config */
+int	PHY_MACConfig8188E(IN	PADAPTER	Adapter);
+int	PHY_BBConfig8188E(IN	PADAPTER	Adapter);
+int	PHY_RFConfig8188E(IN	PADAPTER	Adapter);
+
+/* RF config */
+int	rtl8188e_PHY_ConfigRFWithParaFile(IN PADAPTER Adapter, IN u8 *pFileName, enum rf_path eRFPath);
+
+/*
+ * RF Power setting
+ */
+/* extern	BOOLEAN	PHY_SetRFPowerState(IN	PADAPTER			Adapter,
+ *									IN	RT_RF_POWER_STATE	eRFPowerState); */
+
+/*
+ * BB TX Power R/W
+ *   */
+void	PHY_GetTxPowerLevel8188E(IN	PADAPTER		Adapter,
+				 OUT s32		*powerlevel);
+void	PHY_SetTxPowerLevel8188E(IN	PADAPTER		Adapter,
+				 IN	u8			channel);
+BOOLEAN	PHY_UpdateTxPowerDbm8188E(IN	PADAPTER	Adapter,
+				  IN	int		powerInDbm);
+
+VOID
+PHY_SetTxPowerIndex_8188E(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8188E(
+	IN	PADAPTER		pAdapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	IN	u8				BandWidth,
+	IN	u8				Channel,
+	struct txpwr_idx_comp *tic
+);
+
+/*
+ * Switch bandwidth for 8192S
+ */
+/* extern	void	PHY_SetBWModeCallback8192C(	IN	PRT_TIMER		pTimer	); */
+void	PHY_SetBWMode8188E(IN	PADAPTER			pAdapter,
+			   IN	enum channel_width	ChnlWidth,
+			   IN	unsigned char	Offset);
+
+/*
+ * Set FW CMD IO for 8192S.
+ */
+/* extern	BOOLEAN HalSetIO8192C(	IN	PADAPTER			Adapter,
+ *									IN	IO_TYPE				IOType); */
+
+/*
+ * Set A2 entry to fw for 8192S
+ *   */
+extern	void FillA2Entry8192C(IN	PADAPTER			Adapter,
+			      IN	u8				index,
+			      IN	u8				*val);
+
+
+/*
+ * channel switch related funciton
+ */
+/* extern	void	PHY_SwChnlCallback8192C(	IN	PRT_TIMER		pTimer	); */
+void	PHY_SwChnl8188E(IN	PADAPTER		pAdapter,
+			IN	u8			channel);
+
+VOID
+PHY_SetSwChnlBWMode8188E(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID
+PHY_SetRFEReg_8188E(
+	IN PADAPTER		Adapter
+);
+/*
+ * BB/MAC/RF other monitor API
+ *   */
+VOID phy_set_rf_path_switch_8188e(IN	struct dm_struct	*phydm, IN	bool		bMain);
+
+extern	VOID
+PHY_SwitchEphyParameter(
+	IN	PADAPTER			Adapter
+);
+
+extern	VOID
+PHY_EnableHostClkReq(
+	IN	PADAPTER			Adapter
+);
+
+BOOLEAN
+SetAntennaConfig92C(
+	IN	PADAPTER	Adapter,
+	IN	u8		DefaultAnt
+);
+
+/*--------------------------Exported Function prototype---------------------*/
+
+/*
+ * Initialization related function
+ *
+ * MAC/BB/RF HAL config */
+/* extern s32 PHY_MACConfig8723(PADAPTER padapter);
+ * s32 PHY_BBConfig8723(PADAPTER padapter);
+ * s32 PHY_RFConfig8723(PADAPTER padapter); */
+
+
+
+/* ******************************************************************
+ * Note: If SIC_ENABLE under PCIE, because of the slow operation
+ *	you should
+ * 	2) "#define RTL8723_FPGA_VERIFICATION	1"				in Precomp.h.WlanE.Windows
+ * 	3) "#define RTL8190_Download_Firmware_From_Header	0"	in Precomp.h.WlanE.Windows if needed.
+ *   */
+#if (RTL8188E_SUPPORT == 1) && (RTL8188E_FPGA_TRUE_PHY_VERIFICATION == 1)
+	#define	SIC_ENABLE				1
+	#define	SIC_HW_SUPPORT		1
+#else
+	#define	SIC_ENABLE				0
+	#define	SIC_HW_SUPPORT		0
+#endif
+/* ****************************************************************** */
+
+
+#define	SIC_MAX_POLL_CNT		5
+
+#if (SIC_HW_SUPPORT == 1)
+	#define	SIC_CMD_READY			0
+	#define	SIC_CMD_PREWRITE		0x1
+	#if (RTL8188E_SUPPORT == 1)
+		#define	SIC_CMD_WRITE			0x40
+		#define	SIC_CMD_PREREAD		0x2
+		#define	SIC_CMD_READ			0x80
+		#define	SIC_CMD_INIT			0xf0
+		#define	SIC_INIT_VAL			0xff
+
+		#define	SIC_INIT_REG			0x1b7
+		#define	SIC_CMD_REG			0x1EB		/* 1byte */
+		#define	SIC_ADDR_REG			0x1E8		/* 1b4~1b5, 2 bytes */
+		#define	SIC_DATA_REG			0x1EC		/* 1b0~1b3 */
+	#else
+		#define	SIC_CMD_WRITE			0x11
+		#define	SIC_CMD_PREREAD		0x2
+		#define	SIC_CMD_READ			0x12
+		#define	SIC_CMD_INIT			0x1f
+		#define	SIC_INIT_VAL			0xff
+
+		#define	SIC_INIT_REG			0x1b7
+		#define	SIC_CMD_REG			0x1b6		/* 1byte */
+		#define	SIC_ADDR_REG			0x1b4		/* 1b4~1b5, 2 bytes */
+		#define	SIC_DATA_REG			0x1b0		/* 1b0~1b3 */
+	#endif
+#else
+	#define	SIC_CMD_READY			0
+	#define	SIC_CMD_WRITE			1
+	#define	SIC_CMD_READ			2
+
+	#if (RTL8188E_SUPPORT == 1)
+		#define	SIC_CMD_REG			0x1EB		/* 1byte */
+		#define	SIC_ADDR_REG			0x1E8		/* 1b9~1ba, 2 bytes */
+		#define	SIC_DATA_REG			0x1EC		/* 1bc~1bf */
+	#else
+		#define	SIC_CMD_REG			0x1b8		/* 1byte */
+		#define	SIC_ADDR_REG			0x1b9		/* 1b9~1ba, 2 bytes */
+		#define	SIC_DATA_REG			0x1bc		/* 1bc~1bf */
+	#endif
+#endif
+
+#if (SIC_ENABLE == 1)
+	VOID SIC_Init(IN PADAPTER Adapter);
+#endif
+
+
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyReg.h
index 2113a2609d23..94972bf7200f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPhyReg.h
@@ -1,1106 +1,1101 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8188EPHYREG_H__
-#define __INC_HAL8188EPHYREG_H__
-/*--------------------------Define Parameters-------------------------------*/
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
-
-
-//
-// 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		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		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
-#define		rFPGA0_AdDaClockEn			0x888	// enable ad/da clock1 for dual-phy
-#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_ram64x16				0xb2c
-#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_csi_fix_mask1				0xd40
-#define		rOFDM1_csi_fix_mask2				0xd44
-#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		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		rTxAGC_B_Mcs15_Mcs12		0x868
-#define		rTxAGC_B_CCK11_A_CCK2_11		0x86c
-
-#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
-
-//#endif
-#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_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_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_88E					0x42	// 
-#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
-#define		RF_TX_BIAS_A					0x35
-#define		RF_TX_BIAS_D					0x36
-#define		RF_LOBF_9					0x38
-#define		RF_RXRF_A3					0x3C	//	
-#define		RF_TRSW						0x3F
-
-#define		RF_TXRF_A2					0x41
-#define		RF_TXPA_G4					0x46	
-#define		RF_TXPA_A4					0x4B	
-#define 	RF_0x52 					0x52
-#define		RF_WE_LUT					0xEF	
-
-
-//
-//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		bMaskH3Bytes				0xffffff00
-#define		bMask12Bits				0xfff	
-#define		bMaskH4Bits				0xf0000000	
-#define 		bMaskOFDM_D			0xffc00000
-#define		bMaskCCK				0x3f3f3f3f
-
-
-  		
-#define		bEnable                   0x1	// Useless
-#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
-
-/*--------------------------Define Parameters-------------------------------*/
-
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8188EPHYREG_H__
+#define __INC_HAL8188EPHYREG_H__
+/*--------------------------Define Parameters-------------------------------*/
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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		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		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
+#define		rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#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_ram64x16				0xb2c
+#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_csi_fix_mask1				0xd40
+#define		rOFDM1_csi_fix_mask2				0xd44
+#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		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		rTxAGC_B_Mcs15_Mcs12		0x868
+#define		rTxAGC_B_CCK11_A_CCK2_11		0x86c
+
+#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 */
+
+/* #endif */
+#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_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_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_88E					0x42	/*  */
+#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 */
+#define		RF_TX_BIAS_A					0x35
+#define		RF_TX_BIAS_D					0x36
+#define		RF_LOBF_9					0x38
+#define		RF_RXRF_A3					0x3C	/*	 */
+#define		RF_TRSW						0x3F
+
+#define		RF_TXRF_A2					0x41
+#define		RF_TXPA_G4					0x46
+#define		RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define		RF_WE_LUT					0xEF
+
+
+/*
+ * 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		bMaskH3Bytes				0xffffff00
+#define		bMask12Bits				0xfff
+#define		bMaskH4Bits				0xf0000000
+#define		bMaskOFDM_D			0xffc00000
+#define		bMaskCCK				0x3f3f3f3f
+
+
+
+#define		bEnable                   0x1	/* Useless */
+#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
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPwrSeq.h
index 41f852f22402..4eab945a7a17 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188EPwrSeq.h
@@ -1,176 +1,171 @@
-
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef __HAL8188EPWRSEQ_H__
-#define __HAL8188EPWRSEQ_H__
-
-#include "HalPwrSeqCmd.h"
-
-/* 
-	Check document WM-20110607-Paul-RTL8188E_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
-
-    PWR SEQ Version: rtl8188E_PwrSeq_V09.h
-*/
-#define	RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS	10
-#define	RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS	10
-#define	RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS	10
-#define	RTL8188E_TRANS_SUS_TO_CARDEMU_STEPS	10
-#define	RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS	10
-#define	RTL8188E_TRANS_PDN_TO_CARDEMU_STEPS	10
-#define	RTL8188E_TRANS_ACT_TO_LPS_STEPS	15
-#define	RTL8188E_TRANS_LPS_TO_ACT_STEPS	15	
-#define	RTL8188E_TRANS_END_STEPS	1
-
-
-#define RTL8188E_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0|BIT1, 0}, /* 0x02[1:0] = 0	reset BB*/			\
-	{0x0026, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7}, /*0x24[23] = 2b'01 schmit trigger */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0}, /* 0x04[15] = 0 disable HWPDN (control by DRV)*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, 0}, /*0x04[12:11] = 2b'00 disable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*0x04[8] = 1 polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0}, /*wait till 0x04[8] = 0*/	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*LDO normal mode*/	\
-
-#define RTL8188E_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{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*/	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*LDO Sleep mode*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
-
-#define RTL8188E_TRANS_CARDEMU_TO_SUS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11enable WL suspend for PCIe*/	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, BIT7}, /*  0x04[31:30] = 2b'10 enable enable bandgap mbias in suspend */	\
-	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*Clear SIC_EN register 0x40[12] = 1'b0 */	\
-	{0xfe10, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*Set USB suspend enable local register  0xfe10[4]=1 */	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8188E_TRANS_SUS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8188E_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0026, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7}, /*0x24[23] = 2b'01 schmit trigger */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0}, /*  0x04[31:30] = 2b'10 enable enable bandgap mbias in suspend */	\
-	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*Clear SIC_EN register 0x40[12] = 1'b0 */	\
-	{0xfe10, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*Set USB suspend enable local register  0xfe10[4]=1 */	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8188E_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8188E_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8188E_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-//This is used by driver for LPSRadioOff Procedure, not for FW LPS Step
-#define RTL8188E_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x7F},/*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, BIT0, 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*/	\
-	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x3F},/*Reset MAC TRX*/	\
-	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
-
-
-#define RTL8188E_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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 RTL8188E_TRANS_END															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8188E_power_on_flow[RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_radio_off_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_card_disable_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_card_enable_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_suspend_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_resume_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_hwpdn_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_enter_lps_flow[RTL8188E_TRANS_ACT_TO_LPS_STEPS+RTL8188E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188E_leave_lps_flow[RTL8188E_TRANS_LPS_TO_ACT_STEPS+RTL8188E_TRANS_END_STEPS];
-
-#endif //__HAL8188EPWRSEQ_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HAL8188EPWRSEQ_H__
+#define __HAL8188EPWRSEQ_H__
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20110607-Paul-RTL8188E_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
+
+    PWR SEQ Version: rtl8188E_PwrSeq_V09.h
+*/
+#define	RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS	10
+#define	RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS	10
+#define	RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS	10
+#define	RTL8188E_TRANS_SUS_TO_CARDEMU_STEPS	10
+#define	RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS	10
+#define	RTL8188E_TRANS_PDN_TO_CARDEMU_STEPS	10
+#define	RTL8188E_TRANS_ACT_TO_LPS_STEPS	15
+#define	RTL8188E_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8188E_TRANS_END_STEPS	1
+
+
+#define RTL8188E_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 | BIT1, 0}, /* 0x02[1:0] = 0	reset BB*/			\
+	{0x0026, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7}, /*0x24[23] = 2b'01 schmit trigger */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0}, /* 0x04[15] = 0 disable HWPDN (control by DRV)*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, 0}, /*0x04[12:11] = 2b'00 disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*0x04[8] = 1 polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0}, /*wait till 0x04[8] = 0*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*LDO normal mode*/	\
+
+#define RTL8188E_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*LDO Sleep mode*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+
+#define RTL8188E_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11enable WL suspend for PCIe*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, BIT7}, /*  0x04[31:30] = 2b'10 enable enable bandgap mbias in suspend */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*Clear SIC_EN register 0x40[12] = 1'b0 */	\
+	{0xfe10, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*Set USB suspend enable local register  0xfe10[4]=1 */	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8188E_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8188E_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0026, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7}, /*0x24[23] = 2b'01 schmit trigger */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0}, /*  0x04[31:30] = 2b'10 enable enable bandgap mbias in suspend */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*Clear SIC_EN register 0x40[12] = 1'b0 */	\
+	{0xfe10, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*Set USB suspend enable local register  0xfe10[4]=1 */	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8188E_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8188E_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8188E_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+	/* This is used by driver for LPSRadioOff Procedure, not for FW LPS Step */
+#define RTL8188E_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x7F},/*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, BIT0, 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*/	\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x3F},/*Reset MAC TRX*/	\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8188E_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8188E_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8188E_power_on_flow[RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_radio_off_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_card_disable_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_card_enable_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_suspend_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_resume_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_hwpdn_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_enter_lps_flow[RTL8188E_TRANS_ACT_TO_LPS_STEPS + RTL8188E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188E_leave_lps_flow[RTL8188E_TRANS_LPS_TO_ACT_STEPS + RTL8188E_TRANS_END_STEPS];
+
+#endif /* __HAL8188EPWRSEQ_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyCfg.h
index f4ef1d46415b..18e79f1c4e03 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyCfg.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,27 +12,22 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __INC_HAL8188FPHYCFG_H__
 #define __INC_HAL8188FPHYCFG_H__
 
 /*--------------------------Define Parameters-------------------------------*/
 #define LOOP_LIMIT				5
-#define MAX_STALL_TIME			50		//us
-#define AntennaDiversityValue	0x80	//(Adapter->bSoftwareAntennaDiversity ? 0x00:0x80)
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
 #define MAX_TXPWR_IDX_NMODE_92S	63
 #define Reset_Cnt_Limit			3
 
 #ifdef CONFIG_PCI_HCI
-#define MAX_AGGR_NUM	0x0B
+	#define MAX_AGGR_NUM	0x0B
 #else
-#define MAX_AGGR_NUM	0x07
-#endif // CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
 
 
 /*--------------------------Define Parameters End-------------------------------*/
@@ -47,7 +43,7 @@ PHY_QueryBBReg_8188F(
 	IN	PADAPTER	Adapter,
 	IN	u32		RegAddr,
 	IN	u32		BitMask
-	);
+);
 
 VOID
 PHY_SetBBReg_8188F(
@@ -55,86 +51,85 @@ PHY_SetBBReg_8188F(
 	IN	u32		RegAddr,
 	IN	u32		BitMask,
 	IN	u32		Data
-	);
+);
 
 u32
 PHY_QueryRFReg_8188F(
 	IN	PADAPTER			Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path			eRFPath,
 	IN	u32				RegAddr,
 	IN	u32				BitMask
-	);
+);
 
 VOID
 PHY_SetRFReg_8188F(
 	IN	PADAPTER			Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path			eRFPath,
 	IN	u32				RegAddr,
 	IN	u32				BitMask,
 	IN	u32				Data
-	);
+);
 
 /* MAC/BB/RF HAL config */
-int PHY_BBConfig8188F(PADAPTER	Adapter	);
+int PHY_BBConfig8188F(PADAPTER	Adapter);
 
-int PHY_RFConfig8188F(PADAPTER	Adapter	);
+int PHY_RFConfig8188F(PADAPTER	Adapter);
 
 s32 PHY_MACConfig8188F(PADAPTER padapter);
 
 int
 PHY_ConfigRFWithParaFile_8188F(
 	IN	PADAPTER			Adapter,
-	IN	u8* 				pFileName,
-	RF_PATH				eRFPath
+	IN	u8					*pFileName,
+	enum rf_path				eRFPath
 );
 
 VOID
 PHY_SetTxPowerIndex_8188F(
 	IN	PADAPTER			Adapter,
 	IN	u32					PowerIndex,
-	IN	u8					RFPath,	
+	IN	enum rf_path			RFPath,
 	IN	u8					Rate
-	);
+);
 
 u8
 PHY_GetTxPowerIndex_8188F(
 	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
+	IN	enum rf_path			RFPath,
 	IN	u8					Rate,
 	IN	u8		BandWidth,
 	IN	u8					Channel,
 	struct txpwr_idx_comp *tic
-	);
+);
 
-VOID	
-PHY_GetTxPowerLevel8188F(			
+VOID
+PHY_GetTxPowerLevel8188F(
 	IN	PADAPTER		Adapter,
-	OUT s32*		    		powerlevel	
-	);
+	OUT s32				*powerlevel
+);
 
 VOID
 PHY_SetTxPowerLevel8188F(
 	IN	PADAPTER		Adapter,
 	IN	u8			channel
-	);
+);
 
 VOID
 PHY_SetSwChnlBWMode8188F(
 	IN	PADAPTER			Adapter,
 	IN	u8					channel,
-	IN	CHANNEL_WIDTH		Bandwidth,
+	IN	enum channel_width	Bandwidth,
 	IN	u8					Offset40,
 	IN	u8					Offset80
 );
 
-VOID PHY_SetRFPathSwitch_8188F(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN		bMain
-	);
+VOID phy_set_rf_path_switch_8188f(
+	IN	struct		dm_struct *phydm,
+	IN	bool		bMain
+);
 
 void BBTurnOnBlock_8188F(_adapter *adapter);
 
 /*--------------------------Exported Function prototype End---------------------*/
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyReg.h
index 817ff8e8a76a..f87c348bc333 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPhyReg.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,35 +12,30 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __INC_HAL8188FPHYREG_H__
 #define __INC_HAL8188FPHYREG_H__
 
 /*--------------------------Define Parameters-------------------------------*/
 
-//============================================================
-//       Regsiter offset definition
-//============================================================
+/* ************************************************************
+ * Regsiter offset definition
+ * ************************************************************ */
 
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
 
 
-//
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 1. Page1(0x100)
-//
+/*
+ * 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
@@ -68,27 +64,27 @@
 #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.
+/*
+ * 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??
+/*
+ * 3. Page8(0x800)
+ *   */
+#define		rFPGA0_RFMOD				0x800	/* RF mode & CCK TxSC */ /* RF BW Setting?? */
 
-#define		rFPGA0_TxInfo				0x804	// Status report??
+#define		rFPGA0_TxInfo				0x804	/* Status report?? */
 #define		rFPGA0_PSDFunction			0x808
 
-#define		rFPGA0_TxGainStage			0x80c	// Set TX PWR init gain?
+#define		rFPGA0_TxGainStage			0x80c	/* Set TX PWR init gain? */
 
-#define		rFPGA0_RFTiming1			0x810	// Useless now
+#define		rFPGA0_RFTiming1			0x810	/* Useless now */
 #define		rFPGA0_RFTiming2			0x814
 
-#define		rFPGA0_XA_HSSIParameter1		0x820	// RF 3 wire register
+#define		rFPGA0_XA_HSSIParameter1		0x820	/* RF 3 wire register */
 #define		rFPGA0_XA_HSSIParameter2		0x824
 #define		rFPGA0_XB_HSSIParameter1		0x828
 #define		rFPGA0_XB_HSSIParameter2		0x82c
@@ -103,117 +99,117 @@
 #define		rFPGA0_XA_LSSIParameter		0x840
 #define		rFPGA0_XB_LSSIParameter		0x844
 
-#define		rFPGA0_RFWakeUpParameter		0x850	// Useless now
+#define		rFPGA0_RFWakeUpParameter		0x850	/* Useless now */
 #define		rFPGA0_RFSleepUpParameter		0x854
 
-#define		rFPGA0_XAB_SwitchControl		0x858	// RF Channel switch
+#define		rFPGA0_XAB_SwitchControl		0x858	/* RF Channel switch */
 #define		rFPGA0_XCD_SwitchControl		0x85c
 
-#define		rFPGA0_XA_RFInterfaceOE		0x860	// RF Channel switch
+#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_XAB_RFInterfaceSW		0x870	/* RF Interface Software Control */
 #define		rFPGA0_XCD_RFInterfaceSW		0x874
 
-#define		rFPGA0_XAB_RFParameter		0x878	// RF Parameter
+#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_AnalogParameter1		0x880	/* Crystal cap setting RF-R/W protection for parameter4?? */
 #define		rFPGA0_AnalogParameter2		0x884
-#define		rFPGA0_AnalogParameter3		0x888	// Useless now
+#define		rFPGA0_AnalogParameter3		0x888	/* Useless now */
 #define		rFPGA0_AnalogParameter4		0x88c
 
-#define		rFPGA0_XA_LSSIReadBack		0x8a0	// Tranceiver LSSI Readback
+#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??
-#define 	rS0S1_PathSwitch			0x948
-
-//
-// 5. PageA(0xA00)
-//
-// Set Control channel to upper or lower. These settings are required only for 40MHz
+#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?? */
+#define	rS0S1_PathSwitch			0x948
+
+/*
+ * 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_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_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_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		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)
-//
+/*
+ * 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_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
@@ -227,12 +223,12 @@
 #define		rOFDM0_AGCRSSITable			0xc78
 #define		rOFDM0_HTSTFAGC				0xc7c
 
-#define		rOFDM0_XATxIQImbalance		0xc80	// TX PWR TRACK and DIG
+#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_XCTxAFE			0xc94
 #define		rOFDM0_XDTxIQImbalance		0xc98
 #define		rOFDM0_XDTxAFE				0xc9c
 
@@ -248,13 +244,13 @@
 #define		rOFDM0_FrameSync				0xcf0
 #define		rOFDM0_DFSReport				0xcf4
 
-//
-// 7. PageD(0xD00)
-//
+/*
+ * 7. PageD(0xD00)
+ *   */
 #define		rOFDM1_LSTF					0xd00
 #define		rOFDM1_TRxPathEnable			0xd04
 
-#define		rOFDM1_CFO						0xd08	// No setting now
+#define		rOFDM1_CFO						0xd08	/* No setting now */
 #define		rOFDM1_CSI1					0xd10
 #define		rOFDM1_SBD						0xd14
 #define		rOFDM1_CSI2					0xd18
@@ -265,18 +261,18 @@
 #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_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_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_PWMeasure1		0xdc4
+#define		rOFDM_PWMeasure2		0xdc8
 #define		rOFDM_BWReport				0xdcc
 #define		rOFDM_AGCReport				0xdd0
 #define		rOFDM_RxSNR					0xdd4
@@ -284,9 +280,9 @@
 #define		rOFDM_SIGReport				0xddc
 
 
-//
-// 8. PageE(0xE00)
-//
+/*
+ * 8. PageE(0xE00)
+ *   */
 #define		rTxAGC_A_Rate18_06			0xe00
 #define		rTxAGC_A_Rate54_24			0xe04
 #define		rTxAGC_A_CCK1_Mcs32			0xe08
@@ -301,7 +297,7 @@
 #define		rTx_IQK_PI_A					0xe38
 #define		rRx_IQK_PI_A					0xe3c
 
-#define		rTx_IQK 						0xe40
+#define		rTx_IQK						0xe40
 #define		rRx_IQK						0xe44
 #define		rIQK_AGC_Pts					0xe48
 #define		rIQK_AGC_Rsp					0xe4c
@@ -338,130 +334,130 @@
 #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		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
+/*
+ * 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_Channel				0x7	/* RF channel switch */
 
-//#endif
-#define		rZebra1_TxGain					0x8	// Useless now
+/* #endif */
+#define		rZebra1_TxGain					0x8	/* Useless now */
 #define		rZebra1_TxLPF					0x9
 #define		rZebra1_RxLPF					0xb
 #define		rZebra1_RxHPFCorner			0xc
 
-//Zebra4
-#define		rGlobalCtrl						0	// Useless now
+/* Zebra4 */
+#define		rGlobalCtrl						0	/* Useless now */
 #define		rRTL8256_TxLPF					19
 #define		rRTL8256_RxLPF					11
 
-//RTL8258
-#define		rRTL8258_TxLPF					0x11	// Useless now
+/* RTL8258 */
+#define		rRTL8258_TxLPF					0x11	/* Useless now */
 #define		rRTL8258_RxLPF					0x13
 #define		rRTL8258_RSSILPF				0xa
 
-//
-// RL6052 Register definition
-//
-#define		RF_AC						0x00	// 
+/*
+ * RL6052 Register definition
+ *   */
+#define		RF_AC						0x00	/*  */
 
-#define		RF_IQADJ_G1				0x01	// 
-#define		RF_IQADJ_G2				0x02	// 
+#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_POW_TRSW				0x05	/*  */
 
-#define		RF_GAIN_RX					0x06	// 
-#define		RF_GAIN_TX					0x07	// 
+#define		RF_GAIN_RX					0x06	/*  */
+#define		RF_GAIN_TX					0x07	/*  */
 
-#define		RF_TXM_IDAC				0x08	// 
-#define		RF_IPA_G					0x09	// 
+#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_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
-#define 	RF_TX_BIAS_A				0x35
-#define 	RF_TX_BIAS_D				0x36
-#define 	RF_LOBF_9					0x38
-#define 	RF_RXRF_A3					0x3C	//	
-#define 	RF_TRSW 					0x3F
-
-#define 	RF_TXRF_A2					0x41
-#define 	RF_TXPA_G4					0x46	
-#define 	RF_TXPA_A4					0x4B	
-#define 	RF_0x52 					0x52
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define 	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
 #define		RF_RXG_MIX_SWBW				0x87
 #define		RF_DBG_LP_RX2				0xDF
-#define 	RF_WE_LUT					0xEF	
-#define 	RF_S0S1 					0xB0
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
 
 #define RF_TX_GAIN_OFFSET_8188F(_val) (abs((_val)) | (((_val) > 0) ? BIT5 : 0))
 
-//
-//Bit Mask
-//
-// 1. Page1(0x100)
-#define		bBBResetB						0x100	// Useless now?
+/*
+ * Bit Mask
+ *
+ * 1. Page1(0x100) */
+#define		bBBResetB						0x100	/* Useless now? */
 #define		bGlobalResetB					0x200
 #define		bOFDMTxStart					0x4
 #define		bCCKTxStart						0x8
@@ -506,175 +502,175 @@
 #define		bCCKTxStatus					0x1
 #define		bOFDMTxStatus					0x2
 
-#define 		IS_BB_REG_OFFSET_92S(_Offset)		((_Offset >= 0x800) && (_Offset <= 0xfff))
+#define		IS_BB_REG_OFFSET_92S(_Offset)		((_Offset >= 0x800) && (_Offset <= 0xfff))
 
-// 2. Page8(0x800)
-#define		bRFMOD							0x1	// Reg 0x800 rFPGA0_RFMOD
+/* 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		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		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		bCCKSideBand			0x10	/* Reg 0xa00 rCCK0_System 20/40 switch */
 
-#define		bCCKScramble			0x8	// Useless
+#define		bCCKScramble			0x8	/* Useless */
 #define		bCCKAntDiversity		0x8000
 #define		bCCKCarrierRecovery		0x4000
 #define		bCCKTxRate				0x3000
@@ -690,7 +686,7 @@
 #define		bCCKBistMode			0x80000000
 #define		bCCKCCAMask			0x40000000
 #define		bCCKTxDACPhase		0x4
-#define		bCCKRxADCPhase		0x20000000   //r_rx_clk
+#define		bCCKRxADCPhase		0x20000000   /* r_rx_clk */
 #define		bCCKr_cp_mode0		0x0100
 #define		bCCKTxDCOffset			0xf0
 #define		bCCKRxDCOffset			0xf
@@ -704,12 +700,12 @@
 #define		bCCKRxIG				0x7f00
 #define		bCCKLNAPolarity			0x800000
 #define		bCCKRx1stGain			0x7f0000
-#define		bCCKRFExtend			0x20000000 //CCK Rx Iinital gain polarity
+#define		bCCKRFExtend			0x20000000 /* CCK Rx Iinital gain polarity */
 #define		bCCKRxAGCSatLevel		0x1f000000
 #define		bCCKRxAGCSatCount		0xe0
-#define		bCCKRxRFSettle			0x1f       //AGCsamp_dly
+#define		bCCKRxRFSettle			0x1f       /* AGCsamp_dly */
 #define		bCCKFixedRxAGC			0x8000
-//#define bCCKRxAGCFormat         	 	0x4000   //remove to HSSI register 0x824
+/* #define bCCKRxAGCFormat		0x4000 */   /* remove to HSSI register 0x824 */
 #define		bCCKAntennaPolarity		0x2000
 #define		bCCKTxFilterType		0x0c00
 #define		bCCKRxAGCReportType	0x0300
@@ -741,15 +737,15 @@
 #define		bCCKRxFACounterLower	0xff
 #define		bCCKRxFACounterUpper	0xff000000
 #define		bCCKRxHPAGCStart		0xe000
-#define		bCCKRxHPAGCFinal		0x1c00       		
+#define		bCCKRxHPAGCFinal		0x1c00
 #define		bCCKRxFalseAlarmEnable	0x8000
-#define		bCCKFACounterFreeze	0x4000       		
+#define		bCCKFACounterFreeze	0x4000
 #define		bCCKTxPathSel			0x10000000
 #define		bCCKDefaultRxPath		0xc000000
 #define		bCCKOptionRxPath		0x3000000
 
-// 5. PageC(0xC00)
-#define		bNumOfSTF				0x3	// Useless
+/* 5. PageC(0xC00) */
+#define		bNumOfSTF				0x3	/* Useless */
 #define		bShift_L					0xc0
 #define		bGI_TH					0xc
 #define		bRxPathA				0x1
@@ -850,8 +846,8 @@
 #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		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
@@ -885,7 +881,7 @@
 #define		bRxPD_Delay_TH1		0x38
 #define		bRxPD_Delay_TH2		0x1c0
 #define		bRxPD_DC_COUNT_MAX	0x600
-//#define bRxMF_Hold               0x3800
+/* #define bRxMF_Hold               0x3800 */
 #define		bRxPD_Delay_TH			0x8000
 #define		bRxProcess_Delay		0xf0000
 #define		bRxSearchrange_GI2_Early	0x700000
@@ -895,19 +891,19 @@
 #define		bRxSGI_TH				0xc0000000
 #define		bDFSCnt0				0xff
 #define		bDFSCnt1				0xff00
-#define		bDFSFlag				0xf0000       		
+#define		bDFSFlag				0xf0000
 #define		bMFWeightSum			0x300000
-#define		bMinIdxTH				0x7f000000       		
-#define		bDAFormat				0x40000       		
-#define		bTxChEmuEnable		0x01000000       		
+#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          
+#define		bTRSWIsolation_D		0x7f000000
+#define		bExtLNAGain				0x7c00
 
-// 6. PageE(0xE00)
-#define		bSTBCEn				0x4	// Useless
+/* 6. PageE(0xE00) */
+#define		bSTBCEn				0x4	/* Useless */
 #define		bAntennaMapping		0x10
 #define		bNss					0x20
 #define		bCFOAntSumD			0x200
@@ -916,12 +912,12 @@
 #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 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
@@ -934,14 +930,14 @@
 #define		bCounter_MCSNoSupport	0xffff
 #define		bCounter_FastSync	0xffff
 #define		bShortCFO			0xfff
-#define		bShortCFOTLength	12   //total
-#define		bShortCFOFLength	11   //fraction
+#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		bTailCFOFLength		12
 #define		bmax_en_pwdB		0xffff
 #define		bCC_power_dB		0xffff0000
 #define		bnoise_pwdB		0xffff
@@ -949,28 +945,28 @@
 #define		bPowerMeasFLength	3
 #define		bRx_HT_BW			0x1
 #define		bRxSC				0x6
-#define		bRx_HT				0x8       		
+#define		bRx_HT				0x8
 #define		bNB_intf_det_on		0x1
 #define		bIntf_win_len_cfg	0x30
-#define		bNB_Intf_TH_cfg		0x1c0       		
+#define		bNB_Intf_TH_cfg		0x1c0
 #define		bRFGain				0x3f
 #define		bTableSel			0x40
-#define		bTRSW				0x80       		
+#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		bSNREVMFLength		1
 #define		bCSI1st				0xff
 #define		bCSI2nd				0xff00
 #define		bRxEVM1st			0xff0000
-#define		bRxEVM2nd			0xff000000       		
+#define		bRxEVM2nd			0xff000000
 #define		bSIGEVM			0xff
 #define		bPWDB				0xff00
 #define		bSGIEN				0x10000
-       		
-#define		bSFactorQAM1		0xf	// Useless
+
+#define		bSFactorQAM1		0xf	/* Useless */
 #define		bSFactorQAM2		0xf0
 #define		bSFactorQAM3		0xf00
 #define		bSFactorQAM4		0xf000
@@ -980,8 +976,8 @@
 #define		bSFactorQAM8		0xf000000
 #define		bSFactorQAM9		0xf0000000
 #define		bCSIScheme			0x100000
-       		
-#define		bNoiseLvlTopSet		0x3	// Useless
+
+#define		bNoiseLvlTopSet		0x3	/* Useless */
 #define		bChSmooth			0x4
 #define		bChSmoothCfg1		0x38
 #define		bChSmoothCfg2		0x1c0
@@ -989,8 +985,8 @@
 #define		bChSmoothCfg4		0x7000
 #define		bMRCMode			0x800000
 #define		bTHEVMCfg			0x7000000
-       		
-#define		bLoopFitType		0x1	// Useless
+
+#define		bLoopFitType		0x1	/* Useless */
 #define		bUpdCFO			0x40
 #define		bUpdCFOOffData		0x80
 #define		bAdvUpdCFO			0x100
@@ -1006,8 +1002,8 @@
 #define		bUChCfg				0x7000000
 #define		bUpdEqz			0x8000000
 
-//Rx Pseduo noise
-#define		bRxPesudoNoiseOn		0x20000000	// Useless
+/* Rx Pseduo noise */
+#define		bRxPesudoNoiseOn		0x20000000	/* Useless */
 #define		bRxPesudoNoise_A		0xff
 #define		bRxPesudoNoise_B		0xff00
 #define		bRxPesudoNoise_C		0xff0000
@@ -1017,9 +1013,9 @@
 #define		bPesudoNoiseState_C	0xffff
 #define		bPesudoNoiseState_D	0xffff0000
 
-//7. RF Register
-//Zebra1
-#define		bZebra1_HSSIEnable		0x8		// Useless
+/* 7. RF Register
+ * Zebra1 */
+#define		bZebra1_HSSIEnable		0x8		/* Useless */
 #define		bZebra1_TRxControl		0xc00
 #define		bZebra1_TRxGainSetting	0x07f
 #define		bZebra1_RxCorner		0xc00
@@ -1029,24 +1025,24 @@
 #define		bZebra1_TxLPFBW		0x400
 #define		bZebra1_RxLPFBW		0x600
 
-//Zebra4
-#define		bRTL8256RegModeCtrl1	0x100	// Useless
+/* Zebra4 */
+#define		bRTL8256RegModeCtrl1	0x100	/* Useless */
 #define		bRTL8256RegModeCtrl0	0x40
 #define		bRTL8256_TxLPFBW		0x18
 #define		bRTL8256_RxLPFBW		0x600
 
-//RTL8258
-#define		bRTL8258_TxLPFBW		0xc	// Useless
+/* RTL8258 */
+#define		bRTL8258_TxLPFBW		0xc	/* Useless */
 #define		bRTL8258_RxLPFBW		0xc00
 #define		bRTL8258_RSSILPFBW	0xc0
 
 
-//
-// Other Definition
-//
+/*
+ * Other Definition
+ *   */
 
-//byte endable for sb_write
-#define		bByte0				0x1	// Useless
+/* byte endable for sb_write */
+#define		bByte0				0x1	/* Useless */
 #define		bByte1				0x2
 #define		bByte2				0x4
 #define		bByte3				0x8
@@ -1054,8 +1050,8 @@
 #define		bWord1				0xc
 #define		bDWord				0xf
 
-//for PutRegsetting & GetRegSetting BitMask
-#define		bMaskByte0			0xff	// Reg 0xc50 rOFDM0_XAAGCCore~0xC6f
+/* for PutRegsetting & GetRegSetting BitMask */
+#define		bMaskByte0			0xff	/* Reg 0xc50 rOFDM0_XAAGCCore~0xC6f */
 #define		bMaskByte1			0xff00
 #define		bMaskByte2			0xff0000
 #define		bMaskByte3			0xff000000
@@ -1064,44 +1060,44 @@
 #define		bMaskDWord		0xffffffff
 #define		bMaskH3Bytes		0xffffff00
 #define		bMask12Bits			0xfff
-#define		bMaskH4Bits			0xf0000000	
+#define		bMaskH4Bits			0xf0000000
 #define		bMaskOFDM_D		0xffc00000
 #define		bMaskCCK			0x3f3f3f3f
 
-  		
-#define		bEnable			0x1	// Useless
+
+#define		bEnable			0x1	/* Useless */
 #define		bDisable		0x0
-       		
-#define		LeftAntenna		0x0	// Useless
+
+#define		LeftAntenna		0x0	/* Useless */
 #define		RightAntenna	0x1
-       		
-#define		tCheckTxStatus		500   //500ms // Useless
-#define		tUpdateRxCounter	100   //100ms
-       		
-#define		rateCCK		0	// Useless
+
+#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 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 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		bPMACControl		0x0		/* Useless */
 #define		bWMACControl		0x1
 #define		bWNICControl		0x2
-       		
-#define		PathA			0x0	// Useless
+
+#define		PathA			0x0	/* Useless */
 #define		PathB			0x1
 #define		PathC			0x2
 #define		PathD			0x3
@@ -1109,19 +1105,19 @@
 /*--------------------------Define Parameters-------------------------------*/
 
 
-// BB Register Definition
-//
-// 4. Page9(0x900)
-//
+/* BB Register Definition
+ *
+ * 4. Page9(0x900)
+ *   */
 #define rDPDT_control				0x92c
 #define rfe_ctrl_anta_src				0x930
-#define rS0S1_PathSwitch   			0x948
+#define rS0S1_PathSwitch			0x948
 #define	BBrx_DFIR						0x954
 #define AGC_table_select				0xb2c
 
-//
-// PageB(0xB00)
-//
+/*
+ * PageB(0xB00)
+ *   */
 #define rPdp_AntA						0xb00
 #define rPdp_AntA_4						0xb04
 #define rPdp_AntA_8						0xb08
@@ -1133,7 +1129,7 @@
 #define rPdp_AntA_20					0xb20
 #define rPdp_AntA_24					0xb24
 
-#define rConfig_Pmpd_AntA 				0xb28
+#define rConfig_Pmpd_AntA				0xb28
 #define rConfig_ram64x16				0xb2c
 
 #define rBndA							0xb30
@@ -1168,4 +1164,3 @@
 #define rPm_Rx3_AntB					0xbf8
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPwrSeq.h
index 9686d1e33e96..56088ab60aac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8188FPwrSeq.h
@@ -1,10 +1,24 @@
 /* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8188F
 #define REALTEK_POWER_SEQUENCE_8188F
 
 #include "HalPwrSeqCmd.h"
 
-/* 
+/*
 	Check document WM-20130815-JackieLau-RTL8188F_Power_Architecture v08.vsd
 	There are 6 HW Power States:
 	0: POFF--Power Off
@@ -21,7 +35,7 @@
 	TRANS_SUS_TO_CARDEMU
 	TRANS_CARDEMU_TO_PDN
 	TRANS_ACT_TO_LPS
-	TRANS_LPS_TO_ACT	
+	TRANS_LPS_TO_ACT
 
 	TRANS_END
 */
@@ -32,111 +46,111 @@
 #define	RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS	15
 #define	RTL8188F_TRANS_PDN_TO_CARDEMU_STEPS	15
 #define	RTL8188F_TRANS_ACT_TO_LPS_STEPS		11
-#define	RTL8188F_TRANS_LPS_TO_ACT_STEPS		13	
+#define	RTL8188F_TRANS_LPS_TO_ACT_STEPS		13
 #define	RTL8188F_TRANS_ACT_TO_SWLPS_STEPS		21
 #define	RTL8188F_TRANS_SWLPS_TO_ACT_STEPS		14
 #define	RTL8188F_TRANS_END_STEPS		1
 
 
-#define RTL8188F_TRANS_CARDEMU_TO_ACT 														\
+#define RTL8188F_TRANS_CARDEMU_TO_ACT														\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 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, (BIT3), 0},/*  0x4[11]=1'b0 disable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* 0x4[8]=1 polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/	 \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, (BIT3), 0},/*  0x4[11]=1'b0 disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 0x4[8]=1 polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	 \
 	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x35}, /*0x27<=35 to reduce RF noise*/
 
 #define RTL8188F_TRANS_ACT_TO_CARDEMU													\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{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, BIT7, 0},/*0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */\
-	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x34}, /*0x27 <= 34, xtal_qsel=0 to xtal bring up*/\
+	{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, BIT7, 0},/*0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */\
+	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x34}, /*0x27 <= 34, xtal_qsel = 0 to xtal bring up*/\
 	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
 
 #define RTL8188F_TRANS_CARDEMU_TO_SUS													\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00}, /*0x07=0x00 , SOP option to disable BG/MB*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/ \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00}, /*0x07 = 0x00 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/ \
 	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
 
 #define RTL8188F_TRANS_SUS_TO_CARDEMU													\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
 	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
 
 #define RTL8188F_TRANS_CARDEMU_TO_CARDDIS													\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00}, /*0x07=0x00 , SOP option to disable BG/MB*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/ \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00}, /*0x07 = 0x00 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/ \
 	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
 
 #define RTL8188F_TRANS_CARDDIS_TO_CARDEMU													\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/	\
 	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/* 0xC4[4] <= 1, turn off USB APHY LDO under suspend mode*/
 
 
 #define RTL8188F_TRANS_CARDEMU_TO_PDN												\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
 
 #define RTL8188F_TRANS_PDN_TO_CARDEMU												\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
 
 #define RTL8188F_TRANS_ACT_TO_LPS														\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*set RPWM IMR*/	\
-	{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*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 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, BIT1, 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, 0x3F},/*Reset MAC TRX*/	\
-	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
+	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*set RPWM IMR*/	\
+	{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*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT1, 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, 0x3F},/*Reset MAC TRX*/	\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
 	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/
 
 
 #define RTL8188F_TRANS_LPS_TO_ACT															\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84},  /*SDIO RPWM*/\
-	{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*/\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_DELAY, 0, PWRSEQ_DELAY_MS}, /*Delay*/\
-	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xff,0x35},/*xtal_qsel=1 for low noise*/	\
-	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT7, 0}, /*Polling 0x109[7]=0  TSF in 40M*/\
-	{0x002B, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x1c, 0x1c},   /*.	0x2b[4:2] = 3b'111	to enable BB,AFE clock*/\
-	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0},  /*.	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 RTL8188F_TRANS_ACT_TO_SWLPS														\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84},  /*SDIO RPWM*/\
+	{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*/\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_MS}, /*Delay*/\
+	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x35},/*xtal_qsel = 1 for low noise*/	\
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT7, 0}, /*Polling 0x109[7]=0  TSF in 40M*/\
+	{0x002B, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x1c, 0x1c},   /*.	0x2b[4:2] = 3b'111	to enable BB, AFE clock*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0},  /*.	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 RTL8188F_TRANS_ACT_TO_SWLPS														\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
 	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*set RPWM IMR*/	\
@@ -144,14 +158,14 @@
 	{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*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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_WRITE, BIT0, 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, BIT1, 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, 0x3F},/*Reset MAC TRX*/	\
 	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*check if removed later*/	\
 	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
-	{0x002b, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x1C, 0x00},/*0x2b[4:2]<=0 to gated BB,AFE clock*/	\
-	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x34},/*xtal_qsel=0 for bring up*/	\
+	{0x002b, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x1C, 0x00},/*0x2b[4:2]<=0 to gated BB, AFE clock*/	\
+	{0x0027, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x34},/*xtal_qsel = 0 for bring up*/	\
 	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x00},/* sdio LPS option*/	\
 	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xff, 0x83},/* usb LPS option, open bandgap, xtal*/	\
 	{0x00C4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 0}, /* 0xC4[5]<=0, digital LDO no standby mode*/	\
@@ -164,37 +178,36 @@
 #define RTL8188F_TRANS_SWLPS_TO_ACT															\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/*polling TSF stable*/\
-	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*.	0x101[1] = 1, enable security engine*/\
-	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF}, /*.	0x100[7:0] = 0xFF	 enable WMAC TRX*/\
-	{0x06B7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x09}, /*.	reset MAC rx state machine*/\
-	{0x06B4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x86}, /*.	reset MAC rx state machine*/\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/* set CPU RAM code ready*/	\
-	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0},/* Enable CPU*/	\
-	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*enable CPU IO Wrapper*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2},/* Enable CPU*/	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT7, BIT7},/*polling FW init ready */	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT6, BIT6},/*polling FW init ready */	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/\
-	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0}, /*.	0x522 = 0*/
-	
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/*polling TSF stable*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	0x101[1] = 1, enable security engine*/\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF}, /*.	0x100[7:0] = 0xFF	 enable WMAC TRX*/\
+	{0x06B7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x09}, /*.	reset MAC rx state machine*/\
+	{0x06B4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x86}, /*.	reset MAC rx state machine*/\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/* set CPU RAM code ready*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/* Enable CPU*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*enable CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2},/* Enable CPU*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT7, BIT7},/*polling FW init ready */	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT6, BIT6},/*polling FW init ready */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0}, /*.	0x522 = 0*/
+
 #define RTL8188F_TRANS_END															\
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8188F_power_on_flow[RTL8188F_TRANS_CARDEMU_TO_ACT_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_radio_off_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_card_disable_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_card_enable_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_suspend_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_resume_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_hwpdn_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_enter_lps_flow[RTL8188F_TRANS_ACT_TO_LPS_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_leave_lps_flow[RTL8188F_TRANS_LPS_TO_ACT_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_enter_swlps_flow[RTL8188F_TRANS_ACT_TO_SWLPS_STEPS+RTL8188F_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8188F_leave_swlps_flow[RTL8188F_TRANS_SWLPS_TO_ACT_STEPS+RTL8188F_TRANS_END_STEPS];
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8188F_power_on_flow[RTL8188F_TRANS_CARDEMU_TO_ACT_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_radio_off_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_card_disable_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_card_enable_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_suspend_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_resume_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_hwpdn_flow[RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS + RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_enter_lps_flow[RTL8188F_TRANS_ACT_TO_LPS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_leave_lps_flow[RTL8188F_TRANS_LPS_TO_ACT_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_enter_swlps_flow[RTL8188F_TRANS_ACT_TO_SWLPS_STEPS + RTL8188F_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8188F_leave_swlps_flow[RTL8188F_TRANS_SWLPS_TO_ACT_STEPS + RTL8188F_TRANS_END_STEPS];
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyCfg.h
index 99563fe02162..2273431218e4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyCfg.h
@@ -1,178 +1,149 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8192EPHYCFG_H__
-#define __INC_HAL8192EPHYCFG_H__
-
-
-/*--------------------------Define Parameters-------------------------------*/
-#define LOOP_LIMIT				5
-#define MAX_STALL_TIME			50		//us
-#define AntennaDiversityValue	0x80	//(Adapter->bSoftwareAntennaDiversity ? 0x00:0x80)
-#define MAX_TXPWR_IDX_NMODE_92S	63
-#define Reset_Cnt_Limit			3
-
-#ifdef CONFIG_PCI_HCI
-#define MAX_AGGR_NUM	0x0B
-#else
-#define MAX_AGGR_NUM	0x07
-#endif // CONFIG_PCI_HCI
-
-
-/*--------------------------Define Parameters-------------------------------*/
-
-/*------------------------------Define structure----------------------------*/ 
-
-/* BB/RF related */
-
-/*------------------------------Define structure----------------------------*/ 
-
-
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export global variable----------------------------*/
-
-
-/*------------------------Export Marco Definition---------------------------*/
-/*------------------------Export Marco Definition---------------------------*/
-
-
-/*--------------------------Exported Function prototype---------------------*/
-//
-// BB and RF register read/write
-//
-u32	PHY_QueryBBReg8192E(	IN	PADAPTER	Adapter,
-								IN	u32			RegAddr,
-								IN	u32			BitMask	);
-void	PHY_SetBBReg8192E(	IN	PADAPTER		Adapter,
-								IN	u32			RegAddr,
-								IN	u32			BitMask,
-								IN	u32			Data	);
-u32	PHY_QueryRFReg8192E(	IN	PADAPTER	Adapter,
-								IN	u8			eRFPath,
-								IN	u32			RegAddr,
-								IN	u32			BitMask	);
-void	PHY_SetRFReg8192E(	IN	PADAPTER		Adapter,
-							IN	u8			eRFPath,
-								IN	u32			RegAddr,
-								IN	u32			BitMask,
-								IN	u32			Data	);
-
-//
-// Initialization related function
-//
-/* MAC/BB/RF HAL config */
-int	PHY_MACConfig8192E(IN PADAPTER	Adapter	);
-int	PHY_BBConfig8192E(IN PADAPTER	Adapter	);
-int	PHY_RFConfig8192E(IN PADAPTER	Adapter	);
-
-/* RF config */
-
-
-//
-// BB TX Power R/W
-//
-void	PHY_GetTxPowerLevel8192E(	IN PADAPTER	Adapter, OUT s32*	powerlevel	);
-void	PHY_SetTxPowerLevel8192E(	IN PADAPTER	Adapter, IN u8	channel	);
-BOOLEAN	PHY_UpdateTxPowerDbm8192E( IN PADAPTER	Adapter, IN int	powerInDbm	);
-
-VOID
-PHY_SetTxPowerIndex_8192E(
-	IN	PADAPTER			Adapter,
-	IN	u32					PowerIndex,
-	IN	u8					RFPath,	
-	IN	u8					Rate
-	);
-
-u8
-PHY_GetTxPowerIndex_8192E(
-	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
-	IN	u8					Rate,	
-	IN	CHANNEL_WIDTH		BandWidth,	
-	IN	u8					Channel
-	);
-
-//
-// Switch bandwidth for 8192S
-//
-VOID
-PHY_SetBWMode8192E(
-	IN	PADAPTER			pAdapter,
-	IN	CHANNEL_WIDTH	Bandwidth,
-	IN	u8					Offset
-);
-
-//
-// channel switch related funciton
-//
-VOID
-PHY_SwChnl8192E(
-	IN	PADAPTER	Adapter,
-	IN	u8			channel
-);
-
-
-VOID
-PHY_SetSwChnlBWMode8192E(
-	IN	PADAPTER			Adapter,
-	IN	u8					channel,
-	IN	CHANNEL_WIDTH	Bandwidth,
-	IN	u8					Offset40,
-	IN	u8					Offset80
-);
-
-VOID
-PHY_SetRFEReg_8192E(
-	IN PADAPTER		Adapter
-);
-
-void 
-phy_SpurCalibration_8192E(
-	IN	PADAPTER			Adapter,
-	IN	SPUR_CAL_METHOD	Method
-);
-void PHY_SpurCalibration_8192E(IN PADAPTER Adapter);
-
-#ifdef CONFIG_SPUR_CAL_NBI
-void 
-phy_SpurCalibration_8192E_NBI(
-	IN	PADAPTER			Adapter
-);
-#endif
-//
-// BB/MAC/RF other monitor API
-//
-
-VOID
-PHY_SetRFPathSwitch_8192E(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN		bMain
-);
-
-VOID
-storePwrIndexDiffRateOffset(
-	IN	PADAPTER	Adapter,
-	IN	u32		RegAddr,
-	IN	u32		BitMask,
-	IN	u32		Data
-	);
-
-/*--------------------------Exported Function prototype---------------------*/
-#endif	// __INC_HAL8192CPHYCFG_H
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8192EPHYCFG_H__
+#define __INC_HAL8192EPHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/*------------------------------Define structure----------------------------*/
+
+/* BB/RF related */
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/*
+ * BB and RF register read/write
+ *   */
+u32	PHY_QueryBBReg8192E(IN	PADAPTER	Adapter,
+			    IN	u32			RegAddr,
+			    IN	u32			BitMask);
+void	PHY_SetBBReg8192E(IN	PADAPTER		Adapter,
+			  IN	u32			RegAddr,
+			  IN	u32			BitMask,
+			  IN	u32			Data);
+u32	PHY_QueryRFReg8192E(IN	PADAPTER	Adapter,
+			    IN	enum rf_path	eRFPath,
+			    IN	u32			RegAddr,
+			    IN	u32			BitMask);
+void	PHY_SetRFReg8192E(IN	PADAPTER		Adapter,
+			  IN	enum rf_path	eRFPath,
+			  IN	u32			RegAddr,
+			  IN	u32			BitMask,
+			  IN	u32			Data);
+
+/*
+ * Initialization related function
+ *
+ * MAC/BB/RF HAL config */
+int	PHY_MACConfig8192E(IN PADAPTER	Adapter);
+int	PHY_BBConfig8192E(IN PADAPTER	Adapter);
+int	PHY_RFConfig8192E(IN PADAPTER	Adapter);
+
+/* RF config */
+
+
+/*
+ * BB TX Power R/W
+ *   */
+void	PHY_GetTxPowerLevel8192E(IN PADAPTER	Adapter, OUT s32	*powerlevel);
+void	PHY_SetTxPowerLevel8192E(IN PADAPTER	Adapter, IN u8	channel);
+BOOLEAN	PHY_UpdateTxPowerDbm8192E(IN PADAPTER	Adapter, IN int	powerInDbm);
+
+VOID
+PHY_SetTxPowerIndex_8192E(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8192E(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+/*
+ * channel switch related funciton
+ *   */
+VOID
+PHY_SetSwChnlBWMode8192E(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID
+PHY_SetRFEReg_8192E(
+	IN PADAPTER		Adapter
+);
+
+void
+phy_SpurCalibration_8192E(
+	IN	PADAPTER			Adapter,
+	IN	enum spur_cal_method	method
+);
+void PHY_SpurCalibration_8192E(IN PADAPTER Adapter);
+
+#ifdef CONFIG_SPUR_CAL_NBI
+void
+phy_SpurCalibration_8192E_NBI(
+	IN	PADAPTER			Adapter
+);
+#endif
+/*
+ * BB/MAC/RF other monitor API
+ *   */
+
+VOID
+phy_set_rf_path_switch_8192e(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype---------------------*/
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyReg.h
index 5f5d4586dc4e..4cd2c35540ae 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPhyReg.h
@@ -1,1134 +1,1147 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-/*****************************************************************************
- *	Copyright(c) 2008,  RealTEK Technology Inc. All Right Reserved.
- *
- * Module:	__INC_HAL8192SPHYREG_H
- *
- *
- * Note:	1. Define PMAC/BB register map
- *			2. Define RF register map
- *			3. PMAC/BB register bit mask.
- *			4. RF reg bit mask.
- *			5. Other BB/RF relative definition.
- *			
- *
- * Export:	Constants, macro, functions(API), global variables(None).
- *
- * Abbrev:	
- *
- * History:
- *		Data		Who		Remark 
- *      08/07/2007  MHC    	1. Porting from 9x series PHYCFG.h.
- *							2. Reorganize code architecture.
- *	09/25/2008	MH		1. Add RL6052 register definition
- * 
- *****************************************************************************/
-#ifndef __INC_HAL8192EPHYREG_H
-#define __INC_HAL8192EPHYREG_H
-
-
-/*--------------------------Define Parameters-------------------------------*/
-
-//============================================================
-//       8192S Regsiter offset definition
-//============================================================
-
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
-
-
-//
-// 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
-
-
-//
-// 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		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		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
-#define		rFPGA0_AdDaClockEn			0x888	// enable ad/da clock1 for dual-phy
-#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_ram64x16				0xb2c
-
-#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_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		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		rTxAGC_B_Mcs15_Mcs12		0x868
-#define		rTxAGC_B_CCK11_A_CCK2_11		0x86c
-
-#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
-
-//#endif
-#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_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_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_8192E			0x42	// 
-#define		RF_T_METER_88E				0x42	//
-#define		RF_T_METER					0x24	// 
-
-//#endif
-
-#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
-#define		RF_TX_BIAS_A					0x35
-#define		RF_TX_BIAS_D					0x36
-#define		RF_LOBF_9					0x38
-#define		RF_RXRF_A3					0x3C	//	
-#define		RF_TRSW						0x3F
-
-#define		RF_TXRF_A2					0x41
-#define		RF_TXPA_G4					0x46	
-#define		RF_TXPA_A4					0x4B	
-#define 		RF_0x52						0x52
-#define 		RF_LDO						0xB1
-#define		RF_WE_LUT					0xEF	
-
-
-//
-//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))
-#define		RF_TX_GAIN_OFFSET_8192E(_val)		((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
-
-
-// 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		bMaskH3Bytes				0xffffff00
-#define		bMask12Bits				0xfff	
-#define		bMaskH4Bits				0xf0000000	
-#define 		bMaskOFDM_D			0xffc00000
-#define		bMaskCCK				0x3f3f3f3f
-
-//for PutRFRegsetting & GetRFRegSetting BitMask
-//#define		bMask12Bits               0xfffff	// RF Reg mask bits
-//#define		bMask20Bits               0xfffff	// RF Reg mask bits T65 RF
-#define 		bRFRegOffsetMask			0xfffff		
-  		
-#define		bEnable                   0x1	// Useless
-#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
-
-
-// RSSI Dump Message 
-#define		rA_RSSIDump_92E 			0xcb0
-#define		rB_RSSIDump_92E 			0xcb1
-#define		rS1_RXevmDump_92E			0xcb2 
-#define		rS2_RXevmDump_92E			0xcb3
-#define		rA_RXsnrDump_92E			0xcb4
-#define		rB_RXsnrDump_92E			0xcb5
-#define		rA_CfoShortDump_92E		0xcb6 
-#define		rB_CfoShortDump_92E		0xcb8
-#define   	rA_CfoLongDump_92E			0xcba
-#define		rB_CfoLongDump_92E			0xcbc
-
-/*--------------------------Define Parameters-------------------------------*/
-
-
-#endif	//__INC_HAL8188EPHYREG_H
-
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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) 2008,  RealTEK Technology Inc. All Right Reserved.
+ *
+ * Module:	__INC_HAL8192SPHYREG_H
+ *
+ *
+ * Note:	1. Define PMAC/BB register map
+ *			2. Define RF register map
+ *			3. PMAC/BB register bit mask.
+ *			4. RF reg bit mask.
+ *			5. Other BB/RF relative definition.
+ *
+ *
+ * Export:	Constants, macro, functions(API), global variables(None).
+ *
+ * Abbrev:
+ *
+ * History:
+ *		Data		Who		Remark
+ *      08/07/2007  MHC	1. Porting from 9x series PHYCFG.h.
+ *							2. Reorganize code architecture.
+ *	09/25/2008	MH		1. Add RL6052 register definition
+ *
+ *****************************************************************************/
+#ifndef __INC_HAL8192EPHYREG_H
+#define __INC_HAL8192EPHYREG_H
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/* ************************************************************
+ * 8192S Regsiter offset definition
+ * ************************************************************ */
+
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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
+
+
+/*
+ * 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		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		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
+#define		rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#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_ram64x16				0xb2c
+
+#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_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		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		rTxAGC_B_Mcs15_Mcs12		0x868
+#define		rTxAGC_B_CCK11_A_CCK2_11		0x86c
+
+#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 */
+
+/* #endif */
+#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_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_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_8192E			0x42	/*  */
+#define		RF_T_METER_88E				0x42
+#define		RF_T_METER					0x24	/*  */
+
+/* #endif */
+
+#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 */
+#define		RF_TX_BIAS_A					0x35
+#define		RF_TX_BIAS_D					0x36
+#define		RF_LOBF_9					0x38
+#define		RF_RXRF_A3					0x3C	/*	 */
+#define		RF_TRSW						0x3F
+
+#define		RF_TXRF_A2					0x41
+#define		RF_TXPA_G4					0x46
+#define		RF_TXPA_A4					0x4B
+#define		RF_0x52						0x52
+#define		RF_LDO						0xB1
+#define		RF_WE_LUT					0xEF
+
+
+/*
+ * 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))
+#define		RF_TX_GAIN_OFFSET_8192E(_val)		((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
+
+
+/* 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		bMaskH3Bytes				0xffffff00
+#define		bMask12Bits				0xfff
+#define		bMaskH4Bits				0xf0000000
+#define		bMaskOFDM_D			0xffc00000
+#define		bMaskCCK				0x3f3f3f3f
+
+/* for PutRFRegsetting & GetRFRegSetting BitMask
+ * #define		bMask12Bits               0xfffff */	/* RF Reg mask bits
+ * #define		bMask20Bits               0xfffff */	/* RF Reg mask bits T65 RF */
+#define		bRFRegOffsetMask			0xfffff
+
+#define		bEnable                   0x1	/* Useless */
+#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
+
+
+/* RSSI Dump Message */
+#define		rA_RSSIDump_92E			0xcb0
+#define		rB_RSSIDump_92E			0xcb1
+#define		rS1_RXevmDump_92E			0xcb2
+#define		rS2_RXevmDump_92E			0xcb3
+#define		rA_RXsnrDump_92E			0xcb4
+#define		rB_RXsnrDump_92E			0xcb5
+#define		rA_CfoShortDump_92E		0xcb6
+#define		rB_CfoShortDump_92E		0xcb8
+#define	rA_CfoLongDump_92E			0xcba
+#define		rB_CfoLongDump_92E			0xcbc
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif /* __INC_HAL8188EPHYREG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPwrSeq.h
index 07d4c4ee7da3..c56e0ec00b12 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8192EPwrSeq.h
@@ -1,156 +1,170 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef REALTEK_POWER_SEQUENCE_8192E
-#define REALTEK_POWER_SEQUENCE_8192E
-
-#include "HalPwrSeqCmd.h"
-/* 
-	Check document WM-20110607-Paul-RTL8192E_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
-*/
-#define	RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS	18
-#define	RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS	18
-#define	RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS	18
-#define	RTL8192E_TRANS_SUS_TO_CARDEMU_STEPS	18
-#define	RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS	18
-#define	RTL8192E_TRANS_PDN_TO_CARDEMU_STEPS	18
-#define	RTL8192E_TRANS_ACT_TO_LPS_STEPS	23
-#define	RTL8192E_TRANS_LPS_TO_ACT_STEPS	23	
-#define	RTL8192E_TRANS_END_STEPS	1
-
-
-#define RTL8192E_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 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, BIT2, 0},/* disable SW LPS 0x04[10]=0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, (BIT4|BIT3), 0},/* disable WL suspend*/	\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, BIT1},/* 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, BIT0, BIT0},/* 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, BIT0, BIT0},/* polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/	\
-
-	
-#define RTL8192E_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{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, BIT7, 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
-
-
-#define RTL8192E_TRANS_CARDEMU_TO_SUS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, (BIT4|BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8192E_TRANS_SUS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8192E_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
-	{0x00CC, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*Unlock small LDO Register*/	\
-	{0x0011, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*Disable small LDO*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8192E_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0011, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*Enable small LDO*/	\
-	{0x00CC, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0}, /*Lock small LDO Register*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
-
-
-#define RTL8192E_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8192E_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-#define RTL8192E_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
-	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
-	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
-
-
-#define RTL8192E_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM, For Repeatly In and out, Taggle bit should be changed*/\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 0}, /*Polling 0x109[7]=0  TSF in 40M*/\
-	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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*/\
-	{0x013D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF}, /*Clear ISR*/
- 
-#define RTL8192E_TRANS_END															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8192E_power_on_flow[RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_radio_off_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_card_disable_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_card_enable_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_suspend_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_resume_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_hwpdn_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_enter_lps_flow[RTL8192E_TRANS_ACT_TO_LPS_STEPS+RTL8192E_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8192E_leave_lps_flow[RTL8192E_TRANS_LPS_TO_ACT_STEPS+RTL8192E_TRANS_END_STEPS];
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8192E
+#define REALTEK_POWER_SEQUENCE_8192E
+
+#include "HalPwrSeqCmd.h"
+/*
+	Check document WM-20110607-Paul-RTL8192E_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
+*/
+#define	RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS	18
+#define	RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS	18
+#define	RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS	18
+#define	RTL8192E_TRANS_SUS_TO_CARDEMU_STEPS	18
+#define	RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS	18
+#define	RTL8192E_TRANS_PDN_TO_CARDEMU_STEPS	18
+#define	RTL8192E_TRANS_ACT_TO_LPS_STEPS	23
+#define	RTL8192E_TRANS_LPS_TO_ACT_STEPS	23
+#define	RTL8192E_TRANS_END_STEPS	1
+
+
+#define RTL8192E_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, BIT2, 0},/* disable SW LPS 0x04[10]=0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* 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, BIT0, BIT0},/* 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, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+
+
+#define RTL8192E_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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, BIT7, 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+
+
+#define RTL8192E_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8192E_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8192E_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x00CC, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*Unlock small LDO Register*/	\
+	{0x0011, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*Disable small LDO*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8192E_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0011, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*Enable small LDO*/	\
+	{0x00CC, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*Lock small LDO Register*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+
+
+#define RTL8192E_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8192E_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8192E_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8192E_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM, For Repeatly In and out, Taggle bit should be changed*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 0}, /*Polling 0x109[7]=0  TSF in 40M*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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*/\
+	{0x013D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF}, /*Clear ISR*/
+
+#define RTL8192E_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8192E_power_on_flow[RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_radio_off_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_card_disable_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_card_enable_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_suspend_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_resume_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_hwpdn_flow[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS + RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_enter_lps_flow[RTL8192E_TRANS_ACT_TO_LPS_STEPS + RTL8192E_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8192E_leave_lps_flow[RTL8192E_TRANS_LPS_TO_ACT_STEPS + RTL8192E_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyCfg.h
index 9df208eebefb..96585e66a9f4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyCfg.h
@@ -1,144 +1,133 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8703BPHYCFG_H__
-#define __INC_HAL8703BPHYCFG_H__
-
-/*--------------------------Define Parameters-------------------------------*/
-#define LOOP_LIMIT				5
-#define MAX_STALL_TIME			50		//us
-#define AntennaDiversityValue	0x80	//(Adapter->bSoftwareAntennaDiversity ? 0x00:0x80)
-#define MAX_TXPWR_IDX_NMODE_92S	63
-#define Reset_Cnt_Limit			3
-
-#ifdef CONFIG_PCI_HCI
-#define MAX_AGGR_NUM	0x0B
-#else
-#define MAX_AGGR_NUM	0x07
-#endif // CONFIG_PCI_HCI
-
-
-/*--------------------------Define Parameters End-------------------------------*/
-
-
-/*------------------------------Define structure----------------------------*/
-
-/*------------------------------Define structure End----------------------------*/
-
-/*--------------------------Exported Function prototype---------------------*/
-u32
-PHY_QueryBBReg_8703B(
-	IN	PADAPTER	Adapter,
-	IN	u32		RegAddr,
-	IN	u32		BitMask
-	);
-
-VOID
-PHY_SetBBReg_8703B(
-	IN	PADAPTER	Adapter,
-	IN	u32		RegAddr,
-	IN	u32		BitMask,
-	IN	u32		Data
-	);
-
-u32
-PHY_QueryRFReg_8703B(
-	IN	PADAPTER			Adapter,
-	IN	u8				eRFPath,
-	IN	u32				RegAddr,
-	IN	u32				BitMask
-	);
-
-VOID
-PHY_SetRFReg_8703B(
-	IN	PADAPTER			Adapter,
-	IN	u8				eRFPath,
-	IN	u32				RegAddr,
-	IN	u32				BitMask,
-	IN	u32				Data
-	);
-
-/* MAC/BB/RF HAL config */
-int PHY_BBConfig8703B(PADAPTER	Adapter	);
-
-int PHY_RFConfig8703B(PADAPTER	Adapter	);
-
-s32 PHY_MACConfig8703B(PADAPTER padapter);
-
-int
-PHY_ConfigRFWithParaFile_8703B(
-	IN	PADAPTER			Adapter,
-	IN	u8* 				pFileName,
-	RF_PATH				eRFPath
-);
-
-VOID
-PHY_SetTxPowerIndex_8703B(
-	IN	PADAPTER			Adapter,
-	IN	u32					PowerIndex,
-	IN	u8					RFPath,	
-	IN	u8					Rate
-	);
-
-u8
-PHY_GetTxPowerIndex_8703B(
-	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
-	IN	u8					Rate,	
-	IN	CHANNEL_WIDTH		BandWidth,	
-	IN	u8					Channel
-	);
-
-VOID	
-PHY_GetTxPowerLevel8703B(			
-	IN	PADAPTER		Adapter,
-	OUT s32*		    		powerlevel	
-	);
-
-VOID
-PHY_SetTxPowerLevel8703B(
-	IN	PADAPTER		Adapter,
-	IN	u8			channel
-	);
-
-VOID
-PHY_SetBWMode8703B(
-	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH			Bandwidth,	// 20M or 40M
-	IN	unsigned char				Offset		// Upper, Lower, or Don't care
-);
-
-VOID
-PHY_SwChnl8703B(	// Call after initialization
-	IN	PADAPTER	Adapter,
-	IN	u8		channel
-	);
-
-VOID
-PHY_SetSwChnlBWMode8703B(
-	IN	PADAPTER			Adapter,
-	IN	u8					channel,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					Offset40,
-	IN	u8					Offset80
-);
-/*--------------------------Exported Function prototype End---------------------*/
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8703BPHYCFG_H__
+#define __INC_HAL8703BPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8703B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8703B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8703B(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8703B(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8703B(PADAPTER	Adapter);
+
+int PHY_RFConfig8703B(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8703B(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8703B(
+	IN	PADAPTER			Adapter,
+	IN	u8					*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8703B(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8703B(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8703B(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8703B(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8703B(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8703b(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyReg.h
index 5f0f23f911f4..75e154a48a03 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPhyReg.h
@@ -1,1139 +1,1134 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8703BPHYREG_H__
-#define __INC_HAL8703BPHYREG_H__
-
-#define		rSYM_WLBT_PAPE_SEL		0x64
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
-
-
-//
-// 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??
-#define	rDPDT_control				0x92c
-#define	rfe_ctrl_anta_src				0x930
-#define	rS0S1_PathSwitch   			0x948
-#define	rBBrx_DFIR					0x954
-
-//
-// 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 rPdp_AntA_8						0xb08
-#define rPdp_AntA_C						0xb0c
-#define rPdp_AntA_10					0xb10
-#define rPdp_AntA_14					0xb14
-#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
-//
-// 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
-
-//#endif
-#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
-#define 	RF_TX_BIAS_A				0x35
-#define 	RF_TX_BIAS_D				0x36
-#define 	RF_LOBF_9					0x38
-#define 	RF_RXRF_A3					0x3C	//	
-#define 	RF_TRSW 					0x3F
-
-#define 	RF_TXRF_A2					0x41
-#define 	RF_TXPA_G4					0x46	
-#define 	RF_TXPA_A4					0x4B	
-#define 	RF_0x52 					0x52
-#define 	RF_WE_LUT					0xEF	
-#define 	RF_S0S1 					0xB0
-
-//
-//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))
-#define	RF_TX_GAIN_OFFSET_8703B(_val) (abs((_val)) | (((_val) > 0) ? BIT5 : 0))
-
-// 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		bMaskH3Bytes		0xffffff00
-#define		bMask12Bits			0xfff
-#define		bMaskH4Bits			0xf0000000	
-#define		bMaskOFDM_D		0xffc00000
-#define		bMaskCCK			0x3f3f3f3f
-
-  		
-#define		bEnable			0x1	// Useless
-#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
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8703BPHYREG_H__
+#define __INC_HAL8703BPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+#define	rBBrx_DFIR					0x954
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define 	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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))
+#define	RF_TX_GAIN_OFFSET_8703B(_val) (abs((_val)) | (((_val) > 0) ? BIT5 : 0))
+
+/* 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPwrSeq.h
index 84a0d989d40e..a94e9e67c4a8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8703BPwrSeq.h
@@ -1,185 +1,199 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef REALTEK_POWER_SEQUENCE_8703B
-#define REALTEK_POWER_SEQUENCE_8703B
-
-#include "HalPwrSeqCmd.h"
-
-/* 
-	Check document WM-20140402-JackieLau-RTL8703B_Power_Architecture v09.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
-*/
-#define	RTL8703B_TRANS_CARDEMU_TO_ACT_STEPS	23
-#define	RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS	15
-#define	RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS	15
-#define	RTL8703B_TRANS_SUS_TO_CARDEMU_STEPS	15
-#define	RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS	15
-#define	RTL8703B_TRANS_PDN_TO_CARDEMU_STEPS	15
-#define	RTL8703B_TRANS_ACT_TO_LPS_STEPS		15
-#define	RTL8703B_TRANS_LPS_TO_ACT_STEPS		15	
-#define	RTL8703B_TRANS_END_STEPS		1
-
-
-#define RTL8703B_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
-	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, 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, (BIT4|BIT3|BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/	\
-	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
-	{0x0004, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 , BIT3},/* enabled usb resume */	\
-	{0x0004, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 , 0},/* disable usb resume */	\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
-	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4|BIT3), 0},/* disable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/	\
-	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/* Enable WL control XTAL setting*/	\
-	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
-	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
-	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
-	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
-	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
-	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3},/*For GPIO9 internal pull high setting by test chip*/\
-	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/*For GPIO9 internal pull high setting*/\
-
-
-#define RTL8703B_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{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*/	\
-	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
-	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, 0},/* Enable BT control XTAL setting*/\
-	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
-
-
-#define RTL8703B_TRANS_CARDEMU_TO_SUS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, (BIT4|BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8703B_TRANS_SUS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8703B_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
-        {0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8703B_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-        {0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 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, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
-
-
-#define RTL8703B_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8703B_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-#define RTL8703B_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
-	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
-	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
-
-
-#define RTL8703B_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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 RTL8703B_TRANS_END															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8703B_power_on_flow[RTL8703B_TRANS_CARDEMU_TO_ACT_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_radio_off_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_card_disable_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_card_enable_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_suspend_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_resume_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_hwpdn_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_enter_lps_flow[RTL8703B_TRANS_ACT_TO_LPS_STEPS+RTL8703B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8703B_leave_lps_flow[RTL8703B_TRANS_LPS_TO_ACT_STEPS+RTL8703B_TRANS_END_STEPS];
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8703B
+#define REALTEK_POWER_SEQUENCE_8703B
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20140402-JackieLau-RTL8703B_Power_Architecture v09.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
+*/
+#define	RTL8703B_TRANS_CARDEMU_TO_ACT_STEPS	23
+#define	RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8703B_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8703B_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8703B_TRANS_ACT_TO_LPS_STEPS		15
+#define	RTL8703B_TRANS_LPS_TO_ACT_STEPS		15
+#define	RTL8703B_TRANS_END_STEPS		1
+
+
+#define RTL8703B_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, (BIT4 | BIT3 | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
+	{0x0004, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 , BIT3},/* enabled usb resume */	\
+	{0x0004, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 , 0},/* disable usb resume */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* Enable WL control XTAL setting*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
+	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3},/*For GPIO9 internal pull high setting by test chip*/\
+	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/*For GPIO9 internal pull high setting*/\
+
+
+#define RTL8703B_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* Enable BT control XTAL setting*/\
+	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
+
+
+#define RTL8703B_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8703B_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8703B_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8703B_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8703B_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8703B_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8703B_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8703B_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8703B_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8703B_power_on_flow[RTL8703B_TRANS_CARDEMU_TO_ACT_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_radio_off_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_card_disable_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_card_enable_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_suspend_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_resume_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_hwpdn_flow[RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_enter_lps_flow[RTL8703B_TRANS_ACT_TO_LPS_STEPS + RTL8703B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8703B_leave_lps_flow[RTL8703B_TRANS_LPS_TO_ACT_STEPS + RTL8703B_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyCfg.h
index 534e1be319ab..2a3e4c50418e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyCfg.h
@@ -1,149 +1,133 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8723BPHYCFG_H__
-#define __INC_HAL8723BPHYCFG_H__
-
-/*--------------------------Define Parameters-------------------------------*/
-#define LOOP_LIMIT				5
-#define MAX_STALL_TIME			50		//us
-#define AntennaDiversityValue	0x80	//(Adapter->bSoftwareAntennaDiversity ? 0x00:0x80)
-#define MAX_TXPWR_IDX_NMODE_92S	63
-#define Reset_Cnt_Limit			3
-
-#ifdef CONFIG_PCI_HCI
-#define MAX_AGGR_NUM	0x0B
-#else
-#define MAX_AGGR_NUM	0x07
-#endif // CONFIG_PCI_HCI
-
-
-/*--------------------------Define Parameters End-------------------------------*/
-
-
-/*------------------------------Define structure----------------------------*/
-
-/*------------------------------Define structure End----------------------------*/
-
-/*--------------------------Exported Function prototype---------------------*/
-u32
-PHY_QueryBBReg_8723B(
-	IN	PADAPTER	Adapter,
-	IN	u32		RegAddr,
-	IN	u32		BitMask
-	);
-
-VOID
-PHY_SetBBReg_8723B(
-	IN	PADAPTER	Adapter,
-	IN	u32		RegAddr,
-	IN	u32		BitMask,
-	IN	u32		Data
-	);
-
-u32
-PHY_QueryRFReg_8723B(
-	IN	PADAPTER			Adapter,
-	IN	u8				eRFPath,
-	IN	u32				RegAddr,
-	IN	u32				BitMask
-	);
-
-VOID
-PHY_SetRFReg_8723B(
-	IN	PADAPTER			Adapter,
-	IN	u8				eRFPath,
-	IN	u32				RegAddr,
-	IN	u32				BitMask,
-	IN	u32				Data
-	);
-
-/* MAC/BB/RF HAL config */
-int PHY_BBConfig8723B(PADAPTER	Adapter	);
-
-int PHY_RFConfig8723B(PADAPTER	Adapter	);
-
-s32 PHY_MACConfig8723B(PADAPTER padapter);
-
-int
-PHY_ConfigRFWithParaFile_8723B(
-	IN	PADAPTER			Adapter,
-	IN	u8* 				pFileName,
-	RF_PATH				eRFPath
-);
-
-VOID
-PHY_SetTxPowerIndex_8723B(
-	IN	PADAPTER			Adapter,
-	IN	u32					PowerIndex,
-	IN	u8					RFPath,	
-	IN	u8					Rate
-	);
-
-u8
-PHY_GetTxPowerIndex_8723B(
-	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
-	IN	u8					Rate,	
-	IN	CHANNEL_WIDTH		BandWidth,	
-	IN	u8					Channel
-	);
-
-VOID	
-PHY_GetTxPowerLevel8723B(			
-	IN	PADAPTER		Adapter,
-	OUT s32*		    		powerlevel	
-	);
-
-VOID
-PHY_SetTxPowerLevel8723B(
-	IN	PADAPTER		Adapter,
-	IN	u8			channel
-	);
-
-VOID
-PHY_SetBWMode8723B(
-	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH			Bandwidth,	// 20M or 40M
-	IN	unsigned char				Offset		// Upper, Lower, or Don't care
-);
-
-VOID
-PHY_SwChnl8723B(	// Call after initialization
-	IN	PADAPTER	Adapter,
-	IN	u8		channel
-	);
-
-VOID
-PHY_SetSwChnlBWMode8723B(
-	IN	PADAPTER			Adapter,
-	IN	u8					channel,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					Offset40,
-	IN	u8					Offset80
-);
-
-VOID PHY_SetRFPathSwitch_8723B(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN		bMain
-	);
-/*--------------------------Exported Function prototype End---------------------*/
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723BPHYCFG_H__
+#define __INC_HAL8723BPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8723B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8723B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8723B(
+	IN	PADAPTER			Adapter,
+	IN	enum rf_path			eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8723B(
+	IN	PADAPTER			Adapter,
+	IN	enum rf_path			eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8723B(PADAPTER	Adapter);
+
+int PHY_RFConfig8723B(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8723B(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8723B(
+	IN	PADAPTER			Adapter,
+	IN	u8					*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8723B(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8723B(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8723B(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8723B(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8723B(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8723b(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyReg.h
index ff444b275454..a816352009e2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPhyReg.h
@@ -1,1137 +1,1132 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8723BPHYREG_H__
-#define __INC_HAL8723BPHYREG_H__
-
-#define		rSYM_WLBT_PAPE_SEL		0x64
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
-
-
-//
-// 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??
-#define	rDPDT_control				0x92c
-#define	rfe_ctrl_anta_src				0x930
-#define	rS0S1_PathSwitch   			0x948
-
-//
-// 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 rPdp_AntA_8						0xb08
-#define rPdp_AntA_C						0xb0c
-#define rPdp_AntA_10					0xb10
-#define rPdp_AntA_14					0xb14
-#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
-//
-// 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
-
-//#endif
-#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
-#define 	RF_TX_BIAS_A				0x35
-#define 	RF_TX_BIAS_D				0x36
-#define 	RF_LOBF_9					0x38
-#define 	RF_RXRF_A3					0x3C	//	
-#define 	RF_TRSW 					0x3F
-
-#define 	RF_TXRF_A2					0x41
-#define 	RF_TXPA_G4					0x46	
-#define 	RF_TXPA_A4					0x4B	
-#define 	RF_0x52 					0x52
-#define 	RF_WE_LUT					0xEF	
-#define 	RF_S0S1 					0xB0
-
-//
-//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		bMaskH3Bytes		0xffffff00
-#define		bMask12Bits			0xfff
-#define		bMaskH4Bits			0xf0000000	
-#define		bMaskOFDM_D		0xffc00000
-#define		bMaskCCK			0x3f3f3f3f
-
-  		
-#define		bEnable			0x1	// Useless
-#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
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723BPHYREG_H__
+#define __INC_HAL8723BPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define 	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPwrSeq.h
index c3bb0e95e586..26a6cf8744e9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723BPwrSeq.h
@@ -1,234 +1,247 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef REALTEK_POWER_SEQUENCE_8723B
-#define REALTEK_POWER_SEQUENCE_8723B
-
-#include "HalPwrSeqCmd.h"
-
-/* 
-	Check document WM-20130815-JackieLau-RTL8723B_Power_Architecture v08.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
-*/
-#define	RTL8723B_TRANS_CARDEMU_TO_ACT_STEPS	26
-#define	RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS	15
-#define	RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS	15
-#define	RTL8723B_TRANS_SUS_TO_CARDEMU_STEPS	15
-#define	RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS	15
-#define	RTL8723B_TRANS_PDN_TO_CARDEMU_STEPS	15
-#define	RTL8723B_TRANS_ACT_TO_LPS_STEPS		15
-#define	RTL8723B_TRANS_LPS_TO_ACT_STEPS		15	
-#define	RTL8723B_TRANS_ACT_TO_SWLPS_STEPS		22
-#define	RTL8723B_TRANS_SWLPS_TO_ACT_STEPS		15
-#define	RTL8723B_TRANS_END_STEPS		1
-
-
-#define RTL8723B_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
-	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, 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, (BIT4|BIT3|BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/	\
-	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
-	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4|BIT3), 0},/* disable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/	\
-	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/* Enable WL control XTAL setting*/	\
-	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
-	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
-	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
-	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
-	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
-	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3},/*For GPIO9 internal pull high setting by test chip*/\
-	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/*For GPIO9 internal pull high setting*/\
-
-
-#define RTL8723B_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{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*/	\
-	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
-	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, 0},/* Enable BT control XTAL setting*/\
-	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
-
-
-#define RTL8723B_TRANS_CARDEMU_TO_SUS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, (BIT4|BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8723B_TRANS_SUS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8723B_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
-        {0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8723B_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-        {0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 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, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
-
-
-#define RTL8723B_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8723B_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-#define RTL8723B_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
-	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
-	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
-
-
-#define RTL8723B_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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 RTL8723B_TRANS_ACT_TO_SWLPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*enable 32 K source*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled,and clock are gated*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1},/*CCK and OFDM are enable*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled,and clock are gated*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1},/*CCK and OFDM are enable*/	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled,and clock are gated*/	\
-	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x3F},/*Reset MAC TRX*/	\
-	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*disable security engine*/	\
-	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x40},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*reset dual TSF*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0},/*Reset CPU*/	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*Reset MCUFWDL register*/	\
-	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
-	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1},/*Reset CPU IO Wrapper*/	\
-	{0x0287, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, 0xFF, 0},/*polling RXFF packet number = 0 */	\
-	{0x0286, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, BIT1},/*polling RXDMA idle */	\
-	{0x013D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Clear FW RPWM interrupt */\
-	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Set FW RPWM interrupt source*/\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4},/*switch TSF to 32K*/\
-	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/*polling TSF stable*/\
-	{0x0090, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Set FW LPS*/	\
-	{0x0090, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/*polling FW LPS ready */	
-
-
-#define RTL8723B_TRANS_SWLPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0},/*switch TSF to 32K*/\
-	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/*polling TSF stable*/\
-	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*.	0x101[1] = 1, enable security engine*/\
-	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF}, /*.	0x100[7:0] = 0xFF	 enable WMAC TRX*/\
-	{0x06B7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x09}, /*.	reset MAC rx state machine*/\
-	{0x06B4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x86}, /*.	reset MAC rx state machine*/\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/* set CPU RAM code ready*/	\
-	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0},/* Enable CPU*/	\
-	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*enable CPU IO Wrapper*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2},/* Enable CPU*/	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT7, BIT7},/*polling FW init ready */	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT6, BIT6},/*polling FW init ready */	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/\
-	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0}, /*.	0x522 = 0*/
-	
-#define RTL8723B_TRANS_END															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8723B_power_on_flow[RTL8723B_TRANS_CARDEMU_TO_ACT_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_radio_off_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_card_disable_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_card_enable_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_suspend_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_resume_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_hwpdn_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_enter_lps_flow[RTL8723B_TRANS_ACT_TO_LPS_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_leave_lps_flow[RTL8723B_TRANS_LPS_TO_ACT_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_enter_swlps_flow[RTL8723B_TRANS_ACT_TO_SWLPS_STEPS+RTL8723B_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723B_leave_swlps_flow[RTL8723B_TRANS_SWLPS_TO_ACT_STEPS+RTL8723B_TRANS_END_STEPS];
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8723B
+#define REALTEK_POWER_SEQUENCE_8723B
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20130815-JackieLau-RTL8723B_Power_Architecture v08.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
+*/
+#define	RTL8723B_TRANS_CARDEMU_TO_ACT_STEPS	26
+#define	RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8723B_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8723B_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8723B_TRANS_ACT_TO_LPS_STEPS		15
+#define	RTL8723B_TRANS_LPS_TO_ACT_STEPS		15
+#define	RTL8723B_TRANS_ACT_TO_SWLPS_STEPS		22
+#define	RTL8723B_TRANS_SWLPS_TO_ACT_STEPS		15
+#define	RTL8723B_TRANS_END_STEPS		1
+
+
+#define RTL8723B_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, (BIT4 | BIT3 | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* Enable WL control XTAL setting*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
+	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3},/*For GPIO9 internal pull high setting by test chip*/\
+	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/*For GPIO9 internal pull high setting*/\
+
+
+#define RTL8723B_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	\
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* Enable BT control XTAL setting*/\
+	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
+
+
+#define RTL8723B_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723B_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8723B_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723B_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8723B_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8723B_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8723B_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8723B_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8723B_TRANS_ACT_TO_SWLPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*enable 32 K source*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1},/*CCK and OFDM are enable*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1},/*CCK and OFDM are enable*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated*/	\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x3F},/*Reset MAC TRX*/	\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*disable security engine*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x40},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*reset dual TSF*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/*Reset CPU*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*Reset MCUFWDL register*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1},/*Reset CPU IO Wrapper*/	\
+	{0x0287, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, 0xFF, 0},/*polling RXFF packet number = 0 */	\
+	{0x0286, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/*polling RXDMA idle */	\
+	{0x013D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Clear FW RPWM interrupt */\
+	{0x0139, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Set FW RPWM interrupt source*/\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/*switch TSF to 32K*/\
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/*polling TSF stable*/\
+	{0x0090, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Set FW LPS*/	\
+	{0x0090, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/*polling FW LPS ready */
+
+
+#define RTL8723B_TRANS_SWLPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/*switch TSF to 32K*/\
+	{0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/*polling TSF stable*/\
+	{0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*.	0x101[1] = 1, enable security engine*/\
+	{0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF}, /*.	0x100[7:0] = 0xFF	 enable WMAC TRX*/\
+	{0x06B7, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x09}, /*.	reset MAC rx state machine*/\
+	{0x06B4, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x86}, /*.	reset MAC rx state machine*/\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/* set CPU RAM code ready*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*Reset CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/* Enable CPU*/	\
+	{0x001D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*enable CPU IO Wrapper*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2},/* Enable CPU*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT7, BIT7},/*polling FW init ready */	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT6, BIT6},/*polling FW init ready */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0}, /*.	0x522 = 0*/
+
+#define RTL8723B_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8723B_power_on_flow[RTL8723B_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_radio_off_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_card_disable_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_card_enable_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_suspend_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_resume_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_hwpdn_flow[RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_enter_lps_flow[RTL8723B_TRANS_ACT_TO_LPS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_leave_lps_flow[RTL8723B_TRANS_LPS_TO_ACT_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_enter_swlps_flow[RTL8723B_TRANS_ACT_TO_SWLPS_STEPS + RTL8723B_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723B_leave_swlps_flow[RTL8723B_TRANS_SWLPS_TO_ACT_STEPS + RTL8723B_TRANS_END_STEPS];
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPhyCfg.h
new file mode 100644
index 000000000000..da572858d125
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPhyCfg.h
@@ -0,0 +1,132 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723DPHYCFG_H__
+#define __INC_HAL8723DPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8723D(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8723D(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8723D(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8723D(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8723D(PADAPTER	Adapter);
+
+int PHY_RFConfig8723D(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8723D(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8723D(
+	IN	PADAPTER			Adapter,
+	IN	u8				*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8723D(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8723D(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8723D(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8723D(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8723D(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8723d(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPhyReg.h
new file mode 100644
index 000000000000..f8b190dc790b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPhyReg.h
@@ -0,0 +1,1135 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8723DPHYREG_H__
+#define __INC_HAL8723DPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other definition for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+#define	rBBrx_DFIR					0x954
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 imbalance 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_T_METER_88E				0x42
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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))
+#define		RF_TX_GAIN_OFFSET_8723D(_val) (abs((_val)) | (((_val) > 0) ? BIT(4) : 0))
+
+/* 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPwrSeq.h
new file mode 100644
index 000000000000..021c414c5a94
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723DPwrSeq.h
@@ -0,0 +1,207 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8723D
+#define REALTEK_POWER_SEQUENCE_8723D
+
+/* #include "PwrSeqCmd.h" */
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20110607-Paul-RTL8192e_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 transition 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
+*/
+#define	RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS	27
+#define	RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS	8
+#define	RTL8723D_TRANS_CARDEMU_TO_SUS_STEPS	7
+#define	RTL8723D_TRANS_SUS_TO_CARDEMU_STEPS	5
+#define	RTL8723D_TRANS_CARDEMU_TO_CARDDIS_STEPS	8
+#define	RTL8723D_TRANS_CARDDIS_TO_CARDEMU_STEPS	7
+#define	RTL8723D_TRANS_CARDEMU_TO_PDN_STEPS	4
+#define	RTL8723D_TRANS_PDN_TO_CARDEMU_STEPS	1
+#define	RTL8723D_TRANS_ACT_TO_LPS_STEPS		13
+#define	RTL8723D_TRANS_LPS_TO_ACT_STEPS		11
+#define	RTL8723D_TRANS_END_STEPS	1
+
+
+#define RTL8723D_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*0x20[0] = 1b'1 enable LDOA12 MACRO block for all interface*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_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(4) | BIT(3) | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/ \
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0) , BIT(0)},/* Disable USB suspend */	\
+	{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*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0) , 0},/* Enable USB suspend */	\
+	{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_POLLING, (BIT(1) | BIT(0)), 0}, \
+	{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},/**/ \
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(6), BIT(6)},/* Enable WL control XTAL setting*/ \
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)},/*Enable HSISR GPIO9 interrupt*/\
+	{0x0068, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3), BIT(3)},/*For GPIO9 internal pull high setting by test chip*/\
+	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(6), BIT(6)},/*For GPIO9 internal pull high setting*/\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*reset RF path S1*/\
+	{0x0077, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*reset RF path S0*/\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/*enable RF path S1*/\
+	{0x0077, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/*enalbe RF path S0*/\
+
+
+#define RTL8723D_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	/*{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*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0}, /*0x2[0]=0 Reset BB, RF enter Power Down mode*/ \
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), 0},/*Enable rising edge triggering interrupt*/ \
+	{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(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*/ \
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(6), 0},/* Enable BT control XTAL setting*/\
+	{0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
+
+
+#define RTL8723D_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4) | BIT(3), (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), BIT(4)}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), 0}, /*wait power state to suspend*/
+
+#define RTL8723D_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{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*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), 0}, /*Set SDIO suspend local register*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), BIT(1)}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{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 RTL8723D_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(2), BIT(2)}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(4), BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), BIT(4)}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), 0}, /*wait power state to suspend*/
+
+#define RTL8723D_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{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*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT(0), 0}, /*Set SDIO suspend local register*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT(1), BIT(1)}, /*wait power state to suspend*/\
+	{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*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8723D_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), BIT(4)}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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 RTL8723D_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{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 RTL8723D_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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*/ \
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{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 RTL8723D_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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), BIT1 | BIT0}, /*.	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 RTL8723D_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8723D_power_on_flow[RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_radio_off_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_card_disable_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_CARDDIS_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_card_enable_flow[RTL8723D_TRANS_CARDDIS_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_suspend_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_resume_flow[RTL8723D_TRANS_SUS_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_hwpdn_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_enter_lps_flow[RTL8723D_TRANS_ACT_TO_LPS_STEPS + RTL8723D_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723D_leave_lps_flow[RTL8723D_TRANS_LPS_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723PwrSeq.h
index b2b2489d370f..22d600607d9b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723PwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8723PwrSeq.h
@@ -1,171 +1,184 @@
 /* SPDX-License-Identifier: GPL-2.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"
-
-#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
-
-
-#define RTL8723A_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
-	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, 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, BIT2, 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, BIT1, BIT1},/* 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, BIT0, BIT0},/* 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, BIT7, 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, (BIT4|BIT3), 0},/* disable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/	\
-	{0x004E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 1},/*0x4C[23] = 0x4E[7] = 1, switch DPDT_SEL_P output from WL BB */\
-
-#define RTL8723A_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{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, BIT7, 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, BIT1, BIT1}, /*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, BIT1, 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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/   \
-
-
-#define RTL8723A_TRANS_CARDEMU_TO_SUS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, (BIT4|BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8723A_TRANS_SUS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8723A_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
-	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8723A_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 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, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
-
-
-#define RTL8723A_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8723A_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-#define RTL8723A_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
-	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
-	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
-
-
-#define RTL8723A_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8723A_power_on_flow[RTL8723A_TRANS_CARDEMU_TO_ACT_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_radio_off_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_card_disable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_card_enable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_suspend_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_resume_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_hwpdn_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_enter_lps_flow[RTL8723A_TRANS_ACT_TO_LPS_STEPS+RTL8723A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8723A_leave_lps_flow[RTL8723A_TRANS_LPS_TO_ACT_STEPS+RTL8723A_TRANS_END_STEPS];
-
-#endif
-
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __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"
+
+#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
+
+
+#define RTL8723A_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, BIT2, 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, BIT1, BIT1},/* 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, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x004E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 1},/*0x4C[23] = 0x4E[7] = 1, switch DPDT_SEL_P output from WL BB */\
+
+#define RTL8723A_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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, BIT7, 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, BIT1, BIT1}, /*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, BIT1, 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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/   \
+
+
+#define RTL8723A_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723A_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8723A_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8723A_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8723A_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8723A_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8723A_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8723A_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8723A_power_on_flow[RTL8723A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_radio_off_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_card_disable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_card_enable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_suspend_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_resume_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_hwpdn_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_enter_lps_flow[RTL8723A_TRANS_ACT_TO_LPS_STEPS + RTL8723A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8723A_leave_lps_flow[RTL8723A_TRANS_LPS_TO_ACT_STEPS + RTL8723A_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyCfg.h
index f8c83e156e28..7a6403f459f1 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyCfg.h
@@ -1,165 +1,144 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8812PHYCFG_H__
-#define __INC_HAL8812PHYCFG_H__
-
-
-/*--------------------------Define Parameters-------------------------------*/
-#define LOOP_LIMIT				5
-#define MAX_STALL_TIME			50		//us
-#define AntennaDiversityValue	0x80	//(Adapter->bSoftwareAntennaDiversity ? 0x00:0x80)
-#define MAX_TXPWR_IDX_NMODE_92S	63
-#define Reset_Cnt_Limit			3
-
-
-#ifdef CONFIG_PCI_HCI
-#define MAX_AGGR_NUM	0x0B
-#else
-#define MAX_AGGR_NUM	0x07
-#endif // CONFIG_PCI_HCI
-
-
-/*--------------------------Define Parameters-------------------------------*/
-
-/*------------------------------Define structure----------------------------*/ 
-
-
-/* BB/RF related */
-
-/*------------------------------Define structure----------------------------*/ 
-
-
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export global variable----------------------------*/
-
-
-/*------------------------Export Marco Definition---------------------------*/
-/*------------------------Export Marco Definition---------------------------*/
-
-
-/*--------------------------Exported Function prototype---------------------*/
-//
-// BB and RF register read/write
-//
-u32	PHY_QueryBBReg8812(	IN	PADAPTER	Adapter,
-								IN	u32			RegAddr,
-								IN	u32			BitMask	);
-void	PHY_SetBBReg8812(	IN	PADAPTER		Adapter,
-								IN	u32			RegAddr,
-								IN	u32			BitMask,
-								IN	u32			Data	);
-u32	PHY_QueryRFReg8812(	IN	PADAPTER	Adapter,
-								IN	u8			eRFPath,
-								IN	u32			RegAddr,
-								IN	u32			BitMask	);
-void	PHY_SetRFReg8812(	IN	PADAPTER		Adapter,
-								IN	u8			eRFPath,
-								IN	u32			RegAddr,
-								IN	u32			BitMask,
-								IN	u32			Data	);
-
-//
-// Initialization related function
-//
-/* MAC/BB/RF HAL config */
-int	PHY_MACConfig8812(IN PADAPTER	Adapter	);
-int	PHY_BBConfig8812(IN PADAPTER	Adapter	);
-void	PHY_BB8812_Config_1T(IN PADAPTER	Adapter );
-int	PHY_RFConfig8812(IN PADAPTER	Adapter	);
-
-/* RF config */
-
-s32
-PHY_SwitchWirelessBand8812(
-	IN PADAPTER		Adapter,
-	IN u8			Band
-);
-
-//
-// BB TX Power R/W
-//
-void	PHY_GetTxPowerLevel8812(	IN PADAPTER	Adapter, OUT s32*	powerlevel	);
-void	PHY_SetTxPowerLevel8812(	IN PADAPTER	Adapter, IN u8	Channel	);
-
-BOOLEAN	PHY_UpdateTxPowerDbm8812( IN PADAPTER	Adapter, IN int	powerInDbm	);
-u8 PHY_GetTxPowerIndex_8812A(
-	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
-	IN	u8					Rate,	
-	IN	CHANNEL_WIDTH		BandWidth,	
-	IN	u8					Channel
-	);
-
-u32 PHY_GetTxBBSwing_8812A(
-	IN	PADAPTER	Adapter,
-	IN	BAND_TYPE 	Band,
-	IN	u8			RFPath
-	);
-
-VOID
-PHY_SetTxPowerIndex_8812A(
-	IN	PADAPTER			Adapter,
-	IN	u4Byte				PowerIndex,
-	IN	u1Byte				RFPath, 
-	IN	u1Byte				Rate
-	);
-
-//
-// Switch bandwidth for 8192S
-//
-VOID
-PHY_SetBWMode8812(
-	IN	PADAPTER			pAdapter,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					Offset
-);
-
-//
-// channel switch related funciton
-//
-VOID
-PHY_SwChnl8812(
-	IN	PADAPTER	Adapter,
-	IN	u8			channel
-);
-
-
-VOID
-PHY_SetSwChnlBWMode8812(
-	IN	PADAPTER			Adapter,
-	IN	u8					channel,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					Offset40,
-	IN	u8					Offset80
-);
-
-//
-// BB/MAC/RF other monitor API
-//
-
-VOID
-PHY_SetRFPathSwitch_8812A(
-	IN	PADAPTER	pAdapter,
-	IN	BOOLEAN		bMain
-);
-
-/*--------------------------Exported Function prototype---------------------*/
-#endif	// __INC_HAL8192CPHYCFG_H
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8812PHYCFG_H__
+#define __INC_HAL8812PHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/*------------------------------Define structure----------------------------*/
+
+
+/* BB/RF related */
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/*
+ * BB and RF register read/write
+ *   */
+u32	PHY_QueryBBReg8812(IN	PADAPTER	Adapter,
+			   IN	u32			RegAddr,
+			   IN	u32			BitMask);
+void	PHY_SetBBReg8812(IN	PADAPTER		Adapter,
+			 IN	u32			RegAddr,
+			 IN	u32			BitMask,
+			 IN	u32			Data);
+u32	PHY_QueryRFReg8812(IN	PADAPTER	Adapter,
+			   IN	enum rf_path	eRFPath,
+			   IN	u32			RegAddr,
+			   IN	u32			BitMask);
+void	PHY_SetRFReg8812(IN	PADAPTER		Adapter,
+			 IN	enum rf_path	eRFPath,
+			 IN	u32			RegAddr,
+			 IN	u32			BitMask,
+			 IN	u32			Data);
+
+/*
+ * Initialization related function
+ *
+ * MAC/BB/RF HAL config */
+int	PHY_MACConfig8812(IN PADAPTER	Adapter);
+int	PHY_BBConfig8812(IN PADAPTER	Adapter);
+void	PHY_BB8812_Config_1T(IN PADAPTER	Adapter);
+int	PHY_RFConfig8812(IN PADAPTER	Adapter);
+
+/* RF config */
+
+s32
+PHY_SwitchWirelessBand8812(
+	IN PADAPTER		Adapter,
+	IN u8			Band
+);
+
+/*
+ * BB TX Power R/W
+ *   */
+void	PHY_GetTxPowerLevel8812(IN PADAPTER	Adapter, OUT s32	*powerlevel);
+void	PHY_SetTxPowerLevel8812(IN PADAPTER	Adapter, IN u8	Channel);
+
+BOOLEAN	PHY_UpdateTxPowerDbm8812(IN PADAPTER	Adapter, IN int	powerInDbm);
+u8 PHY_GetTxPowerIndex_8812A(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+u32 phy_get_tx_bb_swing_8812a(
+	IN	PADAPTER	Adapter,
+	IN	BAND_TYPE	Band,
+	IN	enum rf_path	RFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8812A(
+	IN	PADAPTER		Adapter,
+	IN	u32				PowerIndex,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate
+);
+
+/*
+ * channel switch related funciton
+ *   */
+VOID
+PHY_SetSwChnlBWMode8812(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+/*
+ * BB/MAC/RF other monitor API
+ *   */
+
+VOID
+phy_set_rf_path_switch_8812a(
+	IN	struct dm_struct		*phydm,
+	IN	bool		bMain
+);
+
+/*--------------------------Exported Function prototype---------------------*/
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyReg.h
index 0fe2b5898722..e53bde42c283 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PhyReg.h
@@ -1,739 +1,736 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8812PHYREG_H__
-#define __INC_HAL8812PHYREG_H__
-/*--------------------------Define Parameters-------------------------------*/
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
-
-
-// BB Register Definition
-
-#define rCCAonSec_Jaguar		0x838
-#define rPwed_TH_Jaguar			0x830
-
-// BW and sideband setting
-#define rBWIndication_Jaguar		0x834
-#define rL1PeakTH_Jaguar			0x848
-#define rFPGA0_XA_LSSIReadBack	0x8a0	/*Tranceiver LSSI Readback*/
-#define rRFMOD_Jaguar			0x8ac	//RF mode 
-#define rADC_Buf_Clk_Jaguar		0x8c4
-#define rRFECTRL_Jaguar			0x900
-#define bRFMOD_Jaguar			0xc3
-#define rCCK_System_Jaguar		0xa00   // for cck sideband
-#define bCCK_System_Jaguar		0x10
-
-// Block & Path enable
-#define rOFDMCCKEN_Jaguar 		0x808 // OFDM/CCK block enable
-#define bOFDMEN_Jaguar			0x20000000
-#define bCCKEN_Jaguar			0x10000000
-#define rRxPath_Jaguar			0x808	// Rx antenna
-#define bRxPath_Jaguar			0xff
-#define rTxPath_Jaguar			0x80c	// Tx antenna
-#define bTxPath_Jaguar			0x0fffffff
-#define rCCK_RX_Jaguar			0xa04	// for cck rx path selection
-#define bCCK_RX_Jaguar			0x0c000000 
-#define rVhtlen_Use_Lsig_Jaguar	0x8c3	// Use LSIG for VHT length
-
-// RF read/write-related
-#define rHSSIRead_Jaguar			0x8b0  // RF read addr
-#define bHSSIRead_addr_Jaguar		0xff
-#define bHSSIRead_trigger_Jaguar	0x100
-#define rA_PIRead_Jaguar			0xd04 // RF readback with PI
-#define rB_PIRead_Jaguar			0xd44 // RF readback with PI
-#define rA_SIRead_Jaguar			0xd08 // RF readback with SI
-#define rB_SIRead_Jaguar			0xd48 // RF readback with SI
-#define rRead_data_Jaguar			0xfffff
-#define rA_LSSIWrite_Jaguar			0xc90 // RF write addr
-#define rB_LSSIWrite_Jaguar			0xe90 // RF write addr
-#define bLSSIWrite_data_Jaguar		0x000fffff
-#define bLSSIWrite_addr_Jaguar		0x0ff00000
-
-
-
-// YN: mask the following register definition temporarily 
-#define rFPGA0_XA_RFInterfaceOE			0x860	// RF Channel switch
-#define rFPGA0_XB_RFInterfaceOE			0x864
-
-#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
-//#define rFPGA0_AdDaClockEn			0x888	// enable ad/da clock1 for dual-phy
-//#define rFPGA0_AnalogParameter4		0x88c
-
-
-// CCK TX scaling
-#define rCCK_TxFilter1_Jaguar		0xa20
-#define bCCK_TxFilter1_C0_Jaguar   	0x00ff0000
-#define bCCK_TxFilter1_C1_Jaguar		0xff000000
-#define rCCK_TxFilter2_Jaguar		0xa24
-#define bCCK_TxFilter2_C2_Jaguar		0x000000ff
-#define bCCK_TxFilter2_C3_Jaguar		0x0000ff00
-#define bCCK_TxFilter2_C4_Jaguar		0x00ff0000
-#define bCCK_TxFilter2_C5_Jaguar		0xff000000
-#define rCCK_TxFilter3_Jaguar		0xa28
-#define bCCK_TxFilter3_C6_Jaguar		0x000000ff
-#define bCCK_TxFilter3_C7_Jaguar		0x0000ff00
-
-
-// YN: mask the following register definition temporarily
-//#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
-
-// RXIQC
-#define rA_RxIQC_AB_Jaguar    	0xc10  //RxIQ imblance matrix coeff. A & B
-#define rA_RxIQC_CD_Jaguar    	0xc14  //RxIQ imblance matrix coeff. C & D
-#define rA_TxScale_Jaguar 		0xc1c  // Pah_A TX scaling factor
-#define rB_TxScale_Jaguar 		0xe1c  // Path_B TX scaling factor
-#define rB_RxIQC_AB_Jaguar    	0xe10  //RxIQ imblance matrix coeff. A & B
-#define rB_RxIQC_CD_Jaguar    	0xe14  //RxIQ imblance matrix coeff. C & D
-#define b_RxIQC_AC_Jaguar		0x02ff  // bit mask for IQC matrix element A & C
-#define b_RxIQC_BD_Jaguar		0x02ff0000 // bit mask for IQC matrix element A & C
-
-
-// DIG-related
-#define rA_IGI_Jaguar				0xc50	// Initial Gain for path-A
-#define rB_IGI_Jaguar				0xe50	// Initial Gain for path-B
-#define rOFDM_FalseAlarm1_Jaguar	0xf48  // counter for break
-#define rOFDM_FalseAlarm2_Jaguar	0xf4c  // counter for spoofing
-#define rCCK_FalseAlarm_Jaguar        	0xa5c // counter for cck false alarm
-#define b_FalseAlarm_Jaguar			0xffff
-#define rCCK_CCA_Jaguar				0xa08	// cca threshold
-#define bCCK_CCA_Jaguar				0x00ff0000
-
-// Tx Power Ttraining-related
-#define rA_TxPwrTraing_Jaguar		0xc54
-#define rB_TxPwrTraing_Jaguar		0xe54
-
-// Report-related
-#define rOFDM_ShortCFOAB_Jaguar	0xf60  
-#define rOFDM_LongCFOAB_Jaguar		0xf64
-#define rOFDM_EndCFOAB_Jaguar		0xf70
-#define rOFDM_AGCReport_Jaguar		0xf84
-#define rOFDM_RxSNR_Jaguar			0xf88
-#define rOFDM_RxEVMCSI_Jaguar		0xf8c
-#define rOFDM_SIGReport_Jaguar		0xf90
-
-// Misc functions
-#define rEDCCA_Jaguar				0x8a4 // EDCCA
-#define bEDCCA_Jaguar				0xffff
-#define rAGC_table_Jaguar			0x82c   // AGC tabel select
-#define bAGC_table_Jaguar			0x3
-#define b_sel5g_Jaguar    				0x1000 // sel5g
-#define b_LNA_sw_Jaguar				0x8000 // HW/WS control for LNA
-#define rFc_area_Jaguar				0x860   // fc_area 
-#define bFc_area_Jaguar				0x1ffe000
-#define rSingleTone_ContTx_Jaguar	0x914
-
-// RFE
-#define rA_RFE_Pinmux_Jaguar	0xcb0  // Path_A RFE cotrol pinmux
-#define rB_RFE_Pinmux_Jaguar	0xeb0 // Path_B RFE control pinmux
-#define rA_RFE_Inv_Jaguar		0xcb4  // Path_A RFE cotrol   
-#define rB_RFE_Inv_Jaguar		0xeb4 // Path_B RFE control
-#define rA_RFE_Jaguar			0xcb8  // Path_A RFE cotrol   
-#define rB_RFE_Jaguar			0xeb8 // Path_B RFE control
-#define r_ANTSEL_SW_Jaguar		0x900 // ANTSEL SW Control
-#define bMask_RFEInv_Jaguar		0x3ff00000
-#define bMask_AntselPathFollow_Jaguar 0x00030000
-
-// TX AGC 
-#define rTxAGC_A_CCK11_CCK1_JAguar				0xc20
-#define rTxAGC_A_Ofdm18_Ofdm6_JAguar				0xc24
-#define rTxAGC_A_Ofdm54_Ofdm24_JAguar			0xc28
-#define rTxAGC_A_MCS3_MCS0_JAguar					0xc2c
-#define rTxAGC_A_MCS7_MCS4_JAguar					0xc30
-#define rTxAGC_A_MCS11_MCS8_JAguar				0xc34
-#define rTxAGC_A_MCS15_MCS12_JAguar				0xc38
-#define rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	0xc3c
-#define rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	0xc40
-#define rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	0xc44
-#define rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	0xc48
-#define rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	0xc4c
-#define rTxAGC_B_CCK11_CCK1_JAguar				0xe20
-#define rTxAGC_B_Ofdm18_Ofdm6_JAguar				0xe24
-#define rTxAGC_B_Ofdm54_Ofdm24_JAguar			0xe28
-#define rTxAGC_B_MCS3_MCS0_JAguar					0xe2c
-#define rTxAGC_B_MCS7_MCS4_JAguar					0xe30
-#define rTxAGC_B_MCS11_MCS8_JAguar				0xe34
-#define rTxAGC_B_MCS15_MCS12_JAguar				0xe38
-#define rTxAGC_B_Nss1Index3_Nss1Index0_JAguar		0xe3c
-#define rTxAGC_B_Nss1Index7_Nss1Index4_JAguar		0xe40
-#define rTxAGC_B_Nss2Index1_Nss1Index8_JAguar		0xe44
-#define rTxAGC_B_Nss2Index5_Nss2Index2_JAguar		0xe48
-#define rTxAGC_B_Nss2Index9_Nss2Index6_JAguar		0xe4c
-#define bTxAGC_byte0_Jaguar							0xff
-#define bTxAGC_byte1_Jaguar							0xff00
-#define bTxAGC_byte2_Jaguar							0xff0000
-#define bTxAGC_byte3_Jaguar							0xff000000
-
-// IQK YN: temporaily mask this part
-//#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
-
-
-// AFE-related
-#define rA_AFEPwr1_Jaguar					0xc60 // dynamic AFE power control
-#define rA_AFEPwr2_Jaguar					0xc64 // dynamic AFE power control
-#define rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xc68
-#define rA_Tx_CCKBBON_OFDMRFON_Jaguar	0xc6c
-#define rA_Tx_OFDMBBON_Tx2Rx_Jaguar		0xc70
-#define rA_Tx2Tx_RXCCK_Jaguar				0xc74
-#define rA_Rx_OFDM_WaitRIFS_Jaguar			0xc78
-#define rA_Rx2Rx_BT_Jaguar					0xc7c
-#define rA_sleep_nav_Jaguar 					0xc80
-#define rA_pmpd_Jaguar 						0xc84
-#define rB_AFEPwr1_Jaguar					0xe60 // dynamic AFE power control
-#define rB_AFEPwr2_Jaguar					0xe64 // dynamic AFE power control
-#define rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xe68
-#define rB_Tx_CCKBBON_OFDMRFON_Jaguar	0xe6c
-#define rB_Tx_OFDMBBON_Tx2Rx_Jaguar		0xe70
-#define rB_Tx2Tx_RXCCK_Jaguar				0xe74
-#define rB_Rx_OFDM_WaitRIFS_Jaguar			0xe78
-#define rB_Rx2Rx_BT_Jaguar					0xe7c
-#define rB_sleep_nav_Jaguar 					0xe80
-#define rB_pmpd_Jaguar 						0xe84
-
-
-// YN: mask these registers temporaily
-//#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
-
-
-// RSSI Dump
-#define rA_RSSIDump_Jaguar 			0xBF0
-#define rB_RSSIDump_Jaguar 			0xBF1
-#define rS1_RXevmDump_Jaguar		0xBF4 
-#define rS2_RXevmDump_Jaguar 		0xBF5
-#define rA_RXsnrDump_Jaguar		0xBF6
-#define rB_RXsnrDump_Jaguar		0xBF7
-#define rA_CfoShortDump_Jaguar		0xBF8 
-#define rB_CfoShortDump_Jaguar		0xBFA
-#define rA_CfoLongDump_Jaguar		0xBEC
-#define rB_CfoLongDump_Jaguar		0xBEE
- 
-
-// RF Register
-//
-#define RF_AC_Jaguar				0x00	// 
-#define RF_RF_Top_Jaguar			0x07	// 
-#define RF_TXLOK_Jaguar				0x08	// 
-#define RF_TXAPK_Jaguar				0x0B
-#define RF_CHNLBW_Jaguar 			0x18	// RF channel and BW switch
-#define RF_RCK1_Jaguar				0x1c	// 
-#define RF_RCK2_Jaguar				0x1d
-#define RF_RCK3_Jaguar   			0x1e
-#define RF_ModeTableAddr			0x30
-#define RF_ModeTableData0			0x31
-#define RF_ModeTableData1			0x32
-#define RF_TxLCTank_Jaguar          	0x54
-#define RF_APK_Jaguar				0x63
-#define RF_LCK						0xB4
-#define RF_WeLut_Jaguar				0xEF
-
-#define bRF_CHNLBW_MOD_AG_Jaguar	0x70300
-#define bRF_CHNLBW_BW 				0xc00
-
-
-//
-// RL6052 Register definition
-//
-#define RF_AC						0x00	// 
-#define RF_IPA_A					0x0C	// 
-#define RF_TXBIAS_A					0x0D
-#define RF_BS_PA_APSET_G9_G11		0x0E
-#define RF_MODE1					0x10	// 
-#define RF_MODE2					0x11	// 
-#define RF_CHNLBW					0x18	// RF channel and BW switch
-#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
-#define RF_0x52 						0x52
-#define RF_WE_LUT					0xEF
-
-#define RF_TX_GAIN_OFFSET_8812A(_val) ((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
-#define RF_TX_GAIN_OFFSET_8821A(_val) ((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
-
-//
-//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
-
-
-//
-// 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
-
-//
-// 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_XA_HSSIParameter1	0x820	// RF 3 wire register
-#define rFPGA0_XA_HSSIParameter2	0x824
-#define rFPGA0_XB_HSSIParameter1	0x828
-#define rFPGA0_XB_HSSIParameter2	0x82c
-
-#define rFPGA0_XAB_SwitchControl	0x858	// RF Channel switch
-#define rFPGA0_XCD_SwitchControl	0x85c
-
-#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
-#define rFPGA0_AdDaClockEn			0x888	// enable ad/da clock1 for dual-phy
-#define rFPGA0_AnalogParameter4	0x88c
-#define rFPGA0_XB_LSSIReadBack		0x8a4
-#define rFPGA0_XCD_RFPara	0x8b4
-
-//
-// 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??
-
-//
-// PageA(0xA00)
-//
-#define rCCK0_System				0xa00
-#define rCCK0_AFESetting				0xa04	// Disable init gain now // Select RX path by RSSI
-#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
-
-//
-// 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
-
-//
-// 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 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 rTxAGC_B_Mcs15_Mcs12		0x868
-#define rTxAGC_B_CCK11_A_CCK2_11	0x86c
-
-#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
-
-
-// 2. Page8(0x800)
-#define bRFMOD						0x1	// Reg 0x800 rFPGA0_RFMOD
-#define bJapanMode					0x2
-#define bCCKTxSC					0x30
-#define bCCKEn						0x1000000
-#define bOFDMEn						0x2000000
-#define bXBTxAGC                  			0xf00	// Reg 80c rFPGA0_TxGainStage
-#define bXCTxAGC                  			0xf000
-#define bXDTxAGC                  			0xf0000
-
-// 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
-
-// 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
-
-
-//
-// Other Definition
-//
-
-#define bEnable                   0x1	// Useless
-#define bDisable                  0x0
-
-//byte endable for srwrite
-#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 bMaskH3Bytes				0xffffff00
-#define bMask12Bits				0xfff	
-#define bMaskH4Bits				0xf0000000	
-#define bMaskOFDM_D			0xffc00000
-#define bMaskCCK				0x3f3f3f3f
-
-
-/*--------------------------Define Parameters-------------------------------*/
-
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8812PHYREG_H__
+#define __INC_HAL8812PHYREG_H__
+/*--------------------------Define Parameters-------------------------------*/
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/* BB Register Definition */
+
+#define rCCAonSec_Jaguar		0x838
+#define rPwed_TH_Jaguar			0x830
+
+/* BW and sideband setting */
+#define rBWIndication_Jaguar		0x834
+#define rL1PeakTH_Jaguar			0x848
+#define rFPGA0_XA_LSSIReadBack	0x8a0	/*Tranceiver LSSI Readback*/
+#define rRFMOD_Jaguar			0x8ac	/* RF mode */
+#define rADC_Buf_Clk_Jaguar		0x8c4
+#define rRFECTRL_Jaguar			0x900
+#define bRFMOD_Jaguar			0xc3
+#define rCCK_System_Jaguar		0xa00   /* for cck sideband */
+#define bCCK_System_Jaguar		0x10
+
+/* Block & Path enable */
+#define rOFDMCCKEN_Jaguar 		0x808 /* OFDM/CCK block enable */
+#define bOFDMEN_Jaguar			0x20000000
+#define bCCKEN_Jaguar			0x10000000
+#define rRxPath_Jaguar			0x808	/* Rx antenna */
+#define bRxPath_Jaguar			0xff
+#define rTxPath_Jaguar			0x80c	/* Tx antenna */
+#define bTxPath_Jaguar			0x0fffffff
+#define rCCK_RX_Jaguar			0xa04	/* for cck rx path selection */
+#define bCCK_RX_Jaguar			0x0c000000
+#define rVhtlen_Use_Lsig_Jaguar	0x8c3	/* Use LSIG for VHT length */
+
+/* RF read/write-related */
+#define rHSSIRead_Jaguar			0x8b0  /* RF read addr */
+#define bHSSIRead_addr_Jaguar		0xff
+#define bHSSIRead_trigger_Jaguar	0x100
+#define rA_PIRead_Jaguar			0xd04 /* RF readback with PI */
+#define rB_PIRead_Jaguar			0xd44 /* RF readback with PI */
+#define rA_SIRead_Jaguar			0xd08 /* RF readback with SI */
+#define rB_SIRead_Jaguar			0xd48 /* RF readback with SI */
+#define rRead_data_Jaguar			0xfffff
+#define rA_LSSIWrite_Jaguar			0xc90 /* RF write addr */
+#define rB_LSSIWrite_Jaguar			0xe90 /* RF write addr */
+#define bLSSIWrite_data_Jaguar		0x000fffff
+#define bLSSIWrite_addr_Jaguar		0x0ff00000
+
+
+
+/* YN: mask the following register definition temporarily */
+#define rFPGA0_XA_RFInterfaceOE			0x860	/* RF Channel switch */
+#define rFPGA0_XB_RFInterfaceOE			0x864
+
+#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
+ * #define rFPGA0_AdDaClockEn			0x888 */	/* enable ad/da clock1 for dual-phy
+ * #define rFPGA0_AnalogParameter4		0x88c */
+
+
+/* CCK TX scaling */
+#define rCCK_TxFilter1_Jaguar		0xa20
+#define bCCK_TxFilter1_C0_Jaguar	0x00ff0000
+#define bCCK_TxFilter1_C1_Jaguar		0xff000000
+#define rCCK_TxFilter2_Jaguar		0xa24
+#define bCCK_TxFilter2_C2_Jaguar		0x000000ff
+#define bCCK_TxFilter2_C3_Jaguar		0x0000ff00
+#define bCCK_TxFilter2_C4_Jaguar		0x00ff0000
+#define bCCK_TxFilter2_C5_Jaguar		0xff000000
+#define rCCK_TxFilter3_Jaguar		0xa28
+#define bCCK_TxFilter3_C6_Jaguar		0x000000ff
+#define bCCK_TxFilter3_C7_Jaguar		0x0000ff00
+
+
+/* YN: mask the following register definition temporarily
+ * #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 */
+
+/* RXIQC */
+#define rA_RxIQC_AB_Jaguar    	0xc10  /* RxIQ imblance matrix coeff. A & B */
+#define rA_RxIQC_CD_Jaguar    	0xc14  /* RxIQ imblance matrix coeff. C & D */
+#define rA_TxScale_Jaguar 		0xc1c  /* Pah_A TX scaling factor */
+#define rB_TxScale_Jaguar 		0xe1c  /* Path_B TX scaling factor */
+#define rB_RxIQC_AB_Jaguar    	0xe10  /* RxIQ imblance matrix coeff. A & B */
+#define rB_RxIQC_CD_Jaguar    	0xe14  /* RxIQ imblance matrix coeff. C & D */
+#define b_RxIQC_AC_Jaguar		0x02ff  /* bit mask for IQC matrix element A & C */
+#define b_RxIQC_BD_Jaguar		0x02ff0000 /* bit mask for IQC matrix element A & C */
+
+
+/* DIG-related */
+#define rA_IGI_Jaguar				0xc50	/* Initial Gain for path-A */
+#define rB_IGI_Jaguar				0xe50	/* Initial Gain for path-B */
+#define rOFDM_FalseAlarm1_Jaguar	0xf48  /* counter for break */
+#define rOFDM_FalseAlarm2_Jaguar	0xf4c  /* counter for spoofing */
+#define rCCK_FalseAlarm_Jaguar        	0xa5c /* counter for cck false alarm */
+#define b_FalseAlarm_Jaguar			0xffff
+#define rCCK_CCA_Jaguar				0xa08	/* cca threshold */
+#define bCCK_CCA_Jaguar				0x00ff0000
+
+/* Tx Power Ttraining-related */
+#define rA_TxPwrTraing_Jaguar		0xc54
+#define rB_TxPwrTraing_Jaguar		0xe54
+
+/* Report-related */
+#define rOFDM_ShortCFOAB_Jaguar	0xf60
+#define rOFDM_LongCFOAB_Jaguar		0xf64
+#define rOFDM_EndCFOAB_Jaguar		0xf70
+#define rOFDM_AGCReport_Jaguar		0xf84
+#define rOFDM_RxSNR_Jaguar			0xf88
+#define rOFDM_RxEVMCSI_Jaguar		0xf8c
+#define rOFDM_SIGReport_Jaguar		0xf90
+
+/* Misc functions */
+#define rEDCCA_Jaguar				0x8a4 /* EDCCA */
+#define bEDCCA_Jaguar				0xffff
+#define rAGC_table_Jaguar			0x82c   /* AGC tabel select */
+#define bAGC_table_Jaguar			0x3
+#define b_sel5g_Jaguar    				0x1000 /* sel5g */
+#define b_LNA_sw_Jaguar				0x8000 /* HW/WS control for LNA */
+#define rFc_area_Jaguar				0x860   /* fc_area */
+#define bFc_area_Jaguar				0x1ffe000
+#define rSingleTone_ContTx_Jaguar	0x914
+
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xcb0  /* Path_A RFE cotrol pinmux */
+#define rB_RFE_Pinmux_Jaguar	0xeb0 /* Path_B RFE control pinmux */
+#define rA_RFE_Inv_Jaguar		0xcb4  /* Path_A RFE cotrol   */
+#define rB_RFE_Inv_Jaguar		0xeb4 /* Path_B RFE control */
+#define rA_RFE_Jaguar			0xcb8  /* Path_A RFE cotrol   */
+#define rB_RFE_Jaguar			0xeb8 /* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define r_ANTSEL_SW_Jaguar		0x900 /* ANTSEL SW Control */
+#define bMask_RFEInv_Jaguar		0x3ff00000
+#define bMask_AntselPathFollow_Jaguar 0x00030000
+
+/* TX AGC */
+#define rTxAGC_A_CCK11_CCK1_JAguar				0xc20
+#define rTxAGC_A_Ofdm18_Ofdm6_JAguar				0xc24
+#define rTxAGC_A_Ofdm54_Ofdm24_JAguar			0xc28
+#define rTxAGC_A_MCS3_MCS0_JAguar					0xc2c
+#define rTxAGC_A_MCS7_MCS4_JAguar					0xc30
+#define rTxAGC_A_MCS11_MCS8_JAguar				0xc34
+#define rTxAGC_A_MCS15_MCS12_JAguar				0xc38
+#define rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	0xc3c
+#define rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	0xc40
+#define rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	0xc44
+#define rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	0xc48
+#define rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	0xc4c
+#define rTxAGC_B_CCK11_CCK1_JAguar				0xe20
+#define rTxAGC_B_Ofdm18_Ofdm6_JAguar				0xe24
+#define rTxAGC_B_Ofdm54_Ofdm24_JAguar			0xe28
+#define rTxAGC_B_MCS3_MCS0_JAguar					0xe2c
+#define rTxAGC_B_MCS7_MCS4_JAguar					0xe30
+#define rTxAGC_B_MCS11_MCS8_JAguar				0xe34
+#define rTxAGC_B_MCS15_MCS12_JAguar				0xe38
+#define rTxAGC_B_Nss1Index3_Nss1Index0_JAguar		0xe3c
+#define rTxAGC_B_Nss1Index7_Nss1Index4_JAguar		0xe40
+#define rTxAGC_B_Nss2Index1_Nss1Index8_JAguar		0xe44
+#define rTxAGC_B_Nss2Index5_Nss2Index2_JAguar		0xe48
+#define rTxAGC_B_Nss2Index9_Nss2Index6_JAguar		0xe4c
+#define bTxAGC_byte0_Jaguar							0xff
+#define bTxAGC_byte1_Jaguar							0xff00
+#define bTxAGC_byte2_Jaguar							0xff0000
+#define bTxAGC_byte3_Jaguar							0xff000000
+
+/* IQK YN: temporaily mask this part
+ * #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 */
+
+
+/* AFE-related */
+#define rA_AFEPwr1_Jaguar					0xc60 /* dynamic AFE power control */
+#define rA_AFEPwr2_Jaguar					0xc64 /* dynamic AFE power control */
+#define rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xc68
+#define rA_Tx_CCKBBON_OFDMRFON_Jaguar	0xc6c
+#define rA_Tx_OFDMBBON_Tx2Rx_Jaguar		0xc70
+#define rA_Tx2Tx_RXCCK_Jaguar				0xc74
+#define rA_Rx_OFDM_WaitRIFS_Jaguar			0xc78
+#define rA_Rx2Rx_BT_Jaguar					0xc7c
+#define rA_sleep_nav_Jaguar					0xc80
+#define rA_pmpd_Jaguar						0xc84
+#define rB_AFEPwr1_Jaguar					0xe60 /* dynamic AFE power control */
+#define rB_AFEPwr2_Jaguar					0xe64 /* dynamic AFE power control */
+#define rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xe68
+#define rB_Tx_CCKBBON_OFDMRFON_Jaguar	0xe6c
+#define rB_Tx_OFDMBBON_Tx2Rx_Jaguar		0xe70
+#define rB_Tx2Tx_RXCCK_Jaguar				0xe74
+#define rB_Rx_OFDM_WaitRIFS_Jaguar			0xe78
+#define rB_Rx2Rx_BT_Jaguar					0xe7c
+#define rB_sleep_nav_Jaguar					0xe80
+#define rB_pmpd_Jaguar						0xe84
+
+
+/* YN: mask these registers temporaily
+ * #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 */
+
+
+/* RSSI Dump */
+#define rA_RSSIDump_Jaguar			0xBF0
+#define rB_RSSIDump_Jaguar			0xBF1
+#define rS1_RXevmDump_Jaguar		0xBF4
+#define rS2_RXevmDump_Jaguar		0xBF5
+#define rA_RXsnrDump_Jaguar		0xBF6
+#define rB_RXsnrDump_Jaguar		0xBF7
+#define rA_CfoShortDump_Jaguar		0xBF8
+#define rB_CfoShortDump_Jaguar		0xBFA
+#define rA_CfoLongDump_Jaguar		0xBEC
+#define rB_CfoLongDump_Jaguar		0xBEE
+
+
+/* RF Register
+ *   */
+#define RF_AC_Jaguar				0x00	/*  */
+#define RF_RF_Top_Jaguar			0x07	/*  */
+#define RF_TXLOK_Jaguar				0x08	/*  */
+#define RF_TXAPK_Jaguar				0x0B
+#define RF_CHNLBW_Jaguar 			0x18	/* RF channel and BW switch */
+#define RF_RCK1_Jaguar				0x1c	/*  */
+#define RF_RCK2_Jaguar				0x1d
+#define RF_RCK3_Jaguar			0x1e
+#define RF_ModeTableAddr			0x30
+#define RF_ModeTableData0			0x31
+#define RF_ModeTableData1			0x32
+#define RF_TxLCTank_Jaguar	0x54
+#define RF_APK_Jaguar				0x63
+#define RF_LCK						0xB4
+#define RF_WeLut_Jaguar				0xEF
+
+#define bRF_CHNLBW_MOD_AG_Jaguar	0x70300
+#define bRF_CHNLBW_BW				0xc00
+
+
+/*
+ * RL6052 Register definition
+ *   */
+#define RF_AC						0x00	/*  */
+#define RF_IPA_A					0x0C	/*  */
+#define RF_TXBIAS_A					0x0D
+#define RF_BS_PA_APSET_G9_G11		0x0E
+#define RF_MODE1					0x10	/*  */
+#define RF_MODE2					0x11	/*  */
+#define RF_CHNLBW					0x18	/* RF channel and BW switch */
+#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 */
+#define RF_0x52						0x52
+#define RF_WE_LUT					0xEF
+
+#define RF_TX_GAIN_OFFSET_8812A(_val) ((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
+#define RF_TX_GAIN_OFFSET_8821A(_val) ((abs((_val)) << 1) | (((_val) > 0) ? BIT0 : 0))
+
+/*
+ * 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
+
+
+/*
+ * 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
+
+/*
+ * 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_XA_HSSIParameter1	0x820	/* RF 3 wire register */
+#define rFPGA0_XA_HSSIParameter2	0x824
+#define rFPGA0_XB_HSSIParameter1	0x828
+#define rFPGA0_XB_HSSIParameter2	0x82c
+
+#define rFPGA0_XAB_SwitchControl	0x858	/* RF Channel switch */
+#define rFPGA0_XCD_SwitchControl	0x85c
+
+#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
+#define rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#define rFPGA0_AnalogParameter4	0x88c
+#define rFPGA0_XB_LSSIReadBack		0x8a4
+#define rFPGA0_XCD_RFPara	0x8b4
+
+/*
+ * 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?? */
+
+/*
+ * PageA(0xA00)
+ *   */
+#define rCCK0_System				0xa00
+#define rCCK0_AFESetting				0xa04	/* Disable init gain now */ /* Select RX path by RSSI */
+#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 */
+
+/*
+ * 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
+
+/*
+ * 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 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 rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86c
+
+#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
+
+
+/* 2. Page8(0x800) */
+#define bRFMOD						0x1	/* Reg 0x800 rFPGA0_RFMOD */
+#define bJapanMode					0x2
+#define bCCKTxSC					0x30
+#define bCCKEn						0x1000000
+#define bOFDMEn						0x2000000
+#define bXBTxAGC                  			0xf00	/* Reg 80c rFPGA0_TxGainStage */
+#define bXCTxAGC			0xf000
+#define bXDTxAGC			0xf0000
+
+/* 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
+
+/* 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
+
+
+/*
+ * Other Definition
+ *   */
+
+#define bEnable                   0x1	/* Useless */
+#define bDisable                  0x0
+
+/* byte endable for srwrite */
+#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 bMaskH3Bytes				0xffffff00
+#define bMask12Bits				0xfff
+#define bMaskH4Bits				0xf0000000
+#define bMaskOFDM_D			0xffc00000
+#define bMaskCCK				0x3f3f3f3f
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PwrSeq.h
index 5d6a7ad22b6f..28758abc8690 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8812PwrSeq.h
@@ -1,210 +1,209 @@
-
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef __HAL8812PWRSEQ_H__
-#define __HAL8812PWRSEQ_H__
-
-#include "HalPwrSeqCmd.h"
-
-/* 
-	Check document WB-110628-DZ-RTL8195 (Jaguar) Power Architecture-R04.pdf
-	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
-*/
-#define	RTL8812_TRANS_CARDEMU_TO_ACT_STEPS	15
-#define	RTL8812_TRANS_ACT_TO_CARDEMU_STEPS	15
-#define	RTL8812_TRANS_CARDEMU_TO_SUS_STEPS	15
-#define	RTL8812_TRANS_SUS_TO_CARDEMU_STEPS	15
-#define	RTL8812_TRANS_CARDEMU_TO_PDN_STEPS	15
-#define	RTL8812_TRANS_PDN_TO_CARDEMU_STEPS	15
-#define	RTL8812_TRANS_ACT_TO_LPS_STEPS	15
-#define	RTL8812_TRANS_LPS_TO_ACT_STEPS	15	
-#define	RTL8812_TRANS_END_STEPS	1
-
-
-#define RTL8812_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
-	/*{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 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, BIT3, 0},/* disable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/
-
-#define RTL8812_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
-	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
-	{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_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
-	/*{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, BIT7, 0},//0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x2A}, /* 0x07[7:0] = 0x28 sps pwm mode 0x2a for BT coex*/	\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk =500k */	\
-	/*{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0|BIT1, 0}, //  0x02[1:0] = 0	reset BB */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	
-
-#define RTL8812_TRANS_CARDEMU_TO_SUS													\
-	/* format */								\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xF0, 0xcc},\
-	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xF0, 0xEC},\
-	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
-	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
-	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/* suspend option all off */	\
-	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x80, BIT7},/*0x14[7] = 1 turn on ZCD */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x01, BIT0},/* 0x15[0] =1 trun on ZCD */	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x10, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk =500k */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 2b'11 enable WL suspend for PCIe*/	
-
-#define RTL8812_TRANS_SUS_TO_CARDEMU													\
-	/* format */								\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 2b'01enable WL suspend*/   \
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO sleep mode leave */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x01, 0},/* 0x15[0] =0 trun off ZCD */	\
-	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x80, 0},/*0x14[7] = 0 turn off ZCD */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
-	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */
-
-#define RTL8812_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	/**{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, //0x194[0]=0 , disable 32K clock*/	\
-	/**{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x94}, //0x93=0x94 , 90[30] =0 enable 500k ANA clock .switch clock from 12M to 500K , 90 [26] =0 disable EEprom loader clock*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0}, /*0x03[2] = 0, reset 8051*/	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x05}, /*0x80=05h if reload fw, fill the default value of host_CPU handshake field*/	\
-	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xF0, 0xcc},\
-	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xF0, 0xEC},\
-	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
-	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
-	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
-	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x80, BIT7},/*0x14[7] = 1 turn on ZCD */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x01, BIT0},/* 0x15[0] =1 trun on ZCD */	\
-	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x01, 0},/*0x12[0] = 0 force PFM mode */	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x10, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk =500k */	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
-	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /*0x01f[1]=0 , disable RFC_0  control  REG_RF_CTRL_8812 */	\
-	{0x0076, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /*0x076[1]=0 , disable RFC_1  control REG_OPT_CTRL_8812 +2 */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 2b'01 enable WL suspend*/	
-
-#define RTL8812_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/                       \
-	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*0x12[0] = 1 force PWM mode */	\
-	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x80, 0},/*0x14[7] = 0 turn off ZCD */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x01, 0},/* 0x15[0] =0 trun off ZCD */	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO leave sleep mode */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
-	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */ \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0}, /*0x04[10] = 0, enable SW LPS PCIE only*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 2b'01enable WL suspend*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*0x03[2] = 1, enable 8051*/	\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
-
-
-#define RTL8812_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8812_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-#define RTL8812_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
-	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x7F},/*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*/	\
-	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
-	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
-	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled,and clock are gated,and RF closed*/	\
-	{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_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 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, BIT1, 0},/*check if removed later*/		\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	
-
-
-#define RTL8812_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/	\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/	\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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 RTL8812_TRANS_END																\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/		\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8812_power_on_flow[RTL8812_TRANS_CARDEMU_TO_ACT_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_radio_off_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_card_disable_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS+RTL8812_TRANS_CARDEMU_TO_PDN_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_card_enable_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS+RTL8812_TRANS_CARDEMU_TO_PDN_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_suspend_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS+RTL8812_TRANS_CARDEMU_TO_SUS_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_resume_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS+RTL8812_TRANS_CARDEMU_TO_SUS_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_hwpdn_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS+RTL8812_TRANS_CARDEMU_TO_PDN_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_enter_lps_flow[RTL8812_TRANS_ACT_TO_LPS_STEPS+RTL8812_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8812_leave_lps_flow[RTL8812_TRANS_LPS_TO_ACT_STEPS+RTL8812_TRANS_END_STEPS];
-
-#endif //__HAL8812PWRSEQ_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HAL8812PWRSEQ_H__
+#define __HAL8812PWRSEQ_H__
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WB-110628-DZ-RTL8195 (Jaguar) Power Architecture-R04.pdf
+	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
+*/
+#define	RTL8812_TRANS_CARDEMU_TO_ACT_STEPS	15
+#define	RTL8812_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8812_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8812_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8812_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8812_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8812_TRANS_ACT_TO_LPS_STEPS	15
+#define	RTL8812_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8812_TRANS_END_STEPS	1
+
+
+#define RTL8812_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	/*{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, BIT3, 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/   \
+	{0x0024, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /* 0x24[1] Choose the type of buffer after xosc: nand*/   \
+	{0x0028, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, 0}, /* 0x28[33] Choose the type of buffer after xosc: nand*/
+
+#define RTL8812_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
+	{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_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	/*{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, BIT7, 0},//0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x2A}, /* 0x07[7:0] = 0x28 sps pwm mode 0x2a for BT coex*/	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	/*{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 | BIT1, 0}, //  0x02[1:0] = 0	reset BB */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/
+
+#define RTL8812_TRANS_CARDEMU_TO_SUS													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xcc},\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xEC},\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* suspend option all off */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, BIT7},/*0x14[7] = 1 turn on ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, BIT0},/* 0x15[0] =1 trun on ZCD */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 2b'11 enable WL suspend for PCIe*/
+
+#define RTL8812_TRANS_SUS_TO_CARDEMU													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 2b'01enable WL suspend*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO sleep mode leave */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, 0},/* 0x15[0] =0 trun off ZCD */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, 0},/*0x14[7] = 0 turn off ZCD */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */
+
+#define RTL8812_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	/**{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, //0x194[0]=0 , disable 32K clock*/	\
+	/**{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x94}, //0x93 = 0x94 , 90[30] =0 enable 500k ANA clock .switch clock from 12M to 500K , 90 [26] =0 disable EEprom loader clock*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x03[2] = 0, reset 8051*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x05}, /*0x80 = 05h if reload fw, fill the default value of host_CPU handshake field*/	\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xcc},\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xEC},\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, BIT7},/*0x14[7] = 1 turn on ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, BIT0},/* 0x15[0] =1 trun on ZCD */	\
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, 0},/*0x12[0] = 0 force PFM mode */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /*0x01f[1]=0 , disable RFC_0  control  REG_RF_CTRL_8812 */	\
+	{0x0076, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /*0x076[1]=0 , disable RFC_1  control REG_OPT_CTRL_8812 +2 */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 2b'01 enable WL suspend*/
+
+#define RTL8812_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/                       \
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*0x12[0] = 1 force PWM mode */	\
+	{0x0014, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x80, 0},/*0x14[7] = 0 turn off ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x01, 0},/* 0x15[0] =0 trun off ZCD */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO leave sleep mode */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x04[10] = 0, enable SW LPS PCIE only*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 2b'01enable WL suspend*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x03[2] = 1, enable 8051*/	\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/  \
+	{0x0024, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /* 0x24[1] Choose the type of buffer after xosc: schmitt trigger*/ \
+	{0x0028, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /* 0x28[33] Choose the type of buffer after xosc: schmitt trigger*/
+
+
+#define RTL8812_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8812_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8812_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x7F},/*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*/	\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated, and RF closed*/	\
+	{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_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 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, BIT1, 0},/*check if removed later*/		\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/
+
+
+#define RTL8812_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/	\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/	\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8812_TRANS_END																\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/		\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+extern WLAN_PWR_CFG rtl8812_power_on_flow[RTL8812_TRANS_CARDEMU_TO_ACT_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_radio_off_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_card_disable_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_PDN_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_card_enable_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_PDN_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_suspend_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_SUS_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_resume_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_SUS_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_hwpdn_flow[RTL8812_TRANS_ACT_TO_CARDEMU_STEPS + RTL8812_TRANS_CARDEMU_TO_PDN_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_enter_lps_flow[RTL8812_TRANS_ACT_TO_LPS_STEPS + RTL8812_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8812_leave_lps_flow[RTL8812_TRANS_LPS_TO_ACT_STEPS + RTL8812_TRANS_END_STEPS];
+
+#endif /* __HAL8812PWRSEQ_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyCfg.h
index d6be7976cf7e..2d9a00794f61 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyCfg.h
@@ -1,282 +1,265 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8814PHYCFG_H__
-#define __INC_HAL8814PHYCFG_H__
-
-
-/*--------------------------Define Parameters-------------------------------*/
-#define LOOP_LIMIT				5
-#define MAX_STALL_TIME			50		//us
-#define AntennaDiversityValue	0x80	//(Adapter->bSoftwareAntennaDiversity ? 0x00:0x80)
-#define MAX_TXPWR_IDX_NMODE_92S	63
-#define Reset_Cnt_Limit			3
-
-
-#ifdef CONFIG_PCI_HCI
-#define MAX_AGGR_NUM	0x0B
-#else
-#define MAX_AGGR_NUM	0x07
-#endif // CONFIG_PCI_HCI
-
-
-/*--------------------------Define Parameters-------------------------------*/
-
-/*------------------------------Define structure----------------------------*/ 
-
-
-/* BB/RF related */
-
-#define	SIC_ENABLE				0
-
-/*------------------------------Define structure----------------------------*/ 
-
-
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export global variable----------------------------*/
-
-
-/*------------------------Export Marco Definition---------------------------*/
-/*------------------------Export Marco Definition---------------------------*/
-
-
-/*--------------------------Exported Function prototype---------------------*/
-//1. BB register R/W API
-
-extern	u32	
-PHY_QueryBBReg8814A(	IN	PADAPTER	Adapter,
-								IN	u32		RegAddr,
-								IN	u32		BitMask	);
-
-
-VOID	
-PHY_SetBBReg8814A(	IN	PADAPTER	Adapter,
-								IN	u32		RegAddr,
-								IN	u32		BitMask,
-								IN	u32		Data	);
-
-
-extern	u32	
-PHY_QueryRFReg8814A(	IN	PADAPTER			Adapter,
-								IN	u8			eRFPath,
-								IN	u32			RegAddr,
-								IN	u32			BitMask	);
-
-
-void	
-PHY_SetRFReg8814A(	IN	PADAPTER			Adapter,
-								IN	u8			eRFPath,
-								IN	u32				RegAddr,
-								IN	u32				BitMask,
-								IN	u32				Data	);
-
-//1 3. Initial BB/RF config by reading MAC/BB/RF txt.
-s32
-phy_BB8814A_Config_ParaFile(
-	IN	PADAPTER	Adapter
-	);
-
-
-RT_STATUS
-PHY_BBConfigMP_8814A(
-	IN	PADAPTER	Adapter
-	);
-
-VOID
-PHY_ConfigBB_8814A(
-	IN	PADAPTER	Adapter
-	);
-
-
-VOID
-phy_ADC_CLK_8814A(
-	IN	PADAPTER	Adapter
-	);
-
-s32
-PHY_RFConfig8814A(
-	IN	PADAPTER	Adapter	
-	);
-
-//
-// RF Power setting
-//
-//BOOLEAN	PHY_SetRFPowerState8814A(PADAPTER Adapter, rt_rf_power_state	eRFPowerState);
-
-//1 5. Tx  Power setting API
-
-VOID	
-PHY_GetTxPowerLevel8814(
-	IN	PADAPTER		Adapter,
-	OUT ps4Byte			powerlevel
-	);
-
-VOID	
-PHY_SetTxPowerLevel8814(
-	IN	PADAPTER		Adapter,
-	IN	u8			Channel 
-	);
-
-u8
-PHY_GetTxPowerIndex_8814A(
-	IN	PADAPTER			Adapter,
-	IN  u8  				RFPath,
-	IN	u8				Rate,
-	IN	CHANNEL_WIDTH		BandWidth,	
-	IN	u8				Channel
-	);
-
-VOID
-PHY_SetTxPowerIndex_8814A(
-	IN	PADAPTER			Adapter,
-	IN	u32				PowerIndex,
-	IN	u8				RFPath,	
-	IN	u8				Rate
-	);
-
-
-BOOLEAN
-PHY_UpdateTxPowerDbm8814A(
-	IN	PADAPTER	Adapter,
-	IN	s4Byte		powerInDbm	
-	);
-
-
-u32 
-PHY_GetTxBBSwing_8814A(
-	IN	PADAPTER	Adapter,
-	IN	BAND_TYPE 	Band,
-	IN 	u8 		RFPath
-	);
-
-
-
-//1 6. Channel setting API
-
-VOID
-PHY_SwChnlTimerCallback8814A(
-	IN	PRT_TIMER		pTimer
-	);
-
-VOID
-PHY_SwChnlWorkItemCallback8814A(
-	IN PVOID            pContext
-	);
-
-
-VOID
-HAL_HandleSwChnl8814A(	
-	IN	PADAPTER	pAdapter,
-	IN	u8		channel
-	);
-
-VOID	
-PHY_SwChnlSynchronously8814A(	IN	PADAPTER		pAdapter,
-										IN	u8			channel	);
-
-VOID
-PHY_SwChnlAndSetBWModeCallback8814A(IN PVOID            pContext);
-
-
-VOID
-PHY_HandleSwChnlAndSetBW8814A(
-	IN	PADAPTER			Adapter,
-	IN	BOOLEAN				bSwitchChannel,
-	IN	BOOLEAN				bSetBandWidth,
-	IN	u8					ChannelNum,
-	IN	CHANNEL_WIDTH		ChnlWidth,
-	IN	u8					ChnlOffsetOf40MHz,
-	IN	u8					ChnlOffsetOf80MHz,
-	IN	u8					CenterFrequencyIndex1
-);
-
-
-BOOLEAN 
-PHY_QueryRFPathSwitch_8814A(	IN	PADAPTER	pAdapter);
-
-
-
-//VOID PHY_SetMonitorMode8814A(PADAPTER pAdapter, BOOLEAN bEnableMonitorMode);
-
-
-#if (USE_WORKITEM)
-VOID
-RtCheckForHangWorkItemCallback8814A(
-                IN PVOID   pContext
-);
-#endif
-
-BOOLEAN
-SetAntennaConfig8814A(
-	IN	PADAPTER	Adapter,
-	IN	u8		DefaultAnt	
-	);
-
-VOID
-PHY_SetRFEReg8814A(
-	IN PADAPTER		Adapter,
-	IN BOOLEAN		bInit,
-	IN u8		Band
-	);
-
-
-s32
-PHY_SwitchWirelessBand8814A(
-	IN PADAPTER		 Adapter,
-	IN u8		Band
-);
-
-VOID
-PHY_SetIO_8814A(
-    PADAPTER		pAdapter
-    );
-
-VOID
-PHY_SetBWMode8814(
-	IN	PADAPTER			Adapter,
-	IN	CHANNEL_WIDTH	Bandwidth,	// 20M or 40M
-	IN	u8					Offset		// Upper, Lower, or Don't care
-);
-
-VOID
-PHY_SwChnl8814(
-	IN	PADAPTER	Adapter,
-	IN	u8			channel
-	);
-
-VOID
-PHY_SetSwChnlBWMode8814(
-	IN	PADAPTER			Adapter,
-	IN	u8					channel,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					Offset40,
-	IN	u8					Offset80
-);
-
-s32 PHY_MACConfig8814(PADAPTER Adapter);
-int PHY_BBConfig8814(PADAPTER	Adapter);
-VOID PHY_Set_SecCCATH_by_RXANT_8814A(PADAPTER	pAdapter, u4Byte ulAntennaRx);
-
-
-
-/*--------------------------Exported Function prototype---------------------*/
-
-/*--------------------------Exported Function prototype---------------------*/
-#endif	// __INC_HAL8192CPHYCFG_H
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8814PHYCFG_H__
+#define __INC_HAL8814PHYCFG_H__
+
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters-------------------------------*/
+
+/*------------------------------Define structure----------------------------*/
+
+
+/* BB/RF related */
+
+#define	SIC_ENABLE				0
+
+/*------------------------------Define structure----------------------------*/
+
+
+/*------------------------Export global variable----------------------------*/
+/*------------------------Export global variable----------------------------*/
+
+
+/*------------------------Export Marco Definition---------------------------*/
+/*------------------------Export Marco Definition---------------------------*/
+
+
+/*--------------------------Exported Function prototype---------------------*/
+/* 1. BB register R/W API */
+
+extern	u32
+PHY_QueryBBReg8814A(IN	PADAPTER	Adapter,
+		    IN	u32		RegAddr,
+		    IN	u32		BitMask);
+
+
+VOID
+PHY_SetBBReg8814A(IN	PADAPTER	Adapter,
+		  IN	u32		RegAddr,
+		  IN	u32		BitMask,
+		  IN	u32		Data);
+
+
+extern	u32
+PHY_QueryRFReg8814A(IN	PADAPTER			Adapter,
+		    IN	enum rf_path	eRFPath,
+		    IN	u32			RegAddr,
+		    IN	u32			BitMask);
+
+
+void
+PHY_SetRFReg8814A(IN	PADAPTER			Adapter,
+		  IN	enum rf_path		eRFPath,
+		  IN	u32				RegAddr,
+		  IN	u32				BitMask,
+		  IN	u32				Data);
+
+/* 1 3. Initial BB/RF config by reading MAC/BB/RF txt. */
+s32
+phy_BB8814A_Config_ParaFile(
+	IN	PADAPTER	Adapter
+);
+
+VOID
+PHY_ConfigBB_8814A(
+	IN	PADAPTER	Adapter
+);
+
+
+VOID
+phy_ADC_CLK_8814A(
+	IN	PADAPTER	Adapter
+);
+
+s32
+PHY_RFConfig8814A(
+	IN	PADAPTER	Adapter
+);
+
+/*
+ * RF Power setting
+ *
+ * BOOLEAN	PHY_SetRFPowerState8814A(PADAPTER Adapter, rt_rf_power_state	eRFPowerState); */
+
+/* 1 5. Tx  Power setting API */
+
+VOID
+PHY_GetTxPowerLevel8814(
+	IN	PADAPTER		Adapter,
+	OUT ps4Byte			powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8814(
+	IN	PADAPTER		Adapter,
+	IN	u8			Channel
+);
+
+u8
+phy_get_tx_power_index_8814a(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	IN	enum channel_width BandWidth,
+	IN	u8				Channel
+);
+
+u8
+PHY_GetTxPowerIndex8814A(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	IN	u8				BandWidth,
+	IN	u8				Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_SetTxPowerIndex_8814A(
+	IN	PADAPTER		Adapter,
+	IN	u32				PowerIndex,
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate
+);
+
+
+BOOLEAN
+PHY_UpdateTxPowerDbm8814A(
+	IN	PADAPTER	Adapter,
+	IN	s4Byte		powerInDbm
+);
+
+
+u32
+PHY_GetTxBBSwing_8814A(
+	IN	PADAPTER	Adapter,
+	IN	BAND_TYPE	Band,
+	IN	enum rf_path	RFPath
+);
+
+
+
+/* 1 6. Channel setting API */
+#if 0
+VOID
+PHY_SwChnlTimerCallback8814A(
+	IN	struct timer_list		*p_timer
+);
+#endif
+VOID
+PHY_SwChnlWorkItemCallback8814A(
+	IN PVOID            pContext
+);
+
+
+VOID
+HAL_HandleSwChnl8814A(
+	IN	PADAPTER	pAdapter,
+	IN	u8		channel
+);
+
+VOID
+PHY_SwChnlSynchronously8814A(IN	PADAPTER		pAdapter,
+			     IN	u8			channel);
+
+VOID
+PHY_SwChnlAndSetBWModeCallback8814A(IN PVOID            pContext);
+
+
+VOID
+PHY_HandleSwChnlAndSetBW8814A(
+	IN	PADAPTER			Adapter,
+	IN	BOOLEAN				bSwitchChannel,
+	IN	BOOLEAN				bSetBandWidth,
+	IN	u8					ChannelNum,
+	IN	enum channel_width	ChnlWidth,
+	IN	u8					ChnlOffsetOf40MHz,
+	IN	u8					ChnlOffsetOf80MHz,
+	IN	u8					CenterFrequencyIndex1
+);
+
+
+BOOLEAN
+PHY_QueryRFPathSwitch_8814A(IN	PADAPTER	pAdapter);
+
+
+
+#if (USE_WORKITEM)
+VOID
+RtCheckForHangWorkItemCallback8814A(
+	IN PVOID   pContext
+);
+#endif
+
+BOOLEAN
+SetAntennaConfig8814A(
+	IN	PADAPTER	Adapter,
+	IN	u8		DefaultAnt
+);
+
+VOID
+PHY_SetRFEReg8814A(
+	IN PADAPTER		Adapter,
+	IN BOOLEAN		bInit,
+	IN u8		Band
+);
+
+
+s32
+PHY_SwitchWirelessBand8814A(
+	IN PADAPTER		 Adapter,
+	IN u8		Band
+);
+
+VOID
+PHY_SetIO_8814A(
+	PADAPTER		pAdapter
+);
+
+VOID
+PHY_SetSwChnlBWMode8814(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+s32 PHY_MACConfig8814(PADAPTER Adapter);
+int PHY_BBConfig8814(PADAPTER	Adapter);
+VOID PHY_Set_SecCCATH_by_RXANT_8814A(PADAPTER	pAdapter, u4Byte ulAntennaRx);
+
+
+
+/*--------------------------Exported Function prototype---------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+#endif /* __INC_HAL8192CPHYCFG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyReg.h
index 56c74baf81c6..97b6d8998c20 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PhyReg.h
@@ -1,866 +1,864 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8814PHYREG_H__
-#define __INC_HAL8814PHYREG_H__
-/*--------------------------Define Parameters-------------------------------*/
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
-
-
-/* BB Register Definition */
-
-#define rCCAonSec_Jaguar		0x838
-#define rPwed_TH_Jaguar			0x830
-#define rL1_Weight_Jaguar		0x840
-
-// BW and sideband setting
-#define rBWIndication_Jaguar		0x834
-#define rL1PeakTH_Jaguar		0x848
-#define rRFMOD_Jaguar			0x8ac	//RF mode 
-#define rADC_Buf_Clk_Jaguar		0x8c4
-#define	rADC_Buf_40_Clk_Jaguar2		0x8c8
-#define rRFECTRL_Jaguar			0x900
-#define bRFMOD_Jaguar			0xc3
-#define rCCK_System_Jaguar		0xa00   // for cck sideband
-#define bCCK_System_Jaguar		0x10
-
-// Block & Path enable
-#define rOFDMCCKEN_Jaguar 		0x808 // OFDM/CCK block enable
-#define bOFDMEN_Jaguar			0x20000000
-#define bCCKEN_Jaguar			0x10000000
-#define rRxPath_Jaguar			0x808	// Rx antenna
-#define bRxPath_Jaguar			0xff
-#define rTxPath_Jaguar			0x80c	// Tx antenna
-#define bTxPath_Jaguar			0x0fffffff
-#define rCCK_RX_Jaguar			0xa04	// for cck rx path selection
-#define bCCK_RX_Jaguar			0x0c000000 
-#define rVhtlen_Use_Lsig_Jaguar	0x8c3	// Use LSIG for VHT length
-
-#define	rRxPath_Jaguar2				0xa04	// Rx antenna
-#define	rTxAnt_1Nsts_Jaguar2		0x93c	// Tx antenna for 1Nsts
-#define	rTxAnt_23Nsts_Jaguar2		0x940	// Tx antenna for 2Nsts and 3Nsts
-
-
-// RF read/write-related
-#define rHSSIRead_Jaguar			0x8b0  // RF read addr
-#define bHSSIRead_addr_Jaguar		0xff
-#define bHSSIRead_trigger_Jaguar	0x100
-#define rA_PIRead_Jaguar			0xd04 // RF readback with PI
-#define rB_PIRead_Jaguar			0xd44 // RF readback with PI
-#define rA_SIRead_Jaguar			0xd08 // RF readback with SI
-#define rB_SIRead_Jaguar			0xd48 // RF readback with SI
-#define rRead_data_Jaguar			0xfffff
-#define rA_LSSIWrite_Jaguar			0xc90 // RF write addr
-#define rB_LSSIWrite_Jaguar			0xe90 // RF write addr
-#define bLSSIWrite_data_Jaguar		0x000fffff
-#define bLSSIWrite_addr_Jaguar		0x0ff00000
-
-#define	rC_PIRead_Jaguar2			0xd84 // RF readback with PI
-#define	rD_PIRead_Jaguar2			0xdC4 // RF readback with PI
-#define	rC_SIRead_Jaguar2			0xd88 // RF readback with SI
-#define	rD_SIRead_Jaguar2			0xdC8 // RF readback with SI
-#define	rC_LSSIWrite_Jaguar2		0x1890 // RF write addr
-#define	rD_LSSIWrite_Jaguar2		0x1A90 // RF write addr
-
-
-// YN: mask the following register definition temporarily 
-#define rFPGA0_XA_RFInterfaceOE			0x860	// RF Channel switch
-#define rFPGA0_XB_RFInterfaceOE			0x864
-
-#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
-//#define rFPGA0_AdDaClockEn			0x888	// enable ad/da clock1 for dual-phy
-//#define rFPGA0_AnalogParameter4		0x88c
-
-
-// CCK TX scaling
-#define rCCK_TxFilter1_Jaguar		0xa20
-#define bCCK_TxFilter1_C0_Jaguar   	0x00ff0000
-#define bCCK_TxFilter1_C1_Jaguar		0xff000000
-#define rCCK_TxFilter2_Jaguar		0xa24
-#define bCCK_TxFilter2_C2_Jaguar		0x000000ff
-#define bCCK_TxFilter2_C3_Jaguar		0x0000ff00
-#define bCCK_TxFilter2_C4_Jaguar		0x00ff0000
-#define bCCK_TxFilter2_C5_Jaguar		0xff000000
-#define rCCK_TxFilter3_Jaguar		0xa28
-#define bCCK_TxFilter3_C6_Jaguar		0x000000ff
-#define bCCK_TxFilter3_C7_Jaguar		0x0000ff00
-/* NBI & CSI Mask setting */
-#define	rCSI_Mask_Setting1_Jaguar	0x874
-#define	rCSI_Fix_Mask0_Jaguar		0x880
-#define	rCSI_Fix_Mask1_Jaguar		0x884
-#define	rCSI_Fix_Mask2_Jaguar		0x888
-#define	rCSI_Fix_Mask3_Jaguar		0x88c
-#define	rCSI_Fix_Mask4_Jaguar		0x890
-#define	rCSI_Fix_Mask5_Jaguar		0x894
-#define	rCSI_Fix_Mask6_Jaguar		0x898
-#define	rCSI_Fix_Mask7_Jaguar		0x89c
-#define	rNBI_Setting_Jaguar			0x87c
-
-
-// YN: mask the following register definition temporarily
-//#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
-
-// RXIQC
-#define rA_RxIQC_AB_Jaguar    	0xc10  //RxIQ imblance matrix coeff. A & B
-#define rA_RxIQC_CD_Jaguar    	0xc14  //RxIQ imblance matrix coeff. C & D
-#define rA_TxScale_Jaguar 		0xc1c  // Pah_A TX scaling factor
-#define rB_TxScale_Jaguar 		0xe1c  // Path_B TX scaling factor
-#define rB_RxIQC_AB_Jaguar    	0xe10  //RxIQ imblance matrix coeff. A & B
-#define rB_RxIQC_CD_Jaguar    	0xe14  //RxIQ imblance matrix coeff. C & D
-#define b_RxIQC_AC_Jaguar		0x02ff  // bit mask for IQC matrix element A & C
-#define b_RxIQC_BD_Jaguar		0x02ff0000 // bit mask for IQC matrix element A & C
-
-#define	rC_TxScale_Jaguar2 		0x181c  // Pah_C TX scaling factor
-#define	rD_TxScale_Jaguar2 		0x1A1c  // Path_D TX scaling factor
-#define	rRF_TxGainOffset		0x55
-
-// DIG-related
-#define rA_IGI_Jaguar				0xc50	// Initial Gain for path-A
-#define rB_IGI_Jaguar				0xe50	// Initial Gain for path-B
-#define	rC_IGI_Jaguar2				0x1850	// Initial Gain for path-C
-#define	rD_IGI_Jaguar2				0x1A50	// Initial Gain for path-D
-
-#define rOFDM_FalseAlarm1_Jaguar	0xf48  // counter for break
-#define rOFDM_FalseAlarm2_Jaguar	0xf4c  // counter for spoofing
-#define rCCK_FalseAlarm_Jaguar        	0xa5c // counter for cck false alarm
-#define b_FalseAlarm_Jaguar			0xffff
-#define rCCK_CCA_Jaguar				0xa08	// cca threshold
-#define bCCK_CCA_Jaguar				0x00ff0000
-
-// Tx Power Ttraining-related
-#define rA_TxPwrTraing_Jaguar		0xc54
-#define rB_TxPwrTraing_Jaguar		0xe54
-
-// Report-related
-#define rOFDM_ShortCFOAB_Jaguar	0xf60  
-#define rOFDM_LongCFOAB_Jaguar		0xf64
-#define rOFDM_EndCFOAB_Jaguar		0xf70
-#define rOFDM_AGCReport_Jaguar		0xf84
-#define rOFDM_RxSNR_Jaguar			0xf88
-#define rOFDM_RxEVMCSI_Jaguar		0xf8c
-#define rOFDM_SIGReport_Jaguar		0xf90
-
-// Misc functions
-#define rEDCCA_Jaguar				0x8a4 // EDCCA
-#define bEDCCA_Jaguar				0xffff
-#define rAGC_table_Jaguar			0x82c   // AGC tabel select
-#define bAGC_table_Jaguar			0x3
-#define b_sel5g_Jaguar    				0x1000 // sel5g
-#define b_LNA_sw_Jaguar				0x8000 // HW/WS control for LNA
-#define rFc_area_Jaguar				0x860   // fc_area 
-#define bFc_area_Jaguar				0x1ffe000
-#define rSingleTone_ContTx_Jaguar	0x914
-
-#define	rAGC_table_Jaguar2			0x958	// AGC tabel select
-#define	rDMA_trigger_Jaguar2		0x95C	// ADC sample mode
-
-
-// RFE
-#define rA_RFE_Pinmux_Jaguar	0xcb0  // Path_A RFE cotrol pinmux
-#define rB_RFE_Pinmux_Jaguar	0xeb0 // Path_B RFE control pinmux
-#define rA_RFE_Inv_Jaguar		0xcb4  // Path_A RFE cotrol   
-#define rB_RFE_Inv_Jaguar		0xeb4 // Path_B RFE control
-#define rA_RFE_Jaguar			0xcb8  // Path_A RFE cotrol   
-#define rB_RFE_Jaguar			0xeb8 // Path_B RFE control
-#define r_ANTSEL_SW_Jaguar		0x900 // ANTSEL SW Control
-#define bMask_RFEInv_Jaguar		0x3ff00000
-#define bMask_AntselPathFollow_Jaguar 0x00030000
-
-#define	rC_RFE_Pinmux_Jaguar	0x18B4	// Path_C RFE cotrol pinmux
-#define	rD_RFE_Pinmux_Jaguar	0x1AB4	// Path_D RFE cotrol pinmux
-#define	rA_RFE_Sel_Jaguar2		0x1990
-
-
-
-// TX AGC 
-#define rTxAGC_A_CCK11_CCK1_JAguar				0xc20
-#define rTxAGC_A_Ofdm18_Ofdm6_JAguar				0xc24
-#define rTxAGC_A_Ofdm54_Ofdm24_JAguar			0xc28
-#define rTxAGC_A_MCS3_MCS0_JAguar					0xc2c
-#define rTxAGC_A_MCS7_MCS4_JAguar					0xc30
-#define rTxAGC_A_MCS11_MCS8_JAguar				0xc34
-#define rTxAGC_A_MCS15_MCS12_JAguar				0xc38
-#define rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	0xc3c
-#define rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	0xc40
-#define rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	0xc44
-#define rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	0xc48
-#define rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	0xc4c
-#define rTxAGC_B_CCK11_CCK1_JAguar				0xe20
-#define rTxAGC_B_Ofdm18_Ofdm6_JAguar				0xe24
-#define rTxAGC_B_Ofdm54_Ofdm24_JAguar			0xe28
-#define rTxAGC_B_MCS3_MCS0_JAguar					0xe2c
-#define rTxAGC_B_MCS7_MCS4_JAguar					0xe30
-#define rTxAGC_B_MCS11_MCS8_JAguar				0xe34
-#define rTxAGC_B_MCS15_MCS12_JAguar				0xe38
-#define rTxAGC_B_Nss1Index3_Nss1Index0_JAguar		0xe3c
-#define rTxAGC_B_Nss1Index7_Nss1Index4_JAguar		0xe40
-#define rTxAGC_B_Nss2Index1_Nss1Index8_JAguar		0xe44
-#define rTxAGC_B_Nss2Index5_Nss2Index2_JAguar		0xe48
-#define rTxAGC_B_Nss2Index9_Nss2Index6_JAguar		0xe4c
-#define bTxAGC_byte0_Jaguar							0xff
-#define bTxAGC_byte1_Jaguar							0xff00
-#define bTxAGC_byte2_Jaguar							0xff0000
-#define bTxAGC_byte3_Jaguar							0xff000000
-
-
-// TX AGC 
-#define		rTxAGC_A_CCK11_CCK1_Jaguar2	0xc20
-#define		rTxAGC_A_Ofdm18_Ofdm6_Jaguar2	0xc24
-#define		rTxAGC_A_Ofdm54_Ofdm24_Jaguar2	0xc28
-#define		rTxAGC_A_MCS3_MCS0_Jaguar2	0xc2c
-#define		rTxAGC_A_MCS7_MCS4_Jaguar2	0xc30
-#define		rTxAGC_A_MCS11_MCS8_Jaguar2	0xc34
-#define		rTxAGC_A_MCS15_MCS12_Jaguar2	0xc38
-#define		rTxAGC_A_MCS19_MCS16_Jaguar2	0xcd8
-#define		rTxAGC_A_MCS23_MCS20_Jaguar2	0xcdc
-#define		rTxAGC_A_Nss1Index3_Nss1Index0_Jaguar2	0xc3c
-#define		rTxAGC_A_Nss1Index7_Nss1Index4_Jaguar2	0xc40
-#define		rTxAGC_A_Nss2Index1_Nss1Index8_Jaguar2	0xc44
-#define		rTxAGC_A_Nss2Index5_Nss2Index2_Jaguar2	0xc48
-#define		rTxAGC_A_Nss2Index9_Nss2Index6_Jaguar2	0xc4c
-#define		rTxAGC_A_Nss3Index3_Nss3Index0_Jaguar2	0xce0
-#define		rTxAGC_A_Nss3Index7_Nss3Index4_Jaguar2	0xce4
-#define		rTxAGC_A_Nss3Index9_Nss3Index8_Jaguar2	0xce8
-#define		rTxAGC_B_CCK11_CCK1_Jaguar2	0xe20
-#define		rTxAGC_B_Ofdm18_Ofdm6_Jaguar2	0xe24
-#define		rTxAGC_B_Ofdm54_Ofdm24_Jaguar2	0xe28
-#define		rTxAGC_B_MCS3_MCS0_Jaguar2	0xe2c
-#define		rTxAGC_B_MCS7_MCS4_Jaguar2	0xe30
-#define		rTxAGC_B_MCS11_MCS8_Jaguar2	0xe34
-#define		rTxAGC_B_MCS15_MCS12_Jaguar2	0xe38
-#define		rTxAGC_B_MCS19_MCS16_Jaguar2	0xed8
-#define		rTxAGC_B_MCS23_MCS20_Jaguar2	0xedc
-#define		rTxAGC_B_Nss1Index3_Nss1Index0_Jaguar2	0xe3c
-#define		rTxAGC_B_Nss1Index7_Nss1Index4_Jaguar2	0xe40
-#define		rTxAGC_B_Nss2Index1_Nss1Index8_Jaguar2	0xe44
-#define		rTxAGC_B_Nss2Index5_Nss2Index2_Jaguar2	0xe48
-#define		rTxAGC_B_Nss2Index9_Nss2Index6_Jaguar2	0xe4c
-#define		rTxAGC_B_Nss3Index3_Nss3Index0_Jaguar2	0xee0
-#define		rTxAGC_B_Nss3Index7_Nss3Index4_Jaguar2	0xee4
-#define		rTxAGC_B_Nss3Index9_Nss3Index8_Jaguar2	0xee8
-#define		rTxAGC_C_CCK11_CCK1_Jaguar2	0x1820
-#define		rTxAGC_C_Ofdm18_Ofdm6_Jaguar2	0x1824
-#define		rTxAGC_C_Ofdm54_Ofdm24_Jaguar2	0x1828
-#define		rTxAGC_C_MCS3_MCS0_Jaguar2	0x182c
-#define		rTxAGC_C_MCS7_MCS4_Jaguar2	0x1830
-#define		rTxAGC_C_MCS11_MCS8_Jaguar2	0x1834
-#define		rTxAGC_C_MCS15_MCS12_Jaguar2	0x1838
-#define		rTxAGC_C_MCS19_MCS16_Jaguar2	0x18d8
-#define		rTxAGC_C_MCS23_MCS20_Jaguar2	0x18dc
-#define		rTxAGC_C_Nss1Index3_Nss1Index0_Jaguar2	0x183c
-#define		rTxAGC_C_Nss1Index7_Nss1Index4_Jaguar2	0x1840
-#define		rTxAGC_C_Nss2Index1_Nss1Index8_Jaguar2	0x1844
-#define		rTxAGC_C_Nss2Index5_Nss2Index2_Jaguar2	0x1848
-#define		rTxAGC_C_Nss2Index9_Nss2Index6_Jaguar2	0x184c
-#define		rTxAGC_C_Nss3Index3_Nss3Index0_Jaguar2	0x18e0
-#define		rTxAGC_C_Nss3Index7_Nss3Index4_Jaguar2	0x18e4
-#define		rTxAGC_C_Nss3Index9_Nss3Index8_Jaguar2	0x18e8
-#define		rTxAGC_D_CCK11_CCK1_Jaguar2	0x1a20
-#define		rTxAGC_D_Ofdm18_Ofdm6_Jaguar2	0x1a24
-#define		rTxAGC_D_Ofdm54_Ofdm24_Jaguar2	0x1a28
-#define		rTxAGC_D_MCS3_MCS0_Jaguar2	0x1a2c
-#define		rTxAGC_D_MCS7_MCS4_Jaguar2	0x1a30
-#define		rTxAGC_D_MCS11_MCS8_Jaguar2	0x1a34
-#define		rTxAGC_D_MCS15_MCS12_Jaguar2	0x1a38
-#define		rTxAGC_D_MCS19_MCS16_Jaguar2	0x1ad8
-#define		rTxAGC_D_MCS23_MCS20_Jaguar2	0x1adc
-#define		rTxAGC_D_Nss1Index3_Nss1Index0_Jaguar2	0x1a3c
-#define		rTxAGC_D_Nss1Index7_Nss1Index4_Jaguar2	0x1a40
-#define		rTxAGC_D_Nss2Index1_Nss1Index8_Jaguar2	0x1a44
-#define		rTxAGC_D_Nss2Index5_Nss2Index2_Jaguar2	0x1a48
-#define		rTxAGC_D_Nss2Index9_Nss2Index6_Jaguar2	0x1a4c
-#define		rTxAGC_D_Nss3Index3_Nss3Index0_Jaguar2	0x1ae0
-#define		rTxAGC_D_Nss3Index7_Nss3Index4_Jaguar2	0x1ae4
-#define		rTxAGC_D_Nss3Index9_Nss3Index8_Jaguar2	0x1ae8
-// IQK YN: temporaily mask this part
-//#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
-
-
-// AFE-related
-#define rA_AFEPwr1_Jaguar					0xc60 // dynamic AFE power control
-#define rA_AFEPwr2_Jaguar					0xc64 // dynamic AFE power control
-#define rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xc68
-#define rA_Tx_CCKBBON_OFDMRFON_Jaguar	0xc6c
-#define rA_Tx_OFDMBBON_Tx2Rx_Jaguar		0xc70
-#define rA_Tx2Tx_RXCCK_Jaguar				0xc74
-#define rA_Rx_OFDM_WaitRIFS_Jaguar			0xc78
-#define rA_Rx2Rx_BT_Jaguar					0xc7c
-#define rA_sleep_nav_Jaguar 					0xc80
-#define rA_pmpd_Jaguar 						0xc84
-#define rB_AFEPwr1_Jaguar					0xe60 // dynamic AFE power control
-#define rB_AFEPwr2_Jaguar					0xe64 // dynamic AFE power control
-#define rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xe68
-#define rB_Tx_CCKBBON_OFDMRFON_Jaguar	0xe6c
-#define rB_Tx_OFDMBBON_Tx2Rx_Jaguar		0xe70
-#define rB_Tx2Tx_RXCCK_Jaguar				0xe74
-#define rB_Rx_OFDM_WaitRIFS_Jaguar			0xe78
-#define rB_Rx2Rx_BT_Jaguar					0xe7c
-#define rB_sleep_nav_Jaguar 					0xe80
-#define rB_pmpd_Jaguar 						0xe84
-
-
-// YN: mask these registers temporaily
-//#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
-
-
-// RSSI Dump
-#define rA_RSSIDump_Jaguar 			0xBF0
-#define rB_RSSIDump_Jaguar 			0xBF1
-#define rS1_RXevmDump_Jaguar		0xBF4 
-#define rS2_RXevmDump_Jaguar 		0xBF5
-#define rA_RXsnrDump_Jaguar		0xBF6
-#define rB_RXsnrDump_Jaguar		0xBF7
-#define rA_CfoShortDump_Jaguar		0xBF8 
-#define rB_CfoShortDump_Jaguar		0xBFA
-#define rA_CfoLongDump_Jaguar		0xBEC
-#define rB_CfoLongDump_Jaguar		0xBEE
- 
-
-// RF Register
-//
-#define RF_AC_Jaguar				0x00	// 
-#define RF_RF_Top_Jaguar			0x07	// 
-#define RF_TXLOK_Jaguar				0x08	// 
-#define RF_TXAPK_Jaguar				0x0B
-#define RF_CHNLBW_Jaguar 			0x18	// RF channel and BW switch
-#define RF_RCK1_Jaguar				0x1c	// 
-#define RF_RCK2_Jaguar				0x1d
-#define RF_RCK3_Jaguar   			0x1e
-#define RF_ModeTableAddr			0x30
-#define RF_ModeTableData0			0x31
-#define RF_ModeTableData1			0x32
-#define RF_TxLCTank_Jaguar          	0x54
-#define RF_APK_Jaguar				0x63
-#define RF_LCK						0xB4
-#define RF_WeLut_Jaguar				0xEF
-
-#define bRF_CHNLBW_MOD_AG_Jaguar	0x70300
-#define bRF_CHNLBW_BW 				0xc00
-
-
-//
-// RL6052 Register definition
-//
-#define RF_AC						0x00	// 
-#define RF_IPA_A					0x0C	// 
-#define RF_TXBIAS_A					0x0D
-#define RF_BS_PA_APSET_G9_G11		0x0E
-#define RF_MODE1					0x10	// 
-#define RF_MODE2					0x11	// 
-#define RF_CHNLBW					0x18	// RF channel and BW switch
-#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
-#define RF_0x52 						0x52
-#define RF_WE_LUT					0xEF
-
-//
-//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
-
-
-//
-// 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
-
-//
-// 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_XA_HSSIParameter1	0x820	// RF 3 wire register
-#define rFPGA0_XA_HSSIParameter2	0x824
-#define rFPGA0_XB_HSSIParameter1	0x828
-#define rFPGA0_XB_HSSIParameter2	0x82c
-
-#define	rFPGA0_XA_LSSIParameter		0x840
-#define	rFPGA0_XB_LSSIParameter		0x844
-
-#define rFPGA0_XAB_SwitchControl	0x858	// RF Channel switch
-#define rFPGA0_XCD_SwitchControl	0x85c
-
-#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
-#define rFPGA0_AdDaClockEn			0x888	// enable ad/da clock1 for dual-phy
-#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_XCD_RFPara	0x8b4
-#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	REG_BB_TX_PATH_SEL_1		0x93c
-#define	REG_BB_TX_PATH_SEL_2		0x940
-#define rFPGA1_TxBlock				0x904	// Useless now
-#define rFPGA1_DebugSelect			0x908	// Useless now
-#define rFPGA1_TxInfo				0x90c	// Useless now // Status report??
-
/*Page 19 for TxBF*/
-#define	REG_BB_TXBF_ANT_SET_BF1	0x19ac
-#define	REG_BB_TXBF_ANT_SET_BF0	0x19b4
-//
-// PageA(0xA00)
-//
-#define rCCK0_System				0xa00
-#define rCCK0_AFESetting				0xa04	// Disable init gain now // Select RX path by RSSI
-#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
-
-//
-// 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
-
-//
-// 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 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 rTxAGC_B_Mcs15_Mcs12		0x868
-#define rTxAGC_B_CCK11_A_CCK2_11	0x86c
-
-#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
-
-
-// 2. Page8(0x800)
-#define bRFMOD						0x1	// Reg 0x800 rFPGA0_RFMOD
-#define bJapanMode					0x2
-#define bCCKTxSC					0x30
-#define bCCKEn						0x1000000
-#define bOFDMEn						0x2000000
-#define bXBTxAGC                  			0xf00	// Reg 80c rFPGA0_TxGainStage
-#define bXCTxAGC                  			0xf000
-#define bXDTxAGC                  			0xf0000
-
-// 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
-
-#define		RF_T_METER_88E				0x42	//
-
-// 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
-
-
-//
-// Other Definition
-//
-
-#define bEnable                   0x1	// Useless
-#define bDisable                  0x0
-
-//byte endable for srwrite
-#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 bMaskH3Bytes				0xffffff00
-#define bMask12Bits				0xfff	
-#define bMaskH4Bits				0xf0000000	
-#define bMaskOFDM_D			0xffc00000
-#define bMaskCCK				0x3f3f3f3f
-#define bMask7bits				0x7f
-#define bMaskByte2HighNibble			0x00f00000
-#define bMaskByte3LowNibble				0x0f000000
-#define bMaskL3Bytes			0x00ffffff
-
-/*--------------------------Define Parameters-------------------------------*/
-
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8814PHYREG_H__
+#define __INC_HAL8814PHYREG_H__
+/*--------------------------Define Parameters-------------------------------*/
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
+
+
+/* BB Register Definition */
+
+#define rCCAonSec_Jaguar		0x838
+#define rPwed_TH_Jaguar			0x830
+#define rL1_Weight_Jaguar		0x840
+#define	r_L1_SBD_start_time		0x844
+
+/* BW and sideband setting */
+#define rBWIndication_Jaguar		0x834
+#define rL1PeakTH_Jaguar		0x848
+#define rRFMOD_Jaguar			0x8ac	/* RF mode */
+#define rADC_Buf_Clk_Jaguar		0x8c4
+#define	rADC_Buf_40_Clk_Jaguar2		0x8c8
+#define rRFECTRL_Jaguar			0x900
+#define bRFMOD_Jaguar			0xc3
+#define rCCK_System_Jaguar		0xa00   /* for cck sideband */
+#define bCCK_System_Jaguar		0x10
+
+/* Block & Path enable */
+#define rOFDMCCKEN_Jaguar 		0x808 /* OFDM/CCK block enable */
+#define bOFDMEN_Jaguar			0x20000000
+#define bCCKEN_Jaguar			0x10000000
+#define rRxPath_Jaguar			0x808	/* Rx antenna */
+#define bRxPath_Jaguar			0xff
+#define rTxPath_Jaguar			0x80c	/* Tx antenna */
+#define bTxPath_Jaguar			0x0fffffff
+#define rCCK_RX_Jaguar			0xa04	/* for cck rx path selection */
+#define bCCK_RX_Jaguar			0x0c000000
+#define rVhtlen_Use_Lsig_Jaguar	0x8c3	/* Use LSIG for VHT length */
+
+#define	rRxPath_Jaguar2				0xa04	/* Rx antenna */
+#define	rTxAnt_1Nsts_Jaguar2		0x93c	/* Tx antenna for 1Nsts */
+#define	rTxAnt_23Nsts_Jaguar2		0x940	/* Tx antenna for 2Nsts and 3Nsts */
+
+
+/* RF read/write-related */
+#define rHSSIRead_Jaguar			0x8b0  /* RF read addr */
+#define bHSSIRead_addr_Jaguar		0xff
+#define bHSSIRead_trigger_Jaguar	0x100
+#define rA_PIRead_Jaguar			0xd04 /* RF readback with PI */
+#define rB_PIRead_Jaguar			0xd44 /* RF readback with PI */
+#define rA_SIRead_Jaguar			0xd08 /* RF readback with SI */
+#define rB_SIRead_Jaguar			0xd48 /* RF readback with SI */
+#define rRead_data_Jaguar			0xfffff
+#define rA_LSSIWrite_Jaguar			0xc90 /* RF write addr */
+#define rB_LSSIWrite_Jaguar			0xe90 /* RF write addr */
+#define bLSSIWrite_data_Jaguar		0x000fffff
+#define bLSSIWrite_addr_Jaguar		0x0ff00000
+
+#define	rC_PIRead_Jaguar2			0xd84 /* RF readback with PI */
+#define	rD_PIRead_Jaguar2			0xdC4 /* RF readback with PI */
+#define	rC_SIRead_Jaguar2			0xd88 /* RF readback with SI */
+#define	rD_SIRead_Jaguar2			0xdC8 /* RF readback with SI */
+#define	rC_LSSIWrite_Jaguar2		0x1890 /* RF write addr */
+#define	rD_LSSIWrite_Jaguar2		0x1A90 /* RF write addr */
+
+
+/* YN: mask the following register definition temporarily */
+#define rFPGA0_XA_RFInterfaceOE			0x860	/* RF Channel switch */
+#define rFPGA0_XB_RFInterfaceOE			0x864
+
+#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
+ * #define rFPGA0_AdDaClockEn			0x888 */	/* enable ad/da clock1 for dual-phy
+ * #define rFPGA0_AnalogParameter4		0x88c */
+
+
+/* CCK TX scaling */
+#define rCCK_TxFilter1_Jaguar		0xa20
+#define bCCK_TxFilter1_C0_Jaguar	0x00ff0000
+#define bCCK_TxFilter1_C1_Jaguar		0xff000000
+#define rCCK_TxFilter2_Jaguar		0xa24
+#define bCCK_TxFilter2_C2_Jaguar		0x000000ff
+#define bCCK_TxFilter2_C3_Jaguar		0x0000ff00
+#define bCCK_TxFilter2_C4_Jaguar		0x00ff0000
+#define bCCK_TxFilter2_C5_Jaguar		0xff000000
+#define rCCK_TxFilter3_Jaguar		0xa28
+#define bCCK_TxFilter3_C6_Jaguar		0x000000ff
+#define bCCK_TxFilter3_C7_Jaguar		0x0000ff00
+/* NBI & CSI Mask setting */
+#define	rCSI_Mask_Setting1_Jaguar	0x874
+#define	rCSI_Fix_Mask0_Jaguar		0x880
+#define	rCSI_Fix_Mask1_Jaguar		0x884
+#define	rCSI_Fix_Mask2_Jaguar		0x888
+#define	rCSI_Fix_Mask3_Jaguar		0x88c
+#define	rCSI_Fix_Mask4_Jaguar		0x890
+#define	rCSI_Fix_Mask5_Jaguar		0x894
+#define	rCSI_Fix_Mask6_Jaguar		0x898
+#define	rCSI_Fix_Mask7_Jaguar		0x89c
+#define	rNBI_Setting_Jaguar			0x87c
+
+
+/* YN: mask the following register definition temporarily
+ * #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 */
+
+/* RXIQC */
+#define rA_RxIQC_AB_Jaguar    	0xc10  /* RxIQ imblance matrix coeff. A & B */
+#define rA_RxIQC_CD_Jaguar    	0xc14  /* RxIQ imblance matrix coeff. C & D */
+#define rA_TxScale_Jaguar 		0xc1c  /* Pah_A TX scaling factor */
+#define rB_TxScale_Jaguar 		0xe1c  /* Path_B TX scaling factor */
+#define rB_RxIQC_AB_Jaguar    	0xe10  /* RxIQ imblance matrix coeff. A & B */
+#define rB_RxIQC_CD_Jaguar    	0xe14  /* RxIQ imblance matrix coeff. C & D */
+#define b_RxIQC_AC_Jaguar		0x02ff  /* bit mask for IQC matrix element A & C */
+#define b_RxIQC_BD_Jaguar		0x02ff0000 /* bit mask for IQC matrix element A & C */
+
+#define	rC_TxScale_Jaguar2 		0x181c  /* Pah_C TX scaling factor */
+#define	rD_TxScale_Jaguar2 		0x1A1c  /* Path_D TX scaling factor */
+#define	rRF_TxGainOffset		0x55
+
+/* DIG-related */
+#define rA_IGI_Jaguar				0xc50	/* Initial Gain for path-A */
+#define rB_IGI_Jaguar				0xe50	/* Initial Gain for path-B */
+#define	rC_IGI_Jaguar2				0x1850	/* Initial Gain for path-C */
+#define	rD_IGI_Jaguar2				0x1A50	/* Initial Gain for path-D */
+
+#define rOFDM_FalseAlarm1_Jaguar	0xf48  /* counter for break */
+#define rOFDM_FalseAlarm2_Jaguar	0xf4c  /* counter for spoofing */
+#define rCCK_FalseAlarm_Jaguar        	0xa5c /* counter for cck false alarm */
+#define b_FalseAlarm_Jaguar			0xffff
+#define rCCK_CCA_Jaguar				0xa08	/* cca threshold */
+#define bCCK_CCA_Jaguar				0x00ff0000
+
+/* Tx Power Ttraining-related */
+#define rA_TxPwrTraing_Jaguar		0xc54
+#define rB_TxPwrTraing_Jaguar		0xe54
+
+/* Report-related */
+#define rOFDM_ShortCFOAB_Jaguar	0xf60
+#define rOFDM_LongCFOAB_Jaguar		0xf64
+#define rOFDM_EndCFOAB_Jaguar		0xf70
+#define rOFDM_AGCReport_Jaguar		0xf84
+#define rOFDM_RxSNR_Jaguar			0xf88
+#define rOFDM_RxEVMCSI_Jaguar		0xf8c
+#define rOFDM_SIGReport_Jaguar		0xf90
+
+/* Misc functions */
+#define rEDCCA_Jaguar				0x8a4 /* EDCCA */
+#define bEDCCA_Jaguar				0xffff
+#define rAGC_table_Jaguar			0x82c   /* AGC tabel select */
+#define bAGC_table_Jaguar			0x3
+#define b_sel5g_Jaguar    				0x1000 /* sel5g */
+#define b_LNA_sw_Jaguar				0x8000 /* HW/WS control for LNA */
+#define rFc_area_Jaguar				0x860   /* fc_area */
+#define bFc_area_Jaguar				0x1ffe000
+#define rSingleTone_ContTx_Jaguar	0x914
+
+#define	rAGC_table_Jaguar2			0x958	/* AGC tabel select */
+#define	rDMA_trigger_Jaguar2		0x95C	/* ADC sample mode */
+
+
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xcb0  /* Path_A RFE cotrol pinmux */
+#define rB_RFE_Pinmux_Jaguar	0xeb0 /* Path_B RFE control pinmux */
+#define rA_RFE_Inv_Jaguar		0xcb4  /* Path_A RFE cotrol   */
+#define rB_RFE_Inv_Jaguar		0xeb4 /* Path_B RFE control */
+#define rA_RFE_Jaguar			0xcb8  /* Path_A RFE cotrol   */
+#define rB_RFE_Jaguar			0xeb8 /* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define r_ANTSEL_SW_Jaguar		0x900 /* ANTSEL SW Control */
+#define bMask_RFEInv_Jaguar		0x3ff00000
+#define bMask_AntselPathFollow_Jaguar 0x00030000
+
+#define	rC_RFE_Pinmux_Jaguar	0x18B4	/* Path_C RFE cotrol pinmux */
+#define	rD_RFE_Pinmux_Jaguar	0x1AB4	/* Path_D RFE cotrol pinmux */
+#define	rA_RFE_Sel_Jaguar2		0x1990
+
+
+
+/* TX AGC */
+#define rTxAGC_A_CCK11_CCK1_JAguar				0xc20
+#define rTxAGC_A_Ofdm18_Ofdm6_JAguar				0xc24
+#define rTxAGC_A_Ofdm54_Ofdm24_JAguar			0xc28
+#define rTxAGC_A_MCS3_MCS0_JAguar					0xc2c
+#define rTxAGC_A_MCS7_MCS4_JAguar					0xc30
+#define rTxAGC_A_MCS11_MCS8_JAguar				0xc34
+#define rTxAGC_A_MCS15_MCS12_JAguar				0xc38
+#define rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	0xc3c
+#define rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	0xc40
+#define rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	0xc44
+#define rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	0xc48
+#define rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	0xc4c
+#define rTxAGC_B_CCK11_CCK1_JAguar				0xe20
+#define rTxAGC_B_Ofdm18_Ofdm6_JAguar				0xe24
+#define rTxAGC_B_Ofdm54_Ofdm24_JAguar			0xe28
+#define rTxAGC_B_MCS3_MCS0_JAguar					0xe2c
+#define rTxAGC_B_MCS7_MCS4_JAguar					0xe30
+#define rTxAGC_B_MCS11_MCS8_JAguar				0xe34
+#define rTxAGC_B_MCS15_MCS12_JAguar				0xe38
+#define rTxAGC_B_Nss1Index3_Nss1Index0_JAguar		0xe3c
+#define rTxAGC_B_Nss1Index7_Nss1Index4_JAguar		0xe40
+#define rTxAGC_B_Nss2Index1_Nss1Index8_JAguar		0xe44
+#define rTxAGC_B_Nss2Index5_Nss2Index2_JAguar		0xe48
+#define rTxAGC_B_Nss2Index9_Nss2Index6_JAguar		0xe4c
+#define bTxAGC_byte0_Jaguar							0xff
+#define bTxAGC_byte1_Jaguar							0xff00
+#define bTxAGC_byte2_Jaguar							0xff0000
+#define bTxAGC_byte3_Jaguar							0xff000000
+
+
+/* TX AGC */
+#define		rTxAGC_A_CCK11_CCK1_Jaguar2	0xc20
+#define		rTxAGC_A_Ofdm18_Ofdm6_Jaguar2	0xc24
+#define		rTxAGC_A_Ofdm54_Ofdm24_Jaguar2	0xc28
+#define		rTxAGC_A_MCS3_MCS0_Jaguar2	0xc2c
+#define		rTxAGC_A_MCS7_MCS4_Jaguar2	0xc30
+#define		rTxAGC_A_MCS11_MCS8_Jaguar2	0xc34
+#define		rTxAGC_A_MCS15_MCS12_Jaguar2	0xc38
+#define		rTxAGC_A_MCS19_MCS16_Jaguar2	0xcd8
+#define		rTxAGC_A_MCS23_MCS20_Jaguar2	0xcdc
+#define		rTxAGC_A_Nss1Index3_Nss1Index0_Jaguar2	0xc3c
+#define		rTxAGC_A_Nss1Index7_Nss1Index4_Jaguar2	0xc40
+#define		rTxAGC_A_Nss2Index1_Nss1Index8_Jaguar2	0xc44
+#define		rTxAGC_A_Nss2Index5_Nss2Index2_Jaguar2	0xc48
+#define		rTxAGC_A_Nss2Index9_Nss2Index6_Jaguar2	0xc4c
+#define		rTxAGC_A_Nss3Index3_Nss3Index0_Jaguar2	0xce0
+#define		rTxAGC_A_Nss3Index7_Nss3Index4_Jaguar2	0xce4
+#define		rTxAGC_A_Nss3Index9_Nss3Index8_Jaguar2	0xce8
+#define		rTxAGC_B_CCK11_CCK1_Jaguar2	0xe20
+#define		rTxAGC_B_Ofdm18_Ofdm6_Jaguar2	0xe24
+#define		rTxAGC_B_Ofdm54_Ofdm24_Jaguar2	0xe28
+#define		rTxAGC_B_MCS3_MCS0_Jaguar2	0xe2c
+#define		rTxAGC_B_MCS7_MCS4_Jaguar2	0xe30
+#define		rTxAGC_B_MCS11_MCS8_Jaguar2	0xe34
+#define		rTxAGC_B_MCS15_MCS12_Jaguar2	0xe38
+#define		rTxAGC_B_MCS19_MCS16_Jaguar2	0xed8
+#define		rTxAGC_B_MCS23_MCS20_Jaguar2	0xedc
+#define		rTxAGC_B_Nss1Index3_Nss1Index0_Jaguar2	0xe3c
+#define		rTxAGC_B_Nss1Index7_Nss1Index4_Jaguar2	0xe40
+#define		rTxAGC_B_Nss2Index1_Nss1Index8_Jaguar2	0xe44
+#define		rTxAGC_B_Nss2Index5_Nss2Index2_Jaguar2	0xe48
+#define		rTxAGC_B_Nss2Index9_Nss2Index6_Jaguar2	0xe4c
+#define		rTxAGC_B_Nss3Index3_Nss3Index0_Jaguar2	0xee0
+#define		rTxAGC_B_Nss3Index7_Nss3Index4_Jaguar2	0xee4
+#define		rTxAGC_B_Nss3Index9_Nss3Index8_Jaguar2	0xee8
+#define		rTxAGC_C_CCK11_CCK1_Jaguar2	0x1820
+#define		rTxAGC_C_Ofdm18_Ofdm6_Jaguar2	0x1824
+#define		rTxAGC_C_Ofdm54_Ofdm24_Jaguar2	0x1828
+#define		rTxAGC_C_MCS3_MCS0_Jaguar2	0x182c
+#define		rTxAGC_C_MCS7_MCS4_Jaguar2	0x1830
+#define		rTxAGC_C_MCS11_MCS8_Jaguar2	0x1834
+#define		rTxAGC_C_MCS15_MCS12_Jaguar2	0x1838
+#define		rTxAGC_C_MCS19_MCS16_Jaguar2	0x18d8
+#define		rTxAGC_C_MCS23_MCS20_Jaguar2	0x18dc
+#define		rTxAGC_C_Nss1Index3_Nss1Index0_Jaguar2	0x183c
+#define		rTxAGC_C_Nss1Index7_Nss1Index4_Jaguar2	0x1840
+#define		rTxAGC_C_Nss2Index1_Nss1Index8_Jaguar2	0x1844
+#define		rTxAGC_C_Nss2Index5_Nss2Index2_Jaguar2	0x1848
+#define		rTxAGC_C_Nss2Index9_Nss2Index6_Jaguar2	0x184c
+#define		rTxAGC_C_Nss3Index3_Nss3Index0_Jaguar2	0x18e0
+#define		rTxAGC_C_Nss3Index7_Nss3Index4_Jaguar2	0x18e4
+#define		rTxAGC_C_Nss3Index9_Nss3Index8_Jaguar2	0x18e8
+#define		rTxAGC_D_CCK11_CCK1_Jaguar2	0x1a20
+#define		rTxAGC_D_Ofdm18_Ofdm6_Jaguar2	0x1a24
+#define		rTxAGC_D_Ofdm54_Ofdm24_Jaguar2	0x1a28
+#define		rTxAGC_D_MCS3_MCS0_Jaguar2	0x1a2c
+#define		rTxAGC_D_MCS7_MCS4_Jaguar2	0x1a30
+#define		rTxAGC_D_MCS11_MCS8_Jaguar2	0x1a34
+#define		rTxAGC_D_MCS15_MCS12_Jaguar2	0x1a38
+#define		rTxAGC_D_MCS19_MCS16_Jaguar2	0x1ad8
+#define		rTxAGC_D_MCS23_MCS20_Jaguar2	0x1adc
+#define		rTxAGC_D_Nss1Index3_Nss1Index0_Jaguar2	0x1a3c
+#define		rTxAGC_D_Nss1Index7_Nss1Index4_Jaguar2	0x1a40
+#define		rTxAGC_D_Nss2Index1_Nss1Index8_Jaguar2	0x1a44
+#define		rTxAGC_D_Nss2Index5_Nss2Index2_Jaguar2	0x1a48
+#define		rTxAGC_D_Nss2Index9_Nss2Index6_Jaguar2	0x1a4c
+#define		rTxAGC_D_Nss3Index3_Nss3Index0_Jaguar2	0x1ae0
+#define		rTxAGC_D_Nss3Index7_Nss3Index4_Jaguar2	0x1ae4
+#define		rTxAGC_D_Nss3Index9_Nss3Index8_Jaguar2	0x1ae8
+/* IQK YN: temporaily mask this part
+ * #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 */
+
+
+/* AFE-related */
+#define rA_AFEPwr1_Jaguar					0xc60 /* dynamic AFE power control */
+#define rA_AFEPwr2_Jaguar					0xc64 /* dynamic AFE power control */
+#define rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xc68
+#define rA_Tx_CCKBBON_OFDMRFON_Jaguar	0xc6c
+#define rA_Tx_OFDMBBON_Tx2Rx_Jaguar		0xc70
+#define rA_Tx2Tx_RXCCK_Jaguar				0xc74
+#define rA_Rx_OFDM_WaitRIFS_Jaguar			0xc78
+#define rA_Rx2Rx_BT_Jaguar					0xc7c
+#define rA_sleep_nav_Jaguar					0xc80
+#define rA_pmpd_Jaguar						0xc84
+#define rB_AFEPwr1_Jaguar					0xe60 /* dynamic AFE power control */
+#define rB_AFEPwr2_Jaguar					0xe64 /* dynamic AFE power control */
+#define rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	0xe68
+#define rB_Tx_CCKBBON_OFDMRFON_Jaguar	0xe6c
+#define rB_Tx_OFDMBBON_Tx2Rx_Jaguar		0xe70
+#define rB_Tx2Tx_RXCCK_Jaguar				0xe74
+#define rB_Rx_OFDM_WaitRIFS_Jaguar			0xe78
+#define rB_Rx2Rx_BT_Jaguar					0xe7c
+#define rB_sleep_nav_Jaguar					0xe80
+#define rB_pmpd_Jaguar						0xe84
+
+
+/* YN: mask these registers temporaily
+ * #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 */
+
+
+/* RSSI Dump */
+#define rA_RSSIDump_Jaguar			0xBF0
+#define rB_RSSIDump_Jaguar			0xBF1
+#define rS1_RXevmDump_Jaguar		0xBF4
+#define rS2_RXevmDump_Jaguar		0xBF5
+#define rA_RXsnrDump_Jaguar		0xBF6
+#define rB_RXsnrDump_Jaguar		0xBF7
+#define rA_CfoShortDump_Jaguar		0xBF8
+#define rB_CfoShortDump_Jaguar		0xBFA
+#define rA_CfoLongDump_Jaguar		0xBEC
+#define rB_CfoLongDump_Jaguar		0xBEE
+
+
+/* RF Register
+ *   */
+#define RF_AC_Jaguar				0x00	/*  */
+#define RF_RF_Top_Jaguar			0x07	/*  */
+#define RF_TXLOK_Jaguar				0x08	/*  */
+#define RF_TXAPK_Jaguar				0x0B
+#define RF_CHNLBW_Jaguar 			0x18	/* RF channel and BW switch */
+#define RF_RCK1_Jaguar				0x1c	/*  */
+#define RF_RCK2_Jaguar				0x1d
+#define RF_RCK3_Jaguar			0x1e
+#define RF_ModeTableAddr			0x30
+#define RF_ModeTableData0			0x31
+#define RF_ModeTableData1			0x32
+#define RF_TxLCTank_Jaguar	0x54
+#define RF_APK_Jaguar				0x63
+#define RF_LCK						0xB4
+#define RF_WeLut_Jaguar				0xEF
+
+#define bRF_CHNLBW_MOD_AG_Jaguar	0x70300
+#define bRF_CHNLBW_BW				0xc00
+
+
+/*
+ * RL6052 Register definition
+ *   */
+#define RF_AC						0x00	/*  */
+#define RF_IPA_A					0x0C	/*  */
+#define RF_TXBIAS_A					0x0D
+#define RF_BS_PA_APSET_G9_G11		0x0E
+#define RF_MODE1					0x10	/*  */
+#define RF_MODE2					0x11	/*  */
+#define RF_CHNLBW					0x18	/* RF channel and BW switch */
+#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 */
+#define RF_0x52						0x52
+#define RF_WE_LUT					0xEF
+
+/*
+ * 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
+
+
+/*
+ * 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
+
+/*
+ * 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_XA_HSSIParameter1	0x820	/* RF 3 wire register */
+#define rFPGA0_XA_HSSIParameter2	0x824
+#define rFPGA0_XB_HSSIParameter1	0x828
+#define rFPGA0_XB_HSSIParameter2	0x82c
+
+#define	rFPGA0_XA_LSSIParameter		0x840
+#define	rFPGA0_XB_LSSIParameter		0x844
+
+#define rFPGA0_XAB_SwitchControl	0x858	/* RF Channel switch */
+#define rFPGA0_XCD_SwitchControl	0x85c
+
+#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
+#define rFPGA0_AdDaClockEn			0x888	/* enable ad/da clock1 for dual-phy */
+#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_XCD_RFPara	0x8b4
+#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	REG_BB_TX_PATH_SEL_1_8814A		0x93c
+#define	REG_BB_TX_PATH_SEL_2_8814A		0x940
+#define rFPGA1_TxBlock				0x904	/* Useless now */
+#define rFPGA1_DebugSelect			0x908	/* Useless now */
+#define rFPGA1_TxInfo				0x90c	/* Useless now */ /* Status report?? */
+/*Page 19 for TxBF*/
+#define	REG_BB_TXBF_ANT_SET_BF1_8814A	0x19ac
+#define	REG_BB_TXBF_ANT_SET_BF0_8814A	0x19b4
+/*
+ * PageA(0xA00)
+ *   */
+#define rCCK0_System				0xa00
+#define rCCK0_AFESetting				0xa04	/* Disable init gain now */ /* Select RX path by RSSI */
+#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 */
+
+/*
+ * 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
+
+/*
+ * 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 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 rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86c
+
+#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
+
+
+/* 2. Page8(0x800) */
+#define bRFMOD						0x1	/* Reg 0x800 rFPGA0_RFMOD */
+#define bJapanMode					0x2
+#define bCCKTxSC					0x30
+#define bCCKEn						0x1000000
+#define bOFDMEn						0x2000000
+#define bXBTxAGC                  			0xf00	/* Reg 80c rFPGA0_TxGainStage */
+#define bXCTxAGC			0xf000
+#define bXDTxAGC			0xf0000
+
+/* 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
+
+#define		RF_T_METER_88E				0x42
+
+/* 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
+
+
+/*
+ * Other Definition
+ *   */
+
+#define bEnable                   0x1	/* Useless */
+#define bDisable                  0x0
+
+/* byte endable for srwrite */
+#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 bMaskH3Bytes				0xffffff00
+#define bMask12Bits				0xfff
+#define bMaskH4Bits				0xf0000000
+#define bMaskOFDM_D			0xffc00000
+#define bMaskCCK				0x3f3f3f3f
+#define bMask7bits				0x7f
+#define bMaskByte2HighNibble			0x00f00000
+#define bMaskByte3LowNibble				0x0f000000
+#define bMaskL3Bytes			0x00ffffff
+
+/*--------------------------Define Parameters-------------------------------*/
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PwrSeq.h
index 2ef43c23a582..e39ac1b4aec7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8814PwrSeq.h
@@ -1,237 +1,232 @@
-
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef __HAL8814PWRSEQ_H__
-#define __HAL8814PWRSEQ_H__
-
-#include "HalPwrSeqCmd.h"
-
-/* 
-	Check document WB-110628-DZ-RTL8195 (Jaguar) Power Architecture-R04.pdf
-	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
-*/
-#define	RTL8814A_TRANS_CARDEMU_TO_ACT_STEPS	16
-#define	RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS	20
-#define	RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS	17
-#define	RTL8814A_TRANS_SUS_TO_CARDEMU_STEPS	15
-#define	RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS	17
-#define	RTL8814A_TRANS_PDN_TO_CARDEMU_STEPS	16
-#define	RTL8814A_TRANS_ACT_TO_LPS_STEPS	20
-#define	RTL8814A_TRANS_LPS_TO_ACT_STEPS	15	
-#define	RTL8814A_TRANS_END_STEPS	1
-
-
-#define RTL8814A_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
-	{0x002B, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /* ??0x28[24]=1, enable pll phase select*/ \
-	{0x0015, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, (BIT3|BIT2|BIT1), (BIT3|BIT2|BIT1)},/* 0x14[11:9]=3'b111,OCP current threshold=1.5A */ \
-	{0x002D, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x0E, 0x08},/* 0x2C[11:9]=3'b100, select lpf R3 */ \
-	{0x002D, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x70, 0x50},/* 0x2C[14:12]=3'b101, select lpf Rs*/ \
-	{0x007B, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/* 0x78[30]=1'b1, SDM order select*/ \
-	/*{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 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, BIT3, 0},/* disable WL suspend*/	\
-	{0x00F0, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* */	\
-	{0x0081, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x30, 0x20},/* */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/
-
-#define RTL8814A_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
-	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
-	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},  /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
-	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US}, /*Delay 1us*/	\
-	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
-	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},  /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
-	{0x0002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US}, /*Delay 1us*/	\
-	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
-	{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, BIT7, 0},*/  /*0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x28},   /* 0x07[7:0] = 0x28 sps pwm mode 0x2a for BT coex*/	\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x02, 0},   /*0x8[1] = 0 ANA clk =500k */	\
-	/*{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0|BIT1, 0},*/   /*  0x02[1:0] = 0	reset BB */	\
-	{0x0066, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},   /*0x66[7]=0, disable ckreq for gpio7 output SUS */	\
-	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0},   /*0x41[4]=0, disable sic for gpio7 output SUS */	\
-	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},   /*0x42[1]=0, disable ckout for gpio7 output SUS */	\
-	{0x004e, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},   /*0x4E[5]=1, disable LED2 for gpio7 output SUS */	\
-	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},   /*0x41[0]=0, disable uart for gpio7 output SUS */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/	
-
-#define RTL8814A_TRANS_CARDEMU_TO_SUS													\
-	/* format */								\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0061, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x0F, 0x0c},\
-	{0x0061, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x0F, 0x0E},\
-	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x0F, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
-	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
-	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/* suspend option all off */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*0x14[13] = 1 turn on ZCD */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/* 0x14[14] =1 trun on ZCD */	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*0x8[1] = 0 ANA clk =500k */	\
-	{0x0091, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xA0, 0xA0}, /* 0x91[7]=1 0x91[5]=1 , disable sps,ldo sleep mode */	\
-	{0x0070, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /* 0x70[3]=1 enable mainbias polling */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 1 enable WL suspend */
-
-#define RTL8814A_TRANS_SUS_TO_CARDEMU													\
-	/* format */								\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 0 enable WL suspend*/   \
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO sleep mode leave */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, 0},/* 0x14[14] =0 trun off ZCD */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, 0},/*0x14[13] = 0 turn off ZCD */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
-	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */
-
-#define RTL8814A_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	/**{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, //0x194[0]=0 , disable 32K clock*/	\
-	/**{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x94}, //0x93=0x94 , 90[30] =0 enable 500k ANA clock .switch clock from 12M to 500K , 90 [26] =0 disable EEprom loader clock*/	\
-	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0}, /*0x03[2] = 0, reset 3081*/	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x01}, /*0x80=05h if reload fw, fill the default value of host_CPU handshake field*/	\
-	{0x0081, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x30}, /*0x80=05h if reload fw, fill the default value of host_CPU handshake field*/	\
-	/*{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xF0, 0xcc},*/   \
-	/*{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xF0, 0xEC},*/   \
-	/*{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x07},*/  /* gpio11 input mode, gpio10~8 output mode */	\
-	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
-	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/* 0x15[6] =1 trun on ZCD output */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*0x15[5] = 1 turn on ZCD */	\
-	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, 0},/*0x12[6] = 0 force PFM mode */	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
-	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*0x8[1] = 0 ANA clk =500k */	\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
-	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /* 0x01f[1]=0 , disable RFC_0  control  REG_RF_CTRL_8814A */	\
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /* 0x020[1]=0 , disable RFC_1  control  REG_RF_CTRL_8814A */	\
-	{0x0021, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /* 0x021[1]=0 , disable RFC_2  control  REG_RF_CTRL_8814A */	\
-	{0x0076, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0}, /* 0x076[1]=0 , disable RFC_3  control REG_OPT_CTRL_8814A +2 */	\
-	{0x0091, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xA0, 0xA0}, /* 0x91[7]=1 0x91[5]=1 , disable sps,ldo sleep mode */	\
-	{0x0070, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /* 0x70[3]=1 enable mainbias polling */	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 1 enable WL suspend*/	
-
-#define RTL8814A_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/                       \
-	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/*0x12[6] = 1 force PWM mode */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, 0},/*0x15[5] = 0 turn off ZCD */	\
-	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, 0},/* 0x15[6] =0 trun off ZCD output */	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0},/*0x23[4] = 0 hpon LDO leave sleep mode */	\
-	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
-	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00}, /* gpio11 input mode, gpio10~8 input mode */ \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0}, /*0x04[10] = 0, enable SW LPS PCIE only*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 0, enable WL suspend*/	\
-	/*{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2},*/ /*0x03[2] = 1, enable 3081*/	\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/		\
-	{0x0071, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, 0},/*0x70[10] = 0, CPHY_MBIAS_EN disable*/
-
-
-#define RTL8814A_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8814A_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-#define RTL8814A_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
-	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x7F},/*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*/	\
-	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
-	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
-	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled,and clock are gated,and RF closed*/	\
-	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US},/*Delay 1us*/	\
-	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
-	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled,and clock are gated,and RF closed*/	\
-	{0x0002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US},/*Delay 1us*/	\
-	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 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, BIT1, 0},/*check if removed later*/		\
-	{0x05F1, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Respond TxOK to scheduler*/	
-
-
-#define RTL8814A_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/	\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/	\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1|BIT0, BIT1|BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/	\
-	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1|BIT0, BIT1|BIT0}, /*.	0x1002[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 RTL8814A_TRANS_END																\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/		\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8814A_power_on_flow[RTL8814A_TRANS_CARDEMU_TO_ACT_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_radio_off_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_card_disable_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_card_enable_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_suspend_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_resume_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_hwpdn_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_enter_lps_flow[RTL8814A_TRANS_ACT_TO_LPS_STEPS+RTL8814A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8814A_leave_lps_flow[RTL8814A_TRANS_LPS_TO_ACT_STEPS+RTL8814A_TRANS_END_STEPS];
-
-#endif //__HAL8814PWRSEQ_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HAL8814PWRSEQ_H__
+#define __HAL8814PWRSEQ_H__
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WB-110628-DZ-RTL8195 (Jaguar) Power Architecture-R04.pdf
+	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
+*/
+#define	RTL8814A_TRANS_CARDEMU_TO_ACT_STEPS	16
+#define	RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS	20
+#define	RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS	17
+#define	RTL8814A_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define	RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS	17
+#define	RTL8814A_TRANS_PDN_TO_CARDEMU_STEPS	16
+#define	RTL8814A_TRANS_ACT_TO_LPS_STEPS	20
+#define	RTL8814A_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8814A_TRANS_END_STEPS	1
+
+
+#define RTL8814A_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 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, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x002B, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /* ??0x28[24]=1, enable pll phase select*/ \
+	{0x0015, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, (BIT3 | BIT2 | BIT1), (BIT3 | BIT2 | BIT1)},/* 0x14[11:9]=3'b111, OCP current threshold = 1.5A */ \
+	{0x002D, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0E, 0x08},/* 0x2C[11:9]=3'b100, select lpf R3 */ \
+	{0x002D, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x70, 0x50},/* 0x2C[14:12]=3'b101, select lpf Rs*/ \
+	{0x007B, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* 0x78[30]=1'b1, SDM order select*/ \
+	/*{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 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, BIT3, 0},/* disable WL suspend*/	\
+	{0x00F0, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* */	\
+	{0x0081, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x30, 0x20},/* */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/
+
+#define RTL8814A_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},  /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US}, /*Delay 1us*/	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},  /* 0x2[0] = 0	 RESET BB, CLOSE RF */	\
+	{0x0002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US}, /*Delay 1us*/	\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	{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, BIT7, 0},*/  /*0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x28},   /* 0x07[7:0] = 0x28 sps pwm mode 0x2a for BT coex*/	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x02, 0},   /*0x8[1] = 0 ANA clk = 500k */	\
+	/*{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 | BIT1, 0},*/   /*  0x02[1:0] = 0	reset BB */	\
+	{0x0066, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},   /*0x66[7]=0, disable ckreq for gpio7 output SUS */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},   /*0x41[4]=0, disable sic for gpio7 output SUS */	\
+	{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},   /*0x42[1]=0, disable ckout for gpio7 output SUS */	\
+	{0x004e, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},   /*0x4E[5]=1, disable LED2 for gpio7 output SUS */	\
+	{0x0041, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},   /*0x41[0]=0, disable uart for gpio7 output SUS */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/
+
+#define RTL8814A_TRANS_CARDEMU_TO_SUS													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0061, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0F, 0x0c},\
+	{0x0061, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0F, 0x0E},\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x0F, 0x07},/* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* suspend option all off */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*0x14[13] = 1 turn on ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* 0x14[14] =1 trun on ZCD */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0091, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xA0, 0xA0}, /* 0x91[7]=1 0x91[5]=1 , disable sps, ldo sleep mode */	\
+	{0x0070, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /* 0x70[3]=1 enable mainbias polling */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 1 enable WL suspend */
+
+#define RTL8814A_TRANS_SUS_TO_CARDEMU													\
+	/* format */								\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 0 enable WL suspend*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0x10, 0},/*0x23[4] = 0 hpon LDO sleep mode leave */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* 0x14[14] =0 trun off ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 0},/*0x14[13] = 0 turn off ZCD */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio11 input mode, gpio10~8 input mode */
+
+#define RTL8814A_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	/**{0x0194, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, //0x194[0]=0 , disable 32K clock*/	\
+	/**{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x94}, //0x93 = 0x94 , 90[30] =0 enable 500k ANA clock .switch clock from 12M to 500K , 90 [26] =0 disable EEprom loader clock*/	\
+	{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x03[2] = 0, reset 3081*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x01}, /*0x80 = 05h if reload fw, fill the default value of host_CPU handshake field*/	\
+	{0x0081, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x30}, /*0x80 = 05h if reload fw, fill the default value of host_CPU handshake field*/	\
+	/*{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xcc},*/   \
+	/*{0x0042, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xF0, 0xEC},*/   \
+	/*{0x0043, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x07},*/  /* gpio11 input mode, gpio10~8 output mode */	\
+	{0x0045, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio 0~7 output same value as input ?? */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xff},/* gpio0~7 output mode */	\
+	{0x0047, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/* 0x47[7:0] = 00 gpio mode */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/* 0x15[6] =1 trun on ZCD output */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*0x15[5] = 1 turn on ZCD */	\
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/*0x12[6] = 0 force PFM mode */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4},/*0x23[4] = 1 hpon LDO sleep mode */	\
+	{0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*0x8[1] = 0 ANA clk = 500k */	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x01f[1]=0 , disable RFC_0  control  REG_RF_CTRL_8814A */	\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x020[1]=0 , disable RFC_1  control  REG_RF_CTRL_8814A */	\
+	{0x0021, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x021[1]=0 , disable RFC_2  control  REG_RF_CTRL_8814A */	\
+	{0x0076, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0}, /* 0x076[1]=0 , disable RFC_3  control REG_OPT_CTRL_8814A +2 */	\
+	{0x0091, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xA0, 0xA0}, /* 0x91[7]=1 0x91[5]=1 , disable sps, ldo sleep mode */	\
+	{0x0070, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /* 0x70[3]=1 enable mainbias polling */	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, BIT3}, /*0x04[11] = 1 enable WL suspend*/
+
+#define RTL8814A_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/                       \
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, BIT6},/*0x12[6] = 1 force PWM mode */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 0},/*0x15[5] = 0 turn off ZCD */	\
+	{0x0015, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/* 0x15[6] =0 trun off ZCD output */	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0},/*0x23[4] = 0 hpon LDO leave sleep mode */	\
+	{0x0046, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/* gpio0~7 input mode */	\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00}, /* gpio11 input mode, gpio10~8 input mode */ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x04[10] = 0, enable SW LPS PCIE only*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3, 0}, /*0x04[11] = 0, enable WL suspend*/	\
+	/*{0x0003, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2},*/ /*0x03[2] = 1, enable 3081*/	\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/		\
+	{0x0071, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0},/*0x70[10] = 0, CPHY_MBIAS_EN disable*/
+
+
+#define RTL8814A_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8814A_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8814A_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x7F},/*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*/	\
+	{0x0c00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xc00[7:0] = 4	turn off 3-wire */	\
+	{0x0e00, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x04}, /* 0xe00[7:0] = 4	turn off 3-wire */	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated, and RF closed*/	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US},/*Delay 1us*/	\
+	{0x0002, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},  /* Whole BB is reset*/			\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*CCK and OFDM are disabled, and clock are gated, and RF closed*/	\
+	{0x0002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US},/*Delay 1us*/	\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 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, BIT1, 0},/*check if removed later*/		\
+	{0x05F1, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Respond TxOK to scheduler*/
+
+
+#define RTL8814A_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/	\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/	\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1 | BIT0, BIT1 | BIT0}, /*.	0x02[1:0] = 2b'11	 enable BB macro*/	\
+	{0x1002, ~PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1 | BIT0, BIT1 | BIT0}, /*.	0x1002[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 RTL8814A_TRANS_END																\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/		\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+extern WLAN_PWR_CFG rtl8814A_power_on_flow[RTL8814A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_radio_off_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_card_disable_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_card_enable_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_suspend_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_resume_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_hwpdn_flow[RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_enter_lps_flow[RTL8814A_TRANS_ACT_TO_LPS_STEPS + RTL8814A_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8814A_leave_lps_flow[RTL8814A_TRANS_LPS_TO_ACT_STEPS + RTL8814A_TRANS_END_STEPS];
+
+#endif /* __HAL8814PWRSEQ_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8821APwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8821APwrSeq.h
index b70c59381d2b..ffbae537c2dd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8821APwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/Hal8821APwrSeq.h
@@ -1,187 +1,201 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef REALTEK_POWER_SEQUENCE_8821
-#define REALTEK_POWER_SEQUENCE_8821
-
-#include "HalPwrSeqCmd.h"
-
-/* 
-	Check document WM-20130516-JackieLau-RTL8821A_Power_Architecture-R10.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
-*/
-#define	RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS	25
-#define	RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS	15
-#define	RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS	15
-#define	RTL8821A_TRANS_SUS_TO_CARDEMU_STEPS	15
-#define RTL8821A_TRANS_CARDDIS_TO_CARDEMU_STEPS	15
-#define	RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS	15
-#define	RTL8821A_TRANS_PDN_TO_CARDEMU_STEPS	15
-#define	RTL8821A_TRANS_ACT_TO_LPS_STEPS	15
-#define	RTL8821A_TRANS_LPS_TO_ACT_STEPS	15	
-#define	RTL8821A_TRANS_END_STEPS	1
-
-
-#define RTL8821A_TRANS_CARDEMU_TO_ACT 														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
-	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, 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, (BIT4|BIT3|BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[12:11]=0*/	\
-	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
-	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4|BIT3), 0},/* disable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/	\
-	{0x004F, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*0x4C[24] = 0x4F[0] = 1, switch DPDT_SEL_P output from WL BB */\
-	{0x0067, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, (BIT5|BIT4), (BIT5|BIT4)},/*0x66[13] = 0x67[5] = 1, switch for PAPE_G/PAPE_A from WL BB ; 0x66[12] = 0x67[4] = 1, switch LNAON from WL BB */\
-	{0x0025, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, 0},/*anapar_mac<118> , 0x25[6]=0 by wlan single function*/\
-	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
-	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
-	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
-	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
-	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
-	{0x007A, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x3A},/*0x7A = 0x3A start BT*/\
-	{0x002E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF , 0x82 },/* 0x2C[23:12]=0x820 ; XTAL trim */ \
-	{0x0010, PWR_CUT_A_MSK , PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6 , BIT6 },/* 0x10[6]=1 ; MP新增對於0x2C的控制權，須把0x10[6]設為1才能讓WLAN控制 */ \
-
-
-#define RTL8821A_TRANS_ACT_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{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*/	\
-	{0x004F, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*0x4C[24] = 0x4F[0] = 0, switch DPDT_SEL_P output from register 0x65[2] */\
-	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
-	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
-	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/   \
-
-
-#define RTL8821A_TRANS_CARDEMU_TO_SUS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, (BIT4|BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8821A_TRANS_SUS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8821A_TRANS_CARDEMU_TO_CARDDIS													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
-        {0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
-
-#define RTL8821A_TRANS_CARDDIS_TO_CARDEMU													\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
-	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
-	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 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, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/	
-
-
-#define RTL8821A_TRANS_CARDEMU_TO_PDN												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
-	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
-
-#define RTL8821A_TRANS_PDN_TO_CARDEMU												\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
-
-#define RTL8821A_TRANS_ACT_TO_LPS														\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
-	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
-	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
-	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
-
-
-#define RTL8821A_TRANS_LPS_TO_ACT															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
-	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
-	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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 RTL8821A_TRANS_END															\
-	/* format */																\
-	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
-	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
-
-
-extern WLAN_PWR_CFG rtl8821A_power_on_flow[RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_radio_off_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_card_disable_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_card_enable_flow[RTL8821A_TRANS_CARDDIS_TO_CARDEMU_STEPS+RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_suspend_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_resume_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_hwpdn_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_enter_lps_flow[RTL8821A_TRANS_ACT_TO_LPS_STEPS+RTL8821A_TRANS_END_STEPS];
-extern WLAN_PWR_CFG rtl8821A_leave_lps_flow[RTL8821A_TRANS_LPS_TO_ACT_STEPS+RTL8821A_TRANS_END_STEPS];
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8821
+#define REALTEK_POWER_SEQUENCE_8821
+
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20130516-JackieLau-RTL8821A_Power_Architecture-R10.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
+*/
+#define	RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS	25
+#define	RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS	15
+#define	RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS	15
+#define	RTL8821A_TRANS_SUS_TO_CARDEMU_STEPS	15
+#define RTL8821A_TRANS_CARDDIS_TO_CARDEMU_STEPS	15
+#define	RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS	15
+#define	RTL8821A_TRANS_PDN_TO_CARDEMU_STEPS	15
+#define	RTL8821A_TRANS_ACT_TO_LPS_STEPS	15
+#define	RTL8821A_TRANS_LPS_TO_ACT_STEPS	15
+#define	RTL8821A_TRANS_END_STEPS	1
+
+
+#define RTL8821A_TRANS_CARDEMU_TO_ACT														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, 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, (BIT4 | BIT3 | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[12:11]=0*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT7, 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, (BIT4 | BIT3), 0},/* disable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT0, 0},/**/	\
+	{0x004F, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*0x4C[24] = 0x4F[0] = 1, switch DPDT_SEL_P output from WL BB */\
+	{0x0067, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, (BIT5 | BIT4), (BIT5 | BIT4)},/*0x66[13] = 0x67[5] = 1, switch for PAPE_G/PAPE_A from WL BB ; 0x66[12] = 0x67[4] = 1, switch LNAON from WL BB */\
+	{0x0025, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6, 0},/*anapar_mac<118> , 0x25[6]=0 by wlan single function*/\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable GPIO9 interrupt mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x005A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, BIT1},/*Enable HSISR GPIO9 interrupt*/\
+	{0x007A, PWR_CUT_TESTCHIP_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x3A},/*0x7A = 0x3A start BT*/\
+	{0x002E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF , 0x82 },/* 0x2C[23:12]=0x820 ; XTAL trim */ \
+	{0x0010, PWR_CUT_A_MSK , PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT6 , BIT6 },/* 0x10[6]=1 ; MP新增對於0x2C的控制權，須把0x10[6]設為1才能讓WLAN控制 */ \
+
+
+#define RTL8821A_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{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*/	\
+	{0x004F, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0},/*0x4C[24] = 0x4F[0] = 0, switch DPDT_SEL_P output from register 0x65[2] */\
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, BIT0},/* 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, BIT1, BIT1}, /*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, BIT1, 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_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/   \
+
+
+#define RTL8821A_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4 | BIT3, (BIT4 | BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3 | BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8821A_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+
+#define RTL8821A_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07 = 0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8821A_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT0, 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, BIT3 | BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8821A_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/   \
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8821A_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8821A_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/	\
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8821A_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK, PWR_BASEADDR_SDIO, PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6 | BIT7, 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, BIT1, BIT1}, /*.	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, BIT1 | BIT0, BIT1 | BIT0}, /*.	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 RTL8821A_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
+
+
+	extern WLAN_PWR_CFG rtl8821A_power_on_flow[RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_radio_off_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_card_disable_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_card_enable_flow[RTL8821A_TRANS_CARDDIS_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_suspend_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_resume_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_hwpdn_flow[RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS + RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_enter_lps_flow[RTL8821A_TRANS_ACT_TO_LPS_STEPS + RTL8821A_TRANS_END_STEPS];
+	extern WLAN_PWR_CFG rtl8821A_leave_lps_flow[RTL8821A_TRANS_LPS_TO_ACT_STEPS + RTL8821A_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalPwrSeqCmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalPwrSeqCmd.h
index 5cf122fb2b5f..1f9a175e305e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalPwrSeqCmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalPwrSeqCmd.h
@@ -1,138 +1,131 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __HALPWRSEQCMD_H__
-#define __HALPWRSEQCMD_H__
-
-#include <drv_types.h>
-
-/*---------------------------------------------*/
-//3 The value of cmd: 4 bits
-/*---------------------------------------------*/
-#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
-
-
-typedef enum _PWRSEQ_CMD_DELAY_UNIT_
-{
-	PWRSEQ_DELAY_US,
-	PWRSEQ_DELAY_MS,
-} PWRSEQ_DELAY_UNIT;
-
-typedef struct _WL_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;
-} WLAN_PWR_CFG, *PWLAN_PWR_CFG;
-
-
-#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 HalPwrSeqCmdParsing(
-	PADAPTER		padapter,
-	u8				CutVersion,
-	u8				FabVersion,
-	u8				InterfaceType,
-	WLAN_PWR_CFG	PwrCfgCmd[]);
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+/*---------------------------------------------*/
+/* 3 The value of cmd: 4 bits
+ *---------------------------------------------*/
+#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
+
+
+typedef enum _PWRSEQ_CMD_DELAY_UNIT_ {
+	PWRSEQ_DELAY_US,
+	PWRSEQ_DELAY_MS,
+} PWRSEQ_DELAY_UNIT;
+
+typedef struct _WL_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;
+} WLAN_PWR_CFG, *PWLAN_PWR_CFG;
+
+
+#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 HalPwrSeqCmdParsing(
+	PADAPTER		padapter,
+	u8				CutVersion,
+	u8				FabVersion,
+	u8				InterfaceType,
+	WLAN_PWR_CFG	PwrCfgCmd[]);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalVerDef.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalVerDef.h
index 6999503af630..0215d1c8c0bc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalVerDef.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/HalVerDef.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,21 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_VERSION_DEF_H__
 #define __HAL_VERSION_DEF_H__
 
-#define TRUE 	_TRUE	
+#define TRUE	_TRUE
 #define FALSE	_FALSE
 
-// HAL_IC_TYPE_E
-typedef enum tag_HAL_IC_Type_Definition
-{
+/* HAL_IC_TYPE_E */
+typedef enum tag_HAL_IC_Type_Definition {
 	CHIP_8192S	=	0,
 	CHIP_8188C	=	1,
 	CHIP_8192C	=	2,
@@ -34,105 +29,107 @@ typedef enum tag_HAL_IC_Type_Definition
 	CHIP_8188E	=	5,
 	CHIP_8812	=	6,
 	CHIP_8821	=	7,
-	CHIP_8723B 	=	8,
-	CHIP_8192E 	=	9,
+	CHIP_8723B	=	8,
+	CHIP_8192E	=	9,
 	CHIP_8814A	=	10,
 	CHIP_8703B	=	11,
 	CHIP_8188F	=	12,
-}HAL_IC_TYPE_E;
-
-//HAL_CHIP_TYPE_E
-typedef enum tag_HAL_CHIP_Type_Definition
-{
-	TEST_CHIP 		=	0,
-	NORMAL_CHIP 	=	1,
+	CHIP_8822B	=	13,
+	CHIP_8723D	=	14,
+	CHIP_8821C	=	15,
+	CHIP_8188GTV =	16,
+} HAL_IC_TYPE_E;
+
+/* HAL_CHIP_TYPE_E */
+typedef enum tag_HAL_CHIP_Type_Definition {
+	TEST_CHIP		=	0,
+	NORMAL_CHIP	=	1,
 	FPGA			=	2,
-}HAL_CHIP_TYPE_E;
-
-//HAL_CUT_VERSION_E
-typedef enum tag_HAL_Cut_Version_Definition
-{
-	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,
-	H_CUT_VERSION 		=	7,	
-	I_CUT_VERSION 		=	8,
-	J_CUT_VERSION 		=	9,
-	K_CUT_VERSION 		=	10,
-}HAL_CUT_VERSION_E;
-
-// HAL_Manufacturer
-typedef enum tag_HAL_Manufacturer_Version_Definition
-{
-	CHIP_VENDOR_TSMC 	=	0,
-	CHIP_VENDOR_UMC 	=	1,
-	CHIP_VENDOR_SMIC 	=	2, 
-}HAL_VENDOR_E;
-
-typedef enum tag_HAL_RF_Type_Definition
-{
-	RF_TYPE_1T1R 	=	0,
-	RF_TYPE_1T2R 	=	1,
+} HAL_CHIP_TYPE_E;
+
+/* HAL_CUT_VERSION_E */
+typedef enum tag_HAL_Cut_Version_Definition {
+	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,
+	H_CUT_VERSION		=	7,
+	I_CUT_VERSION		=	8,
+	J_CUT_VERSION		=	9,
+	K_CUT_VERSION		=	10,
+} HAL_CUT_VERSION_E;
+
+/* HAL_Manufacturer */
+typedef enum tag_HAL_Manufacturer_Version_Definition {
+	CHIP_VENDOR_TSMC	=	0,
+	CHIP_VENDOR_UMC	=	1,
+	CHIP_VENDOR_SMIC	=	2,
+} HAL_VENDOR_E;
+
+typedef enum tag_HAL_RF_Type_Definition {
+	RF_TYPE_1T1R	=	0,
+	RF_TYPE_1T2R	=	1,
 	RF_TYPE_2T2R	=	2,
 	RF_TYPE_2T3R	=	3,
 	RF_TYPE_2T4R	=	4,
 	RF_TYPE_3T3R	=	5,
 	RF_TYPE_3T4R	=	6,
 	RF_TYPE_4T4R	=	7,
-}HAL_RF_TYPE_E;
+} HAL_RF_TYPE_E;
 
-typedef	struct tag_HAL_VERSION
-{
+typedef	struct tag_HAL_VERSION {
 	HAL_IC_TYPE_E		ICType;
 	HAL_CHIP_TYPE_E		ChipType;
 	HAL_CUT_VERSION_E	CUTVersion;
 	HAL_VENDOR_E		VendorType;
-	HAL_RF_TYPE_E		RFType;	
+	HAL_RF_TYPE_E		RFType;
 	u8					ROMVer;
-	u8					irv;
-}HAL_VERSION,*PHAL_VERSION;
+} HAL_VERSION, *PHAL_VERSION;
 
-//VERSION_8192C			VersionID;
-//HAL_VERSION			VersionID;
+/* VERSION_8192C			VersionID;
+ * HAL_VERSION			VersionID; */
 
-// Get element
-#define GET_CVID_IC_TYPE(version)			((HAL_IC_TYPE_E)(((HAL_VERSION)version).ICType)	)
-#define GET_CVID_CHIP_TYPE(version)			((HAL_CHIP_TYPE_E)(((HAL_VERSION)version).ChipType)	)
+/* Get element */
+#define GET_CVID_IC_TYPE(version)			((HAL_IC_TYPE_E)(((HAL_VERSION)version).ICType))
+#define GET_CVID_CHIP_TYPE(version)			((HAL_CHIP_TYPE_E)(((HAL_VERSION)version).ChipType))
 #define GET_CVID_RF_TYPE(version)			((HAL_RF_TYPE_E)(((HAL_VERSION)version).RFType))
 #define GET_CVID_MANUFACTUER(version)		((HAL_VENDOR_E)(((HAL_VERSION)version).VendorType))
 #define GET_CVID_CUT_VERSION(version)		((HAL_CUT_VERSION_E)(((HAL_VERSION)version).CUTVersion))
 #define GET_CVID_ROM_VERSION(version)		((((HAL_VERSION)version).ROMVer) & ROM_VERSION_MASK)
 
-//----------------------------------------------------------------------------
-//Common Macro. --
-//----------------------------------------------------------------------------
-//HAL_VERSION VersionID
+/* ----------------------------------------------------------------------------
+ * Common Macro. --
+ * ----------------------------------------------------------------------------
+ * HAL_VERSION VersionID */
 
-// HAL_IC_TYPE_E
+/* HAL_IC_TYPE_E */
 #if 0
-#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_92D(version)					((GET_CVID_IC_TYPE(version) == CHIP_8192D)? TRUE : FALSE)
+	#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_92D(version)					((GET_CVID_IC_TYPE(version) == CHIP_8192D) ? TRUE : FALSE)
 #endif
 
-#define IS_8188E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188E)? TRUE : FALSE)
+#define IS_8188E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188E) ? TRUE : FALSE)
 #define IS_8188F(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188F) ? TRUE : FALSE)
-#define IS_8192E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8192E)? TRUE : FALSE)
-#define IS_8812_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8812)? TRUE : FALSE)
-#define IS_8821_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8821)? TRUE : FALSE)
+#define IS_8188GTV(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188GTV) ? TRUE : FALSE)
+#define IS_8192E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8192E) ? TRUE : FALSE)
+#define IS_8812_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8812) ? TRUE : FALSE)
+#define IS_8821_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8821) ? TRUE : FALSE)
 #define IS_8814A_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8814A) ? TRUE : FALSE)
-#define IS_8723B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8723B)? TRUE : FALSE)
-#define IS_8703B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8703B)? TRUE : FALSE)
-
-//HAL_CHIP_TYPE_E
-#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)
-
-//HAL_CUT_VERSION_E
+#define IS_8723B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8723B) ? TRUE : FALSE)
+#define IS_8703B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8703B) ? TRUE : FALSE)
+#define IS_8822B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8822B) ? TRUE : FALSE)
+#define IS_8821C_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8821C) ? TRUE : FALSE)
+#define IS_8723D_SERIES(version)\
+	((GET_CVID_IC_TYPE(version) == CHIP_8723D) ? TRUE : FALSE)
+/* HAL_CHIP_TYPE_E */
+#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)
+
+/* HAL_CUT_VERSION_E */
 #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)
@@ -143,61 +140,58 @@ typedef	struct tag_HAL_VERSION
 #define IS_J_CUT(version)				((GET_CVID_CUT_VERSION(version) == J_CUT_VERSION) ? TRUE : FALSE)
 #define IS_K_CUT(version)				((GET_CVID_CUT_VERSION(version) == K_CUT_VERSION) ? TRUE : FALSE)
 
-//HAL_VENDOR_E
-#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)
-#define IS_CHIP_VENDOR_SMIC(version)	((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_SMIC)? TRUE: FALSE)
+/* HAL_VENDOR_E */
+#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)
+#define IS_CHIP_VENDOR_SMIC(version)	((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_SMIC) ? TRUE : FALSE)
 
-//HAL_RF_TYPE_E
-#define IS_1T1R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_1T1R)? TRUE : FALSE )
-#define IS_1T2R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_1T2R)? TRUE : FALSE)
-#define IS_2T2R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_2T2R)? TRUE : FALSE)
-#define IS_3T3R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_3T3R)? TRUE : FALSE)
-#define IS_3T4R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_3T4R)? TRUE : FALSE)
-#define IS_4T4R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_4T4R)? TRUE : FALSE)
+/* HAL_RF_TYPE_E */
+#define IS_1T1R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_1T1R) ? TRUE : FALSE)
+#define IS_1T2R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_1T2R) ? TRUE : FALSE)
+#define IS_2T2R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_2T2R) ? TRUE : FALSE)
+#define IS_3T3R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_3T3R) ? TRUE : FALSE)
+#define IS_3T4R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_3T4R) ? TRUE : FALSE)
+#define IS_4T4R(version)					((GET_CVID_RF_TYPE(version) == RF_TYPE_4T4R) ? TRUE : FALSE)
 
 
 
-//----------------------------------------------------------------------------
-//Chip version Macro. --
-//----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------
+ * Chip version Macro. --
+ * ---------------------------------------------------------------------------- */
 #if 0
-#define IS_81XXC_TEST_CHIP(version)		((IS_81XXC(version) && (!IS_NORMAL_CHIP(version)))? TRUE: FALSE)
+	#define IS_81XXC_TEST_CHIP(version)		((IS_81XXC(version) && (!IS_NORMAL_CHIP(version))) ? TRUE : FALSE)
 
-#define IS_92C_SERIAL(version)   					((IS_81XXC(version) && IS_2T2R(version)) ? TRUE : FALSE)
-#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_92C_SERIAL(version)					((IS_81XXC(version) && IS_2T2R(version)) ? TRUE : FALSE)
+	#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_NORMAL_CHIP92D(version)		(( IS_92D(version))?((GET_CVID_CHIP_TYPE(version)==NORMAL_CHIP)? TRUE: FALSE):FALSE)
+	#define IS_NORMAL_CHIP92D(version)		((IS_92D(version)) ? ((GET_CVID_CHIP_TYPE(version) == NORMAL_CHIP) ? TRUE : FALSE) : FALSE)
 
-#define IS_92D_SINGLEPHY(version)		((IS_92D(version)) ? (IS_2T2R(version) ? TRUE: FALSE) : FALSE)
-#define IS_92D_C_CUT(version)			((IS_92D(version)) ? (IS_C_CUT(version) ? TRUE : FALSE) : FALSE)
-#define IS_92D_D_CUT(version)			((IS_92D(version)) ? (IS_D_CUT(version) ? TRUE : FALSE) : FALSE)
-#define IS_92D_E_CUT(version)			((IS_92D(version)) ? (IS_E_CUT(version) ? TRUE : FALSE) : FALSE)
+	#define IS_92D_SINGLEPHY(version)		((IS_92D(version)) ? (IS_2T2R(version) ? TRUE : FALSE) : FALSE)
+	#define IS_92D_C_CUT(version)			((IS_92D(version)) ? (IS_C_CUT(version) ? TRUE : FALSE) : FALSE)
+	#define IS_92D_D_CUT(version)			((IS_92D(version)) ? (IS_D_CUT(version) ? TRUE : FALSE) : FALSE)
+	#define IS_92D_E_CUT(version)			((IS_92D(version)) ? (IS_E_CUT(version) ? TRUE : 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)
+	#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
+#define IS_VENDOR_8188E_I_CUT_SERIES(_Adapter)		((IS_8188E(GET_HAL_DATA(_Adapter)->version_id)) ? ((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->version_id) >= I_CUT_VERSION) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8812A_TEST_CHIP(_Adapter)		((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8812A_MP_CHIP(_Adapter)		((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8812A_C_CUT(_Adapter)			((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->version_id) == C_CUT_VERSION) ? TRUE : FALSE) : FALSE)
 
-#define IS_VENDOR_8188E_I_CUT_SERIES(_Adapter)		((IS_8188E(GET_HAL_DATA(_Adapter)->VersionID)) ? ((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->VersionID) >= I_CUT_VERSION) ? TRUE : FALSE) : FALSE)
-
-#define IS_VENDOR_8812A_TEST_CHIP(_Adapter)		((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? FALSE : TRUE) : FALSE)
-#define IS_VENDOR_8812A_MP_CHIP(_Adapter)		((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? TRUE : FALSE) : FALSE)
-#define IS_VENDOR_8812A_C_CUT(_Adapter)			((IS_8812_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->VersionID) == C_CUT_VERSION) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8821A_TEST_CHIP(_Adapter)	((IS_8821_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8821A_MP_CHIP(_Adapter)		((IS_8821_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
 
-#define IS_VENDOR_8821A_TEST_CHIP(_Adapter)	((IS_8821_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? FALSE : TRUE) : FALSE)
-#define IS_VENDOR_8821A_MP_CHIP(_Adapter)		((IS_8821_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8192E_B_CUT(_Adapter)		((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->version_id) == B_CUT_VERSION) ? TRUE : FALSE)
 
-#define IS_VENDOR_8192E_B_CUT(_Adapter)		((GET_CVID_CUT_VERSION(GET_HAL_DATA(_Adapter)->VersionID) == B_CUT_VERSION) ? TRUE : FALSE)
+#define IS_VENDOR_8723B_TEST_CHIP(_Adapter)	((IS_8723B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8723B_MP_CHIP(_Adapter)		((IS_8723B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
 
-#define IS_VENDOR_8723B_TEST_CHIP(_Adapter)	((IS_8723B_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? FALSE : TRUE) : FALSE)
-#define IS_VENDOR_8723B_MP_CHIP(_Adapter)		((IS_8723B_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? TRUE : FALSE) : FALSE)
-
-#define IS_VENDOR_8703B_TEST_CHIP(_Adapter)	((IS_8703B_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? FALSE : TRUE) : FALSE)
-#define IS_VENDOR_8703B_MP_CHIP(_Adapter)		((IS_8703B_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? TRUE : FALSE) : FALSE)
-#define IS_VENDOR_8814A_TEST_CHIP(_Adapter)	((IS_8814A_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? FALSE : TRUE) : FALSE)
-#define IS_VENDOR_8814A_MP_CHIP(_Adapter)		((IS_8814A_SERIES(GET_HAL_DATA(_Adapter)->VersionID)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->VersionID)) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8703B_TEST_CHIP(_Adapter)	((IS_8703B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8703B_MP_CHIP(_Adapter)		((IS_8703B_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
+#define IS_VENDOR_8814A_TEST_CHIP(_Adapter)	((IS_8814A_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? FALSE : TRUE) : FALSE)
+#define IS_VENDOR_8814A_MP_CHIP(_Adapter)		((IS_8814A_SERIES(GET_HAL_DATA(_Adapter)->version_id)) ? ((IS_NORMAL_CHIP(GET_HAL_DATA(_Adapter)->version_id)) ? TRUE : FALSE) : FALSE)
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/autoconf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/autoconf.h
index 6f4090351274..721fe317932c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/autoconf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/autoconf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2014 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 /*
  * Public General Config
  */
@@ -39,7 +35,7 @@
 #define CONFIG_80211N_HT
 #define CONFIG_RECV_REORDERING_CTRL
 
-//#define CONFIG_IOCTL_CFG80211		// Set from Makefile
+/* #define CONFIG_IOCTL_CFG80211 */		/* Set from Makefile */
 #ifdef CONFIG_IOCTL_CFG80211
 	/*
 	 * Indecate new sta asoc through cfg80211_new_sta
@@ -47,13 +43,12 @@
 	 * version < 3.2 but already apply cfg80211 patch,
 	 * RTW_USE_CFG80211_STA_EVENT must be defiend!
 	 */
-	//#define RTW_USE_CFG80211_STA_EVENT /* Indecate new sta asoc through cfg80211_new_sta */
+	/* #define RTW_USE_CFG80211_STA_EVENT */ /* Indecate new sta asoc through cfg80211_new_sta */
 	#ifndef CONFIG_PLATFORM_INTEL_BYT
 	#define CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER
-	#endif //!CONFIG_PLATFORM_INTEL_BYT
-	//#define CONFIG_DEBUG_CFG80211
+	#endif /* !CONFIG_PLATFORM_INTEL_BYT */
+	/* #define CONFIG_DEBUG_CFG80211 */
 	#define CONFIG_SET_SCAN_DENY_TIMER
-	/*#define SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42*/ /* wpa_supplicant realtek version <= jb42 will be defined this */
 #endif
 
 #define CONFIG_AP_MODE
@@ -62,70 +57,68 @@
 	#ifndef CONFIG_NATIVEAP_MLME
 		#define CONFIG_HOSTAPD_MLME
 	#endif
-	//#define CONFIG_FIND_BEST_CHANNEL
-	#define CONFIG_TX_MCAST2UNI	// Support IP multicast->unicast
+	/* #define CONFIG_FIND_BEST_CHANNEL */
+	#define CONFIG_TX_MCAST2UNI	/* Support IP multicast->unicast */
 #endif
 
 #define CONFIG_P2P
 #ifdef CONFIG_P2P
-	//Added by Albert 20110812
-	//The CONFIG_WFD is for supporting the Wi-Fi display
+	/* Added by Albert 20110812 */
+	/* The CONFIG_WFD is for supporting the Wi-Fi display */
 	#define CONFIG_WFD
 
 	#define CONFIG_P2P_REMOVE_GROUP_INFO
 
-	//#define CONFIG_DBG_P2P
+	/* #define CONFIG_DBG_P2P */
 	#define CONFIG_P2P_PS
 	#define CONFIG_P2P_OP_CHK_SOCIAL_CH
-	#define CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT  //replace CONFIG_P2P_CHK_INVITE_CH_LIST flag
-	#define CONFIG_P2P_INVITE_IOT
+	#define CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT  /* replace CONFIG_P2P_CHK_INVITE_CH_LIST flag */
+	/*#define CONFIG_P2P_INVITE_IOT*/
 #endif
 
-// Added by Kurt 20110511
+/* Added by Kurt 20110511 */
 #ifdef CONFIG_TDLS
 	#define CONFIG_TDLS_DRIVER_SETUP
-//	#ifndef CONFIG_WFD
-//		#define CONFIG_WFD
-//	#endif
-//	#define CONFIG_TDLS_AUTOSETUP
+/*	#ifndef CONFIG_WFD */
+/*		#define CONFIG_WFD */
+/*	#endif */
+/*	#define CONFIG_TDLS_AUTOSETUP */
 	#define CONFIG_TDLS_AUTOCHECKALIVE
-	#define CONFIG_TDLS_CH_SW		/* Enable "CONFIG_TDLS_CH_SW" by default, however limit it to only work in wifi logo test mode but not in normal mode currently */
+	/* #define CONFIG_TDLS_CH_SW */	/* Enable this flag only when we confirm that TDLS CH SW is supported in FW */
 #endif
 
-//#define CONFIG_CONCURRENT_MODE	// Set from Makefile
+/* #define CONFIG_CONCURRENT_MODE */	/* Set from Makefile */
 #ifdef CONFIG_CONCURRENT_MODE
-	//#define CONFIG_HWPORT_SWAP				// Port0->Sec , Port1 -> Pri
 	#define CONFIG_RUNTIME_PORT_SWITCH
+	/* #define DBG_RUNTIME_PORT_SWITCH */
+
+
 	#ifndef CONFIG_RUNTIME_PORT_SWITCH
-		#define CONFIG_TSF_RESET_OFFLOAD			// For 2 PORT TSF SYNC.
+		#define CONFIG_TSF_RESET_OFFLOAD			/* For 2 PORT TSF SYNC. */
 	#endif
-	//#define DBG_RUNTIME_PORT_SWITCH
-	#define CONFIG_SCAN_BACKOP
-#endif // CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_CONCURRENT_MODE */
 
 #define CONFIG_LAYER2_ROAMING
 #define CONFIG_LAYER2_ROAMING_RESUME
 
-//#define CONFIG_80211D
-
-
 /*
  * Hareware/Firmware Related Config
  */
-//#define CONFIG_BT_COEXIST	// Set from Makefile
-//#define CONFIG_ANTENNA_DIVERSITY	// Set from Makefile
-//#define SUPPORT_HW_RFOFF_DETECTED
+/* #define CONFIG_BT_COEXIST */	/* Set from Makefile */
+/* #define CONFIG_ANTENNA_DIVERSITY */
+/* #define SUPPORT_HW_RFOFF_DETECTED */
 
-//#define CONFIG_SW_LED
+/*#define CONFIG_RTW_LED*/
+#ifdef CONFIG_RTW_LED
+	/*#define CONFIG_RTW_SW_LED*/
+#endif /* CONFIG_RTW_LED */
 
 #define CONFIG_XMIT_ACK
 #ifdef CONFIG_XMIT_ACK
 	#define CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 #endif
 
-#define CONFIG_C2H_PACKET_EN
-
-#define CONFIG_RF_GAIN_OFFSET
+#define CONFIG_RF_POWER_TRIM
 
 #define DISABLE_BB_RF	0
 
@@ -138,24 +131,27 @@
 #define CONFIG_TX_AGGREGATION
 #define CONFIG_SDIO_RX_COPY
 #define CONFIG_XMIT_THREAD_MODE
-//#define CONFIG_SDIO_TX_ENABLE_AVAL_INT
+/* #define CONFIG_SDIO_TX_ENABLE_AVAL_INT */
 
 /* #define CONFIG_RECV_THREAD_MODE */
 
 /*
  * Others
  */
-//#define CONFIG_MAC_LOOPBACK_DRIVER
+/* #define CONFIG_MAC_LOOPBACK_DRIVER */
 
-#define CONFIG_SKB_COPY	//for amsdu
+#define CONFIG_SKB_COPY	/* for amsdu */
 
 #define CONFIG_NEW_SIGNAL_STAT_PROCESS
 
 #define CONFIG_EMBEDDED_FWIMG
-//#define CONFIG_FILE_FWIMG
+#ifdef CONFIG_EMBEDDED_FWIMG
+	#define	LOAD_FW_HEADER_FROM_DRIVER
+#endif
+/* #define CONFIG_FILE_FWIMG */
 
 #define CONFIG_LONG_DELAY_ISSUE
-//#define CONFIG_PATCH_JOIN_WRONG_CHANNEL
+/* #define CONFIG_PATCH_JOIN_WRONG_CHANNEL */
 #define CONFIG_ATTEMPT_TO_FIX_AP_BEACON_ERROR
 
 
@@ -175,9 +171,9 @@
 #ifdef CONFIG_MP_INCLUDED
 	#define MP_DRIVER	1
 	#define CONFIG_MP_IWPRIV_SUPPORT
-#else // !CONFIG_MP_INCLUDED
+#else /* !CONFIG_MP_INCLUDED */
 	#define MP_DRIVER	0
-#endif // !CONFIG_MP_INCLUDED
+#endif /* !CONFIG_MP_INCLUDED */
 
 #ifdef CONFIG_POWER_SAVING
 	#define CONFIG_IPS
@@ -189,7 +185,7 @@
 
 	#ifdef CONFIG_LPS
 		#define CONFIG_CHECK_LEAVE_LPS
-		//#define CONFIG_LPS_SLOW_TRANSITION
+		/* #define CONFIG_LPS_SLOW_TRANSITION */
 	#endif
 
 	#ifdef CONFIG_LPS_LCLK
@@ -203,17 +199,15 @@
 
 	#ifdef CONFIG_IPS
 		#define CONFIG_IPS_CHECK_IN_WD /* Do IPS Check in WatchDog */
-		//#define CONFIG_SWLPS_IN_IPS /* Do SW LPS flow when entering and leaving IPS */
-		//#define CONFIG_FWLPS_IN_IPS /* issue H2C command to let FW do LPS when entering IPS */
+		/* #define CONFIG_SWLPS_IN_IPS */ /* Do SW LPS flow when entering and leaving IPS */
+		/* #define CONFIG_FWLPS_IN_IPS */ /* issue H2C command to let FW do LPS when entering IPS */
 	#endif
 #endif /* CONFIG_POWER_SAVING */
 
-#define BT_30_SUPPORT 0
-
 #ifdef CONFIG_WOWLAN
-	//#define CONFIG_GTK_OL
-	#define CONFIG_ARP_KEEP_ALIVE
-#endif // CONFIG_WOWLAN
+	/* #define CONFIG_GTK_OL */
+	/* #define CONFIG_ARP_KEEP_ALIVE */
+#endif /* CONFIG_WOWLAN */
 
 #ifdef CONFIG_GPIO_WAKEUP
 	#ifndef WAKEUP_GPIO_IDX
@@ -224,21 +218,18 @@
 /*
  * Debug Related Config
  */
-//#define CONFIG_DEBUG /* DBG_871X, etc... */
-
-#ifdef CONFIG_DEBUG
-#define DBG	1	// for ODM & BTCOEX debug
-//#define CONFIG_DEBUG_RTL871X /* RT_TRACE, RT_PRINT_DATA, _func_enter_, _func_exit_ */
-#else // !CONFIG_DEBUG
-#define DBG	0	// for ODM & BTCOEX debug
-#endif // !CONFIG_DEBUG
+#ifdef CONFIG_RTW_DEBUG
+#define DBG	1	/* for ODM & BTCOEX debug */
+#else /* !CONFIG_RTW_DEBUG */
+#define DBG	0	/* for ODM & BTCOEX debug */
+#endif /* CONFIG_RTW_DEBUG */
 
 #define CONFIG_PROC_DEBUG
 
 #define DBG_CONFIG_ERROR_DETECT
-//#define DBG_XMIT_BUF
-//#define DBG_XMIT_BUF_EXT
-//#define DBG_CHECK_FW_PS_STATE
-//#define DBG_CHECK_FW_PS_STATE_H2C
-//#define CONFIG_FW_C2H_DEBUG 
-
+/* #define DBG_XMIT_BUF */
+/* #define DBG_XMIT_BUF_EXT */
+/* #define DBG_CHECK_FW_PS_STATE */
+/* #define DBG_CHECK_FW_PS_STATE_H2C */
+/* #define CONFIG_FW_C2H_DEBUG */
+#define	DBG_RX_DFRAME_RAW_DATA
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/basic_types.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/basic_types.h
index 0b75813e70c4..ebab784baf3b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/basic_types.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/basic_types.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __BASIC_TYPES_H__
 #define __BASIC_TYPES_H__
 
@@ -27,13 +23,13 @@
 #ifndef TRUE
 	#define _TRUE	1
 #else
-	#define _TRUE	TRUE	
+	#define _TRUE	TRUE
 #endif
-		
-#ifndef FALSE		
+
+#ifndef FALSE
 	#define _FALSE	0
 #else
-	#define _FALSE	FALSE	
+	#define _FALSE	FALSE
 #endif
 
 #ifdef PLATFORM_WINDOWS
@@ -46,7 +42,7 @@
 
 	typedef signed long s32;
 	typedef unsigned long u32;
-	
+
 	typedef unsigned int	uint;
 	typedef	signed int		sint;
 
@@ -55,7 +51,7 @@
 	typedef unsigned long long u64;
 
 	#ifdef NDIS50_MINIPORT
-	
+
 		#define NDIS_MAJOR_VERSION       5
 		#define NDIS_MINOR_VERSION       0
 
@@ -91,25 +87,60 @@
 	typedef	signed int sint;
 
 	#ifndef	PVOID
-	typedef void * PVOID;
-	//#define PVOID	(void *)
+		typedef void *PVOID;
+		/* #define PVOID	(void *) */
 	#endif
 
-        #define UCHAR u8
+	#define UCHAR u8
 	#define USHORT u16
 	#define UINT u32
-	#define ULONG u32	
+	#define ULONG u32
 
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 19))
-		typedef _Bool bool;
-	#endif
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 19))
+typedef _Bool bool;
 
-	typedef void (*proc_t)(void*);
+enum {
+	false	= 0,
+	true	= 1
+};
+#endif
+
+	typedef void (*proc_t)(void *);
 
-	typedef 	__kernel_size_t	SIZE_T;	
+	typedef	__kernel_size_t	SIZE_T;
 	typedef	__kernel_ssize_t	SSIZE_T;
-	#define FIELD_OFFSET(s,field)	((SSIZE_T)&((s*)(0))->field)
-	
+	#define FIELD_OFFSET(s, field)	((SSIZE_T)&((s *)(0))->field)
+
+#define u1Byte		u8
+#define pu1Byte		u8*
+
+#define u2Byte		u16
+#define pu2Byte		u16*
+
+#define u4Byte		u32
+#define pu4Byte		u32*
+
+#define u8Byte		u64
+#define pu8Byte		u64*
+
+#define s1Byte		s8
+#define ps1Byte		s8*
+
+#define s2Byte		s16
+#define ps2Byte		s16*
+
+#define s4Byte		s32
+#define ps4Byte		s32*
+
+#define s8Byte		s64
+#define ps8Byte		s64*
+
+#define UCHAR u8
+#define USHORT u16
+#define UINT u32
+#define ULONG u32
+#define PULONG u32*
+
 #endif
 
 
@@ -123,7 +154,7 @@
 
 	typedef signed int s32;
 	typedef unsigned int u32;
-	
+
 	typedef unsigned int	uint;
 	typedef	signed int		sint;
 	typedef long atomic_t;
@@ -135,26 +166,26 @@
 	#define VOID void
 	#define NDIS_OID uint
 	#define NDIS_STATUS uint
-	
+
 	#ifndef	PVOID
-	typedef void * PVOID;
-	//#define PVOID	(void *)
+		typedef void *PVOID;
+		/* #define PVOID	(void *) */
 	#endif
 	typedef u32 dma_addr_t;
-    #define UCHAR u8
+	#define UCHAR u8
 	#define USHORT u16
 	#define UINT u32
-	#define ULONG u32	
-
-	typedef void (*proc_t)(void*);
-  
-  typedef unsigned int __kernel_size_t;
-  typedef int __kernel_ssize_t;
-  
-	typedef 	__kernel_size_t	SIZE_T;	
+	#define ULONG u32
+
+	typedef void (*proc_t)(void *);
+
+	typedef unsigned int __kernel_size_t;
+	typedef int __kernel_ssize_t;
+
+	typedef	__kernel_size_t	SIZE_T;
 	typedef	__kernel_ssize_t	SSIZE_T;
-	#define FIELD_OFFSET(s,field)	((SSIZE_T)&((s*)(0))->field)
-	
+	#define FIELD_OFFSET(s, field)	((SSIZE_T)&((s *)(0))->field)
+
 #endif
 
 #define MEM_ALIGNMENT_OFFSET	(sizeof (SIZE_T))
@@ -209,16 +240,16 @@
 /*
 * Write host byte order data to memory in LE order
 */
-#define WriteLE4Byte(_ptr, _val)	(*((u32 *)(_ptr))) = cpu_to_le32(_val)
-#define WriteLE2Byte(_ptr, _val)	(*((u16 *)(_ptr))) = cpu_to_le16(_val)
-#define WriteLE1Byte(_ptr, _val)	(*((u8 *)(_ptr))) = ((u8)(_val))
+#define WriteLE4Byte(_ptr, _val)	((*((u32 *)(_ptr))) = cpu_to_le32(_val))
+#define WriteLE2Byte(_ptr, _val)	((*((u16 *)(_ptr))) = cpu_to_le16(_val))
+#define WriteLE1Byte(_ptr, _val)	((*((u8 *)(_ptr))) = ((u8)(_val)))
 
 /*
 * Write host byte order data to memory in BE order
 */
-#define WriteBE4Byte(_ptr, _val)	(*((u32 *)(_ptr))) = cpu_to_be32(_val)
-#define WriteBE2Byte(_ptr, _val)	(*((u16 *)(_ptr))) = cpu_to_be16(_val)
-#define WriteBE1Byte(_ptr, _val)	(*((u8 *)(_ptr))) = ((u8)(_val))
+#define WriteBE4Byte(_ptr, _val)	((*((u32 *)(_ptr))) = cpu_to_be32(_val))
+#define WriteBE2Byte(_ptr, _val)	((*((u16 *)(_ptr))) = cpu_to_be16(_val))
+#define WriteBE1Byte(_ptr, _val)	((*((u8 *)(_ptr))) = ((u8)(_val)))
 
 /*
 * Return 4-byte value in host byte ordering from 4-byte pointer in litten-endian system.
@@ -271,7 +302,7 @@
 	(LE_P2BYTE_TO_HOST_2BYTE(__pStart) & (~BIT_OFFSET_LEN_MASK_16(__BitOffset, __BitLen)))
 
 #define LE_BITS_CLEARED_TO_1BYTE(__pStart, __BitOffset, __BitLen) \
-	(LE_P1BYTE_TO_HOST_1BYTE(__pStart) & (~BIT_OFFSET_LEN_MASK_8(__BitOffset, __BitLen)))
+	(LE_P1BYTE_TO_HOST_1BYTE(__pStart) & ((u8)(~BIT_OFFSET_LEN_MASK_8(__BitOffset, __BitLen))))
 
 /*
 * Mask subfield (continuous bits in big-endian) of 4-byte value in BE byte oredering
@@ -370,16 +401,15 @@
 		} \
 	} while (0)
 
-// Get the N-bytes aligment offset from the current length
+/* Get the N-bytes aligment offset from the current length */
 #define N_BYTE_ALIGMENT(__Value, __Aligment) ((__Aligment == 1) ? (__Value) : (((__Value + __Aligment - 1) / __Aligment) * __Aligment))
 
-typedef unsigned char	BOOLEAN,*PBOOLEAN;
+typedef unsigned char	BOOLEAN, *PBOOLEAN, boolean;
 
-#define TEST_FLAG(__Flag,__testFlag)		(((__Flag) & (__testFlag)) != 0)
+#define TEST_FLAG(__Flag, __testFlag)		(((__Flag) & (__testFlag)) != 0)
 #define SET_FLAG(__Flag, __setFlag)			((__Flag) |= __setFlag)
 #define CLEAR_FLAG(__Flag, __clearFlag)		((__Flag) &= ~(__clearFlag))
 #define CLEAR_FLAGS(__Flag)					((__Flag) = 0)
 #define TEST_FLAGS(__Flag, __testFlags)		(((__Flag) & (__testFlags)) == (__testFlags))
 
-#endif //__BASIC_TYPES_H__
-
+#endif /* __BASIC_TYPES_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/big_endian.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/big_endian.h
index ccb31328dd28..76542f0c4867 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/big_endian.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/big_endian.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,20 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _LINUX_BYTEORDER_BIG_ENDIAN_H
 #define _LINUX_BYTEORDER_BIG_ENDIAN_H
 
 #ifndef __BIG_ENDIAN
-#define __BIG_ENDIAN 4321
+	#define __BIG_ENDIAN 4321
 #endif
 #ifndef __BIG_ENDIAN_BITFIELD
-#define __BIG_ENDIAN_BITFIELD
+	#define __BIG_ENDIAN_BITFIELD
 #endif
 
 #include <byteorder/swab.h>
@@ -63,12 +59,12 @@
 #define __le32_to_cpup(x) __swab32p((x))
 #define __cpu_to_le16p(x) __swab16p((x))
 #define __le16_to_cpup(x) __swab16p((x))
-#define __cpu_to_be64p(x) (*(__u64*)(x))
-#define __be64_to_cpup(x) (*(__u64*)(x))
-#define __cpu_to_be32p(x) (*(__u32*)(x))
-#define __be32_to_cpup(x) (*(__u32*)(x))
-#define __cpu_to_be16p(x) (*(__u16*)(x))
-#define __be16_to_cpup(x) (*(__u16*)(x))
+#define __cpu_to_be64p(x) (*(__u64 *)(x))
+#define __be64_to_cpup(x) (*(__u64 *)(x))
+#define __cpu_to_be32p(x) (*(__u32 *)(x))
+#define __be32_to_cpup(x) (*(__u32 *)(x))
+#define __cpu_to_be16p(x) (*(__u16 *)(x))
+#define __be16_to_cpup(x) (*(__u16 *)(x))
 #define __cpu_to_le64s(x) __swab64s((x))
 #define __le64_to_cpus(x) __swab64s((x))
 #define __cpu_to_le32s(x) __swab32s((x))
@@ -85,4 +81,3 @@
 #include <byteorder/generic.h>
 
 #endif /* _LINUX_BYTEORDER_BIG_ENDIAN_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/generic.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/generic.h
index 759b0c472ceb..32d424a1d7a8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/generic.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/generic.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _LINUX_BYTEORDER_GENERIC_H
 #define _LINUX_BYTEORDER_GENERIC_H
 
@@ -99,46 +95,46 @@
 
 
 #if defined(PLATFORM_LINUX) || defined(PLATFORM_WINDOWS) || defined(PLATFORM_MPIXEL) || defined(PLATFORM_FREEBSD)
-/*
- * inside the kernel, we can use nicknames;
- * outside of it, we must avoid POSIX namespace pollution...
- */
-#define cpu_to_le64 __cpu_to_le64
-#define le64_to_cpu __le64_to_cpu
-#define cpu_to_le32 __cpu_to_le32
-#define le32_to_cpu __le32_to_cpu
-#define cpu_to_le16 __cpu_to_le16
-#define le16_to_cpu __le16_to_cpu
-#define cpu_to_be64 __cpu_to_be64
-#define be64_to_cpu __be64_to_cpu
-#define cpu_to_be32 __cpu_to_be32
-#define be32_to_cpu __be32_to_cpu
-#define cpu_to_be16 __cpu_to_be16
-#define be16_to_cpu __be16_to_cpu
-#define cpu_to_le64p __cpu_to_le64p
-#define le64_to_cpup __le64_to_cpup
-#define cpu_to_le32p __cpu_to_le32p
-#define le32_to_cpup __le32_to_cpup
-#define cpu_to_le16p __cpu_to_le16p
-#define le16_to_cpup __le16_to_cpup
-#define cpu_to_be64p __cpu_to_be64p
-#define be64_to_cpup __be64_to_cpup
-#define cpu_to_be32p __cpu_to_be32p
-#define be32_to_cpup __be32_to_cpup
-#define cpu_to_be16p __cpu_to_be16p
-#define be16_to_cpup __be16_to_cpup
-#define cpu_to_le64s __cpu_to_le64s
-#define le64_to_cpus __le64_to_cpus
-#define cpu_to_le32s __cpu_to_le32s
-#define le32_to_cpus __le32_to_cpus
-#define cpu_to_le16s __cpu_to_le16s
-#define le16_to_cpus __le16_to_cpus
-#define cpu_to_be64s __cpu_to_be64s
-#define be64_to_cpus __be64_to_cpus
-#define cpu_to_be32s __cpu_to_be32s
-#define be32_to_cpus __be32_to_cpus
-#define cpu_to_be16s __cpu_to_be16s
-#define be16_to_cpus __be16_to_cpus
+	/*
+	* inside the kernel, we can use nicknames;
+	* outside of it, we must avoid POSIX namespace pollution...
+	*/
+	#define cpu_to_le64 __cpu_to_le64
+	#define le64_to_cpu __le64_to_cpu
+	#define cpu_to_le32 __cpu_to_le32
+	#define le32_to_cpu __le32_to_cpu
+	#define cpu_to_le16 __cpu_to_le16
+	#define le16_to_cpu __le16_to_cpu
+	#define cpu_to_be64 __cpu_to_be64
+	#define be64_to_cpu __be64_to_cpu
+	#define cpu_to_be32 __cpu_to_be32
+	#define be32_to_cpu __be32_to_cpu
+	#define cpu_to_be16 __cpu_to_be16
+	#define be16_to_cpu __be16_to_cpu
+	#define cpu_to_le64p __cpu_to_le64p
+	#define le64_to_cpup __le64_to_cpup
+	#define cpu_to_le32p __cpu_to_le32p
+	#define le32_to_cpup __le32_to_cpup
+	#define cpu_to_le16p __cpu_to_le16p
+	#define le16_to_cpup __le16_to_cpup
+	#define cpu_to_be64p __cpu_to_be64p
+	#define be64_to_cpup __be64_to_cpup
+	#define cpu_to_be32p __cpu_to_be32p
+	#define be32_to_cpup __be32_to_cpup
+	#define cpu_to_be16p __cpu_to_be16p
+	#define be16_to_cpup __be16_to_cpup
+	#define cpu_to_le64s __cpu_to_le64s
+	#define le64_to_cpus __le64_to_cpus
+	#define cpu_to_le32s __cpu_to_le32s
+	#define le32_to_cpus __le32_to_cpus
+	#define cpu_to_le16s __cpu_to_le16s
+	#define le16_to_cpus __le16_to_cpus
+	#define cpu_to_be64s __cpu_to_be64s
+	#define be64_to_cpus __be64_to_cpus
+	#define cpu_to_be32s __cpu_to_be32s
+	#define be32_to_cpus __be32_to_cpus
+	#define cpu_to_be16s __cpu_to_be16s
+	#define be16_to_cpus __be16_to_cpus
 #endif
 
 
@@ -165,49 +161,48 @@
  * Do the prototypes. Somebody might want to take the
  * address or some such sick thing..
  */
-#if defined(PLATFORM_LINUX) || (defined (__GLIBC__) && __GLIBC__ >= 2)
-extern __u32			ntohl(__u32);
-extern __u32			htonl(__u32);
-#else //defined(PLATFORM_LINUX) || (defined (__GLIBC__) && __GLIBC__ >= 2)
-#ifndef PLATFORM_FREEBSD
-extern unsigned long int	ntohl(unsigned long int);
-extern unsigned long int	htonl(unsigned long int);
-#endif
+#if defined(PLATFORM_LINUX) || (defined(__GLIBC__) && __GLIBC__ >= 2)
+	extern __u32			ntohl(__u32);
+	extern __u32			htonl(__u32);
+#else /* defined(PLATFORM_LINUX) || (defined (__GLIBC__) && __GLIBC__ >= 2) */
+	#ifndef PLATFORM_FREEBSD
+		extern unsigned long int	ntohl(unsigned long int);
+		extern unsigned long int	htonl(unsigned long int);
+	#endif
 #endif
 #ifndef PLATFORM_FREEBSD
-extern unsigned short int	ntohs(unsigned short int);
-extern unsigned short int	htons(unsigned short int);
+	extern unsigned short int	ntohs(unsigned short int);
+	extern unsigned short int	htons(unsigned short int);
 #endif
 
-#if defined(__GNUC__) && (__GNUC__ >= 2) && defined(__OPTIMIZE__) ||  defined(PLATFORM_MPIXEL)
+#if defined(__GNUC__) && (__GNUC__ >= 2) && defined(__OPTIMIZE__) || defined(PLATFORM_MPIXEL)
 
-#define ___htonl(x) __cpu_to_be32(x)
-#define ___htons(x) __cpu_to_be16(x)
-#define ___ntohl(x) __be32_to_cpu(x)
-#define ___ntohs(x) __be16_to_cpu(x)
+	#define ___htonl(x) __cpu_to_be32(x)
+	#define ___htons(x) __cpu_to_be16(x)
+	#define ___ntohl(x) __be32_to_cpu(x)
+	#define ___ntohs(x) __be16_to_cpu(x)
 
-#if defined(PLATFORM_LINUX) || (defined (__GLIBC__) && __GLIBC__ >= 2)
-#define htonl(x) ___htonl(x)
-#define ntohl(x) ___ntohl(x)
-#else
-#define htonl(x) ((unsigned long)___htonl(x))
-#define ntohl(x) ((unsigned long)___ntohl(x))
-#endif
-#define htons(x) ___htons(x)
-#define ntohs(x) ___ntohs(x)
+	#if defined(PLATFORM_LINUX) || (defined(__GLIBC__) && __GLIBC__ >= 2)
+		#define htonl(x) ___htonl(x)
+		#define ntohl(x) ___ntohl(x)
+	#else
+		#define htonl(x) ((unsigned long)___htonl(x))
+		#define ntohl(x) ((unsigned long)___ntohl(x))
+	#endif
+	#define htons(x) ___htons(x)
+	#define ntohs(x) ___ntohs(x)
 
 #endif /* OPTIMIZE */
 
 
-#if defined (PLATFORM_WINDOWS)
+#if defined(PLATFORM_WINDOWS)
 
-#define htonl(x) __cpu_to_be32(x)
-#define ntohl(x) __be32_to_cpu(x)
-#define htons(x) __cpu_to_be16(x)
-#define ntohs(x) __be16_to_cpu(x)
+	#define htonl(x) __cpu_to_be32(x)
+	#define ntohl(x) __be32_to_cpu(x)
+	#define htons(x) __cpu_to_be16(x)
+	#define ntohs(x) __be16_to_cpu(x)
 
 
 #endif
 
 #endif /* _LINUX_BYTEORDER_GENERIC_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/little_endian.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/little_endian.h
index 5a3c8ab484ec..1f9287f205ad 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/little_endian.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/little_endian.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,80 +12,74 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _LINUX_BYTEORDER_LITTLE_ENDIAN_H
 #define _LINUX_BYTEORDER_LITTLE_ENDIAN_H
 
 #ifndef __LITTLE_ENDIAN
-#define __LITTLE_ENDIAN 1234
+	#define __LITTLE_ENDIAN 1234
 #endif
 #ifndef __LITTLE_ENDIAN_BITFIELD
-#define __LITTLE_ENDIAN_BITFIELD
+	#define __LITTLE_ENDIAN_BITFIELD
 #endif
 
 #include <byteorder/swab.h>
 
 #ifndef __constant_htonl
-#define __constant_htonl(x) ___constant_swab32((x))
-#define __constant_ntohl(x) ___constant_swab32((x))
-#define __constant_htons(x) ___constant_swab16((x))
-#define __constant_ntohs(x) ___constant_swab16((x))
-#define __constant_cpu_to_le64(x) ((__u64)(x))
-#define __constant_le64_to_cpu(x) ((__u64)(x))
-#define __constant_cpu_to_le32(x) ((__u32)(x))
-#define __constant_le32_to_cpu(x) ((__u32)(x))
-#define __constant_cpu_to_le16(x) ((__u16)(x))
-#define __constant_le16_to_cpu(x) ((__u16)(x))
-#define __constant_cpu_to_be64(x) ___constant_swab64((x))
-#define __constant_be64_to_cpu(x) ___constant_swab64((x))
-#define __constant_cpu_to_be32(x) ___constant_swab32((x))
-#define __constant_be32_to_cpu(x) ___constant_swab32((x))
-#define __constant_cpu_to_be16(x) ___constant_swab16((x))
-#define __constant_be16_to_cpu(x) ___constant_swab16((x))
-#define __cpu_to_le64(x) ((__u64)(x))
-#define __le64_to_cpu(x) ((__u64)(x))
-#define __cpu_to_le32(x) ((__u32)(x))
-#define __le32_to_cpu(x) ((__u32)(x))
-#define __cpu_to_le16(x) ((__u16)(x))
-#define __le16_to_cpu(x) ((__u16)(x))
-#define __cpu_to_be64(x) __swab64((x))
-#define __be64_to_cpu(x) __swab64((x))
-#define __cpu_to_be32(x) __swab32((x))
-#define __be32_to_cpu(x) __swab32((x))
-#define __cpu_to_be16(x) __swab16((x))
-#define __be16_to_cpu(x) __swab16((x))
-#define __cpu_to_le64p(x) (*(__u64*)(x))
-#define __le64_to_cpup(x) (*(__u64*)(x))
-#define __cpu_to_le32p(x) (*(__u32*)(x))
-#define __le32_to_cpup(x) (*(__u32*)(x))
-#define __cpu_to_le16p(x) (*(__u16*)(x))
-#define __le16_to_cpup(x) (*(__u16*)(x))
-#define __cpu_to_be64p(x) __swab64p((x))
-#define __be64_to_cpup(x) __swab64p((x))
-#define __cpu_to_be32p(x) __swab32p((x))
-#define __be32_to_cpup(x) __swab32p((x))
-#define __cpu_to_be16p(x) __swab16p((x))
-#define __be16_to_cpup(x) __swab16p((x))
-#define __cpu_to_le64s(x) do {} while (0)
-#define __le64_to_cpus(x) do {} while (0)
-#define __cpu_to_le32s(x) do {} while (0)
-#define __le32_to_cpus(x) do {} while (0)
-#define __cpu_to_le16s(x) do {} while (0)
-#define __le16_to_cpus(x) do {} while (0)
-#define __cpu_to_be64s(x) __swab64s((x))
-#define __be64_to_cpus(x) __swab64s((x))
-#define __cpu_to_be32s(x) __swab32s((x))
-#define __be32_to_cpus(x) __swab32s((x))
-#define __cpu_to_be16s(x) __swab16s((x))
-#define __be16_to_cpus(x) __swab16s((x))
-#endif	// __constant_htonl
+	#define __constant_htonl(x) ___constant_swab32((x))
+	#define __constant_ntohl(x) ___constant_swab32((x))
+	#define __constant_htons(x) ___constant_swab16((x))
+	#define __constant_ntohs(x) ___constant_swab16((x))
+	#define __constant_cpu_to_le64(x) ((__u64)(x))
+	#define __constant_le64_to_cpu(x) ((__u64)(x))
+	#define __constant_cpu_to_le32(x) ((__u32)(x))
+	#define __constant_le32_to_cpu(x) ((__u32)(x))
+	#define __constant_cpu_to_le16(x) ((__u16)(x))
+	#define __constant_le16_to_cpu(x) ((__u16)(x))
+	#define __constant_cpu_to_be64(x) ___constant_swab64((x))
+	#define __constant_be64_to_cpu(x) ___constant_swab64((x))
+	#define __constant_cpu_to_be32(x) ___constant_swab32((x))
+	#define __constant_be32_to_cpu(x) ___constant_swab32((x))
+	#define __constant_cpu_to_be16(x) ___constant_swab16((x))
+	#define __constant_be16_to_cpu(x) ___constant_swab16((x))
+	#define __cpu_to_le64(x) ((__u64)(x))
+	#define __le64_to_cpu(x) ((__u64)(x))
+	#define __cpu_to_le32(x) ((__u32)(x))
+	#define __le32_to_cpu(x) ((__u32)(x))
+	#define __cpu_to_le16(x) ((__u16)(x))
+	#define __le16_to_cpu(x) ((__u16)(x))
+	#define __cpu_to_be64(x) __swab64((x))
+	#define __be64_to_cpu(x) __swab64((x))
+	#define __cpu_to_be32(x) __swab32((x))
+	#define __be32_to_cpu(x) __swab32((x))
+	#define __cpu_to_be16(x) __swab16((x))
+	#define __be16_to_cpu(x) __swab16((x))
+	#define __cpu_to_le64p(x) (*(__u64 *)(x))
+	#define __le64_to_cpup(x) (*(__u64 *)(x))
+	#define __cpu_to_le32p(x) (*(__u32 *)(x))
+	#define __le32_to_cpup(x) (*(__u32 *)(x))
+	#define __cpu_to_le16p(x) (*(__u16 *)(x))
+	#define __le16_to_cpup(x) (*(__u16 *)(x))
+	#define __cpu_to_be64p(x) __swab64p((x))
+	#define __be64_to_cpup(x) __swab64p((x))
+	#define __cpu_to_be32p(x) __swab32p((x))
+	#define __be32_to_cpup(x) __swab32p((x))
+	#define __cpu_to_be16p(x) __swab16p((x))
+	#define __be16_to_cpup(x) __swab16p((x))
+	#define __cpu_to_le64s(x) do {} while (0)
+	#define __le64_to_cpus(x) do {} while (0)
+	#define __cpu_to_le32s(x) do {} while (0)
+	#define __le32_to_cpus(x) do {} while (0)
+	#define __cpu_to_le16s(x) do {} while (0)
+	#define __le16_to_cpus(x) do {} while (0)
+	#define __cpu_to_be64s(x) __swab64s((x))
+	#define __be64_to_cpus(x) __swab64s((x))
+	#define __cpu_to_be32s(x) __swab32s((x))
+	#define __be32_to_cpus(x) __swab32s((x))
+	#define __cpu_to_be16s(x) __swab16s((x))
+	#define __be16_to_cpus(x) __swab16s((x))
+#endif /* __constant_htonl */
 
 #include <byteorder/generic.h>
 
 #endif /* _LINUX_BYTEORDER_LITTLE_ENDIAN_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swab.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swab.h
index 067c8e434a1f..8c3eb866c0be 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swab.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swab.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,69 +12,65 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _LINUX_BYTEORDER_SWAB_H
 #define _LINUX_BYTEORDER_SWAB_H
 
 #if !defined(CONFIG_PLATFORM_MSTAR)
 #ifndef __u16
-typedef unsigned short __u16;
+	typedef unsigned short __u16;
 #endif
 
 #ifndef __u32
-typedef unsigned int	__u32;
+	typedef unsigned int	__u32;
 #endif
 
 #ifndef __u8
-typedef unsigned char __u8;
+	typedef unsigned char __u8;
 #endif
 
 #ifndef __u64
-typedef unsigned long long	__u64;	
+	typedef unsigned long long	__u64;
 #endif
 
 
 __inline static __u16  ___swab16(__u16 x)
 {
-	__u16 __x = x; 
-	return 
-	((__u16)( 
-		(((__u16)(__x) & (__u16)0x00ffU) << 8) |
-		(((__u16)(__x) & (__u16)0xff00U) >> 8) ));
+	__u16 __x = x;
+	return
+		 (__u16)(
+			 (((__u16)(__x)&(__u16)0x00ffU) << 8) |
+			 (((__u16)(__x)&(__u16)0xff00U) >> 8));
 
 }
 
 __inline static __u32  ___swab32(__u32 x)
 {
 	__u32 __x = (x);
-	return ((__u32)(
-		(((__u32)(__x) & (__u32)0x000000ffUL) << 24) |
-		(((__u32)(__x) & (__u32)0x0000ff00UL) <<  8) |
-		(((__u32)(__x) & (__u32)0x00ff0000UL) >>  8) |
-		(((__u32)(__x) & (__u32)0xff000000UL) >> 24) ));
+	return  (__u32)(
+			(((__u32)(__x)&(__u32)0x000000ffUL) << 24) |
+			(((__u32)(__x)&(__u32)0x0000ff00UL) <<  8) |
+			(((__u32)(__x)&(__u32)0x00ff0000UL) >>  8) |
+			(((__u32)(__x)&(__u32)0xff000000UL) >> 24));
 }
 
 __inline static __u64  ___swab64(__u64 x)
 {
 	__u64 __x = (x);
-	
-	return 
-	((__u64)( \
-		(__u64)(((__u64)(__x) & (__u64)0x00000000000000ffULL) << 56) | \
-		(__u64)(((__u64)(__x) & (__u64)0x000000000000ff00ULL) << 40) | \
-		(__u64)(((__u64)(__x) & (__u64)0x0000000000ff0000ULL) << 24) | \
-		(__u64)(((__u64)(__x) & (__u64)0x00000000ff000000ULL) <<  8) | \
-	        (__u64)(((__u64)(__x) & (__u64)0x000000ff00000000ULL) >>  8) | \
-		(__u64)(((__u64)(__x) & (__u64)0x0000ff0000000000ULL) >> 24) | \
-		(__u64)(((__u64)(__x) & (__u64)0x00ff000000000000ULL) >> 40) | \
-		(__u64)(((__u64)(__x) & (__u64)0xff00000000000000ULL) >> 56) )); \
+
+	return
+		 (__u64)(\
+		 (__u64)(((__u64)(__x)&(__u64)0x00000000000000ffULL) << 56) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x000000000000ff00ULL) << 40) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x0000000000ff0000ULL) << 24) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x00000000ff000000ULL) <<  8) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x000000ff00000000ULL) >>  8) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x0000ff0000000000ULL) >> 24) | \
+		 (__u64)(((__u64)(__x)&(__u64)0x00ff000000000000ULL) >> 40) | \
+		 (__u64)(((__u64)(__x)&(__u64)0xff00000000000000ULL) >> 56));
+	\
 }
-#endif // CONFIG_PLATFORM_MSTAR
+#endif /* CONFIG_PLATFORM_MSTAR */
 
 #ifndef __arch__swab16
 __inline static __u16 __arch__swab16(__u16 x)
@@ -86,7 +83,7 @@ __inline static __u16 __arch__swab16(__u16 x)
 #ifndef __arch__swab32
 __inline static __u32 __arch__swab32(__u32 x)
 {
-	__u32 __tmp = (x) ; 
+	__u32 __tmp = (x) ;
 	return ___swab32(__tmp);
 }
 #endif
@@ -95,7 +92,7 @@ __inline static __u32 __arch__swab32(__u32 x)
 
 __inline static __u64 __arch__swab64(__u64 x)
 {
-	__u64 __tmp = (x) ; 
+	__u64 __tmp = (x) ;
 	return ___swab64(__tmp);
 }
 
@@ -103,39 +100,38 @@ __inline static __u64 __arch__swab64(__u64 x)
 #endif
 
 #ifndef __swab16
-#define __swab16(x) __fswab16(x)
-#define __swab32(x) __fswab32(x)
-#define __swab64(x) __fswab64(x)
-#endif	// __swab16
+	#define __swab16(x) __fswab16(x)
+	#define __swab32(x) __fswab32(x)
+	#define __swab64(x) __fswab64(x)
+#endif /* __swab16 */
 
 #ifdef PLATFORM_FREEBSD
-__inline static __u16 __fswab16(__u16 x)
+	__inline static __u16 __fswab16(__u16 x)
 #else
-__inline static const __u16 __fswab16(__u16 x)
-#endif //PLATFORM_FREEBSD
+	__inline static const __u16 __fswab16(__u16 x)
+#endif /* PLATFORM_FREEBSD */
 {
 	return __arch__swab16(x);
 }
 #ifdef PLATFORM_FREEBSD
-__inline static __u32 __fswab32(__u32 x)
+	__inline static __u32 __fswab32(__u32 x)
 #else
-__inline static const __u32 __fswab32(__u32 x)
-#endif //PLATFORM_FREEBSD
+	__inline static const __u32 __fswab32(__u32 x)
+#endif /* PLATFORM_FREEBSD */
 {
 	return __arch__swab32(x);
 }
 
 #if defined(PLATFORM_LINUX) || defined(PLATFORM_WINDOWS)
-#define swab16 __swab16
-#define swab32 __swab32
-#define swab64 __swab64
-#define swab16p __swab16p
-#define swab32p __swab32p
-#define swab64p __swab64p
-#define swab16s __swab16s
-#define swab32s __swab32s
-#define swab64s __swab64s
+	#define swab16 __swab16
+	#define swab32 __swab32
+	#define swab64 __swab64
+	#define swab16p __swab16p
+	#define swab32p __swab32p
+	#define swab64p __swab64p
+	#define swab16s __swab16s
+	#define swab32s __swab32s
+	#define swab64s __swab64s
 #endif
 
 #endif /* _LINUX_BYTEORDER_SWAB_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swabb.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swabb.h
index dbbd50f89206..2e6b196051f9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swabb.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/byteorder/swabb.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _LINUX_BYTEORDER_SWABB_H
 #define _LINUX_BYTEORDER_SWABB_H
 
@@ -45,51 +41,51 @@
  */
 
 #define ___swahw32(x) \
-({ \
-	__u32 __x = (x); \
-	((__u32)( \
-		(((__u32)(__x) & (__u32)0x0000ffffUL) << 16) | \
-		(((__u32)(__x) & (__u32)0xffff0000UL) >> 16) )); \
-})
+	({ \
+		__u32 __x = (x); \
+		((__u32)(\
+			 (((__u32)(__x) & (__u32)0x0000ffffUL) << 16) | \
+			 (((__u32)(__x) & (__u32)0xffff0000UL) >> 16))); \
+	})
 #define ___swahb32(x) \
-({ \
-	__u32 __x = (x); \
-	((__u32)( \
-		(((__u32)(__x) & (__u32)0x00ff00ffUL) << 8) | \
-		(((__u32)(__x) & (__u32)0xff00ff00UL) >> 8) )); \
-})
+	({ \
+		__u32 __x = (x); \
+		((__u32)(\
+			 (((__u32)(__x) & (__u32)0x00ff00ffUL) << 8) | \
+			 (((__u32)(__x) & (__u32)0xff00ff00UL) >> 8))); \
+	})
 
 #define ___constant_swahw32(x) \
-	((__u32)( \
-		(((__u32)(x) & (__u32)0x0000ffffUL) << 16) | \
-		(((__u32)(x) & (__u32)0xffff0000UL) >> 16) ))
+	((__u32)(\
+		 (((__u32)(x) & (__u32)0x0000ffffUL) << 16) | \
+		 (((__u32)(x) & (__u32)0xffff0000UL) >> 16)))
 #define ___constant_swahb32(x) \
-	((__u32)( \
-		(((__u32)(x) & (__u32)0x00ff00ffUL) << 8) | \
-		(((__u32)(x) & (__u32)0xff00ff00UL) >> 8) ))
+	((__u32)(\
+		 (((__u32)(x) & (__u32)0x00ff00ffUL) << 8) | \
+		 (((__u32)(x) & (__u32)0xff00ff00UL) >> 8)))
 
 /*
  * provide defaults when no architecture-specific optimization is detected
  */
 #ifndef __arch__swahw32
-#  define __arch__swahw32(x) ___swahw32(x)
+	#define __arch__swahw32(x) ___swahw32(x)
 #endif
 #ifndef __arch__swahb32
-#  define __arch__swahb32(x) ___swahb32(x)
+	#define __arch__swahb32(x) ___swahb32(x)
 #endif
 
 #ifndef __arch__swahw32p
-#  define __arch__swahw32p(x) __swahw32(*(x))
+	#define __arch__swahw32p(x) __swahw32(*(x))
 #endif
 #ifndef __arch__swahb32p
-#  define __arch__swahb32p(x) __swahb32(*(x))
+	#define __arch__swahb32p(x) __swahb32(*(x))
 #endif
 
 #ifndef __arch__swahw32s
-#  define __arch__swahw32s(x) do { *(x) = __swahw32p((x)); } while (0)
+	#define __arch__swahw32s(x) do { *(x) = __swahw32p((x)); } while (0)
 #endif
 #ifndef __arch__swahb32s
-#  define __arch__swahb32s(x) do { *(x) = __swahb32p((x)); } while (0)
+	#define __arch__swahb32s(x) do { *(x) = __swahb32p((x)); } while (0)
 #endif
 
 
@@ -98,13 +94,13 @@
  */
 #if defined(__GNUC__) && (__GNUC__ >= 2) && defined(__OPTIMIZE__)
 #  define __swahw32(x) \
-(__builtin_constant_p((__u32)(x)) ? \
- ___swahw32((x)) : \
- __fswahw32((x)))
+	(__builtin_constant_p((__u32)(x)) ? \
+	 ___swahw32((x)) : \
+	 __fswahw32((x)))
 #  define __swahb32(x) \
-(__builtin_constant_p((__u32)(x)) ? \
- ___swahb32((x)) : \
- __fswahb32((x)))
+	(__builtin_constant_p((__u32)(x)) ? \
+	 ___swahb32((x)) : \
+	 __fswahb32((x)))
 #else
 #  define __swahw32(x) __fswahw32(x)
 #  define __swahb32(x) __fswahb32(x)
@@ -139,19 +135,18 @@ __inline static__ void __swahb32s(__u32 *addr)
 }
 
 #ifdef __BYTEORDER_HAS_U64__
-/*
- * Not supported yet
- */
+	/*
+	* Not supported yet
+	*/
 #endif /* __BYTEORDER_HAS_U64__ */
 
 #if defined(PLATFORM_LINUX)
-#define swahw32 __swahw32
-#define swahb32 __swahb32
-#define swahw32p __swahw32p
-#define swahb32p __swahb32p
-#define swahw32s __swahw32s
-#define swahb32s __swahb32s
+	#define swahw32 __swahw32
+	#define swahb32 __swahb32
+	#define swahw32p __swahw32p
+	#define swahb32p __swahb32p
+	#define swahw32s __swahw32s
+	#define swahb32s __swahb32s
 #endif
 
 #endif /* _LINUX_BYTEORDER_SWABB_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/circ_buf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/circ_buf.h
index 23523164cd36..cccb0602e27d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/circ_buf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/circ_buf.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __CIRC_BUF_H_
 #define __CIRC_BUF_H_ 1
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/cmd_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/cmd_osdep.h
index 65a7253b3318..c98ba148679e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/cmd_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/cmd_osdep.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,22 +12,16 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __CMD_OSDEP_H_
 #define __CMD_OSDEP_H_
 
 
-extern sint _rtw_init_cmd_priv (struct	cmd_priv *pcmdpriv);
+extern sint _rtw_init_cmd_priv(struct	cmd_priv *pcmdpriv);
 extern sint _rtw_init_evt_priv(struct evt_priv *pevtpriv);
-extern void _rtw_free_evt_priv (struct	evt_priv *pevtpriv);
-extern void _rtw_free_cmd_priv (struct	cmd_priv *pcmdpriv);
+extern void _rtw_free_evt_priv(struct	evt_priv *pevtpriv);
+extern void _rtw_free_cmd_priv(struct	cmd_priv *pcmdpriv);
 extern sint _rtw_enqueue_cmd(_queue *queue, struct cmd_obj *obj, bool to_head);
 extern struct cmd_obj *_rtw_dequeue_cmd(_queue *queue);
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/cmn_info/rtw_sta_info.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/cmn_info/rtw_sta_info.h
new file mode 100644
index 000000000000..234064c57336
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/cmn_info/rtw_sta_info.h
@@ -0,0 +1,254 @@
+/* SPDX-License-Identifier: GPL-2.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.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
+ *
+ *
+ ******************************************************************************/
+
+ /*This header file is for all driver teams to use the same station info.
+If you want to change this file please make sure notify all driver teams maintainers.*/
+
+/*Created by YuChen 20170301*/
+
+#ifndef __INC_RTW_STA_INFO_H
+#define __INC_RTW_STA_INFO_H
+
+/*--------------------Define ---------------------------------------*/
+
+#define STA_DM_CTRL_ACTIVE			BIT(0)
+#define STA_DM_CTRL_CFO_TRACKING	BIT(1)
+
+#ifdef CONFIG_BEAMFORMING
+#define	BEAMFORMING_HT_BEAMFORMER_ENABLE	BIT(0)	/*Declare sta support beamformer*/
+#define	BEAMFORMING_HT_BEAMFORMEE_ENABLE	BIT(1)	/*Declare sta support beamformee*/
+#define	BEAMFORMING_HT_BEAMFORMER_TEST		BIT(2)	/*Transmiting Beamforming no matter the target supports it or not*/
+#define	BEAMFORMING_HT_BEAMFORMER_STEER_NUM		(BIT(4)|BIT(5))		/*Sta Bfer's capability*/
+#define	BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP	(BIT(6)|BIT(7))		/*Sta BFee's capability*/
+
+#define	BEAMFORMING_VHT_BEAMFORMER_ENABLE	BIT(0)	/*Declare sta support beamformer*/
+#define	BEAMFORMING_VHT_BEAMFORMEE_ENABLE	BIT(1)	/*Declare sta support beamformee*/
+#define	BEAMFORMING_VHT_MU_MIMO_AP_ENABLE	BIT(2)	/*Declare sta support MU beamformer*/
+#define	BEAMFORMING_VHT_MU_MIMO_STA_ENABLE	BIT(3)	/*Declare sta support MU beamformer*/
+#define	BEAMFORMING_VHT_BEAMFORMER_TEST		BIT(4)	/*Transmiting Beamforming no matter the target supports it or not*/
+#define	BEAMFORMING_VHT_BEAMFORMER_STS_CAP		(BIT(8)|BIT(9)|BIT(10))		/*Sta BFee's capability*/
+#define	BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM	(BIT(12)|BIT(13)|BIT(14))	/*Sta Bfer's capability*/
+#endif
+
+#define HT_STBC_EN	BIT(0)
+#define VHT_STBC_EN	BIT(1)
+
+#define HT_LDPC_EN	BIT(0)
+#define VHT_LDPC_EN	BIT(1)
+
+#define	SM_PS_STATIC	0
+#define	SM_PS_DYNAMIC	1
+#define	SM_PS_INVALID	2
+#define	SM_PS_DISABLE	3
+
+
+/*cmn_sta_info.ra_sta_info.txrx_state*/
+#define	TX_STATE				0
+#define	RX_STATE				1
+#define	BI_DIRECTION_STATE	2
+
+/*--------------------Define Enum-----------------------------------*/
+enum channel_width {
+	CHANNEL_WIDTH_20		= 0,
+	CHANNEL_WIDTH_40		= 1,
+	CHANNEL_WIDTH_80		= 2,
+	CHANNEL_WIDTH_160		= 3,
+	CHANNEL_WIDTH_80_80	= 4,
+	CHANNEL_WIDTH_5		= 5,
+	CHANNEL_WIDTH_10	= 6,
+	CHANNEL_WIDTH_MAX	= 7,
+};
+
+enum rf_type {
+	RF_1T1R			= 0,
+	RF_1T2R			= 1,
+	RF_2T2R			= 2,
+	RF_2T3R			= 3,
+	RF_2T4R			= 4,
+	RF_3T3R			= 5,
+	RF_3T4R			= 6,
+	RF_4T4R			= 7,
+	RF_TYPE_MAX,
+};
+
+enum bb_path {
+	BB_PATH_A = 0x00000001,
+	BB_PATH_B = 0x00000002,
+	BB_PATH_C = 0x00000004,
+	BB_PATH_D = 0x00000008,
+
+	BB_PATH_AB = (BB_PATH_A | BB_PATH_B),
+	BB_PATH_AC = (BB_PATH_A | BB_PATH_C),
+	BB_PATH_AD = (BB_PATH_A | BB_PATH_D),
+	BB_PATH_BC = (BB_PATH_B | BB_PATH_C),
+	BB_PATH_BD = (BB_PATH_B | BB_PATH_D),
+	BB_PATH_CD = (BB_PATH_C | BB_PATH_D),
+
+	BB_PATH_ABC = (BB_PATH_A | BB_PATH_B | BB_PATH_C),
+	BB_PATH_ABD = (BB_PATH_A | BB_PATH_B | BB_PATH_D),
+	BB_PATH_ACD = (BB_PATH_A | BB_PATH_C | BB_PATH_D),
+	BB_PATH_BCD = (BB_PATH_B | BB_PATH_C | BB_PATH_D),
+
+	BB_PATH_ABCD = (BB_PATH_A | BB_PATH_B | BB_PATH_C | BB_PATH_D),
+};
+
+enum rf_path {
+	RF_PATH_A = 0,
+	RF_PATH_B = 1,
+	RF_PATH_C = 2,
+	RF_PATH_D = 3,
+	RF_PATH_AB,
+	RF_PATH_AC,
+	RF_PATH_AD,
+	RF_PATH_BC,
+	RF_PATH_BD,
+	RF_PATH_CD,
+	RF_PATH_ABC,
+	RF_PATH_ACD,
+	RF_PATH_BCD,
+	RF_PATH_ABCD,
+};
+
+enum wireless_set {
+	WIRELESS_CCK	= 0x00000001,
+	WIRELESS_OFDM	= 0x00000002,
+	WIRELESS_HT	= 0x00000004,
+	WIRELESS_VHT	= 0x00000008,
+};
+
+/*--------------------Define MACRO---------------------------------*/
+
+/*--------------------Define Struct-----------------------------------*/
+
+#ifdef CONFIG_BEAMFORMING
+struct bf_cmn_info {
+	u8	ht_beamform_cap;		/*Sta capablity*/
+	u16	vht_beamform_cap;		/*Sta capablity*/
+	u16	p_aid;
+	u8	g_id;
+};
+#endif
+struct rssi_info {
+	s8		rssi;
+	s8		rssi_cck;
+	s8		rssi_ofdm;
+	u8		packet_map;
+	u8		ofdm_pkt_cnt;
+	u8		cck_pkt_cnt;
+	u16		cck_sum_power;
+	u8		is_send_rssi;
+	u8		valid_bit;
+	s16		rssi_acc;	/*accumulate RSSI for per packet MA sum*/
+};
+
+struct ra_sta_info {
+	u8	rate_id;			/*ratr_idx*/
+	u8	rssi_level;
+
+	/*New*/
+	u8	is_first_connect:1;	/*CE: ra_rpt_linked, AP: H2C_rssi_rpt*/
+	u8	is_support_sgi:1;	/*driver*/
+	u8	is_vht_enable:2;		/*driver*/
+	u8	disable_ra:1;		/*driver*/
+	u8	disable_pt:1;		/*driver*/  /*remove is_disable_power_training*/
+	u8	txrx_state:2;		/*0: Tx, 1:Rx, 2:bi-direction*/
+	u8	is_noisy:1;
+	
+	u8 curr_tx_rate;					/*FW->Driver*/
+	enum channel_width	ra_bw_mode;	/*max bandwidth, for RA only*/
+	enum channel_width	curr_tx_bw;    /*FW->Driver*/
+	u8 curr_retry_ratio;				/*FW->Driver*/
+
+	u64	ramask;
+};
+
+struct dtp_info {
+	u8	dyn_tx_power;	/*Dynamic Tx power offset*/
+	u8	sta_tx_high_power_lvl:4;
+	u8	sta_last_dtp_lvl:4;
+};
+
+struct cmn_sta_info {
+	u16	dm_ctrl;
+	enum channel_width	bw_mode;	/*max bandwidth*/
+	u8	mac_id;
+	u8	mac_addr[6];
+	u16	aid;
+	enum rf_type mimo_type;		/*sta XTXR*/
+	struct rssi_info	rssi_stat;
+	struct ra_sta_info	ra_info;
+	u16	tx_moving_average_tp;	/*tx average MBps*/
+	u16	rx_moving_average_tp;	/*rx average MBps*/
+	u8	stbc_en:2;		/*Driver : really use stbc!!*/
+	u8	ldpc_en:2;
+	enum wireless_set	support_wireless_set;
+#ifdef CONFIG_BEAMFORMING
+	struct bf_cmn_info	bf_info;
+#endif
+	u8	sm_ps:2;
+	struct dtp_info dtp_stat;	/*Dynamic Tx power offset*/
+	/*u8		pw2cca_over_TH_cnt;*/
+	/*u8		total_pw2cca_cnt;*/
+};
+
+struct phydm_phyinfo_struct {
+	u8		rx_pwdb_all;
+	u8		signal_quality;				/* OFDM: signal_quality=rx_mimo_signal_quality[0], CCK: signal qualityin 0-100 index. */
+	u8		rx_mimo_signal_strength[4];	/* RSSI in 0~100 index */
+	s8		rx_mimo_signal_quality[4];		/* OFDM: per-path's EVM translate to 0~100% , no used for CCK*/
+	u8		rx_mimo_evm_dbm[4];			/* per-path's original EVM (dbm) */
+	s16		cfo_short[4];					/* per-path's cfo_short */
+	s16		cfo_tail[4];					/* per-path's cfo_tail */
+	s8		rx_power;					/* in dBm Translate from PWdB */
+	s8		recv_signal_power;			/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. */
+	u8		bt_rx_rssi_percentage;
+	u8		signal_strength;				/* in 0-100 index. */
+	s8		rx_pwr[4];					/* per-path's pwdb */
+	s8		rx_snr[4];					/* per-path's SNR	*/
+/*ODM_PHY_STATUS_NEW_TYPE_SUPPORT*/
+	u8		rx_count:2;					/* RX path counter---*/
+	u8		band_width:2;
+	u8		rxsc:4;						/* sub-channel---*/
+	u8		channel;						/* channel number---*/
+	u8		is_mu_packet:1;				/* is MU packet or not---boolean*/
+	u8		is_beamformed:1;				/* BF packet---boolean*/
+	u8		cnt_pw2cca;
+	u8		cnt_cca2agc_rdy;
+/*ODM_PHY_STATUS_NEW_TYPE_SUPPORT*/
+};
+
+struct phydm_perpkt_info_struct {
+	u8		data_rate;
+	u8		station_id;
+	u8		is_cck_rate: 1;
+	u8		rate_ss:3;			/*spatial stream of data rate*/
+	u8		is_packet_match_bssid:1;	/*boolean*/
+	u8		is_packet_to_self:1;		/*boolean*/
+	u8		is_packet_beacon:1;		/*boolean*/
+	u8		is_to_self:1;				/*boolean*/
+	u8		ppdu_cnt;
+};
+
+/*--------------------Export global variable----------------------------*/
+
+/*--------------------Function declaration-----------------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/custom_gpio.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/custom_gpio.h
index 5499a2d38c47..0c2597da7b33 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/custom_gpio.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/custom_gpio.h
@@ -1,4 +1,18 @@
 /* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __CUSTOM_GPIO_H__
 #define __CUSTOM_GPIO_H___
 
@@ -6,15 +20,15 @@
 #include <osdep_service.h>
 
 #ifdef PLATFORM_OS_XP
-#include <drv_types_xp.h>
+	#include <drv_types_xp.h>
 #endif
 
 #ifdef PLATFORM_OS_CE
-#include <drv_types_ce.h>
+	#include <drv_types_ce.h>
 #endif
 
 #ifdef PLATFORM_LINUX
-#include <drv_types_linux.h>
+	#include <drv_types_linux.h>
 #endif
 
 typedef enum cust_gpio_modes {
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_conf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_conf.h
index 1a93cb181d68..c5a1c1ddbd7b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_conf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_conf.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,63 +12,102 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __DRV_CONF_H__
 #define __DRV_CONF_H__
 #include "autoconf.h"
 #include "hal_ic_cfg.h"
 
-#if defined (PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
 
-#error "Shall be Linux or Windows, but not both!\n"
+	#error "Shall be Linux or Windows, but not both!\n"
 
 #endif
+#define CONFIG_RSSI_PRIORITY
+#ifdef CONFIG_RTW_REPEATER_SON
+	#ifndef CONFIG_AP
+		#define CONFIG_AP
+	#endif
+	#ifndef CONFIG_CONCURRENT_MODE
+		#define CONFIG_CONCURRENT_MODE
+	#endif
+	#ifndef CONFIG_BR_EXT
+		#define CONFIG_BR_EXT
+	#endif
+	#ifndef CONFIG_RTW_REPEATER_SON_ID
+		#define CONFIG_RTW_REPEATER_SON_ID			0x02040608
+	#endif
+	//#define CONFIG_RTW_REPEATER_SON_ROOT
+	#ifndef CONFIG_RTW_REPEATER_SON_ROOT
+		#define CONFIG_LAYER2_ROAMING_ACTIVE
+	#endif
+	#undef CONFIG_POWER_SAVING
+#endif
+
+#if defined(CONFIG_MCC_MODE) && (!defined(CONFIG_CONCURRENT_MODE))
+
+	#error "Enable CONCURRENT_MODE before enable MCC MODE\n"
 
-//Older Android kernel doesn't has CONFIG_ANDROID defined,
-//add this to force CONFIG_ANDROID defined
-#ifdef CONFIG_PLATFORM_ANDROID
-#ifndef CONFIG_ANDROID
-#define CONFIG_ANDROID
 #endif
+
+#if defined(CONFIG_MCC_MODE) && defined(CONFIG_BT_COEXIST)
+
+	#error "Disable BT COEXIST before enable MCC MODE\n"
+
+#endif
+
+#if defined(CONFIG_MCC_MODE) && defined(CONFIG_TDLS)
+
+	#error "Disable TDLS before enable MCC MODE\n"
+
+#endif
+
+#if defined(CONFIG_RTW_80211R) && !defined(CONFIG_LAYER2_ROAMING)
+
+	#error "Enable CONFIG_LAYER2_ROAMING before enable CONFIG_RTW_80211R\n"
+
+#endif
+
+/* Older Android kernel doesn't has CONFIG_ANDROID defined,
+ * add this to force CONFIG_ANDROID defined */
+#ifdef CONFIG_PLATFORM_ANDROID
+	#ifndef CONFIG_ANDROID
+		#define CONFIG_ANDROID
+	#endif
 #endif
 
 #ifdef CONFIG_ANDROID
-//Some Android build will restart the UI while non-printable ascii is passed
-//between java and c/c++ layer (JNI). We force CONFIG_VALIDATE_SSID
-//for Android here. If you are sure there is no risk on your system about this,
-//mask this macro define to support non-printable ascii ssid.
-//#define CONFIG_VALIDATE_SSID
+	/* Some Android build will restart the UI while non-printable ascii is passed
+	* between java and c/c++ layer (JNI). We force CONFIG_VALIDATE_SSID
+	* for Android here. If you are sure there is no risk on your system about this,
+	* mask this macro define to support non-printable ascii ssid.
+	* #define CONFIG_VALIDATE_SSID */
 
-//Android expect dbm as the rx signal strength unit
-#define CONFIG_SIGNAL_DISPLAY_DBM
+	/* Android expect dbm as the rx signal strength unit */
+	#define CONFIG_SIGNAL_DISPLAY_DBM
 #endif
 
 /*
-#if defined(CONFIG_HAS_EARLYSUSPEND) && defined (CONFIG_RESUME_IN_WORKQUEUE)
+#if defined(CONFIG_HAS_EARLYSUSPEND) && defined(CONFIG_RESUME_IN_WORKQUEUE)
 	#warning "You have CONFIG_HAS_EARLYSUSPEND enabled in your system, we disable CONFIG_RESUME_IN_WORKQUEUE automatically"
 	#undef CONFIG_RESUME_IN_WORKQUEUE
 #endif
 
-#if defined(CONFIG_ANDROID_POWER) && defined (CONFIG_RESUME_IN_WORKQUEUE)
+#if defined(CONFIG_ANDROID_POWER) && defined(CONFIG_RESUME_IN_WORKQUEUE)
 	#warning "You have CONFIG_ANDROID_POWER enabled in your system, we disable CONFIG_RESUME_IN_WORKQUEUE automatically"
 	#undef CONFIG_RESUME_IN_WORKQUEUE
 #endif
 */
 
-#ifdef CONFIG_RESUME_IN_WORKQUEUE //this can be removed, because there is no case for this...
-	#if !defined( CONFIG_WAKELOCK) && !defined(CONFIG_ANDROID_POWER)
-	#error "enable CONFIG_RESUME_IN_WORKQUEUE without CONFIG_WAKELOCK or CONFIG_ANDROID_POWER will suffer from the danger of wifi's unfunctionality..."
-	#error "If you still want to enable CONFIG_RESUME_IN_WORKQUEUE in this case, mask this preprossor checking and GOOD LUCK..."
+#ifdef CONFIG_RESUME_IN_WORKQUEUE /* this can be removed, because there is no case for this... */
+	#if !defined(CONFIG_WAKELOCK) && !defined(CONFIG_ANDROID_POWER)
+		#error "enable CONFIG_RESUME_IN_WORKQUEUE without CONFIG_WAKELOCK or CONFIG_ANDROID_POWER will suffer from the danger of wifi's unfunctionality..."
+		#error "If you still want to enable CONFIG_RESUME_IN_WORKQUEUE in this case, mask this preprossor checking and GOOD LUCK..."
 	#endif
 #endif
 
-//About USB VENDOR REQ
-#if defined(CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC) && !defined(CONFIG_USB_VENDOR_REQ_MUTEX) 
+/* About USB VENDOR REQ */
+#if defined(CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC) && !defined(CONFIG_USB_VENDOR_REQ_MUTEX)
 	#warning "define CONFIG_USB_VENDOR_REQ_MUTEX for CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC automatically"
 	#define CONFIG_USB_VENDOR_REQ_MUTEX
 #endif
@@ -81,10 +121,40 @@
 	#undef CONFIG_DFS_MASTER
 #endif
 
-#define DYNAMIC_CAMID_ALLOC
+#ifdef CONFIG_RTW_MESH
+	#ifndef CONFIG_RTW_MESH_OFFCH_CAND
+	#define CONFIG_RTW_MESH_OFFCH_CAND 1
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_PEER_BLACKLIST
+	#define CONFIG_RTW_MESH_PEER_BLACKLIST 1
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	#define CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST 1
+	#endif
+
+	#ifndef CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+	#define CONFIG_RTW_MPM_TX_IES_SYNC_BSS 1
+	#endif
+	#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+		#ifndef CONFIG_RTW_MESH_AEK
+		#define CONFIG_RTW_MESH_AEK
+		#endif
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	#define CONFIG_RTW_MESH_DATA_BMC_TO_UC 1
+	#endif
+#endif
+
+#if !defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_AP_MODE)
+#define CONFIG_SCAN_BACKOP
+#endif
 
 #define RTW_SCAN_SPARSE_MIRACAST 1
 #define RTW_SCAN_SPARSE_BG 0
+#define RTW_SCAN_SPARSE_ROAMING_ACTIVE 1
 
 #ifndef CONFIG_RTW_HIQ_FILTER
 	#define CONFIG_RTW_HIQ_FILTER 1
@@ -114,6 +184,14 @@
 	#define CONFIG_RTW_ADAPTIVITY_TH_EDCCA_HL_DIFF 0
 #endif
 
+#ifndef CONFIG_RTW_EXCL_CHS
+	#define CONFIG_RTW_EXCL_CHS {0}
+#endif
+
+#ifndef CONFIG_RTW_DFS_REGION_DOMAIN
+	#define CONFIG_RTW_DFS_REGION_DOMAIN 0
+#endif
+
 #ifndef CONFIG_TXPWR_BY_RATE_EN
 #define CONFIG_TXPWR_BY_RATE_EN 2 /* by efuse */
 #endif
@@ -121,6 +199,10 @@
 #define CONFIG_TXPWR_LIMIT_EN 2 /* by efuse */
 #endif
 
+#ifndef CONFIG_RTW_CHPLAN
+#define CONFIG_RTW_CHPLAN 0xFF /* RTW_CHPLAN_UNSPECIFIED */
+#endif
+
 /* compatible with old fashion configuration */
 #if defined(CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY)
 	#undef CONFIG_TXPWR_BY_RATE_EN
@@ -146,6 +228,32 @@
 	#define CONFIG_TXPWR_LIMIT_EN 1
 #endif
 
+#if !defined(CONFIG_TXPWR_LIMIT) && CONFIG_TXPWR_LIMIT_EN
+	#define CONFIG_TXPWR_LIMIT
+#endif
+
+#ifdef CONFIG_RTW_IPCAM_APPLICATION
+	#undef CONFIG_TXPWR_BY_RATE_EN
+	#define CONFIG_TXPWR_BY_RATE_EN 1
+	#define CONFIG_RTW_CUSTOMIZE_BEEDCA		0x0000431C
+	#define CONFIG_RTW_CUSTOMIZE_BWMODE		0x00
+	#define CONFIG_RTW_CUSTOMIZE_RLSTA		0x7
+#endif
+
+
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_2SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_2SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_3SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_3SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+#ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_4SS
+	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_4SS {0xFF, 0xFF, 0xFF, 0xFF}
+#endif
+
 #ifndef CONFIG_RTW_TARGET_TX_PWR_2G_A
 	#define CONFIG_RTW_TARGET_TX_PWR_2G_A {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}
 #endif
@@ -198,6 +306,48 @@
 	#define CONFIG_RTW_PLL_REF_CLK_SEL 0x0F
 #endif
 
+#ifndef CONFIG_IFACE_NUMBER
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define CONFIG_IFACE_NUMBER	2
+	#else
+		#define CONFIG_IFACE_NUMBER	1
+	#endif
+#endif
+
+#ifndef CONFIG_CONCURRENT_MODE
+	#if (CONFIG_IFACE_NUMBER > 1)
+		#error "CONFIG_IFACE_NUMBER over 1,but CONFIG_CONCURRENT_MODE not defined"
+	#endif
+#endif
+
+#if (CONFIG_IFACE_NUMBER == 0)
+	#error "CONFIG_IFACE_NUMBER cound not equel to 0 !!"
+#endif
+
+#if (CONFIG_IFACE_NUMBER > 3)
+	#error "Not support over 3 interfaces yet !!"
+#endif
+
+#if (CONFIG_IFACE_NUMBER > 8)	/*IFACE_ID_MAX*/
+	#error "HW count not support over 8 interfaces !!"
+#endif
+
+#if (CONFIG_IFACE_NUMBER > 2)
+	#define CONFIG_MI_WITH_MBSSID_CAM
+
+	#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		#define CONFIG_MBSSID_CAM
+		#if defined(CONFIG_RUNTIME_PORT_SWITCH)
+			#undef CONFIG_RUNTIME_PORT_SWITCH
+		#endif
+	#endif
+
+	#ifdef CONFIG_AP_MODE
+		#define CONFIG_SWTIMER_BASED_TXBCN
+		/*#define CONFIG_FW_BASED_BCN*/
+	#endif
+#endif
+
 #define MACID_NUM_SW_LIMIT 32
 #define SEC_CAM_ENT_NUM_SW_LIMIT 32
 
@@ -205,6 +355,10 @@
 	#define CONFIG_IEEE80211_BAND_5GHZ
 #endif
 
+#if defined(CONFIG_WOWLAN) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+	#define CONFIG_WOW_PATTERN_HW_CAM
+#endif
+
 /*
 	Mark CONFIG_DEAUTH_BEFORE_CONNECT by Arvin 2015/07/20
 	If the failure of Wi-Fi connection is due to some irregular disconnection behavior (like unplug dongle,
@@ -213,10 +367,50 @@
 /*#define CONFIG_DEAUTH_BEFORE_CONNECT */
 
 /*#define CONFIG_WEXT_DONT_JOIN_BYSSID	*/
-//#include <rtl871x_byteorder.h>
+/* #include <rtl871x_byteorder.h> */
 
 
 /*#define CONFIG_DOSCAN_IN_BUSYTRAFFIC	*/
+/*#define CONFIG_PHDYM_FW_FIXRATE		*/	/*	Another way to fix tx rate	*/
+
+/*Don't release SDIO irq in suspend/resume procedure*/
+#define CONFIG_RTW_SDIO_KEEP_IRQ	0
+
+/*
+ * Add by Lucas@2016/02/15
+ * For RX Aggregation
+ */
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_RX_AGGREGATION)
+	#define RTW_RX_AGGREGATION
+#endif /* CONFIG_SDIO_HCI || CONFIG_USB_RX_AGGREGATION */
+
+#ifdef CONFIG_RTW_HOSTAPD_ACS
+	#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
+		#ifndef CONFIG_FIND_BEST_CHANNEL
+			#define CONFIG_FIND_BEST_CHANNEL
+		#endif
+	#else
+		#ifdef CONFIG_FIND_BEST_CHANNEL
+			#undef CONFIG_FIND_BEST_CHANNEL
+		#endif
+		#ifndef CONFIG_RTW_ACS
+			#define CONFIG_RTW_ACS
+		#endif
+		#ifndef CONFIG_BACKGROUND_NOISE_MONITOR
+			#define CONFIG_BACKGROUND_NOISE_MONITOR
+		#endif
+	#endif
+#endif
 
-#endif // __DRV_CONF_H__
+#ifdef CONFIG_RTW_80211K
+	#ifndef CONFIG_RTW_ACS
+		#define CONFIG_RTW_ACS
+	#endif
+#endif /*CONFIG_RTW_80211K*/
 
+#ifdef DBG_CONFIG_ERROR_RESET
+#ifndef CONFIG_IPS
+#define CONFIG_IPS
+#endif
+#endif
+#endif /* __DRV_CONF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types.h
index c6f36143d9fe..ad6b6c6e1e67 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 /*-------------------------------------------------------------------------------
 
 	For type defines and data structure defines
@@ -35,20 +31,20 @@
 #include <wifi.h>
 #include <ieee80211.h>
 #ifdef CONFIG_ARP_KEEP_ALIVE
-#include <net/neighbour.h>
-#include <net/arp.h>
+	#include <net/neighbour.h>
+	#include <net/arp.h>
 #endif
 
 #ifdef PLATFORM_OS_XP
-#include <drv_types_xp.h>
+	#include <drv_types_xp.h>
 #endif
 
 #ifdef PLATFORM_OS_CE
-#include <drv_types_ce.h>
+	#include <drv_types_ce.h>
 #endif
 
 #ifdef PLATFORM_LINUX
-#include <drv_types_linux.h>
+	#include <drv_types_linux.h>
 #endif
 
 enum _NIC_VERSION {
@@ -60,21 +56,22 @@ enum _NIC_VERSION {
 
 };
 
-typedef struct _ADAPTER _adapter, ADAPTER,*PADAPTER;
+typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;
 
 #include <rtw_debug.h>
+#include <cmn_info/rtw_sta_info.h>
 #include <rtw_rf.h>
 
 #ifdef CONFIG_80211N_HT
-#include <rtw_ht.h>
+	#include <rtw_ht.h>
 #endif
 
 #ifdef CONFIG_80211AC_VHT
-#include <rtw_vht.h>
+	#include <rtw_vht.h>
 #endif
 
 #ifdef CONFIG_INTEL_WIDI
-#include <rtw_intel_widi.h>
+	#include <rtw_intel_widi.h>
 #endif
 
 #include <rtw_cmd.h>
@@ -83,9 +80,10 @@ typedef struct _ADAPTER _adapter, ADAPTER,*PADAPTER;
 #include <rtw_xmit.h>
 #include <xmit_osdep.h>
 #include <rtw_recv.h>
+#include <rtw_rm.h>
 
 #ifdef CONFIG_BEAMFORMING
-#include <rtw_beamforming.h>
+	#include <rtw_beamforming.h>
 #endif
 
 #include <recv_osdep.h>
@@ -110,40 +108,40 @@ typedef struct _ADAPTER _adapter, ADAPTER,*PADAPTER;
 #include <sta_info.h>
 #include <rtw_event.h>
 #include <rtw_mlme_ext.h>
+#include <rtw_mi.h>
 #include <rtw_ap.h>
+#ifdef CONFIG_RTW_MESH
+#include "../core/mesh/rtw_mesh.h"
+#endif
 #include <rtw_efuse.h>
 #include <rtw_version.h>
 #include <rtw_odm.h>
 
 #ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
-#include <rtw_mem.h>
+	#include <rtw_mem.h>
 #endif
 
 #include <rtw_p2p.h>
 
 #ifdef CONFIG_TDLS
-#include <rtw_tdls.h>
-#endif // CONFIG_TDLS
+	#include <rtw_tdls.h>
+#endif /* CONFIG_TDLS */
 
 #ifdef CONFIG_WAPI_SUPPORT
-#include <rtw_wapi.h>
-#endif // CONFIG_WAPI_SUPPORT
-
-#ifdef CONFIG_DRVEXT_MODULE
-#include <drvext_api.h>
-#endif // CONFIG_DRVEXT_MODULE
+	#include <rtw_wapi.h>
+#endif /* CONFIG_WAPI_SUPPORT */
 
 #ifdef CONFIG_MP_INCLUDED
-#include <rtw_mp.h>
-#endif // CONFIG_MP_INCLUDED
+	#include <rtw_mp.h>
+#endif /* CONFIG_MP_INCLUDED */
 
 #ifdef CONFIG_BR_EXT
-#include <rtw_br_ext.h>
-#endif // CONFIG_BR_EXT
+	#include <rtw_br_ext.h>
+#endif /* CONFIG_BR_EXT */
 
 #ifdef CONFIG_IOL
-#include <rtw_iol.h>
-#endif // CONFIG_IOL
+	#include <rtw_iol.h>
+#endif /* CONFIG_IOL */
 
 #include <ip.h>
 #include <if_ether.h>
@@ -152,9 +150,16 @@ typedef struct _ADAPTER _adapter, ADAPTER,*PADAPTER;
 
 #include <rtw_android.h>
 
-#ifdef CONFIG_BT_COEXIST
+#include <rtw_btcoex_wifionly.h>
 #include <rtw_btcoex.h>
-#endif // CONFIG_BT_COEXIST
+
+#ifdef CONFIG_MCC_MODE
+	#include <rtw_mcc.h>
+#endif /*CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	#include <rtw_rson.h>
+#endif /*CONFIG_RTW_REPEATER_SON */
 
 #define SPEC_DEV_ID_NONE BIT(0)
 #define SPEC_DEV_ID_DISABLE_HT BIT(1)
@@ -163,7 +168,7 @@ typedef struct _ADAPTER _adapter, ADAPTER,*PADAPTER;
 #define SPEC_DEV_ID_RF_CONFIG_2T2R BIT(4)
 #define SPEC_DEV_ID_ASSIGN_IFNAME BIT(5)
 
-struct specific_device_id{
+struct specific_device_id {
 
 	u32		flags;
 
@@ -172,32 +177,37 @@ struct specific_device_id{
 
 };
 
-struct registry_priv
-{
+struct registry_priv {
 	u8	chip_version;
 	u8	rfintfs;
 	u8	lbkmode;
 	u8	hci;
 	NDIS_802_11_SSID	ssid;
-	u8	network_mode;	//infra, ad-hoc, auto
-	u8	channel;//ad-hoc support requirement
-	u8	wireless_mode;//A, B, G, auto
-	u8 	scan_mode;//active, passive
+	u8	network_mode;	/* infra, ad-hoc, auto */
+	u8	channel;/* ad-hoc support requirement */
+	u8	wireless_mode;/* A, B, G, auto */
+	u8	scan_mode;/* active, passive */
 	u8	radio_enable;
-	u8	preamble;//long, short, auto
-	u8	vrtl_carrier_sense;//Enable, Disable, Auto
-	u8	vcs_type;//RTS/CTS, CTS-to-self
+	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	lps_level;
 	u8	smart_ps;
+#ifdef CONFIG_WMMPS_STA
+	u8	wmm_smart_ps;
+#endif /* CONFIG_WMMPS_STA */
 	u8   usb_rxagg_mode;
+	u8	dynamic_agg_enable;
 	u8	long_retry_lmt;
 	u8	short_retry_lmt;
 	u16	busy_thresh;
+	u16	max_bss_cnt;
 	u8	ack_policy;
 	u8	mp_mode;
 #if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
@@ -206,94 +216,109 @@ struct registry_priv
 	u8  mp_dm;
 	u8	software_encrypt;
 	u8	software_decrypt;
-	#ifdef CONFIG_TX_EARLY_MODE
+#ifdef CONFIG_TX_EARLY_MODE
 	u8   early_mode;
-	#endif
+#endif
 	u8	acm_method;
-	  //UAPSD
+	/* WMM */
 	u8	wmm_enable;
-	u8	uapsd_enable;
-	u8	uapsd_max_sp;
-	u8	uapsd_acbk_en;
-	u8	uapsd_acbe_en;
-	u8	uapsd_acvi_en;
-	u8	uapsd_acvo_en;
+#ifdef CONFIG_WMMPS_STA
+	/* uapsd (unscheduled automatic power-save delivery) = a kind of wmmps */
+	u8	uapsd_max_sp_len;
+	/* BIT0: AC_VO UAPSD, BIT1: AC_VI UAPSD, BIT2: AC_BK UAPSD, BIT3: AC_BE UAPSD */
+	u8	uapsd_ac_enable;
+#endif /* CONFIG_WMMPS_STA */
 
 	WLAN_BSSID_EX    dev_network;
 
 	u8 tx_bw_mode;
-
+#ifdef CONFIG_AP_MODE
+	u8 bmc_tx_rate;
+#endif
 #ifdef CONFIG_80211N_HT
 	u8	ht_enable;
-	// 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz
-	// 2.4G use bit 0 ~ 3, 5G use bit 4 ~ 7
-	// 0x21 means enable 2.4G 40MHz & 5G 80MHz
+	/* 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz */
+	/* 2.4G use bit 0 ~ 3, 5G use bit 4 ~ 7 */
+	/* 0x21 means enable 2.4G 40MHz & 5G 80MHz */
 	u8	bw_mode;
-	u8	ampdu_enable;//for tx
-	u8 	rx_stbc;
-	u8	ampdu_amsdu;//A-MPDU Supports A-MSDU is permitted
-	// Short GI support Bit Map
-	// BIT0 - 20MHz, 1: support, 0: non-support
-	// BIT1 - 40MHz, 1: support, 0: non-support
-	// BIT2 - 80MHz, 1: support, 0: non-support
-	// BIT3 - 160MHz, 1: support, 0: non-support
+	u8	ampdu_enable;/* for tx */
+	u8	rx_stbc;
+	u8	rx_ampdu_amsdu;/* Rx A-MPDU Supports A-MSDU is permitted */
+	u8	tx_ampdu_amsdu;/* Tx A-MPDU Supports A-MSDU is permitted */
+	u8 rx_ampdu_sz_limit_by_nss_bw[4][4]; /* 1~4SS, BW20~BW160 */
+	/* Short GI support Bit Map */
+	/* BIT0 - 20MHz, 1: support, 0: non-support */
+	/* BIT1 - 40MHz, 1: support, 0: non-support */
+	/* BIT2 - 80MHz, 1: support, 0: non-support */
+	/* BIT3 - 160MHz, 1: support, 0: non-support */
 	u8	short_gi;
-	// BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx
+	/* BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx */
 	u8	ldpc_cap;
-	// BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx
+	/* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
 	u8	stbc_cap;
-	// BIT0: Enable VHT Beamformer, BIT1: Enable VHT Beamformee, BIT4: Enable HT Beamformer, BIT5: Enable HT Beamformee
+	/*
+	 * BIT0: Enable VHT SU Beamformer
+	 * BIT1: Enable VHT SU Beamformee
+	 * BIT2: Enable VHT MU Beamformer, depend on VHT SU Beamformer
+	 * BIT3: Enable VHT MU Beamformee, depend on VHT SU Beamformee
+	 * BIT4: Enable HT Beamformer
+	 * BIT5: Enable HT Beamformee
+	 */
 	u8	beamform_cap;
 	u8	beamformer_rf_num;
 	u8	beamformee_rf_num;
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 
 #ifdef CONFIG_80211AC_VHT
-	u8	vht_enable; //0:disable, 1:enable, 2:auto
+	u8	vht_enable; /* 0:disable, 1:enable, 2:auto */
 	u8	ampdu_factor;
-	u8	vht_rate_sel;
-#endif //CONFIG_80211AC_VHT
+	u8 vht_rx_mcs_map[2];
+#endif /* CONFIG_80211AC_VHT */
 
 	u8	lowrate_two_xmit;
 
 	u8	rf_config ;
 	u8	low_power ;
 
-	u8	wifi_spec;// !turbo_mode
-	u8	special_rf_path; // 0: 2T2R ,1: only turn on path A 1T1R
+	u8	wifi_spec;/* !turbo_mode */
+	u8	special_rf_path; /* 0: 2T2R ,1: only turn on path A 1T1R */
 	char alpha2[2];
 	u8	channel_plan;
-	u8  full_ch_in_p2p_handshake; /* 0: reply only softap channel, 1: reply full channel list*/
+	u8	excl_chs[MAX_CHANNEL_NUM];
+	u8	full_ch_in_p2p_handshake; /* 0: reply only softap channel, 1: reply full channel list*/
+
 #ifdef CONFIG_BT_COEXIST
 	u8	btcoex;
 	u8	bt_iso;
 	u8	bt_sco;
 	u8	bt_ampdu;
-	s8	ant_num;
+	u8	ant_num;
+	u8	single_ant_path;
 #endif
 	BOOLEAN	bAcceptAddbaReq;
 
 	u8	antdiv_cfg;
 	u8	antdiv_type;
-	
-	u8	switch_usb3;
+	u8	drv_ant_band_switch;
 
-	u8	usbss_enable;//0:disable,1:enable
-	u8	hwpdn_mode;//0:disable,1:enable,2:decide by EFUSE config
-	u8	hwpwrp_detect;//0:disable,1:enable
+	u8	switch_usb_mode;
 
-	u8	hw_wps_pbc;//0:disable,1:enable
+	u8	usbss_enable;/* 0:disable,1:enable */
+	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 */
 
 #ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
 	char	adaptor_info_caching_file_path[PATH_LENGTH_MAX];
 #endif
 
 #ifdef CONFIG_LAYER2_ROAMING
-	u8	max_roaming_times; // the max number driver will try to roaming
+	u8	max_roaming_times; /* the max number driver will try to roaming */
 #endif
 
 #ifdef CONFIG_IOL
-	u8 fw_iol; //enable iol without other concern
+	u8 fw_iol; /* enable iol without other concern */
 #endif
 
 #ifdef CONFIG_80211D
@@ -305,19 +330,14 @@ struct registry_priv
 
 	u8 notch_filter;
 
-#ifdef CONFIG_SPECIAL_SETTING_FOR_FUNAI_TV
-	u8 force_ant;//0 normal,1 main,2 aux
-	u8 force_igi;//0 normal
-#endif
-
 	/* for pll reference clock selction */
 	u8 pll_ref_clk_sel;
 
-	//define for tx power adjust
+	/* define for tx power adjust */
+#ifdef CONFIG_TXPWR_LIMIT
 	u8	RegEnableTxPowerLimit;
+#endif
 	u8	RegEnableTxPowerByRate;
-	u8	RegPowerBase;
-	u8	RegPwrTblSel;
 
 	u8 target_tx_pwr_valid;
 	s8 target_tx_pwr_2g[RF_PATH_MAX][RATE_SECTION_NUM];
@@ -331,17 +351,17 @@ struct registry_priv
 	u8	AmplifierType_5G;
 	u8	bEn_RFE;
 	u8	RFE_Type;
-	u8	GLNA_Type;	
+	u8	PowerTracking_Type;
+	u8	GLNA_Type;
 	u8  check_fw_ps;
-	u8	RegRfKFreeEnable;
-	
+	u8	RegPwrTrimEnable;
+
 #ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
 	u8	load_phy_file;
 	u8	RegDecryptCustomFile;
 #endif
-
-#ifdef CONFIG_MULTI_VIR_IFACES
-	u8 ext_iface_num;//primary/secondary iface is excluded
+#ifdef CONFIG_CONCURRENT_MODE
+	u8 virtual_iface_num;
 #endif
 	u8 qos_opt_enable;
 
@@ -355,19 +375,84 @@ struct registry_priv
 
 	u8 boffefusemask;
 	BOOLEAN bFileMaskEfuse;
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-	u8 acs_mode;
+#ifdef CONFIG_RTW_ACS
 	u8 acs_auto_scan;
+	u8 acs_mode;
+#endif
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	u8 nm_mode;
 #endif
 	u32	reg_rxgain_offset_2g;
 	u32	reg_rxgain_offset_5gl;
 	u32	reg_rxgain_offset_5gm;
 	u32	reg_rxgain_offset_5gh;
+
+#ifdef CONFIG_DFS_MASTER
+	u8 dfs_region_domain;
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	u8 en_mcc;
+	u32 rtw_mcc_single_tx_cri;
+	u32 rtw_mcc_ap_bw20_target_tx_tp;
+	u32 rtw_mcc_ap_bw40_target_tx_tp;
+	u32 rtw_mcc_ap_bw80_target_tx_tp;
+	u32 rtw_mcc_sta_bw20_target_tx_tp;
+	u32 rtw_mcc_sta_bw40_target_tx_tp;
+	u32 rtw_mcc_sta_bw80_target_tx_tp;
+	s8 rtw_mcc_policy_table_idx;
+	u8 rtw_mcc_duration;
+	u8 rtw_mcc_enable_runtime_duration;
+#endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_NAPI
+	u8 en_napi;
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	u32 napi_threshold;	/* unit: Mbps */
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#ifdef CONFIG_RTW_GRO
+	u8 en_gro;
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+#ifdef CONFIG_WOWLAN
+	u8 wakeup_event;
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	u8 trx_share_mode;
+#endif
+	u8 check_hw_status;
+
+	u32 pci_aspm_config;
+
+	u8 iqk_fw_offload;
+	u8 ch_switch_offload;
+
+#ifdef CONFIG_TDLS
+	u8 en_tdls;
+#endif
+
+#ifdef CONFIG_ADVANCE_OTA
+	u8	adv_ota;
+#endif
+
+#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+	u8 fw_param_init;
+#endif
+#ifdef CONFIG_DYNAMIC_SOML
+	u8 dyn_soml_en;
+	u8 dyn_soml_train_num;
+	u8 dyn_soml_interval;
+	u8 dyn_soml_period;
+	u8 dyn_soml_delay;
+#endif
 };
 
-//For registry parameters
-#define RGTRY_OFT(field) ((ULONG)FIELD_OFFSET(struct registry_priv,field))
-#define RGTRY_SZ(field)   sizeof(((struct registry_priv*) 0)->field)
+/* For registry parameters */
+#define RGTRY_OFT(field) ((ULONG)FIELD_OFFSET(struct registry_priv, field))
+#define RGTRY_SZ(field)   sizeof(((struct registry_priv *) 0)->field)
 
 #define GetRegAmplifierType2G(_Adapter)	(_Adapter->registrypriv.AmplifierType_2G)
 #define GetRegAmplifierType5G(_Adapter)	(_Adapter->registrypriv.AmplifierType_5G)
@@ -378,8 +463,9 @@ struct registry_priv
 #define GetRegbENRFEType(_Adapter)	(_Adapter->registrypriv.bEn_RFE)
 #define GetRegRFEType(_Adapter)	(_Adapter->registrypriv.RFE_Type)
 #define GetRegGLNAType(_Adapter)	(_Adapter->registrypriv.GLNA_Type)
+#define GetRegPowerTrackingType(_Adapter)	(_Adapter->registrypriv.PowerTracking_Type)
 
-#define BSSID_OFT(field) ((ULONG)FIELD_OFFSET(WLAN_BSSID_EX,field))
+#define BSSID_OFT(field) ((ULONG)FIELD_OFFSET(WLAN_BSSID_EX, field))
 #define BSSID_SZ(field)   sizeof(((PWLAN_BSSID_EX) 0)->field)
 
 #define BW_MODE_2G(bw_mode) ((bw_mode) & 0x0F)
@@ -392,24 +478,32 @@ struct registry_priv
 #define REGSTY_IS_11AC_ENABLE(regsty) ((regsty)->vht_enable != 0)
 #define REGSTY_IS_11AC_AUTO(regsty) ((regsty)->vht_enable == 2)
 
+typedef struct rtw_if_operations {
+	int __must_check (*read)(struct dvobj_priv *d, unsigned int addr, void *buf,
+				size_t len, bool fixed);
+	int __must_check (*write)(struct dvobj_priv *d, unsigned int addr, void *buf,
+				 size_t len, bool fixed);
+} RTW_IF_OPS, *PRTW_IF_OPS;
+
 #ifdef CONFIG_SDIO_HCI
-#include <drv_types_sdio.h>
-#define INTF_DATA SDIO_DATA
+	#include <drv_types_sdio.h>
+	#define INTF_DATA	SDIO_DATA
+	#define INTF_OPS	PRTW_IF_OPS
 #elif defined(CONFIG_GSPI_HCI)
-#include <drv_types_gspi.h>
-#define INTF_DATA GSPI_DATA
+	#include <drv_types_gspi.h>
+	#define INTF_DATA GSPI_DATA
 #elif defined(CONFIG_PCI_HCI)
-#include <drv_types_pci.h>
+	#include <drv_types_pci.h>
 #endif
 
 #ifdef CONFIG_CONCURRENT_MODE
-#define is_primary_adapter(adapter) (adapter->adapter_type == PRIMARY_ADAPTER)
-#define is_vir_adapter(adapter) (adapter->adapter_type == MAX_ADAPTER)
-#define get_iface_type(adapter) (adapter->iface_type)
+	#define is_primary_adapter(adapter) (adapter->adapter_type == PRIMARY_ADAPTER)
+	#define is_vir_adapter(adapter) (adapter->adapter_type == VIRTUAL_ADAPTER)
+	#define get_hw_port(adapter) (adapter->hw_port)
 #else
-#define is_primary_adapter(adapter) (1)
-#define is_vir_adapter(adapter) (0)
-#define get_iface_type(adapter) (IFACE_PORT0)
+	#define is_primary_adapter(adapter) (1)
+	#define is_vir_adapter(adapter) (0)
+	#define get_hw_port(adapter) (HW_PORT0)
 #endif
 #define GET_PRIMARY_ADAPTER(padapter) (((_adapter *)padapter)->dvobj->padapters[IFACE_ID0])
 #define GET_IFACE_NUMS(padapter) (((_adapter *)padapter)->dvobj->iface_nums)
@@ -418,13 +512,19 @@ struct registry_priv
 #define GetDefaultAdapter(padapter)	padapter
 
 enum _IFACE_ID {
-	IFACE_ID0, //maping to PRIMARY_ADAPTER
-	IFACE_ID1, //maping to SECONDARY_ADAPTER
+	IFACE_ID0, /*PRIMARY_ADAPTER*/
+	IFACE_ID1,
 	IFACE_ID2,
 	IFACE_ID3,
+	IFACE_ID4,
+	IFACE_ID5,
+	IFACE_ID6,
+	IFACE_ID7,
 	IFACE_ID_MAX,
 };
 
+#define VIF_START_ID	1
+
 #ifdef CONFIG_DBG_COUNTER
 
 struct rx_logs {
@@ -548,7 +648,7 @@ struct int_logs {
 	u32 vodok;
 };
 
-#endif // CONFIG_DBG_COUNTER
+#endif /* CONFIG_DBG_COUNTER */
 
 struct debug_priv {
 	u32 dbg_sdio_free_irq_error_cnt;
@@ -580,33 +680,28 @@ struct debug_priv {
 	u32 dbg_rpwm_toogle_cnt;
 	u32 dbg_rpwm_timeout_fail_cnt;
 	u32 dbg_sreset_cnt;
+	u32 dbg_fw_mem_dl_error_cnt;
 	u64 dbg_rx_fifo_last_overflow;
 	u64 dbg_rx_fifo_curr_overflow;
 	u64 dbg_rx_fifo_diff_overflow;
-	u64 dbg_rx_ampdu_drop_count;
-	u64 dbg_rx_ampdu_forced_indicate_count;
-	u64 dbg_rx_ampdu_loss_count;
-	u64 dbg_rx_dup_mgt_frame_drop_count;
-	u64 dbg_rx_ampdu_window_shift_cnt;
-	u64 dbg_rx_conflic_mac_addr_cnt;
 };
 
 struct rtw_traffic_statistics {
-	// tx statistics
+	/* tx statistics */
 	u64	tx_bytes;
 	u64	tx_pkts;
 	u64	tx_drop;
 	u64	cur_tx_bytes;
 	u64	last_tx_bytes;
-	u32	cur_tx_tp; // Tx throughput in MBps.
+	u32	cur_tx_tp; /* Tx throughput in MBps. */
 
-	// rx statistics
+	/* rx statistics */
 	u64	rx_bytes;
 	u64	rx_pkts;
 	u64	rx_drop;
 	u64	cur_rx_bytes;
 	u64	last_rx_bytes;
-	u32	cur_rx_tp; // Rx throughput in MBps.
+	u32	cur_rx_tp; /* Rx throughput in MBps. */
 };
 
 #define SEC_CAP_CHK_BMC	BIT0
@@ -645,9 +740,11 @@ struct sec_cam_ent {
 };
 
 #define KEY_FMT "%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
-#define KEY_ARG(x) ((u8*)(x))[0],((u8*)(x))[1],((u8*)(x))[2],((u8*)(x))[3],((u8*)(x))[4],((u8*)(x))[5], \
-	((u8*)(x))[6],((u8*)(x))[7],((u8*)(x))[8],((u8*)(x))[9],((u8*)(x))[10],((u8*)(x))[11], \
-	((u8*)(x))[12],((u8*)(x))[13],((u8*)(x))[14],((u8*)(x))[15]
+#define KEY_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
+	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9], ((u8 *)(x))[10], ((u8 *)(x))[11], \
+	((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15]
+
+#define RTW_DEFAULT_MGMT_MACID 1
 
 struct macid_bmp {
 	u32 m0;
@@ -667,14 +764,30 @@ struct macid_ctl_t {
 	u8 num;
 	struct macid_bmp used;
 	struct macid_bmp bmc;
-	struct macid_bmp if_g[IFACE_ID_MAX];
+	struct macid_bmp if_g[CONFIG_IFACE_NUMBER];
 	struct macid_bmp ch_g[2]; /* 2 ch concurrency */
+
+	u8 iface_bmc[CONFIG_IFACE_NUMBER]; /* bmc TX macid for each iface*/
+
 	u8 h2c_msr[MACID_NUM_SW_LIMIT];
 	u8 bw[MACID_NUM_SW_LIMIT];
 	u8 vht_en[MACID_NUM_SW_LIMIT];
 	u32 rate_bmp0[MACID_NUM_SW_LIMIT];
 	u32 rate_bmp1[MACID_NUM_SW_LIMIT];
-	struct sta_info *sta[MACID_NUM_SW_LIMIT];
+
+	struct sta_info *sta[MACID_NUM_SW_LIMIT]; /* corresponding stainfo when macid is not shared */
+
+	/* macid sleep registers */
+	u16 reg_sleep_m0;
+#if (MACID_NUM_SW_LIMIT > 32)
+	u16 reg_sleep_m1;
+#endif
+#if (MACID_NUM_SW_LIMIT > 64)
+	u16 reg_sleep_m2;
+#endif
+#if (MACID_NUM_SW_LIMIT > 96)
+	u16 reg_sleep_m3;
+#endif
 };
 
 /* used for rf_ctl_t.rate_bmp_cck_ofdm */
@@ -710,7 +823,33 @@ struct macid_ctl_t {
 #define RATE_BMP_GET_VHT_2SS(_bmp_vht)		((_bmp_vht & RATE_BMP_VHT_2SS) >> 10)
 #define RATE_BMP_GET_VHT_3SS(_bmp_vht)		((_bmp_vht & RATE_BMP_VHT_3SS) >> 20)
 
+#define TXPWR_LMT_REF_VHT_FROM_HT	BIT0
+#define TXPWR_LMT_REF_HT_FROM_VHT	BIT1
+
+#define TXPWR_LMT_HAS_CCK_1T	BIT0
+#define TXPWR_LMT_HAS_CCK_2T	BIT1
+#define TXPWR_LMT_HAS_CCK_3T	BIT2
+#define TXPWR_LMT_HAS_CCK_4T	BIT3
+#define TXPWR_LMT_HAS_OFDM_1T	BIT4
+#define TXPWR_LMT_HAS_OFDM_2T	BIT5
+#define TXPWR_LMT_HAS_OFDM_3T	BIT6
+#define TXPWR_LMT_HAS_OFDM_4T	BIT7
+
+#define OFFCHS_NONE			0
+#define OFFCHS_LEAVING_OP	1
+#define OFFCHS_LEAVE_OP		2
+#define OFFCHS_BACKING_OP	3
+
 struct rf_ctl_t {
+	const struct country_chplan *country_ent;
+	u8 ChannelPlan;
+	u8 max_chan_nums;
+	RT_CHANNEL_INFO channel_set[MAX_CHANNEL_NUM];
+	struct p2p_channels channel_list;
+
+	_mutex offch_mutex;
+	u8 offch_state;
+
 	/* used for debug or by tx power limit */
 	u16 rate_bmp_cck_ofdm;		/* 20MHz */
 	u32 rate_bmp_ht_by_bw[2];	/* 20MHz, 40MHz. 4SS supported */
@@ -720,33 +859,95 @@ struct rf_ctl_t {
 	u8 highest_ht_rate_bw_bmp;
 	u8 highest_vht_rate_bw_bmp;
 
-	#ifdef CONFIG_DFS_MASTER
-	bool radar_detect_by_sta_link;
-	bool pre_radar_detect_by_sta_link;
-	bool dfs_master_enabled;
+#ifdef CONFIG_TXPWR_LIMIT
+	_mutex txpwr_lmt_mutex;
+	_list reg_exc_list;
+	u8 regd_exc_num;
+	_list txpwr_lmt_list;
+	u8 txpwr_regd_num;
+	const char *regd_name;
+
+	u8 txpwr_lmt_2g_cck_ofdm_state;
+	#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	u8 txpwr_lmt_5g_cck_ofdm_state;
+	u8 txpwr_lmt_5g_20_40_ref;
+	#endif
+#endif
+
+	u8 ch_sel_same_band_prefer;
+
+#ifdef CONFIG_DFS_MASTER
+	bool radar_detect_by_others;
+	u8 dfs_master_enabled;
+	bool radar_detected;
 
 	u8 radar_detect_ch;
 	u8 radar_detect_bw;
 	u8 radar_detect_offset;
-	u8 pre_radar_detect_ch;
-	u8 pre_radar_detect_bw;
-	u8 pre_radar_detect_offset;
 
-	u32 cac_end_time;
+	systime cac_start_time;
+	systime cac_end_time;
+	u8 cac_force_stop;
+
+	u8 dfs_ch_sel_d_flags;
 
 	u8 dbg_dfs_master_fake_radar_detect_cnt;
 	u8 dbg_dfs_master_radar_detect_trigger_non;
 	u8 dbg_dfs_master_choose_dfs_ch_first;
-	#endif
+#endif
 };
 
 #define RTW_CAC_STOPPED 0
-#define IS_UNDER_CAC(rfctl) ((rfctl)->cac_end_time > rtw_get_current_time())
+#ifdef CONFIG_DFS_MASTER
 #define IS_CAC_STOPPED(rfctl) ((rfctl)->cac_end_time == RTW_CAC_STOPPED)
+#define IS_CH_WAITING(rfctl) (!IS_CAC_STOPPED(rfctl) && rtw_time_after((rfctl)->cac_end_time, rtw_get_current_time()))
+#define IS_UNDER_CAC(rfctl) (IS_CH_WAITING(rfctl) && rtw_time_after(rtw_get_current_time(), (rfctl)->cac_start_time))
+#else
+#define IS_CAC_STOPPED(rfctl) 1
+#define IS_CH_WAITING(rfctl) 0
+#define IS_UNDER_CAC(rfctl) 0
+#endif /* CONFIG_DFS_MASTER */
+
+#ifdef CONFIG_MBSSID_CAM
+#define TOTAL_MBID_CAM_NUM	8
+#define INVALID_CAM_ID			0xFF
+struct mbid_cam_ctl_t {
+	_lock lock;
+	u8 bitmap;
+	ATOMIC_T mbid_entry_num;
+};
+struct mbid_cam_cache {
+	u8 iface_id;
+	/*u8 role;*/ /*WIFI_STATION_STATE or WIFI_AP_STATE*/
+	u8 mac_addr[ETH_ALEN];
+};
+#endif /*CONFIG_MBSSID_CAM*/
+
+#ifdef RTW_HALMAC
+struct halmac_indicator {
+	struct submit_ctx *sctx;
+	u8 *buffer;
+	u32 buf_size;
+	u32 ret_size;
+	u32 status;
+};
 
-struct dvobj_priv
-{
-	/*-------- below is common data --------*/	
+struct halmacpriv {
+	/* flags */
+
+	/* For asynchronous functions */
+	struct halmac_indicator *indicator;
+
+	/* Hardware parameters */
+#ifdef CONFIG_SDIO_HCI
+	/* Store hardware tx queue page number setting */
+	u16 txpage[HW_QUEUE_ENTRY];
+#endif /* CONFIG_SDIO_HCI */
+};
+#endif /* RTW_HALMAC */
+
+struct dvobj_priv {
+	/*-------- below is common data --------*/
 	u8	chip_type;
 	u8	HardwareType;
 	u8	interface_type;/*USB,SDIO,SPI,PCI*/
@@ -774,61 +975,101 @@ struct dvobj_priv
 	_mutex sd_indirect_access_mutex;
 #endif
 
-	unsigned char	oper_channel; //saved channel info when call set_channel_bw
+	unsigned char	oper_channel; /* saved channel info when call set_channel_bw */
 	unsigned char	oper_bwmode;
-	unsigned char	oper_ch_offset;//PRIME_CHNL_OFFSET
-	u32 on_oper_ch_time;
+	unsigned char	oper_ch_offset;/* PRIME_CHNL_OFFSET */
+	systime on_oper_ch_time;
+
+	_adapter *padapters[CONFIG_IFACE_NUMBER];/*IFACE_ID_MAX*/
+	u8 iface_nums; /* total number of ifaces used runtime */
+	struct mi_state iface_state;
+
+#ifdef CONFIG_AP_MODE
+	u8 nr_ap_if; /* total interface s number of ap/go mode. */
+	u16 inter_bcn_space; /* unit:ms */
+	_queue	ap_if_q;
+#ifdef CONFIG_RTW_REPEATER_SON
+	struct rtw_rson_struct  rson_data;
+#endif
 
-	//extend to support mulitu interface
-	/*padapters[IFACE_ID0] == if1 - PRIMARY_ADAPTER*/
-	/*padapters[IFACE_ID1] == if2 - SECONDARY_ADAPTER*/
-	_adapter *padapters[IFACE_ID_MAX];
-	u8 iface_nums; // total number of ifaces used runtime
+#endif
 
 	struct macid_ctl_t macid_ctl;
 
 	struct cam_ctl_t cam_ctl;
 	struct sec_cam_ent cam_cache[SEC_CAM_ENT_NUM_SW_LIMIT];
 
+#ifdef CONFIG_MBSSID_CAM
+	struct mbid_cam_ctl_t mbid_cam_ctl;
+	struct mbid_cam_cache mbid_cam_cache[TOTAL_MBID_CAM_NUM];
+#endif
+
 	struct rf_ctl_t rf_ctl;
 
-	//For 92D, DMDP have 2 interface.
+	/* For 92D, DMDP have 2 interface. */
 	u8	InterfaceNumber;
 	u8	NumInterfaces;
 
-	//In /Out Pipe information
+	/* In /Out Pipe information */
 	int	RtInPipe[2];
 	int	RtOutPipe[4];
-	u8	Queue2Pipe[HW_QUEUE_ENTRY];//for out pipe mapping
+	u8	Queue2Pipe[HW_QUEUE_ENTRY];/* for out pipe mapping */
 
 	u8	irq_alloc;
 	ATOMIC_T continual_io_error;
 
 	ATOMIC_T disable_func;
 
+	u8 xmit_block;
+	_lock xmit_block_lock;
+
 	struct pwrctrl_priv pwrctl_priv;
 
 	struct rtw_traffic_statistics	traffic_stat;
 
-#if defined(CONFIG_IOCTL_CFG80211) && defined(RTW_SINGLE_WIPHY)
+#ifdef PLATFORM_LINUX
+	_thread_hdl_ rtnl_lock_holder;
+
+	#if defined(CONFIG_IOCTL_CFG80211) && defined(RTW_SINGLE_WIPHY)
 	struct wiphy *wiphy;
+	#endif
+#endif /* PLATFORM_LINUX */
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	_timer txbcn_timer;
 #endif
+	_timer dynamic_chk_timer; /* dynamic/periodic check timer */
+	
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	u8 en_napi_dynamic;
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
 
-/*-------- below is for SDIO INTERFACE --------*/
+#ifdef RTW_HALMAC
+	void *halmac;
+	struct halmacpriv hmpriv;
+#endif /* RTW_HALMAC */
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	u8 default_port_id;
+#endif
+	/*-------- below is for SDIO INTERFACE --------*/
 
 #ifdef INTF_DATA
 	INTF_DATA intf_data;
 #endif
+#ifdef INTF_OPS
+	INTF_OPS intf_ops;
+#endif
 
-/*-------- below is for USB INTERFACE --------*/
+	/*-------- below is for USB INTERFACE --------*/
 
 #ifdef CONFIG_USB_HCI
 
-	u8	usb_speed; // 1.1, 2.0 or 3.0
+	u8	usb_speed; /* 1.1, 2.0 or 3.0 */
 	u8	nr_endpoint;
 	u8	RtNumInPipes;
 	u8	RtNumOutPipes;
-	int	ep_num[6]; //endpoint number
+	int	ep_num[6]; /* endpoint number */
 
 	int	RegUsbSS;
 
@@ -839,62 +1080,73 @@ struct dvobj_priv
 #endif
 
 #ifdef CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC
-	u8 * usb_alloc_vendor_req_buf;
-	u8 * usb_vendor_req_buf;
+	u8 *usb_alloc_vendor_req_buf;
+	u8 *usb_vendor_req_buf;
 #endif
 
 #ifdef PLATFORM_WINDOWS
-	//related device objects
-	PDEVICE_OBJECT	pphysdevobj;//pPhysDevObj;
-	PDEVICE_OBJECT	pfuncdevobj;//pFuncDevObj;
-	PDEVICE_OBJECT	pnextdevobj;//pNextDevObj;
+	/* related device objects */
+	PDEVICE_OBJECT	pphysdevobj;/* pPhysDevObj; */
+	PDEVICE_OBJECT	pfuncdevobj;/* pFuncDevObj; */
+	PDEVICE_OBJECT	pnextdevobj;/* pNextDevObj; */
 
-	u8	nextdevstacksz;//unsigned char NextDeviceStackSize;	//= (CHAR)CEdevice->pUsbDevObj->StackSize + 1;
+	u8	nextdevstacksz;/* unsigned char NextDeviceStackSize;	 */ /* = (CHAR)CEdevice->pUsbDevObj->StackSize + 1; */
 
-	//urb for control diescriptor request
+	/* urb for control diescriptor request */
 
 #ifdef PLATFORM_OS_XP
 	struct _URB_CONTROL_DESCRIPTOR_REQUEST descriptor_urb;
-	PUSB_CONFIGURATION_DESCRIPTOR	pconfig_descriptor;//UsbConfigurationDescriptor;
+	PUSB_CONFIGURATION_DESCRIPTOR	pconfig_descriptor;/* UsbConfigurationDescriptor; */
 #endif
 
 #ifdef PLATFORM_OS_CE
-	WCHAR			active_path[MAX_ACTIVE_REG_PATH];	// adapter regpath
+	WCHAR			active_path[MAX_ACTIVE_REG_PATH];	/* adapter regpath */
 	USB_EXTENSION	usb_extension;
 
 	_nic_hdl		pipehdls_r8192c[0x10];
 #endif
 
-	u32	config_descriptor_len;//ULONG UsbConfigurationDescriptorLength;
-#endif//PLATFORM_WINDOWS
+	u32	config_descriptor_len;/* ULONG UsbConfigurationDescriptorLength; */
+#endif/* PLATFORM_WINDOWS */
 
 #ifdef PLATFORM_LINUX
 	struct usb_interface *pusbintf;
 	struct usb_device *pusbdev;
-#endif//PLATFORM_LINUX
+#endif/* PLATFORM_LINUX */
 
 #ifdef PLATFORM_FREEBSD
 	struct usb_interface *pusbintf;
 	struct usb_device *pusbdev;
-#endif//PLATFORM_FREEBSD
-	
-#endif//CONFIG_USB_HCI
+#endif/* PLATFORM_FREEBSD */
+
+#endif/* CONFIG_USB_HCI */
 
-/*-------- below is for PCIE INTERFACE --------*/
+	/*-------- below is for PCIE INTERFACE --------*/
 
 #ifdef CONFIG_PCI_HCI
 
 #ifdef PLATFORM_LINUX
 	struct pci_dev *ppcidev;
 
-	//PCI MEM map
+	/* PCI MEM map */
 	unsigned long	pci_mem_end;	/* shared mem end	*/
 	unsigned long	pci_mem_start;	/* shared mem start	*/
 
-	//PCI IO map
+	/* PCI IO map */
 	unsigned long	pci_base_addr;	/* device I/O address	*/
 
-	//PciBridge
+#ifdef RTK_129X_PLATFORM
+	unsigned long	ctrl_start;
+	/* PCI MASK addr */
+	unsigned long	mask_addr;
+
+	/* PCI TRANSLATE addr */
+	unsigned long	tran_addr;
+
+	_lock   io_reg_lock;
+#endif
+
+	/* PciBridge */
 	struct pci_priv	pcipriv;
 
 	unsigned int irq; /* get from pci_dev.irq, store to net_device.irq */
@@ -903,26 +1155,50 @@ struct dvobj_priv
 	RT_ISR_CONTENT	isr_content;
 	_lock	irq_th_lock;
 
-	//ASPM
+	/* ASPM */
 	u8	const_pci_aspm;
 	u8	const_amdpci_aspm;
 	u8	const_hwsw_rfoff_d3;
 	u8	const_support_pciaspm;
-	// pci-e bridge */
-	u8 	const_hostpci_aspm_setting;
-	// pci-e device */
-	u8 	const_devicepci_aspm_setting;
-	u8 	b_support_aspm; // If it supports ASPM, Offset[560h] = 0x40, otherwise Offset[560h] = 0x00.
+	/* pci-e bridge */
+	u8	const_hostpci_aspm_setting;
+	/* pci-e device */
+	u8	const_devicepci_aspm_setting;
+	u8	b_support_aspm; /* If it supports ASPM, Offset[560h] = 0x40, otherwise Offset[560h] = 0x00. */
 	u8	b_support_backdoor;
 	u8	bdma64;
-#endif//PLATFORM_LINUX
+#endif/* PLATFORM_LINUX */
+
+#endif/* CONFIG_PCI_HCI */
 
-#endif//CONFIG_PCI_HCI
+#ifdef CONFIG_MCC_MODE
+	struct mcc_obj_priv mcc_objpriv;
+#endif /*CONFIG_MCC_MODE */
 };
 
+#define DEV_STA_NUM(_dvobj)			MSTATE_STA_NUM(&((_dvobj)->iface_state))
+#define DEV_STA_LD_NUM(_dvobj)		MSTATE_STA_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_STA_LG_NUM(_dvobj)		MSTATE_STA_LG_NUM(&((_dvobj)->iface_state))
+#define DEV_TDLS_LD_NUM(_dvobj)		MSTATE_TDLS_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_AP_NUM(_dvobj)			MSTATE_AP_NUM(&((_dvobj)->iface_state))
+#define DEV_AP_STARTING_NUM(_dvobj)	MSTATE_AP_STARTING_NUM(&((_dvobj)->iface_state))
+#define DEV_AP_LD_NUM(_dvobj)		MSTATE_AP_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_ADHOC_NUM(_dvobj)		MSTATE_ADHOC_NUM(&((_dvobj)->iface_state))
+#define DEV_ADHOC_LD_NUM(_dvobj)	MSTATE_ADHOC_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_MESH_NUM(_dvobj)		MSTATE_MESH_NUM(&((_dvobj)->iface_state))
+#define DEV_MESH_LD_NUM(_dvobj)		MSTATE_MESH_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_SCAN_NUM(_dvobj)		MSTATE_SCAN_NUM(&((_dvobj)->iface_state))
+#define DEV_WPS_NUM(_dvobj)			MSTATE_WPS_NUM(&((_dvobj)->iface_state))
+#define DEV_ROCH_NUM(_dvobj)		MSTATE_ROCH_NUM(&((_dvobj)->iface_state))
+#define DEV_MGMT_TX_NUM(_dvobj)		MSTATE_MGMT_TX_NUM(&((_dvobj)->iface_state))
+#define DEV_U_CH(_dvobj)			MSTATE_U_CH(&((_dvobj)->iface_state))
+#define DEV_U_BW(_dvobj)			MSTATE_U_BW(&((_dvobj)->iface_state))
+#define DEV_U_OFFSET(_dvobj)		MSTATE_U_OFFSET(&((_dvobj)->iface_state))
+
 #define dvobj_to_pwrctl(dvobj) (&(dvobj->pwrctl_priv))
 #define pwrctl_to_dvobj(pwrctl) container_of(pwrctl, struct dvobj_priv, pwrctl_priv)
 #define dvobj_to_macidctl(dvobj) (&(dvobj->macid_ctl))
+#define dvobj_to_sec_camctl(dvobj) (&(dvobj->cam_ctl))
 #define dvobj_to_regsty(dvobj) (&(dvobj->padapters[IFACE_ID0]->registrypriv))
 #if defined(CONFIG_IOCTL_CFG80211) && defined(RTW_SINGLE_WIPHY)
 #define dvobj_to_wiphy(dvobj) ((dvobj)->wiphy)
@@ -930,6 +1206,25 @@ struct dvobj_priv
 #define dvobj_to_rfctl(dvobj) (&(dvobj->rf_ctl))
 #define rfctl_to_dvobj(rfctl) container_of((rfctl), struct dvobj_priv, rf_ctl)
 
+static inline void dev_set_surprise_removed(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bSurpriseRemoved, _TRUE);
+}
+static inline void dev_clr_surprise_removed(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bSurpriseRemoved, _FALSE);
+}
+static inline void dev_set_drv_stopped(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bDriverStopped, _TRUE);
+}
+static inline void dev_clr_drv_stopped(struct dvobj_priv *dvobj)
+{
+	ATOMIC_SET(&dvobj->bDriverStopped, _FALSE);
+}
+#define dev_is_surprise_removed(dvobj)	(ATOMIC_READ(&dvobj->bSurpriseRemoved) == _TRUE)
+#define dev_is_drv_stopped(dvobj)		(ATOMIC_READ(&dvobj->bDriverStopped) == _TRUE)
+
 #ifdef PLATFORM_LINUX
 static struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
 {
@@ -953,25 +1248,37 @@ static struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
 #endif
 
 _adapter *dvobj_get_port0_adapter(struct dvobj_priv *dvobj);
+_adapter *dvobj_get_unregisterd_adapter(struct dvobj_priv *dvobj);
+_adapter *dvobj_get_adapter_by_addr(struct dvobj_priv *dvobj, u8 *addr);
 #define dvobj_get_primary_adapter(dvobj)	((dvobj)->padapters[IFACE_ID0])
 
-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 _hw_port {
+	HW_PORT0,
+	HW_PORT1,
+	HW_PORT2,
+	HW_PORT3,
+	HW_PORT4,
+	MAX_HW_PORT,
 };
 
 enum _ADAPTER_TYPE {
 	PRIMARY_ADAPTER,
-	SECONDARY_ADAPTER,
+	VIRTUAL_ADAPTER,
 	MAX_ADAPTER = 0xFF,
 };
 
-typedef enum _DRIVER_STATE{
+typedef enum _DRIVER_STATE {
 	DRIVER_NORMAL = 0,
 	DRIVER_DISAPPEAR = 1,
 	DRIVER_REPLACE_DONGLE = 2,
-}DRIVER_STATE;
+} DRIVER_STATE;
+
+#ifdef CONFIG_RTW_NAPI
+enum _NAPI_STATE {
+	NAPI_DISABLE = 0,
+	NAPI_ENABLE = 1,
+};
+#endif
 
 #ifdef CONFIG_INTEL_PROXIM
 struct proxim {
@@ -980,14 +1287,13 @@ struct proxim {
 
 	void *proximity_priv;
 	int (*proxim_rx)(_adapter *padapter,
-		union recv_frame *precv_frame);
-	u8	(*proxim_get_var)(_adapter* padapter, u8 type);
+			 union recv_frame *precv_frame);
+	u8(*proxim_get_var)(_adapter *padapter, u8 type);
 };
-#endif	//CONFIG_INTEL_PROXIM
+#endif /* CONFIG_INTEL_PROXIM */
 
 #ifdef CONFIG_MAC_LOOPBACK_DRIVER
-typedef struct loopbackdata
-{
+typedef struct loopbackdata {
 	_sema	sema;
 	_thread_hdl_ lbkthread;
 	u8 bstop;
@@ -999,39 +1305,49 @@ typedef struct loopbackdata
 	u8 rxbuf[0x8000];
 	u8 msg[100];
 
-}LOOPBACKDATA, *PLOOPBACKDATA;
+} LOOPBACKDATA, *PLOOPBACKDATA;
 #endif
 
+struct tsf_info {
+	u8 sync_port;/*tsf sync from portx*/
+	u8 offset; /*tsf timer offset*/
+};
+
 #define ADAPTER_TX_BW_2G(adapter) BW_MODE_2G((adapter)->driver_tx_bw_mode)
 #define ADAPTER_TX_BW_5G(adapter) BW_MODE_5G((adapter)->driver_tx_bw_mode)
 
-struct _ADAPTER{
-	int	DriverState;// for disable driver using module, use dongle to replace module.
-	int	pid[3];//process id from UI, 0:wps, 1:hostapd, 2:dhcpcd
-	int	bDongle;//build-in module or external dongle
+struct _ADAPTER {
+	int	DriverState;/* for disable driver using module, use dongle to replace module. */
+	int	pid[3];/* process id from UI, 0:wps, 1:hostapd, 2:dhcpcd */
+	int	bDongle;/* build-in module or external dongle */
+
+	_list	list;
 
 	struct dvobj_priv *dvobj;
 	struct	mlme_priv mlmepriv;
 	struct	mlme_ext_priv mlmeextpriv;
 	struct	cmd_priv	cmdpriv;
 	struct	evt_priv	evtpriv;
-	//struct	io_queue	*pio_queue;
-	struct 	io_priv	iopriv;
+
+#ifdef CONFIG_RTW_80211K
+	struct	rm_priv		rmpriv;
+#endif
+	/* struct	io_queue	*pio_queue; */
+	struct	io_priv	iopriv;
 	struct	xmit_priv	xmitpriv;
 	struct	recv_priv	recvpriv;
 	struct	sta_priv	stapriv;
 	struct	security_priv	securitypriv;
-	_lock   security_key_mutex; // add for CONFIG_IEEE80211W, none 11w also can use
-	struct	registry_priv	registrypriv;	
-
-	struct	led_priv	ledpriv;
+	_lock   security_key_mutex; /* add for CONFIG_IEEE80211W, none 11w also can use */
+	struct	registry_priv	registrypriv;
 
-#ifdef CONFIG_MP_INCLUDED
-       struct	mp_priv	mppriv;
+#ifdef CONFIG_RTW_NAPI
+	struct	napi_struct napi;
+	u8	napi_state;
 #endif
 
-#ifdef CONFIG_DRVEXT_MODULE
-	struct	drvext_priv	drvextpriv;
+#ifdef CONFIG_MP_INCLUDED
+	struct	mp_priv	mppriv;
 #endif
 
 #ifdef CONFIG_AP_MODE
@@ -1041,36 +1357,41 @@ struct _ADAPTER{
 #ifdef CONFIG_IOCTL_CFG80211
 #ifdef CONFIG_P2P
 	struct cfg80211_wifidirect_info	cfg80211_wdinfo;
-#endif //CONFIG_P2P
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_P2P */
+#endif /* CONFIG_IOCTL_CFG80211 */
 	u32	setband;
+	ATOMIC_T bandskip;
+
 #ifdef CONFIG_P2P
 	struct wifidirect_info	wdinfo;
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 #ifdef CONFIG_TDLS
 	struct tdls_info	tdlsinfo;
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 #ifdef CONFIG_WAPI_SUPPORT
 	u8	WapiSupport;
 	RT_WAPI_T	wapiInfo;
 #endif
 
+#ifdef CONFIG_RTW_REPEATER_SON
+	u8	rtw_rson_scanstage;
+#endif
 
 #ifdef CONFIG_WFD
 	struct wifi_display_info wfd_info;
-#endif //CONFIG_WFD
+#endif /* CONFIG_WFD */
 
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	struct bt_coex_info coex_info;
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-	
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
 	ERROR_CODE		LastError; /* <20130613, Kordan> Only the functions associated with MP records the error code by now. */
-	
+
 	PVOID			HalData;
 	u32 hal_data_sz;
-	struct hal_ops	HalFunc;
+	struct hal_ops	hal_func;
 
 	u32	IsrContent;
 	u32	ImrContent;
@@ -1079,49 +1400,49 @@ struct _ADAPTER{
 	u8	bDriverIsGoingToUnload;
 	u8	init_adpt_in_progress;
 	u8	bHaltInProgress;
-#ifdef CONFIG_GPIO_API	
+#ifdef CONFIG_GPIO_API
 	u8	pre_gpio_pin;
 	struct gpio_int_priv {
 		u8 interrupt_mode;
 		u8 interrupt_enable_mask;
 		void (*callback[8])(u8 level);
-	}gpiointpriv;
-#endif	
+	} gpiointpriv;
+#endif
 	_thread_hdl_ cmdThread;
+#ifdef CONFIG_EVENT_THREAD_MODE
 	_thread_hdl_ evtThread;
+#endif
+#ifdef CONFIG_XMIT_THREAD_MODE
 	_thread_hdl_ xmitThread;
+#endif
+#ifdef CONFIG_RECV_THREAD_MODE
 	_thread_hdl_ recvThread;
-
+#endif
+	u8 registered;
 #ifndef PLATFORM_LINUX
-	NDIS_STATUS (*dvobj_init)(struct dvobj_priv *dvobj);
+	NDIS_STATUS(*dvobj_init)(struct dvobj_priv *dvobj);
 	void (*dvobj_deinit)(struct dvobj_priv *dvobj);
 #endif
 
- 	u32 (*intf_init)(struct dvobj_priv *dvobj);
-	void (*intf_deinit)(struct dvobj_priv *dvobj);
-	int (*intf_alloc_irq)(struct dvobj_priv *dvobj);
-	void (*intf_free_irq)(struct dvobj_priv *dvobj);
-	
-
-	void (*intf_start)(_adapter * adapter);
-	void (*intf_stop)(_adapter * adapter);
+	void (*intf_start)(_adapter *adapter);
+	void (*intf_stop)(_adapter *adapter);
 
 #ifdef PLATFORM_WINDOWS
-	_nic_hdl		hndis_adapter;//hNdisAdapter(NDISMiniportAdapterHandle);
-	_nic_hdl		hndis_config;//hNdisConfiguration;
+	_nic_hdl		hndis_adapter;/* hNdisAdapter(NDISMiniportAdapterHandle); */
+	_nic_hdl		hndis_config;/* hNdisConfiguration; */
 	NDIS_STRING fw_img;
 
 	u32	NdisPacketFilter;
 	u8	MCList[MAX_MCAST_LIST_NUM][6];
 	u32	MCAddrCount;
-#endif //end of PLATFORM_WINDOWS
+#endif /* end of PLATFORM_WINDOWS */
 
 
 #ifdef PLATFORM_LINUX
 	_nic_hdl pnetdev;
 	char old_ifname[IFNAMSIZ];
 
-	// used by rtw_rereg_nd_name related function
+	/* used by rtw_rereg_nd_name related function */
 	struct rereg_nd_name_data {
 		_nic_hdl old_pnetdev;
 		char old_ifname[IFNAMSIZ];
@@ -1133,16 +1454,20 @@ struct _ADAPTER{
 	int bup;
 	struct net_device_stats stats;
 	struct iw_statistics iwstats;
-	struct proc_dir_entry *dir_dev;// for proc directory
+	struct proc_dir_entry *dir_dev;/* for proc directory */
 	struct proc_dir_entry *dir_odm;
 
+#ifdef CONFIG_MCC_MODE
+	struct proc_dir_entry *dir_mcc;
+#endif /* CONFIG_MCC_MODE */
+
 #ifdef CONFIG_IOCTL_CFG80211
 	struct wireless_dev *rtw_wdev;
 	struct rtw_wdev_priv wdev_data;
 
-	#if !defined(RTW_SINGLE_WIPHY)
+#if !defined(RTW_SINGLE_WIPHY)
 	struct wiphy *wiphy;
-	#endif
+#endif
 
 #endif /* CONFIG_IOCTL_CFG80211 */
 
@@ -1152,54 +1477,44 @@ struct _ADAPTER{
 	_nic_hdl pifp;
 	int bup;
 	_lock glock;
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 	u8 mac_addr[ETH_ALEN];
 	int net_closed;
-	
+
 	u8 netif_up;
 
-	u8 bFWReady;
-	u8 bBTFWReady;
 	u8 bLinkInfoDump;
-	u8 bRxRSSIDisplay;
-	//	Added by Albert 2012/10/26
-	//	The driver will show up the desired channel number when this flag is 1.
+	/*	Added by Albert 2012/10/26 */
+	/*	The driver will show up the desired channel number when this flag is 1. */
 	u8 bNotifyChannelChange;
+	u8 bsta_tp_dump;
 #ifdef CONFIG_P2P
-	//	Added by Albert 2012/12/06
-	//	The driver will show the current P2P status when the upper application reads it.
+	/*	Added by Albert 2012/12/06 */
+	/*	The driver will show the current P2P status when the upper application reads it. */
 	u8 bShowGetP2PState;
 #endif
 #ifdef CONFIG_AUTOSUSPEND
 	u8	bDisableAutosuspend;
 #endif
 
-	//pbuddy_adapter is used only in  two inteface case, (iface_nums=2 in struct dvobj_priv)
-	//PRIMARY_ADAPTER's buddy is SECONDARY_ADAPTER
-	//SECONDARY_ADAPTER's buddy is PRIMARY_ADAPTER
-	//for iface_id > SECONDARY_ADAPTER(IFACE_ID1), refer to padapters[iface_id]  in struct dvobj_priv
-	//and their pbuddy_adapter is PRIMARY_ADAPTER.
-	//for PRIMARY_ADAPTER(IFACE_ID0) can directly refer to if1 in struct dvobj_priv
-	_adapter *pbuddy_adapter;
-
-#if defined(CONFIG_CONCURRENT_MODE)
-	u8 isprimary; //is primary adapter or not
-	//notes:
-	// if isprimary is true, the adapter_type value is 0, iface_id is IFACE_ID0 for PRIMARY_ADAPTER
-	// if isprimary is false, the adapter_type value is 1, iface_id is IFACE_ID1 for SECONDARY_ADAPTER
-	// refer to iface_id if iface_nums>2 and isprimary is false and the adapter_type value is 0xff.
-	u8 adapter_type;//used only in  two inteface case(PRIMARY_ADAPTER and SECONDARY_ADAPTER) .
-	u8 iface_type; //interface port type, it depends on HW port
-#endif //CONFIG_CONCURRENT_MODE 
-
-	//extend to support multi interface
-       //IFACE_ID0 is equals to PRIMARY_ADAPTER
-       //IFACE_ID1 is equals to SECONDARY_ADAPTER
+	u8 isprimary; /* is primary adapter or not */
+	/* notes:
+	**	if isprimary is true, the adapter_type value is 0, iface_id is IFACE_ID0 for PRIMARY_ADAPTER
+	**	if isprimary is false, the adapter_type value is 1, iface_id is IFACE_ID1 for VIRTUAL_ADAPTER
+	**	refer to iface_id if iface_nums>2 and isprimary is false and the adapter_type value is 0xff.*/
+	u8 adapter_type;/*be used in  Multi-interface to recognize whether is PRIMARY_ADAPTER  or not(PRIMARY_ADAPTER/VIRTUAL_ADAPTER) .*/
+	u8 hw_port; /*interface port type, it depends on HW port */
+	struct tsf_info tsf;
+
+
+	/*extend to support multi interface*/
+	/*IFACE_ID0 is equals to PRIMARY_ADAPTER
+	IFACE_ID1 is equals to VIRTUAL_ADAPTER*/
 	u8 iface_id;
 
 #ifdef CONFIG_BR_EXT
 	_lock					br_ext_lock;
-	//unsigned int			macclone_completed;
+	/* unsigned int			macclone_completed; */
 	struct nat25_network_db_entry	*nethash[NAT25_HASH_SIZE];
 	int				pppoe_connection_in_progress;
 	unsigned char			pppoe_addr[MACADDRLEN];
@@ -1210,45 +1525,74 @@ struct _ADAPTER{
 	unsigned char			br_ip[4];
 
 	struct br_ext_info		ethBrExtInfo;
-#endif	// CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
 
 #ifdef CONFIG_INTEL_PROXIM
 	/* intel Proximity, should be alloc mem
 	 * in intel Proximity module and can only
 	 * be used in intel Proximity mode */
 	struct proxim proximity;
-#endif	//CONFIG_INTEL_PROXIM
+#endif /* CONFIG_INTEL_PROXIM */
 
 #ifdef CONFIG_MAC_LOOPBACK_DRIVER
 	PLOOPBACKDATA ploopback;
 #endif
+#ifdef CONFIG_AP_MODE
+	u8 bmc_tx_rate;
+#endif
 
-	//for debug purpose
+	/* for debug purpose */
 	u8 fix_rate;
+	u8 fix_bw;
 	u8 data_fb; /* data rate fallback, valid only when fix_rate is not 0xff */
-
+	u8 power_offset;
 	u8 driver_tx_bw_mode;
+	u8 rsvd_page_offset;
+	u8 rsvd_page_num;
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+	u8 fifo_sel;
+	u32 fifo_addr;
+	u32 fifo_size;
+#endif
 
-	u8 driver_vcs_en; //Enable=1, Disable=0 driver control vrtl_carrier_sense for tx
-	u8 driver_vcs_type;//force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1.
-	u8 driver_ampdu_spacing;//driver control AMPDU Density for peer sta's rx
-	u8 driver_rx_ampdu_factor;//0xff: disable drv ctrl, 0:8k, 1:16k, 2:32k, 3:64k;
-	u8 driver_rx_ampdu_spacing;  //driver control Rx AMPDU Density 
+	u8 driver_vcs_en; /* Enable=1, Disable=0 driver control vrtl_carrier_sense for tx */
+	u8 driver_vcs_type;/* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. */
+	u8 driver_ampdu_spacing;/* driver control AMPDU Density for peer sta's rx */
+	u8 driver_rx_ampdu_factor;/* 0xff: disable drv ctrl, 0:8k, 1:16k, 2:32k, 3:64k; */
+	u8 driver_rx_ampdu_spacing;  /* driver control Rx AMPDU Density */
 	u8 fix_rx_ampdu_accept;
 	u8 fix_rx_ampdu_size; /* 0~127, TODO:consider each sta and each TID */
-	unsigned char     in_cta_test;
-#ifdef DBG_RX_COUNTER_DUMP		
+#ifdef CONFIG_TX_AMSDU
+	u8 tx_amsdu;
+	u16 tx_amsdu_rate;
+#endif
+	u8 driver_tx_max_agg_num; /*fix tx desc max agg num , 0xff: disable drv ctrl*/
+#ifdef DBG_RX_COUNTER_DUMP
 	u8 dump_rx_cnt_mode;/*BIT0:drv,BIT1:mac,BIT2:phy*/
 	u32 drv_rx_cnt_ok;
 	u32 drv_rx_cnt_crcerror;
 	u32 drv_rx_cnt_drop;
 #endif
 
-#ifdef CONFIG_DBG_COUNTER	
+#ifdef CONFIG_DBG_COUNTER
 	struct rx_logs rx_logs;
 	struct tx_logs tx_logs;
 	struct int_logs int_logs;
 #endif
+
+#ifdef CONFIG_MCC_MODE
+	struct mcc_adapter_priv mcc_adapterpriv;
+#endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_MESH
+	struct rtw_mesh_cfg mesh_cfg;
+	struct rtw_mesh_info mesh_info;
+	_timer mesh_path_timer;
+	_timer mesh_path_root_timer;
+	_timer mesh_atlm_param_req_timer; /* airtime link metrics param request timer */
+	_workitem mesh_work;
+	unsigned long wrkq_flags;
+#endif /* CONFIG_RTW_MESH */
 };
 
 #define adapter_to_dvobj(adapter) ((adapter)->dvobj)
@@ -1262,8 +1606,10 @@ struct _ADAPTER{
 #endif
 
 #define adapter_to_rfctl(adapter) dvobj_to_rfctl(adapter_to_dvobj((adapter)))
+#define adapter_to_macidctl(adapter) dvobj_to_macidctl(adapter_to_dvobj((adapter)))
 
 #define adapter_mac_addr(adapter) (adapter->mac_addr)
+#define adapter_to_chset(adapter) (adapter_to_rfctl((adapter))->channel_set)
 
 #define mlme_to_adapter(mlme) container_of((mlme), struct _ADAPTER, mlmepriv)
 #define tdls_info_to_adapter(tdls) container_of((tdls), struct _ADAPTER, tdlsinfo)
@@ -1272,42 +1618,44 @@ struct _ADAPTER{
 #define rtw_get_hw_type(adapter) (((PADAPTER)adapter)->dvobj->HardwareType)
 #define rtw_get_intf_type(adapter) (((PADAPTER)adapter)->dvobj->interface_type)
 
+#define rtw_get_mi_nums(adapter) (((PADAPTER)adapter)->dvobj->iface_nums)
+
 static inline void rtw_set_surprise_removed(_adapter *padapter)
 {
-	ATOMIC_SET(&adapter_to_dvobj(padapter)->bSurpriseRemoved, _TRUE);
+	dev_set_surprise_removed(adapter_to_dvobj(padapter));
 }
 static inline void rtw_clr_surprise_removed(_adapter *padapter)
 {
-	ATOMIC_SET(&adapter_to_dvobj(padapter)->bSurpriseRemoved, _FALSE);
+	dev_clr_surprise_removed(adapter_to_dvobj(padapter));
 }
 static inline void rtw_set_drv_stopped(_adapter *padapter)
 {
-	ATOMIC_SET(&adapter_to_dvobj(padapter)->bDriverStopped, _TRUE);
+	dev_set_drv_stopped(adapter_to_dvobj(padapter));
 }
 static inline void rtw_clr_drv_stopped(_adapter *padapter)
 {
-	ATOMIC_SET(&adapter_to_dvobj(padapter)->bDriverStopped, _FALSE);
+	dev_clr_drv_stopped(adapter_to_dvobj(padapter));
 }
-#define rtw_is_surprise_removed(padapter)	(ATOMIC_READ(&adapter_to_dvobj(padapter)->bSurpriseRemoved) == _TRUE)
-#define rtw_is_drv_stopped(padapter)		(ATOMIC_READ(&adapter_to_dvobj(padapter)->bDriverStopped) == _TRUE)
+#define rtw_is_surprise_removed(padapter)	(dev_is_surprise_removed(adapter_to_dvobj(padapter)))
+#define rtw_is_drv_stopped(padapter)		(dev_is_drv_stopped(adapter_to_dvobj(padapter)))
 
-//
-// Function disabled.
-//
+/*
+ * Function disabled.
+ *   */
 #define DF_TX_BIT		BIT0			/*write_port_cancel*/
 #define DF_RX_BIT		BIT1			/*read_port_cancel*/
 #define DF_IO_BIT		BIT2
 
-//#define RTW_DISABLE_FUNC(padapter, func) (ATOMIC_ADD(&adapter_to_dvobj(padapter)->disable_func, (func)))
-//#define RTW_ENABLE_FUNC(padapter, func) (ATOMIC_SUB(&adapter_to_dvobj(padapter)->disable_func, (func)))
-__inline static void RTW_DISABLE_FUNC(_adapter*padapter, int func_bit)
+/* #define RTW_DISABLE_FUNC(padapter, func) (ATOMIC_ADD(&adapter_to_dvobj(padapter)->disable_func, (func))) */
+/* #define RTW_ENABLE_FUNC(padapter, func) (ATOMIC_SUB(&adapter_to_dvobj(padapter)->disable_func, (func))) */
+__inline static void RTW_DISABLE_FUNC(_adapter *padapter, int func_bit)
 {
 	int	df = ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func);
 	df |= func_bit;
 	ATOMIC_SET(&adapter_to_dvobj(padapter)->disable_func, df);
 }
 
-__inline static void RTW_ENABLE_FUNC(_adapter*padapter, int func_bit)
+__inline static void RTW_ENABLE_FUNC(_adapter *padapter, int func_bit)
 {
 	int	df = ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func);
 	df &= ~(func_bit);
@@ -1315,61 +1663,61 @@ __inline static void RTW_ENABLE_FUNC(_adapter*padapter, int func_bit)
 }
 
 #define RTW_CANNOT_RUN(padapter) \
-			(rtw_is_surprise_removed(padapter) || \
-				rtw_is_drv_stopped(padapter))
+	(rtw_is_surprise_removed(padapter) || \
+	 rtw_is_drv_stopped(padapter))
 
 #define RTW_IS_FUNC_DISABLED(padapter, func_bit) (ATOMIC_READ(&adapter_to_dvobj(padapter)->disable_func) & (func_bit))
 
 #define RTW_CANNOT_IO(padapter) \
-			(rtw_is_surprise_removed(padapter) || \
-				RTW_IS_FUNC_DISABLED((padapter), DF_IO_BIT))
+	(rtw_is_surprise_removed(padapter) || \
+	 RTW_IS_FUNC_DISABLED((padapter), DF_IO_BIT))
 
 #define RTW_CANNOT_RX(padapter) \
-			(RTW_CANNOT_RUN(padapter) || \
-			 RTW_IS_FUNC_DISABLED((padapter), DF_RX_BIT))
+	(RTW_CANNOT_RUN(padapter) || \
+	 RTW_IS_FUNC_DISABLED((padapter), DF_RX_BIT))
 
 #define RTW_CANNOT_TX(padapter) \
-			(RTW_CANNOT_RUN(padapter) || \
-			 RTW_IS_FUNC_DISABLED((padapter), DF_TX_BIT))
+	(RTW_CANNOT_RUN(padapter) || \
+	 RTW_IS_FUNC_DISABLED((padapter), DF_TX_BIT))
 
 #ifdef CONFIG_PNO_SUPPORT
-int rtw_parse_ssid_list_tlv(char** list_str, pno_ssid_t* ssid, int max, int *bytes_left);
-int rtw_dev_pno_set(struct net_device *net, pno_ssid_t* ssid, int num, 
-					int pno_time, int pno_repeat, int pno_freq_expo_max);
+int rtw_parse_ssid_list_tlv(char **list_str, pno_ssid_t *ssid, int max, int *bytes_left);
+int rtw_dev_pno_set(struct net_device *net, pno_ssid_t *ssid, int num,
+		    int pno_time, int pno_repeat, int pno_freq_expo_max);
 #ifdef CONFIG_PNO_SET_DEBUG
-void rtw_dev_pno_debug(struct net_device *net);
-#endif //CONFIG_PNO_SET_DEBUG
-#endif //CONFIG_PNO_SUPPORT
+	void rtw_dev_pno_debug(struct net_device *net);
+#endif /* CONFIG_PNO_SET_DEBUG */
+#endif /* CONFIG_PNO_SUPPORT */
 
+int rtw_suspend_free_assoc_resource(_adapter *padapter);
 #ifdef CONFIG_WOWLAN
-int rtw_suspend_wow(_adapter *padapter);
-int rtw_resume_process_wow(_adapter *padapter);
+	int rtw_suspend_wow(_adapter *padapter);
+	int rtw_resume_process_wow(_adapter *padapter);
 #endif
 
-// HCI Related header file
+/* HCI Related header file */
 #ifdef CONFIG_USB_HCI
-#include <usb_osintf.h>
-#include <usb_ops.h>
-#include <usb_hal.h>
+	#include <usb_osintf.h>
+	#include <usb_ops.h>
+	#include <usb_hal.h>
 #endif
 
 #ifdef CONFIG_SDIO_HCI
-#include <sdio_osintf.h>
-#include <sdio_ops.h>
-#include <sdio_hal.h>
+	#include <sdio_osintf.h>
+	#include <sdio_ops.h>
+	#include <sdio_hal.h>
 #endif
 
 #ifdef CONFIG_GSPI_HCI
-#include <gspi_osintf.h>
-#include <gspi_ops.h>
-#include <gspi_hal.h>
+	#include <gspi_osintf.h>
+	#include <gspi_ops.h>
+	#include <gspi_hal.h>
 #endif
 
 #ifdef CONFIG_PCI_HCI
-#include <pci_osintf.h>
-#include <pci_ops.h>
-#include <pci_hal.h>
+	#include <pci_osintf.h>
+	#include <pci_ops.h>
+	#include <pci_hal.h>
 #endif
 
-#endif //__DRV_TYPES_H__
-
+#endif /* __DRV_TYPES_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_ce.h
index b3d35235c5fd..a8e8e2a07546 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_ce.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __DRV_TYPES_CE_H__
 #define __DRV_TYPES_CE_H__
 
@@ -31,56 +27,55 @@
 
 
 
-//for ioctl
-#define MAKE_DRIVER_VERSION(_MainVer,_MinorVer)	((((u32)(_MainVer))<<16)+_MinorVer)
+/* for ioctl */
+#define MAKE_DRIVER_VERSION(_MainVer, _MinorVer)	((((u32)(_MainVer))<<16)+_MinorVer)
 
-#define NIC_HEADER_SIZE				14			//!< can be moved to typedef.h
-#define NIC_MAX_PACKET_SIZE			1514		//!< can be moved to typedef.h
-#define NIC_MAX_SEND_PACKETS			10		// max number of send packets the MiniportSendPackets function can accept, can be moved to typedef.h
-#define NIC_VENDOR_DRIVER_VERSION       MAKE_DRIVER_VERSION(0,001)	//!< can be moved to typedef.h
-#define NIC_MAX_PACKET_SIZE			1514		//!< can be moved to typedef.h
+#define NIC_HEADER_SIZE				14			/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
+#define NIC_MAX_SEND_PACKETS			10		/* max number of send packets the MiniportSendPackets function can accept, can be moved to typedef.h */
+#define NIC_VENDOR_DRIVER_VERSION       MAKE_DRIVER_VERSION(0, 001)	/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
 
-typedef struct _MP_REG_ENTRY
-{
+typedef struct _MP_REG_ENTRY {
 
-	NDIS_STRING		RegName;	// variable name text
-	BOOLEAN			bRequired;	// 1 -> required, 0 -> optional
+	NDIS_STRING		RegName;	/* variable name text */
+	BOOLEAN			bRequired;	/* 1->required, 0->optional */
+
+	u8			Type;		/* NdisParameterInteger/NdisParameterHexInteger/NdisParameterStringle/NdisParameterMultiString */
+	uint			FieldOffset;	/* offset to MP_ADAPTER field */
+	uint			FieldSize;	/* size (in bytes) of the field */
 
-	u8			Type;		// NdisParameterInteger/NdisParameterHexInteger/NdisParameterStringle/NdisParameterMultiString
-	uint			FieldOffset;	// offset to MP_ADAPTER field
-	uint			FieldSize;	// size (in bytes) of the field
-	
 #ifdef UNDER_AMD64
 	u64			Default;
 #else
-	u32			Default;		// default value to use
+	u32			Default;		/* default value to use */
 #endif
 
-	u32			Min;			// minimum value allowed
-	u32			Max;		// maximum value allowed
+	u32			Min;			/* minimum value allowed */
+	u32			Max;		/* maximum value allowed */
 } MP_REG_ENTRY, *PMP_REG_ENTRY;
 
 #ifdef CONFIG_USB_HCI
 typedef struct _USB_EXTENSION {
-    LPCUSB_FUNCS    _lpUsbFuncs;
+	LPCUSB_FUNCS    _lpUsbFuncs;
 	USB_HANDLE	    _hDevice;
-    PVOID 		    pAdapter;
+	PVOID		    pAdapter;
 
 #if 0
 	USB_ENDPOINT_DESCRIPTOR		_endpACLIn;
-    USB_ENDPOINT_DESCRIPTOR		_endpACLOutHigh;
+	USB_ENDPOINT_DESCRIPTOR		_endpACLOutHigh;
 	USB_ENDPOINT_DESCRIPTOR		_endpACLOutNormal;
 
 	USB_PIPE        pPipeIn;
-    USB_PIPE        pPipeOutNormal;
-    USB_PIPE        pPipeOutHigh;
+	USB_PIPE        pPipeOutNormal;
+	USB_PIPE        pPipeOutHigh;
 #endif
 
 } USB_EXTENSION, *PUSB_EXTENSION;
 #endif
 
 
-typedef struct _OCTET_STRING{
+typedef struct _OCTET_STRING {
 	u8      *Octet;
 	u16      Length;
 } OCTET_STRING, *POCTET_STRING;
@@ -90,4 +85,3 @@ typedef struct _OCTET_STRING{
 
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_gspi.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_gspi.h
index 27b3cb074d37..142ff0d5884e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_gspi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_gspi.h
@@ -1,56 +1,50 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __DRV_TYPES_GSPI_H__
-#define __DRV_TYPES_GSPI_H__
-
-// SPI Header Files
-#ifdef PLATFORM_LINUX
-	#include <linux/platform_device.h>
-	#include <linux/spi/spi.h>
-	#include <linux/gpio.h>
-	//#include <mach/ldo.h>
-	#include <asm/mach-types.h>
-	#include <asm/gpio.h>
-	#include <asm/io.h>
-	#include <mach/board.h>
-	#include <mach/hardware.h>
-	#include <mach/irqs.h>
-	#include <custom_gpio.h>
-#endif
-
-
-typedef struct gspi_data
-{
-	u8  func_number;
-
-	u8  tx_block_mode;
-	u8  rx_block_mode;
-	u32 block_transfer_len;
-
-#ifdef PLATFORM_LINUX
-	struct spi_device *func;
-
-	struct workqueue_struct *priv_wq;
-	struct delayed_work irq_work;
-#endif
-} GSPI_DATA, *PGSPI_DATA;
-
-#endif // #ifndef __DRV_TYPES_GSPI_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_GSPI_H__
+#define __DRV_TYPES_GSPI_H__
+
+/* SPI Header Files */
+#ifdef PLATFORM_LINUX
+	#include <linux/platform_device.h>
+	#include <linux/spi/spi.h>
+	#include <linux/gpio.h>
+	/* #include <mach/ldo.h> */
+	#include <asm/mach-types.h>
+	#include <asm/gpio.h>
+	#include <asm/io.h>
+	#include <mach/board.h>
+	#include <mach/hardware.h>
+	#include <mach/irqs.h>
+	#include <custom_gpio.h>
+#endif
+
+
+typedef struct gspi_data {
+	u8  func_number;
+
+	u8  tx_block_mode;
+	u8  rx_block_mode;
+	u32 block_transfer_len;
+
+#ifdef PLATFORM_LINUX
+	struct spi_device *func;
+
+	struct workqueue_struct *priv_wq;
+	struct delayed_work irq_work;
+#endif
+} GSPI_DATA, *PGSPI_DATA;
+
+#endif /*  #ifndef __DRV_TYPES_GSPI_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_linux.h
index db1c585690ff..66e88cfe4b31 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_linux.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,15 +12,9 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __DRV_TYPES_LINUX_H__
 #define __DRV_TYPES_LINUX_H__
 
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_pci.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_pci.h
index a5b52ac783f8..4222c1b5fbff 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_pci.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_pci.h
@@ -1,273 +1,267 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __DRV_TYPES_PCI_H__
-#define __DRV_TYPES_PCI_H__
-
-
-#ifdef PLATFORM_LINUX
-#include <linux/pci.h>
-#endif
-
-
-#define	INTEL_VENDOR_ID				0x8086
-#define	SIS_VENDOR_ID					0x1039
-#define	ATI_VENDOR_ID					0x1002
-#define	ATI_DEVICE_ID					0x7914
-#define	AMD_VENDOR_ID					0x1022
-
-#define	PCI_MAX_BRIDGE_NUMBER			255
-#define	PCI_MAX_DEVICES				32
-#define	PCI_MAX_FUNCTION				8
-
-#define	PCI_CONF_ADDRESS   				0x0CF8   // PCI Configuration Space Address 
-#define	PCI_CONF_DATA					0x0CFC   // PCI Configuration Space Data 
-
-#define	PCI_CLASS_BRIDGE_DEV			0x06
-#define	PCI_SUBCLASS_BR_PCI_TO_PCI	0x04
-
-#define 	PCI_CAPABILITY_ID_PCI_EXPRESS	0x10
-
-#define	U1DONTCARE 					0xFF	
-#define	U2DONTCARE 					0xFFFF	
-#define	U4DONTCARE 					0xFFFFFFFF
-
-#define PCI_VENDER_ID_REALTEK		0x10ec
-
-#define HAL_HW_PCI_8180_DEVICE_ID           	0x8180
-#define HAL_HW_PCI_8185_DEVICE_ID           	0x8185	//8185 or 8185b
-#define HAL_HW_PCI_8188_DEVICE_ID           	0x8188	//8185b		
-#define HAL_HW_PCI_8198_DEVICE_ID           	0x8198	//8185b		
-#define HAL_HW_PCI_8190_DEVICE_ID           	0x8190	//8190
-#define HAL_HW_PCI_8723E_DEVICE_ID		0x8723	//8723E
-#define HAL_HW_PCI_8192_DEVICE_ID           	0x8192	//8192 PCI-E
-#define HAL_HW_PCI_8192SE_DEVICE_ID		0x8192	//8192 SE
-#define HAL_HW_PCI_8174_DEVICE_ID           	0x8174	//8192 SE 
-#define HAL_HW_PCI_8173_DEVICE_ID           	0x8173	//8191 SE Crab
-#define HAL_HW_PCI_8172_DEVICE_ID           	0x8172	//8191 SE RE
-#define HAL_HW_PCI_8171_DEVICE_ID           	0x8171	//8191 SE Unicron
-#define HAL_HW_PCI_0045_DEVICE_ID			0x0045	//8190 PCI for Ceraga
-#define HAL_HW_PCI_0046_DEVICE_ID			0x0046	//8190 Cardbus for Ceraga
-#define HAL_HW_PCI_0044_DEVICE_ID			0x0044	//8192e PCIE for Ceraga
-#define HAL_HW_PCI_0047_DEVICE_ID			0x0047	//8192e Express Card for Ceraga
-#define HAL_HW_PCI_700F_DEVICE_ID			0x700F
-#define HAL_HW_PCI_701F_DEVICE_ID			0x701F
-#define HAL_HW_PCI_DLINK_DEVICE_ID		0x3304
-#define HAL_HW_PCI_8188EE_DEVICE_ID		0x8179
-
-#define HAL_MEMORY_MAPPED_IO_RANGE_8190PCI 		0x1000     //8190 support 16 pages of IO registers
-#define HAL_HW_PCI_REVISION_ID_8190PCI			0x00
-#define HAL_MEMORY_MAPPED_IO_RANGE_8192PCIE	0x4000	//8192 support 16 pages of IO registers
-#define HAL_HW_PCI_REVISION_ID_8192PCIE			0x01
-#define HAL_MEMORY_MAPPED_IO_RANGE_8192SE		0x4000	//8192 support 16 pages of IO registers
-#define HAL_HW_PCI_REVISION_ID_8192SE			0x10
-#define HAL_HW_PCI_REVISION_ID_8192CE			0x1
-#define HAL_MEMORY_MAPPED_IO_RANGE_8192CE		0x4000	//8192 support 16 pages of IO registers
-#define HAL_HW_PCI_REVISION_ID_8192DE			0x0
-#define HAL_MEMORY_MAPPED_IO_RANGE_8192DE		0x4000	//8192 support 16 pages of IO registers
-
-enum pci_bridge_vendor {
-	PCI_BRIDGE_VENDOR_INTEL = 0x0,//0b'0000,0001
-	PCI_BRIDGE_VENDOR_ATI, //= 0x02,//0b'0000,0010
-	PCI_BRIDGE_VENDOR_AMD, //= 0x04,//0b'0000,0100
-	PCI_BRIDGE_VENDOR_SIS ,//= 0x08,//0b'0000,1000
-	PCI_BRIDGE_VENDOR_UNKNOWN, //= 0x40,//0b'0100,0000
-	PCI_BRIDGE_VENDOR_MAX ,//= 0x80
-} ;
-
-// copy this data structor defination from MSDN SDK
-typedef struct _PCI_COMMON_CONFIG {
-	u16	VendorID;
-	u16	DeviceID;
-	u16	Command;
-	u16	Status;
-	u8	RevisionID;
-	u8	ProgIf;
-	u8	SubClass;
-	u8	BaseClass;
-	u8	CacheLineSize;
-	u8	LatencyTimer;
-	u8	HeaderType;
-	u8	BIST;
-
-	union {
-	struct _PCI_HEADER_TYPE_0 {
-		u32	BaseAddresses[6];
-		u32	CIS;
-		u16	SubVendorID;
-		u16	SubSystemID;
-		u32	ROMBaseAddress;
-		u8	CapabilitiesPtr;
-		u8	Reserved1[3];
-		u32	Reserved2;
-
-		u8	InterruptLine;
-		u8	InterruptPin;
-		u8	MinimumGrant;
-		u8	MaximumLatency;
-	} type0;
-#if 0
-	struct _PCI_HEADER_TYPE_1 {
-		ULONG BaseAddresses[PCI_TYPE1_ADDRESSES];
-		UCHAR PrimaryBusNumber;
-		UCHAR SecondaryBusNumber;
-		UCHAR SubordinateBusNumber;
-		UCHAR SecondaryLatencyTimer;
-		UCHAR IOBase;
-		UCHAR IOLimit;
-		USHORT SecondaryStatus;
-		USHORT MemoryBase;
-		USHORT MemoryLimit;
-		USHORT PrefetchableMemoryBase;
-		USHORT PrefetchableMemoryLimit;
-		ULONG PrefetchableMemoryBaseUpper32;
-		ULONG PrefetchableMemoryLimitUpper32;
-		USHORT IOBaseUpper;
-		USHORT IOLimitUpper;
-		ULONG Reserved2;
-		ULONG ExpansionROMBase;
-		UCHAR InterruptLine;
-		UCHAR InterruptPin;
-		USHORT BridgeControl;
-	} type1;
-
-	struct _PCI_HEADER_TYPE_2 {
-		ULONG BaseAddress;
-		UCHAR CapabilitiesPtr;
-		UCHAR Reserved2;
-		USHORT SecondaryStatus;
-		UCHAR PrimaryBusNumber;
-		UCHAR CardbusBusNumber;
-		UCHAR SubordinateBusNumber;
-		UCHAR CardbusLatencyTimer;
-		ULONG MemoryBase0;
-		ULONG MemoryLimit0;
-		ULONG MemoryBase1;
-		ULONG MemoryLimit1;
-		USHORT IOBase0_LO;
-		USHORT IOBase0_HI;
-		USHORT IOLimit0_LO;
-		USHORT IOLimit0_HI;
-		USHORT IOBase1_LO;
-		USHORT IOBase1_HI;
-		USHORT IOLimit1_LO;
-		USHORT IOLimit1_HI;
-		UCHAR InterruptLine;
-		UCHAR InterruptPin;
-		USHORT BridgeControl;
-		USHORT SubVendorID;
-		USHORT SubSystemID;
-		ULONG LegacyBaseAddress;
-		UCHAR Reserved3[56];
-		ULONG SystemControl;
-		UCHAR MultiMediaControl;
-		UCHAR GeneralStatus;
-		UCHAR Reserved4[2];
-		UCHAR GPIO0Control;
-		UCHAR GPIO1Control;
-		UCHAR GPIO2Control;
-		UCHAR GPIO3Control;
-		ULONG IRQMuxRouting;
-		UCHAR RetryStatus;
-		UCHAR CardControl;
-		UCHAR DeviceControl;
-		UCHAR Diagnostic;
-	} type2;
-#endif
-	} u;
-
-	u8	DeviceSpecific[108];
-} PCI_COMMON_CONFIG , *PPCI_COMMON_CONFIG;
-
-typedef struct _RT_PCI_CAPABILITIES_HEADER {
-    u8   CapabilityID;
-    u8   Next;
-} RT_PCI_CAPABILITIES_HEADER, *PRT_PCI_CAPABILITIES_HEADER;
-
-struct pci_priv{
-	BOOLEAN		pci_clk_req;
-	
-	u8	pciehdr_offset;
-	//  PCIeCap is only differece between B-cut and C-cut.
-	//  Configuration Space offset 72[7:4] 
-	//  0: A/B cut 
-	//  1: C cut and later.
-	u8	pcie_cap;
-	u8	linkctrl_reg;
-	
-	u8	busnumber;
-	u8	devnumber;	
-	u8	funcnumber;	
-
-	u8	pcibridge_busnum;
-	u8	pcibridge_devnum;
-	u8	pcibridge_funcnum;
-	u8	pcibridge_vendor;
-	u16	pcibridge_vendorid;
-	u16	pcibridge_deviceid;
-	u8	pcibridge_pciehdr_offset;
-	u8	pcibridge_linkctrlreg;	
-
-	u8	amd_l1_patch;
-};
-
-typedef struct _RT_ISR_CONTENT
-{
-	union{
-		u32			IntArray[2];
-		u32			IntReg4Byte;
-		u16			IntReg2Byte;
-	};
-}RT_ISR_CONTENT, *PRT_ISR_CONTENT;
-
-//#define RegAddr(addr)           (addr + 0xB2000000UL)
-//some platform macros will def here
-static inline void NdisRawWritePortUlong(u32 port,  u32 val) 		
-{
-	outl(val, port);
-	//writel(val, (u8 *)RegAddr(port));	
-}
-
-static inline void NdisRawWritePortUchar(u32 port,  u8 val)
-{
-	outb(val, port);
-	//writeb(val, (u8 *)RegAddr(port));
-}
-
-static inline void NdisRawReadPortUchar(u32 port, u8 *pval)
-{
-	*pval = inb(port);
-	//*pval = readb((u8 *)RegAddr(port));
-}
-
-static inline void NdisRawReadPortUshort(u32 port, u16 *pval)
-{
-	*pval = inw(port);
-	//*pval = readw((u8 *)RegAddr(port));
-}
-
-static inline void NdisRawReadPortUlong(u32 port, u32 *pval)
-{
-	*pval = inl(port);
-	//*pval = readl((u8 *)RegAddr(port));
-}
-
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_PCI_H__
+#define __DRV_TYPES_PCI_H__
+
+
+#ifdef PLATFORM_LINUX
+	#include <linux/pci.h>
+#endif
+
+
+#define	INTEL_VENDOR_ID				0x8086
+#define	SIS_VENDOR_ID					0x1039
+#define	ATI_VENDOR_ID					0x1002
+#define	ATI_DEVICE_ID					0x7914
+#define	AMD_VENDOR_ID					0x1022
+
+#define	PCI_MAX_BRIDGE_NUMBER			255
+#define	PCI_MAX_DEVICES				32
+#define	PCI_MAX_FUNCTION				8
+
+#define	PCI_CONF_ADDRESS   				0x0CF8   /* PCI Configuration Space Address */
+#define	PCI_CONF_DATA					0x0CFC   /* PCI Configuration Space Data */
+
+#define	PCI_CLASS_BRIDGE_DEV			0x06
+#define	PCI_SUBCLASS_BR_PCI_TO_PCI	0x04
+
+#define	PCI_CAPABILITY_ID_PCI_EXPRESS	0x10
+
+#define	U1DONTCARE					0xFF
+#define	U2DONTCARE					0xFFFF
+#define	U4DONTCARE					0xFFFFFFFF
+
+#define PCI_VENDER_ID_REALTEK		0x10ec
+
+#define HAL_HW_PCI_8180_DEVICE_ID	0x8180
+#define HAL_HW_PCI_8185_DEVICE_ID           	0x8185	/* 8185 or 8185b */
+#define HAL_HW_PCI_8188_DEVICE_ID           	0x8188	/* 8185b		 */
+#define HAL_HW_PCI_8198_DEVICE_ID           	0x8198	/* 8185b		 */
+#define HAL_HW_PCI_8190_DEVICE_ID           	0x8190	/* 8190 */
+#define HAL_HW_PCI_8723E_DEVICE_ID		0x8723	/* 8723E */
+#define HAL_HW_PCI_8192_DEVICE_ID           	0x8192	/* 8192 PCI-E */
+#define HAL_HW_PCI_8192SE_DEVICE_ID		0x8192	/* 8192 SE */
+#define HAL_HW_PCI_8174_DEVICE_ID           	0x8174	/* 8192 SE */
+#define HAL_HW_PCI_8173_DEVICE_ID           	0x8173	/* 8191 SE Crab */
+#define HAL_HW_PCI_8172_DEVICE_ID           	0x8172	/* 8191 SE RE */
+#define HAL_HW_PCI_8171_DEVICE_ID           	0x8171	/* 8191 SE Unicron */
+#define HAL_HW_PCI_0045_DEVICE_ID			0x0045	/* 8190 PCI for Ceraga */
+#define HAL_HW_PCI_0046_DEVICE_ID			0x0046	/* 8190 Cardbus for Ceraga */
+#define HAL_HW_PCI_0044_DEVICE_ID			0x0044	/* 8192e PCIE for Ceraga */
+#define HAL_HW_PCI_0047_DEVICE_ID			0x0047	/* 8192e Express Card for Ceraga */
+#define HAL_HW_PCI_700F_DEVICE_ID			0x700F
+#define HAL_HW_PCI_701F_DEVICE_ID			0x701F
+#define HAL_HW_PCI_DLINK_DEVICE_ID		0x3304
+#define HAL_HW_PCI_8188EE_DEVICE_ID		0x8179
+
+#define HAL_MEMORY_MAPPED_IO_RANGE_8190PCI 		0x1000     /* 8190 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8190PCI			0x00
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192PCIE	0x4000	/* 8192 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8192PCIE			0x01
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192SE		0x4000	/* 8192 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8192SE			0x10
+#define HAL_HW_PCI_REVISION_ID_8192CE			0x1
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192CE		0x4000	/* 8192 support 16 pages of IO registers */
+#define HAL_HW_PCI_REVISION_ID_8192DE			0x0
+#define HAL_MEMORY_MAPPED_IO_RANGE_8192DE		0x4000	/* 8192 support 16 pages of IO registers */
+
+enum pci_bridge_vendor {
+	PCI_BRIDGE_VENDOR_INTEL = 0x0,/* 0b'0000,0001 */
+	PCI_BRIDGE_VENDOR_ATI, /* = 0x02, */ /* 0b'0000,0010 */
+	PCI_BRIDGE_VENDOR_AMD, /* = 0x04, */ /* 0b'0000,0100 */
+	PCI_BRIDGE_VENDOR_SIS ,/* = 0x08, */ /* 0b'0000,1000 */
+	PCI_BRIDGE_VENDOR_UNKNOWN, /* = 0x40, */ /* 0b'0100,0000 */
+	PCI_BRIDGE_VENDOR_MAX ,/* = 0x80 */
+} ;
+
+/* copy this data structor defination from MSDN SDK */
+typedef struct _PCI_COMMON_CONFIG {
+	u16	VendorID;
+	u16	DeviceID;
+	u16	Command;
+	u16	Status;
+	u8	RevisionID;
+	u8	ProgIf;
+	u8	SubClass;
+	u8	BaseClass;
+	u8	CacheLineSize;
+	u8	LatencyTimer;
+	u8	HeaderType;
+	u8	BIST;
+
+	union {
+		struct _PCI_HEADER_TYPE_0 {
+			u32	BaseAddresses[6];
+			u32	CIS;
+			u16	SubVendorID;
+			u16	SubSystemID;
+			u32	ROMBaseAddress;
+			u8	CapabilitiesPtr;
+			u8	Reserved1[3];
+			u32	Reserved2;
+
+			u8	InterruptLine;
+			u8	InterruptPin;
+			u8	MinimumGrant;
+			u8	MaximumLatency;
+		} type0;
+#if 0
+		struct _PCI_HEADER_TYPE_1 {
+			ULONG BaseAddresses[PCI_TYPE1_ADDRESSES];
+			UCHAR PrimaryBusNumber;
+			UCHAR SecondaryBusNumber;
+			UCHAR SubordinateBusNumber;
+			UCHAR SecondaryLatencyTimer;
+			UCHAR IOBase;
+			UCHAR IOLimit;
+			USHORT SecondaryStatus;
+			USHORT MemoryBase;
+			USHORT MemoryLimit;
+			USHORT PrefetchableMemoryBase;
+			USHORT PrefetchableMemoryLimit;
+			ULONG PrefetchableMemoryBaseUpper32;
+			ULONG PrefetchableMemoryLimitUpper32;
+			USHORT IOBaseUpper;
+			USHORT IOLimitUpper;
+			ULONG Reserved2;
+			ULONG ExpansionROMBase;
+			UCHAR InterruptLine;
+			UCHAR InterruptPin;
+			USHORT BridgeControl;
+		} type1;
+
+		struct _PCI_HEADER_TYPE_2 {
+			ULONG BaseAddress;
+			UCHAR CapabilitiesPtr;
+			UCHAR Reserved2;
+			USHORT SecondaryStatus;
+			UCHAR PrimaryBusNumber;
+			UCHAR CardbusBusNumber;
+			UCHAR SubordinateBusNumber;
+			UCHAR CardbusLatencyTimer;
+			ULONG MemoryBase0;
+			ULONG MemoryLimit0;
+			ULONG MemoryBase1;
+			ULONG MemoryLimit1;
+			USHORT IOBase0_LO;
+			USHORT IOBase0_HI;
+			USHORT IOLimit0_LO;
+			USHORT IOLimit0_HI;
+			USHORT IOBase1_LO;
+			USHORT IOBase1_HI;
+			USHORT IOLimit1_LO;
+			USHORT IOLimit1_HI;
+			UCHAR InterruptLine;
+			UCHAR InterruptPin;
+			USHORT BridgeControl;
+			USHORT SubVendorID;
+			USHORT SubSystemID;
+			ULONG LegacyBaseAddress;
+			UCHAR Reserved3[56];
+			ULONG SystemControl;
+			UCHAR MultiMediaControl;
+			UCHAR GeneralStatus;
+			UCHAR Reserved4[2];
+			UCHAR GPIO0Control;
+			UCHAR GPIO1Control;
+			UCHAR GPIO2Control;
+			UCHAR GPIO3Control;
+			ULONG IRQMuxRouting;
+			UCHAR RetryStatus;
+			UCHAR CardControl;
+			UCHAR DeviceControl;
+			UCHAR Diagnostic;
+		} type2;
+#endif
+	} u;
+
+	u8	DeviceSpecific[108];
+} PCI_COMMON_CONFIG , *PPCI_COMMON_CONFIG;
+
+typedef struct _RT_PCI_CAPABILITIES_HEADER {
+	u8   CapabilityID;
+	u8   Next;
+} RT_PCI_CAPABILITIES_HEADER, *PRT_PCI_CAPABILITIES_HEADER;
+
+struct pci_priv {
+	BOOLEAN		pci_clk_req;
+
+	u8	pciehdr_offset;
+	/* PCIeCap is only differece between B-cut and C-cut. */
+	/* Configuration Space offset 72[7:4] */
+	/* 0: A/B cut */
+	/* 1: C cut and later. */
+	u8	pcie_cap;
+	u8	linkctrl_reg;
+
+	u8	busnumber;
+	u8	devnumber;
+	u8	funcnumber;
+
+	u8	pcibridge_busnum;
+	u8	pcibridge_devnum;
+	u8	pcibridge_funcnum;
+	u8	pcibridge_vendor;
+	u16	pcibridge_vendorid;
+	u16	pcibridge_deviceid;
+	u8	pcibridge_pciehdr_offset;
+	u8	pcibridge_linkctrlreg;
+
+	u8	amd_l1_patch;
+};
+
+typedef struct _RT_ISR_CONTENT {
+	union {
+		u32			IntArray[2];
+		u32			IntReg4Byte;
+		u16			IntReg2Byte;
+	};
+} RT_ISR_CONTENT, *PRT_ISR_CONTENT;
+
+/* #define RegAddr(addr)           (addr + 0xB2000000UL) */
+/* some platform macros will def here */
+static inline void NdisRawWritePortUlong(u32 port,  u32 val)
+{
+	outl(val, port);
+	/* writel(val, (u8 *)RegAddr(port));	 */
+}
+
+static inline void NdisRawWritePortUchar(u32 port,  u8 val)
+{
+	outb(val, port);
+	/* writeb(val, (u8 *)RegAddr(port)); */
+}
+
+static inline void NdisRawReadPortUchar(u32 port, u8 *pval)
+{
+	*pval = inb(port);
+	/* *pval = readb((u8 *)RegAddr(port)); */
+}
+
+static inline void NdisRawReadPortUshort(u32 port, u16 *pval)
+{
+	*pval = inw(port);
+	/* *pval = readw((u8 *)RegAddr(port)); */
+}
+
+static inline void NdisRawReadPortUlong(u32 port, u32 *pval)
+{
+	*pval = inl(port);
+	/* *pval = readl((u8 *)RegAddr(port)); */
+}
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_sdio.h
index 044ef5125f5d..a143e26fdfb2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_sdio.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_sdio.h
@@ -1,81 +1,91 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __DRV_TYPES_SDIO_H__
-#define __DRV_TYPES_SDIO_H__
-
-// SDIO Header Files
-#ifdef PLATFORM_LINUX
-	#include <linux/mmc/sdio_func.h> 
-	#include <linux/mmc/sdio_ids.h>
-
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_PLATFORM_SPRD)
-	#include <linux/mmc/host.h>
-	#include <linux/mmc/card.h>
-#endif
-
-#ifdef CONFIG_PLATFORM_SPRD
-	#include <linux/gpio.h>
-	#include <custom_gpio.h>
-#endif // CONFIG_PLATFORM_SPRD
-#endif
-
-#ifdef PLATFORM_OS_XP
-#include <wdm.h>
-#include <ntddsd.h>
-#endif
-
-#ifdef PLATFORM_OS_CE
-#include <sdcardddk.h>
-#endif
-
-
-typedef struct sdio_data
-{
-	u8  func_number;
- 
-	u8  tx_block_mode;
-	u8  rx_block_mode;
-	u32 block_transfer_len;
-
-#ifdef PLATFORM_LINUX
-	struct sdio_func	 *func;
-	_thread_hdl_ sys_sdio_irq_thd;
-#endif
-
-#ifdef PLATFORM_OS_XP
-	PDEVICE_OBJECT				pphysdevobj;
-	PDEVICE_OBJECT				pfuncdevobj;
-	PDEVICE_OBJECT				pnextdevobj;
-	SDBUS_INTERFACE_STANDARD	sdbusinft;
-	u8							nextdevstacksz;
-#endif
-
-#ifdef PLATFORM_OS_CE
-	SD_DEVICE_HANDLE			hDevice;
-	SD_CARD_RCA					sd_rca;
-	SD_CARD_INTERFACE			card_intf;
-	BOOLEAN						enableIsarWithStatus;
-	WCHAR						active_path[MAX_ACTIVE_REG_PATH];
-	SD_HOST_BLOCK_CAPABILITY	sd_host_blk_cap;
-#endif
-} SDIO_DATA, *PSDIO_DATA;
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __DRV_TYPES_SDIO_H__
+#define __DRV_TYPES_SDIO_H__
+
+/* SDIO Header Files */
+#ifdef PLATFORM_LINUX
+	#include <linux/mmc/sdio_func.h>
+	#include <linux/mmc/sdio_ids.h>
+	#include <linux/mmc/host.h>
+	#include <linux/mmc/card.h>
+
+	#ifdef CONFIG_PLATFORM_SPRD
+		#include <linux/gpio.h>
+		#include <custom_gpio.h>
+	#endif /* CONFIG_PLATFORM_SPRD */
+#endif
+
+#ifdef PLATFORM_OS_XP
+	#include <wdm.h>
+	#include <ntddsd.h>
+#endif
+
+#ifdef PLATFORM_OS_CE
+	#include <sdcardddk.h>
+#endif
+
+#define RTW_SDIO_CLK_33M	33000000
+#define RTW_SDIO_CLK_40M	40000000
+#define RTW_SDIO_CLK_80M	80000000
+#define RTW_SDIO_CLK_160M	160000000
+
+typedef struct sdio_data {
+	u8  func_number;
+
+	u8  tx_block_mode;
+	u8  rx_block_mode;
+	u32 block_transfer_len;
+
+#ifdef PLATFORM_LINUX
+	struct sdio_func	*func;
+	_thread_hdl_ sys_sdio_irq_thd;
+	unsigned int clock;
+	unsigned int timing;
+	u8	sd3_bus_mode;
+#endif
+
+#ifdef PLATFORM_OS_XP
+	PDEVICE_OBJECT				pphysdevobj;
+	PDEVICE_OBJECT				pfuncdevobj;
+	PDEVICE_OBJECT				pnextdevobj;
+	SDBUS_INTERFACE_STANDARD	sdbusinft;
+	u8							nextdevstacksz;
+#endif
+
+#ifdef PLATFORM_OS_CE
+	SD_DEVICE_HANDLE			hDevice;
+	SD_CARD_RCA					sd_rca;
+	SD_CARD_INTERFACE			card_intf;
+	BOOLEAN						enableIsarWithStatus;
+	WCHAR						active_path[MAX_ACTIVE_REG_PATH];
+	SD_HOST_BLOCK_CAPABILITY	sd_host_blk_cap;
+#endif
+} SDIO_DATA, *PSDIO_DATA;
+
+#define dvobj_to_sdio_func(d)	((d)->intf_data.func)
+
+#define RTW_SDIO_ADDR_CMD52_BIT		(1<<17)
+#define RTW_SDIO_ADDR_CMD52_GEN(a)	(a | RTW_SDIO_ADDR_CMD52_BIT)
+#define RTW_SDIO_ADDR_CMD52_CLR(a)	(a&~RTW_SDIO_ADDR_CMD52_BIT)
+#define RTW_SDIO_ADDR_CMD52_CHK(a)	(a&RTW_SDIO_ADDR_CMD52_BIT ? 1 : 0)
+
+#define RTW_SDIO_ADDR_F0_BIT		(1<<18)
+#define RTW_SDIO_ADDR_F0_GEN(a)		(a | RTW_SDIO_ADDR_F0_BIT)
+#define RTW_SDIO_ADDR_F0_CLR(a)		(a&~RTW_SDIO_ADDR_F0_BIT)
+#define RTW_SDIO_ADDR_F0_CHK(a)		(a&RTW_SDIO_ADDR_F0_BIT ? 1 : 0)
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_xp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_xp.h
index 2d51b1db13b0..7bbd2403ca71 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_xp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/drv_types_xp.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __DRV_TYPES_XP_H__
 #define __DRV_TYPES_XP_H__
 
@@ -29,60 +25,59 @@
 
 
 
-//for ioctl
-#define MAKE_DRIVER_VERSION(_MainVer,_MinorVer)	((((u32)(_MainVer))<<16)+_MinorVer)
+/* for ioctl */
+#define MAKE_DRIVER_VERSION(_MainVer, _MinorVer)	((((u32)(_MainVer))<<16)+_MinorVer)
 
-#define NIC_HEADER_SIZE				14			//!< can be moved to typedef.h
-#define NIC_MAX_PACKET_SIZE			1514		//!< can be moved to typedef.h
-#define NIC_MAX_SEND_PACKETS			10		// max number of send packets the MiniportSendPackets function can accept, can be moved to typedef.h
-#define NIC_VENDOR_DRIVER_VERSION       MAKE_DRIVER_VERSION(0,001)	//!< can be moved to typedef.h
-#define NIC_MAX_PACKET_SIZE			1514		//!< can be moved to typedef.h
+#define NIC_HEADER_SIZE				14			/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
+#define NIC_MAX_SEND_PACKETS			10		/* max number of send packets the MiniportSendPackets function can accept, can be moved to typedef.h */
+#define NIC_VENDOR_DRIVER_VERSION       MAKE_DRIVER_VERSION(0, 001)	/* !< can be moved to typedef.h */
+#define NIC_MAX_PACKET_SIZE			1514		/* !< can be moved to typedef.h */
 
 
 #undef ON_VISTA
-//added by Jackson
+/* added by Jackson */
 #ifndef ON_VISTA
-//
-// Bus driver versions
-//
-
-#define SDBUS_DRIVER_VERSION_1          0x100
-#define SDBUS_DRIVER_VERSION_2          0x200
-
-#define    SDP_FUNCTION_TYPE	4
-#define    SDP_BUS_DRIVER_VERSION 5
-#define    SDP_BUS_WIDTH 6
-#define    SDP_BUS_CLOCK 7
-#define    SDP_BUS_INTERFACE_CONTROL 8
-#define    SDP_HOST_BLOCK_LENGTH 9
-#define    SDP_FUNCTION_BLOCK_LENGTH 10
-#define    SDP_FN0_BLOCK_LENGTH 11
-#define    SDP_FUNCTION_INT_ENABLE 12
+	/*
+	* Bus driver versions
+	*   */
+
+	#define SDBUS_DRIVER_VERSION_1          0x100
+	#define SDBUS_DRIVER_VERSION_2          0x200
+
+	#define    SDP_FUNCTION_TYPE	4
+	#define    SDP_BUS_DRIVER_VERSION 5
+	#define    SDP_BUS_WIDTH 6
+	#define    SDP_BUS_CLOCK 7
+	#define    SDP_BUS_INTERFACE_CONTROL 8
+	#define    SDP_HOST_BLOCK_LENGTH 9
+	#define    SDP_FUNCTION_BLOCK_LENGTH 10
+	#define    SDP_FN0_BLOCK_LENGTH 11
+	#define    SDP_FUNCTION_INT_ENABLE 12
 #endif
 
 
-typedef struct _MP_REG_ENTRY
-{
+typedef struct _MP_REG_ENTRY {
 
-	NDIS_STRING		RegName;	// variable name text
-	BOOLEAN			bRequired;	// 1 -> required, 0 -> optional
+	NDIS_STRING		RegName;	/* variable name text */
+	BOOLEAN			bRequired;	/* 1->required, 0->optional */
+
+	u8			Type;		/* NdisParameterInteger/NdisParameterHexInteger/NdisParameterStringle/NdisParameterMultiString */
+	uint			FieldOffset;	/* offset to MP_ADAPTER field */
+	uint			FieldSize;	/* size (in bytes) of the field */
 
-	u8			Type;		// NdisParameterInteger/NdisParameterHexInteger/NdisParameterStringle/NdisParameterMultiString
-	uint			FieldOffset;	// offset to MP_ADAPTER field
-	uint			FieldSize;	// size (in bytes) of the field
-	
 #ifdef UNDER_AMD64
 	u64			Default;
 #else
-	u32			Default;		// default value to use
+	u32			Default;		/* default value to use */
 #endif
 
-	u32			Min;			// minimum value allowed
-	u32			Max;		// maximum value allowed
+	u32			Min;			/* minimum value allowed */
+	u32			Max;		/* maximum value allowed */
 } MP_REG_ENTRY, *PMP_REG_ENTRY;
 
 
-typedef struct _OCTET_STRING{
+typedef struct _OCTET_STRING {
 	u8      *Octet;
 	u16      Length;
 } OCTET_STRING, *POCTET_STRING;
@@ -92,4 +87,3 @@ typedef struct _OCTET_STRING{
 
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ethernet.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ethernet.h
index cadc8c1d8f07..36ad72110f45 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ethernet.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ethernet.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,32 +12,26 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-/*! \file */ 
+ *****************************************************************************/
+/*! \file */
 #ifndef __INC_ETHERNET_H
 #define __INC_ETHERNET_H
 
-#define ETHERNET_ADDRESS_LENGTH				6		//!< Ethernet Address Length
-#define ETHERNET_HEADER_SIZE				14		//!< Ethernet Header Length
-#define LLC_HEADER_SIZE						6		//!< LLC Header Length
-#define TYPE_LENGTH_FIELD_SIZE				2		//!< Type/Length Size
-#define MINIMUM_ETHERNET_PACKET_SIZE		60		//!< Minimum Ethernet Packet Size
-#define MAXIMUM_ETHERNET_PACKET_SIZE		1514	//!< Maximum Ethernet Packet Size
-
-#define RT_ETH_IS_MULTICAST(_pAddr)	((((UCHAR *)(_pAddr))[0]&0x01)!=0)		//!< Is Multicast Address?
-#define RT_ETH_IS_BROADCAST(_pAddr)	(										\
-											((UCHAR *)(_pAddr))[0]==0xff	&& 		\
-											((UCHAR *)(_pAddr))[1]==0xff	&&		\
-											((UCHAR *)(_pAddr))[2]==0xff	&&		\
-											((UCHAR *)(_pAddr))[3]==0xff	&&		\
-											((UCHAR *)(_pAddr))[4]==0xff	&&		\
-											((UCHAR *)(_pAddr))[5]==0xff		)	//!< Is Broadcast Address?
+#define ETHERNET_ADDRESS_LENGTH				6		/* !< Ethernet Address Length */
+#define ETHERNET_HEADER_SIZE				14		/* !< Ethernet Header Length */
+#define LLC_HEADER_SIZE						6		/* !< LLC Header Length */
+#define TYPE_LENGTH_FIELD_SIZE				2		/* !< Type/Length Size */
+#define MINIMUM_ETHERNET_PACKET_SIZE		60		/* !< Minimum Ethernet Packet Size */
+#define MAXIMUM_ETHERNET_PACKET_SIZE		1514	/* !< Maximum Ethernet Packet Size */
 
+#define RT_ETH_IS_MULTICAST(_pAddr)	((((UCHAR *)(_pAddr))[0]&0x01) != 0)		/* !< Is Multicast Address? */
+#define RT_ETH_IS_BROADCAST(_pAddr)	(\
+		((UCHAR *)(_pAddr))[0] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[1] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[2] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[3] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[4] == 0xff	&&		\
+		((UCHAR *)(_pAddr))[5] == 0xff)	/* !< Is Broadcast Address? */
 
-#endif // #ifndef __INC_ETHERNET_H
 
+#endif /*  #ifndef __INC_ETHERNET_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_hal.h
index 7581512582a1..5aefa3ed42b4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_hal.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __GSPI_HAL_H__
 #define __GSPI_HAL_H__
 
@@ -25,12 +21,11 @@ void spi_int_dpc(PADAPTER padapter, u32 sdio_hisr);
 u8 rtw_set_hal_ops(_adapter *padapter);
 
 #ifdef CONFIG_RTL8188E
-void rtl8188es_set_hal_ops(PADAPTER padapter);
+	void rtl8188es_set_hal_ops(PADAPTER padapter);
 #endif
 
 #ifdef CONFIG_RTL8723B
-void rtl8723bs_set_hal_ops(PADAPTER padapter);
+	void rtl8723bs_set_hal_ops(PADAPTER padapter);
 #endif
 
-#endif //__GSPI_HAL_H__
-
+#endif /* __GSPI_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops.h
index e04c28a914c7..676bf658e2cb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __GSPI_OPS_H__
 #define __GSPI_OPS_H__
 
@@ -25,55 +21,55 @@
  * suppose that it will be the same
  * for diff chips of GSPI, if not
  * we should move it to HAL folder */
-#define SPI_LOCAL_DOMAIN 				0x0
-#define WLAN_IOREG_DOMAIN 			0x8
-#define FW_FIFO_DOMAIN 				0x4
-#define TX_HIQ_DOMAIN 					0xc
-#define TX_MIQ_DOMAIN 					0xd
-#define TX_LOQ_DOMAIN 					0xe
-#define RX_RXFIFO_DOMAIN 				0x1f
-
-//IO Bus domain address mapping
+#define SPI_LOCAL_DOMAIN				0x0
+#define WLAN_IOREG_DOMAIN			0x8
+#define FW_FIFO_DOMAIN				0x4
+#define TX_HIQ_DOMAIN					0xc
+#define TX_MIQ_DOMAIN					0xd
+#define TX_LOQ_DOMAIN					0xe
+#define RX_RXFIFO_DOMAIN				0x1f
+
+/* IO Bus domain address mapping */
 #define DEFUALT_OFFSET					0x0
-#define SPI_LOCAL_OFFSET    				0x10250000
-#define WLAN_IOREG_OFFSET   			0x10260000
-#define FW_FIFO_OFFSET 	    			0x10270000
-#define TX_HIQ_OFFSET	    				0x10310000
+#define SPI_LOCAL_OFFSET				0x10250000
+#define WLAN_IOREG_OFFSET			0x10260000
+#define FW_FIFO_OFFSET				0x10270000
+#define TX_HIQ_OFFSET					0x10310000
 #define TX_MIQ_OFFSET					0x1032000
 #define TX_LOQ_OFFSET					0x10330000
-#define RX_RXOFF_OFFSET	    			0x10340000
+#define RX_RXOFF_OFFSET				0x10340000
 
-//SPI Local registers
-#define SPI_REG_TX_CTRL					0x0000 // SPI Tx Control
+/* SPI Local registers */
+#define SPI_REG_TX_CTRL					0x0000 /* SPI Tx Control */
 #define SPI_REG_STATUS_RECOVERY		0x0004
-#define SPI_REG_INT_TIMEOUT		   	0x0006
-#define SPI_REG_HIMR					0x0014 // SPI Host Interrupt Mask
-#define SPI_REG_HISR					0x0018 // SPI Host Interrupt Service Routine
-#define SPI_REG_RX0_REQ_LEN			0x001C // RXDMA Request Length
-#define SPI_REG_FREE_TXPG				0x0020 // Free Tx Buffer Page
-#define SPI_REG_HCPWM1					0x0024 // HCI Current Power Mode 1
-#define SPI_REG_HCPWM2					0x0026 // HCI Current Power Mode 2
-#define SPI_REG_HTSFR_INFO				0x0030 // HTSF Informaion
-#define SPI_REG_HRPWM1					0x0080 // HCI Request Power Mode 1
-#define SPI_REG_HRPWM2					0x0082 // HCI Request Power Mode 2
-#define SPI_REG_HPS_CLKR				0x0084 // HCI Power Save Clock
-#define SPI_REG_HSUS_CTRL				0x0086 // SPI HCI Suspend Control
-#define SPI_REG_HIMR_ON				0x0090 //SPI Host Extension Interrupt Mask Always
-#define SPI_REG_HISR_ON				0x0091 //SPI Host Extension Interrupt Status Always
-#define SPI_REG_CFG						0x00F0 //SPI Configuration Register
-
-#define SPI_TX_CTRL 	               			(SPI_REG_TX_CTRL  |SPI_LOCAL_OFFSET)
-#define SPI_STATUS_RECOVERY		   	(SPI_REG_STATUS_RECOVERY  |SPI_LOCAL_OFFSET)
-#define SPI_INT_TIMEOUT		   	   		(SPI_REG_INT_TIMEOUT  |SPI_LOCAL_OFFSET)
-#define SPI_HIMR 	                  			(SPI_REG_HIMR |SPI_LOCAL_OFFSET)
-#define SPI_HISR 	                   			(SPI_REG_HISR |SPI_LOCAL_OFFSET)
-#define SPI_RX0_REQ_LEN_1_BYTE 	   	(SPI_REG_RX0_REQ_LEN |SPI_LOCAL_OFFSET)
-#define SPI_FREE_TXPG 	               		(SPI_REG_FREE_TXPG |SPI_LOCAL_OFFSET)
+#define SPI_REG_INT_TIMEOUT			0x0006
+#define SPI_REG_HIMR					0x0014 /* SPI Host Interrupt Mask */
+#define SPI_REG_HISR					0x0018 /* SPI Host Interrupt Service Routine */
+#define SPI_REG_RX0_REQ_LEN			0x001C /* RXDMA Request Length */
+#define SPI_REG_FREE_TXPG				0x0020 /* Free Tx Buffer Page */
+#define SPI_REG_HCPWM1					0x0024 /* HCI Current Power Mode 1 */
+#define SPI_REG_HCPWM2					0x0026 /* HCI Current Power Mode 2 */
+#define SPI_REG_HTSFR_INFO				0x0030 /* HTSF Informaion */
+#define SPI_REG_HRPWM1					0x0080 /* HCI Request Power Mode 1 */
+#define SPI_REG_HRPWM2					0x0082 /* HCI Request Power Mode 2 */
+#define SPI_REG_HPS_CLKR				0x0084 /* HCI Power Save Clock */
+#define SPI_REG_HSUS_CTRL				0x0086 /* SPI HCI Suspend Control */
+#define SPI_REG_HIMR_ON				0x0090 /* SPI Host Extension Interrupt Mask Always */
+#define SPI_REG_HISR_ON				0x0091 /* SPI Host Extension Interrupt Status Always */
+#define SPI_REG_CFG						0x00F0 /* SPI Configuration Register */
+
+#define SPI_TX_CTRL				(SPI_REG_TX_CTRL | SPI_LOCAL_OFFSET)
+#define SPI_STATUS_RECOVERY			(SPI_REG_STATUS_RECOVERY | SPI_LOCAL_OFFSET)
+#define SPI_INT_TIMEOUT					(SPI_REG_INT_TIMEOUT | SPI_LOCAL_OFFSET)
+#define SPI_HIMR				(SPI_REG_HIMR | SPI_LOCAL_OFFSET)
+#define SPI_HISR				(SPI_REG_HISR | SPI_LOCAL_OFFSET)
+#define SPI_RX0_REQ_LEN_1_BYTE		(SPI_REG_RX0_REQ_LEN | SPI_LOCAL_OFFSET)
+#define SPI_FREE_TXPG			(SPI_REG_FREE_TXPG | SPI_LOCAL_OFFSET)
 
 #define	SPI_HIMR_DISABLED				0
 
-//SPI HIMR MASK diff with SDIO
-#define SPI_HISR_RX_REQUEST    			BIT(0)
+/* SPI HIMR MASK diff with SDIO */
+#define SPI_HISR_RX_REQUEST			BIT(0)
 #define SPI_HISR_AVAL					BIT(1)
 #define SPI_HISR_TXERR					BIT(2)
 #define SPI_HISR_RXERR					BIT(3)
@@ -96,45 +92,45 @@
 #define SPI_HISR_TSF_BIT32_TOGGLE		BIT(29)
 
 #define MASK_SPI_HISR_CLEAR		(SPI_HISR_TXERR |\
-									SPI_HISR_RXERR |\
-									SPI_HISR_TXFOVW |\
-									SPI_HISR_RXFOVW |\
-									SPI_HISR_TXBCNOK |\
-									SPI_HISR_TXBCNERR |\
-									SPI_HISR_C2HCMD |\
-									SPI_HISR_CPWM1 |\
-									SPI_HISR_CPWM2 |\
-									SPI_HISR_HSISR_IND |\
-									SPI_HISR_GTINT3_IND |\
-									SPI_HISR_GTINT4_IND |\
-									SPI_HISR_PSTIMEOUT |\
-									SPI_HISR_OCPINT)
-
-#define REG_LEN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 0, 8, x)//(x<<(unsigned int)24)
-#define REG_ADDR_FORMAT(pcmd,x) 			SET_BITS_TO_LE_4BYTE(pcmd, 8, 16, x)//(x<<(unsigned int)16)
-#define REG_DOMAIN_ID_FORMAT(pcmd,x) 		SET_BITS_TO_LE_4BYTE(pcmd, 24, 5, x)//(x<<(unsigned int)0)
-#define REG_FUN_FORMAT(pcmd,x) 			SET_BITS_TO_LE_4BYTE(pcmd, 29, 2, x)//(x<<(unsigned int)5)
-#define REG_RW_FORMAT(pcmd,x) 				SET_BITS_TO_LE_4BYTE(pcmd, 31, 1, x)//(x<<(unsigned int)7)
-
-#define FIFO_LEN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 0, 16, x)//(x<<(unsigned int)24)
-//#define FIFO_ADDR_FORMAT(pcmd,x) 			SET_BITS_TO_LE_4BYTE(pcmd, 8, 16, x)//(x<<(unsigned int)16)
-#define FIFO_DOMAIN_ID_FORMAT(pcmd,x) 	SET_BITS_TO_LE_4BYTE(pcmd, 24, 5, x)//(x<<(unsigned int)0)
-#define FIFO_FUN_FORMAT(pcmd,x) 			SET_BITS_TO_LE_4BYTE(pcmd, 29, 2, x)//(x<<(unsigned int)5)
-#define FIFO_RW_FORMAT(pcmd,x) 			SET_BITS_TO_LE_4BYTE(pcmd, 31, 1, x)//(x<<(unsigned int)7)
-
-
-//get status dword0
+		SPI_HISR_RXERR |\
+		SPI_HISR_TXFOVW |\
+		SPI_HISR_RXFOVW |\
+		SPI_HISR_TXBCNOK |\
+		SPI_HISR_TXBCNERR |\
+		SPI_HISR_C2HCMD |\
+		SPI_HISR_CPWM1 |\
+		SPI_HISR_CPWM2 |\
+		SPI_HISR_HSISR_IND |\
+		SPI_HISR_GTINT3_IND |\
+		SPI_HISR_GTINT4_IND |\
+		SPI_HISR_PSTIMEOUT |\
+		SPI_HISR_OCPINT)
+
+#define REG_LEN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 0, 8, x)/* (x<<(unsigned int)24) */
+#define REG_ADDR_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 8, 16, x)/* (x<<(unsigned int)16) */
+#define REG_DOMAIN_ID_FORMAT(pcmd, x) 		SET_BITS_TO_LE_4BYTE(pcmd, 24, 5, x)/* (x<<(unsigned int)0) */
+#define REG_FUN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 29, 2, x)/* (x<<(unsigned int)5) */
+#define REG_RW_FORMAT(pcmd, x) 				SET_BITS_TO_LE_4BYTE(pcmd, 31, 1, x)/* (x<<(unsigned int)7) */
+
+#define FIFO_LEN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 0, 16, x)/* (x<<(unsigned int)24)
+ * #define FIFO_ADDR_FORMAT(pcmd,x) 			SET_BITS_TO_LE_4BYTE(pcmd, 8, 16, x) */ /* (x<<(unsigned int)16) */
+#define FIFO_DOMAIN_ID_FORMAT(pcmd, x) 	SET_BITS_TO_LE_4BYTE(pcmd, 24, 5, x)/* (x<<(unsigned int)0) */
+#define FIFO_FUN_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 29, 2, x)/* (x<<(unsigned int)5) */
+#define FIFO_RW_FORMAT(pcmd, x) 			SET_BITS_TO_LE_4BYTE(pcmd, 31, 1, x)/* (x<<(unsigned int)7) */
+
+
+/* get status dword0 */
 #define GET_STATUS_PUB_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 24, 8)
 #define GET_STATUS_HI_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 18, 6)
 #define GET_STATUS_MID_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 12, 6)
 #define GET_STATUS_LOW_PAGE_NUM(status)		LE_BITS_TO_4BYTE(status, 6, 6)
 #define GET_STATUS_HISR_HI6BIT(status)			LE_BITS_TO_4BYTE(status, 0, 6)
 
-//get status dword1
+/* get status dword1 */
 #define GET_STATUS_HISR_MID8BIT(status)		LE_BITS_TO_4BYTE(status + 4, 24, 8)
 #define GET_STATUS_HISR_LOW8BIT(status)		LE_BITS_TO_4BYTE(status + 4, 16, 8)
-#define GET_STATUS_ERROR(status)		    		LE_BITS_TO_4BYTE(status + 4, 17, 1)
-#define GET_STATUS_INT(status)		        		LE_BITS_TO_4BYTE(status + 4, 16, 1)
+#define GET_STATUS_ERROR(status)				LE_BITS_TO_4BYTE(status + 4, 17, 1)
+#define GET_STATUS_INT(status)				LE_BITS_TO_4BYTE(status + 4, 16, 1)
 #define GET_STATUS_RX_LENGTH(status)			LE_BITS_TO_4BYTE(status + 4, 0, 16)
 
 
@@ -147,12 +143,12 @@ struct spi_more_data {
 };
 
 #ifdef CONFIG_RTL8188E
-void rtl8188es_set_hal_ops(PADAPTER padapter);
-#define set_hal_ops rtl8188es_set_hal_ops
+	void rtl8188es_set_hal_ops(PADAPTER padapter);
+	#define set_hal_ops rtl8188es_set_hal_ops
 #endif
 extern void spi_set_chip_endian(PADAPTER padapter);
 extern unsigned int spi_write8_endian(ADAPTER *Adapter, unsigned int addr, unsigned int buf, u32 big);
-extern void spi_set_intf_ops(_adapter *padapter,struct _io_ops *pops);
+extern void spi_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
 extern void spi_set_chip_endian(PADAPTER padapter);
 extern void InitInterrupt8723ASdio(PADAPTER padapter);
 extern void InitSysInterrupt8723ASdio(PADAPTER padapter);
@@ -161,25 +157,25 @@ extern void DisableInterrupt8723ASdio(PADAPTER padapter);
 extern void spi_int_hdl(PADAPTER padapter);
 extern u8 HalQueryTxBufferStatus8723ASdio(PADAPTER padapter);
 #ifdef CONFIG_RTL8723B
-extern void InitInterrupt8723BSdio(PADAPTER padapter);
-extern void InitSysInterrupt8723BSdio(PADAPTER padapter);
-extern void EnableInterrupt8723BSdio(PADAPTER padapter);
-extern void DisableInterrupt8723BSdio(PADAPTER padapter);
-extern u8 HalQueryTxBufferStatus8723BSdio(PADAPTER padapter);
+	extern void InitInterrupt8723BSdio(PADAPTER padapter);
+	extern void InitSysInterrupt8723BSdio(PADAPTER padapter);
+	extern void EnableInterrupt8723BSdio(PADAPTER padapter);
+	extern void DisableInterrupt8723BSdio(PADAPTER padapter);
+	extern u8 HalQueryTxBufferStatus8723BSdio(PADAPTER padapter);
 #endif
 
 #ifdef CONFIG_RTL8188E
-extern void InitInterrupt8188EGspi(PADAPTER padapter);
-extern void EnableInterrupt8188EGspi(PADAPTER padapter);
-extern void DisableInterrupt8188EGspi(PADAPTER padapter);
-extern void UpdateInterruptMask8188EGspi(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
-extern u8 HalQueryTxBufferStatus8189EGspi(PADAPTER padapter);
-extern u8 HalQueryTxOQTBufferStatus8189EGspi(PADAPTER padapter);
-extern void ClearInterrupt8188EGspi(PADAPTER padapter);
-extern u8 CheckIPSStatus(PADAPTER padapter);
-#endif // CONFIG_RTL8188E
+	extern void InitInterrupt8188EGspi(PADAPTER padapter);
+	extern void EnableInterrupt8188EGspi(PADAPTER padapter);
+	extern void DisableInterrupt8188EGspi(PADAPTER padapter);
+	extern void UpdateInterruptMask8188EGspi(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
+	extern u8 HalQueryTxBufferStatus8189EGspi(PADAPTER padapter);
+	extern u8 HalQueryTxOQTBufferStatus8189EGspi(PADAPTER padapter);
+	extern void ClearInterrupt8188EGspi(PADAPTER padapter);
+	extern u8 CheckIPSStatus(PADAPTER padapter);
+#endif /* CONFIG_RTL8188E */
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-extern u8 RecvOnePkt(PADAPTER padapter, u32 size);
-#endif // CONFIG_WOWLAN
+	extern u8 RecvOnePkt(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
 
-#endif //__GSPI_OPS_H__
+#endif /* __GSPI_OPS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops_linux.h
index 6358a0fa6b9f..a70f86c75e28 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_ops_linux.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,14 +12,8 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __SDIO_OPS_LINUX_H__
 #define __SDIO_OPS_LINUX_H__
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_osintf.h
index 5b57bdb660b9..f2f03e86ec54 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/gspi_osintf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,21 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __SDIO_OSINTF_H__
 #define __SDIO_OSINTF_H__
 
 
 #ifdef PLATFORM_OS_CE
-extern NDIS_STATUS ce_sd_get_dev_hdl(PADAPTER padapter);
-SD_API_STATUS ce_sd_int_callback(SD_DEVICE_HANDLE hDevice, PADAPTER padapter);
-extern void sd_setup_irs(PADAPTER padapter);
+	extern NDIS_STATUS ce_sd_get_dev_hdl(PADAPTER padapter);
+	SD_API_STATUS ce_sd_int_callback(SD_DEVICE_HANDLE hDevice, PADAPTER padapter);
+	extern void sd_setup_irs(PADAPTER padapter);
 #endif
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/h2clbk.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/h2clbk.h
index 4fa863c2da93..d62d04dad90b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/h2clbk.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/h2clbk.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 
 #define _H2CLBK_H_
@@ -29,4 +25,3 @@ void _lbk_rsp(PADAPTER Adapter);
 void _lbk_evt(IN PADAPTER Adapter);
 
 void h2c_event_callback(unsigned char *dev, unsigned char *pbuf);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_btcoex.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_btcoex.h
index dd2eb84f4ab8..c7e5b491df7a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_btcoex.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_btcoex.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,21 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_BTCOEX_H__
 #define __HAL_BTCOEX_H__
 
 #include <drv_types.h>
 
-// Some variables can't get from outsrc BT-Coex,
-// so we need to save here
-typedef struct _BT_COEXIST
-{
+/* Some variables can't get from outsrc BT-Coex,
+ * so we need to save here */
+typedef struct _BT_COEXIST {
 	u8 bBtExist;
 	u8 btTotalAntNum;
 	u8 btChipType;
@@ -39,13 +34,12 @@ void hal_btcoex_SetBTCoexist(PADAPTER padapter, u8 bBtExist);
 u8 hal_btcoex_IsBtExist(PADAPTER padapter);
 u8 hal_btcoex_IsBtDisabled(PADAPTER);
 void hal_btcoex_SetChipType(PADAPTER padapter, u8 chipType);
-u8 hal_btcoex_GetChipType(PADAPTER padapter);
 void hal_btcoex_SetPgAntNum(PADAPTER padapter, u8 antNum);
-u8 hal_btcoex_GetPgAntNum(PADAPTER padapter);
-void hal_btcoex_SetSingleAntPath(PADAPTER padapter, u8 singleAntPath);
 
 u8 hal_btcoex_Initialize(PADAPTER padapter);
 void hal_btcoex_PowerOnSetting(PADAPTER padapter);
+void hal_btcoex_AntInfoSetting(PADAPTER padapter);
+void hal_btcoex_PowerOffSetting(PADAPTER padapter);
 void hal_btcoex_PreLoadFirmware(PADAPTER padapter);
 void hal_btcoex_InitHwConfig(PADAPTER padapter, u8 bWifiOnly);
 
@@ -59,8 +53,7 @@ void hal_btcoex_IQKNotify(PADAPTER padapter, u8 state);
 void hal_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf);
 void hal_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf);
 void hal_btcoex_SuspendNotify(PADAPTER padapter, u8 state);
-void hal_btcoex_HaltNotify(PADAPTER padapter);
-void hal_btcoex_ScoreBoardStatusNotify(PADAPTER padapter, u8 length, u8 *tmpBuf);
+void hal_btcoex_HaltNotify(PADAPTER padapter, u8 do_halt);
 void hal_btcoex_SwitchBtTRxMask(PADAPTER padapter);
 
 void hal_btcoex_Hanlder(PADAPTER padapter);
@@ -81,17 +74,25 @@ void hal_btcoex_SetDBG(PADAPTER, u32 *pDbgModule);
 u32 hal_btcoex_GetDBG(PADAPTER, u8 *pStrBuf, u32 bufSize);
 u8 hal_btcoex_IncreaseScanDeviceNum(PADAPTER);
 u8 hal_btcoex_IsBtLinkExist(PADAPTER);
-void hal_btcoex_SetBtPatchVersion(PADAPTER,u16 btHciVer,u16 btPatchVer);
+void hal_btcoex_SetBtPatchVersion(PADAPTER, u16 btHciVer, u16 btPatchVer);
 void hal_btcoex_SetHciVersion(PADAPTER, u16 hciVersion);
 void hal_btcoex_SendScanNotify(PADAPTER, u8 type);
 void hal_btcoex_StackUpdateProfileInfo(void);
-void hal_btcoex_BTOffOnNotify(PADAPTER padapter, u8 bBTON);
+void hal_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON);
 void hal_btcoex_SetAntIsolationType(PADAPTER padapter, u8 anttype);
 #ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
-int hal_btcoex_AntIsolationConfig_ParaFile(IN PADAPTER	Adapter,IN char* pFileName);
-int hal_btcoex_ParseAntIsolationConfigFile(PADAPTER Adapter, char*	buffer);
-#endif // CONFIG_LOAD_PHY_PARA_FROM_FILE
+	int hal_btcoex_AntIsolationConfig_ParaFile(IN PADAPTER	Adapter, IN char *pFileName);
+	int hal_btcoex_ParseAntIsolationConfigFile(PADAPTER Adapter, char	*buffer);
+#endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
 u16 hal_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data);
 u16 hal_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val);
-#endif // !__HAL_BTCOEX_H__
+void hal_btcoex_set_rfe_type(u8 type);
+void hal_btcoex_switchband_notify(u8 under_scan, u8 band_type);
+void hal_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length);
+void hal_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id);
 
+#ifdef CONFIG_RF4CE_COEXIST
+void hal_btcoex_set_rf4ce_link_state(u8 state);
+u8 hal_btcoex_get_rf4ce_link_state(void);
+#endif
+#endif /* !__HAL_BTCOEX_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_btcoex_wifionly.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_btcoex_wifionly.h
new file mode 100644
index 000000000000..c6e28f9cdd4b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_btcoex_wifionly.h
@@ -0,0 +1,80 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __HALBTC_WIFIONLY_H__
+#define __HALBTC_WIFIONLY_H__
+
+#include <drv_types.h>
+#include <hal_data.h>
+
+/* Define the ICs that support wifi only cfg in coex. codes */
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+#define CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG 1
+#else
+#define CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG 0
+#endif
+
+#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
+
+typedef enum _WIFIONLY_CHIP_INTERFACE {
+	WIFIONLY_INTF_UNKNOWN	= 0,
+	WIFIONLY_INTF_PCI		= 1,
+	WIFIONLY_INTF_USB		= 2,
+	WIFIONLY_INTF_SDIO		= 3,
+	WIFIONLY_INTF_MAX
+} WIFIONLY_CHIP_INTERFACE, *PWIFIONLY_CHIP_INTERFACE;
+
+typedef enum _WIFIONLY_CUSTOMER_ID {
+	CUSTOMER_NORMAL			= 0,
+	CUSTOMER_HP_1			= 1
+} WIFIONLY_CUSTOMER_ID, *PWIFIONLY_CUSTOMER_ID;
+
+struct wifi_only_haldata {
+	u16		customer_id;
+	u8		efuse_pg_antnum;
+	u8		efuse_pg_antpath;
+	u8		rfe_type;
+	u8		ant_div_cfg;
+};
+
+struct wifi_only_cfg {
+	PVOID						Adapter;
+	struct	wifi_only_haldata		haldata_info;
+	WIFIONLY_CHIP_INTERFACE	chip_interface;
+};
+
+void halwifionly_write1byte(PVOID pwifionlyContext, u32 RegAddr, u8 Data);
+void halwifionly_write2byte(PVOID pwifionlyContext, u32 RegAddr, u16 Data);
+void halwifionly_write4byte(PVOID pwifionlyContext, u32 RegAddr, u32 Data);
+u8 halwifionly_read1byte(PVOID pwifionlyContext, u32 RegAddr);
+u16 halwifionly_read2byte(PVOID pwifionlyContext, u32 RegAddr);
+u32 halwifionly_read4byte(PVOID pwifionlyContext, u32 RegAddr);
+void halwifionly_bitmaskwrite1byte(PVOID pwifionlyContext, u32 regAddr, u8 bitMask, u8 data);
+void halwifionly_phy_set_rf_reg(PVOID pwifionlyContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
+void halwifionly_phy_set_bb_reg(PVOID pwifionlyContext, u32 RegAddr, u32 BitMask, u32 Data);
+void hal_btcoex_wifionly_switchband_notify(PADAPTER padapter);
+void hal_btcoex_wifionly_scan_notify(PADAPTER padapter);
+void hal_btcoex_wifionly_hw_config(PADAPTER padapter);
+void hal_btcoex_wifionly_initlizevariables(PADAPTER padapter);
+void hal_btcoex_wifionly_AntInfoSetting(PADAPTER padapter);
+#else
+#define hal_btcoex_wifionly_switchband_notify(padapter)
+#define hal_btcoex_wifionly_scan_notify(padapter)
+#define hal_btcoex_wifionly_hw_config(padapter)
+#define hal_btcoex_wifionly_initlizevariables(padapter)
+#define hal_btcoex_wifionly_AntInfoSetting(padapter)
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com.h
index 99817f7753d4..179c440f1745 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_COMMON_H__
 #define __HAL_COMMON_H__
 
@@ -28,19 +24,19 @@
 #include "hal_com_phycfg.h"
 #include "../hal/hal_com_c2h.h"
 
-/*------------------------------ Tx Desc definition Macro ------------------------*/ 
-//#pragma mark -- Tx Desc related definition. --
-//----------------------------------------------------------------------------
-//-----------------------------------------------------------
-//	Rate
-//-----------------------------------------------------------
-// CCK Rates, TxHT = 0
+/*------------------------------ 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
+/* OFDM Rates, TxHT = 0 */
 #define DESC_RATE6M					0x04
 #define DESC_RATE9M					0x05
 #define DESC_RATE12M				0x06
@@ -50,7 +46,7 @@
 #define DESC_RATE48M				0x0a
 #define DESC_RATE54M				0x0b
 
-// MCS Rates, TxHT = 1
+/* MCS Rates, TxHT = 1 */
 #define DESC_RATEMCS0				0x0c
 #define DESC_RATEMCS1				0x0d
 #define DESC_RATEMCS2				0x0e
@@ -125,136 +121,186 @@
 #define DESC_RATEVHTSS4MCS9		0x53
 
 #define HDATA_RATE(rate)\
-(rate == DESC_RATE1M)?"CCK_1M" :\
-(rate == DESC_RATE2M)?"CCK_2M" :\
-(rate == DESC_RATE5_5M)?"CCK5_5M" :\
-(rate == DESC_RATE11M)?"CCK_11M" :\
-(rate == DESC_RATE6M)?"OFDM_6M" :\
-(rate == DESC_RATE9M)?"OFDM_9M" :\
-(rate == DESC_RATE12M)?"OFDM_12M" :\
-(rate == DESC_RATE18M)?"OFDM_18M" :\
-(rate == DESC_RATE24M)?"OFDM_24M" :\
-(rate == DESC_RATE36M)?"OFDM_36M" :\
-(rate == DESC_RATE48M)?"OFDM_48M" :\
-(rate == DESC_RATE54M)?"OFDM_54M" :\
-(rate == DESC_RATEMCS0)?"MCS0" :\
-(rate == DESC_RATEMCS1)?"MCS1" :\
-(rate == DESC_RATEMCS2)?"MCS2" :\
-(rate == DESC_RATEMCS3)?"MCS3" :\
-(rate == DESC_RATEMCS4)?"MCS4" :\
-(rate == DESC_RATEMCS5)?"MCS5" :\
-(rate == DESC_RATEMCS6)?"MCS6" :\
-(rate == DESC_RATEMCS7)?"MCS7" :\
-(rate == DESC_RATEMCS8)?"MCS8" :\
-(rate == DESC_RATEMCS9)?"MCS9" :\
-(rate == DESC_RATEMCS10)?"MCS10" :\
-(rate == DESC_RATEMCS11)?"MCS11" :\
-(rate == DESC_RATEMCS12)?"MCS12" :\
-(rate == DESC_RATEMCS13)?"MCS13" :\
-(rate == DESC_RATEMCS14)?"MCS14" :\
-(rate == DESC_RATEMCS15)?"MCS15" :\
-(rate == DESC_RATEMCS16)?"MCS16" :\
-(rate == DESC_RATEMCS17)?"MCS17" :\
-(rate == DESC_RATEMCS18)?"MCS18" :\
-(rate == DESC_RATEMCS19)?"MCS19" :\
-(rate == DESC_RATEMCS20)?"MCS20" :\
-(rate == DESC_RATEMCS21)?"MCS21" :\
-(rate == DESC_RATEMCS22)?"MCS22" :\
-(rate == DESC_RATEMCS23)?"MCS23" :\
-(rate == DESC_RATEVHTSS1MCS0)?"VHTSS1MCS0" :\
-(rate == DESC_RATEVHTSS1MCS1)?"VHTSS1MCS1" :\
-(rate == DESC_RATEVHTSS1MCS2)?"VHTSS1MCS2" :\
-(rate == DESC_RATEVHTSS1MCS3)?"VHTSS1MCS3" :\
-(rate == DESC_RATEVHTSS1MCS4)?"VHTSS1MCS4" :\
-(rate == DESC_RATEVHTSS1MCS5)?"VHTSS1MCS5" :\
-(rate == DESC_RATEVHTSS1MCS6)?"VHTSS1MCS6" :\
-(rate == DESC_RATEVHTSS1MCS7)?"VHTSS1MCS7" :\
-(rate == DESC_RATEVHTSS1MCS8)?"VHTSS1MCS8" :\
-(rate == DESC_RATEVHTSS1MCS9)?"VHTSS1MCS9" :\
-(rate == DESC_RATEVHTSS2MCS0)?"VHTSS2MCS0" :\
-(rate == DESC_RATEVHTSS2MCS1)?"VHTSS2MCS1" :\
-(rate == DESC_RATEVHTSS2MCS2)?"VHTSS2MCS2" :\
-(rate == DESC_RATEVHTSS2MCS3)?"VHTSS2MCS3" :\
-(rate == DESC_RATEVHTSS2MCS4)?"VHTSS2MCS4" :\
-(rate == DESC_RATEVHTSS2MCS5)?"VHTSS2MCS5" :\
-(rate == DESC_RATEVHTSS2MCS6)?"VHTSS2MCS6" :\
-(rate == DESC_RATEVHTSS2MCS7)?"VHTSS2MCS7" :\
-(rate == DESC_RATEVHTSS2MCS8)?"VHTSS2MCS8" :\
-(rate == DESC_RATEVHTSS2MCS9)?"VHTSS2MCS9" :\
-(rate == DESC_RATEVHTSS3MCS0)?"VHTSS3MCS0" :\
-(rate == DESC_RATEVHTSS3MCS1)?"VHTSS3MCS1" :\
-(rate == DESC_RATEVHTSS3MCS2)?"VHTSS3MCS2" :\
-(rate == DESC_RATEVHTSS3MCS3)?"VHTSS3MCS3" :\
-(rate == DESC_RATEVHTSS3MCS4)?"VHTSS3MCS4" :\
-(rate == DESC_RATEVHTSS3MCS5)?"VHTSS3MCS5" :\
-(rate == DESC_RATEVHTSS3MCS6)?"VHTSS3MCS6" :\
-(rate == DESC_RATEVHTSS3MCS7)?"VHTSS3MCS7" :\
-(rate == DESC_RATEVHTSS3MCS8)?"VHTSS3MCS8" :\
-(rate == DESC_RATEVHTSS3MCS9)?"VHTSS3MCS9" : "UNKNOWN"
-
-
-enum{
+	(rate == DESC_RATE1M) ? "CCK_1M" :\
+	(rate == DESC_RATE2M) ? "CCK_2M" :\
+	(rate == DESC_RATE5_5M) ? "CCK5_5M" :\
+	(rate == DESC_RATE11M) ? "CCK_11M" :\
+	(rate == DESC_RATE6M) ? "OFDM_6M" :\
+	(rate == DESC_RATE9M) ? "OFDM_9M" :\
+	(rate == DESC_RATE12M) ? "OFDM_12M" :\
+	(rate == DESC_RATE18M) ? "OFDM_18M" :\
+	(rate == DESC_RATE24M) ? "OFDM_24M" :\
+	(rate == DESC_RATE36M) ? "OFDM_36M" :\
+	(rate == DESC_RATE48M) ? "OFDM_48M" :\
+	(rate == DESC_RATE54M) ? "OFDM_54M" :\
+	(rate == DESC_RATEMCS0) ? "MCS0" :\
+	(rate == DESC_RATEMCS1) ? "MCS1" :\
+	(rate == DESC_RATEMCS2) ? "MCS2" :\
+	(rate == DESC_RATEMCS3) ? "MCS3" :\
+	(rate == DESC_RATEMCS4) ? "MCS4" :\
+	(rate == DESC_RATEMCS5) ? "MCS5" :\
+	(rate == DESC_RATEMCS6) ? "MCS6" :\
+	(rate == DESC_RATEMCS7) ? "MCS7" :\
+	(rate == DESC_RATEMCS8) ? "MCS8" :\
+	(rate == DESC_RATEMCS9) ? "MCS9" :\
+	(rate == DESC_RATEMCS10) ? "MCS10" :\
+	(rate == DESC_RATEMCS11) ? "MCS11" :\
+	(rate == DESC_RATEMCS12) ? "MCS12" :\
+	(rate == DESC_RATEMCS13) ? "MCS13" :\
+	(rate == DESC_RATEMCS14) ? "MCS14" :\
+	(rate == DESC_RATEMCS15) ? "MCS15" :\
+	(rate == DESC_RATEMCS16) ? "MCS16" :\
+	(rate == DESC_RATEMCS17) ? "MCS17" :\
+	(rate == DESC_RATEMCS18) ? "MCS18" :\
+	(rate == DESC_RATEMCS19) ? "MCS19" :\
+	(rate == DESC_RATEMCS20) ? "MCS20" :\
+	(rate == DESC_RATEMCS21) ? "MCS21" :\
+	(rate == DESC_RATEMCS22) ? "MCS22" :\
+	(rate == DESC_RATEMCS23) ? "MCS23" :\
+	(rate == DESC_RATEVHTSS1MCS0) ? "VHTSS1MCS0" :\
+	(rate == DESC_RATEVHTSS1MCS1) ? "VHTSS1MCS1" :\
+	(rate == DESC_RATEVHTSS1MCS2) ? "VHTSS1MCS2" :\
+	(rate == DESC_RATEVHTSS1MCS3) ? "VHTSS1MCS3" :\
+	(rate == DESC_RATEVHTSS1MCS4) ? "VHTSS1MCS4" :\
+	(rate == DESC_RATEVHTSS1MCS5) ? "VHTSS1MCS5" :\
+	(rate == DESC_RATEVHTSS1MCS6) ? "VHTSS1MCS6" :\
+	(rate == DESC_RATEVHTSS1MCS7) ? "VHTSS1MCS7" :\
+	(rate == DESC_RATEVHTSS1MCS8) ? "VHTSS1MCS8" :\
+	(rate == DESC_RATEVHTSS1MCS9) ? "VHTSS1MCS9" :\
+	(rate == DESC_RATEVHTSS2MCS0) ? "VHTSS2MCS0" :\
+	(rate == DESC_RATEVHTSS2MCS1) ? "VHTSS2MCS1" :\
+	(rate == DESC_RATEVHTSS2MCS2) ? "VHTSS2MCS2" :\
+	(rate == DESC_RATEVHTSS2MCS3) ? "VHTSS2MCS3" :\
+	(rate == DESC_RATEVHTSS2MCS4) ? "VHTSS2MCS4" :\
+	(rate == DESC_RATEVHTSS2MCS5) ? "VHTSS2MCS5" :\
+	(rate == DESC_RATEVHTSS2MCS6) ? "VHTSS2MCS6" :\
+	(rate == DESC_RATEVHTSS2MCS7) ? "VHTSS2MCS7" :\
+	(rate == DESC_RATEVHTSS2MCS8) ? "VHTSS2MCS8" :\
+	(rate == DESC_RATEVHTSS2MCS9) ? "VHTSS2MCS9" :\
+	(rate == DESC_RATEVHTSS3MCS0) ? "VHTSS3MCS0" :\
+	(rate == DESC_RATEVHTSS3MCS1) ? "VHTSS3MCS1" :\
+	(rate == DESC_RATEVHTSS3MCS2) ? "VHTSS3MCS2" :\
+	(rate == DESC_RATEVHTSS3MCS3) ? "VHTSS3MCS3" :\
+	(rate == DESC_RATEVHTSS3MCS4) ? "VHTSS3MCS4" :\
+	(rate == DESC_RATEVHTSS3MCS5) ? "VHTSS3MCS5" :\
+	(rate == DESC_RATEVHTSS3MCS6) ? "VHTSS3MCS6" :\
+	(rate == DESC_RATEVHTSS3MCS7) ? "VHTSS3MCS7" :\
+	(rate == DESC_RATEVHTSS3MCS8) ? "VHTSS3MCS8" :\
+	(rate == DESC_RATEVHTSS3MCS9) ? "VHTSS3MCS9" : "UNKNOWN"
+
+enum {
 	UP_LINK,
-	DOWN_LINK,	
+	DOWN_LINK,
 };
 typedef enum _RT_MEDIA_STATUS {
 	RT_MEDIA_DISCONNECT = 0,
 	RT_MEDIA_CONNECT       = 1
 } RT_MEDIA_STATUS;
 
-#define MAX_DLFW_PAGE_SIZE			4096	// @ page : 4k bytes
+#define MAX_DLFW_PAGE_SIZE			4096	/* @ page : 4k bytes */
 typedef enum _FIRMWARE_SOURCE {
 	FW_SOURCE_IMG_FILE = 0,
-	FW_SOURCE_HEADER_FILE = 1,		//from header file
+	FW_SOURCE_HEADER_FILE = 1,		/* from header file */
 } FIRMWARE_SOURCE, *PFIRMWARE_SOURCE;
 
-//
-// Queue Select Value in TxDesc
-//
-#define QSLT_BK							0x2//0x01
+typedef enum _CH_SW_USE_CASE {
+	CH_SW_USE_CASE_TDLS		= 0,
+	CH_SW_USE_CASE_MCC		= 1
+} CH_SW_USE_CASE;
+
+typedef enum _WAKEUP_REASON{
+	RX_PAIRWISEKEY					= 0x01,
+	RX_GTK							= 0x02,
+	RX_FOURWAY_HANDSHAKE			= 0x03,
+	RX_DISASSOC						= 0x04,
+	RX_DEAUTH						= 0x08,
+	RX_ARP_REQUEST					= 0x09,
+	FW_DECISION_DISCONNECT			= 0x10,
+	RX_MAGIC_PKT					= 0x21,
+	RX_UNICAST_PKT					= 0x22,
+	RX_PATTERN_PKT					= 0x23,
+	RTD3_SSID_MATCH					= 0x24,
+	RX_REALWOW_V2_WAKEUP_PKT		= 0x30,
+	RX_REALWOW_V2_ACK_LOST			= 0x31,
+	ENABLE_FAIL_DMA_IDLE			= 0x40,
+	ENABLE_FAIL_DMA_PAUSE			= 0x41,
+	RTIME_FAIL_DMA_IDLE				= 0x42,
+	RTIME_FAIL_DMA_PAUSE			= 0x43,
+	RX_PNO							= 0x55,
+	AP_OFFLOAD_WAKEUP				= 0x66,
+	CLK_32K_UNLOCK					= 0xFD,
+	CLK_32K_LOCK					= 0xFE
+}WAKEUP_REASON;
+
+/*
+ * 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_VI							0x5/* 0x4 */
+#define QSLT_VO							0x7/* 0x6 */
 #define QSLT_BEACON						0x10
 #define QSLT_HIGH						0x11
 #define QSLT_MGNT						0x12
 #define QSLT_CMD						0x13
 
-// BK, BE, VI, VO, HCCA, MANAGEMENT, COMMAND, HIGH, BEACON.
-//#define MAX_TX_QUEUE		9
+/* 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
-#define TX_SELE_EQ			BIT(3)		// Extern Queue
+#define TX_SELE_HQ			BIT(0)		/* High Queue */
+#define TX_SELE_LQ			BIT(1)		/* Low Queue */
+#define TX_SELE_NQ			BIT(2)		/* Normal Queue */
+#define TX_SELE_EQ			BIT(3)		/* Extern Queue */
 
-#define PageNum_128(_Len)		(u32)(((_Len)>>7) + ((_Len)&0x7F ? 1:0))
-#define PageNum_256(_Len)		(u32)(((_Len)>>8) + ((_Len)&0xFF ? 1:0))
-#define PageNum_512(_Len)		(u32)(((_Len)>>9) + ((_Len)&0x1FF ? 1:0))
-#define PageNum(_Len, _Size)		(u32)(((_Len)/(_Size)) + ((_Len)&((_Size) - 1) ? 1:0))
+#define PageNum_128(_Len)		(u32)(((_Len)>>7) + ((_Len) & 0x7F ? 1 : 0))
+#define PageNum_256(_Len)		(u32)(((_Len)>>8) + ((_Len) & 0xFF ? 1 : 0))
+#define PageNum_512(_Len)		(u32)(((_Len)>>9) + ((_Len) & 0x1FF ? 1 : 0))
+#define PageNum(_Len, _Size)		(u32)(((_Len)/(_Size)) + ((_Len)&((_Size) - 1) ? 1 : 0))
 
-struct dbg_rx_counter
-{
+struct dbg_rx_counter {
 	u32	rx_pkt_ok;
 	u32	rx_pkt_crc_error;
-	u32	rx_pkt_drop;	
+	u32	rx_pkt_drop;
 	u32	rx_ofdm_fa;
 	u32	rx_cck_fa;
 	u32	rx_ht_fa;
 };
-void rtw_dump_mac_rx_counters(_adapter* padapter,struct dbg_rx_counter *rx_counter);
-void rtw_dump_phy_rx_counters(_adapter* padapter,struct dbg_rx_counter *rx_counter);
-void rtw_reset_mac_rx_counters(_adapter* padapter);
-void rtw_reset_phy_rx_counters(_adapter* padapter);
+
+#ifdef CONFIG_MBSSID_CAM
+	#define DBG_MBID_CAM_DUMP
+
+	void rtw_mbid_cam_init(struct dvobj_priv *dvobj);
+	void rtw_mbid_cam_deinit(struct dvobj_priv *dvobj);
+	void rtw_mbid_cam_reset(_adapter *adapter);
+	u8 rtw_get_max_mbid_cam_id(_adapter *adapter);
+	u8 rtw_get_mbid_cam_entry_num(_adapter *adapter);
+	int rtw_mbid_cam_cache_dump(void *sel, const char *fun_name , _adapter *adapter);
+	int rtw_mbid_cam_dump(void *sel, const char *fun_name, _adapter *adapter);
+	void rtw_mbid_cam_restore(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	void rtw_hal_set_macaddr_mbid(_adapter *adapter, u8 *mac_addr);
+	void rtw_hal_change_macaddr_mbid(_adapter *adapter, u8 *mac_addr);
+	#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	u16 rtw_hal_bcn_interval_adjust(_adapter *adapter, u16 bcn_interval);
+	#endif
+#endif
+
+void rtw_dump_mac_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter);
+void rtw_dump_phy_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter);
+void rtw_reset_mac_rx_counters(_adapter *padapter);
+void rtw_reset_phy_rx_counters(_adapter *padapter);
+void rtw_reset_phy_trx_ok_counters(_adapter *padapter);
 
 #ifdef DBG_RX_COUNTER_DUMP
-#define DUMP_DRV_RX_COUNTER	BIT0
-#define DUMP_MAC_RX_COUNTER	BIT1
-#define DUMP_PHY_RX_COUNTER	BIT2
-#define DUMP_DRV_TRX_COUNTER_DATA	BIT3
+	#define DUMP_DRV_RX_COUNTER	BIT0
+	#define DUMP_MAC_RX_COUNTER	BIT1
+	#define DUMP_PHY_RX_COUNTER	BIT2
+	#define DUMP_DRV_TRX_COUNTER_DATA	BIT3
 
-void rtw_dump_phy_rxcnts_preprocess(_adapter* padapter,u8 rx_cnt_mode);
-void rtw_dump_rx_counters(_adapter* padapter);
+	void rtw_dump_phy_rxcnts_preprocess(_adapter *padapter, u8 rx_cnt_mode);
+	void rtw_dump_rx_counters(_adapter *padapter);
 #endif
 
 void dump_chip_info(HAL_VERSION	ChipVersion);
@@ -285,6 +331,10 @@ void rtw_hal_config_rftype(PADAPTER  padapter);
 #define WL_FUNC_FTM			BIT3
 #define WL_FUNC_BIT_NUM		4
 
+#define TBTT_PROHIBIT_SETUP_TIME 0x04 /* 128us, unit is 32us */
+#define TBTT_PROHIBIT_HOLD_TIME 0x80 /* 4ms, unit is 32us*/
+#define TBTT_PROHIBIT_HOLD_TIME_STOP_BCN 0x64 /* 3.2ms unit is 32us*/
+
 int hal_spec_init(_adapter *adapter);
 void dump_hal_spec(void *sel, _adapter *adapter);
 
@@ -298,7 +348,7 @@ u8 hal_largest_bw(_adapter *adapter, u8 in_bw);
 
 bool hal_chk_wl_func(_adapter *adapter, u8 func);
 
-u8 hal_com_config_channel_plan(
+void hal_com_config_channel_plan(
 	IN	PADAPTER padapter,
 	IN	char *hw_alpha2,
 	IN	u8 hw_chplan,
@@ -306,7 +356,7 @@ u8 hal_com_config_channel_plan(
 	IN	u8 sw_chplan,
 	IN	u8 def_chplan,
 	IN	BOOLEAN AutoLoadFail
-	);
+);
 
 int hal_config_macaddr(_adapter *adapter, bool autoload_fail);
 
@@ -314,11 +364,11 @@ BOOLEAN
 HAL_IsLegalChannel(
 	IN	PADAPTER	Adapter,
 	IN	u32			Channel
-	);
+);
 
 u8	MRateToHwRate(u8 rate);
 
-u8	HwRateToMRate(u8 rate);
+u8	hw_rate_to_m_rate(u8 rate);
 
 void	HalSetBrateCfg(
 	IN PADAPTER		Adapter,
@@ -329,214 +379,301 @@ BOOLEAN
 Hal_MappingOutPipe(
 	IN	PADAPTER	pAdapter,
 	IN	u8		NumOutPipe
-	);
+);
 
-void hal_init_macaddr(_adapter *adapter);
+void rtw_dump_fw_info(void *sel, _adapter *adapter);
+void rtw_restore_hw_port_cfg(_adapter *adapter);
+void rtw_restore_mac_addr(_adapter *adapter);/*set mac addr when hal_init for all iface*/
+void rtw_hal_dump_macaddr(void *sel, _adapter *adapter);
 
 void rtw_init_hal_com_default_value(PADAPTER Adapter);
 
+#ifdef CONFIG_FW_C2H_REG
 void c2h_evt_clear(_adapter *adapter);
-s32 c2h_evt_read(_adapter *adapter, u8 *buf);
 s32 c2h_evt_read_88xx(_adapter *adapter, u8 *buf);
+#endif
+
+#ifdef CONFIG_FW_C2H_PKT
+void rtw_hal_c2h_pkt_pre_hdl(_adapter *adapter, u8 *buf, u16 len);
+void rtw_hal_c2h_pkt_hdl(_adapter *adapter, u8 *buf, u16 len);
+#endif
+
+u8 rtw_get_mgntframe_raid(_adapter *adapter, unsigned char network_type);
 
-u8  rtw_hal_networktype_to_raid(_adapter *adapter, struct sta_info *psta);
-u8 rtw_get_mgntframe_raid(_adapter *adapter,unsigned char network_type);
-void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta);
+void rtw_hal_update_sta_wset(_adapter *adapter, struct sta_info *psta);
+s8 rtw_get_sta_rx_nss(_adapter *adapter, struct sta_info *psta);
+s8 rtw_get_sta_tx_nss(_adapter *adapter, struct sta_info *psta);
+void rtw_hal_update_sta_ra_info(PADAPTER padapter, struct sta_info *psta);
 
 /* access HW only */
 u32 rtw_sec_read_cam(_adapter *adapter, u8 addr);
 void rtw_sec_write_cam(_adapter *adapter, u8 addr, u32 wdata);
 void rtw_sec_read_cam_ent(_adapter *adapter, u8 id, u8 *ctrl, u8 *mac, u8 *key);
 void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key);
+void rtw_sec_clr_cam_ent(_adapter *adapter, u8 id);
 bool rtw_sec_read_cam_is_gk(_adapter *adapter, u8 id);
 
+u8 rtw_hal_rcr_check(_adapter *adapter, u32 check_bit);
+
+u8 rtw_hal_rcr_add(_adapter *adapter, u32 add);
+u8 rtw_hal_rcr_clear(_adapter *adapter, u32 clear);
+void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action);
+
 void hw_var_port_switch(_adapter *adapter);
 
-void SetHwReg(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHwReg(PADAPTER padapter, u8 variable, u8 *val);
 void GetHwReg(PADAPTER padapter, u8 variable, u8 *val);
 void rtw_hal_check_rxfifo_full(_adapter *adapter);
+void rtw_hal_reqtxrpt(_adapter *padapter, u8 macid);
 
 u8 SetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value);
 u8 GetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value);
 
-BOOLEAN 
+BOOLEAN
 eqNByte(
-	u8*	str1,
-	u8*	str2,
+	u8	*str1,
+	u8	*str2,
 	u32	num
-	);
+);
 
 u32
 MapCharToHexDigit(
 	IN	char	chTmp
 );
 
-BOOLEAN 
+BOOLEAN
 GetHexValueFromString(
-	IN		char*			szStr,
-	IN OUT	u32*			pu4bVal,
-	IN OUT	u32*			pu4bMove
-	);
+	IN		char			*szStr,
+	IN OUT	u32			*pu4bVal,
+	IN OUT	u32			*pu4bMove
+);
 
-BOOLEAN 
+BOOLEAN
 GetFractionValueFromString(
-	IN		char*		szStr,
-	IN OUT	u8*			pInteger,
-	IN OUT	u8*			pFraction,
-	IN OUT	u32*		pu4bMove
-	);
+	IN		char		*szStr,
+	IN OUT	u8			*pInteger,
+	IN OUT	u8			*pFraction,
+	IN OUT	u32		*pu4bMove
+);
 
 BOOLEAN
 IsCommentString(
-	IN		char*		szStr
-	);
+	IN		char		*szStr
+);
 
-BOOLEAN 
+BOOLEAN
 ParseQualifiedString(
-    IN	char* In, 
-    IN OUT  u32* Start, 
-    OUT	char* Out, 
-    IN	char  LeftQualifier, 
-    IN	char  RightQualifier
-    );
+	IN	char *In,
+	IN OUT  u32 *Start,
+	OUT	char *Out,
+	IN	char  LeftQualifier,
+	IN	char  RightQualifier
+);
 
 BOOLEAN
 GetU1ByteIntegerFromStringInDecimal(
-	IN		char* Str,
-	IN OUT	u8* pInt
-	);
+	IN		char *Str,
+	IN OUT	u8 *pInt
+);
 
 BOOLEAN
 isAllSpaceOrTab(
-	u8*	data,
+	u8	*data,
 	u8	size
-	);
+);
 
-void linked_info_dump(_adapter *padapter,u8 benable);
+void linked_info_dump(_adapter *padapter, u8 benable);
 #ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
-void rtw_get_raw_rssi_info(void *sel, _adapter *padapter);
-void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe);
-void rtw_dump_raw_rssi_info(_adapter *padapter);
+	void rtw_get_raw_rssi_info(void *sel, _adapter *padapter);
+	void rtw_dump_raw_rssi_info(_adapter *padapter, void *sel);
 #endif
 
-#define		HWSET_MAX_SIZE			512
+#ifdef DBG_RX_DFRAME_RAW_DATA
+	void rtw_dump_rx_dframe_info(_adapter *padapter, void *sel);
+#endif
+void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe);
+#define		HWSET_MAX_SIZE			1024
+
 #ifdef CONFIG_EFUSE_CONFIG_FILE
-#define		EFUSE_FILE_COLUMN_NUM		16
 u32 Hal_readPGDataFromConfigFile(PADAPTER padapter);
 u32 Hal_ReadMACAddrFromFile(PADAPTER padapter, u8 *mac_addr);
 #endif /* CONFIG_EFUSE_CONFIG_FILE */
 
-int check_phy_efuse_tx_power_info_valid(PADAPTER padapter);
 int hal_efuse_macaddr_offset(_adapter *adapter);
 int Hal_GetPhyEfuseMACAddr(PADAPTER padapter, u8 *mac_addr);
 void rtw_dump_cur_efuse(PADAPTER padapter);
 
-#ifdef CONFIG_RF_GAIN_OFFSET
-void rtw_bb_rf_gain_offset(_adapter *padapter);
-#endif //CONFIG_RF_GAIN_OFFSET
+#ifdef CONFIG_RF_POWER_TRIM
+	void rtw_bb_rf_gain_offset(_adapter *padapter);
+#endif /*CONFIG_RF_POWER_TRIM*/
 
 void dm_DynamicUsbTxAgg(_adapter *padapter, u8 from_timer);
-u8 rtw_hal_busagg_qsel_check(_adapter *padapter,u8 pre_qsel,u8 next_qsel);
-void GetHalODMVar(	
-	PADAPTER				Adapter,
-	HAL_ODM_VARIABLE		eVariable,
-	PVOID					pValue1,
-	PVOID					pValue2);
-void SetHalODMVar(
-	PADAPTER				Adapter,
-	HAL_ODM_VARIABLE		eVariable,
-	PVOID					pValue1,
-	BOOLEAN					bSet);
-
-#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
-struct noise_info
-{
-	u8 		bPauseDIG;
-	u8 		IGIValue;
-	u32 	max_time;//ms	
-	u8		chan;
-};
+u8 rtw_hal_busagg_qsel_check(_adapter *padapter, u8 pre_qsel, u8 next_qsel);
+
+u8 rtw_get_current_tx_rate(_adapter *padapter, struct sta_info *psta);
+u8 rtw_get_current_tx_sgi(_adapter *padapter, struct sta_info *psta);
+
+void rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished);
+u8 rtw_hal_get_rsvd_page_num(struct _ADAPTER *adapter);
+
+#ifdef CONFIG_TSF_RESET_OFFLOAD
+int rtw_hal_reset_tsf(_adapter *adapter, u8 reset_port);
 #endif
 
-void rtw_get_noise(_adapter* padapter);
-u8 rtw_get_current_tx_rate(_adapter *padapter, u8 macid);
-void rtw_hal_set_fw_rsvd_page(_adapter* adapter, bool finished);
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		s32 rtw_hal_ch_sw_oper_offload(_adapter *padapter, u8 channel, u8 channel_offset, u16 bwmode);
+	#endif
+#endif
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+s32 rtw_hal_set_wifi_port_id_cmd(_adapter *adapter);
+#endif
 
 #ifdef CONFIG_GPIO_API
-u8 rtw_hal_get_gpio(_adapter* adapter, u8 gpio_num);
-int rtw_hal_set_gpio_output_value(_adapter* adapter, u8 gpio_num, bool isHigh);
-int rtw_hal_config_gpio(_adapter* adapter, u8 gpio_num, bool isOutput);
-int rtw_hal_register_gpio_interrupt(_adapter* adapter, int gpio_num, void(*callback)(u8 level));
-int rtw_hal_disable_gpio_interrupt(_adapter* adapter, int gpio_num);
+	u8 rtw_hal_get_gpio(_adapter *adapter, u8 gpio_num);
+	int rtw_hal_set_gpio_output_value(_adapter *adapter, u8 gpio_num, bool isHigh);
+	int rtw_hal_config_gpio(_adapter *adapter, u8 gpio_num, bool isOutput);
+	int rtw_hal_register_gpio_interrupt(_adapter *adapter, int gpio_num, void(*callback)(u8 level));
+	int rtw_hal_disable_gpio_interrupt(_adapter *adapter, int gpio_num);
 #endif
 
+s8 rtw_hal_ch_sw_iqk_info_search(_adapter *padapter, u8 central_chnl, u8 bw_mode);
+void rtw_hal_ch_sw_iqk_info_backup(_adapter *adapter);
+void rtw_hal_ch_sw_iqk_info_restore(_adapter *padapter, u8 ch_sw_use_case);
+
 #ifdef CONFIG_GPIO_WAKEUP
-void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable);
-void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval);
+	void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable);
+	void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval);
+	void rtw_hal_set_input_gpio(_adapter *padapter, u8 index);
 #endif
 
-typedef enum _HAL_PHYDM_OPS {
-	HAL_PHYDM_DIS_ALL_FUNC,
-	HAL_PHYDM_FUNC_SET,
-	HAL_PHYDM_FUNC_CLR,
-	HAL_PHYDM_ABILITY_BK,
-	HAL_PHYDM_ABILITY_RESTORE,
-	HAL_PHYDM_ABILITY_SET,
-	HAL_PHYDM_ABILITY_GET,
-} HAL_PHYDM_OPS;
+#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+	extern char *rtw_phy_file_path;
+	extern char rtw_phy_para_file_path[PATH_LENGTH_MAX];
+	#define GetLineFromBuffer(buffer)   strsep(&buffer, "\r\n")
+#endif
 
+void update_IOT_info(_adapter *padapter);
 
-#define DYNAMIC_FUNC_DISABLE		(0x0)
-u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability);
+void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap);
+void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf);
 
-#define rtw_phydm_func_disable_all(adapter)	\
-	rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0)
+void ResumeTxBeacon(_adapter *padapter);
+void StopTxBeacon(_adapter *padapter);
+#ifdef CONFIG_MI_WITH_MBSSID_CAM /*HW port0 - MBSS*/
+	void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode);
+	u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr);
+#endif
 
-#define rtw_phydm_func_for_offchannel(adapter) \
-	do { \
-		rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0); \
-		if (rtw_odm_adaptivity_needed(adapter)) \
-			rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ODM_BB_ADAPTIVITY); \
-	} while (0)
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	u8	rtw_hal_antdiv_before_linked(_adapter *padapter);
+	void	rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
+#endif
 
-#define rtw_phydm_func_set(adapter, ability)	\
-	rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ability)
+#ifdef DBG_SEC_CAM_MOVE
+	void rtw_hal_move_sta_gk_to_dk(_adapter *adapter);
+	void rtw_hal_read_sta_dk_key(_adapter *adapter, u8 key_id);
+#endif
 
-#define rtw_phydm_func_clr(adapter, ability)	\
-	rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_CLR, ability)
+#ifdef CONFIG_LPS_PG
+#define LPSPG_RSVD_PAGE_SET_MACID(_rsvd_pag, _value)		SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 0, 8, _value)/*used macid*/
+#define LPSPG_RSVD_PAGE_SET_MBSSCAMID(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 8, 8, _value)/*used BSSID CAM entry*/
+#define LPSPG_RSVD_PAGE_SET_PMC_NUM(_rsvd_pag, _value)		SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 16, 8, _value)/*Max used Pattern Match CAM entry*/
+#define LPSPG_RSVD_PAGE_SET_MU_RAID_GID(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x00, 24, 8, _value)/*Max MU rate table Group ID*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_NUM(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x04, 0, 8, _value)/*used Security CAM entry number*/
+#define LPSPG_RSVD_PAGE_SET_DRV_RSVDPAGE_NUM(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x04, 8, 8, _value)/*Txbuf used page number for fw offload*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID1(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 0, 8, _value)/*used Security CAM entry -1*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID2(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 8, 8, _value)/*used Security CAM entry -2*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID3(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 16, 8, _value)/*used Security CAM entry -3*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID4(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x08, 24, 8, _value)/*used Security CAM entry -4*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID5(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 0, 8, _value)/*used Security CAM entry -5*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID6(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 8, 8, _value)/*used Security CAM entry -6*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID7(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 16, 8, _value)/*used Security CAM entry -7*/
+#define LPSPG_RSVD_PAGE_SET_SEC_CAM_ID8(_rsvd_pag, _value)	SET_BITS_TO_LE_4BYTE(_rsvd_pag+0x0C, 24, 8, _value)/*used Security CAM entry -8*/
+enum lps_pg_hdl_id {
+	LPS_PG_INFO_CFG = 0,
+	LPS_PG_REDLEMEM,
+	LPS_PG_RESEND_H2C,
+};
 
-#define rtw_phydm_ability_backup(adapter)	\
-	rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_BK, 0)
+	u8 rtw_hal_set_lps_pg_info(_adapter *adapter);
+#endif
 
-#define rtw_phydm_ability_restore(adapter)	\
-	rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_RESTORE, 0)
+int rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset, u32 page_num, u8 *buffer, u32 buffer_size);
+void rtw_hal_construct_beacon(_adapter *padapter, u8 *pframe, u32 *pLength);
+void rtw_hal_construct_NullFunctionData(PADAPTER, u8 *pframe, u32 *pLength,
+				u8 *StaAddr, u8 bQoS, u8 AC, u8 bEosp, u8 bForcePowerSave);
 
-#define rtw_phydm_ability_set(adapter, ability)	\
-	rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_SET, ability)
+#ifdef CONFIG_WOWLAN
+struct rtl_wow_pattern {
+	u16	crc;
+	u8	type;
+	u32	mask[4];
+};
+void rtw_wow_pattern_cam_dump(_adapter *adapter);
 
-static inline u32 rtw_phydm_ability_get(_adapter *adapter)
-{
-	return rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_GET, 0);
-}
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+void rtw_wow_pattern_read_cam_ent(_adapter *adapter, u8 id, struct  rtl_wow_pattern *context);
+void rtw_dump_wow_pattern(void *sel, struct rtl_wow_pattern *pwow_pattern, u8 idx);
+#endif
 
-#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
-extern char *rtw_phy_file_path;
-extern char rtw_phy_para_file_path[PATH_LENGTH_MAX];
-#define GetLineFromBuffer(buffer)   strsep(&buffer, "\r\n")
+struct rtw_ndp_info {
+	u8 enable:1;
+	u8 check_remote_ip:1; /* Need to Check Sender IP or not */
+	u8 rsvd:6;
+	u8 num_of_target_ip; /* Number of Check IP which NA query IP */
+	u8 target_link_addr[6]; /* DUT's MAC address */
+	u8 remote_ipv6_addr[16]; /* Just respond IP */
+	u8 target_ipv6_addr[16]; /* target IP */
+};
+#define REMOTE_INFO_CTRL_SET_VALD_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 0, 0, 8, _value)
+#define REMOTE_INFO_CTRL_SET_PTK_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 1, 0, 1, _value)
+#define REMOTE_INFO_CTRL_SET_GTK_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 1, 1, 1, _value)
+#define REMOTE_INFO_CTRL_SET_GTK_IDX(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 2, 0, 8, _value)
+#endif /*CONFIG_WOWLAN*/
+
+void rtw_dump_phy_cap(void *sel, _adapter *adapter);
+void rtw_dump_rsvd_page(void *sel, _adapter *adapter, u8 page_offset, u8 page_num);
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+void rtw_dump_fifo(void *sel, _adapter *adapter, u8 fifo_sel, u32 fifo_addr, u32 fifo_size);
 #endif
 
-#ifdef CONFIG_FW_C2H_DEBUG
-void Debug_FwC2H(PADAPTER padapter, u8 *pdata, u8 len);
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+s32 rtw_hal_set_default_port_id_cmd(_adapter *adapter, u8 mac_id);
+s32 rtw_set_default_port_id(_adapter *adapter);
+s32 rtw_set_ps_rsvd_page(_adapter *adapter);
 #endif
-/*CONFIG_FW_C2H_DEBUG*/
 
-void update_IOT_info(_adapter *padapter);
+#ifdef CONFIG_P2P_PS
+#ifdef RTW_HALMAC
+void rtw_set_p2p_ps_offload_cmd(_adapter *adapter, u8 p2p_ps_state);
+#endif
+#endif
 
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-void rtw_acs_start(_adapter *padapter, bool bStart);
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+void rtw_hal_switch_chnl_and_set_bw_offload(_adapter *adapter, u8 central_ch, u8 pri_ch_idx, u8 bw);
 #endif
 
-void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap);
+s16 translate_dbm_to_percentage(s16 signal);
 
-#endif //__HAL_COMMON_H__
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+#ifdef CONFIG_BCN_RECOVERY
+u8 rtw_ap_bcn_recovery(_adapter *padapter);
+#endif
+#ifdef CONFIG_BCN_XMIT_PROTECT
+u8 rtw_ap_bcn_queue_empty_check(_adapter *padapter, u32 txbcn_timer_ms);
+#endif
+#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
 
+void rtw_hal_get_rf_path(struct dvobj_priv *d, enum rf_type *type,
+			 enum bb_path *tx, enum bb_path *rx);
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+void rtw_hal_beamforming_config_csirate(PADAPTER adapter);
+#endif
+#endif
+#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_h2c.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_h2c.h
index b595a930660b..e95887cede25 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_h2c.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_h2c.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,52 +12,68 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __COMMON_H2C_H__
 #define __COMMON_H2C_H__
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD DEFINITION    ------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
-// 88e, 8723b, 8812, 8821, 92e use the same FW code base
-enum h2c_cmd{
-	//Common Class: 000
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * 88e, 8723b, 8812, 8821, 92e use the same FW code base */
+enum h2c_cmd {
+	/* Common Class: 000 */
 	H2C_RSVD_PAGE = 0x00,
 	H2C_MEDIA_STATUS_RPT = 0x01,
 	H2C_SCAN_ENABLE = 0x02,
 	H2C_KEEP_ALIVE = 0x03,
-	H2C_DISCON_DECISION = 0x04,	
-	H2C_PSD_OFFLOAD = 0x05,	
+	H2C_DISCON_DECISION = 0x04,
+	H2C_PSD_OFFLOAD = 0x05,
 	H2C_CUSTOMER_STR_REQ = 0x06,
-	H2C_AP_OFFLOAD = 0x08,	
-	H2C_BCN_RSVDPAGE = 0x09,	
-	H2C_PROBERSP_RSVDPAGE = 0x0A,	
-	H2C_FCS_RSVDPAGE = 0x10,	
-	H2C_FCS_INFO = 0x11,	
+	H2C_AP_OFFLOAD = 0x08,
+	H2C_BCN_RSVDPAGE = 0x09,
+	H2C_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_FCS_RSVDPAGE = 0x10,
+	H2C_FCS_INFO = 0x11,
 	H2C_AP_WOW_GPIO_CTRL = 0x13,
-
-	//PoweSave Class: 001
+#ifdef CONFIG_MCC_MODE
+	H2C_MCC_RQT_TSF = 0x15,
+	H2C_MCC_MACID_BITMAP = 0x16,
+	H2C_MCC_LOCATION = 0x10,
+	H2C_MCC_CTRL_V2 = 0x17,
+	H2C_MCC_CTRL = 0x18,
+	H2C_MCC_TIME_SETTING = 0x19,
+	H2C_MCC_IQK_PARAM = 0x1A,
+#endif /* CONFIG_MCC_MODE */
+	H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C,
+	H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D,
+
+	/* PoweSave Class: 001 */
 	H2C_SET_PWR_MODE = 0x20,
 	H2C_PS_TUNING_PARA = 0x21,
 	H2C_PS_TUNING_PARA2 = 0x22,
-	H2C_P2P_LPS_PARAM = 0x23,	
-	H2C_P2P_PS_OFFLOAD = 0x24,	
-	H2C_PS_SCAN_ENABLE = 0x25,	
-	H2C_SAP_PS_ = 0x26,	
-	H2C_INACTIVE_PS_ = 0x27, //Inactive_PS
+	H2C_P2P_LPS_PARAM = 0x23,
+	H2C_P2P_PS_OFFLOAD = 0x24,
+	H2C_PS_SCAN_ENABLE = 0x25,
+	H2C_SAP_PS_ = 0x26,
+	H2C_INACTIVE_PS_ = 0x27, /* Inactive_PS */
 	H2C_FWLPS_IN_IPS_ = 0x28,
-	
-	//Dynamic Mechanism Class: 010
+#ifdef CONFIG_LPS_POFF
+	H2C_LPS_POFF_CTRL = 0x29,
+	H2C_LPS_POFF_PARAM = 0x2A,
+#endif
+#ifdef CONFIG_LPS_PG
+	H2C_LPS_PG_INFO = 0x2B,
+#endif
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	H2C_DEFAULT_PORT_ID = 0x2C,
+#endif
+	/* Dynamic Mechanism Class: 010 */
 	H2C_MACID_CFG = 0x40,
-	H2C_TXBF = 0x41,	
-	H2C_RSSI_SETTING = 0x42,	
-	H2C_AP_REQ_TXRPT = 0x43,	
-	H2C_INIT_RATE_COLLECT = 0x44,	
+	H2C_TXBF = 0x41,
+	H2C_RSSI_SETTING = 0x42,
+	H2C_AP_REQ_TXRPT = 0x43,
+	H2C_INIT_RATE_COLLECT = 0x44,
 	H2C_IQ_CALIBRATION	= 0x45,
 
 	H2C_RA_MASK_3SS = 0x46,/* for 8814A */
@@ -64,8 +81,10 @@ enum h2c_cmd{
 	H2C_DYNAMIC_TX_PATH = 0x48,/* for 8814A */
 
 	H2C_FW_TRACE_EN = 0x49,
-	
-	//BT Class: 011
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	H2C_REQ_PER_RPT = 0x4e,
+#endif
+	/* BT Class: 011 */
 	H2C_B_TYPE_TDMA = 0x60,
 	H2C_BT_INFO = 0x61,
 	H2C_FORCE_BT_TXPWR = 0x62,
@@ -77,12 +96,14 @@ enum h2c_cmd{
 	H2C_BT_CONTROL = 0x68,
 	H2C_BT_WIFI_CTRL = 0x69,
 	H2C_BT_FW_PATCH = 0x6A,
-	
-	//WOWLAN Class: 100
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+	H2C_BTC_WL_PORT_ID = 0x71,
+#endif
+	/* WOWLAN Class: 100 */
 	H2C_WOWLAN = 0x80,
 	H2C_REMOTE_WAKE_CTRL = 0x81,
-	H2C_AOAC_GLOBAL_INFO = 0x82,	
-	H2C_AOAC_RSVD_PAGE = 0x83,	
+	H2C_AOAC_GLOBAL_INFO = 0x82,
+	H2C_AOAC_RSVD_PAGE = 0x83,
 	H2C_AOAC_RSVD_PAGE2 = 0x84,
 	H2C_D0_SCAN_OFFLOAD_CTRL = 0x85,
 	H2C_D0_SCAN_OFFLOAD_INFO = 0x86,
@@ -96,61 +117,101 @@ enum h2c_cmd{
 	H2C_CUSTOMER_STR_W1 = 0xC6,
 	H2C_CUSTOMER_STR_W2 = 0xC7,
 	H2C_CUSTOMER_STR_W3 = 0xC8,
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	H2C_FW_DBG_MSG_PKT = 0xE1,
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 	H2C_MAXID,
 };
 
 #define H2C_INACTIVE_PS_LEN		3
 #define H2C_RSVDPAGE_LOC_LEN		5
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+#define H2C_DEFAULT_PORT_ID_LEN		2
+#define H2C_MEDIA_STATUS_RPT_LEN		4
+#else
 #define H2C_MEDIA_STATUS_RPT_LEN		3
+#endif
 #define H2C_KEEP_ALIVE_CTRL_LEN	2
-#define H2C_DISCON_DECISION_LEN	 	3
+#define H2C_DISCON_DECISION_LEN		3
 #define H2C_AP_OFFLOAD_LEN		3
 #define H2C_AP_WOW_GPIO_CTRL_LEN	4
 #define H2C_AP_PS_LEN			2
 #define H2C_PWRMODE_LEN			7
 #define H2C_PSTUNEPARAM_LEN			4
-#define H2C_MACID_CFG_LEN	 	7
+#define H2C_MACID_CFG_LEN		7
 #define H2C_BTMP_OPER_LEN			5
-#define H2C_WOWLAN_LEN			5
+#define H2C_WOWLAN_LEN			6
 #define H2C_REMOTE_WAKE_CTRL_LEN	3
 #define H2C_AOAC_GLOBAL_INFO_LEN	2
 #define H2C_AOAC_RSVDPAGE_LOC_LEN	7
 #define H2C_SCAN_OFFLOAD_CTRL_LEN	4
 #define H2C_BT_FW_PATCH_LEN			6
 #define H2C_RSSI_SETTING_LEN		4
-#define H2C_AP_REQ_TXRPT_LEN		2
+#define H2C_AP_REQ_TXRPT_LEN		3
 #define H2C_FORCE_BT_TXPWR_LEN		3
 #define H2C_BCN_RSVDPAGE_LEN		5
 #define H2C_PROBERSP_RSVDPAGE_LEN	5
 #define H2C_P2PRSVDPAGE_LOC_LEN	5
 #define H2C_P2P_OFFLOAD_LEN	3
+#ifdef CONFIG_MCC_MODE
+	#define H2C_MCC_CTRL_LEN			7
+#ifdef CONFIG_MCC_MODE_V2
+	#define H2C_MCC_LOCATION_LEN		7
+#else
+	#define H2C_MCC_LOCATION_LEN		3
+#endif
+	#define H2C_MCC_MACID_BITMAP_LEN	6
+	#define H2C_MCC_RQT_TSF_LEN		1
+	#define H2C_MCC_TIME_SETTING_LEN		6
+	#define H2C_MCC_IQK_PARAM_LEN		7
+#endif /* CONFIG_MCC_MODE */
+#ifdef CONFIG_LPS_PG
+	#define H2C_LPS_PG_INFO_LEN		2
+	#define H2C_LPSPG_LEN			16
+#endif
+#ifdef CONFIG_LPS_POFF
+	#define H2C_LPS_POFF_CTRL_LEN		1
+	#define H2C_LPS_POFF_PARAM_LEN		5
+#endif
+
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+#define H2C_BTC_WL_PORT_ID_LEN	1
+#endif
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	#define H2C_FW_DBG_MSG_PKT_LEN	2
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+#define H2C_SINGLE_CHANNELSWITCH_V2_LEN 2
+
+#define eq_mac_addr(a, b)						(((a)[0] == (b)[0] && (a)[1] == (b)[1] && (a)[2] == (b)[2] && (a)[3] == (b)[3] && (a)[4] == (b)[4] && (a)[5] == (b)[5]) ? 1 : 0)
+#define cp_mac_addr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3], (des)[4] = (src)[4], (des)[5] = (src)[5])
+#define cpIpAddr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3])
+
 
-#define eqMacAddr(a,b)						( ((a)[0]==(b)[0] && (a)[1]==(b)[1] && (a)[2]==(b)[2] && (a)[3]==(b)[3] && (a)[4]==(b)[4] && (a)[5]==(b)[5]) ? 1:0 )
-#define cpMacAddr(des,src)					((des)[0]=(src)[0],(des)[1]=(src)[1],(des)[2]=(src)[2],(des)[3]=(src)[3],(des)[4]=(src)[4],(des)[5]=(src)[5])
-#define cpIpAddr(des,src)					((des)[0]=(src)[0],(des)[1]=(src)[1],(des)[2]=(src)[2],(des)[3]=(src)[3])
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-//
-// ARP packet
-//
-// LLC Header
+/*
+* ARP packet
+*
+* LLC Header */
 #define GET_ARP_PKT_LLC_TYPE(__pHeader)					ReadLE2Byte(((u8 *)(__pHeader)) + 6)
 
-//ARP element
+/* ARP element */
 #define GET_ARP_PKT_OPERATION(__pHeader)				ReadLE2Byte(((u8 *)(__pHeader)) + 6)
-#define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val) 	cpMacAddr((u8*)(_val), ((u8*)(__pHeader))+8)
-#define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val) 		cpIpAddr((u8*)(_val), ((u8*)(__pHeader))+14)
-#define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val) 	cpMacAddr((u8*)(_val), ((u8*)(__pHeader))+18)
-#define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val) 	cpIpAddr((u8*)(_val), ((u8*)(__pHeader))+24)
+#define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+8)
+#define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+14)
+#define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+18)
+#define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)	cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+24)
 
 #define SET_ARP_PKT_HW(__pHeader, __Value)					WriteLE2Byte(((u8 *)(__pHeader)) + 0, __Value)
 #define SET_ARP_PKT_PROTOCOL(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 2, __Value)
 #define SET_ARP_PKT_HW_ADDR_LEN(__pHeader, __Value)			WriteLE1Byte(((u8 *)(__pHeader)) + 4, __Value)
 #define SET_ARP_PKT_PROTOCOL_ADDR_LEN(__pHeader, __Value)	WriteLE1Byte(((u8 *)(__pHeader)) + 5, __Value)
 #define SET_ARP_PKT_OPERATION(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 6, __Value)
-#define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val) 	cpMacAddr(((u8*)(__pHeader))+8, (u8*)(_val))
-#define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val) 		cpIpAddr(((u8*)(__pHeader))+14, (u8*)(_val))
-#define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val) 	cpMacAddr(((u8*)(__pHeader))+18, (u8*)(_val))
-#define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val) 		cpIpAddr(((u8*)(__pHeader))+24, (u8*)(_val))
+#define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cp_mac_addr(((u8 *)(__pHeader))+8, (u8 *)(_val))
+#define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+14, (u8 *)(_val))
+#define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cp_mac_addr(((u8 *)(__pHeader))+18, (u8 *)(_val))
+#define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+24, (u8 *)(_val))
 
 #define FW_WOWLAN_FUN_EN				BIT(0)
 #define FW_WOWLAN_PATTERN_MATCH			BIT(1)
@@ -176,16 +237,16 @@ enum h2c_cmd{
 #define FW_REALWOWLAN_EN				BIT(5)
 #define FW_WOW_FW_UNICAST_EN			BIT(7)
 
-#endif //CONFIG_WOWLAN
+#endif /* CONFIG_WOWLAN */
 
-//_RSVDPAGE_LOC_CMD_0x00
+/* _RSVDPAGE_LOC_CMD_0x00 */
 #define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 
-//_MEDIA_STATUS_RPT_PARM_CMD_0x01
+/* _MEDIA_STATUS_RPT_PARM_CMD_0x01 */
 #define SET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 1, (__Value))
 #define SET_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 1, 1, (__Value))
 #define SET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 2, 1, (__Value))
@@ -193,6 +254,7 @@ enum h2c_cmd{
 #define SET_H2CCMD_MSRRPT_PARM_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 4, 4, (__Value))
 #define SET_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
 #define SET_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 2, 0, 8, (__Value))
+#define SET_H2CCMD_MSRRPT_PARM_PORT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 3, 0, 3, (__Value))
 
 #define GET_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 0, 1)
 #define GET_H2CCMD_MSRRPT_PARM_MIRACAST(__pH2CCmd)		LE_BITS_TO_1BYTE(((u8 *)(__pH2CCmd)), 2, 1)
@@ -206,9 +268,10 @@ enum h2c_cmd{
 #define H2C_MSR_ROLE_GO		4
 #define H2C_MSR_ROLE_TDLS	5
 #define H2C_MSR_ROLE_ADHOC	6
-#define H2C_MSR_ROLE_MAX	7
+#define H2C_MSR_ROLE_MESH	7
+#define H2C_MSR_ROLE_MAX	8
 
-extern const char * const _h2c_msr_role_str[];
+extern const char *const _h2c_msr_role_str[];
 #define h2c_msr_role_str(role) (((role) >= H2C_MSR_ROLE_MAX) ? _h2c_msr_role_str[H2C_MSR_ROLE_MAX] : _h2c_msr_role_str[(role)])
 
 #define H2C_MSR_FMT "%s %s%s"
@@ -221,15 +284,17 @@ s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miraca
 s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid);
 s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end);
 
-//_KEEP_ALIVE_CMD_0x03
+/* _KEEP_ALIVE_CMD_0x03 */
 #define SET_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 3, __Value)
 #define SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 
-//_DISCONNECT_DECISION_CMD_0x04
+/* _DISCONNECT_DECISION_CMD_0x04 */
 #define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_DISCONDECISION_PORT_NUM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 3, __Value)
 #define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
 
@@ -264,13 +329,13 @@ s32 rtw_hal_h2c_customer_str_write(_adapter *adapter, const u8 *cs);
 s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #endif /* CONFIG_RTW_CUSTOMER_STR */
 
-//_AP_Offload 0x08
+/* _AP_Offload 0x08 */
 #define SET_H2CCMD_AP_WOWLAN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
-//_BCN_RsvdPage	0x09
+/* _BCN_RsvdPage	0x09 */
 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
-//_Probersp_RsvdPage 0x0a
+/* _Probersp_RsvdPage 0x0a */
 #define SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
-//_Probersp_RsvdPage 0x13
+/* _Probersp_RsvdPage 0x13 */
 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
@@ -278,13 +343,129 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION(__pH2CCmd, __Value)SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
-//_AP_PS 0x26
+/* _AP_PS 0x26 */
 #define SET_H2CCMD_AP_WOW_PS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_H2CCMD_AP_WOW_PS_32K_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
 #define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 
-// _WoWLAN PARAM_CMD_0x80
+#ifdef CONFIG_LPS_POFF
+/*PARTIAL OFF Control 0x29*/
+#define SET_H2CCMD_LPS_POFF_CTRL_EN(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+/*PARTIAL OFF PARAM   0x2A*/
+#define SET_H2CCMD_LPS_POFF_PARAM_RDVLD(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_WRVLD(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_STARTADDL(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_STARTADDH(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_ENDADDL(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_H2CCMD_LPS_POFF_PARAM_ENDADDH(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#endif
+
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+/* DEFAULT PORT ID 0x2C*/
+#define SET_H2CCMD_DFTPID_PORT_ID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)), 0, 8, (__Value))
+#define SET_H2CCMD_DFTPID_MAC_ID(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(((u8 *)(__pH2CCmd)) + 1, 0, 8, (__Value))
+#endif
+
+#ifdef CONFIG_MCC_MODE
+/* MCC LOC CMD 0x10 */
+#define SET_H2CCMD_MCC_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 0, 1, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_RFNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 4, 4, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 4, 0, 8, __Value)
+
+/* MCC RQT TSF 0x15 */
+#define SET_H2CCMD_MCC_RQT_TSFX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_RQT_TSFY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+
+/* MCC MAC ID CMD 0x16 */
+#define SET_H2CCMD_MCC_MACID_BITMAP_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_MCC_MACID_BITMAP_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+
+/* NEW MCC CTRL CMD 0x17 */
+#define SET_H2CCMD_MCC_CTRL_V2_ORDER(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_CENTRAL_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_PRIMARY_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_BW(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_ROLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)			
+#define SET_H2CCMD_MCC_CTRL_V2_INCURCH(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DIS_SW_RETRY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DISTXNULL(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_C2HRPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 6, 2, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_TSFX(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_NULL_EARLY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_UPDATE_PARM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
+
+
+/* MCC CTRL CMD 0x18 */
+#define SET_H2CCMD_MCC_CTRL_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_CHIDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
+#define SET_H2CCMD_MCC_CTRL_BW40SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 3, __Value)
+#define SET_H2CCMD_MCC_CTRL_BW80SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 5, 3, __Value)
+#define SET_H2CCMD_MCC_CTRL_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_ROLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)
+#define SET_H2CCMD_MCC_CTRL_INCURCH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_RSVD0(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_RSVD1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_RFETYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_DISTXNULL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 4, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_C2HRPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 5, 2, __Value)
+#define SET_H2CCMD_MCC_CTRL_CHSCAN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
+
+/* MCC Time CMD 0x19 */
+#define SET_H2CCMD_MCC_TIME_SETTING_FW_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_START_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 4, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_UPDATE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 1, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 1, 7, __Value)
+
+/* MCC IQK CMD 0x1A */
+#define SET_H2CCMD_MCC_IQK_READY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_MCC_IQK_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 4, __Value)
+#define SET_H2CCMD_MCC_IQK_PATH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 2, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 2, 6, __Value)
+#define SET_H2CCMD_MCC_IQK_RX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 4, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_M1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 3, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_M2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 3, 5, __Value)
+#define SET_H2CCMD_MCC_IQK_TX_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 6, __Value)
+#endif /* CONFIG_MCC_MODE */
+
+/* CHNL SWITCH OPER OFFLOAD 0x1C */
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 2, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 2, 3, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 5, 3, __Value)
+#define SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 2, 0, 4, __Value)
+
+/* H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D */
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_CENTRAL_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_PRIMARY_CH_IDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 4, __Value)
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 4, 4, __Value)
+
+
+#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
+#define SET_H2CCMD_BTC_WL_PORT_ID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#endif
+
+/* _WoWLAN PARAM_CMD_0x80 */
 #define SET_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
@@ -298,9 +479,15 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 1, __Value)
 #define SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 1, 7, __Value)
-#define SET_H2CCMD_WOWLAN_LOWPR_RX(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 1, __Value)
+#define SET_H2CCMD_WOWLAN_DISABLE_UPHY(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 1, __Value)
+#define SET_H2CCMD_WOWLAN_HST2DEV_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 1, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_DURATION_MS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
 #define SET_H2CCMD_WOWLAN_CHANGE_UNIT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 2, 1, __Value)
-// _REMOTE_WAKEUP_CMD_0x81
+#define SET_H2CCMD_WOWLAN_UNIT_FOR_UPHY_DISABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
+#define SET_H2CCMD_WOWLAN_TAKE_PDN_UPHY_DIS_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
+#define SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
+
+/* _REMOTE_WAKEUP_CMD_0x81 */
 #define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
@@ -309,14 +496,17 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 7, 1, __Value)
 #define SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 1, __Value)
 #define SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 2, 1, __Value)
+#define SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 3, 1, __Value)
+
 #define SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 1, __Value)
 #define SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 1, __Value)
 
-// AOAC_GLOBAL_INFO_0x82
+/* AOAC_GLOBAL_INFO_0x82 */
 #define SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 
-// AOAC_RSVDPAGE_LOC_0x83
+/* AOAC_RSVDPAGE_LOC_0x83 */
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
@@ -324,32 +514,55 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 #ifdef CONFIG_GTK_OL
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NDP_INFO(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 0, 8, __Value)
+
+/* AOAC_RSVDPAGE_2_0x84 */
+
+/* AOAC_RSVDPAGE_3_0x88 */
 #ifdef CONFIG_PNO_SUPPORT
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
 #endif
+#define SET_H2CCMD_AOAC_RSVDPAGE_LOC_AOAC_REPORT(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 8, __Value)
 
 #ifdef CONFIG_PNO_SUPPORT
-// D0_Scan_Offload_Info_0x86
+/* D0_Scan_Offload_Info_0x86 */
 #define SET_H2CCMD_AOAC_NLO_FUN_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 3, 1, __Value)
 #define SET_H2CCMD_AOAC_NLO_IPS_EN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd), 4, 1, __Value)
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 
 #ifdef CONFIG_P2P_WOWLAN
-//P2P_RsvdPage_0x8a
+/* P2P_RsvdPage_0x8a */
 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
+
+#ifdef CONFIG_LPS_PG
+#define SET_H2CCMD_LPSPG_SEC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*SecurityCAM_En*/
+#define SET_H2CCMD_LPSPG_MBID_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)/*BSSIDCAM_En*/
+#define SET_H2CCMD_LPSPG_PMC_CAM_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)/*PatternMatchCAM_En*/
+#define SET_H2CCMD_LPSPG_MACID_SEARCH_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)/*MACIDSearch_En*/
+#define SET_H2CCMD_LPSPG_TXSC_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)/*TXSC_En*/
+#define SET_H2CCMD_LPSPG_MU_RATE_TB_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)/*MURateTable_En*/
+#define SET_H2CCMD_LPSPG_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)/*Loc_LPS_PG*/
+#endif
 
-//---------------------------------------------------------------------------------------------------------//
-//-------------------------------------------    Structure    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+#ifdef DBG_FW_DEBUG_MSG_PKT
+#define SET_H2CCMD_FW_DBG_MSG_PKT_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*sniffer_dbg_en*/
+#define SET_H2CCMD_RSVDPAGE_LOC_FW_DBG_MSG_PKT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) /*loc_debug_packet*/
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 typedef struct _RSVDPAGE_LOC {
 	u8 LocProbeRsp;
 	u8 LocPsPoll;
@@ -366,14 +579,16 @@ typedef struct _RSVDPAGE_LOC {
 	u8 LocNetList;
 #ifdef CONFIG_GTK_OL
 	u8 LocGTKEXTMEM;
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
+	u8 LocNDPInfo;
+	u8 LocAOACReport;
 #ifdef CONFIG_PNO_SUPPORT
 	u8 LocPNOInfo;
 	u8 LocScanInfo;
 	u8 LocSSIDInfo;
 	u8 LocProbePacket;
-#endif //CONFIG_PNO_SUPPORT
-#endif //CONFIG_WOWLAN	
+#endif /* CONFIG_PNO_SUPPORT */
+#endif /* CONFIG_WOWLAN	 */
 	u8 LocApOffloadBCN;
 #ifdef CONFIG_P2P_WOWLAN
 	u8 LocP2PBeacon;
@@ -381,19 +596,27 @@ typedef struct _RSVDPAGE_LOC {
 	u8 LocNegoRsp;
 	u8 LocInviteRsp;
 	u8 LocPDRsp;
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	u8 loc_fw_dbg_msg_pkt;
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 } RSVDPAGE_LOC, *PRSVDPAGE_LOC;
 
 #endif
 void dump_TX_FIFO(PADAPTER padapter, u8 page_num, u16 page_size);
-u8 rtw_hal_set_fw_media_status_cmd(_adapter* adapter, u8 mstatus, u8 macid);
+u8 rtw_hal_set_fw_media_status_cmd(_adapter *adapter, u8 mstatus, u8 macid);
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-//WOW command function
-void rtw_hal_set_fw_wow_related_cmd(_adapter* padapter, u8 enable);
-#ifdef CONFIG_P2P_WOWLAN
-//H2C 0x8A
-u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter* adapter, PRSVDPAGE_LOC rsvdpageloc);
-//H2C 0x8B
-u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter* adapter);
-#endif //CONFIG_P2P_WOWLAN
+	/* WOW command function */
+	void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable);
+	#ifdef CONFIG_P2P_WOWLAN
+		/* H2C 0x8A */
+		u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc);
+		/* H2C 0x8B */
+		u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter);
+	#endif /* CONFIG_P2P_WOWLAN */
+#endif
+
+#ifdef RTW_PER_CMD_SUPPORT_FW
+u8 rtw_hal_set_req_per_rpt_cmd(_adapter *adapter, u8 group_macid,
+			       u8 rpt_type, u32 macid_bitmap);
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_led.h
index 79e62c6e58f1..597cb648fd80 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_led.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,72 +12,70 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_COMMON_LED_H_
 #define __HAL_COMMON_LED_H_
 
+#define NO_LED 0
+#define HW_LED 1
 
+#ifdef CONFIG_RTW_LED
 #define MSECS(t)        (HZ * ((t) / 1000) + (HZ * ((t) % 1000)) / 1000)
 
-//================================================================================
-//	LED Behavior Constant.
-//================================================================================
-// Default LED behavior.
-//
+/* ********************************************************************************
+ *	LED Behavior Constant.
+ * ********************************************************************************
+ * Default LED behavior.
+ *   */
 #define LED_BLINK_NORMAL_INTERVAL	100
 #define LED_BLINK_SLOWLY_INTERVAL	200
 #define LED_BLINK_LONG_INTERVAL	400
 #define LED_INITIAL_INTERVAL		1800
 
-// LED Customerization
+/* LED Customerization */
 
-//NETTRONIX
+/* NETTRONIX */
 #define LED_BLINK_NORMAL_INTERVAL_NETTRONIX	100
 #define LED_BLINK_SLOWLY_INTERVAL_NETTRONIX	2000
 
-//PORNET
+/* PORNET */
 #define LED_BLINK_SLOWLY_INTERVAL_PORNET	1000
 #define LED_BLINK_NORMAL_INTERVAL_PORNET	100
 #define LED_BLINK_FAST_INTERVAL_BITLAND		30
 
-//AzWave.
+/* AzWave. */
 #define LED_CM2_BLINK_ON_INTERVAL		250
 #define LED_CM2_BLINK_OFF_INTERVAL		4750
-#define LED_CM8_BLINK_OFF_INTERVAL		3750	//for QMI
+#define LED_CM8_BLINK_OFF_INTERVAL		3750	/* for QMI */
 
-//RunTop
+/* RunTop */
 #define LED_RunTop_BLINK_INTERVAL		300
 
-//ALPHA
+/* ALPHA */
 #define LED_BLINK_NO_LINK_INTERVAL_ALPHA	1000
-#define LED_BLINK_NO_LINK_INTERVAL_ALPHA_500MS 500 //add by ylb 20121012 for customer led for alpha
-#define LED_BLINK_LINK_INTERVAL_ALPHA		500	//500
-#define LED_BLINK_SCAN_INTERVAL_ALPHA		180 	//150
+#define LED_BLINK_NO_LINK_INTERVAL_ALPHA_500MS 500 /* add by ylb 20121012 for customer led for alpha */
+#define LED_BLINK_LINK_INTERVAL_ALPHA		500	/* 500 */
+#define LED_BLINK_SCAN_INTERVAL_ALPHA		180	/* 150 */
 #define LED_BLINK_FASTER_INTERVAL_ALPHA		50
 #define LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA	5000
 
-// 111122 by hpfan: Customized for Xavi
+/* 111122 by hpfan: Customized for Xavi */
 #define LED_CM11_BLINK_INTERVAL			300
 #define LED_CM11_LINK_ON_INTERVEL		3000
 
-//Netgear
+/* Netgear */
 #define LED_BLINK_LINK_INTERVAL_NETGEAR		500
 #define LED_BLINK_LINK_SLOWLY_INTERVAL_NETGEAR		1000
 
 #define LED_WPS_BLINK_OFF_INTERVAL_NETGEAR		100
 #define LED_WPS_BLINK_ON_INTERVAL_NETGEAR		500
 
-//Belkin AC950
+/* Belkin AC950 */
 #define LED_BLINK_LINK_INTERVAL_ON_BELKIN		200
 #define LED_BLINK_LINK_INTERVAL_OFF_BELKIN		100
 #define LED_BLINK_ERROR_INTERVAL_BELKIN		100
 
-//by chiyokolin for Azurewave
+/* by chiyokolin for Azurewave */
 #define LED_CM12_BLINK_INTERVAL_5Mbps		160
 #define LED_CM12_BLINK_INTERVAL_10Mbps		80
 #define LED_CM12_BLINK_INTERVAL_20Mbps		50
@@ -84,7 +83,7 @@
 #define LED_CM12_BLINK_INTERVAL_80Mbps		30
 #define LED_CM12_BLINK_INTERVAL_MAXMbps		25
 
-//Dlink
+/* Dlink */
 #define	LED_BLINK_NO_LINK_INTERVAL		1000
 #define	LED_BLINK_LINK_IDEL_INTERVAL		100
 
@@ -95,47 +94,51 @@
 #define LED_WPS_BLINK_OFF_INTERVAL_DLINK			300
 #define LED_WPS_BLINK_LINKED_ON_INTERVAL_DLINK			5000
 
-//================================================================================
-// LED object.
-//================================================================================
+/* ********************************************************************************
+ * LED object.
+ * ******************************************************************************** */
 
-typedef enum _LED_CTL_MODE{
+typedef enum _LED_CTL_MODE {
 	LED_CTL_POWER_ON = 1,
 	LED_CTL_LINK = 2,
 	LED_CTL_NO_LINK = 3,
-	LED_CTL_TX = 4,
-	LED_CTL_RX = 5,
-	LED_CTL_SITE_SURVEY = 6,
-	LED_CTL_POWER_OFF = 7,
-	LED_CTL_START_TO_LINK = 8,
-	LED_CTL_START_WPS = 9,
-	LED_CTL_STOP_WPS = 10,
-	LED_CTL_START_WPS_BOTTON = 11, //added for runtop
-	LED_CTL_STOP_WPS_FAIL = 12, //added for ALPHA	
-	LED_CTL_STOP_WPS_FAIL_OVERLAP = 13, //added for BELKIN
-	LED_CTL_CONNECTION_NO_TRANSFER = 14,
-}LED_CTL_MODE;
-
-typedef	enum _LED_STATE{
+	LED_CTL_TX = 4, /* unspecific data TX, including single & group addressed */
+	LED_CTL_RX = 5, /* unspecific data RX, including single & group addressed */
+	LED_CTL_UC_TX = 6, /* single addressed data TX */
+	LED_CTL_UC_RX = 7, /* single addressed data RX */
+	LED_CTL_BMC_TX = 8, /* group addressed data TX */
+	LED_CTL_BMC_RX = 9, /* group addressed data RX */
+	LED_CTL_SITE_SURVEY = 10,
+	LED_CTL_POWER_OFF = 11,
+	LED_CTL_START_TO_LINK = 12,
+	LED_CTL_START_WPS = 13,
+	LED_CTL_STOP_WPS = 14,
+	LED_CTL_START_WPS_BOTTON = 15, /* added for runtop */
+	LED_CTL_STOP_WPS_FAIL = 16, /* added for ALPHA	 */
+	LED_CTL_STOP_WPS_FAIL_OVERLAP = 17, /* added for BELKIN */
+	LED_CTL_CONNECTION_NO_TRANSFER = 18,
+} LED_CTL_MODE;
+
+typedef	enum _LED_STATE {
 	LED_UNKNOWN = 0,
 	RTW_LED_ON = 1,
 	RTW_LED_OFF = 2,
 	LED_BLINK_NORMAL = 3,
 	LED_BLINK_SLOWLY = 4,
 	LED_BLINK_POWER_ON = 5,
-	LED_BLINK_SCAN = 6, 	// LED is blinking during scanning period, the # of times to blink is depend on time for scanning.
-	LED_BLINK_NO_LINK = 7, // LED is blinking during no link state.
-	LED_BLINK_StartToBlink = 8, // Customzied for Sercomm Printer Server case
+	LED_BLINK_SCAN = 6,	/* LED is blinking during scanning period, the # of times to blink is depend on time for scanning. */
+	LED_BLINK_NO_LINK = 7, /* LED is blinking during no link state. */
+	LED_BLINK_StartToBlink = 8, /* Customzied for Sercomm Printer Server case */
 	LED_BLINK_TXRX = 9,
-	LED_BLINK_WPS = 10,	// LED is blinkg during WPS communication
-	LED_BLINK_WPS_STOP = 11,	//for ALPHA
-	LED_BLINK_WPS_STOP_OVERLAP = 12,	//for BELKIN
-	LED_BLINK_RUNTOP = 13, 	// Customized for RunTop
+	LED_BLINK_WPS = 10,	/* LED is blinkg during WPS communication */
+	LED_BLINK_WPS_STOP = 11,	/* for ALPHA */
+	LED_BLINK_WPS_STOP_OVERLAP = 12,	/* for BELKIN */
+	LED_BLINK_RUNTOP = 13,	/* Customized for RunTop */
 	LED_BLINK_CAMEO = 14,
 	LED_BLINK_XAVI = 15,
 	LED_BLINK_ALWAYS_ON = 16,
-	LED_BLINK_LINK_IN_PROCESS = 17,  //Customized for Belkin AC950
-	LED_BLINK_AUTH_ERROR = 18,  //Customized for Belkin AC950
+	LED_BLINK_LINK_IN_PROCESS = 17,  /* Customized for Belkin AC950 */
+	LED_BLINK_AUTH_ERROR = 18,  /* Customized for Belkin AC950 */
 	LED_BLINK_Azurewave_5Mbps = 19,
 	LED_BLINK_Azurewave_10Mbps = 20,
 	LED_BLINK_Azurewave_20Mbps = 21,
@@ -144,53 +147,54 @@ typedef	enum _LED_STATE{
 	LED_BLINK_Azurewave_MAXMbps = 24,
 	LED_BLINK_LINK_IDEL = 25,
 	LED_BLINK_WPS_LINKED = 26,
-}LED_STATE;
+} LED_STATE;
 
-typedef enum _LED_PIN{
+typedef enum _LED_PIN {
 	LED_PIN_GPIO0,
 	LED_PIN_LED0,
 	LED_PIN_LED1,
 	LED_PIN_LED2
-}LED_PIN;
+} LED_PIN;
 
 
-//================================================================================
-// PCIE LED Definition.
-//================================================================================
+/* ********************************************************************************
+ * PCIE LED Definition.
+ * ******************************************************************************** */
 #ifdef CONFIG_PCI_HCI
-typedef	enum _LED_STRATEGY_PCIE{
-	SW_LED_MODE0, // SW control 1 LED via GPIO0. It is default option.
-	SW_LED_MODE1, // SW control for PCI Express
-	SW_LED_MODE2, // SW control for Cameo.
-	SW_LED_MODE3, // SW contorl for RunTop.
-	SW_LED_MODE4, // SW control for Netcore
-	SW_LED_MODE5, //added by vivi, for led new mode, DLINK
-	SW_LED_MODE6, //added by vivi, for led new mode, PRONET
-	SW_LED_MODE7, //added by chiyokolin, for Lenovo, PCI Express Minicard Spec Rev.1.2 spec
-	SW_LED_MODE8, //added by chiyokolin, for QMI
-	SW_LED_MODE9, //added by chiyokolin, for BITLAND-LENOVO, PCI Express Minicard Spec Rev.1.1 	
-	SW_LED_MODE10, //added by chiyokolin, for Edimax-ASUS
-	SW_LED_MODE11,	//added by hpfan, for Xavi
-	SW_LED_MODE12,	//added by chiyokolin, for Azurewave
-	HW_LED, // HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes)
-}LED_STRATEGY_PCIE, *PLED_STRATEGY_PCIE;
-
-typedef struct _LED_PCIE{
+typedef	enum _LED_STRATEGY_PCIE {
+	/* start from 2 */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE1, /* SW control for PCI Express */
+	SW_LED_MODE2, /* SW control for Cameo. */
+	SW_LED_MODE3, /* SW contorl for RunTop. */
+	SW_LED_MODE4, /* SW control for Netcore */
+	SW_LED_MODE5, /* added by vivi, for led new mode, DLINK */
+	SW_LED_MODE6, /* added by vivi, for led new mode, PRONET */
+	SW_LED_MODE7, /* added by chiyokolin, for Lenovo, PCI Express Minicard Spec Rev.1.2 spec */
+	SW_LED_MODE8, /* added by chiyokolin, for QMI */
+	SW_LED_MODE9, /* added by chiyokolin, for BITLAND-LENOVO, PCI Express Minicard Spec Rev.1.1	 */
+	SW_LED_MODE10, /* added by chiyokolin, for Edimax-ASUS */
+	SW_LED_MODE11,	/* added by hpfan, for Xavi */
+	SW_LED_MODE12,	/* added by chiyokolin, for Azurewave */
+} LED_STRATEGY_PCIE, *PLED_STRATEGY_PCIE;
+
+typedef struct _LED_PCIE {
 	PADAPTER		padapter;
 
-	LED_PIN			LedPin;	// Identify how to implement this SW led.
+	LED_PIN			LedPin;	/* Identify how to implement this SW led. */
 
-	LED_STATE		CurrLedState; // Current LED state.
-	BOOLEAN			bLedOn; // TRUE if LED is ON, FALSE if LED is OFF.
+	LED_STATE		CurrLedState; /* Current LED state. */
+	BOOLEAN			bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
 
-	BOOLEAN			bLedBlinkInProgress; // TRUE if it is blinking, FALSE o.w..
-	BOOLEAN			bLedWPSBlinkInProgress; // TRUE if it is blinking, FALSE o.w..
+	BOOLEAN			bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
+	BOOLEAN			bLedWPSBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
 
-	BOOLEAN			bLedSlowBlinkInProgress;//added by vivi, for led new mode
-	u32				BlinkTimes; // Number of times to toggle led state for blinking.
-	LED_STATE		BlinkingLedState; // Next state for blinking, either LED_ON or LED_OFF are.
+	BOOLEAN			bLedSlowBlinkInProgress;/* added by vivi, for led new mode */
+	u32				BlinkTimes; /* Number of times to toggle led state for blinking. */
+	LED_STATE		BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
 
-	_timer			BlinkTimer; // Timer object for led blinking.
+	_timer			BlinkTimer; /* Timer object for led blinking. */
 } LED_PCIE, *PLED_PCIE;
 
 typedef struct _LED_PCIE	LED_DATA, *PLED_DATA;
@@ -200,132 +204,134 @@ VOID
 LedControlPCIE(
 	IN	PADAPTER		Adapter,
 	IN	LED_CTL_MODE		LedAction
-	);
+);
 
 VOID
 gen_RefreshLedState(
 	IN	PADAPTER		Adapter);
 
-//================================================================================
-// USB  LED Definition.
-//================================================================================
+/* ********************************************************************************
+ * USB  LED Definition.
+ * ******************************************************************************** */
 #elif defined(CONFIG_USB_HCI)
 
-#define IS_LED_WPS_BLINKING(_LED_USB)	(((PLED_USB)_LED_USB)->CurrLedState==LED_BLINK_WPS \
-					|| ((PLED_USB)_LED_USB)->CurrLedState==LED_BLINK_WPS_STOP \
-					|| ((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress)
-
-#define IS_LED_BLINKING(_LED_USB) 	(((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress \
-					||((PLED_USB)_LED_USB)->bLedScanBlinkInProgress)
-
-
-typedef	enum _LED_STRATEGY_USB{
-	SW_LED_MODE0, // SW control 1 LED via GPIO0. It is default option.
-	SW_LED_MODE1, // 2 LEDs, through LED0 and LED1. For ALPHA.
-	SW_LED_MODE2, // SW control 1 LED via GPIO0, customized for AzWave 8187 minicard.
-	SW_LED_MODE3, // SW control 1 LED via GPIO0, customized for Sercomm Printer Server case.
-	SW_LED_MODE4, //for Edimax / Belkin
-	SW_LED_MODE5, //for Sercomm / Belkin	
-	SW_LED_MODE6,	//for 88CU minicard, porting from ce SW_LED_MODE7
-	SW_LED_MODE7,	//for Netgear special requirement
-	SW_LED_MODE8, //for LC
-	SW_LED_MODE9, //for Belkin AC950
-	SW_LED_MODE10, //for Netgear A6200V2
-	SW_LED_MODE11, //for Edimax / ASUS
-	SW_LED_MODE12, //for WNC/NEC
-	SW_LED_MODE13, //for Netgear A6100, 8811Au
-	SW_LED_MODE14, //for Buffalo, DNI, 8811Au
-	SW_LED_MODE15, //for DLINK,  8811Au/8812AU	
-	HW_LED, // HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes, see MAC.CONFIG1 for details.)
-}LED_STRATEGY_USB, *PLED_STRATEGY_USB;
-
-
-typedef struct _LED_USB{
+#define IS_LED_WPS_BLINKING(_LED_USB)	(((PLED_USB)_LED_USB)->CurrLedState == LED_BLINK_WPS \
+		|| ((PLED_USB)_LED_USB)->CurrLedState == LED_BLINK_WPS_STOP \
+		|| ((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress)
+
+#define IS_LED_BLINKING(_LED_USB)	(((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress \
+		|| ((PLED_USB)_LED_USB)->bLedScanBlinkInProgress)
+
+
+typedef	enum _LED_STRATEGY_USB {
+	/* start from 2 */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
+	SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
+	SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
+	SW_LED_MODE4, /* for Edimax / Belkin */
+	SW_LED_MODE5, /* for Sercomm / Belkin	 */
+	SW_LED_MODE6,	/* for 88CU minicard, porting from ce SW_LED_MODE7 */
+	SW_LED_MODE7,	/* for Netgear special requirement */
+	SW_LED_MODE8, /* for LC */
+	SW_LED_MODE9, /* for Belkin AC950 */
+	SW_LED_MODE10, /* for Netgear A6200V2 */
+	SW_LED_MODE11, /* for Edimax / ASUS */
+	SW_LED_MODE12, /* for WNC/NEC */
+	SW_LED_MODE13, /* for Netgear A6100, 8811Au */
+	SW_LED_MODE14, /* for Buffalo, DNI, 8811Au */
+	SW_LED_MODE15, /* for DLINK,  8811Au/8812AU	 */
+} LED_STRATEGY_USB, *PLED_STRATEGY_USB;
+
+
+typedef struct _LED_USB {
 	PADAPTER			padapter;
 
-	LED_PIN				LedPin;	// Identify how to implement this SW led.
+	LED_PIN				LedPin;	/* Identify how to implement this SW led. */
 
-	LED_STATE			CurrLedState; // Current LED state.
-	BOOLEAN				bLedOn; // TRUE if LED is ON, FALSE if LED is OFF.
+	LED_STATE			CurrLedState; /* Current LED state. */
+	BOOLEAN				bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
 
 	BOOLEAN				bSWLedCtrl;
 
-	BOOLEAN				bLedBlinkInProgress; // TRUE if it is blinking, FALSE o.w..
-	// ALPHA, added by chiyoko, 20090106
+	BOOLEAN				bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
+	/* ALPHA, added by chiyoko, 20090106 */
 	BOOLEAN				bLedNoLinkBlinkInProgress;
 	BOOLEAN				bLedLinkBlinkInProgress;
-	BOOLEAN				bLedStartToLinkBlinkInProgress;	
+	BOOLEAN				bLedStartToLinkBlinkInProgress;
 	BOOLEAN				bLedScanBlinkInProgress;
 	BOOLEAN				bLedWPSBlinkInProgress;
-	
-	u32					BlinkTimes; // Number of times to toggle led state for blinking.
-	u8					BlinkCounter; //Added for turn off overlap led after blinking a while, by page, 20120821
-	LED_STATE			BlinkingLedState; // Next state for blinking, either LED_ON or LED_OFF are.
 
-	_timer				BlinkTimer; // Timer object for led blinking.
+	u32					BlinkTimes; /* Number of times to toggle led state for blinking. */
+	u8					BlinkCounter; /* Added for turn off overlap led after blinking a while, by page, 20120821 */
+	LED_STATE			BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
 
-	_workitem			BlinkWorkItem; // Workitem used by BlinkTimer to manipulate H/W to blink LED.'
-	ATOMIC_T			bCancelWorkItem; //check if WorkItem is cancelled
+	_timer				BlinkTimer; /* Timer object for led blinking. */
+
+	_workitem			BlinkWorkItem; /* Workitem used by BlinkTimer to manipulate H/W to blink LED.' */
 } LED_USB, *PLED_USB;
 
 typedef struct _LED_USB	LED_DATA, *PLED_DATA;
 typedef enum _LED_STRATEGY_USB	LED_STRATEGY, *PLED_STRATEGY;
-
+#ifdef CONFIG_RTW_SW_LED
 VOID
 LedControlUSB(
 	IN	PADAPTER		Adapter,
 	IN	LED_CTL_MODE		LedAction
-	);
+);
+#endif
 
 
-//================================================================================
-// SDIO LED Definition.
-//================================================================================
+/* ********************************************************************************
+ * SDIO LED Definition.
+ * ******************************************************************************** */
 #elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 
-#define IS_LED_WPS_BLINKING(_LED_SDIO)	(((PLED_SDIO)_LED_SDIO)->CurrLedState==LED_BLINK_WPS \
-					|| ((PLED_SDIO)_LED_SDIO)->CurrLedState==LED_BLINK_WPS_STOP \
-					|| ((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress)
+#define IS_LED_WPS_BLINKING(_LED_SDIO)	(((PLED_SDIO)_LED_SDIO)->CurrLedState == LED_BLINK_WPS \
+		|| ((PLED_SDIO)_LED_SDIO)->CurrLedState == LED_BLINK_WPS_STOP \
+		|| ((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress)
 
-#define IS_LED_BLINKING(_LED_SDIO) 	(((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress \
-					||((PLED_SDIO)_LED_SDIO)->bLedScanBlinkInProgress)
+#define IS_LED_BLINKING(_LED_SDIO)	(((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress \
+		|| ((PLED_SDIO)_LED_SDIO)->bLedScanBlinkInProgress)
 
 
-typedef	enum _LED_STRATEGY_SDIO{
-	SW_LED_MODE0, // SW control 1 LED via GPIO0. It is default option.
-	SW_LED_MODE1, // 2 LEDs, through LED0 and LED1. For ALPHA.
-	SW_LED_MODE2, // SW control 1 LED via GPIO0, customized for AzWave 8187 minicard.
-	SW_LED_MODE3, // SW control 1 LED via GPIO0, customized for Sercomm Printer Server case.
-	SW_LED_MODE4, //for Edimax / Belkin
-	SW_LED_MODE5, //for Sercomm / Belkin	
-	SW_LED_MODE6,	//for 88CU minicard, porting from ce SW_LED_MODE7
-	HW_LED, // HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes, see MAC.CONFIG1 for details.)
-}LED_STRATEGY_SDIO, *PLED_STRATEGY_SDIO;
+typedef	enum _LED_STRATEGY_SDIO {
+	/* start from 2 */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
+	SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
+	SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
+	SW_LED_MODE4, /* for Edimax / Belkin */
+	SW_LED_MODE5, /* for Sercomm / Belkin	 */
+	SW_LED_MODE6,	/* for 88CU minicard, porting from ce SW_LED_MODE7 */
+} LED_STRATEGY_SDIO, *PLED_STRATEGY_SDIO;
 
-typedef struct _LED_SDIO{
+typedef struct _LED_SDIO {
 	PADAPTER			padapter;
 
-	LED_PIN				LedPin;	// Identify how to implement this SW led.
+	LED_PIN				LedPin;	/* Identify how to implement this SW led. */
 
-	LED_STATE			CurrLedState; // Current LED state.
-	BOOLEAN				bLedOn; // TRUE if LED is ON, FALSE if LED is OFF.
+	LED_STATE			CurrLedState; /* Current LED state. */
+	BOOLEAN				bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
 
 	BOOLEAN				bSWLedCtrl;
 
-	BOOLEAN				bLedBlinkInProgress; // TRUE if it is blinking, FALSE o.w..
-	// ALPHA, added by chiyoko, 20090106
+	BOOLEAN				bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
+	/* ALPHA, added by chiyoko, 20090106 */
 	BOOLEAN				bLedNoLinkBlinkInProgress;
 	BOOLEAN				bLedLinkBlinkInProgress;
-	BOOLEAN				bLedStartToLinkBlinkInProgress;	
+	BOOLEAN				bLedStartToLinkBlinkInProgress;
 	BOOLEAN				bLedScanBlinkInProgress;
 	BOOLEAN				bLedWPSBlinkInProgress;
-	
-	u32					BlinkTimes; // Number of times to toggle led state for blinking.
-	LED_STATE			BlinkingLedState; // Next state for blinking, either LED_ON or LED_OFF are.
 
-	_timer				BlinkTimer; // Timer object for led blinking.
+	u32					BlinkTimes; /* Number of times to toggle led state for blinking. */
+	LED_STATE			BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
+
+	_timer				BlinkTimer; /* Timer object for led blinking. */
 
-	_workitem			BlinkWorkItem; // Workitem used by BlinkTimer to manipulate H/W to blink LED.
+	_workitem			BlinkWorkItem; /* Workitem used by BlinkTimer to manipulate H/W to blink LED. */
 } LED_SDIO, *PLED_SDIO;
 
 typedef struct _LED_SDIO	LED_DATA, *PLED_DATA;
@@ -335,44 +341,36 @@ VOID
 LedControlSDIO(
 	IN	PADAPTER		Adapter,
 	IN	LED_CTL_MODE		LedAction
-	);
+);
 
 #endif
 
-struct led_priv{
-	/* add for led controll */
+struct led_priv {
+	LED_STRATEGY		LedStrategy;
+#ifdef CONFIG_RTW_SW_LED
 	LED_DATA			SwLed0;
 	LED_DATA			SwLed1;
 	LED_DATA			SwLed2;
-	LED_STRATEGY		LedStrategy;
 	u8					bRegUseLed;
+	u8 iface_en_mask;
+	u32 ctl_en_mask[CONFIG_IFACE_NUMBER];
 	void (*LedControlHandler)(_adapter *padapter, LED_CTL_MODE LedAction);
 	void (*SwLedOn)(_adapter *padapter, PLED_DATA pLed);
 	void (*SwLedOff)(_adapter *padapter, PLED_DATA pLed);
-	/* add for led controll */
+#endif
 };
 
-#ifdef CONFIG_SW_LED
-#define rtw_led_control(adapter, LedAction) \
-	do { \
-		if((adapter)->ledpriv.LedControlHandler) \
-			(adapter)->ledpriv.LedControlHandler((adapter), (LedAction)); \
-	} while(0)
-#else //CONFIG_SW_LED
-#define rtw_led_control(adapter, LedAction)
-#endif //CONFIG_SW_LED
-
 #define SwLedOn(adapter, pLed) \
 	do { \
-		if((adapter)->ledpriv.SwLedOn) \
-			(adapter)->ledpriv.SwLedOn((adapter), (pLed)); \
-	} while(0)
+		if (adapter_to_led(adapter)->SwLedOn) \
+			adapter_to_led(adapter)->SwLedOn((adapter), (pLed)); \
+	} while (0)
 
 #define SwLedOff(adapter, pLed) \
 	do { \
-		if((adapter)->ledpriv.SwLedOff) \
-			(adapter)->ledpriv.SwLedOff((adapter), (pLed)); \
-	} while(0)
+		if (adapter_to_led(adapter)->SwLedOff) \
+			adapter_to_led(adapter)->SwLedOff((adapter), (pLed)); \
+	} while (0)
 
 void BlinkTimerCallback(void *data);
 void BlinkWorkItemCallback(_workitem *work);
@@ -384,15 +382,57 @@ InitLed(
 	_adapter			*padapter,
 	PLED_DATA		pLed,
 	LED_PIN			LedPin
-	);
+);
 
 void
 DeInitLed(
 	PLED_DATA		pLed
-	);
+);
 
-//hal...
+/* hal... */
 extern void BlinkHandler(PLED_DATA	pLed);
+void dump_led_config(void *sel, _adapter *adapter);
+void rtw_led_set_strategy(_adapter *adapter, u8 strategy);
+#endif /* CONFIG_RTW_LED */
+
+#if defined(CONFIG_RTW_LED)
+#define rtw_led_get_strategy(adapter) (adapter_to_led(adapter)->LedStrategy)
+#else
+#define rtw_led_get_strategy(adapter) NO_LED
+#endif
+
+#define IS_NO_LED_STRATEGY(s) ((s) == NO_LED)
+#define IS_HW_LED_STRATEGY(s) ((s) == HW_LED)
+#define IS_SW_LED_STRATEGY(s) ((s) != NO_LED && (s) != HW_LED)
 
-#endif //__RTW_LED_H_
+#if defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED)
+
+#ifndef CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+#define CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY 0
+#endif
+
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+void rtw_sw_led_blink_uc_trx_only(LED_DATA *led);
+void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl);
+#endif
+void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl);
+void rtw_led_tx_control(_adapter *adapter, const u8 *da);
+void rtw_led_rx_control(_adapter *adapter, const u8 *da);
+void rtw_led_set_iface_en(_adapter *adapter, u8 en);
+void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask);
+void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask);
+void rtw_led_set_ctl_en_mask_primary(_adapter *adapter);
+void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter);
+#else
+#define rtw_led_control(adapter, ctl) do {} while (0)
+#define rtw_led_tx_control(adapter, da) do {} while (0)
+#define rtw_led_rx_control(adapter, da) do {} while (0)
+#define rtw_led_set_iface_en(adapter, en) do {} while (0)
+#define rtw_led_set_iface_en_mask(adapter, mask) do {} while (0)
+#define rtw_led_set_ctl_en_mask(adapter, ctl_mask) do {} while (0)
+#define rtw_led_set_ctl_en_mask_primary(adapter) do {} while (0)
+#define rtw_led_set_ctl_en_mask_virtual(adapter) do {} while (0)
+#endif /* defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED) */
+
+#endif /*__HAL_COMMON_LED_H_*/
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_phycfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_phycfg.h
index 4ff5b514474b..90d98dea0b64 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_phycfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_phycfg.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_COM_PHYCFG_H__
 #define __HAL_COM_PHYCFG_H__
 
-#define		PathA                     			0x0	// Useless
-#define		PathB                     			0x1
-#define		PathC                     			0x2
-#define		PathD                     			0x3
+#define		PathA                     			0x0	/* Useless */
+#define		PathB			0x1
+#define		PathC			0x2
+#define		PathD			0x3
 
 typedef enum _RF_TX_NUM {
 	RF_1TX = 0,
@@ -34,63 +30,41 @@ typedef enum _RF_TX_NUM {
 	RF_TX_NUM_NONIMPLEMENT,
 } RF_TX_NUM;
 
-#define MAX_POWER_INDEX 		0x3F
+#define MAX_POWER_INDEX		0x3F
 
-typedef enum _REGULATION_TXPWR_LMT {
-	TXPWR_LMT_FCC = 0,
-	TXPWR_LMT_MKK = 1,
-	TXPWR_LMT_ETSI = 2,
-	TXPWR_LMT_WW = 3,	
+/*------------------------------Define structure----------------------------*/
+typedef struct _BB_REGISTER_DEFINITION {
+	u32 rfintfs;			/* set software control: */
+	/*		0x870~0x877[8 bytes] */
 
-	TXPWR_LMT_MAX_REGULATION_NUM = 4
-} REGULATION_TXPWR_LMT;
+	u32 rfintfo; 			/* output data: */
+	/*		0x860~0x86f [16 bytes] */
 
-#define TX_PWR_LMT_REF_VHT_FROM_HT	BIT0
-#define TX_PWR_LMT_REF_HT_FROM_VHT	BIT1
+	u32 rfintfe; 			/* output enable: */
+	/*		0x860~0x86f [16 bytes] */
 
-/*------------------------------Define structure----------------------------*/ 
-typedef struct _BB_REGISTER_DEFINITION{
-	u32 rfintfs;			// set software control: 
-						//		0x870~0x877[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 rf3wireOffset;	/* LSSI data: */
+	/*		0x840~0x84f [16 bytes] */
 
-	u32 rfHSSIPara2; 	// wire parameter control2 : 
-						//		0x824~0x827,0x82c~0x82f, 0x834~0x837, 0x83c~0x83f [16 bytes]
-								
-	u32 rfLSSIReadBack; 	//LSSI RF readback data SI mode
-						//		0x8a0~0x8af [16 bytes]
+	u32 rfHSSIPara2;	/* wire parameter control2 :  */
+	/*		0x824~0x827,0x82c~0x82f, 0x834~0x837, 0x83c~0x83f [16 bytes] */
 
-	u32 rfLSSIReadBackPi; 	//LSSI RF readback data PI mode 0x8b8-8bc for Path A and B
+	u32 rfLSSIReadBack;	/* LSSI RF readback data SI mode */
+	/*		0x8a0~0x8af [16 bytes] */
 
-}BB_REGISTER_DEFINITION_T, *PBB_REGISTER_DEFINITION_T;
+	u32 rfLSSIReadBackPi;	/* LSSI RF readback data PI mode 0x8b8-8bc for Path A and B */
 
+} BB_REGISTER_DEFINITION_T, *PBB_REGISTER_DEFINITION_T;
 
-//----------------------------------------------------------------------
+
+/* ---------------------------------------------------------------------- */
 u8
 PHY_GetTxPowerByRateBase(
 	IN	PADAPTER		Adapter,
 	IN	u8				Band,
 	IN	u8				RfPath,
-	IN	u8				TxNum,
 	IN	RATE_SECTION	RateSection
-	);
-
-#ifdef TX_POWER_BY_RATE_OLD
-u8
-PHY_GetRateSectionIndexOfTxPowerByRate(
-	IN	PADAPTER	pAdapter,
-	IN	u32			RegAddr,
-	IN	u32			BitMask
-	);
-#endif /* TX_POWER_BY_RATE_OLD */
+);
 
 VOID
 PHY_GetRateValuesOfTxPowerByRate(
@@ -101,73 +75,70 @@ PHY_GetRateValuesOfTxPowerByRate(
 	OUT	u8 *Rate,
 	OUT	s8 *PwrByRateVal,
 	OUT	u8 *RateNum
-	);
+);
 
 u8
 PHY_GetRateIndexOfTxPowerByRate(
 	IN	u8	Rate
-	);
+);
 
-VOID 
-PHY_SetTxPowerIndexByRateSection(
+VOID
+phy_set_tx_power_index_by_rate_section(
 	IN	PADAPTER		pAdapter,
-	IN	u8				RFPath,	
+	IN	enum rf_path		RFPath,
 	IN	u8				Channel,
 	IN	u8				RateSection
-	);
+);
 
 s8
 _PHY_GetTxPowerByRate(
 	IN	PADAPTER	pAdapter,
 	IN	u8			Band,
-	IN	u8			RFPath,
-	IN	u8			TxNum,
+	IN	enum rf_path	RFPath,
 	IN	u8			RateIndex
-	);
+);
 
 s8
-PHY_GetTxPowerByRate( 
-	IN	PADAPTER	pAdapter, 
-	IN	u8			Band, 
-	IN	u8			RFPath, 
-	IN	u8			TxNum, 
+PHY_GetTxPowerByRate(
+	IN	PADAPTER	pAdapter,
+	IN	u8			Band,
+	IN	enum rf_path	RFPath,
 	IN	u8			RateIndex
-	);
+);
 
 VOID
-PHY_SetTxPowerByRate( 
-	IN	PADAPTER	pAdapter, 
-	IN	u8			Band, 
-	IN	u8			RFPath, 
-	IN	u8			TxNum, 
+PHY_SetTxPowerByRate(
+	IN	PADAPTER	pAdapter,
+	IN	u8			Band,
+	IN	enum rf_path	RFPath,
 	IN	u8			Rate,
 	IN	s8			Value
-	);
+);
 
 VOID
-PHY_SetTxPowerLevelByPath(
+phy_set_tx_power_level_by_path(
 	IN	PADAPTER	Adapter,
 	IN	u8			channel,
 	IN	u8			path
-	);
+);
 
-VOID 
+VOID
 PHY_SetTxPowerIndexByRateArray(
 	IN	PADAPTER		pAdapter,
-	IN	u8				RFPath,
-	IN	CHANNEL_WIDTH	BandWidth,	
+	IN	enum rf_path		RFPath,
+	IN	enum channel_width BandWidth,
 	IN	u8				Channel,
-	IN	u8*				Rates,
+	IN	u8				*Rates,
 	IN	u8				RateArraySize
-	);
+);
 
 VOID
 PHY_InitTxPowerByRate(
 	IN	PADAPTER	pAdapter
-	);
+);
 
 VOID
-PHY_StoreTxPowerByRate(
+phy_store_tx_power_by_rate(
 	IN	PADAPTER	pAdapter,
 	IN	u32			Band,
 	IN	u32			RfPath,
@@ -175,63 +146,57 @@ PHY_StoreTxPowerByRate(
 	IN	u32			RegAddr,
 	IN	u32			BitMask,
 	IN	u32			Data
-	);
+);
 
 VOID
 PHY_TxPowerByRateConfiguration(
 	IN  PADAPTER			pAdapter
-	);
+);
 
 u8
 PHY_GetTxPowerIndexBase(
 	IN	PADAPTER		pAdapter,
-	IN	u8				RFPath,
-	IN	u8				Rate,	
-	IN	CHANNEL_WIDTH	BandWidth,	
+	IN	enum rf_path		RFPath,
+	IN	u8				Rate,
+	u8 ntx_idx,
+	IN	enum channel_width	BandWidth,
 	IN	u8				Channel,
 	OUT PBOOLEAN		bIn24G
-	);
-
-s8
-PHY_GetTxPowerLimit(
-	IN	PADAPTER		Adapter,
-	IN	u32				RegPwrTblSel,
-	IN	BAND_TYPE		Band,
-	IN	CHANNEL_WIDTH	Bandwidth,
-	IN	u8				RfPath,
-	IN	u8				DataRate,
-	IN	u8				Channel
-	);
+);
 
-s8
-PHY_GetTxPowerLimit_no_sc(
-	IN	PADAPTER			Adapter,
-	IN	u32					RegPwrTblSel,
-	IN	BAND_TYPE			Band,
-	IN	CHANNEL_WIDTH		Bandwidth,
-	IN	u8					RfPath,
-	IN	u8					DataRate,
-	IN	u8					Channel
+#ifdef CONFIG_TXPWR_LIMIT
+s8 phy_get_txpwr_lmt_abs(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 tlrs, u8 ntx_idx, u8 cch, u8 lock
 );
 
-VOID 
-PHY_ConvertTxPowerLimitToPowerIndex(
-	IN	PADAPTER			Adapter
-	);
+s8 phy_get_txpwr_lmt(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 rfpath, u8 rs, u8 ntx_idx, u8 cch, u8 lock
+);
 
-VOID
-PHY_InitTxPowerLimit(
-	IN	PADAPTER			Adapter
-	);
+s8 PHY_GetTxPowerLimit(_adapter *adapter
+	, const char *regd_name
+	, BAND_TYPE band, enum channel_width bw
+	, u8 rfpath, u8 rate, u8 ntx_idx, u8 cch
+);
+#else
+#define phy_get_txpwr_lmt_abs(adapter, regd_name, band, bw, tlrs, ntx_idx, cch, lock) MAX_POWER_INDEX
+#define phy_get_txpwr_lmt(adapter, regd_name, band, bw, rfpath, rs, ntx_idx, cch, lock) MAX_POWER_INDEX
+#define PHY_GetTxPowerLimit(adapter, regd_name, band, bw, rfpath, rate, ntx_idx, cch) MAX_POWER_INDEX
+#endif /* CONFIG_TXPWR_LIMIT */
 
 s8
-PHY_GetTxPowerTrackingOffset( 
+PHY_GetTxPowerTrackingOffset(
 	PADAPTER	pAdapter,
-	u8			Rate,
-	u8			RFPath
-	);
+	enum rf_path	RFPath,
+	u8			Rate
+);
 
 struct txpwr_idx_comp {
+	u8 ntx_idx;
 	u8 base;
 	s8 by_rate;
 	s8 limit;
@@ -240,21 +205,21 @@ struct txpwr_idx_comp {
 };
 
 u8
-PHY_GetTxPowerIndex(
+phy_get_tx_power_index(
 	IN	PADAPTER			pAdapter,
-	IN	u8					RFPath,
-	IN	u8					Rate,	
-	IN	CHANNEL_WIDTH		BandWidth,	
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	enum channel_width	BandWidth,
 	IN	u8					Channel
-	);
+);
 
 VOID
 PHY_SetTxPowerIndex(
 	IN	PADAPTER		pAdapter,
 	IN	u32				PowerIndex,
-	IN	u8				RFPath,	
+	IN	enum rf_path		RFPath,
 	IN	u8				Rate
-	);
+);
 
 void dump_tx_power_idx_title(void *sel, _adapter *adapter);
 void dump_tx_power_idx_by_path_rs(void *sel, _adapter *adapter, u8 rfpath, u8 rs);
@@ -263,15 +228,18 @@ void dump_tx_power_idx(void *sel, _adapter *adapter);
 bool phy_is_tx_power_limit_needed(_adapter *adapter);
 bool phy_is_tx_power_by_rate_needed(_adapter *adapter);
 int phy_load_tx_power_by_rate(_adapter *adapter, u8 chk_file);
+#ifdef CONFIG_TXPWR_LIMIT
 int phy_load_tx_power_limit(_adapter *adapter, u8 chk_file);
+#endif
 void phy_load_tx_power_ext_info(_adapter *adapter, u8 chk_file);
 void phy_reload_tx_power_ext_info(_adapter *adapter);
 void phy_reload_default_tx_power_ext_info(_adapter *adapter);
 
 const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter);
 
-void dump_pg_txpwr_info_2g(void *sel, TxPowerInfo24G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt);
-void dump_pg_txpwr_info_5g(void *sel, TxPowerInfo5G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt);
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+int check_phy_efuse_tx_power_info_valid(_adapter *adapter);
+#endif
 
 void dump_hal_txpwr_info_2g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt);
 void dump_hal_txpwr_info_5g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt);
@@ -286,7 +254,6 @@ void hal_load_txpwr_info(
 void dump_tx_power_ext_info(void *sel, _adapter *adapter);
 void dump_target_tx_power(void *sel, _adapter *adapter);
 void dump_tx_power_by_rate(void *sel, _adapter *adapter);
-void dump_tx_power_limit(void *sel, _adapter *adapter);
 
 int rtw_get_phy_file_path(_adapter *adapter, const char *file_name);
 
@@ -319,23 +286,17 @@ int rtw_get_phy_file_path(_adapter *adapter, const char *file_name);
 #define LOAD_RF_TXPWR_TRACK_PARA_FILE	BIT5
 #define LOAD_RF_TXPWR_LMT_PARA_FILE		BIT6
 
-int phy_ConfigMACWithParaFile(IN PADAPTER	Adapter, IN char*	pFileName);
-
-int phy_ConfigBBWithParaFile(IN PADAPTER	Adapter, IN char*	pFileName, IN u32	ConfigType);
-
+int phy_ConfigMACWithParaFile(IN PADAPTER	Adapter, IN char	*pFileName);
+int phy_ConfigBBWithParaFile(IN PADAPTER	Adapter, IN char	*pFileName, IN u32	ConfigType);
 int phy_ConfigBBWithPgParaFile(IN PADAPTER	Adapter, IN const char *pFileName);
-
-int phy_ConfigBBWithMpParaFile(IN PADAPTER	Adapter, IN char*	pFileName);
-
-int PHY_ConfigRFWithParaFile(IN	PADAPTER	Adapter, IN char*	pFileName, IN u8	eRFPath);
-
-int PHY_ConfigRFWithTxPwrTrackParaFile(IN PADAPTER	Adapter, IN char*	pFileName);
-
+int phy_ConfigBBWithMpParaFile(IN PADAPTER	Adapter, IN char	*pFileName);
+int PHY_ConfigRFWithParaFile(IN	PADAPTER	Adapter, IN char	*pFileName, IN enum rf_path	eRFPath);
+int PHY_ConfigRFWithTxPwrTrackParaFile(IN PADAPTER	Adapter, IN char	*pFileName);
+#ifdef CONFIG_TXPWR_LIMIT
 int PHY_ConfigRFWithPowerLimitTableParaFile(IN PADAPTER	Adapter, IN const char *pFileName);
-
+#endif
 void phy_free_filebuf_mask(_adapter *padapter, u8 mask);
 void phy_free_filebuf(_adapter *padapter);
 #endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
 
 #endif /* __HAL_COMMON_H__ */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_reg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_reg.h
index 0548729d7705..80c820185288 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_reg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_com_reg.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,34 +12,30 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_COMMON_REG_H__
 #define __HAL_COMMON_REG_H__
 
 
 #define MAC_ADDR_LEN				6
 
-#define HAL_NAV_UPPER_UNIT		128		// micro-second
+#define HAL_NAV_UPPER_UNIT		128		/* micro-second */
 
-// 8188E PKT_BUFF_ACCESS_CTRL value
+/* 8188E PKT_BUFF_ACCESS_CTRL value */
 #define TXPKT_BUF_SELECT				0x69
 #define RXPKT_BUF_SELECT				0xA5
 #define DISABLE_TRXPKT_BUF_ACCESS		0x0
 
-//============================================================
-//
-//============================================================
+#ifndef RTW_HALMAC
+/* ************************************************************
+*
+* ************************************************************ */
 
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0000h ~ 0x00FFh	System Configuration
+*
+* ----------------------------------------------------- */
 #define REG_SYS_ISO_CTRL				0x0000
 #define REG_SYS_FUNC_EN				0x0002
 #define REG_APS_FSMCO					0x0004
@@ -50,7 +47,7 @@
 #define REG_AFE_MISC					0x0010
 #define REG_SPS0_CTRL					0x0011
 #define REG_SPS0_CTRL_6					0x0016
-#define REG_POWER_OFF_IN_PROCESS 		0x0017
+#define REG_POWER_OFF_IN_PROCESS		0x0017
 #define REG_SPS_OCP_CFG				0x0018
 #define REG_RSV_CTRL					0x001C
 #define REG_RF_CTRL						0x001F
@@ -59,9 +56,9 @@
 #define REG_LDOHCI12_CTRL				0x0022
 #define REG_LPLDO_CTRL					0x0023
 #define REG_AFE_XTAL_CTRL				0x0024
-#define REG_AFE_LDO_CTRL				0x0027 // 1.5v for 8188EE test chip, 1.4v for MP chip
+#define REG_AFE_LDO_CTRL				0x0027 /* 1.5v for 8188EE test chip, 1.4v for MP chip */
 #define REG_AFE_PLL_CTRL				0x0028
-#define REG_MAC_PHY_CTRL				0x002c //for 92d, DMDP,SMSP,DMSP contrl
+#define REG_MAC_PHY_CTRL				0x002c /* for 92d, DMDP, SMSP, DMSP contrl */
 #define REG_APE_PLL_CTRL_EXT			0x002c
 #define REG_EFUSE_CTRL					0x0030
 #define REG_EFUSE_TEST					0x0034
@@ -81,19 +78,20 @@
 #define REG_FSISR						0x0054
 #define REG_HSIMR						0x0058
 #define REG_HSISR						0x005c
-#define REG_GPIO_PIN_CTRL_2			0x0060 // RTL8723 WIFI/BT/GPS Multi-Function GPIO Pin Control.
-#define REG_GPIO_IO_SEL_2				0x0062 // RTL8723 WIFI/BT/GPS Multi-Function GPIO Select.
-#define REG_MULTI_FUNC_CTRL			0x0068 // RTL8723 WIFI/BT/GPS Multi-Function control source.
+#define REG_GPIO_PIN_CTRL_2			0x0060 /* RTL8723 WIFI/BT/GPS Multi-Function GPIO Pin Control. */
+#define REG_GPIO_IO_SEL_2				0x0062 /* RTL8723 WIFI/BT/GPS Multi-Function GPIO Select. */
+#define REG_PAD_CTRL_1				0x0064
+#define REG_MULTI_FUNC_CTRL			0x0068 /* RTL8723 WIFI/BT/GPS Multi-Function control source. */
 #define REG_GSSR						0x006c
-#define REG_AFE_XTAL_CTRL_EXT			0x0078 //RTL8188E
-#define REG_XCK_OUT_CTRL				0x007c //RTL8188E
+#define REG_AFE_XTAL_CTRL_EXT			0x0078 /* RTL8188E */
+#define REG_XCK_OUT_CTRL				0x007c /* RTL8188E */
 #define REG_MCUFWDL					0x0080
-#define REG_WOL_EVENT					0x0081 //RTL8188E
+#define REG_WOL_EVENT					0x0081 /* RTL8188E */
 #define REG_MCUTSTCFG					0x0084
 #define REG_FDHM0						0x0088
-#define REG_HOST_SUSP_CNT				0x00BC	// RTL8192C Host suspend counter on FPGA platform
-#define REG_SYSTEM_ON_CTRL			0x00CC	// For 8723AE Reset after S3
-#define REG_EFUSE_ACCESS				0x00CF	// Efuse access protection for RTL8723
+#define REG_HOST_SUSP_CNT				0x00BC	/* RTL8192C Host suspend counter on FPGA platform */
+#define REG_SYSTEM_ON_CTRL			0x00CC	/* For 8723AE Reset after S3 */
+#define REG_EFUSE_ACCESS				0x00CF	/* Efuse access protection for RTL8723 */
 #define REG_BIST_SCAN					0x00D0
 #define REG_BIST_RPT					0x00D4
 #define REG_BIST_ROM_RPT				0x00D8
@@ -102,20 +100,20 @@
 #define REG_PCIE_MIO_INTD				0x00E8
 #define REG_HPON_FSM					0x00EC
 #define REG_SYS_CFG						0x00F0
-#define REG_GPIO_OUTSTS				0x00F4	// For RTL8723 only.
+#define REG_GPIO_OUTSTS				0x00F4	/* For RTL8723 only. */
 #define REG_TYPE_ID						0x00FC
 
-//
-// 2010/12/29 MH Add for 92D
-//
+/*
+* 2010/12/29 MH Add for 92D
+*   */
 #define REG_MAC_PHY_CTRL_NORMAL		0x00f8
 
 
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0100h ~ 0x01FFh	MACTOP General Configuration
+*
+* ----------------------------------------------------- */
 #define REG_CR							0x0100
 #define REG_PBP							0x0104
 #define REG_PKT_BUFF_ACCESS_CTRL		0x0106
@@ -124,14 +122,15 @@
 #define REG_TRXFF_STATUS				0x0118
 #define REG_RXFF_PTR					0x011C
 #define REG_HIMR						0x0120
-#define REG_HISR						0x0124
+#define REG_FE1IMR						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_FTIMR						0x0138
-#define REG_FTISR						0x013C //RTL8192C
+#define REG_FTISR						0x013C /* RTL8192C */
 #define REG_PKTBUF_DBG_CTRL			0x0140
 #define REG_RXPKTBUF_CTRL				(REG_PKTBUF_DBG_CTRL+2)
 #define REG_PKTBUF_DBG_DATA_L			0x0144
@@ -146,11 +145,11 @@
 #define REG_MBIST_START				0x0174
 #define REG_MBIST_DONE					0x0178
 #define REG_MBIST_FAIL					0x017C
-#define REG_32K_CTRL					0x0194 //RTL8188E
+#define REG_32K_CTRL					0x0194 /* RTL8188E */
 #define REG_C2HEVT_MSG_NORMAL		0x01A0
 #define REG_C2HEVT_CLEAR				0x01AF
 #define REG_MCUTST_1					0x01c0
-#define REG_MCUTST_WOWLAN			0x01C7	// Defined after 8188E series.
+#define REG_MCUTST_WOWLAN			0x01C7	/* Defined after 8188E series. */
 #define REG_FMETHR						0x01C8
 #define REG_HMETFR						0x01CC
 #define REG_HMEBOX_0					0x01D0
@@ -164,11 +163,11 @@
 #define REG_HMEBOX_EXT_3				0x01FC
 
 
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0200h ~ 0x027Fh	TXDMA Configuration
+*
+* ----------------------------------------------------- */
 #define REG_RQPN						0x0200
 #define REG_FIFOPAGE					0x0204
 #define REG_TDECTRL						0x0208
@@ -178,20 +177,22 @@
 #define REG_AUTO_LLT					0x0224
 
 
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0280h ~ 0x02FFh	RXDMA Configuration
+*
+* ----------------------------------------------------- */
 #define REG_RXDMA_AGG_PG_TH			0x0280
-#define REG_RXPKT_NUM					0x0284 
+#define REG_RXPKT_NUM					0x0284
 #define REG_RXDMA_STATUS				0x0288
 
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0300h ~ 0x03FFh	PCIe
+*
+* ----------------------------------------------------- */
+#ifndef CONFIG_TRX_BD_ARCH	/* prevent CONFIG_TRX_BD_ARCH to use old registers */
+
 #define REG_PCIE_CTRL_REG				0x0300
 #define REG_INT_MIG					0x0304	/* Interrupt Migration */
 #define REG_BCNQ_DESA					0x0308	/* TX Beacon Descriptor Address */
@@ -202,36 +203,36 @@
 #define REG_BEQ_DESA					0x0330	/* TX BE Queue Descriptor Address */
 #define REG_BKQ_DESA					0x0338	/* TX BK Queue Descriptor Address */
 #define REG_RX_DESA					0x0340	/* RX Queue Descriptor Address */
-//sherry added for DBI Read/Write  20091126
+/* sherry added for DBI Read/Write  20091126 */
 #define REG_DBI_WDATA					0x0348	/*  Backdoor REG for Access Configuration */
 #define REG_DBI_RDATA					0x034C	/* Backdoor REG for Access Configuration */
 #define REG_DBI_CTRL					0x0350	/* Backdoor REG for Access Configuration */
 #define REG_DBI_FLAG					0x0352	/* Backdoor REG for Access Configuration */
 #define REG_MDIO					0x0354	/* MDIO for Access PCIE PHY */
 #define REG_DBG_SEL					0x0360	/* Debug Selection Register */
-#define REG_PCIE_HRPWM					0x0361	/* PCIe RPWM */
-#define REG_PCIE_HCPWM					0x0363	/* PCIe CPWM */
 #define REG_WATCH_DOG					0x0368
 #define REG_RX_RXBD_NUM					0x0382
 
-// RTL8723 series -------------------------------
+/* RTL8723 series ------------------------------- */
 #define REG_PCIE_HISR_EN				0x0394	/* PCIE Local Interrupt Enable Register */
 #define REG_PCIE_HISR					0x03A0
 #define REG_PCIE_HISRE					0x03A4
 #define REG_PCIE_HIMR					0x03A8
 #define REG_PCIE_HIMRE					0x03AC
 
+#endif /* !CONFIG_TRX_BD_ARCH */
+
 #define REG_USB_HIMR					0xFE38
 #define REG_USB_HIMRE					0xFE3C
 #define REG_USB_HISR					0xFE78
 #define REG_USB_HISRE					0xFE7C
 
 
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0400h ~ 0x047Fh	Protocol Configuration
+*
+* ----------------------------------------------------- */
 
 /* 92C, 92D */
 #define REG_VOQ_INFO	0x0400
@@ -265,6 +266,7 @@
 #define REG_ARFR1						0x0448
 #define REG_ARFR2						0x044C
 #define REG_ARFR3						0x0450
+#define REG_CCK_CHECK					0x0454
 #define REG_BCNQ1_BDNY					0x0457
 
 #define REG_AGGLEN_LMT					0x0458
@@ -312,19 +314,24 @@
 #define REG_MACID_SLEEP	0x04D4
 
 #define REG_NQOS_SEQ					0x04DC
+#define REG_HW_SEQ0						0x04D8
+#define REG_HW_SEQ1						0x04DA
+#define REG_HW_SEQ2						0x04DC
+#define REG_HW_SEQ3						0x04DE
+
 #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_TX_RPT_CTRL					0x04EC
-#define REG_TX_RPT_TIME					0x04F0	// 2 byte
+#define REG_TX_RPT_TIME					0x04F0	/* 2 byte */
 #define REG_DUMMY						0x04FC
 
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0500h ~ 0x05FFh	EDCA Configuration
+*
+* ----------------------------------------------------- */
 #define REG_EDCA_VO_PARAM				0x0500
 #define REG_EDCA_VI_PARAM				0x0504
 #define REG_EDCA_BE_PARAM				0x0508
@@ -341,21 +348,21 @@
 #define REG_TXPAUSE						0x0522
 #define REG_DIS_TXREQ_CLR				0x0523
 #define REG_RD_CTRL						0x0524
-//
-// Format for offset 540h-542h:
-//	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
-//	[7:4]:   Reserved.
-//	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
-//	[23:20]: Reserved
-// Description:
-//	              |
-//     |<--Setup--|--Hold------------>|
-//	--------------|----------------------
-//                |
-//               TBTT
-// Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
-// Described by Designer Tim and Bruce, 2011-01-14.
-//
+/*
+* Format for offset 540h-542h:
+*	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+*	[7:4]:   Reserved.
+*	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+*	[23:20]: Reserved
+* Description:
+*	              |
+*      |<--Setup--|--Hold------------>|
+*   --------------|----------------------
+*                 |
+*                TBTT
+* Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+* Described by Designer Tim and Bruce, 2011-01-14.
+*   */
 #define REG_TBTT_PROHIBIT				0x0540
 #define REG_RD_NAV_NXT					0x0544
 #define REG_NAV_PROT_LEN				0x0546
@@ -363,21 +370,22 @@
 #define REG_BCN_CTRL_1					0x0551
 #define REG_MBID_NUM					0x0552
 #define REG_DUAL_TSF_RST				0x0553
-#define REG_BCN_INTERVAL				0x0554	// The same as REG_MBSSID_BCN_SPACE
+#define REG_BCN_INTERVAL				0x0554	/* The same as REG_MBSSID_BCN_SPACE */
 #define REG_DRVERLYINT					0x0558
 #define REG_BCNDMATIM					0x0559
 #define REG_ATIMWND					0x055A
 #define REG_USTIME_TSF					0x055C
 #define REG_BCN_MAX_ERR				0x055D
 #define REG_RXTSF_OFFSET_CCK			0x055E
-#define REG_RXTSF_OFFSET_OFDM			0x055F	
+#define REG_RXTSF_OFFSET_OFDM			0x055F
 #define REG_TSFTR						0x0560
-#define REG_TSFTR1						0x0568	// HW Port 1 TSF Register
+#define REG_TSFTR1						0x0568	/* HW Port 1 TSF Register */
 #define REG_ATIMWND_1					0x0570
-#define REG_P2P_CTWIN					0x0572 // 1 Byte long (in unit of TU)
+#define REG_P2P_CTWIN					0x0572 /* 1 Byte long (in unit of TU) */
 #define REG_PSTIMER						0x0580
 #define REG_TIMER0						0x0584
 #define REG_TIMER1						0x0588
+#define REG_HIQ_NO_LMT_EN				0x05A7
 #define REG_ACMHWCTRL					0x05C0
 #define REG_NOA_DESC_SEL				0x05CF
 #define REG_NOA_DESC_DURATION		0x05E0
@@ -385,18 +393,18 @@
 #define REG_NOA_DESC_START			0x05E8
 #define REG_NOA_DESC_COUNT			0x05EC
 
-#define REG_DMC							0x05F0	//Dual MAC Co-Existence Register
+#define REG_DMC							0x05F0	/* Dual MAC Co-Existence Register */
 #define REG_SCH_TX_CMD					0x05F8
 
 #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
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	0x0600h ~ 0x07FFh	WMAC Configuration
+*
+* ----------------------------------------------------- */
 #define REG_APSD_CTRL					0x0600
 #define REG_BWOPMODE					0x0603
 #define REG_TCR							0x0604
@@ -408,26 +416,27 @@
 #define REG_MACID						0x0610
 #define REG_BSSID						0x0618
 #define REG_MAR							0x0620
-#define REG_MBIDCAMCFG					0x0628
+#define REG_MBIDCAMCFG_1				0x0628
+#define REG_MBIDCAMCFG_2				0x062C
 
 #define REG_PNO_STATUS					0x0631
 #define REG_USTIME_EDCA				0x0638
 #define REG_MAC_SPEC_SIFS				0x063A
-// 20100719 Joseph: Hardware register definition change. (HW datasheet v54)
-#define REG_RESP_SIFS_CCK				0x063C	// [15:8]SIFS_R2T_OFDM, [7:0]SIFS_R2T_CCK
-#define REG_RESP_SIFS_OFDM                    0x063E	// [15:8]SIFS_T2T_OFDM, [7:0]SIFS_T2T_CCK
+/* 20100719 Joseph: Hardware register definition change. (HW datasheet v54) */
+#define REG_RESP_SIFS_CCK				0x063C	/* [15:8]SIFS_R2T_OFDM, [7:0]SIFS_R2T_CCK */
+#define REG_RESP_SIFS_OFDM                    0x063E	/* [15:8]SIFS_T2T_OFDM, [7:0]SIFS_T2T_CCK */
 
 #define REG_ACKTO						0x0640
 #define REG_CTS2TO						0x0641
 #define REG_EIFS							0x0642
 
 
-//RXERR_RPT
+/* RXERR_RPT */
 #define RXERR_TYPE_OFDM_PPDU			0
-#define RXERR_TYPE_OFDM_FALSE_ALARM 	1
-#define RXERR_TYPE_OFDM_MPDU_OK 		2
+#define RXERR_TYPE_OFDM_FALSE_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_CCK_PPDU			4
 #define RXERR_TYPE_CCK_FALSE_ALARM	5
 #define RXERR_TYPE_CCK_MPDU_OK		6
 #define RXERR_TYPE_CCK_MPDU_FAIL		7
@@ -435,25 +444,25 @@
 #define RXERR_TYPE_HT_FALSE_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_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)
 
-//
-// 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
-
-//WMA, BA, CCX
+/*
+* 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 */
+
+/* WMA, BA, CCX */
 #define REG_NAV_CTRL					0x0650
 #define REG_BACAMCMD					0x0654
 #define REG_BACAMCONTENT				0x0658
@@ -462,17 +471,17 @@
 #define REG_RXERR_RPT					0x0664
 #define REG_WMAC_TRXPTCL_CTL			0x0668
 
-// Security
+/* Security */
 #define REG_CAMCMD						0x0670
 #define REG_CAMWRITE					0x0674
 #define REG_CAMREAD					0x0678
 #define REG_CAMDBG						0x067C
 #define REG_SECCFG						0x0680
 
-// Power
+/* Power */
 #define REG_WOW_CTRL					0x0690
 #define REG_PS_RX_INFO					0x0692
-#define REG_UAPSD_TID					0x0693
+#define REG_WMMPS_UAPSD_TID			0x0693
 #define REG_WKFMCAM_CMD				0x0698
 #define REG_WKFMCAM_NUM				REG_WKFMCAM_CMD
 #define REG_WKFMCAM_RWD				0x069C
@@ -482,16 +491,27 @@
 #define REG_BCN_PSR_RPT				0x06A8
 #define REG_BT_COEX_TABLE				0x06C0
 
-// Hardware Port 2
+/* Hardware Port 1 */
 #define REG_MACID1						0x0700
 #define REG_BSSID1						0x0708
-
-
-//-----------------------------------------------------
-//
-//	0xFE00h ~ 0xFE55h	USB Configuration
-//
-//-----------------------------------------------------
+/* Hardware Port 2 */
+#define REG_MACID2						0x1620
+#define REG_BSSID2						0x1628
+/* Hardware Port 3*/
+#define REG_MACID3						0x1630
+#define REG_BSSID3						0x1638
+/* Hardware Port 4 */
+#define REG_MACID4						0x1640
+#define REG_BSSID4						0x1648
+
+
+#define REG_CR_EXT						0x1100
+
+/* -----------------------------------------------------
+*
+*	0xFE00h ~ 0xFE55h	USB Configuration
+*
+* ----------------------------------------------------- */
 #define REG_USB_INFO					0xFE17
 #define REG_USB_SPECIAL_OPTION		0xFE55
 #define REG_USB_DMA_AGG_TO			0xFE5B
@@ -501,129 +521,130 @@
 #define REG_USB_HRPWM					0xFE58
 #define REG_USB_HCPWM					0xFE57
 
-// for 92DU high_Queue low_Queue Normal_Queue select 
+/* for 92DU high_Queue low_Queue Normal_Queue select */
 #define REG_USB_High_NORMAL_Queue_Select_MAC0	0xFE44
-//#define REG_USB_LOW_Queue_Select_MAC0		0xFE45
+/* #define REG_USB_LOW_Queue_Select_MAC0		0xFE45 */
 #define REG_USB_High_NORMAL_Queue_Select_MAC1	0xFE47
-//#define REG_USB_LOW_Queue_Select_MAC1		0xFE48
+/* #define REG_USB_LOW_Queue_Select_MAC1		0xFE48 */
 
-// For test chip
+/* 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_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
+#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
+/* 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_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		// 0xFE6D, for RTL8723 only.
-#define REG_NORMAL_SIE_MAC_ADDR		0xFE70		// 0xFE70~0xFE75
-#define REG_NORMAL_SIE_STRING			0xFE80		// 0xFE80~0xFEDF
+#define REG_NORMAL_SIE_GPS_EP			0xFE6D		/* 0xFE6D, for 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
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+*
+*	Redifine 8192C register definition for compatibility
+*
+* ----------------------------------------------------- */
 
-// TODO: use these definition when using REG_xxx naming rule.
-// NOTE: DO NOT Remove these definition. Use later.
+/* TODO: use these definition when using REG_xxx naming rule.
+* NOTE: DO NOT Remove these definition. Use later. */
 
-#define EFUSE_CTRL				REG_EFUSE_CTRL		// E-Fuse Control.
-#define EFUSE_TEST				REG_EFUSE_TEST		// E-Fuse Test.
-#define MSR						(REG_CR + 2)		// Media Status register
-//#define ISR						REG_HISR
+#define EFUSE_CTRL				REG_EFUSE_CTRL		/* E-Fuse Control. */
+#define EFUSE_TEST				REG_EFUSE_TEST		/* E-Fuse Test. */
+#define MSR						(REG_CR + 2)		/* Media Status register */
+/* #define ISR						REG_HISR */
+#define MSR1						REG_CR_EXT
 
-#define TSFR						REG_TSFTR			// Timing Sync Function Timer Register.
-#define TSFR1					REG_TSFTR1			// HW Port 1 TSF Register
+#define TSFR						REG_TSFTR			/* Timing Sync Function Timer Register. */
+#define TSFR1					REG_TSFTR1			/* HW Port 1 TSF Register */
 
 #define PBP						REG_PBP
 
-// Redifine MACID register, to compatible prior ICs.
-#define IDR0						REG_MACID			// MAC ID Register, Offset 0x0050-0x0053
-#define IDR4						(REG_MACID + 4)		// MAC ID Register, Offset 0x0054-0x0055
+/* Redifine MACID register, to compatible prior ICs. */
+#define IDR0						REG_MACID			/* MAC ID Register, Offset 0x0050-0x0053 */
+#define IDR4						(REG_MACID + 4)		/* MAC ID Register, Offset 0x0054-0x0055 */
 
 
-//
-// 9. Security Control Registers	(Offset: )
-//
-#define RWCAM					REG_CAMCMD		//IN 8190 Data Sheet is called CAMcmd
-#define WCAMI					REG_CAMWRITE	// Software write CAM input content
-#define RCAMO					REG_CAMREAD		// Software read/write CAM config
+/*
+* 9. Security Control Registers	(Offset: )
+*   */
+#define RWCAM					REG_CAMCMD		/* IN 8190 Data Sheet is called CAMcmd */
+#define WCAMI					REG_CAMWRITE	/* Software write CAM input content */
+#define RCAMO					REG_CAMREAD		/* Software read/write CAM config */
 #define CAMDBG					REG_CAMDBG
-#define SECR						REG_SECCFG		//Security Configuration Register
+#define SECR						REG_SECCFG		/* Security Configuration Register */
 
-// Unused register
+/* Unused register */
 #define UnusedRegister			0x1BF
 #define DCAM					UnusedRegister
 #define PSR						UnusedRegister
 #define BBAddr					UnusedRegister
 #define PhyDataR					UnusedRegister
 
-// Min Spacing related settings.
-#define MAX_MSS_DENSITY_2T 			0x13
-#define MAX_MSS_DENSITY_1T 			0x0A
+/* Min Spacing related settings. */
+#define MAX_MSS_DENSITY_2T			0x13
+#define MAX_MSS_DENSITY_1T			0x0A
 
-//----------------------------------------------------------------------------
-//       8192C Cmd9346CR bits					(Offset 0xA, 16bit)
-//----------------------------------------------------------------------------
-#define CmdEEPROM_En				BIT5	 // EEPROM enable when set 1
-#define CmdEERPOMSEL				BIT4 	// System EEPROM select, 0: boot from E-FUSE, 1: The EEPROM used is 9346
-#define Cmd9346CR_9356SEL			BIT4
+/* ----------------------------------------------------------------------------
+* 8192C Cmd9346CR bits					(Offset 0xA, 16bit)
+* ---------------------------------------------------------------------------- */
+#define CmdEEPROM_En				BIT(5)	 /* EEPROM enable when set 1 */
+#define CmdEERPOMSEL				BIT(4)	/* System EEPROM select, 0: boot from E-FUSE, 1: The EEPROM used is 9346 */
+#define Cmd9346CR_9356SEL			BIT(4)
 
-//----------------------------------------------------------------------------
-//       8192C GPIO MUX Configuration Register (offset 0x40, 4 byte)
-//----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------
+* 8192C GPIO MUX Configuration Register (offset 0x40, 4 byte)
+* ---------------------------------------------------------------------------- */
 #define GPIOSEL_GPIO				0
-#define GPIOSEL_ENBT				BIT5
-
-//----------------------------------------------------------------------------
-//       8192C GPIO PIN Control Register (offset 0x44, 4 byte)
-//----------------------------------------------------------------------------
-#define GPIO_IN					REG_GPIO_PIN_CTRL		// GPIO pins input value
-#define GPIO_OUT				(REG_GPIO_PIN_CTRL+1)	// GPIO pins output value
-#define GPIO_IO_SEL				(REG_GPIO_PIN_CTRL+2)	// GPIO pins output enable when a bit is set to "1"; otherwise, input is configured.
+#define GPIOSEL_ENBT				BIT(5)
+
+/* ----------------------------------------------------------------------------
+* 8192C GPIO PIN Control Register (offset 0x44, 4 byte)
+* ---------------------------------------------------------------------------- */
+#define GPIO_IN					REG_GPIO_PIN_CTRL		/* GPIO pins input value */
+#define GPIO_OUT				(REG_GPIO_PIN_CTRL+1)	/* GPIO pins output value */
+#define GPIO_IO_SEL				(REG_GPIO_PIN_CTRL+2)	/* GPIO pins output enable when a bit is set to "1"; otherwise, input is configured. */
 #define GPIO_MOD				(REG_GPIO_PIN_CTRL+3)
 
-//----------------------------------------------------------------------------
-//       8811A GPIO PIN Control Register (offset 0x60, 4 byte)
-//----------------------------------------------------------------------------
-#define GPIO_IN_8811A			REG_GPIO_PIN_CTRL_2		// GPIO pins input value
-#define GPIO_OUT_8811A			(REG_GPIO_PIN_CTRL_2+1)	// GPIO pins output value
-#define GPIO_IO_SEL_8811A		(REG_GPIO_PIN_CTRL_2+2)	// GPIO pins output enable when a bit is set to "1"; otherwise, input is configured.
+/* ----------------------------------------------------------------------------
+* 8811A GPIO PIN Control Register (offset 0x60, 4 byte)
+* ---------------------------------------------------------------------------- */
+#define GPIO_IN_8811A			REG_GPIO_PIN_CTRL_2		/* GPIO pins input value */
+#define GPIO_OUT_8811A			(REG_GPIO_PIN_CTRL_2+1)	/* GPIO pins output value */
+#define GPIO_IO_SEL_8811A		(REG_GPIO_PIN_CTRL_2+2)	/* GPIO pins output enable when a bit is set to "1"; otherwise, input is configured. */
 #define GPIO_MOD_8811A			(REG_GPIO_PIN_CTRL_2+3)
 
-//----------------------------------------------------------------------------
-//       8723/8188E Host System Interrupt Mask Register (offset 0x58, 32 byte)
-//----------------------------------------------------------------------------
-#define HSIMR_GPIO12_0_INT_EN			BIT0
-#define HSIMR_SPS_OCP_INT_EN			BIT5
-#define HSIMR_RON_INT_EN				BIT6
-#define HSIMR_PDN_INT_EN				BIT7
-#define HSIMR_GPIO9_INT_EN				BIT25
-
-//----------------------------------------------------------------------------
-//       8723/8188E Host System Interrupt Status Register (offset 0x5C, 32 byte)
-//----------------------------------------------------------------------------
-#define HSISR_GPIO12_0_INT				BIT0
-#define HSISR_SPS_OCP_INT				BIT5
-#define HSISR_RON_INT					BIT6
-#define HSISR_PDNINT					BIT7
-#define HSISR_GPIO9_INT					BIT25
-
-//----------------------------------------------------------------------------
-//       8192C (MSR) Media Status Register	(Offset 0x4C, 8 bits)  
-//----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------
+* 8723/8188E 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_PDN_INT_EN				BIT(7)
+#define HSIMR_GPIO9_INT_EN				BIT(25)
+
+/* ----------------------------------------------------------------------------
+* 8723/8188E 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)
+
+/* ----------------------------------------------------------------------------
+* 8192C (MSR) Media Status Register	(Offset 0x4C, 8 bits)
+* ---------------------------------------------------------------------------- */
 /*
 Network Type
 00: No link
@@ -637,9 +658,9 @@ Default: 00b.
 #define MSR_INFRA				0x02
 #define MSR_AP					0x03
 
-//----------------------------------------------------------------------------
-//       USB INTR CONTENT
-//----------------------------------------------------------------------------
+/* ----------------------------------------------------------------------------
+* USB INTR CONTENT
+* ---------------------------------------------------------------------------- */
 #define USB_C2H_CMDID_OFFSET					0
 #define USB_C2H_SEQ_OFFSET					1
 #define USB_C2H_EVENT_OFFSET					2
@@ -651,49 +672,58 @@ Default: 00b.
 #define USB_INTR_CONTENT_HISRE_OFFSET		52
 #define USB_INTR_CONTENT_LENGTH				56
 
-//----------------------------------------------------------------------------
-//       Response Rate Set Register	(offset 0x440, 24bits)
-//----------------------------------------------------------------------------
-#define RRSR_1M					BIT0
-#define RRSR_2M					BIT1 
-#define RRSR_5_5M				BIT2 
-#define RRSR_11M				BIT3 
-#define RRSR_6M					BIT4 
-#define RRSR_9M					BIT5 
-#define RRSR_12M				BIT6 
-#define RRSR_18M				BIT7 
-#define RRSR_24M				BIT8 
-#define RRSR_36M				BIT9 
-#define RRSR_48M				BIT10 
-#define RRSR_54M				BIT11
-#define RRSR_MCS0				BIT12
-#define RRSR_MCS1				BIT13
-#define RRSR_MCS2				BIT14
-#define RRSR_MCS3				BIT15
-#define RRSR_MCS4				BIT16
-#define RRSR_MCS5				BIT17
-#define RRSR_MCS6				BIT18
-#define RRSR_MCS7				BIT19
-
-#define RRSR_CCK_RATES (RRSR_11M|RRSR_5_5M|RRSR_2M|RRSR_1M)
-#define RRSR_OFDM_RATES (RRSR_54M|RRSR_48M|RRSR_36M|RRSR_24M|RRSR_18M|RRSR_12M|RRSR_9M|RRSR_6M)
-
-// WOL bit information
-#define HAL92C_WOL_PTK_UPDATE_EVENT		BIT0
-#define HAL92C_WOL_GTK_UPDATE_EVENT		BIT1
-#define HAL92C_WOL_DISASSOC_EVENT		BIT2
-#define HAL92C_WOL_DEAUTH_EVENT			BIT3
-#define HAL92C_WOL_FW_DISCONNECT_EVENT	BIT4
-
-//----------------------------------------------------------------------------
-//       Rate Definition
-//----------------------------------------------------------------------------
-//CCK
+/* ----------------------------------------------------------------------------
+* Response Rate Set Register	(offset 0x440, 24bits)
+* ---------------------------------------------------------------------------- */
+#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 RRSR_CCK_RATES (RRSR_11M | RRSR_5_5M | RRSR_2M | RRSR_1M)
+#define RRSR_OFDM_RATES (RRSR_54M | RRSR_48M | RRSR_36M | RRSR_24M | RRSR_18M | RRSR_12M | RRSR_9M | RRSR_6M)
+
+/* WOL bit information */
+#define HAL92C_WOL_PTK_UPDATE_EVENT		BIT(0)
+#define HAL92C_WOL_GTK_UPDATE_EVENT		BIT(1)
+#define HAL92C_WOL_DISASSOC_EVENT		BIT(2)
+#define HAL92C_WOL_DEAUTH_EVENT			BIT(3)
+#define HAL92C_WOL_FW_DISCONNECT_EVENT	BIT(4)
+
+
+/*----------------------------------------------------------------------------
+**      REG_CCK_CHECK						(offset 0x454)
+------------------------------------------------------------------------------*/
+#define BIT_BCN_PORT_SEL		BIT(5)
+#define BIT_EN_BCN_PKT_REL		BIT(6)
+
+#endif /* RTW_HALMAC */
+
+/* ----------------------------------------------------------------------------
+ * Rate Definition
+ * ---------------------------------------------------------------------------- */
+/* CCK */
 #define	RATR_1M					0x00000001
 #define	RATR_2M					0x00000002
 #define	RATR_55M					0x00000004
 #define	RATR_11M					0x00000008
-//OFDM 		
+/* OFDM		 */
 #define	RATR_6M					0x00000010
 #define	RATR_9M					0x00000020
 #define	RATR_12M					0x00000040
@@ -702,7 +732,7 @@ Default: 00b.
 #define	RATR_36M					0x00000200
 #define	RATR_48M					0x00000400
 #define	RATR_54M					0x00000800
-//MCS 1 Spatial Stream	
+/* MCS 1 Spatial Stream	 */
 #define	RATR_MCS0					0x00001000
 #define	RATR_MCS1					0x00002000
 #define	RATR_MCS2					0x00004000
@@ -711,7 +741,7 @@ Default: 00b.
 #define	RATR_MCS5					0x00020000
 #define	RATR_MCS6					0x00040000
 #define	RATR_MCS7					0x00080000
-//MCS 2 Spatial Stream
+/* MCS 2 Spatial Stream */
 #define	RATR_MCS8					0x00100000
 #define	RATR_MCS9					0x00200000
 #define	RATR_MCS10					0x00400000
@@ -721,12 +751,12 @@ Default: 00b.
 #define	RATR_MCS14					0x04000000
 #define	RATR_MCS15					0x08000000
 
-//CCK
+/* CCK */
 #define RATE_1M					BIT(0)
 #define RATE_2M					BIT(1)
 #define RATE_5_5M				BIT(2)
 #define RATE_11M				BIT(3)
-//OFDM 
+/* OFDM */
 #define RATE_6M					BIT(4)
 #define RATE_9M					BIT(5)
 #define RATE_12M				BIT(6)
@@ -735,7 +765,7 @@ Default: 00b.
 #define RATE_36M				BIT(9)
 #define RATE_48M				BIT(10)
 #define RATE_54M				BIT(11)
-//MCS 1 Spatial Stream
+/* MCS 1 Spatial Stream */
 #define RATE_MCS0				BIT(12)
 #define RATE_MCS1				BIT(13)
 #define RATE_MCS2				BIT(14)
@@ -744,7 +774,7 @@ Default: 00b.
 #define RATE_MCS5				BIT(17)
 #define RATE_MCS6				BIT(18)
 #define RATE_MCS7				BIT(19)
-//MCS 2 Spatial Stream
+/* MCS 2 Spatial Stream */
 #define RATE_MCS8				BIT(20)
 #define RATE_MCS9				BIT(21)
 #define RATE_MCS10				BIT(22)
@@ -755,35 +785,35 @@ Default: 00b.
 #define RATE_MCS15				BIT(27)
 
 
-// ALL CCK Rate
-#define	RATE_ALL_CCK				RATR_1M|RATR_2M|RATR_55M|RATR_11M 
-#define	RATE_ALL_OFDM_AG			RATR_6M|RATR_9M|RATR_12M|RATR_18M|RATR_24M|\
-						RATR_36M|RATR_48M|RATR_54M	
-#define	RATE_ALL_OFDM_1SS			RATR_MCS0|RATR_MCS1|RATR_MCS2|RATR_MCS3 |\
-						RATR_MCS4|RATR_MCS5|RATR_MCS6	|RATR_MCS7	
-#define	RATE_ALL_OFDM_2SS			RATR_MCS8|RATR_MCS9	|RATR_MCS10|RATR_MCS11|\
-						RATR_MCS12|RATR_MCS13|RATR_MCS14|RATR_MCS15
+/* ALL CCK Rate */
+#define	RATE_ALL_CCK				(RATR_1M | RATR_2M | RATR_55M | RATR_11M)
+#define	RATE_ALL_OFDM_AG			(RATR_6M | RATR_9M | RATR_12M | RATR_18M | RATR_24M|\
+	RATR_36M | RATR_48M | RATR_54M)
+#define	RATE_ALL_OFDM_1SS			(RATR_MCS0 | RATR_MCS1 | RATR_MCS2 | RATR_MCS3 |\
+	RATR_MCS4 | RATR_MCS5 | RATR_MCS6 | RATR_MCS7)
+#define	RATE_ALL_OFDM_2SS			(RATR_MCS8 | RATR_MCS9 | RATR_MCS10 | RATR_MCS11|\
+	RATR_MCS12 | RATR_MCS13 | RATR_MCS14 | RATR_MCS15)
 
 #define RATE_BITMAP_ALL			0xFFFFF
 
-// Only use CCK 1M rate for ACK
+/* Only use CCK 1M rate for ACK */
 #define RATE_RRSR_CCK_ONLY_1M		0xFFFF1
 #define RATE_RRSR_WITHOUT_CCK		0xFFFF0
 
-//----------------------------------------------------------------------------
-//       BW_OPMODE bits				(Offset 0x603, 8bit)
-//----------------------------------------------------------------------------
-#define BW_OPMODE_20MHZ			BIT2
-#define BW_OPMODE_5G				BIT1
+/* ----------------------------------------------------------------------------
+ * BW_OPMODE bits				(Offset 0x603, 8bit)
+ * ---------------------------------------------------------------------------- */
+#define BW_OPMODE_20MHZ			BIT(2)
+#define BW_OPMODE_5G				BIT(1)
 
-//----------------------------------------------------------------------------
-//       CAM Config Setting (offset 0x680, 1 byte)
-//----------------------------------------------------------------------------   	       		
-#define CAM_VALID				BIT15
+/* ----------------------------------------------------------------------------
+ * CAM Config Setting (offset 0x680, 1 byte)
+ * ----------------------------------------------------------------------------			 */
+#define CAM_VALID				BIT(15)
 #define CAM_NOTVALID			0x0000
-#define CAM_USEDK				BIT5
+#define CAM_USEDK				BIT(5)
 
-#define CAM_CONTENT_COUNT 	8
+#define CAM_CONTENT_COUNT	8
 
 #define CAM_NONE				0x0
 #define CAM_WEP40				0x01
@@ -791,244 +821,244 @@ Default: 00b.
 #define CAM_AES					0x04
 #define CAM_WEP104				0x05
 #define CAM_SMS4				0x6
-        		
+
 #define TOTAL_CAM_ENTRY		32
-#define HALF_CAM_ENTRY			16	
-       		
+#define HALF_CAM_ENTRY			16
+
 #define CAM_CONFIG_USEDK		_TRUE
 #define CAM_CONFIG_NO_USEDK	_FALSE
 
-#define CAM_WRITE				BIT16
+#define CAM_WRITE				BIT(16)
 #define CAM_READ				0x00000000
-#define CAM_POLLINIG			BIT31
-
-//
-// 10. Power Save Control Registers	 
-//
-#define WOW_PMEN				BIT0 // Power management Enable.
-#define WOW_WOMEN				BIT1 // WoW function on or off. 
-#define WOW_MAGIC				BIT2 // Magic packet
-#define WOW_UWF				BIT3 // Unicast Wakeup frame.
-
-//
-// 12. Host Interrupt Status Registers	 
-//
-//----------------------------------------------------------------------------
-//      8190 IMR/ISR bits						
-//----------------------------------------------------------------------------
+#define CAM_POLLINIG			BIT(31)
+
+/*
+ * 10. Power Save Control Registers
+ *   */
+#define WOW_PMEN				BIT(0) /* Power management Enable. */
+#define WOW_WOMEN				BIT(1) /* WoW function on or off. */
+#define WOW_MAGIC				BIT(2) /* Magic packet */
+#define WOW_UWF				BIT(3) /* Unicast Wakeup frame. */
+
+/*
+ * 12. Host Interrupt Status Registers
+ *
+ * ----------------------------------------------------------------------------
+ * 8190 IMR/ISR bits
+ * ---------------------------------------------------------------------------- */
 #define IMR8190_DISABLED		0x0
 #define IMR_DISABLED			0x0
-// IMR DW0 Bit 0-31
-#define IMR_BCNDMAINT6			BIT31		// Beacon DMA Interrupt 6
-#define IMR_BCNDMAINT5			BIT30		// Beacon DMA Interrupt 5
-#define IMR_BCNDMAINT4			BIT29		// Beacon DMA Interrupt 4
-#define IMR_BCNDMAINT3			BIT28		// Beacon DMA Interrupt 3
-#define IMR_BCNDMAINT2			BIT27		// Beacon DMA Interrupt 2
-#define IMR_BCNDMAINT1			BIT26		// Beacon DMA Interrupt 1
-#define IMR_BCNDOK8				BIT25		// Beacon Queue DMA OK Interrup 8
-#define IMR_BCNDOK7				BIT24		// Beacon Queue DMA OK Interrup 7
-#define IMR_BCNDOK6				BIT23		// Beacon Queue DMA OK Interrup 6
-#define IMR_BCNDOK5				BIT22		// Beacon Queue DMA OK Interrup 5
-#define IMR_BCNDOK4				BIT21		// Beacon Queue DMA OK Interrup 4
-#define IMR_BCNDOK3				BIT20		// Beacon Queue DMA OK Interrup 3
-#define IMR_BCNDOK2				BIT19		// Beacon Queue DMA OK Interrup 2
-#define IMR_BCNDOK1				BIT18		// Beacon Queue DMA OK Interrup 1
-#define IMR_TIMEOUT2			BIT17		// Timeout interrupt 2
-#define IMR_TIMEOUT1			BIT16		// Timeout interrupt 1
-#define IMR_TXFOVW				BIT15		// Transmit FIFO Overflow
-#define IMR_PSTIMEOUT			BIT14		// Power save time out interrupt 
-#define IMR_BcnInt				BIT13		// Beacon DMA Interrupt 0
-#define IMR_RXFOVW				BIT12		// Receive FIFO Overflow
-#define IMR_RDU					BIT11		// Receive Descriptor Unavailable
-#define IMR_ATIMEND				BIT10		// For 92C,ATIM Window End Interrupt. For 8723 and later ICs, it also means P2P CTWin End interrupt.
-#define IMR_BDOK				BIT9		// Beacon Queue DMA OK Interrup
-#define IMR_HIGHDOK				BIT8		// High Queue DMA OK Interrupt
-#define IMR_TBDOK				BIT7		// Transmit Beacon OK interrup
-#define IMR_MGNTDOK			BIT6		// Management Queue DMA OK Interrupt
-#define IMR_TBDER				BIT5		// For 92C,Transmit Beacon Error Interrupt
-#define IMR_BKDOK				BIT4		// AC_BK DMA OK Interrupt
-#define IMR_BEDOK				BIT3		// AC_BE DMA OK Interrupt
-#define IMR_VIDOK				BIT2		// AC_VI DMA OK Interrupt
-#define IMR_VODOK				BIT1		// AC_VO DMA Interrupt
-#define IMR_ROK					BIT0		// Receive DMA OK Interrupt
-
-// 13. Host Interrupt Status Extension Register	 (Offset: 0x012C-012Eh)
-#define IMR_TSF_BIT32_TOGGLE	BIT15
-#define IMR_BcnInt_E				BIT12
-#define IMR_TXERR				BIT11
-#define IMR_RXERR				BIT10
-#define IMR_C2HCMD				BIT9
-#define IMR_CPWM				BIT8
-//RSVD [2-7]
-#define IMR_OCPINT				BIT1
-#define IMR_WLANOFF			BIT0
-
-//----------------------------------------------------------------------------
-// 8723E series PCIE Host IMR/ISR bit
-//----------------------------------------------------------------------------
-// IMR DW0 Bit 0-31
-#define PHIMR_TIMEOUT2				BIT31
-#define PHIMR_TIMEOUT1				BIT30
-#define PHIMR_PSTIMEOUT			BIT29
-#define PHIMR_GTINT4				BIT28
-#define PHIMR_GTINT3				BIT27
-#define PHIMR_TXBCNERR				BIT26
-#define PHIMR_TXBCNOK				BIT25
-#define PHIMR_TSF_BIT32_TOGGLE	BIT24
-#define PHIMR_BCNDMAINT3			BIT23
-#define PHIMR_BCNDMAINT2			BIT22
-#define PHIMR_BCNDMAINT1			BIT21
-#define PHIMR_BCNDMAINT0			BIT20
-#define PHIMR_BCNDOK3				BIT19
-#define PHIMR_BCNDOK2				BIT18
-#define PHIMR_BCNDOK1				BIT17
-#define PHIMR_BCNDOK0				BIT16
-#define PHIMR_HSISR_IND_ON			BIT15
-#define PHIMR_BCNDMAINT_E			BIT14
-#define PHIMR_ATIMEND_E			BIT13
-#define PHIMR_ATIM_CTW_END		BIT12
-#define PHIMR_HISRE_IND			BIT11	// RO. HISRE Indicator (HISRE & HIMRE is true, this bit is set to 1)
-#define PHIMR_C2HCMD				BIT10
-#define PHIMR_CPWM2				BIT9
-#define PHIMR_CPWM					BIT8
-#define PHIMR_HIGHDOK				BIT7		// High Queue DMA OK Interrupt
-#define PHIMR_MGNTDOK				BIT6		// Management Queue DMA OK Interrupt
-#define PHIMR_BKDOK					BIT5		// AC_BK DMA OK Interrupt
-#define PHIMR_BEDOK					BIT4		// AC_BE DMA OK Interrupt
-#define PHIMR_VIDOK					BIT3		// AC_VI DMA OK Interrupt
-#define PHIMR_VODOK				BIT2		// AC_VO DMA Interrupt
-#define PHIMR_RDU					BIT1		// Receive Descriptor Unavailable
-#define PHIMR_ROK					BIT0		// Receive DMA OK Interrupt
-
-// PCIE Host Interrupt Status Extension bit
-#define PHIMR_BCNDMAINT7			BIT23
-#define PHIMR_BCNDMAINT6			BIT22
-#define PHIMR_BCNDMAINT5			BIT21
-#define PHIMR_BCNDMAINT4			BIT20
-#define PHIMR_BCNDOK7				BIT19
-#define PHIMR_BCNDOK6				BIT18
-#define PHIMR_BCNDOK5				BIT17
-#define PHIMR_BCNDOK4				BIT16
-// bit12 15: RSVD
-#define PHIMR_TXERR					BIT11
-#define PHIMR_RXERR					BIT10
-#define PHIMR_TXFOVW				BIT9
-#define PHIMR_RXFOVW				BIT8
-// bit2-7: RSVD
-#define PHIMR_OCPINT				BIT1
-// bit0: RSVD
-
-#define UHIMR_TIMEOUT2				BIT31
-#define UHIMR_TIMEOUT1				BIT30
-#define UHIMR_PSTIMEOUT			BIT29
-#define UHIMR_GTINT4				BIT28
-#define UHIMR_GTINT3				BIT27
-#define UHIMR_TXBCNERR				BIT26
-#define UHIMR_TXBCNOK				BIT25
-#define UHIMR_TSF_BIT32_TOGGLE	BIT24
-#define UHIMR_BCNDMAINT3			BIT23
-#define UHIMR_BCNDMAINT2			BIT22
-#define UHIMR_BCNDMAINT1			BIT21
-#define UHIMR_BCNDMAINT0			BIT20
-#define UHIMR_BCNDOK3				BIT19
-#define UHIMR_BCNDOK2				BIT18
-#define UHIMR_BCNDOK1				BIT17
-#define UHIMR_BCNDOK0				BIT16
-#define UHIMR_HSISR_IND			BIT15
-#define UHIMR_BCNDMAINT_E			BIT14
-//RSVD	BIT13
-#define UHIMR_CTW_END				BIT12
-//RSVD	BIT11
-#define UHIMR_C2HCMD				BIT10
-#define UHIMR_CPWM2				BIT9
-#define UHIMR_CPWM					BIT8
-#define UHIMR_HIGHDOK				BIT7		// High Queue DMA OK Interrupt
-#define UHIMR_MGNTDOK				BIT6		// Management Queue DMA OK Interrupt
-#define UHIMR_BKDOK				BIT5		// AC_BK DMA OK Interrupt
-#define UHIMR_BEDOK				BIT4		// AC_BE DMA OK Interrupt
-#define UHIMR_VIDOK					BIT3		// AC_VI DMA OK Interrupt
-#define UHIMR_VODOK				BIT2		// AC_VO DMA Interrupt
-#define UHIMR_RDU					BIT1		// Receive Descriptor Unavailable
-#define UHIMR_ROK					BIT0		// Receive DMA OK Interrupt
-
-// USB Host Interrupt Status Extension bit
-#define UHIMR_BCNDMAINT7			BIT23
-#define UHIMR_BCNDMAINT6			BIT22
-#define UHIMR_BCNDMAINT5			BIT21
-#define UHIMR_BCNDMAINT4			BIT20
-#define UHIMR_BCNDOK7				BIT19
-#define UHIMR_BCNDOK6				BIT18
-#define UHIMR_BCNDOK5				BIT17
-#define UHIMR_BCNDOK4				BIT16
-// bit14-15: RSVD
-#define UHIMR_ATIMEND_E			BIT13
-#define UHIMR_ATIMEND				BIT12
-#define UHIMR_TXERR					BIT11
-#define UHIMR_RXERR					BIT10
-#define UHIMR_TXFOVW				BIT9
-#define UHIMR_RXFOVW				BIT8
-// bit2-7: RSVD
-#define UHIMR_OCPINT				BIT1
-// bit0: RSVD
-
-
-#define HAL_NIC_UNPLUG_ISR			0xFFFFFFFF	// The value when the NIC is unplugged for PCI.
-#define HAL_NIC_UNPLUG_PCI_ISR		0xEAEAEAEA	// The value when the NIC is unplugged for PCI in PCI interrupt (page 3).
-
-//----------------------------------------------------------------------------
-//       8188 IMR/ISR bits						
-//----------------------------------------------------------------------------
+/* 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. For 8723 and later ICs, it also means P2P CTWin End interrupt. */
+#define IMR_BDOK				BIT(9)		/* Beacon Queue DMA OK Interrupt */
+#define IMR_HIGHDOK				BIT(8)		/* High Queue DMA OK Interrupt */
+#define IMR_TBDOK				BIT(7)		/* Transmit Beacon OK interrupt */
+#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 */
+
+/* 13. Host Interrupt Status Extension Register	 (Offset: 0x012C-012Eh) */
+#define IMR_TSF_BIT32_TOGGLE	BIT(15)
+#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)
+
+/* ----------------------------------------------------------------------------
+ * 8723E series PCIE Host IMR/ISR bit
+ * ---------------------------------------------------------------------------- */
+/* IMR DW0 Bit 0-31 */
+#define PHIMR_TIMEOUT2				BIT(31)
+#define PHIMR_TIMEOUT1				BIT(30)
+#define PHIMR_PSTIMEOUT			BIT(29)
+#define PHIMR_GTINT4				BIT(28)
+#define PHIMR_GTINT3				BIT(27)
+#define PHIMR_TXBCNERR				BIT(26)
+#define PHIMR_TXBCNOK				BIT(25)
+#define PHIMR_TSF_BIT32_TOGGLE	BIT(24)
+#define PHIMR_BCNDMAINT3			BIT(23)
+#define PHIMR_BCNDMAINT2			BIT(22)
+#define PHIMR_BCNDMAINT1			BIT(21)
+#define PHIMR_BCNDMAINT0			BIT(20)
+#define PHIMR_BCNDOK3				BIT(19)
+#define PHIMR_BCNDOK2				BIT(18)
+#define PHIMR_BCNDOK1				BIT(17)
+#define PHIMR_BCNDOK0				BIT(16)
+#define PHIMR_HSISR_IND_ON			BIT(15)
+#define PHIMR_BCNDMAINT_E			BIT(14)
+#define PHIMR_ATIMEND_E			BIT(13)
+#define PHIMR_ATIM_CTW_END		BIT(12)
+#define PHIMR_HISRE_IND			BIT(11)	/* RO. HISRE Indicator (HISRE & HIMRE is true, this bit is set to 1) */
+#define PHIMR_C2HCMD				BIT(10)
+#define PHIMR_CPWM2				BIT(9)
+#define PHIMR_CPWM					BIT(8)
+#define PHIMR_HIGHDOK				BIT(7)		/* High Queue DMA OK Interrupt */
+#define PHIMR_MGNTDOK				BIT(6)		/* Management Queue DMA OK Interrupt */
+#define PHIMR_BKDOK					BIT(5)		/* AC_BK DMA OK Interrupt */
+#define PHIMR_BEDOK					BIT(4)		/* AC_BE DMA OK Interrupt */
+#define PHIMR_VIDOK					BIT(3)		/* AC_VI DMA OK Interrupt */
+#define PHIMR_VODOK				BIT(2)		/* AC_VO DMA Interrupt */
+#define PHIMR_RDU					BIT(1)		/* Receive Descriptor Unavailable */
+#define PHIMR_ROK					BIT(0)		/* Receive DMA OK Interrupt */
+
+/* PCIE Host Interrupt Status Extension bit */
+#define PHIMR_BCNDMAINT7			BIT(23)
+#define PHIMR_BCNDMAINT6			BIT(22)
+#define PHIMR_BCNDMAINT5			BIT(21)
+#define PHIMR_BCNDMAINT4			BIT(20)
+#define PHIMR_BCNDOK7				BIT(19)
+#define PHIMR_BCNDOK6				BIT(18)
+#define PHIMR_BCNDOK5				BIT(17)
+#define PHIMR_BCNDOK4				BIT(16)
+/* bit12 15: RSVD */
+#define PHIMR_TXERR					BIT(11)
+#define PHIMR_RXERR					BIT(10)
+#define PHIMR_TXFOVW				BIT(9)
+#define PHIMR_RXFOVW				BIT(8)
+/* bit2-7: RSVD */
+#define PHIMR_OCPINT				BIT(1)
+/* bit0: RSVD */
+
+#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 HAL_NIC_UNPLUG_ISR			0xFFFFFFFF	/* The value when the NIC is unplugged for PCI. */
+#define HAL_NIC_UNPLUG_PCI_ISR		0xEAEAEAEA	/* The value when the NIC is unplugged for PCI in PCI interrupt (page 3). */
+
+/* ----------------------------------------------------------------------------
+ * 8188 IMR/ISR bits
+ * ---------------------------------------------------------------------------- */
 #define IMR_DISABLED_88E			0x0
-// IMR DW0(0x0060-0063) Bit 0-31
-#define IMR_TXCCK_88E				BIT30		// TXRPT interrupt when CCX bit of the packet is set	
-#define IMR_PSTIMEOUT_88E			BIT29		// Power Save Time Out Interrupt
-#define IMR_GTINT4_88E				BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define IMR_GTINT3_88E				BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define IMR_TBDER_88E				BIT26		// Transmit Beacon0 Error			
-#define IMR_TBDOK_88E				BIT25		// Transmit Beacon0 OK			
-#define IMR_TSF_BIT32_TOGGLE_88E	BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define IMR_BCNDMAINT0_88E		BIT20		// Beacon DMA Interrupt 0			
-#define IMR_BCNDERR0_88E			BIT16		// Beacon Queue DMA Error 0
-#define IMR_HSISR_IND_ON_INT_88E	BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)			
-#define IMR_BCNDMAINT_E_88E		BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define IMR_ATIMEND_88E			BIT12		// CTWidnow End or ATIM Window End
-#define IMR_HISR1_IND_INT_88E		BIT11		// HISR1 Indicator (HISR1 & HIMR1 is true, this bit is set to 1)
-#define IMR_C2HCMD_88E				BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define IMR_CPWM2_88E				BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define IMR_CPWM_88E				BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define IMR_HIGHDOK_88E			BIT7			// High Queue DMA OK	
-#define IMR_MGNTDOK_88E			BIT6			// Management Queue DMA OK	
-#define IMR_BKDOK_88E				BIT5			// AC_BK DMA OK		
-#define IMR_BEDOK_88E				BIT4			// AC_BE DMA OK	
-#define IMR_VIDOK_88E				BIT3			// AC_VI DMA OK		
-#define IMR_VODOK_88E				BIT2			// AC_VO DMA OK	
-#define IMR_RDU_88E					BIT1			// Rx Descriptor Unavailable	
-#define IMR_ROK_88E					BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define IMR_BCNDMAINT7_88E		BIT27		// Beacon DMA Interrupt 7
-#define IMR_BCNDMAINT6_88E		BIT26		// Beacon DMA Interrupt 6
-#define IMR_BCNDMAINT5_88E		BIT25		// Beacon DMA Interrupt 5
-#define IMR_BCNDMAINT4_88E		BIT24		// Beacon DMA Interrupt 4
-#define IMR_BCNDMAINT3_88E		BIT23		// Beacon DMA Interrupt 3
-#define IMR_BCNDMAINT2_88E		BIT22		// Beacon DMA Interrupt 2
-#define IMR_BCNDMAINT1_88E		BIT21		// Beacon DMA Interrupt 1
-#define IMR_BCNDOK7_88E			BIT20		// Beacon Queue DMA OK Interrup 7
-#define IMR_BCNDOK6_88E			BIT19		// Beacon Queue DMA OK Interrup 6
-#define IMR_BCNDOK5_88E			BIT18		// Beacon Queue DMA OK Interrup 5
-#define IMR_BCNDOK4_88E			BIT17		// Beacon Queue DMA OK Interrup 4
-#define IMR_BCNDOK3_88E			BIT16		// Beacon Queue DMA OK Interrup 3
-#define IMR_BCNDOK2_88E			BIT15		// Beacon Queue DMA OK Interrup 2
-#define IMR_BCNDOK1_88E			BIT14		// Beacon Queue DMA OK Interrup 1
-#define IMR_ATIMEND_E_88E			BIT13		// ATIM Window End Extension for Win7
-#define IMR_TXERR_88E				BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define IMR_RXERR_88E				BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define IMR_TXFOVW_88E				BIT9			// Transmit FIFO Overflow
-#define IMR_RXFOVW_88E				BIT8			// Receive FIFO Overflow
+/* IMR DW0(0x0060-0063) Bit 0-31 */
+#define IMR_TXCCK_88E				BIT(30)		/* TXRPT interrupt when CCX bit of the packet is set	 */
+#define IMR_PSTIMEOUT_88E			BIT(29)		/* Power Save Time Out Interrupt */
+#define IMR_GTINT4_88E				BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define IMR_GTINT3_88E				BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define IMR_TBDER_88E				BIT(26)		/* Transmit Beacon0 Error			 */
+#define IMR_TBDOK_88E				BIT(25)		/* Transmit Beacon0 OK			 */
+#define IMR_TSF_BIT32_TOGGLE_88E	BIT(24)		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define IMR_BCNDMAINT0_88E		BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define IMR_BCNDERR0_88E			BIT(16)		/* Beacon Queue DMA Error 0 */
+#define IMR_HSISR_IND_ON_INT_88E	BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)			 */
+#define IMR_BCNDMAINT_E_88E		BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define IMR_ATIMEND_88E			BIT(12)		/* CTWidnow End or ATIM Window End */
+#define IMR_HISR1_IND_INT_88E		BIT(11)		/* HISR1 Indicator (HISR1 & HIMR1 is true, this bit is set to 1) */
+#define IMR_C2HCMD_88E				BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define IMR_CPWM2_88E				BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define IMR_CPWM_88E				BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define IMR_HIGHDOK_88E			BIT(7)			/* High Queue DMA OK	 */
+#define IMR_MGNTDOK_88E			BIT(6)			/* Management Queue DMA OK	 */
+#define IMR_BKDOK_88E				BIT(5)			/* AC_BK DMA OK		 */
+#define IMR_BEDOK_88E				BIT(4)			/* AC_BE DMA OK	 */
+#define IMR_VIDOK_88E				BIT(3)			/* AC_VI DMA OK		 */
+#define IMR_VODOK_88E				BIT(2)			/* AC_VO DMA OK	 */
+#define IMR_RDU_88E					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define IMR_ROK_88E					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define IMR_BCNDMAINT7_88E		BIT(27)		/* Beacon DMA Interrupt 7 */
+#define IMR_BCNDMAINT6_88E		BIT(26)		/* Beacon DMA Interrupt 6 */
+#define IMR_BCNDMAINT5_88E		BIT(25)		/* Beacon DMA Interrupt 5 */
+#define IMR_BCNDMAINT4_88E		BIT(24)		/* Beacon DMA Interrupt 4 */
+#define IMR_BCNDMAINT3_88E		BIT(23)		/* Beacon DMA Interrupt 3 */
+#define IMR_BCNDMAINT2_88E		BIT(22)		/* Beacon DMA Interrupt 2 */
+#define IMR_BCNDMAINT1_88E		BIT(21)		/* Beacon DMA Interrupt 1 */
+#define IMR_BCNDOK7_88E			BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define IMR_BCNDOK6_88E			BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define IMR_BCNDOK5_88E			BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define IMR_BCNDOK4_88E			BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define IMR_BCNDOK3_88E			BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define IMR_BCNDOK2_88E			BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define IMR_BCNDOK1_88E			BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define IMR_ATIMEND_E_88E			BIT(13)		/* ATIM Window End Extension for Win7 */
+#define IMR_TXERR_88E				BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define IMR_RXERR_88E				BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define IMR_TXFOVW_88E				BIT(9)			/* Transmit FIFO Overflow */
+#define IMR_RXFOVW_88E				BIT(8)			/* Receive FIFO Overflow */
 
 /*===================================================================
 =====================================================================
-Here the register defines are for 92C. When the define is as same with 92C, 
+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!!!!!!
 =====================================================================
@@ -1047,66 +1077,66 @@ Current IOREG MAP
 0x0600h ~ 0x07FFh   WMAC Configuration (512 Bytes)
 0x2000h ~ 0x3FFFh   8051 FW Download Region (8196 Bytes)
 */
-	//----------------------------------------------------------------------------
-	//		 8192C (TXPAUSE) transmission pause 	(Offset 0x522, 8 bits)
-	//----------------------------------------------------------------------------
-// Note:
-//	The the bits of stoping AC(VO/VI/BE/BK) queue in datasheet RTL8192S/RTL8192C are wrong,
-//	the correct arragement is VO - Bit0, VI - Bit1, BE - Bit2, and BK - Bit3.
-//	8723 and 88E may be not correct either in the eralier version. Confirmed with DD Tim.
-// By Bruce, 2011-09-22.
-#define StopBecon		BIT6
-#define StopHigh			BIT5
-#define StopMgt			BIT4
-#define StopBK			BIT3
-#define StopBE			BIT2
-#define StopVI			BIT1
-#define StopVO			BIT0
-
-//----------------------------------------------------------------------------
-//       8192C (RCR) Receive Configuration Register	(Offset 0x608, 32 bits)
-//----------------------------------------------------------------------------
-#define RCR_APPFCS				BIT31	// WMAC append FCS after pauload
-#define RCR_APP_MIC				BIT30	// MACRX will retain the MIC at the bottom of the packet. 
-#define RCR_APP_ICV				BIT29	// MACRX will retain the ICV at the bottom of the packet.
-#define RCR_APP_PHYST_RXFF		BIT28	// PHY Status is appended before RX packet in RXFF
-#define RCR_APP_BA_SSN			BIT27	// SSN of previous TXBA is appended as after original RXDESC as the 4-th DW of RXDESC.
-#define RCR_VHT_DACK			BIT26	/* This bit to control response type for vht single mpdu data packet. 1. ACK as response 0. BA as response */
-#define RCR_TCPOFLD_EN			BIT25	/* Enable TCP checksum offload */
-#define RCR_ENMBID				BIT24	// Enable Multiple BssId. Only response ACK to the packets whose DID(A1) matching to the addresses in the MBSSID CAM Entries.
-#define RCR_LSIGEN				BIT23	// Enable LSIG TXOP Protection function. Search KEYCAM for each rx packet to check if LSIGEN bit is set.
-#define RCR_MFBEN				BIT22	// Enable immediate MCS Feedback function. When Rx packet with MRQ = 1'b1, then search KEYCAM to find sender's MCS Feedback function and send response.
-#define RCR_DISCHKPPDLLEN		BIT21	/* Do not check PPDU while the PPDU length is smaller than 14 byte. */
-#define RCR_PKTCTL_DLEN			BIT20	/* While rx path dead lock occurs, reset rx path */
-#define RCR_DISGCLK				BIT19	/* Disable macrx clock gating control (no used) */
-#define RCR_TIM_PARSER_EN		BIT18	// RX Beacon TIM Parser.
-#define RCR_BC_MD_EN			BIT17	/* Broadcast data packet more data bit check interrupt enable.*/
-#define RCR_UC_MD_EN			BIT16	/* Unicast data packet more data bit check interrupt enable. */
-#define RCR_RXSK_PERPKT			BIT15	/* Executing key search per MPDU */
-#define RCR_HTC_LOC_CTRL		BIT14	// MFC<--HTC=1 MFC-->HTC=0
-#define RCR_AMF					BIT13	// Accept management type frame
-#define RCR_ACF					BIT12	// Accept control type frame. Control frames BA, BAR, and PS-Poll (when in AP mode) are not controlled by this bit. They are controlled by ADF.
-#define RCR_ADF					BIT11	// Accept data type frame. This bit also regulates BA, BAR, and PS-Poll (AP mode only).
-#define RCR_DISDECMYPKT			BIT10	/* This bit determines whether hw need to do decryption.1: If A1 match, do decryption.0: Do decryption. */
-#define RCR_AICV					BIT9		// Accept ICV error packet
-#define RCR_ACRC32				BIT8		// Accept CRC32 error packet 
-#define RCR_CBSSID_BCN			BIT7		// Accept BSSID match packet (Rx beacon, probe rsp)
-#define RCR_CBSSID_DATA		BIT6		// Accept BSSID match packet (Data)
-#define RCR_APWRMGT			BIT5		// Accept power management packet
-#define RCR_ADD3				BIT4		// Accept address 3 match packet
-#define RCR_AB					BIT3		// Accept broadcast packet 
-#define RCR_AM					BIT2		// Accept multicast packet 
-#define RCR_APM					BIT1		// Accept physical match packet
-#define RCR_AAP					BIT0		// Accept all unicast packet 
-
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-
-//2 SYS_ISO_CTRL
+/* ---------------------------------------------------------------------------- */
+/*		 8192C (TXPAUSE) transmission pause 	(Offset 0x522, 8 bits) */
+/* ---------------------------------------------------------------------------- */
+/* Note:
+*	The the bits of stoping AC(VO/VI/BE/BK) queue in datasheet RTL8192S/RTL8192C are wrong,
+*	the correct arragement is VO - Bit0, VI - Bit1, BE - Bit2, and BK - Bit3.
+*	8723 and 88E may be not correct either in the eralier version. Confirmed with DD Tim.
+* By Bruce, 2011-09-22. */
+#define StopBecon		BIT(6)
+#define StopHigh			BIT(5)
+#define StopMgt			BIT(4)
+#define StopBK			BIT(3)
+#define StopBE			BIT(2)
+#define StopVI			BIT(1)
+#define StopVO			BIT(0)
+
+/* ----------------------------------------------------------------------------
+ * 8192C (RCR) Receive Configuration Register	(Offset 0x608, 32 bits)
+ * ---------------------------------------------------------------------------- */
+#define RCR_APPFCS				BIT(31)	/* WMAC append FCS after pauload */
+#define RCR_APP_MIC				BIT(30)	/* MACRX will retain the MIC at the bottom of the packet. */
+#define RCR_APP_ICV				BIT(29)	/* MACRX will retain the ICV at the bottom of the packet. */
+#define RCR_APP_PHYST_RXFF		BIT(28)	/* PHY Status is appended before RX packet in RXFF */
+#define RCR_APP_BA_SSN			BIT(27)	/* SSN of previous TXBA is appended as after original RXDESC as the 4-th DW of RXDESC. */
+#define RCR_VHT_DACK			BIT(26)	/* This bit to control response type for vht single mpdu data packet. 1. ACK as response 0. BA as response */
+#define RCR_TCPOFLD_EN			BIT(25)	/* Enable TCP checksum offload */
+#define RCR_ENMBID				BIT(24)	/* Enable Multiple BssId. Only response ACK to the packets whose DID(A1) matching to the addresses in the MBSSID CAM Entries. */
+#define RCR_LSIGEN				BIT(23)	/* Enable LSIG TXOP Protection function. Search KEYCAM for each rx packet to check if LSIGEN bit is set. */
+#define RCR_MFBEN				BIT(22)	/* Enable immediate MCS Feedback function. When Rx packet with MRQ = 1'b1, then search KEYCAM to find sender's MCS Feedback function and send response. */
+#define RCR_DISCHKPPDLLEN		BIT(21)	/* Do not check PPDU while the PPDU length is smaller than 14 byte. */
+#define RCR_PKTCTL_DLEN			BIT(20)	/* While rx path dead lock occurs, reset rx path */
+#define RCR_DISGCLK				BIT(19)	/* Disable macrx clock gating control (no used) */
+#define RCR_TIM_PARSER_EN		BIT(18)	/* RX Beacon TIM Parser. */
+#define RCR_BC_MD_EN			BIT(17)	/* Broadcast data packet more data bit check interrupt enable.*/
+#define RCR_UC_MD_EN			BIT(16)	/* Unicast data packet more data bit check interrupt enable. */
+#define RCR_RXSK_PERPKT			BIT(15)	/* Executing key search per MPDU */
+#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. Control frames BA, BAR, and PS-Poll (when in AP mode) are not controlled by this bit. They are controlled by ADF. */
+#define RCR_ADF					BIT(11)	/* Accept data type frame. This bit also regulates BA, BAR, and PS-Poll (AP mode only). */
+#define RCR_DISDECMYPKT			BIT(10)	/* This bit determines whether hw need to do decryption.1: If A1 match, do decryption.0: Do decryption. */
+#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_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 */
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* 2 SYS_ISO_CTRL */
 #define ISO_MD2PP				BIT(0)
 #define ISO_UA2USB				BIT(1)
 #define ISO_UD2CORE				BIT(2)
@@ -1120,7 +1150,7 @@ Current IOREG MAP
 #define PWC_EV12V				BIT(15)
 
 
-//2 SYS_FUNC_EN
+/* 2 SYS_FUNC_EN */
 #define FEN_BBRSTB				BIT(0)
 #define FEN_BB_GLB_RSTn		BIT(1)
 #define FEN_USBA				BIT(2)
@@ -1138,7 +1168,7 @@ Current IOREG MAP
 #define FEN_HWPDN				BIT(14)
 #define FEN_MREGEN				BIT(15)
 
-//2 APS_FSMCO
+/* 2 APS_FSMCO */
 #define PFM_LDALL				BIT(0)
 #define PFM_ALDN				BIT(1)
 #define PFM_LDKP				BIT(2)
@@ -1166,26 +1196,26 @@ Current IOREG MAP
 #define SOP_A8M					BIT(30)
 #define XOP_BTCK				BIT(31)
 
-//2 SYS_CLKR
+/* 2 SYS_CLKR */
 #define ANAD16V_EN				BIT(0)
 #define ANA8M					BIT(1)
 #define MACSLP					BIT(4)
 #define LOADER_CLK_EN			BIT(5)
 
 
-//2 9346CR /REG_SYS_EEPROM_CTRL
+/* 2 9346CR /REG_SYS_EEPROM_CTRL */
 #define BOOT_FROM_EEPROM		BIT(4)
 #define EEPROMSEL				BIT(4)
 #define EEPROM_EN				BIT(5)
 
 
-//2 RF_CTRL
+/* 2 RF_CTRL */
 #define RF_EN					BIT(0)
 #define RF_RSTB					BIT(1)
 #define RF_SDMRSTB				BIT(2)
 
 
-//2 LDOV12D_CTRL
+/* 2 LDOV12D_CTRL */
 #define LDV12_EN				BIT(0)
 #define LDV12_SDBY				BIT(1)
 #define LPLDO_HSM				BIT(2)
@@ -1194,9 +1224,9 @@ Current IOREG MAP
 
 
 
-//2 EFUSE_TEST (For RTL8723 partially)
+/* 2 EFUSE_TEST (For RTL8723 partially) */
 #define EF_TRPT					BIT(7)
-#define EF_CELL_SEL				(BIT(8)|BIT(9)) // 00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2
+#define EF_CELL_SEL				(BIT(8) | BIT(9)) /* 00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2 */
 #define LDOE25_EN				BIT(31)
 #define EFUSE_SEL(x)				(((x) & 0x3) << 8)
 #define EFUSE_SEL_MASK			0x300
@@ -1206,8 +1236,8 @@ Current IOREG MAP
 #define EFUSE_BT_SEL_2			0x3
 
 
-//2 8051FWDL
-//2 MCUFWDL
+/* 2 8051FWDL
+ * 2 MCUFWDL */
 #define MCUFWDL_EN				BIT(0)
 #define MCUFWDL_RDY			BIT(1)
 #define FWDL_ChkSum_rpt		BIT(2)
@@ -1221,7 +1251,7 @@ Current IOREG MAP
 #define CPRST					BIT(23)
 
 
-//2 REG_SYS_CFG
+/* 2 REG_SYS_CFG */
 #define XCLK_VLD				BIT(0)
 #define ACLK_VLD				BIT(1)
 #define UCLK_VLD				BIT(2)
@@ -1233,30 +1263,30 @@ Current IOREG MAP
 #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 CHIP_VER				(BIT(12) | BIT(13) | BIT(14) | BIT(15))
 #define BT_FUNC					BIT(16)
 #define VENDOR_ID				BIT(19)
-#define EXT_VENDOR_ID			(BIT(18)|BIT(19)) //Currently only for RTL8723B
+#define EXT_VENDOR_ID			(BIT(18) | BIT(19)) /* Currently only for RTL8723B */
 #define PAD_HWPD_IDN			BIT(22)
-#define TRP_VAUX_EN				BIT(23)	// RTL ID
+#define TRP_VAUX_EN				BIT(23)	/* RTL ID */
 #define TRP_BT_EN				BIT(24)
 #define BD_PKG_SEL				BIT(25)
 #define BD_HCI_SEL				BIT(26)
 #define TYPE_ID					BIT(27)
 #define RF_TYPE_ID				BIT(27)
 
-#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
+#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 */
 
 
-#define CHIP_VER_RTL_MASK		0xF000	//Bit 12 ~ 15
+#define CHIP_VER_RTL_MASK		0xF000	/* Bit 12 ~ 15 */
 #define CHIP_VER_RTL_SHIFT		12
 #define EXT_VENDOR_ID_SHIFT	18
 
-//2 REG_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)) 
+/* 2 REG_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)
@@ -1273,17 +1303,17 @@ Current IOREG MAP
 #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))
+#define RF_RL_ID					(BIT(31) | BIT(30) | BIT(29) | BIT(28))
 
 
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
 
-//2 Function Enable Registers
-//2 CR
+/* 2 Function Enable Registers
+ * 2 CR */
 #define HCI_TXDMA_EN			BIT(0)
 #define HCI_RXDMA_EN			BIT(1)
 #define TXDMA_EN				BIT(2)
@@ -1294,9 +1324,9 @@ Current IOREG MAP
 #define MACRXEN					BIT(7)
 #define ENSWBCN					BIT(8)
 #define ENSEC					BIT(9)
-#define CALTMR_EN				BIT(10)	// 32k CAL TMR enable
+#define CALTMR_EN				BIT(10)	/* 32k CAL TMR enable */
 
-// Network type
+/* Network type */
 #define _NETTYPE(x)				(((x) & 0x3) << 16)
 #define MASK_NETTYPE			0x30000
 #define NT_NO_LINK				0x0
@@ -1304,7 +1334,7 @@ Current IOREG MAP
 #define NT_LINK_AP				0x2
 #define NT_AS_AP				0x3
 
-//2 PBP - Page Size Register
+/* 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
@@ -1319,7 +1349,7 @@ Current IOREG MAP
 #define PBP_1024				0x4
 
 
-//2 TX/RXDMA
+/* 2 TX/RXDMA */
 #define RXDMA_ARBBW_EN		BIT(0)
 #define RXSHFT_EN				BIT(1)
 #define RXDMA_AGG_EN			BIT(2)
@@ -1337,14 +1367,14 @@ Current IOREG MAP
 #define HQSEL_MGTQ				BIT(4)
 #define HQSEL_HIQ				BIT(5)
 
-// For normal driver, 0x10C
-#define _TXDMA_CMQ_MAP(x) 	 		(((x)&0x3) << 16)
-#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 )
+/* For normal driver, 0x10C */
+#define _TXDMA_CMQ_MAP(x)			(((x) & 0x3) << 16)
+#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_EXTRA				0
 #define QUEUE_LOW				1
@@ -1352,10 +1382,10 @@ Current IOREG MAP
 #define QUEUE_HIGH				3
 
 
-//2 TRXFF_BNDY
+/* 2 TRXFF_BNDY */
 
 
-//2 LLT_INIT
+/* 2 LLT_INIT */
 #define _LLT_NO_ACTIVE				0x0
 #define _LLT_WRITE_ACCESS			0x1
 #define _LLT_READ_ACCESS			0x2
@@ -1366,17 +1396,17 @@ Current IOREG MAP
 #define _LLT_OP_VALUE(x)			(((x) >> 30) & 0x3)
 
 
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-//2 RQPN
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+/* 2 RQPN */
 #define _HPQ(x)					((x) & 0xFF)
 #define _LPQ(x)					(((x) & 0xFF) << 8)
 #define _PUBQ(x)					(((x) & 0xFF) << 16)
-#define _NPQ(x)					((x) & 0xFF)			// NOTE: in RQPN_NPQ register
-#define _EPQ(x)					(((x) & 0xFF) << 16)	// NOTE: in RQPN_EPQ register
+#define _NPQ(x)					((x) & 0xFF)			/* NOTE: in RQPN_NPQ register */
+#define _EPQ(x)					(((x) & 0xFF) << 16)	/* NOTE: in RQPN_EPQ register */
 
 
 #define HPQ_PUBLIC_DIS			BIT(24)
@@ -1384,15 +1414,15 @@ Current IOREG MAP
 #define LD_RQPN					BIT(31)
 
 
-//2 TDECTL
+/* 2 TDECTL */
 #define BLK_DESC_NUM_SHIFT			4
 #define BLK_DESC_NUM_MASK			0xF
 
 
-//2 TXDMA_OFFSET_CHK
+/* 2 TXDMA_OFFSET_CHK */
 #define DROP_DATA_EN				BIT(9)
 
-//2 AUTO_LLT
+/* 2 AUTO_LLT */
 #define BIT_SHIFT_TXPKTNUM 24
 #define BIT_MASK_TXPKTNUM 0xff
 #define BIT_TXPKTNUM(x) (((x) & BIT_MASK_TXPKTNUM) << BIT_SHIFT_TXPKTNUM)
@@ -1405,52 +1435,69 @@ Current IOREG MAP
 #define BIT_Tx_OQT_free_space(x) (((x) & BIT_MASK_Tx_OQT_free_space) << BIT_SHIFT_Tx_OQT_free_space)
 
 
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x028Bh	RX DMA Configuration
-//
-//-----------------------------------------------------
-
-//2 REG_RXDMA_CONTROL, 0x0286h
-// Write only. When this bit is set, RXDMA will decrease RX PKT counter by one. Before
-// this bit is polled, FW shall update RXFF_RD_PTR first. This register is write pulse and auto clear.
-//#define RXPKT_RELEASE_POLL			BIT(0)
-// Read only. When RXMA finishes on-going DMA operation, RXMDA will report idle state in 
-// this bit. FW can start releasing packets after RXDMA entering idle mode.
-//#define RXDMA_IDLE					BIT(1)
-// When this bit is set, RXDMA will enter this mode after on-going RXDMA packet to host 
-// completed, and stop DMA packet to host. RXDMA will then report Default: 0;
-//#define RW_RELEASE_EN				BIT(2)
-
-//2 REG_RXPKT_NUM, 0x0284
-#define 	RXPKT_RELEASE_POLL	BIT(16)
+/* -----------------------------------------------------
+ *
+ *	0x0120h ~ 0x0123h	RX DMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define BIT_FS_RXDONE_INT_EN				BIT(16)
+
+
+/* REG_RXPKT_NUM				(Offset 0x0284) */
+#define BIT_RW_RELEASE_EN				BIT(18)
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x028Bh	RX DMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* 2 REG_RXDMA_CONTROL, 0x0286h
+ * Write only. When this bit is set, RXDMA will decrease RX PKT counter by one. Before
+ * this bit is polled, FW shall update RXFF_RD_PTR first. This register is write pulse and auto clear.
+ * #define RXPKT_RELEASE_POLL			BIT(0)
+ * Read only. When RXMA finishes on-going DMA operation, RXMDA will report idle state in
+ * this bit. FW can start releasing packets after RXDMA entering idle mode.
+ * #define RXDMA_IDLE					BIT(1)
+ * When this bit is set, RXDMA will enter this mode after on-going RXDMA packet to host
+ * completed, and stop DMA packet to host. RXDMA will then report Default: 0;
+ * #define RW_RELEASE_EN				BIT(2) */
+
+/* 2 REG_RXPKT_NUM, 0x0284 */
+#define	RXPKT_RELEASE_POLL	BIT(16)
 #define	RXDMA_IDLE				BIT(17)
 #define	RW_RELEASE_EN			BIT(18)
 
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-//2 FWHW_TXQ_CTRL
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+/* 2 FWHW_TXQ_CTRL */
 #define EN_AMPDU_RTY_NEW			BIT(7)
 
 
-//2 SPEC SIFS
+/* 2 SPEC SIFS */
 #define _SPEC_SIFS_CCK(x)			((x) & 0xFF)
 #define _SPEC_SIFS_OFDM(x)			(((x) & 0xFF) << 8)
 
-//2 RL
+/* 2 RL */
 #define	RETRY_LIMIT_SHORT_SHIFT			8
 #define	RETRY_LIMIT_LONG_SHIFT			0
 
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
+#define	RL_VAL_AP					7
+#ifdef CONFIG_RTW_CUSTOMIZE_RLSTA
+#define	RL_VAL_STA					CONFIG_RTW_CUSTOMIZE_RLSTA
+#else
+#define	RL_VAL_STA					0x30
+#endif
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
 
-//2 EDCA setting
+/* 2 EDCA setting */
 #define AC_PARAM_TXOP_LIMIT_OFFSET		16
 #define AC_PARAM_ECW_MAX_OFFSET			12
 #define AC_PARAM_ECW_MIN_OFFSET			8
@@ -1461,7 +1508,7 @@ Current IOREG MAP
 #define _SRL(x)					(((x) & 0x3F) << 8)
 
 
-//2 BCN_CTRL
+/* 2 BCN_CTRL */
 #define EN_TXBCN_RPT			BIT(2)
 #define EN_BCN_FUNCTION		BIT(3)
 #define STOP_BCNQ				BIT(6)
@@ -1471,37 +1518,37 @@ Current IOREG MAP
 #define DIS_BCNQ_SUB			BIT(1)
 #define DIS_TSF_UDT				BIT(4)
 
-// The same function but different bit field.
+/* 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
+/* 2 ACMHWCTRL */
 #define AcmHw_HwEn				BIT(0)
-#define AcmHw_BeqEn			BIT(1)
+#define AcmHw_VoqEn			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)
+#define AcmHw_BeqEn			BIT(3)
+#define AcmHw_VoqStatus		BIT(5)
+#define AcmHw_ViqStatus			BIT(6)
+#define AcmHw_BeqStatus		BIT(7)
 
-//2 //REG_DUAL_TSF_RST (0x553)
+/* 2 */ /* REG_DUAL_TSF_RST (0x553) */
 #define DUAL_TSF_RST_P2P		BIT(4)
 
-//2 // REG_NOA_DESC_SEL (0x5CF)
+/* 2 */ /* REG_NOA_DESC_SEL (0x5CF) */
 #define NOA_DESC_SEL_0			0
 #define NOA_DESC_SEL_1			BIT(4)
 
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
 
-//2 APSD_CTRL
+/* 2 APSD_CTRL */
 #define APSDOFF					BIT(6)
 
-//2 TCR
+/* 2 TCR */
 #define TSFRST					BIT(0)
 #define DIS_GCLK					BIT(1)
 #define PAD_SEL					BIT(2)
@@ -1512,7 +1559,7 @@ Current IOREG MAP
 #define ICV						BIT(10)
 
 
-//2 RCR
+/* 2 RCR */
 #define AAP						BIT(0)
 #define APM						BIT(1)
 #define AM						BIT(2)
@@ -1541,25 +1588,36 @@ Current IOREG MAP
 #define APP_FCS					BIT(31)
 
 
-//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
-#define SCR_TXBCUSEDK			BIT(6)			// Force Tx Broadcast packets Use Default Key
-#define SCR_RXBCUSEDK			BIT(7)			// Force Rx Broadcast packets Use Default Key
+/* 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 */
+#define SCR_TXBCUSEDK			BIT(6)			/* Force Tx Broadcast packets Use Default Key */
+#define SCR_RXBCUSEDK			BIT(7)			/* Force Rx Broadcast packets Use Default Key */
 #define SCR_CHK_KEYID			BIT(8)
 #define SCR_CHK_BMC				BIT(9)			/* add option to support a2+keyid+bcm */
 
-//-----------------------------------------------------
-//
-//	SDIO Bus Specification
-//
-//-----------------------------------------------------
+/*REG_MBIDCAMCFG           (Offset 0x0628/0x62C)*/
+#define BIT_MBIDCAM_POLL		BIT(31)
+#define BIT_MBIDCAM_WT_EN		BIT(30)
+
+#define MBIDCAM_ADDR_MASK		0x1F
+#define MBIDCAM_ADDR_SHIFT		24
+
+#define BIT_MBIDCAM_VALID		BIT(23)
+#define BIT_LSIC_TXOP_EN		BIT(17)
+#define BIT_CTS_EN				BIT(16)
+
+/* -----------------------------------------------------
+ *
+ *	SDIO Bus Specification
+ *
+ * ----------------------------------------------------- */
 
-// I/O bus domain address mapping
+/* I/O bus domain address mapping */
 #define SDIO_LOCAL_BASE		0x10250000
 #define WLAN_IOREG_BASE		0x10260000
 #define FIRMWARE_FIFO_BASE	0x10270000
@@ -1569,139 +1627,139 @@ Current IOREG MAP
 #define TX_EPQ_BASE				0x10350000
 #define RX_RX0FF_BASE			0x10340000
 
-//SDIO host local register space mapping.
+/* SDIO host local register space mapping. */
 #define SDIO_LOCAL_MSK				0x0FFF
-#define WLAN_IOREG_MSK 	             	0x7FFF
-#define WLAN_FIFO_MSK			      	0x1FFF	// Aggregation Length[12:0]
-#define WLAN_RX0FF_MSK			      	0x0003
-
-#define SDIO_WITHOUT_REF_DEVICE_ID	0	// Without reference to the SDIO Device ID
-#define SDIO_LOCAL_DEVICE_ID           		0	// 0b[16], 000b[15:13]
-#define WLAN_TX_HIQ_DEVICE_ID			4	// 0b[16], 100b[15:13]
-#define WLAN_TX_MIQ_DEVICE_ID 		5	// 0b[16], 101b[15:13]
-#define WLAN_TX_LOQ_DEVICE_ID 		6	// 0b[16], 110b[15:13]
-#define WLAN_TX_EXQ_DEVICE_ID		3	// 0b[16], 011b[15:13]
-#define WLAN_RX0FF_DEVICE_ID 			7	// 0b[16], 111b[15:13]
-#define WLAN_IOREG_DEVICE_ID 			8	// 1b[16]
-
-//SDIO Tx Free Page Index
-#define HI_QUEUE_IDX           			0
-#define MID_QUEUE_IDX         			1
-#define LOW_QUEUE_IDX 	      			2
-#define PUBLIC_QUEUE_IDX    			3
-
-#define SDIO_MAX_TX_QUEUE			3		// HIQ, MIQ and LOQ
+#define WLAN_IOREG_MSK		0x7FFF
+#define WLAN_FIFO_MSK			      	0x1FFF	/* Aggregation Length[12:0] */
+#define WLAN_RX0FF_MSK				0x0003
+
+#define SDIO_WITHOUT_REF_DEVICE_ID	0	/* Without reference to the SDIO Device ID */
+#define SDIO_LOCAL_DEVICE_ID           		0	/* 0b[16], 000b[15:13] */
+#define WLAN_TX_HIQ_DEVICE_ID			4	/* 0b[16], 100b[15:13] */
+#define WLAN_TX_MIQ_DEVICE_ID 		5	/* 0b[16], 101b[15:13] */
+#define WLAN_TX_LOQ_DEVICE_ID 		6	/* 0b[16], 110b[15:13] */
+#define WLAN_TX_EXQ_DEVICE_ID		3	/* 0b[16], 011b[15:13] */
+#define WLAN_RX0FF_DEVICE_ID 			7	/* 0b[16], 111b[15:13] */
+#define WLAN_IOREG_DEVICE_ID 			8	/* 1b[16] */
+
+/* SDIO Tx Free Page Index */
+#define HI_QUEUE_IDX			0
+#define MID_QUEUE_IDX			1
+#define LOW_QUEUE_IDX				2
+#define PUBLIC_QUEUE_IDX			3
+
+#define SDIO_MAX_TX_QUEUE			3		/* HIQ, MIQ and LOQ */
 #define SDIO_MAX_RX_QUEUE			1
 
-#define SDIO_REG_TX_CTRL			0x0000 // SDIO Tx Control
-#define SDIO_REG_HIMR				0x0014 // SDIO Host Interrupt Mask
-#define SDIO_REG_HISR				0x0018 // SDIO Host Interrupt Service Routine
-#define SDIO_REG_HCPWM			0x0019 // HCI Current Power Mode
-#define SDIO_REG_RX0_REQ_LEN		0x001C // RXDMA Request Length
-#define SDIO_REG_OQT_FREE_PG		0x001E // OQT Free Page
-#define SDIO_REG_FREE_TXPG			0x0020 // Free Tx Buffer Page
-#define SDIO_REG_HCPWM1			0x0024 // HCI Current Power Mode 1
-#define SDIO_REG_HCPWM2			0x0026 // HCI Current Power Mode 2
-#define SDIO_REG_FREE_TXPG_SEQ	0x0028 // Free Tx Page Sequence
-#define SDIO_REG_HTSFR_INFO		0x0030 // HTSF Informaion
-#define SDIO_REG_HRPWM1			0x0080 // HCI Request Power Mode 1
-#define SDIO_REG_HRPWM2			0x0082 // HCI Request Power Mode 2
-#define SDIO_REG_HPS_CLKR			0x0084 // HCI Power Save Clock
-#define SDIO_REG_HSUS_CTRL			0x0086 // SDIO HCI Suspend Control
-#define SDIO_REG_HIMR_ON			0x0090 //SDIO Host Extension Interrupt Mask Always
-#define SDIO_REG_HISR_ON			0x0091 //SDIO Host Extension Interrupt Status Always
+#define SDIO_REG_TX_CTRL			0x0000 /* SDIO Tx Control */
+#define SDIO_REG_HIMR				0x0014 /* SDIO Host Interrupt Mask */
+#define SDIO_REG_HISR				0x0018 /* SDIO Host Interrupt Service Routine */
+#define SDIO_REG_HCPWM			0x0019 /* HCI Current Power Mode */
+#define SDIO_REG_RX0_REQ_LEN		0x001C /* RXDMA Request Length */
+#define SDIO_REG_OQT_FREE_PG		0x001E /* OQT Free Page */
+#define SDIO_REG_FREE_TXPG			0x0020 /* Free Tx Buffer Page */
+#define SDIO_REG_HCPWM1			0x0024 /* HCI Current Power Mode 1 */
+#define SDIO_REG_HCPWM2			0x0026 /* HCI Current Power Mode 2 */
+#define SDIO_REG_FREE_TXPG_SEQ	0x0028 /* Free Tx Page Sequence */
+#define SDIO_REG_HTSFR_INFO		0x0030 /* HTSF Informaion */
+#define SDIO_REG_HRPWM1			0x0080 /* HCI Request Power Mode 1 */
+#define SDIO_REG_HRPWM2			0x0082 /* HCI Request Power Mode 2 */
+#define SDIO_REG_HPS_CLKR			0x0084 /* HCI Power Save Clock */
+#define SDIO_REG_HSUS_CTRL			0x0086 /* SDIO HCI Suspend Control */
+#define SDIO_REG_HIMR_ON			0x0090 /* SDIO Host Extension Interrupt Mask Always */
+#define SDIO_REG_HISR_ON			0x0091 /* SDIO Host Extension Interrupt Status Always */
 
 #define SDIO_HIMR_DISABLED			0
 
-// RTL8723/RTL8188E SDIO Host Interrupt Mask Register
-#define SDIO_HIMR_RX_REQUEST_MSK		BIT0
-#define SDIO_HIMR_AVAL_MSK			BIT1
-#define SDIO_HIMR_TXERR_MSK			BIT2
-#define SDIO_HIMR_RXERR_MSK			BIT3
-#define SDIO_HIMR_TXFOVW_MSK			BIT4
-#define SDIO_HIMR_RXFOVW_MSK			BIT5
-#define SDIO_HIMR_TXBCNOK_MSK			BIT6
-#define SDIO_HIMR_TXBCNERR_MSK		BIT7
-#define SDIO_HIMR_BCNERLY_INT_MSK		BIT16
-#define SDIO_HIMR_C2HCMD_MSK			BIT17
-#define SDIO_HIMR_CPWM1_MSK			BIT18
-#define SDIO_HIMR_CPWM2_MSK			BIT19
-#define SDIO_HIMR_HSISR_IND_MSK		BIT20
-#define SDIO_HIMR_GTINT3_IND_MSK		BIT21
-#define SDIO_HIMR_GTINT4_IND_MSK		BIT22
-#define SDIO_HIMR_PSTIMEOUT_MSK		BIT23
-#define SDIO_HIMR_OCPINT_MSK			BIT24
-#define SDIO_HIMR_ATIMEND_MSK			BIT25
-#define SDIO_HIMR_ATIMEND_E_MSK		BIT26
-#define SDIO_HIMR_CTWEND_MSK			BIT27
-
-//RTL8188E SDIO Specific
-#define SDIO_HIMR_MCU_ERR_MSK			BIT28
-#define SDIO_HIMR_TSF_BIT32_TOGGLE_MSK		BIT29
-
-// SDIO Host Interrupt Service Routine
-#define SDIO_HISR_RX_REQUEST			BIT0
-#define SDIO_HISR_AVAL					BIT1
-#define SDIO_HISR_TXERR					BIT2
-#define SDIO_HISR_RXERR					BIT3
-#define SDIO_HISR_TXFOVW				BIT4
-#define SDIO_HISR_RXFOVW				BIT5
-#define SDIO_HISR_TXBCNOK				BIT6
-#define SDIO_HISR_TXBCNERR				BIT7
-#define SDIO_HISR_BCNERLY_INT			BIT16
-#define SDIO_HISR_C2HCMD				BIT17
-#define SDIO_HISR_CPWM1				BIT18
-#define SDIO_HISR_CPWM2				BIT19
-#define SDIO_HISR_HSISR_IND			BIT20
-#define SDIO_HISR_GTINT3_IND			BIT21
-#define SDIO_HISR_GTINT4_IND			BIT22
-#define SDIO_HISR_PSTIMEOUT			BIT23
-#define SDIO_HISR_OCPINT				BIT24
-#define SDIO_HISR_ATIMEND				BIT25
-#define SDIO_HISR_ATIMEND_E			BIT26
-#define SDIO_HISR_CTWEND				BIT27
-
-//RTL8188E SDIO Specific
-#define SDIO_HISR_MCU_ERR				BIT28
-#define SDIO_HISR_TSF_BIT32_TOGGLE	BIT29
+/* RTL8723/RTL8188E SDIO Host Interrupt Mask Register */
+#define SDIO_HIMR_RX_REQUEST_MSK		BIT(0)
+#define SDIO_HIMR_AVAL_MSK			BIT(1)
+#define SDIO_HIMR_TXERR_MSK			BIT(2)
+#define SDIO_HIMR_RXERR_MSK			BIT(3)
+#define SDIO_HIMR_TXFOVW_MSK			BIT(4)
+#define SDIO_HIMR_RXFOVW_MSK			BIT(5)
+#define SDIO_HIMR_TXBCNOK_MSK			BIT(6)
+#define SDIO_HIMR_TXBCNERR_MSK		BIT(7)
+#define SDIO_HIMR_BCNERLY_INT_MSK		BIT(16)
+#define SDIO_HIMR_C2HCMD_MSK			BIT(17)
+#define SDIO_HIMR_CPWM1_MSK			BIT(18)
+#define SDIO_HIMR_CPWM2_MSK			BIT(19)
+#define SDIO_HIMR_HSISR_IND_MSK		BIT(20)
+#define SDIO_HIMR_GTINT3_IND_MSK		BIT(21)
+#define SDIO_HIMR_GTINT4_IND_MSK		BIT(22)
+#define SDIO_HIMR_PSTIMEOUT_MSK		BIT(23)
+#define SDIO_HIMR_OCPINT_MSK			BIT(24)
+#define SDIO_HIMR_ATIMEND_MSK			BIT(25)
+#define SDIO_HIMR_ATIMEND_E_MSK		BIT(26)
+#define SDIO_HIMR_CTWEND_MSK			BIT(27)
+
+/* RTL8188E SDIO Specific */
+#define SDIO_HIMR_MCU_ERR_MSK			BIT(28)
+#define SDIO_HIMR_TSF_BIT32_TOGGLE_MSK		BIT(29)
+
+/* SDIO Host Interrupt Service Routine */
+#define SDIO_HISR_RX_REQUEST			BIT(0)
+#define SDIO_HISR_AVAL					BIT(1)
+#define SDIO_HISR_TXERR					BIT(2)
+#define SDIO_HISR_RXERR					BIT(3)
+#define SDIO_HISR_TXFOVW				BIT(4)
+#define SDIO_HISR_RXFOVW				BIT(5)
+#define SDIO_HISR_TXBCNOK				BIT(6)
+#define SDIO_HISR_TXBCNERR				BIT(7)
+#define SDIO_HISR_BCNERLY_INT			BIT(16)
+#define SDIO_HISR_C2HCMD				BIT(17)
+#define SDIO_HISR_CPWM1				BIT(18)
+#define SDIO_HISR_CPWM2				BIT(19)
+#define SDIO_HISR_HSISR_IND			BIT(20)
+#define SDIO_HISR_GTINT3_IND			BIT(21)
+#define SDIO_HISR_GTINT4_IND			BIT(22)
+#define SDIO_HISR_PSTIMEOUT			BIT(23)
+#define SDIO_HISR_OCPINT				BIT(24)
+#define SDIO_HISR_ATIMEND				BIT(25)
+#define SDIO_HISR_ATIMEND_E			BIT(26)
+#define SDIO_HISR_CTWEND				BIT(27)
+
+/* RTL8188E SDIO Specific */
+#define SDIO_HISR_MCU_ERR				BIT(28)
+#define SDIO_HISR_TSF_BIT32_TOGGLE	BIT(29)
 
 #define MASK_SDIO_HISR_CLEAR		(SDIO_HISR_TXERR |\
-									SDIO_HISR_RXERR |\
-									SDIO_HISR_TXFOVW |\
-									SDIO_HISR_RXFOVW |\
-									SDIO_HISR_TXBCNOK |\
-									SDIO_HISR_TXBCNERR |\
-									SDIO_HISR_C2HCMD |\
-									SDIO_HISR_CPWM1 |\
-									SDIO_HISR_CPWM2 |\
-									SDIO_HISR_HSISR_IND |\
-									SDIO_HISR_GTINT3_IND |\
-									SDIO_HISR_GTINT4_IND |\
-									SDIO_HISR_PSTIMEOUT |\
-									SDIO_HISR_OCPINT)
-
-// SDIO HCI Suspend Control Register
-#define HCI_RESUME_PWR_RDY			BIT1
-#define HCI_SUS_CTRL					BIT0
-
-// SDIO Tx FIFO related
-#define SDIO_TX_FREE_PG_QUEUE			4	// The number of Tx FIFO free page
-#define SDIO_TX_FIFO_PAGE_SZ 			128
+		SDIO_HISR_RXERR |\
+		SDIO_HISR_TXFOVW |\
+		SDIO_HISR_RXFOVW |\
+		SDIO_HISR_TXBCNOK |\
+		SDIO_HISR_TXBCNERR |\
+		SDIO_HISR_C2HCMD |\
+		SDIO_HISR_CPWM1 |\
+		SDIO_HISR_CPWM2 |\
+		SDIO_HISR_HSISR_IND |\
+		SDIO_HISR_GTINT3_IND |\
+		SDIO_HISR_GTINT4_IND |\
+		SDIO_HISR_PSTIMEOUT |\
+		SDIO_HISR_OCPINT)
+
+/* SDIO HCI Suspend Control Register */
+#define HCI_RESUME_PWR_RDY			BIT(1)
+#define HCI_SUS_CTRL					BIT(0)
+
+/* SDIO Tx FIFO related */
+#define SDIO_TX_FREE_PG_QUEUE			4	/* The number of Tx FIFO free page */
+#define SDIO_TX_FIFO_PAGE_SZ			128
 
 #ifdef CONFIG_SDIO_HCI
-	#define MAX_TX_AGG_PACKET_NUMBER 	0x8
+	#define MAX_TX_AGG_PACKET_NUMBER	0x8
 #else
-	#define MAX_TX_AGG_PACKET_NUMBER 	0xFF
-	#define MAX_TX_AGG_PACKET_NUMBER_8812 	64
+	#define MAX_TX_AGG_PACKET_NUMBER	0xFF
+	#define MAX_TX_AGG_PACKET_NUMBER_8812	64
 #endif
 
-//-----------------------------------------------------
-//
-//	0xFE00h ~ 0xFE55h	USB Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0xFE00h ~ 0xFE55h	USB Configuration
+ *
+ * ----------------------------------------------------- */
 
-//2 USB Information (0xFE17)
+/* 2 USB Information (0xFE17) */
 #define USB_IS_HIGH_SPEED			0
 #define USB_IS_FULL_SPEED			1
 #define USB_SPEED_MASK				BIT(5)
@@ -1709,72 +1767,77 @@ Current IOREG MAP
 #define USB_NORMAL_SIE_EP_MASK	0xF
 #define USB_NORMAL_SIE_EP_SHIFT	4
 
-//2 Special Option
+/* 2 Special Option */
 #define USB_AGG_EN				BIT(3)
 
-// 0; Use interrupt endpoint to upload interrupt pkt
-// 1; Use bulk endpoint to upload interrupt pkt,
+/* 0; Use interrupt endpoint to upload interrupt pkt
+ * 1; Use bulk endpoint to upload interrupt pkt, */
 #define INT_BULK_SEL			BIT(4)
 
-//2REG_C2HEVT_CLEAR
-#define C2H_EVT_HOST_CLOSE		0x00	// Set by driver and notify FW that the driver has read the C2H command message
-#define C2H_EVT_FW_CLOSE		0xFF	// Set by FW indicating that FW had set the C2H command message and it's not yet read by driver.
-
-
-//2REG_MULTI_FUNC_CTRL(For RTL8723 Only)
-#define WL_HWPDN_EN			BIT0	// Enable GPIO[9] as WiFi HW PDn source
-#define WL_HWPDN_SL			BIT1	// WiFi HW PDn polarity control
-#define WL_FUNC_EN				BIT2	// WiFi function enable
-#define WL_HWROF_EN			BIT3	// Enable GPIO[9] as WiFi RF HW PDn source
-#define BT_HWPDN_EN			BIT16	// Enable GPIO[11] as BT HW PDn source
-#define BT_HWPDN_SL			BIT17	// BT HW PDn polarity control
-#define BT_FUNC_EN				BIT18	// BT function enable
-#define BT_HWROF_EN			BIT19	// Enable GPIO[11] as BT/GPS RF HW PDn source
-#define GPS_HWPDN_EN			BIT20	// Enable GPIO[10] as GPS HW PDn source
-#define GPS_HWPDN_SL			BIT21	// GPS HW PDn polarity control
-#define GPS_FUNC_EN			BIT22	// GPS function enable
-
-//3 REG_LIFECTRL_CTRL
-#define HAL92C_EN_PKT_LIFE_TIME_BK		BIT3
-#define HAL92C_EN_PKT_LIFE_TIME_BE		BIT2
-#define HAL92C_EN_PKT_LIFE_TIME_VI		BIT1
-#define HAL92C_EN_PKT_LIFE_TIME_VO		BIT0
-
-#define HAL92C_MSDU_LIFE_TIME_UNIT		128	// in us, said by Tim.
-
-//2 8192D PartNo.
-#define PARTNO_92D_NIC							(BIT7|BIT6)
-#define PARTNO_92D_NIC_REMARK 				(BIT5|BIT4)
-#define PARTNO_SINGLE_BAND_VS  				BIT3
-#define PARTNO_SINGLE_BAND_VS_REMARK 		BIT1
-#define PARTNO_CONCURRENT_BAND_VC 			(BIT3|BIT2)
-#define PARTNO_CONCURRENT_BAND_VC_REMARK 	(BIT1|BIT0)
-
-//========================================================
-// General definitions
-//========================================================
-
-#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188E(__Adapter)	   ( IS_VENDOR_8188E_I_CUT_SERIES(__Adapter) ? 255 : 175 )
+/* 2REG_C2HEVT_CLEAR */
+#define C2H_EVT_HOST_CLOSE		0x00	/* Set by driver and notify FW that the driver has read the C2H command message */
+#define C2H_EVT_FW_CLOSE		0xFF	/* Set by FW indicating that FW had set the C2H command message and it's not yet read by driver. */
+
+
+/* 2REG_MULTI_FUNC_CTRL(For RTL8723 Only) */
+#define WL_HWPDN_EN			BIT(0)	/* Enable GPIO[9] as WiFi HW PDn source */
+#define WL_HWPDN_SL			BIT(1)	/* WiFi HW PDn polarity control */
+#define WL_FUNC_EN				BIT(2)	/* WiFi function enable */
+#define WL_HWROF_EN			BIT(3)	/* Enable GPIO[9] as WiFi RF HW PDn source */
+#define BT_HWPDN_EN			BIT(16)	/* Enable GPIO[11] as BT HW PDn source */
+#define BT_HWPDN_SL			BIT(17)	/* BT HW PDn polarity control */
+#define BT_FUNC_EN				BIT(18)	/* BT function enable */
+#define BT_HWROF_EN			BIT(19)	/* Enable GPIO[11] as BT/GPS RF HW PDn source */
+#define GPS_HWPDN_EN			BIT(20)	/* Enable GPIO[10] as GPS HW PDn source */
+#define GPS_HWPDN_SL			BIT(21)	/* GPS HW PDn polarity control */
+#define GPS_FUNC_EN			BIT(22)	/* GPS function enable */
+
+/* 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. */
+
+/* 2 8192D PartNo. */
+#define PARTNO_92D_NIC							(BIT7 | BIT6)
+#define PARTNO_92D_NIC_REMARK				(BIT5 | BIT4)
+#define PARTNO_SINGLE_BAND_VS				BIT(3)
+#define PARTNO_SINGLE_BAND_VS_REMARK		BIT(1)
+#define PARTNO_CONCURRENT_BAND_VC			(BIT3 | BIT2)
+#define PARTNO_CONCURRENT_BAND_VC_REMARK	(BIT1 | BIT0)
+
+/* ********************************************************
+ * General definitions
+ * ******************************************************** */
+
+#ifdef CONFIG_USB_HCI
+	#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188E(__Adapter)	(175)
+#else
+	#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188E(__Adapter)	(IS_VENDOR_8188E_I_CUT_SERIES(__Adapter) ? 255 : 175)
+#endif
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8812			255
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8723B		255
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8192C		255
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8703B		255
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_DUAL_MAC	127
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8188F		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188GTV		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8723D		255
 
 #define POLLING_LLT_THRESHOLD				20
 #if defined(CONFIG_RTL8723B) && defined(CONFIG_PCI_HCI)
-#define POLLING_READY_TIMEOUT_COUNT		6000
+	#define POLLING_READY_TIMEOUT_COUNT		6000
 #else
-#define POLLING_READY_TIMEOUT_COUNT		1000
+	#define POLLING_READY_TIMEOUT_COUNT		1000
 #endif
 
 
-// GPIO BIT
-#define	HAL_8812A_HW_GPIO_WPS_BIT	BIT2
-#define	HAL_8192C_HW_GPIO_WPS_BIT	BIT2
-#define	HAL_8192EU_HW_GPIO_WPS_BIT	BIT7
-#define	HAL_8188E_HW_GPIO_WPS_BIT	BIT7
-
-#endif //__HAL_COMMON_H__
+/* GPIO BIT */
+#define	HAL_8812A_HW_GPIO_WPS_BIT	BIT(2)
+#define	HAL_8192C_HW_GPIO_WPS_BIT	BIT(2)
+#define	HAL_8192EU_HW_GPIO_WPS_BIT	BIT(7)
+#define	HAL_8188E_HW_GPIO_WPS_BIT	BIT(7)
 
+#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_data.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_data.h
index b57e4b31daad..2a8e8aff4cb4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_data.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_data.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,123 +12,164 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_DATA_H__
 #define __HAL_DATA_H__
 
-#if 1//def  CONFIG_SINGLE_IMG
+#if 1/* def  CONFIG_SINGLE_IMG */
 
 #include "../hal/phydm/phydm_precomp.h"
 #ifdef CONFIG_BT_COEXIST
-#include <hal_btcoex.h>
+	#include <hal_btcoex.h>
 #endif
 
 #ifdef CONFIG_SDIO_HCI
-#include <hal_sdio.h>
+	#include <hal_sdio.h>
 #endif
 #ifdef CONFIG_GSPI_HCI
-#include <hal_gspi.h>
+	#include <hal_gspi.h>
+#endif
+
+#if defined(CONFIG_RTW_ACS) || defined(CONFIG_BACKGROUND_NOISE_MONITOR)
+#include "../hal/hal_dm_acs.h"
 #endif
-//
-// <Roger_Notes> For RTL8723 WiFi/BT/GPS multi-function configuration. 2010.10.06.
-//
-typedef enum _RT_MULTI_FUNC{
+
+/*
+ * <Roger_Notes> For RTL8723 WiFi/BT/GPS multi-function configuration. 2010.10.06.
+ *   */
+typedef enum _RT_MULTI_FUNC {
 	RT_MULTI_FUNC_NONE	= 0x00,
-	RT_MULTI_FUNC_WIFI 	= 0x01,
-	RT_MULTI_FUNC_BT 		= 0x02,
-	RT_MULTI_FUNC_GPS 	= 0x04,
-}RT_MULTI_FUNC,*PRT_MULTI_FUNC;
-//
-// <Roger_Notes> For RTL8723 WiFi PDn/GPIO polarity control configuration. 2010.10.08.
-//
+	RT_MULTI_FUNC_WIFI	= 0x01,
+	RT_MULTI_FUNC_BT		= 0x02,
+	RT_MULTI_FUNC_GPS	= 0x04,
+} RT_MULTI_FUNC, *PRT_MULTI_FUNC;
+/*
+ * <Roger_Notes> For RTL8723 WiFi PDn/GPIO polarity control configuration. 2010.10.08.
+ *   */
 typedef enum _RT_POLARITY_CTL {
-	RT_POLARITY_LOW_ACT 	= 0,
-	RT_POLARITY_HIGH_ACT 	= 1,	
+	RT_POLARITY_LOW_ACT	= 0,
+	RT_POLARITY_HIGH_ACT	= 1,
 } RT_POLARITY_CTL, *PRT_POLARITY_CTL;
 
-// For RTL8723 regulator mode. by tynli. 2011.01.14.
+/* For RTL8723 regulator mode. by tynli. 2011.01.14. */
 typedef enum _RT_REGULATOR_MODE {
-	RT_SWITCHING_REGULATOR 	= 0,
-	RT_LDO_REGULATOR 			= 1,
+	RT_SWITCHING_REGULATOR	= 0,
+	RT_LDO_REGULATOR			= 1,
 } RT_REGULATOR_MODE, *PRT_REGULATOR_MODE;
 
-//
-// Interface type.
-//
-typedef	enum _INTERFACE_SELECT_PCIE{
-	INTF_SEL0_SOLO_MINICARD			= 0,		// WiFi solo-mCard
-	INTF_SEL1_BT_COMBO_MINICARD		= 1,		// WiFi+BT combo-mCard
-	INTF_SEL2_PCIe						= 2,		// PCIe Card
+/*
+ * Interface type.
+ *   */
+typedef	enum _INTERFACE_SELECT_PCIE {
+	INTF_SEL0_SOLO_MINICARD			= 0,		/* WiFi solo-mCard */
+	INTF_SEL1_BT_COMBO_MINICARD		= 1,		/* WiFi+BT combo-mCard */
+	INTF_SEL2_PCIe						= 2,		/* PCIe Card */
 } INTERFACE_SELECT_PCIE, *PINTERFACE_SELECT_PCIE;
 
 
-typedef	enum _INTERFACE_SELECT_USB{
-	INTF_SEL0_USB 				= 0,		// USB
-	INTF_SEL1_USB_High_Power  	= 1,		// USB with high power PA
-	INTF_SEL2_MINICARD		  	= 2,		// Minicard
-	INTF_SEL3_USB_Solo 		= 3,		// USB solo-Slim module
-	INTF_SEL4_USB_Combo		= 4,		// USB Combo-Slim module
-	INTF_SEL5_USB_Combo_MF	= 5,		// USB WiFi+BT Multi-Function Combo, i.e., Proprietary layout(AS-VAU) which is the same as SDIO card
+typedef	enum _INTERFACE_SELECT_USB {
+	INTF_SEL0_USB 				= 0,		/* USB */
+	INTF_SEL1_USB_High_Power  	= 1,		/* USB with high power PA */
+	INTF_SEL2_MINICARD		  	= 2,		/* Minicard */
+	INTF_SEL3_USB_Solo 		= 3,		/* USB solo-Slim module */
+	INTF_SEL4_USB_Combo		= 4,		/* USB Combo-Slim module */
+	INTF_SEL5_USB_Combo_MF	= 5,		/* USB WiFi+BT Multi-Function Combo, i.e., Proprietary layout(AS-VAU) which is the same as SDIO card */
 } INTERFACE_SELECT_USB, *PINTERFACE_SELECT_USB;
 
-typedef enum _RT_AMPDU_BRUST_MODE{
-	RT_AMPDU_BRUST_NONE 		= 0,
-	RT_AMPDU_BRUST_92D 		= 1,
-	RT_AMPDU_BRUST_88E 		= 2,
-	RT_AMPDU_BRUST_8812_4 	= 3,
-	RT_AMPDU_BRUST_8812_8 	= 4,
-	RT_AMPDU_BRUST_8812_12 	= 5,
+typedef enum _RT_AMPDU_BRUST_MODE {
+	RT_AMPDU_BRUST_NONE		= 0,
+	RT_AMPDU_BRUST_92D		= 1,
+	RT_AMPDU_BRUST_88E		= 2,
+	RT_AMPDU_BRUST_8812_4	= 3,
+	RT_AMPDU_BRUST_8812_8	= 4,
+	RT_AMPDU_BRUST_8812_12	= 5,
 	RT_AMPDU_BRUST_8812_15	= 6,
-	RT_AMPDU_BRUST_8723B	 	= 7,
-}RT_AMPDU_BRUST,*PRT_AMPDU_BRUST_MODE;
-
-/*
-#define CHANNEL_MAX_NUMBER			14+24+21	// 14 is the max channel number
-*/
-#define CHANNEL_GROUP_MAX		(3 + 9)	/* ch1~3, ch4~9, ch10~14 total three groups */
-#define MAX_PG_GROUP			13
+	RT_AMPDU_BRUST_8723B		= 7,
+} RT_AMPDU_BRUST, *PRT_AMPDU_BRUST_MODE;
 
-// Tx Power Limit Table Size
+/* Tx Power Limit Table Size */
 #define MAX_REGULATION_NUM						4
 #define MAX_RF_PATH_NUM_IN_POWER_LIMIT_TABLE	4
 #define MAX_2_4G_BANDWIDTH_NUM					2
 #define MAX_RATE_SECTION_NUM						10
 #define MAX_5G_BANDWIDTH_NUM						4
 
-#define MAX_BASE_NUM_IN_PHY_REG_PG_2_4G			10 //  CCK:1,OFDM:1, HT:4, VHT:4
-#define MAX_BASE_NUM_IN_PHY_REG_PG_5G			9 // OFDM:1, HT:4, VHT:4
-
-
-//###### duplicate code,will move to ODM #########
-//#define IQK_MAC_REG_NUM		4
-//#define IQK_ADDA_REG_NUM		16
+#define MAX_BASE_NUM_IN_PHY_REG_PG_2_4G			10 /* CCK:1, OFDM:1, HT:4, VHT:4 */
+#define MAX_BASE_NUM_IN_PHY_REG_PG_5G			9 /* OFDM:1, HT:4, VHT:4 */
 
-//#define IQK_BB_REG_NUM			10
-#define IQK_BB_REG_NUM_92C	9
-#define IQK_BB_REG_NUM_92D	10
-#define IQK_BB_REG_NUM_test	6
+#ifdef RTW_RX_AGGREGATION
+typedef enum _RX_AGG_MODE {
+	RX_AGG_DISABLE,
+	RX_AGG_DMA,
+	RX_AGG_USB,
+	RX_AGG_MIX
+} RX_AGG_MODE;
 
-#define IQK_Matrix_Settings_NUM_92D	1+24+21
+/* #define MAX_RX_DMA_BUFFER_SIZE	10240 */		/* 10K for 8192C RX DMA buffer */
 
-//#define HP_THERMAL_NUM		8
-//###### duplicate code,will move to ODM #########
-
-#ifdef CONFIG_USB_RX_AGGREGATION
-typedef enum _USB_RX_AGG_MODE{
-	USB_RX_AGG_DISABLE,
-	USB_RX_AGG_DMA,
-	USB_RX_AGG_USB,
-	USB_RX_AGG_MIX
-}USB_RX_AGG_MODE;
+#endif /* RTW_RX_AGGREGATION */
 
-//#define MAX_RX_DMA_BUFFER_SIZE	10240		// 10K for 8192C RX DMA buffer
+/* E-Fuse */
+#ifdef CONFIG_RTL8188E
+	#define EFUSE_MAP_SIZE	512
+#endif
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8192E
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8723B
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8814A
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8703B
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8723D
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8188F
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8188GTV
+	#define EFUSE_MAP_SIZE	512
+#endif
 
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	#define EFUSE_MAX_SIZE	1024
+#elif defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8703B)
+	#define EFUSE_MAX_SIZE	256
+#else
+	#define EFUSE_MAX_SIZE	512
 #endif
+/* end of E-Fuse */
+
+#define Mac_OFDM_OK			0x00000000
+#define Mac_OFDM_Fail		0x10000000
+#define Mac_OFDM_FasleAlarm	0x20000000
+#define Mac_CCK_OK			0x30000000
+#define Mac_CCK_Fail		0x40000000
+#define Mac_CCK_FasleAlarm	0x50000000
+#define Mac_HT_OK			0x60000000
+#define Mac_HT_Fail			0x70000000
+#define Mac_HT_FasleAlarm	0x90000000
+#define Mac_DropPacket		0xA0000000
+
+#ifdef CONFIG_RF_POWER_TRIM
+#if defined(CONFIG_RTL8723B)
+	#define REG_RF_BB_GAIN_OFFSET	0x7f
+	#define RF_GAIN_OFFSET_MASK		0xfffff
+#elif defined(CONFIG_RTL8188E)
+	#define REG_RF_BB_GAIN_OFFSET	0x55
+	#define RF_GAIN_OFFSET_MASK		0xfffff
+#else
+	#define REG_RF_BB_GAIN_OFFSET	0x55
+	#define RF_GAIN_OFFSET_MASK		0xfffff
+#endif /* CONFIG_RTL8723B */
+#endif /*CONFIG_RF_POWER_TRIM*/
 
 /* For store initial value of BB register */
 typedef struct _BB_INIT_REGISTER {
@@ -146,24 +188,6 @@ typedef struct _BB_INIT_REGISTER {
 #define HCI_SUS_ENTERING	3
 #define HCI_SUS_ERR			4
 
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-typedef enum _ACS_OP {
-	ACS_INIT,		/*ACS - Variable init*/
-	ACS_RESET,		/*ACS - NHM Counter reset*/
-	ACS_SELECT,		/*ACS - NHM Counter Statistics */
-} ACS_OP;
-
-typedef enum _ACS_STATE {
-	ACS_DISABLE,
-	ACS_ENABLE,
-} ACS_STATE;
-
-struct auto_chan_sel {
-	ATOMIC_T state;
-	u8	ch; /* previous channel*/
-};
-#endif /*CONFIG_AUTO_CHNL_SEL_NHM*/
-
 #define EFUSE_FILE_UNUSED 0
 #define EFUSE_FILE_FAILED 1
 #define EFUSE_FILE_LOADED 2
@@ -172,18 +196,18 @@ struct auto_chan_sel {
 #define MACADDR_FILE_FAILED 1
 #define MACADDR_FILE_LOADED 2
 
-#define KFREE_FLAG_ON				BIT0
-#define KFREE_FLAG_THERMAL_K_ON		BIT1
+#define MAX_IQK_INFO_BACKUP_CHNL_NUM	5
+#define MAX_IQK_INFO_BACKUP_REG_NUM		10
 
 struct kfree_data_t {
-		u8 flag;
-		s8 bb_gain[BB_GAIN_NUM][RF_PATH_MAX];
+	u8 flag;
+	s8 bb_gain[BB_GAIN_NUM][RF_PATH_MAX];
 
 #ifdef CONFIG_IEEE80211_BAND_5GHZ
-		s8 pa_bias_5g[RF_PATH_MAX];
-		s8 pad_bias_5g[RF_PATH_MAX];
+	s8 pa_bias_5g[RF_PATH_MAX];
+	s8 pad_bias_5g[RF_PATH_MAX];
 #endif
-		s8 thermal;
+	s8 thermal;
 };
 
 bool kfree_data_is_bb_gain_empty(struct kfree_data_t *data);
@@ -195,72 +219,177 @@ struct hal_spec_t {
 	u8 sec_cam_ent_num;
 	u8 sec_cap;
 
-	u8 rfpath_num;	/* used for tx power index path */
+	u8 rfpath_num_2g:4;	/* used for tx power index path */
+	u8 rfpath_num_5g:4;	/* used for tx power index path */
+
 	u8 max_tx_cnt;
-	u8 nss_num;
+	u8 tx_nss_num:4;
+	u8 rx_nss_num:4;
 	u8 band_cap;	/* value of BAND_CAP_XXX */
 	u8 bw_cap;		/* value of BW_CAP_XXX */
+	u8 port_num;
 	u8 proto_cap;	/* value of PROTO_CAP_XXX */
-
 	u8 wl_func;		/* value of WL_FUNC_XXX */
+
+	u8 pg_txpwr_saddr; /* starting address of PG tx power info */
+
+	u8 hci_type;	/* value of HCI Type */
 };
 
-#define HAL_SPEC_CHK_RF_PATH(_spec, _path) ((_spec)->rfpath_num > (_path))
+#define HAL_SPEC_CHK_RF_PATH_2G(_spec, _path) ((_spec)->rfpath_num_2g > (_path))
+#define HAL_SPEC_CHK_RF_PATH_5G(_spec, _path) ((_spec)->rfpath_num_5g > (_path))
+#define HAL_SPEC_CHK_RF_PATH(_spec, _band, _path) ( \
+	_band == BAND_ON_2_4G ? HAL_SPEC_CHK_RF_PATH_2G(_spec, _path) : \
+	_band == BAND_ON_5G ? HAL_SPEC_CHK_RF_PATH_5G(_spec, _path) : 0)
+
 #define HAL_SPEC_CHK_TX_CNT(_spec, _cnt_idx) ((_spec)->max_tx_cnt > (_cnt_idx))
 
+#ifdef CONFIG_PHY_CAPABILITY_QUERY
+struct phy_spec_t {
+	u32 trx_cap;
+	u32 stbc_cap;
+	u32 ldpc_cap;
+	u32 txbf_param;
+	u32 txbf_cap;
+};
+#endif
+struct hal_iqk_reg_backup {
+	u8 central_chnl;
+	u8 bw_mode;
+	u32 reg_backup[MAX_RF_PATH][MAX_IQK_INFO_BACKUP_REG_NUM];
+};
+
+
+typedef struct hal_p2p_ps_para {
+	/*DW0*/
+	u8  offload_en:1;
+	u8  role:1;
+	u8  ctwindow_en:1;
+	u8  noa_en:1;
+	u8  noa_sel:1;
+	u8  all_sta_sleep:1;
+	u8  discovery:1;
+	u8  rsvd2:1;
+	u8  p2p_port_id;
+	u8  p2p_group;
+	u8  p2p_macid;
+
+	/*DW1*/
+	u8 ctwindow_length;
+	u8 rsvd3;
+	u8 rsvd4;
+	u8 rsvd5;
+
+	/*DW2*/
+	u32 noa_duration_para;
+
+	/*DW3*/
+	u32 noa_interval_para;
+
+	/*DW4*/
+	u32 noa_start_time_para;
+
+	/*DW5*/
+	u32 noa_count_para;
+} HAL_P2P_PS_PARA, *PHAL_P2P_PS_PARA;
+
+#define TXPWR_LMT_RS_CCK	0
+#define TXPWR_LMT_RS_OFDM	1
+#define TXPWR_LMT_RS_HT		2
+#define TXPWR_LMT_RS_VHT	3
+#define TXPWR_LMT_RS_NUM	4
+
+#define TXPWR_LMT_RS_NUM_2G	4 /* CCK, OFDM, HT, VHT */
+#define TXPWR_LMT_RS_NUM_5G	3 /* OFDM, HT, VHT */
+
+#ifdef CONFIG_TXPWR_LIMIT
+extern const char *const _txpwr_lmt_rs_str[];
+#define txpwr_lmt_rs_str(rs) (((rs) >= TXPWR_LMT_RS_NUM) ? _txpwr_lmt_rs_str[TXPWR_LMT_RS_NUM] : _txpwr_lmt_rs_str[(rs)])
+
+struct txpwr_lmt_ent {
+	_list list;
+
+	s8 lmt_2g[MAX_2_4G_BANDWIDTH_NUM]
+		[TXPWR_LMT_RS_NUM_2G]
+		[CENTER_CH_2G_NUM]
+		[MAX_TX_COUNT];
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	s8 lmt_5g[MAX_5G_BANDWIDTH_NUM]
+		[TXPWR_LMT_RS_NUM_5G]
+		[CENTER_CH_5G_ALL_NUM]
+		[MAX_TX_COUNT];
+#endif
+
+	char regd_name[0];
+};
+#endif /* CONFIG_TXPWR_LIMIT */
+
 typedef struct hal_com_data {
-	HAL_VERSION			VersionID;
-	RT_MULTI_FUNC		MultiFunc; // For multi-function consideration.
-	RT_POLARITY_CTL		PolarityCtl; // For Wifi PDn Polarity control.
-	RT_REGULATOR_MODE	RegulatorMode; // switching regulator or LDO
+	HAL_VERSION			version_id;
+	RT_MULTI_FUNC		MultiFunc; /* For multi-function consideration. */
+	RT_POLARITY_CTL		PolarityCtl; /* For Wifi PDn Polarity control. */
+	RT_REGULATOR_MODE	RegulatorMode; /* switching regulator or LDO */
 	u8	hw_init_completed;
 	/****** FW related ******/
-	u16	FirmwareVersion;
+	u32 firmware_size;
+	u16 firmware_version;
 	u16	FirmwareVersionRev;
-	u16	FirmwareSubVersion;
+	u16 firmware_sub_version;
 	u16	FirmwareSignature;
-	u8	RegFWOffload;	
+	u8	RegFWOffload;
+	u8	bFWReady;
+	u8	bBTFWReady;
 	u8	fw_ractrl;
-	u8	FwRsvdPageStartOffset; /* 2010.06.23. Added by tynli. Reserve page start offset except beacon in TxQ.*/
 	u8	LastHMEBoxNum;	/* H2C - for host message to fw */
 
 	/****** current WIFI_PHY values ******/
 	WIRELESS_MODE	CurrentWirelessMode;
-	CHANNEL_WIDTH	CurrentChannelBW;
-	BAND_TYPE		CurrentBandType;	/* 0:2.4G, 1:5G */
+	enum channel_width current_channel_bw;
+	BAND_TYPE		current_band_type;	/* 0:2.4G, 1:5G */
 	BAND_TYPE		BandSet;
-	u8				CurrentChannel;
+	u8				current_channel;
 	u8				cch_20;
 	u8				cch_40;
 	u8				cch_80;
 	u8				CurrentCenterFrequencyIndex1;
 	u8				nCur40MhzPrimeSC;	/* Control channel sub-carrier */
 	u8				nCur80MhzPrimeSC;   /* used for primary 40MHz of 80MHz mode */
-	BOOLEAN 		bSwChnlAndSetBWInProgress;	
+	BOOLEAN		bSwChnlAndSetBWInProgress;
 	u8				bDisableSWChannelPlan; /* flag of disable software change channel plan	 */
-	u16				BasicRateSet;	
+	u16				BasicRateSet;
 	u32				ReceiveConfig;
+	u32				rcr_backup; /* used for switching back from monitor mode */
+	u8				rx_tsf_addr_filter_config; /* for 8822B/8821C USE */
 	BOOLEAN			bSwChnl;
 	BOOLEAN			bSetChnlBW;
+	BOOLEAN			bSWToBW40M;
+	BOOLEAN			bSWToBW80M;
 	BOOLEAN			bChnlBWInitialized;
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
+	u32				BackUp_BB_REG_4_2nd_CCA[3];
+
+#ifdef CONFIG_RTW_ACS
 	struct auto_chan_sel acs;
 #endif
+#ifdef CONFIG_BCN_RECOVERY
+	u8 issue_bcn_fail;
+#endif /*CONFIG_BCN_RECOVERY*/
+
 	/****** rf_ctrl *****/
 	u8	rf_chip;
-	u8	rf_type;
+	u8	rf_type;	/*enum rf_type*/
 	u8	PackageType;
 	u8	NumTotalRFPath;
+	u8	antenna_test;
 
 	/****** Debug ******/
 	u16	ForcedDataRate;	/* Force Data Rate. 0: Auto, 0x02: 1M ~ 0x6C: 54M. */
-	u8	u1ForcedIgiLb;	/* forced IGI lower bound */	
 	u8	bDumpRxPkt;
 	u8	bDumpTxPkt;
-	u8 	bDisableTXPowerTraining;
+	u8	dis_turboedca;
 
-	
-	/****** EEPROM setting.******/	
+
+	/****** EEPROM setting.******/
 	u8	bautoload_fail_flag;
 	u8	efuse_file_status;
 	u8	macaddr_file_status;
@@ -268,38 +397,45 @@ typedef struct hal_com_data {
 	u8	efuse_eeprom_data[EEPROM_MAX_SIZE]; /*92C:256bytes, 88E:512bytes, we use union set (512bytes)*/
 	u8	InterfaceSel; /* board type kept in eFuse */
 	u16	CustomerID;
-	
+
 	u16	EEPROMVID;
 	u16	EEPROMSVID;
 #ifdef CONFIG_USB_HCI
+	u8	EEPROMUsbSwitch;
 	u16	EEPROMPID;
 	u16	EEPROMSDID;
 #endif
 #ifdef CONFIG_PCI_HCI
- 	u16	EEPROMDID;
-	u16	EEPROMSMID;	
+	u16	EEPROMDID;
+	u16	EEPROMSMID;
 #endif
 
 	u8	EEPROMCustomerID;
 	u8	EEPROMSubCustomerID;
 	u8	EEPROMVersion;
 	u8	EEPROMRegulatory;
-	u8	EEPROMThermalMeter;
-	u8	EEPROMBluetoothCoexist;	
+	u8	eeprom_thermal_meter;
+	u8	EEPROMBluetoothCoexist;
 	u8	EEPROMBluetoothType;
 	u8	EEPROMBluetoothAntNum;
 	u8	EEPROMBluetoothAntIsolation;
 	u8	EEPROMBluetoothRadioShared;
 	u8	EEPROMMACAddr[ETH_ALEN];
-	
-#ifdef CONFIG_RF_GAIN_OFFSET
+	u8	tx_bbswing_24G;
+	u8	tx_bbswing_5G;
+	u8	efuse0x3d7;	/* efuse[0x3D7] */
+	u8	efuse0x3d8;	/* efuse[0x3D8] */
+
+#ifdef CONFIG_RF_POWER_TRIM
 	u8	EEPROMRFGainOffset;
 	u8	EEPROMRFGainVal;
 	struct kfree_data_t kfree_data;
-#endif /*CONFIG_RF_GAIN_OFFSET*/
+#endif /*CONFIG_RF_POWER_TRIM*/
 
-#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B)
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || \
+	defined(CONFIG_RTL8723D)
 	u8	adjuseVoltageVal;
+	u8	need_restore;
 #endif
 	u8	EfuseUsedPercentage;
 	u16	EfuseUsedBytes;
@@ -325,146 +461,84 @@ typedef struct hal_com_data {
 	s8	BW80_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];
 #endif
 
-	u8	Regulation2_4G;
-	u8	Regulation5G;
-
-	/********************************
-	*	TX power by rate table at most 4RF path.
-	*	The register is 
-	*
-	*	VHT TX power by rate off setArray = 
-	*	Band:-2G&5G = 0 / 1
-	*	RF: at most 4*4 = ABCD=0/1/2/3
-	*	CCK=0 OFDM=1/2 HT-MCS 0-15=3/4/56 VHT=7/8/9/10/11			
-	**********************************/
-	u8	TxPwrByRateTable;
-	u8	TxPwrByRateBand;
+	u8 txpwr_by_rate_undefined_band_path[TX_PWR_BY_RATE_NUM_BAND]
+		[TX_PWR_BY_RATE_NUM_RF];
+
 	s8	TxPwrByRateOffset[TX_PWR_BY_RATE_NUM_BAND]
-						 [TX_PWR_BY_RATE_NUM_RF]
-						 [TX_PWR_BY_RATE_NUM_RF]
-						 [TX_PWR_BY_RATE_NUM_RATE];
-	//---------------------------------------------------------------------------------//
+		[TX_PWR_BY_RATE_NUM_RF]
+		[TX_PWR_BY_RATE_NUM_RATE];
 
-	/*
-	//2 Power Limit Table 
-	u8	TxPwrLevelCck[RF_PATH_MAX_92C_88E][CHANNEL_MAX_NUMBER];
-	u8	TxPwrLevelHT40_1S[RF_PATH_MAX_92C_88E][CHANNEL_MAX_NUMBER];	// For HT 40MHZ pwr
-	u8	TxPwrLevelHT40_2S[RF_PATH_MAX_92C_88E][CHANNEL_MAX_NUMBER];	// For HT 40MHZ pwr
-	s8	TxPwrHt20Diff[RF_PATH_MAX_92C_88E][CHANNEL_MAX_NUMBER];// HT 20<->40 Pwr diff
-	u8	TxPwrLegacyHtDiff[RF_PATH_MAX_92C_88E][CHANNEL_MAX_NUMBER];// For HT<->legacy pwr diff
-	*/
-
-	u8 tx_pwr_lmt_5g_20_40_ref;
-
-	// Power Limit Table for 2.4G
-	s8	TxPwrLimit_2_4G[MAX_REGULATION_NUM]
-						[MAX_2_4G_BANDWIDTH_NUM]
-						[MAX_RATE_SECTION_NUM]
-						[CENTER_CH_2G_NUM]
-						[MAX_RF_PATH];
-
-	// Power Limit Table for 5G
-	s8	TxPwrLimit_5G[MAX_REGULATION_NUM]
-						[MAX_5G_BANDWIDTH_NUM]
-						[MAX_RATE_SECTION_NUM]
-						[CENTER_CH_5G_ALL_NUM]
-						[MAX_RF_PATH];
-
-	
-	// Store the original power by rate value of the base of each rate section of rf path A & B
+	/* Store the original power by rate value of the base rate for each rate section and rf path */
 	u8	TxPwrByRateBase2_4G[TX_PWR_BY_RATE_NUM_RF]
-						[TX_PWR_BY_RATE_NUM_RF]
-						[MAX_BASE_NUM_IN_PHY_REG_PG_2_4G];
+		[MAX_BASE_NUM_IN_PHY_REG_PG_2_4G];
 	u8	TxPwrByRateBase5G[TX_PWR_BY_RATE_NUM_RF]
-						[TX_PWR_BY_RATE_NUM_RF]
-						[MAX_BASE_NUM_IN_PHY_REG_PG_5G];
+		[MAX_BASE_NUM_IN_PHY_REG_PG_5G];
 
 	u8	txpwr_by_rate_loaded:1;
 	u8	txpwr_by_rate_from_file:1;
 	u8	txpwr_limit_loaded:1;
 	u8	txpwr_limit_from_file:1;
+	u8	rf_power_tracking_type;
+
+	/* Read/write are allow for following hardware information variables	 */
+	u8	crystal_cap;
 
-	// For power group
-	/*
-	u8	PwrGroupHT20[RF_PATH_MAX_92C_88E][CHANNEL_MAX_NUMBER];
-	u8	PwrGroupHT40[RF_PATH_MAX_92C_88E][CHANNEL_MAX_NUMBER];
-	*/
-	u8	PGMaxGroup;
-	
-	// The current Tx Power Level
-	u8	CurrentCckTxPwrIdx;
-	u8	CurrentOfdm24GTxPwrIdx;
-	u8	CurrentBW2024GTxPwrIdx;
-	u8	CurrentBW4024GTxPwrIdx;
-	
-	// Read/write are allow for following hardware information variables	
-	u8	pwrGroupCnt;
-	u32	MCSTxPowerLevelOriginalOffset[MAX_PG_GROUP][16];
-	u32	CCKTxPowerLevelOriginalOffset;
-
-	u8	CrystalCap;
-	
 	u8	PAType_2G;
 	u8	PAType_5G;
 	u8	LNAType_2G;
 	u8	LNAType_5G;
 	u8	ExternalPA_2G;
 	u8	ExternalLNA_2G;
-	u8	ExternalPA_5G;
-	u8	ExternalLNA_5G;
+	u8	external_pa_5g;
+	u8	external_lna_5g;
 	u16	TypeGLNA;
 	u16	TypeGPA;
 	u16	TypeALNA;
 	u16	TypeAPA;
-	u16	RFEType;
+	u16	rfe_type;
 
 	u8	bLedOpenDrain; /* Support Open-drain arrangement for controlling the LED. Added by Roger, 2009.10.16. */
-	u32	AcParam_BE; /* Original parameter for BE, use for EDCA turbo.	*/
-
-	BB_REGISTER_DEFINITION_T	PHYRegDef[MAX_RF_PATH];	//Radio A/B/C/D
+	u32	ac_param_be; /* Original parameter for BE, use for EDCA turbo.	*/
+	u8	is_turbo_edca;
+	u8	prv_traffic_idx;
+	BB_REGISTER_DEFINITION_T	PHYRegDef[MAX_RF_PATH];	/* Radio A/B/C/D */
 
 	u32	RfRegChnlVal[MAX_RF_PATH];
 
-	//RDG enable
+	/* RDG enable */
 	BOOLEAN	 bRDGEnable;
 
-	u8	RegTxPause;
-	// Beacon function related global variable.
-	u8	RegBcnCtrlVal;
-	u8	RegFwHwTxQCtrl;
-	u8	RegReg542;
-	u8	RegCR_1;
-	u8	Reg837;
-	u16	RegRRSR;
-	
+	u16 RegRRSR;
 	/****** antenna diversity ******/
-	u8	CurAntenna;
 	u8	AntDivCfg;
+	u8	with_extenal_ant_switch;
+	u8	b_fix_tx_ant;
 	u8	AntDetection;
 	u8	TRxAntDivType;
-	u8	ant_path; //for 8723B s0/s1 selection	
-	u32	AntennaTxPath;					/* Antenna path Tx */
+	u8	ant_path; /* for 8723B s0/s1 selection	 */
+	u32	antenna_tx_path;					/* Antenna path Tx */
 	u32	AntennaRxPath;					/* Antenna path Rx */
+	u8 sw_antdiv_bl_state;
 
 	/******** PHY DM & DM Section **********/
-	u8			DM_Type;
-	_lock		IQKSpinLock;	
+	_lock		IQKSpinLock;
 	u8			INIDATA_RATE[MACID_NUM_SW_LIMIT];
-	/* Upper and Lower Signal threshold for Rate Adaptive*/	
-	int			EntryMinUndecoratedSmoothedPWDB;
-	int			EntryMaxUndecoratedSmoothedPWDB;
-	int			MinUndecoratedPWDBForDM;
-	DM_ODM_T	odmpriv;	
+
+	struct dm_struct	 odmpriv;
+	u64			bk_rf_ability;
 	u8			bIQKInitialized;
-	u8 			bNeedIQK;
+	u8			bNeedIQK;
+	u8			neediqk_24g;
+	u8			IQK_MP_Switch;
+	u8			bScanInProcess;
 	/******** PHY DM & DM Section **********/
 
 
 
-	// 2010/08/09 MH Add CU power down mode.
+	/* 2010/08/09 MH Add CU power down mode. */
 	BOOLEAN		pwrdown;
 
-	// Add for dual MAC  0--Mac0 1--Mac1
+	/* Add for dual MAC  0--Mac0 1--Mac1 */
 	u32	interfaceIndex;
 
 #ifdef CONFIG_P2P
@@ -473,120 +547,153 @@ typedef struct hal_com_data {
 	/* Auto FSM to Turn On, include clock, isolation, power control for MAC only */
 	u8	bMacPwrCtrlOn;
 	u8 hci_sus_state;
-	
+
 	u8	RegIQKFWOffload;
-	struct submit_ctx 	iqk_sctx;
+	struct submit_ctx	iqk_sctx;
+	u8 ch_switch_offload;
+	struct submit_ctx chsw_sctx;
 
-	RT_AMPDU_BRUST		AMPDUBurstMode; //92C maybe not use, but for compile successfully
+	RT_AMPDU_BRUST		AMPDUBurstMode; /* 92C maybe not use, but for compile successfully */
 
 	u8	OutEpQueueSel;
-	u8	OutEpNumber;	
-
-#if defined (CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	//
-	// For SDIO Interface HAL related
-	//
-
-	//
-	// SDIO ISR Related
-	//
-//	u32			IntrMask[1];
-//	u32			IntrMaskToSet[1];
-//	LOG_INTERRUPT		InterruptLog;
+	u8	OutEpNumber;
+
+#ifdef RTW_RX_AGGREGATION
+	RX_AGG_MODE rxagg_mode;
+
+	/* For RX Aggregation DMA Mode */
+	u8 rxagg_dma_size;
+	u8 rxagg_dma_timeout;
+#endif /* RTW_RX_AGGREGATION */
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	/*  */
+	/* For SDIO Interface HAL related */
+	/*  */
+
+	/*  */
+	/* SDIO ISR Related */
+	/*
+	*	u32			IntrMask[1];
+	*	u32			IntrMaskToSet[1];
+	*	LOG_INTERRUPT		InterruptLog; */
 	u32			sdio_himr;
 	u32			sdio_hisr;
-
-	//
-	// SDIO Tx FIFO related.
-	//
-	// HIQ, MID, LOW, PUB free pages; padapter->xmitpriv.free_txpg
+#ifndef RTW_HALMAC
+	/*  */
+	/* SDIO Tx FIFO related. */
+	/*  */
+	/* HIQ, MID, LOW, PUB free pages; padapter->xmitpriv.free_txpg */
 	u8			SdioTxFIFOFreePage[SDIO_TX_FREE_PG_QUEUE];
 	_lock		SdioTxFIFOFreePageLock;
 	u8			SdioTxOQTMaxFreeSpace;
 	u8			SdioTxOQTFreeSpace;
+#else /* RTW_HALMAC */
+	u16			SdioTxOQTFreeSpace;
+#endif /* RTW_HALMAC */
 
-	//
-	// SDIO Rx FIFO related.
-	//
+	/*  */
+	/* SDIO Rx FIFO related. */
+	/*  */
 	u8			SdioRxFIFOCnt;
 	u16			SdioRxFIFOSize;
 
-	u32			sdio_tx_max_len[SDIO_MAX_TX_QUEUE];// H, N, L, used for sdio tx aggregation max length per queue
-#endif //CONFIG_SDIO_HCI
+#ifndef RTW_HALMAC
+	u32			sdio_tx_max_len[SDIO_MAX_TX_QUEUE];/* H, N, L, used for sdio tx aggregation max length per queue */
+#else
+#ifdef CONFIG_RTL8821C
+	u16			tx_high_page;
+	u16			tx_low_page;
+	u16			tx_normal_page;
+	u16			tx_extra_page;
+	u16			tx_pub_page;
+	u8			max_oqt_size;
+	#ifdef XMIT_BUF_SIZE
+	u32			max_xmit_size_vovi;
+	u32			max_xmit_size_bebk;
+	#endif /*XMIT_BUF_SIZE*/
+	u16			max_xmit_page;
+	u16			max_xmit_page_vo;
+	u16			max_xmit_page_vi;
+	u16			max_xmit_page_be;
+	u16			max_xmit_page_bk;
+
+#endif /*#ifdef CONFIG_RTL8821C*/
+#endif /* !RTW_HALMAC */
+#endif /* CONFIG_SDIO_HCI */
 
 #ifdef CONFIG_USB_HCI
 
-	// 2010/12/10 MH Add for USB aggreation mode dynamic shceme.
+	/* 2010/12/10 MH Add for USB aggreation mode dynamic shceme. */
 	BOOLEAN		UsbRxHighSpeedMode;
 	BOOLEAN		UsbTxVeryHighSpeedMode;
 	u32			UsbBulkOutSize;
 	BOOLEAN		bSupportUSB3;
+	u8			usb_intf_start;
 
-	// Interrupt relatd register information.
-	u32			IntArray[3];//HISR0,HISR1,HSISR
+	/* Interrupt relatd register information. */
+	u32			IntArray[3];/* HISR0,HISR1,HSISR */
 	u32			IntrMask[3];
-	u8			C2hArray[16];
-	#ifdef CONFIG_USB_TX_AGGREGATION
+#ifdef CONFIG_USB_TX_AGGREGATION
 	u8			UsbTxAggMode;
 	u8			UsbTxAggDescNum;
-	#endif // CONFIG_USB_TX_AGGREGATION
-	
-	#ifdef CONFIG_USB_RX_AGGREGATION
-	u16			HwRxPageSize;				// Hardware setting
-	u32			MaxUsbRxAggBlock;
+#endif /* CONFIG_USB_TX_AGGREGATION */
 
-	USB_RX_AGG_MODE	UsbRxAggMode;
-	u8			UsbRxAggBlockCount;		/* FOR USB Mode, USB Block count. Block size is 512-byte in hight speed and 64-byte in full speed */
-	u8			UsbRxAggBlockTimeout;
-	u8			UsbRxAggPageCount;			/* FOR DMA Mode, 8192C DMA page count*/
-	u8			UsbRxAggPageTimeout;
+#ifdef CONFIG_USB_RX_AGGREGATION
+	u16			HwRxPageSize;				/* Hardware setting */
 
-	u8			RegAcUsbDmaSize;
-	u8			RegAcUsbDmaTime;
-	#endif//CONFIG_USB_RX_AGGREGATION
-#endif //CONFIG_USB_HCI
+	/* For RX Aggregation USB Mode */
+	u8			rxagg_usb_size;
+	u8			rxagg_usb_timeout;
+#endif/* CONFIG_USB_RX_AGGREGATION */
+#endif /* CONFIG_USB_HCI */
 
 
 #ifdef CONFIG_PCI_HCI
-	//
-	// EEPROM setting.
-	//
+	/*  */
+	/* EEPROM setting. */
+	/*  */
 	u32			TransmitConfig;
 	u32			IntrMaskToSet[2];
-	u32			IntArray[2];
-	u32			IntrMask[2];
+	u32			IntArray[4];
+	u32			IntrMask[4];
 	u32			SysIntArray[1];
 	u32			SysIntrMask[1];
 	u32			IntrMaskReg[2];
-	u32			IntrMaskDefault[2];
+	u32			IntrMaskDefault[4];
 
-	BOOLEAN	 	bL1OffSupport;
-	BOOLEAN 	bSupportBackDoor;
+	BOOLEAN		bL1OffSupport;
+	BOOLEAN	bSupportBackDoor;
+	u32			pci_backdoor_ctrl;
 
 	u8			bDefaultAntenna;
-	
+
 	u8			bInterruptMigration;
 	u8			bDisableTxInt;
 
-	u16			RxTag;	
-#endif //CONFIG_PCI_HCI
-	
+	u16			RxTag;
+#ifdef CONFIG_PCI_DYNAMIC_ASPM
+	BOOLEAN		bAspmL1LastIdle;
+#endif
+#endif /* CONFIG_PCI_HCI */
+
 
 #ifdef DBG_CONFIG_ERROR_DETECT
 	struct sreset_priv srestpriv;
-#endif //#ifdef DBG_CONFIG_ERROR_DETECT
+#endif /* #ifdef DBG_CONFIG_ERROR_DETECT */
 
 #ifdef CONFIG_BT_COEXIST
-	// For bluetooth co-existance
+	/* For bluetooth co-existance */
 	BT_COEXIST		bt_coexist;
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
-#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || defined(CONFIG_RTL8188F)
-	#ifndef CONFIG_PCI_HCI	// mutual exclusive with PCI -- so they're SDIO and GSPI 
-	// Interrupt relatd register information.
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) \
+	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8723D)
+#ifndef CONFIG_PCI_HCI	/* mutual exclusive with PCI -- so they're SDIO and GSPI */
+	/* Interrupt relatd register information. */
 	u32			SysIntrStatus;
 	u32			SysIntrMask;
-	#endif
+#endif
 #endif /*endif CONFIG_RTL8723B	*/
 
 #ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
@@ -612,11 +719,13 @@ typedef struct hal_com_data {
 #endif
 
 #ifdef CONFIG_BACKGROUND_NOISE_MONITOR
-	s16 noise[ODM_MAX_CHANNEL_NUM];
+	struct noise_monitor nm;
 #endif
 
 	struct hal_spec_t hal_spec;
-
+#ifdef CONFIG_PHY_CAPABILITY_QUERY
+	struct phy_spec_t phy_spec;
+#endif
 	u8	RfKFreeEnable;
 	u8	RfKFree_ch_group;
 	BOOLEAN				bCCKinCH14;
@@ -627,36 +736,309 @@ typedef struct hal_com_data {
 #endif
 	u32 RxGainOffset[4]; /*{2G, 5G_Low, 5G_Middle, G_High}*/
 	u8 BackUp_IG_REG_4_Chnl_Section[4]; /*{A,B,C,D}*/
-} HAL_DATA_COMMON, *PHAL_DATA_COMMON;
 
+	struct hal_iqk_reg_backup iqk_reg_backup[MAX_IQK_INFO_BACKUP_CHNL_NUM];
 
+#ifdef RTW_HALMAC
+	u8 drv_rsvd_page_number;
+#endif
+
+#ifdef CONFIG_BEAMFORMING
+	u8 backup_snd_ptcl_ctrl;
+#ifdef RTW_BEAMFORMING_VERSION_2
+	struct beamforming_info beamforming_info;
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+
+	u8 not_xmitframe_fw_dl; /*not use xmitframe to download fw*/
+	u8 phydm_op_mode;
+
+	u8 in_cta_test;
+
+#ifdef CONFIG_RTW_LED
+	struct led_priv led;
+#endif
+} HAL_DATA_COMMON, *PHAL_DATA_COMMON;
 
 typedef struct hal_com_data HAL_DATA_TYPE, *PHAL_DATA_TYPE;
-#define GET_HAL_DATA(__pAdapter)			((HAL_DATA_TYPE *)((__pAdapter)->HalData))
+#define GET_HAL_DATA(__pAdapter)			((HAL_DATA_TYPE *)(((struct _ADAPTER*)__pAdapter)->HalData))
 #define GET_HAL_SPEC(__pAdapter)			(&(GET_HAL_DATA((__pAdapter))->hal_spec))
-#define GET_ODM(__pAdapter)			(&(GET_HAL_DATA((__pAdapter))->odmpriv))
+#define adapter_to_led(adapter) (&(GET_HAL_DATA(adapter)->led))
 
-#define GET_HAL_RFPATH_NUM(__pAdapter)		(((HAL_DATA_TYPE *)((__pAdapter)->HalData))->NumTotalRFPath )
-#define RT_GetInterfaceSelection(_Adapter) 		(GET_HAL_DATA(_Adapter)->InterfaceSel)
+#define GET_HAL_RFPATH_NUM(__pAdapter)		(((HAL_DATA_TYPE *)((__pAdapter)->HalData))->NumTotalRFPath)
+#define RT_GetInterfaceSelection(_Adapter)		(GET_HAL_DATA(_Adapter)->InterfaceSel)
 #define GET_RF_TYPE(__pAdapter)				(GET_HAL_DATA(__pAdapter)->rf_type)
 #define GET_KFREE_DATA(_adapter) (&(GET_HAL_DATA((_adapter))->kfree_data))
 
-#define	SUPPORT_HW_RADIO_DETECT(Adapter)	(	RT_GetInterfaceSelection(Adapter) == INTF_SEL2_MINICARD ||\
-												RT_GetInterfaceSelection(Adapter) == INTF_SEL3_USB_Solo ||\
-												RT_GetInterfaceSelection(Adapter) == INTF_SEL4_USB_Combo)
+#define	SUPPORT_HW_RADIO_DETECT(Adapter)	(RT_GetInterfaceSelection(Adapter) == INTF_SEL2_MINICARD || \
+		RT_GetInterfaceSelection(Adapter) == INTF_SEL3_USB_Solo || \
+		RT_GetInterfaceSelection(Adapter) == INTF_SEL4_USB_Combo)
 
-#define get_hal_mac_addr(adapter) 				(GET_HAL_DATA(adapter)->EEPROMMACAddr)
-#define is_boot_from_eeprom(adapter) 			(GET_HAL_DATA(adapter)->EepromOrEfuse)
+#define get_hal_mac_addr(adapter)				(GET_HAL_DATA(adapter)->EEPROMMACAddr)
+#define is_boot_from_eeprom(adapter)			(GET_HAL_DATA(adapter)->EepromOrEfuse)
 #define rtw_get_hw_init_completed(adapter)		(GET_HAL_DATA(adapter)->hw_init_completed)
+#define rtw_set_hw_init_completed(adapter, cmp)	(GET_HAL_DATA(adapter)->hw_init_completed = cmp)
 #define rtw_is_hw_init_completed(adapter)		(GET_HAL_DATA(adapter)->hw_init_completed == _TRUE)
 #endif
 
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-#define GET_ACS_STATE(padapter)					(ATOMIC_READ(&GET_HAL_DATA(padapter)->acs.state))
-#define SET_ACS_STATE(padapter, set_state)			(ATOMIC_SET(&GET_HAL_DATA(padapter)->acs.state, set_state))
-#define rtw_get_acs_channel(padapter)				(GET_HAL_DATA(padapter)->acs.ch)
-#define rtw_set_acs_channel(padapter, survey_ch)	(GET_HAL_DATA(padapter)->acs.ch = survey_ch)
-#endif /*CONFIG_AUTO_CHNL_SEL_NHM*/
-
-#endif //__HAL_DATA_H__
-
+#ifdef RTW_HALMAC
+int rtw_halmac_deinit_adapter(struct dvobj_priv *);
+#endif /* RTW_HALMAC */
+
+/* alias for phydm coding style */
+#define REG_OFDM_0_XA_TX_IQ_IMBALANCE	rOFDM0_XATxIQImbalance
+#define REG_OFDM_0_ECCA_THRESHOLD		rOFDM0_ECCAThreshold
+#define REG_FPGA0_XB_LSSI_READ_BACK		rFPGA0_XB_LSSIReadBack
+#define REG_FPGA0_TX_GAIN_STAGE			rFPGA0_TxGainStage
+#define REG_OFDM_0_XA_AGC_CORE1			rOFDM0_XAAGCCore1
+#define REG_OFDM_0_XB_AGC_CORE1			rOFDM0_XBAGCCore1
+#define REG_A_TX_SCALE_JAGUAR			rA_TxScale_Jaguar
+#define REG_B_TX_SCALE_JAGUAR			rB_TxScale_Jaguar
+
+#define REG_FPGA0_XAB_RF_INTERFACE_SW	rFPGA0_XAB_RFInterfaceSW
+#define REG_FPGA0_XAB_RF_PARAMETER	rFPGA0_XAB_RFParameter
+#define REG_FPGA0_XA_HSSI_PARAMETER1	rFPGA0_XA_HSSIParameter1
+#define REG_FPGA0_XA_LSSI_PARAMETER	rFPGA0_XA_LSSIParameter
+#define REG_FPGA0_XA_RF_INTERFACE_OE	rFPGA0_XA_RFInterfaceOE
+#define REG_FPGA0_XB_HSSI_PARAMETER1	rFPGA0_XB_HSSIParameter1
+#define REG_FPGA0_XB_LSSI_PARAMETER	rFPGA0_XB_LSSIParameter
+#define REG_FPGA0_XB_LSSI_READ_BACK	rFPGA0_XB_LSSIReadBack
+#define REG_FPGA0_XB_RF_INTERFACE_OE	rFPGA0_XB_RFInterfaceOE
+#define REG_FPGA0_XCD_RF_INTERFACE_SW	rFPGA0_XCD_RFInterfaceSW
+#define REG_FPGA0_XCD_SWITCH_CONTROL	rFPGA0_XCD_SwitchControl
+#define REG_FPGA1_TX_BLOCK	rFPGA1_TxBlock
+#define REG_FPGA1_TX_INFO	rFPGA1_TxInfo
+#define REG_IQK_AGC_CONT	rIQK_AGC_Cont
+#define REG_IQK_AGC_PTS	rIQK_AGC_Pts
+#define REG_IQK_AGC_RSP	rIQK_AGC_Rsp
+#define REG_OFDM_0_AGC_RSSI_TABLE	rOFDM0_AGCRSSITable
+#define REG_OFDM_0_ECCA_THRESHOLD	rOFDM0_ECCAThreshold
+#define REG_OFDM_0_RX_IQ_EXT_ANTA	rOFDM0_RxIQExtAnta
+#define REG_OFDM_0_TR_MUX_PAR	rOFDM0_TRMuxPar
+#define REG_OFDM_0_TRX_PATH_ENABLE	rOFDM0_TRxPathEnable
+#define REG_OFDM_0_XA_AGC_CORE1	rOFDM0_XAAGCCore1
+#define REG_OFDM_0_XA_RX_IQ_IMBALANCE	rOFDM0_XARxIQImbalance
+#define REG_OFDM_0_XA_TX_IQ_IMBALANCE	rOFDM0_XATxIQImbalance
+#define REG_OFDM_0_XB_AGC_CORE1	rOFDM0_XBAGCCore1
+#define REG_OFDM_0_XB_RX_IQ_IMBALANCE	rOFDM0_XBRxIQImbalance
+#define REG_OFDM_0_XB_TX_IQ_IMBALANCE	rOFDM0_XBTxIQImbalance
+#define REG_OFDM_0_XC_TX_AFE	rOFDM0_XCTxAFE
+#define REG_OFDM_0_XD_TX_AFE	rOFDM0_XDTxAFE
+
+/*#define REG_A_CFO_LONG_DUMP_92E	rA_CfoLongDump_92E*/
+#define REG_A_CFO_LONG_DUMP_JAGUAR	rA_CfoLongDump_Jaguar
+/*#define REG_A_CFO_SHORT_DUMP_92E	rA_CfoShortDump_92E*/
+#define REG_A_CFO_SHORT_DUMP_JAGUAR	rA_CfoShortDump_Jaguar
+#define REG_A_RFE_PINMUX_JAGUAR	rA_RFE_Pinmux_Jaguar
+/*#define REG_A_RSSI_DUMP_92E	rA_RSSIDump_92E*/
+#define REG_A_RSSI_DUMP_JAGUAR	rA_RSSIDump_Jaguar
+/*#define REG_A_RX_SNR_DUMP_92E	rA_RXsnrDump_92E*/
+#define REG_A_RX_SNR_DUMP_JAGUAR	rA_RXsnrDump_Jaguar
+/*#define REG_A_TX_AGC	rA_TXAGC*/
+#define REG_A_TX_SCALE_JAGUAR	rA_TxScale_Jaguar
+#define REG_BW_INDICATION_JAGUAR	rBWIndication_Jaguar
+/*#define REG_B_BBSWING	rB_BBSWING*/
+/*#define REG_B_CFO_LONG_DUMP_92E	rB_CfoLongDump_92E*/
+#define REG_B_CFO_LONG_DUMP_JAGUAR	rB_CfoLongDump_Jaguar
+/*#define REG_B_CFO_SHORT_DUMP_92E	rB_CfoShortDump_92E*/
+#define REG_B_CFO_SHORT_DUMP_JAGUAR	rB_CfoShortDump_Jaguar
+/*#define REG_B_RSSI_DUMP_92E	rB_RSSIDump_92E*/
+#define REG_B_RSSI_DUMP_JAGUAR	rB_RSSIDump_Jaguar
+/*#define REG_B_RX_SNR_DUMP_92E	rB_RXsnrDump_92E*/
+#define REG_B_RX_SNR_DUMP_JAGUAR	rB_RXsnrDump_Jaguar
+/*#define REG_B_TX_AGC	rB_TXAGC*/
+#define REG_B_TX_SCALE_JAGUAR	rB_TxScale_Jaguar
+#define REG_BLUE_TOOTH	rBlue_Tooth
+#define REG_CCK_0_AFE_SETTING	rCCK0_AFESetting
+/*#define REG_C_BBSWING	rC_BBSWING*/
+/*#define REG_C_TX_AGC	rC_TXAGC*/
+#define REG_C_TX_SCALE_JAGUAR2	rC_TxScale_Jaguar2
+#define REG_CONFIG_ANT_A	rConfig_AntA
+#define REG_CONFIG_ANT_B	rConfig_AntB
+#define REG_CONFIG_PMPD_ANT_A	rConfig_Pmpd_AntA
+#define REG_CONFIG_PMPD_ANT_B	rConfig_Pmpd_AntB
+#define REG_DPDT_CONTROL	rDPDT_control
+/*#define REG_D_BBSWING	rD_BBSWING*/
+/*#define REG_D_TX_AGC	rD_TXAGC*/
+#define REG_D_TX_SCALE_JAGUAR2	rD_TxScale_Jaguar2
+#define REG_FPGA0_ANALOG_PARAMETER4	rFPGA0_AnalogParameter4
+#define REG_FPGA0_IQK	rFPGA0_IQK
+#define REG_FPGA0_PSD_FUNCTION	rFPGA0_PSDFunction
+#define REG_FPGA0_PSD_REPORT	rFPGA0_PSDReport
+#define REG_FPGA0_RFMOD	rFPGA0_RFMOD
+#define REG_FPGA0_TX_GAIN_STAGE	rFPGA0_TxGainStage
+#define REG_FPGA0_XAB_RF_INTERFACE_SW	rFPGA0_XAB_RFInterfaceSW
+#define REG_FPGA0_XAB_RF_PARAMETER	rFPGA0_XAB_RFParameter
+#define REG_FPGA0_XA_HSSI_PARAMETER1	rFPGA0_XA_HSSIParameter1
+#define REG_FPGA0_XA_LSSI_PARAMETER	rFPGA0_XA_LSSIParameter
+#define REG_FPGA0_XA_RF_INTERFACE_OE	rFPGA0_XA_RFInterfaceOE
+#define REG_FPGA0_XB_HSSI_PARAMETER1	rFPGA0_XB_HSSIParameter1
+#define REG_FPGA0_XB_LSSI_PARAMETER	rFPGA0_XB_LSSIParameter
+#define REG_FPGA0_XB_LSSI_READ_BACK	rFPGA0_XB_LSSIReadBack
+#define REG_FPGA0_XB_RF_INTERFACE_OE	rFPGA0_XB_RFInterfaceOE
+#define REG_FPGA0_XCD_RF_INTERFACE_SW	rFPGA0_XCD_RFInterfaceSW
+#define REG_FPGA0_XCD_SWITCH_CONTROL	rFPGA0_XCD_SwitchControl
+#define REG_FPGA1_TX_BLOCK	rFPGA1_TxBlock
+#define REG_FPGA1_TX_INFO	rFPGA1_TxInfo
+#define REG_IQK_AGC_CONT	rIQK_AGC_Cont
+#define REG_IQK_AGC_PTS	rIQK_AGC_Pts
+#define REG_IQK_AGC_RSP	rIQK_AGC_Rsp
+#define REG_OFDM_0_AGC_RSSI_TABLE	rOFDM0_AGCRSSITable
+#define REG_OFDM_0_ECCA_THRESHOLD	rOFDM0_ECCAThreshold
+#define REG_OFDM_0_RX_IQ_EXT_ANTA	rOFDM0_RxIQExtAnta
+#define REG_OFDM_0_TR_MUX_PAR	rOFDM0_TRMuxPar
+#define REG_OFDM_0_TRX_PATH_ENABLE	rOFDM0_TRxPathEnable
+#define REG_OFDM_0_XA_AGC_CORE1	rOFDM0_XAAGCCore1
+#define REG_OFDM_0_XA_RX_IQ_IMBALANCE	rOFDM0_XARxIQImbalance
+#define REG_OFDM_0_XA_TX_IQ_IMBALANCE	rOFDM0_XATxIQImbalance
+#define REG_OFDM_0_XB_AGC_CORE1	rOFDM0_XBAGCCore1
+#define REG_OFDM_0_XB_RX_IQ_IMBALANCE	rOFDM0_XBRxIQImbalance
+#define REG_OFDM_0_XB_TX_IQ_IMBALANCE	rOFDM0_XBTxIQImbalance
+#define REG_OFDM_0_XC_TX_AFE	rOFDM0_XCTxAFE
+#define REG_OFDM_0_XD_TX_AFE	rOFDM0_XDTxAFE
+#define REG_PMPD_ANAEN	rPMPD_ANAEN
+#define REG_PDP_ANT_A	rPdp_AntA
+#define REG_PDP_ANT_A_4	rPdp_AntA_4
+#define REG_PDP_ANT_B	rPdp_AntB
+#define REG_PDP_ANT_B_4	rPdp_AntB_4
+#define REG_PWED_TH_JAGUAR	rPwed_TH_Jaguar
+#define REG_RX_CCK	rRx_CCK
+#define REG_RX_IQK	rRx_IQK
+#define REG_RX_IQK_PI_A	rRx_IQK_PI_A
+#define REG_RX_IQK_PI_B	rRx_IQK_PI_B
+#define REG_RX_IQK_TONE_A	rRx_IQK_Tone_A
+#define REG_RX_IQK_TONE_B	rRx_IQK_Tone_B
+#define REG_RX_OFDM	rRx_OFDM
+#define REG_RX_POWER_AFTER_IQK_A_2	rRx_Power_After_IQK_A_2
+#define REG_RX_POWER_AFTER_IQK_B_2	rRx_Power_After_IQK_B_2
+#define REG_RX_POWER_BEFORE_IQK_A_2	rRx_Power_Before_IQK_A_2
+#define REG_RX_POWER_BEFORE_IQK_B_2	rRx_Power_Before_IQK_B_2
+#define REG_RX_TO_RX	rRx_TO_Rx
+#define REG_RX_WAIT_CCA	rRx_Wait_CCA
+#define REG_RX_WAIT_RIFS	rRx_Wait_RIFS
+#define REG_S0_S1_PATH_SWITCH	rS0S1_PathSwitch
+/*#define REG_S1_RXEVM_DUMP_92E	rS1_RXevmDump_92E*/
+#define REG_S1_RXEVM_DUMP_JAGUAR	rS1_RXevmDump_Jaguar
+/*#define REG_S2_RXEVM_DUMP_92E	rS2_RXevmDump_92E*/
+#define REG_S2_RXEVM_DUMP_JAGUAR	rS2_RXevmDump_Jaguar
+#define REG_SYM_WLBT_PAPE_SEL	rSYM_WLBT_PAPE_SEL
+#define REG_SINGLE_TONE_CONT_TX_JAGUAR	rSingleTone_ContTx_Jaguar
+#define REG_SLEEP	rSleep
+#define REG_STANDBY	rStandby
+#define REG_TX_AGC_A_CCK_11_CCK_1_JAGUAR	rTxAGC_A_CCK11_CCK1_JAguar
+#define REG_TX_AGC_A_CCK_1_MCS32	rTxAGC_A_CCK1_Mcs32
+#define REG_TX_AGC_A_MCS11_MCS8_JAGUAR	rTxAGC_A_MCS11_MCS8_JAguar
+#define REG_TX_AGC_A_MCS15_MCS12_JAGUAR	rTxAGC_A_MCS15_MCS12_JAguar
+#define REG_TX_AGC_A_MCS19_MCS16_JAGUAR	rTxAGC_A_MCS19_MCS16_JAguar
+#define REG_TX_AGC_A_MCS23_MCS20_JAGUAR	rTxAGC_A_MCS23_MCS20_JAguar
+#define REG_TX_AGC_A_MCS3_MCS0_JAGUAR	rTxAGC_A_MCS3_MCS0_JAguar
+#define REG_TX_AGC_A_MCS7_MCS4_JAGUAR	rTxAGC_A_MCS7_MCS4_JAguar
+#define REG_TX_AGC_A_MCS03_MCS00	rTxAGC_A_Mcs03_Mcs00
+#define REG_TX_AGC_A_MCS07_MCS04	rTxAGC_A_Mcs07_Mcs04
+#define REG_TX_AGC_A_MCS11_MCS08	rTxAGC_A_Mcs11_Mcs08
+#define REG_TX_AGC_A_MCS15_MCS12	rTxAGC_A_Mcs15_Mcs12
+#define REG_TX_AGC_A_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_A_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_A_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_A_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_A_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_A_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_A_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_A_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_A_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_A_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_A_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_A_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_A_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_A_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_A_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_A_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_A_OFDM18_OFDM6_JAGUAR	rTxAGC_A_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_A_OFDM54_OFDM24_JAGUAR	rTxAGC_A_Ofdm54_Ofdm24_JAguar
+#define REG_TX_AGC_A_RATE18_06	rTxAGC_A_Rate18_06
+#define REG_TX_AGC_A_RATE54_24	rTxAGC_A_Rate54_24
+#define REG_TX_AGC_B_CCK_11_A_CCK_2_11	rTxAGC_B_CCK11_A_CCK2_11
+#define REG_TX_AGC_B_CCK_11_CCK_1_JAGUAR	rTxAGC_B_CCK11_CCK1_JAguar
+#define REG_TX_AGC_B_CCK_1_55_MCS32	rTxAGC_B_CCK1_55_Mcs32
+#define REG_TX_AGC_B_MCS11_MCS8_JAGUAR	rTxAGC_B_MCS11_MCS8_JAguar
+#define REG_TX_AGC_B_MCS15_MCS12_JAGUAR	rTxAGC_B_MCS15_MCS12_JAguar
+#define REG_TX_AGC_B_MCS19_MCS16_JAGUAR	rTxAGC_B_MCS19_MCS16_JAguar
+#define REG_TX_AGC_B_MCS23_MCS20_JAGUAR	rTxAGC_B_MCS23_MCS20_JAguar
+#define REG_TX_AGC_B_MCS3_MCS0_JAGUAR	rTxAGC_B_MCS3_MCS0_JAguar
+#define REG_TX_AGC_B_MCS7_MCS4_JAGUAR	rTxAGC_B_MCS7_MCS4_JAguar
+#define REG_TX_AGC_B_MCS03_MCS00	rTxAGC_B_Mcs03_Mcs00
+#define REG_TX_AGC_B_MCS07_MCS04	rTxAGC_B_Mcs07_Mcs04
+#define REG_TX_AGC_B_MCS11_MCS08	rTxAGC_B_Mcs11_Mcs08
+#define REG_TX_AGC_B_MCS15_MCS12	rTxAGC_B_Mcs15_Mcs12
+#define REG_TX_AGC_B_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_B_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_B_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_B_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_B_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_B_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_B_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_B_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_B_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_B_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_B_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_B_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_B_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_B_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_B_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_B_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_B_OFDM18_OFDM6_JAGUAR	rTxAGC_B_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_B_OFDM54_OFDM24_JAGUAR	rTxAGC_B_Ofdm54_Ofdm24_JAguar
+#define REG_TX_AGC_B_RATE18_06	rTxAGC_B_Rate18_06
+#define REG_TX_AGC_B_RATE54_24	rTxAGC_B_Rate54_24
+#define REG_TX_AGC_C_CCK_11_CCK_1_JAGUAR	rTxAGC_C_CCK11_CCK1_JAguar
+#define REG_TX_AGC_C_MCS11_MCS8_JAGUAR	rTxAGC_C_MCS11_MCS8_JAguar
+#define REG_TX_AGC_C_MCS15_MCS12_JAGUAR	rTxAGC_C_MCS15_MCS12_JAguar
+#define REG_TX_AGC_C_MCS19_MCS16_JAGUAR	rTxAGC_C_MCS19_MCS16_JAguar
+#define REG_TX_AGC_C_MCS23_MCS20_JAGUAR	rTxAGC_C_MCS23_MCS20_JAguar
+#define REG_TX_AGC_C_MCS3_MCS0_JAGUAR	rTxAGC_C_MCS3_MCS0_JAguar
+#define REG_TX_AGC_C_MCS7_MCS4_JAGUAR	rTxAGC_C_MCS7_MCS4_JAguar
+#define REG_TX_AGC_C_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_C_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_C_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_C_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_C_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_C_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_C_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_C_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_C_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_C_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_C_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_C_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_C_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_C_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_C_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_C_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_C_OFDM18_OFDM6_JAGUAR	rTxAGC_C_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_C_OFDM54_OFDM24_JAGUAR	rTxAGC_C_Ofdm54_Ofdm24_JAguar
+#define REG_TX_AGC_D_CCK_11_CCK_1_JAGUAR	rTxAGC_D_CCK11_CCK1_JAguar
+#define REG_TX_AGC_D_MCS11_MCS8_JAGUAR	rTxAGC_D_MCS11_MCS8_JAguar
+#define REG_TX_AGC_D_MCS15_MCS12_JAGUAR	rTxAGC_D_MCS15_MCS12_JAguar
+#define REG_TX_AGC_D_MCS19_MCS16_JAGUAR	rTxAGC_D_MCS19_MCS16_JAguar
+#define REG_TX_AGC_D_MCS23_MCS20_JAGUAR	rTxAGC_D_MCS23_MCS20_JAguar
+#define REG_TX_AGC_D_MCS3_MCS0_JAGUAR	rTxAGC_D_MCS3_MCS0_JAguar
+#define REG_TX_AGC_D_MCS7_MCS4_JAGUAR	rTxAGC_D_MCS7_MCS4_JAguar
+#define REG_TX_AGC_D_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	rTxAGC_D_Nss1Index3_Nss1Index0_JAguar
+#define REG_TX_AGC_D_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	rTxAGC_D_Nss1Index7_Nss1Index4_JAguar
+#define REG_TX_AGC_D_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	rTxAGC_D_Nss2Index1_Nss1Index8_JAguar
+#define REG_TX_AGC_D_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	rTxAGC_D_Nss2Index5_Nss2Index2_JAguar
+#define REG_TX_AGC_D_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	rTxAGC_D_Nss2Index9_Nss2Index6_JAguar
+#define REG_TX_AGC_D_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	rTxAGC_D_Nss3Index3_Nss3Index0_JAguar
+#define REG_TX_AGC_D_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	rTxAGC_D_Nss3Index7_Nss3Index4_JAguar
+#define REG_TX_AGC_D_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	rTxAGC_D_Nss3Index9_Nss3Index8_JAguar
+#define REG_TX_AGC_D_OFDM18_OFDM6_JAGUAR	rTxAGC_D_Ofdm18_Ofdm6_JAguar
+#define REG_TX_AGC_D_OFDM54_OFDM24_JAGUAR	rTxAGC_D_Ofdm54_Ofdm24_JAguar
+#define REG_TX_PATH_JAGUAR	rTxPath_Jaguar
+#define REG_TX_CCK_BBON	rTx_CCK_BBON
+#define REG_TX_CCK_RFON	rTx_CCK_RFON
+#define REG_TX_IQK	rTx_IQK
+#define REG_TX_IQK_PI_A	rTx_IQK_PI_A
+#define REG_TX_IQK_PI_B	rTx_IQK_PI_B
+#define REG_TX_IQK_TONE_A	rTx_IQK_Tone_A
+#define REG_TX_IQK_TONE_B	rTx_IQK_Tone_B
+#define REG_TX_OFDM_BBON	rTx_OFDM_BBON
+#define REG_TX_OFDM_RFON	rTx_OFDM_RFON
+#define REG_TX_POWER_AFTER_IQK_A	rTx_Power_After_IQK_A
+#define REG_TX_POWER_AFTER_IQK_B	rTx_Power_After_IQK_B
+#define REG_TX_POWER_BEFORE_IQK_A	rTx_Power_Before_IQK_A
+#define REG_TX_POWER_BEFORE_IQK_B	rTx_Power_Before_IQK_B
+#define REG_TX_TO_RX	rTx_To_Rx
+#define REG_TX_TO_TX	rTx_To_Tx
+#define REG_APK	rAPK
+#define REG_ANTSEL_SW_JAGUAR	r_ANTSEL_SW_Jaguar
+
+
+
+#define rf_welut_jaguar	RF_WeLut_Jaguar
+#define rf_mode_table_addr	RF_ModeTableAddr
+#define rf_mode_table_data0	RF_ModeTableData0
+#define rf_mode_table_data1	RF_ModeTableData1
+
+
+
+
+
+
+#define RX_SMOOTH_FACTOR	Rx_Smooth_Factor
+
+#endif /* __HAL_DATA_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_gspi.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_gspi.h
index f5880e274512..f9a6d2ca916c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_gspi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_gspi.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_GSPI_H_
 #define __HAL_GSPI_H_
 
@@ -28,5 +24,4 @@ void rtw_hal_gspi_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 Required
 void rtw_hal_set_gspi_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
 u32 rtw_hal_get_gspi_tx_max_length(PADAPTER padapter, u8 queue_idx);
 
-#endif 
-
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_ic_cfg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_ic_cfg.h
index 3a9f6c253ab7..ed060880d433 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_ic_cfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_ic_cfg.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_IC_CFG_H__
 #define __HAL_IC_CFG_H__
 
@@ -24,73 +20,240 @@
 #define RTL8812A_SUPPORT				0
 #define RTL8821A_SUPPORT				0
 #define RTL8723B_SUPPORT				0
+#define RTL8723D_SUPPORT				0
 #define RTL8192E_SUPPORT				0
 #define RTL8814A_SUPPORT				0
 #define RTL8195A_SUPPORT				0
+#define RTL8197F_SUPPORT				0
 #define RTL8703B_SUPPORT				0
 #define RTL8188F_SUPPORT				0
 #define RTL8822B_SUPPORT				0
 #define RTL8821B_SUPPORT				0
-
+#define RTL8821C_SUPPORT				0
+#define RTL8710B_SUPPORT				0
+#define RTL8814B_SUPPORT				0
+#define RTL8824B_SUPPORT				0
+#define RTL8192F_SUPPORT				0
+#define RTL8198F_SUPPORT				0
+#define RTL8195B_SUPPORT				0
 /*#if (RTL8188E_SUPPORT==1)*/
 #define RATE_ADAPTIVE_SUPPORT			0
 #define POWER_TRAINING_ACTIVE			0
 
-#ifdef CONFIG_MULTIDRV 
+#ifdef CONFIG_MULTIDRV
 #endif
 
 #ifdef CONFIG_RTL8188E
-#undef RTL8188E_SUPPORT
-#undef RATE_ADAPTIVE_SUPPORT
-#undef POWER_TRAINING_ACTIVE
+	#undef RTL8188E_SUPPORT
+	#undef RATE_ADAPTIVE_SUPPORT
+	#undef POWER_TRAINING_ACTIVE
 
-#define RTL8188E_SUPPORT				1
-#define RATE_ADAPTIVE_SUPPORT			1
-#define POWER_TRAINING_ACTIVE			1
+	#define RTL8188E_SUPPORT				1
+	#define RATE_ADAPTIVE_SUPPORT			1
+	#define POWER_TRAINING_ACTIVE			1
 #endif
 
 #ifdef CONFIG_RTL8812A
-#undef RTL8812A_SUPPORT
-#define RTL8812A_SUPPORT				1
+	#undef RTL8812A_SUPPORT
+	#define RTL8812A_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
 #endif
 
 #ifdef CONFIG_RTL8821A
-#undef RTL8821A_SUPPORT
-#define RTL8821A_SUPPORT				1
+	#undef RTL8821A_SUPPORT
+	#define RTL8821A_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
 #endif
 
 #ifdef CONFIG_RTL8192E
-#undef RTL8192E_SUPPORT
-#define RTL8192E_SUPPORT				1
+	#undef RTL8192E_SUPPORT
+	#define RTL8192E_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
 #endif
 
 #ifdef CONFIG_RTL8723B
-#undef RTL8723B_SUPPORT
-#define RTL8723B_SUPPORT				1
+	#undef RTL8723B_SUPPORT
+	#define RTL8723B_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8723D
+	#undef RTL8723D_SUPPORT
+	#define RTL8723D_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
+	#ifndef CONFIG_RTW_CUSTOMER_STR
+		#define CONFIG_RTW_CUSTOMER_STR
+	#endif
 #endif
 
 #ifdef CONFIG_RTL8814A
-#undef RTL8814A_SUPPORT
-#define RTL8814A_SUPPORT				1
+	#undef RTL8814A_SUPPORT
+	#define RTL8814A_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
 #endif
 
 #ifdef CONFIG_RTL8703B
-#undef RTL8703B_SUPPORT
-#define RTL8703B_SUPPORT				1
+	#undef RTL8703B_SUPPORT
+	#define RTL8703B_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
 #endif
 
 #ifdef CONFIG_RTL8188F
-#undef RTL8188F_SUPPORT
-#define RTL8188F_SUPPORT				1
+	#undef RTL8188F_SUPPORT
+	#define RTL8188F_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
+	#ifndef CONFIG_RTW_CUSTOMER_STR
+		#define CONFIG_RTW_CUSTOMER_STR
+	#endif
+#endif
+
+#ifdef CONFIG_RTL8188GTV
+	#undef RTL8188F_SUPPORT
+	#define RTL8188F_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
 	#ifndef CONFIG_RTW_CUSTOMER_STR
 		#define CONFIG_RTW_CUSTOMER_STR
 	#endif
 #endif
 
 #ifdef CONFIG_RTL8822B
-#undef RTL8822B_SUPPORT
-#define RTL8822B_SUPPORT				1
+	#undef RTL8822B_SUPPORT
+	#define RTL8822B_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif /* CONFIG_FW_C2H_PKT */
+	#define RTW_TX_PA_BIAS	/* Adjust TX PA Bias from eFuse */
+	#define CONFIG_DFS	/* Enable 5G band 2&3 channel */
+
+	#ifdef CONFIG_WOWLAN
+		#define CONFIG_GTK_OL
+		/*#define CONFIG_ARP_KEEP_ALIVE*/
+
+		#ifdef CONFIG_GPIO_WAKEUP
+			#ifndef WAKEUP_GPIO_IDX
+				#define WAKEUP_GPIO_IDX	6	/* WIFI Chip Side */
+			#endif /* !WAKEUP_GPIO_IDX */
+		#endif /* CONFIG_GPIO_WAKEUP */
+	#endif /* CONFIG_WOWLAN */
+
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define CONFIG_AP_PORT_SWAP
+		#define CONFIG_FW_MULTI_PORT_SUPPORT
+	#endif /* CONFIG_CONCURRENT_MODE */
+
+	/*
+	 * Beamforming related definition
+	 */
+	/* Beamforming mechanism is on driver not phydm, always disable it */
+	#define BEAMFORMING_SUPPORT				0
+	/* Only support new beamforming mechanism */
+	#ifdef CONFIG_BEAMFORMING
+		#define RTW_BEAMFORMING_VERSION_2
+	#endif /* CONFIG_BEAMFORMING */
+
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif /* CONFIG_RTW_MAC_HIDDEN_RPT */
+
+	#ifndef DBG_RX_DFRAME_RAW_DATA
+		#define DBG_RX_DFRAME_RAW_DATA
+	#endif /* DBG_RX_DFRAME_RAW_DATA */
+
+	#ifndef RTW_IQK_FW_OFFLOAD
+		#define RTW_IQK_FW_OFFLOAD
+	#endif /* RTW_IQK_FW_OFFLOAD */
+	#define CONFIG_ADVANCE_OTA
+
+	#ifdef CONFIG_MCC_MODE
+		#define CONFIG_MCC_MODE_V2
+	#endif /* CONFIG_MCC_MODE */
+
+	#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
+		#define CONFIG_TDLS_CH_SW_V2
+	#endif
+
+	#ifndef RTW_CHANNEL_SWITCH_OFFLOAD
+		#ifdef CONFIG_TDLS_CH_SW_V2
+			#define RTW_CHANNEL_SWITCH_OFFLOAD
+		#endif
+	#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+
+	#if defined(CONFIG_RTW_MESH) && !defined(RTW_PER_CMD_SUPPORT_FW)
+		/* Supported since fw v22.1 */
+		#define RTW_PER_CMD_SUPPORT_FW
+	#endif /* RTW_PER_CMD_SUPPORT_FW */
+	
+	#ifndef CONFIG_DYNAMIC_SOML
+		#define CONFIG_DYNAMIC_SOML
+	#endif /* CONFIG_DYNAMIC_SOML */
+#endif /* CONFIG_RTL8822B */
+
+#ifdef CONFIG_RTL8821C
+	#undef RTL8821C_SUPPORT
+	#define RTL8821C_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifdef CONFIG_NO_FW
+		#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
+			#undef CONFIG_RTW_MAC_HIDDEN_RPT
+		#endif
+	#else
+		#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+			#define CONFIG_RTW_MAC_HIDDEN_RPT
+		#endif
+	#endif
+	#define LOAD_FW_HEADER_FROM_DRIVER
+	#define CONFIG_PHY_CAPABILITY_QUERY
+	#ifdef CONFIG_CONCURRENT_MODE
+	#define CONFIG_AP_PORT_SWAP
+	#define CONFIG_FW_MULTI_PORT_SUPPORT
+	#endif
+	#define CONFIG_SUPPORT_FIFO_DUMP
+	#ifndef RTW_IQK_FW_OFFLOAD
+		#define RTW_IQK_FW_OFFLOAD
+	#endif /* RTW_IQK_FW_OFFLOAD */
+	/*#define CONFIG_AMPDU_PRETX_CD*/
+	/*#define DBG_PRE_TX_HANG*/
+	/*
+	 * Beamforming related definition
+	 */
+	/* Beamforming mechanism is on driver not phydm, always disable it */
+	#define BEAMFORMING_SUPPORT				0
+	/* Only support new beamforming mechanism */
+	#ifdef CONFIG_BEAMFORMING
+		#define RTW_BEAMFORMING_VERSION_2
+	#endif /* CONFIG_BEAMFORMING */
 #endif
 
 #endif /*__HAL_IC_CFG_H__*/
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_intf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_intf.h
index a1b9bc9868c6..af867ed258bf 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_intf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_intf.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,20 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_INTF_H__
 #define __HAL_INTF_H__
 
 
 enum RTL871X_HCI_TYPE {
 	RTW_PCIE	= BIT0,
-	RTW_USB 	= BIT1,
-	RTW_SDIO 	= BIT2,
+	RTW_USB	= BIT1,
+	RTW_SDIO	= BIT2,
 	RTW_GSPI	= BIT3,
 };
 
@@ -34,14 +30,26 @@ enum _CHIP_TYPE {
 	RTL8188E,
 	RTL8192E,
 	RTL8812,
-	RTL8821, //RTL8811
+	RTL8821, /* RTL8811 */
 	RTL8723B,
 	RTL8814A,
 	RTL8703B,
 	RTL8188F,
+	RTL8188GTV,
+	RTL8822B,
+	RTL8723D,
+	RTL8821C,
 	MAX_CHIP_TYPE
 };
 
+#ifdef RTW_HALMAC
+enum fw_mem {
+	FW_EMEM,
+	FW_IMEM,
+	FW_DMEM,
+};
+#endif
+
 extern const u32 _chip_type_to_odm_ic_type[];
 #define chip_type_to_odm_ic_type(chip_type) (((chip_type) >= MAX_CHIP_TYPE) ? _chip_type_to_odm_ic_type[MAX_CHIP_TYPE] : _chip_type_to_odm_ic_type[(chip_type)])
 
@@ -52,9 +60,8 @@ typedef enum _HAL_HW_TIMER_TYPE {
 } HAL_HW_TIMER_TYPE, *PHAL_HW_TIMER_TYPE;
 
 
-typedef enum _HW_VARIABLES{
+typedef enum _HW_VARIABLES {
 	HW_VAR_MEDIA_STATUS,
-	HW_VAR_MEDIA_STATUS1,
 	HW_VAR_SET_OPMODE,
 	HW_VAR_MAC_ADDR,
 	HW_VAR_BSSID,
@@ -63,12 +70,12 @@ typedef enum _HW_VARIABLES{
 	HW_VAR_TXPAUSE,
 	HW_VAR_BCN_FUNC,
 	HW_VAR_CORRECT_TSF,
-	HW_VAR_CHECK_BSSID,
+	HW_VAR_RCR,
 	HW_VAR_MLME_DISCONNECT,
 	HW_VAR_MLME_SITESURVEY,
 	HW_VAR_MLME_JOIN,
 	HW_VAR_ON_RCR_AM,
-       HW_VAR_OFF_RCR_AM,
+	HW_VAR_OFF_RCR_AM,
 	HW_VAR_BEACON_INTERVAL,
 	HW_VAR_SLOT_TIME,
 	HW_VAR_RESP_SIFS,
@@ -77,6 +84,9 @@ typedef enum _HW_VARIABLES{
 	HW_VAR_SEC_DK_CFG,
 	HW_VAR_BCN_VALID,
 	HW_VAR_RF_TYPE,
+	HW_VAR_TSF,
+	HW_VAR_FREECNT,
+
 	/* PHYDM odm->SupportAbility */
 	HW_VAR_CAM_EMPTY_ENTRY,
 	HW_VAR_CAM_INVALID_ALL,
@@ -85,6 +95,9 @@ typedef enum _HW_VARIABLES{
 	HW_VAR_AC_PARAM_BE,
 	HW_VAR_AC_PARAM_BK,
 	HW_VAR_ACM_CTRL,
+#ifdef CONFIG_WMMPS_STA
+	HW_VAR_UAPSD_TID,
+#endif /* CONFIG_WMMPS_STA */
 	HW_VAR_AMPDU_MIN_SPACE,
 	HW_VAR_AMPDU_FACTOR,
 	HW_VAR_RXDMA_AGG_PG_TH,
@@ -95,13 +108,18 @@ typedef enum _HW_VARIABLES{
 	HW_VAR_H2C_FW_JOINBSSRPT,
 	HW_VAR_FWLPS_RF_ON,
 	HW_VAR_H2C_FW_P2P_PS_OFFLOAD,
-	HW_VAR_TDLS_WRCR,
-	HW_VAR_TDLS_RS_RCR,
+#ifdef CONFIG_LPS_POFF
+	HW_VAR_LPS_POFF_INIT,
+	HW_VAR_LPS_POFF_DEINIT,
+	HW_VAR_LPS_POFF_SET_MODE,
+	HW_VAR_LPS_POFF_WOW_EN,
+#endif
+#ifdef CONFIG_LPS_PG
+	HW_VAR_LPS_PG_HANDLE,
+#endif
 	HW_VAR_TRIGGER_GPIO_0,
 	HW_VAR_BT_SET_COEXIST,
-	HW_VAR_BT_ISSUE_DELBA,	
-	HW_VAR_CURRENT_ANTENNA,
-	HW_VAR_ANTENNA_DIVERSITY_SELECT,
+	HW_VAR_BT_ISSUE_DELBA,
 	HW_VAR_SWITCH_EPHY_WoWLAN,
 	HW_VAR_EFUSE_USAGE,
 	HW_VAR_EFUSE_BYTES,
@@ -111,31 +129,32 @@ typedef enum _HW_VARIABLES{
 	HW_VAR_RESTORE_HW_SEQ,
 	HW_VAR_CHECK_TXBUF,
 	HW_VAR_PCIE_STOP_TX_DMA,
-	HW_VAR_APFM_ON_MAC, //Auto FSM to Turn On, include clock, isolation, power control for MAC only
+	HW_VAR_APFM_ON_MAC, /* Auto FSM to Turn On, include clock, isolation, power control for MAC only */
 	HW_VAR_HCI_SUS_STATE,
-	// The valid upper nav range for the HW updating, if the true value is larger than the upper range, the HW won't update it.
-	// Unit in microsecond. 0 means disable this function.
+	/* The valid upper nav range for the HW updating, if the true value is larger than the upper range, the HW won't update it. */
+	/* Unit in microsecond. 0 means disable this function. */
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 	HW_VAR_WOWLAN,
 	HW_VAR_WAKEUP_REASON,
-	HW_VAR_RPWM_TOG,
 #endif
+	HW_VAR_RPWM_TOG,
 #ifdef CONFIG_GPIO_WAKEUP
 	HW_SET_GPIO_WL_CTRL,
 #endif
 	HW_VAR_SYS_CLKR,
 	HW_VAR_NAV_UPPER,
-	HW_VAR_C2H_HANDLE,
 	HW_VAR_RPT_TIMER_SETTING,
-	HW_VAR_TX_RPT_MAX_MACID,	
+	HW_VAR_TX_RPT_MAX_MACID,
 	HW_VAR_CHK_HI_QUEUE_EMPTY,
+	HW_VAR_CHK_MGQ_CPU_EMPTY,
 	HW_VAR_DL_BCN_SEL,
 	HW_VAR_AMPDU_MAX_TIME,
 	HW_VAR_WIRELESS_MODE,
 	HW_VAR_USB_MODE,
 	HW_VAR_PORT_SWITCH,
+	HW_VAR_PORT_CFG,
 	HW_VAR_DO_IQK,
-	HW_VAR_DM_IN_LPS,
+	HW_VAR_DM_IN_LPS_LCLK,/*flag CONFIG_LPS_LCLK_WD_TIMER*/
 	HW_VAR_SET_REQ_FW_PS,
 	HW_VAR_FW_PS_STATE,
 	HW_VAR_SOUNDING_ENTER,
@@ -144,42 +163,66 @@ typedef enum _HW_VARIABLES{
 	HW_VAR_SOUNDING_STATUS,
 	HW_VAR_SOUNDING_FW_NDPA,
 	HW_VAR_SOUNDING_CLK,
-/*Add by YuChen for TXBF HW timer*/
+	HW_VAR_SOUNDING_SET_GID_TABLE,
+	HW_VAR_SOUNDING_CSI_REPORT,
+	/*Add by YuChen for TXBF HW timer*/
 	HW_VAR_HW_REG_TIMER_INIT,
 	HW_VAR_HW_REG_TIMER_RESTART,
 	HW_VAR_HW_REG_TIMER_START,
 	HW_VAR_HW_REG_TIMER_STOP,
-/*Add by YuChen for TXBF HW timer*/
+	/*Add by YuChen for TXBF HW timer*/
 	HW_VAR_DL_RSVD_PAGE,
 	HW_VAR_MACID_LINK,
 	HW_VAR_MACID_NOLINK,
-	HW_VAR_MACID_SLEEP,
-	HW_VAR_MACID_WAKEUP,
 	HW_VAR_DUMP_MAC_QUEUE_INFO,
 	HW_VAR_ASIX_IOT,
+#ifdef CONFIG_MBSSID_CAM
+	HW_VAR_MBSSID_CAM_WRITE,
+	HW_VAR_MBSSID_CAM_CLEAR,
+	HW_VAR_RCR_MBSSID_EN,
+#endif
 	HW_VAR_EN_HW_UPDATE_TSF,
-}HW_VARIABLES;
-
-typedef enum _HAL_DEF_VARIABLE{
+	HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO,
+	HW_VAR_CH_SW_IQK_INFO_BACKUP,
+	HW_VAR_CH_SW_IQK_INFO_RESTORE,
+
+	HW_VAR_DBI,
+	HW_VAR_MDIO,
+	HW_VAR_L1OFF_CAPABILITY,
+	HW_VAR_L1OFF_NIC_SUPPORT,
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+	HW_VAR_TDLS_BCN_EARLY_C2H_RPT,
+#endif
+#endif
+	HW_VAR_DUMP_MAC_TXFIFO,
+	HW_VAR_PWR_CMD,
+	HW_VAR_SET_SOML_PARAM,
+	HW_VAR_ENABLE_RX_BAR,
+	HW_VAR_TSF_AUTO_SYNC,
+} HW_VARIABLES;
+
+typedef 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_RX_DMA_SZ_WOW,
 	HAL_DEF_RX_DMA_SZ,
 	HAL_DEF_RX_PAGE_SIZE,
-	HAL_DEF_DBG_DUMP_RXPKT,//for dbg
+	HAL_DEF_DBG_DUMP_RXPKT,/* for dbg */
 	HAL_DEF_RA_DECISION_RATE,
 	HAL_DEF_RA_SGI,
 	HAL_DEF_PT_PWR_STATUS,
-	HAL_DEF_TX_LDPC, 				// LDPC support
-	HAL_DEF_RX_LDPC, 				// LDPC support
-	HAL_DEF_TX_STBC, 				// TX STBC support
-	HAL_DEF_RX_STBC, 				// RX STBC support
-	HAL_DEF_EXPLICIT_BEAMFORMER,// Explicit  Compressed Steering Capable
-	HAL_DEF_EXPLICIT_BEAMFORMEE,// Explicit Compressed Beamforming Feedback Capable
+	HAL_DEF_TX_LDPC,				/* LDPC support */
+	HAL_DEF_RX_LDPC,				/* LDPC support */
+	HAL_DEF_TX_STBC,				/* TX STBC support */
+	HAL_DEF_RX_STBC,				/* RX STBC support */
+	HAL_DEF_EXPLICIT_BEAMFORMER,/* Explicit  Compressed Steering Capable */
+	HAL_DEF_EXPLICIT_BEAMFORMEE,/* Explicit Compressed Beamforming Feedback Capable */
+	HAL_DEF_VHT_MU_BEAMFORMER,	/* VHT MU Beamformer support */
+	HAL_DEF_VHT_MU_BEAMFORMEE,	/* VHT MU Beamformee support */
 	HAL_DEF_BEAMFORMER_CAP,
 	HAL_DEF_BEAMFORMEE_CAP,
 	HW_VAR_MAX_RX_AMPDU_FACTOR,
@@ -189,40 +232,34 @@ typedef enum _HAL_DEF_VARIABLE{
 	HAL_DEF_TX_PAGE_SIZE,
 	HAL_DEF_TX_PAGE_BOUNDARY,
 	HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN,
-	HAL_DEF_ANT_DETECT,//to do for 8723a
-	HAL_DEF_PCI_SUUPORT_L1_BACKDOOR, // Determine if the L1 Backdoor setting is turned on.
+	HAL_DEF_ANT_DETECT,/* to do for 8723a */
+	HAL_DEF_PCI_SUUPORT_L1_BACKDOOR, /* Determine if the L1 Backdoor setting is turned on. */
 	HAL_DEF_PCI_AMD_L1_SUPPORT,
-	HAL_DEF_PCI_ASPM_OSC, // Support for ASPM OSC, added by Roger, 2013.03.27.
-	HAL_DEF_MACID_SLEEP, // Support for MACID sleep
-	HAL_DEF_DBG_DIS_PWT, //disable Tx power training or not.
+	HAL_DEF_PCI_ASPM_OSC, /* Support for ASPM OSC, added by Roger, 2013.03.27. */
 	HAL_DEF_EFUSE_USAGE,	/* Get current EFUSE utilization. 2008.12.19. Added by Roger. */
 	HAL_DEF_EFUSE_BYTES,
 	HW_VAR_BEST_AMPDU_DENSITY,
-}HAL_DEF_VARIABLE;
+} HAL_DEF_VARIABLE;
 
-typedef enum _HAL_ODM_VARIABLE{
-	HAL_ODM_STA_INFO,	
+typedef enum _HAL_ODM_VARIABLE {
+	HAL_ODM_STA_INFO,
 	HAL_ODM_P2P_STATE,
 	HAL_ODM_WIFI_DISPLAY_STATE,
-	HAL_ODM_NOISE_MONITOR,
 	HAL_ODM_REGULATION,
 	HAL_ODM_INITIAL_GAIN,
-	HAL_ODM_FA_CNT_DUMP,
-	HAL_ODM_DBG_FLAG,
-	HAL_ODM_DBG_LEVEL,
 	HAL_ODM_RX_INFO_DUMP,
-
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-	HAL_ODM_AUTO_CHNL_SEL,
+	HAL_ODM_RX_Dframe_INFO,
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	HAL_ODM_ANTDIV_SELECT
 #endif
-}HAL_ODM_VARIABLE;
+} HAL_ODM_VARIABLE;
 
-typedef enum _HAL_INTF_PS_FUNC{
+typedef enum _HAL_INTF_PS_FUNC {
 	HAL_USB_SELECT_SUSPEND,
 	HAL_MAX_ID,
-}HAL_INTF_PS_FUNC;
+} HAL_INTF_PS_FUNC;
 
-typedef s32 (*c2h_id_filter)(u8 *c2h_evt);
+typedef s32(*c2h_id_filter)(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
 
 struct txpwr_idx_comp;
 
@@ -231,45 +268,45 @@ struct hal_ops {
 	void	(*read_chip_version)(_adapter *padapter);
 	void	(*init_default_value)(_adapter *padapter);
 	void	(*intf_chip_configure)(_adapter *padapter);
-	void	(*read_adapter_info)(_adapter *padapter);
-	u32	(*hal_power_on)(_adapter *padapter);
-	void	(*hal_power_off)(_adapter *padapter);	
-	u32	(*hal_init)(_adapter *padapter);
-	u32	(*hal_deinit)(_adapter *padapter);
+	u8	(*read_adapter_info)(_adapter *padapter);
+	u32(*hal_power_on)(_adapter *padapter);
+	void	(*hal_power_off)(_adapter *padapter);
+	u32(*hal_init)(_adapter *padapter);
+	u32(*hal_deinit)(_adapter *padapter);
 	void	(*dm_init)(_adapter *padapter);
 	void	(*dm_deinit)(_adapter *padapter);
-	
+
 	/*** xmit section ***/
-	s32	(*init_xmit_priv)(_adapter *padapter);
+	s32(*init_xmit_priv)(_adapter *padapter);
 	void	(*free_xmit_priv)(_adapter *padapter);
-	s32	(*hal_xmit)(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32(*hal_xmit)(_adapter *padapter, struct xmit_frame *pxmitframe);
 	/*
 	 * mgnt_xmit should be implemented to run in interrupt context
 	 */
-	s32 (*mgnt_xmit)(_adapter *padapter, struct xmit_frame *pmgntframe);
-	s32	(*hal_xmitframe_enqueue)(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32(*mgnt_xmit)(_adapter *padapter, struct xmit_frame *pmgntframe);
+	s32(*hal_xmitframe_enqueue)(_adapter *padapter, struct xmit_frame *pxmitframe);
 #ifdef CONFIG_XMIT_THREAD_MODE
-	s32 (*xmit_thread_handler)(_adapter *padapter);
+	s32(*xmit_thread_handler)(_adapter *padapter);
 #endif
 	void	(*run_thread)(_adapter *padapter);
 	void	(*cancel_thread)(_adapter *padapter);
 
 	/*** recv section ***/
-	s32	(*init_recv_priv)(_adapter *padapter);
+	s32(*init_recv_priv)(_adapter *padapter);
 	void	(*free_recv_priv)(_adapter *padapter);
 #ifdef CONFIG_RECV_THREAD_MODE
 	s32 (*recv_hdl)(_adapter *adapter);
 #endif
 #if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
-	u32	(*inirp_init)(_adapter *padapter);
-	u32	(*inirp_deinit)(_adapter *padapter);
+	u32(*inirp_init)(_adapter *padapter);
+	u32(*inirp_deinit)(_adapter *padapter);
 #endif
 	/*** interrupt hdl section ***/
 	void	(*enable_interrupt)(_adapter *padapter);
 	void	(*disable_interrupt)(_adapter *padapter);
-	u8	(*check_ips_status)(_adapter *padapter);
+	u8(*check_ips_status)(_adapter *padapter);
 #if defined(CONFIG_PCI_HCI)
-	s32	(*interrupt_handler)(_adapter *padapter);
+	s32(*interrupt_handler)(_adapter *padapter);
 #endif
 
 #if defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
@@ -279,77 +316,67 @@ struct hal_ops {
 #if defined(CONFIG_PCI_HCI)
 	void	(*irp_reset)(_adapter *padapter);
 #endif
-		
+
 	/*** DM section ***/
-	
+#ifdef CONFIG_RTW_SW_LED
 	void	(*InitSwLeds)(_adapter *padapter);
 	void	(*DeInitSwLeds)(_adapter *padapter);
-
-	void	(*set_chnl_bw_handler)(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth, u8 Offset40, u8 Offset80);
+#endif
+	void	(*set_chnl_bw_handler)(_adapter *padapter, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80);
 
 	void	(*set_tx_power_level_handler)(_adapter *padapter, u8 channel);
 	void	(*get_tx_power_level_handler)(_adapter *padapter, s32 *powerlevel);
 
-	void (*set_tx_power_index_handler)(_adapter *padapter, u32 powerindex, u8 rfpath, u8 rate);
-	u8(*get_tx_power_index_handler)(_adapter *padapter, u8 rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);
+	void (*set_tx_power_index_handler)(_adapter *padapter, u32 powerindex, enum rf_path rfpath, u8 rate);
+	u8 (*get_tx_power_index_handler)(_adapter *padapter, enum rf_path rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);
 
 	void	(*hal_dm_watchdog)(_adapter *padapter);
-#ifdef CONFIG_LPS_LCLK_WD_TIMER
-	void	(*hal_dm_watchdog_in_lps)(_adapter *padapter);
-#endif
 
-	void	(*SetHwRegHandler)(_adapter *padapter, u8	variable,u8* val);
-	void	(*GetHwRegHandler)(_adapter *padapter, u8	variable,u8* val);
+	u8	(*set_hw_reg_handler)(_adapter *padapter, u8	variable, u8 *val);
 
-#ifdef CONFIG_C2H_PACKET_EN
-	void	(*SetHwRegHandlerWithBuf)(_adapter *padapter, u8 variable, u8 * pbuf, int len);
-#endif
+	void	(*GetHwRegHandler)(_adapter *padapter, u8	variable, u8 *val);
 
-	u8	(*GetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
-	u8	(*SetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
 
-	void	(*GetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,PVOID pValue2);
-	void	(*SetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,BOOLEAN bSet);
 
-	void	(*UpdateRAMaskHandler)(_adapter *padapter, u32 mac_id, u8 rssi_level);
-	void	(*SetBeaconRelatedRegistersHandler)(_adapter *padapter);
+	u8 (*get_hal_def_var_handler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
 
-	void	(*Add_RateATid)(_adapter *padapter, u64 bitmap, u8 *arg, u8 rssi_level);
+	u8(*SetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
 
+	void	(*GetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, PVOID pValue2);
+	void	(*SetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, BOOLEAN bSet);
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-	u8	(*AntDivBeforeLinkHandler)(_adapter *padapter);
-	void	(*AntDivCompareHandler)(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
-#endif
-	u8	(*interface_ps_func)(_adapter *padapter,HAL_INTF_PS_FUNC efunc_id, u8* val);
+	void	(*SetBeaconRelatedRegistersHandler)(_adapter *padapter);
 
+	u8(*interface_ps_func)(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val);
 
-	u32	(*read_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask);
+	u32(*read_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask);
 	void	(*write_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
-	u32	(*read_rfreg)(_adapter *padapter, u8 eRFPath, u32 RegAddr, u32 BitMask);
-	void	(*write_rfreg)(_adapter *padapter, u8 eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
+	u32 (*read_rfreg)(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask);
+	void	(*write_rfreg)(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
 
+	void (*read_wmmedca_reg)(_adapter *padapter, u16 *vo_params, u16 *vi_params, u16 *be_params, u16 *bk_params);
+	
 #ifdef CONFIG_HOSTAPD_MLME
-	s32	(*hostap_mgnt_xmit_entry)(_adapter *padapter, _pkt *pkt);
+	s32(*hostap_mgnt_xmit_entry)(_adapter *padapter, _pkt *pkt);
 #endif
 
 	void (*EfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);
 	void (*BTEfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);
 	void (*ReadEFuse)(_adapter *padapter, u8 efuseType, u16 _offset, u16 _size_byte, u8 *pbuf, BOOLEAN bPseudoTest);
 	void (*EFUSEGetEfuseDefinition)(_adapter *padapter, u8 efuseType, u8 type, void *pOut, BOOLEAN bPseudoTest);
-	u16	(*EfuseGetCurrentSize)(_adapter *padapter, u8 efuseType, BOOLEAN bPseudoTest);
-	int 	(*Efuse_PgPacketRead)(_adapter *padapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);
-	int 	(*Efuse_PgPacketWrite)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
-	u8	(*Efuse_WordEnableDataWrite)(_adapter *padapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
-	BOOLEAN	(*Efuse_PgPacketWrite_BT)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
-	
+	u16(*EfuseGetCurrentSize)(_adapter *padapter, u8 efuseType, BOOLEAN bPseudoTest);
+	int	(*Efuse_PgPacketRead)(_adapter *padapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);
+	int	(*Efuse_PgPacketWrite)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+	u8(*Efuse_WordEnableDataWrite)(_adapter *padapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+	BOOLEAN(*Efuse_PgPacketWrite_BT)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+
 #ifdef DBG_CONFIG_ERROR_DETECT
 	void (*sreset_init_value)(_adapter *padapter);
-	void (*sreset_reset_value)(_adapter *padapter);		
+	void (*sreset_reset_value)(_adapter *padapter);
 	void (*silentreset)(_adapter *padapter);
 	void (*sreset_xmit_status_check)(_adapter *padapter);
-	void (*sreset_linked_status_check) (_adapter *padapter);
-	u8 (*sreset_get_wifi_status)(_adapter *padapter);
+	void (*sreset_linked_status_check)(_adapter *padapter);
+	u8(*sreset_get_wifi_status)(_adapter *padapter);
 	bool (*sreset_inprogress)(_adapter *padapter);
 #endif
 
@@ -357,43 +384,66 @@ struct hal_ops {
 	int (*IOL_exec_cmds_sync)(_adapter *padapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
 #endif
 
-	void (*hal_notch_filter)(_adapter * adapter, bool enable);
-	s32 (*c2h_handler)(_adapter *padapter, u8 *c2h_evt);
-	c2h_id_filter c2h_id_filter_ccx;
-	s32 (*fill_h2c_cmd)(PADAPTER, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+	void (*hal_notch_filter)(_adapter *adapter, bool enable);
+#ifdef RTW_HALMAC
+	void (*hal_mac_c2h_handler)(_adapter *adapter, u8 *pbuf, u16 length);
+#else
+	s32(*c2h_handler)(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+#endif
+	void (*reqtxrpt)(_adapter *padapter, u8 macid);
+	s32(*fill_h2c_cmd)(PADAPTER, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 	void (*fill_fake_txdesc)(PADAPTER, u8 *pDesc, u32 BufferLen,
-			u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
-	s32 (*fw_dl)(_adapter *adapter, u8 wowlan);
+				 u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+	s32(*fw_dl)(_adapter *adapter, u8 wowlan);
+#ifdef RTW_HALMAC
+	s32 (*fw_mem_dl)(_adapter *adapter, enum fw_mem mem);
+#endif
 
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_PCI_HCI)
 	void (*clear_interrupt)(_adapter *padapter);
-#endif	
-	u8 (*hal_get_tx_buff_rsvd_page_num)(_adapter *adapter, bool wowlan);
+#endif
+	u8(*hal_get_tx_buff_rsvd_page_num)(_adapter *adapter, bool wowlan);
 #ifdef CONFIG_GPIO_API
 	void (*update_hisr_hsisr_ind)(PADAPTER padapter, u32 flag);
+	int (*hal_gpio_func_check)(_adapter *padapter, u8 gpio_num);
+	void (*hal_gpio_multi_func_reset)(_adapter *padapter, u8 gpio_num);
 #endif
 	void (*fw_correct_bcn)(PADAPTER padapter);
+
+#ifdef RTW_HALMAC
+	u8(*init_mac_register)(PADAPTER);
+	u8(*init_phy)(PADAPTER);
+#endif /* RTW_HALMAC */
+
+#ifdef CONFIG_PCI_HCI
+	void (*hal_set_l1ssbackdoor_handler)(_adapter *padapter, u8 enable);
+#endif
+
+#ifdef CONFIG_RFKILL_POLL
+	bool (*hal_radio_onoff_check)(_adapter *adapter, u8 *valid);
+#endif
+
 };
 
-typedef	enum _RT_EEPROM_TYPE{
+typedef	enum _RT_EEPROM_TYPE {
 	EEPROM_93C46,
 	EEPROM_93C56,
 	EEPROM_BOOT_EFUSE,
-}RT_EEPROM_TYPE,*PRT_EEPROM_TYPE;
+} RT_EEPROM_TYPE, *PRT_EEPROM_TYPE;
 
 
 
 #define RF_CHANGE_BY_INIT	0
-#define RF_CHANGE_BY_IPS 	BIT28
-#define RF_CHANGE_BY_PS 	BIT29
-#define RF_CHANGE_BY_HW 	BIT30
-#define RF_CHANGE_BY_SW 	BIT31
+#define RF_CHANGE_BY_IPS	BIT28
+#define RF_CHANGE_BY_PS	BIT29
+#define RF_CHANGE_BY_HW	BIT30
+#define RF_CHANGE_BY_SW	BIT31
 
-typedef enum _HARDWARE_TYPE{
+typedef enum _HARDWARE_TYPE {
 	HARDWARE_TYPE_RTL8188EE,
 	HARDWARE_TYPE_RTL8188EU,
 	HARDWARE_TYPE_RTL8188ES,
-//	NEW_GENERATION_IC
+	/*	NEW_GENERATION_IC */
 	HARDWARE_TYPE_RTL8192EE,
 	HARDWARE_TYPE_RTL8192EU,
 	HARDWARE_TYPE_RTL8192ES,
@@ -421,51 +471,59 @@ typedef enum _HARDWARE_TYPE{
 	HARDWARE_TYPE_RTL8188FE,
 	HARDWARE_TYPE_RTL8188FU,
 	HARDWARE_TYPE_RTL8188FS,
+	HARDWARE_TYPE_RTL8188GTVU,
+	HARDWARE_TYPE_RTL8188GTVS,
+	HARDWARE_TYPE_RTL8723DE,
+	HARDWARE_TYPE_RTL8723DU,
+	HARDWARE_TYPE_RTL8723DS,
+	HARDWARE_TYPE_RTL8821CE,
+	HARDWARE_TYPE_RTL8821CU,
+	HARDWARE_TYPE_RTL8821CS,
 	HARDWARE_TYPE_MAX,
-}HARDWARE_TYPE;
+} HARDWARE_TYPE;
 
 #define IS_NEW_GENERATION_IC(_Adapter)	(rtw_get_hw_type(_Adapter) >= HARDWARE_TYPE_RTL8192EE)
-//
-// RTL8188E Series
-//
+/*
+ * RTL8188E Series
+ *   */
 #define IS_HARDWARE_TYPE_8188EE(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188EE)
 #define IS_HARDWARE_TYPE_8188EU(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188EU)
 #define IS_HARDWARE_TYPE_8188ES(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188ES)
 #define	IS_HARDWARE_TYPE_8188E(_Adapter)	\
-(IS_HARDWARE_TYPE_8188EE(_Adapter) || IS_HARDWARE_TYPE_8188EU(_Adapter) || IS_HARDWARE_TYPE_8188ES(_Adapter))
+	(IS_HARDWARE_TYPE_8188EE(_Adapter) || IS_HARDWARE_TYPE_8188EU(_Adapter) || IS_HARDWARE_TYPE_8188ES(_Adapter))
 
-// RTL8812 Series
+/* RTL8812 Series */
 #define IS_HARDWARE_TYPE_8812E(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8812E)
 #define IS_HARDWARE_TYPE_8812AU(_Adapter)	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8812AU)
 #define IS_HARDWARE_TYPE_8812(_Adapter)			\
-(IS_HARDWARE_TYPE_8812E(_Adapter) || IS_HARDWARE_TYPE_8812AU(_Adapter))
+	(IS_HARDWARE_TYPE_8812E(_Adapter) || IS_HARDWARE_TYPE_8812AU(_Adapter))
 
-// RTL8821 Series
+/* RTL8821 Series */
 #define IS_HARDWARE_TYPE_8821E(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821E)
 #define IS_HARDWARE_TYPE_8811AU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8811AU)
-#define IS_HARDWARE_TYPE_8821U(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821U ||	\
-													rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8811AU)
+#define IS_HARDWARE_TYPE_8821U(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821U || \
+		rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8811AU)
 #define IS_HARDWARE_TYPE_8821S(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821S)
 #define IS_HARDWARE_TYPE_8821(_Adapter)			\
-(IS_HARDWARE_TYPE_8821E(_Adapter) || IS_HARDWARE_TYPE_8821U(_Adapter)|| IS_HARDWARE_TYPE_8821S(_Adapter))
+	(IS_HARDWARE_TYPE_8821E(_Adapter) || IS_HARDWARE_TYPE_8821U(_Adapter) || IS_HARDWARE_TYPE_8821S(_Adapter))
 
 #define IS_HARDWARE_TYPE_JAGUAR(_Adapter)		\
-(IS_HARDWARE_TYPE_8812(_Adapter) || IS_HARDWARE_TYPE_8821(_Adapter))
+	(IS_HARDWARE_TYPE_8812(_Adapter) || IS_HARDWARE_TYPE_8821(_Adapter))
 
-//RTL8192E Series
+/* RTL8192E Series */
 #define IS_HARDWARE_TYPE_8192EE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192EE)
 #define IS_HARDWARE_TYPE_8192EU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192EU)
 #define IS_HARDWARE_TYPE_8192ES(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192ES)
 
 #define IS_HARDWARE_TYPE_8192E(_Adapter)		\
-(IS_HARDWARE_TYPE_8192EE(_Adapter) || IS_HARDWARE_TYPE_8192EU(_Adapter) ||IS_HARDWARE_TYPE_8192ES(_Adapter))
+	(IS_HARDWARE_TYPE_8192EE(_Adapter) || IS_HARDWARE_TYPE_8192EU(_Adapter) || IS_HARDWARE_TYPE_8192ES(_Adapter))
 
 #define IS_HARDWARE_TYPE_8723BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723BE)
 #define IS_HARDWARE_TYPE_8723BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723BU)
 #define IS_HARDWARE_TYPE_8723BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723BS)
 
 #define IS_HARDWARE_TYPE_8723B(_Adapter) \
-	(IS_HARDWARE_TYPE_8723BE(_Adapter) || IS_HARDWARE_TYPE_8723BU(_Adapter) ||IS_HARDWARE_TYPE_8723BS(_Adapter))
+	(IS_HARDWARE_TYPE_8723BE(_Adapter) || IS_HARDWARE_TYPE_8723BU(_Adapter) || IS_HARDWARE_TYPE_8723BS(_Adapter))
 
 /* RTL8814A Series */
 #define IS_HARDWARE_TYPE_8814AE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8814AE)
@@ -473,40 +531,63 @@ typedef enum _HARDWARE_TYPE{
 #define IS_HARDWARE_TYPE_8814AS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8814AS)
 
 #define IS_HARDWARE_TYPE_8814A(_Adapter)		\
-(IS_HARDWARE_TYPE_8814AE(_Adapter) || IS_HARDWARE_TYPE_8814AU(_Adapter) || IS_HARDWARE_TYPE_8814AS(_Adapter))
-
-#define IS_HARDWARE_TYPE_JAGUAR2(_Adapter)		\
-(IS_HARDWARE_TYPE_8814A(_Adapter) || IS_HARDWARE_TYPE_8821B(_Adapter) || IS_HARDWARE_TYPE_8822B(_Adapter))
-
-#define IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(_Adapter)		\
-(IS_HARDWARE_TYPE_JAGUAR(_Adapter) || IS_HARDWARE_TYPE_JAGUAR2(_Adapter))
+	(IS_HARDWARE_TYPE_8814AE(_Adapter) || IS_HARDWARE_TYPE_8814AU(_Adapter) || IS_HARDWARE_TYPE_8814AS(_Adapter))
 
 /* RTL8703B Series */
 #define IS_HARDWARE_TYPE_8703BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8703BE)
 #define IS_HARDWARE_TYPE_8703BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8703BS)
 #define IS_HARDWARE_TYPE_8703BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8703BU)
 #define	IS_HARDWARE_TYPE_8703B(_Adapter)			\
-(IS_HARDWARE_TYPE_8703BE(_Adapter) || IS_HARDWARE_TYPE_8703BU(_Adapter) || IS_HARDWARE_TYPE_8703BS(_Adapter))
+	(IS_HARDWARE_TYPE_8703BE(_Adapter) || IS_HARDWARE_TYPE_8703BU(_Adapter) || IS_HARDWARE_TYPE_8703BS(_Adapter))
+
+/* RTL8723D Series */
+#define IS_HARDWARE_TYPE_8723DE(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723DE)
+#define IS_HARDWARE_TYPE_8723DS(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723DS)
+#define IS_HARDWARE_TYPE_8723DU(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8723DU)
+#define	IS_HARDWARE_TYPE_8723D(_Adapter)\
+	(IS_HARDWARE_TYPE_8723DE(_Adapter) || \
+	 IS_HARDWARE_TYPE_8723DU(_Adapter) || \
+	 IS_HARDWARE_TYPE_8723DS(_Adapter))
 
 /* RTL8188F Series */
 #define IS_HARDWARE_TYPE_8188FE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FE)
 #define IS_HARDWARE_TYPE_8188FS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FS)
 #define IS_HARDWARE_TYPE_8188FU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FU)
 #define	IS_HARDWARE_TYPE_8188F(_Adapter)			\
-(IS_HARDWARE_TYPE_8188FE(_Adapter) || IS_HARDWARE_TYPE_8188FU(_Adapter) || IS_HARDWARE_TYPE_8188FS(_Adapter))
+	(IS_HARDWARE_TYPE_8188FE(_Adapter) || IS_HARDWARE_TYPE_8188FU(_Adapter) || IS_HARDWARE_TYPE_8188FS(_Adapter))
+
+#define IS_HARDWARE_TYPE_8188GTVU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188GTVU)
+#define IS_HARDWARE_TYPE_8188GTVS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188GTVS)
+#define	IS_HARDWARE_TYPE_8188GTV(_Adapter)			\
+	(IS_HARDWARE_TYPE_8188GTVU(_Adapter) || IS_HARDWARE_TYPE_8188GTVS(_Adapter))
 
 #define IS_HARDWARE_TYPE_8821BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BE)
 #define IS_HARDWARE_TYPE_8821BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BU)
 #define IS_HARDWARE_TYPE_8821BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BS)
 
 #define IS_HARDWARE_TYPE_8821B(_Adapter)		\
-(IS_HARDWARE_TYPE_8821BE(_Adapter) || IS_HARDWARE_TYPE_8821BU(_Adapter) || IS_HARDWARE_TYPE_8821BS(_Adapter))
+	(IS_HARDWARE_TYPE_8821BE(_Adapter) || IS_HARDWARE_TYPE_8821BU(_Adapter) || IS_HARDWARE_TYPE_8821BS(_Adapter))
 
 #define IS_HARDWARE_TYPE_8822BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8822BE)
 #define IS_HARDWARE_TYPE_8822BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8822BU)
 #define IS_HARDWARE_TYPE_8822BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8822BS)
 #define IS_HARDWARE_TYPE_8822B(_Adapter)		\
-(IS_HARDWARE_TYPE_8822BE(_Adapter) || IS_HARDWARE_TYPE_8822BU(_Adapter) || IS_HARDWARE_TYPE_8822BS(_Adapter))
+	(IS_HARDWARE_TYPE_8822BE(_Adapter) || IS_HARDWARE_TYPE_8822BU(_Adapter) || IS_HARDWARE_TYPE_8822BS(_Adapter))
+
+#define IS_HARDWARE_TYPE_8821CE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821CE)
+#define IS_HARDWARE_TYPE_8821CU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821CU)
+#define IS_HARDWARE_TYPE_8821CS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821CS)
+#define IS_HARDWARE_TYPE_8821C(_Adapter)		\
+	(IS_HARDWARE_TYPE_8821CE(_Adapter) || IS_HARDWARE_TYPE_8821CU(_Adapter) || IS_HARDWARE_TYPE_8821CS(_Adapter))
+
+#define IS_HARDWARE_TYPE_JAGUAR2(_Adapter)		\
+	(IS_HARDWARE_TYPE_8814A(_Adapter) || IS_HARDWARE_TYPE_8821B(_Adapter) || IS_HARDWARE_TYPE_8822B(_Adapter) || IS_HARDWARE_TYPE_8821C(_Adapter))
+
+#define IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(_Adapter)		\
+	(IS_HARDWARE_TYPE_JAGUAR(_Adapter) || IS_HARDWARE_TYPE_JAGUAR2(_Adapter))
 
 
 
@@ -518,24 +599,12 @@ typedef enum _wowlan_subcode {
 	WOWLAN_PATTERN_CLEAN		= 4
 } wowlan_subcode;
 
-struct wowlan_ioctl_param{
+struct wowlan_ioctl_param {
 	unsigned int subcode;
 	unsigned int subcode_value;
 	unsigned int wakeup_reason;
 };
 
-#define Rx_Pairwisekey			0x01
-#define Rx_GTK					0x02
-#define Rx_DisAssoc				0x04
-#define Rx_DeAuth				0x08
-#define Rx_ARPReq				0x09
-#define FWDecisionDisconnect	0x10
-#define Rx_MagicPkt				0x21
-#define Rx_UnicastPkt			0x22
-#define Rx_PatternPkt			0x23
-#define	RX_PNOWakeUp			0x55
-#define	AP_WakeUp			0x66
-
 u8 rtw_hal_data_init(_adapter *padapter);
 void rtw_hal_data_deinit(_adapter *padapter);
 
@@ -545,47 +614,50 @@ void	rtw_hal_free_data(_adapter *padapter);
 
 void rtw_hal_dm_init(_adapter *padapter);
 void rtw_hal_dm_deinit(_adapter *padapter);
+#ifdef CONFIG_RTW_SW_LED
 void rtw_hal_sw_led_init(_adapter *padapter);
 void rtw_hal_sw_led_deinit(_adapter *padapter);
-
+#endif
 u32 rtw_hal_power_on(_adapter *padapter);
 void rtw_hal_power_off(_adapter *padapter);
 
 uint rtw_hal_init(_adapter *padapter);
 uint rtw_hal_deinit(_adapter *padapter);
 void rtw_hal_stop(_adapter *padapter);
-void rtw_hal_set_hwreg(PADAPTER padapter, u8 variable, u8 *val);
+u8 rtw_hal_set_hwreg(PADAPTER padapter, u8 variable, u8 *val);
 void rtw_hal_get_hwreg(PADAPTER padapter, u8 variable, u8 *val);
 
-#ifdef CONFIG_C2H_PACKET_EN
-void rtw_hal_set_hwreg_with_buf(_adapter *padapter, u8 variable, u8 *pbuf, int len);
-#endif
-
 void rtw_hal_chip_configure(_adapter *padapter);
-void rtw_hal_read_chip_info(_adapter *padapter);
+u8 rtw_hal_read_chip_info(_adapter *padapter);
 void rtw_hal_read_chip_version(_adapter *padapter);
 
 u8 rtw_hal_set_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
 u8 rtw_hal_get_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
 
-void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,BOOLEAN bSet);
-void	rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,PVOID pValue2);
+void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, BOOLEAN bSet);
+void	rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, PVOID pValue2);
 
 void rtw_hal_enable_interrupt(_adapter *padapter);
 void rtw_hal_disable_interrupt(_adapter *padapter);
 
 u8 rtw_hal_check_ips_status(_adapter *padapter);
 
-#if defined(CONFIG_USB_HCI)||defined(CONFIG_PCI_HCI)
-u32	rtw_hal_inirp_init(_adapter *padapter);
-u32	rtw_hal_inirp_deinit(_adapter *padapter);
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
+	u32	rtw_hal_inirp_init(_adapter *padapter);
+	u32	rtw_hal_inirp_deinit(_adapter *padapter);
 #endif
 
 #if defined(CONFIG_PCI_HCI)
-void	rtw_hal_irp_reset(_adapter *padapter);
+	void	rtw_hal_irp_reset(_adapter *padapter);
+void	rtw_hal_pci_dbi_write(_adapter *padapter, u16 addr, u8 data);
+u8	rtw_hal_pci_dbi_read(_adapter *padapter, u16 addr);
+void	rtw_hal_pci_mdio_write(_adapter *padapter, u8 addr, u16 data);
+u16	rtw_hal_pci_mdio_read(_adapter *padapter, u8 addr);
+u8	rtw_hal_pci_l1off_nic_support(_adapter *padapter);
+u8	rtw_hal_pci_l1off_capability(_adapter *padapter);
 #endif
 
-u8	rtw_hal_intf_ps_func(_adapter *padapter,HAL_INTF_PS_FUNC efunc_id, u8* val);
+u8	rtw_hal_intf_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val);
 
 s32	rtw_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
 s32	rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe);
@@ -597,8 +669,7 @@ void	rtw_hal_free_xmit_priv(_adapter *padapter);
 s32	rtw_hal_init_recv_priv(_adapter *padapter);
 void	rtw_hal_free_recv_priv(_adapter *padapter);
 
-void rtw_hal_update_ra_mask(struct sta_info *psta, u8 rssi_level);
-void	rtw_hal_add_ra_tid(_adapter *padapter, u64 bitmap, u8 *arg, u8 rssi_level);
+void rtw_hal_update_ra_mask(struct sta_info *psta);
 
 void	rtw_hal_start_thread(_adapter *padapter);
 void	rtw_hal_stop_thread(_adapter *padapter);
@@ -607,38 +678,35 @@ void rtw_hal_bcn_related_reg_setting(_adapter *padapter);
 
 u32	rtw_hal_read_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask);
 void	rtw_hal_write_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
-u32	rtw_hal_read_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask);
-void	rtw_hal_write_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
+u32	rtw_hal_read_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask);
+void	rtw_hal_write_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
 
-#define PHY_QueryBBReg(Adapter, RegAddr, BitMask) rtw_hal_read_bbreg((Adapter), (RegAddr), (BitMask))
-#define PHY_SetBBReg(Adapter, RegAddr, BitMask, Data) rtw_hal_write_bbreg((Adapter), (RegAddr), (BitMask), (Data))
-#define PHY_QueryRFReg(Adapter, eRFPath, RegAddr, BitMask) rtw_hal_read_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask))
-#define PHY_SetRFReg(Adapter, eRFPath, RegAddr, BitMask, Data) rtw_hal_write_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask), (Data))
 
-#define PHY_SetMacReg	PHY_SetBBReg
-#define PHY_QueryMacReg PHY_QueryBBReg
+#define phy_query_bb_reg(Adapter, RegAddr, BitMask) rtw_hal_read_bbreg((Adapter), (RegAddr), (BitMask))
+#define phy_set_bb_reg(Adapter, RegAddr, BitMask, Data) rtw_hal_write_bbreg((Adapter), (RegAddr), (BitMask), (Data))
+#define phy_query_rf_reg(Adapter, eRFPath, RegAddr, BitMask) rtw_hal_read_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask))
+#define phy_set_rf_reg(Adapter, eRFPath, RegAddr, BitMask, Data) rtw_hal_write_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask), (Data))
+
+#define phy_set_mac_reg	phy_set_bb_reg
+#define phy_query_mac_reg phy_query_bb_reg
+
 
 #if defined(CONFIG_PCI_HCI)
-s32	rtw_hal_interrupt_handler(_adapter *padapter);
+	s32	rtw_hal_interrupt_handler(_adapter *padapter);
 #endif
 #if  defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
-void	rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+	void	rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
 
-void	rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth, u8 Offset40, u8 Offset80);
+void	rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80);
 void	rtw_hal_dm_watchdog(_adapter *padapter);
 void	rtw_hal_dm_watchdog_in_lps(_adapter *padapter);
 
 void	rtw_hal_set_tx_power_level(_adapter *padapter, u8 channel);
 void	rtw_hal_get_tx_power_level(_adapter *padapter, s32 *powerlevel);
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-u8	rtw_hal_antdiv_before_linked(_adapter *padapter);
-void	rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
-#endif
-
 #ifdef CONFIG_HOSTAPD_MLME
-s32	rtw_hal_hostap_mgnt_xmit_entry(_adapter *padapter, _pkt *pkt);
+	s32	rtw_hal_hostap_mgnt_xmit_entry(_adapter *padapter, _pkt *pkt);
 #endif
 
 #ifdef DBG_CONFIG_ERROR_DETECT
@@ -646,7 +714,7 @@ void rtw_hal_sreset_init(_adapter *padapter);
 void rtw_hal_sreset_reset(_adapter *padapter);
 void rtw_hal_sreset_reset_value(_adapter *padapter);
 void rtw_hal_sreset_xmit_status_check(_adapter *padapter);
-void rtw_hal_sreset_linked_status_check (_adapter *padapter);
+void rtw_hal_sreset_linked_status_check(_adapter *padapter);
 u8   rtw_hal_sreset_get_wifi_status(_adapter *padapter);
 bool rtw_hal_sreset_inprogress(_adapter *padapter);
 #endif
@@ -665,36 +733,61 @@ s32 rtw_hal_recv_hdl(_adapter *adapter);
 
 void rtw_hal_notch_filter(_adapter *adapter, bool enable);
 
+#ifdef CONFIG_FW_C2H_REG
+bool rtw_hal_c2h_reg_hdr_parse(_adapter *adapter, u8 *buf, u8 *id, u8 *seq, u8 *plen, u8 **payload);
 bool rtw_hal_c2h_valid(_adapter *adapter, u8 *buf);
 s32 rtw_hal_c2h_evt_read(_adapter *adapter, u8 *buf);
-s32 rtw_hal_c2h_handler(_adapter *adapter, u8 *c2h_evt);
-c2h_id_filter rtw_hal_c2h_id_filter_ccx(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_FW_C2H_PKT
+bool rtw_hal_c2h_pkt_hdr_parse(_adapter *adapter, u8 *buf, u16 len, u8 *id, u8 *seq, u8 *plen, u8 **payload);
+#endif
+
+s32 c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+#ifndef RTW_HALMAC
+s32 rtw_hal_c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+s32 rtw_hal_c2h_id_handle_directly(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+#endif
 
 s32 rtw_hal_is_disable_sw_channel_plan(PADAPTER padapter);
 
-s32 rtw_hal_macid_sleep(PADAPTER padapter, u8 macid);
-s32 rtw_hal_macid_wakeup(PADAPTER padapter, u8 macid);
+s32 rtw_hal_macid_sleep(_adapter *adapter, u8 macid);
+s32 rtw_hal_macid_wakeup(_adapter *adapter, u8 macid);
+s32 rtw_hal_macid_sleep_all_used(_adapter *adapter);
+s32 rtw_hal_macid_wakeup_all_used(_adapter *adapter);
 
 s32 rtw_hal_fill_h2c_cmd(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 void rtw_hal_fill_fake_txdesc(_adapter *padapter, u8 *pDesc, u32 BufferLen,
-		u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+			      u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
 u8 rtw_hal_get_txbuff_rsvd_page_num(_adapter *adapter, bool wowlan);
 
 #ifdef CONFIG_GPIO_API
 void rtw_hal_update_hisr_hsisr_ind(_adapter *padapter, u32 flag);
+int rtw_hal_gpio_func_check(_adapter *padapter, u8 gpio_num);
+void rtw_hal_gpio_multi_func_reset(_adapter *padapter, u8 gpio_num);
 #endif
 
 void rtw_hal_fw_correct_bcn(_adapter *padapter);
 s32 rtw_hal_fw_dl(_adapter *padapter, u8 wowlan);
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-void rtw_hal_clear_interrupt(_adapter *padapter);
+	void rtw_hal_clear_interrupt(_adapter *padapter);
 #endif
 
-void rtw_hal_set_tx_power_index(PADAPTER, u32 powerindex, u8 rfpath, u8 rate);
-u8 rtw_hal_get_tx_power_index(PADAPTER, u8 rfpath, u8 rate, u8 bandwidth, u8 channel,struct txpwr_idx_comp *tic);
+void rtw_hal_set_tx_power_index(PADAPTER adapter, u32 powerindex, enum rf_path rfpath, u8 rate);
+u8 rtw_hal_get_tx_power_index(PADAPTER adapter, enum rf_path
+	rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);
 
 u8 rtw_hal_ops_check(_adapter *padapter);
 
-#endif //__HAL_INTF_H__
+#ifdef RTW_HALMAC
+	u8 rtw_hal_init_mac_register(PADAPTER);
+	u8 rtw_hal_init_phy(PADAPTER);
+s32 rtw_hal_fw_mem_dl(_adapter *padapter, enum fw_mem mem);
+#endif /* RTW_HALMAC */
+
+#ifdef CONFIG_RFKILL_POLL
+bool rtw_hal_rfkill_poll(_adapter *adapter, u8 *valid);
+#endif
 
+#endif /* __HAL_INTF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_pg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_pg.h
index 72b62a19ddbb..37a3d2ba4894 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_pg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_pg.h
@@ -1,650 +1,807 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef __HAL_PG_H__
-#define __HAL_PG_H__
-
-#define PPG_BB_GAIN_2G_TX_OFFSET_MASK	0x0F
-#define PPG_BB_GAIN_2G_TXB_OFFSET_MASK	0xF0
-
-#define PPG_BB_GAIN_5G_TX_OFFSET_MASK	0x1F
-#define PPG_THERMAL_OFFSET_MASK			0x1F
-#define KFREE_BB_GAIN_2G_TX_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_2G_TX_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
-#define KFREE_BB_GAIN_5G_TX_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_5G_TX_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
-#define KFREE_THERMAL_OFFSET(_ppg_v) (((_ppg_v) == PPG_THERMAL_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
-
-//====================================================
-//			EEPROM/Efuse PG Offset for 88EE/88EU/88ES
-//====================================================
-#define EEPROM_TX_PWR_INX_88E					0x10
-
-#define EEPROM_ChannelPlan_88E					0xB8
-#define EEPROM_XTAL_88E						0xB9
-#define EEPROM_THERMAL_METER_88E				0xBA
-#define EEPROM_IQK_LCK_88E						0xBB
-
-#define EEPROM_RF_BOARD_OPTION_88E			0xC1
-#define EEPROM_RF_FEATURE_OPTION_88E			0xC2
-#define EEPROM_RF_BT_SETTING_88E				0xC3
-#define EEPROM_VERSION_88E						0xC4
-#define EEPROM_CustomID_88E					0xC5
-#define EEPROM_RF_ANTENNA_OPT_88E			0xC9
-#define EEPROM_COUNTRY_CODE_88E				0xCB
-
-// RTL88EE
-#define EEPROM_MAC_ADDR_88EE					0xD0
-#define EEPROM_VID_88EE						0xD6
-#define EEPROM_DID_88EE						0xD8
-#define EEPROM_SVID_88EE						0xDA
-#define EEPROM_SMID_88EE						0xDC
-
-//RTL88EU
-#define EEPROM_MAC_ADDR_88EU					0xD7
-#define EEPROM_VID_88EU						0xD0
-#define EEPROM_PID_88EU						0xD2
-#define EEPROM_USB_OPTIONAL_FUNCTION0		0xD4 //8188EU,8192EU, 8812AU is the same
-#define EEPROM_USB_OPTIONAL_FUNCTION0_8811AU 0x104
-
-// RTL88ES
-#define EEPROM_MAC_ADDR_88ES					0x11A
-//====================================================
-//			EEPROM/Efuse PG Offset for 8192EE/8192EU/8192ES
-//====================================================
-#define GET_PG_KFREE_ON_8192E(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
-#define GET_PG_KFREE_THERMAL_K_ON_8192E(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
-
-#define PPG_BB_GAIN_2G_TXA_OFFSET_8192E	0x1F6
-#define PPG_THERMAL_OFFSET_8192E		0x1F5
-
-// 0x10 ~ 0x63 = TX power area.
-#define	EEPROM_TX_PWR_INX_8192E				0x10
-
-#define	EEPROM_ChannelPlan_8192E				0xB8
-#define	EEPROM_XTAL_8192E						0xB9
-#define	EEPROM_THERMAL_METER_8192E			0xBA
-#define	EEPROM_IQK_LCK_8192E					0xBB
-#define	EEPROM_2G_5G_PA_TYPE_8192E			0xBC
-#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8192E	0xBD
-#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8192E	0xBF
-
-#define	EEPROM_RF_BOARD_OPTION_8192E		0xC1
-#define	EEPROM_RF_FEATURE_OPTION_8192E		0xC2
-#define	EEPROM_RF_BT_SETTING_8192E			0xC3
-#define	EEPROM_VERSION_8192E					0xC4
-#define	EEPROM_CustomID_8192E				0xC5
-#define	EEPROM_TX_BBSWING_2G_8192E			0xC6
-#define	EEPROM_TX_BBSWING_5G_8192E			0xC7
-#define	EEPROM_TX_PWR_CALIBRATE_RATE_8192E	0xC8
-#define	EEPROM_RF_ANTENNA_OPT_8192E			0xC9
-#define	EEPROM_RFE_OPTION_8192E				0xCA
-#define EEPROM_COUNTRY_CODE_8192E			0xCB
-
-// RTL8192EE
-#define	EEPROM_MAC_ADDR_8192EE				0xD0
-#define	EEPROM_VID_8192EE						0xD6
-#define	EEPROM_DID_8192EE						0xD8
-#define	EEPROM_SVID_8192EE					0xDA
-#define	EEPROM_SMID_8192EE					0xDC
-
-//RTL8192EU
-#define	EEPROM_MAC_ADDR_8192EU				0xD7
-#define	EEPROM_VID_8192EU						0xD0
-#define	EEPROM_PID_8192EU						0xD2
-#define 	EEPROM_PA_TYPE_8192EU               		0xBC
-#define 	EEPROM_LNA_TYPE_2G_8192EU           	0xBD
-#define 	EEPROM_LNA_TYPE_5G_8192EU           	0xBF
-
-// RTL8192ES
-#define	EEPROM_MAC_ADDR_8192ES				0x11A
-//====================================================
-//			EEPROM/Efuse PG Offset for 8812AE/8812AU/8812AS
-//====================================================
-// 0x10 ~ 0x63 = TX power area.
-#define EEPROM_USB_MODE_8812					0x08
-#define EEPROM_TX_PWR_INX_8812				0x10
-
-#define EEPROM_ChannelPlan_8812				0xB8
-#define EEPROM_XTAL_8812						0xB9
-#define EEPROM_THERMAL_METER_8812			0xBA
-#define EEPROM_IQK_LCK_8812					0xBB
-#define EEPROM_2G_5G_PA_TYPE_8812			0xBC
-#define EEPROM_2G_LNA_TYPE_GAIN_SEL_8812	0xBD
-#define EEPROM_5G_LNA_TYPE_GAIN_SEL_8812	0xBF
-
-#define EEPROM_RF_BOARD_OPTION_8812			0xC1
-#define EEPROM_RF_FEATURE_OPTION_8812		0xC2
-#define EEPROM_RF_BT_SETTING_8812				0xC3
-#define EEPROM_VERSION_8812					0xC4
-#define EEPROM_CustomID_8812					0xC5
-#define EEPROM_TX_BBSWING_2G_8812			0xC6
-#define EEPROM_TX_BBSWING_5G_8812			0xC7
-#define EEPROM_TX_PWR_CALIBRATE_RATE_8812	0xC8
-#define EEPROM_RF_ANTENNA_OPT_8812			0xC9
-#define EEPROM_RFE_OPTION_8812				0xCA
-#define EEPROM_COUNTRY_CODE_8812			0xCB
-
-// RTL8812AE
-#define EEPROM_MAC_ADDR_8812AE				0xD0
-#define EEPROM_VID_8812AE						0xD6
-#define EEPROM_DID_8812AE						0xD8
-#define EEPROM_SVID_8812AE						0xDA
-#define EEPROM_SMID_8812AE					0xDC
-
-//RTL8812AU
-#define EEPROM_MAC_ADDR_8812AU				0xD7
-#define EEPROM_VID_8812AU						0xD0
-#define EEPROM_PID_8812AU						0xD2
-#define EEPROM_PA_TYPE_8812AU					0xBC
-#define EEPROM_LNA_TYPE_2G_8812AU			0xBD
-#define EEPROM_LNA_TYPE_5G_8812AU			0xBF
-
-//RTL8814AU
-#define	EEPROM_MAC_ADDR_8814AU				0xD8
-#define	EEPROM_VID_8814AU						0xD0
-#define	EEPROM_PID_8814AU						0xD2
-#define	EEPROM_PA_TYPE_8814AU				0xBC
-#define	EEPROM_LNA_TYPE_2G_8814AU			0xBD
-#define	EEPROM_LNA_TYPE_5G_8814AU			0xBF
-
-/* RTL8814AE */
-#define EEPROM_MAC_ADDR_8814AE				0xD0
-#define EEPROM_VID_8814AE						0xD6
-#define EEPROM_DID_8814AE						0xD8
-#define EEPROM_SVID_8814AE						0xDA
-#define EEPROM_SMID_8814AE					0xDC
-
-//====================================================
-//			EEPROM/Efuse PG Offset for 8814AU
-//====================================================
-#define GET_PG_KFREE_ON_8814A(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 4, 1)
-#define GET_PG_KFREE_THERMAL_K_ON_8814A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
-#define GET_PG_TX_POWER_TRACKING_MODE_8814A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 6, 2)
-
-#define KFREE_GAIN_DATA_LENGTH_8814A	22
-
-#define PPG_BB_GAIN_2G_TXBA_OFFSET_8814A	0x3EE
-
-#define PPG_THERMAL_OFFSET_8814A		0x3EF
-
-#define EEPROM_TX_PWR_INX_8814				0x10
-#define EEPROM_ChannelPlan_8814				0xB8
-#define EEPROM_XTAL_8814					0xB9
-#define EEPROM_THERMAL_METER_8814			0xBA
-#define	EEPROM_IQK_LCK_8814					0xBB
-
-
-#define EEPROM_PA_TYPE_8814					0xBC
-#define EEPROM_LNA_TYPE_AB_2G_8814			0xBD
-#define	EEPROM_LNA_TYPE_CD_2G_8814			0xBE
-#define EEPROM_LNA_TYPE_AB_5G_8814			0xBF
-#define EEPROM_LNA_TYPE_CD_5G_8814			0xC0
-#define	EEPROM_RF_BOARD_OPTION_8814			0xC1
-#define	EEPROM_RF_BT_SETTING_8814			0xC3
-#define	EEPROM_VERSION_8814					0xC4
-#define	EEPROM_CustomID_8814				0xC5
-#define	EEPROM_TX_BBSWING_2G_8814			0xC6
-#define	EEPROM_TX_BBSWING_5G_8814			0xC7
-#define EEPROM_TRX_ANTENNA_OPTION_8814		0xC9
-#define	EEPROM_RFE_OPTION_8814				0xCA
-#define EEPROM_COUNTRY_CODE_8814			0xCB
-
-/*Extra Info for 8814A Initial Gain Fine Tune  suggested by Willis, JIRA: MP123*/
-#define	EEPROM_IG_OFFSET_4_AB_2G_8814A				0x120
-#define	EEPROM_IG_OFFSET_4_CD_2G_8814A				0x121
-#define	EEPROM_IG_OFFSET_4_AB_5GL_8814A				0x122
-#define	EEPROM_IG_OFFSET_4_CD_5GL_8814A				0x123
-#define	EEPROM_IG_OFFSET_4_AB_5GM_8814A				0x124
-#define	EEPROM_IG_OFFSET_4_CD_5GM_8814A				0x125
-#define	EEPROM_IG_OFFSET_4_AB_5GH_8814A				0x126
-#define	EEPROM_IG_OFFSET_4_CD_5GH_8814A				0x127
-
-//====================================================
-//			EEPROM/Efuse PG Offset for 8821AE/8821AU/8821AS
-//====================================================
-
-#define GET_PG_KFREE_ON_8821A(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 4, 1)
-#define GET_PG_KFREE_THERMAL_K_ON_8821A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
-
-#define PPG_BB_GAIN_2G_TXA_OFFSET_8821A		0x1F6
-#define PPG_THERMAL_OFFSET_8821A			0x1F5
-#define PPG_BB_GAIN_5GLB1_TXA_OFFSET_8821A	0x1F4
-#define PPG_BB_GAIN_5GLB2_TXA_OFFSET_8821A	0x1F3
-#define PPG_BB_GAIN_5GMB1_TXA_OFFSET_8821A	0x1F2
-#define PPG_BB_GAIN_5GMB2_TXA_OFFSET_8821A	0x1F1
-#define PPG_BB_GAIN_5GHB_TXA_OFFSET_8821A	0x1F0
-
-#define EEPROM_TX_PWR_INX_8821				0x10
-
-#define EEPROM_ChannelPlan_8821				0xB8
-#define EEPROM_XTAL_8821						0xB9
-#define EEPROM_THERMAL_METER_8821			0xBA
-#define EEPROM_IQK_LCK_8821					0xBB
-
-
-#define EEPROM_RF_BOARD_OPTION_8821			0xC1
-#define EEPROM_RF_FEATURE_OPTION_8821		0xC2
-#define EEPROM_RF_BT_SETTING_8821				0xC3
-#define EEPROM_VERSION_8821					0xC4
-#define EEPROM_CustomID_8821					0xC5
-#define EEPROM_RF_ANTENNA_OPT_8821			0xC9
-
-// RTL8821AE
-#define EEPROM_MAC_ADDR_8821AE				0xD0
-#define EEPROM_VID_8821AE						0xD6
-#define EEPROM_DID_8821AE						0xD8
-#define EEPROM_SVID_8821AE						0xDA
-#define EEPROM_SMID_8821AE					0xDC
-
-//RTL8821AU
-#define EEPROM_PA_TYPE_8821AU					0xBC
-#define EEPROM_LNA_TYPE_8821AU				0xBF
-
-// RTL8821AS
-#define EEPROM_MAC_ADDR_8821AS				0x11A
-
-//RTL8821AU
-#define EEPROM_MAC_ADDR_8821AU				0x107
-#define EEPROM_VID_8821AU						0x100
-#define EEPROM_PID_8821AU						0x102
-
-
-//====================================================
-//			EEPROM/Efuse PG Offset for 8192 SE/SU
-//====================================================
-#define EEPROM_VID_92SE						0x0A
-#define EEPROM_DID_92SE						0x0C
-#define EEPROM_SVID_92SE						0x0E
-#define EEPROM_SMID_92SE						0x10
-
-#define EEPROM_MAC_ADDR_92S					0x12
-
-#define EEPROM_TSSI_A_92SE						0x74
-#define EEPROM_TSSI_B_92SE						0x75
-
-#define EEPROM_Version_92SE					0x7C
-
-
-#define EEPROM_VID_92SU						0x08
-#define EEPROM_PID_92SU						0x0A 
-
-#define EEPROM_Version_92SU					0x50
-#define EEPROM_TSSI_A_92SU						0x6b 
-#define EEPROM_TSSI_B_92SU						0x6c 
-
-/* ====================================================
-	EEPROM/Efuse PG Offset for 8188FE/8188FU/8188FS
-   ====================================================
- */
-
-#define GET_PG_KFREE_ON_8188F(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
-#define GET_PG_KFREE_THERMAL_K_ON_8188F(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
-
-#define PPG_BB_GAIN_2G_TXA_OFFSET_8188F	0xEE
-#define PPG_THERMAL_OFFSET_8188F		0xEF
-
-/* 0x10 ~ 0x63 = TX power area. */
-#define	EEPROM_TX_PWR_INX_8188F				0x10
-
-#define	EEPROM_ChannelPlan_8188F			0xB8
-#define	EEPROM_XTAL_8188F					0xB9
-#define	EEPROM_THERMAL_METER_8188F			0xBA
-#define	EEPROM_IQK_LCK_8188F				0xBB
-#define	EEPROM_2G_5G_PA_TYPE_8188F			0xBC
-#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8188F	0xBD
-#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8188F	0xBF
-
-#define	EEPROM_RF_BOARD_OPTION_8188F		0xC1
-#define	EEPROM_FEATURE_OPTION_8188F			0xC2
-#define	EEPROM_RF_BT_SETTING_8188F			0xC3
-#define	EEPROM_VERSION_8188F				0xC4
-#define	EEPROM_CustomID_8188F				0xC5
-#define	EEPROM_TX_BBSWING_2G_8188F			0xC6
-#define	EEPROM_TX_PWR_CALIBRATE_RATE_8188F	0xC8
-#define	EEPROM_RF_ANTENNA_OPT_8188F			0xC9
-#define	EEPROM_RFE_OPTION_8188F				0xCA
-#define EEPROM_COUNTRY_CODE_8188F			0xCB
-#define EEPROM_CUSTOMER_ID_8188F			0x7F
-#define EEPROM_SUBCUSTOMER_ID_8188F			0x59
-
-/* RTL8188FU */
-#define EEPROM_MAC_ADDR_8188FU				0xD7
-#define EEPROM_VID_8188FU					0xD0
-#define EEPROM_PID_8188FU					0xD2
-#define EEPROM_PA_TYPE_8188FU				0xBC
-#define EEPROM_LNA_TYPE_2G_8188FU			0xBD
-#define EEPROM_USB_OPTIONAL_FUNCTION0_8188FU 0xD4
-
-/* RTL8188FS */
-#define	EEPROM_MAC_ADDR_8188FS				0x11A
-#define EEPROM_Voltage_ADDR_8188F			0x8
-
-//====================================================
-//			EEPROM/Efuse PG Offset for 8723BE/8723BU/8723BS
-//====================================================
-// 0x10 ~ 0x63 = TX power area.
-#define	EEPROM_TX_PWR_INX_8723B				0x10
-
-#define	EEPROM_ChannelPlan_8723B				0xB8
-#define	EEPROM_XTAL_8723B						0xB9
-#define	EEPROM_THERMAL_METER_8723B			0xBA
-#define	EEPROM_IQK_LCK_8723B					0xBB
-#define	EEPROM_2G_5G_PA_TYPE_8723B			0xBC
-#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8723B	0xBD
-#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8723B	0xBF
-
-#define	EEPROM_RF_BOARD_OPTION_8723B		0xC1
-#define	EEPROM_FEATURE_OPTION_8723B			0xC2
-#define	EEPROM_RF_BT_SETTING_8723B			0xC3
-#define	EEPROM_VERSION_8723B					0xC4
-#define	EEPROM_CustomID_8723B				0xC5
-#define	EEPROM_TX_BBSWING_2G_8723B			0xC6
-#define	EEPROM_TX_PWR_CALIBRATE_RATE_8723B	0xC8
-#define	EEPROM_RF_ANTENNA_OPT_8723B		0xC9
-#define	EEPROM_RFE_OPTION_8723B				0xCA
-#define EEPROM_COUNTRY_CODE_8723B			0xCB
-
-// RTL8723BE
-#define EEPROM_MAC_ADDR_8723BE				0xD0
-#define EEPROM_VID_8723BE						0xD6
-#define EEPROM_DID_8723BE						0xD8
-#define EEPROM_SVID_8723BE						0xDA
-#define EEPROM_SMID_8723BE						0xDC
-
-//RTL8723BU
-#define EEPROM_MAC_ADDR_8723BU				0x107
-#define EEPROM_VID_8723BU						0x100
-#define EEPROM_PID_8723BU						0x102
-#define EEPROM_PA_TYPE_8723BU					0xBC
-#define EEPROM_LNA_TYPE_2G_8723BU				0xBD
-
-
-//RTL8723BS
-#define	EEPROM_MAC_ADDR_8723BS				0x11A
-#define EEPROM_Voltage_ADDR_8723B			0x8
-
-//====================================================
-/*			EEPROM/Efuse PG Offset for 8703B		*/
-//====================================================
-#define GET_PG_KFREE_ON_8703B(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
-#define GET_PG_KFREE_THERMAL_K_ON_8703B(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
-
-#define PPG_BB_GAIN_2G_TXA_OFFSET_8703B	0xEE
-#define PPG_THERMAL_OFFSET_8703B		0xEF
-
-#define	EEPROM_TX_PWR_INX_8703B				0x10
-
-#define	EEPROM_ChannelPlan_8703B				0xB8
-#define	EEPROM_XTAL_8703B					0xB9
-#define	EEPROM_THERMAL_METER_8703B			0xBA
-#define	EEPROM_IQK_LCK_8703B					0xBB
-#define	EEPROM_2G_5G_PA_TYPE_8703B			0xBC
-#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8703B	0xBD
-#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8703B	0xBF
-
-#define	EEPROM_RF_BOARD_OPTION_8703B		0xC1
-#define	EEPROM_FEATURE_OPTION_8703B			0xC2
-#define	EEPROM_RF_BT_SETTING_8703B			0xC3
-#define	EEPROM_VERSION_8703B					0xC4
-#define	EEPROM_CustomID_8703B					0xC5
-#define	EEPROM_TX_BBSWING_2G_8703B			0xC6
-#define	EEPROM_TX_PWR_CALIBRATE_RATE_8703B	0xC8
-#define	EEPROM_RF_ANTENNA_OPT_8703B		0xC9
-#define	EEPROM_RFE_OPTION_8703B				0xCA
-#define EEPROM_COUNTRY_CODE_8703B			0xCB
-
-/* MAC Hidden */
-#define PPG_MAC_HIDDEN_START_8703B			0xF0
-#define PPG_MAC_HIDDEN_END_8703B			0xFF
-#define EEPROM_HCI_AND_PACKAGE_TYPE_8703B	0xF8
-#define EEPROM_WL_FUNC_CAP_8703B			0xF9
-#define EEPROM_BW_AND_ANT_NUM_CAP_8703B		0xFB
-#define GET_PMH_HCI_TYPE_8703B(_pmh_m)		LE_BITS_TO_1BYTE(((u8 *)(_pmh_m)) + EEPROM_HCI_AND_PACKAGE_TYPE_8703B - PPG_MAC_HIDDEN_START_8703B, 0, 4)
-#define	GET_PMH_PACKAGE_TYPE_8703B(_pmh_m)	LE_BITS_TO_1BYTE(((u8 *)(_pmh_m)) + EEPROM_HCI_AND_PACKAGE_TYPE_8703B - PPG_MAC_HIDDEN_START_8703B, 4, 4)
-#define GET_PMH_WL_FUNC_CAP_8703B(_pmh_m)	LE_BITS_TO_1BYTE(((u8 *)(_pmh_m)) + EEPROM_WL_FUNC_CAP_8703B - PPG_MAC_HIDDEN_START_8703B, 0, 4)
-#define GET_PMH_BW_CAP_8703B(_pmh_m)		LE_BITS_TO_1BYTE(((u8 *)(_pmh_m)) + EEPROM_BW_AND_ANT_NUM_CAP_8703B - PPG_MAC_HIDDEN_START_8703B, 0, 3)
-#define GET_PMH_ANT_NUM_CAP_8703B(_pmh_m)	LE_BITS_TO_1BYTE(((u8 *)(_pmh_m)) + EEPROM_BW_AND_ANT_NUM_CAP_8703B - PPG_MAC_HIDDEN_START_8703B, 5, 3)
-
-/* RTL8703BU */
-#define EEPROM_MAC_ADDR_8703BU                          0x107
-#define EEPROM_VID_8703BU                               0x100
-#define EEPROM_PID_8703BU                               0x102
-#define EEPROM_USB_OPTIONAL_FUNCTION0_8703BU            0x104
-#define EEPROM_PA_TYPE_8703BU                           0xBC
-#define EEPROM_LNA_TYPE_2G_8703BU                       0xBD
-
-//RTL8703BS
-#define	EEPROM_MAC_ADDR_8703BS				0x11A
-#define 	EEPROM_Voltage_ADDR_8703B			0x8
-
-//====================================================
-//			EEPROM/Efuse Value Type
-//====================================================
-#define EETYPE_TX_PWR							0x0
-//====================================================
-//			EEPROM/Efuse Default Value
-//====================================================
-#define EEPROM_CID_DEFAULT					0x0
-#define EEPROM_CID_DEFAULT_EXT				0xFF // Reserved for Realtek
-#define EEPROM_CID_TOSHIBA						0x4
-#define EEPROM_CID_CCX							0x10
-#define EEPROM_CID_QMI							0x0D
-#define EEPROM_CID_WHQL 						0xFE
-
-#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_TAIWAN		0xB
-#define EEPROM_CHANNEL_PLAN_CHIAN			0XC
-#define EEPROM_CHANNEL_PLAN_SINGAPORE_INDIA_MEXICO  0XD
-#define EEPROM_CHANNEL_PLAN_KOREA			0xE
-#define EEPROM_CHANNEL_PLAN_TURKEY              	0xF
-#define EEPROM_CHANNEL_PLAN_JAPAN                 	0x10
-#define EEPROM_CHANNEL_PLAN_FCC_NO_DFS		0x11
-#define EEPROM_CHANNEL_PLAN_JAPAN_NO_DFS	0x12
-#define EEPROM_CHANNEL_PLAN_WORLD_WIDE_5G	0x13
-#define EEPROM_CHANNEL_PLAN_TAIWAN_NO_DFS 	0x14
-
-#define EEPROM_USB_OPTIONAL1					0xE
-#define EEPROM_CHANNEL_PLAN_BY_HW_MASK		0x80
-
-#define RTL_EEPROM_ID							0x8129
-#define EEPROM_Default_TSSI						0x0
-#define EEPROM_Default_BoardType				0x02
-#define EEPROM_Default_ThermalMeter			0x12
-#define EEPROM_Default_ThermalMeter_92SU		0x7
-#define EEPROM_Default_ThermalMeter_88E		0x18
-#define EEPROM_Default_ThermalMeter_8812		0x18
-#define	EEPROM_Default_ThermalMeter_8192E			0x1A
-#define	EEPROM_Default_ThermalMeter_8723B		0x18
-#define	EEPROM_Default_ThermalMeter_8703B		0x18
-#define	EEPROM_Default_ThermalMeter_8188F		0x18
-#define EEPROM_Default_ThermalMeter_8814A		0x18
-
-
-#define EEPROM_Default_CrystalCap				0x0
-#define EEPROM_Default_CrystalCap_8723A		0x20
-#define EEPROM_Default_CrystalCap_88E 			0x20
-#define EEPROM_Default_CrystalCap_8812			0x20
-#define EEPROM_Default_CrystalCap_8814			0x20
-#define EEPROM_Default_CrystalCap_8192E			0x20
-#define EEPROM_Default_CrystalCap_8723B			0x20
-#define EEPROM_Default_CrystalCap_8703B			0x20
-#define EEPROM_Default_CrystalCap_8188F			0x20
-#define EEPROM_Default_CrystalFreq				0x0
-#define EEPROM_Default_TxPowerLevel_92C		0x22
-#define EEPROM_Default_TxPowerLevel_2G			0x2C
-#define EEPROM_Default_TxPowerLevel_5G			0x22
-#define EEPROM_Default_TxPowerLevel			0x22
-#define EEPROM_Default_HT40_2SDiff				0x0
-#define EEPROM_Default_HT20_Diff				2
-#define EEPROM_Default_LegacyHTTxPowerDiff		0x3
-#define EEPROM_Default_LegacyHTTxPowerDiff_92C	0x3
-#define EEPROM_Default_LegacyHTTxPowerDiff_92D	0x4	
-#define EEPROM_Default_HT40_PwrMaxOffset		0
-#define EEPROM_Default_HT20_PwrMaxOffset		0
-
-#define EEPROM_Default_PID						0x1234
-#define EEPROM_Default_VID						0x5678
-#define EEPROM_Default_CustomerID				0xAB
-#define EEPROM_Default_CustomerID_8188E		0x00
-#define EEPROM_Default_SubCustomerID			0xCD
-#define EEPROM_Default_Version					0
-
-#define EEPROM_Default_externalPA_C9		0x00
-#define EEPROM_Default_externalPA_CC		0xFF
-#define EEPROM_Default_internalPA_SP3T_C9	0xAA
-#define EEPROM_Default_internalPA_SP3T_CC	0xAF
-#define EEPROM_Default_internalPA_SPDT_C9	0xAA
-#ifdef CONFIG_PCI_HCI
-#define EEPROM_Default_internalPA_SPDT_CC	0xA0
-#else
-#define EEPROM_Default_internalPA_SPDT_CC	0xFA
-#endif
-#define EEPROM_Default_PAType						0
-#define EEPROM_Default_LNAType						0
-
-//New EFUSE deafult value
-#define EEPROM_DEFAULT_CHANNEL_PLAN		0x7F
-#define EEPROM_DEFAULT_BOARD_OPTION		0x00
-#define EEPROM_DEFAULT_RFE_OPTION_8192E 0xFF
-#define EEPROM_DEFAULT_RFE_OPTION		0x04
-#define EEPROM_DEFAULT_FEATURE_OPTION	0x00
-#define EEPROM_DEFAULT_BT_OPTION			0x10
-
-
-#define EEPROM_DEFAULT_TX_CALIBRATE_RATE	0x00
-
-// PCIe related
-#define	EEPROM_PCIE_DEV_CAP_01				0xE0 // Express device capability in PCIe configuration space, i.e., map to offset 0x74
-#define	EEPROM_PCIE_DEV_CAP_02				0xE1 // Express device capability in PCIe configuration space, i.e., map to offset 0x75
-
-
-//
-// For VHT series TX power by rate table.
-// VHT TX power by rate off setArray = 
-// Band:-2G&5G = 0 / 1
-// RF: at most 4*4 = ABCD=0/1/2/3
-// CCK=0 OFDM=1/2 HT-MCS 0-15=3/4/56 VHT=7/8/9/10/11			
-//
-#define TX_PWR_BY_RATE_NUM_BAND			2
-#define TX_PWR_BY_RATE_NUM_RF			4
-#define TX_PWR_BY_RATE_NUM_RATE			84
-
-#define TXPWR_LMT_MAX_RF				4
-
-//----------------------------------------------------------------------------
-//       EEPROM/EFUSE data structure definition.
-//----------------------------------------------------------------------------
-
-//For 88E new structure
-
-/*
-2.4G: 
-{
-{1,2},
-{3,4,5},
-{6,7,8},
-{9,10,11},
-{12,13},
-{14}
-}
-
-5G:
-{
-{36,38,40},
-{44,46,48},
-{52,54,56},
-{60,62,64},
-{100,102,104},
-{108,110,112},
-{116,118,120},
-{124,126,128},
-{132,134,136},
-{140,142,144},
-{149,151,153},
-{157,159,161},
-{173,175,177},
-}
-*/
-#define	MAX_RF_PATH				4
-#define RF_PATH_MAX				MAX_RF_PATH	
-#define	MAX_CHNL_GROUP_24G		6 
-#define	MAX_CHNL_GROUP_5G		14 
-
-//It must always set to 4, otherwise read efuse table secquence will be wrong.
-#define 	MAX_TX_COUNT				4
-
-typedef struct _TxPowerInfo24G{
-	u8 IndexCCK_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];
-	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];
-	//If only one tx, only BW20 and OFDM are used.
-	s8 CCK_Diff[MAX_RF_PATH][MAX_TX_COUNT];	
-	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-}TxPowerInfo24G, *PTxPowerInfo24G;
-
-typedef struct _TxPowerInfo5G{
-	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_5G];
-	//If only one tx, only BW20, OFDM, BW80 and BW160 are used.
-	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-	s8 BW80_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-	s8 BW160_Diff[MAX_RF_PATH][MAX_TX_COUNT];
-}TxPowerInfo5G, *PTxPowerInfo5G;
-
-
-typedef	enum _BT_Ant_NUM{
-	Ant_x2	= 0,		
-	Ant_x1	= 1
-} BT_Ant_NUM, *PBT_Ant_NUM;
-
-typedef	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,
-	BT_RTL8821		= 7,
-	BT_RTL8723B		= 8,
-	BT_RTL8192E		= 9,
-	BT_RTL8814A		= 10,
-	BT_RTL8812A		= 11,
-	BT_RTL8703B		= 12
-} BT_CoType, *PBT_CoType;
-
-typedef	enum _BT_RadioShared{
-	BT_Radio_Shared 	= 0,	
-	BT_Radio_Individual	= 1,
-} BT_RadioShared, *PBT_RadioShared;
-
-
-#endif
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_PG_H__
+#define __HAL_PG_H__
+
+#define PPG_BB_GAIN_2G_TX_OFFSET_MASK	0x0F
+#define PPG_BB_GAIN_2G_TXB_OFFSET_MASK	0xF0
+
+#define PPG_BB_GAIN_5G_TX_OFFSET_MASK	0x1F
+#define PPG_THERMAL_OFFSET_MASK			0x1F
+#define KFREE_BB_GAIN_2G_TX_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_2G_TX_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
+#define KFREE_BB_GAIN_2G_TXB_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_2G_TXB_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x10) ? ((_ppg_v) >> 5) : (-((_ppg_v) >> 5))))
+#define KFREE_BB_GAIN_5G_TX_OFFSET(_ppg_v) (((_ppg_v) == PPG_BB_GAIN_5G_TX_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
+#define KFREE_THERMAL_OFFSET(_ppg_v) (((_ppg_v) == PPG_THERMAL_OFFSET_MASK) ? 0 : (((_ppg_v) & 0x01) ? ((_ppg_v) >> 1) : (-((_ppg_v) >> 1))))
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 88EE/88EU/88ES
+ * **************************************************** */
+#define EEPROM_ChannelPlan_88E					0xB8
+#define EEPROM_XTAL_88E						0xB9
+#define EEPROM_THERMAL_METER_88E				0xBA
+#define EEPROM_IQK_LCK_88E						0xBB
+
+#define EEPROM_RF_BOARD_OPTION_88E			0xC1
+#define EEPROM_RF_FEATURE_OPTION_88E			0xC2
+#define EEPROM_RF_BT_SETTING_88E				0xC3
+#define EEPROM_VERSION_88E						0xC4
+#define EEPROM_CustomID_88E					0xC5
+#define EEPROM_RF_ANTENNA_OPT_88E			0xC9
+#define EEPROM_COUNTRY_CODE_88E				0xCB
+
+/* RTL88EE */
+#define EEPROM_MAC_ADDR_88EE					0xD0
+#define EEPROM_VID_88EE						0xD6
+#define EEPROM_DID_88EE						0xD8
+#define EEPROM_SVID_88EE						0xDA
+#define EEPROM_SMID_88EE						0xDC
+
+/* RTL88EU */
+#define EEPROM_MAC_ADDR_88EU					0xD7
+#define EEPROM_VID_88EU						0xD0
+#define EEPROM_PID_88EU						0xD2
+#define EEPROM_USB_OPTIONAL_FUNCTION0		0xD4 /* 8188EU, 8192EU, 8812AU is the same */
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8811AU 0x104
+
+/* RTL88ES */
+#define EEPROM_MAC_ADDR_88ES					0x11A
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8192EE/8192EU/8192ES
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8192E(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8192E(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8192E	0x1F6
+#define PPG_THERMAL_OFFSET_8192E		0x1F5
+
+#define	EEPROM_ChannelPlan_8192E				0xB8
+#define	EEPROM_XTAL_8192E						0xB9
+#define	EEPROM_THERMAL_METER_8192E			0xBA
+#define	EEPROM_IQK_LCK_8192E					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8192E			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8192E	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8192E	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8192E		0xC1
+#define	EEPROM_RF_FEATURE_OPTION_8192E		0xC2
+#define	EEPROM_RF_BT_SETTING_8192E			0xC3
+#define	EEPROM_VERSION_8192E					0xC4
+#define	EEPROM_CustomID_8192E				0xC5
+#define	EEPROM_TX_BBSWING_2G_8192E			0xC6
+#define	EEPROM_TX_BBSWING_5G_8192E			0xC7
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8192E	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8192E			0xC9
+#define	EEPROM_RFE_OPTION_8192E				0xCA
+#define	EEPROM_RFE_OPTION_8188E				0xCA
+#define EEPROM_COUNTRY_CODE_8192E			0xCB
+
+/* RTL8192EE */
+#define	EEPROM_MAC_ADDR_8192EE				0xD0
+#define	EEPROM_VID_8192EE						0xD6
+#define	EEPROM_DID_8192EE						0xD8
+#define	EEPROM_SVID_8192EE					0xDA
+#define	EEPROM_SMID_8192EE					0xDC
+
+/* RTL8192EU */
+#define	EEPROM_MAC_ADDR_8192EU				0xD7
+#define	EEPROM_VID_8192EU						0xD0
+#define	EEPROM_PID_8192EU						0xD2
+#define	EEPROM_PA_TYPE_8192EU		0xBC
+#define	EEPROM_LNA_TYPE_2G_8192EU	0xBD
+#define	EEPROM_LNA_TYPE_5G_8192EU	0xBF
+
+/* RTL8192ES */
+#define	EEPROM_MAC_ADDR_8192ES				0x11A
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8812AE/8812AU/8812AS
+ * *****************************************************/
+#define EEPROM_USB_MODE_8812					0x08
+
+#define EEPROM_ChannelPlan_8812				0xB8
+#define EEPROM_XTAL_8812						0xB9
+#define EEPROM_THERMAL_METER_8812			0xBA
+#define EEPROM_IQK_LCK_8812					0xBB
+#define EEPROM_2G_5G_PA_TYPE_8812			0xBC
+#define EEPROM_2G_LNA_TYPE_GAIN_SEL_8812	0xBD
+#define EEPROM_5G_LNA_TYPE_GAIN_SEL_8812	0xBF
+
+#define EEPROM_RF_BOARD_OPTION_8812			0xC1
+#define EEPROM_RF_FEATURE_OPTION_8812		0xC2
+#define EEPROM_RF_BT_SETTING_8812				0xC3
+#define EEPROM_VERSION_8812					0xC4
+#define EEPROM_CustomID_8812					0xC5
+#define EEPROM_TX_BBSWING_2G_8812			0xC6
+#define EEPROM_TX_BBSWING_5G_8812			0xC7
+#define EEPROM_TX_PWR_CALIBRATE_RATE_8812	0xC8
+#define EEPROM_RF_ANTENNA_OPT_8812			0xC9
+#define EEPROM_RFE_OPTION_8812				0xCA
+#define EEPROM_COUNTRY_CODE_8812			0xCB
+
+/* RTL8812AE */
+#define EEPROM_MAC_ADDR_8812AE				0xD0
+#define EEPROM_VID_8812AE						0xD6
+#define EEPROM_DID_8812AE						0xD8
+#define EEPROM_SVID_8812AE						0xDA
+#define EEPROM_SMID_8812AE					0xDC
+
+/* RTL8812AU */
+#define EEPROM_MAC_ADDR_8812AU				0xD7
+#define EEPROM_VID_8812AU						0xD0
+#define EEPROM_PID_8812AU						0xD2
+#define EEPROM_PA_TYPE_8812AU					0xBC
+#define EEPROM_LNA_TYPE_2G_8812AU			0xBD
+#define EEPROM_LNA_TYPE_5G_8812AU			0xBF
+
+/* RTL8814AU */
+#define	EEPROM_MAC_ADDR_8814AU				0xD8
+#define	EEPROM_VID_8814AU						0xD0
+#define	EEPROM_PID_8814AU						0xD2
+#define	EEPROM_PA_TYPE_8814AU				0xBC
+#define	EEPROM_LNA_TYPE_2G_8814AU			0xBD
+#define	EEPROM_LNA_TYPE_5G_8814AU			0xBF
+
+/* RTL8814AE */
+#define EEPROM_MAC_ADDR_8814AE				0xD0
+#define EEPROM_VID_8814AE						0xD6
+#define EEPROM_DID_8814AE						0xD8
+#define EEPROM_SVID_8814AE						0xDA
+#define EEPROM_SMID_8814AE					0xDC
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8814AU
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8814A(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8814A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+#define GET_PG_TX_POWER_TRACKING_MODE_8814A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 6, 2)
+
+#define KFREE_GAIN_DATA_LENGTH_8814A	22
+
+#define PPG_BB_GAIN_2G_TXBA_OFFSET_8814A	0x3EE
+
+#define PPG_THERMAL_OFFSET_8814A		0x3EF
+
+#define EEPROM_USB_MODE_8814A				0x0E
+#define EEPROM_ChannelPlan_8814				0xB8
+#define EEPROM_XTAL_8814					0xB9
+#define EEPROM_THERMAL_METER_8814			0xBA
+#define	EEPROM_IQK_LCK_8814					0xBB
+
+
+#define EEPROM_PA_TYPE_8814					0xBC
+#define EEPROM_LNA_TYPE_AB_2G_8814			0xBD
+#define	EEPROM_LNA_TYPE_CD_2G_8814			0xBE
+#define EEPROM_LNA_TYPE_AB_5G_8814			0xBF
+#define EEPROM_LNA_TYPE_CD_5G_8814			0xC0
+#define	EEPROM_RF_BOARD_OPTION_8814			0xC1
+#define	EEPROM_RF_BT_SETTING_8814			0xC3
+#define	EEPROM_VERSION_8814					0xC4
+#define	EEPROM_CustomID_8814				0xC5
+#define	EEPROM_TX_BBSWING_2G_8814			0xC6
+#define	EEPROM_TX_BBSWING_5G_8814			0xC7
+#define EEPROM_TRX_ANTENNA_OPTION_8814		0xC9
+#define	EEPROM_RFE_OPTION_8814				0xCA
+#define EEPROM_COUNTRY_CODE_8814			0xCB
+
+/*Extra Info for 8814A Initial Gain Fine Tune  suggested by Willis, JIRA: MP123*/
+#define	EEPROM_IG_OFFSET_4_AB_2G_8814A				0x120
+#define	EEPROM_IG_OFFSET_4_CD_2G_8814A				0x121
+#define	EEPROM_IG_OFFSET_4_AB_5GL_8814A				0x122
+#define	EEPROM_IG_OFFSET_4_CD_5GL_8814A				0x123
+#define	EEPROM_IG_OFFSET_4_AB_5GM_8814A				0x124
+#define	EEPROM_IG_OFFSET_4_CD_5GM_8814A				0x125
+#define	EEPROM_IG_OFFSET_4_AB_5GH_8814A				0x126
+#define	EEPROM_IG_OFFSET_4_CD_5GH_8814A				0x127
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8821AE/8821AU/8821AS
+ * **************************************************** */
+
+#define GET_PG_KFREE_ON_8821A(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8821A(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8821A		0x1F6
+#define PPG_THERMAL_OFFSET_8821A			0x1F5
+#define PPG_BB_GAIN_5GLB1_TXA_OFFSET_8821A	0x1F4
+#define PPG_BB_GAIN_5GLB2_TXA_OFFSET_8821A	0x1F3
+#define PPG_BB_GAIN_5GMB1_TXA_OFFSET_8821A	0x1F2
+#define PPG_BB_GAIN_5GMB2_TXA_OFFSET_8821A	0x1F1
+#define PPG_BB_GAIN_5GHB_TXA_OFFSET_8821A	0x1F0
+
+#define EEPROM_ChannelPlan_8821				0xB8
+#define EEPROM_XTAL_8821						0xB9
+#define EEPROM_THERMAL_METER_8821			0xBA
+#define EEPROM_IQK_LCK_8821					0xBB
+
+
+#define EEPROM_RF_BOARD_OPTION_8821			0xC1
+#define EEPROM_RF_FEATURE_OPTION_8821		0xC2
+#define EEPROM_RF_BT_SETTING_8821				0xC3
+#define EEPROM_VERSION_8821					0xC4
+#define EEPROM_CustomID_8821					0xC5
+#define EEPROM_RF_ANTENNA_OPT_8821			0xC9
+
+/* RTL8821AE */
+#define EEPROM_MAC_ADDR_8821AE				0xD0
+#define EEPROM_VID_8821AE						0xD6
+#define EEPROM_DID_8821AE						0xD8
+#define EEPROM_SVID_8821AE						0xDA
+#define EEPROM_SMID_8821AE					0xDC
+
+/* RTL8821AU */
+#define EEPROM_PA_TYPE_8821AU					0xBC
+#define EEPROM_LNA_TYPE_8821AU				0xBF
+
+/* RTL8821AS */
+#define EEPROM_MAC_ADDR_8821AS				0x11A
+
+/* RTL8821AU */
+#define EEPROM_MAC_ADDR_8821AU				0x107
+#define EEPROM_VID_8821AU						0x100
+#define EEPROM_PID_8821AU						0x102
+
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8192 SE/SU
+ * **************************************************** */
+#define EEPROM_VID_92SE						0x0A
+#define EEPROM_DID_92SE						0x0C
+#define EEPROM_SVID_92SE						0x0E
+#define EEPROM_SMID_92SE						0x10
+
+#define EEPROM_MAC_ADDR_92S					0x12
+
+#define EEPROM_TSSI_A_92SE						0x74
+#define EEPROM_TSSI_B_92SE						0x75
+
+#define EEPROM_Version_92SE					0x7C
+
+
+#define EEPROM_VID_92SU						0x08
+#define EEPROM_PID_92SU						0x0A
+
+#define EEPROM_Version_92SU					0x50
+#define EEPROM_TSSI_A_92SU						0x6b
+#define EEPROM_TSSI_B_92SU						0x6c
+
+/* ====================================================
+	EEPROM/Efuse PG Offset for 8188FE/8188FU/8188FS
+   ====================================================
+ */
+
+#define GET_PG_KFREE_ON_8188F(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8188F(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8188F	0xEE
+#define PPG_THERMAL_OFFSET_8188F		0xEF
+
+#define	EEPROM_ChannelPlan_8188F			0xB8
+#define	EEPROM_XTAL_8188F					0xB9
+#define	EEPROM_THERMAL_METER_8188F			0xBA
+#define	EEPROM_IQK_LCK_8188F				0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8188F			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8188F	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8188F	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8188F		0xC1
+#define	EEPROM_FEATURE_OPTION_8188F			0xC2
+#define	EEPROM_RF_BT_SETTING_8188F			0xC3
+#define	EEPROM_VERSION_8188F				0xC4
+#define	EEPROM_CustomID_8188F				0xC5
+#define	EEPROM_TX_BBSWING_2G_8188F			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8188F	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8188F			0xC9
+#define	EEPROM_RFE_OPTION_8188F				0xCA
+#define EEPROM_COUNTRY_CODE_8188F			0xCB
+#define EEPROM_CUSTOMER_ID_8188F			0x7F
+#define EEPROM_SUBCUSTOMER_ID_8188F			0x59
+
+/* RTL8188FU */
+#define EEPROM_MAC_ADDR_8188FU				0xD7
+#define EEPROM_VID_8188FU					0xD0
+#define EEPROM_PID_8188FU					0xD2
+#define EEPROM_PA_TYPE_8188FU				0xBC
+#define EEPROM_LNA_TYPE_2G_8188FU			0xBD
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8188FU 0xD4
+
+/* RTL8188FS */
+#define	EEPROM_MAC_ADDR_8188FS				0x11A
+#define EEPROM_Voltage_ADDR_8188F			0x8
+
+/* ====================================================
+	EEPROM/Efuse PG Offset for 8188GTV/8188GTVS
+   ====================================================
+ */
+
+#define GET_PG_KFREE_ON_8188GTV(_pg_m)				LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8188GTV(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8188GTV	0xEE
+#define PPG_THERMAL_OFFSET_8188GTV			0xEF
+
+#define	EEPROM_ChannelPlan_8188GTV				0xB8
+#define	EEPROM_XTAL_8188GTV						0xB9
+#define	EEPROM_THERMAL_METER_8188GTV			0xBA
+#define	EEPROM_IQK_LCK_8188GTV					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8188GTV			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8188GTV		0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8188GTV		0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8188GTV			0xC1
+#define	EEPROM_FEATURE_OPTION_8188GTV			0xC2
+#define	EEPROM_RF_BT_SETTING_8188GTV			0xC3
+#define	EEPROM_VERSION_8188GTV					0xC4
+#define	EEPROM_CustomID_8188GTV					0xC5
+#define	EEPROM_TX_BBSWING_2G_8188GTV			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8188GTV	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8188GTV			0xC9
+#define	EEPROM_RFE_OPTION_8188GTV				0xCA
+#define EEPROM_COUNTRY_CODE_8188GTV				0xCB
+#define EEPROM_CUSTOMER_ID_8188GTV				0x7F
+#define EEPROM_SUBCUSTOMER_ID_8188GTV			0x59
+
+/* RTL8188GTVU */
+#define EEPROM_MAC_ADDR_8188GTVU				0xD7
+#define EEPROM_VID_8188GTVU						0xD0
+#define EEPROM_PID_8188GTVU						0xD2
+#define EEPROM_PA_TYPE_8188GTVU					0xBC
+#define EEPROM_LNA_TYPE_2G_8188GTVU				0xBD
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8188GTVU	0xD4
+
+/* RTL8188GTVS */
+#define	EEPROM_MAC_ADDR_8188GTVS				0x11A
+#define EEPROM_Voltage_ADDR_8188GTV				0x8
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8723BE/8723BU/8723BS
+ * *****************************************************/
+#define	EEPROM_ChannelPlan_8723B				0xB8
+#define	EEPROM_XTAL_8723B						0xB9
+#define	EEPROM_THERMAL_METER_8723B			0xBA
+#define	EEPROM_IQK_LCK_8723B					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8723B			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8723B	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8723B	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8723B		0xC1
+#define	EEPROM_FEATURE_OPTION_8723B			0xC2
+#define	EEPROM_RF_BT_SETTING_8723B			0xC3
+#define	EEPROM_VERSION_8723B					0xC4
+#define	EEPROM_CustomID_8723B				0xC5
+#define	EEPROM_TX_BBSWING_2G_8723B			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8723B	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8723B		0xC9
+#define	EEPROM_RFE_OPTION_8723B				0xCA
+#define EEPROM_COUNTRY_CODE_8723B			0xCB
+
+/* RTL8723BE */
+#define EEPROM_MAC_ADDR_8723BE				0xD0
+#define EEPROM_VID_8723BE						0xD6
+#define EEPROM_DID_8723BE						0xD8
+#define EEPROM_SVID_8723BE						0xDA
+#define EEPROM_SMID_8723BE						0xDC
+
+/* RTL8723BU */
+#define EEPROM_MAC_ADDR_8723BU				0x107
+#define EEPROM_VID_8723BU						0x100
+#define EEPROM_PID_8723BU						0x102
+#define EEPROM_PA_TYPE_8723BU					0xBC
+#define EEPROM_LNA_TYPE_2G_8723BU				0xBD
+
+
+/* RTL8723BS */
+#define	EEPROM_MAC_ADDR_8723BS				0x11A
+#define EEPROM_Voltage_ADDR_8723B			0x8
+
+/* ****************************************************
+ *			EEPROM/Efuse PG Offset for 8703B
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8703B(_pg_m)			LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8703B(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8703B	0xEE
+#define PPG_THERMAL_OFFSET_8703B		0xEF
+
+#define	EEPROM_ChannelPlan_8703B				0xB8
+#define	EEPROM_XTAL_8703B					0xB9
+#define	EEPROM_THERMAL_METER_8703B			0xBA
+#define	EEPROM_IQK_LCK_8703B					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8703B			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8703B	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8703B	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8703B		0xC1
+#define	EEPROM_FEATURE_OPTION_8703B			0xC2
+#define	EEPROM_RF_BT_SETTING_8703B			0xC3
+#define	EEPROM_VERSION_8703B					0xC4
+#define	EEPROM_CustomID_8703B					0xC5
+#define	EEPROM_TX_BBSWING_2G_8703B			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8703B	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8703B		0xC9
+#define	EEPROM_RFE_OPTION_8703B				0xCA
+#define EEPROM_COUNTRY_CODE_8703B			0xCB
+
+/* RTL8703BU */
+#define EEPROM_MAC_ADDR_8703BU                          0x107
+#define EEPROM_VID_8703BU                               0x100
+#define EEPROM_PID_8703BU                               0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8703BU            0x104
+#define EEPROM_PA_TYPE_8703BU                           0xBC
+#define EEPROM_LNA_TYPE_2G_8703BU                       0xBD
+
+/* RTL8703BS */
+#define	EEPROM_MAC_ADDR_8703BS				0x11A
+#define	EEPROM_Voltage_ADDR_8703B			0x8
+
+/*
+ * ====================================================
+ *	EEPROM/Efuse PG Offset for 8822B
+ * ====================================================
+ */
+#define	EEPROM_ChannelPlan_8822B		0xB8
+#define	EEPROM_XTAL_8822B			0xB9
+#define	EEPROM_THERMAL_METER_8822B		0xBA
+#define	EEPROM_IQK_LCK_8822B			0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8822B		0xBC
+/* PATH A & PATH B */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B	0xBD
+/* PATH C & PATH D */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_CD_8822B	0xBE
+/* PATH A & PATH B */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B	0xBF
+/* PATH C & PATH D */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_CD_8822B	0xC0
+
+#define	EEPROM_RF_BOARD_OPTION_8822B		0xC1
+#define	EEPROM_FEATURE_OPTION_8822B		0xC2
+#define	EEPROM_RF_BT_SETTING_8822B		0xC3
+#define	EEPROM_VERSION_8822B			0xC4
+#define	EEPROM_CustomID_8822B			0xC5
+#define	EEPROM_TX_BBSWING_2G_8822B		0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8822B	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8822B		0xC9
+#define	EEPROM_RFE_OPTION_8822B			0xCA
+#define EEPROM_COUNTRY_CODE_8822B		0xCB
+
+/* RTL8822BU */
+#define EEPROM_MAC_ADDR_8822BU			0x107
+#define EEPROM_VID_8822BU			0x100
+#define EEPROM_PID_8822BU			0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8822BU	0x104
+#define EEPROM_USB_MODE_8822BU			0x06
+
+/* RTL8822BS */
+#define	EEPROM_MAC_ADDR_8822BS			0x11A
+
+/* RTL8822BE */
+#define	EEPROM_MAC_ADDR_8822BE			0xD0
+/*
+ * ====================================================
+ *	EEPROM/Efuse PG Offset for 8821C
+ * ====================================================
+ */
+#define	EEPROM_CHANNEL_PLAN_8821C		0xB8
+#define	EEPROM_XTAL_8821C			0xB9
+#define	EEPROM_THERMAL_METER_8821C		0xBA
+#define	EEPROM_IQK_LCK_8821C			0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8821C		0xBC
+/* PATH A & PATH B */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8821C	0xBD
+/* PATH C & PATH D */
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_CD_8821C	0xBE
+/* PATH A & PATH B */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8821C	0xBF
+/* PATH C & PATH D */
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_CD_8821C	0xC0
+
+#define	EEPROM_RF_BOARD_OPTION_8821C		0xC1
+#define	EEPROM_FEATURE_OPTION_8821C		0xC2
+#define	EEPROM_RF_BT_SETTING_8821C		0xC3
+#define	EEPROM_VERSION_8821C			0xC4
+#define	EEPROM_CUSTOMER_ID_8821C			0xC5
+#define	EEPROM_TX_BBSWING_2G_8821C		0xC6
+#define	EEPROM_TX_BBSWING_5G_8821C		0xC7
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8821C	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8821C		0xC9
+#define	EEPROM_RFE_OPTION_8821C			0xCA
+#define EEPROM_COUNTRY_CODE_8821C		0xCB
+
+/* RTL8821CU */
+#define EEPROM_MAC_ADDR_8821CU			0x107
+#define EEPROM_VID_8821CU					0x100
+#define EEPROM_PID_8821CU					0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8821CU	0x104
+#define EEPROM_USB_MODE_8821CU			0x06
+
+/* RTL8821CS */
+#define	EEPROM_MAC_ADDR_8821CS			0x11A
+
+/* RTL8821CE */
+#define	EEPROM_MAC_ADDR_8821CE			0xD0
+/* ****************************************************
+ *	EEPROM/Efuse PG Offset for 8723D
+ * **************************************************** */
+#define GET_PG_KFREE_ON_8723D(_pg_m)	\
+	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8723D(_pg_m)	\
+	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_8723D_S1	0
+#define PPG_8723D_S0	1
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8723D		0xEE
+#define PPG_BB_GAIN_2G_TX_OFFSET_8723D		0x1EE
+#define PPG_THERMAL_OFFSET_8723D		0xEF
+
+#define	EEPROM_ChannelPlan_8723D		0xB8
+#define	EEPROM_XTAL_8723D			0xB9
+#define	EEPROM_THERMAL_METER_8723D		0xBA
+#define	EEPROM_IQK_LCK_8723D			0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8723D		0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8723D	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8723D	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8723D		0xC1
+#define	EEPROM_FEATURE_OPTION_8723D		0xC2
+#define	EEPROM_RF_BT_SETTING_8723D		0xC3
+#define	EEPROM_VERSION_8723D			0xC4
+#define	EEPROM_CustomID_8723D			0xC5
+#define	EEPROM_TX_BBSWING_2G_8723D		0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8723D	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8723D		0xC9
+#define	EEPROM_RFE_OPTION_8723D			0xCA
+#define EEPROM_COUNTRY_CODE_8723D		0xCB
+
+/* RTL8723DE */
+#define EEPROM_MAC_ADDR_8723DE              0xD0
+#define EEPROM_VID_8723DE                   0xD6
+#define EEPROM_DID_8723DE                   0xD8
+#define EEPROM_SVID_8723DE                  0xDA
+#define EEPROM_SMID_8723DE                  0xDC
+
+/* RTL8723DU */
+#define EEPROM_MAC_ADDR_8723DU                  0x107
+#define EEPROM_VID_8723DU                       0x100
+#define EEPROM_PID_8723DU                       0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8723DU    0x104
+
+/* RTL8723BS */
+#define	EEPROM_MAC_ADDR_8723DS			0x11A
+#define	EEPROM_Voltage_ADDR_8723D		0x8
+
+/* ****************************************************
+ *			EEPROM/Efuse Value Type
+ * **************************************************** */
+#define EETYPE_TX_PWR							0x0
+/* ****************************************************
+ *			EEPROM/Efuse Default Value
+ * **************************************************** */
+#define EEPROM_CID_DEFAULT					0x0
+#define EEPROM_CID_DEFAULT_EXT				0xFF /* Reserved for Realtek */
+#define EEPROM_CID_TOSHIBA						0x4
+#define EEPROM_CID_CCX							0x10
+#define EEPROM_CID_QMI							0x0D
+#define EEPROM_CID_WHQL						0xFE
+
+#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_TAIWAN		0xB
+#define EEPROM_CHANNEL_PLAN_CHIAN			0XC
+#define EEPROM_CHANNEL_PLAN_SINGAPORE_INDIA_MEXICO  0XD
+#define EEPROM_CHANNEL_PLAN_KOREA			0xE
+#define EEPROM_CHANNEL_PLAN_TURKEY	0xF
+#define EEPROM_CHANNEL_PLAN_JAPAN	0x10
+#define EEPROM_CHANNEL_PLAN_FCC_NO_DFS		0x11
+#define EEPROM_CHANNEL_PLAN_JAPAN_NO_DFS	0x12
+#define EEPROM_CHANNEL_PLAN_WORLD_WIDE_5G	0x13
+#define EEPROM_CHANNEL_PLAN_TAIWAN_NO_DFS	0x14
+
+#define EEPROM_USB_OPTIONAL1					0xE
+#define EEPROM_CHANNEL_PLAN_BY_HW_MASK		0x80
+
+#define RTL_EEPROM_ID							0x8129
+#define EEPROM_Default_TSSI						0x0
+#define EEPROM_Default_BoardType				0x02
+#define EEPROM_Default_ThermalMeter			0x12
+#define EEPROM_Default_ThermalMeter_92SU		0x7
+#define EEPROM_Default_ThermalMeter_88E		0x18
+#define EEPROM_Default_ThermalMeter_8812		0x18
+#define	EEPROM_Default_ThermalMeter_8192E			0x1A
+#define	EEPROM_Default_ThermalMeter_8723B		0x18
+#define	EEPROM_Default_ThermalMeter_8703B		0x18
+#define	EEPROM_Default_ThermalMeter_8723D		0x18
+#define	EEPROM_Default_ThermalMeter_8188F		0x18
+#define	EEPROM_Default_ThermalMeter_8188GTV		0x18
+#define EEPROM_Default_ThermalMeter_8814A		0x18
+
+
+#define EEPROM_Default_CrystalCap				0x0
+#define EEPROM_Default_CrystalCap_8723A		0x20
+#define EEPROM_Default_CrystalCap_88E			0x20
+#define EEPROM_Default_CrystalCap_8812			0x20
+#define EEPROM_Default_CrystalCap_8814			0x20
+#define EEPROM_Default_CrystalCap_8192E			0x20
+#define EEPROM_Default_CrystalCap_8723B			0x20
+#define EEPROM_Default_CrystalCap_8703B			0x20
+#define EEPROM_Default_CrystalCap_8723D			0x20
+#define EEPROM_Default_CrystalCap_8188F			0x20
+#define EEPROM_Default_CrystalCap_8188GTV		0x20
+#define EEPROM_Default_CrystalFreq				0x0
+#define EEPROM_Default_TxPowerLevel_92C		0x22
+#define EEPROM_Default_TxPowerLevel_2G			0x2C
+#define EEPROM_Default_TxPowerLevel_5G			0x22
+#define EEPROM_Default_TxPowerLevel			0x22
+#define EEPROM_Default_HT40_2SDiff				0x0
+#define EEPROM_Default_HT20_Diff				2
+#define EEPROM_Default_LegacyHTTxPowerDiff		0x3
+#define EEPROM_Default_LegacyHTTxPowerDiff_92C	0x3
+#define EEPROM_Default_LegacyHTTxPowerDiff_92D	0x4
+#define EEPROM_Default_HT40_PwrMaxOffset		0
+#define EEPROM_Default_HT20_PwrMaxOffset		0
+
+#define EEPROM_Default_PID						0x1234
+#define EEPROM_Default_VID						0x5678
+#define EEPROM_Default_CustomerID				0xAB
+#define EEPROM_Default_CustomerID_8188E		0x00
+#define EEPROM_Default_SubCustomerID			0xCD
+#define EEPROM_Default_Version					0
+
+#define EEPROM_Default_externalPA_C9		0x00
+#define EEPROM_Default_externalPA_CC		0xFF
+#define EEPROM_Default_internalPA_SP3T_C9	0xAA
+#define EEPROM_Default_internalPA_SP3T_CC	0xAF
+#define EEPROM_Default_internalPA_SPDT_C9	0xAA
+#ifdef CONFIG_PCI_HCI
+	#define EEPROM_Default_internalPA_SPDT_CC	0xA0
+#else
+	#define EEPROM_Default_internalPA_SPDT_CC	0xFA
+#endif
+#define EEPROM_Default_PAType						0
+#define EEPROM_Default_LNAType						0
+
+/* New EFUSE default value */
+#define EEPROM_DEFAULT_CHANNEL_PLAN		0x7F
+#define EEPROM_DEFAULT_BOARD_OPTION		0x00
+#define EEPROM_DEFAULT_RFE_OPTION_8192E 0xFF
+#define EEPROM_DEFAULT_RFE_OPTION_8188E 0xFF
+#define EEPROM_DEFAULT_RFE_OPTION		0x04
+#define EEPROM_DEFAULT_FEATURE_OPTION	0x00
+#define EEPROM_DEFAULT_BT_OPTION			0x10
+
+
+#define EEPROM_DEFAULT_TX_CALIBRATE_RATE	0x00
+
+/* PCIe related */
+#define	EEPROM_PCIE_DEV_CAP_01				0xE0 /* Express device capability in PCIe configuration space, i.e., map to offset 0x74 */
+#define	EEPROM_PCIE_DEV_CAP_02				0xE1 /* Express device capability in PCIe configuration space, i.e., map to offset 0x75 */
+
+
+/*
+ * For VHT series TX power by rate table.
+ * VHT TX power by rate off setArray =
+ * Band:-2G&5G = 0 / 1
+ * RF: at most 4*4 = ABCD=0/1/2/3
+ * CCK=0 OFDM=1/2 HT-MCS 0-15=3/4/56 VHT=7/8/9/10/11
+ *   */
+#define TX_PWR_BY_RATE_NUM_BAND			2
+#define TX_PWR_BY_RATE_NUM_RF			4
+#define TX_PWR_BY_RATE_NUM_RATE			84
+
+#define TXPWR_LMT_MAX_RF				4
+
+/* ----------------------------------------------------------------------------
+ * EEPROM/EFUSE data structure definition.
+ * ---------------------------------------------------------------------------- */
+
+/* For 88E new structure */
+
+/*
+2.4G:
+{
+{1,2},
+{3,4,5},
+{6,7,8},
+{9,10,11},
+{12,13},
+{14}
+}
+
+5G:
+{
+{36,38,40},
+{44,46,48},
+{52,54,56},
+{60,62,64},
+{100,102,104},
+{108,110,112},
+{116,118,120},
+{124,126,128},
+{132,134,136},
+{140,142,144},
+{149,151,153},
+{157,159,161},
+{173,175,177},
+}
+*/
+#define	MAX_RF_PATH				4
+#define RF_PATH_MAX				MAX_RF_PATH
+#define	MAX_CHNL_GROUP_24G		6
+#define	MAX_CHNL_GROUP_5G		14
+
+/* It must always set to 4, otherwise read efuse table sequence will be wrong. */
+#define	MAX_TX_COUNT				4
+
+typedef struct _TxPowerInfo24G {
+	u8 IndexCCK_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];
+	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];
+	/* If only one tx, only BW20 and OFDM are used. */
+	s8 CCK_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+} TxPowerInfo24G, *PTxPowerInfo24G;
+
+typedef struct _TxPowerInfo5G {
+	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_5G];
+	/* If only one tx, only BW20, OFDM, BW80 and BW160 are used. */
+	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW80_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+	s8 BW160_Diff[MAX_RF_PATH][MAX_TX_COUNT];
+} TxPowerInfo5G, *PTxPowerInfo5G;
+
+
+typedef	enum _BT_Ant_NUM {
+	Ant_x2	= 0,
+	Ant_x1	= 1
+} BT_Ant_NUM, *PBT_Ant_NUM;
+
+typedef	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,
+	BT_RTL8821		= 7,
+	BT_RTL8723B		= 8,
+	BT_RTL8192E		= 9,
+	BT_RTL8814A		= 10,
+	BT_RTL8812A		= 11,
+	BT_RTL8703B		= 12,
+	BT_RTL8822B		= 13,
+	BT_RTL8723D		= 14,
+	BT_RTL8821C		= 15
+} BT_CoType, *PBT_CoType;
+
+typedef	enum _BT_RadioShared {
+	BT_Radio_Shared	= 0,
+	BT_Radio_Individual	= 1,
+} BT_RadioShared, *PBT_RadioShared;
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy.h
index 56b50c800713..c369a7af3af6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,26 +12,21 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_PHY_H__
 #define __HAL_PHY_H__
 
 
 #if DISABLE_BB_RF
-#define	HAL_FW_ENABLE				0
-#define	HAL_MAC_ENABLE			0
-#define	HAL_BB_ENABLE				0
-#define	HAL_RF_ENABLE				0
-#else // FPGA_PHY and ASIC
-#define 	HAL_FW_ENABLE				1
-#define	HAL_MAC_ENABLE			1
-#define	HAL_BB_ENABLE				1
-#define	HAL_RF_ENABLE				1
+	#define	HAL_FW_ENABLE				0
+	#define	HAL_MAC_ENABLE			0
+	#define	HAL_BB_ENABLE				0
+	#define	HAL_RF_ENABLE				0
+#else /* FPGA_PHY and ASIC */
+	#define	HAL_FW_ENABLE				1
+	#define	HAL_MAC_ENABLE			1
+	#define	HAL_BB_ENABLE				1
+	#define	HAL_RF_ENABLE				1
 #endif
 
 #define	RF6052_MAX_TX_PWR			0x3F
@@ -38,17 +34,17 @@
 #define	RF6052_MAX_REG_92C			0x7F
 
 #define	RF6052_MAX_REG	\
-		(RF6052_MAX_REG_88E > RF6052_MAX_REG_92C) ? RF6052_MAX_REG_88E: RF6052_MAX_REG_92C
+	((RF6052_MAX_REG_88E > RF6052_MAX_REG_92C) ? RF6052_MAX_REG_88E : RF6052_MAX_REG_92C)
 
 #define GET_RF6052_REAL_MAX_REG(_Adapter)	\
-		IS_HARDWARE_TYPE_8188E(_Adapter) ? RF6052_MAX_REG_88E : RF6052_MAX_REG_92C
+	(IS_HARDWARE_TYPE_8188E(_Adapter) ? RF6052_MAX_REG_88E : RF6052_MAX_REG_92C)
 
 #define	RF6052_MAX_PATH				2
 
-//
-// Antenna detection method, i.e., using single tone detection or RSSI reported from each antenna detected. 
-// Added by Roger, 2013.05.22.
-//
+/*
+ * Antenna detection method, i.e., using single tone detection or RSSI reported from each antenna detected.
+ * Added by Roger, 2013.05.22.
+ *   */
 #define ANT_DETECT_BY_SINGLE_TONE	BIT0
 #define ANT_DETECT_BY_RSSI				BIT1
 #define IS_ANT_DETECT_SUPPORT_SINGLE_TONE(__Adapter)		((GET_HAL_DATA(__Adapter)->AntDetection) & ANT_DETECT_BY_SINGLE_TONE)
@@ -56,26 +52,18 @@
 
 
 /*--------------------------Define Parameters-------------------------------*/
-typedef	enum _RF_TYPE{
-	RF_TYPE_MIN = 0, 	// 0
-	RF_8225=1,			// 1 11b/g RF for verification only
-	RF_8256=2,			// 2 11b/g/n 
-	RF_8258=3,			// 3 11a/b/g/n RF
-	RF_6052=4,			// 4 11b/g/n RF
-	RF_PSEUDO_11N=5,	// 5, It is a temporality RF. 
-	RF_TYPE_MAX
-}RF_TYPE_E,*PRF_TYPE_E;
-
-#define	TX_1S			0			
-#define	TX_2S			1			
-#define	TX_3S			2			
-#define	TX_4S			3
-
-#define	RF_PATH_MAX_92C_88E 		2
-#define	RF_PATH_MAX_90_8812		4	//Max RF number 90 support 
-
-typedef enum _ANTENNA_PATH{
-       ANTENNA_NONE 	= 0,
+typedef	enum _RF_CHIP {
+	RF_CHIP_MIN = 0,	/* 0 */
+	RF_8225 = 1,			/* 1 11b/g RF for verification only */
+	RF_8256 = 2,			/* 2 11b/g/n */
+	RF_8258 = 3,			/* 3 11a/b/g/n RF */
+	RF_6052 = 4,			/* 4 11b/g/n RF */
+	RF_PSEUDO_11N = 5,	/* 5, It is a temporality RF. */
+	RF_CHIP_MAX
+} RF_CHIP_E, *PRF_CHIP_E;
+
+typedef enum _ANTENNA_PATH {
+	ANTENNA_NONE	= 0,
 	ANTENNA_D		= 1,
 	ANTENNA_C		= 2,
 	ANTENNA_CD	= 3,
@@ -93,28 +81,28 @@ typedef enum _ANTENNA_PATH{
 	ANTENNA_ABCD	= 15
 } ANTENNA_PATH;
 
-typedef enum _RF_CONTENT{
+typedef enum _RF_CONTENT {
 	radioa_txt = 0x1000,
 	radiob_txt = 0x1001,
 	radioc_txt = 0x1002,
 	radiod_txt = 0x1003
 } RF_CONTENT;
 
-typedef enum _BaseBand_Config_Type{
-	BaseBand_Config_PHY_REG = 0,			//Radio Path A
-	BaseBand_Config_AGC_TAB = 1,			//Radio Path B
+typedef enum _BaseBand_Config_Type {
+	BaseBand_Config_PHY_REG = 0,			/* Radio Path A */
+	BaseBand_Config_AGC_TAB = 1,			/* Radio Path B */
 	BaseBand_Config_AGC_TAB_2G = 2,
-	BaseBand_Config_AGC_TAB_5G = 3,	
+	BaseBand_Config_AGC_TAB_5G = 3,
 	BaseBand_Config_PHY_REG_PG
-}BaseBand_Config_Type, *PBaseBand_Config_Type;
+} BaseBand_Config_Type, *PBaseBand_Config_Type;
 
-typedef enum _HW_BLOCK{
+typedef enum _HW_BLOCK {
 	HW_BLOCK_MAC = 0,
 	HW_BLOCK_PHY0 = 1,
 	HW_BLOCK_PHY1 = 2,
 	HW_BLOCK_RF = 3,
-	HW_BLOCK_MAXIMUM = 4, // Never use this
-}HW_BLOCK_E, *PHW_BLOCK_E;
+	HW_BLOCK_MAXIMUM = 4, /* Never use this */
+} HW_BLOCK_E, *PHW_BLOCK_E;
 
 typedef enum _WIRELESS_MODE {
 	WIRELESS_MODE_UNKNOWN = 0x00,
@@ -129,7 +117,7 @@ typedef enum _WIRELESS_MODE {
 	WIRELESS_MODE_AC_ONLY  = 0x100,
 } WIRELESS_MODE;
 
-typedef enum _SwChnlCmdID{
+typedef enum _SwChnlCmdID {
 	CmdID_End,
 	CmdID_SetTxPowerLevel,
 	CmdID_BBRegWrite10,
@@ -137,76 +125,77 @@ typedef enum _SwChnlCmdID{
 	CmdID_WritePortUshort,
 	CmdID_WritePortUchar,
 	CmdID_RF_WriteReg,
-}SwChnlCmdID;
+} SwChnlCmdID;
 
-typedef struct _SwChnlCmd{
+typedef struct _SwChnlCmd {
 	SwChnlCmdID	CmdID;
 	u32				Para1;
 	u32				Para2;
 	u32				msDelay;
-}SwChnlCmd;
+} SwChnlCmd;
 
-typedef struct _R_ANTENNA_SELECT_OFDM{	
-	u32			r_tx_antenna:4;	
+typedef struct _R_ANTENNA_SELECT_OFDM {
+	u32			r_tx_antenna:4;
 	u32			r_ant_l:4;
-	u32			r_ant_non_ht: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;
-}R_ANTENNA_SELECT_OFDM;
+} R_ANTENNA_SELECT_OFDM;
 
-typedef struct _R_ANTENNA_SELECT_CCK{
-	u8			r_cckrx_enable_2:2;	
+typedef struct _R_ANTENNA_SELECT_CCK {
+	u8			r_cckrx_enable_2:2;
 	u8			r_cckrx_enable:2;
 	u8			r_ccktx_enable:4;
-}R_ANTENNA_SELECT_CCK;
+} R_ANTENNA_SELECT_CCK;
+
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_CalculateBitShift(
+	u32 BitMask
+);
 
+#ifdef CONFIG_RF_SHADOW_RW
 typedef struct RF_Shadow_Compare_Map {
-	// Shadow register value
+	/* Shadow register value */
 	u32		Value;
-	// Compare or not flag
+	/* Compare or not flag */
 	u8		Compare;
-	// Record If it had ever modified unpredicted
+	/* Record If it had ever modified unpredicted */
 	u8		ErrorOrNot;
-	// Recorver Flag
+	/* Recorver Flag */
 	u8		Recorver;
-	//
+	/*  */
 	u8		Driver_Write;
-}RF_SHADOW_T;
-
-/*--------------------------Exported Function prototype---------------------*/
-
-u32
-PHY_CalculateBitShift(
-	u32 BitMask
-	);
+} RF_SHADOW_T;
 
 u32
 PHY_RFShadowRead(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset);
 
 VOID
 PHY_RFShadowWrite(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset,
 	IN	u32				Data);
 
 BOOLEAN
 PHY_RFShadowCompare(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset);
 
 VOID
 PHY_RFShadowRecorver(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset);
 
 VOID
@@ -220,14 +209,14 @@ PHY_RFShadowRecorverAll(
 VOID
 PHY_RFShadowCompareFlagSet(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset,
 	IN	u8				Type);
 
 VOID
 PHY_RFShadowRecorverFlagSet(
 	IN	PADAPTER		Adapter,
-	IN	u8				eRFPath,
+	IN	enum rf_path		eRFPath,
 	IN	u32				Offset,
 	IN	u8				Type);
 
@@ -242,6 +231,5 @@ PHY_RFShadowRecorverFlagSetAll(
 VOID
 PHY_RFShadowRefresh(
 	IN	PADAPTER		Adapter);
-
-#endif //__HAL_COMMON_H__
-
+#endif /*#CONFIG_RF_SHADOW_RW*/
+#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy_reg.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy_reg.h
index 723eddb64e8b..a970094f0b21 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy_reg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_phy_reg.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,21 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_PHY_REG_H__
 #define __HAL_PHY_REG_H__
 
-//for PutRFRegsetting & GetRFRegSetting BitMask
-//#if (RTL92SE_FPGA_VERIFY == 1)
-//#define 		bRFRegOffsetMask	0xfff		
-//#else
-#define 		bRFRegOffsetMask	0xfffff
-//#endif
-
-#endif //__HAL_PHY_REG_H__
+/* for PutRFRegsetting & GetRFRegSetting BitMask
+ * #if (RTL92SE_FPGA_VERIFY == 1)
+ * #define		bRFRegOffsetMask	0xfff
+ * #else */
+#define		bRFRegOffsetMask	0xfffff
+/* #endif */
 
+#endif /* __HAL_PHY_REG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_sdio.h
index ccb49e780a4c..b3d87885abbc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_sdio.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/hal_sdio.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __HAL_SDIO_H_
 #define __HAL_SDIO_H_
 
@@ -27,6 +23,10 @@ u8 rtw_hal_sdio_query_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPag
 void rtw_hal_sdio_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum);
 void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
 u32 rtw_hal_get_sdio_tx_max_length(PADAPTER padapter, u8 queue_idx);
+bool sdio_power_on_check(PADAPTER padapter);
 
-#endif //__RTW_LED_H_
+#ifdef CONFIG_FW_C2H_REG
+void sd_c2h_hisr_hdl(_adapter *adapter);
+#endif
 
+#endif /* __HAL_SDIO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211.h
index 45781db20302..2719a905cd29 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __IEEE80211_H
 #define __IEEE80211_H
 
@@ -24,7 +20,7 @@
 #ifndef CONFIG_RTL8711FW
 
 	#if defined PLATFORM_OS_XP
-	#include <ntstrsafe.h>
+		#include <ntstrsafe.h>
 	#endif
 #else
 
@@ -36,6 +32,9 @@
 #define ETH_TYPE_LEN		2
 #define PAYLOAD_TYPE_LEN	1
 
+#define NET80211_TU_TO_US	1024		/* unit:us */
+#define DEFAULT_BCN_INTERVAL 100 /* 100 ms */
+
 #ifdef CONFIG_AP_MODE
 
 #define RTL_IOCTL_HOSTAPD (SIOCIWFIRSTPRIV + 28)
@@ -58,7 +57,7 @@ enum {
 	RTL871X_HOSTAPD_MLME = 13,
 	RTL871X_HOSTAPD_SCAN_REQ = 14,
 	RTL871X_HOSTAPD_STA_CLEAR_STATS = 15,
-	RTL871X_HOSTAPD_SET_BEACON=16,
+	RTL871X_HOSTAPD_SET_BEACON = 16,
 	RTL871X_HOSTAPD_SET_WPS_BEACON = 17,
 	RTL871X_HOSTAPD_SET_WPS_PROBE_RESP = 18,
 	RTL871X_HOSTAPD_SET_WPS_ASSOC_RESP = 19,
@@ -118,11 +117,11 @@ enum {
 
 #define	IEEE_CRYPT_ALG_NAME_LEN			16
 
-#define WPA_CIPHER_NONE 	BIT(0)
-#define WPA_CIPHER_WEP40 	BIT(1)
+#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_CIPHER_TKIP	BIT(3)
+#define WPA_CIPHER_CCMP	BIT(4)
 
 
 
@@ -172,70 +171,72 @@ typedef enum _RATEID_IDX_ {
 	RATEID_IDX_BGN_3SS = 14,
 } RATEID_IDX, *PRATEID_IDX;
 
-typedef 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
+typedef 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,
-}RATR_TABLE_MODE, *PRATR_TABLE_MODE;
+} RATR_TABLE_MODE, *PRATR_TABLE_MODE;
 
 
-enum NETWORK_TYPE
-{
+enum NETWORK_TYPE {
 	WIRELESS_INVALID = 0,
-	//Sub-Element
-	WIRELESS_11B = BIT(0), // tx: cck only , rx: cck only, hw: cck
-	WIRELESS_11G = BIT(1), // tx: ofdm only, rx: ofdm & cck, hw: cck & ofdm
-	WIRELESS_11A = BIT(2), // tx: ofdm only, rx: ofdm only, hw: ofdm only
-	WIRELESS_11_24N = BIT(3), // tx: MCS only, rx: MCS & cck, hw: MCS & cck
-	WIRELESS_11_5N = BIT(4), // tx: MCS only, rx: MCS & ofdm, hw: ofdm only
-	WIRELESS_AUTO = BIT(5), 
-	WIRELESS_11AC = BIT(6), 
-
-	//Combination
-	//Type for current wireless mode
-	WIRELESS_11BG = (WIRELESS_11B|WIRELESS_11G), // tx: cck & ofdm, rx: cck & ofdm & MCS, hw: cck & ofdm
-	WIRELESS_11G_24N = (WIRELESS_11G|WIRELESS_11_24N), // tx: ofdm & MCS, rx: ofdm & cck & MCS, hw: cck & ofdm
-	WIRELESS_11A_5N = (WIRELESS_11A|WIRELESS_11_5N), // tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only
-	WIRELESS_11B_24N = (WIRELESS_11B|WIRELESS_11_24N), // tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck
-	WIRELESS_11BG_24N = (WIRELESS_11B|WIRELESS_11G|WIRELESS_11_24N), // tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck
-	WIRELESS_11_24AC = (WIRELESS_11G|WIRELESS_11AC),
-	WIRELESS_11_5AC = (WIRELESS_11A|WIRELESS_11AC),
-
-
-	//Type for registry default wireless mode
-	WIRELESS_11AGN = (WIRELESS_11A|WIRELESS_11G|WIRELESS_11_24N|WIRELESS_11_5N), // tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only
-	WIRELESS_11ABGN = (WIRELESS_11A|WIRELESS_11B|WIRELESS_11G|WIRELESS_11_24N|WIRELESS_11_5N),
-	WIRELESS_MODE_24G = (WIRELESS_11B|WIRELESS_11G|WIRELESS_11_24N),
-	WIRELESS_MODE_5G = (WIRELESS_11A|WIRELESS_11_5N|WIRELESS_11AC),
-	WIRELESS_MODE_MAX = (WIRELESS_11A|WIRELESS_11B|WIRELESS_11G|WIRELESS_11_24N|WIRELESS_11_5N|WIRELESS_11AC),
+	/* Sub-Element */
+	WIRELESS_11B = BIT(0), /* tx: cck only , rx: cck only, hw: cck */
+	WIRELESS_11G = BIT(1), /* tx: ofdm only, rx: ofdm & cck, hw: cck & ofdm */
+	WIRELESS_11A = BIT(2), /* tx: ofdm only, rx: ofdm only, hw: ofdm only */
+	WIRELESS_11_24N = BIT(3), /* tx: MCS only, rx: MCS & cck, hw: MCS & cck */
+	WIRELESS_11_5N = BIT(4), /* tx: MCS only, rx: MCS & ofdm, hw: ofdm only */
+	WIRELESS_AUTO = BIT(5),
+	WIRELESS_11AC = BIT(6),
+
+	/* Combination */
+	/* Type for current wireless mode */
+	WIRELESS_11BG = (WIRELESS_11B | WIRELESS_11G), /* tx: cck & ofdm, rx: cck & ofdm & MCS, hw: cck & ofdm */
+	WIRELESS_11G_24N = (WIRELESS_11G | WIRELESS_11_24N), /* tx: ofdm & MCS, rx: ofdm & cck & MCS, hw: cck & ofdm */
+	WIRELESS_11A_5N = (WIRELESS_11A | WIRELESS_11_5N), /* tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only */
+	WIRELESS_11B_24N = (WIRELESS_11B | WIRELESS_11_24N), /* tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck */
+	WIRELESS_11BG_24N = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N), /* tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck */
+	WIRELESS_11_24AC = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11AC),
+	WIRELESS_11_5AC = (WIRELESS_11A | WIRELESS_11AC),
+
+
+	/* Type for registry default wireless mode */
+	WIRELESS_11AGN = (WIRELESS_11A | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N), /* tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only */
+	WIRELESS_11ABGN = (WIRELESS_11A | WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N),
+	WIRELESS_MODE_24G = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N),
+	WIRELESS_MODE_5G = (WIRELESS_11A | WIRELESS_11_5N | WIRELESS_11AC),
+	WIRELESS_MODE_MAX = (WIRELESS_11A | WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N | WIRELESS_11AC),
 };
 
 #define SUPPORTED_24G_NETTYPE_MSK WIRELESS_MODE_24G
-#define SUPPORTED_5G_NETTYPE_MSK WIRELESS_MODE_5G 
+#define SUPPORTED_5G_NETTYPE_MSK WIRELESS_MODE_5G
 
-#define IsLegacyOnly(NetType)  ((NetType) == ((NetType) & (WIRELESS_11BG|WIRELESS_11A)))
+#define IsLegacyOnly(NetType)  ((NetType) == ((NetType) & (WIRELESS_11BG | WIRELESS_11A)))
 
 #define IsSupported24G(NetType) ((NetType) & SUPPORTED_24G_NETTYPE_MSK ? _TRUE : _FALSE)
-#define IsSupported5G(NetType) ((NetType) & SUPPORTED_5G_NETTYPE_MSK ? _TRUE : _FALSE)
+#define is_supported_5g(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 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 IsSupportedRxHT(NetType) IsEnableHWOFDM(NetType)
 
 #define IsSupportedTxCCK(NetType) ((NetType) & (WIRELESS_11B) ? _TRUE : _FALSE)
-#define IsSupportedTxOFDM(NetType) ((NetType) & (WIRELESS_11G|WIRELESS_11A) ? _TRUE : _FALSE)
-#define IsSupportedHT(NetType) ((NetType) & (WIRELESS_11_24N|WIRELESS_11_5N) ? _TRUE : _FALSE) 
+#define IsSupportedTxOFDM(NetType) ((NetType) & (WIRELESS_11G | WIRELESS_11A) ? _TRUE : _FALSE)
+#define is_supported_ht(NetType) ((NetType) & (WIRELESS_11_24N | WIRELESS_11_5N) ? _TRUE : _FALSE)
+
+#define is_supported_vht(NetType) ((NetType) & (WIRELESS_11AC) ? _TRUE : _FALSE)
+
+
 
-#define IsSupportedVHT(NetType) ((NetType) & (WIRELESS_11AC) ? _TRUE : _FALSE) 
 
 
 typedef struct ieee_param {
@@ -251,9 +252,9 @@ typedef struct ieee_param {
 			u8 reserved[32];
 			u8 data[0];
 		} wpa_ie;
-	        struct{
+		struct {
 			int command;
-    			int reason_code;
+			int reason_code;
 		} mlme;
 		struct {
 			u8 alg[IEEE_CRYPT_ALG_NAME_LEN];
@@ -269,31 +270,31 @@ typedef struct ieee_param {
 			u16 aid;
 			u16 capability;
 			int flags;
-			u8 tx_supp_rates[16];		
+			u8 tx_supp_rates[16];
 			struct rtw_ieee80211_ht_cap ht_cap;
 		} add_sta;
 		struct {
-			u8	reserved[2];//for set max_num_sta
+			u8	reserved[2];/* for set max_num_sta */
 			u8	buf[0];
 		} bcn_ie;
 #endif
 
-	} u;	   
-}ieee_param;
+	} u;
+} ieee_param;
 
 #ifdef CONFIG_AP_MODE
 typedef struct ieee_param_ex {
 	u32 cmd;
 	u8 sta_addr[ETH_ALEN];
 	u8 data[0];
-}ieee_param_ex;
+} ieee_param_ex;
 
-struct sta_data{
+struct sta_data {
 	u16 aid;
 	u16 capability;
 	int flags;
 	u32 sta_set;
-	u8 tx_supp_rates[16];	
+	u8 tx_supp_rates[16];
 	u32 tx_supp_rates_len;
 	struct rtw_ieee80211_ht_cap ht_cap;
 	u64	rx_pkts;
@@ -307,12 +308,12 @@ struct sta_data{
 
 
 #if WIRELESS_EXT < 17
-#define IW_QUAL_QUAL_INVALID   0x10
-#define IW_QUAL_LEVEL_INVALID  0x20
-#define IW_QUAL_NOISE_INVALID  0x40
-#define IW_QUAL_QUAL_UPDATED   0x1
-#define IW_QUAL_LEVEL_UPDATED  0x2
-#define IW_QUAL_NOISE_UPDATED  0x4
+	#define IW_QUAL_QUAL_INVALID   0x10
+	#define IW_QUAL_LEVEL_INVALID  0x20
+	#define IW_QUAL_NOISE_INVALID  0x40
+	#define IW_QUAL_QUAL_UPDATED   0x1
+	#define IW_QUAL_LEVEL_UPDATED  0x2
+	#define IW_QUAL_NOISE_UPDATED  0x4
 #endif
 
 #define IEEE80211_DATA_LEN		2304
@@ -340,7 +341,7 @@ struct ieee_ibss_seq {
 	_list	list;
 };
 
-#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW)||defined(PLATFORM_FREEBSD) 
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW) || defined(PLATFORM_FREEBSD)
 
 struct rtw_ieee80211_hdr {
 	u16 frame_ctl;
@@ -350,7 +351,7 @@ struct rtw_ieee80211_hdr {
 	u8 addr3[ETH_ALEN];
 	u16 seq_ctl;
 	u8 addr4[ETH_ALEN];
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 struct rtw_ieee80211_hdr_3addr {
 	u16 frame_ctl;
@@ -359,7 +360,7 @@ struct rtw_ieee80211_hdr_3addr {
 	u8 addr2[ETH_ALEN];
 	u8 addr3[ETH_ALEN];
 	u16 seq_ctl;
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 
 struct rtw_ieee80211_hdr_qos {
@@ -371,17 +372,17 @@ struct rtw_ieee80211_hdr_qos {
 	u16 seq_ctl;
 	u8 addr4[ETH_ALEN];
 	u16	qc;
-}  __attribute__ ((packed));
+}  __attribute__((packed));
 
 struct rtw_ieee80211_hdr_3addr_qos {
-        u16 frame_ctl;
+	u16 frame_ctl;
 	u16 duration_id;
 	u8 addr1[ETH_ALEN];
 	u8 addr2[ETH_ALEN];
 	u8 addr3[ETH_ALEN];
 	u16 seq_ctl;
-       u16     qc;
-}  __attribute__ ((packed));
+	u16     qc;
+}  __attribute__((packed));
 
 struct eapol {
 	u8 snap[6];
@@ -389,8 +390,30 @@ struct eapol {
 	u8 version;
 	u8 type;
 	u16 length;
-} __attribute__ ((packed));
+} __attribute__((packed));
 
+struct rtw_ieee80211s_hdr {
+	u8 flags;
+	u8 ttl;
+	u32 seqnum;
+	u8 eaddr1[ETH_ALEN];
+	u8 eaddr2[ETH_ALEN];
+} __attribute__((packed));
+
+/**
+ * struct rtw_ieee80211_rann_ie
+ *
+ * This structure refers to "Root Announcement information element"
+ */
+ struct rtw_ieee80211_rann_ie {
+	u8 rann_flags;
+	u8 rann_hopcount;
+	u8 rann_ttl;
+	u8 rann_addr[ETH_ALEN];
+	u32 rann_seq;
+	u32 rann_interval;
+	u32 rann_metric;
+} __attribute__((packed));
 #endif
 
 
@@ -424,8 +447,8 @@ struct rtw_ieee80211_hdr_qos {
 };
 
 struct rtw_ieee80211_hdr_3addr_qos {
-        struct  rtw_ieee80211_hdr_3addr wlan_hdr;
-        u16     qc;
+	struct  rtw_ieee80211_hdr_3addr wlan_hdr;
+	u16     qc;
 };
 
 struct eapol {
@@ -477,7 +500,7 @@ enum eap_type {
 
 /* management */
 #define RTW_IEEE80211_STYPE_ASSOC_REQ	0x0000
-#define RTW_IEEE80211_STYPE_ASSOC_RESP 	0x0010
+#define RTW_IEEE80211_STYPE_ASSOC_RESP	0x0010
 #define RTW_IEEE80211_STYPE_REASSOC_REQ	0x0020
 #define RTW_IEEE80211_STYPE_REASSOC_RESP	0x0030
 #define RTW_IEEE80211_STYPE_PROBE_REQ	0x0040
@@ -534,7 +557,7 @@ enum eap_type {
 #define BLOCK_ACK			3
 
 #ifndef ETH_P_PAE
-#define ETH_P_PAE 0x888E /* Port Access Entity (IEEE 802.1X) */
+	#define ETH_P_PAE 0x888E /* Port Access Entity (IEEE 802.1X) */
 #endif /* ETH_P_PAE */
 
 #define ETH_P_PREAUTH 0x88C7 /* IEEE 802.11i pre-authentication */
@@ -542,7 +565,7 @@ enum eap_type {
 #define ETH_P_ECONET	0x0018
 
 #ifndef ETH_P_80211_RAW
-#define ETH_P_80211_RAW (ETH_P_ECONET + 1)
+	#define ETH_P_80211_RAW (ETH_P_ECONET + 1)
 #endif
 
 /* IEEE 802.11 defines */
@@ -553,12 +576,12 @@ enum eap_type {
 
 struct ieee80211_snap_hdr {
 
-        u8    dsap;   /* always 0xAA */
-        u8    ssap;   /* always 0xAA */
-        u8    ctrl;   /* always 0x03 */
-        u8    oui[P80211_OUI_LEN];    /* organizational universal id */
+	u8    dsap;   /* always 0xAA */
+	u8    ssap;   /* always 0xAA */
+	u8    ctrl;   /* always 0x03 */
+	u8    oui[P80211_OUI_LEN];    /* organizational universal id */
 
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 #endif
 
@@ -567,10 +590,10 @@ struct ieee80211_snap_hdr {
 #pragma pack(1)
 struct ieee80211_snap_hdr {
 
-        u8    dsap;   /* always 0xAA */
-        u8    ssap;   /* always 0xAA */
-        u8    ctrl;   /* always 0x03 */
-        u8    oui[P80211_OUI_LEN];    /* organizational universal id */
+	u8    dsap;   /* always 0xAA */
+	u8    ssap;   /* always 0xAA */
+	u8    ctrl;   /* always 0x03 */
+	u8    oui[P80211_OUI_LEN];    /* organizational universal id */
 
 };
 #pragma pack()
@@ -631,10 +654,33 @@ struct ieee80211_snap_hdr {
 #define WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA 7
 #define WLAN_REASON_DISASSOC_STA_HAS_LEFT 8
 #define WLAN_REASON_STA_REQ_ASSOC_WITHOUT_AUTH 9
+#define WLAN_REASON_MESH_PEER_CANCELED 52
+#define WLAN_REASON_MESH_MAX_PEERS 53
+#define WLAN_REASON_MESH_CONFIG 54
+#define WLAN_REASON_MESH_CLOSE 55
+#define WLAN_REASON_MESH_MAX_RETRIES 56 
+#define WLAN_REASON_MESH_CONFIRM_TIMEOUT 57
+#define WLAN_REASON_MESH_INVALID_GTK 58
+#define WLAN_REASON_MESH_INCONSISTENT_PARAM 59
+#define WLAN_REASON_MESH_INVALID_SECURITY 60
+#define WLAN_REASON_MESH_PATH_NOPROXY 61
+#define WLAN_REASON_MESH_PATH_NOFORWARD 62
+#define WLAN_REASON_MESH_PATH_DEST_UNREACHABLE 63
+#define WLAN_REASON_MAC_EXISTS_IN_MBSS 64
+#define WLAN_REASON_MESH_CHAN_REGULATORY 65
+#define WLAN_REASON_MESH_CHAN 66
+#define WLAN_REASON_SA_QUERY_TIMEOUT 65532
 #define WLAN_REASON_ACTIVE_ROAM 65533
 #define WLAN_REASON_JOIN_WRONG_CHANNEL       65534
 #define WLAN_REASON_EXPIRATION_CHK 65535
 
+#define WLAN_REASON_IS_PRIVATE(reason) ( \
+	reason == WLAN_REASON_EXPIRATION_CHK \
+	|| reason == WLAN_REASON_JOIN_WRONG_CHANNEL \
+	|| reason == WLAN_REASON_ACTIVE_ROAM \
+	|| reason == WLAN_REASON_SA_QUERY_TIMEOUT \
+	)
+
 /* Information Element IDs */
 #define WLAN_EID_SSID 0
 #define WLAN_EID_SUPP_RATES 1
@@ -670,6 +716,15 @@ struct ieee80211_snap_hdr {
 #define WLAN_EID_20_40_BSS_INTOLERANT 73
 #define WLAN_EID_OVERLAPPING_BSS_SCAN_PARAMS 74
 #define WLAN_EID_MMIE 76
+#define WLAN_EID_MESH_CONFIG 113
+#define WLAN_EID_MESH_ID 114
+#define WLAN_EID_MPM 117
+#define	WLAN_EID_RANN 126
+#define	WLAN_EID_PREQ 130
+#define	WLAN_EID_PREP 131
+#define	WLAN_EID_PERR 132
+#define WLAN_EID_AMPE 139
+#define WLAN_EID_MIC 140
 #define WLAN_EID_VENDOR_SPECIFIC 221
 #define WLAN_EID_GENERIC (WLAN_EID_VENDOR_SPECIFIC)
 #define WLAN_EID_VHT_CAPABILITY 191
@@ -694,7 +749,7 @@ struct ieee80211_snap_hdr {
 #define IEEE80211_24GHZ_BAND     (1<<0)
 #define IEEE80211_52GHZ_BAND     (1<<1)
 
-#define IEEE80211_CCK_RATE_LEN  		4
+#define IEEE80211_CCK_RATE_LEN		4
 #define IEEE80211_NUM_OFDM_RATESLEN	8
 
 
@@ -702,7 +757,7 @@ struct ieee80211_snap_hdr {
 #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_LEN		8
 #define IEEE80211_OFDM_RATE_6MB		        0x0C
 #define IEEE80211_OFDM_RATE_9MB		        0x12
 #define IEEE80211_OFDM_RATE_12MB		0x18
@@ -728,36 +783,36 @@ struct ieee80211_snap_hdr {
 
 #define IEEE80211_CCK_RATES_MASK	        0x0000000F
 #define IEEE80211_CCK_BASIC_RATES_MASK	(IEEE80211_CCK_RATE_1MB_MASK | \
-	IEEE80211_CCK_RATE_2MB_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)
+		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)
+		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)
+		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)
+				      IEEE80211_CCK_DEFAULT_RATES_MASK)
 
 #define IEEE80211_NUM_OFDM_RATES	    8
 #define IEEE80211_NUM_CCK_RATES	            4
 #define IEEE80211_OFDM_SHIFT_MASK_A         4
 
 
-enum MGN_RATE{
+enum MGN_RATE {
 	MGN_1M		= 0x02,
 	MGN_2M		= 0x04,
-	MGN_5_5M 	= 0x0B,
-	MGN_6M	 	= 0x0C,
+	MGN_5_5M	= 0x0B,
+	MGN_6M		= 0x0C,
 	MGN_9M		= 0x12,
-	MGN_11M 	= 0x16,
+	MGN_11M	= 0x16,
 	MGN_12M	= 0x18,
 	MGN_18M	= 0x24,
 	MGN_24M	= 0x30,
@@ -1007,13 +1062,13 @@ extern struct rate_section_ent rates_by_sections[];
  *       information for frames received.  Not setting these will not cause
  *       any adverse affects. */
 struct ieee80211_rx_stats {
-	//u32 mac_time[2];
+	/* u32 mac_time[2]; */
 	s8 rssi;
 	u8 signal;
 	u8 noise;
 	u8 received_channel;
 	u16 rate; /* in 100 kbps */
-	//u8 control;
+	/* u8 control; */
 	u8 mask;
 	u8 freq;
 	u16 len;
@@ -1029,14 +1084,14 @@ struct ieee80211_frag_entry {
 	u32 first_frag_time;
 	uint seq;
 	uint last_frag;
-	uint qos;   //jackson
-	uint tid;	//jackson
+	uint qos;   /* jackson */
+	uint tid;	/* jackson */
 	struct sk_buff *skb;
 	u8 src_addr[ETH_ALEN];
 	u8 dst_addr[ETH_ALEN];
 };
 
-#ifndef PLATFORM_FREEBSD //Baron BSD has already defined
+#ifndef PLATFORM_FREEBSD /* Baron BSD has already defined */
 struct ieee80211_stats {
 	uint tx_unicast_frames;
 	uint tx_multicast_frames;
@@ -1060,8 +1115,8 @@ struct ieee80211_stats {
 	uint rx_message_in_msg_fragments;
 	uint rx_message_in_bad_msg_fragments;
 };
-#endif //PLATFORM_FREEBSD
-struct ieee80211_softmac_stats{
+#endif /* PLATFORM_FREEBSD */
+struct ieee80211_softmac_stats {
 	uint rx_ass_ok;
 	uint rx_ass_err;
 	uint rx_probe_rq;
@@ -1099,25 +1154,22 @@ struct ieee80211_softmac_stats{
 
 #define WEP_KEYS 4
 #define WEP_KEY_LEN 13
-
-#ifdef CONFIG_IEEE80211W
 #define BIP_MAX_KEYID 5
 #define BIP_AAD_SIZE  20
-#endif //CONFIG_IEEE80211W
 
 #if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW)
 
 struct ieee80211_security {
 	u16 active_key:2,
-            enabled:1,
+	    enabled:1,
 	    auth_mode:2,
-            auth_algo:4,
-            unicast_uses_group:1;
+	    auth_algo:4,
+	    unicast_uses_group:1;
 	u8 key_sizes[WEP_KEYS];
 	u8 keys[WEP_KEYS][WEP_KEY_LEN];
 	u8 level;
 	u16 flags;
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 #endif
 
@@ -1126,10 +1178,10 @@ struct ieee80211_security {
 #pragma pack(1)
 struct ieee80211_security {
 	u16 active_key:2,
-            enabled:1,
+	    enabled:1,
 	    auth_mode:2,
-            auth_algo:4,
-            unicast_uses_group:1;
+	    auth_algo:4,
+	    unicast_uses_group:1;
 	u8 key_sizes[WEP_KEYS];
 	u8 keys[WEP_KEYS][WEP_KEY_LEN];
 	u8 level;
@@ -1184,13 +1236,13 @@ struct ieee80211_header_data {
 struct ieee80211_info_element_hdr {
 	u8 id;
 	u8 len;
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 struct ieee80211_info_element {
 	u8 id;
 	u8 len;
 	u8 data[0];
-} __attribute__ ((packed));
+} __attribute__((packed));
 #endif
 
 #ifdef PLATFORM_WINDOWS
@@ -1240,8 +1292,8 @@ struct ieee80211_authentication {
 	u16 algorithm;
 	u16 transaction;
 	u16 status;
-	//struct ieee80211_info_element_hdr info_element;
-} __attribute__ ((packed));
+	/* struct ieee80211_info_element_hdr info_element; */
+} __attribute__((packed));
 
 
 struct ieee80211_probe_response {
@@ -1250,28 +1302,28 @@ struct ieee80211_probe_response {
 	u16 beacon_interval;
 	u16 capability;
 	struct ieee80211_info_element info_element;
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 struct ieee80211_probe_request {
 	struct ieee80211_header_data header;
 	/*struct ieee80211_info_element info_element;*/
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 struct ieee80211_assoc_request_frame {
 	struct rtw_ieee80211_hdr_3addr header;
 	u16 capability;
 	u16 listen_interval;
-	//u8 current_ap[ETH_ALEN];
+	/* u8 current_ap[ETH_ALEN]; */
 	struct ieee80211_info_element_hdr info_element;
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 struct ieee80211_assoc_response_frame {
 	struct rtw_ieee80211_hdr_3addr header;
 	u16 capability;
 	u16 status;
 	u16 aid;
-//	struct ieee80211_info_element info_element; /* supported rates */
-} __attribute__ ((packed));
+	/*	struct ieee80211_info_element info_element;  supported rates  */
+} __attribute__((packed));
 #endif
 
 
@@ -1285,7 +1337,7 @@ struct ieee80211_authentication {
 	u16 algorithm;
 	u16 transaction;
 	u16 status;
-	//struct ieee80211_info_element_hdr info_element;
+	/* struct ieee80211_info_element_hdr info_element; */
 } ;
 
 
@@ -1306,7 +1358,7 @@ struct ieee80211_assoc_request_frame {
 	struct rtw_ieee80211_hdr_3addr header;
 	u16 capability;
 	u16 listen_interval;
-	//u8 current_ap[ETH_ALEN];
+	/* u8 current_ap[ETH_ALEN]; */
 	struct ieee80211_info_element_hdr info_element;
 } ;
 
@@ -1315,7 +1367,7 @@ struct ieee80211_assoc_response_frame {
 	u16 capability;
 	u16 status;
 	u16 aid;
-//	struct ieee80211_info_element info_element; /* supported rates */
+	/*	struct ieee80211_info_element info_element;  supported rates  */
 };
 
 #pragma pack()
@@ -1345,9 +1397,8 @@ struct ieee80211_txb {
 #define MAX_RATES_LENGTH                  ((u8)12)
 #define MAX_RATES_EX_LENGTH               ((u8)16)
 #define MAX_NETWORK_COUNT                  128
-#define MAX_CHANNEL_NUMBER                 161
 #define IEEE80211_SOFTMAC_SCAN_TIME	  400
-//(HZ / 2)
+/* (HZ / 2) */
 #define IEEE80211_SOFTMAC_ASSOC_RETRY_TIME (HZ * 2)
 
 #define CRC_LENGTH                 4U
@@ -1378,20 +1429,20 @@ struct ieee80211_network {
 	/* Ensure null-terminated for any debug msgs */
 	u8 ssid[IW_ESSID_MAX_SIZE + 1];
 	u8 ssid_len;
-	u8	rssi;	//relative signal strength
-	u8	sq;		//signal quality
+	u8	rssi;	/* relative signal strength */
+	u8	sq;		/* signal quality */
 
 	/* These are network statistics */
-	//struct ieee80211_rx_stats stats;
+	/* struct ieee80211_rx_stats stats; */
 	u16 capability;
 	u16	aid;
 	u8 rates[MAX_RATES_LENGTH];
 	u8 rates_len;
 	u8 rates_ex[MAX_RATES_EX_LENGTH];
 	u8 rates_ex_len;
-	
+
 	u8 edca_parmsets[18];
-		
+
 	u8 mode;
 	u8 flags;
 	u8 time_stamp[8];
@@ -1410,7 +1461,7 @@ struct ieee80211_network {
 	u8 qbssload[5];
 	u8 network_type;
 	int join_res;
-	unsigned long	last_scanned;	
+	unsigned long	last_scanned;
 };
 #endif
 /*
@@ -1420,13 +1471,13 @@ join_res:
 > 0: TID
 */
 
-#ifndef PLATFORM_FREEBSD //Baron BSD has already defined
+#ifndef PLATFORM_FREEBSD /* Baron BSD has already defined */
 
 enum ieee80211_state {
 
 	/* the card is not linked at all */
 	IEEE80211_NOLINK = 0,
-	
+
 	/* IEEE80211_ASSOCIATING* are for BSS client mode
 	 * the driver shall not perform RX filtering unless
 	 * the state is LINKED.
@@ -1434,52 +1485,54 @@ enum ieee80211_state {
 	 * defaults to NOLINK for ALL the other states (including
 	 * LINKED_SCANNING)
 	 */
-	
+
 	/* the association procedure will start (wq scheduling)*/
 	IEEE80211_ASSOCIATING,
 	IEEE80211_ASSOCIATING_RETRY,
-	
+
 	/* the association procedure is sending AUTH request*/
 	IEEE80211_ASSOCIATING_AUTHENTICATING,
-	
+
 	/* the association procedure has successfully authentcated
 	 * and is sending association request
 	 */
 	IEEE80211_ASSOCIATING_AUTHENTICATED,
-	
+
 	/* the link is ok. the card associated to a BSS or linked
 	 * to a ibss cell or acting as an AP and creating the bss
 	 */
 	IEEE80211_LINKED,
-	
+
 	/* same as LINKED, but the driver shall apply RX filter
 	 * rules as we are in NO_LINK mode. As the card is still
 	 * logically linked, but it is doing a syncro site survey
 	 * then it will be back to LINKED state.
 	 */
 	IEEE80211_LINKED_SCANNING,
-	
+
 };
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 
 #define DEFAULT_MAX_SCAN_AGE (15 * HZ)
 #define DEFAULT_FTS 2346
 #define MAC_FMT "%02x:%02x:%02x:%02x:%02x:%02x"
-#define MAC_ARG(x) ((u8*)(x))[0],((u8*)(x))[1],((u8*)(x))[2],((u8*)(x))[3],((u8*)(x))[4],((u8*)(x))[5]
+#define MAC_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5]
+#define MAC_SFMT "%02hhx:%02hhx:%02hhx:%02hhx:%02hhx:%02hhx"
+#define MAC_SARG(x) ((u8*)(x)),((u8*)(x)) + 1,((u8*)(x)) + 2,((u8*)(x)) + 3,((u8*)(x)) + 4,((u8*)(x)) + 5
 #define IP_FMT "%d.%d.%d.%d"
-#define IP_ARG(x) ((u8*)(x))[0],((u8*)(x))[1],((u8*)(x))[2],((u8*)(x))[3]
+#define IP_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3]
 #define PORT_FMT "%u"
 #define PORT_ARG(x) ntohs(*((u16 *)(x)))
 
-#ifdef PLATFORM_FREEBSD //Baron change func to macro
+#ifdef PLATFORM_FREEBSD /* Baron change func to macro */
 #define is_multicast_mac_addr(Addr) ((((Addr[0]) & 0x01) == 0x01) && ((Addr[0]) != 0xff))
 #define is_broadcast_mac_addr(Addr) ((((Addr[0]) & 0xff) == 0xff) && (((Addr[1]) & 0xff) == 0xff) && \
-(((Addr[2]) & 0xff) == 0xff) && (((Addr[3]) & 0xff) == 0xff) && (((Addr[4]) & 0xff) == 0xff) && \
-(((Addr[5]) & 0xff) == 0xff))
+	(((Addr[2]) & 0xff) == 0xff) && (((Addr[3]) & 0xff) == 0xff) && (((Addr[4]) & 0xff) == 0xff) && \
+				     (((Addr[5]) & 0xff) == 0xff))
 #else
 extern __inline int is_multicast_mac_addr(const u8 *addr)
 {
-        return ((addr[0] != 0xff) && (0x01 & addr[0]));
+	return (addr[0] != 0xff) && (0x01 & addr[0]);
 }
 
 extern __inline int is_broadcast_mac_addr(const u8 *addr)
@@ -1493,15 +1546,15 @@ extern __inline int is_zero_mac_addr(const u8 *addr)
 	return ((addr[0] == 0x00) && (addr[1] == 0x00) && (addr[2] == 0x00) &&   \
 		(addr[3] == 0x00) && (addr[4] == 0x00) && (addr[5] == 0x00));
 }
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 
 #define CFG_IEEE80211_RESERVE_FCS (1<<0)
 #define CFG_IEEE80211_COMPUTE_FCS (1<<1)
 
-typedef struct tx_pending_t{
+typedef struct tx_pending_t {
 	int frag;
 	struct ieee80211_txb *txb;
-}tx_pending_t;
+} tx_pending_t;
 
 
 
@@ -1510,22 +1563,22 @@ typedef struct tx_pending_t{
 #define IEEE_A            (1<<0)
 #define IEEE_B            (1<<1)
 #define IEEE_G            (1<<2)
-#define IEEE_MODE_MASK    (IEEE_A|IEEE_B|IEEE_G)
+#define IEEE_MODE_MASK    (IEEE_A | IEEE_B | IEEE_G)
 
-//Baron move to ieee80211.c
+/* Baron move to ieee80211.c */
 int ieee80211_is_empty_essid(const char *essid, int essid_len);
 int ieee80211_get_hdrlen(u16 fc);
 
 #if 0
-/* Action frame categories (IEEE 802.11-2007, 7.3.1.11, Table 7-24) */
-#define WLAN_ACTION_SPECTRUM_MGMT 0
-#define WLAN_ACTION_QOS 1
-#define WLAN_ACTION_DLS 2
-#define WLAN_ACTION_BLOCK_ACK 3
-#define WLAN_ACTION_RADIO_MEASUREMENT 5
-#define WLAN_ACTION_FT 6
-#define WLAN_ACTION_SA_QUERY 8
-#define WLAN_ACTION_WMM 17
+	/* Action frame categories (IEEE 802.11-2007, 7.3.1.11, Table 7-24) */
+	#define WLAN_ACTION_SPECTRUM_MGMT 0
+	#define WLAN_ACTION_QOS 1
+	#define WLAN_ACTION_DLS 2
+	#define WLAN_ACTION_BLOCK_ACK 3
+	#define WLAN_ACTION_RADIO_MEASUREMENT 5
+	#define WLAN_ACTION_FT 6
+	#define WLAN_ACTION_SA_QUERY 8
+	#define WLAN_ACTION_WMM 17
 #endif
 
 
@@ -1535,19 +1588,35 @@ enum rtw_ieee80211_category {
 	RTW_WLAN_CATEGORY_QOS = 1,
 	RTW_WLAN_CATEGORY_DLS = 2,
 	RTW_WLAN_CATEGORY_BACK = 3,
-	RTW_WLAN_CATEGORY_PUBLIC = 4, //IEEE 802.11 public action frames
-	RTW_WLAN_CATEGORY_RADIO_MEASUREMENT  = 5,
+	RTW_WLAN_CATEGORY_PUBLIC = 4, /* IEEE 802.11 public action frames */
+	RTW_WLAN_CATEGORY_RADIO_MEAS = 5,
 	RTW_WLAN_CATEGORY_FT = 6,
 	RTW_WLAN_CATEGORY_HT = 7,
 	RTW_WLAN_CATEGORY_SA_QUERY = 8,
-	RTW_WLAN_CATEGORY_UNPROTECTED_WNM = 11, // add for CONFIG_IEEE80211W, none 11w also can use
+	RTW_WLAN_CATEGORY_WNM = 10,
+	RTW_WLAN_CATEGORY_UNPROTECTED_WNM = 11, /* add for CONFIG_IEEE80211W, none 11w also can use */
 	RTW_WLAN_CATEGORY_TDLS = 12,
-	RTW_WLAN_CATEGORY_SELF_PROTECTED = 15, // add for CONFIG_IEEE80211W, none 11w also can use
+	RTW_WLAN_CATEGORY_MESH = 13,
+	RTW_WLAN_CATEGORY_MULTIHOP = 14,
+	RTW_WLAN_CATEGORY_SELF_PROTECTED = 15,
 	RTW_WLAN_CATEGORY_WMM = 17,
 	RTW_WLAN_CATEGORY_VHT = 21,
-	RTW_WLAN_CATEGORY_P2P = 0x7f,//P2P action frames
+	RTW_WLAN_CATEGORY_P2P = 0x7f,/* P2P action frames */
 };
 
+#define CATEGORY_IS_GROUP_PRIVACY(cat) \
+	(cat == RTW_WLAN_CATEGORY_MESH || cat == RTW_WLAN_CATEGORY_MULTIHOP)
+
+#define CATEGORY_IS_NON_ROBUST(cat) \
+	(cat == RTW_WLAN_CATEGORY_PUBLIC \
+	|| cat == RTW_WLAN_CATEGORY_HT \
+	|| cat == RTW_WLAN_CATEGORY_UNPROTECTED_WNM \
+	|| cat == RTW_WLAN_CATEGORY_SELF_PROTECTED \
+	|| cat == RTW_WLAN_CATEGORY_VHT \
+	|| cat == RTW_WLAN_CATEGORY_P2P)
+
+#define CATEGORY_IS_ROBUST(cat) !CATEGORY_IS_NON_ROBUST(cat)
+
 /* SPECTRUM_MGMT action code */
 enum rtw_ieee80211_spectrum_mgmt_actioncode {
 	RTW_WLAN_ACTION_SPCT_MSR_REQ = 0,
@@ -1558,17 +1627,43 @@ enum rtw_ieee80211_spectrum_mgmt_actioncode {
 	RTW_WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,
 };
 
-enum _PUBLIC_ACTION{
-	ACT_PUBLIC_BSSCOEXIST = 0, // 20/40 BSS Coexistence
+/* SELF_PROTECTED action code */
+enum rtw_ieee80211_self_protected_actioncode {
+	RTW_ACT_SELF_PROTECTED_RSVD = 0,
+	RTW_ACT_SELF_PROTECTED_MESH_OPEN = 1,
+	RTW_ACT_SELF_PROTECTED_MESH_CONF = 2,
+	RTW_ACT_SELF_PROTECTED_MESH_CLOSE = 3,
+	RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM = 4,
+	RTW_ACT_SELF_PROTECTED_MESH_GK_ACK = 5,
+	RTW_ACT_SELF_PROTECTED_NUM,
+};
+
+/* MESH action code */
+enum rtw_ieee80211_mesh_actioncode {
+	RTW_ACT_MESH_LINK_METRIC_REPORT,
+	RTW_ACT_MESH_HWMP_PATH_SELECTION,
+	RTW_ACT_MESH_GATE_ANNOUNCEMENT,
+	RTW_ACT_MESH_CONGESTION_CONTROL_NOTIFICATION,
+	RTW_ACT_MESH_MCCA_SETUP_REQUEST,
+	RTW_ACT_MESH_MCCA_SETUP_REPLY,
+	RTW_ACT_MESH_MCCA_ADVERTISEMENT_REQUEST,
+	RTW_ACT_MESH_MCCA_ADVERTISEMENT,
+	RTW_ACT_MESH_MCCA_TEARDOWN,
+	RTW_ACT_MESH_TBTT_ADJUSTMENT_REQUEST,
+	RTW_ACT_MESH_TBTT_ADJUSTMENT_RESPONSE,
+};
+
+enum _PUBLIC_ACTION {
+	ACT_PUBLIC_BSSCOEXIST = 0, /* 20/40 BSS Coexistence */
 	ACT_PUBLIC_DSE_ENABLE = 1,
 	ACT_PUBLIC_DSE_DEENABLE = 2,
 	ACT_PUBLIC_DSE_REG_LOCATION = 3,
 	ACT_PUBLIC_EXT_CHL_SWITCH = 4,
 	ACT_PUBLIC_DSE_MSR_REQ = 5,
 	ACT_PUBLIC_DSE_MSR_RPRT = 6,
-	ACT_PUBLIC_MP = 7, // Measurement Pilot
+	ACT_PUBLIC_MP = 7, /* Measurement Pilot */
 	ACT_PUBLIC_DSE_PWR_CONSTRAINT = 8,
-	ACT_PUBLIC_VENDOR = 9, // for WIFI_DIRECT
+	ACT_PUBLIC_VENDOR = 9, /* for WIFI_DIRECT */
 	ACT_PUBLIC_GAS_INITIAL_REQ = 10,
 	ACT_PUBLIC_GAS_INITIAL_RSP = 11,
 	ACT_PUBLIC_GAS_COMEBACK_REQ = 12,
@@ -1579,7 +1674,7 @@ enum _PUBLIC_ACTION{
 };
 
 #ifdef CONFIG_TDLS
-enum TDLS_ACTION_FIELD{
+enum TDLS_ACTION_FIELD {
 	TDLS_SETUP_REQUEST = 0,
 	TDLS_SETUP_RESPONSE = 1,
 	TDLS_SETUP_CONFIRM = 2,
@@ -1591,12 +1686,12 @@ enum TDLS_ACTION_FIELD{
 	TDLS_PEER_PSM_RESPONSE = 8,
 	TDLS_PEER_TRAFFIC_RESPONSE = 9,
 	TDLS_DISCOVERY_REQUEST = 10,
-	TDLS_DISCOVERY_RESPONSE = 14,	//it's used in public action frame
+	TDLS_DISCOVERY_RESPONSE = 14,	/* it's used in public action frame */
 };
 
 #define	TUNNELED_PROBE_REQ	15
 #define	TUNNELED_PROBE_RSP	16
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 /* BACK action code */
 enum rtw_ieee80211_back_actioncode {
@@ -1608,13 +1703,13 @@ enum rtw_ieee80211_back_actioncode {
 /* HT features action code */
 enum rtw_ieee80211_ht_actioncode {
 	RTW_WLAN_ACTION_HT_NOTI_CHNL_WIDTH = 0,
-       RTW_WLAN_ACTION_HT_SM_PS = 1,
-       RTW_WLAN_ACTION_HT_PSMP = 2,
-       RTW_WLAN_ACTION_HT_SET_PCO_PHASE = 3,
-       RTW_WLAN_ACTION_HT_CSI = 4,
-       RTW_WLAN_ACTION_HT_NON_COMPRESS_BEAMFORMING = 5,
-       RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING = 6,
-       RTW_WLAN_ACTION_HT_ASEL_FEEDBACK = 7,
+	RTW_WLAN_ACTION_HT_SM_PS = 1,
+	RTW_WLAN_ACTION_HT_PSMP = 2,
+	RTW_WLAN_ACTION_HT_SET_PCO_PHASE = 3,
+	RTW_WLAN_ACTION_HT_CSI = 4,
+	RTW_WLAN_ACTION_HT_NON_COMPRESS_BEAMFORMING = 5,
+	RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING = 6,
+	RTW_WLAN_ACTION_HT_ASEL_FEEDBACK = 7,
 };
 
 /* BACK (block-ack) parties */
@@ -1632,18 +1727,37 @@ enum rtw_ieee80211_back_parties {
 #define RTW_WLAN_20_40_BSS_COEX_OBSS_EXEMPT_GRNT    BIT(4)
 
 /* VHT features action code */
-enum rtw_ieee80211_vht_actioncode{
+enum rtw_ieee80211_vht_actioncode {
 	RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING = 0,
-       RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT = 1,
-       RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION = 2,
+	RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT = 1,
+	RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION = 2,
+};
+
+/*IEEE 802.11r action code*/
+#ifdef CONFIG_RTW_80211R
+enum rtw_ieee80211_ft_actioncode {
+	RTW_WLAN_ACTION_FT_RESV,
+	RTW_WLAN_ACTION_FT_REQ,
+	RTW_WLAN_ACTION_FT_RSP,
+	RTW_WLAN_ACTION_FT_CONF,
+	RTW_WLAN_ACTION_FT_ACK,
+	RTW_WLAN_ACTION_FT_MAX,
 };
+#endif
 
+#ifdef CONFIG_RTW_WNM
+enum rtw_ieee80211_wnm_actioncode {
+	RTW_WLAN_ACTION_WNM_BTM_QUERY = 6,
+	RTW_WLAN_ACTION_WNM_BTM_REQ = 7,
+	RTW_WLAN_ACTION_WNM_BTM_RSP = 8,
+};
+#endif
 
 #define OUI_MICROSOFT 0x0050f2 /* Microsoft (also used in Wi-Fi specs)
 				* 00:50:F2 */
-#ifndef PLATFORM_FREEBSD //Baron BSD has defined
-#define WME_OUI_TYPE 2
-#endif //PLATFORM_FREEBSD
+#ifndef PLATFORM_FREEBSD /* Baron BSD has defined */
+	#define WME_OUI_TYPE 2
+#endif /* PLATFORM_FREEBSD */
 #define WME_OUI_SUBTYPE_INFORMATION_ELEMENT 0
 #define WME_OUI_SUBTYPE_PARAMETER_ELEMENT 1
 #define WME_OUI_SUBTYPE_TSPEC_ELEMENT 2
@@ -1666,6 +1780,55 @@ enum rtw_ieee80211_vht_actioncode{
 
 #define VENDOR_HT_CAPAB_OUI_TYPE 0x33 /* 00-90-4c:0x33 */
 
+enum rtw_ieee80211_rann_flags {
+	RTW_RANN_FLAG_IS_GATE = 1 << 0,
+};
+
+/**
+ * enum rtw_ieee80211_preq_flags - mesh PREQ element flags
+ *
+ * @RTW_IEEE80211_PREQ_IS_GATE_FLAG: Gate Announcement subfield
+ * @RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG: proactive PREP subfield
+ */
+enum rtw_ieee80211_preq_flags {
+	RTW_IEEE80211_PREQ_IS_GATE_FLAG = 1 << 0,
+	RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG	= 1 << 2,
+};
+
+/**
+ * enum rtw_ieee80211_preq_target_flags - mesh PREQ element per target flags
+ *
+ * @RTW_IEEE80211_PREQ_TO_FLAG: target only subfield
+ * @RTW_IEEE80211_PREQ_USN_FLAG: unknown target HWMP sequence number subfield
+ */
+enum rtw_ieee80211_preq_target_flags {
+	RTW_IEEE80211_PREQ_TO_FLAG	= 1<<0,
+	RTW_IEEE80211_PREQ_USN_FLAG	= 1<<2,
+};
+
+/**
+ * enum rtw_ieee80211_root_mode_identifier - root mesh STA mode identifier
+ *
+ * These attribute are used by dot11MeshHWMPRootMode to set root mesh STA mode
+ *
+ * @RTW_IEEE80211_ROOTMODE_NO_ROOT: the mesh STA is not a root mesh STA (default)
+ * @RTW_IEEE80211_ROOTMODE_ROOT: the mesh STA is a root mesh STA if greater than
+ *	this value
+ * @RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP: the mesh STA is a root mesh STA supports
+ *	the proactive PREQ with proactive PREP subfield set to 0
+ * @RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP: the mesh STA is a root mesh STA
+ *	supports the proactive PREQ with proactive PREP subfield set to 1
+ * @RTW_IEEE80211_PROACTIVE_RANN: the mesh STA is a root mesh STA supports
+ *	the proactive RANN
+ */
+enum rtw_ieee80211_root_mode_identifier {
+	RTW_IEEE80211_ROOTMODE_NO_ROOT = 0,
+	RTW_IEEE80211_ROOTMODE_ROOT = 1,
+	RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP = 2,
+	RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP = 3,
+	RTW_IEEE80211_PROACTIVE_RANN = 4,
+};
+
 /**
  * enum rtw_ieee80211_channel_flags - channel flags
  *
@@ -1681,32 +1844,32 @@ enum rtw_ieee80211_vht_actioncode{
  * @RTW_IEEE80211_CHAN_NO_HT40MINUS: extension channel below this channel
  *      is not permitted.
  */
-  enum rtw_ieee80211_channel_flags {
-          RTW_IEEE80211_CHAN_DISABLED         = 1<<0,
-          RTW_IEEE80211_CHAN_PASSIVE_SCAN     = 1<<1,
-          RTW_IEEE80211_CHAN_NO_IBSS          = 1<<2,
-          RTW_IEEE80211_CHAN_RADAR            = 1<<3,
-          RTW_IEEE80211_CHAN_NO_HT40PLUS      = 1<<4,
-          RTW_IEEE80211_CHAN_NO_HT40MINUS     = 1<<5,
-  };
-  
-  #define RTW_IEEE80211_CHAN_NO_HT40 \
-          (RTW_IEEE80211_CHAN_NO_HT40PLUS | RTW_IEEE80211_CHAN_NO_HT40MINUS)
+enum rtw_ieee80211_channel_flags {
+	RTW_IEEE80211_CHAN_DISABLED         = 1 << 0,
+	RTW_IEEE80211_CHAN_PASSIVE_SCAN     = 1 << 1,
+	RTW_IEEE80211_CHAN_NO_IBSS          = 1 << 2,
+	RTW_IEEE80211_CHAN_RADAR            = 1 << 3,
+	RTW_IEEE80211_CHAN_NO_HT40PLUS      = 1 << 4,
+	RTW_IEEE80211_CHAN_NO_HT40MINUS     = 1 << 5,
+};
+
+#define RTW_IEEE80211_CHAN_NO_HT40 \
+	(RTW_IEEE80211_CHAN_NO_HT40PLUS | RTW_IEEE80211_CHAN_NO_HT40MINUS)
 
 /* Represent channel details, subset of ieee80211_channel */
 struct rtw_ieee80211_channel {
-	//enum ieee80211_band band;
-	//u16 center_freq;
+	/* enum ieee80211_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;
-}; 
+	/* 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, "*/ \
@@ -1719,7 +1882,7 @@ struct rtw_ieee80211_channel {
 	/*"beacon_found:%u\n"*/ \
 	/*"orig_flags:0x%08x\n"*/ \
 	/*"orig_mag:%d\n"*/ \
-	/*"orig_mpwr:%d\n"*/ 
+	/*"orig_mpwr:%d\n"*/
 
 #define CHAN_ARG(channel) \
 	/*(channel)->band*/ \
@@ -1788,6 +1951,18 @@ struct rtw_ieee802_11_elems {
 	u8 vht_operation_len;
 	u8 *vht_op_mode_notify;
 	u8 vht_op_mode_notify_len;
+	u8 *rm_en_cap;
+	u8 rm_en_cap_len;
+#ifdef CONFIG_RTW_MESH
+	u8 *preq;
+	u8 preq_len;
+	u8 *prep;
+	u8 prep_len;
+	u8 *perr;
+	u8 perr_len;
+	u8 *rann;
+	u8 rann_len;
+#endif
 };
 
 typedef enum { ParseOK = 0, ParseUnknown = 1, ParseFailed = -1 } ParseRes;
@@ -1797,7 +1972,7 @@ ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
 				int show_errors);
 
 u8 *rtw_set_fixed_ie(unsigned char *pbuf, unsigned int len, unsigned char *source, unsigned int *frlen);
-u8 *rtw_set_ie(u8 *pbuf, sint index, uint len, u8 *source, uint *frlen);
+u8 *rtw_set_ie(u8 *pbuf, sint index, uint len, const u8 *source, uint *frlen);
 
 enum secondary_ch_offset {
 	SCN = 0, /* no secondary channel */
@@ -1810,27 +1985,49 @@ u8 *rtw_set_ie_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode, u8 new_ch, u8
 u8 *rtw_set_ie_secondary_ch_offset(u8 *buf, u32 *buf_len, u8 secondary_ch_offset);
 u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl, u8 flags, u16 reason, u16 precedence);
 
-u8 *rtw_get_ie(u8*pbuf, sint index, sint *len, sint limit);
-u8 *rtw_get_ie_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len, u8 *ie, uint *ielen);
+u8 *rtw_get_ie(const u8 *pbuf, sint index, sint *len, sint limit);
+u8 *rtw_get_ie_ex(const u8 *in_ie, uint in_len, u8 eid, const u8 *oui, u8 oui_len, u8 *ie, uint *ielen);
 int rtw_ies_remove_ie(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 oui_len);
 
-void rtw_set_supported_rate(u8* SupportedRates, uint mode) ;
+void rtw_set_supported_rate(u8 *SupportedRates, uint mode) ;
+
+#define GET_RSN_CAP_MFP_OPTION(cap)	LE_BITS_TO_2BYTE(((u8 *)(cap)), 6, 2)
+
+#define MFP_NO			0
+#define MFP_INVALID		1
+#define MFP_OPTIONAL	2
+#define MFP_REQUIRED	3
+
+struct rsne_info {
+	u8 *gcs;
+	u16 pcs_cnt;
+	u8 *pcs_list;
+	u16 akm_cnt;
+	u8 *akm_list;
+	u8 *cap;
+	u16 pmkid_cnt;
+	u8 *pmkid_list;
+	u8 *gmcs;
+
+	u8 err;
+};
+int rtw_rsne_info_parse(const u8 *ie, uint ie_len, struct rsne_info *info);
 
 unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit);
 unsigned char *rtw_get_wpa2_ie(unsigned char *pie, int *rsn_ie_len, int limit);
 int rtw_get_wpa_cipher_suite(u8 *s);
 int rtw_get_wpa2_cipher_suite(u8 *s);
-int rtw_get_wapi_ie(u8 *in_ie,uint in_len,u8 *wapi_ie,u16 *wapi_len);
-int rtw_parse_wpa_ie(u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
-int rtw_parse_wpa2_ie(u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
+int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len);
+int rtw_parse_wpa_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
+int rtw_parse_wpa2_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x, u8 *mfp_opt);
 
-int rtw_get_sec_ie(u8 *in_ie,uint in_len,u8 *rsn_ie,u16 *rsn_len,u8 *wpa_ie,u16 *wpa_len);
+int rtw_get_sec_ie(u8 *in_ie, uint in_len, u8 *rsn_ie, u16 *rsn_len, u8 *wpa_ie, u16 *wpa_len);
 
 u8 rtw_is_wps_ie(u8 *ie_ptr, uint *wps_ielen);
-u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, u8 frame_type);
-u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen);
-u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8 *buf_attr, u32 *len_attr);
-u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8 *buf_content, uint *len_content);
+u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, enum bss_type frame_type);
+u8 *rtw_get_wps_ie(const u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen);
+u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_attr, u32 *len_attr);
+u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_content, uint *len_content);
 
 /**
  * for_each_ie - iterate over continuous IEs
@@ -1839,19 +2036,23 @@ u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8
  * @buf_len:
  */
 #define for_each_ie(ie, buf, buf_len) \
-	for (ie = (void*)buf; (((u8*)ie) - ((u8*)buf) + 1) < buf_len; ie = (void*)(((u8*)ie) + *(((u8*)ie)+1) + 2))
+	for (ie = (void *)buf; (((u8 *)ie) - ((u8 *)buf) + 1) < buf_len; ie = (void *)(((u8 *)ie) + *(((u8 *)ie)+1) + 2))
+
+void dump_ies(void *sel, const u8 *buf, u32 buf_len);
 
-void dump_ies(void *sel, u8 *buf, u32 buf_len);
-	
 #ifdef CONFIG_80211N_HT
-void dump_ht_cap_ie_content(void *sel, u8 *buf, u32 buf_len);
+#define HT_SC_OFFSET_MAX 4
+extern const char *const _ht_sc_offset_str[];
+#define ht_sc_offset_str(sc) (((sc) >= HT_SC_OFFSET_MAX) ? _ht_sc_offset_str[2] : _ht_sc_offset_str[(sc)])
+
+void dump_ht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len);
 #endif
 
-void dump_wps_ie(void *sel, u8 *ie, u32 ie_len);
+void dump_wps_ie(void *sel, const u8 *ie, u32 ie_len);
 
-void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset);
+void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht);
 
-void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset);
+void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht);
 
 bool rtw_is_chbw_grouped(u8 ch_a, u8 bw_a, u8 offset_a
 	, u8 ch_b, u8 bw_b, u8 offset_b);
@@ -1860,10 +2061,10 @@ void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
 
 u32 rtw_get_p2p_merged_ies_len(u8 *in_ie, u32 in_len);
 int rtw_p2p_merge_ies(u8 *in_ie, u32 in_len, u8 *merge_ie);
-void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len);
-u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen);
-u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_attr, u32 *len_attr);
-u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id ,u8 *buf_content, uint *len_content);
+void dump_p2p_ie(void *sel, const u8 *ie, u32 ie_len);
+u8 *rtw_get_p2p_ie(const u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen);
+u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr);
+u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content);
 u32 rtw_set_p2p_attr_content(u8 *pbuf, u8 attr_id, u16 attr_len, u8 *pdata_attr);
 uint rtw_del_p2p_ie(u8 *ies, uint ies_len_ori, const char *msg);
 uint rtw_del_p2p_attr(u8 *ie, uint ielen_ori, u8 attr_id);
@@ -1871,8 +2072,8 @@ u8 *rtw_bss_ex_get_p2p_ie(WLAN_BSSID_EX *bss_ex, u8 *p2p_ie, uint *p2p_ielen);
 void rtw_bss_ex_del_p2p_ie(WLAN_BSSID_EX *bss_ex);
 void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id);
 
-void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len);
-u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen);
+void dump_wfd_ie(void *sel, const u8 *ie, u32 ie_len);
+u8 *rtw_get_wfd_ie(const u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen);
 u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr);
 u8 *rtw_get_wfd_attr_content(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content);
 uint rtw_del_wfd_ie(u8 *ies, uint ies_len_ori, const char *msg);
@@ -1899,10 +2100,11 @@ void rtw_get_bcn_info(struct wlan_network *pnetwork);
 u8 rtw_check_invalid_mac_address(u8 *mac_addr, u8 check_local_bit);
 void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr);
 
-u16 rtw_mcs_rate(u8 rf_type, u8 bw_40MHz, u8 short_GI, unsigned char * MCS_rate);
+u16 rtw_mcs_rate(u8 rf_type, u8 bw_40MHz, u8 short_GI, unsigned char *MCS_rate);
 u8	rtw_ht_mcsset_to_nss(u8 *supp_mcs_set);
+u32	rtw_ht_mcs_set_to_bitmap(u8 *mcs_set, u8 nss);
 
-int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8* category, u8 *action);
+int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8 *category, u8 *action);
 const char *action_public_str(u8 action);
 
 u8 key_2char2num(u8 hch, u8 lch);
@@ -1911,5 +2113,5 @@ void macstr2num(u8 *dst, u8 *src);
 u8 convert_ip_addr(u8 hch, u8 mch, u8 lch);
 int wifirate2_ratetbl_inx(unsigned char rate);
 
-#endif /* IEEE80211_H */
 
+#endif /* IEEE80211_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211_ext.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211_ext.h
index 14f1b239c72f..3008777dac11 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211_ext.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ieee80211_ext.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,467 +12,461 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __IEEE80211_EXT_H
-#define __IEEE80211_EXT_H
-
-#include <drv_conf.h>
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#define WMM_OUI_TYPE 2
-#define WMM_OUI_SUBTYPE_INFORMATION_ELEMENT 0
-#define WMM_OUI_SUBTYPE_PARAMETER_ELEMENT 1
-#define WMM_OUI_SUBTYPE_TSPEC_ELEMENT 2
-#define WMM_VERSION 1
-
-#define WPA_PROTO_WPA BIT(0)
-#define WPA_PROTO_RSN BIT(1)
-
-#define WPA_KEY_MGMT_IEEE8021X BIT(0)
-#define WPA_KEY_MGMT_PSK BIT(1)
-#define WPA_KEY_MGMT_NONE BIT(2)
-#define WPA_KEY_MGMT_IEEE8021X_NO_WPA BIT(3)
-#define WPA_KEY_MGMT_WPA_NONE BIT(4)
-
-
-#define WPA_CAPABILITY_PREAUTH BIT(0)
-#define WPA_CAPABILITY_MGMT_FRAME_PROTECTION BIT(6)
-#define WPA_CAPABILITY_PEERKEY_ENABLED BIT(9)
-
-
-#define PMKID_LEN 16
-
-
-#ifdef PLATFORM_LINUX
-struct wpa_ie_hdr {
-	u8 elem_id;
-	u8 len;
-	u8 oui[4]; /* 24-bit OUI followed by 8-bit OUI type */
-	u8 version[2]; /* little endian */
-}__attribute__ ((packed));
-
-struct rsn_ie_hdr {
-	u8 elem_id; /* WLAN_EID_RSN */
-	u8 len;
-	u8 version[2]; /* little endian */
-}__attribute__ ((packed));
-
-struct wme_ac_parameter {
-#if defined(CONFIG_LITTLE_ENDIAN)
-	/* byte 1 */
-	u8 	aifsn:4,
-		acm:1,
-	 	aci:2,
-	 	reserved:1;
-
-	/* byte 2 */
-	u8 	eCWmin:4,
-	 	eCWmax:4;
-#elif defined(CONFIG_BIG_ENDIAN)
-	/* byte 1 */
-	u8 	reserved:1,
-	 	aci:2,
-	 	acm:1,
-	 	aifsn:4;
-
-	/* byte 2 */
-	u8 	eCWmax:4,
-	 	eCWmin:4;
-#else
-#error	"Please fix <endian.h>"
-#endif
-
-	/* bytes 3 & 4 */
-	u16 txopLimit;
-} __attribute__ ((packed));
-
-struct wme_parameter_element {
-	/* required fields for WME version 1 */
-	u8 oui[3];
-	u8 oui_type;
-	u8 oui_subtype;
-	u8 version;
-	u8 acInfo;
-	u8 reserved;
-	struct wme_ac_parameter ac[4];
-
-} __attribute__ ((packed));
-
-#endif
-
-#ifdef PLATFORM_WINDOWS
-
-#pragma pack(1)
-
-struct wpa_ie_hdr {
-	u8 elem_id;
-	u8 len;
-	u8 oui[4]; /* 24-bit OUI followed by 8-bit OUI type */
-	u8 version[2]; /* little endian */
-};
-
-struct rsn_ie_hdr {
-	u8 elem_id; /* WLAN_EID_RSN */
-	u8 len;
-	u8 version[2]; /* little endian */
-};
-
-#pragma pack()
-
-#endif
-
-#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_LE32(a, val)					\
-	do {							\
-		(a)[3] = (u8) ((((u32) (val)) >> 24) & 0xff);	\
-		(a)[2] = (u8) ((((u32) (val)) >> 16) & 0xff);	\
-		(a)[1] = (u8) ((((u32) (val)) >> 8) & 0xff);	\
-		(a)[0] = (u8) (((u32) (val)) & 0xff);		\
-	} while (0)
-
-#define RSN_SELECTOR_PUT(a, val) WPA_PUT_BE32((u8 *) (a), (val))
-//#define RSN_SELECTOR_PUT(a, val) WPA_PUT_LE32((u8 *) (a), (val))
-
-
-
-/* Action category code */
-enum ieee80211_category {
-	WLAN_CATEGORY_SPECTRUM_MGMT = 0,
-	WLAN_CATEGORY_QOS = 1,
-	WLAN_CATEGORY_DLS = 2,
-	WLAN_CATEGORY_BACK = 3,
-	WLAN_CATEGORY_HT = 7,
-	WLAN_CATEGORY_WMM = 17,
-};
-
-/* SPECTRUM_MGMT action code */
-enum ieee80211_spectrum_mgmt_actioncode {
-	WLAN_ACTION_SPCT_MSR_REQ = 0,
-	WLAN_ACTION_SPCT_MSR_RPRT = 1,
-	WLAN_ACTION_SPCT_TPC_REQ = 2,
-	WLAN_ACTION_SPCT_TPC_RPRT = 3,
-	WLAN_ACTION_SPCT_CHL_SWITCH = 4,
-	WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,
-};
-
-/* BACK action code */
-enum ieee80211_back_actioncode {
-	WLAN_ACTION_ADDBA_REQ = 0,
-	WLAN_ACTION_ADDBA_RESP = 1,
-	WLAN_ACTION_DELBA = 2,
-};
-
-/* HT features action code */
-enum ieee80211_ht_actioncode {
-	WLAN_ACTION_NOTIFY_CH_WIDTH = 0,
-       WLAN_ACTION_SM_PS = 1,
-       WLAN_ACTION_PSPM = 2,
-       WLAN_ACTION_PCO_PHASE = 3,
-       WLAN_ACTION_MIMO_CSI_MX = 4,
-       WLAN_ACTION_MIMO_NONCP_BF = 5,
-       WLAN_ACTION_MIMP_CP_BF = 6,
-       WLAN_ACTION_ASEL_INDICATES_FB = 7,
-       WLAN_ACTION_HI_INFO_EXCHG = 8,
-};
-
-/* BACK (block-ack) parties */
-enum ieee80211_back_parties {
-	WLAN_BACK_RECIPIENT = 0,
-	WLAN_BACK_INITIATOR = 1,
-	WLAN_BACK_TIMER = 2,
-};
-
-#ifdef PLATFORM_LINUX
-
-struct ieee80211_mgmt {
-	u16 frame_control;
-	u16 duration;
-	u8 da[6];
-	u8 sa[6];
-	u8 bssid[6];
-	u16 seq_ctrl;
-	union {
-		struct {
-			u16 auth_alg;
-			u16 auth_transaction;
-			u16 status_code;
-			/* possibly followed by Challenge text */
-			u8 variable[0];
-		}  __attribute__ ((packed)) auth;
-		struct {
-			u16 reason_code;
-		}  __attribute__ ((packed)) deauth;
-		struct {
-			u16 capab_info;
-			u16 listen_interval;
-			/* followed by SSID and Supported rates */
-			u8 variable[0];
-		}  __attribute__ ((packed)) assoc_req;
-		struct {
-			u16 capab_info;
-			u16 status_code;
-			u16 aid;
-			/* followed by Supported rates */
-			u8 variable[0];
-		}  __attribute__ ((packed)) assoc_resp, reassoc_resp;
-		struct {
-			u16 capab_info;
-			u16 listen_interval;
-			u8 current_ap[6];
-			/* followed by SSID and Supported rates */
-			u8 variable[0];
-		}  __attribute__ ((packed)) reassoc_req;
-		struct {
-			u16 reason_code;
-		}  __attribute__ ((packed)) disassoc;
-		struct {
-			__le64 timestamp;
-			u16 beacon_int;
-			u16 capab_info;
-			/* followed by some of SSID, Supported rates,
-			 * FH Params, DS Params, CF Params, IBSS Params, TIM */
-			u8 variable[0];
-		}  __attribute__ ((packed)) beacon;
-		struct {
-			/* only variable items: SSID, Supported rates */
-			u8 variable[0];
-		}  __attribute__ ((packed)) probe_req;
-		struct {
-			__le64 timestamp;
-			u16 beacon_int;
-			u16 capab_info;
-			/* followed by some of SSID, Supported rates,
-			 * FH Params, DS Params, CF Params, IBSS Params */
-			u8 variable[0];
-		}  __attribute__ ((packed)) probe_resp;
-		struct {
-			u8 category;
-			union {
-				struct {
-					u8 action_code;
-					u8 dialog_token;
-					u8 status_code;
-					u8 variable[0];
-				}  __attribute__ ((packed)) wme_action;
-#if 0
-				struct{
-					u8 action_code;
-					u8 element_id;
-					u8 length;
-					struct ieee80211_channel_sw_ie sw_elem;
-				}  __attribute__ ((packed)) chan_switch;
-				struct{
-					u8 action_code;
-					u8 dialog_token;
-					u8 element_id;
-					u8 length;
-					struct ieee80211_msrment_ie msr_elem;
-				}  __attribute__ ((packed)) measurement;
-#endif
-				struct{
-					u8 action_code;
-					u8 dialog_token;
-					u16 capab;
-					u16 timeout;
-					u16 start_seq_num;
-				}  __attribute__ ((packed)) addba_req;
-				struct{
-					u8 action_code;
-					u8 dialog_token;
-					u16 status;
-					u16 capab;
-					u16 timeout;
-				}  __attribute__ ((packed)) addba_resp;
-				struct{
-					u8 action_code;
-					u16 params;
-					u16 reason_code;
-				}  __attribute__ ((packed)) delba;
-				struct{
-					u8 action_code;
-					/* capab_info for open and confirm,
-					 * reason for close
-					 */
-					u16 aux;
-					/* Followed in plink_confirm by status
-					 * code, AID and supported rates,
-					 * and directly by supported rates in
-					 * plink_open and plink_close
-					 */
-					u8 variable[0];
-				}  __attribute__ ((packed)) plink_action;
-				struct{
-					u8 action_code;
-					u8 variable[0];
-				}  __attribute__ ((packed)) mesh_action;
-			} __attribute__ ((packed)) u;
-		}  __attribute__ ((packed)) action;
-	} __attribute__ ((packed)) u;
-}__attribute__ ((packed));
-
-#endif
-
-
-#ifdef PLATFORM_WINDOWS
-
-#pragma pack(1)
-
-struct ieee80211_mgmt {
-	u16 frame_control;
-	u16 duration;
-	u8 da[6];
-	u8 sa[6];
-	u8 bssid[6];
-	u16 seq_ctrl;
-	union {
-		struct {
-			u16 auth_alg;
-			u16 auth_transaction;
-			u16 status_code;
-			/* possibly followed by Challenge text */
-			u8 variable[0];
-		}  auth;
-		struct {
-			u16 reason_code;
-		}  deauth;
-		struct {
-			u16 capab_info;
-			u16 listen_interval;
-			/* followed by SSID and Supported rates */
-			u8 variable[0];
-		}  assoc_req;
-		struct {
-			u16 capab_info;
-			u16 status_code;
-			u16 aid;
-			/* followed by Supported rates */
-			u8 variable[0];
-		}  assoc_resp, reassoc_resp;
-		struct {
-			u16 capab_info;
-			u16 listen_interval;
-			u8 current_ap[6];
-			/* followed by SSID and Supported rates */
-			u8 variable[0];
-		}  reassoc_req;
-		struct {
-			u16 reason_code;
-		}  disassoc;
-#if 0		
-		struct {
-			__le64 timestamp;
-			u16 beacon_int;
-			u16 capab_info;
-			/* followed by some of SSID, Supported rates,
-			 * FH Params, DS Params, CF Params, IBSS Params, TIM */
-			u8 variable[0];
-		}  beacon;
-		struct {
-			/* only variable items: SSID, Supported rates */
-			u8 variable[0];
-		}  probe_req;
-		
-		struct {
-			__le64 timestamp;
-			u16 beacon_int;
-			u16 capab_info;
-			/* followed by some of SSID, Supported rates,
-			 * FH Params, DS Params, CF Params, IBSS Params */
-			u8 variable[0];
-		}  probe_resp;
-#endif	
-		struct {
-			u8 category;
-			union {
-				struct {
-					u8 action_code;
-					u8 dialog_token;
-					u8 status_code;
-					u8 variable[0];
-				}  wme_action;
-/*				
-				struct{
-					u8 action_code;
-					u8 element_id;
-					u8 length;
-					struct ieee80211_channel_sw_ie sw_elem;
-				}  chan_switch;
-				struct{
-					u8 action_code;
-					u8 dialog_token;
-					u8 element_id;
-					u8 length;
-					struct ieee80211_msrment_ie msr_elem;
-				}  measurement;
-*/				
-				struct{
-					u8 action_code;
-					u8 dialog_token;
-					u16 capab;
-					u16 timeout;
-					u16 start_seq_num;
-				}  addba_req;
-				struct{
-					u8 action_code;
-					u8 dialog_token;
-					u16 status;
-					u16 capab;
-					u16 timeout;
-				}  addba_resp;
-				struct{
-					u8 action_code;
-					u16 params;
-					u16 reason_code;
-				}  delba;
-				struct{
-					u8 action_code;
-					/* capab_info for open and confirm,
-					 * reason for close
-					 */
-					u16 aux;
-					/* Followed in plink_confirm by status
-					 * code, AID and supported rates,
-					 * and directly by supported rates in
-					 * plink_open and plink_close
-					 */
-					u8 variable[0];
-				}  plink_action;
-				struct{
-					u8 action_code;
-					u8 variable[0];
-				}  mesh_action;
-			} u;
-		}  action;
-	} u;
-} ;
-
-#pragma pack()
-
-#endif
-
-/* mgmt header + 1 byte category code */
-#define IEEE80211_MIN_ACTION_SIZE FIELD_OFFSET(struct ieee80211_mgmt, u.action.u)
-
-
-
-#endif
-
+ *****************************************************************************/
+#ifndef __IEEE80211_EXT_H
+#define __IEEE80211_EXT_H
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#define WMM_OUI_TYPE 2
+#define WMM_OUI_SUBTYPE_INFORMATION_ELEMENT 0
+#define WMM_OUI_SUBTYPE_PARAMETER_ELEMENT 1
+#define WMM_OUI_SUBTYPE_TSPEC_ELEMENT 2
+#define WMM_VERSION 1
+
+#define WPA_PROTO_WPA BIT(0)
+#define WPA_PROTO_RSN BIT(1)
+
+#define WPA_KEY_MGMT_IEEE8021X BIT(0)
+#define WPA_KEY_MGMT_PSK BIT(1)
+#define WPA_KEY_MGMT_NONE BIT(2)
+#define WPA_KEY_MGMT_IEEE8021X_NO_WPA BIT(3)
+#define WPA_KEY_MGMT_WPA_NONE BIT(4)
+
+
+#define WPA_CAPABILITY_PREAUTH BIT(0)
+#define WPA_CAPABILITY_MGMT_FRAME_PROTECTION BIT(6)
+#define WPA_CAPABILITY_PEERKEY_ENABLED BIT(9)
+
+
+#define PMKID_LEN 16
+
+
+#ifdef PLATFORM_LINUX
+struct wpa_ie_hdr {
+	u8 elem_id;
+	u8 len;
+	u8 oui[4]; /* 24-bit OUI followed by 8-bit OUI type */
+	u8 version[2]; /* little endian */
+} __attribute__((packed));
+
+struct rsn_ie_hdr {
+	u8 elem_id; /* WLAN_EID_RSN */
+	u8 len;
+	u8 version[2]; /* little endian */
+} __attribute__((packed));
+
+struct wme_ac_parameter {
+#if defined(CONFIG_LITTLE_ENDIAN)
+	/* byte 1 */
+	u8	aifsn:4,
+	     acm:1,
+	     aci:2,
+	     reserved:1;
+
+	/* byte 2 */
+	u8	eCWmin:4,
+	     eCWmax:4;
+#elif defined(CONFIG_BIG_ENDIAN)
+	/* byte 1 */
+	u8	reserved:1,
+	     aci:2,
+	     acm:1,
+	     aifsn:4;
+
+	/* byte 2 */
+	u8	eCWmax:4,
+	     eCWmin:4;
+#else
+#error	"Please fix <endian.h>"
+#endif
+
+	/* bytes 3 & 4 */
+	u16 txopLimit;
+} __attribute__((packed));
+
+struct wme_parameter_element {
+	/* required fields for WME version 1 */
+	u8 oui[3];
+	u8 oui_type;
+	u8 oui_subtype;
+	u8 version;
+	u8 acInfo;
+	u8 reserved;
+	struct wme_ac_parameter ac[4];
+
+} __attribute__((packed));
+
+#endif
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+
+struct wpa_ie_hdr {
+	u8 elem_id;
+	u8 len;
+	u8 oui[4]; /* 24-bit OUI followed by 8-bit OUI type */
+	u8 version[2]; /* little endian */
+};
+
+struct rsn_ie_hdr {
+	u8 elem_id; /* WLAN_EID_RSN */
+	u8 len;
+	u8 version[2]; /* little endian */
+};
+
+#pragma pack()
+
+#endif
+
+#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_LE32(a, val)					\
+	do {							\
+		(a)[3] = (u8) ((((u32) (val)) >> 24) & 0xff);	\
+		(a)[2] = (u8) ((((u32) (val)) >> 16) & 0xff);	\
+		(a)[1] = (u8) ((((u32) (val)) >> 8) & 0xff);	\
+		(a)[0] = (u8) (((u32) (val)) & 0xff);		\
+	} while (0)
+
+#define RSN_SELECTOR_PUT(a, val) WPA_PUT_BE32((u8 *) (a), (val))
+/* #define RSN_SELECTOR_PUT(a, val) WPA_PUT_LE32((u8 *) (a), (val)) */
+
+
+
+/* Action category code */
+enum ieee80211_category {
+	WLAN_CATEGORY_SPECTRUM_MGMT = 0,
+	WLAN_CATEGORY_QOS = 1,
+	WLAN_CATEGORY_DLS = 2,
+	WLAN_CATEGORY_BACK = 3,
+	WLAN_CATEGORY_HT = 7,
+	WLAN_CATEGORY_WMM = 17,
+};
+
+/* SPECTRUM_MGMT action code */
+enum ieee80211_spectrum_mgmt_actioncode {
+	WLAN_ACTION_SPCT_MSR_REQ = 0,
+	WLAN_ACTION_SPCT_MSR_RPRT = 1,
+	WLAN_ACTION_SPCT_TPC_REQ = 2,
+	WLAN_ACTION_SPCT_TPC_RPRT = 3,
+	WLAN_ACTION_SPCT_CHL_SWITCH = 4,
+	WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,
+};
+
+/* BACK action code */
+enum ieee80211_back_actioncode {
+	WLAN_ACTION_ADDBA_REQ = 0,
+	WLAN_ACTION_ADDBA_RESP = 1,
+	WLAN_ACTION_DELBA = 2,
+};
+
+/* HT features action code */
+enum ieee80211_ht_actioncode {
+	WLAN_ACTION_NOTIFY_CH_WIDTH = 0,
+	WLAN_ACTION_SM_PS = 1,
+	WLAN_ACTION_PSPM = 2,
+	WLAN_ACTION_PCO_PHASE = 3,
+	WLAN_ACTION_MIMO_CSI_MX = 4,
+	WLAN_ACTION_MIMO_NONCP_BF = 5,
+	WLAN_ACTION_MIMP_CP_BF = 6,
+	WLAN_ACTION_ASEL_INDICATES_FB = 7,
+	WLAN_ACTION_HI_INFO_EXCHG = 8,
+};
+
+/* BACK (block-ack) parties */
+enum ieee80211_back_parties {
+	WLAN_BACK_RECIPIENT = 0,
+	WLAN_BACK_INITIATOR = 1,
+	WLAN_BACK_TIMER = 2,
+};
+
+#ifdef PLATFORM_LINUX
+
+struct ieee80211_mgmt {
+	u16 frame_control;
+	u16 duration;
+	u8 da[6];
+	u8 sa[6];
+	u8 bssid[6];
+	u16 seq_ctrl;
+	union {
+		struct {
+			u16 auth_alg;
+			u16 auth_transaction;
+			u16 status_code;
+			/* possibly followed by Challenge text */
+			u8 variable[0];
+		}  __attribute__((packed)) auth;
+		struct {
+			u16 reason_code;
+		}  __attribute__((packed)) deauth;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) assoc_req;
+		struct {
+			u16 capab_info;
+			u16 status_code;
+			u16 aid;
+			/* followed by Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) assoc_resp, reassoc_resp;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			u8 current_ap[6];
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) reassoc_req;
+		struct {
+			u16 reason_code;
+		}  __attribute__((packed)) disassoc;
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params, TIM */
+			u8 variable[0];
+		}  __attribute__((packed)) beacon;
+		struct {
+			/* only variable items: SSID, Supported rates */
+			u8 variable[0];
+		}  __attribute__((packed)) probe_req;
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params */
+			u8 variable[0];
+		}  __attribute__((packed)) probe_resp;
+		struct {
+			u8 category;
+			union {
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u8 status_code;
+					u8 variable[0];
+				}  __attribute__((packed)) wme_action;
+#if 0
+				struct {
+					u8 action_code;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_channel_sw_ie sw_elem;
+				}  __attribute__((packed)) chan_switch;
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_msrment_ie msr_elem;
+				}  __attribute__((packed)) measurement;
+#endif
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 capab;
+					u16 timeout;
+					u16 start_seq_num;
+				}  __attribute__((packed)) addba_req;
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 status;
+					u16 capab;
+					u16 timeout;
+				}  __attribute__((packed)) addba_resp;
+				struct {
+					u8 action_code;
+					u16 params;
+					u16 reason_code;
+				}  __attribute__((packed)) delba;
+				struct {
+					u8 action_code;
+					/* capab_info for open and confirm,
+					 * reason for close
+					 */
+					u16 aux;
+					/* Followed in plink_confirm by status
+					 * code, AID and supported rates,
+					 * and directly by supported rates in
+					 * plink_open and plink_close
+					 */
+					u8 variable[0];
+				}  __attribute__((packed)) plink_action;
+				struct {
+					u8 action_code;
+					u8 variable[0];
+				}  __attribute__((packed)) mesh_action;
+			} __attribute__((packed)) u;
+		}  __attribute__((packed)) action;
+	} __attribute__((packed)) u;
+} __attribute__((packed));
+
+#endif
+
+
+#ifdef PLATFORM_WINDOWS
+
+#pragma pack(1)
+
+struct ieee80211_mgmt {
+	u16 frame_control;
+	u16 duration;
+	u8 da[6];
+	u8 sa[6];
+	u8 bssid[6];
+	u16 seq_ctrl;
+	union {
+		struct {
+			u16 auth_alg;
+			u16 auth_transaction;
+			u16 status_code;
+			/* possibly followed by Challenge text */
+			u8 variable[0];
+		}  auth;
+		struct {
+			u16 reason_code;
+		}  deauth;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  assoc_req;
+		struct {
+			u16 capab_info;
+			u16 status_code;
+			u16 aid;
+			/* followed by Supported rates */
+			u8 variable[0];
+		}  assoc_resp, reassoc_resp;
+		struct {
+			u16 capab_info;
+			u16 listen_interval;
+			u8 current_ap[6];
+			/* followed by SSID and Supported rates */
+			u8 variable[0];
+		}  reassoc_req;
+		struct {
+			u16 reason_code;
+		}  disassoc;
+#if 0
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params, TIM */
+			u8 variable[0];
+		}  beacon;
+		struct {
+			/* only variable items: SSID, Supported rates */
+			u8 variable[0];
+		}  probe_req;
+
+		struct {
+			__le64 timestamp;
+			u16 beacon_int;
+			u16 capab_info;
+			/* followed by some of SSID, Supported rates,
+			 * FH Params, DS Params, CF Params, IBSS Params */
+			u8 variable[0];
+		}  probe_resp;
+#endif
+		struct {
+			u8 category;
+			union {
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u8 status_code;
+					u8 variable[0];
+				}  wme_action;
+				#if 0
+				struct{
+					u8 action_code;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_channel_sw_ie sw_elem;
+				}  chan_switch;
+				struct{
+					u8 action_code;
+					u8 dialog_token;
+					u8 element_id;
+					u8 length;
+					struct ieee80211_msrment_ie msr_elem;
+				}  measurement;
+				#endif
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 capab;
+					u16 timeout;
+					u16 start_seq_num;
+				}  addba_req;
+				struct {
+					u8 action_code;
+					u8 dialog_token;
+					u16 status;
+					u16 capab;
+					u16 timeout;
+				}  addba_resp;
+				struct {
+					u8 action_code;
+					u16 params;
+					u16 reason_code;
+				}  delba;
+				struct {
+					u8 action_code;
+					/* capab_info for open and confirm,
+					 * reason for close
+					 */
+					u16 aux;
+					/* Followed in plink_confirm by status
+					 * code, AID and supported rates,
+					 * and directly by supported rates in
+					 * plink_open and plink_close
+					 */
+					u8 variable[0];
+				}  plink_action;
+				struct {
+					u8 action_code;
+					u8 variable[0];
+				}  mesh_action;
+			} u;
+		}  action;
+	} u;
+} ;
+
+#pragma pack()
+
+#endif
+
+/* mgmt header + 1 byte category code */
+#define IEEE80211_MIN_ACTION_SIZE FIELD_OFFSET(struct ieee80211_mgmt, u.action.u)
+
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/if_ether.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/if_ether.h
index 93ed096df54b..335233b55272 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/if_ether.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/if_ether.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
+ *****************************************************************************/
+
 #ifndef _LINUX_IF_ETHER_H
 #define _LINUX_IF_ETHER_H
 
 /*
  *	IEEE 802.3 Ethernet magic constants.  The frame sizes omit the preamble
- *	and FCS/CRC (frame check sequence). 
+ *	and FCS/CRC (frame check sequence).
  */
 
 #define ETH_ALEN	6		/* Octets in one ethernet addr	 */
@@ -45,21 +41,21 @@
 #define	ETH_P_BPQ	0x08FF		/* G8BPQ AX.25 Ethernet Packet	[ NOT AN OFFICIALLY REGISTERED ID ] */
 #define ETH_P_IEEEPUP	0x0a00		/* Xerox IEEE802.3 PUP packet */
 #define ETH_P_IEEEPUPAT	0x0a01		/* Xerox IEEE802.3 PUP Addr Trans packet */
-#define ETH_P_DEC       0x6000          /* DEC Assigned proto           */
-#define ETH_P_DNA_DL    0x6001          /* DEC DNA Dump/Load            */
-#define ETH_P_DNA_RC    0x6002          /* DEC DNA Remote Console       */
-#define ETH_P_DNA_RT    0x6003          /* DEC DNA Routing              */
-#define ETH_P_LAT       0x6004          /* DEC LAT                      */
-#define ETH_P_DIAG      0x6005          /* DEC Diagnostics              */
-#define ETH_P_CUST      0x6006          /* DEC Customer use             */
-#define ETH_P_SCA       0x6007          /* DEC Systems Comms Arch       */
+#define ETH_P_DEC       0x6000          /* DEC Assigned proto          */
+#define ETH_P_DNA_DL    0x6001          /* DEC DNA Dump/Load           */
+#define ETH_P_DNA_RC    0x6002          /* DEC DNA Remote Console      */
+#define ETH_P_DNA_RT    0x6003          /* DEC DNA Routing             */
+#define ETH_P_LAT       0x6004          /* DEC LAT                     */
+#define ETH_P_DIAG      0x6005          /* DEC Diagnostics             */
+#define ETH_P_CUST      0x6006          /* DEC Customer use            */
+#define ETH_P_SCA       0x6007          /* DEC Systems Comms Arch      */
 #define ETH_P_RARP      0x8035		/* Reverse Addr Res packet	*/
 #define ETH_P_ATALK	0x809B		/* Appletalk DDP		*/
 #define ETH_P_AARP	0x80F3		/* Appletalk AARP		*/
-#define ETH_P_8021Q	0x8100          /* 802.1Q VLAN Extended Header  */
+#define ETH_P_8021Q	0x8100          /* 802.1Q VLAN Extended Header */
 #define ETH_P_IPX	0x8137		/* IPX over DIX			*/
 #define ETH_P_IPV6	0x86DD		/* IPv6 over bluebook		*/
-#define ETH_P_PPP_DISC	0x8863		/* PPPoE discovery messages     */
+#define ETH_P_PPP_DISC	0x8863		/* PPPoE discovery messages    */
 #define ETH_P_PPP_SES	0x8864		/* PPPoE session messages	*/
 #define ETH_P_ATMMPOA	0x884c		/* MultiProtocol Over ATM	*/
 #define ETH_P_ATMFATE	0x8884		/* Frame-based ATM Transport
@@ -69,13 +65,13 @@
 /*
  *	Non DIX types. Won't clash for 1500 types.
  */
- 
-#define ETH_P_802_3	0x0001		/* Dummy type for 802.3 frames  */
-#define ETH_P_AX25	0x0002		/* Dummy protocol id for AX.25  */
+
+#define ETH_P_802_3	0x0001		/* Dummy type for 802.3 frames */
+#define ETH_P_AX25	0x0002		/* Dummy protocol id for AX.25 */
 #define ETH_P_ALL	0x0003		/* Every packet (be careful!!!) */
 #define ETH_P_802_2	0x0004		/* 802.2 frames 		*/
 #define ETH_P_SNAP	0x0005		/* Internal only		*/
-#define ETH_P_DDCMP     0x0006          /* DEC DDCMP: Internal only     */
+#define ETH_P_DDCMP     0x0006          /* DEC DDCMP: Internal only    */
 #define ETH_P_WAN_PPP   0x0007          /* Dummy type for WAN PPP frames*/
 #define ETH_P_PPP_MP    0x0008          /* Dummy type for PPP MP frames */
 #define ETH_P_LOCALTALK 0x0009		/* Localtalk pseudo type 	*/
@@ -89,25 +85,23 @@
 /*
  *	This is an Ethernet frame header.
  */
- 
-struct ethhdr 
-{
+
+struct ethhdr {
 	unsigned char	h_dest[ETH_ALEN];	/* destination eth addr	*/
 	unsigned char	h_source[ETH_ALEN];	/* source ether addr	*/
 	unsigned short	h_proto;		/* packet type ID field	*/
 };
 
 struct _vlan {
-   unsigned short       h_vlan_TCI;                // Encapsulates priority and VLAN ID
-   unsigned short       h_vlan_encapsulated_proto;
+	unsigned short       h_vlan_TCI;                /* Encapsulates priority and VLAN ID */
+	unsigned short       h_vlan_encapsulated_proto;
 };
 
 
 
-#define get_vlan_id(pvlan) ((ntohs((unsigned short )pvlan->h_vlan_TCI)) & 0xfff)
-#define get_vlan_priority(pvlan) ((ntohs((unsigned short )pvlan->h_vlan_TCI))>>13)
-#define get_vlan_encap_proto(pvlan) (ntohs((unsigned short )pvlan->h_vlan_encapsulated_proto))
+#define get_vlan_id(pvlan) ((ntohs((unsigned short)pvlan->h_vlan_TCI)) & 0xfff)
+#define get_vlan_priority(pvlan) ((ntohs((unsigned short)pvlan->h_vlan_TCI))>>13)
+#define get_vlan_encap_proto(pvlan) (ntohs((unsigned short)pvlan->h_vlan_encapsulated_proto))
 
 
 #endif	/* _LINUX_IF_ETHER_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ip.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ip.h
index a637d048c4bd..339e23d50d1d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ip.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/ip.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _LINUX_IP_H
 #define _LINUX_IP_H
 
@@ -55,15 +51,15 @@
 #define	IPOPT_MEASUREMENT	0x40
 #define	IPOPT_RESERVED2		0x60
 
-#define IPOPT_END	(0 |IPOPT_CONTROL)
-#define IPOPT_NOOP	(1 |IPOPT_CONTROL)
-#define IPOPT_SEC	(2 |IPOPT_CONTROL|IPOPT_COPY)
-#define IPOPT_LSRR	(3 |IPOPT_CONTROL|IPOPT_COPY)
-#define IPOPT_TIMESTAMP	(4 |IPOPT_MEASUREMENT)
-#define IPOPT_RR	(7 |IPOPT_CONTROL)
-#define IPOPT_SID	(8 |IPOPT_CONTROL|IPOPT_COPY)
-#define IPOPT_SSRR	(9 |IPOPT_CONTROL|IPOPT_COPY)
-#define IPOPT_RA	(20|IPOPT_CONTROL|IPOPT_COPY)
+#define IPOPT_END	(0 | IPOPT_CONTROL)
+#define IPOPT_NOOP	(1 | IPOPT_CONTROL)
+#define IPOPT_SEC	(2 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_LSRR	(3 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_TIMESTAMP	(4 | IPOPT_MEASUREMENT)
+#define IPOPT_RR	(7 | IPOPT_CONTROL)
+#define IPOPT_SID	(8 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_SSRR	(9 | IPOPT_CONTROL | IPOPT_COPY)
+#define IPOPT_RA	(20 | IPOPT_CONTROL | IPOPT_COPY)
 
 #define IPVERSION	4
 #define MAXTTL		255
@@ -93,23 +89,23 @@
 #ifdef PLATFORM_LINUX
 
 struct ip_options {
-  __u32		faddr;				/* Saved first hop address */
-  unsigned char	optlen;
-  unsigned char srr;
-  unsigned char rr;
-  unsigned char ts;
-  unsigned char is_setbyuser:1,			/* Set by setsockopt?			*/
-                is_data:1,			/* Options in __data, rather than skb	*/
-                is_strictroute:1,		/* Strict source route			*/
-                srr_is_hit:1,			/* Packet destination addr was our one	*/
-                is_changed:1,			/* IP checksum more not valid		*/	
-                rr_needaddr:1,			/* Need to record addr of outgoing dev	*/
-                ts_needtime:1,			/* Need to record timestamp		*/
-                ts_needaddr:1;			/* Need to record addr of outgoing dev  */
-  unsigned char router_alert;
-  unsigned char __pad1;
-  unsigned char __pad2;
-  unsigned char __data[0];
+	__u32		faddr;				/* Saved first hop address */
+	unsigned char	optlen;
+	unsigned char srr;
+	unsigned char rr;
+	unsigned char ts;
+	unsigned char is_setbyuser:1,			/* Set by setsockopt?			*/
+		 is_data:1,			/* Options in __data, rather than skb	*/
+		 is_strictroute:1,		/* Strict source route			*/
+		 srr_is_hit:1,			/* Packet destination addr was our one	*/
+		 is_changed:1,			/* IP checksum more not valid		*/
+		 rr_needaddr:1,			/* Need to record addr of outgoing dev	*/
+		 ts_needtime:1,			/* Need to record timestamp		*/
+		 ts_needaddr:1;			/* Need to record addr of outgoing dev */
+	unsigned char router_alert;
+	unsigned char __pad1;
+	unsigned char __pad2;
+	unsigned char __data[0];
 };
 
 #define optlength(opt) (sizeof(struct ip_options) + opt->optlen)
@@ -121,7 +117,7 @@ struct iphdr {
 		version:4;
 #elif defined (__BIG_ENDIAN_BITFIELD)
 	__u8	version:4,
-  		ihl:4;
+		ihl:4;
 #else
 #error	"Please fix <asm/byteorder.h>"
 #endif
@@ -138,4 +134,3 @@ struct iphdr {
 };
 
 #endif	/* _LINUX_IP_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/linux/wireless.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/linux/wireless.h
index d79caeb592bc..acaa37384089 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/linux/wireless.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/linux/wireless.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #ifndef _LINUX_WIRELESS_H
 #define _LINUX_WIRELESS_H
@@ -24,22 +20,22 @@
 /***************************** INCLUDES *****************************/
 
 #if 0
-#include <linux/types.h>		/* for __u* and __s* typedefs */
-#include <linux/socket.h>		/* for "struct sockaddr" et al	*/
-#include <linux/if.h>			/* for IFNAMSIZ and co... */
+	#include <linux/types.h>		/* for __u* and __s* typedefs */
+	#include <linux/socket.h>		/* for "struct sockaddr" et al	*/
+	#include <linux/if.h>			/* for IFNAMSIZ and co... */
 #else
-#define __user
-//typedef uint16_t	__u16;
-#include <sys/socket.h>			/* for "struct sockaddr" et al	*/
-#include <net/if.h>			/* for IFNAMSIZ and co... */
+	#define __user
+	/* typedef uint16_t	__u16; */
+	#include <sys/socket.h>			/* for "struct sockaddr" et al	*/
+	#include <net/if.h>			/* for IFNAMSIZ and co... */
 #endif
 
 /****************************** TYPES ******************************/
 #ifdef CONFIG_COMPAT
 struct compat_iw_point {
-         compat_caddr_t pointer;
-         __u16 length;
-         __u16 flags;
+	compat_caddr_t pointer;
+	__u16 length;
+	__u16 flags;
 };
 #endif
 /* --------------------------- SUBTYPES --------------------------- */
@@ -47,17 +43,16 @@ struct compat_iw_point {
  *	For all data larger than 16 octets, we need to use a
  *	pointer to memory allocated in user space.
  */
-struct	iw_point
-{
-  void __user	*pointer;	/* Pointer to the data  (in user space) */
-  __u16		length;		/* number of fields or size in bytes */
-  __u16		flags;		/* Optional params */
+struct	iw_point {
+	void __user	*pointer;	/* Pointer to the data  (in user space) */
+	__u16		length;		/* number of fields or size in bytes */
+	__u16		flags;		/* Optional params */
 };
 
 
 /* ------------------------ IOCTL REQUEST ------------------------ */
 /*
- * This structure defines the payload of an ioctl, and is used 
+ * This structure defines the payload of an ioctl, and is used
  * below.
  *
  * Note that this structure should fit on the memory footprint
@@ -66,8 +61,7 @@ struct	iw_point
  * You should check this when increasing the structures defined
  * above in this file...
  */
-union	iwreq_data
-{
+union	iwreq_data {
 	/* Config - generic */
 	char		name[IFNAMSIZ];
 	/* Name : used to verify the presence of  wireless extensions.
@@ -82,10 +76,8 @@ union	iwreq_data
  * convenience...
  * Do I need to remind you about structure size (32 octets) ?
  */
-struct	iwreq 
-{
-	union
-	{
+struct	iwreq {
+	union {
 		char	ifrn_name[IFNAMSIZ];	/* if name, e.g. "eth0" */
 	} ifr_ifrn;
 
@@ -94,4 +86,3 @@ struct	iwreq
 };
 
 #endif	/* _LINUX_WIRELESS_H */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mlme_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mlme_osdep.h
index a740a1306f66..29b8426c59ac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mlme_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mlme_osdep.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,27 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef	__MLME_OSDEP_H_
 #define __MLME_OSDEP_H_
 
-
-#if defined(PLATFORM_WINDOWS) || defined(PLATFORM_MPIXEL)
-extern int time_after(u32 now, u32 old);
-#endif
-
-extern void rtw_init_mlme_timer(_adapter *padapter);
 extern void rtw_os_indicate_disconnect(_adapter *adapter, u16 reason, u8 locally_generated);
-extern void rtw_os_indicate_connect( _adapter *adapter );
-void rtw_os_indicate_scan_done( _adapter *padapter, bool aborted);
-extern void rtw_report_sec_ie(_adapter *adapter,u8 authmode,u8 *sec_ie);
-
-void rtw_reset_securitypriv( _adapter *adapter );
+extern void rtw_os_indicate_connect(_adapter *adapter);
+void rtw_os_indicate_scan_done(_adapter *padapter, bool aborted);
+extern void rtw_report_sec_ie(_adapter *adapter, u8 authmode, u8 *sec_ie);
 
-#endif	//_MLME_OSDEP_H_
+void rtw_reset_securitypriv(_adapter *adapter);
 
+#endif /* _MLME_OSDEP_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mp_custom_oid.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mp_custom_oid.h
index 9cf1c8270090..51146ef49446 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mp_custom_oid.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/mp_custom_oid.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,34 +12,29 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef	__CUSTOM_OID_H
 #define __CUSTOM_OID_H
 
-// by Owen
-// 0xFF818000 - 0xFF81802F		RTL8180 Mass Production Kit
-// 0xFF818500 - 0xFF81850F		RTL8185 Setup Utility
-// 0xFF818580 - 0xFF81858F		RTL8185 Phy Status Utility
+/* by Owen
+ * 0xFF818000 - 0xFF81802F		RTL8180 Mass Production Kit
+ * 0xFF818500 - 0xFF81850F		RTL8185 Setup Utility
+ * 0xFF818580 - 0xFF81858F		RTL8185 Phy Status Utility */
 
-//
+/*  */
 
-// by Owen for Production Kit
-// For Production Kit with Agilent Equipments
-// in order to make our custom oids hopefully somewhat unique
-// we will use 0xFF (indicating implementation specific OID)
-//               81(first byte of non zero Realtek unique identifier)
-//               80 (second byte of non zero Realtek unique identifier)
-//               XX (the custom OID number - providing 255 possible custom oids)
+/* by Owen for Production Kit
+ * For Production Kit with Agilent Equipments
+ * in order to make our custom oids hopefully somewhat unique
+ * we will use 0xFF (indicating implementation specific OID)
+ * 81(first byte of non zero Realtek unique identifier)
+ * 80 (second byte of non zero Realtek unique identifier)
+ * XX (the custom OID number - providing 255 possible custom oids) */
 
 #define OID_RT_PRO_RESET_DUT				0xFF818000
 #define OID_RT_PRO_SET_DATA_RATE			0xFF818001
 #define OID_RT_PRO_START_TEST				0xFF818002
-#define OID_RT_PRO_STOP_TEST    			0xFF818003
+#define OID_RT_PRO_STOP_TEST			0xFF818003
 #define OID_RT_PRO_SET_PREAMBLE				0xFF818004
 #define OID_RT_PRO_SET_SCRAMBLER			0xFF818005
 #define OID_RT_PRO_SET_FILTER_BB			0xFF818006
@@ -71,33 +67,33 @@
 #define OID_RT_PRO_READ_EEPROM				0xFF818022
 #define OID_RT_PRO_RESET_TX_PACKET_SENT			0xFF818023
 #define OID_RT_PRO_QUERY_TX_PACKET_SENT			0xFF818024
-#define OID_RT_PRO_RESET_RX_PACKET_RECEIVED		0xFF818025 
+#define OID_RT_PRO_RESET_RX_PACKET_RECEIVED		0xFF818025
 #define OID_RT_PRO_QUERY_RX_PACKET_RECEIVED		0xFF818026
 #define OID_RT_PRO_QUERY_RX_PACKET_CRC32_ERROR		0xFF818027
 #define OID_RT_PRO_QUERY_CURRENT_ADDRESS		0xFF818028
 #define OID_RT_PRO_QUERY_PERMANENT_ADDRESS		0xFF818029
 #define OID_RT_PRO_SET_PHILIPS_RF_PARAMETERS		0xFF81802A
 #define OID_RT_PRO_RECEIVE_PACKET			0xFF81802C
-// added by Owen on 04/08/03 for Cameo's request
+/* added by Owen on 04/08/03 for Cameo's request */
 #define OID_RT_PRO_WRITE_EEPROM_BYTE			0xFF81802D
 #define OID_RT_PRO_READ_EEPROM_BYTE			0xFF81802E
 #define OID_RT_PRO_SET_MODULATION			0xFF81802F
-//
+/*  */
 
-//Sean		
+/* Sean		 */
 #define OID_RT_DRIVER_OPTION				0xFF818080
 #define OID_RT_RF_OFF					0xFF818081
 #define OID_RT_AUTH_STATUS				0xFF818082
 
-//========================================================================
+/* ************************************************************************ */
 #define OID_RT_PRO_SET_CONTINUOUS_TX			0xFF81800B
 #define OID_RT_PRO_SET_SINGLE_CARRIER_TX		0xFF81800C
 #define OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX		0xFF81802B
 #define OID_RT_PRO_SET_SINGLE_TONE_TX			0xFF818043
-//========================================================================
+/* ************************************************************************ */
 
 
-// by Owen for RTL8185 Phy Status Report Utility
+/* by Owen for RTL8185 Phy Status Report Utility */
 #define OID_RT_UTILITY_FALSE_ALARM_COUNTERS				0xFF818580
 #define OID_RT_UTILITY_SELECT_DEBUG_MODE				0xFF818581
 #define OID_RT_UTILITY_SELECT_SUBCARRIER_NUMBER				0xFF818582
@@ -105,30 +101,30 @@
 #define OID_RT_UTILITY_GET_FRAME_DETECTION_STATUS			0xFF818584
 #define OID_RT_UTILITY_GET_AGC_AND_FREQUENCY_OFFSET_ESTIMATION_STATUS	0xFF818585
 #define OID_RT_UTILITY_GET_CHANNEL_ESTIMATION_STATUS			0xFF818586
-//
+/*  */
 
-// by Owen on 03/09/19-03/09/22 for RTL8185
+/* by Owen on 03/09/19-03/09/22 for RTL8185 */
 #define OID_RT_WIRELESS_MODE				0xFF818500
 #define OID_RT_SUPPORTED_RATES				0xFF818501
 #define OID_RT_DESIRED_RATES				0xFF818502
 #define OID_RT_WIRELESS_MODE_STARTING_ADHOC		0xFF818503
-//
+/*  */
 
-#define OID_RT_GET_CONNECT_STATE                	0xFF030001
-#define OID_RT_RESCAN	                        	0xFF030002
+#define OID_RT_GET_CONNECT_STATE	0xFF030001
+#define OID_RT_RESCAN		0xFF030002
 #define OID_RT_SET_KEY_LENGTH				0xFF030003
 #define OID_RT_SET_DEFAULT_KEY_ID			0xFF030004
 
 #define OID_RT_SET_CHANNEL				0xFF010182
-#define OID_RT_SET_SNIFFER_MODE                 	0xFF010183
-#define OID_RT_GET_SIGNAL_QUALITY               	0xFF010184
-#define OID_RT_GET_SMALL_PACKET_CRC			0xFF010185		
+#define OID_RT_SET_SNIFFER_MODE	0xFF010183
+#define OID_RT_GET_SIGNAL_QUALITY	0xFF010184
+#define OID_RT_GET_SMALL_PACKET_CRC			0xFF010185
 #define OID_RT_GET_MIDDLE_PACKET_CRC			0xFF010186
 #define OID_RT_GET_LARGE_PACKET_CRC			0xFF010187
 #define OID_RT_GET_TX_RETRY				0xFF010188
 #define OID_RT_GET_RX_RETRY				0xFF010189
-#define OID_RT_PRO_SET_FW_DIG_STATE			0xFF01018A//S
-#define OID_RT_PRO_SET_FW_RA_STATE			0xFF01018B//S
+#define OID_RT_PRO_SET_FW_DIG_STATE			0xFF01018A/* S */
+#define OID_RT_PRO_SET_FW_RA_STATE			0xFF01018B/* S */
 
 #define OID_RT_GET_RX_TOTAL_PACKET			0xFF010190
 #define OID_RT_GET_TX_BEACON_OK				0xFF010191
@@ -155,9 +151,9 @@
 #define OID_RT_GET_CCA_UPGRADE_EVALUATE_TIMES		0xFF0101A3
 #define OID_RT_GET_CCA_FALLBACK_EVALUATE_TIMES		0xFF0101A4
 
-// by Owen on 03/31/03 for Cameo's request
+/* by Owen on 03/31/03 for Cameo's request */
 #define OID_RT_SET_RATE_ADAPTIVE			0xFF0101A5
-//
+/*  */
 #define OID_RT_GET_DCST_EVALUATE_PERIOD			0xFF0101A5
 #define OID_RT_GET_DCST_TIME_UNIT_INDEX			0xFF0101A6
 #define OID_RT_GET_TOTAL_TX_BYTES			0xFF0101A7
@@ -188,20 +184,20 @@
 #define OID_RT_RF_READ_WRITE_OFFSET			0xFF0101BF
 #define OID_RT_RF_READ_WRITE				0xFF0101C0
 
-// For Netgear request. 2005.01.13, by rcnjko.
+/* For Netgear request. 2005.01.13, by rcnjko. */
 #define OID_RT_FORCED_DATA_RATE				0xFF0101C1
 #define OID_RT_WIRELESS_MODE_FOR_SCAN_LIST		0xFF0101C2
-// For Netgear request. 2005.02.17, by rcnjko.
+/* For Netgear request. 2005.02.17, by rcnjko. */
 #define OID_RT_GET_BSS_WIRELESS_MODE			0xFF0101C3
-// For AZ project. 2005.06.27, by rcnjko.
+/* For AZ project. 2005.06.27, by rcnjko. */
 #define OID_RT_SCAN_WITH_MAGIC_PACKET			0xFF0101C4
 
-// Vincent 8185MP
+/* Vincent 8185MP */
 #define OID_RT_PRO_RX_FILTER				0xFF0111C0
 
-//Andy TEST
-//#define OID_RT_PRO_WRITE_REGISTRY			0xFF0111C1
-//#define OID_RT_PRO_READ_REGISTRY			0xFF0111C2
+/* Andy TEST
+ * #define OID_RT_PRO_WRITE_REGISTRY			0xFF0111C1
+ * #define OID_RT_PRO_READ_REGISTRY			0xFF0111C2 */
 #define OID_CE_USB_WRITE_REGISTRY			0xFF0111C1
 #define OID_CE_USB_READ_REGISTRY			0xFF0111C2
 
@@ -215,140 +211,139 @@
 #define OID_RT_PRO_RF_READ_REGISTRY			0xFF0111C9
 #define OID_RT_PRO_QUERY_RF_TYPE			0xFF0111CA
 
-// AP OID
+/* AP OID */
 #define OID_RT_AP_GET_ASSOCIATED_STATION_LIST		0xFF010300
 #define OID_RT_AP_GET_CURRENT_TIME_STAMP		0xFF010301
 #define OID_RT_AP_SWITCH_INTO_AP_MODE			0xFF010302
 #define OID_RT_AP_SET_DTIM_PERIOD			0xFF010303
-#define OID_RT_AP_SUPPORTED				0xFF010304	// Determine if driver supports AP mode. 2004.08.27, by rcnjko.
-#define OID_RT_AP_SET_PASSPHRASE			0xFF010305	// Set WPA-PSK passphrase into authenticator. 2005.07.08, byrcnjko.
+#define OID_RT_AP_SUPPORTED				0xFF010304	/* Determine if driver supports AP mode. 2004.08.27, by rcnjko. */
+#define OID_RT_AP_SET_PASSPHRASE			0xFF010305	/* Set WPA-PSK passphrase into authenticator. 2005.07.08, byrcnjko. */
 
-// 8187MP. 2004.09.06, by rcnjko.
+/* 8187MP. 2004.09.06, by rcnjko. */
 #define OID_RT_PRO8187_WI_POLL				0xFF818780
 #define OID_RT_PRO_WRITE_BB_REG				0xFF818781
 #define OID_RT_PRO_READ_BB_REG				0xFF818782
 #define OID_RT_PRO_WRITE_RF_REG				0xFF818783
 #define OID_RT_PRO_READ_RF_REG				0xFF818784
 
-// Meeting House. added by Annie, 2005-07-20.
+/* Meeting House. added by Annie, 2005-07-20. */
 #define OID_RT_MH_VENDER_ID				0xFFEDC100
 
-//8711 MP OID added 20051230.
-#define OID_RT_PRO8711_JOIN_BSS				0xFF871100//S
-
-#define OID_RT_PRO_READ_REGISTER			0xFF871101 //Q
-#define OID_RT_PRO_WRITE_REGISTER			0xFF871102 //S
-
-#define OID_RT_PRO_BURST_READ_REGISTER			0xFF871103 //Q		
-#define OID_RT_PRO_BURST_WRITE_REGISTER 		0xFF871104 //S
-
-#define OID_RT_PRO_WRITE_TXCMD				0xFF871105 //S
-
-#define OID_RT_PRO_READ16_EEPROM			0xFF871106 //Q
-#define OID_RT_PRO_WRITE16_EEPROM			0xFF871107 //S
-
-#define OID_RT_PRO_H2C_SET_COMMAND			0xFF871108 //S
-#define OID_RT_PRO_H2C_QUERY_RESULT			0xFF871109 //Q
-
-#define OID_RT_PRO8711_WI_POLL				0xFF87110A //Q
-#define OID_RT_PRO8711_PKT_LOSS				0xFF87110B //Q
-#define OID_RT_RD_ATTRIB_MEM				0xFF87110C//Q
-#define OID_RT_WR_ATTRIB_MEM				0xFF87110D//S
-
-
-//Method 2 for H2C/C2H
-#define OID_RT_PRO_H2C_CMD_MODE				0xFF871110 //S
-#define OID_RT_PRO_H2C_CMD_RSP_MODE			0xFF871111 //Q
-#define OID_RT_PRO_H2C_CMD_EVENT_MODE			0xFF871112 //S
-#define OID_RT_PRO_WAIT_C2H_EVENT			0xFF871113 //Q
-#define OID_RT_PRO_RW_ACCESS_PROTOCOL_TEST		0xFF871114//Q
-
-#define OID_RT_PRO_SCSI_ACCESS_TEST			0xFF871115 //Q, S
-
-#define OID_RT_PRO_SCSI_TCPIPOFFLOAD_OUT		0xFF871116 //S
-#define OID_RT_PRO_SCSI_TCPIPOFFLOAD_IN			0xFF871117 //Q,S
-#define OID_RT_RRO_RX_PKT_VIA_IOCTRL			0xFF871118 //Q
-#define OID_RT_RRO_RX_PKTARRAY_VIA_IOCTRL		0xFF871119 //Q
-
-#define OID_RT_RPO_SET_PWRMGT_TEST			0xFF87111A //S
-#define OID_RT_PRO_QRY_PWRMGT_TEST			0XFF87111B //Q
-#define OID_RT_RPO_ASYNC_RWIO_TEST			0xFF87111C //S
-#define OID_RT_RPO_ASYNC_RWIO_POLL			0xFF87111D //Q
-#define OID_RT_PRO_SET_RF_INTFS				0xFF87111E //S
-#define OID_RT_POLL_RX_STATUS				0xFF87111F //Q
-
-#define OID_RT_PRO_CFG_DEBUG_MESSAGE			0xFF871120 //Q,S
-#define OID_RT_PRO_SET_DATA_RATE_EX			0xFF871121//S
-#define OID_RT_PRO_SET_BASIC_RATE			0xFF871122//S
-#define OID_RT_PRO_READ_TSSI				0xFF871123//S
-#define OID_RT_PRO_SET_POWER_TRACKING			0xFF871124//S
-
- 
-#define OID_RT_PRO_QRY_PWRSTATE				0xFF871150 //Q
-#define OID_RT_PRO_SET_PWRSTATE				0xFF871151 //S 
-
-//Method 2 , using workitem
-#define OID_RT_SET_READ_REG				0xFF871181 //S
-#define OID_RT_SET_WRITE_REG				0xFF871182 //S
-#define OID_RT_SET_BURST_READ_REG			0xFF871183 //S
-#define OID_RT_SET_BURST_WRITE_REG			0xFF871184 //S
-#define OID_RT_SET_WRITE_TXCMD				0xFF871185 //S
-#define OID_RT_SET_READ16_EEPROM			0xFF871186 //S
-#define OID_RT_SET_WRITE16_EEPROM			0xFF871187 //S
-#define OID_RT_QRY_POLL_WKITEM				0xFF871188 //Q
-
-//For SDIO INTERFACE only
-#define OID_RT_PRO_SYNCPAGERW_SRAM			0xFF8711A0 //Q, S
-#define OID_RT_PRO_871X_DRV_EXT 			0xFF8711A1
-
-//For USB INTERFACE only
-#define OID_RT_PRO_USB_VENDOR_REQ			0xFF8711B0 //Q, S
-#define OID_RT_PRO_SCSI_AUTO_TEST			0xFF8711B1 //S
-#define OID_RT_PRO_USB_MAC_AC_FIFO_WRITE		0xFF8711B2 //S
-#define OID_RT_PRO_USB_MAC_RX_FIFO_READ			0xFF8711B3 //Q
-#define OID_RT_PRO_USB_MAC_RX_FIFO_POLLING		0xFF8711B4 //Q
-
-#define OID_RT_PRO_H2C_SET_RATE_TABLE			0xFF8711FB //S
-#define OID_RT_PRO_H2C_GET_RATE_TABLE			0xFF8711FC //S
-#define OID_RT_PRO_H2C_C2H_LBK_TEST			0xFF8711FE
+/* 8711 MP OID added 20051230. */
+#define OID_RT_PRO8711_JOIN_BSS				0xFF871100/* S */
+
+#define OID_RT_PRO_READ_REGISTER			0xFF871101 /* Q */
+#define OID_RT_PRO_WRITE_REGISTER			0xFF871102 /* S */
+
+#define OID_RT_PRO_BURST_READ_REGISTER			0xFF871103 /* Q		 */
+#define OID_RT_PRO_BURST_WRITE_REGISTER 		0xFF871104 /* S */
+
+#define OID_RT_PRO_WRITE_TXCMD				0xFF871105 /* S */
+
+#define OID_RT_PRO_READ16_EEPROM			0xFF871106 /* Q */
+#define OID_RT_PRO_WRITE16_EEPROM			0xFF871107 /* S */
+
+#define OID_RT_PRO_H2C_SET_COMMAND			0xFF871108 /* S */
+#define OID_RT_PRO_H2C_QUERY_RESULT			0xFF871109 /* Q */
+
+#define OID_RT_PRO8711_WI_POLL				0xFF87110A /* Q */
+#define OID_RT_PRO8711_PKT_LOSS				0xFF87110B /* Q */
+#define OID_RT_RD_ATTRIB_MEM				0xFF87110C/* Q */
+#define OID_RT_WR_ATTRIB_MEM				0xFF87110D/* S */
+
 
-#define OID_RT_PRO_ENCRYPTION_CTRL			0xFF871200 //Q, S
-#define OID_RT_PRO_ADD_STA_INFO				0xFF871201 //S
-#define OID_RT_PRO_DELE_STA_INFO    			0xFF871202 //S
-#define OID_RT_PRO_QUERY_DR_VARIABLE   			0xFF871203 //Q
+/* Method 2 for H2C/C2H */
+#define OID_RT_PRO_H2C_CMD_MODE				0xFF871110 /* S */
+#define OID_RT_PRO_H2C_CMD_RSP_MODE			0xFF871111 /* Q */
+#define OID_RT_PRO_H2C_CMD_EVENT_MODE			0xFF871112 /* S */
+#define OID_RT_PRO_WAIT_C2H_EVENT			0xFF871113 /* Q */
+#define OID_RT_PRO_RW_ACCESS_PROTOCOL_TEST		0xFF871114/* Q */
+
+#define OID_RT_PRO_SCSI_ACCESS_TEST			0xFF871115 /* Q, S */
+
+#define OID_RT_PRO_SCSI_TCPIPOFFLOAD_OUT		0xFF871116 /* S */
+#define OID_RT_PRO_SCSI_TCPIPOFFLOAD_IN			0xFF871117 /* Q, S */
+#define OID_RT_RRO_RX_PKT_VIA_IOCTRL			0xFF871118 /* Q */
+#define OID_RT_RRO_RX_PKTARRAY_VIA_IOCTRL		0xFF871119 /* Q */
+
+#define OID_RT_RPO_SET_PWRMGT_TEST			0xFF87111A /* S */
+#define OID_RT_PRO_QRY_PWRMGT_TEST			0XFF87111B /* Q */
+#define OID_RT_RPO_ASYNC_RWIO_TEST			0xFF87111C /* S */
+#define OID_RT_RPO_ASYNC_RWIO_POLL			0xFF87111D /* Q */
+#define OID_RT_PRO_SET_RF_INTFS				0xFF87111E /* S */
+#define OID_RT_POLL_RX_STATUS				0xFF87111F /* Q */
+
+#define OID_RT_PRO_CFG_DEBUG_MESSAGE			0xFF871120 /* Q, S */
+#define OID_RT_PRO_SET_DATA_RATE_EX			0xFF871121/* S */
+#define OID_RT_PRO_SET_BASIC_RATE			0xFF871122/* S */
+#define OID_RT_PRO_READ_TSSI				0xFF871123/* S */
+#define OID_RT_PRO_SET_POWER_TRACKING			0xFF871124/* S */
+
+
+#define OID_RT_PRO_QRY_PWRSTATE				0xFF871150 /* Q */
+#define OID_RT_PRO_SET_PWRSTATE				0xFF871151 /* S */
+
+/* Method 2 , using workitem */
+#define OID_RT_SET_READ_REG				0xFF871181 /* S */
+#define OID_RT_SET_WRITE_REG				0xFF871182 /* S */
+#define OID_RT_SET_BURST_READ_REG			0xFF871183 /* S */
+#define OID_RT_SET_BURST_WRITE_REG			0xFF871184 /* S */
+#define OID_RT_SET_WRITE_TXCMD				0xFF871185 /* S */
+#define OID_RT_SET_READ16_EEPROM			0xFF871186 /* S */
+#define OID_RT_SET_WRITE16_EEPROM			0xFF871187 /* S */
+#define OID_RT_QRY_POLL_WKITEM				0xFF871188 /* Q */
+
+/* For SDIO INTERFACE only */
+#define OID_RT_PRO_SYNCPAGERW_SRAM			0xFF8711A0 /* Q, S */
+#define OID_RT_PRO_871X_DRV_EXT			0xFF8711A1
+
+/* For USB INTERFACE only */
+#define OID_RT_PRO_USB_VENDOR_REQ			0xFF8711B0 /* Q, S */
+#define OID_RT_PRO_SCSI_AUTO_TEST			0xFF8711B1 /* S */
+#define OID_RT_PRO_USB_MAC_AC_FIFO_WRITE		0xFF8711B2 /* S */
+#define OID_RT_PRO_USB_MAC_RX_FIFO_READ			0xFF8711B3 /* Q */
+#define OID_RT_PRO_USB_MAC_RX_FIFO_POLLING		0xFF8711B4 /* Q */
+
+#define OID_RT_PRO_H2C_SET_RATE_TABLE			0xFF8711FB /* S */
+#define OID_RT_PRO_H2C_GET_RATE_TABLE			0xFF8711FC /* S */
+#define OID_RT_PRO_H2C_C2H_LBK_TEST			0xFF8711FE
 
-#define OID_RT_PRO_RX_PACKET_TYPE			0xFF871204 //Q, S
+#define OID_RT_PRO_ENCRYPTION_CTRL			0xFF871200 /* Q, S */
+#define OID_RT_PRO_ADD_STA_INFO				0xFF871201 /* S */
+#define OID_RT_PRO_DELE_STA_INFO    			0xFF871202 /* S */
+#define OID_RT_PRO_QUERY_DR_VARIABLE   			0xFF871203 /* Q */
 
-#define OID_RT_PRO_READ_EFUSE				0xFF871205 //Q
-#define OID_RT_PRO_WRITE_EFUSE				0xFF871206 //S
-#define OID_RT_PRO_RW_EFUSE_PGPKT			0xFF871207 //Q, S
-#define OID_RT_GET_EFUSE_CURRENT_SIZE			0xFF871208 //Q
+#define OID_RT_PRO_RX_PACKET_TYPE			0xFF871204 /* Q, S */
 
-#define OID_RT_SET_BANDWIDTH				0xFF871209 //S
-#define OID_RT_SET_CRYSTAL_CAP				0xFF87120A //S
+#define OID_RT_PRO_READ_EFUSE				0xFF871205 /* Q */
+#define OID_RT_PRO_WRITE_EFUSE				0xFF871206 /* S */
+#define OID_RT_PRO_RW_EFUSE_PGPKT			0xFF871207 /* Q, S */
+#define OID_RT_GET_EFUSE_CURRENT_SIZE			0xFF871208 /* Q */
 
-#define OID_RT_SET_RX_PACKET_TYPE    			0xFF87120B //S
+#define OID_RT_SET_BANDWIDTH				0xFF871209 /* S */
+#define OID_RT_SET_CRYSTAL_CAP				0xFF87120A /* S */
 
-#define OID_RT_GET_EFUSE_MAX_SIZE			0xFF87120C //Q
+#define OID_RT_SET_RX_PACKET_TYPE    			0xFF87120B /* S */
 
-#define OID_RT_PRO_SET_TX_AGC_OFFSET			0xFF87120D //S
+#define OID_RT_GET_EFUSE_MAX_SIZE			0xFF87120C /* Q */
 
-#define OID_RT_PRO_SET_PKT_TEST_MODE			0xFF87120E //S
+#define OID_RT_PRO_SET_TX_AGC_OFFSET			0xFF87120D /* S */
 
-#define OID_RT_PRO_FOR_EVM_TEST_SETTING			0xFF87120F //S
+#define OID_RT_PRO_SET_PKT_TEST_MODE			0xFF87120E /* S */
 
-#define OID_RT_PRO_GET_THERMAL_METER			0xFF871210 //Q
+#define OID_RT_PRO_FOR_EVM_TEST_SETTING			0xFF87120F /* S */
 
-#define OID_RT_RESET_PHY_RX_PACKET_COUNT		0xFF871211 //S
-#define OID_RT_GET_PHY_RX_PACKET_RECEIVED		0xFF871212 //Q
-#define OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR		0xFF871213 //Q
+#define OID_RT_PRO_GET_THERMAL_METER			0xFF871210 /* Q */
 
-#define OID_RT_SET_POWER_DOWN				0xFF871214 //S
+#define OID_RT_RESET_PHY_RX_PACKET_COUNT		0xFF871211 /* S */
+#define OID_RT_GET_PHY_RX_PACKET_RECEIVED		0xFF871212 /* Q */
+#define OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR		0xFF871213 /* Q */
 
-#define OID_RT_GET_POWER_MODE				0xFF871215 //Q
+#define OID_RT_SET_POWER_DOWN				0xFF871214 /* S */
 
-#define OID_RT_PRO_EFUSE				0xFF871216 //Q, S
-#define OID_RT_PRO_EFUSE_MAP				0xFF871217 //Q, S
+#define OID_RT_GET_POWER_MODE				0xFF871215 /* Q */
 
-#endif //#ifndef	__CUSTOM_OID_H
+#define OID_RT_PRO_EFUSE				0xFF871216 /* Q, S */
+#define OID_RT_PRO_EFUSE_MAP				0xFF871217 /* Q, S */
 
+#endif /* #ifndef	__CUSTOM_OID_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/nic_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/nic_spec.h
index 18e7b2c09671..5e66f6c82b3b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/nic_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/nic_spec.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/	
+ *****************************************************************************/
 
 
 #ifndef __NIC_SPEC_H__
@@ -43,5 +39,4 @@
 #include <rtl8711_bitdef.h>
 
 
-#endif // __RTL8711_SPEC_H__
-
+#endif /* __RTL8711_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_intf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_intf.h
index 8b8679fa1a43..fcd5c972e3fc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_intf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_intf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #ifndef __OSDEP_INTF_H_
 #define __OSDEP_INTF_H_
@@ -25,33 +21,33 @@
 struct intf_priv {
 
 	u8 *intf_dev;
-	u32	max_iosz; 	//USB2.0: 128, USB1.1: 64, SDIO:64
-	u32	max_xmitsz; //USB2.0: unlimited, SDIO:512
-	u32	max_recvsz; //USB2.0: unlimited, SDIO:512
+	u32	max_iosz;	/* USB2.0: 128, USB1.1: 64, SDIO:64 */
+	u32	max_xmitsz; /* USB2.0: unlimited, SDIO:512 */
+	u32	max_recvsz; /* USB2.0: unlimited, SDIO:512 */
 
 	volatile u8 *io_rwmem;
 	volatile u8 *allocated_io_rwmem;
-	u32	io_wsz; //unit: 4bytes
-	u32	io_rsz;//unit: 4bytes
+	u32	io_wsz; /* unit: 4bytes */
+	u32	io_rsz;/* unit: 4bytes */
 	u8 intf_status;
 
 	void (*_bus_io)(u8 *priv);
 
-/*
-Under Sync. IRP (SDIO/USB)
-A protection mechanism is necessary for the io_rwmem(read/write protocol)
+	/*
+	Under Sync. IRP (SDIO/USB)
+	A protection mechanism is necessary for the io_rwmem(read/write protocol)
 
-Under Async. IRP (SDIO/USB)
-The protection mechanism is through the pending queue.
-*/
+	Under Async. IRP (SDIO/USB)
+	The protection mechanism is through the pending queue.
+	*/
 
 	_mutex ioctl_mutex;
 
 
 #ifdef PLATFORM_LINUX
-	#ifdef CONFIG_USB_HCI
-	// when in USB, IO is through interrupt in/out endpoints
-	struct usb_device 	*udev;
+#ifdef CONFIG_USB_HCI
+	/* when in USB, IO is through interrupt in/out endpoints */
+	struct usb_device	*udev;
 	PURB	piorw_urb;
 	u8 io_irp_cnt;
 	u8 bio_irp_pending;
@@ -59,35 +55,35 @@ The protection mechanism is through the pending queue.
 	_timer	io_timer;
 	u8 bio_irp_timeout;
 	u8 bio_timer_cancel;
-	#endif
+#endif
 #endif
 
 #ifdef PLATFORM_OS_XP
-	#ifdef CONFIG_SDIO_HCI
-		// below is for io_rwmem...
-		PMDL pmdl;
-		PSDBUS_REQUEST_PACKET  sdrp;
-		PSDBUS_REQUEST_PACKET  recv_sdrp;
-		PSDBUS_REQUEST_PACKET  xmit_sdrp;
-
-			PIRP		piorw_irp;
-
-	#endif
-	#ifdef CONFIG_USB_HCI
-		PURB	piorw_urb;
-		PIRP		piorw_irp;
-		u8 io_irp_cnt;
-		u8 bio_irp_pending;
-		_sema io_retevt;
-	#endif
+#ifdef CONFIG_SDIO_HCI
+	/* below is for io_rwmem... */
+	PMDL pmdl;
+	PSDBUS_REQUEST_PACKET  sdrp;
+	PSDBUS_REQUEST_PACKET  recv_sdrp;
+	PSDBUS_REQUEST_PACKET  xmit_sdrp;
+
+	PIRP		piorw_irp;
+
+#endif
+#ifdef CONFIG_USB_HCI
+	PURB	piorw_urb;
+	PIRP		piorw_irp;
+	u8 io_irp_cnt;
+	u8 bio_irp_pending;
+	_sema io_retevt;
+#endif
 #endif
 
 };
 
 
 #ifdef CONFIG_R871X_TEST
-int rtw_start_pseudo_adhoc(_adapter *padapter);
-int rtw_stop_pseudo_adhoc(_adapter *padapter);
+	int rtw_start_pseudo_adhoc(_adapter *padapter);
+	int rtw_stop_pseudo_adhoc(_adapter *padapter);
 #endif
 
 struct dvobj_priv *devobj_init(void);
@@ -99,7 +95,7 @@ u8 rtw_reset_drv_sw(_adapter *padapter);
 void rtw_dev_unload(PADAPTER padapter);
 
 u32 rtw_start_drv_threads(_adapter *padapter);
-void rtw_stop_drv_threads (_adapter *padapter);
+void rtw_stop_drv_threads(_adapter *padapter);
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 void rtw_cancel_dynamic_chk_timer(_adapter *padapter);
 #endif
@@ -114,30 +110,36 @@ int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname);
 struct net_device *rtw_init_netdev(_adapter *padapter);
 
 void rtw_os_ndev_free(_adapter *adapter);
-int rtw_os_ndev_init(_adapter *adapter, char *name);
+int rtw_os_ndev_init(_adapter *adapter, const char *name);
 void rtw_os_ndev_deinit(_adapter *adapter);
+void rtw_os_ndev_unregister(_adapter *adapter);
 void rtw_os_ndevs_unregister(struct dvobj_priv *dvobj);
 int rtw_os_ndevs_init(struct dvobj_priv *dvobj);
 void rtw_os_ndevs_deinit(struct dvobj_priv *dvobj);
 
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 u16 rtw_recv_select_queue(struct sk_buff *skb);
-#endif //LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35)
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35) */
 
 int rtw_ndev_notifier_register(void);
 void rtw_ndev_notifier_unregister(void);
+void rtw_inetaddr_notifier_register(void);
+void rtw_inetaddr_notifier_unregister(void);
 
 #include "../os_dep/linux/rtw_proc.h"
 
 #ifdef CONFIG_IOCTL_CFG80211
-#include "../os_dep/linux/ioctl_cfg80211.h"
-#endif //CONFIG_IOCTL_CFG80211
+	#include "../os_dep/linux/ioctl_cfg80211.h"
+#endif /* CONFIG_IOCTL_CFG80211 */
 
-#endif //PLATFORM_LINUX
+u8 rtw_rtnl_lock_needed(struct dvobj_priv *dvobj);
+void rtw_set_rtnl_lock_holder(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl);
+
+#endif /* PLATFORM_LINUX */
 
 
 #ifdef PLATFORM_FREEBSD
-extern int rtw_ioctl(struct ifnet * ifp, u_long cmd, caddr_t data);
+extern int rtw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data);
 #endif
 
 void rtw_ips_dev_unload(_adapter *padapter);
@@ -149,25 +151,18 @@ void rtw_ips_pwr_down(_adapter *padapter);
 
 #ifdef CONFIG_CONCURRENT_MODE
 struct _io_ops;
-_adapter *rtw_drv_if2_init(_adapter *primary_padapter, void (*set_intf_ops)(_adapter *primary_padapter,struct _io_ops *pops));
-void rtw_drv_if2_free(_adapter *if2);
-void rtw_drv_if2_stop(_adapter *if2);
-#ifdef CONFIG_MULTI_VIR_IFACES
 struct dvobj_priv;
-_adapter *rtw_drv_add_vir_if(_adapter *primary_padapter, void (*set_intf_ops)(_adapter *primary_padapter,struct _io_ops *pops));
+_adapter *rtw_drv_add_vir_if(_adapter *primary_padapter, void (*set_intf_ops)(_adapter *primary_padapter, struct _io_ops *pops));
 void rtw_drv_stop_vir_ifaces(struct dvobj_priv *dvobj);
 void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj);
-#endif //CONFIG_MULTI_VIR_IFACES
 #endif
 
 void rtw_ndev_destructor(_nic_hdl ndev);
-
 #ifdef CONFIG_ARP_KEEP_ALIVE
-int	rtw_gw_addr_query(_adapter *padapter);
+int rtw_gw_addr_query(_adapter *padapter);
 #endif
 
 int rtw_suspend_common(_adapter *padapter);
 int rtw_resume_common(_adapter *padapter);
 
-#endif	//_OSDEP_INTF_H_
-
+#endif /* _OSDEP_INTF_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service.h
index d731b43c514a..ca862cfcf374 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2013 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __OSDEP_SERVICE_H_
 #define __OSDEP_SERVICE_H_
 
@@ -28,8 +24,12 @@
 #define RTW_RFRAME_PKT_UNAVAIL	4
 #define RTW_RBUF_UNAVAIL		5
 #define RTW_RBUF_PKT_UNAVAIL	6
+#define RTW_SDIO_READ_PORT_FAIL	7
+#define RTW_ALREADY				8
+#define RTW_RA_RESOLVING		9
+#define RTW_BMC_NO_NEED			10
 
-//#define RTW_STATUS_TIMEDOUT -110
+/* #define RTW_STATUS_TIMEDOUT -110 */
 
 #undef _TRUE
 #define _TRUE		1
@@ -39,28 +39,30 @@
 
 
 #ifdef PLATFORM_FREEBSD
-#include <osdep_service_bsd.h>
+	#include <osdep_service_bsd.h>
 #endif
 
 #ifdef PLATFORM_LINUX
-#include <osdep_service_linux.h>
+	#include <linux/version.h>
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0))
+	#include <linux/sched/signal.h>
+	#include <linux/sched/types.h>
+#endif
+	#include <osdep_service_linux.h>
 #endif
 
 #ifdef PLATFORM_OS_XP
-#include <osdep_service_xp.h>
+	#include <osdep_service_xp.h>
 #endif
 
 #ifdef PLATFORM_OS_CE
-#include <osdep_service_ce.h>
+	#include <osdep_service_ce.h>
 #endif
 
-#define RTW_TIMER_HDL_NAME(name) rtw_##name##_timer_hdl
-#define RTW_DECLARE_TIMER_HDL(name) void RTW_TIMER_HDL_NAME(name)(RTW_TIMER_HDL_ARGS)
-
-//#include <rtw_byteorder.h>
+/* #include <rtw_byteorder.h> */
 
 #ifndef BIT
-	#define BIT(x)	( 1 << (x))
+	#define BIT(x)	(1 << (x))
 #endif
 
 #define BIT0	0x00000001
@@ -104,33 +106,33 @@
 extern int RTW_STATUS_CODE(int error_code);
 
 #ifndef RTK_DMP_PLATFORM
-#define CONFIG_USE_VMALLOC
+	#define CONFIG_USE_VMALLOC
 #endif
 
 /* flags used for rtw_mstat_update() */
 enum mstat_f {
 	/* type: 0x00ff */
 	MSTAT_TYPE_VIR = 0x00,
-	MSTAT_TYPE_PHY= 0x01,
+	MSTAT_TYPE_PHY = 0x01,
 	MSTAT_TYPE_SKB = 0x02,
 	MSTAT_TYPE_USB = 0x03,
 	MSTAT_TYPE_MAX = 0x04,
 
 	/* func: 0xff00 */
-	MSTAT_FUNC_UNSPECIFIED = 0x00<<8,
-	MSTAT_FUNC_IO = 0x01<<8,
-	MSTAT_FUNC_TX_IO = 0x02<<8,
-	MSTAT_FUNC_RX_IO = 0x03<<8,
-	MSTAT_FUNC_TX = 0x04<<8,
-	MSTAT_FUNC_RX = 0x05<<8,
-	MSTAT_FUNC_CFG_VENDOR = 0x06<<8,
-	MSTAT_FUNC_MAX = 0x07<<8,
+	MSTAT_FUNC_UNSPECIFIED = 0x00 << 8,
+	MSTAT_FUNC_IO = 0x01 << 8,
+	MSTAT_FUNC_TX_IO = 0x02 << 8,
+	MSTAT_FUNC_RX_IO = 0x03 << 8,
+	MSTAT_FUNC_TX = 0x04 << 8,
+	MSTAT_FUNC_RX = 0x05 << 8,
+	MSTAT_FUNC_CFG_VENDOR = 0x06 << 8,
+	MSTAT_FUNC_MAX = 0x07 << 8,
 };
 
-#define mstat_tf_idx(flags) ((flags)&0xff)
-#define mstat_ff_idx(flags) (((flags)&0xff00) >> 8)
+#define mstat_tf_idx(flags) ((flags) & 0xff)
+#define mstat_ff_idx(flags) (((flags) & 0xff00) >> 8)
 
-typedef enum mstat_status{
+typedef enum mstat_status {
 	MSTAT_ALLOC_SUCCESS = 0,
 	MSTAT_ALLOC_FAIL,
 	MSTAT_FREE
@@ -138,19 +140,26 @@ typedef enum mstat_status{
 
 #ifdef DBG_MEM_ALLOC
 void rtw_mstat_update(const enum mstat_f flags, const MSTAT_STATUS status, u32 sz);
-void rtw_mstat_dump (void *sel);
-u8* dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-u8* dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-void dbg_rtw_vmfree(u8 *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
-u8* dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-u8* dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-void dbg_rtw_mfree(u8 *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
-
-struct sk_buff * dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, const int line);
+void rtw_mstat_dump(void *sel);
+bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size);
+void *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_vmfree(void *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
+void *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_mfree(void *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
+
+struct sk_buff *dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, const int line);
 void dbg_rtw_skb_free(struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line);
 struct sk_buff *dbg_rtw_skb_copy(const struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line);
 struct sk_buff *dbg_rtw_skb_clone(struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line);
 int dbg_rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line);
+#ifdef CONFIG_RTW_NAPI
+int dbg_rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line);
+#ifdef CONFIG_RTW_GRO
+gro_result_t dbg_rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line);
+#endif
+#endif /* CONFIG_RTW_NAPI */
 void dbg_rtw_skb_queue_purge(struct sk_buff_head *list, enum mstat_f flags, const char *func, int line);
 #ifdef CONFIG_USB_HCI
 void *dbg_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma, const enum mstat_f flags, const char *func, const int line);
@@ -161,56 +170,69 @@ void dbg_rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dm
 #define rtw_vmalloc(sz)			dbg_rtw_vmalloc((sz), MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
 #define rtw_zvmalloc(sz)			dbg_rtw_zvmalloc((sz), MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
 #define rtw_vmfree(pbuf, sz)		dbg_rtw_vmfree((pbuf), (sz), MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
-#define rtw_vmalloc_f(sz, mstat_f)			dbg_rtw_vmalloc((sz), ((mstat_f)&0xff00)|MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
-#define rtw_zvmalloc_f(sz, mstat_f)		dbg_rtw_zvmalloc((sz), ((mstat_f)&0xff00)|MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
-#define rtw_vmfree_f(pbuf, sz, mstat_f)	dbg_rtw_vmfree((pbuf), (sz), ((mstat_f)&0xff00)|MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_vmalloc_f(sz, mstat_f)			dbg_rtw_vmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_zvmalloc_f(sz, mstat_f)		dbg_rtw_zvmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
+#define rtw_vmfree_f(pbuf, sz, mstat_f)	dbg_rtw_vmfree((pbuf), (sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_VIR, __FUNCTION__, __LINE__)
 #else /* CONFIG_USE_VMALLOC */
 #define rtw_vmalloc(sz)			dbg_rtw_malloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
 #define rtw_zvmalloc(sz)			dbg_rtw_zmalloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
 #define rtw_vmfree(pbuf, sz)		dbg_rtw_mfree((pbuf), (sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
-#define rtw_vmalloc_f(sz, mstat_f)			dbg_rtw_malloc((sz), ((mstat_f)&0xff00)|MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
-#define rtw_zvmalloc_f(sz, mstat_f)		dbg_rtw_zmalloc((sz), ((mstat_f)&0xff00)|MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
-#define rtw_vmfree_f(pbuf, sz, mstat_f)	dbg_rtw_mfree((pbuf), (sz), ((mstat_f)&0xff00)|MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_vmalloc_f(sz, mstat_f)			dbg_rtw_malloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_zvmalloc_f(sz, mstat_f)		dbg_rtw_zmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_vmfree_f(pbuf, sz, mstat_f)	dbg_rtw_mfree((pbuf), (sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
 #endif /* CONFIG_USE_VMALLOC */
 #define rtw_malloc(sz)			dbg_rtw_malloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
 #define rtw_zmalloc(sz)			dbg_rtw_zmalloc((sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
 #define rtw_mfree(pbuf, sz)		dbg_rtw_mfree((pbuf), (sz), MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
-#define rtw_malloc_f(sz, mstat_f)			dbg_rtw_malloc((sz), ((mstat_f)&0xff00)|MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
-#define rtw_zmalloc_f(sz, mstat_f)			dbg_rtw_zmalloc((sz), ((mstat_f)&0xff00)|MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
-#define rtw_mfree_f(pbuf, sz, mstat_f)		dbg_rtw_mfree((pbuf), (sz), ((mstat_f)&0xff00)|MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_malloc_f(sz, mstat_f)			dbg_rtw_malloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_zmalloc_f(sz, mstat_f)			dbg_rtw_zmalloc((sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_mfree_f(pbuf, sz, mstat_f)		dbg_rtw_mfree((pbuf), (sz), ((mstat_f) & 0xff00) | MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
 
 #define rtw_skb_alloc(size)	dbg_rtw_skb_alloc((size), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
 #define rtw_skb_free(skb)	dbg_rtw_skb_free((skb), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
-#define rtw_skb_alloc_f(size, mstat_f)	dbg_rtw_skb_alloc((size), ((mstat_f)&0xff00)|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
-#define rtw_skb_free_f(skb, mstat_f)	dbg_rtw_skb_free((skb), ((mstat_f)&0xff00)|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_alloc_f(size, mstat_f)	dbg_rtw_skb_alloc((size), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_free_f(skb, mstat_f)	dbg_rtw_skb_free((skb), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
 #define rtw_skb_copy(skb)	dbg_rtw_skb_copy((skb), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
 #define rtw_skb_clone(skb)	dbg_rtw_skb_clone((skb), MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
-#define rtw_skb_copy_f(skb, mstat_f)	dbg_rtw_skb_copy((skb), ((mstat_f)&0xff00)|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
-#define rtw_skb_clone_f(skb, mstat_f)	dbg_rtw_skb_clone((skb), ((mstat_f)&0xff00)|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_copy_f(skb, mstat_f)	dbg_rtw_skb_copy((skb), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#define rtw_skb_clone_f(skb, mstat_f)	dbg_rtw_skb_clone((skb), ((mstat_f) & 0xff00) | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
 #define rtw_netif_rx(ndev, skb)	dbg_rtw_netif_rx(ndev, skb, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#ifdef CONFIG_RTW_NAPI
+#define rtw_netif_receive_skb(ndev, skb) dbg_rtw_netif_receive_skb(ndev, skb, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#ifdef CONFIG_RTW_GRO
+#define rtw_napi_gro_receive(napi, skb) dbg_rtw_napi_gro_receive(napi, skb, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+#endif
+#endif /* CONFIG_RTW_NAPI */
 #define rtw_skb_queue_purge(sk_buff_head) dbg_rtw_skb_queue_purge(sk_buff_head, MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
 #ifdef CONFIG_USB_HCI
 #define rtw_usb_buffer_alloc(dev, size, dma)		dbg_rtw_usb_buffer_alloc((dev), (size), (dma), MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
 #define rtw_usb_buffer_free(dev, size, addr, dma)	dbg_rtw_usb_buffer_free((dev), (size), (addr), (dma), MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
-#define rtw_usb_buffer_alloc_f(dev, size, dma, mstat_f)			dbg_rtw_usb_buffer_alloc((dev), (size), (dma), ((mstat_f)&0xff00)|MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
-#define rtw_usb_buffer_free_f(dev, size, addr, dma, mstat_f)	dbg_rtw_usb_buffer_free((dev), (size), (addr), (dma), ((mstat_f)&0xff00)|MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
+#define rtw_usb_buffer_alloc_f(dev, size, dma, mstat_f)			dbg_rtw_usb_buffer_alloc((dev), (size), (dma), ((mstat_f) & 0xff00) | MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
+#define rtw_usb_buffer_free_f(dev, size, addr, dma, mstat_f)	dbg_rtw_usb_buffer_free((dev), (size), (addr), (dma), ((mstat_f) & 0xff00) | MSTAT_TYPE_USB, __FUNCTION__, __LINE__)
 #endif /* CONFIG_USB_HCI */
 
 #else /* DBG_MEM_ALLOC */
-#define rtw_mstat_update(flag, status, sz) do {} while(0)
-#define rtw_mstat_dump(sel) do {} while(0)
-u8*	_rtw_vmalloc(u32 sz);
-u8*	_rtw_zvmalloc(u32 sz);
-void	_rtw_vmfree(u8 *pbuf, u32 sz);
-u8*	_rtw_zmalloc(u32 sz);
-u8*	_rtw_malloc(u32 sz);
-void	_rtw_mfree(u8 *pbuf, u32 sz);
+#define rtw_mstat_update(flag, status, sz) do {} while (0)
+#define rtw_mstat_dump(sel) do {} while (0)
+#define match_mstat_sniff_rules(flags, size) _FALSE
+void *_rtw_vmalloc(u32 sz);
+void *_rtw_zvmalloc(u32 sz);
+void _rtw_vmfree(void *pbuf, u32 sz);
+void *_rtw_zmalloc(u32 sz);
+void *_rtw_malloc(u32 sz);
+void _rtw_mfree(void *pbuf, u32 sz);
 
 struct sk_buff *_rtw_skb_alloc(u32 sz);
 void _rtw_skb_free(struct sk_buff *skb);
 struct sk_buff *_rtw_skb_copy(const struct sk_buff *skb);
 struct sk_buff *_rtw_skb_clone(struct sk_buff *skb);
 int _rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb);
+#ifdef CONFIG_RTW_NAPI
+int _rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb);
+#ifdef CONFIG_RTW_GRO
+gro_result_t _rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb);
+#endif
+#endif /* CONFIG_RTW_NAPI */
 void _rtw_skb_queue_purge(struct sk_buff_head *list);
 
 #ifdef CONFIG_USB_HCI
@@ -249,6 +271,12 @@ void _rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_a
 #define rtw_skb_copy_f(skb, mstat_f)	_rtw_skb_copy((skb))
 #define rtw_skb_clone_f(skb, mstat_f)	_rtw_skb_clone((skb))
 #define rtw_netif_rx(ndev, skb) _rtw_netif_rx(ndev, skb)
+#ifdef CONFIG_RTW_NAPI
+#define rtw_netif_receive_skb(ndev, skb) _rtw_netif_receive_skb(ndev, skb)
+#ifdef CONFIG_RTW_GRO
+#define rtw_napi_gro_receive(napi, skb) _rtw_napi_gro_receive(napi, skb)
+#endif
+#endif /* CONFIG_RTW_NAPI */
 #define rtw_skb_queue_purge(sk_buff_head) _rtw_skb_queue_purge(sk_buff_head)
 #ifdef CONFIG_USB_HCI
 #define rtw_usb_buffer_alloc(dev, size, dma) _rtw_usb_buffer_alloc((dev), (size), (dma))
@@ -258,9 +286,14 @@ void _rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_a
 #endif /* CONFIG_USB_HCI */
 #endif /* DBG_MEM_ALLOC */
 
-extern void*	rtw_malloc2d(int h, int w, size_t size);
+extern void	*rtw_malloc2d(int h, int w, size_t size);
 extern void	rtw_mfree2d(void *pbuf, int h, int w, int size);
 
+void rtw_os_pkt_free(_pkt *pkt);
+_pkt *rtw_os_pkt_copy(_pkt *pkt);
+void *rtw_os_pkt_data(_pkt *pkt);
+u32 rtw_os_pkt_len(_pkt *pkt);
+
 extern void	_rtw_memcpy(void *dec, const void *sour, u32 sz);
 extern void _rtw_memmove(void *dst, const void *src, u32 sz);
 extern int	_rtw_memcmp(const void *dst, const void *src, u32 sz);
@@ -270,9 +303,19 @@ extern void	_rtw_init_listhead(_list *list);
 extern u32	rtw_is_list_empty(_list *phead);
 extern void	rtw_list_insert_head(_list *plist, _list *phead);
 extern void	rtw_list_insert_tail(_list *plist, _list *phead);
+void rtw_list_splice(_list *list, _list *head);
+void rtw_list_splice_init(_list *list, _list *head);
+void rtw_list_splice_tail(_list *list, _list *head);
+
 #ifndef PLATFORM_FREEBSD
 extern void	rtw_list_delete(_list *plist);
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
+
+void rtw_hlist_head_init(rtw_hlist_head *h);
+void rtw_hlist_add_head(rtw_hlist_node *n, rtw_hlist_head *h);
+void rtw_hlist_del(rtw_hlist_node *n);
+void rtw_hlist_add_head_rcu(rtw_hlist_node *n, rtw_hlist_head *h);
+void rtw_hlist_del_rcu(rtw_hlist_node *n);
 
 extern void	_rtw_init_sema(_sema *sema, int init_val);
 extern void	_rtw_free_sema(_sema	*sema);
@@ -282,7 +325,7 @@ extern void	_rtw_mutex_init(_mutex *pmutex);
 extern void	_rtw_mutex_free(_mutex *pmutex);
 #ifndef PLATFORM_FREEBSD
 extern void	_rtw_spinlock_init(_lock *plock);
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 extern void	_rtw_spinlock_free(_lock *plock);
 extern void	_rtw_spinlock(_lock	*plock);
 extern void	_rtw_spinunlock(_lock	*plock);
@@ -294,18 +337,43 @@ extern void _rtw_deinit_queue(_queue *pqueue);
 extern u32	_rtw_queue_empty(_queue	*pqueue);
 extern u32	rtw_end_of_queue_search(_list *queue, _list *pelement);
 
-extern u32	rtw_get_current_time(void);
-extern u32	rtw_systime_to_ms(u32 systime);
-extern u32	rtw_ms_to_systime(u32 ms);
-extern s32	rtw_get_passing_time_ms(u32 start);
-extern s32	rtw_get_time_interval_ms(u32 start, u32 end);
+extern systime _rtw_get_current_time(void);
+extern u32	_rtw_systime_to_ms(systime stime);
+extern systime _rtw_ms_to_systime(u32 ms);
+extern systime _rtw_us_to_systime(u32 us);
+extern s32	_rtw_get_passing_time_ms(systime start);
+extern s32 _rtw_get_remaining_time_ms(systime end);
+extern s32	_rtw_get_time_interval_ms(systime start, systime end);
+extern bool _rtw_time_after(systime a, systime b);
+
+#ifdef DBG_SYSTIME
+#define rtw_get_current_time() ({systime __stime = _rtw_get_current_time(); __stime;})
+#define rtw_systime_to_ms(stime) ({u32 __ms = _rtw_systime_to_ms(stime); typecheck(systime, stime); __ms;})
+#define rtw_ms_to_systime(ms) ({systime __stime = _rtw_ms_to_systime(ms); __stime;})
+#define rtw_us_to_systime(us) ({systime __stime = _rtw_us_to_systime(us); __stime;})
+#define rtw_get_passing_time_ms(start) ({u32 __ms = _rtw_get_passing_time_ms(start); typecheck(systime, start); __ms;})
+#define rtw_get_remaining_time_ms(end) ({u32 __ms = _rtw_get_remaining_time_ms(end); typecheck(systime, end); __ms;})
+#define rtw_get_time_interval_ms(start, end) ({u32 __ms = _rtw_get_time_interval_ms(start, end); typecheck(systime, start); typecheck(systime, end); __ms;})
+#define rtw_time_after(a,b) ({bool __r = _rtw_time_after(a,b); typecheck(systime, a); typecheck(systime, b); __r;})
+#define rtw_time_before(a,b) ({bool __r = _rtw_time_after(b, a); typecheck(systime, a); typecheck(systime, b); __r;})
+#else
+#define rtw_get_current_time() _rtw_get_current_time()
+#define rtw_systime_to_ms(stime) _rtw_systime_to_ms(stime)
+#define rtw_ms_to_systime(ms) _rtw_ms_to_systime(ms)
+#define rtw_us_to_systime(us) _rtw_us_to_systime(us)
+#define rtw_get_passing_time_ms(start) _rtw_get_passing_time_ms(start)
+#define rtw_get_remaining_time_ms(end) _rtw_get_remaining_time_ms(end)
+#define rtw_get_time_interval_ms(start, end) _rtw_get_time_interval_ms(start, end)
+#define rtw_time_after(a,b) _rtw_time_after(a,b)
+#define rtw_time_before(a,b) _rtw_time_after(b,a)
+#endif
 
 extern void	rtw_sleep_schedulable(int ms);
 
 extern void	rtw_msleep_os(int ms);
 extern void	rtw_usleep_os(int us);
 
-extern u32 	rtw_atoi(u8* s);
+extern u32	rtw_atoi(u8 *s);
 
 #ifdef DBG_DELAY_OS
 #define rtw_mdelay_os(ms) _rtw_mdelay_os((ms), __FUNCTION__, __LINE__)
@@ -320,54 +388,67 @@ extern void	rtw_udelay_os(int us);
 extern void rtw_yield_os(void);
 
 
-extern void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc);
+extern void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc, void *ctx);
 
 
 __inline static unsigned char _cancel_timer_ex(_timer *ptimer)
 {
-#ifdef PLATFORM_LINUX
-	return del_timer_sync(ptimer);
-#endif
-#ifdef PLATFORM_FREEBSD
-	_cancel_timer(ptimer,0);
-	return 0;
-#endif
-#ifdef PLATFORM_WINDOWS
 	u8 bcancelled;
-	
+
 	_cancel_timer(ptimer, &bcancelled);
-	
+
 	return bcancelled;
-#endif
 }
 
 static __inline void thread_enter(char *name)
 {
 #ifdef PLATFORM_LINUX
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
-	daemonize("%s", name);
-	#endif
 	allow_signal(SIGTERM);
 #endif
 #ifdef PLATFORM_FREEBSD
 	printf("%s", "RTKTHREAD_enter");
 #endif
 }
+void thread_exit(_completion *comp);
+void _rtw_init_completion(_completion *comp);
+void _rtw_wait_for_comp_timeout(_completion *comp);
+void _rtw_wait_for_comp(_completion *comp);
 
-__inline static void flush_signals_thread(void) 
+static inline bool rtw_thread_stop(_thread_hdl_ th)
 {
 #ifdef PLATFORM_LINUX
-	if (signal_pending (current)) 
-	{
-		flush_signals(current);
+	return kthread_stop(th);
+#endif
+}
+static inline void rtw_thread_wait_stop(void)
+{
+#ifdef PLATFORM_LINUX
+	#if 0
+	while (!kthread_should_stop())
+		rtw_msleep_os(10);
+	#else
+	set_current_state(TASK_INTERRUPTIBLE);
+	while (!kthread_should_stop()) {
+		schedule();
+		set_current_state(TASK_INTERRUPTIBLE);
 	}
+	__set_current_state(TASK_RUNNING);
+	#endif
+#endif
+}
+
+__inline static void flush_signals_thread(void)
+{
+#ifdef PLATFORM_LINUX
+	if (signal_pending(current))
+		flush_signals(current);
 #endif
 }
 
 __inline static _OS_STATUS res_to_status(sint res)
 {
 
-#if defined (PLATFORM_LINUX) || defined (PLATFORM_MPIXEL) || defined (PLATFORM_FREEBSD)
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_MPIXEL) || defined (PLATFORM_FREEBSD)
 	return res;
 #endif
 
@@ -378,8 +459,8 @@ __inline static _OS_STATUS res_to_status(sint res)
 	else
 		return NDIS_STATUS_FAILURE;
 
-#endif	
-	
+#endif
+
 }
 
 __inline static void rtw_dump_stack(void)
@@ -400,30 +481,34 @@ __inline static int rtw_bug_check(void *parg1, void *parg2, void *parg3, void *p
 	int ret = _TRUE;
 
 #ifdef PLATFORM_WINDOWS
-	if ( ((uint)parg1) <= 0x7fffffff || 
-	 	((uint)parg2) <= 0x7fffffff ||
-	 	((uint)parg3) <= 0x7fffffff ||
-	 	((uint)parg4) <= 0x7fffffff)
-	{
+	if (((uint)parg1) <= 0x7fffffff ||
+	    ((uint)parg2) <= 0x7fffffff ||
+	    ((uint)parg3) <= 0x7fffffff ||
+	    ((uint)parg4) <= 0x7fffffff) {
 		ret = _FALSE;
-		KeBugCheckEx(0x87110000, (ULONG_PTR)parg1, (ULONG_PTR)parg2, (ULONG_PTR)parg3, (ULONG_PTR)parg4);		
+		KeBugCheckEx(0x87110000, (ULONG_PTR)parg1, (ULONG_PTR)parg2, (ULONG_PTR)parg3, (ULONG_PTR)parg4);
 	}
 #endif
 
 	return ret;
 
 }
+#ifdef PLATFORM_LINUX
+#define RTW_DIV_ROUND_UP(n, d)	DIV_ROUND_UP(n, d)
+#else /* !PLATFORM_LINUX */
+#define RTW_DIV_ROUND_UP(n, d)	(((n) + (d - 1)) / d)
+#endif /* !PLATFORM_LINUX */
 
 #define _RND(sz, r) ((((sz)+((r)-1))/(r))*(r))
-#define RND4(x)	(((x >> 2) + (((x & 3) == 0) ?  0: 1)) << 2)
+#define RND4(x)	(((x >> 2) + (((x & 3) == 0) ? 0 : 1)) << 2)
 
 __inline static u32 _RND4(u32 sz)
 {
 
 	u32	val;
 
-	val = ((sz >> 2) + ((sz & 3) ? 1: 0)) << 2;
-	
+	val = ((sz >> 2) + ((sz & 3) ? 1 : 0)) << 2;
+
 	return val;
 
 }
@@ -433,8 +518,8 @@ __inline static u32 _RND8(u32 sz)
 
 	u32	val;
 
-	val = ((sz >> 3) + ((sz & 7) ? 1: 0)) << 3;
-	
+	val = ((sz >> 3) + ((sz & 7) ? 1 : 0)) << 3;
+
 	return val;
 
 }
@@ -444,8 +529,8 @@ __inline static u32 _RND128(u32 sz)
 
 	u32	val;
 
-	val = ((sz >> 7) + ((sz & 127) ? 1: 0)) << 7;
-	
+	val = ((sz >> 7) + ((sz & 127) ? 1 : 0)) << 7;
+
 	return val;
 
 }
@@ -455,8 +540,8 @@ __inline static u32 _RND256(u32 sz)
 
 	u32	val;
 
-	val = ((sz >> 8) + ((sz & 255) ? 1: 0)) << 8;
-	
+	val = ((sz >> 8) + ((sz & 255) ? 1 : 0)) << 8;
+
 	return val;
 
 }
@@ -466,8 +551,8 @@ __inline static u32 _RND512(u32 sz)
 
 	u32	val;
 
-	val = ((sz >> 9) + ((sz & 511) ? 1: 0)) << 9;
-	
+	val = ((sz >> 9) + ((sz & 511) ? 1 : 0)) << 9;
+
 	return val;
 
 }
@@ -477,7 +562,8 @@ __inline static u32 bitshift(u32 bitmask)
 	u32 i;
 
 	for (i = 0; i <= 31; i++)
-		if (((bitmask>>i) &  0x1) == 1) break;
+		if (((bitmask >> i) &  0x1) == 1)
+			break;
 
 	return i;
 }
@@ -493,7 +579,7 @@ static inline int largest_bit(u32 bitmask)
 	return i;
 }
 
-#define rtw_min(a, b) ((a>b)?b:a)
+#define rtw_min(a, b) ((a > b) ? b : a)
 #define rtw_is_range_a_in_b(hi_a, lo_a, hi_b, lo_b) (((hi_a) <= (hi_b)) && ((lo_a) >= (lo_b)))
 #define rtw_is_range_overlap(hi_a, lo_a, hi_b, lo_b) (((hi_a) > (lo_b)) && ((lo_a) < (hi_b)))
 
@@ -501,19 +587,17 @@ static inline int largest_bit(u32 bitmask)
 #define MAC_FMT "%02x:%02x:%02x:%02x:%02x:%02x"
 #endif
 #ifndef MAC_ARG
-#define MAC_ARG(x) ((u8*)(x))[0],((u8*)(x))[1],((u8*)(x))[2],((u8*)(x))[3],((u8*)(x))[4],((u8*)(x))[5]
+#define MAC_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5]
 #endif
 
+bool rtw_macaddr_is_larger(const u8 *a, const u8 *b);
 
 extern void rtw_suspend_lock_init(void);
 extern void rtw_suspend_lock_uninit(void);
 extern void rtw_lock_suspend(void);
 extern void rtw_unlock_suspend(void);
 extern void rtw_lock_suspend_timeout(u32 timeout_ms);
-extern void rtw_lock_ext_suspend_timeout(u32 timeout_ms);
-extern void rtw_lock_rx_suspend_timeout(u32 timeout_ms);
 extern void rtw_lock_traffic_suspend_timeout(u32 timeout_ms);
-extern void rtw_lock_resume_scan_timeout(u32 timeout_ms);
 extern void rtw_resume_lock_suspend(void);
 extern void rtw_resume_unlock_suspend(void);
 #ifdef CONFIG_AP_WOWLAN
@@ -521,6 +605,10 @@ extern void rtw_softap_lock_suspend(void);
 extern void rtw_softap_unlock_suspend(void);
 #endif
 
+extern void rtw_set_bit(int nr, unsigned long *addr);
+extern void rtw_clear_bit(int nr, unsigned long *addr);
+extern int rtw_test_and_clear_bit(int nr, unsigned long *addr);
+
 extern void ATOMIC_SET(ATOMIC_T *v, int i);
 extern int ATOMIC_READ(ATOMIC_T *v);
 extern void ATOMIC_ADD(ATOMIC_T *v, int i);
@@ -531,8 +619,9 @@ extern int ATOMIC_ADD_RETURN(ATOMIC_T *v, int i);
 extern int ATOMIC_SUB_RETURN(ATOMIC_T *v, int i);
 extern int ATOMIC_INC_RETURN(ATOMIC_T *v);
 extern int ATOMIC_DEC_RETURN(ATOMIC_T *v);
+extern bool ATOMIC_INC_UNLESS(ATOMIC_T *v, int u);
 
-//File operation APIs, just for linux now
+/* File operation APIs, just for linux now */
 extern int rtw_is_file_readable(const char *path);
 extern int rtw_is_file_readable_with_size(const char *path, u32 *sz);
 extern int rtw_retrieve_from_file(const char *path, u8 *buf, u32 sz);
@@ -540,8 +629,8 @@ extern int rtw_store_to_file(const char *path, u8 *buf, u32 sz);
 
 
 #ifndef PLATFORM_FREEBSD
-extern void rtw_free_netdev(struct net_device * netdev);
-#endif //PLATFORM_FREEBSD
+extern void rtw_free_netdev(struct net_device *netdev);
+#endif /* PLATFORM_FREEBSD */
 
 
 extern u64 rtw_modular64(u64 x, u64 y);
@@ -565,7 +654,7 @@ extern u32 rtw_random32(void);
 	} while (0)
 
 #define RTW_GET_BE24(a) ((((u32) (a)[0]) << 16) | (((u32) (a)[1]) << 8) | \
-			 ((u32) (a)[2]))			 
+			 ((u32) (a)[2]))
 #define RTW_PUT_BE24(a, val)					\
 	do {							\
 		(a)[0] = (u8) ((((u32) (val)) >> 16) & 0xff);	\
@@ -574,7 +663,7 @@ extern u32 rtw_random32(void);
 	} while (0)
 
 #define RTW_GET_BE32(a) ((((u32) (a)[0]) << 24) | (((u32) (a)[1]) << 16) | \
-			 (((u32) (a)[2]) << 8) | ((u32) (a)[3]))			 
+			 (((u32) (a)[2]) << 8) | ((u32) (a)[3]))
 #define RTW_PUT_BE32(a, val)					\
 	do {							\
 		(a)[0] = (u8) ((((u32) (val)) >> 24) & 0xff);	\
@@ -584,7 +673,7 @@ extern u32 rtw_random32(void);
 	} while (0)
 
 #define RTW_GET_LE32(a) ((((u32) (a)[3]) << 24) | (((u32) (a)[2]) << 16) | \
-			 (((u32) (a)[1]) << 8) | ((u32) (a)[0]))			 
+			 (((u32) (a)[1]) << 8) | ((u32) (a)[0]))
 #define RTW_PUT_LE32(a, val)					\
 	do {							\
 		(a)[3] = (u8) ((((u32) (val)) >> 24) & 0xff);	\
@@ -596,7 +685,7 @@ extern u32 rtw_random32(void);
 #define RTW_GET_BE64(a) ((((u64) (a)[0]) << 56) | (((u64) (a)[1]) << 48) | \
 			 (((u64) (a)[2]) << 40) | (((u64) (a)[3]) << 32) | \
 			 (((u64) (a)[4]) << 24) | (((u64) (a)[5]) << 16) | \
-			 (((u64) (a)[6]) << 8) | ((u64) (a)[7]))			 
+			 (((u64) (a)[6]) << 8) | ((u64) (a)[7]))
 #define RTW_PUT_BE64(a, val)				\
 	do {						\
 		(a)[0] = (u8) (((u64) (val)) >> 56);	\
@@ -613,6 +702,17 @@ extern u32 rtw_random32(void);
 			 (((u64) (a)[5]) << 40) | (((u64) (a)[4]) << 32) | \
 			 (((u64) (a)[3]) << 24) | (((u64) (a)[2]) << 16) | \
 			 (((u64) (a)[1]) << 8) | ((u64) (a)[0]))
+#define RTW_PUT_LE64(a, val)					\
+	do {							\
+		(a)[7] = (u8) ((((u64) (val)) >> 56) & 0xff);	\
+		(a)[6] = (u8) ((((u64) (val)) >> 48) & 0xff);	\
+		(a)[5] = (u8) ((((u64) (val)) >> 40) & 0xff);	\
+		(a)[4] = (u8) ((((u64) (val)) >> 32) & 0xff);	\
+		(a)[3] = (u8) ((((u64) (val)) >> 24) & 0xff);	\
+		(a)[2] = (u8) ((((u64) (val)) >> 16) & 0xff);	\
+		(a)[1] = (u8) ((((u64) (val)) >> 8) & 0xff);	\
+		(a)[0] = (u8) (((u64) (val)) & 0xff);		\
+	} while (0)
 
 void rtw_buf_free(u8 **buf, u32 *buf_len);
 void rtw_buf_update(u8 **buf, u32 *buf_len, u8 *src, u32 src_len);
@@ -656,24 +756,39 @@ struct map_t {
 int map_readN(const struct map_t *map, u16 offset, u16 len, u8 *buf);
 u8 map_read8(const struct map_t *map, u16 offset);
 
+struct blacklist_ent {
+	_list list;
+	u8 addr[ETH_ALEN];
+	systime exp_time;
+};
+
+int rtw_blacklist_add(_queue *blist, const u8 *addr, u32 timeout_ms);
+int rtw_blacklist_del(_queue *blist, const u8 *addr);
+int rtw_blacklist_search(_queue *blist, const u8 *addr);
+void rtw_blacklist_flush(_queue *blist);
+void dump_blacklist(void *sel, _queue *blist, const char *title);
+
 /* String handler */
 
 BOOLEAN is_null(char c);
+BOOLEAN is_all_null(char *c, int len);
 BOOLEAN is_eol(char c);
 BOOLEAN is_space(char c);
 BOOLEAN IsHexDigit(char chTmp);
 BOOLEAN is_alpha(char chTmp);
 char alpha_to_upper(char c);
 
+int hex2num_i(char c);
+int hex2byte_i(const char *hex);
+int hexstr2bin(const char *hex, u8 *buf, size_t len);
+
 /*
  * Write formatted output to sized buffer
  */
 #ifdef PLATFORM_LINUX
 #define rtw_sprintf(buf, size, format, arg...)	snprintf(buf, size, format, ##arg)
-#else // !PLATFORM_LINUX
+#else /* !PLATFORM_LINUX */
 #error "NOT DEFINE \"rtw_sprintf\"!!"
-#endif // !PLATFORM_LINUX
+#endif /* !PLATFORM_LINUX */
 
 #endif
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_bsd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_bsd.h
index b56ccbb2b0f1..81d645ae4d23 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_bsd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_bsd.h
@@ -1,749 +1,757 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __OSDEP_BSD_SERVICE_H_
-#define __OSDEP_BSD_SERVICE_H_
-
-
-#include <sys/cdefs.h>
-#include <sys/types.h>
-#include <sys/systm.h>
-#include <sys/param.h>
-#include <sys/sockio.h>
-#include <sys/sysctl.h>
-#include <sys/lock.h>
-#include <sys/mutex.h>
-#include <sys/mbuf.h>
-#include <sys/kernel.h>
-#include <sys/socket.h>
-#include <sys/systm.h>
-#include <sys/malloc.h>
-#include <sys/module.h>
-#include <sys/bus.h>
-#include <sys/endian.h>
-#include <sys/kdb.h>
-#include <sys/kthread.h>
-#include <sys/malloc.h>
-#include <sys/time.h>
-#include <machine/atomic.h>
-#include <machine/bus.h>
-#include <machine/resource.h>
-#include <sys/rman.h>
-
-#include <net/bpf.h>
-#include <net/if.h>
-#include <net/if_arp.h>
-#include <net/ethernet.h>
-#include <net/if_dl.h>
-#include <net/if_media.h>
-#include <net/if_types.h>
-#include <net/route.h>
-
-
-#include <netinet/in.h>
-#include <netinet/in_systm.h>
-#include <netinet/in_var.h>
-#include <netinet/if_ether.h>
-#include <if_ether.h>
-
-#include <net80211/ieee80211_var.h>
-#include <net80211/ieee80211_regdomain.h>
-#include <net80211/ieee80211_radiotap.h>
-#include <net80211/ieee80211_ratectl.h>
-
-#include <dev/usb/usb.h>
-#include <dev/usb/usbdi.h>
-#include "usbdevs.h"
-
-#define	USB_DEBUG_VAR rum_debug
-#include <dev/usb/usb_debug.h>
-
-#if 1 //Baron porting from linux, it's all temp solution, needs to check again
-#include <sys/sema.h>
-#include <sys/pcpu.h> /* XXX for PCPU_GET */
-//	typedef struct 	semaphore _sema;
-	typedef struct 	sema _sema;
-//	typedef	spinlock_t	_lock;
-	typedef	struct mtx	_lock;
-	typedef struct mtx 		_mutex;
-	typedef struct timer_list _timer;
-	struct list_head {
-	struct list_head *next, *prev;
-	};
-	struct	__queue	{
-		struct	list_head	queue;	
-		_lock	lock;
-	};
-
-	//typedef	struct sk_buff	_pkt;
-	typedef	struct mbuf	_pkt;
-	typedef struct mbuf	_buffer;
-	
-	typedef struct	__queue	_queue;
-	typedef struct	list_head	_list;
-	typedef	int	_OS_STATUS;
-	//typedef u32	_irqL;
-	typedef unsigned long _irqL;
-	typedef	struct	ifnet * _nic_hdl;
-	
-	typedef pid_t		_thread_hdl_;
-//	typedef struct thread		_thread_hdl_;
-	typedef void		thread_return;
-	typedef void*	thread_context;
-
-	//#define thread_exit() complete_and_exit(NULL, 0)
-
-	#define thread_exit() do{printf("%s", "RTKTHREAD_exit");}while(0)
-
-	typedef void timer_hdl_return;
-	typedef void* timer_hdl_context;
-	typedef struct work_struct _workitem;
-
-#define   KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))
-/* emulate a modern version */
-#define LINUX_VERSION_CODE KERNEL_VERSION(2, 6, 35)
-
-#define WIRELESS_EXT -1
-#define HZ hz
-#define spin_lock_irqsave mtx_lock_irqsave
-#define spin_lock_bh mtx_lock_irqsave
-#define mtx_lock_irqsave(lock, x) mtx_lock(lock)//{local_irq_save((x)); mtx_lock_spin((lock));}
-//#define IFT_RTW	0xf9 //ifnet allocate type for RTW
-#define free_netdev if_free
-#define LIST_CONTAINOR(ptr, type, member) \
-        ((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))
-#define container_of(p,t,n) (t*)((p)-&(((t*)0)->n))
-/* 
- * Linux timers are emulated using FreeBSD callout functions
- * (and taskqueue functionality).
- *
- * Currently no timer stats functionality.
- *
- * See (linux_compat) processes.c
- *
- */
-struct timer_list {
-
-        /* FreeBSD callout related fields */
-        struct callout callout;
-
- 	//timeout function
-        void (*function)(void*);
-	//argument
-	 void *arg;
-        
-};
-struct workqueue_struct;
-struct work_struct;
-typedef void (*work_func_t)(struct work_struct *work);
-/* Values for the state of an item of work (work_struct) */
-typedef enum work_state {
-        WORK_STATE_UNSET = 0,
-        WORK_STATE_CALLOUT_PENDING = 1,
-        WORK_STATE_TASK_PENDING = 2,
-        WORK_STATE_WORK_CANCELLED = 3        
-} work_state_t;
-
-struct work_struct {
-        struct task task; /* FreeBSD task */
-        work_state_t state; /* the pending or otherwise state of work. */
-        work_func_t func;       
-};
-#define spin_unlock_irqrestore mtx_unlock_irqrestore
-#define spin_unlock_bh mtx_unlock_irqrestore
-#define mtx_unlock_irqrestore(lock,x)    mtx_unlock(lock);
-extern void	_rtw_spinlock_init(_lock *plock);
-
-//modify private structure to match freebsd
-#define BITS_PER_LONG 32
-union ktime {
-	s64	tv64;
-#if BITS_PER_LONG != 64 && !defined(CONFIG_KTIME_SCALAR)
-	struct {
-#ifdef __BIG_ENDIAN
-	s32	sec, nsec;
-#else
-	s32	nsec, sec;
-#endif
-	} tv;
-#endif
-};
-#define kmemcheck_bitfield_begin(name)
-#define kmemcheck_bitfield_end(name)
-#define CHECKSUM_NONE 0
-typedef unsigned char *sk_buff_data_t;
-typedef union ktime ktime_t;		/* Kill this */
-
-void rtw_mtx_lock(_lock *plock);
-	
-void rtw_mtx_unlock(_lock *plock);
-
-/** 
- *	struct sk_buff - socket buffer
- *	@next: Next buffer in list
- *	@prev: Previous buffer in list
- *	@sk: Socket we are owned by
- *	@tstamp: Time we arrived
- *	@dev: Device we arrived on/are leaving by
- *	@transport_header: Transport layer header
- *	@network_header: Network layer header
- *	@mac_header: Link layer header
- *	@_skb_refdst: destination entry (with norefcount bit)
- *	@sp: the security path, used for xfrm
- *	@cb: Control buffer. Free for use by every layer. Put private vars here
- *	@len: Length of actual data
- *	@data_len: Data length
- *	@mac_len: Length of link layer header
- *	@hdr_len: writable header length of cloned skb
- *	@csum: Checksum (must include start/offset pair)
- *	@csum_start: Offset from skb->head where checksumming should start
- *	@csum_offset: Offset from csum_start where checksum should be stored
- *	@local_df: allow local fragmentation
- *	@cloned: Head may be cloned (check refcnt to be sure)
- *	@nohdr: Payload reference only, must not modify header
- *	@pkt_type: Packet class
- *	@fclone: skbuff clone status
- *	@ip_summed: Driver fed us an IP checksum
- *	@priority: Packet queueing priority
- *	@users: User count - see {datagram,tcp}.c
- *	@protocol: Packet protocol from driver
- *	@truesize: Buffer size 
- *	@head: Head of buffer
- *	@data: Data head pointer
- *	@tail: Tail pointer
- *	@end: End pointer
- *	@destructor: Destruct function
- *	@mark: Generic packet mark
- *	@nfct: Associated connection, if any
- *	@ipvs_property: skbuff is owned by ipvs
- *	@peeked: this packet has been seen already, so stats have been
- *		done for it, don't do them again
- *	@nf_trace: netfilter packet trace flag
- *	@nfctinfo: Relationship of this skb to the connection
- *	@nfct_reasm: netfilter conntrack re-assembly pointer
- *	@nf_bridge: Saved data about a bridged frame - see br_netfilter.c
- *	@skb_iif: ifindex of device we arrived on
- *	@rxhash: the packet hash computed on receive
- *	@queue_mapping: Queue mapping for multiqueue devices
- *	@tc_index: Traffic control index
- *	@tc_verd: traffic control verdict
- *	@ndisc_nodetype: router type (from link layer)
- *	@dma_cookie: a cookie to one of several possible DMA operations
- *		done by skb DMA functions
- *	@secmark: security marking
- *	@vlan_tci: vlan tag control information
- */
-
-struct sk_buff {
-	/* These two members must be first. */
-	struct sk_buff		*next;
-	struct sk_buff		*prev;
-
-	ktime_t			tstamp;
-
-	struct sock		*sk;
-	//struct net_device	*dev;
-	struct ifnet *dev;
-
-	/*
-	 * This is the control buffer. It is free to use for every
-	 * layer. Please put your private variables there. If you
-	 * want to keep them across layers you have to do a skb_clone()
-	 * first. This is owned by whoever has the skb queued ATM.
-	 */
-	char			cb[48] __aligned(8);
-
-	unsigned long		_skb_refdst;
-#ifdef CONFIG_XFRM
-	struct	sec_path	*sp;
-#endif
-	unsigned int		len,
-				data_len;
-	u16			mac_len,
-				hdr_len;
-	union {
-		u32		csum;
-		struct {
-			u16	csum_start;
-			u16	csum_offset;
-		}smbol2;
-	}smbol1;
-	u32			priority;
-	kmemcheck_bitfield_begin(flags1);
-	u8			local_df:1,
-				cloned:1,
-				ip_summed:2,
-				nohdr:1,
-				nfctinfo:3;
-	u8			pkt_type:3,
-				fclone:2,
-				ipvs_property:1,
-				peeked:1,
-				nf_trace:1;
-	kmemcheck_bitfield_end(flags1);
-	u16			protocol;
-
-	void			(*destructor)(struct sk_buff *skb);
-#if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE)
-	struct nf_conntrack	*nfct;
-	struct sk_buff		*nfct_reasm;
-#endif
-#ifdef CONFIG_BRIDGE_NETFILTER
-	struct nf_bridge_info	*nf_bridge;
-#endif
-
-	int			skb_iif;
-#ifdef CONFIG_NET_SCHED
-	u16			tc_index;	/* traffic control index */
-#ifdef CONFIG_NET_CLS_ACT
-	u16			tc_verd;	/* traffic control verdict */
-#endif
-#endif
-
-	u32			rxhash;
-
-	kmemcheck_bitfield_begin(flags2);
-	u16			queue_mapping:16;
-#ifdef CONFIG_IPV6_NDISC_NODETYPE
-	u8			ndisc_nodetype:2,
-				deliver_no_wcard:1;
-#else
-	u8			deliver_no_wcard:1;
-#endif
-	kmemcheck_bitfield_end(flags2);
-
-	/* 0/14 bit hole */
-
-#ifdef CONFIG_NET_DMA
-	dma_cookie_t		dma_cookie;
-#endif
-#ifdef CONFIG_NETWORK_SECMARK
-	u32			secmark;
-#endif
-	union {
-		u32		mark;
-		u32		dropcount;
-	}symbol3;
-
-	u16			vlan_tci;
-
-	sk_buff_data_t		transport_header;
-	sk_buff_data_t		network_header;
-	sk_buff_data_t		mac_header;
-	/* These elements must be at the end, see alloc_skb() for details.  */
-	sk_buff_data_t		tail;
-	sk_buff_data_t		end;
-	unsigned char		*head,
-				*data;
-	unsigned int		truesize;
-	atomic_t		users;
-};
-struct sk_buff_head {
-	/* These two members must be first. */
-	struct sk_buff	*next;
-	struct sk_buff	*prev;
-
-	u32		qlen;
-	_lock	lock;
-};
-#define skb_tail_pointer(skb)	skb->tail
-static inline unsigned char *skb_put(struct sk_buff *skb, unsigned int len)
-{
-	unsigned char *tmp = skb_tail_pointer(skb);
-	//SKB_LINEAR_ASSERT(skb);
-	skb->tail += len;
-	skb->len  += len;
-	return tmp;
-}
-
-static inline unsigned char *__skb_pull(struct sk_buff *skb, unsigned int len)
-{
-	skb->len -= len;
-	if(skb->len < skb->data_len)
-		printf("%s(),%d,error!\n",__FUNCTION__,__LINE__);
-	return skb->data += len;
-}
-static inline unsigned char *skb_pull(struct sk_buff *skb, unsigned int len)
-{
-	#ifdef PLATFORM_FREEBSD
-	return __skb_pull(skb, len);
-	#else
-	return unlikely(len > skb->len) ? NULL : __skb_pull(skb, len);
-	#endif //PLATFORM_FREEBSD
-}
-static inline u32 skb_queue_len(const struct sk_buff_head *list_)
-{
-	return list_->qlen;
-}
-static inline void __skb_insert(struct sk_buff *newsk,
-				struct sk_buff *prev, struct sk_buff *next,
-				struct sk_buff_head *list)
-{
-	newsk->next = next;
-	newsk->prev = prev;
-	next->prev  = prev->next = newsk;
-	list->qlen++;
-}
-static inline void __skb_queue_before(struct sk_buff_head *list,
-				      struct sk_buff *next,
-				      struct sk_buff *newsk)
-{
-	__skb_insert(newsk, next->prev, next, list);
-}
-static inline void skb_queue_tail(struct sk_buff_head *list,
-				   struct sk_buff *newsk)
-{
-	mtx_lock(&list->lock);
-	__skb_queue_before(list, (struct sk_buff *)list, newsk);
-	mtx_unlock(&list->lock);
-}
-static inline struct sk_buff *skb_peek(struct sk_buff_head *list_)
-{
-	struct sk_buff *list = ((struct sk_buff *)list_)->next;
-	if (list == (struct sk_buff *)list_)
-		list = NULL;
-	return list;
-}
-static inline void __skb_unlink(struct sk_buff *skb, struct sk_buff_head *list)
-{
-	struct sk_buff *next, *prev;
-
-	list->qlen--;
-	next	   = skb->next;
-	prev	   = skb->prev;
-	skb->next  = skb->prev = NULL;
-	next->prev = prev;
-	prev->next = next;
-}
-
-static inline struct sk_buff *skb_dequeue(struct sk_buff_head *list)
-{
-	mtx_lock(&list->lock);
-
-	struct sk_buff *skb = skb_peek(list);
-	if (skb)
-		__skb_unlink(skb, list);
-
-	mtx_unlock(&list->lock);
-
-	return skb;
-}
-static inline void skb_reserve(struct sk_buff *skb, int len)
-{
-	skb->data += len;
-	skb->tail += len;
-}
-static inline void __skb_queue_head_init(struct sk_buff_head *list)
-{
-	list->prev = list->next = (struct sk_buff *)list;
-	list->qlen = 0;
-}
-/*
- * This function creates a split out lock class for each invocation;
- * this is needed for now since a whole lot of users of the skb-queue
- * infrastructure in drivers have different locking usage (in hardirq)
- * than the networking core (in softirq only). In the long run either the
- * network layer or drivers should need annotation to consolidate the
- * main types of usage into 3 classes.
- */
-static inline void skb_queue_head_init(struct sk_buff_head *list)
-{
-	_rtw_spinlock_init(&list->lock);
-	__skb_queue_head_init(list);
-}
-unsigned long copy_from_user(void *to, const void *from, unsigned long n);
-unsigned long copy_to_user(void *to, const void *from, unsigned long n);
-struct sk_buff * dev_alloc_skb(unsigned int size);
-struct sk_buff *skb_clone(const struct sk_buff *skb);
-void dev_kfree_skb_any(struct sk_buff *skb);
-#endif //Baron porting from linux, it's all temp solution, needs to check again
-
-
-#if 1 // kenny add Linux compatibility code for Linux USB driver
-#include <dev/usb/usb_compat_linux.h>
-
-#define __init		// __attribute ((constructor))
-#define __exit		// __attribute ((destructor))
-
-/*
- * Definitions for module_init and module_exit macros.
- *
- * These macros will use the SYSINIT framework to call a specified
- * function (with no arguments) on module loading or unloading.
- * 
- */
-
-void module_init_exit_wrapper(void *arg);
-
-#define module_init(initfn)                             \
-        SYSINIT(mod_init_ ## initfn,                    \
-                SI_SUB_KLD, SI_ORDER_FIRST,             \
-                module_init_exit_wrapper, initfn)
-
-#define module_exit(exitfn)                             \
-        SYSUNINIT(mod_exit_ ## exitfn,                  \
-                  SI_SUB_KLD, SI_ORDER_ANY,             \
-                  module_init_exit_wrapper, exitfn)
-
-/*
- * The usb_register and usb_deregister functions are used to register
- * usb drivers with the usb subsystem. 
- */
-int usb_register(struct usb_driver *driver);
-int usb_deregister(struct usb_driver *driver);
-
-/*
- * usb_get_dev and usb_put_dev - increment/decrement the reference count 
- * of the usb device structure.
- *
- * Original body of usb_get_dev:
- *
- *       if (dev)
- *               get_device(&dev->dev);
- *       return dev;
- *
- * Reference counts are not currently used in this compatibility
- * layer. So these functions will do nothing.
- */
-static inline struct usb_device *
-usb_get_dev(struct usb_device *dev)
-{
-        return dev;
-}
-
-static inline void 
-usb_put_dev(struct usb_device *dev)
-{
-        return;
-}
-
-
-// rtw_usb_compat_linux
-int rtw_usb_submit_urb(struct urb *urb, uint16_t mem_flags);
-int rtw_usb_unlink_urb(struct urb *urb);
-int rtw_usb_clear_halt(struct usb_device *dev, struct usb_host_endpoint *uhe);
-int rtw_usb_control_msg(struct usb_device *dev, struct usb_host_endpoint *uhe,
-    uint8_t request, uint8_t requesttype,
-    uint16_t value, uint16_t index, void *data,
-    uint16_t size, usb_timeout_t timeout);
-int rtw_usb_set_interface(struct usb_device *dev, uint8_t iface_no, uint8_t alt_index);
-int rtw_usb_setup_endpoint(struct usb_device *dev,
-    struct usb_host_endpoint *uhe, usb_size_t bufsize);
-struct urb *rtw_usb_alloc_urb(uint16_t iso_packets, uint16_t mem_flags);
-struct usb_host_endpoint *rtw_usb_find_host_endpoint(struct usb_device *dev, uint8_t type, uint8_t ep);
-struct usb_host_interface *rtw_usb_altnum_to_altsetting(const struct usb_interface *intf, uint8_t alt_index);
-struct usb_interface *rtw_usb_ifnum_to_if(struct usb_device *dev, uint8_t iface_no);
-void *rtw_usbd_get_intfdata(struct usb_interface *intf);
-void rtw_usb_linux_register(void *arg);
-void rtw_usb_linux_deregister(void *arg);
-void rtw_usb_linux_free_device(struct usb_device *dev);
-void rtw_usb_free_urb(struct urb *urb);
-void rtw_usb_init_urb(struct urb *urb);
-void rtw_usb_kill_urb(struct urb *urb);
-void rtw_usb_set_intfdata(struct usb_interface *intf, void *data);
-void rtw_usb_fill_bulk_urb(struct urb *urb, struct usb_device *udev,
-    struct usb_host_endpoint *uhe, void *buf,
-    int length, usb_complete_t callback, void *arg);
-int rtw_usb_bulk_msg(struct usb_device *udev, struct usb_host_endpoint *uhe,
-    void *data, int len, uint16_t *pactlen, usb_timeout_t timeout);
-void *usb_get_intfdata(struct usb_interface *intf);
-int usb_linux_init_endpoints(struct usb_device *udev);
-
-
-
-typedef struct urb *  PURB;
-
-typedef unsigned gfp_t;
-#define __GFP_WAIT      ((gfp_t)0x10u)  /* Can wait and reschedule? */
-#define __GFP_HIGH      ((gfp_t)0x20u)  /* Should access emergency pools? */
-#define __GFP_IO        ((gfp_t)0x40u)  /* Can start physical IO? */
-#define __GFP_FS        ((gfp_t)0x80u)  /* Can call down to low-level FS? */
-#define __GFP_COLD      ((gfp_t)0x100u) /* Cache-cold page required */
-#define __GFP_NOWARN    ((gfp_t)0x200u) /* Suppress page allocation failure warning */
-#define __GFP_REPEAT    ((gfp_t)0x400u) /* Retry the allocation.  Might fail */
-#define __GFP_NOFAIL    ((gfp_t)0x800u) /* Retry for ever.  Cannot fail */
-#define __GFP_NORETRY   ((gfp_t)0x1000u)/* Do not retry.  Might fail */
-#define __GFP_NO_GROW   ((gfp_t)0x2000u)/* Slab internal usage */
-#define __GFP_COMP      ((gfp_t)0x4000u)/* Add compound page metadata */
-#define __GFP_ZERO      ((gfp_t)0x8000u)/* Return zeroed page on success */
-#define __GFP_NOMEMALLOC ((gfp_t)0x10000u) /* Don't use emergency reserves */
-#define __GFP_HARDWALL   ((gfp_t)0x20000u) /* Enforce hardwall cpuset memory allocs */
-
-/* This equals 0, but use constants in case they ever change */
-#define GFP_NOWAIT      (GFP_ATOMIC & ~__GFP_HIGH)
-/* GFP_ATOMIC means both !wait (__GFP_WAIT not set) and use emergency pool */
-#define GFP_ATOMIC      (__GFP_HIGH)
-#define GFP_NOIO        (__GFP_WAIT)
-#define GFP_NOFS        (__GFP_WAIT | __GFP_IO)
-#define GFP_KERNEL      (__GFP_WAIT | __GFP_IO | __GFP_FS)
-#define GFP_USER        (__GFP_WAIT | __GFP_IO | __GFP_FS | __GFP_HARDWALL)
-#define GFP_HIGHUSER    (__GFP_WAIT | __GFP_IO | __GFP_FS | __GFP_HARDWALL | \
-                         __GFP_HIGHMEM)
-
-
-#endif // kenny add Linux compatibility code for Linux USB
-
-__inline static _list *get_next(_list	*list)
-{
-	return list->next;
-}	
-
-__inline static _list	*get_list_head(_queue	*queue)
-{
-	return (&(queue->queue));
-}
-
-	
-#define LIST_CONTAINOR(ptr, type, member) \
-        ((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))	
-
-        
-__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
-{
-	spin_lock_irqsave(plock, *pirqL);
-}
-
-__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
-{
-	spin_unlock_irqrestore(plock, *pirqL);
-}
-
-__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	spin_lock_irqsave(plock, *pirqL);
-}
-
-__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	spin_unlock_irqrestore(plock, *pirqL);
-}
-
-__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
-{
-	spin_lock_bh(plock, *pirqL);
-}
-
-__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
-{
-	spin_unlock_bh(plock, *pirqL);
-}
-
-__inline static void _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
-{
-
-		mtx_lock(pmutex);
-
-}
-
-
-__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
-{
-
-		mtx_unlock(pmutex);
-
-}
-static inline void __list_del(struct list_head * prev, struct list_head * next)
-{
-	next->prev = prev;
-	prev->next = next;
-}
-static inline void INIT_LIST_HEAD(struct list_head *list)
-{
-	list->next = list;
-	list->prev = list;
-}
-__inline static void rtw_list_delete(_list *plist)
-{
-	__list_del(plist->prev, plist->next);
-	INIT_LIST_HEAD(plist);
-}
-
-__inline static void _init_timer(_timer *ptimer,_nic_hdl padapter,void *pfunc,void* cntx)
-{
-	ptimer->function = pfunc;
-	ptimer->arg = cntx;
-	callout_init(&ptimer->callout, CALLOUT_MPSAFE);
-}
-
-__inline static void _set_timer(_timer *ptimer,u32 delay_time)
-{	
-	//	mod_timer(ptimer , (jiffies+(delay_time*HZ/1000)));
-	if(ptimer->function && ptimer->arg){
-		rtw_mtx_lock(NULL);
-		callout_reset(&ptimer->callout, delay_time,ptimer->function, ptimer->arg);
-		rtw_mtx_unlock(NULL);
-	}
-}
-
-__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)
-{
-	//	del_timer_sync(ptimer); 	
-	//	*bcancelled=  _TRUE;//TRUE ==1; FALSE==0	
-	rtw_mtx_lock(NULL);
-	callout_drain(&ptimer->callout);
-	rtw_mtx_unlock(NULL);
-}
-
-__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
-{
-	printf("%s Not implement yet! \n",__FUNCTION__);
-}
-
-__inline static void _set_workitem(_workitem *pwork)
-{
-	printf("%s Not implement yet! \n",__FUNCTION__);
-//	schedule_work(pwork);
-}
-
-//
-// Global Mutex: can only be used at PASSIVE level.
-//
-
-#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-}
-
-#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-}
-
-#define ATOMIC_INIT(i)  { (i) }
-
-static __inline void thread_enter(char *name);
-
-//Atomic integer operations
-typedef uint32_t ATOMIC_T ;
-
-#define rtw_netdev_priv(netdev) (((struct ifnet *)netdev)->if_softc)
-
-#define rtw_free_netdev(netdev) if_free((netdev))
-
-#define NDEV_FMT "%s"
-#define NDEV_ARG(ndev) ""
-#define ADPT_FMT "%s"
-#define ADPT_ARG(adapter) ""
-#define FUNC_NDEV_FMT "%s"
-#define FUNC_NDEV_ARG(ndev) __func__
-#define FUNC_ADPT_FMT "%s"
-#define FUNC_ADPT_ARG(adapter) __func__
-
-#define STRUCT_PACKED
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BSD_SERVICE_H_
+#define __OSDEP_BSD_SERVICE_H_
+
+
+#include <sys/cdefs.h>
+#include <sys/types.h>
+#include <sys/systm.h>
+#include <sys/param.h>
+#include <sys/sockio.h>
+#include <sys/sysctl.h>
+#include <sys/lock.h>
+#include <sys/mutex.h>
+#include <sys/mbuf.h>
+#include <sys/kernel.h>
+#include <sys/socket.h>
+#include <sys/systm.h>
+#include <sys/malloc.h>
+#include <sys/module.h>
+#include <sys/bus.h>
+#include <sys/endian.h>
+#include <sys/kdb.h>
+#include <sys/kthread.h>
+#include <sys/malloc.h>
+#include <sys/time.h>
+#include <machine/atomic.h>
+#include <machine/bus.h>
+#include <machine/resource.h>
+#include <sys/rman.h>
+
+#include <net/bpf.h>
+#include <net/if.h>
+#include <net/if_arp.h>
+#include <net/ethernet.h>
+#include <net/if_dl.h>
+#include <net/if_media.h>
+#include <net/if_types.h>
+#include <net/route.h>
+
+
+#include <netinet/in.h>
+#include <netinet/in_systm.h>
+#include <netinet/in_var.h>
+#include <netinet/if_ether.h>
+#include <if_ether.h>
+
+#include <net80211/ieee80211_var.h>
+#include <net80211/ieee80211_regdomain.h>
+#include <net80211/ieee80211_radiotap.h>
+#include <net80211/ieee80211_ratectl.h>
+
+#include <dev/usb/usb.h>
+#include <dev/usb/usbdi.h>
+#include "usbdevs.h"
+
+#define	USB_DEBUG_VAR rum_debug
+#include <dev/usb/usb_debug.h>
+
+#if 1 //Baron porting from linux, it's all temp solution, needs to check again
+#include <sys/sema.h>
+#include <sys/pcpu.h> /* XXX for PCPU_GET */
+//	typedef struct 	semaphore _sema;
+	typedef struct 	sema _sema;
+//	typedef	spinlock_t	_lock;
+	typedef	struct mtx	_lock;
+	typedef struct mtx 		_mutex;
+	typedef struct rtw_timer_list _timer;
+	struct list_head {
+	struct list_head *next, *prev;
+	};
+	struct	__queue	{
+		struct	list_head	queue;	
+		_lock	lock;
+	};
+
+	typedef	struct mbuf _pkt;
+	typedef struct mbuf	_buffer;
+	
+	typedef struct	__queue	_queue;
+	typedef struct	list_head	_list;
+	typedef	int	_OS_STATUS;
+	//typedef u32	_irqL;
+	typedef unsigned long _irqL;
+	typedef	struct	ifnet * _nic_hdl;
+	
+	typedef pid_t		_thread_hdl_;
+//	typedef struct thread		_thread_hdl_;
+	typedef void		thread_return;
+	typedef void*	thread_context;
+
+	typedef void timer_hdl_return;
+	typedef void* timer_hdl_context;
+	typedef struct work_struct _workitem;
+
+#define   KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))
+/* emulate a modern version */
+#define LINUX_VERSION_CODE KERNEL_VERSION(2, 6, 35)
+
+#define WIRELESS_EXT -1
+#define HZ hz
+#define spin_lock_irqsave mtx_lock_irqsave
+#define spin_lock_bh mtx_lock_irqsave
+#define mtx_lock_irqsave(lock, x) mtx_lock(lock)//{local_irq_save((x)); mtx_lock_spin((lock));}
+//#define IFT_RTW	0xf9 //ifnet allocate type for RTW
+#define free_netdev if_free
+#define LIST_CONTAINOR(ptr, type, member) \
+        ((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))
+#define container_of(p,t,n) (t*)((p)-&(((t*)0)->n))
+/* 
+ * Linux timers are emulated using FreeBSD callout functions
+ * (and taskqueue functionality).
+ *
+ * Currently no timer stats functionality.
+ *
+ * See (linux_compat) processes.c
+ *
+ */
+struct rtw_timer_list {
+	struct callout callout;
+	void (*function)(void *);
+	void *arg;
+};
+
+struct workqueue_struct;
+struct work_struct;
+typedef void (*work_func_t)(struct work_struct *work);
+/* Values for the state of an item of work (work_struct) */
+typedef enum work_state {
+        WORK_STATE_UNSET = 0,
+        WORK_STATE_CALLOUT_PENDING = 1,
+        WORK_STATE_TASK_PENDING = 2,
+        WORK_STATE_WORK_CANCELLED = 3        
+} work_state_t;
+
+struct work_struct {
+        struct task task; /* FreeBSD task */
+        work_state_t state; /* the pending or otherwise state of work. */
+        work_func_t func;       
+};
+#define spin_unlock_irqrestore mtx_unlock_irqrestore
+#define spin_unlock_bh mtx_unlock_irqrestore
+#define mtx_unlock_irqrestore(lock,x)    mtx_unlock(lock);
+extern void	_rtw_spinlock_init(_lock *plock);
+
+//modify private structure to match freebsd
+#define BITS_PER_LONG 32
+union ktime {
+	s64	tv64;
+#if BITS_PER_LONG != 64 && !defined(CONFIG_KTIME_SCALAR)
+	struct {
+#ifdef __BIG_ENDIAN
+	s32	sec, nsec;
+#else
+	s32	nsec, sec;
+#endif
+	} tv;
+#endif
+};
+#define kmemcheck_bitfield_begin(name)
+#define kmemcheck_bitfield_end(name)
+#define CHECKSUM_NONE 0
+typedef unsigned char *sk_buff_data_t;
+typedef union ktime ktime_t;		/* Kill this */
+
+void rtw_mtx_lock(_lock *plock);
+	
+void rtw_mtx_unlock(_lock *plock);
+
+/** 
+ *	struct sk_buff - socket buffer
+ *	@next: Next buffer in list
+ *	@prev: Previous buffer in list
+ *	@sk: Socket we are owned by
+ *	@tstamp: Time we arrived
+ *	@dev: Device we arrived on/are leaving by
+ *	@transport_header: Transport layer header
+ *	@network_header: Network layer header
+ *	@mac_header: Link layer header
+ *	@_skb_refdst: destination entry (with norefcount bit)
+ *	@sp: the security path, used for xfrm
+ *	@cb: Control buffer. Free for use by every layer. Put private vars here
+ *	@len: Length of actual data
+ *	@data_len: Data length
+ *	@mac_len: Length of link layer header
+ *	@hdr_len: writable header length of cloned skb
+ *	@csum: Checksum (must include start/offset pair)
+ *	@csum_start: Offset from skb->head where checksumming should start
+ *	@csum_offset: Offset from csum_start where checksum should be stored
+ *	@local_df: allow local fragmentation
+ *	@cloned: Head may be cloned (check refcnt to be sure)
+ *	@nohdr: Payload reference only, must not modify header
+ *	@pkt_type: Packet class
+ *	@fclone: skbuff clone status
+ *	@ip_summed: Driver fed us an IP checksum
+ *	@priority: Packet queueing priority
+ *	@users: User count - see {datagram,tcp}.c
+ *	@protocol: Packet protocol from driver
+ *	@truesize: Buffer size 
+ *	@head: Head of buffer
+ *	@data: Data head pointer
+ *	@tail: Tail pointer
+ *	@end: End pointer
+ *	@destructor: Destruct function
+ *	@mark: Generic packet mark
+ *	@nfct: Associated connection, if any
+ *	@ipvs_property: skbuff is owned by ipvs
+ *	@peeked: this packet has been seen already, so stats have been
+ *		done for it, don't do them again
+ *	@nf_trace: netfilter packet trace flag
+ *	@nfctinfo: Relationship of this skb to the connection
+ *	@nfct_reasm: netfilter conntrack re-assembly pointer
+ *	@nf_bridge: Saved data about a bridged frame - see br_netfilter.c
+ *	@skb_iif: ifindex of device we arrived on
+ *	@rxhash: the packet hash computed on receive
+ *	@queue_mapping: Queue mapping for multiqueue devices
+ *	@tc_index: Traffic control index
+ *	@tc_verd: traffic control verdict
+ *	@ndisc_nodetype: router type (from link layer)
+ *	@dma_cookie: a cookie to one of several possible DMA operations
+ *		done by skb DMA functions
+ *	@secmark: security marking
+ *	@vlan_tci: vlan tag control information
+ */
+
+struct sk_buff {
+	/* These two members must be first. */
+	struct sk_buff		*next;
+	struct sk_buff		*prev;
+
+	ktime_t			tstamp;
+
+	struct sock		*sk;
+	//struct net_device	*dev;
+	struct ifnet *dev;
+
+	/*
+	 * This is the control buffer. It is free to use for every
+	 * layer. Please put your private variables there. If you
+	 * want to keep them across layers you have to do a skb_clone()
+	 * first. This is owned by whoever has the skb queued ATM.
+	 */
+	char			cb[48] __aligned(8);
+
+	unsigned long		_skb_refdst;
+#ifdef CONFIG_XFRM
+	struct	sec_path	*sp;
+#endif
+	unsigned int		len,
+				data_len;
+	u16			mac_len,
+				hdr_len;
+	union {
+		u32		csum;
+		struct {
+			u16	csum_start;
+			u16	csum_offset;
+		}smbol2;
+	}smbol1;
+	u32			priority;
+	kmemcheck_bitfield_begin(flags1);
+	u8			local_df:1,
+				cloned:1,
+				ip_summed:2,
+				nohdr:1,
+				nfctinfo:3;
+	u8			pkt_type:3,
+				fclone:2,
+				ipvs_property:1,
+				peeked:1,
+				nf_trace:1;
+	kmemcheck_bitfield_end(flags1);
+	u16			protocol;
+
+	void			(*destructor)(struct sk_buff *skb);
+#if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE)
+	struct nf_conntrack	*nfct;
+	struct sk_buff		*nfct_reasm;
+#endif
+#ifdef CONFIG_BRIDGE_NETFILTER
+	struct nf_bridge_info	*nf_bridge;
+#endif
+
+	int			skb_iif;
+#ifdef CONFIG_NET_SCHED
+	u16			tc_index;	/* traffic control index */
+#ifdef CONFIG_NET_CLS_ACT
+	u16			tc_verd;	/* traffic control verdict */
+#endif
+#endif
+
+	u32			rxhash;
+
+	kmemcheck_bitfield_begin(flags2);
+	u16			queue_mapping:16;
+#ifdef CONFIG_IPV6_NDISC_NODETYPE
+	u8			ndisc_nodetype:2,
+				deliver_no_wcard:1;
+#else
+	u8			deliver_no_wcard:1;
+#endif
+	kmemcheck_bitfield_end(flags2);
+
+	/* 0/14 bit hole */
+
+#ifdef CONFIG_NET_DMA
+	dma_cookie_t		dma_cookie;
+#endif
+#ifdef CONFIG_NETWORK_SECMARK
+	u32			secmark;
+#endif
+	union {
+		u32		mark;
+		u32		dropcount;
+	}symbol3;
+
+	u16			vlan_tci;
+
+	sk_buff_data_t		transport_header;
+	sk_buff_data_t		network_header;
+	sk_buff_data_t		mac_header;
+	/* These elements must be at the end, see alloc_skb() for details.  */
+	sk_buff_data_t		tail;
+	sk_buff_data_t		end;
+	unsigned char		*head,
+				*data;
+	unsigned int		truesize;
+	atomic_t		users;
+};
+struct sk_buff_head {
+	/* These two members must be first. */
+	struct sk_buff	*next;
+	struct sk_buff	*prev;
+
+	u32		qlen;
+	_lock	lock;
+};
+#define skb_tail_pointer(skb)	skb->tail
+static inline unsigned char *skb_put(struct sk_buff *skb, unsigned int len)
+{
+	unsigned char *tmp = skb_tail_pointer(skb);
+	//SKB_LINEAR_ASSERT(skb);
+	skb->tail += len;
+	skb->len  += len;
+	return tmp;
+}
+
+static inline unsigned char *__skb_pull(struct sk_buff *skb, unsigned int len)
+{
+	skb->len -= len;
+	if(skb->len < skb->data_len)
+		printf("%s(),%d,error!\n",__FUNCTION__,__LINE__);
+	return skb->data += len;
+}
+static inline unsigned char *skb_pull(struct sk_buff *skb, unsigned int len)
+{
+	#ifdef PLATFORM_FREEBSD
+	return __skb_pull(skb, len);
+	#else
+	return unlikely(len > skb->len) ? NULL : __skb_pull(skb, len);
+	#endif //PLATFORM_FREEBSD
+}
+static inline u32 skb_queue_len(const struct sk_buff_head *list_)
+{
+	return list_->qlen;
+}
+static inline void __skb_insert(struct sk_buff *newsk,
+				struct sk_buff *prev, struct sk_buff *next,
+				struct sk_buff_head *list)
+{
+	newsk->next = next;
+	newsk->prev = prev;
+	next->prev  = prev->next = newsk;
+	list->qlen++;
+}
+static inline void __skb_queue_before(struct sk_buff_head *list,
+				      struct sk_buff *next,
+				      struct sk_buff *newsk)
+{
+	__skb_insert(newsk, next->prev, next, list);
+}
+static inline void skb_queue_tail(struct sk_buff_head *list,
+				   struct sk_buff *newsk)
+{
+	mtx_lock(&list->lock);
+	__skb_queue_before(list, (struct sk_buff *)list, newsk);
+	mtx_unlock(&list->lock);
+}
+static inline struct sk_buff *skb_peek(struct sk_buff_head *list_)
+{
+	struct sk_buff *list = ((struct sk_buff *)list_)->next;
+	if (list == (struct sk_buff *)list_)
+		list = NULL;
+	return list;
+}
+static inline void __skb_unlink(struct sk_buff *skb, struct sk_buff_head *list)
+{
+	struct sk_buff *next, *prev;
+
+	list->qlen--;
+	next	   = skb->next;
+	prev	   = skb->prev;
+	skb->next  = skb->prev = NULL;
+	next->prev = prev;
+	prev->next = next;
+}
+
+static inline struct sk_buff *skb_dequeue(struct sk_buff_head *list)
+{
+	mtx_lock(&list->lock);
+
+	struct sk_buff *skb = skb_peek(list);
+	if (skb)
+		__skb_unlink(skb, list);
+
+	mtx_unlock(&list->lock);
+
+	return skb;
+}
+static inline void skb_reserve(struct sk_buff *skb, int len)
+{
+	skb->data += len;
+	skb->tail += len;
+}
+static inline void __skb_queue_head_init(struct sk_buff_head *list)
+{
+	list->prev = list->next = (struct sk_buff *)list;
+	list->qlen = 0;
+}
+/*
+ * This function creates a split out lock class for each invocation;
+ * this is needed for now since a whole lot of users of the skb-queue
+ * infrastructure in drivers have different locking usage (in hardirq)
+ * than the networking core (in softirq only). In the long run either the
+ * network layer or drivers should need annotation to consolidate the
+ * main types of usage into 3 classes.
+ */
+static inline void skb_queue_head_init(struct sk_buff_head *list)
+{
+	_rtw_spinlock_init(&list->lock);
+	__skb_queue_head_init(list);
+}
+unsigned long copy_from_user(void *to, const void *from, unsigned long n);
+unsigned long copy_to_user(void *to, const void *from, unsigned long n);
+struct sk_buff * dev_alloc_skb(unsigned int size);
+struct sk_buff *skb_clone(const struct sk_buff *skb);
+void dev_kfree_skb_any(struct sk_buff *skb);
+#endif //Baron porting from linux, it's all temp solution, needs to check again
+
+
+#if 1 // kenny add Linux compatibility code for Linux USB driver
+#include <dev/usb/usb_compat_linux.h>
+
+#define __init		// __attribute ((constructor))
+#define __exit		// __attribute ((destructor))
+
+/*
+ * Definitions for module_init and module_exit macros.
+ *
+ * These macros will use the SYSINIT framework to call a specified
+ * function (with no arguments) on module loading or unloading.
+ * 
+ */
+
+void module_init_exit_wrapper(void *arg);
+
+#define module_init(initfn)                             \
+        SYSINIT(mod_init_ ## initfn,                    \
+                SI_SUB_KLD, SI_ORDER_FIRST,             \
+                module_init_exit_wrapper, initfn)
+
+#define module_exit(exitfn)                             \
+        SYSUNINIT(mod_exit_ ## exitfn,                  \
+                  SI_SUB_KLD, SI_ORDER_ANY,             \
+                  module_init_exit_wrapper, exitfn)
+
+/*
+ * The usb_register and usb_deregister functions are used to register
+ * usb drivers with the usb subsystem. 
+ */
+int usb_register(struct usb_driver *driver);
+int usb_deregister(struct usb_driver *driver);
+
+/*
+ * usb_get_dev and usb_put_dev - increment/decrement the reference count 
+ * of the usb device structure.
+ *
+ * Original body of usb_get_dev:
+ *
+ *       if (dev)
+ *               get_device(&dev->dev);
+ *       return dev;
+ *
+ * Reference counts are not currently used in this compatibility
+ * layer. So these functions will do nothing.
+ */
+static inline struct usb_device *
+usb_get_dev(struct usb_device *dev)
+{
+        return dev;
+}
+
+static inline void 
+usb_put_dev(struct usb_device *dev)
+{
+        return;
+}
+
+
+// rtw_usb_compat_linux
+int rtw_usb_submit_urb(struct urb *urb, uint16_t mem_flags);
+int rtw_usb_unlink_urb(struct urb *urb);
+int rtw_usb_clear_halt(struct usb_device *dev, struct usb_host_endpoint *uhe);
+int rtw_usb_control_msg(struct usb_device *dev, struct usb_host_endpoint *uhe,
+    uint8_t request, uint8_t requesttype,
+    uint16_t value, uint16_t index, void *data,
+    uint16_t size, usb_timeout_t timeout);
+int rtw_usb_set_interface(struct usb_device *dev, uint8_t iface_no, uint8_t alt_index);
+int rtw_usb_setup_endpoint(struct usb_device *dev,
+    struct usb_host_endpoint *uhe, usb_size_t bufsize);
+struct urb *rtw_usb_alloc_urb(uint16_t iso_packets, uint16_t mem_flags);
+struct usb_host_endpoint *rtw_usb_find_host_endpoint(struct usb_device *dev, uint8_t type, uint8_t ep);
+struct usb_host_interface *rtw_usb_altnum_to_altsetting(const struct usb_interface *intf, uint8_t alt_index);
+struct usb_interface *rtw_usb_ifnum_to_if(struct usb_device *dev, uint8_t iface_no);
+void *rtw_usbd_get_intfdata(struct usb_interface *intf);
+void rtw_usb_linux_register(void *arg);
+void rtw_usb_linux_deregister(void *arg);
+void rtw_usb_linux_free_device(struct usb_device *dev);
+void rtw_usb_free_urb(struct urb *urb);
+void rtw_usb_init_urb(struct urb *urb);
+void rtw_usb_kill_urb(struct urb *urb);
+void rtw_usb_set_intfdata(struct usb_interface *intf, void *data);
+void rtw_usb_fill_bulk_urb(struct urb *urb, struct usb_device *udev,
+    struct usb_host_endpoint *uhe, void *buf,
+    int length, usb_complete_t callback, void *arg);
+int rtw_usb_bulk_msg(struct usb_device *udev, struct usb_host_endpoint *uhe,
+    void *data, int len, uint16_t *pactlen, usb_timeout_t timeout);
+void *usb_get_intfdata(struct usb_interface *intf);
+int usb_linux_init_endpoints(struct usb_device *udev);
+
+
+
+typedef struct urb *  PURB;
+
+typedef unsigned gfp_t;
+#define __GFP_WAIT      ((gfp_t)0x10u)  /* Can wait and reschedule? */
+#define __GFP_HIGH      ((gfp_t)0x20u)  /* Should access emergency pools? */
+#define __GFP_IO        ((gfp_t)0x40u)  /* Can start physical IO? */
+#define __GFP_FS        ((gfp_t)0x80u)  /* Can call down to low-level FS? */
+#define __GFP_COLD      ((gfp_t)0x100u) /* Cache-cold page required */
+#define __GFP_NOWARN    ((gfp_t)0x200u) /* Suppress page allocation failure warning */
+#define __GFP_REPEAT    ((gfp_t)0x400u) /* Retry the allocation.  Might fail */
+#define __GFP_NOFAIL    ((gfp_t)0x800u) /* Retry for ever.  Cannot fail */
+#define __GFP_NORETRY   ((gfp_t)0x1000u)/* Do not retry.  Might fail */
+#define __GFP_NO_GROW   ((gfp_t)0x2000u)/* Slab internal usage */
+#define __GFP_COMP      ((gfp_t)0x4000u)/* Add compound page metadata */
+#define __GFP_ZERO      ((gfp_t)0x8000u)/* Return zeroed page on success */
+#define __GFP_NOMEMALLOC ((gfp_t)0x10000u) /* Don't use emergency reserves */
+#define __GFP_HARDWALL   ((gfp_t)0x20000u) /* Enforce hardwall cpuset memory allocs */
+
+/* This equals 0, but use constants in case they ever change */
+#define GFP_NOWAIT      (GFP_ATOMIC & ~__GFP_HIGH)
+/* GFP_ATOMIC means both !wait (__GFP_WAIT not set) and use emergency pool */
+#define GFP_ATOMIC      (__GFP_HIGH)
+#define GFP_NOIO        (__GFP_WAIT)
+#define GFP_NOFS        (__GFP_WAIT | __GFP_IO)
+#define GFP_KERNEL      (__GFP_WAIT | __GFP_IO | __GFP_FS)
+#define GFP_USER        (__GFP_WAIT | __GFP_IO | __GFP_FS | __GFP_HARDWALL)
+#define GFP_HIGHUSER    (__GFP_WAIT | __GFP_IO | __GFP_FS | __GFP_HARDWALL | \
+                         __GFP_HIGHMEM)
+
+
+#endif // kenny add Linux compatibility code for Linux USB
+
+__inline static _list *get_next(_list	*list)
+{
+	return list->next;
+}	
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return (&(queue->queue));
+}
+
+	
+#define LIST_CONTAINOR(ptr, type, member) \
+        ((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))	
+
+        
+__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_bh(plock, *pirqL);
+}
+
+__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_bh(plock, *pirqL);
+}
+
+__inline static void _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+
+		mtx_lock(pmutex);
+
+}
+
+
+__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+
+		mtx_unlock(pmutex);
+
+}
+static inline void __list_del(struct list_head * prev, struct list_head * next)
+{
+	next->prev = prev;
+	prev->next = next;
+}
+static inline void INIT_LIST_HEAD(struct list_head *list)
+{
+	list->next = list;
+	list->prev = list;
+}
+__inline static void rtw_list_delete(_list *plist)
+{
+	__list_del(plist->prev, plist->next);
+	INIT_LIST_HEAD(plist);
+}
+
+static inline void timer_hdl(void *ctx)
+{
+	_timer *timer = (_timer *)ctx;
+
+	rtw_mtx_lock(NULL);
+	if (callout_pending(&timer->callout)) {
+		/* callout was reset */
+		rtw_mtx_unlock(NULL);
+		return;
+	}
+
+	if (!callout_active(&timer->callout)) {
+		/* callout was stopped */
+		rtw_mtx_unlock(NULL);
+		return;
+	}
+
+	callout_deactivate(&timer->callout);
+
+	timer->function(timer->arg);
+
+	rtw_mtx_unlock(NULL);
+}
+
+static inline void _init_timer(_timer *ptimer, _nic_hdl padapter, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+	callout_init(&ptimer->callout, CALLOUT_MPSAFE);
+}
+
+__inline static void _set_timer(_timer *ptimer,u32 delay_time)
+{	
+	if (ptimer->function && ptimer->arg) {
+		rtw_mtx_lock(NULL);
+		callout_reset(&ptimer->callout, delay_time, timer_hdl, ptimer);
+		rtw_mtx_unlock(NULL);
+	}
+}
+
+__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)
+{
+	rtw_mtx_lock(NULL);
+	callout_drain(&ptimer->callout);
+	rtw_mtx_unlock(NULL);
+	*bcancelled = 1; /* assume an pending timer to be canceled */
+}
+
+__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
+{
+	printf("%s Not implement yet! \n",__FUNCTION__);
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+	printf("%s Not implement yet! \n",__FUNCTION__);
+//	schedule_work(pwork);
+}
+
+//
+// Global Mutex: can only be used at PASSIVE level.
+//
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+}
+
+#define ATOMIC_INIT(i)  { (i) }
+
+static __inline void thread_enter(char *name);
+
+//Atomic integer operations
+typedef uint32_t ATOMIC_T ;
+
+#define rtw_netdev_priv(netdev) (((struct ifnet *)netdev)->if_softc)
+
+#define rtw_free_netdev(netdev) if_free((netdev))
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ""
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) ""
+#define FUNC_NDEV_FMT "%s"
+#define FUNC_NDEV_ARG(ndev) __func__
+#define FUNC_ADPT_FMT "%s"
+#define FUNC_ADPT_ARG(adapter) __func__
+
+#define STRUCT_PACKED
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_ce.h
index 04c5b188e647..3d6d75aa6db9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_ce.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,182 +12,190 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef __OSDEP_CE_SERVICE_H_
-#define __OSDEP_CE_SERVICE_H_
-
-
-#include <ndis.h>
-#include <ntddndis.h>
-
-#ifdef CONFIG_SDIO_HCI
-#include "SDCardDDK.h"
-#endif
-
-#ifdef CONFIG_USB_HCI
-#include <usbdi.h>
-#endif
-
-typedef HANDLE 	_sema;
-typedef	LIST_ENTRY	_list;
-typedef NDIS_STATUS _OS_STATUS;
-
-typedef NDIS_SPIN_LOCK	_lock;
-
-typedef HANDLE 		_rwlock; //Mutex
-
-typedef u32	_irqL;
-
-typedef NDIS_HANDLE  _nic_hdl;
-
-
-typedef NDIS_MINIPORT_TIMER    _timer;
-
-struct	__queue	{
-	LIST_ENTRY	queue;
-	_lock	lock;
-};
-
-typedef	NDIS_PACKET	_pkt;
-typedef NDIS_BUFFER	_buffer;
-typedef struct	__queue	_queue;
-
-typedef HANDLE 	_thread_hdl_;
-typedef DWORD thread_return;
-typedef void*	thread_context;
-typedef NDIS_WORK_ITEM _workitem;
-
-#define thread_exit() ExitThread(STATUS_SUCCESS); return 0;
-
-
-#define SEMA_UPBND	(0x7FFFFFFF)   //8192
-
-__inline static _list *get_prev(_list	*list)
-{
-	return list->Blink;
-}
-	
-__inline static _list *get_next(_list	*list)
-{
-	return list->Flink;
-}
-
-__inline static _list	*get_list_head(_queue	*queue)
-{
-	return (&(queue->queue));
-}
-
-#define LIST_CONTAINOR(ptr, type, member) CONTAINING_RECORD(ptr, type, member)
-
-__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
-{
-	NdisAcquireSpinLock(plock);
-}
-
-__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
-{
-	NdisReleaseSpinLock(plock);
-}
-
-__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	NdisDprAcquireSpinLock(plock);	
-}
-
-__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	NdisDprReleaseSpinLock(plock);	
-}
-
-
-__inline static void _enter_hwio_critical(_rwlock *prwlock, _irqL *pirqL)
-{
-	WaitForSingleObject(*prwlock, INFINITE );
-
-}
-
-__inline static void _exit_hwio_critical(_rwlock *prwlock, _irqL *pirqL)
-{
-	ReleaseMutex(*prwlock);
-}
-
-__inline static void rtw_list_delete(_list *plist)
-{
-	RemoveEntryList(plist);
-	InitializeListHead(plist);
-}
-
-#define RTW_TIMER_HDL_ARGS IN PVOID SystemSpecific1, IN PVOID FunctionContext, IN PVOID SystemSpecific2, IN PVOID SystemSpecific3
-
-__inline static void _init_timer(_timer *ptimer,_nic_hdl nic_hdl,void *pfunc,PVOID cntx)
-{
-	NdisMInitializeTimer(ptimer, nic_hdl, pfunc, cntx);
-}
-
-__inline static void _set_timer(_timer *ptimer,u32 delay_time)
-{
- 	NdisMSetTimer(ptimer,delay_time);
-}
-
-__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)
-{
-	NdisMCancelTimer(ptimer,bcancelled);
-}
-
-__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
-{
-
-	NdisInitializeWorkItem(pwork, pfunc, cntx);
-}
-
-__inline static void _set_workitem(_workitem *pwork)
-{
-	NdisScheduleWorkItem(pwork);
-}
-
-#define ATOMIC_INIT(i)  { (i) }
-
-//
-// Global Mutex: can only be used at PASSIVE level.
-//
-
-#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-    while (NdisInterlockedIncrement((PULONG)&(_MutexCounter)) != 1)\
-    {                                                           \
-        NdisInterlockedDecrement((PULONG)&(_MutexCounter));        \
-        NdisMSleep(10000);                          \
-    }                                                           \
-}
-
-#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-    NdisInterlockedDecrement((PULONG)&(_MutexCounter));              \
-}
-
-// limitation of path length
-#define PATH_LENGTH_MAX MAX_PATH
-
-//Atomic integer operations
-#define ATOMIC_T LONG
-
-#define NDEV_FMT "%s"
-#define NDEV_ARG(ndev) ""
-#define ADPT_FMT "%s"
-#define ADPT_ARG(adapter) ""
-#define FUNC_NDEV_FMT "%s"
-#define FUNC_NDEV_ARG(ndev) __func__
-#define FUNC_ADPT_FMT "%s"
-#define FUNC_ADPT_ARG(adapter) __func__
-
-#define STRUCT_PACKED
-
-
-#endif
-
+ *****************************************************************************/
+
+#ifndef __OSDEP_CE_SERVICE_H_
+#define __OSDEP_CE_SERVICE_H_
+
+
+#include <ndis.h>
+#include <ntddndis.h>
+
+#ifdef CONFIG_SDIO_HCI
+#include "SDCardDDK.h"
+#endif
+
+#ifdef CONFIG_USB_HCI
+#include <usbdi.h>
+#endif
+
+typedef HANDLE 	_sema;
+typedef	LIST_ENTRY	_list;
+typedef NDIS_STATUS _OS_STATUS;
+
+typedef NDIS_SPIN_LOCK	_lock;
+
+typedef HANDLE 		_rwlock; //Mutex
+
+typedef u32	_irqL;
+
+typedef NDIS_HANDLE  _nic_hdl;
+
+struct rtw_timer_list {
+	NDIS_MINIPORT_TIMER ndis_timer;
+	void (*function)(void *);
+	void *arg;
+};
+
+struct	__queue	{
+	LIST_ENTRY	queue;
+	_lock	lock;
+};
+
+typedef	NDIS_PACKET	_pkt;
+typedef NDIS_BUFFER	_buffer;
+typedef struct	__queue	_queue;
+
+typedef HANDLE 	_thread_hdl_;
+typedef DWORD thread_return;
+typedef void*	thread_context;
+typedef NDIS_WORK_ITEM _workitem;
+
+
+
+#define SEMA_UPBND	(0x7FFFFFFF)   //8192
+
+__inline static _list *get_prev(_list	*list)
+{
+	return list->Blink;
+}
+	
+__inline static _list *get_next(_list	*list)
+{
+	return list->Flink;
+}
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return (&(queue->queue));
+}
+
+#define LIST_CONTAINOR(ptr, type, member) CONTAINING_RECORD(ptr, type, member)
+
+__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisAcquireSpinLock(plock);
+}
+
+__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisReleaseSpinLock(plock);
+}
+
+__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprAcquireSpinLock(plock);	
+}
+
+__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprReleaseSpinLock(plock);	
+}
+
+
+__inline static void _enter_hwio_critical(_rwlock *prwlock, _irqL *pirqL)
+{
+	WaitForSingleObject(*prwlock, INFINITE );
+
+}
+
+__inline static void _exit_hwio_critical(_rwlock *prwlock, _irqL *pirqL)
+{
+	ReleaseMutex(*prwlock);
+}
+
+__inline static void rtw_list_delete(_list *plist)
+{
+	RemoveEntryList(plist);
+	InitializeListHead(plist);
+}
+
+static inline void timer_hdl(
+	IN PVOID SystemSpecific1,
+	IN PVOID FunctionContext,
+	IN PVOID SystemSpecific2,
+	IN PVOID SystemSpecific3)
+{
+	_timer *timer = (_timer *)FunctionContext;
+
+	timer->function(timer->arg);
+}
+
+static inline void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+	NdisMInitializeTimer(&ptimer->ndis_timer, nic_hdl, timer_hdl, ptimer);
+}
+
+static inline void _set_timer(_timer *ptimer, u32 delay_time)
+{
+	NdisMSetTimer(ptimer, delay_time);
+}
+
+static inline void _cancel_timer(_timer *ptimer, u8 *bcancelled)
+{
+	NdisMCancelTimer(ptimer, bcancelled);
+}
+
+__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
+{
+
+	NdisInitializeWorkItem(pwork, pfunc, cntx);
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+	NdisScheduleWorkItem(pwork);
+}
+
+#define ATOMIC_INIT(i)  { (i) }
+
+//
+// Global Mutex: can only be used at PASSIVE level.
+//
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    while (NdisInterlockedIncrement((PULONG)&(_MutexCounter)) != 1)\
+    {                                                           \
+        NdisInterlockedDecrement((PULONG)&(_MutexCounter));        \
+        NdisMSleep(10000);                          \
+    }                                                           \
+}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    NdisInterlockedDecrement((PULONG)&(_MutexCounter));              \
+}
+
+// limitation of path length
+#define PATH_LENGTH_MAX MAX_PATH
+
+//Atomic integer operations
+#define ATOMIC_T LONG
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ""
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) ""
+#define FUNC_NDEV_FMT "%s"
+#define FUNC_NDEV_ARG(ndev) __func__
+#define FUNC_ADPT_FMT "%s"
+#define FUNC_ADPT_ARG(adapter) __func__
+
+#define STRUCT_PACKED
+
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_linux.h
index 939d9d423550..6034756bf19a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_linux.h
@@ -1,429 +1,544 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __OSDEP_LINUX_SERVICE_H_
-#define __OSDEP_LINUX_SERVICE_H_
-
-	#include <linux/version.h>
-	#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>
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,5))
-	#include <linux/kref.h>
-#endif
-	//#include <linux/smp_lock.h>
-	#include <linux/netdevice.h>
-	#include <linux/skbuff.h>
-	#include <linux/circ_buf.h>
-	#include <asm/uaccess.h>
-	#include <asm/byteorder.h>
-	#include <asm/atomic.h>
-	#include <asm/io.h>
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,26))
-	#include <asm/semaphore.h>
-#else
-	#include <linux/semaphore.h>
-#endif
-	#include <linux/sem.h>
-	#include <linux/sched.h>
-	#include <linux/etherdevice.h>
-	#include <linux/wireless.h>
-	#include <net/iw_handler.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 <linux/kthread.h>
-	#include <linux/list.h>
-	#include <linux/vmalloc.h>
-
-#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2,5,41))
-	#include <linux/tqueue.h>
-#endif
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 7, 0))
-	#include <uapi/linux/limits.h>
-#else
-	#include <linux/limits.h>
-#endif
-
-#ifdef RTK_DMP_PLATFORM
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,12))
-	#include <linux/pageremap.h>
-#endif
-	#include <asm/io.h>
-#endif
-
-#ifdef CONFIG_NET_RADIO
-	#define CONFIG_WIRELESS_EXT
-#endif
-
-	/* Monitor mode */
-	#include <net/ieee80211_radiotap.h>
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_LINUX_SERVICE_H_
+#define __OSDEP_LINUX_SERVICE_H_
+
+#include <linux/version.h>
+#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>
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 5))
+	#include <linux/kref.h>
+#endif
+/* #include <linux/smp_lock.h> */
+#include <linux/netdevice.h>
+#include <linux/inetdevice.h>
+#include <linux/skbuff.h>
+#include <linux/circ_buf.h>
+#include <asm/uaccess.h>
+#include <asm/byteorder.h>
+#include <asm/atomic.h>
+#include <asm/io.h>
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
+	#include <asm/semaphore.h>
+#else
+	#include <linux/semaphore.h>
+#endif
+#include <linux/sem.h>
+#include <linux/sched.h>
+#include <linux/etherdevice.h>
+#include <linux/wireless.h>
+#include <net/iw_handler.h>
+#include <net/addrconf.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 <linux/kthread.h>
+#include <linux/list.h>
+#include <linux/vmalloc.h>
+
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 5, 41))
+	#include <linux/tqueue.h>
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 7, 0))
+	#include <uapi/linux/limits.h>
+#else
+	#include <linux/limits.h>
+#endif
+
+#ifdef RTK_DMP_PLATFORM
+	#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
+		#include <linux/pageremap.h>
+	#endif
+	#include <asm/io.h>
+#endif
+
+#ifdef CONFIG_NET_RADIO
+	#define CONFIG_WIRELESS_EXT
+#endif
+
+/* Monitor mode */
+#include <net/ieee80211_radiotap.h>
+
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
 	#include <linux/ieee80211.h>
 #endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 25) && \
+	 LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 29))
+	#define CONFIG_IEEE80211_HT_ADDT_INFO
+#endif
+
 #ifdef CONFIG_IOCTL_CFG80211
-/*	#include <linux/ieee80211.h> */
-	#include <net/cfg80211.h>
-#endif //CONFIG_IOCTL_CFG80211
-
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
-	#include <linux/in.h>
-	#include <linux/udp.h>
-#endif
-
-#ifdef CONFIG_HAS_EARLYSUSPEND
-	#include <linux/earlysuspend.h>
-#endif //CONFIG_HAS_EARLYSUSPEND
-
-#ifdef CONFIG_EFUSE_CONFIG_FILE
-	#include <linux/fs.h>
-#endif
-
-#ifdef CONFIG_USB_HCI
-	#include <linux/usb.h>
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,21))
-	#include <linux/usb_ch9.h>
-#else
-	#include <linux/usb/ch9.h>
-#endif
-#endif
-
-#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-	#include <net/sock.h>
-	#include <net/tcp.h>
-	#include <linux/udp.h>
-	#include <linux/in.h>
-	#include <linux/netlink.h>
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-
-#ifdef CONFIG_USB_HCI
-	typedef struct urb *  PURB;
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,22))
-#ifdef CONFIG_USB_SUSPEND
-#define CONFIG_AUTOSUSPEND	1
-#endif
-#endif
-#endif
-
-	typedef struct 	semaphore _sema;
-	typedef	spinlock_t	_lock;
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-	typedef struct mutex 		_mutex;
-#else
-	typedef struct semaphore	_mutex;
-#endif
-	typedef struct timer_list _timer;
-
-	struct	__queue	{
-		struct	list_head	queue;	
-		_lock	lock;
-	};
-
-	typedef	struct sk_buff	_pkt;
-	typedef unsigned char	_buffer;
-	
-	typedef struct	__queue	_queue;
-	typedef struct	list_head	_list;
-	typedef	int	_OS_STATUS;
-	//typedef u32	_irqL;
-	typedef unsigned long _irqL;
-	typedef	struct	net_device * _nic_hdl;
-	
-	typedef void*		_thread_hdl_;
-	typedef int		thread_return;
-	typedef void*	thread_context;
-
-	#define thread_exit() complete_and_exit(NULL, 0)
-
-	typedef void timer_hdl_return;
-	typedef void* timer_hdl_context;
-
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2,5,41))
-	typedef struct work_struct _workitem;
-#else
-	typedef struct tq_struct _workitem;
-#endif
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,24))
-	#define DMA_BIT_MASK(n) (((n) == 64) ? ~0ULL : ((1ULL<<(n))-1))
-#endif
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,22))
-// Porting from linux kernel, for compatible with old kernel.
-static inline unsigned char *skb_tail_pointer(const struct sk_buff *skb)
-{
-	return skb->tail;
-}
-
-static inline void skb_reset_tail_pointer(struct sk_buff *skb)
-{
-	skb->tail = skb->data;
-}
-
-static inline void skb_set_tail_pointer(struct sk_buff *skb, const int offset)
-{
-	skb->tail = skb->data + offset;
-}
-
-static inline unsigned char *skb_end_pointer(const struct sk_buff *skb)
-{
-	return skb->end;
-}
-#endif
-
-__inline static _list *get_next(_list	*list)
-{
-	return list->next;
-}	
-
-__inline static _list	*get_list_head(_queue	*queue)
-{
-	return (&(queue->queue));
-}
-
-	
-#define LIST_CONTAINOR(ptr, type, member) \
-        ((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))	
-
-        
-__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
-{
-	spin_lock_irqsave(plock, *pirqL);
-}
-
-__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
-{
-	spin_unlock_irqrestore(plock, *pirqL);
-}
-
-__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	spin_lock_irqsave(plock, *pirqL);
-}
-
-__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	spin_unlock_irqrestore(plock, *pirqL);
-}
-
-__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
-{
-	spin_lock_bh(plock);
-}
-
-__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
-{
-	spin_unlock_bh(plock);
-}
-
-__inline static int _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
-{
-	int ret = 0;
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-	//mutex_lock(pmutex);
-	ret = mutex_lock_interruptible(pmutex);
-#else
-	ret = down_interruptible(pmutex);
-#endif
-	return ret;
-}
-
-
-__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-		mutex_unlock(pmutex);
-#else
-		up(pmutex);
-#endif
-}
-
-__inline static void rtw_list_delete(_list *plist)
-{
-	list_del_init(plist);
-}
-
-#define RTW_TIMER_HDL_ARGS void *FunctionContext
-
-__inline static void _init_timer(_timer *ptimer,_nic_hdl nic_hdl,void *pfunc,void* cntx)
-{
-	//setup_timer(ptimer, pfunc,(u32)cntx);	
-	ptimer->function = pfunc;
-	ptimer->data = (unsigned long)cntx;
-	init_timer(ptimer);
-}
-
-__inline static void _set_timer(_timer *ptimer,u32 delay_time)
-{	
-	mod_timer(ptimer , (jiffies+(delay_time*HZ/1000)));	
-}
-
-__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)
-{
-	del_timer_sync(ptimer); 	
-	*bcancelled = 1;
-}
-
-
-static inline void _init_workitem(_workitem *pwork, void *pfunc, void *cntx)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,20))
-	INIT_WORK(pwork, pfunc);
-#elif (LINUX_VERSION_CODE > KERNEL_VERSION(2,5,41))
-	INIT_WORK(pwork, pfunc,pwork);
-#else
-	INIT_TQUEUE(pwork, pfunc,pwork);
-#endif
-}
-
-__inline static void _set_workitem(_workitem *pwork)
-{
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2,5,41))
-	schedule_work(pwork);
-#else
-	schedule_task(pwork);
-#endif
-}
-
-__inline static void _cancel_workitem_sync(_workitem *pwork)
-{
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,22))
-	cancel_work_sync(pwork);
-#elif (LINUX_VERSION_CODE > KERNEL_VERSION(2,5,41))
-	flush_scheduled_work();
-#else
-	flush_scheduled_tasks();
-#endif
-}
-//
-// Global Mutex: can only be used at PASSIVE level.
-//
-
-#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-	while (atomic_inc_return((atomic_t *)&(_MutexCounter)) != 1)\
-	{                                                           \
-		atomic_dec((atomic_t *)&(_MutexCounter));        \
-		msleep(10);                          \
-	}                                                           \
-}
-
-#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-	atomic_dec((atomic_t *)&(_MutexCounter));        \
-}
-
-static inline int rtw_netif_queue_stopped(struct net_device *pnetdev)
-{
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
-	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)) );
-#else
-	return netif_queue_stopped(pnetdev);
-#endif
-}
-
-static inline void rtw_netif_wake_queue(struct net_device *pnetdev)
-{
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
-	netif_tx_wake_all_queues(pnetdev);
-#else
-	netif_wake_queue(pnetdev);
-#endif
-}
-
-static inline void rtw_netif_start_queue(struct net_device *pnetdev)
-{
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
-	netif_tx_start_all_queues(pnetdev);
-#else
-	netif_start_queue(pnetdev);
-#endif
-}
-
-static inline void rtw_netif_stop_queue(struct net_device *pnetdev)
-{
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
-	netif_tx_stop_all_queues(pnetdev);
-#else
-	netif_stop_queue(pnetdev);
-#endif
-}
-
-static inline int rtw_merge_string(char *dst, int dst_len, const char *src1, const char *src2)
-{
-	int	len = 0;
-	len += snprintf(dst + len, dst_len - len, "%s", src1);
-	len += snprintf(dst + len, dst_len - len, "%s", src2);
-
-	return len;
-}
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27))
-#define rtw_signal_process(pid, sig) kill_pid(find_vpid((pid)),(sig), 1)
-#else //(LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27))
-#define rtw_signal_process(pid, sig) kill_proc((pid), (sig), 1)
-#endif //(LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27))
-
-
-// Suspend lock prevent system from going suspend
-#ifdef CONFIG_WAKELOCK
-#include <linux/wakelock.h>
-#elif defined(CONFIG_ANDROID_POWER)
-#include <linux/android_power.h>
-#endif
-
-// limitation of path length
-#define PATH_LENGTH_MAX PATH_MAX
-
-//Atomic integer operations
-#define ATOMIC_T atomic_t
-
-#define rtw_netdev_priv(netdev) ( ((struct rtw_netdev_priv_indicator *)netdev_priv(netdev))->priv )
-
-#define NDEV_FMT "%s"
-#define NDEV_ARG(ndev) ndev->name
-#define ADPT_FMT "%s"
-#define ADPT_ARG(adapter) adapter->pnetdev->name
-#define FUNC_NDEV_FMT "%s(%s)"
-#define FUNC_NDEV_ARG(ndev) __func__, ndev->name
-#define FUNC_ADPT_FMT "%s(%s)"
-#define FUNC_ADPT_ARG(adapter) __func__, adapter->pnetdev->name
-
-struct rtw_netdev_priv_indicator {
-	void *priv;
-	u32 sizeof_priv;
-};
-struct net_device *rtw_alloc_etherdev_with_old_priv(int sizeof_priv, void *old_priv);
-extern struct net_device * rtw_alloc_etherdev(int sizeof_priv);
-
-#define STRUCT_PACKED __attribute__ ((packed))
-
-
-#endif
-
+	/*	#include <linux/ieee80211.h> */
+	#include <net/cfg80211.h>
+#endif /* CONFIG_IOCTL_CFG80211 */
+
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+	#include <linux/in.h>
+	#include <linux/udp.h>
+#endif
+
+#ifdef CONFIG_HAS_EARLYSUSPEND
+	#include <linux/earlysuspend.h>
+#endif /* CONFIG_HAS_EARLYSUSPEND */
+
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+	#include <linux/fs.h>
+#endif
+
+#ifdef CONFIG_USB_HCI
+	#include <linux/usb.h>
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 21))
+		#include <linux/usb_ch9.h>
+	#else
+		#include <linux/usb/ch9.h>
+	#endif
+#endif
+
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+	#include <net/sock.h>
+	#include <net/tcp.h>
+	#include <linux/udp.h>
+	#include <linux/in.h>
+	#include <linux/netlink.h>
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+#ifdef CONFIG_USB_HCI
+	typedef struct urb   *PURB;
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22))
+		#ifdef CONFIG_USB_SUSPEND
+			#define CONFIG_AUTOSUSPEND	1
+		#endif
+	#endif
+#endif
+
+#if defined(CONFIG_RTW_GRO) && (!defined(CONFIG_RTW_NAPI))
+
+	#error "Enable NAPI before enable GRO\n"
+
+#endif
+
+
+#if (KERNEL_VERSION(2, 6, 29) > LINUX_VERSION_CODE && defined(CONFIG_RTW_NAPI))
+
+	#undef CONFIG_RTW_NAPI
+	/*#warning "Linux Kernel version too old to support NAPI (should newer than 2.6.29)\n"*/
+
+#endif
+
+#if (KERNEL_VERSION(2, 6, 33) > LINUX_VERSION_CODE && defined(CONFIG_RTW_GRO))
+
+	#undef CONFIG_RTW_GRO
+	/*#warning "Linux Kernel version too old to support GRO(should newer than 2.6.33)\n"*/
+
+#endif
+
+typedef struct	semaphore _sema;
+typedef	spinlock_t	_lock;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	typedef struct mutex		_mutex;
+#else
+	typedef struct semaphore	_mutex;
+#endif
+struct rtw_timer_list {
+	struct timer_list timer;
+	void (*function)(void *);
+	void *arg;
+};
+
+typedef struct rtw_timer_list _timer;
+typedef struct completion _completion;
+
+struct	__queue	{
+	struct	list_head	queue;
+	_lock	lock;
+};
+
+typedef	struct sk_buff	_pkt;
+typedef unsigned char	_buffer;
+
+typedef struct	__queue	_queue;
+typedef struct	list_head	_list;
+
+/* hlist */
+typedef struct	hlist_head	rtw_hlist_head;
+typedef struct	hlist_node	rtw_hlist_node;
+
+/* RCU */
+typedef struct rcu_head rtw_rcu_head;
+#define rtw_rcu_dereference(p) rcu_dereference((p))
+#define rtw_rcu_dereference_protected(p, c) rcu_dereference_protected(p, c)
+#define rtw_rcu_assign_pointer(p, v) rcu_assign_pointer((p), (v))
+#define rtw_rcu_read_lock() rcu_read_lock()
+#define rtw_rcu_read_unlock() rcu_read_unlock()
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34))
+#define rtw_rcu_access_pointer(p) rcu_access_pointer(p)
+#endif
+
+/* rhashtable */
+#include "../os_dep/linux/rtw_rhashtable.h"
+
+typedef	int	_OS_STATUS;
+/* typedef u32	_irqL; */
+typedef unsigned long _irqL;
+typedef	struct	net_device *_nic_hdl;
+
+typedef void		*_thread_hdl_;
+typedef int		thread_return;
+typedef void	*thread_context;
+
+typedef void timer_hdl_return;
+typedef void *timer_hdl_context;
+
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	typedef struct work_struct _workitem;
+#else
+	typedef struct tq_struct _workitem;
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+	#define DMA_BIT_MASK(n) (((n) == 64) ? ~0ULL : ((1ULL<<(n))-1))
+#endif
+
+typedef unsigned long systime;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 22))
+/* Porting from linux kernel, for compatible with old kernel. */
+static inline unsigned char *skb_tail_pointer(const struct sk_buff *skb)
+{
+	return skb->tail;
+}
+
+static inline void skb_reset_tail_pointer(struct sk_buff *skb)
+{
+	skb->tail = skb->data;
+}
+
+static inline void skb_set_tail_pointer(struct sk_buff *skb, const int offset)
+{
+	skb->tail = skb->data + offset;
+}
+
+static inline unsigned char *skb_end_pointer(const struct sk_buff *skb)
+{
+	return skb->end;
+}
+#endif
+
+__inline static void rtw_list_delete(_list *plist)
+{
+	list_del_init(plist);
+}
+
+__inline static _list *get_next(_list	*list)
+{
+	return list->next;
+}
+
+#define LIST_CONTAINOR(ptr, type, member) \
+	((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))
+
+#define rtw_list_first_entry(ptr, type, member) list_first_entry(ptr, type, member)
+
+#define rtw_hlist_for_each_entry(pos, head, member) hlist_for_each_entry(pos, head, member)
+#define rtw_hlist_for_each_safe(pos, n, head) hlist_for_each_safe(pos, n, head)
+#define rtw_hlist_entry(ptr, type, member) hlist_entry(ptr, type, member)
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+#define rtw_hlist_for_each_entry_safe(pos, np, n, head, member) hlist_for_each_entry_safe(pos, n, head, member)
+#define rtw_hlist_for_each_entry_rcu(pos, node, head, member) hlist_for_each_entry_rcu(pos, head, member)
+#else
+#define rtw_hlist_for_each_entry_safe(pos, np, n, head, member) hlist_for_each_entry_safe(pos, np, n, head, member)
+#define rtw_hlist_for_each_entry_rcu(pos, node, head, member) hlist_for_each_entry_rcu(pos, node, head, member)
+#endif
+
+__inline static void _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_irqsave(plock, *pirqL);
+}
+
+__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_irqrestore(plock, *pirqL);
+}
+
+__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_lock_bh(plock);
+}
+
+__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	spin_unlock_bh(plock);
+}
+
+__inline static void enter_critical_bh(_lock *plock)
+{
+	spin_lock_bh(plock);
+}
+
+__inline static void exit_critical_bh(_lock *plock)
+{
+	spin_unlock_bh(plock);
+}
+
+__inline static int _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+	int ret = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	/* mutex_lock(pmutex); */
+	ret = mutex_lock_interruptible(pmutex);
+#else
+	ret = down_interruptible(pmutex);
+#endif
+	return ret;
+}
+
+
+__inline static int _enter_critical_mutex_lock(_mutex *pmutex, _irqL *pirqL)
+{
+	int ret = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	mutex_lock(pmutex);
+#else
+	down(pmutex);
+#endif
+	return ret;
+}
+
+__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	mutex_unlock(pmutex);
+#else
+	up(pmutex);
+#endif
+}
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return &(queue->queue);
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+static inline void timer_hdl(struct timer_list *in_timer)
+#else
+static inline void timer_hdl(unsigned long cntx)
+#endif
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+	_timer *ptimer = from_timer(ptimer, in_timer, timer);
+#else
+	_timer *ptimer = (_timer *)cntx;
+#endif
+	ptimer->function(ptimer->arg);
+}
+
+__inline static void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+	timer_setup(&ptimer->timer, timer_hdl, 0);
+#else
+	/* setup_timer(ptimer, pfunc,(u32)cntx);	 */
+	ptimer->timer.function = timer_hdl;
+	ptimer->timer.data = (unsigned long)ptimer;
+	init_timer(&ptimer->timer);
+#endif
+}
+
+__inline static void _set_timer(_timer *ptimer, u32 delay_time)
+{
+	mod_timer(&ptimer->timer , (jiffies + (delay_time * HZ / 1000)));
+}
+
+__inline static void _cancel_timer(_timer *ptimer, u8 *bcancelled)
+{
+	*bcancelled = del_timer_sync(&ptimer->timer) == 1 ? 1 : 0;
+}
+
+static inline void _init_workitem(_workitem *pwork, void *pfunc, void *cntx)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
+	INIT_WORK(pwork, pfunc);
+#elif (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	INIT_WORK(pwork, pfunc, pwork);
+#else
+	INIT_TQUEUE(pwork, pfunc, pwork);
+#endif
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	schedule_work(pwork);
+#else
+	schedule_task(pwork);
+#endif
+}
+
+__inline static void _cancel_workitem_sync(_workitem *pwork)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22))
+	cancel_work_sync(pwork);
+#elif (LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 41))
+	flush_scheduled_work();
+#else
+	flush_scheduled_tasks();
+#endif
+}
+/*
+ * Global Mutex: can only be used at PASSIVE level.
+ *   */
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+	{                                                               \
+		while (atomic_inc_return((atomic_t *)&(_MutexCounter)) != 1) { \
+			atomic_dec((atomic_t *)&(_MutexCounter));        \
+			msleep(10);                          \
+		}                                                           \
+	}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+	{                                                               \
+		atomic_dec((atomic_t *)&(_MutexCounter));        \
+	}
+
+static inline int rtw_netif_queue_stopped(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	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)));
+#else
+	return netif_queue_stopped(pnetdev);
+#endif
+}
+
+static inline void rtw_netif_wake_queue(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	netif_tx_wake_all_queues(pnetdev);
+#else
+	netif_wake_queue(pnetdev);
+#endif
+}
+
+static inline void rtw_netif_start_queue(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	netif_tx_start_all_queues(pnetdev);
+#else
+	netif_start_queue(pnetdev);
+#endif
+}
+
+static inline void rtw_netif_stop_queue(struct net_device *pnetdev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	netif_tx_stop_all_queues(pnetdev);
+#else
+	netif_stop_queue(pnetdev);
+#endif
+}
+static inline void rtw_netif_device_attach(struct net_device *pnetdev)
+{
+	netif_device_attach(pnetdev);
+}
+static inline void rtw_netif_device_detach(struct net_device *pnetdev)
+{
+	netif_device_detach(pnetdev);
+}
+static inline void rtw_netif_carrier_on(struct net_device *pnetdev)
+{
+	netif_carrier_on(pnetdev);
+}
+static inline void rtw_netif_carrier_off(struct net_device *pnetdev)
+{
+	netif_carrier_off(pnetdev);
+}
+
+static inline int rtw_merge_string(char *dst, int dst_len, const char *src1, const char *src2)
+{
+	int	len = 0;
+	len += snprintf(dst + len, dst_len - len, "%s", src1);
+	len += snprintf(dst + len, dst_len - len, "%s", src2);
+
+	return len;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27))
+	#define rtw_signal_process(pid, sig) kill_pid(find_vpid((pid)), (sig), 1)
+#else /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27)) */
+	#define rtw_signal_process(pid, sig) kill_proc((pid), (sig), 1)
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27)) */
+
+
+/* Suspend lock prevent system from going suspend */
+#ifdef CONFIG_WAKELOCK
+	#include <linux/wakelock.h>
+#elif defined(CONFIG_ANDROID_POWER)
+	#include <linux/android_power.h>
+#endif
+
+/* limitation of path length */
+#define PATH_LENGTH_MAX PATH_MAX
+
+/* Atomic integer operations */
+#define ATOMIC_T atomic_t
+
+#define rtw_netdev_priv(netdev) (((struct rtw_netdev_priv_indicator *)netdev_priv(netdev))->priv)
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ndev->name
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) (adapter->pnetdev ? adapter->pnetdev->name : NULL)
+#define FUNC_NDEV_FMT "%s(%s)"
+#define FUNC_NDEV_ARG(ndev) __func__, ndev->name
+#define FUNC_ADPT_FMT "%s(%s)"
+#define FUNC_ADPT_ARG(adapter) __func__, (adapter->pnetdev ? adapter->pnetdev->name : NULL)
+
+struct rtw_netdev_priv_indicator {
+	void *priv;
+	u32 sizeof_priv;
+};
+struct net_device *rtw_alloc_etherdev_with_old_priv(int sizeof_priv, void *old_priv);
+extern struct net_device *rtw_alloc_etherdev(int sizeof_priv);
+
+#define STRUCT_PACKED __attribute__ ((packed))
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_xp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_xp.h
index 45d54af1f3be..46cc0638665b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_xp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/osdep_service_xp.h
@@ -1,202 +1,211 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __OSDEP_LINUX_SERVICE_H_
-#define __OSDEP_LINUX_SERVICE_H_
-
-	#include <ndis.h>
-	#include <ntddk.h>
-	#include <ntddndis.h>
-	#include <ntdef.h>
-
-#ifdef CONFIG_USB_HCI
-	#include <usb.h>
-	#include <usbioctl.h>
-	#include <usbdlib.h>
-#endif
-
-	typedef KSEMAPHORE 	_sema;
-	typedef	LIST_ENTRY	_list;
-	typedef NDIS_STATUS _OS_STATUS;
-	
-
-	typedef NDIS_SPIN_LOCK	_lock;
-
-	typedef KMUTEX 			_mutex;
-
-	typedef KIRQL	_irqL;
-
-	// USB_PIPE for WINCE , but handle can be use just integer under windows
-	typedef NDIS_HANDLE  _nic_hdl;
-
-
-	typedef NDIS_MINIPORT_TIMER    _timer;
-
-	struct	__queue	{
-		LIST_ENTRY	queue;	
-		_lock	lock;
-	};
-
-	typedef	NDIS_PACKET	_pkt;
-	typedef NDIS_BUFFER	_buffer;
-	typedef struct	__queue	_queue;
-	
-	typedef PKTHREAD _thread_hdl_;
-	typedef void	thread_return;
-	typedef void* thread_context;
-
-	typedef NDIS_WORK_ITEM _workitem;
-
-	#define thread_exit() PsTerminateSystemThread(STATUS_SUCCESS);
-
-	#define HZ			10000000
-	#define SEMA_UPBND	(0x7FFFFFFF)   //8192
-	
-__inline static _list *get_next(_list	*list)
-{
-	return list->Flink;
-}	
-
-__inline static _list	*get_list_head(_queue	*queue)
-{
-	return (&(queue->queue));
-}
-	
-
-#define LIST_CONTAINOR(ptr, type, member) CONTAINING_RECORD(ptr, type, member)
-     
-
-__inline static _enter_critical(_lock *plock, _irqL *pirqL)
-{
-	NdisAcquireSpinLock(plock);	
-}
-
-__inline static _exit_critical(_lock *plock, _irqL *pirqL)
-{
-	NdisReleaseSpinLock(plock);	
-}
-
-
-__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	NdisDprAcquireSpinLock(plock);	
-}
-
-__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)
-{
-	NdisDprReleaseSpinLock(plock);	
-}
-
-__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
-{
-	NdisDprAcquireSpinLock(plock);
-}
-
-__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
-{
-	NdisDprReleaseSpinLock(plock);
-}
-
-__inline static _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
-{
-	KeWaitForSingleObject(pmutex, Executive, KernelMode, FALSE, NULL);
-}
-
-
-__inline static _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
-{
-	KeReleaseMutex(pmutex, FALSE);
-}
-
-
-__inline static void rtw_list_delete(_list *plist)
-{
-	RemoveEntryList(plist);
-	InitializeListHead(plist);	
-}
-
-#define RTW_TIMER_HDL_ARGS IN PVOID SystemSpecific1, IN PVOID FunctionContext, IN PVOID SystemSpecific2, IN PVOID SystemSpecific3
-
-__inline static void _init_timer(_timer *ptimer,_nic_hdl nic_hdl,void *pfunc,PVOID cntx)
-{
-	NdisMInitializeTimer(ptimer, nic_hdl, pfunc, cntx);
-}
-
-__inline static void _set_timer(_timer *ptimer,u32 delay_time)
-{	
- 	NdisMSetTimer(ptimer,delay_time);	
-}
-
-__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)
-{
-	NdisMCancelTimer(ptimer,bcancelled);
-}
-
-__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
-{
-
-	NdisInitializeWorkItem(pwork, pfunc, cntx);
-}
-
-__inline static void _set_workitem(_workitem *pwork)
-{
-	NdisScheduleWorkItem(pwork);
-}
-
-
-#define ATOMIC_INIT(i)  { (i) }
-
-//
-// Global Mutex: can only be used at PASSIVE level.
-//
-
-#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-    while (NdisInterlockedIncrement((PULONG)&(_MutexCounter)) != 1)\
-    {                                                           \
-        NdisInterlockedDecrement((PULONG)&(_MutexCounter));        \
-        NdisMSleep(10000);                          \
-    }                                                           \
-}
-
-#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
-{                                                               \
-    NdisInterlockedDecrement((PULONG)&(_MutexCounter));              \
-}
-
-// limitation of path length
-#define PATH_LENGTH_MAX MAX_PATH
-
-//Atomic integer operations
-#define ATOMIC_T LONG
-
-
-#define NDEV_FMT "%s"
-#define NDEV_ARG(ndev) ""
-#define ADPT_FMT "%s"
-#define ADPT_ARG(adapter) ""
-#define FUNC_NDEV_FMT "%s"
-#define FUNC_NDEV_ARG(ndev) __func__
-#define FUNC_ADPT_FMT "%s"
-#define FUNC_ADPT_ARG(adapter) __func__
-
-#define STRUCT_PACKED
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_LINUX_SERVICE_H_
+#define __OSDEP_LINUX_SERVICE_H_
+
+	#include <ndis.h>
+	#include <ntddk.h>
+	#include <ntddndis.h>
+	#include <ntdef.h>
+
+#ifdef CONFIG_USB_HCI
+	#include <usb.h>
+	#include <usbioctl.h>
+	#include <usbdlib.h>
+#endif
+
+	typedef KSEMAPHORE 	_sema;
+	typedef	LIST_ENTRY	_list;
+	typedef NDIS_STATUS _OS_STATUS;
+	
+
+	typedef NDIS_SPIN_LOCK	_lock;
+
+	typedef KMUTEX 			_mutex;
+
+	typedef KIRQL	_irqL;
+
+	// USB_PIPE for WINCE , but handle can be use just integer under windows
+	typedef NDIS_HANDLE  _nic_hdl;
+
+	struct rtw_timer_list {
+		NDIS_MINIPORT_TIMER ndis_timer;
+		void (*function)(void *);
+		void *arg;
+	};
+
+	struct	__queue	{
+		LIST_ENTRY	queue;	
+		_lock	lock;
+	};
+
+	typedef	NDIS_PACKET	_pkt;
+	typedef NDIS_BUFFER	_buffer;
+	typedef struct	__queue	_queue;
+	
+	typedef PKTHREAD _thread_hdl_;
+	typedef void	thread_return;
+	typedef void* thread_context;
+
+	typedef NDIS_WORK_ITEM _workitem;
+
+
+	#define HZ			10000000
+	#define SEMA_UPBND	(0x7FFFFFFF)   //8192
+	
+__inline static _list *get_next(_list	*list)
+{
+	return list->Flink;
+}	
+
+__inline static _list	*get_list_head(_queue	*queue)
+{
+	return (&(queue->queue));
+}
+	
+
+#define LIST_CONTAINOR(ptr, type, member) CONTAINING_RECORD(ptr, type, member)
+     
+
+__inline static _enter_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisAcquireSpinLock(plock);	
+}
+
+__inline static _exit_critical(_lock *plock, _irqL *pirqL)
+{
+	NdisReleaseSpinLock(plock);	
+}
+
+
+__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprAcquireSpinLock(plock);	
+}
+
+__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)
+{
+	NdisDprReleaseSpinLock(plock);	
+}
+
+__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	NdisDprAcquireSpinLock(plock);
+}
+
+__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
+{
+	NdisDprReleaseSpinLock(plock);
+}
+
+__inline static _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+	KeWaitForSingleObject(pmutex, Executive, KernelMode, FALSE, NULL);
+}
+
+
+__inline static _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
+{
+	KeReleaseMutex(pmutex, FALSE);
+}
+
+
+__inline static void rtw_list_delete(_list *plist)
+{
+	RemoveEntryList(plist);
+	InitializeListHead(plist);	
+}
+
+static inline void timer_hdl(
+	IN PVOID SystemSpecific1,
+	IN PVOID FunctionContext,
+	IN PVOID SystemSpecific2,
+	IN PVOID SystemSpecific3)
+{
+	_timer *timer = (_timer *)FunctionContext;
+
+	timer->function(timer->arg);
+}
+
+static inline void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)
+{
+	ptimer->function = pfunc;
+	ptimer->arg = cntx;
+	NdisMInitializeTimer(&ptimer->ndis_timer, nic_hdl, timer_hdl, ptimer);
+}
+
+static inline void _set_timer(_timer *ptimer, u32 delay_time)
+{
+	NdisMSetTimer(ptimer, delay_time);
+}
+
+static inline void _cancel_timer(_timer *ptimer, u8 *bcancelled)
+{
+	NdisMCancelTimer(ptimer, bcancelled);
+}
+
+__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)
+{
+
+	NdisInitializeWorkItem(pwork, pfunc, cntx);
+}
+
+__inline static void _set_workitem(_workitem *pwork)
+{
+	NdisScheduleWorkItem(pwork);
+}
+
+
+#define ATOMIC_INIT(i)  { (i) }
+
+//
+// Global Mutex: can only be used at PASSIVE level.
+//
+
+#define ACQUIRE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    while (NdisInterlockedIncrement((PULONG)&(_MutexCounter)) != 1)\
+    {                                                           \
+        NdisInterlockedDecrement((PULONG)&(_MutexCounter));        \
+        NdisMSleep(10000);                          \
+    }                                                           \
+}
+
+#define RELEASE_GLOBAL_MUTEX(_MutexCounter)                              \
+{                                                               \
+    NdisInterlockedDecrement((PULONG)&(_MutexCounter));              \
+}
+
+// limitation of path length
+#define PATH_LENGTH_MAX MAX_PATH
+
+//Atomic integer operations
+#define ATOMIC_T LONG
+
+
+#define NDEV_FMT "%s"
+#define NDEV_ARG(ndev) ""
+#define ADPT_FMT "%s"
+#define ADPT_ARG(adapter) ""
+#define FUNC_NDEV_FMT "%s"
+#define FUNC_NDEV_ARG(ndev) __func__
+#define FUNC_ADPT_FMT "%s"
+#define FUNC_ADPT_ARG(adapter) __func__
+
+#define STRUCT_PACKED
+
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_hal.h
index 00157707c7e5..b45c87611430 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_hal.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,36 +12,38 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __PCI_HAL_H__
 #define __PCI_HAL_H__
 
 #ifdef CONFIG_RTL8188E
-void rtl8188ee_set_hal_ops(_adapter *padapter);
+	void rtl8188ee_set_hal_ops(_adapter *padapter);
 #endif
 
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-void rtl8812ae_set_hal_ops(_adapter *padapter);
+	void rtl8812ae_set_hal_ops(_adapter *padapter);
 #endif
 
 #if defined(CONFIG_RTL8192E)
-void rtl8192ee_set_hal_ops(_adapter *padapter);
+	void rtl8192ee_set_hal_ops(_adapter *padapter);
 #endif
 
 #ifdef CONFIG_RTL8723B
-void rtl8723be_set_hal_ops(_adapter *padapter);
+	void rtl8723be_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	void rtl8723de_set_hal_ops(_adapter *padapter);
 #endif
 
 #ifdef CONFIG_RTL8814A
-void rtl8814ae_set_hal_ops(_adapter *padapter);
+	void rtl8814ae_set_hal_ops(_adapter *padapter);
 #endif
 
-u8 rtw_set_hal_ops(_adapter *padapter);
+#ifdef CONFIG_RTL8822B
+	void rtl8822be_set_hal_ops(PADAPTER padapter);
+#endif
 
-#endif //__PCIE_HAL_H__
+u8 rtw_set_hal_ops(_adapter *padapter);
 
+#endif /* __PCIE_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_ops.h
index 07add16848bb..23ccc6ffe31a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_ops.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,68 +12,81 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __PCI_OPS_H_
 #define __PCI_OPS_H_
 
 
 #ifdef CONFIG_RTL8188E
-u32	rtl8188ee_init_desc_ring(_adapter *padapter);
-u32	rtl8188ee_free_desc_ring(_adapter *padapter);
-void	rtl8188ee_reset_desc_ring(_adapter *padapter);
-int	rtl8188ee_interrupt(PADAPTER Adapter);
-void	rtl8188ee_xmit_tasklet(void *priv);
-void	rtl8188ee_recv_tasklet(void *priv);
-void	rtl8188ee_prepare_bcn_tasklet(void *priv);
-void	rtl8188ee_set_intf_ops(struct _io_ops	*pops);
+	u32	rtl8188ee_init_desc_ring(_adapter *padapter);
+	u32	rtl8188ee_free_desc_ring(_adapter *padapter);
+	void	rtl8188ee_reset_desc_ring(_adapter *padapter);
+	int	rtl8188ee_interrupt(PADAPTER Adapter);
+	void	rtl8188ee_xmit_tasklet(void *priv);
+	void	rtl8188ee_recv_tasklet(void *priv);
+	void	rtl8188ee_prepare_bcn_tasklet(void *priv);
+	void	rtl8188ee_set_intf_ops(struct _io_ops	*pops);
 #endif
 
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-u32	rtl8812ae_init_desc_ring(_adapter *padapter);
-u32	rtl8812ae_free_desc_ring(_adapter *padapter);
-void	rtl8812ae_reset_desc_ring(_adapter *padapter);
-int	rtl8812ae_interrupt(PADAPTER Adapter);
-void	rtl8812ae_xmit_tasklet(void *priv);
-void	rtl8812ae_recv_tasklet(void *priv);
-void	rtl8812ae_prepare_bcn_tasklet(void *priv);
-void	rtl8812ae_set_intf_ops(struct _io_ops	*pops);
+	u32	rtl8812ae_init_desc_ring(_adapter *padapter);
+	u32	rtl8812ae_free_desc_ring(_adapter *padapter);
+	void	rtl8812ae_reset_desc_ring(_adapter *padapter);
+	int	rtl8812ae_interrupt(PADAPTER Adapter);
+	void	rtl8812ae_xmit_tasklet(void *priv);
+	void	rtl8812ae_recv_tasklet(void *priv);
+	void	rtl8812ae_prepare_bcn_tasklet(void *priv);
+	void	rtl8812ae_set_intf_ops(struct _io_ops	*pops);
 #endif
 
 #ifdef CONFIG_RTL8192E
-u32	rtl8192ee_init_desc_ring(_adapter *padapter);
-u32	rtl8192ee_free_desc_ring(_adapter *padapter);
-void	rtl8192ee_reset_desc_ring(_adapter *padapter);
-void	rtl8192ee_recv_tasklet(void *priv);
-void	rtl8192ee_prepare_bcn_tasklet(void *priv);
-int	rtl8192ee_interrupt(PADAPTER Adapter);
-void	rtl8192ee_set_intf_ops(struct _io_ops	*pops);
+	u32	rtl8192ee_init_desc_ring(_adapter *padapter);
+	u32	rtl8192ee_free_desc_ring(_adapter *padapter);
+	void	rtl8192ee_reset_desc_ring(_adapter *padapter);
+	void	rtl8192ee_recv_tasklet(void *priv);
+	void	rtl8192ee_prepare_bcn_tasklet(void *priv);
+	int	rtl8192ee_interrupt(PADAPTER Adapter);
+	void	rtl8192ee_set_intf_ops(struct _io_ops	*pops);
 #endif
 
 #ifdef CONFIG_RTL8723B
-u32	rtl8723be_init_desc_ring(_adapter *padapter);
-u32	rtl8723be_free_desc_ring(_adapter *padapter);
-void	rtl8723be_reset_desc_ring(_adapter *padapter);
-int	rtl8723be_interrupt(PADAPTER Adapter);
-void	rtl8723be_recv_tasklet(void *priv);
-void	rtl8723be_prepare_bcn_tasklet(void *priv);
-void	rtl8723be_set_intf_ops(struct _io_ops	*pops);
+	u32	rtl8723be_init_desc_ring(_adapter *padapter);
+	u32	rtl8723be_free_desc_ring(_adapter *padapter);
+	void	rtl8723be_reset_desc_ring(_adapter *padapter);
+	int	rtl8723be_interrupt(PADAPTER Adapter);
+	void	rtl8723be_recv_tasklet(void *priv);
+	void	rtl8723be_prepare_bcn_tasklet(void *priv);
+	void	rtl8723be_set_intf_ops(struct _io_ops	*pops);
+#endif
+
+#ifdef CONFIG_RTL8723D
+	u32	rtl8723de_init_desc_ring(_adapter *padapter);
+	u32	rtl8723de_free_desc_ring(_adapter *padapter);
+	void	rtl8723de_reset_desc_ring(_adapter *padapter);
+	int	rtl8723de_interrupt(PADAPTER Adapter);
+	void	rtl8723de_recv_tasklet(void *priv);
+	void	rtl8723de_prepare_bcn_tasklet(void *priv);
+	void	rtl8723de_set_intf_ops(struct _io_ops	*pops);
+	u8 check_tx_desc_resource(_adapter *padapter, int prio);
 #endif
 
 #ifdef CONFIG_RTL8814A
-u32	rtl8814ae_init_desc_ring(_adapter *padapter);
-u32	rtl8814ae_free_desc_ring(_adapter *padapter);
-void	rtl8814ae_reset_desc_ring(_adapter *padapter);
-int	rtl8814ae_interrupt(PADAPTER Adapter);
-void	rtl8814ae_xmit_tasklet(void *priv);
-void	rtl8814ae_recv_tasklet(void *priv);
-void	rtl8814ae_prepare_bcn_tasklet(void *priv);
-void	rtl8814ae_set_intf_ops(struct _io_ops	*pops);
+	u32	rtl8814ae_init_desc_ring(_adapter *padapter);
+	u32	rtl8814ae_free_desc_ring(_adapter *padapter);
+	void	rtl8814ae_reset_desc_ring(_adapter *padapter);
+	int	rtl8814ae_interrupt(PADAPTER Adapter);
+	void	rtl8814ae_xmit_tasklet(void *priv);
+	void	rtl8814ae_recv_tasklet(void *priv);
+	void	rtl8814ae_prepare_bcn_tasklet(void *priv);
+	void	rtl8814ae_set_intf_ops(struct _io_ops	*pops);
+#endif
+
+#ifdef CONFIG_RTL8822B
+	void rtl8822be_set_intf_ops(struct _io_ops *pops);
 #endif
 
+#ifdef CONFIG_RTL8821C
+	void rtl8821ce_set_intf_ops(struct _io_ops *pops);
 #endif
 
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_osintf.h
index 9df50f733bd4..56d6942277f9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/pci_osintf.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,22 +12,40 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __PCI_OSINTF_H
 #define __PCI_OSINTF_H
 
+#ifdef RTK_129X_PLATFORM
+#define PCIE_SLOT1_MEM_START	0x9804F000
+#define PCIE_SLOT1_MEM_LEN	0x1000
+#define PCIE_SLOT1_CTRL_START	0x9804EC00
+
+#define PCIE_SLOT2_MEM_START	0x9803C000
+#define PCIE_SLOT2_MEM_LEN	0x1000
+#define PCIE_SLOT2_CTRL_START	0x9803BC00
+
+#define PCIE_MASK_OFFSET	0x100 /* mask offset from CTRL_START */
+#define PCIE_TRANSLATE_OFFSET	0x104 /* translate offset from CTRL_START */
+#endif
+
+#define PCI_BC_CLK_REQ		BIT0
+#define PCI_BC_ASPM_L0s		BIT1
+#define PCI_BC_ASPM_L1		BIT2
+#define PCI_BC_ASPM_L1Off	BIT3
+//#define PCI_BC_ASPM_LTR	BIT4
+//#define PCI_BC_ASPM_OBFF	BIT5
 
 void	rtw_pci_disable_aspm(_adapter *padapter);
 void	rtw_pci_enable_aspm(_adapter *padapter);
 void	PlatformClearPciPMEStatus(PADAPTER Adapter);
+void	rtw_pci_aspm_config(_adapter *padapter);
+void	rtw_pci_aspm_config_l1off_general(_adapter *padapter, u8 eanble);
+#ifdef CONFIG_PCI_DYNAMIC_ASPM
+void	rtw_pci_aspm_config_dynamic_l1_ilde_time(_adapter *padapter);
+#endif
 #ifdef CONFIG_64BIT_DMA
-u8	PlatformEnableDMA64(PADAPTER Adapter);
+	u8	PlatformEnableDMA64(PADAPTER Adapter);
 #endif
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/recv_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/recv_osdep.h
index 0a65313ffe9c..7ff484c989b3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/recv_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/recv_osdep.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,34 +12,28 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RECV_OSDEP_H_
 #define __RECV_OSDEP_H_
 
 
 extern sint _rtw_init_recv_priv(struct recv_priv *precvpriv, _adapter *padapter);
-extern void _rtw_free_recv_priv (struct recv_priv *precvpriv);
+extern void _rtw_free_recv_priv(struct recv_priv *precvpriv);
 
 
-extern s32  rtw_recv_entry(union recv_frame *precv_frame);	
+extern s32  rtw_recv_entry(union recv_frame *precv_frame);
+void rtw_rframe_set_os_pkt(union recv_frame *rframe);
 extern int rtw_recv_indicatepkt(_adapter *adapter, union recv_frame *precv_frame);
 extern void rtw_recv_returnpacket(IN _nic_hdl cnxt, IN _pkt *preturnedpkt);
 
 extern int rtw_recv_monitor(_adapter *padapter, union recv_frame *precv_frame);
 
+#ifdef CONFIG_HOSTAPD_MLME
 extern void rtw_hostapd_mlme_rx(_adapter *padapter, union recv_frame *precv_frame);
+#endif
 
 struct sta_info;
 extern void rtw_handle_tkip_mic_err(_adapter *padapter, struct sta_info *sta, u8 bgroup);
-		
-
-int	rtw_init_recv_priv(struct recv_priv *precvpriv, _adapter *padapter);
-void rtw_free_recv_priv (struct recv_priv *precvpriv);
 
 
 int rtw_os_recv_resource_init(struct recv_priv *precvpriv, _adapter *padapter);
@@ -47,19 +42,27 @@ void rtw_os_recv_resource_free(struct recv_priv *precvpriv);
 
 
 int rtw_os_alloc_recvframe(_adapter *padapter, union recv_frame *precvframe, u8 *pdata, _pkt *pskb);
+int rtw_os_recvframe_duplicate_skb(_adapter *padapter, union recv_frame *pcloneframe, _pkt *pskb);
 void rtw_os_free_recvframe(union recv_frame *precvframe);
 
 
 int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf);
 int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf);
 
-_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8 *pdata);
-void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, struct rx_pkt_attrib *pattrib);
+_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, const u8 *da, const u8 *sa, u8 *msdu ,u16 msdu_len);
+void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, union recv_frame *rframe);
 
 void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf);
 
-void rtw_init_recv_timer(struct recv_reorder_ctrl *preorder_ctrl);
-
+#ifdef PLATFORM_LINUX
+#ifdef CONFIG_RTW_NAPI
+#include <linux/netdevice.h>	/* struct napi_struct */
 
-#endif //
+int rtw_recv_napi_poll(struct napi_struct *, int budget);
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+void dynamic_napi_th_chk (_adapter *adapter);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#endif /* CONFIG_RTW_NAPI */
+#endif /* PLATFORM_LINUX */
 
+#endif /*  */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_cmd.h
index 9fc2ad6c713d..865896002189 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_cmd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,18 +12,12 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188E_CMD_H__
 #define __RTL8188E_CMD_H__
 
 #if 0
-enum cmd_msg_element_id
-{
+enum cmd_msg_element_id {
 	NONE_CMDMSG_EID,
 	AP_OFFLOAD_EID = 0,
 	SET_PWRMODE_EID = 1,
@@ -35,91 +30,91 @@ enum cmd_msg_element_id
 	P2P_PS_OFFLOAD_EID = 8,
 	SELECTIVE_SUSPEND_ROF_CMD = 9,
 	P2P_PS_CTW_CMD_EID = 32,
-	MAX_CMDMSG_EID	 
+	MAX_CMDMSG_EID
 };
 #else
-typedef enum _RTL8188E_H2C_CMD_ID
-{
-	//Class Common
-	H2C_COM_RSVD_PAGE			=0x00,
-	H2C_COM_MEDIA_STATUS_RPT	=0x01,
-	H2C_COM_SCAN					=0x02,	
-	H2C_COM_KEEP_ALIVE			=0x03,	
-	H2C_COM_DISCNT_DECISION		=0x04,
+typedef enum _RTL8188E_H2C_CMD_ID {
+	/* Class Common */
+	H2C_COM_RSVD_PAGE			= 0x00,
+	H2C_COM_MEDIA_STATUS_RPT	= 0x01,
+	H2C_COM_SCAN					= 0x02,
+	H2C_COM_KEEP_ALIVE			= 0x03,
+	H2C_COM_DISCNT_DECISION		= 0x04,
 #ifndef CONFIG_WOWLAN
-	H2C_COM_WWLAN				=0x05,
+	H2C_COM_WWLAN				= 0x05,
 #endif
-	H2C_COM_INIT_OFFLOAD			=0x06,
-	H2C_COM_REMOTE_WAKE_CTL	=0x07,
-	H2C_COM_AP_OFFLOAD			=0x08,
-	H2C_COM_BCN_RSVD_PAGE		=0x09,
-	H2C_COM_PROB_RSP_RSVD_PAGE	=0x0A,
-
-	//Class PS
-	H2C_PS_PWR_MODE				=0x20,
-	H2C_PS_TUNE_PARA				=0x21,
-	H2C_PS_TUNE_PARA_2			=0x22,
-	H2C_PS_LPS_PARA				=0x23,
-	H2C_PS_P2P_OFFLOAD			=0x24,
-
-	//Class DM
-	H2C_DM_MACID_CFG				=0x40,
-	H2C_DM_TXBF					=0x41,
-	H2C_RSSI_REPORT 				=0x42,
-	//Class BT
-	H2C_BT_COEX_MASK				=0x60,
-	H2C_BT_COEX_GPIO_MODE		=0x61,
-	H2C_BT_DAC_SWING_VAL			=0x62,
-	H2C_BT_PSD_RST				=0x63,
-	
-	//Class Remote WakeUp
+	H2C_COM_INIT_OFFLOAD			= 0x06,
+	H2C_COM_REMOTE_WAKE_CTL	= 0x07,
+	H2C_COM_AP_OFFLOAD			= 0x08,
+	H2C_COM_BCN_RSVD_PAGE		= 0x09,
+	H2C_COM_PROB_RSP_RSVD_PAGE	= 0x0A,
+
+	/* Class PS */
+	H2C_PS_PWR_MODE				= 0x20,
+	H2C_PS_TUNE_PARA				= 0x21,
+	H2C_PS_TUNE_PARA_2			= 0x22,
+	H2C_PS_LPS_PARA				= 0x23,
+	H2C_PS_P2P_OFFLOAD			= 0x24,
+
+	/* Class DM */
+	H2C_DM_MACID_CFG				= 0x40,
+	H2C_DM_TXBF					= 0x41,
+	H2C_RSSI_REPORT				= 0x42,
+	/* Class BT */
+	H2C_BT_COEX_MASK				= 0x60,
+	H2C_BT_COEX_GPIO_MODE		= 0x61,
+	H2C_BT_DAC_SWING_VAL			= 0x62,
+	H2C_BT_PSD_RST				= 0x63,
+
+	/* Class Remote WakeUp */
 #ifdef CONFIG_WOWLAN
-	H2C_COM_WWLAN				=0x80,
-	H2C_COM_REMOTE_WAKE_CTRL	=0x81,
-	H2C_COM_AOAC_GLOBAL_INFO	=0x82,
-	H2C_COM_AOAC_RSVD_PAGE		=0x83,
+	H2C_COM_WWLAN				= 0x80,
+	H2C_COM_REMOTE_WAKE_CTRL	= 0x81,
+	H2C_COM_AOAC_GLOBAL_INFO	= 0x82,
+	H2C_COM_AOAC_RSVD_PAGE		= 0x83,
 #endif
 
-	//Class 
-	 //H2C_RESET_TSF				=0xc0,
-}RTL8188E_H2C_CMD_ID;
-	
+	/* Class */
+	/* H2C_RESET_TSF				=0xc0, */
+} RTL8188E_H2C_CMD_ID;
+
 #endif
 
 
 struct cmd_msg_parm {
-	u8 eid; //element id
-	u8 sz; // sz
+	u8 eid; /* element id */
+	u8 sz; /* sz */
 	u8 buf[6];
 };
 
-enum{
+enum {
 	PWRS
 };
 
 typedef struct _SETPWRMODE_PARM {
-	u8 Mode;//0:Active,1:LPS,2:WMMPS
-	//u8 RLBM:4;//0:Min,1:Max,2: User define
-	u8 SmartPS_RLBM;//LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData
-	u8 AwakeInterval;	// unit: beacon interval
+	u8 Mode;/* 0:Active,1:LPS,2:WMMPS */
+	/* u8 RLBM:4; */ /* 0:Min,1:Max,2: User define */
+	u8 SmartPS_RLBM;/* LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData */
+	u8 AwakeInterval;	/* unit: beacon interval */
 	u8 bAllQueueUAPSD;
-	u8 PwrState;//AllON(0x0c),RFON(0x04),RFOFF(0x00)
+	u8 PwrState;/* AllON(0x0c),RFON(0x04),RFOFF(0x00) */
 } SETPWRMODE_PARM, *PSETPWRMODE_PARM;
 
-struct H2C_SS_RFOFF_PARAM{
-	u8 ROFOn; // 1: on, 0:off
-	u16 gpio_period; // unit: 1024 us
-}__attribute__ ((packed));
+struct H2C_SS_RFOFF_PARAM {
+	u8 ROFOn; /* 1: on, 0:off */
+	u16 gpio_period; /* unit: 1024 us */
+} __attribute__((packed));
 
 
-typedef struct JOINBSSRPT_PARM_88E{
-	u8 OpMode;	// RT_MEDIA_STATUS
+typedef struct JOINBSSRPT_PARM_88E {
+	u8 OpMode;	/* RT_MEDIA_STATUS */
 #ifdef CONFIG_WOWLAN
-	u8 MacID;       // MACID
-#endif //CONFIG_WOWLAN
-}JOINBSSRPT_PARM_88E, *PJOINBSSRPT_PARM_88E;
+	u8 MacID;       /* MACID */
+#endif /* CONFIG_WOWLAN */
+} JOINBSSRPT_PARM_88E, *PJOINBSSRPT_PARM_88E;
 
-/* move to hal_com_h2c.h
+#if 0
+/* move to hal_com_h2c.h */
 typedef struct _RSVDPAGE_LOC_88E {
 	u8 LocProbeRsp;
 	u8 LocPsPoll;
@@ -134,49 +129,39 @@ typedef struct _RSVDPAGE_LOC_88E {
 	u8 LocGTKInfo;
 	u8 LocProbeReq;
 	u8 LocNetList;
-#endif //CONFIG_WOWLAN	
+#endif /* CONFIG_WOWLAN	 */
 } RSVDPAGE_LOC_88E, *PRSVDPAGE_LOC_88E;
-*/
+#endif
 
-// host message to firmware cmd
+/* host message to firmware cmd */
 void rtl8188e_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8188e_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
 u8 rtl8188e_set_rssi_cmd(PADAPTER padapter, u8 *param);
-u8 rtl8188e_set_raid_cmd(_adapter *padapter, u32 bitmap, u8 *arg);
-void rtl8188e_Add_RateATid(PADAPTER padapter, u64 rate_bitmap, u8 *arg, u8 rssi_level);
 s32 FillH2CCmd_88E(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
-//u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period);
+/* u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period); */
 u8 GetTxBufferRsvdPageNum8188E(_adapter *padapter, bool wowlan);
 
 
 #ifdef CONFIG_P2P
-void rtl8188e_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
-#endif //CONFIG_P2P
-
-void CheckFwRsvdPageContent(PADAPTER padapter);
-
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-//u8 rtl8188e_reset_tsf(_adapter *padapter, u8 reset_port);
-int reset_tsf(PADAPTER Adapter, u8 reset_port );
-#endif	// CONFIG_TSF_RESET_OFFLOAD
-
-//#define H2C_8188E_RSVDPAGE_LOC_LEN      5
-//#define H2C_8188E_AOAC_RSVDPAGE_LOC_LEN 7
-
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD CONTENT    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
-//
-/* move to hal_com_h2c.h
-//_RSVDPAGE_LOC_CMD_0x00
-#define SET_8188E_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
-#define SET_8188E_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
-#define SET_8188E_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
-#define SET_8188E_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
-// AOAC_RSVDPAGE_LOC_0x83
-#define SET_8188E_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
-#define SET_8188E_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)                  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
-*/
-#endif//__RTL8188E_CMD_H__
+	void rtl8188e_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
 
+/* #define H2C_8188E_RSVDPAGE_LOC_LEN      5 */
+/* #define H2C_8188E_AOAC_RSVDPAGE_LOC_LEN 7 */
 
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ *   */
+#if 0
+	/* move to hal_com_h2c.h
+	* _RSVDPAGE_LOC_CMD_0x00 */
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+	#define SET_8188E_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)     SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+	/*  AOAC_RSVDPAGE_LOC_0x83 */
+	#define SET_8188E_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 8, __Value)
+	#define SET_8188E_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(__pH2CCmd, __Value)                  SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#endif
+#endif/* __RTL8188E_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_dm.h
index eb97de187378..70ce157f54f3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188E_DM_H__
 #define __RTL8188E_DM_H__
 
@@ -25,13 +21,8 @@ void rtl8188e_deinit_dm_priv(IN PADAPTER Adapter);
 void rtl8188e_InitHalDm(IN PADAPTER Adapter);
 void rtl8188e_HalDmWatchDog(IN PADAPTER Adapter);
 
-//VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter);
+/* VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter); */
 
-//void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal);
+/* void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal); */
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-void	AntDivCompare8188E(PADAPTER Adapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
-u8 AntDivBeforeLink8188E(PADAPTER Adapter );
 #endif
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_hal.h
index 20e7bb4fac2b..d26ebec4b181 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_hal.h
@@ -1,332 +1,320 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8188E_HAL_H__
-#define __RTL8188E_HAL_H__
-
-//#include "hal_com.h"
-#include "hal_data.h"
-
-//include HAL Related header after HAL Related compiling flags 
-#include "rtl8188e_spec.h"
-#include "Hal8188EPhyReg.h"
-#include "Hal8188EPhyCfg.h"
-#include "rtl8188e_rf.h"
-#include "rtl8188e_dm.h"
-#include "rtl8188e_recv.h"
-#include "rtl8188e_xmit.h"
-#include "rtl8188e_cmd.h"
-#include "rtl8188e_led.h"
-#include "Hal8188EPwrSeq.h"
-#ifdef DBG_CONFIG_ERROR_DETECT
-#include "rtl8188e_sreset.h"
-#endif
-
-#if 0
-	// Fw Array
-	#define Rtl8188E_FwImageArray				Rtl8188EFwImgArray
-	#define Rtl8188E_FWImgArrayLength			Rtl8188EFWImgArrayLength
-#ifdef CONFIG_WOWLAN
-	#define Rtl8188E_FwWoWImageArray			Array_MP_8188E_FW_WoWLAN
-	#define Rtl8188E_FwWoWImgArrayLength		ArrayLength_MP_8188E_FW_WoWLAN
-#endif //CONFIG_WOWLAN
-#endif
-
-
-	#define RTL8188E_FW_IMG					"rtl8188e/FW_NIC.bin"
-	#define RTL8188E_FW_WW_IMG				"rtl8188e/FW_WoWLAN.bin"
-	#define RTL8188E_PHY_REG					"rtl8188e/PHY_REG.txt" 
-	#define RTL8188E_PHY_RADIO_A				"rtl8188e/RadioA.txt"
-	#define RTL8188E_PHY_RADIO_B				"rtl8188e/RadioB.txt"
-	#define RTL8188E_TXPWR_TRACK				"rtl8188e/TxPowerTrack.txt"			
-	#define RTL8188E_AGC_TAB					"rtl8188e/AGC_TAB.txt"
-	#define RTL8188E_PHY_MACREG 				"rtl8188e/MAC_REG.txt"
-	#define RTL8188E_PHY_REG_PG				"rtl8188e/PHY_REG_PG.txt"
-	#define RTL8188E_PHY_REG_MP 				"rtl8188e/PHY_REG_MP.txt" 
-	#define RTL8188E_TXPWR_LMT				"rtl8188e/TXPWR_LMT.txt" 
-
-	//---------------------------------------------------------------------
-	//		RTL8188E Power Configuration CMDs for USB/SDIO/PCIE interfaces
-	//---------------------------------------------------------------------
-	#define Rtl8188E_NIC_PWR_ON_FLOW				rtl8188E_power_on_flow
-	#define Rtl8188E_NIC_RF_OFF_FLOW				rtl8188E_radio_off_flow
-	#define Rtl8188E_NIC_DISABLE_FLOW				rtl8188E_card_disable_flow
-	#define Rtl8188E_NIC_ENABLE_FLOW				rtl8188E_card_enable_flow
-	#define Rtl8188E_NIC_SUSPEND_FLOW				rtl8188E_suspend_flow
-	#define Rtl8188E_NIC_RESUME_FLOW				rtl8188E_resume_flow
-	#define Rtl8188E_NIC_PDN_FLOW					rtl8188E_hwpdn_flow
-	#define Rtl8188E_NIC_LPS_ENTER_FLOW			rtl8188E_enter_lps_flow
-	#define Rtl8188E_NIC_LPS_LEAVE_FLOW			rtl8188E_leave_lps_flow
-
-
-#if 1 // download firmware related data structure
-#define MAX_FW_8188E_SIZE			0x8000 //32768,32k / 16384,16k
-
-#define FW_8188E_SIZE				0x4000 //16384,16k
-#define FW_8188E_SIZE_2			0x8000 //32768,32k 
-
-#define FW_8188E_START_ADDRESS	0x1000
-#define FW_8188E_END_ADDRESS		0x1FFF //0x5FFF
-
-
-#define IS_FW_HEADER_EXIST_88E(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature)&0xFFF0) == 0x88E0)
-
-typedef struct _RT_FIRMWARE_8188E {
-	FIRMWARE_SOURCE	eFWSource;
-#ifdef CONFIG_EMBEDDED_FWIMG
-	u8*			szFwBuffer;
-#else
-	u8			szFwBuffer[MAX_FW_8188E_SIZE];
-#endif
-	u32			ulFwLength;
-} RT_FIRMWARE_8188E, *PRT_FIRMWARE_8188E;
-
-//
-// This structure must be cared byte-ordering
-//
-
-typedef struct _RT_8188E_FIRMWARE_HDR
-{
-	// 8-byte alinment required
-
-	//--- LONG WORD 0 ----
-	u16		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
-	u16		Version;		// FW Version
-	u8		Subversion;	// FW Subversion, default 0x00
-	u16		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
-	u16		RamCodeSize;	// The size of RAM code
-	u8		Foundry;
-	u8		Rsvd2;
-
-	//--- LONG WORD 2 ----
-	u32		SvnIdx;	// The SVN entry index
-	u32		Rsvd3;
-
-	//--- LONG WORD 3 ----
-	u32		Rsvd4;
-	u32		Rsvd5;
-}RT_8188E_FIRMWARE_HDR, *PRT_8188E_FIRMWARE_HDR;
-#endif // download firmware related data structure
-
-
-#define DRIVER_EARLY_INT_TIME_8188E			0x05
-#define BCN_DMA_ATIME_INT_TIME_8188E		0x02
-
-
-//#define MAX_RX_DMA_BUFFER_SIZE_88E	      0x2400 //9k for 88E nornal chip , //MaxRxBuff=10k-max(TxReportSize(64*8), WOLPattern(16*24))
-#define RX_DMA_SIZE_88E(__Adapter) ((!IS_VENDOR_8188E_I_CUT_SERIES(__Adapter))?0x2800:0x4000)
-
-#ifdef CONFIG_WOWLAN
-#define RESV_FMWF	WKFMCAM_SIZE*MAX_WKFM_NUM /* 16 entries, for each is 24 bytes*/
-#else
-#define RESV_FMWF	0
-#endif
-
-#define RX_DMA_RESERVD_FW_FEATURE	0x200 /* for tx report (64*8) */
-
-#define MAX_RX_DMA_BUFFER_SIZE_88E(__Adapter) RX_DMA_SIZE_88E(__Adapter)-RX_DMA_RESERVD_FW_FEATURE
-
-#define MAX_TX_REPORT_BUFFER_SIZE			0x0400 /* 1k */
-
-// Note: We will divide number of page equally for each queue other than public queue!
-// 22k = 22528 bytes = 176 pages (@page =  128 bytes)
-// must reserved about 7 pages for LPS =>  176-7 = 169 (0xA9)
-// 2*BCN / 1*ps-poll / 1*null-data /1*prob_rsp /1*QOS null-data /1*BT QOS null-data 
-
-#define BCNQ_PAGE_NUM_88E		0x08
-
-//For WoWLan , more reserved page
-#ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_88E	0x00
-#else
-#define WOWLAN_PAGE_NUM_88E	0x00
-#endif
-
-/* Note: 
-Tx FIFO Size : previous CUT:22K /I_CUT after:32KB
-Tx page Size : 128B
-Total page numbers : 176(0xB0) / 256(0x100)
-*/
-#define TOTAL_PAGE_NUMBER_88E(_Adapter)	((IS_VENDOR_8188E_I_CUT_SERIES(_Adapter)?0x100:0xB0) - 1)/* must reserved 1 page for dma issue */
-#define TX_TOTAL_PAGE_NUMBER_88E(_Adapter)	(TOTAL_PAGE_NUMBER_88E(_Adapter) - BCNQ_PAGE_NUM_88E - WOWLAN_PAGE_NUM_88E)
-#define TX_PAGE_BOUNDARY_88E(_Adapter)		(TX_TOTAL_PAGE_NUMBER_88E(_Adapter) + 1) /* beacon header start address */
-
-#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_88E(_Adapter)	TX_TOTAL_PAGE_NUMBER_88E(_Adapter)
-#define WMM_NORMAL_TX_PAGE_BOUNDARY_88E(_Adapter)		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_88E(_Adapter) + 1)
-
-// For Normal Chip Setting
-// (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723B
-#define NORMAL_PAGE_NUM_HPQ_88E		0x0
-#define NORMAL_PAGE_NUM_LPQ_88E		0x09
-#define NORMAL_PAGE_NUM_NPQ_88E		0x0
-
-// Note: For Normal Chip Setting, modify later
-#define WMM_NORMAL_PAGE_NUM_HPQ_88E		0x29
-#define WMM_NORMAL_PAGE_NUM_LPQ_88E		0x1C
-#define WMM_NORMAL_PAGE_NUM_NPQ_88E		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
-
-//-------------------------------------------------------------------------
-//	Channel Plan
-//-------------------------------------------------------------------------
-
-
-#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)	      |
-//
-#define EFUSE_OOB_PROTECT_BYTES 		15	// PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte.
-
-#define		EFUSE_REAL_CONTENT_LEN_88E	256
-#define		EFUSE_MAP_LEN_88E		512
-#define		EFUSE_MAX_SECTION_88E		64
-#define		EFUSE_MAX_WORD_UNIT_88E		4
-#define		EFUSE_IC_ID_OFFSET_88E			506	//For some inferiority IC purpose. added by Roger, 2009.09.02.
-#define 		AVAILABLE_EFUSE_ADDR_88E(addr) 	(addr < EFUSE_REAL_CONTENT_LEN_88E)
-// <Roger_Notes> To prevent out of boundary programming case, leave 1byte and program full section
-// 9bytes + 1byt + 5bytes and pre 1byte.
-// For worst case:
-// | 2byte|----8bytes----|1byte|--7bytes--| //92D
-#define 		EFUSE_OOB_PROTECT_BYTES_88E	18 	// PG data exclude header, dummy 7 bytes frome CP test and reserved 1byte.
-#define		EFUSE_PROTECT_BYTES_BANK_88E	16
-
-
-//========================================================
-//			EFUSE for BT definition
-//========================================================
-#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
-
-#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)
-
-//#define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE)
-
-//#define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) )
-
-#ifdef CONFIG_PCI_HCI
- /* according to the define in the rtw_xmit.h, rtw_recv.h */
-#define TX_DESC_NUM_8188EE  TXDESC_NUM   /* 128 */
-#ifdef CONFIG_CONCURRENT_MODE
-/*#define BE_QUEUE_TX_DESC_NUM_8188EE  (TXDESC_NUM<<1)*/		/* 256 */
-#define BE_QUEUE_TX_DESC_NUM_8188EE  ((TXDESC_NUM<<1)+(TXDESC_NUM>>1))    /* 320 */
-/*#define BE_QUEUE_TX_DESC_NUM_8188EE  ((TXDESC_NUM<<1)+TXDESC_NUM)*/    /* 384 */
-#else
-#define BE_QUEUE_TX_DESC_NUM_8188EE  TXDESC_NUM /* 128 */
-/*#define BE_QUEUE_TX_DESC_NUM_8188EE  (TXDESC_NUM+(TXDESC_NUM>>1)) *//* 192 */
-#endif
-
-void InterruptRecognized8188EE(PADAPTER Adapter, PRT_ISR_CONTENT pIsrContent);
-void UpdateInterruptMask8188EE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
-#endif	//CONFIG_PCI_HCI
-
-// rtl8188e_hal_init.c
-
-s32 rtl8188e_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
-void _8051Reset88E(PADAPTER padapter);
-void rtl8188e_InitializeFirmwareVars(PADAPTER padapter);
-
-
-s32 InitLLTTable(PADAPTER padapter, u8 txpktbuf_bndy);
-
-// EFuse
-u8 GetEEPROMSize8188E(PADAPTER padapter);
-void Hal_InitPGData88E(PADAPTER padapter);
-void Hal_EfuseParseIDCode88E(PADAPTER padapter, u8 *hwinfo);
-void Hal_ReadTxPowerInfo88E(PADAPTER padapter,u8* hwinfo,BOOLEAN	AutoLoadFail);
-	
-void Hal_EfuseParseEEPROMVer88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void rtl8188e_EfuseParseChnlPlan(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseCustomerID88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_ReadAntennaDiversity88E	(PADAPTER pAdapter,u8*PROMContent,BOOLEAN AutoLoadFail);
-void Hal_ReadThermalMeter_88E(PADAPTER	Adapter,u8* PROMContent,BOOLEAN 	AutoloadFail);
-void Hal_EfuseParseXtal_8188E(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-void Hal_EfuseParseBoardType88E(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-void Hal_ReadPowerSavingMode88E(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-
-BOOLEAN HalDetectPwrDownMode88E(PADAPTER Adapter);
-	
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-void Hal_DetectWoWMode(PADAPTER pAdapter);
-#endif //CONFIG_WOWLAN
-
-
-#ifdef CONFIG_RF_GAIN_OFFSET
-void Hal_ReadRFGainOffset(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-#endif //CONFIG_RF_GAIN_OFFSET
-
-void rtl8188e_init_default_value(_adapter *adapter);
-
-void rtl8188e_set_hal_ops(struct hal_ops *pHalFunc);
-void init_hal_spec_8188e(_adapter *adapter);
-
-// register
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
-
-void rtl8188e_start_thread(_adapter *padapter);
-void rtl8188e_stop_thread(_adapter *padapter);
-
-void rtw_IOL_cmd_tx_pkt_buf_dump(ADAPTER *Adapter,int data_len);
-#ifdef CONFIG_IOL_EFUSE_PATCH
-s32 rtl8188e_iol_efuse_patch(PADAPTER padapter);
-#endif//CONFIG_IOL_EFUSE_PATCH
-void _InitTransferPageSize(PADAPTER padapter);
-
-void SetHwReg8188E(PADAPTER padapter, u8 variable, u8 *val);
-void GetHwReg8188E(PADAPTER padapter, u8 variable, u8 *val);
-void ResumeTxBeacon(PADAPTER padapter);
-void StopTxBeacon(PADAPTER padapter);
-u8
-GetHalDefVar8188E(
-	IN	PADAPTER				Adapter,
-	IN	HAL_DEF_VARIABLE		eVariable,
-	IN	PVOID					pValue
-	);
-#endif //__RTL8188E_HAL_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_HAL_H__
+#define __RTL8188E_HAL_H__
+
+/* #include "hal_com.h" */
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8188e_spec.h"
+#include "Hal8188EPhyReg.h"
+#include "Hal8188EPhyCfg.h"
+#include "rtl8188e_rf.h"
+#include "rtl8188e_dm.h"
+#include "rtl8188e_recv.h"
+#include "rtl8188e_xmit.h"
+#include "rtl8188e_cmd.h"
+#include "rtl8188e_led.h"
+#include "Hal8188EPwrSeq.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8188e_sreset.h"
+#endif
+
+/* --------------------------------------------------------------------- */
+/*		RTL8188E Power Configuration CMDs for USB/SDIO/PCIE interfaces */
+/* --------------------------------------------------------------------- */
+#define Rtl8188E_NIC_PWR_ON_FLOW				rtl8188E_power_on_flow
+#define Rtl8188E_NIC_RF_OFF_FLOW				rtl8188E_radio_off_flow
+#define Rtl8188E_NIC_DISABLE_FLOW				rtl8188E_card_disable_flow
+#define Rtl8188E_NIC_ENABLE_FLOW				rtl8188E_card_enable_flow
+#define Rtl8188E_NIC_SUSPEND_FLOW				rtl8188E_suspend_flow
+#define Rtl8188E_NIC_RESUME_FLOW				rtl8188E_resume_flow
+#define Rtl8188E_NIC_PDN_FLOW					rtl8188E_hwpdn_flow
+#define Rtl8188E_NIC_LPS_ENTER_FLOW			rtl8188E_enter_lps_flow
+#define Rtl8188E_NIC_LPS_LEAVE_FLOW			rtl8188E_leave_lps_flow
+
+
+#if 1 /* download firmware related data structure */
+#define MAX_FW_8188E_SIZE			0x8000 /* 32768, 32k / 16384, 16k */
+
+#define FW_8188E_SIZE				0x4000 /* 16384, 16k */
+#define FW_8188E_SIZE_2			0x8000 /* 32768, 32k */
+
+#define FW_8188E_START_ADDRESS	0x1000
+#define FW_8188E_END_ADDRESS		0x1FFF /* 0x5FFF */
+
+
+#define IS_FW_HEADER_EXIST_88E(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x88E0)
+
+typedef struct _RT_FIRMWARE_8188E {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[MAX_FW_8188E_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8188E, *PRT_FIRMWARE_8188E;
+
+/*
+ * This structure must be cared byte-ordering
+ *   */
+
+typedef struct _RT_8188E_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u8		Subversion;	/* FW Subversion, default 0x00 */
+	u16		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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u8		Foundry;
+	u8		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8188E_FIRMWARE_HDR, *PRT_8188E_FIRMWARE_HDR;
+#endif /* download firmware related data structure */
+
+
+#define DRIVER_EARLY_INT_TIME_8188E			0x05
+#define BCN_DMA_ATIME_INT_TIME_8188E		0x02
+
+
+/* #define MAX_RX_DMA_BUFFER_SIZE_88E	      0x2400 */ /* 9k for 88E nornal chip , */ /* MaxRxBuff=10k-max(TxReportSize(64*8), WOLPattern(16*24)) */
+#ifdef CONFIG_USB_HCI
+	#define RX_DMA_SIZE_88E(__Adapter) 0x2800
+#else
+	#define RX_DMA_SIZE_88E(__Adapter) ((!IS_VENDOR_8188E_I_CUT_SERIES(__Adapter))?0x2800:0x4000)
+#endif
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#define RX_DMA_RESERVD_FW_FEATURE	0x200 /* for tx report (64*8) */
+
+#define MAX_RX_DMA_BUFFER_SIZE_88E(__Adapter) (RX_DMA_SIZE_88E(__Adapter)-RX_DMA_RESERVD_FW_FEATURE)
+
+#define MAX_TX_REPORT_BUFFER_SIZE			0x0400 /* 1k */
+
+/* Note: We will divide number of page equally for each queue other than public queue!
+ * 22k = 22528 bytes = 176 pages (@page =  128 bytes)
+ * At leat 4 BCN pages for GO
+ * 4 BCN + 1 ps-poll + 1 null-data + 1 prob_rsp + 1 QOS null-data = 8 pages */
+
+#define BCNQ_PAGE_NUM_88E		0x08
+
+/* For WoWLan , more reserved page */
+#ifdef CONFIG_WOWLAN
+	/* 1 ArpRsp + 2 NbrAdv + 2 NDPInfo + 1 RCI + 1 AOAC = 7 pages*/
+	#define WOWLAN_PAGE_NUM_88E	0x07
+#else
+	#define WOWLAN_PAGE_NUM_88E	0x00
+#endif
+
+/* Note:
+Tx FIFO Size : previous CUT:22K /I_CUT after:32KB
+Tx page Size : 128B
+Total page numbers : 176(0xB0) / 256(0x100)
+*/
+#ifdef CONFIG_USB_HCI
+	#define TOTAL_PAGE_NUMBER_88E(_Adapter) (0xB0 - 1)
+#else
+	#define TOTAL_PAGE_NUMBER_88E(_Adapter)	((IS_VENDOR_8188E_I_CUT_SERIES(_Adapter)?0x100:0xB0) - 1)/* must reserved 1 page for dma issue */
+#endif
+#define TX_TOTAL_PAGE_NUMBER_88E(_Adapter)	(TOTAL_PAGE_NUMBER_88E(_Adapter) - BCNQ_PAGE_NUM_88E - WOWLAN_PAGE_NUM_88E)
+#define TX_PAGE_BOUNDARY_88E(_Adapter)		(TX_TOTAL_PAGE_NUMBER_88E(_Adapter) + 1) /* beacon header start address */
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_88E(_Adapter)	TX_TOTAL_PAGE_NUMBER_88E(_Adapter)
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_88E(_Adapter)		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_88E(_Adapter) + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723B */
+#define NORMAL_PAGE_NUM_HPQ_88E		0x0
+#define NORMAL_PAGE_NUM_LPQ_88E		0x09
+#define NORMAL_PAGE_NUM_NPQ_88E		0x0
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_88E		0x29
+#define WMM_NORMAL_PAGE_NUM_LPQ_88E		0x1C
+#define WMM_NORMAL_PAGE_NUM_NPQ_88E		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
+
+/* -------------------------------------------------------------------------
+ *	Channel Plan
+ * ------------------------------------------------------------------------- */
+
+
+#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)	      |
+ *   */
+#define EFUSE_OOB_PROTECT_BYTES 		15	/* PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte. */
+
+#define		EFUSE_REAL_CONTENT_LEN_88E	256
+#define		EFUSE_MAP_LEN_88E		512
+#define		EFUSE_MAX_SECTION_88E		64
+#define		EFUSE_MAX_WORD_UNIT_88E		4
+#define		EFUSE_IC_ID_OFFSET_88E			506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define		AVAILABLE_EFUSE_ADDR_88E(addr)	(addr < EFUSE_REAL_CONTENT_LEN_88E)
+/* <Roger_Notes> To prevent out of boundary programming case, leave 1byte and program full section
+ * 9bytes + 1byt + 5bytes and pre 1byte.
+ * For worst case:
+ * | 2byte|----8bytes----|1byte|--7bytes--|  */ /* 92D */
+#define 		EFUSE_OOB_PROTECT_BYTES_88E	18	/* PG data exclude header, dummy 7 bytes frome CP test and reserved 1byte. */
+#define		EFUSE_PROTECT_BYTES_BANK_88E	16
+
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#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
+
+#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)
+
+/* #define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE) */
+
+/* #define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) ) */
+
+#ifdef CONFIG_PCI_HCI
+	/* according to the define in the rtw_xmit.h, rtw_recv.h */
+	#define TX_DESC_NUM_8188EE  TXDESC_NUM   /* 128 */
+	#ifdef CONFIG_CONCURRENT_MODE
+		/*#define BE_QUEUE_TX_DESC_NUM_8188EE  (TXDESC_NUM<<1)*/		/* 256 */
+		#define BE_QUEUE_TX_DESC_NUM_8188EE  ((TXDESC_NUM<<1)+(TXDESC_NUM>>1))    /* 320 */
+		/*#define BE_QUEUE_TX_DESC_NUM_8188EE  ((TXDESC_NUM<<1)+TXDESC_NUM)*/    /* 384 */
+	#else
+		#define BE_QUEUE_TX_DESC_NUM_8188EE  TXDESC_NUM /* 128 */
+		/*#define BE_QUEUE_TX_DESC_NUM_8188EE  (TXDESC_NUM+(TXDESC_NUM>>1)) */ /* 192 */
+	#endif
+
+	void InterruptRecognized8188EE(PADAPTER Adapter, PRT_ISR_CONTENT pIsrContent);
+	void UpdateInterruptMask8188EE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+#endif /* CONFIG_PCI_HCI */
+
+/* rtl8188e_hal_init.c */
+
+s32 rtl8188e_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void _8051Reset88E(PADAPTER padapter);
+void rtl8188e_InitializeFirmwareVars(PADAPTER padapter);
+
+
+s32 InitLLTTable(PADAPTER padapter, u8 txpktbuf_bndy);
+
+/* EFuse */
+u8 GetEEPROMSize8188E(PADAPTER padapter);
+void Hal_InitPGData88E(PADAPTER padapter);
+void Hal_EfuseParseIDCode88E(PADAPTER padapter, u8 *hwinfo);
+void Hal_ReadTxPowerInfo88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+
+void Hal_EfuseParseEEPROMVer88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void rtl8188e_EfuseParseChnlPlan(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID88E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_ReadAntennaDiversity88E(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_ReadThermalMeter_88E(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void Hal_EfuseParseXtal_8188E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBoardType88E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_ReadPowerSavingMode88E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_ReadPAType_8188E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void Hal_ReadAmplifierType_8188E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void Hal_ReadRFEType_8188E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+
+BOOLEAN HalDetectPwrDownMode88E(PADAPTER Adapter);
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+
+#ifdef CONFIG_RF_POWER_TRIM
+	void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+void rtl8188e_init_default_value(_adapter *adapter);
+
+void InitBeaconParameters_8188e(_adapter *adapter);
+void SetBeaconRelatedRegisters8188E(PADAPTER padapter);
+
+void rtl8188e_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8188e(_adapter *adapter);
+
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+
+void rtl8188e_start_thread(_adapter *padapter);
+void rtl8188e_stop_thread(_adapter *padapter);
+
+void rtw_IOL_cmd_tx_pkt_buf_dump(ADAPTER *Adapter, int data_len);
+#ifdef CONFIG_IOL_EFUSE_PATCH
+	s32 rtl8188e_iol_efuse_patch(PADAPTER padapter);
+#endif/* CONFIG_IOL_EFUSE_PATCH */
+void _InitTransferPageSize(PADAPTER padapter);
+
+u8 SetHwReg8188E(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8188E(PADAPTER padapter, u8 variable, u8 *val);
+
+u8
+GetHalDefVar8188E(
+	IN	PADAPTER				Adapter,
+	IN	HAL_DEF_VARIABLE		eVariable,
+	IN	PVOID					pValue
+);
+#ifdef CONFIG_GPIO_API
+int rtl8188e_GpioFuncCheck(PADAPTER adapter, u8 gpio_num);
+#endif
+#endif /* __RTL8188E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_led.h
index 4b05994a8ba0..5d42f8013d01 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_led.h
@@ -1,41 +1,38 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8188E_LED_H__
-#define __RTL8188E_LED_H__
-
-
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
-#ifdef CONFIG_USB_HCI
-void rtl8188eu_InitSwLeds(PADAPTER padapter);
-void rtl8188eu_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_PCI_HCI
-void rtl8188ee_InitSwLeds(PADAPTER padapter);
-void rtl8188ee_DeInitSwLeds(PADAPTER padapter);
-#endif
-#if defined (CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-void rtl8188es_InitSwLeds(PADAPTER padapter);
-void rtl8188es_DeInitSwLeds(PADAPTER padapter);
-#endif
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_LED_H__
+#define __RTL8188E_LED_H__
+
+#ifdef CONFIG_RTW_SW_LED
+
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8188eu_InitSwLeds(PADAPTER padapter);
+	void rtl8188eu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8188ee_InitSwLeds(PADAPTER padapter);
+	void rtl8188ee_DeInitSwLeds(PADAPTER padapter);
+#endif
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	void rtl8188es_InitSwLeds(PADAPTER padapter);
+	void rtl8188es_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif
+#endif /*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_recv.h
index 8326afa0cfcb..f82ca8b2ea88 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_recv.h
@@ -1,175 +1,162 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8188E_RECV_H__
-#define __RTL8188E_RECV_H__
-
-#define RECV_BLK_SZ 512
-#define RECV_BLK_CNT 16
-#define RECV_BLK_TH RECV_BLK_CNT
-
-#if defined(CONFIG_USB_HCI)
-
-#ifndef MAX_RECVBUF_SZ
-#ifdef PLATFORM_OS_CE
-#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-#else
-	#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-		//#define MAX_RECVBUF_SZ (32768) // 32k
-		//#define MAX_RECVBUF_SZ (16384) //16K
-		//#define MAX_RECVBUF_SZ (10240) //10K
-		#ifdef CONFIG_PLATFORM_MSTAR
-			#define MAX_RECVBUF_SZ (8192) // 8K
-		#else
-		        #define MAX_RECVBUF_SZ (15360) // 15k < 16k
-		#endif
-		//#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-	#else
-		#define MAX_RECVBUF_SZ (4000) // about 4K
-	#endif
-#endif
-#endif //!MAX_RECVBUF_SZ
-
-#elif defined(CONFIG_PCI_HCI)
-//#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-//	#define MAX_RECVBUF_SZ (9100)
-//#else
-	#define MAX_RECVBUF_SZ (4000) // about 4K
-//#endif
-
-
-#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-
-#define MAX_RECVBUF_SZ (10240)
-
-#endif
-
-// Rx smooth factor
-#define	Rx_Smooth_Factor (20)
-
-#define TX_RPT1_PKT_LEN 8
-
-typedef struct rxreport_8188e
-{
-	//Offset 0
-	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;
-
-	//Offset 4
-	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;
-
-	//Offset 8
-	u32 seq:12;
-	u32 frag:4;
-	u32 nextpktlen:14;
-	u32 nextind:1;
-	u32 rsvd0831:1;
-
-	//Offset 12
-	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 rpt_sel:2;
-	u32 rsvd1216:13;
-	u32 pattern_match:1;
-	u32 unicastwake:1;
-	u32 magicwake:1;
-
-	//Offset 16
-	/*
-	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 rsvd16;
-
-	//Offset 20
-	u32 tsfl;
-
-	//Offset 24
-	u32 bassn:12;
-	u32 bavld:1;
-	u32 rsvd2413:19;
-} RXREPORT, *PRXREPORT;
-
-
-#if defined (CONFIG_SDIO_HCI)||defined(CONFIG_GSPI_HCI)
-s32 rtl8188es_init_recv_priv(PADAPTER padapter);
-void rtl8188es_free_recv_priv(PADAPTER padapter);
-void rtl8188es_recv_hdl(PADAPTER padapter, struct recv_buf *precvbuf);
-#endif
-
-#ifdef CONFIG_USB_HCI
-void rtl8188eu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
-s32 rtl8188eu_init_recv_priv(PADAPTER padapter);
-void rtl8188eu_free_recv_priv(PADAPTER padapter);
-void rtl8188eu_recv_hdl(PADAPTER padapter, struct recv_buf *precvbuf);
-void rtl8188eu_recv_tasklet(void *priv);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8188ee_init_recv_priv(PADAPTER padapter);
-void rtl8188ee_free_recv_priv(PADAPTER padapter);
-#endif
-
-void rtl8188e_query_rx_desc_status(union recv_frame *precvframe, struct recv_stat *prxstat);
-
-#endif /* __RTL8188E_RECV_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_RECV_H__
+#define __RTL8188E_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ (10240)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#define TX_RPT1_PKT_LEN 8
+
+typedef struct rxreport_8188e {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	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;
+
+	/* Offset 8 */
+	u32 seq:12;
+	u32 frag:4;
+	u32 nextpktlen:14;
+	u32 nextind:1;
+	u32 rsvd0831:1;
+
+	/* Offset 12 */
+	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 rpt_sel:2;
+	u32 rsvd1216:13;
+	u32 pattern_match:1;
+	u32 unicastwake:1;
+	u32 magicwake:1;
+
+	/* Offset 16 */
+	/*
+	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 rsvd16;
+
+	/* Offset 20 */
+	u32 tsfl;
+
+	/* Offset 24 */
+	u32 bassn:12;
+	u32 bavld:1;
+	u32 rsvd2413:19;
+} RXREPORT, *PRXREPORT;
+
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8188es_init_recv_priv(PADAPTER padapter);
+	void rtl8188es_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	void rtl8188eu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+	s32 rtl8188eu_init_recv_priv(PADAPTER padapter);
+	void rtl8188eu_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8188ee_init_recv_priv(PADAPTER padapter);
+	void rtl8188ee_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8188e_query_rx_desc_status(union recv_frame *precvframe, struct recv_stat *prxstat);
+
+#endif /* __RTL8188E_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_rf.h
index 28e58f298eab..58488beed640 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,23 +12,17 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188E_RF_H__
 #define __RTL8188E_RF_H__
 
 
 
-int	PHY_RF6052_Config8188E(	IN	PADAPTER		Adapter	);
-void		rtl8188e_RF_ChangeTxPath(	IN	PADAPTER	Adapter, 
-										IN	u16		DataRate);
-void		rtl8188e_PHY_RF6052SetBandwidth(	
-										IN	PADAPTER				Adapter,
-										IN	CHANNEL_WIDTH		Bandwidth);
-
-#endif//__RTL8188E_RF_H__
+int	PHY_RF6052_Config8188E(IN	PADAPTER		Adapter);
+void		rtl8188e_RF_ChangeTxPath(IN	PADAPTER	Adapter,
+		IN	u16		DataRate);
+void		rtl8188e_PHY_RF6052SetBandwidth(
+	IN	PADAPTER				Adapter,
+	IN	enum channel_width		Bandwidth);
 
+#endif/* __RTL8188E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_spec.h
index 91c820e222ea..e87126e41ed6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_spec.h
@@ -1,165 +1,160 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
-#ifndef __RTL8188E_SPEC_H__
-#define __RTL8188E_SPEC_H__
-
-
-//============================================================
-//       8188E Regsiter offset definition
-//============================================================
-
-
-//============================================================
-//
-//============================================================
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_BB_PAD_CTRL				0x0064
-#define REG_HMEBOX_E0					0x0088
-#define REG_HMEBOX_E1					0x008A
-#define REG_HMEBOX_E2					0x008C
-#define REG_HMEBOX_E3					0x008E
-#define REG_HMEBOX_EXT_0				0x01F0
-#define REG_HMEBOX_EXT_1				0x01F4
-#define REG_HMEBOX_EXT_2				0x01F8
-#define REG_HMEBOX_EXT_3				0x01FC
-#define REG_HIMR_88E					0x00B0 //RTL8188E
-#define REG_HISR_88E					0x00B4 //RTL8188E
-#define REG_HIMRE_88E					0x00B8 //RTL8188E
-#define REG_HISRE_88E					0x00BC //RTL8188E
-#define REG_MACID_NO_LINK_0			0x0484
-#define REG_MACID_NO_LINK_1			0x0488
-#define REG_MACID_PAUSE_0			0x048c
-#define REG_MACID_PAUSE_1			0x0490
-
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-#define REG_PKTBUF_DBG_ADDR 			(REG_PKTBUF_DBG_CTRL)
-#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
-#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
-#define REG_WOWLAN_WAKE_REASON		REG_MCUTST_WOWLAN
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-#ifdef CONFIG_WOWLAN
-#define REG_TXPKTBUF_IV_LOW             0x01a4
-#define REG_TXPKTBUF_IV_HIGH            0x01a8
-#endif
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-#ifdef CONFIG_RF_GAIN_OFFSET
-#define EEPROM_RF_GAIN_OFFSET			0xC1
-#define EEPROM_RF_GAIN_VAL				0xF6
-#define EEPROM_THERMAL_OFFSET			0xF5
-#endif //CONFIG_RF_GAIN_OFFSET
-//----------------------------------------------------------------------------
-//       88E Driver Initialization Offload REG_FDHM0(Offset 0x88, 8 bits)  
-//----------------------------------------------------------------------------
-//IOL config for REG_FDHM0(Reg0x88)
-#define CMD_INIT_LLT					BIT0
-#define CMD_READ_EFUSE_MAP		BIT1
-#define CMD_EFUSE_PATCH			BIT2
-#define CMD_IOCONFIG				BIT3
-#define CMD_INIT_LLT_ERR			BIT4
-#define CMD_READ_EFUSE_MAP_ERR	BIT5
-#define CMD_EFUSE_PATCH_ERR		BIT6
-#define CMD_IOCONFIG_ERR			BIT7
-
-//-----------------------------------------------------
-//
-//	Redifine register definition for compatibility
-//
-//-----------------------------------------------------
-
-// TODO: use these definition when using REG_xxx naming rule.
-// NOTE: DO NOT Remove these definition. Use later.
-#define ISR_88E				REG_HISR_88E
-
-#ifdef CONFIG_PCI_HCI
-//#define IMR_RX_MASK		(IMR_ROK_88E|IMR_RDU_88E|IMR_RXFOVW_88E)
-#define IMR_TX_MASK			(IMR_VODOK_88E|IMR_VIDOK_88E|IMR_BEDOK_88E|IMR_BKDOK_88E|IMR_MGNTDOK_88E|IMR_HIGHDOK_88E|IMR_BCNDERR0_88E)
-
-#ifdef CONFIG_CONCURRENT_MODE
-#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_88E | IMR_TBDOK_88E | IMR_TBDER_88E | IMR_BCNDMAINT_E_88E)
-#else
-#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_88E | IMR_TBDOK_88E | IMR_TBDER_88E)
-#endif
-
-#define RT_AC_INT_MASKS	(IMR_VIDOK_88E | IMR_VODOK_88E | IMR_BEDOK_88E|IMR_BKDOK_88E)
-#endif
-
-
-//========================================================
-// General definitions
-//========================================================
-
-#define MACID_NUM_88E 64
-#define SEC_CAM_ENT_NUM_88E 32
-#define NSS_NUM_88E 1
-#define BAND_CAP_88E (BAND_CAP_2G)
-#define BW_CAP_88E (BW_CAP_20M | BW_CAP_40M)
-#define PROTO_CAP_88E (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N)
-
-//----------------------------------------------------------------------------
-//       8192C EEPROM/EFUSE share register definition.
-//----------------------------------------------------------------------------
-
-#define EFUSE_ACCESS_ON			0x69	// For RTL8723 only.
-#define EFUSE_ACCESS_OFF			0x00	// For RTL8723 only.
-
-#endif /* __RTL8188E_SPEC_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_SPEC_H__
+#define __RTL8188E_SPEC_H__
+
+
+/* ************************************************************
+ * 8188E Regsiter offset definition
+ * ************************************************************ */
+
+
+/* ************************************************************
+ *
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_BB_PAD_CTRL				0x0064
+#define REG_HMEBOX_E0					0x0088
+#define REG_HMEBOX_E1					0x008A
+#define REG_HMEBOX_E2					0x008C
+#define REG_HMEBOX_E3					0x008E
+#define REG_HMEBOX_EXT_0				0x01F0
+#define REG_HMEBOX_EXT_1				0x01F4
+#define REG_HMEBOX_EXT_2				0x01F8
+#define REG_HMEBOX_EXT_3				0x01FC
+#define REG_HIMR_88E					0x00B0 /* RTL8188E */
+#define REG_HISR_88E					0x00B4 /* RTL8188E */
+#define REG_HIMRE_88E					0x00B8 /* RTL8188E */
+#define REG_HISRE_88E					0x00BC /* RTL8188E */
+
+#define	REG_DBI_WDATA_8188E				0x0348	/* DBI Write data */
+#define	REG_DBI_RDATA_8188E				0x034C	/* DBI Read data */
+#define	REG_DBI_ADDR_8188E				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8188E				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8188E				0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8188E				0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8188E				0x0358	/* MDIO for Control */
+
+#define REG_MACID_NO_LINK_0			0x0484
+#define REG_MACID_NO_LINK_1			0x0488
+#define REG_MACID_PAUSE_0			0x048c
+#define REG_MACID_PAUSE_1			0x0490
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_PKTBUF_DBG_ADDR			(REG_PKTBUF_DBG_CTRL)
+#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
+#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
+#define REG_WOWLAN_WAKE_REASON		REG_MCUTST_WOWLAN
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define REG_PCIE_HRPWM_8188E		0x0361	/* PCIe RPWM */
+#define REG_PCIE_HCPWM_8188E		0x0363	/* PCIe CPWM */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x01a4
+	#define REG_TXPKTBUF_IV_HIGH            0x01a8
+#endif
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#ifdef CONFIG_RF_POWER_TRIM
+	#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#define EEPROM_RF_GAIN_VAL				0xF6
+	#define EEPROM_THERMAL_OFFSET			0xF5
+#endif /*CONFIG_RF_POWER_TRIM*/
+/* ----------------------------------------------------------------------------
+ * 88E Driver Initialization Offload REG_FDHM0(Offset 0x88, 8 bits)
+ * ----------------------------------------------------------------------------
+ * IOL config for REG_FDHM0(Reg0x88) */
+#define CMD_INIT_LLT					BIT0
+#define CMD_READ_EFUSE_MAP		BIT1
+#define CMD_EFUSE_PATCH			BIT2
+#define CMD_IOCONFIG				BIT3
+#define CMD_INIT_LLT_ERR			BIT4
+#define CMD_READ_EFUSE_MAP_ERR	BIT5
+#define CMD_EFUSE_PATCH_ERR		BIT6
+#define CMD_IOCONFIG_ERR			BIT7
+
+/* -----------------------------------------------------
+ *
+ *	Redifine register definition for compatibility
+ *
+ * ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+ * NOTE: DO NOT Remove these definition. Use later. */
+#define ISR_88E				REG_HISR_88E
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_88E|IMR_RDU_88E|IMR_RXFOVW_88E) */
+	#define IMR_TX_MASK			(IMR_VODOK_88E | IMR_VIDOK_88E | IMR_BEDOK_88E | IMR_BKDOK_88E | IMR_MGNTDOK_88E | IMR_HIGHDOK_88E | IMR_BCNDERR0_88E)
+
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_88E | IMR_TBDOK_88E | IMR_TBDER_88E | IMR_BCNDMAINT_E_88E)
+	#else
+		#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_88E | IMR_TBDOK_88E | IMR_TBDER_88E)
+	#endif
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_88E | IMR_VODOK_88E | IMR_BEDOK_88E | IMR_BKDOK_88E)
+#endif
+
+/* ----------------------------------------------------------------------------
+ * 8192C EEPROM/EFUSE share register definition.
+ * ---------------------------------------------------------------------------- */
+
+#define EFUSE_ACCESS_ON			0x69	/* For RTL8723 only. */
+#define EFUSE_ACCESS_OFF			0x00	/* For RTL8723 only. */
+
+#endif /* __RTL8188E_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_sreset.h
index 34cb21a07e69..7fa89af73715 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_sreset.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,20 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL8188E_SRESET_H_
 #define _RTL8188E_SRESET_H_
 
 #include <rtw_sreset.h>
 
 #ifdef DBG_CONFIG_ERROR_DETECT
-extern void rtl8188e_sreset_xmit_status_check(_adapter *padapter);
-extern void rtl8188e_sreset_linked_status_check(_adapter *padapter);
+	extern void rtl8188e_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8188e_sreset_linked_status_check(_adapter *padapter);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_xmit.h
index 793a66bfbc14..790d334b9e09 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188e_xmit.h
@@ -1,299 +1,296 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8188E_XMIT_H__
-#define __RTL8188E_XMIT_H__
-
-
-
-
-//For 88e early mode
-#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
-#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
-#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
-#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
-#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
-#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
-#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
-
-//
-//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 QSEL_SHT			8
-#define RATE_ID_SHT			16
-#define NAVUSEHDR			BIT(20)
-#define SEC_TYPE_SHT 		22
-#define PKT_OFFSET_SHT		26
-
-//OFFSET 8
-#define AGG_EN				BIT(12)
-#define AGG_BK					BIT(16)
-#define AMPDU_DENSITY_SHT	20
-#define ANTSEL_A			BIT(24)
-#define ANTSEL_B			BIT(25)
-#define TX_ANT_CCK_SHT		26
-#define TX_ANTL_SHT			28
-#define TX_ANT_HT_SHT		30
-
-//OFFSET 12
-#define SEQ_SHT				16
-#define EN_HWSEQ			BIT(31)
-
-//OFFSET 16
-#define 	QOS                          BIT(6)
-#define	HW_SSN				BIT(7)
-#define 	USERATE			BIT(8)
-#define 	DISDATAFB			BIT(10)
-#define   CTS_2_SELF			BIT(11)
-#define	RTS_EN				BIT(12)
-#define	HW_RTS_EN			BIT(13)
-#define 	DATA_SHORT			BIT(24)
-#define 	PWR_STATUS_SHT	15
-#define 	DATA_SC_SHT		20
-#define 	DATA_BW			BIT(25)
-
-//OFFSET 20
-#define	RTY_LMT_EN			BIT(17)
-
-
-//OFFSET 20
-#define SGI					BIT(6)
-#define USB_TXAGG_NUM_SHT	24
-
-typedef struct txdesc_88e
-{
-	//Offset 0
-	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;
-
-	//Offset 4
-	u32 macid:6;
-	u32 rsvd0406:2;	
-	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;
-
-	//Offset 8
-	u32 rts_rc:6;
-	u32 data_rc:6;
-	u32 agg_en:1;
-	u32 rd_en:1;
-	u32 bar_rty_th:2;
-	u32 bk: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;
-
-	//Offset 12
-	u32 nextheadpage:8;
-	u32 tailpage:8;
-	u32 seq:12;
-	u32 cpu_handle:1;
-	u32 tag1:1;
-	u32 trigger_int:1;
-	u32 hwseq_en:1;
-
-	//Offset 16
-	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 pwr_status: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;
-
-	//Offset 20
-	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;
-
-	//Offset 24
-	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;
-
-	//Offset 28
-	u32 checksum:16;	// TxBuffSize(PCIe)/CheckSum(USB)
-	u32 sw0:8; /* offset 30 */
-	u32 sw1:4;
-	u32 mcs15_sgi_max_len:4;
-}TXDESC_8188E, *PTXDESC_8188E;
-
-#define txdesc_set_ccx_sw_88e(txdesc, value) \
-	do { \
-		((struct txdesc_88e *)(txdesc))->sw1 = (((value)>>8) & 0x0f); \
-		((struct txdesc_88e *)(txdesc))->sw0 = ((value) & 0xff); \
-	} while (0)
-
-struct txrpt_ccx_88e {
-	/* offset 0 */
-	u8 tag1:1;
-	u8 pkt_num:3;
-	u8 txdma_underflow:1;
-	u8 int_bt:1;
-	u8 int_tri:1;
-	u8 int_ccx:1;
-
-	/* offset 1 */
-	u8 mac_id:6;
-	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_88e(txrpt_ccx) ((txrpt_ccx)->sw0 + ((txrpt_ccx)->sw1<<8))
-#define txrpt_ccx_qtime_88e(txrpt_ccx) ((txrpt_ccx)->ccx_qtime0+((txrpt_ccx)->ccx_qtime1<<8))
-
-#define SET_TX_DESC_SEC_TYPE_8188E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
-
-void rtl8188e_fill_fake_txdesc(PADAPTER	padapter,u8*pDesc,u32 BufferLen,
-		u8 IsPsPoll,u8	IsBTQosNull, u8 bDataFrame);
-void rtl8188e_cal_txdesc_chksum(struct tx_desc	*ptxdesc);
-
-#if defined(CONFIG_SDIO_HCI)||defined (CONFIG_GSPI_HCI)
-s32 rtl8188es_init_xmit_priv(PADAPTER padapter);
-void rtl8188es_free_xmit_priv(PADAPTER padapter);
-s32 rtl8188es_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8188es_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8188es_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-thread_return rtl8188es_xmit_thread(thread_context context);
-s32 rtl8188es_xmit_buf_handler(PADAPTER padapter);
-
-#ifdef CONFIG_SDIO_TX_TASKLET
-void rtl8188es_xmit_tasklet(void *priv);
-#endif
-#endif
-
-#ifdef CONFIG_USB_HCI
-s32 rtl8188eu_init_xmit_priv(PADAPTER padapter);
-void rtl8188eu_free_xmit_priv(PADAPTER padapter);
-s32 rtl8188eu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8188eu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8188eu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-s32 rtl8188eu_xmit_buf_handler(PADAPTER padapter);
-void rtl8188eu_xmit_tasklet(void *priv);
-s32 rtl8188eu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8188ee_init_xmit_priv(PADAPTER padapter);
-void rtl8188ee_free_xmit_priv(PADAPTER padapter);
-void	rtl8188ee_xmitframe_resume(_adapter *padapter);
-s32 rtl8188ee_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8188ee_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8188ee_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-void rtl8188ee_xmit_tasklet(void *priv);
-#endif
-
-
-
-#ifdef CONFIG_TX_EARLY_MODE
-void UpdateEarlyModeInfo8188E(struct xmit_priv *pxmitpriv,struct xmit_buf *pxmitbuf );
-#endif
-
-#ifdef CONFIG_XMIT_ACK
-void dump_txrpt_ccx_88e(void *buf);
-void handle_txrpt_ccx_88e(_adapter *adapter, u8 *buf);
-#else
-#define dump_txrpt_ccx_88e(buf) do {} while(0)
-#define handle_txrpt_ccx_88e(adapter, buf) do {} while(0)
-#endif //CONFIG_XMIT_ACK
-
-void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag,struct tx_desc *ptxdesc);
-#endif //__RTL8188E_XMIT_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8188E_XMIT_H__
+#define __RTL8188E_XMIT_H__
+
+
+
+
+/* For 88e early mode */
+#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
+#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
+#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
+#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
+#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
+#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
+#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
+
+/*
+ * 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 QSEL_SHT			8
+#define RATE_ID_SHT			16
+#define NAVUSEHDR			BIT(20)
+#define SEC_TYPE_SHT		22
+#define PKT_OFFSET_SHT		26
+
+/* OFFSET 8 */
+#define AGG_EN				BIT(12)
+#define AGG_BK					BIT(16)
+#define AMPDU_DENSITY_SHT	20
+#define ANTSEL_A			BIT(24)
+#define ANTSEL_B			BIT(25)
+#define TX_ANT_CCK_SHT		26
+#define TX_ANTL_SHT			28
+#define TX_ANT_HT_SHT		30
+
+/* OFFSET 12 */
+#define SEQ_SHT				16
+#define EN_HWSEQ			BIT(31)
+
+/* OFFSET 16 */
+#define	QOS                          BIT(6)
+#define	HW_SSN				BIT(7)
+#define	USERATE			BIT(8)
+#define	DISDATAFB			BIT(10)
+#define   CTS_2_SELF			BIT(11)
+#define	RTS_EN				BIT(12)
+#define	HW_RTS_EN			BIT(13)
+#define	DATA_SHORT			BIT(24)
+#define	PWR_STATUS_SHT	15
+#define	DATA_SC_SHT		20
+#define	DATA_BW			BIT(25)
+
+/* OFFSET 20 */
+#define	RTY_LMT_EN			BIT(17)
+
+
+/* OFFSET 20 */
+#define SGI					BIT(6)
+#define USB_TXAGG_NUM_SHT	24
+
+typedef struct txdesc_88e {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	u32 macid:6;
+	u32 rsvd0406:2;
+	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;
+
+	/* Offset 8 */
+	u32 rts_rc:6;
+	u32 data_rc:6;
+	u32 agg_en:1;
+	u32 rd_en:1;
+	u32 bar_rty_th:2;
+	u32 bk: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;
+
+	/* Offset 12 */
+	u32 nextheadpage:8;
+	u32 tailpage:8;
+	u32 seq:12;
+	u32 cpu_handle:1;
+	u32 tag1:1;
+	u32 trigger_int:1;
+	u32 hwseq_en:1;
+
+	/* Offset 16 */
+	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 pwr_status: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;
+
+	/* Offset 20 */
+	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;
+
+	/* Offset 24 */
+	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;
+
+	/* Offset 28 */
+	u32 checksum:16;	/* TxBuffSize(PCIe)/CheckSum(USB) */
+	u32 sw0:8; /* offset 30 */
+	u32 sw1:4;
+	u32 mcs15_sgi_max_len:4;
+} TXDESC_8188E, *PTXDESC_8188E;
+
+#define txdesc_set_ccx_sw_88e(txdesc, value) \
+	do { \
+		((struct txdesc_88e *)(txdesc))->sw1 = (((value)>>8) & 0x0f); \
+		((struct txdesc_88e *)(txdesc))->sw0 = ((value) & 0xff); \
+	} while (0)
+
+struct txrpt_ccx_88e {
+	/* offset 0 */
+	u8 tag1:1;
+	u8 pkt_num:3;
+	u8 txdma_underflow:1;
+	u8 int_bt:1;
+	u8 int_tri:1;
+	u8 int_ccx:1;
+
+	/* offset 1 */
+	u8 mac_id:6;
+	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_88e(txrpt_ccx) ((txrpt_ccx)->sw0 + ((txrpt_ccx)->sw1<<8))
+#define txrpt_ccx_qtime_88e(txrpt_ccx) ((txrpt_ccx)->ccx_qtime0+((txrpt_ccx)->ccx_qtime1<<8))
+
+#define SET_TX_DESC_SEC_TYPE_8188E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+
+void rtl8188e_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen,
+			       u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8188e_cal_txdesc_chksum(struct tx_desc	*ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8188es_init_xmit_priv(PADAPTER padapter);
+	void rtl8188es_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8188es_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188es_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8188es_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	thread_return rtl8188es_xmit_thread(thread_context context);
+	s32 rtl8188es_xmit_buf_handler(PADAPTER padapter);
+
+	#ifdef CONFIG_SDIO_TX_TASKLET
+		void rtl8188es_xmit_tasklet(void *priv);
+	#endif
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8188eu_init_xmit_priv(PADAPTER padapter);
+	void rtl8188eu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8188eu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188eu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8188eu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188eu_xmit_buf_handler(PADAPTER padapter);
+	void rtl8188eu_xmit_tasklet(void *priv);
+	s32 rtl8188eu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8188ee_init_xmit_priv(PADAPTER padapter);
+	void rtl8188ee_free_xmit_priv(PADAPTER padapter);
+	void	rtl8188ee_xmitframe_resume(_adapter *padapter);
+	s32 rtl8188ee_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8188ee_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8188ee_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8188ee_xmit_tasklet(void *priv);
+#endif
+
+
+
+#ifdef CONFIG_TX_EARLY_MODE
+	void UpdateEarlyModeInfo8188E(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_XMIT_ACK
+	void dump_txrpt_ccx_88e(void *buf);
+	void handle_txrpt_ccx_88e(_adapter *adapter, u8 *buf);
+#else
+	#define dump_txrpt_ccx_88e(buf) do {} while (0)
+	#define handle_txrpt_ccx_88e(adapter, buf) do {} while (0)
+#endif /* CONFIG_XMIT_ACK */
+
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif /* __RTL8188E_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_cmd.h
index ddb4cd70af1f..ef629c4fdc52 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_cmd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,54 +12,49 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_CMD_H__
 #define __RTL8188F_CMD_H__
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD DEFINITION    ------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
-enum h2c_cmd_8188F{
-	//Common Class: 000
+enum h2c_cmd_8188F {
+	/* Common Class: 000 */
 	H2C_8188F_RSVD_PAGE = 0x00,
 	H2C_8188F_MEDIA_STATUS_RPT = 0x01,
 	H2C_8188F_SCAN_ENABLE = 0x02,
 	H2C_8188F_KEEP_ALIVE = 0x03,
-	H2C_8188F_DISCON_DECISION = 0x04,	
-	H2C_8188F_PSD_OFFLOAD = 0x05,	
-	H2C_8188F_AP_OFFLOAD = 0x08,	
-	H2C_8188F_BCN_RSVDPAGE = 0x09,	
-	H2C_8188F_PROBERSP_RSVDPAGE = 0x0A,	
-	H2C_8188F_FCS_RSVDPAGE = 0x10,	
-	H2C_8188F_FCS_INFO = 0x11,	
+	H2C_8188F_DISCON_DECISION = 0x04,
+	H2C_8188F_PSD_OFFLOAD = 0x05,
+	H2C_8188F_AP_OFFLOAD = 0x08,
+	H2C_8188F_BCN_RSVDPAGE = 0x09,
+	H2C_8188F_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8188F_FCS_RSVDPAGE = 0x10,
+	H2C_8188F_FCS_INFO = 0x11,
 	H2C_8188F_AP_WOW_GPIO_CTRL = 0x13,
 
-	//PoweSave Class: 001
+	/* PoweSave Class: 001 */
 	H2C_8188F_SET_PWR_MODE = 0x20,
 	H2C_8188F_PS_TUNING_PARA = 0x21,
 	H2C_8188F_PS_TUNING_PARA2 = 0x22,
-	H2C_8188F_P2P_LPS_PARAM = 0x23,	
-	H2C_8188F_P2P_PS_OFFLOAD = 0x24,	
-	H2C_8188F_PS_SCAN_ENABLE = 0x25,	
-	H2C_8188F_SAP_PS_ = 0x26,	
-	H2C_8188F_INACTIVE_PS_ = 0x27, //Inactive_PS
+	H2C_8188F_P2P_LPS_PARAM = 0x23,
+	H2C_8188F_P2P_PS_OFFLOAD = 0x24,
+	H2C_8188F_PS_SCAN_ENABLE = 0x25,
+	H2C_8188F_SAP_PS_ = 0x26,
+	H2C_8188F_INACTIVE_PS_ = 0x27, /* Inactive_PS */
 	H2C_8188F_FWLPS_IN_IPS_ = 0x28,
-	
-	//Dynamic Mechanism Class: 010
-	H2C_8188F_MACID_CFG = 0x40,	
-	H2C_8188F_TXBF = 0x41,	
-	H2C_8188F_RSSI_SETTING = 0x42,	
-	H2C_8188F_AP_REQ_TXRPT = 0x43,	
-	H2C_8188F_INIT_RATE_COLLECT = 0x44,	
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8188F_MACID_CFG = 0x40,
+	H2C_8188F_TXBF = 0x41,
+	H2C_8188F_RSSI_SETTING = 0x42,
+	H2C_8188F_AP_REQ_TXRPT = 0x43,
+	H2C_8188F_INIT_RATE_COLLECT = 0x44,
 	H2C_8188F_RA_PARA_ADJUST = 0x46,
-	
-	//BT Class: 011
+
+	/* BT Class: 011 */
 	H2C_8188F_B_TYPE_TDMA = 0x60,
 	H2C_8188F_BT_INFO = 0x61,
 	H2C_8188F_FORCE_BT_TXPWR = 0x62,
@@ -70,65 +66,66 @@ enum h2c_cmd_8188F{
 	H2C_8188F_BT_CONTROL = 0x68,
 	H2C_8188F_BT_WIFI_CTRL = 0x69,
 	H2C_8188F_BT_FW_PATCH = 0x6A,
-	H2C_8188F_BT_WLAN_CALIBRATION = 0x6D,	
-	
-	//WOWLAN Class: 100
+	H2C_8188F_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
 	H2C_8188F_WOWLAN = 0x80,
 	H2C_8188F_REMOTE_WAKE_CTRL = 0x81,
-	H2C_8188F_AOAC_GLOBAL_INFO = 0x82,	
-	H2C_8188F_AOAC_RSVD_PAGE = 0x83,	
+	H2C_8188F_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8188F_AOAC_RSVD_PAGE = 0x83,
 	H2C_8188F_AOAC_RSVD_PAGE2 = 0x84,
 	H2C_8188F_D0_SCAN_OFFLOAD_CTRL = 0x85,
 	H2C_8188F_D0_SCAN_OFFLOAD_INFO = 0x86,
 	H2C_8188F_CHNL_SWITCH_OFFLOAD = 0x87,
-	H2C_8188F_P2P_OFFLOAD_RSVD_PAGE = 0x8A,	
+	H2C_8188F_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
 	H2C_8188F_P2P_OFFLOAD = 0x8B,
 
 	H2C_8188F_RESET_TSF = 0xC0,
 	H2C_8188F_MAXID,
 };
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD CONTENT    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
-//_RSVDPAGE_LOC_CMD_0x00
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
 #define SET_8188F_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8188F_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_8188F_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8188F_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8188F_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 
-//_KEEP_ALIVE_CMD_0x03
+/* _KEEP_ALIVE_CMD_0x03 */
 #define SET_8188F_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8188F_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8188F_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
 #define SET_8188F_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 
-//_DISCONNECT_DECISION_CMD_0x04
+/* _DISCONNECT_DECISION_CMD_0x04 */
 #define SET_8188F_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8188F_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8188F_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_8188F_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
 
-// _PWR_MOD_CMD_0x20
+/* _PWR_MOD_CMD_0x20 */
 #define SET_8188F_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8188F_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8188F_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
-// _PS_TUNE_PARAM_CMD_0x21
+/* _PS_TUNE_PARAM_CMD_0x21 */
 #define SET_8188F_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_8188F_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
 #define SET_8188F_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
 #define SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 
-//_MACID_CFG_CMD_0x40
+/* _MACID_CFG_CMD_0x40 */
 #define SET_8188F_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8188F_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
 #define SET_8188F_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
@@ -142,19 +139,19 @@ enum h2c_cmd_8188F{
 #define SET_8188F_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
 #define SET_8188F_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
 
-//_RSSI_SETTING_CMD_0x42
+/* _RSSI_SETTING_CMD_0x42 */
 #define SET_8188F_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8188F_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
 #define SET_8188F_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 
-// _AP_REQ_TXRPT_CMD_0x43
+/* _AP_REQ_TXRPT_CMD_0x43 */
 #define SET_8188F_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8188F_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 
-// _FORCE_BT_TXPWR_CMD_0x62
+/* _FORCE_BT_TXPWR_CMD_0x62 */
 #define SET_8188F_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 
-// _FORCE_BT_MP_OPER_CMD_0x67
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
 #define SET_8188F_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
 #define SET_8188F_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
 #define SET_8188F_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
@@ -162,42 +159,44 @@ enum h2c_cmd_8188F{
 #define SET_8188F_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 #define SET_8188F_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
 
-// _BT_FW_PATCH_0x6A
+/* _BT_FW_PATCH_0x6A */
 #define SET_8188F_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
-#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 
-#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 
-#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value) 
-#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8188F_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 
-//---------------------------------------------------------------------------------------------------------//
-//-------------------------------------------    Structure    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    Function Statement     --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
-// host message to firmware cmd
+/* host message to firmware cmd */
 void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8188f_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
 void rtl8188f_set_rssi_cmd(PADAPTER padapter, u8 *param);
-void rtl8188f_Add_RateATid(PADAPTER pAdapter, u64 bitmap, u8* arg, u8 rssi_level);
 void rtl8188f_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
-//s32 rtl8188f_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable);
+/* s32 rtl8188f_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
 void rtl8188f_set_FwPsTuneParam_cmd(PADAPTER padapter);
-void rtl8188f_set_FwMacIdConfig_cmd(_adapter* padapter, u8 mac_id, u8 raid, u8 bw, u8 sgi, u32 mask);
 void rtl8188f_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param);
 void rtl8188f_download_rsvd_page(PADAPTER padapter, u8 mstatus);
 #ifdef CONFIG_BT_COEXIST
-void rtl8188f_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
-#endif // CONFIG_BT_COEXIST
+	void rtl8188f_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
 #ifdef CONFIG_P2P
 void rtl8188f_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
-void CheckFwRsvdPageContent(PADAPTER padapter);
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8188f_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
 
 #ifdef CONFIG_P2P_WOWLAN
 void rtl8188f_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
@@ -205,10 +204,6 @@ void rtl8188f_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
 
 void rtl8188f_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
 
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-u8 rtl8188f_reset_tsf(_adapter *padapter, u8 reset_port);
-#endif	// CONFIG_TSF_RESET_OFFLOAD
 s32 FillH2CCmd8188F(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 u8 GetTxBufferRsvdPageNum8188F(_adapter *padapter, bool wowlan);
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_dm.h
index d703ae524825..146490e88a04 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,38 +12,29 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_DM_H__
 #define __RTL8188F_DM_H__
-//============================================================
-// Description:
-//
-// This file is for 8188F dynamic mechanism only
-//
-//
-//============================================================
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8188F dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
 
-//============================================================
-// structure and define
-//============================================================
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
 
-//============================================================
-// function prototype
-//============================================================
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
 
 void rtl8188f_init_dm_priv(PADAPTER padapter);
 void rtl8188f_deinit_dm_priv(PADAPTER padapter);
 
 void rtl8188f_InitHalDm(PADAPTER padapter);
 void rtl8188f_HalDmWatchDog(PADAPTER padapter);
-void rtl8188f_HalDmWatchDog_in_LPS(PADAPTER padapter);
-void rtl8188f_hal_dm_in_lps(PADAPTER padapter);
-
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_hal.h
index 12cbd2c4d17b..66508aa856b9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_hal.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_HAL_H__
 #define __RTL8188F_HAL_H__
 
@@ -38,97 +34,98 @@
 
 #define FW_8188F_SIZE			0x8000
 #define FW_8188F_START_ADDRESS	0x1000
-#define FW_8188F_END_ADDRESS		0x1FFF //0x5FFF
+#define FW_8188F_END_ADDRESS		0x1FFF /* 0x5FFF */
 
-#define IS_FW_HEADER_EXIST_8188F(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature)&0xFFF0) == 0x88F0)
+#define IS_FW_HEADER_EXIST_8188F(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x88F0)
 
 typedef struct _RT_FIRMWARE {
 	FIRMWARE_SOURCE	eFWSource;
 #ifdef CONFIG_EMBEDDED_FWIMG
-	u8*			szFwBuffer;
+	u8			*szFwBuffer;
 #else
 	u8			szFwBuffer[FW_8188F_SIZE];
 #endif
 	u32			ulFwLength;
 } RT_FIRMWARE_8188F, *PRT_FIRMWARE_8188F;
 
-//
-// This structure must be cared byte-ordering
-//
-// Added by tynli. 2009.12.04.
-typedef struct _RT_8188F_FIRMWARE_HDR
-{
-	// 8-byte alinment required
-
-	//--- LONG WORD 0 ----
-	u16		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
-	u16		Version;		// FW Version
-	u16		Subversion;	// FW Subversion, default 0x00
-
-	//--- 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
-	u16		RamCodeSize;	// The size of RAM code
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8188F_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
 	u16		Rsvd2;
 
-	//--- LONG WORD 2 ----
-	u32		SvnIdx;	// The SVN entry index
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
 	u32		Rsvd3;
 
-	//--- LONG WORD 3 ----
+	/* --- LONG WORD 3 ---- */
 	u32		Rsvd4;
 	u32		Rsvd5;
-}RT_8188F_FIRMWARE_HDR, *PRT_8188F_FIRMWARE_HDR;
+} RT_8188F_FIRMWARE_HDR, *PRT_8188F_FIRMWARE_HDR;
 
 #define DRIVER_EARLY_INT_TIME_8188F		0x05
 #define BCN_DMA_ATIME_INT_TIME_8188F		0x02
 
-// for 8188F
-// TX 32K, RX 16K, Page size 128B for TX, 8B for RX
+/* for 8188F
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
 #define PAGE_SIZE_TX_8188F			128
 #define PAGE_SIZE_RX_8188F			8
 
-#define RX_DMA_SIZE_8188F			0x4000	// 16K
-#ifdef CONFIG_FW_C2H_DEBUG 
-#define RX_DMA_RESERVED_SIZE_8188F	0x100	// 256B, reserved for c2h debug message
+#define RX_DMA_SIZE_8188F			0x4000	/* 16K */
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8188F	0x100	/* 256B, reserved for c2h debug message */
 #else
-#define RX_DMA_RESERVED_SIZE_8188F	0x80	// 128B, reserved for tx report
+	#define RX_DMA_RESERVED_SIZE_8188F	0x80	/* 128B, reserved for tx report */
 #endif
 
 #ifdef CONFIG_WOWLAN
-#define RESV_FMWF	WKFMCAM_SIZE*MAX_WKFM_NUM /* 16 entries, for each is 24 bytes*/
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
 #else
-#define RESV_FMWF	0
+	#define RESV_FMWF	0
 #endif
 
 #define RX_DMA_BOUNDARY_8188F		(RX_DMA_SIZE_8188F - RX_DMA_RESERVED_SIZE_8188F - 1)
 
-// Note: We will divide number of page equally for each queue other than public queue!
+/* Note: We will divide number of page equally for each queue other than public queue! */
 
-//For General Reserved Page Number(Beacon Queue is reserved page)
-//Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
 #define BCNQ_PAGE_NUM_8188F		0x08
 #ifdef CONFIG_CONCURRENT_MODE
-#define BCNQ1_PAGE_NUM_8188F		0x08 // 0x04
+	#define BCNQ1_PAGE_NUM_8188F		0x08 /* 0x04 */
 #else
-#define BCNQ1_PAGE_NUM_8188F		0x00
+	#define BCNQ1_PAGE_NUM_8188F		0x00
 #endif
 
 #ifdef CONFIG_PNO_SUPPORT
 #undef BCNQ1_PAGE_NUM_8188F
-#define BCNQ1_PAGE_NUM_8188F		0x00 // 0x04
+#define BCNQ1_PAGE_NUM_8188F		0x00 /* 0x04 */
 #endif
 
-//For WoWLan , more reserved page
-//ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, PNO: 6
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt:1 ,PNO: 6
+ * NS offload:2 NDP info: 1
+ */
 #ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_8188F	0x07
+	#define WOWLAN_PAGE_NUM_8188F	0x0b
 #else
-#define WOWLAN_PAGE_NUM_8188F	0x00
+	#define WOWLAN_PAGE_NUM_8188F	0x00
 #endif
 
 #ifdef CONFIG_PNO_SUPPORT
@@ -146,13 +143,13 @@ typedef struct _RT_8188F_FIRMWARE_HDR
 #define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8188F	TX_TOTAL_PAGE_NUMBER_8188F
 #define WMM_NORMAL_TX_PAGE_BOUNDARY_8188F		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8188F + 1)
 
-// For Normal Chip Setting
-// (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8188F
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8188F */
 #define NORMAL_PAGE_NUM_HPQ_8188F		0x0C
 #define NORMAL_PAGE_NUM_LPQ_8188F		0x02
 #define NORMAL_PAGE_NUM_NPQ_8188F		0x02
 
-// Note: For Normal Chip Setting, modify later
+/* Note: For Normal Chip Setting, modify later */
 #define WMM_NORMAL_PAGE_NUM_HPQ_8188F		0x30
 #define WMM_NORMAL_PAGE_NUM_LPQ_8188F		0x20
 #define WMM_NORMAL_PAGE_NUM_NPQ_8188F		0x20
@@ -170,33 +167,26 @@ typedef struct _RT_8188F_FIRMWARE_HDR
 #define EFUSE_MAP_LEN_8188F				512
 #define EFUSE_MAX_SECTION_8188F			(EFUSE_MAP_LEN_8188F / 8)
 
-#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_8188F)
+#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_8188F)
 
-#define EFUSE_ACCESS_ON			0x69	// For RTL8188 only.
-#define EFUSE_ACCESS_OFF			0x00	// For RTL8188 only.
+#define EFUSE_ACCESS_ON			0x69	/* For RTL8188 only. */
+#define EFUSE_ACCESS_OFF			0x00	/* For RTL8188 only. */
 
-//========================================================
-//			EFUSE for BT definition
-//========================================================
+/* ********************************************************
+ *			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_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
 
-typedef struct _C2H_EVT_HDR
-{
-	u8	CmdID;
-	u8	CmdLen;
-	u8	CmdSeq;
-} __attribute__((__packed__)) C2H_EVT_HDR, *PC2H_EVT_HDR;
-
 #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)
 
-// rtl8188a_hal_init.c
+/* rtl8188a_hal_init.c */
 s32 rtl8188f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
 void rtl8188f_FirmwareSelfReset(PADAPTER padapter);
 void rtl8188f_InitializeFirmwareVars(PADAPTER padapter);
@@ -211,7 +201,7 @@ s32 rtl8188f_InitLLTTable(PADAPTER padapter);
 s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
 s32 CardDisableWithoutHWSM(PADAPTER padapter);
 
-// EFuse
+/* EFuse */
 u8 GetEEPROMSize8188F(PADAPTER padapter);
 void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
 void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
@@ -227,56 +217,47 @@ void Hal_EfuseParseThermalMeter_8188F(PADAPTER padapter, u8 *hwinfo, u8 AutoLoad
 void Hal_EfuseParseKFreeData_8188F(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
 
 #if 0 /* Do not need for rtl8188f */
-VOID Hal_EfuseParseVoltage_8188F(PADAPTER pAdapter,u8* hwinfo,BOOLEAN 	AutoLoadFail); 
-#endif
-
-#ifdef CONFIG_C2H_PACKET_EN
-void rtl8188f_c2h_packet_handler(PADAPTER padapter, u8 *pbuf, u16 length);
+VOID Hal_EfuseParseVoltage_8188F(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
 #endif
 
 void rtl8188f_set_pll_ref_clk_sel(_adapter *adapter, u8 sel);
 
 void rtl8188f_set_hal_ops(struct hal_ops *pHalFunc);
 void init_hal_spec_8188f(_adapter *adapter);
-void SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val);
 void GetHwReg8188F(PADAPTER padapter, u8 variable, u8 *val);
-#ifdef CONFIG_C2H_PACKET_EN
-void SetHwRegWithBuf8188F(PADAPTER padapter, u8 variable, u8 *pbuf, int len);
-#endif // CONFIG_C2H_PACKET_EN
 u8 SetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
 u8 GetHalDefVar8188F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
 
-// register
+/* register */
 void rtl8188f_InitBeaconParameters(PADAPTER padapter);
 void rtl8188f_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
 void	_InitBurstPktLen_8188FS(PADAPTER Adapter);
 void _8051Reset8188(PADAPTER padapter);
 #ifdef CONFIG_WOWLAN
 void Hal_DetectWoWMode(PADAPTER pAdapter);
-#endif //CONFIG_WOWLAN
+#endif /* CONFIG_WOWLAN */
 
 void rtl8188f_start_thread(_adapter *padapter);
 void rtl8188f_stop_thread(_adapter *padapter);
 
 #if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
-void rtl8188fs_init_checkbthang_workqueue(_adapter * adapter);
-void rtl8188fs_free_checkbthang_workqueue(_adapter * adapter);
-void rtl8188fs_cancle_checkbthang_workqueue(_adapter * adapter);
-void rtl8188fs_hal_check_bt_hang(_adapter * adapter);
+	void rtl8188fs_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8188fs_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8188fs_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8188fs_hal_check_bt_hang(_adapter *adapter);
 #endif
 
 #ifdef CONFIG_GPIO_WAKEUP
 void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
 #endif
 
+#ifdef CONFIG_MP_INCLUDED
 int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
 
 void CCX_FwC2HTxRpt_8188f(PADAPTER padapter, u8 *pdata, u8 len);
-#ifdef CONFIG_FW_C2H_DEBUG
-void Debug_FwC2H_8188f(PADAPTER padapter, u8 *pdata, u8 len);
-#endif //CONFIG_FW_C2H_DEBUG
-s32 c2h_id_filter_ccx_8188f(u8 *buf);
-s32 c2h_handler_8188f(PADAPTER padapter, u8 *pC2hEvent);
+
 u8 MRateToHwRate8188F(u8  rate);
 u8 HwRateToMRate8188F(u8	 rate);
 
@@ -286,4 +267,3 @@ VOID	UpdateInterruptMask8188FE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 Re
 #endif
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_led.h
index 9b7bf78c5e5c..67258fde0842 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_led.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,23 +12,19 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_LED_H__
 #define __RTL8188F_LED_H__
+#ifdef CONFIG_RTW_SW_LED
 
 #include <drv_conf.h>
 #include <osdep_service.h>
 #include <drv_types.h>
 
 
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
 #ifdef CONFIG_USB_HCI
 void rtl8188fu_InitSwLeds(PADAPTER padapter);
 void rtl8188fu_DeInitSwLeds(PADAPTER padapter);
@@ -46,4 +43,4 @@ void rtl8188fe_DeInitSwLeds(PADAPTER padapter);
 #endif
 
 #endif
-
+#endif/*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_recv.h
index 1dab7f354f4f..99acfa5aef89 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_recv.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,44 +12,39 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_RECV_H__
 #define __RTL8188F_RECV_H__
 
 #if defined(CONFIG_USB_HCI)
 	#ifndef MAX_RECVBUF_SZ
 		#ifdef PLATFORM_OS_CE
-			#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
 		#else
 			#ifdef CONFIG_MINIMAL_MEMORY_USAGE
-				#define MAX_RECVBUF_SZ (4000) // about 4K
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
 			#else
 				#ifdef CONFIG_PLATFORM_MSTAR
-					#define MAX_RECVBUF_SZ (8192) // 8K
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
 				#elif defined(CONFIG_PLATFORM_HISILICON)
 					#define MAX_RECVBUF_SZ (16384) /* 16k */
 				#else
 					#define MAX_RECVBUF_SZ (32768) /* 32k */
 				#endif
-				//#define MAX_RECVBUF_SZ (20480) //20K
-				//#define MAX_RECVBUF_SZ (10240) //10K 
-				//#define MAX_RECVBUF_SZ (16384) //  16k - 92E RX BUF :16K
-				//#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k		
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240)  */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16k - 92E RX BUF :16K */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k		 */
 			#endif
 		#endif
-	#endif //!MAX_RECVBUF_SZ
+	#endif /* !MAX_RECVBUF_SZ */
 #elif defined(CONFIG_PCI_HCI)
-	#define MAX_RECVBUF_SZ (4000) // about 4K
+	#define MAX_RECVBUF_SZ (4000) /* about 4K */
 #elif defined(CONFIG_SDIO_HCI)
 	#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8188F + 1)
 #endif /* CONFIG_SDIO_HCI */
 
-// Rx smooth factor
+/* Rx smooth factor */
 #define	Rx_Smooth_Factor (20)
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
@@ -59,7 +55,7 @@ s32 rtl8188fs_recv_hdl(_adapter *padapter);
 
 #ifdef CONFIG_USB_HCI
 int rtl8188fu_init_recv_priv(_adapter *padapter);
-void rtl8188fu_free_recv_priv (_adapter *padapter);
+void rtl8188fu_free_recv_priv(_adapter *padapter);
 void rtl8188fu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
 #endif
 
@@ -71,4 +67,3 @@ void rtl8188fe_free_recv_priv(PADAPTER padapter);
 void rtl8188f_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
 
 #endif /* __RTL8188F_RECV_H__ */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_rf.h
index ea71ef13ecbc..871ea98ffdc4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,21 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_RF_H__
 #define __RTL8188F_RF_H__
 
-int	PHY_RF6052_Config8188F(	IN	PADAPTER		Adapter	);
+int	PHY_RF6052_Config8188F(IN	PADAPTER		Adapter);
 
 VOID
 PHY_RF6052SetBandwidth8188F(
 	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH		Bandwidth);
+	IN	enum channel_width		Bandwidth);
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_spec.h
index 4324a535c53f..9814a7d9574a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_spec.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,25 +12,21 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_SPEC_H__
 #define __RTL8188F_SPEC_H__
 
 #include <drv_conf.h>
 
 
-#define HAL_NAV_UPPER_UNIT_8188F		128		// micro-second
+#define HAL_NAV_UPPER_UNIT_8188F		128		/* micro-second */
 
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_RSV_CTRL_8188F				0x001C	// 3 Byte
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RSV_CTRL_8188F				0x001C	/* 3 Byte */
 #define REG_BT_WIFI_ANTENNA_SWITCH_8188F	0x0038
 #define REG_HSISR_8188F					0x005c
 #define REG_PAD_CTRL1_8188F		0x0064
@@ -44,11 +41,11 @@
 #define REG_HISR1_8188F					0x00BC
 #define REG_PMC_DBG_CTRL2_8188F			0x00CC
 
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_C2HEVT_CMD_ID_8188F	0x01A0
 #define REG_C2HEVT_CMD_LEN_8188F	0x01AE
 #define REG_WOWLAN_WAKE_REASON 0x01C7
@@ -60,52 +57,52 @@
 #define REG_HMEBOX_EXT2_8188F			0x01F8
 #define REG_HMEBOX_EXT3_8188F			0x01FC
 
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_RXDMA_CONTROL_8188F		0x0286 // Control the RX DMA.
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_CONTROL_8188F		0x0286 /* Control the RX DMA. */
 #define REG_RXDMA_MODE_CTRL_8188F		0x0290
 
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
 #define	REG_PCIE_CTRL_REG_8188F		0x0300
-#define	REG_INT_MIG_8188F				0x0304	// Interrupt Migration 
-#define	REG_BCNQ_DESA_8188F			0x0308	// TX Beacon Descriptor Address
-#define	REG_HQ_DESA_8188F				0x0310	// TX High Queue Descriptor Address
-#define	REG_MGQ_DESA_8188F			0x0318	// TX Manage Queue Descriptor Address
-#define	REG_VOQ_DESA_8188F			0x0320	// TX VO Queue Descriptor Address
-#define	REG_VIQ_DESA_8188F				0x0328	// TX VI Queue Descriptor Address
-#define	REG_BEQ_DESA_8188F			0x0330	// TX BE Queue Descriptor Address
-#define	REG_BKQ_DESA_8188F			0x0338	// TX BK Queue Descriptor Address
-#define	REG_RX_DESA_8188F				0x0340	// RX Queue	Descriptor Address
-#define	REG_DBI_WDATA_8188F			0x0348	// DBI Write Data
-#define	REG_DBI_RDATA_8188F			0x034C	// DBI Read Data
-#define	REG_DBI_ADDR_8188F				0x0350	// DBI Address
-#define	REG_DBI_FLAG_8188F				0x0352	// DBI Read/Write Flag
-#define	REG_MDIO_WDATA_8188F		0x0354	// MDIO for Write PCIE PHY
-#define	REG_MDIO_RDATA_8188F			0x0356	// MDIO for Reads PCIE PHY
-#define	REG_MDIO_CTL_8188F			0x0358	// MDIO for Control
-#define	REG_DBG_SEL_8188F				0x0360	// Debug Selection Register
-#define	REG_PCIE_HRPWM_8188F			0x0361	//PCIe RPWM
-#define	REG_PCIE_HCPWM_8188F			0x0363	//PCIe CPWM
-#define	REG_PCIE_MULTIFET_CTRL_8188F	0x036A	//PCIE Multi-Fethc Control
-
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
+#define	REG_INT_MIG_8188F				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_DESA_8188F			0x0308	/* TX Beacon Descriptor Address */
+#define	REG_HQ_DESA_8188F				0x0310	/* TX High Queue Descriptor Address */
+#define	REG_MGQ_DESA_8188F			0x0318	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_DESA_8188F			0x0320	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_DESA_8188F				0x0328	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_DESA_8188F			0x0330	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_DESA_8188F			0x0338	/* TX BK Queue Descriptor Address */
+#define	REG_RX_DESA_8188F				0x0340	/* RX Queue	Descriptor Address */
+#define	REG_DBI_WDATA_8188F			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8188F			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8188F				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8188F				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8188F		0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8188F			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8188F			0x0358	/* MDIO for Control */
+#define	REG_DBG_SEL_8188F				0x0360	/* Debug Selection Register */
+#define	REG_PCIE_HRPWM_8188F			0x0361	/* PCIe RPWM */
+#define	REG_PCIE_HCPWM_8188F			0x0363	/* PCIe CPWM */
+#define	REG_PCIE_MULTIFET_CTRL_8188F	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_TXPKTBUF_BCNQ_BDNY_8188F	0x0424
 #define REG_TXPKTBUF_MGQ_BDNY_8188F	0x0425
 #define REG_TXPKTBUF_WMAC_LBK_BF_HD_8188F	0x045D
@@ -115,35 +112,35 @@
 #endif
 #define REG_AMPDU_BURST_MODE_8188F	0x04BC
 
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
 #define REG_SECONDARY_CCA_CTRL_8188F	0x0577
 
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
 
 
-//============================================================
-// SDIO Bus Specification
-//============================================================
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
 
-//-----------------------------------------------------
-// SDIO CMD Address Mapping
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
 
-//-----------------------------------------------------
-// I/O bus domain (Host)
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
 
-//-----------------------------------------------------
-// SDIO register
-//-----------------------------------------------------
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
 #define SDIO_REG_HIQ_FREEPG_8188F		0x0020
 #define SDIO_REG_MID_FREEPG_8188F		0x0022
 #define SDIO_REG_LOW_FREEPG_8188F		0x0024
@@ -166,36 +163,36 @@
 
 #define SDIO_REG_INDIRECT_REG_DATA_8188F	0x44
 
-//============================================================================
-//	8188 Regsiter Bit and Content definition
-//============================================================================
+/* ****************************************************************************
+ *	8188 Regsiter Bit and Content definition
+ * **************************************************************************** */
 
-//2 HSISR
-// interrupt mask which needs to clear
+/* 2 HSISR
+ * 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)
-
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
+		HSISR_SPS_OCP_INT |\
+		HSISR_RON_INT |\
+		HSISR_PDNINT |\
+		HSISR_GPIO9_INT)
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
 #define BIT_USB_RXDMA_AGG_EN	BIT(31)
 #define RXDMA_AGG_MODE_EN		BIT(1)
 
@@ -205,99 +202,87 @@
 #define RW_RELEASE_EN			BIT(18)
 #endif
 
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-
-//----------------------------------------------------------------------------
-//       8188F REG_CCK_CHECK						(offset 0x454)
-//----------------------------------------------------------------------------
-#define BIT_BCN_PORT_SEL		BIT5
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-
-//----------------------------------------------------------------------------
-//       8195 IMR/ISR bits						(offset 0xB0,  8bits)
-//----------------------------------------------------------------------------
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* ----------------------------------------------------------------------------
+ * 8188F REG_CCK_CHECK						(offset 0x454)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
 #define	IMR_DISABLED_8188F					0
-// IMR DW0(0x00B0-00B3) Bit 0-31
-#define	IMR_TIMER2_8188F					BIT31		// Timeout interrupt 2
-#define	IMR_TIMER1_8188F					BIT30		// Timeout interrupt 1	
-#define	IMR_PSTIMEOUT_8188F				BIT29		// Power Save Time Out Interrupt
-#define	IMR_GTINT4_8188F					BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define	IMR_GTINT3_8188F					BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define	IMR_TXBCN0ERR_8188F				BIT26		// Transmit Beacon0 Error			
-#define	IMR_TXBCN0OK_8188F				BIT25		// Transmit Beacon0 OK			
-#define	IMR_TSF_BIT32_TOGGLE_8188F		BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define	IMR_BCNDMAINT0_8188F				BIT20		// Beacon DMA Interrupt 0			
-#define	IMR_BCNDERR0_8188F				BIT16		// Beacon Queue DMA OK0			
-#define	IMR_HSISR_IND_ON_INT_8188F		BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)
-#define	IMR_BCNDMAINT_E_8188F			BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define	IMR_ATIMEND_8188F				BIT12		// CTWidnow End or ATIM Window End
-#define	IMR_C2HCMD_8188F					BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define	IMR_CPWM2_8188F					BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_CPWM_8188F					BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_HIGHDOK_8188F				BIT7			// High Queue DMA OK	
-#define	IMR_MGNTDOK_8188F				BIT6			// Management Queue DMA OK	
-#define	IMR_BKDOK_8188F					BIT5			// AC_BK DMA OK		
-#define	IMR_BEDOK_8188F					BIT4			// AC_BE DMA OK	
-#define	IMR_VIDOK_8188F					BIT3			// AC_VI DMA OK		
-#define	IMR_VODOK_8188F					BIT2			// AC_VO DMA OK	
-#define	IMR_RDU_8188F					BIT1			// Rx Descriptor Unavailable	
-#define	IMR_ROK_8188F					BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define	IMR_BCNDMAINT7_8188F				BIT27		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT6_8188F				BIT26		// Beacon DMA Interrupt 6
-#define	IMR_BCNDMAINT5_8188F				BIT25		// Beacon DMA Interrupt 5
-#define	IMR_BCNDMAINT4_8188F				BIT24		// Beacon DMA Interrupt 4
-#define	IMR_BCNDMAINT3_8188F				BIT23		// Beacon DMA Interrupt 3
-#define	IMR_BCNDMAINT2_8188F				BIT22		// Beacon DMA Interrupt 2
-#define	IMR_BCNDMAINT1_8188F				BIT21		// Beacon DMA Interrupt 1
-#define	IMR_BCNDOK7_8188F					BIT20		// Beacon Queue DMA OK Interrup 7
-#define	IMR_BCNDOK6_8188F					BIT19		// Beacon Queue DMA OK Interrup 6
-#define	IMR_BCNDOK5_8188F					BIT18		// Beacon Queue DMA OK Interrup 5
-#define	IMR_BCNDOK4_8188F					BIT17		// Beacon Queue DMA OK Interrup 4
-#define	IMR_BCNDOK3_8188F					BIT16		// Beacon Queue DMA OK Interrup 3
-#define	IMR_BCNDOK2_8188F					BIT15		// Beacon Queue DMA OK Interrup 2
-#define	IMR_BCNDOK1_8188F					BIT14		// Beacon Queue DMA OK Interrup 1
-#define	IMR_ATIMEND_E_8188F				BIT13		// ATIM Window End Extension for Win7
-#define	IMR_TXERR_8188F					BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define	IMR_RXERR_8188F					BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define	IMR_TXFOVW_8188F					BIT9			// Transmit FIFO Overflow
-#define	IMR_RXFOVW_8188F					BIT8			// Receive FIFO Overflow
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8188F					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8188F					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8188F				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8188F					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8188F					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8188F				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8188F				BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8188F		BIT(24)		/* TSF Timer BIT(32) toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8188F				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8188F				BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8188F		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8188F			BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8188F				BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8188F					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8188F					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8188F					BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8188F				BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8188F				BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8188F					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8188F					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8188F					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8188F					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8188F					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8188F					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8188F				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8188F				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8188F				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8188F				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8188F				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8188F				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8188F				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8188F					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8188F					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8188F					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8188F					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8188F					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8188F					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8188F					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8188F				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8188F					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8188F					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8188F					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8188F					BIT(8)			/* Receive FIFO Overflow */
 
 #ifdef CONFIG_PCI_HCI
-//#define IMR_RX_MASK		(IMR_ROK_8188F|IMR_RDU_8188F|IMR_RXFOVW_8188F)
-#define IMR_TX_MASK			(IMR_VODOK_8188F|IMR_VIDOK_8188F|IMR_BEDOK_8188F|IMR_BKDOK_8188F|IMR_MGNTDOK_8188F|IMR_HIGHDOK_8188F)
+/* #define IMR_RX_MASK		(IMR_ROK_8188F|IMR_RDU_8188F|IMR_RXFOVW_8188F) */
+#define IMR_TX_MASK			(IMR_VODOK_8188F | IMR_VIDOK_8188F | IMR_BEDOK_8188F | IMR_BKDOK_8188F | IMR_MGNTDOK_8188F | IMR_HIGHDOK_8188F)
 
 #define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8188F | IMR_TXBCN0OK_8188F | IMR_TXBCN0ERR_8188F | IMR_BCNDERR0_8188F)
 
-#define RT_AC_INT_MASKS	(IMR_VIDOK_8188F | IMR_VODOK_8188F | IMR_BEDOK_8188F|IMR_BKDOK_8188F)
+#define RT_AC_INT_MASKS	(IMR_VIDOK_8188F | IMR_VODOK_8188F | IMR_BEDOK_8188F | IMR_BKDOK_8188F)
 #endif
 
-//========================================================
-// General definitions
-//========================================================
-
-#define MACID_NUM_8188F 16
-#define SEC_CAM_ENT_NUM_8188F 16
-#define NSS_NUM_8188F 1
-#define BAND_CAP_8188F (BAND_CAP_2G)
-#define BW_CAP_8188F (BW_CAP_20M | BW_CAP_40M)
-#define PROTO_CAP_8188F (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N)
-
 #endif /* __RTL8188F_SPEC_H__ */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_sreset.h
index 8a2762415bd6..bd0193b3ab4d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_sreset.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL8188F_SRESET_H_
 #define _RTL8188F_SRESET_H_
 
@@ -27,4 +23,3 @@ extern void rtl8188f_sreset_xmit_status_check(_adapter *padapter);
 extern void rtl8188f_sreset_linked_status_check(_adapter *padapter);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_xmit.h
index 265b887310c3..72a976f674bb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8188f_xmit.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8188F_XMIT_H__
 #define __RTL8188F_XMIT_H__
 
@@ -31,79 +27,79 @@
 #define RX_DRV_INFO_SIZE_UNIT_8188F 8
 
 
-//DWORD 0
-#define SET_RX_STATUS_DESC_PKT_LEN_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_STATUS_DESC_EOR_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 30, 1, __Value)
-#define SET_RX_STATUS_DESC_OWN_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 31, 1, __Value)
-
-#define GET_RX_STATUS_DESC_PKT_LEN_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 0, 14)
-#define GET_RX_STATUS_DESC_CRC32_8188F(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 14, 1)
-#define GET_RX_STATUS_DESC_ICV_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 15, 1)
-#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 4)
-#define GET_RX_STATUS_DESC_SECURITY_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 20, 3)
-#define GET_RX_STATUS_DESC_QOS_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 23, 1)
-#define GET_RX_STATUS_DESC_SHIFT_8188F(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 24, 2)
-#define GET_RX_STATUS_DESC_PHY_STATUS_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 26, 1)
-#define GET_RX_STATUS_DESC_SWDEC_8188F(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 27, 1)
-#define GET_RX_STATUS_DESC_LAST_SEG_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 28, 1)
-#define GET_RX_STATUS_DESC_FIRST_SEG_8188F(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 29, 1)
-#define GET_RX_STATUS_DESC_EOR_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 30, 1)
-#define GET_RX_STATUS_DESC_OWN_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 31, 1)
-
-//DWORD 1
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8188F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_LAST_SEG_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+#define GET_RX_STATUS_DESC_FIRST_SEG_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+#define GET_RX_STATUS_DESC_EOR_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
 #define GET_RX_STATUS_DESC_MACID_8188F(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
-#define GET_RX_STATUS_DESC_TID_8188F(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_TID_8188F(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
 #define GET_RX_STATUS_DESC_AMSDU_8188F(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
-#define GET_RX_STATUS_DESC_RXID_MATCH_8188F(__pRxDesc)		LE_BITS_TO_4BYTE( __pRxDesc+4, 14, 1)
-#define GET_RX_STATUS_DESC_PAGGR_8188F(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 15, 1)
-#define GET_RX_STATUS_DESC_A1_FIT_8188F(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 16, 4)
-#define GET_RX_STATUS_DESC_CHKERR_8188F(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
 #define GET_RX_STATUS_DESC_IPVER_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
 #define GET_RX_STATUS_DESC_IS_TCPUDP__8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
-#define GET_RX_STATUS_DESC_CHK_VLD_8188F(__pRxDesc) 	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
-#define GET_RX_STATUS_DESC_PAM_8188F(__pRxDesc) 			LE_BITS_TO_4BYTE( __pRxDesc+4, 24, 1)
-#define GET_RX_STATUS_DESC_PWR_8188F(__pRxDesc) 			LE_BITS_TO_4BYTE( __pRxDesc+4, 25, 1)
-#define GET_RX_STATUS_DESC_MORE_DATA_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 26, 1)
-#define GET_RX_STATUS_DESC_MORE_FRAG_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 27, 1)
-#define GET_RX_STATUS_DESC_TYPE_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 28, 2)
-#define GET_RX_STATUS_DESC_MC_8188F(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 30, 1)
-#define GET_RX_STATUS_DESC_BC_8188F(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 31, 1)
-
-//DWORD 2
-#define GET_RX_STATUS_DESC_SEQ_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 0, 12)
-#define GET_RX_STATUS_DESC_FRAG_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 12, 4)
-#define GET_RX_STATUS_DESC_RX_IS_QOS_8188F(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 16, 1)
-#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8188F(__pRxStatusDesc) 	LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 18, 6)
-#define GET_RX_STATUS_DESC_RPT_SEL_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 28, 1)
-
-//DWORD 3
-#define GET_RX_STATUS_DESC_RX_RATE_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 0, 7)
-#define GET_RX_STATUS_DESC_HTC_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 10, 1)
-#define GET_RX_STATUS_DESC_EOSP_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 11, 1)
-#define GET_RX_STATUS_DESC_BSSID_FIT_8188F(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 12, 2)
+#define GET_RX_STATUS_DESC_CHK_VLD_8188F(__pRxDesc)	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8188F(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8188F(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8188F(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8188F(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8188F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
 #ifdef CONFIG_USB_RX_AGGREGATION
-#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8188F(__pRxStatusDesc)	LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 16, 8)
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8188F(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
 #endif
-#define GET_RX_STATUS_DESC_PATTERN_MATCH_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 29, 1)
-#define GET_RX_STATUS_DESC_UNICAST_MATCH_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 30, 1)
-#define GET_RX_STATUS_DESC_MAGIC_MATCH_8188F(__pRxDesc) 		LE_BITS_TO_4BYTE( __pRxDesc+12, 31, 1)
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
 
-//DWORD 6
-#define GET_RX_STATUS_DESC_SPLCP_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 0, 1)
-#define GET_RX_STATUS_DESC_LDPC_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 1, 1)
-#define GET_RX_STATUS_DESC_STBC_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 2, 1)
-#define GET_RX_STATUS_DESC_BW_8188F(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 4, 2)
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_SPLCP_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+#define GET_RX_STATUS_DESC_LDPC_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+#define GET_RX_STATUS_DESC_STBC_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+#define GET_RX_STATUS_DESC_BW_8188F(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
 
-//DWORD 5
-#define GET_RX_STATUS_DESC_TSFL_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+20, 0, 32)
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8188F(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
 
 #define GET_RX_STATUS_DESC_BUFF_ADDR_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
-#define GET_RX_STATUS_DESC_BUFF_ADDR64_8188F(__pRxDesc) 		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8188F(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
 
 #define SET_RX_STATUS_DESC_BUFF_ADDR_8188F(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
 
 
-// Dword 0
+/* Dword 0 */
 #define GET_TX_DESC_OWN_8188F(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
 
 #define SET_TX_DESC_PKT_SIZE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
@@ -117,7 +113,7 @@
 #define SET_TX_DESC_GF_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
 #define SET_TX_DESC_OWN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
 
-// Dword 1
+/* Dword 1 */
 #define SET_TX_DESC_MACID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
 #define SET_TX_DESC_QUEUE_SEL_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
 #define SET_TX_DESC_RDG_NAV_EXT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
@@ -129,12 +125,12 @@
 #define SET_TX_DESC_PKT_OFFSET_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
 
 
-// Dword 2
-#define SET_TX_DESC_PAID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value) 
+/* Dword 2 */
+#define SET_TX_DESC_PAID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
 #define SET_TX_DESC_CCA_RTS_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
 #define SET_TX_DESC_AGG_ENABLE_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
 #define SET_TX_DESC_RDG_ENABLE_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
-#define SET_TX_DESC_AGG_BREAK_8188F(__pTxDesc, __Value) 				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_AGG_BREAK_8188F(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
 #define SET_TX_DESC_MORE_FRAG_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
 #define SET_TX_DESC_RAW_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
 #define SET_TX_DESC_SPE_RPT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
@@ -143,7 +139,7 @@
 #define SET_TX_DESC_GID_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
 
 
-// Dword 3
+/* Dword 3 */
 #define SET_TX_DESC_WHEADER_LEN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
 #define SET_TX_DESC_CHK_EN_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
 #define SET_TX_DESC_EARLY_MODE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
@@ -160,7 +156,7 @@
 #define SET_TX_DESC_NDPA_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
 #define SET_TX_DESC_AMPDU_MAX_TIME_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
 
-// Dword 4
+/* Dword 4 */
 #define SET_TX_DESC_TX_RATE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
 #define SET_TX_DESC_DATA_RATE_FB_LIMIT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
 #define SET_TX_DESC_RTS_RATE_FB_LIMIT_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
@@ -169,7 +165,7 @@
 #define SET_TX_DESC_RTS_RATE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
 
 
-// Dword 5
+/* Dword 5 */
 #define SET_TX_DESC_DATA_SC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
 #define SET_TX_DESC_DATA_SHORT_8188F(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
 #define SET_TX_DESC_DATA_BW_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
@@ -180,7 +176,7 @@
 #define SET_TX_DESC_RTS_SC_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
 
 
-// Dword 6
+/* Dword 6 */
 #define SET_TX_DESC_SW_DEFINE_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
 #define SET_TX_DESC_MBSSID_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
 #define SET_TX_DESC_ANTSEL_A_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
@@ -188,29 +184,29 @@
 #define SET_TX_DESC_ANTSEL_C_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
 #define SET_TX_DESC_ANTSEL_D_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
 
-// Dword 7
-#if(DEV_BUS_TYPE == RT_PCI_INTERFACE)
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
 #define SET_TX_DESC_TX_BUFFER_SIZE_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
 #else
 #define SET_TX_DESC_TX_DESC_CHECKSUM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
 #endif
 #define SET_TX_DESC_USB_TXAGG_NUM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-#if(DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
 #define SET_TX_DESC_SDIO_TXSEQ_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
 #endif
 
-// Dword 8
+/* Dword 8 */
 #define SET_TX_DESC_HWSEQ_EN_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
 
-// Dword 9
+/* Dword 9 */
 #define SET_TX_DESC_SEQ_8188F(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
 
-// Dword 10
-#define SET_TX_DESC_TX_BUFFER_ADDRESS_8188F(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
-#define GET_TX_DESC_TX_BUFFER_ADDRESS_8188F(__pTxDesc) 	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+/* Dword 10 */
+#define SET_TX_DESC_TX_BUFFER_ADDRESS_8188F(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+#define GET_TX_DESC_TX_BUFFER_ADDRESS_8188F(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
 
-// Dword 11
-#define SET_TX_DESC_NEXT_DESC_ADDRESS_8188F(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+/* Dword 11 */
+#define SET_TX_DESC_NEXT_DESC_ADDRESS_8188F(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
 
 
 #define SET_EARLYMODE_PKTNUM_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
@@ -221,18 +217,18 @@
 #define SET_EARLYMODE_LEN3_8188F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
 
 #endif
-//-----------------------------------------------------------
-//
-//	Rate
-//
-//-----------------------------------------------------------
-// CCK Rates, TxHT = 0
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
 #define DESC8188F_RATE1M				0x00
 #define DESC8188F_RATE2M				0x01
 #define DESC8188F_RATE5_5M				0x02
 #define DESC8188F_RATE11M				0x03
 
-// OFDM Rates, TxHT = 0
+/* OFDM Rates, TxHT = 0 */
 #define DESC8188F_RATE6M				0x04
 #define DESC8188F_RATE9M				0x05
 #define DESC8188F_RATE12M				0x06
@@ -242,7 +238,7 @@
 #define DESC8188F_RATE48M				0x0a
 #define DESC8188F_RATE54M				0x0b
 
-// MCS Rates, TxHT = 1
+/* MCS Rates, TxHT = 1 */
 #define DESC8188F_RATEMCS0				0x0c
 #define DESC8188F_RATEMCS1				0x0d
 #define DESC8188F_RATEMCS2				0x0e
@@ -253,12 +249,12 @@
 #define DESC8188F_RATEMCS7				0x13
 #define DESC8188F_RATEMCS8				0x14
 #define DESC8188F_RATEMCS9				0x15
-#define DESC8188F_RATEMCS10 		0x16
-#define DESC8188F_RATEMCS11 		0x17
-#define DESC8188F_RATEMCS12 		0x18
-#define DESC8188F_RATEMCS13 		0x19
-#define DESC8188F_RATEMCS14 		0x1a
-#define DESC8188F_RATEMCS15 		0x1b
+#define DESC8188F_RATEMCS10		0x16
+#define DESC8188F_RATEMCS11		0x17
+#define DESC8188F_RATEMCS12		0x18
+#define DESC8188F_RATEMCS13		0x19
+#define DESC8188F_RATEMCS14		0x1a
+#define DESC8188F_RATEMCS15		0x1b
 #define DESC8188F_RATEVHTSS1MCS0		0x2c
 #define DESC8188F_RATEVHTSS1MCS1		0x2d
 #define DESC8188F_RATEVHTSS1MCS2		0x2e
@@ -281,15 +277,18 @@
 #define DESC8188F_RATEVHTSS2MCS9		0x3f
 
 
-#define 	RX_HAL_IS_CCK_RATE_8188F(pDesc)\
-			(GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE1M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE2M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE5_5M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE11M)
+#define	RX_HAL_IS_CCK_RATE_8188F(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8188F(pDesc) == DESC8188F_RATE11M)
 
 
 void rtl8188f_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
 void rtl8188f_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+#if defined(CONFIG_CONCURRENT_MODE)
+void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 s32 rtl8188fs_init_xmit_priv(PADAPTER padapter);
@@ -303,19 +302,20 @@ thread_return rtl8188fs_xmit_thread(thread_context context);
 #endif
 
 #ifdef CONFIG_USB_HCI
+#ifdef CONFIG_XMIT_THREAD_MODE
 s32 rtl8188fu_xmit_buf_handler(PADAPTER padapter);
 #define hal_xmit_handler rtl8188fu_xmit_buf_handler
-
+#endif
 
 s32 rtl8188fu_init_xmit_priv(PADAPTER padapter);
 void rtl8188fu_free_xmit_priv(PADAPTER padapter);
 s32 rtl8188fu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
 s32 rtl8188fu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
 s32	 rtl8188fu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-//s32 rtl8812au_xmit_buf_handler(PADAPTER padapter);
+/* s32 rtl8812au_xmit_buf_handler(PADAPTER padapter); */
 void rtl8188fu_xmit_tasklet(void *priv);
 s32 rtl8188fu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag,struct tx_desc *ptxdesc);
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
 #endif
 
 #ifdef CONFIG_PCI_HCI
@@ -333,4 +333,3 @@ u8	BWMapping_8188F(PADAPTER Adapter, struct pkt_attrib *pattrib);
 u8	SCMapping_8188F(PADAPTER Adapter, struct pkt_attrib	*pattrib);
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_cmd.h
index f14cbfe69a43..5ded2efa2360 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_cmd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,17 +12,11 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8192E_CMD_H__
 #define __RTL8192E_CMD_H__
 
-typedef enum _RTL8192E_H2C_CMD 
-{
+typedef enum _RTL8192E_H2C_CMD {
 	H2C_8192E_RSVDPAGE	= 0x00,
 	H2C_8192E_MSRRPT	= 0x01,
 	H2C_8192E_SCAN		= 0x02,
@@ -33,8 +28,8 @@ typedef enum _RTL8192E_H2C_CMD
 	H2C_8192E_PROBERSP_RSVDPAGE = 0x0a,
 
 	H2C_8192E_AP_WOW_GPIO_CTRL = 0x13,
-	
-	H2C_8192E_SETPWRMODE = 0x20,		
+
+	H2C_8192E_SETPWRMODE = 0x20,
 	H2C_8192E_PS_TUNING_PARA = 0x21,
 	H2C_8192E_PS_TUNING_PARA2 = 0x22,
 	H2C_8192E_PS_LPS_PARA = 0x23,
@@ -49,44 +44,44 @@ typedef enum _RTL8192E_H2C_CMD
 	H2C_8192E_AOAC_GLOBAL_INFO = 0x82,
 	H2C_8192E_AOAC_RSVDPAGE = 0x83,
 
-	//Not defined in new 88E H2C CMD Format
+	/* Not defined in new 88E H2C CMD Format */
 	H2C_8192E_SELECTIVE_SUSPEND_ROF_CMD,
 	H2C_8192E_P2P_PS_MODE,
 	H2C_8192E_PSD_RESULT,
 	MAX_8192E_H2CCMD
-}RTL8192E_H2C_CMD;
+} RTL8192E_H2C_CMD;
 
 struct cmd_msg_parm {
-	u8 eid; //element id
-	u8 sz; // sz
+	u8 eid; /* element id */
+	u8 sz; /* sz */
 	u8 buf[6];
 };
 
-enum{
+enum {
 	PWRS
 };
 
 typedef struct _SETPWRMODE_PARM {
-	u8 Mode;//0:Active,1:LPS,2:WMMPS
-	//u8 RLBM:4;//0:Min,1:Max,2: User define
-	u8 SmartPS_RLBM;//LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData
-	u8 AwakeInterval;	// unit: beacon interval
+	u8 Mode;/* 0:Active,1:LPS,2:WMMPS */
+	/* u8 RLBM:4; */ /* 0:Min,1:Max,2: User define */
+	u8 SmartPS_RLBM;/* LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData */
+	u8 AwakeInterval;	/* unit: beacon interval */
 	u8 bAllQueueUAPSD;
-	u8 PwrState;//AllON(0x0c),RFON(0x04),RFOFF(0x00)
+	u8 PwrState;/* AllON(0x0c),RFON(0x04),RFOFF(0x00) */
 } SETPWRMODE_PARM, *PSETPWRMODE_PARM;
 
-struct H2C_SS_RFOFF_PARAM{
-	u8 ROFOn; // 1: on, 0:off
-	u16 gpio_period; // unit: 1024 us
-}__attribute__ ((packed));
+struct H2C_SS_RFOFF_PARAM {
+	u8 ROFOn; /* 1: on, 0:off */
+	u16 gpio_period; /* unit: 1024 us */
+} __attribute__((packed));
 
 
-typedef struct JOINBSSRPT_PARM_92E{
-	u8 OpMode;	// RT_MEDIA_STATUS
+typedef struct JOINBSSRPT_PARM_92E {
+	u8 OpMode;	/* RT_MEDIA_STATUS */
 #ifdef CONFIG_WOWLAN
-	u8 MacID;       // MACID
-#endif //CONFIG_WOWLAN
-}JOINBSSRPT_PARM_92E, *PJOINBSSRPT_PARM_92E;
+	u8 MacID;       /* MACID */
+#endif /* CONFIG_WOWLAN */
+} JOINBSSRPT_PARM_92E, *PJOINBSSRPT_PARM_92E;
 
 /* move to hal_com_h2c.h
 typedef struct _RSVDPAGE_LOC_92E {
@@ -99,17 +94,18 @@ typedef struct _RSVDPAGE_LOC_92E {
 */
 
 
-//_SETPWRMODE_PARM
+/* _SETPWRMODE_PARM */
 #define SET_8192E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8192E_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 #define GET_8192E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)						LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
-//_P2P_PS_OFFLOAD
+/* _P2P_PS_OFFLOAD */
 #define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
@@ -118,31 +114,29 @@ typedef struct _RSVDPAGE_LOC_92E {
 #define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
 
 
-// host message to firmware cmd
+/* host message to firmware cmd */
 void rtl8192e_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8192e_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
 u8 rtl8192e_set_rssi_cmd(PADAPTER padapter, u8 *param);
-void rtl8192e_set_raid_cmd(PADAPTER padapter, u32 bitmap, u8* arg);
-void rtl8192e_Add_RateATid(PADAPTER padapter, u64 rate_bitmap, u8 *arg, u8 rssi_level);
 s32 FillH2CCmd_8192E(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 u8 GetTxBufferRsvdPageNum8192E(_adapter *padapter, bool wowlan);
-//u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period);
-s32 c2h_handler_8192e(PADAPTER padapter, u8 *buf);
+/* u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period); */
+s32 c2h_handler_8192e(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
 #ifdef CONFIG_BT_COEXIST
-void rtl8192e_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
-#endif // CONFIG_BT_COEXIST
+	void rtl8192e_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
 #ifdef CONFIG_P2P_PS
-void rtl8192e_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
-#endif //CONFIG_P2P
-
-void CheckFwRsvdPageContent(PADAPTER padapter);
+	void rtl8192e_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
 
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-int reset_tsf(PADAPTER Adapter, u8 reset_port );
-#endif	// CONFIG_TSF_RESET_OFFLOAD
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8192e_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
 
-/// TX Feedback Content
-#define 	USEC_UNIT_FOR_8192E_C2H_TX_RPT_QUEUE_TIME			256
+/* / TX Feedback Content */
+#define	USEC_UNIT_FOR_8192E_C2H_TX_RPT_QUEUE_TIME			256
 
 #define	GET_8192E_C2H_TX_RPT_QUEUE_SELECT(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 5)
 #define	GET_8192E_C2H_TX_RPT_PKT_BROCAST(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 5, 1)
@@ -150,22 +144,7 @@ int reset_tsf(PADAPTER Adapter, u8 reset_port );
 #define	GET_8192E_C2H_TX_RPT_RETRY_OVER(_Header)				LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
 #define	GET_8192E_C2H_TX_RPT_MAC_ID(_Header)					LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
 #define	GET_8192E_C2H_TX_RPT_DATA_RETRY_CNT(_Header)		LE_BITS_TO_1BYTE((_Header + 2), 0, 6)
-#define	GET_8192E_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	// In unit of 256 microseconds.
+#define	GET_8192E_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	/* In unit of 256 microseconds. */
 #define	GET_8192E_C2H_TX_RPT_FINAL_DATA_RATE(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
 
-
-
-void C2HContentParsing8192E(
-	IN	PADAPTER		Adapter,
-	IN	u1Byte			c2hCmdId, 
-	IN	u1Byte			c2hCmdLen,
-	IN	pu1Byte 			tmpBuf
-);
-VOID
-C2HPacketHandler_8192E(
-	IN	PADAPTER		Adapter,
-	IN	pu1Byte			Buffer,
-	IN	u1Byte			Length
-);
-
-#endif//__RTL8192E_CMD_H__
\ No newline at end of file
+#endif /* __RTL8192E_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_dm.h
index bb4f7a5ef3fd..555faff59152 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8192E_DM_H__
 #define __RTL8192E_DM_H__
 
@@ -26,13 +22,8 @@ void rtl8192e_deinit_dm_priv(IN PADAPTER Adapter);
 void rtl8192e_InitHalDm(IN PADAPTER Adapter);
 void rtl8192e_HalDmWatchDog(IN PADAPTER Adapter);
 
-//VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter);
+/* VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter); */
 
-//void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal);
+/* void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal); */
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-void	AntDivCompare8192e(PADAPTER Adapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
-u8 AntDivBeforeLink8192e(PADAPTER Adapter );
 #endif
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_hal.h
index 97b8f19381ce..d06f4191c2b8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_hal.h
@@ -1,350 +1,329 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8192E_HAL_H__
-#define __RTL8192E_HAL_H__
-
-//#include "hal_com.h"
-
-#include "hal_data.h"
-
-//include HAL Related header after HAL Related compiling flags 
-#include "rtl8192e_spec.h"
-#include "rtl8192e_rf.h"
-#include "rtl8192e_dm.h"
-#include "rtl8192e_recv.h"
-#include "rtl8192e_xmit.h"
-#include "rtl8192e_cmd.h"
-#include "rtl8192e_led.h"
-#include "Hal8192EPwrSeq.h"
-#include "Hal8192EPhyReg.h"
-#include "Hal8192EPhyCfg.h"
-
-
-#ifdef DBG_CONFIG_ERROR_DETECT
-#include "rtl8192e_sreset.h"
-#endif
-
-
-//---------------------------------------------------------------------
-//		RTL8192E From header
-//---------------------------------------------------------------------
-	#define RTL8192E_FW_IMG					"rtl8192e/FW_NIC.bin"
-	#define RTL8192E_FW_WW_IMG				"rtl8192e/FW_WoWLAN.bin"
-	#define RTL8192E_PHY_REG					"rtl8192e/PHY_REG.txt" 
-	#define RTL8192E_PHY_RADIO_A				"rtl8192e/RadioA.txt"
-	#define RTL8192E_PHY_RADIO_B				"rtl8192e/RadioB.txt"
-	#define RTL8192E_TXPWR_TRACK				"rtl8192e/TxPowerTrack.txt"
-	#define RTL8192E_AGC_TAB					"rtl8192e/AGC_TAB.txt"
-	#define RTL8192E_PHY_MACREG 				"rtl8192e/MAC_REG.txt"
-	#define RTL8192E_PHY_REG_PG				"rtl8192e/PHY_REG_PG.txt"
-	#define RTL8192E_PHY_REG_MP 				"rtl8192e/PHY_REG_MP.txt" 
-	#define RTL8192E_TXPWR_LMT					"rtl8192e/TXPWR_LMT.txt"
-	#define RTL8192E_WIFI_ANT_ISOLATION		"rtl8192e/wifi_ant_isolation.txt"
-
-//---------------------------------------------------------------------
-//		RTL8192E Power Configuration CMDs for PCIe interface
-//---------------------------------------------------------------------
-#define Rtl8192E_NIC_PWR_ON_FLOW				rtl8192E_power_on_flow
-#define Rtl8192E_NIC_RF_OFF_FLOW				rtl8192E_radio_off_flow
-#define Rtl8192E_NIC_DISABLE_FLOW				rtl8192E_card_disable_flow
-#define Rtl8192E_NIC_ENABLE_FLOW				rtl8192E_card_enable_flow
-#define Rtl8192E_NIC_SUSPEND_FLOW				rtl8192E_suspend_flow
-#define Rtl8192E_NIC_RESUME_FLOW				rtl8192E_resume_flow
-#define Rtl8192E_NIC_PDN_FLOW					rtl8192E_hwpdn_flow
-#define Rtl8192E_NIC_LPS_ENTER_FLOW			rtl8192E_enter_lps_flow
-#define Rtl8192E_NIC_LPS_LEAVE_FLOW			rtl8192E_leave_lps_flow	
-
-
-#if 1 // download firmware related data structure
-#define FW_SIZE_8192E			0x8000 // Compatible with RTL8192e Maximal RAM code size 32k
-#define FW_START_ADDRESS		0x1000
-#define FW_END_ADDRESS			0x5FFF
-
-
-#define IS_FW_HEADER_EXIST_8192E(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8192E(_pFwHdr) &0xFFF0) ==  0x92E0)
-
-
-
-typedef struct _RT_FIRMWARE_8192E {
-	FIRMWARE_SOURCE	eFWSource;
-#ifdef CONFIG_EMBEDDED_FWIMG
-	u8*			szFwBuffer;
-#else
-	u8			szFwBuffer[FW_SIZE_8192E];
-#endif
-	u32			ulFwLength;
-} RT_FIRMWARE_8192E, *PRT_FIRMWARE_8192E;
-
-//
-// This structure must be cared byte-ordering
-//
-// Added by tynli. 2009.12.04.
-
-//=====================================================
-//					Firmware Header(8-byte alinment required)
-//=====================================================
-//--- LONG WORD 0 ----
-#define GET_FIRMWARE_HDR_SIGNATURE_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16) // 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut
-#define GET_FIRMWARE_HDR_CATEGORY_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) // AP/NIC and USB/PCI
-#define GET_FIRMWARE_HDR_FUNCTION_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 24, 8) // Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions
-#define GET_FIRMWARE_HDR_VERSION_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)// FW Version
-#define GET_FIRMWARE_HDR_SUB_VER_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) // FW Subversion, default 0x00
-#define GET_FIRMWARE_HDR_RSVD1_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8) 		
-
-//--- LONG WORD 1 ----
-#define GET_FIRMWARE_HDR_MONTH_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 8) // Release time Month field
-#define GET_FIRMWARE_HDR_DATE_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 8, 8) // Release time Date field
-#define GET_FIRMWARE_HDR_HOUR_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 16, 8)// Release time Hour field
-#define GET_FIRMWARE_HDR_MINUTE_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 24, 8)// Release time Minute field
-#define GET_FIRMWARE_HDR_ROMCODE_SIZE_8192E(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+12, 0, 16)// The size of RAM code
-#define GET_FIRMWARE_HDR_RSVD2_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 16, 16)
-
-//--- LONG WORD 2 ----
-#define GET_FIRMWARE_HDR_SVN_IDX_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 0, 32)// The SVN entry index
-#define GET_FIRMWARE_HDR_RSVD3_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 0, 32)
-
-//--- LONG WORD 3 ----
-#define GET_FIRMWARE_HDR_RSVD4_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 0, 32)
-#define GET_FIRMWARE_HDR_RSVD5_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
-
-#endif // download firmware related data structure
-
-#define DRIVER_EARLY_INT_TIME_8192E		0x05
-#define BCN_DMA_ATIME_INT_TIME_8192E		0x02
-#define RX_DMA_SIZE_8192E					0x4000	/* 16K*/
-
-#ifdef CONFIG_WOWLAN
-#define RESV_FMWF	WKFMCAM_SIZE*MAX_WKFM_NUM /* 16 entries, for each is 24 bytes*/
-#else
-#define RESV_FMWF	0
-#endif
-
-#ifdef CONFIG_FW_C2H_DEBUG 
-	#define RX_DMA_RESERVED_SIZE_8192E	0x100	/* 256B, reserved for c2h debug message*/
-#else
-	#define RX_DMA_RESERVED_SIZE_8192E	0x40	/* 64B, reserved for c2h event(16bytes) or ccx(8 Bytes )*/
-#endif
-#define MAX_RX_DMA_BUFFER_SIZE_8192E		(RX_DMA_SIZE_8192E-RX_DMA_RESERVED_SIZE_8192E)	/*RX 16K*/
-
-//For General Reserved Page Number(Beacon Queue is reserved page)
-//if (CONFIG_2BCN_EN) Beacon:4, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1
-//Beacon:2, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1
-#define RSVD_PAGE_NUM_8192E		0x08
-//For WoWLan , more reserved page
-//ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, PNO: 6
-#ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_8192E	0x07
-#else
-#define WOWLAN_PAGE_NUM_8192E	0x00
-#endif
-
-#ifdef CONFIG_PNO_SUPPORT
-#undef WOWLAN_PAGE_NUM_8192E
-#define WOWLAN_PAGE_NUM_8192E	0x0d
-#endif
-
-/* Note: 
-Tx FIFO Size : 64KB
-Tx page Size : 256B
-Total page numbers : 256(0x100)
-*/
-
-#define	TOTAL_RSVD_PAGE_NUMBER_8192E 	(RSVD_PAGE_NUM_8192E+WOWLAN_PAGE_NUM_8192E)
-
-#define	TOTAL_PAGE_NUMBER_8192E	(0x100) 
-#define	TX_TOTAL_PAGE_NUMBER_8192E	(TOTAL_PAGE_NUMBER_8192E - TOTAL_RSVD_PAGE_NUMBER_8192E)
-
-#define	TX_PAGE_BOUNDARY_8192E	( TX_TOTAL_PAGE_NUMBER_8192E ) /* beacon header start address */
-
-
-#define PAGE_SIZE_TX_92E	PAGE_SIZE_256
-#define RSVD_PKT_LEN_92E	(TOTAL_RSVD_PAGE_NUMBER_8192E *PAGE_SIZE_TX_92E)
-
-#define TX_PAGE_LOAD_FW_BOUNDARY_8192E		0x47 //0xA5
-#define TX_PAGE_BOUNDARY_WOWLAN_8192E		0xE0
-
-// For Normal Chip Setting
-// (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_92C
-
-#define NORMAL_PAGE_NUM_HPQ_8192E			0x10
-#define NORMAL_PAGE_NUM_LPQ_8192E			0x10
-#define NORMAL_PAGE_NUM_NPQ_8192E			0x10
-#define NORMAL_PAGE_NUM_EPQ_8192E			0x00
-
-
-//Note: For WMM Normal Chip Setting ,modify later
-#define WMM_NORMAL_PAGE_NUM_HPQ_8192E		NORMAL_PAGE_NUM_HPQ_8192E
-#define WMM_NORMAL_PAGE_NUM_LPQ_8192E		NORMAL_PAGE_NUM_LPQ_8192E
-#define WMM_NORMAL_PAGE_NUM_NPQ_8192E		NORMAL_PAGE_NUM_NPQ_8192E
-
-
-//-------------------------------------------------------------------------
-//	Chip specific
-//-------------------------------------------------------------------------
-
-// pic buffer descriptor
-#define RTL8192EE_SEG_NUM			TX_BUFFER_SEG_NUM
-#define TX_DESC_NUM_92E			128
-#define RX_DESC_NUM_92E			128
-
-//-------------------------------------------------------------------------
-//	Channel Plan
-//-------------------------------------------------------------------------
-
-#define		HWSET_MAX_SIZE_8192E			512
-
-#define		EFUSE_REAL_CONTENT_LEN_8192E	512
-
-#define		EFUSE_MAP_LEN_8192E			512
-#define		EFUSE_MAX_SECTION_8192E		64
-#define		EFUSE_MAX_WORD_UNIT_8192E		4
-#define		EFUSE_IC_ID_OFFSET_8192E		506	//For some inferiority IC purpose. added by Roger, 2009.09.02.
-#define 		AVAILABLE_EFUSE_ADDR_8192E(addr) 	(addr < EFUSE_REAL_CONTENT_LEN_8192E)
-//
-// <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)	      |
-//
-#define		EFUSE_OOB_PROTECT_BYTES_8192E 		15	// PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte.
-
-
-
-//========================================================
-//			EFUSE for BT definition
-//========================================================
-#define		EFUSE_BT_REAL_BANK_CONTENT_LEN_8192E	512
-#define		EFUSE_BT_REAL_CONTENT_LEN_8192E			1024	// 512*2
-#define		EFUSE_BT_MAP_LEN_8192E					1024	// 1k bytes
-#define		EFUSE_BT_MAX_SECTION_8192E				128		// 1024/8
-
-#define		EFUSE_PROTECT_BYTES_BANK_8192E			16
-#define 		EFUSE_MAX_BANK_8192E					3
-//===========================================================
-
-#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)
-
-//#define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE)
-
-//#define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) )
-
-// rtl8812_hal_init.c
-void	_8051Reset8192E(PADAPTER padapter);
-s32	FirmwareDownload8192E(PADAPTER Adapter, BOOLEAN bUsedWoWLANFw);
-void	InitializeFirmwareVars8192E(PADAPTER padapter);
-
-s32	InitLLTTable8192E(PADAPTER padapter, u8 txpktbuf_bndy);
-
-// EFuse
-u8	GetEEPROMSize8192E(PADAPTER padapter);
-void	hal_InitPGData_8192E(PADAPTER padapter, u8* PROMContent);
-void	Hal_EfuseParseIDCode8192E(PADAPTER padapter, u8 *hwinfo);
-void	Hal_ReadPROMVersion8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void	Hal_ReadPowerSavingMode8192E(PADAPTER padapter, u8*	hwinfo, BOOLEAN	AutoLoadFail);
-void	Hal_ReadTxPowerInfo8192E(PADAPTER padapter,u8* hwinfo,BOOLEAN	AutoLoadFail);
-void	Hal_ReadBoardType8192E(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-void	Hal_ReadThermalMeter_8192E(PADAPTER	Adapter,u8* PROMContent,BOOLEAN 	AutoloadFail);
-void	Hal_ReadChannelPlan8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void	Hal_EfuseParseXtal_8192E(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-void	Hal_ReadAntennaDiversity8192E(PADAPTER pAdapter,u8* PROMContent,BOOLEAN AutoLoadFail);
-void	Hal_ReadPAType_8192E(PADAPTER Adapter,u8* PROMContent, BOOLEAN AutoloadFail);
-void	Hal_ReadAmplifierType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
-void	Hal_ReadRFEType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
-void	Hal_EfuseParseBTCoexistInfo8192E(PADAPTER Adapter, u8* hwinfo, BOOLEAN AutoLoadFail);
-void	Hal_EfuseParseKFreeData_8192E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-
-u8 Hal_CrystalAFEAdjust(_adapter * Adapter);
-
-BOOLEAN HalDetectPwrDownMode8192E(PADAPTER Adapter);
-	
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-void Hal_DetectWoWMode(PADAPTER pAdapter);
-#endif //CONFIG_WOWLAN
-
-/***********************************************************/
-// RTL8192E-MAC Setting
-VOID _InitQueueReservedPage_8192E(IN  PADAPTER Adapter);
-VOID _InitQueuePriority_8192E(IN	PADAPTER Adapter);
-VOID _InitTxBufferBoundary_8192E(IN PADAPTER Adapter,IN u8 txpktbuf_bndy);
-VOID _InitPageBoundary_8192E(IN PADAPTER Adapter);
-//VOID _InitTransferPageSize_8192E(IN PADAPTER Adapter);
-VOID _InitDriverInfoSize_8192E(IN PADAPTER Adapter,IN u8 drvInfoSize);
-VOID _InitRDGSetting_8192E(PADAPTER Adapter);
-void _InitID_8192E(IN  PADAPTER Adapter);
-VOID _InitNetworkType_8192E(IN  PADAPTER Adapter);
-VOID _InitWMACSetting_8192E(IN PADAPTER Adapter);
-VOID _InitAdaptiveCtrl_8192E(IN  PADAPTER Adapter);

-VOID _InitRateFallback_8192E(IN  PADAPTER Adapter);
-VOID _InitEDCA_8192E( IN  PADAPTER Adapter);
-VOID _InitRetryFunction_8192E(	IN  PADAPTER Adapter);
-VOID _BBTurnOnBlock_8192E(IN	PADAPTER Adapter);
-VOID _InitBeaconParameters_8192E(IN  PADAPTER Adapter);
-VOID _InitBeaconMaxError_8192E(
-	IN  PADAPTER	Adapter,
-	IN	BOOLEAN		InfraMode
-	);
-void SetBeaconRelatedRegisters8192E(PADAPTER padapter);
-VOID hal_ReadRFType_8192E(PADAPTER	Adapter);
-// RTL8192E-MAC Setting
-/***********************************************************/
-
-void SetHwReg8192E(PADAPTER Adapter, u8 variable, u8* val);
-void GetHwReg8192E(PADAPTER Adapter, u8 variable, u8* val);
-u8
-SetHalDefVar8192E(
-	IN	PADAPTER				Adapter,
-	IN	HAL_DEF_VARIABLE		eVariable,
-	IN	PVOID					pValue
-	);
-u8
-GetHalDefVar8192E(
-	IN	PADAPTER				Adapter,
-	IN	HAL_DEF_VARIABLE		eVariable,
-	IN	PVOID					pValue
-	);
-
-void rtl8192e_set_hal_ops(struct hal_ops *pHalFunc);
-void init_hal_spec_8192e(_adapter *adapter);
-void rtl8192e_init_default_value(_adapter * padapter);
-// register
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
-
-void rtl8192e_start_thread(_adapter *padapter);
-void rtl8192e_stop_thread(_adapter *padapter);
-
-#ifdef CONFIG_PCI_HCI
-BOOLEAN	InterruptRecognized8192EE(PADAPTER Adapter);
-u16	get_txdesc_buf_addr(u16 ff_hwaddr);
-#endif
-
-#ifdef CONFIG_SDIO_HCI
-#ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT
-void _init_available_page_threshold(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
-#endif
-#endif
-
-#ifdef CONFIG_BT_COEXIST
-void rtl8192e_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
-#endif
-
-#endif //__RTL8192E_HAL_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_HAL_H__
+#define __RTL8192E_HAL_H__
+
+/* #include "hal_com.h" */
+
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8192e_spec.h"
+#include "rtl8192e_rf.h"
+#include "rtl8192e_dm.h"
+#include "rtl8192e_recv.h"
+#include "rtl8192e_xmit.h"
+#include "rtl8192e_cmd.h"
+#include "rtl8192e_led.h"
+#include "Hal8192EPwrSeq.h"
+#include "Hal8192EPhyReg.h"
+#include "Hal8192EPhyCfg.h"
+
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8192e_sreset.h"
+#endif
+
+/* ---------------------------------------------------------------------
+ *		RTL8192E Power Configuration CMDs for PCIe interface
+ * --------------------------------------------------------------------- */
+#define Rtl8192E_NIC_PWR_ON_FLOW				rtl8192E_power_on_flow
+#define Rtl8192E_NIC_RF_OFF_FLOW				rtl8192E_radio_off_flow
+#define Rtl8192E_NIC_DISABLE_FLOW				rtl8192E_card_disable_flow
+#define Rtl8192E_NIC_ENABLE_FLOW				rtl8192E_card_enable_flow
+#define Rtl8192E_NIC_SUSPEND_FLOW				rtl8192E_suspend_flow
+#define Rtl8192E_NIC_RESUME_FLOW				rtl8192E_resume_flow
+#define Rtl8192E_NIC_PDN_FLOW					rtl8192E_hwpdn_flow
+#define Rtl8192E_NIC_LPS_ENTER_FLOW			rtl8192E_enter_lps_flow
+#define Rtl8192E_NIC_LPS_LEAVE_FLOW			rtl8192E_leave_lps_flow
+
+
+#if 1 /* download firmware related data structure */
+#define FW_SIZE_8192E			0x8000 /* Compatible with RTL8192e Maximal RAM code size 32k */
+#define FW_START_ADDRESS		0x1000
+#define FW_END_ADDRESS			0x5FFF
+
+
+#define IS_FW_HEADER_EXIST_8192E(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8192E(_pFwHdr) & 0xFFF0) == 0x92E0)
+
+
+
+typedef struct _RT_FIRMWARE_8192E {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_SIZE_8192E];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8192E, *PRT_FIRMWARE_8192E;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+
+/* *****************************************************
+ *					Firmware Header(8-byte alinment required)
+ * *****************************************************
+ * --- LONG WORD 0 ---- */
+#define GET_FIRMWARE_HDR_SIGNATURE_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16) /* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut */
+#define GET_FIRMWARE_HDR_CATEGORY_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) /* AP/NIC and USB/PCI */
+#define GET_FIRMWARE_HDR_FUNCTION_8192E(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 24, 8) /* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions */
+#define GET_FIRMWARE_HDR_VERSION_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)/* FW Version */
+#define GET_FIRMWARE_HDR_SUB_VER_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) /* FW Subversion, default 0x00 */
+#define GET_FIRMWARE_HDR_RSVD1_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8)
+
+/* --- LONG WORD 1 ---- */
+#define GET_FIRMWARE_HDR_MONTH_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 8) /* Release time Month field */
+#define GET_FIRMWARE_HDR_DATE_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 8, 8) /* Release time Date field */
+#define GET_FIRMWARE_HDR_HOUR_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 16, 8)/* Release time Hour field */
+#define GET_FIRMWARE_HDR_MINUTE_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 24, 8)/* Release time Minute field */
+#define GET_FIRMWARE_HDR_ROMCODE_SIZE_8192E(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+12, 0, 16)/* The size of RAM code */
+#define GET_FIRMWARE_HDR_RSVD2_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 16, 16)
+
+/* --- LONG WORD 2 ---- */
+#define GET_FIRMWARE_HDR_SVN_IDX_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 0, 32)/* The SVN entry index */
+#define GET_FIRMWARE_HDR_RSVD3_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 0, 32)
+
+/* --- LONG WORD 3 ---- */
+#define GET_FIRMWARE_HDR_RSVD4_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 0, 32)
+#define GET_FIRMWARE_HDR_RSVD5_8192E(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
+
+#endif /* download firmware related data structure */
+
+#define DRIVER_EARLY_INT_TIME_8192E		0x05
+#define BCN_DMA_ATIME_INT_TIME_8192E		0x02
+#define RX_DMA_SIZE_8192E					0x4000	/* 16K*/
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8192E	0x100	/* 256B, reserved for c2h debug message*/
+#else
+	#define RX_DMA_RESERVED_SIZE_8192E	0x40	/* 64B, reserved for c2h event(16bytes) or ccx(8 Bytes)*/
+#endif
+#define MAX_RX_DMA_BUFFER_SIZE_8192E		(RX_DMA_SIZE_8192E-RX_DMA_RESERVED_SIZE_8192E)	/*RX 16K*/
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * if (CONFIG_2BCN_EN) Beacon:4, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1
+ * Beacon:2, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1 */
+#define RSVD_PAGE_NUM_8192E		0x08
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1,PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8192E	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8192E	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8192E
+	#define WOWLAN_PAGE_NUM_8192E	0x0d
+#endif
+
+/* Note:
+Tx FIFO Size : 64KB
+Tx page Size : 256B
+Total page numbers : 256(0x100)
+*/
+
+#define	TOTAL_RSVD_PAGE_NUMBER_8192E	(RSVD_PAGE_NUM_8192E + WOWLAN_PAGE_NUM_8192E)
+
+#define	TOTAL_PAGE_NUMBER_8192E	(0x100)
+#define	TX_TOTAL_PAGE_NUMBER_8192E	(TOTAL_PAGE_NUMBER_8192E - TOTAL_RSVD_PAGE_NUMBER_8192E)
+
+#define	TX_PAGE_BOUNDARY_8192E	(TX_TOTAL_PAGE_NUMBER_8192E) /* beacon header start address */
+
+
+#define PAGE_SIZE_TX_92E	PAGE_SIZE_256
+#define RSVD_PKT_LEN_92E	(TOTAL_RSVD_PAGE_NUMBER_8192E * PAGE_SIZE_TX_92E)
+
+#define TX_PAGE_LOAD_FW_BOUNDARY_8192E		0x47 /* 0xA5 */
+#define TX_PAGE_BOUNDARY_WOWLAN_8192E		0xE0
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_92C */
+
+#define NORMAL_PAGE_NUM_HPQ_8192E			0x10
+#define NORMAL_PAGE_NUM_LPQ_8192E			0x10
+#define NORMAL_PAGE_NUM_NPQ_8192E			0x10
+#define NORMAL_PAGE_NUM_EPQ_8192E			0x00
+
+
+/* Note: For WMM Normal Chip Setting ,modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8192E		NORMAL_PAGE_NUM_HPQ_8192E
+#define WMM_NORMAL_PAGE_NUM_LPQ_8192E		NORMAL_PAGE_NUM_LPQ_8192E
+#define WMM_NORMAL_PAGE_NUM_NPQ_8192E		NORMAL_PAGE_NUM_NPQ_8192E
+
+
+/* -------------------------------------------------------------------------
+ *	Chip specific
+ * ------------------------------------------------------------------------- */
+
+/* pic buffer descriptor */
+#define RTL8192EE_SEG_NUM			TX_BUFFER_SEG_NUM
+#define TX_DESC_NUM_92E			128
+#define RX_DESC_NUM_92E			128
+
+/* -------------------------------------------------------------------------
+ *	Channel Plan
+ * ------------------------------------------------------------------------- */
+
+#define		HWSET_MAX_SIZE_8192E			512
+
+#define		EFUSE_REAL_CONTENT_LEN_8192E	512
+
+#define		EFUSE_MAP_LEN_8192E			512
+#define		EFUSE_MAX_SECTION_8192E		64
+#define		EFUSE_MAX_WORD_UNIT_8192E		4
+#define		EFUSE_IC_ID_OFFSET_8192E		506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define		AVAILABLE_EFUSE_ADDR_8192E(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8192E)
+/*
+ * <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)	      |
+ *   */
+#define		EFUSE_OOB_PROTECT_BYTES_8192E 		15	/* PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte. */
+
+
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define		EFUSE_BT_REAL_BANK_CONTENT_LEN_8192E	512
+#define		EFUSE_BT_REAL_CONTENT_LEN_8192E			1024	/* 512*2 */
+#define		EFUSE_BT_MAP_LEN_8192E					1024	/* 1k bytes */
+#define		EFUSE_BT_MAX_SECTION_8192E				128		/* 1024/8 */
+
+#define		EFUSE_PROTECT_BYTES_BANK_8192E			16
+#define		EFUSE_MAX_BANK_8192E					3
+/* *********************************************************** */
+
+#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)
+
+/* #define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE) */
+
+/* #define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) ) */
+
+/* rtl8812_hal_init.c */
+void	_8051Reset8192E(PADAPTER padapter);
+s32	FirmwareDownload8192E(PADAPTER Adapter, BOOLEAN bUsedWoWLANFw);
+void	InitializeFirmwareVars8192E(PADAPTER padapter);
+
+s32	InitLLTTable8192E(PADAPTER padapter, u8 txpktbuf_bndy);
+
+/* EFuse */
+u8	GetEEPROMSize8192E(PADAPTER padapter);
+void	hal_InitPGData_8192E(PADAPTER padapter, u8 *PROMContent);
+void	Hal_EfuseParseIDCode8192E(PADAPTER padapter, u8 *hwinfo);
+void	Hal_ReadPROMVersion8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadPowerSavingMode8192E(PADAPTER padapter, u8	*hwinfo, BOOLEAN	AutoLoadFail);
+void	Hal_ReadTxPowerInfo8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+void	Hal_ReadBoardType8192E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadThermalMeter_8192E(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void	Hal_ReadChannelPlan8192E(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_EfuseParseXtal_8192E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadAntennaDiversity8192E(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void	Hal_ReadPAType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadAmplifierType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadRFEType_8192E(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_EfuseParseBTCoexistInfo8192E(PADAPTER Adapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_EfuseParseKFreeData_8192E(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+u8 Hal_CrystalAFEAdjust(_adapter *Adapter);
+
+BOOLEAN HalDetectPwrDownMode8192E(PADAPTER Adapter);
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+/***********************************************************/
+/* RTL8192E-MAC Setting */
+VOID _InitQueueReservedPage_8192E(IN  PADAPTER Adapter);
+VOID _InitQueuePriority_8192E(IN	PADAPTER Adapter);
+VOID _InitTxBufferBoundary_8192E(IN PADAPTER Adapter, IN u8 txpktbuf_bndy);
+VOID _InitPageBoundary_8192E(IN PADAPTER Adapter);
+/* VOID _InitTransferPageSize_8192E(IN PADAPTER Adapter); */
+VOID _InitDriverInfoSize_8192E(IN PADAPTER Adapter, IN u8 drvInfoSize);
+VOID _InitRDGSetting_8192E(PADAPTER Adapter);
+void _InitID_8192E(IN  PADAPTER Adapter);
+VOID _InitNetworkType_8192E(IN  PADAPTER Adapter);
+VOID _InitWMACSetting_8192E(IN PADAPTER Adapter);
+VOID _InitAdaptiveCtrl_8192E(IN  PADAPTER Adapter);
+VOID _InitEDCA_8192E(IN  PADAPTER Adapter);
+VOID _InitRetryFunction_8192E(IN  PADAPTER Adapter);
+VOID _BBTurnOnBlock_8192E(IN	PADAPTER Adapter);
+VOID _InitBeaconParameters_8192E(IN  PADAPTER Adapter);
+VOID _InitBeaconMaxError_8192E(
+	IN  PADAPTER	Adapter,
+	IN	BOOLEAN		InfraMode
+);
+void SetBeaconRelatedRegisters8192E(PADAPTER padapter);
+VOID hal_ReadRFType_8192E(PADAPTER	Adapter);
+/* RTL8192E-MAC Setting
+ ***********************************************************/
+
+u8 SetHwReg8192E(PADAPTER Adapter, u8 variable, u8 *val);
+void GetHwReg8192E(PADAPTER Adapter, u8 variable, u8 *val);
+u8
+SetHalDefVar8192E(
+	IN	PADAPTER				Adapter,
+	IN	HAL_DEF_VARIABLE		eVariable,
+	IN	PVOID					pValue
+);
+u8
+GetHalDefVar8192E(
+	IN	PADAPTER				Adapter,
+	IN	HAL_DEF_VARIABLE		eVariable,
+	IN	PVOID					pValue
+);
+
+void rtl8192e_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8192e(_adapter *adapter);
+void rtl8192e_init_default_value(_adapter *padapter);
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+
+void rtl8192e_start_thread(_adapter *padapter);
+void rtl8192e_stop_thread(_adapter *padapter);
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8192EE(PADAPTER Adapter);
+	u16	get_txbd_rw_reg(u16 ff_hwaddr);
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+	#ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT
+		void _init_available_page_threshold(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
+	#endif
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+	void rtl8192e_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
+#endif
+
+#endif /* __RTL8192E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_led.h
index 221e0aa2642c..b276d62b61c9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_led.h
@@ -1,41 +1,37 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8192E_LED_H__
-#define __RTL8192E_LED_H__
-
-
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
-#ifdef CONFIG_USB_HCI
-void rtl8192eu_InitSwLeds(PADAPTER padapter);
-void rtl8192eu_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_PCI_HCI
-void rtl8192ee_InitSwLeds(PADAPTER padapter);
-void rtl8192ee_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_SDIO_HCI
-void rtl8192es_InitSwLeds(PADAPTER padapter);
-void rtl8192es_DeInitSwLeds(PADAPTER padapter);
-#endif
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_LED_H__
+#define __RTL8192E_LED_H__
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8192eu_InitSwLeds(PADAPTER padapter);
+	void rtl8192eu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8192ee_InitSwLeds(PADAPTER padapter);
+	void rtl8192ee_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8192es_InitSwLeds(PADAPTER padapter);
+	void rtl8192es_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif
+#endif/*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_recv.h
index 766a677f2107..3ac9a03346a3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_recv.h
@@ -1,178 +1,180 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8192E_RECV_H__
-#define __RTL8192E_RECV_H__
-
-#if defined(CONFIG_USB_HCI)
-
-#ifndef MAX_RECVBUF_SZ
-#ifdef PLATFORM_OS_CE
-#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-#else
-	#ifdef CONFIG_MINIMAL_MEMORY_USAGE
-		#define MAX_RECVBUF_SZ (4000) // about 4K
-	#else
-		#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
-			#define MAX_RECVBUF_SZ (rtw_rtkm_get_buff_size()) /*depend rtkm*/
-		#elif defined(CONFIG_PLATFORM_HISILICON)
-			#define MAX_RECVBUF_SZ (16384) /* 16k */
-		#else
-			#define MAX_RECVBUF_SZ (32768) /* 32k */
-		#endif
-		//#define MAX_RECVBUF_SZ (20480) //20K
-		//#define MAX_RECVBUF_SZ (10240) //10K 
-		//#define MAX_RECVBUF_SZ (16384) //  16k - 92E RX BUF :16K
-		//#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k		
-	#endif
-#endif
-#endif //!MAX_RECVBUF_SZ
-
-#elif defined(CONFIG_PCI_HCI)
-//#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-//	#define MAX_RECVBUF_SZ (9100)
-//#else
-	#define MAX_RECVBUF_SZ (4000) // about 4K
-//#endif
-
-
-#elif defined(CONFIG_SDIO_HCI)
-
-#define MAX_RECVBUF_SZ (16384)
-
-#endif
-
-
-// Rx smooth factor
-#define Rx_Smooth_Factor (20)
-
-//=============
-// [1] Rx Buffer Descriptor (for PCIE) buffer descriptor architecture
-//DWORD 0
-#define SET_RX_BUFFER_DESC_DATA_LENGTH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_BUFFER_DESC_LS_92E(__pRxStatusDesc,__Value)	SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 15, 1, __Value)
-#define SET_RX_BUFFER_DESC_FS_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 16, 1, __Value)
-#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 16, 15, __Value)
-
-#define GET_RX_BUFFER_DESC_OWN_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 31, 1)
-#define GET_RX_BUFFER_DESC_LS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 15, 1)
-#define GET_RX_BUFFER_DESC_FS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 1)
-#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 15)
-
-
-//DWORD 1
-#define SET_RX_BUFFER_PHYSICAL_LOW_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc+4, 0, 32, __Value)
-#define GET_RX_BUFFER_PHYSICAL_LOW_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 0, 32)
-
-//DWORD 2
-#define SET_RX_BUFFER_PHYSICAL_HIGH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc+8, 0, 32, __Value)
-
-//=============
-// [2] Rx Descriptor
-//DWORD 0
-#define GET_RX_STATUS_DESC_PKT_LEN_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 0, 14)
-#define GET_RX_STATUS_DESC_CRC32_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 14, 1)
-#define GET_RX_STATUS_DESC_ICVERR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 15, 1)
-#define GET_RX_STATUS_DESC_DRVINFO_SIZE_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 4)
-#define GET_RX_STATUS_DESC_SECURITY_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 20, 3)
-#define GET_RX_STATUS_DESC_QOS_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 23, 1)
-#define GET_RX_STATUS_DESC_SHIFT_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 24, 2)
-#define GET_RX_STATUS_DESC_PHY_STATUS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 26, 1)
-#define GET_RX_STATUS_DESC_SWDEC_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 27, 1)
-#define GET_RX_STATUS_DESC_EOR_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 30, 1)
-#define GET_RX_STATUS_DESC_OWN_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 31, 1)
-
-
-#define SET_RX_STATUS_DESC_PKT_LEN_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_STATUS_DESC_EOR_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 30, 1, __Value)
-#define SET_RX_STATUS_DESC_OWN_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 31, 1, __Value)
-
-//DWORD 1
-#define GET_RX_STATUS_DESC_MACID_92E(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
-#define GET_RX_STATUS_DESC_TID_92E(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
-#define GET_RX_STATUS_DESC_MACID_VLD_92E(__pRxDesc) 				LE_BITS_TO_4BYTE(__pRxDesc+4, 12, 1)
-#define GET_RX_STATUS_DESC_AMSDU_92E(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
-#define GET_RX_STATUS_DESC_RXID_MATCH_92E(__pRxDesc) 			LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
-#define GET_RX_STATUS_DESC_PAGGR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 15, 1)
-#define GET_RX_STATUS_DESC_A1_FITS_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 16, 4)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 20, 1)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 21, 1)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 22, 1)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 23, 1)
-#define GET_RX_STATUS_DESC_PAM_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 24, 1)
-#define GET_RX_STATUS_DESC_PWR_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 25, 1)
-#define GET_RX_STATUS_DESC_MORE_DATA_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 26, 1)
-#define GET_RX_STATUS_DESC_MORE_FRAG_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 27, 1)
-#define GET_RX_STATUS_DESC_TYPE_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 28, 2)
-#define GET_RX_STATUS_DESC_MC_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 30, 1)
-#define GET_RX_STATUS_DESC_BC_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 31, 1)
-
-//DWORD 2
-#define GET_RX_STATUS_DESC_SEQ_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 0, 12)
-#define GET_RX_STATUS_DESC_FRAG_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 12, 4)
-#define GET_RX_STATUS_DESC_RX_IS_QOS_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 16, 1)
-
-#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 18, 6)
-#define GET_RX_STATUS_DESC_HWRSVD_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 24, 4)
-#define GET_RX_STATUS_DESC_FCS_OK_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 31, 1)
-#define GET_RX_STATUS_DESC_RPT_SEL_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 28, 1)
-
-//DWORD 3
-#define GET_RX_STATUS_DESC_RX_RATE_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 0, 7)
-#define GET_RX_STATUS_DESC_HTC_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 10, 1)
-#define GET_RX_STATUS_DESC_EOSP_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 11, 1)
-#define GET_RX_STATUS_DESC_BSSID_FIT_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 12, 2)
-#define GET_RX_STATUS_DESC_DMA_AGG_NUM_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 16, 8)
-
-#define GET_RX_STATUS_DESC_PATTERN_MATCH_92E(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 29, 1)
-#define GET_RX_STATUS_DESC_UNICAST_92E(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 30, 1)
-#define GET_RX_STATUS_DESC_MAGIC_WAKE_92E(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 31, 1)
-
-
-//DWORD 5
-#define GET_RX_STATUS_DESC_TSFL_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+20, 0, 32)
-
-#define GET_RX_STATUS_DESC_BUFF_ADDR_92E(__pRxDesc) 		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
-#define GET_RX_STATUS_DESC_BUFF_ADDR64_92E(__pRxDesc) 		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
-
-
-#ifdef CONFIG_SDIO_HCI
-s32 rtl8192es_init_recv_priv(PADAPTER padapter);
-void rtl8192es_free_recv_priv(PADAPTER padapter);
-void rtl8192es_recv_hdl(PADAPTER padapter, struct recv_buf *precvbuf);
-#endif
-
-#ifdef CONFIG_USB_HCI
-void rtl8192eu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
-s32 rtl8192eu_init_recv_priv(PADAPTER padapter);
-void rtl8192eu_free_recv_priv(PADAPTER padapter);
-void rtl8192eu_recv_hdl(PADAPTER padapter, struct recv_buf *precvbuf);
-void rtl8192eu_recv_tasklet(void *priv);
-
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8192ee_init_recv_priv(PADAPTER padapter);
-void rtl8192ee_free_recv_priv(PADAPTER padapter);
-#endif
-
-void rtl8192e_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
-
-#endif /* __RTL8192E_RECV_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_RECV_H__
+#define __RTL8192E_RECV_H__
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifdef CONFIG_MINIMAL_MEMORY_USAGE
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#else
+				#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+					#define MAX_RECVBUF_SZ (rtw_rtkm_get_buff_size()) /*depend rtkm*/
+				#elif defined(CONFIG_PLATFORM_HISILICON)
+					#define MAX_RECVBUF_SZ (16384) /* 16k */
+				#else
+					#define MAX_RECVBUF_SZ (32768) /* 32k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240)  */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16k - 92E RX BUF :16K */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k		 */
+				#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+					#undef MAX_RECVBUF_SZ
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI)
+
+	#define MAX_RECVBUF_SZ (16384)
+
+#endif
+
+
+/* Rx smooth factor */
+#define Rx_Smooth_Factor (20)
+
+/* *************
+ * [1] Rx Buffer Descriptor (for PCIE) buffer descriptor architecture
+ * DWORD 0 */
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_92E(__pRxStatusDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 15, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_FS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 1)
+#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+
+
+/* DWORD 1 */
+#define SET_RX_BUFFER_PHYSICAL_LOW_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+#define GET_RX_BUFFER_PHYSICAL_LOW_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 32)
+
+/* DWORD 2 */
+#define SET_RX_BUFFER_PHYSICAL_HIGH_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+
+/* *************
+ * [2] Rx Descriptor
+ * DWORD 0 */
+#define GET_RX_STATUS_DESC_PKT_LEN_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICVERR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_EOR_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+
+#define SET_RX_STATUS_DESC_PKT_LEN_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_92E(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_92E(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_92E(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_MACID_VLD_92E(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 12, 1)
+#define GET_RX_STATUS_DESC_AMSDU_92E(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FITS_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_92E(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_HWRSVD_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 24, 4)
+#define GET_RX_STATUS_DESC_FCS_OK_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+#define GET_RX_STATUS_DESC_RPT_SEL_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_92E(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#define GET_RX_STATUS_DESC_DMA_AGG_NUM_92E(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_WAKE_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_SPLCP_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+#define GET_RX_STATUS_DESC_LDPC_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+#define GET_RX_STATUS_DESC_STBC_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+#define GET_RX_STATUS_DESC_BW_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_92E(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_92E(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+
+#ifdef CONFIG_SDIO_HCI
+	s32 rtl8192es_init_recv_priv(PADAPTER padapter);
+	void rtl8192es_free_recv_priv(PADAPTER padapter);
+	s32 rtl8192es_recv_hdl(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	void rtl8192eu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+	s32 rtl8192eu_init_recv_priv(PADAPTER padapter);
+	void rtl8192eu_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8192ee_init_recv_priv(PADAPTER padapter);
+	void rtl8192ee_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8192e_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8192E_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_rf.h
index fec92256ce9d..3686c63fe2b4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,24 +12,18 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8192E_RF_H__
 #define __RTL8192E_RF_H__
 
 VOID
 PHY_RF6052SetBandwidth8192E(
 	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH		Bandwidth);
+	IN	enum channel_width		Bandwidth);
 
 
 int
 PHY_RF6052_Config_8192E(
-	IN	PADAPTER	Adapter	);
-
-#endif//__RTL8192E_RF_H__
+	IN	PADAPTER	Adapter);
 
+#endif/* __RTL8192E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_spec.h
index d6b63baf7740..2ff0768f5946 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_spec.h
@@ -1,328 +1,314 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
-#ifndef __RTL8192E_SPEC_H__
-#define __RTL8192E_SPEC_H__
-
-#include <drv_conf.h>
-
-
-//============================================================
-//       8192E Regsiter offset definition
-//============================================================
-
-//============================================================
-//
-//============================================================
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_SYS_SWR_CTRL1_8192E		0x0010	// 1 Byte        
-#define REG_SYS_SWR_CTRL2_8192E		0x0014	// 1 Byte      
-#define REG_AFE_CTRL1_8192E			0x0024
-#define REG_AFE_CTRL2_8192E			0x0028
-#define REG_AFE_CTRL3_8192E			0x002c
-
-#define REG_PAD_CTRL1_8192E			0x0064           
-#define REG_SDIO_CTRL_8192E			0x0070
-#define REG_OPT_CTRL_8192E				0x0074
-#define REG_RF_B_CTRL_8192E			0x0076
-#define REG_AFE_CTRL4_8192E			0x0078 
-#define REG_LDO_SWR_CTRL				0x007C
-#define REG_FW_DRV_MSG_8192E			0x0088
-#define REG_HMEBOX_E2_E3_8192E		0x008C
-#define REG_HIMR0_8192E				0x00B0
-#define REG_HISR0_8192E					0x00B4
-#define REG_HIMR1_8192E					0x00B8
-#define REG_HISR1_8192E					0x00BC
-
-#define REG_SYS_CFG1_8192E				0x00F0
-#define REG_SYS_CFG2_8192E				0x00FC 
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-#define REG_PKTBUF_DBG_ADDR 			(REG_PKTBUF_DBG_CTRL)
-#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
-#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
-#define REG_WOWLAN_WAKE_REASON		REG_MCUTST_WOWLAN
-
-#define REG_RSVD3_8192E					0x0168
-#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
-#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
-#define REG_C2HEVT_CMD_LEN_88XX		0x01AE
-
-#define REG_HMEBOX_EXT0_8192E			0x01F0
-#define REG_HMEBOX_EXT1_8192E			0x01F4
-#define REG_HMEBOX_EXT2_8192E			0x01F8
-#define REG_HMEBOX_EXT3_8192E			0x01FC
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_DWBCN0_CTRL             0x0208
-#define REG_DWBCN1_CTRL             0x0228
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_RXDMA_8192E					0x0290
-#define REG_EARLY_MODE_CONTROL_8192E		0x02BC
-
-#define REG_RSVD5_8192E					0x02F0
-#define REG_RSVD6_8192E					0x02F4
-#define REG_RSVD7_8192E					0x02F8
-#define REG_RSVD8_8192E					0x02FC
-
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
-#define	REG_PCIE_CTRL_REG_8192E			0x0300
-#define	REG_INT_MIG_8192E					0x0304	// Interrupt Migration 
-#define	REG_BCNQ_TXBD_DESA_8192E		0x0308	// TX Beacon Descriptor Address
-#define	REG_MGQ_TXBD_DESA_8192E			0x0310	// TX Manage Queue Descriptor Address
-#define	REG_VOQ_TXBD_DESA_8192E			0x0318	// TX VO Queue Descriptor Address
-#define	REG_VIQ_TXBD_DESA_8192E			0x0320	// TX VI Queue Descriptor Address
-#define	REG_BEQ_TXBD_DESA_8192E			0x0328	// TX BE Queue Descriptor Address
-#define	REG_BKQ_TXBD_DESA_8192E			0x0330	// TX BK Queue Descriptor Address
-#define	REG_RXQ_RXBD_DESA_8192E			0x0338	// RX Queue	Descriptor Address
-#define 	REG_HI0Q_TXBD_DESA_8192E			0x0340
-#define 	REG_HI1Q_TXBD_DESA_8192E			0x0348
-#define 	REG_HI2Q_TXBD_DESA_8192E			0x0350
-#define 	REG_HI3Q_TXBD_DESA_8192E			0x0358
-#define	REG_HI4Q_TXBD_DESA_8192E			0x0360
-#define 	REG_HI5Q_TXBD_DESA_8192E			0x0368
-#define 	REG_HI6Q_TXBD_DESA_8192E			0x0370
-#define 	REG_HI7Q_TXBD_DESA_8192E			0x0378
-#define	REG_MGQ_TXBD_NUM_8192E			0x0380
-#define	REG_RX_RXBD_NUM_8192E			0x0382
-#define	REG_VOQ_TXBD_NUM_8192E			0x0384
-#define	REG_VIQ_TXBD_NUM_8192E			0x0386
-#define	REG_BEQ_TXBD_NUM_8192E			0x0388
-#define	REG_BKQ_TXBD_NUM_8192E			0x038A
-#define	REG_HI0Q_TXBD_NUM_8192E			0x038C
-#define	REG_HI1Q_TXBD_NUM_8192E			0x038E
-#define	REG_HI2Q_TXBD_NUM_8192E			0x0390
-#define	REG_HI3Q_TXBD_NUM_8192E			0x0392
-#define	REG_HI4Q_TXBD_NUM_8192E			0x0394
-#define	REG_HI5Q_TXBD_NUM_8192E			0x0396
-#define	REG_HI6Q_TXBD_NUM_8192E			0x0398
-#define	REG_HI7Q_TXBD_NUM_8192E			0x039A
-#define	REG_TSFTIMER_HCI_8192E			0x039C
-
-//Read Write Point
-#define	REG_VOQ_TXBD_IDX_8192E			0x03A0
-#define	REG_VIQ_TXBD_IDX_8192E			0x03A4
-#define	REG_BEQ_TXBD_IDX_8192E			0x03A8
-#define	REG_BKQ_TXBD_IDX_8192E			0x03AC
-#define	REG_MGQ_TXBD_IDX_8192E			0x03B0
-#define	REG_RXQ_TXBD_IDX_8192E			0x03B4
-#define	REG_HI0Q_TXBD_IDX_8192E			0x03B8
-#define	REG_HI1Q_TXBD_IDX_8192E			0x03BC
-#define	REG_HI2Q_TXBD_IDX_8192E			0x03C0
-#define	REG_HI3Q_TXBD_IDX_8192E			0x03C4
-#define	REG_HI4Q_TXBD_IDX_8192E			0x03C8
-#define	REG_HI5Q_TXBD_IDX_8192E			0x03CC
-#define	REG_HI6Q_TXBD_IDX_8192E			0x03D0
-#define	REG_HI7Q_TXBD_IDX_8192E			0x03D4
-
-#define	REG_PCIE_HCPWM_8192EE			0x03D8 // ??????
-#define	REG_PCIE_HRPWM_8192EE			0x03DC	//PCIe RPWM // ??????
-#define	REG_DBI_WDATA_V1_8192E			0x03E8
-#define	REG_DBI_RDATA_V1_8192E			0x03EC
-#define	REG_DBI_FLAG_V1_8192E				0x03F0
-#define 	REG_MDIO_V1_8192E					0x3F4
-#define 	REG_PCIE_MIX_CFG_8192E				0x3F8
-
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-#define REG_TXBF_CTRL_8192E				0x042C
-#define REG_ARFR0_8192E					0x0444
-#define REG_ARFR1_8192E					0x044C
-#define REG_CCK_CHECK_8192E				0x0454
-#define REG_AMPDU_MAX_TIME_8192E			0x0456
-#define REG_BCNQ1_BDNY_8192E				0x0457
-
-#define REG_AMPDU_MAX_LENGTH_8192E	0x0458
-#define REG_WMAC_LBK_BUF_HD_8192E			0x045D
-#define REG_NDPA_OPT_CTRL_8192E		0x045F
-#define REG_DATA_SC_8192E				0x0483
-#ifdef CONFIG_WOWLAN
-#define REG_TXPKTBUF_IV_LOW             0x0484
-#define REG_TXPKTBUF_IV_HIGH            0x0488
-#endif
-#define REG_ARFR2_8192E					0x048C
-#define REG_ARFR3_8192E					0x0494
-#define REG_TXRPT_START_OFFSET			0x04AC
-#define REG_AMPDU_BURST_MODE_8192E	0x04BC
-#define REG_HT_SINGLE_AMPDU_8192E		0x04C7
-#define REG_MACID_PKT_DROP0_8192E		0x04D0
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-#define REG_CTWND_8192E					0x0572
-#define REG_SECONDARY_CCA_CTRL_8192E	0x0577
-#define REG_SCH_TXCMD_8192E			0x05F8
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-#define REG_MAC_CR_8192E				0x0600
-
-#define REG_MAC_TX_SM_STATE_8192E		0x06B4
-
-// Power
-#define REG_BFMER0_INFO_8192E			0x06E4
-#define REG_BFMER1_INFO_8192E			0x06EC
-#define REG_CSI_RPT_PARAM_BW20_8192E	0x06F4
-#define REG_CSI_RPT_PARAM_BW40_8192E	0x06F8
-#define REG_CSI_RPT_PARAM_BW80_8192E	0x06FC
-
-// Hardware Port 2
-#define REG_BFMEE_SEL_8192E				0x0714
-#define REG_SND_PTCL_CTRL_8192E		0x0718
-
-
-//-----------------------------------------------------
-//
-//	Redifine register definition for compatibility
-//
-//-----------------------------------------------------
-
-// TODO: use these definition when using REG_xxx naming rule.
-// NOTE: DO NOT Remove these definition. Use later.
-#define	ISR_8192E							REG_HISR0_8192E
-
-//----------------------------------------------------------------------------
-//       8192E IMR/ISR bits						(offset 0xB0,  8bits)
-//----------------------------------------------------------------------------
-#define	IMR_DISABLED_8192E					0
-// IMR DW0(0x00B0-00B3) Bit 0-31
-#define	IMR_TIMER2_8192E					BIT31		// Timeout interrupt 2
-#define	IMR_TIMER1_8192E					BIT30		// Timeout interrupt 1	
-#define	IMR_PSTIMEOUT_8192E				BIT29		// Power Save Time Out Interrupt
-#define	IMR_GTINT4_8192E					BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define	IMR_GTINT3_8192E					BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define	IMR_TXBCN0ERR_8192E				BIT26		// Transmit Beacon0 Error			
-#define	IMR_TXBCN0OK_8192E					BIT25		// Transmit Beacon0 OK			
-#define	IMR_TSF_BIT32_TOGGLE_8192E		BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define	IMR_BCNDMAINT0_8192E				BIT20		// Beacon DMA Interrupt 0			
-#define	IMR_BCNDERR0_8192E					BIT16		// Beacon Queue DMA OK0			
-#define	IMR_HSISR_IND_ON_INT_8192E		BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)
-#define	IMR_BCNDMAINT_E_8192E				BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define	IMR_ATIMEND_8192E					BIT12		// CTWidnow End or ATIM Window End
-#define	IMR_C2HCMD_8192E					BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define	IMR_CPWM2_8192E					BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_CPWM_8192E						BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_HIGHDOK_8192E					BIT7			// High Queue DMA OK	
-#define	IMR_MGNTDOK_8192E					BIT6			// Management Queue DMA OK	
-#define	IMR_BKDOK_8192E					BIT5			// AC_BK DMA OK		
-#define	IMR_BEDOK_8192E					BIT4			// AC_BE DMA OK	
-#define	IMR_VIDOK_8192E					BIT3			// AC_VI DMA OK		
-#define	IMR_VODOK_8192E					BIT2			// AC_VO DMA OK	
-#define	IMR_RDU_8192E						BIT1			// Rx Descriptor Unavailable	
-#define	IMR_ROK_8192E						BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define	IMR_BCNDMAINT7_8192E				BIT27		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT6_8192E				BIT26		// Beacon DMA Interrupt 6
-#define	IMR_BCNDMAINT5_8192E				BIT25		// Beacon DMA Interrupt 5
-#define	IMR_BCNDMAINT4_8192E				BIT24		// Beacon DMA Interrupt 4
-#define	IMR_BCNDMAINT3_8192E				BIT23		// Beacon DMA Interrupt 3
-#define	IMR_BCNDMAINT2_8192E				BIT22		// Beacon DMA Interrupt 2
-#define	IMR_BCNDMAINT1_8192E				BIT21		// Beacon DMA Interrupt 1
-#define	IMR_BCNDOK7_8192E					BIT20		// Beacon Queue DMA OK Interrup 7
-#define	IMR_BCNDOK6_8192E					BIT19		// Beacon Queue DMA OK Interrup 6
-#define	IMR_BCNDOK5_8192E					BIT18		// Beacon Queue DMA OK Interrup 5
-#define	IMR_BCNDOK4_8192E					BIT17		// Beacon Queue DMA OK Interrup 4
-#define	IMR_BCNDOK3_8192E					BIT16		// Beacon Queue DMA OK Interrup 3
-#define	IMR_BCNDOK2_8192E					BIT15		// Beacon Queue DMA OK Interrup 2
-#define	IMR_BCNDOK1_8192E					BIT14		// Beacon Queue DMA OK Interrup 1
-#define	IMR_ATIMEND_E_8192E				BIT13		// ATIM Window End Extension for Win7
-#define	IMR_TXERR_8192E					BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define	IMR_RXERR_8192E					BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define	IMR_TXFOVW_8192E					BIT9			// Transmit FIFO Overflow
-#define	IMR_RXFOVW_8192E					BIT8			// Receive FIFO Overflow
-
-//----------------------------------------------------------------------------
-//       8192E Auto LLT bits						(offset 0x224,  8bits)
-//----------------------------------------------------------------------------
-//224 REG_AUTO_LLT
-// move to hal_com_reg.h
-
-//----------------------------------------------------------------------------
-//       8192E Auto LLT bits						(offset 0x290,  32bits)
-//----------------------------------------------------------------------------
-#define BIT_DMA_MODE			BIT1
-#define BIT_USB_RXDMA_AGG_EN	BIT31
-
-//----------------------------------------------------------------------------
-//       8192E REG_SYS_CFG1						(offset 0xF0,  32bits)
-//----------------------------------------------------------------------------
-#define BIT_SPSLDO_SEL			BIT24
-
-
-//----------------------------------------------------------------------------
-//       8192E REG_CCK_CHECK						(offset 0x454,  8bits)
-//----------------------------------------------------------------------------
-#define BIT_BCN_PORT_SEL		BIT5
-
-//============================================================================
-//       Regsiter Bit and Content definition 
-//============================================================================
-
-//2 ACMHWCTRL 0x05C0
-#define	AcmHw_HwEn_8192E				BIT(0)
-#define	AcmHw_VoqEn_8192E				BIT(1)
-#define	AcmHw_ViqEn_8192E				BIT(2)
-#define	AcmHw_BeqEn_8192E				BIT(3)
-#define	AcmHw_VoqStatus_8192E			BIT(5)
-#define	AcmHw_ViqStatus_8192E			BIT(6)
-#define	AcmHw_BeqStatus_8192E			BIT(7)
-
-//========================================================
-// General definitions
-//========================================================
-
-#define MACID_NUM_8192E 128
-#define SEC_CAM_ENT_NUM_8192E 64
-#define NSS_NUM_8192E 2
-#define BAND_CAP_8192E (BAND_CAP_2G)
-#define BW_CAP_8192E (BW_CAP_20M | BW_CAP_40M)
-#define PROTO_CAP_8192E (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N)
-
-#endif //__RTL8192E_SPEC_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_SPEC_H__
+#define __RTL8192E_SPEC_H__
+
+#include <drv_conf.h>
+
+#define HAL_NAV_UPPER_UNIT_8192E		128		/* micro-second */
+
+/* ************************************************************
+ * 8192E Regsiter offset definition
+ * ************************************************************ */
+
+/* ************************************************************
+ *
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_SWR_CTRL1_8192E		0x0010	/* 1 Byte        */
+#define REG_SYS_SWR_CTRL2_8192E		0x0014	/* 1 Byte      */
+#define REG_AFE_CTRL1_8192E			0x0024
+#define REG_AFE_CTRL2_8192E			0x0028
+#define REG_AFE_CTRL3_8192E			0x002c
+
+#define REG_PAD_CTRL1_8192E			0x0064
+#define REG_SDIO_CTRL_8192E			0x0070
+#define REG_OPT_CTRL_8192E				0x0074
+#define REG_RF_B_CTRL_8192E			0x0076
+#define REG_AFE_CTRL4_8192E			0x0078
+#define REG_LDO_SWR_CTRL				0x007C
+#define REG_FW_DRV_MSG_8192E			0x0088
+#define REG_HMEBOX_E2_E3_8192E		0x008C
+#define REG_HIMR0_8192E				0x00B0
+#define REG_HISR0_8192E					0x00B4
+#define REG_HIMR1_8192E					0x00B8
+#define REG_HISR1_8192E					0x00BC
+
+#define REG_SYS_CFG1_8192E				0x00F0
+#define REG_SYS_CFG2_8192E				0x00FC
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_PKTBUF_DBG_ADDR			(REG_PKTBUF_DBG_CTRL)
+#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
+#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
+#define REG_WOWLAN_WAKE_REASON		REG_MCUTST_WOWLAN
+
+#define REG_RSVD3_8192E					0x0168
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_88XX		0x01AE
+
+#define REG_HMEBOX_EXT0_8192E			0x01F0
+#define REG_HMEBOX_EXT1_8192E			0x01F4
+#define REG_HMEBOX_EXT2_8192E			0x01F8
+#define REG_HMEBOX_EXT3_8192E			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_DWBCN0_CTRL             0x0208
+#define REG_DWBCN1_CTRL             0x0228
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_8192E					0x0290
+#define REG_EARLY_MODE_CONTROL_8192E		0x02BC
+
+#define REG_RSVD5_8192E					0x02F0
+#define REG_RSVD6_8192E					0x02F4
+#define REG_RSVD7_8192E					0x02F8
+#define REG_RSVD8_8192E					0x02FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8192E			0x0300
+#define	REG_INT_MIG_8192E					0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8192E		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8192E			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8192E			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8192E			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8192E			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8192E			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8192E			0x0338	/* RX Queue	Descriptor Address */
+#define	REG_HI0Q_TXBD_DESA_8192E			0x0340
+#define	REG_HI1Q_TXBD_DESA_8192E			0x0348
+#define	REG_HI2Q_TXBD_DESA_8192E			0x0350
+#define	REG_HI3Q_TXBD_DESA_8192E			0x0358
+#define	REG_HI4Q_TXBD_DESA_8192E			0x0360
+#define	REG_HI5Q_TXBD_DESA_8192E			0x0368
+#define	REG_HI6Q_TXBD_DESA_8192E			0x0370
+#define	REG_HI7Q_TXBD_DESA_8192E			0x0378
+#define	REG_MGQ_TXBD_NUM_8192E			0x0380
+#define	REG_RX_RXBD_NUM_8192E			0x0382
+#define	REG_VOQ_TXBD_NUM_8192E			0x0384
+#define	REG_VIQ_TXBD_NUM_8192E			0x0386
+#define	REG_BEQ_TXBD_NUM_8192E			0x0388
+#define	REG_BKQ_TXBD_NUM_8192E			0x038A
+#define	REG_HI0Q_TXBD_NUM_8192E			0x038C
+#define	REG_HI1Q_TXBD_NUM_8192E			0x038E
+#define	REG_HI2Q_TXBD_NUM_8192E			0x0390
+#define	REG_HI3Q_TXBD_NUM_8192E			0x0392
+#define	REG_HI4Q_TXBD_NUM_8192E			0x0394
+#define	REG_HI5Q_TXBD_NUM_8192E			0x0396
+#define	REG_HI6Q_TXBD_NUM_8192E			0x0398
+#define	REG_HI7Q_TXBD_NUM_8192E			0x039A
+#define	REG_TSFTIMER_HCI_8192E			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8192E			0x03A0
+#define	REG_VIQ_TXBD_IDX_8192E			0x03A4
+#define	REG_BEQ_TXBD_IDX_8192E			0x03A8
+#define	REG_BKQ_TXBD_IDX_8192E			0x03AC
+#define	REG_MGQ_TXBD_IDX_8192E			0x03B0
+#define	REG_RXQ_TXBD_IDX_8192E			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8192E			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8192E			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8192E			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8192E			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8192E			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8192E			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8192E			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8192E			0x03D4
+
+#define	REG_PCIE_HCPWM_8192EE			0x03D8 /* ?????? */
+#define	REG_PCIE_HRPWM_8192EE			0x03DC	/* PCIe RPWM */ /* ?????? */
+#define	REG_DBI_WDATA_V1_8192E			0x03E8
+#define	REG_DBI_RDATA_V1_8192E			0x03EC
+#define	REG_DBI_FLAG_V1_8192E				0x03F0
+#define	REG_MDIO_V1_8192E					0x3F4
+#define	REG_PCIE_MIX_CFG_8192E				0x3F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_TXBF_CTRL_8192E				0x042C
+#define REG_ARFR0_8192E					0x0444
+#define REG_ARFR1_8192E					0x044C
+#define REG_CCK_CHECK_8192E				0x0454
+#define REG_AMPDU_MAX_TIME_8192E			0x0456
+#define REG_BCNQ1_BDNY_8192E				0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8192E	0x0458
+#define REG_WMAC_LBK_BUF_HD_8192E			0x045D
+#define REG_NDPA_OPT_CTRL_8192E		0x045F
+#define REG_DATA_SC_8192E				0x0483
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_ARFR2_8192E					0x048C
+#define REG_ARFR3_8192E					0x0494
+#define REG_TXRPT_START_OFFSET			0x04AC
+#define REG_AMPDU_BURST_MODE_8192E	0x04BC
+#define REG_HT_SINGLE_AMPDU_8192E		0x04C7
+#define REG_MACID_PKT_DROP0_8192E		0x04D0
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_CTWND_8192E					0x0572
+#define REG_SECONDARY_CCA_CTRL_8192E	0x0577
+#define REG_SCH_TXCMD_8192E			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8192E				0x0600
+
+#define REG_MAC_TX_SM_STATE_8192E		0x06B4
+
+/* Power */
+#define REG_BFMER0_INFO_8192E			0x06E4
+#define REG_BFMER1_INFO_8192E			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8192E	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8192E	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8192E	0x06FC
+
+/* Hardware Port 2 */
+#define REG_BFMEE_SEL_8192E				0x0714
+#define REG_SND_PTCL_CTRL_8192E		0x0718
+
+
+/* -----------------------------------------------------
+ *
+ *	Redifine register definition for compatibility
+ *
+ * ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+ * NOTE: DO NOT Remove these definition. Use later. */
+#define	ISR_8192E							REG_HISR0_8192E
+
+/* ----------------------------------------------------------------------------
+ * 8192E IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8192E					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8192E					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8192E					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8192E				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8192E					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8192E					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8192E				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8192E					BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8192E		BIT(24)		/* TSF Timer BIT(32) toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8192E				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8192E					BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8192E		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8192E				BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8192E					BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8192E					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8192E					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8192E						BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8192E					BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8192E					BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8192E					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8192E					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8192E					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8192E					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8192E						BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8192E						BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8192E				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8192E				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8192E				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8192E				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8192E				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8192E				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8192E				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8192E					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8192E					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8192E					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8192E					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8192E					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8192E					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8192E					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8192E				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8192E					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8192E					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8192E					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8192E					BIT(8)			/* Receive FIFO Overflow */
+
+/* ----------------------------------------------------------------------------
+ * 8192E Auto LLT bits						(offset 0x224,  8bits)
+ * ----------------------------------------------------------------------------
+ * 224 REG_AUTO_LLT
+ * move to hal_com_reg.h */
+
+/* ----------------------------------------------------------------------------
+ * 8192E Auto LLT bits						(offset 0x290,  32bits)
+ * ---------------------------------------------------------------------------- */
+#define BIT_DMA_MODE			BIT(1)
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+
+/* ----------------------------------------------------------------------------
+ * 8192E REG_SYS_CFG1						(offset 0xF0,  32bits)
+ * ---------------------------------------------------------------------------- */
+#define BIT_SPSLDO_SEL			BIT(24)
+
+
+/* ----------------------------------------------------------------------------
+ * 8192E REG_CCK_CHECK						(offset 0x454,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+/* ****************************************************************************
+ * Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+/* 2 ACMHWCTRL 0x05C0 */
+#define	AcmHw_HwEn_8192E				BIT(0)
+#define	AcmHw_VoqEn_8192E				BIT(1)
+#define	AcmHw_ViqEn_8192E				BIT(2)
+#define	AcmHw_BeqEn_8192E				BIT(3)
+#define	AcmHw_VoqStatus_8192E			BIT(5)
+#define	AcmHw_ViqStatus_8192E			BIT(6)
+#define	AcmHw_BeqStatus_8192E			BIT(7)
+
+#endif /* __RTL8192E_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_sreset.h
index ea2f19f04cf0..60e6afae36ea 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_sreset.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,20 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL88812A_SRESET_H_
 #define _RTL8812A_SRESET_H_
 
 #include <rtw_sreset.h>
 
 #ifdef DBG_CONFIG_ERROR_DETECT
-extern void rtl8192e_sreset_xmit_status_check(_adapter *padapter);
-extern void rtl8192e_sreset_linked_status_check(_adapter *padapter);
+	extern void rtl8192e_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8192e_sreset_linked_status_check(_adapter *padapter);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_xmit.h
index 37e00887f007..fea8ea9c647f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8192e_xmit.h
@@ -1,451 +1,449 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8192E_XMIT_H__
-#define __RTL8192E_XMIT_H__
-
-typedef struct txdescriptor_8192e
-{
-	//Offset 0
-	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;
-
-	//Offset 4
-	u32 macid:6;
-	u32 rsvd0406:2;	
-	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;
-
-	//Offset 8
-	u32 rts_rc:6;
-	u32 data_rc:6;
-	u32 agg_en:1;
-	u32 rd_en:1;
-	u32 bar_rty_th:2;
-	u32 bk: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;
-
-	//Offset 12
-	u32 nextheadpage:8;
-	u32 tailpage:8;
-	u32 seq:12;
-	u32 cpu_handle:1;
-	u32 tag1:1;
-	u32 trigger_int:1;
-	u32 hwseq_en:1;
-
-	//Offset 16
-	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 pwr_status: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;
-
-	//Offset 20
-	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;
-
-	//Offset 24
-	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;
-
-	//Offset 28
-	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;
-}TXDESC_8192E, *PTXDESC_8192E; 
-
-
-
-//For 88e early mode
-#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
-#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
-#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
-#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
-#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
-#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
-#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
-
-//
-//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 QSEL_SHT			8
-#define RATE_ID_SHT			16
-#define NAVUSEHDR			BIT(20)
-#define SEC_TYPE_SHT 		22
-#define PKT_OFFSET_SHT		26
-
-//OFFSET 8
-#define AGG_EN				BIT(12)
-#define AGG_BK					BIT(16)
-#define AMPDU_DENSITY_SHT	20
-#define ANTSEL_A			BIT(24)
-#define ANTSEL_B			BIT(25)
-#define TX_ANT_CCK_SHT		26
-#define TX_ANTL_SHT			28
-#define TX_ANT_HT_SHT		30
-
-//OFFSET 12
-#define SEQ_SHT				16
-#define EN_HWSEQ			BIT(31)
-
-//OFFSET 16
-#define 	QOS                          BIT(6)
-#define	HW_SSN				BIT(7)
-#define 	USERATE			BIT(8)
-#define 	DISDATAFB			BIT(10)
-#define   CTS_2_SELF			BIT(11)
-#define	RTS_EN				BIT(12)
-#define	HW_RTS_EN			BIT(13)
-#define 	DATA_SHORT			BIT(24)
-#define 	PWR_STATUS_SHT	15
-#define 	DATA_SC_SHT		20
-#define 	DATA_BW			BIT(25)
-
-//OFFSET 20
-#define	RTY_LMT_EN			BIT(17)
-
-
-//OFFSET 20
-#define SGI					BIT(6)
-#define USB_TXAGG_NUM_SHT	24
-
-
-//=====Tx Desc Buffer content
-
-// config element for each tx buffer 
-/*
-#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 0, 16, __Valeu)
-#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 31, 1, __Valeu)
-#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+4, 0, 32, __Valeu)
-#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+8, 0, 32, __Valeu)
-*/
-#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
-#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
-#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
-#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+8, 0, 32, __Valeu)
-
-
-// Dword 0
-#define SET_TX_BUFF_DESC_LEN_0_92E(__pTxDesc, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 14, __Valeu)
-#define SET_TX_BUFF_DESC_PSB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
-#define SET_TX_BUFF_DESC_OWN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
-// Dword 1
-#define SET_TX_BUFF_DESC_ADDR_LOW_0_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
-#define GET_TX_DESC_TX_BUFFER_ADDRESS_92E(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+4, 0,32)
-
-
-// Dword 2
-#define SET_TX_BUFF_DESC_ADDR_HIGH_0_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0, 32, __Value)
-// Dword 3, RESERVED 
-
-
-//=====Tx Desc content
-// Dword 0
-#define SET_TX_DESC_PKT_SIZE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
-#define SET_TX_DESC_OFFSET_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
-#define SET_TX_DESC_BMC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
-#define SET_TX_DESC_HTC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
-#define SET_TX_DESC_LAST_SEG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
-#define SET_TX_DESC_FIRST_SEG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
-#define SET_TX_DESC_LINIP_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
-#define SET_TX_DESC_NO_ACM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
-#define SET_TX_DESC_GF_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
-#define SET_TX_DESC_OWN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
-#define GET_TX_DESC_OWN_92E(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
-
-// Dword 1
-#define SET_TX_DESC_MACID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
-#define SET_TX_DESC_QUEUE_SEL_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
-#define SET_TX_DESC_RDG_NAV_EXT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
-#define SET_TX_DESC_LSIG_TXOP_EN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
-#define SET_TX_DESC_PIFS_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
-#define SET_TX_DESC_RATE_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
-#define SET_TX_DESC_EN_DESC_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
-#define SET_TX_DESC_SEC_TYPE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
-#define SET_TX_DESC_PKT_OFFSET_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
-#define SET_TX_DESC_MORE_DATA_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
-#define SET_TX_DESC_TXOP_PS_CAP_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 30, 1, __Value)
-#define SET_TX_DESC_TXOP_PS_MODE_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 31, 1, __Value)
-
-
-// Dword 2
-#define SET_TX_DESC_PAID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value) 
-#define SET_TX_DESC_CCA_RTS_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
-#define SET_TX_DESC_AGG_ENABLE_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
-#define SET_TX_DESC_RDG_ENABLE_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
-#define SET_TX_DESC_NULL_0_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
-#define SET_TX_DESC_NULL_1_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
-#define SET_TX_DESC_BK_92E(__pTxDesc, __Value) 				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
-#define SET_TX_DESC_MORE_FRAG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
-#define SET_TX_DESC_RAW_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
-#define GET_TX_DESC_MORE_FRAG_92E(__pTxDesc)				LE_BITS_TO_4BYTE( __pTxDesc+8, 17, 1)
-#define SET_TX_DESC_SPE_RPT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
-#define SET_TX_DESC_AMPDU_DENSITY_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
-#define SET_TX_DESC_BT_NULL_92E(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
-#define SET_TX_DESC_GID_92E(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
-
-
-// Dword 3
-#define SET_TX_DESC_WHEADER_LEN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
-#define SET_TX_DESC_CHK_EN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
-#define SET_TX_DESC_EARLY_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
-#define SET_TX_DESC_HWSEQ_SEL_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
-#define SET_TX_DESC_USE_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
-#define SET_TX_DESC_DISABLE_RTS_FB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
-#define SET_TX_DESC_DISABLE_FB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
-#define SET_TX_DESC_CTS2SELF_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
-#define SET_TX_DESC_RTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
-#define SET_TX_DESC_HW_RTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
-#define SET_TX_DESC_HW_PORT_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 1, __Value)
-#define SET_TX_DESC_NAV_USE_HDR_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
-#define SET_TX_DESC_USE_MAX_LEN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
-#define SET_TX_DESC_MAX_AGG_NUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
-#define SET_TX_DESC_NDPA_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
-#define SET_TX_DESC_AMPDU_MAX_TIME_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
-
-// Dword 4
-#define SET_TX_DESC_TX_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
-#define SET_TX_DESC_TRY_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
-#define SET_TX_DESC_DATA_RATE_FB_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
-#define SET_TX_DESC_RTS_RATE_FB_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
-#define SET_TX_DESC_RETRY_LIMIT_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
-#define SET_TX_DESC_DATA_RETRY_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
-#define SET_TX_DESC_RTS_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
-#define SET_TX_DESC_PCTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
-#define SET_TX_DESC_PCTS_MASK_IDX_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
-
-
-// Dword 5
-#define SET_TX_DESC_DATA_SC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
-#define SET_TX_DESC_DATA_SHORT_92E(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
-#define SET_TX_DESC_DATA_BW_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
-#define SET_TX_DESC_DATA_LDPC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
-#define SET_TX_DESC_DATA_STBC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
-#define SET_TX_DESC_VCS_STBC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
-#define SET_TX_DESC_RTS_SHORT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
-#define SET_TX_DESC_RTS_SC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
-#define SET_TX_DESC_TX_ANT_92E(__pTxDesc,__Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
-#define SET_TX_DESC_TX_POWER_0_PSET_92E(__pTxDesc,__Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
-
-// Dword 6
-#define SET_TX_DESC_SW_DEFINE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
-#define SET_TX_DESC_MBSSID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
-#define SET_TX_DESC_ANTSEL_A_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
-#define SET_TX_DESC_ANTSEL_B_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
-#define SET_TX_DESC_ANTSEL_C_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
-#define SET_TX_DESC_ANTSEL_D_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
-
-// Dword 7
-#if(DEV_BUS_TYPE == RT_PCI_INTERFACE)
-#define SET_TX_DESC_TX_BUFFER_SIZE_92E(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
-#define SET_TX_DESC_TX_DESC_CHECKSUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#endif
-#define SET_TX_DESC_USB_TXAGG_NUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-
-
-//#define SET_TX_DESC_HWSEQ_EN_92E(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
-// Dword 8
-
-#define SET_TX_DESC_RTS_RC_92E(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
-#define SET_TX_DESC_BAR_RTY_TH_92E(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
-#define SET_TX_DESC_DATA_RC_92E(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
-#define SET_TX_DESC_EN_HWSEQ_92E(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
-#define SET_TX_DESC_NEXT_HEAD_PAGE_92E(__pTxDesc,__Value)(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
-#define SET_TX_DESC_TAIL_PAGE_92E(__pTxDesc,__Value)(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
-
-// Dword 9
-#define SET_TX_DESC_PADDING_LENGTH_92E(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
-#define SET_TX_DESC_TXBF_PATH_92E(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 11, 1, __Value)
-#define SET_TX_DESC_SEQ_92E(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
-#define SET_TX_DESC_FINAL_DATA_RATE_92E(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 8, __Value)
-
-
-#define SET_EARLYMODE_PKTNUM_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
-#define SET_EARLYMODE_LEN0_92E(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
-#define SET_EARLYMODE_LEN1_1_92E(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
-#define SET_EARLYMODE_LEN1_2_92E(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
-#define SET_EARLYMODE_LEN2_92E(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
-#define SET_EARLYMODE_LEN3_92E(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
-
-void rtl8192e_cal_txdesc_chksum(u8 *ptxdesc);
-
-#ifdef CONFIG_USB_HCI
-s32 rtl8192eu_init_xmit_priv(PADAPTER padapter);
-void rtl8192eu_free_xmit_priv(PADAPTER padapter);
-s32 rtl8192eu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8192eu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8192eu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-s32 rtl8192eu_xmit_buf_handler(PADAPTER padapter);
-#define hal_xmit_handler rtl8192eu_xmit_buf_handler
-void rtl8192eu_xmit_tasklet(void *priv);
-s32 rtl8192eu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8192ee_init_xmit_priv(PADAPTER padapter);
-void rtl8192ee_free_xmit_priv(PADAPTER padapter);
-struct xmit_buf *rtl8192ee_dequeue_xmitbuf(struct rtw_tx_ring *ring);
-s32	rtl8192ee_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-void	rtl8192ee_xmitframe_resume(_adapter *padapter);
-s32 rtl8192ee_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8192ee_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-void rtl8192ee_xmit_tasklet(void *priv);
-#endif
-
-#if defined(CONFIG_SDIO_HCI)||defined (CONFIG_GSPI_HCI)
-s32 rtl8192es_init_xmit_priv(PADAPTER padapter);
-void rtl8192es_free_xmit_priv(PADAPTER padapter);
-
-s32 rtl8192es_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8192es_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8192es_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-thread_return rtl8192es_xmit_thread(thread_context context);
-s32 rtl8192es_xmit_buf_handler(PADAPTER padapter);
-
-#ifdef CONFIG_SDIO_TX_TASKLET
-void rtl8192es_xmit_tasklet(void *priv);
-#endif
-#endif
-
-struct txrpt_ccx_92e {
-	/* offset 0 */
-	u8 tag1:1;
-	u8 pkt_num:3;
-	u8 txdma_underflow:1;
-	u8 int_bt:1;
-	u8 int_tri:1;
-	u8 int_ccx:1;
-
-	/* offset 1 */
-	u8 mac_id:6;
-	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;
-};
-
-#ifdef CONFIG_TX_EARLY_MODE
-void UpdateEarlyModeInfo8192E(struct xmit_priv *pxmitpriv,struct xmit_buf *pxmitbuf );
-#endif
- s32	rtl8192e_init_xmit_priv(_adapter *padapter);
-void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag,u8 *ptxdesc);
-
-void rtl8192e_fill_fake_txdesc(PADAPTER	padapter,u8*pDesc,u32 BufferLen,
-		u8 IsPsPoll,u8	IsBTQosNull, u8 bDataFrame);
-void rtl8192e_cal_txdesc_chksum(u8 *ptxdesc);
-
-u8	BWMapping_92E(PADAPTER Adapter, struct pkt_attrib *pattrib);
-u8	SCMapping_92E(PADAPTER Adapter, struct pkt_attrib	*pattrib);
-void fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
-void fill_txdesc_vcs(struct pkt_attrib *pattrib, u8 *ptxdesc);
-void fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
-void rtl8192e_fixed_rate(_adapter *padapter,u8 *ptxdesc);
-
-#endif //__RTL8192E_XMIT_H__
-
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192E_XMIT_H__
+#define __RTL8192E_XMIT_H__
+
+typedef struct txdescriptor_8192e {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	u32 macid:6;
+	u32 rsvd0406:2;
+	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;
+
+	/* Offset 8 */
+	u32 rts_rc:6;
+	u32 data_rc:6;
+	u32 agg_en:1;
+	u32 rd_en:1;
+	u32 bar_rty_th:2;
+	u32 bk: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;
+
+	/* Offset 12 */
+	u32 nextheadpage:8;
+	u32 tailpage:8;
+	u32 seq:12;
+	u32 cpu_handle:1;
+	u32 tag1:1;
+	u32 trigger_int:1;
+	u32 hwseq_en:1;
+
+	/* Offset 16 */
+	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 pwr_status: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;
+
+	/* Offset 20 */
+	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;
+
+	/* Offset 24 */
+	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;
+
+	/* Offset 28 */
+	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;
+} TXDESC_8192E, *PTXDESC_8192E;
+
+
+
+/* For 88e early mode */
+#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
+#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
+#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
+#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
+#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
+#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
+#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
+
+/*
+ * 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 QSEL_SHT			8
+#define RATE_ID_SHT			16
+#define NAVUSEHDR			BIT(20)
+#define SEC_TYPE_SHT		22
+#define PKT_OFFSET_SHT		26
+
+/* OFFSET 8 */
+#define AGG_EN				BIT(12)
+#define AGG_BK					BIT(16)
+#define AMPDU_DENSITY_SHT	20
+#define ANTSEL_A			BIT(24)
+#define ANTSEL_B			BIT(25)
+#define TX_ANT_CCK_SHT		26
+#define TX_ANTL_SHT			28
+#define TX_ANT_HT_SHT		30
+
+/* OFFSET 12 */
+#define SEQ_SHT				16
+#define EN_HWSEQ			BIT(31)
+
+/* OFFSET 16 */
+#define	QOS                          BIT(6)
+#define	HW_SSN				BIT(7)
+#define	USERATE			BIT(8)
+#define	DISDATAFB			BIT(10)
+#define   CTS_2_SELF			BIT(11)
+#define	RTS_EN				BIT(12)
+#define	HW_RTS_EN			BIT(13)
+#define	DATA_SHORT			BIT(24)
+#define	PWR_STATUS_SHT	15
+#define	DATA_SC_SHT		20
+#define	DATA_BW			BIT(25)
+
+/* OFFSET 20 */
+#define	RTY_LMT_EN			BIT(17)
+
+
+/* OFFSET 20 */
+#define SGI					BIT(6)
+#define USB_TXAGG_NUM_SHT	24
+
+
+/* *****Tx Desc Buffer content */
+
+/* config element for each tx buffer
+ *
+#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 0, 16, __Valeu)
+#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 31, 1, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+4, 0, 32, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+8, 0, 32, __Valeu)
+*/
+#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
+#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
+#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+8, 0, 32, __Valeu)
+
+
+/* Dword 0 */
+#define SET_TX_BUFF_DESC_LEN_0_92E(__pTxDesc, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 14, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+/* Dword 1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_DESC_TX_BUFFER_ADDRESS_92E(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+
+
+/* Dword 2 */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0, 32, __Value)
+/* Dword 3, RESERVED */
+
+
+/* *****Tx Desc content
+ * Dword 0 */
+#define SET_TX_DESC_PKT_SIZE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_LAST_SEG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+#define SET_TX_DESC_FIRST_SEG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_LINIP_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+#define SET_TX_DESC_NO_ACM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+#define SET_TX_DESC_OWN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+#define GET_TX_DESC_OWN_92E(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_CAP_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 30, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_MODE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 31, 1, __Value)
+
+
+/* Dword 2 */
+#define SET_TX_DESC_PAID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+#define SET_TX_DESC_CCA_RTS_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL_0_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL_1_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_92E(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define GET_TX_DESC_MORE_FRAG_92E(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc+8, 17, 1)
+#define SET_TX_DESC_SPE_RPT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_NULL_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_GID_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+
+/* Dword 3 */
+#define SET_TX_DESC_WHEADER_LEN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+#define SET_TX_DESC_CHK_EN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+#define SET_TX_DESC_EARLY_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HWSEQ_SEL_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_HW_PORT_ID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TRY_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_ENABLE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_92E(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_VCS_STBC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_TX_ANT_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
+#define SET_TX_DESC_TX_POWER_0_PSET_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_ANTSEL_A_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+#define SET_TX_DESC_ANTSEL_B_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+#define SET_TX_DESC_ANTSEL_C_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+#define SET_TX_DESC_ANTSEL_D_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	#define SET_TX_DESC_TX_BUFFER_SIZE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#else
+	#define SET_TX_DESC_TX_DESC_CHECKSUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+#define SET_TX_DESC_USB_TXAGG_NUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+
+/* #define SET_TX_DESC_HWSEQ_EN_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value) */
+/* Dword 8 */
+
+#define SET_TX_DESC_RTS_RC_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RTY_TH_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_EN_HWSEQ_92E(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#define SET_TX_DESC_NEXT_HEAD_PAGE_92E(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#define SET_TX_DESC_TAIL_PAGE_92E(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LENGTH_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_TXBF_PATH_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 11, 1, __Value)
+#define SET_TX_DESC_SEQ_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_FINAL_DATA_RATE_92E(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 8, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
+#define SET_EARLYMODE_LEN3_92E(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+void rtl8192e_cal_txdesc_chksum(u8 *ptxdesc);
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8192eu_init_xmit_priv(PADAPTER padapter);
+	void rtl8192eu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8192eu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192eu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8192eu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192eu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8192eu_xmit_buf_handler
+	void rtl8192eu_xmit_tasklet(void *priv);
+	s32 rtl8192eu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8192ee_init_xmit_priv(PADAPTER padapter);
+	void rtl8192ee_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8192ee_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	s32	rtl8192ee_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void	rtl8192ee_xmitframe_resume(_adapter *padapter);
+	s32 rtl8192ee_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192ee_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	void rtl8192ee_xmit_tasklet(void *priv);
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8192es_init_xmit_priv(PADAPTER padapter);
+	void rtl8192es_free_xmit_priv(PADAPTER padapter);
+
+	s32 rtl8192es_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192es_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8192es_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	thread_return rtl8192es_xmit_thread(thread_context context);
+	s32 rtl8192es_xmit_buf_handler(PADAPTER padapter);
+
+	#ifdef CONFIG_SDIO_TX_TASKLET
+		void rtl8192es_xmit_tasklet(void *priv);
+	#endif
+#endif
+
+struct txrpt_ccx_92e {
+	/* offset 0 */
+	u8 tag1:1;
+	u8 pkt_num:3;
+	u8 txdma_underflow:1;
+	u8 int_bt:1;
+	u8 int_tri:1;
+	u8 int_ccx:1;
+
+	/* offset 1 */
+	u8 mac_id:6;
+	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;
+};
+
+#ifdef CONFIG_TX_EARLY_MODE
+	void UpdateEarlyModeInfo8192E(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+s32	rtl8192e_init_xmit_priv(_adapter *padapter);
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, u8 *ptxdesc);
+
+void rtl8192e_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen,
+			       u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8192e_cal_txdesc_chksum(u8 *ptxdesc);
+
+u8	BWMapping_92E(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_92E(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+void fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+void fill_txdesc_vcs(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+void fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8192e_fixed_rate(_adapter *padapter, u8 *ptxdesc);
+
+#endif /* __RTL8192E_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_cmd.h
index ab4fe6c5521d..4e306baaec8a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_cmd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,54 +12,49 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8703B_CMD_H__
 #define __RTL8703B_CMD_H__
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD DEFINITION    ------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
-enum h2c_cmd_8703B{
-	//Common Class: 000
+enum h2c_cmd_8703B {
+	/* Common Class: 000 */
 	H2C_8703B_RSVD_PAGE = 0x00,
 	H2C_8703B_MEDIA_STATUS_RPT = 0x01,
 	H2C_8703B_SCAN_ENABLE = 0x02,
 	H2C_8703B_KEEP_ALIVE = 0x03,
-	H2C_8703B_DISCON_DECISION = 0x04,	
-	H2C_8703B_PSD_OFFLOAD = 0x05,	
-	H2C_8703B_AP_OFFLOAD = 0x08,	
-	H2C_8703B_BCN_RSVDPAGE = 0x09,	
-	H2C_8703B_PROBERSP_RSVDPAGE = 0x0A,	
-	H2C_8703B_FCS_RSVDPAGE = 0x10,	
-	H2C_8703B_FCS_INFO = 0x11,	
+	H2C_8703B_DISCON_DECISION = 0x04,
+	H2C_8703B_PSD_OFFLOAD = 0x05,
+	H2C_8703B_AP_OFFLOAD = 0x08,
+	H2C_8703B_BCN_RSVDPAGE = 0x09,
+	H2C_8703B_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8703B_FCS_RSVDPAGE = 0x10,
+	H2C_8703B_FCS_INFO = 0x11,
 	H2C_8703B_AP_WOW_GPIO_CTRL = 0x13,
 
-	//PoweSave Class: 001
+	/* PoweSave Class: 001 */
 	H2C_8703B_SET_PWR_MODE = 0x20,
 	H2C_8703B_PS_TUNING_PARA = 0x21,
 	H2C_8703B_PS_TUNING_PARA2 = 0x22,
-	H2C_8703B_P2P_LPS_PARAM = 0x23,	
-	H2C_8703B_P2P_PS_OFFLOAD = 0x24,	
-	H2C_8703B_PS_SCAN_ENABLE = 0x25,	
-	H2C_8703B_SAP_PS_ = 0x26,	
-	H2C_8703B_INACTIVE_PS_ = 0x27, //Inactive_PS
+	H2C_8703B_P2P_LPS_PARAM = 0x23,
+	H2C_8703B_P2P_PS_OFFLOAD = 0x24,
+	H2C_8703B_PS_SCAN_ENABLE = 0x25,
+	H2C_8703B_SAP_PS_ = 0x26,
+	H2C_8703B_INACTIVE_PS_ = 0x27, /* Inactive_PS */
 	H2C_8703B_FWLPS_IN_IPS_ = 0x28,
-	
-	//Dynamic Mechanism Class: 010
-	H2C_8703B_MACID_CFG = 0x40,	
-	H2C_8703B_TXBF = 0x41,	
-	H2C_8703B_RSSI_SETTING = 0x42,	
-	H2C_8703B_AP_REQ_TXRPT = 0x43,	
-	H2C_8703B_INIT_RATE_COLLECT = 0x44,	
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8703B_MACID_CFG = 0x40,
+	H2C_8703B_TXBF = 0x41,
+	H2C_8703B_RSSI_SETTING = 0x42,
+	H2C_8703B_AP_REQ_TXRPT = 0x43,
+	H2C_8703B_INIT_RATE_COLLECT = 0x44,
 	H2C_8703B_RA_PARA_ADJUST = 0x46,
-	
-	//BT Class: 011
+
+	/* BT Class: 011 */
 	H2C_8703B_B_TYPE_TDMA = 0x60,
 	H2C_8703B_BT_INFO = 0x61,
 	H2C_8703B_FORCE_BT_TXPWR = 0x62,
@@ -70,65 +66,66 @@ enum h2c_cmd_8703B{
 	H2C_8703B_BT_CONTROL = 0x68,
 	H2C_8703B_BT_WIFI_CTRL = 0x69,
 	H2C_8703B_BT_FW_PATCH = 0x6A,
-	H2C_8703B_BT_WLAN_CALIBRATION = 0x6D,	
-	
-	//WOWLAN Class: 100
+	H2C_8703B_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
 	H2C_8703B_WOWLAN = 0x80,
 	H2C_8703B_REMOTE_WAKE_CTRL = 0x81,
-	H2C_8703B_AOAC_GLOBAL_INFO = 0x82,	
-	H2C_8703B_AOAC_RSVD_PAGE = 0x83,	
+	H2C_8703B_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8703B_AOAC_RSVD_PAGE = 0x83,
 	H2C_8703B_AOAC_RSVD_PAGE2 = 0x84,
 	H2C_8703B_D0_SCAN_OFFLOAD_CTRL = 0x85,
 	H2C_8703B_D0_SCAN_OFFLOAD_INFO = 0x86,
 	H2C_8703B_CHNL_SWITCH_OFFLOAD = 0x87,
-	H2C_8703B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,	
+	H2C_8703B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
 	H2C_8703B_P2P_OFFLOAD = 0x8B,
 
 	H2C_8703B_RESET_TSF = 0xC0,
 	H2C_8703B_MAXID,
 };
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD CONTENT    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
-//_RSVDPAGE_LOC_CMD_0x00
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
 #define SET_8703B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8703B_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_8703B_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8703B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8703B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 
-//_KEEP_ALIVE_CMD_0x03
+/* _KEEP_ALIVE_CMD_0x03 */
 #define SET_8703B_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8703B_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8703B_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
 #define SET_8703B_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 
-//_DISCONNECT_DECISION_CMD_0x04
+/* _DISCONNECT_DECISION_CMD_0x04 */
 #define SET_8703B_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8703B_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8703B_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_8703B_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
 
-// _PWR_MOD_CMD_0x20
+/* _PWR_MOD_CMD_0x20 */
 #define SET_8703B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8703B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8703B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
-// _PS_TUNE_PARAM_CMD_0x21
+/* _PS_TUNE_PARAM_CMD_0x21 */
 #define SET_8703B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8703B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_8703B_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
 #define SET_8703B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
 #define SET_8703B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 
-//_MACID_CFG_CMD_0x40
+/* _MACID_CFG_CMD_0x40 */
 #define SET_8703B_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8703B_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
 #define SET_8703B_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
@@ -142,19 +139,19 @@ enum h2c_cmd_8703B{
 #define SET_8703B_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
 #define SET_8703B_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
 
-//_RSSI_SETTING_CMD_0x42
+/* _RSSI_SETTING_CMD_0x42 */
 #define SET_8703B_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8703B_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
 #define SET_8703B_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 
-// _AP_REQ_TXRPT_CMD_0x43
+/* _AP_REQ_TXRPT_CMD_0x43 */
 #define SET_8703B_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8703B_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 
-// _FORCE_BT_TXPWR_CMD_0x62
+/* _FORCE_BT_TXPWR_CMD_0x62 */
 #define SET_8703B_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 
-// _FORCE_BT_MP_OPER_CMD_0x67
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
 #define SET_8703B_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
 #define SET_8703B_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
 #define SET_8703B_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
@@ -162,52 +159,50 @@ enum h2c_cmd_8703B{
 #define SET_8703B_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 #define SET_8703B_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
 
-// _BT_FW_PATCH_0x6A
+/* _BT_FW_PATCH_0x6A */
 #define SET_8703B_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
-#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 
-#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 
-#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value) 
-#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8703B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
-//---------------------------------------------------------------------------------------------------------//
-//-------------------------------------------    Structure    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    Function Statement     --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
-// host message to firmware cmd
+/* host message to firmware cmd */
 void rtl8703b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8703b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
 void rtl8703b_set_rssi_cmd(PADAPTER padapter, u8 *param);
-void rtl8703b_Add_RateATid(PADAPTER pAdapter, u64 rate_bitmap, u8 *arg, u8 rssi_level);
 void rtl8703b_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
-//s32 rtl8703b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable);
+/* s32 rtl8703b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
 void rtl8703b_set_FwPsTuneParam_cmd(PADAPTER padapter);
-void rtl8703b_set_FwMacIdConfig_cmd(_adapter* padapter, u8 mac_id, u8 raid, u8 bw, u8 sgi, u32 mask);
 void rtl8703b_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param);
 void rtl8703b_download_rsvd_page(PADAPTER padapter, u8 mstatus);
 #ifdef CONFIG_BT_COEXIST
-void rtl8703b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
-#endif // CONFIG_BT_COEXIST
+	void rtl8703b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
 #ifdef CONFIG_P2P
-void rtl8703b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
-#endif //CONFIG_P2P
+	void rtl8703b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
 
-void CheckFwRsvdPageContent(PADAPTER padapter);
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8703b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
 
 #ifdef CONFIG_P2P_WOWLAN
-void rtl8703b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+	void rtl8703b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
 #endif
 
 void rtl8703b_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
 
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-u8 rtl8703b_reset_tsf(_adapter *padapter, u8 reset_port);
-#endif	// CONFIG_TSF_RESET_OFFLOAD
 s32 FillH2CCmd8703B(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 u8 GetTxBufferRsvdPageNum8703B(_adapter *padapter, bool wowlan);
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_dm.h
index 094adc85e101..1fe6a521d16b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,38 +12,29 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8703B_DM_H__
 #define __RTL8703B_DM_H__
-//============================================================
-// Description:
-//
-// This file is for 8703B dynamic mechanism only
-//
-//
-//============================================================
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8703B dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
 
-//============================================================
-// structure and define
-//============================================================
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
 
-//============================================================
-// function prototype
-//============================================================
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
 
 void rtl8703b_init_dm_priv(PADAPTER padapter);
 void rtl8703b_deinit_dm_priv(PADAPTER padapter);
 
 void rtl8703b_InitHalDm(PADAPTER padapter);
 void rtl8703b_HalDmWatchDog(PADAPTER padapter);
-void rtl8703b_HalDmWatchDog_in_LPS(PADAPTER padapter);
-void rtl8703b_hal_dm_in_lps(PADAPTER padapter);
-
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_hal.h
index 69a6dc5ff6f0..82c9a1505e17 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_hal.h
@@ -1,326 +1,275 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8703B_HAL_H__
-#define __RTL8703B_HAL_H__
-
-#include "hal_data.h"
-
-#include "rtl8703b_spec.h"
-#include "rtl8703b_rf.h"
-#include "rtl8703b_dm.h"
-#include "rtl8703b_recv.h"
-#include "rtl8703b_xmit.h"
-#include "rtl8703b_cmd.h"
-#include "rtl8703b_led.h"
-#include "Hal8703BPwrSeq.h"
-#include "Hal8703BPhyReg.h"
-#include "Hal8703BPhyCfg.h"
-#ifdef DBG_CONFIG_ERROR_DETECT
-#include "rtl8703b_sreset.h"
-#endif
-
-
-//---------------------------------------------------------------------
-//		RTL8703B From file
-//---------------------------------------------------------------------
-	#define RTL8703B_FW_IMG					"rtl8703b/FW_NIC.bin"
-	#define RTL8703B_FW_WW_IMG				"rtl8703b/FW_WoWLAN.bin"
-	#define RTL8703B_PHY_REG					"rtl8703b/PHY_REG.txt"
-	#define RTL8703B_PHY_RADIO_A				"rtl8703b/RadioA.txt"
-	#define RTL8703B_PHY_RADIO_B				"rtl8703b/RadioB.txt"
-	#define RTL8703B_TXPWR_TRACK				"rtl8703b/TxPowerTrack.txt" 
-	#define RTL8703B_AGC_TAB					"rtl8703b/AGC_TAB.txt"
-	#define RTL8703B_PHY_MACREG 				"rtl8703b/MAC_REG.txt"
-	#define RTL8703B_PHY_REG_PG				"rtl8703b/PHY_REG_PG.txt"
-	#define RTL8703B_PHY_REG_MP				"rtl8703b/PHY_REG_MP.txt"
-	#define RTL8703B_TXPWR_LMT 				"rtl8703b/TXPWR_LMT.txt"
-
-//---------------------------------------------------------------------
-//		RTL8703B From header
-//---------------------------------------------------------------------
-
-#if MP_DRIVER == 1
-	#define Rtl8703B_FwBTImgArray				Rtl8703BFwBTImgArray
-	#define Rtl8703B_FwBTImgArrayLength		Rtl8703BFwBTImgArrayLength
-
-	#define Rtl8703B_PHY_REG_Array_MP			Rtl8703B_PHYREG_Array_MP
-	#define Rtl8703B_PHY_REG_Array_MPLength	Rtl8703B_PHYREG_Array_MPLength
-#endif
-
-
-#define FW_8703B_SIZE			0x8000
-#define FW_8703B_START_ADDRESS	0x1000
-#define FW_8703B_END_ADDRESS		0x1FFF //0x5FFF
-
-#define IS_FW_HEADER_EXIST_8703B(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature)&0xFFF0) == 0x03B0)
-
-typedef struct _RT_FIRMWARE {
-	FIRMWARE_SOURCE	eFWSource;
-#ifdef CONFIG_EMBEDDED_FWIMG
-	u8*			szFwBuffer;
-#else
-	u8			szFwBuffer[FW_8703B_SIZE];
-#endif
-	u32			ulFwLength;
-} RT_FIRMWARE_8703B, *PRT_FIRMWARE_8703B;
-
-//
-// This structure must be cared byte-ordering
-//
-// Added by tynli. 2009.12.04.
-typedef struct _RT_8703B_FIRMWARE_HDR
-{
-	// 8-byte alinment required
-
-	//--- LONG WORD 0 ----
-	u16		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
-	u16		Version;		// FW Version
-	u16		Subversion;	// FW Subversion, default 0x00
-
-	//--- 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
-	u16		RamCodeSize;	// The size of RAM code
-	u16		Rsvd2;
-
-	//--- LONG WORD 2 ----
-	u32		SvnIdx;	// The SVN entry index
-	u32		Rsvd3;
-
-	//--- LONG WORD 3 ----
-	u32		Rsvd4;
-	u32		Rsvd5;
-}RT_8703B_FIRMWARE_HDR, *PRT_8703B_FIRMWARE_HDR;
-
-#define DRIVER_EARLY_INT_TIME_8703B		0x05
-#define BCN_DMA_ATIME_INT_TIME_8703B		0x02
-
-// for 8703B
-// TX 32K, RX 16K, Page size 128B for TX, 8B for RX
-#define PAGE_SIZE_TX_8703B			128
-#define PAGE_SIZE_RX_8703B			8
-
-#define TX_DMA_SIZE_8703B			0x8000	/* 32K(TX) */
-#define RX_DMA_SIZE_8703B			0x4000	/* 16K(RX) */
-
-#ifdef CONFIG_WOWLAN
-#define RESV_FMWF	WKFMCAM_SIZE*MAX_WKFM_NUM /* 16 entries, for each is 24 bytes*/
-#else
-#define RESV_FMWF	0
-#endif
-
-#ifdef CONFIG_FW_C2H_DEBUG 
-#define RX_DMA_RESERVED_SIZE_8703B	0x100	// 256B, reserved for c2h debug message
-#else
-#define RX_DMA_RESERVED_SIZE_8703B	0x80	// 128B, reserved for tx report
-#endif
-#define RX_DMA_BOUNDARY_8703B		(RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B - 1)
-
-
-// Note: We will divide number of page equally for each queue other than public queue!
-
-//For General Reserved Page Number(Beacon Queue is reserved page)
-//Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1
-#define BCNQ_PAGE_NUM_8703B		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-#define BCNQ1_PAGE_NUM_8703B		0x08 // 0x04
-#else
-#define BCNQ1_PAGE_NUM_8703B		0x00
-#endif
-
-#ifdef CONFIG_PNO_SUPPORT
-#undef BCNQ1_PAGE_NUM_8703B
-#define BCNQ1_PAGE_NUM_8703B		0x00 // 0x04
-#endif
-
-//For WoWLan , more reserved page
-//ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, PNO: 6
-#ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_8703B	0x07
-#else
-#define WOWLAN_PAGE_NUM_8703B	0x00
-#endif
-
-#ifdef CONFIG_PNO_SUPPORT
-#undef WOWLAN_PAGE_NUM_8703B
-#define WOWLAN_PAGE_NUM_8703B	0x15
-#endif
-
-#ifdef CONFIG_AP_WOWLAN
-#define AP_WOWLAN_PAGE_NUM_8703B	0x02
-#endif
-
-#define TX_TOTAL_PAGE_NUMBER_8703B	(0xFF - BCNQ_PAGE_NUM_8703B - BCNQ1_PAGE_NUM_8703B - WOWLAN_PAGE_NUM_8703B)
-#define TX_PAGE_BOUNDARY_8703B		(TX_TOTAL_PAGE_NUMBER_8703B + 1)
-
-#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B	TX_TOTAL_PAGE_NUMBER_8703B
-#define WMM_NORMAL_TX_PAGE_BOUNDARY_8703B		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B + 1)
-
-// For Normal Chip Setting
-// (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8703B
-#define NORMAL_PAGE_NUM_HPQ_8703B		0x0C
-#define NORMAL_PAGE_NUM_LPQ_8703B		0x02
-#define NORMAL_PAGE_NUM_NPQ_8703B		0x02
-
-// Note: For Normal Chip Setting, modify later
-#define WMM_NORMAL_PAGE_NUM_HPQ_8703B		0x30
-#define WMM_NORMAL_PAGE_NUM_LPQ_8703B		0x20
-#define WMM_NORMAL_PAGE_NUM_NPQ_8703B		0x20
-
-
-#include "HalVerDef.h"
-#include "hal_com.h"
-
-#define EFUSE_OOB_PROTECT_BYTES 		15
-
-#define HAL_EFUSE_MEMORY
-
-#define HWSET_MAX_SIZE_8703B			256
-#define EFUSE_REAL_CONTENT_LEN_8703B		256
-#define EFUSE_MAP_LEN_8703B				512
-#define EFUSE_MAX_SECTION_8703B			64
-
-#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_8703B)
-
-#define EFUSE_ACCESS_ON			0x69	
-#define EFUSE_ACCESS_OFF			0x00	
-
-//========================================================
-//			EFUSE for BT definition
-//========================================================
-#define BANK_NUM		1
-#define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
-#define EFUSE_BT_REAL_CONTENT_LEN		(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
-#define EFUSE_BT_MAP_LEN				1024	// 1k bytes
-#define EFUSE_BT_MAX_SECTION			(EFUSE_BT_MAP_LEN / 8)
-#define EFUSE_PROTECT_BYTES_BANK		16
-
-typedef struct _C2H_EVT_HDR
-{
-	u8	CmdID;
-	u8	CmdLen;
-	u8	CmdSeq;
-} __attribute__((__packed__)) C2H_EVT_HDR, *PC2H_EVT_HDR;
-
-typedef enum tag_Package_Definition
-{
-    PACKAGE_DEFAULT,
-    PACKAGE_QFN68,
-    PACKAGE_TFBGA90,
-    PACKAGE_TFBGA80,
-    PACKAGE_TFBGA79
-}PACKAGE_TYPE_E;
-
-#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)
-
-// rtl8703b_hal_init.c
-s32 rtl8703b_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
-void rtl8703b_FirmwareSelfReset(PADAPTER padapter);
-void rtl8703b_InitializeFirmwareVars(PADAPTER padapter);
-
-void rtl8703b_InitAntenna_Selection(PADAPTER padapter);
-void rtl8703b_DeinitAntenna_Selection(PADAPTER padapter);
-void rtl8703b_CheckAntenna_Selection(PADAPTER padapter);
-void rtl8703b_init_default_value(PADAPTER padapter);
-
-s32 rtl8703b_InitLLTTable(PADAPTER padapter);
-
-s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
-s32 CardDisableWithoutHWSM(PADAPTER padapter);
-
-// EFuse
-u8 GetEEPROMSize8703B(PADAPTER padapter);
-void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
-void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
-void Hal_EfuseParseTxPowerInfo_8703B(PADAPTER padapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseBTCoexistInfo_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseEEPROMVer_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseChnlPlan_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseCustomerID_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseAntennaDiversity_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseXtal_8703B(PADAPTER pAdapter, u8 *hwinfo, u8 AutoLoadFail);
-void Hal_EfuseParseThermalMeter_8703B(PADAPTER padapter, u8 *hwinfo, u8 AutoLoadFail);
-VOID Hal_EfuseParseMacHidden_8703B(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-VOID Hal_EfuseParseVoltage_8703B(PADAPTER pAdapter,u8* hwinfo,BOOLEAN 	AutoLoadFail); 
-VOID Hal_EfuseParseBoardType_8703B(PADAPTER Adapter,	u8*	PROMContent,BOOLEAN AutoloadFail);
-
-#ifdef CONFIG_C2H_PACKET_EN
-void rtl8703b_c2h_packet_handler(PADAPTER padapter, u8 *pbuf, u16 length);
-#endif
-
-
-void rtl8703b_set_hal_ops(struct hal_ops *pHalFunc);
-void init_hal_spec_8703b(_adapter *adapter);
-void SetHwReg8703B(PADAPTER padapter, u8 variable, u8 *val);
-void GetHwReg8703B(PADAPTER padapter, u8 variable, u8 *val);
-#ifdef CONFIG_C2H_PACKET_EN
-void SetHwRegWithBuf8703B(PADAPTER padapter, u8 variable, u8 *pbuf, int len);
-#endif // CONFIG_C2H_PACKET_EN
-u8 SetHalDefVar8703B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-u8 GetHalDefVar8703B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-
-// register
-void rtl8703b_InitBeaconParameters(PADAPTER padapter);
-void rtl8703b_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
-void	_InitBurstPktLen_8703BS(PADAPTER Adapter);
-void _InitLTECoex_8703BS(PADAPTER Adapter);
-void _InitMacAPLLSetting_8703B(PADAPTER Adapter);
-void _8051Reset8703(PADAPTER padapter);
-#ifdef CONFIG_WOWLAN
-void Hal_DetectWoWMode(PADAPTER pAdapter);
-#endif //CONFIG_WOWLAN
-
-void rtl8703b_start_thread(_adapter *padapter);
-void rtl8703b_stop_thread(_adapter *padapter);
-
-#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
-void rtl8703bs_init_checkbthang_workqueue(_adapter * adapter);
-void rtl8703bs_free_checkbthang_workqueue(_adapter * adapter);
-void rtl8703bs_cancle_checkbthang_workqueue(_adapter * adapter);
-void rtl8703bs_hal_check_bt_hang(_adapter * adapter);
-#endif
-
-#ifdef CONFIG_GPIO_WAKEUP
-void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
-#endif
-
-int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
-
-void CCX_FwC2HTxRpt_8703b(PADAPTER padapter, u8 *pdata, u8 len);
-s32 c2h_id_filter_ccx_8703b(u8 *buf);
-s32 c2h_handler_8703b(PADAPTER padapter, u8 *pC2hEvent);
-u8 MRateToHwRate8703B(u8  rate);
-u8 HwRateToMRate8703B(u8	 rate);
-
-void Hal_ReadRFGainOffset(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-
-#ifdef CONFIG_PCI_HCI
-BOOLEAN	InterruptRecognized8703BE(PADAPTER Adapter);
-VOID	UpdateInterruptMask8703BE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
-#endif
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_HAL_H__
+#define __RTL8703B_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8703b_spec.h"
+#include "rtl8703b_rf.h"
+#include "rtl8703b_dm.h"
+#include "rtl8703b_recv.h"
+#include "rtl8703b_xmit.h"
+#include "rtl8703b_cmd.h"
+#include "rtl8703b_led.h"
+#include "Hal8703BPwrSeq.h"
+#include "Hal8703BPhyReg.h"
+#include "Hal8703BPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8703b_sreset.h"
+#endif
+
+#define FW_8703B_SIZE			0x8000
+#define FW_8703B_START_ADDRESS	0x1000
+#define FW_8703B_END_ADDRESS		0x1FFF /* 0x5FFF */
+
+#define IS_FW_HEADER_EXIST_8703B(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x03B0)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8703B_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8703B, *PRT_FIRMWARE_8703B;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8703B_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8703B_FIRMWARE_HDR, *PRT_8703B_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8703B		0x05
+#define BCN_DMA_ATIME_INT_TIME_8703B		0x02
+
+/* for 8703B
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8703B			128
+#define PAGE_SIZE_RX_8703B			8
+
+#define TX_DMA_SIZE_8703B			0x8000	/* 32K(TX) */
+#define RX_DMA_SIZE_8703B			0x4000	/* 16K(RX) */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8703B	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8703B	0x80	/* 128B, reserved for tx report */
+#endif
+#define RX_DMA_BOUNDARY_8703B		(RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
+#define BCNQ_PAGE_NUM_8703B		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8703B		0x08 /* 0x04 */
+#else
+	#define BCNQ1_PAGE_NUM_8703B		0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef BCNQ1_PAGE_NUM_8703B
+	#define BCNQ1_PAGE_NUM_8703B		0x00 /* 0x04 */
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1 PNO: 6
+ * NS offload: 2NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8703B	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8703B	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8703B
+	#define WOWLAN_PAGE_NUM_8703B	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8703B	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8703B	(0xFF - BCNQ_PAGE_NUM_8703B - BCNQ1_PAGE_NUM_8703B - WOWLAN_PAGE_NUM_8703B)
+#define TX_PAGE_BOUNDARY_8703B		(TX_TOTAL_PAGE_NUMBER_8703B + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B	TX_TOTAL_PAGE_NUMBER_8703B
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8703B		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8703B */
+#define NORMAL_PAGE_NUM_HPQ_8703B		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8703B		0x02
+#define NORMAL_PAGE_NUM_NPQ_8703B		0x02
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8703B		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8703B		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8703B		0x20
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES		15
+
+#define HAL_EFUSE_MEMORY
+
+#define HWSET_MAX_SIZE_8703B			256
+#define EFUSE_REAL_CONTENT_LEN_8703B		256
+#define EFUSE_MAP_LEN_8703B				512
+#define EFUSE_MAX_SECTION_8703B			64
+
+#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_8703B)
+
+#define EFUSE_ACCESS_ON			0x69
+#define EFUSE_ACCESS_OFF			0x00
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define BANK_NUM		1
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
+#define EFUSE_BT_REAL_CONTENT_LEN		(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN				1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION			(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK		16
+
+typedef enum tag_Package_Definition {
+	PACKAGE_DEFAULT,
+	PACKAGE_QFN68,
+	PACKAGE_TFBGA90,
+	PACKAGE_TFBGA80,
+	PACKAGE_TFBGA79
+} PACKAGE_TYPE_E;
+
+#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)
+
+/* rtl8703b_hal_init.c */
+s32 rtl8703b_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8703b_FirmwareSelfReset(PADAPTER padapter);
+void rtl8703b_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8703b_InitAntenna_Selection(PADAPTER padapter);
+void rtl8703b_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8703b_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8703b_init_default_value(PADAPTER padapter);
+
+s32 rtl8703b_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8703B(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8703B(PADAPTER padapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBTCoexistInfo_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseEEPROMVer_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8703B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8703B(PADAPTER pAdapter, u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8703B(PADAPTER padapter, u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParseVoltage_8703B(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8703B(PADAPTER Adapter,	u8	*PROMContent, BOOLEAN AutoloadFail);
+
+void rtl8703b_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8703b(_adapter *adapter);
+u8 SetHwReg8703B(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8703B(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8703B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8703B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8703b_InitBeaconParameters(PADAPTER padapter);
+void rtl8703b_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void	_InitBurstPktLen_8703BS(PADAPTER Adapter);
+void _InitLTECoex_8703BS(PADAPTER Adapter);
+void _InitMacAPLLSetting_8703B(PADAPTER Adapter);
+void _8051Reset8703(PADAPTER padapter);
+#ifdef CONFIG_WOWLAN
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8703b_start_thread(_adapter *padapter);
+void rtl8703b_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8703bs_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8703bs_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8703bs_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8703bs_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void CCX_FwC2HTxRpt_8703b(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8703B(u8  rate);
+u8 HwRateToMRate8703B(u8	 rate);
+
+void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8703BE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8703BE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_led.h
index 1be67548a0c0..4a79ce03f984 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_led.h
@@ -1,49 +1,45 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8703B_LED_H__
-#define __RTL8703B_LED_H__
-
-#include <drv_conf.h>
-#include <osdep_service.h>
-#include <drv_types.h>
-
-
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
-#ifdef CONFIG_USB_HCI
-void rtl8703bu_InitSwLeds(PADAPTER padapter);
-void rtl8703bu_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_SDIO_HCI
-void rtl8703bs_InitSwLeds(PADAPTER padapter);
-void rtl8703bs_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_GSPI_HCI
-void rtl8703bs_InitSwLeds(PADAPTER padapter);
-void rtl8703bs_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_PCI_HCI
-void rtl8703be_InitSwLeds(PADAPTER padapter);
-void rtl8703be_DeInitSwLeds(PADAPTER padapter);
-#endif
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_LED_H__
+#define __RTL8703B_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8703bu_InitSwLeds(PADAPTER padapter);
+	void rtl8703bu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8703bs_InitSwLeds(PADAPTER padapter);
+	void rtl8703bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+	void rtl8703bs_InitSwLeds(PADAPTER padapter);
+	void rtl8703bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8703be_InitSwLeds(PADAPTER padapter);
+	void rtl8703be_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif/*CONFIG_RTW_SW_LED*/
+#endif /*__RTL8703B_LED_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_recv.h
index 024f912abdba..941f6289e6ed 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_recv.h
@@ -1,92 +1,87 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8703B_RECV_H__
-#define __RTL8703B_RECV_H__
-
-#define RECV_BLK_SZ 512
-#define RECV_BLK_CNT 16
-#define RECV_BLK_TH RECV_BLK_CNT
-
-#if defined(CONFIG_USB_HCI)
-
-#ifndef MAX_RECVBUF_SZ
-#ifdef PLATFORM_OS_CE
-#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-#else
-	#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-		//#define MAX_RECVBUF_SZ (32768) // 32k
-		//#define MAX_RECVBUF_SZ (16384) //16K
-		//#define MAX_RECVBUF_SZ (10240) //10K
-		#ifdef CONFIG_PLATFORM_MSTAR
-			#define MAX_RECVBUF_SZ (8192) // 8K
-		#else
-		        #define MAX_RECVBUF_SZ (15360) // 15k < 16k
-		#endif
-		//#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-	#else
-		#define MAX_RECVBUF_SZ (4000) // about 4K
-	#endif
-#endif
-#endif //!MAX_RECVBUF_SZ
-
-#elif defined(CONFIG_PCI_HCI)
-//#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-//	#define MAX_RECVBUF_SZ (9100)
-//#else
-	#define MAX_RECVBUF_SZ (4000) // about 4K
-//#endif
-
-
-#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-
-#define MAX_RECVBUF_SZ (10240)
-
-#endif
-
-// Rx smooth factor
-#define	Rx_Smooth_Factor (20)
-
-#ifdef CONFIG_SDIO_HCI
-#ifndef CONFIG_SDIO_RX_COPY
-#undef MAX_RECVBUF_SZ
-#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B)
-#endif // !CONFIG_SDIO_RX_COPY
-#endif // CONFIG_SDIO_HCI
-
-#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-s32 rtl8703bs_init_recv_priv(PADAPTER padapter);
-void rtl8703bs_free_recv_priv(PADAPTER padapter);
-#endif
-
-#ifdef CONFIG_USB_HCI
-int rtl8703bu_init_recv_priv(_adapter *padapter);
-void rtl8703bu_free_recv_priv (_adapter *padapter);
-void rtl8703bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8703be_init_recv_priv(PADAPTER padapter);
-void rtl8703be_free_recv_priv(PADAPTER padapter);
-#endif
-
-void rtl8703b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
-
-#endif /* __RTL8703B_RECV_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_RECV_H__
+#define __RTL8703B_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ (RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_SDIO_HCI
+	#ifndef CONFIG_SDIO_RX_COPY
+		#undef MAX_RECVBUF_SZ
+		#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8703B - RX_DMA_RESERVED_SIZE_8703B)
+	#endif /* !CONFIG_SDIO_RX_COPY */
+#endif /* CONFIG_SDIO_HCI */
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8703bs_init_recv_priv(PADAPTER padapter);
+	void rtl8703bs_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8703bu_init_recv_priv(_adapter *padapter);
+	void rtl8703bu_free_recv_priv(_adapter *padapter);
+	void rtl8703bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8703be_init_recv_priv(PADAPTER padapter);
+	void rtl8703be_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8703b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8703B_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_rf.h
index 20e7268aa01b..28ff2f9b5600 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,21 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8703B_RF_H__
 #define __RTL8703B_RF_H__
 
-int	PHY_RF6052_Config8703B(	IN	PADAPTER		Adapter	);
+int	PHY_RF6052_Config8703B(IN	PADAPTER		Adapter);
 
 VOID
 PHY_RF6052SetBandwidth8703B(
 	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH		Bandwidth);
+	IN	enum channel_width		Bandwidth);
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_spec.h
index 814104428e65..a71151090dad 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_spec.h
@@ -1,480 +1,465 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
-#ifndef __RTL8703B_SPEC_H__
-#define __RTL8703B_SPEC_H__
-
-#include <drv_conf.h>
-
-
-#define HAL_NAV_UPPER_UNIT_8703B		128		// micro-second
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_SYS_ISO_CTRL_8703B			0x0000	// 2 Byte
-#define REG_SYS_FUNC_EN_8703B			0x0002	// 2 Byte
-#define REG_APS_FSMCO_8703B			0x0004	// 4 Byte
-#define REG_SYS_CLKR_8703B				0x0008	// 2 Byte
-#define REG_9346CR_8703B				0x000A	// 2 Byte
-#define REG_EE_VPD_8703B				0x000C	// 2 Byte
-#define REG_AFE_MISC_8703B				0x0010	// 1 Byte
-#define REG_SPS0_CTRL_8703B				0x0011	// 7 Byte
-#define REG_SPS_OCP_CFG_8703B			0x0018	// 4 Byte
-#define REG_RSV_CTRL_8703B				0x001C	// 3 Byte
-#define REG_RF_CTRL_8703B				0x001F	// 1 Byte
-#define REG_LPLDO_CTRL_8703B			0x0023	// 1 Byte
-#define REG_AFE_XTAL_CTRL_8703B		0x0024	// 4 Byte
-#define REG_AFE_PLL_CTRL_8703B			0x0028	// 4 Byte
-#define REG_MAC_PLL_CTRL_EXT_8703B		0x002c 	// 4 Byte
-#define REG_EFUSE_CTRL_8703B			0x0030
-#define REG_EFUSE_TEST_8703B			0x0034
-#define REG_PWR_DATA_8703B				0x0038
-#define REG_CAL_TIMER_8703B				0x003C
-#define REG_ACLK_MON_8703B				0x003E
-#define REG_GPIO_MUXCFG_8703B			0x0040
-#define REG_GPIO_IO_SEL_8703B			0x0042
-#define REG_MAC_PINMUX_CFG_8703B		0x0043
-#define REG_GPIO_PIN_CTRL_8703B			0x0044
-#define REG_GPIO_INTM_8703B				0x0048
-#define REG_LEDCFG0_8703B				0x004C
-#define REG_LEDCFG1_8703B				0x004D
-#define REG_LEDCFG2_8703B				0x004E
-#define REG_LEDCFG3_8703B				0x004F
-#define REG_FSIMR_8703B					0x0050
-#define REG_FSISR_8703B					0x0054
-#define REG_HSIMR_8703B					0x0058
-#define REG_HSISR_8703B					0x005c
-#define REG_GPIO_EXT_CTRL				0x0060
-#define REG_PAD_CTRL1_8703B		0x0064
-#define REG_MULTI_FUNC_CTRL_8703B		0x0068
-#define REG_GPIO_STATUS_8703B			0x006C
-#define REG_SDIO_CTRL_8703B				0x0070
-#define REG_OPT_CTRL_8703B				0x0074
-#define REG_AFE_CTRL_4_8703B		0x0078
-#define REG_MCUFWDL_8703B				0x0080
-#define REG_HMEBOX_DBG_0_8703B	0x0088
-#define REG_HMEBOX_DBG_1_8703B	0x008A
-#define REG_HMEBOX_DBG_2_8703B	0x008C
-#define REG_HMEBOX_DBG_3_8703B	0x008E
-#define REG_HIMR0_8703B					0x00B0
-#define REG_HISR0_8703B					0x00B4
-#define REG_HIMR1_8703B					0x00B8
-#define REG_HISR1_8703B					0x00BC
-#define REG_PMC_DBG_CTRL2_8703B			0x00CC
-#define	REG_EFUSE_BURN_GNT_8703B		0x00CF
-#define REG_HPON_FSM_8703B				0x00EC
-#define REG_SYS_CFG_8703B				0x00F0
-#define REG_SYS_CFG1_8703B				0x00FC
-#define REG_ROM_VERSION					0x00FD
-
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-#define REG_C2HEVT_CMD_ID_8703B	0x01A0
-#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
-#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
-#define REG_C2HEVT_CMD_LEN_8703B        0x01AE
-#define REG_C2HEVT_CMD_LEN_88XX		REG_C2HEVT_CMD_LEN_8703B
-#define REG_C2HEVT_CLEAR_8703B			0x01AF
-#define REG_MCUTST_1_8703B				0x01C0
-#define REG_WOWLAN_WAKE_REASON 0x01C7
-#define REG_FMETHR_8703B				0x01C8
-#define REG_HMETFR_8703B				0x01CC
-#define REG_HMEBOX_0_8703B				0x01D0
-#define REG_HMEBOX_1_8703B				0x01D4
-#define REG_HMEBOX_2_8703B				0x01D8
-#define REG_HMEBOX_3_8703B				0x01DC
-#define REG_LLT_INIT_8703B				0x01E0
-#define REG_HMEBOX_EXT0_8703B			0x01F0
-#define REG_HMEBOX_EXT1_8703B			0x01F4
-#define REG_HMEBOX_EXT2_8703B			0x01F8
-#define REG_HMEBOX_EXT3_8703B			0x01FC
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_RQPN_8703B					0x0200
-#define REG_FIFOPAGE_8703B				0x0204
-#define REG_DWBCN0_CTRL_8703B			REG_TDECTRL
-#define REG_TXDMA_OFFSET_CHK_8703B	0x020C
-#define REG_TXDMA_STATUS_8703B		0x0210
-#define REG_RQPN_NPQ_8703B			0x0214
-#define REG_DWBCN1_CTRL_8703B			0x0228
-
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_RXDMA_AGG_PG_TH_8703B		0x0280
-#define REG_FW_UPD_RDPTR_8703B		0x0284 // FW shall update this register before FW write RXPKT_RELEASE_POLL to 1
-#define REG_RXDMA_CONTROL_8703B		0x0286 // Control the RX DMA.
-#define REG_RXPKT_NUM_8703B			0x0287 // The number of packets in RXPKTBUF.	
-#define REG_RXDMA_STATUS_8703B			0x0288
-#define REG_RXDMA_MODE_CTRL_8703B		0x0290
-#define REG_EARLY_MODE_CONTROL_8703B	0x02BC
-#define REG_RSVD5_8703B					0x02F0
-#define REG_RSVD6_8703B					0x02F4
-
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
-#define	REG_PCIE_CTRL_REG_8703B		0x0300
-#define	REG_INT_MIG_8703B				0x0304	// Interrupt Migration 
-#define	REG_BCNQ_DESA_8703B			0x0308	// TX Beacon Descriptor Address
-#define	REG_HQ_DESA_8703B				0x0310	// TX High Queue Descriptor Address
-#define	REG_MGQ_DESA_8703B			0x0318	// TX Manage Queue Descriptor Address
-#define	REG_VOQ_DESA_8703B			0x0320	// TX VO Queue Descriptor Address
-#define	REG_VIQ_DESA_8703B				0x0328	// TX VI Queue Descriptor Address
-#define	REG_BEQ_DESA_8703B			0x0330	// TX BE Queue Descriptor Address
-#define	REG_BKQ_DESA_8703B			0x0338	// TX BK Queue Descriptor Address
-#define	REG_RX_DESA_8703B				0x0340	// RX Queue	Descriptor Address
-#define	REG_DBI_WDATA_8703B			0x0348	// DBI Write Data
-#define	REG_DBI_RDATA_8703B			0x034C	// DBI Read Data
-#define	REG_DBI_ADDR_8703B				0x0350	// DBI Address
-#define	REG_DBI_FLAG_8703B				0x0352	// DBI Read/Write Flag
-#define	REG_MDIO_WDATA_8703B		0x0354	// MDIO for Write PCIE PHY
-#define	REG_MDIO_RDATA_8703B			0x0356	// MDIO for Reads PCIE PHY
-#define	REG_MDIO_CTL_8703B			0x0358	// MDIO for Control
-#define	REG_DBG_SEL_8703B				0x0360	// Debug Selection Register
-#define	REG_PCIE_HRPWM_8703B			0x0361	//PCIe RPWM
-#define	REG_PCIE_HCPWM_8703B			0x0363	//PCIe CPWM
-#define	REG_PCIE_MULTIFET_CTRL_8703B	0x036A	//PCIE Multi-Fethc Control
-
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-#define REG_VOQ_INFORMATION_8703B		0x0400
-#define REG_VIQ_INFORMATION_8703B		0x0404
-#define REG_BEQ_INFORMATION_8703B		0x0408
-#define REG_BKQ_INFORMATION_8703B		0x040C
-#define REG_MGQ_INFORMATION_8703B		0x0410
-#define REG_HGQ_INFORMATION_8703B		0x0414
-#define REG_BCNQ_INFORMATION_8703B	0x0418
-#define REG_TXPKT_EMPTY_8703B			0x041A
-
-#define REG_FWHW_TXQ_CTRL_8703B		0x0420
-#define REG_HWSEQ_CTRL_8703B			0x0423
-#define REG_TXPKTBUF_BCNQ_BDNY_8703B	0x0424
-#define REG_TXPKTBUF_MGQ_BDNY_8703B	0x0425
-#define REG_LIFECTRL_CTRL_8703B			0x0426
-#define REG_MULTI_BCNQ_OFFSET_8703B	0x0427
-#define REG_SPEC_SIFS_8703B				0x0428
-#define REG_RL_8703B						0x042A
-#define REG_TXBF_CTRL_8703B				0x042C
-#define REG_DARFRC_8703B				0x0430
-#define REG_RARFRC_8703B				0x0438
-#define REG_RRSR_8703B					0x0440
-#define REG_ARFR0_8703B					0x0444
-#define REG_ARFR1_8703B					0x044C
-#define REG_CCK_CHECK_8703B				0x0454
-#define REG_AMPDU_MAX_TIME_8703B		0x0456
-#define REG_TXPKTBUF_BCNQ_BDNY1_8703B	0x0457
-
-#define REG_AMPDU_MAX_LENGTH_8703B	0x0458
-#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8703B	0x045D
-#define REG_NDPA_OPT_CTRL_8703B		0x045F
-#define REG_FAST_EDCA_CTRL_8703B		0x0460
-#define REG_RD_RESP_PKT_TH_8703B		0x0463
-#define REG_DATA_SC_8703B				0x0483
-#ifdef CONFIG_WOWLAN
-#define REG_TXPKTBUF_IV_LOW             0x0484
-#define REG_TXPKTBUF_IV_HIGH            0x0488
-#endif
-#define REG_TXRPT_START_OFFSET		0x04AC
-#define REG_POWER_STAGE1_8703B		0x04B4
-#define REG_POWER_STAGE2_8703B		0x04B8
-#define REG_AMPDU_BURST_MODE_8703B	0x04BC
-#define REG_PKT_VO_VI_LIFE_TIME_8703B	0x04C0
-#define REG_PKT_BE_BK_LIFE_TIME_8703B	0x04C2
-#define REG_STBC_SETTING_8703B			0x04C4
-#define REG_HT_SINGLE_AMPDU_8703B		0x04C7
-#define REG_PROT_MODE_CTRL_8703B		0x04C8
-#define REG_MAX_AGGR_NUM_8703B		0x04CA
-#define REG_RTS_MAX_AGGR_NUM_8703B	0x04CB
-#define REG_BAR_MODE_CTRL_8703B		0x04CC
-#define REG_RA_TRY_RATE_AGG_LMT_8703B	0x04CF
-#define REG_MACID_PKT_DROP0_8703B		0x04D0
-#define REG_MACID_PKT_SLEEP_8703B		0x04D4
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-#define REG_EDCA_VO_PARAM_8703B		0x0500
-#define REG_EDCA_VI_PARAM_8703B		0x0504
-#define REG_EDCA_BE_PARAM_8703B		0x0508
-#define REG_EDCA_BK_PARAM_8703B		0x050C
-#define REG_BCNTCFG_8703B				0x0510
-#define REG_PIFS_8703B					0x0512
-#define REG_RDG_PIFS_8703B				0x0513
-#define REG_SIFS_CTX_8703B				0x0514
-#define REG_SIFS_TRX_8703B				0x0516
-#define REG_AGGR_BREAK_TIME_8703B		0x051A
-#define REG_SLOT_8703B					0x051B
-#define REG_TX_PTCL_CTRL_8703B			0x0520
-#define REG_TXPAUSE_8703B				0x0522
-#define REG_DIS_TXREQ_CLR_8703B		0x0523
-#define REG_RD_CTRL_8703B				0x0524
-//
-// Format for offset 540h-542h:
-//	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
-//	[7:4]:   Reserved.
-//	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
-//	[23:20]: Reserved
-// Description:
-//	              |
-//     |<--Setup--|--Hold------------>|
-//	--------------|----------------------
-//                |
-//               TBTT
-// Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
-// Described by Designer Tim and Bruce, 2011-01-14.
-//
-#define REG_TBTT_PROHIBIT_8703B			0x0540
-#define REG_RD_NAV_NXT_8703B			0x0544
-#define REG_NAV_PROT_LEN_8703B			0x0546
-#define REG_BCN_CTRL_8703B				0x0550
-#define REG_BCN_CTRL_1_8703B			0x0551
-#define REG_MBID_NUM_8703B				0x0552
-#define REG_DUAL_TSF_RST_8703B			0x0553
-#define REG_BCN_INTERVAL_8703B			0x0554
-#define REG_DRVERLYINT_8703B			0x0558
-#define REG_BCNDMATIM_8703B			0x0559
-#define REG_ATIMWND_8703B				0x055A
-#define REG_USTIME_TSF_8703B			0x055C
-#define REG_BCN_MAX_ERR_8703B			0x055D
-#define REG_RXTSF_OFFSET_CCK_8703B		0x055E
-#define REG_RXTSF_OFFSET_OFDM_8703B	0x055F	
-#define REG_TSFTR_8703B					0x0560
-#define REG_CTWND_8703B					0x0572
-#define REG_SECONDARY_CCA_CTRL_8703B	0x0577
-#define REG_PSTIMER_8703B				0x0580
-#define REG_TIMER0_8703B				0x0584
-#define REG_TIMER1_8703B				0x0588
-#define REG_ACMHWCTRL_8703B			0x05C0
-#define REG_SCH_TXCMD_8703B			0x05F8
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-#define REG_MAC_CR_8703B				0x0600
-#define REG_TCR_8703B					0x0604
-#define REG_RCR_8703B					0x0608
-#define REG_RX_PKT_LIMIT_8703B			0x060C
-#define REG_RX_DLK_TIME_8703B			0x060D
-#define REG_RX_DRVINFO_SZ_8703B		0x060F
-
-#define REG_MACID_8703B					0x0610
-#define REG_BSSID_8703B					0x0618
-#define REG_MAR_8703B					0x0620
-#define REG_MBIDCAMCFG_8703B			0x0628
-#define REG_WOWLAN_GTK_DBG1	0x630
-#define REG_WOWLAN_GTK_DBG2	0x634
-
-#define REG_USTIME_EDCA_8703B			0x0638
-#define REG_MAC_SPEC_SIFS_8703B		0x063A
-#define REG_RESP_SIFP_CCK_8703B			0x063C
-#define REG_RESP_SIFS_OFDM_8703B		0x063E
-#define REG_ACKTO_8703B					0x0640
-#define REG_CTS2TO_8703B				0x0641
-#define REG_EIFS_8703B					0x0642
-
-#define REG_NAV_UPPER_8703B			0x0652	// unit of 128
-#define REG_TRXPTCL_CTL_8703B			0x0668
-
-// Security
-#define REG_CAMCMD_8703B				0x0670
-#define REG_CAMWRITE_8703B				0x0674
-#define REG_CAMREAD_8703B				0x0678
-#define REG_CAMDBG_8703B				0x067C
-#define REG_SECCFG_8703B				0x0680
-
-// Power
-#define REG_WOW_CTRL_8703B				0x0690
-#define REG_PS_RX_INFO_8703B			0x0692
-#define REG_UAPSD_TID_8703B				0x0693
-#define REG_WKFMCAM_CMD_8703B			0x0698
-#define REG_WKFMCAM_NUM_8703B			0x0698
-#define REG_WKFMCAM_RWD_8703B			0x069C
-#define REG_RXFLTMAP0_8703B				0x06A0
-#define REG_RXFLTMAP1_8703B				0x06A2
-#define REG_RXFLTMAP2_8703B				0x06A4
-#define REG_BCN_PSR_RPT_8703B			0x06A8
-#define REG_BT_COEX_TABLE_8703B		0x06C0
-#define REG_BFMER0_INFO_8703B			0x06E4
-#define REG_BFMER1_INFO_8703B			0x06EC
-#define REG_CSI_RPT_PARAM_BW20_8703B	0x06F4
-#define REG_CSI_RPT_PARAM_BW40_8703B	0x06F8
-#define REG_CSI_RPT_PARAM_BW80_8703B	0x06FC
-
-// Hardware Port 2
-#define REG_MACID1_8703B				0x0700
-#define REG_BSSID1_8703B				0x0708
-#define REG_BFMEE_SEL_8703B				0x0714
-#define REG_SND_PTCL_CTRL_8703B		0x0718
-
-// LTE_COEX
-#define REG_LTECOEX_CTRL			0x07C0
-#define REG_LTECOEX_WRITE_DATA		0x07C4	
-#define REG_LTECOEX_READ_DATA		0x07C8
-#define REG_LTECOEX_PATH_CONTROL	0x70
-
-//============================================================
-// SDIO Bus Specification
-//============================================================
-
-//-----------------------------------------------------
-// SDIO CMD Address Mapping
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-// I/O bus domain (Host)
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-// SDIO register
-//-----------------------------------------------------
-#define SDIO_REG_HCPWM1_8703B	0x025 // HCI Current Power Mode 1
-
-
-//============================================================================
-//	8703 Regsiter Bit and Content definition
-//============================================================================
-
-#define BIT_USB_RXDMA_AGG_EN	BIT(31)
-#define RXDMA_AGG_MODE_EN		BIT(1)
-
-#ifdef CONFIG_WOWLAN
-#define RXPKT_RELEASE_POLL		BIT(16)
-#define RXDMA_IDLE				BIT(17)
-#define RW_RELEASE_EN			BIT(18)
-#endif
-
-//2 HSISR
-// 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)
-
-
-//----------------------------------------------------------------------------
-//       8703B REG_CCK_CHECK						(offset 0x454)
-//----------------------------------------------------------------------------
-#define BIT_BCN_PORT_SEL		BIT5
-
-#ifdef CONFIG_RF_GAIN_OFFSET
-
-#ifdef CONFIG_RTL8703B
-#define EEPROM_RF_GAIN_OFFSET			0xC1
-#endif
-
-#define EEPROM_RF_GAIN_VAL				0x1F6
-#endif //CONFIG_RF_GAIN_OFFSET
-
-
-//----------------------------------------------------------------------------
-//       8195 IMR/ISR bits						(offset 0xB0,  8bits)
-//----------------------------------------------------------------------------
-#define	IMR_DISABLED_8703B					0
-// IMR DW0(0x00B0-00B3) Bit 0-31
-#define	IMR_TIMER2_8703B					BIT31		// Timeout interrupt 2
-#define	IMR_TIMER1_8703B					BIT30		// Timeout interrupt 1	
-#define	IMR_PSTIMEOUT_8703B				BIT29		// Power Save Time Out Interrupt
-#define	IMR_GTINT4_8703B					BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define	IMR_GTINT3_8703B					BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define	IMR_TXBCN0ERR_8703B				BIT26		// Transmit Beacon0 Error			
-#define	IMR_TXBCN0OK_8703B				BIT25		// Transmit Beacon0 OK			
-#define	IMR_TSF_BIT32_TOGGLE_8703B		BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define	IMR_BCNDMAINT0_8703B				BIT20		// Beacon DMA Interrupt 0			
-#define	IMR_BCNDERR0_8703B				BIT16		// Beacon Queue DMA OK0			
-#define	IMR_HSISR_IND_ON_INT_8703B		BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)
-#define	IMR_BCNDMAINT_E_8703B			BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define	IMR_ATIMEND_8703B				BIT12		// CTWidnow End or ATIM Window End
-#define	IMR_C2HCMD_8703B					BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define	IMR_CPWM2_8703B					BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_CPWM_8703B					BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_HIGHDOK_8703B				BIT7			// High Queue DMA OK	
-#define	IMR_MGNTDOK_8703B				BIT6			// Management Queue DMA OK	
-#define	IMR_BKDOK_8703B					BIT5			// AC_BK DMA OK		
-#define	IMR_BEDOK_8703B					BIT4			// AC_BE DMA OK	
-#define	IMR_VIDOK_8703B					BIT3			// AC_VI DMA OK		
-#define	IMR_VODOK_8703B					BIT2			// AC_VO DMA OK	
-#define	IMR_RDU_8703B					BIT1			// Rx Descriptor Unavailable	
-#define	IMR_ROK_8703B					BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define	IMR_BCNDMAINT7_8703B				BIT27		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT6_8703B				BIT26		// Beacon DMA Interrupt 6
-#define	IMR_BCNDMAINT5_8703B				BIT25		// Beacon DMA Interrupt 5
-#define	IMR_BCNDMAINT4_8703B				BIT24		// Beacon DMA Interrupt 4
-#define	IMR_BCNDMAINT3_8703B				BIT23		// Beacon DMA Interrupt 3
-#define	IMR_BCNDMAINT2_8703B				BIT22		// Beacon DMA Interrupt 2
-#define	IMR_BCNDMAINT1_8703B				BIT21		// Beacon DMA Interrupt 1
-#define	IMR_BCNDOK7_8703B					BIT20		// Beacon Queue DMA OK Interrup 7
-#define	IMR_BCNDOK6_8703B					BIT19		// Beacon Queue DMA OK Interrup 6
-#define	IMR_BCNDOK5_8703B					BIT18		// Beacon Queue DMA OK Interrup 5
-#define	IMR_BCNDOK4_8703B					BIT17		// Beacon Queue DMA OK Interrup 4
-#define	IMR_BCNDOK3_8703B					BIT16		// Beacon Queue DMA OK Interrup 3
-#define	IMR_BCNDOK2_8703B					BIT15		// Beacon Queue DMA OK Interrup 2
-#define	IMR_BCNDOK1_8703B					BIT14		// Beacon Queue DMA OK Interrup 1
-#define	IMR_ATIMEND_E_8703B				BIT13		// ATIM Window End Extension for Win7
-#define	IMR_TXERR_8703B					BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define	IMR_RXERR_8703B					BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define	IMR_TXFOVW_8703B					BIT9			// Transmit FIFO Overflow
-#define	IMR_RXFOVW_8703B					BIT8			// Receive FIFO Overflow
-
-#ifdef CONFIG_PCI_HCI
-//#define IMR_RX_MASK		(IMR_ROK_8703B|IMR_RDU_8703B|IMR_RXFOVW_8703B)
-#define IMR_TX_MASK			(IMR_VODOK_8703B|IMR_VIDOK_8703B|IMR_BEDOK_8703B|IMR_BKDOK_8703B|IMR_MGNTDOK_8703B|IMR_HIGHDOK_8703B)
-
-#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8703B | IMR_TXBCN0OK_8703B | IMR_TXBCN0ERR_8703B | IMR_BCNDERR0_8703B)
-
-#define RT_AC_INT_MASKS	(IMR_VIDOK_8703B | IMR_VODOK_8703B | IMR_BEDOK_8703B|IMR_BKDOK_8703B)
-#endif
-
-//========================================================
-// General definitions
-//========================================================
-
-#define MACID_NUM_8703B 16
-#define SEC_CAM_ENT_NUM_8703B 16
-#define NSS_NUM_8703B 1
-#define BAND_CAP_8703B (BAND_CAP_2G)
-#define BW_CAP_8703B (BW_CAP_20M | BW_CAP_40M)
-#define PROTO_CAP_8703B (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N)
-
-#endif /* __RTL8703B_SPEC_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_SPEC_H__
+#define __RTL8703B_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8703B		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8703B			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8703B			0x0002	/* 2 Byte */
+#define REG_APS_FSMCO_8703B			0x0004	/* 4 Byte */
+#define REG_SYS_CLKR_8703B				0x0008	/* 2 Byte */
+#define REG_9346CR_8703B				0x000A	/* 2 Byte */
+#define REG_EE_VPD_8703B				0x000C	/* 2 Byte */
+#define REG_AFE_MISC_8703B				0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8703B				0x0011	/* 7 Byte */
+#define REG_SPS_OCP_CFG_8703B			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8703B				0x001C	/* 3 Byte */
+#define REG_RF_CTRL_8703B				0x001F	/* 1 Byte */
+#define REG_LPLDO_CTRL_8703B			0x0023	/* 1 Byte */
+#define REG_AFE_XTAL_CTRL_8703B		0x0024	/* 4 Byte */
+#define REG_AFE_PLL_CTRL_8703B			0x0028	/* 4 Byte */
+#define REG_MAC_PLL_CTRL_EXT_8703B		0x002c	/* 4 Byte */
+#define REG_EFUSE_CTRL_8703B			0x0030
+#define REG_EFUSE_TEST_8703B			0x0034
+#define REG_PWR_DATA_8703B				0x0038
+#define REG_CAL_TIMER_8703B				0x003C
+#define REG_ACLK_MON_8703B				0x003E
+#define REG_GPIO_MUXCFG_8703B			0x0040
+#define REG_GPIO_IO_SEL_8703B			0x0042
+#define REG_MAC_PINMUX_CFG_8703B		0x0043
+#define REG_GPIO_PIN_CTRL_8703B			0x0044
+#define REG_GPIO_INTM_8703B				0x0048
+#define REG_LEDCFG0_8703B				0x004C
+#define REG_LEDCFG1_8703B				0x004D
+#define REG_LEDCFG2_8703B				0x004E
+#define REG_LEDCFG3_8703B				0x004F
+#define REG_FSIMR_8703B					0x0050
+#define REG_FSISR_8703B					0x0054
+#define REG_HSIMR_8703B					0x0058
+#define REG_HSISR_8703B					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_PAD_CTRL1_8703B		0x0064
+#define REG_MULTI_FUNC_CTRL_8703B		0x0068
+#define REG_GPIO_STATUS_8703B			0x006C
+#define REG_SDIO_CTRL_8703B				0x0070
+#define REG_OPT_CTRL_8703B				0x0074
+#define REG_AFE_CTRL_4_8703B		0x0078
+#define REG_MCUFWDL_8703B				0x0080
+#define REG_HMEBOX_DBG_0_8703B	0x0088
+#define REG_HMEBOX_DBG_1_8703B	0x008A
+#define REG_HMEBOX_DBG_2_8703B	0x008C
+#define REG_HMEBOX_DBG_3_8703B	0x008E
+#define REG_HIMR0_8703B					0x00B0
+#define REG_HISR0_8703B					0x00B4
+#define REG_HIMR1_8703B					0x00B8
+#define REG_HISR1_8703B					0x00BC
+#define REG_PMC_DBG_CTRL2_8703B			0x00CC
+#define	REG_EFUSE_BURN_GNT_8703B		0x00CF
+#define REG_HPON_FSM_8703B				0x00EC
+#define REG_SYS_CFG_8703B				0x00F0
+#define REG_SYS_CFG1_8703B				0x00FC
+#define REG_ROM_VERSION					0x00FD
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8703B	0x01A0
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_8703B        0x01AE
+#define REG_C2HEVT_CMD_LEN_88XX		REG_C2HEVT_CMD_LEN_8703B
+#define REG_C2HEVT_CLEAR_8703B			0x01AF
+#define REG_MCUTST_1_8703B				0x01C0
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_FMETHR_8703B				0x01C8
+#define REG_HMETFR_8703B				0x01CC
+#define REG_HMEBOX_0_8703B				0x01D0
+#define REG_HMEBOX_1_8703B				0x01D4
+#define REG_HMEBOX_2_8703B				0x01D8
+#define REG_HMEBOX_3_8703B				0x01DC
+#define REG_LLT_INIT_8703B				0x01E0
+#define REG_HMEBOX_EXT0_8703B			0x01F0
+#define REG_HMEBOX_EXT1_8703B			0x01F4
+#define REG_HMEBOX_EXT2_8703B			0x01F8
+#define REG_HMEBOX_EXT3_8703B			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RQPN_8703B					0x0200
+#define REG_FIFOPAGE_8703B				0x0204
+#define REG_DWBCN0_CTRL_8703B			REG_TDECTRL
+#define REG_TXDMA_OFFSET_CHK_8703B	0x020C
+#define REG_TXDMA_STATUS_8703B		0x0210
+#define REG_RQPN_NPQ_8703B			0x0214
+#define REG_DWBCN1_CTRL_8703B			0x0228
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8703B		0x0280
+#define REG_FW_UPD_RDPTR_8703B		0x0284 /* FW shall update this register before FW write RXPKT_RELEASE_POLL to 1 */
+#define REG_RXDMA_CONTROL_8703B		0x0286 /* Control the RX DMA. */
+#define REG_RXPKT_NUM_8703B			0x0287 /* The number of packets in RXPKTBUF.	 */
+#define REG_RXDMA_STATUS_8703B			0x0288
+#define REG_RXDMA_MODE_CTRL_8703B		0x0290
+#define REG_EARLY_MODE_CONTROL_8703B	0x02BC
+#define REG_RSVD5_8703B					0x02F0
+#define REG_RSVD6_8703B					0x02F4
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8703B		0x0300
+#define	REG_INT_MIG_8703B				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_DESA_8703B			0x0308	/* TX Beacon Descriptor Address */
+#define	REG_HQ_DESA_8703B				0x0310	/* TX High Queue Descriptor Address */
+#define	REG_MGQ_DESA_8703B			0x0318	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_DESA_8703B			0x0320	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_DESA_8703B				0x0328	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_DESA_8703B			0x0330	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_DESA_8703B			0x0338	/* TX BK Queue Descriptor Address */
+#define	REG_RX_DESA_8703B				0x0340	/* RX Queue	Descriptor Address */
+#define	REG_DBI_WDATA_8703B			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8703B			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8703B				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8703B				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8703B		0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8703B			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8703B			0x0358	/* MDIO for Control */
+#define	REG_DBG_SEL_8703B				0x0360	/* Debug Selection Register */
+#define	REG_PCIE_HRPWM_8703B			0x0361	/* PCIe RPWM */
+#define	REG_PCIE_HCPWM_8703B			0x0363	/* PCIe CPWM */
+#define	REG_PCIE_MULTIFET_CTRL_8703B	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_VOQ_INFORMATION_8703B		0x0400
+#define REG_VIQ_INFORMATION_8703B		0x0404
+#define REG_BEQ_INFORMATION_8703B		0x0408
+#define REG_BKQ_INFORMATION_8703B		0x040C
+#define REG_MGQ_INFORMATION_8703B		0x0410
+#define REG_HGQ_INFORMATION_8703B		0x0414
+#define REG_BCNQ_INFORMATION_8703B	0x0418
+#define REG_TXPKT_EMPTY_8703B			0x041A
+
+#define REG_FWHW_TXQ_CTRL_8703B		0x0420
+#define REG_HWSEQ_CTRL_8703B			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8703B	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8703B	0x0425
+#define REG_LIFECTRL_CTRL_8703B			0x0426
+#define REG_MULTI_BCNQ_OFFSET_8703B	0x0427
+#define REG_SPEC_SIFS_8703B				0x0428
+#define REG_RL_8703B						0x042A
+#define REG_TXBF_CTRL_8703B				0x042C
+#define REG_DARFRC_8703B				0x0430
+#define REG_RARFRC_8703B				0x0438
+#define REG_RRSR_8703B					0x0440
+#define REG_ARFR0_8703B					0x0444
+#define REG_ARFR1_8703B					0x044C
+#define REG_CCK_CHECK_8703B				0x0454
+#define REG_AMPDU_MAX_TIME_8703B		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8703B	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8703B	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8703B	0x045D
+#define REG_NDPA_OPT_CTRL_8703B		0x045F
+#define REG_FAST_EDCA_CTRL_8703B		0x0460
+#define REG_RD_RESP_PKT_TH_8703B		0x0463
+#define REG_DATA_SC_8703B				0x0483
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_POWER_STAGE1_8703B		0x04B4
+#define REG_POWER_STAGE2_8703B		0x04B8
+#define REG_AMPDU_BURST_MODE_8703B	0x04BC
+#define REG_PKT_VO_VI_LIFE_TIME_8703B	0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8703B	0x04C2
+#define REG_STBC_SETTING_8703B			0x04C4
+#define REG_HT_SINGLE_AMPDU_8703B		0x04C7
+#define REG_PROT_MODE_CTRL_8703B		0x04C8
+#define REG_MAX_AGGR_NUM_8703B		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8703B	0x04CB
+#define REG_BAR_MODE_CTRL_8703B		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8703B	0x04CF
+#define REG_MACID_PKT_DROP0_8703B		0x04D0
+#define REG_MACID_PKT_SLEEP_8703B		0x04D4
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8703B		0x0500
+#define REG_EDCA_VI_PARAM_8703B		0x0504
+#define REG_EDCA_BE_PARAM_8703B		0x0508
+#define REG_EDCA_BK_PARAM_8703B		0x050C
+#define REG_BCNTCFG_8703B				0x0510
+#define REG_PIFS_8703B					0x0512
+#define REG_RDG_PIFS_8703B				0x0513
+#define REG_SIFS_CTX_8703B				0x0514
+#define REG_SIFS_TRX_8703B				0x0516
+#define REG_AGGR_BREAK_TIME_8703B		0x051A
+#define REG_SLOT_8703B					0x051B
+#define REG_TX_PTCL_CTRL_8703B			0x0520
+#define REG_TXPAUSE_8703B				0x0522
+#define REG_DIS_TXREQ_CLR_8703B		0x0523
+#define REG_RD_CTRL_8703B				0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8703B			0x0540
+#define REG_RD_NAV_NXT_8703B			0x0544
+#define REG_NAV_PROT_LEN_8703B			0x0546
+#define REG_BCN_CTRL_8703B				0x0550
+#define REG_BCN_CTRL_1_8703B			0x0551
+#define REG_MBID_NUM_8703B				0x0552
+#define REG_DUAL_TSF_RST_8703B			0x0553
+#define REG_BCN_INTERVAL_8703B			0x0554
+#define REG_DRVERLYINT_8703B			0x0558
+#define REG_BCNDMATIM_8703B			0x0559
+#define REG_ATIMWND_8703B				0x055A
+#define REG_USTIME_TSF_8703B			0x055C
+#define REG_BCN_MAX_ERR_8703B			0x055D
+#define REG_RXTSF_OFFSET_CCK_8703B		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8703B	0x055F
+#define REG_TSFTR_8703B					0x0560
+#define REG_CTWND_8703B					0x0572
+#define REG_SECONDARY_CCA_CTRL_8703B	0x0577
+#define REG_PSTIMER_8703B				0x0580
+#define REG_TIMER0_8703B				0x0584
+#define REG_TIMER1_8703B				0x0588
+#define REG_ACMHWCTRL_8703B			0x05C0
+#define REG_SCH_TXCMD_8703B			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8703B				0x0600
+#define REG_TCR_8703B					0x0604
+#define REG_RCR_8703B					0x0608
+#define REG_RX_PKT_LIMIT_8703B			0x060C
+#define REG_RX_DLK_TIME_8703B			0x060D
+#define REG_RX_DRVINFO_SZ_8703B		0x060F
+
+#define REG_MACID_8703B					0x0610
+#define REG_BSSID_8703B					0x0618
+#define REG_MAR_8703B					0x0620
+#define REG_MBIDCAMCFG_8703B			0x0628
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_USTIME_EDCA_8703B			0x0638
+#define REG_MAC_SPEC_SIFS_8703B		0x063A
+#define REG_RESP_SIFP_CCK_8703B			0x063C
+#define REG_RESP_SIFS_OFDM_8703B		0x063E
+#define REG_ACKTO_8703B					0x0640
+#define REG_CTS2TO_8703B				0x0641
+#define REG_EIFS_8703B					0x0642
+
+#define REG_NAV_UPPER_8703B			0x0652	/* unit of 128 */
+#define REG_TRXPTCL_CTL_8703B			0x0668
+
+/* Security */
+#define REG_CAMCMD_8703B				0x0670
+#define REG_CAMWRITE_8703B				0x0674
+#define REG_CAMREAD_8703B				0x0678
+#define REG_CAMDBG_8703B				0x067C
+#define REG_SECCFG_8703B				0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8703B				0x0690
+#define REG_PS_RX_INFO_8703B			0x0692
+#define REG_UAPSD_TID_8703B				0x0693
+#define REG_WKFMCAM_CMD_8703B			0x0698
+#define REG_WKFMCAM_NUM_8703B			0x0698
+#define REG_WKFMCAM_RWD_8703B			0x069C
+#define REG_RXFLTMAP0_8703B				0x06A0
+#define REG_RXFLTMAP1_8703B				0x06A2
+#define REG_RXFLTMAP2_8703B				0x06A4
+#define REG_BCN_PSR_RPT_8703B			0x06A8
+#define REG_BT_COEX_TABLE_8703B		0x06C0
+#define REG_BFMER0_INFO_8703B			0x06E4
+#define REG_BFMER1_INFO_8703B			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8703B	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8703B	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8703B	0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8703B				0x0700
+#define REG_BSSID1_8703B				0x0708
+#define REG_BFMEE_SEL_8703B				0x0714
+#define REG_SND_PTCL_CTRL_8703B		0x0718
+
+/* LTE_COEX */
+#define REG_LTECOEX_CTRL			0x07C0
+#define REG_LTECOEX_WRITE_DATA		0x07C4
+#define REG_LTECOEX_READ_DATA		0x07C8
+#define REG_LTECOEX_PATH_CONTROL	0x70
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HCPWM1_8703B	0x025 /* HCI Current Power Mode 1 */
+
+
+/* ****************************************************************************
+ *	8703 Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* 2 HSISR
+ * 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)
+
+
+/* ----------------------------------------------------------------------------
+ * 8703B REG_CCK_CHECK						(offset 0x454)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+#ifdef CONFIG_RF_POWER_TRIM
+
+	#ifdef CONFIG_RTL8703B
+		#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#endif
+
+	#define EEPROM_RF_GAIN_VAL				0x1F6
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8703B					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8703B					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8703B					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8703B				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8703B					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8703B					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8703B				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8703B				BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8703B		BIT(24)		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8703B				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8703B				BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8703B		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8703B			BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8703B				BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8703B					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8703B					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8703B					BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8703B				BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8703B				BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8703B					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8703B					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8703B					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8703B					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8703B					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8703B					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8703B				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8703B				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8703B				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8703B				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8703B				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8703B				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8703B				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8703B					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8703B					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8703B					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8703B					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8703B					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8703B					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8703B					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8703B				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8703B					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8703B					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8703B					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8703B					BIT(8)			/* Receive FIFO Overflow */
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_8703B|IMR_RDU_8703B|IMR_RXFOVW_8703B) */
+	#define IMR_TX_MASK			(IMR_VODOK_8703B | IMR_VIDOK_8703B | IMR_BEDOK_8703B | IMR_BKDOK_8703B | IMR_MGNTDOK_8703B | IMR_HIGHDOK_8703B)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8703B | IMR_TXBCN0OK_8703B | IMR_TXBCN0ERR_8703B | IMR_BCNDERR0_8703B)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8703B | IMR_VODOK_8703B | IMR_BEDOK_8703B | IMR_BKDOK_8703B)
+#endif
+
+#endif /* __RTL8703B_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_sreset.h
index 4eb70ddb9d8e..5433c19e1383 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_sreset.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,20 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL8703B_SRESET_H_
 #define _RTL8703B_SRESET_H_
 
 #include <rtw_sreset.h>
 
 #ifdef DBG_CONFIG_ERROR_DETECT
-extern void rtl8703b_sreset_xmit_status_check(_adapter *padapter);
-extern void rtl8703b_sreset_linked_status_check(_adapter *padapter);
+	extern void rtl8703b_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8703b_sreset_linked_status_check(_adapter *padapter);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_xmit.h
index 2509b2f3a9b3..004def3a37ac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8703b_xmit.h
@@ -1,336 +1,335 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8703B_XMIT_H__
-#define __RTL8703B_XMIT_H__
-
-
-#define MAX_TID (15)
-
-
-#ifndef __INC_HAL8703BDESC_H
-#define __INC_HAL8703BDESC_H
-
-#define RX_STATUS_DESC_SIZE_8703B		24
-#define RX_DRV_INFO_SIZE_UNIT_8703B 8
-
-
-//DWORD 0
-#define SET_RX_STATUS_DESC_PKT_LEN_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_STATUS_DESC_EOR_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 30, 1, __Value)
-#define SET_RX_STATUS_DESC_OWN_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 31, 1, __Value)
-
-#define GET_RX_STATUS_DESC_PKT_LEN_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 0, 14)
-#define GET_RX_STATUS_DESC_CRC32_8703B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 14, 1)
-#define GET_RX_STATUS_DESC_ICV_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 15, 1)
-#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 4)
-#define GET_RX_STATUS_DESC_SECURITY_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 20, 3)
-#define GET_RX_STATUS_DESC_QOS_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 23, 1)
-#define GET_RX_STATUS_DESC_SHIFT_8703B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 24, 2)
-#define GET_RX_STATUS_DESC_PHY_STATUS_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 26, 1)
-#define GET_RX_STATUS_DESC_SWDEC_8703B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 27, 1)
-#define GET_RX_STATUS_DESC_LAST_SEG_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 28, 1)
-#define GET_RX_STATUS_DESC_FIRST_SEG_8703B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 29, 1)
-#define GET_RX_STATUS_DESC_EOR_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 30, 1)
-#define GET_RX_STATUS_DESC_OWN_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 31, 1)
-
-//DWORD 1
-#define GET_RX_STATUS_DESC_MACID_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
-#define GET_RX_STATUS_DESC_TID_8703B(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
-#define GET_RX_STATUS_DESC_AMSDU_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
-#define GET_RX_STATUS_DESC_RXID_MATCH_8703B(__pRxDesc)		LE_BITS_TO_4BYTE( __pRxDesc+4, 14, 1)
-#define GET_RX_STATUS_DESC_PAGGR_8703B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 15, 1)
-#define GET_RX_STATUS_DESC_A1_FIT_8703B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 16, 4)
-#define GET_RX_STATUS_DESC_CHKERR_8703B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 20, 1)
-#define GET_RX_STATUS_DESC_IPVER_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
-#define GET_RX_STATUS_DESC_IS_TCPUDP__8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
-#define GET_RX_STATUS_DESC_CHK_VLD_8703B(__pRxDesc) 	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
-#define GET_RX_STATUS_DESC_PAM_8703B(__pRxDesc) 			LE_BITS_TO_4BYTE( __pRxDesc+4, 24, 1)
-#define GET_RX_STATUS_DESC_PWR_8703B(__pRxDesc) 			LE_BITS_TO_4BYTE( __pRxDesc+4, 25, 1)
-#define GET_RX_STATUS_DESC_MORE_DATA_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 26, 1)
-#define GET_RX_STATUS_DESC_MORE_FRAG_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 27, 1)
-#define GET_RX_STATUS_DESC_TYPE_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 28, 2)
-#define GET_RX_STATUS_DESC_MC_8703B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 30, 1)
-#define GET_RX_STATUS_DESC_BC_8703B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 31, 1)
-
-//DWORD 2
-#define GET_RX_STATUS_DESC_SEQ_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 0, 12)
-#define GET_RX_STATUS_DESC_FRAG_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 12, 4)
-#define GET_RX_STATUS_DESC_RX_IS_QOS_8703B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 16, 1)
-#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8703B(__pRxStatusDesc) 	LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 18, 6)
-#define GET_RX_STATUS_DESC_RPT_SEL_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 28, 1)
-
-//DWORD 3
-#define GET_RX_STATUS_DESC_RX_RATE_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 0, 7)
-#define GET_RX_STATUS_DESC_HTC_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 10, 1)
-#define GET_RX_STATUS_DESC_EOSP_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 11, 1)
-#define GET_RX_STATUS_DESC_BSSID_FIT_8703B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 12, 2)
-#ifdef CONFIG_USB_RX_AGGREGATION
-#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8703B(__pRxStatusDesc)	LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 16, 8)
-#endif
-#define GET_RX_STATUS_DESC_PATTERN_MATCH_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 29, 1)
-#define GET_RX_STATUS_DESC_UNICAST_MATCH_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 30, 1)
-#define GET_RX_STATUS_DESC_MAGIC_MATCH_8703B(__pRxDesc) 		LE_BITS_TO_4BYTE( __pRxDesc+12, 31, 1)
-
-//DWORD 6
-#define GET_RX_STATUS_DESC_SPLCP_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 0, 1)
-#define GET_RX_STATUS_DESC_LDPC_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 1, 1)
-#define GET_RX_STATUS_DESC_STBC_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 2, 1)
-#define GET_RX_STATUS_DESC_BW_8703B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 4, 2)
-
-//DWORD 5
-#define GET_RX_STATUS_DESC_TSFL_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+20, 0, 32)
-
-#define GET_RX_STATUS_DESC_BUFF_ADDR_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
-#define GET_RX_STATUS_DESC_BUFF_ADDR64_8703B(__pRxDesc) 		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
-
-#define SET_RX_STATUS_DESC_BUFF_ADDR_8703B(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
-
-
-// Dword 0
-#define GET_TX_DESC_OWN_8703B(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
-
-#define SET_TX_DESC_PKT_SIZE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
-#define SET_TX_DESC_OFFSET_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
-#define SET_TX_DESC_BMC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
-#define SET_TX_DESC_HTC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
-#define SET_TX_DESC_LAST_SEG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
-#define SET_TX_DESC_FIRST_SEG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
-#define SET_TX_DESC_LINIP_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
-#define SET_TX_DESC_NO_ACM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
-#define SET_TX_DESC_GF_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
-#define SET_TX_DESC_OWN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
-
-// Dword 1
-#define SET_TX_DESC_MACID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
-#define SET_TX_DESC_QUEUE_SEL_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
-#define SET_TX_DESC_RDG_NAV_EXT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
-#define SET_TX_DESC_LSIG_TXOP_EN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
-#define SET_TX_DESC_PIFS_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
-#define SET_TX_DESC_RATE_ID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
-#define SET_TX_DESC_EN_DESC_ID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
-#define SET_TX_DESC_SEC_TYPE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
-#define SET_TX_DESC_PKT_OFFSET_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
-
-
-// Dword 2
-#define SET_TX_DESC_PAID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value) 
-#define SET_TX_DESC_CCA_RTS_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
-#define SET_TX_DESC_AGG_ENABLE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
-#define SET_TX_DESC_RDG_ENABLE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
-#define SET_TX_DESC_AGG_BREAK_8703B(__pTxDesc, __Value) 				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
-#define SET_TX_DESC_MORE_FRAG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
-#define SET_TX_DESC_RAW_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
-#define SET_TX_DESC_SPE_RPT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
-#define SET_TX_DESC_AMPDU_DENSITY_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
-#define SET_TX_DESC_BT_INT_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
-#define SET_TX_DESC_GID_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
-
-
-// Dword 3
-#define SET_TX_DESC_WHEADER_LEN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
-#define SET_TX_DESC_CHK_EN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
-#define SET_TX_DESC_EARLY_MODE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
-#define SET_TX_DESC_HWSEQ_SEL_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
-#define SET_TX_DESC_USE_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
-#define SET_TX_DESC_DISABLE_RTS_FB_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
-#define SET_TX_DESC_DISABLE_FB_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
-#define SET_TX_DESC_CTS2SELF_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
-#define SET_TX_DESC_RTS_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
-#define SET_TX_DESC_HW_RTS_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
-#define SET_TX_DESC_NAV_USE_HDR_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
-#define SET_TX_DESC_USE_MAX_LEN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
-#define SET_TX_DESC_MAX_AGG_NUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
-#define SET_TX_DESC_NDPA_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
-#define SET_TX_DESC_AMPDU_MAX_TIME_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
-
-// Dword 4
-#define SET_TX_DESC_TX_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
-#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
-#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
-#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
-#define SET_TX_DESC_DATA_RETRY_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
-#define SET_TX_DESC_RTS_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
-
-
-// Dword 5
-#define SET_TX_DESC_DATA_SC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
-#define SET_TX_DESC_DATA_SHORT_8703B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
-#define SET_TX_DESC_DATA_BW_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
-#define SET_TX_DESC_DATA_LDPC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
-#define SET_TX_DESC_DATA_STBC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
-#define SET_TX_DESC_CTROL_STBC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
-#define SET_TX_DESC_RTS_SHORT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
-#define SET_TX_DESC_RTS_SC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
-
-
-// Dword 6
-#define SET_TX_DESC_SW_DEFINE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
-#define SET_TX_DESC_MBSSID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
-#define SET_TX_DESC_ANTSEL_A_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
-#define SET_TX_DESC_ANTSEL_B_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
-#define SET_TX_DESC_ANTSEL_C_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
-#define SET_TX_DESC_ANTSEL_D_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
-
-// Dword 7
-#if(DEV_BUS_TYPE == RT_PCI_INTERFACE)
-#define SET_TX_DESC_TX_BUFFER_SIZE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
-#define SET_TX_DESC_TX_DESC_CHECKSUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#endif
-#define SET_TX_DESC_USB_TXAGG_NUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-#if(DEV_BUS_TYPE == RT_SDIO_INTERFACE)
-#define SET_TX_DESC_SDIO_TXSEQ_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
-#endif
-
-// Dword 8
-#define SET_TX_DESC_HWSEQ_EN_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
-
-// Dword 9
-#define SET_TX_DESC_SEQ_8703B(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
-
-// Dword 10
-#define SET_TX_DESC_TX_BUFFER_ADDRESS_8703B(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
-#define GET_TX_DESC_TX_BUFFER_ADDRESS_8703B(__pTxDesc) 	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
-
-// Dword 11
-#define SET_TX_DESC_NEXT_DESC_ADDRESS_8703B(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
-
-
-#define SET_EARLYMODE_PKTNUM_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
-#define SET_EARLYMODE_LEN0_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
-#define SET_EARLYMODE_LEN1_1_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
-#define SET_EARLYMODE_LEN1_2_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
-#define SET_EARLYMODE_LEN2_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
-#define SET_EARLYMODE_LEN3_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
-
-#endif
-//-----------------------------------------------------------
-//
-//	Rate
-//
-//-----------------------------------------------------------
-// CCK Rates, TxHT = 0
-#define DESC8703B_RATE1M				0x00
-#define DESC8703B_RATE2M				0x01
-#define DESC8703B_RATE5_5M				0x02
-#define DESC8703B_RATE11M				0x03
-
-// OFDM Rates, TxHT = 0
-#define DESC8703B_RATE6M				0x04
-#define DESC8703B_RATE9M				0x05
-#define DESC8703B_RATE12M				0x06
-#define DESC8703B_RATE18M				0x07
-#define DESC8703B_RATE24M				0x08
-#define DESC8703B_RATE36M				0x09
-#define DESC8703B_RATE48M				0x0a
-#define DESC8703B_RATE54M				0x0b
-
-// MCS Rates, TxHT = 1
-#define DESC8703B_RATEMCS0				0x0c
-#define DESC8703B_RATEMCS1				0x0d
-#define DESC8703B_RATEMCS2				0x0e
-#define DESC8703B_RATEMCS3				0x0f
-#define DESC8703B_RATEMCS4				0x10
-#define DESC8703B_RATEMCS5				0x11
-#define DESC8703B_RATEMCS6				0x12
-#define DESC8703B_RATEMCS7				0x13
-#define DESC8703B_RATEMCS8				0x14
-#define DESC8703B_RATEMCS9				0x15
-#define DESC8703B_RATEMCS10 		0x16
-#define DESC8703B_RATEMCS11 		0x17
-#define DESC8703B_RATEMCS12 		0x18
-#define DESC8703B_RATEMCS13 		0x19
-#define DESC8703B_RATEMCS14 		0x1a
-#define DESC8703B_RATEMCS15 		0x1b
-#define DESC8703B_RATEVHTSS1MCS0		0x2c
-#define DESC8703B_RATEVHTSS1MCS1		0x2d
-#define DESC8703B_RATEVHTSS1MCS2		0x2e
-#define DESC8703B_RATEVHTSS1MCS3		0x2f
-#define DESC8703B_RATEVHTSS1MCS4		0x30
-#define DESC8703B_RATEVHTSS1MCS5		0x31
-#define DESC8703B_RATEVHTSS1MCS6		0x32
-#define DESC8703B_RATEVHTSS1MCS7		0x33
-#define DESC8703B_RATEVHTSS1MCS8		0x34
-#define DESC8703B_RATEVHTSS1MCS9		0x35
-#define DESC8703B_RATEVHTSS2MCS0		0x36
-#define DESC8703B_RATEVHTSS2MCS1		0x37
-#define DESC8703B_RATEVHTSS2MCS2		0x38
-#define DESC8703B_RATEVHTSS2MCS3		0x39
-#define DESC8703B_RATEVHTSS2MCS4		0x3a
-#define DESC8703B_RATEVHTSS2MCS5		0x3b
-#define DESC8703B_RATEVHTSS2MCS6		0x3c
-#define DESC8703B_RATEVHTSS2MCS7		0x3d
-#define DESC8703B_RATEVHTSS2MCS8		0x3e
-#define DESC8703B_RATEVHTSS2MCS9		0x3f
-
-
-#define 	RX_HAL_IS_CCK_RATE_8703B(pDesc)\
-			(GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE1M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE2M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE5_5M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE11M)
-
-
-void rtl8703b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
-void rtl8703b_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
-
-#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-s32 rtl8703bs_init_xmit_priv(PADAPTER padapter);
-void rtl8703bs_free_xmit_priv(PADAPTER padapter);
-s32 rtl8703bs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8703bs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8703bs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-s32 rtl8703bs_xmit_buf_handler(PADAPTER padapter);
-thread_return rtl8703bs_xmit_thread(thread_context context);
-#define hal_xmit_handler rtl8703bs_xmit_buf_handler
-#endif
-
-#ifdef CONFIG_USB_HCI
-s32 rtl8703bu_xmit_buf_handler(PADAPTER padapter);
-#define hal_xmit_handler rtl8703bu_xmit_buf_handler
-
-
-s32 rtl8703bu_init_xmit_priv(PADAPTER padapter);
-void rtl8703bu_free_xmit_priv(PADAPTER padapter);
-s32 rtl8703bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8703bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	 rtl8703bu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-//s32 rtl8812au_xmit_buf_handler(PADAPTER padapter);
-void rtl8703bu_xmit_tasklet(void *priv);
-s32 rtl8703bu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag,struct tx_desc *ptxdesc);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8703be_init_xmit_priv(PADAPTER padapter);
-void rtl8703be_free_xmit_priv(PADAPTER padapter);
-struct xmit_buf *rtl8703be_dequeue_xmitbuf(struct rtw_tx_ring *ring);
-void	rtl8703be_xmitframe_resume(_adapter *padapter);
-s32 rtl8703be_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8703be_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8703be_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-void rtl8703be_xmit_tasklet(void *priv);
-#endif
-
-u8	BWMapping_8703B(PADAPTER Adapter, struct pkt_attrib *pattrib);
-u8	SCMapping_8703B(PADAPTER Adapter, struct pkt_attrib	*pattrib);
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8703B_XMIT_H__
+#define __RTL8703B_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8703BDESC_H
+	#define __INC_HAL8703BDESC_H
+
+	#define RX_STATUS_DESC_SIZE_8703B		24
+	#define RX_DRV_INFO_SIZE_UNIT_8703B 8
+
+
+	/* DWORD 0 */
+	#define SET_RX_STATUS_DESC_PKT_LEN_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+	#define SET_RX_STATUS_DESC_EOR_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+	#define SET_RX_STATUS_DESC_OWN_8703B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+	#define GET_RX_STATUS_DESC_PKT_LEN_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+	#define GET_RX_STATUS_DESC_CRC32_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+	#define GET_RX_STATUS_DESC_ICV_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+	#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+	#define GET_RX_STATUS_DESC_SECURITY_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+	#define GET_RX_STATUS_DESC_QOS_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+	#define GET_RX_STATUS_DESC_SHIFT_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+	#define GET_RX_STATUS_DESC_PHY_STATUS_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+	#define GET_RX_STATUS_DESC_SWDEC_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+	#define GET_RX_STATUS_DESC_LAST_SEG_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+	#define GET_RX_STATUS_DESC_FIRST_SEG_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+	#define GET_RX_STATUS_DESC_EOR_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+	#define GET_RX_STATUS_DESC_OWN_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+	/* DWORD 1 */
+	#define GET_RX_STATUS_DESC_MACID_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+	#define GET_RX_STATUS_DESC_TID_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+	#define GET_RX_STATUS_DESC_AMSDU_8703B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+	#define GET_RX_STATUS_DESC_RXID_MATCH_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+	#define GET_RX_STATUS_DESC_PAGGR_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+	#define GET_RX_STATUS_DESC_A1_FIT_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+	#define GET_RX_STATUS_DESC_CHKERR_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+	#define GET_RX_STATUS_DESC_IPVER_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+	#define GET_RX_STATUS_DESC_IS_TCPUDP__8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+	#define GET_RX_STATUS_DESC_CHK_VLD_8703B(__pRxDesc)	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+	#define GET_RX_STATUS_DESC_PAM_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+	#define GET_RX_STATUS_DESC_PWR_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+	#define GET_RX_STATUS_DESC_MORE_DATA_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+	#define GET_RX_STATUS_DESC_MORE_FRAG_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+	#define GET_RX_STATUS_DESC_TYPE_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+	#define GET_RX_STATUS_DESC_MC_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+	#define GET_RX_STATUS_DESC_BC_8703B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+	/* DWORD 2 */
+	#define GET_RX_STATUS_DESC_SEQ_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+	#define GET_RX_STATUS_DESC_FRAG_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+	#define GET_RX_STATUS_DESC_RX_IS_QOS_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+	#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8703B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+	#define GET_RX_STATUS_DESC_RPT_SEL_8703B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+	/* DWORD 3 */
+	#define GET_RX_STATUS_DESC_RX_RATE_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+	#define GET_RX_STATUS_DESC_HTC_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+	#define GET_RX_STATUS_DESC_EOSP_8703B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+	#define GET_RX_STATUS_DESC_BSSID_FIT_8703B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+	#ifdef CONFIG_USB_RX_AGGREGATION
+		#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8703B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+	#endif
+	#define GET_RX_STATUS_DESC_PATTERN_MATCH_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+	#define GET_RX_STATUS_DESC_UNICAST_MATCH_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+	#define GET_RX_STATUS_DESC_MAGIC_MATCH_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+	/* DWORD 6 */
+	#define GET_RX_STATUS_DESC_SPLCP_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+	#define GET_RX_STATUS_DESC_LDPC_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+	#define GET_RX_STATUS_DESC_STBC_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+	#define GET_RX_STATUS_DESC_BW_8703B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+	/* DWORD 5 */
+	#define GET_RX_STATUS_DESC_TSFL_8703B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+	#define GET_RX_STATUS_DESC_BUFF_ADDR_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+	#define GET_RX_STATUS_DESC_BUFF_ADDR64_8703B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+	#define SET_RX_STATUS_DESC_BUFF_ADDR_8703B(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+	/* Dword 0 */
+	#define GET_TX_DESC_OWN_8703B(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+	#define SET_TX_DESC_PKT_SIZE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+	#define SET_TX_DESC_OFFSET_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+	#define SET_TX_DESC_BMC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+	#define SET_TX_DESC_HTC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+	#define SET_TX_DESC_LAST_SEG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+	#define SET_TX_DESC_FIRST_SEG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+	#define SET_TX_DESC_LINIP_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+	#define SET_TX_DESC_NO_ACM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+	#define SET_TX_DESC_GF_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+	#define SET_TX_DESC_OWN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+	/* Dword 1 */
+	#define SET_TX_DESC_MACID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+	#define SET_TX_DESC_QUEUE_SEL_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+	#define SET_TX_DESC_RDG_NAV_EXT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+	#define SET_TX_DESC_LSIG_TXOP_EN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+	#define SET_TX_DESC_PIFS_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+	#define SET_TX_DESC_RATE_ID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+	#define SET_TX_DESC_EN_DESC_ID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+	#define SET_TX_DESC_SEC_TYPE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+	#define SET_TX_DESC_PKT_OFFSET_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+
+
+	/* Dword 2 */
+	#define SET_TX_DESC_PAID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+	#define SET_TX_DESC_CCA_RTS_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+	#define SET_TX_DESC_AGG_ENABLE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+	#define SET_TX_DESC_RDG_ENABLE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+	#define SET_TX_DESC_AGG_BREAK_8703B(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+	#define SET_TX_DESC_MORE_FRAG_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+	#define SET_TX_DESC_RAW_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+	#define SET_TX_DESC_SPE_RPT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+	#define SET_TX_DESC_AMPDU_DENSITY_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+	#define SET_TX_DESC_BT_INT_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+	#define SET_TX_DESC_GID_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+
+	/* Dword 3 */
+	#define SET_TX_DESC_WHEADER_LEN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+	#define SET_TX_DESC_CHK_EN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+	#define SET_TX_DESC_EARLY_MODE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+	#define SET_TX_DESC_HWSEQ_SEL_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+	#define SET_TX_DESC_USE_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+	#define SET_TX_DESC_DISABLE_RTS_FB_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+	#define SET_TX_DESC_DISABLE_FB_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+	#define SET_TX_DESC_CTS2SELF_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+	#define SET_TX_DESC_RTS_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+	#define SET_TX_DESC_HW_RTS_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+	#define SET_TX_DESC_NAV_USE_HDR_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+	#define SET_TX_DESC_USE_MAX_LEN_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+	#define SET_TX_DESC_MAX_AGG_NUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+	#define SET_TX_DESC_NDPA_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+	#define SET_TX_DESC_AMPDU_MAX_TIME_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+	/* Dword 4 */
+	#define SET_TX_DESC_TX_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+	#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+	#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+	#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+	#define SET_TX_DESC_DATA_RETRY_LIMIT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+	#define SET_TX_DESC_RTS_RATE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+
+
+	/* Dword 5 */
+	#define SET_TX_DESC_DATA_SC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+	#define SET_TX_DESC_DATA_SHORT_8703B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+	#define SET_TX_DESC_DATA_BW_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+	#define SET_TX_DESC_DATA_LDPC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+	#define SET_TX_DESC_DATA_STBC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+	#define SET_TX_DESC_CTROL_STBC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+	#define SET_TX_DESC_RTS_SHORT_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+	#define SET_TX_DESC_RTS_SC_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+
+
+	/* Dword 6 */
+	#define SET_TX_DESC_SW_DEFINE_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+	#define SET_TX_DESC_MBSSID_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+	#define SET_TX_DESC_ANTSEL_A_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_B_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_C_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_D_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+
+	/* Dword 7 */
+	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		#define SET_TX_DESC_TX_BUFFER_SIZE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#else
+		#define SET_TX_DESC_TX_DESC_CHECKSUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#endif
+	#define SET_TX_DESC_USB_TXAGG_NUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+	#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+		#define SET_TX_DESC_SDIO_TXSEQ_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+	#endif
+
+	/* Dword 8 */
+	#define SET_TX_DESC_HWSEQ_EN_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+
+	/* Dword 9 */
+	#define SET_TX_DESC_SEQ_8703B(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+
+	/* Dword 10 */
+	#define SET_TX_DESC_TX_BUFFER_ADDRESS_8703B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+	#define GET_TX_DESC_TX_BUFFER_ADDRESS_8703B(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+
+	/* Dword 11 */
+	#define SET_TX_DESC_NEXT_DESC_ADDRESS_8703B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+
+
+	#define SET_EARLYMODE_PKTNUM_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+	#define SET_EARLYMODE_LEN0_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+	#define SET_EARLYMODE_LEN1_1_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+	#define SET_EARLYMODE_LEN1_2_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+	#define SET_EARLYMODE_LEN2_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+	#define SET_EARLYMODE_LEN3_8703B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8703B_RATE1M				0x00
+#define DESC8703B_RATE2M				0x01
+#define DESC8703B_RATE5_5M				0x02
+#define DESC8703B_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8703B_RATE6M				0x04
+#define DESC8703B_RATE9M				0x05
+#define DESC8703B_RATE12M				0x06
+#define DESC8703B_RATE18M				0x07
+#define DESC8703B_RATE24M				0x08
+#define DESC8703B_RATE36M				0x09
+#define DESC8703B_RATE48M				0x0a
+#define DESC8703B_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8703B_RATEMCS0				0x0c
+#define DESC8703B_RATEMCS1				0x0d
+#define DESC8703B_RATEMCS2				0x0e
+#define DESC8703B_RATEMCS3				0x0f
+#define DESC8703B_RATEMCS4				0x10
+#define DESC8703B_RATEMCS5				0x11
+#define DESC8703B_RATEMCS6				0x12
+#define DESC8703B_RATEMCS7				0x13
+#define DESC8703B_RATEMCS8				0x14
+#define DESC8703B_RATEMCS9				0x15
+#define DESC8703B_RATEMCS10		0x16
+#define DESC8703B_RATEMCS11		0x17
+#define DESC8703B_RATEMCS12		0x18
+#define DESC8703B_RATEMCS13		0x19
+#define DESC8703B_RATEMCS14		0x1a
+#define DESC8703B_RATEMCS15		0x1b
+#define DESC8703B_RATEVHTSS1MCS0		0x2c
+#define DESC8703B_RATEVHTSS1MCS1		0x2d
+#define DESC8703B_RATEVHTSS1MCS2		0x2e
+#define DESC8703B_RATEVHTSS1MCS3		0x2f
+#define DESC8703B_RATEVHTSS1MCS4		0x30
+#define DESC8703B_RATEVHTSS1MCS5		0x31
+#define DESC8703B_RATEVHTSS1MCS6		0x32
+#define DESC8703B_RATEVHTSS1MCS7		0x33
+#define DESC8703B_RATEVHTSS1MCS8		0x34
+#define DESC8703B_RATEVHTSS1MCS9		0x35
+#define DESC8703B_RATEVHTSS2MCS0		0x36
+#define DESC8703B_RATEVHTSS2MCS1		0x37
+#define DESC8703B_RATEVHTSS2MCS2		0x38
+#define DESC8703B_RATEVHTSS2MCS3		0x39
+#define DESC8703B_RATEVHTSS2MCS4		0x3a
+#define DESC8703B_RATEVHTSS2MCS5		0x3b
+#define DESC8703B_RATEVHTSS2MCS6		0x3c
+#define DESC8703B_RATEVHTSS2MCS7		0x3d
+#define DESC8703B_RATEVHTSS2MCS8		0x3e
+#define DESC8703B_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8703B(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8703B(pDesc) == DESC8703B_RATE11M)
+
+
+void rtl8703b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8703b_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8703bs_init_xmit_priv(PADAPTER padapter);
+	void rtl8703bs_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8703bs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703bs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8703bs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703bs_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8703bs_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8703bs_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8703bu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8703bu_xmit_buf_handler
+
+
+	s32 rtl8703bu_init_xmit_priv(PADAPTER padapter);
+	void rtl8703bu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8703bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8703bu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	/* s32 rtl8812au_xmit_buf_handler(PADAPTER padapter); */
+	void rtl8703bu_xmit_tasklet(void *priv);
+	s32 rtl8703bu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8703be_init_xmit_priv(PADAPTER padapter);
+	void rtl8703be_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8703be_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void	rtl8703be_xmitframe_resume(_adapter *padapter);
+	s32 rtl8703be_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8703be_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8703be_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8703be_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8703B(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8703B(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_cmd.h
index f656b27ffb35..9cc6f6db7570 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_cmd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,54 +12,49 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8723B_CMD_H__
 #define __RTL8723B_CMD_H__
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD DEFINITION    ------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
-enum h2c_cmd_8723B{
-	//Common Class: 000
+enum h2c_cmd_8723B {
+	/* Common Class: 000 */
 	H2C_8723B_RSVD_PAGE = 0x00,
 	H2C_8723B_MEDIA_STATUS_RPT = 0x01,
 	H2C_8723B_SCAN_ENABLE = 0x02,
 	H2C_8723B_KEEP_ALIVE = 0x03,
-	H2C_8723B_DISCON_DECISION = 0x04,	
-	H2C_8723B_PSD_OFFLOAD = 0x05,	
-	H2C_8723B_AP_OFFLOAD = 0x08,	
-	H2C_8723B_BCN_RSVDPAGE = 0x09,	
-	H2C_8723B_PROBERSP_RSVDPAGE = 0x0A,	
-	H2C_8723B_FCS_RSVDPAGE = 0x10,	
-	H2C_8723B_FCS_INFO = 0x11,	
+	H2C_8723B_DISCON_DECISION = 0x04,
+	H2C_8723B_PSD_OFFLOAD = 0x05,
+	H2C_8723B_AP_OFFLOAD = 0x08,
+	H2C_8723B_BCN_RSVDPAGE = 0x09,
+	H2C_8723B_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8723B_FCS_RSVDPAGE = 0x10,
+	H2C_8723B_FCS_INFO = 0x11,
 	H2C_8723B_AP_WOW_GPIO_CTRL = 0x13,
 
-	//PoweSave Class: 001
+	/* PoweSave Class: 001 */
 	H2C_8723B_SET_PWR_MODE = 0x20,
 	H2C_8723B_PS_TUNING_PARA = 0x21,
 	H2C_8723B_PS_TUNING_PARA2 = 0x22,
-	H2C_8723B_P2P_LPS_PARAM = 0x23,	
-	H2C_8723B_P2P_PS_OFFLOAD = 0x24,	
-	H2C_8723B_PS_SCAN_ENABLE = 0x25,	
-	H2C_8723B_SAP_PS_ = 0x26,	
-	H2C_8723B_INACTIVE_PS_ = 0x27, //Inactive_PS
+	H2C_8723B_P2P_LPS_PARAM = 0x23,
+	H2C_8723B_P2P_PS_OFFLOAD = 0x24,
+	H2C_8723B_PS_SCAN_ENABLE = 0x25,
+	H2C_8723B_SAP_PS_ = 0x26,
+	H2C_8723B_INACTIVE_PS_ = 0x27, /* Inactive_PS */
 	H2C_8723B_FWLPS_IN_IPS_ = 0x28,
-	
-	//Dynamic Mechanism Class: 010
-	H2C_8723B_MACID_CFG = 0x40,	
-	H2C_8723B_TXBF = 0x41,	
-	H2C_8723B_RSSI_SETTING = 0x42,	
-	H2C_8723B_AP_REQ_TXRPT = 0x43,	
-	H2C_8723B_INIT_RATE_COLLECT = 0x44,	
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8723B_MACID_CFG = 0x40,
+	H2C_8723B_TXBF = 0x41,
+	H2C_8723B_RSSI_SETTING = 0x42,
+	H2C_8723B_AP_REQ_TXRPT = 0x43,
+	H2C_8723B_INIT_RATE_COLLECT = 0x44,
 	H2C_8723B_RA_PARA_ADJUST = 0x46,
-	
-	//BT Class: 011
+
+	/* BT Class: 011 */
 	H2C_8723B_B_TYPE_TDMA = 0x60,
 	H2C_8723B_BT_INFO = 0x61,
 	H2C_8723B_FORCE_BT_TXPWR = 0x62,
@@ -70,65 +66,66 @@ enum h2c_cmd_8723B{
 	H2C_8723B_BT_CONTROL = 0x68,
 	H2C_8723B_BT_WIFI_CTRL = 0x69,
 	H2C_8723B_BT_FW_PATCH = 0x6A,
-	H2C_8723B_BT_WLAN_CALIBRATION = 0x6D,	
-	
-	//WOWLAN Class: 100
+	H2C_8723B_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
 	H2C_8723B_WOWLAN = 0x80,
 	H2C_8723B_REMOTE_WAKE_CTRL = 0x81,
-	H2C_8723B_AOAC_GLOBAL_INFO = 0x82,	
-	H2C_8723B_AOAC_RSVD_PAGE = 0x83,	
+	H2C_8723B_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8723B_AOAC_RSVD_PAGE = 0x83,
 	H2C_8723B_AOAC_RSVD_PAGE2 = 0x84,
 	H2C_8723B_D0_SCAN_OFFLOAD_CTRL = 0x85,
 	H2C_8723B_D0_SCAN_OFFLOAD_INFO = 0x86,
 	H2C_8723B_CHNL_SWITCH_OFFLOAD = 0x87,
-	H2C_8723B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,	
+	H2C_8723B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
 	H2C_8723B_P2P_OFFLOAD = 0x8B,
 
 	H2C_8723B_RESET_TSF = 0xC0,
 	H2C_8723B_MAXID,
 };
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    H2C CMD CONTENT    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
-//_RSVDPAGE_LOC_CMD_0x00
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
 #define SET_8723B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8723B_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_8723B_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8723B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8723B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 
-//_KEEP_ALIVE_CMD_0x03
+/* _KEEP_ALIVE_CMD_0x03 */
 #define SET_8723B_H2CCMD_KEEPALIVE_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8723B_H2CCMD_KEEPALIVE_PARM_ADOPT(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8723B_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
 #define SET_8723B_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 
-//_DISCONNECT_DECISION_CMD_0x04
+/* _DISCONNECT_DECISION_CMD_0x04 */
 #define SET_8723B_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8723B_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8723B_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_8723B_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
 
-// _PWR_MOD_CMD_0x20
+/* _PWR_MOD_CMD_0x20 */
 #define SET_8723B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8723B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
-// _PS_TUNE_PARAM_CMD_0x21
+/* _PS_TUNE_PARAM_CMD_0x21 */
 #define SET_8723B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8723B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_8723B_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
 #define SET_8723B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
 #define SET_8723B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 
-//_MACID_CFG_CMD_0x40
+/* _MACID_CFG_CMD_0x40 */
 #define SET_8723B_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8723B_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
 #define SET_8723B_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
@@ -142,19 +139,19 @@ enum h2c_cmd_8723B{
 #define SET_8723B_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
 #define SET_8723B_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
 
-//_RSSI_SETTING_CMD_0x42
+/* _RSSI_SETTING_CMD_0x42 */
 #define SET_8723B_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8723B_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
 #define SET_8723B_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 
-// _AP_REQ_TXRPT_CMD_0x43
+/* _AP_REQ_TXRPT_CMD_0x43 */
 #define SET_8723B_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8723B_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 
-// _FORCE_BT_TXPWR_CMD_0x62
+/* _FORCE_BT_TXPWR_CMD_0x62 */
 #define SET_8723B_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 
-// _FORCE_BT_MP_OPER_CMD_0x67
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
 #define SET_8723B_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
 #define SET_8723B_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
 #define SET_8723B_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
@@ -162,52 +159,50 @@ enum h2c_cmd_8723B{
 #define SET_8723B_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 #define SET_8723B_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
 
-// _BT_FW_PATCH_0x6A
+/* _BT_FW_PATCH_0x6A */
 #define SET_8723B_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
-#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value) 
-#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value) 
-#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value) 
-#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value) 					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8723B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
-//---------------------------------------------------------------------------------------------------------//
-//-------------------------------------------    Structure    --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
 
-//---------------------------------------------------------------------------------------------------------//
-//----------------------------------    Function Statement     --------------------------------------------------//
-//---------------------------------------------------------------------------------------------------------//
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
 
-// host message to firmware cmd
+/* host message to firmware cmd */
 void rtl8723b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8723b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
 void rtl8723b_set_rssi_cmd(PADAPTER padapter, u8 *param);
-void rtl8723b_Add_RateATid(PADAPTER pAdapter, u64 rate_bitmap, u8 *arg, u8 rssi_level);
 void rtl8723b_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
-//s32 rtl8723b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable);
+/* s32 rtl8723b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
 void rtl8723b_set_FwPsTuneParam_cmd(PADAPTER padapter);
-void rtl8723b_set_FwMacIdConfig_cmd(_adapter* padapter, u8 mac_id, u8 raid, u8 bw, u8 sgi, u32 mask);
 void rtl8723b_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param);
 void rtl8723b_download_rsvd_page(PADAPTER padapter, u8 mstatus);
 #ifdef CONFIG_BT_COEXIST
-void rtl8723b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
-#endif // CONFIG_BT_COEXIST
+	void rtl8723b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
 #ifdef CONFIG_P2P
-void rtl8723b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
-#endif //CONFIG_P2P
+	void rtl8723b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
 
-void CheckFwRsvdPageContent(PADAPTER padapter);
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8723b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
 
 #ifdef CONFIG_P2P_WOWLAN
-void rtl8723b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+	void rtl8723b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
 #endif
 
 void rtl8723b_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
 
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-u8 rtl8723b_reset_tsf(_adapter *padapter, u8 reset_port);
-#endif	// CONFIG_TSF_RESET_OFFLOAD
 s32 FillH2CCmd8723B(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 u8 GetTxBufferRsvdPageNum8723B(_adapter *padapter, bool wowlan);
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_dm.h
index 2108c46dd603..0a18c1654b42 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,38 +12,28 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8723B_DM_H__
 #define __RTL8723B_DM_H__
-//============================================================
-// Description:
-//
-// This file is for 8723B dynamic mechanism only
-//
-//
-//============================================================
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8723B dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
 
-//============================================================
-// structure and define
-//============================================================
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
 
-//============================================================
-// function prototype
-//============================================================
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
 
 void rtl8723b_init_dm_priv(PADAPTER padapter);
 void rtl8723b_deinit_dm_priv(PADAPTER padapter);
 
 void rtl8723b_InitHalDm(PADAPTER padapter);
 void rtl8723b_HalDmWatchDog(PADAPTER padapter);
-void rtl8723b_HalDmWatchDog_in_LPS(PADAPTER padapter);
-void rtl8723b_hal_dm_in_lps(PADAPTER padapter);
-
-
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_hal.h
index 842430819d59..e3de25d37540 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_hal.h
@@ -1,326 +1,283 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8723B_HAL_H__
-#define __RTL8723B_HAL_H__
-
-#include "hal_data.h"
-
-#include "rtl8723b_spec.h"
-#include "rtl8723b_rf.h"
-#include "rtl8723b_dm.h"
-#include "rtl8723b_recv.h"
-#include "rtl8723b_xmit.h"
-#include "rtl8723b_cmd.h"
-#include "rtl8723b_led.h"
-#include "Hal8723BPwrSeq.h"
-#include "Hal8723BPhyReg.h"
-#include "Hal8723BPhyCfg.h"
-#ifdef DBG_CONFIG_ERROR_DETECT
-#include "rtl8723b_sreset.h"
-#endif
-
-
-//---------------------------------------------------------------------
-//		RTL8723B From file
-//---------------------------------------------------------------------
-	#define RTL8723B_FW_IMG					"rtl8723b/FW_NIC.bin"
-	#define RTL8723B_FW_WW_IMG				"rtl8723b/FW_WoWLAN.bin"
-	#define RTL8723B_PHY_REG					"rtl8723b/PHY_REG.txt"
-	#define RTL8723B_PHY_RADIO_A				"rtl8723b/RadioA.txt"
-	#define RTL8723B_PHY_RADIO_B				"rtl8723b/RadioB.txt"
-	#define RTL8723B_TXPWR_TRACK				"rtl8723b/TxPowerTrack.txt" 
-	#define RTL8723B_AGC_TAB					"rtl8723b/AGC_TAB.txt"
-	#define RTL8723B_PHY_MACREG 				"rtl8723b/MAC_REG.txt"
-	#define RTL8723B_PHY_REG_PG				"rtl8723b/PHY_REG_PG.txt"
-	#define RTL8723B_PHY_REG_MP				"rtl8723b/PHY_REG_MP.txt"
-	#define RTL8723B_TXPWR_LMT 				"rtl8723b/TXPWR_LMT.txt"
-
-//---------------------------------------------------------------------
-//		RTL8723B From header
-//---------------------------------------------------------------------
-
-#if MP_DRIVER == 1
-	#define Rtl8723B_FwBTImgArray				Rtl8723BFwBTImgArray
-	#define Rtl8723B_FwBTImgArrayLength		Rtl8723BFwBTImgArrayLength
-
-	#define Rtl8723B_PHY_REG_Array_MP			Rtl8723B_PHYREG_Array_MP
-	#define Rtl8723B_PHY_REG_Array_MPLength	Rtl8723B_PHYREG_Array_MPLength
-#endif
-
-
-#define FW_8723B_SIZE			0x8000
-#define FW_8723B_START_ADDRESS	0x1000
-#define FW_8723B_END_ADDRESS		0x1FFF //0x5FFF
-
-#define IS_FW_HEADER_EXIST_8723B(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature)&0xFFF0) == 0x5300)
-
-typedef struct _RT_FIRMWARE {
-	FIRMWARE_SOURCE	eFWSource;
-#ifdef CONFIG_EMBEDDED_FWIMG
-	u8*			szFwBuffer;
-#else
-	u8			szFwBuffer[FW_8723B_SIZE];
-#endif
-	u32			ulFwLength;
-} RT_FIRMWARE_8723B, *PRT_FIRMWARE_8723B;
-
-//
-// This structure must be cared byte-ordering
-//
-// Added by tynli. 2009.12.04.
-typedef struct _RT_8723B_FIRMWARE_HDR
-{
-	// 8-byte alinment required
-
-	//--- LONG WORD 0 ----
-	u16		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
-	u16		Version;		// FW Version
-	u16		Subversion;	// FW Subversion, default 0x00
-
-	//--- 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
-	u16		RamCodeSize;	// The size of RAM code
-	u16		Rsvd2;
-
-	//--- LONG WORD 2 ----
-	u32		SvnIdx;	// The SVN entry index
-	u32		Rsvd3;
-
-	//--- LONG WORD 3 ----
-	u32		Rsvd4;
-	u32		Rsvd5;
-}RT_8723B_FIRMWARE_HDR, *PRT_8723B_FIRMWARE_HDR;
-
-#define DRIVER_EARLY_INT_TIME_8723B		0x05
-#define BCN_DMA_ATIME_INT_TIME_8723B		0x02
-
-// for 8723B
-// TX 32K, RX 16K, Page size 128B for TX, 8B for RX
-#define PAGE_SIZE_TX_8723B			128
-#define PAGE_SIZE_RX_8723B			8
-
-#define TX_DMA_SIZE_8723B			0x8000	/* 32K(TX) */
-#define RX_DMA_SIZE_8723B			0x4000	/* 16K(RX) */
-
-#ifdef CONFIG_WOWLAN
-#define RESV_FMWF	WKFMCAM_SIZE*MAX_WKFM_NUM /* 16 entries, for each is 24 bytes*/
-#else
-#define RESV_FMWF	0
-#endif
-
-#ifdef CONFIG_FW_C2H_DEBUG 
-#define RX_DMA_RESERVED_SIZE_8723B	0x100	// 256B, reserved for c2h debug message
-#else
-#define RX_DMA_RESERVED_SIZE_8723B	0x80	// 128B, reserved for tx report
-#endif
-#define RX_DMA_BOUNDARY_8723B		(RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B - 1)
-
-
-// Note: We will divide number of page equally for each queue other than public queue!
-
-//For General Reserved Page Number(Beacon Queue is reserved page)
-//Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1
-#define BCNQ_PAGE_NUM_8723B		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-#define BCNQ1_PAGE_NUM_8723B		0x08 // 0x04
-#else
-#define BCNQ1_PAGE_NUM_8723B		0x00
-#endif
-
-#ifdef CONFIG_PNO_SUPPORT
-#undef BCNQ1_PAGE_NUM_8723B
-#define BCNQ1_PAGE_NUM_8723B		0x00 // 0x04
-#endif
-
-//For WoWLan , more reserved page
-//ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, PNO: 6
-#ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_8723B	0x07
-#else
-#define WOWLAN_PAGE_NUM_8723B	0x00
-#endif
-
-#ifdef CONFIG_PNO_SUPPORT
-#undef WOWLAN_PAGE_NUM_8723B
-#define WOWLAN_PAGE_NUM_8723B	0x15
-#endif
-
-#ifdef CONFIG_AP_WOWLAN
-#define AP_WOWLAN_PAGE_NUM_8723B	0x02
-#endif
-
-#define TX_TOTAL_PAGE_NUMBER_8723B	(0xFF - BCNQ_PAGE_NUM_8723B - BCNQ1_PAGE_NUM_8723B - WOWLAN_PAGE_NUM_8723B)
-#define TX_PAGE_BOUNDARY_8723B		(TX_TOTAL_PAGE_NUMBER_8723B + 1)
-
-#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B	TX_TOTAL_PAGE_NUMBER_8723B
-#define WMM_NORMAL_TX_PAGE_BOUNDARY_8723B		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B + 1)
-
-// For Normal Chip Setting
-// (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723B
-#define NORMAL_PAGE_NUM_HPQ_8723B		0x0C
-#define NORMAL_PAGE_NUM_LPQ_8723B		0x02
-#define NORMAL_PAGE_NUM_NPQ_8723B		0x02
-
-// Note: For Normal Chip Setting, modify later
-#define WMM_NORMAL_PAGE_NUM_HPQ_8723B		0x30
-#define WMM_NORMAL_PAGE_NUM_LPQ_8723B		0x20
-#define WMM_NORMAL_PAGE_NUM_NPQ_8723B		0x20
-
-
-#include "HalVerDef.h"
-#include "hal_com.h"
-
-#define EFUSE_OOB_PROTECT_BYTES 		15
-
-#define HAL_EFUSE_MEMORY
-
-#define HWSET_MAX_SIZE_8723B			512
-#define EFUSE_REAL_CONTENT_LEN_8723B		512
-#define EFUSE_MAP_LEN_8723B				512
-#define EFUSE_MAX_SECTION_8723B			64
-
-#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_8723B)
-
-#define EFUSE_ACCESS_ON			0x69	// For RTL8723 only.
-#define EFUSE_ACCESS_OFF			0x00	// For RTL8723 only.
-
-//========================================================
-//			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
-
-typedef struct _C2H_EVT_HDR
-{
-	u8	CmdID;
-	u8	CmdLen;
-	u8	CmdSeq;
-} __attribute__((__packed__)) C2H_EVT_HDR, *PC2H_EVT_HDR;
-
-typedef enum tag_Package_Definition
-{
-    PACKAGE_DEFAULT,
-    PACKAGE_QFN68,
-    PACKAGE_TFBGA90,
-    PACKAGE_TFBGA80,
-    PACKAGE_TFBGA79
-}PACKAGE_TYPE_E;
-
-#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)
-
-// rtl8723a_hal_init.c
-s32 rtl8723b_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
-void rtl8723b_FirmwareSelfReset(PADAPTER padapter);
-void rtl8723b_InitializeFirmwareVars(PADAPTER padapter);
-
-void rtl8723b_InitAntenna_Selection(PADAPTER padapter);
-void rtl8723b_DeinitAntenna_Selection(PADAPTER padapter);
-void rtl8723b_CheckAntenna_Selection(PADAPTER padapter);
-void rtl8723b_init_default_value(PADAPTER padapter);
-
-s32 rtl8723b_InitLLTTable(PADAPTER padapter);
-
-s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
-s32 CardDisableWithoutHWSM(PADAPTER padapter);
-
-// EFuse
-u8 GetEEPROMSize8723B(PADAPTER padapter);
-void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
-void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
-void Hal_EfuseParseTxPowerInfo_8723B(PADAPTER padapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseBTCoexistInfo_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseEEPROMVer_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseChnlPlan_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseCustomerID_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseAntennaDiversity_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParseXtal_8723B(PADAPTER pAdapter, u8 *hwinfo, u8 AutoLoadFail);
-void Hal_EfuseParseThermalMeter_8723B(PADAPTER padapter, u8 *hwinfo, u8 AutoLoadFail);
-VOID Hal_EfuseParsePackageType_8723B(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-VOID Hal_EfuseParseVoltage_8723B(PADAPTER pAdapter,u8* hwinfo,BOOLEAN 	AutoLoadFail); 
-VOID Hal_EfuseParseBoardType_8723B(PADAPTER Adapter,	u8*	PROMContent,BOOLEAN AutoloadFail);
-
-#ifdef CONFIG_C2H_PACKET_EN
-void rtl8723b_c2h_packet_handler(PADAPTER padapter, u8 *pbuf, u16 length);
-#endif
-
-
-void rtl8723b_set_hal_ops(struct hal_ops *pHalFunc);
-void init_hal_spec_8723b(_adapter *adapter);
-void SetHwReg8723B(PADAPTER padapter, u8 variable, u8 *val);
-void GetHwReg8723B(PADAPTER padapter, u8 variable, u8 *val);
-#ifdef CONFIG_C2H_PACKET_EN
-void SetHwRegWithBuf8723B(PADAPTER padapter, u8 variable, u8 *pbuf, int len);
-#endif // CONFIG_C2H_PACKET_EN
-u8 SetHalDefVar8723B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-u8 GetHalDefVar8723B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-
-// register
-void rtl8723b_InitBeaconParameters(PADAPTER padapter);
-void rtl8723b_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
-void	_InitBurstPktLen_8723BS(PADAPTER Adapter);
-void _8051Reset8723(PADAPTER padapter);
-#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-void Hal_DetectWoWMode(PADAPTER pAdapter);
-#endif //CONFIG_WOWLAN
-
-void rtl8723b_start_thread(_adapter *padapter);
-void rtl8723b_stop_thread(_adapter *padapter);
-
-#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
-void rtl8723bs_init_checkbthang_workqueue(_adapter * adapter);
-void rtl8723bs_free_checkbthang_workqueue(_adapter * adapter);
-void rtl8723bs_cancle_checkbthang_workqueue(_adapter * adapter);
-void rtl8723bs_hal_check_bt_hang(_adapter * adapter);
-#endif
-
-#ifdef CONFIG_GPIO_WAKEUP
-void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
-#endif
-
-int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
-
-void CCX_FwC2HTxRpt_8723b(PADAPTER padapter, u8 *pdata, u8 len);
-s32 c2h_id_filter_ccx_8723b(u8 *buf);
-s32 c2h_handler_8723b(PADAPTER padapter, u8 *pC2hEvent);
-u8 MRateToHwRate8723B(u8  rate);
-u8 HwRateToMRate8723B(u8	 rate);
-
-#ifdef CONFIG_RF_GAIN_OFFSET
-void Hal_ReadRFGainOffset(PADAPTER pAdapter,u8* hwinfo,BOOLEAN AutoLoadFail);
-#endif //CONFIG_RF_GAIN_OFFSET
-
-#ifdef CONFIG_PCI_HCI
-BOOLEAN	InterruptRecognized8723BE(PADAPTER Adapter);
-VOID	UpdateInterruptMask8723BE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
-#endif
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_HAL_H__
+#define __RTL8723B_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8723b_spec.h"
+#include "rtl8723b_rf.h"
+#include "rtl8723b_dm.h"
+#include "rtl8723b_recv.h"
+#include "rtl8723b_xmit.h"
+#include "rtl8723b_cmd.h"
+#include "rtl8723b_led.h"
+#include "Hal8723BPwrSeq.h"
+#include "Hal8723BPhyReg.h"
+#include "Hal8723BPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8723b_sreset.h"
+#endif
+
+#define FW_8723B_SIZE			0x8000
+#define FW_8723B_START_ADDRESS	0x1000
+#define FW_8723B_END_ADDRESS		0x1FFF /* 0x5FFF */
+
+#define IS_FW_HEADER_EXIST_8723B(_pFwHdr)	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x5300)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8723B_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8723B, *PRT_FIRMWARE_8723B;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8723B_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8723B_FIRMWARE_HDR, *PRT_8723B_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8723B		0x05
+#define BCN_DMA_ATIME_INT_TIME_8723B		0x02
+
+/* for 8723B
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8723B			128
+#define PAGE_SIZE_RX_8723B			8
+
+#define TX_DMA_SIZE_8723B			0x8000	/* 32K(TX) */
+#define RX_DMA_SIZE_8723B			0x4000	/* 16K(RX) */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8723B	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8723B	0x80	/* 128B, reserved for tx report */
+#endif
+#define RX_DMA_BOUNDARY_8723B		(RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
+#define BCNQ_PAGE_NUM_8723B		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8723B		0x08 /* 0x04 */
+#else
+	#define BCNQ1_PAGE_NUM_8723B		0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef BCNQ1_PAGE_NUM_8723B
+	#define BCNQ1_PAGE_NUM_8723B		0x00 /* 0x04 */
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1,PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8723B	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8723B	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8723B
+	#define WOWLAN_PAGE_NUM_8723B	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8723B	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8723B	(0xFF - BCNQ_PAGE_NUM_8723B - BCNQ1_PAGE_NUM_8723B - WOWLAN_PAGE_NUM_8723B)
+#define TX_PAGE_BOUNDARY_8723B		(TX_TOTAL_PAGE_NUMBER_8723B + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B	TX_TOTAL_PAGE_NUMBER_8723B
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8723B		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723B */
+#define NORMAL_PAGE_NUM_HPQ_8723B		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8723B		0x02
+#define NORMAL_PAGE_NUM_NPQ_8723B		0x02
+#define NORMAL_PAGE_NUM_EPQ_8723B		0x04
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8723B		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8723B		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8723B		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8723B		0x00
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES		15
+
+#define HAL_EFUSE_MEMORY
+
+#define HWSET_MAX_SIZE_8723B			512
+#define EFUSE_REAL_CONTENT_LEN_8723B		512
+#define EFUSE_MAP_LEN_8723B				512
+#define EFUSE_MAX_SECTION_8723B			64
+
+#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_8723B)
+
+#define EFUSE_ACCESS_ON			0x69	/* For RTL8723 only. */
+#define EFUSE_ACCESS_OFF			0x00	/* For RTL8723 only. */
+
+/* ********************************************************
+ *			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
+
+typedef enum tag_Package_Definition {
+	PACKAGE_DEFAULT,
+	PACKAGE_QFN68,
+	PACKAGE_TFBGA90,
+	PACKAGE_TFBGA80,
+	PACKAGE_TFBGA79
+} PACKAGE_TYPE_E;
+
+#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)
+
+/* rtl8723a_hal_init.c */
+s32 rtl8723b_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8723b_FirmwareSelfReset(PADAPTER padapter);
+void rtl8723b_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8723b_InitAntenna_Selection(PADAPTER padapter);
+void rtl8723b_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8723b_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8723b_init_default_value(PADAPTER padapter);
+
+s32 rtl8723b_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8723B(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8723B(PADAPTER padapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBTCoexistInfo_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseEEPROMVer_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8723B(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8723B(PADAPTER pAdapter, u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8723B(PADAPTER padapter, u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParsePackageType_8723B(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+VOID Hal_EfuseParseVoltage_8723B(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8723B(PADAPTER Adapter,	u8	*PROMContent, BOOLEAN AutoloadFail);
+
+void rtl8723b_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8723b(_adapter *adapter);
+u8 SetHwReg8723B(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8723B(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8723B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8723B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8723b_InitBeaconParameters(PADAPTER padapter);
+void rtl8723b_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void	_InitBurstPktLen_8723BS(PADAPTER Adapter);
+void _8051Reset8723(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8723b_start_thread(_adapter *padapter);
+void rtl8723b_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8723bs_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723bs_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723bs_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723bs_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void CCX_FwC2HTxRpt_8723b(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8723B(u8  rate);
+u8 HwRateToMRate8723B(u8	 rate);
+
+#ifdef CONFIG_RF_POWER_TRIM
+	void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8723BE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8723BE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+#endif
+
+#ifdef CONFIG_GPIO_API
+int rtl8723b_GpioFuncCheck(PADAPTER adapter, u8 gpio_num);
+VOID rtl8723b_GpioMultiFuncReset(PADAPTER adapter, u8 gpio_num);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_led.h
index 36772c051571..1261c5e9a4d3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_led.h
@@ -1,49 +1,45 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8723B_LED_H__
-#define __RTL8723B_LED_H__
-
-#include <drv_conf.h>
-#include <osdep_service.h>
-#include <drv_types.h>
-
-
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
-#ifdef CONFIG_USB_HCI
-void rtl8723bu_InitSwLeds(PADAPTER padapter);
-void rtl8723bu_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_SDIO_HCI
-void rtl8723bs_InitSwLeds(PADAPTER padapter);
-void rtl8723bs_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_GSPI_HCI
-void rtl8723bs_InitSwLeds(PADAPTER padapter);
-void rtl8723bs_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_PCI_HCI
-void rtl8723be_InitSwLeds(PADAPTER padapter);
-void rtl8723be_DeInitSwLeds(PADAPTER padapter);
-#endif
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_LED_H__
+#define __RTL8723B_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8723bu_InitSwLeds(PADAPTER padapter);
+	void rtl8723bu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8723bs_InitSwLeds(PADAPTER padapter);
+	void rtl8723bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+	void rtl8723bs_InitSwLeds(PADAPTER padapter);
+	void rtl8723bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8723be_InitSwLeds(PADAPTER padapter);
+	void rtl8723be_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif
+#endif/*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_recv.h
index f4611864dc78..ec20f1016eec 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_recv.h
@@ -1,92 +1,87 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8723B_RECV_H__
-#define __RTL8723B_RECV_H__
-
-#define RECV_BLK_SZ 512
-#define RECV_BLK_CNT 16
-#define RECV_BLK_TH RECV_BLK_CNT
-
-#if defined(CONFIG_USB_HCI)
-
-#ifndef MAX_RECVBUF_SZ
-#ifdef PLATFORM_OS_CE
-#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-#else
-	#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-		//#define MAX_RECVBUF_SZ (32768) // 32k
-		//#define MAX_RECVBUF_SZ (16384) //16K
-		//#define MAX_RECVBUF_SZ (10240) //10K
-		#ifdef CONFIG_PLATFORM_MSTAR
-			#define MAX_RECVBUF_SZ (8192) // 8K
-		#else
-		        #define MAX_RECVBUF_SZ (15360) // 15k < 16k
-		#endif
-		//#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-	#else
-		#define MAX_RECVBUF_SZ (4000) // about 4K
-	#endif
-#endif
-#endif //!MAX_RECVBUF_SZ
-
-#elif defined(CONFIG_PCI_HCI)
-//#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-//	#define MAX_RECVBUF_SZ (9100)
-//#else
-	#define MAX_RECVBUF_SZ (4000) // about 4K
-//#endif
-
-
-#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-
-#define MAX_RECVBUF_SZ (10240)
-
-#endif
-
-// Rx smooth factor
-#define	Rx_Smooth_Factor (20)
-
-#ifdef CONFIG_SDIO_HCI
-#ifndef CONFIG_SDIO_RX_COPY
-#undef MAX_RECVBUF_SZ
-#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B)
-#endif // !CONFIG_SDIO_RX_COPY
-#endif // CONFIG_SDIO_HCI
-
-#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-s32 rtl8723bs_init_recv_priv(PADAPTER padapter);
-void rtl8723bs_free_recv_priv(PADAPTER padapter);
-#endif
-
-#ifdef CONFIG_USB_HCI
-int rtl8723bu_init_recv_priv(_adapter *padapter);
-void rtl8723bu_free_recv_priv (_adapter *padapter);
-void rtl8723bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8723be_init_recv_priv(PADAPTER padapter);
-void rtl8723be_free_recv_priv(PADAPTER padapter);
-#endif
-
-void rtl8723b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
-
-#endif /* __RTL8723B_RECV_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_RECV_H__
+#define __RTL8723B_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ  (RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_SDIO_HCI
+	#ifndef CONFIG_SDIO_RX_COPY
+		#undef MAX_RECVBUF_SZ
+		#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8723B - RX_DMA_RESERVED_SIZE_8723B)
+	#endif /* !CONFIG_SDIO_RX_COPY */
+#endif /* CONFIG_SDIO_HCI */
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723bs_init_recv_priv(PADAPTER padapter);
+	void rtl8723bs_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8723bu_init_recv_priv(_adapter *padapter);
+	void rtl8723bu_free_recv_priv(_adapter *padapter);
+	void rtl8723bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723be_init_recv_priv(PADAPTER padapter);
+	void rtl8723be_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8723b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8723B_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_rf.h
index 2bb734176e96..5341460705af 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,21 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8723B_RF_H__
 #define __RTL8723B_RF_H__
 
-int	PHY_RF6052_Config8723B(	IN	PADAPTER		Adapter	);
+int	PHY_RF6052_Config8723B(IN	PADAPTER		Adapter);
 
 VOID
 PHY_RF6052SetBandwidth8723B(
 	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH		Bandwidth);
+	IN	enum channel_width		Bandwidth);
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_spec.h
index ce8169199948..d8643cc4afdc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_spec.h
@@ -1,296 +1,281 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
-#ifndef __RTL8723B_SPEC_H__
-#define __RTL8723B_SPEC_H__
-
-#include <drv_conf.h>
-
-
-#define HAL_NAV_UPPER_UNIT_8723B		128		// micro-second
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_RSV_CTRL_8723B				0x001C	// 3 Byte
-#define REG_BT_WIFI_ANTENNA_SWITCH_8723B	0x0038
-#define REG_HSISR_8723B					0x005c
-#define REG_PAD_CTRL1_8723B		0x0064
-#define REG_AFE_CTRL_4_8723B		0x0078
-#define REG_HMEBOX_DBG_0_8723B	0x0088
-#define REG_HMEBOX_DBG_1_8723B	0x008A
-#define REG_HMEBOX_DBG_2_8723B	0x008C
-#define REG_HMEBOX_DBG_3_8723B	0x008E
-#define REG_HIMR0_8723B					0x00B0
-#define REG_HISR0_8723B					0x00B4
-#define REG_HIMR1_8723B					0x00B8
-#define REG_HISR1_8723B					0x00BC
-#define REG_PMC_DBG_CTRL2_8723B			0x00CC
-
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-#define REG_C2HEVT_CMD_ID_8723B	0x01A0
-#define REG_C2HEVT_CMD_LEN_8723B	0x01AE
-#define REG_WOWLAN_WAKE_REASON 0x01C7
-#define REG_WOWLAN_GTK_DBG1	0x630
-#define REG_WOWLAN_GTK_DBG2	0x634
-
-#define REG_HMEBOX_EXT0_8723B			0x01F0
-#define REG_HMEBOX_EXT1_8723B			0x01F4
-#define REG_HMEBOX_EXT2_8723B			0x01F8
-#define REG_HMEBOX_EXT3_8723B			0x01FC
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_RXDMA_CONTROL_8723B		0x0286 // Control the RX DMA.
-#define REG_RXDMA_MODE_CTRL_8723B		0x0290
-
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
-#define	REG_PCIE_CTRL_REG_8723B		0x0300
-#define	REG_INT_MIG_8723B				0x0304	// Interrupt Migration 
-#define	REG_BCNQ_DESA_8723B			0x0308	// TX Beacon Descriptor Address
-#define	REG_HQ_DESA_8723B				0x0310	// TX High Queue Descriptor Address
-#define	REG_MGQ_DESA_8723B			0x0318	// TX Manage Queue Descriptor Address
-#define	REG_VOQ_DESA_8723B			0x0320	// TX VO Queue Descriptor Address
-#define	REG_VIQ_DESA_8723B				0x0328	// TX VI Queue Descriptor Address
-#define	REG_BEQ_DESA_8723B			0x0330	// TX BE Queue Descriptor Address
-#define	REG_BKQ_DESA_8723B			0x0338	// TX BK Queue Descriptor Address
-#define	REG_RX_DESA_8723B				0x0340	// RX Queue	Descriptor Address
-#define	REG_DBI_WDATA_8723B			0x0348	// DBI Write Data
-#define	REG_DBI_RDATA_8723B			0x034C	// DBI Read Data
-#define	REG_DBI_ADDR_8723B				0x0350	// DBI Address
-#define	REG_DBI_FLAG_8723B				0x0352	// DBI Read/Write Flag
-#define	REG_MDIO_WDATA_8723B		0x0354	// MDIO for Write PCIE PHY
-#define	REG_MDIO_RDATA_8723B			0x0356	// MDIO for Reads PCIE PHY
-#define	REG_MDIO_CTL_8723B			0x0358	// MDIO for Control
-#define	REG_DBG_SEL_8723B				0x0360	// Debug Selection Register
-#define	REG_PCIE_HRPWM_8723B			0x0361	//PCIe RPWM
-#define	REG_PCIE_HCPWM_8723B			0x0363	//PCIe CPWM
-#define	REG_PCIE_MULTIFET_CTRL_8723B	0x036A	//PCIE Multi-Fethc Control
-
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-#define REG_TXPKTBUF_BCNQ_BDNY_8723B	0x0424
-#define REG_TXPKTBUF_MGQ_BDNY_8723B	0x0425
-#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8723B	0x045D
-#ifdef CONFIG_WOWLAN
-#define REG_TXPKTBUF_IV_LOW             0x0484
-#define REG_TXPKTBUF_IV_HIGH            0x0488
-#endif
-#define REG_AMPDU_BURST_MODE_8723B	0x04BC
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-#define REG_SECONDARY_CCA_CTRL_8723B	0x0577
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-
-
-//============================================================
-// SDIO Bus Specification
-//============================================================
-
-//-----------------------------------------------------
-// SDIO CMD Address Mapping
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-// I/O bus domain (Host)
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-// SDIO register
-//-----------------------------------------------------
-#define SDIO_REG_HCPWM1_8723B	0x025 // HCI Current Power Mode 1
-
-
-//============================================================================
-//	8723 Regsiter Bit and Content definition
-//============================================================================
-
-//2 HSISR
-// 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)
-
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-#undef IS_E_CUT
-#define IS_E_CUT(version)		FALSE
-#undef IS_F_CUT
-#define IS_F_CUT(version)		((GET_CVID_CUT_VERSION(version) == E_CUT_VERSION) ? TRUE : FALSE)
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-#define BIT_USB_RXDMA_AGG_EN	BIT(31)
-#define RXDMA_AGG_MODE_EN		BIT(1)
-
-#ifdef CONFIG_WOWLAN
-#define RXPKT_RELEASE_POLL		BIT(16)
-#define RXDMA_IDLE				BIT(17)
-#define RW_RELEASE_EN			BIT(18)
-#endif
-
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-
-//----------------------------------------------------------------------------
-//       8723B REG_CCK_CHECK						(offset 0x454)
-//----------------------------------------------------------------------------
-#define BIT_BCN_PORT_SEL		BIT5
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-#ifdef CONFIG_RF_GAIN_OFFSET
-
-#ifdef CONFIG_RTL8723B
-#define EEPROM_RF_GAIN_OFFSET			0xC1
-#endif
-
-#define EEPROM_RF_GAIN_VAL				0x1F6
-#endif //CONFIG_RF_GAIN_OFFSET
-
-
-//----------------------------------------------------------------------------
-//       8195 IMR/ISR bits						(offset 0xB0,  8bits)
-//----------------------------------------------------------------------------
-#define	IMR_DISABLED_8723B					0
-// IMR DW0(0x00B0-00B3) Bit 0-31
-#define	IMR_TIMER2_8723B					BIT31		// Timeout interrupt 2
-#define	IMR_TIMER1_8723B					BIT30		// Timeout interrupt 1	
-#define	IMR_PSTIMEOUT_8723B				BIT29		// Power Save Time Out Interrupt
-#define	IMR_GTINT4_8723B					BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define	IMR_GTINT3_8723B					BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define	IMR_TXBCN0ERR_8723B				BIT26		// Transmit Beacon0 Error			
-#define	IMR_TXBCN0OK_8723B				BIT25		// Transmit Beacon0 OK			
-#define	IMR_TSF_BIT32_TOGGLE_8723B		BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define	IMR_BCNDMAINT0_8723B				BIT20		// Beacon DMA Interrupt 0			
-#define	IMR_BCNDERR0_8723B				BIT16		// Beacon Queue DMA OK0			
-#define	IMR_HSISR_IND_ON_INT_8723B		BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)
-#define	IMR_BCNDMAINT_E_8723B			BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define	IMR_ATIMEND_8723B				BIT12		// CTWidnow End or ATIM Window End
-#define	IMR_C2HCMD_8723B					BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define	IMR_CPWM2_8723B					BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_CPWM_8723B					BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_HIGHDOK_8723B				BIT7			// High Queue DMA OK	
-#define	IMR_MGNTDOK_8723B				BIT6			// Management Queue DMA OK	
-#define	IMR_BKDOK_8723B					BIT5			// AC_BK DMA OK		
-#define	IMR_BEDOK_8723B					BIT4			// AC_BE DMA OK	
-#define	IMR_VIDOK_8723B					BIT3			// AC_VI DMA OK		
-#define	IMR_VODOK_8723B					BIT2			// AC_VO DMA OK	
-#define	IMR_RDU_8723B					BIT1			// Rx Descriptor Unavailable	
-#define	IMR_ROK_8723B					BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define	IMR_BCNDMAINT7_8723B				BIT27		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT6_8723B				BIT26		// Beacon DMA Interrupt 6
-#define	IMR_BCNDMAINT5_8723B				BIT25		// Beacon DMA Interrupt 5
-#define	IMR_BCNDMAINT4_8723B				BIT24		// Beacon DMA Interrupt 4
-#define	IMR_BCNDMAINT3_8723B				BIT23		// Beacon DMA Interrupt 3
-#define	IMR_BCNDMAINT2_8723B				BIT22		// Beacon DMA Interrupt 2
-#define	IMR_BCNDMAINT1_8723B				BIT21		// Beacon DMA Interrupt 1
-#define	IMR_BCNDOK7_8723B					BIT20		// Beacon Queue DMA OK Interrup 7
-#define	IMR_BCNDOK6_8723B					BIT19		// Beacon Queue DMA OK Interrup 6
-#define	IMR_BCNDOK5_8723B					BIT18		// Beacon Queue DMA OK Interrup 5
-#define	IMR_BCNDOK4_8723B					BIT17		// Beacon Queue DMA OK Interrup 4
-#define	IMR_BCNDOK3_8723B					BIT16		// Beacon Queue DMA OK Interrup 3
-#define	IMR_BCNDOK2_8723B					BIT15		// Beacon Queue DMA OK Interrup 2
-#define	IMR_BCNDOK1_8723B					BIT14		// Beacon Queue DMA OK Interrup 1
-#define	IMR_ATIMEND_E_8723B				BIT13		// ATIM Window End Extension for Win7
-#define	IMR_TXERR_8723B					BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define	IMR_RXERR_8723B					BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define	IMR_TXFOVW_8723B					BIT9			// Transmit FIFO Overflow
-#define	IMR_RXFOVW_8723B					BIT8			// Receive FIFO Overflow
-
-#ifdef CONFIG_PCI_HCI
-//#define IMR_RX_MASK		(IMR_ROK_8723B|IMR_RDU_8723B|IMR_RXFOVW_8723B)
-#define IMR_TX_MASK			(IMR_VODOK_8723B|IMR_VIDOK_8723B|IMR_BEDOK_8723B|IMR_BKDOK_8723B|IMR_MGNTDOK_8723B|IMR_HIGHDOK_8723B)
-
-#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8723B | IMR_TXBCN0OK_8723B | IMR_TXBCN0ERR_8723B | IMR_BCNDERR0_8723B)
-
-#define RT_AC_INT_MASKS	(IMR_VIDOK_8723B | IMR_VODOK_8723B | IMR_BEDOK_8723B|IMR_BKDOK_8723B)
-#endif
-
-//========================================================
-// General definitions
-//========================================================
-
-#define MACID_NUM_8723B 128
-#define SEC_CAM_ENT_NUM_8723B 64
-#define NSS_NUM_8723B 1
-#define BAND_CAP_8723B (BAND_CAP_2G)
-#define BW_CAP_8723B (BW_CAP_20M | BW_CAP_40M)
-#define PROTO_CAP_8723B (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N)
-
-#endif /* __RTL8723B_SPEC_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_SPEC_H__
+#define __RTL8723B_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8723B		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RSV_CTRL_8723B				0x001C	/* 3 Byte */
+#define REG_BT_WIFI_ANTENNA_SWITCH_8723B	0x0038
+#define REG_HSISR_8723B					0x005c
+#define REG_PAD_CTRL1_8723B		0x0064
+#define REG_AFE_CTRL_4_8723B		0x0078
+#define REG_HMEBOX_DBG_0_8723B	0x0088
+#define REG_HMEBOX_DBG_1_8723B	0x008A
+#define REG_HMEBOX_DBG_2_8723B	0x008C
+#define REG_HMEBOX_DBG_3_8723B	0x008E
+#define REG_HIMR0_8723B					0x00B0
+#define REG_HISR0_8723B					0x00B4
+#define REG_HIMR1_8723B					0x00B8
+#define REG_HISR1_8723B					0x00BC
+#define REG_PMC_DBG_CTRL2_8723B			0x00CC
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8723B	0x01A0
+#define REG_C2HEVT_CMD_LEN_8723B	0x01AE
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_HMEBOX_EXT0_8723B			0x01F0
+#define REG_HMEBOX_EXT1_8723B			0x01F4
+#define REG_HMEBOX_EXT2_8723B			0x01F8
+#define REG_HMEBOX_EXT3_8723B			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_CONTROL_8723B		0x0286 /* Control the RX DMA. */
+#define REG_RXDMA_MODE_CTRL_8723B		0x0290
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8723B		0x0300
+#define	REG_INT_MIG_8723B				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_DESA_8723B			0x0308	/* TX Beacon Descriptor Address */
+#define	REG_HQ_DESA_8723B				0x0310	/* TX High Queue Descriptor Address */
+#define	REG_MGQ_DESA_8723B			0x0318	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_DESA_8723B			0x0320	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_DESA_8723B				0x0328	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_DESA_8723B			0x0330	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_DESA_8723B			0x0338	/* TX BK Queue Descriptor Address */
+#define	REG_RX_DESA_8723B				0x0340	/* RX Queue	Descriptor Address */
+#define	REG_DBI_WDATA_8723B			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8723B			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8723B				0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8723B				0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8723B		0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8723B			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8723B			0x0358	/* MDIO for Control */
+#define	REG_DBG_SEL_8723B				0x0360	/* Debug Selection Register */
+#define	REG_PCIE_HRPWM_8723B			0x0361	/* PCIe RPWM */
+#define	REG_PCIE_HCPWM_8723B			0x0363	/* PCIe CPWM */
+#define	REG_PCIE_MULTIFET_CTRL_8723B	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_TXPKTBUF_BCNQ_BDNY_8723B	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8723B	0x0425
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8723B	0x045D
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_AMPDU_BURST_MODE_8723B	0x04BC
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SECONDARY_CCA_CTRL_8723B	0x0577
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HCPWM1_8723B	0x025 /* HCI Current Power Mode 1 */
+
+
+/* ****************************************************************************
+ *	8723 Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+/* 2 HSISR
+ * 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)
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#undef IS_E_CUT
+#define IS_E_CUT(version)		FALSE
+#undef IS_F_CUT
+#define IS_F_CUT(version)		((GET_CVID_CUT_VERSION(version) == E_CUT_VERSION) ? TRUE : FALSE)
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* ----------------------------------------------------------------------------
+ * 8723B REG_CCK_CHECK						(offset 0x454)
+ * ---------------------------------------------------------------------------- */
+#define BIT_BCN_PORT_SEL		BIT(5)
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#ifdef CONFIG_RF_POWER_TRIM
+
+	#ifdef CONFIG_RTL8723B
+		#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#endif
+
+	#define EEPROM_RF_GAIN_VAL				0x1F6
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8723B					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8723B					BIT(31)		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8723B					BIT(30)		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8723B				BIT(29)		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8723B					BIT(28)		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8723B					BIT(27)		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8723B				BIT(26)		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8723B				BIT(25)		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8723B		BIT(24)		/* TSF Timer BIT(32) toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8723B				BIT(20)		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8723B				BIT(16)		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8723B		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8723B			BIT(14)		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8723B				BIT(12)		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8723B					BIT(10)		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8723B					BIT(9)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8723B					BIT(8)			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8723B				BIT(7)			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8723B				BIT(6)			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8723B					BIT(5)			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8723B					BIT(4)			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8723B					BIT(3)			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8723B					BIT(2)			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8723B					BIT(1)			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8723B					BIT(0)			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8723B				BIT(27)		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8723B				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8723B				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8723B				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8723B				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8723B				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8723B				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8723B					BIT(20)		/* Beacon Queue DMA OK Interrupt 7 */
+#define	IMR_BCNDOK6_8723B					BIT(19)		/* Beacon Queue DMA OK Interrupt 6 */
+#define	IMR_BCNDOK5_8723B					BIT(18)		/* Beacon Queue DMA OK Interrupt 5 */
+#define	IMR_BCNDOK4_8723B					BIT(17)		/* Beacon Queue DMA OK Interrupt 4 */
+#define	IMR_BCNDOK3_8723B					BIT(16)		/* Beacon Queue DMA OK Interrupt 3 */
+#define	IMR_BCNDOK2_8723B					BIT(15)		/* Beacon Queue DMA OK Interrupt 2 */
+#define	IMR_BCNDOK1_8723B					BIT(14)		/* Beacon Queue DMA OK Interrupt 1 */
+#define	IMR_ATIMEND_E_8723B				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8723B					BIT(11)		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8723B					BIT(10)		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8723B					BIT(9)			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8723B					BIT(8)			/* Receive FIFO Overflow */
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_8723B|IMR_RDU_8723B|IMR_RXFOVW_8723B) */
+	#define IMR_TX_MASK			(IMR_VODOK_8723B | IMR_VIDOK_8723B | IMR_BEDOK_8723B | IMR_BKDOK_8723B | IMR_MGNTDOK_8723B | IMR_HIGHDOK_8723B)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8723B | IMR_TXBCN0OK_8723B | IMR_TXBCN0ERR_8723B | IMR_BCNDERR0_8723B)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8723B | IMR_VODOK_8723B | IMR_BEDOK_8723B | IMR_BKDOK_8723B)
+#endif
+
+#endif /* __RTL8723B_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_sreset.h
index 9ade2dc7567a..5bae23bc608c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_sreset.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,20 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL8723B_SRESET_H_
 #define _RTL8723B_SRESET_H_
 
 #include <rtw_sreset.h>
 
 #ifdef DBG_CONFIG_ERROR_DETECT
-extern void rtl8723b_sreset_xmit_status_check(_adapter *padapter);
-extern void rtl8723b_sreset_linked_status_check(_adapter *padapter);
+	extern void rtl8723b_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8723b_sreset_linked_status_check(_adapter *padapter);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_xmit.h
index b998233610e2..cafa1acdec41 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723b_xmit.h
@@ -1,336 +1,335 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8723B_XMIT_H__
-#define __RTL8723B_XMIT_H__
-
-
-#define MAX_TID (15)
-
-
-#ifndef __INC_HAL8723BDESC_H
-#define __INC_HAL8723BDESC_H
-
-#define RX_STATUS_DESC_SIZE_8723B		24
-#define RX_DRV_INFO_SIZE_UNIT_8723B 8
-
-
-//DWORD 0
-#define SET_RX_STATUS_DESC_PKT_LEN_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_STATUS_DESC_EOR_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 30, 1, __Value)
-#define SET_RX_STATUS_DESC_OWN_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 31, 1, __Value)
-
-#define GET_RX_STATUS_DESC_PKT_LEN_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 0, 14)
-#define GET_RX_STATUS_DESC_CRC32_8723B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 14, 1)
-#define GET_RX_STATUS_DESC_ICV_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 15, 1)
-#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 4)
-#define GET_RX_STATUS_DESC_SECURITY_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 20, 3)
-#define GET_RX_STATUS_DESC_QOS_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 23, 1)
-#define GET_RX_STATUS_DESC_SHIFT_8723B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 24, 2)
-#define GET_RX_STATUS_DESC_PHY_STATUS_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 26, 1)
-#define GET_RX_STATUS_DESC_SWDEC_8723B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 27, 1)
-#define GET_RX_STATUS_DESC_LAST_SEG_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 28, 1)
-#define GET_RX_STATUS_DESC_FIRST_SEG_8723B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc, 29, 1)
-#define GET_RX_STATUS_DESC_EOR_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 30, 1)
-#define GET_RX_STATUS_DESC_OWN_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 31, 1)
-
-//DWORD 1
-#define GET_RX_STATUS_DESC_MACID_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
-#define GET_RX_STATUS_DESC_TID_8723B(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
-#define GET_RX_STATUS_DESC_AMSDU_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
-#define GET_RX_STATUS_DESC_RXID_MATCH_8723B(__pRxDesc)		LE_BITS_TO_4BYTE( __pRxDesc+4, 14, 1)
-#define GET_RX_STATUS_DESC_PAGGR_8723B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 15, 1)
-#define GET_RX_STATUS_DESC_A1_FIT_8723B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 16, 4)
-#define GET_RX_STATUS_DESC_CHKERR_8723B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 20, 1)
-#define GET_RX_STATUS_DESC_IPVER_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
-#define GET_RX_STATUS_DESC_IS_TCPUDP__8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
-#define GET_RX_STATUS_DESC_CHK_VLD_8723B(__pRxDesc) 	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
-#define GET_RX_STATUS_DESC_PAM_8723B(__pRxDesc) 			LE_BITS_TO_4BYTE( __pRxDesc+4, 24, 1)
-#define GET_RX_STATUS_DESC_PWR_8723B(__pRxDesc) 			LE_BITS_TO_4BYTE( __pRxDesc+4, 25, 1)
-#define GET_RX_STATUS_DESC_MORE_DATA_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 26, 1)
-#define GET_RX_STATUS_DESC_MORE_FRAG_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 27, 1)
-#define GET_RX_STATUS_DESC_TYPE_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 28, 2)
-#define GET_RX_STATUS_DESC_MC_8723B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 30, 1)
-#define GET_RX_STATUS_DESC_BC_8723B(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 31, 1)
-
-//DWORD 2
-#define GET_RX_STATUS_DESC_SEQ_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 0, 12)
-#define GET_RX_STATUS_DESC_FRAG_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 12, 4)
-#define GET_RX_STATUS_DESC_RX_IS_QOS_8723B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 16, 1)
-#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8723B(__pRxStatusDesc) 	LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 18, 6)
-#define GET_RX_STATUS_DESC_RPT_SEL_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 28, 1)
-
-//DWORD 3
-#define GET_RX_STATUS_DESC_RX_RATE_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 0, 7)
-#define GET_RX_STATUS_DESC_HTC_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 10, 1)
-#define GET_RX_STATUS_DESC_EOSP_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 11, 1)
-#define GET_RX_STATUS_DESC_BSSID_FIT_8723B(__pRxStatusDesc) 		LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 12, 2)
-#ifdef CONFIG_USB_RX_AGGREGATION
-#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8723B(__pRxStatusDesc)	LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 16, 8)
-#endif
-#define GET_RX_STATUS_DESC_PATTERN_MATCH_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 29, 1)
-#define GET_RX_STATUS_DESC_UNICAST_MATCH_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 30, 1)
-#define GET_RX_STATUS_DESC_MAGIC_MATCH_8723B(__pRxDesc) 		LE_BITS_TO_4BYTE( __pRxDesc+12, 31, 1)
-
-//DWORD 6
-#define GET_RX_STATUS_DESC_SPLCP_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 0, 1)
-#define GET_RX_STATUS_DESC_LDPC_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 1, 1)
-#define GET_RX_STATUS_DESC_STBC_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 2, 1)
-#define GET_RX_STATUS_DESC_BW_8723B(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 4, 2)
-
-//DWORD 5
-#define GET_RX_STATUS_DESC_TSFL_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+20, 0, 32)
-
-#define GET_RX_STATUS_DESC_BUFF_ADDR_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
-#define GET_RX_STATUS_DESC_BUFF_ADDR64_8723B(__pRxDesc) 		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
-
-#define SET_RX_STATUS_DESC_BUFF_ADDR_8723B(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
-
-
-// Dword 0
-#define GET_TX_DESC_OWN_8723B(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
-
-#define SET_TX_DESC_PKT_SIZE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
-#define SET_TX_DESC_OFFSET_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
-#define SET_TX_DESC_BMC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
-#define SET_TX_DESC_HTC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
-#define SET_TX_DESC_LAST_SEG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
-#define SET_TX_DESC_FIRST_SEG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
-#define SET_TX_DESC_LINIP_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
-#define SET_TX_DESC_NO_ACM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
-#define SET_TX_DESC_GF_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
-#define SET_TX_DESC_OWN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
-
-// Dword 1
-#define SET_TX_DESC_MACID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
-#define SET_TX_DESC_QUEUE_SEL_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
-#define SET_TX_DESC_RDG_NAV_EXT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
-#define SET_TX_DESC_LSIG_TXOP_EN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
-#define SET_TX_DESC_PIFS_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
-#define SET_TX_DESC_RATE_ID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
-#define SET_TX_DESC_EN_DESC_ID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
-#define SET_TX_DESC_SEC_TYPE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
-#define SET_TX_DESC_PKT_OFFSET_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
-
-
-// Dword 2
-#define SET_TX_DESC_PAID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value) 
-#define SET_TX_DESC_CCA_RTS_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
-#define SET_TX_DESC_AGG_ENABLE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
-#define SET_TX_DESC_RDG_ENABLE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
-#define SET_TX_DESC_AGG_BREAK_8723B(__pTxDesc, __Value) 				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
-#define SET_TX_DESC_MORE_FRAG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
-#define SET_TX_DESC_RAW_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
-#define SET_TX_DESC_SPE_RPT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
-#define SET_TX_DESC_AMPDU_DENSITY_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
-#define SET_TX_DESC_BT_INT_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
-#define SET_TX_DESC_GID_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
-
-
-// Dword 3
-#define SET_TX_DESC_WHEADER_LEN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
-#define SET_TX_DESC_CHK_EN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
-#define SET_TX_DESC_EARLY_MODE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
-#define SET_TX_DESC_HWSEQ_SEL_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
-#define SET_TX_DESC_USE_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
-#define SET_TX_DESC_DISABLE_RTS_FB_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
-#define SET_TX_DESC_DISABLE_FB_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
-#define SET_TX_DESC_CTS2SELF_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
-#define SET_TX_DESC_RTS_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
-#define SET_TX_DESC_HW_RTS_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
-#define SET_TX_DESC_NAV_USE_HDR_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
-#define SET_TX_DESC_USE_MAX_LEN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
-#define SET_TX_DESC_MAX_AGG_NUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
-#define SET_TX_DESC_NDPA_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
-#define SET_TX_DESC_AMPDU_MAX_TIME_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
-
-// Dword 4
-#define SET_TX_DESC_TX_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
-#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
-#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
-#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
-#define SET_TX_DESC_DATA_RETRY_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
-#define SET_TX_DESC_RTS_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
-
-
-// Dword 5
-#define SET_TX_DESC_DATA_SC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
-#define SET_TX_DESC_DATA_SHORT_8723B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
-#define SET_TX_DESC_DATA_BW_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
-#define SET_TX_DESC_DATA_LDPC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
-#define SET_TX_DESC_DATA_STBC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
-#define SET_TX_DESC_CTROL_STBC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
-#define SET_TX_DESC_RTS_SHORT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
-#define SET_TX_DESC_RTS_SC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
-
-
-// Dword 6
-#define SET_TX_DESC_SW_DEFINE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
-#define SET_TX_DESC_MBSSID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
-#define SET_TX_DESC_ANTSEL_A_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
-#define SET_TX_DESC_ANTSEL_B_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
-#define SET_TX_DESC_ANTSEL_C_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
-#define SET_TX_DESC_ANTSEL_D_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
-
-// Dword 7
-#if(DEV_BUS_TYPE == RT_PCI_INTERFACE)
-#define SET_TX_DESC_TX_BUFFER_SIZE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
-#define SET_TX_DESC_TX_DESC_CHECKSUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#endif
-#define SET_TX_DESC_USB_TXAGG_NUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-#if(DEV_BUS_TYPE == RT_SDIO_INTERFACE)
-#define SET_TX_DESC_SDIO_TXSEQ_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
-#endif
-
-// Dword 8
-#define SET_TX_DESC_HWSEQ_EN_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
-
-// Dword 9
-#define SET_TX_DESC_SEQ_8723B(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
-
-// Dword 10
-#define SET_TX_DESC_TX_BUFFER_ADDRESS_8723B(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
-#define GET_TX_DESC_TX_BUFFER_ADDRESS_8723B(__pTxDesc) 	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
-
-// Dword 11
-#define SET_TX_DESC_NEXT_DESC_ADDRESS_8723B(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
-
-
-#define SET_EARLYMODE_PKTNUM_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
-#define SET_EARLYMODE_LEN0_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
-#define SET_EARLYMODE_LEN1_1_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
-#define SET_EARLYMODE_LEN1_2_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
-#define SET_EARLYMODE_LEN2_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
-#define SET_EARLYMODE_LEN3_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
-
-#endif
-//-----------------------------------------------------------
-//
-//	Rate
-//
-//-----------------------------------------------------------
-// CCK Rates, TxHT = 0
-#define DESC8723B_RATE1M				0x00
-#define DESC8723B_RATE2M				0x01
-#define DESC8723B_RATE5_5M				0x02
-#define DESC8723B_RATE11M				0x03
-
-// OFDM Rates, TxHT = 0
-#define DESC8723B_RATE6M				0x04
-#define DESC8723B_RATE9M				0x05
-#define DESC8723B_RATE12M				0x06
-#define DESC8723B_RATE18M				0x07
-#define DESC8723B_RATE24M				0x08
-#define DESC8723B_RATE36M				0x09
-#define DESC8723B_RATE48M				0x0a
-#define DESC8723B_RATE54M				0x0b
-
-// MCS Rates, TxHT = 1
-#define DESC8723B_RATEMCS0				0x0c
-#define DESC8723B_RATEMCS1				0x0d
-#define DESC8723B_RATEMCS2				0x0e
-#define DESC8723B_RATEMCS3				0x0f
-#define DESC8723B_RATEMCS4				0x10
-#define DESC8723B_RATEMCS5				0x11
-#define DESC8723B_RATEMCS6				0x12
-#define DESC8723B_RATEMCS7				0x13
-#define DESC8723B_RATEMCS8				0x14
-#define DESC8723B_RATEMCS9				0x15
-#define DESC8723B_RATEMCS10 		0x16
-#define DESC8723B_RATEMCS11 		0x17
-#define DESC8723B_RATEMCS12 		0x18
-#define DESC8723B_RATEMCS13 		0x19
-#define DESC8723B_RATEMCS14 		0x1a
-#define DESC8723B_RATEMCS15 		0x1b
-#define DESC8723B_RATEVHTSS1MCS0		0x2c
-#define DESC8723B_RATEVHTSS1MCS1		0x2d
-#define DESC8723B_RATEVHTSS1MCS2		0x2e
-#define DESC8723B_RATEVHTSS1MCS3		0x2f
-#define DESC8723B_RATEVHTSS1MCS4		0x30
-#define DESC8723B_RATEVHTSS1MCS5		0x31
-#define DESC8723B_RATEVHTSS1MCS6		0x32
-#define DESC8723B_RATEVHTSS1MCS7		0x33
-#define DESC8723B_RATEVHTSS1MCS8		0x34
-#define DESC8723B_RATEVHTSS1MCS9		0x35
-#define DESC8723B_RATEVHTSS2MCS0		0x36
-#define DESC8723B_RATEVHTSS2MCS1		0x37
-#define DESC8723B_RATEVHTSS2MCS2		0x38
-#define DESC8723B_RATEVHTSS2MCS3		0x39
-#define DESC8723B_RATEVHTSS2MCS4		0x3a
-#define DESC8723B_RATEVHTSS2MCS5		0x3b
-#define DESC8723B_RATEVHTSS2MCS6		0x3c
-#define DESC8723B_RATEVHTSS2MCS7		0x3d
-#define DESC8723B_RATEVHTSS2MCS8		0x3e
-#define DESC8723B_RATEVHTSS2MCS9		0x3f
-
-
-#define 	RX_HAL_IS_CCK_RATE_8723B(pDesc)\
-			(GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE1M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE2M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE5_5M ||\
-			GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE11M)
-
-
-void rtl8723b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
-void rtl8723b_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
-
-#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-s32 rtl8723bs_init_xmit_priv(PADAPTER padapter);
-void rtl8723bs_free_xmit_priv(PADAPTER padapter);
-s32 rtl8723bs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8723bs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8723bs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-s32 rtl8723bs_xmit_buf_handler(PADAPTER padapter);
-thread_return rtl8723bs_xmit_thread(thread_context context);
-#define hal_xmit_handler rtl8723bs_xmit_buf_handler
-#endif
-
-#ifdef CONFIG_USB_HCI
-s32 rtl8723bu_xmit_buf_handler(PADAPTER padapter);
-#define hal_xmit_handler rtl8723bu_xmit_buf_handler
-
-
-s32 rtl8723bu_init_xmit_priv(PADAPTER padapter);
-void rtl8723bu_free_xmit_priv(PADAPTER padapter);
-s32 rtl8723bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8723bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	 rtl8723bu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-//s32 rtl8812au_xmit_buf_handler(PADAPTER padapter);
-void rtl8723bu_xmit_tasklet(void *priv);
-s32 rtl8723bu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag,struct tx_desc *ptxdesc);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8723be_init_xmit_priv(PADAPTER padapter);
-void rtl8723be_free_xmit_priv(PADAPTER padapter);
-struct xmit_buf *rtl8723be_dequeue_xmitbuf(struct rtw_tx_ring *ring);
-void	rtl8723be_xmitframe_resume(_adapter *padapter);
-s32 rtl8723be_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8723be_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8723be_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-void rtl8723be_xmit_tasklet(void *priv);
-#endif
-
-u8	BWMapping_8723B(PADAPTER Adapter, struct pkt_attrib *pattrib);
-u8	SCMapping_8723B(PADAPTER Adapter, struct pkt_attrib	*pattrib);
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723B_XMIT_H__
+#define __RTL8723B_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8723BDESC_H
+	#define __INC_HAL8723BDESC_H
+
+	#define RX_STATUS_DESC_SIZE_8723B		24
+	#define RX_DRV_INFO_SIZE_UNIT_8723B 8
+
+
+	/* DWORD 0 */
+	#define SET_RX_STATUS_DESC_PKT_LEN_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+	#define SET_RX_STATUS_DESC_EOR_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+	#define SET_RX_STATUS_DESC_OWN_8723B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+	#define GET_RX_STATUS_DESC_PKT_LEN_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+	#define GET_RX_STATUS_DESC_CRC32_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+	#define GET_RX_STATUS_DESC_ICV_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+	#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+	#define GET_RX_STATUS_DESC_SECURITY_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+	#define GET_RX_STATUS_DESC_QOS_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+	#define GET_RX_STATUS_DESC_SHIFT_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+	#define GET_RX_STATUS_DESC_PHY_STATUS_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+	#define GET_RX_STATUS_DESC_SWDEC_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+	#define GET_RX_STATUS_DESC_LAST_SEG_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+	#define GET_RX_STATUS_DESC_FIRST_SEG_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+	#define GET_RX_STATUS_DESC_EOR_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+	#define GET_RX_STATUS_DESC_OWN_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+	/* DWORD 1 */
+	#define GET_RX_STATUS_DESC_MACID_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+	#define GET_RX_STATUS_DESC_TID_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+	#define GET_RX_STATUS_DESC_AMSDU_8723B(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+	#define GET_RX_STATUS_DESC_RXID_MATCH_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+	#define GET_RX_STATUS_DESC_PAGGR_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+	#define GET_RX_STATUS_DESC_A1_FIT_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+	#define GET_RX_STATUS_DESC_CHKERR_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+	#define GET_RX_STATUS_DESC_IPVER_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+	#define GET_RX_STATUS_DESC_IS_TCPUDP__8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+	#define GET_RX_STATUS_DESC_CHK_VLD_8723B(__pRxDesc)	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+	#define GET_RX_STATUS_DESC_PAM_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+	#define GET_RX_STATUS_DESC_PWR_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+	#define GET_RX_STATUS_DESC_MORE_DATA_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+	#define GET_RX_STATUS_DESC_MORE_FRAG_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+	#define GET_RX_STATUS_DESC_TYPE_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+	#define GET_RX_STATUS_DESC_MC_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+	#define GET_RX_STATUS_DESC_BC_8723B(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+	/* DWORD 2 */
+	#define GET_RX_STATUS_DESC_SEQ_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+	#define GET_RX_STATUS_DESC_FRAG_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+	#define GET_RX_STATUS_DESC_RX_IS_QOS_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+	#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8723B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+	#define GET_RX_STATUS_DESC_RPT_SEL_8723B(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+	/* DWORD 3 */
+	#define GET_RX_STATUS_DESC_RX_RATE_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+	#define GET_RX_STATUS_DESC_HTC_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+	#define GET_RX_STATUS_DESC_EOSP_8723B(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+	#define GET_RX_STATUS_DESC_BSSID_FIT_8723B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+	#ifdef CONFIG_USB_RX_AGGREGATION
+		#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8723B(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+	#endif
+	#define GET_RX_STATUS_DESC_PATTERN_MATCH_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+	#define GET_RX_STATUS_DESC_UNICAST_MATCH_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+	#define GET_RX_STATUS_DESC_MAGIC_MATCH_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+	/* DWORD 6 */
+	#define GET_RX_STATUS_DESC_SPLCP_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+	#define GET_RX_STATUS_DESC_LDPC_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+	#define GET_RX_STATUS_DESC_STBC_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+	#define GET_RX_STATUS_DESC_BW_8723B(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+	/* DWORD 5 */
+	#define GET_RX_STATUS_DESC_TSFL_8723B(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+	#define GET_RX_STATUS_DESC_BUFF_ADDR_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+	#define GET_RX_STATUS_DESC_BUFF_ADDR64_8723B(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+	#define SET_RX_STATUS_DESC_BUFF_ADDR_8723B(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+	/* Dword 0 */
+	#define GET_TX_DESC_OWN_8723B(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+	#define SET_TX_DESC_PKT_SIZE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+	#define SET_TX_DESC_OFFSET_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+	#define SET_TX_DESC_BMC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+	#define SET_TX_DESC_HTC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+	#define SET_TX_DESC_LAST_SEG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+	#define SET_TX_DESC_FIRST_SEG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+	#define SET_TX_DESC_LINIP_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+	#define SET_TX_DESC_NO_ACM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+	#define SET_TX_DESC_GF_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+	#define SET_TX_DESC_OWN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+	/* Dword 1 */
+	#define SET_TX_DESC_MACID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+	#define SET_TX_DESC_QUEUE_SEL_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+	#define SET_TX_DESC_RDG_NAV_EXT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+	#define SET_TX_DESC_LSIG_TXOP_EN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+	#define SET_TX_DESC_PIFS_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+	#define SET_TX_DESC_RATE_ID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+	#define SET_TX_DESC_EN_DESC_ID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+	#define SET_TX_DESC_SEC_TYPE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+	#define SET_TX_DESC_PKT_OFFSET_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+
+
+	/* Dword 2 */
+	#define SET_TX_DESC_PAID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+	#define SET_TX_DESC_CCA_RTS_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+	#define SET_TX_DESC_AGG_ENABLE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+	#define SET_TX_DESC_RDG_ENABLE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+	#define SET_TX_DESC_AGG_BREAK_8723B(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+	#define SET_TX_DESC_MORE_FRAG_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+	#define SET_TX_DESC_RAW_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+	#define SET_TX_DESC_SPE_RPT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+	#define SET_TX_DESC_AMPDU_DENSITY_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+	#define SET_TX_DESC_BT_INT_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+	#define SET_TX_DESC_GID_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+
+	/* Dword 3 */
+	#define SET_TX_DESC_WHEADER_LEN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+	#define SET_TX_DESC_CHK_EN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+	#define SET_TX_DESC_EARLY_MODE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+	#define SET_TX_DESC_HWSEQ_SEL_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+	#define SET_TX_DESC_USE_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+	#define SET_TX_DESC_DISABLE_RTS_FB_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+	#define SET_TX_DESC_DISABLE_FB_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+	#define SET_TX_DESC_CTS2SELF_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+	#define SET_TX_DESC_RTS_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+	#define SET_TX_DESC_HW_RTS_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+	#define SET_TX_DESC_NAV_USE_HDR_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+	#define SET_TX_DESC_USE_MAX_LEN_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+	#define SET_TX_DESC_MAX_AGG_NUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+	#define SET_TX_DESC_NDPA_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+	#define SET_TX_DESC_AMPDU_MAX_TIME_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+	/* Dword 4 */
+	#define SET_TX_DESC_TX_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+	#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+	#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+	#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+	#define SET_TX_DESC_DATA_RETRY_LIMIT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+	#define SET_TX_DESC_RTS_RATE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+
+
+	/* Dword 5 */
+	#define SET_TX_DESC_DATA_SC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+	#define SET_TX_DESC_DATA_SHORT_8723B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+	#define SET_TX_DESC_DATA_BW_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+	#define SET_TX_DESC_DATA_LDPC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+	#define SET_TX_DESC_DATA_STBC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+	#define SET_TX_DESC_CTROL_STBC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+	#define SET_TX_DESC_RTS_SHORT_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+	#define SET_TX_DESC_RTS_SC_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+
+
+	/* Dword 6 */
+	#define SET_TX_DESC_SW_DEFINE_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+	#define SET_TX_DESC_MBSSID_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+	#define SET_TX_DESC_ANTSEL_A_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_B_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_C_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+	#define SET_TX_DESC_ANTSEL_D_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+
+	/* Dword 7 */
+	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+		#define SET_TX_DESC_TX_BUFFER_SIZE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#else
+		#define SET_TX_DESC_TX_DESC_CHECKSUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+	#endif
+	#define SET_TX_DESC_USB_TXAGG_NUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+	#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+		#define SET_TX_DESC_SDIO_TXSEQ_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+	#endif
+
+	/* Dword 8 */
+	#define SET_TX_DESC_HWSEQ_EN_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+
+	/* Dword 9 */
+	#define SET_TX_DESC_SEQ_8723B(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+
+	/* Dword 10 */
+	#define SET_TX_DESC_TX_BUFFER_ADDRESS_8723B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+	#define GET_TX_DESC_TX_BUFFER_ADDRESS_8723B(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+
+	/* Dword 11 */
+	#define SET_TX_DESC_NEXT_DESC_ADDRESS_8723B(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+
+
+	#define SET_EARLYMODE_PKTNUM_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+	#define SET_EARLYMODE_LEN0_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+	#define SET_EARLYMODE_LEN1_1_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+	#define SET_EARLYMODE_LEN1_2_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+	#define SET_EARLYMODE_LEN2_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+	#define SET_EARLYMODE_LEN3_8723B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8723B_RATE1M				0x00
+#define DESC8723B_RATE2M				0x01
+#define DESC8723B_RATE5_5M				0x02
+#define DESC8723B_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8723B_RATE6M				0x04
+#define DESC8723B_RATE9M				0x05
+#define DESC8723B_RATE12M				0x06
+#define DESC8723B_RATE18M				0x07
+#define DESC8723B_RATE24M				0x08
+#define DESC8723B_RATE36M				0x09
+#define DESC8723B_RATE48M				0x0a
+#define DESC8723B_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8723B_RATEMCS0				0x0c
+#define DESC8723B_RATEMCS1				0x0d
+#define DESC8723B_RATEMCS2				0x0e
+#define DESC8723B_RATEMCS3				0x0f
+#define DESC8723B_RATEMCS4				0x10
+#define DESC8723B_RATEMCS5				0x11
+#define DESC8723B_RATEMCS6				0x12
+#define DESC8723B_RATEMCS7				0x13
+#define DESC8723B_RATEMCS8				0x14
+#define DESC8723B_RATEMCS9				0x15
+#define DESC8723B_RATEMCS10		0x16
+#define DESC8723B_RATEMCS11		0x17
+#define DESC8723B_RATEMCS12		0x18
+#define DESC8723B_RATEMCS13		0x19
+#define DESC8723B_RATEMCS14		0x1a
+#define DESC8723B_RATEMCS15		0x1b
+#define DESC8723B_RATEVHTSS1MCS0		0x2c
+#define DESC8723B_RATEVHTSS1MCS1		0x2d
+#define DESC8723B_RATEVHTSS1MCS2		0x2e
+#define DESC8723B_RATEVHTSS1MCS3		0x2f
+#define DESC8723B_RATEVHTSS1MCS4		0x30
+#define DESC8723B_RATEVHTSS1MCS5		0x31
+#define DESC8723B_RATEVHTSS1MCS6		0x32
+#define DESC8723B_RATEVHTSS1MCS7		0x33
+#define DESC8723B_RATEVHTSS1MCS8		0x34
+#define DESC8723B_RATEVHTSS1MCS9		0x35
+#define DESC8723B_RATEVHTSS2MCS0		0x36
+#define DESC8723B_RATEVHTSS2MCS1		0x37
+#define DESC8723B_RATEVHTSS2MCS2		0x38
+#define DESC8723B_RATEVHTSS2MCS3		0x39
+#define DESC8723B_RATEVHTSS2MCS4		0x3a
+#define DESC8723B_RATEVHTSS2MCS5		0x3b
+#define DESC8723B_RATEVHTSS2MCS6		0x3c
+#define DESC8723B_RATEVHTSS2MCS7		0x3d
+#define DESC8723B_RATEVHTSS2MCS8		0x3e
+#define DESC8723B_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8723B(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723B(pDesc) == DESC8723B_RATE11M)
+
+
+void rtl8723b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8723b_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723bs_init_xmit_priv(PADAPTER padapter);
+	void rtl8723bs_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723bs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723bs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723bs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723bs_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8723bs_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8723bs_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8723bu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8723bu_xmit_buf_handler
+
+
+	s32 rtl8723bu_init_xmit_priv(PADAPTER padapter);
+	void rtl8723bu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8723bu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	/* s32 rtl8812au_xmit_buf_handler(PADAPTER padapter); */
+	void rtl8723bu_xmit_tasklet(void *priv);
+	s32 rtl8723bu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723be_init_xmit_priv(PADAPTER padapter);
+	void rtl8723be_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8723be_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void	rtl8723be_xmitframe_resume(_adapter *padapter);
+	s32 rtl8723be_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723be_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723be_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8723be_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8723B(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8723B(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_cmd.h
new file mode 100644
index 000000000000..07b2dce28522
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_cmd.h
@@ -0,0 +1,191 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_CMD_H__
+#define __RTL8723D_CMD_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+enum h2c_cmd_8723D {
+	/* Common Class: 000 */
+	H2C_8723D_RSVD_PAGE = 0x00,
+	H2C_8723D_MEDIA_STATUS_RPT = 0x01,
+	H2C_8723D_SCAN_ENABLE = 0x02,
+	H2C_8723D_KEEP_ALIVE = 0x03,
+	H2C_8723D_DISCON_DECISION = 0x04,
+	H2C_8723D_PSD_OFFLOAD = 0x05,
+	H2C_8723D_AP_OFFLOAD = 0x08,
+	H2C_8723D_BCN_RSVDPAGE = 0x09,
+	H2C_8723D_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8723D_FCS_RSVDPAGE = 0x10,
+	H2C_8723D_FCS_INFO = 0x11,
+	H2C_8723D_AP_WOW_GPIO_CTRL = 0x13,
+
+	/* PoweSave Class: 001 */
+	H2C_8723D_SET_PWR_MODE = 0x20,
+	H2C_8723D_PS_TUNING_PARA = 0x21,
+	H2C_8723D_PS_TUNING_PARA2 = 0x22,
+	H2C_8723D_P2P_LPS_PARAM = 0x23,
+	H2C_8723D_P2P_PS_OFFLOAD = 0x24,
+	H2C_8723D_PS_SCAN_ENABLE = 0x25,
+	H2C_8723D_SAP_PS_ = 0x26,
+	H2C_8723D_INACTIVE_PS_ = 0x27, /* Inactive_PS */
+	H2C_8723D_FWLPS_IN_IPS_ = 0x28,
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8723D_MACID_CFG = 0x40,
+	H2C_8723D_TXBF = 0x41,
+	H2C_8723D_RSSI_SETTING = 0x42,
+	H2C_8723D_AP_REQ_TXRPT = 0x43,
+	H2C_8723D_INIT_RATE_COLLECT = 0x44,
+	H2C_8723D_RA_PARA_ADJUST = 0x46,
+
+	/* BT Class: 011 */
+	H2C_8723D_B_TYPE_TDMA = 0x60,
+	H2C_8723D_BT_INFO = 0x61,
+	H2C_8723D_FORCE_BT_TXPWR = 0x62,
+	H2C_8723D_BT_IGNORE_WLANACT = 0x63,
+	H2C_8723D_DAC_SWING_VALUE = 0x64,
+	H2C_8723D_ANT_SEL_RSV = 0x65,
+	H2C_8723D_WL_OPMODE = 0x66,
+	H2C_8723D_BT_MP_OPER = 0x67,
+	H2C_8723D_BT_CONTROL = 0x68,
+	H2C_8723D_BT_WIFI_CTRL = 0x69,
+	H2C_8723D_BT_FW_PATCH = 0x6A,
+	H2C_8723D_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
+	H2C_8723D_WOWLAN = 0x80,
+	H2C_8723D_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8723D_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8723D_AOAC_RSVD_PAGE = 0x83,
+	H2C_8723D_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_8723D_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_8723D_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_8723D_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_8723D_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
+	H2C_8723D_P2P_OFFLOAD = 0x8B,
+
+	H2C_8723D_RESET_TSF = 0xC0,
+	H2C_8723D_MAXID,
+};
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _PWR_MOD_CMD_0x20 */
+#define SET_8723D_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+#define GET_8723D_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _PS_TUNE_PARAM_CMD_0x21 */
+#define SET_8723D_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
+#define SET_8723D_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _MACID_CFG_CMD_0x40 */
+#define SET_8723D_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
+#define SET_8723D_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
+
+/* _RSSI_SETTING_CMD_0x42 */
+#define SET_8723D_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
+#define SET_8723D_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _AP_REQ_TXRPT_CMD_0x43 */
+#define SET_8723D_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8723D_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _FORCE_BT_TXPWR_CMD_0x62 */
+#define SET_8723D_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
+#define SET_8723D_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+
+/* _BT_FW_PATCH_0x6A */
+#define SET_8723D_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8723D_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+/* host message to firmware cmd */
+void rtl8723d_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8723d_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
+/* s32 rtl8723d_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
+void rtl8723d_set_FwPsTuneParam_cmd(PADAPTER padapter);
+void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8723d_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P
+	void rtl8723d_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8723d_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+	void rtl8723d_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+#endif
+
+s32 FillH2CCmd8723D(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8723D(_adapter *padapter, bool wowlan);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_dm.h
new file mode 100644
index 000000000000..f0d3a2e7de9f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_dm.h
@@ -0,0 +1,40 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_DM_H__
+#define __RTL8723D_DM_H__
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8723D dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
+
+void rtl8723d_init_dm_priv(PADAPTER padapter);
+void rtl8723d_deinit_dm_priv(PADAPTER padapter);
+
+void rtl8723d_InitHalDm(PADAPTER padapter);
+void rtl8723d_HalDmWatchDog(PADAPTER padapter);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_hal.h
new file mode 100644
index 000000000000..64b1c445e9c1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_hal.h
@@ -0,0 +1,314 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_HAL_H__
+#define __RTL8723D_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8723d_spec.h"
+#include "rtl8723d_rf.h"
+#include "rtl8723d_dm.h"
+#include "rtl8723d_recv.h"
+#include "rtl8723d_xmit.h"
+#include "rtl8723d_cmd.h"
+#include "rtl8723d_led.h"
+#include "Hal8723DPwrSeq.h"
+#include "Hal8723DPhyReg.h"
+#include "Hal8723DPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8723d_sreset.h"
+#endif
+#ifdef CONFIG_LPS_POFF
+	#include "rtl8723d_lps_poff.h"
+#endif
+
+#define FW_8723D_SIZE		0x8000
+#define FW_8723D_START_ADDRESS	0x1000
+#define FW_8723D_END_ADDRESS	0x1FFF /* 0x5FFF */
+
+#define IS_FW_HEADER_EXIST_8723D(_pFwHdr)\
+	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x23D0)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8723D_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8723D, *PRT_FIRMWARE_8723D;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8723D_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8723D_FIRMWARE_HDR, *PRT_8723D_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8723D		0x05
+#define BCN_DMA_ATIME_INT_TIME_8723D		0x02
+
+/* for 8723D
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8723D			128
+#define PAGE_SIZE_RX_8723D			8
+
+#define TX_DMA_SIZE_8723D			0x8000	/* 32K(TX) */
+#define RX_DMA_SIZE_8723D			0x4000	/* 16K(RX) */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8723D	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8723D	0x80	/* 128B, reserved for tx report */
+#endif
+#define RX_DMA_BOUNDARY_8723D\
+	(RX_DMA_SIZE_8723D - RX_DMA_RESERVED_SIZE_8723D - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
+#define BCNQ_PAGE_NUM_8723D		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8723D		0x08 /* 0x04 */
+#else
+	#define BCNQ1_PAGE_NUM_8723D		0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef BCNQ1_PAGE_NUM_8723D
+	#define BCNQ1_PAGE_NUM_8723D		0x00 /* 0x04 */
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt 1, PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8723D	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8723D	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8723D
+	#define WOWLAN_PAGE_NUM_8723D	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8723D	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8723D\
+	(0xFF - BCNQ_PAGE_NUM_8723D - BCNQ1_PAGE_NUM_8723D - WOWLAN_PAGE_NUM_8723D)
+#define TX_PAGE_BOUNDARY_8723D		(TX_TOTAL_PAGE_NUMBER_8723D + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723D	TX_TOTAL_PAGE_NUMBER_8723D
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8723D\
+	(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723D + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8723D */
+#define NORMAL_PAGE_NUM_HPQ_8723D		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8723D		0x02
+#define NORMAL_PAGE_NUM_NPQ_8723D		0x02
+#define NORMAL_PAGE_NUM_EPQ_8723D		0x04
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8723D		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8723D		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8723D		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8723D		0x00
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES (96 + 1)
+
+#define HAL_EFUSE_MEMORY
+#define HWSET_MAX_SIZE_8723D                512
+#define EFUSE_REAL_CONTENT_LEN_8723D        512
+#define EFUSE_MAP_LEN_8723D                 512
+#define EFUSE_MAX_SECTION_8723D             64
+
+/* For some inferiority IC purpose. added by Roger, 2009.09.02.*/
+#define EFUSE_IC_ID_OFFSET			506
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8723D)
+
+#define EFUSE_ACCESS_ON		0x69
+#define EFUSE_ACCESS_OFF	0x00
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define BANK_NUM			1
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
+#define EFUSE_BT_REAL_CONTENT_LEN	\
+	(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN		1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION		(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK	16
+
+typedef enum tag_Package_Definition {
+	PACKAGE_DEFAULT,
+	PACKAGE_QFN68,
+	PACKAGE_TFBGA90,
+	PACKAGE_TFBGA80,
+	PACKAGE_TFBGA79
+} PACKAGE_TYPE_E;
+
+#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)
+
+#ifdef CONFIG_FILE_FWIMG
+	extern char *rtw_fw_file_path;
+	extern char *rtw_fw_wow_file_path;
+	#ifdef CONFIG_MP_INCLUDED
+		extern char *rtw_fw_mp_bt_file_path;
+	#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
+
+/* rtl8723d_hal_init.c */
+s32 rtl8723d_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8723d_FirmwareSelfReset(PADAPTER padapter);
+void rtl8723d_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8723d_InitAntenna_Selection(PADAPTER padapter);
+void rtl8723d_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8723d_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8723d_init_default_value(PADAPTER padapter);
+
+s32 rtl8723d_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8723D(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8723D(PADAPTER padapter,
+				     u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseBTCoexistInfo_8723D(PADAPTER padapter,
+				       u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseEEPROMVer_8723D(PADAPTER padapter,
+				   u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParsePackageType_8723D(PADAPTER pAdapter,
+				     u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8723D(PADAPTER padapter,
+				  u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8723D(PADAPTER padapter,
+				    u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8723D(PADAPTER padapter,
+		u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8723D(PADAPTER pAdapter,
+			      u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8723D(PADAPTER padapter,
+				      u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParseVoltage_8723D(PADAPTER pAdapter,
+				 u8 *hwinfo, BOOLEAN	AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8723D(PADAPTER Adapter,
+				   u8	*PROMContent, BOOLEAN AutoloadFail);
+
+void rtl8723d_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8723d(_adapter *adapter);
+u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8723D(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8723D(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8723d_InitBeaconParameters(PADAPTER padapter);
+void rtl8723d_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void _InitMacAPLLSetting_8723D(PADAPTER Adapter);
+void _8051Reset8723(PADAPTER padapter);
+#ifdef CONFIG_WOWLAN
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8723d_start_thread(_adapter *padapter);
+void rtl8723d_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8723ds_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723ds_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723ds_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8723ds_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void CCX_FwC2HTxRpt_8723d(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8723D(u8 rate);
+u8 HwRateToMRate8723D(u8 rate);
+
+void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void check_bt_status_work(void *data);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	void rtl8723d_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8723DE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8723DE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+	u16 get_txbd_rw_reg(u16 ff_hwaddr);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_led.h
new file mode 100644
index 000000000000..80d5001b88d5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_led.h
@@ -0,0 +1,45 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_LED_H__
+#define __RTL8723D_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8723du_InitSwLeds(PADAPTER padapter);
+	void rtl8723du_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8723ds_InitSwLeds(PADAPTER padapter);
+	void rtl8723ds_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+	void rtl8723ds_InitSwLeds(PADAPTER padapter);
+	void rtl8723ds_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8723de_InitSwLeds(PADAPTER padapter);
+	void rtl8723de_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif /*#ifdef CONFIG_RTW_SW_LED*/
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_lps_poff.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_lps_poff.h
new file mode 100644
index 000000000000..0193d46fc4d7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_lps_poff.h
@@ -0,0 +1,57 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/******************************************** CONST  ************************/
+#define NUM_OF_REGISTER_BANK	13
+#define NUM_OF_TOTAL_DWORD (NUM_OF_REGISTER_BANK * 64)
+#define TOTAL_LEN_FOR_HIOE ((NUM_OF_TOTAL_DWORD + 1) * 8)
+#define LPS_POFF_STATIC_FILE_LEN (TOTAL_LEN_FOR_HIOE + TXDESC_SIZE)
+#define LPS_POFF_DYNAMIC_FILE_LEN	(512 + TXDESC_SIZE)
+/******************************************** CONST  ************************/
+
+/******************************************** MACRO   ************************/
+/* HOIE Entry Definition */
+#define SET_HOIE_ENTRY_LOW_DATA(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE),	0, 16, __Value)
+#define SET_HOIE_ENTRY_HIGH_DATA(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE), 16, 16, __Value)
+#define SET_HOIE_ENTRY_MODE_SELECT(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 0, 1, __Value)
+#define SET_HOIE_ENTRY_ADDRESS(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 1, 14, __Value)
+#define SET_HOIE_ENTRY_BYTE_MASK(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 15, 4, __Value)
+#define SET_HOIE_ENTRY_IO_LOCK(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 19, 1, __Value)
+#define SET_HOIE_ENTRY_RD_EN(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 20, 1, __Value)
+#define SET_HOIE_ENTRY_WR_EN(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 21, 1, __Value)
+#define SET_HOIE_ENTRY_RAW_RW(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 22, 1, __Value)
+#define SET_HOIE_ENTRY_RAW(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 23, 1, __Value)
+#define SET_HOIE_ENTRY_IO_DELAY(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 24, 8, __Value)
+
+/*********************Function Definition*******************************************/
+void rtl8723d_lps_poff_init(PADAPTER padapter);
+void rtl8723d_lps_poff_deinit(PADAPTER padapter);
+bool rtl8723d_lps_poff_get_txbndy_status(PADAPTER padapter);
+void rtl8723d_lps_poff_h2c_ctrl(PADAPTER padapter, u8 enable);
+void rtl8723d_lps_poff_set_ps_mode(PADAPTER padapter, bool bEnterLPS);
+bool rtl8723d_lps_poff_get_status(PADAPTER padapter);
+void rtl8723d_lps_poff_wow(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_recv.h
new file mode 100644
index 000000000000..5964355dd131
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_recv.h
@@ -0,0 +1,117 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_RECV_H__
+#define __RTL8723D_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8723D + 1)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_SDIO_HCI
+	#ifndef CONFIG_SDIO_RX_COPY
+		#undef MAX_RECVBUF_SZ
+		#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8723D - RX_DMA_RESERVED_SIZE_8723D)
+	#endif /* !CONFIG_SDIO_RX_COPY */
+#endif /* CONFIG_SDIO_HCI */
+
+/*-----------------------------------------------------------------*/
+/*	RTL8723D RX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+/*DWORD 0*/
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_8723D(__pRxStatusDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 15, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_FS_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 1)
+#ifdef USING_RX_TAG
+	#define GET_RX_BUFFER_DESC_RX_TAG_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 13)
+#else
+	#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8723D(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+#endif
+
+/*DWORD 1*/
+#define SET_RX_BUFFER_PHYSICAL_LOW_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+
+/*DWORD 2*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8723D(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+#else
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8723D(__pRxStatusDesc, __Value)
+#endif
+
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723ds_init_recv_priv(PADAPTER padapter);
+	void rtl8723ds_free_recv_priv(PADAPTER padapter);
+	s32 rtl8723ds_recv_hdl(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8723du_init_recv_priv(_adapter *padapter);
+	void rtl8723du_free_recv_priv(_adapter *padapter);
+	void rtl8723du_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723de_init_recv_priv(PADAPTER padapter);
+	void rtl8723de_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8723d_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8723D_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_rf.h
new file mode 100644
index 000000000000..8479dfb48216
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_rf.h
@@ -0,0 +1,22 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_RF_H__
+#define __RTL8723D_RF_H__
+
+int PHY_RF6052_Config8723D(IN PADAPTER pdapter);
+
+void PHY_RF6052SetBandwidth8723D(IN PADAPTER Adapter, IN enum channel_width Bandwidth);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_spec.h
new file mode 100644
index 000000000000..72f0b8ca0845
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_spec.h
@@ -0,0 +1,448 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_SPEC_H__
+#define __RTL8723D_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8723D		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8723D			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8723D			0x0002	/* 2 Byte */
+#define REG_APS_FSMCO_8723D			0x0004	/* 4 Byte */
+#define REG_SYS_CLKR_8723D				0x0008	/* 2 Byte */
+#define REG_9346CR_8723D				0x000A	/* 2 Byte */
+#define REG_EE_VPD_8723D				0x000C	/* 2 Byte */
+#define REG_AFE_MISC_8723D				0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8723D				0x0011	/* 7 Byte */
+#define REG_SPS_OCP_CFG_8723D			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8723D				0x001C	/* 3 Byte */
+#define REG_RF_CTRL_8723D				0x001F	/* 1 Byte */
+#define REG_LPLDO_CTRL_8723D			0x0023	/* 1 Byte */
+#define REG_AFE_XTAL_CTRL_8723D		0x0024	/* 4 Byte */
+#define REG_AFE_PLL_CTRL_8723D			0x0028	/* 4 Byte */
+#define REG_MAC_PLL_CTRL_EXT_8723D		0x002c	/* 4 Byte */
+#define REG_EFUSE_CTRL_8723D			0x0030
+#define REG_EFUSE_TEST_8723D			0x0034
+#define REG_PWR_DATA_8723D				0x0038
+#define REG_CAL_TIMER_8723D				0x003C
+#define REG_ACLK_MON_8723D				0x003E
+#define REG_GPIO_MUXCFG_8723D			0x0040
+#define REG_GPIO_IO_SEL_8723D			0x0042
+#define REG_MAC_PINMUX_CFG_8723D		0x0043
+#define REG_GPIO_PIN_CTRL_8723D			0x0044
+#define REG_GPIO_INTM_8723D				0x0048
+#define REG_LEDCFG0_8723D				0x004C
+#define REG_LEDCFG1_8723D				0x004D
+#define REG_LEDCFG2_8723D				0x004E
+#define REG_LEDCFG3_8723D				0x004F
+#define REG_FSIMR_8723D					0x0050
+#define REG_FSISR_8723D					0x0054
+#define REG_HSIMR_8723D					0x0058
+#define REG_HSISR_8723D					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_PAD_CTRL1_8723D		0x0064
+#define REG_MULTI_FUNC_CTRL_8723D		0x0068
+#define REG_GPIO_STATUS_8723D			0x006C
+#define REG_SDIO_CTRL_8723D				0x0070
+#define REG_OPT_CTRL_8723D				0x0074
+#define REG_AFE_CTRL_4_8723D		0x0078
+#define REG_MCUFWDL_8723D				0x0080
+#define REG_8051FW_CTRL_8723D			0x0080
+#define REG_HMEBOX_DBG_0_8723D	0x0088
+#define REG_HMEBOX_DBG_1_8723D	0x008A
+#define REG_HMEBOX_DBG_2_8723D	0x008C
+#define REG_HMEBOX_DBG_3_8723D	0x008E
+#define REG_WLLPS_CTRL		0x0090
+#define REG_HIMR0_8723D					0x00B0
+#define REG_HISR0_8723D					0x00B4
+#define REG_HIMR1_8723D					0x00B8
+#define REG_HISR1_8723D					0x00BC
+#define REG_PMC_DBG_CTRL2_8723D			0x00CC
+#define	REG_EFUSE_BURN_GNT_8723D		0x00CF
+#define REG_HPON_FSM_8723D				0x00EC
+#define REG_SYS_CFG1_8723D				0x00F0
+#define REG_SYS_CFG_8723D				0x00FC
+#define REG_ROM_VERSION					0x00FD
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8723D	0x01A0
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_8723D        0x01AE
+#define REG_C2HEVT_CLEAR_8723D			0x01AF
+#define REG_MCUTST_1_8723D				0x01C0
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_FMETHR_8723D				0x01C8
+#define REG_HMETFR_8723D				0x01CC
+#define REG_HMEBOX_0_8723D				0x01D0
+#define REG_HMEBOX_1_8723D				0x01D4
+#define REG_HMEBOX_2_8723D				0x01D8
+#define REG_HMEBOX_3_8723D				0x01DC
+#define REG_LLT_INIT_8723D				0x01E0
+#define REG_HMEBOX_EXT0_8723D			0x01F0
+#define REG_HMEBOX_EXT1_8723D			0x01F4
+#define REG_HMEBOX_EXT2_8723D			0x01F8
+#define REG_HMEBOX_EXT3_8723D			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RQPN_8723D					0x0200
+#define REG_FIFOPAGE_8723D				0x0204
+#define REG_DWBCN0_CTRL_8723D			REG_TDECTRL
+#define REG_TXDMA_OFFSET_CHK_8723D	0x020C
+#define REG_TXDMA_STATUS_8723D		0x0210
+#define REG_RQPN_NPQ_8723D			0x0214
+#define REG_DWBCN1_CTRL_8723D			0x0228
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8723D		0x0280
+#define REG_FW_UPD_RDPTR_8723D		0x0284 /* FW shall update this register before FW write RXPKT_RELEASE_POLL to 1 */
+#define REG_RXDMA_CONTROL_8723D		0x0286 /* Control the RX DMA. */
+#define REG_RXDMA_STATUS_8723D			0x0288
+#define REG_RXDMA_MODE_CTRL_8723D		0x0290
+#define REG_EARLY_MODE_CONTROL_8723D	0x02BC
+#define REG_RSVD5_8723D					0x02F0
+#define REG_RSVD6_8723D					0x02F4
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8723D			0x0300
+#define	REG_INT_MIG_8723D				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8723D		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8723D			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8723D			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8723D			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8723D			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8723D			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8723D			0x0338	/* RX Queue	Descriptor Address */
+#define REG_HI0Q_TXBD_DESA_8723D		0x0340
+#define REG_HI1Q_TXBD_DESA_8723D		0x0348
+#define REG_HI2Q_TXBD_DESA_8723D		0x0350
+#define REG_HI3Q_TXBD_DESA_8723D		0x0358
+#define REG_HI4Q_TXBD_DESA_8723D		0x0360
+#define REG_HI5Q_TXBD_DESA_8723D		0x0368
+#define REG_HI6Q_TXBD_DESA_8723D		0x0370
+#define REG_HI7Q_TXBD_DESA_8723D		0x0378
+#define	REG_MGQ_TXBD_NUM_8723D			0x0380
+#define	REG_RX_RXBD_NUM_8723D			0x0382
+#define	REG_VOQ_TXBD_NUM_8723D			0x0384
+#define	REG_VIQ_TXBD_NUM_8723D			0x0386
+#define	REG_BEQ_TXBD_NUM_8723D			0x0388
+#define	REG_BKQ_TXBD_NUM_8723D			0x038A
+#define	REG_HI0Q_TXBD_NUM_8723D			0x038C
+#define	REG_HI1Q_TXBD_NUM_8723D			0x038E
+#define	REG_HI2Q_TXBD_NUM_8723D			0x0390
+#define	REG_HI3Q_TXBD_NUM_8723D			0x0392
+#define	REG_HI4Q_TXBD_NUM_8723D			0x0394
+#define	REG_HI5Q_TXBD_NUM_8723D			0x0396
+#define	REG_HI6Q_TXBD_NUM_8723D			0x0398
+#define	REG_HI7Q_TXBD_NUM_8723D			0x039A
+#define	REG_TSFTIMER_HCI_8723D			0x039C
+#define	REG_BD_RW_PTR_CLR_8723D			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8723D			0x03A0
+#define	REG_VIQ_TXBD_IDX_8723D			0x03A4
+#define	REG_BEQ_TXBD_IDX_8723D			0x03A8
+#define	REG_BKQ_TXBD_IDX_8723D			0x03AC
+#define	REG_MGQ_TXBD_IDX_8723D			0x03B0
+#define	REG_RXQ_TXBD_IDX_8723D			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8723D			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8723D			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8723D			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8723D			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8723D			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8723D			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8723D			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8723D			0x03D4
+
+#define	REG_PCIE_HCPWM_8723DE			0x03D8 /* ?????? */
+#define	REG_PCIE_HRPWM_8723DE			0x03DC	/* PCIe RPWM  ?????? */
+#define	REG_DBI_WDATA_V1_8723D			0x03E8
+#define	REG_DBI_RDATA_V1_8723D			0x03EC
+#define	REG_DBI_FLAG_V1_8723D			0x03F0
+#define REG_MDIO_V1_8723D				0x03F4
+#define REG_PCIE_MIX_CFG_8723D			0x03F8
+#define REG_HCI_MIX_CFG_8723D			0x03FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_VOQ_INFORMATION_8723D		0x0400
+#define REG_VIQ_INFORMATION_8723D		0x0404
+#define REG_BEQ_INFORMATION_8723D		0x0408
+#define REG_BKQ_INFORMATION_8723D		0x040C
+#define REG_MGQ_INFORMATION_8723D		0x0410
+#define REG_HGQ_INFORMATION_8723D		0x0414
+#define REG_BCNQ_INFORMATION_8723D	0x0418
+#define REG_TXPKT_EMPTY_8723D			0x041A
+
+#define REG_FWHW_TXQ_CTRL_8723D		0x0420
+#define REG_HWSEQ_CTRL_8723D			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8723D	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8723D	0x0425
+#define REG_LIFECTRL_CTRL_8723D			0x0426
+#define REG_MULTI_BCNQ_OFFSET_8723D	0x0427
+#define REG_SPEC_SIFS_8723D				0x0428
+#define REG_RL_8723D						0x042A
+#define REG_TXBF_CTRL_8723D				0x042C
+#define REG_DARFRC_8723D				0x0430
+#define REG_RARFRC_8723D				0x0438
+#define REG_RRSR_8723D					0x0440
+#define REG_ARFR0_8723D					0x0444
+#define REG_ARFR1_8723D					0x044C
+#define REG_CCK_CHECK_8723D				0x0454
+#define REG_AMPDU_MAX_TIME_8723D		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8723D	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8723D	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8723D	0x045D
+#define REG_NDPA_OPT_CTRL_8723D		0x045F
+#define REG_FAST_EDCA_CTRL_8723D		0x0460
+#define REG_RD_RESP_PKT_TH_8723D		0x0463
+#define REG_DATA_SC_8723D				0x0483
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_POWER_STAGE1_8723D		0x04B4
+#define REG_POWER_STAGE2_8723D		0x04B8
+#define REG_AMPDU_BURST_MODE_8723D	0x04BC
+#define REG_PKT_VO_VI_LIFE_TIME_8723D	0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8723D	0x04C2
+#define REG_STBC_SETTING_8723D			0x04C4
+#define REG_HT_SINGLE_AMPDU_8723D		0x04C7
+#define REG_PROT_MODE_CTRL_8723D		0x04C8
+#define REG_MAX_AGGR_NUM_8723D		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8723D	0x04CB
+#define REG_BAR_MODE_CTRL_8723D		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8723D	0x04CF
+#define REG_MACID_PKT_DROP0_8723D		0x04D0
+#define REG_MACID_PKT_SLEEP_8723D		0x04D4
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8723D		0x0500
+#define REG_EDCA_VI_PARAM_8723D		0x0504
+#define REG_EDCA_BE_PARAM_8723D		0x0508
+#define REG_EDCA_BK_PARAM_8723D		0x050C
+#define REG_BCNTCFG_8723D				0x0510
+#define REG_PIFS_8723D					0x0512
+#define REG_RDG_PIFS_8723D				0x0513
+#define REG_SIFS_CTX_8723D				0x0514
+#define REG_SIFS_TRX_8723D				0x0516
+#define REG_AGGR_BREAK_TIME_8723D		0x051A
+#define REG_SLOT_8723D					0x051B
+#define REG_TX_PTCL_CTRL_8723D			0x0520
+#define REG_TXPAUSE_8723D				0x0522
+#define REG_DIS_TXREQ_CLR_8723D		0x0523
+#define REG_RD_CTRL_8723D				0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8723D			0x0540
+#define REG_RD_NAV_NXT_8723D			0x0544
+#define REG_NAV_PROT_LEN_8723D			0x0546
+#define REG_BCN_CTRL_8723D				0x0550
+#define REG_BCN_CTRL_1_8723D			0x0551
+#define REG_MBID_NUM_8723D				0x0552
+#define REG_DUAL_TSF_RST_8723D			0x0553
+#define REG_BCN_INTERVAL_8723D			0x0554
+#define REG_DRVERLYINT_8723D			0x0558
+#define REG_BCNDMATIM_8723D			0x0559
+#define REG_ATIMWND_8723D				0x055A
+#define REG_USTIME_TSF_8723D			0x055C
+#define REG_BCN_MAX_ERR_8723D			0x055D
+#define REG_RXTSF_OFFSET_CCK_8723D		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8723D	0x055F
+#define REG_TSFTR_8723D					0x0560
+#define REG_CTWND_8723D					0x0572
+#define REG_SECONDARY_CCA_CTRL_8723D	0x0577
+#define REG_PSTIMER_8723D				0x0580
+#define REG_TIMER0_8723D				0x0584
+#define REG_TIMER1_8723D				0x0588
+#define REG_ACMHWCTRL_8723D			0x05C0
+#define REG_SCH_TXCMD_8723D			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8723D				0x0600
+#define REG_TCR_8723D					0x0604
+#define REG_RCR_8723D					0x0608
+#define REG_RX_PKT_LIMIT_8723D			0x060C
+#define REG_RX_DLK_TIME_8723D			0x060D
+#define REG_RX_DRVINFO_SZ_8723D		0x060F
+
+#define REG_MACID_8723D					0x0610
+#define REG_BSSID_8723D					0x0618
+#define REG_MAR_8723D					0x0620
+#define REG_MBIDCAMCFG_8723D			0x0628
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_USTIME_EDCA_8723D			0x0638
+#define REG_MAC_SPEC_SIFS_8723D		0x063A
+#define REG_RESP_SIFP_CCK_8723D			0x063C
+#define REG_RESP_SIFS_OFDM_8723D		0x063E
+#define REG_ACKTO_8723D					0x0640
+#define REG_CTS2TO_8723D				0x0641
+#define REG_EIFS_8723D					0x0642
+
+#define REG_NAV_UPPER_8723D			0x0652	/* unit of 128 */
+#define REG_TRXPTCL_CTL_8723D			0x0668
+
+/* Security */
+#define REG_CAMCMD_8723D				0x0670
+#define REG_CAMWRITE_8723D				0x0674
+#define REG_CAMREAD_8723D				0x0678
+#define REG_CAMDBG_8723D				0x067C
+#define REG_SECCFG_8723D				0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8723D				0x0690
+#define REG_PS_RX_INFO_8723D			0x0692
+#define REG_UAPSD_TID_8723D				0x0693
+#define REG_WKFMCAM_CMD_8723D			0x0698
+#define REG_WKFMCAM_NUM_8723D			0x0698
+#define REG_WKFMCAM_RWD_8723D			0x069C
+#define REG_RXFLTMAP0_8723D				0x06A0
+#define REG_RXFLTMAP1_8723D				0x06A2
+#define REG_RXFLTMAP2_8723D				0x06A4
+#define REG_BCN_PSR_RPT_8723D			0x06A8
+#define REG_BT_COEX_TABLE_8723D		0x06C0
+#define REG_BFMER0_INFO_8723D			0x06E4
+#define REG_BFMER1_INFO_8723D			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8723D	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8723D	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8723D	0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8723D				0x0700
+#define REG_BSSID1_8723D				0x0708
+#define REG_BFMEE_SEL_8723D				0x0714
+#define REG_SND_PTCL_CTRL_8723D		0x0718
+
+/* LTR */
+#define REG_LTR_CTRL_BASIC_8723D		0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8723D		0x0798
+#define REG_LTR_ACTIVE_LATENCY_V1_8723D		0x079C
+
+/* LTE_COEX */
+#define REG_LTECOEX_CTRL			0x07C0
+#define REG_LTECOEX_WRITE_DATA		0x07C4
+#define REG_LTECOEX_READ_DATA		0x07C8
+#define REG_LTECOEX_PATH_CONTROL	0x70
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HCPWM1_8723D	0x025 /* HCI Current Power Mode 1 */
+
+
+/* ****************************************************************************
+ *	8723 Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* 2 HSISR
+ * 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)
+
+#ifdef CONFIG_RF_POWER_TRIM
+	#ifdef CONFIG_RTL8723D
+		#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#endif
+
+	#define EEPROM_RF_GAIN_VAL				0x1F6
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+#ifdef CONFIG_PCI_HCI
+	/* #define IMR_RX_MASK		(IMR_ROK_8723D|IMR_RDU_8723D|IMR_RXFOVW_8723D) */
+	#define IMR_TX_MASK			(IMR_VODOK_8723D | IMR_VIDOK_8723D | IMR_BEDOK_8723D | IMR_BKDOK_8723D | IMR_MGNTDOK_8723D | IMR_HIGHDOK_8723D)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8723D | IMR_TXBCN0OK_8723D | IMR_TXBCN0ERR_8723D | IMR_BCNDERR0_8723D)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8723D | IMR_VODOK_8723D | IMR_BEDOK_8723D | IMR_BKDOK_8723D)
+#endif
+
+#endif /* __RTL8723D_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_sreset.h
new file mode 100644
index 000000000000..6310e8208e77
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_sreset.h
@@ -0,0 +1,25 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8723D_SRESET_H_
+#define _RTL8723D_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8723d_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8723d_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_xmit.h
new file mode 100644
index 000000000000..75b5124f0a36
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8723d_xmit.h
@@ -0,0 +1,520 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8723D_XMIT_H__
+#define __RTL8723D_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8723DDESC_H
+#define __INC_HAL8723DDESC_H
+
+#define RX_STATUS_DESC_SIZE_8723D		24
+#define RX_DRV_INFO_SIZE_UNIT_8723D 8
+
+
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8723D(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8723D(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8723D(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_EOR_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_AMSDU_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_IPVER_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_IS_TCPUDP__8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_CHK_VLD_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+#define GET_RX_STATUS_DESC_FCS_OK_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#ifdef CONFIG_USB_RX_AGGREGATION
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+#endif
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_MATCH_ID_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 7)
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8723D(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8723D(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+#define SET_RX_STATUS_DESC_BUFF_ADDR_8723D(__pRxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+/* Dword 0, rsvd: bit26, bit28 */
+#define GET_TX_DESC_OWN_8723D(__pTxDesc)\
+	LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+#define SET_TX_DESC_PKT_SIZE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_AMSDU_PAD_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+
+/* Dword 2  remove P_AID, G_ID field*/
+#define SET_TX_DESC_CCA_RTS_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL0_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL1_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_CCX_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_INT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_FTM_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 30, 1, __Value)
+
+/* Dword 3 */
+#define SET_TX_DESC_HWSEQ_SEL_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_PORT_ID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 2, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TX_TRY_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_STBC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_RTS_STBC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_PATH_A_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 1, __Value)
+#define SET_TX_DESC_TXPWR_OF_SET_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_RF_SEL_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#define SET_TX_DESC_TX_BUFFER_SIZE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#elif(DEV_BUS_TYPE == RT_USB_INTERFACE)
+#define SET_TX_DESC_TX_DESC_CHECKSUM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#else
+#define SET_TX_DESC_TX_TIMESTAMP_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 6, 18, __Value)
+#endif
+
+#define SET_TX_DESC_USB_TXAGG_NUM_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+/* Dword 8 */
+#define SET_TX_DESC_RTS_RC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_HWSEQ_EN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#define SET_TX_DESC_NEXTHEADPAGE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#define SET_TX_DESC_TAILPAGE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LEN_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_SEQ_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_FINAL_DATA_RATE_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 8, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+#define SET_EARLYMODE_LEN3_8723D(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+
+/*-----------------------------------------------------------------*/
+/*	RTL8723D TX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+8, 0, 32, __Valeu)
+#else
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu)	/* 64 BIT mode only */
+#endif
+/* ********************************************************* */
+
+/* 64 bits  -- 32 bits */
+/* =======     ======= */
+/* Dword 0     0 */
+#define SET_TX_BUFF_DESC_LEN_0_8723D(__pTxDesc, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 14, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_8723D(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_8723D(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1     1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_8723D(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_LOW_0_8723D(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+/* Dword 2     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 0, __Value)
+#ifdef CONFIG_64BIT_DMA
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8723D(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+8, 0, 32)
+#else
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8723D(__pTxDesc) 0
+#endif
+/* Dword 3     NA */
+/* RESERVED 0 */
+/* Dword 4     2 */
+#define SET_TX_BUFF_DESC_LEN_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 1, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 5     3 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 6     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_1_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 7     NA */
+/*RESERVED 0 */
+/* Dword 8     4 */
+#define SET_TX_BUFF_DESC_LEN_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 2, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 9     5 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 10    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_2_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 11    NA */
+/*RESERVED 0 */
+/* Dword 12    6 */
+#define SET_TX_BUFF_DESC_LEN_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 3, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 13    7 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 14    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_3_8723D(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 15    NA */
+/*RESERVED 0 */
+
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8723D_RATE1M				0x00
+#define DESC8723D_RATE2M				0x01
+#define DESC8723D_RATE5_5M				0x02
+#define DESC8723D_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8723D_RATE6M				0x04
+#define DESC8723D_RATE9M				0x05
+#define DESC8723D_RATE12M				0x06
+#define DESC8723D_RATE18M				0x07
+#define DESC8723D_RATE24M				0x08
+#define DESC8723D_RATE36M				0x09
+#define DESC8723D_RATE48M				0x0a
+#define DESC8723D_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8723D_RATEMCS0				0x0c
+#define DESC8723D_RATEMCS1				0x0d
+#define DESC8723D_RATEMCS2				0x0e
+#define DESC8723D_RATEMCS3				0x0f
+#define DESC8723D_RATEMCS4				0x10
+#define DESC8723D_RATEMCS5				0x11
+#define DESC8723D_RATEMCS6				0x12
+#define DESC8723D_RATEMCS7				0x13
+#define DESC8723D_RATEMCS8				0x14
+#define DESC8723D_RATEMCS9				0x15
+#define DESC8723D_RATEMCS10		0x16
+#define DESC8723D_RATEMCS11		0x17
+#define DESC8723D_RATEMCS12		0x18
+#define DESC8723D_RATEMCS13		0x19
+#define DESC8723D_RATEMCS14		0x1a
+#define DESC8723D_RATEMCS15		0x1b
+#define DESC8723D_RATEVHTSS1MCS0		0x2c
+#define DESC8723D_RATEVHTSS1MCS1		0x2d
+#define DESC8723D_RATEVHTSS1MCS2		0x2e
+#define DESC8723D_RATEVHTSS1MCS3		0x2f
+#define DESC8723D_RATEVHTSS1MCS4		0x30
+#define DESC8723D_RATEVHTSS1MCS5		0x31
+#define DESC8723D_RATEVHTSS1MCS6		0x32
+#define DESC8723D_RATEVHTSS1MCS7		0x33
+#define DESC8723D_RATEVHTSS1MCS8		0x34
+#define DESC8723D_RATEVHTSS1MCS9		0x35
+#define DESC8723D_RATEVHTSS2MCS0		0x36
+#define DESC8723D_RATEVHTSS2MCS1		0x37
+#define DESC8723D_RATEVHTSS2MCS2		0x38
+#define DESC8723D_RATEVHTSS2MCS3		0x39
+#define DESC8723D_RATEVHTSS2MCS4		0x3a
+#define DESC8723D_RATEVHTSS2MCS5		0x3b
+#define DESC8723D_RATEVHTSS2MCS6		0x3c
+#define DESC8723D_RATEVHTSS2MCS7		0x3d
+#define DESC8723D_RATEVHTSS2MCS8		0x3e
+#define DESC8723D_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8723D(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8723D(pDesc) == DESC8723D_RATE11M)
+
+#ifdef CONFIG_TRX_BD_ARCH
+	struct tx_desc;
+#endif
+
+void rtl8723d_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+void rtl8723d_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8723d_fill_txdesc_sectype(struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8723d_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8723d_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8723d_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8723ds_init_xmit_priv(PADAPTER padapter);
+	void rtl8723ds_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723ds_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723ds_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723ds_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723ds_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8723ds_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8723ds_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8723du_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8723du_xmit_buf_handler
+	s32 rtl8723du_init_xmit_priv(PADAPTER padapter);
+	void rtl8723du_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8723du_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723du_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8723du_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8723du_xmit_tasklet(void *priv);
+	s32 rtl8723du_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8723de_init_xmit_priv(PADAPTER padapter);
+	void rtl8723de_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8723de_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void	rtl8723de_xmitframe_resume(_adapter *padapter);
+	s32 rtl8723de_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8723de_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8723de_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8723de_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8723D(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8723D(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_cmd.h
index db534966f08d..e1aa4aefb747 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_cmd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,33 +12,28 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8812A_CMD_H__
 #define __RTL8812A_CMD_H__
 
-typedef enum _RTL8812_H2C_CMD 
-{
+typedef enum _RTL8812_H2C_CMD {
 	H2C_8812_RSVDPAGE = 0,
 	H2C_8812_MSRRPT = 1,
 	H2C_8812_SCAN = 2,
 	H2C_8812_KEEP_ALIVE_CTRL = 3,
 	H2C_8812_DISCONNECT_DECISION = 4,
 
-	H2C_8812_INIT_OFFLOAD = 6,		
+	H2C_8812_INIT_OFFLOAD = 6,
 	H2C_8812_AP_OFFLOAD = 8,
 	H2C_8812_BCN_RSVDPAGE = 9,
 	H2C_8812_PROBERSP_RSVDPAGE = 10,
-	
-	H2C_8812_SETPWRMODE = 0x20,		
+
+	H2C_8812_SETPWRMODE = 0x20,
 	H2C_8812_PS_TUNING_PARA = 0x21,
 	H2C_8812_PS_TUNING_PARA2 = 0x22,
 	H2C_8812_PS_LPS_PARA = 0x23,
 	H2C_8812_P2P_PS_OFFLOAD = 0x24,
+	H2C_8812_INACTIVE_PS = 0x27,
 	H2C_8812_RA_MASK = 0x40,
 	H2C_8812_TxBF = 0x41,
 	H2C_8812_RSSI_REPORT = 0x42,
@@ -55,44 +51,45 @@ typedef enum _RTL8812_H2C_CMD
 	H2C_8812_TSF_RESET = 0xC0,
 
 	MAX_8812_H2CCMD
-}RTL8812_H2C_CMD;
+} RTL8812_H2C_CMD;
 
 struct cmd_msg_parm {
-	u8 eid; //element id
-	u8 sz; // sz
+	u8 eid; /* element id */
+	u8 sz; /* sz */
 	u8 buf[6];
 };
 
-enum{
+enum {
 	PWRS
 };
 
-struct H2C_SS_RFOFF_PARAM{
-	u8 ROFOn; // 1: on, 0:off
-	u16 gpio_period; // unit: 1024 us
-}__attribute__ ((packed));
+struct H2C_SS_RFOFF_PARAM {
+	u8 ROFOn; /* 1: on, 0:off */
+	u16 gpio_period; /* unit: 1024 us */
+} __attribute__((packed));
 
 
 
-//_RSVDPAGE_LOC_CMD0
+/* _RSVDPAGE_LOC_CMD0 */
 #define SET_8812_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8812_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_8812_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8812_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8812_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 
-//_SETPWRMODE_PARM
+/* _SETPWRMODE_PARM */
 #define SET_8812_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8812_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8812_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)							LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
-//_P2P_PS_OFFLOAD
+/* _P2P_PS_OFFLOAD */
 #define SET_8812_H2CCMD_P2P_PS_OFFLOAD_ENABLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8812_H2CCMD_P2P_PS_OFFLOAD_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8812_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
@@ -102,44 +99,45 @@ struct H2C_SS_RFOFF_PARAM{
 #define SET_8812_H2CCMD_P2P_PS_OFFLOAD_DISCOVERY(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
 
 
-void	Set_RA_LDPC_8812(struct sta_info	*psta, BOOLEAN bLDPC);
+void	set_ra_ldpc_8812(struct cmn_sta_info *cmn_sta_info, BOOLEAN bLDPC);
 
-// host message to firmware cmd
-s32 FillH2CCmd_8812(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+/* host message to firmware cmd */
+s32 fill_h2c_cmd_8812(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 void rtl8812_set_FwPwrMode_cmd(PADAPTER padapter, u8 PSMode);
 void rtl8812_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
 u8 rtl8812_set_rssi_cmd(PADAPTER padapter, u8 *param);
-void rtl8812_set_raid_cmd(PADAPTER padapter, u32 bitmap, u8* arg);
-void rtl8812_Add_RateATid(PADAPTER padapter, u64 rate_bitmap, u8 *arg, u8 rssi_level);
-void rtl8812_set_wowlan_cmd(_adapter* padapter, u8 enable);
-s32 FillH2CCmd_8812(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+void rtl8812_set_wowlan_cmd(_adapter *padapter, u8 enable);
 u8 GetTxBufferRsvdPageNum8812(_adapter *padapter, bool wowlan);
 
 #ifdef CONFIG_BT_COEXIST
 void rtl8812a_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 #ifdef CONFIG_P2P_PS
 void rtl8812_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
-void CheckFwRsvdPageContent(PADAPTER padapter);
+#ifdef CONFIG_FWLPS_IN_IPS
+void rtl8812_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 cmd_param);
+#endif
 
-#ifdef CONFIG_TSF_RESET_OFFLOAD
-int reset_tsf(PADAPTER Adapter, u8 reset_port );
-#endif	// CONFIG_TSF_RESET_OFFLOAD
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8812_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
 
-//------------------------------------
-//     C2H format
-//------------------------------------
+/* ------------------------------------
+ * C2H format
+ * ------------------------------------ */
 
-// TX Beamforming
+/* TX Beamforming */
 #define GET_8812_C2H_TXBF_ORIGINATE(_Header)			LE_BITS_TO_1BYTE(_Header, 0, 8)
 #define GET_8812_C2H_TXBF_MACID(_Header)				LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
 
 
 
-/// TX Feedback Content
-#define 	USEC_UNIT_FOR_8812_C2H_TX_RPT_QUEUE_TIME			256
+/* / TX Feedback Content */
+#define	USEC_UNIT_FOR_8812_C2H_TX_RPT_QUEUE_TIME			256
 
 #define	GET_8812_C2H_TX_RPT_QUEUE_SELECT(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 5)
 #define	GET_8812_C2H_TX_RPT_PKT_BROCAST(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 5, 1)
@@ -147,27 +145,16 @@ int reset_tsf(PADAPTER Adapter, u8 reset_port );
 #define	GET_8812_C2H_TX_RPT_RETRY_OVER(_Header)				LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
 #define	GET_8812_C2H_TX_RPT_MAC_ID(_Header)					LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
 #define	GET_8812_C2H_TX_RPT_DATA_RETRY_CNT(_Header)		LE_BITS_TO_1BYTE((_Header + 2), 0, 6)
-#define	GET_8812_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	// In unit of 256 microseconds.
+#define	GET_8812_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	/* In unit of 256 microseconds. */
 #define	GET_8812_C2H_TX_RPT_FINAL_DATA_RATE(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
 
-// BT_FW_PATCH
+/* BT_FW_PATCH */
 #define SET_8812_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
 #define SET_8812_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8812_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8812_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+4, 0, 8, __Value)
 #define SET_8812_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((pu1Byte)(__pH2CCmd)+5, 0, 8, __Value)
 
-int	rtl8812_iqk_wait(_adapter* padapter, u32 timeout_ms);
-void	rtl8812_iqk_done(_adapter* padapter);
-
-s32
-_C2HContentParsing8812(
-	IN	PADAPTER	Adapter,
-	IN	u8			c2hCmdId, 
-	IN	u8			c2hCmdLen,
-	IN	u8 			*tmpBuf
-);
-void	C2HPacketHandler_8812(PADAPTER Adapter, u8 *Buffer, u8 Length);
-
-#endif//__RTL8812A_CMD_H__
+s32 c2h_handler_8812a(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
 
+#endif/* __RTL8812A_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_dm.h
index 3196973d8f9a..90b8f37002c4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8812A_DM_H__
 #define __RTL8812A_DM_H__
 
@@ -25,13 +21,8 @@ void rtl8812_deinit_dm_priv(IN PADAPTER Adapter);
 void rtl8812_InitHalDm(IN PADAPTER Adapter);
 void rtl8812_HalDmWatchDog(IN PADAPTER Adapter);
 
-//VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter);
+/* VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter); */
 
-//void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal);
+/* void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal); */
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-void	AntDivCompare8812(PADAPTER Adapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
-u8 AntDivBeforeLink8812(PADAPTER Adapter );
 #endif
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_hal.h
index 8260256e434e..98a656f7d9ec 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_hal.h
@@ -1,373 +1,370 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8812A_HAL_H__
-#define __RTL8812A_HAL_H__
-
-//#include "hal_com.h"
-#include "hal_data.h"
-
-//include HAL Related header after HAL Related compiling flags 
-#include "rtl8812a_spec.h"
-#include "rtl8812a_rf.h"
-#include "rtl8812a_dm.h"
-#include "rtl8812a_recv.h"
-#include "rtl8812a_xmit.h"
-#include "rtl8812a_cmd.h"
-#include "rtl8812a_led.h"
-#include "Hal8812PwrSeq.h"
-#include "Hal8821APwrSeq.h" //for 8821A/8811A
-#include "Hal8812PhyReg.h"
-#include "Hal8812PhyCfg.h"
-#ifdef DBG_CONFIG_ERROR_DETECT
-#include "rtl8812a_sreset.h"
-#endif
-
-
-//---------------------------------------------------------------------
-//		RTL8812AU From header
-//---------------------------------------------------------------------
-		#define RTL8812_FW_IMG						"rtl8812a/FW_NIC.bin"
-		#define RTL8812_FW_WW_IMG				"rtl8812a/FW_WoWLAN.bin"
-		#define RTL8812_PHY_REG					"rtl8812a/PHY_REG.txt" 
-		#define RTL8812_PHY_RADIO_A				"rtl8812a/RadioA.txt"
-		#define RTL8812_PHY_RADIO_B				"rtl8812a/RadioB.txt"
-		#define RTL8812_TXPWR_TRACK				"rtl8812a/TxPowerTrack.txt"			
-		#define RTL8812_AGC_TAB					"rtl8812a/AGC_TAB.txt"
-		#define RTL8812_PHY_MACREG 				"rtl8812a/MAC_REG.txt"
-		#define RTL8812_PHY_REG_PG					"rtl8812a/PHY_REG_PG.txt"
-		#define RTL8812_PHY_REG_MP 				"rtl8812a/PHY_REG_MP.txt" 
-		#define RTL8812_TXPWR_LMT					"rtl8812a/TXPWR_LMT.txt" 
-		#define RTL8812_WIFI_ANT_ISOLATION		"rtl8812a/wifi_ant_isolation.txt"
-
-//---------------------------------------------------------------------
-//		RTL8821U From file
-//---------------------------------------------------------------------
-		#define RTL8821_FW_IMG						"rtl8821a/FW_NIC.bin"
-		#define RTL8821_FW_WW_IMG				"rtl8821a/FW_WoWLAN.bin"
-		#define RTL8821_PHY_REG					"rtl8821a/PHY_REG.txt" 
-		#define RTL8821_PHY_RADIO_A				"rtl8821a/RadioA.txt"
-		#define RTL8821_PHY_RADIO_B				"rtl8821a/RadioB.txt" 
-		#define RTL8821_TXPWR_TRACK				"rtl8821a/TxPowerTrack.txt"		
-		#define RTL8821_AGC_TAB					"rtl8821a/AGC_TAB.txt"
-		#define RTL8821_PHY_MACREG 				"rtl8821a/MAC_REG.txt"
-		#define RTL8821_PHY_REG_PG					"rtl8821a/PHY_REG_PG.txt"
-		#define RTL8821_PHY_REG_MP 				"rtl8821a/PHY_REG_MP.txt"
-		#define RTL8821_TXPWR_LMT					"rtl8821a/TXPWR_LMT.txt" 
-
-//---------------------------------------------------------------------
-//		RTL8812 Power Configuration CMDs for PCIe interface
-//---------------------------------------------------------------------
-#define Rtl8812_NIC_PWR_ON_FLOW				rtl8812_power_on_flow
-#define Rtl8812_NIC_RF_OFF_FLOW				rtl8812_radio_off_flow
-#define Rtl8812_NIC_DISABLE_FLOW				rtl8812_card_disable_flow
-#define Rtl8812_NIC_ENABLE_FLOW				rtl8812_card_enable_flow
-#define Rtl8812_NIC_SUSPEND_FLOW				rtl8812_suspend_flow
-#define Rtl8812_NIC_RESUME_FLOW				rtl8812_resume_flow
-#define Rtl8812_NIC_PDN_FLOW					rtl8812_hwpdn_flow
-#define Rtl8812_NIC_LPS_ENTER_FLOW			rtl8812_enter_lps_flow
-#define Rtl8812_NIC_LPS_LEAVE_FLOW				rtl8812_leave_lps_flow		
-
-//---------------------------------------------------------------------
-//		RTL8821 Power Configuration CMDs for PCIe interface
-//---------------------------------------------------------------------
-#define Rtl8821A_NIC_PWR_ON_FLOW				rtl8821A_power_on_flow
-#define Rtl8821A_NIC_RF_OFF_FLOW				rtl8821A_radio_off_flow
-#define Rtl8821A_NIC_DISABLE_FLOW				rtl8821A_card_disable_flow
-#define Rtl8821A_NIC_ENABLE_FLOW				rtl8821A_card_enable_flow
-#define Rtl8821A_NIC_SUSPEND_FLOW				rtl8821A_suspend_flow
-#define Rtl8821A_NIC_RESUME_FLOW				rtl8821A_resume_flow
-#define Rtl8821A_NIC_PDN_FLOW					rtl8821A_hwpdn_flow
-#define Rtl8821A_NIC_LPS_ENTER_FLOW			rtl8821A_enter_lps_flow
-#define Rtl8821A_NIC_LPS_LEAVE_FLOW			rtl8821A_leave_lps_flow	
-
-
-#if 1 // download firmware related data structure
-#define FW_SIZE_8812			0x8000 // Compatible with RTL8723 Maximal RAM code size 24K.   modified to 32k, TO compatible with 92d maximal fw size 32k
-#define FW_START_ADDRESS		0x1000
-#define FW_END_ADDRESS		0x5FFF
-
-
-
-typedef struct _RT_FIRMWARE_8812 {
-	FIRMWARE_SOURCE	eFWSource;
-#ifdef CONFIG_EMBEDDED_FWIMG
-	u8*			szFwBuffer;
-#else
-	u8			szFwBuffer[FW_SIZE_8812];
-#endif
-	u32			ulFwLength;
-} RT_FIRMWARE_8812, *PRT_FIRMWARE_8812;
-
-//
-// This structure must be cared byte-ordering
-//
-// Added by tynli. 2009.12.04.
-#define IS_FW_HEADER_EXIST_8812(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8812(_pFwHdr) &0xFFF0) ==  0x9500)
-
-#define IS_FW_HEADER_EXIST_8821(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8812(_pFwHdr) &0xFFF0) ==  0x2100)
-//=====================================================
-//					Firmware Header(8-byte alinment required)
-//=====================================================
-//--- LONG WORD 0 ----
-#define GET_FIRMWARE_HDR_SIGNATURE_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16) // 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut
-#define GET_FIRMWARE_HDR_CATEGORY_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) // AP/NIC and USB/PCI
-#define GET_FIRMWARE_HDR_FUNCTION_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 24, 8) // Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions
-#define GET_FIRMWARE_HDR_VERSION_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)// FW Version
-#define GET_FIRMWARE_HDR_SUB_VER_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) // FW Subversion, default 0x00
-#define GET_FIRMWARE_HDR_RSVD1_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8) 		
-
-//--- LONG WORD 1 ----
-#define GET_FIRMWARE_HDR_MONTH_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 8) // Release time Month field
-#define GET_FIRMWARE_HDR_DATE_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 8, 8) // Release time Date field
-#define GET_FIRMWARE_HDR_HOUR_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 16, 8)// Release time Hour field
-#define GET_FIRMWARE_HDR_MINUTE_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+8, 24, 8)// Release time Minute field
-#define GET_FIRMWARE_HDR_ROMCODE_SIZE_8812(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+12, 0, 16)// The size of RAM code
-#define GET_FIRMWARE_HDR_RSVD2_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 16, 16)
-
-//--- LONG WORD 2 ----
-#define GET_FIRMWARE_HDR_SVN_IDX_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+16, 0, 32)// The SVN entry index
-#define GET_FIRMWARE_HDR_RSVD3_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 0, 32)
-
-//--- LONG WORD 3 ----
-#define GET_FIRMWARE_HDR_RSVD4_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 0, 32)
-#define GET_FIRMWARE_HDR_RSVD5_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
-
-#endif // download firmware related data structure
-
-
-#define DRIVER_EARLY_INT_TIME_8812		0x05
-#define BCN_DMA_ATIME_INT_TIME_8812		0x02
-
-//for 8812
-// TX 128K, RX 16K, Page size 512B for TX, 128B for RX
-#define MAX_RX_DMA_BUFFER_SIZE_8812	0x3E80 /* RX 16K */
-
-#ifdef CONFIG_WOWLAN
-#define RESV_FMWF	WKFMCAM_SIZE*MAX_WKFM_NUM /* 16 entries, for each is 24 bytes*/
-#else
-#define RESV_FMWF	0
-#endif
-
-#ifdef CONFIG_FW_C2H_DEBUG 
-#define RX_DMA_RESERVED_SIZE_8812	0x100	// 256B, reserved for c2h debug message
-#else
-#define RX_DMA_RESERVED_SIZE_8812	0x0	// 0B
-#endif
-#define RX_DMA_BOUNDARY_8812		(MAX_RX_DMA_BUFFER_SIZE_8812 - RX_DMA_RESERVED_SIZE_8812 - 1)
-
-#define BCNQ_PAGE_NUM_8812		0x07
-
-//For WoWLan , more reserved page
-//ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, PNO: 6
-#ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_8812	0x05
-#else
-#define WOWLAN_PAGE_NUM_8812	0x00
-#endif
-
-
-#ifdef	CONFIG_BEAMFORMER_FW_NDPA
-#define FW_NDPA_PAGE_NUM	0x02
-#else
-#define FW_NDPA_PAGE_NUM	0x00
-#endif
-
-#define TX_TOTAL_PAGE_NUMBER_8812	(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812-FW_NDPA_PAGE_NUM)
-#define TX_PAGE_BOUNDARY_8812			(TX_TOTAL_PAGE_NUMBER_8812 + 1)
-
-#define TX_PAGE_BOUNDARY_WOWLAN_8812		(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812 + 1)
-
-#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8812	TX_TOTAL_PAGE_NUMBER_8812
-#define WMM_NORMAL_TX_PAGE_BOUNDARY_8812		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8812 + 1)
-
-// For Normal Chip Setting
-// (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8812
-#define NORMAL_PAGE_NUM_LPQ_8812				0x10
-#define NORMAL_PAGE_NUM_HPQ_8812			0x10
-#define NORMAL_PAGE_NUM_NPQ_8812			0x00
-
-#define WMM_NORMAL_PAGE_NUM_HPQ_8812		0x30
-#define WMM_NORMAL_PAGE_NUM_LPQ_8812		0x20
-#define WMM_NORMAL_PAGE_NUM_NPQ_8812		0x20
-
-
-// for 8821A
-// TX 64K, RX 16K, Page size 256B for TX, 128B for RX
-#define PAGE_SIZE_TX_8821A					256
-#define PAGE_SIZE_RX_8821A					128
-
-#define MAX_RX_DMA_BUFFER_SIZE_8821			0x3E80 /* RX 16K */
-
-#ifdef CONFIG_FW_C2H_DEBUG 
-#define RX_DMA_RESERVED_SIZE_8821	0x100	// 256B, reserved for c2h debug message
-#else
-#define RX_DMA_RESERVED_SIZE_8821	0x0	// 0B
-#endif
-#define RX_DMA_BOUNDARY_8821		(MAX_RX_DMA_BUFFER_SIZE_8821 - RX_DMA_RESERVED_SIZE_8821 - 1)
-
-#define BCNQ_PAGE_NUM_8821		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-#define BCNQ1_PAGE_NUM_8821		0x04
-#else
-#define BCNQ1_PAGE_NUM_8821		0x00
-#endif
-
-//For WoWLan , more reserved page
-//ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, PNO: 6
-#ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_8821	0x06
-#else
-#define WOWLAN_PAGE_NUM_8821	0x00
-#endif
-
-#define TX_TOTAL_PAGE_NUMBER_8821	(0xFF - BCNQ_PAGE_NUM_8821 - BCNQ1_PAGE_NUM_8821 - WOWLAN_PAGE_NUM_8821)
-#define TX_PAGE_BOUNDARY_8821				(TX_TOTAL_PAGE_NUMBER_8821 + 1)
-//#define TX_PAGE_BOUNDARY_WOWLAN_8821		0xE0
-
-#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8821	TX_TOTAL_PAGE_NUMBER_8821
-#define WMM_NORMAL_TX_PAGE_BOUNDARY_8821		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8821 + 1)
-
-
-// (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER
-#define NORMAL_PAGE_NUM_LPQ_8821			0x08//0x10
-#define NORMAL_PAGE_NUM_HPQ_8821		0x08//0x10
-#define NORMAL_PAGE_NUM_NPQ_8821		0x00
-
-#define WMM_NORMAL_PAGE_NUM_HPQ_8821		0x30
-#define WMM_NORMAL_PAGE_NUM_LPQ_8821		0x20
-#define WMM_NORMAL_PAGE_NUM_NPQ_8821		0x20
-
-
-#define	EFUSE_HIDDEN_812AU					0
-#define	EFUSE_HIDDEN_812AU_VS				1
-#define	EFUSE_HIDDEN_812AU_VL				2
-#define	EFUSE_HIDDEN_812AU_VN				3
-
-#if 0
-#define EFUSE_REAL_CONTENT_LEN_JAGUAR		1024
-#define HWSET_MAX_SIZE_JAGUAR					1024
-#else
-#define EFUSE_REAL_CONTENT_LEN_JAGUAR		512
-#define HWSET_MAX_SIZE_JAGUAR					512
-#endif
-
-#define EFUSE_MAX_BANK_8812A					2
-#define EFUSE_MAP_LEN_JAGUAR					512
-#define EFUSE_MAX_SECTION_JAGUAR				64
-#define EFUSE_MAX_WORD_UNIT_JAGUAR			4
-#define EFUSE_IC_ID_OFFSET_JAGUAR				506	//For some inferiority IC purpose. added by Roger, 2009.09.02.
-#define AVAILABLE_EFUSE_ADDR_8812(addr) 	(addr < EFUSE_REAL_CONTENT_LEN_JAGUAR)
-// <Roger_Notes> To prevent out of boundary programming case, leave 1byte and program full section
-// 9bytes + 1byt + 5bytes and pre 1byte.
-// For worst case:
-// | 2byte|----8bytes----|1byte|--7bytes--| //92D
-#define EFUSE_OOB_PROTECT_BYTES_JAGUAR		18 	// PG data exclude header, dummy 7 bytes frome CP test and reserved 1byte.
-#define EFUSE_PROTECT_BYTES_BANK_JAGUAR		16
-// Added for different registry settings to adjust TxPwr index. added by Roger, 2010.03.09.
-typedef enum _TX_PWR_PERCENTAGE{
-	TX_PWR_PERCENTAGE_0 = 0x01, // 12.5%
-	TX_PWR_PERCENTAGE_1 = 0x02, // 25%
-	TX_PWR_PERCENTAGE_2 = 0x04, // 50%
-	TX_PWR_PERCENTAGE_3 = 0x08, //100%, default target output power.	
-} TX_PWR_PERCENTAGE;
-
-#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)
-
-//#define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE)
-
-//#define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) )
-
-// rtl8812_hal_init.c
-void	_8051Reset8812(PADAPTER padapter);
-s32	FirmwareDownload8812(PADAPTER Adapter, BOOLEAN bUsedWoWLANFw);
-void	InitializeFirmwareVars8812(PADAPTER padapter);
-
-s32	_LLTWrite_8812A(PADAPTER Adapter, u32 address, u32 data);
-s32	InitLLTTable8812A(PADAPTER padapter, u8 txpktbuf_bndy);
-void InitRDGSetting8812A(PADAPTER padapter);
-
-void CheckAutoloadState8812A(PADAPTER padapter);
-
-// EFuse
-u8	GetEEPROMSize8812A(PADAPTER padapter);
-void InitPGData8812A(PADAPTER padapter);
-void	Hal_EfuseParseIDCode8812A(PADAPTER padapter, u8 *hwinfo);
-void	Hal_ReadPROMVersion8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void	Hal_ReadTxPowerInfo8812A(PADAPTER padapter, u8* hwinfo,BOOLEAN	AutoLoadFail);
-void	Hal_ReadBoardType8812A(PADAPTER pAdapter, u8* hwinfo,BOOLEAN AutoLoadFail);
-void	Hal_ReadThermalMeter_8812A(PADAPTER	Adapter, u8* PROMContent,BOOLEAN 	AutoloadFail);
-void	Hal_ReadChannelPlan8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void	Hal_EfuseParseXtal_8812A(PADAPTER pAdapter, u8* hwinfo,BOOLEAN AutoLoadFail);
-void	Hal_ReadAntennaDiversity8812A(PADAPTER pAdapter,u8* PROMContent,BOOLEAN AutoLoadFail);
-void	Hal_ReadAntennaDiversity8821A(PADAPTER pAdapter, u8* PROMContent, BOOLEAN AutoLoadFail);
-void	Hal_ReadAmplifierType_8812A(PADAPTER Adapter,u8* PROMContent, BOOLEAN AutoloadFail);
-void	Hal_ReadPAType_8821A(PADAPTER Adapter,u8* PROMContent, BOOLEAN AutoloadFail);
-void	Hal_ReadRFEType_8812A(PADAPTER Adapter,u8* PROMContent, BOOLEAN AutoloadFail);
-void	Hal_EfuseParseBTCoexistInfo8812A(PADAPTER Adapter, u8* hwinfo, BOOLEAN AutoLoadFail);
-void	hal_ReadUsbType_8812AU(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
-int 	FirmwareDownloadBT(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
-void	Hal_ReadRemoteWakeup_8812A(PADAPTER padapter, u8* hwinfo, BOOLEAN AutoLoadFail);
-
-BOOLEAN HalDetectPwrDownMode8812(PADAPTER Adapter);
-void Hal_EfuseParseKFreeData_8821A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
-	
-#ifdef CONFIG_WOWLAN
-void Hal_DetectWoWMode(PADAPTER pAdapter);
-#endif //CONFIG_WOWLAN
-
-void _InitBeaconParameters_8812A(PADAPTER padapter);
-void SetBeaconRelatedRegisters8812A(PADAPTER padapter);
-
-void ReadRFType8812A(PADAPTER padapter);
-void InitDefaultValue8821A(PADAPTER padapter);
-
-void SetHwReg8812A(PADAPTER padapter, u8 variable, u8 *pval);
-void GetHwReg8812A(PADAPTER padapter, u8 variable, u8 *pval);
-u8 SetHalDefVar8812A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-u8 GetHalDefVar8812A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-s32 c2h_id_filter_ccx_8812a(u8 *buf);
-void rtl8812_set_hal_ops(struct hal_ops *pHalFunc);
-void init_hal_spec_8812a(_adapter *adapter);
-void init_hal_spec_8821a(_adapter *adapter);
-
-// register
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
-
-void rtl8812_start_thread(PADAPTER padapter);
-void rtl8812_stop_thread(PADAPTER padapter);
-
-#ifdef CONFIG_PCI_HCI
-BOOLEAN	InterruptRecognized8812AE(PADAPTER Adapter);
-VOID	UpdateInterruptMask8812AE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
-#endif
-
-#ifdef CONFIG_BT_COEXIST
-void rtl8812a_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
-#endif
-
-VOID
-Hal_PatchwithJaguar_8812(
-	IN PADAPTER				Adapter,
-	IN RT_MEDIA_STATUS		MediaStatus
-	);
-
-#endif //__RTL8188E_HAL_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_HAL_H__
+#define __RTL8812A_HAL_H__
+
+/* #include "hal_com.h" */
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8812a_spec.h"
+#include "rtl8812a_rf.h"
+#include "rtl8812a_dm.h"
+#include "rtl8812a_recv.h"
+#include "rtl8812a_xmit.h"
+#include "rtl8812a_cmd.h"
+#include "rtl8812a_led.h"
+#include "Hal8812PwrSeq.h"
+#include "Hal8821APwrSeq.h" /* for 8821A/8811A */
+#include "Hal8812PhyReg.h"
+#include "Hal8812PhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+#include "rtl8812a_sreset.h"
+#endif
+
+/* ---------------------------------------------------------------------
+ *		RTL8812 Power Configuration CMDs for PCIe interface
+ * --------------------------------------------------------------------- */
+#define Rtl8812_NIC_PWR_ON_FLOW				rtl8812_power_on_flow
+#define Rtl8812_NIC_RF_OFF_FLOW				rtl8812_radio_off_flow
+#define Rtl8812_NIC_DISABLE_FLOW				rtl8812_card_disable_flow
+#define Rtl8812_NIC_ENABLE_FLOW				rtl8812_card_enable_flow
+#define Rtl8812_NIC_SUSPEND_FLOW				rtl8812_suspend_flow
+#define Rtl8812_NIC_RESUME_FLOW				rtl8812_resume_flow
+#define Rtl8812_NIC_PDN_FLOW					rtl8812_hwpdn_flow
+#define Rtl8812_NIC_LPS_ENTER_FLOW			rtl8812_enter_lps_flow
+#define Rtl8812_NIC_LPS_LEAVE_FLOW				rtl8812_leave_lps_flow
+
+/* ---------------------------------------------------------------------
+ *		RTL8821 Power Configuration CMDs for PCIe interface
+ * --------------------------------------------------------------------- */
+#define Rtl8821A_NIC_PWR_ON_FLOW				rtl8821A_power_on_flow
+#define Rtl8821A_NIC_RF_OFF_FLOW				rtl8821A_radio_off_flow
+#define Rtl8821A_NIC_DISABLE_FLOW				rtl8821A_card_disable_flow
+#define Rtl8821A_NIC_ENABLE_FLOW				rtl8821A_card_enable_flow
+#define Rtl8821A_NIC_SUSPEND_FLOW				rtl8821A_suspend_flow
+#define Rtl8821A_NIC_RESUME_FLOW				rtl8821A_resume_flow
+#define Rtl8821A_NIC_PDN_FLOW					rtl8821A_hwpdn_flow
+#define Rtl8821A_NIC_LPS_ENTER_FLOW			rtl8821A_enter_lps_flow
+#define Rtl8821A_NIC_LPS_LEAVE_FLOW			rtl8821A_leave_lps_flow
+
+
+#if 1 /* download firmware related data structure */
+#define FW_SIZE_8812			0x8000 /* Compatible with RTL8723 Maximal RAM code size 24K.   modified to 32k, TO compatible with 92d maximal fw size 32k */
+#define FW_START_ADDRESS		0x1000
+#define FW_END_ADDRESS		0x5FFF
+
+
+
+typedef struct _RT_FIRMWARE_8812 {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_SIZE_8812];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8812, *PRT_FIRMWARE_8812;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+#define IS_FW_HEADER_EXIST_8812(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8812(_pFwHdr) & 0xFFF0) == 0x9500)
+
+#define IS_FW_HEADER_EXIST_8821(_pFwHdr)	((GET_FIRMWARE_HDR_SIGNATURE_8812(_pFwHdr) & 0xFFF0) == 0x2100)
+/* *****************************************************
+ *					Firmware Header(8-byte alinment required)
+ * *****************************************************
+ * --- LONG WORD 0 ---- */
+#define GET_FIRMWARE_HDR_SIGNATURE_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16) /* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut */
+#define GET_FIRMWARE_HDR_CATEGORY_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) /* AP/NIC and USB/PCI */
+#define GET_FIRMWARE_HDR_FUNCTION_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 24, 8) /* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions */
+#define GET_FIRMWARE_HDR_VERSION_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)/* FW Version */
+#define GET_FIRMWARE_HDR_SUB_VER_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) /* FW Subversion, default 0x00 */
+#define GET_FIRMWARE_HDR_RSVD1_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8)
+
+/* --- LONG WORD 1 ---- */
+#define GET_FIRMWARE_HDR_MONTH_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 8) /* Release time Month field */
+#define GET_FIRMWARE_HDR_DATE_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 8, 8) /* Release time Date field */
+#define GET_FIRMWARE_HDR_HOUR_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 16, 8)/* Release time Hour field */
+#define GET_FIRMWARE_HDR_MINUTE_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+8, 24, 8)/* Release time Minute field */
+#define GET_FIRMWARE_HDR_ROMCODE_SIZE_8812(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+12, 0, 16)/* The size of RAM code */
+#define GET_FIRMWARE_HDR_RSVD2_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 16, 16)
+
+/* --- LONG WORD 2 ---- */
+#define GET_FIRMWARE_HDR_SVN_IDX_8812(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+16, 0, 32)/* The SVN entry index */
+#define GET_FIRMWARE_HDR_RSVD3_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 0, 32)
+
+/* --- LONG WORD 3 ---- */
+#define GET_FIRMWARE_HDR_RSVD4_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 0, 32)
+#define GET_FIRMWARE_HDR_RSVD5_8812(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
+
+#endif /* download firmware related data structure */
+
+
+#define DRIVER_EARLY_INT_TIME_8812		0x05
+#define BCN_DMA_ATIME_INT_TIME_8812		0x02
+
+/* for 8812
+ * TX 128K, RX 16K, Page size 512B for TX, 128B for RX */
+#define MAX_RX_DMA_BUFFER_SIZE_8812	0x3E80 /* RX 16K */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8812	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8812	0x0	/* 0B */
+#endif
+#define RX_DMA_BOUNDARY_8812		(MAX_RX_DMA_BUFFER_SIZE_8812 - RX_DMA_RESERVED_SIZE_8812 - 1)
+
+#define BCNQ_PAGE_NUM_8812		0x07
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, AOAC rpt: 1,PNO: 6
+ * NS offload: 1 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8812	0x08
+#else
+	#define WOWLAN_PAGE_NUM_8812	0x00
+#endif
+
+
+#ifdef CONFIG_BEAMFORMER_FW_NDPA
+	#define FW_NDPA_PAGE_NUM	0x02
+#else
+	#define FW_NDPA_PAGE_NUM	0x00
+#endif
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	#define FW_DBG_MSG_PKT_PAGE_NUM_8812	0x01
+#else
+	#define FW_DBG_MSG_PKT_PAGE_NUM_8812	0x00
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+#define TX_TOTAL_PAGE_NUMBER_8812	(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812 - FW_NDPA_PAGE_NUM - FW_DBG_MSG_PKT_PAGE_NUM_8812)
+#define TX_PAGE_BOUNDARY_8812			(TX_TOTAL_PAGE_NUMBER_8812 + 1)
+
+#define TX_PAGE_BOUNDARY_WOWLAN_8812		(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812 + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8812	TX_TOTAL_PAGE_NUMBER_8812
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8812		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8812 + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8812 */
+#define NORMAL_PAGE_NUM_LPQ_8812				0x10
+#define NORMAL_PAGE_NUM_HPQ_8812			0x10
+#define NORMAL_PAGE_NUM_NPQ_8812			0x00
+
+#define WMM_NORMAL_PAGE_NUM_HPQ_8812		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8812		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8812		0x20
+
+
+/* for 8821A
+ * TX 64K, RX 16K, Page size 256B for TX, 128B for RX */
+#define PAGE_SIZE_TX_8821A					256
+#define PAGE_SIZE_RX_8821A					128
+
+#define MAX_RX_DMA_BUFFER_SIZE_8821			0x3E80 /* RX 16K */
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8821	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8821	0x0	/* 0B */
+#endif
+#define RX_DMA_BOUNDARY_8821		(MAX_RX_DMA_BUFFER_SIZE_8821 - RX_DMA_RESERVED_SIZE_8821 - 1)
+
+#define BCNQ_PAGE_NUM_8821		0x08
+#ifdef CONFIG_CONCURRENT_MODE
+	#define BCNQ1_PAGE_NUM_8821		0x04
+#else
+	#define BCNQ1_PAGE_NUM_8821		0x00
+#endif
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, PNO: 6 */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8821	0x06
+#else
+	#define WOWLAN_PAGE_NUM_8821	0x00
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8821	(0xFF - BCNQ_PAGE_NUM_8821 - BCNQ1_PAGE_NUM_8821 - WOWLAN_PAGE_NUM_8821)
+#define TX_PAGE_BOUNDARY_8821				(TX_TOTAL_PAGE_NUMBER_8821 + 1)
+/* #define TX_PAGE_BOUNDARY_WOWLAN_8821		0xE0 */
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8821	TX_TOTAL_PAGE_NUMBER_8821
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8821		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8821 + 1)
+
+
+/* (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER */
+#define NORMAL_PAGE_NUM_LPQ_8821			0x08/* 0x10 */
+#define NORMAL_PAGE_NUM_HPQ_8821		0x08/* 0x10 */
+#define NORMAL_PAGE_NUM_NPQ_8821		0x00
+#define NORMAL_PAGE_NUM_EPQ_8821			0x04
+
+#define WMM_NORMAL_PAGE_NUM_HPQ_8821		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8821		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8821		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8821		0x00
+
+#define MCC_NORMAL_PAGE_NUM_HPQ_8821		0x10
+#define MCC_NORMAL_PAGE_NUM_LPQ_8821		0x10
+#define MCC_NORMAL_PAGE_NUM_NPQ_8821		0x10
+
+#define	EFUSE_HIDDEN_812AU					0
+#define	EFUSE_HIDDEN_812AU_VS				1
+#define	EFUSE_HIDDEN_812AU_VL				2
+#define	EFUSE_HIDDEN_812AU_VN				3
+
+#if 0
+#define EFUSE_REAL_CONTENT_LEN_JAGUAR		1024
+#define HWSET_MAX_SIZE_JAGUAR					1024
+#else
+#define EFUSE_REAL_CONTENT_LEN_JAGUAR		512
+#define HWSET_MAX_SIZE_JAGUAR					512
+#endif
+
+#define EFUSE_MAX_BANK_8812A					2
+#define EFUSE_MAP_LEN_JAGUAR					512
+#define EFUSE_MAX_SECTION_JAGUAR				64
+#define EFUSE_MAX_WORD_UNIT_JAGUAR			4
+#define EFUSE_IC_ID_OFFSET_JAGUAR				506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define AVAILABLE_EFUSE_ADDR_8812(addr)	(addr < EFUSE_REAL_CONTENT_LEN_JAGUAR)
+/* <Roger_Notes> To prevent out of boundary programming case, leave 1byte and program full section
+ * 9bytes + 1byt + 5bytes and pre 1byte.
+ * For worst case:
+ * | 2byte|----8bytes----|1byte|--7bytes--|  */ /* 92D */
+#define EFUSE_OOB_PROTECT_BYTES_JAGUAR		18	/* PG data exclude header, dummy 7 bytes frome CP test and reserved 1byte. */
+#define EFUSE_PROTECT_BYTES_BANK_JAGUAR		16
+
+#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)
+
+/* #define IS_MULTI_FUNC_CHIP(_Adapter)	(((((PHAL_DATA_TYPE)(_Adapter->HalData))->MultiFunc) & (RT_MULTI_FUNC_BT|RT_MULTI_FUNC_GPS)) ? _TRUE : _FALSE) */
+
+/* #define RT_IS_FUNC_DISABLED(__pAdapter, __FuncBits) ( (__pAdapter)->DisabledFunctions & (__FuncBits) ) */
+#define HAL_EFUSE_MEMORY
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define BANK_NUM			2
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	512
+#define EFUSE_BT_REAL_CONTENT_LEN	\
+	(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN		1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION		(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK	16
+
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_BT_REAL_CONTENT_LEN)
+
+#ifdef CONFIG_FILE_FWIMG
+extern char *rtw_fw_file_path;
+#ifdef CONFIG_WOWLAN
+extern char *rtw_fw_wow_file_path;
+#endif
+#ifdef CONFIG_MP_INCLUDED
+extern char *rtw_fw_mp_bt_file_path;
+#endif
+#endif
+
+
+/* rtl8812_hal_init.c */
+void	_8051Reset8812(PADAPTER padapter);
+s32	FirmwareDownload8812(PADAPTER Adapter, BOOLEAN bUsedWoWLANFw);
+void	InitializeFirmwareVars8812(PADAPTER padapter);
+
+s32	_LLTWrite_8812A(PADAPTER Adapter, u32 address, u32 data);
+s32	InitLLTTable8812A(PADAPTER padapter, u8 txpktbuf_bndy);
+void InitRDGSetting8812A(PADAPTER padapter);
+
+void CheckAutoloadState8812A(PADAPTER padapter);
+
+/* EFuse */
+u8	GetEEPROMSize8812A(PADAPTER padapter);
+void InitPGData8812A(PADAPTER padapter);
+void	Hal_EfuseParseIDCode8812A(PADAPTER padapter, u8 *hwinfo);
+void	Hal_ReadPROMVersion8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadTxPowerInfo8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+void	Hal_ReadBoardType8812A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadThermalMeter_8812A(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void	Hal_ReadChannelPlan8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_EfuseParseXtal_8812A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	Hal_ReadAntennaDiversity8812A(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void	Hal_ReadAmplifierType_8812A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadPAType_8821A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_ReadRFEType_8812A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	Hal_EfuseParseBTCoexistInfo8812A(PADAPTER Adapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadUsbType_8812AU(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+#ifdef CONFIG_MP_INCLUDED
+int	FirmwareDownloadBT(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void	Hal_ReadRemoteWakeup_8812A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+BOOLEAN HalDetectPwrDownMode8812(PADAPTER Adapter);
+void Hal_EfuseParseKFreeData_8821A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+
+#ifdef CONFIG_WOWLAN
+void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void _InitBeaconParameters_8812A(PADAPTER padapter);
+void SetBeaconRelatedRegisters8812A(PADAPTER padapter);
+
+void ReadRFType8812A(PADAPTER padapter);
+void InitDefaultValue8821A(PADAPTER padapter);
+
+u8 SetHwReg8812A(PADAPTER padapter, u8 variable, u8 *pval);
+void GetHwReg8812A(PADAPTER padapter, u8 variable, u8 *pval);
+u8 SetHalDefVar8812A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8812A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+void rtl8812_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8812a(_adapter *adapter);
+void init_hal_spec_8821a(_adapter *adapter);
+
+u32 upload_txpktbuf_8812au(_adapter *adapter, u8 *buf, u32 buflen);
+
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+
+void rtl8812_start_thread(PADAPTER padapter);
+void rtl8812_stop_thread(PADAPTER padapter);
+
+#ifdef CONFIG_PCI_HCI
+BOOLEAN	InterruptRecognized8812AE(PADAPTER Adapter);
+VOID	UpdateInterruptMask8812AE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+VOID	InitTRXDescHwAddress8812AE(PADAPTER Adapter);
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+void rtl8812a_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
+#endif
+
+VOID
+Hal_PatchwithJaguar_8812(
+	IN PADAPTER				Adapter,
+	IN RT_MEDIA_STATUS		MediaStatus
+);
+
+#endif /* __RTL8188E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_led.h
index 52eb6e006f13..7396fed0d56d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_led.h
@@ -1,41 +1,42 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8812A_LED_H__
-#define __RTL8812A_LED_H__
-
-
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
-#ifdef CONFIG_USB_HCI
-void rtl8812au_InitSwLeds(PADAPTER padapter);
-void rtl8812au_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_PCI_HCI
-void rtl8812ae_InitSwLeds(PADAPTER padapter);
-void rtl8812ae_DeInitSwLeds(PADAPTER padapter);
-#endif
-#ifdef CONFIG_SDIO_HCI
-void rtl8821as_InitSwLeds(PADAPTER padapter);
-void rtl8821as_DeInitSwLeds(PADAPTER padapter);
-#endif
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_LED_H__
+#define __RTL8812A_LED_H__
+#ifdef CONFIG_RTW_LED
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+void rtl8812au_InitSwLeds(PADAPTER padapter);
+void rtl8812au_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+void rtl8812ae_InitSwLeds(PADAPTER padapter);
+void rtl8812ae_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+void rtl8821as_InitSwLeds(PADAPTER padapter);
+void rtl8821as_DeInitSwLeds(PADAPTER padapter);
+#endif
+#endif/*CONFIG_RTW_SW_LED*/
+#endif/*#ifdef CONFIG_RTW_LED*/
+
+#ifdef CONFIG_SDIO_HCI
+void rtl8821as_init_led_circuit(PADAPTER adapter);
+#endif
+
+#endif /*__RTL8812A_LED_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_recv.h
index ff5fa76c8184..e26304f9da0f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_recv.h
@@ -1,162 +1,154 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8812A_RECV_H__
-#define __RTL8812A_RECV_H__
-
-#if defined(CONFIG_USB_HCI)
-
-#ifndef MAX_RECVBUF_SZ
-#ifdef PLATFORM_OS_CE
-#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-#else
-	#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-		#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
-			#define MAX_RECVBUF_SZ (rtw_rtkm_get_buff_size()) /*depend rtkm*/
-		#else
-			#define MAX_RECVBUF_SZ (32768)  /*32k*/
-		#endif
-		//#define MAX_RECVBUF_SZ (24576) // 24k
-		//#define MAX_RECVBUF_SZ (20480) //20K
-		//#define MAX_RECVBUF_SZ (10240) //10K
-		//#define MAX_RECVBUF_SZ (15360) // 15k < 16k
-		//#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-		#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
-		#undef MAX_RECVBUF_SZ
-		#define MAX_RECVBUF_SZ (15360) // 15k < 16k
-		#endif //CONFIG_PLATFORM_NOVATEK_NT72668
-	#else
-		#define MAX_RECVBUF_SZ (4000) // about 4K
-	#endif
-#endif
-#endif //!MAX_RECVBUF_SZ
-
-#elif defined(CONFIG_PCI_HCI)
-//#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-//	#define MAX_RECVBUF_SZ (9100)
-//#else
-	#define MAX_RECVBUF_SZ (4000) // about 4K
-//#endif
-
-
-#elif defined(CONFIG_SDIO_HCI)
-
-#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8821 + 1)
-
-#endif
-
-
-// Rx smooth factor
-#define Rx_Smooth_Factor (20)
-
-//DWORD 0
-#define SET_RX_STATUS_DESC_PKT_LEN_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_STATUS_DESC_EOR_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 30, 1, __Value)
-#define SET_RX_STATUS_DESC_OWN_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 31, 1, __Value)
-
-#define GET_RX_STATUS_DESC_PKT_LEN_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 0, 14)
-#define GET_RX_STATUS_DESC_CRC32_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 14, 1)
-#define GET_RX_STATUS_DESC_ICV_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 15, 1)
-#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8812(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 4)
-#define GET_RX_STATUS_DESC_SECURITY_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 20, 3)
-#define GET_RX_STATUS_DESC_QOS_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 23, 1)
-#define GET_RX_STATUS_DESC_SHIFT_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 24, 2)
-#define GET_RX_STATUS_DESC_PHY_STATUS_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 26, 1)
-#define GET_RX_STATUS_DESC_SWDEC_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 27, 1)
-#define GET_RX_STATUS_DESC_LAST_SEG_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 28, 1)
-#define GET_RX_STATUS_DESC_FIRST_SEG_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 29, 1)
-#define GET_RX_STATUS_DESC_EOR_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 30, 1)
-#define GET_RX_STATUS_DESC_OWN_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 31, 1)
-
-//DWORD 1
-#define GET_RX_STATUS_DESC_MACID_8812(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
-#define GET_RX_STATUS_DESC_TID_8812(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
-#define GET_RX_STATUS_DESC_AMSDU_8812(__pRxDesc) 					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
-#define GET_RX_STATUS_DESC_RXID_MATCH_8812(__pRxDesc)		LE_BITS_TO_4BYTE( __pRxDesc+4, 14, 1)
-#define GET_RX_STATUS_DESC_PAGGR_8812(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 15, 1)
-#define GET_RX_STATUS_DESC_A1_FIT_8812(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 16, 4)
-#define GET_RX_STATUS_DESC_CHKERR_8812(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 20, 1)
-#define GET_RX_STATUS_DESC_IPVER_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
-#define GET_RX_STATUS_DESC_IS_TCPUDP__8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
-#define GET_RX_STATUS_DESC_CHK_VLD_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
-#define GET_RX_STATUS_DESC_PAM_8812(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 24, 1)
-#define GET_RX_STATUS_DESC_PWR_8812(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 25, 1)
-#define GET_RX_STATUS_DESC_MORE_DATA_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 26, 1)
-#define GET_RX_STATUS_DESC_MORE_FRAG_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 27, 1)
-#define GET_RX_STATUS_DESC_TYPE_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+4, 28, 2)
-#define GET_RX_STATUS_DESC_MC_8812(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 30, 1)
-#define GET_RX_STATUS_DESC_BC_8812(__pRxDesc)				LE_BITS_TO_4BYTE( __pRxDesc+4, 31, 1)
-
-//DWORD 2
-#define GET_RX_STATUS_DESC_SEQ_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 0, 12)
-#define GET_RX_STATUS_DESC_FRAG_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 12, 4)
-#define GET_RX_STATUS_DESC_RX_IS_QOS_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 16, 1)
-#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8812(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 18, 6)
-#define GET_RX_STATUS_DESC_RPT_SEL_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 28, 1)
-
-//DWORD 3
-#define GET_RX_STATUS_DESC_RX_RATE_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 0, 7)
-#define GET_RX_STATUS_DESC_HTC_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 10, 1)
-#define GET_RX_STATUS_DESC_EOSP_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 11, 1)
-#define GET_RX_STATUS_DESC_BSSID_FIT_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 12, 2)
-#ifdef CONFIG_USB_RX_AGGREGATION
-#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8812(__pRxStatusDesc)	LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 16, 8)
-#endif
-#define GET_RX_STATUS_DESC_PATTERN_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 29, 1)
-#define GET_RX_STATUS_DESC_UNICAST_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 30, 1)
-#define GET_RX_STATUS_DESC_MAGIC_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+12, 31, 1)
-
-//DWORD 6
-#define GET_RX_STATUS_DESC_SPLCP_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 0, 1)
-#define GET_RX_STATUS_DESC_LDPC_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 1, 1)
-#define GET_RX_STATUS_DESC_STBC_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 2, 1)
-#define GET_RX_STATUS_DESC_BW_8812(__pRxDesc)			LE_BITS_TO_4BYTE( __pRxDesc+16, 4, 2)
-
-//DWORD 5
-#define GET_RX_STATUS_DESC_TSFL_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+20, 0, 32)
-
-#define GET_RX_STATUS_DESC_BUFF_ADDR_8812(__pRxDesc) 		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
-#define GET_RX_STATUS_DESC_BUFF_ADDR64_8812(__pRxDesc) 		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
-
-#define SET_RX_STATUS_DESC_BUFF_ADDR_8812(__pRxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
-
-
-#ifdef CONFIG_SDIO_HCI
-s32 InitRecvPriv8821AS(PADAPTER padapter);
-void FreeRecvPriv8821AS(PADAPTER padapter);
-#endif // CONFIG_SDIO_HCI
-
-#ifdef CONFIG_USB_HCI
-void rtl8812au_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
-s32 rtl8812au_init_recv_priv(PADAPTER padapter);
-void rtl8812au_free_recv_priv(PADAPTER padapter);
-void rtl8812au_recv_hdl(PADAPTER padapter, struct recv_buf *precvbuf);
-void rtl8812au_recv_tasklet(void *priv);
-
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8812ae_init_recv_priv(PADAPTER padapter);
-void rtl8812ae_free_recv_priv(PADAPTER padapter);
-#endif
-
-void rtl8812_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
-
-#endif /* __RTL8812A_RECV_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_RECV_H__
+#define __RTL8812A_RECV_H__
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
+					#define MAX_RECVBUF_SZ (rtw_rtkm_get_buff_size()) /*depend rtkm*/
+				#else
+					#define MAX_RECVBUF_SZ (32768)  /*32k*/
+				#endif
+				/* #define MAX_RECVBUF_SZ (24576) */ /* 24k */
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (15360) */ /* 15k < 16k */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+				#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+					#undef MAX_RECVBUF_SZ
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI)
+
+	#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8821 + 1)
+
+#endif
+
+
+/* Rx smooth factor */
+#define Rx_Smooth_Factor (20)
+
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8812(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8812(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_LAST_SEG_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+#define GET_RX_STATUS_DESC_FIRST_SEG_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+#define GET_RX_STATUS_DESC_EOR_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8812(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_8812(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_AMSDU_8812(__pRxDesc)					LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_IPVER_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_IS_TCPUDP__8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_CHK_VLD_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8812(__pRxDesc)				LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8812(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8812(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8812(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#ifdef CONFIG_USB_RX_AGGREGATION
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8812(__pRxStatusDesc)	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+#endif
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_SPLCP_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+#define GET_RX_STATUS_DESC_LDPC_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+#define GET_RX_STATUS_DESC_STBC_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+#define GET_RX_STATUS_DESC_BW_8812(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8812(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8812(__pRxDesc)		LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+#define SET_RX_STATUS_DESC_BUFF_ADDR_8812(__pRxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+#ifdef CONFIG_SDIO_HCI
+s32 InitRecvPriv8821AS(PADAPTER padapter);
+void FreeRecvPriv8821AS(PADAPTER padapter);
+#endif /* CONFIG_SDIO_HCI */
+
+#ifdef CONFIG_USB_HCI
+void rtl8812au_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+s32 rtl8812au_init_recv_priv(PADAPTER padapter);
+void rtl8812au_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8812ae_init_recv_priv(PADAPTER padapter);
+void rtl8812ae_free_recv_priv(PADAPTER padapter);
+#endif
+
+void rtl8812_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8812A_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_rf.h
index e87b88534292..4250d3672b40 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,24 +12,18 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8812A_RF_H__
 #define __RTL8812A_RF_H__
 
 VOID
 PHY_RF6052SetBandwidth8812(
 	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH		Bandwidth);
+	IN	enum channel_width		Bandwidth);
 
 
 int
 PHY_RF6052_Config_8812(
-	IN	PADAPTER	Adapter	);
-
-#endif//__RTL8188E_RF_H__
+	IN	PADAPTER	Adapter);
 
+#endif/* __RTL8188E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_spec.h
index d0a62330e5a0..8d038ca9d09e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_spec.h
@@ -1,276 +1,264 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
-#ifndef __RTL8812A_SPEC_H__
-#define __RTL8812A_SPEC_H__
-
-#include <drv_conf.h>
-
-
-//============================================================
-//       8812 Regsiter offset definition
-//============================================================
-
-//============================================================
-//
-//============================================================
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_SYS_CLKR_8812A				0x0008
-#define REG_AFE_PLL_CTRL_8812A		0x0028
-#define REG_HSIMR_8812					0x0058
-#define REG_HSISR_8812					0x005c
-#define REG_GPIO_EXT_CTRL				0x0060
-#define REG_GPIO_STATUS_8812			0x006C
-#define REG_SDIO_CTRL_8812				0x0070
-#define REG_OPT_CTRL_8812				0x0074
-#define REG_RF_B_CTRL_8812				0x0076
-#define REG_FW_DRV_MSG_8812			0x0088
-#define REG_HMEBOX_E2_E3_8812			0x008C
-#define REG_HIMR0_8812					0x00B0
-#define REG_HISR0_8812					0x00B4
-#define REG_HIMR1_8812					0x00B8
-#define REG_HISR1_8812					0x00BC
-#define REG_EFUSE_BURN_GNT_8812		0x00CF
-#define REG_SYS_CFG1_8812				0x00FC
-
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-#define REG_CR_8812A					0x100
-#define REG_PKTBUF_DBG_ADDR 			(REG_PKTBUF_DBG_CTRL)
-#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
-#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
-#define REG_WOWLAN_WAKE_REASON			REG_MCUTST_WOWLAN
-
-#define REG_RSVD3_8812					0x0168
-#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
-#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
-#define REG_C2HEVT_CMD_LEN_88XX		0x01AE
-
-#define REG_HMEBOX_EXT0_8812			0x01F0
-#define REG_HMEBOX_EXT1_8812			0x01F4
-#define REG_HMEBOX_EXT2_8812			0x01F8
-#define REG_HMEBOX_EXT3_8812			0x01FC
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_DWBCN0_CTRL_8812				REG_TDECTRL
-#define REG_DWBCN1_CTRL_8812				0x0228
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_TDECTRL_8812A				0x0208
-#define REG_RXDMA_CONTROL_8812A		0x0286		/*Control the RX DMA.*/
-#define REG_RXDMA_PRO_8812			0x0290
-#define REG_EARLY_MODE_CONTROL_8812	0x02BC
-#define REG_RSVD5_8812					0x02F0
-#define REG_RSVD6_8812					0x02F4
-#define REG_RSVD7_8812					0x02F8
-#define REG_RSVD8_8812					0x02FC
-
-
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
-#define	REG_PCIE_CTRL_REG_8812A		0x0300
-#define	REG_DBI_WDATA_8812			0x0348	// DBI Write Data
-#define	REG_DBI_RDATA_8812			0x034C	// DBI Read Data
-#define	REG_DBI_ADDR_8812				0x0350	// DBI Address
-#define	REG_DBI_FLAG_8812				0x0352	// DBI Read/Write Flag
-#define	REG_MDIO_WDATA_8812			0x0354	// MDIO for Write PCIE PHY
-#define	REG_MDIO_RDATA_8812			0x0356	// MDIO for Reads PCIE PHY
-#define	REG_MDIO_CTL_8812				0x0358	// MDIO for Control 
-#define	REG_PCIE_MULTIFET_CTRL_8812	0x036A	//PCIE Multi-Fethc Control
-
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-#define REG_TXPKT_EMPTY_8812A			0x041A
-#define REG_FWHW_TXQ_CTRL_8812A		0x0420
-#define REG_TXBF_CTRL_8812A			0x042C
-#define REG_ARFR0_8812					0x0444
-#define REG_ARFR1_8812					0x044C
-#define REG_CCK_CHECK_8812				0x0454
-#define REG_AMPDU_MAX_TIME_8812		0x0456
-#define REG_TXPKTBUF_BCNQ_BDNY1_8812	0x0457
-
-#define REG_AMPDU_MAX_LENGTH_8812	0x0458
-#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8812	0x045D
-#define REG_NDPA_OPT_CTRL_8812A		0x045F
-#define REG_DATA_SC_8812				0x0483
-#ifdef CONFIG_WOWLAN
-#define REG_TXPKTBUF_IV_LOW             0x0484
-#define REG_TXPKTBUF_IV_HIGH            0x0488
-#endif
-#define REG_ARFR2_8812					0x048C
-#define REG_ARFR3_8812					0x0494
-#define REG_TXRPT_START_OFFSET		0x04AC
-#define REG_AMPDU_BURST_MODE_8812	0x04BC
-#define REG_HT_SINGLE_AMPDU_8812		0x04C7
-#define REG_MACID_PKT_DROP0_8812		0x04D0
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-#define REG_TXPAUSE_8812A				0x0522
-#define REG_CTWND_8812					0x0572
-#define REG_SECONDARY_CCA_CTRL_8812	0x0577
-#define REG_SCH_TXCMD_8812A			0x05F8
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-#define REG_MAC_CR_8812				0x0600
-
-#define REG_MAC_TX_SM_STATE_8812		0x06B4
-
-// Power
-#define REG_BFMER0_INFO_8812A			0x06E4
-#define REG_BFMER1_INFO_8812A			0x06EC
-#define REG_CSI_RPT_PARAM_BW20_8812A	0x06F4
-#define REG_CSI_RPT_PARAM_BW40_8812A	0x06F8
-#define REG_CSI_RPT_PARAM_BW80_8812A	0x06FC
-
-// Hardware Port 2
-#define REG_BFMEE_SEL_8812A			0x0714
-#define REG_SND_PTCL_CTRL_8812A		0x0718
-
-
-//-----------------------------------------------------
-//
-//	Redifine register definition for compatibility
-//
-//-----------------------------------------------------
-
-// TODO: use these definition when using REG_xxx naming rule.
-// NOTE: DO NOT Remove these definition. Use later.
-#define	ISR_8812							REG_HISR0_8812
-
-//----------------------------------------------------------------------------
-//       8195 IMR/ISR bits						(offset 0xB0,  8bits)
-//----------------------------------------------------------------------------
-#define	IMR_DISABLED_8812					0
-// IMR DW0(0x00B0-00B3) Bit 0-31
-#define	IMR_TIMER2_8812					BIT31		// Timeout interrupt 2
-#define	IMR_TIMER1_8812					BIT30		// Timeout interrupt 1	
-#define	IMR_PSTIMEOUT_8812				BIT29		// Power Save Time Out Interrupt
-#define	IMR_GTINT4_8812					BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define	IMR_GTINT3_8812					BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define	IMR_TXBCN0ERR_8812				BIT26		// Transmit Beacon0 Error			
-#define	IMR_TXBCN0OK_8812					BIT25		// Transmit Beacon0 OK			
-#define	IMR_TSF_BIT32_TOGGLE_8812		BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define	IMR_BCNDMAINT0_8812				BIT20		// Beacon DMA Interrupt 0			
-#define	IMR_BCNDERR0_8812					BIT16		// Beacon Queue DMA OK0			
-#define	IMR_HSISR_IND_ON_INT_8812		BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)
-#define	IMR_BCNDMAINT_E_8812				BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define	IMR_ATIMEND_8812					BIT12		// CTWidnow End or ATIM Window End
-#define	IMR_C2HCMD_8812					BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define	IMR_CPWM2_8812					BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_CPWM_8812						BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_HIGHDOK_8812					BIT7			// High Queue DMA OK	
-#define	IMR_MGNTDOK_8812					BIT6			// Management Queue DMA OK	
-#define	IMR_BKDOK_8812					BIT5			// AC_BK DMA OK		
-#define	IMR_BEDOK_8812					BIT4			// AC_BE DMA OK	
-#define	IMR_VIDOK_8812					BIT3			// AC_VI DMA OK		
-#define	IMR_VODOK_8812					BIT2			// AC_VO DMA OK	
-#define	IMR_RDU_8812						BIT1			// Rx Descriptor Unavailable	
-#define	IMR_ROK_8812						BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define	IMR_BCNDMAINT7_8812				BIT27		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT6_8812				BIT26		// Beacon DMA Interrupt 6
-#define	IMR_BCNDMAINT5_8812				BIT25		// Beacon DMA Interrupt 5
-#define	IMR_BCNDMAINT4_8812				BIT24		// Beacon DMA Interrupt 4
-#define	IMR_BCNDMAINT3_8812				BIT23		// Beacon DMA Interrupt 3
-#define	IMR_BCNDMAINT2_8812				BIT22		// Beacon DMA Interrupt 2
-#define	IMR_BCNDMAINT1_8812				BIT21		// Beacon DMA Interrupt 1
-#define	IMR_BCNDOK7_8812					BIT20		// Beacon Queue DMA OK Interrup 7
-#define	IMR_BCNDOK6_8812					BIT19		// Beacon Queue DMA OK Interrup 6
-#define	IMR_BCNDOK5_8812					BIT18		// Beacon Queue DMA OK Interrup 5
-#define	IMR_BCNDOK4_8812					BIT17		// Beacon Queue DMA OK Interrup 4
-#define	IMR_BCNDOK3_8812					BIT16		// Beacon Queue DMA OK Interrup 3
-#define	IMR_BCNDOK2_8812					BIT15		// Beacon Queue DMA OK Interrup 2
-#define	IMR_BCNDOK1_8812					BIT14		// Beacon Queue DMA OK Interrup 1
-#define	IMR_ATIMEND_E_8812				BIT13		// ATIM Window End Extension for Win7
-#define	IMR_TXERR_8812					BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define	IMR_RXERR_8812					BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define	IMR_TXFOVW_8812					BIT9			// Transmit FIFO Overflow
-#define	IMR_RXFOVW_8812					BIT8			// Receive FIFO Overflow
-
-
-#ifdef CONFIG_PCI_HCI
-//#define IMR_RX_MASK		(IMR_ROK_8812|IMR_RDU_8812|IMR_RXFOVW_8812)
-#define IMR_TX_MASK			(IMR_VODOK_8812|IMR_VIDOK_8812|IMR_BEDOK_8812|IMR_BKDOK_8812|IMR_MGNTDOK_8812|IMR_HIGHDOK_8812)
-
-#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8812 | IMR_TXBCN0OK_8812 | IMR_TXBCN0ERR_8812 | IMR_BCNDERR0_8812)
-
-#define RT_AC_INT_MASKS	(IMR_VIDOK_8812 | IMR_VODOK_8812 | IMR_BEDOK_8812|IMR_BKDOK_8812)
-#endif
-
-
-//============================================================================
-//       Regsiter Bit and Content definition 
-//============================================================================
-
-//2 ACMHWCTRL 0x05C0
-#define	AcmHw_HwEn_8812				BIT(0)
-#define	AcmHw_VoqEn_8812				BIT(1)
-#define	AcmHw_ViqEn_8812				BIT(2)
-#define	AcmHw_BeqEn_8812				BIT(3)
-#define	AcmHw_VoqStatus_8812			BIT(5)
-#define	AcmHw_ViqStatus_8812			BIT(6)
-#define	AcmHw_BeqStatus_8812			BIT(7)
-
-//========================================================
-// General definitions
-//========================================================
-
-#define MACID_NUM_8812A 128
-#define SEC_CAM_ENT_NUM_8812A 64
-#define NSS_NUM_8812A 2
-#define BAND_CAP_8812A (BAND_CAP_2G | BAND_CAP_5G)
-#define BW_CAP_8812A (BW_CAP_20M | BW_CAP_40M | BW_CAP_80M)
-#define PROTO_CAP_8812A (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N|PROTO_CAP_11AC)
-
-#endif /* __RTL8812A_SPEC_H__ */
-
-#ifdef CONFIG_RTL8821A
-#include "rtl8821a_spec.h"
-#endif /* CONFIG_RTL8821A */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_SPEC_H__
+#define __RTL8812A_SPEC_H__
+
+#include <drv_conf.h>
+
+
+/* ************************************************************
+* 8812 Regsiter offset definition
+* ************************************************************ */
+
+/* ************************************************************
+*
+* ************************************************************ */
+
+/* -----------------------------------------------------
+*
+*	0x0000h ~ 0x00FFh	System Configuration
+*
+* ----------------------------------------------------- */
+#define REG_SYS_CLKR_8812A				0x0008
+#define REG_AFE_PLL_CTRL_8812A		0x0028
+#define REG_HSIMR_8812					0x0058
+#define REG_HSISR_8812					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_GPIO_STATUS_8812			0x006C
+#define REG_SDIO_CTRL_8812				0x0070
+#define REG_OPT_CTRL_8812				0x0074
+#define REG_RF_B_CTRL_8812				0x0076
+#define REG_FW_DRV_MSG_8812			0x0088
+#define REG_HMEBOX_E2_E3_8812			0x008C
+#define REG_HIMR0_8812					0x00B0
+#define REG_HISR0_8812					0x00B4
+#define REG_HIMR1_8812					0x00B8
+#define REG_HISR1_8812					0x00BC
+#define REG_EFUSE_BURN_GNT_8812		0x00CF
+#define REG_SYS_CFG1_8812				0x00FC
+
+/* -----------------------------------------------------
+*
+*	0x0100h ~ 0x01FFh	MACTOP General Configuration
+*
+* ----------------------------------------------------- */
+#define REG_CR_8812A					0x100
+#define REG_PKTBUF_DBG_ADDR			(REG_PKTBUF_DBG_CTRL)
+#define REG_RXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+2)
+#define REG_TXPKTBUF_DBG				(REG_PKTBUF_DBG_CTRL+3)
+#define REG_WOWLAN_WAKE_REASON			REG_MCUTST_WOWLAN
+
+#define REG_RSVD3_8812					0x0168
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_88XX		0x01AE
+
+#define REG_HMEBOX_EXT0_8812			0x01F0
+#define REG_HMEBOX_EXT1_8812			0x01F4
+#define REG_HMEBOX_EXT2_8812			0x01F8
+#define REG_HMEBOX_EXT3_8812			0x01FC
+
+/* -----------------------------------------------------
+*
+*	0x0200h ~ 0x027Fh	TXDMA Configuration
+*
+* ----------------------------------------------------- */
+#define REG_DWBCN0_CTRL_8812				REG_TDECTRL
+#define REG_DWBCN1_CTRL_8812				0x0228
+
+/* -----------------------------------------------------
+*
+*	0x0280h ~ 0x02FFh	RXDMA Configuration
+*
+* ----------------------------------------------------- */
+#define REG_TDECTRL_8812A				0x0208
+#define REG_RXDMA_CONTROL_8812A		0x0286		/*Control the RX DMA.*/
+#define REG_RXDMA_PRO_8812			0x0290
+#define REG_EARLY_MODE_CONTROL_8812	0x02BC
+#define REG_RSVD5_8812					0x02F0
+#define REG_RSVD6_8812					0x02F4
+#define REG_RSVD7_8812					0x02F8
+#define REG_RSVD8_8812					0x02FC
+
+
+/* -----------------------------------------------------
+*
+*	0x0300h ~ 0x03FFh	PCIe
+*
+* ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8812A			0x0300
+#define	REG_DBI_WDATA_8812			0x0348	/* DBI Write Data */
+#define	REG_DBI_RDATA_8812			0x034C	/* DBI Read Data */
+#define	REG_DBI_ADDR_8812			0x0350	/* DBI Address */
+#define	REG_DBI_FLAG_8812			0x0352	/* DBI Read/Write Flag */
+#define	REG_MDIO_WDATA_8812			0x0354	/* MDIO for Write PCIE PHY */
+#define	REG_MDIO_RDATA_8812			0x0356	/* MDIO for Reads PCIE PHY */
+#define	REG_MDIO_CTL_8812			0x0358	/* MDIO for Control */
+#define REG_PCIE_HRPWM_8812A			0x0361  /* PCIe RPWM */
+#define REG_PCIE_HCPWM_8812A			0x0363  /* PCIe CPWM */
+
+#define	REG_PCIE_MULTIFET_CTRL_8812	0x036A	/* PCIE Multi-Fethc Control */
+
+/* -----------------------------------------------------
+*
+*	0x0400h ~ 0x047Fh	Protocol Configuration
+*
+* ----------------------------------------------------- */
+#define REG_TXPKT_EMPTY_8812A			0x041A
+#define REG_FWHW_TXQ_CTRL_8812A		0x0420
+#define REG_TXBF_CTRL_8812A			0x042C
+#define REG_ARFR0_8812					0x0444
+#define REG_ARFR1_8812					0x044C
+#define REG_CCK_CHECK_8812				0x0454
+#define REG_AMPDU_MAX_TIME_8812		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8812	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8812	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8812	0x045D
+#define REG_NDPA_OPT_CTRL_8812A		0x045F
+#define REG_DATA_SC_8812				0x0483
+#ifdef CONFIG_WOWLAN
+#define REG_TXPKTBUF_IV_LOW             0x0484
+#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_ARFR2_8812					0x048C
+#define REG_ARFR3_8812					0x0494
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_AMPDU_BURST_MODE_8812	0x04BC
+#define REG_HT_SINGLE_AMPDU_8812		0x04C7
+#define REG_MACID_PKT_DROP0_8812		0x04D0
+
+/* -----------------------------------------------------
+*
+*	0x0500h ~ 0x05FFh	EDCA Configuration
+*
+* ----------------------------------------------------- */
+#define REG_TXPAUSE_8812A				0x0522
+#define REG_CTWND_8812					0x0572
+#define REG_SECONDARY_CCA_CTRL_8812	0x0577
+#define REG_SCH_TXCMD_8812A			0x05F8
+
+/* -----------------------------------------------------
+*
+*	0x0600h ~ 0x07FFh	WMAC Configuration
+*
+* ----------------------------------------------------- */
+#define REG_MAC_CR_8812				0x0600
+
+#define REG_MAC_TX_SM_STATE_8812		0x06B4
+
+/* Power */
+#define REG_BFMER0_INFO_8812A			0x06E4
+#define REG_BFMER1_INFO_8812A			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8812A	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8812A	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8812A	0x06FC
+
+/* Hardware Port 2 */
+#define REG_BFMEE_SEL_8812A			0x0714
+#define REG_SND_PTCL_CTRL_8812A		0x0718
+
+
+/* -----------------------------------------------------
+*
+*	Redifine register definition for compatibility
+*
+* ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+* NOTE: DO NOT Remove these definition. Use later. */
+#define	ISR_8812							REG_HISR0_8812
+
+/* ----------------------------------------------------------------------------
+* 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+* ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8812					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8812					BIT31		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8812					BIT30		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8812				BIT29		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8812					BIT28		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8812					BIT27		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8812				BIT26		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8812					BIT25		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8812		BIT24		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8812				BIT20		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8812					BIT16		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8812		BIT15		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8812				BIT14		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8812					BIT12		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8812					BIT10		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8812					BIT9			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8812						BIT8			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8812					BIT7			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8812					BIT6			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8812					BIT5			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8812					BIT4			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8812					BIT3			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8812					BIT2			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8812						BIT1			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8812						BIT0			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_BCNDMAINT7_8812				BIT27		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8812				BIT26		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8812				BIT25		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8812				BIT24		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8812				BIT23		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8812				BIT22		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8812				BIT21		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8812					BIT20		/* Beacon Queue DMA OK Interrup 7 */
+#define	IMR_BCNDOK6_8812					BIT19		/* Beacon Queue DMA OK Interrup 6 */
+#define	IMR_BCNDOK5_8812					BIT18		/* Beacon Queue DMA OK Interrup 5 */
+#define	IMR_BCNDOK4_8812					BIT17		/* Beacon Queue DMA OK Interrup 4 */
+#define	IMR_BCNDOK3_8812					BIT16		/* Beacon Queue DMA OK Interrup 3 */
+#define	IMR_BCNDOK2_8812					BIT15		/* Beacon Queue DMA OK Interrup 2 */
+#define	IMR_BCNDOK1_8812					BIT14		/* Beacon Queue DMA OK Interrup 1 */
+#define	IMR_ATIMEND_E_8812				BIT13		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8812					BIT11		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8812					BIT10		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8812					BIT9			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8812					BIT8			/* Receive FIFO Overflow */
+
+
+#ifdef CONFIG_PCI_HCI
+/* #define IMR_RX_MASK		(IMR_ROK_8812|IMR_RDU_8812|IMR_RXFOVW_8812) */
+#define IMR_TX_MASK			(IMR_VODOK_8812 | IMR_VIDOK_8812 | IMR_BEDOK_8812 | IMR_BKDOK_8812 | IMR_MGNTDOK_8812 | IMR_HIGHDOK_8812)
+
+#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8812 | IMR_TXBCN0OK_8812 | IMR_TXBCN0ERR_8812 | IMR_BCNDERR0_8812)
+
+#define RT_AC_INT_MASKS	(IMR_VIDOK_8812 | IMR_VODOK_8812 | IMR_BEDOK_8812 | IMR_BKDOK_8812)
+#endif
+
+
+/* ****************************************************************************
+* Regsiter Bit and Content definition
+* **************************************************************************** */
+
+/* 2 ACMHWCTRL 0x05C0 */
+#define	AcmHw_HwEn_8812				BIT(0)
+#define	AcmHw_VoqEn_8812				BIT(1)
+#define	AcmHw_ViqEn_8812				BIT(2)
+#define	AcmHw_BeqEn_8812				BIT(3)
+#define	AcmHw_VoqStatus_8812			BIT(5)
+#define	AcmHw_ViqStatus_8812			BIT(6)
+#define	AcmHw_BeqStatus_8812			BIT(7)
+
+#endif /* __RTL8812A_SPEC_H__ */
+
+#ifdef CONFIG_RTL8821A
+#include "rtl8821a_spec.h"
+#endif /* CONFIG_RTL8821A */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_sreset.h
index 53f39d762095..309ada941815 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_sreset.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL88812A_SRESET_H_
 #define _RTL8812A_SRESET_H_
 
@@ -27,4 +23,3 @@ extern void rtl8812_sreset_xmit_status_check(_adapter *padapter);
 extern void rtl8812_sreset_linked_status_check(_adapter *padapter);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_xmit.h
index 42e1a8895c7f..790317bd975d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8812a_xmit.h
@@ -1,365 +1,368 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8812A_XMIT_H__
-#define __RTL8812A_XMIT_H__
-
-
-//For 88e early mode
-#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
-#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
-#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
-#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
-#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
-#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
-#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
-
-//
-//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 QSEL_SHT			8
-#define RATE_ID_SHT			16
-#define NAVUSEHDR			BIT(20)
-#define SEC_TYPE_SHT 		22
-#define PKT_OFFSET_SHT		26
-
-//OFFSET 8
-#define AGG_EN				BIT(12)
-#define AGG_BK				BIT(16)
-#define AMPDU_DENSITY_SHT	20
-#define ANTSEL_A			BIT(24)
-#define ANTSEL_B			BIT(25)
-#define TX_ANT_CCK_SHT		26
-#define TX_ANTL_SHT			28
-#define TX_ANT_HT_SHT		30
-
-//OFFSET 12
-#define SEQ_SHT				16
-#define EN_HWSEQ			BIT(31)
-
-//OFFSET 16
-#define QOS					BIT(6)
-#define	HW_SSN				BIT(7)
-#define USERATE				BIT(8)
-#define DISDATAFB			BIT(10)
-#define CTS_2_SELF			BIT(11)
-#define	RTS_EN				BIT(12)
-#define	HW_RTS_EN			BIT(13)
-#define DATA_SHORT			BIT(24)
-#define PWR_STATUS_SHT	15
-#define DATA_SC_SHT		20
-#define DATA_BW				BIT(25)
-
-//OFFSET 20
-#define	RTY_LMT_EN			BIT(17)
-
-//OFFSET 20
-#define SGI					BIT(6)
-#define USB_TXAGG_NUM_SHT	24
-
-typedef struct txdescriptor_8812
-{
-	// Offset 0
-	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;
-
-	// Offset 4
-	u32 macid:6;
-	u32 rsvd0406:2;	
-	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;
-
-	// Offset 8
-	u32 rts_rc:6;
-	u32 data_rc:6;
-	u32 agg_en:1;
-	u32 rd_en:1;
-	u32 bar_rty_th:2;
-	u32 bk: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;
-
-	// Offset 12
-	u32 nextheadpage:8;
-	u32 tailpage:8;
-	u32 seq:12;
-	u32 cpu_handle:1;
-	u32 tag1:1;
-	u32 trigger_int:1;
-	u32 hwseq_en:1;
-
-	// Offset 16
-	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 pwr_status: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;
-
-	// Offset 20
-	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;
-
-	// Offset 24
-	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;
-
-	// Offset 28
-	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;
-
-	// Offset 32
-	u32 rsvd32;
-
-	// Offset 36
-	u32 rsvd36;
-}TXDESC_8812, *PTXDESC_8812; 
-
-
-// Dword 0
-#define GET_TX_DESC_OWN_8812(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
-#define SET_TX_DESC_PKT_SIZE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
-#define SET_TX_DESC_OFFSET_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
-#define SET_TX_DESC_BMC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
-#define SET_TX_DESC_HTC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
-#define SET_TX_DESC_LAST_SEG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
-#define SET_TX_DESC_FIRST_SEG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
-#define SET_TX_DESC_LINIP_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
-#define SET_TX_DESC_NO_ACM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
-#define SET_TX_DESC_GF_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
-#define SET_TX_DESC_OWN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
-
-// Dword 1
-#define SET_TX_DESC_MACID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
-#define SET_TX_DESC_QUEUE_SEL_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
-#define SET_TX_DESC_RDG_NAV_EXT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
-#define SET_TX_DESC_LSIG_TXOP_EN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
-#define SET_TX_DESC_PIFS_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
-#define SET_TX_DESC_RATE_ID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
-#define SET_TX_DESC_EN_DESC_ID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
-#define SET_TX_DESC_SEC_TYPE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
-#define SET_TX_DESC_PKT_OFFSET_8812(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
-
-// Dword 2
-#define SET_TX_DESC_PAID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value) 
-#define SET_TX_DESC_CCA_RTS_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
-#define SET_TX_DESC_AGG_ENABLE_8812(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
-#define SET_TX_DESC_RDG_ENABLE_8812(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
-#define SET_TX_DESC_AGG_BREAK_8812(__pTxDesc, __Value) 				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
-#define SET_TX_DESC_MORE_FRAG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
-#define SET_TX_DESC_RAW_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
-#define SET_TX_DESC_SPE_RPT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
-#define SET_TX_DESC_AMPDU_DENSITY_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
-#define SET_TX_DESC_BT_INT_8812(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
-#define SET_TX_DESC_GID_8812(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
-
-// Dword 3
-#define SET_TX_DESC_WHEADER_LEN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
-#define SET_TX_DESC_CHK_EN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
-#define SET_TX_DESC_EARLY_MODE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
-#define SET_TX_DESC_HWSEQ_SEL_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
-#define SET_TX_DESC_USE_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
-#define SET_TX_DESC_DISABLE_RTS_FB_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
-#define SET_TX_DESC_DISABLE_FB_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
-#define SET_TX_DESC_CTS2SELF_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
-#define SET_TX_DESC_RTS_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
-#define SET_TX_DESC_HW_RTS_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
-#define SET_TX_DESC_NAV_USE_HDR_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
-#define SET_TX_DESC_USE_MAX_LEN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
-#define SET_TX_DESC_MAX_AGG_NUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
-#define SET_TX_DESC_NDPA_8812(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
-#define SET_TX_DESC_AMPDU_MAX_TIME_8812(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
-
-// Dword 4
-#define SET_TX_DESC_TX_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
-#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
-#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
-#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
-#define SET_TX_DESC_DATA_RETRY_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
-#define SET_TX_DESC_RTS_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
-
-// Dword 5
-#define SET_TX_DESC_DATA_SC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
-#define SET_TX_DESC_DATA_SHORT_8812(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
-#define SET_TX_DESC_DATA_BW_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
-#define SET_TX_DESC_DATA_LDPC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
-#define SET_TX_DESC_DATA_STBC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
-#define SET_TX_DESC_CTROL_STBC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
-#define SET_TX_DESC_RTS_SHORT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
-#define SET_TX_DESC_RTS_SC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
-#define SET_TX_DESC_TX_ANT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
-
-// Dword 6
-#define SET_TX_DESC_SW_DEFINE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
-#define SET_TX_DESC_ANTSEL_A_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
-#define SET_TX_DESC_ANTSEL_B_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
-#define SET_TX_DESC_ANTSEL_C_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
-#define SET_TX_DESC_ANTSEL_D_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
-#define SET_TX_DESC_MBSSID_8821(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
-
-// Dword 7 
-#define SET_TX_DESC_TX_BUFFER_SIZE_8812(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#define SET_TX_DESC_TX_DESC_CHECKSUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#define SET_TX_DESC_USB_TXAGG_NUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value) 
-#ifdef CONFIG_SDIO_HCI
-#define SET_TX_DESC_SDIO_TXSEQ_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
-#endif
-
-// Dword 8
-#define SET_TX_DESC_HWSEQ_EN_8812(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
-
-// Dword 9
-#define SET_TX_DESC_SEQ_8812(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
-
-// Dword 10
-#define SET_TX_DESC_TX_BUFFER_ADDRESS_8812(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
-#define GET_TX_DESC_TX_BUFFER_ADDRESS_8812(__pTxDesc) 	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
-
-// Dword 11
-#define SET_TX_DESC_NEXT_DESC_ADDRESS_8812(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
-
-
-#define SET_EARLYMODE_PKTNUM_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
-#define SET_EARLYMODE_LEN0_8812(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
-#define SET_EARLYMODE_LEN1_1_8812(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
-#define SET_EARLYMODE_LEN1_2_8812(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
-#define SET_EARLYMODE_LEN2_8812(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
-#define SET_EARLYMODE_LEN3_8812(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
-
-#ifdef CONFIG_TX_EARLY_MODE
-#define USB_DUMMY_OFFSET		2
-#else
-#define USB_DUMMY_OFFSET		1
-#endif
-#define USB_DUMMY_LENGTH		(USB_DUMMY_OFFSET * PACKET_OFFSET_SZ)
-
-
-void rtl8812a_cal_txdesc_chksum(u8 *ptxdesc);
-void rtl8812a_fill_fake_txdesc(PADAPTER	padapter,u8*pDesc,u32 BufferLen,u8 IsPsPoll,u8	IsBTQosNull, u8 bDataFrame);
-void rtl8812a_fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
-void rtl8812a_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
-void rtl8812a_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
-
-#ifdef CONFIG_USB_HCI
-s32 rtl8812au_init_xmit_priv(PADAPTER padapter);
-void rtl8812au_free_xmit_priv(PADAPTER padapter);
-s32 rtl8812au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8812au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	 rtl8812au_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-s32 rtl8812au_xmit_buf_handler(PADAPTER padapter);
-void rtl8812au_xmit_tasklet(void *priv);
-s32 rtl8812au_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8812ae_init_xmit_priv(PADAPTER padapter);
-void rtl8812ae_free_xmit_priv(PADAPTER padapter);
-struct xmit_buf *rtl8812ae_dequeue_xmitbuf(struct rtw_tx_ring *ring);
-void	rtl8812ae_xmitframe_resume(_adapter *padapter);
-s32 rtl8812ae_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8812ae_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8812ae_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-void rtl8812ae_xmit_tasklet(void *priv);
-#endif
-
-#ifdef CONFIG_TX_EARLY_MODE
-void UpdateEarlyModeInfo8812(struct xmit_priv *pxmitpriv,struct xmit_buf *pxmitbuf );
-#endif
-
-void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag,u8 *ptxdesc);
-
-u8	BWMapping_8812(PADAPTER Adapter, struct pkt_attrib *pattrib);
-
-u8	SCMapping_8812(PADAPTER Adapter, struct pkt_attrib	*pattrib);
-
-#endif //__RTL8812_XMIT_H__
-
-#ifdef CONFIG_RTL8821A
-#include "rtl8821a_xmit.h"
-#endif // CONFIG_RTL8821A
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812A_XMIT_H__
+#define __RTL8812A_XMIT_H__
+
+
+/* For 88e early mode */
+#define SET_EARLYMODE_PKTNUM(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 0, 3, __Value)
+#define SET_EARLYMODE_LEN0(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 4, 12, __Value)
+#define SET_EARLYMODE_LEN1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 16, 12, __Value)
+#define SET_EARLYMODE_LEN2_1(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr, 28, 4, __Value)
+#define SET_EARLYMODE_LEN2_2(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 8, __Value)
+#define SET_EARLYMODE_LEN3(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 8, 12, __Value)
+#define SET_EARLYMODE_LEN4(__pAddr, __Value) SET_BITS_TO_LE_4BYTE(__pAddr+4, 20, 12, __Value)
+
+/*
+ * 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 QSEL_SHT			8
+#define RATE_ID_SHT			16
+#define NAVUSEHDR			BIT(20)
+#define SEC_TYPE_SHT		22
+#define PKT_OFFSET_SHT		26
+
+/* OFFSET 8 */
+#define AGG_EN				BIT(12)
+#define AGG_BK				BIT(16)
+#define AMPDU_DENSITY_SHT	20
+#define ANTSEL_A			BIT(24)
+#define ANTSEL_B			BIT(25)
+#define TX_ANT_CCK_SHT		26
+#define TX_ANTL_SHT			28
+#define TX_ANT_HT_SHT		30
+
+/* OFFSET 12 */
+#define SEQ_SHT				16
+#define EN_HWSEQ			BIT(31)
+
+/* OFFSET 16 */
+#define QOS					BIT(6)
+#define	HW_SSN				BIT(7)
+#define USERATE				BIT(8)
+#define DISDATAFB			BIT(10)
+#define CTS_2_SELF			BIT(11)
+#define	RTS_EN				BIT(12)
+#define	HW_RTS_EN			BIT(13)
+#define DATA_SHORT			BIT(24)
+#define PWR_STATUS_SHT	15
+#define DATA_SC_SHT		20
+#define DATA_BW				BIT(25)
+
+/* OFFSET 20 */
+#define	RTY_LMT_EN			BIT(17)
+
+/* OFFSET 20 */
+#define SGI					BIT(6)
+#define USB_TXAGG_NUM_SHT	24
+
+typedef struct txdescriptor_8812 {
+	/* Offset 0 */
+	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;
+
+	/* Offset 4 */
+	u32 macid:6;
+	u32 rsvd0406:2;
+	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;
+
+	/* Offset 8 */
+	u32 rts_rc:6;
+	u32 data_rc:6;
+	u32 agg_en:1;
+	u32 rd_en:1;
+	u32 bar_rty_th:2;
+	u32 bk: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;
+
+	/* Offset 12 */
+	u32 nextheadpage:8;
+	u32 tailpage:8;
+	u32 seq:12;
+	u32 cpu_handle:1;
+	u32 tag1:1;
+	u32 trigger_int:1;
+	u32 hwseq_en:1;
+
+	/* Offset 16 */
+	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 pwr_status: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;
+
+	/* Offset 20 */
+	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;
+
+	/* Offset 24 */
+	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;
+
+	/* Offset 28 */
+	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;
+
+	/* Offset 32 */
+	u32 rsvd32;
+
+	/* Offset 36 */
+	u32 rsvd36;
+} TXDESC_8812, *PTXDESC_8812;
+
+
+/* Dword 0 */
+#define GET_TX_DESC_OWN_8812(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+#define SET_TX_DESC_PKT_SIZE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_LAST_SEG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+#define SET_TX_DESC_FIRST_SEG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_LINIP_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+#define SET_TX_DESC_OWN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+
+/* Dword 2 */
+#define SET_TX_DESC_PAID_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+#define SET_TX_DESC_CCA_RTS_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_AGG_BREAK_8812(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_SPE_RPT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_INT_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_GID_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+
+/* Dword 3 */
+#define SET_TX_DESC_WHEADER_LEN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 4, __Value)
+#define SET_TX_DESC_CHK_EN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 4, 1, __Value)
+#define SET_TX_DESC_EARLY_MODE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HWSEQ_SEL_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8812(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_CTROL_STBC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_TX_ANT_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_ANTSEL_A_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+#define SET_TX_DESC_ANTSEL_B_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+#define SET_TX_DESC_ANTSEL_C_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 3, __Value)
+#define SET_TX_DESC_ANTSEL_D_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
+#define SET_TX_DESC_MBSSID_8821(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+
+/* Dword 7 */
+#define SET_TX_DESC_TX_BUFFER_SIZE_8812(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#define SET_TX_DESC_TX_DESC_CHECKSUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#define SET_TX_DESC_USB_TXAGG_NUM_8812(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+#ifdef CONFIG_SDIO_HCI
+#define SET_TX_DESC_SDIO_TXSEQ_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+#endif
+
+/* Dword 8 */
+#define SET_TX_DESC_HWSEQ_EN_8812(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_SEQ_8812(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+
+/* Dword 10 */
+#define SET_TX_DESC_TX_BUFFER_ADDRESS_8812(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+#define GET_TX_DESC_TX_BUFFER_ADDRESS_8812(__pTxDesc)	LE_BITS_TO_4BYTE(__pTxDesc+40, 0, 32)
+
+/* Dword 11 */
+#define SET_TX_DESC_NEXT_DESC_ADDRESS_8812(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 32, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
+#define SET_EARLYMODE_LEN3_8812(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+#ifdef CONFIG_TX_EARLY_MODE
+	#define USB_DUMMY_OFFSET		2
+#else
+	#define USB_DUMMY_OFFSET		1
+#endif
+#define USB_DUMMY_LENGTH		(USB_DUMMY_OFFSET * PACKET_OFFSET_SZ)
+
+
+void rtl8812a_cal_txdesc_chksum(u8 *ptxdesc);
+void rtl8812a_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8812a_fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8812a_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8812a_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#ifdef CONFIG_USB_HCI
+s32 rtl8812au_init_xmit_priv(PADAPTER padapter);
+void rtl8812au_free_xmit_priv(PADAPTER padapter);
+s32 rtl8812au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8812au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	 rtl8812au_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+s32 rtl8812au_xmit_buf_handler(PADAPTER padapter);
+void rtl8812au_xmit_tasklet(void *priv);
+s32 rtl8812au_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8812ae_init_xmit_priv(PADAPTER padapter);
+void rtl8812ae_free_xmit_priv(PADAPTER padapter);
+struct xmit_buf *rtl8812ae_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+void	rtl8812ae_xmitframe_resume(_adapter *padapter);
+s32 rtl8812ae_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8812ae_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	rtl8812ae_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+void rtl8812ae_xmit_tasklet(void *priv);
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+s32 rtl8812ae_xmit_buf_handler(_adapter *padapter);
+#endif
+
+#endif
+
+#ifdef CONFIG_TX_EARLY_MODE
+void UpdateEarlyModeInfo8812(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif
+
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, u8 *ptxdesc);
+
+u8	BWMapping_8812(PADAPTER Adapter, struct pkt_attrib *pattrib);
+
+u8	SCMapping_8812(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif /* __RTL8812_XMIT_H__ */
+
+#ifdef CONFIG_RTL8821A
+#include "rtl8821a_xmit.h"
+#endif /* CONFIG_RTL8821A */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_cmd.h
index 6f9cdc2e35be..b8a5dce6ae9f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_cmd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,36 +12,32 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8814A_CMD_H__
 #define __RTL8814A_CMD_H__
 #include "hal_com_h2c.h"
 
-//_RSVDPAGE_LOC_CMD0
+/* _RSVDPAGE_LOC_CMD0 */
 #define SET_8814A_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8814A_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_8814A_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8814A_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8814A_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 
-//_SETPWRMODE_PARM
+/* _SETPWRMODE_PARM */
 #define SET_8814A_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8814A_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8814A_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
 
-// _WoWLAN PARAM_CMD5
+/* _WoWLAN PARAM_CMD5 */
 #define SET_8814A_H2CCMD_WOWLAN_FUNC_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8814A_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8814A_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
@@ -53,25 +50,25 @@
 #define SET_8814A_H2CCMD_WOWLAN_GPIO_DURATION(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 
 
-//WLANINFO_PARM
+/* WLANINFO_PARM */
 #define SET_8814A_H2CCMD_WLANINFO_PARM_OPMODE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8814A_H2CCMD_WLANINFO_PARM_CHANNEL(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_8814A_H2CCMD_WLANINFO_PARM_BW40MHZ(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 
-// _REMOTE_WAKEUP_CMD7
+/* _REMOTE_WAKEUP_CMD7 */
 #define SET_8814A_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
 #define SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
 
 
-// _AP_OFFLOAD_CMD8
+/* _AP_OFFLOAD_CMD8 */
 #define SET_8814A_H2CCMD_AP_OFFLOAD_ON(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_8814A_H2CCMD_AP_OFFLOAD_HIDDEN(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 #define SET_8814A_H2CCMD_AP_OFFLOAD_DENYANY(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
 #define SET_8814A_H2CCMD_AP_OFFLOAD_WAKEUP_EVT_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 
-// _PWR_MOD_CMD20
+/* _PWR_MOD_CMD20 */
 #define SET_88E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_88E_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
 #define SET_88E_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
@@ -79,6 +76,30 @@
 #define SET_88E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_88E_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
 
+/*	AP_REQ_TXREP_CMD 0x43	*/
+#define SET_8814A_H2CCMD_TXREP_PARM_STA1(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8814A_H2CCMD_TXREP_PARM_STA2(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8814A_H2CCMD_TXREP_PARM_RTY(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 2, __Value)
+
+/*		C2H_AP_REQ_TXRPT		*/
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_MACID1(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 8)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXOK1(_Header)			LE_BITS_TO_2BYTE((_Header + 1), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXFAIL1(_Header)			LE_BITS_TO_2BYTE((_Header + 3), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_INIRATE1(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_MACID2(_Header)			LE_BITS_TO_1BYTE((_Header + 6), 0, 8)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXOK2(_Header)			LE_BITS_TO_2BYTE((_Header + 7), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_TXFAIL2(_Header)			LE_BITS_TO_2BYTE((_Header + 9), 0, 16)
+#define	GET_8814A_C2H_TC2H_APREQ_TXRPT_INIRATE2(_Header)		LE_BITS_TO_1BYTE((_Header + 11), 0, 8)
+
+/*		C2H_SPC_STAT			*/
+#define	GET_8814A_C2H_SPC_STAT_IDX(_Header)						LE_BITS_TO_1BYTE((_Header + 0), 0, 8)
+	/*	Tip :TYPE_A data3 is msb and data0 is lsb	*/
+#define	GET_8814A_C2H_SPC_STAT_TYPEA_RETRY(_Header)				LE_BITS_TO_4BYTE((_Header + 1), 0, 32)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_PKT1(_Header)				LE_BITS_TO_2BYTE((_Header + 1), 0, 16)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_RETRY1(_Header)			LE_BITS_TO_2BYTE((_Header + 3), 0, 16)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_PKT2(_Header)				LE_BITS_TO_2BYTE((_Header + 5), 0, 16)
+#define	GET_8814A_C2H_SPC_STAT_TYPEB_RETRY2(_Header)			LE_BITS_TO_2BYTE((_Header + 7), 0, 16)
+
 /*BCNHWSEQ*/
 #define SET_8814A_H2CCMD_BCNHWSEQ_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 0, 1, __Value)
 #define SET_8814A_H2CCMD_BCNHWSEQ_BCN_NUMBER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd), 1, 3, __Value)
@@ -87,14 +108,14 @@
 #define SET_8814A_H2CCMD_BCNHWSEQ_PAGE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 void rtl8814_fw_update_beacon_cmd(_adapter *padapter);
 
-// TX Beamforming
+/* TX Beamforming */
 #define GET_8814A_C2H_TXBF_ORIGINATE(_Header)			LE_BITS_TO_1BYTE(_Header, 0, 8)
 #define GET_8814A_C2H_TXBF_MACID(_Header)				LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
 
 
 
-/// TX Feedback Content
-#define 	USEC_UNIT_FOR_8814A_C2H_TX_RPT_QUEUE_TIME			256
+/* / TX Feedback Content */
+#define	USEC_UNIT_FOR_8814A_C2H_TX_RPT_QUEUE_TIME			256
 
 #define	GET_8814A_C2H_TX_RPT_QUEUE_SELECT(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 0, 5)
 #define	GET_8814A_C2H_TX_RPT_PKT_BROCAST(_Header)			LE_BITS_TO_1BYTE((_Header + 0), 5, 1)
@@ -102,11 +123,11 @@ void rtl8814_fw_update_beacon_cmd(_adapter *padapter);
 #define	GET_8814A_C2H_TX_RPT_RETRY_OVER(_Header)				LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
 #define	GET_8814A_C2H_TX_RPT_MAC_ID(_Header)					LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
 #define	GET_8814A_C2H_TX_RPT_DATA_RETRY_CNT(_Header)		LE_BITS_TO_1BYTE((_Header + 2), 0, 6)
-#define	GET_8814A_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	// In unit of 256 microseconds.
+#define	GET_8814A_C2H_TX_RPT_QUEUE_TIME(_Header)				LE_BITS_TO_2BYTE((_Header + 3), 0, 16)	/* In unit of 256 microseconds. */
 #define	GET_8814A_C2H_TX_RPT_FINAL_DATA_RATE(_Header)		LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
 
 
-//_P2P_PS_OFFLOAD
+/* _P2P_PS_OFFLOAD */
 #define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ENABLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ROLE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
 #define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
@@ -116,38 +137,29 @@ void rtl8814_fw_update_beacon_cmd(_adapter *padapter);
 #define SET_8814A_H2CCMD_P2P_PS_OFFLOAD_DISCOVERY(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 6, 1, __Value)
 
 s32 FillH2CCmd_8814(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
-void rtl8814_set_raid_cmd(PADAPTER padapter, u64 bitmap, u8* arg);
-void rtl8814_Add_RateATid(PADAPTER padapter, u64 rate_bitmap, u8 *arg, u8 rssi_level);
-void rtl8814_set_wowlan_cmd(_adapter* padapter, u8 enable);
+void rtl8814_set_wowlan_cmd(_adapter *padapter, u8 enable);
 void rtl8814_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
 void rtl8814_set_FwPwrMode_cmd(PADAPTER padapter, u8 PSMode);
 u8 GetTxBufferRsvdPageNum8814(_adapter *padapter, bool wowlan);
-u8 rtl8814_set_rssi_cmd(_adapter*padapter, u8 *param);
+u8 rtl8814_set_rssi_cmd(_adapter *padapter, u8 *param);
+void rtl8814_req_txrpt_cmd(PADAPTER padapter, u8 macid);
+
+#ifdef CONFIG_TDLS
+	#ifdef CONFIG_TDLS_CH_SW
+		void rtl8814_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+	#endif
+#endif
 
 void
 Set_RA_LDPC_8814(
 	struct sta_info	*psta,
 	BOOLEAN			bLDPC
-	);
-int rtl8814_iqk_wait(_adapter* padapter, u32 timeout_ms);
-void rtl8814_iqk_done(_adapter* padapter);
-VOID
-C2HPacketHandler_8814(
-	IN	PADAPTER	Adapter,
-	IN	u8			*Buffer,
-	IN	u8			Length
-	);
-#ifdef CONFIG_P2P_PS
-void rtl8814_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
-#endif //CONFIG_P2P
-
-s32
-_C2HContentParsing8814(
-	IN	PADAPTER	Adapter,
-	IN	u8			c2hCmdId, 
-	IN	u8			c2hCmdLen,
-	IN	u8 			*tmpBuf
 );
 
-#endif/* __RTL8814A_CMD_H__ */
+s32 c2h_handler_8814a(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
+
+#ifdef CONFIG_P2P_PS
+	void rtl8814_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
 
+#endif/* __RTL8814A_CMD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_dm.h
index 48837700efe1..ba749723e813 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8814A_DM_H__
 #define __RTL8814A_DM_H__
 
@@ -25,10 +21,4 @@ void rtl8814_deinit_dm_priv(IN PADAPTER Adapter);
 void rtl8814_InitHalDm(IN PADAPTER Adapter);
 void rtl8814_HalDmWatchDog(IN PADAPTER Adapter);
 
-#ifdef CONFIG_ANTENNA_DIVERSITY
-void AntDivCompare8814(PADAPTER Adapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
-u8 AntDivBeforeLink8814(PADAPTER Adapter );
-#endif //CONFIG_ANTENNA_DIVERSITY
-
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_hal.h
index 842ddc69722a..26d24bef33d4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_hal.h
@@ -1,341 +1,331 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8814A_HAL_H__
-#define __RTL8814A_HAL_H__
-
-//#include "hal_com.h"
-#include "hal_data.h"
-
-//include HAL Related header after HAL Related compiling flags 
-#include "rtl8814a_spec.h"
-#include "rtl8814a_rf.h"
-#include "rtl8814a_dm.h"
-#include "rtl8814a_recv.h"
-#include "rtl8814a_xmit.h"
-#include "rtl8814a_cmd.h"
-#include "rtl8814a_led.h"
-#include "Hal8814PwrSeq.h"
-#include "Hal8814PhyReg.h"
-#include "Hal8814PhyCfg.h"
-#ifdef DBG_CONFIG_ERROR_DETECT
-#include "rtl8814a_sreset.h"
-#endif //DBG_CONFIG_ERROR_DETECT
-
-
-typedef enum _TX_PWR_PERCENTAGE{
-	TX_PWR_PERCENTAGE_0 = 0x01, // 12.5%
-	TX_PWR_PERCENTAGE_1 = 0x02, // 25%
-	TX_PWR_PERCENTAGE_2 = 0x04, // 50%
-	TX_PWR_PERCENTAGE_3 = 0x08, //100%, default target output power.	
-} TX_PWR_PERCENTAGE;
-
-
-enum{
-		VOLTAGE_V25						= 0x03,
-		LDOE25_SHIFT					= 28 ,
-	};
-/* max. iram is 64k , max dmen is 32k. Total = 96k = 0x18000*/
-#define FW_SIZE							0x18000
-#define FW_START_ADDRESS   0x1000
-typedef struct _RT_FIRMWARE_8814 {
-	FIRMWARE_SOURCE	eFWSource;
-#ifdef CONFIG_EMBEDDED_FWIMG
-	u8*			szFwBuffer;
-#else
-	u8			szFwBuffer[FW_SIZE];
-#endif
-	u32			ulFwLength;
-} RT_FIRMWARE_8814, *PRT_FIRMWARE_8814;
-
-#define PAGE_SIZE_TX_8814	PAGE_SIZE_128
-#define BCNQ_PAGE_NUM_8814		0x08
-
-//---------------------------------------------------------------------
-//		RTL8814AU From header
-//---------------------------------------------------------------------
-		#define RTL8814A_FW_IMG					"rtl8814a/FW_NIC.bin"
-		#define RTL8814A_FW_WW_IMG				"rtl8814a/FW_WoWLAN.bin"
-		#define RTL8814A_PHY_REG					"rtl8814a/PHY_REG.txt" 
-		#define RTL8814A_PHY_RADIO_A				"rtl8814a/RadioA.txt"
-		#define RTL8814A_PHY_RADIO_B				"rtl8814a/RadioB.txt"
-		#define RTL8814A_PHY_RADIO_C				"rtl8814a/RadioC.txt"
-		#define RTL8814A_PHY_RADIO_D				"rtl8814a/RadioD.txt"
-		#define RTL8814A_TXPWR_TRACK				"rtl8814a/TxPowerTrack.txt"			
-		#define RTL8814A_AGC_TAB					"rtl8814a/AGC_TAB.txt"
-		#define RTL8814A_PHY_MACREG 				"rtl8814a/MAC_REG.txt"
-		#define RTL8814A_PHY_REG_PG				"rtl8814a/PHY_REG_PG.txt"
-		#define RTL8814A_PHY_REG_MP 				"rtl8814a/PHY_REG_MP.txt" 
-		#define RTL8814A_TXPWR_LMT				"rtl8814a/TXPWR_LMT.txt" 
-		#define RTL8814A_WIFI_ANT_ISOLATION		"rtl8814a/wifi_ant_isolation.txt"
-
-#define Rtl8814A_NIC_PWR_ON_FLOW				rtl8814A_power_on_flow
-#define Rtl8814A_NIC_RF_OFF_FLOW				rtl8814A_radio_off_flow
-#define Rtl8814A_NIC_DISABLE_FLOW				rtl8814A_card_disable_flow
-#define Rtl8814A_NIC_ENABLE_FLOW				rtl8814A_card_enable_flow
-#define Rtl8814A_NIC_SUSPEND_FLOW				rtl8814A_suspend_flow
-#define Rtl8814A_NIC_RESUME_FLOW				rtl8814A_resume_flow
-#define Rtl8814A_NIC_PDN_FLOW					rtl8814A_hwpdn_flow
-#define Rtl8814A_NIC_LPS_ENTER_FLOW			rtl8814A_enter_lps_flow
-#define Rtl8814A_NIC_LPS_LEAVE_FLOW			rtl8814A_leave_lps_flow	
-
-//=====================================================
-//				New	Firmware Header(8-byte alinment required)
-//=====================================================
-//--- LONG WORD 0 ----
-#define GET_FIRMWARE_HDR_SIGNATURE_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16) 
-#define GET_FIRMWARE_HDR_CATEGORY_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) // AP/NIC and USB/PCI
-#define GET_FIRMWARE_HDR_FUNCTION_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr, 24, 8) // Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions
-#define GET_FIRMWARE_HDR_VERSION_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)// FW Version
-#define GET_FIRMWARE_HDR_SUB_VER_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) // FW Subversion, default 0x00
-#define GET_FIRMWARE_HDR_SUB_IDX_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8) // FW Subversion Index
-
-//--- LONG WORD 1 ----
-#define GET_FIRMWARE_HDR_SVN_IDX_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 32)// The SVN entry index
-#define GET_FIRMWARE_HDR_RSVD1_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 0, 32)
-
-//--- LONG WORD 2 ----
-#define GET_FIRMWARE_HDR_MONTH_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 0, 8) // Release time Month field
-#define GET_FIRMWARE_HDR_DATE_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+16, 8, 8) // Release time Date field
-#define GET_FIRMWARE_HDR_HOUR_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+16, 16, 8)// Release time Hour field
-#define GET_FIRMWARE_HDR_MINUTE_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 24, 8)// Release time Minute field
-#define GET_FIRMWARE_HDR_YEAR_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+20, 0, 16)// Release time Year field
-#define GET_FIRMWARE_HDR_FOUNDRY_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 16, 8)// Release time Foundry field
-#define GET_FIRMWARE_HDR_RSVD2_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 24, 8)
-
-//--- LONG WORD 3 ----
-#define GET_FIRMWARE_HDR_MEM_UASGE_DL_FROM_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+24, 0, 1)
-#define GET_FIRMWARE_HDR_MEM_UASGE_BOOT_FROM_3081(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+24, 1, 1)
-#define GET_FIRMWARE_HDR_MEM_UASGE_BOOT_LOADER_3081(__FwHdr)LE_BITS_TO_4BYTE(__FwHdr+24, 2, 1)
-#define GET_FIRMWARE_HDR_MEM_UASGE_IRAM_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 3, 1)
-#define GET_FIRMWARE_HDR_MEM_UASGE_ERAM_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 4, 1)
-#define GET_FIRMWARE_HDR_MEM_UASGE_RSVD4_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+24, 5, 3)
-#define GET_FIRMWARE_HDR_RSVD3_3081(__FwHdr)					LE_BITS_TO_4BYTE(__FwHdr+24, 8, 8)
-#define GET_FIRMWARE_HDR_BOOT_LOADER_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 16, 16)
-#define GET_FIRMWARE_HDR_RSVD5_3081(__FwHdr)					LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
-
-//--- LONG WORD 4 ----
-#define GET_FIRMWARE_HDR_TOTAL_DMEM_SZ_3081(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+36, 0, 32)
-#define GET_FIRMWARE_HDR_FW_CFG_SZ_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+36, 0, 16)
-#define GET_FIRMWARE_HDR_FW_ATTR_SZ_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+36, 16, 16)
-
-//--- LONG WORD 5 ----
-#define GET_FIRMWARE_HDR_IROM_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+40, 0, 32)
-#define GET_FIRMWARE_HDR_EROM_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+44, 0, 32)
-
-//--- LONG WORD 6 ----
-#define GET_FIRMWARE_HDR_IRAM_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+48, 0, 32)
-#define GET_FIRMWARE_HDR_ERAM_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+52, 0, 32)
-
-//--- LONG WORD 7 ----
-#define GET_FIRMWARE_HDR_RSVD6_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+56, 0, 32)
-#define GET_FIRMWARE_HDR_RSVD7_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+60, 0, 32)
-
-
-
-//
-// 2013/08/16 MH MOve from SDIO.h for common use.
-//
-#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
-#define TRX_SHARE_MODE_8814A				0	//TRX Buffer Share Index
-#define BASIC_RXFF_SIZE_8814A				24576//Basic RXFF Size is 24K = 24*1024 Unit: Byte
-#define TRX_SHARE_BUFF_UNIT_8814A			65536//TRX Share Buffer unit Size 64K = 64*1024 Unit: Byte
-#define TRX_SHARE_BUFF_UNIT_PAGE_8814A	TRX_SHARE_BUFF_UNIT_8814A/PAGE_SIZE_8814A//512 Pages
-
-//Origin: 
-#define  HPQ_PGNUM_8814A	 				0x20	//High Queue
-#define  LPQ_PGNUM_8814A	 				0x20	//Low Queue
-#define  NPQ_PGNUM_8814A	 				0x20	//Normal Queue
-#define  EPQ_PGNUM_8814A	 				0x20	//Extra Queue
-
-#else	// #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
-
-#define  HPQ_PGNUM_8814A		20
-#define  NPQ_PGNUM_8814A		20
-#define  LPQ_PGNUM_8814A		20 //1972
-#define  EPQ_PGNUM_8814A		20
-#define  BCQ_PGNUM_8814A		32
-
-#endif //#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
-
-#ifdef CONFIG_WOWLAN
-#define WOWLAN_PAGE_NUM_8814	0x00
-#else
-#define WOWLAN_PAGE_NUM_8814	0x00
-#endif
-
-#define PAGE_SIZE_8814A						128//TXFF Page Size, Unit: Byte
-#define MAX_RX_DMA_BUFFER_SIZE_8814A		0x5C00	//BASIC_RXFF_SIZE_8814A+TRX_SHARE_MODE_8814A*TRX_SHARE_BUFF_UNIT_8814A //Basic RXFF Size + ShareBuffer Size
-#define TX_PAGE_BOUNDARY_8814A			TXPKT_PGNUM_8814A	// Need to enlarge boundary, by KaiYuan
-#define TX_PAGE_BOUNDARY_WOWLAN_8814A	TXPKT_PGNUM_8814A	//TODO: 20130415 KaiYuan Check this value later
-
-
-#define  TOTAL_PGNUM_8814A		2048
-#define  TXPKT_PGNUM_8814A		(2048 - BCNQ_PAGE_NUM_8814-WOWLAN_PAGE_NUM_8814)
-#define  PUB_PGNUM_8814A		(TXPKT_PGNUM_8814A-HPQ_PGNUM_8814A-NPQ_PGNUM_8814A-LPQ_PGNUM_8814A-EPQ_PGNUM_8814A)
-
-//Note: For WMM Normal Chip Setting ,modify later
-#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8814A	TX_PAGE_BOUNDARY_8814A
-#define WMM_NORMAL_TX_PAGE_BOUNDARY_8814A		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8814A + 1)
-
-#define DRIVER_EARLY_INT_TIME_8814		0x05
-#define BCN_DMA_ATIME_INT_TIME_8814		0x02
-
-
-#define MAX_PAGE_SIZE			4096	// @ page : 4k bytes
-
-#define EFUSE_MAX_SECTION_JAGUAR				64
-
-#define	HWSET_MAX_SIZE_8814A			512
-
-#define	EFUSE_REAL_CONTENT_LEN_8814A	1024
-#define	EFUSE_MAX_BANK_8814A		2
-
-#define	EFUSE_MAP_LEN_8814A			512
-#define	EFUSE_MAX_SECTION_8814A		64
-#define	EFUSE_MAX_WORD_UNIT_8814A		4
-#define	EFUSE_PROTECT_BYTES_BANK_8814A		16
-
-#define	EFUSE_IC_ID_OFFSET_8814A		506	//For some inferiority IC purpose. added by Roger, 2009.09.02.
-#define AVAILABLE_EFUSE_ADDR_8814A(addr) 	(addr < EFUSE_REAL_CONTENT_LEN_8814A)
-
-/*-------------------------------------------------------------------------
-Chip specific
--------------------------------------------------------------------------*/
-
-/* pic buffer descriptor */
-#if 1 /* according to the define in the rtw_xmit.h, rtw_recv.h */
-#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
-#define TX_DESC_NUM_8814A  TXDESC_NUM   /* 128 */
-#define RX_DESC_NUM_8814A  PCI_MAX_RX_COUNT /* 128 */
-#ifdef CONFIG_CONCURRENT_MODE
-#define BE_QUEUE_TX_DESC_NUM_8814A  (TXDESC_NUM<<1)    /* 256 */
-#else
-#define BE_QUEUE_TX_DESC_NUM_8814A  (TXDESC_NUM+(TXDESC_NUM>>1)) /* 192 */
-#endif
-#else
-#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
-#define TX_DESC_NUM_8814A  128 /* 1024//2048 change by ylb 20130624 */
-#define RX_DESC_NUM_8814A  128 /* 1024 //512 change by ylb 20130624 */
-#endif
-
-// <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)	      |
-//
-#define	EFUSE_OOB_PROTECT_BYTES 		15	// PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte.
-
-/* rtl8814_hal_init.c */
-s32 FirmwareDownload8814A( PADAPTER	Adapter, BOOLEAN bUsedWoWLANFw);
-void	InitializeFirmwareVars8814(PADAPTER padapter);
-
-VOID
-Hal_InitEfuseVars_8814A(
-	IN	PADAPTER	Adapter
-	);
-
-s32 InitLLTTable8814A(
-	IN	PADAPTER	Adapter
-	);
-
-
-void InitRDGSetting8814A(PADAPTER padapter);
-
-//void CheckAutoloadState8812A(PADAPTER padapter);
-
-// EFuse
-u8	GetEEPROMSize8814A(PADAPTER padapter);
-void InitPGData8814A(PADAPTER padapter);
-
-void	hal_ReadPROMVersion8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void	hal_ReadTxPowerInfo8814A(PADAPTER padapter, u8* hwinfo,BOOLEAN	AutoLoadFail);
-void	hal_ReadBoardType8814A(PADAPTER pAdapter, u8* hwinfo,BOOLEAN AutoLoadFail);
-void	hal_ReadThermalMeter_8814A(PADAPTER	Adapter, u8* PROMContent,BOOLEAN 	AutoloadFail);
-void	hal_ReadChannelPlan8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
-void	hal_EfuseParseXtal_8814A(PADAPTER pAdapter, u8* hwinfo,BOOLEAN AutoLoadFail);
-void	hal_ReadAntennaDiversity8814A(PADAPTER pAdapter,u8* PROMContent,BOOLEAN AutoLoadFail);
-void	hal_Read_TRX_antenna_8814A(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
-VOID hal_ReadAmplifierType_8814A(
-	IN	PADAPTER		Adapter	
-	);
-VOID hal_ReadPAType_8814A(
-	IN	PADAPTER	Adapter,
-	IN	u8*			PROMContent,
-	IN	BOOLEAN		AutoloadFail,
-	OUT u8*		pPAType, 
-	OUT u8*		pLNAType
-	);
-void hal_GetRxGainOffset_8814A(
-	PADAPTER	Adapter,
-	pu1Byte		PROMContent,
-	BOOLEAN		AutoloadFail
-	);
-void Hal_EfuseParseKFreeData_8814A(
-	IN		PADAPTER		Adapter,
-	IN		u8				*PROMContent,
-	IN		BOOLEAN			AutoloadFail);
-void	hal_ReadRFEType_8814A(PADAPTER Adapter,u8* PROMContent, BOOLEAN AutoloadFail);
-void	hal_EfuseParseBTCoexistInfo8814A(PADAPTER Adapter, u8* hwinfo, BOOLEAN AutoLoadFail);
-
-//void	hal_ReadUsbType_8812AU(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
-//int 	FirmwareDownloadBT(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
-void	hal_ReadRemoteWakeup_8814A(PADAPTER padapter, u8* hwinfo, BOOLEAN AutoLoadFail);
-u8	MgntQuery_NssTxRate(u16 Rate);
-
-//BOOLEAN HalDetectPwrDownMode8812(PADAPTER Adapter);
-	
-#ifdef CONFIG_WOWLAN
-void Hal_DetectWoWMode(PADAPTER pAdapter);
-#endif //CONFIG_WOWLAN
-
-void _InitBeaconParameters_8814A(PADAPTER padapter);
-void SetBeaconRelatedRegisters8814A(PADAPTER padapter);
-
-void ReadRFType8814A(PADAPTER padapter);
-void InitDefaultValue8814A(PADAPTER padapter);
-
-void SetHwReg8814A(PADAPTER padapter, u8 variable, u8 *pval);
-void GetHwReg8814A(PADAPTER padapter, u8 variable, u8 *pval);
-u8 SetHalDefVar8814A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-u8 GetHalDefVar8814A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
-s32 c2h_id_filter_ccx_8814a(u8 *buf);
-void rtl8814_set_hal_ops(struct hal_ops *pHalFunc);
-void init_hal_spec_8814a(_adapter *adapter);
-
-// register
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
-void SetBcnCtrlReg(PADAPTER	Adapter, u8	SetBits, u8	ClearBits);
-void rtl8814_start_thread(PADAPTER padapter);
-void rtl8814_stop_thread(PADAPTER padapter);
-
-
-#ifdef CONFIG_PCI_HCI
-BOOLEAN	InterruptRecognized8814AE(PADAPTER Adapter);
-VOID	UpdateInterruptMask8814AE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
-u16	get_txbd_idx_addr(u16 ff_hwaddr);
-#endif
-
-#ifdef CONFIG_BT_COEXIST
-void rtl8812a_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
-#endif
-
-#endif //__RTL8188E_HAL_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_HAL_H__
+#define __RTL8814A_HAL_H__
+
+/* #include "hal_com.h" */
+#include "hal_data.h"
+
+/* include HAL Related header after HAL Related compiling flags */
+#include "rtl8814a_spec.h"
+#include "rtl8814a_rf.h"
+#include "rtl8814a_dm.h"
+#include "rtl8814a_recv.h"
+#include "rtl8814a_xmit.h"
+#include "rtl8814a_cmd.h"
+#include "rtl8814a_led.h"
+#include "Hal8814PwrSeq.h"
+#include "Hal8814PhyReg.h"
+#include "Hal8814PhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8814a_sreset.h"
+#endif /* DBG_CONFIG_ERROR_DETECT */
+
+enum {
+	VOLTAGE_V25						= 0x03,
+	LDOE25_SHIFT					= 28 ,
+};
+/* max. iram is 64k , max dmen is 32k. Total = 96k = 0x18000*/
+#define FW_SIZE							0x18000
+#define FW_START_ADDRESS   0x1000
+typedef struct _RT_FIRMWARE_8814 {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8814, *PRT_FIRMWARE_8814;
+
+#define PAGE_SIZE_TX_8814	PAGE_SIZE_128
+#define BCNQ_PAGE_NUM_8814		0x08
+
+#define Rtl8814A_NIC_PWR_ON_FLOW				rtl8814A_power_on_flow
+#define Rtl8814A_NIC_RF_OFF_FLOW				rtl8814A_radio_off_flow
+#define Rtl8814A_NIC_DISABLE_FLOW				rtl8814A_card_disable_flow
+#define Rtl8814A_NIC_ENABLE_FLOW				rtl8814A_card_enable_flow
+#define Rtl8814A_NIC_SUSPEND_FLOW				rtl8814A_suspend_flow
+#define Rtl8814A_NIC_RESUME_FLOW				rtl8814A_resume_flow
+#define Rtl8814A_NIC_PDN_FLOW					rtl8814A_hwpdn_flow
+#define Rtl8814A_NIC_LPS_ENTER_FLOW			rtl8814A_enter_lps_flow
+#define Rtl8814A_NIC_LPS_LEAVE_FLOW			rtl8814A_leave_lps_flow
+
+/* *****************************************************
+ *				New	Firmware Header(8-byte alinment required)
+ * *****************************************************
+ * --- LONG WORD 0 ---- */
+#define GET_FIRMWARE_HDR_SIGNATURE_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 0, 16)
+#define GET_FIRMWARE_HDR_CATEGORY_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr, 16, 8) /* AP/NIC and USB/PCI */
+#define GET_FIRMWARE_HDR_FUNCTION_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr, 24, 8) /* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions */
+#define GET_FIRMWARE_HDR_VERSION_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 0, 16)/* FW Version */
+#define GET_FIRMWARE_HDR_SUB_VER_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 16, 8) /* FW Subversion, default 0x00 */
+#define GET_FIRMWARE_HDR_SUB_IDX_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+4, 24, 8) /* FW Subversion Index */
+
+/* --- LONG WORD 1 ---- */
+#define GET_FIRMWARE_HDR_SVN_IDX_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+8, 0, 32)/* The SVN entry index */
+#define GET_FIRMWARE_HDR_RSVD1_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+12, 0, 32)
+
+/* --- LONG WORD 2 ---- */
+#define GET_FIRMWARE_HDR_MONTH_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 0, 8) /* Release time Month field */
+#define GET_FIRMWARE_HDR_DATE_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+16, 8, 8) /* Release time Date field */
+#define GET_FIRMWARE_HDR_HOUR_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+16, 16, 8)/* Release time Hour field */
+#define GET_FIRMWARE_HDR_MINUTE_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+16, 24, 8)/* Release time Minute field */
+#define GET_FIRMWARE_HDR_YEAR_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+20, 0, 16)/* Release time Year field */
+#define GET_FIRMWARE_HDR_FOUNDRY_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 16, 8)/* Release time Foundry field */
+#define GET_FIRMWARE_HDR_RSVD2_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+20, 24, 8)
+
+/* --- LONG WORD 3 ---- */
+#define GET_FIRMWARE_HDR_MEM_UASGE_DL_FROM_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+24, 0, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_BOOT_FROM_3081(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+24, 1, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_BOOT_LOADER_3081(__FwHdr)LE_BITS_TO_4BYTE(__FwHdr+24, 2, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_IRAM_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 3, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_ERAM_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 4, 1)
+#define GET_FIRMWARE_HDR_MEM_UASGE_RSVD4_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+24, 5, 3)
+#define GET_FIRMWARE_HDR_RSVD3_3081(__FwHdr)					LE_BITS_TO_4BYTE(__FwHdr+24, 8, 8)
+#define GET_FIRMWARE_HDR_BOOT_LOADER_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+24, 16, 16)
+#define GET_FIRMWARE_HDR_RSVD5_3081(__FwHdr)					LE_BITS_TO_4BYTE(__FwHdr+28, 0, 32)
+
+/* --- LONG WORD 4 ---- */
+#define GET_FIRMWARE_HDR_TOTAL_DMEM_SZ_3081(__FwHdr)	LE_BITS_TO_4BYTE(__FwHdr+36, 0, 32)
+#define GET_FIRMWARE_HDR_FW_CFG_SZ_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+36, 0, 16)
+#define GET_FIRMWARE_HDR_FW_ATTR_SZ_3081(__FwHdr)		LE_BITS_TO_4BYTE(__FwHdr+36, 16, 16)
+
+/* --- LONG WORD 5 ---- */
+#define GET_FIRMWARE_HDR_IROM_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+40, 0, 32)
+#define GET_FIRMWARE_HDR_EROM_3081(__FwHdr)				LE_BITS_TO_4BYTE(__FwHdr+44, 0, 32)
+
+/* --- LONG WORD 6 ---- */
+#define GET_FIRMWARE_HDR_IRAM_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+48, 0, 32)
+#define GET_FIRMWARE_HDR_ERAM_SZ_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+52, 0, 32)
+
+/* --- LONG WORD 7 ---- */
+#define GET_FIRMWARE_HDR_RSVD6_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+56, 0, 32)
+#define GET_FIRMWARE_HDR_RSVD7_3081(__FwHdr)			LE_BITS_TO_4BYTE(__FwHdr+60, 0, 32)
+
+
+
+/*
+ * 2013/08/16 MH MOve from SDIO.h for common use.
+ *   */
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
+	#define TRX_SHARE_MODE_8814A				0	/* TRX Buffer Share Index */
+	#define BASIC_RXFF_SIZE_8814A				24576/* Basic RXFF Size is 24K = 24*1024 Unit: Byte */
+	#define TRX_SHARE_BUFF_UNIT_8814A			65536/* TRX Share Buffer unit Size 64K = 64*1024 Unit: Byte */
+	#define TRX_SHARE_BUFF_UNIT_PAGE_8814A	(TRX_SHARE_BUFF_UNIT_8814A/PAGE_SIZE_8814A)/* 512 Pages */
+
+	/* Origin: */
+	#define  HPQ_PGNUM_8814A					0x20	/* High Queue */
+	#define  LPQ_PGNUM_8814A					0x20	/* Low Queue */
+	#define  NPQ_PGNUM_8814A					0x20	/* Normal Queue */
+	#define  EPQ_PGNUM_8814A					0x20	/* Extra Queue */
+
+#else	/*  #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI) */
+
+	#define  HPQ_PGNUM_8814A		20
+	#define  NPQ_PGNUM_8814A		20
+	#define  LPQ_PGNUM_8814A		20 /* 1972 */
+	#define  EPQ_PGNUM_8814A		20
+	#define  BCQ_PGNUM_8814A		32
+
+#endif /* #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI) */
+
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8814	0x06
+#else
+	#define WOWLAN_PAGE_NUM_8814	0x00
+#endif
+
+#define PAGE_SIZE_8814A						128/* TXFF Page Size, Unit: Byte */
+#define MAX_RX_DMA_BUFFER_SIZE_8814A		0x5C00	/* BASIC_RXFF_SIZE_8814A + TRX_SHARE_MODE_8814A * TRX_SHARE_BUFF_UNIT_8814A */ /* Basic RXFF Size + ShareBuffer Size */
+#define TX_PAGE_BOUNDARY_8814A			TXPKT_PGNUM_8814A	/* Need to enlarge boundary, by KaiYuan */
+#define TX_PAGE_BOUNDARY_WOWLAN_8814A	TXPKT_PGNUM_8814A	/* TODO: 20130415 KaiYuan Check this value later */
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8814A	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8814A	0x0	/* 0B */
+#endif
+#define RX_DMA_BOUNDARY_8814A		(MAX_RX_DMA_BUFFER_SIZE_8814A - RX_DMA_RESERVED_SIZE_8814A - 1)
+
+#define  TOTAL_PGNUM_8814A		2048
+#define  TXPKT_PGNUM_8814A		(2048 - BCNQ_PAGE_NUM_8814-WOWLAN_PAGE_NUM_8814)
+#define  PUB_PGNUM_8814A		(TXPKT_PGNUM_8814A-HPQ_PGNUM_8814A-NPQ_PGNUM_8814A-LPQ_PGNUM_8814A-EPQ_PGNUM_8814A)
+
+/* Note: For WMM Normal Chip Setting ,modify later */
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8814A	TX_PAGE_BOUNDARY_8814A
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8814A		(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8814A + 1)
+
+#define DRIVER_EARLY_INT_TIME_8814		0x05
+#define BCN_DMA_ATIME_INT_TIME_8814		0x02
+
+
+#define MAX_PAGE_SIZE			4096	/* @ page : 4k bytes */
+
+#define EFUSE_MAX_SECTION_JAGUAR				64
+
+#define	HWSET_MAX_SIZE_8814A			512
+
+#define	EFUSE_REAL_CONTENT_LEN_8814A	1024
+#define	EFUSE_MAX_BANK_8814A		2
+
+#define	EFUSE_MAP_LEN_8814A			512
+#define	EFUSE_MAX_SECTION_8814A		64
+#define	EFUSE_MAX_WORD_UNIT_8814A		4
+#define	EFUSE_PROTECT_BYTES_BANK_8814A		16
+
+#define	EFUSE_IC_ID_OFFSET_8814A		506	/* For some inferiority IC purpose. added by Roger, 2009.09.02. */
+#define AVAILABLE_EFUSE_ADDR_8814A(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8814A)
+
+/*-------------------------------------------------------------------------
+Chip specific
+-------------------------------------------------------------------------*/
+
+/* pic buffer descriptor */
+#if 1 /* according to the define in the rtw_xmit.h, rtw_recv.h */
+	#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
+	#define TX_DESC_NUM_8814A  TX_BD_NUM   /* 128 */
+	#define RX_DESC_NUM_8814A  PCI_MAX_RX_COUNT /* 128 */
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define BE_QUEUE_TX_DESC_NUM_8814A  (TX_BD_NUM<<1)    /* 256 */
+	#else
+		#define BE_QUEUE_TX_DESC_NUM_8814A  (TX_BD_NUM+(TX_BD_NUM>>1)) /* 192 */
+	#endif
+#else
+	#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
+	#define TX_DESC_NUM_8814A  128 /* 1024//2048 change by ylb 20130624 */
+	#define RX_DESC_NUM_8814A  128 /* 1024 //512 change by ylb 20130624 */
+#endif
+
+/* <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)	      |
+ *   */
+#define	EFUSE_OOB_PROTECT_BYTES		15	/* PG data exclude header, dummy 6 bytes frome CP test and reserved 1byte. */
+
+#ifdef CONFIG_FILE_FWIMG
+extern char *rtw_fw_file_path;
+#ifdef CONFIG_WOWLAN
+extern char *rtw_fw_wow_file_path;
+#endif
+#ifdef CONFIG_MP_INCLUDED
+extern char *rtw_fw_mp_bt_file_path;
+#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
+
+/* rtl8814_hal_init.c */
+s32 FirmwareDownload8814A(PADAPTER	Adapter, BOOLEAN bUsedWoWLANFw);
+void	InitializeFirmwareVars8814(PADAPTER padapter);
+
+VOID
+Hal_InitEfuseVars_8814A(
+	IN	PADAPTER	Adapter
+);
+
+s32 InitLLTTable8814A(
+	IN	PADAPTER	Adapter
+);
+
+
+void InitRDGSetting8814A(PADAPTER padapter);
+
+/* void CheckAutoloadState8812A(PADAPTER padapter); */
+
+/* EFuse */
+u8	GetEEPROMSize8814A(PADAPTER padapter);
+VOID hal_InitPGData_8814A(
+ IN PADAPTER  padapter,
+ IN OUT u8   *PROMContent
+);
+
+void	hal_ReadPROMVersion8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadTxPowerInfo8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN	AutoLoadFail);
+void	hal_ReadBoardType8814A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadThermalMeter_8814A(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN	AutoloadFail);
+void	hal_ReadChannelPlan8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_EfuseParseXtal_8814A(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+void	hal_ReadAntennaDiversity8814A(PADAPTER pAdapter, u8 *PROMContent, BOOLEAN AutoLoadFail);
+void	hal_Read_TRX_antenna_8814A(PADAPTER	Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+VOID hal_ReadAmplifierType_8814A(
+	IN	PADAPTER		Adapter
+);
+VOID hal_ReadPAType_8814A(
+	IN	PADAPTER	Adapter,
+	IN	u8			*PROMContent,
+	IN	BOOLEAN		AutoloadFail,
+	OUT u8		*pPAType,
+	OUT u8		*pLNAType
+);
+
+void hal_ReadPowerTrackingType_8814A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+
+void hal_GetRxGainOffset_8814A(
+	PADAPTER	Adapter,
+	pu1Byte		PROMContent,
+	BOOLEAN		AutoloadFail
+);
+void Hal_EfuseParseKFreeData_8814A(
+	IN		PADAPTER		Adapter,
+	IN		u8				*PROMContent,
+	IN		BOOLEAN			AutoloadFail);
+void	hal_ReadRFEType_8814A(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void	hal_EfuseParseBTCoexistInfo8814A(PADAPTER Adapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+
+/* void	hal_ReadUsbType_8812AU(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+ * int	FirmwareDownloadBT(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware); */
+void	hal_ReadRemoteWakeup_8814A(PADAPTER padapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
+u8	MgntQuery_NssTxRate(u16 Rate);
+
+/* BOOLEAN HalDetectPwrDownMode8812(PADAPTER Adapter); */
+
+#ifdef CONFIG_WOWLAN
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void _InitBeaconParameters_8814A(PADAPTER padapter);
+void SetBeaconRelatedRegisters8814A(PADAPTER padapter);
+
+void ReadRFType8814A(PADAPTER padapter);
+void InitDefaultValue8814A(PADAPTER padapter);
+
+u8 SetHwReg8814A(PADAPTER padapter, u8 variable, u8 *pval);
+void GetHwReg8814A(PADAPTER padapter, u8 variable, u8 *pval);
+u8 SetHalDefVar8814A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8814A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+void rtl8814_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8814a(_adapter *adapter);
+
+/* register */
+void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
+void SetBcnCtrlReg(PADAPTER	Adapter, u8	SetBits, u8	ClearBits);
+void rtl8814_start_thread(PADAPTER padapter);
+void rtl8814_stop_thread(PADAPTER padapter);
+
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8814AE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8814AE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+	VOID	InitMAC_TRXBD_8814AE(PADAPTER Adapter);
+	u16	get_txbd_rw_reg(u16 ff_hwaddr);
+#endif
+
+#ifdef CONFIG_BT_COEXIST
+	void rtl8812a_combo_card_WifiOnlyHwInit(PADAPTER Adapter);
+#endif
+
+#endif /* __RTL8188E_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_led.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_led.h
index 17cbd2cdf02a..755b1b6662fb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_led.h
@@ -1,41 +1,37 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8814A_LED_H__
-#define __RTL8814A_LED_H__
-
-
-//================================================================================
-// Interface to manipulate LED objects.
-//================================================================================
-#ifdef CONFIG_USB_HCI
-void rtl8814au_InitSwLeds(PADAPTER padapter);
-void rtl8814au_DeInitSwLeds(PADAPTER padapter);
-#endif //CONFIG_USB_HCI
-#ifdef CONFIG_PCI_HCI
-void rtl8814ae_InitSwLeds(PADAPTER padapter);
-void rtl8814ae_DeInitSwLeds(PADAPTER padapter);
-#endif //CONFIG_PCI_HCI
-#ifdef CONFIG_SDIO_HCI
-void rtl8814s_InitSwLeds(PADAPTER padapter);
-void rtl8814s_DeInitSwLeds(PADAPTER padapter);
-#endif //CONFIG_SDIO_HCI
-
-#endif //__RTL8814A_LED_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_LED_H__
+#define __RTL8814A_LED_H__
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8814au_InitSwLeds(PADAPTER padapter);
+	void rtl8814au_DeInitSwLeds(PADAPTER padapter);
+#endif /* CONFIG_USB_HCI */
+#ifdef CONFIG_PCI_HCI
+	void rtl8814ae_InitSwLeds(PADAPTER padapter);
+	void rtl8814ae_DeInitSwLeds(PADAPTER padapter);
+#endif /* CONFIG_PCI_HCI */
+#ifdef CONFIG_SDIO_HCI
+	void rtl8814s_InitSwLeds(PADAPTER padapter);
+	void rtl8814s_DeInitSwLeds(PADAPTER padapter);
+#endif /* CONFIG_SDIO_HCI */
+
+#endif /* __RTL8814A_LED_H__ */
+#endif /*CONFIG_RTW_SW_LED*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_recv.h
index f2ae1831d2be..131b33973f7a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_recv.h
@@ -1,188 +1,187 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8814A_RECV_H__
-#define __RTL8814A_RECV_H__
-
-#if defined(CONFIG_USB_HCI)
-
-#ifndef MAX_RECVBUF_SZ
-#ifdef PLATFORM_OS_CE
-#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-#else
-	#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-		#ifdef CONFIG_PLATFORM_MSTAR
-			#define MAX_RECVBUF_SZ (8192) // 8K
-		#else
-		#define MAX_RECVBUF_SZ (32768) // 32k
-		#endif
-		//#define MAX_RECVBUF_SZ (24576) // 24k
-		//#define MAX_RECVBUF_SZ (20480) //20K
-		//#define MAX_RECVBUF_SZ (10240) //10K
-		//#define MAX_RECVBUF_SZ (15360) // 15k < 16k
-		//#define MAX_RECVBUF_SZ (8192+1024) // 8K+1k
-	#else
-		#define MAX_RECVBUF_SZ (4000) // about 4K
-	#endif
-#endif
-#endif //!MAX_RECVBUF_SZ
-
-#elif defined(CONFIG_PCI_HCI)
-//#ifndef CONFIG_MINIMAL_MEMORY_USAGE
-//	#define MAX_RECVBUF_SZ (9100)
-//#else
-	#define MAX_RECVBUF_SZ (4000) // about 4K
-//#endif
-
-
-#elif defined(CONFIG_SDIO_HCI)
-/* temp solution
-#ifdef CONFIG_SDIO_RX_COPY
-#define MAX_RECVBUF_SZ (10240)
-#else // !CONFIG_SDIO_RX_COPY
-#define MAX_RECVBUF_SZ	MAX_RX_DMA_BUFFER_SIZE_8821
-#endif // !CONFIG_SDIO_RX_COPY
-*/
-#endif
-
-
-/* RX buffer descriptor */
-/* DWORD 0 */
-#define SET_RX_BUFFER_DESC_DATA_LENGTH_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_BUFFER_DESC_LS_8814A(__pRxStatusDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 14, 1, __Value)
-#define SET_RX_BUFFER_DESC_FS_8814A(__pRxStatusDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
-#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 16, __Value)
-
-#define GET_RX_BUFFER_DESC_OWN_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
-#define GET_RX_BUFFER_DESC_LS_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
-#define GET_RX_BUFFER_DESC_FS_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
-#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
-
-/* DWORD 1 */
-#define SET_RX_BUFFER_PHYSICAL_LOW_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
-#define GET_RX_BUFFER_PHYSICAL_LOW_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 32)
-
-/* DWORD 2 */
-#define SET_RX_BUFFER_PHYSICAL_HIGH_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
-
-/* DWORD 3*/ /* RESERVED */
-
-
-/*=============
-//RX Info
-==============*/
-//DWORD 0
-#define SET_RX_STATUS_DESC_PKT_LEN_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 0, 14, __Value)
-#define SET_RX_STATUS_DESC_EOR_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 30, 1, __Value)
-#define SET_RX_STATUS_DESC_OWN_8814AE(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE( __pRxStatusDesc, 31, 1, __Value)
-
-#define GET_RX_STATUS_DESC_PKT_LEN_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 0, 14)
-#define GET_RX_STATUS_DESC_CRC32_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc, 14, 1)
-#define GET_RX_STATUS_DESC_ICV_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc, 15, 1)
-#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 16, 4)
-#define GET_RX_STATUS_DESC_SECURITY_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 20, 3)
-#define GET_RX_STATUS_DESC_QOS_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc, 23, 1)
-#define GET_RX_STATUS_DESC_SHIFT_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc, 24, 2)
-#define GET_RX_STATUS_DESC_PHY_STATUS_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 26, 1)
-#define GET_RX_STATUS_DESC_SWDEC_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc, 27, 1)
-#define GET_RX_STATUS_DESC_LAST_SEG_8814AE(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 28, 1)
-#define GET_RX_STATUS_DESC_EOR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc, 30, 1)
-
-//DWORD 1
-#define GET_RX_STATUS_DESC_MACID_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 7)
-#define GET_RX_STATUS_DESC_EXT_SECTYPE_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 7, 1)/* 20130415 KaiYuan add for 8814 */
-#define GET_RX_STATUS_DESC_TID_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 8, 4)
-#define GET_RX_STATUS_DESC_MACID_VLD_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 12, 1)
-#define GET_RX_STATUS_DESC_AMSDU_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 13, 1)
-#define GET_RX_STATUS_DESC_RXID_MATCH_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 14, 1)
-#define GET_RX_STATUS_DESC_PAGGR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 15, 1)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 20, 1)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 21, 1)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 22, 1)
-#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 23, 1)
-#define GET_RX_STATUS_DESC_PAM_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 24, 1)
-#define GET_RX_STATUS_DESC_PWR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 25, 1)
-#define GET_RX_STATUS_DESC_MORE_DATA_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 26, 1)
-#define GET_RX_STATUS_DESC_MORE_FRAG_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 27, 1)
-#define GET_RX_STATUS_DESC_TYPE_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 28, 2)
-#define GET_RX_STATUS_DESC_FIRST_SEG_8814AE(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc, 29, 1)
-#define GET_RX_STATUS_DESC_EOR_8814AE(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc, 30, 1)
-#define GET_RX_STATUS_DESC_MC_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 30, 1)
-#define GET_RX_STATUS_DESC_BC_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE( __pRxStatusDesc+4, 31, 1)
-
-//DWORD 2
-#define GET_RX_STATUS_DESC_SEQ_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 0, 12)
-#define GET_RX_STATUS_DESC_FRAG_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 12, 4)
-#ifdef CONFIG_USB_RX_AGGREGATION
-#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 16, 8)
-#else
-#define GET_RX_STATUS_DESC_RX_IS_QOS_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 16, 1)
-#endif
-#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 18, 6)
-#define GET_RX_STATUS_DESC_HWRSVD_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 24, 4)
-#define GET_RX_STATUS_C2H_8814A(__pRxStatusDesc)								LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 28, 1)
-#define GET_RX_STATUS_DESC_FCS_OK_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+8, 31, 1)
-
-//DWORD 3
-#define GET_RX_STATUS_DESC_RX_RATE_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 0, 7)
-#define GET_RX_STATUS_DESC_BSSID_FIT_H_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 7, 3)//20130415 KaiYuan add for 8814
-#define GET_RX_STATUS_DESC_HTC_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 10, 1)
-#define GET_RX_STATUS_DESC_EOSP_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 11, 1)
-#define GET_RX_STATUS_DESC_BSSID_FIT_L_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 12, 2)
-#define GET_RX_STATUS_DESC_DMA_AGG_NUM_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+12, 16, 8)//20130415 KaiYuan Check if it exist anymore
-#define GET_RX_STATUS_DESC_PATTERN_MATCH_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 29, 1)
-#define GET_RX_STATUS_DESC_UNICAST_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 30, 1)
-#define GET_RX_STATUS_DESC_MAGIC_WAKE_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 31, 1)
-
-//DWORD 4
-#define GET_RX_STATUS_DESC_PATTERN_IDX_8814A(__pRxStatusDesc)	 			LE_BITS_TO_4BYTE( __pRxStatusDesc+16, 0, 8)
-#define GET_RX_STATUS_DESC_RX_EOF_8814A(__pRxStatusDesc)	 				LE_BITS_TO_4BYTE( __pRxStatusDesc+16, 8, 1)
-#define GET_RX_STATUS_DESC_RX_SCRAMBLER_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE( __pRxStatusDesc+16, 9, 7)
-#define GET_RX_STATUS_DESC_RX_PRE_NDP_VLD_8814A(__pRxStatusDesc)	 		LE_BITS_TO_4BYTE( __pRxStatusDesc+16, 16, 1)
-#define GET_RX_STATUS_DESC_A1_FIT_8814A(__pRxStatusDesc)	 					LE_BITS_TO_4BYTE( __pRxStatusDesc+16, 24, 5)
-
-
-//DWORD 5
-#define GET_RX_STATUS_DESC_TSFL_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE( __pRxStatusDesc+20, 0, 32)
-
-
-// Rx smooth factor
-#define Rx_Smooth_Factor (20)
-
-#ifdef CONFIG_USB_HCI
-s32 rtl8814au_init_recv_priv(PADAPTER padapter);
-void rtl8814au_free_recv_priv(PADAPTER padapter);
-#endif
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8814ae_init_recv_priv(PADAPTER padapter);
-void rtl8814ae_free_recv_priv(PADAPTER padapter);
-#endif
-
-/* temp solution
-#ifdef CONFIG_SDIO_HCI
-s32 InitRecvPriv8821AS(PADAPTER padapter);
-void FreeRecvPriv8821AS(PADAPTER padapter);
-#endif // CONFIG_SDIO_HCI
-*/
-
-void rtl8814_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
-
-#endif /* __RTL8814A_RECV_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_RECV_H__
+#define __RTL8814A_RECV_H__
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (32768) /* 32k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (24576) */ /* 24k */
+				/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				/* #define MAX_RECVBUF_SZ (15360) */ /* 15k < 16k */
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	/* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */
+	/*	#define MAX_RECVBUF_SZ (9100) */
+	/* #else */
+	#define MAX_RECVBUF_SZ (4000) /* about 4K
+	* #endif */
+
+
+#elif defined(CONFIG_SDIO_HCI)
+	#if 0
+		/* temp solution */
+		#ifdef CONFIG_SDIO_RX_COPY
+			#define MAX_RECVBUF_SZ (10240)
+		#else /*  !CONFIG_SDIO_RX_COPY */
+			#define MAX_RECVBUF_SZ	MAX_RX_DMA_BUFFER_SIZE_8821
+		#endif /*  !CONFIG_SDIO_RX_COPY */
+	#endif
+#endif
+
+
+/* RX buffer descriptor */
+/* DWORD 0 */
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_8814A(__pRxStatusDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 14, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_8814A(__pRxStatusDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 16, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_BUFFER_DESC_FS_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+
+/* DWORD 1 */
+#define SET_RX_BUFFER_PHYSICAL_LOW_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+#define GET_RX_BUFFER_PHYSICAL_LOW_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 32)
+
+/* DWORD 2 */
+#define SET_RX_BUFFER_PHYSICAL_HIGH_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+
+/* DWORD 3*/ /* RESERVED */
+
+
+#if 0
+	/* =============
+	* RX Info
+	* ============== */
+#endif
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8814A(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8814A(__pRxStatusDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8814AE(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_LAST_SEG_8814AE(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 28, 1)
+#define GET_RX_STATUS_DESC_EOR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_EXT_SECTYPE_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 7, 1)/* 20130415 KaiYuan add for 8814 */
+#define GET_RX_STATUS_DESC_TID_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_MACID_VLD_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 12, 1)
+#define GET_RX_STATUS_DESC_AMSDU_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_8814A(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_FIRST_SEG_8814AE(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc, 29, 1)
+#define GET_RX_STATUS_DESC_EOR_8814AE(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_MC_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8814A(__pRxStatusDesc)							LE_BITS_TO_4BYTE(__pRxStatusDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#ifdef CONFIG_USB_RX_AGGREGATION
+	#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 8)
+#else
+	#define GET_RX_STATUS_DESC_RX_IS_QOS_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#endif
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_HWRSVD_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 24, 4)
+#define GET_RX_STATUS_C2H_8814A(__pRxStatusDesc)								LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+#define GET_RX_STATUS_DESC_FCS_OK_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_BSSID_FIT_H_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 7, 3)/* 20130415 KaiYuan add for 8814 */
+#define GET_RX_STATUS_DESC_HTC_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_L_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#define GET_RX_STATUS_DESC_DMA_AGG_NUM_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)/* 20130415 KaiYuan Check if it exist anymore */
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_WAKE_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 31, 1)
+
+/* DWORD 4 */
+#define GET_RX_STATUS_DESC_PATTERN_IDX_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 0, 8)
+#define GET_RX_STATUS_DESC_RX_EOF_8814A(__pRxStatusDesc)					LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 8, 1)
+#define GET_RX_STATUS_DESC_RX_SCRAMBLER_8814A(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 9, 7)
+#define GET_RX_STATUS_DESC_RX_PRE_NDP_VLD_8814A(__pRxStatusDesc)			LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 16, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+16, 24, 5)
+
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8814A(__pRxStatusDesc)						LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+
+/* Rx smooth factor */
+#define Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8814au_init_recv_priv(PADAPTER padapter);
+	void rtl8814au_free_recv_priv(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8814ae_init_recv_priv(PADAPTER padapter);
+	void rtl8814ae_free_recv_priv(PADAPTER padapter);
+#endif
+
+#if 0
+	/* temp solution */
+	#ifdef CONFIG_SDIO_HCI
+		s32 InitRecvPriv8821AS(PADAPTER padapter);
+		void FreeRecvPriv8821AS(PADAPTER padapter);
+	#endif /*  CONFIG_SDIO_HCI */
+#endif
+
+void rtl8814_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8814A_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_rf.h
index 5cd517a8720b..5c83ecf65bc8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,24 +12,18 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTL8814A_RF_H__
 #define __RTL8814A_RF_H__
 
 VOID
 PHY_RF6052SetBandwidth8814A(
 	IN	PADAPTER				Adapter,
-	IN	CHANNEL_WIDTH		Bandwidth);
+	IN	enum channel_width		Bandwidth);
 
 
 int
 PHY_RF6052_Config_8814A(
-	IN	PADAPTER	Adapter	);
-
-#endif//__RTL8188E_RF_H__
+	IN	PADAPTER	Adapter);
 
+#endif/* __RTL8188E_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_spec.h
index cb3fe95521e0..58364c79bc34 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_spec.h
@@ -1,643 +1,649 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
-#ifndef __RTL8814A_SPEC_H__
-#define __RTL8814A_SPEC_H__
-
-#include <drv_conf.h>
-
-
-//============================================================
-//
-//============================================================
-
-//-----------------------------------------------------
-//
-//	0x0000h ~ 0x00FFh	System Configuration
-//
-//-----------------------------------------------------
-#define REG_SYS_ISO_CTRL_8814A			0x0000	// 2 Byte
-#define REG_SYS_FUNC_EN_8814A			0x0002	// 2 Byte
-#define REG_SYS_PW_CTRL_8814A			0x0004	// 4 Byte        
-#define REG_SYS_CLKR_8814A				0x0008	// 2 Byte
-#define REG_SYS_EEPROM_CTRL_8814A		0x000A	// 2 Byte        
-#define REG_EE_VPD_8814A				0x000C	// 2 Byte
-#define REG_SYS_SWR_CTRL1_8814A			0x0010	// 1 Byte
-#define REG_SPS0_CTRL_8814A				0x0011	// 7 Byte
-#define REG_SYS_SWR_CTRL3_8814A			0x0018	// 4 Byte
-#define REG_RSV_CTRL_8814A				0x001C	// 3 Byte
-#define REG_RF_CTRL0_8814A				0x001F	// 1 Byte
-#define REG_RF_CTRL1_8814A				0x0020	// 1 Byte
-#define REG_RF_CTRL2_8814A				0x0021	// 1 Byte
-#define REG_LPLDO_CTRL_8814A			0x0023	// 1 Byte
-#define REG_AFE_CTRL1_8814A				0x0024	// 4 Byte        
-#define REG_AFE_CTRL2_8814A				0x0028	// 4 Byte        
-#define REG_AFE_CTRL3_8814A				0x002c 	// 4 Byte 
-#define REG_EFUSE_CTRL_8814A			0x0030
-#define REG_LDO_EFUSE_CTRL_8814A		0x0034 
-#define REG_PWR_DATA_8814A				0x0038
-#define REG_CAL_TIMER_8814A				0x003C
-#define REG_ACLK_MON_8814A				0x003E
-#define REG_GPIO_MUXCFG_8814A			0x0040
-#define REG_GPIO_IO_SEL_8814A			0x0042
-#define REG_MAC_PINMUX_CFG_8814A		0x0043
-#define REG_GPIO_PIN_CTRL_8814A			0x0044
-#define REG_GPIO_INTM_8814A				0x0048
-#define REG_LEDCFG0_8814A				0x004C
-#define REG_LEDCFG1_8814A				0x004D
-#define REG_LEDCFG2_8814A				0x004E
-#define REG_LEDCFG3_8814A				0x004F
-#define REG_FSIMR_8814A					0x0050
-#define REG_FSISR_8814A					0x0054
-#define REG_HSIMR_8814A					0x0058
-#define REG_HSISR_8814A					0x005c
-#define REG_GPIO_EXT_CTRL_8814A			0x0060
-#define REG_GPIO_STATUS_8814A			0x006C
-#define REG_SDIO_CTRL_8814A				0x0070
-#define REG_HCI_OPT_CTRL_8814A			0x0074
-#define REG_RF_CTRL3_8814A				0x0076	// 1 Byte
-#define REG_AFE_CTRL4_8814A				0x0078 
-#define REG_8051FW_CTRL_8814A			0x0080 
-#define REG_HIMR0_8814A					0x00B0
-#define REG_HISR0_8814A					0x00B4
-#define REG_HIMR1_8814A					0x00B8
-#define REG_HISR1_8814A					0x00BC
-#define REG_SYS_CFG1_8814A				0x00F0
-#define REG_SYS_CFG2_8814A				0x00FC
-#define REG_SYS_CFG3_8814A				0x1000
-
-//-----------------------------------------------------
-//
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//
-//-----------------------------------------------------
-#define REG_CR_8814A						0x0100
-#define REG_PBP_8814A					0x0104
-#define REG_PKT_BUFF_ACCESS_CTRL_8814A	0x0106
-#define REG_TRXDMA_CTRL_8814A			0x010C
-#define REG_TRXFF_BNDY_8814A			0x0114
-#define REG_TRXFF_STATUS_8814A			0x0118
-#define REG_RXFF_PTR_8814A				0x011C
-#define REG_CPWM_8814A					0x012F
-#define REG_FWIMR_8814A					0x0130
-#define REG_FWISR_8814A					0x0134
-#define REG_FTIMR_8814A					0x0138
-#define REG_PKTBUF_DBG_CTRL_8814A		0x0140
-#define REG_RXPKTBUF_CTRL_8814A		0x0142
-#define REG_PKTBUF_DBG_DATA_L_8814A	0x0144
-#define REG_PKTBUF_DBG_DATA_H_8814A	0x0148
-
-#define REG_TC0_CTRL_8814A				0x0150
-#define REG_TC1_CTRL_8814A				0x0154
-#define REG_TC2_CTRL_8814A				0x0158
-#define REG_TC3_CTRL_8814A				0x015C
-#define REG_TC4_CTRL_8814A				0x0160
-#define REG_TCUNIT_BASE_8814A			0x0164
-#define REG_RSVD3_8814A					0x0168
-#define REG_C2HEVT_MSG_NORMAL_8814A	0x01A0
-#define REG_C2HEVT_CLEAR_8814A			0x01AF
-#define REG_MCUTST_1_8814A				0x01C0
-#define REG_MCUTST_WOWLAN_8814A		0x01C7
-#define REG_FMETHR_8814A				0x01C8
-#define REG_HMETFR_8814A				0x01CC
-#define REG_HMEBOX_0_8814A				0x01D0
-#define REG_HMEBOX_1_8814A				0x01D4
-#define REG_HMEBOX_2_8814A				0x01D8
-#define REG_HMEBOX_3_8814A				0x01DC
-#define REG_LLT_INIT_8814A				0x01E0
-#define REG_LLT_ADDR_8814A				0x01E4 //20130415 KaiYuan add for 8814
-#define REG_HMEBOX_EXT0_8814A			0x01F0
-#define REG_HMEBOX_EXT1_8814A			0x01F4
-#define REG_HMEBOX_EXT2_8814A			0x01F8
-#define REG_HMEBOX_EXT3_8814A			0x01FC
-
-//-----------------------------------------------------
-//
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_FIFOPAGE_CTRL_1_8814A			0x0200
-#define REG_FIFOPAGE_CTRL_2_8814A		0x0204
-#define REG_AUTO_LLT_8814A					0x0208
-#define REG_TXDMA_OFFSET_CHK_8814A	0x020C
-#define REG_TXDMA_STATUS_8814A			0x0210
-#define REG_RQPN_NPQ_8814A				0x0214
-#define REG_TQPNT1_8814A					0x0218
-#define REG_TQPNT2_8814A					0x021C
-#define REG_TQPNT3_8814A					0x0220
-#define REG_TQPNT4_8814A					0x0224
-#define REG_RQPN_CTRL_1_8814A				0x0228
-#define REG_RQPN_CTRL_2_8814A				0x022C
-#define REG_FIFOPAGE_INFO_1_8814A			0x0230
-#define REG_FIFOPAGE_INFO_2_8814A			0x0234
-#define REG_FIFOPAGE_INFO_3_8814A			0x0238
-#define REG_FIFOPAGE_INFO_4_8814A			0x023C
-#define REG_FIFOPAGE_INFO_5_8814A			0x0240
-
-
-//-----------------------------------------------------
-//
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//
-//-----------------------------------------------------
-#define REG_RXDMA_AGG_PG_TH_8814A		0x0280
-#define REG_RXPKT_NUM_8814A				0x0284 // The number of packets in RXPKTBUF.
-#define REG_RXDMA_CONTROL_8814A			0x0286 // ?????? Control the RX DMA.
-#define REG_RXDMA_STATUS_8814A			0x0288
-#define REG_RXDMA_MODE_8814A				0x0290 // ??????
-#define REG_EARLY_MODE_CONTROL_8814A	0x02BC // ??????
-#define REG_RSVD5_8814A					0x02F0 // ??????
-
-
-//-----------------------------------------------------
-//
-//	0x0300h ~ 0x03FFh	PCIe
-//
-//-----------------------------------------------------
-#define	REG_PCIE_CTRL_REG_8814A			0x0300
-#define	REG_INT_MIG_8814A				0x0304	// Interrupt Migration 
-#define	REG_BCNQ_TXBD_DESA_8814A		0x0308	// TX Beacon Descriptor Address
-#define	REG_MGQ_TXBD_DESA_8814A			0x0310	// TX Manage Queue Descriptor Address
-#define	REG_VOQ_TXBD_DESA_8814A			0x0318	// TX VO Queue Descriptor Address
-#define	REG_VIQ_TXBD_DESA_8814A			0x0320	// TX VI Queue Descriptor Address
-#define	REG_BEQ_TXBD_DESA_8814A			0x0328	// TX BE Queue Descriptor Address
-#define	REG_BKQ_TXBD_DESA_8814A			0x0330	// TX BK Queue Descriptor Address
-#define	REG_RXQ_RXBD_DESA_8814A			0x0338	// RX Queue	Descriptor Address
-#define REG_HI0Q_TXBD_DESA_8814A		0x0340
-#define REG_HI1Q_TXBD_DESA_8814A		0x0348
-#define REG_HI2Q_TXBD_DESA_8814A		0x0350
-#define REG_HI3Q_TXBD_DESA_8814A		0x0358
-#define REG_HI4Q_TXBD_DESA_8814A		0x0360
-#define REG_HI5Q_TXBD_DESA_8814A		0x0368
-#define REG_HI6Q_TXBD_DESA_8814A		0x0370
-#define REG_HI7Q_TXBD_DESA_8814A		0x0378
-#define	REG_MGQ_TXBD_NUM_8814A			0x0380
-#define	REG_RX_RXBD_NUM_8814A			0x0382
-#define	REG_VOQ_TXBD_NUM_8814A			0x0384
-#define	REG_VIQ_TXBD_NUM_8814A			0x0386
-#define	REG_BEQ_TXBD_NUM_8814A			0x0388
-#define	REG_BKQ_TXBD_NUM_8814A			0x038A
-#define	REG_HI0Q_TXBD_NUM_8814A			0x038C
-#define	REG_HI1Q_TXBD_NUM_8814A			0x038E
-#define	REG_HI2Q_TXBD_NUM_8814A			0x0390
-#define	REG_HI3Q_TXBD_NUM_8814A			0x0392
-#define	REG_HI4Q_TXBD_NUM_8814A			0x0394
-#define	REG_HI5Q_TXBD_NUM_8814A			0x0396
-#define	REG_HI6Q_TXBD_NUM_8814A			0x0398
-#define	REG_HI7Q_TXBD_NUM_8814A			0x039A
-#define	REG_TSFTIMER_HCI_8814A			0x039C
-
-//Read Write Point
-#define	REG_VOQ_TXBD_IDX_8814A			0x03A0
-#define	REG_VIQ_TXBD_IDX_8814A			0x03A4
-#define	REG_BEQ_TXBD_IDX_8814A			0x03A8
-#define	REG_BKQ_TXBD_IDX_8814A			0x03AC
-#define	REG_MGQ_TXBD_IDX_8814A			0x03B0
-#define	REG_RXQ_TXBD_IDX_8814A			0x03B4
-#define	REG_HI0Q_TXBD_IDX_8814A			0x03B8
-#define	REG_HI1Q_TXBD_IDX_8814A			0x03BC
-#define	REG_HI2Q_TXBD_IDX_8814A			0x03C0
-#define	REG_HI3Q_TXBD_IDX_8814A			0x03C4
-#define	REG_HI4Q_TXBD_IDX_8814A			0x03C8
-#define	REG_HI5Q_TXBD_IDX_8814A			0x03CC
-#define	REG_HI6Q_TXBD_IDX_8814A			0x03D0
-#define	REG_HI7Q_TXBD_IDX_8814A			0x03D4
-#define REG_DBG_SEL_V1_8814A				0x03D8
-#define REG_PCIE_HRPWM1_V1_8814A			0x03D9
-#define REG_PCIE_HCPWM1_V1_8814A			0x03DA
-#define REG_PCIE_CTRL2_8814A				0x03DB
-#define REG_PCIE_HRPWM2_V1_8814A			0x03DC
-#define REG_PCIE_HCPWM2_V1_8814A			0x03DE
-#define REG_PCIE_H2C_MSG_V1_8814A		0x03E0
-#define REG_PCIE_C2H_MSG_V1_8814A		0x03E4
-#define REG_DBI_WDATA_V1_8814A			0x03E8
-#define REG_DBI_RDATA_V1_8814A			0x03EC
-#define REG_DBI_FLAG_V1_8814A				0x03F0
-#define REG_MDIO_V1_8814A					0x03F4
-#define REG_PCIE_MIX_CFG_8814A			0x03F8
-#define REG_DBG_8814A						0x03FC
-//-----------------------------------------------------
-//
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//
-//-----------------------------------------------------
-#define REG_VOQ_INFORMATION_8814A		0x0400
-#define REG_VIQ_INFORMATION_8814A		0x0404
-#define REG_BEQ_INFORMATION_8814A		0x0408
-#define REG_BKQ_INFORMATION_8814A		0x040C
-#define REG_MGQ_INFORMATION_8814A		0x0410
-#define REG_HGQ_INFORMATION_8814A		0x0414
-#define REG_BCNQ_INFORMATION_8814A	0x0418
-#define REG_TXPKT_EMPTY_8814A			0x041A
-#define REG_CPU_MGQ_INFORMATION_8814A	0x041C
-#define REG_FWHW_TXQ_CTRL_8814A		0x0420
-#define REG_HWSEQ_CTRL_8814A			0x0423
-#define REG_TXPKTBUF_BCNQ_BDNY_8814A	0x0424
-//#define REG_MGQ_BDNY_8814A				0x0425
-#define REG_LIFETIME_EN_8814A				0x0426
-//#define REG_FW_FREE_TAIL_8814A			0x0427
-#define REG_SPEC_SIFS_8814A				0x0428
-#define REG_RETRY_LIMIT_8814A				0x042A
-#define REG_TXBF_CTRL_8814A				0x042C
-#define REG_DARFRC_8814A				0x0430
-#define REG_RARFRC_8814A				0x0438
-#define REG_RRSR_8814A					0x0440
-#define REG_ARFR0_8814A					0x0444
-#define REG_ARFR1_8814A					0x044C
-#define REG_CCK_CHECK_8814A				0x0454
-#define REG_AMPDU_MAX_TIME_8814A			0x0455
-#define REG_TXPKTBUF_BCNQ1_BDNY_8814A	0x0456
-#define REG_AMPDU_MAX_LENGTH_8814A	0x0458
-#define REG_ACQ_STOP_8814A				0x045C
-#define REG_NDPA_RATE_8814A				0x045D
-#define REG_TX_HANG_CTRL_8814A			0x045E
-#define REG_NDPA_OPT_CTRL_8814A		0x045F
-#define REG_FAST_EDCA_CTRL_8814A		0x0460
-#define REG_RD_RESP_PKT_TH_8814A		0x0463
-#define REG_CMDQ_INFO_8814A 				0x0464
-#define REG_Q4_INFO_8814A 					0x0468
-#define REG_Q5_INFO_8814A 					0x046C
-#define REG_Q6_INFO_8814A 					0x0470
-#define REG_Q7_INFO_8814A 					0x0474
-#define REG_WMAC_LBK_BUF_HD_8814A		0x0478
-#define REG_MGQ_PGBNDY_8814A 				0x047A
-#define REG_INIRTS_RATE_SEL_8814A 			0x0480
-#define REG_BASIC_CFEND_RATE_8814A 		0x0481
-#define REG_STBC_CFEND_RATE_8814A 		0x0482
-#define REG_DATA_SC_8814A					0x0483
-#define REG_MACID_SLEEP3_8814A 			0x0484
-#define REG_MACID_SLEEP1_8814A 			0x0488
-#define REG_ARFR2_8814A 					0x048C
-#define REG_ARFR3_8814A 					0x0494
-#define REG_ARFR4_8814A 					0x049C
-#define REG_ARFR5_8814A 					0x04A4
-#define REG_TXRPT_START_OFFSET_8814A		0x04AC
-#define REG_TRYING_CNT_TH_8814A 			0x04B0
-#define REG_POWER_STAGE1_8814A		0x04B4
-#define REG_POWER_STAGE2_8814A		0x04B8
-#define REG_SW_AMPDU_BURST_MODE_CTRL_8814A	0x04BC
-#define REG_PKT_LIFE_TIME_8814A			0x04C0
-#define REG_PKT_BE_BK_LIFE_TIME_8814A		0x04C2 // ??????
-#define REG_STBC_SETTING_8814A			0x04C4
-#define REG_STBC_8814A						0x04C5
-#define REG_QUEUE_CTRL_8814A 				0x04C6
-#define REG_SINGLE_AMPDU_CTRL_8814A 		0x04C7
-#define REG_PROT_MODE_CTRL_8814A		0x04C8
-#define REG_MAX_AGGR_NUM_8814A		0x04CA
-#define REG_RTS_MAX_AGGR_NUM_8814A	0x04CB
-#define REG_BAR_MODE_CTRL_8814A		0x04CC
-#define REG_RA_TRY_RATE_AGG_LMT_8814A	0x04CF
-#define REG_MACID_SLEEP2_8814A			0x04D0
-#define REG_MACID_SLEEP0_8814A			0x04D4
-#define REG_HW_SEQ0_8814A 				0x04D8
-#define REG_HW_SEQ1_8814A 				0x04DA
-#define REG_HW_SEQ2_8814A 				0x04DC
-#define REG_HW_SEQ3_8814A 				0x04DE
-#define REG_NULL_PKT_STATUS_8814A 			0x04E0
-#define REG_PTCL_ERR_STATUS_8814A 			0x04E2
-#define REG_DROP_PKT_NUM_8814A 			0x04EC
-#define REG_PTCL_TX_RPT_8814A 				0x04F0
-#define REG_Dummy_8814A 					0x04FC
-
-
-//-----------------------------------------------------
-//
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//
-//-----------------------------------------------------
-#define REG_EDCA_VO_PARAM_8814A			0x0500
-#define REG_EDCA_VI_PARAM_8814A			0x0504
-#define REG_EDCA_BE_PARAM_8814A			0x0508
-#define REG_EDCA_BK_PARAM_8814A			0x050C
-#define REG_BCNTCFG_8814A					0x0510
-#define REG_PIFS_8814A						0x0512
-#define REG_RDG_PIFS_8814A					0x0513
-#define REG_SIFS_CTX_8814A					0x0514
-#define REG_SIFS_TRX_8814A					0x0516
-#define REG_AGGR_BREAK_TIME_8814A			0x051A
-#define REG_SLOT_8814A						0x051B
-#define REG_TX_PTCL_CTRL_8814A				0x0520
-#define REG_TXPAUSE_8814A					0x0522
-#define REG_DIS_TXREQ_CLR_8814A			0x0523
-#define REG_RD_CTRL_8814A					0x0524
-//
-// Format for offset 540h-542h:
-//	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
-//	[7:4]:   Reserved.
-//	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
-//	[23:20]: Reserved
-// Description:
-//	              |
-//     |<--Setup--|--Hold------------>|
-//	--------------|----------------------
-//                |
-//               TBTT
-// Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
-// Described by Designer Tim and Bruce, 2011-01-14.
-//
-#define REG_TBTT_PROHIBIT_8814A			0x0540
-#define REG_RD_NAV_NXT_8814A				0x0544
-#define REG_NAV_PROT_LEN_8814A			0x0546
-#define REG_BCN_CTRL_8814A					0x0550
-#define REG_BCN_CTRL_1_8814A				0x0551
-#define REG_MBID_NUM_8814A				0x0552
-#define REG_DUAL_TSF_RST_8814A				0x0553
-#define REG_MBSSID_BCN_SPACE_8814A		0x0554
-#define REG_DRVERLYINT_8814A				0x0558
-#define REG_BCNDMATIM_8814A				0x0559
-#define REG_ATIMWND_8814A					0x055A
-#define REG_USTIME_TSF_8814A				0x055C
-#define REG_BCN_MAX_ERR_8814A				0x055D
-#define REG_RXTSF_OFFSET_CCK_8814A		0x055E
-#define REG_RXTSF_OFFSET_OFDM_8814A		0x055F	
-#define REG_TSFTR_8814A						0x0560
-#define REG_CTWND_8814A					0x0572
-#define REG_SECONDARY_CCA_CTRL_8814A		0x0577 // ??????
-#define REG_PSTIMER_8814A					0x0580
-#define REG_TIMER0_8814A					0x0584
-#define REG_TIMER1_8814A					0x0588
-#define REG_BCN_PREDL_ITV_8814A			0x058F	//Pre download beacon interval
-#define REG_ACMHWCTRL_8814A				0x05C0
-
-//-----------------------------------------------------
-//
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//
-//-----------------------------------------------------
-#define REG_MAC_CR_8814A					0x0600
-#define REG_TCR_8814A						0x0604
-#define REG_RCR_8814A						0x0608
-#define REG_RX_PKT_LIMIT_8814A				0x060C
-#define REG_RX_DLK_TIME_8814A				0x060D
-#define REG_RX_DRVINFO_SZ_8814A			0x060F
-
-#define REG_MACID_8814A					0x0610
-#define REG_BSSID_8814A						0x0618
-#define REG_MAR_8814A						0x0620
-#define REG_MBIDCAMCFG_8814A				0x0628
-
-#define REG_USTIME_EDCA_8814A				0x0638
-#define REG_MAC_SPEC_SIFS_8814A			0x063A
-#define REG_RESP_SIFP_CCK_8814A			0x063C
-#define REG_RESP_SIFS_OFDM_8814A			0x063E
-#define REG_ACKTO_8814A					0x0640
-#define REG_CTS2TO_8814A					0x0641
-#define REG_EIFS_8814A						0x0642
-
-#define	REG_NAV_UPPER_8814A				0x0652	// unit of 128
-#define REG_TRXPTCL_CTL_8814A				0x0668
-
-// Security
-#define REG_CAMCMD_8814A					0x0670
-#define REG_CAMWRITE_8814A				0x0674
-#define REG_CAMREAD_8814A					0x0678
-#define REG_CAMDBG_8814A					0x067C
-#define REG_SECCFG_8814A					0x0680
-
-// Power
-#define REG_WOW_CTRL_8814A				0x0690
-#define REG_PS_RX_INFO_8814A				0x0692
-#define REG_UAPSD_TID_8814A				0x0693
-#define REG_WKFMCAM_NUM_8814A			0x0698
-#define REG_RXFLTMAP0_8814A				0x06A0
-#define REG_RXFLTMAP1_8814A				0x06A2
-#define REG_RXFLTMAP2_8814A				0x06A4
-#define REG_BCN_PSR_RPT_8814A				0x06A8
-#define REG_BT_COEX_TABLE_8814A			0x06C0
-#define REG_TX_DATA_RSP_RATE_8814A		0x06DE
-#define REG_ASSOCIATED_BFMER0_INFO_8814A	0x06E4
-#define REG_ASSOCIATED_BFMER1_INFO_8814A	0x06EC
-#define REG_CSI_RPT_PARAM_BW20_8814A		0x06F4
-#define REG_CSI_RPT_PARAM_BW40_8814A		0x06F8
-#define REG_CSI_RPT_PARAM_BW80_8814A		0x06FC
-
-// Hardware Port 2
-#define REG_MACID1_8814A					0x0700
-#define REG_BSSID1_8814A					0x0708
-// Hardware Port 3
-#define REG_MACID2_8814A					0x1620
-#define REG_BSSID2_8814A					0x1628
-// Hardware Port 4
-#define REG_MACID3_8814A					0x1630
-#define REG_BSSID3_8814A					0x1638
-// Hardware Port 5
-#define REG_MACID4_8814A					0x1640
-#define REG_BSSID4_8814A					0x1648
-
-#define REG_ASSOCIATED_BFMEE_SEL_8814A	0x0714
-#define REG_SND_PTCL_CTRL_8814A			0x0718
-#define REG_IQ_DUMP_8814A					0x07C0
-
-/**** page 19 ****/
-//TX BeamForming
-#define	REG_BB_TXBF_ANT_SET_BF1				0x19ac
-#define	REG_BB_TXBF_ANT_SET_BF0				0x19b4
-
-//	0x1200h ~ 0x12FFh	DDMA CTRL
-//
-//-----------------------------------------------------
-#define REG_DDMA_CH0SA                   0x1200
-#define REG_DDMA_CH0DA                   0x1204
-#define REG_DDMA_CH0CTRL                0x1208
-#define REG_DDMA_CH1SA                   0x1210
-#define REG_DDMA_CH1DA                	0x1214
-#define REG_DDMA_CH1CTRL                0x1218
-#define REG_DDMA_CH2SA                   0x1220
-#define REG_DDMA_CH2DA                   0x1224
-#define REG_DDMA_CH2CTRL                0x1228
-#define REG_DDMA_CH3SA                   0x1230
-#define REG_DDMA_CH3DA                   0x1234
-#define REG_DDMA_CH3CTRL                0x1238
-#define REG_DDMA_CH4SA                   0x1240
-#define REG_DDMA_CH4DA                   0x1244
-#define REG_DDMA_CH4CTRL                0x1248
-#define REG_DDMA_CH5SA                   0x1250
-#define REG_DDMA_CH5DA                   0x1254
-#define REG_DDMA_CH5CTRL                0x1258
-#define REG_DDMA_INT_MSK                0x12E0
-#define REG_DDMA_CHSTATUS              0x12E8
-#define REG_DDMA_CHKSUM                 0x12F0
-#define REG_DDMA_MONITER                0x12FC
-
-#define DDMA_LEN_MASK              	 	0x0001FFFF
-#define FW_CHKSUM_DUMMY_SZ		8
-#define DDMA_CH_CHKSUM_CNT		BIT(24)
-#define DDMA_RST_CHKSUM_STS		BIT(25)
-#define DDMA_MODE_BLOCK_CPU		BIT(26)
-#define DDMA_CHKSUM_FAIL			BIT(27)
-#define DDMA_DA_W_DISABLE			BIT(28)
-#define DDMA_CHKSUM_EN			BIT(29)
-#define DDMA_CH_OWN                 	BIT(31)
-
-
-//3081 FWDL
-#define FWDL_EN                 BIT0
-#define IMEM_BOOT_DL_RDY        BIT1
-#define IMEM_BOOT_CHKSUM_FAIL   BIT2
-#define IMEM_DL_RDY             BIT3
-#define IMEM_CHKSUM_OK        BIT4
-#define DMEM_DL_RDY             BIT5
-#define DMEM_CHKSUM_OK        BIT6
-#define EMEM_DL_RDY             BIT7
-#define EMEM_CHKSUM_FAIL        BIT8
-#define EMEM_TXBUF_DL_RDY       BIT9
-#define EMEM_TXBUF_CHKSUM_FAIL  BIT10
-#define CPU_CLK_SWITCH_BUSY     BIT11
-#define CPU_CLK_SEL             (BIT12|BIT13)
-#define FWDL_OK                 BIT14
-#define FW_INIT_RDY             BIT15
-#define R_EN_BOOT_FLASH         BIT20
-
-#define OCPBASE_IMEM_3081        0x00000000
-#define OCPBASE_DMEM_3081        0x00200000 
-#define OCPBASE_RPTBUF_3081      0x18660000
-#define OCPBASE_RXBUF2_3081      0x18680000
-#define OCPBASE_RXBUF_3081       0x18700000
-#define OCPBASE_TXBUF_3081       0x18780000
-
-
-#define REG_FAST_EDCA_VOVI_SETTING_8814A 0x1448
-#define REG_FAST_EDCA_BEBK_SETTING_8814A 0x144C
-
-
-//-----------------------------------------------------
-//
-
-
-//-----------------------------------------------------
-//
-//	Redifine 8192C register definition for compatibility
-//
-//-----------------------------------------------------
-
-// TODO: use these definition when using REG_xxx naming rule.
-// NOTE: DO NOT Remove these definition. Use later.
-#define	EFUSE_CTRL_8814A					REG_EFUSE_CTRL_8814A		// E-Fuse Control.
-#define	EFUSE_TEST_8814A					REG_LDO_EFUSE_CTRL_8814A		// E-Fuse Test.
-#define	MSR_8814A							(REG_CR_8814A + 2)		// Media Status register
-#define	ISR_8814A							REG_HISR0_8814A
-#define	TSFR_8814A							REG_TSFTR_8814A			// Timing Sync Function Timer Register.
-					
-#define PBP_8814A							REG_PBP_8814A
-
-// Redifine MACID register, to compatible prior ICs.
-#define	IDR0_8814A							REG_MACID_8814A			// MAC ID Register, Offset 0x0050-0x0053
-#define	IDR4_8814A							(REG_MACID_8814A + 4)	// MAC ID Register, Offset 0x0054-0x0055
-
-
-//
-// 9. Security Control Registers	(Offset: )
-//
-#define	RWCAM_8814A						REG_CAMCMD_8814A		//IN 8190 Data Sheet is called CAMcmd
-#define	WCAMI_8814A						REG_CAMWRITE_8814A		// Software write CAM input content
-#define	RCAMO_8814A						REG_CAMREAD_8814A		// Software read/write CAM config
-#define	CAMDBG_8814A						REG_CAMDBG_8814A
-#define	SECR_8814A							REG_SECCFG_8814A		//Security Configuration Register
-
-
-//----------------------------------------------------------------------------
-//       8195 IMR/ISR bits						(offset 0xB0,  8bits)
-//----------------------------------------------------------------------------
-#define	IMR_DISABLED_8814A					0
-// IMR DW0(0x00B0-00B3) Bit 0-31
-#define	IMR_TIMER2_8814A					BIT31		// Timeout interrupt 2
-#define	IMR_TIMER1_8814A					BIT30		// Timeout interrupt 1	
-#define	IMR_PSTIMEOUT_8814A				BIT29		// Power Save Time Out Interrupt
-#define	IMR_GTINT4_8814A					BIT28		// When GTIMER4 expires, this bit is set to 1	
-#define	IMR_GTINT3_8814A					BIT27		// When GTIMER3 expires, this bit is set to 1	
-#define	IMR_TXBCN0ERR_8814A				BIT26		// Transmit Beacon0 Error			
-#define	IMR_TXBCN0OK_8814A					BIT25		// Transmit Beacon0 OK			
-#define	IMR_TSF_BIT32_TOGGLE_8814A		BIT24		// TSF Timer BIT32 toggle indication interrupt			
-#define	IMR_BCNDMAINT0_8814A				BIT20		// Beacon DMA Interrupt 0			
-#define	IMR_BCNDERR0_8814A					BIT16		// Beacon Queue DMA OK0			
-#define	IMR_HSISR_IND_ON_INT_8814A		BIT15		// HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1)
-#define	IMR_BCNDMAINT_E_8814A				BIT14		// Beacon DMA Interrupt Extension for Win7			
-#define	IMR_ATIMEND_8814A					BIT12		// CTWidnow End or ATIM Window End
-#define	IMR_C2HCMD_8814A					BIT10		// CPU to Host Command INT Status, Write 1 clear	
-#define	IMR_CPWM2_8814A					BIT9			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_CPWM_8814A						BIT8			// CPU power Mode exchange INT Status, Write 1 clear	
-#define	IMR_HIGHDOK_8814A					BIT7			// High Queue DMA OK	
-#define	IMR_MGNTDOK_8814A					BIT6			// Management Queue DMA OK	
-#define	IMR_BKDOK_8814A					BIT5			// AC_BK DMA OK		
-#define	IMR_BEDOK_8814A					BIT4			// AC_BE DMA OK	
-#define	IMR_VIDOK_8814A					BIT3			// AC_VI DMA OK		
-#define	IMR_VODOK_8814A					BIT2			// AC_VO DMA OK	
-#define	IMR_RDU_8814A						BIT1			// Rx Descriptor Unavailable	
-#define	IMR_ROK_8814A						BIT0			// Receive DMA OK
-
-// IMR DW1(0x00B4-00B7) Bit 0-31
-#define	IMR_MCUERR_8814A						BIT28		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT7_8814A				BIT27		// Beacon DMA Interrupt 7
-#define	IMR_BCNDMAINT6_8814A				BIT26		// Beacon DMA Interrupt 6
-#define	IMR_BCNDMAINT5_8814A				BIT25		// Beacon DMA Interrupt 5
-#define	IMR_BCNDMAINT4_8814A				BIT24		// Beacon DMA Interrupt 4
-#define	IMR_BCNDMAINT3_8814A				BIT23		// Beacon DMA Interrupt 3
-#define	IMR_BCNDMAINT2_8814A				BIT22		// Beacon DMA Interrupt 2
-#define	IMR_BCNDMAINT1_8814A				BIT21		// Beacon DMA Interrupt 1
-#define	IMR_BCNDOK7_8814A					BIT20		// Beacon Queue DMA OK Interrup 7
-#define	IMR_BCNDOK6_8814A					BIT19		// Beacon Queue DMA OK Interrup 6
-#define	IMR_BCNDOK5_8814A					BIT18		// Beacon Queue DMA OK Interrup 5
-#define	IMR_BCNDOK4_8814A					BIT17		// Beacon Queue DMA OK Interrup 4
-#define	IMR_BCNDOK3_8814A					BIT16		// Beacon Queue DMA OK Interrup 3
-#define	IMR_BCNDOK2_8814A					BIT15		// Beacon Queue DMA OK Interrup 2
-#define	IMR_BCNDOK1_8814A					BIT14		// Beacon Queue DMA OK Interrup 1
-#define	IMR_ATIMEND_E_8814A				BIT13		// ATIM Window End Extension for Win7
-#define	IMR_TXERR_8814A					BIT11		// Tx Error Flag Interrupt Status, write 1 clear.
-#define	IMR_RXERR_8814A					BIT10		// Rx Error Flag INT Status, Write 1 clear
-#define	IMR_TXFOVW_8814A					BIT9			// Transmit FIFO Overflow
-#define	IMR_RXFOVW_8814A					BIT8			// Receive FIFO Overflow
-
-
-#ifdef CONFIG_PCI_HCI
-#define IMR_TX_MASK			(IMR_VODOK_8814A | IMR_VIDOK_8814A | IMR_BEDOK_8814A | IMR_BKDOK_8814A | IMR_MGNTDOK_8814A | IMR_HIGHDOK_8814A)
-
-#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8814A | IMR_TXBCN0OK_8814A | IMR_TXBCN0ERR_8814A | IMR_BCNDERR0_8814A)
-
-#define RT_AC_INT_MASKS	(IMR_VIDOK_8814A | IMR_VODOK_8814A | IMR_BEDOK_8814A | IMR_BKDOK_8814A)
-#endif
-
-
-/*===================================================================
-=====================================================================
-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!!!!!!
-=====================================================================
-=====================================================================*/
-
-
-//-----------------------------------------------------
-//
-//	0xFE00h ~ 0xFE55h	USB Configuration
-//
-//-----------------------------------------------------
-
-//2 Special Option
-#define USB_AGG_EN_8814A			BIT(7)
-#define REG_USB_HRPWM_U3			0xF052
-
-#define LAST_ENTRY_OF_TX_PKT_BUFFER_8814A       2048-1	//20130415 KaiYuan add for 8814
-
-#define MACID_NUM_8814A 128
-#define SEC_CAM_ENT_NUM_8814A 64
-#define NSS_NUM_8814A 3
-#define BAND_CAP_8814A (BAND_CAP_2G | BAND_CAP_5G)
-#define BW_CAP_8814A (BW_CAP_20M | BW_CAP_40M | BW_CAP_80M)
-#define PROTO_CAP_8814A (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N|PROTO_CAP_11AC)
-
-#endif //__RTL8814A_SPEC_H__
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_SPEC_H__
+#define __RTL8814A_SPEC_H__
+
+#include <drv_conf.h>
+
+
+/* ************************************************************
+ *
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8814A			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8814A			0x0002	/* 2 Byte */
+#define REG_SYS_PW_CTRL_8814A			0x0004	/* 4 Byte        */
+#define REG_SYS_CLKR_8814A				0x0008	/* 2 Byte */
+#define REG_SYS_EEPROM_CTRL_8814A		0x000A	/* 2 Byte        */
+#define REG_EE_VPD_8814A				0x000C	/* 2 Byte */
+#define REG_SYS_SWR_CTRL1_8814A			0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8814A				0x0011	/* 7 Byte */
+#define REG_SYS_SWR_CTRL3_8814A			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8814A				0x001C	/* 3 Byte */
+#define REG_RF_CTRL0_8814A				0x001F	/* 1 Byte */
+#define REG_RF_CTRL1_8814A				0x0020	/* 1 Byte */
+#define REG_RF_CTRL2_8814A				0x0021	/* 1 Byte */
+#define REG_LPLDO_CTRL_8814A			0x0023	/* 1 Byte */
+#define REG_AFE_CTRL1_8814A				0x0024	/* 4 Byte        */
+#define REG_AFE_CTRL2_8814A				0x0028	/* 4 Byte        */
+#define REG_AFE_CTRL3_8814A				0x002c	/* 4 Byte  */
+#define REG_EFUSE_CTRL_8814A			0x0030
+#define REG_LDO_EFUSE_CTRL_8814A		0x0034
+#define REG_PWR_DATA_8814A				0x0038
+#define REG_CAL_TIMER_8814A				0x003C
+#define REG_ACLK_MON_8814A				0x003E
+#define REG_GPIO_MUXCFG_8814A			0x0040
+#define REG_GPIO_IO_SEL_8814A			0x0042
+#define REG_MAC_PINMUX_CFG_8814A		0x0043
+#define REG_GPIO_PIN_CTRL_8814A			0x0044
+#define REG_GPIO_INTM_8814A				0x0048
+#define REG_LEDCFG0_8814A				0x004C
+#define REG_LEDCFG1_8814A				0x004D
+#define REG_LEDCFG2_8814A				0x004E
+#define REG_LEDCFG3_8814A				0x004F
+#define REG_FSIMR_8814A					0x0050
+#define REG_FSISR_8814A					0x0054
+#define REG_HSIMR_8814A					0x0058
+#define REG_HSISR_8814A					0x005c
+#define REG_GPIO_EXT_CTRL_8814A			0x0060
+#define REG_GPIO_STATUS_8814A			0x006C
+#define REG_SDIO_CTRL_8814A				0x0070
+#define REG_HCI_OPT_CTRL_8814A			0x0074
+#define REG_RF_CTRL3_8814A				0x0076	/* 1 Byte */
+#define REG_AFE_CTRL4_8814A				0x0078
+#define REG_8051FW_CTRL_8814A			0x0080
+#define REG_HIMR0_8814A					0x00B0
+#define REG_HISR0_8814A					0x00B4
+#define REG_HIMR1_8814A					0x00B8
+#define REG_HISR1_8814A					0x00BC
+#define REG_SYS_CFG1_8814A				0x00F0
+#define REG_SYS_CFG2_8814A				0x00FC
+#define REG_SYS_CFG3_8814A				0x1000
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_CR_8814A						0x0100
+#define REG_PBP_8814A					0x0104
+#define REG_PKT_BUFF_ACCESS_CTRL_8814A	0x0106
+#define REG_TRXDMA_CTRL_8814A			0x010C
+#define REG_TRXFF_BNDY_8814A			0x0114
+#define REG_TRXFF_STATUS_8814A			0x0118
+#define REG_RXFF_PTR_8814A				0x011C
+#define REG_CPWM_8814A					0x012F
+#define REG_FWIMR_8814A					0x0130
+#define REG_FWISR_8814A					0x0134
+#define REG_FTIMR_8814A					0x0138
+#define REG_PKTBUF_DBG_CTRL_8814A		0x0140
+#define REG_RXPKTBUF_CTRL_8814A		0x0142
+#define REG_PKTBUF_DBG_DATA_L_8814A	0x0144
+#define REG_PKTBUF_DBG_DATA_H_8814A	0x0148
+
+#define REG_WOWLAN_WAKE_REASON			REG_MCUTST_WOWLAN
+
+#define REG_TC0_CTRL_8814A				0x0150
+#define REG_TC1_CTRL_8814A				0x0154
+#define REG_TC2_CTRL_8814A				0x0158
+#define REG_TC3_CTRL_8814A				0x015C
+#define REG_TC4_CTRL_8814A				0x0160
+#define REG_TCUNIT_BASE_8814A			0x0164
+#define REG_RSVD3_8814A					0x0168
+#define REG_C2HEVT_MSG_NORMAL_8814A	0x01A0
+#define REG_C2HEVT_CLEAR_8814A			0x01AF
+#define REG_MCUTST_1_8814A				0x01C0
+#define REG_MCUTST_WOWLAN_8814A		0x01C7
+#define REG_FMETHR_8814A				0x01C8
+#define REG_HMETFR_8814A				0x01CC
+#define REG_HMEBOX_0_8814A				0x01D0
+#define REG_HMEBOX_1_8814A				0x01D4
+#define REG_HMEBOX_2_8814A				0x01D8
+#define REG_HMEBOX_3_8814A				0x01DC
+#define REG_LLT_INIT_8814A				0x01E0
+#define REG_LLT_ADDR_8814A				0x01E4 /* 20130415 KaiYuan add for 8814 */
+#define REG_HMEBOX_EXT0_8814A			0x01F0
+#define REG_HMEBOX_EXT1_8814A			0x01F4
+#define REG_HMEBOX_EXT2_8814A			0x01F8
+#define REG_HMEBOX_EXT3_8814A			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_FIFOPAGE_CTRL_1_8814A			0x0200
+#define REG_FIFOPAGE_CTRL_2_8814A		0x0204
+#define REG_AUTO_LLT_8814A					0x0208
+#define REG_TXDMA_OFFSET_CHK_8814A	0x020C
+#define REG_TXDMA_STATUS_8814A			0x0210
+#define REG_RQPN_NPQ_8814A				0x0214
+#define REG_TQPNT1_8814A					0x0218
+#define REG_TQPNT2_8814A					0x021C
+#define REG_TQPNT3_8814A					0x0220
+#define REG_TQPNT4_8814A					0x0224
+#define REG_RQPN_CTRL_1_8814A				0x0228
+#define REG_RQPN_CTRL_2_8814A				0x022C
+#define REG_FIFOPAGE_INFO_1_8814A			0x0230
+#define REG_FIFOPAGE_INFO_2_8814A			0x0234
+#define REG_FIFOPAGE_INFO_3_8814A			0x0238
+#define REG_FIFOPAGE_INFO_4_8814A			0x023C
+#define REG_FIFOPAGE_INFO_5_8814A			0x0240
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8814A		0x0280
+#define REG_RXPKT_NUM_8814A				0x0284 /* The number of packets in RXPKTBUF. */
+#define REG_RXDMA_CONTROL_8814A			0x0286 /* ?????? Control the RX DMA. */
+#define REG_RXDMA_STATUS_8814A			0x0288
+#define REG_RXDMA_MODE_8814A				0x0290 /* ?????? */
+#define REG_EARLY_MODE_CONTROL_8814A	0x02BC /* ?????? */
+#define REG_RSVD5_8814A					0x02F0 /* ?????? */
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8814A			0x0300
+#define	REG_INT_MIG_8814A				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8814A		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8814A			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8814A			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8814A			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8814A			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8814A			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8814A			0x0338	/* RX Queue	Descriptor Address */
+#define REG_HI0Q_TXBD_DESA_8814A		0x0340
+#define REG_HI1Q_TXBD_DESA_8814A		0x0348
+#define REG_HI2Q_TXBD_DESA_8814A		0x0350
+#define REG_HI3Q_TXBD_DESA_8814A		0x0358
+#define REG_HI4Q_TXBD_DESA_8814A		0x0360
+#define REG_HI5Q_TXBD_DESA_8814A		0x0368
+#define REG_HI6Q_TXBD_DESA_8814A		0x0370
+#define REG_HI7Q_TXBD_DESA_8814A		0x0378
+#define	REG_MGQ_TXBD_NUM_8814A			0x0380
+#define	REG_RX_RXBD_NUM_8814A			0x0382
+#define	REG_VOQ_TXBD_NUM_8814A			0x0384
+#define	REG_VIQ_TXBD_NUM_8814A			0x0386
+#define	REG_BEQ_TXBD_NUM_8814A			0x0388
+#define	REG_BKQ_TXBD_NUM_8814A			0x038A
+#define	REG_HI0Q_TXBD_NUM_8814A			0x038C
+#define	REG_HI1Q_TXBD_NUM_8814A			0x038E
+#define	REG_HI2Q_TXBD_NUM_8814A			0x0390
+#define	REG_HI3Q_TXBD_NUM_8814A			0x0392
+#define	REG_HI4Q_TXBD_NUM_8814A			0x0394
+#define	REG_HI5Q_TXBD_NUM_8814A			0x0396
+#define	REG_HI6Q_TXBD_NUM_8814A			0x0398
+#define	REG_HI7Q_TXBD_NUM_8814A			0x039A
+#define	REG_TSFTIMER_HCI_8814A			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8814A			0x03A0
+#define	REG_VIQ_TXBD_IDX_8814A			0x03A4
+#define	REG_BEQ_TXBD_IDX_8814A			0x03A8
+#define	REG_BKQ_TXBD_IDX_8814A			0x03AC
+#define	REG_MGQ_TXBD_IDX_8814A			0x03B0
+#define	REG_RXQ_TXBD_IDX_8814A			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8814A			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8814A			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8814A			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8814A			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8814A			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8814A			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8814A			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8814A			0x03D4
+#define REG_DBG_SEL_V1_8814A				0x03D8
+#define REG_PCIE_HRPWM1_V1_8814A			0x03D9
+#define REG_PCIE_HCPWM1_V1_8814A			0x03DA
+#define REG_PCIE_CTRL2_8814A				0x03DB
+#define REG_PCIE_HRPWM2_V1_8814A			0x03DC
+#define REG_PCIE_HCPWM2_V1_8814A			0x03DE
+#define REG_PCIE_H2C_MSG_V1_8814A		0x03E0
+#define REG_PCIE_C2H_MSG_V1_8814A		0x03E4
+#define REG_DBI_WDATA_V1_8814A			0x03E8
+#define REG_DBI_RDATA_V1_8814A			0x03EC
+#define REG_DBI_FLAG_V1_8814A				0x03F0
+#define REG_MDIO_V1_8814A					0x03F4
+#define REG_PCIE_MIX_CFG_8814A			0x03F8
+#define REG_DBG_8814A						0x03FC
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_VOQ_INFORMATION_8814A		0x0400
+#define REG_VIQ_INFORMATION_8814A		0x0404
+#define REG_BEQ_INFORMATION_8814A		0x0408
+#define REG_BKQ_INFORMATION_8814A		0x040C
+#define REG_MGQ_INFORMATION_8814A		0x0410
+#define REG_HGQ_INFORMATION_8814A		0x0414
+#define REG_BCNQ_INFORMATION_8814A	0x0418
+#define REG_TXPKT_EMPTY_8814A			0x041A
+#define REG_CPU_MGQ_INFORMATION_8814A	0x041C
+#define REG_FWHW_TXQ_CTRL_8814A		0x0420
+#define REG_HWSEQ_CTRL_8814A			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8814A	0x0424
+/* #define REG_MGQ_BDNY_8814A				0x0425 */
+#define REG_LIFETIME_EN_8814A				0x0426
+/* #define REG_FW_FREE_TAIL_8814A			0x0427 */
+#define REG_SPEC_SIFS_8814A				0x0428
+#define REG_RETRY_LIMIT_8814A				0x042A
+#define REG_TXBF_CTRL_8814A				0x042C
+#define REG_DARFRC_8814A				0x0430
+#define REG_RARFRC_8814A				0x0438
+#define REG_RRSR_8814A					0x0440
+#define REG_ARFR0_8814A					0x0444
+#define REG_ARFR1_8814A					0x044C
+#define REG_CCK_CHECK_8814A				0x0454
+#define REG_AMPDU_MAX_TIME_8814A			0x0455
+#define REG_TXPKTBUF_BCNQ1_BDNY_8814A	0x0456
+#define REG_AMPDU_MAX_LENGTH_8814A	0x0458
+#define REG_ACQ_STOP_8814A				0x045C
+#define REG_NDPA_RATE_8814A				0x045D
+#define REG_TX_HANG_CTRL_8814A			0x045E
+#define REG_NDPA_OPT_CTRL_8814A		0x045F
+#define REG_FAST_EDCA_CTRL_8814A		0x0460
+#define REG_RD_RESP_PKT_TH_8814A		0x0463
+#define REG_CMDQ_INFO_8814A				0x0464
+#define REG_Q4_INFO_8814A					0x0468
+#define REG_Q5_INFO_8814A					0x046C
+#define REG_Q6_INFO_8814A					0x0470
+#define REG_Q7_INFO_8814A					0x0474
+#define REG_WMAC_LBK_BUF_HD_8814A		0x0478
+#define REG_MGQ_PGBNDY_8814A				0x047A
+#define REG_INIRTS_RATE_SEL_8814A			0x0480
+#define REG_BASIC_CFEND_RATE_8814A		0x0481
+#define REG_STBC_CFEND_RATE_8814A		0x0482
+#define REG_DATA_SC_8814A					0x0483
+#define REG_MACID_SLEEP3_8814A			0x0484
+#define REG_MACID_SLEEP1_8814A			0x0488
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW				0x0484
+	#define REG_TXPKTBUF_IV_HIGH			0x0488
+#endif /* CONFIG_WOWLAN */
+#define REG_ARFR2_8814A					0x048C
+#define REG_ARFR3_8814A					0x0494
+#define REG_ARFR4_8814A					0x049C
+#define REG_ARFR5_8814A					0x04A4
+#define REG_TXRPT_START_OFFSET_8814A		0x04AC
+#define REG_TRYING_CNT_TH_8814A			0x04B0
+#define REG_POWER_STAGE1_8814A		0x04B4
+#define REG_POWER_STAGE2_8814A		0x04B8
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8814A	0x04BC
+#define REG_PKT_LIFE_TIME_8814A			0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8814A		0x04C2 /* ?????? */
+#define REG_STBC_SETTING_8814A			0x04C4
+#define REG_STBC_8814A						0x04C5
+#define REG_QUEUE_CTRL_8814A				0x04C6
+#define REG_SINGLE_AMPDU_CTRL_8814A		0x04C7
+#define REG_PROT_MODE_CTRL_8814A		0x04C8
+#define REG_MAX_AGGR_NUM_8814A		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8814A	0x04CB
+#define REG_BAR_MODE_CTRL_8814A		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8814A	0x04CF
+#define REG_MACID_SLEEP2_8814A			0x04D0
+#define REG_MACID_SLEEP0_8814A			0x04D4
+#define REG_HW_SEQ0_8814A				0x04D8
+#define REG_HW_SEQ1_8814A				0x04DA
+#define REG_HW_SEQ2_8814A				0x04DC
+#define REG_HW_SEQ3_8814A				0x04DE
+#define REG_NULL_PKT_STATUS_8814A			0x04E0
+#define REG_PTCL_ERR_STATUS_8814A			0x04E2
+#define REG_DROP_PKT_NUM_8814A			0x04EC
+#define REG_PTCL_TX_RPT_8814A				0x04F0
+#define REG_Dummy_8814A					0x04FC
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8814A			0x0500
+#define REG_EDCA_VI_PARAM_8814A			0x0504
+#define REG_EDCA_BE_PARAM_8814A			0x0508
+#define REG_EDCA_BK_PARAM_8814A			0x050C
+#define REG_BCNTCFG_8814A					0x0510
+#define REG_PIFS_8814A						0x0512
+#define REG_RDG_PIFS_8814A					0x0513
+#define REG_SIFS_CTX_8814A					0x0514
+#define REG_SIFS_TRX_8814A					0x0516
+#define REG_AGGR_BREAK_TIME_8814A			0x051A
+#define REG_SLOT_8814A						0x051B
+#define REG_TX_PTCL_CTRL_8814A				0x0520
+#define REG_TXPAUSE_8814A					0x0522
+#define REG_DIS_TXREQ_CLR_8814A			0x0523
+#define REG_RD_CTRL_8814A					0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8814A			0x0540
+#define REG_RD_NAV_NXT_8814A				0x0544
+#define REG_NAV_PROT_LEN_8814A			0x0546
+#define REG_BCN_CTRL_8814A					0x0550
+#define REG_BCN_CTRL_1_8814A				0x0551
+#define REG_MBID_NUM_8814A				0x0552
+#define REG_DUAL_TSF_RST_8814A				0x0553
+#define REG_MBSSID_BCN_SPACE_8814A		0x0554
+#define REG_DRVERLYINT_8814A				0x0558
+#define REG_BCNDMATIM_8814A				0x0559
+#define REG_ATIMWND_8814A					0x055A
+#define REG_USTIME_TSF_8814A				0x055C
+#define REG_BCN_MAX_ERR_8814A				0x055D
+#define REG_RXTSF_OFFSET_CCK_8814A		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8814A		0x055F
+#define REG_TSFTR_8814A						0x0560
+#define REG_CTWND_8814A					0x0572
+#define REG_SECONDARY_CCA_CTRL_8814A		0x0577 /* ?????? */
+#define REG_PSTIMER_8814A					0x0580
+#define REG_TIMER0_8814A					0x0584
+#define REG_TIMER1_8814A					0x0588
+#define REG_BCN_PREDL_ITV_8814A			0x058F	/* Pre download beacon interval */
+#define REG_ACMHWCTRL_8814A				0x05C0
+#define REG_P2P_RST_8814A				0x05F0
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8814A					0x0600
+#define REG_TCR_8814A						0x0604
+#define REG_RCR_8814A						0x0608
+#define REG_RX_PKT_LIMIT_8814A				0x060C
+#define REG_RX_DLK_TIME_8814A				0x060D
+#define REG_RX_DRVINFO_SZ_8814A			0x060F
+
+#define REG_MACID_8814A					0x0610
+#define REG_BSSID_8814A						0x0618
+#define REG_MAR_8814A						0x0620
+#define REG_MBIDCAMCFG_8814A				0x0628
+
+#define REG_USTIME_EDCA_8814A				0x0638
+#define REG_MAC_SPEC_SIFS_8814A			0x063A
+#define REG_RESP_SIFP_CCK_8814A			0x063C
+#define REG_RESP_SIFS_OFDM_8814A			0x063E
+#define REG_ACKTO_8814A					0x0640
+#define REG_CTS2TO_8814A					0x0641
+#define REG_EIFS_8814A						0x0642
+
+#define	REG_NAV_UPPER_8814A				0x0652	/* unit of 128 */
+#define REG_TRXPTCL_CTL_8814A				0x0668
+
+/* Security */
+#define REG_CAMCMD_8814A					0x0670
+#define REG_CAMWRITE_8814A				0x0674
+#define REG_CAMREAD_8814A					0x0678
+#define REG_CAMDBG_8814A					0x067C
+#define REG_SECCFG_8814A					0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8814A				0x0690
+#define REG_PS_RX_INFO_8814A				0x0692
+#define REG_UAPSD_TID_8814A				0x0693
+#define REG_WKFMCAM_NUM_8814A			0x0698
+#define REG_RXFLTMAP0_8814A				0x06A0
+#define REG_RXFLTMAP1_8814A				0x06A2
+#define REG_RXFLTMAP2_8814A				0x06A4
+#define REG_BCN_PSR_RPT_8814A				0x06A8
+#define REG_BT_COEX_TABLE_8814A			0x06C0
+#define REG_TX_DATA_RSP_RATE_8814A		0x06DE
+#define REG_ASSOCIATED_BFMER0_INFO_8814A	0x06E4
+#define REG_ASSOCIATED_BFMER1_INFO_8814A	0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8814A		0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8814A		0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8814A		0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8814A					0x0700
+#define REG_BSSID1_8814A					0x0708
+/* Hardware Port 3 */
+#define REG_MACID2_8814A					0x1620
+#define REG_BSSID2_8814A					0x1628
+/* Hardware Port 4 */
+#define REG_MACID3_8814A					0x1630
+#define REG_BSSID3_8814A					0x1638
+/* Hardware Port 5 */
+#define REG_MACID4_8814A					0x1640
+#define REG_BSSID4_8814A					0x1648
+
+#define REG_ASSOCIATED_BFMEE_SEL_8814A	0x0714
+#define REG_SND_PTCL_CTRL_8814A			0x0718
+#define REG_IQ_DUMP_8814A					0x07C0
+
+#define REG_CPU_DMEM_CON_8814A			0x1080
+
+/**** page 19 ****/
+/* TX BeamForming */
+#define	REG_BB_TXBF_ANT_SET_BF1				0x19ac
+#define	REG_BB_TXBF_ANT_SET_BF0				0x19b4
+
+/*	0x1200h ~ 0x12FFh	DDMA CTRL
+ *
+ * ----------------------------------------------------- */
+#define REG_DDMA_CH0SA                   0x1200
+#define REG_DDMA_CH0DA                   0x1204
+#define REG_DDMA_CH0CTRL                0x1208
+#define REG_DDMA_CH1SA                   0x1210
+#define REG_DDMA_CH1DA	0x1214
+#define REG_DDMA_CH1CTRL                0x1218
+#define REG_DDMA_CH2SA                   0x1220
+#define REG_DDMA_CH2DA                   0x1224
+#define REG_DDMA_CH2CTRL                0x1228
+#define REG_DDMA_CH3SA                   0x1230
+#define REG_DDMA_CH3DA                   0x1234
+#define REG_DDMA_CH3CTRL                0x1238
+#define REG_DDMA_CH4SA                   0x1240
+#define REG_DDMA_CH4DA                   0x1244
+#define REG_DDMA_CH4CTRL                0x1248
+#define REG_DDMA_CH5SA                   0x1250
+#define REG_DDMA_CH5DA                   0x1254
+#define REG_DDMA_CH5CTRL                0x1258
+#define REG_DDMA_INT_MSK                0x12E0
+#define REG_DDMA_CHSTATUS              0x12E8
+#define REG_DDMA_CHKSUM                 0x12F0
+#define REG_DDMA_MONITER                0x12FC
+
+#define REG_Q0_Q1_INFO_8814A		0x1400
+#define REG_Q2_Q3_INFO_8814A		0x1404
+#define REG_Q4_Q5_INFO_8814A		0x1408
+#define REG_Q6_Q7_INFO_8814A		0x140C
+#define REG_MGQ_HIQ_INFO_8814A	0x1410
+#define REG_CMDQ_BCNQ_INFO_8814A	0x1414
+
+#define DDMA_LEN_MASK		0x0001FFFF
+#define FW_CHKSUM_DUMMY_SZ		8
+#define DDMA_CH_CHKSUM_CNT		BIT(24)
+#define DDMA_RST_CHKSUM_STS		BIT(25)
+#define DDMA_MODE_BLOCK_CPU		BIT(26)
+#define DDMA_CHKSUM_FAIL			BIT(27)
+#define DDMA_DA_W_DISABLE			BIT(28)
+#define DDMA_CHKSUM_EN			BIT(29)
+#define DDMA_CH_OWN	BIT(31)
+
+
+/* 3081 FWDL */
+#define FWDL_EN                 BIT0
+#define IMEM_BOOT_DL_RDY        BIT1
+#define IMEM_BOOT_CHKSUM_FAIL   BIT2
+#define IMEM_DL_RDY             BIT3
+#define IMEM_CHKSUM_OK        BIT4
+#define DMEM_DL_RDY             BIT5
+#define DMEM_CHKSUM_OK        BIT6
+#define EMEM_DL_RDY             BIT7
+#define EMEM_CHKSUM_FAIL        BIT8
+#define EMEM_TXBUF_DL_RDY       BIT9
+#define EMEM_TXBUF_CHKSUM_FAIL  BIT10
+#define CPU_CLK_SWITCH_BUSY     BIT11
+#define CPU_CLK_SEL             (BIT12 | BIT13)
+#define FWDL_OK                 BIT14
+#define FW_INIT_RDY             BIT15
+#define R_EN_BOOT_FLASH         BIT20
+
+#define OCPBASE_IMEM_3081        0x00000000
+#define OCPBASE_DMEM_3081        0x00200000
+#define OCPBASE_RPTBUF_3081      0x18660000
+#define OCPBASE_RXBUF2_3081      0x18680000
+#define OCPBASE_RXBUF_3081       0x18700000
+#define OCPBASE_TXBUF_3081       0x18780000
+
+
+#define REG_FAST_EDCA_VOVI_SETTING_8814A 0x1448
+#define REG_FAST_EDCA_BEBK_SETTING_8814A 0x144C
+
+
+/* -----------------------------------------------------
+ *   */
+
+
+/* -----------------------------------------------------
+ *
+ *	Redifine 8192C register definition for compatibility
+ *
+ * ----------------------------------------------------- */
+
+/* TODO: use these definition when using REG_xxx naming rule.
+ * NOTE: DO NOT Remove these definition. Use later. */
+#define	EFUSE_CTRL_8814A					REG_EFUSE_CTRL_8814A		/* E-Fuse Control. */
+#define	EFUSE_TEST_8814A					REG_LDO_EFUSE_CTRL_8814A		/* E-Fuse Test. */
+#define	MSR_8814A							(REG_CR_8814A + 2)		/* Media Status register */
+#define	ISR_8814A							REG_HISR0_8814A
+#define	TSFR_8814A							REG_TSFTR_8814A			/* Timing Sync Function Timer Register. */
+
+#define PBP_8814A							REG_PBP_8814A
+
+/* Redifine MACID register, to compatible prior ICs. */
+#define	IDR0_8814A							REG_MACID_8814A			/* MAC ID Register, Offset 0x0050-0x0053 */
+#define	IDR4_8814A							(REG_MACID_8814A + 4)	/* MAC ID Register, Offset 0x0054-0x0055 */
+
+
+/*
+ * 9. Security Control Registers	(Offset: )
+ *   */
+#define	RWCAM_8814A						REG_CAMCMD_8814A		/* IN 8190 Data Sheet is called CAMcmd */
+#define	WCAMI_8814A						REG_CAMWRITE_8814A		/* Software write CAM input content */
+#define	RCAMO_8814A						REG_CAMREAD_8814A		/* Software read/write CAM config */
+#define	CAMDBG_8814A						REG_CAMDBG_8814A
+#define	SECR_8814A							REG_SECCFG_8814A		/* Security Configuration Register */
+
+
+/* ----------------------------------------------------------------------------
+ * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
+ * ---------------------------------------------------------------------------- */
+#define	IMR_DISABLED_8814A					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define	IMR_TIMER2_8814A					BIT31		/* Timeout interrupt 2 */
+#define	IMR_TIMER1_8814A					BIT30		/* Timeout interrupt 1	 */
+#define	IMR_PSTIMEOUT_8814A				BIT29		/* Power Save Time Out Interrupt */
+#define	IMR_GTINT4_8814A					BIT28		/* When GTIMER4 expires, this bit is set to 1	 */
+#define	IMR_GTINT3_8814A					BIT27		/* When GTIMER3 expires, this bit is set to 1	 */
+#define	IMR_TXBCN0ERR_8814A				BIT26		/* Transmit Beacon0 Error			 */
+#define	IMR_TXBCN0OK_8814A					BIT25		/* Transmit Beacon0 OK			 */
+#define	IMR_TSF_BIT32_TOGGLE_8814A		BIT24		/* TSF Timer BIT32 toggle indication interrupt			 */
+#define	IMR_BCNDMAINT0_8814A				BIT20		/* Beacon DMA Interrupt 0			 */
+#define	IMR_BCNDERR0_8814A					BIT16		/* Beacon Queue DMA OK0			 */
+#define	IMR_HSISR_IND_ON_INT_8814A		BIT15		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define	IMR_BCNDMAINT_E_8814A				BIT14		/* Beacon DMA Interrupt Extension for Win7			 */
+#define	IMR_ATIMEND_8814A					BIT12		/* CTWidnow End or ATIM Window End */
+#define	IMR_C2HCMD_8814A					BIT10		/* CPU to Host Command INT Status, Write 1 clear	 */
+#define	IMR_CPWM2_8814A					BIT9			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_CPWM_8814A						BIT8			/* CPU power Mode exchange INT Status, Write 1 clear	 */
+#define	IMR_HIGHDOK_8814A					BIT7			/* High Queue DMA OK	 */
+#define	IMR_MGNTDOK_8814A					BIT6			/* Management Queue DMA OK	 */
+#define	IMR_BKDOK_8814A					BIT5			/* AC_BK DMA OK		 */
+#define	IMR_BEDOK_8814A					BIT4			/* AC_BE DMA OK	 */
+#define	IMR_VIDOK_8814A					BIT3			/* AC_VI DMA OK		 */
+#define	IMR_VODOK_8814A					BIT2			/* AC_VO DMA OK	 */
+#define	IMR_RDU_8814A						BIT1			/* Rx Descriptor Unavailable	 */
+#define	IMR_ROK_8814A						BIT0			/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define	IMR_MCUERR_8814A						BIT28		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT7_8814A				BIT27		/* Beacon DMA Interrupt 7 */
+#define	IMR_BCNDMAINT6_8814A				BIT26		/* Beacon DMA Interrupt 6 */
+#define	IMR_BCNDMAINT5_8814A				BIT25		/* Beacon DMA Interrupt 5 */
+#define	IMR_BCNDMAINT4_8814A				BIT24		/* Beacon DMA Interrupt 4 */
+#define	IMR_BCNDMAINT3_8814A				BIT23		/* Beacon DMA Interrupt 3 */
+#define	IMR_BCNDMAINT2_8814A				BIT22		/* Beacon DMA Interrupt 2 */
+#define	IMR_BCNDMAINT1_8814A				BIT21		/* Beacon DMA Interrupt 1 */
+#define	IMR_BCNDOK7_8814A					BIT20		/* Beacon Queue DMA OK Interrup 7 */
+#define	IMR_BCNDOK6_8814A					BIT19		/* Beacon Queue DMA OK Interrup 6 */
+#define	IMR_BCNDOK5_8814A					BIT18		/* Beacon Queue DMA OK Interrup 5 */
+#define	IMR_BCNDOK4_8814A					BIT17		/* Beacon Queue DMA OK Interrup 4 */
+#define	IMR_BCNDOK3_8814A					BIT16		/* Beacon Queue DMA OK Interrup 3 */
+#define	IMR_BCNDOK2_8814A					BIT15		/* Beacon Queue DMA OK Interrup 2 */
+#define	IMR_BCNDOK1_8814A					BIT14		/* Beacon Queue DMA OK Interrup 1 */
+#define	IMR_ATIMEND_E_8814A				BIT13		/* ATIM Window End Extension for Win7 */
+#define	IMR_TXERR_8814A					BIT11		/* Tx Error Flag Interrupt Status, write 1 clear. */
+#define	IMR_RXERR_8814A					BIT10		/* Rx Error Flag INT Status, Write 1 clear */
+#define	IMR_TXFOVW_8814A					BIT9			/* Transmit FIFO Overflow */
+#define	IMR_RXFOVW_8814A					BIT8			/* Receive FIFO Overflow */
+
+
+#ifdef CONFIG_PCI_HCI
+	#define IMR_TX_MASK			(IMR_VODOK_8814A | IMR_VIDOK_8814A | IMR_BEDOK_8814A | IMR_BKDOK_8814A | IMR_MGNTDOK_8814A | IMR_HIGHDOK_8814A)
+
+	#define RT_BCN_INT_MASKS	(IMR_BCNDMAINT0_8814A | IMR_TXBCN0OK_8814A | IMR_TXBCN0ERR_8814A | IMR_BCNDERR0_8814A)
+
+	#define RT_AC_INT_MASKS	(IMR_VIDOK_8814A | IMR_VODOK_8814A | IMR_BEDOK_8814A | IMR_BKDOK_8814A)
+#endif
+
+
+/*===================================================================
+=====================================================================
+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!!!!!!
+=====================================================================
+=====================================================================*/
+
+
+/* -----------------------------------------------------
+ *
+ *	0xFE00h ~ 0xFE55h	USB Configuration
+ *
+ * ----------------------------------------------------- */
+
+/* 2 Special Option */
+#define USB_AGG_EN_8814A			BIT(7)
+#define REG_USB_HRPWM_U3			0xF052
+
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8814A       (2048-1)	/* 20130415 KaiYuan add for 8814 */
+
+#endif /* __RTL8814A_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_sreset.h
index af26460ad935..23649b882787 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_sreset.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,20 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL88814A_SRESET_H_
 #define _RTL8814A_SRESET_H_
 
 #include <rtw_sreset.h>
 
 #ifdef DBG_CONFIG_ERROR_DETECT
-extern void rtl8814_sreset_xmit_status_check(_adapter *padapter);
-extern void rtl8814_sreset_linked_status_check(_adapter *padapter);
+	extern void rtl8814_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8814_sreset_linked_status_check(_adapter *padapter);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_xmit.h
index c005bc5fb3dc..c0e8260a0382 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8814a_xmit.h
@@ -1,309 +1,310 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8814A_XMIT_H__
-#define __RTL8814A_XMIT_H__
-
-typedef struct txdescriptor_8814
-{
-	// Offset 0
-	u32 pktlen:16;
-	u32 offset:8;
-	u32 bmc:1;
-	u32 htc:1;
-	u32 ls:1;
-}TXDESC_8814, *PTXDESC_8814;
-
-
-#define OFFSET_SZ	0
-#define OFFSET_SHT	16
-
-
-
-#ifdef CONFIG_SDIO_HCI
-#define SET_TX_DESC_SDIO_TXSEQ_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
-#endif //CONFIG_SDIO_HCI
-
-//-----------------------------------------------------------------
-//	RTL8814A TX BUFFER DESC
-//-----------------------------------------------------------------
-/*
-- Each TXBD has 4 segment.
- -- For 32 bit, each segment is 8 bytes.
- -- For 64 bit, each segment is 16 bytes.
-*/
-#if 0
-#if 1 /* 32 bit */
-#define SET_TX_EXTBUFF_DESC_LEN_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*8), 0, 16, __Value)
-#define SET_TX_EXTBUFF_DESC_ADDR_LOW_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*8)+4, 0, 32, __Value)
-#else /* 64 bit */
-#define SET_TX_EXTBUFF_DESC_LEN_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16), 0, 16, __Value)
-#define SET_TX_EXTBUFF_DESC_ADDR_LOW_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16)+4, 0, 32, __Value)
-#endif
-#define SET_TX_EXTBUFF_DESC_ADDR_HIGH_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16)+8, 0, 32, __Value)
-#endif
-/*c2h-DWORD 2*/
-#define GET_RX_STATUS_DESC_RPT_SEL_8814A(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+8, 28, 1)
-
-//=========================================================
-// for Txfilldescroptor8814Ae, fill the desc content.
-#if 1 /* 32 bit */
-#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8), 0, 16, __Valeu)
-#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8), 31, 1, __Valeu)
-#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8)+4, 0, 32, __Valeu)
-#else /* 64 bit */
-#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 0, 16, __Valeu)
-#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 31, 1, __Valeu)
-#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+4, 0, 32, __Valeu)
-#endif
-#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+8, 0, 32, __Valeu)
-
-//=========================================================
-
-//TX buffer 
-//=============
-// Dword 0
-#define SET_TX_BUFF_DESC_LEN_0_8814A(__pTxDesc, __Valeu) 			SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Valeu)
-#define SET_TX_BUFF_DESC_PSB_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
-#define SET_TX_BUFF_DESC_OWN_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
-#define GET_TX_BUFF_DESC_OWN_8814A(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
-
-// Dword 1
-#define SET_TX_BUFF_DESC_ADDR_LOW_0_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
-#define GET_TX_BUFF_DESC_ADDR_LOW_0_8814A(__pTxDesc)			LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
-// Dword 2
-#define SET_TX_BUFF_DESC_ADDR_HIGH_0_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0, 32, __Value)
-#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8814A(__pTxDesc)			LE_BITS_TO_4BYTE(__pTxDesc+8, 0, 32)
-// Dword 3 //RESERVED 0
-
-#if 0 /* 64 bit */
-// Dword 4
-#define SET_TX_BUFF_DESC_LEN_1_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 16, __Value)
-#define SET_TX_BUFF_DESC_AMSDU_1_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 31, 1, __Value)
-// Dword 5
-#define SET_TX_BUFF_DESC_ADDR_LOW_1_8814A(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 32, __Value)
-// Dword 6
-#define SET_TX_BUFF_DESC_ADDR_HIGH_1_8814A(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 32, __Value)
-// Dword 7 //RESERVED 0
-// Dword 8
-#define SET_TX_BUFF_DESC_LEN_2_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 16, __Value)
-#define SET_TX_BUFF_DESC_AMSDU_2_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 31, 1, __Value)
-// Dword 9
-#define SET_TX_BUFF_DESC_ADDR_LOW_2_8814A(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 32, __Value)
-// Dword 10
-#define SET_TX_BUFF_DESC_ADDR_HIGH_2_8814A(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
-// Dword 11 //RESERVED 0
-// Dword 12
-#define SET_TX_BUFF_DESC_LEN_3_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 16, __Value)
-#define SET_TX_BUFF_DESC_AMSDU_3_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 31, 1, __Value)
-// Dword 13
-#define SET_TX_BUFF_DESC_ADDR_LOW_3_8814A(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+52, 0, 32, __Value)
-// Dword 14
-#define SET_TX_BUFF_DESC_ADDR_HIGH_3_8814A(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+56, 0, 32, __Value)
-// Dword 15 //RESERVED 0
-#endif
-
-//=====Desc content
-//TX Info
-//=============
-// Dword 0
-#define SET_TX_DESC_PKT_SIZE_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
-#define GET_TX_DESC_PKT_SIZE_8814A(__pTxDesc)									LE_BITS_TO_4BYTE( __pTxDesc, 0, 16)
-#define SET_TX_DESC_OFFSET_8814A(__pTxDesc, __Value) 							SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
-#define GET_TX_DESC_OFFSET_8814A(__pTxDesc)									LE_BITS_TO_4BYTE( __pTxDesc, 16, 8)
-#define SET_TX_DESC_BMC_8814A(__pTxDesc, __Value) 							SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
-#define SET_TX_DESC_HTC_8814A(__pTxDesc, __Value) 								SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
-#define SET_TX_DESC_LAST_SEG_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
-#define SET_TX_DESC_LINIP_8814A(__pTxDesc, __Value) 							SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
-#define SET_TX_DESC_AMSDU_PAD_EN_8814A(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
-#define SET_TX_DESC_NO_ACM_8814A(__pTxDesc, __Value) 							SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
-#define SET_TX_DESC_GF_8814A(__pTxDesc, __Value) 								SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
-#define SET_TX_DESC_DISQSELSEQ_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
-
-// Dword 1
-#define SET_TX_DESC_MACID_8814A(__pTxDesc, __Value) 							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
-#define SET_TX_DESC_QUEUE_SEL_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
-#define SET_TX_DESC_RDG_NAV_EXT_8814A(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
-#define SET_TX_DESC_LSIG_TXOP_EN_8814A(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
-#define SET_TX_DESC_PIFS_8814A(__pTxDesc, __Value) 							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
-#define SET_TX_DESC_RATE_ID_8814A(__pTxDesc, __Value) 							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
-#define SET_TX_DESC_EN_DESC_ID_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
-#define SET_TX_DESC_SEC_TYPE_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
-#define SET_TX_DESC_PKT_OFFSET_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
-#define SET_TX_DESC_MORE_DATA_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
-#define SET_TX_DESC_TXOP_PS_CAP_8814A(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 30, 1, __Value)
-#define SET_TX_DESC_TXOP_PS_MODE_8814A(__pTxDesc, __Value) 					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 31, 1, __Value)
-
-
-// Dword 2
-#define SET_TX_DESC_PAID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value) 
-#define SET_TX_DESC_CCA_RTS_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
-#define SET_TX_DESC_AGG_ENABLE_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
-#define SET_TX_DESC_RDG_ENABLE_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
-#define SET_TX_DESC_NULL_0_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
-#define SET_TX_DESC_NULL_1_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
-#define SET_TX_DESC_BK_8814A(__pTxDesc, __Value) 				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
-#define SET_TX_DESC_MORE_FRAG_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
-#define GET_TX_DESC_MORE_FRAG_8814A(__pTxDesc)				LE_BITS_TO_4BYTE( __pTxDesc+8, 17, 1)
-#define SET_TX_DESC_RAW_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
-#define SET_TX_DESC_SPE_RPT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
-#define SET_TX_DESC_AMPDU_DENSITY_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
-#define SET_TX_DESC_BT_NULL_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
-#define SET_TX_DESC_GID_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
-#define SET_TX_DESC_HW_AES_IV_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 31, 1, __Value)
-
-
-// Dword 3
-#define SET_TX_DESC_WHEADER_LEN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 5, __Value)
-#define SET_TX_DESC_EARLY_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
-#define SET_TX_DESC_HW_SSN_SEL_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
-#define SET_TX_DESC_USE_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
-#define SET_TX_DESC_DISABLE_RTS_FB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
-#define SET_TX_DESC_DISABLE_FB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
-#define SET_TX_DESC_CTS2SELF_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
-#define SET_TX_DESC_RTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
-#define SET_TX_DESC_HW_RTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
-#define SET_TX_DESC_CHECK_EN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 1, __Value)
-#define SET_TX_DESC_NAV_USE_HDR_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
-#define SET_TX_DESC_USE_MAX_LEN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
-#define SET_TX_DESC_MAX_AGG_NUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
-#define SET_TX_DESC_NDPA_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
-#define SET_TX_DESC_AMPDU_MAX_TIME_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
-
-// Dword 4
-#define SET_TX_DESC_TX_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
-#define SET_TX_DESC_TRY_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
-#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
-#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
-#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
-#define SET_TX_DESC_DATA_RETRY_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
-#define SET_TX_DESC_RTS_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
-#define SET_TX_DESC_PCTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
-#define SET_TX_DESC_PCTS_MASK_IDX_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
-
-
-// Dword 5
-#define SET_TX_DESC_DATA_SC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
-#define SET_TX_DESC_DATA_SHORT_8814A(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
-#define SET_TX_DESC_DATA_BW_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
-#define SET_TX_DESC_DATA_LDPC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
-#define SET_TX_DESC_DATA_STBC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
-#define SET_TX_DESC_CTROL_STBC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
-#define SET_TX_DESC_RTS_SHORT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
-#define SET_TX_DESC_RTS_SC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
-#define SET_TX_DESC_SIGNALING_TA_PKT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 17, 1, __Value)
-#define SET_TX_DESC_PORT_ID_8814A(__pTxDesc,__Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 21, 3, __Value)//20130415 KaiYuan add for 8814
-#define SET_TX_DESC_TX_ANT_8814A(__pTxDesc,__Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
-#define SET_TX_DESC_TX_POWER_OFFSET_8814A(__pTxDesc,__Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
-
-// Dword 6
-#define SET_TX_DESC_SW_DEFINE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
-#define SET_TX_DESC_MBSSID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
-#define SET_TX_DESC_ANTSEL_A_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
-#define SET_TX_DESC_ANTSEL_B_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
-#define SET_TX_DESC_ANT_MAPA_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 2, __Value)
-#define SET_TX_DESC_ANT_MAPB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 24, 2, __Value)
-#define SET_TX_DESC_ANT_MAPC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 26, 2, __Value)
-#define SET_TX_DESC_ANT_MAPD_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 28, 2, __Value)
-
-
-// Dword 7
-#if(DEV_BUS_TYPE == RT_PCI_INTERFACE)
-#define SET_TX_DESC_TX_BUFFER_SIZE_8814A(__pTxDesc, __Value) 		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
-#define SET_TX_DESC_TX_DESC_CHECKSUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#endif
-#define SET_TX_DESC_NTX_MAP_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 20, 4, __Value)
-#define SET_TX_DESC_USB_TXAGG_NUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-
-
-// Dword 8
-#define SET_TX_DESC_RTS_RC_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
-#define SET_TX_DESC_BAR_RTY_TH_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
-#define SET_TX_DESC_DATA_RC_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
-#define SET_TX_DESC_EN_HWEXSEQ_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 14, 1, __Value)
-#define SET_TX_DESC_HWSEQ_EN_8814A(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
-#if(DEV_BUS_TYPE != RT_SDIO_INTERFACE)
-#define SET_TX_DESC_NEXT_HEAD_PAGE_L_8814A(__pTxDesc,__Value)(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
-#else
-#define SET_TX_DESC_SDIO_SEQ_8814A(__pTxDesc,__Value)(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value) //20130415 KaiYuan add for 8814AS
-#endif
-#define SET_TX_DESC_TAIL_PAGE_L_8814A(__pTxDesc,__Value)(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
-
-// Dword 9
-#define SET_TX_DESC_PADDING_LENGTH_8814A(__pTxDesc, __Value) 						SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
-#define SET_TX_DESC_TXBF_PATH_8814A(__pTxDesc, __Value) 								SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 11, 1, __Value)
-#define SET_TX_DESC_SEQ_8814A(__pTxDesc, __Value) 										SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
-#define SET_TX_DESC_NEXT_HEAD_PAGE_H_8814A(__pTxDesc,__Value)(__pTxDesc, __Value) 	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 4, __Value)
-#define SET_TX_DESC_TAIL_PAGE_H_8814A(__pTxDesc,__Value)(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 28, 4, __Value)
-
-
-
-#define SET_EARLYMODE_PKTNUM_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
-#define SET_EARLYMODE_LEN0_8814A(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
-#define SET_EARLYMODE_LEN1_1_8814A(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
-#define SET_EARLYMODE_LEN1_2_8814A(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
-#define SET_EARLYMODE_LEN2_8814A(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
-#define SET_EARLYMODE_LEN3_8814A(__pAddr, __Value) 					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
-
-
-void rtl8814a_cal_txdesc_chksum(u8 *ptxdesc);
-void rtl8814a_fill_fake_txdesc(PADAPTER	padapter,u8*pDesc,u32 BufferLen,u8 IsPsPoll,u8	IsBTQosNull, u8 bDataFrame);
-void rtl8814a_fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
-void rtl8814a_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
-void rtl8814a_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
-
-#ifdef CONFIG_USB_HCI
-s32 rtl8814au_init_xmit_priv(PADAPTER padapter);
-void rtl8814au_free_xmit_priv(PADAPTER padapter);
-s32 rtl8814au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8814au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	 rtl8814au_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-s32 rtl8814au_xmit_buf_handler(PADAPTER padapter);
-void rtl8814au_xmit_tasklet(void *priv);
-s32 rtl8814au_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-#endif //CONFIG_USB_HCI
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8814ae_init_xmit_priv(PADAPTER padapter);
-void rtl8814ae_free_xmit_priv(PADAPTER padapter);
-struct xmit_buf *rtl8814ae_dequeue_xmitbuf(struct rtw_tx_ring *ring);
-void rtl8814ae_xmitframe_resume(_adapter *padapter);
-s32 rtl8814ae_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8814ae_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	rtl8814ae_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-void rtl8814ae_xmit_tasklet(void *priv);
-#endif
-
-void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag, u8 *ptxdesc);
-u8 
-SCMapping_8814(
-	IN	PADAPTER		Adapter,
-	IN	struct pkt_attrib	*pattrib
-);
-
-u8 
-BWMapping_8814(
-	IN	PADAPTER		Adapter,
-	IN	struct pkt_attrib	*pattrib
-);
-
-
-#endif /* __RTL8814_XMIT_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8814A_XMIT_H__
+#define __RTL8814A_XMIT_H__
+
+typedef struct txdescriptor_8814 {
+	/* Offset 0 */
+	u32 pktlen:16;
+	u32 offset:8;
+	u32 bmc:1;
+	u32 htc:1;
+	u32 ls:1;
+} TXDESC_8814, *PTXDESC_8814;
+
+
+#define OFFSET_SZ	0
+#define OFFSET_SHT	16
+
+
+
+#ifdef CONFIG_SDIO_HCI
+	#define SET_TX_DESC_SDIO_TXSEQ_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
+#endif /* CONFIG_SDIO_HCI */
+
+/* -----------------------------------------------------------------
+ *	RTL8814A TX BUFFER DESC
+ * -----------------------------------------------------------------
+ *
+- Each TXBD has 4 segment.
+ -- For 32 bit, each segment is 8 bytes.
+ -- For 64 bit, each segment is 16 bytes.
+*/
+#if 0
+	#if 1 /* 32 bit */
+		#define SET_TX_EXTBUFF_DESC_LEN_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*8), 0, 16, __Value)
+		#define SET_TX_EXTBUFF_DESC_ADDR_LOW_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*8)+4, 0, 32, __Value)
+	#else /* 64 bit */
+		#define SET_TX_EXTBUFF_DESC_LEN_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16), 0, 16, __Value)
+		#define SET_TX_EXTBUFF_DESC_ADDR_LOW_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16)+4, 0, 32, __Value)
+	#endif
+	#define SET_TX_EXTBUFF_DESC_ADDR_HIGH_8814A(__pTxDesc, __Value, __Set) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Set*16)+8, 0, 32, __Value)
+#endif
+/*c2h-DWORD 2*/
+#define GET_RX_STATUS_DESC_RPT_SEL_8814A(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+8, 28, 1)
+
+/* *********************************************************
+ * for Txfilldescroptor8814Ae, fill the desc content. */
+#if 1 /* 32 bit */
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*8)+4, 0, 32, __Valeu)
+#else /* 64 bit */
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+4, 0, 32, __Valeu)
+#endif
+#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+8, 0, 32, __Valeu)
+
+/* ********************************************************* */
+
+/* TX buffer
+ * *************
+ * Dword 0 */
+#define SET_TX_BUFF_DESC_LEN_0_8814A(__pTxDesc, __Valeu)			SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+#define GET_TX_BUFF_DESC_OWN_8814A(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+/* Dword 1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_LOW_0_8814A(__pTxDesc)			LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+/* Dword 2 */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8814A(__pTxDesc)			LE_BITS_TO_4BYTE(__pTxDesc+8, 0, 32)
+/* Dword 3 */ /* RESERVED 0 */
+
+#if 0 /* 64 bit */
+	/* Dword 4 */
+	#define SET_TX_BUFF_DESC_LEN_1_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 16, __Value)
+	#define SET_TX_BUFF_DESC_AMSDU_1_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 31, 1, __Value)
+	/* Dword 5 */
+	#define SET_TX_BUFF_DESC_ADDR_LOW_1_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 32, __Value)
+	/* Dword 6 */
+	#define SET_TX_BUFF_DESC_ADDR_HIGH_1_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 32, __Value)
+	/* Dword 7 */ /* RESERVED 0 */
+	/* Dword 8 */
+	#define SET_TX_BUFF_DESC_LEN_2_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 16, __Value)
+	#define SET_TX_BUFF_DESC_AMSDU_2_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 31, 1, __Value)
+	/* Dword 9 */
+	#define SET_TX_BUFF_DESC_ADDR_LOW_2_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 32, __Value)
+	/* Dword 10 */
+	#define SET_TX_BUFF_DESC_ADDR_HIGH_2_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+40, 0, 32, __Value)
+	/* Dword 11 */ /* RESERVED 0 */
+	/* Dword 12 */
+	#define SET_TX_BUFF_DESC_LEN_3_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 0, 16, __Value)
+	#define SET_TX_BUFF_DESC_AMSDU_3_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+48, 31, 1, __Value)
+	/* Dword 13 */
+	#define SET_TX_BUFF_DESC_ADDR_LOW_3_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+52, 0, 32, __Value)
+	/* Dword 14 */
+	#define SET_TX_BUFF_DESC_ADDR_HIGH_3_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+56, 0, 32, __Value)
+	/* Dword 15 */ /* RESERVED 0 */
+#endif
+
+/* *****Desc content
+ * TX Info
+ * *************
+ * Dword 0 */
+#define SET_TX_DESC_PKT_SIZE_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define GET_TX_DESC_PKT_SIZE_8814A(__pTxDesc)									LE_BITS_TO_4BYTE(__pTxDesc, 0, 16)
+#define SET_TX_DESC_OFFSET_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define GET_TX_DESC_OFFSET_8814A(__pTxDesc)									LE_BITS_TO_4BYTE(__pTxDesc, 16, 8)
+#define SET_TX_DESC_BMC_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8814A(__pTxDesc, __Value)								SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_LAST_SEG_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc, 26, 1, __Value)
+#define SET_TX_DESC_LINIP_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 28, 1, __Value)
+#define SET_TX_DESC_AMSDU_PAD_EN_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8814A(__pTxDesc, __Value)								SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+#define SET_TX_DESC_DISQSELSEQ_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8814A(__pTxDesc, __Value)							SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_CAP_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 30, 1, __Value)
+#define SET_TX_DESC_TXOP_PS_MODE_8814A(__pTxDesc, __Value)					SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 31, 1, __Value)
+
+
+/* Dword 2 */
+#define SET_TX_DESC_PAID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0,  9, __Value)
+#define SET_TX_DESC_CCA_RTS_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL_0_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL_1_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_8814A(__pTxDesc, __Value)				SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define GET_TX_DESC_MORE_FRAG_8814A(__pTxDesc)				LE_BITS_TO_4BYTE(__pTxDesc+8, 17, 1)
+#define SET_TX_DESC_RAW_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_SPE_RPT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_NULL_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_GID_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 6, __Value)
+#define SET_TX_DESC_HW_AES_IV_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 31, 1, __Value)
+
+
+/* Dword 3 */
+#define SET_TX_DESC_WHEADER_LEN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 0, 5, __Value)
+#define SET_TX_DESC_EARLY_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HW_SSN_SEL_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_CHECK_EN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TRY_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_ENABLE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8814A(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_CTROL_STBC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_SIGNALING_TA_PKT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 17, 1, __Value)
+#define SET_TX_DESC_PORT_ID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 21, 3, __Value)/* 20130415 KaiYuan add for 8814 */
+#define SET_TX_DESC_TX_ANT_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 4, __Value)
+#define SET_TX_DESC_TX_POWER_OFFSET_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_ANTSEL_A_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+#define SET_TX_DESC_ANTSEL_B_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 19, 3, __Value)
+#define SET_TX_DESC_ANT_MAPA_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 22, 2, __Value)
+#define SET_TX_DESC_ANT_MAPB_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 24, 2, __Value)
+#define SET_TX_DESC_ANT_MAPC_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 26, 2, __Value)
+#define SET_TX_DESC_ANT_MAPD_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 28, 2, __Value)
+
+
+/* Dword 7 */
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	#define SET_TX_DESC_TX_BUFFER_SIZE_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#else
+	#define SET_TX_DESC_TX_DESC_CHECKSUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+#define SET_TX_DESC_NTX_MAP_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 20, 4, __Value)
+#define SET_TX_DESC_USB_TXAGG_NUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+
+/* Dword 8 */
+#define SET_TX_DESC_RTS_RC_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RTY_TH_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_EN_HWEXSEQ_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 14, 1, __Value)
+#define SET_TX_DESC_HWSEQ_EN_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#if (DEV_BUS_TYPE != RT_SDIO_INTERFACE)
+	#define SET_TX_DESC_NEXT_HEAD_PAGE_L_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#else
+	#define SET_TX_DESC_SDIO_SEQ_8814A(__pTxDesc, __Value)(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value) /* 20130415 KaiYuan add for 8814AS */
+#endif
+#define SET_TX_DESC_TAIL_PAGE_L_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LENGTH_8814A(__pTxDesc, __Value)						SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_TXBF_PATH_8814A(__pTxDesc, __Value)								SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 11, 1, __Value)
+#define SET_TX_DESC_SEQ_8814A(__pTxDesc, __Value)										SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_NEXT_HEAD_PAGE_H_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 4, __Value)
+#define SET_TX_DESC_TAIL_PAGE_H_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 28, 4, __Value)
+
+
+
+#define SET_EARLYMODE_PKTNUM_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,  __Value)
+#define SET_EARLYMODE_LEN3_8814A(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+
+void rtl8814a_cal_txdesc_chksum(u8 *ptxdesc);
+void rtl8814a_fill_fake_txdesc(PADAPTER	padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8	IsBTQosNull, u8 bDataFrame);
+void rtl8814a_fill_txdesc_sectype(struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8814a_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+void rtl8814a_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc);
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8814au_init_xmit_priv(PADAPTER padapter);
+	void rtl8814au_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8814au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8814au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8814au_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8814au_xmit_buf_handler(PADAPTER padapter);
+	void rtl8814au_xmit_tasklet(void *priv);
+	s32 rtl8814au_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8814ae_init_xmit_priv(PADAPTER padapter);
+	void rtl8814ae_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8814ae_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void rtl8814ae_xmitframe_resume(_adapter *padapter);
+	s32 rtl8814ae_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8814ae_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8814ae_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8814ae_xmit_tasklet(void *priv);
+#ifdef CONFIG_XMIT_THREAD_MODE
+	s32 rtl8814ae_xmit_buf_handler(_adapter *padapter);
+#endif
+#endif
+
+void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, u8 *ptxdesc);
+u8
+SCMapping_8814(
+	IN	PADAPTER		Adapter,
+	IN	struct pkt_attrib	*pattrib
+);
+
+u8
+BWMapping_8814(
+	IN	PADAPTER		Adapter,
+	IN	struct pkt_attrib	*pattrib
+);
+
+
+#endif /* __RTL8814_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_spec.h
index ce0bac4d4742..ead9de2db0cb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_spec.h
@@ -1,108 +1,91 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
-#ifndef __RTL8821A_SPEC_H__
-#define __RTL8821A_SPEC_H__
-
-#include <drv_conf.h>
-// This file should based on "hal_com_reg.h"
-#include <hal_com_reg.h>
-// Because 8812a and 8821a is the same serial,
-// most of 8821a register definitions are the same as 8812a.
-#include <rtl8812a_spec.h>
-
-
-//============================================================
-//       8821A Regsiter offset definition
-//============================================================
-
-//============================================================
-// MAC register
-//============================================================
-
-//-----------------------------------------------------
-//	0x0000h ~ 0x00FFh	System Configuration
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//	0x0100h ~ 0x01FFh	MACTOP General Configuration
-//-----------------------------------------------------
-#define REG_WOWLAN_WAKE_REASON          REG_MCUTST_WOWLAN
-
-//-----------------------------------------------------
-//	0x0200h ~ 0x027Fh	TXDMA Configuration
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//	0x0280h ~ 0x02FFh	RXDMA Configuration
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//	0x0300h ~ 0x03FFh	PCIe
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//	0x0400h ~ 0x047Fh	Protocol Configuration
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//	0x0500h ~ 0x05FFh	EDCA Configuration
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-//	0x0600h ~ 0x07FFh	WMAC Configuration
-//-----------------------------------------------------
-
-
-//============================================================
-// SDIO Bus Specification
-//============================================================
-
-//-----------------------------------------------------
-// SDIO CMD Address Mapping
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-// I/O bus domain (Host)
-//-----------------------------------------------------
-
-//-----------------------------------------------------
-// SDIO register
-//-----------------------------------------------------
-#undef SDIO_REG_HCPWM1
-#define SDIO_REG_FREE_TXPG2		0x024
-#define SDIO_REG_HCPWM1			0x025
-
-
-//============================================================
-//       Regsiter Bit and Content definition
-//============================================================
-
-//========================================================
-// General definitions
-//========================================================
-
-#define MACID_NUM_8821A 128
-#define SEC_CAM_ENT_NUM_8821A 64
-#define NSS_NUM_8821A 1
-#define BAND_CAP_8821A (BAND_CAP_2G | BAND_CAP_5G)
-#define BW_CAP_8821A (BW_CAP_20M | BW_CAP_40M | BW_CAP_80M)
-#define PROTO_CAP_8821A (PROTO_CAP_11B|PROTO_CAP_11G|PROTO_CAP_11N|PROTO_CAP_11AC)
-
-#endif /* __RTL8821A_SPEC_H__ */
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8821A_SPEC_H__
+#define __RTL8821A_SPEC_H__
+
+#include <drv_conf.h>
+/* This file should based on "hal_com_reg.h" */
+#include <hal_com_reg.h>
+/* Because 8812a and 8821a is the same serial,
+ * most of 8821a register definitions are the same as 8812a. */
+#include <rtl8812a_spec.h>
+
+
+/* ************************************************************
+ * 8821A Regsiter offset definition
+ * ************************************************************ */
+
+/* ************************************************************
+ * MAC register
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ *	0x0000h ~ 0x00FFh	System Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ * ----------------------------------------------------- */
+#define REG_WOWLAN_WAKE_REASON          REG_MCUTST_WOWLAN
+
+/* -----------------------------------------------------
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0300h ~ 0x03FFh	PCIe
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ * ----------------------------------------------------- */
+
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_FREE_TXPG2		0x024
+#define SDIO_REG_HCPWM1_8821A	0x025
+
+/* ************************************************************
+ * Regsiter Bit and Content definition
+ * ************************************************************ */
+
+#endif /* __RTL8821A_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_xmit.h
index 2b7320dfa785..b457d15adb41 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821a_xmit.h
@@ -1,180 +1,174 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTL8821A_XMIT_H__
-#define __RTL8821A_XMIT_H__
-
-#include <drv_types.h>
-
-typedef struct txdescriptor_8821a
-{
-	// Offset 0
-	u32 pktlen:16;
-	u32 offset:8;
-	u32 bmc:1;
-	u32 htc:1;
-	u32 rsvd0026:1;
-	u32 rsvd0027:1;
-	u32 linip:1;
-	u32 noacm:1;
-	u32 gf:1;
-	u32 rsvd0031:1;
-
-	// Offset 4
-	u32 macid:7;
-	u32 rsvd0407:1;
-	u32 qsel:5;
-	u32 rdg_nav_ext:1;
-	u32 lsig_txop_en:1;
-	u32 pifs:1;
-	u32 rate_id:5;
-	u32 en_desc_id:1;
-	u32 sectype:2;
-	u32 pkt_offset:5; // unit: 8 bytes
-	u32 moredata:1;
-	u32 txop_ps_cap:1;
-	u32 txop_ps_mode:1;
-
-	// Offset 8
-	u32 p_aid:9;
-	u32 rsvd0809:1;
-	u32 cca_rts:2;
-	u32 agg_en:1;
-	u32 rdg_en:1;
-	u32 null_0:1;
-	u32 null_1:1;
-	u32 bk:1;
-	u32 morefrag:1;
-	u32 raw:1;
-	u32 spe_rpt:1;
-	u32 ampdu_density:3;
-	u32 bt_null:1;
-	u32 g_id:6;
-	u32 rsvd0830:2;
-
-	// Offset 12
-	u32 wheader_len:4;
-	u32 chk_en:1;
-	u32 early_rate:1;
-	u32 hw_ssn_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 navusehdr:1;
-	u32 use_max_len:1;
-	u32 max_agg_num:5;
-	u32 ndpa:2;
-	u32 ampdu_max_time:8;
-
-	// Offset 16
-	u32 datarate:7;
-	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 rtsrate:5;
-	u32 pcts_en:1;
-	u32 pcts_mask_idx:2;
-
-	// Offset 20
-	u32 data_sc:4;
-	u32 data_short:1;
-	u32 data_bw:2;
-	u32 data_ldpc:1;
-	u32 data_stbc:2;
-	u32 vcs_stbc:2;
-	u32 rts_short:1;
-	u32 rts_sc:4;
-	u32 rsvd2016:7;
-	u32 tx_ant:4;
-	u32 txpwr_offset:3;
-	u32 rsvd2031:1;
-
-	// Offset 24
-	u32 sw_define:12;
-	u32 mbssid:4;
-	u32 antsel_A:3;
-	u32 antsel_B:3;
-	u32 antsel_C:3;
-	u32 antsel_D:3;
-	u32 rsvd2428:4;
-
-	// Offset 28
-	u32 checksum:16;
-	u32 rsvd2816:8;
-	u32 usb_txagg_num:8;
-
-	// Offset 32
-	u32 rts_rc:6;
-	u32 bar_rty_th:2;
-	u32 data_rc:6;
-	u32 rsvd3214:1;
-	u32 en_hwseq:1;
-	u32 nextneadpage:8;
-	u32 tailpage:8;
-
-	// Offset 36
-	u32 padding_len:11;
-	u32 txbf_path:1;
-	u32 seq:12;
-	u32 final_data_rate:8;
-}TXDESC_8821A, *PTXDESC_8821A;
-
-#ifdef CONFIG_SDIO_HCI
-s32 InitXmitPriv8821AS(PADAPTER padapter);
-void FreeXmitPriv8821AS(PADAPTER padapter);
-s32 XmitBufHandler8821AS(PADAPTER padapter);
-s32 MgntXmit8821AS(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32	HalXmitNoLock8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 HalXmit8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe);
-#ifndef CONFIG_SDIO_TX_TASKLET
-thread_return XmitThread8821AS(thread_context context);
-#endif // !CONFIG_SDIO_TX_TASKLET
-#endif // CONFIG_SDIO_HCI
-
-#if 0
-#ifdef CONFIG_USB_HCI
-s32 rtl8821au_init_xmit_priv(PADAPTER padapter);
-void rtl8821au_free_xmit_priv(PADAPTER padapter);
-s32 rtl8821au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8821au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-s32 rtl8821au_hal_xmitframe_enqueue(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8821au_xmit_buf_handler(PADAPTER padapter);
-void rtl8821au_xmit_tasklet(void *priv);
-s32 rtl8821au_xmitframe_complete(PADAPTER padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-#endif // CONFIG_USB_HCI
-
-#ifdef CONFIG_PCI_HCI
-s32 rtl8821e_init_xmit_priv(PADAPTER padapter);
-void rtl8821e_free_xmit_priv(PADAPTER padapter);
-struct xmit_buf* rtl8821e_dequeue_xmitbuf(struct rtw_tx_ring *ring);
-void rtl8821e_xmitframe_resume(PADAPTER padapter);
-s32 rtl8821e_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
-s32 rtl8821e_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
-void rtl8821e_xmit_tasklet(void *priv);
-#endif // CONFIG_PCI_HCI
-#endif
-
-#endif //__RTL8821_XMIT_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8821A_XMIT_H__
+#define __RTL8821A_XMIT_H__
+
+#include <drv_types.h>
+
+typedef struct txdescriptor_8821a {
+	/* Offset 0 */
+	u32 pktlen:16;
+	u32 offset:8;
+	u32 bmc:1;
+	u32 htc:1;
+	u32 rsvd0026:1;
+	u32 rsvd0027:1;
+	u32 linip:1;
+	u32 noacm:1;
+	u32 gf:1;
+	u32 rsvd0031:1;
+
+	/* Offset 4 */
+	u32 macid:7;
+	u32 rsvd0407:1;
+	u32 qsel:5;
+	u32 rdg_nav_ext:1;
+	u32 lsig_txop_en:1;
+	u32 pifs:1;
+	u32 rate_id:5;
+	u32 en_desc_id:1;
+	u32 sectype:2;
+	u32 pkt_offset:5; /* unit: 8 bytes */
+	u32 moredata:1;
+	u32 txop_ps_cap:1;
+	u32 txop_ps_mode:1;
+
+	/* Offset 8 */
+	u32 p_aid:9;
+	u32 rsvd0809:1;
+	u32 cca_rts:2;
+	u32 agg_en:1;
+	u32 rdg_en:1;
+	u32 null_0:1;
+	u32 null_1:1;
+	u32 bk:1;
+	u32 morefrag:1;
+	u32 raw:1;
+	u32 spe_rpt:1;
+	u32 ampdu_density:3;
+	u32 bt_null:1;
+	u32 g_id:6;
+	u32 rsvd0830:2;
+
+	/* Offset 12 */
+	u32 wheader_len:4;
+	u32 chk_en:1;
+	u32 early_rate:1;
+	u32 hw_ssn_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 navusehdr:1;
+	u32 use_max_len:1;
+	u32 max_agg_num:5;
+	u32 ndpa:2;
+	u32 ampdu_max_time:8;
+
+	/* Offset 16 */
+	u32 datarate:7;
+	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 rtsrate:5;
+	u32 pcts_en:1;
+	u32 pcts_mask_idx:2;
+
+	/* Offset 20 */
+	u32 data_sc:4;
+	u32 data_short:1;
+	u32 data_bw:2;
+	u32 data_ldpc:1;
+	u32 data_stbc:2;
+	u32 vcs_stbc:2;
+	u32 rts_short:1;
+	u32 rts_sc:4;
+	u32 rsvd2016:7;
+	u32 tx_ant:4;
+	u32 txpwr_offset:3;
+	u32 rsvd2031:1;
+
+	/* Offset 24 */
+	u32 sw_define:12;
+	u32 mbssid:4;
+	u32 antsel_A:3;
+	u32 antsel_B:3;
+	u32 antsel_C:3;
+	u32 antsel_D:3;
+	u32 rsvd2428:4;
+
+	/* Offset 28 */
+	u32 checksum:16;
+	u32 rsvd2816:8;
+	u32 usb_txagg_num:8;
+
+	/* Offset 32 */
+	u32 rts_rc:6;
+	u32 bar_rty_th:2;
+	u32 data_rc:6;
+	u32 rsvd3214:1;
+	u32 en_hwseq:1;
+	u32 nextneadpage:8;
+	u32 tailpage:8;
+
+	/* Offset 36 */
+	u32 padding_len:11;
+	u32 txbf_path:1;
+	u32 seq:12;
+	u32 final_data_rate:8;
+} TXDESC_8821A, *PTXDESC_8821A;
+
+#ifdef CONFIG_SDIO_HCI
+s32 InitXmitPriv8821AS(PADAPTER padapter);
+void FreeXmitPriv8821AS(PADAPTER padapter);
+s32 XmitBufHandler8821AS(PADAPTER padapter);
+s32 MgntXmit8821AS(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32	HalXmitNoLock8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 HalXmit8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe);
+#ifndef CONFIG_SDIO_TX_TASKLET
+thread_return XmitThread8821AS(thread_context context);
+#endif /* !CONFIG_SDIO_TX_TASKLET */
+#endif /* CONFIG_SDIO_HCI */
+
+#if 0
+#ifdef CONFIG_USB_HCI
+s32 rtl8821au_init_xmit_priv(PADAPTER padapter);
+void rtl8821au_free_xmit_priv(PADAPTER padapter);
+s32 rtl8821au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8821au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+s32 rtl8821au_hal_xmitframe_enqueue(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8821au_xmit_buf_handler(PADAPTER padapter);
+void rtl8821au_xmit_tasklet(void *priv);
+s32 rtl8821au_xmitframe_complete(PADAPTER padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+#endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_PCI_HCI
+s32 rtl8821e_init_xmit_priv(PADAPTER padapter);
+void rtl8821e_free_xmit_priv(PADAPTER padapter);
+struct xmit_buf *rtl8821e_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+void rtl8821e_xmitframe_resume(PADAPTER padapter);
+s32 rtl8821e_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+s32 rtl8821e_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+void rtl8821e_xmit_tasklet(void *priv);
+#endif /* CONFIG_PCI_HCI */
+#endif
+
+#endif /* __RTL8821_XMIT_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_dm.h
new file mode 100644
index 000000000000..32cf516206f9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_dm.h
@@ -0,0 +1,24 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8812C_DM_H__
+#define __RTL8812C_DM_H__
+
+void rtl8821c_phy_init_dm_priv(PADAPTER);
+void rtl8821c_phy_deinit_dm_priv(PADAPTER);
+void rtl8821c_phy_init_haldm(PADAPTER);
+void rtl8821c_phy_haldm_watchdog(PADAPTER);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_hal.h
new file mode 100644
index 000000000000..e671149b2e59
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_hal.h
@@ -0,0 +1,84 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821C_HAL_H_
+#define _RTL8821C_HAL_H_
+
+#include <osdep_service.h>		/* BIT(x) */
+#include "../hal/halmac/halmac_api.h"	/* MAC REG definition */
+#include "hal_data.h"
+#include "rtl8821c_spec.h"
+#include "../hal/rtl8821c/hal8821c_fw.h"
+
+#ifdef CONFIG_USB_HCI
+#include <rtl8821cu_hal.h>
+#endif
+#ifdef CONFIG_SDIO_HCI
+#include <rtl8821cs_hal.h>
+#endif
+#ifdef CONFIG_PCI_HCI
+#include <rtl8821ce_hal.h>
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#define FIFO_BLOCK_SIZE		32768 /*@Block size = 32K*/
+#define RX_FIFO_EXPANDING	(1 * FIFO_BLOCK_SIZE)
+#else
+#define RX_FIFO_EXPANDING	0
+#endif
+
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+			/* 8821C - RX FIFO :16K ,for RX agg DMA mode = 16K, Rx agg USB mode could large than 16k*/
+			/* #define MAX_RECVBUF_SZ		(16384 + RX_FIFO_EXPANDING)*/
+			/* For Max throughput issue , need to use USB AGG mode to replace DMA AGG mode*/
+			#define MAX_RECVBUF_SZ (32768)
+
+			/*#define MAX_RECVBUF_SZ_8821C (24576)*/ /* 24k*/
+			/*#define MAX_RECVBUF_SZ_8821C (20480)*/ /*20K*/
+			/*#define MAX_RECVBUF_SZ_8821C (10240) */ /*10K*/
+			/*#define MAX_RECVBUF_SZ_8821C (15360)*/ /*15k < 16k*/
+			/*#define MAX_RECVBUF_SZ_8821C (8192+1024)*/ /* 8K+1k*/
+		#else
+			#define MAX_RECVBUF_SZ (4096 + RX_FIFO_EXPANDING) /* about 4K */
+		#endif
+	#endif/* !MAX_RECVBUF_SZ*/
+
+#elif defined(CONFIG_PCI_HCI)
+	/*#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+	#define MAX_RECVBUF_SZ (9100)
+	#else*/
+	#define MAX_RECVBUF_SZ (4096 + RX_FIFO_EXPANDING) /* about 4K */
+	/*#endif*/
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	#define MAX_RECVBUF_SZ	(16384 + RX_FIFO_EXPANDING)
+#endif
+
+void init_hal_spec_rtl8821c(PADAPTER);
+/* MP Functions */
+#ifdef CONFIG_MP_INCLUDED
+void rtl8821c_prepare_mp_txdesc(PADAPTER, struct mp_priv *);	/* rtw_mp.c */
+void rtl8821c_mp_config_rfpath(PADAPTER);			/* hal_mp.c */
+#endif
+
+#ifdef CONFIG_PCI_HCI
+u16 get_txbd_rw_reg(u16 q_idx);
+#endif
+
+#endif /* _RTL8821C_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_spec.h
new file mode 100644
index 000000000000..0e13c75fade6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821c_spec.h
@@ -0,0 +1,202 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8821C_SPEC_H__
+#define __RTL8821C_SPEC_H__
+
+#define EFUSE_MAP_SIZE		HALMAC_EFUSE_SIZE_8821C
+
+/*
+ * MAC Register definition
+ */
+#define REG_AFE_XTAL_CTRL			REG_AFE_CTRL1_8821C	/* hal_com.c & phydm */
+#define REG_AFE_PLL_CTRL			REG_AFE_CTRL2_8821C	/* hal_com.c & phydm */
+#define REG_MAC_PHY_CTRL			REG_AFE_CTRL3_8821C	/* phydm only */
+#define REG_LEDCFG0					REG_LED_CFG_8821C	/* rtw_mp.c */
+#define MSR							(REG_CR_8821C + 2)	/* rtw_mp.c */
+#define MSR1						REG_CR_EXT_8821C	/* rtw_mp.c & hal_com.c */
+#define REG_C2HEVT_MSG_NORMAL		0x1A0			/* hal_com.c */
+#define REG_C2HEVT_CLEAR			0x1AF			/* hal_com.c */
+#define REG_BCN_CTRL_1				REG_BCN_CTRL_CLINT0_8821C/* hal_com.c */
+#define REG_TSFTR1					REG_FREERUN_CNT_8821C	/* hal_com.c */
+#define REG_WOWLAN_WAKE_REASON	0x01C7
+#define REG_GPIO_PIN_CTRL_2			REG_GPIO_EXT_CTRL_8821C
+
+/* RXERR_RPT, for rtw_mp.c */
+#define RXERR_TYPE_OFDM_PPDU		0
+#define RXERR_TYPE_OFDM_FALSE_ALARM	2
+#define RXERR_TYPE_OFDM_MPDU_OK		0
+#define RXERR_TYPE_OFDM_MPDU_FAIL	1
+#define RXERR_TYPE_CCK_PPDU		3
+#define RXERR_TYPE_CCK_FALSE_ALARM	5
+#define RXERR_TYPE_CCK_MPDU_OK		3
+#define RXERR_TYPE_CCK_MPDU_FAIL	4
+#define RXERR_TYPE_HT_PPDU		8
+#define RXERR_TYPE_HT_FALSE_ALARM	9
+#define RXERR_TYPE_HT_MPDU_TOTAL	6
+#define RXERR_TYPE_HT_MPDU_OK		6
+#define RXERR_TYPE_HT_MPDU_FAIL		7
+#define RXERR_TYPE_RX_FULL_DROP		10
+
+#define RXERR_COUNTER_MASK		BIT_MASK_RPT_COUNTER_8821C
+#define RXERR_RPT_RST			BIT_RXERR_RPT_RST_8821C
+#define _RXERR_RPT_SEL(type)		(BIT_RXERR_RPT_SEL_V1_3_0_8821C(type) \
+		| ((type & 0x10) ? BIT_RXERR_RPT_SEL_V1_4_8821C : 0))
+
+/*
+ * BB Register definition
+ */
+#define rPMAC_Reset				0x100	/* hal_mp.c */
+
+#define rFPGA0_RFMOD				0x800
+#define rFPGA0_TxInfo				0x804
+#define rOFDMCCKEN_Jaguar		0x808	/* hal_mp.c */
+#define rFPGA0_TxGainStage		0x80C	/* phydm only */
+#define rFPGA0_XA_HSSIParameter1	0x820	/* hal_mp.c */
+#define rFPGA0_XA_HSSIParameter2	0x824	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter1	0x828	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter2	0x82C	/* hal_mp.c */
+#define rTxAGC_B_Rate18_06		0x830
+#define rTxAGC_B_Rate54_24		0x834
+#define rTxAGC_B_CCK1_55_Mcs32	0x838
+#define rCCAonSec_Jaguar			0x838	/* hal_mp.c */
+#define rTxAGC_B_Mcs03_Mcs00		0x83C
+#define rTxAGC_B_Mcs07_Mcs04		0x848
+#define rTxAGC_B_Mcs11_Mcs08		0x84C
+#define rFPGA0_XA_RFInterfaceOE		0x860
+#define rFPGA0_XB_RFInterfaceOE		0x864
+#define rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86C
+#define rFPGA0_XAB_RFInterfaceSW		0x870
+#define rFPGA0_XAB_RFParameter		0x878
+#define rFPGA0_AnalogParameter4		0x88C	/* hal_mp.c & phydm */
+#define rFPGA0_XB_LSSIReadBack		0x8A4	/* phydm */
+#define rHSSIRead_Jaguar				0x8B0	/* RF read addr (rtl8821c_phy.c) */
+
+#define	rC_TxScale_Jaguar2			0x181C  /* Pah_C TX scaling factor (hal_mp.c) */
+#define	rC_IGI_Jaguar2				0x1850	/* Initial Gain for path-C (hal_mp.c) */
+
+#define rFPGA1_TxInfo					0x90C	/* hal_mp.c */
+#define rSingleTone_ContTx_Jaguar		0x914	/* hal_mp.c */
+
+#define rCCK0_System					0xA00
+#define rCCK0_AFESetting				0xA04
+
+#define rCCK0_DSPParameter2			0xA1C
+#define rCCK0_TxFilter1				0xA20
+#define rCCK0_TxFilter2				0xA24
+#define rCCK0_DebugPort				0xA28
+#define rCCK0_FalseAlarmReport		0xA2C
+
+#define	rD_TxScale_Jaguar2			0x1A1C  /* Path_D TX scaling factor (hal_mp.c) */
+#define	rD_IGI_Jaguar2				0x1A50	/* Initial Gain for path-D (hal_mp.c) */
+
+#define rOFDM0_TRxPathEnable			0xC04
+#define rOFDM0_TRMuxPar				0xC08
+#define rA_TxScale_Jaguar				0xC1C	/* Pah_A TX scaling factor (hal_mp.c) */
+#define rOFDM0_RxDetector1			0xC30	/* rtw_mp.c */
+#define rOFDM0_ECCAThreshold			0xC4C	/* phydm only */
+#define rOFDM0_XAAGCCore1			0xC50	/* phydm only */
+#define rA_IGI_Jaguar					0xC50	/* Initial Gain for path-A (hal_mp.c) */
+#define rOFDM0_XBAGCCore1			0xC58	/* phydm only */
+#define rOFDM0_XATxIQImbalance		0xC80	/* phydm only */
+#define rA_LSSIWrite_Jaguar			0xC90	/* RF write addr, LSSI Parameter (rtl8821c_phy.c) */
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xCB0	/* hal_mp.c */
+#define	rB_RFE_Pinmux_Jaguar	0xEB0	/* Path_B RFE control pinmux */
+#define	rA_RFE_Inv_Jaguar		0xCB4	/* Path_A RFE cotrol */  
+#define	rB_RFE_Inv_Jaguar		0xEB4	/* Path_B RFE control */
+#define	rA_RFE_Jaguar			0xCB8 	/* Path_A RFE cotrol */  
+#define	rB_RFE_Jaguar			0xEB8	/* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define	r_ANTSEL_SW_Jaguar		0x900	/* ANTSEL SW Control */
+#define	bMask_RFEInv_Jaguar	0x3FF00000
+#define	bMask_AntselPathFollow_Jaguar 0x00030000   
+
+#define rOFDM1_LSTF					0xD00
+#define rOFDM1_TRxPathEnable			0xD04	/* hal_mp.c */
+#define rA_PIRead_Jaguar				0xD04	/* RF readback with PI (rtl8821c_phy.c) */
+#define rA_SIRead_Jaguar				0xD08	/* RF readback with SI (rtl8821c_phy.c) */
+#define rB_PIRead_Jaguar				0xD44	/* RF readback with PI (rtl8821c_phy.c) */
+#define rB_SIRead_Jaguar				0xD48	/* RF readback with SI (rtl8821c_phy.c) */
+
+#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 rB_TxScale_Jaguar				0xE1C	/* Path_B TX scaling factor (hal_mp.c) */
+#define rB_IGI_Jaguar					0xE50	/* Initial Gain for path-B (hal_mp.c) */
+#define rB_LSSIWrite_Jaguar			0xE90	/* RF write addr, LSSI Parameter (rtl8821c_phy.c) */
+
+/* Page1(0x100) */
+#define bBBResetB					0x100
+
+/* Page8(0x800) */
+#define bCCKEn						0x1000000
+#define bOFDMEn						0x2000000
+/* Reg 0x80C rFPGA0_TxGainStage */
+#define bXBTxAGC						0xF00
+#define bXCTxAGC						0xF000
+#define bXDTxAGC						0xF0000
+
+/* PageA(0xA00) */
+#define bCCKBBMode					0x3
+
+#define bCCKScramble					0x8
+#define bCCKTxRate					0x3000
+
+/* General */
+#define bMaskByte0		0xFF		/* mp, rtw_odm.c & phydm */
+#define bMaskByte1		0xFF00		/* hal_mp.c & phydm */
+#define bMaskByte2		0xFF0000	/* hal_mp.c & phydm */
+#define bMaskByte3		0xFF000000	/* hal_mp.c & phydm */
+#define bMaskHWord		0xFFFF0000	/* hal_com.c, rtw_mp.c */
+#define bMaskLWord		0x0000FFFF	/* mp, hal_com.c & phydm */
+#define bMaskDWord		0xFFFFFFFF	/* mp, hal, rtw_odm.c & phydm */
+
+#define bEnable			0x1		/* hal_mp.c, rtw_mp.c */
+#define bDisable			0x0		/* rtw_mp.c */
+
+#define MAX_STALL_TIME		50		/* unit: us, hal_com_phycfg.c */
+
+#define Rx_Smooth_Factor		20		/* phydm only */
+
+/*
+ * RF Register definition
+ */
+#define RF_AC			0x00
+#define RF_AC_Jaguar		0x00	/* hal_mp.c */
+#define RF_CHNLBW		0x18	/* rtl8821c_phy.c */
+#define RF_0x52			0x52
+
+struct hw_port_reg {
+	u32 net_type;	/*reg_offset*/
+	u8 net_type_shift;
+	u32 macaddr;	/*reg_offset*/
+	u32 bssid;	/*reg_offset*/
+	u32 bcn_ctl;			/*reg_offset*/
+	u32 tsf_rst;			/*reg_offset*/
+	u8 tsf_rst_bit;
+	u32 bcn_space;		/*reg_offset*/
+	u8 bcn_space_shift;
+	u16 bcn_space_mask;
+	u32	ps_aid;			/*reg_offset*/
+};
+
+#endif /* __RTL8192E_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821ce_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821ce_hal.h
new file mode 100644
index 000000000000..b1683ad0648b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821ce_hal.h
@@ -0,0 +1,24 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821CE_HAL_H_
+#define _RTL8821CE_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8821ce_ops.c */
+void rtl8821ce_set_hal_ops(PADAPTER);
+
+#endif /* _RTL8821CE_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821cs_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821cs_hal.h
new file mode 100644
index 000000000000..bec0e21f9761
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821cs_hal.h
@@ -0,0 +1,24 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821CS_HAL_H_
+#define _RTL8821CS_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8821cs_ops.c */
+u8 rtl8821cs_set_hal_ops(PADAPTER);
+
+#endif /* _RTL8821CS_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821cu_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821cu_hal.h
new file mode 100644
index 000000000000..d21d5f5cef7e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8821cu_hal.h
@@ -0,0 +1,25 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8821CU_HAL_H_
+#define _RTL8821CU_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8821cu_ops.c */
+u8 rtl8821cu_set_hal_ops(PADAPTER);
+void rtl8821cu_set_hw_type(struct dvobj_priv *pdvobj);
+
+#endif /* _RTL8821CU_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822b_hal.h
new file mode 100644
index 000000000000..034733c46335
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822b_hal.h
@@ -0,0 +1,230 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822B_HAL_H_
+#define _RTL8822B_HAL_H_
+
+#include <osdep_service.h>		/* BIT(x) */
+#include <drv_types.h>			/* PADAPTER */
+#include "../hal/halmac/halmac_api.h"	/* MAC REG definition */
+
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#define MAX_RECVBUF_SZ		46080	/* 45KB, TX: (256-64)KB */
+#else /* !CONFIG_SUPPORT_TRX_SHARED */
+#define MAX_RECVBUF_SZ		24576	/* 24KB, TX: 256KB */
+#endif /* !CONFIG_SUPPORT_TRX_SHARED */
+
+/*
+ * MAC Register definition
+ */
+#define REG_AFE_XTAL_CTRL	REG_AFE_CTRL1_8822B	/* hal_com.c & phydm */
+#define REG_AFE_PLL_CTRL	REG_AFE_CTRL2_8822B	/* hal_com.c & phydm */
+#define REG_MAC_PHY_CTRL	REG_AFE_CTRL3_8822B	/* phydm only */
+#define REG_LEDCFG0		REG_LED_CFG_8822B	/* rtw_mp.c */
+#define MSR			(REG_CR_8822B + 2)	/* rtw_mp.c & hal_com.c */
+#define MSR1			REG_CR_EXT_8822B	/* rtw_mp.c & hal_com.c */
+#define REG_C2HEVT_MSG_NORMAL	0x1A0			/* hal_com.c */
+#define REG_C2HEVT_CLEAR	0x1AF			/* hal_com.c */
+#define REG_BCN_CTRL_1		REG_BCN_CTRL_CLINT0_8822B	/* hal_com.c */
+#define REG_TSFTR1		REG_FREERUN_CNT_8822B	/* hal_com.c */
+#define REG_WOWLAN_WAKE_REASON	0x01C7 /* hal_com.c */
+#define REG_GPIO_PIN_CTRL_2		REG_GPIO_EXT_CTRL_8822B		/* hal_com.c */
+
+/* RXERR_RPT, for rtw_mp.c */
+#define RXERR_TYPE_OFDM_PPDU		0
+#define RXERR_TYPE_OFDM_FALSE_ALARM	2
+#define RXERR_TYPE_OFDM_MPDU_OK		0
+#define RXERR_TYPE_OFDM_MPDU_FAIL	1
+#define RXERR_TYPE_CCK_PPDU		3
+#define RXERR_TYPE_CCK_FALSE_ALARM	5
+#define RXERR_TYPE_CCK_MPDU_OK		3
+#define RXERR_TYPE_CCK_MPDU_FAIL	4
+#define RXERR_TYPE_HT_PPDU		8
+#define RXERR_TYPE_HT_FALSE_ALARM	9
+#define RXERR_TYPE_HT_MPDU_TOTAL	6
+#define RXERR_TYPE_HT_MPDU_OK		6
+#define RXERR_TYPE_HT_MPDU_FAIL		7
+#define RXERR_TYPE_RX_FULL_DROP		10
+
+#define RXERR_COUNTER_MASK		BIT_MASK_RPT_COUNTER_8822B
+#define RXERR_RPT_RST			BIT_RXERR_RPT_RST_8822B
+#define _RXERR_RPT_SEL(type)		(BIT_RXERR_RPT_SEL_V1_3_0_8822B(type) \
+					| ((type & 0x10) ? BIT_RXERR_RPT_SEL_V1_4_8822B : 0))
+
+/*
+ * BB Register definition
+ */
+#define rPMAC_Reset			0x100	/* hal_mp.c */
+
+#define	rFPGA0_RFMOD			0x800
+#define rFPGA0_TxInfo			0x804
+#define rOFDMCCKEN_Jaguar		0x808	/* hal_mp.c */
+#define rFPGA0_TxGainStage		0x80C	/* phydm only */
+#define rFPGA0_XA_HSSIParameter1	0x820	/* hal_mp.c */
+#define rFPGA0_XA_HSSIParameter2	0x824	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter1	0x828	/* hal_mp.c */
+#define rFPGA0_XB_HSSIParameter2	0x82C	/* hal_mp.c */
+#define rTxAGC_B_Rate18_06		0x830
+#define rTxAGC_B_Rate54_24		0x834
+#define rTxAGC_B_CCK1_55_Mcs32		0x838
+#define rCCAonSec_Jaguar		0x838	/* hal_mp.c */
+#define rTxAGC_B_Mcs03_Mcs00		0x83C
+#define rTxAGC_B_Mcs07_Mcs04		0x848
+#define rTxAGC_B_Mcs11_Mcs08		0x84C
+#define rFPGA0_XA_RFInterfaceOE		0x860
+#define rFPGA0_XB_RFInterfaceOE		0x864
+#define rTxAGC_B_Mcs15_Mcs12		0x868
+#define rTxAGC_B_CCK11_A_CCK2_11	0x86C
+#define rFPGA0_XAB_RFInterfaceSW	0x870
+#define rFPGA0_XAB_RFParameter		0x878
+#define rFPGA0_AnalogParameter4		0x88C	/* hal_mp.c & phydm */
+#define rFPGA0_XB_LSSIReadBack		0x8A4	/* phydm */
+#define rHSSIRead_Jaguar		0x8B0	/* RF read addr (rtl8822b_phy.c) */
+
+#define	rC_TxScale_Jaguar2		0x181C  /* Pah_C TX scaling factor (hal_mp.c) */
+#define	rC_IGI_Jaguar2			0x1850	/* Initial Gain for path-C (hal_mp.c) */
+
+#define rFPGA1_TxInfo			0x90C	/* hal_mp.c */
+#define rSingleTone_ContTx_Jaguar	0x914	/* hal_mp.c */
+/* TX BeamForming */
+#define REG_BB_TX_PATH_SEL_1_8822B	0x93C	/* rtl8822b_phy.c */
+#define REG_BB_TX_PATH_SEL_2_8822B	0x940	/* rtl8822b_phy.c */
+
+/* TX BeamForming */
+#define REG_BB_TXBF_ANT_SET_BF1_8822B	0x19AC	/* rtl8822b_phy.c */
+#define REG_BB_TXBF_ANT_SET_BF0_8822B	0x19B4	/* rtl8822b_phy.c */
+
+#define rCCK0_System			0xA00
+#define rCCK0_AFESetting		0xA04
+
+#define rCCK0_DSPParameter2		0xA1C
+#define rCCK0_TxFilter1			0xA20
+#define rCCK0_TxFilter2			0xA24
+#define rCCK0_DebugPort			0xA28
+#define rCCK0_FalseAlarmReport		0xA2C
+
+#define	rD_TxScale_Jaguar2		0x1A1C  /* Path_D TX scaling factor (hal_mp.c) */
+#define	rD_IGI_Jaguar2			0x1A50	/* Initial Gain for path-D (hal_mp.c) */
+
+#define rOFDM0_TRxPathEnable		0xC04
+#define rOFDM0_TRMuxPar			0xC08
+#define rA_TxScale_Jaguar		0xC1C	/* Pah_A TX scaling factor (hal_mp.c) */
+#define rOFDM0_RxDetector1		0xC30	/* rtw_mp.c */
+#define rOFDM0_ECCAThreshold		0xC4C	/* phydm only */
+#define rOFDM0_XAAGCCore1		0xC50	/* phydm only */
+#define rA_IGI_Jaguar			0xC50	/* Initial Gain for path-A (hal_mp.c) */
+#define rOFDM0_XBAGCCore1		0xC58	/* phydm only */
+#define rOFDM0_XATxIQImbalance		0xC80	/* phydm only */
+#define rA_LSSIWrite_Jaguar		0xC90	/* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
+
+#define rOFDM1_LSTF			0xD00
+#define rOFDM1_TRxPathEnable		0xD04	/* hal_mp.c */
+#define rA_PIRead_Jaguar		0xD04	/* RF readback with PI (rtl8822b_phy.c) */
+#define rA_SIRead_Jaguar		0xD08	/* RF readback with SI (rtl8822b_phy.c) */
+#define rB_PIRead_Jaguar		0xD44	/* RF readback with PI (rtl8822b_phy.c) */
+#define rB_SIRead_Jaguar		0xD48	/* RF readback with SI (rtl8822b_phy.c) */
+
+#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 rB_TxScale_Jaguar		0xE1C	/* Path_B TX scaling factor (hal_mp.c) */
+#define rB_IGI_Jaguar			0xE50	/* Initial Gain for path-B (hal_mp.c) */
+#define rB_LSSIWrite_Jaguar		0xE90	/* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xCB0	/* hal_mp.c */
+#define	rB_RFE_Pinmux_Jaguar	0xEB0	/* Path_B RFE control pinmux */
+#define	rA_RFE_Inv_Jaguar		0xCB4	/* Path_A RFE cotrol */  
+#define	rB_RFE_Inv_Jaguar		0xEB4	/* Path_B RFE control */
+#define	rA_RFE_Jaguar			0xCB8 	/* Path_A RFE cotrol */  
+#define	rB_RFE_Jaguar			0xEB8	/* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define	r_ANTSEL_SW_Jaguar		0x900	/* ANTSEL SW Control */
+#define	bMask_RFEInv_Jaguar	0x3FF00000
+#define	bMask_AntselPathFollow_Jaguar 0x00030000
+
+#define		rC_RFE_Pinmux_Jaguar	0x18B4	/* Path_C RFE cotrol pinmux*/
+#define		rD_RFE_Pinmux_Jaguar	0x1AB4	/* Path_D RFE cotrol pinmux*/
+#define		rA_RFE_Sel_Jaguar2		0x1990
+
+/* Page1(0x100) */
+#define bBBResetB			0x100
+
+/* Page8(0x800) */
+#define bCCKEn				0x1000000
+#define bOFDMEn				0x2000000
+/* Reg 0x80C rFPGA0_TxGainStage */
+#define bXBTxAGC			0xF00
+#define bXCTxAGC			0xF000
+#define bXDTxAGC			0xF0000
+
+/* PageA(0xA00) */
+#define bCCKBBMode			0x3
+
+#define bCCKScramble			0x8
+#define bCCKTxRate			0x3000
+
+/* General */
+#define bMaskByte0		0xFF		/* mp, rtw_odm.c & phydm */
+#define bMaskByte1		0xFF00		/* hal_mp.c & phydm */
+#define bMaskByte2		0xFF0000	/* hal_mp.c & phydm */
+#define bMaskByte3		0xFF000000	/* hal_mp.c & phydm */
+#define bMaskHWord		0xFFFF0000	/* hal_com.c, rtw_mp.c */
+#define bMaskLWord		0x0000FFFF	/* mp, hal_com.c & phydm */
+#define bMaskDWord		0xFFFFFFFF	/* mp, hal, rtw_odm.c & phydm */
+
+#define bEnable			0x1		/* hal_mp.c, rtw_mp.c */
+#define bDisable		0x0		/* rtw_mp.c */
+
+#define MAX_STALL_TIME		50		/* unit: us, hal_com_phycfg.c */
+
+#define Rx_Smooth_Factor	20		/* phydm only */
+
+/*
+ * RF Register definition
+ */
+#define RF_AC			0x00
+#define RF_AC_Jaguar		0x00	/* hal_mp.c */
+#define RF_CHNLBW		0x18	/* rtl8822b_phy.c */
+#define RF_ModeTableAddr	0x30	/* rtl8822b_phy.c */
+#define RF_ModeTableData0	0x31	/* rtl8822b_phy.c */
+#define RF_ModeTableData1	0x32	/* rtl8822b_phy.c */
+#define RF_0x52			0x52
+#define RF_WeLut_Jaguar		0xEF	/* rtl8822b_phy.c */
+
+/* General Functions */
+void rtl8822b_init_hal_spec(PADAPTER);				/* hal/hal_com.c */
+
+#ifdef CONFIG_MP_INCLUDED
+/* MP Functions */
+#include <rtw_mp.h>		/* struct mp_priv */
+void rtl8822b_prepare_mp_txdesc(PADAPTER, struct mp_priv *);	/* rtw_mp.c */
+void rtl8822b_mp_config_rfpath(PADAPTER);			/* hal_mp.c */
+#endif
+
+#ifdef CONFIG_USB_HCI
+#include <rtl8822bu_hal.h>
+#elif defined(CONFIG_SDIO_HCI)
+#include <rtl8822bs_hal.h>
+#elif defined(CONFIG_PCI_HCI)
+#include <rtl8822be_hal.h>
+#endif
+
+#endif /* _RTL8822B_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822be_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822be_hal.h
new file mode 100644
index 000000000000..38e5d6fa1536
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822be_hal.h
@@ -0,0 +1,28 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BE_HAL_H_
+#define _RTL8822BE_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+#define RT_BCN_INT_MASKS	(BIT20 | BIT25 | BIT26 | BIT16)
+
+/* rtl8822be_ops.c */
+void UpdateInterruptMask8822BE(PADAPTER, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+u16 get_txbd_rw_reg(u16 q_idx);
+
+
+#endif /* _RTL8822BE_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822bs_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822bs_hal.h
new file mode 100644
index 000000000000..bb92cbc6113e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822bs_hal.h
@@ -0,0 +1,32 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BS_HAL_H_
+#define _RTL8822BS_HAL_H_
+
+#include <drv_types.h>		/* PADAPTER */
+
+/* rtl8822bs_ops.c */
+void rtl8822bs_set_hal_ops(PADAPTER);
+
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+void rtl8822bs_disable_interrupt_but_cpwm2(PADAPTER adapter);
+#endif
+
+/* rtl8822bs_xmit.c */
+s32 rtl8822bs_dequeue_writeport(PADAPTER);
+#define _dequeue_writeport(a)	rtl8822bs_dequeue_writeport(a)
+
+#endif /* _RTL8822BS_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822bu_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822bu_hal.h
new file mode 100644
index 000000000000..6e5f23c26d56
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtl8822bu_hal.h
@@ -0,0 +1,66 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8822BU_HAL_H_
+#define _RTL8822BU_HAL_H_
+
+#ifdef CONFIG_USB_HCI
+	#include <drv_types.h>		/* PADAPTER */
+
+	#ifdef CONFIG_USB_HCI
+		#ifdef USB_PACKET_OFFSET_SZ
+			#define PACKET_OFFSET_SZ (USB_PACKET_OFFSET_SZ)
+		#else
+			#define PACKET_OFFSET_SZ (8)
+		#endif
+		#define TXDESC_OFFSET (TXDESC_SIZE + PACKET_OFFSET_SZ)
+	#endif
+
+	/* undefine MAX_RECVBUF_SZ from rtl8822b_hal.h  */
+	#ifdef MAX_RECVBUF_SZ
+		#undef MAX_RECVBUF_SZ
+	#endif
+
+	/* recv_buffer must be large than usb agg size */
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024)
+		#else /* !PLATFORM_OS_CE */
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+				#define MAX_RECVBUF_SZ (15360) /* 15k */
+				#elif defined(CONFIG_PLATFORM_HISILICON)
+				/* use 16k to workaround for HISILICON platform */
+				#define MAX_RECVBUF_SZ (16384)
+				#else
+				#define MAX_RECVBUF_SZ (32768)
+				#endif
+			#else
+				#define MAX_RECVBUF_SZ (4000)
+			#endif
+		#endif /* PLATFORM_OS_CE */
+	#endif /* !MAX_RECVBUF_SZ */
+
+	/* rtl8822bu_ops.c */
+	void rtl8822bu_set_hal_ops(PADAPTER padapter);
+	void rtl8822bu_set_hw_type(struct dvobj_priv *pdvobj);
+
+	/* rtl8822bu_io.c */
+	void rtl8822bu_set_intf_ops(struct _io_ops *pops);
+
+#endif /* CONFIG_USB_HCI */
+
+
+#endif /* _RTL8822BU_HAL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_android.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_android.h
index 5b52846f2aab..b5f8b126f32f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_android.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_android.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,39 +12,34 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
- 
+ *****************************************************************************/
+
 #ifndef __RTW_ANDROID_H__
 #define __RTW_ANDROID_H__
 
 enum ANDROID_WIFI_CMD {
-	ANDROID_WIFI_CMD_START,				
-	ANDROID_WIFI_CMD_STOP,			
+	ANDROID_WIFI_CMD_START,
+	ANDROID_WIFI_CMD_STOP,
 	ANDROID_WIFI_CMD_SCAN_ACTIVE,
-	ANDROID_WIFI_CMD_SCAN_PASSIVE,		
-	ANDROID_WIFI_CMD_RSSI,	
+	ANDROID_WIFI_CMD_SCAN_PASSIVE,
+	ANDROID_WIFI_CMD_RSSI,
 	ANDROID_WIFI_CMD_LINKSPEED,
 	ANDROID_WIFI_CMD_RXFILTER_START,
-	ANDROID_WIFI_CMD_RXFILTER_STOP,	
-	ANDROID_WIFI_CMD_RXFILTER_ADD,	
+	ANDROID_WIFI_CMD_RXFILTER_STOP,
+	ANDROID_WIFI_CMD_RXFILTER_ADD,
 	ANDROID_WIFI_CMD_RXFILTER_REMOVE,
 	ANDROID_WIFI_CMD_BTCOEXSCAN_START,
 	ANDROID_WIFI_CMD_BTCOEXSCAN_STOP,
 	ANDROID_WIFI_CMD_BTCOEXMODE,
 	ANDROID_WIFI_CMD_SETSUSPENDOPT,
-	ANDROID_WIFI_CMD_P2P_DEV_ADDR,	
-	ANDROID_WIFI_CMD_SETFWPATH,		
-	ANDROID_WIFI_CMD_SETBAND,		
-	ANDROID_WIFI_CMD_GETBAND,			
-	ANDROID_WIFI_CMD_COUNTRY,			
+	ANDROID_WIFI_CMD_P2P_DEV_ADDR,
+	ANDROID_WIFI_CMD_SETFWPATH,
+	ANDROID_WIFI_CMD_SETBAND,
+	ANDROID_WIFI_CMD_GETBAND,
+	ANDROID_WIFI_CMD_COUNTRY,
 	ANDROID_WIFI_CMD_P2P_SET_NOA,
-	ANDROID_WIFI_CMD_P2P_GET_NOA,	
-	ANDROID_WIFI_CMD_P2P_SET_PS,	
+	ANDROID_WIFI_CMD_P2P_GET_NOA,
+	ANDROID_WIFI_CMD_P2P_SET_PS,
 	ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE,
 
 	ANDROID_WIFI_CMD_MIRACAST,
@@ -62,7 +58,7 @@ enum ANDROID_WIFI_CMD {
 
 	ANDROID_WIFI_CMD_WFD_ENABLE,
 	ANDROID_WIFI_CMD_WFD_DISABLE,
-	
+
 	ANDROID_WIFI_CMD_WFD_SET_TCPPORT,
 	ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT,
 	ANDROID_WIFI_CMD_WFD_SET_DEVTYPE,
@@ -70,10 +66,11 @@ enum ANDROID_WIFI_CMD {
 	ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL,
 	ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA,
 	ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA,
-#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))	
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
 	ANDROID_WIFI_CMD_GTK_REKEY_OFFLOAD,
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
 	ANDROID_WIFI_CMD_P2P_DISABLE,
+	ANDROID_WIFI_CMD_SET_AEK,
 	ANDROID_WIFI_CMD_DRIVERVERSION,
 	ANDROID_WIFI_CMD_MAX
 };
@@ -81,33 +78,35 @@ enum ANDROID_WIFI_CMD {
 int rtw_android_cmdstr_to_num(char *cmdstr);
 int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd);
 
-#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3,0,0))
+#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
 int rtw_android_pno_enable(struct net_device *net, int pno_enable);
 int rtw_android_cfg80211_pno_setup(struct net_device *net,
-		struct cfg80211_ssid *ssid, int n_ssids, int interval);
+		   struct cfg80211_ssid *ssid, int n_ssids, int interval);
 #endif
 
 #if defined(RTW_ENABLE_WIFI_CONTROL_FUNC)
 int rtw_android_wifictrl_func_add(void);
 void rtw_android_wifictrl_func_del(void);
-void* wl_android_prealloc(int section, unsigned long size);
+void *wl_android_prealloc(int section, unsigned long size);
 
 int wifi_get_irq_number(unsigned long *irq_flags_ptr);
 int wifi_set_power(int on, unsigned long msec);
 int wifi_get_mac_addr(unsigned char *buf);
 void *wifi_get_country_code(char *ccode);
 #else
-static int rtw_android_wifictrl_func_add(void) { return 0; }
+static int rtw_android_wifictrl_func_add(void)
+{
+	return 0;
+}
 static void rtw_android_wifictrl_func_del(void) {}
 #endif /* defined(RTW_ENABLE_WIFI_CONTROL_FUNC) */
 
 #ifdef CONFIG_GPIO_WAKEUP
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 int wifi_configure_gpio(void);
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 void wifi_free_gpio(unsigned int gpio);
-#endif //CONFIG_GPIO_WAKEUP
-
+#endif /* CONFIG_GPIO_WAKEUP */
 
-#endif //__RTW_ANDROID_H__
 
+#endif /* __RTW_ANDROID_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ap.h
index 9eaf324cb476..e499376122a6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ap.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ap.h
@@ -1,80 +1,105 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTW_AP_H_
-#define __RTW_AP_H_
-
-
-#ifdef CONFIG_AP_MODE
-
-//external function
-extern void rtw_indicate_sta_assoc_event(_adapter *padapter, struct sta_info *psta);
-extern void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info *psta);
-
-
-void init_mlme_ap_info(_adapter *padapter);
-void free_mlme_ap_info(_adapter *padapter);
-//void update_BCNTIM(_adapter *padapter);
-void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len);
-void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index);
-void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *tag);
-#define update_beacon(adapter, ie_id, oui, tx) _update_beacon((adapter), (ie_id), (oui), (tx), __func__)
-void add_RATid(_adapter *padapter, struct sta_info *psta, u8 rssi_level);
-void expire_timeout_chk(_adapter *padapter);
-void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta);
-void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter);
-void start_bss_network(_adapter *padapter, struct createbss_parm *parm);
-int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len);
-void rtw_ap_restore_network(_adapter *padapter);
-void rtw_set_macaddr_acl(_adapter *padapter, int mode);
-int rtw_acl_add_sta(_adapter *padapter, u8 *addr);
-int rtw_acl_remove_sta(_adapter *padapter, u8 *addr);
-
-u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta);
-int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid);
-int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx);
-
-#ifdef CONFIG_NATIVEAP_MLME
-void associated_clients_update(_adapter *padapter, u8 updated, u32 sta_info_type);
-void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta);
-u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta);
-void sta_info_update(_adapter *padapter, struct sta_info *psta);
-void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta);
-u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reason, bool enqueue);
-int rtw_sta_flush(_adapter *padapter, bool enqueue);
-int rtw_ap_inform_ch_switch(_adapter *padapter, u8 new_ch, u8 ch_offset);
-void start_ap_mode(_adapter *padapter);
-void stop_ap_mode(_adapter *padapter);
-#endif
-
-void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset);
-bool rtw_ap_chbw_decision(_adapter *adapter, u8 req_ch, u8 req_bw, u8 req_offset, u8 *ch, u8 *bw, u8 *offset);
-
-#ifdef CONFIG_AUTO_AP_MODE
-extern void rtw_start_auto_ap(_adapter *adapter);
-#endif //CONFIG_AUTO_AP_MODE
-
-#endif //end of CONFIG_AP_MODE
-
-#endif
-void update_bmc_sta(_adapter *padapter);
-
-void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field);
-void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len);
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_
+
+
+#ifdef CONFIG_AP_MODE
+
+/* external function */
+extern void rtw_indicate_sta_assoc_event(_adapter *padapter, struct sta_info *psta);
+extern void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info *psta);
+
+
+void init_mlme_ap_info(_adapter *padapter);
+void free_mlme_ap_info(_adapter *padapter);
+u8 rtw_set_tim_ie(u8 dtim_cnt, u8 dtim_period
+	, const u8 *tim_bmp, u8 tim_bmp_len, u8 *tim_ie);
+/* void update_BCNTIM(_adapter *padapter); */
+void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len);
+void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index);
+void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *tag);
+#define update_beacon(adapter, ie_id, oui, tx) _update_beacon((adapter), (ie_id), (oui), (tx), __func__)
+
+void rtw_ap_update_sta_ra_info(_adapter *padapter, struct sta_info *psta);
+
+void expire_timeout_chk(_adapter *padapter);
+void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta);
+void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter);
+void start_bss_network(_adapter *padapter, struct createbss_parm *parm);
+int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len);
+void rtw_ap_restore_network(_adapter *padapter);
+
+#if CONFIG_RTW_MACADDR_ACL
+void rtw_macaddr_acl_init(_adapter *adapter, u8 period);
+void rtw_macaddr_acl_deinit(_adapter *adapter, u8 period);
+void rtw_macaddr_acl_clear(_adapter *adapter, u8 period);
+void rtw_set_macaddr_acl(_adapter *adapter, u8 period, int mode);
+int rtw_acl_add_sta(_adapter *adapter, u8 period, const u8 *addr);
+int rtw_acl_remove_sta(_adapter *adapter, u8 period, const u8 *addr);
+#endif /* CONFIG_RTW_MACADDR_ACL */
+
+u8 rtw_ap_set_sta_key(_adapter *adapter, const u8 *addr, u8 alg, const u8 *key, u8 keyid, u8 gk);
+u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta);
+int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid);
+int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx);
+
+#ifdef CONFIG_NATIVEAP_MLME
+void associated_clients_update(_adapter *padapter, u8 updated, u32 sta_info_type);
+void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta);
+u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta);
+void sta_info_update(_adapter *padapter, struct sta_info *psta);
+void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta);
+u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reason, bool enqueue);
+int rtw_sta_flush(_adapter *padapter, bool enqueue);
+int rtw_ap_inform_ch_switch(_adapter *padapter, u8 new_ch, u8 ch_offset);
+void start_ap_mode(_adapter *padapter);
+void stop_ap_mode(_adapter *padapter);
+#endif
+
+void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset);
+bool rtw_ap_chbw_decision(_adapter *adapter, s16 req_ch, s8 req_bw, s8 req_offset, u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow);
+
+#ifdef CONFIG_AUTO_AP_MODE
+void rtw_auto_ap_rx_msg_dump(_adapter *padapter, union recv_frame *precv_frame, u8 *ehdr_pos);
+extern void rtw_start_auto_ap(_adapter *adapter);
+#endif /* CONFIG_AUTO_AP_MODE */
+
+void rtw_ap_parse_sta_capability(_adapter *adapter, struct sta_info *sta, u8 *cap);
+u16 rtw_ap_parse_sta_supported_rates(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len);
+u16 rtw_ap_parse_sta_security_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems);
+void rtw_ap_parse_sta_wmm_ie(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len);
+void rtw_ap_parse_sta_ht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems);
+void rtw_ap_parse_sta_vht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems);
+
+void update_bmc_sta(_adapter *padapter);
+
+#ifdef CONFIG_BMC_TX_RATE_SELECT
+void rtw_update_bmc_sta_tx_rate(_adapter *adapter);
+#endif
+
+void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field);
+void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len);
+int rtw_ht_operation_update(_adapter *padapter);
+u8 rtw_ap_sta_linking_state_check(_adapter *adapter);
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+void tx_beacon_handlder(struct dvobj_priv *pdvobj);
+void tx_beacon_timer_handlder(void *ctx);
+#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
+
+#endif /* end of CONFIG_AP_MODE */
+#endif /*__RTW_AP_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_beamforming.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_beamforming.h
index 8f71afddebe4..536214213c35 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_beamforming.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_beamforming.h
@@ -1,150 +1,402 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTW_BEAMFORMING_H_
-#define __RTW_BEAMFORMING_H_
-
-#ifdef CONFIG_BEAMFORMING
-
-#if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
-#define BEAMFORMING_ENTRY_NUM		2
-#define GET_BEAMFORM_INFO(_pmlmepriv)	((struct beamforming_info *)(&(_pmlmepriv)->beamforming_info))
-
-
-typedef enum _BEAMFORMING_ENTRY_STATE
-{
-	BEAMFORMING_ENTRY_STATE_UNINITIALIZE, 
-	BEAMFORMING_ENTRY_STATE_INITIALIZEING, 
-	BEAMFORMING_ENTRY_STATE_INITIALIZED, 
-	BEAMFORMING_ENTRY_STATE_PROGRESSING, 
-	BEAMFORMING_ENTRY_STATE_PROGRESSED, 
-}BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;
-
-
-typedef enum _BEAMFORMING_STATE
-{
-	BEAMFORMING_STATE_IDLE, 
-	BEAMFORMING_STATE_START, 
-	BEAMFORMING_STATE_END,
-}BEAMFORMING_STATE, *PBEAMFORMING_STATE;
-
-
-typedef enum _BEAMFORMING_CAP
-{
-	BEAMFORMING_CAP_NONE = 0x0,
-	BEAMFORMER_CAP_HT_EXPLICIT = 0x1, 
-	BEAMFORMEE_CAP_HT_EXPLICIT = 0x2, 
-	BEAMFORMER_CAP_VHT_SU = 0x4,			// Self has er Cap, because Reg er  & peer ee
-	BEAMFORMEE_CAP_VHT_SU = 0x8, 			// Self has ee Cap, because Reg ee & peer er 
-	BEAMFORMER_CAP = 0x10,
-	BEAMFORMEE_CAP = 0x20,
-}BEAMFORMING_CAP, *PBEAMFORMING_CAP;
-
-
-typedef enum _SOUNDING_MODE
-{
-	SOUNDING_SW_VHT_TIMER = 0x0,
-	SOUNDING_SW_HT_TIMER = 0x1, 
-	SOUNDING_STOP_All_TIMER = 0x2, 
-	SOUNDING_HW_VHT_TIMER = 0x3,			
-	SOUNDING_HW_HT_TIMER = 0x4,
-	SOUNDING_STOP_OID_TIMER = 0x5, 
-	SOUNDING_AUTO_VHT_TIMER = 0x6,
-	SOUNDING_AUTO_HT_TIMER = 0x7,
-	SOUNDING_FW_VHT_TIMER = 0x8,
-	SOUNDING_FW_HT_TIMER = 0x9,
-}SOUNDING_MODE, *PSOUNDING_MODE;
-
-struct beamforming_entry {
-	BOOLEAN	bUsed;
-	BOOLEAN	bSound;
-	u16	aid;			// Used to construct AID field of NDPA packet.
-	u16	mac_id;		// Used to Set Reg42C in IBSS mode. 
-	u16	p_aid;		// Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. 
-	u16 g_id;
-	u8	mac_addr[6];// Used to fill Reg6E4 to fill Mac address of CSI report frame.
-	CHANNEL_WIDTH	sound_bw;	// Sounding BandWidth
-	u16	sound_period;
-	BEAMFORMING_CAP	beamforming_entry_cap;
-	BEAMFORMING_ENTRY_STATE	beamforming_entry_state;
-	u8				ClockResetTimes;			/*Modified by Jeffery @2015-04-10*/
-	u8				PreLogSeq;				/*Modified by Jeffery @2015-03-30*/
-	u8				LogSeq;					/*Modified by Jeffery @2014-10-29*/
-	u16				LogRetryCnt:3;			/*Modified by Jeffery @2014-10-29*/
-	u16				LogSuccess:2;			/*Modified by Jeffery @2014-10-29*/
-
-	u8	LogStatusFailCnt;
-	u8	PreCsiReport[327];
-	u8	DefaultCsiCnt;
-	BOOLEAN	bDefaultCSI;
-};
-
-struct sounding_info {
-	u8				sound_idx;
-	CHANNEL_WIDTH	sound_bw;
-	SOUNDING_MODE	sound_mode; 
-	u16				sound_period;
-};
-
-struct beamforming_info {
-	BEAMFORMING_CAP		beamforming_cap;
-	BEAMFORMING_STATE		beamforming_state;
-	struct beamforming_entry	beamforming_entry[BEAMFORMING_ENTRY_NUM];
-	u8						beamforming_cur_idx;
-	u8						beamforming_in_progress;
-	u8						sounding_sequence;
-	struct sounding_info		sounding_info;
-};
-
-struct rtw_ndpa_sta_info {
-	u16	aid:12;	
-	u16	feedback_type:1;
-	u16	nc_index:3;	
-};
-
-BEAMFORMING_CAP beamforming_get_entry_beam_cap_by_mac_id(PVOID pmlmepriv ,u8 mac_id);
-void	beamforming_notify(PADAPTER adapter);
-BEAMFORMING_CAP beamforming_get_beamform_cap(struct beamforming_info	*pBeamInfo);
-
-BOOLEAN	beamforming_send_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, CHANNEL_WIDTH bw, u8 qidx);
-BOOLEAN	beamforming_send_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, CHANNEL_WIDTH bw, u8 qidx);
-
-void	beamforming_check_sounding_success(PADAPTER Adapter,BOOLEAN status);
-
-void	beamforming_watchdog(PADAPTER Adapter);
-#endif /*#if (BEAMFORMING_SUPPORT ==0)- for diver defined beamforming*/
-
-enum BEAMFORMING_CTRL_TYPE {
-	BEAMFORMING_CTRL_ENTER = 0,
-	BEAMFORMING_CTRL_LEAVE = 1,
-	BEAMFORMING_CTRL_START_PERIOD = 2,
-	BEAMFORMING_CTRL_END_PERIOD = 3,
-	BEAMFORMING_CTRL_SOUNDING_FAIL = 4,
-	BEAMFORMING_CTRL_SOUNDING_CLK = 5,
-};
-u32	beamforming_get_report_frame(PADAPTER	 Adapter, union recv_frame *precv_frame);
-void	beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_frame);
-
-void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf);
-u8	beamforming_wk_cmd(_adapter*padapter, s32 type, u8 *pbuf, s32 size, u8 enqueue);
-void update_attrib_txbf_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
-
-#endif /*#ifdef CONFIG_BEAMFORMING */
-
-#endif /*__RTW_BEAMFORMING_H_*/
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BEAMFORMING_H_
+#define __RTW_BEAMFORMING_H_
+
+#ifdef CONFIG_BEAMFORMING
+
+#ifdef RTW_BEAMFORMING_VERSION_2
+#define MAX_NUM_BEAMFORMEE_SU	2
+#define MAX_NUM_BEAMFORMER_SU	2
+#define MAX_NUM_BEAMFORMEE_MU	6
+#define MAX_NUM_BEAMFORMER_MU	1
+
+#define MAX_BEAMFORMEE_ENTRY_NUM	(MAX_NUM_BEAMFORMEE_SU + MAX_NUM_BEAMFORMEE_MU)
+#define MAX_BEAMFORMER_ENTRY_NUM	(MAX_NUM_BEAMFORMER_SU + MAX_NUM_BEAMFORMER_MU)
+
+/* <Note> Need to be defined by IC */
+#define SU_SOUNDING_TIMEOUT	5	/* unit: ms */
+#define MU_SOUNDING_TIMEOUT	8	/* unit: ms */
+
+#define GET_BEAMFORM_INFO(adapter)	(&GET_HAL_DATA(adapter)->beamforming_info)
+#define GetInitSoundCnt(_SoundPeriod, _MinSoundPeriod)	((_SoundPeriod)/(_MinSoundPeriod))
+
+enum BEAMFORMING_CTRL_TYPE {
+	BEAMFORMING_CTRL_ENTER = 0,
+	BEAMFORMING_CTRL_LEAVE = 1,
+	BEAMFORMING_CTRL_START_PERIOD = 2,
+	BEAMFORMING_CTRL_END_PERIOD = 3,
+	BEAMFORMING_CTRL_SOUNDING_FAIL = 4,
+	BEAMFORMING_CTRL_SOUNDING_CLK = 5,
+	BEAMFORMING_CTRL_SET_GID_TABLE = 6,
+	BEAMFORMING_CTRL_SET_CSI_REPORT = 7,
+};
+
+enum _BEAMFORMING_STATE {
+	BEAMFORMING_STATE_IDLE,
+	BEAMFORMING_STATE_START,
+	BEAMFORMING_STATE_END,
+};
+
+/*
+ * typedef BEAMFORMING_CAP for phydm
+ */
+typedef enum beamforming_cap {
+	BEAMFORMING_CAP_NONE = 0x0,
+	BEAMFORMER_CAP_HT_EXPLICIT = 0x1,
+	BEAMFORMEE_CAP_HT_EXPLICIT = 0x2,
+	BEAMFORMER_CAP_VHT_SU = 0x4,			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_SU = 0x8, 			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP_VHT_MU = 0x10,			/* Self has er Cap, because Reg er & peer ee */
+	BEAMFORMEE_CAP_VHT_MU = 0x20,			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP = 0x40,
+	BEAMFORMEE_CAP = 0x80,
+} BEAMFORMING_CAP;
+
+enum _BEAMFORM_ENTRY_HW_STATE {
+	BEAMFORM_ENTRY_HW_STATE_NONE,
+	BEAMFORM_ENTRY_HW_STATE_ADD_INIT,
+	BEAMFORM_ENTRY_HW_STATE_ADDING,
+	BEAMFORM_ENTRY_HW_STATE_ADDED,
+	BEAMFORM_ENTRY_HW_STATE_DELETE_INIT,
+	BEAMFORM_ENTRY_HW_STATE_DELETING,
+	BEAMFORM_ENTRY_HW_STATE_MAX
+};
+
+/* The sounding state is recorded by BFer. */
+enum _SOUNDING_STATE {
+	SOUNDING_STATE_NONE		= 0,
+	SOUNDING_STATE_INIT		= 1,
+	SOUNDING_STATE_SU_START		= 2,
+	SOUNDING_STATE_SU_SOUNDDOWN	= 3,
+	SOUNDING_STATE_MU_START		= 4,
+	SOUNDING_STATE_MU_SOUNDDOWN	= 5,
+	SOUNDING_STATE_SOUNDING_TIMEOUT	= 6,
+	SOUNDING_STATE_MAX
+};
+
+struct beamformee_entry {
+	u8 used;	/* _TRUE/_FALSE */
+	u8 txbf;
+	u8 sounding;
+	/* Used to construct AID field of NDPA packet */
+	u16 aid;
+	/* Used to Set Reg42C in IBSS mode */
+	u16 mac_id;
+	/* Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC */
+	u16 p_aid;
+	u8 g_id;
+	/* Used to fill Reg6E4 to fill Mac address of CSI report frame */
+	u8 mac_addr[ETH_ALEN];
+	/* Sounding BandWidth */
+	enum channel_width sound_bw;
+	u16 sound_period;
+
+	enum beamforming_cap cap;
+	enum _BEAMFORM_ENTRY_HW_STATE state;
+
+	/* The BFee need to be sounded when count to zero */
+	u8 SoundCnt;
+	u8 bCandidateSoundingPeer;
+	u8 bSoundingTimeout;
+	u8 bDeleteSounding;
+	/* Get the result through throughput and Tx rate from BB API */
+	u8 bApplySounding;
+
+	/* information for sounding judgement */
+	systime tx_timestamp;
+	u64 tx_bytes;
+
+	u16 LogStatusFailCnt:5;	/* 0~21 */
+	u16 DefaultCSICnt:5; /* 0~21 */
+	u8 CSIMatrix[327];
+	u16 CSIMatrixLen;
+
+	u8 NumofSoundingDim;
+
+	u8 comp_steering_num_of_bfer;
+
+
+	/* SU-MIMO */
+	u8 su_reg_index;
+
+	/* MU-MIMO */
+	u8 mu_reg_index;
+	u8 gid_valid[8];
+	u8 user_position[16];
+
+	/* For 8822B C-cut workaround */
+	/* If the flag set to _TRUE, do not sound this STA */
+	u8 bSuspendSUCap;
+};
+
+struct beamformer_entry {
+	u8 used;
+	/* p_aid of BFer entry is probably not used */
+	/* Used to fill Reg42C & Reg714 to compare with p_aid of Tx DESC */
+	u16 p_aid;
+	u8 g_id;
+	u8 mac_addr[ETH_ALEN];
+
+	enum beamforming_cap cap;
+	enum _BEAMFORM_ENTRY_HW_STATE state;
+
+	u8 NumofSoundingDim;
+
+	/* SU-MIMO */
+	u8 su_reg_index;
+
+	/* MU-MIMO */
+	u8 gid_valid[8];
+	u8 user_position[16];
+	u16 aid;
+};
+
+struct sounding_info {
+	u8 su_sounding_list[MAX_NUM_BEAMFORMEE_SU];
+	u8 mu_sounding_list[MAX_NUM_BEAMFORMEE_MU];
+
+	enum _SOUNDING_STATE state;
+	/*
+	 * su_bfee_curidx is index for beamforming_info.bfee_entry[]
+	 * range: 0~MAX_BEAMFORMEE_ENTRY_NUM
+	 */
+	u8 su_bfee_curidx;
+	u8 candidate_mu_bfee_cnt;
+
+	/* For sounding schedule maintenance */
+	u16 min_sounding_period;
+	/* Get from sounding list */
+	/* Ex: SU STA1, SU STA2, MU STA(1~n) => the value will be 2+1=3 */
+	u8 sound_remain_cnt_per_period;
+};
+
+struct _RT_CSI_INFO{
+	u8 Nc;
+	u8 Nr;
+	u8 Ng;
+	u8 CodeBook;
+	u8 ChnlWidth;
+	u8 bVHT;
+};
+
+struct beamforming_info {
+	enum beamforming_cap beamforming_cap;
+	enum _BEAMFORMING_STATE beamforming_state;
+	struct beamformee_entry bfee_entry[MAX_BEAMFORMEE_ENTRY_NUM];
+	struct beamformer_entry bfer_entry[MAX_BEAMFORMER_ENTRY_NUM];
+	u8 sounding_sequence;
+	u8 beamformee_su_cnt;
+	u8 beamformer_su_cnt;
+	u32 beamformee_su_reg_maping;
+	u32 beamformer_su_reg_maping;
+	/* For MU-MINO */
+	u8 beamformee_mu_cnt;
+	u8 beamformer_mu_cnt;
+	u32 beamformee_mu_reg_maping;
+	u8 first_mu_bfee_index;
+	u8 mu_bfer_curidx;
+	u8 cur_csi_rpt_rate;
+
+	struct sounding_info sounding_info;
+	/* schedule regular timer for sounding */
+	_timer sounding_timer;
+	/* moniter if soudning too long */
+	_timer sounding_timeout_timer;
+
+	/* For HW configuration */
+	u8 SetHalBFEnterOnDemandCnt;
+	u8 SetHalBFLeaveOnDemandCnt;
+	u8 SetHalSoundownOnDemandCnt;
+	u8 bSetBFHwConfigInProgess;
+
+	/*
+	 * Target CSI report info.
+	 * Keep the first SU CSI report info for 8822B HW bug workaround.
+	 */
+	u8 bEnableSUTxBFWorkAround;
+	struct _RT_CSI_INFO TargetCSIInfo;
+	/* Only peform sounding to the first SU BFee */
+	struct beamformee_entry *TargetSUBFee;
+
+	/* For debug */
+	s8 sounding_running;
+};
+
+enum beamforming_cap rtw_bf_bfee_get_entry_cap_by_macid(void *mlmepriv, u8 mac_id);
+struct beamformer_entry *rtw_bf_bfer_get_entry_by_addr(PADAPTER, u8 *ra);
+struct beamformee_entry *rtw_bf_bfee_get_entry_by_addr(PADAPTER, u8 *ra);
+void rtw_bf_get_ndpa_packet(PADAPTER, union recv_frame *);
+u32 rtw_bf_get_report_packet(PADAPTER, union recv_frame *);
+u8 rtw_bf_send_vht_gid_mgnt_packet(PADAPTER, u8 *ra, u8 *gid, u8 *position);
+void rtw_bf_get_vht_gid_mgnt_packet(PADAPTER, union recv_frame *);
+void rtw_bf_init(PADAPTER);
+void rtw_bf_cmd_hdl(PADAPTER, u8 type, u8 *pbuf);
+u8 rtw_bf_cmd(PADAPTER, s32 type, u8 *pbuf, s32 size, u8 enqueue);
+void rtw_bf_update_attrib(PADAPTER, struct pkt_attrib *, struct sta_info *);
+void rtw_bf_c2h_handler(PADAPTER, u8 id, u8 *buf, u8 buf_len);
+void rtw_bf_update_traffic(PADAPTER);
+
+/* Compatible with old function name, only for using outside rtw_beamforming.c */
+#define beamforming_get_entry_beam_cap_by_mac_id	rtw_bf_bfee_get_entry_cap_by_macid
+#define rtw_beamforming_get_ndpa_frame			rtw_bf_get_ndpa_packet
+#define rtw_beamforming_get_report_frame			rtw_bf_get_report_packet
+#define rtw_beamforming_get_vht_gid_mgnt_frame		rtw_bf_get_vht_gid_mgnt_packet
+#define beamforming_wk_hdl				rtw_bf_cmd_hdl
+#define beamforming_wk_cmd				rtw_bf_cmd
+#define update_attrib_txbf_info				rtw_bf_update_attrib
+
+#define HT_BF_CAP(adapter) ((adapter)->mlmepriv.htpriv.beamform_cap)
+#define VHT_BF_CAP(adapter) ((adapter)->mlmepriv.vhtpriv.beamform_cap)
+
+#define IS_HT_BEAMFORMEE(adapter) \
+		(HT_BF_CAP(adapter) & \
+		(BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+
+#define IS_VHT_BEAMFORMEE(adapter) \
+		(VHT_BF_CAP(adapter) & \
+		(BEAMFORMING_VHT_BEAMFORMEE_ENABLE | \
+		 BEAMFORMING_VHT_MU_MIMO_STA_ENABLE))
+
+#define IS_BEAMFORMEE(adapter) (IS_HT_BEAMFORMEE(adapter) | \
+				IS_VHT_BEAMFORMEE(adapter))
+
+#else /* !RTW_BEAMFORMING_VERSION_2 */
+
+#if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
+#define BEAMFORMING_ENTRY_NUM		2
+#define GET_BEAMFORM_INFO(_pmlmepriv)	((struct beamforming_info *)(&(_pmlmepriv)->beamforming_info))
+
+
+typedef enum _BEAMFORMING_ENTRY_STATE {
+	BEAMFORMING_ENTRY_STATE_UNINITIALIZE,
+	BEAMFORMING_ENTRY_STATE_INITIALIZEING,
+	BEAMFORMING_ENTRY_STATE_INITIALIZED,
+	BEAMFORMING_ENTRY_STATE_PROGRESSING,
+	BEAMFORMING_ENTRY_STATE_PROGRESSED,
+} BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;
+
+
+typedef enum _BEAMFORMING_STATE {
+	BEAMFORMING_STATE_IDLE,
+	BEAMFORMING_STATE_START,
+	BEAMFORMING_STATE_END,
+} BEAMFORMING_STATE, *PBEAMFORMING_STATE;
+
+
+typedef enum _BEAMFORMING_CAP {
+	BEAMFORMING_CAP_NONE = 0x0,
+	BEAMFORMER_CAP_HT_EXPLICIT = 0x1,
+	BEAMFORMEE_CAP_HT_EXPLICIT = 0x2,
+	BEAMFORMER_CAP_VHT_SU = 0x4,			/* Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_SU = 0x8, 			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP = 0x10,
+	BEAMFORMEE_CAP = 0x20,
+} BEAMFORMING_CAP, *PBEAMFORMING_CAP;
+
+
+typedef enum _SOUNDING_MODE {
+	SOUNDING_SW_VHT_TIMER = 0x0,
+	SOUNDING_SW_HT_TIMER = 0x1,
+	SOUNDING_STOP_All_TIMER = 0x2,
+	SOUNDING_HW_VHT_TIMER = 0x3,
+	SOUNDING_HW_HT_TIMER = 0x4,
+	SOUNDING_STOP_OID_TIMER = 0x5,
+	SOUNDING_AUTO_VHT_TIMER = 0x6,
+	SOUNDING_AUTO_HT_TIMER = 0x7,
+	SOUNDING_FW_VHT_TIMER = 0x8,
+	SOUNDING_FW_HT_TIMER = 0x9,
+} SOUNDING_MODE, *PSOUNDING_MODE;
+
+struct beamforming_entry {
+	BOOLEAN	bUsed;
+	BOOLEAN	bSound;
+	u16	aid;			/* Used to construct AID field of NDPA packet. */
+	u16	mac_id;		/* Used to Set Reg42C in IBSS mode. */
+	u16	p_aid;		/* Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u16 g_id;
+	u8	mac_addr[6];/* Used to fill Reg6E4 to fill Mac address of CSI report frame. */
+	enum channel_width	sound_bw;	/* Sounding BandWidth */
+	u16	sound_period;
+	BEAMFORMING_CAP	beamforming_entry_cap;
+	BEAMFORMING_ENTRY_STATE	beamforming_entry_state;
+	u8				ClockResetTimes;			/*Modified by Jeffery @2015-04-10*/
+	u8				PreLogSeq;				/*Modified by Jeffery @2015-03-30*/
+	u8				LogSeq;					/*Modified by Jeffery @2014-10-29*/
+	u16				LogRetryCnt:3;			/*Modified by Jeffery @2014-10-29*/
+	u16				LogSuccess:2;			/*Modified by Jeffery @2014-10-29*/
+
+	u8	LogStatusFailCnt;
+	u8	PreCsiReport[327];
+	u8	DefaultCsiCnt;
+	BOOLEAN	bDefaultCSI;
+};
+
+struct sounding_info {
+	u8				sound_idx;
+	enum channel_width	sound_bw;
+	SOUNDING_MODE	sound_mode;
+	u16				sound_period;
+};
+
+struct beamforming_info {
+	BEAMFORMING_CAP		beamforming_cap;
+	BEAMFORMING_STATE		beamforming_state;
+	struct beamforming_entry	beamforming_entry[BEAMFORMING_ENTRY_NUM];
+	u8						beamforming_cur_idx;
+	u8						beamforming_in_progress;
+	u8						sounding_sequence;
+	struct sounding_info		sounding_info;
+};
+
+struct rtw_ndpa_sta_info {
+	u16	aid:12;
+	u16	feedback_type:1;
+	u16	nc_index:3;
+};
+
+BEAMFORMING_CAP beamforming_get_entry_beam_cap_by_mac_id(PVOID pmlmepriv , u8 mac_id);
+void	beamforming_notify(PADAPTER adapter);
+BEAMFORMING_CAP beamforming_get_beamform_cap(struct beamforming_info	*pBeamInfo);
+
+BOOLEAN	beamforming_send_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, enum channel_width bw, u8 qidx);
+BOOLEAN	beamforming_send_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, enum channel_width bw, u8 qidx);
+
+void	beamforming_check_sounding_success(PADAPTER Adapter, BOOLEAN status);
+
+void	beamforming_watchdog(PADAPTER Adapter);
+#endif /*#if (BEAMFORMING_SUPPORT ==0)- for diver defined beamforming*/
+
+enum BEAMFORMING_CTRL_TYPE {
+	BEAMFORMING_CTRL_ENTER = 0,
+	BEAMFORMING_CTRL_LEAVE = 1,
+	BEAMFORMING_CTRL_START_PERIOD = 2,
+	BEAMFORMING_CTRL_END_PERIOD = 3,
+	BEAMFORMING_CTRL_SOUNDING_FAIL = 4,
+	BEAMFORMING_CTRL_SOUNDING_CLK = 5,
+};
+u32	rtw_beamforming_get_report_frame(PADAPTER	 Adapter, union recv_frame *precv_frame);
+void	rtw_beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_frame);
+
+void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf);
+u8	beamforming_wk_cmd(_adapter *padapter, s32 type, u8 *pbuf, s32 size, u8 enqueue);
+void update_attrib_txbf_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
+
+#endif /* !RTW_BEAMFORMING_VERSION_2 */
+
+#endif /*#ifdef CONFIG_BEAMFORMING */
+
+#endif /*__RTW_BEAMFORMING_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_br_ext.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_br_ext.h
index dcb51014ae2f..40e72a49d030 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_br_ext.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_br_ext.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,45 +12,39 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_BR_EXT_H_
 #define _RTW_BR_EXT_H_
 
-#if 1	// rtw_wifi_driver
-#define CL_IPV6_PASS    	1
+#if 1	/* rtw_wifi_driver */
+#define CL_IPV6_PASS	1
 #define MACADDRLEN		6
-#define _DEBUG_ERR		DBG_8192C
-#define _DEBUG_INFO		//DBG_8192C
-#define DEBUG_WARN		DBG_8192C
-#define DEBUG_INFO		//DBG_8192C
-#define DEBUG_ERR		DBG_8192C
-//#define GET_MY_HWADDR		((GET_MIB(priv))->dot11OperationEntry.hwaddr)
+#define _DEBUG_ERR		RTW_INFO
+#define _DEBUG_INFO		/* RTW_INFO */
+#define DEBUG_WARN		RTW_INFO
+#define DEBUG_INFO		/* RTW_INFO */
+#define DEBUG_ERR		RTW_INFO
+/* #define GET_MY_HWADDR		((GET_MIB(priv))->dot11OperationEntry.hwaddr) */
 #define GET_MY_HWADDR(padapter)		(adapter_mac_addr(padapter))
-#endif	// rtw_wifi_driver
+#endif /* rtw_wifi_driver */
 
 #define NAT25_HASH_BITS		4
 #define NAT25_HASH_SIZE		(1 << NAT25_HASH_BITS)
 #define NAT25_AGEING_TIME	300
 
 #ifdef CL_IPV6_PASS
-#define MAX_NETWORK_ADDR_LEN	17
+	#define MAX_NETWORK_ADDR_LEN	17
 #else
-#define MAX_NETWORK_ADDR_LEN	11
+	#define MAX_NETWORK_ADDR_LEN	11
 #endif
 
-struct nat25_network_db_entry
-{
+struct nat25_network_db_entry {
 	struct nat25_network_db_entry	*next_hash;
 	struct nat25_network_db_entry	**pprev_hash;
 	atomic_t						use_count;
 	unsigned char					macAddr[6];
 	unsigned long					ageing_timer;
-	unsigned char    				networkAddr[MAX_NETWORK_ADDR_LEN];
+	unsigned char				networkAddr[MAX_NETWORK_ADDR_LEN];
 };
 
 enum NAT25_METHOD {
@@ -65,12 +60,11 @@ struct br_ext_info {
 	unsigned int	nat25_disable;
 	unsigned int	macclone_enable;
 	unsigned int	dhcp_bcst_disable;
-	int		addPPPoETag;		// 1: Add PPPoE relay-SID, 0: disable
+	int		addPPPoETag;		/* 1: Add PPPoE relay-SID, 0: disable */
 	unsigned char	nat25_dmzMac[MACADDRLEN];
 	unsigned int	nat25sc_disable;
 };
 
 void nat25_db_cleanup(_adapter *priv);
 
-#endif // _RTW_BR_EXT_H_
-
+#endif /* _RTW_BR_EXT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_bt_mp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_bt_mp.h
index 8d26045a5afe..fa5eea300038 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_bt_mp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_bt_mp.h
@@ -1,295 +1,289 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#ifndef __RTW_BT_MP_H
-#define __RTW_BT_MP_H
-
-
-#if(MP_DRIVER == 1)
-
-#pragma pack(1)
-
-// definition for BT_UP_OP_BT_READY
-#define	MP_BT_NOT_READY						0
-#define	MP_BT_READY							1
-
-// definition for BT_UP_OP_BT_SET_MODE
-typedef enum _MP_BT_MODE{
-	MP_BT_MODE_RF_TXRX_TEST_MODE							= 0,
-	MP_BT_MODE_BT20_DUT_TEST_MODE							= 1,
-	MP_BT_MODE_BT40_DIRECT_TEST_MODE						= 2,
-	MP_BT_MODE_CONNECT_TEST_MODE							= 3,
-	MP_BT_MODE_MAX
-}MP_BT_MODE,*PMP_BT_MODE;
-
-
-// definition for BT_UP_OP_BT_SET_TX_RX_PARAMETER
-typedef struct _BT_TXRX_PARAMETERS{
-    u1Byte		txrxChannel;
-    u4Byte		txrxTxPktCnt;
-    u1Byte		txrxTxPktInterval;
-	u1Byte		txrxPayloadType;
-	u1Byte		txrxPktType;
-	u2Byte		txrxPayloadLen;
-	u4Byte		txrxPktHeader;
-	u1Byte		txrxWhitenCoeff;
-	u1Byte		txrxBdaddr[6];
-	u1Byte		txrxTxGainIndex;
-} BT_TXRX_PARAMETERS, *PBT_TXRX_PARAMETERS;
-
-// txrxPktType
-typedef enum _MP_BT_PKT_TYPE{
-	MP_BT_PKT_DH1							= 0,
-	MP_BT_PKT_DH3							= 1,
-	MP_BT_PKT_DH5							= 2,
-	MP_BT_PKT_2DH1							= 3,
-	MP_BT_PKT_2DH3							= 4,
-	MP_BT_PKT_2DH5							= 5,
-	MP_BT_PKT_3DH1							= 6,
-	MP_BT_PKT_3DH3							= 7,
-	MP_BT_PKT_3DH5							= 8,
-	MP_BT_PKT_LE							= 9,
-	MP_BT_PKT_MAX
-}MP_BT_PKT_TYPE,*PMP_BT_PKT_TYPE;
-// txrxPayloadType
-typedef enum _MP_BT_PAYLOAD_TYPE{
-	MP_BT_PAYLOAD_01010101					= 0,
-	MP_BT_PAYLOAD_ALL_1						= 1,
-	MP_BT_PAYLOAD_ALL_0						= 2,
-	MP_BT_PAYLOAD_11110000					= 3,
-	MP_BT_PAYLOAD_PRBS9						= 4,
-	MP_BT_PAYLOAD_MAX						= 8,
-}MP_BT_PAYLOAD_TYPE,*PMP_BT_PAYLOAD_TYPE;
-
-
-// definition for BT_UP_OP_BT_TEST_CTRL
-typedef enum _MP_BT_TEST_CTRL{
-	MP_BT_TEST_STOP_ALL_TESTS						= 0,
-	MP_BT_TEST_START_RX_TEST						= 1,
-	MP_BT_TEST_START_PACKET_TX_TEST					= 2,
-	MP_BT_TEST_START_CONTINUOUS_TX_TEST 			= 3,
-	MP_BT_TEST_START_INQUIRY_SCAN_TEST				= 4,
-	MP_BT_TEST_START_PAGE_SCAN_TEST					= 5,
-	MP_BT_TEST_START_INQUIRY_PAGE_SCAN_TEST			= 6,
-	MP_BT_TEST_START_LEGACY_CONNECT_TEST			= 7,
-	MP_BT_TEST_START_LE_CONNECT_TEST_INITIATOR 		= 8,
-	MP_BT_TEST_START_LE_CONNECT_TEST_ADVERTISER 	= 9,
-	MP_BT_TEST_MAX
-}MP_BT_TEST_CTRL,*PMP_BT_TEST_CTRL;
-
-
-typedef enum _RTL_EXT_C2H_EVT
-{
-	EXT_C2H_WIFI_FW_ACTIVE_RSP = 0,
-	EXT_C2H_TRIG_BY_BT_FW = 1,
-	MAX_EXT_C2HEVENT
-}RTL_EXT_C2H_EVT;
-
-// OP codes definition between the user layer and driver
-typedef enum _BT_CTRL_OPCODE_UPPER{
-	BT_UP_OP_BT_READY										= 0x00, 
-	BT_UP_OP_BT_SET_MODE									= 0x01,
-	BT_UP_OP_BT_SET_TX_RX_PARAMETER 						= 0x02,
-	BT_UP_OP_BT_SET_GENERAL 								= 0x03,
-	BT_UP_OP_BT_GET_GENERAL 								= 0x04,
-	BT_UP_OP_BT_TEST_CTRL									= 0x05,
-	BT_UP_OP_TEST_BT										= 0x06,
-	BT_UP_OP_MAX
-}BT_CTRL_OPCODE_UPPER,*PBT_CTRL_OPCODE_UPPER;
-
-
-typedef enum _BT_SET_GENERAL{
-	BT_GSET_REG 											= 0x00, 
-	BT_GSET_RESET											= 0x01, 
-	BT_GSET_TARGET_BD_ADDR									= 0x02, 
-	BT_GSET_TX_PWR_FINETUNE 								= 0x03,
-	BT_SET_TRACKING_INTERVAL								= 0x04,
-	BT_SET_THERMAL_METER									= 0x05,
-	BT_ENABLE_CFO_TRACKING									= 0x06,									
-	BT_GSET_UPDATE_BT_PATCH 								= 0x07,
-	BT_GSET_MAX
-}BT_SET_GENERAL,*PBT_SET_GENERAL;
-
-typedef enum _BT_GET_GENERAL{
-	BT_GGET_REG 											= 0x00, 
-	BT_GGET_STATUS											= 0x01,
-	BT_GGET_REPORT											= 0x02,
-	BT_GGET_AFH_MAP 										= 0x03,
-	BT_GGET_AFH_STATUS										= 0x04,
-	BT_GGET_MAX
-}BT_GET_GENERAL,*PBT_GET_GENERAL;
-
-// definition for BT_UP_OP_BT_SET_GENERAL
-typedef enum _BT_REG_TYPE{
-	BT_REG_RF								= 0,
-	BT_REG_MODEM							= 1,
-	BT_REG_BLUEWIZE 						= 2,
-	BT_REG_VENDOR							= 3,
-	BT_REG_LE								= 4,
-	BT_REG_MAX
-}BT_REG_TYPE,*PBT_REG_TYPE;
-
-// definition for BT_LO_OP_GET_AFH_MAP
-typedef enum _BT_AFH_MAP_TYPE{
-	BT_AFH_MAP_RESULT						= 0,
-	BT_AFH_MAP_WIFI_PSD_ONLY				= 1,
-	BT_AFH_MAP_WIFI_CH_BW_ONLY				= 2,
-	BT_AFH_MAP_BT_PSD_ONLY					= 3,
-	BT_AFH_MAP_HOST_CLASSIFICATION_ONLY 	= 4,
-	BT_AFH_MAP_MAX
-}BT_AFH_MAP_TYPE,*PBT_AFH_MAP_TYPE;
-
-// definition for BT_UP_OP_BT_GET_GENERAL
-typedef enum _BT_REPORT_TYPE{
-	BT_REPORT_RX_PACKET_CNT 				= 0,
-	BT_REPORT_RX_ERROR_BITS 				= 1,
-	BT_REPORT_RSSI							= 2,
-	BT_REPORT_CFO_HDR_QUALITY				= 3,
-	BT_REPORT_CONNECT_TARGET_BD_ADDR		= 4,
-	BT_REPORT_MAX
-}BT_REPORT_TYPE,*PBT_REPORT_TYPE;
-
-VOID
-MPTBT_Test(
-	IN	PADAPTER	Adapter,
-	IN	u1Byte		opCode,
-	IN	u1Byte		byte1,
-	IN	u1Byte		byte2,
-	IN	u1Byte		byte3
-	);
-
-NDIS_STATUS
-MPTBT_SendOidBT(
-	IN	PADAPTER		pAdapter,
-	IN	PVOID			InformationBuffer,
-	IN	ULONG			InformationBufferLength,
-	OUT	PULONG			BytesRead,
-	OUT	PULONG			BytesNeeded
-	);
-
-VOID
-MPTBT_FwC2hBtMpCtrl(
-	PADAPTER	Adapter,
-	pu1Byte 	tmpBuf,
-	u1Byte		length
-	);
-
-void MPh2c_timeout_handle(void *FunctionContext);
-
-VOID mptbt_BtControlProcess(
-	PADAPTER	Adapter,
-	PVOID		pInBuf
-	);
-
-#define	BT_H2C_MAX_RETRY								1
-#define	BT_MAX_C2H_LEN								20
-
-typedef struct _BT_REQ_CMD{
-    UCHAR       opCodeVer;
-    UCHAR       OpCode;
-    USHORT      paraLength;
-    UCHAR       pParamStart[100];
-} BT_REQ_CMD, *PBT_REQ_CMD;
-
-typedef struct _BT_RSP_CMD{
-    USHORT      status;
-    USHORT      paraLength;
-    UCHAR       pParamStart[100];
-} BT_RSP_CMD, *PBT_RSP_CMD;
-
-
-typedef struct _BT_H2C{
-	u1Byte	opCodeVer:4;
-	u1Byte	reqNum:4;
-	u1Byte	opCode;
-	u1Byte	buf[100];
-}BT_H2C, *PBT_H2C;
-
-
-
-typedef struct _BT_EXT_C2H{
-	u1Byte	extendId;
-	u1Byte	statusCode:4;
-	u1Byte	retLen:4;
-	u1Byte	opCodeVer:4;
-	u1Byte	reqNum:4;
-	u1Byte	buf[100];
-}BT_EXT_C2H, *PBT_EXT_C2H;
-
-
-typedef enum _BT_OPCODE_STATUS{
-	BT_OP_STATUS_SUCCESS									= 0x00, // Success
-	BT_OP_STATUS_VERSION_MISMATCH							= 0x01,	
-	BT_OP_STATUS_UNKNOWN_OPCODE								= 0x02,
-	BT_OP_STATUS_ERROR_PARAMETER							= 0x03,
-	BT_OP_STATUS_MAX
-}BT_OPCODE_STATUS,*PBT_OPCODE_STATUS;
-
-
-
-//OP codes definition between driver and bt fw
-typedef enum _BT_CTRL_OPCODE_LOWER{
-	BT_LO_OP_GET_BT_VERSION 									= 0x00, 
-	BT_LO_OP_RESET												= 0x01,
-	BT_LO_OP_TEST_CTRL											= 0x02,
-	BT_LO_OP_SET_BT_MODE										= 0x03,
-	BT_LO_OP_SET_CHNL_TX_GAIN									= 0x04,
-	BT_LO_OP_SET_PKT_TYPE_LEN									= 0x05,
-	BT_LO_OP_SET_PKT_CNT_L_PL_TYPE								= 0x06,
-	BT_LO_OP_SET_PKT_CNT_H_PKT_INTV 							= 0x07,
-	BT_LO_OP_SET_PKT_HEADER 									= 0x08,
-	BT_LO_OP_SET_WHITENCOEFF									= 0x09,
-	BT_LO_OP_SET_BD_ADDR_L										= 0x0a,
-	BT_LO_OP_SET_BD_ADDR_H										= 0x0b,
-	BT_LO_OP_WRITE_REG_ADDR 									= 0x0c,
-	BT_LO_OP_WRITE_REG_VALUE									= 0x0d,
-	BT_LO_OP_GET_BT_STATUS										= 0x0e,
-	BT_LO_OP_GET_BD_ADDR_L										= 0x0f,
-	BT_LO_OP_GET_BD_ADDR_H										= 0x10,
-	BT_LO_OP_READ_REG											= 0x11,
-	BT_LO_OP_SET_TARGET_BD_ADDR_L								= 0x12,
-	BT_LO_OP_SET_TARGET_BD_ADDR_H								= 0x13,
-	BT_LO_OP_SET_TX_POWER_CALIBRATION							= 0x14,
-	BT_LO_OP_GET_RX_PKT_CNT_L									= 0x15,
-	BT_LO_OP_GET_RX_PKT_CNT_H									= 0x16,
-	BT_LO_OP_GET_RX_ERROR_BITS_L								= 0x17,
-	BT_LO_OP_GET_RX_ERROR_BITS_H								= 0x18,
-	BT_LO_OP_GET_RSSI											= 0x19,
-	BT_LO_OP_GET_CFO_HDR_QUALITY_L								= 0x1a,
-	BT_LO_OP_GET_CFO_HDR_QUALITY_H								= 0x1b,
-	BT_LO_OP_GET_TARGET_BD_ADDR_L								= 0x1c,
-	BT_LO_OP_GET_TARGET_BD_ADDR_H								= 0x1d,
-	BT_LO_OP_GET_AFH_MAP_L										= 0x1e,
-	BT_LO_OP_GET_AFH_MAP_M										= 0x1f,
-	BT_LO_OP_GET_AFH_MAP_H										= 0x20,
-	BT_LO_OP_GET_AFH_STATUS 									= 0x21,
-	BT_LO_OP_SET_TRACKING_INTERVAL								= 0x22,
-	BT_LO_OP_SET_THERMAL_METER									= 0x23,
-	BT_LO_OP_ENABLE_CFO_TRACKING								= 0x24,
-	BT_LO_OP_MAX
-}BT_CTRL_OPCODE_LOWER,*PBT_CTRL_OPCODE_LOWER;
-
-
-
-
-#endif  /* #if(MP_DRIVER == 1) */
-
-#endif // #ifndef __INC_MPT_BT_H
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_BT_MP_H
+#define __RTW_BT_MP_H
+
+
+#if (MP_DRIVER == 1)
+
+#pragma pack(1)
+
+/* definition for BT_UP_OP_BT_READY */
+#define	MP_BT_NOT_READY						0
+#define	MP_BT_READY							1
+
+/* definition for BT_UP_OP_BT_SET_MODE */
+typedef enum _MP_BT_MODE {
+	MP_BT_MODE_RF_TXRX_TEST_MODE							= 0,
+	MP_BT_MODE_BT20_DUT_TEST_MODE							= 1,
+	MP_BT_MODE_BT40_DIRECT_TEST_MODE						= 2,
+	MP_BT_MODE_CONNECT_TEST_MODE							= 3,
+	MP_BT_MODE_MAX
+} MP_BT_MODE, *PMP_BT_MODE;
+
+
+/* definition for BT_UP_OP_BT_SET_TX_RX_PARAMETER */
+typedef struct _BT_TXRX_PARAMETERS {
+	u1Byte		txrxChannel;
+	u4Byte		txrxTxPktCnt;
+	u1Byte		txrxTxPktInterval;
+	u1Byte		txrxPayloadType;
+	u1Byte		txrxPktType;
+	u2Byte		txrxPayloadLen;
+	u4Byte		txrxPktHeader;
+	u1Byte		txrxWhitenCoeff;
+	u1Byte		txrxBdaddr[6];
+	u1Byte		txrxTxGainIndex;
+} BT_TXRX_PARAMETERS, *PBT_TXRX_PARAMETERS;
+
+/* txrxPktType */
+typedef enum _MP_BT_PKT_TYPE {
+	MP_BT_PKT_DH1							= 0,
+	MP_BT_PKT_DH3							= 1,
+	MP_BT_PKT_DH5							= 2,
+	MP_BT_PKT_2DH1							= 3,
+	MP_BT_PKT_2DH3							= 4,
+	MP_BT_PKT_2DH5							= 5,
+	MP_BT_PKT_3DH1							= 6,
+	MP_BT_PKT_3DH3							= 7,
+	MP_BT_PKT_3DH5							= 8,
+	MP_BT_PKT_LE							= 9,
+	MP_BT_PKT_MAX
+} MP_BT_PKT_TYPE, *PMP_BT_PKT_TYPE;
+/* txrxPayloadType */
+typedef enum _MP_BT_PAYLOAD_TYPE {
+	MP_BT_PAYLOAD_01010101					= 0,
+	MP_BT_PAYLOAD_ALL_1						= 1,
+	MP_BT_PAYLOAD_ALL_0						= 2,
+	MP_BT_PAYLOAD_11110000					= 3,
+	MP_BT_PAYLOAD_PRBS9						= 4,
+	MP_BT_PAYLOAD_MAX						= 8,
+} MP_BT_PAYLOAD_TYPE, *PMP_BT_PAYLOAD_TYPE;
+
+
+/* definition for BT_UP_OP_BT_TEST_CTRL */
+typedef enum _MP_BT_TEST_CTRL {
+	MP_BT_TEST_STOP_ALL_TESTS						= 0,
+	MP_BT_TEST_START_RX_TEST						= 1,
+	MP_BT_TEST_START_PACKET_TX_TEST					= 2,
+	MP_BT_TEST_START_CONTINUOUS_TX_TEST			= 3,
+	MP_BT_TEST_START_INQUIRY_SCAN_TEST				= 4,
+	MP_BT_TEST_START_PAGE_SCAN_TEST					= 5,
+	MP_BT_TEST_START_INQUIRY_PAGE_SCAN_TEST			= 6,
+	MP_BT_TEST_START_LEGACY_CONNECT_TEST			= 7,
+	MP_BT_TEST_START_LE_CONNECT_TEST_INITIATOR		= 8,
+	MP_BT_TEST_START_LE_CONNECT_TEST_ADVERTISER	= 9,
+	MP_BT_TEST_MAX
+} MP_BT_TEST_CTRL, *PMP_BT_TEST_CTRL;
+
+
+typedef enum _RTL_EXT_C2H_EVT {
+	EXT_C2H_WIFI_FW_ACTIVE_RSP = 0,
+	EXT_C2H_TRIG_BY_BT_FW = 1,
+	MAX_EXT_C2HEVENT
+} RTL_EXT_C2H_EVT;
+
+/* OP codes definition between the user layer and driver */
+typedef enum _BT_CTRL_OPCODE_UPPER {
+	BT_UP_OP_BT_READY										= 0x00,
+	BT_UP_OP_BT_SET_MODE									= 0x01,
+	BT_UP_OP_BT_SET_TX_RX_PARAMETER						= 0x02,
+	BT_UP_OP_BT_SET_GENERAL								= 0x03,
+	BT_UP_OP_BT_GET_GENERAL								= 0x04,
+	BT_UP_OP_BT_TEST_CTRL									= 0x05,
+	BT_UP_OP_TEST_BT										= 0x06,
+	BT_UP_OP_MAX
+} BT_CTRL_OPCODE_UPPER, *PBT_CTRL_OPCODE_UPPER;
+
+
+typedef enum _BT_SET_GENERAL {
+	BT_GSET_REG											= 0x00,
+	BT_GSET_RESET											= 0x01,
+	BT_GSET_TARGET_BD_ADDR									= 0x02,
+	BT_GSET_TX_PWR_FINETUNE								= 0x03,
+	BT_SET_TRACKING_INTERVAL								= 0x04,
+	BT_SET_THERMAL_METER									= 0x05,
+	BT_ENABLE_CFO_TRACKING									= 0x06,
+	BT_GSET_UPDATE_BT_PATCH								= 0x07,
+	BT_GSET_MAX
+} BT_SET_GENERAL, *PBT_SET_GENERAL;
+
+typedef enum _BT_GET_GENERAL {
+	BT_GGET_REG											= 0x00,
+	BT_GGET_STATUS											= 0x01,
+	BT_GGET_REPORT											= 0x02,
+	BT_GGET_AFH_MAP										= 0x03,
+	BT_GGET_AFH_STATUS										= 0x04,
+	BT_GGET_MAX
+} BT_GET_GENERAL, *PBT_GET_GENERAL;
+
+/* definition for BT_UP_OP_BT_SET_GENERAL */
+typedef enum _BT_REG_TYPE {
+	BT_REG_RF								= 0,
+	BT_REG_MODEM							= 1,
+	BT_REG_BLUEWIZE						= 2,
+	BT_REG_VENDOR							= 3,
+	BT_REG_LE								= 4,
+	BT_REG_MAX
+} BT_REG_TYPE, *PBT_REG_TYPE;
+
+/* definition for BT_LO_OP_GET_AFH_MAP */
+typedef enum _BT_AFH_MAP_TYPE {
+	BT_AFH_MAP_RESULT						= 0,
+	BT_AFH_MAP_WIFI_PSD_ONLY				= 1,
+	BT_AFH_MAP_WIFI_CH_BW_ONLY				= 2,
+	BT_AFH_MAP_BT_PSD_ONLY					= 3,
+	BT_AFH_MAP_HOST_CLASSIFICATION_ONLY	= 4,
+	BT_AFH_MAP_MAX
+} BT_AFH_MAP_TYPE, *PBT_AFH_MAP_TYPE;
+
+/* definition for BT_UP_OP_BT_GET_GENERAL */
+typedef enum _BT_REPORT_TYPE {
+	BT_REPORT_RX_PACKET_CNT				= 0,
+	BT_REPORT_RX_ERROR_BITS				= 1,
+	BT_REPORT_RSSI							= 2,
+	BT_REPORT_CFO_HDR_QUALITY				= 3,
+	BT_REPORT_CONNECT_TARGET_BD_ADDR		= 4,
+	BT_REPORT_MAX
+} BT_REPORT_TYPE, *PBT_REPORT_TYPE;
+
+VOID
+MPTBT_Test(
+	IN	PADAPTER	Adapter,
+	IN	u1Byte		opCode,
+	IN	u1Byte		byte1,
+	IN	u1Byte		byte2,
+	IN	u1Byte		byte3
+);
+
+NDIS_STATUS
+MPTBT_SendOidBT(
+	IN	PADAPTER		pAdapter,
+	IN	PVOID			InformationBuffer,
+	IN	ULONG			InformationBufferLength,
+	OUT	PULONG			BytesRead,
+	OUT	PULONG			BytesNeeded
+);
+
+VOID
+MPTBT_FwC2hBtMpCtrl(
+	PADAPTER	Adapter,
+	pu1Byte	tmpBuf,
+	u1Byte		length
+);
+
+void MPh2c_timeout_handle(void *FunctionContext);
+
+VOID mptbt_BtControlProcess(
+	PADAPTER	Adapter,
+	PVOID		pInBuf
+);
+
+#define	BT_H2C_MAX_RETRY								1
+#define	BT_MAX_C2H_LEN								20
+
+typedef struct _BT_REQ_CMD {
+	UCHAR       opCodeVer;
+	UCHAR       OpCode;
+	USHORT      paraLength;
+	UCHAR       pParamStart[100];
+} BT_REQ_CMD, *PBT_REQ_CMD;
+
+typedef struct _BT_RSP_CMD {
+	USHORT      status;
+	USHORT      paraLength;
+	UCHAR       pParamStart[100];
+} BT_RSP_CMD, *PBT_RSP_CMD;
+
+
+typedef struct _BT_H2C {
+	u1Byte	opCodeVer:4;
+	u1Byte	reqNum:4;
+	u1Byte	opCode;
+	u1Byte	buf[100];
+} BT_H2C, *PBT_H2C;
+
+
+
+typedef struct _BT_EXT_C2H {
+	u1Byte	extendId;
+	u1Byte	statusCode:4;
+	u1Byte	retLen:4;
+	u1Byte	opCodeVer:4;
+	u1Byte	reqNum:4;
+	u1Byte	buf[100];
+} BT_EXT_C2H, *PBT_EXT_C2H;
+
+
+typedef enum _BT_OPCODE_STATUS {
+	BT_OP_STATUS_SUCCESS									= 0x00, /* Success */
+	BT_OP_STATUS_VERSION_MISMATCH							= 0x01,
+	BT_OP_STATUS_UNKNOWN_OPCODE								= 0x02,
+	BT_OP_STATUS_ERROR_PARAMETER							= 0x03,
+	BT_OP_STATUS_MAX
+} BT_OPCODE_STATUS, *PBT_OPCODE_STATUS;
+
+
+
+/* OP codes definition between driver and bt fw */
+typedef enum _BT_CTRL_OPCODE_LOWER {
+	BT_LO_OP_GET_BT_VERSION									= 0x00,
+	BT_LO_OP_RESET												= 0x01,
+	BT_LO_OP_TEST_CTRL											= 0x02,
+	BT_LO_OP_SET_BT_MODE										= 0x03,
+	BT_LO_OP_SET_CHNL_TX_GAIN									= 0x04,
+	BT_LO_OP_SET_PKT_TYPE_LEN									= 0x05,
+	BT_LO_OP_SET_PKT_CNT_L_PL_TYPE								= 0x06,
+	BT_LO_OP_SET_PKT_CNT_H_PKT_INTV							= 0x07,
+	BT_LO_OP_SET_PKT_HEADER									= 0x08,
+	BT_LO_OP_SET_WHITENCOEFF									= 0x09,
+	BT_LO_OP_SET_BD_ADDR_L										= 0x0a,
+	BT_LO_OP_SET_BD_ADDR_H										= 0x0b,
+	BT_LO_OP_WRITE_REG_ADDR									= 0x0c,
+	BT_LO_OP_WRITE_REG_VALUE									= 0x0d,
+	BT_LO_OP_GET_BT_STATUS										= 0x0e,
+	BT_LO_OP_GET_BD_ADDR_L										= 0x0f,
+	BT_LO_OP_GET_BD_ADDR_H										= 0x10,
+	BT_LO_OP_READ_REG											= 0x11,
+	BT_LO_OP_SET_TARGET_BD_ADDR_L								= 0x12,
+	BT_LO_OP_SET_TARGET_BD_ADDR_H								= 0x13,
+	BT_LO_OP_SET_TX_POWER_CALIBRATION							= 0x14,
+	BT_LO_OP_GET_RX_PKT_CNT_L									= 0x15,
+	BT_LO_OP_GET_RX_PKT_CNT_H									= 0x16,
+	BT_LO_OP_GET_RX_ERROR_BITS_L								= 0x17,
+	BT_LO_OP_GET_RX_ERROR_BITS_H								= 0x18,
+	BT_LO_OP_GET_RSSI											= 0x19,
+	BT_LO_OP_GET_CFO_HDR_QUALITY_L								= 0x1a,
+	BT_LO_OP_GET_CFO_HDR_QUALITY_H								= 0x1b,
+	BT_LO_OP_GET_TARGET_BD_ADDR_L								= 0x1c,
+	BT_LO_OP_GET_TARGET_BD_ADDR_H								= 0x1d,
+	BT_LO_OP_GET_AFH_MAP_L										= 0x1e,
+	BT_LO_OP_GET_AFH_MAP_M										= 0x1f,
+	BT_LO_OP_GET_AFH_MAP_H										= 0x20,
+	BT_LO_OP_GET_AFH_STATUS									= 0x21,
+	BT_LO_OP_SET_TRACKING_INTERVAL								= 0x22,
+	BT_LO_OP_SET_THERMAL_METER									= 0x23,
+	BT_LO_OP_ENABLE_CFO_TRACKING								= 0x24,
+	BT_LO_OP_MAX
+} BT_CTRL_OPCODE_LOWER, *PBT_CTRL_OPCODE_LOWER;
+
+
+
+
+#endif  /* #if(MP_DRIVER == 1) */
+
+#endif /*  #ifndef __INC_MPT_BT_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_btcoex.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_btcoex.h
index b1489c4b6eb5..975ea8f30b3e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_btcoex.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_btcoex.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,9 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
+#ifdef CONFIG_BT_COEXIST
+
 #ifndef __RTW_BTCOEX_H__
 #define __RTW_BTCOEX_H__
 
@@ -53,6 +51,13 @@ typedef enum _BT_CTRL_STATUS {
 	BT_STATUS_MAX
 } BT_CTRL_STATUS, *PBT_CTRL_STATUS;
 
+typedef enum _BTCOEX_SUSPEND_STATE {
+	BTCOEX_SUSPEND_STATE_RESUME					= 0x0,
+	BTCOEX_SUSPEND_STATE_SUSPEND				= 0x1,
+	BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT		= 0x2,
+	BTCOEX_SUSPEND_STATE_MAX
+} BTCOEX_SUSPEND_STATE, *PBTCOEX_SUSPEND_STATE;
+
 #define SET_BT_MP_OPER_RET(OpCode, StatusCode)						((OpCode << 8) | StatusCode)
 #define GET_OP_CODE_FROM_BT_MP_OPER_RET(RetCode)					((RetCode & 0xF0) >> 8)
 #define GET_STATUS_CODE_FROM_BT_MP_OPER_RET(RetCode)				(RetCode & 0x0F)
@@ -63,7 +68,7 @@ typedef enum _BT_CTRL_STATUS {
 #define NETLINK_USER 31
 #define CONNECT_PORT 30000
 #define CONNECT_PORT_BT 30001
-#define KERNEL_SOCKET_OK 0x01	
+#define KERNEL_SOCKET_OK 0x01
 #define NETLINK_SOCKET_OK 0x02
 
 #define OTHER 0
@@ -85,7 +90,7 @@ typedef enum _BT_CTRL_STATUS {
 #define BT_INFO_NOTIFY_CMD 0x0106
 #define BT_INFO_LEN 8
 
-typedef struct _HCI_LINK_INFO{
+typedef struct _HCI_LINK_INFO {
 	u2Byte					ConnectHandle;
 	u1Byte					IncomingTrafficMode;
 	u1Byte					OutgoingTrafficMode;
@@ -94,11 +99,11 @@ typedef struct _HCI_LINK_INFO{
 	s1Byte					BT_RSSI;
 	u1Byte					TrafficProfile;
 	u1Byte					linkRole;
-}HCI_LINK_INFO, *PHCI_LINK_INFO;
+} HCI_LINK_INFO, *PHCI_LINK_INFO;
 
 #define	MAX_BT_ACL_LINK_NUM				8
 
-typedef struct _HCI_EXT_CONFIG{
+typedef struct _HCI_EXT_CONFIG {
 	HCI_LINK_INFO				aclLink[MAX_BT_ACL_LINK_NUM];
 	u1Byte					btOperationCode;
 	u2Byte					CurrentConnectHandle;
@@ -111,29 +116,29 @@ typedef struct _HCI_EXT_CONFIG{
 	u2Byte					HCIExtensionVer;
 
 	BOOLEAN					bEnableWifiScanNotify;
-}HCI_EXT_CONFIG, *PHCI_EXT_CONFIG;
+} HCI_EXT_CONFIG, *PHCI_EXT_CONFIG;
+
+typedef struct _HCI_PHY_LINK_BSS_INFO {
+	u2Byte						bdCap;			/* capability information */
 
-typedef struct _HCI_PHY_LINK_BSS_INFO{
-	u2Byte						bdCap;			// capability information
+	/* Qos related. Added by Annie, 2005-11-01. */
+	/* BSS_QOS						BssQos;		 */
 
-	// Qos related. Added by Annie, 2005-11-01.
-	//BSS_QOS						BssQos;		
-	
-}HCI_PHY_LINK_BSS_INFO, *PHCI_PHY_LINK_BSS_INFO;
+} HCI_PHY_LINK_BSS_INFO, *PHCI_PHY_LINK_BSS_INFO;
 
-typedef 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
-}BT_CONNECT_TYPE,*PBT_CONNECT_TYPE;
+typedef 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
+} BT_CONNECT_TYPE, *PBT_CONNECT_TYPE;
 
 
 typedef struct _PACKET_IRP_HCIEVENT_DATA {
-	    u8		EventCode;
-	    u8		Length; //total cmd length = extension event length+1(extension event code length)
-	    u8		Data[1]; // byte1 is extension event code
+	u8		EventCode;
+	u8		Length; /* total cmd length = extension event length+1(extension event code length) */
+	u8		Data[1]; /* byte1 is extension event code */
 } rtw_HCI_event;
 
 
@@ -172,124 +177,124 @@ struct btinfo_8761ATV {
 };
 
 #define HCIOPCODE(_OCF, _OGF)     ((_OGF)<<10|(_OCF))
-#define HCIOPCODELOW(_OCF, _OGF)	(u8)(HCIOPCODE(_OCF, _OGF)&0x00ff)
+#define HCIOPCODELOW(_OCF, _OGF)	(u8)(HCIOPCODE(_OCF, _OGF) & 0x00ff)
 #define HCIOPCODEHIGHT(_OCF, _OGF) (u8)(HCIOPCODE(_OCF, _OGF)>>8)
 #define HCI_OGF(opCode)  (unsigned char)((0xFC00 & (opCode)) >> 10)
-#define HCI_OCF(opCode)  ( 0x3FF & (opCode))
-
-
-typedef 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
-}RTW_HCI_STATUS;
+#define HCI_OCF(opCode)  (0x3FF & (opCode))
+
+
+typedef 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 */
+} RTW_HCI_STATUS;
 
 #define HCI_EVENT_COMMAND_COMPLETE					0x0e
 
 #define OGF_EXTENSION									0X3f
-typedef 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,
-	HCI_QUERY_RF_STATUS								=0x0104,
-	HCI_BT_ABNORMAL_NOTIFY							=0x0105,
-	HCI_BT_INFO_NOTIFY								=0x0106,
-	HCI_BT_COEX_NOTIFY								=0x0107,
-	HCI_BT_PATCH_VERSION_NOTIFY						=0x0108,
-	HCI_BT_AFH_MAP_NOTIFY							=0x0109,
-	HCI_BT_REGISTER_VALUE_NOTIFY					=0x010a,
-	
-	//The following is for IVT
-	HCI_WIFI_CURRENT_CHANNEL						=0x0300,	
-	HCI_WIFI_CURRENT_BANDWIDTH						=0x0301,		
-	HCI_WIFI_CONNECTION_STATUS						=0x0302
-}RTW_HCI_EXT_CMD;
+typedef 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,
+	HCI_QUERY_RF_STATUS								= 0x0104,
+	HCI_BT_ABNORMAL_NOTIFY							= 0x0105,
+	HCI_BT_INFO_NOTIFY								= 0x0106,
+	HCI_BT_COEX_NOTIFY								= 0x0107,
+	HCI_BT_PATCH_VERSION_NOTIFY						= 0x0108,
+	HCI_BT_AFH_MAP_NOTIFY							= 0x0109,
+	HCI_BT_REGISTER_VALUE_NOTIFY					= 0x010a,
+
+	/* The following is for IVT */
+	HCI_WIFI_CURRENT_CHANNEL						= 0x0300,
+	HCI_WIFI_CURRENT_BANDWIDTH						= 0x0301,
+	HCI_WIFI_CONNECTION_STATUS						= 0x0302
+} RTW_HCI_EXT_CMD;
 
 #define HCI_EVENT_EXTENSION_RTK						0xfe
-typedef enum HCI_EXTENSION_EVENT_RTK{
-	HCI_EVENT_EXT_WIFI_SCAN_NOTIFY								=0x01,
-	HCI_EVENT_EXT_WIFI_RF_STATUS_NOTIFY						=0x02,
-	HCI_EVENT_EXT_BT_INFO_CONTROL								=0x03,
-	HCI_EVENT_EXT_BT_COEX_CONTROL								=0x04
-}RTW_HCI_EXT_EVENT;
-
-typedef 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.
+typedef enum HCI_EXTENSION_EVENT_RTK {
+	HCI_EVENT_EXT_WIFI_SCAN_NOTIFY								= 0x01,
+	HCI_EVENT_EXT_WIFI_RF_STATUS_NOTIFY						= 0x02,
+	HCI_EVENT_EXT_BT_INFO_CONTROL								= 0x03,
+	HCI_EVENT_EXT_BT_COEX_CONTROL								= 0x04
+} RTW_HCI_EXT_EVENT;
+
+typedef 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. */
 } BT_TRAFFIC_MODE;
 
-typedef enum _BT_TRAFFIC_MODE_PROFILE{
-	BT_PROFILE_NONE,	
+typedef enum _BT_TRAFFIC_MODE_PROFILE {
+	BT_PROFILE_NONE,
 	BT_PROFILE_A2DP,
 	BT_PROFILE_PAN	,
 	BT_PROFILE_HID,
-	BT_PROFILE_SCO		
+	BT_PROFILE_SCO
 } BT_TRAFFIC_MODE_PROFILE;
 
 typedef enum _HCI_EXT_BT_OPERATION {
@@ -306,18 +311,18 @@ typedef enum _HCI_EXT_BT_OPERATION {
 	HCI_BT_OP_MAX
 } HCI_EXT_BT_OPERATION, *PHCI_EXT_BT_OPERATION;
 
-typedef struct _BT_MGNT{
+typedef struct _BT_MGNT {
 	BOOLEAN				bBTConnectInProgress;
 	BOOLEAN				bLogLinkInProgress;
 	BOOLEAN				bPhyLinkInProgress;
 	BOOLEAN				bPhyLinkInProgressStartLL;
 	u1Byte				BtCurrentPhyLinkhandle;
-	u2Byte				BtCurrentLogLinkhandle;	
+	u2Byte				BtCurrentLogLinkhandle;
 	u1Byte				CurrentConnectEntryNum;
 	u1Byte				DisconnectEntryNum;
 	u1Byte				CurrentBTConnectionCnt;
 	BT_CONNECT_TYPE		BTCurrentConnectType;
-	BT_CONNECT_TYPE		BTReceiveConnectPkt;	
+	BT_CONNECT_TYPE		BTReceiveConnectPkt;
 	u1Byte				BTAuthCount;
 	u1Byte				BTAsocCount;
 	BOOLEAN				bStartSendSupervisionPkt;
@@ -335,25 +340,25 @@ typedef struct _BT_MGNT{
 	BOOLEAN				btLogoTest;
 	BOOLEAN				bRfStatusNotified;
 	BOOLEAN				bBtRsvedPageDownload;
-}BT_MGNT, *PBT_MGNT;
+} BT_MGNT, *PBT_MGNT;
 
 struct bt_coex_info {
 	/* For Kernel Socket */
-	struct socket *udpsock; 
+	struct socket *udpsock;
 	struct sockaddr_in wifi_sockaddr; /*wifi socket*/
-	struct sockaddr_in bt_sockaddr;/* BT socket  */
+	struct sockaddr_in bt_sockaddr;/* BT socket */
 	struct sock *sk_store;/*back up socket for UDP RX int*/
-	
+
 	/* store which socket is OK */
 	u8 sock_open;
-		
+
 	u8 BT_attend;
 	u8 is_exist; /* socket exist */
 	BT_MGNT BtMgnt;
 	struct workqueue_struct *btcoex_wq;
 	struct delayed_work recvmsg_work;
 };
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 
 #define	PACKET_NORMAL			0
 #define	PACKET_DHCP				1
@@ -362,6 +367,8 @@ struct bt_coex_info {
 
 void rtw_btcoex_Initialize(PADAPTER);
 void rtw_btcoex_PowerOnSetting(PADAPTER padapter);
+void rtw_btcoex_AntInfoSetting(PADAPTER padapter);
+void rtw_btcoex_PowerOffSetting(PADAPTER padapter);
 void rtw_btcoex_PreLoadFirmware(PADAPTER padapter);
 void rtw_btcoex_HAL_Initialize(PADAPTER padapter, u8 bWifiOnly);
 void rtw_btcoex_IpsNotify(PADAPTER, u8 type);
@@ -375,7 +382,9 @@ void rtw_btcoex_BtInfoNotify(PADAPTER, u8 length, u8 *tmpBuf);
 void rtw_btcoex_BtMpRptNotify(PADAPTER, u8 length, u8 *tmpBuf);
 void rtw_btcoex_SuspendNotify(PADAPTER, u8 state);
 void rtw_btcoex_HaltNotify(PADAPTER);
-void rtw_btcoex_ScoreBoardStatusNotify(PADAPTER, u8 length, u8 *tmpBuf);
+void rtw_btcoex_switchband_notify(u8 under_scan, u8 band_type);
+void rtw_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length);
+void rtw_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id);
 void rtw_btcoex_SwitchBtTRxMask(PADAPTER);
 void rtw_btcoex_Switch(PADAPTER, u8 enable);
 u8 rtw_btcoex_IsBtDisabled(PADAPTER);
@@ -389,11 +398,6 @@ u8 rtw_btcoex_IsBtControlLps(PADAPTER);
 u8 rtw_btcoex_IsLpsOn(PADAPTER);
 u8 rtw_btcoex_RpwmVal(PADAPTER);
 u8 rtw_btcoex_LpsVal(PADAPTER);
-void rtw_btcoex_SetBTCoexist(PADAPTER, u8 bBtExist);
-void rtw_btcoex_SetChipType(PADAPTER, u8 chipType);
-void rtw_btcoex_SetPGAntNum(PADAPTER, u8 antNum);
-u8 rtw_btcoex_GetPGAntNum(PADAPTER);
-void rtw_btcoex_SetSingleAntPath(PADAPTER padapter, u8 singleAntPath);
 u32 rtw_btcoex_GetRaMask(PADAPTER);
 void rtw_btcoex_RecordPwrMode(PADAPTER, u8 *pCmdBuf, u8 cmdLen);
 void rtw_btcoex_DisplayBtCoexInfo(PADAPTER, u8 *pbuf, u32 bufsize);
@@ -401,9 +405,15 @@ void rtw_btcoex_SetDBG(PADAPTER, u32 *pDbgModule);
 u32 rtw_btcoex_GetDBG(PADAPTER, u8 *pStrBuf, u32 bufSize);
 u8 rtw_btcoex_IncreaseScanDeviceNum(PADAPTER);
 u8 rtw_btcoex_IsBtLinkExist(PADAPTER);
-void rtw_btcoex_BTOffOnNotify(PADAPTER padapter, u8 bBTON);
+void rtw_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON);
+
+#ifdef CONFIG_RF4CE_COEXIST
+void rtw_btcoex_SetRf4ceLinkState(PADAPTER padapter, u8 state);
+u8 rtw_btcoex_GetRf4ceLinkState(PADAPTER padapter);
+#endif
+
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-void rtw_btcoex_SetBtPatchVersion(PADAPTER padapter,u16 btHciVer, u16 btPatchVer);
+void rtw_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer);
 void rtw_btcoex_SetHciVersion(PADAPTER  padapter, u16 hciVersion);
 void rtw_btcoex_StackUpdateProfileInfo(void);
 void rtw_btcoex_init_socket(_adapter *padapter);
@@ -421,16 +431,26 @@ void rtw_btcoex_SendEventExtBtInfoControl(PADAPTER Adapter, u8 dataLen, void *pD
 void rtw_btcoex_SendScanNotify(PADAPTER padapter, u8 scanType);
 #define BT_SendEventExtBtCoexControl(Adapter, bNeedDbgRsp, dataLen, pData) rtw_btcoex_SendEventExtBtCoexControl(Adapter, bNeedDbgRsp, dataLen, pData)
 #define BT_SendEventExtBtInfoControl(Adapter, dataLen, pData) rtw_btcoex_SendEventExtBtInfoControl(Adapter, dataLen, pData)
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 u16 rtw_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data);
 u16 rtw_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val);
-
-// ==================================================
-// Below Functions are called by BT-Coex
-// ==================================================
-void rtw_btcoex_rx_ampdu_apply(PADAPTER);
-void rtw_btcoex_LPS_Enter(PADAPTER);
-void rtw_btcoex_LPS_Leave(PADAPTER);
-
-#endif // __RTW_BTCOEX_H__
+u8 rtw_btcoex_get_bt_coexist(PADAPTER padapter);
+u8 rtw_btcoex_get_chip_type(PADAPTER padapter);
+u8 rtw_btcoex_get_pg_ant_num(PADAPTER padapter);
+u8 rtw_btcoex_get_pg_single_ant_path(PADAPTER padapter);
+u8 rtw_btcoex_get_pg_rfe_type(PADAPTER padapter);
+u8 rtw_btcoex_is_tfbga_package_type(PADAPTER padapter);
+u8 rtw_btcoex_get_ant_div_cfg(PADAPTER padapter);
+
+/* ==================================================
+ * Below Functions are called by BT-Coex
+ * ================================================== */
+void rtw_btcoex_rx_ampdu_apply(PADAPTER padapter);
+void rtw_btcoex_LPS_Enter(PADAPTER padapter);
+u8 rtw_btcoex_LPS_Leave(PADAPTER padapter);
+
+#endif /* __RTW_BTCOEX_H__ */
+#endif /* CONFIG_BT_COEXIST */
+
+void rtw_btcoex_set_ant_info(PADAPTER padapter);
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_btcoex_wifionly.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_btcoex_wifionly.h
new file mode 100644
index 000000000000..1934eeab7cf1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_btcoex_wifionly.h
@@ -0,0 +1,24 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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_BTCOEX_WIFIONLY_H__
+#define __RTW_BTCOEX_WIFIONLY_H__
+
+void rtw_btcoex_wifionly_switchband_notify(PADAPTER padapter);
+void rtw_btcoex_wifionly_scan_notify(PADAPTER padapter);
+void rtw_btcoex_wifionly_hw_config(PADAPTER padapter);
+void rtw_btcoex_wifionly_initialize(PADAPTER padapter);
+void rtw_btcoex_wifionly_AntInfoSetting(PADAPTER padapter);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_byteorder.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_byteorder.h
index 29c5029cebb1..f117fe317d4e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_byteorder.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_byteorder.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,29 +12,23 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTL871X_BYTEORDER_H_
 #define _RTL871X_BYTEORDER_H_
 
 
-#if defined (CONFIG_LITTLE_ENDIAN) && defined (CONFIG_BIG_ENDIAN)
-#error "Shall be CONFIG_LITTLE_ENDIAN or CONFIG_BIG_ENDIAN, but not both!\n"
+#if defined(CONFIG_LITTLE_ENDIAN) && defined (CONFIG_BIG_ENDIAN)
+	#error "Shall be CONFIG_LITTLE_ENDIAN or CONFIG_BIG_ENDIAN, but not both!\n"
 #endif
 
-#if defined (CONFIG_LITTLE_ENDIAN)
-#ifndef CONFIG_PLATFORM_MSTAR389
-#  include <byteorder/little_endian.h>
-#endif
+#if defined(CONFIG_LITTLE_ENDIAN)
+	#ifndef CONFIG_PLATFORM_MSTAR389
+		#include <byteorder/little_endian.h>
+	#endif
 #elif defined (CONFIG_BIG_ENDIAN)
-#  include <byteorder/big_endian.h>
+	#include <byteorder/big_endian.h>
 #else
-#  error "Must be LITTLE/BIG Endian Host"
+	#  error "Must be LITTLE/BIG Endian Host"
 #endif
 
 #endif /* _RTL871X_BYTEORDER_H_ */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_cmd.h
index 4f06a3a22e65..1c9bb087b5f4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_cmd.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_CMD_H_
 #define __RTW_CMD_H_
 
@@ -25,11 +21,11 @@
 
 #ifndef CONFIG_RTL8711FW
 
-	#define FREE_CMDOBJ_SZ	128
-	
-	#define MAX_CMDSZ	1024
-	#define MAX_RSPSZ	512
-	#define MAX_EVTSZ	1024
+#define FREE_CMDOBJ_SZ	128
+
+#define MAX_CMDSZ	1024
+#define MAX_RSPSZ	512
+#define MAX_EVTSZ	1024
 
 #ifdef PLATFORM_OS_CE
 	#define CMDBUFF_ALIGN_SZ 4
@@ -37,152 +33,139 @@
 	#define CMDBUFF_ALIGN_SZ 512
 #endif
 
-	struct cmd_obj {
-		_adapter *padapter;
-		u16	cmdcode;
-		u8	res;
-		u8	*parmbuf;
-		u32	cmdsz;
-		u8	*rsp;
-		u32	rspsz;
-		struct submit_ctx *sctx;
-		u8 no_io;
-		//_sema 	cmd_sem;
-		_list	list;
-	};
-
-	/* cmd flags */
-	enum {
-		RTW_CMDF_DIRECTLY = BIT0,
-		RTW_CMDF_WAIT_ACK = BIT1,
-	};
-
-	struct cmd_priv {
-		_sema	cmd_queue_sema;
-		//_sema	cmd_done_sema;
-		_sema	terminate_cmdthread_sema;		
-		_queue	cmd_queue;
-		u8	cmd_seq;
-		u8	*cmd_buf;	//shall be non-paged, and 4 bytes aligned
-		u8	*cmd_allocated_buf;
-		u8	*rsp_buf;	//shall be non-paged, and 4 bytes aligned		
-		u8	*rsp_allocated_buf;
-		u32	cmd_issued_cnt;
-		u32	cmd_done_cnt;
-		u32	rsp_cnt;
-		ATOMIC_T cmdthd_running;
-		//u8 cmdthd_running;
-		u8 stop_req;
-		_adapter *padapter;
-		_mutex sctx_mutex;
-	};
+struct cmd_obj {
+	_adapter *padapter;
+	u16	cmdcode;
+	u8	res;
+	u8	*parmbuf;
+	u32	cmdsz;
+	u8	*rsp;
+	u32	rspsz;
+	struct submit_ctx *sctx;
+	u8 no_io;
+	/* _sema 	cmd_sem; */
+	_list	list;
+};
+
+/* cmd flags */
+enum {
+	RTW_CMDF_DIRECTLY = BIT0,
+	RTW_CMDF_WAIT_ACK = BIT1,
+};
+
+struct cmd_priv {
+	_sema	cmd_queue_sema;
+	/* _sema	cmd_done_sema; */
+	_sema	start_cmdthread_sema;
+
+	_queue	cmd_queue;
+	u8	cmd_seq;
+	u8	*cmd_buf;	/* shall be non-paged, and 4 bytes aligned */
+	u8	*cmd_allocated_buf;
+	u8	*rsp_buf;	/* shall be non-paged, and 4 bytes aligned		 */
+	u8	*rsp_allocated_buf;
+	u32	cmd_issued_cnt;
+	u32	cmd_done_cnt;
+	u32	rsp_cnt;
+	ATOMIC_T cmdthd_running;
+	/* u8 cmdthd_running; */
+
+	_adapter *padapter;
+	_mutex sctx_mutex;
+};
 
 #ifdef CONFIG_EVENT_THREAD_MODE
-	struct evt_obj {
-		u16	evtcode;
-		u8	res;
-		u8	*parmbuf;
-		u32	evtsz;		
-		_list	list;
-	};
+struct evt_obj {
+	u16	evtcode;
+	u8	res;
+	u8	*parmbuf;
+	u32	evtsz;
+	_list	list;
+};
 #endif
 
-	struct	evt_priv {
+struct	evt_priv {
 #ifdef CONFIG_EVENT_THREAD_MODE
-		_sema	evt_notify;
-		_sema	terminate_evtthread_sema;
-		_queue	evt_queue;
+	_sema	evt_notify;
+
+	_queue	evt_queue;
+#endif
+
+#ifdef CONFIG_FW_C2H_REG
+	#define CONFIG_C2H_WK
 #endif
 
-#define CONFIG_C2H_WK
 #ifdef CONFIG_C2H_WK
-		_workitem c2h_wk;
-		bool c2h_wk_alive;
-		struct rtw_cbuf *c2h_queue;
-		#define C2H_QUEUE_MAX_LEN 10
+	_workitem c2h_wk;
+	bool c2h_wk_alive;
+	struct rtw_cbuf *c2h_queue;
+	#define C2H_QUEUE_MAX_LEN 10
 #endif
-		
+
 #ifdef CONFIG_H2CLBK
-		_sema	lbkevt_done;
-		u8	lbkevt_limit;
-		u8	lbkevt_num;
-		u8	*cmdevt_parm;		
+	_sema	lbkevt_done;
+	u8	lbkevt_limit;
+	u8	lbkevt_num;
+	u8	*cmdevt_parm;
 #endif
-		ATOMIC_T event_seq;
-		u8	*evt_buf;	//shall be non-paged, and 4 bytes aligned		
-		u8	*evt_allocated_buf;
-		u32	evt_done_cnt;
+	ATOMIC_T event_seq;
+	u8	*evt_buf;	/* shall be non-paged, and 4 bytes aligned		 */
+	u8	*evt_allocated_buf;
+	u32	evt_done_cnt;
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-		u8	*c2h_mem;
-		u8	*allocated_c2h_mem;
+	u8	*c2h_mem;
+	u8	*allocated_c2h_mem;
 #ifdef PLATFORM_OS_XP
-		PMDL	pc2h_mdl;
+	PMDL	pc2h_mdl;
 #endif
 #endif
 
-	};
+};
 
 #define init_h2fwcmd_w_parm_no_rsp(pcmd, pparm, code) \
-do {\
-	_rtw_init_listhead(&pcmd->list);\
-	pcmd->cmdcode = code;\
-	pcmd->parmbuf = (u8 *)(pparm);\
-	pcmd->cmdsz = sizeof (*pparm);\
-	pcmd->rsp = NULL;\
-	pcmd->rspsz = 0;\
-} while(0)
+	do {\
+		_rtw_init_listhead(&pcmd->list);\
+		pcmd->cmdcode = code;\
+		pcmd->parmbuf = (u8 *)(pparm);\
+		pcmd->cmdsz = sizeof (*pparm);\
+		pcmd->rsp = NULL;\
+		pcmd->rspsz = 0;\
+	} while (0)
 
 #define init_h2fwcmd_w_parm_no_parm_rsp(pcmd, code) \
-do {\
-	_rtw_init_listhead(&pcmd->list);\
-	pcmd->cmdcode = code;\
-	pcmd->parmbuf = NULL;\
-	pcmd->cmdsz = 0;\
-	pcmd->rsp = NULL;\
-	pcmd->rspsz = 0;\
-} while(0)
-
-struct c2h_evt_hdr {
-	u8 id:4;
-	u8 plen:4;
-	u8 seq;
-	u8 payload[0];
-};
-
-struct c2h_evt_hdr_88xx {
-	u8 id;
-	u8 seq;
-	u8 payload[12];
-	u8 plen;
-	u8 trigger;
-};
-
-#define c2h_evt_valid(c2h_evt) ((c2h_evt)->id || (c2h_evt)->plen)
+	do {\
+		_rtw_init_listhead(&pcmd->list);\
+		pcmd->cmdcode = code;\
+		pcmd->parmbuf = NULL;\
+		pcmd->cmdsz = 0;\
+		pcmd->rsp = NULL;\
+		pcmd->rspsz = 0;\
+	} while (0)
 
 struct P2P_PS_Offload_t {
 	u8 Offload_En:1;
-	u8 role:1; // 1: Owner, 0: Client
+	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 AllStaSleep:1; /* Only valid in Owner */
 	u8 discovery:1;
 	u8 rsvd:1;
 };
 
 struct P2P_PS_CTWPeriod_t {
-	u8 CTWPeriod;	//TU
+	u8 CTWPeriod;	/* TU */
 };
 
 #ifdef CONFIG_P2P_WOWLAN
 
-struct P2P_WoWlan_Offload_t{
+struct P2P_WoWlan_Offload_t {
 	u8 Disconnect_Wkup_Drv:1;
 	u8 role:2;
 	u8 Wps_Config[2];
 };
 
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
 
 extern u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *obj);
 extern struct cmd_obj *rtw_dequeue_cmd(struct cmd_priv *pcmdpriv);
@@ -197,71 +180,108 @@ extern void rtw_free_evt_obj(struct evt_obj *pcmd);
 void rtw_stop_cmd_thread(_adapter *adapter);
 thread_return rtw_cmd_thread(thread_context context);
 
-extern u32 rtw_init_cmd_priv (struct cmd_priv *pcmdpriv);
-extern void rtw_free_cmd_priv (struct cmd_priv *pcmdpriv);
+extern u32 rtw_init_cmd_priv(struct cmd_priv *pcmdpriv);
+extern void rtw_free_cmd_priv(struct cmd_priv *pcmdpriv);
 
-extern u32 rtw_init_evt_priv (struct evt_priv *pevtpriv);
-extern void rtw_free_evt_priv (struct evt_priv *pevtpriv);
+extern u32 rtw_init_evt_priv(struct evt_priv *pevtpriv);
+extern void rtw_free_evt_priv(struct evt_priv *pevtpriv);
 extern void rtw_cmd_clr_isr(struct cmd_priv *pcmdpriv);
 extern void rtw_evt_notify_isr(struct evt_priv *pevtpriv);
 #ifdef CONFIG_P2P
-u8 p2p_protocol_wk_cmd(_adapter*padapter, int intCmdType );
-#endif //CONFIG_P2P
+u8 p2p_protocol_wk_cmd(_adapter *padapter, int intCmdType);
+
+#ifdef CONFIG_IOCTL_CFG80211
+struct p2p_roch_parm {
+	u64 cookie;
+	struct wireless_dev *wdev;
+	struct ieee80211_channel ch;
+	enum nl80211_channel_type ch_type;
+	unsigned int duration;
+};
+
+u8 p2p_roch_cmd(_adapter *adapter
+	, u64 cookie, struct wireless_dev *wdev
+	, struct ieee80211_channel *ch, enum nl80211_channel_type ch_type
+	, unsigned int duration
+	, u8 flags
+);
+u8 p2p_cancel_roch_cmd(_adapter *adapter, u64 cookie, struct wireless_dev *wdev, u8 flags);
+
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_IOCTL_CFG80211 
+u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack, u8 flags);
+struct mgnt_tx_parm {
+	u8 tx_ch;
+	u8 no_cck;
+	const u8 *buf;
+	size_t len;
+	int wait_ack;
+};
+#endif
 
 #else
-	//#include <ieee80211.h>
+/* #include <ieee80211.h> */
 #endif	/* CONFIG_RTL8711FW */
 
-enum rtw_drvextra_cmd_id
-{	
+enum rtw_drvextra_cmd_id {
 	NONE_WK_CID,
 	STA_MSTATUS_RPT_WK_CID,
 	DYNAMIC_CHK_WK_CID,
 	DM_CTRL_WK_CID,
 	PBC_POLLING_WK_CID,
-	POWER_SAVING_CTRL_WK_CID,//IPS,AUTOSuspend
+	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
+	CHECK_HIQ_WK_CID,/* for softap mode, check hi queue if empty */
 	INTEl_WIDI_WK_CID,
 	C2H_WK_CID,
 	RTP_TIMER_CFG_WK_CID,
-	RESET_SECURITYPRIV, // add for CONFIG_IEEE80211W, none 11w also can use
-	FREE_ASSOC_RESOURCES, // add for CONFIG_IEEE80211W, none 11w also can use
+	RESET_SECURITYPRIV, /* add for CONFIG_IEEE80211W, none 11w also can use */
+	FREE_ASSOC_RESOURCES, /* add for CONFIG_IEEE80211W, none 11w also can use */
 	DM_IN_LPS_WK_CID,
-	DM_RA_MSK_WK_CID, //add for STA update RAMask when bandwith change.
+	DM_RA_MSK_WK_CID, /* add for STA update RAMask when bandwith change. */
 	BEAMFORMING_WK_CID,
 	LPS_CHANGE_DTIM_CID,
 	BTINFO_WK_CID,
 	DFS_MASTER_WK_CID,
 	SESSION_TRACKER_WK_CID,
 	EN_HW_UPDATE_TSF_WK_CID,
+	TEST_H2C_CID,
+	MP_CMD_WK_CID,
 	CUSTOMER_STR_WK_CID,
+#ifdef CONFIG_RTW_REPEATER_SON
+	RSON_SCAN_WK_CID,
+#endif
+	MGNT_TX_WK_CID,
+#ifdef CONFIG_MCC_MODE
+	MCC_SET_DURATION_WK_CID,
+#endif /* CONFIG_MCC_MODE */
+	REQ_PER_CMD_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 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,
 	LPS_CTRL_TRAFFIC_BUSY = 6,
 	LPS_CTRL_TX_TRAFFIC_LEAVE = 7,
-	LPS_CTRL_RX_TRAFFIC_LEAVE = 8,	
+	LPS_CTRL_RX_TRAFFIC_LEAVE = 8,
 	LPS_CTRL_ENTER = 9,
 	LPS_CTRL_LEAVE_CFG80211_PWRMGMT = 10,
 };
 
-enum STAKEY_TYPE
-{
-	GROUP_KEY		=0,
-	UNICAST_KEY		=1,
-	TDLS_KEY		=2,
+enum STAKEY_TYPE {
+	GROUP_KEY		= 0,
+	UNICAST_KEY		= 1,
+	TDLS_KEY		= 2,
 };
 
 enum RFINTFS {
@@ -279,7 +299,7 @@ Command Mode
 
 */
 struct usb_suspend_parm {
-	u32 action;// 1: sleep, 0:resume
+	u32 action;/* 1: sleep, 0:resume */
 };
 
 /*
@@ -327,28 +347,25 @@ struct createbss_parm {
 
 	/* used by AP mode now */
 	s16 req_ch;
-	u8 req_bw;
-	u8 req_offset;
-};
-
-/*
-Caller Mode: AP, Ad-HoC, Infra
-
-Notes: To set the NIC mode of RTL8711
-
-Command Mode
-
-The definition of mode:
-
-#define IW_MODE_AUTO	0	// Let the driver decides which AP to join
-#define IW_MODE_ADHOC	1	// Single cell network (Ad-Hoc Clients)
-#define IW_MODE_INFRA	2	// Multi cell network, roaming, ..
-#define IW_MODE_MASTER	3	// Synchronisation master or Access Point
-#define IW_MODE_REPEAT	4	// Wireless Repeater (forwarder)
-#define IW_MODE_SECOND	5	// Secondary master/repeater (backup)
-#define IW_MODE_MONITOR	6	// Passive monitor (listen only)
+	s8 req_bw;
+	s8 req_offset;
+};
+
+#if 0
+/* Caller Mode: AP, Ad-HoC, Infra */
+/* Notes: To set the NIC mode of RTL8711 */
+/* Command Mode */
+/* The definition of mode: */
+
+#define IW_MODE_AUTO	0	/*  Let the driver decides which AP to join */
+#define IW_MODE_ADHOC	1	/*  Single cell network (Ad-Hoc Clients) */
+#define IW_MODE_INFRA	2	/*  Multi cell network, roaming, .. */
+#define IW_MODE_MASTER	3	/*  Synchronisation master or Access Point */
+#define IW_MODE_REPEAT	4	/*  Wireless Repeater (forwarder) */
+#define IW_MODE_SECOND	5	/*  Secondary master/repeater (backup) */
+#define IW_MODE_MONITOR	6	/*  Passive monitor (listen only) */
+#endif
 
-*/
 struct	setopmode_parm {
 	u8	mode;
 	u8	rsvd[3];
@@ -359,19 +376,24 @@ Caller Mode: AP, Ad-HoC, Infra
 
 Notes: To ask RTL8711 performing site-survey
 
-Command-Event Mode 
+Command-Event Mode
 
 */
 
-#define RTW_SSID_SCAN_AMOUNT 9 // for WEXT_CSCAN_AMOUNT 9
+#define RTW_SSID_SCAN_AMOUNT 9 /* for WEXT_CSCAN_AMOUNT 9 */
 #define RTW_CHANNEL_SCAN_AMOUNT (14+37)
 struct sitesurvey_parm {
-	sint scan_mode;	//active: 1, passive: 0 
+	sint scan_mode;	/* active: 1, passive: 0 */
 	/* sint bsslimit;	// 1 ~ 48 */
 	u8 ssid_num;
 	u8 ch_num;
 	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];
 	struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
+
+	u32 token; 	/* 80211k use it to identify caller */
+	u16 duration;	/* 0: use default, otherwise: channel scan time */
+	u8 igi;		/* 0: use defalut */
+	u8 bw;		/* 0: use default */
 };
 
 /*
@@ -383,8 +405,8 @@ Command Mode
 
 */
 struct setauth_parm {
-	u8 mode;  //0: legacy open, 1: legacy shared 2: 802.1x
-	u8 _1x;   //0: PSK, 1: TLS
+	u8 mode;  /* 0: legacy open, 1: legacy shared 2: 802.1x */
+	u8 _1x;   /* 0: PSK, 1: TLS */
 	u8 rsvd[2];
 };
 
@@ -401,27 +423,27 @@ when 802.1x ==> keyid > 2 ==> unicast key
 
 */
 struct setkey_parm {
-	u8	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
+	u8	algorithm;	/* encryption algorithm, could be none, wep40, TKIP, CCMP, wep104 */
+	u8	keyid;
+	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 
+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 
+when shared key ==> algorithm/keyid
 
 */
 struct set_stakey_parm {
-	u8	addr[ETH_ALEN];
-	u8	algorithm;
-	u8	keyid;
-	u8	key[16];
+	u8 addr[ETH_ALEN];
+	u8 algorithm;
+	u8 keyid;
+	u8 key[16];
+	u8 gk;
 };
 
 struct set_stakey_rsp {
@@ -451,16 +473,12 @@ struct set_assocsta_rsp {
 
 /*
 	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];
+	u8	addr[ETH_ALEN];
 };
 
 /*
@@ -532,41 +550,12 @@ 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
 
@@ -639,26 +628,25 @@ struct getrfintfs_parm {
 };
 
 
-struct Tx_Beacon_param
-{
+struct Tx_Beacon_param {
 	WLAN_BSSID_EX network;
 };
 
 /*
 	Notes: This command is used for H2C/C2H loopback testing
 
-	mac[0] == 0 
+	mac[0] == 0
 	==> CMD mode, return H2C_SUCCESS.
 	The following condition must be ture under CMD mode
 		mac[1] == mac[4], mac[2] == mac[3], mac[0]=mac[5]= 0;
 		s0 == 0x1234, s1 == 0xabcd, w0 == 0x78563412, w1 == 0x5aa5def7;
 		s2 == (b1 << 8 | b0);
-	
+
 	mac[0] == 1
 	==> CMD_RSP mode, return H2C_SUCCESS_RSP
-	
+
 	The rsp layout shall be:
-	rsp: 			parm:
+	rsp:			parm:
 		mac[0]  =   mac[5];
 		mac[1]  =   mac[4];
 		mac[2]  =   mac[3];
@@ -667,14 +655,14 @@ struct Tx_Beacon_param
 		mac[5]  =   mac[0];
 		s0		=   s1;
 		s1		=   swap16(s0);
-		w0		=  	swap32(w1);
-		b0		= 	b1
-		s2		= 	s0 + s1
-		b1		= 	b0
+		w0		=	swap32(w1);
+		b0		=	b1
+		s2		=	s0 + s1
+		b1		=	b0
 		w1		=	w0
-		
-	mac[0] == 	2
-	==> CMD_EVENT mode, return 	H2C_SUCCESS
+
+	mac[0] ==	2
+	==> CMD_EVENT mode, return	H2C_SUCCESS
 	The event layout shall be:
 	event:			parm:
 		mac[0]  =   mac[5];
@@ -685,17 +673,17 @@ struct Tx_Beacon_param
 		mac[5]  =   mac[0];
 		s0		=   swap16(s0) - event.mac[2];
 		s1		=   s1 + event.mac[2];
-		w0		=  	swap32(w0);
-		b0		= 	b1
-		s2		= 	s0 + event.mac[2]
-		b1		= 	b0 
-		w1		=	swap32(w1) - event.mac[2];	
-	
+		w0		=	swap32(w0);
+		b0		=	b1
+		s2		=	s0 + event.mac[2]
+		b1		=	b0
+		w1		=	swap32(w1) - event.mac[2];
+
 		parm->mac[3] is the total event counts that host requested.
-		
-	
+
+
 	event will be the same with the cmd's param.
-		
+
 */
 
 #ifdef CONFIG_H2CLBK
@@ -712,7 +700,7 @@ struct seth2clbk_parm {
 };
 
 struct geth2clbk_parm {
-	u32 rsv;	
+	u32 rsv;
 };
 
 struct geth2clbk_rsp {
@@ -728,21 +716,21 @@ struct geth2clbk_rsp {
 
 #endif	/* CONFIG_H2CLBK */
 
-// CMD param Formart for driver extra cmd handler
+/* CMD param Formart for driver extra cmd handler */
 struct drvextra_cmd_parm {
-	int ec_id; //extra cmd id
-	int type; // Can use this field as the type id or command size
-	int size; //buffer size
+	int ec_id; /* extra cmd id */
+	int type; /* Can use this field as the type id or command size */
+	int size; /* buffer size */
 	unsigned char *pbuf;
 };
 
 /*------------------- Below are used for RF/BB tunning ---------------------*/
 
 struct	setantenna_parm {
-	u8	tx_antset;		
+	u8	tx_antset;
 	u8	rx_antset;
-	u8	tx_antenna;		
-	u8	rx_antenna;		
+	u8	tx_antenna;
+	u8	rx_antenna;
 };
 
 struct	enrateadaptive_parm {
@@ -761,7 +749,7 @@ struct gettxagctbl_rsp {
 };
 
 struct setagcctrl_parm {
-	u32	agcctrl;		// 0: pure hw, 1: fw
+	u32	agcctrl;		/* 0: pure hw, 1: fw */
 };
 
 
@@ -820,51 +808,51 @@ struct setratable_parm {
 };
 
 struct getratable_parm {
-                uint rsvd;
+	uint rsvd;
 };
 struct getratable_rsp {
-        u8 ss_ForceUp[NumRates];
-        u8 ss_ULevel[NumRates];
-        u8 ss_DLevel[NumRates];
-        u8 count_judge[NumRates];
+	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{
+/* to get TX,RX retry count */
+struct gettxretrycnt_parm {
 	unsigned int rsvd;
 };
-struct gettxretrycnt_rsp{
+struct gettxretrycnt_rsp {
 	unsigned long tx_retrycnt;
 };
 
-struct getrxretrycnt_parm{
+struct getrxretrycnt_parm {
 	unsigned int rsvd;
 };
-struct getrxretrycnt_rsp{
+struct getrxretrycnt_rsp {
 	unsigned long rx_retrycnt;
 };
 
-//to get BCNOK,BCNERR count
-struct getbcnokcnt_parm{
+/* to get BCNOK,BCNERR count */
+struct getbcnokcnt_parm {
 	unsigned int rsvd;
 };
-struct getbcnokcnt_rsp{
+struct getbcnokcnt_rsp {
 	unsigned long  bcnokcnt;
 };
 
-struct getbcnerrcnt_parm{
+struct getbcnerrcnt_parm {
 	unsigned int rsvd;
 };
-struct getbcnerrcnt_rsp{
+struct getbcnerrcnt_rsp {
 	unsigned long bcnerrcnt;
 };
 
-// to get current TX power level
-struct getcurtxpwrlevel_parm{
+/* to get current TX power level */
+struct getcurtxpwrlevel_parm {
 	unsigned int rsvd;
 };
-struct getcurtxpwrlevel_rsp{
+struct getcurtxpwrlevel_rsp {
 	unsigned short tx_power;
 };
 
@@ -893,12 +881,19 @@ struct setassocrspextraie_parm {
 };
 
 
-struct addBaReq_parm
-{
- 	unsigned int tid;
+struct addBaReq_parm {
+	unsigned int tid;
 	u8	addr[ETH_ALEN];
 };
 
+struct addBaRsp_parm {
+	unsigned int tid;
+	unsigned int start_seq;
+	u8 addr[ETH_ALEN];
+	u8 status;
+	u8 size;
+};
+
 /*H2C Handler index: 46 */
 struct set_ch_parm {
 	u8 ch;
@@ -908,92 +903,79 @@ struct set_ch_parm {
 
 #ifdef MP_FIRMWARE_OFFLOAD
 /*H2C Handler index: 47 */
-struct SetTxPower_parm
-{
+struct SetTxPower_parm {
 	u8 TxPower;
 };
 
 /*H2C Handler index: 48 */
-struct SwitchAntenna_parm
-{
+struct SwitchAntenna_parm {
 	u16 antenna_tx;
 	u16 antenna_rx;
-//	R_ANTENNA_SELECT_CCK cck_txrx;
+	/*	R_ANTENNA_SELECT_CCK cck_txrx; */
 	u8 cck_txrx;
 };
 
 /*H2C Handler index: 49 */
-struct SetCrystalCap_parm
-{
+struct SetCrystalCap_parm {
 	u32 curr_crystalcap;
 };
 
 /*H2C Handler index: 50 */
-struct SetSingleCarrierTx_parm
-{
+struct SetSingleCarrierTx_parm {
 	u8 bStart;
 };
 
 /*H2C Handler index: 51 */
-struct SetSingleToneTx_parm
-{
+struct SetSingleToneTx_parm {
 	u8 bStart;
 	u8 curr_rfpath;
 };
 
 /*H2C Handler index: 52 */
-struct SetCarrierSuppressionTx_parm
-{
+struct SetCarrierSuppressionTx_parm {
 	u8 bStart;
 	u32 curr_rateidx;
 };
 
 /*H2C Handler index: 53 */
-struct SetContinuousTx_parm
-{
+struct SetContinuousTx_parm {
 	u8 bStart;
 	u8 CCK_flag; /*1:CCK 2:OFDM*/
 	u32 curr_rateidx;
 };
 
 /*H2C Handler index: 54 */
-struct SwitchBandwidth_parm
-{
+struct SwitchBandwidth_parm {
 	u8 curr_bandwidth;
 };
 
 #endif	/* MP_FIRMWARE_OFFLOAD */
 
-/*H2C Handler index: 59 */ 
-struct SetChannelPlan_param
-{
+/*H2C Handler index: 59 */
+struct SetChannelPlan_param {
 	const struct country_chplan *country_ent;
 	u8 channel_plan;
 };
 
-/*H2C Handler index: 60 */ 
-struct LedBlink_param
-{
+/*H2C Handler index: 60 */
+struct LedBlink_param {
 	PVOID	 pLed;
 };
 
-/*H2C Handler index: 61 */ 
-struct SetChannelSwitch_param
-{
+/*H2C Handler index: 61 */
+struct SetChannelSwitch_param {
 	u8 new_ch_no;
 };
 
-/*H2C Handler index: 62 */ 
-struct TDLSoption_param
-{
+/*H2C Handler index: 62 */
+struct TDLSoption_param {
 	u8 addr[ETH_ALEN];
 	u8 option;
 };
 
 /*H2C Handler index: 64 */
-struct RunInThread_param
-{
-	void (*func)(void*);
+struct RunInThread_param {
+	void (*func)(void *);
 	void *context;
 };
 
@@ -1003,7 +985,7 @@ struct RunInThread_param
 
 /*
 
-Result: 
+Result:
 0x00: success
 0x01: sucess, and check Response.
 0x02: cmd ignored due to duplicated sequcne number
@@ -1024,14 +1006,20 @@ Result:
 #define H2C_RESERVED			0x07
 #define H2C_ENQ_HEAD			0x08
 #define H2C_ENQ_HEAD_FAIL		0x09
+#define H2C_CMD_FAIL			0x0A
 
 extern u8 rtw_setassocsta_cmd(_adapter  *padapter, u8 *mac_addr);
 extern u8 rtw_setstandby_cmd(_adapter *padapter, uint action);
-u8 rtw_sitesurvey_cmd(_adapter  *padapter, NDIS_802_11_SSID *ssid, int ssid_num, struct rtw_ieee80211_channel *ch, int ch_num);
-
+void rtw_init_sitesurvey_parm(_adapter *padapter, struct sitesurvey_parm *pparm);
+u8 rtw_sitesurvey_cmd(_adapter *padapter, struct sitesurvey_parm *pparm);
 u8 rtw_create_ibss_cmd(_adapter *adapter, int flags);
 u8 rtw_startbss_cmd(_adapter *adapter, int flags);
-u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, u8 req_ch, u8 req_bw, u8 req_offset);
+
+#define REQ_CH_NONE		-1
+#define REQ_BW_NONE		-1
+#define REQ_OFFSET_NONE	-1
+
+u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, s16 req_ch, s8 req_bw, s8 req_offset);
 
 extern u8 rtw_setphy_cmd(_adapter  *padapter, u8 modem, u8 ch);
 
@@ -1039,61 +1027,55 @@ struct sta_info;
 extern u8 rtw_setstakey_cmd(_adapter  *padapter, struct sta_info *sta, u8 key_type, bool enqueue);
 extern u8 rtw_clearstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 enqueue);
 
-extern u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network* pnetwork);
-u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, bool enqueue);
-extern u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, bool enqueue);
+extern u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork);
+u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, int flags);
+extern u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, u8 flags);
 extern u8 rtw_setdatarate_cmd(_adapter  *padapter, u8 *rateset);
 extern u8 rtw_setbasicrate_cmd(_adapter  *padapter, u8 *rateset);
 extern u8 rtw_getmacreg_cmd(_adapter *padapter, u8 len, u32 addr);
 extern void rtw_usb_catc_trigger_cmd(_adapter *padapter, const char *caller);
-extern u8 rtw_setbbreg_cmd(_adapter * padapter, u8 offset, u8 val);
-extern u8 rtw_setrfreg_cmd(_adapter * padapter, u8 offset, u32 val);
-extern u8 rtw_getbbreg_cmd(_adapter * padapter, u8 offset, u8 * pval);
-extern u8 rtw_getrfreg_cmd(_adapter * padapter, u8 offset, u8 * pval);
+extern u8 rtw_setbbreg_cmd(_adapter *padapter, u8 offset, u8 val);
+extern u8 rtw_setrfreg_cmd(_adapter *padapter, u8 offset, u32 val);
+extern u8 rtw_getbbreg_cmd(_adapter *padapter, u8 offset, u8 *pval);
+extern u8 rtw_getrfreg_cmd(_adapter *padapter, u8 offset, u8 *pval);
 extern u8 rtw_setrfintfs_cmd(_adapter  *padapter, u8 mode);
 extern u8 rtw_setrttbl_cmd(_adapter  *padapter, struct setratable_parm *prate_table);
 extern u8 rtw_getrttbl_cmd(_adapter  *padapter, struct getratable_rsp *pval);
 
-extern u8 rtw_gettssi_cmd(_adapter  *padapter, u8 offset,u8 *pval);
-extern u8 rtw_setfwdig_cmd(_adapter*padapter, u8 type);
-extern u8 rtw_setfwra_cmd(_adapter*padapter, u8 type);
+extern u8 rtw_gettssi_cmd(_adapter  *padapter, u8 offset, u8 *pval);
+extern u8 rtw_setfwdig_cmd(_adapter *padapter, u8 type);
+extern u8 rtw_setfwra_cmd(_adapter *padapter, u8 type);
 
-extern u8 rtw_addbareq_cmd(_adapter*padapter, u8 tid, u8 *addr);
-// add for CONFIG_IEEE80211W, none 11w also can use
-extern u8 rtw_reset_securitypriv_cmd(_adapter*padapter);
-extern u8 rtw_free_assoc_resources_cmd(_adapter *padapter);
+extern u8 rtw_addbareq_cmd(_adapter *padapter, u8 tid, u8 *addr);
+extern u8 rtw_addbarsp_cmd(_adapter *padapter, u8 *addr, u16 tid, u8 status, u8 size, u16 start_seq);
+/* add for CONFIG_IEEE80211W, none 11w also can use */
+extern u8 rtw_reset_securitypriv_cmd(_adapter *padapter);
+extern u8 rtw_free_assoc_resources_cmd(_adapter *padapter, u8 lock_scanned_queue);
 extern u8 rtw_dynamic_chk_wk_cmd(_adapter *adapter);
 
-u8 rtw_lps_ctrl_wk_cmd(_adapter*padapter, u8 lps_ctrl_type, u8 enqueue);
-u8 rtw_dm_in_lps_wk_cmd(_adapter*padapter);
-u8 rtw_lps_change_dtim_cmd(_adapter*padapter, u8 dtim);
+u8 rtw_lps_ctrl_wk_cmd(_adapter *padapter, u8 lps_ctrl_type, u8 enqueue);
+u8 rtw_dm_in_lps_wk_cmd(_adapter *padapter);
+u8 rtw_lps_change_dtim_cmd(_adapter *padapter, u8 dtim);
 
-#if (RATE_ADAPTIVE_SUPPORT==1)
-u8 rtw_rpt_timer_cfg_cmd(_adapter*padapter, u16 minRptTime);
+#if (RATE_ADAPTIVE_SUPPORT == 1)
+u8 rtw_rpt_timer_cfg_cmd(_adapter *padapter, u16 minRptTime);
 #endif
 
 #ifdef CONFIG_ANTENNA_DIVERSITY
-extern  u8 rtw_antenna_select_cmd(_adapter*padapter, u8 antenna,u8 enqueue);
+extern  u8 rtw_antenna_select_cmd(_adapter *padapter, u8 antenna, u8 enqueue);
 #endif
 
-u8 rtw_dm_ra_mask_wk_cmd(_adapter*padapter, u8 *psta);
+u8 rtw_dm_ra_mask_wk_cmd(_adapter *padapter, u8 *psta);
 
-extern u8 rtw_ps_cmd(_adapter*padapter);
+extern u8 rtw_ps_cmd(_adapter *padapter);
 
 #ifdef CONFIG_AP_MODE
-u8 rtw_chk_hi_queue_cmd(_adapter*padapter);
+u8 rtw_chk_hi_queue_cmd(_adapter *padapter);
 #ifdef CONFIG_DFS_MASTER
 u8 rtw_dfs_master_cmd(_adapter *adapter, bool enqueue);
-void rtw_dfs_master_timer_hdl(RTW_TIMER_HDL_ARGS);
+void rtw_dfs_master_timer_hdl(void *ctx);
 void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset);
-void rtw_dfs_master_disable(_adapter *adapter, bool ld_sta_in_dfs);
-enum {
-	MLME_STA_CONNECTING,
-	MLME_STA_CONNECTED,
-	MLME_STA_DISCONNECTED,
-	MLME_AP_STARTED,
-	MLME_AP_STOPPED,
-};
+void rtw_dfs_master_disable(_adapter *adapter, u8 ch, u8 bw, u8 offset, bool by_others);
 void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action);
 #endif /* CONFIG_DFS_MASTER */
 #endif /* CONFIG_AP_MODE */
@@ -1102,34 +1084,49 @@ void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action);
 u8 rtw_btinfo_cmd(PADAPTER padapter, u8 *pbuf, u16 length);
 #endif
 
+u8 rtw_test_h2c_cmd(_adapter *adapter, u8 *buf, u8 len);
+
 u8 rtw_enable_hw_update_tsf_cmd(_adapter *padapter);
 
-u8 rtw_set_ch_cmd(_adapter*padapter, u8 ch, u8 bw, u8 ch_offset, u8 enqueue);
+u8 rtw_set_chbw_cmd(_adapter *padapter, u8 ch, u8 bw, u8 ch_offset, u8 flags);
 
 u8 rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, u8 swconfig);
 u8 rtw_set_country_cmd(_adapter *adapter, int flags, const char *country_code, u8 swconfig);
 
-extern u8 rtw_led_blink_cmd(_adapter*padapter, PVOID pLed);
-extern u8 rtw_set_csa_cmd(_adapter*padapter, u8 new_ch_no);
-extern u8 rtw_tdls_cmd(_adapter*padapter, u8 *addr, u8 option);
+extern u8 rtw_led_blink_cmd(_adapter *padapter, PVOID pLed);
+extern u8 rtw_set_csa_cmd(_adapter *padapter, u8 new_ch_no);
+extern u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option);
 
-//#ifdef CONFIG_C2H_PACKET_EN
-extern u8 rtw_c2h_packet_wk_cmd(PADAPTER padapter, u8 *pbuf, u16 length);
-//#else
-extern u8 rtw_c2h_wk_cmd(PADAPTER padapter, u8 *c2h_evt);
-//#endif
+u8 rtw_mp_cmd(_adapter *adapter, u8 mp_cmd_id, u8 flags);
 
 #ifdef CONFIG_RTW_CUSTOMER_STR
 u8 rtw_customer_str_req_cmd(_adapter *adapter);
 u8 rtw_customer_str_write_cmd(_adapter *adapter, const u8 *cstr);
 #endif
 
-u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void*), void* context);
+#ifdef CONFIG_FW_C2H_REG
+u8 rtw_c2h_reg_wk_cmd(_adapter *adapter, u8 *c2h_evt);
+#endif
+#ifdef CONFIG_FW_C2H_PKT
+u8 rtw_c2h_packet_wk_cmd(_adapter *adapter, u8 *c2h_evt, u16 length);
+#endif
+
+#ifdef CONFIG_RTW_REPEATER_SON
+#define RSON_SCAN_PROCESS		10
+#define RSON_SCAN_DISABLE		11
+u8 rtw_rson_scan_wk_cmd(_adapter *adapter, int op);
+#endif
+
+u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void *), void *context);
 
 u8 session_tracker_chk_cmd(_adapter *adapter, struct sta_info *sta);
 u8 session_tracker_add_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
 u8 session_tracker_del_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
 
+#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
+u8 rtw_req_per_cmd(_adapter * adapter);
+#endif
+
 u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf);
 
 extern void rtw_survey_cmd_callback(_adapter  *padapter, struct cmd_obj *pcmd);
@@ -1137,7 +1134,7 @@ extern void rtw_disassoc_cmd_callback(_adapter  *padapter, struct cmd_obj *pcmd)
 extern void rtw_joinbss_cmd_callback(_adapter  *padapter, struct cmd_obj *pcmd);
 void rtw_create_ibss_post_hdl(_adapter *padapter, int status);
 extern void rtw_getbbrfreg_cmdrsp_callback(_adapter  *padapter, struct cmd_obj *pcmd);
-extern void rtw_readtssi_cmdrsp_callback(_adapter*	padapter,  struct cmd_obj *pcmd);
+extern void rtw_readtssi_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd);
 
 extern void rtw_setstaKey_cmdrsp_callback(_adapter  *padapter,  struct cmd_obj *pcmd);
 extern void rtw_setassocsta_cmdrsp_callback(_adapter  *padapter,  struct cmd_obj *pcmd);
@@ -1150,74 +1147,73 @@ struct _cmd_callback {
 	void (*callback)(_adapter  *padapter, struct cmd_obj *cmd);
 };
 
-enum rtw_h2c_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(_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(_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(_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(_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(_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*/
 
@@ -1226,6 +1222,8 @@ enum rtw_h2c_cmd
 	GEN_CMD_CODE(_ChkBMCSleepq), /*63*/
 
 	GEN_CMD_CODE(_RunInThreadCMD), /*64*/
+	GEN_CMD_CODE(_AddBARsp) , /*65*/
+	GEN_CMD_CODE(_RM_POST_EVENT), /*66*/
 
 	MAX_H2CCMD
 };
@@ -1233,15 +1231,14 @@ enum rtw_h2c_cmd
 #define _GetMACReg_CMD_ _Read_MACREG_CMD_
 #define _SetMACReg_CMD_ _Write_MACREG_CMD_
 #define _GetBBReg_CMD_		_Read_BBREG_CMD_
-#define _SetBBReg_CMD_ 		_Write_BBREG_CMD_
-#define _GetRFReg_CMD_ 		_Read_RFREG_CMD_
-#define _SetRFReg_CMD_ 		_Write_RFREG_CMD_
+#define _SetBBReg_CMD_		_Write_BBREG_CMD_
+#define _GetRFReg_CMD_		_Read_RFREG_CMD_
+#define _SetRFReg_CMD_		_Write_RFREG_CMD_
 
 #ifdef _RTW_CMD_C_
-struct _cmd_callback 	rtw_cmd_callback[] = 
-{
+struct _cmd_callback	rtw_cmd_callback[] = {
 	{GEN_CMD_CODE(_Read_MACREG), &rtw_getmacreg_cmdrsp_callback}, /*0*/
-	{GEN_CMD_CODE(_Write_MACREG), NULL}, 
+	{GEN_CMD_CODE(_Write_MACREG), NULL},
 	{GEN_CMD_CODE(_Read_BBREG), &rtw_getbbrfreg_cmdrsp_callback},
 	{GEN_CMD_CODE(_Write_BBREG), NULL},
 	{GEN_CMD_CODE(_Read_RFREG), &rtw_getbbrfreg_cmdrsp_callback},
@@ -1250,32 +1247,32 @@ struct _cmd_callback 	rtw_cmd_callback[] =
 	{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(_Write_CAM),	 NULL},
 	{GEN_CMD_CODE(_setBCNITV), NULL},
- 	{GEN_CMD_CODE(_setMBIDCFG), NULL},
+	{GEN_CMD_CODE(_setMBIDCFG), NULL},
 	{GEN_CMD_CODE(_JoinBss), &rtw_joinbss_cmd_callback},  /*14*/
 	{GEN_CMD_CODE(_DisConnect), &rtw_disassoc_cmd_callback}, /*15*/
 	{GEN_CMD_CODE(_CreateBss), NULL},
 	{GEN_CMD_CODE(_SetOpMode), NULL},
 	{GEN_CMD_CODE(_SiteSurvey), &rtw_survey_cmd_callback}, /*18*/
 	{GEN_CMD_CODE(_SetAuth), NULL},
-	
+
 	{GEN_CMD_CODE(_SetKey), NULL},	/*20*/
 	{GEN_CMD_CODE(_SetStaKey), &rtw_setstaKey_cmdrsp_callback},
 	{GEN_CMD_CODE(_SetAssocSta), &rtw_setassocsta_cmdrsp_callback},
-	{GEN_CMD_CODE(_DelAssocSta), NULL},	
-	{GEN_CMD_CODE(_SetStaPwrState), NULL},	
+	{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(_GetPhy), NULL},
 	{GEN_CMD_CODE(_readRssi), NULL},
 	{GEN_CMD_CODE(_readGain), NULL},
 	{GEN_CMD_CODE(_SetAtim), NULL}, /*35*/
@@ -1283,19 +1280,19 @@ struct _cmd_callback 	rtw_cmd_callback[] =
 	{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(_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},
@@ -1307,12 +1304,14 @@ struct _cmd_callback 	rtw_cmd_callback[] =
 	{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*/
 	{GEN_CMD_CODE(_ChkBMCSleepq), NULL}, /*63*/
 
 	{GEN_CMD_CODE(_RunInThreadCMD), NULL},/*64*/
+	{GEN_CMD_CODE(_AddBARsp), NULL}, /*65*/
+	{GEN_CMD_CODE(_RM_POST_EVENT), NULL}, /*66*/
 };
 #endif
 
@@ -1322,5 +1321,4 @@ struct _cmd_callback 	rtw_cmd_callback[] =
 	(cmd)->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra) ? ((struct drvextra_cmd_parm *)(cmd)->parmbuf)->ec_id : ((cmd)->cmdcode == GEN_CMD_CODE(_Set_MLME_EVT) ? ((struct C2HEvent_Header *)(cmd)->parmbuf)->ID : 0), \
 	(cmd)->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra) ? ((struct drvextra_cmd_parm *)(cmd)->parmbuf)->type : 0
 
-#endif // _CMD_H_
-
+#endif /* _CMD_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_debug.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_debug.h
index 712ff0ebe97d..39749f0c5747 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_debug.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_debug.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,350 +12,245 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_DEBUG_H__
 #define __RTW_DEBUG_H__
 
+/* driver log level*/
+enum {
+	_DRV_NONE_ = 0,
+	_DRV_ALWAYS_ = 1,
+	_DRV_ERR_ = 2,
+	_DRV_WARNING_ = 3,
+	_DRV_INFO_ = 4,
+	_DRV_DEBUG_ = 5,
+	_DRV_MAX_ = 6
+};
 
-#define _drv_always_		1
-#define _drv_emerg_			2
-#define _drv_alert_			3
-#define _drv_crit_			4
-#define _drv_err_			5
-#define	_drv_warning_		6
-#define _drv_notice_		7
-#define _drv_info_			8
-#define _drv_dump_			9
-#define	_drv_debug_			10
-
-
-#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_efuse_			BIT(27)
-#define	_module_rtl8192c_xmit_c_ BIT(28)
-#define _module_hal_xmit_c_	BIT(28)
-#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 "RTW: "
 
 #ifdef PLATFORM_OS_CE
 extern void rtl871x_cedbg(const char *fmt, ...);
 #endif
 
-#define RT_TRACE(_Comp, _Level, Fmt) do{}while(0)
-#define _func_enter_ do{}while(0)
-#define _func_exit_ do{}while(0)
-#define RT_PRINT_DATA(_Comp, _Level, _TitleString, _HexData, _HexDataLen) do{}while(0)
-
 #ifdef PLATFORM_WINDOWS
-	#define DBG_871X do {} while(0)
-	#define MSG_8192C do {} while(0)
-	#define DBG_8192C do {} while(0)
-	#define DBG_871X_LEVEL do {} while(0)
+	#define RTW_PRINT do {} while (0)
+	#define RTW_ERR do {} while (0)
+	#define RTW_WARN do {} while (0)
+	#define RTW_INFO do {} while (0)
+	#define RTW_DBG do {} while (0)
+	#define RTW_PRINT_SEL do {} while (0)
+	#define _RTW_PRINT do {} while (0)
+	#define _RTW_ERR do {} while (0)
+	#define _RTW_WARN do {} while (0)
+	#define _RTW_INFO do {} while (0)
+	#define _RTW_DBG do {} while (0)
+	#define _RTW_PRINT_SEL do {} while (0)
 #else
-	#define DBG_871X(x, ...) do {} while(0)
-	#define MSG_8192C(x, ...) do {} while(0)
-	#define DBG_8192C(x,...) do {} while(0)
-	#define DBG_871X_LEVEL(x,...) do {} while(0)
-	#define RTW_WARN(x, ...) do {} while(0)
-	#define RTW_INFO(x, ...) do {} while(0)
+	#define RTW_PRINT(x, ...) do {} while (0)
+	#define RTW_ERR(x, ...) do {} while (0)
+	#define RTW_WARN(x,...) do {} while (0)
+	#define RTW_INFO(x,...) do {} while (0)
+	#define RTW_DBG(x,...) do {} while (0)
+	#define RTW_PRINT_SEL(x,...) do {} while (0)
+	#define _RTW_PRINT(x, ...) do {} while (0)
+	#define _RTW_ERR(x, ...) do {} while (0)
+	#define _RTW_WARN(x,...) do {} while (0)
+	#define _RTW_INFO(x,...) do {} while (0)
+	#define _RTW_DBG(x,...) do {} while (0)
+	#define _RTW_PRINT_SEL(x,...) do {} while (0)
 #endif
 
+#define RTW_INFO_DUMP(_TitleString, _HexData, _HexDataLen) do {} while (0)
+#define RTW_DBG_DUMP(_TitleString, _HexData, _HexDataLen) do {} while (0)
+#define RTW_PRINT_DUMP(_TitleString, _HexData, _HexDataLen) do {} while (0)
+
+#define RTW_DBG_EXPR(EXPR) do {} while (0)
+
+#define RTW_DBGDUMP 0 /* 'stream' for _dbgdump */
+
+
+
 #undef _dbgdump
 #undef _seqdump
 
-#ifndef _RTL871X_DEBUG_C_
-	extern u32 GlobalDebugLevel;
-	extern u64 GlobalDebugComponents;
-#endif
-
 #if defined(PLATFORM_WINDOWS) && defined(PLATFORM_OS_XP)
 	#define _dbgdump DbgPrint
+	#define KERN_CONT
 	#define _seqdump(sel, fmt, arg...) _dbgdump(fmt, ##arg)
 #elif defined(PLATFORM_WINDOWS) && defined(PLATFORM_OS_CE)
 	#define _dbgdump rtl871x_cedbg
+	#define KERN_CONT
 	#define _seqdump(sel, fmt, arg...) _dbgdump(fmt, ##arg)
 #elif defined PLATFORM_LINUX
 	#define _dbgdump printk
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+	#define KERN_CONT
+	#endif
 	#define _seqdump seq_printf
 #elif defined PLATFORM_FREEBSD
 	#define _dbgdump printf
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
+	#define KERN_CONT
+	#endif
 	#define _seqdump(sel, fmt, arg...) _dbgdump(fmt, ##arg)
 #endif
 
-#define DRIVER_PREFIX "RTL871X: "
+void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
+								bool _idx_show, const u8 *_hexdata, int _hexdatalen);
 
-#if defined(_dbgdump)
+#ifdef CONFIG_RTW_DEBUG
+
+#ifndef _OS_INTFS_C_
+extern uint rtw_drv_log_level;
+#endif
 
-#define DBG_871X_EXP(level, EXP) do { if (level <= GlobalDebugLevel) EXP; } while (0)
+#if defined(_dbgdump)
 
 /* with driver-defined prefix */
-#undef DBG_871X_LEVEL
-#define DBG_871X_LEVEL(level, fmt, arg...)     \
+#undef RTW_PRINT
+#define RTW_PRINT(fmt, arg...)     \
+	do {\
+		if (_DRV_ALWAYS_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef RTW_ERR
+#define RTW_ERR(fmt, arg...)     \
 	do {\
-		if (level <= GlobalDebugLevel) {\
-			if (level <= _drv_err_ && level > _drv_always_) \
-				_dbgdump(DRIVER_PREFIX"ERROR " fmt, ##arg);\
-			else \
-				_dbgdump(DRIVER_PREFIX fmt, ##arg);\
-		}\
-	}while(0)
+		if (_DRV_ERR_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX"ERROR " fmt, ##arg);\
+		} \
+	} while (0)
 
-#define RTW_ERR(fmt, arg...) DBG_871X_LEVEL(_drv_err_, fmt, ##arg)
 
-#undef RTW_PRINT_DUMP
-#define RTW_PRINT_DUMP(_TitleString, _HexData, _HexDataLen)			\
+#undef RTW_WARN
+#define RTW_WARN(fmt, arg...)     \
+	do {\
+		if (_DRV_WARNING_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX"WARN " fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef RTW_INFO
+#define RTW_INFO(fmt, arg...)     \
+	do {\
+		if (_DRV_INFO_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX fmt, ##arg);\
+		} \
+	} while (0)
+
+
+#undef RTW_DBG
+#define RTW_DBG(fmt, arg...)     \
 	do {\
-		int __i;								\
-		u8	*ptr = (u8 *)_HexData;				\
-		_dbgdump("%s", DRIVER_PREFIX);						\
-		_dbgdump(_TitleString); 					\
-		for (__i = 0; __i < (int)_HexDataLen; __i++) {				\
-			_dbgdump("%02X%s", ptr[__i], (((__i + 1) % 4) == 0) ? "  " : " ");	\
-			if (((__i + 1) % 16) == 0)	\
-				_dbgdump("\n"); 		\
-		}								\
-		_dbgdump("\n"); 						\
+		if (_DRV_DEBUG_ <= rtw_drv_log_level) {\
+			_dbgdump(DRIVER_PREFIX fmt, ##arg);\
+		} \
 	} while (0)
 
 #undef RTW_INFO_DUMP
-#define RTW_INFO_DUMP RTW_PRINT_DUMP
+#define RTW_INFO_DUMP(_TitleString, _HexData, _HexDataLen)	\
+	RTW_BUF_DUMP_SEL(_DRV_INFO_, RTW_DBGDUMP, _TitleString, _FALSE, _HexData, _HexDataLen)
+
+#undef RTW_DBG_DUMP
+#define RTW_DBG_DUMP(_TitleString, _HexData, _HexDataLen)	\
+	RTW_BUF_DUMP_SEL(_DRV_DEBUG_, RTW_DBGDUMP, _TitleString, _FALSE, _HexData, _HexDataLen)
+
+
+#undef RTW_PRINT_DUMP
+#define RTW_PRINT_DUMP(_TitleString, _HexData, _HexDataLen)	\
+	RTW_BUF_DUMP_SEL(_DRV_ALWAYS_, RTW_DBGDUMP, _TitleString, _FALSE, _HexData, _HexDataLen)
 
 /* without driver-defined prefix */
-#undef _DBG_871X_LEVEL
-#define _DBG_871X_LEVEL(level, fmt, arg...)	   \
+#undef _RTW_PRINT
+#define _RTW_PRINT(fmt, arg...)     \
 	do {\
-		if (level <= GlobalDebugLevel) {\
-			if (level <= _drv_err_ && level > _drv_always_) \
-				_dbgdump("ERROR " fmt, ##arg);\
-			else \
-				_dbgdump(fmt, ##arg);\
-		}\
-	}while(0)
+		if (_DRV_ALWAYS_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
 
-#if defined(_seqdump)
-#define RTW_DBGDUMP 0 /* 'stream' for _dbgdump */
+#undef _RTW_ERR
+#define _RTW_ERR(fmt, arg...)     \
+	do {\
+		if (_DRV_ERR_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
 
-/* dump message to selected 'stream' */
-#define DBG_871X_SEL(sel, fmt, arg...) \
+
+#undef _RTW_WARN
+#define _RTW_WARN(fmt, arg...)     \
 	do {\
-		if (sel == RTW_DBGDUMP)\
-			_DBG_871X_LEVEL(_drv_always_, fmt, ##arg); \
-		else {\
-			_seqdump(sel, fmt, ##arg); \
+		if (_DRV_WARNING_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
 		} \
-	}while(0)
+	} while (0)
 
-/* dump message to selected 'stream' with driver-defined prefix */
-#define DBG_871X_SEL_NL(sel, fmt, arg...) \
+#undef _RTW_INFO
+#define _RTW_INFO(fmt, arg...)     \
 	do {\
-		if (sel == RTW_DBGDUMP)\
-			DBG_871X_LEVEL(_drv_always_, fmt, ##arg); \
-		else {\
-			_seqdump(sel, fmt, ##arg); \
+		if (_DRV_INFO_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
+		} \
+	} while (0)
+
+#undef _RTW_DBG
+#define _RTW_DBG(fmt, arg...)     \
+	do {\
+		if (_DRV_DEBUG_ <= rtw_drv_log_level) {\
+			_dbgdump(KERN_CONT fmt, ##arg);\
 		} \
-	}while(0)
+	} while (0)
 
-#define RTW_PRINT_SEL DBG_871X_SEL_NL
-#define _RTW_PRINT_SEL DBG_871X_SEL
-#endif /* defined(_seqdump) */
 
-#endif /* defined(_dbgdump) */
+/* other debug APIs */
+#undef RTW_DBG_EXPR
+#define RTW_DBG_EXPR(EXPR) do { if (_DRV_DEBUG_ <= rtw_drv_log_level) EXPR; } while (0)
 
-#ifdef CONFIG_DEBUG
-#if	defined(_dbgdump)
-	#undef DBG_871X
-	#define DBG_871X(...)     do {\
-		_dbgdump(DRIVER_PREFIX __VA_ARGS__);\
-	}while(0)
-
-	#undef MSG_8192C
-	#define MSG_8192C(...)     do {\
-		_dbgdump(DRIVER_PREFIX __VA_ARGS__);\
-	}while(0)
-
-	#undef DBG_8192C
-	#define DBG_8192C(...)     do {\
-		_dbgdump(DRIVER_PREFIX __VA_ARGS__);\
-	}while(0)
-
-	#undef RTW_WARN
-	#define RTW_WARN(...)	  do {\
-		_dbgdump(DRIVER_PREFIX"WARN " __VA_ARGS__);\
-	}while(0)
-
-	#undef RTW_INFO
-	#define RTW_INFO DBG_871X
 #endif /* defined(_dbgdump) */
-#endif /* CONFIG_DEBUG */
+#endif /* CONFIG_RTW_DEBUG */
 
-#ifdef CONFIG_DEBUG_RTL871X
 
-#if	defined(_dbgdump) && defined(_MODULE_DEFINE_)
+#if defined(_seqdump)
+/* dump message to selected 'stream' with driver-defined prefix */
+#undef RTW_PRINT_SEL
+#define RTW_PRINT_SEL(sel, fmt, arg...) \
+	do {\
+		if (sel == RTW_DBGDUMP)\
+			RTW_PRINT(fmt, ##arg); \
+		else {\
+			_seqdump(sel, fmt, ##arg) /*rtw_warn_on(1)*/; \
+		} \
+	} while (0)
 
-	#undef RT_TRACE
-	#define RT_TRACE(_Comp, _Level, Fmt)\
+/* dump message to selected 'stream' */
+#undef _RTW_PRINT_SEL
+#define _RTW_PRINT_SEL(sel, fmt, arg...) \
 	do {\
-		if((_Comp & GlobalDebugComponents) && (_Level <= GlobalDebugLevel)) {\
-			_dbgdump("%s [0x%08x,%d]", DRIVER_PREFIX, (unsigned int)_Comp, _Level);\
-			_dbgdump Fmt;\
-		}\
-	}while(0)
-
-#endif /* defined(_dbgdump) && defined(_MODULE_DEFINE_) */
-
-
-#if	defined(_dbgdump)
-	#undef  _func_enter_
-	#define _func_enter_ \
-	do {	\
-		if (GlobalDebugLevel >= _drv_debug_) \
-		{																	\
-			_dbgdump("\n %s : %s enters at %d\n", DRIVER_PREFIX, __FUNCTION__, __LINE__);\
-		}		\
-	} while(0)
-
-	#undef  _func_exit_
-	#define _func_exit_ \
-	do {	\
-		if (GlobalDebugLevel >= _drv_debug_) \
-		{																	\
-			_dbgdump("\n %s : %s exits at %d\n", DRIVER_PREFIX, __FUNCTION__, __LINE__); \
-		}	\
-	} while(0)
-
-	#undef RT_PRINT_DATA
-	#define RT_PRINT_DATA(_Comp, _Level, _TitleString, _HexData, _HexDataLen)			\
-		if(((_Comp) & GlobalDebugComponents) && (_Level <= GlobalDebugLevel))	\
-		{									\
-			int __i;								\
-			u8	*ptr = (u8 *)_HexData;				\
-			_dbgdump("%s", DRIVER_PREFIX);						\
-			_dbgdump(_TitleString);						\
-			for( __i=0; __i<(int)_HexDataLen; __i++ )				\
-			{								\
-				_dbgdump("%02X%s", ptr[__i], (((__i + 1) % 4) == 0)?"  ":" ");	\
-				if (((__i + 1) % 16) == 0)	_dbgdump("\n");			\
-			}								\
-			_dbgdump("\n");							\
-		}
-#endif /* defined(_dbgdump) */
-#endif /* CONFIG_DEBUG_RTL871X */
+		if (sel == RTW_DBGDUMP)\
+			_RTW_PRINT(fmt, ##arg); \
+		else {\
+			_seqdump(sel, fmt, ##arg) /*rtw_warn_on(1)*/; \
+		} \
+	} while (0)
+
+/* dump message to selected 'stream' */
+#undef RTW_DUMP_SEL
+#define RTW_DUMP_SEL(sel, _HexData, _HexDataLen) \
+	RTW_BUF_DUMP_SEL(_DRV_ALWAYS_, sel, NULL, _FALSE, _HexData, _HexDataLen)
+
+#define RTW_MAP_DUMP_SEL(sel, _TitleString, _HexData, _HexDataLen) \
+	RTW_BUF_DUMP_SEL(_DRV_ALWAYS_, sel, _TitleString, _TRUE, _HexData, _HexDataLen)
+#endif /* defined(_seqdump) */
+
 
 #ifdef CONFIG_DBG_COUNTER
-#define DBG_COUNTER(counter) counter++
+	#define DBG_COUNTER(counter) counter++
 #else
-#define DBG_COUNTER(counter) 
+	#define DBG_COUNTER(counter)
 #endif
 
 void dump_drv_version(void *sel);
@@ -368,14 +264,10 @@ void sdio_local_reg_dump(void *sel, _adapter *adapter);
 
 void mac_reg_dump(void *sel, _adapter *adapter);
 void bb_reg_dump(void *sel, _adapter *adapter);
+void bb_reg_dump_ex(void *sel, _adapter *adapter);
 void rf_reg_dump(void *sel, _adapter *adapter);
 
-bool rtw_fwdl_test_trigger_chksum_fail(void);
-bool rtw_fwdl_test_trigger_wintint_rdy_fail(void);
-bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void);
-
-u32 rtw_get_wait_hiq_empty_ms(void);
-void rtw_sink_rtp_seq_dbg( _adapter *adapter,_pkt *pkt);
+void rtw_sink_rtp_seq_dbg(_adapter *adapter, u8 *ehdr_pos);
 
 struct sta_info;
 void sta_rx_reorder_ctl_dump(void *sel, struct sta_info *sta);
@@ -388,6 +280,7 @@ struct sec_cam_ent;
 void dump_sec_cam_ent(void *sel, struct sec_cam_ent *ent, int id);
 void dump_sec_cam_ent_title(void *sel, u8 has_id);
 void dump_sec_cam(void *sel, _adapter *adapter);
+void dump_sec_cam_cache(void *sel, _adapter *adapter);
 
 #ifdef CONFIG_PROC_DEBUG
 ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
@@ -404,43 +297,59 @@ int proc_get_roam_param(struct seq_file *m, void *v);
 ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 ssize_t proc_set_roam_tgt_addr(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #endif /* CONFIG_LAYER2_ROAMING */
+#ifdef CONFIG_RTW_80211R
+int proc_get_ft_flags(struct seq_file *m, void *v);
+ssize_t proc_set_ft_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 int proc_get_qos_option(struct seq_file *m, void *v);
 int proc_get_ht_option(struct seq_file *m, void *v);
 int proc_get_rf_info(struct seq_file *m, void *v);
 int proc_get_scan_param(struct seq_file *m, void *v);
 ssize_t proc_set_scan_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_scan_abort(struct seq_file *m, void *v);
-#ifdef CONFIG_SCAN_BACKOP
-int proc_get_backop_flags_sta(struct seq_file *m, void *v);
-ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-int proc_get_backop_flags_ap(struct seq_file *m, void *v);
-ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-#endif /* CONFIG_SCAN_BACKOP */
+#ifdef CONFIG_RTW_REPEATER_SON
+int proc_get_rson_data(struct seq_file *m, void *v);
+ssize_t proc_set_rson_data(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 int proc_get_survey_info(struct seq_file *m, void *v);
 ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_ap_info(struct seq_file *m, void *v);
 ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_trx_info(struct seq_file *m, void *v);
+ssize_t proc_set_tx_power_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tx_power_offset(struct seq_file *m, void *v);
 int proc_get_rate_ctl(struct seq_file *m, void *v);
 int proc_get_wifi_spec(struct seq_file *m, void *v);
 ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_bw_ctl(struct seq_file *m, void *v);
+ssize_t proc_set_bw_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #ifdef DBG_RX_COUNTER_DUMP
 int proc_get_rx_cnt_dump(struct seq_file *m, void *v);
-ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);	
+ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #endif
-int proc_get_dis_pwt(struct seq_file *m, void *v);
-ssize_t proc_set_dis_pwt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);	
 
-int proc_get_suspend_resume_info(struct seq_file *m, void *v);
+#ifdef CONFIG_AP_MODE
+int proc_get_bmc_tx_rate(struct seq_file *m, void *v);
+ssize_t proc_set_bmc_tx_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /*CONFIG_AP_MODE*/
+
+int proc_get_ps_dbg_info(struct seq_file *m, void *v);
+ssize_t proc_set_ps_dbg_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
+bool rtw_fwdl_test_trigger_chksum_fail(void);
+bool rtw_fwdl_test_trigger_wintint_rdy_fail(void);
 ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void);
 ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-#ifdef CONFIG_DFS_MASTER
-int proc_get_dfs_master_test_case(struct seq_file *m, void *v);
-ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-#endif /* CONFIG_DFS_MASTER */
+u32 rtw_get_wait_hiq_empty_ms(void);
 ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+void rtw_sta_linking_test_set_start(void);
+bool rtw_sta_linking_test_wait_done(void);
+bool rtw_sta_linking_test_force_fail(void);
+ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
+int proc_get_rx_stat(struct seq_file *m, void *v);
+int proc_get_tx_stat(struct seq_file *m, void *v);
 #ifdef CONFIG_AP_MODE
 int proc_get_all_sta_info(struct seq_file *m, void *v);
 #endif /* CONFIG_AP_MODE */
@@ -454,9 +363,12 @@ int proc_get_best_channel(struct seq_file *m, void *v);
 ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #endif /* CONFIG_FIND_BEST_CHANNEL */
 
+int proc_get_trx_info_debug(struct seq_file *m, void *v);
+
 int proc_get_rx_signal(struct seq_file *m, void *v);
 ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_hw_status(struct seq_file *m, void *v);
+ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
 #ifdef CONFIG_80211N_HT
 int proc_get_ht_enable(struct seq_file *m, void *v);
@@ -470,34 +382,61 @@ ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size
 
 int proc_get_mac_rptbuf(struct seq_file *m, void *v);
 
+void dump_regsty_rx_ampdu_size_limit(void *sel, _adapter *adapter);
 int proc_get_rx_ampdu(struct seq_file *m, void *v);
 ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
+void rtw_dump_dft_phy_cap(void *sel, _adapter *adapter);
+void rtw_get_dft_phy_cap(void *sel, _adapter *adapter);
+void rtw_dump_drv_phy_cap(void *sel, _adapter *adapter);
+
 int proc_get_rx_stbc(struct seq_file *m, void *v);
 ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-
-
+int proc_get_stbc_cap(struct seq_file *m, void *v);
+ssize_t proc_set_stbc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_ldpc_cap(struct seq_file *m, void *v);
+ssize_t proc_set_ldpc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#ifdef CONFIG_BEAMFORMING
+int proc_get_txbf_cap(struct seq_file *m, void *v);
+ssize_t proc_set_txbf_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 int proc_get_rx_ampdu_factor(struct seq_file *m, void *v);
 ssize_t proc_set_rx_ampdu_factor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
+int proc_get_tx_max_agg_num(struct seq_file *m, void *v);
+ssize_t proc_set_tx_max_agg_num(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
 int proc_get_rx_ampdu_density(struct seq_file *m, void *v);
 ssize_t proc_set_rx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
 int proc_get_tx_ampdu_density(struct seq_file *m, void *v);
 ssize_t proc_set_tx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_TX_AMSDU
+int proc_get_tx_amsdu(struct seq_file *m, void *v);
+ssize_t proc_set_tx_amsdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_tx_amsdu_rate(struct seq_file *m, void *v);
+ssize_t proc_set_tx_amsdu_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 #endif /* CONFIG_80211N_HT */
 
 int proc_get_en_fwps(struct seq_file *m, void *v);
 ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
-//int proc_get_two_path_rssi(struct seq_file *m, void *v);
-//int proc_get_rssi_disp(struct seq_file *m, void *v);
-//ssize_t proc_set_rssi_disp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#if 0
+int proc_get_two_path_rssi(struct seq_file *m, void *v);
+int proc_get_rssi_disp(struct seq_file *m, void *v);
+ssize_t proc_set_rssi_disp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 
 #ifdef CONFIG_BT_COEXIST
 int proc_get_btcoex_dbg(struct seq_file *m, void *v);
 ssize_t proc_set_btcoex_dbg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_btcoex_info(struct seq_file *m, void *v);
+#ifdef CONFIG_RF4CE_COEXIST
+int proc_get_rf4ce_state(struct seq_file *m, void *v);
+ssize_t proc_set_rf4ce_state(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 #endif /* CONFIG_BT_COEXIST */
 
 #if defined(DBG_CONFIG_ERROR_DETECT)
@@ -505,11 +444,6 @@ int proc_get_sreset(struct seq_file *m, void *v);
 ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #endif /* DBG_CONFIG_ERROR_DETECT */
 
-int proc_get_odm_dbg_comp(struct seq_file *m, void *v);
-ssize_t proc_set_odm_dbg_comp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-int proc_get_odm_dbg_level(struct seq_file *m, void *v);
-ssize_t proc_set_odm_dbg_level(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-
 int proc_get_odm_adaptivity(struct seq_file *m, void *v);
 ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
@@ -522,6 +456,21 @@ int proc_get_int_logs(struct seq_file *m, void *v);
 #ifdef CONFIG_PCI_HCI
 int proc_get_rx_ring(struct seq_file *m, void *v);
 int proc_get_tx_ring(struct seq_file *m, void *v);
+int proc_get_pci_aspm(struct seq_file *m, void *v);
+#ifdef DBG_TXBD_DESC_DUMP
+int proc_get_tx_ring_ext(struct seq_file *m, void *v);
+ssize_t proc_set_tx_ring_ext(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+#endif
+
+#ifdef CONFIG_WOWLAN
+int proc_get_pattern_info(struct seq_file *m, void *v);
+ssize_t proc_set_pattern_info(struct file *file, const char __user *buffer,
+		size_t count, loff_t *pos, void *data);
+int proc_get_wakeup_event(struct seq_file *m, void *v);
+ssize_t proc_set_wakeup_event(struct file *file, const char __user *buffer,
+		size_t count, loff_t *pos, void *data);
+int proc_get_wakeup_reason(struct seq_file *m, void *v);
 #endif
 
 #ifdef CONFIG_GPIO_WAKEUP
@@ -539,15 +488,25 @@ ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_
 
 #ifdef CONFIG_POWER_SAVING
 int proc_get_ps_info(struct seq_file *m, void *v);
-#endif //CONFIG_POWER_SAVING
+#ifdef CONFIG_WMMPS_STA	
+int proc_get_wmmps_info(struct seq_file *m, void *v);
+ssize_t proc_set_wmmps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /* CONFIG_WMMPS_STA */
+#endif /* CONFIG_POWER_SAVING */
 
 #ifdef CONFIG_TDLS
+int proc_get_tdls_enable(struct seq_file *m, void *v);
+ssize_t proc_set_tdls_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_tdls_info(struct seq_file *m, void *v);
 #endif
 
 int proc_get_monitor(struct seq_file *m, void *v);
 ssize_t proc_set_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
+#ifdef DBG_XMIT_BLOCK
+int proc_get_xmit_block(struct seq_file *m, void *v);
+ssize_t proc_set_xmit_block(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 
 #ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
 int proc_get_rtkm_info(struct seq_file *m, void *v);
@@ -567,5 +526,76 @@ int proc_get_tx_auth(struct seq_file *m, void *v);
 int proc_get_efuse_map(struct seq_file *m, void *v);
 ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
-#endif	//__RTW_DEBUG_H__
+#ifdef CONFIG_MCC_MODE
+int proc_get_mcc_info(struct seq_file *m, void *v);
+ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_duration(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_single_tx_criteria(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_ap_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_ap_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_ap_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_sta_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_sta_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_sta_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_mcc_policy_table(struct seq_file *m, void *v);
+#endif /* CONFIG_MCC_MODE */
+
+int proc_get_ack_timeout(struct seq_file *m, void *v);
+ssize_t proc_set_ack_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_fw_offload(struct seq_file *m, void *v);
+ssize_t proc_set_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_DBG_RF_CAL
+int proc_get_iqk_info(struct seq_file *m, void *v);
+ssize_t proc_set_iqk(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_lck_info(struct seq_file *m, void *v);
+ssize_t proc_set_lck(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif /*CONFIG_DBG_RF_CAL*/
+
+#define _drv_always_		1
+#define _drv_emerg_			2
+#define _drv_alert_			3
+#define _drv_crit_			4
+#define _drv_err_			5
+#define _drv_warning_		6
+#define _drv_notice_		7
+#define _drv_info_			8
+#define _drv_dump_			9
+#define _drv_debug_			10
+
+#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_efuse_			BIT(27) */
+#define	_module_rtl8192c_xmit_c_ BIT(28)
+#define _module_hal_xmit_c_	BIT(28)
+#define _module_efuse_			BIT(29)
+#define _module_rtl8712_recv_c_		BIT(30)
+#define _module_rtl8712_led_c_		BIT(31)
 
+#endif /* __RTW_DEBUG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_eeprom.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_eeprom.h
index 2da2a67b348e..02c160dc114d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_eeprom.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_eeprom.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,18 +12,13 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_EEPROM_H__
 #define __RTW_EEPROM_H__
 
 
 #define	RTL8712_EEPROM_ID			0x8712
-//#define	EEPROM_MAX_SIZE			256
+/* #define	EEPROM_MAX_SIZE			256 */
 
 #define	HWSET_MAX_SIZE_128		128
 #define	HWSET_MAX_SIZE_256		256
@@ -31,30 +27,29 @@
 
 #define	EEPROM_MAX_SIZE			HWSET_MAX_SIZE_1024
 
-#define	CLOCK_RATE					50			//100us		
+#define	CLOCK_RATE					50			/* 100us		 */
 
-//- EEPROM opcodes
+/* - 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
+#define EEPROM_EWEN_OPCODE		19      /* Erase/write enable */
+#define EEPROM_EWDS_OPCODE		16      /* Erase/write disable */
 
-//Country codes
+/* Country codes */
 #define USA							0x555320
-#define EUROPE						0x1 //temp, should be provided later	
-#define JAPAN						0x2 //temp, should be provided later
+#define EUROPE						0x1 /* temp, should be provided later	 */
+#define JAPAN						0x2 /* temp, should be provided later */
 
-//
-// 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.
-//
-typedef enum _RT_CUSTOMER_ID
-{
+/*
+ * 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.
+ *   */
+typedef enum _RT_CUSTOMER_ID {
 	RT_CID_DEFAULT = 0,
 	RT_CID_8187_ALPHA0 = 1,
 	RT_CID_8187_SERCOMM_PS = 2,
@@ -64,7 +59,7 @@ typedef enum _RT_CUSTOMER_ID
 	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_TOSHIBA = 9,	/* Merge by Jacken, 2008/01/31. */
 	RT_CID_819x_Netcore = 10,
 	RT_CID_Nettronix = 11,
 	RT_CID_DLINK = 12,
@@ -73,16 +68,16 @@ typedef enum _RT_CUSTOMER_ID
 	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_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_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_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,
@@ -99,25 +94,24 @@ typedef enum _RT_CUSTOMER_ID
 	RT_CID_INTEL_CHINA = 41,
 	RT_CID_TPLINK_HPWR = 42,
 	RT_CID_819x_Sercomm_Netgear = 43,
-	RT_CID_819x_ALPHA_Dlink = 44,//add by ylb 20121012 for customer led for alpha
-	RT_CID_WNC_NEC = 45,//add by page for NEC
-	RT_CID_DNI_BUFFALO = 46,//add by page for NEC
-}RT_CUSTOMER_ID, *PRT_CUSTOMER_ID;
+	RT_CID_819x_ALPHA_Dlink = 44,/* add by ylb 20121012 for customer led for alpha */
+	RT_CID_WNC_NEC = 45,/* add by page for NEC */
+	RT_CID_DNI_BUFFALO = 46,/* add by page for NEC */
+} RT_CUSTOMER_ID, *PRT_CUSTOMER_ID;
 
 extern void eeprom_write16(_adapter *padapter, u16 reg, u16 data);
 extern u16 eeprom_read16(_adapter *padapter, u16 reg);
 extern void read_eeprom_content(_adapter *padapter);
-extern void eeprom_read_sz(_adapter * padapter, u16 reg,u8* data, u32 sz); 
+extern void eeprom_read_sz(_adapter *padapter, u16 reg, u8 *data, u32 sz);
 
-extern void read_eeprom_content_by_attrib(_adapter *	padapter	);
+extern void read_eeprom_content_by_attrib(_adapter	*padapter);
 
 #ifdef PLATFORM_LINUX
 #ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
 extern int isAdaptorInfoFileValid(void);
 extern int storeAdaptorInfoFile(char *path, u8 *efuse_data);
 extern int retriveAdaptorInfoFile(char *path, u8 *efuse_data);
-#endif //CONFIG_ADAPTOR_INFO_CACHING_FILE
-#endif //PLATFORM_LINUX
-
-#endif  //__RTL871X_EEPROM_H__
+#endif /* CONFIG_ADAPTOR_INFO_CACHING_FILE */
+#endif /* PLATFORM_LINUX */
 
+#endif /* __RTL871X_EEPROM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_efuse.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_efuse.h
index e35800618d7f..f18793657e66 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_efuse.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_efuse.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_EFUSE_H__
 #define __RTW_EFUSE_H__
 
 
 #define	EFUSE_ERROE_HANDLE		1
 
-#define	PG_STATE_HEADER 		0x01
+#define	PG_STATE_HEADER		0x01
 #define	PG_STATE_WORD_0		0x02
 #define	PG_STATE_WORD_1		0x04
 #define	PG_STATE_WORD_2		0x08
@@ -48,14 +44,27 @@ enum _EFUSE_DEF_TYPE {
 	TYPE_EFUSE_CONTENT_LEN_BANK			= 6,
 };
 
-#define		EFUSE_MAX_MAP_LEN		512
+#define		EFUSE_MAX_MAP_LEN		1024
 
-#define		EFUSE_MAX_HW_SIZE		512
+#define		EFUSE_MAX_HW_SIZE		1024
 #define		EFUSE_MAX_SECTION_BASE	16
+#define		EFUSE_MAX_SECTION_NUM	128
+#define		EFUSE_MAX_BANK_SIZE		512
+
+/*RTL8822B 8821C BT EFUSE Define 1 BANK 128 size logical map 1024*/
+#ifdef RTW_HALMAC
+#define BANK_NUM		1
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
+#define EFUSE_BT_REAL_CONTENT_LEN		(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)
+#define EFUSE_BT_MAP_LEN				1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION			(EFUSE_BT_MAP_LEN / 8)
+#define EFUSE_PROTECT_BYTES_BANK		16
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_BT_REAL_CONTENT_LEN)
+#endif
 
-#define EXT_HEADER(header) ((header & 0x1F ) == 0x0F)
+#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 GET_HDR_OFFSET_2_0(header) ((header & 0xE0) >> 5)
 
 #define		EFUSE_REPEAT_THRESHOLD_			3
 
@@ -67,30 +76,29 @@ enum _EFUSE_DEF_TYPE {
 #define GET_MASK_ARRAY_TC(ic, txt, offset) (EFUSE_GetMaskArray_TC_##ic##txt(offset))
 
 
-#define IS_MASKED(ic, txt, offset) ( IS_MASKED_MP(ic,txt, offset) )
-#define GET_MASK_ARRAY_LEN(ic, txt) ( GET_MASK_ARRAY_LEN_MP(ic,txt) )
-#define GET_MASK_ARRAY(ic, txt, out) do { GET_MASK_ARRAY_MP(ic,txt, out);} while(0)
+#define IS_MASKED(ic, txt, offset) (IS_MASKED_MP(ic, txt, offset))
+#define GET_MASK_ARRAY_LEN(ic, txt) (GET_MASK_ARRAY_LEN_MP(ic, txt))
+#define GET_MASK_ARRAY(ic, txt, out) do { GET_MASK_ARRAY_MP(ic, txt, out); } while (0)
 
-//=============================================
-//	The following is for BT Efuse definition
-//=============================================
+/* *********************************************
+ *	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 Parameters-------------------------------*/
 #define		EFUSE_MAX_WORD_UNIT			4
 
-/*------------------------------Define structure----------------------------*/ 
-typedef struct PG_PKT_STRUCT_A{
+/*------------------------------Define structure----------------------------*/
+typedef struct PG_PKT_STRUCT_A {
 	u8 offset;
 	u8 word_en;
-	u8 data[8];	
+	u8 data[8];
 	u8 word_cnts;
-}PGPKT_STRUCT,*PPGPKT_STRUCT;
+} PGPKT_STRUCT, *PPGPKT_STRUCT;
 
-typedef enum
-{
+typedef enum {
 	ERR_SUCCESS = 0,
 	ERR_DRIVER_FAILURE,
 	ERR_IO_FAILURE,
@@ -104,8 +112,8 @@ typedef enum
 	ERR_OUT_OF_RANGE
 } ERROR_CODE;
 
-/*------------------------------Define structure----------------------------*/ 
-typedef struct _EFUSE_HAL{
+/*------------------------------Define structure----------------------------*/
+typedef struct _EFUSE_HAL {
 	u8	fakeEfuseBank;
 	u32	fakeEfuseUsedBytes;
 	u8	fakeEfuseContent[EFUSE_MAX_HW_SIZE];
@@ -113,7 +121,7 @@ typedef struct _EFUSE_HAL{
 	u8	fakeEfuseModifiedMap[EFUSE_MAX_MAP_LEN];
 	u32	EfuseUsedBytes;
 	u8	EfuseUsedPercentage;
-	
+
 	u16	BTEfuseUsedBytes;
 	u8	BTEfuseUsedPercentage;
 	u8	BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
@@ -125,31 +133,31 @@ typedef struct _EFUSE_HAL{
 	u8	fakeBTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN];
 	u8	fakeBTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN];
 
-	// EFUSE Configuration, initialized in HAL_CmnInitPGData().
+	/* EFUSE Configuration, initialized in HAL_CmnInitPGData(). */
 	const u16  MaxSecNum_WiFi;
-	const u16  MaxSecNum_BT;	
-	const u16  WordUnit;	
+	const u16  MaxSecNum_BT;
+	const u16  WordUnit;
 	const u16  PhysicalLen_WiFi;
-	const u16  PhysicalLen_BT;	
+	const u16  PhysicalLen_BT;
 	const u16  LogicalLen_WiFi;
-	const u16  LogicalLen_BT;	
+	const u16  LogicalLen_BT;
 	const u16  BankSize;
 	const u16  TotalBankNum;
 	const u16  BankNum_WiFi;
-	const u16  BankNum_BT;	
+	const u16  BankNum_BT;
 	const u16  OOBProtectBytes;
 	const u16  ProtectBytes;
-	const u16  BankAvailBytes;	
+	const u16  BankAvailBytes;
 	const u16  TotalAvailBytes_WiFi;
-	const u16  TotalAvailBytes_BT;	
-	const u16  HeaderRetry;	
-	const u16  DataRetry;	
+	const u16  TotalAvailBytes_BT;
+	const u16  HeaderRetry;
+	const u16  DataRetry;
+
+	ERROR_CODE	  Status;
 
-	ERROR_CODE 	  Status;
-	
-}EFUSE_HAL, *PEFUSE_HAL;
+} EFUSE_HAL, *PEFUSE_HAL;
 
-extern u8 maskfileBuffer[32];
+extern u8 maskfileBuffer[64];
 
 /*------------------------Export global variable----------------------------*/
 extern u8 fakeEfuseBank;
@@ -168,36 +176,71 @@ extern u8 fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
 extern u8 fakeBTEfuseInitMap[];
 extern u8 fakeBTEfuseModifiedMap[];
 /*------------------------Export global variable----------------------------*/
+#define		MAX_SEGMENT_SIZE			200
+#define		MAX_SEGMENT_NUM			200
+#define		MAX_BUF_SIZE				(MAX_SEGMENT_SIZE*MAX_SEGMENT_NUM)
+#define		TMP_BUF_SIZE				100
+
+static	u8	dcmd_Return_Buffer[MAX_BUF_SIZE] = {0};
+static	u32	dcmd_Buf_Idx = 0;
+static	u32	dcmd_Finifh_Flag = 0;
+
+static	char	dcmd_Buf[TMP_BUF_SIZE];
+
+#define		rtprintf					dcmd_Store_Return_Buf
+
 u8	efuse_bt_GetCurrentSize(PADAPTER padapter, u16 *size);
 u16	efuse_bt_GetMaxSize(PADAPTER padapter);
+u16 efuse_GetavailableSize(PADAPTER adapter);
 
 u8	efuse_GetCurrentSize(PADAPTER padapter, u16 *size);
 u16	efuse_GetMaxSize(PADAPTER padapter);
 u8	rtw_efuse_access(PADAPTER padapter, u8 bRead, u16 start_addr, u16 cnts, u8 *data);
+u8	rtw_efuse_bt_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data);
+
 u8	rtw_efuse_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
 u8	rtw_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
 u8	rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
 u8	rtw_BT_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
-u8 	rtw_BT_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
+u8	rtw_BT_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data);
 
 u16	Efuse_GetCurrentSize(PADAPTER pAdapter, u8 efuseType, BOOLEAN bPseudoTest);
 u8	Efuse_CalculateWordCnts(u8 word_en);
 void	ReadEFuseByte(PADAPTER Adapter, u16 _offset, u8 *pbuf, BOOLEAN bPseudoTest) ;
 void	EFUSE_GetEfuseDefinition(PADAPTER pAdapter, u8 efuseType, u8 type, void *pOut, BOOLEAN bPseudoTest);
 u8	efuse_OneByteRead(PADAPTER pAdapter, u16 addr, u8 *data, BOOLEAN	 bPseudoTest);
+#define efuse_onebyte_read(adapter, addr, data, pseudo_test) efuse_OneByteRead((adapter), (addr), (data), (pseudo_test))
+
 u8	efuse_OneByteWrite(PADAPTER pAdapter, u16 addr, u8 data, BOOLEAN	 bPseudoTest);
 
-void	BTEfuse_PowerSwitch(PADAPTER pAdapter,u8	bWrite,u8	 PwrState);
-void	Efuse_PowerSwitch(PADAPTER pAdapter,u8	bWrite,u8	 PwrState);
-int 	Efuse_PgPacketRead(PADAPTER pAdapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);
-int 	Efuse_PgPacketWrite(PADAPTER pAdapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+void	BTEfuse_PowerSwitch(PADAPTER pAdapter, u8	bWrite, u8	 PwrState);
+void	Efuse_PowerSwitch(PADAPTER pAdapter, u8	bWrite, u8	 PwrState);
+int	Efuse_PgPacketRead(PADAPTER pAdapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);
+int	Efuse_PgPacketWrite(PADAPTER pAdapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
 void	efuse_WordEnableDataRead(u8 word_en, u8 *sourdata, u8 *targetdata);
 u8	Efuse_WordEnableDataWrite(PADAPTER pAdapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
-
-u8	EFUSE_Read1Byte(PADAPTER pAdapter, u16 Address);
 void	EFUSE_ShadowMapUpdate(PADAPTER pAdapter, u8 efuseType, BOOLEAN bPseudoTest);
 void	EFUSE_ShadowRead(PADAPTER pAdapter, u8 Type, u16 Offset, u32 *Value);
-u8 rtw_efuse_file_read(PADAPTER padapter,u8 *filepatch,u8 *buf, u32 len);
+#define efuse_logical_map_read(adapter, type, offset, value) EFUSE_ShadowRead((adapter), (type), (offset), (value))
+
+BOOLEAN rtw_file_efuse_IsMasked(PADAPTER pAdapter, u16 Offset);
+BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset);
+
+VOID	hal_ReadEFuse_BT_logic_map(
+	PADAPTER	padapter,
+	u16			_offset,
+	u16			_size_byte,
+	u8			*pbuf
+);
+u8	EfusePgPacketWrite_BT(
+	PADAPTER	pAdapter,
+	u8			offset,
+	u8			word_en,
+	u8			*pData,
+	u8			bPseudoTest);
+u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter);
+void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray);
+void rtw_efuse_analyze(PADAPTER	padapter, u8 Type, u8 Fake);
 
 #define MAC_HIDDEN_MAX_BW_NUM 8
 extern const u8 _mac_hidden_max_bw_to_hal_bw_cap[];
@@ -210,6 +253,7 @@ extern const u8 _mac_hidden_proto_to_hal_proto_cap[];
 u8 mac_hidden_wl_func_to_hal_wl_func(u8 func);
 
 #ifdef PLATFORM_LINUX
+u8 rtw_efuse_file_read(PADAPTER padapter, u8 *filepatch, u8 *buf, u32 len);
 #ifdef CONFIG_EFUSE_CONFIG_FILE
 u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size);
 u32 rtw_read_macaddr_from_file(const char *path, u8 *buf);
@@ -217,4 +261,3 @@ u32 rtw_read_macaddr_from_file(const char *path, u8 *buf);
 #endif /* PLATFORM_LINUX */
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_event.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_event.h
index 2aad9cbe48d9..4d2220323f11 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_event.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_event.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,17 +12,12 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_EVENT_H_
 #define _RTW_EVENT_H_
 
 #ifdef CONFIG_H2CLBK
-#include <h2clbk.h>
+	#include <h2clbk.h>
 #endif
 
 /*
@@ -40,8 +36,8 @@ bss_cnt indicates the number of bss that has been reported.
 
 */
 struct surveydone_event {
-	unsigned int	bss_cnt;	
-	
+	unsigned int	bss_cnt;
+
 };
 
 /*
@@ -69,24 +65,22 @@ struct stassoc_event {
 };
 
 struct stadel_event {
- unsigned char macaddr[6];
- unsigned char rsvd[2]; //for reason
-unsigned char locally_generated;
- int mac_id;
+	unsigned char macaddr[6];
+	unsigned char rsvd[2]; /* for reason */
+	unsigned char locally_generated;
+	int mac_id;
 };
 
-struct addba_event
-{
- 	unsigned int tid;
+struct addba_event {
+	unsigned int tid;
 };
 
-struct wmm_event
-{
- 	unsigned char wmm;
+struct wmm_event {
+	unsigned char wmm;
 };
 
 #ifdef CONFIG_H2CLBK
-struct c2hlbk_event{
+struct c2hlbk_event {
 	unsigned char mac[6];
 	unsigned short	s0;
 	unsigned short	s1;
@@ -94,9 +88,9 @@ struct c2hlbk_event{
 	unsigned char	b0;
 	unsigned short  s2;
 	unsigned char	b1;
-	unsigned int	w1;	
+	unsigned int	w1;
 };
-#endif//CONFIG_H2CLBK
+#endif/* CONFIG_H2CLBK */
 
 #define GEN_EVT_CODE(event)	event ## _EVT_
 
@@ -108,9 +102,9 @@ struct fwevent {
 };
 
 
-#define C2HEVENT_SZ			32	
+#define C2HEVENT_SZ			32
 
-struct event_node{
+struct event_node {
 	unsigned char *node;
 	unsigned char evt_code;
 	unsigned short evt_sz;
@@ -130,9 +124,8 @@ struct c2hevent_queue {
 struct network_queue {
 	volatile int	head;
 	volatile int	tail;
-	WLAN_BSSID_EX networks[NETWORK_QUEUE_SZ];	
+	WLAN_BSSID_EX networks[NETWORK_QUEUE_SZ];
 };
 
 
-#endif // _WLANEVENT_H_
-
+#endif /* _WLANEVENT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ht.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ht.h
index 1509dba62fb1..69f2b82c2fb3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ht.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ht.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,36 +12,32 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_HT_H_
 #define _RTW_HT_H_
 
+#define HT_CAP_IE_LEN 26
+#define HT_OP_IE_LEN 22
 
-struct ht_priv
-{
+struct ht_priv {
 	u8	ht_option;
-	u8	ampdu_enable;//for enable Tx A-MPDU
-	u8	tx_amsdu_enable;//for enable Tx A-MSDU
-	u8	bss_coexist;//for 20/40 Bss coexist
-
-	//u8	baddbareq_issued[16];
-	u32	tx_amsdu_maxlen; // 1: 8k, 0:4k ; default:8k, for tx
-	u32	rx_ampdu_maxlen; //for rx reordering ctrl win_sz, updated when join_callback.
-	
-	u8 	rx_ampdu_min_spacing;
-	
-	u8	ch_offset;//PRIME_CHNL_OFFSET
+	u8	ampdu_enable;/* for enable Tx A-MPDU */
+	u8	tx_amsdu_enable;/* for enable Tx A-MSDU */
+	u8	bss_coexist;/* for 20/40 Bss coexist */
+
+	/* u8	baddbareq_issued[16]; */
+	u32	tx_amsdu_maxlen; /* 1: 8k, 0:4k ; default:8k, for tx */
+	u32	rx_ampdu_maxlen; /* for rx reordering ctrl win_sz, updated when join_callback. */
+
+	u8	rx_ampdu_min_spacing;
+
+	u8	ch_offset;/* PRIME_CHNL_OFFSET */
 	u8	sgi_20m;
 	u8	sgi_40m;
 
-	//for processing Tx A-MPDU
+	/* for processing Tx A-MPDU */
 	u8	agg_enable_bitmap;
-	//u8	ADDBA_retry_count;
+	/* u8	ADDBA_retry_count; */
 	u8	candidate_tid_bitmap;
 
 	u8	ldpc_cap;
@@ -48,11 +45,14 @@ struct ht_priv
 	u8	beamform_cap;
 	u8	smps_cap; /*spatial multiplexing power save mode. 0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
 
+	u8 op_present:1; /* ht_op is present */
+
 	struct rtw_ieee80211_ht_cap ht_cap;
-	
+	u8 ht_op[HT_OP_IE_LEN];
+
 };
 
-typedef enum AGGRE_SIZE{
+typedef enum AGGRE_SIZE {
 	HT_AGG_SIZE_8K = 0,
 	HT_AGG_SIZE_16K = 1,
 	HT_AGG_SIZE_32K = 2,
@@ -61,24 +61,24 @@ typedef enum AGGRE_SIZE{
 	VHT_AGG_SIZE_256K = 5,
 	VHT_AGG_SIZE_512K = 6,
 	VHT_AGG_SIZE_1024K = 7,
-}AGGRE_SIZE_E, *PAGGRE_SIZE_E;
+} AGGRE_SIZE_E, *PAGGRE_SIZE_E;
 
-typedef enum _RT_HT_INF0_CAP{
+typedef enum _RT_HT_INF0_CAP {
 	RT_HT_CAP_USE_TURBO_AGGR = 0x01,
 	RT_HT_CAP_USE_LONG_PREAMBLE = 0x02,
 	RT_HT_CAP_USE_AMPDU = 0x04,
-	RT_HT_CAP_USE_WOW = 0x8,	
-	RT_HT_CAP_USE_SOFTAP = 0x10,	
+	RT_HT_CAP_USE_WOW = 0x8,
+	RT_HT_CAP_USE_SOFTAP = 0x10,
 	RT_HT_CAP_USE_92SE = 0x20,
 	RT_HT_CAP_USE_88C_92C = 0x40,
-	RT_HT_CAP_USE_AP_CLIENT_MODE = 0x80,	// AP team request to reserve this bit, by Emily
-}RT_HT_INF0_CAPBILITY, *PRT_HT_INF0_CAPBILITY;
+	RT_HT_CAP_USE_AP_CLIENT_MODE = 0x80,	/* AP team request to reserve this bit, by Emily */
+} RT_HT_INF0_CAPBILITY, *PRT_HT_INF0_CAPBILITY;
 
-typedef enum _RT_HT_INF1_CAP{
+typedef enum _RT_HT_INF1_CAP {
 	RT_HT_CAP_USE_VIDEO_CLIENT = 0x01,
 	RT_HT_CAP_USE_JAGUAR_BCUT = 0x02,
 	RT_HT_CAP_USE_JAGUAR_CCUT = 0x04,
-}RT_HT_INF1_CAPBILITY, *PRT_HT_INF1_CAPBILITY;
+} RT_HT_INF1_CAPBILITY, *PRT_HT_INF1_CAPBILITY;
 
 #define	LDPC_HT_ENABLE_RX			BIT0
 #define	LDPC_HT_ENABLE_TX			BIT1
@@ -90,20 +90,14 @@ typedef enum _RT_HT_INF1_CAP{
 #define	STBC_HT_TEST_TX_ENABLE		BIT2
 #define	STBC_HT_CAP_TX				BIT3
 
-#define	BEAMFORMING_HT_BEAMFORMER_ENABLE	BIT0	// Declare our NIC supports beamformer
-#define	BEAMFORMING_HT_BEAMFORMEE_ENABLE	BIT1	// Declare our NIC supports beamformee
-#define	BEAMFORMING_HT_BEAMFORMER_TEST		BIT2	// Transmiting Beamforming no matter the target supports it or not
-#define	BEAMFORMING_HT_BEAMFORMER_STEER_NUM		(BIT4|BIT5)
-#define	BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP	(BIT6|BIT7)
-
-//------------------------------------------------------------
-// The HT Control field
-//------------------------------------------------------------
+/* ------------------------------------------------------------
+ * The HT Control field
+ * ------------------------------------------------------------ */
 #define SET_HT_CTRL_CSI_STEERING(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart))+2, 6, 2, _val)
 #define SET_HT_CTRL_NDP_ANNOUNCEMENT(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart))+3, 0, 1, _val)
 #define GET_HT_CTRL_NDP_ANNOUNCEMENT(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+3, 0, 1)
 
-// 20/40 BSS Coexist
+/* 20/40 BSS Coexist */
 #define SET_EXT_CAPABILITY_ELE_BSS_COEXIST(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)), 0, 1, _val)
 #define GET_EXT_CAPABILITY_ELE_BSS_COEXIST(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart)), 0, 1)
 
@@ -146,9 +140,12 @@ typedef enum _RT_HT_INF1_CAP{
 	"MAX AMPDU len:%u bytes, MIN MPDU Start Spacing:%u"
 
 #define HT_AMPDU_PARA_ARG(x) \
-	*((u8*)(x)) \
-	, (1 << (13+GET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(((u8*)x)-2)))-1 \
-	, GET_HT_CAP_ELE_MIN_MPDU_S_SPACE(((u8*)x)-2)
+	*((u8 *)(x)) \
+	, (1 << (13+GET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(((u8 *)x)-2)))-1 \
+	, GET_HT_CAP_ELE_MIN_MPDU_S_SPACE(((u8 *)x)-2)
+
+#define SET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 0, 2, _val)
+#define SET_HT_CAP_ELE_MIN_MPDU_S_SPACE(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 2, 3, _val)
 
 /* Supported MCS Set field */
 #define HT_CAP_ELE_SUP_MCS_SET(_pEleStart)				(((u8 *)(_pEleStart))+3)
@@ -159,18 +156,21 @@ typedef enum _RT_HT_INF1_CAP{
 #define GET_HT_CAP_ELE_TX_MAX_SS(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 2, 2)
 #define GET_HT_CAP_ELE_TX_UEQM(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 4, 1)
 
-#define HT_SUP_MCS_SET_FMT "%02x %02x %02x %02x %02x%02x%02x%02x%02x%02x" \
+#define HT_RX_MCS_BMP_FMT "%02x %02x %02x %02x %02x%02x%02x%02x%02x%02x"
+#define HT_RX_MCS_BMP_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
+	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9]
+
+#define HT_SUP_MCS_SET_FMT HT_RX_MCS_BMP_FMT \
 	/* "\n%02x%02x%02x%02x%02x%02x" */\
 	" %uMbps %s%s%s"
-#define HT_SUP_MCS_SET_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
-	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9] \
-	/*,((u8 *)(x))[10],((u8 *)(x))[11], ((u8 *)(x))[12],((u8 *)(x))[13],((u8 *)(x))[14],((u8 *)(x))[15] */\
+#define HT_SUP_MCS_SET_ARG(x) HT_RX_MCS_BMP_ARG(x) \
+	/*,((u8 *)(x))[10], ((u8 *)(x))[11], ((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15] */\
 	, GET_HT_CAP_ELE_RX_HIGHEST_DATA_RATE(((u8 *)x)-3) \
 	, GET_HT_CAP_ELE_TX_MCS_DEF(((u8 *)x)-3) ? "TX_MCS_DEF " : "" \
 	, GET_HT_CAP_ELE_TRX_MCS_NEQ(((u8 *)x)-3) ? "TRX_MCS_NEQ " : "" \
 	, GET_HT_CAP_ELE_TX_UEQM(((u8 *)x)-3) ? "TX_UEQM " : ""
 
-//TXBF Capabilities
+/* TXBF Capabilities */
 #define SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(_pEleStart, _val)				SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 3, 1, ((u8)_val))
 #define SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(_pEleStart, _val)				SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 4, 1, ((u8)_val))
 #define SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(_pEleStart, _val)	SET_BITS_TO_LE_4BYTE(((u8 *)(_pEleStart))+21, 10, 1, ((u8)_val))
@@ -217,5 +217,4 @@ typedef enum _RT_HT_INF1_CAP{
 #define SET_HT_OP_ELE_PCO_ACTIVE(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 5, 2, 1, _val)
 #define SET_HT_OP_ELE_PCO_PHASE(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 5, 3, 1, _val)
 
-#endif	//_RTL871X_HT_H_
-
+#endif /* _RTL871X_HT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_io.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_io.h
index 1b031f57eb0a..79a1771a36da 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_io.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_io.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #ifndef _RTW_IO_H_
 #define _RTW_IO_H_
@@ -24,17 +20,17 @@
 #define NUM_IOREQ		8
 
 #ifdef PLATFORM_WINDOWS
-#define MAX_PROT_SZ	64
+	#define MAX_PROT_SZ	64
 #endif
 #ifdef PLATFORM_LINUX
-#define MAX_PROT_SZ	(64-16)
+	#define MAX_PROT_SZ	(64-16)
 #endif
 
 #define _IOREADY			0
 #define _IO_WAIT_COMPLETE   1
 #define _IO_WAIT_RSP        2
 
-// IO COMMAND TYPE
+/* IO COMMAND TYPE */
 #define _IOSZ_MASK_		(0x7F)
 #define _IO_WRITE_		BIT(7)
 #define _IO_FIXED_		BIT(8)
@@ -46,14 +42,14 @@
 #define _IO_CMDMASK_	(0x1F80)
 
 
-/* 
+/*
 	For prompt mode accessing, caller shall free io_req
 	Otherwise, io_handler will free io_req
 */
 
 
 
-// IO STATUS TYPE
+/* IO STATUS TYPE */
 #define _IO_ERR_		BIT(2)
 #define _IO_SUCCESS_	BIT(1)
 #define _IO_DONE_		BIT(0)
@@ -81,103 +77,102 @@
 
 */
 
-#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_))
+#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...
+/* below is for the intf_option bit defition... */
 
-#define _INTF_ASYNC_	BIT(0)	//support async io
+#define _INTF_ASYNC_	BIT(0)	/* support async io */
 
 struct intf_priv;
 struct intf_hdl;
 struct io_queue;
 
-struct _io_ops
-{
-		u8 (*_read8)(struct intf_hdl *pintfhdl, u32 addr);
-		u16 (*_read16)(struct intf_hdl *pintfhdl, u32 addr);
-		u32 (*_read32)(struct intf_hdl *pintfhdl, u32 addr);
+struct _io_ops {
+	u8(*_read8)(struct intf_hdl *pintfhdl, u32 addr);
+	u16(*_read16)(struct intf_hdl *pintfhdl, u32 addr);
+	u32(*_read32)(struct intf_hdl *pintfhdl, u32 addr);
 
-		int (*_write8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
-		int (*_write16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
-		int (*_write32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
-		int (*_writeN)(struct intf_hdl *pintfhdl, u32 addr, u32 length, u8 *pdata);
+	int (*_write8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+	int (*_write16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+	int (*_write32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+	int (*_writeN)(struct intf_hdl *pintfhdl, u32 addr, u32 length, u8 *pdata);
 
-		int (*_write8_async)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
-		int (*_write16_async)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
-		int (*_write32_async)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+	int (*_write8_async)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+	int (*_write16_async)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+	int (*_write32_async)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
 
-		void (*_read_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
-		void (*_write_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	void (*_read_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	void (*_write_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
 
-		void (*_sync_irp_protocol_rw)(struct io_queue *pio_q);
+	void (*_sync_irp_protocol_rw)(struct io_queue *pio_q);
 
-		u32 (*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
+	u32(*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);
 
-		u32 (*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
-		u32 (*_write_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	u32(*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
+	u32(*_write_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
 
-		u32 (*_write_scsi)(struct intf_hdl *pintfhdl,u32 cnt, u8 *pmem);
+	u32(*_write_scsi)(struct intf_hdl *pintfhdl, u32 cnt, u8 *pmem);
 
-		void (*_read_port_cancel)(struct intf_hdl *pintfhdl);
-		void (*_write_port_cancel)(struct intf_hdl *pintfhdl);
+	void (*_read_port_cancel)(struct intf_hdl *pintfhdl);
+	void (*_write_port_cancel)(struct intf_hdl *pintfhdl);
 
 #ifdef CONFIG_SDIO_HCI
-		u8 (*_sd_f0_read8)(struct intf_hdl *pintfhdl, u32 addr);
-		#ifdef CONFIG_SDIO_INDIRECT_ACCESS
-		u8 (*_sd_iread8)(struct intf_hdl *pintfhdl, u32 addr);
-		u16 (*_sd_iread16)(struct intf_hdl *pintfhdl, u32 addr);
-		u32 (*_sd_iread32)(struct intf_hdl *pintfhdl, u32 addr);
-		int (*_sd_iwrite8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
-		int (*_sd_iwrite16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
-		int (*_sd_iwrite32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
-		#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+	u8(*_sd_f0_read8)(struct intf_hdl *pintfhdl, u32 addr);
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+	u8(*_sd_iread8)(struct intf_hdl *pintfhdl, u32 addr);
+	u16(*_sd_iread16)(struct intf_hdl *pintfhdl, u32 addr);
+	u32(*_sd_iread32)(struct intf_hdl *pintfhdl, u32 addr);
+	int (*_sd_iwrite8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+	int (*_sd_iwrite16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+	int (*_sd_iwrite32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
 #endif
-		
+
 };
 
-struct io_req {	
+struct io_req {
 	_list	list;
-	u32	addr;	
+	u32	addr;
 	volatile u32	val;
 	u32	command;
 	u32	status;
-	u8	*pbuf;	
+	u8	*pbuf;
 	_sema	sema;
 
 #ifdef PLATFORM_OS_CE
 #ifdef CONFIG_USB_HCI
-	// URB handler for rtw_write_mem
+	/* URB handler for rtw_write_mem */
 	USB_TRANSFER usb_transfer_write_mem;
 #endif
 #endif
-	
+
 	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt);
-	u8 *cnxt;	
+	u8 *cnxt;
 
-#ifdef PLATFORM_OS_XP	
+#ifdef PLATFORM_OS_XP
 	PMDL pmdl;
-	PIRP  pirp; 
+	PIRP  pirp;
 
 #ifdef CONFIG_SDIO_HCI
 	PSDBUS_REQUEST_PACKET sdrp;
-#endif	
+#endif
 
-#endif	
+#endif
 
 
 };
 
 struct	intf_hdl {
 
-/*	
+#if 0
 	u32	intf_option;
 	u32	bus_status;
 	u32	do_flush;
 	u8	*adapter;
-	u8	*intf_dev;	
+	u8	*intf_dev;
 	struct intf_priv	*pintfpriv;
 	u8	cnt;
 	void (*intf_hdl_init)(u8 *priv);
@@ -185,12 +180,12 @@ struct	intf_hdl {
 	void (*intf_hdl_open)(u8 *priv);
 	void (*intf_hdl_close)(u8 *priv);
 	struct	_io_ops	io_ops;
-	//u8 intf_status;//moved to struct intf_priv
+	/* u8 intf_status;//moved to struct intf_priv */
 	u16 len;
-	u16 done_len;	
-*/
+	u16 done_len;
+#endif
 	_adapter *padapter;
-	struct dvobj_priv *pintf_dev;//	pointer to &(padapter->dvobjpriv);
+	struct dvobj_priv *pintf_dev;/*	pointer to &(padapter->dvobjpriv); */
 
 	struct _io_ops	io_ops;
 
@@ -198,110 +193,110 @@ struct	intf_hdl {
 
 struct reg_protocol_rd {
 
-#ifdef CONFIG_LITTLE_ENDIAN	
+#ifdef CONFIG_LITTLE_ENDIAN
 
-	//DW1
+	/* DW1 */
 	u32		NumOfTrans:4;
 	u32		Reserved1:4;
 	u32		Reserved2:24;
-	//DW2
+	/* DW2 */
 	u32		ByteCount:7;
-	u32		WriteEnable:1;		//0:read, 1:write
-	u32		FixOrContinuous:1;	//0:continuous, 1: Fix
+	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
+	/* DW3 */
 	u32		BusAddress;
-	//DW4
-	//u32		Value;
+	/* DW4 */
+	/* u32		Value; */
 #else
 
 
-//DW1
-	u32 Reserved1  :4;
-	u32 NumOfTrans :4;	
+	/* DW1 */
+	u32 Reserved1:4;
+	u32 NumOfTrans:4;
 
-	u32 Reserved2  :24;	
+	u32 Reserved2:24;
 
-	//DW2
-	u32 WriteEnable : 1;
-	u32 ByteCount :7;	
+	/* DW2 */
+	u32 WriteEnable:1;
+	u32 ByteCount:7;
 
 
-	u32 Reserved3 : 3;
-	u32 Byte4Access : 1;	
+	u32 Reserved3:3;
+	u32 Byte4Access:1;
 
-	u32 Byte2Access : 1;
-	u32 Byte1Access : 1;	
-	u32 BurstMode :1 ;	
-	u32 FixOrContinuous : 1;	
+	u32 Byte2Access:1;
+	u32 Byte1Access:1;
+	u32 BurstMode:1;
+	u32 FixOrContinuous:1;
 
-	u32 Reserved4 : 16;
+	u32 Reserved4:16;
 
-	//DW3
+	/* DW3 */
 	u32		BusAddress;
 
-	//DW4
-	//u32		Value;
+	/* DW4 */
+	/* u32		Value; */
 
 #endif
-	
+
 };
 
 
 struct reg_protocol_wt {
-	
+
 
 #ifdef CONFIG_LITTLE_ENDIAN
 
-	//DW1
+	/* DW1 */
 	u32		NumOfTrans:4;
 	u32		Reserved1:4;
 	u32		Reserved2:24;
-	//DW2
+	/* DW2 */
 	u32		ByteCount:7;
-	u32		WriteEnable:1;		//0:read, 1:write
-	u32		FixOrContinuous:1;	//0:continuous, 1: Fix
+	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
+	/* DW3 */
 	u32		BusAddress;
-	//DW4
+	/* DW4 */
 	u32		Value;
 
 #else
-	//DW1
-	u32 Reserved1  :4;
-	u32 NumOfTrans :4;	
+	/* DW1 */
+	u32 Reserved1:4;
+	u32 NumOfTrans:4;
+
+	u32 Reserved2:24;
 
-	u32 Reserved2  :24;	
+	/* DW2 */
+	u32 WriteEnable:1;
+	u32 ByteCount:7;
 
-	//DW2
-	u32 WriteEnable : 1;
-	u32 ByteCount :7;	
-		
-	u32 Reserved3 : 3;
-	u32 Byte4Access : 1;	
+	u32 Reserved3:3;
+	u32 Byte4Access:1;
 
-	u32 Byte2Access : 1;
-	u32 Byte1Access : 1;	
-	u32 BurstMode :1 ;	
-	u32 FixOrContinuous : 1;	
+	u32 Byte2Access:1;
+	u32 Byte1Access:1;
+	u32 BurstMode:1;
+	u32 FixOrContinuous:1;
 
-	u32 Reserved4 : 16;
+	u32 Reserved4:16;
 
-	//DW3
+	/* DW3 */
 	u32		BusAddress;
 
-	//DW4
+	/* DW4 */
 	u32		Value;
 
 #endif
@@ -334,26 +329,26 @@ Below is the data structure used by _io_handler
 
 */
 
-struct io_queue {	
-	_lock	lock;	
-	_list  	free_ioreqs;	
-	_list		pending;		//The io_req list that will be served in the single protocol read/write.	
+struct io_queue {
+	_lock	lock;
+	_list	free_ioreqs;
+	_list		pending;		/* The io_req list that will be served in the single protocol read/write.	 */
 	_list		processing;
-	u8	*free_ioreqs_buf; // 4-byte aligned
+	u8	*free_ioreqs_buf; /* 4-byte aligned */
 	u8	*pallocated_free_ioreqs_buf;
 	struct	intf_hdl	intf;
 };
 
-struct io_priv{
-	
-	_adapter *padapter;	
-		
+struct io_priv {
+
+	_adapter *padapter;
+
 	struct intf_hdl intf;
 
 };
 
 extern uint ioreq_flush(_adapter *adapter, struct io_queue *ioqueue);
-extern void sync_ioreq_enqueue(struct io_req *preq,struct io_queue *ioqueue);
+extern void sync_ioreq_enqueue(struct io_req *preq, struct io_queue *ioqueue);
 extern uint sync_ioreq_flush(_adapter *adapter, struct io_queue *ioqueue);
 
 
@@ -413,7 +408,7 @@ extern u32 dbg_rtw_read32(_adapter *adapter, u32 addr, const char *caller, const
 extern int dbg_rtw_write8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line);
 extern int dbg_rtw_write16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line);
 extern int dbg_rtw_write32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line);
-extern int dbg_rtw_writeN(_adapter *adapter, u32 addr ,u32 length , u8 *data, const char *caller, const int line);
+extern int dbg_rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *data, const char *caller, const int line);
 
 #ifdef CONFIG_SDIO_HCI
 u8 dbg_rtw_sd_f0_read8(_adapter *adapter, u32 addr, const char *caller, const int line);
@@ -452,7 +447,7 @@ int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller
 #define rtw_sd_f0_read8(adapter, addr) dbg_rtw_sd_f0_read8((adapter), (addr), __func__, __LINE__)
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
 #define rtw_sd_iread8(adapter, addr) dbg_rtw_sd_iread8((adapter), (addr), __func__, __LINE__)
-#define rtw_sd_iread16(adapter, addr) dbg_rtw_sd_iread16((adapter), (addr), __func__, __LINE__) 
+#define rtw_sd_iread16(adapter, addr) dbg_rtw_sd_iread16((adapter), (addr), __func__, __LINE__)
 #define rtw_sd_iread32(adapter, addr) dbg_rtw_sd_iread32((adapter), (addr), __func__, __LINE__)
 #define rtw_sd_iwrite8(adapter, addr, val) dbg_rtw_sd_iwrite8((adapter), (addr), (val), __func__, __LINE__)
 #define rtw_sd_iwrite16(adapter, addr, val) dbg_rtw_sd_iwrite16((adapter), (addr), (val), __func__, __LINE__)
@@ -490,7 +485,7 @@ int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller
 #define rtw_sd_f0_read8(adapter, addr) _rtw_sd_f0_read8((adapter), (addr))
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
 #define rtw_sd_iread8(adapter, addr) _rtw_sd_iread8((adapter), (addr))
-#define rtw_sd_iread16(adapter, addr) _rtw_sd_iread16((adapter), (addr)) 
+#define rtw_sd_iread16(adapter, addr) _rtw_sd_iread16((adapter), (addr))
 #define rtw_sd_iread32(adapter, addr) _rtw_sd_iread32((adapter), (addr))
 #define rtw_sd_iwrite8(adapter, addr, val) _rtw_sd_iwrite8((adapter), (addr), (val))
 #define rtw_sd_iwrite16(adapter, addr, val) _rtw_sd_iwrite16((adapter), (addr), (val))
@@ -502,9 +497,9 @@ int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller
 
 extern void rtw_write_scsi(_adapter *adapter, u32 cnt, u8 *pmem);
 
-//ioreq 
+/* ioreq */
 extern void ioreq_read8(_adapter *adapter, u32 addr, u8 *pval);
-extern void ioreq_read16(_adapter *adapter, u32 addr, u16 *pval);	
+extern void ioreq_read16(_adapter *adapter, u32 addr, u16 *pval);
 extern void ioreq_read32(_adapter *adapter, u32 addr, u32 *pval);
 extern void ioreq_write8(_adapter *adapter, u32 addr, u8 val);
 extern void ioreq_write16(_adapter *adapter, u32 addr, u16 val);
@@ -512,11 +507,11 @@ extern void ioreq_write32(_adapter *adapter, u32 addr, u32 val);
 
 
 extern uint async_read8(_adapter *adapter, u32 addr, u8 *pbuff,
-	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt); 
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
 extern uint async_read16(_adapter *adapter, u32 addr,  u8 *pbuff,
-	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt); 
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
 extern uint async_read32(_adapter *adapter, u32 addr,  u8 *pbuff,
-	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt); 
+	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt), u8 *cnxt);
 
 extern void async_read_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
 extern void async_read_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
@@ -532,7 +527,7 @@ extern void async_write_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
 extern void async_write_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem);
 
 
-int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter,struct _io_ops *pops));
+int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter, struct _io_ops *pops));
 
 
 extern uint alloc_io_queue(_adapter *adapter);
@@ -540,7 +535,7 @@ extern void free_io_queue(_adapter *adapter);
 extern void async_bus_io(struct io_queue *pio_q);
 extern void bus_sync_io(struct io_queue *pio_q);
 extern u32 _ioreq2rwmem(struct io_queue *pio_q);
-extern void dev_power_down(_adapter * Adapter, u8 bpwrup);
+extern void dev_power_down(_adapter *Adapter, u8 bpwrup);
 
 /*
 #define RTL_R8(reg)		rtw_read8(padapter, reg)
@@ -560,19 +555,18 @@ extern void dev_power_down(_adapter * Adapter, u8 bpwrup);
 #define RTL_READ_BB(reg)	phy_QueryUsbBBReg(padapter, reg)
 */
 
-#define PlatformEFIOWrite1Byte(_a,_b,_c)		\
-	rtw_write8(_a,_b,_c)
-#define PlatformEFIOWrite2Byte(_a,_b,_c)		\
-	rtw_write16(_a,_b,_c)
-#define PlatformEFIOWrite4Byte(_a,_b,_c)		\
-	rtw_write32(_a,_b,_c)
-
-#define PlatformEFIORead1Byte(_a,_b)		\
-		rtw_read8(_a,_b)
-#define PlatformEFIORead2Byte(_a,_b)		\
-		rtw_read16(_a,_b)
-#define PlatformEFIORead4Byte(_a,_b)		\
-		rtw_read32(_a,_b)
-
-#endif	//_RTL8711_IO_H_
-
+#define PlatformEFIOWrite1Byte(_a, _b, _c)		\
+	rtw_write8(_a, _b, _c)
+#define PlatformEFIOWrite2Byte(_a, _b, _c)		\
+	rtw_write16(_a, _b, _c)
+#define PlatformEFIOWrite4Byte(_a, _b, _c)		\
+	rtw_write32(_a, _b, _c)
+
+#define PlatformEFIORead1Byte(_a, _b)		\
+	rtw_read8(_a, _b)
+#define PlatformEFIORead2Byte(_a, _b)		\
+	rtw_read16(_a, _b)
+#define PlatformEFIORead4Byte(_a, _b)		\
+	rtw_read32(_a, _b)
+
+#endif /* _RTL8711_IO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl.h
index 3a82c6d5a743..8621af5d444d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,18 +12,13 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_IOCTL_H_
 #define _RTW_IOCTL_H_
 
 #ifndef PLATFORM_WINDOWS
-//	00 - Success
-//	11 - Error
+/*	00 - Success
+*	11 - Error */
 #define STATUS_SUCCESS				(0x00000000L)
 #define STATUS_PENDING				(0x00000103L)
 
@@ -74,12 +70,12 @@
 #define NDIS_STATUS_SAP_IN_USE			((NDIS_STATUS)0xC0010021L)
 #define NDIS_STATUS_INVALID_ADDRESS		((NDIS_STATUS)0xC0010022L)
 #define NDIS_STATUS_VC_NOT_ACTIVATED		((NDIS_STATUS)0xC0010023L)
-#define NDIS_STATUS_DEST_OUT_OF_ORDER		((NDIS_STATUS)0xC0010024L)  // cause 27
-#define NDIS_STATUS_VC_NOT_AVAILABLE		((NDIS_STATUS)0xC0010025L)  // cause 35,45
-#define NDIS_STATUS_CELLRATE_NOT_AVAILABLE	((NDIS_STATUS)0xC0010026L)  // cause 37
-#define NDIS_STATUS_INCOMPATABLE_QOS		((NDIS_STATUS)0xC0010027L)  // cause 49
-#define NDIS_STATUS_AAL_PARAMS_UNSUPPORTED	((NDIS_STATUS)0xC0010028L)  // cause 93
-#define NDIS_STATUS_NO_ROUTE_TO_DESTINATION	((NDIS_STATUS)0xC0010029L)  // cause 3
+#define NDIS_STATUS_DEST_OUT_OF_ORDER		((NDIS_STATUS)0xC0010024L)  /* cause 27 */
+#define NDIS_STATUS_VC_NOT_AVAILABLE		((NDIS_STATUS)0xC0010025L)  /* cause 35, 45 */
+#define NDIS_STATUS_CELLRATE_NOT_AVAILABLE	((NDIS_STATUS)0xC0010026L)  /* cause 37 */
+#define NDIS_STATUS_INCOMPATABLE_QOS		((NDIS_STATUS)0xC0010027L)  /* cause 49 */
+#define NDIS_STATUS_AAL_PARAMS_UNSUPPORTED	((NDIS_STATUS)0xC0010028L)  /* cause 93 */
+#define NDIS_STATUS_NO_ROUTE_TO_DESTINATION	((NDIS_STATUS)0xC0010029L)  /* cause 3 */
 #endif /* #ifndef PLATFORM_WINDOWS */
 
 
@@ -92,7 +88,7 @@
 #endif
 
 
-// For DDK-defined OIDs
+/* For DDK-defined OIDs */
 #define OID_NDIS_SEG1	0x00010100
 #define OID_NDIS_SEG2	0x00010200
 #define OID_NDIS_SEG3	0x00020100
@@ -115,37 +111,28 @@
 #define SZ_OID_NDIS_SEG9		  24
 #define SZ_OID_NDIS_SEG10		  19
 
-// For Realtek-defined OIDs
+/* For Realtek-defined OIDs */
 #define OID_MP_SEG1		0xFF871100
 #define OID_MP_SEG2		0xFF818000
 
 #define OID_MP_SEG3		0xFF818700
 #define OID_MP_SEG4		0xFF011100
 
-#define DEBUG_OID(dbg, str)     		\
-       if((!dbg))				    			\
-      	{					    			\
-	   RT_TRACE(_module_rtl871x_ioctl_c_,_drv_info_,("%s(%d): %s", __FUNCTION__, __LINE__, str));	\
-      	}			
-
-
-enum oid_type
-{
+enum oid_type {
 	QUERY_OID,
 	SET_OID
 };
 
 struct oid_funs_node {
-	unsigned int oid_start; //the starting number for OID
-	unsigned int oid_end; //the ending number for OID
-	struct oid_obj_priv *node_array; 
-	unsigned int array_sz; //the size of node_array
-	int query_counter; //count the number of query hits for this segment  
-	int set_counter; //count the number of set hits for this segment  
+	unsigned int oid_start; /* the starting number for OID */
+	unsigned int oid_end; /* the ending number for OID */
+	struct oid_obj_priv *node_array;
+	unsigned int array_sz; /* the size of node_array */
+	int query_counter; /* count the number of query hits for this segment  */
+	int set_counter; /* count the number of set hits for this segment  */
 };
 
-struct oid_par_priv
-{
+struct oid_par_priv {
 	void		*adapter_context;
 	NDIS_OID	oid;
 	void		*information_buf;
@@ -157,16 +144,14 @@ struct oid_par_priv
 };
 
 struct oid_obj_priv {
-	unsigned char	dbg; // 0: without OID debug message  1: with OID debug message 
-	NDIS_STATUS (*oidfuns)(struct oid_par_priv *poid_par_priv);	
+	unsigned char	dbg; /* 0: without OID debug message  1: with OID debug message */
+	NDIS_STATUS(*oidfuns)(struct oid_par_priv *poid_par_priv);
 };
 
 #if (defined(CONFIG_MP_INCLUDED) && defined(_RTW_MP_IOCTL_C_)) || \
 	(defined(PLATFORM_WINDOWS) && defined(_RTW_IOCTL_RTL_C_))
-static NDIS_STATUS oid_null_function(struct oid_par_priv* poid_par_priv)
+static NDIS_STATUS oid_null_function(struct oid_par_priv *poid_par_priv)
 {
-	_func_enter_;
-	_func_exit_;
 	return NDIS_STATUS_SUCCESS;
 }
 #endif
@@ -175,131 +160,131 @@ static NDIS_STATUS oid_null_function(struct oid_par_priv* poid_par_priv)
 
 int TranslateNdisPsToRtPs(IN NDIS_802_11_POWER_MODE	ndisPsMode);
 
-//OID Handler for Segment 1
-NDIS_STATUS oid_gen_supported_list_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_hardware_status_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_media_supported_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_media_in_use_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_maximum_lookahead_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_maximum_frame_size_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_link_speed_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_transmit_buffer_space_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_receive_buffer_space_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_transmit_block_size_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_receive_block_size_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_vendor_id_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_vendor_description_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_current_packet_filter_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_current_lookahead_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_driver_version_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_maximum_total_size_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_protocol_options_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_mac_options_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_media_connect_status_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_maximum_send_packets_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_vendor_driver_version_hdl(struct oid_par_priv* poid_par_priv);
-
-
-//OID Handler for Segment 2
-NDIS_STATUS oid_gen_physical_medium_hdl(struct oid_par_priv* poid_par_priv);
-
-//OID Handler for Segment 3
-NDIS_STATUS oid_gen_xmit_ok_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_rcv_ok_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_xmit_error_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_rcv_error_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_gen_rcv_no_buffer_hdl(struct oid_par_priv* poid_par_priv);
-
-
-//OID Handler for Segment 4
-NDIS_STATUS oid_802_3_permanent_address_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_current_address_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_multicast_list_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_maximum_list_size_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_mac_options_hdl(struct oid_par_priv* poid_par_priv);
-
-
-
-//OID Handler for Segment 5
-NDIS_STATUS oid_802_3_rcv_error_alignment_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_xmit_one_collision_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_xmit_more_collisions_hdl(struct oid_par_priv* poid_par_priv);
-
-
-//OID Handler for Segment 6
-NDIS_STATUS oid_802_3_xmit_deferred_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_xmit_max_collisions_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_rcv_overrun_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_xmit_underrun_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_xmit_heartbeat_failure_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_xmit_times_crs_lost_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_3_xmit_late_collisions_hdl(struct oid_par_priv* poid_par_priv);
-
-
-
-//OID Handler for Segment 7
-NDIS_STATUS oid_pnp_capabilities_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_pnp_set_power_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_pnp_query_power_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_pnp_add_wake_up_pattern_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_pnp_remove_wake_up_pattern_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_pnp_wake_up_pattern_list_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_pnp_enable_wake_up_hdl(struct oid_par_priv* poid_par_priv);
-
-
-
-//OID Handler for Segment 8
-NDIS_STATUS oid_802_11_bssid_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_ssid_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_infrastructure_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_add_wep_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_remove_wep_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_disassociate_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_authentication_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_privacy_filter_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_bssid_list_scan_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_encryption_status_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_reload_defaults_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_add_key_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_remove_key_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_association_information_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_test_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_media_stream_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_capability_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_pmkid_hdl(struct oid_par_priv* poid_par_priv);
-
-
-
-
-
-//OID Handler for Segment 9
-NDIS_STATUS oid_802_11_network_types_supported_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_network_type_in_use_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_tx_power_level_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_rssi_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_rssi_trigger_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_fragmentation_threshold_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_rts_threshold_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_number_of_antennas_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_rx_antenna_selected_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_tx_antenna_selected_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_supported_rates_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_desired_rates_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_configuration_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_power_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_802_11_bssid_list_hdl(struct oid_par_priv* poid_par_priv);
-
-
-//OID Handler for Segment 10
-NDIS_STATUS oid_802_11_statistics_hdl(struct oid_par_priv* poid_par_priv);
+/* OID Handler for Segment 1 */
+NDIS_STATUS oid_gen_supported_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_hardware_status_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_media_supported_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_media_in_use_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_lookahead_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_frame_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_link_speed_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_transmit_buffer_space_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_receive_buffer_space_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_transmit_block_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_receive_block_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_vendor_id_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_vendor_description_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_current_packet_filter_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_current_lookahead_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_driver_version_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_total_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_protocol_options_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_mac_options_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_media_connect_status_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_maximum_send_packets_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_vendor_driver_version_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 2 */
+NDIS_STATUS oid_gen_physical_medium_hdl(struct oid_par_priv *poid_par_priv);
+
+/* OID Handler for Segment 3 */
+NDIS_STATUS oid_gen_xmit_ok_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_rcv_ok_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_xmit_error_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_rcv_error_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_gen_rcv_no_buffer_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 4 */
+NDIS_STATUS oid_802_3_permanent_address_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_current_address_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_multicast_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_maximum_list_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_mac_options_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+/* OID Handler for Segment 5 */
+NDIS_STATUS oid_802_3_rcv_error_alignment_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_one_collision_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_more_collisions_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 6 */
+NDIS_STATUS oid_802_3_xmit_deferred_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_max_collisions_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_rcv_overrun_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_underrun_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_heartbeat_failure_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_times_crs_lost_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_3_xmit_late_collisions_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+/* OID Handler for Segment 7 */
+NDIS_STATUS oid_pnp_capabilities_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_set_power_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_query_power_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_add_wake_up_pattern_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_remove_wake_up_pattern_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_wake_up_pattern_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_pnp_enable_wake_up_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+/* OID Handler for Segment 8 */
+NDIS_STATUS oid_802_11_bssid_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_ssid_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_infrastructure_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_add_wep_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_remove_wep_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_disassociate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_authentication_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_privacy_filter_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_bssid_list_scan_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_encryption_status_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_reload_defaults_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_add_key_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_remove_key_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_association_information_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_test_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_media_stream_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_capability_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_pmkid_hdl(struct oid_par_priv *poid_par_priv);
+
+
+
+
+
+/* OID Handler for Segment 9 */
+NDIS_STATUS oid_802_11_network_types_supported_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_network_type_in_use_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_tx_power_level_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rssi_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rssi_trigger_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_fragmentation_threshold_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rts_threshold_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_number_of_antennas_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_rx_antenna_selected_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_tx_antenna_selected_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_supported_rates_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_desired_rates_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_configuration_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_power_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_802_11_bssid_list_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* OID Handler for Segment 10 */
+NDIS_STATUS oid_802_11_statistics_hdl(struct oid_par_priv *poid_par_priv);
 
 
-//OID Handler for Segment ED 
-NDIS_STATUS oid_rt_mh_vender_id_hdl(struct oid_par_priv* poid_par_priv);
+/* OID Handler for Segment ED */
+NDIS_STATUS oid_rt_mh_vender_id_hdl(struct oid_par_priv *poid_par_priv);
 
 void Set_802_3_MULTICAST_LIST(ADAPTER *pAdapter, UCHAR *MCListbuf, ULONG MCListlen, BOOLEAN bAcceptAllMulticast);
 
-#endif// end of PLATFORM_WINDOWS
+#endif/* end of PLATFORM_WINDOWS */
 
 #if defined(PLATFORM_LINUX) && defined(CONFIG_WIRELESS_EXT)
 extern struct iw_handler_def  rtw_handlers_def;
@@ -310,20 +295,26 @@ extern void rtw_request_wps_pbc_event(_adapter *padapter);
 extern	NDIS_STATUS drv_query_info(
 	IN	_nic_hdl		MiniportAdapterContext,
 	IN	NDIS_OID		Oid,
-	IN	void *			InformationBuffer,
+	IN	void			*InformationBuffer,
 	IN	u32			InformationBufferLength,
-	OUT	u32*			BytesWritten,
-	OUT	u32*			BytesNeeded
-	);
+	OUT	u32			*BytesWritten,
+	OUT	u32			*BytesNeeded
+);
 
-extern	NDIS_STATUS 	drv_set_info(
+extern	NDIS_STATUS	drv_set_info(
 	IN	_nic_hdl		MiniportAdapterContext,
 	IN	NDIS_OID		Oid,
-	IN	void *			InformationBuffer,
+	IN	void			*InformationBuffer,
 	IN	u32			InformationBufferLength,
-	OUT	u32*			BytesRead,
-	OUT	u32*			BytesNeeded
-	);
-
-#endif // #ifndef __INC_CEINFO_
+	OUT	u32			*BytesRead,
+	OUT	u32			*BytesNeeded
+);
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+extern int rtw_vendor_ie_get_raw_data(struct net_device *, u32, char *, u32);
+extern int rtw_vendor_ie_get_data(struct net_device*, int , char*);
+extern int rtw_vendor_ie_get(struct net_device *, struct iw_request_info *, union iwreq_data *, char *);
+extern int rtw_vendor_ie_set(struct net_device*, struct iw_request_info*, union iwreq_data*, char*);
+#endif
 
+#endif /*  #ifndef __INC_CEINFO_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_query.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_query.h
index d91d35f99067..549ee371591c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_query.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_query.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,23 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_IOCTL_QUERY_H_
 #define _RTW_IOCTL_QUERY_H_
 
 
 #ifdef PLATFORM_WINDOWS
-
-u8 query_802_11_capability(_adapter*	padapter,u8*	pucBuf,u32 *	pulOutLen);
-u8 query_802_11_association_information (_adapter * padapter, PNDIS_802_11_ASSOCIATION_INFORMATION pAssocInfo);
-
+u8 query_802_11_capability(_adapter	*padapter, u8 *pucBuf, u32 *pulOutLen);
+u8 query_802_11_association_information(_adapter *padapter, PNDIS_802_11_ASSOCIATION_INFORMATION pAssocInfo);
 #endif
 
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_rtl.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_rtl.h
index a1b3491f59ad..f3e0bbeb9389 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_rtl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_rtl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,71 +12,65 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_IOCTL_RTL_H_
 #define _RTW_IOCTL_RTL_H_
 
 
-//************** oid_rtl_seg_01_01 ************** 
-NDIS_STATUS oid_rt_get_signal_quality_hdl(struct oid_par_priv* poid_par_priv);//84
-NDIS_STATUS oid_rt_get_small_packet_crc_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_middle_packet_crc_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_large_packet_crc_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_tx_retry_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_rx_retry_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_rx_total_packet_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_tx_beacon_ok_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_tx_beacon_err_hdl(struct oid_par_priv* poid_par_priv);
+/* ************** oid_rtl_seg_01_01 ************** */
+NDIS_STATUS oid_rt_get_signal_quality_hdl(struct oid_par_priv *poid_par_priv);/* 84 */
+NDIS_STATUS oid_rt_get_small_packet_crc_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_middle_packet_crc_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_large_packet_crc_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_tx_retry_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_rx_retry_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_rx_total_packet_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_tx_beacon_ok_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_tx_beacon_err_hdl(struct oid_par_priv *poid_par_priv);
 
-NDIS_STATUS oid_rt_pro_set_fw_dig_state_hdl(struct oid_par_priv* poid_par_priv);	//8a
-NDIS_STATUS oid_rt_pro_set_fw_ra_state_hdl(struct oid_par_priv* poid_par_priv);	//8b
+NDIS_STATUS oid_rt_pro_set_fw_dig_state_hdl(struct oid_par_priv *poid_par_priv);	/* 8a */
+NDIS_STATUS oid_rt_pro_set_fw_ra_state_hdl(struct oid_par_priv *poid_par_priv);	/* 8b */
 
-NDIS_STATUS oid_rt_get_rx_icv_err_hdl(struct oid_par_priv* poid_par_priv);//93
-NDIS_STATUS oid_rt_set_encryption_algorithm_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_preamble_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_ap_ip_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_channelplan_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_set_channelplan_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_set_preamble_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_set_bcn_intvl_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_dedicate_probe_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_total_tx_bytes_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_total_rx_bytes_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_current_tx_power_level_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_enc_key_mismatch_count_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_enc_key_match_count_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_channel_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_hardware_radio_off_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_key_mismatch_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_supported_wireless_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_channel_list_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_scan_in_progress_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_forced_data_rate_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_wireless_mode_for_scan_list_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_bss_wireless_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_scan_with_magic_packet_hdl(struct oid_par_priv* poid_par_priv);
+NDIS_STATUS oid_rt_get_rx_icv_err_hdl(struct oid_par_priv *poid_par_priv);/* 93 */
+NDIS_STATUS oid_rt_set_encryption_algorithm_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_preamble_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_ap_ip_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_channelplan_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_channelplan_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_preamble_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_bcn_intvl_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_dedicate_probe_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_total_tx_bytes_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_total_rx_bytes_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_current_tx_power_level_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_enc_key_mismatch_count_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_enc_key_match_count_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_channel_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_hardware_radio_off_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_key_mismatch_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_supported_wireless_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_channel_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_scan_in_progress_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_forced_data_rate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_wireless_mode_for_scan_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_bss_wireless_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_scan_with_magic_packet_hdl(struct oid_par_priv *poid_par_priv);
 
-//**************  oid_rtl_seg_01_03 section start ************** 
-NDIS_STATUS oid_rt_ap_get_associated_station_list_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_ap_switch_into_ap_mode_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_ap_supported_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_ap_set_passphrase_hdl(struct oid_par_priv* poid_par_priv);
+/* **************  oid_rtl_seg_01_03 section start ************** */
+NDIS_STATUS oid_rt_ap_get_associated_station_list_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_ap_switch_into_ap_mode_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_ap_supported_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_ap_set_passphrase_hdl(struct oid_par_priv *poid_par_priv);
 
-// oid_rtl_seg_01_11 
-NDIS_STATUS oid_rt_pro_rf_write_registry_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_rf_read_registry_hdl(struct oid_par_priv* poid_par_priv);
+/* oid_rtl_seg_01_11 */
+NDIS_STATUS oid_rt_pro_rf_write_registry_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_rf_read_registry_hdl(struct oid_par_priv *poid_par_priv);
 
-//**************  oid_rtl_seg_03_00 section start **************  
-NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_set_default_key_id_hdl(struct oid_par_priv* poid_par_priv);
+/* **************  oid_rtl_seg_03_00 section start **************  */
+NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_default_key_id_hdl(struct oid_par_priv *poid_par_priv);
 
 
 
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_set.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_set.h
index 1b7184688dc4..d8688ac5bd51 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_set.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_ioctl_set.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_IOCTL_SET_H_
 #define __RTW_IOCTL_SET_H_
 
@@ -39,29 +35,26 @@ typedef struct _NDIS_802_11_PMKID {
 
 
 #ifdef PLATFORM_WINDOWS
-u8 rtw_set_802_11_reload_defaults(_adapter * padapter, NDIS_802_11_RELOAD_DEFAULTS reloadDefaults);
-u8 rtw_set_802_11_test(_adapter * padapter, NDIS_802_11_TEST * test);
+u8 rtw_set_802_11_reload_defaults(_adapter *padapter, NDIS_802_11_RELOAD_DEFAULTS reloadDefaults);
+u8 rtw_set_802_11_test(_adapter *padapter, NDIS_802_11_TEST *test);
 u8 rtw_set_802_11_pmkid(_adapter *pdapter, NDIS_802_11_PMKID *pmkid);
 
-u8 rtw_pnp_set_power_sleep(_adapter* padapter);
-u8 rtw_pnp_set_power_wakeup(_adapter* padapter);
+u8 rtw_pnp_set_power_sleep(_adapter *padapter);
+u8 rtw_pnp_set_power_wakeup(_adapter *padapter);
 
 void rtw_pnp_resume_wk(void *context);
-void rtw_pnp_sleep_wk(void * context);
+void rtw_pnp_sleep_wk(void *context);
 
 #endif
 
-u8 rtw_set_802_11_add_key(_adapter * padapter, NDIS_802_11_KEY * key);
 u8 rtw_set_802_11_authentication_mode(_adapter *pdapter, NDIS_802_11_AUTHENTICATION_MODE authmode);
-u8 rtw_set_802_11_bssid(_adapter* padapter, u8 *bssid);
-u8 rtw_set_802_11_add_wep(_adapter * padapter, NDIS_802_11_WEP * wep);
-u8 rtw_set_802_11_disassociate(_adapter * padapter);
-u8 rtw_set_802_11_bssid_list_scan(_adapter* padapter, NDIS_802_11_SSID *pssid, int ssid_max_num);
-u8 rtw_set_802_11_infrastructure_mode(_adapter * padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype);
-u8 rtw_set_802_11_remove_wep(_adapter * padapter, u32 keyindex);
-u8 rtw_set_802_11_ssid(_adapter * padapter, NDIS_802_11_SSID * ssid);
-u8 rtw_set_802_11_connect(_adapter* padapter, u8 *bssid, NDIS_802_11_SSID *ssid);
-u8 rtw_set_802_11_remove_key(_adapter * padapter, NDIS_802_11_REMOVE_KEY * key);
+u8 rtw_set_802_11_bssid(_adapter *padapter, u8 *bssid);
+u8 rtw_set_802_11_add_wep(_adapter *padapter, NDIS_802_11_WEP *wep);
+u8 rtw_set_802_11_disassociate(_adapter *padapter);
+u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, struct sitesurvey_parm *pparm);
+u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype);
+u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid);
+u8 rtw_set_802_11_connect(_adapter *padapter, u8 *bssid, NDIS_802_11_SSID *ssid);
 
 u8 rtw_validate_bssid(u8 *bssid);
 u8 rtw_validate_ssid(NDIS_802_11_SSID *ssid);
@@ -73,4 +66,3 @@ int rtw_set_country(_adapter *adapter, const char *country_code);
 int rtw_set_band(_adapter *adapter, u8 band);
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_iol.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_iol.h
index ddabeacc35b7..21e1af8a61ed 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_iol.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_iol.h
@@ -1,137 +1,132 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTW_IOL_H_
-#define __RTW_IOL_H_
-
-
-struct xmit_frame	*rtw_IOL_accquire_xmit_frame(ADAPTER *adapter);
-int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len);
-int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary);
-int rtw_IOL_exec_cmds_sync(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
-bool rtw_IOL_applied(ADAPTER *adapter);
-int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us);
-int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms);
-int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame);
-
-
-#ifdef CONFIG_IOL_NEW_GENERATION
-#define IOREG_CMD_END_LEN	4
-
-struct ioreg_cfg{
-	u8 	length;
-	u8 	cmd_id;
-	u16 	address;
-	u32	data;
-	u32  mask;
-};
-enum ioreg_cmd{
-	IOREG_CMD_LLT 			= 0x01,
-	IOREG_CMD_REFUSE 		= 0x02,
-	IOREG_CMD_EFUSE_PATH = 0x03,
-	IOREG_CMD_WB_REG		= 0x04,
-	IOREG_CMD_WW_REG	= 0x05,
-	IOREG_CMD_WD_REG 	= 0x06,
-	IOREG_CMD_W_RF 		= 0x07,
-	IOREG_CMD_DELAY_US 	= 0x10,
-	IOREG_CMD_DELAY_MS	= 0x11,
-	IOREG_CMD_END 		= 0xFF,		
-};
-void read_efuse_from_txpktbuf(ADAPTER *adapter, int bcnhead, u8 *content, u16 *size);
-
-int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, u8 mask);
-int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, u16 mask);
-int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, u32 mask);
-int _rtw_IOL_append_WRF_cmd(struct xmit_frame *xmit_frame, u8 rf_path, u16 addr, u32 value, u32 mask);
-#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value,mask) _rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value) ,(mask))
-#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value,mask) _rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value),(mask))
-#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value,mask) _rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value),(mask))
-#define rtw_IOL_append_WRF_cmd(xmit_frame, rf_path, addr, value,mask) _rtw_IOL_append_WRF_cmd((xmit_frame),(rf_path), (addr), (value),(mask))
-
-u8 rtw_IOL_cmd_boundary_handle(struct xmit_frame *pxmit_frame);
-void  rtw_IOL_cmd_buf_dump(ADAPTER *Adapter,int buf_len,u8 *pbuf);
-
-#ifdef CONFIG_IOL_IOREG_CFG_DBG
-	struct cmd_cmp{
-		u16 addr;
-		u32 value;
-	};
-#endif
-
-#else //CONFIG_IOL_NEW_GENERATION
-
-typedef struct _io_offload_cmd {
-	u8 rsvd0;
-	u8 cmd;
-	u16 address;
-	u32 value;
-} IO_OFFLOAD_CMD, IOL_CMD;
-
-#define IOL_CMD_LLT			0x00
-//#define IOL_CMD_R_EFUSE	0x01
-#define IOL_CMD_WB_REG		0x02
-#define IOL_CMD_WW_REG 	0x03
-#define IOL_CMD_WD_REG		0x04
-//#define IOL_CMD_W_RF		0x05
-#define IOL_CMD_DELAY_US	0x80
-#define IOL_CMD_DELAY_MS	0x81
-//#define IOL_CMD_DELAY_S	0x82
-#define IOL_CMD_END			0x83
-
-/*****************************************************
-CMD					Address			Value
-(B1)					(B2/B3:H/L addr)	(B4:B7 : MSB:LSB)
-******************************************************
-IOL_CMD_LLT			-				B7: PGBNDY
-//IOL_CMD_R_EFUSE	-				-
-IOL_CMD_WB_REG		0x0~0xFFFF		B7
-IOL_CMD_WW_REG	0x0~0xFFFF		B6~B7
-IOL_CMD_WD_REG	0x0~0xFFFF		B4~B7
-//IOL_CMD_W_RF		RF Reg			B5~B7
-IOL_CMD_DELAY_US	-				B6~B7
-IOL_CMD_DELAY_MS	-				B6~B7
-//IOL_CMD_DELAY_S	-				B6~B7
-IOL_CMD_END		-				-
-******************************************************/
-int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value);
-int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value);
-int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value);
-
-
-int rtw_IOL_exec_cmd_array_sync(PADAPTER adapter, u8 *IOL_cmds, u32 cmd_num, u32 max_wating_ms);
-int rtw_IOL_exec_empty_cmds_sync(ADAPTER *adapter, u32 max_wating_ms);
-
-#ifdef DBG_IO
-int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line);
-int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line);
-int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line);
-#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
-#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
-#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
-#else
-#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value) _rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value))
-#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value) _rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value))
-#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value) _rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value))
-#endif // DBG_IO
-#endif // CONFIG_IOL_NEW_GENERATION
-
-
-
-#endif //__RTW_IOL_H_
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_IOL_H_
+#define __RTW_IOL_H_
+
+
+struct xmit_frame	*rtw_IOL_accquire_xmit_frame(ADAPTER *adapter);
+int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len);
+int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary);
+int rtw_IOL_exec_cmds_sync(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
+bool rtw_IOL_applied(ADAPTER *adapter);
+int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us);
+int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms);
+int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame);
+
+
+#ifdef CONFIG_IOL_NEW_GENERATION
+#define IOREG_CMD_END_LEN	4
+
+struct ioreg_cfg {
+	u8	length;
+	u8	cmd_id;
+	u16	address;
+	u32	data;
+	u32  mask;
+};
+enum ioreg_cmd {
+	IOREG_CMD_LLT			= 0x01,
+	IOREG_CMD_REFUSE		= 0x02,
+	IOREG_CMD_EFUSE_PATH = 0x03,
+	IOREG_CMD_WB_REG		= 0x04,
+	IOREG_CMD_WW_REG	= 0x05,
+	IOREG_CMD_WD_REG	= 0x06,
+	IOREG_CMD_W_RF		= 0x07,
+	IOREG_CMD_DELAY_US	= 0x10,
+	IOREG_CMD_DELAY_MS	= 0x11,
+	IOREG_CMD_END		= 0xFF,
+};
+void read_efuse_from_txpktbuf(ADAPTER *adapter, int bcnhead, u8 *content, u16 *size);
+
+int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, u8 mask);
+int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, u16 mask);
+int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, u32 mask);
+int _rtw_IOL_append_WRF_cmd(struct xmit_frame *xmit_frame, u8 rf_path, u16 addr, u32 value, u32 mask);
+#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value, mask) _rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value), (mask))
+#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value, mask) _rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value), (mask))
+#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value, mask) _rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value), (mask))
+#define rtw_IOL_append_WRF_cmd(xmit_frame, rf_path, addr, value, mask) _rtw_IOL_append_WRF_cmd((xmit_frame), (rf_path), (addr), (value), (mask))
+
+u8 rtw_IOL_cmd_boundary_handle(struct xmit_frame *pxmit_frame);
+void  rtw_IOL_cmd_buf_dump(ADAPTER *Adapter, int buf_len, u8 *pbuf);
+
+#ifdef CONFIG_IOL_IOREG_CFG_DBG
+struct cmd_cmp {
+	u16 addr;
+	u32 value;
+};
+#endif
+
+#else /* CONFIG_IOL_NEW_GENERATION */
+
+typedef struct _io_offload_cmd {
+	u8 rsvd0;
+	u8 cmd;
+	u16 address;
+	u32 value;
+} IO_OFFLOAD_CMD, IOL_CMD;
+
+#define IOL_CMD_LLT			0x00
+/* #define IOL_CMD_R_EFUSE	0x01 */
+#define IOL_CMD_WB_REG		0x02
+#define IOL_CMD_WW_REG	0x03
+#define IOL_CMD_WD_REG		0x04
+/* #define IOL_CMD_W_RF		0x05 */
+#define IOL_CMD_DELAY_US	0x80
+#define IOL_CMD_DELAY_MS	0x81
+/* #define IOL_CMD_DELAY_S	0x82 */
+#define IOL_CMD_END			0x83
+
+/*****************************************************
+CMD					Address			Value
+(B1)					(B2/B3:H/L addr)	(B4:B7 : MSB:LSB)
+******************************************************
+IOL_CMD_LLT			-				B7: PGBNDY
+IOL_CMD_R_EFUSE	-				-
+IOL_CMD_WB_REG		0x0~0xFFFF		B7
+IOL_CMD_WW_REG	0x0~0xFFFF		B6~B7
+IOL_CMD_WD_REG	0x0~0xFFFF		B4~B7
+IOL_CMD_W_RF		RF Reg			B5~B7
+IOL_CMD_DELAY_US	-				B6~B7
+IOL_CMD_DELAY_MS	-				B6~B7
+IOL_CMD_DELAY_S	-				B6~B7
+IOL_CMD_END		-				-
+******************************************************/
+int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value);
+int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value);
+int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value);
+
+
+int rtw_IOL_exec_cmd_array_sync(PADAPTER adapter, u8 *IOL_cmds, u32 cmd_num, u32 max_wating_ms);
+int rtw_IOL_exec_empty_cmds_sync(ADAPTER *adapter, u32 max_wating_ms);
+
+#ifdef DBG_IO
+int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line);
+int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line);
+int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line);
+#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
+#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
+#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value) dbg_rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value), __FUNCTION__, __LINE__)
+#else
+#define rtw_IOL_append_WB_cmd(xmit_frame, addr, value) _rtw_IOL_append_WB_cmd((xmit_frame), (addr), (value))
+#define rtw_IOL_append_WW_cmd(xmit_frame, addr, value) _rtw_IOL_append_WW_cmd((xmit_frame), (addr), (value))
+#define rtw_IOL_append_WD_cmd(xmit_frame, addr, value) _rtw_IOL_append_WD_cmd((xmit_frame), (addr), (value))
+#endif /* DBG_IO */
+#endif /* CONFIG_IOL_NEW_GENERATION */
+
+
+
+#endif /* __RTW_IOL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mcc.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mcc.h
new file mode 100644
index 000000000000..25ccf6b82aba
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mcc.h
@@ -0,0 +1,270 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+#ifdef CONFIG_MCC_MODE
+
+#ifndef _RTW_MCC_H_
+#define _RTW_MCC_H_
+
+#include <drv_types.h> /* PADAPTER */
+
+#define MCC_STATUS_PROCESS_MCC_START_SETTING BIT0
+#define MCC_STATUS_PROCESS_MCC_STOP_SETTING BIT1
+#define MCC_STATUS_NEED_MCC BIT2
+#define MCC_STATUS_DOING_MCC BIT3
+
+
+#define MCC_SWCH_FW_EARLY_TIME 10 /* ms */
+#define MCC_EXPIRE_TIME 50 /* ms */
+#define MCC_TOLERANCE_TIME 2 /* 2*2 = 4s */
+#define MCC_UPDATE_PARAMETER_THRESHOLD 5 /* ms */
+
+#define MCC_ROLE_STA_GC_MGMT_QUEUE_MACID 0
+#define MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID 1
+
+/* Lower for stop, Higher for start */
+#define MCC_SETCMD_STATUS_STOP_DISCONNECT 0x0
+#define MCC_SETCMD_STATUS_STOP_SCAN_START 0x1
+#define MCC_SETCMD_STATUS_START_CONNECT 0x80
+#define MCC_SETCMD_STATUS_START_SCAN_DONE 0x81
+
+/*
+* depenad platform or customer requirement(TP unit:Mbps),
+* must be provided by PM or sales or product document
+* too large value means not to limit tx bytes (current for ap mode)
+* NOTE: following values ref from test results
+*/
+#define MCC_AP_BW20_TARGET_TX_TP (300)
+#define MCC_AP_BW40_TARGET_TX_TP (300)
+#define MCC_AP_BW80_TARGET_TX_TP (300)
+#define MCC_STA_BW20_TARGET_TX_TP (35)
+#define MCC_STA_BW40_TARGET_TX_TP (70)
+#define MCC_STA_BW80_TARGET_TX_TP (140)
+#define MCC_SINGLE_TX_CRITERIA 5 /* Mbps */
+
+#define MAX_MCC_NUM 2
+
+#define MCC_STOP(adapter) (adapter->mcc_adapterpriv.mcc_tx_stop)
+#define MCC_EN(adapter) (adapter_to_dvobj(adapter)->mcc_objpriv.en_mcc)
+#define SET_MCC_EN_FLAG(adapter, flag)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.en_mcc = (flag); \
+	} while (0)
+#define SET_MCC_DURATION(adapter, val)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.duration = (val); \
+	} while (0)
+#define SET_MCC_RUNTIME_DURATION(adapter, flag)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.enable_runtime_duration = (flag); \
+	} while (0)
+/* Represent Channel Tx Null setting */
+enum mcc_channel_tx_null {
+	MCC_ENABLE_TX_NULL = 0,
+	MCC_DISABLE_TX_NULL = 1,
+};
+
+/* Represent C2H Report setting */
+enum mcc_c2h_report {
+	MCC_C2H_REPORT_DISABLE = 0,
+	MCC_C2H_REPORT_FAIL_STATUS = 1,
+	MCC_C2H_REPORT_ALL_STATUS = 2,
+};
+
+/* Represent Channel Scan */
+enum mcc_channel_scan {
+	MCC_CHIDX = 0,
+	MCC_SCANCH_RSVD_LOC = 1,
+};
+
+/* Represent FW status report of channel switch */
+enum mcc_status_rpt {
+	MCC_RPT_SUCCESS = 0,
+	MCC_RPT_TXNULL_FAIL = 1,
+	MCC_RPT_STOPMCC = 2,
+	MCC_RPT_READY = 3,
+	MCC_RPT_SWICH_CHANNEL_NOTIFY = 7,
+	MCC_RPT_UPDATE_NOA_START_TIME = 8,
+	MCC_RPT_TSF = 9,
+	MCC_RPT_MAX,
+};
+
+enum MCC_ROLE {
+	MCC_ROLE_STA = 0,
+	MCC_ROLE_AP = 1,
+	MCC_ROLE_GC = 2,
+	MCC_ROLE_GO = 3,
+	MCC_ROLE_MAX,
+};
+
+struct mcc_iqk_backup {
+	u16 TX_X;
+	u16 TX_Y;
+	u16 RX_X;
+	u16 RX_Y;
+};
+
+enum MCC_DURATION_SETTING {
+	MCC_DURATION_MAPPING = 0,
+	MCC_DURATION_DIRECET = 1,
+};
+
+enum MCC_SCHED_MODE {
+	MCC_FAIR_SCHEDULE = 0,
+	MCC_FAVOE_STA = 1,
+	MCC_FAVOE_P2P = 2,
+};
+
+/*  mcc data for adapter */
+struct mcc_adapter_priv {
+	u8 order;		/* FW document, softap/AP must be 0 */
+	u8 role;			/* MCC role(AP,STA,GO,GC) */
+	u8 mcc_duration; /* channel stay period, UNIT:1TU */
+
+	/* flow control */
+	u8 mcc_tx_stop;				/* check if tp stop or not */
+	u8 mcc_tp_limit;				/* check if tp limit or not */
+	u32 mcc_target_tx_bytes_to_port;		/* customer require  */
+	u32 mcc_tx_bytes_to_port;	/* already tx to tx fifo (write port) */
+
+	/* data from kernel to check if enqueue data or netif stop queue */
+	u32 mcc_tp;
+	u64 mcc_tx_bytes_from_kernel;
+	u64 mcc_last_tx_bytes_from_kernel;
+
+	/* Backup IQK value for MCC */
+	struct mcc_iqk_backup mcc_iqk_arr[MAX_RF_PATH];
+
+	/* mgmt queue macid to avoid RA issue */
+	u8 mgmt_queue_macid;
+
+	/* set macid bitmap to let fw know which macid should be tx pause */
+	/* all interface share total 16 macid */
+	u16 mcc_macid_bitmap;
+
+	/* use for NoA start time (unit: mircoseconds) */
+	u32 noa_start_time;
+
+	u8 p2p_go_noa_ie[MAX_P2P_IE_LEN];
+	u32 p2p_go_noa_ie_len;
+	u64 tsf;
+#ifdef CONFIG_TDLS
+	u8 backup_tdls_en;
+#endif /* CONFIG_TDLS */
+
+	u8 null_early;
+	u8 null_rty_num;
+};
+
+struct mcc_obj_priv {
+	u8 en_mcc; /* enable MCC or not */
+	u8 duration; /* store duration(%) from registry, for primary adapter */
+	u8 interval;
+	u8 start_time;
+	u8 mcc_c2h_status;
+	u8 cur_mcc_success_cnt; /* used for check mcc switch channel success */
+	u8 prev_mcc_success_cnt; /* used for check mcc switch channel success */
+	u8 mcc_tolerance_time; /* used for detect mcc switch channel success */
+	u8 mcc_loc_rsvd_paga[MAX_MCC_NUM];  /* mcc rsvd page */
+	u8 mcc_status; /* mcc status stop or start .... */
+	u8 policy_index;
+	u8 mcc_stop_threshold;
+	u8 current_order;
+	u8 last_tsfdiff;
+	u32 mcc_launch_time; /* mcc launch time, used for starting detect mcc switch channel success */
+	_mutex mcc_mutex;
+	_lock mcc_lock;
+	PADAPTER iface[MAX_MCC_NUM]; /* by order, use for mcc parameter cmd */
+	struct submit_ctx mcc_sctx;
+	struct submit_ctx mcc_tsf_req_sctx;
+#ifdef CONFIG_MCC_MODE_V2
+	u8 mcc_iqk_value_rsvd_page[3];
+#endif /* CONFIG_MCC_MODE_V2 */
+	u8 mcc_pwr_idx_rsvd_page[MAX_MCC_NUM];
+	u8 enable_runtime_duration;
+	u32 backup_phydm_ability;
+	/* for LG */
+	u8 mchan_sched_mode;
+};
+
+/* backup IQK val */
+void rtw_hal_mcc_restore_iqk_val(PADAPTER padapter);
+
+/* check mcc status */
+u8 rtw_hal_check_mcc_status(PADAPTER padapter, u8 mcc_status);
+
+/* set mcc status */
+void rtw_hal_set_mcc_status(PADAPTER padapter, u8 mcc_status);
+
+/* clear mcc status */
+void rtw_hal_clear_mcc_status(PADAPTER padapter, u8 mcc_status);
+
+/* dl mcc rsvd page */
+u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index
+	, u8 tx_desc, u32 page_size, u8 *total_page_num, RSVDPAGE_LOC *rsvd_page_loc, u8 *page_num);
+
+/* handle C2H */
+void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf);
+
+/* switch channel successfully or not */
+void rtw_hal_mcc_sw_status_check(PADAPTER padapter);
+
+/* change some scan flags under site survey */
+u8 rtw_hal_mcc_change_scan_flag(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset);
+
+/* record data kernel TX to driver to check MCC concurrent TX  */
+void rtw_hal_mcc_calc_tx_bytes_from_kernel(PADAPTER padapter, u32 len);
+
+/* record data to port to let driver do flow ctrl  */
+void rtw_hal_mcc_calc_tx_bytes_to_port(PADAPTER padapter, u32 len);
+
+/* check stop write port or not  */
+u8 rtw_hal_mcc_stop_tx_bytes_to_port(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_scan_start(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_scan_complete(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_start_bss_network(PADAPTER padapter, u8 chbw_grouped);
+
+u8 rtw_hal_set_mcc_setting_disconnect(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_join_done_chk_ch(PADAPTER padapter);
+
+u8 rtw_hal_set_mcc_setting_chk_start_clnt_join(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset, u8 chbw_allow);
+
+void rtw_hal_dump_mcc_info(void *sel, struct dvobj_priv *dvobj);
+
+void update_mcc_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib);
+
+u8 rtw_hal_mcc_link_status_chk(_adapter *padapter, const char *msg);
+
+void rtw_hal_mcc_issue_null_data(_adapter *padapter, u8 chbw_allow, u8 ps_mode);
+
+u8 *rtw_hal_mcc_append_go_p2p_ie(PADAPTER padapter, u8 *pframe, u32 *len);
+
+void rtw_hal_dump_mcc_policy_table(void *sel);
+
+void rtw_hal_mcc_update_macid_bitmap(PADAPTER padapter, int mac_id, u8 add);
+
+void rtw_hal_mcc_process_noa(PADAPTER padapter);
+
+void rtw_hal_mcc_parameter_init(PADAPTER padapter);
+
+u8 rtw_set_mcc_duration_hdl(PADAPTER adapter, u8 type, const u8 *val);
+
+u8 rtw_set_mcc_duration_cmd(_adapter *adapter, u8 type, u8 val);
+#endif /* _RTW_MCC_H_ */
+#endif /* CONFIG_MCC_MODE */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mem.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mem.h
index 1c11db1bc60a..2dcef922a038 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mem.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mem.h
@@ -1,42 +1,37 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTW_MEM_H__
-#define __RTW_MEM_H__
-
-#include <drv_conf.h>
-#include <basic_types.h>
-#include <osdep_service.h>
-
-#ifdef CONFIG_PLATFORM_MSTAR_HIGH
-#define MAX_RTKM_RECVBUF_SZ (31744) /* 31k */
-#else
-#define MAX_RTKM_RECVBUF_SZ (15360) /* 15k */
-#endif /* CONFIG_PLATFORM_MSTAR_HIGH */
-#define MAX_RTKM_NR_PREALLOC_RECV_SKB 16
-
-u16 rtw_rtkm_get_buff_size(void);
-u8 rtw_rtkm_get_nr_recv_skb(void);
-struct u8* rtw_alloc_revcbuf_premem(void);
-struct sk_buff *rtw_alloc_skb_premem(u16 in_size);
-int rtw_free_skb_premem(struct sk_buff *pskb);
-
-
-#endif //__RTW_MEM_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MEM_H__
+#define __RTW_MEM_H__
+
+#include <drv_conf.h>
+#include <basic_types.h>
+#include <osdep_service.h>
+
+#ifdef CONFIG_PLATFORM_MSTAR_HIGH
+	#define MAX_RTKM_RECVBUF_SZ (31744) /* 31k */
+#else
+	#define MAX_RTKM_RECVBUF_SZ (15360) /* 15k */
+#endif /* CONFIG_PLATFORM_MSTAR_HIGH */
+#define MAX_RTKM_NR_PREALLOC_RECV_SKB 16
+
+u16 rtw_rtkm_get_buff_size(void);
+u8 rtw_rtkm_get_nr_recv_skb(void);
+struct u8 *rtw_alloc_revcbuf_premem(void);
+struct sk_buff *rtw_alloc_skb_premem(u16 in_size);
+int rtw_free_skb_premem(struct sk_buff *pskb);
+
+
+#endif /* __RTW_MEM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mi.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mi.h
new file mode 100644
index 000000000000..11b3d6062e3f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mi.h
@@ -0,0 +1,284 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MI_H_
+#define __RTW_MI_H_
+
+void rtw_mi_update_union_chan_inf(_adapter *adapter, u8 ch, u8 offset , u8 bw);
+u8 rtw_mi_stayin_union_ch_chk(_adapter *adapter);
+u8 rtw_mi_stayin_union_band_chk(_adapter *adapter);
+int rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
+int rtw_mi_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
+
+struct mi_state {
+	u8 sta_num;			/* WIFI_STATION_STATE */
+	u8 ld_sta_num;		/* WIFI_STATION_STATE && _FW_LINKED */
+	u8 lg_sta_num;		/* WIFI_STATION_STATE && _FW_UNDER_LINKING */
+#ifdef CONFIG_TDLS
+	u8 ld_tdls_num;		/* adapter.tdlsinfo.link_established */
+#endif
+#ifdef CONFIG_AP_MODE
+	u8 ap_num;			/* WIFI_AP_STATE && _FW_LINKED */
+	u8 starting_ap_num;	/*WIFI_FW_AP_STATE*/
+	u8 ld_ap_num;		/* WIFI_AP_STATE && _FW_LINKED && asoc_sta_count > 2 */
+#endif
+	u8 adhoc_num;		/* (WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) && _FW_LINKED */
+	u8 ld_adhoc_num;	/* (WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) && _FW_LINKED && asoc_sta_count > 2 */
+#ifdef CONFIG_RTW_MESH
+	u8 mesh_num;		/* WIFI_MESH_STATE &&  _FW_LINKED */
+	u8 ld_mesh_num;		/* WIFI_MESH_STATE &&  _FW_LINKED && asoc_sta_count > 2 */
+#endif
+	u8 scan_num;		/* WIFI_SITE_MONITOR */
+	u8 scan_enter_num;	/* WIFI_SITE_MONITOR && !SCAN_DISABLE && !SCAN_BACK_OP */
+	u8 uwps_num;		/* WIFI_UNDER_WPS */
+#ifdef CONFIG_IOCTL_CFG80211
+	#ifdef CONFIG_P2P
+	u8 roch_num;
+	#endif
+	u8 mgmt_tx_num;
+#endif
+
+	u8 union_ch;
+	u8 union_bw;
+	u8 union_offset;
+};
+
+#define MSTATE_STA_NUM(_mstate)			((_mstate)->sta_num)
+#define MSTATE_STA_LD_NUM(_mstate)		((_mstate)->ld_sta_num)
+#define MSTATE_STA_LG_NUM(_mstate)		((_mstate)->lg_sta_num)
+
+#ifdef CONFIG_TDLS
+#define MSTATE_TDLS_LD_NUM(_mstate)		((_mstate)->ld_tdls_num)
+#else
+#define MSTATE_TDLS_LD_NUM(_mstate)		0
+#endif
+
+#ifdef CONFIG_AP_MODE
+#define MSTATE_AP_NUM(_mstate)			((_mstate)->ap_num)
+#define MSTATE_AP_STARTING_NUM(_mstate)	((_mstate)->starting_ap_num)
+#define MSTATE_AP_LD_NUM(_mstate)		((_mstate)->ld_ap_num)
+#else
+#define MSTATE_AP_NUM(_mstate)			0
+#define MSTATE_AP_STARTING_NUM(_mstate) 0
+#define MSTATE_AP_LD_NUM(_mstate)		0
+#endif
+
+#define MSTATE_ADHOC_NUM(_mstate)		((_mstate)->adhoc_num)
+#define MSTATE_ADHOC_LD_NUM(_mstate)	((_mstate)->ld_adhoc_num)
+
+#ifdef CONFIG_RTW_MESH
+#define MSTATE_MESH_NUM(_mstate)		((_mstate)->mesh_num)
+#define MSTATE_MESH_LD_NUM(_mstate)		((_mstate)->ld_mesh_num)
+#else
+#define MSTATE_MESH_NUM(_mstate)		0
+#define MSTATE_MESH_LD_NUM(_mstate)		0
+#endif
+
+#define MSTATE_SCAN_NUM(_mstate)		((_mstate)->scan_num)
+#define MSTATE_SCAN_ENTER_NUM(_mstate)	((_mstate)->scan_enter_num)
+#define MSTATE_WPS_NUM(_mstate)			((_mstate)->uwps_num)
+
+#if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_P2P)
+#define MSTATE_ROCH_NUM(_mstate)		((_mstate)->roch_num)
+#else
+#define MSTATE_ROCH_NUM(_mstate)		0
+#endif
+
+#if defined(CONFIG_IOCTL_CFG80211)
+#define MSTATE_MGMT_TX_NUM(_mstate)		((_mstate)->mgmt_tx_num)
+#else
+#define MSTATE_MGMT_TX_NUM(_mstate)		0
+#endif
+
+#define MSTATE_U_CH(_mstate)			((_mstate)->union_ch)
+#define MSTATE_U_BW(_mstate)			((_mstate)->union_bw)
+#define MSTATE_U_OFFSET(_mstate)		((_mstate)->union_offset)
+
+#define rtw_mi_get_union_chan(adapter)	adapter_to_dvobj(adapter)->iface_state.union_ch
+#define rtw_mi_get_union_bw(adapter)		adapter_to_dvobj(adapter)->iface_state.union_bw
+#define rtw_mi_get_union_offset(adapter)	adapter_to_dvobj(adapter)->iface_state.union_offset
+
+#define rtw_mi_get_assoced_sta_num(adapter)	DEV_STA_LD_NUM(adapter_to_dvobj(adapter))
+#define rtw_mi_get_ap_num(adapter)			DEV_AP_NUM(adapter_to_dvobj(adapter))
+#define rtw_mi_get_mesh_num(adapter)		DEV_MESH_NUM(adapter_to_dvobj(adapter))
+
+/* For now, not return union_ch/bw/offset */
+void rtw_mi_status(_adapter *adapter, struct mi_state *mstate);
+void rtw_mi_status_no_self(_adapter *adapter, struct mi_state *mstate);
+void rtw_mi_status_no_others(_adapter *adapter, struct mi_state *mstate);
+
+/* For now, not handle union_ch/bw/offset */
+void rtw_mi_status_merge(struct mi_state *d, struct mi_state *a);
+
+void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state);
+
+u8 rtw_mi_netif_stop_queue(_adapter *padapter);
+u8 rtw_mi_buddy_netif_stop_queue(_adapter *padapter);
+
+u8 rtw_mi_netif_wake_queue(_adapter *padapter);
+u8 rtw_mi_buddy_netif_wake_queue(_adapter *padapter);
+
+u8 rtw_mi_netif_carrier_on(_adapter *padapter);
+u8 rtw_mi_buddy_netif_carrier_on(_adapter *padapter);
+u8 rtw_mi_netif_carrier_off(_adapter *padapter);
+u8 rtw_mi_buddy_netif_carrier_off(_adapter *padapter);
+
+u8 rtw_mi_netif_caroff_qstop(_adapter *padapter);
+u8 rtw_mi_buddy_netif_caroff_qstop(_adapter *padapter);
+u8 rtw_mi_netif_caron_qstart(_adapter *padapter);
+u8 rtw_mi_buddy_netif_caron_qstart(_adapter *padapter);
+
+void rtw_mi_scan_abort(_adapter *adapter, bool bwait);
+void rtw_mi_buddy_scan_abort(_adapter *adapter, bool bwait);
+u32 rtw_mi_start_drv_threads(_adapter *adapter);
+u32 rtw_mi_buddy_start_drv_threads(_adapter *adapter);
+void rtw_mi_stop_drv_threads(_adapter *adapter);
+void rtw_mi_buddy_stop_drv_threads(_adapter *adapter);
+void rtw_mi_cancel_all_timer(_adapter *adapter);
+void rtw_mi_buddy_cancel_all_timer(_adapter *adapter);
+void rtw_mi_reset_drv_sw(_adapter *adapter);
+void rtw_mi_buddy_reset_drv_sw(_adapter *adapter);
+
+extern void rtw_intf_start(_adapter *adapter);
+extern void rtw_intf_stop(_adapter *adapter);
+void rtw_mi_intf_start(_adapter *adapter);
+void rtw_mi_buddy_intf_start(_adapter *adapter);
+void rtw_mi_intf_stop(_adapter *adapter);
+void rtw_mi_buddy_intf_stop(_adapter *adapter);
+
+void rtw_mi_suspend_free_assoc_resource(_adapter *adapter);
+void rtw_mi_buddy_suspend_free_assoc_resource(_adapter *adapter);
+
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
+void rtw_mi_set_scan_deny(_adapter *adapter, u32 ms);
+void rtw_mi_buddy_set_scan_deny(_adapter *adapter, u32 ms);
+#else
+#define rtw_mi_set_scan_deny(adapter, ms) do {} while (0)
+#define rtw_mi_buddy_set_scan_deny(adapter, ms) do {} while (0)
+#endif
+
+u8 rtw_mi_is_scan_deny(_adapter *adapter);
+u8 rtw_mi_buddy_is_scan_deny(_adapter *adapter);
+
+void rtw_mi_beacon_update(_adapter *padapter);
+void rtw_mi_buddy_beacon_update(_adapter *padapter);
+
+void rtw_mi_hal_dump_macaddr(_adapter *padapter);
+void rtw_mi_buddy_hal_dump_macaddr(_adapter *padapter);
+
+#ifdef CONFIG_PCI_HCI
+void rtw_mi_xmit_tasklet_schedule(_adapter *padapter);
+void rtw_mi_buddy_xmit_tasklet_schedule(_adapter *padapter);
+#endif
+
+u8 rtw_mi_busy_traffic_check(_adapter *padapter, bool check_sc_interval);
+u8 rtw_mi_buddy_busy_traffic_check(_adapter *padapter, bool check_sc_interval);
+
+u8 rtw_mi_check_mlmeinfo_state(_adapter *padapter, u32 state);
+u8 rtw_mi_buddy_check_mlmeinfo_state(_adapter *padapter, u32 state);
+
+u8 rtw_mi_check_fwstate(_adapter *padapter, sint state);
+u8 rtw_mi_buddy_check_fwstate(_adapter *padapter, sint state);
+enum {
+	MI_LINKED,
+	MI_ASSOC,
+	MI_UNDER_WPS,
+	MI_AP_MODE,
+	MI_AP_ASSOC,
+	MI_ADHOC,
+	MI_ADHOC_ASSOC,
+	MI_MESH,
+	MI_MESH_ASSOC,
+	MI_STA_NOLINK, /* this is misleading, but not used now */
+	MI_STA_LINKED,
+	MI_STA_LINKING,
+};
+u8 rtw_mi_check_status(_adapter *adapter, u8 type);
+
+void dump_dvobj_mi_status(void *sel, const char *fun_name, _adapter *adapter);
+#ifdef DBG_IFACE_STATUS
+#define DBG_IFACE_STATUS_DUMP(adapter)	dump_dvobj_mi_status(RTW_DBGDUMP, __func__, adapter)
+#endif
+void dump_mi_status(void *sel, struct dvobj_priv *dvobj);
+
+u8 rtw_mi_traffic_statistics(_adapter *padapter);
+u8 rtw_mi_check_miracast_enabled(_adapter *padapter);
+
+#ifdef CONFIG_XMIT_THREAD_MODE
+u8 rtw_mi_check_pending_xmitbuf(_adapter *padapter);
+u8 rtw_mi_buddy_check_pending_xmitbuf(_adapter *padapter);
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#ifdef CONFIG_RTL8822B
+	#include <rtl8822b_hal.h>
+#else
+	extern s32 _dequeue_writeport(PADAPTER padapter);
+#endif
+u8 rtw_mi_dequeue_writeport(_adapter *padapter);
+u8 rtw_mi_buddy_dequeue_writeport(_adapter *padapter);
+#endif
+
+void rtw_mi_adapter_reset(_adapter *padapter);
+void rtw_mi_buddy_adapter_reset(_adapter *padapter);
+
+u8 rtw_mi_dynamic_check_timer_handlder(_adapter *padapter);
+u8 rtw_mi_buddy_dynamic_check_timer_handlder(_adapter *padapter);
+
+u8 rtw_mi_dev_unload(_adapter *padapter);
+u8 rtw_mi_buddy_dev_unload(_adapter *padapter);
+
+extern void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter);
+u8 rtw_mi_dynamic_chk_wk_hdl(_adapter *padapter);
+u8 rtw_mi_buddy_dynamic_chk_wk_hdl(_adapter *padapter);
+
+u8 rtw_mi_os_xmit_schedule(_adapter *padapter);
+u8 rtw_mi_buddy_os_xmit_schedule(_adapter *padapter);
+
+u8 rtw_mi_report_survey_event(_adapter *padapter, union recv_frame *precv_frame);
+u8 rtw_mi_buddy_report_survey_event(_adapter *padapter, union recv_frame *precv_frame);
+
+extern void sreset_start_adapter(_adapter *padapter);
+extern void sreset_stop_adapter(_adapter *padapter);
+u8 rtw_mi_sreset_adapter_hdl(_adapter *padapter, u8 bstart);
+u8 rtw_mi_buddy_sreset_adapter_hdl(_adapter *padapter, u8 bstart);
+
+u8 rtw_mi_tx_beacon_hdl(_adapter *padapter);
+u8 rtw_mi_buddy_tx_beacon_hdl(_adapter *padapter);
+
+u8 rtw_mi_set_tx_beacon_cmd(_adapter *padapter);
+u8 rtw_mi_buddy_set_tx_beacon_cmd(_adapter *padapter);
+
+#ifdef CONFIG_P2P
+u8 rtw_mi_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state);
+u8 rtw_mi_buddy_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state);
+u8 rtw_mi_stay_in_p2p_mode(_adapter *padapter);
+u8 rtw_mi_buddy_stay_in_p2p_mode(_adapter *padapter);
+#endif
+
+_adapter *rtw_get_iface_by_id(_adapter *padapter, u8 iface_id);
+_adapter *rtw_get_iface_by_macddr(_adapter *padapter, const u8 *mac_addr);
+_adapter *rtw_get_iface_by_hwport(_adapter *padapter, u8 hw_port);
+
+void rtw_mi_buddy_clone_bcmc_packet(_adapter *padapter, union recv_frame *precvframe, u8 *pphy_status);
+
+#ifdef CONFIG_PCI_HCI
+/*API be create temporary for MI, caller is interrupt-handler, PCIE's interrupt handler cannot apply to multi-AP*/
+_adapter *rtw_mi_get_ap_adapter(_adapter *padapter);
+#endif
+
+void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b);
+
+#endif /*__RTW_MI_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme.h
index 22a25ebae77c..33081b1e8077 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,34 +12,24 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_MLME_H_
 #define __RTW_MLME_H_
 
 
 #define	MAX_BSS_CNT	128
-//#define   MAX_JOIN_TIMEOUT	2000
-//#define   MAX_JOIN_TIMEOUT	2500
+/* #define   MAX_JOIN_TIMEOUT	2000 */
+/* #define   MAX_JOIN_TIMEOUT	2500 */
 #define   MAX_JOIN_TIMEOUT	6500
 
-//	Commented by Albert 20101105
-//	Increase the scanning timeout because of increasing the SURVEY_TO value.
+/*	Commented by Albert 20101105
+ *	Increase the scanning timeout because of increasing the SURVEY_TO value. */
 
-#define SCANNING_TIMEOUT 8000
-#ifdef CONFIG_SCAN_BACKOP
-#define CONC_SCANNING_TIMEOUT_SINGLE_BAND 10000
-#define CONC_SCANNING_TIMEOUT_DUAL_BAND 15000
-#endif
 
 #ifdef PALTFORM_OS_WINCE
-#define	SCANQUEUE_LIFETIME 12000000 // unit:us
+#define	SCANQUEUE_LIFETIME 12000000 /* unit:us */
 #else
-#define	SCANQUEUE_LIFETIME 20000 // 20sec, unit:msec
+#define	SCANQUEUE_LIFETIME 20000 /* 20sec, unit:msec */
 #endif
 
 #define WIFI_NULL_STATE					0x00000000
@@ -51,7 +42,7 @@
 #define WIFI_ADHOC_MASTER_STATE			0x00000040
 #define WIFI_UNDER_LINKING				0x00000080
 #define WIFI_UNDER_WPS					0x00000100
-/*#define WIFI_UNDEFINED_STATE			0x00000200*/
+#define WIFI_MESH_STATE					0x00000200
 #define WIFI_STA_ALIVE_CHK_STATE		0x00000400
 #define WIFI_SITE_MONITOR				0x00000800 /* under site surveying */
 #define WIFI_WDS						0x00001000
@@ -88,61 +79,108 @@ const char *get_miracast_mode_str(int mode);
 void rtw_wfd_st_switch(struct sta_info *sta, bool on);
 
 #define MLME_STATE(adapter) get_fwstate(&((adapter)->mlmepriv))
-
-#define MLME_IS_STA(adapter) (MLME_STATE((adapter)) & WIFI_STATION_STATE)
-#define MLME_IS_AP(adapter) (MLME_STATE((adapter)) & WIFI_AP_STATE)
-#define MLME_IS_ADHOC(adapter) (MLME_STATE((adapter)) & WIFI_ADHOC_STATE)
-#define MLME_IS_ADHOC_MASTER(adapter) (MLME_STATE((adapter)) & WIFI_ADHOC_MASTER_STATE)
-#define MLME_IS_MONITOR(adapter) (MLME_STATE((adapter)) & WIFI_MONITOR_STATE)
-#define MLME_IS_MP(adapter) (MLME_STATE((adapter)) & WIFI_MP_STATE)
+#define CHK_MLME_STATE(adapter, state) check_fwstate(&((adapter)->mlmepriv), (state))
+
+#define MLME_IS_NULL(adapter) CHK_MLME_STATE(adapter, WIFI_NULL_STATE)
+#define MLME_IS_STA(adapter) CHK_MLME_STATE(adapter, WIFI_STATION_STATE)
+#define MLME_IS_AP(adapter) CHK_MLME_STATE(adapter, WIFI_AP_STATE)
+#define MLME_IS_ADHOC(adapter) CHK_MLME_STATE(adapter, WIFI_ADHOC_STATE)
+#define MLME_IS_ADHOC_MASTER(adapter) CHK_MLME_STATE(adapter, WIFI_ADHOC_MASTER_STATE)
+#define MLME_IS_MESH(adapter) CHK_MLME_STATE(adapter, WIFI_MESH_STATE)
+#define MLME_IS_MONITOR(adapter) CHK_MLME_STATE(adapter, WIFI_MONITOR_STATE)
+#define MLME_IS_MP(adapter) CHK_MLME_STATE(adapter, WIFI_MP_STATE)
 #ifdef CONFIG_P2P
-#define MLME_IS_GC(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_CLIENT)
-#define MLME_IS_GO(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_GO)
+	#define MLME_IS_PD(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_DEVICE)
+	#define MLME_IS_GC(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_CLIENT)
+	#define MLME_IS_GO(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_GO)
 #else /* !CONFIG_P2P */
-#define MLME_IS_GC(adapter) 0
-#define MLME_IS_GO(adapter) 0
+	#define MLME_IS_PD(adapter) 0
+	#define MLME_IS_GC(adapter) 0
+	#define MLME_IS_GO(adapter) 0
 #endif /* !CONFIG_P2P */
+
 #define MLME_IS_MSRC(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SOURCE)
 #define MLME_IS_MSINK(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SINK)
 
-#define MLME_STATE_FMT "%s%s%s%s%s%s%s%s%s%s%s%s%s%s"
+#define MLME_IS_SCAN(adapter) CHK_MLME_STATE(adapter, WIFI_SITE_MONITOR)
+#define MLME_IS_LINKING(adapter) CHK_MLME_STATE(adapter, WIFI_UNDER_LINKING)
+#define MLME_IS_ASOC(adapter) CHK_MLME_STATE(adapter, WIFI_ASOC_STATE)
+#define MLME_IS_OPCH_SW(adapter) CHK_MLME_STATE(adapter, WIFI_OP_CH_SWITCHING)
+#define MLME_IS_WPS(adapter) CHK_MLME_STATE(adapter, WIFI_UNDER_WPS)
+
+#if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_P2P)
+#define MLME_IS_ROCH(adapter) (rtw_cfg80211_get_is_roch(adapter) == _TRUE)
+#else
+#define MLME_IS_ROCH(adapter) 0
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+#define MLME_IS_MGMT_TX(adapter) rtw_cfg80211_get_is_mgmt_tx(adapter)
+#else
+#define MLME_IS_MGMT_TX(adapter) 0
+#endif
+
+#define MLME_STATE_FMT "%s%s%s%s%s%s%s%s%s%s%s%s"
 #define MLME_STATE_ARG(adapter) \
-	MLME_IS_STA((adapter)) ? (MLME_IS_GC((adapter)) ? " GC" : " STA") : "", \
-	MLME_IS_AP((adapter)) ? (MLME_IS_GO((adapter)) ? " GO" : " AP") : "", \
-	MLME_IS_ADHOC((adapter)) ? " ADHOC" : "", \
-	MLME_IS_ADHOC_MASTER((adapter)) ? " ADHOC_M" : "", \
-	MLME_IS_MONITOR((adapter)) ? " MONITOR" : "", \
+	MLME_IS_STA((adapter)) ? (MLME_IS_GC((adapter)) ? " GC" : " STA") : \
+	MLME_IS_AP((adapter)) ? (MLME_IS_GO((adapter)) ? " GO" : " AP") : \
+	MLME_IS_ADHOC((adapter)) ? " ADHOC" : \
+	MLME_IS_ADHOC_MASTER((adapter)) ? " ADHOC_M" : \
+	MLME_IS_MESH((adapter)) ? " MESH" : \
+	MLME_IS_MONITOR((adapter)) ? " MONITOR" : \
 	MLME_IS_MP((adapter)) ? " MP" : "", \
+	MLME_IS_PD((adapter)) ? " PD" : "", \
 	MLME_IS_MSRC((adapter)) ? " MSRC" : "", \
 	MLME_IS_MSINK((adapter)) ? " MSINK" : "", \
-	(MLME_STATE((adapter)) & WIFI_SITE_MONITOR) ? " SCAN" : "", \
-	(MLME_STATE((adapter)) & WIFI_UNDER_LINKING) ? " LINKING" : "", \
-	(MLME_STATE((adapter)) & WIFI_ASOC_STATE) ? " ASOC" : "", \
-	(MLME_STATE((adapter)) & WIFI_OP_CH_SWITCHING) ? " OP_CH_SW" : "", \
-	(MLME_STATE((adapter)) & WIFI_UNDER_WPS) ? " WPS" : "", \
+	MLME_IS_SCAN((adapter)) ? " SCAN" : "", \
+	MLME_IS_LINKING((adapter)) ? " LINKING" : "", \
+	MLME_IS_ASOC((adapter)) ? " ASOC" : "", \
+	MLME_IS_OPCH_SW((adapter)) ? " OPCH_SW" : "", \
+	MLME_IS_WPS((adapter)) ? " WPS" : "", \
+	MLME_IS_ROCH((adapter)) ? " ROCH" : "", \
+	MLME_IS_MGMT_TX((adapter)) ? " MGMT_TX" : "", \
 	(MLME_STATE((adapter)) & WIFI_SLEEP_STATE) ? " SLEEP" : ""
 
+enum {
+	MLME_ACTION_UNKNOWN,
+	MLME_ACTION_NONE,
+	MLME_SCAN_ENABLE, /* WIFI_SITE_MONITOR */
+	MLME_SCAN_ENTER, /* WIFI_SITE_MONITOR && !SCAN_DISABLE && !SCAN_BACK_OP */
+	MLME_SCAN_DONE, /*  WIFI_SITE_MONITOR && (SCAN_DISABLE || SCAN_BACK_OP) */
+	MLME_SCAN_DISABLE, /* WIFI_SITE_MONITOR is going to be cleared */
+	MLME_STA_CONNECTING,
+	MLME_STA_CONNECTED,
+	MLME_STA_DISCONNECTED,
+	MLME_TDLS_LINKED,
+	MLME_TDLS_NOLINK,
+	MLME_AP_STARTED,
+	MLME_AP_STOPPED,
+	MLME_ADHOC_STARTED,
+	MLME_ADHOC_STOPPED,
+	MLME_MESH_STARTED,
+	MLME_MESH_STOPPED,
+};
+
 #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_WAPI,
- dot11AuthAlgrthm_MaxNum
+	dot11AuthAlgrthm_Open = 0,
+	dot11AuthAlgrthm_Shared,
+	dot11AuthAlgrthm_8021X,
+	dot11AuthAlgrthm_Auto,
+	dot11AuthAlgrthm_WAPI,
+	dot11AuthAlgrthm_MaxNum
 };
 
-// Scan type including active and passive scan.
-typedef enum _RT_SCAN_TYPE
-{
+/* Scan type including active and passive scan. */
+typedef enum _RT_SCAN_TYPE {
 	SCAN_PASSIVE,
 	SCAN_ACTIVE,
 	SCAN_MIX,
-}RT_SCAN_TYPE, *PRT_SCAN_TYPE;
+} RT_SCAN_TYPE, *PRT_SCAN_TYPE;
 
 #define WIFI_FREQUENCY_BAND_AUTO 0
 #define WIFI_FREQUENCY_BAND_5GHZ 1
@@ -155,12 +193,11 @@ enum DriverInterface {
 	DRIVER_CFG80211 = 2
 };
 
-enum SCAN_RESULT_TYPE
-{
-	SCAN_RESULT_P2P_ONLY = 0,		//	Will return all the P2P devices.
-	SCAN_RESULT_ALL = 1,			//	Will return all the scanned device, include AP.
-	SCAN_RESULT_WFD_TYPE = 2		//	Will just return the correct WFD device.
-									//	If this device is Miracast sink device, it will just return all the Miracast source devices.
+enum SCAN_RESULT_TYPE {
+	SCAN_RESULT_P2P_ONLY = 0,		/*	Will return all the P2P devices. */
+	SCAN_RESULT_ALL = 1,			/*	Will return all the scanned device, include AP. */
+	SCAN_RESULT_WFD_TYPE = 2		/*	Will just return the correct WFD device. */
+									/*	If this device is Miracast sink device, it will just return all the Miracast source devices. */
 };
 
 /*
@@ -182,116 +219,109 @@ SHALL not lock up more than one locks at a time!
 #define traffic_threshold	10
 #define	traffic_scan_period	500
 
-struct sitesurvey_ctrl {
-	u64	last_tx_pkts;
-	uint	last_rx_pkts;
-	sint	traffic_busy;
-	_timer	sitesurvey_ctrl_timer;
-};
-
-typedef struct _RT_LINK_DETECT_T{
+typedef struct _RT_LINK_DETECT_T {
 	u32				NumTxOkInPeriod;
 	u32				NumRxOkInPeriod;
 	u32				NumRxUnicastOkInPeriod;
 	BOOLEAN			bBusyTraffic;
 	BOOLEAN			bTxBusyTraffic;
 	BOOLEAN			bRxBusyTraffic;
-	BOOLEAN			bHigherBusyTraffic; // For interrupt migration purpose.
-	BOOLEAN			bHigherBusyRxTraffic; // We may disable Tx interrupt according as Rx traffic.
-	BOOLEAN			bHigherBusyTxTraffic; // We may disable Tx interrupt according as Tx traffic.
-	//u8 TrafficBusyState;
+	BOOLEAN			bHigherBusyTraffic; /* For interrupt migration purpose. */
+	BOOLEAN			bHigherBusyRxTraffic; /* We may disable Tx interrupt according as Rx traffic. */
+	BOOLEAN			bHigherBusyTxTraffic; /* We may disable Tx interrupt according as Tx traffic. */
+	/* u8 TrafficBusyState; */
 	u8 TrafficTransitionCount;
 	u32 LowPowerTransitionCount;
-}RT_LINK_DETECT_T, *PRT_LINK_DETECT_T;
+} RT_LINK_DETECT_T, *PRT_LINK_DETECT_T;
 
 struct profile_info {
 	u8	ssidlen;
-	u8	ssid[ WLAN_SSID_MAXLEN ];
-	u8	peermac[ ETH_ALEN ];
+	u8	ssid[WLAN_SSID_MAXLEN];
+	u8	peermac[ETH_ALEN];
 };
 
-struct tx_invite_req_info{
+struct tx_invite_req_info {
 	u8					token;
 	u8					benable;
-	u8					go_ssid[ WLAN_SSID_MAXLEN ];
+	u8					go_ssid[WLAN_SSID_MAXLEN];
 	u8					ssidlen;
-	u8					go_bssid[ ETH_ALEN ];
-	u8					peer_macaddr[ ETH_ALEN ];
-	u8					operating_ch;	//	This information will be set by using the p2p_set op_ch=x
-	u8					peer_ch;		//	The listen channel for peer P2P device
+	u8					go_bssid[ETH_ALEN];
+	u8					peer_macaddr[ETH_ALEN];
+	u8					operating_ch;	/*	This information will be set by using the p2p_set op_ch=x */
+	u8					peer_ch;		/*	The listen channel for peer P2P device */
 
 };
 
-struct tx_invite_resp_info{
-	u8					token;	//	Used to record the dialog token of p2p invitation request frame.
+struct tx_invite_resp_info {
+	u8					token;	/*	Used to record the dialog token of p2p invitation request frame. */
 };
 
 #ifdef CONFIG_WFD
 
-struct wifi_display_info{
-	u16							wfd_enable;			//	Eanble/Disable the WFD function.
+struct wifi_display_info {
+	u16							wfd_enable;			/*	Eanble/Disable the WFD function. */
 	u16							init_rtsp_ctrlport;	/* init value of rtsp_ctrlport when WFD enable */
 	u16							rtsp_ctrlport;		/* TCP port number at which the this WFD device listens for RTSP messages, 0 when WFD disable */
 	u16							tdls_rtsp_ctrlport;	/* rtsp_ctrlport used by tdls, will sync when rtsp_ctrlport is changed by user */
-	u16							peer_rtsp_ctrlport;	//	TCP port number at which the peer WFD device listens for RTSP messages
-													//	This filed should be filled when receiving the gropu negotiation request
+	u16							peer_rtsp_ctrlport;	/*	TCP port number at which the peer WFD device listens for RTSP messages */
+													/*	This filed should be filled when receiving the gropu negotiation request */
 
-	u8							peer_session_avail;	//	WFD session is available or not for the peer wfd device.
-													//	This variable will be set when sending the provisioning discovery request to peer WFD device.
-													//	And this variable will be reset when it is read by using the iwpriv p2p_get wfd_sa command.
+	u8							peer_session_avail;	/*	WFD session is available or not for the peer wfd device. */
+													/*	This variable will be set when sending the provisioning discovery request to peer WFD device. */
+													/*	And this variable will be reset when it is read by using the iwpriv p2p_get wfd_sa command. */
 	u8							ip_address[4];
 	u8							peer_ip_address[4];
-	u8							wfd_pc;				//	WFD preferred connection
-													//	0 -> Prefer to use the P2P for WFD connection on peer side.
-													//	1 -> Prefer to use the TDLS for WFD connection on peer side.
-											
-	u8							wfd_device_type;	//	WFD Device Type
-													//	0 -> WFD Source Device
-													//	1 -> WFD Primary Sink Device
-	enum	SCAN_RESULT_TYPE	scan_result_type;	//	Used when P2P is enable. This parameter will impact the scan result.
+	u8							wfd_pc;				/*	WFD preferred connection */
+													/*	0 -> Prefer to use the P2P for WFD connection on peer side. */
+													/*	1 -> Prefer to use the TDLS for WFD connection on peer side. */
+
+	u8							wfd_device_type;	/*	WFD Device Type */
+													/*	0 -> WFD Source Device */
+													/*	1 -> WFD Primary Sink Device */
+	enum	SCAN_RESULT_TYPE	scan_result_type;	/*	Used when P2P is enable. This parameter will impact the scan result. */
 	u8 op_wfd_mode;
 	u8 stack_wfd_mode;
 };
-#endif //CONFIG_WFD
+#endif /* CONFIG_WFD */
 
-struct tx_provdisc_req_info{
-	u16					wps_config_method_request;	//	Used when sending the provisioning request frame
-	u16					peer_channel_num[2];		//	The channel number which the receiver stands.
+struct tx_provdisc_req_info {
+	u16					wps_config_method_request;	/*	Used when sending the provisioning request frame */
+	u16					peer_channel_num[2];		/*	The channel number which the receiver stands. */
 	NDIS_802_11_SSID	ssid;
-	u8					peerDevAddr[ ETH_ALEN ];		//	Peer device address
-	u8					peerIFAddr[ ETH_ALEN ];		//	Peer interface address
-	u8					benable;					//	This provision discovery request frame is trigger to send or not
+	u8					peerDevAddr[ETH_ALEN];		/*	Peer device address */
+	u8					peerIFAddr[ETH_ALEN];		/*	Peer interface address */
+	u8					benable;					/*	This provision discovery request frame is trigger to send or not */
 };
 
-struct rx_provdisc_req_info{	//When peer device issue prov_disc_req first, we should store the following informations
-	u8					peerDevAddr[ ETH_ALEN ];		//	Peer device address
-	u8					strconfig_method_desc_of_prov_disc_req[4];	//	description for the config method located in the provisioning discovery request frame.	
-																	//	The UI must know this information to know which config method the remote p2p device is requiring.
+struct rx_provdisc_req_info {	/* When peer device issue prov_disc_req first, we should store the following informations */
+	u8					peerDevAddr[ETH_ALEN];		/*	Peer device address */
+	u8					strconfig_method_desc_of_prov_disc_req[4];	/*	description for the config method located in the provisioning discovery request frame.	 */
+																	/*	The UI must know this information to know which config method the remote p2p device is requiring. */
 };
 
-struct tx_nego_req_info{
-	u16					peer_channel_num[2];		//	The channel number which the receiver stands.
-	u8					peerDevAddr[ ETH_ALEN ];		//	Peer device address
-	u8					benable;					//	This negoitation request frame is trigger to send or not
-	u8					peer_ch;		                   /*   The listen channel for peer P2P device    */
+struct tx_nego_req_info {
+	u16					peer_channel_num[2];		/*	The channel number which the receiver stands. */
+	u8					peerDevAddr[ETH_ALEN];		/*	Peer device address */
+	u8					benable;					/*	This negoitation request frame is trigger to send or not */
+	u8					peer_ch;					/*	The listen channel for peer P2P device */
 };
 
-struct group_id_info{
-	u8					go_device_addr[ ETH_ALEN ];	//	The GO's device address of this P2P group
-	u8					ssid[ WLAN_SSID_MAXLEN ];	//	The SSID of this P2P group
+struct group_id_info {
+	u8					go_device_addr[ETH_ALEN];	/*	The GO's device address of this P2P group */
+	u8					ssid[WLAN_SSID_MAXLEN];		/*	The SSID of this P2P group */
 };
 
-struct scan_limit_info{
-	u8					scan_op_ch_only;			//	When this flag is set, the driver should just scan the operation channel
+struct scan_limit_info {
+	u8					scan_op_ch_only;			/*	When this flag is set, the driver should just scan the operation channel */
 #ifndef CONFIG_P2P_OP_CHK_SOCIAL_CH
-	u8					operation_ch[2];				//	Store the operation channel of invitation request frame
+	u8					operation_ch[2];				/*	Store the operation channel of invitation request frame */
 #else
-	u8					operation_ch[5];				//	Store additional channel 1,6,11  for Android 4.2 IOT & Nexus 4
-#endif //CONFIG_P2P_OP_CHK_SOCIAL_CH
+	u8					operation_ch[5];				/*	Store additional channel 1,6,11  for Android 4.2 IOT & Nexus 4 */
+#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
 };
 
 #ifdef CONFIG_IOCTL_CFG80211
-struct cfg80211_wifidirect_info{
+struct cfg80211_wifidirect_info {
 	_timer					remain_on_ch_timer;
 	u8						restore_channel;
 	struct ieee80211_channel	remain_on_ch_channel;
@@ -299,147 +329,147 @@ struct cfg80211_wifidirect_info{
 	ATOMIC_T ro_ch_cookie_gen;
 	u64 remain_on_ch_cookie;
 	bool is_ro_ch;
-	u32 last_ro_ch_time; /* this will be updated at the beginning and end of ro_ch */
+	struct wireless_dev *ro_ch_wdev;
+	systime last_ro_ch_time; /* this will be updated at the beginning and end of ro_ch */
 };
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 #ifdef CONFIG_P2P_WOWLAN
 
-enum P2P_WOWLAN_RECV_FRAME_TYPE
-{
+enum P2P_WOWLAN_RECV_FRAME_TYPE {
 	P2P_WOWLAN_RECV_NEGO_REQ = 0,
 	P2P_WOWLAN_RECV_INVITE_REQ = 1,
 	P2P_WOWLAN_RECV_PROVISION_REQ = 2,
 };
 
-struct p2p_wowlan_info{
+struct p2p_wowlan_info {
 
-	u8 						is_trigger;
+	u8						is_trigger;
 	enum P2P_WOWLAN_RECV_FRAME_TYPE	wowlan_recv_frame_type;
-	u8 						wowlan_peer_addr[ETH_ALEN];
+	u8						wowlan_peer_addr[ETH_ALEN];
 	u16						wowlan_peer_wpsconfig;
 	u8						wowlan_peer_is_persistent;
 	u8						wowlan_peer_invitation_type;
 };
 
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
 
-struct wifidirect_info{
-	_adapter*				padapter;
+struct wifidirect_info {
+	_adapter				*padapter;
 	_timer					find_phase_timer;
 	_timer					restore_p2p_state_timer;
-	
-	//	Used to do the scanning. After confirming the peer is availalble, the driver transmits the P2P frame to peer.
+
+	/*	Used to do the scanning. After confirming the peer is availalble, the driver transmits the P2P frame to peer. */
 	_timer					pre_tx_scan_timer;
 	_timer					reset_ch_sitesurvey;
-	_timer					reset_ch_sitesurvey2;	//	Just for resetting the scan limit function by using p2p nego
+	_timer					reset_ch_sitesurvey2;	/*	Just for resetting the scan limit function by using p2p nego */
 #ifdef CONFIG_CONCURRENT_MODE
-	//	Used to switch the channel between legacy AP and listen state.
+	/*	Used to switch the channel between legacy AP and listen state. */
 	_timer					ap_p2p_switch_timer;
 #endif
 	struct tx_provdisc_req_info	tx_prov_disc_info;
 	struct rx_provdisc_req_info rx_prov_disc_info;
 	struct tx_invite_req_info	invitereq_info;
-	struct profile_info			profileinfo[ P2P_MAX_PERSISTENT_GROUP_NUM ];	//	Store the profile information of persistent group
+	struct profile_info			profileinfo[P2P_MAX_PERSISTENT_GROUP_NUM];	/*	Store the profile information of persistent group */
 	struct tx_invite_resp_info	inviteresp_info;
 	struct tx_nego_req_info	nego_req_info;
-	struct group_id_info		groupid_info;	//	Store the group id information when doing the group negotiation handshake.
-	struct scan_limit_info		rx_invitereq_info;	//	Used for get the limit scan channel from the Invitation procedure
-	struct scan_limit_info		p2p_info;		//	Used for get the limit scan channel from the P2P negotiation handshake
+	struct group_id_info		groupid_info;	/*	Store the group id information when doing the group negotiation handshake. */
+	struct scan_limit_info		rx_invitereq_info;	/*	Used for get the limit scan channel from the Invitation procedure */
+	struct scan_limit_info		p2p_info;		/*	Used for get the limit scan channel from the P2P negotiation handshake */
 #ifdef CONFIG_WFD
 	struct wifi_display_info		*wfd_info;
-#endif	
+#endif
 
 #ifdef CONFIG_P2P_WOWLAN
 	struct p2p_wowlan_info		p2p_wow_info;
-#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
 
 	enum P2P_ROLE			role;
 	enum P2P_STATE			pre_p2p_state;
 	enum P2P_STATE			p2p_state;
-	u8 						device_addr[ETH_ALEN];	//	The device address should be the mac address of this device.
+	u8						device_addr[ETH_ALEN];	/*	The device address should be the mac address of this device. */
 	u8						interface_addr[ETH_ALEN];
 	u8						social_chan[4];
 	u8						listen_channel;
 	u8						operating_channel;
-	u8						listen_dwell;		//	This value should be between 1 and 3
+	u8						listen_dwell;		/*	This value should be between 1 and 3 */
 	u8						support_rate[8];
 	u8						p2p_wildcard_ssid[P2P_WILDCARD_SSID_LEN];
-	u8						intent;		//	should only include the intent value.
-	u8						p2p_peer_interface_addr[ ETH_ALEN ];
-	u8						p2p_peer_device_addr[ ETH_ALEN ];
-	u8						peer_intent;	//	Included the intent value and tie breaker value.
-	u8						device_name[ WPS_MAX_DEVICE_NAME_LEN ];	//	Device name for displaying on searching device screen
-	u8						device_name_len;
-	u8						profileindex;	//	Used to point to the index of profileinfo array
+	u8						intent;		/*	should only include the intent value. */
+	u8						p2p_peer_interface_addr[ETH_ALEN];
+	u8						p2p_peer_device_addr[ETH_ALEN];
+	u8						peer_intent;	/*	Included the intent value and tie breaker value. */
+	u8						device_name[WPS_MAX_DEVICE_NAME_LEN];	/*	Device name for displaying on searching device screen */
+	u16						device_name_len;
+	u8						profileindex;	/*	Used to point to the index of profileinfo array */
 	u8						peer_operating_ch;
 	u8						find_phase_state_exchange_cnt;
-	u16						device_password_id_for_nego;	//	The device password ID for group negotation
+	u16						device_password_id_for_nego;	/*	The device password ID for group negotation */
 	u8						negotiation_dialog_token;
-	u8						nego_ssid[ WLAN_SSID_MAXLEN ];	//	SSID information for group negotitation
+	u8						nego_ssid[WLAN_SSID_MAXLEN];	/*	SSID information for group negotitation */
 	u8						nego_ssidlen;
-	u8 						p2p_group_ssid[WLAN_SSID_MAXLEN];
-	u8 						p2p_group_ssid_len;
-	u8						persistent_supported;		//	Flag to know the persistent function should be supported or not.
-														//	In the Sigma test, the Sigma will provide this enable from the sta_set_p2p CAPI.
-														//	0: disable
-														//	1: enable
-	u8						session_available;			//	Flag to set the WFD session available to enable or disable "by Sigma"
-														//	In the Sigma test, the Sigma will disable the session available by using the sta_preset CAPI.
-														//	0: disable
-														//	1: enable
-
-	u8						wfd_tdls_enable;			//	Flag to enable or disable the TDLS by WFD Sigma
-														//	0: disable
-														//	1: enable
-	u8						wfd_tdls_weaksec;			//	Flag to enable or disable the weak security function for TDLS by WFD Sigma
-														//	0: disable
-														//	In this case, the driver can't issue the tdsl setup request frame.
-														//	1: enable
-														//	In this case, the driver can issue the tdls setup request frame
-														//	even the current security is weak security.
-
-	enum	P2P_WPSINFO		ui_got_wps_info;			//	This field will store the WPS value (PIN value or PBC) that UI had got from the user.
-	u16						supported_wps_cm;			//	This field describes the WPS config method which this driver supported.
-														//	The value should be the combination of config method defined in page104 of WPS v2.0 spec.	
-	u8						external_uuid;				// UUID flag
-	u8						uuid[16];					// UUID
-	uint						channel_list_attr_len;		//	This field will contain the length of body of P2P Channel List attribute of group negotitation response frame.
-	u8						channel_list_attr[100];		//	This field will contain the body of P2P Channel List attribute of group negotitation response frame.
-														//	We will use the channel_cnt and channel_list fields when constructing the group negotitation confirm frame.
-	u8						driver_interface;			//	Indicate DRIVER_WEXT or DRIVER_CFG80211
+	u8						p2p_group_ssid[WLAN_SSID_MAXLEN];
+	u8						p2p_group_ssid_len;
+	u8						persistent_supported;		/*	Flag to know the persistent function should be supported or not. */
+														/*	In the Sigma test, the Sigma will provide this enable from the sta_set_p2p CAPI. */
+														/*	0: disable */
+														/*	1: enable */
+	u8						session_available;			/*	Flag to set the WFD session available to enable or disable "by Sigma" */
+														/*	In the Sigma test, the Sigma will disable the session available by using the sta_preset CAPI. */
+														/*	0: disable */
+														/*	1: enable */
+
+	u8						wfd_tdls_enable;			/*	Flag to enable or disable the TDLS by WFD Sigma */
+														/*	0: disable */
+														/*	1: enable */
+	u8						wfd_tdls_weaksec;			/*	Flag to enable or disable the weak security function for TDLS by WFD Sigma */
+														/*	0: disable */
+														/*	In this case, the driver can't issue the tdsl setup request frame. */
+														/*	1: enable */
+														/*	In this case, the driver can issue the tdls setup request frame */
+														/*	even the current security is weak security. */
+
+	enum	P2P_WPSINFO		ui_got_wps_info;			/*	This field will store the WPS value (PIN value or PBC) that UI had got from the user. */
+	u16						supported_wps_cm;			/*	This field describes the WPS config method which this driver supported. */
+														/*	The value should be the combination of config method defined in page104 of WPS v2.0 spec.	 */
+	u8						external_uuid;				/* UUID flag */
+	u8						uuid[16];					/* UUID */
+	uint						channel_list_attr_len;	/*	This field will contain the length of body of P2P Channel List attribute of group negotitation response frame. */
+	u8						channel_list_attr[100];		/*	This field will contain the body of P2P Channel List attribute of group negotitation response frame. */
+														/*	We will use the channel_cnt and channel_list fields when constructing the group negotitation confirm frame. */
+	u8						driver_interface;			/*	Indicate DRIVER_WEXT or DRIVER_CFG80211 */
 
 #ifdef CONFIG_CONCURRENT_MODE
-	u16						ext_listen_interval;	//	The interval to be available with legacy AP (ms)
-	u16						ext_listen_period;	//	The time period to be available for P2P listen state (ms)
+	u16						ext_listen_interval;	/*	The interval to be available with legacy AP (ms) */
+	u16						ext_listen_period;	/*	The time period to be available for P2P listen state (ms) */
 #endif
 #ifdef CONFIG_P2P_PS
-	enum P2P_PS_MODE		p2p_ps_mode; // indicate p2p ps mode
-	enum P2P_PS_STATE		p2p_ps_state; // indicate p2p ps state
-	u8						noa_index; // Identifies and instance of Notice of Absence timing.
-	u8						ctwindow; // Client traffic window. A period of time in TU after TBTT.
-	u8						opp_ps; // opportunistic power save.
-	u8						noa_num; // number of NoA descriptor in P2P IE.
-	u8						noa_count[P2P_MAX_NOA_NUM]; // Count for owner, Type of client.
-	u32						noa_duration[P2P_MAX_NOA_NUM]; // Max duration for owner, preferred or min acceptable duration for client.
-	u32						noa_interval[P2P_MAX_NOA_NUM]; // Length of interval for owner, preferred or max acceptable interval of client.
-	u32						noa_start_time[P2P_MAX_NOA_NUM]; // schedule expressed in terms of the lower 4 bytes of the TSF timer.
-#endif // CONFIG_P2P_PS
+	enum P2P_PS_MODE		p2p_ps_mode; /* indicate p2p ps mode */
+	enum P2P_PS_STATE		p2p_ps_state; /* indicate p2p ps state */
+	u8						noa_index; /* Identifies and instance of Notice of Absence timing. */
+	u8						ctwindow; /* Client traffic window. A period of time in TU after TBTT. */
+	u8						opp_ps; /* opportunistic power save. */
+	u8						noa_num; /* number of NoA descriptor in P2P IE. */
+	u8						noa_count[P2P_MAX_NOA_NUM]; /* Count for owner, Type of client. */
+	u32						noa_duration[P2P_MAX_NOA_NUM]; /* Max duration for owner, preferred or min acceptable duration for client. */
+	u32						noa_interval[P2P_MAX_NOA_NUM]; /* Length of interval for owner, preferred or max acceptable interval of client. */
+	u32						noa_start_time[P2P_MAX_NOA_NUM]; /* schedule expressed in terms of the lower 4 bytes of the TSF timer. */
+#endif /* CONFIG_P2P_PS */
 };
 
-struct tdls_ss_record{	//signal strength record
+struct tdls_ss_record {	/* signal strength record */
 	u8		macaddr[ETH_ALEN];
 	u8		RxPWDBAll;
-	u8		is_tdls_sta;	// _TRUE: direct link sta, _FALSE: else
+	u8		is_tdls_sta;	/* _TRUE: direct link sta, _FALSE: else */
 };
 
-struct tdls_temp_mgmt{
-	u8	initiator;	// 0: None, 1: we initiate, 2: peer initiate
+struct tdls_temp_mgmt {
+	u8	initiator;	/* 0: None, 1: we initiate, 2: peer initiate */
 	u8	peer_addr[ETH_ALEN];
 };
 
 #ifdef CONFIG_TDLS_CH_SW
-struct tdls_ch_switch{
+struct tdls_ch_switch {
 	u32	ch_sw_state;
 	ATOMIC_T	chsw_on;
 	u8	addr[ETH_ALEN];
@@ -448,17 +478,18 @@ struct tdls_ch_switch{
 	u32	cur_time;
 	u8	delay_switch_back;
 	u8	dump_stack;
+	struct submit_ctx	chsw_sctx;
 };
 #endif
 
-struct tdls_info{
+struct tdls_info {
 	u8					ap_prohibited;
 	u8					ch_switch_prohibited;
 	u8					link_established;
 	u8					sta_cnt;
 	u8					sta_maximum;	/* 1:tdls sta is equal (NUM_STA-1), reach max direct link number; 0: else; */
 	struct tdls_ss_record	ss_record;
-#ifdef CONFIG_TDLS_CH_SW	
+#ifdef CONFIG_TDLS_CH_SW
 	struct tdls_ch_switch	chsw_info;
 #endif
 
@@ -469,13 +500,14 @@ struct tdls_info{
 	_lock				hdl_lock;
 	u8					watchdog_count;
 	u8					dev_discovered;		/* WFD_TDLS: for sigma test */
-	u8					tdls_enable;
 
 	/* Let wpa_supplicant to setup*/
 	u8					driver_setup;
 #ifdef CONFIG_WFD
 	struct wifi_display_info		*wfd_info;
-#endif		
+#endif
+
+	struct submit_ctx	*tdls_sctx;
 };
 
 struct tdls_txmgmt {
@@ -499,20 +531,227 @@ struct beacon_keys {
 	u32 ssid_len;
 	u8 bcn_channel;
 	u16 ht_cap_info;
-	u8 ht_info_infos_0_sco; // bit0 & bit1 in infos[0] is second channel offset
+	u8 ht_info_infos_0_sco; /* bit0 & bit1 in infos[0] is second channel offset */
 	int encryp_protocol;
 	int pairwise_cipher;
 	int group_cipher;
 	int is_8021x;
 };
+#ifdef CONFIG_RTW_80211R
+#define RTW_FT_ACTION_REQ_LMT	4
+#define RTW_FT_MAX_IE_SZ	256
+
+enum _rtw_ft_sta_status {
+	RTW_FT_UNASSOCIATED_STA = 0,
+	RTW_FT_AUTHENTICATING_STA,
+	RTW_FT_AUTHENTICATED_STA,
+	RTW_FT_ASSOCIATING_STA,
+	RTW_FT_ASSOCIATED_STA,
+	RTW_FT_REQUESTING_STA,
+	RTW_FT_REQUESTED_STA,
+	RTW_FT_CONFIRMED_STA,
+	RTW_FT_UNSPECIFIED_STA
+};
+
+#define rtw_ft_chk_status(a, s) \
+	((a)->mlmepriv.ft_roam.ft_status == (s))
+
+#define rtw_ft_roam_status(a, s)	\
+	((rtw_to_roam(a) > 0) && rtw_ft_chk_status(a, s))
+
+#define rtw_ft_authed_sta(a)	\
+	((rtw_ft_chk_status(a, RTW_FT_AUTHENTICATED_STA)) ||	\
+	(rtw_ft_chk_status(a, RTW_FT_ASSOCIATING_STA)) ||	\
+	(rtw_ft_chk_status(a, RTW_FT_ASSOCIATED_STA)))
+
+#define rtw_ft_set_status(a, s) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_status = (s)); \
+	} while (0)
+
+#define rtw_ft_lock_set_status(a, s, irq) \
+	do { \
+		_enter_critical_bh(&(a)->mlmepriv.lock, ((_irqL *)(irq)));	\
+		((a)->mlmepriv.ft_roam.ft_status = (s));	\
+		_exit_critical_bh(&(a)->mlmepriv.lock, ((_irqL *)(irq)));	\
+	} while (0)
+
+#define rtw_ft_reset_status(a) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_status = RTW_FT_UNASSOCIATED_STA); \
+	} while (0)
+
+enum rtw_ft_capability {
+	RTW_FT_EN = BIT0,
+	RTW_FT_OTD_EN = BIT1,
+	RTW_FT_PEER_EN = BIT2,
+	RTW_FT_PEER_OTD_EN = BIT3,
+	RTW_FT_BTM_ROAM = BIT4,
+};
+
+#define rtw_ft_chk_flags(a, f) \
+	((a)->mlmepriv.ft_roam.ft_flags & (f))
+
+#define rtw_ft_set_flags(a, f) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_flags |= (f)); \
+	} while (0)
+
+#define rtw_ft_clr_flags(a, f) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_flags &= ~(f)); \
+	} while (0)
+
+#define rtw_ft_roam(a)	\
+	((rtw_to_roam(a) > 0) && rtw_ft_chk_flags(a, RTW_FT_PEER_EN))
+	
+#define rtw_ft_valid_akm(a, t)	\
+	((rtw_ft_chk_flags(a, RTW_FT_EN)) && \
+	(((t) == 3) || ((t) == 4)))
+
+#define rtw_ft_roam_expired(a, r)	\
+	((rtw_chk_roam_flags(a, RTW_ROAM_ON_EXPIRED)) \
+	&& (r == WLAN_REASON_ACTIVE_ROAM))
+
+#define rtw_ft_otd_roam_en(a)	\
+	((rtw_ft_chk_flags(a, RTW_FT_OTD_EN))	\
+	&& ((a)->mlmepriv.ft_roam.ft_roam_on_expired == _FALSE)	\
+	&& ((a)->mlmepriv.ft_roam.ft_cap & 0x01))
+	
+#define rtw_ft_otd_roam(a) \
+	rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN)
+
+#define rtw_ft_valid_otd_candidate(a, p)	\
+	((rtw_ft_chk_flags(a, RTW_FT_OTD_EN)) 	\
+	&& ((rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN)	\
+	&& ((*((p)+4) & 0x01) == 0))	\
+	|| ((rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN) == 0)	\
+	&& (*((p)+4) & 0x01))))
+
+struct ft_roam_info {
+	u16	mdid;
+	u8	ft_cap;	
+	/*b0: FT over DS, b1: Resource Req Protocol Cap, b2~b7: Reserved*/
+	u8	updated_ft_ies[RTW_FT_MAX_IE_SZ];
+	u16	updated_ft_ies_len;
+	u8	ft_action[RTW_FT_MAX_IE_SZ];
+	u16	ft_action_len;
+	struct cfg80211_ft_event_params ft_event;
+	u8	ft_roam_on_expired;
+	u8	ft_flags;
+	u32 ft_status;
+	u32 ft_req_retry_cnt;
+	bool ft_updated_bcn;	
+};
+#endif
+
+#ifdef CONFIG_LAYER2_ROAMING
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+#define RTW_RRM_NB_RPT_EN		BIT(1)
+#define RTW_MAX_NB_RPT_NUM	8
+
+#define rtw_roam_busy_scan(a, nb)	\
+	(((a)->mlmepriv.LinkDetectInfo.bBusyTraffic == _TRUE) && \
+	(((a)->mlmepriv.ch_cnt) < ((nb)->nb_rpt_ch_list_num)))
+
+#define rtw_wnm_btm_preference_cap(a) \
+	((a)->mlmepriv.nb_info.preference_en == _TRUE)
+
+#define rtw_wnm_btm_diff_bss(a) \
+	((rtw_wnm_btm_preference_cap(a)) && \
+	(is_zero_mac_addr((a)->mlmepriv.nb_info.roam_target_addr) == _FALSE) && \
+	(_rtw_memcmp((a)->mlmepriv.nb_info.roam_target_addr,\
+		(a)->mlmepriv.cur_network.network.MacAddress, ETH_ALEN) == _FALSE))
+
+#define rtw_wnm_btm_roam_candidate(a, c) \
+	((rtw_wnm_btm_preference_cap(a)) && \
+	(is_zero_mac_addr((a)->mlmepriv.nb_info.roam_target_addr) == _FALSE) && \
+	(_rtw_memcmp((a)->mlmepriv.nb_info.roam_target_addr,\
+		(c)->network.MacAddress, ETH_ALEN)))
+
+#define rtw_wnm_set_ext_cap_btm(_pEleStart, _val) \
+	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart))+2, 3, 1, _val)
+
+#define wnm_btm_bss_term_inc(p) (*((u8 *)((p)+3)) & BSS_TERMINATION_INCLUDED)
+
+#define wnm_btm_ess_disassoc_im(p) (*((u8 *)((p)+3)) & ESS_DISASSOC_IMMINENT)
+
+#define wnm_btm_req_mode(p) (*((u8 *)((p)+3)))
+
+#define wnm_btm_disassoc_timer(p) (*((u16 *)((p)+4)))
+
+#define wnm_btm_valid_interval(p) (*((u8 *)((p)+6)))
+
+#define wnm_btm_term_duration_offset(p) ((p)+7)
+
+/*IEEE Std 80211k Figure 7-95b Neighbor Report element format*/
+struct nb_rpt_hdr {
+	u8 id; /*0x34: Neighbor Report Element ID*/
+	u8 len;
+	u8 bssid[ETH_ALEN];
+	u32 bss_info;
+	u8 reg_class;
+	u8 ch_num;
+	u8 phy_type;	
+};
+
+/*IEEE Std 80211v, Figure 7-95e2—BSS Termination Duration subelement field format */
+struct btm_term_duration {
+	u8 id;
+	u8 len;
+	u64 tsf;
+	u16 duration;
+};
+
+/*IEEE Std 80211v, Figure 7-101n8—BSS Transition Management Request frame body format */
+struct btm_req_hdr {
+	u8 req_mode;
+	u16 disassoc_timer;
+	u8 validity_interval;
+	struct btm_term_duration term_duration;
+};
+
+/*IEEE Std 80211v,  Table 7-43b Optional Subelement IDs for Neighbor Report*/
+/* BSS Transition Candidate Preference */
+#define WNM_BTM_CAND_PREF_SUBEID 0x03
+
+/* BSS Termination Duration */
+#define WNM_BTM_TERM_DUR_SUBEID		0x04
+
+struct wnm_btm_cant {
+	struct nb_rpt_hdr nb_rpt;
+	u8 preference;	/* BSS Transition Candidate Preference */
+};
+
+enum rtw_btm_req_mod {
+	PREFERRED_CANDIDATE_LIST_INCLUDED = BIT0,
+	ABRIDGED = BIT1,
+	DISASSOC_IMMINENT = BIT2,
+	BSS_TERMINATION_INCLUDED = BIT3,
+	ESS_DISASSOC_IMMINENT = BIT4,
+};
+
+struct roam_nb_info {
+	struct nb_rpt_hdr nb_rpt[RTW_MAX_NB_RPT_NUM];
+	struct rtw_ieee80211_channel nb_rpt_ch_list[RTW_MAX_NB_RPT_NUM];
+	bool	nb_rpt_valid;
+	u8	nb_rpt_ch_list_num;
+	u8 preference_en;
+	u8 roam_target_addr[ETH_ALEN];
+	u32	last_nb_rpt_entries;
+	bool	nb_rpt_is_same;
+	_timer roam_scan_timer;
+};
+#endif	/* defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K) */
+#endif
 
 struct mlme_priv {
 
 	_lock	lock;
-	sint	fw_state;	//shall we protect this variable? maybe not necessarily...
-	u8 bScanInProcess;
-	u8	to_join; //flag
-	#ifdef CONFIG_LAYER2_ROAMING
+	sint	fw_state;	/* shall we protect this variable? maybe not necessarily... */
+	u8	to_join; /* flag */
+	u16 join_status;
+#ifdef CONFIG_LAYER2_ROAMING
 	u8 to_roam; /* roaming trying times */
 	struct wlan_network *roam_network; /* the target of active roam */
 	u8 roam_flags;
@@ -520,13 +759,12 @@ struct mlme_priv {
 	u32 roam_scan_int_ms; /* scan interval for active roam */
 	u32 roam_scanr_exp_ms; /* scan result expire time in ms  for roam */
 	u8 roam_tgt_addr[ETH_ALEN]; /* request to roam to speicific target without other consideration */
-	#endif
+	u8 roam_rssi_threshold;
+	bool need_to_roam;
+#endif
 
 	u8	*nic_hdl;
-
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	u8	not_indic_disco;
-	#endif
+	u32	max_bss_cnt;		/*	The size of scan queue	*/
 	_list		*pscanned;
 	_queue	free_bss_pool;
 	_queue	scanned_queue;
@@ -539,19 +777,20 @@ struct mlme_priv {
 	struct wlan_network	cur_network;
 	struct wlan_network *cur_network_scanned;
 
-	// bcn check info
-	struct beacon_keys cur_beacon_keys; // save current beacon keys
-	struct beacon_keys new_beacon_keys; // save new beacon keys
-	u8 new_beacon_cnts; // if new_beacon_cnts >= threshold, ap beacon is changed
+	/* bcn check info */
+	struct beacon_keys cur_beacon_keys; /* save current beacon keys */
+	struct beacon_keys new_beacon_keys; /* save new beacon keys */
+	u8 new_beacon_cnts; /* if new_beacon_cnts >= threshold, ap beacon is changed */
 
 #ifdef CONFIG_ARP_KEEP_ALIVE
-	// for arp offload keep alive
+	/* for arp offload keep alive */
 	u8 bGetGateway;
+	u8	GetGatewayTryCnt;
 	u8	gw_mac_addr[6];
 	u8	gw_ip[4];
 #endif
 
-	//uint wireless_mode; no used, remove it
+	/* uint wireless_mode; no used, remove it */
 
 	u32	auto_scan_int_ms;
 
@@ -560,13 +799,13 @@ struct mlme_priv {
 	uint assoc_by_bssid;
 	uint assoc_by_rssi;
 
-	_timer scan_to_timer; // driver itself handles scan_timeout status.
-	u32 scan_start_time; // used to evaluate the time spent in scanning
+	_timer scan_to_timer; /* driver itself handles scan_timeout status. */
+	systime scan_start_time; /* used to evaluate the time spent in scanning */
 
-	#ifdef CONFIG_SET_SCAN_DENY_TIMER
+#ifdef CONFIG_SET_SCAN_DENY_TIMER
 	_timer set_scan_deny_timer;
-	ATOMIC_T set_scan_deny; //0: allowed, 1: deny
-	#endif
+	ATOMIC_T set_scan_deny; /* 0: allowed, 1: deny */
+#endif
 
 	struct qos_priv qospriv;
 
@@ -576,7 +815,7 @@ struct mlme_priv {
 	int num_sta_no_ht;
 
 	/* Number of HT AP/stations 20 MHz */
-	//int num_sta_ht_20mhz; 
+	/* int num_sta_ht_20mhz; */
 
 
 	int num_FortyMHzIntolerant;
@@ -589,9 +828,11 @@ struct mlme_priv {
 	struct vht_priv	vhtpriv;
 #endif
 #ifdef CONFIG_BEAMFORMING
+#ifndef RTW_BEAMFORMING_VERSION_2
 #if (BEAMFORMING_SUPPORT == 0)/*for driver beamforming*/
 	struct beamforming_info	beamforming_info;
 #endif
+#endif /* !RTW_BEAMFORMING_VERSION_2 */
 #endif
 
 #ifdef CONFIG_DFS
@@ -601,22 +842,26 @@ struct mlme_priv {
 	/* TODO: move to rfctl */
 	_timer dfs_master_timer;
 #endif
+#ifdef CONFIG_RTW_80211R
+	struct ft_roam_info ft_roam;
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+	struct roam_nb_info nb_info;
+	u8 ch_cnt;
+#endif
 
 	RT_LINK_DETECT_T	LinkDetectInfo;
-	_timer	dynamic_chk_timer; //dynamic/periodic check timer
 
-	u8	acm_mask; // for wmm acm mask
-	const struct country_chplan *country_ent;
-	u8	ChannelPlan;
-	RT_SCAN_TYPE 	scan_mode; // active: 1, passive: 0
+	u8	acm_mask; /* for wmm acm mask */
+	RT_SCAN_TYPE	scan_mode; /* active: 1, passive: 0 */
 
 	u8 *wps_probe_req_ie;
 	u32 wps_probe_req_ie_len;
 
 	u8 ext_capab_ie_data[8];/*currently for ap mode only*/
-	u8 ext_capab_ie_len; 
-	
-#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	u8 ext_capab_ie_len;
+
+#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
 	/* Number of associated Non-ERP stations (i.e., stations using 802.11b
 	 * in 802.11g BSS) */
 	int num_sta_non_erp;
@@ -627,87 +872,103 @@ struct mlme_priv {
 	/* Number of associated stations that do not support Short Preamble */
 	int num_sta_no_short_preamble;
 
-	int olbc; /* Overlapping Legacy BSS Condition (Legacy b/g)*/
+	ATOMIC_T olbc; /* Overlapping Legacy BSS Condition (Legacy b/g)*/
 
 	/* 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;
+	/* int num_sta_no_ht; */
 
 	/* Number of HT associated stations 20 MHz */
 	int num_sta_ht_20mhz;
 
 	/* number of associated stations 40MHz intolerant */
 	int num_sta_40mhz_intolerant;
-	
+
 	/* Overlapping BSS information */
-	int olbc_ht;
-	
+	ATOMIC_T olbc_ht;
+
 #ifdef CONFIG_80211N_HT
-	int ht_20mhz_width_req; 
-	int ht_intolerant_ch_reported;		
+	int ht_20mhz_width_req;
+	int ht_intolerant_ch_reported;
 	u16 ht_op_mode;
 	u8 sw_to_20mhz; /*switch to 20Mhz BW*/
-#endif /* CONFIG_80211N_HT */	
+#endif /* CONFIG_80211N_HT */
 
+#ifdef CONFIG_RTW_80211R
+	u8 *auth_rsp;
+	u32 auth_rsp_len;
+#endif
 	u8 *assoc_req;
 	u32 assoc_req_len;
+
 	u8 *assoc_rsp;
 	u32 assoc_rsp_len;
 
-	u8 *wps_beacon_ie;	
-	//u8 *wps_probe_req_ie;
-	u8 *wps_probe_resp_ie;
-	u8 *wps_assoc_resp_ie; // for CONFIG_IOCTL_CFG80211, this IE could include p2p ie / wfd ie
+	/* u8 *wps_probe_req_ie; */
+	/* u32 wps_probe_req_ie_len; */
 
+	u8 *wps_beacon_ie;
 	u32 wps_beacon_ie_len;
-	//u32 wps_probe_req_ie_len;
+
+	u8 *wps_probe_resp_ie;
 	u32 wps_probe_resp_ie_len;
-	u32 wps_assoc_resp_ie_len; // for CONFIG_IOCTL_CFG80211, this IE len could include p2p ie / wfd ie
-	
-	u8 *p2p_beacon_ie;
-	u8 *p2p_probe_req_ie;
-	u8 *p2p_probe_resp_ie;	
-	u8 *p2p_go_probe_resp_ie; //for GO	
-	u8 *p2p_assoc_req_ie;
-	u8 *p2p_assoc_resp_ie;
 
+	u8 *wps_assoc_resp_ie;
+	u32 wps_assoc_resp_ie_len;
+
+	u8 *p2p_beacon_ie;
 	u32 p2p_beacon_ie_len;
+
+	u8 *p2p_probe_req_ie;
 	u32 p2p_probe_req_ie_len;
+
+	u8 *p2p_probe_resp_ie;
 	u32 p2p_probe_resp_ie_len;
-	u32 p2p_go_probe_resp_ie_len; //for GO
+
+	u8 *p2p_go_probe_resp_ie;		/* for GO */
+	u32 p2p_go_probe_resp_ie_len;	/* for GO */
+
+	u8 *p2p_assoc_req_ie;
 	u32 p2p_assoc_req_ie_len;
+
+	u8 *p2p_assoc_resp_ie;
 	u32 p2p_assoc_resp_ie_len;
-	
+
 	_lock	bcn_update_lock;
 	u8		update_bcn;
-	
+
 	u8 ori_ch;
 	u8 ori_bw;
 	u8 ori_offset;
-#endif //#if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
+	#ifdef CONFIG_80211AC_VHT
+	u8 ori_vht_en;
+	#endif
+#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 
 #if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
-	
 	u8 *wfd_beacon_ie;
-	u8 *wfd_probe_req_ie;
-	u8 *wfd_probe_resp_ie;	
-	u8 *wfd_go_probe_resp_ie; //for GO	
-	u8 *wfd_assoc_req_ie;
-	u8 *wfd_assoc_resp_ie;
-
 	u32 wfd_beacon_ie_len;
+
+	u8 *wfd_probe_req_ie;
 	u32 wfd_probe_req_ie_len;
+
+	u8 *wfd_probe_resp_ie;
 	u32 wfd_probe_resp_ie_len;
-	u32 wfd_go_probe_resp_ie_len; //for GO
+
+	u8 *wfd_go_probe_resp_ie;		/* for GO */
+	u32 wfd_go_probe_resp_ie_len;	/* for GO */
+
+	u8 *wfd_assoc_req_ie;
 	u32 wfd_assoc_req_ie_len;
-	u32 wfd_assoc_resp_ie_len;
 
+	u8 *wfd_assoc_resp_ie;
+	u32 wfd_assoc_resp_ie_len;
 #endif
 
 #ifdef RTK_DMP_PLATFORM
-	// DMP kobject_hotplug function  signal need in passive level
+	/* DMP kobject_hotplug function  signal need in passive level */
 	_workitem	Linkup_workitem;
 	_workitem	Linkdown_workitem;
 #endif
@@ -716,10 +977,10 @@ struct mlme_priv {
 	int	widi_state;
 	int	listen_state;
 	_timer	listen_timer;
-	ATOMIC_T	rx_probe_rsp; // 1:receive probe respone from RDS source.
+	ATOMIC_T	rx_probe_rsp; /* 1:receive probe respone from RDS source. */
 	u8	*l2sdTaBuffer;
 	u8	channel_idx;
-	u8	group_cnt;	//In WiDi 3.5, they specified another scan algo. for WFD/RDS co-existed
+	u8	group_cnt;	/* In WiDi 3.5, they specified another scan algo. for WFD/RDS co-existed */
 	u8	sa_ext[L2SDTA_SERVICE_VE_LEN];
 
 	u8	widi_enable;
@@ -735,42 +996,55 @@ struct mlme_priv {
 	u8	num_p2p_sdt;
 	u16	p2p_sdt_cid[MAX_NUM_P2P_SDT];
 	u16	p2p_sdt_scid[MAX_NUM_P2P_SDT];
-	u8	p2p_reject_disable;	//When starting NL80211 wpa_supplicant/hostapd, it will call netdev_close
-							//such that it will cause p2p disabled. Use this flag to reject.
-#endif // CONFIG_INTEL_WIDI
-
+	u8	p2p_reject_disable;	/* When starting NL80211 wpa_supplicant/hostapd, it will call netdev_close */
+							/* such that it will cause p2p disabled. Use this flag to reject. */
+#endif /* CONFIG_INTEL_WIDI */
+	systime lastscantime;
 #ifdef CONFIG_CONCURRENT_MODE
 	u8	scanning_via_buddy_intf;
 #endif
 
-//	u8 	NumOfBcnInfoChkFail;
-//	u32	timeBcnInfoChkStart;
+#if 0
+	u8	NumOfBcnInfoChkFail;
+	u32	timeBcnInfoChkStart;
+#endif
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	u32 vendor_ie_mask[WLAN_MAX_VENDOR_IE_NUM];
+	u8 vendor_ie[WLAN_MAX_VENDOR_IE_NUM][WLAN_MAX_VENDOR_IE_LEN];
+	u32 vendor_ielen[WLAN_MAX_VENDOR_IE_NUM];
+#endif
 };
 
 #define mlme_set_scan_to_timer(mlme, ms) \
 	do { \
-		/* DBG_871X("%s set_scan_to_timer(%p, %d)\n", __FUNCTION__, (mlme), (ms)); */ \
+		/* RTW_INFO("%s set_scan_to_timer(%p, %d)\n", __FUNCTION__, (mlme), (ms)); */ \
 		_set_timer(&(mlme)->scan_to_timer, (ms)); \
-	} while(0)
+	} while (0)
 
 #define rtw_mlme_set_auto_scan_int(adapter, ms) \
 	do { \
 		adapter->mlmepriv.auto_scan_int_ms = ms; \
 	} while (0)
 
-void rtw_mlme_reset_auto_scan_int(_adapter *adapter);
+#define RTW_AUTO_SCAN_REASON_UNSPECIFIED		0
+#define RTW_AUTO_SCAN_REASON_2040_BSS			BIT0
+#define RTW_AUTO_SCAN_REASON_ACS				BIT1
+#define RTW_AUTO_SCAN_REASON_ROAM				BIT2
+#define RTW_AUTO_SCAN_REASON_MESH_OFFCH_CAND	BIT3
+
+void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason);
 
 #ifdef CONFIG_AP_MODE
 
-struct hostapd_priv
-{
+struct hostapd_priv {
 	_adapter *padapter;
 
 #ifdef CONFIG_HOSTAPD_MLME
 	struct net_device *pmgnt_netdev;
 	struct usb_anchor anchored;
-#endif	
-	
+#endif
+
 };
 
 extern int hostapd_mode_init(_adapter *padapter);
@@ -778,41 +1052,56 @@ extern void hostapd_mode_unload(_adapter *padapter);
 #endif
 
 
-extern void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf);
+extern void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf, u16 status);
 extern void rtw_survey_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_surveydone_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_joinbss_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf);
+void rtw_sta_mstatus_disc_rpt(_adapter *adapter, u8 mac_id);
+void rtw_sta_mstatus_report(_adapter *adapter);
 extern void rtw_atimdone_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_cpwm_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_wmm_event_callback(PADAPTER padapter, u8 *pbuf);
 #ifdef CONFIG_IEEE80211W
 void rtw_sta_timeout_event_callback(_adapter *adapter, u8 *pbuf);
 #endif /* CONFIG_IEEE80211W */
-extern void rtw_join_timeout_handler(RTW_TIMER_HDL_ARGS);
-extern void _rtw_scan_timeout_handler(RTW_TIMER_HDL_ARGS);
+#ifdef CONFIG_RTW_80211R
+void rtw_ft_info_init(struct ft_roam_info *pft);
+u8 rtw_ft_chk_roaming_candidate(_adapter *padapter, 
+	struct wlan_network *competitor);
+void rtw_ft_update_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork);
+void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf);
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+void rtw_roam_nb_info_init(_adapter *padapter);
+#endif
 
 thread_return event_thread(thread_context context);
 
-extern void rtw_free_network_queue(_adapter *adapter,u8 isfreeall);
-extern int rtw_init_mlme_priv(_adapter *adapter);// (struct mlme_priv *pmlmepriv);
+extern void rtw_free_network_queue(_adapter *adapter, u8 isfreeall);
+extern int rtw_init_mlme_priv(_adapter *adapter);/* (struct mlme_priv *pmlmepriv); */
 
-extern void rtw_free_mlme_priv (struct mlme_priv *pmlmepriv);
+extern void rtw_free_mlme_priv(struct mlme_priv *pmlmepriv);
 
 
 extern sint rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv);
-extern sint rtw_set_key(_adapter *adapter,struct security_priv *psecuritypriv,sint keyid, u8 set_tx, bool enqueue);
-extern sint rtw_set_auth(_adapter *adapter,struct security_priv *psecuritypriv);
+extern sint rtw_set_key(_adapter *adapter, struct security_priv *psecuritypriv, sint keyid, u8 set_tx, bool enqueue);
+extern sint rtw_set_auth(_adapter *adapter, struct security_priv *psecuritypriv);
 
 __inline static 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
+{
+	/* 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;
 }
 
 __inline static sint check_fwstate(struct mlme_priv *pmlmepriv, sint state)
 {
+	if ((state == WIFI_NULL_STATE) &&
+		(pmlmepriv->fw_state == WIFI_NULL_STATE))
+		return _TRUE;
+
 	if (pmlmepriv->fw_state & state)
 		return _TRUE;
 
@@ -831,29 +1120,30 @@ __inline static sint get_fwstate(struct mlme_priv *pmlmepriv)
  * ### NOTE:#### (!!!!)
  * MUST TAKE CARE THAT BEFORE CALLING THIS FUNC, YOU SHOULD HAVE LOCKED pmlmepriv->lock
  */
-__inline static void set_fwstate(struct mlme_priv *pmlmepriv, sint state)
+extern void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state);
+
+static inline void set_fwstate(struct mlme_priv *pmlmepriv, sint state)
 {
 	pmlmepriv->fw_state |= state;
-	//FOR HW integration
-	if(_FW_UNDER_SURVEY==state){
-		pmlmepriv->bScanInProcess = _TRUE;
-	}
+	rtw_mi_update_iface_status(pmlmepriv, state);
+}
+static inline void init_fwstate(struct mlme_priv *pmlmepriv, sint state)
+{
+	pmlmepriv->fw_state = state;
+	rtw_mi_update_iface_status(pmlmepriv, state);
 }
 
-__inline static void _clr_fwstate_(struct mlme_priv *pmlmepriv, sint state)
+static inline void _clr_fwstate_(struct mlme_priv *pmlmepriv, sint state)
 {
 	pmlmepriv->fw_state &= ~state;
-	//FOR HW integration
-	if(_FW_UNDER_SURVEY==state){
-		pmlmepriv->bScanInProcess = _FALSE;
-	}
+	rtw_mi_update_iface_status(pmlmepriv, state);
 }
 
 /*
  * No Limit on the calling context,
  * therefore set it to be the critical section...
  */
-__inline static void clr_fwstate(struct mlme_priv *pmlmepriv, sint state)
+static inline void clr_fwstate(struct mlme_priv *pmlmepriv, sint state)
 {
 	_irqL irqL;
 
@@ -862,7 +1152,7 @@ __inline static void clr_fwstate(struct mlme_priv *pmlmepriv, sint state)
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 }
 
-__inline static void up_scanned_network(struct mlme_priv *pmlmepriv)
+static inline void up_scanned_network(struct mlme_priv *pmlmepriv)
 {
 	_irqL irqL;
 
@@ -870,12 +1160,7 @@ __inline static void up_scanned_network(struct mlme_priv *pmlmepriv)
 	pmlmepriv->num_of_scanned++;
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 }
-
-#ifdef CONFIG_CONCURRENT_MODE
-sint rtw_buddy_adapter_up(_adapter *padapter);
-sint check_buddy_fwstate(_adapter *padapter, sint state);
-u8 rtw_get_buddy_bBusyTraffic(_adapter *padapter);
-#endif //CONFIG_CONCURRENT_MODE
+u8 rtw_is_adapter_up(_adapter *padapter);
 
 __inline static void down_scanned_network(struct mlme_priv *pmlmepriv)
 {
@@ -896,26 +1181,32 @@ __inline static void set_scanned_network_val(struct mlme_priv *pmlmepriv, sint v
 }
 
 extern u16 rtw_get_capability(WLAN_BSSID_EX *bss);
-extern void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target);
-extern void rtw_disconnect_hdl_under_linked(_adapter* adapter, struct sta_info *psta, u8 free_assoc);
+extern bool rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target);
+extern void rtw_disconnect_hdl_under_linked(_adapter *adapter, struct sta_info *psta, u8 free_assoc);
 extern void rtw_generate_random_ibss(u8 *pibss);
-extern struct wlan_network* rtw_find_network(_queue *scanned_queue, u8 *addr);
-extern struct wlan_network* rtw_get_oldest_wlan_network(_queue *scanned_queue);
+struct wlan_network *_rtw_find_network(_queue *scanned_queue, const u8 *addr);
+struct wlan_network *rtw_find_network(_queue *scanned_queue, const u8 *addr);
+extern struct wlan_network *rtw_get_oldest_wlan_network(_queue *scanned_queue);
 struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network);
 struct wlan_network *rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network);
 
-extern void rtw_free_assoc_resources(_adapter* adapter, int lock_scanned_queue);
+extern void rtw_free_assoc_resources(_adapter *adapter, u8 lock_scanned_queue);
 extern void rtw_indicate_disconnect(_adapter *adapter, u16 reason, u8 locally_generated);
-extern void rtw_indicate_connect(_adapter* adapter);
-void rtw_indicate_scan_done( _adapter *padapter, bool aborted);
+extern void rtw_indicate_connect(_adapter *adapter);
+void rtw_indicate_scan_done(_adapter *padapter, bool aborted);
 
-void rtw_drv_scan_by_self(_adapter *padapter);
+void rtw_drv_scan_by_self(_adapter *padapter, u8 reason);
 void rtw_scan_wait_completed(_adapter *adapter);
 u32 rtw_scan_abort_timeout(_adapter *adapter, u32 timeout_ms);
 void rtw_scan_abort_no_wait(_adapter *adapter);
 void rtw_scan_abort(_adapter *adapter);
+u32 rtw_join_abort_timeout(_adapter *adapter, u32 timeout_ms);
 
-extern int rtw_restruct_sec_ie(_adapter *adapter,u8 *in_ie,u8 *out_ie,uint in_len);
+extern int rtw_restruct_sec_ie(_adapter *adapter, u8 *out_ie);
+#ifdef CONFIG_WMMPS_STA
+void rtw_uapsd_use_default_setting(_adapter *padapter);
+bool rtw_is_wmmps_mode(_adapter *padapter);
+#endif /* CONFIG_WMMPS_STA */
 extern int rtw_restruct_wmm_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len, uint initial_out_len);
 extern void rtw_init_registrypriv_dev_network(_adapter *adapter);
 
@@ -923,19 +1214,20 @@ extern void rtw_update_registrypriv_dev_network(_adapter *adapter);
 
 extern void rtw_get_encrypt_decrypt_from_registrypriv(_adapter *adapter);
 
-extern void _rtw_join_timeout_handler(_adapter *adapter);
-extern void rtw_scan_timeout_handler(_adapter *adapter);
+extern void rtw_join_timeout_handler(void *ctx);
+extern void rtw_scan_timeout_handler(void *ctx);
+
+extern void rtw_dynamic_check_timer_handlder(void *ctx);
+extern void rtw_iface_dynamic_check_timer_handlder(_adapter *adapter);
 
-extern void rtw_dynamic_check_timer_handlder(_adapter *adapter);
 #ifdef CONFIG_SET_SCAN_DENY_TIMER
 bool rtw_is_scan_deny(_adapter *adapter);
 void rtw_clear_scan_deny(_adapter *adapter);
-void rtw_set_scan_deny_timer_hdl(_adapter *adapter);
+void rtw_set_scan_deny_timer_hdl(void *ctx);
 void rtw_set_scan_deny(_adapter *adapter, u32 ms);
 #else
 #define rtw_is_scan_deny(adapter) _FALSE
 #define rtw_clear_scan_deny(adapter) do {} while (0)
-#define rtw_set_scan_deny_timer_hdl(adapter) do {} while (0)
 #define rtw_set_scan_deny(adapter, ms) do {} while (0)
 #endif
 
@@ -952,23 +1244,16 @@ void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv);
 int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_len);
 #endif
 
-extern int _rtw_init_mlme_priv(_adapter *padapter);
-extern void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv);
-
-extern int _rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork);
 
-//extern struct wlan_network* _rtw_dequeue_network(_queue *queue);
+/* extern struct wlan_network* _rtw_dequeue_network(_queue *queue); */
 
-extern struct wlan_network* _rtw_alloc_network(struct mlme_priv *pmlmepriv);
+extern struct wlan_network *_rtw_alloc_network(struct mlme_priv *pmlmepriv);
 
 
 extern void _rtw_free_network(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork, u8 isfreeall);
 extern void _rtw_free_network_nolock(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork);
 
-
-extern struct wlan_network* _rtw_find_network(_queue *scanned_queue, u8 *addr);
-
-extern void _rtw_free_network_queue(_adapter* padapter, u8 isfreeall);
+extern void _rtw_free_network_queue(_adapter *padapter, u8 isfreeall);
 
 extern sint rtw_if_up(_adapter *padapter);
 
@@ -1023,9 +1308,9 @@ int rtw_select_roaming_candidate(struct mlme_priv *pmlmepriv);
 #define rtw_clr_roam_flags(adapter, flags) do {} while (0)
 #define rtw_set_roam_flags(adapter, flags) do {} while (0)
 #define rtw_assign_roam_flags(adapter, flags) do {} while (0)
-#define _rtw_roaming(adapter, tgt_network) do {} while(0)
-#define rtw_roaming(adapter, tgt_network) do {} while(0)
-#define rtw_set_to_roam(adapter, to_roam) do {} while(0)
+#define _rtw_roaming(adapter, tgt_network) do {} while (0)
+#define rtw_roaming(adapter, tgt_network) do {} while (0)
+#define rtw_set_to_roam(adapter, to_roam) do {} while (0)
 #define rtw_dec_to_roam(adapter) 0
 #define rtw_to_roam(adapter) 0
 #define rtw_select_roaming_candidate(mlme) _FAIL
@@ -1041,12 +1326,13 @@ struct sta_media_status_rpt_cmd_parm {
 void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool connected);
 u8 rtw_sta_media_status_rpt_cmd(_adapter *adapter, struct sta_info *sta, bool connected);
 void rtw_sta_media_status_rpt_cmd_hdl(_adapter *adapter, struct sta_media_status_rpt_cmd_parm *parm);
+void rtw_sta_traffic_info(void *sel, _adapter *adapter);
 
 #ifdef CONFIG_INTEL_PROXIM
 void rtw_proxim_enable(_adapter *padapter);
 void rtw_proxim_disable(_adapter *padapter);
-void rtw_proxim_send_packet(_adapter *padapter,u8 *pbuf,u16 len,u8 hw_rate);
-#endif //CONFIG_INTEL_PROXIM
+void rtw_proxim_send_packet(_adapter *padapter, u8 *pbuf, u16 len, u8 m_rate);
+#endif /* CONFIG_INTEL_PROXIM */
 
 #define IPV4_SRC(_iphdr)			(((u8 *)(_iphdr)) + 12)
 #define IPV4_DST(_iphdr)			(((u8 *)(_iphdr)) + 16)
@@ -1074,5 +1360,4 @@ void rtw_proxim_send_packet(_adapter *padapter,u8 *pbuf,u16 len,u8 hw_rate);
 #define GET_TCP_ECE(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 6, 1)
 #define GET_TCP_CWR(_tcphdr)			BE_BITS_TO_1BYTE(((u8 *)(_tcphdr)) + 13, 7, 1)
 
-#endif //__RTL871X_MLME_H_
-
+#endif /* __RTL871X_MLME_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme_ext.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme_ext.h
index d7829b34549e..e984aaf2e44f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme_ext.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mlme_ext.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,29 +12,24 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_MLME_EXT_H_
 #define __RTW_MLME_EXT_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.
-
+/*	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 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 LINKED_TO (1) /* unit:2 sec, 1x2 = 2 sec */
 
 #define REAUTH_LIMIT	(4)
 #define REASSOC_LIMIT	(4)
@@ -44,19 +40,19 @@
 #else
 	#define ROAMING_LIMIT	8
 #endif
-//#define	IOCMD_REG0		0x10250370		 	
-//#define	IOCMD_REG1		0x10250374
-//#define	IOCMD_REG2		0x10250378
+/* #define	IOCMD_REG0		0x10250370 */
+/* #define	IOCMD_REG1		0x10250374 */
+/* #define	IOCMD_REG2		0x10250378 */
 
-//#define	FW_DYNAMIC_FUN_SWITCH	0x10250364
+/* #define	FW_DYNAMIC_FUN_SWITCH	0x10250364 */
 
-//#define	WRITE_BB_CMD		0xF0000001
-//#define	SET_CHANNEL_CMD	0xF3000000
-//#define	UPDATE_RA_CMD	0xFD0000A2
+/* #define	WRITE_BB_CMD		0xF0000001 */
+/* #define	SET_CHANNEL_CMD	0xF3000000 */
+/* #define	UPDATE_RA_CMD	0xFD0000A2 */
 
 #define _HW_STATE_NOLINK_		0x00
 #define _HW_STATE_ADHOC_		0x01
-#define _HW_STATE_STATION_ 	0x02
+#define _HW_STATE_STATION_	0x02
 #define _HW_STATE_AP_			0x03
 #define _HW_STATE_MONITOR_ 0x04
 
@@ -93,8 +89,7 @@ extern unsigned char P2P_OUI[];
 extern unsigned char WMM_INFO_OUI[];
 extern unsigned char WMM_PARA_OUI[];
 
-typedef enum _RT_CHANNEL_DOMAIN
-{
+typedef enum _RT_CHANNEL_DOMAIN {
 	/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
 	RTW_CHPLAN_FCC = 0x00,
 	RTW_CHPLAN_IC = 0x01,
@@ -130,6 +125,11 @@ typedef enum _RT_CHANNEL_DOMAIN
 	RTW_CHPLAN_WORLD_KCC1 = 0x28,
 	RTW_CHPLAN_WORLD_FCC2 = 0x29,
 	RTW_CHPLAN_FCC2_NULL = 0x2A,
+	RTW_CHPLAN_IC1_IC2 = 0x2B,
+	RTW_CHPLAN_MKK2_NULL = 0x2C,
+	RTW_CHPLAN_WORLD_CHILE1= 0x2D,
+	RTW_CHPLAN_WORLD1_WORLD1 = 0x2E,
+	RTW_CHPLAN_WORLD_CHILE2 = 0x2F,
 	RTW_CHPLAN_WORLD_FCC3 = 0x30,
 	RTW_CHPLAN_WORLD_FCC4 = 0x31,
 	RTW_CHPLAN_WORLD_FCC5 = 0x32,
@@ -140,12 +140,16 @@ typedef enum _RT_CHANNEL_DOMAIN
 	RTW_CHPLAN_MKK1_MKK2 = 0x37,
 	RTW_CHPLAN_MKK1_MKK3 = 0x38,
 	RTW_CHPLAN_FCC1_NCC1 = 0x39,
+	RTW_CHPLAN_ETSI1_ETSI1 = 0x3A,
+	RTW_CHPLAN_ETSI1_ACMA1 = 0x3B,
+	RTW_CHPLAN_ETSI1_ETSI6 = 0x3C,
+	RTW_CHPLAN_ETSI1_ETSI12 = 0x3D,
 	RTW_CHPLAN_FCC1_NCC2 = 0x40,
 	RTW_CHPLAN_GLOBAL_NULL = 0x41,
 	RTW_CHPLAN_ETSI1_ETSI4 = 0x42,
 	RTW_CHPLAN_FCC1_FCC2 = 0x43,
 	RTW_CHPLAN_FCC1_NCC3 = 0x44,
-	RTW_CHPLAN_WORLD_ETSI5 = 0x45,
+	RTW_CHPLAN_WORLD_ACMA1 = 0x45,
 	RTW_CHPLAN_FCC1_FCC8 = 0x46,
 	RTW_CHPLAN_WORLD_ETSI6 = 0x47,
 	RTW_CHPLAN_WORLD_ETSI7 = 0x48,
@@ -161,150 +165,117 @@ typedef enum _RT_CHANNEL_DOMAIN
 	RTW_CHPLAN_MKK2_MKK4 = 0x58,
 	RTW_CHPLAN_WORLD_ETSI14 = 0x59,
 	RTW_CHPLAN_FCC1_FCC5 = 0x60,
+	RTW_CHPLAN_FCC2_FCC7 = 0x61,
+	RTW_CHPLAN_FCC2_FCC1 = 0x62,
+	RTW_CHPLAN_WORLD_ETSI15 = 0x63,
+	RTW_CHPLAN_MKK2_MKK5 = 0x64,
+	RTW_CHPLAN_ETSI1_ETSI16 = 0x65,
+	RTW_CHPLAN_FCC1_FCC14 = 0x66,
+	RTW_CHPLAN_FCC1_FCC12 = 0x67,
+	RTW_CHPLAN_FCC2_FCC14 = 0x68,
+	RTW_CHPLAN_FCC2_FCC12 = 0x69,
+	RTW_CHPLAN_ETSI1_ETSI17 = 0x6A,
+	RTW_CHPLAN_WORLD_FCC16 = 0x6B,
+	RTW_CHPLAN_WORLD_FCC13 = 0x6C,
+	RTW_CHPLAN_FCC2_FCC15 = 0x6D,
+	RTW_CHPLAN_WORLD_FCC12 = 0x6E,
+	RTW_CHPLAN_NULL_ETSI8 = 0x6F,
+	RTW_CHPLAN_NULL_ETSI18 = 0x70,
+	RTW_CHPLAN_NULL_ETSI17 = 0x71,
+	RTW_CHPLAN_NULL_ETSI19 = 0x72,
+	RTW_CHPLAN_WORLD_FCC7 = 0x73,
+	RTW_CHPLAN_FCC2_FCC17 = 0x74,
+	RTW_CHPLAN_WORLD_ETSI20 = 0x75,
+	RTW_CHPLAN_FCC2_FCC11 = 0x76,
+	RTW_CHPLAN_WORLD_ETSI21 = 0x77,
+	RTW_CHPLAN_FCC1_FCC18 = 0x78,
+	RTW_CHPLAN_MKK2_MKK1 = 0x79,
 
 	RTW_CHPLAN_MAX,
 	RTW_CHPLAN_REALTEK_DEFINE = 0x7F,
-}RT_CHANNEL_DOMAIN, *PRT_CHANNEL_DOMAIN;
-
-typedef enum _RT_CHANNEL_DOMAIN_2G
-{
-	RTW_RD_2G_NULL = 0,
-	RTW_RD_2G_WORLD = 1,	/* Worldwird 13 */
-	RTW_RD_2G_ETSI1 = 2,	/* Europe */
-	RTW_RD_2G_FCC1 = 3,		/* US */
-	RTW_RD_2G_MKK1 = 4,		/* Japan */
-	RTW_RD_2G_ETSI2 = 5,	/* France */
-	RTW_RD_2G_GLOBAL = 6,	/* Global domain */
-	RTW_RD_2G_MKK2 = 7,		/* Japan */
-	RTW_RD_2G_FCC2 = 8,		/* US */
-
-	RTW_RD_2G_MAX,
-}RT_CHANNEL_DOMAIN_2G, *PRT_CHANNEL_DOMAIN_2G;
-
-typedef enum _RT_CHANNEL_DOMAIN_5G
-{
-	RTW_RD_5G_NULL = 0,		/*	*/
-	RTW_RD_5G_ETSI1 = 1,	/* Europe */
-	RTW_RD_5G_ETSI2 = 2,	/* Australia, New Zealand */
-	RTW_RD_5G_ETSI3 = 3,	/* Russia */
-	RTW_RD_5G_FCC1 = 4,		/* US */
-	RTW_RD_5G_FCC2 = 5,		/* FCC w/o DFS Channels */
-	RTW_RD_5G_FCC3 = 6,		/* Bolivia, Chile, El Salvador, Venezuela */
-	RTW_RD_5G_FCC4 = 7,		/* Venezuela */
-	RTW_RD_5G_FCC5 = 8,		/* China */
-	RTW_RD_5G_FCC6 = 9,		/*	*/
-	RTW_RD_5G_FCC7 = 10,	/* US Canada(w/o Weather radar) */
-	RTW_RD_5G_KCC1 = 11,	/* Korea */
-	RTW_RD_5G_MKK1 = 12,	/* Japan */
-	RTW_RD_5G_MKK2 = 13,	/* Japan (W52, W53) */
-	RTW_RD_5G_MKK3 = 14,	/* Japan (W56) */
-	RTW_RD_5G_NCC1 = 15,	/* Taiwan, (w/o Weather radar) */
-	RTW_RD_5G_NCC2 = 16,	/* Taiwan, Band2, Band4 */
-	RTW_RD_5G_NCC3 = 17,	/* Taiwan w/o DFS, Band4 only */
-	RTW_RD_5G_ETSI4 = 18,	/* Europe w/o DFS, Band1 only */
-	RTW_RD_5G_ETSI5 = 19,	/* Australia, New Zealand(w/o Weather radar) */
-	RTW_RD_5G_FCC8 = 20,	/* Latin America */
-	RTW_RD_5G_ETSI6 = 21,	/* Israel, Bahrain, Egypt, India, China, Malaysia */
-	RTW_RD_5G_ETSI7 = 22,	/* China */
-	RTW_RD_5G_ETSI8 = 23,	/* Jordan */
-	RTW_RD_5G_ETSI9 = 24,	/* Lebanon */
-	RTW_RD_5G_ETSI10 = 25,	/* Qatar */
-	RTW_RD_5G_ETSI11 = 26,	/* Russia */
-	RTW_RD_5G_NCC4 = 27,	/* Taiwan, (w/o Weather radar) */
-	RTW_RD_5G_ETSI12 = 28,	/* Indonesia */
-	RTW_RD_5G_FCC9 = 29,	/* (w/o Weather radar) */
-	RTW_RD_5G_ETSI13 = 30,	/* (w/o Weather radar) */
-	RTW_RD_5G_FCC10 = 31,	/* Argentina(w/o Weather radar) */
-	RTW_RD_5G_MKK4 = 32,	/* Japan (W52) */
-	RTW_RD_5G_ETSI14 = 33,	/* Russia */
-
-	/* === Below are driver defined for legacy channel plan compatible, DON'T assign index ==== */
-	RTW_RD_5G_OLD_FCC1,
-	RTW_RD_5G_OLD_NCC1,
-	RTW_RD_5G_OLD_KCC1,
-
-	RTW_RD_5G_MAX,
-}RT_CHANNEL_DOMAIN_5G, *PRT_CHANNEL_DOMAIN_5G;
+	RTW_CHPLAN_UNSPECIFIED = 0xFF,
+} RT_CHANNEL_DOMAIN, *PRT_CHANNEL_DOMAIN;
 
 bool rtw_chplan_is_empty(u8 id);
 #define rtw_is_channel_plan_valid(chplan) (((chplan) < RTW_CHPLAN_MAX || (chplan) == RTW_CHPLAN_REALTEK_DEFINE) && !rtw_chplan_is_empty(chplan))
 #define rtw_is_legacy_channel_plan(chplan) ((chplan) < 0x20)
 
-typedef struct _RT_CHANNEL_PLAN
-{
+typedef struct _RT_CHANNEL_PLAN {
 	unsigned char	Channel[MAX_CHANNEL_NUM];
 	unsigned char	Len;
-}RT_CHANNEL_PLAN, *PRT_CHANNEL_PLAN;
+} RT_CHANNEL_PLAN, *PRT_CHANNEL_PLAN;
 
-typedef struct _RT_CHANNEL_PLAN_2G
-{
-	unsigned char	Channel[MAX_CHANNEL_NUM_2G];
-	unsigned char	Len;
-}RT_CHANNEL_PLAN_2G, *PRT_CHANNEL_PLAN_2G;
+struct ch_list_t {
+	u8 *len_ch;
+};
 
-typedef struct _RT_CHANNEL_PLAN_5G
-{
-	unsigned char	Channel[MAX_CHANNEL_NUM_5G];
-	unsigned char	Len;
-}RT_CHANNEL_PLAN_5G, *PRT_CHANNEL_PLAN_5G;
+#define CH_LIST_ENT(_len, arg...) \
+	{.len_ch = (u8[_len + 1]) {_len, ##arg}, }
 
-typedef struct _RT_CHANNEL_PLAN_MAP
-{
+#define CH_LIST_LEN(_ch_list) (_ch_list.len_ch[0])
+#define CH_LIST_CH(_ch_list, _i) (_ch_list.len_ch[_i + 1])
+
+typedef struct _RT_CHANNEL_PLAN_MAP {
 	u8 Index2G;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
 	u8 Index5G;
+#endif
 	u8 regd; /* value of REGULATION_TXPWR_LMT */
-}RT_CHANNEL_PLAN_MAP, *PRT_CHANNEL_PLAN_MAP;
+} RT_CHANNEL_PLAN_MAP, *PRT_CHANNEL_PLAN_MAP;
 
-enum Associated_AP
-{
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+#define CHPLAN_ENT(i2g, i5g, regd) {i2g, i5g, regd}
+#else
+#define CHPLAN_ENT(i2g, i5g, regd) {i2g, regd}
+#endif
+
+enum Associated_AP {
 	atherosAP	= 0,
 	broadcomAP	= 1,
 	ciscoAP		= 2,
 	marvellAP	= 3,
 	ralinkAP	= 4,
 	realtekAP	= 5,
-	airgocapAP 	= 6,
+	airgocapAP	= 6,
 	unknownAP	= 7,
 	maxAP,
 };
 
-typedef enum _HT_IOT_PEER
-{
-	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,
+typedef enum _HT_IOT_PEER {
+	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_REALTEK_JAGUAR_BCUTAP = 16,
 	HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,
-	HT_IOT_PEER_MAX 				= 18
-}HT_IOT_PEER_E, *PHTIOT_PEER_E;
+	HT_IOT_PEER_MAX				= 18
+} HT_IOT_PEER_E, *PHTIOT_PEER_E;
 
 struct mlme_handler {
 	unsigned int   num;
-	char* str;
+	char *str;
 	unsigned int (*func)(_adapter *padapter, union recv_frame *precv_frame);
 };
 
 struct action_handler {
 	unsigned int   num;
-	char* str;
+	char *str;
 	unsigned int (*func)(_adapter *padapter, union recv_frame *precv_frame);
 };
 
-enum SCAN_STATE
-{
+enum SCAN_STATE {
 	SCAN_DISABLE = 0,
 	SCAN_START = 1,
 	SCAN_PS_ANNC_WAIT = 2,
@@ -321,7 +292,7 @@ enum SCAN_STATE
 	SCAN_SW_ANTDIV_BL = 9,
 
 	/* legacy p2p */
-	SCAN_TO_P2P_LISTEN = 10, 
+	SCAN_TO_P2P_LISTEN = 10,
 	SCAN_P2P_LISTEN = 11,
 
 	SCAN_COMPLETE = 12,
@@ -343,19 +314,28 @@ struct ss_res {
 	u8 next_state; /* will set to state on next cmd hdl */
 	int	bss_cnt;
 	int	channel_idx;
+#ifdef CONFIG_DFS
+	u8 dfs_ch_ssid_scan;
+#endif
 	int	scan_mode;
 	u16 scan_ch_ms;
+	u32 scan_timeout_ms;
 	u8 rx_ampdu_accept;
 	u8 rx_ampdu_size;
 	u8 igi_scan;
 	u8 igi_before_scan; /* used for restoring IGI value without enable DIG & FA_CNT */
 #ifdef CONFIG_SCAN_BACKOP
 	u8 backop_flags_sta; /* policy for station mode*/
+	#ifdef CONFIG_AP_MODE
 	u8 backop_flags_ap; /* policy for ap mode */
+	#endif
+	#ifdef CONFIG_RTW_MESH
+	u8 backop_flags_mesh; /* policy for mesh mode */
+	#endif
 	u8 backop_flags; /* per backop runtime decision */
 	u8 scan_cnt;
 	u8 scan_cnt_max;
-	u32 backop_time; /* the start time of backop */
+	systime backop_time; /* the start time of backop */
 	u16 backop_ms;
 #endif
 #if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
@@ -365,18 +345,24 @@ struct ss_res {
 	u8 ch_num;
 	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];
 	struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
+
+	u32 token; 	/* 0: use to identify caller */
+	u16 duration;	/* 0: use default */
+	u8 igi;		/* 0: use defalut */
+	u8 bw;		/* 0: use default */
 };
 
-//#define AP_MODE				0x0C
-//#define STATION_MODE	0x08
-//#define AD_HOC_MODE		0x04
-//#define NO_LINK_MODE	0x00
+/* #define AP_MODE				0x0C */
+/* #define STATION_MODE	0x08 */
+/* #define AD_HOC_MODE		0x04 */
+/* #define NO_LINK_MODE	0x00 */
 
-#define 	WIFI_FW_NULL_STATE			_HW_STATE_NOLINK_
+#define	WIFI_FW_NULL_STATE			_HW_STATE_NOLINK_
 #define	WIFI_FW_STATION_STATE		_HW_STATE_STATION_
 #define	WIFI_FW_AP_STATE				_HW_STATE_AP_
 #define	WIFI_FW_ADHOC_STATE			_HW_STATE_ADHOC_
 
+#define WIFI_FW_PRE_LINK			0x00000800
 #define	WIFI_FW_AUTH_NULL			0x00000100
 #define	WIFI_FW_AUTH_STATE			0x00000200
 #define	WIFI_FW_AUTH_SUCCESS			0x00000400
@@ -384,60 +370,73 @@ struct ss_res {
 #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)
+#define	WIFI_FW_LINKING_STATE		(WIFI_FW_AUTH_NULL | WIFI_FW_AUTH_STATE | WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE)
 
 #ifdef CONFIG_TDLS
-enum TDLS_option
-{
-	TDLS_ESTABLISHED	= 	1,
-	TDLS_ISSUE_PTI				=	2,
-	TDLS_CH_SW_RESP			=	3,
-	TDLS_CH_SW				=	4,
-	TDLS_CH_SW_BACK			=	5,
-	TDLS_RS_RCR				=	6,
-	TDLS_TEAR_STA				=	7,
+enum TDLS_option {
+	TDLS_ESTABLISHED = 1,
+	TDLS_ISSUE_PTI,
+	TDLS_CH_SW_RESP,
+	TDLS_CH_SW_PREPARE,
+	TDLS_CH_SW_START,
+	TDLS_CH_SW_TO_OFF_CHNL,
+	TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED,
+	TDLS_CH_SW_TO_BASE_CHNL,
+	TDLS_CH_SW_END_TO_BASE_CHNL,
+	TDLS_CH_SW_END,
+	TDLS_RS_RCR,
+	TDLS_TEARDOWN_STA,
+	TDLS_TEARDOWN_STA_NO_WAIT,
+	TDLS_TEARDOWN_STA_LOCALLY,
+	TDLS_TEARDOWN_STA_LOCALLY_POST,
 	maxTDLS,
 };
 
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
 /*
  * Usage:
- * When one iface acted as AP mode and the other iface is STA mode and scanning, 
+ * 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_BACK_OP_CH_MS milliseconds.
  * Example:
- * For chip supports 2.4G + 5GHz and AP mode is operating in channel 1, 
+ * For chip supports 2.4G + 5GHz and AP mode is operating in channel 1,
  * RTW_SCAN_NUM_OF_CH is 8, RTW_BACK_OP_CH_MS is 300
- * 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 
+ * 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.
  */
 #if defined(CONFIG_ATMEL_RC_PATCH)
-#define RTW_SCAN_NUM_OF_CH 2
-#define RTW_BACK_OP_CH_MS 200
+	#define RTW_SCAN_NUM_OF_CH 2
+	#define RTW_BACK_OP_CH_MS 200
 #else
-#define RTW_SCAN_NUM_OF_CH 3
-#define RTW_BACK_OP_CH_MS 400
+	#define RTW_SCAN_NUM_OF_CH 3
+	#define RTW_BACK_OP_CH_MS 400
 #endif
 
-struct mlme_ext_info
-{
+#define RTW_IP_ADDR_LEN 4
+#define RTW_IPv6_ADDR_LEN 16
+
+struct mlme_ext_info {
 	u32	state;
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	u8	hw_media_state;
+#endif
 	u32	reauth_count;
 	u32	reassoc_count;
 	u32	link_count;
 	u32	auth_seq;
-	u32	auth_algo;	// 802.11 auth, could be open, shared, auto
+	u32	auth_algo;	/* 802.11 auth, could be open, shared, auto */
+	u16 auth_status;
 	u32	authModeToggle;
-	u32	enc_algo;//encrypt algorithm;
-	u32	key_index;	// this is only valid for legendary wep, 0~3 for key id.
+	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;
@@ -450,7 +449,7 @@ struct mlme_ext_info
 	u8	ERP_enable;
 	u8	ERP_IE;
 	u8	HT_enable;
-	u8	HT_caps_enable;	
+	u8	HT_caps_enable;
 	u8	HT_info_enable;
 	u8	HT_protection;
 	u8	turboMode_cts2self;
@@ -460,55 +459,74 @@ struct mlme_ext_info
 	u8	ADDBA_retry_count;
 	u8	candidate_tid_bitmap;
 	u8	dialogToken;
-	// Accept ADDBA Request
+	/* Accept ADDBA Request */
 	BOOLEAN bAcceptAddbaReq;
 	u8	bwmode_updated;
 	u8	hidden_ssid_mode;
 	u8	VHT_enable;
 
+	u8 ip_addr[RTW_IP_ADDR_LEN];
+	u8 ip6_addr[RTW_IPv6_ADDR_LEN];
+
 	struct ADDBA_request		ADDBA_req;
 	struct WMM_para_element	WMM_param;
 	struct HT_caps_element	HT_caps;
 	struct HT_info_element		HT_info;
-	WLAN_BSSID_EX			network;//join network or bss_network, if in ap mode, it is the same to cur_network.network
+	WLAN_BSSID_EX			network;/* join network or bss_network, if in ap mode, it is the same to cur_network.network */
 };
 
-// The channel information about this channel including joining, scanning, and power constraints.
-typedef struct _RT_CHANNEL_INFO
-{
-	u8				ChannelNum;		// The channel number.
-	RT_SCAN_TYPE	ScanType;		// Scan type such as passive or active scan.
-	//u16				ScanPeriod;		// Listen time in millisecond in this channel.
-	//s32				MaxTxPwrDbm;	// Max allowed tx power.
-	//u32				ExInfo;			// Extended Information for this channel.
+/* The channel information about this channel including joining, scanning, and power constraints. */
+typedef struct _RT_CHANNEL_INFO {
+	u8				ChannelNum;		/* The channel number. */
+	RT_SCAN_TYPE	ScanType;		/* Scan type such as passive or active scan. */
+	/* u16				ScanPeriod;		 */ /* Listen time in millisecond in this channel. */
+	/* s32				MaxTxPwrDbm;	 */ /* Max allowed tx power. */
+	/* u32				ExInfo;			 */ /* Extended Information for this channel. */
 #ifdef CONFIG_FIND_BEST_CHANNEL
 	u32				rx_count;
 #endif
-#ifdef CONFIG_DFS_MASTER
-	u32 non_ocp_end_time;
+#ifdef CONFIG_DFS
+	#ifdef CONFIG_DFS_MASTER
+	systime non_ocp_end_time;
+	#endif
+	u8 hidden_bss_cnt; /* per scan count */
 #endif
-}RT_CHANNEL_INFO, *PRT_CHANNEL_INFO;
+
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_OFFCH_CAND
+	u8 mesh_candidate_cnt; /* update at scan done for specific mesh iface */
+	#endif
+#endif /* CONFIG_RTW_MESH */
+} RT_CHANNEL_INFO, *PRT_CHANNEL_INFO;
 
 #define DFS_MASTER_TIMER_MS 100
 #define CAC_TIME_MS (60*1000)
 #define CAC_TIME_CE_MS (10*60*1000)
 #define NON_OCP_TIME_MS (30*60*1000)
 
+#ifdef CONFIG_TXPWR_LIMIT
+void rtw_txpwr_init_regd(struct rf_ctl_t *rfctl);
+#endif
+void rtw_rfctl_init(_adapter *adapter);
+void rtw_rfctl_deinit(_adapter *adapter);
+
 #ifdef CONFIG_DFS_MASTER
 struct rf_ctl_t;
-#define CH_IS_NON_OCP(rt_ch_info) ((rt_ch_info)->non_ocp_end_time > rtw_get_current_time())
-void rtw_rfctl_reset_cac(struct rf_ctl_t *rfctl);
-bool rtw_is_cac_reset_needed(_adapter *adapter);
+#define CH_IS_NON_OCP(rt_ch_info) (rtw_time_after((rt_ch_info)->non_ocp_end_time, rtw_get_current_time()))
+bool rtw_is_cac_reset_needed(_adapter *adapter, u8 ch, u8 bw, u8 offset);
 bool _rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset);
 bool rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl);
-bool rtw_rfctl_is_tx_blocked_by_cac(struct rf_ctl_t *rfctl);
+bool rtw_rfctl_is_tx_blocked_by_ch_waiting(struct rf_ctl_t *rfctl);
 bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
 void rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
 void rtw_chset_update_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms);
+u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms);
+void rtw_reset_cac(_adapter *adapter, u8 ch, u8 bw, u8 offset);
+u32 rtw_force_stop_cac(_adapter *adapter, u32 timeout_ms);
 #else
 #define CH_IS_NON_OCP(rt_ch_info) 0
 #define rtw_chset_is_ch_non_ocp(ch_set, ch, bw, offset) _FALSE
-#define rtw_rfctl_is_tx_blocked_by_cac(rfctl) _FALSE
+#define rtw_rfctl_is_tx_blocked_by_ch_waiting(rfctl) _FALSE
 #endif
 
 enum {
@@ -518,8 +536,13 @@ enum {
 	RTW_CHF_LONG_CAC = BIT3,
 	RTW_CHF_NON_DFS = BIT4,
 	RTW_CHF_NON_LONG_CAC = BIT5,
+	RTW_CHF_NON_OCP = BIT6,
 };
-bool rtw_choose_available_chbw(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset, u8 d_flags);
+
+bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 sel_ch, u8 max_bw
+	, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset
+	, u8 d_flags, u8 cur_ch, u8 same_band_prefer);
+
 void dump_country_chplan(void *sel, const struct country_chplan *ent);
 void dump_country_chplan_map(void *sel);
 void dump_chplan_id_list(void *sel);
@@ -527,35 +550,50 @@ void dump_chplan_test(void *sel);
 void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set);
 void dump_cur_chset(void *sel, _adapter *adapter);
 
-int rtw_ch_set_search_ch(RT_CHANNEL_INFO *ch_set, const u32 ch);
+int rtw_chset_search_ch(RT_CHANNEL_INFO *ch_set, const u32 ch);
+u8 rtw_chset_is_chbw_valid(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
+void rtw_chset_sync_chbw(RT_CHANNEL_INFO *ch_set, u8 *req_ch, u8 *req_bw, u8 *req_offset
+	, u8 *g_ch, u8 *g_bw, u8 *g_offset);
+
 bool rtw_mlme_band_check(_adapter *adapter, const u32 ch);
 
-// P2P_MAX_REG_CLASSES - Maximum number of regulatory classes
+
+enum {
+	BAND_24G = BIT0,
+	BAND_5G = BIT1,
+};
+void RTW_SET_SCAN_BAND_SKIP(_adapter *padapter, int skip_band);
+void RTW_CLR_SCAN_BAND_SKIP(_adapter *padapter, int skip_band);
+int RTW_GET_SCAN_BAND_SKIP(_adapter *padapter);
+
+bool rtw_mlme_ignore_chan(_adapter *adapter, 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
+/* 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 - List of supported channels */
 struct p2p_channels {
-	// struct p2p_reg_class - Supported regulatory class
+	/* struct p2p_reg_class - Supported regulatory class */
 	struct p2p_reg_class {
-		// reg_class - Regulatory class (IEEE 802.11-2007, Annex J)
+		/* reg_class - Regulatory class (IEEE 802.11-2007, Annex J) */
 		u8 reg_class;
 
-		// channel - Supported channels
+		/* channel - Supported channels */
 		u8 channel[P2P_MAX_REG_CLASS_CHANNELS];
 
-		// channels - Number of channel entries in use
+		/* 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
+	/* reg_classes - Number of reg_class entries in use */
 	size_t reg_classes;
 };
 
 struct p2p_oper_class_map {
-	enum hw_mode {IEEE80211G,IEEE80211A} mode;
+	enum hw_mode {IEEE80211G, IEEE80211A} mode;
 	u8 op_class;
 	u8 min_chan;
 	u8 max_chan;
@@ -563,49 +601,51 @@ struct p2p_oper_class_map {
 	enum { BW20, BW40PLUS, BW40MINUS } bw;
 };
 
-struct mlme_ext_priv
-{
+struct mlme_ext_priv {
 	_adapter	*padapter;
 	u8	mlmeext_init;
 	ATOMIC_T		event_seq;
 	u16	mgnt_seq;
 #ifdef CONFIG_IEEE80211W
 	u16	sa_query_seq;
-	u64 mgnt_80211w_IPN;
-	u64 mgnt_80211w_IPN_rx;
-#endif //CONFIG_IEEE80211W
-	//struct fw_priv 	fwpriv;
-	
+#endif
+	/* 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;
-	RT_CHANNEL_INFO		channel_set[MAX_CHANNEL_NUM];
-	struct p2p_channels channel_list;
+	unsigned char	cur_ch_offset;/* PRIME_CHNL_OFFSET */
+	unsigned char	cur_wireless_mode;	/* NETWORK_TYPE */
+
 	unsigned char	basicrate[NumRates];
 	unsigned char	datarate[NumRates];
 #ifdef CONFIG_80211N_HT
 	unsigned char default_supported_mcs_set[16];
 #endif
-	
-	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 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 */
 	_timer		survey_timer;
 	_timer		link_timer;
 
-	//_timer		ADDBA_timer;
-	u32 last_scan_time;
+#ifdef CONFIG_RTW_REPEATER_SON
+	_timer		rson_scan_timer;
+#endif
+#ifdef CONFIG_RTW_80211R
+	_timer		ft_link_timer;
+	_timer		ft_roam_timer;
+#endif
+
+	systime last_scan_time;
 	u8	scan_abort;
-	u8	tx_rate; // TXRATE when USERATE is set.
+	u8 join_abort;
+	u8	tx_rate; /* TXRATE when USERATE is set. */
+
+	u32	retry; /* retry for issue probereq */
 
-	u32	retry; //retry for issue probereq
-	
 	u64 TSFValue;
 
-	//for LPS-32K to adaptive bcn early and timeout
+	/* for LPS-32K to adaptive bcn early and timeout */
 	u8 adaptive_tsf_done;
 	u32 bcn_delay_cnt[9];
 	u32 bcn_delay_ratio[9];
@@ -613,20 +653,20 @@ struct mlme_ext_priv
 	u8 DrvBcnEarly;
 	u8 DrvBcnTimeOut;
 
-#ifdef CONFIG_AP_MODE	
+#ifdef CONFIG_AP_MODE
 	unsigned char bstart_bss;
 #endif
 
 #ifdef CONFIG_80211D
 	u8 update_channel_plan_by_ap_done;
 #endif
-	//recv_decache check for Action_public frame 
+	/* recv_decache check for Action_public frame */
 	u8 action_public_dialog_token;
-	u16 	 action_public_rxseq;
+	u16	 action_public_rxseq;
 
-//#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+	/* #ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
 	u8 active_keep_alive_check;
-//#endif
+	/* #endif */
 #ifdef DBG_FIXED_CHAN
 	u8 fixed_chan;
 #endif
@@ -634,6 +674,16 @@ struct mlme_ext_priv
 	u8 en_hw_update_tsf;
 };
 
+static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)
+{
+	if ((plmeext->mlmext_info.state & 0x03) == state)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+void sitesurvey_set_offch_state(_adapter *adapter, u8 scan_state);
+
 #define mlmeext_msr(mlmeext) ((mlmeext)->mlmext_info.state & 0x03)
 #define mlmeext_scan_state(mlmeext) ((mlmeext)->sitesurvey_res.state)
 #define mlmeext_scan_state_str(mlmeext) scan_state_str((mlmeext)->sitesurvey_res.state)
@@ -642,24 +692,26 @@ struct mlme_ext_priv
 	do { \
 		((mlmeext)->sitesurvey_res.state = (_state)); \
 		((mlmeext)->sitesurvey_res.next_state = (_state)); \
-		/* DBG_871X("set_scan_state:%s\n", scan_state_str(_state)); */ \
+		rtw_mi_update_iface_status(&((container_of(mlmeext, _adapter, mlmeextpriv)->mlmepriv)), 0); \
+		/* RTW_INFO("set_scan_state:%s\n", scan_state_str(_state)); */ \
+		sitesurvey_set_offch_state(container_of(mlmeext, _adapter, mlmeextpriv), _state); \
 	} while (0)
 
 #define mlmeext_scan_next_state(mlmeext) ((mlmeext)->sitesurvey_res.next_state)
 #define mlmeext_set_scan_next_state(mlmeext, _state) \
 	do { \
 		((mlmeext)->sitesurvey_res.next_state = (_state)); \
-		/* DBG_871X("set_scan_next_state:%s\n", scan_state_str(_state)); */ \
+		/* RTW_INFO("set_scan_next_state:%s\n", scan_state_str(_state)); */ \
 	} while (0)
 
 #ifdef CONFIG_SCAN_BACKOP
 #define mlmeext_scan_backop_flags(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags)
 #define mlmeext_chk_scan_backop_flags(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags & (flags))
 #define mlmeext_assign_scan_backop_flags(mlmeext, flags) \
-		do { \
-			((mlmeext)->sitesurvey_res.backop_flags = (flags)); \
-			DBG_871X("assign_scan_backop_flags:0x%02x\n", (mlmeext)->sitesurvey_res.backop_flags); \
-		} while (0)
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags = (flags)); \
+		RTW_INFO("assign_scan_backop_flags:0x%02x\n", (mlmeext)->sitesurvey_res.backop_flags); \
+	} while (0)
 
 #define mlmeext_scan_backop_flags_sta(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_sta)
 #define mlmeext_chk_scan_backop_flags_sta(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_sta & (flags))
@@ -667,13 +719,6 @@ struct mlme_ext_priv
 	do { \
 		((mlmeext)->sitesurvey_res.backop_flags_sta = (flags)); \
 	} while (0)
-
-#define mlmeext_scan_backop_flags_ap(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_ap)
-#define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_ap & (flags))
-#define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) \
-	do { \
-		((mlmeext)->sitesurvey_res.backop_flags_ap = (flags)); \
-	} while (0)
 #else
 #define mlmeext_scan_backop_flags(mlmeext) (0)
 #define mlmeext_chk_scan_backop_flags(mlmeext, flags) (0)
@@ -682,35 +727,51 @@ struct mlme_ext_priv
 #define mlmeext_scan_backop_flags_sta(mlmeext) (0)
 #define mlmeext_chk_scan_backop_flags_sta(mlmeext, flags) (0)
 #define mlmeext_assign_scan_backop_flags_sta(mlmeext, flags) do {} while (0)
+#endif /* CONFIG_SCAN_BACKOP */
 
+#if defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_AP_MODE)
+#define mlmeext_scan_backop_flags_ap(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_ap)
+#define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_ap & (flags))
+#define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) \
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags_ap = (flags)); \
+	} while (0)
+#else
 #define mlmeext_scan_backop_flags_ap(mlmeext) (0)
 #define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) (0)
 #define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) do {} while (0)
-#endif
+#endif /* defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_AP_MODE) */
+
+#if defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_RTW_MESH)
+#define mlmeext_scan_backop_flags_mesh(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_mesh)
+#define mlmeext_chk_scan_backop_flags_mesh(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_mesh & (flags))
+#define mlmeext_assign_scan_backop_flags_mesh(mlmeext, flags) \
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags_mesh = (flags)); \
+	} while (0)
+#else
+#define mlmeext_scan_backop_flags_mesh(mlmeext) (0)
+#define mlmeext_chk_scan_backop_flags_mesh(mlmeext, flags) (0)
+#define mlmeext_assign_scan_backop_flags_mesh(mlmeext, flags) do {} while (0)
+#endif /* defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_RTW_MESH) */
+
+u32 rtw_scan_timeout_decision(_adapter *padapter);
 
-void init_mlme_default_rate_set(_adapter* padapter);
-int init_mlme_ext_priv(_adapter* padapter);
+void init_mlme_default_rate_set(_adapter *padapter);
+int init_mlme_ext_priv(_adapter *padapter);
 int init_hw_mlme_ext(_adapter *padapter);
-void free_mlme_ext_priv (struct mlme_ext_priv *pmlmeext);
-extern void init_mlme_ext_timer(_adapter *padapter);
-extern void init_addba_retry_timer(_adapter *padapter, struct sta_info *psta);
+void free_mlme_ext_priv(struct mlme_ext_priv *pmlmeext);
 extern struct xmit_frame *alloc_mgtxmitframe(struct xmit_priv *pxmitpriv);
 struct xmit_frame *alloc_mgtxmitframe_once(struct xmit_priv *pxmitpriv);
 
-//void fill_fwpriv(_adapter * padapter, struct fw_priv *pfwpriv);
-
-unsigned char networktype_to_raid(_adapter *adapter,struct sta_info *psta);
-unsigned char networktype_to_raid_ex(_adapter *adapter, struct sta_info *psta);
-
+/* void fill_fwpriv(_adapter * padapter, struct fw_priv *pfwpriv); */
 u8 judge_network_type(_adapter *padapter, unsigned char *rate, int ratelen);
 void get_rate_set(_adapter *padapter, unsigned char *pbssrate, int *bssrate_len);
 void set_mcs_rate_by_mask(u8 *mcs_set, u32 mask);
-void UpdateBrateTbl(_adapter *padapter,u8 *mBratesOS);
+void UpdateBrateTbl(_adapter *padapter, u8 *mBratesOS);
 void UpdateBrateTblForSoftAP(u8 *bssrateset, u32 bssratelen);
 void change_band_update_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 ch);
 
-//void Set_NETYPE1_MSR(_adapter *padapter, u8 type);
-//void Set_NETYPE0_MSR(_adapter *padapter, u8 type);
 void Set_MSR(_adapter *padapter, u8 type);
 
 u8 rtw_get_oper_ch(_adapter *adapter);
@@ -720,10 +781,10 @@ void rtw_set_oper_bw(_adapter *adapter, u8 bw);
 u8 rtw_get_oper_choffset(_adapter *adapter);
 void rtw_set_oper_choffset(_adapter *adapter, u8 offset);
 u8	rtw_get_center_ch(u8 channel, u8 chnl_bw, u8 chnl_offset);
-u32 rtw_get_on_oper_ch_time(_adapter *adapter);
-u32 rtw_get_on_cur_ch_time(_adapter *adapter);
+systime rtw_get_on_oper_ch_time(_adapter *adapter);
+systime rtw_get_on_cur_ch_time(_adapter *adapter);
 
-u8 rtw_get_offset_by_ch(u8 channel);
+u8 rtw_get_offset_by_chbw(u8 ch, u8 bw, u8 *r_offset);
 
 void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char channel_offset, unsigned short bwmode);
 
@@ -731,6 +792,9 @@ unsigned int decide_wait_for_beacon_timeout(unsigned int bcn_interval);
 
 void _clear_cam_entry(_adapter *padapter, u8 entry);
 void write_cam_from_cache(_adapter *adapter, u8 id);
+void rtw_sec_cam_swap(_adapter *adapter, u8 cam_id_a, u8 cam_id_b);
+void rtw_clean_dk_section(_adapter *adapter);
+void rtw_clean_hw_dk_cam(_adapter *adapter);
 
 /* modify both HW and cache */
 void write_cam(_adapter *padapter, u8 id, u16 ctrl, u8 *mac, u8 *key);
@@ -749,10 +813,9 @@ BOOLEAN IsLegal5GChannel(PADAPTER Adapter, u8 channel);
 
 void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType);
 u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid);
-void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src, _adapter * padapter, bool update_ie);
+void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src, _adapter *padapter, bool update_ie);
 
-int get_bsstype(unsigned short capability);
-u8* get_my_bssid(WLAN_BSSID_EX *pnetwork);
+u8 *get_my_bssid(WLAN_BSSID_EX *pnetwork);
 u16 get_beacon_interval(WLAN_BSSID_EX *bss);
 
 int is_client_associated_to_ap(_adapter *padapter);
@@ -760,6 +823,9 @@ int is_client_associated_to_ibss(_adapter *padapter);
 int is_IBSS_empty(_adapter *padapter);
 
 unsigned char check_assoc_AP(u8 *pframe, uint len);
+#ifdef CONFIG_80211AC_VHT
+unsigned char get_vht_mu_bfer_cap(u8 *pframe, uint len);
+#endif
 
 int WMM_param_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs	pIE);
 #ifdef CONFIG_WFD
@@ -778,35 +844,37 @@ void	update_ldpc_stbc_cap(struct sta_info *psta);
 
 int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
 		struct beacon_keys *recv_beacon);
+int validate_beacon_len(u8 *pframe, uint len);
 void rtw_dump_bcn_keys(struct beacon_keys *recv_beacon);
 int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len);
 void update_beacon_info(_adapter *padapter, u8 *pframe, uint len, struct sta_info *psta);
 #ifdef CONFIG_DFS
-void process_csa_ie(_adapter *padapter, u8 *pframe, uint len);
-#endif //CONFIG_DFS
+void process_csa_ie(_adapter *padapter, u8 *ies, uint ies_len);
+#endif /* CONFIG_DFS */
 void update_capinfo(PADAPTER Adapter, u16 updateCap);
-void update_wireless_mode(_adapter * padapter);
+void update_wireless_mode(_adapter *padapter);
 void update_tx_basic_rate(_adapter *padapter, u8 modulation);
 void update_sta_basic_rate(struct sta_info *psta, u8 wireless_mode);
 int rtw_ies_get_supported_rate(u8 *ies, uint ies_len, u8 *rate_set, u8 *rate_num);
 
-//for sta/adhoc mode
+/* for sta/adhoc mode */
 void update_sta_info(_adapter *padapter, struct sta_info *psta);
 unsigned int update_basic_rate(unsigned char *ptn, unsigned int ptn_sz);
 unsigned int update_supported_rate(unsigned char *ptn, unsigned int ptn_sz);
-unsigned int update_MCS_rate(struct HT_caps_element *pHT_caps);
 void Update_RA_Entry(_adapter *padapter, struct sta_info *psta);
 void set_sta_rate(_adapter *padapter, struct sta_info *psta);
 
 unsigned int receive_disconnect(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, u8 locally_generated);
 
-unsigned char get_highest_rate_idx(u32 mask);
+unsigned char get_highest_rate_idx(u64 mask);
+unsigned char get_lowest_rate_idx_ex(u64 mask, int start_bit);
+#define get_lowest_rate_idx(mask) get_lowest_rate_idx_ex(mask, 0)
+
 int support_short_GI(_adapter *padapter, struct HT_caps_element *pHT_caps, u8 bwmode);
 unsigned int is_ap_in_tkip(_adapter *padapter);
 unsigned int is_ap_in_wep(_adapter *padapter);
-unsigned int should_forbid_n_rate(_adapter * padapter);
+unsigned int should_forbid_n_rate(_adapter *padapter);
 
-s16 rtw_get_camid(_adapter *adapter, struct sta_info* sta, s16 kid);
 bool _rtw_camctl_chk_cap(_adapter *adapter, u8 cap);
 void _rtw_camctl_set_flags(_adapter *adapter, u32 flags);
 void rtw_camctl_set_flags(_adapter *adapter, u32 flags);
@@ -821,16 +889,20 @@ void rtw_sec_cam_map_clr_all(struct sec_cam_bmp *map);
 bool _rtw_camid_is_gk(_adapter *adapter, u8 cam_id);
 bool rtw_camid_is_gk(_adapter *adapter, u8 cam_id);
 s16 rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk);
-s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used);
+s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, u8 gk, bool *used);
 void rtw_camid_free(_adapter *adapter, u8 cam_id);
+u8 rtw_get_sec_camid(_adapter *adapter, u8 max_bk_key_num, u8 *sec_key_id);
 
 struct macid_bmp;
 struct macid_ctl_t;
 void dump_macid_map(void *sel, struct macid_bmp *map, u8 max_num);
 bool rtw_macid_is_set(struct macid_bmp *map, u8 id);
+void rtw_macid_map_clr(struct macid_bmp *map, u8 id);
 bool rtw_macid_is_used(struct macid_ctl_t *macid_ctl, u8 id);
 bool rtw_macid_is_bmc(struct macid_ctl_t *macid_ctl, u8 id);
-s8 rtw_macid_get_if_g(struct macid_ctl_t *macid_ctl, u8 id);
+u8 rtw_macid_get_iface_bmp(struct macid_ctl_t *macid_ctl, u8 id);
+bool rtw_macid_is_iface_shared(struct macid_ctl_t *macid_ctl, u8 id);
+bool rtw_macid_is_iface_specific(struct macid_ctl_t *macid_ctl, u8 id, _adapter *adapter);
 s8 rtw_macid_get_ch_g(struct macid_ctl_t *macid_ctl, u8 id);
 void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta);
 void rtw_release_macid(_adapter *padapter, struct sta_info *psta);
@@ -840,20 +912,37 @@ void rtw_macid_ctl_set_bw(struct macid_ctl_t *macid_ctl, u8 id, u8 bw);
 void rtw_macid_ctl_set_vht_en(struct macid_ctl_t *macid_ctl, u8 id, u8 en);
 void rtw_macid_ctl_set_rate_bmp0(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp);
 void rtw_macid_ctl_set_rate_bmp1(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp);
+void rtw_macid_ctl_init_sleep_reg(struct macid_ctl_t *macid_ctl, u16 m0, u16 m1, u16 m2, u16 m3);
 void rtw_macid_ctl_init(struct macid_ctl_t *macid_ctl);
 void rtw_macid_ctl_deinit(struct macid_ctl_t *macid_ctl);
-
-void report_join_res(_adapter *padapter, int res);
+u8 rtw_iface_bcmc_id_get(_adapter *padapter);
+void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id);
+
+bool rtw_bmp_is_set(const u8 *bmp, u8 bmp_len, u8 id);
+void rtw_bmp_set(u8 *bmp, u8 bmp_len, u8 id);
+void rtw_bmp_clear(u8 *bmp, u8 bmp_len, u8 id);
+bool rtw_bmp_not_empty(const u8 *bmp, u8 bmp_len);
+bool rtw_bmp_not_empty_exclude_bit0(const u8 *bmp, u8 bmp_len);
+
+#ifdef CONFIG_AP_MODE
+bool rtw_tim_map_is_set(_adapter *padapter, const u8 *map, u8 id);
+void rtw_tim_map_set(_adapter *padapter, u8 *map, u8 id);
+void rtw_tim_map_clear(_adapter *padapter, u8 *map, u8 id);
+bool rtw_tim_map_anyone_be_set(_adapter *padapter, const u8 *map);
+bool rtw_tim_map_anyone_be_set_exclude_aid0(_adapter *padapter, const u8 *map);
+#endif /* CONFIG_AP_MODE */
+
+u32 report_join_res(_adapter *padapter, int aid_res, u16 status);
 void report_survey_event(_adapter *padapter, union recv_frame *precv_frame);
 void report_surveydone_event(_adapter *padapter);
-void report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated);
+u32 report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated);
 void report_add_sta_event(_adapter *padapter, unsigned char *MacAddr);
 bool rtw_port_switch_chk(_adapter *adapter);
 void report_wmm_edca_update(_adapter *padapter);
 
 void beacon_timing_control(_adapter *padapter);
-u8 chk_bmc_sleepq_cmd(_adapter* padapter);
-extern u8 set_tx_beacon_cmd(_adapter*padapter);
+u8 chk_bmc_sleepq_cmd(_adapter *padapter);
+extern u8 set_tx_beacon_cmd(_adapter *padapter);
 unsigned int setup_beacon_frame(_adapter *padapter, unsigned char *beacon_frame);
 void update_mgnt_tx_rate(_adapter *padapter, u8 rate);
 void update_monitor_frame_attrib(_adapter *padapter, struct pkt_attrib *pattrib);
@@ -862,39 +951,43 @@ void update_mgntframe_attrib_addr(_adapter *padapter, struct xmit_frame *pmgntfr
 void dump_mgntframe(_adapter *padapter, struct xmit_frame *pmgntframe);
 s32 dump_mgntframe_and_wait(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms);
 s32 dump_mgntframe_and_wait_ack(_adapter *padapter, struct xmit_frame *pmgntframe);
+s32 dump_mgntframe_and_wait_ack_timeout(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms);
 
 #ifdef CONFIG_P2P
+int get_reg_classes_full_count(struct p2p_channels *channel_list);
 void issue_probersp_p2p(_adapter *padapter, unsigned char *da);
-void issue_p2p_provision_request( _adapter *padapter, u8* pssid, u8 ussidlen, u8* pdev_raddr);
-void issue_p2p_GO_request(_adapter *padapter, u8* raddr);
+void issue_p2p_provision_request(_adapter *padapter, u8 *pssid, u8 ussidlen, u8 *pdev_raddr);
+void issue_p2p_GO_request(_adapter *padapter, u8 *raddr);
 void issue_probereq_p2p(_adapter *padapter, u8 *da);
 int issue_probereq_p2p_ex(_adapter *adapter, u8 *da, int try_cnt, int wait_ms);
-void issue_p2p_invitation_response(_adapter *padapter, u8* raddr, u8 dialogToken, u8 success);
-void issue_p2p_invitation_request(_adapter *padapter, u8* raddr );
-#endif //CONFIG_P2P
+void issue_p2p_invitation_response(_adapter *padapter, u8 *raddr, u8 dialogToken, u8 success);
+void issue_p2p_invitation_request(_adapter *padapter, u8 *raddr);
+#endif /* CONFIG_P2P */
 void issue_beacon(_adapter *padapter, int timeout_ms);
 void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probereq);
+void _issue_assocreq(_adapter *padapter, u8 is_assoc);
 void issue_assocreq(_adapter *padapter);
+void issue_reassocreq(_adapter *padapter);
 void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *pstat, int pkt_type);
 void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status);
-void issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da);
-s32 issue_probereq_ex(_adapter *padapter, NDIS_802_11_SSID *pssid, u8* da, u8 ch, bool append_wps, int try_cnt, int wait_ms);
+void issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da);
+s32 issue_probereq_ex(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps, int try_cnt, int wait_ms);
 int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms);
-s32 issue_nulldata_in_interrupt(PADAPTER padapter, u8 *da, unsigned int power_mode);
-int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int try_cnt, int wait_ms);
+int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int try_cnt, int wait_ms);
 int issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason);
 int issue_deauth_ex(_adapter *padapter, u8 *da, unsigned short reason, int try_cnt, int wait_ms);
 void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset);
 void issue_addba_req(_adapter *adapter, unsigned char *ra, u8 tid);
 void issue_addba_rsp(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size);
+u8 issue_addba_rsp_wait_ack(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size, int try_cnt, int wait_ms);
 void issue_del_ba(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator);
 int issue_del_ba_ex(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator, int try_cnt, int wait_ms);
+void issue_action_BSSCoexistPacket(_adapter *padapter);
 
 #ifdef CONFIG_IEEE80211W
 void issue_action_SA_Query(_adapter *padapter, unsigned char *raddr, unsigned char action, unsigned short tid, u8 key_type);
 int issue_deauth_11w(_adapter *padapter, unsigned char *da, unsigned short reason, u8 key_type);
-extern void init_dot11w_expire_timer(_adapter *padapter, struct sta_info *psta);
-#endif //CONFIG_IEEE80211W
+#endif /* CONFIG_IEEE80211W */
 int issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode);
 int issue_action_SM_PS_wait_ack(_adapter *padapter, unsigned char *raddr, u8 NewMimoPsMode, int try_cnt, int wait_ms);
 
@@ -905,9 +998,9 @@ unsigned int send_delba(_adapter *padapter, u8 initiator, u8 *addr);
 unsigned int send_beacon(_adapter *padapter);
 
 void start_clnt_assoc(_adapter *padapter);
-void start_clnt_auth(_adapter* padapter);
-void start_clnt_join(_adapter* padapter);
-void start_create_ibss(_adapter* padapter);
+void start_clnt_auth(_adapter *padapter);
+void start_clnt_join(_adapter *padapter);
+void start_create_ibss(_adapter *padapter);
 
 unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame);
@@ -925,6 +1018,9 @@ unsigned int OnAction(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAction_qos(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAction_dls(_adapter *padapter, union recv_frame *precv_frame);
+#ifdef CONFIG_RTW_WNM
+unsigned int on_action_wnm(_adapter *adapter, union recv_frame *rframe);
+#endif
 
 #define RX_AMPDU_ACCEPT_INVALID 0xFF
 #define RX_AMPDU_SIZE_INVALID 0xFF
@@ -939,20 +1035,50 @@ bool rtw_rx_ampdu_is_accept(_adapter *adapter);
 bool rtw_rx_ampdu_set_size(_adapter *adapter, u8 size, u8 reason);
 bool rtw_rx_ampdu_set_accept(_adapter *adapter, u8 accept, u8 reason);
 u8 rx_ampdu_apply_sta_tid(_adapter *adapter, struct sta_info *sta, u8 tid, u8 accept, u8 size);
+u8 rx_ampdu_size_sta_limit(_adapter *adapter, struct sta_info *sta);
 u8 rx_ampdu_apply_sta(_adapter *adapter, struct sta_info *sta, u8 accept, u8 size);
 u16 rtw_rx_ampdu_apply(_adapter *adapter);
 
 unsigned int OnAction_back(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int on_action_public(_adapter *padapter, union recv_frame *precv_frame);
+unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAction_ht(_adapter *padapter, union recv_frame *precv_frame);
 #ifdef CONFIG_IEEE80211W
 unsigned int OnAction_sa_query(_adapter *padapter, union recv_frame *precv_frame);
-#endif //CONFIG_IEEE80211W
+#endif /* CONFIG_IEEE80211W */
+unsigned int on_action_rm(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAction_wmm(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAction_p2p(_adapter *padapter, union recv_frame *precv_frame);
 
-
+#ifdef CONFIG_RTW_80211R
+void rtw_ft_update_bcn(_adapter *padapter, union recv_frame *precv_frame);
+void rtw_ft_start_clnt_join(_adapter *padapter);
+u8 rtw_ft_update_rsnie(_adapter *padapter, u8 bwrite, 
+	struct pkt_attrib *pattrib, u8 **pframe);
+void rtw_ft_build_auth_req_ies(_adapter *padapter, 
+	struct pkt_attrib *pattrib, u8 **pframe);
+void rtw_ft_build_assoc_req_ies(_adapter *padapter, 
+	u8 is_reassoc, struct pkt_attrib *pattrib, u8 **pframe);
+u8 rtw_ft_update_auth_rsp_ies(_adapter *padapter, u8 *pframe, u32 len);
+void rtw_ft_start_roam(_adapter *padapter, u8 *pTargetAddr);
+void rtw_ft_issue_action_req(_adapter *padapter, u8 *pTargetAddr);
+void rtw_ft_report_evt(_adapter *padapter);
+void rtw_ft_report_reassoc_evt(_adapter *padapter, u8 *pMacAddr);
+void rtw_ft_link_timer_hdl(void *ctx);
+void rtw_ft_roam_timer_hdl(void *ctx);
+void rtw_ft_roam_status_reset(_adapter *padapter);
+#endif
+#ifdef CONFIG_RTW_WNM
+void rtw_wnm_roam_scan_hdl(void *ctx);
+void rtw_wnm_process_btm_req(_adapter *padapter,  u8* pframe, u32 frame_len);
+void rtw_wnm_reset_btm_candidate(struct roam_nb_info *pnb);
+void rtw_wnm_reset_btm_state(_adapter *padapter);
+void rtw_wnm_issue_action(_adapter *padapter, u8 action, u8 reason);
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+u32 rtw_wnm_btm_candidates_survey(_adapter *padapter, u8* pframe, u32 elem_len, u8 is_preference);
+#endif
 void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res);
 void mlmeext_sta_del_event_callback(_adapter *padapter);
 void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta);
@@ -961,26 +1087,35 @@ void linked_status_chk(_adapter *padapter, u8 from_timer);
 
 void _linked_info_dump(_adapter *padapter);
 
-void survey_timer_hdl (_adapter *padapter);
-void link_timer_hdl (_adapter *padapter);
-void addba_timer_hdl(struct sta_info *psta);
+void survey_timer_hdl(void *ctx);
+#ifdef CONFIG_RTW_REPEATER_SON
+void rson_timer_hdl(void *ctx);
+#endif
+void link_timer_hdl(void *ctx);
+void addba_timer_hdl(void *ctx);
 #ifdef CONFIG_IEEE80211W
-void sa_query_timer_hdl(struct sta_info *psta);
-#endif //CONFIG_IEEE80211W
-//void reauth_timer_hdl(_adapter *padapter);
-//void reassoc_timer_hdl(_adapter *padapter);
+void sa_query_timer_hdl(void *ctx);
+#endif /* CONFIG_IEEE80211W */
+#if 0
+void reauth_timer_hdl(_adapter *padapter);
+void reassoc_timer_hdl(_adapter *padapter);
+#endif
 
 #define set_survey_timer(mlmeext, ms) \
 	do { \
-		/*DBG_871X("%s set_survey_timer(%p, %d)\n", __FUNCTION__, (mlmeext), (ms));*/ \
+		/*RTW_INFO("%s set_survey_timer(%p, %d)\n", __FUNCTION__, (mlmeext), (ms));*/ \
 		_set_timer(&(mlmeext)->survey_timer, (ms)); \
-	} while(0)
+	} while (0)
 
 #define set_link_timer(mlmeext, ms) \
 	do { \
-		/*DBG_871X("%s set_link_timer(%p, %d)\n", __FUNCTION__, (mlmeext), (ms));*/ \
+		/*RTW_INFO("%s set_link_timer(%p, %d)\n", __FUNCTION__, (mlmeext), (ms));*/ \
 		_set_timer(&(mlmeext)->link_timer, (ms)); \
-	} while(0)
+	} while (0)
+
+bool rtw_is_basic_rate_cck(u8 rate);
+bool rtw_is_basic_rate_ofdm(u8 rate);
+bool rtw_is_basic_rate_mix(u8 rate);
 
 extern int cckrates_included(unsigned char *rate, int ratelen);
 extern int cckratesonly_included(unsigned char *rate, int ratelen);
@@ -992,29 +1127,24 @@ extern void correct_TSF(_adapter *padapter, struct mlme_ext_priv *pmlmeext);
 extern void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len);
 extern u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer);
 
-
-#ifdef CONFIG_CONCURRENT_MODE
-sint check_buddy_mlmeinfo_state(_adapter *padapter, u32 state);
-#endif
-
+void rtw_process_bar_frame(_adapter *padapter, union recv_frame *precv_frame);
 void rtw_join_done_chk_ch(_adapter *padapter, int join_res);
 
 int rtw_chk_start_clnt_join(_adapter *padapter, u8 *ch, u8 *bw, u8 *offset);
-int rtw_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
-int rtw_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
 
-void rtw_dev_iface_status(_adapter *adapter, u8 *sta_num, u8 *ld_sta_num, u8 *lg_sta_num
-	, u8 *ap_num, u8 *ld_ap_num);
-void rtw_dev_iface_status_no_self(_adapter *adapter, u8 *sta_num, u8 *ld_sta_num, u8 *lg_sta_num
-	, u8 *ap_num, u8 *ld_ap_num);
-
-u8 rtw_mp_mode_check(_adapter *padapter);
+#ifdef CONFIG_PLATFORM_ARM_SUN8I
+	#define BUSY_TRAFFIC_SCAN_DENY_PERIOD	8000
+#else
+	#define BUSY_TRAFFIC_SCAN_DENY_PERIOD	12000
+#endif
 
 struct cmd_hdl {
 	uint	parmsize;
-	u8 (*h2cfuns)(struct _ADAPTER *padapter, u8 *pbuf);	
+	u8(*h2cfuns)(struct _ADAPTER *padapter, u8 *pbuf);
 };
 
+void rtw_leave_opch(_adapter *adapter);
+void rtw_back_opch(_adapter *adapter);
 
 u8 read_macreg_hdl(_adapter *padapter, u8 *pbuf);
 u8 write_macreg_hdl(_adapter *padapter, u8 *pbuf);
@@ -1029,22 +1159,25 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf);
 u8 disconnect_hdl(_adapter *padapter, u8 *pbuf);
 u8 createbss_hdl(_adapter *padapter, u8 *pbuf);
 u8 setopmode_hdl(_adapter *padapter, u8 *pbuf);
-u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf);	
+u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf);
 u8 setauth_hdl(_adapter *padapter, u8 *pbuf);
 u8 setkey_hdl(_adapter *padapter, u8 *pbuf);
 u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf);
 u8 set_assocsta_hdl(_adapter *padapter, u8 *pbuf);
 u8 del_assocsta_hdl(_adapter *padapter, u8 *pbuf);
 u8 add_ba_hdl(_adapter *padapter, unsigned char *pbuf);
+u8 add_ba_rsp_hdl(_adapter *padapter, unsigned char *pbuf);
+
+void rtw_ap_wep_pk_setting(_adapter *adapter, struct sta_info *psta);
 
 u8 mlme_evt_hdl(_adapter *padapter, unsigned char *pbuf);
 u8 h2c_msg_hdl(_adapter *padapter, unsigned char *pbuf);
 u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf);
 u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf);
-u8 set_ch_hdl(_adapter *padapter, u8 *pbuf);
+u8 rtw_set_chbw_hdl(_adapter *padapter, u8 *pbuf);
 u8 set_chplan_hdl(_adapter *padapter, unsigned char *pbuf);
 u8 led_blink_hdl(_adapter *padapter, unsigned char *pbuf);
-u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf);	//Kurt: Handling DFS channel switch announcement ie.
+u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf);	/* Kurt: Handling DFS channel switch announcement ie. */
 u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf);
 u8 run_in_thread_hdl(_adapter *padapter, u8 *pbuf);
 u8 rtw_getmacreg_hdl(_adapter *padapter, u8 *pbuf);
@@ -1054,8 +1187,7 @@ u8 rtw_getmacreg_hdl(_adapter *padapter, u8 *pbuf);
 
 #ifdef _RTW_CMD_C_
 
-struct cmd_hdl wlancmds[] = 
-{
+struct cmd_hdl wlancmds[] = {
 	GEN_DRV_CMD_HANDLER(sizeof(struct readMAC_parm), rtw_getmacreg) /*0*/
 	GEN_DRV_CMD_HANDLER(0, NULL)
 	GEN_DRV_CMD_HANDLER(0, NULL)
@@ -1069,26 +1201,26 @@ struct cmd_hdl wlancmds[] =
 	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 joinbss_parm), join_cmd_hdl) /*14*/
-	GEN_MLME_EXT_HANDLER(sizeof (struct disconnect_parm), disconnect_hdl)
-	GEN_MLME_EXT_HANDLER(sizeof (struct createbss_parm), createbss_hdl)
-	GEN_MLME_EXT_HANDLER(sizeof (struct setopmode_parm), setopmode_hdl)
-	GEN_MLME_EXT_HANDLER(sizeof (struct sitesurvey_parm), sitesurvey_cmd_hdl) /*18*/
-	GEN_MLME_EXT_HANDLER(sizeof (struct setauth_parm), setauth_hdl)
-	GEN_MLME_EXT_HANDLER(sizeof (struct setkey_parm), setkey_hdl) /*20*/
-	GEN_MLME_EXT_HANDLER(sizeof (struct set_stakey_parm), set_stakey_hdl)
-	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(sizeof(struct joinbss_parm), join_cmd_hdl)  /*14*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct disconnect_parm), disconnect_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct createbss_parm), createbss_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct setopmode_parm), setopmode_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct sitesurvey_parm), sitesurvey_cmd_hdl)  /*18*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct setauth_parm), setauth_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct setkey_parm), setkey_hdl)  /*20*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct set_stakey_parm), set_stakey_hdl)
+	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(0, NULL)
+	GEN_MLME_EXT_HANDLER(0, 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)
@@ -1101,8 +1233,8 @@ struct cmd_hdl wlancmds[] =
 	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_hdl)	
-	GEN_MLME_EXT_HANDLER(sizeof(struct set_ch_parm), set_ch_hdl) /* 46 */
+	GEN_MLME_EXT_HANDLER(sizeof(struct addBaReq_parm), add_ba_hdl)
+	GEN_MLME_EXT_HANDLER(sizeof(struct set_ch_parm), rtw_set_chbw_hdl) /* 46 */
 	GEN_MLME_EXT_HANDLER(0, NULL)
 	GEN_MLME_EXT_HANDLER(0, NULL)
 	GEN_MLME_EXT_HANDLER(0, NULL)
@@ -1110,7 +1242,7 @@ struct cmd_hdl wlancmds[] =
 	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(sizeof(struct Tx_Beacon_param), tx_beacon_hdl) /*55*/
 
 	GEN_MLME_EXT_HANDLER(0, mlme_evt_hdl) /*56*/
@@ -1124,25 +1256,26 @@ struct cmd_hdl wlancmds[] =
 	GEN_MLME_EXT_HANDLER(sizeof(struct TDLSoption_param), tdls_hdl) /*62*/
 	GEN_MLME_EXT_HANDLER(0, chk_bmc_sleepq_hdl) /*63*/
 	GEN_MLME_EXT_HANDLER(sizeof(struct RunInThread_param), run_in_thread_hdl) /*64*/
+	GEN_MLME_EXT_HANDLER(sizeof(struct addBaRsp_parm), add_ba_rsp_hdl) /* 65 */
+	GEN_MLME_EXT_HANDLER(sizeof(struct rm_event), rm_post_event_hdl) /* 66 */
 };
 
 #endif
 
-struct C2HEvent_Header
-{
+struct C2HEvent_Header {
 
 #ifdef CONFIG_LITTLE_ENDIAN
 
 	unsigned int len:16;
 	unsigned int ID:8;
 	unsigned int seq:8;
-	
+
 #elif defined(CONFIG_BIG_ENDIAN)
 
 	unsigned int seq:8;
 	unsigned int ID:8;
 	unsigned int len:16;
-	
+
 #else
 
 #  error "Must be LITTLE or BIG Endian"
@@ -1156,47 +1289,48 @@ struct C2HEvent_Header
 void rtw_dummy_event_callback(_adapter *adapter , u8 *pbuf);
 void rtw_fwdbg_event_callback(_adapter *adapter , u8 *pbuf);
 
-enum rtw_c2h_event
-{
-	GEN_EVT_CODE(_Read_MACREG)=0, /*0*/
+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_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(_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(_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
+	GEN_EVT_CODE(_ReportPwrState),		/* filen: only for PCIE, USB	 */
+	GEN_EVT_CODE(_CloseRF),				/* filen: only for PCIE, work around ASPM */
 	GEN_EVT_CODE(_WMM),					/*25*/
 #ifdef CONFIG_IEEE80211W
 	GEN_EVT_CODE(_TimeoutSTA),
 #endif /* CONFIG_IEEE80211W */
- 	MAX_C2HEVT
+#ifdef CONFIG_RTW_80211R
+	GEN_EVT_CODE(_FT_REASSOC),
+#endif
+	MAX_C2HEVT
 };
 
 
-#ifdef _RTW_MLME_EXT_C_		
+#ifdef _RTW_MLME_EXT_C_
 
-static struct fwevent wlanevents[] = 
-{
-	{0, rtw_dummy_event_callback}, 	/*0*/
+static struct fwevent wlanevents[] = {
+	{0, rtw_dummy_event_callback},	/*0*/
 	{0, NULL},
 	{0, NULL},
 	{0, NULL},
@@ -1205,11 +1339,11 @@ static struct fwevent wlanevents[] =
 	{0, NULL},
 	{0, NULL},
 	{0, &rtw_survey_event_callback},		/*8*/
-	{sizeof (struct surveydone_event), &rtw_surveydone_event_callback},	/*9*/
-		
+	{sizeof(struct surveydone_event), &rtw_surveydone_event_callback},	/*9*/
+
 	{0, &rtw_joinbss_event_callback},		/*10*/
 	{sizeof(struct stassoc_event), &rtw_stassoc_event_callback},
-	{sizeof(struct stadel_event), &rtw_stadel_event_callback},	
+	{sizeof(struct stadel_event), &rtw_stadel_event_callback},
 	{0, &rtw_atimdone_event_callback},
 	{0, rtw_dummy_event_callback},
 	{0, NULL},	/*15*/
@@ -1226,10 +1360,11 @@ static struct fwevent wlanevents[] =
 #ifdef CONFIG_IEEE80211W
 	{sizeof(struct stadel_event), &rtw_sta_timeout_event_callback},
 #endif /* CONFIG_IEEE80211W */
-
+#ifdef CONFIG_RTW_80211R
+	{sizeof(struct stassoc_event), &rtw_ft_reassoc_event_callback},
+#endif
 };
 
-#endif//_RTW_MLME_EXT_C_
+#endif/* _RTW_MLME_EXT_C_ */
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp.h
index 100c98957bd6..8a2fe208bc05 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,22 +12,16 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_MP_H_
 #define _RTW_MP_H_
 
 #define RTWPRIV_VER_INFO	1
 
-#define MAX_MP_XMITBUF_SZ 	2048
+#define MAX_MP_XMITBUF_SZ	2048
 #define NR_MP_XMITFRAME		8
 
-struct mp_xmit_frame
-{
+struct mp_xmit_frame {
 	_list	list;
 
 	struct pkt_attrib attrib;
@@ -39,8 +34,8 @@ struct mp_xmit_frame
 
 #ifdef CONFIG_USB_HCI
 
-	//insert urb, irp, and irpcnt info below...
-	//max frag_cnt = 8
+	/* insert urb, irp, and irpcnt info below... */
+	/* max frag_cnt = 8 */
 
 	u8 *mem_addr;
 	u32 sz[8];
@@ -63,40 +58,37 @@ struct mp_xmit_frame
 	uint mem[(MAX_MP_XMITBUF_SZ >> 2)];
 };
 
-struct mp_wiparam
-{
+struct mp_wiparam {
 	u32 bcompleted;
 	u32 act_type;
 	u32 io_offset;
 	u32 io_value;
 };
 
-typedef void(*wi_act_func)(void* padapter);
+typedef void(*wi_act_func)(void *padapter);
 
 #ifdef PLATFORM_WINDOWS
-struct mp_wi_cntx
-{
+struct mp_wi_cntx {
 	u8 bmpdrv_unload;
 
-	// Work Item
+	/* Work Item */
 	NDIS_WORK_ITEM mp_wi;
 	NDIS_EVENT mp_wi_evt;
 	_lock mp_wi_lock;
 	u8 bmp_wi_progress;
 	wi_act_func curractfunc;
-	// Variable needed in each implementation of CurrActFunc.
+	/* Variable needed in each implementation of CurrActFunc. */
 	struct mp_wiparam param;
 };
 #endif
 
-struct mp_tx
-{
+struct mp_tx {
 	u8 stop;
 	u32 count, sended;
 	u8 payload;
 	struct pkt_attrib attrib;
-	//struct tx_desc desc;
-	//u8 resvdtx[7];
+	/* struct tx_desc desc; */
+	/* u8 resvdtx[7]; */
 	u8 desc[TXDESC_SIZE];
 	u8 *pallocated_buf;
 	u8 *buf;
@@ -106,39 +98,7 @@ struct mp_tx
 
 #define MP_MAX_LINES		1000
 #define MP_MAX_LINES_BYTES	256
-#define u1Byte u8
-#define s1Byte s8
-#define u4Byte u32
-#define s4Byte s32
-#define u1Byte		u8
-#define pu1Byte 		u8* 
-
-#define u2Byte		u16
-#define pu2Byte 		u16*		
-
-#define u4Byte		u32
-#define pu4Byte 		u32*	
-
-#define u8Byte		u64
-#define pu8Byte 		u64*
-
-#define s1Byte		s8
-#define ps1Byte 		s8* 
-
-#define s2Byte		s16
-#define ps2Byte 		s16*	
-
-#define s4Byte		s32
-#define ps4Byte 		s32*	
-
-#define s8Byte		s64
-#define ps8Byte 		s64*
 
-#define UCHAR u8
-#define USHORT u16
-#define UINT u32
-#define ULONG u32
-#define PULONG u32*
 
 typedef struct _RT_PMAC_PKT_INFO {
 	UCHAR			MCS;
@@ -162,14 +122,14 @@ typedef struct _RT_PMAC_TX_INFO {
 	u8			NDP_sound:1;
 	u8			BandWidth:3;		/* 0: 20 1:40 2:80Mhz */
 	u8			m_STBC;			/* bSTBC + 1 */
-	u8			PacketPeriod;
+	USHORT			PacketPeriod;
 	UINT		PacketCount;
 	UINT		PacketLength;
 	u8			PacketPattern;
-	u32			SFD;
+	USHORT			SFD;
 	u8			SignalField;
 	u8			ServiceField;
-	u8			LENGTH;
+	USHORT			LENGTH;
 	u8			CRC16[2];
 	u8			LSIG[3];
 	u8			HT_SIG[6];
@@ -182,150 +142,128 @@ typedef struct _RT_PMAC_TX_INFO {
 
 
 typedef VOID (*MPT_WORK_ITEM_HANDLER)(IN PVOID Adapter);
-typedef struct _MPT_CONTEXT
-{
-	// Indicate if we have started Mass Production Test.
+typedef struct _MPT_CONTEXT {
+	/* Indicate if we have started Mass Production Test. */
 	BOOLEAN			bMassProdTest;
 
-	// Indicate if the driver is unloading or unloaded.
+	/* Indicate if the driver is unloading or unloaded. */
 	BOOLEAN			bMptDrvUnload;
 
 	_sema			MPh2c_Sema;
 	_timer			MPh2c_timeout_timer;
-// Event used to sync H2c for BT control
+	/* Event used to sync H2c for BT control */
 
 	BOOLEAN		MptH2cRspEvent;
 	BOOLEAN		MptBtC2hEvent;
 	BOOLEAN		bMPh2c_timeout;
-	
+
 	/* 8190 PCI does not support NDIS_WORK_ITEM. */
-	// Work Item for Mass Production Test.
-	//NDIS_WORK_ITEM	MptWorkItem;
-//	RT_WORK_ITEM		MptWorkItem;
-	// Event used to sync the case unloading driver and MptWorkItem is still in progress.
-//	NDIS_EVENT		MptWorkItemEvent;
-	// To protect the following variables.
-//	NDIS_SPIN_LOCK		MptWorkItemSpinLock;
-	// Indicate a MptWorkItem is scheduled and not yet finished.
+	/* Work Item for Mass Production Test. */
+	/* NDIS_WORK_ITEM	MptWorkItem;
+	*	RT_WORK_ITEM		MptWorkItem; */
+	/* Event used to sync the case unloading driver and MptWorkItem is still in progress.
+	*	NDIS_EVENT		MptWorkItemEvent; */
+	/* To protect the following variables.
+	*	NDIS_SPIN_LOCK		MptWorkItemSpinLock; */
+	/* Indicate a MptWorkItem is scheduled and not yet finished. */
 	BOOLEAN			bMptWorkItemInProgress;
-	// An instance which implements function and context of MptWorkItem.
+	/* An instance which implements function and context of MptWorkItem. */
 	MPT_WORK_ITEM_HANDLER	CurrMptAct;
 
-	// 1=Start, 0=Stop from UI.
+	/* 1=Start, 0=Stop from UI. */
 	ULONG			MptTestStart;
-	// _TEST_MODE, defined in MPT_Req2.h
+	/* _TEST_MODE, defined in MPT_Req2.h */
 	ULONG			MptTestItem;
-	// Variable needed in each implementation of CurrMptAct.
-	ULONG			MptActType; 	// Type of action performed in CurrMptAct.
-	// The Offset of IO operation is depend of MptActType.
+	/* Variable needed in each implementation of CurrMptAct. */
+	ULONG			MptActType;	/* Type of action performed in CurrMptAct. */
+	/* The Offset of IO operation is depend of MptActType. */
 	ULONG			MptIoOffset;
-	// The Value of IO operation is depend of MptActType.
+	/* The Value of IO operation is depend of MptActType. */
 	ULONG			MptIoValue;
-	// The RfPath of IO operation is depend of MptActType.
-	ULONG			MptRfPath;
-
-	WIRELESS_MODE		MptWirelessModeToSw;	// Wireless mode to switch.
-	u8			MptChannelToSw; 	// Channel to switch.
-	u8			MptInitGainToSet; 	// Initial gain to set.
-	//ULONG			bMptAntennaA; 		// TRUE if we want to use antenna A.
-	ULONG			MptBandWidth;		// bandwidth to switch.
-	ULONG			MptRateIndex;		// rate index.
-	// Register value kept for Single Carrier Tx test.
+	/* The RfPath of IO operation is depend of MptActType. */
+
+	ULONG			mpt_rf_path;
+
+
+	WIRELESS_MODE		MptWirelessModeToSw;	/* Wireless mode to switch. */
+	u8			MptChannelToSw;	/* Channel to switch. */
+	u8			MptInitGainToSet;	/* Initial gain to set. */
+	/* ULONG			bMptAntennaA;		 */ /* TRUE if we want to use antenna A. */
+	ULONG			MptBandWidth;		/* bandwidth to switch. */
+
+	ULONG			mpt_rate_index;/* rate index. */
+
+	/* Register value kept for Single Carrier Tx test. */
 	u8			btMpCckTxPower;
-	// Register value kept for Single Carrier Tx test.
+	/* Register value kept for Single Carrier Tx test. */
 	u8			btMpOfdmTxPower;
-	// For MP Tx Power index
+	/* For MP Tx Power index */
 	u8			TxPwrLevel[4];	/* rf-A, rf-B*/
 	u32			RegTxPwrLimit;
-	// Content of RCR Regsiter for Mass Production Test.
+	/* Content of RCR Regsiter for Mass Production Test. */
 	ULONG			MptRCR;
-	// TRUE if we only receive packets with specific pattern.
+	/* TRUE if we only receive packets with specific pattern. */
 	BOOLEAN			bMptFilterPattern;
- 	// Rx OK count, statistics used in Mass Production Test.
- 	ULONG			MptRxOkCnt;
- 	// Rx CRC32 error count, statistics used in Mass Production Test.
- 	ULONG			MptRxCrcErrCnt;
-
-	BOOLEAN			bCckContTx;	// TRUE if we are in CCK Continuous Tx test.
- 	BOOLEAN			bOfdmContTx;	// TRUE if we are in OFDM Continuous Tx test.
-	BOOLEAN			bStartContTx; 	// TRUE if we have start Continuous Tx test.
-	// TRUE if we are in Single Carrier Tx test.
+	/* Rx OK count, statistics used in Mass Production Test. */
+	ULONG			MptRxOkCnt;
+	/* Rx CRC32 error count, statistics used in Mass Production Test. */
+	ULONG			MptRxCrcErrCnt;
+
+	BOOLEAN			bCckContTx;	/* TRUE if we are in CCK Continuous Tx test. */
+	BOOLEAN			bOfdmContTx;	/* TRUE if we are in OFDM Continuous Tx test. */
+		/* TRUE if we have start Continuous Tx test. */
+	BOOLEAN			is_start_cont_tx;
+
+	/* TRUE if we are in Single Carrier Tx test. */
 	BOOLEAN			bSingleCarrier;
-	// TRUE if we are in Carrier Suppression Tx Test.
-	BOOLEAN			bCarrierSuppression;
-	//TRUE if we are in Single Tone Tx test.
-	BOOLEAN			bSingleTone;
+	/* TRUE if we are in Carrier Suppression Tx Test. */
+
+	BOOLEAN			is_carrier_suppression;
 
-	// ACK counter asked by K.Y..
+	/* TRUE if we are in Single Tone Tx test. */
+
+	BOOLEAN			is_single_tone;
+
+
+	/* ACK counter asked by K.Y.. */
 	BOOLEAN			bMptEnableAckCounter;
 	ULONG			MptAckCounter;
 
-	// SD3 Willis For 8192S to save 1T/2T RF table for ACUT	Only fro ACUT delete later ~~~!
-	//s1Byte		BufOfLines[2][MAX_LINES_HWCONFIG_TXT][MAX_BYTES_LINE_HWCONFIG_TXT];
-	//s1Byte			BufOfLines[2][MP_MAX_LINES][MP_MAX_LINES_BYTES];
-	//s4Byte			RfReadLine[2];
+	/* SD3 Willis For 8192S to save 1T/2T RF table for ACUT	Only fro ACUT delete later ~~~! */
+	/* s1Byte		BufOfLines[2][MAX_LINES_HWCONFIG_TXT][MAX_BYTES_LINE_HWCONFIG_TXT]; */
+	/* s1Byte			BufOfLines[2][MP_MAX_LINES][MP_MAX_LINES_BYTES]; */
+	/* s4Byte			RfReadLine[2]; */
 
-	u8		APK_bound[2];	//for APK	path A/path B
+	u8		APK_bound[2];	/* for APK	path A/path B */
 	BOOLEAN		bMptIndexEven;
 
 	u8		backup0xc50;
 	u8		backup0xc58;
 	u8		backup0xc30;
-	u8 		backup0x52_RF_A;
-	u8 		backup0x52_RF_B;
-	
-	u4Byte			backup0x58_RF_A;	
+	u8		backup0x52_RF_A;
+	u8		backup0x52_RF_B;
+
+	u4Byte			backup0x58_RF_A;
 	u4Byte			backup0x58_RF_B;
-	
+
 	u1Byte			h2cReqNum;
 	u1Byte			c2hBuf[32];
 
-    u1Byte          btInBuf[100];
+	u1Byte          btInBuf[100];
 	ULONG			mptOutLen;
-    u1Byte          mptOutBuf[100];
+	u1Byte          mptOutBuf[100];
 	RT_PMAC_TX_INFO	PMacTxInfo;
 	RT_PMAC_PKT_INFO	PMacPktInfo;
 	u8 HWTxmode;
 
 	BOOLEAN			bldpc;
 	BOOLEAN			bstbc;
-}MPT_CONTEXT, *PMPT_CONTEXT;
-//#endif
-
-/* E-Fuse */
-#ifdef CONFIG_RTL8188E
-#define EFUSE_MAP_SIZE		512
-#endif
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A)
-#define EFUSE_MAP_SIZE		512
-#endif
-#ifdef CONFIG_RTL8192E
-#define EFUSE_MAP_SIZE		512
-#endif
-#ifdef CONFIG_RTL8723B
-#define EFUSE_MAP_SIZE		512
-#endif
-#ifdef CONFIG_RTL8814A
-#define EFUSE_MAP_SIZE		512
-#endif
-#ifdef CONFIG_RTL8703B
-#define EFUSE_MAP_SIZE		512
-#endif
-#ifdef CONFIG_RTL8188F
-#define EFUSE_MAP_SIZE		512
-#endif
+} MPT_CONTEXT, *PMPT_CONTEXT;
+/* #endif */
 
-#if defined(CONFIG_RTL8814A)
-#define EFUSE_MAX_SIZE		1024
-#elif defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8703B)
-#define EFUSE_MAX_SIZE		256
-#else
-#define EFUSE_MAX_SIZE		512
-#endif
-/* end of E-Fuse */
 
-//#define RTPRIV_IOCTL_MP 					( SIOCIWFIRSTPRIV + 0x17)
-enum {	  
+/* #define RTPRIV_IOCTL_MP					( SIOCIWFIRSTPRIV + 0x17) */
+enum {
 	WRITE_REG = 1,
 	READ_REG,
 	WRITE_RF,
@@ -334,6 +272,7 @@ enum {
 	MP_STOP,
 	MP_RATE,
 	MP_CHANNEL,
+	MP_CHL_OFFSET,
 	MP_BANDWIDTH,
 	MP_TXPOWER,
 	MP_ANT_TX,
@@ -352,7 +291,6 @@ enum {
 	MP_PHYPARA,
 	MP_SetRFPathSwh,
 	MP_QueryDrvStats,
-	MP_SetBT,
 	CTA_TEST,
 	MP_DISABLE_BT_COEXIST,
 	MP_PwrCtlDM,
@@ -364,7 +302,19 @@ enum {
 	MP_RX,
 	MP_IQK,
 	MP_LCK,
+	MP_HW_TX_MODE,
+	MP_GET_TXPOWER_INX,
 	MP_CUSTOMER_STR,
+	MP_PWRLMT,
+	MP_PWRBYRATE,
+	BT_EFUSE_FILE,
+	MP_SetBT,
+	MP_SWRFPath,
+	MP_NULL,
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	VENDOR_IE_SET ,
+	VENDOR_IE_GET ,
+#endif
 #ifdef CONFIG_WOWLAN
 	MP_WOW_ENABLE,
 	MP_WOW_SET_PATTERN,
@@ -372,34 +322,30 @@ enum {
 #ifdef CONFIG_AP_WOWLAN
 	MP_AP_WOW_ENABLE,
 #endif
-	MP_NULL,
-	MP_GET_TXPOWER_INX,
-
 	MP_SD_IREAD,
 	MP_SD_IWRITE,
 };
 
-struct mp_priv
-{
+struct mp_priv {
 	_adapter *papdater;
 
-	//Testing Flag
-	u32 mode;//0 for normal type packet, 1 for loopback packet (16bytes TXCMD)
+	/* Testing Flag */
+	u32 mode;/* 0 for normal type packet, 1 for loopback packet (16bytes TXCMD) */
 
 	u32 prev_fw_state;
 
-	//OID cmd handler
+	/* OID cmd handler */
 	struct mp_wiparam workparam;
-//	u8 act_in_progress;
+	/*	u8 act_in_progress; */
 
-	//Tx Section
+	/* Tx Section */
 	u8 TID;
 	u32 tx_pktcount;
 	u32 pktInterval;
 	u32 pktLength;
 	struct mp_tx tx;
 
-	//Rx Section
+	/* Rx Section */
 	u32 rx_bssidpktcount;
 	u32 rx_pktcount;
 	u32 rx_pktcount_filter_out;
@@ -408,29 +354,32 @@ struct mp_priv
 	BOOLEAN  rx_bindicatePkt;
 	struct recv_stat rxstat;
 
-	//RF/BB relative
+	/* RF/BB relative */
 	u8 channel;
 	u8 bandwidth;
 	u8 prime_channel_offset;
 	u8 txpoweridx;
 	u8 rateidx;
 	u32 preamble;
-//	u8 modem;
+	/*	u8 modem; */
 	u32 CrystalCap;
-//	u32 curr_crystalcap;
+	/*	u32 curr_crystalcap; */
 
 	u16 antenna_tx;
 	u16 antenna_rx;
-//	u8 curr_rfpath;
-	
+	/*	u8 curr_rfpath; */
+
 	u8 check_mp_pkt;
 
 	u8 bSetTxPower;
-//	uint ForcedDataRate;
+	/*	uint ForcedDataRate; */
 	u8 mp_dm;
 	u8 mac_filter[ETH_ALEN];
 	u8 bmac_filter;
-	
+
+	/* RF PATH Setting for WLG WLA BTG BT */
+	u8 rf_path_cfg;
+
 	struct wlan_network mp_network;
 	NDIS_802_11_MAC_ADDRESS network_macaddr;
 
@@ -466,7 +415,12 @@ struct mp_priv
 	BOOLEAN bSetRxBssid;
 	BOOLEAN bTxBufCkFail;
 	BOOLEAN bRTWSmbCfg;
-	MPT_CONTEXT MptCtx;
+	BOOLEAN bloopback;
+	BOOLEAN bloadefusemap;
+	BOOLEAN bloadBTefusemap;
+
+	MPT_CONTEXT	mpt_ctx;
+
 
 	u8		*TXradomBuffer;
 };
@@ -475,7 +429,7 @@ typedef struct _IOCMD_STRUCT_ {
 	u8	cmdclass;
 	u16	value;
 	u8	index;
-}IOCMD_STRUCT;
+} IOCMD_STRUCT;
 
 struct rf_reg_param {
 	u32 path;
@@ -491,19 +445,19 @@ struct bb_reg_param {
 typedef struct _MP_FIRMWARE {
 	FIRMWARE_SOURCE eFWSource;
 #ifdef CONFIG_EMBEDDED_FWIMG
-	u8* 		szFwBuffer;
+	u8		*szFwBuffer;
 #else
 	u8			szFwBuffer[0x8000];
 #endif
-	u32 		ulFwLength;
+	u32		ulFwLength;
 } RT_MP_FIRMWARE, *PRT_MP_FIRMWARE;
 
 
 
 
-//=======================================================================
+/* *********************************************************************** */
 
-#define LOWER 	_TRUE
+#define LOWER	_TRUE
 #define RAISE	_FALSE
 
 /* Hardware Registers */
@@ -574,8 +528,7 @@ typedef enum _MPT_BANDWIDTH {
 extern u8 mpdatarate[NumRates];
 
 /* MP set force data rate base on the definition. */
-typedef enum _MPT_RATE_INDEX
-{
+typedef enum _MPT_RATE_INDEX {
 	/* CCK rate. */
 	MPT_RATE_1M = 1 ,	/* 0 */
 	MPT_RATE_2M,
@@ -610,34 +563,34 @@ typedef enum _MPT_RATE_INDEX
 	MPT_RATE_MCS14,
 	MPT_RATE_MCS15,	/* 27 */
 	MPT_RATE_MCS16,
-	MPT_RATE_MCS17, // #29
+	MPT_RATE_MCS17, /*  #29 */
 	MPT_RATE_MCS18,
 	MPT_RATE_MCS19,
 	MPT_RATE_MCS20,
 	MPT_RATE_MCS21,
-	MPT_RATE_MCS22, // #34
+	MPT_RATE_MCS22, /*  #34 */
 	MPT_RATE_MCS23,
 	MPT_RATE_MCS24,
 	MPT_RATE_MCS25,
 	MPT_RATE_MCS26,
-	MPT_RATE_MCS27, // #39
-	MPT_RATE_MCS28, // #40
-	MPT_RATE_MCS29, // #41
-	MPT_RATE_MCS30, // #42
-	MPT_RATE_MCS31, // #43
+	MPT_RATE_MCS27, /*  #39 */
+	MPT_RATE_MCS28, /*  #40 */
+	MPT_RATE_MCS29, /*  #41 */
+	MPT_RATE_MCS30, /*  #42 */
+	MPT_RATE_MCS31, /*  #43 */
 	/* VHT rate. Total: 20*/
 	MPT_RATE_VHT1SS_MCS0 = 100,/*  #44*/
-	MPT_RATE_VHT1SS_MCS1, // #
+	MPT_RATE_VHT1SS_MCS1, /*  # */
 	MPT_RATE_VHT1SS_MCS2,
 	MPT_RATE_VHT1SS_MCS3,
 	MPT_RATE_VHT1SS_MCS4,
 	MPT_RATE_VHT1SS_MCS5,
-	MPT_RATE_VHT1SS_MCS6, // #
+	MPT_RATE_VHT1SS_MCS6, /*  # */
 	MPT_RATE_VHT1SS_MCS7,
 	MPT_RATE_VHT1SS_MCS8,
-	MPT_RATE_VHT1SS_MCS9, //#53
-	MPT_RATE_VHT2SS_MCS0, //#54
-	MPT_RATE_VHT2SS_MCS1, 
+	MPT_RATE_VHT1SS_MCS9, /* #53 */
+	MPT_RATE_VHT2SS_MCS0, /* #54 */
+	MPT_RATE_VHT2SS_MCS1,
 	MPT_RATE_VHT2SS_MCS2,
 	MPT_RATE_VHT2SS_MCS3,
 	MPT_RATE_VHT2SS_MCS4,
@@ -645,31 +598,31 @@ typedef enum _MPT_RATE_INDEX
 	MPT_RATE_VHT2SS_MCS6,
 	MPT_RATE_VHT2SS_MCS7,
 	MPT_RATE_VHT2SS_MCS8,
-	MPT_RATE_VHT2SS_MCS9, //#63
+	MPT_RATE_VHT2SS_MCS9, /* #63 */
 	MPT_RATE_VHT3SS_MCS0,
-	MPT_RATE_VHT3SS_MCS1, 
+	MPT_RATE_VHT3SS_MCS1,
 	MPT_RATE_VHT3SS_MCS2,
 	MPT_RATE_VHT3SS_MCS3,
 	MPT_RATE_VHT3SS_MCS4,
 	MPT_RATE_VHT3SS_MCS5,
-	MPT_RATE_VHT3SS_MCS6, // #126
+	MPT_RATE_VHT3SS_MCS6, /*  #126 */
 	MPT_RATE_VHT3SS_MCS7,
 	MPT_RATE_VHT3SS_MCS8,
 	MPT_RATE_VHT3SS_MCS9,
 	MPT_RATE_VHT4SS_MCS0,
-	MPT_RATE_VHT4SS_MCS1, // #131
+	MPT_RATE_VHT4SS_MCS1, /*  #131 */
 	MPT_RATE_VHT4SS_MCS2,
 	MPT_RATE_VHT4SS_MCS3,
 	MPT_RATE_VHT4SS_MCS4,
 	MPT_RATE_VHT4SS_MCS5,
-	MPT_RATE_VHT4SS_MCS6, // #136
+	MPT_RATE_VHT4SS_MCS6, /*  #136 */
 	MPT_RATE_VHT4SS_MCS7,
 	MPT_RATE_VHT4SS_MCS8,
 	MPT_RATE_VHT4SS_MCS9,
 	MPT_RATE_LAST
-}MPT_RATE_E, *PMPT_RATE_E;
+} MPT_RATE_E, *PMPT_RATE_E;
 
-#define MAX_TX_PWR_INDEX_N_MODE 64	// 0x3F
+#define MAX_TX_PWR_INDEX_N_MODE 64	/* 0x3F */
 
 #define MPT_IS_CCK_RATE(_value)		(MPT_RATE_1M <= _value && _value <= MPT_RATE_11M)
 #define MPT_IS_OFDM_RATE(_value)	(MPT_RATE_6M <= _value && _value <= MPT_RATE_54M)
@@ -685,24 +638,24 @@ typedef enum _MPT_RATE_INDEX
 #define MPT_IS_VHT_3S_RATE(_value)	(MPT_RATE_VHT3SS_MCS0 <= _value && _value <= MPT_RATE_VHT3SS_MCS9)
 #define MPT_IS_VHT_4S_RATE(_value)	(MPT_RATE_VHT4SS_MCS0 <= _value && _value <= MPT_RATE_VHT4SS_MCS9)
 
-#define MPT_IS_2SS_RATE(_rate) ((MPT_RATE_MCS8 <= _rate && _rate <= MPT_RATE_MCS15) ||\
-							(MPT_RATE_VHT2SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT2SS_MCS9))
-#define MPT_IS_3SS_RATE(_rate) ((MPT_RATE_MCS16 <= _rate && _rate <= MPT_RATE_MCS23) ||\
-							(MPT_RATE_VHT3SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT3SS_MCS9))
-#define MPT_IS_4SS_RATE(_rate) ((MPT_RATE_MCS24 <= _rate && _rate <= MPT_RATE_MCS31) ||\
-							(MPT_RATE_VHT4SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT4SS_MCS9))
+#define MPT_IS_2SS_RATE(_rate) ((MPT_RATE_MCS8 <= _rate && _rate <= MPT_RATE_MCS15) || \
+	(MPT_RATE_VHT2SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT2SS_MCS9))
+#define MPT_IS_3SS_RATE(_rate) ((MPT_RATE_MCS16 <= _rate && _rate <= MPT_RATE_MCS23) || \
+	(MPT_RATE_VHT3SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT3SS_MCS9))
+#define MPT_IS_4SS_RATE(_rate) ((MPT_RATE_MCS24 <= _rate && _rate <= MPT_RATE_MCS31) || \
+	(MPT_RATE_VHT4SS_MCS0 <= _rate && _rate <= MPT_RATE_VHT4SS_MCS9))
 
 typedef enum _POWER_MODE_ {
 	POWER_LOW = 0,
 	POWER_NORMAL
-}POWER_MODE;
+} POWER_MODE;
 
-// The following enumeration is used to define the value of Reg0xD00[30:28] or JaguarReg0x914[18:16].
+/* The following enumeration is used to define the value of Reg0xD00[30:28] or JaguarReg0x914[18:16]. */
 typedef enum _OFDM_TX_MODE {
-	OFDM_ALL_OFF		= 0,	
+	OFDM_ALL_OFF		= 0,
 	OFDM_ContinuousTx	= 1,
 	OFDM_SingleCarrier	= 2,
-	OFDM_SingleTone 	= 4,
+	OFDM_SingleTone	= 4,
 } OFDM_TX_MODE;
 
 
@@ -710,54 +663,31 @@ typedef enum _OFDM_TX_MODE {
 #define RX_PKT_DEST_ADDR	2
 #define RX_PKT_PHY_MATCH	3
 
-#define Mac_OFDM_OK 			0x00000000
-#define Mac_OFDM_Fail			0x10000000
-#define Mac_OFDM_FasleAlarm 	0x20000000
-#define Mac_CCK_OK				0x30000000
-#define Mac_CCK_Fail			0x40000000
-#define Mac_CCK_FasleAlarm		0x50000000
-#define Mac_HT_OK				0x60000000
-#define Mac_HT_Fail 			0x70000000
-#define Mac_HT_FasleAlarm		0x90000000
-#define Mac_DropPacket			0xA0000000
-
 typedef enum _ENCRY_CTRL_STATE_ {
-	HW_CONTROL,		//hw encryption& decryption
-	SW_CONTROL,		//sw encryption& decryption
-	HW_ENCRY_SW_DECRY,	//hw encryption & sw decryption
-	SW_ENCRY_HW_DECRY	//sw encryption & hw decryption
-}ENCRY_CTRL_STATE;
+	HW_CONTROL,		/* hw encryption& decryption */
+	SW_CONTROL,		/* sw encryption& decryption */
+	HW_ENCRY_SW_DECRY,	/* hw encryption & sw decryption */
+	SW_ENCRY_HW_DECRY	/* sw encryption & hw decryption */
+} ENCRY_CTRL_STATE;
 
-typedef enum	_MPT_TXPWR_DEF{
+typedef enum	_MPT_TXPWR_DEF {
 	MPT_CCK,
-	MPT_OFDM, // L and HT OFDM
+	MPT_OFDM, /* L and HT OFDM */
 	MPT_OFDM_AND_HT,
 	MPT_HT,
 	MPT_VHT
-}MPT_TXPWR_DEF;
-
-#ifdef CONFIG_RF_GAIN_OFFSET
-
-#if defined(CONFIG_RTL8723B)
-	#define 	REG_RF_BB_GAIN_OFFSET	0x7f
-	#define 	RF_GAIN_OFFSET_MASK 	0xfffff
-#elif defined(CONFIG_RTL8188E)
-	#define 	REG_RF_BB_GAIN_OFFSET	0x55
-	#define 	RF_GAIN_OFFSET_MASK 	0xfffff
-#else
-	#define 	REG_RF_BB_GAIN_OFFSET	0x55
-	#define 	RF_GAIN_OFFSET_MASK 	0xfffff
-#endif	//CONFIG_RTL8723B
+} MPT_TXPWR_DEF;
 
-#endif //CONFIG_RF_GAIN_OFFSET
 
 #define IS_MPT_HT_RATE(_rate)			(_rate >= MPT_RATE_MCS0 && _rate <= MPT_RATE_MCS31)
 #define IS_MPT_VHT_RATE(_rate)			(_rate >= MPT_RATE_VHT1SS_MCS0 && _rate <= MPT_RATE_VHT4SS_MCS9)
 #define IS_MPT_CCK_RATE(_rate)			(_rate >= MPT_RATE_1M && _rate <= MPT_RATE_11M)
 #define IS_MPT_OFDM_RATE(_rate)			(_rate >= MPT_RATE_6M && _rate <= MPT_RATE_54M)
-//=======================================================================
-//extern struct mp_xmit_frame *alloc_mp_xmitframe(struct mp_priv *pmp_priv);
-//extern int free_mp_xmitframe(struct xmit_priv *pxmitpriv, struct mp_xmit_frame *pmp_xmitframe);
+/*************************************************************************/
+#if 0
+extern struct mp_xmit_frame *alloc_mp_xmitframe(struct mp_priv *pmp_priv);
+extern int free_mp_xmitframe(struct xmit_priv *pxmitpriv, struct mp_xmit_frame *pmp_xmitframe);
+#endif
 
 extern s32 init_mp_priv(PADAPTER padapter);
 extern void free_mp_priv(struct mp_priv *pmp_priv);
@@ -775,7 +705,9 @@ extern u32 read_bbreg(_adapter *padapter, u32 addr, u32 bitmask);
 extern void write_bbreg(_adapter *padapter, u32 addr, u32 bitmask, u32 val);
 extern u32 read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr);
 extern void write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 val);
-
+#ifdef CONFIG_ANTENNA_DIVERSITY
+u8 rtw_mp_set_antdiv(PADAPTER padapter, BOOLEAN bMain);
+#endif
 void	SetChannel(PADAPTER pAdapter);
 void	SetBandwidth(PADAPTER pAdapter);
 int	SetTxPower(PADAPTER pAdapter);
@@ -800,7 +732,7 @@ void	GetPowerTracking(PADAPTER padapter, u8 *enable);
 u32	mp_query_psd(PADAPTER pAdapter, u8 *data);
 void	rtw_mp_trigger_iqk(PADAPTER padapter);
 void	rtw_mp_trigger_lck(PADAPTER padapter);
-
+u8 rtw_mp_mode_check(PADAPTER padapter);
 
 
 void hal_mpt_SwitchRfSetting(PADAPTER pAdapter);
@@ -820,38 +752,38 @@ void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart);
 void hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart);
 void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart);
 void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
-void hal_mpt_SetCCKContinuousTx(PADAPTER pAdapter, u8 bStart);
-void hal_mpt_SetOFDMContinuousTx(PADAPTER pAdapter, u8 bStart);
-VOID mpt_ProSetPMacTx(PADAPTER	Adapter);
-
+void mpt_ProSetPMacTx(PADAPTER	Adapter);
 void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter , BOOLEAN bMain);
+void mp_phy_switch_rf_path_set(PADAPTER pAdapter , u8 *pstate);
+u8 MP_PHY_QueryRFPathSwitch(PADAPTER pAdapter);
 ULONG mpt_ProQueryCalTxPower(PADAPTER	pAdapter, u8 RfPath);
 void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart);
-u8 MptToMgntRate(u32	MptRateIdx);
+u8 mpt_to_mgnt_rate(u32	MptRateIdx);
 u8 rtw_mpRateParseFunc(PADAPTER pAdapter, u8 *targetStr);
 u32 mp_join(PADAPTER padapter, u8 mode);
+u32 hal_mpt_query_phytxok(PADAPTER	pAdapter);
 
 void
 PMAC_Get_Pkt_Param(
 	PRT_PMAC_TX_INFO	pPMacTxInfo,
 	PRT_PMAC_PKT_INFO	pPMacPktInfo
-	);
+);
 void
 CCK_generator(
 	PRT_PMAC_TX_INFO	pPMacTxInfo,
 	PRT_PMAC_PKT_INFO	pPMacPktInfo
-	);
+);
 void
 PMAC_Nsym_generator(
 	PRT_PMAC_TX_INFO	pPMacTxInfo,
 	PRT_PMAC_PKT_INFO	pPMacPktInfo
-	);
+);
 void
 L_SIG_generator(
 	UINT	N_SYM,		/* Max: 750*/
 	PRT_PMAC_TX_INFO	pPMacTxInfo,
 	PRT_PMAC_PKT_INFO	pPMacPktInfo
-	);
+);
 
 void HT_SIG_generator(
 	PRT_PMAC_TX_INFO	pPMacTxInfo,
@@ -869,120 +801,137 @@ void VHT_Delimiter_generator(
 
 
 int rtw_mp_write_reg(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_read_reg(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_write_rf(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_read_rf(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_start(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_stop(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_rate(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_channel(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_ch_offset(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_bandwidth(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_txpower_index(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_txpower(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_txpower(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_ant_tx(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_ant_rx(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_set_ctx_destAddr(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_ctx(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_disable_bt_coexist(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_mp_disable_bt_coexist(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_mp_arx(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_trx_query(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_pwrtrk(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_psd(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_thermal(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_reset_stats(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_dump(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_phypara(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_SetRFPath(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
+int rtw_mp_switch_rf_path(struct net_device *dev,
 			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+			struct iw_point *wrqu, char *extra);
 int rtw_mp_QueryDrv(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_mp_PwrCtlDM(struct net_device *dev,
-			struct iw_request_info *info,
-			struct iw_point *wrqu, char *extra);
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_getver(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_mp_mon(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_pwrlmt(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_pwrbyrate(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_efuse_mask_file(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_efuse_file_map(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_bt_efuse_file_map(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_mp_SetBT(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra);
 int rtw_mp_tx(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 int rtw_mp_rx(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wrqu, char *extra);
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
+int rtw_mp_hwtx(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra);
 u8 HwRateToMPTRate(u8 rate);
 int rtw_mp_iqk(struct net_device *dev,
 		 struct iw_request_info *info,
 		 struct iw_point *wrqu, char *extra);
-int rtw_mp_lck(struct net_device *dev, 
-		struct iw_request_info *info, 
+int rtw_mp_lck(struct net_device *dev,
+		struct iw_request_info *info,
 		struct iw_point *wrqu, char *extra);
-#endif //_RTW_MP_H_
-
+#endif /* _RTW_MP_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_ioctl.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_ioctl.h
index cd6303c2d31c..df9286989805 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_ioctl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_ioctl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_MP_IOCTL_H_
 #define _RTW_MP_IOCTL_H_
 
@@ -30,54 +26,54 @@
 #define HCI_TEST_SYSCFG_HWMASK		1
 #define _BUSCLK_40M			(4 << 2)
 #endif
-//------------------------------------------------------------------------------
+/* ------------------------------------------------------------------------------ */
 typedef struct CFG_DBG_MSG_STRUCT {
 	u32 DebugLevel;
 	u32 DebugComponent_H32;
 	u32 DebugComponent_L32;
-}CFG_DBG_MSG_STRUCT,*PCFG_DBG_MSG_STRUCT;
+} CFG_DBG_MSG_STRUCT, *PCFG_DBG_MSG_STRUCT;
 
 typedef struct _RW_REG {
 	u32 offset;
 	u32 width;
 	u32 value;
-}mp_rw_reg,RW_Reg, *pRW_Reg;
+} mp_rw_reg, RW_Reg, *pRW_Reg;
 
-//for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM
+/* for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM */
 typedef struct _EEPROM_RW_PARAM {
 	u32 offset;
 	u16 value;
-}eeprom_rw_param,EEPROM_RWParam, *pEEPROM_RWParam;
+} eeprom_rw_param, EEPROM_RWParam, *pEEPROM_RWParam;
 
 typedef struct _EFUSE_ACCESS_STRUCT_ {
 	u16	start_addr;
 	u16	cnts;
 	u8	data[0];
-}EFUSE_ACCESS_STRUCT, *PEFUSE_ACCESS_STRUCT;
+} EFUSE_ACCESS_STRUCT, *PEFUSE_ACCESS_STRUCT;
 
 typedef struct _BURST_RW_REG {
 	u32 offset;
 	u32 len;
 	u8 Data[256];
-}burst_rw_reg,Burst_RW_Reg, *pBurst_RW_Reg;
+} burst_rw_reg, Burst_RW_Reg, *pBurst_RW_Reg;
 
-typedef struct _USB_VendorReq{
+typedef struct _USB_VendorReq {
 	u8	bRequest;
 	u16	wValue;
 	u16	wIndex;
 	u16	wLength;
-	u8	u8Dir;//0:OUT, 1:IN
+	u8	u8Dir;/* 0:OUT, 1:IN */
 	u8	u8InData;
-}usb_vendor_req, USB_VendorReq, *pUSB_VendorReq;
+} usb_vendor_req, USB_VendorReq, *pUSB_VendorReq;
 
 typedef struct _DR_VARIABLE_STRUCT_ {
 	u8 offset;
 	u32 variable;
-}DR_VARIABLE_STRUCT;
+} DR_VARIABLE_STRUCT;
 
-//int mp_start_joinbss(_adapter *padapter, NDIS_802_11_SSID *pssid);
+/* int mp_start_joinbss(_adapter *padapter, NDIS_802_11_SSID *pssid); */
 
-//void _irqlevel_changed_(_irqL *irqlevel, /*BOOLEAN*/unsigned char bLower);
+/* void _irqlevel_changed_(_irqL *irqlevel, BOOLEANunsigned char bLower); */
 #ifdef PLATFORM_OS_XP
 static void _irqlevel_changed_(_irqL *irqlevel, u8 bLower)
 {
@@ -85,89 +81,87 @@ static void _irqlevel_changed_(_irqL *irqlevel, u8 bLower)
 	if (bLower == LOWER) {
 		*irqlevel = KeGetCurrentIrql();
 
-		if (*irqlevel > PASSIVE_LEVEL) {
+		if (*irqlevel > PASSIVE_LEVEL)
 			KeLowerIrql(PASSIVE_LEVEL);
-		}
 	} else {
-		if (KeGetCurrentIrql() == PASSIVE_LEVEL) {
+		if (KeGetCurrentIrql() == PASSIVE_LEVEL)
 			KeRaiseIrql(DISPATCH_LEVEL, irqlevel);
-		}
 	}
 
 }
 #else
-#define _irqlevel_changed_(a,b)
+#define _irqlevel_changed_(a, b)
 #endif
 
-//oid_rtl_seg_81_80_00
-NDIS_STATUS oid_rt_pro_set_data_rate_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_start_test_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_stop_test_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_channel_direct_call_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_antenna_bb_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_tx_power_control_hdl(struct oid_par_priv* poid_par_priv);
-//oid_rtl_seg_81_80_20
-NDIS_STATUS oid_rt_pro_query_tx_packet_sent_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_query_rx_packet_received_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_query_rx_packet_crc32_error_hdl(struct oid_par_priv* poid_par_priv);
-
-NDIS_STATUS oid_rt_pro_reset_tx_packet_sent_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_reset_rx_packet_received_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_modulation_hdl(struct oid_par_priv* poid_par_priv);
-
-NDIS_STATUS oid_rt_pro_set_continuous_tx_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_single_carrier_tx_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_carrier_suppression_tx_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_single_tone_tx_hdl(struct oid_par_priv* poid_par_priv);
-
-
-//oid_rtl_seg_81_87
-NDIS_STATUS oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv* poid_par_priv);
-
-NDIS_STATUS oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv* poid_par_priv);
-
-
-//oid_rtl_seg_81_85
-NDIS_STATUS oid_rt_wireless_mode_hdl(struct oid_par_priv* poid_par_priv);
-
-
-// oid_rtl_seg_87_11_00
-NDIS_STATUS oid_rt_pro8711_join_bss_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_read_register_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_write_register_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_burst_read_register_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_burst_write_register_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_write_txcmd_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_read16_eeprom_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_write16_eeprom_hdl (struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro8711_wi_poll_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro8711_pkt_loss_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_rd_attrib_mem_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_wr_attrib_mem_hdl (struct oid_par_priv* poid_par_priv);
-NDIS_STATUS  oid_rt_pro_set_rf_intfs_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_poll_rx_status_hdl(struct oid_par_priv* poid_par_priv);
-// oid_rtl_seg_87_11_20
-NDIS_STATUS oid_rt_pro_cfg_debug_message_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_data_rate_ex_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_basic_rate_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_read_tssi_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_power_tracking_hdl(struct oid_par_priv* poid_par_priv);
-//oid_rtl_seg_87_11_50
-NDIS_STATUS oid_rt_pro_qry_pwrstate_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_pwrstate_hdl(struct oid_par_priv* poid_par_priv);
-//oid_rtl_seg_87_11_F0
-NDIS_STATUS oid_rt_pro_h2c_set_rate_table_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_h2c_get_rate_table_hdl(struct oid_par_priv* poid_par_priv);
-
-
-//oid_rtl_seg_87_12_00
-NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_dele_sta_info_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_query_dr_variable_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_rx_packet_type_hdl(struct oid_par_priv* poid_par_priv);
+/* oid_rtl_seg_81_80_00 */
+NDIS_STATUS oid_rt_pro_set_data_rate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_start_test_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_stop_test_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_channel_direct_call_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_antenna_bb_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_tx_power_control_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_81_80_20 */
+NDIS_STATUS oid_rt_pro_query_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_query_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_query_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_reset_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_reset_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_modulation_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_set_continuous_tx_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_single_carrier_tx_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_carrier_suppression_tx_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_single_tone_tx_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_81_87 */
+NDIS_STATUS oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv *poid_par_priv);
+
+NDIS_STATUS oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_81_85 */
+NDIS_STATUS oid_rt_wireless_mode_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_87_11_00 */
+NDIS_STATUS oid_rt_pro8711_join_bss_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_write_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_burst_read_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_burst_write_register_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_write_txcmd_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read16_eeprom_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_write16_eeprom_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro8711_wi_poll_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro8711_pkt_loss_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_rd_attrib_mem_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_wr_attrib_mem_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS  oid_rt_pro_set_rf_intfs_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_poll_rx_status_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_87_11_20 */
+NDIS_STATUS oid_rt_pro_cfg_debug_message_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_data_rate_ex_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_basic_rate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_read_tssi_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_power_tracking_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_87_11_50 */
+NDIS_STATUS oid_rt_pro_qry_pwrstate_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_pwrstate_hdl(struct oid_par_priv *poid_par_priv);
+/* oid_rtl_seg_87_11_F0 */
+NDIS_STATUS oid_rt_pro_h2c_set_rate_table_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_h2c_get_rate_table_hdl(struct oid_par_priv *poid_par_priv);
+
+
+/* oid_rtl_seg_87_12_00 */
+NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_dele_sta_info_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_query_dr_variable_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv);
 
 NDIS_STATUS oid_rt_pro_read_efuse_hdl(struct oid_par_priv *poid_par_priv);
 NDIS_STATUS oid_rt_pro_write_efuse_hdl(struct oid_par_priv *poid_par_priv);
@@ -176,225 +170,212 @@ NDIS_STATUS oid_rt_get_efuse_current_size_hdl(struct oid_par_priv *poid_par_priv
 NDIS_STATUS oid_rt_pro_efuse_hdl(struct oid_par_priv *poid_par_priv);
 NDIS_STATUS oid_rt_pro_efuse_map_hdl(struct oid_par_priv *poid_par_priv);
 
-NDIS_STATUS oid_rt_set_bandwidth_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_set_crystal_cap_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_set_rx_packet_type_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_efuse_max_size_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_pro_set_tx_agc_offset_hdl(struct oid_par_priv* poid_par_priv);
+NDIS_STATUS oid_rt_set_bandwidth_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_crystal_cap_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_set_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_efuse_max_size_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_tx_agc_offset_hdl(struct oid_par_priv *poid_par_priv);
 
-NDIS_STATUS oid_rt_pro_set_pkt_test_mode_hdl(struct oid_par_priv* poid_par_priv);
+NDIS_STATUS oid_rt_pro_set_pkt_test_mode_hdl(struct oid_par_priv *poid_par_priv);
 
-NDIS_STATUS oid_rt_get_thermal_meter_hdl(struct oid_par_priv* poid_par_priv);
+NDIS_STATUS oid_rt_get_thermal_meter_hdl(struct oid_par_priv *poid_par_priv);
 
-NDIS_STATUS oid_rt_reset_phy_rx_packet_count_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_phy_rx_packet_received_hdl(struct oid_par_priv* poid_par_priv);
-NDIS_STATUS oid_rt_get_phy_rx_packet_crc32_error_hdl(struct oid_par_priv* poid_par_priv);
+NDIS_STATUS oid_rt_reset_phy_rx_packet_count_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_phy_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv);
+NDIS_STATUS oid_rt_get_phy_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv);
 
-NDIS_STATUS oid_rt_set_power_down_hdl(struct oid_par_priv* poid_par_priv);
+NDIS_STATUS oid_rt_set_power_down_hdl(struct oid_par_priv *poid_par_priv);
 
-NDIS_STATUS oid_rt_get_power_mode_hdl(struct oid_par_priv* poid_par_priv);
+NDIS_STATUS oid_rt_get_power_mode_hdl(struct oid_par_priv *poid_par_priv);
 
 NDIS_STATUS oid_rt_pro_trigger_gpio_hdl(struct oid_par_priv *poid_par_priv);
 
 #ifdef _RTW_MP_IOCTL_C_
 
-const struct oid_obj_priv oid_rtl_seg_81_80_00[] =
-{
-	{1, &oid_null_function},			//0x00	OID_RT_PRO_RESET_DUT
-	{1, &oid_rt_pro_set_data_rate_hdl},		//0x01
-	{1, &oid_rt_pro_start_test_hdl},		//0x02
-	{1, &oid_rt_pro_stop_test_hdl},			//0x03
-	{1, &oid_null_function},			//0x04	OID_RT_PRO_SET_PREAMBLE
-	{1, &oid_null_function},			//0x05	OID_RT_PRO_SET_SCRAMBLER
-	{1, &oid_null_function},			//0x06	OID_RT_PRO_SET_FILTER_BB
-	{1, &oid_null_function},			//0x07	OID_RT_PRO_SET_MANUAL_DIVERSITY_BB
-	{1, &oid_rt_pro_set_channel_direct_call_hdl},	//0x08
-	{1, &oid_null_function},			//0x09	OID_RT_PRO_SET_SLEEP_MODE_DIRECT_CALL
-	{1, &oid_null_function},			//0x0A	OID_RT_PRO_SET_WAKE_MODE_DIRECT_CALL
-	{1, &oid_rt_pro_set_continuous_tx_hdl},		//0x0B	OID_RT_PRO_SET_TX_CONTINUOUS_DIRECT_CALL
-	{1, &oid_rt_pro_set_single_carrier_tx_hdl},	//0x0C	OID_RT_PRO_SET_SINGLE_CARRIER_TX_CONTINUOUS
-	{1, &oid_null_function},			//0x0D	OID_RT_PRO_SET_TX_ANTENNA_BB
-	{1, &oid_rt_pro_set_antenna_bb_hdl},		//0x0E
-	{1, &oid_null_function},			//0x0F	OID_RT_PRO_SET_CR_SCRAMBLER
-	{1, &oid_null_function},			//0x10	OID_RT_PRO_SET_CR_NEW_FILTER
-	{1, &oid_rt_pro_set_tx_power_control_hdl},	//0x11	OID_RT_PRO_SET_TX_POWER_CONTROL
-	{1, &oid_null_function},			//0x12	OID_RT_PRO_SET_CR_TX_CONFIG
-	{1, &oid_null_function},			//0x13	OID_RT_PRO_GET_TX_POWER_CONTROL
-	{1, &oid_null_function},			//0x14	OID_RT_PRO_GET_CR_SIGNAL_QUALITY
-	{1, &oid_null_function},			//0x15	OID_RT_PRO_SET_CR_SETPOINT
-	{1, &oid_null_function},			//0x16	OID_RT_PRO_SET_INTEGRATOR
-	{1, &oid_null_function},			//0x17	OID_RT_PRO_SET_SIGNAL_QUALITY
-	{1, &oid_null_function},			//0x18	OID_RT_PRO_GET_INTEGRATOR
-	{1, &oid_null_function},			//0x19	OID_RT_PRO_GET_SIGNAL_QUALITY
-	{1, &oid_null_function},			//0x1A	OID_RT_PRO_QUERY_EEPROM_TYPE
-	{1, &oid_null_function},			//0x1B	OID_RT_PRO_WRITE_MAC_ADDRESS
-	{1, &oid_null_function},			//0x1C	OID_RT_PRO_READ_MAC_ADDRESS
-	{1, &oid_null_function},			//0x1D	OID_RT_PRO_WRITE_CIS_DATA
-	{1, &oid_null_function},			//0x1E	OID_RT_PRO_READ_CIS_DATA
-	{1, &oid_null_function}				//0x1F	OID_RT_PRO_WRITE_POWER_CONTROL
+const struct oid_obj_priv oid_rtl_seg_81_80_00[] = {
+	{1, &oid_null_function},			/* 0x00	OID_RT_PRO_RESET_DUT */
+	{1, &oid_rt_pro_set_data_rate_hdl},		/* 0x01 */
+	{1, &oid_rt_pro_start_test_hdl},		/* 0x02 */
+	{1, &oid_rt_pro_stop_test_hdl},			/* 0x03 */
+	{1, &oid_null_function},			/* 0x04	OID_RT_PRO_SET_PREAMBLE */
+	{1, &oid_null_function},			/* 0x05	OID_RT_PRO_SET_SCRAMBLER */
+	{1, &oid_null_function},			/* 0x06	OID_RT_PRO_SET_FILTER_BB */
+	{1, &oid_null_function},			/* 0x07	OID_RT_PRO_SET_MANUAL_DIVERSITY_BB */
+	{1, &oid_rt_pro_set_channel_direct_call_hdl},	/* 0x08 */
+	{1, &oid_null_function},			/* 0x09	OID_RT_PRO_SET_SLEEP_MODE_DIRECT_CALL */
+	{1, &oid_null_function},			/* 0x0A	OID_RT_PRO_SET_WAKE_MODE_DIRECT_CALL */
+	{1, &oid_rt_pro_set_continuous_tx_hdl},		/* 0x0B	OID_RT_PRO_SET_TX_CONTINUOUS_DIRECT_CALL */
+	{1, &oid_rt_pro_set_single_carrier_tx_hdl},	/* 0x0C	OID_RT_PRO_SET_SINGLE_CARRIER_TX_CONTINUOUS */
+	{1, &oid_null_function},			/* 0x0D	OID_RT_PRO_SET_TX_ANTENNA_BB */
+	{1, &oid_rt_pro_set_antenna_bb_hdl},		/* 0x0E */
+	{1, &oid_null_function},			/* 0x0F	OID_RT_PRO_SET_CR_SCRAMBLER */
+	{1, &oid_null_function},			/* 0x10	OID_RT_PRO_SET_CR_NEW_FILTER */
+	{1, &oid_rt_pro_set_tx_power_control_hdl},	/* 0x11	OID_RT_PRO_SET_TX_POWER_CONTROL */
+	{1, &oid_null_function},			/* 0x12	OID_RT_PRO_SET_CR_TX_CONFIG */
+	{1, &oid_null_function},			/* 0x13	OID_RT_PRO_GET_TX_POWER_CONTROL */
+	{1, &oid_null_function},			/* 0x14	OID_RT_PRO_GET_CR_SIGNAL_QUALITY */
+	{1, &oid_null_function},			/* 0x15	OID_RT_PRO_SET_CR_SETPOINT */
+	{1, &oid_null_function},			/* 0x16	OID_RT_PRO_SET_INTEGRATOR */
+	{1, &oid_null_function},			/* 0x17	OID_RT_PRO_SET_SIGNAL_QUALITY */
+	{1, &oid_null_function},			/* 0x18	OID_RT_PRO_GET_INTEGRATOR */
+	{1, &oid_null_function},			/* 0x19	OID_RT_PRO_GET_SIGNAL_QUALITY */
+	{1, &oid_null_function},			/* 0x1A	OID_RT_PRO_QUERY_EEPROM_TYPE */
+	{1, &oid_null_function},			/* 0x1B	OID_RT_PRO_WRITE_MAC_ADDRESS */
+	{1, &oid_null_function},			/* 0x1C	OID_RT_PRO_READ_MAC_ADDRESS */
+	{1, &oid_null_function},			/* 0x1D	OID_RT_PRO_WRITE_CIS_DATA */
+	{1, &oid_null_function},			/* 0x1E	OID_RT_PRO_READ_CIS_DATA */
+	{1, &oid_null_function}				/* 0x1F	OID_RT_PRO_WRITE_POWER_CONTROL */
 
 };
 
-const struct oid_obj_priv oid_rtl_seg_81_80_20[] =
-{
-	{1, &oid_null_function},			//0x20	OID_RT_PRO_READ_POWER_CONTROL
-	{1, &oid_null_function},			//0x21	OID_RT_PRO_WRITE_EEPROM
-	{1, &oid_null_function},			//0x22	OID_RT_PRO_READ_EEPROM
-	{1, &oid_rt_pro_reset_tx_packet_sent_hdl},	//0x23
-	{1, &oid_rt_pro_query_tx_packet_sent_hdl},	//0x24
-	{1, &oid_rt_pro_reset_rx_packet_received_hdl},	//0x25
-	{1, &oid_rt_pro_query_rx_packet_received_hdl},	//0x26
-	{1, &oid_rt_pro_query_rx_packet_crc32_error_hdl},	//0x27
-	{1, &oid_null_function},			//0x28	OID_RT_PRO_QUERY_CURRENT_ADDRESS
-	{1, &oid_null_function},			//0x29	OID_RT_PRO_QUERY_PERMANENT_ADDRESS
-	{1, &oid_null_function},			//0x2A	OID_RT_PRO_SET_PHILIPS_RF_PARAMETERS
-	{1, &oid_rt_pro_set_carrier_suppression_tx_hdl},//0x2B	OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX
-	{1, &oid_null_function},			//0x2C	OID_RT_PRO_RECEIVE_PACKET
-	{1, &oid_null_function},			//0x2D	OID_RT_PRO_WRITE_EEPROM_BYTE
-	{1, &oid_null_function},			//0x2E	OID_RT_PRO_READ_EEPROM_BYTE
-	{1, &oid_rt_pro_set_modulation_hdl}		//0x2F
+const struct oid_obj_priv oid_rtl_seg_81_80_20[] = {
+	{1, &oid_null_function},			/* 0x20	OID_RT_PRO_READ_POWER_CONTROL */
+	{1, &oid_null_function},			/* 0x21	OID_RT_PRO_WRITE_EEPROM */
+	{1, &oid_null_function},			/* 0x22	OID_RT_PRO_READ_EEPROM */
+	{1, &oid_rt_pro_reset_tx_packet_sent_hdl},	/* 0x23 */
+	{1, &oid_rt_pro_query_tx_packet_sent_hdl},	/* 0x24 */
+	{1, &oid_rt_pro_reset_rx_packet_received_hdl},	/* 0x25 */
+	{1, &oid_rt_pro_query_rx_packet_received_hdl},	/* 0x26 */
+	{1, &oid_rt_pro_query_rx_packet_crc32_error_hdl},	/* 0x27 */
+	{1, &oid_null_function},			/* 0x28	OID_RT_PRO_QUERY_CURRENT_ADDRESS */
+	{1, &oid_null_function},			/* 0x29	OID_RT_PRO_QUERY_PERMANENT_ADDRESS */
+	{1, &oid_null_function},			/* 0x2A	OID_RT_PRO_SET_PHILIPS_RF_PARAMETERS */
+	{1, &oid_rt_pro_set_carrier_suppression_tx_hdl},/* 0x2B	OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX */
+	{1, &oid_null_function},			/* 0x2C	OID_RT_PRO_RECEIVE_PACKET */
+	{1, &oid_null_function},			/* 0x2D	OID_RT_PRO_WRITE_EEPROM_BYTE */
+	{1, &oid_null_function},			/* 0x2E	OID_RT_PRO_READ_EEPROM_BYTE */
+	{1, &oid_rt_pro_set_modulation_hdl}		/* 0x2F */
 
 };
 
-const struct oid_obj_priv oid_rtl_seg_81_80_40[] =
-{
-	{1, &oid_null_function},			//0x40
-	{1, &oid_null_function},			//0x41
-	{1, &oid_null_function},			//0x42
-	{1, &oid_rt_pro_set_single_tone_tx_hdl},	//0x43
-	{1, &oid_null_function},			//0x44
-	{1, &oid_null_function}				//0x45
+const struct oid_obj_priv oid_rtl_seg_81_80_40[] = {
+	{1, &oid_null_function},			/* 0x40 */
+	{1, &oid_null_function},			/* 0x41 */
+	{1, &oid_null_function},			/* 0x42 */
+	{1, &oid_rt_pro_set_single_tone_tx_hdl},	/* 0x43 */
+	{1, &oid_null_function},			/* 0x44 */
+	{1, &oid_null_function}				/* 0x45 */
 };
 
-const struct oid_obj_priv oid_rtl_seg_81_80_80[] =
-{
-	{1, &oid_null_function},			//0x80	OID_RT_DRIVER_OPTION
-	{1, &oid_null_function},			//0x81	OID_RT_RF_OFF
-	{1, &oid_null_function}				//0x82	OID_RT_AUTH_STATUS
+const struct oid_obj_priv oid_rtl_seg_81_80_80[] = {
+	{1, &oid_null_function},			/* 0x80	OID_RT_DRIVER_OPTION */
+	{1, &oid_null_function},			/* 0x81	OID_RT_RF_OFF */
+	{1, &oid_null_function}				/* 0x82	OID_RT_AUTH_STATUS */
 
 };
 
-const struct oid_obj_priv oid_rtl_seg_81_85[] =
-{
-	{1, &oid_rt_wireless_mode_hdl}			//0x00	OID_RT_WIRELESS_MODE
+const struct oid_obj_priv oid_rtl_seg_81_85[] = {
+	{1, &oid_rt_wireless_mode_hdl}			/* 0x00	OID_RT_WIRELESS_MODE */
 };
 
-struct oid_obj_priv oid_rtl_seg_81_87[] =
-{
-	{1, &oid_null_function},			//0x80	OID_RT_PRO8187_WI_POLL
-	{1, &oid_rt_pro_write_bb_reg_hdl},		//0x81
-	{1, &oid_rt_pro_read_bb_reg_hdl},		//0x82
-	{1, &oid_rt_pro_write_rf_reg_hdl},		//0x82
-	{1, &oid_rt_pro_read_rf_reg_hdl}		//0x83
+struct oid_obj_priv oid_rtl_seg_81_87[] = {
+	{1, &oid_null_function},			/* 0x80	OID_RT_PRO8187_WI_POLL */
+	{1, &oid_rt_pro_write_bb_reg_hdl},		/* 0x81 */
+	{1, &oid_rt_pro_read_bb_reg_hdl},		/* 0x82 */
+	{1, &oid_rt_pro_write_rf_reg_hdl},		/* 0x82 */
+	{1, &oid_rt_pro_read_rf_reg_hdl}		/* 0x83 */
 };
 
-struct oid_obj_priv oid_rtl_seg_87_11_00[] =
-{
-	{1, &oid_rt_pro8711_join_bss_hdl},		//0x00  //S
-	{1, &oid_rt_pro_read_register_hdl},		//0x01
-	{1, &oid_rt_pro_write_register_hdl},		//0x02
-	{1, &oid_rt_pro_burst_read_register_hdl},	//0x03
-	{1, &oid_rt_pro_burst_write_register_hdl},	//0x04
-	{1, &oid_rt_pro_write_txcmd_hdl},		//0x05
-	{1, &oid_rt_pro_read16_eeprom_hdl},		//0x06
-	{1, &oid_rt_pro_write16_eeprom_hdl},		//0x07
-	{1, &oid_null_function},			//0x08	OID_RT_PRO_H2C_SET_COMMAND
-	{1, &oid_null_function},			//0x09	OID_RT_PRO_H2C_QUERY_RESULT
-	{1, &oid_rt_pro8711_wi_poll_hdl},		//0x0A
-	{1, &oid_rt_pro8711_pkt_loss_hdl},		//0x0B
-	{1, &oid_rt_rd_attrib_mem_hdl},			//0x0C
-	{1, &oid_rt_wr_attrib_mem_hdl},			//0x0D
-	{1, &oid_null_function},			//0x0E
-	{1, &oid_null_function},			//0x0F
-	{1, &oid_null_function},			//0x10	OID_RT_PRO_H2C_CMD_MODE
-	{1, &oid_null_function},			//0x11	OID_RT_PRO_H2C_CMD_RSP_MODE
-	{1, &oid_null_function},			//0X12	OID_RT_PRO_WAIT_C2H_EVENT
-	{1, &oid_null_function},			//0X13	OID_RT_PRO_RW_ACCESS_PROTOCOL_TEST
-	{1, &oid_null_function},			//0X14	OID_RT_PRO_SCSI_ACCESS_TEST
-	{1, &oid_null_function},			//0X15	OID_RT_PRO_SCSI_TCPIPOFFLOAD_OUT
-	{1, &oid_null_function},			//0X16	OID_RT_PRO_SCSI_TCPIPOFFLOAD_IN
-	{1, &oid_null_function},			//0X17	OID_RT_RRO_RX_PKT_VIA_IOCTRL
-	{1, &oid_null_function},			//0X18	OID_RT_RRO_RX_PKTARRAY_VIA_IOCTRL
-	{1, &oid_null_function},			//0X19	OID_RT_RPO_SET_PWRMGT_TEST
-	{1, &oid_null_function},			//0X1A
-	{1, &oid_null_function},			//0X1B	OID_RT_PRO_QRY_PWRMGT_TEST
-	{1, &oid_null_function},			//0X1C	OID_RT_RPO_ASYNC_RWIO_TEST
-	{1, &oid_null_function},			//0X1D	OID_RT_RPO_ASYNC_RWIO_POLL
-	{1, &oid_rt_pro_set_rf_intfs_hdl},		//0X1E
-	{1, &oid_rt_poll_rx_status_hdl}			//0X1F
+struct oid_obj_priv oid_rtl_seg_87_11_00[] = {
+	{1, &oid_rt_pro8711_join_bss_hdl},		/* 0x00  */ /* S */
+	{1, &oid_rt_pro_read_register_hdl},		/* 0x01 */
+	{1, &oid_rt_pro_write_register_hdl},		/* 0x02 */
+	{1, &oid_rt_pro_burst_read_register_hdl},	/* 0x03 */
+	{1, &oid_rt_pro_burst_write_register_hdl},	/* 0x04 */
+	{1, &oid_rt_pro_write_txcmd_hdl},		/* 0x05 */
+	{1, &oid_rt_pro_read16_eeprom_hdl},		/* 0x06 */
+	{1, &oid_rt_pro_write16_eeprom_hdl},		/* 0x07 */
+	{1, &oid_null_function},			/* 0x08	OID_RT_PRO_H2C_SET_COMMAND */
+	{1, &oid_null_function},			/* 0x09	OID_RT_PRO_H2C_QUERY_RESULT */
+	{1, &oid_rt_pro8711_wi_poll_hdl},		/* 0x0A */
+	{1, &oid_rt_pro8711_pkt_loss_hdl},		/* 0x0B */
+	{1, &oid_rt_rd_attrib_mem_hdl},			/* 0x0C */
+	{1, &oid_rt_wr_attrib_mem_hdl},			/* 0x0D */
+	{1, &oid_null_function},			/* 0x0E */
+	{1, &oid_null_function},			/* 0x0F */
+	{1, &oid_null_function},			/* 0x10	OID_RT_PRO_H2C_CMD_MODE */
+	{1, &oid_null_function},			/* 0x11	OID_RT_PRO_H2C_CMD_RSP_MODE */
+	{1, &oid_null_function},			/* 0X12	OID_RT_PRO_WAIT_C2H_EVENT */
+	{1, &oid_null_function},			/* 0X13	OID_RT_PRO_RW_ACCESS_PROTOCOL_TEST */
+	{1, &oid_null_function},			/* 0X14	OID_RT_PRO_SCSI_ACCESS_TEST */
+	{1, &oid_null_function},			/* 0X15	OID_RT_PRO_SCSI_TCPIPOFFLOAD_OUT */
+	{1, &oid_null_function},			/* 0X16	OID_RT_PRO_SCSI_TCPIPOFFLOAD_IN */
+	{1, &oid_null_function},			/* 0X17	OID_RT_RRO_RX_PKT_VIA_IOCTRL */
+	{1, &oid_null_function},			/* 0X18	OID_RT_RRO_RX_PKTARRAY_VIA_IOCTRL */
+	{1, &oid_null_function},			/* 0X19	OID_RT_RPO_SET_PWRMGT_TEST */
+	{1, &oid_null_function},			/* 0X1A */
+	{1, &oid_null_function},			/* 0X1B	OID_RT_PRO_QRY_PWRMGT_TEST */
+	{1, &oid_null_function},			/* 0X1C	OID_RT_RPO_ASYNC_RWIO_TEST */
+	{1, &oid_null_function},			/* 0X1D	OID_RT_RPO_ASYNC_RWIO_POLL */
+	{1, &oid_rt_pro_set_rf_intfs_hdl},		/* 0X1E */
+	{1, &oid_rt_poll_rx_status_hdl}			/* 0X1F */
 };
 
-struct oid_obj_priv oid_rtl_seg_87_11_20[] =
-{
-	{1, &oid_rt_pro_cfg_debug_message_hdl},		//0x20
-	{1, &oid_rt_pro_set_data_rate_ex_hdl},		//0x21
-	{1, &oid_rt_pro_set_basic_rate_hdl},		//0x22
-	{1, &oid_rt_pro_read_tssi_hdl},			//0x23
-	{1, &oid_rt_pro_set_power_tracking_hdl}		//0x24
+struct oid_obj_priv oid_rtl_seg_87_11_20[] = {
+	{1, &oid_rt_pro_cfg_debug_message_hdl},		/* 0x20 */
+	{1, &oid_rt_pro_set_data_rate_ex_hdl},		/* 0x21 */
+	{1, &oid_rt_pro_set_basic_rate_hdl},		/* 0x22 */
+	{1, &oid_rt_pro_read_tssi_hdl},			/* 0x23 */
+	{1, &oid_rt_pro_set_power_tracking_hdl}		/* 0x24 */
 };
 
 
-struct oid_obj_priv oid_rtl_seg_87_11_50[] =
-{
-	{1, &oid_rt_pro_qry_pwrstate_hdl},		//0x50
-	{1, &oid_rt_pro_set_pwrstate_hdl}		//0x51
+struct oid_obj_priv oid_rtl_seg_87_11_50[] = {
+	{1, &oid_rt_pro_qry_pwrstate_hdl},		/* 0x50 */
+	{1, &oid_rt_pro_set_pwrstate_hdl}		/* 0x51 */
 };
 
-struct oid_obj_priv oid_rtl_seg_87_11_80[] =
-{
-	{1, &oid_null_function}				//0x80
+struct oid_obj_priv oid_rtl_seg_87_11_80[] = {
+	{1, &oid_null_function}				/* 0x80 */
 };
 
-struct oid_obj_priv oid_rtl_seg_87_11_B0[] =
-{
-	{1, &oid_null_function}				//0xB0
+struct oid_obj_priv oid_rtl_seg_87_11_B0[] = {
+	{1, &oid_null_function}				/* 0xB0 */
 };
 
-struct oid_obj_priv oid_rtl_seg_87_11_F0[] =
-{
-	{1, &oid_null_function},			//0xF0
-	{1, &oid_null_function},			//0xF1
-	{1, &oid_null_function},			//0xF2
-	{1, &oid_null_function},			//0xF3
-	{1, &oid_null_function},			//0xF4
-	{1, &oid_null_function},			//0xF5
-	{1, &oid_null_function},			//0xF6
-	{1, &oid_null_function},			//0xF7
-	{1, &oid_null_function},			//0xF8
-	{1, &oid_null_function},			//0xF9
-	{1, &oid_null_function},			//0xFA
-	{1, &oid_rt_pro_h2c_set_rate_table_hdl},	//0xFB
-	{1, &oid_rt_pro_h2c_get_rate_table_hdl},	//0xFC
-	{1, &oid_null_function},			//0xFD
-	{1, &oid_null_function},			//0xFE	OID_RT_PRO_H2C_C2H_LBK_TEST
-	{1, &oid_null_function}				//0xFF
+struct oid_obj_priv oid_rtl_seg_87_11_F0[] = {
+	{1, &oid_null_function},			/* 0xF0 */
+	{1, &oid_null_function},			/* 0xF1 */
+	{1, &oid_null_function},			/* 0xF2 */
+	{1, &oid_null_function},			/* 0xF3 */
+	{1, &oid_null_function},			/* 0xF4 */
+	{1, &oid_null_function},			/* 0xF5 */
+	{1, &oid_null_function},			/* 0xF6 */
+	{1, &oid_null_function},			/* 0xF7 */
+	{1, &oid_null_function},			/* 0xF8 */
+	{1, &oid_null_function},			/* 0xF9 */
+	{1, &oid_null_function},			/* 0xFA */
+	{1, &oid_rt_pro_h2c_set_rate_table_hdl},	/* 0xFB */
+	{1, &oid_rt_pro_h2c_get_rate_table_hdl},	/* 0xFC */
+	{1, &oid_null_function},			/* 0xFD */
+	{1, &oid_null_function},			/* 0xFE	OID_RT_PRO_H2C_C2H_LBK_TEST */
+	{1, &oid_null_function}				/* 0xFF */
 
 };
 
-struct oid_obj_priv oid_rtl_seg_87_12_00[]=
-{
-	{1, &oid_rt_pro_encryption_ctrl_hdl},		//0x00	Q&S
-	{1, &oid_rt_pro_add_sta_info_hdl},		//0x01	S
-	{1, &oid_rt_pro_dele_sta_info_hdl},		//0x02	S
-	{1, &oid_rt_pro_query_dr_variable_hdl},		//0x03	Q
-	{1, &oid_rt_pro_rx_packet_type_hdl},		//0x04	Q,S
-	{1, &oid_rt_pro_read_efuse_hdl},		//0x05	Q	OID_RT_PRO_READ_EFUSE
-	{1, &oid_rt_pro_write_efuse_hdl},		//0x06	S	OID_RT_PRO_WRITE_EFUSE
-	{1, &oid_rt_pro_rw_efuse_pgpkt_hdl},		//0x07	Q,S
-	{1, &oid_rt_get_efuse_current_size_hdl},	//0x08 	Q
-	{1, &oid_rt_set_bandwidth_hdl},			//0x09
-	{1, &oid_rt_set_crystal_cap_hdl},		//0x0a
-	{1, &oid_rt_set_rx_packet_type_hdl},		//0x0b	S
-	{1, &oid_rt_get_efuse_max_size_hdl},		//0x0c
-	{1, &oid_rt_pro_set_tx_agc_offset_hdl},		//0x0d
-	{1, &oid_rt_pro_set_pkt_test_mode_hdl},		//0x0e
-	{1, &oid_null_function},			//0x0f		OID_RT_PRO_FOR_EVM_TEST_SETTING
-	{1, &oid_rt_get_thermal_meter_hdl},		//0x10	Q	OID_RT_PRO_GET_THERMAL_METER
-	{1, &oid_rt_reset_phy_rx_packet_count_hdl},	//0x11	S	OID_RT_RESET_PHY_RX_PACKET_COUNT
-	{1, &oid_rt_get_phy_rx_packet_received_hdl},	//0x12	Q	OID_RT_GET_PHY_RX_PACKET_RECEIVED
-	{1, &oid_rt_get_phy_rx_packet_crc32_error_hdl},	//0x13	Q	OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR
-	{1, &oid_rt_set_power_down_hdl},		//0x14	Q	OID_RT_SET_POWER_DOWN
-	{1, &oid_rt_get_power_mode_hdl}			//0x15	Q	OID_RT_GET_POWER_MODE
+struct oid_obj_priv oid_rtl_seg_87_12_00[] = {
+	{1, &oid_rt_pro_encryption_ctrl_hdl},		/* 0x00	Q&S */
+	{1, &oid_rt_pro_add_sta_info_hdl},		/* 0x01	S */
+	{1, &oid_rt_pro_dele_sta_info_hdl},		/* 0x02	S */
+	{1, &oid_rt_pro_query_dr_variable_hdl},		/* 0x03	Q */
+	{1, &oid_rt_pro_rx_packet_type_hdl},		/* 0x04	Q,S */
+	{1, &oid_rt_pro_read_efuse_hdl},		/* 0x05	Q	OID_RT_PRO_READ_EFUSE */
+	{1, &oid_rt_pro_write_efuse_hdl},		/* 0x06	S	OID_RT_PRO_WRITE_EFUSE */
+	{1, &oid_rt_pro_rw_efuse_pgpkt_hdl},		/* 0x07	Q,S */
+	{1, &oid_rt_get_efuse_current_size_hdl},	/* 0x08 	Q */
+	{1, &oid_rt_set_bandwidth_hdl},			/* 0x09 */
+	{1, &oid_rt_set_crystal_cap_hdl},		/* 0x0a */
+	{1, &oid_rt_set_rx_packet_type_hdl},		/* 0x0b	S */
+	{1, &oid_rt_get_efuse_max_size_hdl},		/* 0x0c */
+	{1, &oid_rt_pro_set_tx_agc_offset_hdl},		/* 0x0d */
+	{1, &oid_rt_pro_set_pkt_test_mode_hdl},		/* 0x0e */
+	{1, &oid_null_function},			/* 0x0f		OID_RT_PRO_FOR_EVM_TEST_SETTING */
+	{1, &oid_rt_get_thermal_meter_hdl},		/* 0x10	Q	OID_RT_PRO_GET_THERMAL_METER */
+	{1, &oid_rt_reset_phy_rx_packet_count_hdl},	/* 0x11	S	OID_RT_RESET_PHY_RX_PACKET_COUNT */
+	{1, &oid_rt_get_phy_rx_packet_received_hdl},	/* 0x12	Q	OID_RT_GET_PHY_RX_PACKET_RECEIVED */
+	{1, &oid_rt_get_phy_rx_packet_crc32_error_hdl},	/* 0x13	Q	OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR */
+	{1, &oid_rt_set_power_down_hdl},		/* 0x14	Q	OID_RT_SET_POWER_DOWN */
+	{1, &oid_rt_get_power_mode_hdl}			/* 0x15	Q	OID_RT_GET_POWER_MODE */
 };
 
 #else /* _RTL871X_MP_IOCTL_C_ */
@@ -418,13 +399,13 @@ extern struct oid_obj_priv oid_rtl_seg_87_12_00[32];
 
 #endif /* _RTL871X_MP_IOCTL_C_ */
 
-struct rwreg_param{
+struct rwreg_param {
 	u32 offset;
 	u32 width;
 	u32 value;
 };
 
-struct bbreg_param{
+struct bbreg_param {
 	u32 offset;
 	u32 phymask;
 	u32 value;
@@ -435,12 +416,12 @@ struct rfchannel_param{
 	u32 modem;
 };
 */
-struct txpower_param{
+struct txpower_param {
 	u32 pwr_index;
 };
 
 
-struct datarate_param{
+struct datarate_param {
 	u32 rate_index;
 };
 
@@ -455,7 +436,7 @@ typedef struct _mp_xmit_parm_ {
 	u16 length;
 	u8 payload_type;
 	u8 da[ETH_ALEN];
-}MP_XMIT_PARM, *PMP_XMIT_PARM;
+} MP_XMIT_PARM, *PMP_XMIT_PARM;
 
 struct mp_xmit_packet {
 	u32 len;
@@ -467,7 +448,7 @@ struct psmode_param {
 	u32 smart_ps;
 };
 
-//for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM
+/* for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM */
 struct eeprom_rw_param {
 	u32 offset;
 	u16 value;
@@ -475,11 +456,11 @@ struct eeprom_rw_param {
 
 struct mp_ioctl_handler {
 	u32 paramsize;
-	u32 (*handler)(struct oid_par_priv* poid_par_priv);
+	u32(*handler)(struct oid_par_priv *poid_par_priv);
 	u32 oid;
 };
 
-struct mp_ioctl_param{
+struct mp_ioctl_param {
 	u32 subcode;
 	u32 len;
 	u8 data[0];
@@ -522,11 +503,11 @@ enum RTL871X_MP_IOCTL_SUBCODE {
 	GEN_MP_IOCTL_SUBCODE(TRIGGER_GPIO),
 	GEN_MP_IOCTL_SUBCODE(SET_DM_BT),		/*32*/
 	GEN_MP_IOCTL_SUBCODE(DEL_BA),			/*33*/
-	GEN_MP_IOCTL_SUBCODE(GET_WIFI_STATUS),	/*34*/	
+	GEN_MP_IOCTL_SUBCODE(GET_WIFI_STATUS),	/*34*/
 	MAX_MP_IOCTL_SUBCODE,
 };
 
-u32 mp_ioctl_xmit_packet_hdl(struct oid_par_priv* poid_par_priv);
+u32 mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv);
 
 #ifdef _RTW_MP_IOCTL_C_
 
@@ -537,45 +518,45 @@ u32 mp_ioctl_xmit_packet_hdl(struct oid_par_priv* poid_par_priv);
 
 struct mp_ioctl_handler mp_ioctl_hdl[] = {
 
-/*0*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_start_test_hdl, OID_RT_PRO_START_TEST)
+	/*0*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_start_test_hdl, OID_RT_PRO_START_TEST)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_stop_test_hdl, OID_RT_PRO_STOP_TEST)
 
 	GEN_MP_IOCTL_HANDLER(sizeof(struct rwreg_param), oid_rt_pro_read_register_hdl, OID_RT_PRO_READ_REGISTER)
 	GEN_MP_IOCTL_HANDLER(sizeof(struct rwreg_param), oid_rt_pro_write_register_hdl, OID_RT_PRO_WRITE_REGISTER)
 	GEN_MP_IOCTL_HANDLER(sizeof(struct bb_reg_param), oid_rt_pro_read_bb_reg_hdl, OID_RT_PRO_READ_BB_REG)
-/*5*/	GEN_MP_IOCTL_HANDLER(sizeof(struct bb_reg_param), oid_rt_pro_write_bb_reg_hdl, OID_RT_PRO_WRITE_BB_REG)
+	/*5*/	GEN_MP_IOCTL_HANDLER(sizeof(struct bb_reg_param), oid_rt_pro_write_bb_reg_hdl, OID_RT_PRO_WRITE_BB_REG)
 	GEN_MP_IOCTL_HANDLER(sizeof(struct rf_reg_param), oid_rt_pro_read_rf_reg_hdl, OID_RT_PRO_RF_READ_REGISTRY)
 	GEN_MP_IOCTL_HANDLER(sizeof(struct rf_reg_param), oid_rt_pro_write_rf_reg_hdl, OID_RT_PRO_RF_WRITE_REGISTRY)
 
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_channel_direct_call_hdl, OID_RT_PRO_SET_CHANNEL_DIRECT_CALL)
 	GEN_MP_IOCTL_HANDLER(sizeof(struct txpower_param), oid_rt_pro_set_tx_power_control_hdl, OID_RT_PRO_SET_TX_POWER_CONTROL)
-/*10*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_data_rate_hdl, OID_RT_PRO_SET_DATA_RATE)
+	/*10*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_data_rate_hdl, OID_RT_PRO_SET_DATA_RATE)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_set_bandwidth_hdl, OID_RT_SET_BANDWIDTH)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_antenna_bb_hdl, OID_RT_PRO_SET_ANTENNA_BB)
 
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_continuous_tx_hdl, OID_RT_PRO_SET_CONTINUOUS_TX)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_single_carrier_tx_hdl, OID_RT_PRO_SET_SINGLE_CARRIER_TX)
-/*15*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_carrier_suppression_tx_hdl, OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX)
+	/*15*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_carrier_suppression_tx_hdl, OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_pro_set_single_tone_tx_hdl, OID_RT_PRO_SET_SINGLE_TONE_TX)
 
 	EXT_MP_IOCTL_HANDLER(0, xmit_packet, 0)
 
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_set_rx_packet_type_hdl, OID_RT_SET_RX_PACKET_TYPE)
 	GEN_MP_IOCTL_HANDLER(0, oid_rt_reset_phy_rx_packet_count_hdl, OID_RT_RESET_PHY_RX_PACKET_COUNT)
-/*20*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_phy_rx_packet_received_hdl, OID_RT_GET_PHY_RX_PACKET_RECEIVED)
+	/*20*/	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_phy_rx_packet_received_hdl, OID_RT_GET_PHY_RX_PACKET_RECEIVED)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_phy_rx_packet_crc32_error_hdl, OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR)
 
 	GEN_MP_IOCTL_HANDLER(sizeof(struct eeprom_rw_param), NULL, 0)
 	GEN_MP_IOCTL_HANDLER(sizeof(struct eeprom_rw_param), NULL, 0)
 	GEN_MP_IOCTL_HANDLER(sizeof(EFUSE_ACCESS_STRUCT), oid_rt_pro_efuse_hdl, OID_RT_PRO_EFUSE)
-/*25*/	GEN_MP_IOCTL_HANDLER(0, oid_rt_pro_efuse_map_hdl, OID_RT_PRO_EFUSE_MAP)
+	/*25*/	GEN_MP_IOCTL_HANDLER(0, oid_rt_pro_efuse_map_hdl, OID_RT_PRO_EFUSE_MAP)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_efuse_max_size_hdl, OID_RT_GET_EFUSE_MAX_SIZE)
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_efuse_current_size_hdl, OID_RT_GET_EFUSE_CURRENT_SIZE)
 
 	GEN_MP_IOCTL_HANDLER(sizeof(u32), oid_rt_get_thermal_meter_hdl, OID_RT_PRO_GET_THERMAL_METER)
 	GEN_MP_IOCTL_HANDLER(sizeof(u8), oid_rt_pro_set_power_tracking_hdl, OID_RT_PRO_SET_POWER_TRACKING)
-/*30*/	GEN_MP_IOCTL_HANDLER(sizeof(u8), oid_rt_set_power_down_hdl, OID_RT_SET_POWER_DOWN)
-/*31*/	GEN_MP_IOCTL_HANDLER(0, oid_rt_pro_trigger_gpio_hdl, 0)
+	/*30*/	GEN_MP_IOCTL_HANDLER(sizeof(u8), oid_rt_set_power_down_hdl, OID_RT_SET_POWER_DOWN)
+	/*31*/	GEN_MP_IOCTL_HANDLER(0, oid_rt_pro_trigger_gpio_hdl, 0)
 	GEN_MP_IOCTL_HANDLER(0, NULL, 0)
 	GEN_MP_IOCTL_HANDLER(0, NULL, 0)
 	GEN_MP_IOCTL_HANDLER(0, NULL, 0)
@@ -588,4 +569,3 @@ extern struct mp_ioctl_handler mp_ioctl_hdl[];
 #endif /* _RTW_MP_IOCTL_C_ */
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_phy_regdef.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_phy_regdef.h
index 340015cd3b2b..330ecbfdd957 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_phy_regdef.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_mp_phy_regdef.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 /*****************************************************************************
  *
  * Module:	__RTW_MP_PHY_REGDEF_H_
@@ -27,18 +23,18 @@
  *			3. PMAC/BB register bit mask.
  *			4. RF reg bit mask.
  *			5. Other BB/RF relative definition.
- *			
+ *
  *
  * Export:	Constants, macro, functions(API), global variables(None).
  *
- * Abbrev:	
+ * Abbrev:
  *
  * History:
- *	Data			Who		Remark 
+ *	Data			Who		Remark
  *	08/07/2007	MHC		1. Porting from 9x series PHYCFG.h.
  *						2. Reorganize code architecture.
  *	09/25/2008	MH		1. Add RL6052 register definition
- * 
+ *
  *****************************************************************************/
 #ifndef __RTW_MP_PHY_REGDEF_H_
 #define __RTW_MP_PHY_REGDEF_H_
@@ -46,24 +42,24 @@
 
 /*--------------------------Define Parameters-------------------------------*/
 
-//============================================================
-//       8192S Regsiter offset definition
-//============================================================
+/* ************************************************************
+ * 8192S Regsiter offset definition
+ * ************************************************************ */
 
-//
-// BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
-// 3. RF register 0x00-2E
-// 4. Bit Mask for BB/RF register
-// 5. Other defintion for BB/RF R/W
-//
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other defintion for BB/RF R/W
+ *   */
 
 
-//
-// 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
-// 1. Page1(0x100)
-//
+/*
+ * 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
@@ -92,29 +88,29 @@
 #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.
+/*
+ * 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??
+/*
+ * 3. Page8(0x800)
+ *   */
+#define		rFPGA0_RFMOD				0x800	/* RF mode & CCK TxSC */ /* RF BW Setting?? */
 
-#define		rFPGA0_TxInfo				0x804	// Status report??
+#define		rFPGA0_TxInfo				0x804	/* Status report?? */
 #define		rFPGA0_PSDFunction			0x808
 
-#define		rFPGA0_TxGainStage			0x80c	// Set TX PWR init gain?
+#define		rFPGA0_TxGainStage			0x80c	/* Set TX PWR init gain? */
 
-#define		rFPGA0_RFTiming1			0x810	// Useless now
+#define		rFPGA0_RFTiming1			0x810	/* Useless now */
 #define		rFPGA0_RFTiming2			0x814
-//#define rFPGA0_XC_RFTiming        		0x818
-//#define rFPGA0_XD_RFTiming        		0x81c
+/* #define rFPGA0_XC_RFTiming		0x818 */
+/* #define rFPGA0_XD_RFTiming		0x81c */
 
-#define		rFPGA0_XA_HSSIParameter1		0x820	// RF 3 wire register
+#define		rFPGA0_XA_HSSIParameter1		0x820	/* RF 3 wire register */
 #define		rFPGA0_XA_HSSIParameter2		0x824
 #define		rFPGA0_XB_HSSIParameter1		0x828
 #define		rFPGA0_XB_HSSIParameter2		0x82c
@@ -127,102 +123,102 @@
 #define		rFPGA0_XC_LSSIParameter		0x848
 #define		rFPGA0_XD_LSSIParameter		0x84c
 
-#define		rFPGA0_RFWakeUpParameter		0x850	// Useless now
+#define		rFPGA0_RFWakeUpParameter		0x850	/* Useless now */
 #define		rFPGA0_RFSleepUpParameter		0x854
 
-#define		rFPGA0_XAB_SwitchControl		0x858	// RF Channel switch
+#define		rFPGA0_XAB_SwitchControl		0x858	/* RF Channel switch */
 #define		rFPGA0_XCD_SwitchControl		0x85c
 
-#define		rFPGA0_XA_RFInterfaceOE		0x860	// RF Channel switch
+#define		rFPGA0_XA_RFInterfaceOE		0x860	/* RF Channel switch */
 #define		rFPGA0_XB_RFInterfaceOE		0x864
 #define		rFPGA0_XC_RFInterfaceOE		0x868
 #define		rFPGA0_XD_RFInterfaceOE		0x86c
 
-#define		rFPGA0_XAB_RFInterfaceSW		0x870	// RF Interface Software Control
+#define		rFPGA0_XAB_RFInterfaceSW		0x870	/* RF Interface Software Control */
 #define		rFPGA0_XCD_RFInterfaceSW		0x874
 
-#define		rFPGA0_XAB_RFParameter		0x878	// RF Parameter
+#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_AnalogParameter1		0x880	/* Crystal cap setting RF-R/W protection for parameter4?? */
 #define		rFPGA0_AnalogParameter2		0x884
-#define		rFPGA0_AnalogParameter3		0x888	// Useless now
+#define		rFPGA0_AnalogParameter3		0x888	/* Useless now */
 #define		rFPGA0_AnalogParameter4		0x88c
 
-#define		rFPGA0_XA_LSSIReadBack		0x8a0	// Tranceiver LSSI Readback
+#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		rFPGA0_XAB_RFInterfaceRB		0x8e0	// Useless now // RF Interface Readback Value
-#define		rFPGA0_XCD_RFInterfaceRB		0x8e4	// Useless now
+#define		rFPGA0_PSDReport				0x8b4	/* Useless now */
+#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??
+/*
+ * 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??
-#define 	rS0S1_PathSwitch			0x948
+#define		rFPGA1_TxBlock				0x904	/* Useless now */
+#define		rFPGA1_DebugSelect			0x908	/* Useless now */
+#define		rFPGA1_TxInfo				0x90c	/* Useless now */ /* Status report?? */
+#define	rS0S1_PathSwitch			0x948
 
-//
-// 5. PageA(0xA00)
-//
-// Set Control channel to upper or lower. These settings are required only for 40MHz
+/*
+ * 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_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_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_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
-
-//
-// 6. PageC(0xC00)
-//
+#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 */
+
+/*
+ * 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_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
@@ -236,12 +232,12 @@
 #define		rOFDM0_AGCRSSITable			0xc78
 #define		rOFDM0_HTSTFAGC				0xc7c
 
-#define		rOFDM0_XATxIQImbalance		0xc80	// TX PWR TRACK and DIG
+#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_XCTxAFE			0xc94
 #define		rOFDM0_XDTxIQImbalance		0xc98
 #define		rOFDM0_XDTxAFE				0xc9c
 #define		rOFDM0_RxIQExtAnta			0xca0
@@ -258,13 +254,13 @@
 #define		rOFDM0_TxCoeff6				0xcb8
 
 
-//
-// 7. PageD(0xD00)
-//
+/*
+ * 7. PageD(0xD00)
+ *   */
 #define		rOFDM1_LSTF					0xd00
 #define		rOFDM1_TRxPathEnable			0xd04
 
-#define		rOFDM1_CFO						0xd08	// No setting now
+#define		rOFDM1_CFO						0xd08	/* No setting now */
 #define		rOFDM1_CSI1					0xd10
 #define		rOFDM1_SBD						0xd14
 #define		rOFDM1_CSI2					0xd18
@@ -275,18 +271,18 @@
 #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_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_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_PWMeasure1		0xdc4
+#define		rOFDM_PWMeasure2		0xdc8
 #define		rOFDM_BWReport				0xdcc
 #define		rOFDM_AGCReport				0xdd0
 #define		rOFDM_RxSNR					0xdd4
@@ -294,9 +290,9 @@
 #define		rOFDM_SIGReport				0xddc
 
 
-//
-// 8. PageE(0xE00)
-//
+/*
+ * 8. PageE(0xE00)
+ *   */
 #define		rTxAGC_Rate18_06				0xe00
 #define		rTxAGC_Rate54_24				0xe04
 #define		rTxAGC_CCK_Mcs32				0xe08
@@ -305,107 +301,107 @@
 #define		rTxAGC_Mcs11_Mcs08			0xe18
 #define		rTxAGC_Mcs15_Mcs12			0xe1c
 
-// Analog- control in RX_WAIT_CCA : REG: EE0 [Analog- Power & Control Register]
-#define 		rRx_Wait_CCCA					0xe70
+/* Analog- control in RX_WAIT_CCA : REG: EE0 [Analog- Power & Control Register] */
+#define		rRx_Wait_CCCA					0xe70
 #define		rAnapar_Ctrl_BB					0xee0
 
-//
-// 7. RF Register 0x00-0x2E (RF 8256)
-//    RF-0222D 0x00-3F
-//
-//Zebra1
+/*
+ * 7. RF Register 0x00-0x2E (RF 8256)
+ * RF-0222D 0x00-3F
+ *
+ * Zebra1 */
 #define RTL92SE_FPGA_VERIFY 0
-#define		rZebra1_HSSIEnable				0x0	// Useless now
+#define		rZebra1_HSSIEnable				0x0	/* Useless now */
 #define		rZebra1_TRxEnable1				0x1
 #define		rZebra1_TRxEnable2				0x2
 #define		rZebra1_AGC					0x4
 #define		rZebra1_ChargePump			0x5
-//#if (RTL92SE_FPGA_VERIFY == 1)
-#define		rZebra1_Channel				0x7	// RF channel switch
-//#else
+/* #if (RTL92SE_FPGA_VERIFY == 1) */
+#define		rZebra1_Channel				0x7	/* RF channel switch
+ * #else */
 
-//#endif
-#define		rZebra1_TxGain					0x8	// Useless now
+/* #endif */
+#define		rZebra1_TxGain					0x8	/* Useless now */
 #define		rZebra1_TxLPF					0x9
 #define		rZebra1_RxLPF					0xb
 #define		rZebra1_RxHPFCorner			0xc
 
-//Zebra4
-#define		rGlobalCtrl						0	// Useless now
+/* Zebra4 */
+#define		rGlobalCtrl						0	/* Useless now */
 #define		rRTL8256_TxLPF					19
 #define		rRTL8256_RxLPF					11
 
-//RTL8258
-#define		rRTL8258_TxLPF					0x11	// Useless now
+/* RTL8258 */
+#define		rRTL8258_TxLPF					0x11	/* Useless now */
 #define		rRTL8258_RxLPF					0x13
 #define		rRTL8258_RSSILPF				0xa
 
-//
-// RL6052 Register definition
-//
-#define		RF_AC						0x00	// 
+/*
+ * RL6052 Register definition
+ *   */
+#define		RF_AC						0x00	/*  */
 
-#define		RF_IQADJ_G1				0x01	// 
-#define		RF_IQADJ_G2				0x02	// 
-#define		RF_POW_TRSW				0x05	// 
+#define		RF_IQADJ_G1				0x01	/*  */
+#define		RF_IQADJ_G2				0x02	/*  */
+#define		RF_POW_TRSW				0x05	/*  */
 
-#define		RF_GAIN_RX					0x06	// 
-#define		RF_GAIN_TX					0x07	// 
+#define		RF_GAIN_RX					0x06	/*  */
+#define		RF_GAIN_TX					0x07	/*  */
 
-#define		RF_TXM_IDAC				0x08	// 
-#define		RF_BS_IQGEN				0x0F	// 
+#define		RF_TXM_IDAC				0x08	/*  */
+#define		RF_BS_IQGEN				0x0F	/*  */
 
-#define		RF_MODE1					0x10	// 
-#define		RF_MODE2					0x11	// 
+#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_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_G1					0x1A	/*  */
+#define		RF_RX_G2					0x1B	/*  */
 
-#define		RF_RX_BB2					0x1C	// 
-#define		RF_RX_BB1					0x1D	// 
+#define		RF_RX_BB2					0x1C	/*  */
+#define		RF_RX_BB1					0x1D	/*  */
 
-#define		RF_RCK1					0x1E	// 
-#define		RF_RCK2					0x1F	// 
+#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_G1					0x20	/*  */
+#define		RF_TX_G2					0x21	/*  */
+#define		RF_TX_G3					0x22	/*  */
 
-#define		RF_TX_BB1					0x23	// 
+#define		RF_TX_BB1					0x23	/*  */
 
-#define		RF_T_METER					0x24	// 
+#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_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_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
+#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?
+/*
+ * Bit Mask
+ *
+ * 1. Page1(0x100) */
+#define		bBBResetB						0x100	/* Useless now? */
 #define		bGlobalResetB					0x200
 #define		bOFDMTxStart					0x4
 #define		bCCKTxStart						0x8
@@ -450,326 +446,326 @@
 #define		bCCKTxStatus					0x1
 #define		bOFDMTxStatus					0x2
 
-#define 		IS_BB_REG_OFFSET_92S(_Offset)		((_Offset >= 0x800) && (_Offset <= 0xfff))
+#define		IS_BB_REG_OFFSET_92S(_Offset)		((_Offset >= 0x800) && (_Offset <= 0xfff))
 
-// 2. Page8(0x800)
-#define		bRFMOD							0x1	// Reg 0x800 rFPGA0_RFMOD
+/* 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		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		bOFDMRxADCPhase           		0x10000	/* Useless now */
+#define		bOFDMTxDACPhase		0x40000
+#define		bXATxAGC			0x3f
+
+#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
 #if (RTL92SE_FPGA_VERIFY == 1)
-#define		bLSSIReadAddress          		0x3f000000   //LSSI "Read" Address	// Reg 0x824 rFPGA0_XA_HSSIParameter2
+	#define		bLSSIReadAddress          		0x3f000000   /* LSSI "Read" Address	 */ /* Reg 0x824 rFPGA0_XA_HSSIParameter2 */
 #else
-#define		bLSSIReadAddress          		0x7f800000   // T65 RF
+	#define		bLSSIReadAddress          		0x7f800000   /* T65 RF */
 #endif
-#define		bLSSIReadEdge             		0x80000000   //LSSI "Read" edge signal
+#define		bLSSIReadEdge             		0x80000000   /* LSSI "Read" edge signal */
 #if (RTL92SE_FPGA_VERIFY == 1)
-#define		bLSSIReadBackData         		0xfff		// Reg 0x8a0 rFPGA0_XA_LSSIReadBack
+	#define		bLSSIReadBackData         		0xfff		/* Reg 0x8a0 rFPGA0_XA_LSSIReadBack */
 #else
-#define		bLSSIReadBackData         		0xfffff		// T65 RF
+	#define		bLSSIReadBackData         		0xfffff		/* T65 RF */
 #endif
-#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		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		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
@@ -796,8 +792,8 @@
 #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		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
@@ -831,7 +827,7 @@
 #define		bRxPD_Delay_TH1          0x38
 #define		bRxPD_Delay_TH2          0x1c0
 #define		bRxPD_DC_COUNT_MAX       0x600
-//#define bRxMF_Hold               0x3800
+/* #define bRxMF_Hold               0x3800 */
 #define		bRxPD_Delay_TH           0x8000
 #define		bRxProcess_Delay         0xf0000
 #define		bRxSearchrange_GI2_Early 0x700000
@@ -841,19 +837,19 @@
 #define		bRxSGI_TH                0xc0000000
 #define		bDFSCnt0                 0xff
 #define		bDFSCnt1                 0xff00
-#define		bDFSFlag                 0xf0000       		
+#define		bDFSFlag                 0xf0000
 #define		bMFWeightSum             0x300000
-#define		bMinIdxTH                0x7f000000       		
-#define		bDAFormat                0x40000       		
-#define		bTxChEmuEnable           0x01000000       		
+#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          
+#define		bTRSWIsolation_D         0x7f000000
+#define		bExtLNAGain              0x7c00
 
-// 6. PageE(0xE00)
-#define		bSTBCEn                  0x4	// Useless
+/* 6. PageE(0xE00) */
+#define		bSTBCEn                  0x4	/* Useless */
 #define		bAntennaMapping          0x10
 #define		bNss                     0x20
 #define		bCFOAntSumD              0x200
@@ -862,12 +858,12 @@
 #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 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
@@ -880,14 +876,14 @@
 #define		bCounter_MCSNoSupport    0xffff
 #define		bCounter_FastSync        0xffff
 #define		bShortCFO                0xfff
-#define		bShortCFOTLength         12   //total
-#define		bShortCFOFLength         11   //fraction
+#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		bTailCFOFLength          12
 #define		bmax_en_pwdB             0xffff
 #define		bCC_power_dB             0xffff0000
 #define		bnoise_pwdB              0xffff
@@ -895,28 +891,28 @@
 #define		bPowerMeasFLength        3
 #define		bRx_HT_BW                0x1
 #define		bRxSC                    0x6
-#define		bRx_HT                   0x8       		
+#define		bRx_HT                   0x8
 #define		bNB_intf_det_on          0x1
 #define		bIntf_win_len_cfg        0x30
-#define		bNB_Intf_TH_cfg          0x1c0       		
+#define		bNB_Intf_TH_cfg          0x1c0
 #define		bRFGain                  0x3f
 #define		bTableSel                0x40
-#define		bTRSW                    0x80       		
+#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		bSNREVMFLength           1
 #define		bCSI1st                  0xff
 #define		bCSI2nd                  0xff00
 #define		bRxEVM1st                0xff0000
-#define		bRxEVM2nd                0xff000000       		
+#define		bRxEVM2nd                0xff000000
 #define		bSIGEVM                  0xff
 #define		bPWDB                    0xff00
 #define		bSGIEN                   0x10000
-       		
-#define		bSFactorQAM1             0xf	// Useless
+
+#define		bSFactorQAM1             0xf	/* Useless */
 #define		bSFactorQAM2             0xf0
 #define		bSFactorQAM3             0xf00
 #define		bSFactorQAM4             0xf000
@@ -926,8 +922,8 @@
 #define		bSFactorQAM8             0xf000000
 #define		bSFactorQAM9             0xf0000000
 #define		bCSIScheme               0x100000
-       		
-#define		bNoiseLvlTopSet          0x3	// Useless
+
+#define		bNoiseLvlTopSet          0x3	/* Useless */
 #define		bChSmooth                0x4
 #define		bChSmoothCfg1            0x38
 #define		bChSmoothCfg2            0x1c0
@@ -935,8 +931,8 @@
 #define		bChSmoothCfg4            0x7000
 #define		bMRCMode                 0x800000
 #define		bTHEVMCfg                0x7000000
-       		
-#define		bLoopFitType             0x1	// Useless
+
+#define		bLoopFitType             0x1	/* Useless */
 #define		bUpdCFO                  0x40
 #define		bUpdCFOOffData           0x80
 #define		bAdvUpdCFO               0x100
@@ -952,7 +948,7 @@
 #define		bUChCfg                  0x7000000
 #define		bUpdEqz                  0x8000000
 
-#define		bTxAGCRate18_06			0x7f7f7f7f	// Useless
+#define		bTxAGCRate18_06			0x7f7f7f7f	/* Useless */
 #define		bTxAGCRate54_24			0x7f7f7f7f
 #define		bTxAGCRateMCS32			0x7f
 #define		bTxAGCRateCCK			0x7f00
@@ -961,8 +957,8 @@
 #define		bTxAGCRateMCS11_MCS8	0x7f7f7f7f
 #define		bTxAGCRateMCS15_MCS12	0x7f7f7f7f
 
-//Rx Pseduo noise
-#define		bRxPesudoNoiseOn         0x20000000	// Useless
+/* Rx Pseduo noise */
+#define		bRxPesudoNoiseOn         0x20000000	/* Useless */
 #define		bRxPesudoNoise_A         0xff
 #define		bRxPesudoNoise_B         0xff00
 #define		bRxPesudoNoise_C         0xff0000
@@ -972,9 +968,9 @@
 #define		bPesudoNoiseState_C      0xffff
 #define		bPesudoNoiseState_D      0xffff0000
 
-//7. RF Register
-//Zebra1
-#define		bZebra1_HSSIEnable        0x8		// Useless
+/* 7. RF Register
+ * Zebra1 */
+#define		bZebra1_HSSIEnable        0x8		/* Useless */
 #define		bZebra1_TRxControl        0xc00
 #define		bZebra1_TRxGainSetting    0x07f
 #define		bZebra1_RxCorner          0xc00
@@ -984,24 +980,24 @@
 #define		bZebra1_TxLPFBW           0x400
 #define		bZebra1_RxLPFBW           0x600
 
-//Zebra4
-#define		bRTL8256RegModeCtrl1      0x100	// Useless
+/* Zebra4 */
+#define		bRTL8256RegModeCtrl1      0x100	/* Useless */
 #define		bRTL8256RegModeCtrl0      0x40
 #define		bRTL8256_TxLPFBW          0x18
 #define		bRTL8256_RxLPFBW          0x600
 
-//RTL8258
-#define		bRTL8258_TxLPFBW          0xc	// Useless
+/* RTL8258 */
+#define		bRTL8258_TxLPFBW          0xc	/* Useless */
 #define		bRTL8258_RxLPFBW          0xc00
 #define		bRTL8258_RSSILPFBW        0xc0
 
 
-//
-// Other Definition
-//
+/*
+ * Other Definition
+ *   */
 
-//byte endable for sb_write
-#define		bByte0                    0x1	// Useless
+/* byte endable for sb_write */
+#define		bByte0                    0x1	/* Useless */
 #define		bByte1                    0x2
 #define		bByte2                    0x4
 #define		bByte3                    0x8
@@ -1009,8 +1005,8 @@
 #define		bWord1                    0xc
 #define		bDWord                    0xf
 
-//for PutRegsetting & GetRegSetting BitMask
-#define		bMaskByte0		0xff	// Reg 0xc50 rOFDM0_XAAGCCore~0xC6f
+/* for PutRegsetting & GetRegSetting BitMask */
+#define		bMaskByte0		0xff	/* Reg 0xc50 rOFDM0_XAAGCCore~0xC6f */
 #define		bMaskByte1		0xff00
 #define		bMaskByte2		0xff0000
 #define		bMaskByte3		0xff000000
@@ -1019,82 +1015,81 @@
 #define		bMaskDWord	0xffffffff
 #define		bMaskH4Bits		0xf0000000
 #define		bMaskH3Bytes	0xffffff00
-#define 		bMaskOFDM_D	0xffc00000
+#define		bMaskOFDM_D	0xffc00000
 #define		bMaskCCK		0x3f3f3f3f
 #define		bMask12Bits		0xfff
 
-//for PutRFRegsetting & GetRFRegSetting BitMask
+/* for PutRFRegsetting & GetRFRegSetting BitMask */
 #if (RTL92SE_FPGA_VERIFY == 1)
-//#define		bMask12Bits               0xfff	// RF Reg mask bits
-//#define		bMask20Bits               0xfff	// RF Reg mask bits T65 RF
-#define 		bRFRegOffsetMask	0xfff		
+/* #define		bMask12Bits               0xfff */	/* RF Reg mask bits */
+/* #define		bMask20Bits               0xfff */	/* RF Reg mask bits T65 RF */
+#define		bRFRegOffsetMask	0xfff
 #else
-//#define		bMask12Bits               0xfffff	// RF Reg mask bits
-//#define		bMask20Bits               0xfffff	// RF Reg mask bits T65 RF
-#define 		bRFRegOffsetMask	0xfffff		
-#endif       		
-#define		bEnable                   0x1	// Useless
+/* #define		bMask12Bits               0xfffff */	/* RF Reg mask bits */
+/* #define		bMask20Bits               0xfffff */	/* RF Reg mask bits T65 RF */
+#define		bRFRegOffsetMask	0xfffff
+#endif
+#define		bEnable                   0x1	/* Useless */
 #define		bDisable                  0x0
-       		
-#define		LeftAntenna               0x0	// Useless
+
+#define		LeftAntenna               0x0	/* Useless */
 #define		RightAntenna              0x1
-       		
-#define		tCheckTxStatus            500   //500ms // Useless
-#define		tUpdateRxCounter          100   //100ms
-       		
-#define		rateCCK     0	// Useless
+
+#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 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 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		bPMACControl	0x0		/* Useless */
 #define		bWMACControl	0x1
 #define		bWNICControl	0x2
 
 #if 0
-#define		ANTENNA_A	0x1	// Useless
+#define		ANTENNA_A	0x1	/* Useless */
 #define		ANTENNA_B	0x2
-#define		ANTENNA_AB	0x3	// ANTENNA_A|ANTENNA_B
+#define		ANTENNA_AB	0x3	/* ANTENNA_A | ANTENNA_B */
 
 #define		ANTENNA_C	0x4
 #define		ANTENNA_D	0x8
 #endif
 
-#define RCR_AAP			BIT(0)				// accept all physical address
-#define RCR_APM			BIT(1)				// accept physical match
-#define RCR_AM			BIT(2)				// accept multicast
-#define RCR_AB			BIT(3)				// accept broadcast
-#define RCR_ACRC32		BIT(5)				// accept error packet
+#define RCR_AAP			BIT(0)				/* accept all physical address */
+#define RCR_APM			BIT(1)				/* accept physical match */
+#define RCR_AM			BIT(2)				/* accept multicast */
+#define RCR_AB			BIT(3)				/* accept broadcast */
+#define RCR_ACRC32		BIT(5)				/* accept error packet */
 #define RCR_9356SEL		BIT(6)
-#define RCR_AICV		BIT(9)				// Accept ICV error packet
-#define RCR_RXFTH0		(BIT(13)|BIT(14)|BIT(15))	// Rx FIFO threshold
-#define RCR_ADF			BIT(18)				// Accept Data(frame type) frame
-#define RCR_ACF			BIT(19)				// Accept control frame
-#define RCR_AMF			BIT(20)				// Accept management frame
+#define RCR_AICV		BIT(9)				/* Accept ICV error packet */
+#define RCR_RXFTH0		(BIT(13) | BIT(14) | BIT(15))	/* Rx FIFO threshold */
+#define RCR_ADF			BIT(18)				/* Accept Data(frame type) frame */
+#define RCR_ACF			BIT(19)				/* Accept control frame */
+#define RCR_AMF			BIT(20)				/* Accept management frame */
 #define RCR_ADD3		BIT(21)
-#define RCR_APWRMGT		BIT(22)				// Accept power management packet
-#define RCR_CBSSID		BIT(23)				// Accept BSSID match packet
-#define RCR_ENMARP		BIT(28)				// enable mac auto reset phy
-#define RCR_EnCS1		BIT(29)				// enable carrier sense method 1
-#define RCR_EnCS2		BIT(30)				// enable carrier sense method 2
-#define RCR_OnlyErlPkt		BIT(31)				// Rx Early mode is performed for packet size greater than 1536
+#define RCR_APWRMGT		BIT(22)				/* Accept power management packet */
+#define RCR_CBSSID		BIT(23)				/* Accept BSSID match packet */
+#define RCR_ENMARP		BIT(28)				/* enable mac auto reset phy */
+#define RCR_EnCS1		BIT(29)				/* enable carrier sense method 1 */
+#define RCR_EnCS2		BIT(30)				/* enable carrier sense method 2 */
+#define RCR_OnlyErlPkt		BIT(31)				/* Rx Early mode is performed for packet size greater than 1536 */
 
 /*--------------------------Define Parameters-------------------------------*/
 
 
-#endif	//__INC_HAL8192SPHYREG_H
-
+#endif /* __INC_HAL8192SPHYREG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_odm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_odm.h
index 8375fe14a1b8..99f132b650d4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_odm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_odm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_ODM_H__
 #define __RTW_ODM_H__
 
@@ -25,31 +21,77 @@
 /*
 * This file provides utilities/wrappers for rtw driver to use ODM
 */
+typedef enum _HAL_PHYDM_OPS {
+	HAL_PHYDM_DIS_ALL_FUNC,
+	HAL_PHYDM_FUNC_SET,
+	HAL_PHYDM_FUNC_CLR,
+	HAL_PHYDM_ABILITY_BK,
+	HAL_PHYDM_ABILITY_RESTORE,
+	HAL_PHYDM_ABILITY_SET,
+	HAL_PHYDM_ABILITY_GET,
+} HAL_PHYDM_OPS;
+
+
+#define DYNAMIC_FUNC_DISABLE		(0x0)
+	u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability);
+
+#define rtw_phydm_func_disable_all(adapter)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0)
+
+#ifdef CONFIG_RTW_ACS
+#define rtw_phydm_func_for_offchannel(adapter) \
+		do { \
+			rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0); \
+			if (rtw_odm_adaptivity_needed(adapter)) \
+				rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ODM_BB_ADAPTIVITY); \
+			if (IS_ACS_ENABLE(adapter))\
+				rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ODM_BB_ENV_MONITOR); \
+		} while (0)
+#else
+#define rtw_phydm_func_for_offchannel(adapter) \
+		do { \
+			rtw_phydm_ability_ops(adapter, HAL_PHYDM_DIS_ALL_FUNC, 0); \
+			if (rtw_odm_adaptivity_needed(adapter)) \
+				rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_SET, ODM_BB_ADAPTIVITY); \
+		} while (0)
+#endif
 
-void rtw_odm_dbg_comp_msg(void *sel,_adapter *adapter);
-void rtw_odm_dbg_comp_set(_adapter *adapter, u64 comps);
-void rtw_odm_dbg_level_msg(void *sel,_adapter *adapter);
-void rtw_odm_dbg_level_set(_adapter *adapter, u32 level);
+#define rtw_phydm_func_clr(adapter, ability)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_FUNC_CLR, ability)
+
+#define rtw_phydm_ability_backup(adapter)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_BK, 0)
+
+#define rtw_phydm_ability_restore(adapter)	\
+		rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_RESTORE, 0)
+
+
+static inline u32 rtw_phydm_ability_get(_adapter *adapter)
+{
+	return rtw_phydm_ability_ops(adapter, HAL_PHYDM_ABILITY_GET, 0);
+}
 
-void rtw_odm_ability_msg(void *sel, _adapter *adapter);
-void rtw_odm_ability_set(_adapter *adapter, u32 ability);
 
 void rtw_odm_init_ic_type(_adapter *adapter);
 
 void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter);
 
 bool rtw_odm_adaptivity_needed(_adapter *adapter);
-void rtw_odm_adaptivity_parm_msg(void *sel,_adapter *adapter);
-void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 TH_L2H_ini, s8 TH_EDCCA_HL_diff, s8 TH_L2H_ini_mode2, s8 TH_EDCCA_HL_diff_mode2, u8 EDCCA_enable);
+void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter);
+void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff, s8 th_l2h_ini_mode2, s8 th_edcca_hl_diff_mode2, u8 edcca_enable);
 void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter);
-void rtw_odm_acquirespinlock(_adapter *adapter,	RT_SPINLOCK_TYPE type);
-void rtw_odm_releasespinlock(_adapter *adapter,	RT_SPINLOCK_TYPE type);
+void rtw_odm_acquirespinlock(_adapter *adapter,	enum rt_spinlock_type type);
+void rtw_odm_releasespinlock(_adapter *adapter,	enum rt_spinlock_type type);
 
+u8 rtw_odm_get_dfs_domain(_adapter *adapter);
+u8 rtw_odm_dfs_domain_unknown(_adapter *adapter);
 #ifdef CONFIG_DFS_MASTER
 VOID rtw_odm_radar_detect_reset(_adapter *adapter);
 VOID rtw_odm_radar_detect_disable(_adapter *adapter);
 VOID rtw_odm_radar_detect_enable(_adapter *adapter);
 BOOLEAN rtw_odm_radar_detect(_adapter *adapter);
 #endif /* CONFIG_DFS_MASTER */
-#endif // __RTW_ODM_H__
 
+void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys);
+
+#endif /* __RTW_ODM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_p2p.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_p2p.h
index ab3f4c87deed..c2a73b65c053 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_p2p.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_p2p.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_P2P_H_
 #define __RTW_P2P_H_
 
 
 u32 build_beacon_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
 u32 build_probe_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
-u32 build_prov_disc_request_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8* pssid, u8 ussidlen, u8* pdev_raddr );
+u32 build_prov_disc_request_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 *pssid, u8 ussidlen, u8 *pdev_raddr);
 u32 build_assoc_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 status_code);
 u32 build_deauth_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf);
 #ifdef CONFIG_WFD
@@ -60,48 +56,48 @@ u32 process_p2p_devdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint le
 u32 process_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
 u8 process_p2p_provdisc_req(struct wifidirect_info *pwdinfo,  u8 *pframe, uint len);
 u8 process_p2p_provdisc_resp(struct wifidirect_info *pwdinfo,  u8 *pframe);
-u8 process_p2p_group_negotation_req( struct wifidirect_info *pwdinfo, u8 *pframe, uint len );
-u8 process_p2p_group_negotation_resp( struct wifidirect_info *pwdinfo, u8 *pframe, uint len );
-u8 process_p2p_group_negotation_confirm( struct wifidirect_info *pwdinfo, u8 *pframe, uint len );
+u8 process_p2p_group_negotation_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
+u8 process_p2p_group_negotation_confirm(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
 u8 process_p2p_presence_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len);
 int process_p2p_cross_connect_ie(PADAPTER padapter, u8 *IEs, u32 IELength);
 
-void p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType);
+s32 p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType, u8 *buf);
 
 #ifdef CONFIG_P2P_PS
 void	process_p2p_ps_ie(PADAPTER padapter, u8 *IEs, u32 IELength);
 void	p2p_ps_wk_hdl(_adapter *padapter, u8 p2p_ps_state);
-u8	p2p_ps_wk_cmd(_adapter*padapter, u8 p2p_ps_state, u8 enqueue);
-#endif // CONFIG_P2P_PS
+u8	p2p_ps_wk_cmd(_adapter *padapter, u8 p2p_ps_state, u8 enqueue);
+#endif /* CONFIG_P2P_PS */
 
 #ifdef CONFIG_IOCTL_CFG80211
-void rtw_init_cfg80211_wifidirect_info( _adapter*	padapter);
+u8 roch_stay_in_cur_chan(_adapter *padapter);
+void rtw_init_cfg80211_wifidirect_info(_adapter	*padapter);
 int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx);
 #endif /* CONFIG_IOCTL_CFG80211 */
 
-void reset_global_wifidirect_info( _adapter* padapter );
-void rtw_init_wifidirect_timers(_adapter* padapter);
-void rtw_init_wifidirect_addrs(_adapter* padapter, u8 *dev_addr, u8 *iface_addr);
-void init_wifidirect_info( _adapter* padapter, enum P2P_ROLE role);
+void reset_global_wifidirect_info(_adapter *padapter);
+void rtw_init_wifidirect_timers(_adapter *padapter);
+void rtw_init_wifidirect_addrs(_adapter *padapter, u8 *dev_addr, u8 *iface_addr);
+void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role);
 int rtw_p2p_enable(_adapter *padapter, enum P2P_ROLE role);
 
 static inline void _rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)
 {
-	if(wdinfo->p2p_state != state) {
-		//wdinfo->pre_p2p_state = wdinfo->p2p_state;
+	if (wdinfo->p2p_state != state) {
+		/* wdinfo->pre_p2p_state = wdinfo->p2p_state; */
 		wdinfo->p2p_state = state;
 	}
 }
 static inline void _rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)
 {
-	if(wdinfo->pre_p2p_state != state) {
+	if (wdinfo->pre_p2p_state != state)
 		wdinfo->pre_p2p_state = state;
-	}
 }
 #if 0
 static inline void _rtw_p2p_restore_state(struct wifidirect_info *wdinfo)
 {
-	if(wdinfo->pre_p2p_state != -1) {
+	if (wdinfo->pre_p2p_state != -1) {
 		wdinfo->p2p_state = wdinfo->pre_p2p_state;
 		wdinfo->pre_p2p_state = -1;
 	}
@@ -109,9 +105,8 @@ static inline void _rtw_p2p_restore_state(struct wifidirect_info *wdinfo)
 #endif
 static inline void _rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)
 {
-	if(wdinfo->role != role) {
+	if (wdinfo->role != role)
 		wdinfo->role = role;
-	}
 }
 static inline int _rtw_p2p_state(struct wifidirect_info *wdinfo)
 {
@@ -137,18 +132,18 @@ static inline bool _rtw_p2p_chk_role(struct wifidirect_info *wdinfo, enum P2P_RO
 #ifdef CONFIG_DBG_P2P
 void dbg_rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line);
 void dbg_rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line);
-//void dbg_rtw_p2p_restore_state(struct wifidirect_info *wdinfo, const char *caller, int line);
+/* void dbg_rtw_p2p_restore_state(struct wifidirect_info *wdinfo, const char *caller, int line); */
 void dbg_rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role, const char *caller, int line);
 #define rtw_p2p_set_state(wdinfo, state) dbg_rtw_p2p_set_state(wdinfo, state, __FUNCTION__, __LINE__)
 #define rtw_p2p_set_pre_state(wdinfo, state) dbg_rtw_p2p_set_pre_state(wdinfo, state, __FUNCTION__, __LINE__)
 #define rtw_p2p_set_role(wdinfo, role) dbg_rtw_p2p_set_role(wdinfo, role, __FUNCTION__, __LINE__)
-//#define rtw_p2p_restore_state(wdinfo) dbg_rtw_p2p_restore_state(wdinfo, __FUNCTION__, __LINE__)
-#else //CONFIG_DBG_P2P
+/* #define rtw_p2p_restore_state(wdinfo) dbg_rtw_p2p_restore_state(wdinfo, __FUNCTION__, __LINE__) */
+#else /* CONFIG_DBG_P2P */
 #define rtw_p2p_set_state(wdinfo, state) _rtw_p2p_set_state(wdinfo, state)
 #define rtw_p2p_set_pre_state(wdinfo, state) _rtw_p2p_set_pre_state(wdinfo, state)
 #define rtw_p2p_set_role(wdinfo, role) _rtw_p2p_set_role(wdinfo, role)
-//#define rtw_p2p_restore_state(wdinfo) _rtw_p2p_restore_state(wdinfo)
-#endif //CONFIG_DBG_P2P
+/* #define rtw_p2p_restore_state(wdinfo) _rtw_p2p_restore_state(wdinfo) */
+#endif /* CONFIG_DBG_P2P */
 
 #define rtw_p2p_state(wdinfo) _rtw_p2p_state(wdinfo)
 #define rtw_p2p_pre_state(wdinfo) _rtw_p2p_pre_state(wdinfo)
@@ -160,20 +155,19 @@ void dbg_rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role, co
 	(wdinfo)->find_phase_state_exchange_cnt = (value)
 
 #ifdef CONFIG_P2P
-//is this find phase exchange for social channel scan?
+/* is this find phase exchange for social channel scan? */
 #define rtw_p2p_findphase_ex_is_social(wdinfo)   \
 	(wdinfo)->find_phase_state_exchange_cnt >= P2P_FINDPHASE_EX_SOCIAL_FIRST
 
-//should we need find phase exchange anymore?
+/* should we need find phase exchange anymore? */
 #define rtw_p2p_findphase_ex_is_needed(wdinfo) \
 	((wdinfo)->find_phase_state_exchange_cnt < P2P_FINDPHASE_EX_MAX && \
-	(wdinfo)->find_phase_state_exchange_cnt != P2P_FINDPHASE_EX_NONE && \
-	!(wdinfo)->rx_invitereq_info.scan_op_ch_only && \
-	!(wdinfo)->p2p_info.scan_op_ch_only)
+	 (wdinfo)->find_phase_state_exchange_cnt != P2P_FINDPHASE_EX_NONE && \
+	 !(wdinfo)->rx_invitereq_info.scan_op_ch_only && \
+	 !(wdinfo)->p2p_info.scan_op_ch_only)
 #else
 #define rtw_p2p_findphase_ex_is_social(wdinfo) 0
 #define rtw_p2p_findphase_ex_is_needed(wdinfo) 0
 #endif /* CONFIG_P2P */
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_pwrctrl.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_pwrctrl.h
index 7041103865b9..409d376bc860 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_pwrctrl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_pwrctrl.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,25 +12,20 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_PWRCTRL_H_
 #define __RTW_PWRCTRL_H_
 
 
-#define FW_PWR0	0	
-#define FW_PWR1 	1
-#define FW_PWR2 	2
-#define FW_PWR3 	3
+#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_PWR0	7
+#define HW_PWR1	6
+#define HW_PWR2	2
 #define HW_PWR3	0
 #define HW_PWR4	8
 
@@ -42,10 +38,23 @@
 #define EVT_ALIVE	BIT(3)
 #ifdef CONFIG_BT_COEXIST
 #define BTCOEX_ALIVE	BIT(4)
-#endif // CONFIG_BT_COEXIST
+#endif /* CONFIG_BT_COEXIST */
 
 #ifdef CONFIG_WOWLAN
-#define MAX_WKFM_NUM 16	/* Frame Mask Cam number for pattern match */
+	#ifdef CONFIG_PLATFORM_ANDROID_INTEL_X86
+		/* TCP/ICMP/UDP multicast with specific IP addr */
+		#define DEFAULT_PATTERN_NUM 4
+	#else
+		/* TCP/ICMP */
+		#define DEFAULT_PATTERN_NUM 3
+	#endif
+
+#ifdef CONFIG_WOW_PATTERN_HW_CAM	/* Frame Mask Cam number for pattern match */
+#define MAX_WKFM_CAM_NUM	12
+#else
+#define MAX_WKFM_CAM_NUM	16
+#endif
+
 #define MAX_WKFM_SIZE	16 /* (16 bytes for WKFM bit mask, 16*8 = 128 bits) */
 #define MAX_WKFM_PATTERN_SIZE	128
 #define WKFMCAM_ADDR_NUM 6
@@ -64,19 +73,13 @@ typedef struct rtl_priv_pattern {
 	char mask[MAX_WKFM_SIZE];
 } rtl_priv_pattern_t;
 
-struct rtl_wow_pattern {
-	u16	crc;
-	u8	type;
-	u32	mask[4];
-};
 #endif /* CONFIG_WOWLAN */
 
-enum Power_Mgnt
-{
+enum Power_Mgnt {
 	PS_MODE_ACTIVE	= 0	,
 	PS_MODE_MIN			,
 	PS_MODE_MAX			,
-	PS_MODE_DTIM			,	//PS_MODE_SELF_DEFINED
+	PS_MODE_DTIM			,	/* PS_MODE_SELF_DEFINED */
 	PS_MODE_VOIP			,
 	PS_MODE_UAPSD_WMM	,
 	PS_MODE_UAPSD			,
@@ -87,10 +90,17 @@ enum Power_Mgnt
 	PS_MODE_NUM,
 };
 
+enum lps_level {
+	LPS_NORMAL = 0,
+	LPS_LCLK,
+	LPS_PG,
+	LPS_LEVEL_MAX,
+};
+
 #ifdef CONFIG_PNO_SUPPORT
 #define MAX_PNO_LIST_COUNT 16
-#define MAX_SCAN_LIST_COUNT 14	//2.4G only
-#define MAX_HIDDEN_AP 8		//8 hidden AP
+#define MAX_SCAN_LIST_COUNT 14	/* 2.4G only */
+#define MAX_HIDDEN_AP 8		/* 8 hidden AP */
 #endif
 
 /*
@@ -132,9 +142,9 @@ enum Power_Mgnt
 
 struct reportpwrstate_parm {
 	unsigned char mode;
-	unsigned char state; //the CPWM value
+	unsigned char state; /* the CPWM value */
 	unsigned short rsvd;
-}; 
+};
 
 
 typedef _sema _pwrlock;
@@ -162,41 +172,40 @@ __inline static void _exit_pwrlock(_pwrlock *plock)
 	_rtw_up_sema(plock);
 }
 
-#define LPS_DELAY_TIME	1*HZ // 1 sec
+#define LPS_DELAY_MS	1000 /* 1 sec */
 
 #define EXE_PWR_NONE	0x01
 #define EXE_PWR_IPS		0x02
 #define EXE_PWR_LPS		0x04
 
-// RF state.
-typedef 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 state. */
+typedef 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
-}rt_rf_power_state;
-
-// 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
-#define	RT_RF_OFF_LEVL_HALT_NIC		BIT(3)	// NIC halt, re-initialize hw parameters
-#define	RT_RF_OFF_LEVL_FREE_FW		BIT(4)	// FW free, re-download the FW
-#define	RT_RF_OFF_LEVL_FW_32K		BIT(5)	// FW in 32k
-#define	RT_RF_PS_LEVEL_ALWAYS_ASPM	BIT(6)	// Always enable ASPM and Clock Req in initialization.
-#define	RT_RF_LPS_DISALBE_2R			BIT(30)	// When LPS is on, disable 2R if no packet is received or transmittd.
-#define	RT_RF_LPS_LEVEL_ASPM			BIT(31)	// LPS with ASPM
+} rt_rf_power_state;
+
+/* 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 */
+#define	RT_RF_OFF_LEVL_HALT_NIC		BIT(3)	/* NIC halt, re-initialize hw parameters */
+#define	RT_RF_OFF_LEVL_FREE_FW		BIT(4)	/* FW free, re-download the FW */
+#define	RT_RF_OFF_LEVL_FW_32K		BIT(5)	/* FW in 32k */
+#define	RT_RF_PS_LEVEL_ALWAYS_ASPM	BIT(6)	/* Always enable ASPM and Clock Req in initialization. */
+#define	RT_RF_LPS_DISALBE_2R			BIT(30)	/* When LPS is on, disable 2R if no packet is received or transmittd. */
+#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)
 
-// ASPM OSC Control bit, added by Roger, 2013.03.29.
-#define	RT_PCI_ASPM_OSC_IGNORE		0	 // PCI ASPM ignore OSC control in default
-#define	RT_PCI_ASPM_OSC_ENABLE		BIT0 // PCI ASPM controlled by OS according to ACPI Spec 5.0
-#define	RT_PCI_ASPM_OSC_DISABLE		BIT1 // PCI ASPM controlled by driver or BIOS, i.e., force enable ASPM
+/* ASPM OSC Control bit, added by Roger, 2013.03.29. */
+#define	RT_PCI_ASPM_OSC_IGNORE		0	 /* PCI ASPM ignore OSC control in default */
+#define	RT_PCI_ASPM_OSC_ENABLE		BIT0 /* PCI ASPM controlled by OS according to ACPI Spec 5.0 */
+#define	RT_PCI_ASPM_OSC_DISABLE		BIT1 /* PCI ASPM controlled by driver or BIOS, i.e., force enable ASPM */
 
 
 enum _PS_BBRegBackup_ {
@@ -207,16 +216,15 @@ enum _PS_BBRegBackup_ {
 	PSBBREG_TOTALCNT
 };
 
-enum { // for ips_mode
-	IPS_NONE=0,
+enum { /* for ips_mode */
+	IPS_NONE = 0,
 	IPS_NORMAL,
-	IPS_LEVEL_2,	
+	IPS_LEVEL_2,
 	IPS_NUM
 };
 
-// Design for pwrctrl_priv.ips_deny, 32 bits for 32 reasons at most
-typedef enum _PS_DENY_REASON
-{
+/* Design for pwrctrl_priv.ips_deny, 32 bits for 32 reasons at most */
+typedef enum _PS_DENY_REASON {
 	PS_DENY_DRV_INITIAL = 0,
 	PS_DENY_SCAN,
 	PS_DENY_JOIN,
@@ -225,23 +233,23 @@ typedef enum _PS_DENY_REASON
 	PS_DENY_IOCTL,
 	PS_DENY_MGNT_TX,
 	PS_DENY_MONITOR_MODE,
+	PS_DENY_BEAMFORMING,		/* Beamforming */
 	PS_DENY_DRV_REMOVE = 30,
 	PS_DENY_OTHERS = 31
 } PS_DENY_REASON;
 
 #ifdef CONFIG_PNO_SUPPORT
-typedef struct pno_nlo_info
-{
-	u32 fast_scan_period;				//Fast scan period
-	u8	ssid_num;				//number of entry
+typedef struct pno_nlo_info {
+	u32 fast_scan_period;				/* Fast scan period */
+	u8	ssid_num;				/* number of entry */
 	u8	hidden_ssid_num;
-	u32	slow_scan_period;			//slow scan period
-	u32	fast_scan_iterations;			//Fast scan iterations
-	u8	ssid_length[MAX_PNO_LIST_COUNT];	//SSID Length Array
-	u8	ssid_cipher_info[MAX_PNO_LIST_COUNT];	//Cipher information for security
-	u8	ssid_channel_info[MAX_PNO_LIST_COUNT];	//channel information
-	u8	loc_probe_req[MAX_HIDDEN_AP];		//loc_probeReq
-}pno_nlo_info_t;
+	u32	slow_scan_period;			/* slow scan period */
+	u32	fast_scan_iterations;			/* Fast scan iterations */
+	u8	ssid_length[MAX_PNO_LIST_COUNT];	/* SSID Length Array */
+	u8	ssid_cipher_info[MAX_PNO_LIST_COUNT];	/* Cipher information for security */
+	u8	ssid_channel_info[MAX_PNO_LIST_COUNT];	/* channel information */
+	u8	loc_probe_req[MAX_HIDDEN_AP];		/* loc_probeReq */
+} pno_nlo_info_t;
 
 typedef struct pno_ssid {
 	u32		SSID_len;
@@ -250,79 +258,111 @@ typedef struct pno_ssid {
 
 typedef struct pno_ssid_list {
 	pno_ssid_t	node[MAX_PNO_LIST_COUNT];
-}pno_ssid_list_t;
+} pno_ssid_list_t;
 
-typedef struct pno_scan_channel_info
-{
+typedef struct pno_scan_channel_info {
 	u8	channel;
 	u8	tx_power;
 	u8	timeout;
-	u8	active;				//set 1 means active scan, or pasivite scan.
-}pno_scan_channel_info_t;
-
-typedef struct pno_scan_info
-{
-	u8	enableRFE;			//Enable RFE
-	u8	period_scan_time;		//exclusive with fast_scan_period and slow_scan_period
-	u8	periodScan;			//exclusive with fast_scan_period and slow_scan_period
-	u8	orig_80_offset;			//original channel 80 offset
-	u8	orig_40_offset;			//original channel 40 offset
-	u8	orig_bw;			//original bandwidth
-	u8	orig_ch;			//original channel
-	u8	channel_num;			//number of channel
-	u64	rfe_type;			//rfe_type && 0x00000000000000ff
+	u8	active;				/* set 1 means active scan, or pasivite scan. */
+} pno_scan_channel_info_t;
+
+typedef struct pno_scan_info {
+	u8	enableRFE;			/* Enable RFE */
+	u8	period_scan_time;		/* exclusive with fast_scan_period and slow_scan_period */
+	u8	periodScan;			/* exclusive with fast_scan_period and slow_scan_period */
+	u8	orig_80_offset;			/* original channel 80 offset */
+	u8	orig_40_offset;			/* original channel 40 offset */
+	u8	orig_bw;			/* original bandwidth */
+	u8	orig_ch;			/* original channel */
+	u8	channel_num;			/* number of channel */
+	u64	rfe_type;			/* rfe_type && 0x00000000000000ff */
 	pno_scan_channel_info_t ssid_channel_info[MAX_SCAN_LIST_COUNT];
-}pno_scan_info_t;
-#endif //CONFIG_PNO_SUPPORT
+} pno_scan_info_t;
+#endif /* CONFIG_PNO_SUPPORT */
 
-struct pwrctrl_priv
-{
+#ifdef CONFIG_LPS_POFF
+/* Driver context for LPS 32K Close IO Power */
+typedef struct lps_poff_info {
+	bool	bEn;
+	u8	*pStaticFile;
+	u8	*pDynamicFile;
+	u32	ConfFileOffset;
+	u32	tx_bndy_static;
+	u32	tx_bndy_dynamic;
+	u16	ConfLenForPTK;
+	u16	ConfLenForGTK;
+	ATOMIC_T bEnterPOFF;
+	ATOMIC_T bTxBoundInProgress;
+	ATOMIC_T bSetPOFFParm;
+} lps_poff_info_t;
+#endif /*CONFIG_LPS_POFF*/
+
+struct aoac_report {
+	u8 iv[8];
+	u8 replay_counter_eapol_key[8];
+	u8 group_key[32];
+	u8 key_index;
+	u8 security_type;
+	u8 wow_pattern_idx;
+	u8 version_info;
+	u8 reserved[4];
+	u8 rxptk_iv[8];
+	u8 rxgtk_iv[4][8];
+};
+
+struct pwrctrl_priv {
 	_pwrlock	lock;
 	_pwrlock	check_32k_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
-	volatile u8 cpwm_tog; // toggling
+	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 */
+	volatile u8 cpwm_tog; /* toggling */
 
 	u8	pwr_mode;
 	u8	smart_ps;
 	u8	bcn_ant_mode;
-	u8 	dtim;
+	u8	dtim;
+
+#ifdef CONFIG_WMMPS_STA
+	u8 wmm_smart_ps;
+#endif /* CONFIG_WMMPS_STA */	
 
 	u32	alives;
 	_workitem cpwm_event;
+	_workitem dma_event; /*for handle un-synchronized tx dma*/
 #ifdef CONFIG_LPS_RPWM_TIMER
 	u8 brpwmtimeout;
 	_workitem rpwmtimeoutwi;
 	_timer pwr_rpwm_timer;
-#endif // CONFIG_LPS_RPWM_TIMER
-	u8	bpower_saving; //for LPS/IPS
+#endif /* CONFIG_LPS_RPWM_TIMER */
+	u8	bpower_saving; /* for LPS/IPS */
 
 	u8	b_hw_radio_off;
 	u8	reg_rfoff;
-	u8	reg_pdnmode; //powerdown mode
+	u8	reg_pdnmode; /* powerdown mode */
 	u32	rfoff_reason;
 
-	//RF OFF Level
+	/* RF OFF Level */
 	u32	cur_ps_level;
 	u32	reg_rfps_level;
 
-	uint 	ips_enter_cnts;
-	uint 	ips_leave_cnts;
-	uint 	lps_enter_cnts;
-	uint 	lps_leave_cnts;
+	uint	ips_enter_cnts;
+	uint	ips_leave_cnts;
+	uint	lps_enter_cnts;
+	uint	lps_leave_cnts;
 
-	u8	ips_mode; 
-	u8	ips_org_mode; 
-	u8	ips_mode_req; // used to accept the mode setting request, will update to ipsmode later
+	u8	ips_mode;
+	u8	ips_org_mode;
+	u8	ips_mode_req; /* used to accept the mode setting request, will update to ipsmode later */
 	uint bips_processing;
-	u32 ips_deny_time; /* will deny IPS when system time is smaller than this */
-	u8 pre_ips_type;// 0: default flow, 1: carddisbale flow
+	systime ips_deny_time; /* will deny IPS when system time is smaller than this */
+	u8 pre_ips_type;/* 0: default flow, 1: carddisbale flow */
 
-	// ps_deny: if 0, power save is free to go; otherwise deny all kinds of power save.
-	// Use PS_DENY_REASON to decide reason.
-	// Don't access this variable directly without control function,
-	// and this variable should be protected by lock.
+	/* ps_deny: if 0, power save is free to go; otherwise deny all kinds of power save. */
+	/* Use PS_DENY_REASON to decide reason. */
+	/* Don't access this variable directly without control function, */
+	/* and this variable should be protected by lock. */
 	u32 ps_deny;
 
 	u8 ps_processing; /* temporarily used to mark whether in rtw_ps_processor */
@@ -333,48 +373,60 @@ struct pwrctrl_priv
 	u8	power_mgnt;
 	u8	org_power_mgnt;
 	u8	bFwCurrentInPSMode;
-	u32	DelayLPSLastTimeStamp;
+	systime	DelayLPSLastTimeStamp;
 	s32		pnp_current_pwr_state;
 	u8		pnp_bstop_trx;
 
-
+	#ifdef CONFIG_AUTOSUSPEND
+	int		ps_flag; /* used by autosuspend */
 	u8		bInternalAutoSuspend;
+	#endif
 	u8		bInSuspend;
-#ifdef	CONFIG_BT_COEXIST
+#ifdef CONFIG_BT_COEXIST
 	u8		bAutoResume;
 	u8		autopm_cnt;
 #endif
-	u8		bSupportRemoteWakeup;	
+	u8		bSupportRemoteWakeup;
 	u8		wowlan_wake_reason;
+	u8		wowlan_last_wake_reason;
 	u8		wowlan_ap_mode;
 	u8		wowlan_mode;
 	u8		wowlan_p2p_mode;
 	u8		wowlan_pno_enable;
+	u8		wowlan_in_resume;
+
 #ifdef CONFIG_GPIO_WAKEUP
 	u8		is_high_active;
 #endif /* CONFIG_GPIO_WAKEUP */
 #ifdef CONFIG_WOWLAN
+	bool		default_patterns_en;
+#ifdef CONFIG_IPV6
+	u8		wowlan_ns_offload_en;
+#endif /*CONFIG_IPV6*/
 	u8		wowlan_txpause_status;
-	u8		wowlan_pattern;
 	u8		wowlan_pattern_idx;
 	u64		wowlan_fw_iv;
-	struct rtl_priv_pattern	patterns[MAX_WKFM_NUM];
+	struct rtl_priv_pattern	patterns[MAX_WKFM_CAM_NUM];
 #ifdef CONFIG_PNO_SUPPORT
-	u8		pno_in_resume;
 	u8		pno_inited;
 	pno_nlo_info_t	*pnlo_info;
 	pno_scan_info_t	*pscan_info;
 	pno_ssid_list_t	*pno_ssid_list;
 #endif /* CONFIG_PNO_SUPPORT */
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+	_mutex	wowlan_pattern_cam_mutex;
+#endif
+	u8		wowlan_aoac_rpt_loc;
+	struct aoac_report wowlan_aoac_rpt;
+	u8		wowlan_dis_lps;/*for debug purpose*/
 #endif /* CONFIG_WOWLAN */
-	_timer 	pwr_state_check_timer;
+	_timer	pwr_state_check_timer;
 	int		pwr_state_check_interval;
 	u8		pwr_state_check_cnts;
 
-	int 		ps_flag; /* used by autosuspend */
-	
-	rt_rf_power_state	rf_pwrstate;//cur power state, only for IPS
-	//rt_rf_power_state 	current_rfpwrstate;
+
+	rt_rf_power_state	rf_pwrstate;/* cur power state, only for IPS */
+	/* rt_rf_power_state	current_rfpwrstate; */
 	rt_rf_power_state	change_rfpwrstate;
 
 	u8		bHWPowerdown; /* power down mode selection. 0:radio off, 1:power down */
@@ -383,24 +435,45 @@ struct pwrctrl_priv
 	u8		brfoffbyhw;
 	unsigned long PS_BBRegBackup[PSBBREG_TOTALCNT];
 
-	#ifdef CONFIG_RESUME_IN_WORKQUEUE
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
 	struct workqueue_struct *rtw_workqueue;
 	_workitem resume_work;
-	#endif
+#endif
 
-	#ifdef CONFIG_HAS_EARLYSUSPEND
+#ifdef CONFIG_HAS_EARLYSUSPEND
 	struct early_suspend early_suspend;
 	u8 do_late_resume;
-	#endif //CONFIG_HAS_EARLYSUSPEND
-	
-	#ifdef CONFIG_ANDROID_POWER
+#endif /* CONFIG_HAS_EARLYSUSPEND */
+
+#ifdef CONFIG_ANDROID_POWER
 	android_early_suspend_t early_suspend;
 	u8 do_late_resume;
-	#endif
+#endif
 
-	#ifdef CONFIG_INTEL_PROXIM
+#ifdef CONFIG_INTEL_PROXIM
 	u8	stored_power_mgnt;
-	#endif
+#endif
+
+#ifdef CONFIG_LPS_POFF
+	lps_poff_info_t	*plps_poff_info;
+#endif
+	u8 lps_level_bk;
+	u8 lps_level; /*LPS_NORMAL,LPA_CG,LPS_PG*/
+#ifdef CONFIG_LPS_PG
+	u8 lpspg_rsvd_page_locate;
+	u8 blpspg_info_up;
+#endif
+	u8 current_lps_hw_port_id;
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	systime radio_on_start_time;
+	systime pwr_saving_start_time;
+	u32 pwr_saving_time;
+	u32 on_time;
+	u32 tx_time;
+	u32 rx_time;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 };
 
 #define rtw_get_ips_mode_req(pwrctl) \
@@ -413,15 +486,15 @@ struct pwrctrl_priv
 
 #define _rtw_set_pwr_state_check_timer(pwrctl, ms) \
 	do { \
-		/*DBG_871X("%s _rtw_set_pwr_state_check_timer(%p, %d)\n", __FUNCTION__, (pwrctl), (ms));*/ \
+		/*RTW_INFO("%s _rtw_set_pwr_state_check_timer(%p, %d)\n", __FUNCTION__, (pwrctl), (ms));*/ \
 		_set_timer(&(pwrctl)->pwr_state_check_timer, (ms)); \
-	} while(0)
-	
+	} while (0)
+
 #define rtw_set_pwr_state_check_timer(pwrctl) \
 	_rtw_set_pwr_state_check_timer((pwrctl), (pwrctl)->pwr_state_check_interval)
 
 extern void rtw_init_pwrctrl_priv(_adapter *adapter);
-extern void rtw_free_pwrctrl_priv(_adapter * adapter);
+extern void rtw_free_pwrctrl_priv(_adapter *adapter);
 
 #ifdef CONFIG_LPS_LCLK
 s32 rtw_register_task_alive(PADAPTER, u32 task);
@@ -441,19 +514,19 @@ extern void LPS_Leave_check(PADAPTER padapter);
 extern void LeaveAllPowerSaveMode(PADAPTER Adapter);
 extern void LeaveAllPowerSaveModeDirect(PADAPTER Adapter);
 #ifdef CONFIG_IPS
-void _ips_enter(_adapter * padapter);
-void ips_enter(_adapter * padapter);
-int _ips_leave(_adapter * padapter);
-int ips_leave(_adapter * padapter);
+void _ips_enter(_adapter *padapter);
+void ips_enter(_adapter *padapter);
+int _ips_leave(_adapter *padapter);
+int ips_leave(_adapter *padapter);
 #endif
 
-void rtw_ps_processor(_adapter*padapter);
+void rtw_ps_processor(_adapter *padapter);
 
 #ifdef CONFIG_AUTOSUSPEND
-int autoresume_enter(_adapter* padapter);
+int autoresume_enter(_adapter *padapter);
 #endif
 #ifdef SUPPORT_HW_RFOFF_DETECTED
-rt_rf_power_state RfOnOffDetect(IN	PADAPTER pAdapter );
+rt_rf_power_state RfOnOffDetect(IN	PADAPTER pAdapter);
 #endif
 
 
@@ -466,14 +539,15 @@ void LPS_Leave(PADAPTER padapter, const char *msg);
 void traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets);
 void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode, const char *msg);
 void rtw_set_fw_in_ips_mode(PADAPTER padapter, u8 enable);
-void rtw_set_rpwm(_adapter * padapter, u8 val8);
+void rtw_set_rpwm(_adapter *padapter, u8 val8);
+void rtw_wow_lps_level_decide(_adapter *adapter, u8 wow_en);
 #endif
 
 #ifdef CONFIG_RESUME_IN_WORKQUEUE
 void rtw_resume_in_workqueue(struct pwrctrl_priv *pwrpriv);
-#endif //CONFIG_RESUME_IN_WORKQUEUE
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
 
-#if defined(CONFIG_HAS_EARLYSUSPEND ) || defined(CONFIG_ANDROID_POWER)
+#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
 bool rtw_is_earlysuspend_registered(struct pwrctrl_priv *pwrpriv);
 bool rtw_is_do_late_resume(struct pwrctrl_priv *pwrpriv);
 void rtw_set_do_late_resume(struct pwrctrl_priv *pwrpriv, bool enable);
@@ -487,13 +561,14 @@ void rtw_unregister_early_suspend(struct pwrctrl_priv *pwrpriv);
 #define rtw_unregister_early_suspend(pwrpriv) do {} while (0)
 #endif /* CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER */
 
-u8 rtw_interface_ps_func(_adapter *padapter,HAL_INTF_PS_FUNC efunc_id,u8* val);
+u8 rtw_interface_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val);
 void rtw_set_ips_deny(_adapter *padapter, u32 ms);
 int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller);
 #define rtw_pwr_wakeup(adapter) _rtw_pwr_wakeup(adapter, RTW_PWR_STATE_CHK_INTERVAL, __FUNCTION__)
 #define rtw_pwr_wakeup_ex(adapter, ips_deffer_ms) _rtw_pwr_wakeup(adapter, ips_deffer_ms, __FUNCTION__)
 int rtw_pm_set_ips(_adapter *padapter, u8 mode);
 int rtw_pm_set_lps(_adapter *padapter, u8 mode);
+int rtw_pm_set_lps_level(_adapter *padapter, u8 level);
 
 void rtw_ps_deny(PADAPTER padapter, PS_DENY_REASON reason);
 void rtw_ps_deny_cancel(PADAPTER padapter, PS_DENY_REASON reason);
@@ -502,14 +577,11 @@ u32 rtw_ps_deny_get(PADAPTER padapter);
 #if defined(CONFIG_WOWLAN)
 void rtw_get_current_ip_address(PADAPTER padapter, u8 *pcurrentip);
 void rtw_get_sec_iv(PADAPTER padapter, u8 *pcur_dot11txpn, u8 *StaAddr);
-void rtw_set_sec_pn(_adapter *padapter);
 bool rtw_check_pattern_valid(u8 *input, u8 len);
-bool rtw_write_to_frame_mask(_adapter *adapter, u8 idx,
-		struct rtl_wow_pattern *content);
-
-bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx);
-void rtw_dump_priv_pattern(_adapter *adapter, u8 idx);
-void rtw_clean_pattern(_adapter *adapter);
+bool rtw_wowlan_parser_pattern_cmd(u8 *input, char *pattern,
+				int *pattern_len, char *bit_mask);
+void rtw_wow_pattern_sw_reset(_adapter *adapter);
+u8 rtw_set_default_pattern(_adapter *adapter);
+void rtw_wow_pattern_sw_dump(_adapter *adapter);
 #endif /* CONFIG_WOWLAN */
-#endif  //__RTL871X_PWRCTRL_H_
-
+#endif /* __RTL871X_PWRCTRL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_qos.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_qos.h
index cc5fcea5130e..c3011b4148d3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_qos.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_qos.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,25 +12,56 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 
 #ifndef _RTW_QOS_H_
 #define _RTW_QOS_H_
 
+#define DRV_CFG_UAPSD_VO 	BIT0
+#define DRV_CFG_UAPSD_VI 	BIT1
+#define DRV_CFG_UAPSD_BK 	BIT2
+#define DRV_CFG_UAPSD_BE 	BIT3
+
+#define WMM_IE_UAPSD_VO 	BIT0
+#define WMM_IE_UAPSD_VI 	BIT1
+#define WMM_IE_UAPSD_BK 	BIT2
+#define WMM_IE_UAPSD_BE 	BIT3
 
+#define WMM_TID0 	BIT0
+#define WMM_TID1 	BIT1
+#define WMM_TID2 	BIT2
+#define WMM_TID3 	BIT3
+#define WMM_TID4 	BIT4
+#define WMM_TID5 	BIT5
+#define WMM_TID6 	BIT6
+#define WMM_TID7 	BIT7
+
+#define AP_SUPPORTED_UAPSD BIT7
+/* TC = Traffic Category,  TID0~7 represents TC */
+#define BIT_MASK_TID_TC 0xff
+/* TS = Traffic Stream,  TID8~15 represents TS */
+#define BIT_MASK_TID_TS 0xff00
+#define ALL_TID_TC_SUPPORTED_UAPSD 0xff
 
 struct	qos_priv	{
-	
-	unsigned int	  qos_option;	//bit mask option: u-apsd, s-apsd, ts, block ack...		
 
-};
+	unsigned int	  qos_option;	/* bit mask option: u-apsd, s-apsd, ts, block ack...		 */
 
+#ifdef CONFIG_WMMPS_STA
+	/* uapsd (unscheduled automatic power-save delivery) = a kind of wmmps */
+	u8 uapsd_max_sp_len;
+	/* declare uapsd_tid as a bitmap for the uapsd setting of TID 0~15 */
+	u16 uapsd_tid;
+	/* declare uapsd_tid_delivery_enabled as a bitmap for the delivery-enabled setting of TID 0~7 */
+	u8 uapsd_tid_delivery_enabled;
+	/* declare uapsd_tid_trigger_enabled as a bitmap for the trigger-enabled setting of TID 0~7 */
+	u8 uapsd_tid_trigger_enabled;
+	/* declare uapsd_ap_supported to record whether the connected ap  supports uapsd or not */
+	u8 uapsd_ap_supported;
+#endif /* CONFIG_WMMPS_STA */	
+
+};
 
-#endif	//_RTL871X_QOS_H_
 
+#endif /* _RTL871X_QOS_H_ */
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_recv.h
index 9cff2987f341..b615b03af323 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_recv.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,18 +12,17 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_RECV_H_
 #define _RTW_RECV_H_
 
+#define RTW_RX_MSDU_ACT_NONE		0
+#define RTW_RX_MSDU_ACT_INDICATE	BIT0
+#define RTW_RX_MSDU_ACT_FORWARD		BIT1
+
 #ifdef PLATFORM_OS_XP
 	#ifdef CONFIG_SDIO_HCI
-		#define NR_RECVBUFF 1024//512//128
+		#define NR_RECVBUFF 1024/* 512 */ /* 128 */
 	#else
 		#define NR_RECVBUFF (16)
 	#endif
@@ -32,7 +32,7 @@
 	#else
 		#define NR_RECVBUFF (4)
 	#endif
-#else //PLATFORM_LINUX /PLATFORM_BSD
+#else /* PLATFORM_LINUX /PLATFORM_BSD */
 
 	#ifdef CONFIG_SINGLE_RECV_BUF
 		#define NR_RECVBUFF (1)
@@ -40,17 +40,27 @@
 		#if defined(CONFIG_GSPI_HCI)
 			#define NR_RECVBUFF (32)
 		#elif defined(CONFIG_SDIO_HCI)
-			#define NR_RECVBUFF (8)	
+			#define NR_RECVBUFF (8)
 		#else
 			#define NR_RECVBUFF (8)
-		#endif	
-	#endif //CONFIG_SINGLE_RECV_BUF
+		#endif
+	#endif /* CONFIG_SINGLE_RECV_BUF */
 	#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
 		#define NR_PREALLOC_RECV_SKB (rtw_rtkm_get_nr_recv_skb()>>1)
 	#else /*!CONFIG_PREALLOC_RX_SKB_BUFFER */
 		#define NR_PREALLOC_RECV_SKB 8
 	#endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
 
+	#ifdef CONFIG_RTW_NAPI
+		#define RTL_NAPI_WEIGHT (32)
+	#endif
+#endif
+
+#if defined(CONFIG_RTL8821C) && defined(CONFIG_SDIO_HCI) && defined(CONFIG_RECV_THREAD_MODE)
+	#ifdef NR_RECVBUFF
+	#undef NR_RECVBUFF
+	#define NR_RECVBUFF (32)
+	#endif
 #endif
 
 #define NR_RECVFRAME 256
@@ -58,12 +68,12 @@
 #define RXFRAME_ALIGN	8
 #define RXFRAME_ALIGN_SZ	(1<<RXFRAME_ALIGN)
 
-#define DRVINFO_SZ	4 // unit is 8bytes
+#define DRVINFO_SZ	4 /* unit is 8bytes */
 
 #define MAX_RXFRAME_CNT	512
 #define MAX_RX_NUMBLKS		(32)
 #define RECVFRAME_HDR_ALIGN 128
-#define MAX_CONTINUAL_NORXPACKET_COUNT 1    /*  In MAX_CONTINUAL_NORXPACKET_COUNT*2 sec  , no rx traffict would issue DELBA*/
+#define MAX_CONTINUAL_NORXPACKET_COUNT 4    /*  In MAX_CONTINUAL_NORXPACKET_COUNT*2 sec  , no rx traffict would issue DELBA*/
 
 #define PHY_RSSI_SLID_WIN_MAX				100
 #define PHY_LINKQUALITY_SLID_WIN_MAX		20
@@ -80,24 +90,22 @@ static u8 SNAP_ETH_TYPE_IPX[2] = {0x81, 0x37};
 static u8 SNAP_ETH_TYPE_APPLETALK_AARP[2] = {0x80, 0xf3};
 static u8 SNAP_ETH_TYPE_APPLETALK_DDP[2] = {0x80, 0x9b};
 static u8 SNAP_ETH_TYPE_TDLS[2] = {0x89, 0x0d};
-static u8 SNAP_HDR_APPLETALK_DDP[3] = {0x08, 0x00, 0x07}; // Datagram Delivery Protocol
+static u8 SNAP_HDR_APPLETALK_DDP[3] = {0x08, 0x00, 0x07}; /* Datagram Delivery Protocol */
 
 static u8 oui_8021h[] = {0x00, 0x00, 0xf8};
-static u8 oui_rfc1042[]= {0x00,0x00,0x00};
+static u8 oui_rfc1042[] = {0x00, 0x00, 0x00};
 
 #define MAX_SUBFRAME_COUNT	64
-static u8 rtw_rfc1042_header[] =
-{ 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };
+static u8 rtw_rfc1042_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };
 /* Bridge-Tunnel header (for EtherTypes ETH_P_AARP and ETH_P_IPX) */
-static u8 rtw_bridge_tunnel_header[] =
-{ 0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8 };
+static u8 rtw_bridge_tunnel_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8 };
 
-//for Rx reordering buffer control
-struct recv_reorder_ctrl
-{
+/* for Rx reordering buffer control */
+struct recv_reorder_ctrl {
 	_adapter	*padapter;
+	u8 tid;
 	u8 enable;
-	u16 indicate_seq;//=wstart_b, init_value=0xffff
+	u16 indicate_seq;/* =wstart_b, init_value=0xffff */
 	u16 wend_b;
 	u8 wsize_b;
 	u8 ampdu_size;
@@ -107,131 +115,67 @@ struct recv_reorder_ctrl
 };
 
 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;
-*/
+	u16	tid_rxseq[16];
+	u8 iv[16][8];
+	u8 last_tid;
+#if 0
+	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;
+#endif
 };
 
 
 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
+	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	
+	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	 */
 };
-/*
-typedef struct _ODM_Phy_Status_Info_
-{
-	//
-	// Be care, if you want to add any element please insert between 
-	// RxPWDBAll & SignalStrength.
-	//
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN))
-	u4Byte		RxPWDBAll;	
-#else
-	u1Byte		RxPWDBAll;	
-#endif
-
-	u1Byte		SignalQuality;	 		// in 0-100 index. 
-	s1Byte		RxMIMOSignalQuality[4];	//per-path's EVM
-	u1Byte		RxMIMOEVMdbm[4]; 		//per-path's EVM dbm
-
-	u1Byte		RxMIMOSignalStrength[4];// in 0~100 index
-
-	u2Byte		Cfo_short[4]; 			// per-path's Cfo_short
-	u2Byte		Cfo_tail[4];			// per-path's Cfo_tail
-	
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))
-	s1Byte		RxPower;				// in dBm Translate from PWdB
-	s1Byte		RecvSignalPower;		// Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures.
-	u1Byte		BTRxRSSIPercentage;	
-	u1Byte		SignalStrength; 		// in 0-100 index.
- 
-	u1Byte		RxPwr[4];				//per-path's pwdb
-#endif
-	u1Byte		RxSNR[4];				//per-path's SNR	
-	u1Byte		BandWidth;
-	u1Byte		btCoexPwrAdjust;
-}ODM_PHY_INFO_T,*PODM_PHY_INFO_T;
-*/
 
-struct phy_info
-{		
-	u8			RxPWDBAll;
-	u8			SignalQuality;				/* in 0-100 index. */
-	s8			RxMIMOSignalQuality[4];		/* per-path's EVM */
-	u8			RxMIMOEVMdbm[4];			/* per-path's EVM dbm */
-	u8			RxMIMOSignalStrength[4];	/* in 0~100 index */
-	s16			Cfo_short[4];				/* per-path's Cfo_short */
-	s16			Cfo_tail[4];					/* per-path's Cfo_tail */
-	s8			RxPower;					/* in dBm Translate from PWdB */
-	s8			RecvSignalPower;			/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. */
-	u8			BTRxRSSIPercentage;	
-	u8			SignalStrength;				/* in 0-100 index. */
-	s8			RxPwr[4];					/* per-path's pwdb */
-	s8			RxSNR[4];
-#if (RTL8822B_SUPPORT == 1)
-	u8			RxCount:2;
-	u8			BandWidth:2;
-	u8			rxsc:4;
-#else
-	u8			BandWidth;
-#endif
-	u8			btCoexPwrAdjust;
-#if (RTL8822B_SUPPORT == 1)
-	u8			channel;						/* channel number---*/
-	BOOLEAN		bMuPacket;					/* is MU packet or not---*/
-	BOOLEAN		bBeamformed;
-#endif
-};
-
-#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
-struct rx_raw_rssi
-{
+struct rx_raw_rssi {
 	u8 data_rate;
 	u8 pwdball;
 	s8 pwr_all;
-	
+
 	u8 mimo_signal_strength[4];/* in 0~100 index */
 	u8 mimo_signal_quality[4];
-	
+
 	s8 ofdm_pwr[4];
 	u8 ofdm_snr[4];
-
 };
-#endif
+
+
+#include "cmn_info/rtw_sta_info.h"
 
 struct rx_pkt_attrib	{
 	u16	pkt_len;
 	u8	physt;
 	u8	drvinfo_sz;
 	u8	shift_sz;
-	u8	hdrlen; //the WLAN Header Len
-	u8 	to_fr_ds;
-	u8 	amsdu;
+	u8	hdrlen; /* the WLAN Header Len */
+	u8	to_fr_ds;
+	u8	amsdu;
 	u8	qos;
 	u8	priority;
 	u8	pw_save;
@@ -240,9 +184,9 @@ struct rx_pkt_attrib	{
 	u8	frag_num;
 	u8	mfrag;
 	u8	order;
-	u8	privacy; //in frame_ctrl field
+	u8	privacy; /* in frame_ctrl field */
 	u8	bdecrypted;
-	u8	encrypt; //when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith
+	u8	encrypt; /* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith */
 	u8	iv_len;
 	u8	icv_len;
 	u8	crc_err;
@@ -250,69 +194,84 @@ struct rx_pkt_attrib	{
 
 	u16	eth_type;
 
-	u8 	dst[ETH_ALEN];
-	u8 	src[ETH_ALEN];
-	u8 	ta[ETH_ALEN];
-	u8 	ra[ETH_ALEN];
-	u8 	bssid[ETH_ALEN];
-	
+	u8	dst[ETH_ALEN];
+	u8	src[ETH_ALEN];
+	u8	ta[ETH_ALEN];
+	u8	ra[ETH_ALEN];
+	u8	bssid[ETH_ALEN];
+#ifdef CONFIG_RTW_MESH
+	u8	msa[ETH_ALEN]; /* mesh sa */
+	u8	mda[ETH_ALEN]; /* mesh da */
+	u8 mesh_ctrl_present;
+	u8	mesh_ctrl_len; /* length of mesh control field */
+#endif
+
 	u8	ack_policy;
-	
-//#ifdef CONFIG_TCP_CSUM_OFFLOAD_RX
-	u8	tcpchk_valid; // 0: invalid, 1: valid
-	u8	ip_chkrpt; //0: incorrect, 1: correct
-	u8	tcp_chkrpt; //0: incorrect, 1: correct
-//#endif
-	u8 	key_index;
+
+	u8	key_index;
 
 	u8	data_rate;
+	u8 ch; /* RX channel */
 	u8	bw;
 	u8	stbc;
 	u8	ldpc;
-	u8 	sgi;
-	u8 	pkt_rpt_type;
+	u8	sgi;
+	u8	pkt_rpt_type;
 	u32 tsfl;
-	u32	MacIDValidEntry[2];	// 64 bits present 64 entry.
-
-/*
-	u8	signal_qual;
-	s8	rx_mimo_signal_qual[2];
-	u8	signal_strength;
-	u32	RxPWDBAll;	
-	s32	RecvSignalPower;
-*/
-	struct phy_info phy_info;
+	u32	MacIDValidEntry[2];	/* 64 bits present 64 entry. */
+	u8	ppdu_cnt;
+	u32 	free_cnt;		/* free run counter */
+	struct phydm_phyinfo_struct phy_info;
 };
 
+#ifdef CONFIG_RTW_MESH
+#define RATTRIB_GET_MCTRL_LEN(rattrib) ((rattrib)->mesh_ctrl_len)
+#else
+#define RATTRIB_GET_MCTRL_LEN(rattrib) 0
+#endif
 
-//These definition is used for Rx packet reordering.
-#define SN_LESS(a, b)		(((a-b)&0x800)!=0)
+/* 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_WIN_SIZE	128
-//#define REORDER_ENTRY_NUM	128
-#define REORDER_WAIT_TIME	(50) // (ms)
-
-#define RECVBUFF_ALIGN_SZ 8
+/* #define REORDER_WIN_SIZE	128 */
+/* #define REORDER_ENTRY_NUM	128 */
+#define REORDER_WAIT_TIME	(50) /* (ms) */
 
-#if defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A)
-	#ifdef CONFIG_PCI_HCI
-		#define RXDESC_SIZE 16
-		#define RX_WIFI_INFO_SIZE	24
-	#else
-		#define RXDESC_SIZE	24
-	#endif
+#if defined(CONFIG_PLATFORM_RTK390X) && defined(CONFIG_USB_HCI)
+	#define RECVBUFF_ALIGN_SZ 32
 #else
-#define RXDESC_SIZE	24
+	#define RECVBUFF_ALIGN_SZ 8
 #endif
+
+#ifdef CONFIG_TRX_BD_ARCH
+	#define RX_WIFI_INFO_SIZE	24
+#elif (defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)) && defined(CONFIG_PCI_HCI)
+	#define RXBD_SIZE	sizeof(struct recv_stat)
+#endif
+
+#define RXDESC_SIZE	24
 #define RXDESC_OFFSET RXDESC_SIZE
 
-struct recv_stat
-{
+#ifdef CONFIG_TRX_BD_ARCH
+struct rx_buf_desc {
+	/* RX has exactly one segment */
+#ifdef CONFIG_64BIT_DMA
+	unsigned int dword[4];
+#else
+	unsigned int dword[2];
+#endif
+};
+
+struct recv_stat {
+	unsigned int rxdw[8];
+};
+#else
+struct recv_stat {
 	unsigned int rxdw0;
 
 	unsigned int rxdw1;
 
-#if !((defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A)) && defined(CONFIG_PCI_HCI))  /* exclude 8192ee, 8814ae */
+#if !((defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)) && defined(CONFIG_PCI_HCI))  /* exclude 8192ee, 8814ae, 8822be, 8821ce */
 	unsigned int rxdw2;
 
 	unsigned int rxdw3;
@@ -328,17 +287,25 @@ struct recv_stat
 
 	unsigned int rxdw7;
 #endif
-#endif //if BUF_DESC_ARCH is defined, rx_buf_desc occupy 4 double words
+#endif /* if BUF_DESC_ARCH is defined, rx_buf_desc occupy 4 double words */
 };
+#endif
 
 #define EOR BIT(30)
 
 #ifdef CONFIG_PCI_HCI
-#define PCI_MAX_RX_QUEUE		1// MSDU packet queue, Rx Command Queue
+#define PCI_MAX_RX_QUEUE		1/* MSDU packet queue, Rx Command Queue */
 #define PCI_MAX_RX_COUNT		128
+#ifdef CONFIG_TRX_BD_ARCH
+#define RX_BD_NUM				PCI_MAX_RX_COUNT	/* alias */
+#endif
 
 struct rtw_rx_ring {
+#ifdef CONFIG_TRX_BD_ARCH
+	struct rx_buf_desc	*buf_desc;
+#else
 	struct recv_stat	*desc;
+#endif
 	dma_addr_t		dma;
 	unsigned int		idx;
 	struct sk_buff	*rx_buf[PCI_MAX_RX_COUNT];
@@ -353,16 +320,20 @@ accesser of recv_priv: rtw_recv_entry(dispatch / passive level); recv_thread(pas
 
 using enter_critical section to protect
 */
-struct recv_priv
-{
+
+#ifndef DBG_RX_BH_TRACKING
+#define DBG_RX_BH_TRACKING 0
+#endif
+
+struct recv_priv {
 	_lock	lock;
 
 #ifdef CONFIG_RECV_THREAD_MODE
 	_sema	recv_sema;
-	_sema	terminate_recvthread_sema;
+
 #endif
 
-	//_queue	blk_strms[MAX_RX_NUMBLKS];    // keeping the block ack frame until return ack
+	/* _queue	blk_strms[MAX_RX_NUMBLKS];    */ /* keeping the block ack frame until return ack */
 	_queue	free_recv_queue;
 	_queue	recv_pending_queue;
 	_queue	uc_swdec_pending_queue;
@@ -373,6 +344,17 @@ struct recv_priv
 
 	uint free_recvframe_cnt;
 
+	#if DBG_RX_BH_TRACKING
+	u32 rx_bh_stage;
+	u32 rx_bh_buf_dq_cnt;
+	void *rx_bh_lbuf;
+	void *rx_bh_cbuf;
+	void *rx_bh_cbuf_data;
+	u32 rx_bh_cbuf_dlen;
+	u32 rx_bh_cbuf_pos;
+	void *rx_bh_cframe;
+	#endif
+
 	_adapter	*adapter;
 
 #ifdef PLATFORM_WINDOWS
@@ -382,22 +364,32 @@ struct recv_priv
 #ifdef PLATFORM_OS_XP
 	PMDL	pbytecnt_mdl;
 #endif
-	uint	counter; //record the number that up-layer will return to drv; only when counter==0 can we  release recv_priv
-	NDIS_EVENT 	recv_resource_evt ;
+	uint	counter; /* record the number that up-layer will return to drv; only when counter==0 can we  release recv_priv */
+	NDIS_EVENT	recv_resource_evt ;
 #endif
 
-	u32	bIsAnyNonBEPkts;
+
+	u32 is_any_non_be_pkts;
+
 	u64	rx_bytes;
 	u64	rx_pkts;
 	u64	rx_drop;
 
+	u64 dbg_rx_drop_count;
+	u64 dbg_rx_ampdu_drop_count;
+	u64 dbg_rx_ampdu_forced_indicate_count;
+	u64 dbg_rx_ampdu_loss_count;
+	u64 dbg_rx_dup_mgt_frame_drop_count;
+	u64 dbg_rx_ampdu_window_shift_cnt;
+	u64 dbg_rx_conflic_mac_addr_cnt;
+
 	uint  rx_icv_err;
 	uint  rx_largepacket_crcerr;
 	uint  rx_smallpacket_crcerr;
 	uint  rx_middlepacket_crcerr;
 
 #ifdef CONFIG_USB_HCI
-	//u8 *pallocated_urb_buf;
+	/* u8 *pallocated_urb_buf; */
 	_sema allrxreturnevt;
 	uint	ff_hwaddr;
 	ATOMIC_T	rx_pending_cnt;
@@ -408,95 +400,121 @@ struct recv_priv
 #endif
 
 	u8	*int_in_buf;
-#endif //CONFIG_USB_INTERRUPT_IN_PIPE
+#endif /* CONFIG_USB_INTERRUPT_IN_PIPE */
 
 #endif
 #if defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
 #ifdef PLATFORM_FREEBSD
 	struct task irq_prepare_beacon_tasklet;
 	struct task recv_tasklet;
-#else //PLATFORM_FREEBSD
+#else /* PLATFORM_FREEBSD */
 	struct tasklet_struct irq_prepare_beacon_tasklet;
 	struct tasklet_struct recv_tasklet;
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 	struct sk_buff_head free_recv_skb_queue;
 	struct sk_buff_head rx_skb_queue;
+#ifdef CONFIG_RTW_NAPI
+		struct sk_buff_head rx_napi_skb_queue;
+#endif 
 #ifdef CONFIG_RX_INDICATE_QUEUE
 	struct task rx_indicate_tasklet;
 	struct ifqueue rx_indicate_queue;
-#endif	// CONFIG_RX_INDICATE_QUEUE
+#endif /* CONFIG_RX_INDICATE_QUEUE */
 
-#endif //defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
+#endif /* defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD) */
 
 	u8 *pallocated_recv_buf;
-	u8 *precv_buf;    // 4 alignment
+	u8 *precv_buf;    /* 4 alignment */
 	_queue	free_recv_buf_queue;
 	u32	free_recv_buf_queue_cnt;
 
-#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_USB_HCI) 
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_USB_HCI)
 	_queue	recv_buf_pending_queue;
 #endif
 
 #ifdef CONFIG_PCI_HCI
-	// Rx
+	/* Rx */
 	struct rtw_rx_ring	rx_ring[PCI_MAX_RX_QUEUE];
-	int 	rxringcount;
+	int rxringcount;	/* size should be PCI_MAX_RX_QUEUE */
 	u16	rxbuffersize;
 #endif
 
-	//For display the phy informatiom
-	u8 is_signal_dbg;	// for debug
-	u8 signal_strength_dbg;	// for debug
-	
+	/* For display the phy informatiom */
+	u8 is_signal_dbg;	/* for debug */
+	u8 signal_strength_dbg;	/* for debug */
+
 	u8 signal_strength;
 	u8 signal_qual;
-	s8 rssi;	//translate_percentage_to_dbm(ptarget_wlan->network.PhyInfo.SignalStrength);
-	#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
+	s8 rssi;	/* translate_percentage_to_dbm(ptarget_wlan->network.PhyInfo.SignalStrength); */
 	struct rx_raw_rssi raw_rssi_info;
-	#endif
-	//s8 rxpwdb;	
-	s16 noise;	
-	//int RxSNRdB[2];
-	//s8 RxRssi[2];
-	//int FalseAlmCnt_all;
-	
+	/* s8 rxpwdb;	 */
+	/* int RxSNRdB[2]; */
+	/* s8 RxRssi[2]; */
+	/* int FalseAlmCnt_all; */
+
 
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	_timer signal_stat_timer;
 	u32 signal_stat_sampling_interval;
-	//u32 signal_stat_converging_constant;
+	/* u32 signal_stat_converging_constant; */
 	struct signal_stat signal_qual_data;
 	struct signal_stat signal_strength_data;
-#else //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 	struct smooth_rssi_data signal_qual_data;
 	struct smooth_rssi_data signal_strength_data;
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
-	u16 sink_udpport,pre_rtp_rxseq,cur_rtp_rxseq;
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+	u16 sink_udpport, pre_rtp_rxseq, cur_rtp_rxseq;
+
+	BOOLEAN store_law_data_flag;
 };
 
+#define RX_BH_STG_UNKNOWN		0
+#define RX_BH_STG_HDL_ENTER		1
+#define RX_BH_STG_HDL_EXIT		2
+#define RX_BH_STG_NEW_BUF		3
+#define RX_BH_STG_NEW_FRAME		4
+#define RX_BH_STG_NORMAL_RX		5
+#define RX_BH_STG_NORMAL_RX_END	6
+#define RX_BH_STG_C2H			7
+#define RX_BH_STG_C2H_END		8
+
+#if DBG_RX_BH_TRACKING
+void rx_bh_tk_set_stage(struct recv_priv *recv, u32 s);
+void rx_bh_tk_set_buf(struct recv_priv *recv, void *buf, void *data, u32 dlen);
+void rx_bh_tk_set_buf_pos(struct recv_priv *recv, void *pos);
+void rx_bh_tk_set_frame(struct recv_priv *recv, void *frame);
+void dump_rx_bh_tk(void *sel, struct recv_priv *recv);
+#else
+#define rx_bh_tk_set_stage(recv, s) do {} while (0)
+#define rx_bh_tk_set_buf(recv, buf, data, dlen) do {} while (0)
+#define rx_bh_tk_set_buf_pos(recv, pos) do {} while (0)
+#define rx_bh_tk_set_frame(recv, frame) do {} while (0)
+#define dump_rx_bh_tk(sel, recv) do {} while (0)
+#endif
+
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 #define rtw_set_signal_stat_timer(recvpriv) _set_timer(&(recvpriv)->signal_stat_timer, (recvpriv)->signal_stat_sampling_interval)
-#endif //CONFIG_NEW_SIGNAL_STAT_PROCESS
+#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
 struct sta_recv_priv {
 
 	_lock	lock;
 	sint	option;
 
-	//_queue	blk_strms[MAX_RX_NUMBLKS];
-	_queue defrag_q;	 //keeping the fragment frame until defrag
+	/* _queue	blk_strms[MAX_RX_NUMBLKS]; */
+	_queue defrag_q;	 /* keeping the fragment frame until defrag */
 
 	struct	stainfo_rxcache rxcache;
+	u16	bmc_tid_rxseq[16];
 
-	//uint	sta_rx_bytes;
-	//uint	sta_rx_pkts;
-	//uint	sta_rx_fail;
+	/* uint	sta_rx_bytes; */
+	/* uint	sta_rx_pkts; */
+	/* uint	sta_rx_fail; */
 
 };
 
 
-struct recv_buf
-{
+struct recv_buf {
 	_list list;
 
 	_lock recvbuf_lock;
@@ -516,31 +534,30 @@ struct recv_buf
 
 #ifdef CONFIG_USB_HCI
 
-	#if defined(PLATFORM_OS_XP)||defined(PLATFORM_LINUX)||defined(PLATFORM_FREEBSD)
+#if defined(PLATFORM_OS_XP) || defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
 	PURB	purb;
 	dma_addr_t dma_transfer_addr;	/* (in) dma addr for transfer_buffer */
 	u32 alloc_sz;
-	#endif
+#endif
 
-	#ifdef PLATFORM_OS_XP
+#ifdef PLATFORM_OS_XP
 	PIRP		pirp;
-	#endif
+#endif
 
-	#ifdef PLATFORM_OS_CE
+#ifdef PLATFORM_OS_CE
 	USB_TRANSFER	usb_transfer_read_port;
-	#endif
+#endif
 
 	u8  irp_pending;
 	int  transfer_len;
 
 #endif
 
-#ifdef PLATFORM_LINUX
-	_pkt	*pskb;
-#endif
-#ifdef PLATFORM_FREEBSD //skb solution
+#if defined(PLATFORM_LINUX)
+	_pkt *pskb;
+#elif defined(PLATFORM_FREEBSD) /* skb solution */
 	struct sk_buff *pskb;
-#endif //PLATFORM_FREEBSD //skb solution
+#endif
 };
 
 
@@ -559,16 +576,9 @@ struct recv_buf
 	len = (unsigned int )(tail - data);
 
 */
-struct recv_frame_hdr
-{
+struct recv_frame_hdr {
 	_list	list;
-#ifndef CONFIG_BSD_RX_USE_MBUF
-	struct sk_buff	 *pkt;
-	struct sk_buff	 *pkt_newalloc;
-#else // CONFIG_BSD_RX_USE_MBUF
-	_pkt	*pkt;
-	_pkt *pkt_newalloc;
-#endif // CONFIG_BSD_RX_USE_MBUF
+	_pkt *pkt;
 
 	_adapter  *adapter;
 
@@ -587,10 +597,10 @@ struct recv_frame_hdr
 	void *precvbuf;
 
 
-	//
+	/*  */
 	struct sta_info *psta;
 
-	//for A-MPDU Rx reordering buffer control
+	/* for A-MPDU Rx reordering buffer control */
 	struct recv_reorder_ctrl *preorder_ctrl;
 
 #ifdef CONFIG_WAPI_SUPPORT
@@ -604,31 +614,31 @@ struct recv_frame_hdr
 };
 
 
-union recv_frame{
+union recv_frame {
 
-	union{
+	union {
 		_list list;
 		struct recv_frame_hdr hdr;
-		uint mem[RECVFRAME_HDR_ALIGN>>2];
-	}u;
+		uint mem[RECVFRAME_HDR_ALIGN >> 2];
+	} u;
 
-	//uint mem[MAX_RXSZ>>2];
+	/* uint mem[MAX_RXSZ>>2]; */
 
 };
 
 bool rtw_rframe_del_wfd_ie(union recv_frame *rframe, u8 ies_offset);
 
-typedef enum _RX_PACKET_TYPE{
-	NORMAL_RX,//Normal rx packet
-	TX_REPORT1,//CCX
-	TX_REPORT2,//TX RPT
-	HIS_REPORT,// USB HISR RPT
+typedef enum _RX_PACKET_TYPE {
+	NORMAL_RX,/* Normal rx packet */
+	TX_REPORT1,/* CCX */
+	TX_REPORT2,/* TX RPT */
+	HIS_REPORT,/* USB HISR RPT */
 	C2H_PACKET
-}RX_PACKET_TYPE, *PRX_PACKET_TYPE;
+} RX_PACKET_TYPE, *PRX_PACKET_TYPE;
 
-extern union recv_frame *_rtw_alloc_recvframe (_queue *pfree_recv_queue);  //get a free recv_frame from pfree_recv_queue
-extern union recv_frame *rtw_alloc_recvframe (_queue *pfree_recv_queue);  //get a free recv_frame from pfree_recv_queue
-extern void rtw_init_recvframe(union recv_frame *precvframe ,struct recv_priv *precvpriv);
+extern union recv_frame *_rtw_alloc_recvframe(_queue *pfree_recv_queue);   /* get a free recv_frame from pfree_recv_queue */
+extern union recv_frame *rtw_alloc_recvframe(_queue *pfree_recv_queue);   /* get a free recv_frame from pfree_recv_queue */
+extern void rtw_init_recvframe(union recv_frame *precvframe , struct recv_priv *precvpriv);
 extern int	 rtw_free_recvframe(union recv_frame *precvframe, _queue *pfree_recv_queue);
 
 #define rtw_dequeue_recvframe(queue) rtw_alloc_recvframe(queue)
@@ -640,9 +650,11 @@ u32 rtw_free_uc_swdec_pending_queue(_adapter *adapter);
 
 sint rtw_enqueue_recvbuf_to_head(struct recv_buf *precvbuf, _queue *queue);
 sint rtw_enqueue_recvbuf(struct recv_buf *precvbuf, _queue *queue);
-struct recv_buf *rtw_dequeue_recvbuf (_queue *queue);
+struct recv_buf *rtw_dequeue_recvbuf(_queue *queue);
 
+#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
 void rtw_reordering_ctrl_timeout_handler(void *pcontext);
+#endif
 
 void rx_query_phy_status(union recv_frame *rframe, u8 *phy_stat);
 int rtw_inc_and_chk_continual_no_rx_packet(struct sta_info *sta, int tid_index);
@@ -654,8 +666,8 @@ thread_return rtw_recv_thread(thread_context context);
 
 __inline static u8 *get_rxmem(union recv_frame *precvframe)
 {
-	//always return rx_head...
-	if(precvframe==NULL)
+	/* always return rx_head... */
+	if (precvframe == NULL)
 		return NULL;
 
 	return precvframe->u.hdr.rx_head;
@@ -671,8 +683,8 @@ __inline static u8 *get_rx_status(union recv_frame *precvframe)
 __inline static u8 *get_recvframe_data(union recv_frame *precvframe)
 {
 
-	//alwasy return rx_data
-	if(precvframe==NULL)
+	/* alwasy return rx_data */
+	if (precvframe == NULL)
 		return NULL;
 
 	return precvframe->u.hdr.rx_data;
@@ -681,26 +693,25 @@ __inline static u8 *get_recvframe_data(union recv_frame *precvframe)
 
 __inline static u8 *recvframe_push(union recv_frame *precvframe, sint sz)
 {
-	// append data before rx_data
+	/* append data before rx_data */
 
 	/* add data to the start of recv_frame
- *
- *      This function extends the used data area of the recv_frame at the buffer
- *      start. rx_data must be still larger than rx_head, after pushing.
- */
+	*
+	*      This function extends the used data area of the recv_frame at the buffer
+	*      start. rx_data must be still larger than rx_head, after pushing.
+	*/
 
-	if(precvframe==NULL)
+	if (precvframe == NULL)
 		return NULL;
 
 
 	precvframe->u.hdr.rx_data -= sz ;
-	if( precvframe->u.hdr.rx_data < precvframe->u.hdr.rx_head )
-	{
+	if (precvframe->u.hdr.rx_data < precvframe->u.hdr.rx_head) {
 		precvframe->u.hdr.rx_data += sz ;
 		return NULL;
 	}
 
-	precvframe->u.hdr.len +=sz;
+	precvframe->u.hdr.len += sz;
 
 	return precvframe->u.hdr.rx_data;
 
@@ -709,24 +720,23 @@ __inline static u8 *recvframe_push(union recv_frame *precvframe, sint sz)
 
 __inline static u8 *recvframe_pull(union recv_frame *precvframe, sint sz)
 {
-	// rx_data += sz; move rx_data sz bytes  hereafter
+	/* rx_data += sz; move rx_data sz bytes  hereafter */
 
-	//used for extract sz bytes from rx_data, update rx_data and return the updated rx_data to the caller
+	/* used for extract sz bytes from rx_data, update rx_data and return the updated rx_data to the caller */
 
 
-	if(precvframe==NULL)
+	if (precvframe == NULL)
 		return NULL;
 
 
 	precvframe->u.hdr.rx_data += sz;
 
-	if(precvframe->u.hdr.rx_data > precvframe->u.hdr.rx_tail)
-	{
+	if (precvframe->u.hdr.rx_data > precvframe->u.hdr.rx_tail) {
 		precvframe->u.hdr.rx_data -= sz;
 		return NULL;
 	}
 
-	precvframe->u.hdr.len -=sz;
+	precvframe->u.hdr.len -= sz;
 
 	return precvframe->u.hdr.rx_data;
 
@@ -734,28 +744,27 @@ __inline static u8 *recvframe_pull(union recv_frame *precvframe, sint sz)
 
 __inline static u8 *recvframe_put(union recv_frame *precvframe, sint sz)
 {
-	// rx_tai += sz; move rx_tail sz bytes  hereafter
+	/* rx_tai += sz; move rx_tail sz bytes  hereafter */
 
-	//used for append sz bytes from ptr to rx_tail, update rx_tail and return the updated rx_tail to the caller
-	//after putting, rx_tail must be still larger than rx_end.
- 	unsigned char * prev_rx_tail;
+	/* used for append sz bytes from ptr to rx_tail, update rx_tail and return the updated rx_tail to the caller */
+	/* after putting, rx_tail must be still larger than rx_end. */
+	unsigned char *prev_rx_tail;
 
-	/* DBG_871X("recvframe_put: len=%d\n", sz); */
+	/* RTW_INFO("recvframe_put: len=%d\n", sz); */
 
-	if(precvframe==NULL)
+	if (precvframe == NULL)
 		return NULL;
 
 	prev_rx_tail = precvframe->u.hdr.rx_tail;
 
 	precvframe->u.hdr.rx_tail += sz;
 
-	if(precvframe->u.hdr.rx_tail > precvframe->u.hdr.rx_end)
-	{
+	if (precvframe->u.hdr.rx_tail > precvframe->u.hdr.rx_end) {
 		precvframe->u.hdr.rx_tail -= sz;
 		return NULL;
 	}
 
-	precvframe->u.hdr.len +=sz;
+	precvframe->u.hdr.len += sz;
 
 	return precvframe->u.hdr.rx_tail;
 
@@ -765,23 +774,22 @@ __inline static u8 *recvframe_put(union recv_frame *precvframe, sint sz)
 
 __inline static u8 *recvframe_pull_tail(union recv_frame *precvframe, sint sz)
 {
-	// rmv data from rx_tail (by yitsen)
+	/* rmv data from rx_tail (by yitsen) */
 
-	//used for extract sz bytes from rx_end, update rx_end and return the updated rx_end to the caller
-	//after pulling, rx_end must be still larger than rx_data.
+	/* used for extract sz bytes from rx_end, update rx_end and return the updated rx_end to the caller */
+	/* after pulling, rx_end must be still larger than rx_data. */
 
-	if(precvframe==NULL)
+	if (precvframe == NULL)
 		return NULL;
 
 	precvframe->u.hdr.rx_tail -= sz;
 
-	if(precvframe->u.hdr.rx_tail < precvframe->u.hdr.rx_data)
-	{
+	if (precvframe->u.hdr.rx_tail < precvframe->u.hdr.rx_data) {
 		precvframe->u.hdr.rx_tail += sz;
 		return NULL;
 	}
 
-	precvframe->u.hdr.len -=sz;
+	precvframe->u.hdr.len -= sz;
 
 	return precvframe->u.hdr.rx_tail;
 
@@ -789,11 +797,11 @@ __inline static u8 *recvframe_pull_tail(union recv_frame *precvframe, sint sz)
 
 
 
-__inline static _buffer * get_rxbuf_desc(union recv_frame *precvframe)
+__inline static _buffer *get_rxbuf_desc(union recv_frame *precvframe)
 {
-	_buffer * buf_desc;
+	_buffer *buf_desc;
 
-	if(precvframe==NULL)
+	if (precvframe == NULL)
 		return NULL;
 #ifdef PLATFORM_WINDOWS
 	NdisQueryPacket(precvframe->u.hdr.pkt, NULL, NULL, &buf_desc, NULL);
@@ -805,48 +813,48 @@ __inline static _buffer * get_rxbuf_desc(union recv_frame *precvframe)
 
 __inline static union recv_frame *rxmem_to_recvframe(u8 *rxmem)
 {
-	//due to the design of 2048 bytes alignment of recv_frame, we can reference the union recv_frame
-	//from any given member of recv_frame.
-	// rxmem indicates the any member/address in recv_frame
+	/* due to the design of 2048 bytes alignment of recv_frame, we can reference the union recv_frame */
+	/* from any given member of recv_frame. */
+	/* rxmem indicates the any member/address in recv_frame */
 
-	return (union recv_frame*)(((SIZE_PTR)rxmem >> RXFRAME_ALIGN) << RXFRAME_ALIGN);
+	return (union recv_frame *)(((SIZE_PTR)rxmem >> RXFRAME_ALIGN) << RXFRAME_ALIGN);
 
 }
 
 __inline static union recv_frame *pkt_to_recvframe(_pkt *pkt)
 {
 
-	u8 * buf_star;
-	union recv_frame * precv_frame;
+	u8 *buf_star;
+	union recv_frame *precv_frame;
 #ifdef PLATFORM_WINDOWS
-	_buffer * buf_desc;
+	_buffer *buf_desc;
 	uint len;
 
 	NdisQueryPacket(pkt, NULL, NULL, &buf_desc, &len);
 	NdisQueryBufferSafe(buf_desc, &buf_star, &len, HighPagePriority);
 #endif
-	precv_frame = rxmem_to_recvframe((unsigned char*)buf_star);
+	precv_frame = rxmem_to_recvframe((unsigned char *)buf_star);
 
 	return precv_frame;
 }
 
 __inline static u8 *pkt_to_recvmem(_pkt *pkt)
 {
-	// return the rx_head
+	/* return the rx_head */
 
-	union recv_frame * precv_frame = pkt_to_recvframe(pkt);
+	union recv_frame *precv_frame = pkt_to_recvframe(pkt);
 
-	return 	precv_frame->u.hdr.rx_head;
+	return	precv_frame->u.hdr.rx_head;
 
 }
 
 __inline static u8 *pkt_to_recvdata(_pkt *pkt)
 {
-	// return the rx_data
+	/* return the rx_data */
 
-	union recv_frame * precv_frame =pkt_to_recvframe(pkt);
+	union recv_frame *precv_frame = pkt_to_recvframe(pkt);
 
-	return 	precv_frame->u.hdr.rx_data;
+	return	precv_frame->u.hdr.rx_data;
 
 }
 
@@ -859,12 +867,12 @@ __inline static sint get_recvframe_len(union recv_frame *precvframe)
 
 __inline static s32 translate_percentage_to_dbm(u32 SignalStrengthIndex)
 {
-	s32	SignalPower; // in dBm.
+	s32	SignalPower; /* in dBm. */
 
 #ifdef CONFIG_SIGNAL_SCALE_MAPPING
 	/* Translate to dBm (x=0.5y-95). */
-	SignalPower = (s32)((SignalStrengthIndex + 1) >> 1); 
-	SignalPower -= 95; 
+	SignalPower = (s32)((SignalStrengthIndex + 1) >> 1);
+	SignalPower -= 95;
 #else
 	/* Translate to dBm (x=y-100) */
 	SignalPower = SignalStrengthIndex - 100;
@@ -873,12 +881,14 @@ __inline static s32 translate_percentage_to_dbm(u32 SignalStrengthIndex)
 	return SignalPower;
 }
 
-
 struct sta_info;
 
 extern void _rtw_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv);
 
 extern void  mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame);
 
-#endif
+u8 adapter_allow_bmc_data_rx(_adapter *adapter);
+s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status);
+void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info *sta);
 
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rf.h
index f363aa9a8c7c..58353789f730 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,39 +12,16 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef	__RTW_RF_H_
 #define __RTW_RF_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
 
-#define RTL8711_RF_MAX_SENS 6
-#define RTL8711_RF_DEF_SENS 4
-
-/*
- * We now define the following channels as the max channels in each channel plan.
- * 2G, total 14 chnls
- * {1,2,3,4,5,6,7,8,9,10,11,12,13,14}
- * 5G, total 24 chnls
- * {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140,149,153,157,161,165} */
-#define	MAX_CHANNEL_NUM_2G				14
-#define	MAX_CHANNEL_NUM_5G				24
-#define	MAX_CHANNEL_NUM					38/* 14+24 */
-
 #define CENTER_CH_2G_40M_NUM	9
 #define CENTER_CH_2G_NUM		14
 #define CENTER_CH_5G_20M_NUM	28	/* 20M center channels */
@@ -52,6 +30,10 @@
 #define CENTER_CH_5G_160M_NUM	3	/* 160M center channels */
 #define CENTER_CH_5G_ALL_NUM	(CENTER_CH_5G_20M_NUM + CENTER_CH_5G_40M_NUM + CENTER_CH_5G_80M_NUM)
 
+#define	MAX_CHANNEL_NUM_2G	CENTER_CH_2G_NUM
+#define	MAX_CHANNEL_NUM_5G	CENTER_CH_5G_20M_NUM
+#define	MAX_CHANNEL_NUM		(MAX_CHANNEL_NUM_2G + MAX_CHANNEL_NUM_5G)
+
 extern u8 center_ch_2g[CENTER_CH_2G_NUM];
 extern u8 center_ch_2g_40m[CENTER_CH_2G_40M_NUM];
 
@@ -73,24 +55,6 @@ u8 rtw_get_op_chs_by_cch_bw(u8 cch, u8 bw, u8 **op_chs, u8 *op_ch_num);
 
 u8 rtw_get_ch_group(u8 ch, u8 *group, u8 *cck_group);
 
-/* #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;
-};
-
 typedef enum _CAPABILITY {
 	cESS			= 0x0001,
 	cIBSS			= 0x0002,
@@ -116,25 +80,6 @@ enum	_REG_PREAMBLE_MODE {
 	PREAMBLE_SHORT	= 3,
 };
 
-
-enum _RTL8712_RF_MIMO_CONFIG_ {
-	RTL8712_RFCONFIG_1T = 0x10,
-	RTL8712_RFCONFIG_2T = 0x20,
-	RTL8712_RFCONFIG_1R = 0x01,
-	RTL8712_RFCONFIG_2R = 0x02,
-	RTL8712_RFCONFIG_1T1R = 0x11,
-	RTL8712_RFCONFIG_1T2R = 0x12,
-	RTL8712_RFCONFIG_TURBO = 0x92,
-	RTL8712_RFCONFIG_2T2R = 0x22
-};
-
-typedef enum _RF_PATH {
-	RF_PATH_A = 0,
-	RF_PATH_B = 1,
-	RF_PATH_C = 2,
-	RF_PATH_D = 3,
-} RF_PATH, *PRF_PATH;
-
 #define rf_path_char(path) (((path) >= RF_PATH_MAX) ? 'X' : 'A' + (path))
 
 /* Bandwidth Offset */
@@ -155,22 +100,12 @@ extern const char *const _band_str[];
 extern const u8 _band_to_band_cap[];
 #define band_to_band_cap(band) (((band) >= BAND_MAX) ? _band_to_band_cap[BAND_MAX] : _band_to_band_cap[(band)])
 
-/* Represent Channel Width in HT Capabilities
- *   */
-typedef enum _CHANNEL_WIDTH {
-	CHANNEL_WIDTH_20 = 0,
-	CHANNEL_WIDTH_40 = 1,
-	CHANNEL_WIDTH_80 = 2,
-	CHANNEL_WIDTH_160 = 3,
-	CHANNEL_WIDTH_80_80 = 4,
-	CHANNEL_WIDTH_MAX = 5,
-} CHANNEL_WIDTH, *PCHANNEL_WIDTH;
 
 extern const char *const _ch_width_str[];
-#define ch_width_str(bw) (((bw) >= CHANNEL_WIDTH_MAX) ? _ch_width_str[CHANNEL_WIDTH_MAX] : _ch_width_str[(bw)])
+#define ch_width_str(bw) (((bw) < CHANNEL_WIDTH_MAX) ? _ch_width_str[(bw)] : "CHANNEL_WIDTH_MAX")
 
 extern const u8 _ch_width_to_bw_cap[];
-#define ch_width_to_bw_cap(bw) (((bw) >= CHANNEL_WIDTH_MAX) ? _ch_width_to_bw_cap[CHANNEL_WIDTH_MAX] : _ch_width_to_bw_cap[(bw)])
+#define ch_width_to_bw_cap(bw) (((bw) < CHANNEL_WIDTH_MAX) ? _ch_width_to_bw_cap[(bw)] : 0)
 
 /*
  * Represent Extention Channel Offset in HT Capabilities
@@ -203,32 +138,29 @@ typedef enum _PROTECTION_MODE {
 	PROTECTION_MODE_FORCE_DISABLE = 2,
 } PROTECTION_MODE, *PPROTECTION_MODE;
 
-typedef	enum _RT_RF_TYPE_DEFINITION {
-	RF_1T2R = 0,
-	RF_2T4R = 1,
-	RF_2T2R = 2,
-	RF_1T1R = 3,
-	RF_2T2R_GREEN = 4,
-	RF_2T3R = 5,
-	RF_3T3R = 6,
-	RF_3T4R	= 7,
-	RF_4T4R	= 8,
+#define RF_TYPE_VALID(rf_type) (rf_type < RF_TYPE_MAX)
 
-	RF_MAX_TYPE = 0xF, /* u1Byte */
-} RT_RF_TYPE_DEF_E;
+extern const u8 _rf_type_to_rf_tx_cnt[];
+#define rf_type_to_rf_tx_cnt(rf_type) (RF_TYPE_VALID(rf_type) ? _rf_type_to_rf_tx_cnt[rf_type] : 0)
+
+extern const u8 _rf_type_to_rf_rx_cnt[];
+#define rf_type_to_rf_rx_cnt(rf_type) (RF_TYPE_VALID(rf_type) ? _rf_type_to_rf_rx_cnt[rf_type] : 0)
 
 int rtw_ch2freq(int chan);
 int rtw_freq2ch(int freq);
 bool rtw_chbw_to_freq_range(u8 ch, u8 bw, u8 offset, u32 *hi, u32 *lo);
 
-#define RTW_MODULE_RTL8821AE_HMC_M2		BIT0 /* RTL8821AE(HMC + M.2) */
-#define RTW_MODULE_RTL8821AU			BIT1 /* RTL8821AU */
-#define RTW_MODULE_RTL8812AENF_NGFF		BIT2 /* RTL8812AENF(8812AE+8761)_NGFF */
-#define RTW_MODULE_RTL8812AEBT_HMC		BIT3 /* RTL8812AEBT(8812AE+8761)_HMC */
-#define RTW_MODULE_RTL8188EE_HMC_M2		BIT4 /* RTL8188EE(HMC + M.2) */
-#define RTW_MODULE_RTL8723BE_HMC_M2		BIT5 /* RTL8723BE(HMC + M.2) */
-#define RTW_MODULE_RTL8723BS_NGFF1216	BIT6 /* RTL8723BS(NGFF1216) */
-#define RTW_MODULE_RTL8192EEBT_HMC_M2	BIT7 /* RTL8192EEBT(8192EE+8761AU)_(HMC + M.2) */
+#define RTW_MODULE_RTL8821AE_HMC_M2		BIT0	/* RTL8821AE(HMC + M.2) */
+#define RTW_MODULE_RTL8821AU			BIT1	/* RTL8821AU */
+#define RTW_MODULE_RTL8812AENF_NGFF		BIT2	/* RTL8812AENF(8812AE+8761)_NGFF */
+#define RTW_MODULE_RTL8812AEBT_HMC		BIT3	/* RTL8812AEBT(8812AE+8761)_HMC */
+#define RTW_MODULE_RTL8188EE_HMC_M2		BIT4	/* RTL8188EE(HMC + M.2) */
+#define RTW_MODULE_RTL8723BE_HMC_M2		BIT5	/* RTL8723BE(HMC + M.2) */
+#define RTW_MODULE_RTL8723BS_NGFF1216	BIT6	/* RTL8723BS(NGFF1216) */
+#define RTW_MODULE_RTL8192EEBT_HMC_M2	BIT7	/* RTL8192EEBT(8192EE+8761AU)_(HMC + M.2) */
+#define RTW_MODULE_RTL8723DE_NGFF1630	BIT8	/* RTL8723DE(NGFF1630) */
+#define RTW_MODULE_RTL8822BE			BIT9	/* RTL8822BE */
+#define RTW_MODULE_RTL8821CE			BIT10	/* RTL8821CE */
 
 #define IS_ALPHA2_NO_SPECIFIED(_alpha2) ((*((u16 *)(_alpha2))) == 0xFFFF)
 
@@ -239,7 +171,7 @@ struct country_chplan {
 	u8 en_11ac;
 #endif
 #if RTW_DEF_MODULE_REGULATORY_CERT
-	u8 def_module_flags; /* RTW_MODULE_RTLXXX */
+	u16 def_module_flags; /* RTW_MODULE_RTLXXX */
 #endif
 };
 
@@ -257,6 +189,48 @@ struct country_chplan {
 
 const struct country_chplan *rtw_get_chplan_from_country(const char *country_code);
 
+struct rf_ctl_t;
+
+typedef enum _REGULATION_TXPWR_LMT {
+	TXPWR_LMT_NONE = 0, /* no limit */
+	TXPWR_LMT_FCC = 1,
+	TXPWR_LMT_MKK = 2,
+	TXPWR_LMT_ETSI = 3,
+	TXPWR_LMT_IC = 4,
+	TXPWR_LMT_KCC = 5,
+	TXPWR_LMT_ACMA = 6,
+	TXPWR_LMT_CHILE = 7,
+	TXPWR_LMT_WW = 8, /* smallest of all available limit, keep last */
+} REGULATION_TXPWR_LMT;
+
+extern const char *const _regd_str[];
+#define regd_str(regd) (((regd) > TXPWR_LMT_WW) ? _regd_str[TXPWR_LMT_WW] : _regd_str[(regd)])
+
+#ifdef CONFIG_TXPWR_LIMIT
+struct regd_exc_ent {
+	_list list;
+	char country[2];
+	u8 domain;
+	char regd_name[0];
+};
+
+void dump_regd_exc_list(void *sel, struct rf_ctl_t *rfctl);
+void rtw_regd_exc_add_with_nlen(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name, u32 nlen);
+void rtw_regd_exc_add(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name);
+struct regd_exc_ent *_rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain);
+struct regd_exc_ent *rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain);
+void rtw_regd_exc_list_free(struct rf_ctl_t *rfctl);
+
+void dump_txpwr_lmt(void *sel, _adapter *adapter);
+void rtw_txpwr_lmt_add_with_nlen(struct rf_ctl_t *rfctl, const char *regd_name, u32 nlen
+	, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt);
+void rtw_txpwr_lmt_add(struct rf_ctl_t *rfctl, const char *regd_name
+	, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt);
+struct txpwr_lmt_ent *_rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name);
+struct txpwr_lmt_ent *rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name);
+void rtw_txpwr_lmt_list_free(struct rf_ctl_t *rfctl);
+#endif /* CONFIG_TXPWR_LIMIT */
+
 #define BB_GAIN_2G 0
 #ifdef CONFIG_IEEE80211_BAND_5GHZ
 #define BB_GAIN_5GLB1 1
@@ -276,9 +250,27 @@ int rtw_ch_to_bb_gain_sel(int ch);
 void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset);
 void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch);
 
-bool rtw_is_dfs_range(u32 hi, u32 lo);
-bool rtw_is_dfs_ch(u8 ch, u8 bw, u8 offset);
-bool rtw_is_long_cac_range(u32 hi, u32 lo);
-bool rtw_is_long_cac_ch(u8 ch, u8 bw, u8 offset);
+/* only check channel ranges */
+#define rtw_is_2g_ch(ch) (ch >= 1 && ch <= 14)
+#define rtw_is_5g_ch(ch) ((ch) >= 36 && (ch) <= 177)
+#define rtw_is_same_band(a, b) \
+	((rtw_is_2g_ch(a) && rtw_is_2g_ch(b)) \
+	|| (rtw_is_5g_ch(a) && rtw_is_5g_ch(b)))
+
+#define rtw_is_5g_band1(ch) ((ch) >= 36 && (ch) <= 48)
+#define rtw_is_5g_band2(ch) ((ch) >= 52 && (ch) <= 64)
+#define rtw_is_5g_band3(ch) ((ch) >= 100 && (ch) <= 144)
+#define rtw_is_5g_band4(ch) ((ch) >= 149 && (ch) <= 177)
+#define rtw_is_same_5g_band(a, b) \
+	((rtw_is_5g_band1(a) && rtw_is_5g_band1(b)) \
+	|| (rtw_is_5g_band2(a) && rtw_is_5g_band2(b)) \
+	|| (rtw_is_5g_band3(a) && rtw_is_5g_band3(b)) \
+	|| (rtw_is_5g_band4(a) && rtw_is_5g_band4(b)))
+
+u8 rtw_is_dfs_range(u32 hi, u32 lo);
+u8 rtw_is_dfs_ch(u8 ch);
+u8 rtw_is_dfs_chbw(u8 ch, u8 bw, u8 offset);
+bool rtw_is_long_cac_range(u32 hi, u32 lo, u8 dfs_region);
+bool rtw_is_long_cac_ch(u8 ch, u8 bw, u8 offset, u8 dfs_region);
 
 #endif /* _RTL8711_RF_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rm.h
new file mode 100644
index 000000000000..840015d6b44a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rm.h
@@ -0,0 +1,89 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_RM_H_
+#define __RTW_RM_H_
+
+u8 rm_post_event_hdl(_adapter *padapter, u8 *pbuf);
+
+#define RM_TIMER_NUM 		32
+#define RM_ALL_MEAS		BIT(1)
+#define RM_ID_FOR_ALL(aid)	((aid<<16)|RM_ALL_MEAS)
+
+#define RM_CAP_ARG(x) ((u8 *)(x))[4], ((u8 *)(x))[3], ((u8 *)(x))[2], ((u8 *)(x))[1], ((u8 *)(x))[0]
+#define RM_CAP_FMT "%02x %02x%02x %02x%02x"
+
+/* remember to modify rm_event_name() when adding new event */
+enum RM_EV_ID {
+	RM_EV_state_in,
+	RM_EV_busy_timer_expire,
+	RM_EV_delay_timer_expire,
+	RM_EV_meas_timer_expire,
+	RM_EV_retry_timer_expire,
+	RM_EV_repeat_delay_expire,
+	RM_EV_request_timer_expire,
+	RM_EV_wait_report,
+	RM_EV_start_meas,
+	RM_EV_survey_done,
+	RM_EV_recv_rep,
+	RM_EV_cancel,
+	RM_EV_state_out,
+	RM_EV_max
+};
+
+struct rm_event {
+	u32 rmid;
+	enum RM_EV_ID evid;
+	_list list;
+};
+
+#ifdef CONFIG_RTW_80211K
+
+struct rm_clock {
+	struct rm_obj *prm;
+	ATOMIC_T counter;
+	enum RM_EV_ID evid;
+};
+
+struct rm_priv {
+	u8 enable;
+	_queue ev_queue;
+	_queue rm_queue;
+	_timer rm_timer;
+
+	struct rm_clock clock[RM_TIMER_NUM];
+	u8 rm_en_cap_def[5];
+	u8 rm_en_cap_assoc[5];
+
+	/* rm debug */
+	void *prm_sel;
+};
+
+int rtw_init_rm(_adapter *padapter);
+int rtw_free_rm_priv(_adapter *padapter);
+
+unsigned int rm_on_action(_adapter *padapter, union recv_frame *precv_frame);
+void RM_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void rtw_ap_parse_sta_rm_en_cap(_adapter *padapter,
+	struct sta_info *psta, struct rtw_ieee802_11_elems *elems);
+
+int rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid);
+void rm_handler(_adapter *padapter, struct rm_event *pev);
+
+u8 rm_add_nb_req(_adapter *padapter, struct sta_info *psta);
+
+#endif /*CONFIG_RTW_80211K */
+#endif /* __RTW_RM_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rm_fsm.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rm_fsm.h
new file mode 100644
index 000000000000..8b319666c0b9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rm_fsm.h
@@ -0,0 +1,390 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_RM_FSM_H_
+#define __RTW_RM_FSM_H_
+
+#ifdef CONFIG_RTW_80211K
+
+#define RM_SUPPORT_IWPRIV_DBG	1
+#define RM_MORE_DBG_MSG		0
+
+#define DBG_BCN_REQ_DETAIL	0
+#define DBG_BCN_REQ_WILDCARD	0
+#define DBG_BCN_REQ_SSID	0
+#define DBG_BCN_REQ_SSID_NAME	"RealKungFu"
+
+#define RM_REQ_TIMEOUT		10000	/* 10 seconds */
+#define RM_MEAS_TIMEOUT		10000	/* 10 seconds */
+#define RM_REPT_SCAN_INTVL	5000	/*  5 seconds */
+#define RM_REPT_POLL_INTVL	2000	/*  2 seconds */
+#define RM_COND_INTVL		2000	/*  2 seconds */
+#define RM_SCAN_DENY_TIMES	10
+#define RM_BUSY_TRAFFIC_TIMES	10
+#define RM_WAIT_BUSY_TIMEOUT	1000	/*  1 seconds */
+
+#define MEAS_REQ_MOD_PARALLEL	BIT(0)
+#define MEAS_REQ_MOD_ENABLE	BIT(1)
+#define MEAS_REQ_MOD_REQUEST	BIT(2)
+#define MEAS_REQ_MOD_REPORT	BIT(3)
+#define MEAS_REQ_MOD_DUR_MAND	BIT(4)
+
+#define MEAS_REP_MOD_LATE	BIT(0)
+#define MEAS_REP_MOD_INCAP	BIT(1)
+#define MEAS_REP_MOD_REFUSE	BIT(2)
+
+#define RM_MASTER		BIT(0)	/* STA who issue meas_req */
+#define RM_SLAVE		0	/* STA who do measurement */
+
+#define CLOCK_UNIT		10	/* ms */
+#define RTW_MAX_NB_RPT_IE_NUM	16
+
+#define RM_GET_AID(rmid)	((rmid&0xffff0000)>>16)
+#define RM_IS_ID_FOR_ALL(rmid)	(rmid&RM_ALL_MEAS)
+
+/*
+ * define the following channels as the max channels in each channel plan.
+ * 2G, total 14 chnls
+ * {1,2,3,4,5,6,7,8,9,10,11,12,13,14}
+ * 5G, total 25 chnls
+ * {36,40,44,48,52,56,60,64,100,104,108,112,116,120,124,128,132,136,140,144,149,153,157,161,165}
+ */
+#define	MAX_OP_CHANNEL_SET_NUM	11
+typedef struct _RT_OPERATING_CLASS {
+	int	global_op_class;
+	int	Len;
+	u16	Channel[MAX_OP_CHANNEL_SET_NUM];
+} RT_OPERATING_CLASS, *PRT_OPERATING_CLASS;
+
+/* IEEE 802.11-2012 Table 8-59 Measurement Type definitions
+*  for measurement request
+*  modify rm_meas_type_req_name() when adding new type
+*/
+enum meas_type_of_req {
+	basic_req,	/* spectrum measurement */
+	cca_req,
+	rpi_histo_req,
+	ch_load_req,
+	noise_histo_req,
+	bcn_req,
+	frame_req,
+	sta_statis_req,
+	lci_req,
+	meas_type_req_max,
+};
+
+/* IEEE 802.11-2012 Table 8-81 Measurement Type definitions
+*  for measurement report
+*  modify rm_type_rep_name() when adding new type
+*/
+enum meas_type_of_rep {
+	basic_rep,	/* spectrum measurement */
+	cca_rep,
+	rpi_histo_rep,
+	ch_load_rep,	/* radio measurement */
+	noise_histo_rep,
+	bcn_rep,
+	frame_rep,
+	sta_statis_rep,	/* Radio measurement and WNM */
+	lci_rep,
+	meas_type_rep_max
+};
+
+/*
+* Beacon request
+*/
+/* IEEE 802.11-2012 Table 8-64 Measurement mode for Beacon Request element */
+enum bcn_req_meas_mode {
+	bcn_req_passive,
+	bcn_req_active,
+	bcn_req_bcn_table
+};
+
+/* IEEE 802.11-2012 Table 8-65 optional subelement IDs for Beacon Request */
+enum bcn_req_opt_sub_id{
+	bcn_req_ssid = 0,		/* len 0-32 */
+	bcn_req_rep_info = 1,		/* len 2 */
+	bcn_req_rep_detail = 2,		/* len 1 */
+	bcn_req_req = 10,		/* len 0-237 */
+	bcn_req_ac_ch_rep = 51		/* len 1-237 */
+};
+
+/* IEEE 802.11-2012 Table 8-66 Reporting condition of Beacon Report */
+enum bcn_rep_cound_id{
+	bcn_rep_cond_immediately,	/* default */
+	bcn_req_cond_rcpi_greater,
+	bcn_req_cond_rcpi_less,
+	bcn_req_cond_rsni_greater,
+	bcn_req_cond_rsni_less,
+	bcn_req_cond_max
+};
+
+struct opt_rep_info {
+	u8 cond;
+	u8 threshold;
+};
+
+#define BCN_REQ_OPT_MAX_NUM		16
+struct bcn_req_opt {
+	/* all req cmd id */
+	u8 opt_id[BCN_REQ_OPT_MAX_NUM];
+	u8 opt_id_num;
+	u8 rep_detail;
+	NDIS_802_11_SSID ssid;
+
+	/* bcn report condition */
+	struct opt_rep_info rep_cond;
+
+	/* 0:default(Report to be issued after each measurement) */
+	u8 *req_start;	/*id : 10 request;start  */
+	u8 req_len;	/*id : 10 request;length */
+};
+
+/*
+* channel load
+*/
+/* IEEE 802.11-2012 Table 8-60 optional subelement IDs for channel load request */
+enum ch_load_opt_sub_id{
+	ch_load_rsvd,
+	ch_load_rep_info
+};
+
+/* IEEE 802.11-2012 Table 8-61 Reporting condition for channel load Report */
+enum ch_load_cound_id{
+	ch_load_cond_immediately,	/* default */
+	ch_load_cond_anpi_equal_greater,
+	ch_load_cond_anpi_equal_less,
+	ch_load_cond_max
+};
+
+/*
+* Noise histogram
+*/
+/* IEEE 802.11-2012 Table 8-62 optional subelement IDs for noise histogram */
+enum noise_histo_opt_sub_id{
+	noise_histo_rsvd,
+	noise_histo_rep_info
+};
+
+/* IEEE 802.11-2012 Table 8-63 Reporting condition for noise historgarm Report */
+enum noise_histo_cound_id{
+	noise_histo_cond_immediately,	/* default */
+	noise_histo_cond_anpi_equal_greater,
+	noise_histo_cond_anpi_equal_less,
+	noise_histo_cond_max
+};
+
+struct meas_req_opt {
+	/* report condition */
+	struct opt_rep_info rep_cond;
+};
+
+/*
+* State machine
+*/
+
+enum RM_STATE {
+	RM_ST_IDLE,
+	RM_ST_DO_MEAS,
+	RM_ST_WAIT_MEAS,
+	RM_ST_SEND_REPORT,
+	RM_ST_RECV_REPORT,
+	RM_ST_END,
+	RM_ST_MAX
+};
+
+struct rm_meas_req {
+	u8 category;
+	u8 action_code;		/* T8-206  */
+	u8 diag_token;
+	u16 rpt;
+
+	u8 e_id;
+	u8 len;
+	u8 m_token;
+	u8 m_mode;		/* req:F8-105, rep:F8-141 */
+	u8 m_type;		/* T8-59 */
+	u8 op_class;
+	u8 ch_num;
+	u16 rand_intvl;		/* units of TU */
+	u16 meas_dur;		/* units of TU */
+
+	u8 bssid[6];		/* for bcn_req */
+
+	u8 *pssid;
+	u8 *opt_s_elem_start;
+	int opt_s_elem_len;
+
+	union {
+		struct bcn_req_opt bcn;
+		struct meas_req_opt clm;
+		struct meas_req_opt nhm;
+	}opt;
+
+	struct rtw_ieee80211_channel ch_set[MAX_OP_CHANNEL_SET_NUM];
+	u8 ch_set_ch_amount;
+};
+
+struct rm_meas_rep {
+	u8 category;
+	u8 action_code;		/* T8-206  */
+	u8 diag_token;
+
+	u8 e_id;		/* T8-54, 38 request; 39 report */
+	u8 len;
+	u8 m_token;
+	u8 m_mode;		/* req:F8-105, rep:F8-141 */
+	u8 m_type;		/* T8-59 */
+	u8 op_class;
+	u8 ch_num;
+
+	u8 ch_load;
+	u8 anpi;
+	u8 ipi[11];
+
+	u16 rpt;
+	u8 bssid[6];		/* for bcn_req */
+};
+
+#define MAX_BUF_NUM	128
+struct data_buf {
+	u8 *pbuf;
+	u16 len;
+};
+
+struct rm_obj {
+
+	/* aid << 16 
+		|diag_token << 8
+		|B(1) 1/0:All_AID/UNIC
+		|B(0) 1/0:RM_MASTER/RM_SLAVE */
+	u32 rmid;
+
+	enum RM_STATE state;
+	struct rm_meas_req q;
+	struct rm_meas_rep p;
+	struct sta_info *psta;
+	struct rm_clock *pclock;
+
+	/* meas report */
+	u64 meas_start_time;
+	u64 meas_end_time;
+	int wait_busy;
+	u8 poll_mode;
+
+	struct data_buf buf[MAX_BUF_NUM];
+
+	_list list;
+};
+
+/*
+* Measurement
+*/
+struct opt_subelement {
+	u8 id;
+	u8 length;
+	u8 *data;
+};
+
+/* 802.11-2012 Table 8-206 Radio Measurment Action field */
+enum rm_action_code {
+	RM_ACT_RADIO_MEAS_REQ,
+	RM_ACT_RADIO_MEAS_REP,
+	RM_ACT_LINK_MEAS_REQ,
+	RM_ACT_LINK_MEAS_REP,
+	RM_ACT_NB_REP_REQ,	/* 4 */
+	RM_ACT_NB_REP_RESP,
+	RM_ACT_RESV,
+	RM_ACT_MAX
+};
+
+/* 802.11-2012 Table 8-119 RM Enabled Capabilities definition */
+enum rm_cap_en {
+	RM_LINK_MEAS_CAP_EN,
+	RM_NB_REP_CAP_EN,		/* neighbor report */
+	RM_PARAL_MEAS_CAP_EN,		/* parallel report */
+	RM_REPEAT_MEAS_CAP_EN,
+	RM_BCN_PASSIVE_MEAS_CAP_EN,
+	RM_BCN_ACTIVE_MEAS_CAP_EN,
+	RM_BCN_TABLE_MEAS_CAP_EN,
+	RM_BCN_MEAS_REP_COND_CAP_EN,	/* conditions */
+
+	RM_FRAME_MEAS_CAP_EN,
+	RM_CH_LOAD_CAP_EN,
+	RM_NOISE_HISTO_CAP_EN,		/* noise historgram */
+	RM_STATIS_MEAS_CAP_EN,		/* statistics */
+	RM_LCI_MEAS_CAP_EN,		/* 12 */
+	RM_LCI_AMIMUTH_CAP_EN,
+	RM_TRANS_STREAM_CAT_MEAS_CAP_EN,
+	RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN,
+
+	RM_AP_CH_REP_CAP_EN,
+	RM_RM_MIB_CAP_EN,
+	RM_OP_CH_MAX_MEAS_DUR0,		/* 18-20 */
+	RM_OP_CH_MAX_MEAS_DUR1,
+	RM_OP_CH_MAX_MEAS_DUR2,
+	RM_NONOP_CH_MAX_MEAS_DUR0,	/* 21-23 */
+	RM_NONOP_CH_MAX_MEAS_DUR1,
+	RM_NONOP_CH_MAX_MEAS_DUR2,
+
+	RM_MEAS_PILOT_CAP0,		/* 24-26 */
+	RM_MEAS_PILOT_CAP1,
+	RM_MEAS_PILOT_CAP2,
+	RM_MEAS_PILOT_TRANS_INFO_CAP_EN,
+	RM_NB_REP_TSF_OFFSET_CAP_EN,
+	RM_RCPI_MEAS_CAP_EN,		/* 29 */
+	RM_RSNI_MEAS_CAP_EN,
+	RM_BSS_AVG_ACCESS_DELAY_CAP_EN,
+
+	RM_AVALB_ADMIS_CAPACITY_CAP_EN,
+	RM_ANT_CAP_EN,
+	RM_RSVD,			/* 34-39 */
+	RM_MAX
+};
+
+char *rm_state_name(enum RM_STATE state);
+char *rm_event_name(enum RM_EV_ID evid);
+char *rm_type_req_name(u8 meas_type);
+int _rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid);
+int rm_enqueue_rmobj(_adapter *padapter, struct rm_obj *obj, bool to_head);
+
+void rm_free_rmobj(struct rm_obj *prm);
+struct rm_obj *rm_alloc_rmobj(_adapter *padapter);
+struct rm_obj *rm_get_rmobj(_adapter *padapter, u32 rmid);
+struct sta_info *rm_get_psta(_adapter *padapter, u32 rmid);
+
+int retrieve_radio_meas_result(struct rm_obj *prm);
+int rm_radio_meas_report_cond(struct rm_obj *prm);
+int rm_recv_radio_mens_req(_adapter *padapter,
+	union recv_frame *precv_frame,struct sta_info *psta);
+int rm_recv_radio_mens_rep(_adapter *padapter,
+	union recv_frame *precv_frame, struct sta_info *psta);
+int rm_radio_mens_nb_rep(_adapter *padapter,
+	union recv_frame *precv_frame, struct sta_info *psta);
+int issue_null_reply(struct rm_obj *prm);
+int issue_beacon_rep(struct rm_obj *prm);
+int issue_nb_req(struct rm_obj *prm);
+int issue_radio_meas_req(struct rm_obj *prm);
+int issue_radio_meas_rep(struct rm_obj *prm);
+
+void rm_set_rep_mode(struct rm_obj *prm, u8 mode);
+
+int ready_for_scan(struct rm_obj *prm);
+int rm_sitesurvey(struct rm_obj *prm);
+
+#endif /*CONFIG_RTW_80211K*/
+#endif /*__RTW_RM_FSM_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rson.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rson.h
new file mode 100644
index 000000000000..e9e27efe76f1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_rson.h
@@ -0,0 +1,62 @@
+/* SPDX-License-Identifier: GPL-2.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.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
+ *
+ *
+ ******************************************************************************/
+#ifndef __RTW_RSON_H_
+#define __RTW_RSON_H_
+
+
+#define RTW_RSON_VER						1
+
+#define RTW_RSON_SCORE_NOTSUP			0x0
+#define RTW_RSON_SCORE_NOTCNNT			0x1
+#define RTW_RSON_SCORE_MAX				0xFF
+#define RTW_RSON_HC_NOTREADY			0xFF
+#define RTW_RSON_HC_ROOT				0x0
+#define RTW_RSON_ALLOWCONNECT			0x1
+#define RTW_RSON_DENYCONNECT			0x0
+
+
+
+/*	for rtw self-origanization spec 1	*/
+struct rtw_rson_struct {
+	u8 ver;
+	u32 id;
+	u8 hopcnt;
+	u8 connectible;
+	u8 loading;
+	u8 res[16];
+} __attribute__((__packed__));
+
+void init_rtw_rson_data(struct dvobj_priv *dvobj);
+void rtw_rson_get_property_str(_adapter *padapter, char *rson_data_str);
+int rtw_rson_set_property(_adapter *padapter, char *field, char *value);
+int rtw_rson_choose(struct wlan_network **candidate, struct wlan_network *competitor);
+int rtw_get_rson_struct(WLAN_BSSID_EX *bssid, struct  rtw_rson_struct *rson_data);
+u8 rtw_cal_rson_score(struct rtw_rson_struct *cand_rson_data, NDIS_802_11_RSSI  Rssi);
+void rtw_rson_handle_ie(WLAN_BSSID_EX *bssid, u8 ie_offset);
+u32 rtw_rson_append_ie(_adapter *padapter, unsigned char *pframe, u32 *len);
+void rtw_rson_do_disconnect(_adapter *padapter);
+void rtw_rson_join_done(_adapter *padapter);
+int rtw_rson_isupdate_roamcan(struct mlme_priv *mlme, struct wlan_network **candidate, struct wlan_network *competitor);
+void rtw_rson_show_survey_info(struct seq_file *m, _list *plist, _list *phead);
+u8 rtw_rson_ap_check_sta(_adapter *padapter, u8 *pframe, uint pkt_len, unsigned short ie_offset);
+u8 rtw_rson_scan_wk_cmd(_adapter *padapter, int op);
+void rtw_rson_scan_cmd_hdl(_adapter *padapter, int op);
+#endif /* __RTW_RSON_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_sdio.h
new file mode 100644
index 000000000000..b4d28e97e298
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_sdio.h
@@ -0,0 +1,27 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2015 - 2017 Realtek Corporation.
+ *
+ * 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_SDIO_H_
+#define _RTW_SDIO_H_
+
+#include <drv_types.h>		/* struct dvobj_priv and etc. */
+
+u8 rtw_sdio_read_cmd52(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_read_cmd53(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_write_cmd52(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_write_cmd53(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+u8 rtw_sdio_f0_read(struct dvobj_priv *, u32 addr, void *buf, size_t len);
+
+#endif /* _RTW_SDIO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_security.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_security.h
index 5820a55cb7c3..9c042e682ea9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_security.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_security.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_SECURITY_H_
 #define __RTW_SECURITY_H_
 
@@ -27,16 +23,18 @@
 #define _TKIP_WTMIC_		0x3
 #define _AES_				0x4
 #define _WEP104_			0x5
-#define _WEP_WPA_MIXED_	0x07  // WEP + WPA
 #define _SMS4_				0x06
-#ifdef CONFIG_IEEE80211W
+#define _WEP_WPA_MIXED_		0x07 /* WEP + WPA */
 #define _BIP_				0x8
-#endif //CONFIG_IEEE80211W
+
 /* 802.11W use wrong key */
 #define IEEE80211W_RIGHT_KEY	0x0
 #define IEEE80211W_WRONG_KEY	0x1
 #define IEEE80211W_NO_KEY		0x2
 
+#define CCMPH_2_PN(ch)	((ch) & 0x000000000000ffff) \
+			| (((ch) & 0xffffffff00000000) >> 16)
+
 #define is_wep_enc(alg) (((alg) == _WEP40_) || ((alg) == _WEP104_))
 
 const char *security_type_str(u8 value);
@@ -50,16 +48,19 @@ const char *security_type_str(u8 value);
 
 #define RTW_KEK_LEN 16
 #define RTW_KCK_LEN 16
+#define RTW_TKIP_MIC_LEN 8
 #define RTW_REPLAY_CTR_LEN 8
 
+#define INVALID_SEC_MAC_CAM_ID	0xFF
+
 typedef enum {
-	ENCRYP_PROTOCOL_OPENSYS,   //open system
-	ENCRYP_PROTOCOL_WEP,       //WEP
-	ENCRYP_PROTOCOL_WPA,       //WPA
-	ENCRYP_PROTOCOL_WPA2,      //WPA2
-	ENCRYP_PROTOCOL_WAPI,      //WAPI: Not support in this version
+	ENCRYP_PROTOCOL_OPENSYS,   /* open system */
+	ENCRYP_PROTOCOL_WEP,       /* WEP */
+	ENCRYP_PROTOCOL_WPA,       /* WPA */
+	ENCRYP_PROTOCOL_WPA2,      /* WPA2 */
+	ENCRYP_PROTOCOL_WAPI,      /* WAPI: Not support in this version */
 	ENCRYP_PROTOCOL_MAX
-}ENCRYP_PROTOCOL_E;
+} ENCRYP_PROTOCOL_E;
 
 
 #ifndef Ndis802_11AuthModeWPA2
@@ -71,145 +72,150 @@ typedef enum {
 #endif
 
 union pn48	{
-	
+
 	u64	val;
-	
+
 #ifdef CONFIG_LITTLE_ENDIAN
 
 struct {
-  u8 TSC0;
-  u8 TSC1;
-  u8 TSC2;
-  u8 TSC3;
-  u8 TSC4;
-  u8 TSC5;
-  u8 TSC6;
-  u8 TSC7;
+	u8 TSC0;
+	u8 TSC1;
+	u8 TSC2;
+	u8 TSC3;
+	u8 TSC4;
+	u8 TSC5;
+	u8 TSC6;
+	u8 TSC7;
 } _byte_;
- 
+
 #elif defined(CONFIG_BIG_ENDIAN)
 
 struct {
-  u8 TSC7;
-  u8 TSC6;
-  u8 TSC5;
-  u8 TSC4;
-  u8 TSC3;
-  u8 TSC2;
-  u8 TSC1;
-  u8 TSC0;
+	u8 TSC7;
+	u8 TSC6;
+	u8 TSC5;
+	u8 TSC4;
+	u8 TSC3;
+	u8 TSC2;
+	u8 TSC1;
+	u8 TSC0;
 } _byte_;
- 
+
 #endif
 
 };
 
 union Keytype {
-        u8   skey[16];
-        u32    lkey[4];
+	u8   skey[16];
+	u32    lkey[4];
 };
 
 
-typedef struct _RT_PMKID_LIST
-{
+typedef struct _RT_PMKID_LIST {
 	u8						bUsed;
-	u8 						Bssid[6];
+	u8						Bssid[6];
 	u8						PMKID[16];
 	u8						SsidBuf[33];
-	u8*						ssid_octet;
-	u16 						ssid_length;
+	u8						*ssid_octet;
+	u16						ssid_length;
 } RT_PMKID_LIST, *PRT_PMKID_LIST;
 
 
-struct security_priv
-{
-	u32	  dot11AuthAlgrthm;		// 802.11 auth, could be open, shared, 8021x and authswitch 
-	u32	  dot11PrivacyAlgrthm;	// This specify the privacy for shared auth. algorithm.
+struct security_priv {
+	u32	  dot11AuthAlgrthm;		/* 802.11 auth, could be open, shared, 8021x and authswitch */
+	u32	  dot11PrivacyAlgrthm;	/* This specify the privacy for shared auth. algorithm. */
 
 	/* WEP */
-	u32	  dot11PrivacyKeyIndex;	// this is only valid for legendary wep, 0~3 for key id. (tx key index)
-	union Keytype dot11DefKey[4];			// this is only valid for def. key	
-	u32 	dot11DefKeylen[4];
+	u32	  dot11PrivacyKeyIndex;	/* this is only valid for legendary wep, 0~3 for key id. (tx key index) */
+	union Keytype dot11DefKey[6];			/* this is only valid for def. key	 */
+	u32	dot11DefKeylen[6];
+	u8	dot11Def_camid[6];
 	u8 	key_mask; /* use to restore wep key after hal_init */
 
-	u32 dot118021XGrpPrivacy;	// This 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 Group Key, for 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.
+	u32 dot118021XGrpPrivacy;	/* This specify the privacy algthm. used for Grp key */
+	u32	dot118021XGrpKeyid;		/* key id used for Grp Key ( tx key index) */
+	union Keytype	dot118021XGrpKey[6];	/* 802.1x Group Key, for inx0 and inx1	 */
+	union Keytype	dot118021XGrptxmickey[6];
+	union Keytype	dot118021XGrprxmickey[6];
+	union pn48		dot11Grptxpn;			/* PN48 used for Grp Key xmit. */
+	union pn48		dot11Grprxpn;			/* PN48 used for Grp Key recv. */
+	u8				iv_seq[4][8];
 #ifdef CONFIG_IEEE80211W
-	u32	dot11wBIPKeyid;						// key id used for BIP Key ( tx key index)
-	union Keytype	dot11wBIPKey[6];		// BIP Key, for index4 and index5
-	union pn48		dot11wBIPtxpn;			// PN48 used for Grp Key xmit.
-	union pn48		dot11wBIPrxpn;			// PN48 used for Grp Key recv.
-#endif //CONFIG_IEEE80211W
+	u32	dot11wBIPKeyid;						/* key id used for BIP Key ( tx key index) */
+	union Keytype	dot11wBIPKey[6];		/* BIP Key, for index4 and index5 */
+	union pn48		dot11wBIPtxpn;			/* PN48 used for BIP xmit. */
+	union pn48		dot11wBIPrxpn;			/* PN48 used for BIP recv. */
+#endif /* CONFIG_IEEE80211W */
 #ifdef CONFIG_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
+	/* 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;	
+	unsigned int wpa2_pairwise_cipher;
+	u8 mfp_opt;
 #endif
+#ifdef CONFIG_CONCURRENT_MODE
+	u8	dot118021x_bmc_cam_id;
+#endif
+	/*IEEE802.11-2012 Std. Table 8-101 AKM Suite Selectors*/
+	u32	rsn_akm_suite_type;
 
-	u8 wps_ie[MAX_WPS_IE_LEN];//added in assoc req
+	u8 wps_ie[MAX_WPS_IE_LEN];/* added in assoc req */
 	int wps_ie_len;
-	
-	
+
+
 	u8	binstallGrpkey;
 #ifdef CONFIG_GTK_OL
 	u8	binstallKCK_KEK;
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
 #ifdef CONFIG_IEEE80211W
 	u8	binstallBIPkey;
-#endif //CONFIG_IEEE80211W
+#endif /* CONFIG_IEEE80211W */
 	u8	busetkipkey;
-	//_timer tkip_timer;
 	u8	bcheck_grpkey;
 	u8	bgrpkey_handshake;
-	
-	//u8	packet_cnt;//unused, removed
-	
-	s32	sw_encrypt;//from registry_priv
-	s32	sw_decrypt;//from registry_priv
-	
-	s32 	hw_decrypted;//if the rx packets is hw_decrypted==_FALSE, it means the hw has not been ready.
 
+	/* u8	packet_cnt; */ /* unused, removed */
+
+	s32	sw_encrypt;/* from registry_priv */
+	s32	sw_decrypt;/* from registry_priv */
 
-	//keeps the auth_type & enc_status from upper layer ioctl(wpa_supplicant or wzc)
-	u32 ndisauthtype;	// NDIS_802_11_AUTHENTICATION_MODE
-	u32 ndisencryptstatus;	// NDIS_802_11_ENCRYPTION_STATUS
+	s32 	hw_decrypted;/* if the rx packets is hw_decrypted==_FALSE, it means the hw has not been ready. */
+
+
+	/* keeps the auth_type & enc_status from upper layer ioctl(wpa_supplicant or wzc) */
+	u32 ndisauthtype;	/* NDIS_802_11_AUTHENTICATION_MODE */
+	u32 ndisencryptstatus;	/* NDIS_802_11_ENCRYPTION_STATUS */
 
 	NDIS_802_11_WEP ndiswep;
 #ifdef PLATFORM_WINDOWS
-	u8 KeyMaterial[16];// variable length depending on above field.
+	u8 KeyMaterial[16];/* variable length depending on above field. */
 #endif
 
 	u8 assoc_info[600];
-	u8 szofcapability[256]; //for wpa2 usage
-	u8 oidassociation[512]; //for wpa/wpa2 usage
-	u8 authenticator_ie[256];  //store ap security information element
-	u8 supplicant_ie[256];  //store sta security information element
+	u8 szofcapability[256]; /* for wpa2 usage */
+	u8 oidassociation[512]; /* for wpa/wpa2 usage */
+	u8 authenticator_ie[256];  /* store ap security information element */
+	u8 supplicant_ie[256];  /* store sta security information element */
 
 
-	//for tkip countermeasure
-	u32 last_mic_err_time;	
+	/* for tkip countermeasure */
+	systime last_mic_err_time;
 	u8	btkip_countermeasure;
 	u8	btkip_wait_report;
-	u32 btkip_countermeasure_time;
-
-	//---------------------------------------------------------------------------
-	// For WPA2 Pre-Authentication.
-	//---------------------------------------------------------------------------
-	//u8				RegEnablePreAuth;				// Default value: Pre-Authentication enabled or not, from registry "EnablePreAuth". Added by Annie, 2005-11-01.
-	//u8				EnablePreAuthentication;			// Current Value: Pre-Authentication enabled or not.
-	RT_PMKID_LIST		PMKIDList[NUM_PMKID_CACHE];	// Renamed from PreAuthKey[NUM_PRE_AUTH_KEY]. Annie, 2006-10-13.
+	systime btkip_countermeasure_time;
+
+	/* --------------------------------------------------------------------------- */
+	/* For WPA2 Pre-Authentication. */
+	/* --------------------------------------------------------------------------- */
+	/* u8				RegEnablePreAuth;				 */ /* Default value: Pre-Authentication enabled or not, from registry "EnablePreAuth". Added by Annie, 2005-11-01. */
+	/* u8				EnablePreAuthentication;			 */ /* Current Value: Pre-Authentication enabled or not. */
+	RT_PMKID_LIST		PMKIDList[NUM_PMKID_CACHE];	/* Renamed from PreAuthKey[NUM_PRE_AUTH_KEY]. Annie, 2006-10-13. */
 	u8				PMKIDIndex;
-	//u32				PMKIDCount;						// Added by Annie, 2006-10-13.
-	//u8				szCapability[256];				// For WPA2-PSK using zero-config, by Annie, 2005-09-20.
+	/* u32				PMKIDCount;						 */ /* Added by Annie, 2006-10-13. */
+	/* u8				szCapability[256];				 */ /* For WPA2-PSK using zero-config, by Annie, 2005-09-20. */
 
 	u8 bWepDefaultKeyIdxSet;
 
@@ -238,6 +244,12 @@ struct security_priv
 #endif /* DBG_SW_SEC_CNT */
 };
 
+#ifdef CONFIG_IEEE80211W
+#define SEC_IS_BIP_KEY_INSTALLED(sec) ((sec)->binstallBIPkey)
+#else
+#define SEC_IS_BIP_KEY_INSTALLED(sec) _FALSE
+#endif
+
 struct sha256_state {
 	u64 length;
 	u32 state[8], curlen;
@@ -245,32 +257,30 @@ struct sha256_state {
 };
 
 #define GET_ENCRY_ALGO(psecuritypriv, psta, encry_algo, bmcst)\
-do{\
-	switch(psecuritypriv->dot11AuthAlgrthm)\
-	{\
+	do {\
+		switch (psecuritypriv->dot11AuthAlgrthm) {\
 		case dot11AuthAlgrthm_Open:\
 		case dot11AuthAlgrthm_Shared:\
 		case dot11AuthAlgrthm_Auto:\
 			encry_algo = (u8)psecuritypriv->dot11PrivacyAlgrthm;\
 			break;\
 		case dot11AuthAlgrthm_8021X:\
-			if(bmcst)\
+			if (bmcst)\
 				encry_algo = (u8)psecuritypriv->dot118021XGrpPrivacy;\
 			else\
-				encry_algo =(u8) psta->dot118021XPrivacy;\
+				encry_algo = (u8) psta->dot118021XPrivacy;\
+			break;\
+		case dot11AuthAlgrthm_WAPI:\
+			encry_algo = (u8)psecuritypriv->dot11PrivacyAlgrthm;\
 			break;\
-	     case dot11AuthAlgrthm_WAPI:\
-		     encry_algo = (u8)psecuritypriv->dot11PrivacyAlgrthm;\
-		     break;\
-	}\
-}while(0)
+		} \
+	} while (0)
 
 #define _AES_IV_LEN_ 8
 
-#define SET_ICE_IV_LEN( iv_len, icv_len, encrypt)\
-do{\
-	switch(encrypt)\
-	{\
+#define SET_ICE_IV_LEN(iv_len, icv_len, encrypt)\
+	do {\
+		switch (encrypt) {\
 		case _WEP40_:\
 		case _WEP104_:\
 			iv_len = 4;\
@@ -292,30 +302,29 @@ do{\
 			iv_len = 0;\
 			icv_len = 0;\
 			break;\
-	}\
-}while(0)
+		} \
+	} 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 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) )
+#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
+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];
@@ -370,8 +379,8 @@ static inline u32 rotr(u32 val, int bits)
 			((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); }
+		(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]))
@@ -401,11 +410,6 @@ static inline u32 rotr(u32 val, int bits)
 		(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] = {
@@ -427,12 +431,12 @@ static const unsigned long K[64] = {
 
 /* Various logical functions */
 #define RORc(x, y) \
-( ((((unsigned long) (x) & 0xFFFFFFFFUL) >> (unsigned long) ((y) & 31)) | \
-   ((unsigned long) (x) << (unsigned long) (32 - ((y) & 31)))) & 0xFFFFFFFFUL)
-#define Ch(x,y,z)       (z ^ (x & (y ^ z)))
-#define Maj(x,y,z)      (((x | y) & z) | (x & y)) 
+	(((((unsigned long) (x) & 0xFFFFFFFFUL) >> (unsigned long) ((y) & 31)) | \
+	  ((unsigned long) (x) << (unsigned long) (32 - ((y) & 31)))) & 0xFFFFFFFFUL)
+#define Ch(x, y, z)       (z ^ (x & (y ^ z)))
+#define Maj(x, y, z)      (((x | y) & z) | (x & y))
 #define S(x, n)         RORc((x), (n))
-#define R(x, n)         (((x)&0xFFFFFFFFUL)>>(n))
+#define R(x, n)         (((x) & 0xFFFFFFFFUL)>>(n))
 #define Sigma0(x)       (S(x, 2) ^ S(x, 13) ^ S(x, 22))
 #define Sigma1(x)       (S(x, 6) ^ S(x, 11) ^ S(x, 25))
 #define Gamma0(x)       (S(x, 7) ^ S(x, 18) ^ R(x, 3))
@@ -441,15 +445,21 @@ static const unsigned long K[64] = {
 #define MIN(x, y) (((x) < (y)) ? (x) : (y))
 #endif
 #ifdef CONFIG_IEEE80211W
-int omac1_aes_128(u8 *key, u8 *data, size_t data_len, u8 *mac);
-#endif //CONFIG_IEEE80211W
-void rtw_secmicsetkey(struct mic_data *pmicdata, u8 * key );
-void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b );
-void rtw_secmicappend(struct mic_data *pmicdata, u8 * src, u32 nBytes );
-void rtw_secgetmic(struct mic_data *pmicdata, u8 * dst );
+int omac1_aes_128(const u8 *key, const u8 *data, size_t data_len, u8 *mac);
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_RTW_MESH_AEK
+int aes_siv_encrypt(const u8 *key, const u8 *pw, size_t pwlen
+	, size_t num_elem, const u8 *addr[], const size_t *len, u8 *out);
+int aes_siv_decrypt(const u8 *key, const u8 *iv_crypt, size_t iv_c_len
+	, size_t num_elem, const u8 *addr[], const size_t *len, u8 *out);
+#endif
+void rtw_secmicsetkey(struct mic_data *pmicdata, u8 *key);
+void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b);
+void rtw_secmicappend(struct mic_data *pmicdata, u8 *src, u32 nBytes);
+void rtw_secgetmic(struct mic_data *pmicdata, u8 *dst);
 
 void rtw_seccalctkipmic(
-	u8 * key,
+	u8 *key,
 	u8 *header,
 	u8 *data,
 	u32 data_len,
@@ -464,27 +474,25 @@ u32 rtw_aes_decrypt(_adapter *padapter, u8  *precvframe);
 u32 rtw_tkip_decrypt(_adapter *padapter, u8  *precvframe);
 void rtw_wep_decrypt(_adapter *padapter, u8  *precvframe);
 #ifdef CONFIG_IEEE80211W
-u32	rtw_BIP_verify(_adapter *padapter, u8 *precvframe);
-#endif //CONFIG_IEEE80211W
+u32	rtw_BIP_verify(_adapter *padapter, u8 *whdr_pos, sint flen
+	, const u8 *key, u16 id, u64* ipn);
+#endif
 #ifdef CONFIG_TDLS
 void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta);
-int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq, 
-						u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie,
-						u8 *mic);
-int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason, 
-	u8 dialog_token, u8 trans_seq, u8 *ftie, u8 *mic);
-int tdls_verify_mic(u8 *kck, u8 trans_seq, 
-						u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie);
-#endif //CONFIG_TDLS
-
-void rtw_use_tkipkey_handler(RTW_TIMER_HDL_ARGS);
+int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
+			u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie,
+			u8 *mic);
+int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason,
+			u8 dialog_token, u8 trans_seq, u8 *ftie, u8 *mic);
+int tdls_verify_mic(u8 *kck, u8 trans_seq,
+			u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie);
+#endif /* CONFIG_TDLS */
 
 void rtw_sec_restore_wep_key(_adapter *adapter);
-u8 rtw_handle_tkip_countermeasure(_adapter* adapter, const char *caller);
+u8 rtw_handle_tkip_countermeasure(_adapter *adapter, const char *caller);
 
 #ifdef CONFIG_WOWLAN
 u16 rtw_calc_crc(u8  *pdata, int length);
 #endif /*CONFIG_WOWLAN*/
 
-#endif	//__RTL871X_SECURITY_H_
-
+#endif /* __RTL871X_SECURITY_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_sreset.h
index 4a225589a6c8..c3dda35a90a3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_sreset.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,43 +12,49 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_SRESET_H_
 #define _RTW_SRESET_H_
 
-//#include <drv_types.h>
+/* #include <drv_types.h> */
 
 enum {
 	SRESET_TGP_NULL = 0,
 	SRESET_TGP_XMIT_STATUS = 1,
 	SRESET_TGP_LINK_STATUS = 2,
+	SRESET_TGP_INFO = 99,
 };
 
 struct sreset_priv {
-	_mutex 	silentreset_mutex;
-	u8 	silent_reset_inprogress;
+	_mutex	silentreset_mutex;
+	u8	silent_reset_inprogress;
 	u8	Wifi_Error_Status;
-	unsigned long last_tx_time;
-	unsigned long last_tx_complete_time;
+	systime last_tx_time;
+	systime last_tx_complete_time;
 
 	s32 dbg_trigger_point;
+	u64 self_dect_tx_cnt;
+	u64 self_dect_rx_cnt;
+	u64 self_dect_fw_cnt;
+	u64 tx_dma_status_cnt;
+	u64 rx_dma_status_cnt;
+	u8 rx_cnt;
+	u8 self_dect_fw;
+	u8 self_dect_case;
+	u16 last_mac_rxff_ptr;
+	u8 dbg_sreset_ctrl;
 };
 
 
 
-#define	WIFI_STATUS_SUCCESS 		0
-#define	USB_VEN_REQ_CMD_FAIL 	BIT0
-#define	USB_READ_PORT_FAIL 		BIT1
+#define	WIFI_STATUS_SUCCESS		0
+#define	USB_VEN_REQ_CMD_FAIL	BIT0
+#define	USB_READ_PORT_FAIL		BIT1
 #define	USB_WRITE_PORT_FAIL		BIT2
-#define	WIFI_MAC_TXDMA_ERROR 	BIT3			
+#define	WIFI_MAC_TXDMA_ERROR	BIT3
 #define   WIFI_TX_HANG				BIT4
 #define	WIFI_RX_HANG				BIT5
-#define 	WIFI_IF_NOT_EXIST			BIT6
+#define	WIFI_IF_NOT_EXIST			BIT6
 
 void sreset_init_value(_adapter *padapter);
 void sreset_reset_value(_adapter *padapter);
@@ -58,4 +65,3 @@ bool sreset_inprogress(_adapter *padapter);
 void sreset_reset(_adapter *padapter);
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_tdls.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_tdls.h
index 5efd505e6ecb..a18dd823c768 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_tdls.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_tdls.h
@@ -1,148 +1,186 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __RTW_TDLS_H_
-#define __RTW_TDLS_H_
-
-
-#ifdef CONFIG_TDLS
-/* TDLS STA state */
-
-
-/* TDLS Diect Link Establishment */
-#define	TDLS_STATE_NONE				0x00000000		/* Default state */
-#define	TDLS_INITIATOR_STATE		BIT(28)			/* 0x10000000 */
-#define	TDLS_RESPONDER_STATE		BIT(29)			/* 0x20000000 */
-#define	TDLS_LINKED_STATE			BIT(30)			/* 0x40000000 */
-/* TDLS PU Buffer STA */
-#define	TDLS_WAIT_PTR_STATE			BIT(24)			/* 0x01000000 */	/* Waiting peer's TDLS_PEER_TRAFFIC_RESPONSE frame */
-/* TDLS Check ALive */
-#define	TDLS_ALIVE_STATE			BIT(20)			/* 0x00100000 */	/* Check if peer sta is alived. */
-/* TDLS Channel Switch */
-#define	TDLS_CH_SWITCH_ON_STATE		BIT(16)			/* 0x00010000 */
-#define	TDLS_PEER_AT_OFF_STATE		BIT(17)			/* 0x00020000 */	/* Could send pkt on target ch */
-#define	TDLS_CH_SW_INITIATOR_STATE	BIT(18)			/* 0x00040000 */	/* Avoid duplicated or unconditional ch. switch rsp. */
-#define	TDLS_WAIT_CH_RSP_STATE		BIT(19)			/* 0x00080000 */	/* Wait Ch. response as we are TDLS channel switch initiator */
-
-
-#define	TPK_RESEND_COUNT			1800	/*Unit: seconds */
-#define	CH_SWITCH_TIME				5
-#define	CH_SWITCH_TIMEOUT			20
-#define	TDLS_SIGNAL_THRESH			0x20
-#define	TDLS_WATCHDOG_PERIOD		10	/* Periodically sending tdls discovery request in TDLS_WATCHDOG_PERIOD * 2 sec */
-#define	TDLS_HANDSHAKE_TIME			3000
-#define	TDLS_PTI_TIME				7000
-
-#define TDLS_MIC_LEN 16
-#define WPA_NONCE_LEN 32
-#define TDLS_TIMEOUT_LEN 4
-
-struct wpa_tdls_ftie {
-	u8 ie_type; /* FTIE */
-	u8 ie_len;
-	u8 mic_ctrl[2];
-	u8 mic[TDLS_MIC_LEN];
-	u8 Anonce[WPA_NONCE_LEN]; /* Responder Nonce in TDLS */
-	u8 Snonce[WPA_NONCE_LEN]; /* Initiator Nonce in TDLS */
-	/* followed by optional elements */
-} ;
-
-struct wpa_tdls_lnkid {
-	u8 ie_type; /* Link Identifier IE */
-	u8 ie_len;
-	u8 bssid[ETH_ALEN];
-	u8 init_sta[ETH_ALEN];
-	u8 resp_sta[ETH_ALEN];
-} ;
-
-static u8 TDLS_RSNIE[20]={	0x01, 0x00,	/* Version shall be set to 1 */
-							0x00, 0x0f, 0xac, 0x07,	/* Group sipher suite */
-							0x01, 0x00,	/* Pairwise cipher suite count */
-							0x00, 0x0f, 0xac, 0x04,	/* Pairwise cipher suite list; CCMP only */
-							0x01, 0x00,	/* AKM suite count */
-							0x00, 0x0f, 0xac, 0x07,	/* TPK Handshake */
-							0x0c, 0x02,
-							/* PMKID shall not be present */
-						};
-
-static u8 TDLS_WMMIE[]={0x00, 0x50, 0xf2, 0x02, 0x00, 0x01, 0x00};	/* Qos info all set zero */
-
-static u8 TDLS_WMM_PARAM_IE[] = {0x00, 0x00, 0x03, 0xa4, 0x00, 0x00, 0x27, 0xa4, 0x00, 0x00, 0x42, 0x43, 0x5e, 0x00, 0x62, 0x32, 0x2f, 0x00};
-
-static u8 TDLS_EXT_CAPIE[] = {0x00, 0x00, 0x00, 0x50, 0x20, 0x00, 0x00, 0x00};	/* bit(28), bit(30), bit(37) */
-
-/* SRC: Supported Regulatory Classes */
-static u8 TDLS_SRC[] = { 0x01, 0x01, 0x02, 0x03, 0x04, 0x0c, 0x16, 0x17, 0x18, 0x19, 0x1b, 0x1c, 0x1d, 0x1e, 0x20, 0x21 };
-
-int check_ap_tdls_prohibited(u8 *pframe, u8 pkt_len);
-int check_ap_tdls_ch_switching_prohibited(u8 *pframe, u8 pkt_len);
-void rtw_reset_tdls_info(_adapter* padapter);
-int rtw_init_tdls_info(_adapter* padapter);
-void rtw_free_tdls_info(struct tdls_info *ptdlsinfo);
-int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms);
-void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta);
-void	rtw_free_tdls_timer(struct sta_info *psta);
-void free_tdls_sta(_adapter *padapter, struct sta_info *ptdls_sta);
-#ifdef CONFIG_WFD
-int issue_tunneled_probe_req(_adapter *padapter);
-int issue_tunneled_probe_rsp(_adapter *padapter, union recv_frame *precv_frame);
-#endif /* CONFIG_WFD */
-int issue_tdls_dis_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
-int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack);
-int issue_tdls_setup_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
-int issue_tdls_setup_cfm(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
-int issue_tdls_dis_rsp(_adapter * padapter, struct tdls_txmgmt *ptxmgmt, u8 privacy);
-int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack);
-int issue_tdls_peer_traffic_rsp(_adapter *padapter, struct sta_info *psta, struct tdls_txmgmt *ptxmgmt);
-int issue_tdls_peer_traffic_indication(_adapter *padapter, struct sta_info *psta);
-int issue_tdls_ch_switch_req(_adapter *padapter, struct sta_info *ptdls_sta);
-int issue_tdls_ch_switch_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack);
-sint On_TDLS_Dis_Rsp(_adapter *adapter, union recv_frame *precv_frame);
-sint On_TDLS_Setup_Req(_adapter *adapter, union recv_frame *precv_frame);
-int On_TDLS_Setup_Rsp(_adapter *adapter, union recv_frame *precv_frame);
-int On_TDLS_Setup_Cfm(_adapter *adapter, union recv_frame *precv_frame);
-int On_TDLS_Dis_Req(_adapter *adapter, union recv_frame *precv_frame);
-int On_TDLS_Teardown(_adapter *adapter, union recv_frame *precv_frame);
-int On_TDLS_Peer_Traffic_Indication(_adapter *adapter, union recv_frame *precv_frame);
-int On_TDLS_Peer_Traffic_Rsp(_adapter *adapter, union recv_frame *precv_frame);
-#ifdef CONFIG_TDLS_CH_SW
-sint On_TDLS_Ch_Switch_Req(_adapter *adapter, union recv_frame *precv_frame);
-sint On_TDLS_Ch_Switch_Rsp(_adapter *adapter, union recv_frame *precv_frame);
-void rtw_build_tdls_ch_switch_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tdls_ch_switch_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-#endif
-void rtw_build_tdls_setup_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tdls_setup_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tdls_setup_cfm_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tdls_teardown_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tdls_dis_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tdls_dis_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, u8 privacy);
-void rtw_build_tdls_peer_traffic_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tdls_peer_traffic_indication_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
-void rtw_build_tunneled_probe_req_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe);
-void rtw_build_tunneled_probe_rsp_ies(_adapter * padapter, struct xmit_frame * pxmitframe, u8 *pframe);
-
-u32 update_mask_tdls(_adapter *padapter, struct sta_info *psta);
-int rtw_tdls_is_driver_setup(_adapter *padapter);
-void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta);
-const char * rtw_tdls_action_txt(enum TDLS_ACTION_FIELD action);
-#endif /* CONFIG_TDLS */
-
-#endif
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_TDLS_H_
+#define __RTW_TDLS_H_
+
+
+#ifdef CONFIG_TDLS
+/* TDLS STA state */
+
+
+/* TDLS Diect Link Establishment */
+#define	TDLS_STATE_NONE				0x00000000		/* Default state */
+#define	TDLS_INITIATOR_STATE		BIT(28)			/* 0x10000000 */
+#define	TDLS_RESPONDER_STATE		BIT(29)			/* 0x20000000 */
+#define	TDLS_LINKED_STATE			BIT(30)			/* 0x40000000 */
+/* TDLS PU Buffer STA */
+#define	TDLS_WAIT_PTR_STATE			BIT(24)			/* 0x01000000 */	/* Waiting peer's TDLS_PEER_TRAFFIC_RESPONSE frame */
+/* TDLS Check ALive */
+#define	TDLS_ALIVE_STATE			BIT(20)			/* 0x00100000 */	/* Check if peer sta is alived. */
+/* TDLS Channel Switch */
+#define	TDLS_CH_SWITCH_PREPARE_STATE	BIT(15)			/* 0x00008000 */
+#define	TDLS_CH_SWITCH_ON_STATE			BIT(16)			/* 0x00010000 */
+#define	TDLS_PEER_AT_OFF_STATE			BIT(17)			/* 0x00020000 */	/* Could send pkt on target ch */
+#define	TDLS_CH_SW_INITIATOR_STATE		BIT(18)			/* 0x00040000 */	/* Avoid duplicated or unconditional ch. switch rsp. */
+#define	TDLS_WAIT_CH_RSP_STATE			BIT(19)			/* 0x00080000 */	/* Wait Ch. response as we are TDLS channel switch initiator */
+
+
+#define	TDLS_TPK_RESEND_COUNT			86400	/*Unit: seconds */
+#define	TDLS_CH_SWITCH_TIME				15
+#define	TDLS_CH_SWITCH_TIMEOUT			30
+#define	TDLS_CH_SWITCH_OPER_OFFLOAD_TIMEOUT	10
+#define	TDLS_SIGNAL_THRESH			0x20
+#define	TDLS_WATCHDOG_PERIOD		10	/* Periodically sending tdls discovery request in TDLS_WATCHDOG_PERIOD * 2 sec */
+#define	TDLS_HANDSHAKE_TIME			3000
+#define	TDLS_PTI_TIME				7000
+
+#define TDLS_CH_SW_STAY_ON_BASE_CHNL_TIMEOUT	20		/* ms */
+#define TDLS_CH_SW_MONITOR_TIMEOUT				2000	/*ms */
+
+#define TDLS_MIC_LEN 16
+#define WPA_NONCE_LEN 32
+#define TDLS_TIMEOUT_LEN 4
+
+enum TDLS_CH_SW_CHNL {
+	TDLS_CH_SW_BASE_CHNL = 0,
+	TDLS_CH_SW_OFF_CHNL
+};
+
+#define TDLS_MIC_CTRL_LEN 2
+#define TDLS_FTIE_DATA_LEN (TDLS_MIC_CTRL_LEN + TDLS_MIC_LEN + \
+							WPA_NONCE_LEN + WPA_NONCE_LEN)
+struct wpa_tdls_ftie {
+	u8 ie_type; /* FTIE */
+	u8 ie_len;
+	union {
+		struct {
+			u8 mic_ctrl[TDLS_MIC_CTRL_LEN];
+			u8 mic[TDLS_MIC_LEN];
+			u8 Anonce[WPA_NONCE_LEN]; /* Responder Nonce in TDLS */
+			u8 Snonce[WPA_NONCE_LEN]; /* Initiator Nonce in TDLS */
+		};
+		struct {
+			u8 data[TDLS_FTIE_DATA_LEN];
+		};
+	};
+	/* followed by optional elements */
+} ;
+
+struct wpa_tdls_lnkid {
+	u8 ie_type; /* Link Identifier IE */
+	u8 ie_len;
+	u8 bssid[ETH_ALEN];
+	u8 init_sta[ETH_ALEN];
+	u8 resp_sta[ETH_ALEN];
+} ;
+
+static u8 TDLS_RSNIE[20] = {	0x01, 0x00,	/* Version shall be set to 1 */
+				0x00, 0x0f, 0xac, 0x07,	/* Group sipher suite */
+				0x01, 0x00,	/* Pairwise cipher suite count */
+	0x00, 0x0f, 0xac, 0x04,	/* Pairwise cipher suite list; CCMP only */
+				0x01, 0x00,	/* AKM suite count */
+				0x00, 0x0f, 0xac, 0x07,	/* TPK Handshake */
+				0x0c, 0x02,
+				/* PMKID shall not be present */
+			   };
+
+static u8 TDLS_WMMIE[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01, 0x00};	/* Qos info all set zero */
+
+static u8 TDLS_WMM_PARAM_IE[] = {0x00, 0x00, 0x03, 0xa4, 0x00, 0x00, 0x27, 0xa4, 0x00, 0x00, 0x42, 0x43, 0x5e, 0x00, 0x62, 0x32, 0x2f, 0x00};
+
+static u8 TDLS_EXT_CAPIE[] = {0x00, 0x00, 0x00, 0x50, 0x20, 0x00, 0x00, 0x00};	/* bit(28), bit(30), bit(37) */
+
+/* SRC: Supported Regulatory Classes */
+static u8 TDLS_SRC[] = { 0x01, 0x01, 0x02, 0x03, 0x04, 0x0c, 0x16, 0x17, 0x18, 0x19, 0x1b, 0x1c, 0x1d, 0x1e, 0x20, 0x21 };
+
+int check_ap_tdls_prohibited(u8 *pframe, u8 pkt_len);
+int check_ap_tdls_ch_switching_prohibited(u8 *pframe, u8 pkt_len);
+
+void rtw_set_tdls_enable(_adapter *padapter, u8 enable);
+u8 rtw_is_tdls_enabled(_adapter *padapter);
+u8 rtw_is_tdls_sta_existed(_adapter *padapter);
+u8 rtw_tdls_is_setup_allowed(_adapter *padapter);
+#ifdef CONFIG_TDLS_CH_SW
+u8 rtw_tdls_is_chsw_allowed(_adapter *padapter);
+#endif
+
+void rtw_tdls_set_link_established(_adapter *adapter, bool en);
+void rtw_reset_tdls_info(_adapter *padapter);
+int rtw_init_tdls_info(_adapter *padapter);
+void rtw_free_tdls_info(struct tdls_info *ptdlsinfo);
+void rtw_free_all_tdls_sta(_adapter *padapter, u8 enqueue_cmd);
+void rtw_enable_tdls_func(_adapter *padapter);
+void rtw_disable_tdls_func(_adapter *padapter, u8 enqueue_cmd);
+int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms);
+void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta);
+void	rtw_cancel_tdls_timer(struct sta_info *psta);
+void rtw_tdls_teardown_pre_hdl(_adapter *padapter, struct sta_info *psta);
+void rtw_tdls_teardown_post_hdl(_adapter *padapter, struct sta_info *psta, u8 enqueue_cmd);
+
+#ifdef CONFIG_TDLS_CH_SW
+void rtw_tdls_set_ch_sw_oper_control(_adapter *padapter, u8 enable);
+void rtw_tdls_ch_sw_back_to_base_chnl(_adapter *padapter);
+s32 rtw_tdls_do_ch_sw(_adapter *padapter, struct sta_info *ptdls_sta, u8 chnl_type, u8 channel, u8 channel_offset, u16 bwmode, u16 ch_switch_time);
+void rtw_tdls_chsw_oper_done(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_WFD
+int issue_tunneled_probe_req(_adapter *padapter);
+int issue_tunneled_probe_rsp(_adapter *padapter, union recv_frame *precv_frame);
+#endif /* CONFIG_WFD */
+int issue_tdls_dis_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack);
+int issue_tdls_setup_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_setup_cfm(_adapter *padapter, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_dis_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 privacy);
+int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack);
+int issue_tdls_peer_traffic_rsp(_adapter *padapter, struct sta_info *psta, struct tdls_txmgmt *ptxmgmt);
+int issue_tdls_peer_traffic_indication(_adapter *padapter, struct sta_info *psta);
+#ifdef CONFIG_TDLS_CH_SW
+int issue_tdls_ch_switch_req(_adapter *padapter, struct sta_info *ptdls_sta);
+int issue_tdls_ch_switch_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack);
+#endif
+sint On_TDLS_Dis_Rsp(_adapter *adapter, union recv_frame *precv_frame);
+sint On_TDLS_Setup_Req(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Setup_Rsp(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Setup_Cfm(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Dis_Req(_adapter *adapter, union recv_frame *precv_frame);
+int On_TDLS_Teardown(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Peer_Traffic_Indication(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+int On_TDLS_Peer_Traffic_Rsp(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+#ifdef CONFIG_TDLS_CH_SW
+sint On_TDLS_Ch_Switch_Req(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+sint On_TDLS_Ch_Switch_Rsp(_adapter *adapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta);
+void rtw_build_tdls_ch_switch_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_ch_switch_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+#endif
+void rtw_build_tdls_setup_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_setup_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_setup_cfm_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_teardown_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_dis_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt);
+void rtw_build_tdls_dis_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, u8 privacy);
+void rtw_build_tdls_peer_traffic_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tdls_peer_traffic_indication_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta);
+void rtw_build_tunneled_probe_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe);
+void rtw_build_tunneled_probe_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe);
+
+int rtw_tdls_is_driver_setup(_adapter *padapter);
+void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta);
+const char *rtw_tdls_action_txt(enum TDLS_ACTION_FIELD action);
+#endif /* CONFIG_TDLS */
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_version.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_version.h
index d0471b2c8a6c..07dd46cf1d14 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_version.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_version.h
@@ -1,2 +1,2 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#define DRIVERVERSION	"v4.3.24.8_22657.20170607"
+#define DRIVERVERSION	"v5.3.12_28613.20180703"
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_vht.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_vht.h
index def791ab6355..52bd5665c16b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_vht.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_vht.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,15 +12,13 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_VHT_H_
 #define _RTW_VHT_H_
 
+#define VHT_CAP_IE_LEN 12
+#define VHT_OP_IE_LEN 5
+
 #define	LDPC_VHT_ENABLE_RX			BIT0
 #define	LDPC_VHT_ENABLE_TX			BIT1
 #define	LDPC_VHT_TEST_TX_ENABLE		BIT2
@@ -30,16 +29,7 @@
 #define	STBC_VHT_TEST_TX_ENABLE		BIT2
 #define	STBC_VHT_CAP_TX				BIT3
 
-#define	BEAMFORMING_VHT_BEAMFORMER_ENABLE	BIT0	// Declare our NIC supports beamformer
-#define	BEAMFORMING_VHT_BEAMFORMEE_ENABLE	BIT1	// Declare our NIC supports beamformee
-#define	BEAMFORMING_VHT_MU_MIMO_AP_ENABLE		BIT2			/*Declare our NIC support MU-MIMO AP mode*/
-#define	BEAMFORMING_VHT_MU_MIMO_STA_ENABLE	BIT3			/*Declare our NIC support MU-MIMO STA mode*/
-#define	BEAMFORMING_VHT_BEAMFORMER_TEST		BIT4			/*Transmiting Beamforming no matter the target supports it or not*/
-#define	BEAMFORMING_VHT_BEAMFORMER_STS_CAP		(BIT8|BIT9|BIT10)		/*Asoc rsp cap*/
-#define	BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM		(BIT12|BIT13|BIT14)		/*Asoc rsp cap*/
-
-
-//VHT capability info
+/* VHT capability info */
 #define SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 0, 2, _val)
 #define SET_VHT_CAPABILITY_ELE_CHL_WIDTH(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 2, 2, _val)
 #define SET_VHT_CAPABILITY_ELE_RX_LDPC(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 4, 1, _val)
@@ -56,12 +46,12 @@
 #define SET_VHT_CAPABILITY_ELE_MU_BFEE(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 4, 1, _val)
 #define SET_VHT_CAPABILITY_ELE_TXOP_PS(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 5, 1, _val)
 #define SET_VHT_CAPABILITY_ELE_HTC_VHT(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 6, 1, _val)
-#define SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(_pEleStart, _val)		SET_BITS_TO_LE_2BYTE((_pEleStart)+2, 7, 3, _val) //B23~B25
+#define SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(_pEleStart, _val)		SET_BITS_TO_LE_2BYTE((_pEleStart)+2, 7, 3, _val) /* B23~B25 */
 #define SET_VHT_CAPABILITY_ELE_LINK_ADAPTION(_pEleStart, _val)				SET_BITS_TO_LE_1BYTE((_pEleStart)+2, 2, 2, _val)
 #define SET_VHT_CAPABILITY_ELE_MCS_RX_MAP(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+4, 0, 16, _val)   /* B0~B15 indicate Rx MCS MAP, we write 0 to indicate MCS0~7. by page */
-#define SET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+6, 0, 13, _val)  
+#define SET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+6, 0, 13, _val)
 #define SET_VHT_CAPABILITY_ELE_MCS_TX_MAP(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+8, 0, 16, _val)   /* B0~B15 indicate Tx MCS MAP, we write 0 to indicate MCS0~7. by page */
-#define SET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+10, 0, 13, _val)  
+#define SET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(_pEleStart, _val)				SET_BITS_TO_LE_2BYTE((_pEleStart)+10, 0, 13, _val)
 
 
 #define GET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(_pEleStart)			LE_BITS_TO_1BYTE(_pEleStart, 0, 2)
@@ -76,25 +66,27 @@
 /*phydm-beamforming*/
 #define GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(_pEleStart)	LE_BITS_TO_2BYTE((_pEleStart)+1, 5, 3)
 #define GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(_pEleStart)	LE_BITS_TO_2BYTE((_pEleStart)+2, 0, 3)
+#define GET_VHT_CAPABILITY_ELE_MU_BFER(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+2, 3, 1)
+#define GET_VHT_CAPABILITY_ELE_MU_BFEE(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+2, 4, 1)
 #define GET_VHT_CAPABILITY_ELE_TXOP_PS(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+2, 5, 1)
 #define GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(_pEleStart)	LE_BITS_TO_2BYTE((_pEleStart)+2, 7, 3)
 #define GET_VHT_CAPABILITY_ELE_RX_MCS(_pEleStart)					       ((_pEleStart)+4)
-#define GET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(_pEleStart)			LE_BITS_TO_2BYTE((_pEleStart)+6, 0, 13)  
+#define GET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(_pEleStart)			LE_BITS_TO_2BYTE((_pEleStart)+6, 0, 13)
 #define GET_VHT_CAPABILITY_ELE_TX_MCS(_pEleStart)					       ((_pEleStart)+8)
-#define GET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(_pEleStart)			LE_BITS_TO_2BYTE((_pEleStart)+10, 0, 13)  
+#define GET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(_pEleStart)			LE_BITS_TO_2BYTE((_pEleStart)+10, 0, 13)
 
 
-//VHT Operation Information Element
+/* VHT Operation Information Element */
 #define SET_VHT_OPERATION_ELE_CHL_WIDTH(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 0, 8, _val)
 #define SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart+1, 0, 8, _val)
 #define SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart+2, 0, 8, _val)
 #define SET_VHT_OPERATION_ELE_BASIC_MCS_SET(_pEleStart, _val)			SET_BITS_TO_LE_2BYTE((_pEleStart)+3, 0, 16, _val)
 
-#define GET_VHT_OPERATION_ELE_CHL_WIDTH(_pEleStart)		LE_BITS_TO_1BYTE(_pEleStart,0,8)
-#define GET_VHT_OPERATION_ELE_CENTER_FREQ1(_pEleStart)	LE_BITS_TO_1BYTE((_pEleStart)+1,0,8)
-#define GET_VHT_OPERATION_ELE_CENTER_FREQ2(_pEleStart)     LE_BITS_TO_1BYTE((_pEleStart)+2,0,8)
+#define GET_VHT_OPERATION_ELE_CHL_WIDTH(_pEleStart)		LE_BITS_TO_1BYTE(_pEleStart, 0, 8)
+#define GET_VHT_OPERATION_ELE_CENTER_FREQ1(_pEleStart)	LE_BITS_TO_1BYTE((_pEleStart)+1, 0, 8)
+#define GET_VHT_OPERATION_ELE_CENTER_FREQ2(_pEleStart)     LE_BITS_TO_1BYTE((_pEleStart)+2, 0, 8)
 
-//VHT Operating Mode 
+/* VHT Operating Mode */
 #define SET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(_pEleStart, _val)		SET_BITS_TO_LE_1BYTE(_pEleStart, 0, 2, _val)
 #define SET_VHT_OPERATING_MODE_FIELD_RX_NSS(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE(_pEleStart, 4, 3, _val)
 #define SET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(_pEleStart, 7, 1, _val)
@@ -105,27 +97,50 @@
 #define SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE((_pEleStart)+7, 6, 1, _val)
 #define GET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+7, 6, 1)
 
-struct vht_priv
-{
+#define VHT_MAX_MPDU_LEN_MAX 3
+extern const u16 _vht_max_mpdu_len[];
+#define vht_max_mpdu_len(val) (((val) >= VHT_MAX_MPDU_LEN_MAX) ? _vht_max_mpdu_len[VHT_MAX_MPDU_LEN_MAX] : _vht_max_mpdu_len[(val)])
+
+#define VHT_SUP_CH_WIDTH_SET_MAX 3
+extern const u8 _vht_sup_ch_width_set_to_bw_cap[];
+#define vht_sup_ch_width_set_to_bw_cap(set) (((set) >= VHT_SUP_CH_WIDTH_SET_MAX) ? _vht_sup_ch_width_set_to_bw_cap[VHT_SUP_CH_WIDTH_SET_MAX] : _vht_sup_ch_width_set_to_bw_cap[(set)])
+extern const char *const _vht_sup_ch_width_set_str[];
+#define vht_sup_ch_width_set_str(set) (((set) >= VHT_SUP_CH_WIDTH_SET_MAX) ? _vht_sup_ch_width_set_str[VHT_SUP_CH_WIDTH_SET_MAX] : _vht_sup_ch_width_set_str[(set)])
+
+#define VHT_MAX_AMPDU_LEN(f) ((1 << (13 + f)) - 1)
+void dump_vht_cap_ie(void *sel, const u8 *ie, u32 ie_len);
+
+#define VHT_OP_CH_WIDTH_MAX 4
+extern const char *const _vht_op_ch_width_str[];
+#define vht_op_ch_width_str(ch_width) (((ch_width) >= VHT_OP_CH_WIDTH_MAX) ? _vht_op_ch_width_str[VHT_OP_CH_WIDTH_MAX] : _vht_op_ch_width_str[(ch_width)])
+
+void dump_vht_op_ie(void *sel, const u8 *ie, u32 ie_len);
+
+struct vht_priv {
 	u8	vht_option;
 
 	u8	ldpc_cap;
 	u8	stbc_cap;
 	u16	beamform_cap;
+	u8	ap_is_mu_bfer;
 
-	u8	sgi_80m;//short GI
+	u8	sgi_80m;/* short GI */
 	u8	ampdu_len;
 
-	u8	vht_op_mode_notify;
 	u8	vht_highest_rate;
 	u8	vht_mcs_map[2];
 
-	u8	vht_cap[32];
+	u8 op_present:1; /* vht_op is present */
+	u8 notify_present:1; /* vht_op_mode_notify is present */
+
+	u8 vht_cap[32];
+	u8 vht_op[VHT_OP_IE_LEN];
+	u8 vht_op_mode_notify;
 };
 
 u8	rtw_get_vht_highest_rate(u8 *pvht_mcs_map);
 u16	rtw_vht_mcs_to_data_rate(u8 bw, u8 short_GI, u8 vht_mcs_rate);
-u64	rtw_vht_rate_to_bitmap(u8 *pVHTRate);
+u64	rtw_vht_mcs_map_to_bitmap(u8 *mcs_map, u8 nss);
 void	rtw_vht_use_default_setting(_adapter *padapter);
 u32	rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel);
 u32	rtw_build_vht_op_mode_notify_ie(_adapter *padapter, u8 *pbuf, u8 bw);
@@ -138,6 +153,8 @@ void	rtw_process_vht_op_mode_notify(_adapter *padapter, u8 *pframe, PVOID sta);
 u32	rtw_restructure_vht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len);
 void	VHTOnAssocRsp(_adapter *padapter);
 u8	rtw_vht_mcsmap_to_nss(u8 *pvht_mcs_map);
-
-#endif	//_RTW_VHT_H_
-
+void rtw_vht_nss_to_mcsmap(u8 nss, u8 *target_mcs_map, u8 *cur_mcs_map);
+void rtw_vht_ies_attach(_adapter *padapter, WLAN_BSSID_EX *pcur_network);
+void rtw_vht_ies_detach(_adapter *padapter, WLAN_BSSID_EX *pcur_network);
+void rtw_check_for_vht20(_adapter *adapter, u8 *ies, int ies_len);
+#endif /* _RTW_VHT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wapi.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wapi.h
index cf1111cfe963..8e2479a46ba3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wapi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wapi.h
@@ -1,223 +1,231 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#ifndef __INC_WAPI_H
-#define __INC_WAPI_H
-
-
-#define CONFIG_WAPI_SW_SMS4
-#define WAPI_DEBUG
-
-#define SMS4_MIC_LEN                16
-#define WAPI_EXT_LEN                18
-#define MAX_WAPI_IE_LEN		    256
-#define sMacHdrLng				24		// octets in data header, no WEP
-
-#ifdef WAPI_DEBUG
-
-/* WAPI trace debug */
-extern u32 wapi_debug_component;
-
-static inline void dump_buf(u8 *buf, u32 len)
-{
-	u32 i;
-	printk("-----------------Len %d----------------\n", len);
-	for(i=0; i<len; i++)
-		printk("%2.2x-", *(buf+i));
-	printk("\n");
-}
-
-#define WAPI_TRACE(component, x, args...) \
-do { if(wapi_debug_component & (component)) \
-	printk(KERN_DEBUG "WAPI" ":" x "" , \
-	       ##args);\
-}while(0);
-
-#define WAPI_DATA(component, x, buf, len) \
-do { if(wapi_debug_component & (component)){ \
-	printk("%s:\n", x);\
-	dump_buf((buf), (len));}\
-}while(0);
-
-#define RT_ASSERT_RET(_Exp)								\
-		if(!(_Exp))									\
-		{											\
-			printk("RTWLAN: ");					\
-                	printk( "Assertion failed! %s,%s,line=%d\n", \
-                	#_Exp,__FUNCTION__,__LINE__);          \
-			return;						\
-		}
-#define RT_ASSERT_RET_VALUE(_Exp,Ret)								\
-		if(!(_Exp))									\
-		{											\
-			printk("RTWLAN: ");					\
-                	printk( "Assertion failed! %s,%s,line=%d\n", \
-                	#_Exp,__FUNCTION__,__LINE__);          \
-			return (Ret);						\
-		}
-
-#else
-#define RT_ASSERT_RET(_Exp) do {} while(0)
-#define RT_ASSERT_RET_VALUE(_Exp,Ret) do {} while(0)
-#define WAPI_TRACE(component, x, args...) do {} while(0)
-#define WAPI_DATA(component, x, buf, len) do {} while(0)
-#endif
-
-
-enum WAPI_DEBUG {
-	WAPI_INIT				= 1,
-	WAPI_API				= 1<<1,
-	WAPI_TX				= 1<<2,
-	WAPI_RX				= 1<<3,
-	WAPI_MLME				= 1<<4,
-	WAPI_IOCTL				= 1<<5,
-	WAPI_ERR		        	= 1<<31
-};
-
-#define			WAPI_MAX_BKID_NUM				4
-#define			WAPI_MAX_STAINFO_NUM			4
-#define			WAPI_CAM_ENTRY_NUM			14	// 28/2=14
-
-typedef struct  _RT_WAPI_BKID
-{
-	struct list_head	list;
-	u8				bkid[16];
-}RT_WAPI_BKID,*PRT_WAPI_BKID;
-
-typedef struct  _RT_WAPI_KEY
-{
-	u8			dataKey[16];
-	u8			micKey[16];
-	u8			keyId;
-	bool			bSet;
-	bool             bTxEnable;
-}RT_WAPI_KEY,*PRT_WAPI_KEY;
-
-typedef enum _RT_WAPI_PACKET_TYPE
-{
-	WAPI_NONE = 0,
-	WAPI_PREAUTHENTICATE=1,
-	WAPI_STAKEY_REQUEST=2,
-	WAPI_AUTHENTICATE_ACTIVE=3,
-	WAPI_ACCESS_AUTHENTICATE_REQUEST=4,
-	WAPI_ACCESS_AUTHENTICATE_RESPONSE=5,
-	WAPI_CERTIFICATE_AUTHENTICATE_REQUEST=6,
-	WAPI_CERTIFICATE_AUTHENTICATE_RESPONSE=7,
-	WAPI_USK_REQUEST=8,
-	WAPI_USK_RESPONSE=9,
-	WAPI_USK_CONFIRM=10,
-	WAPI_MSK_NOTIFICATION=11,
-	WAPI_MSK_RESPONSE=12
-}RT_WAPI_PACKET_TYPE;
-
-typedef struct	_RT_WAPI_STA_INFO
-{
-	struct list_head		list;
-	u8					PeerMacAddr[6];
-	RT_WAPI_KEY		      wapiUsk;
-	RT_WAPI_KEY		      wapiUskUpdate;
-	RT_WAPI_KEY		      wapiMsk;
-	RT_WAPI_KEY		      wapiMskUpdate;
-	u8					lastRxUnicastPN[16];
-	u8					lastTxUnicastPN[16];
-	u8					lastRxMulticastPN[16];
-	u8					lastRxUnicastPNBEQueue[16];
-	u8					lastRxUnicastPNBKQueue[16];
-	u8					lastRxUnicastPNVIQueue[16];
-	u8					lastRxUnicastPNVOQueue[16];
-	bool					bSetkeyOk;
-	bool					bAuthenticateInProgress;
-	bool					bAuthenticatorInUpdata;
-}RT_WAPI_STA_INFO,*PRT_WAPI_STA_INFO;
-
-//Added for HW wapi en/decryption
-typedef struct _RT_WAPI_CAM_ENTRY{
-	//RT_LIST_ENTRY		list;
-	u8			IsUsed;
-	u8			entry_idx;//for cam entry
-	u8			keyidx;	// 0 or 1,new or old key
-	u8			PeerMacAddr[6];
-	u8			type;	//should be 110,wapi
-}RT_WAPI_CAM_ENTRY,*PRT_WAPI_CAM_ENTRY;
-
-typedef struct _RT_WAPI_T
-{
-//BKID
-	RT_WAPI_BKID		wapiBKID[WAPI_MAX_BKID_NUM];
-	struct list_head		wapiBKIDIdleList;
-	struct list_head  		wapiBKIDStoreList;
-//Key for Tx Multicast/Broadcast
-	RT_WAPI_KEY		      wapiTxMsk;
-
-//sec related
-	u8				lastTxMulticastPN[16];
-//STA list
-	RT_WAPI_STA_INFO	wapiSta[WAPI_MAX_STAINFO_NUM];
-	struct list_head		wapiSTAIdleList;
-	struct list_head		wapiSTAUsedList;
-//
-	bool				bWapiEnable;
-
-//store WAPI IE
-	u8				wapiIE[256];
-	u8				wapiIELength;
-	bool				bWapiPSK;
-//last sequece number for wai packet
-	u16				wapiSeqnumAndFragNum;
-	int extra_prefix_len;
-	int extra_postfix_len;
-
-	RT_WAPI_CAM_ENTRY	wapiCamEntry[WAPI_CAM_ENTRY_NUM];
-}RT_WAPI_T,*PRT_WAPI_T;
-
-typedef struct _WLAN_HEADER_WAPI_EXTENSION
-{
-    u8      KeyIdx;
-    u8      Reserved;
-    u8      PN[16];
-} WLAN_HEADER_WAPI_EXTENSION, *PWLAN_HEADER_WAPI_EXTENSION;
-
-u32 WapiComparePN(u8 *PN1, u8 *PN2);
-
-
-void rtw_wapi_init(_adapter *padapter);
-
-void rtw_wapi_free(_adapter *padapter);
-
-void rtw_wapi_disable_tx(_adapter *padapter);
-
-u8 rtw_wapi_is_wai_packet(_adapter* padapter,u8 *pkt_data);
-
-void rtw_wapi_update_info(_adapter *padapter, union recv_frame *precv_frame);
-
-u8 rtw_wapi_check_for_drop(_adapter *padapter, union recv_frame *precv_frame);
-
-void rtw_build_probe_resp_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
-
-void rtw_build_beacon_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
-
-void rtw_build_assoc_req_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
-
-void rtw_wapi_on_assoc_ok(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
-
-void rtw_wapi_return_one_sta_info(_adapter *padapter, u8 *MacAddr);
-
-void rtw_wapi_return_all_sta_info(_adapter *padapter);
-
-void rtw_wapi_clear_cam_entry(_adapter *padapter, u8 *pMacAddr);
-
-void rtw_wapi_clear_all_cam_entry(_adapter *padapter);
-
-void rtw_wapi_set_key(_adapter *padapter, RT_WAPI_KEY *pWapiKey, RT_WAPI_STA_INFO *pWapiSta, u8 bGroupKey, u8 bUseDefaultKey);
-
-int rtw_wapi_create_event_send(_adapter *padapter, u8 EventId, u8 *MacAddr, u8 *Buff, u16 BufLen);
-
-u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe);
-
-u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe);
-
-void rtw_wapi_get_iv(_adapter *padapter, u8*pRA, u8*IV);
-
-u8 WapiIncreasePN(u8 *PN, u8 AddCount);
-
-bool rtw_wapi_drop_for_key_absent(_adapter *padapter,u8 *pRA);
-
-#endif
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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_WAPI_H
+#define __INC_WAPI_H
+
+
+#define CONFIG_WAPI_SW_SMS4
+#define WAPI_DEBUG
+
+#define SMS4_MIC_LEN                16
+#define WAPI_EXT_LEN                18
+#define MAX_WAPI_IE_LEN		    256
+#define sMacHdrLng				24		/* octets in data header, no WEP */
+
+#ifdef WAPI_DEBUG
+
+/* WAPI trace debug */
+extern u32 wapi_debug_component;
+
+static inline void dump_buf(u8 *buf, u32 len)
+{
+	u32 i;
+	printk("-----------------Len %d----------------\n", len);
+	for (i = 0; i < len; i++)
+		printk("%2.2x-", *(buf + i));
+	printk("\n");
+}
+
+#define WAPI_TRACE(component, x, args...) \
+	do { if (wapi_debug_component & (component)) \
+			printk(KERN_DEBUG "WAPI" ":" x "" , \
+			       ##args);\
+	} while (0);
+
+#define WAPI_DATA(component, x, buf, len) \
+	do { if (wapi_debug_component & (component)) { \
+			printk("%s:\n", x);\
+			dump_buf((buf), (len)); } \
+	} while (0);
+
+#define RT_ASSERT_RET(_Exp)								\
+	if (!(_Exp)) {									\
+		printk("RTWLAN: ");					\
+		printk("Assertion failed! %s,%s, line=%d\n", \
+		       #_Exp, __FUNCTION__, __LINE__);          \
+		return;						\
+	}
+#define RT_ASSERT_RET_VALUE(_Exp, Ret)								\
+	if (!(_Exp)) {									\
+		printk("RTWLAN: ");					\
+		printk("Assertion failed! %s,%s, line=%d\n", \
+		       #_Exp, __FUNCTION__, __LINE__);          \
+		return Ret;						\
+	}
+
+#else
+#define RT_ASSERT_RET(_Exp) do {} while (0)
+#define RT_ASSERT_RET_VALUE(_Exp, Ret) do {} while (0)
+#define WAPI_TRACE(component, x, args...) do {} while (0)
+#define WAPI_DATA(component, x, buf, len) do {} while (0)
+#endif
+
+
+enum WAPI_DEBUG {
+	WAPI_INIT				= 1,
+	WAPI_API				= 1 << 1,
+	WAPI_TX				= 1 << 2,
+	WAPI_RX				= 1 << 3,
+	WAPI_MLME				= 1 << 4,
+	WAPI_IOCTL				= 1 << 5,
+	WAPI_ERR			= 1 << 31
+};
+
+#define			WAPI_MAX_BKID_NUM				4
+#define			WAPI_MAX_STAINFO_NUM			4
+#define			WAPI_CAM_ENTRY_NUM			14	/* 28/2 = 14 */
+
+typedef struct  _RT_WAPI_BKID {
+	struct list_head	list;
+	u8				bkid[16];
+} RT_WAPI_BKID, *PRT_WAPI_BKID;
+
+typedef struct  _RT_WAPI_KEY {
+	u8			dataKey[16];
+	u8			micKey[16];
+	u8			keyId;
+	bool			bSet;
+	bool             bTxEnable;
+} RT_WAPI_KEY, *PRT_WAPI_KEY;
+
+typedef enum _RT_WAPI_PACKET_TYPE {
+	WAPI_NONE = 0,
+	WAPI_PREAUTHENTICATE = 1,
+	WAPI_STAKEY_REQUEST = 2,
+	WAPI_AUTHENTICATE_ACTIVE = 3,
+	WAPI_ACCESS_AUTHENTICATE_REQUEST = 4,
+	WAPI_ACCESS_AUTHENTICATE_RESPONSE = 5,
+	WAPI_CERTIFICATE_AUTHENTICATE_REQUEST = 6,
+	WAPI_CERTIFICATE_AUTHENTICATE_RESPONSE = 7,
+	WAPI_USK_REQUEST = 8,
+	WAPI_USK_RESPONSE = 9,
+	WAPI_USK_CONFIRM = 10,
+	WAPI_MSK_NOTIFICATION = 11,
+	WAPI_MSK_RESPONSE = 12
+} RT_WAPI_PACKET_TYPE;
+
+typedef struct	_RT_WAPI_STA_INFO {
+	struct list_head		list;
+	u8					PeerMacAddr[6];
+	RT_WAPI_KEY		      wapiUsk;
+	RT_WAPI_KEY		      wapiUskUpdate;
+	RT_WAPI_KEY		      wapiMsk;
+	RT_WAPI_KEY		      wapiMskUpdate;
+	u8					lastRxUnicastPN[16];
+	u8					lastTxUnicastPN[16];
+	u8					lastRxMulticastPN[16];
+	u8					lastRxUnicastPNBEQueue[16];
+	u8					lastRxUnicastPNBKQueue[16];
+	u8					lastRxUnicastPNVIQueue[16];
+	u8					lastRxUnicastPNVOQueue[16];
+	bool					bSetkeyOk;
+	bool					bAuthenticateInProgress;
+	bool					bAuthenticatorInUpdata;
+} RT_WAPI_STA_INFO, *PRT_WAPI_STA_INFO;
+
+/* Added for HW wapi en/decryption */
+typedef struct _RT_WAPI_CAM_ENTRY {
+	/* RT_LIST_ENTRY		list; */
+	u8			IsUsed;
+	u8			entry_idx;/* for cam entry */
+	u8			keyidx;	/* 0 or 1,new or old key */
+	u8			PeerMacAddr[6];
+	u8			type;	/* should be 110,wapi */
+} RT_WAPI_CAM_ENTRY, *PRT_WAPI_CAM_ENTRY;
+
+typedef struct _RT_WAPI_T {
+	/* BKID */
+	RT_WAPI_BKID		wapiBKID[WAPI_MAX_BKID_NUM];
+	struct list_head		wapiBKIDIdleList;
+	struct list_head		wapiBKIDStoreList;
+	/* Key for Tx Multicast/Broadcast */
+	RT_WAPI_KEY		      wapiTxMsk;
+
+	/* sec related */
+	u8				lastTxMulticastPN[16];
+	/* STA list */
+	RT_WAPI_STA_INFO	wapiSta[WAPI_MAX_STAINFO_NUM];
+	struct list_head		wapiSTAIdleList;
+	struct list_head		wapiSTAUsedList;
+	/*  */
+	bool				bWapiEnable;
+
+	/* store WAPI IE */
+	u8				wapiIE[256];
+	u8				wapiIELength;
+	bool				bWapiPSK;
+	/* last sequece number for wai packet */
+	u16				wapiSeqnumAndFragNum;
+	int extra_prefix_len;
+	int extra_postfix_len;
+
+	RT_WAPI_CAM_ENTRY	wapiCamEntry[WAPI_CAM_ENTRY_NUM];
+} RT_WAPI_T, *PRT_WAPI_T;
+
+typedef struct _WLAN_HEADER_WAPI_EXTENSION {
+	u8      KeyIdx;
+	u8      Reserved;
+	u8      PN[16];
+} WLAN_HEADER_WAPI_EXTENSION, *PWLAN_HEADER_WAPI_EXTENSION;
+
+u32 WapiComparePN(u8 *PN1, u8 *PN2);
+
+
+void rtw_wapi_init(_adapter *padapter);
+
+void rtw_wapi_free(_adapter *padapter);
+
+void rtw_wapi_disable_tx(_adapter *padapter);
+
+u8 rtw_wapi_is_wai_packet(_adapter *padapter, u8 *pkt_data);
+
+void rtw_wapi_update_info(_adapter *padapter, union recv_frame *precv_frame);
+
+u8 rtw_wapi_check_for_drop(_adapter *padapter, union recv_frame *precv_frame, u8 *ehdr_ops);
+
+void rtw_build_probe_resp_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
+
+void rtw_build_beacon_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
+
+void rtw_build_assoc_req_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib);
+
+void rtw_wapi_on_assoc_ok(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+
+void rtw_wapi_return_one_sta_info(_adapter *padapter, u8 *MacAddr);
+
+void rtw_wapi_return_all_sta_info(_adapter *padapter);
+
+void rtw_wapi_clear_cam_entry(_adapter *padapter, u8 *pMacAddr);
+
+void rtw_wapi_clear_all_cam_entry(_adapter *padapter);
+
+void rtw_wapi_set_key(_adapter *padapter, RT_WAPI_KEY *pWapiKey, RT_WAPI_STA_INFO *pWapiSta, u8 bGroupKey, u8 bUseDefaultKey);
+
+int rtw_wapi_create_event_send(_adapter *padapter, u8 EventId, u8 *MacAddr, u8 *Buff, u16 BufLen);
+
+u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe);
+
+u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe);
+
+void rtw_wapi_get_iv(_adapter *padapter, u8 *pRA, u8 *IV);
+
+u8 WapiIncreasePN(u8 *PN, u8 AddCount);
+
+bool rtw_wapi_drop_for_key_absent(_adapter *padapter, u8 *pRA);
+
+void rtw_wapi_set_set_encryption(_adapter *padapter, struct ieee_param *param);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wifi_regd.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wifi_regd.h
index 13679b809803..b5c5d62ff76e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wifi_regd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_wifi_regd.h
@@ -1,7 +1,16 @@
 /* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2009-2010  Realtek Corporation.
+ * Copyright(c) 2009-2010 - 2017 Realtek Corporation.
+ *
+ * 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.
  *
  *****************************************************************************/
 
@@ -18,10 +27,9 @@ enum country_code_type_t {
 
 	/*add new channel plan above this line */
 	COUNTRY_CODE_MAX
-}; 
+};
 
-int rtw_regd_init(_adapter *padapter);
-void rtw_reg_notify_by_driver(_adapter *adapter);
+void rtw_regd_apply_flags(struct wiphy *wiphy);
+int rtw_regd_init(struct wiphy *wiphy);
 
 #endif /* __RTW_WIFI_REGD_H__ */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_xmit.h
index bc507b436929..46d8c3181396 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/rtw_xmit.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,83 +12,84 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _RTW_XMIT_H_
 #define _RTW_XMIT_H_
 
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-#ifdef CONFIG_TX_AGGREGATION
-#define MAX_XMITBUF_SZ	(20480)	// 20k
-//#define SDIO_TX_AGG_MAX	5
-#else
-#define MAX_XMITBUF_SZ (1664)
-#define SDIO_TX_AGG_MAX	1
-#endif
+	#ifdef CONFIG_TX_AGGREGATION
+		#define MAX_XMITBUF_SZ	(20480)	/* 20k */
+		/* #define SDIO_TX_AGG_MAX	5 */
+	#else
+		#define MAX_XMITBUF_SZ (1664)
+		#define SDIO_TX_AGG_MAX	1
+	#endif
 
-#if defined CONFIG_SDIO_HCI
-#define NR_XMITBUFF	(16)
-#endif
-#if defined(CONFIG_GSPI_HCI)
-#define NR_XMITBUFF	(128)
-#endif
+	#if defined CONFIG_SDIO_HCI
+		#define NR_XMITBUFF	(16)
+	#endif
+	#if defined(CONFIG_GSPI_HCI)
+		#define NR_XMITBUFF	(128)
+	#endif
 
 #elif defined (CONFIG_USB_HCI)
 
-#ifdef CONFIG_USB_TX_AGGREGATION
-	#if defined(CONFIG_PLATFORM_ARM_SUNxI) || defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I) || defined(CONFIG_PLATFORM_ARM_SUN8I) || defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
-		#define MAX_XMITBUF_SZ (12288)  //12k 1536*8
-	#elif defined (CONFIG_PLATFORM_MSTAR)
-		#define MAX_XMITBUF_SZ	7680	// 7.5k
+	#ifdef CONFIG_USB_TX_AGGREGATION
+		#if defined(CONFIG_PLATFORM_ARM_SUNxI) || defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I) || defined(CONFIG_PLATFORM_ARM_SUN8I) || defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+			#define MAX_XMITBUF_SZ (12288)  /* 12k 1536*8 */
+		#elif defined (CONFIG_PLATFORM_MSTAR)
+			#define MAX_XMITBUF_SZ	7680	/* 7.5k */
+		#else
+			#define MAX_XMITBUF_SZ	(20480)	/* 20k */
+		#endif
 	#else
-	#define MAX_XMITBUF_SZ	(20480)	// 20k
+		#define MAX_XMITBUF_SZ	(2048)
 	#endif
-#else
-#define MAX_XMITBUF_SZ	(2048)
-#endif
 
-#ifdef CONFIG_SINGLE_XMIT_BUF
-#define NR_XMITBUFF	(1)
-#else
-#define NR_XMITBUFF	(4)
-#endif //CONFIG_SINGLE_XMIT_BUF
+	#ifdef CONFIG_SINGLE_XMIT_BUF
+		#define NR_XMITBUFF	(1)
+	#else
+		#define NR_XMITBUFF	(4)
+	#endif /* CONFIG_SINGLE_XMIT_BUF */
 #elif defined (CONFIG_PCI_HCI)
-#define MAX_XMITBUF_SZ	(1664)
-#define NR_XMITBUFF	(128)
+#ifdef CONFIG_TX_AMSDU
+	#define MAX_XMITBUF_SZ	(3500)
+#else
+	#define MAX_XMITBUF_SZ	(1664)
+#endif
+	#define NR_XMITBUFF	(128)
 #endif
 
 #ifdef PLATFORM_OS_CE
-#define XMITBUF_ALIGN_SZ 4
-#else
-#ifdef CONFIG_PCI_HCI
-#define XMITBUF_ALIGN_SZ 4
-#else
-#ifdef USB_XMITBUF_ALIGN_SZ
-#define XMITBUF_ALIGN_SZ (USB_XMITBUF_ALIGN_SZ)
+	#define XMITBUF_ALIGN_SZ 4
 #else
-#define XMITBUF_ALIGN_SZ 512
-#endif
-#endif
+	#ifdef CONFIG_PCI_HCI
+		#define XMITBUF_ALIGN_SZ 4
+	#else
+		#ifdef USB_XMITBUF_ALIGN_SZ
+			#define XMITBUF_ALIGN_SZ (USB_XMITBUF_ALIGN_SZ)
+		#else
+			#define XMITBUF_ALIGN_SZ 512
+		#endif
+	#endif
 #endif
 
-// xmit extension buff defination
+/* xmit extension buff defination */
 #define MAX_XMIT_EXTBUF_SZ	(1536)
 
 #ifdef CONFIG_SINGLE_XMIT_BUF
-#define NR_XMIT_EXTBUFF	(1)
+	#define NR_XMIT_EXTBUFF	(1)
 #else
-#define NR_XMIT_EXTBUFF	(32)
+	#define NR_XMIT_EXTBUFF	(32)
 #endif
 
 #ifdef CONFIG_RTL8812A
-#define MAX_CMDBUF_SZ	(512*14)
+	#define MAX_CMDBUF_SZ	(512 * 18)
+#elif defined(CONFIG_RTL8723D) && defined(CONFIG_LPS_POFF)
+	#define MAX_CMDBUF_SZ	(128*70) /*(8960)*/
 #else
-#define MAX_CMDBUF_SZ	(5120)	//(4096)
+	#define MAX_CMDBUF_SZ	(5120)	/* (4096) */
 #endif
 
 #define MAX_NUMBLKS		(1)
@@ -109,114 +111,148 @@
 #define HW_QUEUE_ENTRY	8
 
 #ifdef CONFIG_PCI_HCI
-//#define TXDESC_NUM						64
-#define TXDESC_NUM						128
-#define TXDESC_NUM_BE_QUEUE			128
+	#ifdef CONFIG_TRX_BD_ARCH
+		#define TX_BD_NUM			(128+1)	/* +1 result from ring buffer */
+	#else
+		#define TXDESC_NUM			128
+	#endif
 #endif
 
 #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)
+	do {\
+		dot11txpn.val = (dot11txpn.val == 0xffffff) ? 0 : (dot11txpn.val + 1);\
+		pattrib_iv[0] = dot11txpn._byte_.TSC0;\
+		pattrib_iv[1] = dot11txpn._byte_.TSC1;\
+		pattrib_iv[2] = dot11txpn._byte_.TSC2;\
+		pattrib_iv[3] = ((keyidx & 0x3)<<6);\
+	} 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)
+	do {\
+		dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 : (dot11txpn.val + 1);\
+		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;\
+	} 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)
-
+	do {\
+		dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 : (dot11txpn.val + 1);\
+		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;\
+	} while (0)
+
+/* Check if AMPDU Tx is supported or not. If it is supported,
+* it need to check "amsdu in ampdu" is supported or not.
+* (ampdu_en, amsdu_ampdu_en) =
+* (0, x) : AMPDU is not enable, but AMSDU is valid to send.
+* (1, 0) : AMPDU is enable, AMSDU in AMPDU is not enable. So, AMSDU is not valid to send.
+* (1, 1) : AMPDU and AMSDU in AMPDU are enable. So, AMSDU is valid to send.
+*/
+#define IS_AMSDU_AMPDU_NOT_VALID(pattrib)\
+	 ((pattrib->ampdu_en == _TRUE) && (pattrib->amsdu_ampdu_en == _FALSE))
+
+#define IS_AMSDU_AMPDU_VALID(pattrib)\
+	 !((pattrib->ampdu_en == _TRUE) && (pattrib->amsdu_ampdu_en == _FALSE))
 
 #define HWXMIT_ENTRY	4
 
-// For Buffer Descriptor ring architecture
-#ifdef BUF_DESC_ARCH	
-#if defined(CONFIG_RTL8192E)
-#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
-#elif defined(CONFIG_RTL8814A)
-#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
-#endif
+/* For Buffer Descriptor ring architecture */
+#if defined(BUF_DESC_ARCH) || defined(CONFIG_TRX_BD_ARCH)
+	#if defined(CONFIG_RTL8192E)
+		#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
+	#elif defined(CONFIG_RTL8814A)
+		#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
+	#else
+		#define TX_BUFFER_SEG_NUM	1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
+	#endif
 #endif
 
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8703B) || defined(CONFIG_RTL8188F)
-#define TXDESC_SIZE 40
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) ||\
+	defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8192E) ||\
+	defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8703B) ||\
+	defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8723D)
+	#define TXDESC_SIZE 40
+#elif defined(CONFIG_RTL8822B)
+	#define TXDESC_SIZE 48		/* HALMAC_TX_DESC_SIZE_8822B */
+#elif defined(CONFIG_RTL8821C)
+	#define TXDESC_SIZE 48		/* HALMAC_TX_DESC_SIZE_8821C */
 #else
-#define TXDESC_SIZE 32 /* old IC (ex: 8188E) */
+	#define TXDESC_SIZE 32 /* old IC (ex: 8188E) */
 #endif
 
 #ifdef CONFIG_TX_EARLY_MODE
-#define EARLY_MODE_INFO_SIZE	8
+	#define EARLY_MODE_INFO_SIZE	8
 #endif
 
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-#define TXDESC_OFFSET TXDESC_SIZE
+	#define TXDESC_OFFSET TXDESC_SIZE
 #endif
 
 #ifdef CONFIG_USB_HCI
-#ifdef USB_PACKET_OFFSET_SZ
-#define PACKET_OFFSET_SZ (USB_PACKET_OFFSET_SZ)
-#else
-#define PACKET_OFFSET_SZ (8)
-#endif
-#define TXDESC_OFFSET (TXDESC_SIZE + PACKET_OFFSET_SZ)
+	#ifdef USB_PACKET_OFFSET_SZ
+		#define PACKET_OFFSET_SZ (USB_PACKET_OFFSET_SZ)
+	#else
+		#define PACKET_OFFSET_SZ (8)
+	#endif
+	#define TXDESC_OFFSET (TXDESC_SIZE + PACKET_OFFSET_SZ)
 #endif
 
 #ifdef CONFIG_PCI_HCI
-#if defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A)
-/* this section is defined for buffer descriptor ring architecture */
-#define TX_WIFI_INFO_SIZE (TXDESC_SIZE) /* it may add 802.11 hdr or others... */
-/* tx desc and payload are in the same buf */
-#define TXDESC_OFFSET (TX_WIFI_INFO_SIZE)
-#else
-/* tx desc and payload are NOT in the same buf */
-#define TXDESC_OFFSET (0)
-/* 8188ee/8723be/8812ae/8821ae has extra PCI DMA info in tx desc */
-#define TX_DESC_NEXT_DESC_OFFSET	(TXDESC_SIZE + 8)
-#endif
+	#if defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_TRX_BD_ARCH)
+		/* this section is defined for buffer descriptor ring architecture */
+		#define TX_WIFI_INFO_SIZE (TXDESC_SIZE) /* it may add 802.11 hdr or others... */
+		/* tx desc and payload are in the same buf */
+		#define TXDESC_OFFSET (TX_WIFI_INFO_SIZE)
+	#else
+		/* tx desc and payload are NOT in the same buf */
+		#define TXDESC_OFFSET (0)
+		/* 8188ee/8723be/8812ae/8821ae has extra PCI DMA info in tx desc */
+		#define TX_DESC_NEXT_DESC_OFFSET	(TXDESC_SIZE + 8)
+	#endif
 #endif /* CONFIG_PCI_HCI */
 
-enum TXDESC_SC{
+enum TXDESC_SC {
 	SC_DONT_CARE = 0x00,
-	SC_UPPER= 0x01,	
-	SC_LOWER=0x02,
-	SC_DUPLICATE=0x03
+	SC_UPPER = 0x01,
+	SC_LOWER = 0x02,
+	SC_DUPLICATE = 0x03
 };
 
 #ifdef CONFIG_PCI_HCI
-#define TXDESC_64_BYTES
-#elif defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8188F)
-#define TXDESC_40_BYTES
+	#ifndef CONFIG_TRX_BD_ARCH	/* CONFIG_TRX_BD_ARCH doesn't need this */
+		#define TXDESC_64_BYTES
+	#endif
+#elif defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8723B) \
+	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8723D)
+	#define TXDESC_40_BYTES
 #endif
 
-#if (defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A)) && defined(CONFIG_PCI_HCI) /* 8192ee or 8814ae */
-//8192EE_TODO
-struct tx_desc
-{
+#ifdef CONFIG_TRX_BD_ARCH
+struct tx_buf_desc {
+#ifdef CONFIG_64BIT_DMA
+#define TX_BUFFER_SEG_SIZE	4	/* in unit of DWORD */
+#else
+#define TX_BUFFER_SEG_SIZE	2	/* in unit of DWORD */
+#endif
+	unsigned int dword[TX_BUFFER_SEG_SIZE * (2 << TX_BUFFER_SEG_NUM)];
+} __packed;
+#elif (defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)) && defined(CONFIG_PCI_HCI) /* 8192ee or 8814ae */
+/* 8192EE_TODO */
+struct tx_desc {
 	unsigned int txdw0;
 	unsigned int txdw1;
 	unsigned int txdw2;
@@ -227,8 +263,7 @@ struct tx_desc
 	unsigned int txdw7;
 };
 #else
-struct tx_desc
-{
+struct tx_desc {
 	unsigned int txdw0;
 	unsigned int txdw1;
 	unsigned int txdw2;
@@ -241,16 +276,16 @@ struct tx_desc
 #if defined(TXDESC_40_BYTES) || defined(TXDESC_64_BYTES)
 	unsigned int txdw8;
 	unsigned int txdw9;
-#endif // TXDESC_40_BYTES
+#endif /* TXDESC_40_BYTES */
 
 #ifdef TXDESC_64_BYTES
 	unsigned int txdw10;
 	unsigned int txdw11;
 
-	// 2008/05/15 MH Because PCIE HW memory R/W 4K limit. And now,  our descriptor
-	// size is 40 bytes. If you use more than 102 descriptor( 103*40>4096), HW will execute
-	// memoryR/W CRC error. And then all DMA fetch will fail. We must decrease descriptor
-	// number or enlarge descriptor size as 64 bytes.
+	/* 2008/05/15 MH Because PCIE HW memory R/W 4K limit. And now,  our descriptor */
+	/* size is 40 bytes. If you use more than 102 descriptor( 103*40>4096), HW will execute */
+	/* memoryR/W CRC error. And then all DMA fetch will fail. We must decrease descriptor */
+	/* number or enlarge descriptor size as 64 bytes. */
 	unsigned int txdw12;
 	unsigned int txdw13;
 	unsigned int txdw14;
@@ -259,48 +294,71 @@ struct tx_desc
 };
 #endif
 
+#ifndef CONFIG_TRX_BD_ARCH
 union txdesc {
 	struct tx_desc txdesc;
-	unsigned int value[TXDESC_SIZE>>2];
+	unsigned int value[TXDESC_SIZE >> 2];
 };
+#endif
 
 #ifdef CONFIG_PCI_HCI
-#define PCI_MAX_TX_QUEUE_COUNT	8
+#define PCI_MAX_TX_QUEUE_COUNT	8	/* == HW_QUEUE_ENTRY */
 
 struct rtw_tx_ring {
 	unsigned char	qid;
+#ifdef CONFIG_TRX_BD_ARCH
+	struct tx_buf_desc	*buf_desc;
+#else
 	struct tx_desc	*desc;
+#endif
 	dma_addr_t	dma;
 	unsigned int	idx;
 	unsigned int	entries;
 	_queue		queue;
 	u32		qlen;
+#ifdef CONFIG_TRX_BD_ARCH
+	u16		hw_rp_cache;
+#endif
+};
+
+#ifdef DBG_TXBD_DESC_DUMP
+
+#define TX_BAK_FRMAE_CNT	10
+#define TX_BAK_DESC_LEN	48	/* byte */
+#define TX_BAK_DATA_LEN		30	/* byte */
+
+struct rtw_tx_desc_backup {
+	int tx_bak_rp;
+	int tx_bak_wp;
+	u8 tx_bak_desc[TX_BAK_DESC_LEN];
+	u8 tx_bak_data_hdr[TX_BAK_DATA_LEN];
+	u8 tx_desc_size;
 };
 #endif
+#endif
 
 struct	hw_xmit	{
-	//_lock xmit_lock;
-	//_list	pending;
+	/* _lock xmit_lock; */
+	/* _list	pending; */
 	_queue *sta_queue;
-	//struct hw_txqueue *phwtxqueue;
-	//sint	txcmdcnt;
+	/* struct hw_txqueue *phwtxqueue; */
+	/* sint	txcmdcnt; */
 	int	accnt;
 };
 
 #if 0
-struct pkt_attrib
-{
+struct pkt_attrib {
 	u8	type;
 	u8	subtype;
 	u8	bswenc;
 	u8	dhcp_pkt;
 	u16	ether_type;
-	int	pktlen;		//the original 802.3 pkt raw_data len (not include ether_hdr data)
-	int	pkt_hdrlen;	//the original 802.3 pkt header len
-	int	hdrlen;		//the WLAN Header Len
+	int	pktlen;		/* the original 802.3 pkt raw_data len (not include ether_hdr data) */
+	int	pkt_hdrlen;	/* the original 802.3 pkt header len */
+	int	hdrlen;		/* the WLAN Header Len */
 	int	nr_frags;
 	int	last_txcmdsz;
-	int	encrypt;	//when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith
+	int	encrypt;	/* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith */
 	u8	iv[8];
 	int	iv_len;
 	u8	icv[8];
@@ -308,52 +366,54 @@ struct pkt_attrib
 	int	priority;
 	int	ack_policy;
 	int	mac_id;
-	int	vcs_mode;	//virtual carrier sense method
+	int	vcs_mode;	/* virtual carrier sense method */
 
-	u8 	dst[ETH_ALEN];
+	u8	dst[ETH_ALEN];
 	u8	src[ETH_ALEN];
 	u8	ta[ETH_ALEN];
-	u8 	ra[ETH_ALEN];
+	u8	ra[ETH_ALEN];
 
 	u8	key_idx;
 
 	u8	qos_en;
 	u8	ht_en;
-	u8	raid;//rate adpative id
+	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	ch_offset;/* PRIME_CHNL_OFFSET */
+	u8	sgi;/* short GI */
+	u8	ampdu_en;/* tx ampdu enable */
+	u8	mdata;/* more data bit */
 	u8	eosp;
 
-	u8	triggered;//for ap mode handling Power Saving sta
+	u8	triggered;/* for ap mode handling Power Saving sta */
 
 	u32	qsel;
 	u16	seqnum;
 
-	struct sta_info * psta;
+	struct sta_info *psta;
 #ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
 	u8	hw_tcp_csum;
 #endif
 };
 #else
-//reduce size
-struct pkt_attrib
-{
+/* reduce size */
+struct pkt_attrib {
 	u8	type;
 	u8	subtype;
 	u8	bswenc;
 	u8	dhcp_pkt;
 	u16	ether_type;
 	u16	seqnum;
-	u8 	hw_ssn_sel;	//for HW_SEQ0,1,2,3
-	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 (not include ether_hdr data)
+	u8	hw_ssn_sel;	/* for HW_SEQ0,1,2,3 */
+	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 (not include ether_hdr data) */
 	u32	last_txcmdsz;
 	u8	nr_frags;
-	u8	encrypt;	//when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith
+	u8	encrypt;	/* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith */
+#if defined(CONFIG_CONCURRENT_MODE)
+	u8	bmc_camid;
+#endif
 	u8	iv_len;
 	u8	icv_len;
 	u8	iv[18];
@@ -361,33 +421,50 @@ struct pkt_attrib
 	u8	priority;
 	u8	ack_policy;
 	u8	mac_id;
-	u8	vcs_mode;	//virtual carrier sense method
-	u8 	dst[ETH_ALEN];
+	u8	vcs_mode;	/* virtual carrier sense method */
+	u8	dst[ETH_ALEN];
 	u8	src[ETH_ALEN];
 	u8	ta[ETH_ALEN];
-	u8 	ra[ETH_ALEN];
+	u8	ra[ETH_ALEN];
+#ifdef CONFIG_RTW_MESH
+	u8	mda[ETH_ALEN];	/* mesh da */
+	u8	msa[ETH_ALEN];	/* mesh sa */
+	u8	meshctrl_len;	/* Length of Mesh Control field */
+	u8	mesh_frame_mode;
+	#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	u8 mb2u;
+	#endif
+	u8 mfwd_ttl;
+	u32 mseq;
+#endif
 	u8	key_idx;
 	u8	qos_en;
 	u8	ht_en;
-	u8	raid;//rate adpative id
+	u8	raid;/* rate adpative id */
 	u8	bwmode;
-	u8	ch_offset;//PRIME_CHNL_OFFSET
-	u8	sgi;//short GI
-	u8	ampdu_en;//tx ampdu enable
-	u8	ampdu_spacing; //ampdu_min_spacing for peer sta's rx
-	u8	mdata;//more data bit
-	u8	pctrl;//per packet txdesc control enable
-	u8	triggered;//for ap mode handling Power Saving sta
+	u8	ch_offset;/* PRIME_CHNL_OFFSET */
+	u8	sgi;/* short GI */
+	u8	ampdu_en;/* tx ampdu enable */
+	u8	ampdu_spacing; /* ampdu_min_spacing for peer sta's rx */
+	u8	amsdu;
+	u8	amsdu_ampdu_en;/* tx amsdu in 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	order;//order bit
+	u8	order;/* order bit */
 	u8	eosp;
 	u8	rate;
 	u8	intel_proxim;
-	u8 	retry_ctrl;
+	u8	retry_ctrl;
 	u8   mbssid;
 	u8	ldpc;
 	u8	stbc;
-	struct sta_info * psta;
+#ifdef CONFIG_WMMPS_STA
+	u8	trigger_frame;
+#endif /* CONFIG_WMMPS_STA */
+	
+	struct sta_info *psta;
 #ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
 	u8	hw_tcp_csum;
 #endif
@@ -395,13 +472,13 @@ struct pkt_attrib
 	u8 rtsen;
 	u8 cts2self;
 	union Keytype	dot11tkiptxmickey;
-	//union Keytype	dot11tkiprxmickey;
+	/* union Keytype	dot11tkiprxmickey; */
 	union Keytype	dot118021x_UncstKey;
 
 #ifdef CONFIG_TDLS
 	u8 direct_link;
 	struct sta_info *ptdls_sta;
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 	u8 key_type;
 
 	u8 icmp_pkt;
@@ -409,11 +486,33 @@ struct pkt_attrib
 #ifdef CONFIG_BEAMFORMING
 	u16 txbf_p_aid;/*beamforming Partial_AID*/
 	u16 txbf_g_id;/*beamforming Group ID*/
- #endif
+
+	/*
+	 * 2'b00: Unicast NDPA
+	 * 2'b01: Broadcast NDPA
+	 * 2'b10: Beamforming Report Poll
+	 * 2'b11: Final Beamforming Report Poll
+	 */
+	u8 bf_pkt_type;
+#endif
 
 };
 #endif
 
+#ifdef CONFIG_RTW_MESH
+#define XATTRIB_GET_MCTRL_LEN(xattrib) ((xattrib)->meshctrl_len)
+#else
+#define XATTRIB_GET_MCTRL_LEN(xattrib) 0
+#endif
+
+#ifdef CONFIG_TX_AMSDU
+enum {
+	RTW_AMSDU_TIMER_UNSET = 0,
+	RTW_AMSDU_TIMER_SETTING,
+	RTW_AMSDU_TIMER_TIMEOUT,
+};
+#endif
+
 #define WLANHDR_OFFSET	64
 
 #define NULL_FRAMETAG		(0x0)
@@ -427,7 +526,7 @@ struct pkt_attrib
 
 #define MP_FRAMETAG		0x07
 
-#define TXAGG_FRAMETAG 	0x08
+#define TXAGG_FRAMETAG	0x08
 
 enum {
 	XMITBUF_DATA = 0,
@@ -437,8 +536,8 @@ enum {
 
 bool rtw_xmit_ac_blocked(_adapter *adapter);
 
-struct  submit_ctx{
-	u32 submit_time; /* */
+struct  submit_ctx {
+	systime submit_time; /* */
 	u32 timeout_ms; /* <0: not synchronous, 0: wait forever, >0: up to ms waiting */
 	int status; /* status for operation */
 #ifdef PLATFORM_LINUX
@@ -470,8 +569,7 @@ int rtw_sctx_wait(struct submit_ctx *sctx, const char *msg);
 void rtw_sctx_done_err(struct submit_ctx **sctx, int status);
 void rtw_sctx_done(struct submit_ctx **sctx);
 
-struct xmit_buf
-{
+struct xmit_buf {
 	_list	list;
 
 	_adapter *padapter;
@@ -482,7 +580,7 @@ struct xmit_buf
 
 	void *priv_data;
 
-	u16 buf_tag; // 0: Normal xmitbuf, 1: extension xmitbuf, 2:cmd xmitbuf
+	u16 buf_tag; /* 0: Normal xmitbuf, 1: extension xmitbuf, 2:cmd xmitbuf */
 	u16 flags;
 	u32 alloc_sz;
 
@@ -492,10 +590,13 @@ struct xmit_buf
 
 #ifdef CONFIG_USB_HCI
 
-	//u32 sz[8];
+	/* u32 sz[8]; */
 	u32	ff_hwaddr;
+#ifdef RTW_HALMAC
+	u8 bulkout_id; /* for halmac */
+#endif /* RTW_HALMAC */
 
-#if defined(PLATFORM_OS_XP)||defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
+#if defined(PLATFORM_OS_XP) || defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD)
 	PURB	pxmit_urb[8];
 	dma_addr_t dma_transfer_addr;	/* (in) dma addr for transfer_buffer */
 #endif
@@ -520,7 +621,7 @@ struct xmit_buf
 	u8 *ptail;
 	u8 *pend;
 	u32 ff_hwaddr;
-	u8	pg_num;	
+	u8	pg_num;
 	u8	agg_num;
 #ifdef PLATFORM_OS_XP
 	PMDL pxmitbuf_mdl;
@@ -530,18 +631,21 @@ struct xmit_buf
 #endif
 
 #ifdef CONFIG_PCI_HCI
+#ifdef CONFIG_TRX_BD_ARCH
+	/*struct tx_buf_desc *buf_desc;*/
+#else
 	struct tx_desc *desc;
 #endif
+#endif
 
-#if defined(DBG_XMIT_BUF )|| defined(DBG_XMIT_BUF_EXT)
+#if defined(DBG_XMIT_BUF) || defined(DBG_XMIT_BUF_EXT)
 	u8 no;
 #endif
 
 };
 
 
-struct xmit_frame
-{
+struct xmit_frame {
 	_list	list;
 
 	struct pkt_attrib attrib;
@@ -584,26 +688,25 @@ struct tx_servq {
 };
 
 
-struct sta_xmit_priv
-{
+struct sta_xmit_priv {
 	_lock	lock;
 	sint	option;
-	sint	apsd_setting;	//When bit mask is on, the associated edca queue supports APSD.
+	sint	apsd_setting;	/* When bit mask is on, the associated edca queue supports APSD. */
 
 
-	//struct tx_servq blk_q[MAX_NUMBLKS];
-	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
-	_list 	legacy_dz;
+	/* struct tx_servq blk_q[MAX_NUMBLKS]; */
+	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 */
+	_list	legacy_dz;
 	_list  apsd;
 
 	u16 txseq_tid[16];
 
-	//uint	sta_tx_bytes;
-	//u64	sta_tx_pkts;
-	//uint	sta_tx_fail;
+	/* uint	sta_tx_bytes; */
+	/* u64	sta_tx_pkts; */
+	/* uint	sta_tx_fail; */
 
 
 };
@@ -612,7 +715,7 @@ struct sta_xmit_priv
 struct	hw_txqueue	{
 	volatile sint	head;
 	volatile sint	tail;
-	volatile sint 	free_sz;	//in units of 64 bytes
+	volatile sint 	free_sz;	/* in units of 64 bytes */
 	volatile sint      free_cmdsz;
 	volatile sint	 txsz[8];
 	uint	ff_hwaddr;
@@ -620,7 +723,7 @@ struct	hw_txqueue	{
 	sint	ac_tag;
 };
 
-struct agg_pkt_info{
+struct agg_pkt_info {
 	u16 offset;
 	u16 pkt_len;
 };
@@ -638,36 +741,35 @@ struct	xmit_priv	{
 	_lock	lock;
 
 	_sema	xmit_sema;
-	_sema	terminate_xmitthread_sema;
 
-	//_queue	blk_strms[MAX_NUMBLKS];
+	/* _queue	blk_strms[MAX_NUMBLKS]; */
 	_queue	be_pending;
 	_queue	bk_pending;
 	_queue	vi_pending;
 	_queue	vo_pending;
 	_queue	bm_pending;
 
-	//_queue	legacy_dz_queue;
-	//_queue	apsd_queue;
+	/* _queue	legacy_dz_queue; */
+	/* _queue	apsd_queue; */
 
 	u8 *pallocated_frame_buf;
 	u8 *pxmit_frame_buf;
 	uint free_xmitframe_cnt;
 	_queue	free_xmit_queue;
 
-	//uint mapping_addr;
-	//uint pkt_sz;
+	/* uint mapping_addr; */
+	/* uint pkt_sz; */
 
 	u8 *xframe_ext_alloc_addr;
 	u8 *xframe_ext;
 	uint free_xframe_ext_cnt;
 	_queue free_xframe_ext_queue;
 
-	//struct	hw_txqueue	be_txqueue;
-	//struct	hw_txqueue	bk_txqueue;
-	//struct	hw_txqueue	vi_txqueue;
-	//struct	hw_txqueue	vo_txqueue;
-	//struct	hw_txqueue	bmc_txqueue;
+	/* struct	hw_txqueue	be_txqueue; */
+	/* struct	hw_txqueue	bk_txqueue; */
+	/* struct	hw_txqueue	vi_txqueue; */
+	/* struct	hw_txqueue	vo_txqueue; */
+	/* struct	hw_txqueue	bmc_txqueue; */
 
 	uint	frag_len;
 
@@ -676,7 +778,7 @@ struct	xmit_priv	{
 	u8   vcs_setting;
 	u8	vcs;
 	u8	vcs_type;
-	//u16  rts_thresh;
+	/* u16  rts_thresh; */
 
 	u64	tx_bytes;
 	u64	tx_pkts;
@@ -686,15 +788,15 @@ struct	xmit_priv	{
 	struct hw_xmit *hwxmits;
 	u8	hwxmit_entry;
 
-	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.
+	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. */
 
 #ifdef CONFIG_USB_HCI
-	_sema	tx_retevt;//all tx return event;
-	u8		txirp_cnt;//
+	_sema	tx_retevt;/* all tx return event; */
+	u8		txirp_cnt;
 
 #ifdef PLATFORM_OS_CE
 	USB_TRANSFER	usb_transfer_write_port;
-//	USB_TRANSFER	usb_transfer_write_mem;
+	/*	USB_TRANSFER	usb_transfer_write_mem; */
 #endif
 #ifdef PLATFORM_LINUX
 	struct tasklet_struct xmit_tasklet;
@@ -702,7 +804,7 @@ struct	xmit_priv	{
 #ifdef PLATFORM_FREEBSD
 	struct task xmit_tasklet;
 #endif
-	//per AC pending irp
+	/* per AC pending irp */
 	int beq_cnt;
 	int bkq_cnt;
 	int viq_cnt;
@@ -711,24 +813,23 @@ struct	xmit_priv	{
 #endif
 
 #ifdef CONFIG_PCI_HCI
-	// Tx
+	/* Tx */
 	struct rtw_tx_ring	tx_ring[PCI_MAX_TX_QUEUE_COUNT];
 	int	txringcount[PCI_MAX_TX_QUEUE_COUNT];
-	u8 	beaconDMAing;		//flag of indicating beacon is transmiting to HW by DMA
+	u8 	beaconDMAing;		/* flag of indicating beacon is transmiting to HW by DMA */
 #ifdef PLATFORM_LINUX
 	struct tasklet_struct xmit_tasklet;
 #endif
 #endif
 
-#if defined (CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 #ifdef CONFIG_SDIO_TX_TASKLET
-	#ifdef PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 	struct tasklet_struct xmit_tasklet;
-	#endif /* PLATFORM_LINUX */
+#endif /* PLATFORM_LINUX */
 #else
 	_thread_hdl_	SdioXmitThread;
 	_sema		SdioXmitSema;
-	_sema		SdioXmitTerminateSema;
 #endif /* CONFIG_SDIO_TX_TASKLET */
 #endif /* CONFIG_SDIO_HCI */
 
@@ -744,18 +845,18 @@ struct	xmit_priv	{
 	uint free_xmit_extbuf_cnt;
 
 	struct xmit_buf	pcmd_xmitbuf[CMDBUF_MAX];
-	u8   hw_ssn_seq_no;//mapping to REG_HW_SEQ 0,1,2,3
+	u8   hw_ssn_seq_no;/* mapping to REG_HW_SEQ 0,1,2,3 */
 	u16	nqos_ssn;
-	#ifdef CONFIG_TX_EARLY_MODE
+#ifdef CONFIG_TX_EARLY_MODE
+
+#ifdef CONFIG_SDIO_HCI
+#define MAX_AGG_PKT_NUM 20
+#else
+#define MAX_AGG_PKT_NUM 256 /* Max tx ampdu coounts		 */
+#endif
 
-	#ifdef CONFIG_SDIO_HCI
-	#define MAX_AGG_PKT_NUM 20	
-	#else
-	#define MAX_AGG_PKT_NUM 256 //Max tx ampdu coounts		
-	#endif
-	
 	struct agg_pkt_info agg_pkt[MAX_AGG_PKT_NUM];
-	#endif
+#endif
 
 #ifdef CONFIG_XMIT_ACK
 	int	ack_tx;
@@ -763,16 +864,48 @@ struct	xmit_priv	{
 	struct submit_ctx ack_tx_ops;
 	u8 seq_no;
 #endif
+
+#ifdef CONFIG_TX_AMSDU
+	_timer amsdu_vo_timer;
+	u8 amsdu_vo_timeout;
+
+	_timer amsdu_vi_timer;
+	u8 amsdu_vi_timeout;
+
+	_timer amsdu_be_timer;
+	u8 amsdu_be_timeout;
+
+	_timer amsdu_bk_timer;
+	u8 amsdu_bk_timeout;
+
+	u32 amsdu_debug_set_timer;
+	u32 amsdu_debug_timeout;
+	u32 amsdu_debug_coalesce_one;
+	u32 amsdu_debug_coalesce_two;
+
+#endif
+#ifdef DBG_TXBD_DESC_DUMP
+	BOOLEAN	 dump_txbd_desc;
+#endif
 	_lock lock_sctx;
+
 };
 
 extern struct xmit_frame *__rtw_alloc_cmdxmitframe(struct xmit_priv *pxmitpriv,
 		enum cmdbuf_type buf_type);
 #define rtw_alloc_cmdxmitframe(p) __rtw_alloc_cmdxmitframe(p, CMDBUF_RSVD)
-#if defined(CONFIG_RTL8192E) && defined(CONFIG_PCI_HCI) 
+#if defined(CONFIG_RTL8192E) && defined(CONFIG_PCI_HCI)
 extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8192ee(struct xmit_priv *pxmitpriv,
 		enum cmdbuf_type buf_type);
 #define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8192ee(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8822B) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8822be(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8822be(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8821C) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8821ce(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8821ce(p, CMDBUF_BEACON)
 #else
 #define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe(p, CMDBUF_BEACON)
 #endif
@@ -787,6 +920,11 @@ void rtw_count_tx_stats(_adapter *padapter, struct xmit_frame *pxmitframe, int s
 extern void rtw_update_protection(_adapter *padapter, u8 *ie, uint ie_len);
 static s32 update_attrib_sec_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
 static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
+
+#ifdef CONFIG_WMMPS_STA
+static void update_attrib_trigger_frame_info(_adapter *padapter, struct pkt_attrib *pattrib);
+#endif /* CONFIG_WMMPS_STA */
+
 extern s32 rtw_make_wlanhdr(_adapter *padapter, u8 *hdr, struct pkt_attrib *pattrib);
 extern s32 rtw_put_snap(u8 *data, u16 h_proto);
 
@@ -797,21 +935,21 @@ extern s32 rtw_free_xmitframe(struct xmit_priv *pxmitpriv, struct xmit_frame *px
 extern void rtw_free_xmitframe_queue(struct xmit_priv *pxmitpriv, _queue *pframequeue);
 struct tx_servq *rtw_get_sta_pending(_adapter *padapter, struct sta_info *psta, sint up, u8 *ac);
 extern s32 rtw_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
-extern struct xmit_frame* rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i, sint entry);
+extern struct xmit_frame *rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i, sint entry);
 
 extern s32 rtw_xmit_classifier(_adapter *padapter, struct xmit_frame *pxmitframe);
 extern u32 rtw_calculate_wlan_pkt_size_by_attribue(struct pkt_attrib *pattrib);
 #define rtw_wlan_pkt_size(f) rtw_calculate_wlan_pkt_size_by_attribue(&f->attrib)
 extern s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe);
-#ifdef CONFIG_IEEE80211W
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
 extern s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe);
-#endif //CONFIG_IEEE80211W
+#endif
 #ifdef CONFIG_TDLS
 extern struct tdls_txmgmt *ptxmgmt;
 s32 rtw_xmit_tdls_coalesce(_adapter *padapter, struct xmit_frame *pxmitframe, struct tdls_txmgmt *ptxmgmt);
 s32 update_tdls_attrib(_adapter *padapter, struct pkt_attrib *pattrib);
 #endif
-s32 _rtw_init_hw_txqueue(struct hw_txqueue* phw_txqueue, u8 ac_tag);
+s32 _rtw_init_hw_txqueue(struct hw_txqueue *phw_txqueue, u8 ac_tag);
 void _rtw_init_sta_xmit_priv(struct sta_xmit_priv *psta_xmitpriv);
 
 
@@ -821,7 +959,7 @@ void rtw_init_hwxmits(struct hw_xmit *phwxmit, sint entry);
 
 
 s32 _rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, _adapter *padapter);
-void _rtw_free_xmit_priv (struct xmit_priv *pxmitpriv);
+void _rtw_free_xmit_priv(struct xmit_priv *pxmitpriv);
 
 
 void rtw_alloc_hwxmits(_adapter *padapter);
@@ -829,6 +967,7 @@ void rtw_free_hwxmits(_adapter *padapter);
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
 s32 rtw_monitor_xmit_entry(struct sk_buff *skb, struct net_device *ndev);
 #endif
+s32 rtw_xmit_posthandle(_adapter *padapter, struct xmit_frame *pxmitframe, _pkt *pkt);
 s32 rtw_xmit(_adapter *padapter, _pkt **pkt);
 bool xmitframe_hiq_filter(struct xmit_frame *xmitframe);
 #if defined(CONFIG_AP_MODE) || defined(CONFIG_TDLS)
@@ -855,23 +994,60 @@ u8	qos_acm(u8 acm_mask, u8 priority);
 #ifdef CONFIG_XMIT_THREAD_MODE
 void	enqueue_pending_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
 void enqueue_pending_xmitbuf_to_head(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-struct xmit_buf*	dequeue_pending_xmitbuf(struct xmit_priv *pxmitpriv);
-struct xmit_buf*	dequeue_pending_xmitbuf_under_survey(struct xmit_priv *pxmitpriv);
+struct xmit_buf	*dequeue_pending_xmitbuf(struct xmit_priv *pxmitpriv);
+struct xmit_buf	*select_and_dequeue_pending_xmitbuf(_adapter *padapter);
 sint	check_pending_xmitbuf(struct xmit_priv *pxmitpriv);
 thread_return	rtw_xmit_thread(thread_context context);
 #endif
 
-static void do_queue_select(_adapter * padapter, struct pkt_attrib * pattrib);
+#ifdef CONFIG_TX_AMSDU
+extern void rtw_amsdu_vo_timeout_handler(void *FunctionContext);
+extern void rtw_amsdu_vi_timeout_handler(void *FunctionContext);
+extern void rtw_amsdu_be_timeout_handler(void *FunctionContext);
+extern void rtw_amsdu_bk_timeout_handler(void *FunctionContext);
+
+extern u8 rtw_amsdu_get_timer_status(_adapter *padapter, u8 priority);
+extern void rtw_amsdu_set_timer_status(_adapter *padapter, u8 priority, u8 status);
+extern void rtw_amsdu_set_timer(_adapter *padapter, u8 priority);
+extern void rtw_amsdu_cancel_timer(_adapter *padapter, u8 priority);
+
+extern s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitframe, struct xmit_frame *pxmitframe_queue);	
+extern s32 check_amsdu(struct xmit_frame *pxmitframe);
+extern s32 check_amsdu_tx_support(_adapter *padapter);
+extern struct xmit_frame *rtw_get_xframe(struct xmit_priv *pxmitpriv, int *num_frame);
+#endif
+
+#ifdef DBG_TXBD_DESC_DUMP
+void rtw_tx_desc_backup(_adapter *padapter, struct xmit_frame *pxmitframe, u8 desc_size, u8 hwq);
+void rtw_tx_desc_backup_reset(void);
+u8 rtw_get_tx_desc_backup(_adapter *padapter, u8 hwq, struct rtw_tx_desc_backup **pbak);
+#endif
+
+static void do_queue_select(_adapter *padapter, struct pkt_attrib *pattrib);
 u32	rtw_get_ff_hwaddr(struct xmit_frame	*pxmitframe);
 
 #ifdef CONFIG_XMIT_ACK
 int rtw_ack_tx_wait(struct xmit_priv *pxmitpriv, u32 timeout_ms);
 void rtw_ack_tx_done(struct xmit_priv *pxmitpriv, int status);
-#endif //CONFIG_XMIT_ACK
+#endif /* CONFIG_XMIT_ACK */
+
+enum XMIT_BLOCK_REASON {
+	XMIT_BLOCK_NONE = 0,
+	XMIT_BLOCK_REDLMEM = BIT0, /*LPS-PG*/
+	XMIT_BLOCK_SUSPEND = BIT1, /*WOW*/
+	XMIT_BLOCK_MAX = 0xFF,
+};
+void rtw_init_xmit_block(_adapter *padapter);
+void rtw_deinit_xmit_block(_adapter *padapter);
 
+#ifdef DBG_XMIT_BLOCK
+void dump_xmit_block(void *sel, _adapter *padapter);
+#endif
+void rtw_set_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason);
+void rtw_clr_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason);
+bool rtw_is_xmit_blocked(_adapter *padapter);
 
-//include after declaring struct xmit_buf, in order to avoid warning
+/* include after declaring struct xmit_buf, in order to avoid warning */
 #include <xmit_osdep.h>
 
-#endif	//_RTL871X_XMIT_H_
-
+#endif /* _RTL871X_XMIT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_hal.h
index a694cdd468af..a79412c6d547 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_hal.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,20 +12,10 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __SDIO_HAL_H__
 #define __SDIO_HAL_H__
 
-
-extern u8 sd_hal_bus_init(PADAPTER padapter);
-extern u8 sd_hal_bus_deinit(PADAPTER padapter);
-
-u8 sd_int_isr(PADAPTER padapter);
 void sd_int_dpc(PADAPTER padapter);
 u8 rtw_set_hal_ops(_adapter *padapter);
 
@@ -48,9 +39,16 @@ void rtl8192es_set_hal_ops(PADAPTER padapter);
 void rtl8703bs_set_hal_ops(PADAPTER padapter);
 #endif
 
+#ifdef CONFIG_RTL8723D
+void rtl8723ds_set_hal_ops(PADAPTER padapter);
+#endif
+
 #ifdef CONFIG_RTL8188F
 void rtl8188fs_set_hal_ops(PADAPTER padapter);
 #endif
 
-#endif //__SDIO_HAL_H__
+#ifdef CONFIG_RTL8188GTV
+void rtl8188gtvs_set_hal_ops(PADAPTER padapter);
+#endif
 
+#endif /* __SDIO_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops.h
index 6907814d36d4..01acd588b4d8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,16 +12,16 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __SDIO_OPS_H__
 #define __SDIO_OPS_H__
 
 
+/* Follow mac team suggestion, default I/O fail return value is 0xFF */
+#define SDIO_ERR_VAL8	0xFF
+#define SDIO_ERR_VAL16	0xFFFF
+#define SDIO_ERR_VAL32	0xFFFFFFFF
+
 #ifdef PLATFORM_LINUX
 #include <sdio_ops_linux.h>
 #endif
@@ -29,12 +30,11 @@
 
 #ifdef PLATFORM_OS_XP
 #include <sdio_ops_xp.h>
-struct async_context
-{
+struct async_context {
 	PMDL pmdl;
 	PSDBUS_REQUEST_PACKET sdrp;
-	unsigned char* r_buf;
-	unsigned char* padapter;
+	unsigned char *r_buf;
+	unsigned char *padapter;
 };
 #endif
 
@@ -42,13 +42,21 @@ struct async_context
 #include <sdio_ops_ce.h>
 #endif
 
-#endif // PLATFORM_WINDOWS
+#endif /* PLATFORM_WINDOWS */
+
+
+extern void sdio_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
+void dump_sdio_card_info(void *sel, struct dvobj_priv *dvobj);
 
+u32 sdio_init(struct dvobj_priv *dvobj);
+void sdio_deinit(struct dvobj_priv *dvobj);
+int sdio_alloc_irq(struct dvobj_priv *dvobj);
+void sdio_free_irq(struct dvobj_priv *dvobj);
 
-extern void sdio_set_intf_ops(_adapter *padapter,struct _io_ops *pops);
-	
-//extern void sdio_func1cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem);
-//extern void sdio_func1cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem);
+#if 0
+extern void sdio_func1cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem);
+extern void sdio_func1cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem);
+#endif
 extern u8 SdioLocalCmd52Read1Byte(PADAPTER padapter, u32 addr);
 extern void SdioLocalCmd52Write1Byte(PADAPTER padapter, u32 addr, u8 v);
 extern s32 _sdio_local_read(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
@@ -70,7 +78,7 @@ extern void UpdateInterruptMask8188ESdio(PADAPTER padapter, u32 AddMSR, u32 Remo
 extern u8 HalQueryTxBufferStatus8189ESdio(PADAPTER padapter);
 extern u8 HalQueryTxOQTBufferStatus8189ESdio(PADAPTER padapter);
 extern void ClearInterrupt8188ESdio(PADAPTER padapter);
-#endif // CONFIG_RTL8188E
+#endif /* CONFIG_RTL8188E */
 
 #ifdef CONFIG_RTL8821A
 extern void InitInterrupt8821AS(PADAPTER padapter);
@@ -84,8 +92,11 @@ void ClearInterrupt8821AS(PADAPTER padapter);
 #endif /* CONFIG_RTL8821A */
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-extern u8 RecvOnePkt(PADAPTER padapter, u32 size);
-#endif // CONFIG_WOWLAN
+#if defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822B)
+u8 rtw_hal_enable_cpwm2(_adapter *adapter);
+#endif
+extern u8 RecvOnePkt(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
 #ifdef CONFIG_RTL8723B
 extern void InitInterrupt8723BSdio(PADAPTER padapter);
 extern void InitSysInterrupt8723BSdio(PADAPTER padapter);
@@ -96,7 +107,7 @@ extern u8 HalQueryTxOQTBufferStatus8723BSdio(PADAPTER padapter);
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 extern void DisableInterruptButCpwm28723BSdio(PADAPTER padapter);
 extern void ClearInterrupt8723BSdio(PADAPTER padapter);
-#endif //CONFIG_WOWLAN
+#endif /* CONFIG_WOWLAN */
 #endif
 
 
@@ -108,7 +119,7 @@ extern void UpdateInterruptMask8192ESdio(PADAPTER padapter, u32 AddMSR, u32 Remo
 extern u8 HalQueryTxBufferStatus8192ESdio(PADAPTER padapter);
 extern u8 HalQueryTxOQTBufferStatus8192ESdio(PADAPTER padapter);
 extern void ClearInterrupt8192ESdio(PADAPTER padapter);
-#endif // CONFIG_RTL8192E
+#endif /* CONFIG_RTL8192E */
 
 #ifdef CONFIG_RTL8703B
 extern void InitInterrupt8703BSdio(PADAPTER padapter);
@@ -120,7 +131,20 @@ extern u8 HalQueryTxOQTBufferStatus8703BSdio(PADAPTER padapter);
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 extern void DisableInterruptButCpwm28703BSdio(PADAPTER padapter);
 extern void ClearInterrupt8703BSdio(PADAPTER padapter);
-#endif //CONFIG_WOWLAN
+#endif /* CONFIG_WOWLAN */
+#endif
+
+#ifdef CONFIG_RTL8723D
+extern void InitInterrupt8723DSdio(PADAPTER padapter);
+extern void InitSysInterrupt8723DSdio(PADAPTER padapter);
+extern void EnableInterrupt8723DSdio(PADAPTER padapter);
+extern void DisableInterrupt8723DSdio(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8723DSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8723DSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm28723dSdio(PADAPTER padapter);
+extern void ClearInterrupt8723DSdio(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
 #endif
 
 #ifdef CONFIG_RTL8188F
@@ -136,5 +160,52 @@ extern void ClearInterrupt8188FSdio(PADAPTER padapter);
 #endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
 #endif
 
-#endif // !__SDIO_OPS_H__
+#ifdef CONFIG_RTL8188GTV
+extern void InitInterrupt8188GTVSdio(PADAPTER padapter);
+extern void InitSysInterrupt8188GTVSdio(PADAPTER padapter);
+extern void EnableInterrupt8188GTVSdio(PADAPTER padapter);
+extern void DisableInterrupt8188GTVSdio(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8188GTVSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8188GTVSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm28188GTVSdio(PADAPTER padapter);
+extern void ClearInterrupt8188GTVSdio(PADAPTER padapter);
+#endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
+#endif
+
+/**
+ * rtw_sdio_get_block_size() - Get block size of SDIO transfer
+ * @d		struct dvobj_priv*
+ *
+ * The unit of return value is byte.
+ */
+static inline u32 rtw_sdio_get_block_size(struct dvobj_priv *d)
+{
+	return d->intf_data.block_transfer_len;
+}
+
+/**
+ * rtw_sdio_cmd53_align_size() - Align size to one CMD53 could complete
+ * @d		struct dvobj_priv*
+ * @len		length to align
+ *
+ * Adjust len to align block size, and the new size could be transfered by one
+ * CMD53.
+ * If len < block size, it would keep original value, otherwise the value
+ * would be rounded up by block size.
+ *
+ * Return adjusted length.
+ */
+static inline size_t rtw_sdio_cmd53_align_size(struct dvobj_priv *d, size_t len)
+{
+	u32 blk_sz;
+
+
+	blk_sz = rtw_sdio_get_block_size(d);
+	if (len <= blk_sz)
+		return len;
+
+	return _RND(len, blk_sz);
+}
 
+#endif /* !__SDIO_OPS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_ce.h
index d2da29331f28..b4e994bddd99 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_ce.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,45 +12,39 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef _SDIO_OPS_WINCE_H_
-#define _SDIO_OPS_WINCE_H_
-
-#include <drv_conf.h>
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <osdep_intf.h>
-
-
-#ifdef PLATFORM_OS_CE
-
-
-extern u8 sdbus_cmd52r_ce(struct intf_priv *pintfpriv, u32 addr);
-
-
-extern void sdbus_cmd52w_ce(struct intf_priv *pintfpriv, u32 addr,u8 val8);
-
-
-uint sdbus_read_blocks_to_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
-
-extern uint sdbus_read_bytes_to_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
-
-
-extern uint sdbus_write_blocks_from_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf,u8 async);
-
-extern uint sdbus_write_bytes_from_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
-extern u8 sdbus_func1cmd52r_ce(struct intf_priv *pintfpriv, u32 addr);
-extern void sdbus_func1cmd52w_ce(struct intf_priv *pintfpriv, u32 addr, u8 val8);
-extern uint sdbus_read_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt,void *pdata);
-extern uint sdbus_write_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt,void *pdata);
-extern void sdio_read_int(_adapter *padapter, u32 addr,u8 sz,void *pdata);
-
-#endif
-
-#endif
-
+ *****************************************************************************/
+#ifndef _SDIO_OPS_WINCE_H_
+#define _SDIO_OPS_WINCE_H_
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+#include <osdep_intf.h>
+
+
+#ifdef PLATFORM_OS_CE
+
+
+extern u8 sdbus_cmd52r_ce(struct intf_priv *pintfpriv, u32 addr);
+
+
+extern void sdbus_cmd52w_ce(struct intf_priv *pintfpriv, u32 addr, u8 val8);
+
+
+uint sdbus_read_blocks_to_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+
+extern uint sdbus_read_bytes_to_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+
+
+extern uint sdbus_write_blocks_from_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf, u8 async);
+
+extern uint sdbus_write_bytes_from_membuf_ce(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
+extern u8 sdbus_func1cmd52r_ce(struct intf_priv *pintfpriv, u32 addr);
+extern void sdbus_func1cmd52w_ce(struct intf_priv *pintfpriv, u32 addr, u8 val8);
+extern uint sdbus_read_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern uint sdbus_write_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern void sdio_read_int(_adapter *padapter, u32 addr, u8 sz, void *pdata);
+
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_linux.h
index 38b6a215f748..bc0862fbc4a3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_linux.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,11 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __SDIO_OPS_LINUX_H__
 #define __SDIO_OPS_LINUX_H__
 
-#define SDIO_ERR_VAL8	0xEA
-#define SDIO_ERR_VAL16	0xEAEA
-#define SDIO_ERR_VAL32	0xEAEAEAEA
-
+#ifndef RTW_HALMAC
 u8 sd_f0_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
 void sd_f0_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err);
 
@@ -37,16 +30,30 @@ u8 sd_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
 u16 sd_read16(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
 u32 _sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
 u32 sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err);
-s32 _sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
-s32 sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
 void sd_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err);
 void sd_write16(struct intf_hdl *pintfhdl, u32 addr, u16 v, s32 *err);
 void _sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err);
 void sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err);
+#endif /* RTW_HALMAC */
+
+bool rtw_is_sdio30(_adapter *adapter);
+
+/* The unit of return value is Hz */
+static inline u32 rtw_sdio_get_clock(struct dvobj_priv *d)
+{
+	return d->intf_data.clock;
+}
+
+s32 _sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
+s32 sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
 s32 _sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
 s32 sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata);
 
-
 void rtw_sdio_set_irq_thd(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl);
-#endif
+int __must_check rtw_sdio_raw_read(struct dvobj_priv *d, unsigned int addr,
+				void *buf, size_t len, bool fixed);
+int __must_check rtw_sdio_raw_write(struct dvobj_priv *d, unsigned int addr,
+				void *buf, size_t len, bool fixed);
+
+#endif /* __SDIO_OPS_LINUX_H__ */
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_xp.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_xp.h
index 757b35d44cf3..a00a25c38fbc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_xp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_ops_xp.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _SDIO_OPS_XP_H_
 #define _SDIO_OPS_XP_H_
 
@@ -32,7 +28,7 @@
 extern u8 sdbus_cmd52r_xp(struct intf_priv *pintfpriv, u32 addr);
 
 
-extern void sdbus_cmd52w_xp(struct intf_priv *pintfpriv, u32 addr,u8 val8);
+extern void sdbus_cmd52w_xp(struct intf_priv *pintfpriv, u32 addr, u8 val8);
 
 
 uint sdbus_read_blocks_to_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
@@ -40,16 +36,15 @@ uint sdbus_read_blocks_to_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 c
 extern uint sdbus_read_bytes_to_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
 
 
-extern uint sdbus_write_blocks_from_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf,u8 async);
+extern uint sdbus_write_blocks_from_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf, u8 async);
 
 extern uint sdbus_write_bytes_from_membuf_xp(struct intf_priv *pintfpriv, u32 addr, u32 cnt, u8 *pbuf);
 extern u8 sdbus_func1cmd52r_xp(struct intf_priv *pintfpriv, u32 addr);
 extern void sdbus_func1cmd52w_xp(struct intf_priv *pintfpriv, u32 addr, u8 val8);
-extern uint sdbus_read_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt,void *pdata);
-extern uint sdbus_write_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt,void *pdata);
-extern void sdio_read_int(_adapter *padapter, u32 addr,u8 sz,void *pdata);
+extern uint sdbus_read_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern uint sdbus_write_reg(struct intf_priv *pintfpriv, u32 addr, u32 cnt, void *pdata);
+extern void sdio_read_int(_adapter *padapter, u32 addr, u8 sz, void *pdata);
 
 #endif
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_osintf.h
index 1a81d2ebcbf3..dc271ad9bfc5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sdio_osintf.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,21 +12,11 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __SDIO_OSINTF_H__
 #define __SDIO_OSINTF_H__
 
 
-
-u8 sd_hal_bus_init(PADAPTER padapter);
-u8 sd_hal_bus_deinit(PADAPTER padapter);
-void sd_c2h_hdl(PADAPTER padapter);
-
 #ifdef PLATFORM_OS_CE
 extern NDIS_STATUS ce_sd_get_dev_hdl(PADAPTER padapter);
 SD_API_STATUS ce_sd_int_callback(SD_DEVICE_HANDLE hDevice, PADAPTER padapter);
@@ -33,4 +24,3 @@ extern void sd_setup_irs(PADAPTER padapter);
 #endif
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sta_info.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sta_info.h
index bfb63df165b8..4c6f79fa9bb9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sta_info.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/sta_info.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,52 +12,83 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __STA_INFO_H_
 #define __STA_INFO_H_
 
+#include <cmn_info/rtw_sta_info.h>
 
 #define IBSS_START_MAC_ID	2
 #define NUM_STA MACID_NUM_SW_LIMIT
+
+#ifndef CONFIG_RTW_MACADDR_ACL
+	#define CONFIG_RTW_MACADDR_ACL 1
+#endif
+
+#ifndef CONFIG_RTW_PRE_LINK_STA
+	#define CONFIG_RTW_PRE_LINK_STA 0
+#endif
+
 #define NUM_ACL 16
 
+#define RTW_ACL_PERIOD_DEV 0
+#define RTW_ACL_PERIOD_BSS 1
+#define RTW_ACL_PERIOD_NUM 2
+
+#define RTW_ACL_MODE_DISABLED				0
+#define RTW_ACL_MODE_ACCEPT_UNLESS_LISTED	1
+#define RTW_ACL_MODE_DENY_UNLESS_LISTED		2
+#define RTW_ACL_MODE_MAX					3
+
+#if CONFIG_RTW_MACADDR_ACL
+extern const char *const _acl_period_str[RTW_ACL_PERIOD_NUM];
+#define acl_period_str(mode) (((mode) >= RTW_ACL_PERIOD_NUM) ? "INVALID" : _acl_period_str[(mode)])
+extern const char *const _acl_mode_str[RTW_ACL_MODE_MAX];
+#define acl_mode_str(mode) (((mode) >= RTW_ACL_MODE_MAX) ? "INVALID" : _acl_mode_str[(mode)])
+#endif
+
+#ifndef RTW_PRE_LINK_STA_NUM
+	#define RTW_PRE_LINK_STA_NUM 8
+#endif
+
+struct pre_link_sta_node_t {
+	u8 valid;
+	u8 addr[ETH_ALEN];
+};
+
+struct pre_link_sta_ctl_t {
+	_lock lock;
+	u8 num;
+	struct pre_link_sta_node_t node[RTW_PRE_LINK_STA_NUM];
+};
+
 #ifdef CONFIG_TDLS
 #define MAX_ALLOWED_TDLS_STA_NUM	4
 #endif
 
 enum sta_info_update_type {
-	STA_INFO_UPDATE_NONE = 0, 
-	STA_INFO_UPDATE_BW = BIT(0), 
-	STA_INFO_UPDATE_RATE = BIT(1),	
+	STA_INFO_UPDATE_NONE = 0,
+	STA_INFO_UPDATE_BW = BIT(0),
+	STA_INFO_UPDATE_RATE = BIT(1),
 	STA_INFO_UPDATE_PROTECTION_MODE = BIT(2),
 	STA_INFO_UPDATE_CAP = BIT(3),
 	STA_INFO_UPDATE_HT_CAP = BIT(4),
 	STA_INFO_UPDATE_VHT_CAP = BIT(5),
 	STA_INFO_UPDATE_ALL = STA_INFO_UPDATE_BW
-							|STA_INFO_UPDATE_RATE
-							|STA_INFO_UPDATE_PROTECTION_MODE
-							|STA_INFO_UPDATE_CAP
-							|STA_INFO_UPDATE_HT_CAP
-							|STA_INFO_UPDATE_VHT_CAP,
+			      | STA_INFO_UPDATE_RATE
+			      | STA_INFO_UPDATE_PROTECTION_MODE
+			      | STA_INFO_UPDATE_CAP
+			      | STA_INFO_UPDATE_HT_CAP
+			      | STA_INFO_UPDATE_VHT_CAP,
 	STA_INFO_UPDATE_MAX
 };
 
-//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 {
-        _list		        list;
-        u8       addr[ETH_ALEN];
-        u8       valid;
+	_list		        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;
@@ -64,45 +96,66 @@ struct wlan_acl_pool {
 	_queue	acl_node_q;
 };
 
-typedef struct _RSSI_STA{
-	s32	UndecoratedSmoothedPWDB;
-	s32	UndecoratedSmoothedCCK;
-	s32	UndecoratedSmoothedOFDM;
-	u32	OFDM_pkt;
-	u64	PacketMap;
-	u8	ValidBit;
-}RSSI_STA, *PRSSI_STA;
-
 struct	stainfo_stats	{
+	systime last_rx_time;
 
 	u64 rx_mgnt_pkts;
 		u64 rx_beacon_pkts;
 		u64 rx_probereq_pkts;
-		u64 rx_probersp_pkts;
+		u64 rx_probersp_pkts; /* unicast to self */
 		u64 rx_probersp_bm_pkts;
-		u64 rx_probersp_uo_pkts;
+		u64 rx_probersp_uo_pkts; /* unicast to others */
 	u64 rx_ctrl_pkts;
 	u64 rx_data_pkts;
-	u64 rx_data_qos_pkts[TID_NUM];
+		u64 rx_data_bc_pkts;
+		u64 rx_data_mc_pkts;
+	u64 rx_data_qos_pkts[TID_NUM]; /* unicast only */
+
 	u64	last_rx_mgnt_pkts;
 		u64 last_rx_beacon_pkts;
 		u64 last_rx_probereq_pkts;
-		u64 last_rx_probersp_pkts;
+		u64 last_rx_probersp_pkts; /* unicast to self */
 		u64 last_rx_probersp_bm_pkts;
-		u64 last_rx_probersp_uo_pkts;
+		u64 last_rx_probersp_uo_pkts; /* unicast to others */
 	u64	last_rx_ctrl_pkts;
 	u64	last_rx_data_pkts;
-	u64 last_rx_data_qos_pkts[TID_NUM];
+		u64 last_rx_data_bc_pkts;
+		u64 last_rx_data_mc_pkts;
+	u64 last_rx_data_qos_pkts[TID_NUM]; /* unicast only */
+
 #ifdef CONFIG_TDLS
 	u64 rx_tdls_disc_rsp_pkts;
 	u64 last_rx_tdls_disc_rsp_pkts;
 #endif
+
 	u64	rx_bytes;
-	u64	rx_drops;
+		u64	rx_bc_bytes;
+		u64	rx_mc_bytes;
+	u64	last_rx_bytes;
+		u64 last_rx_bc_bytes;
+		u64 last_rx_mc_bytes;
+	u64	rx_drops; /* TBD */
+	u16 rx_tp_mbytes;
 
 	u64	tx_pkts;
+	u64	last_tx_pkts;
+
 	u64	tx_bytes;
-	u64  tx_drops;
+	u64	last_tx_bytes;
+	u64 tx_drops; /* TBD */
+	u16 tx_tp_mbytes;
+
+	/* unicast only */
+	u64 last_rx_data_uc_pkts; /* For Read & Clear requirement in proc_get_rx_stat() */
+	u32 duplicate_cnt;	/* Read & Clear, in proc_get_rx_stat() */
+	u32 rxratecnt[128];	/* Read & Clear, in proc_get_rx_stat() */
+	u32 tx_ok_cnt;		/* Read & Clear, in proc_get_tx_stat() */
+	u32 tx_fail_cnt;	/* Read & Clear, in proc_get_tx_stat() */
+	u32 tx_retry_cnt;	/* Read & Clear, in proc_get_tx_stat() */
+#ifdef CONFIG_RTW_MESH
+	u32 rx_hwmp_pkts;
+	u32 last_rx_hwmp_pkts;
+#endif
 };
 
 #ifndef DBG_SESSION_TRACKER
@@ -123,7 +176,7 @@ struct session_tracker {
 	u16 local_port;
 	u32 remote_naddr;
 	u16 remote_port;
-	u32 set_time;
+	systime set_time;
 	u8 status;
 };
 
@@ -162,6 +215,7 @@ void rtw_st_ctl_register(struct st_ctl_t *st_ctl, u8 st_reg_id, struct st_regist
 void rtw_st_ctl_unregister(struct st_ctl_t *st_ctl, u8 st_reg_id);
 bool rtw_st_ctl_chk_reg_s_proto(struct st_ctl_t *st_ctl, u8 s_proto);
 bool rtw_st_ctl_chk_reg_rule(struct st_ctl_t *st_ctl, _adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
+void rtw_st_ctl_rx(struct sta_info *sta, u8 *ehdr_pos);
 void dump_st_ctl(void *sel, struct st_ctl_t *st_ctl);
 
 #ifdef CONFIG_TDLS
@@ -169,72 +223,104 @@ struct TDLS_PeerKey {
 	u8 kck[16]; /* TPK-KCK */
 	u8 tk[16]; /* TPK-TK; only CCMP will be used */
 } ;
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
+
+#ifdef DBG_RX_DFRAME_RAW_DATA
+struct sta_recv_dframe_info {
+
+	u8 sta_data_rate;
+	u8 sta_sgi;
+	u8 sta_bw_mode;
+	s8 sta_mimo_signal_strength[4];
+	s8 sta_RxPwr[4];
+	u8 sta_ofdm_snr[4];
+};
+#endif
+
+#ifdef CONFIG_RTW_MESH
+struct mesh_plink_ent;
+struct rtw_ewma_err_rate {
+	unsigned long internal;
+};
+
+/* Mesh airtime link metrics parameters */
+struct rtw_atlm_param {
+	struct rtw_ewma_err_rate err_rate; /* Now is PACKET error rate */
+	u16 data_rate; /* The unit is 100Kbps */
+	u16 total_pkt;
+	u16 overhead; /* Channel access overhead */
+};
+#endif
 
 struct sta_info {
 
 	_lock	lock;
-	_list	list; //free_sta_queue
-	_list	hash_list; //sta_hash
-	//_list asoc_list; //20061114
-	//_list sleep_list;//sleep_q
-	//_list wakeup_list;//wakeup_q
+	_list	list; /* free_sta_queue */
+	_list	hash_list; /* sta_hash */
+	/* _list asoc_list; */ /* 20061114 */
+	/* _list sleep_list; */ /* sleep_q */
+	/* _list wakeup_list; */ /* wakeup_q */
 	_adapter *padapter;
-	
+	struct cmn_sta_info cmn;
+
 	struct sta_xmit_priv sta_xmitpriv;
 	struct sta_recv_priv sta_recvpriv;
-	
+
+#ifdef DBG_RX_DFRAME_RAW_DATA
+	struct sta_recv_dframe_info  sta_dframe_info;
+	struct sta_recv_dframe_info  sta_dframe_info_bmc;
+#endif
 	_queue sleep_q;
 	unsigned int sleepq_len;
-	
+
 	uint state;
-	uint aid;
-	uint mac_id;
 	uint qos_option;
-	u8	hwaddr[ETH_ALEN];
 	u16 hwseq;
-	u8	ra_rpt_linked;
 
-	uint	ieee8021x_blocked;	//0: allowed, 1:blocked 
-	uint	dot118021XPrivacy; //aes, tkip...
+#ifdef CONFIG_RTW_80211K
+	u8 rm_en_cap[5];
+	u8 rm_diag_token;
+#endif /* CONFIG_RTW_80211K */
+
+	uint	ieee8021x_blocked;	/* 0: allowed, 1:blocked */
+	uint	dot118021XPrivacy; /* aes, tkip... */
 	union Keytype	dot11tkiptxmickey;
 	union Keytype	dot11tkiprxmickey;
-	union Keytype	dot118021x_UncstKey;	
-	union pn48		dot11txpn;			// PN48 used for Unicast xmit
+	union Keytype	dot118021x_UncstKey;
+	union pn48		dot11txpn;			/* PN48 used for Unicast xmit */
+	union pn48		dot11rxpn;			/* PN48 used for Unicast recv. */
+#ifdef CONFIG_RTW_MESH
+	/* peer's GTK, RX only */
+	u8 group_privacy;
+	u8 gtk_bmp;
+	union Keytype gtk;
+	union pn48 gtk_pn;
+	#ifdef CONFIG_IEEE80211W
+	/* peer's IGTK, RX only */
+	u8 igtk_bmp;
+	u8 igtk_id;
+	union Keytype igtk;
+	union pn48 igtk_pn;
+	#endif /* CONFIG_IEEE80211W */
+#endif /* CONFIG_RTW_MESH */
 #ifdef CONFIG_GTK_OL
 	u8 kek[RTW_KEK_LEN];
 	u8 kck[RTW_KCK_LEN];
 	u8 replay_ctr[RTW_REPLAY_CTR_LEN];
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
 #ifdef CONFIG_IEEE80211W
-	union pn48		dot11wtxpn;			// PN48 used for Unicast mgmt xmit.
 	_timer dot11w_expire_timer;
-#endif //CONFIG_IEEE80211W
-	union pn48		dot11rxpn;			// PN48 used for Unicast recv.
-
+#endif /* CONFIG_IEEE80211W */
 
 	u8	bssrateset[16];
 	u32	bssratelen;
-	s32  rssi;
-	s32	signal_quality;
-	
+
 	u8	cts2self;
 	u8	rtsen;
 
-	u8	raid;
-	u8 	init_rate;
-	u64	ra_mask;
-	u8	wireless_mode;	// NETWORK_TYPE
-	u8	bw_mode;
+	u8	init_rate;
+	u8	wireless_mode;	/* NETWORK_TYPE */
 
-	u8	ldpc;
-	u8	stbc;
-
-#ifdef CONFIG_BEAMFORMING
-	u16 txbf_paid;
-	u16 txbf_gid;
-#endif
-		
 	struct stainfo_stats sta_stats;
 
 #ifdef CONFIG_TDLS
@@ -242,32 +328,34 @@ struct sta_info {
 	u8	SNonce[32];
 	u8	ANonce[32];
 	u32	TDLS_PeerKey_Lifetime;
-	u16	TPK_count;
+	u32	TPK_count;
 	_timer	TPK_timer;
 	struct TDLS_PeerKey	tpk;
-#ifdef CONFIG_TDLS_CH_SW	
+#ifdef CONFIG_TDLS_CH_SW
 	u16	ch_switch_time;
 	u16	ch_switch_timeout;
-	//u8	option;
+	/* u8	option; */
 	_timer	ch_sw_timer;
 	_timer	delay_timer;
-#endif	
+	_timer	stay_on_base_chnl_timer;
+	_timer	ch_sw_monitor_timer;
+#endif
 	_timer handshake_timer;
 	u8 alive_count;
 	_timer	pti_timer;
 	u8	TDLS_RSNIE[20];	/* Save peer's RSNIE, used for sending TDLS_SETUP_RSP */
 #endif /* CONFIG_TDLS */
 
-	//for A-MPDU TX, ADDBA timeout check	
+	/* for A-MPDU TX, ADDBA timeout check	 */
 	_timer addba_retry_timer;
-	
-	//for A-MPDU Rx reordering buffer control 
+
+	/* for A-MPDU Rx reordering buffer control */
 	struct recv_reorder_ctrl recvreorder_ctrl[TID_NUM];
 	ATOMIC_T continual_no_rx_packet[TID_NUM];
-	//for A-MPDU Tx
-	//unsigned char		ampdu_txen_bitmap;
+	/* for A-MPDU Tx */
+	/* unsigned char		ampdu_txen_bitmap; */
 	u16	BA_starting_seqctrl[16];
-	
+
 
 #ifdef CONFIG_80211N_HT
 	struct ht_priv	htpriv;
@@ -277,14 +365,14 @@ struct sta_info {
 	struct vht_priv	vhtpriv;
 #endif
 
-	//Notes:	
-	//STA_Mode:
-	//curr_network(mlme_priv/security_priv/qos/ht) + sta_info: (STA & AP) CAP/INFO	
-	//scan_q: AP CAP/INFO
+	/* 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
+	/* AP_Mode: */
+	/* curr_network(mlme_priv/security_priv/qos/ht) : AP CAP/INFO */
+	/* sta_info: (AP & STA) CAP/INFO */
 
 	unsigned int expire_to;
 
@@ -297,17 +385,20 @@ struct sta_info {
 	unsigned int authalg;
 	unsigned char chg_txt[128];
 
-	u16 capability;	
-	int flags;	
+	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 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;	
+	int wpa2_pairwise_cipher;
 
 	u8 bpairwise_key_installed;
+#ifdef CONFIG_RTW_80211R
+	u8 ft_pairwise_key_installed;
+#endif
 
 #ifdef CONFIG_NATIVEAP_MLME
 	u8 wpa_ie[32];
@@ -319,7 +410,7 @@ struct sta_info {
 	u8 no_ht_set;
 	u8 ht_20mhz_set;
 	u8 ht_40mhz_intolerant;
-#endif	// CONFIG_NATIVEAP_MLME
+#endif /* CONFIG_NATIVEAP_MLME */
 
 #ifdef CONFIG_ATMEL_RC_PATCH
 	u8 flag_atmel_rc;
@@ -328,30 +419,30 @@ struct sta_info {
 	u8 qos_info;
 
 	u8 max_sp_len;
-	u8 uapsd_bk;//BIT(0): Delivery enabled, BIT(1): Trigger enabled
+	u8 uapsd_bk;/* BIT(0): Delivery enabled, BIT(1): Trigger enabled */
 	u8 uapsd_be;
 	u8 uapsd_vi;
-	u8 uapsd_vo;	
+	u8 uapsd_vo;
 
 	u8 has_legacy_ac;
 	unsigned int sleepq_ac_len;
 
 #ifdef CONFIG_P2P
-	//p2p priv data
+	/* p2p priv data */
 	u8 is_p2p_device;
 	u8 p2p_status_code;
 
-	//p2p client info
+	/* p2p client info */
 	u8 dev_addr[ETH_ALEN];
-	//u8 iface_addr[ETH_ALEN];//= hwaddr[ETH_ALEN]
+	/* u8 iface_addr[ETH_ALEN]; */ /* = hwaddr[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;
+	u8 secdev_types_list[32];/* 32/8 == 4; */
 	u16 dev_name_len;
-	u8 dev_name[32];	
-#endif //CONFIG_P2P
+	u8 dev_name[32];
+#endif /* CONFIG_P2P */
 
 #ifdef CONFIG_WFD
 	u8 op_wfd_mode;
@@ -359,76 +450,77 @@ struct sta_info {
 
 #ifdef CONFIG_TX_MCAST2UNI
 	u8 under_exist_checking;
-#endif	// CONFIG_TX_MCAST2UNI
-	
+#endif /* CONFIG_TX_MCAST2UNI */
+
 	u8 keep_alive_trycnt;
 
 #ifdef CONFIG_AUTO_AP_MODE
-	u8 isrc; //this device is rc
-	u16 pid; // pairing id
+	u8 isrc; /* this device is rc */
+	u16 pid; /* pairing id */
 #endif
 
-#endif	// CONFIG_AP_MODE	
+#endif /* CONFIG_AP_MODE	 */
+
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink;
+
+	u8 local_mps;
+	u8 peer_mps;
+	u8 nonpeer_mps;
+
+	struct rtw_atlm_param metrics;
+#endif
 
 #ifdef CONFIG_IOCTL_CFG80211
 	u8 *passoc_req;
 	u32 assoc_req_len;
 #endif
 
-	//for DM
-	RSSI_STA	 rssi_stat;
-	
-	//ODM_STA_INFO_T
-	// ================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		WirelessMode;		// 
-	u8		IOTPeer;			// Enum value.	HT_IOT_PEER_E
-	// ODM Write
-	//1 PHY_STATUS_INFO
-	u8		RSSI_Path[4];		// 
-	u8		RSSI_Ave;
-	u8		RXEVM[4];
-	u8		RXSNR[4];
-
-	u8		rssi_level;			//for Refresh RA mask
-	// ODM Write
-	//1 TX_INFO (may changed by IC)
-	//TX_INFO_T		pTxInfo;				// Define in IC folder. Move lower layer.
-	//
-	// ================ODM Relative Info=======================
-	//
+	u8		IOTPeer;			/* Enum value.	HT_IOT_PEER_E */
+#ifdef CONFIG_LPS_PG
+	u8		lps_pg_rssi_lv;
+#endif
 
 	/* To store the sequence number of received management frame */
 	u16 RxMgmtFrameSeqNum;
 
 	struct st_ctl_t st_ctl;
+	u8 max_agg_num_minimal_record; /*keep minimal tx desc max_agg_num setting*/
+	u8 curr_rx_rate;
+	u8 curr_rx_rate_bmc;
 };
 
+#ifdef CONFIG_RTW_MESH
+#define STA_SET_MESH_PLINK(sta, link) (sta)->plink = link
+#else
+#define STA_SET_MESH_PLINK(sta, link) do {} while (0)
+#endif
+
+#define sta_tx_pkts(sta) \
+	(sta->sta_stats.tx_pkts)
+
+#define sta_last_tx_pkts(sta) \
+	(sta->sta_stats.last_tx_pkts)
+
 #define sta_rx_pkts(sta) \
 	(sta->sta_stats.rx_mgnt_pkts \
-	+ sta->sta_stats.rx_ctrl_pkts \
-	+ sta->sta_stats.rx_data_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)
+	 + 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_data_pkts(sta) \
-	(sta->sta_stats.rx_data_pkts)
+#define sta_rx_data_uc_pkts(sta) (sta->sta_stats.rx_data_pkts - sta->sta_stats.rx_data_bc_pkts - sta->sta_stats.rx_data_mc_pkts)
+#define sta_last_rx_data_uc_pkts(sta) (sta->sta_stats.last_rx_data_pkts - sta->sta_stats.last_rx_data_bc_pkts - sta->sta_stats.last_rx_data_mc_pkts)
 
 #define sta_rx_data_qos_pkts(sta, i) \
 	(sta->sta_stats.rx_data_qos_pkts[i])
 
-#define sta_last_rx_data_pkts(sta) \
-	(sta->sta_stats.last_rx_data_pkts)
-
 #define sta_last_rx_data_qos_pkts(sta, i) \
 	(sta->sta_stats.last_rx_data_qos_pkts[i])
 
@@ -468,8 +560,19 @@ struct sta_info {
 #define sta_last_rx_probersp_uo_pkts(sta) \
 	(sta->sta_stats.last_rx_probersp_uo_pkts)
 
+#ifdef CONFIG_RTW_MESH
+#define update_last_rx_hwmp_pkts(sta) \
+	do { \
+		sta->sta_stats.last_rx_hwmp_pkts = sta->sta_stats.rx_hwmp_pkts; \
+	} while(0)
+#else
+#define update_last_rx_hwmp_pkts(sta) do {} while(0)
+#endif
+
 #define sta_update_last_rx_pkts(sta) \
 	do { \
+		int __i; \
+		\
 		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; \
@@ -477,8 +580,14 @@ struct sta_info {
 		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; \
+		update_last_rx_hwmp_pkts(sta); \
+		\
 		sta->sta_stats.last_rx_data_pkts = sta->sta_stats.rx_data_pkts; \
-	} while(0)
+		sta->sta_stats.last_rx_data_bc_pkts = sta->sta_stats.rx_data_bc_pkts; \
+		sta->sta_stats.last_rx_data_mc_pkts = sta->sta_stats.rx_data_mc_pkts; \
+		for (__i = 0; __i < TID_NUM; __i++) \
+			sta->sta_stats.last_rx_data_qos_pkts[__i] = sta->sta_stats.rx_data_qos_pkts[__i]; \
+	} while (0)
 
 #define STA_RX_PKTS_ARG(sta) \
 	sta->sta_stats.rx_mgnt_pkts \
@@ -493,10 +602,13 @@ struct sta_info {
 #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
+	, sta->sta_stats.rx_data_pkts - sta->sta_stats.last_rx_data_pkts
 
 #define STA_PKTS_FMT "(m:%llu, c:%llu, d:%llu)"
 
+#define sta_rx_uc_bytes(sta) (sta->sta_stats.rx_bytes - sta->sta_stats.rx_bc_bytes - sta->sta_stats.rx_mc_bytes)
+#define sta_last_rx_uc_bytes(sta) (sta->sta_stats.last_rx_bytes - sta->sta_stats.last_rx_bc_bytes - sta->sta_stats.last_rx_mc_bytes)
+
 #ifdef CONFIG_WFD
 #define STA_OP_WFD_MODE(sta) (sta)->op_wfd_mode
 #define STA_SET_OP_WFD_MODE(sta, mode) (sta)->op_wfd_mode = (mode)
@@ -505,18 +617,20 @@ struct sta_info {
 #define STA_SET_OP_WFD_MODE(sta, mode) do {} while (0)
 #endif
 
+#define AID_BMP_LEN(max_aid) ((max_aid + 1) / 8 + (((max_aid + 1) % 8) ? 1 : 0))
+
 struct	sta_priv {
-	
+
 	u8 *pallocated_stainfo_buf;
 	u8 *pstainfo_buf;
 	_queue	free_sta_queue;
-	
+
 	_lock sta_hash_lock;
 	_list   sta_hash[NUM_STA];
 	int asoc_sta_count;
 	_queue sleep_q;
 	_queue wakeup_q;
-	
+
 	_adapter *padapter;
 
 	u32 adhoc_expire_to;
@@ -529,46 +643,58 @@ struct	sta_priv {
 	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, staion aid bitmap for sleeping sta.
-	u16 tim_bitmap;//only support 15 stations, aid=0~15 mapping bit0~bit15	
+	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
+	*/
+	struct sta_info **sta_aid;
+	u16 max_aid;
+	u16 started_aid; /* started AID for allocation search */
+	bool rr_aid; /* round robin AID allocation, will modify started_aid */
+	u8 aid_bmp_len; /* in byte */
+	u8 *sta_dz_bitmap;
+	u8 *tim_bitmap;
 
 	u16 max_num_sta;
 
-	struct wlan_acl_pool acl_list;
+#if CONFIG_RTW_MACADDR_ACL
+	struct wlan_acl_pool acl_list[RTW_ACL_PERIOD_NUM];
 #endif
 
+	#if CONFIG_RTW_PRE_LINK_STA
+	struct pre_link_sta_ctl_t pre_link_sta_ctl;
+	#endif
+
+#endif /* CONFIG_AP_MODE */
+
 #ifdef CONFIG_ATMEL_RC_PATCH
-	u8 atmel_rc_pattern [6];
+	u8 atmel_rc_pattern[6];
 #endif
-
+	u8 c2h_sta_mac[ETH_ALEN];
+	u8 c2h_adapter_id;
+	struct submit_ctx *gotc2h;
 };
 
 
-__inline static u32 wifi_mac_hash(u8 *mac)
+__inline static 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;
+	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;
 }
 
 
@@ -579,13 +705,31 @@ extern u32	_rtw_free_sta_priv(struct sta_priv *pstapriv);
 int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta);
 struct sta_info *rtw_get_stainfo_by_offset(struct sta_priv *stapriv, int offset);
 
-extern struct sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr);
+extern struct sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, const u8 *hwaddr);
 extern u32	rtw_free_stainfo(_adapter *padapter , struct sta_info *psta);
 extern void rtw_free_all_stainfo(_adapter *padapter);
-extern struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, u8 *hwaddr);
-extern u32 rtw_init_bcmc_stainfo(_adapter* padapter);
-extern struct sta_info* rtw_get_bcmc_stainfo(_adapter* padapter);
-extern u8 rtw_access_ctrl(_adapter *padapter, u8 *mac_addr);
+extern struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, const u8 *hwaddr);
+extern u32 rtw_init_bcmc_stainfo(_adapter *padapter);
+extern struct sta_info *rtw_get_bcmc_stainfo(_adapter *padapter);
 
-#endif //_STA_INFO_H_
+#ifdef CONFIG_AP_MODE
+u16 rtw_aid_alloc(_adapter *adapter, struct sta_info *sta);
+void dump_aid_status(void *sel, _adapter *adapter);
+#endif
+
+#if CONFIG_RTW_MACADDR_ACL
+extern u8 rtw_access_ctrl(_adapter *adapter, const u8 *mac_addr);
+void dump_macaddr_acl(void *sel, _adapter *adapter);
+#endif
 
+bool rtw_is_pre_link_sta(struct sta_priv *stapriv, u8 *addr);
+#if CONFIG_RTW_PRE_LINK_STA
+struct sta_info *rtw_pre_link_sta_add(struct sta_priv *stapriv, u8 *hwaddr);
+void rtw_pre_link_sta_del(struct sta_priv *stapriv, u8 *hwaddr);
+void rtw_pre_link_sta_ctl_reset(struct sta_priv *stapriv);
+void rtw_pre_link_sta_ctl_init(struct sta_priv *stapriv);
+void rtw_pre_link_sta_ctl_deinit(struct sta_priv *stapriv);
+void dump_pre_link_sta_ctl(void *sel, struct sta_priv *stapriv);
+#endif /* CONFIG_RTW_PRE_LINK_STA */
+
+#endif /* _STA_INFO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_hal.h
index 8d500eb5050f..0e44ba08bb14 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_hal.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,51 +12,56 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __USB_HAL_H__
 #define __USB_HAL_H__
 
 int usb_init_recv_priv(_adapter *padapter, u16 ini_in_buf_sz);
-void usb_free_recv_priv (_adapter *padapter, u16 ini_in_buf_sz);
+void usb_free_recv_priv(_adapter *padapter, u16 ini_in_buf_sz);
+#ifdef CONFIG_FW_C2H_REG
+void usb_c2h_hisr_hdl(_adapter *adapter, u8 *buf);
+#endif
 
 u8 rtw_set_hal_ops(_adapter *padapter);
 
 #ifdef CONFIG_RTL8188E
-void rtl8188eu_set_hal_ops(_adapter * padapter);
+void rtl8188eu_set_hal_ops(_adapter *padapter);
 #endif
 
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-void rtl8812au_set_hal_ops(_adapter * padapter);
+void rtl8812au_set_hal_ops(_adapter *padapter);
 #endif
 
 #ifdef CONFIG_RTL8192E
-void rtl8192eu_set_hal_ops(_adapter * padapter);
+void rtl8192eu_set_hal_ops(_adapter *padapter);
 #endif
 
 
 #ifdef CONFIG_RTL8723B
-void rtl8723bu_set_hal_ops(_adapter * padapter);
+void rtl8723bu_set_hal_ops(_adapter *padapter);
 #endif
 
 #ifdef CONFIG_RTL8814A
-void rtl8814au_set_hal_ops(_adapter * padapter);
+void rtl8814au_set_hal_ops(_adapter *padapter);
 #endif /* CONFIG_RTL8814A */
 
 #ifdef CONFIG_RTL8188F
 void rtl8188fu_set_hal_ops(_adapter *padapter);
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+void rtl8188gtvu_set_hal_ops(_adapter *padapter);
+#endif
+
 #ifdef CONFIG_RTL8703B
 void rtl8703bu_set_hal_ops(_adapter *padapter);
 #endif
 
-#ifdef CONFIG_INTEL_PROXIM	
-extern _adapter  *rtw_usb_get_sw_pointer(void);
-#endif	//CONFIG_INTEL_PROXIM
-#endif //__USB_HAL_H__
+#ifdef CONFIG_RTL8723D
+void rtl8723du_set_hal_ops(_adapter *padapter);
+#endif
 
+#ifdef CONFIG_INTEL_PROXIM
+extern _adapter  *rtw_usb_get_sw_pointer(void);
+#endif /* CONFIG_INTEL_PROXIM */
+#endif /* __USB_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops.h
index ee23314aac99..69442842f0fd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __USB_OPS_H_
 #define __USB_OPS_H_
 
@@ -27,34 +23,20 @@
 #define REALTEK_USB_VENQT_CMD_IDX	0x00
 #define REALTEK_USB_IN_INT_EP_IDX	1
 
-enum{
+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)
+#define MAX_VENDOR_REQ_CMD_SIZE	254		/* 8188cu SIE Support */
+#define MAX_USB_IO_CTL_SIZE		(MAX_VENDOR_REQ_CMD_SIZE + ALIGNMENT_UNIT)
 
 #ifdef PLATFORM_LINUX
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,12)) 
-#define rtw_usb_control_msg(dev, pipe, request, requesttype, value, index, data, size, timeout_ms) \
-	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), (data), (size), (timeout_ms)) 
-#define rtw_usb_bulk_msg(usb_dev, pipe, data, len, actual_length, timeout_ms) \
-	usb_bulk_msg((usb_dev), (pipe), (data), (len), (actual_length), (timeout_ms))
-#else
-#define rtw_usb_control_msg(dev, pipe, request, requesttype, value, index, data, size,timeout_ms) \
-	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), (data), (size), \
-		((timeout_ms) == 0) ||((timeout_ms)*HZ/1000>0)?((timeout_ms)*HZ/1000):1) 
-#define rtw_usb_bulk_msg(usb_dev, pipe, data, len, actual_length, timeout_ms) \
-	usb_bulk_msg((usb_dev), (pipe), (data), (len), (actual_length), \
-		((timeout_ms) == 0) ||((timeout_ms)*HZ/1000>0)?((timeout_ms)*HZ/1000):1) 
-#endif
 #include <usb_ops_linux.h>
-#endif //PLATFORM_LINUX
+#endif /* PLATFORM_LINUX */
 
 #ifdef CONFIG_RTL8188E
 void rtl8188eu_set_hw_type(struct dvobj_priv *pdvobj);
-void rtl8188eu_set_intf_ops(struct _io_ops *pops);
 #ifdef CONFIG_SUPPORT_USB_INT
 void interrupt_handler_8188eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
@@ -62,7 +44,6 @@ void interrupt_handler_8188eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
 void rtl8812au_set_hw_type(struct dvobj_priv *pdvobj);
-void rtl8812au_set_intf_ops(struct _io_ops *pops);
 #ifdef CONFIG_SUPPORT_USB_INT
 void interrupt_handler_8812au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
@@ -70,7 +51,6 @@ void interrupt_handler_8812au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 
 #ifdef CONFIG_RTL8814A
 void rtl8814au_set_hw_type(struct dvobj_priv *pdvobj);
-void rtl8814au_set_intf_ops(struct _io_ops	*pops);
 #ifdef CONFIG_SUPPORT_USB_INT
 void interrupt_handler_8814au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
@@ -78,7 +58,6 @@ void interrupt_handler_8814au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 
 #ifdef CONFIG_RTL8192E
 void rtl8192eu_set_hw_type(struct dvobj_priv *pdvobj);
-void rtl8192eu_set_intf_ops(struct _io_ops *pops);
 #ifdef CONFIG_SUPPORT_USB_INT
 void interrupt_handler_8192eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
@@ -87,19 +66,20 @@ void interrupt_handler_8192eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 
 #ifdef CONFIG_RTL8188F
 void rtl8188fu_set_hw_type(struct dvobj_priv *pdvobj);
-void rtl8188fu_set_intf_ops(struct _io_ops *pops);
-void rtl8188fu_recv_tasklet(void *priv);
-void rtl8188fu_xmit_tasklet(void *priv);
 #ifdef CONFIG_SUPPORT_USB_INT
 void interrupt_handler_8188fu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+void rtl8188gtvu_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8188gtvu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+#endif
+
 #ifdef CONFIG_RTL8723B
 void rtl8723bu_set_hw_type(struct dvobj_priv *pdvobj);
-void rtl8723bu_set_intf_ops(struct _io_ops *pops);
-void rtl8723bu_recv_tasklet(void *priv);
-void rtl8723bu_xmit_tasklet(void *priv);
 #ifdef CONFIG_SUPPORT_USB_INT
 void interrupt_handler_8723bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
@@ -107,14 +87,23 @@ void interrupt_handler_8723bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 
 #ifdef CONFIG_RTL8703B
 void rtl8703bu_set_hw_type(struct dvobj_priv *pdvobj);
-void rtl8703bu_set_intf_ops(struct _io_ops *pops);
-void rtl8703bu_recv_tasklet(void *priv);
-void rtl8703bu_xmit_tasklet(void *priv);
 #ifdef CONFIG_SUPPORT_USB_INT
 void interrupt_handler_8703bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif /* CONFIG_SUPPORT_USB_INT */
 #endif /* CONFIG_RTL8703B */
 
+void usb_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
+
+#ifdef CONFIG_RTL8723D
+void rtl8723du_set_hw_type(struct dvobj_priv *pdvobj);
+void rtl8723du_set_intf_ops(struct _io_ops *pops);
+void rtl8723du_recv_tasklet(void *priv);
+void rtl8723du_xmit_tasklet(void *priv);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8723du(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif /* CONFIG_SUPPORT_USB_INT */
+#endif /* CONFIG_RTL8723D */
+
 enum RTW_USB_SPEED {
 	RTW_USB_SPEED_UNKNOWN	= 0,
 	RTW_USB_SPEED_1_1	= 1,
@@ -126,23 +115,22 @@ enum RTW_USB_SPEED {
 #define IS_HIGH_SPEED_USB(Adapter)	(adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_2)
 #define IS_SUPER_SPEED_USB(Adapter)	(adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_3)
 
-#define USB_SUPER_SPEED_BULK_SIZE	1024	// usb 3.0
-#define USB_HIGH_SPEED_BULK_SIZE	512		// usb 2.0
-#define USB_FULL_SPEED_BULK_SIZE	64		// usb 1.1
+#define USB_SUPER_SPEED_BULK_SIZE	1024	/* usb 3.0 */
+#define USB_HIGH_SPEED_BULK_SIZE	512		/* usb 2.0 */
+#define USB_FULL_SPEED_BULK_SIZE	64		/* usb 1.1 */
 
-static inline u8 rtw_usb_bulk_size_boundary(_adapter * padapter,int buf_len)
+static inline u8 rtw_usb_bulk_size_boundary(_adapter *padapter, int buf_len)
 {
 	u8 rst = _TRUE;
 
 	if (IS_SUPER_SPEED_USB(padapter))
-		rst = (0 == (buf_len) % USB_SUPER_SPEED_BULK_SIZE)?_TRUE:_FALSE;
-	if (IS_HIGH_SPEED_USB(padapter))
-		rst = (0 == (buf_len) % USB_HIGH_SPEED_BULK_SIZE)?_TRUE:_FALSE;	
-	else	
-		rst = (0 == (buf_len) % USB_FULL_SPEED_BULK_SIZE)?_TRUE:_FALSE;		
+		rst = (0 == (buf_len) % USB_SUPER_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
+	else if (IS_HIGH_SPEED_USB(padapter))
+		rst = (0 == (buf_len) % USB_HIGH_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
+	else
+		rst = (0 == (buf_len) % USB_FULL_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
 	return rst;
 }
 
 
-#endif //__USB_OPS_H_
-
+#endif /* __USB_OPS_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops_linux.h
index b0d0f43ee432..6ed3b29b9de2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_ops_linux.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,36 +12,31 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __USB_OPS_LINUX_H__
 #define __USB_OPS_LINUX_H__
 
 #define VENDOR_CMD_MAX_DATA_LEN	254
 #define FW_START_ADDRESS	0x1000
 
-#define RTW_USB_CONTROL_MSG_TIMEOUT_TEST	10//ms
-#define RTW_USB_CONTROL_MSG_TIMEOUT	500//ms
+#define RTW_USB_CONTROL_MSG_TIMEOUT_TEST	10/* ms */
+#define RTW_USB_CONTROL_MSG_TIMEOUT	500/* ms */
 
-#define RECV_BULK_IN_ADDR		0x80//assign by drv,not real address 
-#define RECV_INT_IN_ADDR		0x81//assign by drv,not real address 
+#define RECV_BULK_IN_ADDR		0x80/* assign by drv, not real address */
+#define RECV_INT_IN_ADDR		0x81/* assign by drv, not real address */
 
 #define INTERRUPT_MSG_FORMAT_LEN 60
 
 #if defined(CONFIG_VENDOR_REQ_RETRY) && defined(CONFIG_USB_VENDOR_REQ_MUTEX)
-/* vendor req retry should be in the situation when each vendor req is atomically submitted from others */
-#define MAX_USBCTRL_VENDORREQ_TIMES	10
+	/* vendor req retry should be in the situation when each vendor req is atomically submitted from others */
+	#define MAX_USBCTRL_VENDORREQ_TIMES	10
 #else
-#define MAX_USBCTRL_VENDORREQ_TIMES	1
+	#define MAX_USBCTRL_VENDORREQ_TIMES	1
 #endif
 
-#define RTW_USB_BULKOUT_TIMEOUT	5000//ms
+#define RTW_USB_BULKOUT_TIMEOUT	5000/* ms */
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)) || (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,18))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 5, 0)) || (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 18))
 #define _usbctrl_vendorreq_async_callback(urb, regs)	_usbctrl_vendorreq_async_callback(urb)
 #define usb_bulkout_zero_complete(purb, regs)	usb_bulkout_zero_complete(purb)
 #define usb_write_mem_complete(purb, regs)	usb_write_mem_complete(purb)
@@ -49,6 +45,21 @@
 #define usb_read_interrupt_complete(purb, regs)	usb_read_interrupt_complete(purb)
 #endif
 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 12))
+#define rtw_usb_control_msg(dev, pipe, request, requesttype, value, index, data, size, timeout_ms) \
+	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), (data), (size), (timeout_ms))
+#define rtw_usb_bulk_msg(usb_dev, pipe, data, len, actual_length, timeout_ms) \
+	usb_bulk_msg((usb_dev), (pipe), (data), (len), (actual_length), (timeout_ms))
+#else
+#define rtw_usb_control_msg(dev, pipe, request, requesttype, value, index, data, size, timeout_ms) \
+	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), (data), (size), \
+		((timeout_ms) == 0) || ((timeout_ms) * HZ / 1000 > 0) ? ((timeout_ms) * HZ / 1000) : 1)
+#define rtw_usb_bulk_msg(usb_dev, pipe, data, len, actual_length, timeout_ms) \
+	usb_bulk_msg((usb_dev), (pipe), (data), (len), (actual_length), \
+		((timeout_ms) == 0) || ((timeout_ms) * HZ / 1000 > 0) ? ((timeout_ms) * HZ / 1000) : 1)
+#endif
+
+
 #ifdef CONFIG_USB_SUPPORT_ASYNC_VDN_REQ
 int usb_async_write8(struct intf_hdl *pintfhdl, u32 addr, u8 val);
 int usb_async_write16(struct intf_hdl *pintfhdl, u32 addr, u16 val);
@@ -68,7 +79,7 @@ void usb_write_port_cancel(struct intf_hdl *pintfhdl);
 int usbctrl_vendorreq(struct intf_hdl *pintfhdl, u8 request, u16 value, u16 index, void *pdata, u16 len, u8 requesttype);
 #ifdef CONFIG_USB_SUPPORT_ASYNC_VDN_REQ
 int _usbctrl_vendorreq_async_write(struct usb_device *udev, u8 request,
-	u16 value, u16 index, void *pdata, u16 len, u8 requesttype);
+		u16 value, u16 index, void *pdata, u16 len, u8 requesttype);
 #endif /* CONFIG_USB_SUPPORT_ASYNC_VDN_REQ */
 
 u8 usb_read8(struct intf_hdl *pintfhdl, u32 addr);
@@ -86,4 +97,3 @@ void usb_read_interrupt_complete(struct urb *purb, struct pt_regs *regs);
 u32 usb_read_interrupt(struct intf_hdl *pintfhdl, u32 addr);
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_osintf.h
index 62dc44aab43f..21e0391a5bbf 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_osintf.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __USB_OSINTF_H
 #define __USB_OSINTF_H
 
@@ -25,8 +21,7 @@
 #define USBD_HALTED(Status) ((ULONG)(Status) >> 30 == 3)
 
 
-u8 usbvendorrequest(struct dvobj_priv *pdvobjpriv, RT_USB_BREQUEST brequest, RT_USB_WVALUE wvalue, u8 windex, void* data, u8 datalen, u8 isdirectionin);
+u8 usbvendorrequest(struct dvobj_priv *pdvobjpriv, RT_USB_BREQUEST brequest, RT_USB_WVALUE wvalue, u8 windex, void *data, u8 datalen, u8 isdirectionin);
 
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_vendor_req.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_vendor_req.h
index b60eeface8f6..54972ead3114 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_vendor_req.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/usb_vendor_req.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,16 +12,11 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _USB_VENDOR_REQUEST_H_
 #define _USB_VENDOR_REQUEST_H_
 
-//4	Set/Get Register related wIndex/Data
+/* 4	Set/Get Register related wIndex/Data */
 #define	RT_USB_RESET_MASK_OFF		0
 #define	RT_USB_RESET_MASK_ON		1
 #define	RT_USB_SLEEP_MASK_OFF		0
@@ -28,7 +24,7 @@
 #define	RT_USB_LDO_ON				1
 #define	RT_USB_LDO_OFF				0
 
-//4	Set/Get SYSCLK related	wValue or Data
+/* 4	Set/Get SYSCLK related	wValue or Data */
 #define	RT_USB_SYSCLK_32KHZ		0
 #define	RT_USB_SYSCLK_40MHZ		1
 #define	RT_USB_SYSCLK_60MHZ		2
@@ -51,10 +47,11 @@ typedef enum _RT_USB_WVALUE {
 } RT_USB_WVALUE;
 
 
-//BOOLEAN usbvendorrequest(PCE_USB_DEVICE	CEdevice, RT_USB_BREQUEST bRequest, RT_USB_WVALUE wValue, UCHAR wIndex, PVOID Data, UCHAR DataLength, BOOLEAN isDirectionIn);
-//BOOLEAN CEusbGetStatusRequest(PCE_USB_DEVICE CEdevice, IN USHORT Op, IN USHORT Index, PVOID Data);
-//BOOLEAN CEusbFeatureRequest(PCE_USB_DEVICE CEdevice, IN USHORT Op, IN USHORT FeatureSelector, IN USHORT Index);
-//BOOLEAN CEusbGetDescriptorRequest(PCE_USB_DEVICE CEdevice, IN short urbLength, IN UCHAR DescriptorType, IN UCHAR Index, IN USHORT LanguageId, IN PVOID  TransferBuffer, IN ULONG TransferBufferLength);
-
+#if 0
+BOOLEAN usbvendorrequest(PCE_USB_DEVICE	CEdevice, RT_USB_BREQUEST bRequest, RT_USB_WVALUE wValue, UCHAR wIndex, PVOID Data, UCHAR DataLength, BOOLEAN isDirectionIn);
+BOOLEAN CEusbGetStatusRequest(PCE_USB_DEVICE CEdevice, IN USHORT Op, IN USHORT Index, PVOID Data);
+BOOLEAN CEusbFeatureRequest(PCE_USB_DEVICE CEdevice, IN USHORT Op, IN USHORT FeatureSelector, IN USHORT Index);
+BOOLEAN CEusbGetDescriptorRequest(PCE_USB_DEVICE CEdevice, IN short urbLength, IN UCHAR DescriptorType, IN UCHAR Index, IN USHORT LanguageId, IN PVOID  TransferBuffer, IN ULONG TransferBufferLength);
 #endif
 
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wifi.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wifi.h
index 0192f8918aac..5981562e07eb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wifi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wifi.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,18 +12,13 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef _WIFI_H_
 #define _WIFI_H_
 
 
 #ifdef BIT
-//#error	"BIT define occurred earlier elsewhere!\n"
+/* #error	"BIT define occurred earlier elsewhere!\n" */
 #undef BIT
 #endif
 #define BIT(x)	(1UL << (x))
@@ -50,11 +46,21 @@
 #define WLAN_ETHHDR_LEN		14
 #define WLAN_WMM_LEN		24
 
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+#define WLAN_MAX_VENDOR_IE_LEN 255
+#define WLAN_MAX_VENDOR_IE_NUM 5
+#define WIFI_BEACON_VENDOR_IE_BIT BIT(0)
+#define WIFI_PROBEREQ_VENDOR_IE_BIT BIT(1)
+#define WIFI_PROBERESP_VENDOR_IE_BIT BIT(2)
+#define WIFI_ASSOCREQ_VENDOR_IE_BIT BIT(3)
+#define WIFI_ASSOCRESP_VENDOR_IE_BIT BIT(4)
+#endif
+
 #define P80211CAPTURE_VERSION	0x80211001
 
-// 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
+/* 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 */
 
 #ifdef GREEN_HILL
 #pragma pack(1)
@@ -64,45 +70,47 @@ enum WIFI_FRAME_TYPE {
 	WIFI_MGT_TYPE  =	(0),
 	WIFI_CTRL_TYPE =	(BIT(2)),
 	WIFI_DATA_TYPE =	(BIT(3)),
-	WIFI_QOS_DATA_TYPE	= (BIT(7)|BIT(3)),	//!< QoS Data	
+	WIFI_QOS_DATA_TYPE	= (BIT(7) | BIT(3)),	/* !< QoS Data	 */
 };
 
 enum WIFI_FRAME_SUBTYPE {
 
-    // below is for mgt frame
-    WIFI_ASSOCREQ       = (0 | WIFI_MGT_TYPE),
-    WIFI_ASSOCRSP       = (BIT(4) | WIFI_MGT_TYPE),
-    WIFI_REASSOCREQ     = (BIT(5) | WIFI_MGT_TYPE),
-    WIFI_REASSOCRSP     = (BIT(5) | BIT(4) | WIFI_MGT_TYPE),
-    WIFI_PROBEREQ       = (BIT(6) | WIFI_MGT_TYPE),
-    WIFI_PROBERSP       = (BIT(6) | BIT(4) | WIFI_MGT_TYPE),
-    WIFI_BEACON         = (BIT(7) | WIFI_MGT_TYPE),
-    WIFI_ATIM           = (BIT(7) | BIT(4) | WIFI_MGT_TYPE),
-    WIFI_DISASSOC       = (BIT(7) | BIT(5) | WIFI_MGT_TYPE),
-    WIFI_AUTH           = (BIT(7) | BIT(5) | BIT(4) | WIFI_MGT_TYPE),
-    WIFI_DEAUTH         = (BIT(7) | BIT(6) | WIFI_MGT_TYPE),
-    WIFI_ACTION         = (BIT(7) | BIT(6) | BIT(4) | WIFI_MGT_TYPE),
-    WIFI_ACTION_NOACK = (BIT(7) | BIT(6) | BIT(5) | WIFI_MGT_TYPE),
-
-    // below is for control frame
-    WIFI_NDPA         = (BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
-    WIFI_PSPOLL         = (BIT(7) | BIT(5) | WIFI_CTRL_TYPE),
-    WIFI_RTS            = (BIT(7) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
-    WIFI_CTS            = (BIT(7) | BIT(6) | WIFI_CTRL_TYPE),
-    WIFI_ACK            = (BIT(7) | BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
-    WIFI_CFEND          = (BIT(7) | BIT(6) | BIT(5) | WIFI_CTRL_TYPE),
-    WIFI_CFEND_CFACK    = (BIT(7) | BIT(6) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
-
-    // below is for data frame
-    WIFI_DATA           = (0 | WIFI_DATA_TYPE),
-    WIFI_DATA_CFACK     = (BIT(4) | WIFI_DATA_TYPE),
-    WIFI_DATA_CFPOLL    = (BIT(5) | WIFI_DATA_TYPE),
-    WIFI_DATA_CFACKPOLL = (BIT(5) | BIT(4) | WIFI_DATA_TYPE),
-    WIFI_DATA_NULL      = (BIT(6) | WIFI_DATA_TYPE),
-    WIFI_CF_ACK         = (BIT(6) | BIT(4) | WIFI_DATA_TYPE),
-    WIFI_CF_POLL        = (BIT(6) | BIT(5) | WIFI_DATA_TYPE),
-    WIFI_CF_ACKPOLL     = (BIT(6) | BIT(5) | BIT(4) | WIFI_DATA_TYPE),
-    WIFI_QOS_DATA_NULL	= (BIT(6) | WIFI_QOS_DATA_TYPE),
+	/* below is for mgt frame */
+	WIFI_ASSOCREQ       = (0 | WIFI_MGT_TYPE),
+	WIFI_ASSOCRSP       = (BIT(4) | WIFI_MGT_TYPE),
+	WIFI_REASSOCREQ     = (BIT(5) | WIFI_MGT_TYPE),
+	WIFI_REASSOCRSP     = (BIT(5) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_PROBEREQ       = (BIT(6) | WIFI_MGT_TYPE),
+	WIFI_PROBERSP       = (BIT(6) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_BEACON         = (BIT(7) | WIFI_MGT_TYPE),
+	WIFI_ATIM           = (BIT(7) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_DISASSOC       = (BIT(7) | BIT(5) | WIFI_MGT_TYPE),
+	WIFI_AUTH           = (BIT(7) | BIT(5) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_DEAUTH         = (BIT(7) | BIT(6) | WIFI_MGT_TYPE),
+	WIFI_ACTION         = (BIT(7) | BIT(6) | BIT(4) | WIFI_MGT_TYPE),
+	WIFI_ACTION_NOACK = (BIT(7) | BIT(6) | BIT(5) | WIFI_MGT_TYPE),
+
+	/* below is for control frame */
+	WIFI_BF_REPORT_POLL = (BIT(6) | WIFI_CTRL_TYPE),
+	WIFI_NDPA         = (BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
+	WIFI_BAR            = (BIT(7) | WIFI_CTRL_TYPE),
+	WIFI_PSPOLL         = (BIT(7) | BIT(5) | WIFI_CTRL_TYPE),
+	WIFI_RTS            = (BIT(7) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
+	WIFI_CTS            = (BIT(7) | BIT(6) | WIFI_CTRL_TYPE),
+	WIFI_ACK            = (BIT(7) | BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
+	WIFI_CFEND          = (BIT(7) | BIT(6) | BIT(5) | WIFI_CTRL_TYPE),
+	WIFI_CFEND_CFACK    = (BIT(7) | BIT(6) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
+
+	/* below is for data frame */
+	WIFI_DATA           = (0 | WIFI_DATA_TYPE),
+	WIFI_DATA_CFACK     = (BIT(4) | WIFI_DATA_TYPE),
+	WIFI_DATA_CFPOLL    = (BIT(5) | WIFI_DATA_TYPE),
+	WIFI_DATA_CFACKPOLL = (BIT(5) | BIT(4) | WIFI_DATA_TYPE),
+	WIFI_DATA_NULL      = (BIT(6) | WIFI_DATA_TYPE),
+	WIFI_CF_ACK         = (BIT(6) | BIT(4) | WIFI_DATA_TYPE),
+	WIFI_CF_POLL        = (BIT(6) | BIT(5) | WIFI_DATA_TYPE),
+	WIFI_CF_ACKPOLL     = (BIT(6) | BIT(5) | BIT(4) | WIFI_DATA_TYPE),
+	WIFI_QOS_DATA_NULL	= (BIT(6) | WIFI_QOS_DATA_TYPE),
 };
 
 enum WIFI_REASON_CODE	{
@@ -117,7 +125,7 @@ enum WIFI_REASON_CODE	{
 	_RSON_DISAOC_STA_LEAVING_		= 8,
 	_RSON_ASOC_NOT_AUTH_			= 9,
 
-	// WPA reason
+	/* WPA reason */
 	_RSON_INVALID_IE_				= 13,
 	_RSON_MIC_FAILURE_				= 14,
 	_RSON_4WAY_HNDSHK_TIMEOUT_		= 15,
@@ -130,7 +138,7 @@ enum WIFI_REASON_CODE	{
 	_RSON_INVALID_RSNE_CAP_			= 22,
 	_RSON_IEEE_802DOT1X_AUTH_FAIL_	= 23,
 
-	//belowing are Realtek definition
+	/* belowing are Realtek definition */
 	_RSON_PMK_NOT_AVAILABLE_		= 24,
 	_RSON_TDLS_TEAR_TOOFAR_			= 25,
 	_RSON_TDLS_TEAR_UN_RSN_			= 26,
@@ -201,7 +209,7 @@ enum WIFI_STATUS_CODE {
 #define WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA 17
 #define WLAN_STATUS_ASSOC_DENIED_RATES 18
 #endif
-//entended 
+/* entended */
 /* IEEE 802.11b */
 #define WLAN_STATUS_ASSOC_DENIED_NOSHORT 19
 #define WLAN_STATUS_ASSOC_DENIED_NOPBCC 20
@@ -263,26 +271,26 @@ enum WIFI_REG_DOMAIN {
 #define SetToDs(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) |= cpu_to_le16(_TO_DS_); \
-	} while(0)
+	} while (0)
 
 #define GetToDs(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_TO_DS_)) != 0)
 
 #define ClearToDs(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_TO_DS_)); \
-	} while(0)
+	} while (0)
 
 #define SetFrDs(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) |= cpu_to_le16(_FROM_DS_); \
-	} while(0)
+	} while (0)
 
 #define GetFrDs(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_FROM_DS_)) != 0)
 
 #define ClearFrDs(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_FROM_DS_)); \
-	} while(0)
+	} while (0)
 
 #define get_tofr_ds(pframe)	((GetToDs(pframe) << 1) | GetFrDs(pframe))
 
@@ -290,81 +298,83 @@ enum WIFI_REG_DOMAIN {
 #define SetMFrag(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) |= cpu_to_le16(_MORE_FRAG_); \
-	} while(0)
+	} while (0)
 
 #define GetMFrag(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_MORE_FRAG_)) != 0)
 
 #define ClearMFrag(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_MORE_FRAG_)); \
-	} while(0)
+	} while (0)
 
 #define SetRetry(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) |= cpu_to_le16(_RETRY_); \
-	} while(0)
+	} while (0)
 
 #define GetRetry(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_RETRY_)) != 0)
 
 #define ClearRetry(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_RETRY_)); \
-	} while(0)
+	} while (0)
 
 #define SetPwrMgt(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) |= cpu_to_le16(_PWRMGT_); \
-	} while(0)
+	} while (0)
 
 #define GetPwrMgt(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_PWRMGT_)) != 0)
 
 #define ClearPwrMgt(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_PWRMGT_)); \
-	} while(0)
+	} while (0)
 
 #define SetMData(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) |= cpu_to_le16(_MORE_DATA_); \
-	} while(0)
+	} while (0)
 
 #define GetMData(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_MORE_DATA_)) != 0)
 
 #define ClearMData(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_MORE_DATA_)); \
-	} while(0)
+	} while (0)
 
 #define SetPrivacy(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) |= cpu_to_le16(_PRIVACY_); \
-	} while(0)
+	} while (0)
 
 #define GetPrivacy(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_PRIVACY_)) != 0)
 
 #define ClearPrivacy(pbuf)	\
 	do	{	\
 		*(unsigned short *)(pbuf) &= (~cpu_to_le16(_PRIVACY_)); \
-	} while(0)
+	} while (0)
 
 
 #define GetOrder(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_ORDER_)) != 0)
 
 #define GetFrameType(pbuf)	(le16_to_cpu(*(unsigned short *)(pbuf)) & (BIT(3) | BIT(2)))
 
-#define SetFrameType(pbuf,type)	\
-	do { 	\
+#define SetFrameType(pbuf, type)	\
+	do {	\
 		*(unsigned short *)(pbuf) &= __constant_cpu_to_le16(~(BIT(3) | BIT(2))); \
 		*(unsigned short *)(pbuf) |= __constant_cpu_to_le16(type); \
-	} while(0)
+	} while (0)
 
-#define GetFrameSubType(pbuf)	(cpu_to_le16(*(unsigned short *)(pbuf)) & (BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3) | BIT(2)))
+#define get_frame_sub_type(pbuf)	(cpu_to_le16(*(unsigned short *)(pbuf)) & (BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3) | BIT(2)))
 
-#define SetFrameSubType(pbuf,type) \
+
+#define set_frame_sub_type(pbuf, type) \
 	do {    \
 		*(unsigned short *)(pbuf) &= cpu_to_le16(~(BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3) | BIT(2))); \
 		*(unsigned short *)(pbuf) |= cpu_to_le16(type); \
-	} while(0)
+	} while (0)
+
 
 #define GetSequence(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + 22)) >> 4)
 
@@ -376,68 +386,64 @@ enum WIFI_REG_DOMAIN {
 	do {    \
 		*(unsigned short *)((SIZE_PTR)(pbuf) + 22) = \
 			((*(unsigned short *)((SIZE_PTR)(pbuf) + 22)) & le16_to_cpu(~(0x000f))) | \
-			cpu_to_le16(0x0f & (num));     \
-	} while(0)
+				cpu_to_le16(0x0f & (num));     \
+	} while (0)
 
 #define SetSeqNum(pbuf, num) \
 	do {    \
 		*(unsigned short *)((SIZE_PTR)(pbuf) + 22) = \
 			((*(unsigned short *)((SIZE_PTR)(pbuf) + 22)) & le16_to_cpu((unsigned short)~0xfff0)) | \
 			le16_to_cpu((unsigned short)(0xfff0 & (num << 4))); \
-	} while(0)
+	} while (0)
 
-#define SetDuration(pbuf, dur) \
+#define set_duration(pbuf, dur) \
 	do {    \
 		*(unsigned short *)((SIZE_PTR)(pbuf) + 2) = cpu_to_le16(0xffff & (dur)); \
-	} while(0)
-
-
-#define SetPriority(pbuf, tid)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16(tid & 0xf); \
-	} while(0)
+	} while (0)
 
-#define GetPriority(pbuf)	((le16_to_cpu(*(unsigned short *)(pbuf))) & 0xf)
 
-#define SetEOSP(pbuf, eosp)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16( (eosp & 1) << 4); \
-	} while(0)
+/* QoS control field */
+#define SetPriority(qc, tid)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 0, 4, tid)
+#define SetEOSP(qc, eosp)		SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 4, 1, eosp)
+#define SetAckpolicy(qc, ack)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 5, 2, ack)
+#define SetAMsdu(qc, amsdu)		SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 7, 1, amsdu)
 
-#define SetAckpolicy(pbuf, ack)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16( (ack & 3) << 5); \
-	} while(0)
+#define GetPriority(qc)		LE_BITS_TO_2BYTE(((u8 *)(qc)), 0, 4)
+#define GetEOSP(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 4, 1)
+#define GetAckpolicy(qc)	LE_BITS_TO_2BYTE(((u8 *)(qc)), 5, 2)
+#define GetAMsdu(qc)		LE_BITS_TO_2BYTE(((u8 *)(qc)), 7, 1)
 
-#define GetAckpolicy(pbuf) (((le16_to_cpu(*(unsigned short *)pbuf)) >> 5) & 0x3)
+/* QoS control field (MSTA only) */
+#define set_mctrl_present(qc, p)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 8, 1, p)
+#define set_mps_lv(qc, lv)			SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 9, 1, lv)
+#define set_rspi(qc, rspi)			SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 10, 1, rspi)
 
-#define GetAMsdu(pbuf) (((le16_to_cpu(*(unsigned short *)pbuf)) >> 7) & 0x1)
+#define get_mctrl_present(qc)	LE_BITS_TO_2BYTE(((u8 *)(qc)), 8, 1)
+#define get_mps_lv(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 9, 1)
+#define get_rspi(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 10, 1)
 
-#define SetAMsdu(pbuf, amsdu)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16( (amsdu & 1) << 7); \
-	} while(0)	
 
 #define GetAid(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + 2)) & 0x3fff)
 
-#define GetTid(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + (((GetToDs(pbuf)<<1)|GetFrDs(pbuf))==3?30:24))) & 0x000f)
+#define GetTid(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + (((GetToDs(pbuf)<<1) | GetFrDs(pbuf)) == 3 ? 30 : 24))) & 0x000f)
 
 #define GetAddr1Ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 4))
 
-#define GetAddr2Ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 10))
+#define get_addr2_ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 10))
 
 #define GetAddr3Ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 16))
 
 #define GetAddr4Ptr(pbuf)	((unsigned char *)((SIZE_PTR)(pbuf) + 24))
 
+
 #define MacAddr_isBcst(addr) \
-( \
-	( (addr[0] == 0xff) && (addr[1] == 0xff) && \
-		(addr[2] == 0xff) && (addr[3] == 0xff) && \
-		(addr[4] == 0xff) && (addr[5] == 0xff) )  ? _TRUE : _FALSE \
-)
+	(\
+	 ((addr[0] == 0xff) && (addr[1] == 0xff) && \
+	  (addr[2] == 0xff) && (addr[3] == 0xff) && \
+	  (addr[4] == 0xff) && (addr[5] == 0xff)) ? _TRUE : _FALSE \
+	)
 
-__inline static int IS_MCAST(unsigned char *da)
+__inline static int IS_MCAST(const u8 *da)
 {
 	if ((*da) & 0x01)
 		return _TRUE;
@@ -445,84 +451,86 @@ __inline static int IS_MCAST(unsigned char *da)
 		return _FALSE;
 }
 
-__inline static unsigned char * get_ra(unsigned char *pframe)
+__inline static unsigned char *get_ra(unsigned char *pframe)
 {
-	unsigned char 	*ra;
+	unsigned char	*ra;
 	ra = GetAddr1Ptr(pframe);
 	return ra;
 }
-__inline static unsigned char * get_ta(unsigned char *pframe)
+__inline static unsigned char *get_ta(unsigned char *pframe)
 {
-	unsigned char 	*ta;
-	ta = GetAddr2Ptr(pframe);
+	unsigned char	*ta;
+	ta = get_addr2_ptr(pframe);
 	return ta;
 }
 
-__inline static unsigned char * get_da(unsigned char *pframe)
+/* can't apply to mesh mode */
+__inline static unsigned char *get_da(unsigned char *pframe)
 {
-	unsigned char 	*da;
+	unsigned char	*da;
 	unsigned int	to_fr_ds	= (GetToDs(pframe) << 1) | GetFrDs(pframe);
 
 	switch (to_fr_ds) {
-		case 0x00:	// ToDs=0, FromDs=0
-			da = GetAddr1Ptr(pframe);
-			break;
-		case 0x01:	// ToDs=0, FromDs=1
-			da = GetAddr1Ptr(pframe);
-			break;
-		case 0x02:	// ToDs=1, FromDs=0
-			da = GetAddr3Ptr(pframe);
-			break;
-		default:	// ToDs=1, FromDs=1
-			da = GetAddr3Ptr(pframe);
-			break;
+	case 0x00:	/* ToDs=0, FromDs=0 */
+		da = GetAddr1Ptr(pframe);
+		break;
+	case 0x01:	/* ToDs=0, FromDs=1 */
+		da = GetAddr1Ptr(pframe);
+		break;
+	case 0x02:	/* ToDs=1, FromDs=0 */
+		da = GetAddr3Ptr(pframe);
+		break;
+	default:	/* ToDs=1, FromDs=1 */
+		da = GetAddr3Ptr(pframe);
+		break;
 	}
 
 	return da;
 }
 
-
-__inline static unsigned char * get_sa(unsigned char *pframe)
+/* can't apply to mesh mode */
+__inline static unsigned char *get_sa(unsigned char *pframe)
 {
-	unsigned char 	*sa;
+	unsigned char	*sa;
 	unsigned int	to_fr_ds	= (GetToDs(pframe) << 1) | GetFrDs(pframe);
 
 	switch (to_fr_ds) {
-		case 0x00:	// ToDs=0, FromDs=0
-			sa = GetAddr2Ptr(pframe);
-			break;
-		case 0x01:	// ToDs=0, FromDs=1
-			sa = GetAddr3Ptr(pframe);
-			break;
-		case 0x02:	// ToDs=1, FromDs=0
-			sa = GetAddr2Ptr(pframe);
-			break;
-		default:	// ToDs=1, FromDs=1
-			sa = GetAddr4Ptr(pframe);
-			break;
+	case 0x00:	/* ToDs=0, FromDs=0 */
+		sa = get_addr2_ptr(pframe);
+		break;
+	case 0x01:	/* ToDs=0, FromDs=1 */
+		sa = GetAddr3Ptr(pframe);
+		break;
+	case 0x02:	/* ToDs=1, FromDs=0 */
+		sa = get_addr2_ptr(pframe);
+		break;
+	default:	/* ToDs=1, FromDs=1 */
+		sa = GetAddr4Ptr(pframe);
+		break;
 	}
 
 	return sa;
 }
 
-__inline static unsigned char * get_hdr_bssid(unsigned char *pframe)
+/* can't apply to mesh mode */
+__inline static unsigned char *get_hdr_bssid(unsigned char *pframe)
 {
-	unsigned char 	*sa = NULL;
+	unsigned char	*sa = NULL;
 	unsigned int	to_fr_ds	= (GetToDs(pframe) << 1) | GetFrDs(pframe);
 
 	switch (to_fr_ds) {
-		case 0x00:	// ToDs=0, FromDs=0
-			sa = GetAddr3Ptr(pframe);
-			break;
-		case 0x01:	// ToDs=0, FromDs=1
-			sa = GetAddr2Ptr(pframe);
-			break;
-		case 0x02:	// ToDs=1, FromDs=0
-			sa = GetAddr1Ptr(pframe);
-			break;
-		case 0x03:	// ToDs=1, FromDs=1
-			sa = GetAddr1Ptr(pframe);
-			break;
+	case 0x00:	/* ToDs=0, FromDs=0 */
+		sa = GetAddr3Ptr(pframe);
+		break;
+	case 0x01:	/* ToDs=0, FromDs=1 */
+		sa = get_addr2_ptr(pframe);
+		break;
+	case 0x02:	/* ToDs=1, FromDs=0 */
+		sa = GetAddr1Ptr(pframe);
+		break;
+	case 0x03:	/* ToDs=1, FromDs=1 */
+		sa = GetAddr1Ptr(pframe);
+		break;
 	}
 
 	return sa;
@@ -531,11 +539,27 @@ __inline static unsigned char * get_hdr_bssid(unsigned char *pframe)
 
 __inline static int IsFrameTypeCtrl(unsigned char *pframe)
 {
-	if(WIFI_CTRL_TYPE == GetFrameType(pframe))
+	if (WIFI_CTRL_TYPE == GetFrameType(pframe))
 		return _TRUE;
 	else
 		return _FALSE;
 }
+static inline int IsFrameTypeMgnt(unsigned char *pframe)
+{
+	if (GetFrameType(pframe) == WIFI_MGT_TYPE)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+static inline int IsFrameTypeData(unsigned char *pframe)
+{
+	if (GetFrameType(pframe) == WIFI_DATA_TYPE)
+		return _TRUE;
+	else
+		return _FALSE;
+}
+
+
 /*-----------------------------------------------------------------------------
 			Below is for the security related definition
 ------------------------------------------------------------------------------*/
@@ -547,11 +571,11 @@ __inline static int IsFrameTypeCtrl(unsigned char *pframe)
 #define _PRE_ALLOCICVHDR_		5
 #define _PRE_ALLOCMICHDR_		6
 
-#define _SIFSTIME_				((priv->pmib->dot11BssType.net_work_type&WIRELESS_11A)?16:10)
-#define _ACKCTSLNG_				14	//14 bytes long, including crclng
+#define _SIFSTIME_				((priv->pmib->dot11BssType.net_work_type&WIRELESS_11A) ? 16 : 10)
+#define _ACKCTSLNG_				14	/* 14 bytes long, including crclng */
 #define _CRCLNG_				4
 
-#define _ASOCREQ_IE_OFFSET_		4	// excluding wlan_hdr
+#define _ASOCREQ_IE_OFFSET_		4	/* excluding wlan_hdr */
 #define	_ASOCRSP_IE_OFFSET_		6
 #define _REASOCREQ_IE_OFFSET_	10
 #define _REASOCRSP_IE_OFFSET_	6
@@ -572,27 +596,31 @@ __inline static int IsFrameTypeCtrl(unsigned char *pframe)
 #define _COUNTRY_IE_			7
 #define _CHLGETXT_IE_			16
 #define _SUPPORTED_CH_IE_		36
-#define _CH_SWTICH_ANNOUNCE_	37	//Secondary Channel Offset
+#define _CH_SWTICH_ANNOUNCE_	37	/* Secondary Channel Offset */
+#define	_MEAS_REQ_IE_		38
+#define	_MEAS_RSP_IE_		39
 #define _RSN_IE_2_				48
 #define _SSN_IE_1_					221
 #define _ERPINFO_IE_			42
 #define _EXT_SUPPORTEDRATES_IE_	50
 
 #define _HT_CAPABILITY_IE_			45
-#define _FTIE_						55
+#define _MDIE_					54
+#define _FTIE_					55
 #define _TIMEOUT_ITVL_IE_			56
 #define _SRC_IE_				59
 #define _HT_EXTRA_INFO_IE_			61
-#define _HT_ADD_INFO_IE_			61 //_HT_EXTRA_INFO_IE_
-#define _WAPI_IE_					68
+#define _HT_ADD_INFO_IE_			61 /* _HT_EXTRA_INFO_IE_ */
+#define _WAPI_IE_				68
+#define _EID_RRM_EN_CAP_IE_			70
 
 
-//#define EID_BSSCoexistence			72 // 20/40 BSS Coexistence
-//#define EID_BSSIntolerantChlReport	73
+/* #define EID_BSSCoexistence			72 */ /* 20/40 BSS Coexistence
+ * #define EID_BSSIntolerantChlReport	73 */
 #define _RIC_Descriptor_IE_			75
 #ifdef CONFIG_IEEE80211W
-#define _MME_IE_					76 //802.11w Management MIC element
-#endif //CONFIG_IEEE80211W
+#define _MME_IE_					76 /* 802.11w Management MIC element */
+#endif /* CONFIG_IEEE80211W */
 #define _LINK_ID_IE_					101
 #define _CH_SWITCH_TIMING_		104
 #define _PTI_BUFFER_STATUS_		106
@@ -601,7 +629,7 @@ __inline static int IsFrameTypeCtrl(unsigned char *pframe)
 
 #define	_RESERVED47_				47
 
-typedef	enum _ELEMENT_ID{
+typedef	enum _ELEMENT_ID {
 	EID_SsId					= 0, /* service set identifier (0:32) */
 	EID_SupRates				= 1, /* supported rates (1:8) */
 	EID_FHParms				= 2, /* FH parameter set (5) */
@@ -611,72 +639,72 @@ typedef	enum _ELEMENT_ID{
 	EID_IbssParms				= 6, /* IBSS parameter set (2) */
 	EID_Country					= 7, /* */
 
-	// Form 7.3.2: Information elements in 802.11E/D13.0, page 46.
+	/* Form 7.3.2: Information elements in 802.11E/D13.0, page 46. */
 	EID_QBSSLoad				= 11,
 	EID_EDCAParms				= 12,
 	EID_TSpec					= 13,
 	EID_TClass					= 14,
 	EID_Schedule				= 15,
-	//
-	
+	/*  */
+
 	EID_Ctext					= 16, /* challenge text*/
 	EID_POWER_CONSTRAINT		= 32, /* Power Constraint*/
 
-	//vivi for WIFITest, 802.11h AP, 20100427
-	// 2010/12/26 MH The definition we can declare always!!
+	/* vivi for WIFITest, 802.11h AP, 20100427 */
+	/* 2010/12/26 MH The definition we can declare always!! */
 	EID_PowerCap				= 33,
 	EID_SupportedChannels		= 36,
 	EID_ChlSwitchAnnounce		= 37,
 
-	EID_MeasureRequest			= 38, // Measurement Request
-	EID_MeasureReport			= 39, // Measurement Report
-	
-	EID_ERPInfo 				= 42,
+	EID_MeasureRequest			= 38, /* Measurement Request */
+	EID_MeasureReport			= 39, /* Measurement Report */
+
+	EID_ERPInfo				= 42,
 
-	// Form 7.3.2: Information elements in 802.11E/D13.0, page 46.
+	/* Form 7.3.2: Information elements in 802.11E/D13.0, page 46. */
 	EID_TSDelay				= 43,
 	EID_TCLASProc				= 44,
 	EID_HTCapability			= 45,
 	EID_QoSCap					= 46,
-	//
-	
+	/*  */
+
 	EID_WPA2					= 48,
 	EID_ExtSupRates			= 50,
 
-	EID_FTIE					= 55, // Defined in 802.11r
-	EID_Timeout				= 56, // Defined in 802.11r
-	
-	EID_SupRegulatory			= 59, // Supported Requlatory Classes 802.11y
-	EID_HTInfo 					= 61,
+	EID_FTIE					= 55, /* Defined in 802.11r */
+	EID_Timeout				= 56, /* Defined in 802.11r */
+
+	EID_SupRegulatory			= 59, /* Supported Requlatory Classes 802.11y */
+	EID_HTInfo					= 61,
 	EID_SecondaryChnlOffset		= 62,
-	
-	EID_BSSCoexistence			= 72, // 20/40 BSS Coexistence
+
+	EID_BSSCoexistence			= 72, /* 20/40 BSS Coexistence */
 	EID_BSSIntolerantChlReport	= 73,
-	EID_OBSS					= 74, // Overlapping BSS Scan Parameters
-	
-	EID_LinkIdentifier			= 101, // Defined in 802.11z
-	EID_WakeupSchedule		= 102, // Defined in 802.11z
-	EID_ChnlSwitchTimeing		= 104, // Defined in 802.11z
-	EID_PTIControl				= 105, // Defined in 802.11z
-	EID_PUBufferStatus			= 106, // Defined in 802.11z
-	
-	EID_EXTCapability			= 127, // Extended Capabilities
-	// From S19:Aironet IE and S21:AP IP address IE in CCX v1.13, p16 and p18.
-	EID_Aironet					= 133, // 0x85: Aironet Element for Cisco CCX
-	EID_CiscoIP					= 149, // 0x95: IP Address IE for Cisco CCX
+	EID_OBSS					= 74, /* Overlapping BSS Scan Parameters */
+
+	EID_LinkIdentifier			= 101, /* Defined in 802.11z */
+	EID_WakeupSchedule		= 102, /* Defined in 802.11z */
+	EID_ChnlSwitchTimeing		= 104, /* Defined in 802.11z */
+	EID_PTIControl				= 105, /* Defined in 802.11z */
+	EID_PUBufferStatus			= 106, /* Defined in 802.11z */
 
-	EID_CellPwr					= 150, // 0x96: Cell Power Limit IE. Ref. 0x96.
+	EID_EXTCapability			= 127, /* Extended Capabilities */
+	/* From S19:Aironet IE and S21:AP IP address IE in CCX v1.13, p16 and p18. */
+	EID_Aironet					= 133, /* 0x85: Aironet Element for Cisco CCX */
+	EID_CiscoIP					= 149, /* 0x95: IP Address IE for Cisco CCX */
 
-	EID_CCKM    					= 156, 
+	EID_CellPwr					= 150, /* 0x96: Cell Power Limit IE. Ref. 0x96. */
 
-	EID_Vendor					= 221, // 0xDD: Vendor Specific
+	EID_CCKM					= 156,
+
+	EID_Vendor					= 221, /* 0xDD: Vendor Specific */
 
 	EID_WAPI					= 68,
-	EID_VHTCapability 			= 191, // Based on 802.11ac D2.0
-	EID_VHTOperation 			= 192, // Based on 802.11ac D2.0
+	EID_VHTCapability 			= 191, /* Based on 802.11ac D2.0 */
+	EID_VHTOperation 			= 192, /* Based on 802.11ac D2.0 */
 	EID_AID						= 197, /* Based on 802.11ac D4.0 */
-	EID_OpModeNotification		= 199, // Based on 802.11ac D3.0
-}ELEMENT_ID, *PELEMENT_ID;
+	EID_OpModeNotification		= 199, /* Based on 802.11ac D3.0 */
+} ELEMENT_ID, *PELEMENT_ID;
 
 /* ---------------------------------------------------------------------------
 					Below is the fixed elements...
@@ -714,39 +742,40 @@ typedef	enum _ELEMENT_ID{
 /*-----------------------------------------------------------------------------
 				Below is the definition for 802.11i / 802.1x
 ------------------------------------------------------------------------------*/
-#define _IEEE8021X_MGT_			1		// WPA
-#define _IEEE8021X_PSK_			2		// WPA with pre-shared key
+#define _IEEE8021X_MGT_			1		/* WPA */
+#define _IEEE8021X_PSK_			2		/* WPA with pre-shared key */
 
-/*
+#if 0
 #define _NO_PRIVACY_			0
 #define _WEP_40_PRIVACY_		1
 #define _TKIP_PRIVACY_			2
 #define _WRAP_PRIVACY_			3
 #define _CCMP_PRIVACY_			4
 #define _WEP_104_PRIVACY_		5
-#define _WEP_WPA_MIXED_PRIVACY_ 6	// WEP + WPA
-*/
+#define _WEP_WPA_MIXED_PRIVACY_ 6	/*  WEP + WPA */
+#endif
 
-#ifdef CONFIG_IEEE80211W
 #define _MME_IE_LENGTH_  18
-#endif //CONFIG_IEEE80211W				
+
 /*-----------------------------------------------------------------------------
 				Below is the definition for WMM
 ------------------------------------------------------------------------------*/
-#define _WMM_IE_Length_				7  // for WMM STA
+#define _WMM_IE_Length_				7  /* for WMM STA */
 #define _WMM_Para_Element_Length_		24
 
 
 /*-----------------------------------------------------------------------------
-				Below is the definition for 802.11n 
+				Below is the definition for 802.11n
 ------------------------------------------------------------------------------*/
 
-//#ifdef CONFIG_80211N_HT
+/* #ifdef CONFIG_80211N_HT */
+
+#define set_order_bit(pbuf)	\
+		do	{	\
+			*(unsigned short *)(pbuf) |= cpu_to_le16(_ORDER_); \
+		} while (0)
+
 
-#define SetOrderBit(pbuf)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16(_ORDER_); \
-	} while(0)
 
 #define GetOrderBit(pbuf)	(((*(unsigned short *)(pbuf)) & le16_to_cpu(_ORDER_)) != 0)
 
@@ -758,7 +787,7 @@ typedef	enum _ELEMENT_ID{
  * This structure refers to "HT BlockAckReq" as
  * described in 802.11n draft section 7.2.1.7.1
  */
- #if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8712FW)
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8712FW)
 struct rtw_ieee80211_bar {
 	unsigned short frame_control;
 	unsigned short duration;
@@ -767,32 +796,32 @@ struct rtw_ieee80211_bar {
 	unsigned short control;
 	unsigned short start_seq_num;
 } __attribute__((packed));
- #endif
+#endif
 
 /* 802.11 BAR control masks */
 #define IEEE80211_BAR_CTRL_ACK_POLICY_NORMAL     0x0000
 #define IEEE80211_BAR_CTRL_CBMTID_COMPRESSED_BA  0x0004
 
 
- #if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8712FW) || defined(PLATFORM_FREEBSD)
+#if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8712FW) || defined(PLATFORM_FREEBSD)
 
 
 
- /**
- * struct rtw_ieee80211_ht_cap - HT capabilities
- *
- * This structure refers to "HT capabilities element" as
- * described in 802.11n draft section 7.3.2.52
- */
- 
+/**
+* struct rtw_ieee80211_ht_cap - HT capabilities
+*
+* This structure refers to "HT capabilities element" as
+* described in 802.11n draft section 7.3.2.52
+*/
+
 struct rtw_ieee80211_ht_cap {
-	unsigned short 	cap_info;
-	unsigned char 	ampdu_params_info;
-	unsigned char 	supp_mcs_set[16];
-	unsigned short 	extended_ht_cap_info;
+	unsigned short	cap_info;
+	unsigned char	ampdu_params_info;
+	unsigned char	supp_mcs_set[16];
+	unsigned short	extended_ht_cap_info;
 	unsigned int		tx_BF_cap_info;
 	unsigned char	       antenna_selection_info;
-} __attribute__ ((packed));
+} __attribute__((packed));
 
 /**
  * struct rtw_ieee80211_ht_cap - HT additional information
@@ -800,21 +829,19 @@ struct rtw_ieee80211_ht_cap {
  * This structure refers to "HT information element" as
  * described in 802.11n draft section 7.3.2.53
  */
+#ifndef CONFIG_IEEE80211_HT_ADDT_INFO
 struct ieee80211_ht_addt_info {
-	unsigned char 	control_chan;
+	unsigned char	control_chan;
 	unsigned char		ht_param;
 	unsigned short	operation_mode;
 	unsigned short	stbc_param;
 	unsigned char		basic_set[16];
-} __attribute__ ((packed));
-
+} __attribute__((packed));
+#endif
 
-struct HT_caps_element
-{
-	union
-	{ 
-		struct 
-		{ 	
+struct HT_caps_element {
+	union {
+		struct {
 			unsigned short	HT_caps_info;
 			unsigned char	AMPDU_para;
 			unsigned char	MCS_rate[16];
@@ -823,37 +850,33 @@ struct HT_caps_element
 			unsigned char	ASEL_caps;
 		} HT_cap_element;
 		unsigned char HT_cap[26];
-	}u;
-} __attribute__ ((packed));
+	} u;
+} __attribute__((packed));
 
-struct HT_info_element
-{
+struct HT_info_element {
 	unsigned char	primary_channel;
 	unsigned char	infos[5];
 	unsigned char	MCS_rate[16];
-}  __attribute__ ((packed));
+}  __attribute__((packed));
 
-struct AC_param
-{
+struct AC_param {
 	unsigned char		ACI_AIFSN;
 	unsigned char		CW;
 	unsigned short	TXOP_limit;
-}  __attribute__ ((packed));
+}  __attribute__((packed));
 
-struct WMM_para_element
-{
+struct WMM_para_element {
 	unsigned char		QoS_info;
 	unsigned char		reserved;
 	struct AC_param	ac_param[4];
-}  __attribute__ ((packed));
+}  __attribute__((packed));
 
-struct ADDBA_request
-{
+struct ADDBA_request {
 	unsigned char		dialog_token;
 	unsigned short	BA_para_set;
 	unsigned short	BA_timeout_value;
 	unsigned short	BA_starting_seqctrl;
-}  __attribute__ ((packed));
+}  __attribute__((packed));
 
 
 
@@ -865,29 +888,26 @@ struct ADDBA_request
 #pragma pack(1)
 
 struct rtw_ieee80211_ht_cap {
-	unsigned short 	cap_info;
-	unsigned char 	ampdu_params_info;
-	unsigned char 	supp_mcs_set[16];
-	unsigned short 	extended_ht_cap_info;
+	unsigned short	cap_info;
+	unsigned char	ampdu_params_info;
+	unsigned char	supp_mcs_set[16];
+	unsigned short	extended_ht_cap_info;
 	unsigned int		tx_BF_cap_info;
 	unsigned char	       antenna_selection_info;
 };
 
 
 struct ieee80211_ht_addt_info {
-	unsigned char 	control_chan;
+	unsigned char	control_chan;
 	unsigned char		ht_param;
 	unsigned short	operation_mode;
 	unsigned short	stbc_param;
 	unsigned char		basic_set[16];
 };
 
-struct HT_caps_element
-{
-	union
-	{ 
-		struct 
-		{ 	
+struct HT_caps_element {
+	union {
+		struct {
 			unsigned short	HT_caps_info;
 			unsigned char	AMPDU_para;
 			unsigned char	MCS_rate[16];
@@ -899,29 +919,25 @@ struct HT_caps_element
 	};
 };
 
-struct HT_info_element
-{
+struct HT_info_element {
 	unsigned char	primary_channel;
 	unsigned char	infos[5];
 	unsigned char	MCS_rate[16];
 };
 
-struct AC_param
-{
+struct AC_param {
 	unsigned char		ACI_AIFSN;
 	unsigned char		CW;
 	unsigned short	TXOP_limit;
 };
 
-struct WMM_para_element
-{
+struct WMM_para_element {
 	unsigned char		QoS_info;
 	unsigned char		reserved;
 	struct AC_param	ac_param[4];
 };
 
-struct ADDBA_request
-{
+struct ADDBA_request {
 	unsigned char		dialog_token;
 	unsigned short	BA_para_set;
 	unsigned short	BA_timeout_value;
@@ -937,8 +953,15 @@ typedef enum _HT_CAP_AMPDU_FACTOR {
 	MAX_AMPDU_FACTOR_8K		= 0,
 	MAX_AMPDU_FACTOR_16K	= 1,
 	MAX_AMPDU_FACTOR_32K	= 2,
-	MAX_AMPDU_FACTOR_64K	= 3,	
-}HT_CAP_AMPDU_FACTOR;
+	MAX_AMPDU_FACTOR_64K	= 3,
+} HT_CAP_AMPDU_FACTOR;
+
+typedef enum _VHT_CAP_AMPDU_FACTOR {
+	MAX_AMPDU_FACTOR_128K = 4,
+	MAX_AMPDU_FACTOR_256K = 5,
+	MAX_AMPDU_FACTOR_512K = 6,
+	MAX_AMPDU_FACTOR_1M = 7,
+} VHT_CAP_AMPDU_FACTOR;
 
 
 typedef enum _HT_CAP_AMPDU_DENSITY {
@@ -986,9 +1009,9 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 
 /* 802.11n HT IE masks */
 #define IEEE80211_HT_IE_CHA_SEC_OFFSET		0x03
-#define IEEE80211_HT_IE_CHA_SEC_NONE	 	0x00
-#define IEEE80211_HT_IE_CHA_SEC_ABOVE 		0x01
-#define IEEE80211_HT_IE_CHA_SEC_BELOW 		0x03
+#define IEEE80211_HT_IE_CHA_SEC_NONE		0x00
+#define IEEE80211_HT_IE_CHA_SEC_ABOVE		0x01
+#define IEEE80211_HT_IE_CHA_SEC_BELOW		0x03
 #define IEEE80211_HT_IE_CHA_WIDTH		0x04
 #define IEEE80211_HT_IE_HT_PROTECTION		0x0003
 #define IEEE80211_HT_IE_NON_GF_STA_PRSNT	0x0004
@@ -1030,7 +1053,7 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define HT_INFO_HT_PARAM_SRV_INTERVAL_GRANULARITY	((u8) BIT(5))
 
 #define HT_INFO_OPERATION_MODE_OP_MODE_MASK	\
-		((u16) (0x0001 | 0x0002))
+	((u16) (0x0001 | 0x0002))
 #define HT_INFO_OPERATION_MODE_OP_MODE_OFFSET		0
 #define HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT	((u8) BIT(2))
 #define HT_INFO_OPERATION_MODE_TRANSMIT_BURST_LIMIT	((u8) BIT(3))
@@ -1045,12 +1068,12 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 
 
 
-//#endif
+/* #endif */
 
-//	===============WPS Section===============
-//	For WPSv1.0
+/*	===============WPS Section=============== */
+/*	For WPSv1.0 */
 #define WPSOUI							0x0050f204
-//	WPS attribute ID
+/*	WPS attribute ID */
 #define WPS_ATTR_VER1					0x104A
 #define WPS_ATTR_SIMPLE_CONF_STATE	0x1044
 #define WPS_ATTR_RESP_TYPE			0x103B
@@ -1071,29 +1094,29 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define WPS_ATTR_VENDOR_EXT			0x1049
 #define WPS_ATTR_SELECTED_REGISTRAR	0x1041
 
-//	Value of WPS attribute "WPS_ATTR_DEVICE_NAME
+/*	Value of WPS attribute "WPS_ATTR_DEVICE_NAME */
 #define WPS_MAX_DEVICE_NAME_LEN		32
 
-//	Value of WPS Request Type Attribute
+/*	Value of WPS Request Type Attribute */
 #define WPS_REQ_TYPE_ENROLLEE_INFO_ONLY			0x00
 #define WPS_REQ_TYPE_ENROLLEE_OPEN_8021X		0x01
 #define WPS_REQ_TYPE_REGISTRAR					0x02
 #define WPS_REQ_TYPE_WLAN_MANAGER_REGISTRAR	0x03
 
-//	Value of WPS Response Type Attribute
+/*	Value of WPS Response Type Attribute */
 #define WPS_RESPONSE_TYPE_INFO_ONLY	0x00
 #define WPS_RESPONSE_TYPE_8021X		0x01
 #define WPS_RESPONSE_TYPE_REGISTRAR	0x02
 #define WPS_RESPONSE_TYPE_AP			0x03
 
-//	Value of WPS WiFi Simple Configuration State Attribute
+/*	Value of WPS WiFi Simple Configuration State Attribute */
 #define WPS_WSC_STATE_NOT_CONFIG	0x01
 #define WPS_WSC_STATE_CONFIG			0x02
 
-//	Value of WPS Version Attribute
+/*	Value of WPS Version Attribute */
 #define WPS_VERSION_1					0x10
 
-//	Value of WPS Configuration Method Attribute
+/*	Value of WPS Configuration Method Attribute */
 #define WPS_CONFIG_METHOD_FLASH		0x0001
 #define WPS_CONFIG_METHOD_ETHERNET	0x0002
 #define WPS_CONFIG_METHOD_LABEL		0x0004
@@ -1108,16 +1131,16 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define WPS_CONFIG_METHOD_VDISPLAY	0x2008
 #define WPS_CONFIG_METHOD_PDISPLAY	0x4008
 
-//	Value of Category ID of WPS Primary Device Type Attribute
+/*	Value of Category ID of WPS Primary Device Type Attribute */
 #define WPS_PDT_CID_DISPLAYS			0x0007
 #define WPS_PDT_CID_MULIT_MEDIA		0x0008
 #define WPS_PDT_CID_RTK_WIDI			WPS_PDT_CID_MULIT_MEDIA
 
-//	Value of Sub Category ID of WPS Primary Device Type Attribute
+/*	Value of Sub Category ID of WPS Primary Device Type Attribute */
 #define WPS_PDT_SCID_MEDIA_SERVER	0x0005
 #define WPS_PDT_SCID_RTK_DMP			WPS_PDT_SCID_MEDIA_SERVER
 
-//	Value of Device Password ID
+/*	Value of Device Password ID */
 #define WPS_DPID_PIN					0x0000
 #define WPS_DPID_USER_SPEC			0x0001
 #define WPS_DPID_MACHINE_SPEC			0x0002
@@ -1125,22 +1148,22 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define WPS_DPID_PBC					0x0004
 #define WPS_DPID_REGISTRAR_SPEC		0x0005
 
-//	Value of WPS RF Bands Attribute
+/*	Value of WPS RF Bands Attribute */
 #define WPS_RF_BANDS_2_4_GHZ		0x01
 #define WPS_RF_BANDS_5_GHZ		0x02
 
-//	Value of WPS Association State Attribute
+/*	Value of WPS Association State Attribute */
 #define WPS_ASSOC_STATE_NOT_ASSOCIATED			0x00
 #define WPS_ASSOC_STATE_CONNECTION_SUCCESS		0x01
 #define WPS_ASSOC_STATE_CONFIGURATION_FAILURE	0x02
 #define WPS_ASSOC_STATE_ASSOCIATION_FAILURE		0x03
 #define WPS_ASSOC_STATE_IP_FAILURE				0x04
 
-//	=====================P2P Section=====================
-//	For P2P
+/*	=====================P2P Section===================== */
+/*	For P2P */
 #define	P2POUI							0x506F9A09
 
-//	P2P Attribute ID
+/*	P2P Attribute ID */
 #define	P2P_ATTR_STATUS					0x00
 #define	P2P_ATTR_MINOR_REASON_CODE		0x01
 #define	P2P_ATTR_CAPABILITY				0x02
@@ -1150,7 +1173,7 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define	P2P_ATTR_LISTEN_CH				0x06
 #define	P2P_ATTR_GROUP_BSSID				0x07
 #define	P2P_ATTR_EX_LISTEN_TIMING		0x08
-#define	P2P_ATTR_INTENTED_IF_ADDR		0x09
+#define	P2P_ATTR_INTENDED_IF_ADDR		0x09
 #define	P2P_ATTR_MANAGEABILITY			0x0A
 #define	P2P_ATTR_CH_LIST					0x0B
 #define	P2P_ATTR_NOA						0x0C
@@ -1161,7 +1184,7 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define	P2P_ATTR_OPERATING_CH			0x11
 #define	P2P_ATTR_INVITATION_FLAGS		0x12
 
-//	Value of Status Attribute
+/*	Value of Status Attribute */
 #define	P2P_STATUS_SUCCESS						0x00
 #define	P2P_STATUS_FAIL_INFO_UNAVAILABLE		0x01
 #define	P2P_STATUS_FAIL_INCOMPATIBLE_PARAM		0x02
@@ -1175,17 +1198,17 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define	P2P_STATUS_FAIL_INCOMPATIBLE_PROVSION	0x0A
 #define	P2P_STATUS_FAIL_USER_REJECT				0x0B
 
-//	Value of Inviation Flags Attribute
+/*	Value of Inviation Flags Attribute */
 #define	P2P_INVITATION_FLAGS_PERSISTENT			BIT(0)
 
 #define	DMP_P2P_DEVCAP_SUPPORT	(P2P_DEVCAP_SERVICE_DISCOVERY | \
-									P2P_DEVCAP_CLIENT_DISCOVERABILITY | \
-									P2P_DEVCAP_CONCURRENT_OPERATION | \
-									P2P_DEVCAP_INVITATION_PROC)
+				 P2P_DEVCAP_CLIENT_DISCOVERABILITY | \
+				 P2P_DEVCAP_CONCURRENT_OPERATION | \
+				 P2P_DEVCAP_INVITATION_PROC)
 
 #define	DMP_P2P_GRPCAP_SUPPORT	(P2P_GRPCAP_INTRABSS)
 
-//	Value of Device Capability Bitmap
+/*	Value of Device Capability Bitmap */
 #define	P2P_DEVCAP_SERVICE_DISCOVERY		BIT(0)
 #define	P2P_DEVCAP_CLIENT_DISCOVERABILITY	BIT(1)
 #define	P2P_DEVCAP_CONCURRENT_OPERATION	BIT(2)
@@ -1193,7 +1216,7 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define	P2P_DEVCAP_DEVICE_LIMIT				BIT(4)
 #define	P2P_DEVCAP_INVITATION_PROC			BIT(5)
 
-//	Value of Group Capability Bitmap
+/*	Value of Group Capability Bitmap */
 #define	P2P_GRPCAP_GO							BIT(0)
 #define	P2P_GRPCAP_PERSISTENT_GROUP			BIT(1)
 #define	P2P_GRPCAP_GROUP_LIMIT				BIT(2)
@@ -1202,10 +1225,10 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define	P2P_GRPCAP_PERSISTENT_RECONN		BIT(5)
 #define	P2P_GRPCAP_GROUP_FORMATION			BIT(6)
 
-//	P2P Public Action Frame ( Management Frame )
+/*	P2P Public Action Frame ( Management Frame ) */
 #define	P2P_PUB_ACTION_ACTION				0x09
 
-//	P2P Public Action Frame Type
+/*	P2P Public Action Frame Type */
 #define	P2P_GO_NEGO_REQ						0
 #define	P2P_GO_NEGO_RESP						1
 #define	P2P_GO_NEGO_CONF						2
@@ -1216,7 +1239,7 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 #define	P2P_PROVISION_DISC_REQ				7
 #define	P2P_PROVISION_DISC_RESP				8
 
-//	P2P Action Frame Type
+/*	P2P Action Frame Type */
 #define	P2P_NOTICE_OF_ABSENCE	0
 #define	P2P_PRESENCE_REQUEST		1
 #define	P2P_PRESENCE_RESPONSE	2
@@ -1229,25 +1252,25 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
 
 #define	P2P_WILDCARD_SSID_LEN				7
 
-#define	P2P_FINDPHASE_EX_NONE				0	// default value, used when: (1)p2p disabed or (2)p2p enabled but only do 1 scan phase
-#define	P2P_FINDPHASE_EX_FULL				1	// used when p2p enabled and want to do 1 scan phase and P2P_FINDPHASE_EX_MAX-1 find phase
-#define	P2P_FINDPHASE_EX_SOCIAL_FIRST		(P2P_FINDPHASE_EX_FULL+1) 
+#define	P2P_FINDPHASE_EX_NONE				0	/* default value, used when: (1)p2p disabed or (2)p2p enabled but only do 1 scan phase */
+#define	P2P_FINDPHASE_EX_FULL				1	/* used when p2p enabled and want to do 1 scan phase and P2P_FINDPHASE_EX_MAX-1 find phase */
+#define	P2P_FINDPHASE_EX_SOCIAL_FIRST		(P2P_FINDPHASE_EX_FULL+1)
 #define	P2P_FINDPHASE_EX_MAX					4
 #define	P2P_FINDPHASE_EX_SOCIAL_LAST		P2P_FINDPHASE_EX_MAX
 
-#define	P2P_PROVISION_TIMEOUT				5000	//	5 seconds timeout for sending the provision discovery request
-#define	P2P_CONCURRENT_PROVISION_TIMEOUT	3000	//	3 seconds timeout for sending the provision discovery request under concurrent mode
-#define	P2P_GO_NEGO_TIMEOUT					5000	//	5 seconds timeout for receiving the group negotation response
-#define	P2P_CONCURRENT_GO_NEGO_TIMEOUT		3000	//	3 seconds timeout for sending the negotiation request under concurrent mode
-#define	P2P_TX_PRESCAN_TIMEOUT				100		//	100ms
-#define	P2P_INVITE_TIMEOUT					5000	//	5 seconds timeout for sending the invitation request
-#define	P2P_CONCURRENT_INVITE_TIMEOUT		3000	//	3 seconds timeout for sending the invitation request under concurrent mode
-#define	P2P_RESET_SCAN_CH						25000	//	25 seconds timeout to reset the scan channel ( based on channel plan )
+#define	P2P_PROVISION_TIMEOUT				5000	/*	5 seconds timeout for sending the provision discovery request */
+#define	P2P_CONCURRENT_PROVISION_TIMEOUT	3000	/*	3 seconds timeout for sending the provision discovery request under concurrent mode */
+#define	P2P_GO_NEGO_TIMEOUT					5000	/*	5 seconds timeout for receiving the group negotation response */
+#define	P2P_CONCURRENT_GO_NEGO_TIMEOUT		3000	/*	3 seconds timeout for sending the negotiation request under concurrent mode */
+#define	P2P_TX_PRESCAN_TIMEOUT				100		/*	100ms */
+#define	P2P_INVITE_TIMEOUT					5000	/*	5 seconds timeout for sending the invitation request */
+#define	P2P_CONCURRENT_INVITE_TIMEOUT		3000	/*	3 seconds timeout for sending the invitation request under concurrent mode */
+#define	P2P_RESET_SCAN_CH						25000	/*	25 seconds timeout to reset the scan channel (based on channel plan) */
 #define	P2P_MAX_INTENT						15
 
 #define	P2P_MAX_NOA_NUM						2
 
-//	WPS Configuration Method
+/*	WPS Configuration Method */
 #define	WPS_CM_NONE							0x0000
 #define	WPS_CM_LABEL							0x0004
 #define	WPS_CM_DISPLYA						0x0008
@@ -1265,33 +1288,33 @@ enum P2P_ROLE {
 	P2P_ROLE_DISABLE = 0,
 	P2P_ROLE_DEVICE = 1,
 	P2P_ROLE_CLIENT = 2,
-	P2P_ROLE_GO = 3	
+	P2P_ROLE_GO = 3
 };
 
 enum P2P_STATE {
-	P2P_STATE_NONE = 0,							//	P2P disable
-	P2P_STATE_IDLE = 1,								//	P2P had enabled and do nothing
-	P2P_STATE_LISTEN = 2,							//	In pure listen state
-	P2P_STATE_SCAN = 3,							//	In scan phase
-	P2P_STATE_FIND_PHASE_LISTEN = 4,				//	In the listen state of find phase
-	P2P_STATE_FIND_PHASE_SEARCH = 5,				//	In the search state of find phase
-	P2P_STATE_TX_PROVISION_DIS_REQ = 6,			//	In P2P provisioning discovery
+	P2P_STATE_NONE = 0,							/*	P2P disable */
+	P2P_STATE_IDLE = 1,								/*	P2P had enabled and do nothing ,  buddy adapters is linked */
+	P2P_STATE_LISTEN = 2,							/*	In pure listen state */
+	P2P_STATE_SCAN = 3,							/*	In scan phase */
+	P2P_STATE_FIND_PHASE_LISTEN = 4,				/*	In the listen state of find phase */
+	P2P_STATE_FIND_PHASE_SEARCH = 5,				/*	In the search state of find phase */
+	P2P_STATE_TX_PROVISION_DIS_REQ = 6,			/*	In P2P provisioning discovery */
 	P2P_STATE_RX_PROVISION_DIS_RSP = 7,
-	P2P_STATE_RX_PROVISION_DIS_REQ = 8,	
-	P2P_STATE_GONEGO_ING = 9,						//	Doing the group owner negoitation handshake
-	P2P_STATE_GONEGO_OK = 10,						//	finish the group negoitation handshake with success
-	P2P_STATE_GONEGO_FAIL = 11,					//	finish the group negoitation handshake with failure
-	P2P_STATE_RECV_INVITE_REQ_MATCH = 12,		//	receiving the P2P Inviation request and match with the profile.
-	P2P_STATE_PROVISIONING_ING = 13,				//	Doing the P2P WPS
-	P2P_STATE_PROVISIONING_DONE = 14,			//	Finish the P2P WPS
-	P2P_STATE_TX_INVITE_REQ = 15,					//	Transmit the P2P Invitation request
-	P2P_STATE_RX_INVITE_RESP_OK = 16,				//	Receiving the P2P Invitation response
-	P2P_STATE_RECV_INVITE_REQ_DISMATCH = 17,	//	receiving the P2P Inviation request and dismatch with the profile.
-	P2P_STATE_RECV_INVITE_REQ_GO = 18,			//	receiving the P2P Inviation request and this wifi is GO.
-	P2P_STATE_RECV_INVITE_REQ_JOIN = 19,			//	receiving the P2P Inviation request to join an existing P2P Group.
-	P2P_STATE_RX_INVITE_RESP_FAIL = 20,			//	recveing the P2P Inviation response with failure
-	P2P_STATE_RX_INFOR_NOREADY = 21, 			// receiving p2p negoitation response with information is not available
-	P2P_STATE_TX_INFOR_NOREADY = 22, 			// sending p2p negoitation response with information is not available
+	P2P_STATE_RX_PROVISION_DIS_REQ = 8,
+	P2P_STATE_GONEGO_ING = 9,						/*	Doing the group owner negoitation handshake */
+	P2P_STATE_GONEGO_OK = 10,						/*	finish the group negoitation handshake with success */
+	P2P_STATE_GONEGO_FAIL = 11,					/*	finish the group negoitation handshake with failure */
+	P2P_STATE_RECV_INVITE_REQ_MATCH = 12,		/*	receiving the P2P Inviation request and match with the profile. */
+	P2P_STATE_PROVISIONING_ING = 13,				/*	Doing the P2P WPS */
+	P2P_STATE_PROVISIONING_DONE = 14,			/*	Finish the P2P WPS */
+	P2P_STATE_TX_INVITE_REQ = 15,					/*	Transmit the P2P Invitation request */
+	P2P_STATE_RX_INVITE_RESP_OK = 16,				/*	Receiving the P2P Invitation response */
+	P2P_STATE_RECV_INVITE_REQ_DISMATCH = 17,	/*	receiving the P2P Inviation request and dismatch with the profile. */
+	P2P_STATE_RECV_INVITE_REQ_GO = 18,			/*	receiving the P2P Inviation request and this wifi is GO. */
+	P2P_STATE_RECV_INVITE_REQ_JOIN = 19,			/*	receiving the P2P Inviation request to join an existing P2P Group. */
+	P2P_STATE_RX_INVITE_RESP_FAIL = 20,			/*	recveing the P2P Inviation response with failure */
+	P2P_STATE_RX_INFOR_NOREADY = 21,			/* receiving p2p negoitation response with information is not available */
+	P2P_STATE_TX_INFOR_NOREADY = 22,			/* sending p2p negoitation response with information is not available */
 };
 
 enum P2P_WPSINFO {
@@ -1303,38 +1326,36 @@ enum P2P_WPSINFO {
 
 #define	P2P_PRIVATE_IOCTL_SET_LEN		64
 
-enum P2P_PROTO_WK_ID
-{
+enum P2P_PROTO_WK_ID {
 	P2P_FIND_PHASE_WK = 0,
 	P2P_RESTORE_STATE_WK = 1,
 	P2P_PRE_TX_PROVDISC_PROCESS_WK = 2,
-	P2P_PRE_TX_NEGOREQ_PROCESS_WK = 3,	
+	P2P_PRE_TX_NEGOREQ_PROCESS_WK = 3,
 	P2P_PRE_TX_INVITEREQ_PROCESS_WK = 4,
-	P2P_AP_P2P_CH_SWITCH_PROCESS_WK =5,
+	P2P_AP_P2P_CH_SWITCH_PROCESS_WK = 5,
 	P2P_RO_CH_WK = 6,
+	P2P_CANCEL_RO_CH_WK = 7,
 };
 
 #ifdef CONFIG_P2P_PS
-enum P2P_PS_STATE
-{
+enum P2P_PS_STATE {
 	P2P_PS_DISABLE = 0,
 	P2P_PS_ENABLE = 1,
 	P2P_PS_SCAN = 2,
 	P2P_PS_SCAN_DONE = 3,
-	P2P_PS_ALLSTASLEEP = 4, // for P2P GO
+	P2P_PS_ALLSTASLEEP = 4, /* for P2P GO */
 };
 
-enum P2P_PS_MODE
-{
+enum P2P_PS_MODE {
 	P2P_PS_NONE = 0,
 	P2P_PS_CTWINDOW = 1,
 	P2P_PS_NOA	 = 2,
-	P2P_PS_MIX = 3, // CTWindow and NoA
+	P2P_PS_MIX = 3, /* CTWindow and NoA */
 };
-#endif // CONFIG_P2P_PS
+#endif /* CONFIG_P2P_PS */
 
-//	=====================WFD Section=====================
-//	For Wi-Fi Display
+/*	=====================WFD Section=====================
+ *	For Wi-Fi Display */
 #define	WFD_ATTR_DEVICE_INFO			0x00
 #define	WFD_ATTR_ASSOC_BSSID			0x01
 #define	WFD_ATTR_COUPLED_SINK_INFO	0x06
@@ -1342,21 +1363,19 @@ enum P2P_PS_MODE
 #define	WFD_ATTR_SESSION_INFO		0x09
 #define	WFD_ATTR_ALTER_MAC			0x0a
 
-//	For WFD Device Information Attribute
+/*	For WFD Device Information Attribute */
 #define	WFD_DEVINFO_SOURCE					0x0000
 #define	WFD_DEVINFO_PSINK					0x0001
 #define	WFD_DEVINFO_SSINK					0x0002
-#define	WFD_DEVINFO_DUAL 					0x0003
+#define	WFD_DEVINFO_DUAL					0x0003
 
 #define	WFD_DEVINFO_SESSION_AVAIL			0x0010
 #define	WFD_DEVINFO_WSD						0x0040
 #define	WFD_DEVINFO_PC_TDLS					0x0080
 #define	WFD_DEVINFO_HDCP_SUPPORT			0x0100
 
-#ifdef  CONFIG_TX_MCAST2UNI
-#define IP_MCAST_MAC(mac)		((mac[0]==0x01)&&(mac[1]==0x00)&&(mac[2]==0x5e))
-#define ICMPV6_MCAST_MAC(mac)	((mac[0]==0x33)&&(mac[1]==0x33)&&(mac[2]!=0xff))
-#endif	// CONFIG_TX_MCAST2UNI
+#define IP_MCAST_MAC(mac)		((mac[0] == 0x01) && (mac[1] == 0x00) && (mac[2] == 0x5e))
+#define ICMPV6_MCAST_MAC(mac)	((mac[0] == 0x33) && (mac[1] == 0x33) && (mac[2] != 0xff))
 
 #ifdef CONFIG_IOCTL_CFG80211
 /* Regulatroy Domain */
@@ -1393,5 +1412,4 @@ struct rtw_regulatory {
 #endif
 #endif
 
-#endif // _WIFI_H_
-
+#endif /* _WIFI_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wlan_bssdef.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wlan_bssdef.h
index bd5237a7504e..63ec9df6f1da 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wlan_bssdef.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/wlan_bssdef.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __WLAN_BSSDEF_H__
 #define __WLAN_BSSDEF_H__
 
@@ -31,82 +27,76 @@
 #define NDIS_802_11_LENGTH_RATES_EX     16
 
 typedef unsigned char   NDIS_802_11_MAC_ADDRESS[6];
-typedef long    		NDIS_802_11_RSSI;           // in dBm
-typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        // Set of 8 data rates
-typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  // Set of 16 data rates
+typedef long    		NDIS_802_11_RSSI;           /* in dBm */
+typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        /* Set of 8 data rates */
+typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  /* Set of 16 data rates */
 
 
 typedef  ULONG  NDIS_802_11_KEY_INDEX;
 typedef unsigned long long NDIS_802_11_KEY_RSC;
 
 
-typedef struct _NDIS_802_11_SSID
-{
-  ULONG  SsidLength;
-  UCHAR  Ssid[32];
+typedef struct _NDIS_802_11_SSID {
+	ULONG  SsidLength;
+	UCHAR  Ssid[32];
 } NDIS_802_11_SSID, *PNDIS_802_11_SSID;
 
-typedef enum _NDIS_802_11_NETWORK_TYPE
-{
-    Ndis802_11FH,
-    Ndis802_11DS,
-    Ndis802_11OFDM5,
-    Ndis802_11OFDM24,
-    Ndis802_11NetworkTypeMax    // not a real type, defined as an upper bound
+typedef enum _NDIS_802_11_NETWORK_TYPE {
+	Ndis802_11FH,
+	Ndis802_11DS,
+	Ndis802_11OFDM5,
+	Ndis802_11OFDM24,
+	Ndis802_11NetworkTypeMax    /* not a real type, defined as an upper bound */
 } NDIS_802_11_NETWORK_TYPE, *PNDIS_802_11_NETWORK_TYPE;
 
-typedef struct _NDIS_802_11_CONFIGURATION_FH
-{
-    ULONG           Length;             // Length of structure
-    ULONG           HopPattern;         // As defined by 802.11, MSB set
-    ULONG           HopSet;             // to one if non-802.11
-    ULONG           DwellTime;          // units are Kusec
+typedef struct _NDIS_802_11_CONFIGURATION_FH {
+	ULONG           Length;             /* Length of structure */
+	ULONG           HopPattern;         /* As defined by 802.11, MSB set */
+	ULONG           HopSet;             /* to one if non-802.11 */
+	ULONG           DwellTime;          /* units are Kusec */
 } NDIS_802_11_CONFIGURATION_FH, *PNDIS_802_11_CONFIGURATION_FH;
- 
+
 
 /*
 	FW will only save the channel number in DSConfig.
-	ODI Handler will convert the channel number to freq. number.	
+	ODI Handler will convert the channel number to freq. number.
 */
-typedef struct _NDIS_802_11_CONFIGURATION
-{
-    ULONG           Length;             // Length of structure
-    ULONG           BeaconPeriod;       // units are Kusec
-    ULONG           ATIMWindow;         // units are Kusec
+typedef struct _NDIS_802_11_CONFIGURATION {
+	ULONG           Length;             /* Length of structure */
+	ULONG           BeaconPeriod;       /* units are Kusec */
+	ULONG           ATIMWindow;         /* units are Kusec */
 	ULONG           DSConfig;           /* channel number */
-    NDIS_802_11_CONFIGURATION_FH    FHConfig;
+	NDIS_802_11_CONFIGURATION_FH    FHConfig;
 } NDIS_802_11_CONFIGURATION, *PNDIS_802_11_CONFIGURATION;
 
 
 
-typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE
-{
-    Ndis802_11IBSS,
-    Ndis802_11Infrastructure,
-    Ndis802_11AutoUnknown,
-    Ndis802_11InfrastructureMax,     // Not a real value, defined as upper bound
+typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE {
+	Ndis802_11IBSS,
+	Ndis802_11Infrastructure,
+	Ndis802_11AutoUnknown,
+	Ndis802_11InfrastructureMax,     /* Not a real value, defined as upper bound */
 	Ndis802_11APMode,
 	Ndis802_11Monitor,
+	Ndis802_11_mesh,
 } NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;
 
 
 
 
 
-typedef struct _NDIS_802_11_FIXED_IEs
-{
-  UCHAR  Timestamp[8];
-  USHORT  BeaconInterval;
-  USHORT  Capabilities;
+typedef struct _NDIS_802_11_FIXED_IEs {
+	UCHAR  Timestamp[8];
+	USHORT  BeaconInterval;
+	USHORT  Capabilities;
 } NDIS_802_11_FIXED_IEs, *PNDIS_802_11_FIXED_IEs;
 
 
 
-typedef struct _NDIS_802_11_VARIABLE_IEs
-{
-  UCHAR  ElementID;
-  UCHAR  Length;
-  UCHAR  data[1];
+typedef struct _NDIS_802_11_VARIABLE_IEs {
+	UCHAR  ElementID;
+	UCHAR  Length;
+	UCHAR  data[1];
 } NDIS_802_11_VARIABLE_IEs, *PNDIS_802_11_VARIABLE_IEs;
 
 
@@ -125,59 +115,55 @@ partial sum.
 
 */
 #if 0
-typedef struct _NDIS_WLAN_BSSID_EX
-{
-  ULONG  Length;
-  NDIS_802_11_MAC_ADDRESS  MacAddress;
-  UCHAR  Reserved[2];//[0]: IS beacon frame, [1]:optimum_antenna=>For antenna diversity;
-  NDIS_802_11_SSID  Ssid;
-  ULONG  Privacy;
-  NDIS_802_11_RSSI  Rssi;
-  NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
-  NDIS_802_11_CONFIGURATION  Configuration;
-  NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
-  NDIS_802_11_RATES_EX  SupportedRates;
-  ULONG  IELength;
-  UCHAR  IEs[MAX_IE_SZ];	//(timestamp, beacon interval, and capability information)
+typedef struct _NDIS_WLAN_BSSID_EX {
+	ULONG  Length;
+	NDIS_802_11_MAC_ADDRESS  MacAddress;
+	UCHAR  Reserved[2];/* [0]: IS beacon frame, [1]:optimum_antenna=>For antenna diversity; */
+	NDIS_802_11_SSID  Ssid;
+	ULONG  Privacy;
+	NDIS_802_11_RSSI  Rssi;
+	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
+	NDIS_802_11_CONFIGURATION  Configuration;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
+	NDIS_802_11_RATES_EX  SupportedRates;
+	ULONG  IELength;
+	UCHAR  IEs[MAX_IE_SZ];	/* (timestamp, beacon interval, and capability information) */
 } NDIS_WLAN_BSSID_EX, *PNDIS_WLAN_BSSID_EX;
 
 
-typedef struct _NDIS_802_11_BSSID_LIST_EX
-{
-  ULONG  NumberOfItems;
-  NDIS_WLAN_BSSID_EX  Bssid[1];
+typedef struct _NDIS_802_11_BSSID_LIST_EX {
+	ULONG  NumberOfItems;
+	NDIS_WLAN_BSSID_EX  Bssid[1];
 } NDIS_802_11_BSSID_LIST_EX, *PNDIS_802_11_BSSID_LIST_EX;
 #endif
 
-typedef enum _NDIS_802_11_AUTHENTICATION_MODE
-{
-    Ndis802_11AuthModeOpen,
-    Ndis802_11AuthModeShared,
-    Ndis802_11AuthModeAutoSwitch,
-    Ndis802_11AuthModeWPA,
-    Ndis802_11AuthModeWPAPSK,
-    Ndis802_11AuthModeWPANone,
-    Ndis802_11AuthModeWAPI,
-    Ndis802_11AuthModeMax               // Not a real mode, defined as upper bound
+typedef enum _NDIS_802_11_AUTHENTICATION_MODE {
+	Ndis802_11AuthModeOpen,
+	Ndis802_11AuthModeShared,
+	Ndis802_11AuthModeAutoSwitch,
+	Ndis802_11AuthModeWPA,
+	Ndis802_11AuthModeWPAPSK,
+	Ndis802_11AuthModeWPANone,
+	Ndis802_11AuthModeWAPI,
+	Ndis802_11AuthModeMax               /* Not a real mode, defined as upper bound */
 } NDIS_802_11_AUTHENTICATION_MODE, *PNDIS_802_11_AUTHENTICATION_MODE;
 
-typedef enum _NDIS_802_11_WEP_STATUS
-{
-    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,
-    Ndis802_11_EncrypteionWAPI
+typedef enum _NDIS_802_11_WEP_STATUS {
+	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,
+	Ndis802_11_EncrypteionWAPI
 } NDIS_802_11_WEP_STATUS, *PNDIS_802_11_WEP_STATUS,
-  NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;
+NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;
 
 
 #define NDIS_802_11_AI_REQFI_CAPABILITIES      1
@@ -188,114 +174,101 @@ typedef enum _NDIS_802_11_WEP_STATUS
 #define NDIS_802_11_AI_RESFI_STATUSCODE        2
 #define NDIS_802_11_AI_RESFI_ASSOCIATIONID     4
 
-typedef struct _NDIS_802_11_AI_REQFI
-{
-    USHORT Capabilities;
-    USHORT ListenInterval;
-    NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;
+typedef struct _NDIS_802_11_AI_REQFI {
+	USHORT Capabilities;
+	USHORT ListenInterval;
+	NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;
 } NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;
 
-typedef struct _NDIS_802_11_AI_RESFI
-{
-    USHORT Capabilities;
-    USHORT StatusCode;
-    USHORT AssociationId;
+typedef struct _NDIS_802_11_AI_RESFI {
+	USHORT Capabilities;
+	USHORT StatusCode;
+	USHORT AssociationId;
 } NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;
 
-typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION
-{
-    ULONG                   Length;
-    USHORT                  AvailableRequestFixedIEs;
-    NDIS_802_11_AI_REQFI    RequestFixedIEs;
-    ULONG                   RequestIELength;
-    ULONG                   OffsetRequestIEs;
-    USHORT                  AvailableResponseFixedIEs;
-    NDIS_802_11_AI_RESFI    ResponseFixedIEs;
-    ULONG                   ResponseIELength;
-    ULONG                   OffsetResponseIEs;
+typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION {
+	ULONG                   Length;
+	USHORT                  AvailableRequestFixedIEs;
+	NDIS_802_11_AI_REQFI    RequestFixedIEs;
+	ULONG                   RequestIELength;
+	ULONG                   OffsetRequestIEs;
+	USHORT                  AvailableResponseFixedIEs;
+	NDIS_802_11_AI_RESFI    ResponseFixedIEs;
+	ULONG                   ResponseIELength;
+	ULONG                   OffsetResponseIEs;
 } NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;
 
-typedef enum _NDIS_802_11_RELOAD_DEFAULTS
-{
-   Ndis802_11ReloadWEPKeys
+typedef enum _NDIS_802_11_RELOAD_DEFAULTS {
+	Ndis802_11ReloadWEPKeys
 } NDIS_802_11_RELOAD_DEFAULTS, *PNDIS_802_11_RELOAD_DEFAULTS;
 
 
-// Key mapping keys require a BSSID
-typedef struct _NDIS_802_11_KEY
-{
-    ULONG           Length;             // Length of this structure
-    ULONG           KeyIndex;           
-    ULONG           KeyLength;          // length of key in bytes
-    NDIS_802_11_MAC_ADDRESS BSSID;
-    NDIS_802_11_KEY_RSC KeyRSC;
-    UCHAR           KeyMaterial[32];     // variable length depending on above field
+/* Key mapping keys require a BSSID */
+typedef struct _NDIS_802_11_KEY {
+	ULONG           Length;             /* Length of this structure */
+	ULONG           KeyIndex;
+	ULONG           KeyLength;          /* length of key in bytes */
+	NDIS_802_11_MAC_ADDRESS BSSID;
+	NDIS_802_11_KEY_RSC KeyRSC;
+	UCHAR           KeyMaterial[32];     /* variable length depending on above field */
 } NDIS_802_11_KEY, *PNDIS_802_11_KEY;
 
-typedef struct _NDIS_802_11_REMOVE_KEY
-{
-    ULONG                   Length;        // Length of this structure
-    ULONG                   KeyIndex;           
-    NDIS_802_11_MAC_ADDRESS BSSID;      
+typedef struct _NDIS_802_11_REMOVE_KEY {
+	ULONG                   Length;        /* Length of this structure */
+	ULONG                   KeyIndex;
+	NDIS_802_11_MAC_ADDRESS BSSID;
 } NDIS_802_11_REMOVE_KEY, *PNDIS_802_11_REMOVE_KEY;
 
-typedef struct _NDIS_802_11_WEP
-{
-    ULONG     Length;        // Length of this structure
-    ULONG     KeyIndex;      // 0 is the per-client key, 1-N are the global keys
-    ULONG     KeyLength;     // length of key in bytes
-    UCHAR     KeyMaterial[16];// variable length depending on above field
+typedef struct _NDIS_802_11_WEP {
+	ULONG     Length;        /* Length of this structure */
+	ULONG     KeyIndex;      /* 0 is the per-client key, 1-N are the global keys */
+	ULONG     KeyLength;     /* length of key in bytes */
+	UCHAR     KeyMaterial[16];/* variable length depending on above field */
 } NDIS_802_11_WEP, *PNDIS_802_11_WEP;
 
-typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST
-{
-    ULONG Length;            // Length of structure
-    NDIS_802_11_MAC_ADDRESS Bssid;
-    ULONG Flags;
+typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST {
+	ULONG Length;            /* Length of structure */
+	NDIS_802_11_MAC_ADDRESS Bssid;
+	ULONG Flags;
 } NDIS_802_11_AUTHENTICATION_REQUEST, *PNDIS_802_11_AUTHENTICATION_REQUEST;
 
-typedef enum _NDIS_802_11_STATUS_TYPE
-{
+typedef enum _NDIS_802_11_STATUS_TYPE {
 	Ndis802_11StatusType_Authentication,
 	Ndis802_11StatusType_MediaStreamMode,
-	Ndis802_11StatusType_PMKID_CandidateList,		
-	Ndis802_11StatusTypeMax    // not a real type, defined as an upper bound
+	Ndis802_11StatusType_PMKID_CandidateList,
+	Ndis802_11StatusTypeMax    /* not a real type, defined as an upper bound */
 } NDIS_802_11_STATUS_TYPE, *PNDIS_802_11_STATUS_TYPE;
 
-typedef struct _NDIS_802_11_STATUS_INDICATION
-{
-    NDIS_802_11_STATUS_TYPE StatusType;
+typedef struct _NDIS_802_11_STATUS_INDICATION {
+	NDIS_802_11_STATUS_TYPE StatusType;
 } NDIS_802_11_STATUS_INDICATION, *PNDIS_802_11_STATUS_INDICATION;
 
-// mask for authentication/integrity fields
+/* mask for authentication/integrity fields */
 #define NDIS_802_11_AUTH_REQUEST_AUTH_FIELDS        0x0f
 #define NDIS_802_11_AUTH_REQUEST_REAUTH			0x01
 #define NDIS_802_11_AUTH_REQUEST_KEYUPDATE		0x02
 #define NDIS_802_11_AUTH_REQUEST_PAIRWISE_ERROR		0x06
 #define NDIS_802_11_AUTH_REQUEST_GROUP_ERROR		0x0E
 
-// MIC check time, 60 seconds.
+/* MIC check time, 60 seconds. */
 #define MIC_CHECK_TIME	60000000
 
-typedef struct _NDIS_802_11_AUTHENTICATION_EVENT
-{
-    NDIS_802_11_STATUS_INDICATION       Status;
-    NDIS_802_11_AUTHENTICATION_REQUEST  Request[1];
+typedef struct _NDIS_802_11_AUTHENTICATION_EVENT {
+	NDIS_802_11_STATUS_INDICATION       Status;
+	NDIS_802_11_AUTHENTICATION_REQUEST  Request[1];
 } NDIS_802_11_AUTHENTICATION_EVENT, *PNDIS_802_11_AUTHENTICATION_EVENT;
-        
-typedef struct _NDIS_802_11_TEST
-{
-    ULONG Length;
-    ULONG Type;
-    union
-    {
-        NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;
-        NDIS_802_11_RSSI RssiTrigger;
-    }tt;
+
+typedef struct _NDIS_802_11_TEST {
+	ULONG Length;
+	ULONG Type;
+	union {
+		NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;
+		NDIS_802_11_RSSI RssiTrigger;
+	} tt;
 } NDIS_802_11_TEST, *PNDIS_802_11_TEST;
 
 
-#endif //end of #ifdef PLATFORM_LINUX
+#endif /* end of #ifdef PLATFORM_LINUX */
 
 #ifdef PLATFORM_FREEBSD
 
@@ -304,81 +277,74 @@ typedef struct _NDIS_802_11_TEST
 #define NDIS_802_11_LENGTH_RATES_EX     16
 
 typedef unsigned char   NDIS_802_11_MAC_ADDRESS[6];
-typedef long    		NDIS_802_11_RSSI;           // in dBm
-typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        // Set of 8 data rates
-typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  // Set of 16 data rates
+typedef long    		NDIS_802_11_RSSI;           /* in dBm */
+typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        /* Set of 8 data rates */
+typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  /* Set of 16 data rates */
 
 
 typedef  ULONG  NDIS_802_11_KEY_INDEX;
 typedef unsigned long long NDIS_802_11_KEY_RSC;
 
 
-typedef struct _NDIS_802_11_SSID
-{
-  ULONG  SsidLength;
-  UCHAR  Ssid[32];
+typedef struct _NDIS_802_11_SSID {
+	ULONG  SsidLength;
+	UCHAR  Ssid[32];
 } NDIS_802_11_SSID, *PNDIS_802_11_SSID;
 
-typedef enum _NDIS_802_11_NETWORK_TYPE
-{
-    Ndis802_11FH,
-    Ndis802_11DS,
-    Ndis802_11OFDM5,
-    Ndis802_11OFDM24,
-    Ndis802_11NetworkTypeMax    // not a real type, defined as an upper bound
+typedef enum _NDIS_802_11_NETWORK_TYPE {
+	Ndis802_11FH,
+	Ndis802_11DS,
+	Ndis802_11OFDM5,
+	Ndis802_11OFDM24,
+	Ndis802_11NetworkTypeMax    /* not a real type, defined as an upper bound */
 } NDIS_802_11_NETWORK_TYPE, *PNDIS_802_11_NETWORK_TYPE;
 
-typedef struct _NDIS_802_11_CONFIGURATION_FH
-{
-    ULONG           Length;             // Length of structure
-    ULONG           HopPattern;         // As defined by 802.11, MSB set
-    ULONG           HopSet;             // to one if non-802.11
-    ULONG           DwellTime;          // units are Kusec
+typedef struct _NDIS_802_11_CONFIGURATION_FH {
+	ULONG           Length;             /* Length of structure */
+	ULONG           HopPattern;         /* As defined by 802.11, MSB set */
+	ULONG           HopSet;             /* to one if non-802.11 */
+	ULONG           DwellTime;          /* units are Kusec */
 } NDIS_802_11_CONFIGURATION_FH, *PNDIS_802_11_CONFIGURATION_FH;
- 
+
 
 /*
 	FW will only save the channel number in DSConfig.
-	ODI Handler will convert the channel number to freq. number.	
+	ODI Handler will convert the channel number to freq. number.
 */
-typedef struct _NDIS_802_11_CONFIGURATION
-{
-    ULONG           Length;             // Length of structure
-    ULONG           BeaconPeriod;       // units are Kusec
-    ULONG           ATIMWindow;         // units are Kusec
-	ULONG           DSConfig;           /* channel number */ 
-    NDIS_802_11_CONFIGURATION_FH    FHConfig;
+typedef struct _NDIS_802_11_CONFIGURATION {
+	ULONG           Length;             /* Length of structure */
+	ULONG           BeaconPeriod;       /* units are Kusec */
+	ULONG           ATIMWindow;         /* units are Kusec */
+	ULONG           DSConfig;           /* channel number */
+	NDIS_802_11_CONFIGURATION_FH    FHConfig;
 } NDIS_802_11_CONFIGURATION, *PNDIS_802_11_CONFIGURATION;
 
 
 
-typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE
-{
-    Ndis802_11IBSS,
-    Ndis802_11Infrastructure,
-    Ndis802_11AutoUnknown,
-    Ndis802_11InfrastructureMax,     // Not a real value, defined as upper bound
-    Ndis802_11APMode
+typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE {
+	Ndis802_11IBSS,
+	Ndis802_11Infrastructure,
+	Ndis802_11AutoUnknown,
+	Ndis802_11InfrastructureMax,     /* Not a real value, defined as upper bound */
+	Ndis802_11APMode
 } NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;
 
 
 
 
 
-typedef struct _NDIS_802_11_FIXED_IEs
-{
-  UCHAR  Timestamp[8];
-  USHORT  BeaconInterval;
-  USHORT  Capabilities;
+typedef struct _NDIS_802_11_FIXED_IEs {
+	UCHAR  Timestamp[8];
+	USHORT  BeaconInterval;
+	USHORT  Capabilities;
 } NDIS_802_11_FIXED_IEs, *PNDIS_802_11_FIXED_IEs;
 
 
 
-typedef struct _NDIS_802_11_VARIABLE_IEs
-{
-  UCHAR  ElementID;
-  UCHAR  Length;
-  UCHAR  data[1];
+typedef struct _NDIS_802_11_VARIABLE_IEs {
+	UCHAR  ElementID;
+	UCHAR  Length;
+	UCHAR  data[1];
 } NDIS_802_11_VARIABLE_IEs, *PNDIS_802_11_VARIABLE_IEs;
 
 
@@ -397,57 +363,53 @@ partial sum.
 
 */
 #if 0
-typedef struct _NDIS_WLAN_BSSID_EX
-{
-  ULONG  Length;
-  NDIS_802_11_MAC_ADDRESS  MacAddress;
-  UCHAR  Reserved[2];//[0]: IS beacon frame, [1]:optimum_antenna=>For antenna diversity;
-  NDIS_802_11_SSID  Ssid;
-  ULONG  Privacy;
-  NDIS_802_11_RSSI  Rssi;
-  NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
-  NDIS_802_11_CONFIGURATION  Configuration;
-  NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
-  NDIS_802_11_RATES_EX  SupportedRates;
-  ULONG  IELength;
-  UCHAR  IEs[MAX_IE_SZ];	//(timestamp, beacon interval, and capability information)
+typedef struct _NDIS_WLAN_BSSID_EX {
+	ULONG  Length;
+	NDIS_802_11_MAC_ADDRESS  MacAddress;
+	UCHAR  Reserved[2];/* [0]: IS beacon frame, [1]:optimum_antenna=>For antenna diversity; */
+	NDIS_802_11_SSID  Ssid;
+	ULONG  Privacy;
+	NDIS_802_11_RSSI  Rssi;
+	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
+	NDIS_802_11_CONFIGURATION  Configuration;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
+	NDIS_802_11_RATES_EX  SupportedRates;
+	ULONG  IELength;
+	UCHAR  IEs[MAX_IE_SZ];	/* (timestamp, beacon interval, and capability information) */
 } NDIS_WLAN_BSSID_EX, *PNDIS_WLAN_BSSID_EX;
 
 
-typedef struct _NDIS_802_11_BSSID_LIST_EX
-{
-  ULONG  NumberOfItems;
-  NDIS_WLAN_BSSID_EX  Bssid[1];
+typedef struct _NDIS_802_11_BSSID_LIST_EX {
+	ULONG  NumberOfItems;
+	NDIS_WLAN_BSSID_EX  Bssid[1];
 } NDIS_802_11_BSSID_LIST_EX, *PNDIS_802_11_BSSID_LIST_EX;
 #endif
 
-typedef enum _NDIS_802_11_AUTHENTICATION_MODE
-{
-    Ndis802_11AuthModeOpen,
-    Ndis802_11AuthModeShared,
-    Ndis802_11AuthModeAutoSwitch,
-    Ndis802_11AuthModeWPA,
-    Ndis802_11AuthModeWPAPSK,
-    Ndis802_11AuthModeWPANone,
-    Ndis802_11AuthModeMax               // Not a real mode, defined as upper bound
+typedef enum _NDIS_802_11_AUTHENTICATION_MODE {
+	Ndis802_11AuthModeOpen,
+	Ndis802_11AuthModeShared,
+	Ndis802_11AuthModeAutoSwitch,
+	Ndis802_11AuthModeWPA,
+	Ndis802_11AuthModeWPAPSK,
+	Ndis802_11AuthModeWPANone,
+	Ndis802_11AuthModeMax               /* Not a real mode, defined as upper bound */
 } NDIS_802_11_AUTHENTICATION_MODE, *PNDIS_802_11_AUTHENTICATION_MODE;
 
-typedef enum _NDIS_802_11_WEP_STATUS
-{
-    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
+typedef enum _NDIS_802_11_WEP_STATUS {
+	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
 } NDIS_802_11_WEP_STATUS, *PNDIS_802_11_WEP_STATUS,
-  NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;
+NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;
 
 
 #define NDIS_802_11_AI_REQFI_CAPABILITIES      1
@@ -458,139 +420,136 @@ typedef enum _NDIS_802_11_WEP_STATUS
 #define NDIS_802_11_AI_RESFI_STATUSCODE        2
 #define NDIS_802_11_AI_RESFI_ASSOCIATIONID     4
 
-typedef struct _NDIS_802_11_AI_REQFI
-{
-    USHORT Capabilities;
-    USHORT ListenInterval;
-    NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;
+typedef struct _NDIS_802_11_AI_REQFI {
+	USHORT Capabilities;
+	USHORT ListenInterval;
+	NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;
 } NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;
 
-typedef struct _NDIS_802_11_AI_RESFI
-{
-    USHORT Capabilities;
-    USHORT StatusCode;
-    USHORT AssociationId;
+typedef struct _NDIS_802_11_AI_RESFI {
+	USHORT Capabilities;
+	USHORT StatusCode;
+	USHORT AssociationId;
 } NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;
 
-typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION
-{
-    ULONG                   Length;
-    USHORT                  AvailableRequestFixedIEs;
-    NDIS_802_11_AI_REQFI    RequestFixedIEs;
-    ULONG                   RequestIELength;
-    ULONG                   OffsetRequestIEs;
-    USHORT                  AvailableResponseFixedIEs;
-    NDIS_802_11_AI_RESFI    ResponseFixedIEs;
-    ULONG                   ResponseIELength;
-    ULONG                   OffsetResponseIEs;
+typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION {
+	ULONG                   Length;
+	USHORT                  AvailableRequestFixedIEs;
+	NDIS_802_11_AI_REQFI    RequestFixedIEs;
+	ULONG                   RequestIELength;
+	ULONG                   OffsetRequestIEs;
+	USHORT                  AvailableResponseFixedIEs;
+	NDIS_802_11_AI_RESFI    ResponseFixedIEs;
+	ULONG                   ResponseIELength;
+	ULONG                   OffsetResponseIEs;
 } NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;
 
-typedef enum _NDIS_802_11_RELOAD_DEFAULTS
-{
-   Ndis802_11ReloadWEPKeys
+typedef enum _NDIS_802_11_RELOAD_DEFAULTS {
+	Ndis802_11ReloadWEPKeys
 } NDIS_802_11_RELOAD_DEFAULTS, *PNDIS_802_11_RELOAD_DEFAULTS;
 
 
-// Key mapping keys require a BSSID
-typedef struct _NDIS_802_11_KEY
-{
-    ULONG           Length;             // Length of this structure
-    ULONG           KeyIndex;           
-    ULONG           KeyLength;          // length of key in bytes
-    NDIS_802_11_MAC_ADDRESS BSSID;
-    NDIS_802_11_KEY_RSC KeyRSC;
-    UCHAR           KeyMaterial[32];     // variable length depending on above field
+/* Key mapping keys require a BSSID */
+typedef struct _NDIS_802_11_KEY {
+	ULONG           Length;             /* Length of this structure */
+	ULONG           KeyIndex;
+	ULONG           KeyLength;          /* length of key in bytes */
+	NDIS_802_11_MAC_ADDRESS BSSID;
+	NDIS_802_11_KEY_RSC KeyRSC;
+	UCHAR           KeyMaterial[32];     /* variable length depending on above field */
 } NDIS_802_11_KEY, *PNDIS_802_11_KEY;
 
-typedef struct _NDIS_802_11_REMOVE_KEY
-{
-    ULONG                   Length;        // Length of this structure
-    ULONG                   KeyIndex;           
-    NDIS_802_11_MAC_ADDRESS BSSID;      
+typedef struct _NDIS_802_11_REMOVE_KEY {
+	ULONG                   Length;        /* Length of this structure */
+	ULONG                   KeyIndex;
+	NDIS_802_11_MAC_ADDRESS BSSID;
 } NDIS_802_11_REMOVE_KEY, *PNDIS_802_11_REMOVE_KEY;
 
-typedef struct _NDIS_802_11_WEP
-{
-    ULONG     Length;        // Length of this structure
-    ULONG     KeyIndex;      // 0 is the per-client key, 1-N are the global keys
-    ULONG     KeyLength;     // length of key in bytes
-    UCHAR     KeyMaterial[16];// variable length depending on above field
+typedef struct _NDIS_802_11_WEP {
+	ULONG     Length;        /* Length of this structure */
+	ULONG     KeyIndex;      /* 0 is the per-client key, 1-N are the global keys */
+	ULONG     KeyLength;     /* length of key in bytes */
+	UCHAR     KeyMaterial[16];/* variable length depending on above field */
 } NDIS_802_11_WEP, *PNDIS_802_11_WEP;
 
-typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST
-{
-    ULONG Length;            // Length of structure
-    NDIS_802_11_MAC_ADDRESS Bssid;
-    ULONG Flags;
+typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST {
+	ULONG Length;            /* Length of structure */
+	NDIS_802_11_MAC_ADDRESS Bssid;
+	ULONG Flags;
 } NDIS_802_11_AUTHENTICATION_REQUEST, *PNDIS_802_11_AUTHENTICATION_REQUEST;
 
-typedef enum _NDIS_802_11_STATUS_TYPE
-{
+typedef enum _NDIS_802_11_STATUS_TYPE {
 	Ndis802_11StatusType_Authentication,
 	Ndis802_11StatusType_MediaStreamMode,
-	Ndis802_11StatusType_PMKID_CandidateList,		
-	Ndis802_11StatusTypeMax    // not a real type, defined as an upper bound
+	Ndis802_11StatusType_PMKID_CandidateList,
+	Ndis802_11StatusTypeMax    /* not a real type, defined as an upper bound */
 } NDIS_802_11_STATUS_TYPE, *PNDIS_802_11_STATUS_TYPE;
 
-typedef struct _NDIS_802_11_STATUS_INDICATION
-{
-    NDIS_802_11_STATUS_TYPE StatusType;
+typedef struct _NDIS_802_11_STATUS_INDICATION {
+	NDIS_802_11_STATUS_TYPE StatusType;
 } NDIS_802_11_STATUS_INDICATION, *PNDIS_802_11_STATUS_INDICATION;
 
-// mask for authentication/integrity fields
+/* mask for authentication/integrity fields */
 #define NDIS_802_11_AUTH_REQUEST_AUTH_FIELDS        0x0f
 #define NDIS_802_11_AUTH_REQUEST_REAUTH			0x01
 #define NDIS_802_11_AUTH_REQUEST_KEYUPDATE		0x02
 #define NDIS_802_11_AUTH_REQUEST_PAIRWISE_ERROR		0x06
 #define NDIS_802_11_AUTH_REQUEST_GROUP_ERROR		0x0E
 
-// MIC check time, 60 seconds.
+/* MIC check time, 60 seconds. */
 #define MIC_CHECK_TIME	60000000
 
-typedef struct _NDIS_802_11_AUTHENTICATION_EVENT
-{
-    NDIS_802_11_STATUS_INDICATION       Status;
-    NDIS_802_11_AUTHENTICATION_REQUEST  Request[1];
+typedef struct _NDIS_802_11_AUTHENTICATION_EVENT {
+	NDIS_802_11_STATUS_INDICATION       Status;
+	NDIS_802_11_AUTHENTICATION_REQUEST  Request[1];
 } NDIS_802_11_AUTHENTICATION_EVENT, *PNDIS_802_11_AUTHENTICATION_EVENT;
-        
-typedef struct _NDIS_802_11_TEST
-{
-    ULONG Length;
-    ULONG Type;
-    union
-    {
-        NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;
-        NDIS_802_11_RSSI RssiTrigger;
-    }tt;
+
+typedef struct _NDIS_802_11_TEST {
+	ULONG Length;
+	ULONG Type;
+	union {
+		NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;
+		NDIS_802_11_RSSI RssiTrigger;
+	} tt;
 } NDIS_802_11_TEST, *PNDIS_802_11_TEST;
 
 
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 #ifndef Ndis802_11APMode
 #define Ndis802_11APMode (Ndis802_11InfrastructureMax+1)
 #endif
 
-typedef struct _WLAN_PHY_INFO
-{
-	u8	SignalStrength;//(in percentage)
-  	u8	SignalQuality;//(in percentage)
-  	u8	Optimum_antenna;  //for Antenna diversity
-  	u8  	Reserved_0;
-}WLAN_PHY_INFO,*PWLAN_PHY_INFO;
+typedef struct _WLAN_PHY_INFO {
+	u8	SignalStrength;/* (in percentage) */
+	u8	SignalQuality;/* (in percentage) */
+	u8	Optimum_antenna;  /* for Antenna diversity */
+	u8	is_cck_rate;	/* 1:cck_rate */
+	s8	rx_snr[4];
+#ifdef CONFIG_RTW_80211K
+	u32	free_cnt; 	/* freerun counter */
+	u8	rm_en_cap[5];
+#endif
+} WLAN_PHY_INFO, *PWLAN_PHY_INFO;
 
-typedef struct _WLAN_BCN_INFO
-{
+typedef 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/WAPI
-	int group_cipher; //WPA/WPA2 group cipher
-	int pairwise_cipher;////WPA/WPA2/WEP pairwise cipher
+	 *	 * translate scan to UI */
+	u8 encryp_protocol;/* ENCRYP_PROTOCOL_E: OPEN/WEP/WPA/WPA2/WAPI */
+	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 */
-	unsigned short 	ht_cap_info;
+	unsigned short	ht_cap_info;
 	unsigned char	ht_info_infos_0;
-}WLAN_BCN_INFO,*PWLAN_BCN_INFO;
+} WLAN_BCN_INFO, *PWLAN_BCN_INFO;
+
+enum bss_type {
+	BSS_TYPE_UNDEF,
+	BSS_TYPE_BCN = 1,
+	BSS_TYPE_PROB_REQ = 2,
+	BSS_TYPE_PROB_RSP = 3,
+};
 
 /* temporally add #pragma pack for structure alignment issue of
 *   WLAN_BSSID_EX and get_WLAN_BSSID_EX_sz()
@@ -599,22 +558,22 @@ typedef struct _WLAN_BCN_INFO
 #pragma pack(push)
 #pragma pack(1)
 #endif
-typedef struct _WLAN_BSSID_EX
-{
-  ULONG  Length;
-  NDIS_802_11_MAC_ADDRESS  MacAddress;
-  UCHAR  Reserved[2];//[0]: IS beacon frame
-  NDIS_802_11_SSID  Ssid;
-  ULONG  Privacy;
-  NDIS_802_11_RSSI  Rssi;//(in dBM,raw data ,get from PHY)
-  NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
-  NDIS_802_11_CONFIGURATION  Configuration;
-  NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
-  NDIS_802_11_RATES_EX  SupportedRates;
-  WLAN_PHY_INFO	PhyInfo;
-  ULONG  IELength;
-  UCHAR  IEs[MAX_IE_SZ];	//(timestamp, beacon interval, and capability information)
-} 
+typedef struct _WLAN_BSSID_EX {
+	ULONG  Length;
+	NDIS_802_11_MAC_ADDRESS  MacAddress;
+	UCHAR  Reserved[2];/* [0]: IS beacon frame , bss_type*/
+	NDIS_802_11_SSID  Ssid;
+	NDIS_802_11_SSID  mesh_id;
+	ULONG  Privacy;
+	NDIS_802_11_RSSI  Rssi;/* (in dBM,raw data ,get from PHY) */
+	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
+	NDIS_802_11_CONFIGURATION  Configuration;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;
+	NDIS_802_11_RATES_EX  SupportedRates;
+	WLAN_PHY_INFO	PhyInfo;
+	ULONG  IELength;
+	UCHAR  IEs[MAX_IE_SZ];	/* (timestamp, beacon interval, and capability information) */
+}
 #ifndef PLATFORM_WINDOWS
 __attribute__((packed))
 #endif
@@ -625,7 +584,7 @@ WLAN_BSSID_EX, *PWLAN_BSSID_EX;
 
 #define BSS_EX_IES(bss_ex) ((bss_ex)->IEs)
 #define BSS_EX_IES_LEN(bss_ex) ((bss_ex)->IELength)
-#define BSS_EX_FIXED_IE_OFFSET(bss_ex) ((bss_ex)->Reserved[0] == 2 ? 0 : 12)
+#define BSS_EX_FIXED_IE_OFFSET(bss_ex) ((bss_ex)->Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12)
 #define BSS_EX_TLV_IES(bss_ex) (BSS_EX_IES((bss_ex)) + BSS_EX_FIXED_IE_OFFSET((bss_ex)))
 #define BSS_EX_TLV_IES_LEN(bss_ex) (BSS_EX_IES_LEN((bss_ex)) - BSS_EX_FIXED_IE_OFFSET((bss_ex)))
 
@@ -633,55 +592,53 @@ __inline  static uint get_WLAN_BSSID_EX_sz(WLAN_BSSID_EX *bss)
 {
 #if 0
 	uint t_len;
-	
-	t_len = sizeof (ULONG) 
-		+ sizeof (NDIS_802_11_MAC_ADDRESS) 
-		+ 2 
-		+ sizeof (NDIS_802_11_SSID) 
-		+ sizeof (ULONG) 
-		+ sizeof (NDIS_802_11_RSSI) 
-		+ sizeof (NDIS_802_11_NETWORK_TYPE)
-		+ sizeof (NDIS_802_11_CONFIGURATION)
-		+ sizeof (NDIS_802_11_NETWORK_INFRASTRUCTURE)
-		+ sizeof (NDIS_802_11_RATES_EX)
-		//all new member add here
+
+	t_len = sizeof(ULONG)
+		+ sizeof(NDIS_802_11_MAC_ADDRESS)
+		+ 2
+		+ sizeof(NDIS_802_11_SSID)
+		+ sizeof(ULONG)
+		+ sizeof(NDIS_802_11_RSSI)
+		+ sizeof(NDIS_802_11_NETWORK_TYPE)
+		+ sizeof(NDIS_802_11_CONFIGURATION)
+		+ sizeof(NDIS_802_11_NETWORK_INFRASTRUCTURE)
+		+ sizeof(NDIS_802_11_RATES_EX)
+		/* all new member add here */
 		+ sizeof(WLAN_PHY_INFO)
-		//all new member add here
-		+ sizeof (ULONG)
-		+ bss->IELength;	
+		/* all new member add here */
+		+ sizeof(ULONG)
+		+ bss->IELength;
 	return t_len;
 #else
-	return (sizeof(WLAN_BSSID_EX) -MAX_IE_SZ + bss->IELength);
+	return sizeof(WLAN_BSSID_EX) - MAX_IE_SZ + bss->IELength;
 #endif
 }
 
 struct	wlan_network {
-	_list	list;	
-	int	network_type;	//refer to ieee80211.h for WIRELESS_11A/B/G
-	int	fixed;			// set to fixed when not to be removed as site-surveying
-	unsigned long	last_scanned; //timestamp for the network
-	int	aid;			//will only be valid when a BSS is joinned.
+	_list	list;
+	int	network_type;	/* refer to ieee80211.h for WIRELESS_11A/B/G */
+	int	fixed;			/* set to fixed when not to be removed as site-surveying */
+	systime last_scanned; /* timestamp for the network */
+	int	aid;			/* will only be valid when a BSS is joinned. */
 	int	join_res;
-	WLAN_BSSID_EX	network; //must be the last item
+	WLAN_BSSID_EX	network; /* must be the last item */
 	WLAN_BCN_INFO	BcnInfo;
-#ifdef PLATFORM_WINDOWS	
+#ifdef PLATFORM_WINDOWS
 	unsigned char  iebuf[MAX_IE_SZ];
 #endif
 
 };
 
-enum VRTL_CARRIER_SENSE
-{
-    DISABLE_VCS,	
-    ENABLE_VCS,	
-    AUTO_VCS
+enum VRTL_CARRIER_SENSE {
+	DISABLE_VCS,
+	ENABLE_VCS,
+	AUTO_VCS
 };
 
-enum VCS_TYPE
-{
-    NONE_VCS,	
-    RTS_CTS,
-    CTS_TO_SELF 
+enum VCS_TYPE {
+	NONE_VCS,
+	RTS_CTS,
+	CTS_TO_SELF
 };
 
 
@@ -694,55 +651,50 @@ enum VCS_TYPE
 #define PWR_VOIP 4
 
 
-enum UAPSD_MAX_SP
-{
+enum UAPSD_MAX_SP {
 	NO_LIMIT,
-       TWO_MSDU,
-       FOUR_MSDU,
-       SIX_MSDU
+	TWO_MSDU,
+	FOUR_MSDU,
+	SIX_MSDU
 };
 
 
-//john
+/* john */
 #define NUM_PRE_AUTH_KEY 16
 #define NUM_PMKID_CACHE NUM_PRE_AUTH_KEY
 
 /*
-* 	WPA2
+*	WPA2
 */
 
 #ifndef PLATFORM_OS_CE
 typedef struct _PMKID_CANDIDATE {
-    NDIS_802_11_MAC_ADDRESS BSSID;
-    ULONG Flags;
+	NDIS_802_11_MAC_ADDRESS BSSID;
+	ULONG Flags;
 } PMKID_CANDIDATE, *PPMKID_CANDIDATE;
 
-typedef struct _NDIS_802_11_PMKID_CANDIDATE_LIST
-{
-    ULONG Version;       // Version of the structure
-    ULONG NumCandidates; // No. of pmkid candidates
-    PMKID_CANDIDATE CandidateList[1];
+typedef struct _NDIS_802_11_PMKID_CANDIDATE_LIST {
+	ULONG Version;       /* Version of the structure */
+	ULONG NumCandidates; /* No. of pmkid candidates */
+	PMKID_CANDIDATE CandidateList[1];
 } NDIS_802_11_PMKID_CANDIDATE_LIST, *PNDIS_802_11_PMKID_CANDIDATE_LIST;
 
 
-typedef struct _NDIS_802_11_AUTHENTICATION_ENCRYPTION
-{
+typedef struct _NDIS_802_11_AUTHENTICATION_ENCRYPTION {
 	NDIS_802_11_AUTHENTICATION_MODE AuthModeSupported;
 	NDIS_802_11_ENCRYPTION_STATUS EncryptStatusSupported;
-	
+
 } NDIS_802_11_AUTHENTICATION_ENCRYPTION, *PNDIS_802_11_AUTHENTICATION_ENCRYPTION;
 
-typedef struct _NDIS_802_11_CAPABILITY 
-{
+typedef struct _NDIS_802_11_CAPABILITY {
 	ULONG  Length;
 	ULONG  Version;
 	ULONG  NoOfPMKIDs;
 	ULONG  NoOfAuthEncryptPairsSupported;
 	NDIS_802_11_AUTHENTICATION_ENCRYPTION AuthenticationEncryptionSupported[1];
-	
+
 } NDIS_802_11_CAPABILITY, *PNDIS_802_11_CAPABILITY;
 #endif
 
 
-#endif //#ifndef WLAN_BSSDEF_H_
-
+#endif /* #ifndef WLAN_BSSDEF_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/xmit_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/xmit_osdep.h
index d489ebfcf642..f9145d55f6d3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/xmit_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/include/xmit_osdep.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,14 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __XMIT_OSDEP_H_
 #define __XMIT_OSDEP_H_
 
 
 struct pkt_file {
 	_pkt *pkt;
-	SIZE_T pkt_len;	 //the remainder length of the open_file
+	SIZE_T pkt_len;	 /* the remainder length of the open_file */
 	_buffer *cur_buffer;
 	u8 *buf_start;
 	u8 *cur_addr;
@@ -41,26 +37,26 @@ struct pkt_file {
 #endif
 
 #ifdef CONFIG_GSPI_HCI
-#define NR_XMITFRAME     64
+	#define NR_XMITFRAME     64
 #else
-#define NR_XMITFRAME     128
+	#define NR_XMITFRAME     128
 #endif
 
 #define ETH_ALEN	6
 
 extern NDIS_STATUS rtw_xmit_entry(
-IN _nic_hdl		cnxt,
-IN NDIS_PACKET		*pkt,
-IN UINT				flags
+	IN _nic_hdl		cnxt,
+	IN NDIS_PACKET		*pkt,
+	IN UINT				flags
 );
 
-#endif
+#endif /* PLATFORM_WINDOWS */
 
 #ifdef PLATFORM_FREEBSD
 #define NR_XMITFRAME	256
 extern int rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev);
-extern void rtw_xmit_entry_wrap (struct ifnet * pifp);
-#endif //PLATFORM_FREEBSD
+extern void rtw_xmit_entry_wrap(struct ifnet *pifp);
+#endif /* PLATFORM_FREEBSD */
 
 #ifdef PLATFORM_LINUX
 
@@ -75,7 +71,7 @@ struct xmit_buf;
 extern int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev);
 extern int rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev);
 
-#endif
+#endif /* PLATFORM_LINUX */
 
 void rtw_os_xmit_schedule(_adapter *padapter);
 
@@ -86,8 +82,8 @@ extern void rtw_set_tx_chksum_offload(_pkt *pkt, struct pkt_attrib *pattrib);
 
 extern uint rtw_remainder_len(struct pkt_file *pfile);
 extern void _rtw_open_pktfile(_pkt *pkt, struct pkt_file *pfile);
-extern uint _rtw_pktfile_read (struct pkt_file *pfile, u8 *rmem, uint rlen);
-extern sint rtw_endofpktfile (struct pkt_file *pfile);
+extern uint _rtw_pktfile_read(struct pkt_file *pfile, u8 *rmem, uint rlen);
+extern sint rtw_endofpktfile(struct pkt_file *pfile);
 
 extern void rtw_os_pkt_complete(_adapter *padapter, _pkt *pkt);
 extern void rtw_os_xmit_complete(_adapter *padapter, struct xmit_frame *pxframe);
@@ -96,5 +92,4 @@ void rtw_os_wake_queue_at_free_stainfo(_adapter *padapter, int *qcnt_freed);
 
 void dump_os_queue(void *sel, _adapter *padapter);
 
-#endif //__XMIT_OSDEP_H_
-
+#endif /* __XMIT_OSDEP_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/custom_gpio_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/custom_gpio_linux.c
index 815bf05f0834..e46c4be2fde8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/custom_gpio_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/custom_gpio_linux.c
@@ -1,7 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
- * Customer code to add GPIO control during WLAN start/stop
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -12,18 +12,13 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #include "drv_types.h"
 
 #ifdef CONFIG_PLATFORM_SPRD
 
-//gspi func & GPIO define
-#include <mach/gpio.h>//0915
+/* gspi func & GPIO define */
+#include <mach/gpio.h>/* 0915 */
 #include <mach/board.h>
 
 #if !(defined ANDROID_2X)
@@ -31,27 +26,27 @@
 #ifdef CONFIG_RTL8188E
 #include <mach/regulator.h>
 #include <linux/regulator/consumer.h>
-#endif // CONFIG_RTL8188E
+#endif /* CONFIG_RTL8188E */
 
 #ifndef GPIO_WIFI_POWER
 #define GPIO_WIFI_POWER -1
-#endif // !GPIO_WIFI_POWER
+#endif /* !GPIO_WIFI_POWER */
 
 #ifndef GPIO_WIFI_RESET
 #define GPIO_WIFI_RESET -1
-#endif // !GPIO_WIFI_RESET
+#endif /* !GPIO_WIFI_RESET */
 
 #ifndef GPIO_WIFI_PWDN
 #define GPIO_WIFI_PWDN -1
-#endif // !GPIO_WIFI_RESET
+#endif /* !GPIO_WIFI_RESET */
 #ifdef CONFIG_GSPI_HCI
 extern unsigned int oob_irq;
-#endif // CONFIG_GSPI_HCI
+#endif /* CONFIG_GSPI_HCI */
 
 #ifdef CONFIG_SDIO_HCI
 extern int rtw_mp_mode;
-#else // !CONFIG_SDIO_HCI
-#endif // !CONFIG_SDIO_HCI
+#else /* !CONFIG_SDIO_HCI */
+#endif /* !CONFIG_SDIO_HCI */
 
 int rtw_wifi_gpio_init(void)
 {
@@ -62,7 +57,7 @@ int rtw_wifi_gpio_init(void)
 
 		oob_irq = gpio_to_irq(GPIO_WIFI_IRQ);
 
-		DBG_8192C("%s oob_irq:%d\n", __func__, oob_irq);
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
 	}
 #endif
 	if (GPIO_WIFI_RESET > 0)
@@ -71,9 +66,9 @@ int rtw_wifi_gpio_init(void)
 		gpio_request(GPIO_WIFI_POWER, "wifi_power");
 
 #ifdef CONFIG_SDIO_HCI
-#if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1) 
-	if(rtw_mp_mode==1){
-		DBG_871X("%s GPIO_BT_RESET pin special for mp_test\n", __func__);	
+#if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
+	if (rtw_mp_mode == 1) {
+		RTW_INFO("%s GPIO_BT_RESET pin special for mp_test\n", __func__);
 		if (GPIO_BT_RESET > 0)
 			gpio_request(GPIO_BT_RESET , "bt_rst");
 	}
@@ -89,14 +84,14 @@ int rtw_wifi_gpio_deinit(void)
 		gpio_free(GPIO_WIFI_IRQ);
 #endif
 	if (GPIO_WIFI_RESET > 0)
-		gpio_free(GPIO_WIFI_RESET );
+		gpio_free(GPIO_WIFI_RESET);
 	if (GPIO_WIFI_POWER > 0)
 		gpio_free(GPIO_WIFI_POWER);
 
 #ifdef CONFIG_SDIO_HCI
-#if ( defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1) 
-	if(rtw_mp_mode==1){
-		DBG_871X("%s GPIO_BT_RESET pin special for mp_test\n", __func__);
+#if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
+	if (rtw_mp_mode == 1) {
+		RTW_INFO("%s GPIO_BT_RESET pin special for mp_test\n", __func__);
 		if (GPIO_BT_RESET > 0)
 			gpio_free(GPIO_BT_RESET);
 	}
@@ -108,48 +103,45 @@ int rtw_wifi_gpio_deinit(void)
 /* Customer function to control hw specific wlan gpios */
 void rtw_wifi_gpio_wlan_ctrl(int onoff)
 {
-	switch (onoff)
-	{
-		case WLAN_PWDN_OFF:
-			DBG_8192C("%s: call customer specific GPIO(%d) to set wifi power down pin to 0\n",
-				__FUNCTION__, GPIO_WIFI_RESET);
+	switch (onoff) {
+	case WLAN_PWDN_OFF:
+		RTW_INFO("%s: call customer specific GPIO(%d) to set wifi power down pin to 0\n",
+			 __FUNCTION__, GPIO_WIFI_RESET);
 
 #ifndef CONFIG_DONT_BUS_SCAN
-			if (GPIO_WIFI_RESET > 0)
-				gpio_direction_output(GPIO_WIFI_RESET , 0);
+		if (GPIO_WIFI_RESET > 0)
+			gpio_direction_output(GPIO_WIFI_RESET , 0);
 #endif
 		break;
 
-		case WLAN_PWDN_ON:
-			DBG_8192C("%s: callc customer specific GPIO(%d) to set wifi power down pin to 1\n",
-				__FUNCTION__, GPIO_WIFI_RESET);
+	case WLAN_PWDN_ON:
+		RTW_INFO("%s: callc customer specific GPIO(%d) to set wifi power down pin to 1\n",
+			 __FUNCTION__, GPIO_WIFI_RESET);
 
-			if (GPIO_WIFI_RESET > 0)
-				gpio_direction_output(GPIO_WIFI_RESET , 1);
+		if (GPIO_WIFI_RESET > 0)
+			gpio_direction_output(GPIO_WIFI_RESET , 1);
 		break;
 
-		case WLAN_POWER_OFF:
+	case WLAN_POWER_OFF:
 		break;
 
-		case WLAN_POWER_ON:
+	case WLAN_POWER_ON:
 		break;
 #ifdef CONFIG_SDIO_HCI
-#if ( defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1) 
-		case WLAN_BT_PWDN_OFF:
-		if(rtw_mp_mode==1)
-		{
-			DBG_871X("%s: call customer specific GPIO to set wifi power down pin to 0\n",
-				       	__FUNCTION__);
+#if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
+	case WLAN_BT_PWDN_OFF:
+		if (rtw_mp_mode == 1) {
+			RTW_INFO("%s: call customer specific GPIO to set wifi power down pin to 0\n",
+				 __FUNCTION__);
 			if (GPIO_BT_RESET > 0)
 				gpio_direction_output(GPIO_BT_RESET , 0);
 		}
 		break;
 
-		case WLAN_BT_PWDN_ON:
-		if(rtw_mp_mode==1)
-		{
-			DBG_871X("%s: callc customer specific GPIO to set wifi power down pin to 1 %x\n",
-					__FUNCTION__, GPIO_BT_RESET);
+	case WLAN_BT_PWDN_ON:
+		if (rtw_mp_mode == 1) {
+			RTW_INFO("%s: callc customer specific GPIO to set wifi power down pin to 1 %x\n",
+				 __FUNCTION__, GPIO_BT_RESET);
 
 			if (GPIO_BT_RESET > 0)
 				gpio_direction_output(GPIO_BT_RESET , 1);
@@ -160,7 +152,7 @@ void rtw_wifi_gpio_wlan_ctrl(int onoff)
 	}
 }
 
-#else //ANDROID_2X
+#else /* ANDROID_2X */
 
 #include <mach/ldo.h>
 
@@ -190,94 +182,90 @@ int rtw_wifi_gpio_deinit(void)
 /* Customer function to control hw specific wlan gpios */
 void rtw_wifi_gpio_wlan_ctrl(int onoff)
 {
-	switch (onoff)
-	{
-		case WLAN_PWDN_OFF:
-			DBG_8192C("%s: call customer specific GPIO to set wifi power down pin to 0\n",
-				__FUNCTION__);
-			if (sprd_3rdparty_gpio_wifi_pwd > 0)
-			{
-				gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 0);
-			}
-
-			if (sprd_3rdparty_gpio_wifi_pwd == 60) {
-				DBG_8192C("%s: turn off VSIM2 2.8V\n", __func__);
-				LDO_TurnOffLDO(LDO_LDO_SIM2);
-			}
+	switch (onoff) {
+	case WLAN_PWDN_OFF:
+		RTW_INFO("%s: call customer specific GPIO to set wifi power down pin to 0\n",
+			 __FUNCTION__);
+		if (sprd_3rdparty_gpio_wifi_pwd > 0)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 0);
+
+		if (sprd_3rdparty_gpio_wifi_pwd == 60) {
+			RTW_INFO("%s: turn off VSIM2 2.8V\n", __func__);
+			LDO_TurnOffLDO(LDO_LDO_SIM2);
+		}
 		break;
 
-		case WLAN_PWDN_ON:
-			DBG_8192C("%s: callc customer specific GPIO to set wifi power down pin to 1\n",
-				__FUNCTION__);
-			if (sprd_3rdparty_gpio_wifi_pwd == 60) {
-				DBG_8192C("%s: turn on VSIM2 2.8V\n", __func__);
-				LDO_SetVoltLevel(LDO_LDO_SIM2, LDO_VOLT_LEVEL0);
-				LDO_TurnOnLDO(LDO_LDO_SIM2);
-			}
-			if (sprd_3rdparty_gpio_wifi_pwd > 0)
-			{
-				gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 1);
-			}
+	case WLAN_PWDN_ON:
+		RTW_INFO("%s: callc customer specific GPIO to set wifi power down pin to 1\n",
+			 __FUNCTION__);
+		if (sprd_3rdparty_gpio_wifi_pwd == 60) {
+			RTW_INFO("%s: turn on VSIM2 2.8V\n", __func__);
+			LDO_SetVoltLevel(LDO_LDO_SIM2, LDO_VOLT_LEVEL0);
+			LDO_TurnOnLDO(LDO_LDO_SIM2);
+		}
+		if (sprd_3rdparty_gpio_wifi_pwd > 0)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 1);
 		break;
 
-		case WLAN_POWER_OFF:
+	case WLAN_POWER_OFF:
 #ifdef CONFIG_RTL8188E
 #ifdef CONFIG_WIF1_LDO
-			DBG_8192C("%s: turn off VDD-WIFI0 1.2V\n", __FUNCTION__);
-			LDO_TurnOffLDO(LDO_LDO_WIF1);
-#endif //CONFIG_WIF1_LDO
+		RTW_INFO("%s: turn off VDD-WIFI0 1.2V\n", __FUNCTION__);
+		LDO_TurnOffLDO(LDO_LDO_WIF1);
+#endif /* CONFIG_WIF1_LDO */
 
-			DBG_8192C("%s: turn off VDD-WIFI0 3.3V\n", __FUNCTION__);
-			LDO_TurnOffLDO(LDO_LDO_WIF0);
+		RTW_INFO("%s: turn off VDD-WIFI0 3.3V\n", __FUNCTION__);
+		LDO_TurnOffLDO(LDO_LDO_WIF0);
 
-			DBG_8192C("%s: call customer specific GPIO(%d) to turn off wifi power\n",
-				__FUNCTION__, sprd_3rdparty_gpio_wifi_power);
-			if (sprd_3rdparty_gpio_wifi_power != 65535)
-				gpio_set_value(sprd_3rdparty_gpio_wifi_power, 0);
+		RTW_INFO("%s: call customer specific GPIO(%d) to turn off wifi power\n",
+			 __FUNCTION__, sprd_3rdparty_gpio_wifi_power);
+		if (sprd_3rdparty_gpio_wifi_power != 65535)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_power, 0);
 #endif
 		break;
 
-		case WLAN_POWER_ON:
+	case WLAN_POWER_ON:
 #ifdef CONFIG_RTL8188E
-			DBG_8192C("%s: call customer specific GPIO(%d) to turn on wifi power\n",
-				__FUNCTION__, sprd_3rdparty_gpio_wifi_power);
-			if (sprd_3rdparty_gpio_wifi_power != 65535)
-				gpio_set_value(sprd_3rdparty_gpio_wifi_power, 1);
+		RTW_INFO("%s: call customer specific GPIO(%d) to turn on wifi power\n",
+			 __FUNCTION__, sprd_3rdparty_gpio_wifi_power);
+		if (sprd_3rdparty_gpio_wifi_power != 65535)
+			gpio_set_value(sprd_3rdparty_gpio_wifi_power, 1);
 
-			DBG_8192C("%s: turn on VDD-WIFI0 3.3V\n", __FUNCTION__);
-			LDO_TurnOnLDO(LDO_LDO_WIF0);
-			LDO_SetVoltLevel(LDO_LDO_WIF0,LDO_VOLT_LEVEL1);
+		RTW_INFO("%s: turn on VDD-WIFI0 3.3V\n", __FUNCTION__);
+		LDO_TurnOnLDO(LDO_LDO_WIF0);
+		LDO_SetVoltLevel(LDO_LDO_WIF0, LDO_VOLT_LEVEL1);
 
 #ifdef CONFIG_WIF1_LDO
-			DBG_8192C("%s: turn on VDD-WIFI1 1.2V\n", __func__);
-			LDO_TurnOnLDO(LDO_LDO_WIF1);
-			LDO_SetVoltLevel(LDO_LDO_WIF1,LDO_VOLT_LEVEL3);
-#endif //CONFIG_WIF1_LDO
+		RTW_INFO("%s: turn on VDD-WIFI1 1.2V\n", __func__);
+		LDO_TurnOnLDO(LDO_LDO_WIF1);
+		LDO_SetVoltLevel(LDO_LDO_WIF1, LDO_VOLT_LEVEL3);
+#endif /* CONFIG_WIF1_LDO */
 #endif
 		break;
 
-		case WLAN_BT_PWDN_OFF:
-			DBG_8192C("%s: call customer specific GPIO to set bt power down pin to 0\n",
-				__FUNCTION__);
+	case WLAN_BT_PWDN_OFF:
+		RTW_INFO("%s: call customer specific GPIO to set bt power down pin to 0\n",
+			 __FUNCTION__);
 #if defined(CONFIG_RTL8723B)
-			if (sprd_3rdparty_gpio_bt_reset > 0)
-				gpio_set_value(sprd_3rdparty_gpio_bt_reset, 0);
+		if (sprd_3rdparty_gpio_bt_reset > 0)
+			gpio_set_value(sprd_3rdparty_gpio_bt_reset, 0);
 #endif
 		break;
 
-		case WLAN_BT_PWDN_ON:
-			DBG_8192C("%s: callc customer specific GPIO to set bt power down pin to 1\n",
-				__FUNCTION__);
+	case WLAN_BT_PWDN_ON:
+		RTW_INFO("%s: callc customer specific GPIO to set bt power down pin to 1\n",
+			 __FUNCTION__);
 #if defined(CONFIG_RTL8723B)
-			if (sprd_3rdparty_gpio_bt_reset > 0)
-				gpio_set_value(sprd_3rdparty_gpio_bt_reset, 1);
+		if (sprd_3rdparty_gpio_bt_reset > 0)
+			gpio_set_value(sprd_3rdparty_gpio_bt_reset, 1);
 #endif
 		break;
 	}
 }
-#endif //ANDROID_2X
+#endif /* ANDROID_2X */
 
 #elif defined(CONFIG_PLATFORM_ARM_RK3066)
+#include <mach/iomux.h>
 
 #define GPIO_WIFI_IRQ		RK30_PIN2_PC2
 extern unsigned int oob_irq;
@@ -285,13 +273,13 @@ int rtw_wifi_gpio_init(void)
 {
 #ifdef CONFIG_GSPI_HCI
 	if (GPIO_WIFI_IRQ > 0) {
-		rk30_mux_api_set(GPIO2C2_LCDC1DATA18_SMCBLSN1_HSADCDATA5_NAME, GPIO2C_GPIO2C2);//jacky_test
+		rk30_mux_api_set(GPIO2C2_LCDC1DATA18_SMCBLSN1_HSADCDATA5_NAME, GPIO2C_GPIO2C2);/* jacky_test */
 		gpio_request(GPIO_WIFI_IRQ, "oob_irq");
 		gpio_direction_input(GPIO_WIFI_IRQ);
 
 		oob_irq = gpio_to_irq(GPIO_WIFI_IRQ);
 
-		DBG_8192C("%s oob_irq:%d\n", __func__, oob_irq);
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
 	}
 #endif
 	return 0;
@@ -312,33 +300,31 @@ void rtw_wifi_gpio_wlan_ctrl(int onoff)
 }
 
 #ifdef CONFIG_GPIO_API
-//this is a demo for extending GPIO pin[7] as interrupt mode
-struct net_device * rtl_net;
+/* this is a demo for extending GPIO pin[7] as interrupt mode */
+struct net_device *rtl_net;
 extern int rtw_register_gpio_interrupt(struct net_device *netdev, int gpio_num, void(*callback)(u8 level));
 extern int rtw_disable_gpio_interrupt(struct net_device *netdev, int gpio_num);
 void gpio_int(u8 is_high)
 {
-	DBG_8192C("%s level=%d\n",__func__, is_high);
+	RTW_INFO("%s level=%d\n", __func__, is_high);
 }
 int register_net_gpio_init(void)
 {
-	rtl_net = dev_get_by_name(&init_net,"wlan0");
-	if(!rtl_net)
-	{
-		DBG_871X_LEVEL(_drv_always_, "rtl_net init fail!\n");
+	rtl_net = dev_get_by_name(&init_net, "wlan0");
+	if (!rtl_net) {
+		RTW_PRINT("rtl_net init fail!\n");
 		return -1;
 	}
-	return rtw_register_gpio_interrupt(rtl_net,7, gpio_int);
+	return rtw_register_gpio_interrupt(rtl_net, 7, gpio_int);
 }
 int unregister_net_gpio_init(void)
 {
-	rtl_net = dev_get_by_name(&init_net,"wlan0");
-	if(!rtl_net)
-	{
-		DBG_871X_LEVEL(_drv_always_, "rtl_net init fail!\n");
+	rtl_net = dev_get_by_name(&init_net, "wlan0");
+	if (!rtl_net) {
+		RTW_PRINT("rtl_net init fail!\n");
 		return -1;
 	}
-	return rtw_disable_gpio_interrupt(rtl_net,7);
+	return rtw_disable_gpio_interrupt(rtl_net, 7);
 }
 #endif
 
@@ -352,4 +338,4 @@ int rtw_wifi_gpio_init(void)
 void rtw_wifi_gpio_wlan_ctrl(int onoff)
 {
 }
-#endif //CONFIG_PLATFORM_SPRD
+#endif /* CONFIG_PLATFORM_SPRD */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.c
index bfd20aa2863c..d996c49cf290 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.c
@@ -1,2120 +1,2517 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#define  _IOCTL_CFG80211_C_
-
-#include <drv_types.h>
-
-#ifdef CONFIG_IOCTL_CFG80211
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 0, 0))
-#define STATION_INFO_SIGNAL		BIT(NL80211_STA_INFO_SIGNAL)
-#define STATION_INFO_TX_BITRATE		BIT(NL80211_STA_INFO_TX_BITRATE)
-#define STATION_INFO_RX_PACKETS		BIT(NL80211_STA_INFO_RX_PACKETS)
-#define STATION_INFO_TX_PACKETS		BIT(NL80211_STA_INFO_TX_PACKETS)
-#define STATION_INFO_ASSOC_REQ_IES	0
-#endif /* Linux kernel >= 4.0.0 */
-
-#include <rtw_wifi_regd.h>
-
-#define RTW_MAX_MGMT_TX_CNT (8)
-#define RTW_MAX_MGMT_TX_MS_GAS (500)
-
-#define RTW_SCAN_IE_LEN_MAX      2304
-#define RTW_MAX_REMAIN_ON_CHANNEL_DURATION 5000 //ms
-#define RTW_MAX_NUM_PMKIDS 4
-
-#define RTW_CH_MAX_2G_CHANNEL               14      /* Max channel in 2G band */
-
-#ifdef CONFIG_WAPI_SUPPORT
-
-#ifndef WLAN_CIPHER_SUITE_SMS4
-#define WLAN_CIPHER_SUITE_SMS4          0x00147201
-#endif
-
-#ifndef WLAN_AKM_SUITE_WAPI_PSK
-#define WLAN_AKM_SUITE_WAPI_PSK         0x000FAC04
-#endif
-
-#ifndef WLAN_AKM_SUITE_WAPI_CERT
-#define WLAN_AKM_SUITE_WAPI_CERT        0x000FAC12
-#endif
-
-#ifndef NL80211_WAPI_VERSION_1
-#define NL80211_WAPI_VERSION_1          (1 << 2)
-#endif
-
-#endif
-
-#ifdef CONFIG_PLATFORM_ARM_SUN8I
-#define BUSY_TRAFFIC_SCAN_DENY_PERIOD	8000
-#else
-#define BUSY_TRAFFIC_SCAN_DENY_PERIOD	12000
-#endif
-
-static const u32 rtw_cipher_suites[] = {
-	WLAN_CIPHER_SUITE_WEP40,
-	WLAN_CIPHER_SUITE_WEP104,
-	WLAN_CIPHER_SUITE_TKIP,
-	WLAN_CIPHER_SUITE_CCMP,
-#ifdef CONFIG_WAPI_SUPPORT
-	WLAN_CIPHER_SUITE_SMS4,
-#endif // CONFIG_WAPI_SUPPORT
-#ifdef CONFIG_IEEE80211W
-	WLAN_CIPHER_SUITE_AES_CMAC,
-#endif //CONFIG_IEEE80211W
-};
-
-#define RATETAB_ENT(_rate, _rateid, _flags) \
-	{								\
-		.bitrate	= (_rate),				\
-		.hw_value	= (_rateid),				\
-		.flags		= (_flags),				\
-	}
-
-#define CHAN2G(_channel, _freq, _flags) {			\
-	.band			= IEEE80211_BAND_2GHZ,		\
-	.center_freq		= (_freq),			\
-	.hw_value		= (_channel),			\
-	.flags			= (_flags),			\
-	.max_antenna_gain	= 0,				\
-	.max_power		= 30,				\
-}
-
-#define CHAN5G(_channel, _flags) {				\
-	.band			= IEEE80211_BAND_5GHZ,		\
-	.center_freq		= 5000 + (5 * (_channel)),	\
-	.hw_value		= (_channel),			\
-	.flags			= (_flags),			\
-	.max_antenna_gain	= 0,				\
-	.max_power		= 30,				\
-}
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
-/* if wowlan is not supported, kernel generate a disconnect at each suspend
- * cf: /net/wireless/sysfs.c, so register a stub wowlan.
- * Moreover wowlan has to be enabled via a the nl80211_set_wowlan callback.
- * (from user space, e.g. iw phy0 wowlan enable)
- */
-static const struct wiphy_wowlan_support wowlan_stub = {
-	.flags = WIPHY_WOWLAN_ANY,
-	.n_patterns = 0,
-	.pattern_max_len = 0,
-	.pattern_min_len = 0,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
-	.max_pkt_offset = 0,
-#endif
-};
-#endif
-
-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),
-};
-
-
-void rtw_2g_channels_init(struct ieee80211_channel *channels)
-{
-	_rtw_memcpy((void*)channels, (void*)rtw_2ghz_channels,
-		sizeof(struct ieee80211_channel)*RTW_2G_CHANNELS_NUM
-	);
-}
-
-void rtw_5g_channels_init(struct ieee80211_channel *channels)
-{
-	_rtw_memcpy((void*)channels, (void*)rtw_5ghz_a_channels,
-		sizeof(struct ieee80211_channel)*RTW_5G_CHANNELS_NUM
-	);
-}
-
-void rtw_2g_rates_init(struct ieee80211_rate *rates)
-{
-	_rtw_memcpy(rates, rtw_g_rates,
-		sizeof(struct ieee80211_rate)*RTW_G_RATES_NUM
-	);
-}
-
-void rtw_5g_rates_init(struct ieee80211_rate *rates)
-{
-	_rtw_memcpy(rates, rtw_a_rates,
-		sizeof(struct ieee80211_rate)*RTW_A_RATES_NUM
-	);
-}
-
-struct ieee80211_supported_band *rtw_spt_band_alloc(
-	enum ieee80211_band band
-	)
-{
-	struct ieee80211_supported_band *spt_band = NULL;
-	int n_channels, n_bitrates;
-
-	if(band == IEEE80211_BAND_2GHZ)
-	{
-		n_channels = RTW_2G_CHANNELS_NUM;
-		n_bitrates = RTW_G_RATES_NUM;
-	}
-	else if(band == IEEE80211_BAND_5GHZ)
-	{
-		n_channels = RTW_5G_CHANNELS_NUM;
-		n_bitrates = RTW_A_RATES_NUM;
-	}
-	else
-	{
-		goto exit;
-	}
-
-	spt_band = (struct ieee80211_supported_band *)rtw_zmalloc(
-		sizeof(struct ieee80211_supported_band)
-		+ sizeof(struct ieee80211_channel)*n_channels
-		+ sizeof(struct ieee80211_rate)*n_bitrates
-	);
-	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 == IEEE80211_BAND_2GHZ)
-	{
-		rtw_2g_channels_init(spt_band->channels);
-		rtw_2g_rates_init(spt_band->bitrates);
-	}
-	else if(band == IEEE80211_BAND_5GHZ)
-	{
-		rtw_5g_channels_init(spt_band->channels);
-		rtw_5g_rates_init(spt_band->bitrates);
-	}
-
-	//spt_band.ht_cap
-	
-exit:
-
-	return spt_band;
-}
-
-void rtw_spt_band_free(struct ieee80211_supported_band *spt_band)
-{
-	u32 size = 0;
-
-	if(!spt_band)
-		return;
-	
-	if(spt_band->band == IEEE80211_BAND_2GHZ)
-	{
-		size = sizeof(struct ieee80211_supported_band)
-			+ sizeof(struct ieee80211_channel)*RTW_2G_CHANNELS_NUM
-			+ sizeof(struct ieee80211_rate)*RTW_G_RATES_NUM;
-	}
-	else if(spt_band->band == IEEE80211_BAND_5GHZ)
-	{
-		size = sizeof(struct ieee80211_supported_band)
-			+ sizeof(struct ieee80211_channel)*RTW_5G_CHANNELS_NUM
-			+ sizeof(struct ieee80211_rate)*RTW_A_RATES_NUM;		
-	}
-	else
-	{
-		
-	}
-	rtw_mfree((u8*)spt_band, size);
-}
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-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)
-	},
-};
-#endif
-
-static u64 rtw_get_systime_us(void)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,39))
-	struct timespec ts;
-	get_monotonic_boottime(&ts);
-	return ((u64)ts.tv_sec*1000000) + ts.tv_nsec / 1000;
-#else
-	struct timeval tv;
-	do_gettimeofday(&tv);
-	return ((u64)tv.tv_sec*1000000) + tv.tv_usec;
-#endif
-}
-
-#define MAX_BSSINFO_LEN 1000
-struct cfg80211_bss *rtw_cfg80211_inform_bss(_adapter *padapter, struct wlan_network *pnetwork)
-{
-	struct ieee80211_channel *notify_channel;
-	struct cfg80211_bss *bss = NULL;
-	//struct ieee80211_supported_band *band;       
-	u16 channel;
-	u32 freq;
-	u64 notify_timestamp;
-	u16 notify_capability;
-	u16 notify_interval;
-	u8 *notify_ie;
-	size_t notify_ielen;
-	s32 notify_signal;
-	//u8 buf[MAX_BSSINFO_LEN];
-
-	u8 *pbuf;
-	size_t buf_size = MAX_BSSINFO_LEN;
-	size_t len,bssinf_len=0;
-	struct rtw_ieee80211_hdr *pwlanhdr;
-	unsigned short *fctrl;
-	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-		
-	struct wireless_dev *wdev = padapter->rtw_wdev;
-	struct wiphy *wiphy = wdev->wiphy;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-
-	pbuf = rtw_zmalloc(buf_size);
-	if(pbuf == NULL){
-		DBG_871X("%s pbuf allocate failed  !! \n",__FUNCTION__);
-		return bss;
-	}
-		
-	//DBG_8192C("%s\n", __func__);
-
-	bssinf_len = pnetwork->network.IELength+sizeof (struct rtw_ieee80211_hdr_3addr);
-	if(bssinf_len > buf_size){
-		DBG_871X("%s IE Length too long > %zu byte \n",__FUNCTION__,buf_size);
-		goto exit;
-	}
-
-#ifndef CONFIG_WAPI_SUPPORT
-	{
-		u16 wapi_len = 0;
-	
-		if(rtw_get_wapi_ie(pnetwork->network.IEs, pnetwork->network.IELength, NULL, &wapi_len)>0)
-		{
-			if(wapi_len > 0)
-			{
-				DBG_871X("%s, no support wapi!\n",__FUNCTION__);
-				goto exit;
-			}	
-		}		
-	}	
-#endif //!CONFIG_WAPI_SUPPORT
-
-	//To reduce PBC Overlap rate
-	//_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-	if(adapter_wdev_data(padapter)->scan_request != NULL)
-	{
-		u8 *psr=NULL, sr = 0;
-		NDIS_802_11_SSID *pssid = &pnetwork->network.Ssid;
-		struct cfg80211_scan_request *request = adapter_wdev_data(padapter)->scan_request;
-		struct cfg80211_ssid *ssids = request->ssids;
-		u32 wpsielen=0;
-		u8 *wpsie=NULL;	
-		
-		wpsie = rtw_get_wps_ie(pnetwork->network.IEs+_FIXED_IE_LENGTH_, pnetwork->network.IELength-_FIXED_IE_LENGTH_, NULL, &wpsielen);
-		
-		if(wpsie && wpsielen>0)
-			psr = rtw_get_wps_attr_content(wpsie,  wpsielen, WPS_ATTR_SELECTED_REGISTRAR, (u8*)(&sr), NULL);
-		
-		if (sr != 0)
-		{			
-			if(request->n_ssids == 1 && request->n_channels == 1) // it means under processing WPS
-			{
-				DBG_8192C("ssid=%s, len=%d\n", pssid->Ssid, pssid->SsidLength);
-
-				if (ssids[0].ssid_len == 0) {
-				}
-				else if(pssid->SsidLength == ssids[0].ssid_len &&
-					_rtw_memcmp(pssid->Ssid, ssids[0].ssid, ssids[0].ssid_len))
-				{
-					DBG_871X("%s, got sr and ssid match!\n", __func__);
-				}
-				else
-				{
-					if(psr !=NULL)
-						*psr = 0; //clear sr
-				
-#if 0			
-					WLAN_BSSID_EX  *pselect_network = &pnetwork->network;
-					struct cfg80211_bss *pselect_bss = NULL;
-					struct ieee80211_channel *notify_channel = NULL;
-					u32 freq;
-
-					DBG_871X("%s, got sr, but ssid mismatch, to remove this bss\n", __func__);
-
-					freq = rtw_ch2freq(pselect_network->Configuration.DSConfig);
-					notify_channel = ieee80211_get_channel(wiphy, freq);
-					pselect_bss = cfg80211_get_bss(wiphy, NULL/*notify_channel*/,
-								pselect_network->MacAddress, pselect_network->Ssid.Ssid,
-								pselect_network->Ssid.SsidLength, 0/*WLAN_CAPABILITY_ESS*/, 
-								0/*WLAN_CAPABILITY_ESS*/);
-
-					if(pselect_bss)
-					{
-						DBG_871X("%s, got bss for cfg80211 for unlinking bss\n", __func__);
-
-						cfg80211_unlink_bss(wiphy, pselect_bss);
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
-						cfg80211_put_bss(wiphy, pselect_bss);
-#else
-						cfg80211_put_bss(pselect_bss);
-#endif
-						
-					}
-					
-					goto exit;
-#endif 					
-				}			
-			}			
-		}		
-	}
-	//_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-	
-
-	channel = pnetwork->network.Configuration.DSConfig;
-	freq = rtw_ch2freq(channel);
-	notify_channel = ieee80211_get_channel(wiphy, freq);
-
-	if (0)
-		notify_timestamp = le64_to_cpu(*(u64*)rtw_get_timestampe_from_ie(pnetwork->network.IEs));
-	else
-		notify_timestamp = rtw_get_systime_us();
-
-	notify_interval = le16_to_cpu(*(u16*)rtw_get_beacon_interval_from_ie(pnetwork->network.IEs));
-	notify_capability = le16_to_cpu(*(u16*)rtw_get_capability_from_ie(pnetwork->network.IEs));		
-
-	notify_ie = pnetwork->network.IEs+_FIXED_IE_LENGTH_;
-	notify_ielen = pnetwork->network.IELength-_FIXED_IE_LENGTH_;
-
-	//We've set wiphy's signal_type as CFG80211_SIGNAL_TYPE_MBM: signal strength in mBm (100*dBm)
-	if ( check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE &&
-		is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
-		notify_signal = 100*translate_percentage_to_dbm(padapter->recvpriv.signal_strength);//dbm
-	} else {
-		notify_signal = 100*translate_percentage_to_dbm(pnetwork->network.PhyInfo.SignalStrength);//dbm
-	}
-		
-	#if 0
-	DBG_8192C("bssid: "MAC_FMT"\n", MAC_ARG(pnetwork->network.MacAddress));
-	DBG_8192C("Channel: %d(%d)\n", channel, freq);
-	DBG_8192C("Capability: %X\n", notify_capability);
-	DBG_8192C("Beacon interval: %d\n", notify_interval);
-	DBG_8192C("Signal: %d\n", notify_signal);
-	DBG_8192C("notify_timestamp: %llu\n", notify_timestamp);
-	#endif
-
-	//pbuf = buf;
-	
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pbuf;	
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;	
-
-	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
-	//pmlmeext->mgnt_seq++;
-
-	if (pnetwork->network.Reserved[0] == 1) { // WIFI_BEACON
-		_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);		
-		SetFrameSubType(pbuf, WIFI_BEACON);
-	} else {
-		_rtw_memcpy(pwlanhdr->addr1, adapter_mac_addr(padapter), ETH_ALEN);
-		SetFrameSubType(pbuf, WIFI_PROBERSP);
-	}
-
-	_rtw_memcpy(pwlanhdr->addr2, pnetwork->network.MacAddress, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, pnetwork->network.MacAddress, ETH_ALEN);
-
-
-	//pbuf += sizeof(struct rtw_ieee80211_hdr_3addr);
-	len = sizeof (struct rtw_ieee80211_hdr_3addr);
-	_rtw_memcpy((pbuf+len), pnetwork->network.IEs, pnetwork->network.IELength);
-	*((u64*)(pbuf+len)) = cpu_to_le64(notify_timestamp);
-	
-	len += pnetwork->network.IELength;	
-
-	//#ifdef CONFIG_P2P
-	//if(rtw_get_p2p_ie(pnetwork->network.IEs+12, pnetwork->network.IELength-12, NULL, NULL))
-	//{
-	//	DBG_8192C("%s, got p2p_ie\n", __func__);
-	//}
-	//#endif
-
-#if 1	
-	bss = cfg80211_inform_bss_frame(wiphy, notify_channel, (struct ieee80211_mgmt *)pbuf,
-		len, notify_signal, GFP_ATOMIC);
-#else			 
-			
-	bss = cfg80211_inform_bss(wiphy, notify_channel, (const u8 *)pnetwork->network.MacAddress,
-                notify_timestamp, notify_capability, notify_interval, notify_ie,
-                notify_ielen, notify_signal, GFP_ATOMIC/*GFP_KERNEL*/);
-#endif
-
-	if (unlikely(!bss)) {
-		DBG_8192C(FUNC_ADPT_FMT" bss NULL\n", FUNC_ADPT_ARG(padapter));
-		goto exit;
-	}
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,38))
-#ifndef COMPAT_KERNEL_RELEASE
-	//patch for cfg80211, update beacon ies to information_elements
-	if (pnetwork->network.Reserved[0] == 1) { // WIFI_BEACON
-	
-		 if(bss->len_information_elements != bss->len_beacon_ies)
-		 {
-			bss->information_elements = bss->beacon_ies;			
-			bss->len_information_elements =  bss->len_beacon_ies;
-		 }		
-	}
-#endif //COMPAT_KERNEL_RELEASE
-#endif //LINUX_VERSION_CODE < KERNEL_VERSION(2,6,38)
-
-/*	
-	{
-		if( bss->information_elements == bss->proberesp_ies) 
-		{
-			if( bss->len_information_elements !=  bss->len_proberesp_ies)
-			{
-				DBG_8192C("error!, len_information_elements !=  bss->len_proberesp_ies\n");
-			}
-							
-		}
-		else if(bss->len_information_elements <  bss->len_beacon_ies)
-		{
-			bss->information_elements = bss->beacon_ies;			
-			bss->len_information_elements =  bss->len_beacon_ies;
-		}
-	}
-*/
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
-	cfg80211_put_bss(wiphy, bss);
-#else
-	cfg80211_put_bss(bss);
-#endif
-	
-exit:
-	if(pbuf)
-		rtw_mfree(pbuf, buf_size);	
-	return bss;
-	
-}
-
-/*
-	Check the given bss is valid by kernel API cfg80211_get_bss()
-	@padapter : the given adapter
-	
-	return _TRUE if bss is valid,  _FALSE for not found.
-*/
-int rtw_cfg80211_check_bss(_adapter *padapter)
-{
-	WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
-	struct cfg80211_bss *bss = NULL;
-	struct ieee80211_channel *notify_channel = NULL;
-	u32 freq;
-
-	if (!(pnetwork) || !(padapter->rtw_wdev))
-		return _FALSE;
-
-	freq = rtw_ch2freq(pnetwork->Configuration.DSConfig);
-	notify_channel = ieee80211_get_channel(padapter->rtw_wdev->wiphy, freq);
-	bss = cfg80211_get_bss(padapter->rtw_wdev->wiphy, notify_channel,
-			pnetwork->MacAddress, pnetwork->Ssid.Ssid,
-			pnetwork->Ssid.SsidLength,
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <drv_types.h>
+#include <hal_data.h>
+
+#ifdef CONFIG_IOCTL_CFG80211
+
+#ifndef DBG_RTW_CFG80211_STA_PARAM
+#define DBG_RTW_CFG80211_STA_PARAM 0
+#endif
+
+#ifndef DBG_RTW_CFG80211_MESH_CONF
+#define DBG_RTW_CFG80211_MESH_CONF 0
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 0, 0))
+#define STATION_INFO_INACTIVE_TIME	BIT(NL80211_STA_INFO_INACTIVE_TIME)
+#define STATION_INFO_LLID			BIT(NL80211_STA_INFO_LLID)
+#define STATION_INFO_PLID			BIT(NL80211_STA_INFO_PLID)
+#define STATION_INFO_PLINK_STATE	BIT(NL80211_STA_INFO_PLINK_STATE)
+#define STATION_INFO_SIGNAL			BIT(NL80211_STA_INFO_SIGNAL)
+#define STATION_INFO_TX_BITRATE		BIT(NL80211_STA_INFO_TX_BITRATE)
+#define STATION_INFO_RX_PACKETS		BIT(NL80211_STA_INFO_RX_PACKETS)
+#define STATION_INFO_TX_PACKETS		BIT(NL80211_STA_INFO_TX_PACKETS)
+#define STATION_INFO_TX_FAILED		BIT(NL80211_STA_INFO_TX_FAILED)
+#define STATION_INFO_LOCAL_PM		BIT(NL80211_STA_INFO_LOCAL_PM)
+#define STATION_INFO_PEER_PM		BIT(NL80211_STA_INFO_PEER_PM)
+#define STATION_INFO_NONPEER_PM		BIT(NL80211_STA_INFO_NONPEER_PM)
+#define STATION_INFO_ASSOC_REQ_IES	0
+#endif /* Linux kernel >= 4.0.0 */
+
+#include <rtw_wifi_regd.h>
+
+#define RTW_MAX_MGMT_TX_CNT (8)
+#define RTW_MAX_MGMT_TX_MS_GAS (500)
+
+#define RTW_SCAN_IE_LEN_MAX      2304
+#define RTW_MAX_REMAIN_ON_CHANNEL_DURATION 5000 /* ms */
+#define RTW_MAX_NUM_PMKIDS 4
+
+#define RTW_CH_MAX_2G_CHANNEL               14      /* Max channel in 2G band */
+
+#ifdef CONFIG_WAPI_SUPPORT
+
+#ifndef WLAN_CIPHER_SUITE_SMS4
+#define WLAN_CIPHER_SUITE_SMS4          0x00147201
+#endif
+
+#ifndef WLAN_AKM_SUITE_WAPI_PSK
+#define WLAN_AKM_SUITE_WAPI_PSK         0x000FAC04
+#endif
+
+#ifndef WLAN_AKM_SUITE_WAPI_CERT
+#define WLAN_AKM_SUITE_WAPI_CERT        0x000FAC12
+#endif
+
+#ifndef NL80211_WAPI_VERSION_1
+#define NL80211_WAPI_VERSION_1          (1 << 2)
+#endif
+
+#endif /* CONFIG_WAPI_SUPPORT */
+
+#ifdef CONFIG_RTW_80211R
+#define WLAN_AKM_SUITE_FT_8021X		0x000FAC03
+#define WLAN_AKM_SUITE_FT_PSK			0x000FAC04
+#endif
+
+/*
+ * In the current design of Wi-Fi driver, it will return success to the system (e.g. supplicant) 
+ * when Wi-Fi driver decides to abort the scan request in the scan flow by default.
+ * Defining this flag makes Wi-Fi driver to return -EBUSY to the system if Wi-Fi driver is too busy to do the scan.
+ */
+#ifndef CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY
+	#define CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY 0
+#endif
+
+static const u32 rtw_cipher_suites[] = {
+	WLAN_CIPHER_SUITE_WEP40,
+	WLAN_CIPHER_SUITE_WEP104,
+	WLAN_CIPHER_SUITE_TKIP,
+	WLAN_CIPHER_SUITE_CCMP,
+#ifdef CONFIG_WAPI_SUPPORT
+	WLAN_CIPHER_SUITE_SMS4,
+#endif /* CONFIG_WAPI_SUPPORT */
+#ifdef CONFIG_IEEE80211W
+	WLAN_CIPHER_SUITE_AES_CMAC,
+#endif /* CONFIG_IEEE80211W */
+};
+
+#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,				\
+	}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+/* if wowlan is not supported, kernel generate a disconnect at each suspend
+ * cf: /net/wireless/sysfs.c, so register a stub wowlan.
+ * Moreover wowlan has to be enabled via a the nl80211_set_wowlan callback.
+ * (from user space, e.g. iw phy0 wowlan enable)
+ */
+static const struct wiphy_wowlan_support wowlan_stub = {
+	.flags = WIPHY_WOWLAN_ANY,
+	.n_patterns = 0,
+	.pattern_max_len = 0,
+	.pattern_min_len = 0,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	.max_pkt_offset = 0,
+#endif
+};
+#endif
+
+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
+
+/* from center_ch_2g */
+static struct ieee80211_channel rtw_2ghz_channels[MAX_CHANNEL_NUM_2G] = {
+	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),
+};
+
+/* from center_ch_5g_20m */
+static struct ieee80211_channel rtw_5ghz_a_channels[MAX_CHANNEL_NUM_5G] = {
+	CHAN5G(36, 0),	CHAN5G(40, 0),	CHAN5G(44, 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(144, 0),
+
+	CHAN5G(149, 0),	CHAN5G(153, 0),	CHAN5G(157, 0),	CHAN5G(161, 0),
+	CHAN5G(165, 0),	CHAN5G(169, 0),	CHAN5G(173, 0),	CHAN5G(177, 0),
+};
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+static const char *nl80211_channel_type_str(enum nl80211_channel_type ctype)
+{
+	switch (ctype) {
+	case NL80211_CHAN_NO_HT:
+		return "NO_HT";
+	case NL80211_CHAN_HT20:
+		return "HT20";
+	case NL80211_CHAN_HT40MINUS:
+		return "HT40-";
+	case NL80211_CHAN_HT40PLUS:
+		return "HT40+";
+	default:
+		return "INVALID";
+	};
+}
+
+static enum nl80211_channel_type rtw_chbw_to_nl80211_channel_type(u8 ch, u8 bw, u8 offset, u8 ht)
+{
+	rtw_warn_on(!ht && (bw >= CHANNEL_WIDTH_40 || offset != HAL_PRIME_CHNL_OFFSET_DONT_CARE));
+
+	if (!ht)
+		return NL80211_CHAN_NO_HT;
+	if (bw >= CHANNEL_WIDTH_40) {
+		if (offset == HAL_PRIME_CHNL_OFFSET_UPPER)
+			return NL80211_CHAN_HT40MINUS;
+		else if (offset == HAL_PRIME_CHNL_OFFSET_LOWER)
+			return NL80211_CHAN_HT40PLUS;
+		else
+			rtw_warn_on(1);
+	}
+	return NL80211_CHAN_HT20;
+}
+
+static void rtw_get_chbw_from_nl80211_channel_type(struct ieee80211_channel *chan, enum nl80211_channel_type ctype, u8 *ht, u8 *ch, u8 *bw, u8 *offset)
+{
+	int pri_freq;
+
+	pri_freq = rtw_ch2freq(chan->hw_value);
+	if (!pri_freq) {
+		RTW_INFO("invalid channel:%d\n", chan->hw_value);
+		rtw_warn_on(1);
+		*ch = 0;
+		return;
+	}
+	*ch = chan->hw_value;
+
+	switch (ctype) {
+	case NL80211_CHAN_NO_HT:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT20:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT40MINUS:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_40;
+		*offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_HT40PLUS:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_40;
+		*offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+	default:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		RTW_INFO("unsupported ctype:%s\n", nl80211_channel_type_str(ctype));
+		rtw_warn_on(1);
+	};
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29)) */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+static const char *nl80211_chan_width_str(enum nl80211_chan_width cwidth)
+{
+	switch (cwidth) {
+	case NL80211_CHAN_WIDTH_20_NOHT:
+		return "20_NOHT";
+	case NL80211_CHAN_WIDTH_20:
+		return "20";
+	case NL80211_CHAN_WIDTH_40:
+		return "40";
+	case NL80211_CHAN_WIDTH_80:
+		return "80";
+	case NL80211_CHAN_WIDTH_80P80:
+		return "80+80";
+	case NL80211_CHAN_WIDTH_160:
+		return "160";
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	case NL80211_CHAN_WIDTH_5:
+		return "5";
+	case NL80211_CHAN_WIDTH_10:
+		return "10";
+#endif
+	default:
+		return "INVALID";
+	};
+}
+
+static u8 rtw_chbw_to_cfg80211_chan_def(struct wiphy *wiphy, struct cfg80211_chan_def *chdef, u8 ch, u8 bw, u8 offset, u8 ht)
+{
+	int freq, cfreq;
+	struct ieee80211_channel *chan;
+	u8 ret = _FAIL;
+
+	freq = rtw_ch2freq(ch);
+	if (!freq)
+		goto exit;
+
+	cfreq = rtw_get_center_ch(ch, bw, offset);
+	if (!cfreq)
+		goto exit;
+	cfreq = rtw_ch2freq(cfreq);
+	if (!cfreq)
+		goto exit;
+
+	chan = ieee80211_get_channel(wiphy, freq);
+	if (!chan)
+		goto exit;
+
+	if (bw == CHANNEL_WIDTH_20) 
+		chdef->width = ht ? NL80211_CHAN_WIDTH_20 : NL80211_CHAN_WIDTH_20_NOHT;
+	else if (bw == CHANNEL_WIDTH_40)
+		chdef->width = NL80211_CHAN_WIDTH_40;
+	else if (bw == CHANNEL_WIDTH_80)
+		chdef->width = NL80211_CHAN_WIDTH_80;
+	else if (bw == CHANNEL_WIDTH_160)
+		chdef->width = NL80211_CHAN_WIDTH_160;
+	else {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	chdef->chan = chan;
+	chdef->center_freq1 = cfreq;
+	chdef->center_freq2 = 0;
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+static void rtw_get_chbw_from_cfg80211_chan_def(struct cfg80211_chan_def *chdef, u8 *ht, u8 *ch, u8 *bw, u8 *offset)
+{
+	int pri_freq;
+	struct ieee80211_channel *chan = chdef->chan;
+
+	pri_freq = rtw_ch2freq(chan->hw_value);
+	if (!pri_freq) {
+		RTW_INFO("invalid channel:%d\n", chan->hw_value);
+		rtw_warn_on(1);
+		*ch = 0;
+		return;
+	}		
+
+	switch (chdef->width) {
+	case NL80211_CHAN_WIDTH_20_NOHT:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_20:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_40:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_40;
+		*offset = pri_freq > chdef->center_freq1 ? HAL_PRIME_CHNL_OFFSET_UPPER : HAL_PRIME_CHNL_OFFSET_LOWER;
+		if (rtw_get_offset_by_chbw(chan->hw_value, *bw, offset))
+			*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_80:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_80;
+		if (rtw_get_offset_by_chbw(chan->hw_value, *bw, offset))
+			*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_160:
+		*ht = 1;
+		*bw = CHANNEL_WIDTH_160;
+		if (rtw_get_offset_by_chbw(chan->hw_value, *bw, offset))
+			*ch = chan->hw_value;
+		break;
+	case NL80211_CHAN_WIDTH_80P80:
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	case NL80211_CHAN_WIDTH_5:
+	case NL80211_CHAN_WIDTH_10:
+	#endif
+	default:
+		*ht = 0;
+		*bw = CHANNEL_WIDTH_20;
+		*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		RTW_INFO("unsupported cwidth:%s\n", nl80211_chan_width_str(chdef->width));
+		rtw_warn_on(1);
+	};
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)) */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+u8 rtw_cfg80211_ch_switch_notify(_adapter *adapter, u8 ch, u8 bw, u8 offset, u8 ht)
+{
+	struct wiphy *wiphy = adapter_to_wiphy(adapter);
+	u8 ret = _SUCCESS;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def chdef;
+
+	ret = rtw_chbw_to_cfg80211_chan_def(wiphy, &chdef, ch, bw, offset, ht);
+	if (ret != _SUCCESS)
+		goto exit;
+
+	cfg80211_ch_switch_notify(adapter->pnetdev, &chdef);
+
+#else
+	int freq = rtw_ch2freq(ch);
+	enum nl80211_channel_type ctype;
+
+	if (!freq) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+	ctype = rtw_chbw_to_nl80211_channel_type(ch, bw, offset, ht);
+	cfg80211_ch_switch_notify(adapter->pnetdev, freq, ctype);
+#endif
+
+exit:
+	return ret;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0)) */
+
+void rtw_2g_channels_init(struct ieee80211_channel *channels)
+{
+	_rtw_memcpy((void *)channels, (void *)rtw_2ghz_channels, sizeof(rtw_2ghz_channels));
+}
+
+void rtw_5g_channels_init(struct ieee80211_channel *channels)
+{
+	_rtw_memcpy((void *)channels, (void *)rtw_5ghz_a_channels, sizeof(rtw_5ghz_a_channels));
+}
+
+void rtw_2g_rates_init(struct ieee80211_rate *rates)
+{
+	_rtw_memcpy(rates, rtw_g_rates,
+		sizeof(struct ieee80211_rate) * RTW_G_RATES_NUM
+	);
+}
+
+void rtw_5g_rates_init(struct ieee80211_rate *rates)
+{
+	_rtw_memcpy(rates, rtw_a_rates,
+		sizeof(struct ieee80211_rate) * RTW_A_RATES_NUM
+	);
+}
+
+struct ieee80211_supported_band *rtw_spt_band_alloc(BAND_TYPE band)
+{
+	struct ieee80211_supported_band *spt_band = NULL;
+	int n_channels, n_bitrates;
+
+	if (band == BAND_ON_2_4G) {
+		n_channels = MAX_CHANNEL_NUM_2G;
+		n_bitrates = RTW_G_RATES_NUM;
+	} else if (band == BAND_ON_5G) {
+		n_channels = MAX_CHANNEL_NUM_5G;
+		n_bitrates = RTW_A_RATES_NUM;
+	} else
+		goto exit;
+
+	spt_band = (struct ieee80211_supported_band *)rtw_zmalloc(
+		sizeof(struct ieee80211_supported_band)
+		+ sizeof(struct ieee80211_channel) * n_channels
+		+ sizeof(struct ieee80211_rate) * n_bitrates
+	);
+	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 = rtw_band_to_nl80211_band(band);
+	spt_band->n_channels = n_channels;
+	spt_band->n_bitrates = n_bitrates;
+
+	if (band == BAND_ON_2_4G) {
+		rtw_2g_channels_init(spt_band->channels);
+		rtw_2g_rates_init(spt_band->bitrates);
+	} else if (band == BAND_ON_5G) {
+		rtw_5g_channels_init(spt_band->channels);
+		rtw_5g_rates_init(spt_band->bitrates);
+	}
+
+	/* spt_band.ht_cap */
+
+exit:
+
+	return spt_band;
+}
+
+void rtw_spt_band_free(struct ieee80211_supported_band *spt_band)
+{
+	u32 size = 0;
+
+	if (!spt_band)
+		return;
+
+	if (spt_band->band == NL80211_BAND_2GHZ) {
+		size = sizeof(struct ieee80211_supported_band)
+			+ sizeof(struct ieee80211_channel) * MAX_CHANNEL_NUM_2G
+			+ sizeof(struct ieee80211_rate) * RTW_G_RATES_NUM;
+	} else if (spt_band->band == NL80211_BAND_5GHZ) {
+		size = sizeof(struct ieee80211_supported_band)
+			+ sizeof(struct ieee80211_channel) * MAX_CHANNEL_NUM_5G
+			+ sizeof(struct ieee80211_rate) * RTW_A_RATES_NUM;
+	} else {
+
+	}
+	rtw_mfree((u8 *)spt_band, size);
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+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)
+	},
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+	[NL80211_IFTYPE_P2P_DEVICE] = {
+		.tx = 0xffff,
+		.rx = BIT(IEEE80211_STYPE_ACTION >> 4) |
+			BIT(IEEE80211_STYPE_PROBE_REQ >> 4)
+	},
+#endif
+#if defined(CONFIG_RTW_MESH)
+	[NL80211_IFTYPE_MESH_POINT] = {
+		.tx = 0xffff,
+		.rx = BIT(IEEE80211_STYPE_ACTION >> 4)
+			| BIT(IEEE80211_STYPE_AUTH >> 4)
+	},
+#endif
+
+};
+#endif
+
+NDIS_802_11_NETWORK_INFRASTRUCTURE nl80211_iftype_to_rtw_network_type(enum nl80211_iftype type)
+{
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		return Ndis802_11IBSS;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	#endif
+	case NL80211_IFTYPE_STATION:
+		return Ndis802_11Infrastructure;
+
+#ifdef CONFIG_AP_MODE
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+	#endif
+	case NL80211_IFTYPE_AP:
+		return Ndis802_11APMode;
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		return Ndis802_11_mesh;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		return Ndis802_11Monitor;
+
+	default:
+		return Ndis802_11InfrastructureMax;
+	}
+}
+
+u32 nl80211_iftype_to_rtw_mlme_state(enum nl80211_iftype type)
+{
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		return WIFI_ADHOC_STATE;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	#endif
+	case NL80211_IFTYPE_STATION:
+		return WIFI_STATION_STATE;
+
+#ifdef CONFIG_AP_MODE
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+	#endif
+	case NL80211_IFTYPE_AP:
+		return WIFI_AP_STATE;
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		return WIFI_MESH_STATE;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		return WIFI_MONITOR_STATE;
+
+	default:
+		return WIFI_NULL_STATE;
+	}
+}
+
+static int rtw_cfg80211_sync_iftype(_adapter *adapter)
+{
+	struct wireless_dev *rtw_wdev = adapter->rtw_wdev;
+
+	if (!(nl80211_iftype_to_rtw_mlme_state(rtw_wdev->iftype) & MLME_STATE(adapter))) {
+		/* iftype and mlme state is not syc */
+		NDIS_802_11_NETWORK_INFRASTRUCTURE network_type;
+
+		network_type = nl80211_iftype_to_rtw_network_type(rtw_wdev->iftype);
+		if (network_type != Ndis802_11InfrastructureMax) {
+			if (rtw_pwr_wakeup(adapter) == _FAIL) {
+				RTW_WARN(FUNC_ADPT_FMT" call rtw_pwr_wakeup fail\n", FUNC_ADPT_ARG(adapter));
+				return _FAIL;
+			}
+
+			rtw_set_802_11_infrastructure_mode(adapter, network_type);
+			rtw_setopmode_cmd(adapter, network_type, RTW_CMDF_WAIT_ACK);
+		} else {
+			rtw_warn_on(1);
+			RTW_WARN(FUNC_ADPT_FMT" iftype:%u is not support\n", FUNC_ADPT_ARG(adapter), rtw_wdev->iftype);
+			return _FAIL;
+		}
+	}
+
+	return _SUCCESS;
+}
+
+static u64 rtw_get_systime_us(void)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39))
+	struct timespec ts;
+	get_monotonic_boottime(&ts);
+	return ((u64)ts.tv_sec * 1000000) + ts.tv_nsec / 1000;
+#else
+	struct timeval tv;
+	do_gettimeofday(&tv);
+	return ((u64)tv.tv_sec * 1000000) + tv.tv_usec;
+#endif
+}
+
+/* Try to remove non target BSS's SR to reduce PBC overlap rate */
+static int rtw_cfg80211_clear_wps_sr_of_non_target_bss(_adapter *padapter, struct wlan_network *pnetwork, struct cfg80211_ssid *req_ssid)
+{
+	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(padapter);
+	int ret = 0;
+	u8 *psr = NULL, sr = 0;
+	NDIS_802_11_SSID *pssid = &pnetwork->network.Ssid;
+	u32 wpsielen = 0;
+	u8 *wpsie = NULL;
+
+	if (pssid->SsidLength == req_ssid->ssid_len
+		&& _rtw_memcmp(pssid->Ssid, req_ssid->ssid, req_ssid->ssid_len) == _TRUE)
+		goto exit;
+
+	wpsie = rtw_get_wps_ie(pnetwork->network.IEs + _FIXED_IE_LENGTH_
+		, pnetwork->network.IELength - _FIXED_IE_LENGTH_, NULL, &wpsielen);
+	if (wpsie && wpsielen > 0)
+		psr = rtw_get_wps_attr_content(wpsie, wpsielen, WPS_ATTR_SELECTED_REGISTRAR, &sr, NULL);
+
+	if (psr && sr) {
+		if (0)
+			RTW_INFO("clear sr of non target bss:%s("MAC_FMT")\n"
+				, pssid->Ssid, MAC_ARG(pnetwork->network.MacAddress));
+		*psr = 0; /* clear sr */
+		ret = 1;
+	}
+
+exit:
+	return ret;
+}
+
+#define MAX_BSSINFO_LEN 1000
+struct cfg80211_bss *rtw_cfg80211_inform_bss(_adapter *padapter, struct wlan_network *pnetwork)
+{
+	struct ieee80211_channel *notify_channel;
+	struct cfg80211_bss *bss = NULL;
+	/* struct ieee80211_supported_band *band;       */
+	u16 channel;
+	u32 freq;
+	u64 notify_timestamp;
+	u16 notify_capability;
+	u16 notify_interval;
+	u8 *notify_ie;
+	size_t notify_ielen;
+	s32 notify_signal;
+	/* u8 buf[MAX_BSSINFO_LEN]; */
+
+	u8 *pbuf;
+	size_t buf_size = MAX_BSSINFO_LEN;
+	size_t len, bssinf_len = 0;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	unsigned short *fctrl;
+	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+	struct wireless_dev *wdev = padapter->rtw_wdev;
+	struct wiphy *wiphy = wdev->wiphy;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	pbuf = rtw_zmalloc(buf_size);
+	if (pbuf == NULL) {
+		RTW_INFO("%s pbuf allocate failed  !!\n", __FUNCTION__);
+		return bss;
+	}
+
+	/* RTW_INFO("%s\n", __func__); */
+
+	bssinf_len = pnetwork->network.IELength + sizeof(struct rtw_ieee80211_hdr_3addr);
+	if (bssinf_len > buf_size) {
+		RTW_INFO("%s IE Length too long > %zu byte\n", __FUNCTION__, buf_size);
+		goto exit;
+	}
+
+#ifndef CONFIG_WAPI_SUPPORT
+	{
+		u16 wapi_len = 0;
+
+		if (rtw_get_wapi_ie(pnetwork->network.IEs, pnetwork->network.IELength, NULL, &wapi_len) > 0) {
+			if (wapi_len > 0) {
+				RTW_INFO("%s, no support wapi!\n", __FUNCTION__);
+				goto exit;
+			}
+		}
+	}
+#endif /* !CONFIG_WAPI_SUPPORT */
+
+	channel = pnetwork->network.Configuration.DSConfig;
+	freq = rtw_ch2freq(channel);
+	notify_channel = ieee80211_get_channel(wiphy, freq);
+
+	if (0)
+		notify_timestamp = le64_to_cpu(*(u64 *)rtw_get_timestampe_from_ie(pnetwork->network.IEs));
+	else
+		notify_timestamp = rtw_get_systime_us();
+
+	notify_interval = le16_to_cpu(*(u16 *)rtw_get_beacon_interval_from_ie(pnetwork->network.IEs));
+	notify_capability = le16_to_cpu(*(u16 *)rtw_get_capability_from_ie(pnetwork->network.IEs));
+
+	notify_ie = pnetwork->network.IEs + _FIXED_IE_LENGTH_;
+	notify_ielen = pnetwork->network.IELength - _FIXED_IE_LENGTH_;
+
+	/* We've set wiphy's signal_type as CFG80211_SIGNAL_TYPE_MBM: signal strength in mBm (100*dBm) */
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
+		is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
+		notify_signal = 100 * translate_percentage_to_dbm(padapter->recvpriv.signal_strength); /* dbm */
+	} else {
+		notify_signal = 100 * translate_percentage_to_dbm(pnetwork->network.PhyInfo.SignalStrength); /* dbm */
+	}
+
+#if 0
+	RTW_INFO("bssid: "MAC_FMT"\n", MAC_ARG(pnetwork->network.MacAddress));
+	RTW_INFO("Channel: %d(%d)\n", channel, freq);
+	RTW_INFO("Capability: %X\n", notify_capability);
+	RTW_INFO("Beacon interval: %d\n", notify_interval);
+	RTW_INFO("Signal: %d\n", notify_signal);
+	RTW_INFO("notify_timestamp: %llu\n", notify_timestamp);
+#endif
+
+	/* pbuf = buf; */
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pbuf;
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
+	/* pmlmeext->mgnt_seq++; */
+
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_BCN) { /* WIFI_BEACON */
+		_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
+		set_frame_sub_type(pbuf, WIFI_BEACON);
+	} else {
+		_rtw_memcpy(pwlanhdr->addr1, adapter_mac_addr(padapter), ETH_ALEN);
+		set_frame_sub_type(pbuf, WIFI_PROBERSP);
+	}
+
+	_rtw_memcpy(pwlanhdr->addr2, pnetwork->network.MacAddress, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, pnetwork->network.MacAddress, ETH_ALEN);
+
+
+	/* pbuf += sizeof(struct rtw_ieee80211_hdr_3addr); */
+	len = sizeof(struct rtw_ieee80211_hdr_3addr);
+	_rtw_memcpy((pbuf + len), pnetwork->network.IEs, pnetwork->network.IELength);
+	*((u64 *)(pbuf + len)) = cpu_to_le64(notify_timestamp);
+
+	len += pnetwork->network.IELength;
+
+	#if defined(CONFIG_P2P) && 0
+	if(rtw_get_p2p_ie(pnetwork->network.IEs+12, pnetwork->network.IELength-12, NULL, NULL))
+		RTW_INFO("%s, got p2p_ie\n", __func__);
+	#endif
+
+#if 1
+	bss = cfg80211_inform_bss_frame(wiphy, notify_channel, (struct ieee80211_mgmt *)pbuf,
+					len, notify_signal, GFP_ATOMIC);
+#else
+
+	bss = cfg80211_inform_bss(wiphy, notify_channel, (const u8 *)pnetwork->network.MacAddress,
+		notify_timestamp, notify_capability, notify_interval, notify_ie,
+		notify_ielen, notify_signal, GFP_ATOMIC/*GFP_KERNEL*/);
+#endif
+
+	if (unlikely(!bss)) {
+		RTW_INFO(FUNC_ADPT_FMT" bss NULL\n", FUNC_ADPT_ARG(padapter));
+		goto exit;
+	}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 38))
+#ifndef COMPAT_KERNEL_RELEASE
+	/* patch for cfg80211, update beacon ies to information_elements */
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_BCN) { /* WIFI_BEACON */
+
+		if (bss->len_information_elements != bss->len_beacon_ies) {
+			bss->information_elements = bss->beacon_ies;
+			bss->len_information_elements =  bss->len_beacon_ies;
+		}
+	}
+#endif /* COMPAT_KERNEL_RELEASE */
+#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 38) */
+
+#if 0
+	{
+		if (bss->information_elements == bss->proberesp_ies) {
+			if (bss->len_information_elements !=  bss->len_proberesp_ies)
+				RTW_INFO("error!, len_information_elements != bss->len_proberesp_ies\n");
+		} else if (bss->len_information_elements <  bss->len_beacon_ies) {
+			bss->information_elements = bss->beacon_ies;
+			bss->len_information_elements =  bss->len_beacon_ies;
+		}
+	}
+#endif
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
+	cfg80211_put_bss(wiphy, bss);
+#else
+	cfg80211_put_bss(bss);
+#endif
+
+exit:
+	if (pbuf)
+		rtw_mfree(pbuf, buf_size);
+	return bss;
+
+}
+
+/*
+	Check the given bss is valid by kernel API cfg80211_get_bss()
+	@padapter : the given adapter
+
+	return _TRUE if bss is valid,  _FALSE for not found.
+*/
+int rtw_cfg80211_check_bss(_adapter *padapter)
+{
+	WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
+	struct cfg80211_bss *bss = NULL;
+	struct ieee80211_channel *notify_channel = NULL;
+	u32 freq;
+
+	if (!(pnetwork) || !(padapter->rtw_wdev))
+		return _FALSE;
+
+	freq = rtw_ch2freq(pnetwork->Configuration.DSConfig);
+	notify_channel = ieee80211_get_channel(padapter->rtw_wdev->wiphy, freq);
+	bss = cfg80211_get_bss(padapter->rtw_wdev->wiphy, notify_channel,
+			pnetwork->MacAddress, pnetwork->Ssid.Ssid,
+			pnetwork->Ssid.SsidLength,
 #if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0)
 			pnetwork->InfrastructureMode == Ndis802_11Infrastructure?IEEE80211_BSS_TYPE_ESS:IEEE80211_BSS_TYPE_IBSS,
 			IEEE80211_PRIVACY(pnetwork->Privacy));
 #else
 			pnetwork->InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS, pnetwork->InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS);
 #endif
-
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
-	cfg80211_put_bss(padapter->rtw_wdev->wiphy, bss);
-#else
-	cfg80211_put_bss(bss);
-#endif
-
-	return 	(bss!=NULL);
-}
-
-void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter)
-{
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
-	struct cfg80211_bss *bss = NULL;
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
-	struct wiphy *wiphy = pwdev->wiphy;
-	int freq = 2412;
-	struct ieee80211_channel *notify_channel;
-#endif
-
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))	
-	freq = rtw_ch2freq(cur_network->network.Configuration.DSConfig);
-
-	if (0)
-		DBG_871X("chan: %d, freq: %d\n", cur_network->network.Configuration.DSConfig, freq);
-#endif
-
-	if (pwdev->iftype != NL80211_IFTYPE_ADHOC) 
-	{
-		return;
-	}
-
-	if (!rtw_cfg80211_check_bss(padapter)) {
-		WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
-		struct wlan_network *scanned = pmlmepriv->cur_network_scanned;
-
-		if(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)==_TRUE)
-		{
-			
-			_rtw_memcpy(&cur_network->network, pnetwork, sizeof(WLAN_BSSID_EX));
-			if(cur_network)
-			{
-				if (!rtw_cfg80211_inform_bss(padapter,cur_network))
-					DBG_871X(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
-				else
-					DBG_871X(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter));
-			}
-			else
-			{
-				DBG_871X("cur_network is not exist!!!\n");
-				return ;
-			}
-		}
-		else
-		{
-			if(scanned == NULL)
-				rtw_warn_on(1);
-
-			if (_rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
-				&& _rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
-			) {
-				if (!rtw_cfg80211_inform_bss(padapter,scanned)) {
-					DBG_871X(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
-				} else {
-					//DBG_871X(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter));
-				}
-			} else {
-				DBG_871X("scanned & pnetwork compare fail\n");
-				rtw_warn_on(1);
-			}
-		}
-
-		if (!rtw_cfg80211_check_bss(padapter))
-			DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" BSS not found !!\n", FUNC_ADPT_ARG(padapter));
-	}
-	//notify cfg80211 that device joined an IBSS
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
-	notify_channel = ieee80211_get_channel(wiphy, freq);
-	cfg80211_ibss_joined(padapter->pnetdev, cur_network->network.MacAddress, notify_channel, GFP_ATOMIC);
-#else
-	cfg80211_ibss_joined(padapter->pnetdev, cur_network->network.MacAddress, GFP_ATOMIC);
-#endif
-}
-
-void rtw_cfg80211_indicate_connect(_adapter *padapter)
-{
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif
-	struct cfg80211_bss *bss = NULL;
-
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-	if (pwdev->iftype != NL80211_IFTYPE_STATION
-		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-		&& pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT
-		#endif
-	) {
-		return;
-	}
-
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-		return;
-
-#ifdef CONFIG_P2P
-	if(pwdinfo->driver_interface == DRIVER_CFG80211 )
-	{
-		if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		{
-			rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
-			rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
-			rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
-			DBG_8192C("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo), rtw_p2p_pre_state(pwdinfo));
-		}
-	}
-#endif //CONFIG_P2P
-
-	if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) != _TRUE) {
-		WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
-		struct wlan_network *scanned = pmlmepriv->cur_network_scanned;
-
-		//DBG_871X(FUNC_ADPT_FMT" BSS not found\n", FUNC_ADPT_ARG(padapter));
-
-		if(scanned == NULL) {
-			rtw_warn_on(1);
-			goto check_bss;
-		}
-
-		if (_rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
-			&& _rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
-		) {
-			if (!rtw_cfg80211_inform_bss(padapter,scanned)) {
-				DBG_871X(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
-			} else {
-				//DBG_871X(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter));
-			}
-		} else {
-			DBG_871X("scanned: %s("MAC_FMT"), cur: %s("MAC_FMT")\n",
-				scanned->network.Ssid.Ssid, MAC_ARG(scanned->network.MacAddress),
-				pnetwork->Ssid.Ssid, MAC_ARG(pnetwork->MacAddress)
-			);
-			rtw_warn_on(1);
-		}
-	}
-
-check_bss:
-	if (!rtw_cfg80211_check_bss(padapter))
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" BSS not found !!\n", FUNC_ADPT_ARG(padapter));
-
-	if (rtw_to_roam(padapter) > 0) {
-		#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39) || defined(COMPAT_KERNEL_RELEASE)
-		struct wiphy *wiphy = pwdev->wiphy;
-		struct ieee80211_channel *notify_channel;
-		u32 freq;
-		u16 channel = cur_network->network.Configuration.DSConfig;
-
-		freq = rtw_ch2freq(channel);
-		notify_channel = ieee80211_get_channel(wiphy, freq);
-		#endif
-
-		DBG_871X(FUNC_ADPT_FMT" call cfg80211_roamed\n", FUNC_ADPT_ARG(padapter));
-		cfg80211_roamed(padapter->pnetdev
-			#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39) || defined(COMPAT_KERNEL_RELEASE)
-			, notify_channel
-			#endif
-			, cur_network->network.MacAddress
-			, pmlmepriv->assoc_req+sizeof(struct rtw_ieee80211_hdr_3addr)+2
-			, pmlmepriv->assoc_req_len-sizeof(struct rtw_ieee80211_hdr_3addr)-2
-			, pmlmepriv->assoc_rsp+sizeof(struct rtw_ieee80211_hdr_3addr)+6
-			, pmlmepriv->assoc_rsp_len-sizeof(struct rtw_ieee80211_hdr_3addr)-6
-			, GFP_ATOMIC);
-	}
-	else
-	{
-	#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)	
-		DBG_8192C("pwdev->sme_state(b)=%d\n", pwdev->sme_state);
-	#endif
-		cfg80211_connect_result(padapter->pnetdev, cur_network->network.MacAddress
-			, pmlmepriv->assoc_req+sizeof(struct rtw_ieee80211_hdr_3addr)+2
-			, pmlmepriv->assoc_req_len-sizeof(struct rtw_ieee80211_hdr_3addr)-2
-			, pmlmepriv->assoc_rsp+sizeof(struct rtw_ieee80211_hdr_3addr)+6
-			, pmlmepriv->assoc_rsp_len-sizeof(struct rtw_ieee80211_hdr_3addr)-6
-			, WLAN_STATUS_SUCCESS, GFP_ATOMIC);
-	#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)	
-		DBG_8192C("pwdev->sme_state(a)=%d\n", pwdev->sme_state);
-	#endif
-	}
-}
-
-void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)
-{
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif
-
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-
-	/*always replace privated definitions with wifi reserved value 0*/
-	if ((reason == WLAN_REASON_ACTIVE_ROAM) || (reason == WLAN_REASON_JOIN_WRONG_CHANNEL) || (reason == WLAN_REASON_EXPIRATION_CHK)) {
-		reason = 0;
-	}
-
-	if (pwdev->iftype != NL80211_IFTYPE_STATION 
-		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-		&& pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT
-		#endif
-	) {
-		return;
-	}
-
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-		return;
-
-#ifdef CONFIG_P2P	
-	if( pwdinfo->driver_interface == DRIVER_CFG80211 )
-	{
-		if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		{
-			rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-
-			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
-			if (pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT)
-			#endif
-				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-
-			DBG_8192C("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo), rtw_p2p_pre_state(pwdinfo));
-		}
-	}
-#endif //CONFIG_P2P
-
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	if (!padapter->mlmepriv.not_indic_disco || padapter->ndev_unregistering) {
-	#else
-	{
-	#endif	
-		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)			
-		DBG_8192C("pwdev->sme_state(b)=%d\n", pwdev->sme_state);
-
-		if(pwdev->sme_state==CFG80211_SME_CONNECTING)
-			cfg80211_connect_result(padapter->pnetdev, NULL, NULL, 0, NULL, 0, 
-				WLAN_STATUS_UNSPECIFIED_FAILURE, GFP_ATOMIC/*GFP_KERNEL*/);
-		else if (pwdev->sme_state == CFG80211_SME_CONNECTED) {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
-			cfg80211_disconnected(padapter->pnetdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
-#else
-			cfg80211_disconnected(padapter->pnetdev, 0, NULL, 0, GFP_ATOMIC);
-#endif
-		}
-		//else
-			//DBG_8192C("pwdev->sme_state=%d\n", pwdev->sme_state);
-
-		DBG_8192C("pwdev->sme_state(a)=%d\n", pwdev->sme_state);
-		#else
-
-		if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
-			DBG_871X(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
-			cfg80211_disconnected(padapter->pnetdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
-#else
-			DBG_871X(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
-			cfg80211_disconnected(padapter->pnetdev, 0, NULL, 0, GFP_ATOMIC);
-#endif
-		} else {
-			DBG_871X(FUNC_ADPT_FMT" call cfg80211_connect_result\n", FUNC_ADPT_ARG(padapter));
-			cfg80211_connect_result(padapter->pnetdev, NULL, NULL, 0, NULL, 0, 
-				WLAN_STATUS_UNSPECIFIED_FAILURE, GFP_ATOMIC);
-		}
-		#endif
-	}
-}
- 	
-
-#ifdef CONFIG_AP_MODE
-static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
-{
-	int ret = 0;
-	u32 wep_key_idx, wep_key_len,wep_total_len;
-	struct sta_info *psta = NULL, *pbcmc_sta = NULL;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
-	struct security_priv* psecuritypriv=&(padapter->securitypriv);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-
-	DBG_8192C("%s\n", __FUNCTION__);
-
-	param->u.crypt.err = 0;
-	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
-
-	//sizeof(struct ieee_param) = 64 bytes;
-	//if (param_len !=  (u32) ((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len)
-	if (param_len !=  sizeof(struct ieee_param) + param->u.crypt.key_len)
-	{
-		ret =  -EINVAL;
-		goto exit;
-	}
-
-	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
-	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-		if (param->u.crypt.idx >= WEP_KEYS
-#ifdef CONFIG_IEEE80211W
-			&& param->u.crypt.idx > BIP_MAX_KEYID
-#endif /* CONFIG_IEEE80211W */
-		)
-		{
-			ret = -EINVAL;
-			goto exit;
-		}	
-	}
-	else 
-	{		
-		psta = rtw_get_stainfo(pstapriv, param->sta_addr);
-		if(!psta)
-		{
-			//ret = -EINVAL;
-			DBG_8192C("rtw_set_encryption(), sta has already been removed or never been added\n");
-			goto exit;
-		}			
-	}
-
-	if (strcmp(param->u.crypt.alg, "none") == 0 && (psta==NULL))
-	{
-		//todo:clear default encryption keys
-
-		DBG_8192C("clear default encryption keys, keyid=%d\n", param->u.crypt.idx);
-		
-		goto exit;
-	}
-
-
-	if (strcmp(param->u.crypt.alg, "WEP") == 0 && (psta==NULL))
-	{		
-		DBG_8192C("r871x_set_encryption, crypt.alg = WEP\n");
-		
-		wep_key_idx = param->u.crypt.idx;
-		wep_key_len = param->u.crypt.key_len;
-					
-		DBG_8192C("r871x_set_encryption, wep_key_idx=%d, len=%d\n", wep_key_idx, wep_key_len);
-
-		if((wep_key_idx >= WEP_KEYS) || (wep_key_len<=0))
-		{
-			ret = -EINVAL;
-			goto exit;
-		}
-			
-		if (wep_key_len > 0) 
-		{			
-		 	wep_key_len = wep_key_len <= 5 ? 5 : 13;
-		}
-		
-		if (psecuritypriv->bWepDefaultKeyIdxSet == 0)
-		{
-			//wep default key has not been set, so use this key index as default key.
-
-			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
-			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
-			psecuritypriv->dot11PrivacyAlgrthm=_WEP40_;
-			psecuritypriv->dot118021XGrpPrivacy=_WEP40_;
-			
-			if(wep_key_len == 13)
-			{
-				psecuritypriv->dot11PrivacyAlgrthm=_WEP104_;
-				psecuritypriv->dot118021XGrpPrivacy=_WEP104_;
-			}
-
-			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
-		}
-			
-		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
-					
-		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
-
-		rtw_ap_set_wep_key(padapter, param->u.crypt.key, wep_key_len, wep_key_idx, 1);
-
-		goto exit;
-		
-	}
-
-	
-	if(!psta && check_fwstate(pmlmepriv, WIFI_AP_STATE)) // //group key
-	{
-		if(param->u.crypt.set_tx == 0) //group key
-		{
-			if(strcmp(param->u.crypt.alg, "WEP") == 0)
-			{
-				DBG_8192C("%s, set group_key, WEP\n", __FUNCTION__);
-				
-				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-					
-				psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-				if(param->u.crypt.key_len==13)
-				{						
-						psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-				}
-				
-			}
-			else if(strcmp(param->u.crypt.alg, "TKIP") == 0)
-			{						
-				DBG_8192C("%s, set group_key, TKIP\n", __FUNCTION__);
-				
-				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
-
-				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				
-				//DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len);
-				//set mic key
-				_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
-				_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
-
-				psecuritypriv->busetkipkey = _TRUE;
-											
-			}
-			else if(strcmp(param->u.crypt.alg, "CCMP") == 0)
-			{
-				DBG_8192C("%s, set group_key, CCMP\n", __FUNCTION__);
-			
-				psecuritypriv->dot118021XGrpPrivacy = _AES_;
-
-				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-			}
-#ifdef CONFIG_IEEE80211W
-			else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
-				int no;
-				
-				DBG_871X("BIP key_len=%d , index=%d\n", param->u.crypt.key_len, param->u.crypt.idx);
-				/* save the IGTK key, length 16 bytes */
-				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16:param->u.crypt.key_len));
-				/* DBG_871X("IGTK key below:\n");
-				for(no=0;no<16;no++)
-					printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-				DBG_871X("\n"); */
-				padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
-				padapter->securitypriv.binstallBIPkey = _TRUE;
-				DBG_871X(" ~~~~set sta key:IGKT\n");
-				goto exit;
-			}
-#endif /* CONFIG_IEEE80211W */
-			else
-			{
-				DBG_8192C("%s, set group_key, none\n", __FUNCTION__);
-				
-				psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
-			}
-
-			psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
-			psecuritypriv->binstallGrpkey = _TRUE;
-
-			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;//!!!
-								
-			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
-			
-			pbcmc_sta=rtw_get_bcmc_stainfo(padapter);
-			if(pbcmc_sta)
-			{
-				pbcmc_sta->ieee8021x_blocked = _FALSE;
-				pbcmc_sta->dot118021XPrivacy= psecuritypriv->dot118021XGrpPrivacy;//rx will use bmc_sta's dot118021XPrivacy			
-			}	
-						
-		}
-
-		goto exit;
-		
-	}	
-
-	if(psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) // psk/802_1x
-	{
-		if(check_fwstate(pmlmepriv, WIFI_AP_STATE))
-		{
-			if(param->u.crypt.set_tx ==1) //pairwise key
-			{ 
-				_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				
-				if(strcmp(param->u.crypt.alg, "WEP") == 0)
-				{
-					DBG_8192C("%s, set pairwise key, WEP\n", __FUNCTION__);
-					
-					psta->dot118021XPrivacy = _WEP40_;
-					if(param->u.crypt.key_len==13)
-					{						
-						psta->dot118021XPrivacy = _WEP104_;
-					}
-				}
-				else if(strcmp(param->u.crypt.alg, "TKIP") == 0)
-				{						
-					DBG_8192C("%s, set pairwise key, TKIP\n", __FUNCTION__);
-					
-					psta->dot118021XPrivacy = _TKIP_;
-				
-					//DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len);
-					//set mic key
-					_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
-					_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
-					psecuritypriv->busetkipkey = _TRUE;
-											
-				}
-				else if(strcmp(param->u.crypt.alg, "CCMP") == 0)
-				{
-
-					DBG_8192C("%s, set pairwise key, CCMP\n", __FUNCTION__);
-					
-					psta->dot118021XPrivacy = _AES_;
-				}
-				else
-				{
-					DBG_8192C("%s, set pairwise key, none\n", __FUNCTION__);
-					
-					psta->dot118021XPrivacy = _NO_PRIVACY_;
-				}
-						
-				rtw_ap_set_pairwise_key(padapter, psta);
-					
-				psta->ieee8021x_blocked = _FALSE;
-					
-				psta->bpairwise_key_installed = _TRUE;
-					
-			}			
-			else//group key???
-			{ 
-				if(strcmp(param->u.crypt.alg, "WEP") == 0)
-				{
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-					
-					psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-					if(param->u.crypt.key_len==13)
-					{						
-						psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-					}
-				}
-				else if(strcmp(param->u.crypt.alg, "TKIP") == 0)
-				{						
-					psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
-
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				
-					//DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len);
-					//set mic key
-					_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
-					_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
-
-					psecuritypriv->busetkipkey = _TRUE;
-											
-				}
-				else if(strcmp(param->u.crypt.alg, "CCMP") == 0)
-				{
-					psecuritypriv->dot118021XGrpPrivacy = _AES_;
-
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				}
-				else
-				{
-					psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
-				}
-
-				psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
-				psecuritypriv->binstallGrpkey = _TRUE;	
-								
-				psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;//!!!
-								
-				rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
-			
-				pbcmc_sta=rtw_get_bcmc_stainfo(padapter);
-				if(pbcmc_sta)
-				{
-					pbcmc_sta->ieee8021x_blocked = _FALSE;
-					pbcmc_sta->dot118021XPrivacy= psecuritypriv->dot118021XGrpPrivacy;//rx will use bmc_sta's dot118021XPrivacy			
-				}					
-
-			}
-			
-		}
-				
-	}
-
-exit:
-
-	return ret;
-	
-}
-#endif
-
-static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
-{
-	int ret = 0;
-	u32 wep_key_idx, wep_key_len,wep_total_len;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;		
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-#ifdef CONFIG_P2P
-	struct wifidirect_info* pwdinfo = &padapter->wdinfo;
-#endif //CONFIG_P2P
-
-_func_enter_;
-
-	DBG_8192C("%s\n", __func__);
-
-	param->u.crypt.err = 0;
-	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
-
-	if (param_len < (u32) ((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len)
-	{
-		ret =  -EINVAL;		
-		goto exit;
-	}
-
-	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
-	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-		if (param->u.crypt.idx >= WEP_KEYS
-#ifdef CONFIG_IEEE80211W
-			&& param->u.crypt.idx > BIP_MAX_KEYID
-#endif //CONFIG_IEEE80211W
-		)
-		{
-			ret = -EINVAL;
-			goto exit;
-		}
-	} else {
-#ifdef CONFIG_WAPI_SUPPORT
-		if (strcmp(param->u.crypt.alg, "SMS4"))
-#endif
-		{
-		ret = -EINVAL;
-		goto exit;
-	}
-	}
-
-	if (strcmp(param->u.crypt.alg, "WEP") == 0)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("wpa_set_encryption, crypt.alg = WEP\n"));
-		DBG_8192C("wpa_set_encryption, crypt.alg = WEP\n");
-
-		wep_key_idx = param->u.crypt.idx;
-		wep_key_len = param->u.crypt.key_len;
-
-		if ((wep_key_idx > WEP_KEYS) || (wep_key_len <= 0))
-		{
-			ret = -EINVAL;
-			goto exit;
-		}
-
-		if (psecuritypriv->bWepDefaultKeyIdxSet == 0)
-		{
-			//wep default key has not been set, so use this key index as default key.
-
-			wep_key_len = wep_key_len <= 5 ? 5 : 13;
-
-			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
-			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
-			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-
-			if(wep_key_len==13)
-			{
-				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
-				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-			}
-
-			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
-		}
-			
-		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
-			
-		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
-			
-		rtw_set_key(padapter, psecuritypriv, wep_key_idx, 0, _TRUE);
-
-		goto exit;		
-	}
-
-	if(padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) // 802_1x
-	{
-		struct sta_info * psta,*pbcmc_sta;
-		struct sta_priv * pstapriv = &padapter->stapriv;
-
-		//DBG_8192C("%s, : dot11AuthAlgrthm == dot11AuthAlgrthm_8021X \n", __func__);
-
-		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_MP_STATE) == _TRUE) //sta mode
-		{
-			psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));			
-			if (psta == NULL) {
-				//DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail \n"));
-				DBG_8192C("%s, : Obtain Sta_info fail \n", __func__);
-			}
-			else
-			{
-				//Jeff: don't disable ieee8021x_blocked while clearing key
-				if (strcmp(param->u.crypt.alg, "none") != 0) 
-					psta->ieee8021x_blocked = _FALSE;
-
-				
-				if((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled)||
-						(padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
-				{
-					psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
-				}		
-
-				if(param->u.crypt.set_tx ==1)//pairwise key
-				{ 
-
-					DBG_8192C("%s, : param->u.crypt.set_tx ==1 \n", __func__);
-					
-					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-					
-					if(strcmp(param->u.crypt.alg, "TKIP") == 0)//set mic key
-					{						
-						//DEBUG_ERR(("\nset key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len));
-						_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
-						_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
-						padapter->securitypriv.busetkipkey=_FALSE;
-						//_set_timer(&padapter->securitypriv.tkip_timer, 50);						
-					}
-					psta->bpairwise_key_installed = _TRUE;
-					//DEBUG_ERR((" param->u.crypt.key_len=%d\n",param->u.crypt.key_len));
-					DBG_871X(" ~~~~set sta key:unicastkey\n");
-					
-					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
-				}
-				else//group key
-				{
-					if(strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0)
-					{
-						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,(param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-						_rtw_memcpy(padapter->securitypriv.dot118021XGrptxmickey[param->u.crypt.idx].skey,&(param->u.crypt.key[16]),8);
-						_rtw_memcpy(padapter->securitypriv.dot118021XGrprxmickey[param->u.crypt.idx].skey,&(param->u.crypt.key[24]),8);
-	                                        padapter->securitypriv.binstallGrpkey = _TRUE;	
-						//DEBUG_ERR((" param->u.crypt.key_len=%d\n", param->u.crypt.key_len));
-						DBG_871X(" ~~~~set sta key:groupkey\n");
-	
-						padapter->securitypriv.dot118021XGrpKeyid = param->u.crypt.idx;
-						rtw_set_key(padapter,&padapter->securitypriv,param->u.crypt.idx, 1, _TRUE);
-					}
-#ifdef CONFIG_IEEE80211W
-					else if(strcmp(param->u.crypt.alg, "BIP") == 0)
-					{
-						int no;
-						//DBG_871X("BIP key_len=%d , index=%d @@@@@@@@@@@@@@@@@@\n", param->u.crypt.key_len, param->u.crypt.idx);
-						//save the IGTK key, length 16 bytes
-						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,(param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-						/*DBG_871X("IGTK key below:\n");
-						for(no=0;no<16;no++)
-							printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-						DBG_871X("\n");*/
-						padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
-						padapter->securitypriv.binstallBIPkey = _TRUE;
-						DBG_871X(" ~~~~set sta key:IGKT\n");
-					}
-#endif //CONFIG_IEEE80211W
-					
-#ifdef CONFIG_P2P
-					if(pwdinfo->driver_interface == DRIVER_CFG80211 )
-					{
-						if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
-						{
-							rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_DONE);
-						}
-					}
-#endif //CONFIG_P2P
-					
-				}						
-			}
-
-			pbcmc_sta=rtw_get_bcmc_stainfo(padapter);
-			if(pbcmc_sta==NULL)
-			{
-				//DEBUG_ERR( ("Set OID_802_11_ADD_KEY: bcmc stainfo is null \n"));
-			}
-			else
-			{
-				//Jeff: don't disable ieee8021x_blocked while clearing key
-				if (strcmp(param->u.crypt.alg, "none") != 0) 
-					pbcmc_sta->ieee8021x_blocked = _FALSE;
-				
-				if((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled)||
-						(padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
-				{							
-					pbcmc_sta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
-				}					
-			}				
-		}
-		else if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) //adhoc mode
-		{		
-		}			
-	}
-
-#ifdef CONFIG_WAPI_SUPPORT
-	if (strcmp(param->u.crypt.alg, "SMS4") == 0)
-	{
-		PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
-		PRT_WAPI_STA_INFO	pWapiSta;
-		u8					WapiASUEPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-		u8					WapiAEPNInitialValueSrc[16] = {0x37,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-		u8 					WapiAEMultiCastPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-
-		if(param->u.crypt.set_tx == 1)
-		{
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if(_rtw_memcmp(pWapiSta->PeerMacAddr,param->sta_addr,6))
-				{
-					_rtw_memcpy(pWapiSta->lastTxUnicastPN,WapiASUEPNInitialValueSrc,16);
-
-					pWapiSta->wapiUsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiUsk.dataKey,param->u.crypt.key,16);
-					_rtw_memcpy(pWapiSta->wapiUsk.micKey,param->u.crypt.key+16,16);
-					pWapiSta->wapiUsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiUsk.bTxEnable = true;
-
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPN,WapiAEPNInitialValueSrc,16);
-					pWapiSta->wapiUskUpdate.bTxEnable = false;
-					pWapiSta->wapiUskUpdate.bSet = false;
-
-					if (psecuritypriv->sw_encrypt== false || psecuritypriv->sw_decrypt == false)
-					{
-						//set unicast key for ASUE
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiUsk, pWapiSta, false, false);
-					}
-				}
-			}
-		}
-		else
-		{
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if(_rtw_memcmp(pWapiSta->PeerMacAddr,get_bssid(pmlmepriv),6))
-				{
-					pWapiSta->wapiMsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiMsk.dataKey,param->u.crypt.key,16);
-					_rtw_memcpy(pWapiSta->wapiMsk.micKey,param->u.crypt.key+16,16);
-					pWapiSta->wapiMsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiMsk.bTxEnable = false;
-					if(!pWapiSta->bSetkeyOk)
-						pWapiSta->bSetkeyOk = true;
-					pWapiSta->bAuthenticateInProgress = false;
-
-					_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
-
-					if (psecuritypriv->sw_decrypt == false)
-					{
-						//set rx broadcast key for ASUE
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiMsk, pWapiSta, true, false);
-					}
-				}
-
-			}
-		}
-	}
-#endif
-
-
-exit:
-
-	DBG_8192C("%s, ret=%d\n", __func__, ret);
-	
-	_func_exit_;
-	
-	return ret;	
-}
-
-static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-				u8 key_index, bool pairwise, const u8 *mac_addr,
-#else	// (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-				u8 key_index, const u8 *mac_addr,
-#endif	// (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-				struct key_params *params)
-{
-	char *alg_name;
-	u32 param_len;
-	struct ieee_param *param = NULL;	
-	int ret=0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-#ifdef CONFIG_TDLS
-	struct sta_info *ptdls_sta;
-#endif /* CONFIG_TDLS */
-	
-	DBG_871X(FUNC_NDEV_FMT" adding key for %pM\n", FUNC_NDEV_ARG(ndev), mac_addr);
-	DBG_871X("cipher=0x%x\n", params->cipher);
-	DBG_871X("key_len=0x%x\n", params->key_len);
-	DBG_871X("seq_len=0x%x\n", params->seq_len);
-	DBG_871X("key_index=%d\n", key_index);
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	DBG_871X("pairwise=%d\n", pairwise);
-#endif	// (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-
-	param_len = sizeof(struct ieee_param) + params->key_len;
-	param = (struct ieee_param *)rtw_malloc(param_len);
-	if (param == NULL)
-		return -1;
-	
-	_rtw_memset(param, 0, param_len);
-
-	param->cmd = IEEE_CMD_SET_ENCRYPTION;
-	_rtw_memset(param->sta_addr, 0xff, ETH_ALEN);
-
-	switch (params->cipher) {
-	case IW_AUTH_CIPHER_NONE:
-		//todo: remove key 
-		//remove = 1;	
-		alg_name = "none";
-		break;
-	case WLAN_CIPHER_SUITE_WEP40:
-	case WLAN_CIPHER_SUITE_WEP104:
-		alg_name = "WEP";
-		break;
-	case WLAN_CIPHER_SUITE_TKIP:
-		alg_name = "TKIP";
-		break;
-	case WLAN_CIPHER_SUITE_CCMP:
-		alg_name = "CCMP";
-		break;
-#ifdef CONFIG_IEEE80211W
-	case WLAN_CIPHER_SUITE_AES_CMAC:
-		alg_name = "BIP";
-		break;
-#endif //CONFIG_IEEE80211W
-#ifdef CONFIG_WAPI_SUPPORT
-	case WLAN_CIPHER_SUITE_SMS4:
-		alg_name= "SMS4";
-		if(pairwise == NL80211_KEYTYPE_PAIRWISE) {
-			if (key_index != 0 && key_index != 1) {
-				ret = -ENOTSUPP;
-				goto addkey_end;
-			}
-			_rtw_memcpy((void*)param->sta_addr, (void*)mac_addr, ETH_ALEN);
-		} else {
-			DBG_871X("mac_addr is null \n");
-		}
-		DBG_871X("rtw_wx_set_enc_ext: SMS4 case \n");
-		break;
-#endif
-
-	default:	
-		ret = -ENOTSUPP;
-		goto addkey_end;
-	}
-	
-	strncpy((char *)param->u.crypt.alg, alg_name, IEEE_CRYPT_ALG_NAME_LEN);
-	
-
-	if (!mac_addr || is_broadcast_ether_addr(mac_addr))
-	{
-		param->u.crypt.set_tx = 0; //for wpa/wpa2 group key
-	} else {
-		param->u.crypt.set_tx = 1; //for wpa/wpa2 pairwise key
-	}
-	
-	
-	//param->u.crypt.idx = key_index - 1;
-	param->u.crypt.idx = key_index;
-	
-	if (params->seq_len && params->seq) 
-	{	
-		_rtw_memcpy(param->u.crypt.seq, (u8 *)params->seq, params->seq_len);
-	}
-
-	if(params->key_len && params->key)
-	{
-		param->u.crypt.key_len = params->key_len;		
-		_rtw_memcpy(param->u.crypt.key, (u8 *)params->key, params->key_len);
-	}	
-
-	if(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-	{
-#ifdef CONFIG_TDLS
-		if (rtw_tdls_is_driver_setup(padapter) == _FALSE && mac_addr) {
-			ptdls_sta = rtw_get_stainfo(&padapter->stapriv, (void *)mac_addr);
-			if (ptdls_sta != NULL && ptdls_sta->tdls_sta_state) {
-				_rtw_memcpy(ptdls_sta->tpk.tk, params->key, params->key_len);
-				rtw_tdls_set_key(padapter, ptdls_sta);
-				goto addkey_end;
-			}
-		}
-#endif /* CONFIG_TDLS */
-
-		ret =  rtw_cfg80211_set_encryption(ndev, param, param_len);	
-	}
-	else if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
-#ifdef CONFIG_AP_MODE
-		if(mac_addr)
-			_rtw_memcpy(param->sta_addr, (void*)mac_addr, ETH_ALEN);
-	
-		ret = rtw_cfg80211_ap_set_encryption(ndev, param, param_len);
-#endif
-	}
-        else if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE
-                || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)
-        {
-                //DBG_8192C("@@@@@@@@@@ fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype);
-                ret =  rtw_cfg80211_set_encryption(ndev, param, param_len);
-        }
-	else
-	{
-		DBG_8192C("error! fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype);
-		
-	}
-
-addkey_end:
-	if(param)
-	{
-		rtw_mfree((u8*)param, param_len);
-	}
-
-	return ret;
-
-}
-
-static int cfg80211_rtw_get_key(struct wiphy *wiphy, struct net_device *ndev,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-				u8 key_index, bool pairwise, const u8 *mac_addr,
-#else	// (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-				u8 key_index, const u8 *mac_addr,
-#endif	// (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-				void *cookie,
-				void (*callback)(void *cookie,
-						 struct key_params*))
-{
-#if 0
-	struct iwm_priv *iwm = ndev_to_iwm(ndev);
-	struct iwm_key *key = &iwm->keys[key_index];
-	struct key_params params;
-
-	IWM_DBG_WEXT(iwm, DBG, "Getting key %d\n", key_index);
-
-	memset(&params, 0, sizeof(params));
-
-	params.cipher = key->cipher;
-	params.key_len = key->key_len;
-	params.seq_len = key->seq_len;
-	params.seq = key->seq;
-	params.key = key->key;
-
-	callback(cookie, &params);
-
-	return key->key_len ? 0 : -ENOENT;
-#endif
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	return 0;
-}
-
-static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-				u8 key_index, bool pairwise, const u8 *mac_addr)
-#else	// (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-				u8 key_index, const u8 *mac_addr)
-#endif	// (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);		
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-	DBG_871X(FUNC_NDEV_FMT" key_index=%d\n", FUNC_NDEV_ARG(ndev), 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
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)) || defined(COMPAT_KERNEL_RELEASE)
-	, bool unicast, bool multicast
-	#endif
-	)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);		
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-#define SET_DEF_KEY_PARAM_FMT " key_index=%d"
-#define SET_DEF_KEY_PARAM_ARG , key_index
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
-	#define SET_DEF_KEY_PARAM_FMT_2_6_38 ", unicast=%d, multicast=%d"
-	#define SET_DEF_KEY_PARAM_ARG_2_6_38 , unicast, multicast
-#else
-	#define SET_DEF_KEY_PARAM_FMT_2_6_38 ""
-	#define SET_DEF_KEY_PARAM_ARG_2_6_38
-#endif
-
-	DBG_871X(FUNC_NDEV_FMT
-		SET_DEF_KEY_PARAM_FMT
-		SET_DEF_KEY_PARAM_FMT_2_6_38
-		"\n", FUNC_NDEV_ARG(ndev)
-		SET_DEF_KEY_PARAM_ARG
-		SET_DEF_KEY_PARAM_ARG_2_6_38
-	);
-
-	if ((key_index < WEP_KEYS) && ((psecuritypriv->dot11PrivacyAlgrthm == _WEP40_) || (psecuritypriv->dot11PrivacyAlgrthm == _WEP104_))) //set wep default key
-	{
-		psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
-
-		psecuritypriv->dot11PrivacyKeyIndex = key_index;
-
-		psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
-		psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-		if (psecuritypriv->dot11DefKeylen[key_index] == 13)
-		{
-			psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
-			psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-		}
-
-		psecuritypriv->bWepDefaultKeyIdxSet = 1; //set the flag to represent that wep default key has been set
-	}
-
-	return 0;
-
-}
-#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
-static int cfg80211_rtw_set_rekey_data(struct wiphy *wiphy,
-	struct net_device *ndev,
-	struct cfg80211_gtk_rekey_data *data)
-{
-	/*int i;*/
-	struct sta_info *psta;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_priv   *pmlmepriv = &padapter->mlmepriv;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct security_priv *psecuritypriv = &(padapter->securitypriv);
-
-	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
-	if (psta == NULL) {
-		DBG_871X("%s, : Obtain Sta_info fail\n", __func__);
-		return -1;
-	}
-
-	_rtw_memcpy(psta->kek, data->kek, NL80211_KEK_LEN);
-	/*printk("\ncfg80211_rtw_set_rekey_data KEK:");
-	for(i=0;i<NL80211_KEK_LEN; i++)
-		printk(" %02x ", psta->kek[i]);*/
-	_rtw_memcpy(psta->kck, data->kck, NL80211_KCK_LEN);
-	/*printk("\ncfg80211_rtw_set_rekey_data KCK:");
-	for(i=0;i<NL80211_KCK_LEN; i++)
-		printk(" %02x ", psta->kck[i]);*/
-	_rtw_memcpy(psta->replay_ctr, data->replay_ctr, NL80211_REPLAY_CTR_LEN);
-	psecuritypriv->binstallKCK_KEK = _TRUE;
-	/*printk("\nREPLAY_CTR: ");
-	for(i=0;i<RTW_REPLAY_CTR_LEN; i++)
-		printk(" %02x ", psta->replay_ctr[i]);*/
-
-	return 0;
-}
-#endif /*CONFIG_GTK_OL*/
-static int cfg80211_rtw_get_station(struct wiphy *wiphy,
-				struct net_device *ndev,
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,16,0))
-				u8 *mac, 
-#else
-				const u8 *mac,
-#endif
-				struct station_info *sinfo)
-{
-	int ret = 0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct sta_info *psta = NULL;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-
-	sinfo->filled = 0;
-
-	if (!mac) {
-		DBG_871X(FUNC_NDEV_FMT" mac==%p\n", FUNC_NDEV_ARG(ndev), mac);
-		ret = -ENOENT;
-		goto exit;
-	}
-
-	psta = rtw_get_stainfo(pstapriv, (u8 *)mac);
-	if (psta == NULL) {
-		DBG_8192C("%s, sta_info is null\n", __func__);
-		ret = -ENOENT;
-		goto exit;
-	}
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_871X(FUNC_NDEV_FMT" mac="MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
-#endif
-
-	//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 (_rtw_memcmp((u8 *)mac, cur_network->network.MacAddress, ETH_ALEN) == _FALSE) {
-			DBG_871X("%s, mismatch bssid="MAC_FMT"\n", __func__, MAC_ARG(cur_network->network.MacAddress));
-			ret = -ENOENT;
-			goto exit;
-		}
-
-		sinfo->filled |= STATION_INFO_SIGNAL;
-		sinfo->signal = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);
-
-		sinfo->filled |= STATION_INFO_TX_BITRATE;
-		sinfo->txrate.legacy = rtw_get_cur_max_rate(padapter);
-
-		sinfo->filled |= STATION_INFO_RX_PACKETS;
-		sinfo->rx_packets = sta_rx_data_pkts(psta);
-
-		sinfo->filled |= STATION_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;
-}
-
-extern int netdev_open(struct net_device *pnetdev);
-#ifdef CONFIG_CONCURRENT_MODE
-extern int netdev_if2_open(struct net_device *pnetdev);
-#endif
-
-/*
-enum nl80211_iftype {
-	NL80211_IFTYPE_UNSPECIFIED,
-       NL80211_IFTYPE_ADHOC, //1
-       NL80211_IFTYPE_STATION, //2
-       NL80211_IFTYPE_AP, //3
-       NL80211_IFTYPE_AP_VLAN,
-       NL80211_IFTYPE_WDS,
-       NL80211_IFTYPE_MONITOR, //6
-       NL80211_IFTYPE_MESH_POINT,
-       NL80211_IFTYPE_P2P_CLIENT, //8
-	NL80211_IFTYPE_P2P_GO, //9
-       //keep last 
-       NUM_NL80211_IFTYPES,
-       NL80211_IFTYPE_MAX = NUM_NL80211_IFTYPES - 1
-};
-*/
-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;
-	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-#endif
-	int ret = 0;
-	u8 change = _FALSE;
-
-	DBG_871X(FUNC_NDEV_FMT" type=%d\n", FUNC_NDEV_ARG(ndev), type);
-
-	if(adapter_to_dvobj(padapter)->processing_dev_remove == _TRUE)
-	{
-		ret= -EPERM;
-		goto exit;
-	}		
-	
-#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->adapter_type == SECONDARY_ADAPTER)
-	{
-		DBG_871X(FUNC_NDEV_FMT" call netdev_if2_open\n", FUNC_NDEV_ARG(ndev));
-		if(netdev_if2_open(ndev) != 0) {
-			DBG_871X(FUNC_NDEV_FMT" call netdev_if2_open fail\n", FUNC_NDEV_ARG(ndev));
-			ret= -EPERM;
-			goto exit;
-		}
-	}
-	else if(padapter->adapter_type == PRIMARY_ADAPTER)
-#endif //CONFIG_CONCURRENT_MODE
-	{
-		DBG_871X(FUNC_NDEV_FMT" call netdev_open\n", FUNC_NDEV_ARG(ndev));
-		if(netdev_open(ndev) != 0) {
-			DBG_871X(FUNC_NDEV_FMT" call netdev_open fail\n", FUNC_NDEV_ARG(ndev));
-			ret= -EPERM;
-			goto exit;
-		}
-	}
-
-	if(_FAIL == rtw_pwr_wakeup(padapter)) {
-		DBG_871X(FUNC_NDEV_FMT" call rtw_pwr_wakeup fail\n", FUNC_NDEV_ARG(ndev));
-		ret= -EPERM;
-		goto exit;
-	}
-
-	old_type = rtw_wdev->iftype;
-	DBG_871X(FUNC_NDEV_FMT" old_iftype=%d, new_iftype=%d\n",
-		FUNC_NDEV_ARG(ndev), old_type, type);
-
-	if(old_type != type)
-	{
-		change = _TRUE;
-		pmlmeext->action_public_rxseq = 0xffff;
-		pmlmeext->action_public_dialog_token = 0xff;
-	}	
-
-	/* initial default type */
-	ndev->type = ARPHRD_ETHER;
-
-	if (type == NL80211_IFTYPE_MONITOR) {
-		rtw_ps_deny(padapter, PS_DENY_MONITOR_MODE);
-		LeaveAllPowerSaveMode(padapter);
-	} else {
-		rtw_ps_deny_cancel(padapter, PS_DENY_MONITOR_MODE);
-	}
-
-	switch (type) {
-	case NL80211_IFTYPE_ADHOC:
-		networkType = Ndis802_11IBSS;
-		break;
-#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE))
-	case NL80211_IFTYPE_P2P_CLIENT:
-#endif
-	case NL80211_IFTYPE_STATION:
-		networkType = Ndis802_11Infrastructure;
-		#ifdef CONFIG_P2P
-		if(pwdinfo->driver_interface == DRIVER_CFG80211 )
-		{
-			if(change && rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-			{
-				//it means remove GO and change mode from AP(GO) to station(P2P DEVICE)
-				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-				rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-
-				DBG_8192C("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo), rtw_p2p_pre_state(pwdinfo));
-			}
-			#if ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
-			if (type == NL80211_IFTYPE_P2P_CLIENT)
-				rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
-			else {
-				/* NL80211_IFTYPE_STATION */
-				if (rtw_p2p_role(pwdinfo) == P2P_ROLE_CLIENT)
-					rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
-			}
-			#endif
-		}
-		#endif //CONFIG_P2P
-		break;
-#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE))
-	case NL80211_IFTYPE_P2P_GO:
-#endif
-	case NL80211_IFTYPE_AP:
-		networkType = Ndis802_11APMode;
-		#ifdef CONFIG_P2P
-		if(pwdinfo->driver_interface == DRIVER_CFG80211 )
-		{
-			if(change && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-			{
-				//it means P2P Group created, we will be GO and change mode from  P2P DEVICE to AP(GO)
-				rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-			}
-		}
-		#endif //CONFIG_P2P
-		break;
-	case NL80211_IFTYPE_MONITOR:
-		networkType = Ndis802_11Monitor;
-#if 0
-		ndev->type = ARPHRD_IEEE80211; /* IEEE 802.11 : 801 */
-#endif
-		ndev->type = ARPHRD_IEEE80211_RADIOTAP; /* IEEE 802.11 + radiotap header : 803 */
-		break;
-	default:
-		ret = -EOPNOTSUPP;
-		goto exit;
-	}
-
-	rtw_wdev->iftype = type;
-	
-	if (rtw_set_802_11_infrastructure_mode(padapter, networkType) ==_FALSE)
-	{
-		rtw_wdev->iftype = old_type;
-		ret = -EPERM;
-		goto exit;
-	}
-
-	rtw_setopmode_cmd(padapter, networkType, _TRUE);
-	
-exit:
-
-	DBG_871X(FUNC_NDEV_FMT" ret:%d\n", FUNC_NDEV_ARG(ndev), ret);
-	return ret;
-}
-
-void rtw_cfg80211_indicate_scan_done(_adapter *adapter, bool aborted)
-{
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
-	_irqL	irqL;
-
-	_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-	if (pwdev_priv->scan_request != NULL) {
-		#ifdef CONFIG_DEBUG_CFG80211
-		DBG_871X("%s with scan req\n", __FUNCTION__);
-		#endif
-
-		/* avoid WARN_ON(request != wiphy_to_dev(request->wiphy)->scan_req); */
-		if(pwdev_priv->scan_request->wiphy != pwdev_priv->rtw_wdev->wiphy)
-		{
-			DBG_8192C("error wiphy compare\n");
-		}
-		else
-		{
-			cfg80211_scan_done(pwdev_priv->scan_request, aborted);
-		}
-
-		pwdev_priv->scan_request = NULL;
-	} else {
-		#ifdef CONFIG_DEBUG_CFG80211
-		DBG_871X("%s without scan req\n", __FUNCTION__);
-		#endif
-	}
-	_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-}
-
-u32 rtw_cfg80211_wait_scan_req_empty(_adapter *adapter, u32 timeout_ms)
-{
-	struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
-	u8 empty = _FALSE;
-	u32 start;
-	u32 pass_ms;
-
-	start = rtw_get_current_time();
-
-	while (rtw_get_passing_time_ms(start) <= timeout_ms) {
-
-		if (RTW_CANNOT_RUN(adapter))
-			break;
-
-		if (!wdev_priv->scan_request) {
-			empty = _TRUE;
-			break;
-		}
-
-		rtw_msleep_os(10);
-	}
-
-	pass_ms = rtw_get_passing_time_ms(start);
-
-	if (empty == _FALSE && pass_ms > timeout_ms)
-		DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" pass_ms:%u, timeout\n"
-			, FUNC_ADPT_ARG(adapter), pass_ms);
-
-	return pass_ms;
-}
-
-void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork)
-{
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
-	struct wiphy *wiphy = pwdev->wiphy;
-	struct cfg80211_bss *bss = NULL;
-	WLAN_BSSID_EX select_network = pnetwork->network;
-	
-	bss = cfg80211_get_bss(wiphy, NULL/*notify_channel*/,
-		select_network.MacAddress, select_network.Ssid.Ssid,
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
+	cfg80211_put_bss(padapter->rtw_wdev->wiphy, bss);
+#else
+	cfg80211_put_bss(bss);
+#endif
+
+	return bss != NULL;
+}
+
+void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct cfg80211_bss *bss = NULL;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	struct wiphy *wiphy = pwdev->wiphy;
+	int freq = 2412;
+	struct ieee80211_channel *notify_channel;
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	freq = rtw_ch2freq(cur_network->network.Configuration.DSConfig);
+
+	if (0)
+		RTW_INFO("chan: %d, freq: %d\n", cur_network->network.Configuration.DSConfig, freq);
+#endif
+
+	if (pwdev->iftype != NL80211_IFTYPE_ADHOC)
+		return;
+
+	if (!rtw_cfg80211_check_bss(padapter)) {
+		WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
+		struct wlan_network *scanned = pmlmepriv->cur_network_scanned;
+
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
+
+			_rtw_memcpy(&cur_network->network, pnetwork, sizeof(WLAN_BSSID_EX));
+			if (cur_network) {
+				if (!rtw_cfg80211_inform_bss(padapter, cur_network))
+					RTW_INFO(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
+				else
+					RTW_INFO(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter));
+			} else {
+				RTW_INFO("cur_network is not exist!!!\n");
+				return ;
+			}
+		} else {
+			if (scanned == NULL)
+				rtw_warn_on(1);
+
+			if (_rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
+				&& _rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
+			) {
+				if (!rtw_cfg80211_inform_bss(padapter, scanned))
+					RTW_INFO(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
+				else {
+					/* RTW_INFO(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter)); */
+				}
+			} else {
+				RTW_INFO("scanned & pnetwork compare fail\n");
+				rtw_warn_on(1);
+			}
+		}
+
+		if (!rtw_cfg80211_check_bss(padapter))
+			RTW_PRINT(FUNC_ADPT_FMT" BSS not found !!\n", FUNC_ADPT_ARG(padapter));
+	}
+	/* notify cfg80211 that device joined an IBSS */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	notify_channel = ieee80211_get_channel(wiphy, freq);
+	cfg80211_ibss_joined(padapter->pnetdev, cur_network->network.MacAddress, notify_channel, GFP_ATOMIC);
+#else
+	cfg80211_ibss_joined(padapter->pnetdev, cur_network->network.MacAddress, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_indicate_connect(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	_irqL irqL;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif
+	struct cfg80211_bss *bss = NULL;
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
+	struct cfg80211_roam_info roam_info ={};
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	if (pwdev->iftype != NL80211_IFTYPE_STATION
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		&& pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT
+		#endif
+	)
+		return;
+
+	if (!MLME_IS_STA(padapter))
+		return;
+
+#ifdef CONFIG_P2P
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		#if !RTW_P2P_GROUP_INTERFACE
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+			rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
+			RTW_INFO("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo), rtw_p2p_pre_state(pwdinfo));
+		}
+		#endif
+	}
+#endif /* CONFIG_P2P */
+
+	if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) != _TRUE) {
+		WLAN_BSSID_EX  *pnetwork = &(padapter->mlmeextpriv.mlmext_info.network);
+		struct wlan_network *scanned = pmlmepriv->cur_network_scanned;
+
+		/* RTW_INFO(FUNC_ADPT_FMT" BSS not found\n", FUNC_ADPT_ARG(padapter)); */
+
+		if (scanned == NULL) {
+			rtw_warn_on(1);
+			goto check_bss;
+		}
+
+		if (_rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
+			&& _rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
+		) {
+			if (!rtw_cfg80211_inform_bss(padapter, scanned))
+				RTW_INFO(FUNC_ADPT_FMT" inform fail !!\n", FUNC_ADPT_ARG(padapter));
+			else {
+				/* RTW_INFO(FUNC_ADPT_FMT" inform success !!\n", FUNC_ADPT_ARG(padapter)); */
+			}
+		} else {
+			RTW_INFO("scanned: %s("MAC_FMT"), cur: %s("MAC_FMT")\n",
+				scanned->network.Ssid.Ssid, MAC_ARG(scanned->network.MacAddress),
+				pnetwork->Ssid.Ssid, MAC_ARG(pnetwork->MacAddress)
+			);
+			rtw_warn_on(1);
+		}
+	}
+
+check_bss:
+	if (!rtw_cfg80211_check_bss(padapter))
+		RTW_PRINT(FUNC_ADPT_FMT" BSS not found !!\n", FUNC_ADPT_ARG(padapter));
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	if (rtw_to_roam(padapter) > 0) {
+		#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39) || defined(COMPAT_KERNEL_RELEASE)
+		struct wiphy *wiphy = pwdev->wiphy;
+		struct ieee80211_channel *notify_channel;
+		u32 freq;
+		u16 channel = cur_network->network.Configuration.DSConfig;
+
+		freq = rtw_ch2freq(channel);
+		notify_channel = ieee80211_get_channel(wiphy, freq);
+		#endif
+
+		#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
+		roam_info.bssid = cur_network->network.MacAddress;
+		roam_info.req_ie = pmlmepriv->assoc_req + sizeof(struct rtw_ieee80211_hdr_3addr) + 2;
+		roam_info.req_ie_len = pmlmepriv->assoc_req_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
+		roam_info.resp_ie = pmlmepriv->assoc_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6;
+		roam_info.resp_ie_len = pmlmepriv->assoc_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6;
+
+		cfg80211_roamed(padapter->pnetdev, &roam_info, GFP_ATOMIC);
+		#else
+		cfg80211_roamed(padapter->pnetdev
+			#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39) || defined(COMPAT_KERNEL_RELEASE)
+			, notify_channel
+			#endif
+			, cur_network->network.MacAddress
+			, pmlmepriv->assoc_req + sizeof(struct rtw_ieee80211_hdr_3addr) + 2
+			, pmlmepriv->assoc_req_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 2
+			, pmlmepriv->assoc_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6
+			, pmlmepriv->assoc_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6
+			, GFP_ATOMIC);
+		#endif /*LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)*/
+
+		RTW_INFO(FUNC_ADPT_FMT" call cfg80211_roamed\n", FUNC_ADPT_ARG(padapter));
+
+#ifdef CONFIG_RTW_80211R
+		if (rtw_ft_roam(padapter))
+			rtw_ft_set_status(padapter, RTW_FT_ASSOCIATED_STA);
+#endif
+	} else {
+		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)
+		RTW_INFO("pwdev->sme_state(b)=%d\n", pwdev->sme_state);
+		#endif
+
+		if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) != _TRUE)
+			rtw_cfg80211_connect_result(pwdev, cur_network->network.MacAddress
+				, pmlmepriv->assoc_req + sizeof(struct rtw_ieee80211_hdr_3addr) + 2
+				, pmlmepriv->assoc_req_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 2
+				, pmlmepriv->assoc_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6
+				, pmlmepriv->assoc_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6
+				, WLAN_STATUS_SUCCESS, GFP_ATOMIC);
+		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)
+		RTW_INFO("pwdev->sme_state(a)=%d\n", pwdev->sme_state);
+		#endif
+	}
+
+	rtw_wdev_free_connect_req(pwdev_priv);
+
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+}
+
+void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	_irqL irqL;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	/*always replace privated definitions with wifi reserved value 0*/
+	if (WLAN_REASON_IS_PRIVATE(reason))
+		reason = 0;
+
+	if (pwdev->iftype != NL80211_IFTYPE_STATION
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		&& pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT
+		#endif
+	)
+		return;
+
+	if (!MLME_IS_STA(padapter))
+		return;
+
+#ifdef CONFIG_P2P
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
+
+			#if RTW_P2P_GROUP_INTERFACE
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+			if (pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT)
+			#endif
+			#endif
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
+
+			RTW_INFO("%s, role=%d, p2p_state=%d, pre_p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo), rtw_p2p_pre_state(pwdinfo));
+		}
+	}
+#endif /* CONFIG_P2P */
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	if (padapter->ndev_unregistering || !rtw_wdev_not_indic_disco(pwdev_priv)) {
+		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)
+		RTW_INFO("pwdev->sme_state(b)=%d\n", pwdev->sme_state);
+
+		if (pwdev->sme_state == CFG80211_SME_CONNECTING) {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_connect_result\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_connect_result(pwdev, NULL, NULL, 0, NULL, 0,
+				reason, GFP_ATOMIC);
+		} else if (pwdev->sme_state == CFG80211_SME_CONNECTED) {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_disconnected(pwdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
+		}
+
+		RTW_INFO("pwdev->sme_state(a)=%d\n", pwdev->sme_state);
+		#else
+		if (pwdev_priv->connect_req) {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_connect_result\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_connect_result(pwdev, NULL, NULL, 0, NULL, 0,
+				reason, GFP_ATOMIC);
+		} else {
+			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
+			rtw_cfg80211_disconnected(pwdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
+		}
+		#endif
+	}
+
+	rtw_wdev_free_connect_req(pwdev_priv);
+
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+}
+
+
+#ifdef CONFIG_AP_MODE
+static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_param *param)
+{
+	int ret = 0;
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	struct sta_info *psta = NULL, *pbcmc_sta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
+	param->u.crypt.err = 0;
+	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
+
+	if (is_broadcast_mac_addr(param->sta_addr)) {
+		if (param->u.crypt.idx >= WEP_KEYS
+			#ifdef CONFIG_IEEE80211W
+			&& param->u.crypt.idx > BIP_MAX_KEYID
+			#endif
+		) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	} else {
+		psta = rtw_get_stainfo(pstapriv, param->sta_addr);
+		if (!psta) {
+			ret = -EINVAL;
+			RTW_INFO(FUNC_ADPT_FMT", sta "MAC_FMT" not found\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(param->sta_addr));
+			goto exit;
+		}
+	}
+
+	if (strcmp(param->u.crypt.alg, "none") == 0 && (psta == NULL)) {
+		/* todo:clear default encryption keys */
+
+		RTW_INFO("clear default encryption keys, keyid=%d\n", param->u.crypt.idx);
+
+		goto exit;
+	}
+
+
+	if (strcmp(param->u.crypt.alg, "WEP") == 0 && (psta == NULL)) {
+		RTW_INFO("r871x_set_encryption, crypt.alg = WEP\n");
+
+		wep_key_idx = param->u.crypt.idx;
+		wep_key_len = param->u.crypt.key_len;
+
+		RTW_INFO("r871x_set_encryption, wep_key_idx=%d, len=%d\n", wep_key_idx, wep_key_len);
+
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		if (wep_key_len > 0)
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+
+		if (psecuritypriv->bWepDefaultKeyIdxSet == 0) {
+			/* wep default key has not been set, so use this key index as default key. */
+
+			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+
+			if (wep_key_len == 13) {
+				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+			}
+
+			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
+		}
+
+		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
+
+		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
+
+		rtw_ap_set_wep_key(padapter, param->u.crypt.key, wep_key_len, wep_key_idx, 1);
+
+		goto exit;
+
+	}
+
+	if (!psta) { /* group key */
+		if (param->u.crypt.set_tx == 0) { /* group key, TX only */
+			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set WEP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+				if (param->u.crypt.key_len == 13)
+					psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+
+			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				/* set mic key */
+				_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
+				_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
+				psecuritypriv->busetkipkey = _TRUE;
+
+			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _AES_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TX IGTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
+				psecuritypriv->dot11wBIPtxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				padapter->securitypriv.binstallBIPkey = _TRUE;
+				goto exit;
+			#endif /* CONFIG_IEEE80211W */
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key, idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx);
+				psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key, not support\n"
+					, FUNC_ADPT_ARG(padapter));
+				goto exit;
+			}
+
+			psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta) {
+				pbcmc_sta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				pbcmc_sta->ieee8021x_blocked = _FALSE;
+				pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
+			}
+			psecuritypriv->binstallGrpkey = _TRUE;
+			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
+
+			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
+		}
+
+		goto exit;
+
+	}
+
+	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) { /* psk/802_1x */
+		if (param->u.crypt.set_tx == 1) {
+			/* pairwise key */
+			_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set WEP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _WEP40_;
+				if (param->u.crypt.key_len == 13)
+					psta->dot118021XPrivacy = _WEP104_;
+
+			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _TKIP_;
+				/* set mic key */
+				_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
+				_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
+				psecuritypriv->busetkipkey = _TRUE;
+
+			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _AES_;
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear pairwise key of "MAC_FMT" idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx);
+				psta->dot118021XPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set pairwise key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
+			}
+
+			psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+			psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+			psta->ieee8021x_blocked = _FALSE;
+			psta->bpairwise_key_installed = _TRUE;
+			rtw_ap_set_pairwise_key(padapter, psta);
+
+		} else {
+			/* peer's group key, RX only */
+			#ifdef CONFIG_RTW_MESH
+			if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP GTK of "MAC_FMT", idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->group_privacy = _AES_;
+				_rtw_memcpy(psta->gtk.skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psta->gtk_bmp |= BIT(param->u.crypt.idx);
+				psta->gtk_pn.val = RTW_GET_LE64(param->u.crypt.seq);
+
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set IGTK of "MAC_FMT", idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(psta->igtk.skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psta->igtk_bmp |= BIT(param->u.crypt.idx);
+				psta->igtk_id = param->u.crypt.idx;
+				psta->igtk_pn.val = RTW_GET_LE64(param->u.crypt.seq);
+				goto exit;
+			#endif /* CONFIG_IEEE80211W */
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key of "MAC_FMT", idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx);
+				psta->group_privacy = _NO_PRIVACY_;
+				psta->gtk_bmp &= ~BIT(param->u.crypt.idx);
+			} else
+			#endif /* CONFIG_RTW_MESH */
+			{
+				RTW_WARN(FUNC_ADPT_FMT" set group key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
+			}
+
+			#ifdef CONFIG_RTW_MESH
+			rtw_ap_set_sta_key(padapter, psta->cmn.mac_addr, psta->group_privacy
+				, param->u.crypt.key, param->u.crypt.idx, 1);
+			#endif
+		}
+
+	}
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_AP_MODE */
+
+static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param *param)
+{
+	int ret = 0;
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
+
+	RTW_INFO("%s\n", __func__);
+
+	param->u.crypt.err = 0;
+	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
+
+	if (is_broadcast_mac_addr(param->sta_addr)) {
+		if (param->u.crypt.idx >= WEP_KEYS
+			#ifdef CONFIG_IEEE80211W
+			&& param->u.crypt.idx > BIP_MAX_KEYID
+			#endif
+		) {
+			ret = -EINVAL;
+			goto exit;
+		}
+	} else {
+#ifdef CONFIG_WAPI_SUPPORT
+		if (strcmp(param->u.crypt.alg, "SMS4"))
+#endif
+		{
+			ret = -EINVAL;
+			goto exit;
+		}
+	}
+
+	if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+		RTW_INFO("wpa_set_encryption, crypt.alg = WEP\n");
+
+		wep_key_idx = param->u.crypt.idx;
+		wep_key_len = param->u.crypt.key_len;
+
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		if (psecuritypriv->bWepDefaultKeyIdxSet == 0) {
+			/* wep default key has not been set, so use this key index as default key. */
+
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+
+			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+
+			if (wep_key_len == 13) {
+				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+			}
+
+			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
+		}
+
+		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
+
+		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
+
+		rtw_set_key(padapter, psecuritypriv, wep_key_idx, 0, _TRUE);
+
+		goto exit;
+	}
+
+	if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) { /* 802_1x */
+		struct sta_info *psta, *pbcmc_sta;
+		struct sta_priv *pstapriv = &padapter->stapriv;
+
+		/* RTW_INFO("%s, : dot11AuthAlgrthm == dot11AuthAlgrthm_8021X\n", __func__); */
+
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_MP_STATE) == _TRUE) { /* sta mode */
+#ifdef CONFIG_RTW_80211R
+			if (rtw_ft_roam(padapter))
+				psta = rtw_get_stainfo(pstapriv, pmlmepriv->assoc_bssid);
+			else
+#endif
+				psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+			if (psta == NULL) {
+				/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
+				RTW_INFO("%s, : Obtain Sta_info fail\n", __func__);
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
+					psta->ieee8021x_blocked = _FALSE;
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
+					psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+
+				if (param->u.crypt.set_tx == 1) { /* pairwise key */
+					RTW_INFO(FUNC_ADPT_FMT" set %s PTK idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0) { /* set mic key */
+						_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
+						_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
+						padapter->securitypriv.busetkipkey = _FALSE;
+					}
+					psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->bpairwise_key_installed = _TRUE;
+					#ifdef CONFIG_RTW_80211R
+					psta->ft_pairwise_key_installed = _TRUE;
+					#endif
+					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
+
+				} else { /* group key */
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set %s GTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
+						padapter->securitypriv.binstallGrpkey = _TRUE;
+						if (param->u.crypt.idx < 4) 
+							_rtw_memcpy(padapter->securitypriv.iv_seq[param->u.crypt.idx], param->u.crypt.seq, 8);							
+						padapter->securitypriv.dot118021XGrpKeyid = param->u.crypt.idx;
+						rtw_set_key(padapter, &padapter->securitypriv, param->u.crypt.idx, 1, _TRUE);
+
+					#ifdef CONFIG_IEEE80211W
+					} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set IGTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+						psecuritypriv->dot11wBIPrxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+						psecuritypriv->binstallBIPkey = _TRUE;
+					#endif /* CONFIG_IEEE80211W */
+
+					}
+
+#ifdef CONFIG_P2P
+					if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+						if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
+							rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_DONE);
+					}
+#endif /* CONFIG_P2P */
+
+				}
+			}
+
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta == NULL) {
+				/* DEBUG_ERR( ("Set OID_802_11_ADD_KEY: bcmc stainfo is null\n")); */
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
+					pbcmc_sta->ieee8021x_blocked = _FALSE;
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
+					pbcmc_sta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
+			}
+		} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) { /* adhoc mode */
+		}
+	}
+
+	#ifdef CONFIG_WAPI_SUPPORT
+	if (strcmp(param->u.crypt.alg, "SMS4") == 0)
+		rtw_wapi_set_set_encryption(padapter, param);
+	#endif
+
+exit:
+
+	RTW_INFO("%s, ret=%d\n", __func__, ret);
+
+
+	return ret;
+}
+
+static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev
+	, u8 key_index
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	, bool pairwise
+#endif
+	, const u8 *mac_addr, struct key_params *params)
+{
+	char *alg_name;
+	u32 param_len;
+	struct ieee_param *param = NULL;
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+#ifdef CONFIG_TDLS
+	struct sta_info *ptdls_sta;
+#endif /* CONFIG_TDLS */
+
+	if (mac_addr)
+		RTW_INFO(FUNC_NDEV_FMT" adding key for %pM\n", FUNC_NDEV_ARG(ndev), mac_addr);
+	RTW_INFO(FUNC_NDEV_FMT" cipher=0x%x\n", FUNC_NDEV_ARG(ndev), params->cipher);
+	RTW_INFO(FUNC_NDEV_FMT" key_len=%d, key_index=%d\n", FUNC_NDEV_ARG(ndev), params->key_len, key_index);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	RTW_INFO(FUNC_NDEV_FMT" pairwise=%d\n", FUNC_NDEV_ARG(ndev), pairwise);
+#endif
+
+	if (rtw_cfg80211_sync_iftype(padapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto addkey_end;
+	}
+
+	param_len = sizeof(struct ieee_param) + params->key_len;
+	param = rtw_malloc(param_len);
+	if (param == NULL)
+		return -1;
+
+	_rtw_memset(param, 0, param_len);
+
+	param->cmd = IEEE_CMD_SET_ENCRYPTION;
+	_rtw_memset(param->sta_addr, 0xff, ETH_ALEN);
+
+	switch (params->cipher) {
+	case IW_AUTH_CIPHER_NONE:
+		/* todo: remove key */
+		/* remove = 1;	 */
+		alg_name = "none";
+		break;
+	case WLAN_CIPHER_SUITE_WEP40:
+	case WLAN_CIPHER_SUITE_WEP104:
+		alg_name = "WEP";
+		break;
+	case WLAN_CIPHER_SUITE_TKIP:
+		alg_name = "TKIP";
+		break;
+	case WLAN_CIPHER_SUITE_CCMP:
+		alg_name = "CCMP";
+		break;
+#ifdef CONFIG_IEEE80211W
+	case WLAN_CIPHER_SUITE_AES_CMAC:
+		alg_name = "BIP";
+		break;
+#endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_WAPI_SUPPORT
+	case WLAN_CIPHER_SUITE_SMS4:
+		alg_name = "SMS4";
+		if (pairwise == NL80211_KEYTYPE_PAIRWISE) {
+			if (key_index != 0 && key_index != 1) {
+				ret = -ENOTSUPP;
+				goto addkey_end;
+			}
+			_rtw_memcpy((void *)param->sta_addr, (void *)mac_addr, ETH_ALEN);
+		} else
+			RTW_INFO("mac_addr is null\n");
+		RTW_INFO("rtw_wx_set_enc_ext: SMS4 case\n");
+		break;
+#endif
+
+	default:
+		ret = -ENOTSUPP;
+		goto addkey_end;
+	}
+
+	strncpy((char *)param->u.crypt.alg, alg_name, IEEE_CRYPT_ALG_NAME_LEN);
+
+
+	if (!mac_addr || is_broadcast_ether_addr(mac_addr)
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		|| !pairwise
+		#endif
+	) {
+		param->u.crypt.set_tx = 0; /* for wpa/wpa2 group key */
+	} else {
+		param->u.crypt.set_tx = 1; /* for wpa/wpa2 pairwise key */
+	}
+
+	param->u.crypt.idx = key_index;
+
+	if (params->seq_len && params->seq) {
+		_rtw_memcpy(param->u.crypt.seq, (u8 *)params->seq, params->seq_len);
+		RTW_INFO(FUNC_NDEV_FMT" seq_len:%u, seq:0x%llx\n", FUNC_NDEV_ARG(ndev)
+			, params->seq_len, RTW_GET_LE64(param->u.crypt.seq));
+	}
+
+	if (params->key_len && params->key) {
+		param->u.crypt.key_len = params->key_len;
+		_rtw_memcpy(param->u.crypt.key, (u8 *)params->key, params->key_len);
+	}
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+#ifdef CONFIG_TDLS
+		if (rtw_tdls_is_driver_setup(padapter) == _FALSE && mac_addr) {
+			ptdls_sta = rtw_get_stainfo(&padapter->stapriv, (void *)mac_addr);
+			if (ptdls_sta != NULL && ptdls_sta->tdls_sta_state) {
+				_rtw_memcpy(ptdls_sta->tpk.tk, params->key, params->key_len);
+				rtw_tdls_set_key(padapter, ptdls_sta);
+				goto addkey_end;
+			}
+		}
+#endif /* CONFIG_TDLS */
+		ret = rtw_cfg80211_set_encryption(ndev, param);
+	} else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+#ifdef CONFIG_AP_MODE
+		if (mac_addr)
+			_rtw_memcpy(param->sta_addr, (void *)mac_addr, ETH_ALEN);
+
+		ret = rtw_cfg80211_ap_set_encryption(ndev, param);
+#endif
+	} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE
+		|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE
+	) {
+		/* RTW_INFO("@@@@@@@@@@ fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype); */
+		ret = rtw_cfg80211_set_encryption(ndev, param);
+	} else
+		RTW_INFO("error! fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype);
+
+
+addkey_end:
+	if (param)
+		rtw_mfree(param, param_len);
+
+	return ret;
+
+}
+
+static int cfg80211_rtw_get_key(struct wiphy *wiphy, struct net_device *ndev
+	, u8 keyid
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	, bool pairwise
+#endif
+	, const u8 *mac_addr, void *cookie
+	, void (*callback)(void *cookie, struct key_params *))
+{
+#define GET_KEY_PARAM_FMT_S " keyid=%d"
+#define GET_KEY_PARAM_ARG_S , keyid
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	#define GET_KEY_PARAM_FMT_2_6_37 ", pairwise=%d"
+	#define GET_KEY_PARAM_ARG_2_6_37 , pairwise
+#else
+	#define GET_KEY_PARAM_FMT_2_6_37 ""
+	#define GET_KEY_PARAM_ARG_2_6_37
+#endif
+#define GET_KEY_PARAM_FMT_E ", addr=%pM"
+#define GET_KEY_PARAM_ARG_E , mac_addr
+
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv *sec = &adapter->securitypriv;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta = NULL;
+	u32 cipher = _NO_PRIVACY_;
+	union Keytype *key = NULL;
+	u8 key_len = 0;
+	u64 *pn = NULL;
+	u8 pn_len = 0;
+	u8 pn_val[8] = {0};
+
+	struct key_params params;
+	int ret = -ENOENT;
+
+	if (keyid >= WEP_KEYS
+		#ifdef CONFIG_IEEE80211W
+		&& keyid > BIP_MAX_KEYID
+		#endif
+	)
+		goto exit;
+
+	if (!mac_addr || is_broadcast_ether_addr(mac_addr)
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		|| (MLME_IS_STA(adapter) && !pairwise)
+		#endif
+	) {	
+		/* WEP key, TX GTK/IGTK, RX GTK/IGTK(for STA mode) */
+		if (is_wep_enc(sec->dot118021XGrpPrivacy)) {
+			if (keyid >= WEP_KEYS)
+				goto exit;
+			if (!(sec->key_mask & BIT(keyid)))
+				goto exit;
+			cipher = sec->dot118021XGrpPrivacy;
+			key = &sec->dot11DefKey[keyid];
+		} else {
+			if (keyid < WEP_KEYS) {
+				if (sec->binstallGrpkey != _TRUE)
+					goto exit;
+				cipher = sec->dot118021XGrpPrivacy;
+				key = &sec->dot118021XGrpKey[keyid];
+				sta = rtw_get_bcmc_stainfo(adapter);
+				if (sta)
+					pn = &sta->dot11txpn.val;
+			#ifdef CONFIG_IEEE80211W
+			} else if (keyid < BIP_MAX_KEYID) {
+				if (SEC_IS_BIP_KEY_INSTALLED(sec) != _TRUE)
+					goto exit;
+				cipher = _BIP_;
+				key = &sec->dot11wBIPKey[keyid];
+				pn = &sec->dot11wBIPtxpn.val;
+			#endif
+			}
+		}
+	} else {
+		/* Pairwise key, RX GTK/IGTK for specific peer */
+		sta = rtw_get_stainfo(stapriv, mac_addr);
+		if (!sta)
+			goto exit;
+
+		if (keyid < WEP_KEYS && pairwise) {
+			if (sta->bpairwise_key_installed != _TRUE)
+				goto exit;
+			cipher = sta->dot118021XPrivacy;
+			key = &sta->dot118021x_UncstKey;
+		#ifdef CONFIG_RTW_MESH
+		} else if (keyid < WEP_KEYS && !pairwise) {
+			if (!(sta->gtk_bmp & BIT(keyid)))
+				goto exit;
+			cipher = sta->group_privacy;
+			key = &sta->gtk;
+		#ifdef CONFIG_IEEE80211W
+		} else if (keyid < BIP_MAX_KEYID && !pairwise) {
+			if (!(sta->igtk_bmp & BIT(keyid)))
+				goto exit;
+			cipher = _BIP_;
+			key = &sta->igtk;
+			pn = &sta->igtk_pn.val;
+		#endif
+		#endif /* CONFIG_RTW_MESH */
+		}
+	}
+
+	if (!key)
+		goto exit;
+
+	if (cipher == _WEP40_) {
+		cipher = WLAN_CIPHER_SUITE_WEP40;
+		key_len = sec->dot11DefKeylen[keyid];
+	} else if (cipher == _WEP104_) {
+		cipher = WLAN_CIPHER_SUITE_WEP104;
+		key_len = sec->dot11DefKeylen[keyid];
+	} else if (cipher == _TKIP_) {
+		cipher = WLAN_CIPHER_SUITE_TKIP;
+		key_len = 16;
+	} else if (cipher == _AES_) {
+		cipher = WLAN_CIPHER_SUITE_CCMP;
+		key_len = 16;
+	#ifdef CONFIG_IEEE80211W
+	} else if (cipher == _BIP_) {
+		cipher = WLAN_CIPHER_SUITE_AES_CMAC;
+		key_len = 16;
+	#endif
+	} else {
+		RTW_WARN(FUNC_NDEV_FMT" unknown cipher:%u\n", FUNC_NDEV_ARG(ndev), cipher);
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (pn) {
+		*((u64 *)pn_val) = cpu_to_le64(*pn);
+		pn_len = 6;
+	}
+
+	ret = 0;
+	
+exit:
+	RTW_INFO(FUNC_NDEV_FMT
+		GET_KEY_PARAM_FMT_S
+		GET_KEY_PARAM_FMT_2_6_37
+		GET_KEY_PARAM_FMT_E
+		" ret %d\n", FUNC_NDEV_ARG(ndev)
+		GET_KEY_PARAM_ARG_S
+		GET_KEY_PARAM_ARG_2_6_37
+		GET_KEY_PARAM_ARG_E
+		, ret);
+	if (pn)
+		RTW_INFO(FUNC_NDEV_FMT " seq:0x%llx\n", FUNC_NDEV_ARG(ndev), *pn);
+
+	if (ret == 0) {
+		_rtw_memset(&params, 0, sizeof(params));
+
+		params.cipher = cipher;
+		params.key = key->skey;
+		params.key_len = key_len;
+		if (pn) {
+			params.seq = pn_val;
+			params.seq_len = pn_len;
+		}
+
+		callback(cookie, &params);
+	}
+
+	return ret;
+}
+
+static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+				u8 key_index, bool pairwise, const u8 *mac_addr)
+#else	/* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
+				u8 key_index, const u8 *mac_addr)
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+
+	RTW_INFO(FUNC_NDEV_FMT" key_index=%d, addr=%pM\n", FUNC_NDEV_ARG(ndev), key_index, mac_addr);
+
+	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
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	, bool unicast, bool multicast
+	#endif
+)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+
+#define SET_DEF_KEY_PARAM_FMT " key_index=%d"
+#define SET_DEF_KEY_PARAM_ARG , key_index
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	#define SET_DEF_KEY_PARAM_FMT_2_6_38 ", unicast=%d, multicast=%d"
+	#define SET_DEF_KEY_PARAM_ARG_2_6_38 , unicast, multicast
+#else
+	#define SET_DEF_KEY_PARAM_FMT_2_6_38 ""
+	#define SET_DEF_KEY_PARAM_ARG_2_6_38
+#endif
+
+	RTW_INFO(FUNC_NDEV_FMT
+		SET_DEF_KEY_PARAM_FMT
+		SET_DEF_KEY_PARAM_FMT_2_6_38
+		"\n", FUNC_NDEV_ARG(ndev)
+		SET_DEF_KEY_PARAM_ARG
+		SET_DEF_KEY_PARAM_ARG_2_6_38
+	);
+
+	if ((key_index < WEP_KEYS) && ((psecuritypriv->dot11PrivacyAlgrthm == _WEP40_) || (psecuritypriv->dot11PrivacyAlgrthm == _WEP104_))) { /* set wep default key */
+		psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
+
+		psecuritypriv->dot11PrivacyKeyIndex = key_index;
+
+		psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+		psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+		if (psecuritypriv->dot11DefKeylen[key_index] == 13) {
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
+		}
+
+		psecuritypriv->bWepDefaultKeyIdxSet = 1; /* set the flag to represent that wep default key has been set */
+	}
+
+	return 0;
+
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 30))
+int cfg80211_rtw_set_default_mgmt_key(struct wiphy *wiphy,
+	struct net_device *ndev, u8 key_index)
+{
+#define SET_DEF_KEY_PARAM_FMT " key_index=%d"
+#define SET_DEF_KEY_PARAM_ARG , key_index
+
+	RTW_INFO(FUNC_NDEV_FMT
+		SET_DEF_KEY_PARAM_FMT
+		"\n", FUNC_NDEV_ARG(ndev)
+		SET_DEF_KEY_PARAM_ARG
+	);
+
+	return 0;
+}
+#endif
+
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
+static int cfg80211_rtw_set_rekey_data(struct wiphy *wiphy,
+	struct net_device *ndev,
+	struct cfg80211_gtk_rekey_data *data)
+{
+	/*int i;*/
+	struct sta_info *psta;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv   *pmlmepriv = &padapter->mlmepriv;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL) {
+		RTW_INFO("%s, : Obtain Sta_info fail\n", __func__);
+		return -1;
+	}
+
+	_rtw_memcpy(psta->kek, data->kek, NL80211_KEK_LEN);
+	/*printk("\ncfg80211_rtw_set_rekey_data KEK:");
+	for(i=0;i<NL80211_KEK_LEN; i++)
+		printk(" %02x ", psta->kek[i]);*/
+	_rtw_memcpy(psta->kck, data->kck, NL80211_KCK_LEN);
+	/*printk("\ncfg80211_rtw_set_rekey_data KCK:");
+	for(i=0;i<NL80211_KCK_LEN; i++)
+		printk(" %02x ", psta->kck[i]);*/
+	_rtw_memcpy(psta->replay_ctr, data->replay_ctr, NL80211_REPLAY_CTR_LEN);
+	psecuritypriv->binstallKCK_KEK = _TRUE;
+	/*printk("\nREPLAY_CTR: ");
+	for(i=0;i<RTW_REPLAY_CTR_LEN; i++)
+		printk(" %02x ", psta->replay_ctr[i]);*/
+
+	return 0;
+}
+#endif /*CONFIG_GTK_OL*/
+
+#ifdef CONFIG_RTW_MESH
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+static enum nl80211_mesh_power_mode rtw_mesh_ps_to_nl80211_mesh_power_mode(u8 ps)
+{
+	if (ps == RTW_MESH_PS_UNKNOWN)
+		return NL80211_MESH_POWER_UNKNOWN;
+	if (ps == RTW_MESH_PS_ACTIVE)
+		return NL80211_MESH_POWER_ACTIVE;
+	if (ps == RTW_MESH_PS_LSLEEP)
+		return NL80211_MESH_POWER_LIGHT_SLEEP;
+	if (ps == RTW_MESH_PS_DSLEEP)
+		return NL80211_MESH_POWER_DEEP_SLEEP;
+
+	rtw_warn_on(1);
+	return NL80211_MESH_POWER_UNKNOWN;
+}
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+enum nl80211_plink_state rtw_plink_state_to_nl80211_plink_state(u8 plink_state)
+{
+	if (plink_state == RTW_MESH_PLINK_UNKNOWN)
+		return NUM_NL80211_PLINK_STATES;
+	if (plink_state == RTW_MESH_PLINK_LISTEN)
+		return NL80211_PLINK_LISTEN;
+	if (plink_state == RTW_MESH_PLINK_OPN_SNT)
+		return NL80211_PLINK_OPN_SNT;
+	if (plink_state == RTW_MESH_PLINK_OPN_RCVD)
+		return NL80211_PLINK_OPN_RCVD;
+	if (plink_state == RTW_MESH_PLINK_CNF_RCVD)
+		return NL80211_PLINK_CNF_RCVD;
+	if (plink_state == RTW_MESH_PLINK_ESTAB)
+		return NL80211_PLINK_ESTAB;
+	if (plink_state == RTW_MESH_PLINK_HOLDING)
+		return NL80211_PLINK_HOLDING;
+	if (plink_state == RTW_MESH_PLINK_BLOCKED)
+		return NL80211_PLINK_BLOCKED;
+
+	rtw_warn_on(1);
+	return NUM_NL80211_PLINK_STATES;
+}
+
+u8 nl80211_plink_state_to_rtw_plink_state(enum nl80211_plink_state plink_state)
+{
+	if (plink_state == NL80211_PLINK_LISTEN)
+		return RTW_MESH_PLINK_LISTEN;
+	if (plink_state == NL80211_PLINK_OPN_SNT)
+		return RTW_MESH_PLINK_OPN_SNT;
+	if (plink_state == NL80211_PLINK_OPN_RCVD)
+		return RTW_MESH_PLINK_OPN_RCVD;
+	if (plink_state == NL80211_PLINK_CNF_RCVD)
+		return RTW_MESH_PLINK_CNF_RCVD;
+	if (plink_state == NL80211_PLINK_ESTAB)
+		return RTW_MESH_PLINK_ESTAB;
+	if (plink_state == NL80211_PLINK_HOLDING)
+		return RTW_MESH_PLINK_HOLDING;
+	if (plink_state == NL80211_PLINK_BLOCKED)
+		return RTW_MESH_PLINK_BLOCKED;
+
+	rtw_warn_on(1);
+	return RTW_MESH_PLINK_UNKNOWN;
+}
+#endif
+
+static void rtw_cfg80211_fill_mesh_only_sta_info(struct mesh_plink_ent *plink, struct sta_info *sta, struct station_info *sinfo)
+{
+	sinfo->filled |= STATION_INFO_LLID;
+	sinfo->llid = plink->llid;
+	sinfo->filled |= STATION_INFO_PLID;
+	sinfo->plid = plink->plid;
+	sinfo->filled |= STATION_INFO_PLINK_STATE;
+	sinfo->plink_state = rtw_plink_state_to_nl80211_plink_state(plink->plink_state);
+	if (!sta && plink->scanned) {
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(plink->scanned->network.PhyInfo.SignalStrength);
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		if (plink->plink_state == RTW_MESH_PLINK_UNKNOWN)
+			sinfo->inactive_time = 0 - 1;
+		else
+			sinfo->inactive_time = rtw_get_passing_time_ms(plink->scanned->last_scanned);
+	}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (sta) {
+		sinfo->filled |= STATION_INFO_LOCAL_PM;
+		sinfo->local_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->local_mps);
+		sinfo->filled |= STATION_INFO_PEER_PM;
+		sinfo->peer_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->peer_mps);
+		sinfo->filled |= STATION_INFO_NONPEER_PM;
+		sinfo->nonpeer_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->nonpeer_mps);
+	}
+#endif
+}
+#endif /* CONFIG_RTW_MESH */
+
+static int cfg80211_rtw_get_station(struct wiphy *wiphy,
+	struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac,
+#else
+	const u8 *mac,
+#endif
+	struct station_info *sinfo)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct sta_info *psta = NULL;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink = NULL;
+#endif
+
+	sinfo->filled = 0;
+
+	if (!mac) {
+		RTW_INFO(FUNC_NDEV_FMT" mac==%p\n", FUNC_NDEV_ARG(ndev), mac);
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	psta = rtw_get_stainfo(pstapriv, mac);
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (!psta)
+			plink = rtw_mesh_plink_get(padapter, mac);
+		else
+			plink = psta->plink;
+	}
+#endif /* CONFIG_RTW_MESH */
+
+	if (!psta
+		#ifdef CONFIG_RTW_MESH
+		&& !plink
+		#endif
+	) {
+		RTW_INFO(FUNC_NDEV_FMT" no sta info for mac="MAC_FMT"\n"
+			, FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+		ret = -ENOENT;
+		goto exit;
+	}
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO(FUNC_NDEV_FMT" mac="MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+#endif
+
+	/* 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 (_rtw_memcmp((u8 *)mac, cur_network->network.MacAddress, ETH_ALEN) == _FALSE) {
+			RTW_INFO("%s, mismatch bssid="MAC_FMT"\n", __func__, MAC_ARG(cur_network->network.MacAddress));
+			ret = -ENOENT;
+			goto exit;
+		}
+
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);
+
+		sinfo->filled |= STATION_INFO_TX_BITRATE;
+		sinfo->txrate.legacy = rtw_get_cur_max_rate(padapter);
+	}
+
+	if (psta) {
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE
+			|| check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE
+		) {
+			sinfo->filled |= STATION_INFO_SIGNAL;
+			sinfo->signal = translate_percentage_to_dbm(psta->cmn.rssi_stat.rssi);
+		}
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		sinfo->inactive_time = rtw_get_passing_time_ms(psta->sta_stats.last_rx_time);
+		sinfo->filled |= STATION_INFO_RX_PACKETS;
+		sinfo->rx_packets = sta_rx_data_pkts(psta);
+		sinfo->filled |= STATION_INFO_TX_PACKETS;
+		sinfo->tx_packets = psta->sta_stats.tx_pkts;
+		sinfo->filled |= STATION_INFO_TX_FAILED;
+		sinfo->tx_failed = psta->sta_stats.tx_fail_cnt;
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_cfg80211_fill_mesh_only_sta_info(plink, psta, sinfo);
+#endif
+
+exit:
+	return ret;
+}
+
+extern int netdev_open(struct net_device *pnetdev);
+
+#if 0
+enum nl80211_iftype {
+	NL80211_IFTYPE_UNSPECIFIED,
+	NL80211_IFTYPE_ADHOC, /* 1 */
+	NL80211_IFTYPE_STATION, /* 2 */
+	NL80211_IFTYPE_AP, /* 3 */
+	NL80211_IFTYPE_AP_VLAN,
+	NL80211_IFTYPE_WDS,
+	NL80211_IFTYPE_MONITOR, /* 6 */
+	NL80211_IFTYPE_MESH_POINT,
+	NL80211_IFTYPE_P2P_CLIENT, /* 8 */
+	NL80211_IFTYPE_P2P_GO, /* 9 */
+	/* keep last */
+	NUM_NL80211_IFTYPES,
+	NL80211_IFTYPE_MAX = NUM_NL80211_IFTYPES - 1
+};
+#endif
+static int cfg80211_rtw_change_iface(struct wiphy *wiphy,
+				     struct net_device *ndev,
+				     enum nl80211_iftype type,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+				     u32 *flags,
+#endif
+				     struct vif_params *params)
+{
+	enum nl80211_iftype old_type;
+	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8 is_p2p = _FALSE;
+#endif
+	int ret = 0;
+	u8 change = _FALSE;
+
+	RTW_INFO(FUNC_NDEV_FMT" type=%d, hw_port:%d\n", FUNC_NDEV_ARG(ndev), type, padapter->hw_port);
+
+	if (adapter_to_dvobj(padapter)->processing_dev_remove == _TRUE) {
+		ret = -EPERM;
+		goto exit;
+	}
+
+
+	RTW_INFO(FUNC_NDEV_FMT" call netdev_open\n", FUNC_NDEV_ARG(ndev));
+	if (netdev_open(ndev) != 0) {
+		RTW_INFO(FUNC_NDEV_FMT" call netdev_open fail\n", FUNC_NDEV_ARG(ndev));
+		ret = -EPERM;
+		goto exit;
+	}
+
+
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		RTW_INFO(FUNC_NDEV_FMT" call rtw_pwr_wakeup fail\n", FUNC_NDEV_ARG(ndev));
+		ret = -EPERM;
+		goto exit;
+	}
+
+	old_type = rtw_wdev->iftype;
+	RTW_INFO(FUNC_NDEV_FMT" old_iftype=%d, new_iftype=%d\n",
+		FUNC_NDEV_ARG(ndev), old_type, type);
+
+	if (old_type != type) {
+		change = _TRUE;
+		pmlmeext->action_public_rxseq = 0xffff;
+		pmlmeext->action_public_dialog_token = 0xff;
+	}
+
+	/* initial default type */
+	ndev->type = ARPHRD_ETHER;
+
+	/*
+	 * Disable Power Save in moniter mode,
+	 * and enable it after leaving moniter mode.
+	 */
+	if (type == NL80211_IFTYPE_MONITOR) {
+		rtw_ps_deny(padapter, PS_DENY_MONITOR_MODE);
+		LeaveAllPowerSaveMode(padapter);
+	} else if (old_type == NL80211_IFTYPE_MONITOR) {
+		/* driver in moniter mode in last time */
+		rtw_ps_deny_cancel(padapter, PS_DENY_MONITOR_MODE);
+	}
+
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		networkType = Ndis802_11IBSS;
+		break;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+		is_p2p = _TRUE;
+	#endif
+	case NL80211_IFTYPE_STATION:
+		networkType = Ndis802_11Infrastructure;
+
+		#ifdef CONFIG_P2P
+		if (change && pwdinfo->driver_interface == DRIVER_CFG80211) {
+			if (is_p2p == _TRUE)
+				rtw_p2p_enable(padapter, P2P_ROLE_CLIENT);
+			#if !RTW_P2P_GROUP_INTERFACE
+			else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)
+					|| rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)
+			) {
+				/* it means remove GC/GO and change mode from GC/GO to station(P2P DEVICE) */
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
+			}
+			#endif
+		}
+		#endif /* CONFIG_P2P */
+
+		break;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+		is_p2p = _TRUE;
+	#endif
+	case NL80211_IFTYPE_AP:
+		networkType = Ndis802_11APMode;
+
+		#ifdef CONFIG_P2P
+		if (change && pwdinfo->driver_interface == DRIVER_CFG80211) {
+			if (is_p2p == _TRUE)
+				rtw_p2p_enable(padapter, P2P_ROLE_GO);
+			#if !RTW_P2P_GROUP_INTERFACE
+			else if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+				/* it means P2P Group created, we will be GO and change mode from  P2P DEVICE to AP(GO) */
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
+			}
+			#endif
+		}
+		#endif /* CONFIG_P2P */
+
+		break;
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		networkType = Ndis802_11_mesh;
+		break;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		networkType = Ndis802_11Monitor;
+#if 0
+		ndev->type = ARPHRD_IEEE80211; /* IEEE 802.11 : 801 */
+#endif
+		ndev->type = ARPHRD_IEEE80211_RADIOTAP; /* IEEE 802.11 + radiotap header : 803 */
+		break;
+	default:
+		ret = -EOPNOTSUPP;
+		goto exit;
+	}
+
+	rtw_wdev->iftype = type;
+
+	if (rtw_set_802_11_infrastructure_mode(padapter, networkType) == _FALSE) {
+		rtw_wdev->iftype = old_type;
+		ret = -EPERM;
+		goto exit;
+	}
+
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
+
+exit:
+
+	RTW_INFO(FUNC_NDEV_FMT" ret:%d\n", FUNC_NDEV_ARG(ndev), ret);
+	return ret;
+}
+
+void rtw_cfg80211_indicate_scan_done(_adapter *adapter, bool aborted)
+{
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	_irqL	irqL;
+
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+	struct cfg80211_scan_info info;
+
+	memset(&info, 0, sizeof(info));
+	info.aborted = aborted;
+#endif
+
+	_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+	if (pwdev_priv->scan_request != NULL) {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("%s with scan req\n", __FUNCTION__);
+		#endif
+
+		/* avoid WARN_ON(request != wiphy_to_dev(request->wiphy)->scan_req); */
+		if (pwdev_priv->scan_request->wiphy != pwdev_priv->rtw_wdev->wiphy)
+			RTW_INFO("error wiphy compare\n");
+		else
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+			cfg80211_scan_done(pwdev_priv->scan_request, &info);
+#else
+			cfg80211_scan_done(pwdev_priv->scan_request, aborted);
+#endif
+
+		pwdev_priv->scan_request = NULL;
+	} else {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("%s without scan req\n", __FUNCTION__);
+		#endif
+	}
+	_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+}
+
+u32 rtw_cfg80211_wait_scan_req_empty(_adapter *adapter, u32 timeout_ms)
+{
+	struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+	u8 empty = _FALSE;
+	systime start;
+	u32 pass_ms;
+
+	start = rtw_get_current_time();
+
+	while (rtw_get_passing_time_ms(start) <= timeout_ms) {
+
+		if (RTW_CANNOT_RUN(adapter))
+			break;
+
+		if (!wdev_priv->scan_request) {
+			empty = _TRUE;
+			break;
+		}
+
+		rtw_msleep_os(10);
+	}
+
+	pass_ms = rtw_get_passing_time_ms(start);
+
+	if (empty == _FALSE && pass_ms > timeout_ms)
+		RTW_PRINT(FUNC_ADPT_FMT" pass_ms:%u, timeout\n"
+			, FUNC_ADPT_ARG(adapter), pass_ms);
+
+	return pass_ms;
+}
+
+void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork)
+{
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct wiphy *wiphy = pwdev->wiphy;
+	struct cfg80211_bss *bss = NULL;
+	WLAN_BSSID_EX select_network = pnetwork->network;
+
+	bss = cfg80211_get_bss(wiphy, NULL/*notify_channel*/,
+		select_network.MacAddress, select_network.Ssid.Ssid,
 		select_network.Ssid.SsidLength,
 #if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0)
 		select_network.InfrastructureMode == Ndis802_11Infrastructure?IEEE80211_BSS_TYPE_ESS:IEEE80211_BSS_TYPE_IBSS,
@@ -2123,4893 +2520,7195 @@ void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork)
 		select_network.InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS,
 		select_network.InfrastructureMode == Ndis802_11Infrastructure?WLAN_CAPABILITY_ESS:WLAN_CAPABILITY_IBSS);
 #endif
-	
-	if (bss) {
-		cfg80211_unlink_bss(wiphy, bss);
-		DBG_8192C("%s(): cfg80211_unlink %s!! () ",__func__,select_network.Ssid.Ssid );
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
-		cfg80211_put_bss(padapter->rtw_wdev->wiphy, bss);
-#else
-		cfg80211_put_bss(bss);
-#endif
-	}
-	return;
-}
-
-void rtw_cfg80211_surveydone_event_callback(_adapter *padapter)
-{
-	_irqL	irqL;
-	_list					*plist, *phead;	
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);	
-	_queue				*queue	= &(pmlmepriv->scanned_queue);	
-	struct	wlan_network	*pnetwork = NULL;
-	u32 cnt=0;
-	u32 wait_for_surveydone;
-	sint wait_status;
-#ifdef CONFIG_P2P
-	struct	wifidirect_info*	pwdinfo = &padapter->wdinfo;
-#endif //CONFIG_P2P
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("%s\n", __func__);
-#endif
-
-	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-
-	phead = get_list_head(queue);
-	plist = get_next(phead);
-       
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
-			break;
-
-		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-
-		//report network only if the current channel set contains the channel to which this network belongs
-		if(rtw_ch_set_search_ch(padapter->mlmeextpriv.channel_set, pnetwork->network.Configuration.DSConfig) >= 0
-			&& rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
-			&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
-		)
-		{		
-			//ev=translate_scan(padapter, a, pnetwork, ev, stop);
-			rtw_cfg80211_inform_bss(padapter, pnetwork);		
-		}
-		/* //check ralink testbed RSN IE length
-		{
-			if(_rtw_memcmp(pnetwork->network.Ssid.Ssid, "Ralink_11n_AP",13))
-			{
-				uint ie_len=0;
-				u8 *p=NULL;
-				p = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
-				DBG_871X("ie_len=%d\n", ie_len);
-			}
-		}*/
-		plist = get_next(plist);
-	
-	}
-	
-	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-}
-
-static int rtw_cfg80211_set_probe_req_wpsp2pie(_adapter *padapter, char *buf, int len)
-{
-	int ret = 0;
-	uint wps_ielen = 0;
-	u8 *wps_ie;
-	u32	p2p_ielen = 0;	
-	u8 *p2p_ie;
-	u32	wfd_ielen = 0;	
-	u8 *wfd_ie;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("%s, ielen=%d\n", __func__, len);
-#endif
-	
-	if(len>0)
-	{
-		if((wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen)))
-		{
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("probe_req_wps_ielen=%d\n", wps_ielen);
-			#endif
-			
-			if(pmlmepriv->wps_probe_req_ie)
-			{
-				u32 free_len = pmlmepriv->wps_probe_req_ie_len;
-				pmlmepriv->wps_probe_req_ie_len = 0;
-				rtw_mfree(pmlmepriv->wps_probe_req_ie, free_len);
-				pmlmepriv->wps_probe_req_ie = NULL;			
-			}	
-
-			pmlmepriv->wps_probe_req_ie = rtw_malloc(wps_ielen);
-			if ( pmlmepriv->wps_probe_req_ie == NULL) {
-				DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-				return -EINVAL;
-			
-			}
-			_rtw_memcpy(pmlmepriv->wps_probe_req_ie, wps_ie, wps_ielen);
-			pmlmepriv->wps_probe_req_ie_len = wps_ielen;
-		}
-
-		//buf += wps_ielen;
-		//len -= wps_ielen;
-
-		#ifdef CONFIG_P2P
-		if((p2p_ie=rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen))) 
-		{
-			struct wifidirect_info *wdinfo = &padapter->wdinfo;
-			u32 attr_contentlen = 0;
-			u8 listen_ch_attr[5];
-
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("probe_req_p2p_ielen=%d\n", p2p_ielen);
-			#endif
-			
-			if(pmlmepriv->p2p_probe_req_ie)
-			{
-				u32 free_len = pmlmepriv->p2p_probe_req_ie_len;
-				pmlmepriv->p2p_probe_req_ie_len = 0;
-				rtw_mfree(pmlmepriv->p2p_probe_req_ie, free_len);
-				pmlmepriv->p2p_probe_req_ie = NULL;
-			}	
-
-			pmlmepriv->p2p_probe_req_ie = rtw_malloc(p2p_ielen);
-			if ( pmlmepriv->p2p_probe_req_ie == NULL) {
-				DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-				return -EINVAL;
-			
-			}
-			_rtw_memcpy(pmlmepriv->p2p_probe_req_ie, p2p_ie, p2p_ielen);
-			pmlmepriv->p2p_probe_req_ie_len = p2p_ielen;
-
-			if(rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, (u8*)listen_ch_attr, (uint*) &attr_contentlen)
-				&& attr_contentlen == 5)
-			{
-				if (wdinfo->listen_channel !=  listen_ch_attr[4]) {
-					DBG_871X(FUNC_ADPT_FMT" listen channel - country:%c%c%c, class:%u, ch:%u\n",
-						FUNC_ADPT_ARG(padapter), listen_ch_attr[0], listen_ch_attr[1], listen_ch_attr[2],
-						listen_ch_attr[3], listen_ch_attr[4]);
-					wdinfo->listen_channel = listen_ch_attr[4];
-				}
-			}
-		}
-		#endif //CONFIG_P2P
-
-		#ifdef CONFIG_WFD
-		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
-		if (wfd_ie) {
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("probe_req_wfd_ielen=%d\n", wfd_ielen);
-			#endif
-
-			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_PROBE_REQ_IE, wfd_ie, wfd_ielen) != _SUCCESS)
-				return -EINVAL;
-		}
-		#endif /* CONFIG_WFD */
-	}
-
-	return ret;
-	
-}
-
-static int cfg80211_rtw_scan(struct wiphy *wiphy
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
-	, struct net_device *ndev
-	#endif
-	, struct cfg80211_scan_request *request)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct net_device *ndev = wdev_to_ndev(request->wdev);
-#endif
-	int i;
-	u8 _status = _FALSE;
-	int ret = 0;	
-	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];
-	struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
-	_irqL	irqL;
-	u8 *wps_ie=NULL;
-	uint wps_ielen=0;	
-	u8 *p2p_ie=NULL;
-	uint p2p_ielen=0;
-	u8 survey_times=3;
-	u8 survey_times_for_one_ch=6;
-	struct cfg80211_ssid *ssids = request->ssids;
-	int social_channel = 0, j = 0;
-	bool need_indicate_scan_done = _FALSE;
-	bool ps_denied = _FALSE;
-
-	_adapter *padapter;
-	struct rtw_wdev_priv *pwdev_priv;
-	struct mlme_priv *pmlmepriv;
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo;
-#endif //CONFIG_P2P
-#ifdef CONFIG_CONCURRENT_MODE	
-	PADAPTER pbuddy_adapter = NULL;
-	struct mlme_priv *pbuddy_mlmepriv = NULL;
-#endif //CONFIG_CONCURRENT_MODE
-
-	if (ndev == NULL) {
-		ret = -EINVAL;
-		goto exit;
-	}
-
-	padapter = (_adapter *)rtw_netdev_priv(ndev);
-	pwdev_priv = adapter_wdev_data(padapter);
-	pmlmepriv= &padapter->mlmepriv;
-#ifdef CONFIG_P2P
-	pwdinfo= &(padapter->wdinfo);	
-#endif //CONFIG_P2P
-
-//#ifdef CONFIG_DEBUG_CFG80211
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-//#endif
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->pbuddy_adapter) {
-		pbuddy_adapter = padapter->pbuddy_adapter;
-		pbuddy_mlmepriv = &(pbuddy_adapter->mlmepriv);	
-	}
-#endif //CONFIG_CONCURRENT_MODE
-
-#ifdef CONFIG_MP_INCLUDED
-if (padapter->registrypriv.mp_mode == 1)
-{
-		DBG_871X(FUNC_ADPT_FMT ": MP mode block Scan request\n", FUNC_ADPT_ARG(padapter));  
-		ret = -EPERM;
-		goto exit;
-}
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->pbuddy_adapter) {
-		if (padapter->pbuddy_adapter->registrypriv.mp_mode == 1)
-		{
-			DBG_871X(FUNC_ADPT_FMT ": MP mode block Scan request\n", FUNC_ADPT_ARG(padapter->pbuddy_adapter));
-			ret = -EPERM;
-			goto exit;
-		}
-	}
-#endif //CONFIG_CONCURRENT_MODE
-#endif
-
-	_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-	pwdev_priv->scan_request = request;
-	_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-
-	if (adapter_wdev_data(padapter)->block_scan == _TRUE) {
-		DBG_871X(FUNC_ADPT_FMT" wdev_priv.block_scan is set\n", FUNC_ADPT_ARG(padapter));
-		need_indicate_scan_done = _TRUE;
-		goto check_need_indicate_scan_done;
-	}
-
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
-#ifdef CONFIG_DEBUG_CFG80211
-		DBG_871X("%s under WIFI_AP_STATE\n", __FUNCTION__);
-#endif
-
-		if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS|_FW_UNDER_SURVEY|_FW_UNDER_LINKING) == _TRUE)
-		{
-			DBG_8192C("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
-
-			if(check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
-			{
-				DBG_8192C("AP mode process WPS \n");
-			}
-			
-			need_indicate_scan_done = _TRUE;
-			goto check_need_indicate_scan_done;
-		} 
-	}
-
-	rtw_ps_deny(padapter, PS_DENY_SCAN);
-	ps_denied = _TRUE;
-	if(_FAIL == rtw_pwr_wakeup(padapter)) {
-		need_indicate_scan_done = _TRUE;
-		goto check_need_indicate_scan_done;
-	}
-
-	#ifdef CONFIG_P2P
-	if( pwdinfo->driver_interface == DRIVER_CFG80211 )
-	{
-		if(ssids->ssid != NULL
-			&& _rtw_memcmp(ssids->ssid, "DIRECT-", 7)
-			&& rtw_get_p2p_ie((u8 *)request->ie, request->ie_len, NULL, NULL)
-		)
-		{
-			if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-			{
-				rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
-				adapter_wdev_data(padapter)->p2p_enabled = _TRUE;
-			}
-			else
-			{
-				rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
-				#ifdef CONFIG_DEBUG_CFG80211
-				DBG_8192C("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
-				#endif
-			}
-			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
-		
-			if(request->n_channels == 3 &&
-				request->channels[0]->hw_value == 1 &&
-				request->channels[1]->hw_value == 6 &&
-				request->channels[2]->hw_value == 11
-			)
-			{
-				social_channel = 1;
-			}
-		}
-	}
-	#endif //CONFIG_P2P
-
-	if(request->ie && request->ie_len>0)
-	{
-		rtw_cfg80211_set_probe_req_wpsp2pie(padapter, (u8 *)request->ie, request->ie_len );
-	}
-
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
-		DBG_8192C("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
-		need_indicate_scan_done = _TRUE;
-		goto check_need_indicate_scan_done;
-	} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
-		DBG_8192C("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
-		ret = -EBUSY;
-		goto check_need_indicate_scan_done;
-	}
-
-	if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE)
-	{
-#if 1 // Miracast can't do AP scan
-		static u32 lastscantime = 0;
-		u32 passtime;
-
-		passtime = rtw_get_passing_time_ms(lastscantime);
-		lastscantime = rtw_get_current_time();
-		if (passtime > BUSY_TRAFFIC_SCAN_DENY_PERIOD)
-#endif
-		{
-			DBG_871X("%s: bBusyTraffic == _TRUE\n", __FUNCTION__);
-			need_indicate_scan_done = _TRUE;
-			goto check_need_indicate_scan_done;
-		}
-	}
-
-	if (rtw_is_scan_deny(padapter)){
-		DBG_871X(FUNC_ADPT_FMT  ": scan deny\n", FUNC_ADPT_ARG(padapter));
-		need_indicate_scan_done = _TRUE;
-		goto check_need_indicate_scan_done;
-	}
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if(pbuddy_mlmepriv && (pbuddy_mlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE))	
-	{
-#if 1 // Miracast can't do AP scan
-		static u32 buddylastscantime = 0;
-		u32 passtime;
-
-		passtime = rtw_get_passing_time_ms(buddylastscantime);
-		buddylastscantime = rtw_get_current_time();
-		if ((passtime > BUSY_TRAFFIC_SCAN_DENY_PERIOD)
-//#ifdef CONFIG_P2P
-//			||(!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE))
-//#endif //CONFIG_P2P
-		)
-#endif
-		{
-			DBG_871X("%s: bBusyTraffic == _TRUE at buddy_intf\n", __FUNCTION__);
-			need_indicate_scan_done = _TRUE;
-			goto check_need_indicate_scan_done;
-		}
-	}
-
-	if (check_buddy_fwstate(padapter, _FW_UNDER_LINKING|WIFI_UNDER_WPS) == _TRUE) {
-		DBG_871X("buddy_intf's mlme state:0x%x\n", pbuddy_mlmepriv->fw_state);
-		need_indicate_scan_done = _TRUE;
-		goto check_need_indicate_scan_done;
-
-	} else if (check_buddy_fwstate(padapter, _FW_UNDER_SURVEY)) {
-		bool scan_via_buddy = _FALSE;
-		struct rtw_wdev_priv *buddy_wdev_priv = adapter_wdev_data(pbuddy_adapter);
-
-		_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-		_enter_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
-		if (buddy_wdev_priv->scan_request) {
-			DBG_871X("scan via buddy\n");
-			pmlmepriv->scanning_via_buddy_intf = _TRUE;
-			_enter_critical_bh(&pmlmepriv->lock, &irqL);
-			set_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
-			_exit_critical_bh(&pmlmepriv->lock, &irqL);
-			scan_via_buddy = _TRUE;
-		}
-		_exit_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
-		_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
-
-		if (scan_via_buddy == _FALSE)
-			need_indicate_scan_done = _TRUE;
-
-		goto check_need_indicate_scan_done;
-	}
-#endif /* CONFIG_CONCURRENT_MODE */
-
-#ifdef CONFIG_P2P
-	if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
-	{
-		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
-		rtw_free_network_queue(padapter, _TRUE);
-
-		if(social_channel == 0)
-			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
-		else
-			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_SOCIAL_LAST);
-	}
-#endif //CONFIG_P2P
-
-
-	_rtw_memset(ssid, 0, sizeof(NDIS_802_11_SSID)*RTW_SSID_SCAN_AMOUNT);
-	//parsing request ssids, n_ssids
-	for (i = 0; i < request->n_ssids && i < RTW_SSID_SCAN_AMOUNT; i++) {
-		#ifdef CONFIG_DEBUG_CFG80211
-		DBG_8192C("ssid=%s, len=%d\n", ssids[i].ssid, ssids[i].ssid_len);
-		#endif
-		_rtw_memcpy(ssid[i].Ssid, ssids[i].ssid, ssids[i].ssid_len);
-		ssid[i].SsidLength = ssids[i].ssid_len;	
-	}
-
-	/* parsing channels, n_channels */
-	_rtw_memset(ch, 0, sizeof(struct rtw_ieee80211_channel)*RTW_CHANNEL_SCAN_AMOUNT);
-	for (i=0;i<request->n_channels && i<RTW_CHANNEL_SCAN_AMOUNT;i++) {
-		#ifdef CONFIG_DEBUG_CFG80211
-		DBG_871X(FUNC_ADPT_FMT CHAN_FMT"\n", FUNC_ADPT_ARG(padapter), CHAN_ARG(request->channels[i]));
-		#endif
-		ch[i].hw_value = request->channels[i]->hw_value;
-		ch[i].flags = request->channels[i]->flags;
-	}
-
-	_enter_critical_bh(&pmlmepriv->lock, &irqL);
-	if (request->n_channels == 1) {
-		for(i=1;i<survey_times_for_one_ch;i++)
-			_rtw_memcpy(&ch[i], &ch[0], sizeof(struct rtw_ieee80211_channel));
-		_status = rtw_sitesurvey_cmd(padapter, ssid, RTW_SSID_SCAN_AMOUNT, ch, survey_times_for_one_ch);
-	} else if (request->n_channels <= 4) {
-		for(j=request->n_channels-1;j>=0;j--)
-			for(i=0;i<survey_times;i++)
-		{
-			_rtw_memcpy(&ch[j*survey_times+i], &ch[j], sizeof(struct rtw_ieee80211_channel));
-		}
-		_status = rtw_sitesurvey_cmd(padapter, ssid, RTW_SSID_SCAN_AMOUNT, ch, survey_times * request->n_channels);
-	} else {
-		_status = rtw_sitesurvey_cmd(padapter, ssid, RTW_SSID_SCAN_AMOUNT, NULL, 0);
-	}
-	_exit_critical_bh(&pmlmepriv->lock, &irqL);
-
-
-	if(_status == _FALSE)
-	{
-		ret = -1;
-	}
-
-check_need_indicate_scan_done:
-	if (_TRUE == need_indicate_scan_done)
-	{
-		rtw_cfg80211_surveydone_event_callback(padapter);
-		rtw_cfg80211_indicate_scan_done(padapter, _FALSE);
-	}
-
-cancel_ps_deny:
-	if (ps_denied == _TRUE)
-		rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
-
-exit:
-	return ret;
-	
-}
-
-static int cfg80211_rtw_set_wiphy_params(struct wiphy *wiphy, u32 changed)
-{
-#if 0
-	struct iwm_priv *iwm = wiphy_to_iwm(wiphy);
-
-	if (changed & WIPHY_PARAM_RTS_THRESHOLD &&
-	    (iwm->conf.rts_threshold != wiphy->rts_threshold)) {
-		int ret;
-
-		iwm->conf.rts_threshold = wiphy->rts_threshold;
-
-		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_CFG_FIX,
-					     CFG_RTS_THRESHOLD,
-					     iwm->conf.rts_threshold);
-		if (ret < 0)
-			return ret;
-	}
-
-	if (changed & WIPHY_PARAM_FRAG_THRESHOLD &&
-	    (iwm->conf.frag_threshold != wiphy->frag_threshold)) {
-		int ret;
-
-		iwm->conf.frag_threshold = wiphy->frag_threshold;
-
-		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_FA_CFG_FIX,
-					     CFG_FRAG_THRESHOLD,
-					     iwm->conf.frag_threshold);
-		if (ret < 0)
-			return ret;
-	}
-#endif
-	DBG_8192C("%s\n", __func__);
-	return 0;
-}
-
-
-
-static int rtw_cfg80211_set_wpa_version(struct security_priv *psecuritypriv, u32 wpa_version)
-{	
-	DBG_8192C("%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;
-	}
-*/
-
-	#ifdef CONFIG_WAPI_SUPPORT
-	if (wpa_version & NL80211_WAPI_VERSION_1)
-	{
-		psecuritypriv->ndisauthtype = Ndis802_11AuthModeWAPI;
-	}
-	#endif
-
-	return 0;
-
-}
-
-static int rtw_cfg80211_set_auth_type(struct security_priv *psecuritypriv,
-			     enum nl80211_auth_type sme_auth_type)
-{
-	DBG_8192C("%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;
-		
-#ifdef CONFIG_WAPI_SUPPORT
-		if(psecuritypriv->ndisauthtype == Ndis802_11AuthModeWAPI)
-			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
-#endif
-
-		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_8192C("%s, ucast=%d, cipher=0x%x\n", __func__, ucast, cipher);
-
-
-	if (!cipher) {
-		*profile_cipher = _NO_PRIVACY_;
-		psecuritypriv->ndisencryptstatus = ndisencryptstatus;
-		return 0;
-	}
-	
-	switch (cipher) {
-	case IW_AUTH_CIPHER_NONE:
-		*profile_cipher = _NO_PRIVACY_;
-		ndisencryptstatus = Ndis802_11EncryptionDisabled;
-#ifdef CONFIG_WAPI_SUPPORT
-		if(psecuritypriv->dot11PrivacyAlgrthm ==_SMS4_ )
-		{
-			*profile_cipher = _SMS4_;
-		}
-#endif
-		break;
-	case WLAN_CIPHER_SUITE_WEP40:
-		*profile_cipher = _WEP40_;
-		ndisencryptstatus = Ndis802_11Encryption1Enabled;
-		break;
-	case WLAN_CIPHER_SUITE_WEP104:
-		*profile_cipher = _WEP104_;
-		ndisencryptstatus = Ndis802_11Encryption1Enabled;
-		break;
-	case WLAN_CIPHER_SUITE_TKIP:
-		*profile_cipher = _TKIP_;
-		ndisencryptstatus = Ndis802_11Encryption2Enabled;
-		break;
-	case WLAN_CIPHER_SUITE_CCMP:
-		*profile_cipher = _AES_;
-		ndisencryptstatus = Ndis802_11Encryption3Enabled;
-		break;
-#ifdef CONFIG_WAPI_SUPPORT
-	case WLAN_CIPHER_SUITE_SMS4:
-		*profile_cipher = _SMS4_;
-		ndisencryptstatus = Ndis802_11_EncrypteionWAPI;
-		break;
-#endif
-	default:
-		DBG_8192C("Unsupported cipher: 0x%x\n", cipher);
-		return -ENOTSUPP;
-	}
-
-	if(ucast)
-	{
-		psecuritypriv->ndisencryptstatus = ndisencryptstatus;
-		
-		//if(psecuritypriv->dot11PrivacyAlgrthm >= _AES_)
-		//	psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK;
-	}	
-
-	return 0;
-}
-
-static int rtw_cfg80211_set_key_mgt(struct security_priv *psecuritypriv, u32 key_mgt)
-{
-	DBG_8192C("%s, key_mgt=0x%x\n", __func__, key_mgt);
-
-	if (key_mgt == WLAN_AKM_SUITE_8021X)
-		//*auth_type = UMAC_AUTH_TYPE_8021X;
-		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-	else if (key_mgt == WLAN_AKM_SUITE_PSK) {
-		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-	}
-#ifdef CONFIG_WAPI_SUPPORT
-	else if(key_mgt ==WLAN_AKM_SUITE_WAPI_PSK){
-		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
-	}
-	else if(key_mgt ==WLAN_AKM_SUITE_WAPI_CERT){
-		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
-	}
-#endif
-
-
-	else {
-		DBG_8192C("Invalid key mgt: 0x%x\n", key_mgt);
-		//return -EINVAL;
-	}
-
-	return 0;
-}
-
-static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)
-{
-	u8 *buf=NULL, *pos=NULL;	
-	u32 left; 	
-	int group_cipher = 0, pairwise_cipher = 0;
-	int ret = 0;
-	int wpa_ielen=0;
-	int wpa2_ielen=0;
-	u8 *pwpa, *pwpa2;
-	u8 null_addr[]= {0,0,0,0,0,0};
-
-	if (pie == NULL || !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;
-	}
-
-	buf = rtw_zmalloc(ielen);
-	if (buf == NULL){
-		ret =  -ENOMEM;
-		goto exit;
-	}
-
-	_rtw_memcpy(buf, pie , ielen);
-
-	//dump
-	{
-		int i;
-		DBG_8192C("set wpa_ie(length:%zu):\n", ielen);
-		for(i=0;i<ielen;i=i+8)
-			DBG_8192C("0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x \n",buf[i],buf[i+1],buf[i+2],buf[i+3],buf[i+4],buf[i+5],buf[i+6],buf[i+7]);
-	}
-
-	pos = buf;
-	if(ielen < RSN_HEADER_LEN){
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("Ie len too short %d\n", ielen));
-		ret  = -1;
-		goto exit;
-	}
-
-	pwpa = rtw_get_wpa_ie(buf, &wpa_ielen, ielen);
-	if(pwpa && wpa_ielen>0)
-	{
-		if(rtw_parse_wpa_ie(pwpa, wpa_ielen+2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS)
-		{
-			padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_8021X;
-			padapter->securitypriv.ndisauthtype=Ndis802_11AuthModeWPAPSK;
-			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &pwpa[0], wpa_ielen+2);
-			
-			DBG_8192C("got wpa_ie, wpa_ielen:%u\n", wpa_ielen);
-		}
-	}
-
-	pwpa2 = rtw_get_wpa2_ie(buf, &wpa2_ielen, ielen);
-	if(pwpa2 && wpa2_ielen>0)
-	{
-		if(rtw_parse_wpa2_ie(pwpa2, wpa2_ielen+2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS)
-		{
-			padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_8021X;
-			padapter->securitypriv.ndisauthtype=Ndis802_11AuthModeWPA2PSK;	
-			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &pwpa2[0], wpa2_ielen+2);
-
-			DBG_8192C("got wpa2_ie, wpa2_ielen:%u\n", wpa2_ielen);
-		}
-	}
-
-	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=_NO_PRIVACY_;
-			padapter->securitypriv.ndisencryptstatus=Ndis802_11EncryptionDisabled;
-			break;
-		case WPA_CIPHER_WEP40:
-			padapter->securitypriv.dot118021XGrpPrivacy=_WEP40_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-			break;
-		case WPA_CIPHER_TKIP:
-			padapter->securitypriv.dot118021XGrpPrivacy=_TKIP_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
-			break;
-		case WPA_CIPHER_CCMP:
-			padapter->securitypriv.dot118021XGrpPrivacy=_AES_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
-			break;
-		case WPA_CIPHER_WEP104:	
-			padapter->securitypriv.dot118021XGrpPrivacy=_WEP104_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-			break;
-	}
-
-	switch(pairwise_cipher)
-	{
-		case WPA_CIPHER_NONE:
-			padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;
-			padapter->securitypriv.ndisencryptstatus=Ndis802_11EncryptionDisabled;
-			break;
-		case WPA_CIPHER_WEP40:
-			padapter->securitypriv.dot11PrivacyAlgrthm=_WEP40_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-			break;
-		case WPA_CIPHER_TKIP:
-			padapter->securitypriv.dot11PrivacyAlgrthm=_TKIP_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
-			break;
-		case WPA_CIPHER_CCMP:
-			padapter->securitypriv.dot11PrivacyAlgrthm=_AES_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
-			break;
-		case WPA_CIPHER_WEP104:	
-			padapter->securitypriv.dot11PrivacyAlgrthm=_WEP104_;
-			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-			break;
-	}
-	
-	{/* handle wps_ie */
-		uint wps_ielen;	
-		u8 *wps_ie;
-
-		wps_ie = rtw_get_wps_ie(buf, ielen, NULL, &wps_ielen);
-		if (wps_ie && wps_ielen > 0) {
-			DBG_8192C("got wps_ie, wps_ielen:%u\n", wps_ielen);
-			padapter->securitypriv.wps_ie_len = wps_ielen<MAX_WPS_IE_LEN?wps_ielen:MAX_WPS_IE_LEN;
-			_rtw_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);
-		}
-	}
-
-	#ifdef CONFIG_P2P
-	{//check p2p_ie for assoc req; 
-		uint p2p_ielen=0;
-		u8 *p2p_ie;
-		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-
-		if((p2p_ie=rtw_get_p2p_ie(buf, ielen, NULL, &p2p_ielen)))
-		{
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("%s p2p_assoc_req_ielen=%d\n", __FUNCTION__, p2p_ielen);
-			#endif
-
-			if(pmlmepriv->p2p_assoc_req_ie)
-			{
-				u32 free_len = pmlmepriv->p2p_assoc_req_ie_len;
-				pmlmepriv->p2p_assoc_req_ie_len = 0;
-				rtw_mfree(pmlmepriv->p2p_assoc_req_ie, free_len);
-				pmlmepriv->p2p_assoc_req_ie = NULL;
-			}
-
-			pmlmepriv->p2p_assoc_req_ie = rtw_malloc(p2p_ielen);
-			if ( pmlmepriv->p2p_assoc_req_ie == NULL) {
-				DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-				goto exit;
-			}
-			_rtw_memcpy(pmlmepriv->p2p_assoc_req_ie, p2p_ie, p2p_ielen);
-			pmlmepriv->p2p_assoc_req_ie_len = p2p_ielen;
-		}
-	}
-	#endif //CONFIG_P2P
-
-	#ifdef CONFIG_WFD
-	{
-		uint wfd_ielen=0;
-		u8 *wfd_ie;
-		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-
-		wfd_ie = rtw_get_wfd_ie(buf, ielen, NULL, &wfd_ielen);
-		if (wfd_ie) {
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("%s wfd_assoc_req_ielen=%d\n", __FUNCTION__, wfd_ielen);
-			#endif
-
-			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_ASSOC_REQ_IE, wfd_ie, wfd_ielen) != _SUCCESS)
-				goto exit;
-		}
-	}
-	#endif /* CONFIG_WFD */
-
-	//TKIP and AES disallow multicast packets until installing group key
-	if(padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_
-		|| padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_WTMIC_
-		|| padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)
-		//WPS open need to enable multicast
-		//|| check_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS) == _TRUE)
-		rtw_hal_set_hwreg(padapter, HW_VAR_OFF_RCR_AM, null_addr);
-
-	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 (buf)
-		rtw_mfree(buf, ielen);
-	if (ret)
-		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
-	return ret;
-}
-
-static int cfg80211_rtw_join_ibss(struct wiphy *wiphy, struct net_device *ndev,
-				  struct cfg80211_ibss_params *params)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	NDIS_802_11_SSID ndis_ssid;
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
-	struct cfg80211_chan_def *pch_def;
-#endif
-	struct ieee80211_channel *pch;
-	int ret=0;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
-	pch_def = (struct cfg80211_chan_def *)(&params->chandef); 
-	pch = (struct ieee80211_channel *) pch_def->chan;
-#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 31))
-	pch = (struct ieee80211_channel *)(params->channel); 
-#endif
-	
-	if(_FAIL == rtw_pwr_wakeup(padapter)) {
-		ret= -EPERM;
-		goto exit;
-	}
-
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-		ret = -EPERM;
-		goto exit;
-	}
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_UNDER_LINKING) == _TRUE) {
-		DBG_8192C("%s, but buddy_intf is under linking\n", __FUNCTION__);
-		ret = -EINVAL;
-		goto exit;
-	}
-	if (check_buddy_fwstate(padapter, _FW_UNDER_SURVEY) == _TRUE) {
-		rtw_scan_abort(padapter->pbuddy_adapter);
-	}
-#endif //CONFIG_CONCURRENT_MODE
-	
-	if (!params->ssid || !params->ssid_len)
-	{
-		ret = -EINVAL;
-		goto exit;
-	}
-
-	if (params->ssid_len > IW_ESSID_MAX_SIZE){
-
-		ret= -E2BIG;
-		goto exit;
-	}
-	
-	_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));			
-	ndis_ssid.SsidLength = params->ssid_len;
-	_rtw_memcpy(ndis_ssid.Ssid, (u8 *)params->ssid, params->ssid_len);
-
-	//DBG_8192C("ssid=%s, len=%zu\n", ndis_ssid.Ssid, params->ssid_len);
-	
-	psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
-	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
-	psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
-	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; //open system
-	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
-	
-	ret = rtw_cfg80211_set_auth_type(psecuritypriv, NL80211_AUTHTYPE_OPEN_SYSTEM);
-	rtw_set_802_11_authentication_mode(padapter, psecuritypriv->ndisauthtype);
-
-	DBG_871X("%s: center_freq = %d\n", __func__, pch->center_freq);
-	pmlmeext->cur_channel = rtw_freq2ch(pch->center_freq);
-	
-	if (rtw_set_802_11_ssid(padapter, &ndis_ssid) == _FALSE) 
-	{
-		ret = -1;
-		goto exit;
-	}	
-	
-exit:
-	return ret;
-}
-
-static int cfg80211_rtw_leave_ibss(struct wiphy *wiphy, struct net_device *ndev)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
-	enum nl80211_iftype old_type;
-	int ret = 0;
-
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	padapter->mlmepriv.not_indic_disco = _TRUE;
-	#endif
-	
-	old_type = rtw_wdev->iftype;
-	
-	rtw_set_to_roam(padapter, 0);
-
-	if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)) 
-	{
-		rtw_scan_abort(padapter);
-		LeaveAllPowerSaveMode(padapter);
-		
-		rtw_wdev->iftype = NL80211_IFTYPE_STATION;
-		
-		if (rtw_set_802_11_infrastructure_mode(padapter, Ndis802_11Infrastructure) ==_FALSE)
-		{
-			rtw_wdev->iftype = old_type;
-			ret = -EPERM;
-			goto leave_ibss;
-		}
-		rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure,_TRUE);	
-	}
-
-leave_ibss:
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	padapter->mlmepriv.not_indic_disco = _FALSE;
-	#endif
-
-	return 0;
-}
-
-static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,
-				 struct cfg80211_connect_params *sme)
-{
-	int ret=0;
-	_irqL irqL;	
-	_list *phead;	
-	struct wlan_network *pnetwork = NULL;
-	NDIS_802_11_AUTHENTICATION_MODE authmode;	
-	NDIS_802_11_SSID ndis_ssid;	
-	u8 *dst_ssid, *src_ssid;
-	u8 *dst_bssid, *src_bssid;
-	//u8 matched_by_bssid=_FALSE;
-	//u8 matched_by_ssid=_FALSE;
-	u8 matched=_FALSE;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;	
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-	_queue *queue = &pmlmepriv->scanned_queue;	
-
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	padapter->mlmepriv.not_indic_disco = _TRUE;
-	#endif
-	
-	DBG_871X("=>"FUNC_NDEV_FMT" - Start to Connection\n", FUNC_NDEV_ARG(ndev));
-	DBG_871X("privacy=%d, key=%p, key_len=%d, key_idx=%d, auth_type=%d\n",
-		sme->privacy, sme->key, sme->key_len, sme->key_idx, sme->auth_type);
-
-
-	if(adapter_wdev_data(padapter)->block == _TRUE)
-	{
-		ret = -EBUSY;
-		DBG_871X("%s wdev_priv.block is set\n", __FUNCTION__);
-		goto exit;
-	}
-
-#ifdef CONFIG_PLATFORM_MSTAR_SCAN_BEFORE_CONNECT
-	printk("MStar Android!\n");
-	if(adapter_wdev_data(padapter)->bandroid_scan == _FALSE)
-	{
-#ifdef CONFIG_P2P
-		struct wifidirect_info *pwdinfo= &(padapter->wdinfo);	
-		if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-#endif //CONFIG_P2P
-		{
-			ret = -EBUSY;
-			printk("Android hasn't attached yet!\n");
-			goto exit;
-		}	
-	}
-#endif
-
-	rtw_ps_deny(padapter, PS_DENY_JOIN);
-	if(_FAIL == rtw_pwr_wakeup(padapter)) {
-		ret= -EPERM;
-		goto exit;
-	}
-
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-		ret = -EPERM;
-		goto exit;
-	}
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_UNDER_LINKING) == _TRUE) {
-		DBG_8192C("%s, but buddy_intf is under linking\n", __FUNCTION__);
-		ret = -EINVAL;
-		goto exit;
-	}
-	if (check_buddy_fwstate(padapter, _FW_UNDER_SURVEY) == _TRUE) {
-		rtw_scan_abort(padapter->pbuddy_adapter);
-	}
-#endif
-
-	if (!sme->ssid || !sme->ssid_len)
-	{
-		ret = -EINVAL;
-		goto exit;
-	}
-
-	if (sme->ssid_len > IW_ESSID_MAX_SIZE){
-
-		ret= -E2BIG;
-		goto exit;
-	}
-	
-	_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));			
-	ndis_ssid.SsidLength = sme->ssid_len;
-	_rtw_memcpy(ndis_ssid.Ssid, (u8 *)sme->ssid, sme->ssid_len);
-
-	DBG_8192C("ssid=%s, len=%zu\n", ndis_ssid.Ssid, sme->ssid_len);
-	
-
-	if (sme->bssid)
-		DBG_8192C("bssid="MAC_FMT"\n", MAC_ARG(sme->bssid));
-
-
-	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
-		ret = -EBUSY;
-		DBG_8192C("%s, fw_state=0x%x, goto exit\n", __FUNCTION__, pmlmepriv->fw_state);
-		goto exit;		
-	}
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
-		rtw_scan_abort(padapter);
-	}
-
-	psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
-	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
-	psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
-	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; //open system
-	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
-
-#ifdef CONFIG_WAPI_SUPPORT
-	 padapter->wapiInfo.bWapiEnable = false;
-#endif
-
-	ret = rtw_cfg80211_set_wpa_version(psecuritypriv, sme->crypto.wpa_versions);
-	if (ret < 0)
-		goto exit;
-
-#ifdef CONFIG_WAPI_SUPPORT
-	if(sme->crypto.wpa_versions & NL80211_WAPI_VERSION_1)
-	{
-		padapter->wapiInfo.bWapiEnable = true;
-		padapter->wapiInfo.extra_prefix_len = WAPI_EXT_LEN;
-		padapter->wapiInfo.extra_postfix_len = SMS4_MIC_LEN;
-	}
-#endif
-
-	ret = rtw_cfg80211_set_auth_type(psecuritypriv, sme->auth_type);
-
-#ifdef CONFIG_WAPI_SUPPORT
-	if(psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_WAPI)
-		padapter->mlmeextpriv.mlmext_info.auth_algo = psecuritypriv->dot11AuthAlgrthm;
-#endif
-
-
-	if (ret < 0)
-		goto exit;
-
-	DBG_8192C("%s, ie_len=%zu\n", __func__, sme->ie_len);
-			
-	ret = rtw_cfg80211_set_wpa_ie(padapter, (u8 *)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 (sme->key_len > 0 && sme->key)
-	{
-		u32 wep_key_idx, wep_key_len,wep_total_len;
-		NDIS_802_11_WEP	 *pwep = NULL;
-		DBG_871X("%s(): Shared/Auto WEP\n",__FUNCTION__);
-
-		wep_key_idx = sme->key_idx;
-		wep_key_len = sme->key_len;
-
-		if (sme->key_idx > WEP_KEYS) {
-			ret = -EINVAL;
-			goto exit;
-		}
-
-		if (wep_key_len > 0) 
-		{
-		 	wep_key_len = wep_key_len <= 5 ? 5 : 13;
-			wep_total_len = wep_key_len + FIELD_OFFSET(NDIS_802_11_WEP, KeyMaterial);
-		 	pwep =(NDIS_802_11_WEP	 *) rtw_malloc(wep_total_len);
-			if(pwep == NULL){
-				DBG_871X(" wpa_set_encryption: pwep allocate fail !!!\n");
-				ret = -ENOMEM;
-				goto exit;
-			}
-
-		 	_rtw_memset(pwep, 0, wep_total_len);
-
-		 	pwep->KeyLength = wep_key_len;
-			pwep->Length = wep_total_len;
-
-			if(wep_key_len==13)
-			{
-				padapter->securitypriv.dot11PrivacyAlgrthm=_WEP104_;
-				padapter->securitypriv.dot118021XGrpPrivacy=_WEP104_;
-			}
-		}
-		else {		
-			ret = -EINVAL;
-			goto exit;
-		}
-
-		pwep->KeyIndex = wep_key_idx;
-		pwep->KeyIndex |= 0x80000000;
-
-		_rtw_memcpy(pwep->KeyMaterial,  (void *)sme->key, pwep->KeyLength);
-
-		if(rtw_set_802_11_add_wep(padapter, pwep) == (u8)_FAIL)
-		{
-			ret = -EOPNOTSUPP ;
-		}
-
-		if (pwep) {
-			rtw_mfree((u8 *)pwep,wep_total_len);		
-		}
-
-		if(ret < 0)
-			goto exit;
-	}
-
-	ret = rtw_cfg80211_set_cipher(psecuritypriv, sme->crypto.cipher_group, _FALSE);
-	if (ret < 0)
-		return ret;
-
-	if (sme->crypto.n_akm_suites) {
-		ret = rtw_cfg80211_set_key_mgt(psecuritypriv, sme->crypto.akm_suites[0]);
-		if (ret < 0)
-			goto exit;
-	}
-
-#ifdef CONFIG_WAPI_SUPPORT
-      if(sme->crypto.akm_suites[0] ==WLAN_AKM_SUITE_WAPI_PSK){
-		padapter->wapiInfo.bWapiPSK = true;
-	}
-	else if(sme->crypto.akm_suites[0] ==WLAN_AKM_SUITE_WAPI_CERT){
-	      padapter->wapiInfo.bWapiPSK = false;
-	}
-#endif
-
-	authmode = psecuritypriv->ndisauthtype;
-	rtw_set_802_11_authentication_mode(padapter, authmode);
-
-	//rtw_set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus);
-
-	if (rtw_set_802_11_connect(padapter, (u8 *)sme->bssid, &ndis_ssid) == _FALSE) {
-		ret = -1;
-		goto exit;
-	}
-
-	DBG_8192C("set ssid:dot11AuthAlgrthm=%d, dot11PrivacyAlgrthm=%d, dot118021XGrpPrivacy=%d\n", psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm, psecuritypriv->dot118021XGrpPrivacy);
-	
-exit:
-
-	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
-
-	DBG_8192C("<=%s, ret %d\n",__FUNCTION__, ret);
-
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	padapter->mlmepriv.not_indic_disco = _FALSE;
-	#endif
-
-	return ret;
-}
-
-static int cfg80211_rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev,
-				   u16 reason_code)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-
-	DBG_871X(FUNC_NDEV_FMT" - Start to Disconnect\n", FUNC_NDEV_ARG(ndev));
-
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	padapter->mlmepriv.not_indic_disco = _TRUE;
-	#endif
-
-	rtw_set_to_roam(padapter, 0);
-
-	//if(check_fwstate(&padapter->mlmepriv, _FW_LINKED))
-	{
-		rtw_scan_abort(padapter);
-		LeaveAllPowerSaveMode(padapter);
-		rtw_disassoc_cmd(padapter, 500, _FALSE);
-		
-		DBG_871X("%s...call rtw_indicate_disconnect\n", __FUNCTION__);
-		
-		rtw_indicate_disconnect(padapter, 0, _TRUE);
-		
-		rtw_free_assoc_resources(padapter, 1);
-		rtw_pwr_wakeup(padapter);		
-	}
-
-	#ifdef SUPPLICANT_RTK_VERSION_LOWER_THAN_JB42
-	padapter->mlmepriv.not_indic_disco = _FALSE;
-	#endif
-
-	DBG_871X(FUNC_NDEV_FMT" return 0\n", FUNC_NDEV_ARG(ndev));
-	return 0;
-}
-
-static int cfg80211_rtw_set_txpower(struct wiphy *wiphy,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,8,0))
-	struct wireless_dev *wdev,
-#endif
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,36)) || defined(COMPAT_KERNEL_RELEASE)
-	enum nl80211_tx_power_setting type, int mbm)
-#else
-	enum tx_power_setting type, int dbm)
-#endif
-{
-#if 0
-	struct iwm_priv *iwm = wiphy_to_iwm(wiphy);
-	int ret;
-
-	switch (type) {
-	case NL80211_TX_POWER_AUTOMATIC:
-		return 0;
-	case NL80211_TX_POWER_FIXED:
-		if (mbm < 0 || (mbm % 100))
-			return -EOPNOTSUPP;
-
-		if (!test_bit(IWM_STATUS_READY, &iwm->status))
-			return 0;
-
-		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_CFG_FIX,
-					      CFG_TX_PWR_LIMIT_USR,
-					      MBM_TO_DBM(mbm) * 2);
-		if (ret < 0)
-			return ret;
-
-		return iwm_tx_power_trigger(iwm);
-	default:
-		IWM_ERR(iwm, "Unsupported power type: %d\n", type);
-		return -EOPNOTSUPP;
-	}
-#endif
-	DBG_8192C("%s\n", __func__);
-	return 0;
-}
-
-static int cfg80211_rtw_get_txpower(struct wiphy *wiphy,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,8,0))
-	struct wireless_dev *wdev,
-#endif
-	int *dbm)
-{
-	DBG_8192C("%s\n", __func__);
-
-	*dbm = (12);
-	
-	return 0;
-}
-
-inline bool rtw_cfg80211_pwr_mgmt(_adapter *adapter)
-{
-	struct rtw_wdev_priv *rtw_wdev_priv = adapter_wdev_data(adapter);
-	return rtw_wdev_priv->power_mgmt;
-}
-
-static int cfg80211_rtw_set_power_mgmt(struct wiphy *wiphy,
-				       struct net_device *ndev,
-				       bool enabled, int timeout)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct rtw_wdev_priv *rtw_wdev_priv = adapter_wdev_data(padapter);
-	
-	DBG_871X(FUNC_NDEV_FMT" enabled:%u, timeout:%d\n", FUNC_NDEV_ARG(ndev),
-		enabled, timeout);
-
-	rtw_wdev_priv->power_mgmt = enabled;
-
-	#ifdef CONFIG_LPS
-	if (!enabled)
-		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE_CFG80211_PWRMGMT, 1);
-	#endif
-
-	return 0;
-}
-
-static int cfg80211_rtw_set_pmksa(struct wiphy *wiphy,
-				  struct net_device *ndev,
-				  struct cfg80211_pmksa *pmksa)
-{
-	u8	index,blInserted = _FALSE;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_priv *mlme = &padapter->mlmepriv;
-	struct security_priv	*psecuritypriv = &padapter->securitypriv;
-	u8	strZeroMacAddress[ ETH_ALEN ] = { 0x00 };
-
-	DBG_871X(FUNC_NDEV_FMT" "MAC_FMT" "KEY_FMT"\n", FUNC_NDEV_ARG(ndev)
-		, MAC_ARG(pmksa->bssid), KEY_ARG(pmksa->pmkid));
-
-	if ( _rtw_memcmp((u8 *)pmksa->bssid, strZeroMacAddress, ETH_ALEN ) == _TRUE )
-	{
-		return -EINVAL;
-	}
-
-	if (check_fwstate(mlme, _FW_LINKED) == _FALSE) {
-		DBG_871X(FUNC_NDEV_FMT" not set pmksa cause not in linked state\n", FUNC_NDEV_ARG(ndev));
-		return -EINVAL;
-	}
-
-	blInserted = _FALSE;
-	
-	//overwrite PMKID
-	for(index=0 ; index<NUM_PMKID_CACHE; index++)
-	{
-		if( _rtw_memcmp(psecuritypriv->PMKIDList[index].Bssid, (u8 *)pmksa->bssid, ETH_ALEN) ==_TRUE )
-		{ // BSSID is matched, the same AP => rewrite with new PMKID.
-			DBG_871X(FUNC_NDEV_FMT" BSSID exists in the PMKList.\n", FUNC_NDEV_ARG(ndev));
-
-			_rtw_memcpy( psecuritypriv->PMKIDList[index].PMKID, (u8 *)pmksa->pmkid, WLAN_PMKID_LEN);
-			psecuritypriv->PMKIDList[index].bUsed = _TRUE;
-			psecuritypriv->PMKIDIndex = index+1;
-			blInserted = _TRUE;
-			break;
-		}	
-	}
-
-	if(!blInserted)
-	{
-		// Find a new entry
-		DBG_871X(FUNC_NDEV_FMT" Use the new entry index = %d for this PMKID.\n",
-			FUNC_NDEV_ARG(ndev), psecuritypriv->PMKIDIndex );
-
-		_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].Bssid, (u8 *)pmksa->bssid, ETH_ALEN);
-		_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].PMKID, (u8 *)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 *ndev,
-				  struct cfg80211_pmksa *pmksa)
-{
-	u8	index, bMatched = _FALSE;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct security_priv	*psecuritypriv = &padapter->securitypriv;
-
-	DBG_871X(FUNC_NDEV_FMT" "MAC_FMT" "KEY_FMT"\n", FUNC_NDEV_ARG(ndev)
-		, MAC_ARG(pmksa->bssid), KEY_ARG(pmksa->pmkid));
-
-	for(index=0 ; index<NUM_PMKID_CACHE; index++)
-	{
-		if( _rtw_memcmp(psecuritypriv->PMKIDList[index].Bssid, (u8 *)pmksa->bssid, ETH_ALEN) ==_TRUE )
-		{ // BSSID is matched, the same AP => Remove this PMKID information and reset it. 
-			_rtw_memset(psecuritypriv->PMKIDList[index].Bssid, 0x00, ETH_ALEN );
-			_rtw_memset(psecuritypriv->PMKIDList[index].PMKID, 0x00, WLAN_PMKID_LEN );
-			psecuritypriv->PMKIDList[index].bUsed = _FALSE;
-			bMatched = _TRUE;
-			DBG_871X(FUNC_NDEV_FMT" clear id:%hhu\n", FUNC_NDEV_ARG(ndev), index);		
-			break;
-		}	
-	}
-
-	if(_FALSE == bMatched)
-	{
-		DBG_871X(FUNC_NDEV_FMT" do not have matched BSSID\n"
-			, FUNC_NDEV_ARG(ndev));
-		return -EINVAL;
-	}
-
-	return 0;
-}
-
-static int cfg80211_rtw_flush_pmksa(struct wiphy *wiphy,
-				    struct net_device *ndev)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct security_priv	*psecuritypriv = &padapter->securitypriv;
-
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-	_rtw_memset( &psecuritypriv->PMKIDList[ 0 ], 0x00, sizeof( RT_PMKID_LIST ) * NUM_PMKID_CACHE );
-	psecuritypriv->PMKIDIndex = 0;
-
-	return 0;
-}
-
-#ifdef CONFIG_AP_MODE
-void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len)
-{
-	s32 freq;
-	int channel;
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
-	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);	
-	struct net_device *ndev = padapter->pnetdev;
-
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-
-#if defined(RTW_USE_CFG80211_STA_EVENT) || defined(COMPAT_KERNEL_RELEASE)
-	{
-		struct station_info sinfo;
-		u8 ie_offset;
-		if (GetFrameSubType(pmgmt_frame) == WIFI_ASSOCREQ)
-			ie_offset = _ASOCREQ_IE_OFFSET_;
-		else // WIFI_REASSOCREQ
-			ie_offset = _REASOCREQ_IE_OFFSET_;
-	
-		sinfo.filled = 0;
-		sinfo.filled = STATION_INFO_ASSOC_REQ_IES;
-		sinfo.assoc_req_ies = pmgmt_frame + WLAN_HDR_A3_LEN + ie_offset;
-		sinfo.assoc_req_ies_len = frame_len - WLAN_HDR_A3_LEN - ie_offset;
-		cfg80211_new_sta(ndev, GetAddr2Ptr(pmgmt_frame), &sinfo, GFP_ATOMIC);
-	}
-#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
-	channel = pmlmeext->cur_channel;
-	freq = rtw_ch2freq(channel);
-
-	#ifdef COMPAT_KERNEL_RELEASE
-	rtw_cfg80211_rx_mgmt(padapter, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
-	#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
-	rtw_cfg80211_rx_mgmt(padapter, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
-	#else //COMPAT_KERNEL_RELEASE
-	{
-		//to avoid WARN_ON(wdev->iftype != NL80211_IFTYPE_STATION)  when calling cfg80211_send_rx_assoc()
-		#ifndef CONFIG_PLATFORM_MSTAR
-		pwdev->iftype = NL80211_IFTYPE_STATION;
-		#endif //CONFIG_PLATFORM_MSTAR
-		DBG_8192C("iftype=%d before call cfg80211_send_rx_assoc()\n", pwdev->iftype);
-		rtw_cfg80211_send_rx_assoc(padapter, NULL, pmgmt_frame, frame_len);
-		DBG_8192C("iftype=%d after call cfg80211_send_rx_assoc()\n", pwdev->iftype);
-		pwdev->iftype = NL80211_IFTYPE_AP;
-		//cfg80211_rx_action(padapter->pnetdev, freq, pmgmt_frame, frame_len, GFP_ATOMIC);
-	}
-	#endif //COMPAT_KERNEL_RELEASE
-#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
-
-}
-
-void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, unsigned char *da, unsigned short reason)
-{
-	s32 freq;
-	int channel;
-	u8 *pmgmt_frame;
-	uint frame_len;
-	struct rtw_ieee80211_hdr *pwlanhdr;
-	unsigned short *fctrl;	
-	u8 mgmt_buf[128] = {0};
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct net_device *ndev = padapter->pnetdev;
-	
-	DBG_871X(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
-
-#if defined(RTW_USE_CFG80211_STA_EVENT) || defined(COMPAT_KERNEL_RELEASE)
-	cfg80211_del_sta(ndev, da, GFP_ATOMIC);
-#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
-	channel = pmlmeext->cur_channel;
-	freq = rtw_ch2freq(channel);
-
-	pmgmt_frame = mgmt_buf;	
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pmgmt_frame;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-
-	_rtw_memcpy(pwlanhdr->addr1, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, da, ETH_ALEN);	
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pmgmt_frame, WIFI_DEAUTH);
-
-	pmgmt_frame += sizeof(struct rtw_ieee80211_hdr_3addr);
-	frame_len = sizeof(struct rtw_ieee80211_hdr_3addr);
-
-	reason = cpu_to_le16(reason);
-	pmgmt_frame = rtw_set_fixed_ie(pmgmt_frame, _RSON_CODE_ , (unsigned char *)&reason, &frame_len);
-
-	#ifdef COMPAT_KERNEL_RELEASE
-	rtw_cfg80211_rx_mgmt(padapter, freq, 0, mgmt_buf, frame_len, GFP_ATOMIC);
-	#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
-	rtw_cfg80211_rx_mgmt(padapter, freq, 0, mgmt_buf, frame_len, GFP_ATOMIC);
-	#else //COMPAT_KERNEL_RELEASE
-	cfg80211_send_disassoc(padapter->pnetdev, mgmt_buf, frame_len);	
-	//cfg80211_rx_action(padapter->pnetdev, freq, mgmt_buf, frame_len, GFP_ATOMIC);
-	#endif //COMPAT_KERNEL_RELEASE
-#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
-}
-
-static int rtw_cfg80211_monitor_if_open(struct net_device *ndev)
-{
-	int ret = 0;
-
-	DBG_8192C("%s\n", __func__);
-	
-	return ret;
-}
-
-static int rtw_cfg80211_monitor_if_close(struct net_device *ndev)
-{
-	int ret = 0;
-
-	DBG_8192C("%s\n", __func__);
-	
-	return ret;
-}
-
-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;
-	u16 frame_ctl;
-	unsigned char src_mac_addr[6];
-	unsigned char dst_mac_addr[6];
-	struct rtw_ieee80211_hdr *dot11_hdr;
-	struct ieee80211_radiotap_header *rtap_hdr;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-	if (skb)
-		rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
-
-	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_8192C("radiotap len (should be 14): %d\n", rtap_len);
-		goto fail;
-	}	
-
-	/* Skip the ratio tap header */
-	skb_pull(skb, rtap_len);
-
-	dot11_hdr = (struct rtw_ieee80211_hdr *)skb->data;
-	frame_ctl = le16_to_cpu(dot11_hdr->frame_ctl);
-	/* Check if the QoS bit is set */
-	if ((frame_ctl & RTW_IEEE80211_FCTL_FTYPE) == RTW_IEEE80211_FTYPE_DATA) {
-		/* Check if this ia a Wireless Distribution System (WDS) frame
-		 * which has 4 MAC addresses
-		 */
-		if (dot11_hdr->frame_ctl & 0x0080)
-			qos_len = 2;
-		if ((dot11_hdr->frame_ctl & 0x0300) == 0x0300)
-			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
-		 * for two MAC addresses
-		 */
-		skb_pull(skb, dot11_hdr_len + qos_len + snap_len - sizeof(src_mac_addr) * 2);
-		pdata = (unsigned char*)skb->data;
-		memcpy(pdata, dst_mac_addr, sizeof(dst_mac_addr));
-		memcpy(pdata + sizeof(dst_mac_addr), src_mac_addr, sizeof(src_mac_addr));
-
-		DBG_8192C("should be eapol packet\n");
-
-		/* Use the real net device to transmit the packet */
-		ret = _rtw_xmit_entry(skb, padapter->pnetdev);
-
-		return ret;
-
-	}
-	else if ((frame_ctl & (RTW_IEEE80211_FCTL_FTYPE|RTW_IEEE80211_FCTL_STYPE))
-		== (RTW_IEEE80211_FTYPE_MGMT|RTW_IEEE80211_STYPE_ACTION)
-	) 
-	{
-		//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 rtw_ieee80211_hdr *pwlanhdr;	
-		struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-		struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-		u8 *buf = skb->data;
-		u32 len = skb->len;
-		u8 category, action;
-		int type = -1;
-
-		if (rtw_action_frame_parse(buf, len, &category, &action) == _FALSE) {
-			DBG_8192C(FUNC_NDEV_FMT" frame_control:0x%x\n", FUNC_NDEV_ARG(ndev),
-				le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl));
-			goto fail;
-		}
-		
-		DBG_8192C("RTW_Tx:da="MAC_FMT" via "FUNC_NDEV_FMT"\n",
-			MAC_ARG(GetAddr1Ptr(buf)), FUNC_NDEV_ARG(ndev));
-		#ifdef CONFIG_P2P
-		if((type = rtw_p2p_check_frames(padapter, buf, len, _TRUE)) >= 0)
-			goto dump;
-		#endif
-		if (category == RTW_WLAN_CATEGORY_PUBLIC)
-			DBG_871X("RTW_Tx:%s\n", action_public_str(action));
-		else
-			DBG_871X("RTW_Tx:category(%u), action(%u)\n", category, action);
-
-dump:
-		//starting alloc mgmt frame to dump it
-		if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-		{			
-			goto fail;
-		}
-
-		//update attribute
-		pattrib = &pmgntframe->attrib;
-		update_mgntframe_attrib(padapter, pattrib);
-		pattrib->retry_ctrl = _FALSE;
-
-		_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-		pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-		_rtw_memcpy(pframe, (void*)buf, len);
-		pattrib->pktlen = len;
-
-#ifdef CONFIG_P2P
-		if (type >= 0)
-			rtw_xframe_chk_wfd_ie(pmgntframe);
-#endif /* CONFIG_P2P */
-	
-		pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-		//update seq number
-		pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
-		pattrib->seqnum = pmlmeext->mgnt_seq;
-		pmlmeext->mgnt_seq++;
-
-	
-		pattrib->last_txcmdsz = pattrib->pktlen;
-	
-		dump_mgntframe(padapter, pmgntframe);
-		
-	}
-	else
-	{
-		DBG_8192C("frame_ctl=0x%x\n", frame_ctl & (RTW_IEEE80211_FCTL_FTYPE|RTW_IEEE80211_FCTL_STYPE));
-	}
-
-	
-fail:
-	
-	rtw_skb_free(skb);
-
-	return 0;
-	
-}
-
-static void rtw_cfg80211_monitor_if_set_multicast_list(struct net_device *ndev)
-{
-	DBG_8192C("%s\n", __func__);
-}
-
-static int rtw_cfg80211_monitor_if_set_mac_address(struct net_device *ndev, void *addr)
-{
-	int ret = 0;
-	
-	DBG_8192C("%s\n", __func__);
-	
-	return ret;
-}
-
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
-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,
-       #if (LINUX_VERSION_CODE < KERNEL_VERSION(3,2,0))
-       .ndo_set_multicast_list = rtw_cfg80211_monitor_if_set_multicast_list,
-       #endif
-       .ndo_set_mac_address = rtw_cfg80211_monitor_if_set_mac_address,       
-};
-#endif
-
-static int rtw_cfg80211_add_monitor_if(_adapter *padapter, char *name, struct net_device **ndev)
-{
-	int ret = 0;
-	struct net_device* mon_ndev = NULL;
-	struct wireless_dev* mon_wdev = NULL;
-	struct rtw_netdev_priv_indicator *pnpi;
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
-		
-	if (!name) {
-		DBG_871X(FUNC_ADPT_FMT" without specific name\n", FUNC_ADPT_ARG(padapter));
-		ret = -EINVAL;
-		goto out;
-	}
-
-	if (pwdev_priv->pmon_ndev) {
-		DBG_871X(FUNC_ADPT_FMT" monitor interface exist: "NDEV_FMT"\n",
-			FUNC_ADPT_ARG(padapter), NDEV_ARG(pwdev_priv->pmon_ndev));
-		ret = -EBUSY;
-		goto out;
-	}
-
-	mon_ndev = alloc_etherdev(sizeof(struct rtw_netdev_priv_indicator));
-	if (!mon_ndev) {
-		DBG_871X(FUNC_ADPT_FMT" allocate ndev fail\n", FUNC_ADPT_ARG(padapter));
-		ret = -ENOMEM;
-		goto out;
-	}
-
-	mon_ndev->type = ARPHRD_IEEE80211_RADIOTAP;
-	strncpy(mon_ndev->name, name, IFNAMSIZ);
-	mon_ndev->name[IFNAMSIZ - 1] = 0;
-	mon_ndev->destructor = rtw_ndev_destructor;
-	
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
-	mon_ndev->netdev_ops = &rtw_cfg80211_monitor_if_ops;
-#else
-	mon_ndev->open = rtw_cfg80211_monitor_if_open;
-	mon_ndev->stop = rtw_cfg80211_monitor_if_close;
-	mon_ndev->hard_start_xmit = rtw_cfg80211_monitor_if_xmit_entry;
-	mon_ndev->set_mac_address = rtw_cfg80211_monitor_if_set_mac_address;
-#endif
-
-	pnpi = netdev_priv(mon_ndev);
-	pnpi->priv = padapter;
-	pnpi->sizeof_priv = sizeof(_adapter);
-
-	/*  wdev */
-	mon_wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
-	if (!mon_wdev) {
-		DBG_871X(FUNC_ADPT_FMT" allocate mon_wdev fail\n", FUNC_ADPT_ARG(padapter));
-		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;
-	_rtw_memcpy(pwdev_priv->ifname_mon, name, IFNAMSIZ+1);
-
-out:
-	if (ret && mon_wdev) {
-		rtw_mfree((u8*)mon_wdev, sizeof(struct wireless_dev));
-		mon_wdev = NULL;
-	}
-
-	if (ret && mon_ndev) {
-		free_netdev(mon_ndev);
-		*ndev = mon_ndev = NULL;
-	}
-
-	return ret;
-}
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-static struct wireless_dev *
-#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)) || defined(COMPAT_KERNEL_RELEASE)
-static struct net_device *
-#else
-static int
-#endif
-	cfg80211_rtw_add_virtual_intf(
-		struct wiphy *wiphy,
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,7,0))
-		const char *name,
-	#else
-		char *name,
-	#endif
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
-		unsigned char name_assign_type,
-	#endif
-		enum nl80211_iftype type, u32 *flags, struct vif_params *params)
-{
-	int ret = 0;
-	struct net_device* ndev = NULL;
-	_adapter *padapter = wiphy_to_adapter(wiphy);
-
-	DBG_871X("%s wiphy:%s, name:%s, type:%d\n",
-		__func__, 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, &ndev);
-		break;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	case NL80211_IFTYPE_P2P_CLIENT:
-#endif
-	case NL80211_IFTYPE_STATION:
-		ret = -ENODEV;
-		break;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	case NL80211_IFTYPE_P2P_GO:
-#endif
-	case NL80211_IFTYPE_AP:
-		ret = -ENODEV;
-		break;
-	default:
-		ret = -ENODEV;
-		DBG_871X("Unsupported interface type\n");
-		break;
-	}
-
-	DBG_871X("%s ndev:%p, ret:%d\n", __func__, ndev, ret);
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	return ndev ? ndev->ieee80211_ptr : ERR_PTR(ret);
-#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)) || defined(COMPAT_KERNEL_RELEASE)
-	return ndev ? ndev : ERR_PTR(ret);
-#else
-	return ret;
-#endif
-}
-
-static int cfg80211_rtw_del_virtual_intf(struct wiphy *wiphy,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct wireless_dev *wdev
-#else
-	struct net_device *ndev
-#endif
-)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct net_device *ndev = wdev_to_ndev(wdev);
-#endif
-	int ret = 0;
-	_adapter *adapter;
-	struct rtw_wdev_priv *pwdev_priv;
-
-	if (!ndev) {
-		ret = -EINVAL;
-		goto exit;
-	}
-
-	adapter = (_adapter *)rtw_netdev_priv(ndev);
-	pwdev_priv = adapter_wdev_data(adapter);
-
-	unregister_netdevice(ndev);
-
-	if (ndev == pwdev_priv->pmon_ndev) {
-		pwdev_priv->pmon_ndev = NULL;
-		pwdev_priv->ifname_mon[0] = '\0';
-		DBG_871X(FUNC_NDEV_FMT" remove monitor interface\n", FUNC_NDEV_ARG(ndev));
-	}
-
-exit:
-	return ret;
-}
-
-static int rtw_add_beacon(_adapter *adapter, const u8 *head, size_t head_len, const u8 *tail, size_t tail_len)
-{
-	int ret=0;
-	u8 *pbuf = NULL;
-	uint len, wps_ielen=0;	
-	uint p2p_ielen=0;
-	u8 *p2p_ie;
-	u8 got_p2p_ie = _FALSE;
-	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
-	//struct sta_priv *pstapriv = &padapter->stapriv;
-	
-
-	DBG_8192C("%s beacon_head_len=%zu, beacon_tail_len=%zu\n", __FUNCTION__, head_len, tail_len);
-
-	
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
-		return -EINVAL;
-
-	if(head_len<24)
-		return -EINVAL;
-	
-
-	pbuf = rtw_zmalloc(head_len+tail_len);
-	if(!pbuf)
-		return -ENOMEM;
-	
-
-	//_rtw_memcpy(&pstapriv->max_num_sta, param->u.bcn_ie.reserved, 2);
-
-	//if((pstapriv->max_num_sta>NUM_STA) || (pstapriv->max_num_sta<=0))
-	//	pstapriv->max_num_sta = NUM_STA;
-
-	
-	_rtw_memcpy(pbuf, (void *)head+24, head_len-24);// 24=beacon header len.
-	_rtw_memcpy(pbuf+head_len-24, (void *)tail, tail_len);
-
-	len = head_len+tail_len-24;
-
-	//check wps ie if inclued
-	if(rtw_get_wps_ie(pbuf+_FIXED_IE_LENGTH_, len-_FIXED_IE_LENGTH_, NULL, &wps_ielen))
-		DBG_8192C("add bcn, wps_ielen=%d\n", wps_ielen);
-
-#ifdef CONFIG_P2P
-	if( adapter->wdinfo.driver_interface == DRIVER_CFG80211 )
-	{
-		//check p2p if enable
-		if(rtw_get_p2p_ie(pbuf+_FIXED_IE_LENGTH_, len-_FIXED_IE_LENGTH_, NULL, &p2p_ielen))
-		{		
-			struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-			struct wifidirect_info *pwdinfo= &(adapter->wdinfo);
-
-			DBG_8192C("got p2p_ie, len=%d\n", p2p_ielen);
-			
-			got_p2p_ie = _TRUE;	
-		
-			if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-			{			
-				DBG_8192C("Enable P2P function for the first time\n");
-				rtw_p2p_enable(adapter, P2P_ROLE_GO);
-				adapter_wdev_data(adapter)->p2p_enabled = _TRUE;
-				
-				adapter->stapriv.expire_to = 3; // 3x2 = 6 sec in p2p mode
-			}
-			else
-			{
-				DBG_8192C("enter GO Mode, p2p_ielen=%d\n", p2p_ielen);
-
-				rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
-				rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
-				pwdinfo->intent = 15;		
-			}
-		}
-	}
-#endif // CONFIG_P2P
-
-	/* pbss_network->IEs will not include p2p_ie, wfd ie */
-	rtw_ies_remove_ie(pbuf, &len, _BEACON_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, P2P_OUI, 4);
-	rtw_ies_remove_ie(pbuf, &len, _BEACON_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, WFD_OUI, 4);
-
-	if (rtw_check_beacon_data(adapter, pbuf,  len) == _SUCCESS) 
-	{
-#ifdef  CONFIG_P2P		
-		//check p2p if enable
-		if(got_p2p_ie == _TRUE)
-		{
-			struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-			struct wifidirect_info *pwdinfo= &(adapter->wdinfo);
-			pwdinfo->operating_channel = pmlmeext->cur_channel;			
-		}
-#endif //CONFIG_P2P
-		ret = 0;
-	}	
-	else
-	{
-		ret = -EINVAL;
-	}	
-	
-
-	rtw_mfree(pbuf, head_len+tail_len);	
-	
-	return ret;	
-}
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,4,0)) && !defined(COMPAT_KERNEL_RELEASE)
-static int cfg80211_rtw_add_beacon(struct wiphy *wiphy, struct net_device *ndev,
-			      struct beacon_parameters *info)
-{
-	int ret=0;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
-
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	ret = rtw_add_beacon(adapter, info->head, info->head_len, info->tail, info->tail_len);
-
-	return ret;
-}
-
-static int cfg80211_rtw_set_beacon(struct wiphy *wiphy, struct net_device *ndev,
-			      struct beacon_parameters *info)
-{
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
-	
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-	pmlmeext->bstart_bss = _TRUE;
-
-	cfg80211_rtw_add_beacon(wiphy, ndev, info);
-	
-	return 0;
-}
-
-static int	cfg80211_rtw_del_beacon(struct wiphy *wiphy, struct net_device *ndev)
-{
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	
-	return 0;
-}
-#else
-static int cfg80211_rtw_start_ap(struct wiphy *wiphy, struct net_device *ndev,
-								struct cfg80211_ap_settings *settings)
-{
-	int ret = 0;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
-	
-	DBG_871X(FUNC_NDEV_FMT" hidden_ssid:%d, auth_type:%d\n", FUNC_NDEV_ARG(ndev),
-		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) {
-		WLAN_BSSID_EX *pbss_network = &adapter->mlmepriv.cur_network.network;
-		WLAN_BSSID_EX *pbss_network_ext = &adapter->mlmeextpriv.mlmext_info.network;
-
-		if(0)
-			DBG_871X(FUNC_ADPT_FMT" ssid:(%s,%zu), from ie:(%s,%d)\n", FUNC_ADPT_ARG(adapter),
-				settings->ssid, settings->ssid_len,
-				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength);
-
-		_rtw_memcpy(pbss_network->Ssid.Ssid, (void *)settings->ssid, settings->ssid_len);
-		pbss_network->Ssid.SsidLength = settings->ssid_len;
-		_rtw_memcpy(pbss_network_ext->Ssid.Ssid, (void *)settings->ssid, settings->ssid_len);
-		pbss_network_ext->Ssid.SsidLength = settings->ssid_len;
-
-		if(0)
-			DBG_871X(FUNC_ADPT_FMT" after ssid:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
-				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength,
-				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
-	}
-
-	return ret;
-}
-
-static int cfg80211_rtw_change_beacon(struct wiphy *wiphy, struct net_device *ndev,
-                                struct cfg80211_beacon_data *info)
-{
-	int ret = 0;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
-
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-	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_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	return 0;
-}
-
-#endif //(LINUX_VERSION_CODE < KERNEL_VERSION(3,4,0))
-
-static int	cfg80211_rtw_add_station(struct wiphy *wiphy, struct net_device *ndev,
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,16,0))
-				u8 *mac, 
-#else
-				const u8 *mac,
-#endif
-			       struct station_parameters *params)
-{
-	int ret = 0;
-#ifdef CONFIG_TDLS
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-   	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta;
-#endif /* CONFIG_TDLS */
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	
-#ifdef CONFIG_TDLS
-	psta = rtw_get_stainfo(pstapriv, mac);
-	if (psta == NULL) {
-		psta = rtw_alloc_stainfo(pstapriv, mac);
-		if (psta ==NULL) {
-			DBG_871X("[%s] Alloc station for "MAC_FMT" fail\n", __FUNCTION__, MAC_ARG(mac));
-			ret =-EOPNOTSUPP;
-			goto exit;
-		}
-	}
-#endif /* CONFIG_TDLS */
-
-exit:
-	return ret;
-}
-
-static int	cfg80211_rtw_del_station(struct wiphy *wiphy, struct net_device *ndev,
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,16,0))
-				u8 *mac
-#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 19, 0))
-				const u8 *mac
-#else
-				struct station_del_parameters *params
-#endif
-			       )
-{
-	int ret=0;	
-	_irqL irqL;
-	_list	*phead, *plist;
-	u8 updated = _FALSE;
-	const u8 *target_mac;
-	struct sta_info *psta = NULL;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-
-	DBG_871X("+"FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 19, 0))
-	target_mac = mac;
-#else
-	target_mac = params->mac;
-#endif
-
-	if(check_fwstate(pmlmepriv, (_FW_LINKED|WIFI_AP_STATE)) != _TRUE)		
-	{
-		DBG_8192C("%s, fw_state != FW_LINKED|WIFI_AP_STATE\n", __func__);
-		return -EINVAL;		
-	}
-
-
-	if (!target_mac)
-	{
-		DBG_8192C("flush all sta, and cam_entry\n");
-
-		flush_all_cam_entry(padapter);	//clear CAM
-
-		ret = rtw_sta_flush(padapter, _TRUE);
-		
-		return ret;
-	}	
-
-
-	DBG_8192C("free sta macaddr =" MAC_FMT "\n", MAC_ARG(target_mac));
-
-	if (target_mac[0] == 0xff && target_mac[1] == 0xff &&
-	    target_mac[2] == 0xff && target_mac[3] == 0xff &&
-	    target_mac[4] == 0xff && target_mac[5] == 0xff) 
-	{
-		return -EINVAL;	
-	}
-
-
-	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	
-	phead = &pstapriv->asoc_list;
-	plist = get_next(phead);
-
-	//check asoc_queue
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)	
-	{
-		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		
-		plist = get_next(plist);	
-	
-		if (_rtw_memcmp((u8 *)target_mac, psta->hwaddr, ETH_ALEN))		
-		{
-			if(psta->dot8021xalg == 1 && psta->bpairwise_key_installed == _FALSE)
-			{
-				DBG_8192C("%s, sta's dot8021xalg = 1 and key_installed = _FALSE\n", __func__);
-			}
-			else
-			{
-				DBG_8192C("free psta=%p, aid=%d\n", psta, psta->aid);
-
-				rtw_list_delete(&psta->asoc_list);
-				pstapriv->asoc_list_cnt--;
-
-				//_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-				if (check_fwstate(pmlmepriv, (WIFI_AP_STATE)) == _TRUE)
-					updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
-				else
-					updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
-				//_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-				psta = NULL;
-
-				break;
-			}		
-					
-		}
-		
-	}
-
-	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-	associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
-
-	DBG_871X("-"FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	
-	return ret;	
-
-}
-
-static int	cfg80211_rtw_change_station(struct wiphy *wiphy, struct net_device *ndev,
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,16,0))
-				u8 *mac, 
-#else
-				const u8 *mac,
-#endif
-				struct station_parameters *params)
-{
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	
-	return 0;
-}
-
-struct sta_info *rtw_sta_info_get_by_idx(const int idx, struct sta_priv *pstapriv)
-
-{
-
-	_list	*phead, *plist;
-	struct sta_info *psta = NULL;
-	int i = 0;
-	
-	phead = &pstapriv->asoc_list;
-	plist = get_next(phead);
-
-	//check asoc_queue
-	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)	
-	{
-		if(idx == i) psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
-		plist = get_next(plist);	
-		i++;
-	}
-	return psta;
-}
-
-static int	cfg80211_rtw_dump_station(struct wiphy *wiphy, struct net_device *ndev,
-			       int idx, u8 *mac, struct station_info *sinfo)
-{
-
-	int ret = 0;
-	_irqL irqL;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct sta_info *psta = NULL;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	psta = rtw_sta_info_get_by_idx(idx, pstapriv);
-	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	if(NULL == psta)
-	{
-		DBG_871X("Station is not found\n");
-		ret = -ENOENT;
-		goto exit;
-	}
-	_rtw_memcpy(mac, psta->hwaddr, ETH_ALEN);
-	sinfo->filled = 0;
-	sinfo->filled |= STATION_INFO_SIGNAL;
-	sinfo->signal = psta->rssi;
-	
-exit:
-	return ret;
-}
-
-static int	cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,
-			      struct bss_parameters *params)
-{
-	u8 i;
-
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-/*
-	DBG_8192C("use_cts_prot=%d\n", params->use_cts_prot);
-	DBG_8192C("use_short_preamble=%d\n", params->use_short_preamble);
-	DBG_8192C("use_short_slot_time=%d\n", params->use_short_slot_time);
-	DBG_8192C("ap_isolate=%d\n", params->ap_isolate);
-
-	DBG_8192C("basic_rates_len=%d\n", params->basic_rates_len);
-	for(i=0; i<params->basic_rates_len; i++)
-	{		
-		DBG_8192C("basic_rates=%d\n", params->basic_rates[i]);
-		
-	}	
-*/	
-	return 0;
-	
-}
-
-static int	cfg80211_rtw_set_channel(struct wiphy *wiphy
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
-	, struct net_device *ndev
-	#endif
-	, struct ieee80211_channel *chan, enum nl80211_channel_type channel_type)
-{
-	int chan_target = (u8) ieee80211_frequency_to_channel(chan->center_freq);
-	int chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	int chan_width = CHANNEL_WIDTH_20;
-	_adapter *padapter = wiphy_to_adapter(wiphy);
-
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	#endif
-
-	switch (channel_type) {
-	case NL80211_CHAN_NO_HT:
-	case NL80211_CHAN_HT20:
-		chan_width = CHANNEL_WIDTH_20;
-		chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	case NL80211_CHAN_HT40MINUS:
-		chan_width = CHANNEL_WIDTH_40;
-		chan_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-		break;
-	case NL80211_CHAN_HT40PLUS:
-		chan_width = CHANNEL_WIDTH_40;
-		chan_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-		break;
-	default:
-		chan_width = CHANNEL_WIDTH_20;
-		chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	}
-
-	set_channel_bwmode(padapter, chan_target, chan_offset, chan_width);
-
-	return 0;
-}
-
-static int cfg80211_rtw_set_monitor_channel(struct wiphy *wiphy
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
-											, struct cfg80211_chan_def *chandef
-#else
-											, struct ieee80211_channel *chan
-											, enum nl80211_channel_type channel_type
-#endif
-										   )
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
-	struct ieee80211_channel *chan = chandef->chan;
-#endif
-
-	_adapter *padapter = wiphy_to_adapter(wiphy);
-	int target_channal = chan->hw_value;
-	int target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	int target_width = CHANNEL_WIDTH_20;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("center_freq %u Mhz ch %u width %u freq1 %u freq2 %u\n"
-			  , chan->center_freq
-			  , chan->hw_value
-			  , chandef->width
-			  , chandef->center_freq1
-			  , chandef->center_freq2);
-#endif /* CONFIG_DEBUG_CFG80211 */
-
-	switch (chandef->width) {
-	case NL80211_CHAN_WIDTH_20_NOHT:
-	case NL80211_CHAN_WIDTH_20:
-		target_width = CHANNEL_WIDTH_20;
-		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	case NL80211_CHAN_WIDTH_40:
-		target_width = CHANNEL_WIDTH_40;
-		if (chandef->center_freq1 > chan->center_freq)
-			target_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-		else
-			target_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-		break;
-	case NL80211_CHAN_WIDTH_80:
-		target_width = CHANNEL_WIDTH_80;
-		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	case NL80211_CHAN_WIDTH_80P80:
-		target_width = CHANNEL_WIDTH_80_80;
-		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	case NL80211_CHAN_WIDTH_160:
-		target_width = CHANNEL_WIDTH_160;
-		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
-	case NL80211_CHAN_WIDTH_5:
-	case NL80211_CHAN_WIDTH_10:
-#endif
-	default:
-		target_width = CHANNEL_WIDTH_20;
-		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	}
-#else
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("center_freq %u Mhz ch %u channel_type %u\n"
-			  , chan->center_freq
-			  , chan->hw_value
-			  , channel_type);
-#endif /* CONFIG_DEBUG_CFG80211 */
-
-	switch (channel_type) {
-	case NL80211_CHAN_NO_HT:
-	case NL80211_CHAN_HT20:
-		target_width = CHANNEL_WIDTH_20;
-		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	case NL80211_CHAN_HT40MINUS:
-		target_width = CHANNEL_WIDTH_40;
-		target_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-		break;
-	case NL80211_CHAN_HT40PLUS:
-		target_width = CHANNEL_WIDTH_40;
-		target_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-		break;
-	default:
-		target_width = CHANNEL_WIDTH_20;
-		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-		break;
-	}
-#endif
-
-	set_channel_bwmode(padapter, target_channal, target_offset, target_width);
-
-	return 0;
-}
-
-static int	cfg80211_rtw_auth(struct wiphy *wiphy, struct net_device *ndev,
-			struct cfg80211_auth_request *req)
-{
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	
-	return 0;
-}
-
-static int	cfg80211_rtw_assoc(struct wiphy *wiphy, struct net_device *ndev,
-			 struct cfg80211_assoc_request *req)
-{
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	
-	return 0;
-}
-#endif //CONFIG_AP_MODE
-
-void rtw_cfg80211_rx_probe_request(_adapter *adapter, u8 *frame, uint frame_len)
-{
-	s32 freq;
-	int channel;
-	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);	
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
-	u8 category, action;
-
-	channel = rtw_get_oper_ch(adapter);
-	freq = rtw_ch2freq(channel);
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("RTW_Rx: probe request, cur_ch=%d\n", channel);
-#endif /* CONFIG_DEBUG_CFG80211 */
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	rtw_cfg80211_rx_mgmt(adapter, freq, 0, frame, frame_len, GFP_ATOMIC);
-#else
-	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
-#endif
-}
-
-void rtw_cfg80211_rx_action_p2p(_adapter *padapter, u8 *pmgmt_frame, uint frame_len)
-{
-	int type;
-	s32 freq;
-	int channel;
-	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
-	u8 category, action;
-
-	channel = rtw_get_oper_ch(padapter);
-
-	DBG_8192C("RTW_Rx:cur_ch=%d\n", channel);
-	#ifdef CONFIG_P2P
-	type = rtw_p2p_check_frames(padapter, pmgmt_frame, frame_len, _FALSE);
-	if (type >= 0)
-		goto indicate;
-	#endif
-	rtw_action_frame_parse(pmgmt_frame, frame_len, &category, &action);
-	DBG_871X("RTW_Rx:category(%u), action(%u)\n", category, action);
-
-indicate:
-	freq = rtw_ch2freq(channel);
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	rtw_cfg80211_rx_mgmt(padapter, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
-#else
-	cfg80211_rx_action(padapter->pnetdev, freq, pmgmt_frame, frame_len, GFP_ATOMIC);
-#endif
-}
-
-void rtw_cfg80211_rx_p2p_action_public(_adapter *padapter, u8 *pmgmt_frame, uint frame_len)
-{
-	int type;
-	s32 freq;
-	int channel;
-	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
-	u8 category, action;
-
-	channel = rtw_get_oper_ch(padapter);
-
-	DBG_8192C("RTW_Rx:cur_ch=%d\n", channel);
-	#ifdef CONFIG_P2P
-	type = rtw_p2p_check_frames(padapter, pmgmt_frame, frame_len, _FALSE);
-	if (type >= 0) {
-		switch (type) {
-		case P2P_GO_NEGO_CONF:
-		case P2P_PROVISION_DISC_RESP:
-		case P2P_INVIT_RESP:
-			rtw_set_scan_deny(padapter, 2000);			
-			rtw_clear_scan_deny(padapter);
-		}
-		goto indicate;
-	}
-	#endif
-	rtw_action_frame_parse(pmgmt_frame, frame_len, &category, &action);
-	DBG_871X("RTW_Rx:category(%u), action(%u)\n", category, action);
-
-indicate:
-	freq = rtw_ch2freq(channel);
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	rtw_cfg80211_rx_mgmt(padapter, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
-#else
-	cfg80211_rx_action(padapter->pnetdev, freq, pmgmt_frame, frame_len, GFP_ATOMIC);
-#endif
-}
-
-void rtw_cfg80211_rx_action(_adapter *adapter, u8 *frame, uint frame_len, const char*msg)
-{
-	s32 freq;
-	int channel;
-	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);	
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
-	u8 category, action;
-
-	channel = rtw_get_oper_ch(adapter);
-
-	rtw_action_frame_parse(frame, frame_len, &category, &action);
-
-	if (action == ACT_PUBLIC_GAS_INITIAL_REQ) {
-		rtw_set_scan_deny(adapter, 200);
-		rtw_scan_abort_no_wait(adapter);
-		#ifdef CONFIG_CONCURRENT_MODE
-		if (rtw_buddy_adapter_up(adapter))
-			rtw_scan_abort_no_wait(adapter->pbuddy_adapter);
-		#endif
-	}
-
-	freq = rtw_ch2freq(channel);
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	rtw_cfg80211_rx_mgmt(adapter, freq, 0, frame, frame_len, GFP_ATOMIC);
-#else
-	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
-#endif
-
-	DBG_8192C("RTW_Rx:cur_ch=%d\n", channel);
-	if (msg)
-		DBG_871X("RTW_Rx:%s\n", msg);
-	else
-		DBG_871X("RTW_Rx:category(%u), action(%u)\n", category, action);
-}
-
-#ifdef CONFIG_P2P
-void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len)
-{
-	u16	wps_devicepassword_id = 0x0000;
-	uint	wps_devicepassword_id_len = 0;
-	u8			wpsie[ 255 ] = { 0x00 }, p2p_ie[ 255 ] = { 0x00 };
-	uint			p2p_ielen = 0;
-	uint			wpsielen = 0;
-	u32	devinfo_contentlen = 0;
-	u8	devinfo_content[64] = { 0x00 };
-	u16	capability = 0;
-	uint capability_len = 0;
-	
-	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
-	u8			action = P2P_PUB_ACTION_ACTION;
-	u8			dialogToken = 1;
-	u32			p2poui = cpu_to_be32(P2POUI);
-	u8			oui_subtype = P2P_PROVISION_DISC_REQ;	
-	u32			p2pielen = 0;
-#ifdef CONFIG_WFD
-	u32					wfdielen = 0;
-#endif
-	
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
-	unsigned char					*pframe;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	unsigned short				*fctrl;
-	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	
-	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
-	u8 *frame_body = (unsigned char *)(buf + sizeof(struct rtw_ieee80211_hdr_3addr));
-	size_t frame_body_len = len - sizeof(struct rtw_ieee80211_hdr_3addr);
-
-
-	DBG_871X( "[%s] In\n", __FUNCTION__ );
-
-	//prepare for building provision_request frame	
-	_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerIFAddr, GetAddr1Ptr(buf), ETH_ALEN);
-	_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerDevAddr, GetAddr1Ptr(buf), ETH_ALEN);
-	
-	pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
-		
-	rtw_get_wps_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, wpsie, &wpsielen);
-	rtw_get_wps_attr_content( wpsie, wpsielen, WPS_ATTR_DEVICE_PWID, (u8*) &wps_devicepassword_id, &wps_devicepassword_id_len);
-	wps_devicepassword_id = be16_to_cpu( wps_devicepassword_id );
-
-	switch(wps_devicepassword_id) 
-	{
-		case WPS_DPID_PIN:
-			pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_LABEL;
-			break;
-		case WPS_DPID_USER_SPEC:
-			pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_DISPLYA;
-			break;
-		case WPS_DPID_MACHINE_SPEC:
-			break;
-		case WPS_DPID_REKEY:
-			break;
-		case WPS_DPID_PBC:
-			pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
-			break;
-		case WPS_DPID_REGISTRAR_SPEC:
-			pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_KEYPAD;
-			break;
-		default:
-			break;
-	}
-
-
-	if ( rtw_get_p2p_ie( frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, p2p_ie, &p2p_ielen ) )
-	{	
-
-		rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO, devinfo_content, &devinfo_contentlen);					
-		rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8*)&capability, &capability_len);
-						
-	}
-
-
-	//start to build provision_request frame	
-	_rtw_memset(wpsie, 0, sizeof(wpsie));
-	_rtw_memset(p2p_ie, 0, sizeof(p2p_ie));
-	p2p_ielen = 0;	
-	
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		return;
-	}
-
-	
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-
-	_rtw_memcpy(pwlanhdr->addr1, pwdinfo->tx_prov_disc_info.peerDevAddr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, pwdinfo->tx_prov_disc_info.peerDevAddr, ETH_ALEN);
-
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
-	SetFrameSubType(pframe, WIFI_ACTION);
-
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-
-	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
-	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));	
-	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));		
-
-
-	//build_prov_disc_request_p2p_ie	
-	//	P2P OUI
-	p2pielen = 0;
-	p2p_ie[ p2pielen++ ] = 0x50;
-	p2p_ie[ p2pielen++ ] = 0x6F;
-	p2p_ie[ p2pielen++ ] = 0x9A;
-	p2p_ie[ p2pielen++ ] = 0x09;	//	WFA P2P v1.0
-
-	//	Commented by Albert 20110301
-	//	According to the P2P Specification, the provision discovery request frame should contain 3 P2P attributes
-	//	1. P2P Capability
-	//	2. Device Info
-	//	3. Group ID ( When joining an operating P2P Group )
-
-	//	P2P Capability ATTR
-	//	Type:	
-	p2p_ie[ p2pielen++ ] = P2P_ATTR_CAPABILITY;
-
-	//	Length:
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 );
-	RTW_PUT_LE16(p2p_ie + p2pielen, 0x0002);
-	p2pielen += 2;
-
-	//	Value:
-	//	Device Capability Bitmap, 1 byte
-	//	Group Capability Bitmap, 1 byte
-	_rtw_memcpy(p2p_ie + p2pielen, &capability, 2);
-	p2pielen += 2;
-	
-
-	//	Device Info ATTR
-	//	Type:
-	p2p_ie[ p2pielen++ ] = P2P_ATTR_DEVICE_INFO;
-
-	//	Length:
-	//	21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) 
-	//	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes)
-	//*(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len );
-	RTW_PUT_LE16(p2p_ie + p2pielen, devinfo_contentlen);
-	p2pielen += 2;
-
-	//	Value:
-	_rtw_memcpy(p2p_ie + p2pielen, devinfo_content, devinfo_contentlen);
-	p2pielen += devinfo_contentlen;
-
-
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2p_ie, &p2p_ielen);			
-	//p2pielen = build_prov_disc_request_p2p_ie( pwdinfo, pframe, NULL, 0, pwdinfo->tx_prov_disc_info.peerDevAddr);
-	//pframe += p2pielen;
-	pattrib->pktlen += p2p_ielen;
-
-	wpsielen = 0;
-	//	WPS OUI
-	*(u32*) ( wpsie ) = cpu_to_be32( WPSOUI );
-	wpsielen += 4;
-
-	//	WPS version
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_VER1 );
-	wpsielen += 2;
-
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0001 );
-	wpsielen += 2;
-
-	//	Value:
-	wpsie[wpsielen++] = WPS_VERSION_1;	//	Version 1.0
-
-	//	Config Method
-	//	Type:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD );
-	wpsielen += 2;
-
-	//	Length:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 );
-	wpsielen += 2;
-
-	//	Value:
-	*(u16*) ( wpsie + wpsielen ) = cpu_to_be16( pwdinfo->tx_prov_disc_info.wps_config_method_request );
-	wpsielen += 2;
-
-	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen );
-
-
-#ifdef CONFIG_WFD
-	wfdielen = build_provdisc_req_wfd_ie(pwdinfo, pframe);
-	pframe += wfdielen;
-	pattrib->pktlen += wfdielen;
-#endif
-
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	//dump_mgntframe(padapter, pmgntframe);
-	if (dump_mgntframe_and_wait_ack(padapter, pmgntframe) != _SUCCESS)
-		DBG_8192C("%s, ack to\n", __func__);
-
-	//if(wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
-	//{
-	//	DBG_8192C("waiting for p2p peer key-in PIN CODE\n");
-	//	rtw_msleep_os(15000); // 15 sec for key in PIN CODE, workaround for GS2 before issuing Nego Req.
-	//}	
-
-}
-
-static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct wireless_dev *wdev,
-#else
-	struct net_device *ndev,
-#endif
-	struct ieee80211_channel * channel,
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,8,0))
-	enum nl80211_channel_type channel_type,
-#endif
-	unsigned int duration, u64 *cookie)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct net_device *ndev = wdev_to_ndev(wdev);
-#endif
-	s32 err = 0;
-	u8 remain_ch = (u8) ieee80211_frequency_to_channel(channel->center_freq);
-	u8 ready_on_channel = _FALSE;
-	_adapter *padapter;
-	struct rtw_wdev_priv *pwdev_priv;
-	struct mlme_ext_priv *pmlmeext;
-	struct wifidirect_info *pwdinfo;
-	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
-	u8 is_p2p_find = _FALSE;
-
-#ifndef CONFIG_RADIO_WORK
-	#define RTW_ROCH_DURATION_ENLARGE
-	#define RTW_ROCH_BACK_OP
-#endif
-
-	if (ndev == NULL) {
-		return  -EINVAL;
-	}
-
-	padapter = (_adapter *)rtw_netdev_priv(ndev);
-	pwdev_priv = adapter_wdev_data(padapter);
-	pmlmeext = &padapter->mlmeextpriv;
-	pwdinfo = &padapter->wdinfo;
-	pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
-	#ifdef CONFIG_CONCURRENT_MODE
-	is_p2p_find=(duration < (pwdinfo->ext_listen_interval))? _TRUE : _FALSE;
-	#endif
-
-	*cookie = ATOMIC_INC_RETURN(&pcfg80211_wdinfo->ro_ch_cookie_gen);
-	
-	DBG_871X(FUNC_ADPT_FMT" ch:%u duration:%d, cookie:0x%llx\n", FUNC_ADPT_ARG(padapter), remain_ch, duration, *cookie);
-
-#ifdef CONFIG_MP_INCLUDED
-	if (padapter->registrypriv.mp_mode == 1) {
-			DBG_871X(FUNC_ADPT_FMT ": MP mode block remain_on_channel request\n", FUNC_ADPT_ARG(padapter)); 
-			err = -EFAULT;
-			goto exit;
-	}
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->pbuddy_adapter) {
-		if (padapter->pbuddy_adapter->registrypriv.mp_mode == 1) {
-			DBG_871X(FUNC_ADPT_FMT ": MP mode block remain_on_channel request\n", FUNC_ADPT_ARG(padapter->pbuddy_adapter));
-			err = -EFAULT;
-			goto exit;
-		}
-	}
-#endif
-#endif
-
-	if(pcfg80211_wdinfo->is_ro_ch == _TRUE)
-	{
-		DBG_8192C("%s, cancel ro ch timer\n", __func__);
-		_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
-		#ifdef CONFIG_CONCURRENT_MODE
-		ATOMIC_SET(&pwdev_priv->ro_ch_to, 1);
-		#endif //CONFIG_CONCURRENT_MODE
-		p2p_protocol_wk_hdl(padapter, P2P_RO_CH_WK);
-	}
-
-	pcfg80211_wdinfo->is_ro_ch = _TRUE;
-	pcfg80211_wdinfo->last_ro_ch_time = rtw_get_current_time();
-
-	if(_FAIL == rtw_pwr_wakeup(padapter)) {
-		err = -EFAULT;
-		goto exit;
-	}
-
-	_rtw_memcpy(&pcfg80211_wdinfo->remain_on_ch_channel, channel, sizeof(struct ieee80211_channel));
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,8,0))
-	pcfg80211_wdinfo->remain_on_ch_type= channel_type;
-	#endif
-	pcfg80211_wdinfo->remain_on_ch_cookie= *cookie;
-
-	rtw_scan_abort(padapter);
-#ifdef CONFIG_CONCURRENT_MODE		
-	if ((rtw_buddy_adapter_up(padapter)) && is_p2p_find)		//don't scan_abort during p2p_listen.
-		rtw_scan_abort(padapter->pbuddy_adapter);			
-#endif //CONFIG_CONCURRENT_MODE
-
-	if (check_fwstate(&padapter->mlmepriv, _FW_UNDER_LINKING|WIFI_UNDER_WPS) == _TRUE)
-	{
-		DBG_871X("mlme state:0x%x\n", get_fwstate(&padapter->mlmepriv));
-		remain_ch = padapter->mlmeextpriv.cur_channel;
-	}
-#ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_UNDER_LINKING|WIFI_UNDER_WPS) == _TRUE)
-	{
-		DBG_871X("buddy_intf's mlme state:0x%x\n", get_fwstate(&(padapter->pbuddy_adapter->mlmepriv)));
-		remain_ch = padapter->pbuddy_adapter->mlmeextpriv.cur_channel;
-	}
-#endif /* CONFIG_CONCURRENT_MODE */
-
-	//if(!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) && !rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
-		rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
-		adapter_wdev_data(padapter)->p2p_enabled = _TRUE;
-		padapter->wdinfo.listen_channel = remain_ch;
-	} else if (rtw_p2p_chk_state(pwdinfo , P2P_STATE_LISTEN)) {
-		padapter->wdinfo.listen_channel = remain_ch;
-	} else {
-		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
-#ifdef CONFIG_DEBUG_CFG80211		
-		DBG_8192C("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
-#endif
-	}
-
-
-	rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
-
-	#ifdef RTW_ROCH_DURATION_ENLARGE
-	if (duration < 400)
-		duration = duration * 3; /* extend from exper */
-	#endif
-
-#ifdef RTW_ROCH_BACK_OP
-#ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_LINKED)) {
-		if (is_p2p_find) /* p2p_find , duration<1000 */
-			duration = duration + pwdinfo->ext_listen_interval;
-		else /* p2p_listen, duration=5000 */
-			duration = pwdinfo->ext_listen_interval + (pwdinfo->ext_listen_interval / 4);
-	}
-#endif
-#endif /* RTW_ROCH_BACK_OP */
-
-	pcfg80211_wdinfo->restore_channel = rtw_get_oper_ch(padapter);
-
-	if(rtw_ch_set_search_ch(pmlmeext->channel_set, remain_ch) >= 0) {
-#ifdef	CONFIG_CONCURRENT_MODE
-		if ( check_buddy_fwstate(padapter, _FW_LINKED) )
-		{
-			PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;			
-			struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;	
-
-			if((remain_ch != pbuddy_mlmeext->cur_channel) && !check_fwstate(&padapter->mlmepriv, _FW_LINKED))
-			{	
-				if(ATOMIC_READ(&pwdev_priv->switch_ch_to)==1 ||
-					(remain_ch != pmlmeext->cur_channel))
-				{
-					if (check_buddy_fwstate(padapter, WIFI_FW_STATION_STATE)) {
-						DBG_8192C("%s, issue nulldata pwrbit=1\n", __func__);
-						issue_nulldata(padapter->pbuddy_adapter, NULL, 1, 3, 500);
-					}
-
-					ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
-
-					#ifdef RTW_ROCH_BACK_OP
-					DBG_8192C("%s, set switch ch timer, duration=%d\n", __func__, duration-pwdinfo->ext_listen_interval);
-					_set_timer(&pwdinfo->ap_p2p_switch_timer, duration-pwdinfo->ext_listen_interval);
-					#endif
-				}			
-			}
-		
-			ready_on_channel = _TRUE;
-			//pmlmeext->cur_channel = remain_ch;			
-			//set_channel_bwmode(padapter, remain_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-		}else 
-#endif //CONFIG_CONCURRENT_MODE
-		if(remain_ch != rtw_get_oper_ch(padapter) )
-		{
-			ready_on_channel = _TRUE;
-			//pmlmeext->cur_channel = remain_ch;			
-			//set_channel_bwmode(padapter, remain_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-		}
-	} else {
-		DBG_871X("%s remain_ch:%u not in channel plan!!!!\n", __FUNCTION__, remain_ch);
-	}
-	
-
-	//call this after other things have been done
-#ifdef	CONFIG_CONCURRENT_MODE	
-	if(ATOMIC_READ(&pwdev_priv->ro_ch_to)==1 ||
-		(remain_ch != rtw_get_oper_ch(padapter)))
-	{
-		u8 co_channel = 0xff;
-		ATOMIC_SET(&pwdev_priv->ro_ch_to, 0);
-#endif
-
-		if(ready_on_channel == _TRUE)
-		{			
-			if ( !check_fwstate(&padapter->mlmepriv, _FW_LINKED ) )
-			{
-				pmlmeext->cur_channel = remain_ch;
-			
-#ifdef	CONFIG_CONCURRENT_MODE
-				co_channel = rtw_get_oper_ch(padapter);
-
-				if(co_channel !=remain_ch)
-#endif
-				{
-					//if (!padapter->mlmepriv.LinkDetectInfo.bBusyTraffic)
-					set_channel_bwmode(padapter, remain_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-				}
-			}
-		}
-		DBG_8192C("%s, set ro ch timer, duration=%d\n", __func__, duration);
-		_set_timer( &pcfg80211_wdinfo->remain_on_ch_timer, duration);
-
-#ifdef	CONFIG_CONCURRENT_MODE
-	}
-#endif
-
-	rtw_cfg80211_ready_on_channel(padapter, *cookie, channel, channel_type, duration, GFP_KERNEL);
-
-exit:
-	if (err) {
-		pcfg80211_wdinfo->is_ro_ch = _FALSE;
-		pcfg80211_wdinfo->last_ro_ch_time = rtw_get_current_time();
-	}
-
-	return err;
-}
-
-static s32 cfg80211_rtw_cancel_remain_on_channel(struct wiphy *wiphy,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct wireless_dev *wdev,
-#else
-	struct net_device *ndev,
-#endif
-	u64 cookie)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct net_device *ndev = wdev_to_ndev(wdev);
-#endif
-	s32 err = 0;
-	_adapter *padapter;
-	struct rtw_wdev_priv *pwdev_priv;
-	struct wifidirect_info *pwdinfo;
-	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
-
-	if (ndev == NULL) {
-		err = -EINVAL;
-		goto exit;
-	}
-
-	padapter = (_adapter *)rtw_netdev_priv(ndev);
-	pwdev_priv = adapter_wdev_data(padapter);
-	pwdinfo = &padapter->wdinfo;
-	pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
-
-	DBG_871X(FUNC_ADPT_FMT" cookie:0x%llx\n", FUNC_ADPT_ARG(padapter), cookie);
-
-	if (pcfg80211_wdinfo->is_ro_ch == _TRUE) {
-		DBG_8192C("%s, cancel ro ch timer\n", __func__);
-		_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
-		#ifdef CONFIG_CONCURRENT_MODE
-		ATOMIC_SET(&pwdev_priv->ro_ch_to, 1);
-		#endif
-		p2p_protocol_wk_hdl(padapter, P2P_RO_CH_WK);
-	}
-
-	#if 0
-	//	Disable P2P Listen State
-	if(!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) && !rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-	{
-		if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		{
-			rtw_p2p_set_state(pwdinfo, P2P_STATE_NONE);
-			_rtw_memset(pwdinfo, 0x00, sizeof(struct wifidirect_info));
-		}
-	}
-	else
-	#endif
-	{
-		rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
-#ifdef CONFIG_DEBUG_CFG80211		 
-		DBG_8192C("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
-#endif
-	}
-
-	pcfg80211_wdinfo->is_ro_ch = _FALSE;
-	pcfg80211_wdinfo->last_ro_ch_time = rtw_get_current_time();
-
-exit:
-	return err;
-}
-
-#endif //CONFIG_P2P
-
-static int _cfg80211_rtw_mgmt_tx(_adapter *padapter, u8 tx_ch, const u8 *buf, size_t len, int wait_ack)
-{
-	struct xmit_frame	*pmgntframe;
-	struct pkt_attrib	*pattrib;
-	unsigned char	*pframe;
-	int ret = _FAIL;
-	bool ack = _TRUE;
-	struct rtw_ieee80211_hdr *pwlanhdr;
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
-	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-#ifdef 	CONFIG_P2P
-	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
-#endif //CONFIG_P2P
-	//struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
-
-	rtw_set_scan_deny(padapter, 1000);
-
-	rtw_scan_abort(padapter);
-	#ifdef CONFIG_CONCURRENT_MODE		
-	if(rtw_buddy_adapter_up(padapter))	
-		rtw_scan_abort(padapter->pbuddy_adapter);
-	#endif /* CONFIG_CONCURRENT_MODE */
-#ifdef CONFIG_P2P
-	if (padapter->cfg80211_wdinfo.is_ro_ch == _TRUE) {
-		//DBG_8192C("%s, cancel ro ch timer\n", __func__);
-		//_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
-		//padapter->cfg80211_wdinfo.is_ro_ch = _FALSE;
-		#ifdef CONFIG_CONCURRENT_MODE			
-		if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED ))
-		{
-			DBG_8192C("%s, extend ro ch time\n", __func__);
-			_set_timer( &padapter->cfg80211_wdinfo.remain_on_ch_timer, pwdinfo->ext_listen_period);
-		}	
-		#endif //CONFIG_CONCURRENT_MODE			
-	}
-#endif //CONFIG_P2P
-#ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_LINKED )) {
-		u8 co_channel=0xff;
-		PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;			
-		struct mlme_ext_priv *pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;	
-
-		co_channel = rtw_get_oper_ch(padapter);
-
-		if (tx_ch != pbuddy_mlmeext->cur_channel) {
-
-			u16 ext_listen_period;
-			
-			if (ATOMIC_READ(&pwdev_priv->switch_ch_to)==1) {
-				if (check_buddy_fwstate(padapter, WIFI_FW_STATION_STATE)) {
-					DBG_8192C("%s, issue nulldata pwrbit=1\n", __func__);
-					issue_nulldata(padapter->pbuddy_adapter, NULL, 1, 3, 500);
-				}
-
-				ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
-
-				//DBG_8192C("%s, set switch ch timer, period=%d\n", __func__, pwdinfo->ext_listen_period);
-				//_set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_period);
-			}
-
-			if (check_fwstate(&padapter->mlmepriv, _FW_LINKED ))
-			{
-				ext_listen_period = 500;// 500ms
-			}	
-			else
-			{				
-				ext_listen_period = pwdinfo->ext_listen_period;
-			}
-
-			DBG_8192C("%s, set switch ch timer, period=%d\n", __func__, ext_listen_period);
-			_set_timer(&pwdinfo->ap_p2p_switch_timer, ext_listen_period);	
-			
-		}
-
-		if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED ))
-			pmlmeext->cur_channel = tx_ch;
-
-		if (tx_ch != co_channel)
-			set_channel_bwmode(padapter, tx_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-	}else 
-#endif //CONFIG_CONCURRENT_MODE
-	//if (tx_ch != pmlmeext->cur_channel) {
-	if(tx_ch != rtw_get_oper_ch(padapter)) {
-		if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED ))
-			pmlmeext->cur_channel = tx_ch;
-		set_channel_bwmode(padapter, tx_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-	}
-
-	//starting alloc mgmt frame to dump it
-	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
-	{
-		//ret = -ENOMEM;
-		ret = _FAIL;
-		goto exit;
-	}
-
-	//update attribute
-	pattrib = &pmgntframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
-	pattrib->retry_ctrl = _FALSE;
-
-	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-	_rtw_memcpy(pframe, (void*)buf, len);
-	pattrib->pktlen = len;	
-	
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-	//update seq number
-	pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
-	pattrib->seqnum = pmlmeext->mgnt_seq;
-	pmlmeext->mgnt_seq++;
-
-#ifdef CONFIG_P2P
-	rtw_xframe_chk_wfd_ie(pmgntframe);
-#endif /* CONFIG_P2P */
-	
-	pattrib->last_txcmdsz = pattrib->pktlen;
-
-	if (wait_ack) {
-		if (dump_mgntframe_and_wait_ack(padapter, pmgntframe) != _SUCCESS) {
-			ack = _FALSE;
-			ret = _FAIL;
-
-#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("%s, ack == _FAIL\n", __func__);
-#endif
-		} else {
-
-#ifdef CONFIG_XMIT_ACK
-			rtw_msleep_os(50);
-#endif
-#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("%s, ack=%d, ok!\n", __func__, ack);
-#endif
-			ret = _SUCCESS;
-		}
-	} else {
-		dump_mgntframe(padapter, pmgntframe);
-		ret = _SUCCESS;
-	}
-exit:
-
-	#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("%s, ret=%d\n", __func__, ret);
-	#endif
-	
-	return ret;		
-	
-}
-
-static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct wireless_dev *wdev,
-#else
-	struct net_device *ndev,
-#endif
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,14,0)) || defined(COMPAT_KERNEL_RELEASE)
-	struct ieee80211_channel *chan,
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)) || defined(COMPAT_KERNEL_RELEASE)
-	bool offchan,
-	#endif
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,8,0))
-	enum nl80211_channel_type channel_type,
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	bool channel_type_valid,
-	#endif
-	#endif
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)) || defined(COMPAT_KERNEL_RELEASE)
-	unsigned int wait,
-	#endif
-	const u8 *buf, size_t len,
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,2,0))
-	bool no_cck,
-	#endif
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,3,0))
-	bool dont_wait_for_ack,
-	#endif
-#else
-	struct cfg80211_mgmt_tx_params *params,
-#endif
-	u64 *cookie)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct net_device *ndev = wdev_to_ndev(wdev);
-#endif
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,14,0)) || defined(COMPAT_KERNEL_RELEASE)
-	struct ieee80211_channel *chan = params->chan;
-	bool offchan = params->offchan;
-	unsigned int wait = params->wait;
-	const u8 *buf = params->buf;
-	size_t len = params->len;
-	bool no_cck = params->no_cck;
-	bool dont_wait_for_ack = params->dont_wait_for_ack;
-#endif
-	int ret = 0;
-	int tx_ret;
-	int wait_ack = 1;
-	u32 dump_limit = RTW_MAX_MGMT_TX_CNT;
-	u32 dump_cnt = 0;
-	bool ack = _TRUE;
-	u8 tx_ch;
-	u8 category, action;
-	u8 frame_styp;
-	int type = (-1);
-	u32 start = rtw_get_current_time();
-	_adapter *padapter;
-	struct rtw_wdev_priv *pwdev_priv;
-
-	if ((ndev == NULL) || (chan == NULL)) {
-		ret = -EINVAL;
-		goto exit;
-	}
-
-	tx_ch = (u8)ieee80211_frequency_to_channel(chan->center_freq);
-
-	padapter = (_adapter *)rtw_netdev_priv(ndev);
-	pwdev_priv = adapter_wdev_data(padapter);
-
-	/* cookie generation */
-	*cookie = (unsigned long) buf;
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_871X(FUNC_ADPT_FMT" len=%zu, ch=%d"
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,8,0))
-		", ch_type=%d"
-		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)	
-		", channel_type_valid=%d"
-		#endif
-	#endif
-		"\n", FUNC_ADPT_ARG(padapter),
-		len, tx_ch
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,8,0))
-		, channel_type
-		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)	
-		, channel_type_valid
-		#endif
-	#endif
-	);
-#endif /* CONFIG_DEBUG_CFG80211 */
-
-	/* indicate ack before issue frame to avoid racing with rsp frame */
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-	rtw_cfg80211_mgmt_tx_status(padapter, *cookie, buf, len, ack, GFP_KERNEL);
-#elif  (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,34) && LINUX_VERSION_CODE<=KERNEL_VERSION(2,6,35))
-	cfg80211_action_tx_status(ndev, *cookie, buf, len, ack, GFP_KERNEL);
-#endif
-
-	frame_styp = le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl) & IEEE80211_FCTL_STYPE;
-	if (IEEE80211_STYPE_PROBE_RESP == frame_styp) {
-#ifdef CONFIG_DEBUG_CFG80211
-		DBG_8192C("RTW_Tx: probe_resp tx_ch=%d, da="MAC_FMT"\n", tx_ch, MAC_ARG(GetAddr1Ptr(buf)));
-#endif /* CONFIG_DEBUG_CFG80211 */
-		wait_ack = 0;
-		goto dump;
-	}
-
-	if (rtw_action_frame_parse(buf, len, &category, &action) == _FALSE) {
-		DBG_8192C(FUNC_ADPT_FMT" frame_control:0x%x\n", FUNC_ADPT_ARG(padapter),
-			le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl));
-		goto exit;
-	}
-
-	DBG_8192C("RTW_Tx:tx_ch=%d, da="MAC_FMT"\n", tx_ch, MAC_ARG(GetAddr1Ptr(buf)));
-	#ifdef CONFIG_P2P
-	if((type = rtw_p2p_check_frames(padapter, buf, len, _TRUE)) >= 0) {
-		goto dump;
-	}
-	#endif
-	if (category == RTW_WLAN_CATEGORY_PUBLIC)
-		DBG_871X("RTW_Tx:%s\n", action_public_str(action));
-	else
-		DBG_871X("RTW_Tx:category(%u), action(%u)\n", category, action);
-
-dump:
-
-	rtw_ps_deny(padapter, PS_DENY_MGNT_TX);
-	if(_FAIL == rtw_pwr_wakeup(padapter)) {
-		ret = -EFAULT;
-		goto cancel_ps_deny;
-	}
-
-	while (1) {
-		u32 sleep_ms = 0;
-		u32 retry_guarantee_ms = 0;
-
-		dump_cnt++;
-		tx_ret = _cfg80211_rtw_mgmt_tx(padapter, tx_ch, buf, len, wait_ack);
-
-		switch (action) {
-		case ACT_PUBLIC_GAS_INITIAL_REQ:
-		case ACT_PUBLIC_GAS_INITIAL_RSP:
-			sleep_ms = 50;
-			retry_guarantee_ms = RTW_MAX_MGMT_TX_MS_GAS;
-		}
-
-		if (tx_ret == _SUCCESS
-			|| (dump_cnt >= dump_limit && rtw_get_passing_time_ms(start) >= retry_guarantee_ms))
-				break;
-
-		if (sleep_ms > 0)
-			rtw_msleep_os(sleep_ms);
-	}
-
-	if (tx_ret != _SUCCESS || dump_cnt > 1) {
-		DBG_871X(FUNC_ADPT_FMT" %s (%d/%d) in %d ms\n", FUNC_ADPT_ARG(padapter),
-			tx_ret==_SUCCESS?"OK":"FAIL", dump_cnt, dump_limit, rtw_get_passing_time_ms(start));
-	}
-
-	switch (type) {
-	case P2P_GO_NEGO_CONF:
-		rtw_clear_scan_deny(padapter);
-		break;
-	case P2P_INVIT_RESP:
-		if (pwdev_priv->invit_info.flags & BIT(0)
-			&& pwdev_priv->invit_info.status == 0) 
-		{
-			DBG_871X(FUNC_ADPT_FMT" agree with invitation of persistent group\n",
-				FUNC_ADPT_ARG(padapter));
-			rtw_set_scan_deny(padapter, 5000);
-			rtw_pwr_wakeup_ex(padapter, 5000);
-			rtw_clear_scan_deny(padapter);
-		}
-		break;
-	}	
-
-cancel_ps_deny:
-	rtw_ps_deny_cancel(padapter, PS_DENY_MGNT_TX);
-exit:
-	return ret;
-}
-
-static void cfg80211_rtw_mgmt_frame_register(struct wiphy *wiphy,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
-	struct wireless_dev *wdev,
-#else
-	struct net_device *ndev,
-#endif
-	u16 frame_type, bool reg)
-{
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0))
-	struct net_device *ndev = wdev_to_ndev(wdev);
-#endif
-	_adapter *adapter;
-
-	struct rtw_wdev_priv *pwdev_priv;
-
-	if (ndev == NULL)
-		goto exit;
-
-	adapter = (_adapter *)rtw_netdev_priv(ndev);
-	pwdev_priv = adapter_wdev_data(adapter);
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_871X(FUNC_ADPT_FMT" frame_type:%x, reg:%d\n", FUNC_ADPT_ARG(adapter),
-		frame_type, reg);
-#endif
-
-	/* Wait QC Verify */
-	return;
-
-	switch (frame_type) {
-	case IEEE80211_STYPE_PROBE_REQ: /* 0x0040 */
-		SET_CFG80211_REPORT_MGMT(pwdev_priv, IEEE80211_STYPE_PROBE_REQ, reg);
-		break;
-	case IEEE80211_STYPE_ACTION: /* 0x00D0 */
-		SET_CFG80211_REPORT_MGMT(pwdev_priv, IEEE80211_STYPE_ACTION, reg);
-		break;
-	default:
-		break;
-	}
-
-exit:
-	return;
-}
-
-#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3,2,0))
-static int cfg80211_rtw_tdls_mgmt(struct wiphy *wiphy,
-	struct net_device *ndev,
-	u8 *peer,
-	u8 action_code,
-	u8 dialog_token,
-	u16 status_code,
-	const u8 *buf,
-	size_t len)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &pmlmeext->mlmext_info;
-	int ret = 0;
-	struct tdls_txmgmt txmgmt;
-
-	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
-		DBG_871X("Discard tdls action:%d, since hal doesn't support tdls\n", action_code);
-		goto discard;
-	}
-
-	if (rtw_tdls_is_driver_setup(padapter)) {
-		DBG_871X("Discard tdls action:%d, let driver to set up direct link\n", action_code);
-		goto discard;
-	}
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	_rtw_memcpy(txmgmt.peer, peer, ETH_ALEN);
-	txmgmt.action_code = action_code;
-	txmgmt.dialog_token= dialog_token;
-	txmgmt.status_code = status_code;
-	txmgmt.len = len;
-	txmgmt.buf = (u8 *)rtw_malloc(txmgmt.len);
-	if (txmgmt.buf == NULL) {
-		ret = -ENOMEM;
-		goto bad;
-	}
-	_rtw_memcpy(txmgmt.buf, (void*)buf, txmgmt.len);
-
-/* Debug purpose */
-#if 1
-	DBG_871X("%s %d\n", __FUNCTION__, __LINE__);
-	DBG_871X("peer:"MAC_FMT", action code:%d, dialog:%d, status code:%d\n",
-				MAC_ARG(txmgmt.peer), txmgmt.action_code, 
-				txmgmt.dialog_token, txmgmt.status_code);
-	if (txmgmt.len > 0) {
-		int i=0;
-		for(;i < len; i++)
-			printk("%02x ", *(txmgmt.buf+i));
-			DBG_871X("len:%d\n", txmgmt.len);
-	}
-#endif
-
-	switch (txmgmt.action_code) {
-	case TDLS_SETUP_REQUEST:
-		issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
-		break;
-	case TDLS_SETUP_RESPONSE:
-		issue_tdls_setup_rsp(padapter, &txmgmt);
-		break;
-	case TDLS_SETUP_CONFIRM:
-		issue_tdls_setup_cfm(padapter, &txmgmt);
-		break;
-	case TDLS_TEARDOWN:
-		issue_tdls_teardown(padapter, &txmgmt, _TRUE);
-		break;
-	case TDLS_DISCOVERY_REQUEST:
-		issue_tdls_dis_req(padapter, &txmgmt);
-		break;
-	case TDLS_DISCOVERY_RESPONSE:
-		issue_tdls_dis_rsp(padapter, &txmgmt, pmlmeinfo->enc_algo? _TRUE : _FALSE);
-		break;
-	}
-
-bad:
-	if (txmgmt.buf)
-		rtw_mfree(txmgmt.buf, txmgmt.len);
-
-discard:
-	return ret;
-}
-
-static int cfg80211_rtw_tdls_oper(struct wiphy *wiphy,
-	struct net_device *ndev,
-	u8 *peer,
-	enum nl80211_tdls_operation oper)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct tdls_txmgmt	txmgmt;
-	struct sta_info *ptdls_sta = NULL;
-
-	DBG_871X(FUNC_NDEV_FMT", nl80211_tdls_operation:%d\n", FUNC_NDEV_ARG(ndev), oper);
-
-	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
-		DBG_871X("Discard tdls oper:%d, since hal doesn't support tdls\n", oper);
-		return 0;
-	}
-
-#ifdef CONFIG_LPS
-	rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1);
-#endif //CONFIG_LPS
-
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	if (peer)
-		_rtw_memcpy(txmgmt.peer, peer, ETH_ALEN);
-
-	if (rtw_tdls_is_driver_setup(padapter)) {
-		/* these two cases are done by driver itself */
-		if (oper == NL80211_TDLS_ENABLE_LINK || oper == NL80211_TDLS_DISABLE_LINK)
-			return 0;
-	}
-
-	switch (oper) {
-	case NL80211_TDLS_DISCOVERY_REQ:
-		issue_tdls_dis_req(padapter, &txmgmt);
-		break;
-	case NL80211_TDLS_SETUP:
-#ifdef CONFIG_WFD
-		if ( _AES_ != padapter->securitypriv.dot11PrivacyAlgrthm ) {
-			if ( padapter->wdinfo.wfd_tdls_weaksec == _TRUE)
-				issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
-			else
-				DBG_871X( "[%s] Current link is not AES, SKIP sending the tdls setup request!!\n", __FUNCTION__ );
-		} else
-#endif // CONFIG_WFD
-		{
-			issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
-		}
-		break;
-	case NL80211_TDLS_TEARDOWN:
-		ptdls_sta = rtw_get_stainfo( &(padapter->stapriv), txmgmt.peer);
-		if (ptdls_sta != NULL) {
-			txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
-			issue_tdls_teardown(padapter, &txmgmt, _TRUE);
-		}else {
-			DBG_871X( "TDLS peer not found\n");
-		}
-		break;
-	case NL80211_TDLS_ENABLE_LINK:
-		DBG_871X(FUNC_NDEV_FMT", NL80211_TDLS_ENABLE_LINK;mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(peer));
-		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), peer);
-		if (ptdls_sta != NULL) {
-			ptdlsinfo->link_established = _TRUE;
-			ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
-			ptdls_sta->state |= _FW_LINKED;
-			rtw_tdls_cmd(padapter, txmgmt.peer, TDLS_ESTABLISHED);
-		}
-		break;
-	case NL80211_TDLS_DISABLE_LINK:
-		DBG_871X(FUNC_NDEV_FMT", NL80211_TDLS_DISABLE_LINK;mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(peer));
-		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), peer);
-		if (ptdls_sta != NULL) {
-			rtw_tdls_cmd(padapter, peer, TDLS_TEAR_STA );
-		}
-		break;
-	}
-	return 0;
-}
-#endif /* CONFIG_TDLS */
-
-#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3,0,0))
-static int cfg80211_rtw_sched_scan_start(struct wiphy *wiphy,
-		struct net_device *dev,
-		struct cfg80211_sched_scan_request *request) {
-
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	u8 ret;
-
-	if (padapter->bup == _FALSE) {
-		DBG_871X("%s: net device is down.\n", __func__);
-		return -EIO;
-	}
-
-	if(check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE ||
-		check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE  ||
-		check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
-		DBG_871X("%s: device is busy.\n", __func__);
-		rtw_scan_abort(padapter);
-	}
-
-	if (request == NULL) {
-		DBG_871X("%s: invalid cfg80211_requests parameters.\n", __func__);
-		return -EINVAL;
-	}
-
-	ret = rtw_android_cfg80211_pno_setup(dev, request->ssids,
-			request->n_ssids, request->interval);
-
-	if (ret < 0) {
-		DBG_871X("%s ret: %d\n", __func__, ret);
-		goto exit;
-	}
-
-	ret = rtw_android_pno_enable(dev, _TRUE);
-	if (ret < 0) {
-		DBG_871X("%s ret: %d\n", __func__, ret);
-		goto exit;
-	}
-exit:
-	return ret;
-}
-
-static int cfg80211_rtw_sched_scan_stop(struct wiphy *wiphy,
-		struct net_device *dev) {
-	return rtw_android_pno_enable(dev, _FALSE);
-}
-#endif /* CONFIG_PNO_SUPPORT */
-
-static int rtw_cfg80211_set_beacon_wpsp2pie(struct net_device *ndev, char *buf, int len)
-{	
-	int ret = 0;
-	uint wps_ielen = 0;
-	u8 *wps_ie;
-	u32	p2p_ielen = 0;
-	u8 wps_oui[8]={0x0,0x50,0xf2,0x04};	
-	u8 *p2p_ie;
-	u32	wfd_ielen = 0;	
-	u8 *wfd_ie;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
-
-	DBG_871X(FUNC_NDEV_FMT" ielen=%d\n", FUNC_NDEV_ARG(ndev), len);
-	
-	if(len>0)
-	{
-		if((wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen)))
-		{	
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("bcn_wps_ielen=%d\n", wps_ielen);
-			#endif
-		
-			if(pmlmepriv->wps_beacon_ie)
-			{
-				u32 free_len = pmlmepriv->wps_beacon_ie_len;
-				pmlmepriv->wps_beacon_ie_len = 0;
-				rtw_mfree(pmlmepriv->wps_beacon_ie, free_len);
-				pmlmepriv->wps_beacon_ie = NULL;			
-			}	
-
-			pmlmepriv->wps_beacon_ie = rtw_malloc(wps_ielen);
-			if ( pmlmepriv->wps_beacon_ie == NULL) {
-				DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-				return -EINVAL;
-			
-			}
-			
-			_rtw_memcpy(pmlmepriv->wps_beacon_ie, wps_ie, wps_ielen);
-			pmlmepriv->wps_beacon_ie_len = wps_ielen;
-	
-			update_beacon(padapter, _VENDOR_SPECIFIC_IE_, wps_oui, _TRUE);
-
-		}
-
-		//buf += wps_ielen;
-		//len -= wps_ielen;
-
-		#ifdef CONFIG_P2P
-		if((p2p_ie=rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen)))
-		{
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("bcn_p2p_ielen=%d\n", p2p_ielen);
-			#endif
-		
-			if(pmlmepriv->p2p_beacon_ie)
-			{
-				u32 free_len = pmlmepriv->p2p_beacon_ie_len;
-				pmlmepriv->p2p_beacon_ie_len = 0;
-				rtw_mfree(pmlmepriv->p2p_beacon_ie, free_len);
-				pmlmepriv->p2p_beacon_ie = NULL;			
-			}	
-
-			pmlmepriv->p2p_beacon_ie = rtw_malloc(p2p_ielen);
-			if ( pmlmepriv->p2p_beacon_ie == NULL) {
-				DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-				return -EINVAL;
-			
-			}
-			
-			_rtw_memcpy(pmlmepriv->p2p_beacon_ie, p2p_ie, p2p_ielen);
-			pmlmepriv->p2p_beacon_ie_len = p2p_ielen;
-			
-		}
-		#endif //CONFIG_P2P
-
-
-		#ifdef CONFIG_WFD
-		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
-		if (wfd_ie) {
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("bcn_wfd_ielen=%d\n", wfd_ielen);
-			#endif
-
-			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_BEACON_IE, wfd_ie, wfd_ielen) != _SUCCESS)
-				return -EINVAL;
-		}
-		#endif /* CONFIG_WFD */
-		
-		pmlmeext->bstart_bss = _TRUE;
-		
-	}
-
-	return ret;
-	
-}
-
-static int rtw_cfg80211_set_probe_resp_wpsp2pie(struct net_device *net, char *buf, int len)
-{
-	int ret = 0;
-	uint wps_ielen = 0;
-	u8 *wps_ie;
-	u32	p2p_ielen = 0;	
-	u8 *p2p_ie;
-	u32	wfd_ielen = 0;	
-	u8 *wfd_ie;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("%s, ielen=%d\n", __func__, len);
-#endif
-	
-	if(len>0)
-	{
-		if((wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen)))
-		{	
-			uint	attr_contentlen = 0;
-			u16	uconfig_method, *puconfig_method = NULL;
-
-			#ifdef CONFIG_DEBUG_CFG80211			
-			DBG_8192C("probe_resp_wps_ielen=%d\n", wps_ielen);
-			#endif
-		
-			if(check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
-			{
-				u8 sr = 0;
-				rtw_get_wps_attr_content(wps_ie,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8*)(&sr), NULL);
-
-				if (sr != 0)
-				{
-					DBG_871X("%s, got sr\n", __func__);
-				}	
-				else
-				{				
-					DBG_8192C("GO mode process WPS under site-survey,  sr no set\n");
-					return ret;
-				}	
-			}			
-		
-			if(pmlmepriv->wps_probe_resp_ie)
-			{
-				u32 free_len = pmlmepriv->wps_probe_resp_ie_len;
-				pmlmepriv->wps_probe_resp_ie_len = 0;
-				rtw_mfree(pmlmepriv->wps_probe_resp_ie, free_len);
-				pmlmepriv->wps_probe_resp_ie = NULL;			
-			}	
-
-			pmlmepriv->wps_probe_resp_ie = rtw_malloc(wps_ielen);
-			if ( pmlmepriv->wps_probe_resp_ie == NULL) {
-				DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-				return -EINVAL;
-			
-			}
-			
-			//add PUSH_BUTTON config_method by driver self in wpsie of probe_resp at GO Mode 
-			if ( (puconfig_method = (u16*)rtw_get_wps_attr_content( wps_ie, wps_ielen, WPS_ATTR_CONF_METHOD , NULL, &attr_contentlen)) != NULL )
-			{
-				//struct registry_priv *pregistrypriv = &padapter->registrypriv;
-				struct wireless_dev *wdev = padapter->rtw_wdev;
-				
-				#ifdef CONFIG_DEBUG_CFG80211		
-				//printk("config_method in wpsie of probe_resp = 0x%x\n", be16_to_cpu(*puconfig_method));
-				#endif
-
-				#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
-				/* for WIFI-DIRECT LOGO 4.2.2, AUTO GO can't set PUSH_BUTTON flags */
-				if (wdev->iftype == NL80211_IFTYPE_P2P_GO) {
-					uconfig_method = WPS_CM_PUSH_BUTTON;
-					uconfig_method = cpu_to_be16(uconfig_method);
-
-					*puconfig_method &= ~uconfig_method;
-				}
-				#endif
-			}
-			
-			_rtw_memcpy(pmlmepriv->wps_probe_resp_ie, wps_ie, wps_ielen);
-			pmlmepriv->wps_probe_resp_ie_len = wps_ielen;
-			
-		}
-
-		//buf += wps_ielen;
-		//len -= wps_ielen;
-
-		#ifdef CONFIG_P2P
-		if((p2p_ie=rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen))) 
-		{
-			u8 is_GO = _FALSE;			
-			u32 attr_contentlen = 0;
-			u16 cap_attr=0;
-
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("probe_resp_p2p_ielen=%d\n", p2p_ielen);
-			#endif			
-
-			//Check P2P Capability ATTR
-			if( rtw_get_p2p_attr_content( p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8*)&cap_attr, (uint*) &attr_contentlen) )
-			{
-				u8 grp_cap=0;
-				//DBG_8192C( "[%s] Got P2P Capability Attr!!\n", __FUNCTION__ );
-				cap_attr = le16_to_cpu(cap_attr);
-				grp_cap = (u8)((cap_attr >> 8)&0xff);
-				
-				is_GO = (grp_cap&BIT(0)) ? _TRUE:_FALSE;
-
-				if(is_GO)
-					DBG_8192C("Got P2P Capability Attr, grp_cap=0x%x, is_GO\n", grp_cap);
-			}
-
-
-			if(is_GO == _FALSE)
-			{
-				if(pmlmepriv->p2p_probe_resp_ie)
-				{
-					u32 free_len = pmlmepriv->p2p_probe_resp_ie_len;
-					pmlmepriv->p2p_probe_resp_ie_len = 0;
-					rtw_mfree(pmlmepriv->p2p_probe_resp_ie, free_len);
-					pmlmepriv->p2p_probe_resp_ie = NULL;		
-				}	
-
-				pmlmepriv->p2p_probe_resp_ie = rtw_malloc(p2p_ielen);
-				if ( pmlmepriv->p2p_probe_resp_ie == NULL) {
-					DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-					return -EINVAL;
-				
-				}
-				_rtw_memcpy(pmlmepriv->p2p_probe_resp_ie, p2p_ie, p2p_ielen);
-				pmlmepriv->p2p_probe_resp_ie_len = p2p_ielen;
-			}		
-			else
-			{
-				if(pmlmepriv->p2p_go_probe_resp_ie)
-				{
-					u32 free_len = pmlmepriv->p2p_go_probe_resp_ie_len;
-					pmlmepriv->p2p_go_probe_resp_ie_len = 0;
-					rtw_mfree(pmlmepriv->p2p_go_probe_resp_ie, free_len);
-					pmlmepriv->p2p_go_probe_resp_ie = NULL;			
-				}	
-
-				pmlmepriv->p2p_go_probe_resp_ie = rtw_malloc(p2p_ielen);
-				if ( pmlmepriv->p2p_go_probe_resp_ie == NULL) {
-					DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-					return -EINVAL;
-			
-				}
-				_rtw_memcpy(pmlmepriv->p2p_go_probe_resp_ie, p2p_ie, p2p_ielen);
-				pmlmepriv->p2p_go_probe_resp_ie_len = p2p_ielen;
-			}
-			
-		}
-		#endif //CONFIG_P2P
-
-
-		#ifdef CONFIG_WFD
-		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
-		if (wfd_ie) {
-			#ifdef CONFIG_DEBUG_CFG80211
-			DBG_8192C("probe_resp_wfd_ielen=%d\n", wfd_ielen);
-			#endif
-
-			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_PROBE_RESP_IE, wfd_ie, wfd_ielen) != _SUCCESS)
-				return -EINVAL;
-		}
-		#endif /* CONFIG_WFD */
-		
-	}
-
-	return ret;
-	
-}
-
-static int rtw_cfg80211_set_assoc_resp_wpsp2pie(struct net_device *net, char *buf, int len)
-{
-	int ret = 0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	u8 *ie;
-	u32 ie_len;
-
-	DBG_8192C("%s, ielen=%d\n", __func__, len);
-
-	if (len <= 0)
-		goto exit;
-
-	ie = rtw_get_wps_ie(buf, len, NULL, &ie_len);
-	if (ie && ie_len) {
-		if (pmlmepriv->wps_assoc_resp_ie) {
-			u32 free_len = pmlmepriv->wps_assoc_resp_ie_len;
-
-			pmlmepriv->wps_assoc_resp_ie_len = 0;
-			rtw_mfree(pmlmepriv->wps_assoc_resp_ie, free_len);
-			pmlmepriv->wps_assoc_resp_ie = NULL;
-		}
-
-		pmlmepriv->wps_assoc_resp_ie = rtw_malloc(ie_len);
-		if (pmlmepriv->wps_assoc_resp_ie == NULL) {
-			DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-			return -EINVAL;
-		}
-		_rtw_memcpy(pmlmepriv->wps_assoc_resp_ie, ie, ie_len);
-		pmlmepriv->wps_assoc_resp_ie_len = ie_len;
-	}
-
-	ie = rtw_get_p2p_ie(buf, len, NULL, &ie_len);
-	if (ie && ie_len) {
-		if (pmlmepriv->p2p_assoc_resp_ie) {
-			u32 free_len = pmlmepriv->p2p_assoc_resp_ie_len;
-
-			pmlmepriv->p2p_assoc_resp_ie_len = 0;
-			rtw_mfree(pmlmepriv->p2p_assoc_resp_ie, free_len);
-			pmlmepriv->p2p_assoc_resp_ie = NULL;
-		}
-
-		pmlmepriv->p2p_assoc_resp_ie = rtw_malloc(ie_len);
-		if (pmlmepriv->p2p_assoc_resp_ie == NULL) {
-			DBG_8192C("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
-			return -EINVAL;
-		}
-		_rtw_memcpy(pmlmepriv->p2p_assoc_resp_ie, ie, ie_len);
-		pmlmepriv->p2p_assoc_resp_ie_len = ie_len;
-	}
-
-#ifdef CONFIG_WFD
-	ie = rtw_get_wfd_ie(buf, len, NULL, &ie_len);
-	if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_ASSOC_RESP_IE, ie, ie_len) != _SUCCESS)
-		return -EINVAL;
-#endif
-
-exit:
-	return ret;
-}
-
-int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len,
-	int type)
-{
-	int ret = 0;
-	uint wps_ielen = 0;
-	u32	p2p_ielen = 0;
-
-#ifdef CONFIG_DEBUG_CFG80211
-	DBG_8192C("%s, ielen=%d\n", __func__, len);
-#endif
-
-	if(	(rtw_get_wps_ie(buf, len, NULL, &wps_ielen) && (wps_ielen>0))
-		#ifdef CONFIG_P2P
-		|| (rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen) && (p2p_ielen>0))
-		#endif
-	)		
-	{	
-		if (net != NULL) 
-		{
-			switch (type) 
-			{
-				case 0x1: //BEACON
-				ret = rtw_cfg80211_set_beacon_wpsp2pie(net, buf, len);
-				break;
-				case 0x2: //PROBE_RESP
-				ret = rtw_cfg80211_set_probe_resp_wpsp2pie(net, buf, len);
-				break;
-				case 0x4: //ASSOC_RESP
-				ret = rtw_cfg80211_set_assoc_resp_wpsp2pie(net, buf, len);
-				break;
-			}		
-		}
-	}	
-
-	return ret;
-	
-}
-
-static void rtw_cfg80211_init_ht_capab_ex(_adapter *padapter, struct ieee80211_sta_ht_cap *ht_cap, enum ieee80211_band band, u8 rf_type)
-{
-	struct registry_priv *pregistrypriv = &padapter->registrypriv;
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
-	u8 stbc_rx_enable = _FALSE;
-
-	rtw_ht_use_default_setting(padapter);
-
-	/* RX LDPC */
-	if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX))
-		ht_cap->cap |= IEEE80211_HT_CAP_LDPC_CODING;
-
-	/* TX STBC */
-	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX))
-		ht_cap->cap |= IEEE80211_HT_CAP_TX_STBC;
-
-	/* RX STBC */
-	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX)) {
-		/*rtw_rx_stbc 0: disable, bit(0):enable 2.4g, bit(1):enable 5g*/
-		if (IEEE80211_BAND_2GHZ == band)
-			stbc_rx_enable = (pregistrypriv->rx_stbc & BIT(0))?_TRUE:_FALSE;
-		if (IEEE80211_BAND_5GHZ == band)
-			stbc_rx_enable = (pregistrypriv->rx_stbc & BIT(1))?_TRUE:_FALSE;
-
-		if (stbc_rx_enable) {
-			switch (rf_type) {
-			case RF_1T1R:
-				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/*RX STBC One spatial stream*/
-				break;
-
-			case RF_2T2R:
-			case RF_1T2R:
-				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/* Only one spatial-stream STBC RX is supported */
-				break;
-			case RF_3T3R:
-			case RF_3T4R:
-			case RF_4T4R:
-				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/* Only one spatial-stream STBC RX is supported */
-				break;
-			default:
-				DBG_871X("[warning] rf_type %d is not expected\n", rf_type);
-				break;
-			}
-		}
-	}
-}
-
-static void rtw_cfg80211_init_ht_capab(_adapter *padapter, struct ieee80211_sta_ht_cap *ht_cap, enum ieee80211_band band, u8 rf_type)
-{
-#define MAX_BIT_RATE_40MHZ_MCS23	450	/* Mbps */
-#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;
-	rtw_cfg80211_init_ht_capab_ex(padapter, ht_cap, band, rf_type);
-
-	/*
-	 *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[IEEE80211_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_highest = MAX_BIT_RATE_40MHZ_MCS7;
-	} else if ((rf_type == RF_1T2R) || (rf_type == RF_2T2R) || (rf_type == RF_2T2R_GREEN)) {
-		ht_cap->mcs.rx_mask[0] = 0xFF;
-		ht_cap->mcs.rx_mask[1] = 0xFF;
-
-		ht_cap->mcs.rx_highest = MAX_BIT_RATE_40MHZ_MCS15;
-	} else if ((rf_type == RF_2T3R) || (rf_type == RF_3T3R)) {
-		ht_cap->mcs.rx_mask[0] = 0xFF;
-		ht_cap->mcs.rx_mask[1] = 0xFF;
-		ht_cap->mcs.rx_mask[2] = 0xFF;
-
-		ht_cap->mcs.rx_highest = MAX_BIT_RATE_40MHZ_MCS23;
-	} else {
-		rtw_warn_on(1);
-		DBG_8192C("%s, error rf_type=%d\n", __func__, rf_type);
-	}	
-	
-}
-
-void rtw_cfg80211_init_wiphy(_adapter *padapter)
-{
-	u8 rf_type;
-	struct ieee80211_supported_band *bands;
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
-	struct wiphy *wiphy = pwdev->wiphy;
-	
-	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-
-	DBG_8192C("%s:rf_type=%d\n", __func__, rf_type);
-
-	if (IsSupported24G(padapter->registrypriv.wireless_mode)) {	
-		bands = wiphy->bands[IEEE80211_BAND_2GHZ];
-		if(bands)
-			rtw_cfg80211_init_ht_capab(padapter, &bands->ht_cap, IEEE80211_BAND_2GHZ, rf_type);
-	}
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-	if (IsSupported5G(padapter->registrypriv.wireless_mode)) {	
-		bands = wiphy->bands[IEEE80211_BAND_5GHZ];
-		if(bands)
-			rtw_cfg80211_init_ht_capab(padapter, &bands->ht_cap, IEEE80211_BAND_5GHZ, rf_type);
-	}
-#endif
-	/* init regulary domain */
-	rtw_regd_init(padapter);
-
-	/* copy mac_addr to wiphy */
-	_rtw_memcpy(wiphy->perm_addr, adapter_mac_addr(padapter), ETH_ALEN);
-
-}
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
-struct ieee80211_iface_limit rtw_limits[] = {
-	{	.max = 2,
-		.types = BIT(NL80211_IFTYPE_STATION)
-			#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
-			| BIT(NL80211_IFTYPE_P2P_CLIENT)
-			#endif
-	},
-	#ifdef CONFIG_AP_MODE
-	{	.max = 1,
-		.types = BIT(NL80211_IFTYPE_AP)
-			#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
-			| BIT(NL80211_IFTYPE_P2P_GO)
-			#endif
-	},
-	#endif
-};
-
-struct ieee80211_iface_combination rtw_combinations[] = {
-	{	.limits = rtw_limits,
-		.n_limits = ARRAY_SIZE(rtw_limits),
-		.max_interfaces = 2,
-		.num_different_channels = 1,
-	},
-};
-#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)) */
-
-static void rtw_cfg80211_preinit_wiphy(_adapter *adapter, struct wiphy *wiphy)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
-
-	wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM;
-
-	wiphy->max_scan_ssids = RTW_SSID_SCAN_AMOUNT;
-	wiphy->max_scan_ie_len = RTW_SCAN_IE_LEN_MAX;	
-	wiphy->max_num_pmkids = RTW_MAX_NUM_PMKIDS;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)) || defined(COMPAT_KERNEL_RELEASE)	 
-	wiphy->max_remain_on_channel_duration = RTW_MAX_REMAIN_ON_CHANNEL_DURATION;
-#endif
-	
-	wiphy->interface_modes =	BIT(NL80211_IFTYPE_STATION)
-								| BIT(NL80211_IFTYPE_ADHOC)
-#ifdef CONFIG_AP_MODE
-								| BIT(NL80211_IFTYPE_AP)
-								#ifdef CONFIG_WIFI_MONITOR
-								| BIT(NL80211_IFTYPE_MONITOR)
-								#endif
-#endif
-#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE))
-								| BIT(NL80211_IFTYPE_P2P_CLIENT)
-								| BIT(NL80211_IFTYPE_P2P_GO)
-#endif
-								;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)	
-#ifdef CONFIG_AP_MODE
-	wiphy->mgmt_stypes = rtw_cfg80211_default_mgmt_stypes;
-#endif //CONFIG_AP_MODE	
-#endif		
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,0,0))
-	#ifdef CONFIG_WIFI_MONITOR
-	wiphy->software_iftypes |= BIT(NL80211_IFTYPE_MONITOR);
-	#endif
-#endif
-
-	#if defined(RTW_SINGLE_WIPHY) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
-	wiphy->iface_combinations = rtw_combinations;
-	wiphy->n_iface_combinations = ARRAY_SIZE(rtw_combinations);
-	#endif
-
-	wiphy->cipher_suites = rtw_cipher_suites;
-	wiphy->n_cipher_suites = ARRAY_SIZE(rtw_cipher_suites);
-
-	if (IsSupported24G(adapter->registrypriv.wireless_mode))
-		wiphy->bands[IEEE80211_BAND_2GHZ] = rtw_spt_band_alloc(IEEE80211_BAND_2GHZ);
-
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-	if (IsSupported5G(adapter->registrypriv.wireless_mode))
-		wiphy->bands[IEEE80211_BAND_5GHZ] = rtw_spt_band_alloc(IEEE80211_BAND_5GHZ);
-#endif
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38) && LINUX_VERSION_CODE < KERNEL_VERSION(3,0,0))
-	wiphy->flags |= WIPHY_FLAG_SUPPORTS_SEPARATE_DEFAULT_KEYS;
-#endif
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,3,0))
-	wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
-	wiphy->flags |= WIPHY_FLAG_HAVE_AP_SME;
-	/* remove WIPHY_FLAG_OFFCHAN_TX, because we not support this feature */
-	/* wiphy->flags |= WIPHY_FLAG_OFFCHAN_TX | WIPHY_FLAG_HAVE_AP_SME; */
-#endif
-
-#if defined(CONFIG_PM) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
-	wiphy->flags |= WIPHY_FLAG_SUPPORTS_SCHED_SCAN;
-#ifdef CONFIG_PNO_SUPPORT
-	wiphy->max_sched_scan_ssids = MAX_PNO_LIST_COUNT;
-#endif
-#endif
-
-#if defined(CONFIG_PM) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,11,0))
-	wiphy->wowlan = wowlan_stub;
-#else
-	wiphy->wowlan = &wowlan_stub;
-#endif
-#endif
-
-#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3,2,0))
-	wiphy->flags |= WIPHY_FLAG_SUPPORTS_TDLS;
-#ifndef CONFIG_TDLS_DRIVER_SETUP
-	wiphy->flags |= WIPHY_FLAG_TDLS_EXTERNAL_SETUP;	//Driver handles key exchange
-	wiphy->flags |= NL80211_ATTR_HT_CAPABILITY;
-#endif //CONFIG_TDLS_DRIVER_SETUP
-#endif /* CONFIG_TDLS */
-
-	if (regsty->power_mgnt != PS_MODE_ACTIVE)
-		wiphy->flags |= WIPHY_FLAG_PS_ON_BY_DEFAULT;
-	else
-		wiphy->flags &= ~WIPHY_FLAG_PS_ON_BY_DEFAULT;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,2,0))
-	//wiphy->flags |= WIPHY_FLAG_SUPPORTS_FW_ROAM;
-#endif
-}
-
-#if defined(RTW_CONFIG_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
-#define SURVEY_INFO_TIME			SURVEY_INFO_CHANNEL_TIME
-#define SURVEY_INFO_TIME_BUSY		SURVEY_INFO_CHANNEL_TIME_BUSY
-#define SURVEY_INFO_TIME_EXT_BUSY	SURVEY_INFO_CHANNEL_TIME_EXT_BUSY
-#define SURVEY_INFO_TIME_RX			SURVEY_INFO_CHANNEL_TIME_RX
-#define SURVEY_INFO_TIME_TX			SURVEY_INFO_CHANNEL_TIME_TX
-#endif
-
-#ifdef CONFIG_FIND_BEST_CHANNEL
-static void rtw_cfg80211_set_survey_info_with_find_best_channel(struct wiphy *wiphy
-	, struct net_device *netdev, int idx, struct survey_info *info)
-{
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
-	RT_CHANNEL_INFO *ch_set = adapter->mlmeextpriv.channel_set;
-	u8 ch_num = adapter->mlmeextpriv.max_chan_nums;
-	u32 total_rx_cnt = 0;
-	int i;
-
-	s8 noise = -50;		/*channel noise in dBm. This and all following fields are optional */
-	u64 time = 100;		/*amount of time in ms the radio was turn on (on the channel)*/
-	u64 time_busy = 0;	/*amount of time the primary channel was sensed busy*/
-
-	info->filled  = SURVEY_INFO_NOISE_DBM
-		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
-		| SURVEY_INFO_TIME | SURVEY_INFO_TIME_BUSY
-		#endif
-		;
-
-	for (i = 0; i < ch_num; i++)
-		total_rx_cnt += ch_set[i].rx_count;
-
-	time_busy = ch_set[idx].rx_count * time / total_rx_cnt;
-	noise += ch_set[idx].rx_count * 50 / total_rx_cnt;
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
-	info->channel_time = time;
-	info->channel_time_busy = time_busy;
-	#else
-	info->time = time;
-	info->time_busy = time_busy;
-	#endif
-#endif
-	info->noise = noise;
-
-	/* reset if final channel is got */
-	if (idx == ch_num - 1) {
-		for (i = 0; i < ch_num; i++)
-			ch_set[i].rx_count = 0;
-	}
-}
-#endif /* CONFIG_FIND_BEST_CHANNEL */
-
-int rtw_hostapd_acs_dump_survey(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info)
-{
-	PADAPTER padapter = (_adapter *)rtw_netdev_priv(netdev);
-	RT_CHANNEL_INFO *pch_set = padapter->mlmeextpriv.channel_set;
-	u8 max_chan_nums = padapter->mlmeextpriv.max_chan_nums;
-	u32 freq = 0;
-	u8 ret = 0;
-	u16 channel = 0;
-
-	if (!netdev || !info) {
-		RTW_INFO("%s: invial parameters.\n", __func__);
-		return -EINVAL;
-	}
-
-	_rtw_memset(info, 0, sizeof(struct survey_info));
-	if (padapter->bup == _FALSE) {
-		RTW_INFO("%s: net device is down.\n", __func__);
-		return -EIO;
-	}
-
-	if (idx >= max_chan_nums)
-		return -ENOENT;
-
-	channel = pch_set[idx].ChannelNum;
-	freq = rtw_ch2freq(channel);
-	info->channel = ieee80211_get_channel(wiphy, freq);
-	/* RTW_INFO("%s: channel %d, freq %d\n", __func__, channel, freq); */
-
-	if (!info->channel)
-		return -EINVAL;
-
-	if (info->channel->flags == IEEE80211_CHAN_DISABLED)
-		return ret;
-
-#ifdef CONFIG_FIND_BEST_CHANNEL
-	rtw_cfg80211_set_survey_info_with_find_best_channel(wiphy, netdev, idx, info);
-#endif
-
-	return ret;
-}
-#endif /* defined(RTW_CONFIG_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33)) */
-
-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,
-#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
-	.set_rekey_data = cfg80211_rtw_set_rekey_data,
-#endif /*CONFIG_GTK_OL*/
-	.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_AP_MODE
-	.add_virtual_intf = cfg80211_rtw_add_virtual_intf,
-	.del_virtual_intf = cfg80211_rtw_del_virtual_intf,
-
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) && !defined(COMPAT_KERNEL_RELEASE)
-	.add_beacon = cfg80211_rtw_add_beacon,
-	.set_beacon = cfg80211_rtw_set_beacon,
-	.del_beacon = cfg80211_rtw_del_beacon,
-	#else
-	.start_ap = cfg80211_rtw_start_ap,
-	.change_beacon = cfg80211_rtw_change_beacon,
-	.stop_ap = cfg80211_rtw_stop_ap,
-	#endif
-	
-	.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,
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
-	.set_channel = cfg80211_rtw_set_channel,
-	#endif
-	//.auth = cfg80211_rtw_auth,
-	//.assoc = cfg80211_rtw_assoc,	
-#endif //CONFIG_AP_MODE
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
-	.set_monitor_channel = cfg80211_rtw_set_monitor_channel,
-#endif
-
-#ifdef CONFIG_P2P
-	.remain_on_channel = cfg80211_rtw_remain_on_channel,
-	.cancel_remain_on_channel = cfg80211_rtw_cancel_remain_on_channel,
-#endif
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)	 
-	.mgmt_tx = cfg80211_rtw_mgmt_tx,
-	.mgmt_frame_register = cfg80211_rtw_mgmt_frame_register,
-#elif  (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,34) && LINUX_VERSION_CODE<=KERNEL_VERSION(2,6,35))
-	.action = cfg80211_rtw_mgmt_tx,
-#endif
-
-#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3,2,0))
-	.tdls_mgmt = cfg80211_rtw_tdls_mgmt,
-	.tdls_oper = cfg80211_rtw_tdls_oper,
-#endif /* CONFIG_TDLS */
-
-#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3,0,0))
-	.sched_scan_start = cfg80211_rtw_sched_scan_start,
-	.sched_scan_stop = cfg80211_rtw_sched_scan_stop,
-#endif /* CONFIG_PNO_SUPPORT */
-
-#if defined(RTW_CONFIG_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
-	.dump_survey = rtw_hostapd_acs_dump_survey,
-#endif
-};
-
-struct wiphy *rtw_wiphy_alloc(_adapter *padapter, struct device *dev)
-{
-	struct wiphy *wiphy;
-	struct rtw_wiphy_data *wiphy_data;
-
-	/* wiphy */
-	wiphy = wiphy_new(&rtw_cfg80211_ops, sizeof(_adapter*));
-	if (!wiphy) {
-		DBG_8192C("Couldn't allocate wiphy device\n");
-		goto exit;
-	}
-	set_wiphy_dev(wiphy, dev);
-	*((_adapter**)wiphy_priv(wiphy)) = padapter;
-
-	rtw_cfg80211_preinit_wiphy(padapter, wiphy);
-
-	DBG_871X(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
-
-exit:
-	return wiphy;
-}
-
-void rtw_wiphy_free(struct wiphy *wiphy)
-{
-	if (!wiphy)
-		return;
-
-	DBG_871X(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
-
-	if (wiphy->bands[IEEE80211_BAND_2GHZ]) {
-		rtw_spt_band_free(wiphy->bands[IEEE80211_BAND_2GHZ]);
-		wiphy->bands[IEEE80211_BAND_2GHZ] = NULL;
-	}
-	if (wiphy->bands[IEEE80211_BAND_5GHZ]) {
-		rtw_spt_band_free(wiphy->bands[IEEE80211_BAND_5GHZ]);
-		wiphy->bands[IEEE80211_BAND_5GHZ] = NULL;
-	}
-
-	wiphy_free(wiphy);
-}
-
-int rtw_wiphy_register(struct wiphy *wiphy)
-{
-	DBG_871X(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
-	rtw_cfgvendor_attach(wiphy);
-#endif
-
-	return wiphy_register(wiphy);
-}
-
-void rtw_wiphy_unregister(struct wiphy *wiphy)
-{
-	DBG_871X(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
-
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
-	rtw_cfgvendor_detach(wiphy);
-#endif
-
-	return wiphy_unregister(wiphy);
-}
-
-int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy)
-{
-	int ret = 0;
-	struct net_device *pnetdev = padapter->pnetdev;
-	struct wireless_dev *wdev;
-	struct rtw_wdev_priv *pwdev_priv;
-	
-	DBG_8192C("%s(padapter=%p)\n", __func__, padapter);
-
-	/*  wdev */
-	wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
-	if (!wdev) {
-		DBG_8192C("Couldn't allocate wireless device\n");
-		ret = -ENOMEM;
-		goto exit;
-	}
-	wdev->wiphy = wiphy;
-	wdev->netdev = pnetdev;
-
-	wdev->iftype = NL80211_IFTYPE_STATION; // will be init in rtw_hal_init()
-	                                       // Must sync with _rtw_init_mlme_priv() 
-										   // pmlmepriv->fw_state = WIFI_STATION_STATE
-	//wdev->iftype = NL80211_IFTYPE_MONITOR; // for rtw_setopmode_cmd() in cfg80211_rtw_change_iface()
-	padapter->rtw_wdev = wdev;
-	pnetdev->ieee80211_ptr = wdev;
-
-	//init pwdev_priv
-	pwdev_priv = adapter_wdev_data(padapter);
-	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;
-	_rtw_spinlock_init(&pwdev_priv->scan_req_lock);
-		
-	pwdev_priv->p2p_enabled = _FALSE;
-	pwdev_priv->provdisc_req_issued = _FALSE;
-	rtw_wdev_invit_info_init(&pwdev_priv->invit_info);
-	rtw_wdev_nego_info_init(&pwdev_priv->nego_info);
-		
-	pwdev_priv->bandroid_scan = _FALSE;
-
-	if(padapter->registrypriv.power_mgnt != PS_MODE_ACTIVE)
-		pwdev_priv->power_mgmt = _TRUE;
-	else
-		pwdev_priv->power_mgmt = _FALSE;
-	
-#ifdef CONFIG_CONCURRENT_MODE
-	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);	
-	ATOMIC_SET(&pwdev_priv->ro_ch_to, 1);	
-#endif
-
-exit:
-	return ret;
-}
-
-void rtw_wdev_free(struct wireless_dev *wdev)
-{
-	DBG_8192C("%s(wdev=%p)\n", __func__, wdev);
-
-	if (!wdev)
-		return;
-
-	rtw_mfree((u8*)wdev, sizeof(struct wireless_dev));
-}
-
-void rtw_wdev_unregister(struct wireless_dev *wdev)
-{
-	struct net_device *ndev;
-	_adapter *adapter;
-	struct rtw_wdev_priv *pwdev_priv;
-
-	DBG_8192C("%s(wdev=%p)\n", __func__, wdev);
-
-	if (!wdev)
-		return;
-
-	if(!(ndev = wdev_to_ndev(wdev)))
-		return;
-
-	adapter = (_adapter *)rtw_netdev_priv(ndev);
-	pwdev_priv = adapter_wdev_data(adapter);
-
-	rtw_cfg80211_indicate_scan_done(adapter, _TRUE);
-
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
-	if (wdev->current_bss) {
-		u8 locally_generated = 1;
-		DBG_871X(FUNC_ADPT_FMT" clear current_bss by cfg80211_disconnected\n", FUNC_ADPT_ARG(adapter));
-		cfg80211_disconnected(adapter->pnetdev, 0, NULL, 0, locally_generated, GFP_ATOMIC);
-	}
-	#elif ((LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 2, 0))) || defined(COMPAT_KERNEL_RELEASE)	
-	if (wdev->current_bss) {
-		DBG_871X(FUNC_ADPT_FMT" clear current_bss by cfg80211_disconnected\n", FUNC_ADPT_ARG(adapter));
-		cfg80211_disconnected(adapter->pnetdev, 0, NULL, 0, GFP_ATOMIC);
-	}
-	#endif
-
-	if (pwdev_priv->pmon_ndev) {
-		DBG_8192C("%s, unregister monitor interface\n", __func__);
-		unregister_netdev(pwdev_priv->pmon_ndev);
-	}
-}
-
-int rtw_cfg80211_ndev_res_alloc(_adapter *adapter)
-{
-	int ret = _FAIL;
-
-#if !defined(RTW_SINGLE_WIPHY)
-	struct wiphy *wiphy;
-	struct device *dev = dvobj_to_dev(adapter_to_dvobj(adapter));
-
-	wiphy = rtw_wiphy_alloc(adapter, dev);
-	if (wiphy == NULL)
-		goto exit;
-
-	adapter->wiphy = wiphy;
-#endif
-
-	if (rtw_wdev_alloc(adapter, adapter_to_wiphy(adapter)) == 0)
-		ret = _SUCCESS;
-
-#if !defined(RTW_SINGLE_WIPHY)
-	if (ret != _SUCCESS) {
-		rtw_wiphy_free(wiphy);
-		adapter->wiphy = NULL;
-	}
-#endif
-
-exit:
-	return ret;
-}
-
-void rtw_cfg80211_ndev_res_free(_adapter *adapter)
-{
-	rtw_wdev_free(adapter->rtw_wdev);
-	adapter->rtw_wdev = NULL;
-#if !defined(RTW_SINGLE_WIPHY)
-	rtw_wiphy_free(adapter_to_wiphy(adapter));
-	adapter->wiphy = NULL;
-#endif
-}
-
-int rtw_cfg80211_ndev_res_register(_adapter *adapter)
-{
-	int ret = _FAIL;
-
-#if !defined(RTW_SINGLE_WIPHY)
-	if (rtw_wiphy_register(adapter_to_wiphy(adapter)) < 0) {
-		DBG_871X("%s rtw_wiphy_register fail for if%d\n", __func__, (adapter->iface_id+1));
-		goto exit;
-	}
-#endif
-
-	ret = _SUCCESS;
-
-exit:
-	return ret;
-}
-
-void rtw_cfg80211_ndev_res_unregister(_adapter *adapter)
-{
-	rtw_wdev_unregister(adapter->rtw_wdev);
-}
-
-int rtw_cfg80211_dev_res_alloc(struct dvobj_priv *dvobj)
-{
-	int ret = _FAIL;
-
-#if defined(RTW_SINGLE_WIPHY)
-	struct wiphy *wiphy;
-	struct device *dev = dvobj_to_dev(dvobj);
-
-	wiphy = rtw_wiphy_alloc(dvobj->padapters[IFACE_ID0], dev);
-	if (wiphy == NULL)
-		goto exit;
-
-	dvobj->wiphy = wiphy;
-#endif
-
-	ret = _SUCCESS;
-
-exit:
-	return ret;
-}
-
-void rtw_cfg80211_dev_res_free(struct dvobj_priv *dvobj)
-{
-#if defined(RTW_SINGLE_WIPHY)
-	rtw_wiphy_free(dvobj_to_wiphy(dvobj));
-	dvobj->wiphy = NULL;
-#endif
-}
-
-int rtw_cfg80211_dev_res_register(struct dvobj_priv *dvobj)
-{
-	int ret = _FAIL;
-
-#if defined(RTW_SINGLE_WIPHY)
-	if (rtw_wiphy_register(dvobj_to_wiphy(dvobj)) != 0)
-		goto exit;
-#endif
-
-	ret = _SUCCESS;
-
-exit:
-	return ret;
-}
-
-void rtw_cfg80211_dev_res_unregister(struct dvobj_priv *dvobj)
-{
-#if defined(RTW_SINGLE_WIPHY)
-	rtw_wiphy_unregister(dvobj_to_wiphy(dvobj));
-#endif
-}
-
-#endif /* CONFIG_IOCTL_CFG80211 */
-
+
+	if (bss) {
+		cfg80211_unlink_bss(wiphy, bss);
+		RTW_INFO("%s(): cfg80211_unlink %s!!\n", __func__, select_network.Ssid.Ssid);
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)
+		cfg80211_put_bss(padapter->rtw_wdev->wiphy, bss);
+#else
+		cfg80211_put_bss(bss);
+#endif
+	}
+	return;
+}
+
+/* if target wps scan ongoing, target_ssid is filled */
+int rtw_cfg80211_is_target_wps_scan(struct cfg80211_scan_request *scan_req, struct cfg80211_ssid *target_ssid)
+{
+	int ret = 0;
+
+	if (scan_req->n_ssids != 1
+		|| scan_req->ssids[0].ssid_len == 0
+		|| scan_req->n_channels != 1
+	)
+		goto exit;
+
+	/* under target WPS scan */
+	_rtw_memcpy(target_ssid, scan_req->ssids, sizeof(struct cfg80211_ssid));
+	ret = 1;
+
+exit:
+	return ret;
+}
+
+static void _rtw_cfg80211_surveydone_event_callback(_adapter *padapter, struct cfg80211_scan_request *scan_req)
+{
+	_irqL	irqL;
+	_list					*plist, *phead;
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	_queue				*queue	= &(pmlmepriv->scanned_queue);
+	struct	wlan_network	*pnetwork = NULL;
+	u32 cnt = 0;
+	u32 wait_for_surveydone;
+	sint wait_status;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct cfg80211_ssid target_ssid;
+	u8 target_wps_scan = 0;
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s\n", __func__);
+#endif
+
+	if (scan_req)
+		target_wps_scan = rtw_cfg80211_is_target_wps_scan(scan_req, &target_ssid);
+	else {
+		_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+		if (pwdev_priv->scan_request != NULL)
+			target_wps_scan = rtw_cfg80211_is_target_wps_scan(pwdev_priv->scan_request, &target_ssid);
+		_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+	}
+
+	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+
+	phead = get_list_head(queue);
+	plist = get_next(phead);
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
+
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+
+		/* report network only if the current channel set contains the channel to which this network belongs */
+		if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
+			&& rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
+			&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
+		) {
+			if (target_wps_scan)
+				rtw_cfg80211_clear_wps_sr_of_non_target_bss(padapter, pnetwork, &target_ssid);
+			rtw_cfg80211_inform_bss(padapter, pnetwork);
+		}
+#if 0
+		/* check ralink testbed RSN IE length */
+		{
+			if (_rtw_memcmp(pnetwork->network.Ssid.Ssid, "Ralink_11n_AP", 13)) {
+				uint ie_len = 0;
+				u8 *p = NULL;
+				p = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
+				RTW_INFO("ie_len=%d\n", ie_len);
+			}
+		}
+#endif
+		plist = get_next(plist);
+
+	}
+
+	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
+}
+
+inline void rtw_cfg80211_surveydone_event_callback(_adapter *padapter)
+{
+	_rtw_cfg80211_surveydone_event_callback(padapter, NULL);
+}
+
+static int rtw_cfg80211_set_probe_req_wpsp2pie(_adapter *padapter, char *buf, int len)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u8 *wps_ie;
+	u32	p2p_ielen = 0;
+	u8 *p2p_ie;
+	u32	wfd_ielen = 0;
+	u8 *wfd_ie;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+#endif
+
+	if (len > 0) {
+		wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen);
+		if (wps_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_req_wps_ielen=%d\n", wps_ielen);
+			#endif
+
+			if (pmlmepriv->wps_probe_req_ie) {
+				u32 free_len = pmlmepriv->wps_probe_req_ie_len;
+				pmlmepriv->wps_probe_req_ie_len = 0;
+				rtw_mfree(pmlmepriv->wps_probe_req_ie, free_len);
+				pmlmepriv->wps_probe_req_ie = NULL;
+			}
+
+			pmlmepriv->wps_probe_req_ie = rtw_malloc(wps_ielen);
+			if (pmlmepriv->wps_probe_req_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+			_rtw_memcpy(pmlmepriv->wps_probe_req_ie, wps_ie, wps_ielen);
+			pmlmepriv->wps_probe_req_ie_len = wps_ielen;
+		}
+
+		/* buf += wps_ielen; */
+		/* len -= wps_ielen; */
+
+		#ifdef CONFIG_P2P
+		p2p_ie = rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			struct wifidirect_info *wdinfo = &padapter->wdinfo;
+			u32 attr_contentlen = 0;
+			u8 listen_ch_attr[5];
+
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_req_p2p_ielen=%d\n", p2p_ielen);
+			#endif
+
+			if (pmlmepriv->p2p_probe_req_ie) {
+				u32 free_len = pmlmepriv->p2p_probe_req_ie_len;
+				pmlmepriv->p2p_probe_req_ie_len = 0;
+				rtw_mfree(pmlmepriv->p2p_probe_req_ie, free_len);
+				pmlmepriv->p2p_probe_req_ie = NULL;
+			}
+
+			pmlmepriv->p2p_probe_req_ie = rtw_malloc(p2p_ielen);
+			if (pmlmepriv->p2p_probe_req_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+			_rtw_memcpy(pmlmepriv->p2p_probe_req_ie, p2p_ie, p2p_ielen);
+			pmlmepriv->p2p_probe_req_ie_len = p2p_ielen;
+
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, (u8 *)listen_ch_attr, (uint *) &attr_contentlen)
+				&& attr_contentlen == 5) {
+				if (wdinfo->listen_channel !=  listen_ch_attr[4]) {
+					RTW_INFO(FUNC_ADPT_FMT" listen channel - country:%c%c%c, class:%u, ch:%u\n",
+						FUNC_ADPT_ARG(padapter), listen_ch_attr[0], listen_ch_attr[1], listen_ch_attr[2],
+						listen_ch_attr[3], listen_ch_attr[4]);
+					wdinfo->listen_channel = listen_ch_attr[4];
+				}
+			}
+		}
+		#endif /* CONFIG_P2P */
+
+		#ifdef CONFIG_WFD
+		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_req_wfd_ielen=%d\n", wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_PROBE_REQ_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				return -EINVAL;
+		}
+		#endif /* CONFIG_WFD */
+	}
+
+	return ret;
+
+}
+
+#ifdef CONFIG_CONCURRENT_MODE
+u8 rtw_cfg80211_scan_via_buddy(_adapter *padapter, struct cfg80211_scan_request *request)
+{
+	int i;
+	u8 ret = _FALSE;
+	_adapter *iface = NULL;
+	_irqL	irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		struct mlme_priv *buddy_mlmepriv;
+		struct rtw_wdev_priv *buddy_wdev_priv;
+
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+
+		if (iface == padapter)
+			continue;
+
+		if (rtw_is_adapter_up(iface) == _FALSE)
+			continue;
+
+		buddy_mlmepriv = &iface->mlmepriv;
+		if (!check_fwstate(buddy_mlmepriv, _FW_UNDER_SURVEY))
+			continue;
+
+		buddy_wdev_priv = adapter_wdev_data(iface);
+		_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+		_enter_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
+		if (buddy_wdev_priv->scan_request) {
+			pmlmepriv->scanning_via_buddy_intf = _TRUE;
+			_enter_critical_bh(&pmlmepriv->lock, &irqL);
+			set_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
+			_exit_critical_bh(&pmlmepriv->lock, &irqL);
+			pwdev_priv->scan_request = request;
+			ret = _TRUE;
+		}
+		_exit_critical_bh(&buddy_wdev_priv->scan_req_lock, &irqL);
+		_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+
+		if (ret == _TRUE)
+			goto exit;
+	}
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_indicate_scan_done_for_buddy(_adapter *padapter, bool bscan_aborted)
+{
+	int i;
+	u8 ret = 0;
+	_adapter *iface = NULL;
+	_irqL	irqL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mlme_priv *mlmepriv;
+	struct rtw_wdev_priv *wdev_priv;
+	bool indicate_buddy_scan;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+
+			if (iface == padapter)
+				continue;
+
+			mlmepriv = &(iface->mlmepriv);
+			wdev_priv = adapter_wdev_data(iface);
+
+			indicate_buddy_scan = _FALSE;
+			_enter_critical_bh(&wdev_priv->scan_req_lock, &irqL);
+			if (wdev_priv->scan_request && mlmepriv->scanning_via_buddy_intf == _TRUE) {
+				mlmepriv->scanning_via_buddy_intf = _FALSE;
+				clr_fwstate(mlmepriv, _FW_UNDER_SURVEY);
+				indicate_buddy_scan = _TRUE;
+			}
+			_exit_critical_bh(&wdev_priv->scan_req_lock, &irqL);
+
+			if (indicate_buddy_scan == _TRUE) {
+				rtw_cfg80211_surveydone_event_callback(iface);
+				rtw_indicate_scan_done(iface, bscan_aborted);
+			}
+
+		}
+	}
+}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+static int cfg80211_rtw_scan(struct wiphy *wiphy
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+	, struct net_device *ndev
+	#endif
+	, struct cfg80211_scan_request *request)
+{
+	int i, chan_num = 0;
+	u8 _status = _FALSE;
+	int ret = 0;
+	struct sitesurvey_parm parm;
+	_irqL	irqL;
+	u8 *wps_ie = NULL;
+	uint wps_ielen = 0;
+	u8 *p2p_ie = NULL;
+	uint p2p_ielen = 0;
+	u8 survey_times = 3;
+	u8 survey_times_for_one_ch = 6;
+	struct cfg80211_ssid *ssids = request->ssids;
+	int social_channel = 0, j = 0;
+	bool need_indicate_scan_done = _FALSE;
+	bool ps_denied = _FALSE;
+
+	_adapter *padapter;
+	struct wireless_dev *wdev;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct mlme_priv *pmlmepriv;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo;
+#endif /* CONFIG_P2P */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	wdev = request->wdev;
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		ret = -EINVAL;
+		goto exit;
+	}
+#else
+	if (ndev == NULL) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	pwdev_priv = adapter_wdev_data(padapter);
+	pmlmepriv = &padapter->mlmepriv;
+#ifdef CONFIG_P2P
+	pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
+
+	RTW_INFO(FUNC_ADPT_FMT"%s\n", FUNC_ADPT_ARG(padapter)
+		, wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : "");
+
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block Scan request\n");
+		ret = -EPERM;
+		goto exit;
+	}
+#endif
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
+		RTW_INFO(FUNC_ADPT_FMT" blocking scan for under rson scanning process\n", FUNC_ADPT_ARG(padapter));
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+#endif
+
+	if (adapter_wdev_data(padapter)->block_scan == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT" wdev_priv.block_scan is set\n", FUNC_ADPT_ARG(padapter));
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	ps_denied = _TRUE;
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
+#ifdef CONFIG_P2P
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (ssids->ssid != NULL
+			&& _rtw_memcmp(ssids->ssid, "DIRECT-", 7)
+			&& rtw_get_p2p_ie((u8 *)request->ie, request->ie_len, NULL, NULL)
+		) {
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+				rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
+			else {
+				rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+				#ifdef CONFIG_DEBUG_CFG80211
+				RTW_INFO("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
+				#endif
+			}
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
+
+			if (request->n_channels == 3 &&
+				request->channels[0]->hw_value == 1 &&
+				request->channels[1]->hw_value == 6 &&
+				request->channels[2]->hw_value == 11
+			)
+				social_channel = 1;
+		}
+	}
+#endif /*CONFIG_P2P*/
+
+	if (request->ie && request->ie_len > 0)
+		rtw_cfg80211_set_probe_req_wpsp2pie(padapter, (u8 *)request->ie, request->ie_len);
+
+	if (rtw_is_scan_deny(padapter)) {
+		RTW_INFO(FUNC_ADPT_FMT	": scan deny\n", FUNC_ADPT_ARG(padapter));
+#if CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY
+		ret = -EBUSY;
+		goto exit;
+#else
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+#endif
+	}
+
+	/* check fw state*/
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+
+#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO(FUNC_ADPT_FMT" under WIFI_AP_STATE\n", FUNC_ADPT_ARG(padapter));
+#endif
+
+		if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS | _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
+			RTW_INFO("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
+
+			if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
+				RTW_INFO("AP mode process WPS\n");
+
+			need_indicate_scan_done = _TRUE;
+			goto check_need_indicate_scan_done;
+		}
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+		RTW_INFO("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("%s, fwstate=0x%x\n", __func__, pmlmepriv->fw_state);
+		ret = -EBUSY;
+		goto check_need_indicate_scan_done;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
+		RTW_INFO("%s exit due to buddy_intf's mlme state under linking or wps\n", __func__);
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+
+	} else if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_SURVEY)) {
+		bool scan_via_buddy = rtw_cfg80211_scan_via_buddy(padapter, request);
+
+		if (scan_via_buddy == _FALSE)
+			need_indicate_scan_done = _TRUE;
+
+		goto check_need_indicate_scan_done;
+	}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+	/* busy traffic check*/
+	if (rtw_mi_busy_traffic_check(padapter, _TRUE)) {
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
+		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
+
+		if (social_channel == 0)
+			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
+		else
+			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_SOCIAL_LAST);
+	}
+#endif /* CONFIG_P2P */
+
+	rtw_init_sitesurvey_parm(padapter, &parm);
+
+	/* parsing request ssids, n_ssids */
+	for (i = 0; i < request->n_ssids && i < RTW_SSID_SCAN_AMOUNT; i++) {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("ssid=%s, len=%d\n", ssids[i].ssid, ssids[i].ssid_len);
+		#endif
+		_rtw_memcpy(&parm.ssid[i].Ssid, ssids[i].ssid, ssids[i].ssid_len);
+		parm.ssid[i].SsidLength = ssids[i].ssid_len;
+	}
+	parm.ssid_num = i;
+
+	/* parsing channels, n_channels */
+	for (i = 0; i < request->n_channels && i < RTW_CHANNEL_SCAN_AMOUNT; i++) {
+		#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO(FUNC_ADPT_FMT CHAN_FMT"\n", FUNC_ADPT_ARG(padapter), CHAN_ARG(request->channels[i]));
+		#endif
+		parm.ch[i].hw_value = request->channels[i]->hw_value;
+		parm.ch[i].flags = request->channels[i]->flags;
+	}
+	parm.ch_num = i;
+
+	if (request->n_channels == 1) {
+		for (i = 1; i < survey_times_for_one_ch; i++)
+			_rtw_memcpy(&parm.ch[i], &parm.ch[0], sizeof(struct rtw_ieee80211_channel));
+		parm.ch_num = survey_times_for_one_ch;
+	} else if (request->n_channels <= 4) {
+		for (j = request->n_channels - 1; j >= 0; j--)
+			for (i = 0; i < survey_times; i++)
+				_rtw_memcpy(&parm.ch[j * survey_times + i], &parm.ch[j], sizeof(struct rtw_ieee80211_channel));
+		parm.ch_num = survey_times * request->n_channels;
+	}
+
+	_enter_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+	_enter_critical_bh(&pmlmepriv->lock, &irqL);
+	_status = rtw_sitesurvey_cmd(padapter, &parm);
+	if (_status == _SUCCESS)
+		pwdev_priv->scan_request = request;
+	else
+		ret = -1;
+	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+	_exit_critical_bh(&pwdev_priv->scan_req_lock, &irqL);
+
+check_need_indicate_scan_done:
+	if (_TRUE == need_indicate_scan_done) {
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+		struct cfg80211_scan_info info;
+
+		memset(&info, 0, sizeof(info));
+		info.aborted = 0;
+#endif
+
+		_rtw_cfg80211_surveydone_event_callback(padapter, request);
+#if (KERNEL_VERSION(4, 7, 0) <= LINUX_VERSION_CODE)
+		cfg80211_scan_done(request, &info);
+#else
+		cfg80211_scan_done(request, 0);
+#endif
+	}
+
+cancel_ps_deny:
+	if (ps_denied == _TRUE)
+		rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
+
+exit:
+	return ret;
+
+}
+
+static int cfg80211_rtw_set_wiphy_params(struct wiphy *wiphy, u32 changed)
+{
+#if 0
+	struct iwm_priv *iwm = wiphy_to_iwm(wiphy);
+
+	if (changed & WIPHY_PARAM_RTS_THRESHOLD &&
+	    (iwm->conf.rts_threshold != wiphy->rts_threshold)) {
+		int ret;
+
+		iwm->conf.rts_threshold = wiphy->rts_threshold;
+
+		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_CFG_FIX,
+				CFG_RTS_THRESHOLD,
+				iwm->conf.rts_threshold);
+		if (ret < 0)
+			return ret;
+	}
+
+	if (changed & WIPHY_PARAM_FRAG_THRESHOLD &&
+	    (iwm->conf.frag_threshold != wiphy->frag_threshold)) {
+		int ret;
+
+		iwm->conf.frag_threshold = wiphy->frag_threshold;
+
+		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_FA_CFG_FIX,
+				CFG_FRAG_THRESHOLD,
+				iwm->conf.frag_threshold);
+		if (ret < 0)
+			return ret;
+	}
+#endif
+	RTW_INFO("%s\n", __func__);
+	return 0;
+}
+
+
+
+static int rtw_cfg80211_set_wpa_version(struct security_priv *psecuritypriv, u32 wpa_version)
+{
+	RTW_INFO("%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 0
+	if (wpa_version & NL80211_WPA_VERSION_2)
+		psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK;
+#endif
+
+	#ifdef CONFIG_WAPI_SUPPORT
+	if (wpa_version & NL80211_WAPI_VERSION_1)
+		psecuritypriv->ndisauthtype = Ndis802_11AuthModeWAPI;
+	#endif
+
+	return 0;
+
+}
+
+static int rtw_cfg80211_set_auth_type(struct security_priv *psecuritypriv,
+		enum nl80211_auth_type sme_auth_type)
+{
+	RTW_INFO("%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;
+
+#ifdef CONFIG_WAPI_SUPPORT
+		if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWAPI)
+			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+#endif
+
+		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;
+
+	RTW_INFO("%s, ucast=%d, cipher=0x%x\n", __func__, ucast, cipher);
+
+
+	if (!cipher) {
+		*profile_cipher = _NO_PRIVACY_;
+		psecuritypriv->ndisencryptstatus = ndisencryptstatus;
+		return 0;
+	}
+
+	switch (cipher) {
+	case IW_AUTH_CIPHER_NONE:
+		*profile_cipher = _NO_PRIVACY_;
+		ndisencryptstatus = Ndis802_11EncryptionDisabled;
+#ifdef CONFIG_WAPI_SUPPORT
+		if (psecuritypriv->dot11PrivacyAlgrthm == _SMS4_)
+			*profile_cipher = _SMS4_;
+#endif
+		break;
+	case WLAN_CIPHER_SUITE_WEP40:
+		*profile_cipher = _WEP40_;
+		ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WLAN_CIPHER_SUITE_WEP104:
+		*profile_cipher = _WEP104_;
+		ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WLAN_CIPHER_SUITE_TKIP:
+		*profile_cipher = _TKIP_;
+		ndisencryptstatus = Ndis802_11Encryption2Enabled;
+		break;
+	case WLAN_CIPHER_SUITE_CCMP:
+		*profile_cipher = _AES_;
+		ndisencryptstatus = Ndis802_11Encryption3Enabled;
+		break;
+#ifdef CONFIG_WAPI_SUPPORT
+	case WLAN_CIPHER_SUITE_SMS4:
+		*profile_cipher = _SMS4_;
+		ndisencryptstatus = Ndis802_11_EncrypteionWAPI;
+		break;
+#endif
+	default:
+		RTW_INFO("Unsupported cipher: 0x%x\n", cipher);
+		return -ENOTSUPP;
+	}
+
+	if (ucast) {
+		psecuritypriv->ndisencryptstatus = ndisencryptstatus;
+
+		/* if(psecuritypriv->dot11PrivacyAlgrthm >= _AES_) */
+		/*	psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK; */
+	}
+
+	return 0;
+}
+
+static int rtw_cfg80211_set_key_mgt(struct security_priv *psecuritypriv, u32 key_mgt)
+{
+	RTW_INFO("%s, key_mgt=0x%x\n", __func__, key_mgt);
+
+	if (key_mgt == WLAN_AKM_SUITE_8021X) {
+		/* *auth_type = UMAC_AUTH_TYPE_8021X; */
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 1;
+	} else if (key_mgt == WLAN_AKM_SUITE_PSK) {
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 2;
+	}
+#ifdef CONFIG_WAPI_SUPPORT
+	else if (key_mgt == WLAN_AKM_SUITE_WAPI_PSK)
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+	else if (key_mgt == WLAN_AKM_SUITE_WAPI_CERT)
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
+#endif
+#ifdef CONFIG_RTW_80211R
+	else if (key_mgt == WLAN_AKM_SUITE_FT_8021X) {
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 3;
+	} else if (key_mgt == WLAN_AKM_SUITE_FT_PSK) {
+		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+		psecuritypriv->rsn_akm_suite_type = 4;
+	}
+#endif
+	else {
+		RTW_INFO("Invalid key mgt: 0x%x\n", key_mgt);
+		/* return -EINVAL; */
+	}
+
+	return 0;
+}
+
+static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)
+{
+	u8 *buf = NULL, *pos = NULL;
+	u32 left;
+	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
+	int ret = 0;
+	int wpa_ielen = 0;
+	int wpa2_ielen = 0;
+	u8 *pwpa, *pwpa2;
+	u8 null_addr[] = {0, 0, 0, 0, 0, 0};
+
+	if (pie == NULL || !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;
+	}
+
+	buf = rtw_zmalloc(ielen);
+	if (buf == NULL) {
+		ret =  -ENOMEM;
+		goto exit;
+	}
+
+	_rtw_memcpy(buf, pie , ielen);
+
+	RTW_INFO("set wpa_ie(length:%zu):\n", ielen);
+	RTW_INFO_DUMP(NULL, buf, ielen);
+
+	pos = buf;
+	if (ielen < RSN_HEADER_LEN) {
+		ret  = -1;
+		goto exit;
+	}
+
+	pwpa = rtw_get_wpa_ie(buf, &wpa_ielen, ielen);
+	if (pwpa && wpa_ielen > 0) {
+		if (rtw_parse_wpa_ie(pwpa, wpa_ielen + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &pwpa[0], wpa_ielen + 2);
+
+			RTW_INFO("got wpa_ie, wpa_ielen:%u\n", wpa_ielen);
+		}
+	}
+
+	pwpa2 = rtw_get_wpa2_ie(buf, &wpa2_ielen, ielen);
+	if (pwpa2 && wpa2_ielen > 0) {
+		if (rtw_parse_wpa2_ie(pwpa2, wpa2_ielen + 2, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &pwpa2[0], wpa2_ielen + 2);
+
+			RTW_INFO("got wpa2_ie, wpa2_ielen:%u\n", wpa2_ielen);
+		}
+	}
+
+	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 = _NO_PRIVACY_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+		break;
+	case WPA_CIPHER_WEP40:
+		padapter->securitypriv.dot118021XGrpPrivacy = _WEP40_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WPA_CIPHER_TKIP:
+		padapter->securitypriv.dot118021XGrpPrivacy = _TKIP_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+		break;
+	case WPA_CIPHER_CCMP:
+		padapter->securitypriv.dot118021XGrpPrivacy = _AES_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+		break;
+	case WPA_CIPHER_WEP104:
+		padapter->securitypriv.dot118021XGrpPrivacy = _WEP104_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	}
+
+	switch (pairwise_cipher) {
+	case WPA_CIPHER_NONE:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+		break;
+	case WPA_CIPHER_WEP40:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	case WPA_CIPHER_TKIP:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _TKIP_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+		break;
+	case WPA_CIPHER_CCMP:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _AES_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+		break;
+	case WPA_CIPHER_WEP104:
+		padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		break;
+	}
+
+	if (mfp_opt == MFP_INVALID) {
+		RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+		ret = -EINVAL;
+		goto exit;
+	}
+	padapter->securitypriv.mfp_opt = mfp_opt;
+
+	{/* handle wps_ie */
+		uint wps_ielen;
+		u8 *wps_ie;
+
+		wps_ie = rtw_get_wps_ie(buf, ielen, NULL, &wps_ielen);
+		if (wps_ie && wps_ielen > 0) {
+			RTW_INFO("got wps_ie, wps_ielen:%u\n", wps_ielen);
+			padapter->securitypriv.wps_ie_len = wps_ielen < MAX_WPS_IE_LEN ? wps_ielen : MAX_WPS_IE_LEN;
+			_rtw_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);
+	}
+
+	#ifdef CONFIG_P2P
+	{/* check p2p_ie for assoc req; */
+		uint p2p_ielen = 0;
+		u8 *p2p_ie;
+		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+		p2p_ie = rtw_get_p2p_ie(buf, ielen, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s p2p_assoc_req_ielen=%d\n", __FUNCTION__, p2p_ielen);
+			#endif
+
+			if (pmlmepriv->p2p_assoc_req_ie) {
+				u32 free_len = pmlmepriv->p2p_assoc_req_ie_len;
+				pmlmepriv->p2p_assoc_req_ie_len = 0;
+				rtw_mfree(pmlmepriv->p2p_assoc_req_ie, free_len);
+				pmlmepriv->p2p_assoc_req_ie = NULL;
+			}
+
+			pmlmepriv->p2p_assoc_req_ie = rtw_malloc(p2p_ielen);
+			if (pmlmepriv->p2p_assoc_req_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				goto exit;
+			}
+			_rtw_memcpy(pmlmepriv->p2p_assoc_req_ie, p2p_ie, p2p_ielen);
+			pmlmepriv->p2p_assoc_req_ie_len = p2p_ielen;
+		}
+	}
+	#endif /* CONFIG_P2P */
+
+	#ifdef CONFIG_WFD
+	{
+		uint wfd_ielen = 0;
+		u8 *wfd_ie;
+		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+		wfd_ie = rtw_get_wfd_ie(buf, ielen, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s wfd_assoc_req_ielen=%d\n", __FUNCTION__, wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_ASSOC_REQ_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				goto exit;
+		}
+	}
+	#endif /* CONFIG_WFD */
+
+	/* TKIP and AES disallow multicast packets until installing group key */
+	if (padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_
+		|| padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_WTMIC_
+		|| padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)
+		/* WPS open need to enable multicast */
+		/* || check_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS) == _TRUE) */
+		rtw_hal_set_hwreg(padapter, HW_VAR_OFF_RCR_AM, null_addr);
+
+
+exit:
+	if (buf)
+		rtw_mfree(buf, ielen);
+	if (ret)
+		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
+
+	return ret;
+}
+
+static int cfg80211_rtw_join_ibss(struct wiphy *wiphy, struct net_device *ndev,
+				  struct cfg80211_ibss_params *params)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	NDIS_802_11_SSID ndis_ssid;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *pch_def;
+#endif
+	struct ieee80211_channel *pch;
+	int ret = 0;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	pch_def = (struct cfg80211_chan_def *)(&params->chandef);
+	pch = (struct ieee80211_channel *) pch_def->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 31))
+	pch = (struct ieee80211_channel *)(params->channel);
+#endif
+
+	if (!params->ssid || !params->ssid_len) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (params->ssid_len > IW_ESSID_MAX_SIZE) {
+		ret = -E2BIG;
+		goto exit;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_JOIN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EPERM;
+		goto cancel_ps_deny;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING)) {
+		RTW_INFO("%s, but buddy_intf is under linking\n", __FUNCTION__);
+		ret = -EINVAL;
+		goto cancel_ps_deny;
+	}
+	rtw_mi_buddy_scan_abort(padapter, _TRUE); /* OR rtw_mi_scan_abort(padapter, _TRUE);*/
+#endif /*CONFIG_CONCURRENT_MODE*/
+
+
+	_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));
+	ndis_ssid.SsidLength = params->ssid_len;
+	_rtw_memcpy(ndis_ssid.Ssid, (u8 *)params->ssid, params->ssid_len);
+
+	/* RTW_INFO("ssid=%s, len=%zu\n", ndis_ssid.Ssid, params->ssid_len); */
+
+	psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
+	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+	psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
+
+	ret = rtw_cfg80211_set_auth_type(psecuritypriv, NL80211_AUTHTYPE_OPEN_SYSTEM);
+	rtw_set_802_11_authentication_mode(padapter, psecuritypriv->ndisauthtype);
+
+	RTW_INFO("%s: center_freq = %d\n", __func__, pch->center_freq);
+	pmlmeext->cur_channel = rtw_freq2ch(pch->center_freq);
+
+	if (rtw_set_802_11_ssid(padapter, &ndis_ssid) == _FALSE) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_leave_ibss(struct wiphy *wiphy, struct net_device *ndev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
+	enum nl80211_iftype old_type;
+	int ret = 0;
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 1);
+#endif
+
+	old_type = rtw_wdev->iftype;
+
+	rtw_set_to_roam(padapter, 0);
+
+	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
+		rtw_scan_abort(padapter);
+		LeaveAllPowerSaveMode(padapter);
+
+		rtw_wdev->iftype = NL80211_IFTYPE_STATION;
+
+		if (rtw_set_802_11_infrastructure_mode(padapter, Ndis802_11Infrastructure) == _FALSE) {
+			rtw_wdev->iftype = old_type;
+			ret = -EPERM;
+			goto leave_ibss;
+		}
+		rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+	}
+
+leave_ibss:
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 0);
+#endif
+
+	return 0;
+}
+
+bool rtw_cfg80211_is_connect_requested(_adapter *adapter)
+{
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	_irqL irqL;
+	bool requested;
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+	requested = pwdev_priv->connect_req ? 1 : 0;
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	return requested;
+}
+
+static int _rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+
+
+	/* if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)) */
+	{
+		rtw_scan_abort(padapter);
+		rtw_join_abort_timeout(padapter, 300);
+		LeaveAllPowerSaveMode(padapter);
+		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
+#ifdef CONFIG_RTW_REPEATER_SON
+		rtw_rson_do_disconnect(padapter);
+#endif
+		RTW_INFO("%s...call rtw_indicate_disconnect\n", __func__);
+
+		rtw_free_assoc_resources_cmd(padapter, _TRUE);
+
+		/* indicate locally_generated = 0 when suspend */
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
+		rtw_indicate_disconnect(padapter, 0, wiphy->dev.power.is_prepared ? _FALSE : _TRUE);
+		#else
+		/*
+		* for kernel < 4.2, DISCONNECT event is hardcoded with
+		* NL80211_ATTR_DISCONNECTED_BY_AP=1 in NL80211 layer
+		* no need to judge if under suspend
+		*/
+		rtw_indicate_disconnect(padapter, 0, _TRUE);
+		#endif
+
+		rtw_pwr_wakeup(padapter);
+	}
+	return 0;
+}
+
+static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,
+				struct cfg80211_connect_params *sme)
+{
+	int ret = 0;
+	struct wlan_network *pnetwork = NULL;
+	NDIS_802_11_AUTHENTICATION_MODE authmode;
+	NDIS_802_11_SSID ndis_ssid;
+	u8 *dst_ssid, *src_ssid;
+	u8 *dst_bssid, *src_bssid;
+	/* u8 matched_by_bssid=_FALSE; */
+	/* u8 matched_by_ssid=_FALSE; */
+	u8 matched = _FALSE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	_queue *queue = &pmlmepriv->scanned_queue;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	_irqL irqL;
+
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT)
+	rtw_wdev_set_not_indic_disco(pwdev_priv, 1);
+#endif
+
+	RTW_INFO("=>"FUNC_NDEV_FMT" - Start to Connection\n", FUNC_NDEV_ARG(ndev));
+	RTW_INFO("privacy=%d, key=%p, key_len=%d, key_idx=%d, auth_type=%d\n",
+		sme->privacy, sme->key, sme->key_len, sme->key_idx, sme->auth_type);
+
+	if (pwdev_priv->block == _TRUE) {
+		ret = -EBUSY;
+		RTW_INFO("%s wdev_priv.block is set\n", __FUNCTION__);
+		goto exit;
+	}
+
+       if (check_fwstate(pmlmepriv, _FW_LINKED | _FW_UNDER_LINKING) == _TRUE) {
+
+		_rtw_disconnect(wiphy, ndev);
+		RTW_INFO("%s disconnect before connecting! fw_state=0x%x\n",
+			__FUNCTION__, pmlmepriv->fw_state);
+	}
+
+#ifdef CONFIG_PLATFORM_MSTAR_SCAN_BEFORE_CONNECT
+	printk("MStar Android!\n");
+	if (pwdev_priv->bandroid_scan == _FALSE) {
+#ifdef CONFIG_P2P
+		struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+#endif /* CONFIG_P2P */
+		{
+			ret = -EBUSY;
+			printk("Android hasn't attached yet!\n");
+			goto exit;
+		}
+	}
+#endif
+
+	if (!sme->ssid || !sme->ssid_len) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	if (sme->ssid_len > IW_ESSID_MAX_SIZE) {
+		ret = -E2BIG;
+		goto exit;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_JOIN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EPERM;
+		goto cancel_ps_deny;
+	}
+
+	rtw_mi_scan_abort(padapter, _TRUE);
+
+	rtw_join_abort_timeout(padapter, 300);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING)) {
+		ret = -EINVAL;
+		goto cancel_ps_deny;
+	}
+#endif
+
+	_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));
+	ndis_ssid.SsidLength = sme->ssid_len;
+	_rtw_memcpy(ndis_ssid.Ssid, (u8 *)sme->ssid, sme->ssid_len);
+
+	RTW_INFO("ssid=%s, len=%zu\n", ndis_ssid.Ssid, sme->ssid_len);
+
+
+	if (sme->bssid)
+		RTW_INFO("bssid="MAC_FMT"\n", MAC_ARG(sme->bssid));
+
+
+	psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
+	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
+	psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
+
+#ifdef CONFIG_WAPI_SUPPORT
+	padapter->wapiInfo.bWapiEnable = false;
+#endif
+
+	ret = rtw_cfg80211_set_wpa_version(psecuritypriv, sme->crypto.wpa_versions);
+	if (ret < 0)
+		goto cancel_ps_deny;
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (sme->crypto.wpa_versions & NL80211_WAPI_VERSION_1) {
+		padapter->wapiInfo.bWapiEnable = true;
+		padapter->wapiInfo.extra_prefix_len = WAPI_EXT_LEN;
+		padapter->wapiInfo.extra_postfix_len = SMS4_MIC_LEN;
+	}
+#endif
+
+	ret = rtw_cfg80211_set_auth_type(psecuritypriv, sme->auth_type);
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_WAPI)
+		padapter->mlmeextpriv.mlmext_info.auth_algo = psecuritypriv->dot11AuthAlgrthm;
+#endif
+
+
+	if (ret < 0)
+		goto cancel_ps_deny;
+
+	RTW_INFO("%s, ie_len=%zu\n", __func__, sme->ie_len);
+
+	ret = rtw_cfg80211_set_wpa_ie(padapter, (u8 *)sme->ie, sme->ie_len);
+	if (ret < 0)
+		goto cancel_ps_deny;
+
+	if (sme->crypto.n_ciphers_pairwise) {
+		ret = rtw_cfg80211_set_cipher(psecuritypriv, sme->crypto.ciphers_pairwise[0], _TRUE);
+		if (ret < 0)
+			goto cancel_ps_deny;
+	}
+
+	/* For WEP Shared auth */
+	if (sme->key_len > 0 && sme->key) {
+		u32 wep_key_idx, wep_key_len, wep_total_len;
+		NDIS_802_11_WEP	*pwep = NULL;
+		RTW_INFO("%s(): Shared/Auto WEP\n", __FUNCTION__);
+
+		wep_key_idx = sme->key_idx;
+		wep_key_len = sme->key_len;
+
+		if (sme->key_idx > WEP_KEYS) {
+			ret = -EINVAL;
+			goto cancel_ps_deny;
+		}
+
+		if (wep_key_len > 0) {
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
+			wep_total_len = wep_key_len + FIELD_OFFSET(NDIS_802_11_WEP, KeyMaterial);
+			pwep = (NDIS_802_11_WEP *) rtw_malloc(wep_total_len);
+			if (pwep == NULL) {
+				RTW_INFO(" wpa_set_encryption: pwep allocate fail !!!\n");
+				ret = -ENOMEM;
+				goto cancel_ps_deny;
+			}
+
+			_rtw_memset(pwep, 0, wep_total_len);
+
+			pwep->KeyLength = wep_key_len;
+			pwep->Length = wep_total_len;
+
+			if (wep_key_len == 13) {
+				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+				padapter->securitypriv.dot118021XGrpPrivacy = _WEP104_;
+			}
+		} else {
+			ret = -EINVAL;
+			goto cancel_ps_deny;
+		}
+
+		pwep->KeyIndex = wep_key_idx;
+		pwep->KeyIndex |= 0x80000000;
+
+		_rtw_memcpy(pwep->KeyMaterial, (void *)sme->key, pwep->KeyLength);
+
+		if (rtw_set_802_11_add_wep(padapter, pwep) == (u8)_FAIL)
+			ret = -EOPNOTSUPP ;
+
+		if (pwep)
+			rtw_mfree((u8 *)pwep, wep_total_len);
+
+		if (ret < 0)
+			goto cancel_ps_deny;
+	}
+
+	ret = rtw_cfg80211_set_cipher(psecuritypriv, sme->crypto.cipher_group, _FALSE);
+	if (ret < 0)
+		return ret;
+
+	if (sme->crypto.n_akm_suites) {
+		ret = rtw_cfg80211_set_key_mgt(psecuritypriv, sme->crypto.akm_suites[0]);
+		if (ret < 0)
+			goto cancel_ps_deny;
+	}
+#ifdef CONFIG_8011R
+	else {
+		/*It could be a connection without RSN IEs*/
+		psecuritypriv->rsn_akm_suite_type = 0;
+	}
+#endif
+
+#ifdef CONFIG_WAPI_SUPPORT
+	if (sme->crypto.akm_suites[0] == WLAN_AKM_SUITE_WAPI_PSK)
+		padapter->wapiInfo.bWapiPSK = true;
+	else if (sme->crypto.akm_suites[0] == WLAN_AKM_SUITE_WAPI_CERT)
+		padapter->wapiInfo.bWapiPSK = false;
+#endif
+
+	authmode = psecuritypriv->ndisauthtype;
+	rtw_set_802_11_authentication_mode(padapter, authmode);
+
+	/* rtw_set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus); */
+
+	if (rtw_set_802_11_connect(padapter, (u8 *)sme->bssid, &ndis_ssid) == _FALSE) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	if (pwdev_priv->connect_req) {
+		rtw_wdev_free_connect_req(pwdev_priv);
+		RTW_INFO(FUNC_NDEV_FMT" free existing connect_req\n", FUNC_NDEV_ARG(ndev));
+	}
+
+	pwdev_priv->connect_req = (struct cfg80211_connect_params *)rtw_malloc(sizeof(*pwdev_priv->connect_req));
+	if (pwdev_priv->connect_req)
+		_rtw_memcpy(pwdev_priv->connect_req, sme, sizeof(*pwdev_priv->connect_req));
+	else
+		RTW_WARN(FUNC_NDEV_FMT" alloc connect_req fail\n", FUNC_NDEV_ARG(ndev));
+
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	RTW_INFO("set ssid:dot11AuthAlgrthm=%d, dot11PrivacyAlgrthm=%d, dot118021XGrpPrivacy=%d\n", psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm,
+		psecuritypriv->dot118021XGrpPrivacy);
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
+
+exit:
+	RTW_INFO("<=%s, ret %d\n", __FUNCTION__, ret);
+
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT)
+	rtw_wdev_set_not_indic_disco(pwdev_priv, 0);
+#endif
+
+	return ret;
+}
+
+static int cfg80211_rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev,
+				   u16 reason_code)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT" - Start to Disconnect\n", FUNC_NDEV_ARG(ndev));
+
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (!wiphy->dev.power.is_prepared)
+	#endif
+		rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 1);
+#endif
+
+	rtw_set_to_roam(padapter, 0);
+
+	/* if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)) */
+	{
+		_rtw_disconnect(wiphy, ndev);
+	}
+
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 0);
+#endif
+
+	RTW_INFO(FUNC_NDEV_FMT" return 0\n", FUNC_NDEV_ARG(ndev));
+	return 0;
+}
+
+static int cfg80211_rtw_set_txpower(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct wireless_dev *wdev,
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)) || defined(COMPAT_KERNEL_RELEASE)
+	enum nl80211_tx_power_setting type, int mbm)
+#else
+	enum tx_power_setting type, int dbm)
+#endif
+{
+#if 0
+	struct iwm_priv *iwm = wiphy_to_iwm(wiphy);
+	int ret;
+
+	switch (type) {
+	case NL80211_TX_POWER_AUTOMATIC:
+		return 0;
+	case NL80211_TX_POWER_FIXED:
+		if (mbm < 0 || (mbm % 100))
+			return -EOPNOTSUPP;
+
+		if (!test_bit(IWM_STATUS_READY, &iwm->status))
+			return 0;
+
+		ret = iwm_umac_set_config_fix(iwm, UMAC_PARAM_TBL_CFG_FIX,
+					      CFG_TX_PWR_LIMIT_USR,
+					      MBM_TO_DBM(mbm) * 2);
+		if (ret < 0)
+			return ret;
+
+		return iwm_tx_power_trigger(iwm);
+	default:
+		IWM_ERR(iwm, "Unsupported power type: %d\n", type);
+		return -EOPNOTSUPP;
+	}
+#endif
+	RTW_INFO("%s\n", __func__);
+	return 0;
+}
+
+static int cfg80211_rtw_get_txpower(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct wireless_dev *wdev,
+#endif
+	int *dbm)
+{
+	RTW_INFO("%s\n", __func__);
+
+	*dbm = (12);
+
+	return 0;
+}
+
+inline bool rtw_cfg80211_pwr_mgmt(_adapter *adapter)
+{
+	struct rtw_wdev_priv *rtw_wdev_priv = adapter_wdev_data(adapter);
+	return rtw_wdev_priv->power_mgmt;
+}
+
+static int cfg80211_rtw_set_power_mgmt(struct wiphy *wiphy,
+				       struct net_device *ndev,
+				       bool enabled, int timeout)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct rtw_wdev_priv *rtw_wdev_priv = adapter_wdev_data(padapter);
+
+	RTW_INFO(FUNC_NDEV_FMT" enabled:%u, timeout:%d\n", FUNC_NDEV_ARG(ndev),
+		enabled, timeout);
+
+	rtw_wdev_priv->power_mgmt = enabled;
+
+#ifdef CONFIG_LPS
+	if (!enabled)
+		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE_CFG80211_PWRMGMT, 1);
+#endif
+
+	return 0;
+}
+
+static int cfg80211_rtw_set_pmksa(struct wiphy *wiphy,
+				  struct net_device *ndev,
+				  struct cfg80211_pmksa *pmksa)
+{
+	u8	index, blInserted = _FALSE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *mlme = &padapter->mlmepriv;
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+	u8	strZeroMacAddress[ETH_ALEN] = { 0x00 };
+
+	RTW_INFO(FUNC_NDEV_FMT" "MAC_FMT" "KEY_FMT"\n", FUNC_NDEV_ARG(ndev)
+		, MAC_ARG(pmksa->bssid), KEY_ARG(pmksa->pmkid));
+
+	if (_rtw_memcmp((u8 *)pmksa->bssid, strZeroMacAddress, ETH_ALEN) == _TRUE)
+		return -EINVAL;
+
+	if (check_fwstate(mlme, _FW_LINKED) == _FALSE) {
+		RTW_INFO(FUNC_NDEV_FMT" not set pmksa cause not in linked state\n", FUNC_NDEV_ARG(ndev));
+		return -EINVAL;
+	}
+
+	blInserted = _FALSE;
+
+	/* overwrite PMKID */
+	for (index = 0 ; index < NUM_PMKID_CACHE; index++) {
+		if (_rtw_memcmp(psecuritypriv->PMKIDList[index].Bssid, (u8 *)pmksa->bssid, ETH_ALEN) == _TRUE) {
+			/* BSSID is matched, the same AP => rewrite with new PMKID. */
+			RTW_INFO(FUNC_NDEV_FMT" BSSID exists in the PMKList.\n", FUNC_NDEV_ARG(ndev));
+
+			_rtw_memcpy(psecuritypriv->PMKIDList[index].PMKID, (u8 *)pmksa->pmkid, WLAN_PMKID_LEN);
+			psecuritypriv->PMKIDList[index].bUsed = _TRUE;
+			psecuritypriv->PMKIDIndex = index + 1;
+			blInserted = _TRUE;
+			break;
+		}
+	}
+
+	if (!blInserted) {
+		/* Find a new entry */
+		RTW_INFO(FUNC_NDEV_FMT" Use the new entry index = %d for this PMKID.\n",
+			FUNC_NDEV_ARG(ndev), psecuritypriv->PMKIDIndex);
+
+		_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].Bssid, (u8 *)pmksa->bssid, ETH_ALEN);
+		_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].PMKID, (u8 *)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 *ndev,
+				  struct cfg80211_pmksa *pmksa)
+{
+	u8	index, bMatched = _FALSE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+
+	RTW_INFO(FUNC_NDEV_FMT" "MAC_FMT" "KEY_FMT"\n", FUNC_NDEV_ARG(ndev)
+		, MAC_ARG(pmksa->bssid), KEY_ARG(pmksa->pmkid));
+
+	for (index = 0 ; index < NUM_PMKID_CACHE; index++) {
+		if (_rtw_memcmp(psecuritypriv->PMKIDList[index].Bssid, (u8 *)pmksa->bssid, ETH_ALEN) == _TRUE) {
+			/* BSSID is matched, the same AP => Remove this PMKID information and reset it. */
+			_rtw_memset(psecuritypriv->PMKIDList[index].Bssid, 0x00, ETH_ALEN);
+			_rtw_memset(psecuritypriv->PMKIDList[index].PMKID, 0x00, WLAN_PMKID_LEN);
+			psecuritypriv->PMKIDList[index].bUsed = _FALSE;
+			bMatched = _TRUE;
+			RTW_INFO(FUNC_NDEV_FMT" clear id:%hhu\n", FUNC_NDEV_ARG(ndev), index);
+			break;
+		}
+	}
+
+	if (_FALSE == bMatched) {
+		RTW_INFO(FUNC_NDEV_FMT" do not have matched BSSID\n"
+			, FUNC_NDEV_ARG(ndev));
+		return -EINVAL;
+	}
+
+	return 0;
+}
+
+static int cfg80211_rtw_flush_pmksa(struct wiphy *wiphy,
+				    struct net_device *ndev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	_rtw_memset(&psecuritypriv->PMKIDList[0], 0x00, sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
+	psecuritypriv->PMKIDIndex = 0;
+
+	return 0;
+}
+
+#ifdef CONFIG_AP_MODE
+void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len)
+{
+	s32 freq;
+	int channel;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct net_device *ndev = padapter->pnetdev;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#if defined(RTW_USE_CFG80211_STA_EVENT) || defined(COMPAT_KERNEL_RELEASE)
+	{
+		struct station_info sinfo;
+		u8 ie_offset;
+		if (get_frame_sub_type(pmgmt_frame) == WIFI_ASSOCREQ)
+			ie_offset = _ASOCREQ_IE_OFFSET_;
+		else /* WIFI_REASSOCREQ */
+			ie_offset = _REASOCREQ_IE_OFFSET_;
+
+		memset(&sinfo, 0, sizeof(sinfo));
+		sinfo.filled = STATION_INFO_ASSOC_REQ_IES;
+		sinfo.assoc_req_ies = pmgmt_frame + WLAN_HDR_A3_LEN + ie_offset;
+		sinfo.assoc_req_ies_len = frame_len - WLAN_HDR_A3_LEN - ie_offset;
+		cfg80211_new_sta(ndev, get_addr2_ptr(pmgmt_frame), &sinfo, GFP_ATOMIC);
+	}
+#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
+	channel = pmlmeext->cur_channel;
+	freq = rtw_ch2freq(channel);
+
+	#ifdef COMPAT_KERNEL_RELEASE
+	rtw_cfg80211_rx_mgmt(pwdev, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
+	#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
+	rtw_cfg80211_rx_mgmt(pwdev, freq, 0, pmgmt_frame, frame_len, GFP_ATOMIC);
+	#else /* COMPAT_KERNEL_RELEASE */
+	{
+		/* to avoid WARN_ON(wdev->iftype != NL80211_IFTYPE_STATION)  when calling cfg80211_send_rx_assoc() */
+		#ifndef CONFIG_PLATFORM_MSTAR
+		pwdev->iftype = NL80211_IFTYPE_STATION;
+		#endif /* CONFIG_PLATFORM_MSTAR */
+		RTW_INFO("iftype=%d before call cfg80211_send_rx_assoc()\n", pwdev->iftype);
+		rtw_cfg80211_send_rx_assoc(padapter, NULL, pmgmt_frame, frame_len);
+		RTW_INFO("iftype=%d after call cfg80211_send_rx_assoc()\n", pwdev->iftype);
+		pwdev->iftype = NL80211_IFTYPE_AP;
+		/* cfg80211_rx_action(padapter->pnetdev, freq, pmgmt_frame, frame_len, GFP_ATOMIC); */
+	}
+	#endif /* COMPAT_KERNEL_RELEASE */
+#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
+
+}
+
+void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, const u8 *da, unsigned short reason)
+{
+	s32 freq;
+	int channel;
+	u8 *pmgmt_frame;
+	uint frame_len;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	unsigned short *fctrl;
+	u8 mgmt_buf[128] = {0};
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct wireless_dev *wdev = padapter->rtw_wdev;
+	struct net_device *ndev = padapter->pnetdev;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#if defined(RTW_USE_CFG80211_STA_EVENT) || defined(COMPAT_KERNEL_RELEASE)
+	cfg80211_del_sta(ndev, da, GFP_ATOMIC);
+#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
+	channel = pmlmeext->cur_channel;
+	freq = rtw_ch2freq(channel);
+
+	pmgmt_frame = mgmt_buf;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pmgmt_frame;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, da, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pmgmt_frame, WIFI_DEAUTH);
+
+	pmgmt_frame += sizeof(struct rtw_ieee80211_hdr_3addr);
+	frame_len = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	reason = cpu_to_le16(reason);
+	pmgmt_frame = rtw_set_fixed_ie(pmgmt_frame, _RSON_CODE_ , (unsigned char *)&reason, &frame_len);
+
+	#ifdef COMPAT_KERNEL_RELEASE
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, mgmt_buf, frame_len, GFP_ATOMIC);
+	#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, mgmt_buf, frame_len, GFP_ATOMIC);
+	#else /* COMPAT_KERNEL_RELEASE */
+	cfg80211_send_disassoc(padapter->pnetdev, mgmt_buf, frame_len);
+	/* cfg80211_rx_action(padapter->pnetdev, freq, mgmt_buf, frame_len, GFP_ATOMIC); */
+	#endif /* COMPAT_KERNEL_RELEASE */
+#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
+}
+
+static int rtw_cfg80211_monitor_if_open(struct net_device *ndev)
+{
+	int ret = 0;
+
+	RTW_INFO("%s\n", __func__);
+
+	return ret;
+}
+
+static int rtw_cfg80211_monitor_if_close(struct net_device *ndev)
+{
+	int ret = 0;
+
+	RTW_INFO("%s\n", __func__);
+
+	return ret;
+}
+
+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;
+	u16 frame_ctl;
+	unsigned char src_mac_addr[6];
+	unsigned char dst_mac_addr[6];
+	struct rtw_ieee80211_hdr *dot11_hdr;
+	struct ieee80211_radiotap_header *rtap_hdr;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	if (skb)
+		rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
+
+	if (IS_CH_WAITING(rfctl)) {
+		#ifdef CONFIG_DFS_MASTER
+		if (rtw_rfctl_overlap_radar_detect_ch(rfctl))
+			goto fail;
+		#endif
+	}
+
+	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) {
+		RTW_INFO("radiotap len (should be 14): %d\n", rtap_len);
+		goto fail;
+	}
+
+	/* Skip the ratio tap header */
+	skb_pull(skb, rtap_len);
+
+	dot11_hdr = (struct rtw_ieee80211_hdr *)skb->data;
+	frame_ctl = le16_to_cpu(dot11_hdr->frame_ctl);
+	/* Check if the QoS bit is set */
+	if ((frame_ctl & RTW_IEEE80211_FCTL_FTYPE) == RTW_IEEE80211_FTYPE_DATA) {
+		/* Check if this ia a Wireless Distribution System (WDS) frame
+		 * which has 4 MAC addresses
+		 */
+		if (dot11_hdr->frame_ctl & 0x0080)
+			qos_len = 2;
+		if ((dot11_hdr->frame_ctl & 0x0300) == 0x0300)
+			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
+		 * for two MAC addresses
+		 */
+		skb_pull(skb, dot11_hdr_len + qos_len + snap_len - sizeof(src_mac_addr) * 2);
+		pdata = (unsigned char *)skb->data;
+		memcpy(pdata, dst_mac_addr, sizeof(dst_mac_addr));
+		memcpy(pdata + sizeof(dst_mac_addr), src_mac_addr, sizeof(src_mac_addr));
+
+		RTW_INFO("should be eapol packet\n");
+
+		/* Use the real net device to transmit the packet */
+		ret = _rtw_xmit_entry(skb, padapter->pnetdev);
+
+		return ret;
+
+	} else if ((frame_ctl & (RTW_IEEE80211_FCTL_FTYPE | RTW_IEEE80211_FCTL_STYPE))
+		== (RTW_IEEE80211_FTYPE_MGMT | RTW_IEEE80211_STYPE_ACTION)
+	) {
+		/* 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 rtw_ieee80211_hdr *pwlanhdr;
+		struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+		struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+		u8 *buf = skb->data;
+		u32 len = skb->len;
+		u8 category, action;
+		int type = -1;
+
+		if (rtw_action_frame_parse(buf, len, &category, &action) == _FALSE) {
+			RTW_INFO(FUNC_NDEV_FMT" frame_control:0x%x\n", FUNC_NDEV_ARG(ndev),
+				le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl));
+			goto fail;
+		}
+
+		RTW_INFO("RTW_Tx:da="MAC_FMT" via "FUNC_NDEV_FMT"\n",
+			MAC_ARG(GetAddr1Ptr(buf)), FUNC_NDEV_ARG(ndev));
+		#ifdef CONFIG_P2P
+		type = rtw_p2p_check_frames(padapter, buf, len, _TRUE);
+		if (type >= 0)
+			goto dump;
+		#endif
+		if (category == RTW_WLAN_CATEGORY_PUBLIC)
+			RTW_INFO("RTW_Tx:%s\n", action_public_str(action));
+		else
+			RTW_INFO("RTW_Tx:category(%u), action(%u)\n", category, action);
+
+dump:
+		/* starting alloc mgmt frame to dump it */
+		pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+		if (pmgntframe == NULL)
+			goto fail;
+
+		/* update attribute */
+		pattrib = &pmgntframe->attrib;
+		update_mgntframe_attrib(padapter, pattrib);
+		pattrib->retry_ctrl = _FALSE;
+
+		_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+		pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+		_rtw_memcpy(pframe, (void *)buf, len);
+		pattrib->pktlen = len;
+
+#ifdef CONFIG_P2P
+		if (type >= 0)
+			rtw_xframe_chk_wfd_ie(pmgntframe);
+#endif /* CONFIG_P2P */
+
+		pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+		/* update seq number */
+		pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
+		pattrib->seqnum = pmlmeext->mgnt_seq;
+		pmlmeext->mgnt_seq++;
+
+
+		pattrib->last_txcmdsz = pattrib->pktlen;
+
+		dump_mgntframe(padapter, pmgntframe);
+
+	} else
+		RTW_INFO("frame_ctl=0x%x\n", frame_ctl & (RTW_IEEE80211_FCTL_FTYPE | RTW_IEEE80211_FCTL_STYPE));
+
+
+fail:
+
+	rtw_skb_free(skb);
+
+	return 0;
+
+}
+
+static void rtw_cfg80211_monitor_if_set_multicast_list(struct net_device *ndev)
+{
+	RTW_INFO("%s\n", __func__);
+}
+
+static int rtw_cfg80211_monitor_if_set_mac_address(struct net_device *ndev, void *addr)
+{
+	int ret = 0;
+
+	RTW_INFO("%s\n", __func__);
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+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,
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 2, 0))
+	.ndo_set_multicast_list = rtw_cfg80211_monitor_if_set_multicast_list,
+	#endif
+	.ndo_set_mac_address = rtw_cfg80211_monitor_if_set_mac_address,
+};
+#endif
+
+static int rtw_cfg80211_add_monitor_if(_adapter *padapter, char *name, struct net_device **ndev)
+{
+	int ret = 0;
+	struct net_device *mon_ndev = NULL;
+	struct wireless_dev *mon_wdev = NULL;
+	struct rtw_netdev_priv_indicator *pnpi;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+
+	if (!name) {
+		RTW_INFO(FUNC_ADPT_FMT" without specific name\n", FUNC_ADPT_ARG(padapter));
+		ret = -EINVAL;
+		goto out;
+	}
+
+	if (pwdev_priv->pmon_ndev) {
+		RTW_INFO(FUNC_ADPT_FMT" monitor interface exist: "NDEV_FMT"\n",
+			FUNC_ADPT_ARG(padapter), NDEV_ARG(pwdev_priv->pmon_ndev));
+		ret = -EBUSY;
+		goto out;
+	}
+
+	mon_ndev = alloc_etherdev(sizeof(struct rtw_netdev_priv_indicator));
+	if (!mon_ndev) {
+		RTW_INFO(FUNC_ADPT_FMT" allocate ndev fail\n", FUNC_ADPT_ARG(padapter));
+		ret = -ENOMEM;
+		goto out;
+	}
+
+	mon_ndev->type = ARPHRD_IEEE80211_RADIOTAP;
+	strncpy(mon_ndev->name, name, IFNAMSIZ);
+	mon_ndev->name[IFNAMSIZ - 1] = 0;
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(4, 11, 8))
+	mon_ndev->priv_destructor = rtw_ndev_destructor;
+#else
+	mon_ndev->destructor = rtw_ndev_destructor;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+	mon_ndev->netdev_ops = &rtw_cfg80211_monitor_if_ops;
+#else
+	mon_ndev->open = rtw_cfg80211_monitor_if_open;
+	mon_ndev->stop = rtw_cfg80211_monitor_if_close;
+	mon_ndev->hard_start_xmit = rtw_cfg80211_monitor_if_xmit_entry;
+	mon_ndev->set_mac_address = rtw_cfg80211_monitor_if_set_mac_address;
+#endif
+
+	pnpi = netdev_priv(mon_ndev);
+	pnpi->priv = padapter;
+	pnpi->sizeof_priv = sizeof(_adapter);
+
+	/*  wdev */
+	mon_wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
+	if (!mon_wdev) {
+		RTW_INFO(FUNC_ADPT_FMT" allocate mon_wdev fail\n", FUNC_ADPT_ARG(padapter));
+		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;
+	_rtw_memcpy(pwdev_priv->ifname_mon, name, IFNAMSIZ + 1);
+
+out:
+	if (ret && mon_wdev) {
+		rtw_mfree((u8 *)mon_wdev, sizeof(struct wireless_dev));
+		mon_wdev = NULL;
+	}
+
+	if (ret && mon_ndev) {
+		free_netdev(mon_ndev);
+		*ndev = mon_ndev = NULL;
+	}
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+static struct wireless_dev *
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+static struct net_device *
+#else
+static int
+#endif
+	cfg80211_rtw_add_virtual_intf(
+		struct wiphy *wiphy,
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 7, 0))
+		const char *name,
+		#else
+		char *name,
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+		unsigned char name_assign_type,
+		#endif
+		enum nl80211_iftype type,
+		#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+		u32 *flags,
+		#endif
+		struct vif_params *params)
+{
+	int ret = 0;
+	struct wireless_dev *wdev = NULL;
+	struct net_device *ndev = NULL;
+	_adapter *padapter;
+	struct dvobj_priv *dvobj = wiphy_to_dvobj(wiphy);
+
+	rtw_set_rtnl_lock_holder(dvobj, current);
+
+	RTW_INFO(FUNC_WIPHY_FMT" name:%s, type:%d\n", FUNC_WIPHY_ARG(wiphy), name, type);
+
+	switch (type) {
+	case NL80211_IFTYPE_MONITOR:
+		padapter = wiphy_to_adapter(wiphy); /* TODO: get ap iface ? */
+		ret = rtw_cfg80211_add_monitor_if(padapter, (char *)name, &ndev);
+		if (ret == 0)
+			wdev = ndev->ieee80211_ptr;
+		break;
+
+#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	case NL80211_IFTYPE_P2P_GO:
+#endif
+	case NL80211_IFTYPE_STATION:
+	case NL80211_IFTYPE_AP:
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+#endif
+		padapter = dvobj_get_unregisterd_adapter(dvobj);
+		if (!padapter) {
+			RTW_WARN("adapter pool empty!\n");
+			ret = -ENODEV;
+			break;
+		}
+		if (rtw_os_ndev_init(padapter, name) != _SUCCESS) {
+			RTW_WARN("ndev init fail!\n");
+			ret = -ENODEV;
+			break;
+		}
+		#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+		if (type == NL80211_IFTYPE_P2P_CLIENT || type == NL80211_IFTYPE_P2P_GO)
+			rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
+		#endif
+		ndev = padapter->pnetdev;
+		wdev = ndev->ieee80211_ptr;
+		break;
+
+#if defined(CONFIG_P2P) && defined(RTW_DEDICATED_P2P_DEVICE)
+	case NL80211_IFTYPE_P2P_DEVICE:
+		ret = rtw_pd_iface_alloc(wiphy, name, &wdev);
+		break;
+#endif
+
+	case NL80211_IFTYPE_ADHOC:
+	case NL80211_IFTYPE_AP_VLAN:
+	case NL80211_IFTYPE_WDS:
+	default:
+		ret = -ENODEV;
+		RTW_INFO("Unsupported interface type\n");
+		break;
+	}
+
+	if (ndev)
+		RTW_INFO(FUNC_WIPHY_FMT" ndev:%p, ret:%d\n", FUNC_WIPHY_ARG(wiphy), ndev, ret);
+	else
+		RTW_INFO(FUNC_WIPHY_FMT" wdev:%p, ret:%d\n", FUNC_WIPHY_ARG(wiphy), wdev, ret);
+
+	rtw_set_rtnl_lock_holder(dvobj, NULL);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	return wdev ? wdev : ERR_PTR(ret);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	return ndev ? ndev : ERR_PTR(ret);
+#else
+	return ret;
+#endif
+}
+
+static int cfg80211_rtw_del_virtual_intf(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev
+#else
+	struct net_device *ndev
+#endif
+)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct net_device *ndev = wdev_to_ndev(wdev);
+#endif
+	int ret = 0;
+	struct dvobj_priv *dvobj = wiphy_to_dvobj(wiphy);
+	_adapter *adapter;
+	struct rtw_wdev_priv *pwdev_priv;
+
+	rtw_set_rtnl_lock_holder(dvobj, current);
+
+	if (ndev) {
+		adapter = (_adapter *)rtw_netdev_priv(ndev);
+		pwdev_priv = adapter_wdev_data(adapter);
+
+		if (ndev == pwdev_priv->pmon_ndev) {
+			unregister_netdevice(ndev);
+			pwdev_priv->pmon_ndev = NULL;
+			pwdev_priv->ifname_mon[0] = '\0';
+			RTW_INFO(FUNC_NDEV_FMT" remove monitor ndev\n", FUNC_NDEV_ARG(ndev));
+		} else {
+			RTW_INFO(FUNC_NDEV_FMT" unregister ndev\n", FUNC_NDEV_ARG(ndev));
+			rtw_os_ndev_unregister(adapter);
+		}
+	} else
+#if defined(CONFIG_P2P) && defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev->iftype == NL80211_IFTYPE_P2P_DEVICE) {
+		if (wdev == wiphy_to_pd_wdev(wiphy))
+			rtw_pd_iface_free(wiphy);
+		else {
+			RTW_ERR(FUNC_WIPHY_FMT" unknown P2P Device wdev:%p\n", FUNC_WIPHY_ARG(wiphy), wdev);
+			rtw_warn_on(1);
+		}
+	} else
+#endif
+	{
+		ret = -EINVAL;
+		goto exit;
+	}
+
+exit:
+	rtw_set_rtnl_lock_holder(dvobj, NULL);
+	return ret;
+}
+
+static int rtw_add_beacon(_adapter *adapter, const u8 *head, size_t head_len, const u8 *tail, size_t tail_len)
+{
+	int ret = 0;
+	u8 *pbuf = NULL;
+	uint len, wps_ielen = 0;
+	uint p2p_ielen = 0;
+	u8 *p2p_ie;
+	u8 got_p2p_ie = _FALSE;
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	/* struct sta_priv *pstapriv = &padapter->stapriv; */
+
+
+	RTW_INFO("%s beacon_head_len=%zu, beacon_tail_len=%zu\n", __FUNCTION__, head_len, tail_len);
+
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	if (head_len < 24)
+		return -EINVAL;
+
+
+	pbuf = rtw_zmalloc(head_len + tail_len);
+	if (!pbuf)
+		return -ENOMEM;
+
+
+	/* _rtw_memcpy(&pstapriv->max_num_sta, param->u.bcn_ie.reserved, 2); */
+
+	/* if((pstapriv->max_num_sta>NUM_STA) || (pstapriv->max_num_sta<=0)) */
+	/*	pstapriv->max_num_sta = NUM_STA; */
+
+
+	_rtw_memcpy(pbuf, (void *)head + 24, head_len - 24); /* 24=beacon header len. */
+	_rtw_memcpy(pbuf + head_len - 24, (void *)tail, tail_len);
+
+	len = head_len + tail_len - 24;
+
+	/* check wps ie if inclued */
+	if (rtw_get_wps_ie(pbuf + _FIXED_IE_LENGTH_, len - _FIXED_IE_LENGTH_, NULL, &wps_ielen))
+		RTW_INFO("add bcn, wps_ielen=%d\n", wps_ielen);
+
+#ifdef CONFIG_P2P
+	if (adapter->wdinfo.driver_interface == DRIVER_CFG80211) {
+		/* check p2p if enable */
+		if (rtw_get_p2p_ie(pbuf + _FIXED_IE_LENGTH_, len - _FIXED_IE_LENGTH_, NULL, &p2p_ielen)) {
+			struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+			struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
+
+			RTW_INFO("got p2p_ie, len=%d\n", p2p_ielen);
+
+			got_p2p_ie = _TRUE;
+
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+				RTW_INFO("Enable P2P function for the first time\n");
+				rtw_p2p_enable(adapter, P2P_ROLE_GO);
+
+				adapter->stapriv.expire_to = 3; /* 3x2 = 6 sec in p2p mode */
+			} else {
+				RTW_INFO("enter GO Mode, p2p_ielen=%d\n", p2p_ielen);
+
+				rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
+				rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
+				pwdinfo->intent = 15;
+			}
+		}
+	}
+#endif /* CONFIG_P2P */
+
+	/* pbss_network->IEs will not include p2p_ie, wfd ie */
+	rtw_ies_remove_ie(pbuf, &len, _BEACON_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, P2P_OUI, 4);
+	rtw_ies_remove_ie(pbuf, &len, _BEACON_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, WFD_OUI, 4);
+
+	if (rtw_check_beacon_data(adapter, pbuf,  len) == _SUCCESS) {
+#ifdef CONFIG_P2P
+		/* check p2p if enable */
+		if (got_p2p_ie == _TRUE) {
+			struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+			struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
+			pwdinfo->operating_channel = pmlmeext->cur_channel;
+		}
+#endif /* CONFIG_P2P */
+		ret = 0;
+	} else
+		ret = -EINVAL;
+
+
+	rtw_mfree(pbuf, head_len + tail_len);
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) && !defined(COMPAT_KERNEL_RELEASE)
+static int cfg80211_rtw_add_beacon(struct wiphy *wiphy, struct net_device *ndev,
+		struct beacon_parameters *info)
+{
+	int ret = 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+
+	ret = rtw_add_beacon(adapter, info->head, info->head_len, info->tail, info->tail_len);
+
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_set_beacon(struct wiphy *wiphy, struct net_device *ndev,
+		struct beacon_parameters *info)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	pmlmeext->bstart_bss = _TRUE;
+
+	cfg80211_rtw_add_beacon(wiphy, ndev, info);
+
+	return 0;
+}
+
+static int	cfg80211_rtw_del_beacon(struct wiphy *wiphy, struct net_device *ndev)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+#else
+static int cfg80211_rtw_start_ap(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_ap_settings *settings)
+{
+	int ret = 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT" hidden_ssid:%d, auth_type:%d\n", FUNC_NDEV_ARG(ndev),
+		settings->hidden_ssid, settings->auth_type);
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+
+	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) {
+		WLAN_BSSID_EX *pbss_network = &adapter->mlmepriv.cur_network.network;
+		WLAN_BSSID_EX *pbss_network_ext = &adapter->mlmeextpriv.mlmext_info.network;
+
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" ssid:(%s,%zu), from ie:(%s,%d)\n", FUNC_ADPT_ARG(adapter),
+				settings->ssid, settings->ssid_len,
+				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength);
+
+		_rtw_memcpy(pbss_network->Ssid.Ssid, (void *)settings->ssid, settings->ssid_len);
+		pbss_network->Ssid.SsidLength = settings->ssid_len;
+		_rtw_memcpy(pbss_network_ext->Ssid.Ssid, (void *)settings->ssid, settings->ssid_len);
+		pbss_network_ext->Ssid.SsidLength = settings->ssid_len;
+
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" after ssid:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
+				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength,
+				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
+	}
+
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_change_beacon(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_beacon_data *info)
+{
+	int ret = 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	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)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) */
+
+#if CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+static int cfg80211_rtw_set_mac_acl(struct wiphy *wiphy, struct net_device *ndev,
+		const struct cfg80211_acl_data *params)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	u8 acl_mode = RTW_ACL_MODE_DISABLED;
+	int ret = -1;
+	int i;
+
+	if (!params) {
+		RTW_WARN(FUNC_ADPT_FMT" params NULL\n", FUNC_ADPT_ARG(adapter));
+		rtw_macaddr_acl_clear(adapter, RTW_ACL_PERIOD_BSS);
+		goto exit;
+	}
+
+	RTW_INFO(FUNC_ADPT_FMT" acl_policy:%d, entry_num:%d\n"
+		, FUNC_ADPT_ARG(adapter), params->acl_policy, params->n_acl_entries);
+
+	if (params->acl_policy == NL80211_ACL_POLICY_ACCEPT_UNLESS_LISTED)
+		acl_mode = RTW_ACL_MODE_ACCEPT_UNLESS_LISTED;
+	else if (params->acl_policy == NL80211_ACL_POLICY_DENY_UNLESS_LISTED)
+		acl_mode = RTW_ACL_MODE_DENY_UNLESS_LISTED;
+
+	rtw_macaddr_acl_clear(adapter, RTW_ACL_PERIOD_BSS);
+
+	rtw_set_macaddr_acl(adapter, RTW_ACL_PERIOD_BSS, acl_mode);
+
+	for (i = 0; i < params->n_acl_entries; i++)
+		rtw_acl_add_sta(adapter, RTW_ACL_PERIOD_BSS, params->mac_addrs[i].addr);
+
+	ret = 0;
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)) */
+
+const char *_nl80211_sta_flags_str[] = {
+	"INVALID",
+	"AUTHORIZED",
+	"SHORT_PREAMBLE",
+	"WME",
+	"MFP",
+	"AUTHENTICATED",
+	"TDLS_PEER",
+	"ASSOCIATED",
+};
+
+#define nl80211_sta_flags_str(_f) ((_f <= NL80211_STA_FLAG_MAX) ? _nl80211_sta_flags_str[_f] : _nl80211_sta_flags_str[0])
+
+const char *_nl80211_plink_state_str[] = {
+	"LISTEN",
+	"OPN_SNT",
+	"OPN_RCVD",
+	"CNF_RCVD",
+	"ESTAB",
+	"HOLDING",
+	"BLOCKED",
+	"UNKNOWN",
+};
+
+#define nl80211_plink_state_str(_s) ((_s < NUM_NL80211_PLINK_STATES) ? _nl80211_plink_state_str[_s] : _nl80211_plink_state_str[NUM_NL80211_PLINK_STATES])
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
+#define NL80211_PLINK_ACTION_NO_ACTION PLINK_ACTION_INVALID
+#define NL80211_PLINK_ACTION_OPEN PLINK_ACTION_OPEN
+#define NL80211_PLINK_ACTION_BLOCK PLINK_ACTION_BLOCK
+#define NUM_NL80211_PLINK_ACTIONS 3
+#endif
+
+const char *_nl80211_plink_actions_str[] = {
+	"NO_ACTION",
+	"OPEN",
+	"BLOCK",
+	"UNKNOWN",
+};
+
+#define nl80211_plink_actions_str(_a) ((_a < NUM_NL80211_PLINK_ACTIONS) ? _nl80211_plink_actions_str[_a] : _nl80211_plink_actions_str[NUM_NL80211_PLINK_ACTIONS])
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+const char *_nl80211_mesh_power_mode_str[] = {
+	"UNKNOWN",
+	"ACTIVE",
+	"LIGHT_SLEEP",
+	"DEEP_SLEEP",
+};
+
+#define nl80211_mesh_power_mode_str(_p) ((_p <= NL80211_MESH_POWER_MAX) ? _nl80211_mesh_power_mode_str[_p] : _nl80211_mesh_power_mode_str[0])
+#endif
+
+void dump_station_parameters(void *sel, struct wiphy *wiphy, const struct station_parameters *params)
+{
+#if DBG_RTW_CFG80211_STA_PARAM
+	if (params->supported_rates_len) {
+		#define SUPP_RATES_BUF_LEN (3 * RTW_G_RATES_NUM + 1)
+		int i;
+		char supp_rates_buf[SUPP_RATES_BUF_LEN] = {0};
+		u8 cnt = 0;
+
+		rtw_warn_on(params->supported_rates_len > RTW_G_RATES_NUM);
+
+		for (i = 0; i < params->supported_rates_len; i++) {
+			if (i >= RTW_G_RATES_NUM)
+				break;
+			cnt += snprintf(supp_rates_buf + cnt, SUPP_RATES_BUF_LEN - cnt -1
+				, "%02X ", params->supported_rates[i]);
+			if (cnt >= SUPP_RATES_BUF_LEN - 1)
+				break;
+		}
+
+		RTW_PRINT_SEL(sel, "supported_rates:%s\n", supp_rates_buf);
+	}
+
+	if (params->vlan)
+		RTW_PRINT_SEL(sel, "vlan:"NDEV_FMT"\n", NDEV_ARG(params->vlan));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 31))
+	if (params->sta_flags_mask) {
+		#define STA_FLAGS_BUF_LEN 128
+		int i = 0;
+		char sta_flags_buf[STA_FLAGS_BUF_LEN] = {0};
+		u8 cnt = 0;
+
+		for (i = 1; i <= NL80211_STA_FLAG_MAX; i++) {
+			if (params->sta_flags_mask & BIT(i)) {
+				cnt += snprintf(sta_flags_buf + cnt, STA_FLAGS_BUF_LEN - cnt -1, "%s=%u "
+					, nl80211_sta_flags_str(i), (params->sta_flags_set & BIT(i)) >> i);
+				if (cnt >= STA_FLAGS_BUF_LEN - 1)
+					break;
+			}
+		}
+
+		RTW_PRINT_SEL(sel, "sta_flags:%s\n", sta_flags_buf);
+	}
+#else
+	u32 station_flags;
+	#error "TBD\n"
+#endif
+
+	if (params->listen_interval != -1)
+		RTW_PRINT_SEL(sel, "listen_interval:%d\n", params->listen_interval);
+
+	if (params->aid)
+		RTW_PRINT_SEL(sel, "aid:%u\n", params->aid);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 8, 0))
+	if (params->peer_aid)
+		RTW_PRINT_SEL(sel, "peer_aid:%u\n", params->peer_aid);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26))
+	if (params->plink_action != NL80211_PLINK_ACTION_NO_ACTION)
+		RTW_PRINT_SEL(sel, "plink_action:%s\n", nl80211_plink_actions_str(params->plink_action));
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+	#endif
+		RTW_PRINT_SEL(sel, "plink_state:%s\n"
+			, nl80211_plink_state_str(params->plink_state));
+#endif
+
+#if 0 /* TODO */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 28))
+	const struct ieee80211_ht_cap *ht_capa;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	const struct ieee80211_vht_cap *vht_capa;
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_UAPSD)
+		RTW_PRINT_SEL(sel, "uapsd_queues:0x%02x\n", params->uapsd_queues);
+	if (params->max_sp)
+		RTW_PRINT_SEL(sel, "max_sp:%u\n", params->max_sp);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (params->local_pm != NL80211_MESH_POWER_UNKNOWN) {
+		RTW_PRINT_SEL(sel, "local_pm:%s\n"
+			, nl80211_mesh_power_mode_str(params->local_pm));
+	}
+
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_CAPABILITY)
+		RTW_PRINT_SEL(sel, "capability:0x%04x\n", params->capability);
+
+#if 0 /* TODO */
+	const u8 *ext_capab;
+	u8 ext_capab_len;
+#endif
+#endif
+
+#if 0 /* TODO */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0))
+	const u8 *supported_channels;
+	u8 supported_channels_len;
+	const u8 *supported_oper_classes;
+	u8 supported_oper_classes_len;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0))
+	u8 opmode_notif;
+	bool opmode_notif_used;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+	int support_p2p_ps;
+#endif
+#endif
+#endif /* DBG_RTW_CFG80211_STA_PARAM */
+}
+
+static int	cfg80211_rtw_add_station(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac,
+#else
+	const u8 *mac,
+#endif
+	struct station_parameters *params)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+#ifdef CONFIG_TDLS
+	struct sta_info *psta;
+#endif /* CONFIG_TDLS */
+
+	RTW_INFO(FUNC_NDEV_FMT" mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+
+#if CONFIG_RTW_MACADDR_ACL
+	if (rtw_access_ctrl(padapter, mac) == _FALSE) {
+		RTW_INFO(FUNC_NDEV_FMT" deny by macaddr ACL\n", FUNC_NDEV_ARG(ndev));
+		ret = -EINVAL;
+		goto exit;
+	}
+#endif
+
+	dump_station_parameters(RTW_DBGDUMP, wiphy, params);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		struct rtw_mesh_cfg *mcfg = &padapter->mesh_cfg;
+		struct rtw_mesh_info *minfo = &padapter->mesh_info;
+		struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+		struct mesh_plink_ent *plink = NULL;
+		struct wlan_network *scanned = NULL;
+		u8 add_new_sta = 0, probe_req = 0;
+		_irqL irqL;
+
+		if (params->plink_state != NL80211_PLINK_LISTEN) {
+			RTW_WARN(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(ndev), nl80211_plink_state_str(params->plink_state));
+			rtw_warn_on(1);
+		}
+		if (!params->aid || params->aid > pstapriv->max_aid) {
+			RTW_WARN(FUNC_NDEV_FMT" invalid aid:%u\n", FUNC_NDEV_ARG(ndev), params->aid);
+			rtw_warn_on(1);
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL);
+
+		plink = _rtw_mesh_plink_get(padapter, mac);
+		if (plink)
+			goto release_plink_ctl;
+
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		if (rtw_mesh_peer_blacklist_search(padapter, mac)) {
+			RTW_INFO(FUNC_NDEV_FMT" deny by peer blacklist\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+		#endif
+
+		/* wpa_supplicant's auto peer will initiate peering when candidate peer is reported without max_peer_links consideration */
+		if (plink_ctl->num >= mcfg->max_peer_links) {
+			RTW_INFO(FUNC_NDEV_FMT" exceed max_peer_links:%u\n"
+				, FUNC_NDEV_ARG(ndev), mcfg->max_peer_links);
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		scanned = rtw_find_network(&padapter->mlmepriv.scanned_queue, mac);
+		if (!scanned
+			|| rtw_get_passing_time_ms(scanned->last_scanned) >= mcfg->peer_sel_policy.scanr_exp_ms
+		) {
+			if (!scanned)
+				RTW_INFO(FUNC_NDEV_FMT" corresponding network not found\n", FUNC_NDEV_ARG(ndev));
+			else
+				RTW_INFO(FUNC_NDEV_FMT" corresponding network too old\n", FUNC_NDEV_ARG(ndev));
+
+			if (adapter_to_rfctl(padapter)->offch_state == OFFCHS_NONE)
+				probe_req = 1;
+
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		if (!rtw_bss_is_candidate_mesh_peer(&padapter->mlmepriv.cur_network.network, &scanned->network, 1, 1)){
+			RTW_WARN(FUNC_NDEV_FMT" corresponding network is not candidate with same ch\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		if (!rtw_mesh_cto_mgate_network_filter(padapter, scanned)) {
+			RTW_INFO(FUNC_NDEV_FMT" peer filtered out by cto_mgate check\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+		#endif
+
+		if (_rtw_mesh_plink_add(padapter, mac) == _SUCCESS) {
+			/* hook corresponding network in scan queue */
+			plink = _rtw_mesh_plink_get(padapter, mac);
+			plink->aid = params->aid;
+			plink->scanned = scanned;
+
+			add_new_sta = 1;
+		} else {
+			RTW_WARN(FUNC_NDEV_FMT" rtw_mesh_plink_add not success\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+		}
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+		if (probe_req)
+			issue_probereq(padapter, &padapter->mlmepriv.cur_network.network.mesh_id, mac);
+
+		if (add_new_sta) {
+			struct station_info sinfo;
+
+			#ifdef CONFIG_DFS_MASTER
+			if (IS_UNDER_CAC(adapter_to_rfctl(padapter)))
+				rtw_force_stop_cac(padapter, 300);
+			#endif
+
+			/* indicate new sta */
+			_rtw_memset(&sinfo, 0, sizeof(sinfo));
+			cfg80211_new_sta(ndev, mac, &sinfo, GFP_ATOMIC);
+		}
+		goto exit;
+	}
+#endif /* CONFIG_RTW_MESH */
+
+#ifdef CONFIG_TDLS
+	psta = rtw_get_stainfo(pstapriv, (u8 *)mac);
+	if (psta == NULL) {
+		psta = rtw_alloc_stainfo(pstapriv, (u8 *)mac);
+		if (psta == NULL) {
+			RTW_INFO("[%s] Alloc station for "MAC_FMT" fail\n", __FUNCTION__, MAC_ARG(mac));
+			ret = -EOPNOTSUPP;
+			goto exit;
+		}
+	}
+#endif /* CONFIG_TDLS */
+
+exit:
+	return ret;
+}
+
+static int	cfg80211_rtw_del_station(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 19, 0))
+	const u8 *mac
+#else
+	struct station_del_parameters *params
+#endif
+)
+{
+	int ret = 0;
+	_irqL irqL;
+	_list	*phead, *plist;
+	u8 updated = _FALSE;
+	const u8 *target_mac;
+	struct sta_info *psta = NULL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 19, 0))
+	target_mac = mac;
+#else
+	target_mac = params->mac;
+#endif
+
+	RTW_INFO("+"FUNC_NDEV_FMT" mac=%pM\n", FUNC_NDEV_ARG(ndev), target_mac);
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE)) != _TRUE) {
+		RTW_INFO("%s, fw_state != FW_LINKED|WIFI_AP_STATE|WIFI_MESH_STATE\n", __func__);
+		return -EINVAL;
+	}
+
+
+	if (!target_mac) {
+		RTW_INFO("flush all sta, and cam_entry\n");
+
+		flush_all_cam_entry(padapter);	/* clear CAM */
+
+#ifdef CONFIG_AP_MODE
+		ret = rtw_sta_flush(padapter, _TRUE);
+#endif
+		return ret;
+	}
+
+
+	RTW_INFO("free sta macaddr =" MAC_FMT "\n", MAC_ARG(target_mac));
+
+	if (target_mac[0] == 0xff && target_mac[1] == 0xff &&
+	    target_mac[2] == 0xff && target_mac[3] == 0xff &&
+	    target_mac[4] == 0xff && target_mac[5] == 0xff)
+		return -EINVAL;
+
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	/* check asoc_queue */
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+
+		plist = get_next(plist);
+
+		if (_rtw_memcmp((u8 *)target_mac, psta->cmn.mac_addr, ETH_ALEN)) {
+			if (psta->dot8021xalg == 1 && psta->bpairwise_key_installed == _FALSE)
+				RTW_INFO("%s, sta's dot8021xalg = 1 and key_installed = _FALSE\n", __func__);
+			else {
+				RTW_INFO("free psta=%p, aid=%d\n", psta, psta->cmn.aid);
+
+				rtw_list_delete(&psta->asoc_list);
+				pstapriv->asoc_list_cnt--;
+				STA_SET_MESH_PLINK(psta, NULL);
+
+				/* _exit_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
+				if (MLME_IS_AP(padapter))
+					updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
+				else
+					updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
+				/* _enter_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
+
+				psta = NULL;
+
+				break;
+			}
+
+		}
+
+	}
+
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+	associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_mesh_plink_del(padapter, target_mac);
+#endif
+
+	RTW_INFO("-"FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	return ret;
+
+}
+
+static int	cfg80211_rtw_change_station(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
+	u8 *mac,
+#else
+	const u8 *mac,
+#endif
+	struct station_parameters *params)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta = NULL;
+	_irqL irqL;
+	int ret = 0;
+
+	RTW_INFO(FUNC_NDEV_FMT" mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+
+	dump_station_parameters(RTW_DBGDUMP, wiphy, params);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		enum cfg80211_station_type sta_type = CFG80211_STA_MESH_PEER_USER;
+		struct rtw_mesh_info *minfo = &adapter->mesh_info;
+		struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+		struct mesh_plink_ent *plink = NULL;
+		_irqL irqL2;
+
+		ret = cfg80211_check_station_change(wiphy, params, sta_type);
+		if (ret) {
+			RTW_INFO("cfg80211_check_station_change return %d\n", ret);
+			goto exit;
+		}
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL2);
+
+		plink = _rtw_mesh_plink_get(adapter, mac);
+		if (!plink) {
+			ret = -ENOENT;
+			goto release_plink_ctl;
+		}
+
+		plink->plink_state = nl80211_plink_state_to_rtw_plink_state(params->plink_state);
+
+		if ((params->plink_state == NL80211_PLINK_OPN_RCVD
+				|| params->plink_state == NL80211_PLINK_CNF_RCVD
+				|| params->plink_state == NL80211_PLINK_ESTAB)
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+			&& (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+			#endif
+		) {
+			sta = rtw_get_stainfo(stapriv, mac);
+			if (!sta) {
+				sta = rtw_alloc_stainfo(stapriv, mac);
+				if (!sta)
+					goto release_plink_ctl;
+			}
+
+			if (params->plink_state == NL80211_PLINK_ESTAB) {
+				if (rtw_mesh_peer_establish(adapter, plink, sta) != _SUCCESS) {
+					rtw_free_stainfo(adapter, sta);
+					ret = -ENOENT;
+					goto release_plink_ctl;
+				}
+			}
+		}
+		else if (params->plink_state == NL80211_PLINK_HOLDING
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+			&& (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+			#endif
+		) {
+			u8 updated = _FALSE;
+
+			sta = rtw_get_stainfo(stapriv, mac);
+			if (!sta)
+				goto release_plink_ctl;
+
+			_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+			if (!rtw_is_list_empty(&sta->asoc_list)) {
+				rtw_list_delete(&sta->asoc_list);
+				stapriv->asoc_list_cnt--;
+				STA_SET_MESH_PLINK(sta, NULL);
+			}
+			_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+			updated = ap_free_sta(adapter, sta, 0, 0, 1);
+			associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
+		}
+
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL2);
+	}
+#endif /* CONFIG_RTW_MESH */
+
+exit:
+	return ret;
+}
+
+struct sta_info *rtw_sta_info_get_by_idx(struct sta_priv *pstapriv, const int idx, u8 *asoc_list_num)
+{
+	_list	*phead, *plist;
+	struct sta_info *psta = NULL;
+	int i = 0;
+
+	phead = &pstapriv->asoc_list;
+	plist = get_next(phead);
+
+	/* check asoc_queue */
+	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+		if (idx == i)
+			psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+		plist = get_next(plist);
+		i++;
+	}
+
+	if (asoc_list_num)
+		*asoc_list_num = i;
+
+	return psta;
+}
+
+static int	cfg80211_rtw_dump_station(struct wiphy *wiphy, struct net_device *ndev,
+		int idx, u8 *mac, struct station_info *sinfo)
+{
+#define DBG_DUMP_STATION 0
+
+	int ret = 0;
+	_irqL irqL;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta = NULL;
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink = NULL;
+#endif
+	u8 asoc_list_num;
+
+	if (DBG_DUMP_STATION)
+		RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+	psta = rtw_sta_info_get_by_idx(pstapriv, idx, &asoc_list_num);
+	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (!psta)
+			plink = rtw_mesh_plink_get_no_estab_by_idx(padapter, idx - asoc_list_num);
+		else
+			plink = psta->plink;
+	}
+#endif /* CONFIG_RTW_MESH */
+
+	if (!psta
+		#ifdef CONFIG_RTW_MESH
+		&& !plink
+		#endif
+	) {
+		if (DBG_DUMP_STATION)
+			RTW_INFO(FUNC_NDEV_FMT" end with idx:%d\n", FUNC_NDEV_ARG(ndev), idx);
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	if (psta)
+		_rtw_memcpy(mac, psta->cmn.mac_addr, ETH_ALEN);
+	#ifdef CONFIG_RTW_MESH
+	else
+		_rtw_memcpy(mac, plink->addr, ETH_ALEN);
+	#endif
+	
+	sinfo->filled = 0;
+
+	if (psta) {
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(psta->cmn.rssi_stat.rssi);
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		sinfo->inactive_time = rtw_get_passing_time_ms(psta->sta_stats.last_rx_time);
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_cfg80211_fill_mesh_only_sta_info(plink, psta, sinfo);
+#endif
+
+exit:
+	return ret;
+}
+
+static int	cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,
+		struct bss_parameters *params)
+{
+	u8 i;
+
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+/*
+	RTW_INFO("use_cts_prot=%d\n", params->use_cts_prot);
+	RTW_INFO("use_short_preamble=%d\n", params->use_short_preamble);
+	RTW_INFO("use_short_slot_time=%d\n", params->use_short_slot_time);
+	RTW_INFO("ap_isolate=%d\n", params->ap_isolate);
+
+	RTW_INFO("basic_rates_len=%d\n", params->basic_rates_len);
+	for(i = 0; i < params->basic_rates_len; i++)
+		RTW_INFO("basic_rates=%d\n", params->basic_rates[i]);
+*/
+	return 0;
+
+}
+
+static int	cfg80211_rtw_set_channel(struct wiphy *wiphy
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	, struct net_device *ndev
+	#endif
+	, struct ieee80211_channel *chan, enum nl80211_channel_type channel_type)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+#else
+	_adapter *padapter = wiphy_to_adapter(wiphy);
+#endif
+	int chan_target = (u8) ieee80211_frequency_to_channel(chan->center_freq);
+	int chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int chan_width = CHANNEL_WIDTH_20;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+#endif
+
+	switch (channel_type) {
+	case NL80211_CHAN_NO_HT:
+	case NL80211_CHAN_HT20:
+		chan_width = CHANNEL_WIDTH_20;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT40MINUS:
+		chan_width = CHANNEL_WIDTH_40;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_HT40PLUS:
+		chan_width = CHANNEL_WIDTH_40;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+	default:
+		chan_width = CHANNEL_WIDTH_20;
+		chan_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
+
+	RTW_INFO(FUNC_ADPT_FMT" ch:%d bw:%d, offset:%d\n"
+		, FUNC_ADPT_ARG(padapter), chan_target, chan_width, chan_offset);
+
+	rtw_set_chbw_cmd(padapter, chan_target, chan_width, chan_offset, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+
+static int cfg80211_rtw_set_monitor_channel(struct wiphy *wiphy
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	, struct cfg80211_chan_def *chandef
+#else
+	, struct ieee80211_channel *chan
+	, enum nl80211_channel_type channel_type
+#endif
+)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct ieee80211_channel *chan = chandef->chan;
+#endif
+
+	_adapter *padapter = wiphy_to_adapter(wiphy);
+	int target_channal = chan->hw_value;
+	int target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int target_width = CHANNEL_WIDTH_20;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("center_freq %u Mhz ch %u width %u freq1 %u freq2 %u\n"
+		, chan->center_freq
+		, chan->hw_value
+		, chandef->width
+		, chandef->center_freq1
+		, chandef->center_freq2);
+#endif /* CONFIG_DEBUG_CFG80211 */
+
+	switch (chandef->width) {
+	case NL80211_CHAN_WIDTH_20_NOHT:
+	case NL80211_CHAN_WIDTH_20:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_WIDTH_40:
+		target_width = CHANNEL_WIDTH_40;
+		if (chandef->center_freq1 > chan->center_freq)
+			target_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		else
+			target_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_WIDTH_80:
+		target_width = CHANNEL_WIDTH_80;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_WIDTH_80P80:
+		target_width = CHANNEL_WIDTH_80_80;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_WIDTH_160:
+		target_width = CHANNEL_WIDTH_160;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	case NL80211_CHAN_WIDTH_5:
+	case NL80211_CHAN_WIDTH_10:
+#endif
+	default:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
+#else
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("center_freq %u Mhz ch %u channel_type %u\n"
+		, chan->center_freq
+		, chan->hw_value
+		, channel_type);
+#endif /* CONFIG_DEBUG_CFG80211 */
+
+	switch (channel_type) {
+	case NL80211_CHAN_NO_HT:
+	case NL80211_CHAN_HT20:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	case NL80211_CHAN_HT40MINUS:
+		target_width = CHANNEL_WIDTH_40;
+		target_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
+	case NL80211_CHAN_HT40PLUS:
+		target_width = CHANNEL_WIDTH_40;
+		target_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+	default:
+		target_width = CHANNEL_WIDTH_20;
+		target_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
+#endif
+	RTW_INFO(FUNC_ADPT_FMT" ch:%d bw:%d, offset:%d\n"
+		, FUNC_ADPT_ARG(padapter), target_channal, target_width, target_offset);
+
+	rtw_set_chbw_cmd(padapter, target_channal, target_width, target_offset, RTW_CMDF_WAIT_ACK);
+
+	return 0;
+}
+
+static int	cfg80211_rtw_auth(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_auth_request *req)
+{
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	return 0;
+}
+
+static int	cfg80211_rtw_assoc(struct wiphy *wiphy, struct net_device *ndev,
+		struct cfg80211_assoc_request *req)
+{
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	return 0;
+}
+#endif /* CONFIG_AP_MODE */
+
+void rtw_cfg80211_rx_probe_request(_adapter *adapter, union recv_frame *rframe)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("RTW_Rx: probe request, ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_rx_action_p2p(_adapter *adapter, union recv_frame *rframe)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+	u8 category, action;
+	int type;
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+#ifdef CONFIG_P2P
+	type = rtw_p2p_check_frames(adapter, frame, frame_len, _FALSE);
+	if (type >= 0)
+		goto indicate;
+#endif
+	rtw_action_frame_parse(frame, frame_len, &category, &action);
+	RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+
+indicate:
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_rx_p2p_action_public(_adapter *adapter, union recv_frame *rframe)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+	u8 category, action;
+	int type;
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+	#ifdef CONFIG_P2P
+	type = rtw_p2p_check_frames(adapter, frame, frame_len, _FALSE);
+	if (type >= 0) {
+		switch (type) {
+		case P2P_GO_NEGO_CONF:
+			if (0) {
+				RTW_INFO(FUNC_ADPT_FMT" Nego confirm. state=%u, status=%u, iaddr="MAC_FMT"\n"
+					, FUNC_ADPT_ARG(adapter), pwdev_priv->nego_info.state, pwdev_priv->nego_info.status
+					, MAC_ARG(pwdev_priv->nego_info.iface_addr));
+			}
+			if (pwdev_priv->nego_info.state == 2
+				&& pwdev_priv->nego_info.status == 0
+				&& rtw_check_invalid_mac_address(pwdev_priv->nego_info.iface_addr, _FALSE) == _FALSE
+			) {
+				_adapter *intended_iface = dvobj_get_adapter_by_addr(dvobj, pwdev_priv->nego_info.iface_addr);
+
+				if (intended_iface) {
+					RTW_INFO(FUNC_ADPT_FMT" Nego confirm. Allow only "ADPT_FMT" to scan for 2000 ms\n"
+						, FUNC_ADPT_ARG(adapter), ADPT_ARG(intended_iface));
+					/* allow only intended_iface to do scan for 2000 ms */
+					rtw_mi_set_scan_deny(adapter, 2000);
+					rtw_clear_scan_deny(intended_iface);
+				}
+			}
+			break;
+		case P2P_PROVISION_DISC_RESP:
+		case P2P_INVIT_RESP:
+			#if !RTW_P2P_GROUP_INTERFACE
+			rtw_mi_buddy_set_scan_deny(adapter, 2000);
+			#endif
+			break;
+		}
+		goto indicate;
+	}
+	#endif
+	rtw_action_frame_parse(frame, frame_len, &category, &action);
+	RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+
+indicate:
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (rtw_cfg80211_redirect_pd_wdev(dvobj_to_wiphy(dvobj), get_ra(frame), &wdev))
+		if (0)
+			RTW_INFO("redirect to pd_wdev:%p\n", wdev);
+	#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+}
+
+void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const char *msg)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+	u8 category, action;
+	int type = -1;
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		type = rtw_mesh_check_frames_rx(adapter, frame, frame_len);
+		if (type >= 0)
+			goto indicate;
+	}
+#endif
+	rtw_action_frame_parse(frame, frame_len, &category, &action);
+	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
+		if (action == ACT_PUBLIC_GAS_INITIAL_REQ) {
+			rtw_mi_set_scan_deny(adapter, 200);
+			rtw_mi_scan_abort(adapter, _FALSE); /*rtw_scan_abort_no_wait*/
+		}
+	}
+
+indicate:
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+
+	if (type == -1) {
+		if (msg)
+			RTW_INFO("RTW_Rx:%s\n", msg);
+		else
+			RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+	}
+}
+
+#ifdef CONFIG_RTW_80211K
+void rtw_cfg80211_rx_rrm_action(_adapter *adapter, union recv_frame *rframe)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+}
+#endif /* CONFIG_RTW_80211K */
+
+void rtw_cfg80211_rx_mframe(_adapter *adapter, union recv_frame *rframe, const char *msg)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n", ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+	#ifdef CONFIG_RTW_MESH
+	if (!rtw_sae_check_frames(adapter, frame, frame_len, _FALSE))
+	#endif
+	{
+		if (msg)
+			RTW_INFO("RTW_Rx:%s\n", msg);
+		else
+			RTW_INFO("RTW_Rx:frame_control:0x%02x\n", le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)rframe)->frame_ctl));
+	}
+}
+
+#ifdef CONFIG_P2P
+void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len)
+{
+	u16	wps_devicepassword_id = 0x0000;
+	uint	wps_devicepassword_id_len = 0;
+	u8			wpsie[255] = { 0x00 }, p2p_ie[255] = { 0x00 };
+	uint			p2p_ielen = 0;
+	uint			wpsielen = 0;
+	u32	devinfo_contentlen = 0;
+	u8	devinfo_content[64] = { 0x00 };
+	u16	capability = 0;
+	uint capability_len = 0;
+
+	unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
+	u8			action = P2P_PUB_ACTION_ACTION;
+	u8			dialogToken = 1;
+	u32			p2poui = cpu_to_be32(P2POUI);
+	u8			oui_subtype = P2P_PROVISION_DISC_REQ;
+	u32			p2pielen = 0;
+#ifdef CONFIG_WFD
+	u32					wfdielen = 0;
+#endif
+
+	struct xmit_frame			*pmgntframe;
+	struct pkt_attrib			*pattrib;
+	unsigned char					*pframe;
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	unsigned short				*fctrl;
+	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8 *frame_body = (unsigned char *)(buf + sizeof(struct rtw_ieee80211_hdr_3addr));
+	size_t frame_body_len = len - sizeof(struct rtw_ieee80211_hdr_3addr);
+
+
+	RTW_INFO("[%s] In\n", __FUNCTION__);
+
+	/* prepare for building provision_request frame	 */
+	_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerIFAddr, GetAddr1Ptr(buf), ETH_ALEN);
+	_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerDevAddr, GetAddr1Ptr(buf), ETH_ALEN);
+
+	pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
+
+	rtw_get_wps_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, wpsie, &wpsielen);
+	rtw_get_wps_attr_content(wpsie, wpsielen, WPS_ATTR_DEVICE_PWID, (u8 *) &wps_devicepassword_id, &wps_devicepassword_id_len);
+	wps_devicepassword_id = be16_to_cpu(wps_devicepassword_id);
+
+	switch (wps_devicepassword_id) {
+	case WPS_DPID_PIN:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_LABEL;
+		break;
+	case WPS_DPID_USER_SPEC:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_DISPLYA;
+		break;
+	case WPS_DPID_MACHINE_SPEC:
+		break;
+	case WPS_DPID_REKEY:
+		break;
+	case WPS_DPID_PBC:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
+		break;
+	case WPS_DPID_REGISTRAR_SPEC:
+		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_KEYPAD;
+		break;
+	default:
+		break;
+	}
+
+
+	if (rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, p2p_ie, &p2p_ielen)) {
+
+		rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO, devinfo_content, &devinfo_contentlen);
+		rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&capability, &capability_len);
+
+	}
+
+
+	/* start to build provision_request frame	 */
+	_rtw_memset(wpsie, 0, sizeof(wpsie));
+	_rtw_memset(p2p_ie, 0, sizeof(p2p_ie));
+	p2p_ielen = 0;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return;
+
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, pwdinfo->tx_prov_disc_info.peerDevAddr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, pwdinfo->tx_prov_disc_info.peerDevAddr, ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
+
+
+	/* build_prov_disc_request_p2p_ie	 */
+	/*	P2P OUI */
+	p2pielen = 0;
+	p2p_ie[p2pielen++] = 0x50;
+	p2p_ie[p2pielen++] = 0x6F;
+	p2p_ie[p2pielen++] = 0x9A;
+	p2p_ie[p2pielen++] = 0x09;	/*	WFA P2P v1.0 */
+
+	/*	Commented by Albert 20110301 */
+	/*	According to the P2P Specification, the provision discovery request frame should contain 3 P2P attributes */
+	/*	1. P2P Capability */
+	/*	2. Device Info */
+	/*	3. Group ID ( When joining an operating P2P Group ) */
+
+	/*	P2P Capability ATTR */
+	/*	Type:	 */
+	p2p_ie[p2pielen++] = P2P_ATTR_CAPABILITY;
+
+	/*	Length: */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 ); */
+	RTW_PUT_LE16(p2p_ie + p2pielen, 0x0002);
+	p2pielen += 2;
+
+	/*	Value: */
+	/*	Device Capability Bitmap, 1 byte */
+	/*	Group Capability Bitmap, 1 byte */
+	_rtw_memcpy(p2p_ie + p2pielen, &capability, 2);
+	p2pielen += 2;
+
+
+	/*	Device Info ATTR */
+	/*	Type: */
+	p2p_ie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
+
+	/*	Length: */
+	/*	21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes)  */
+	/*	+ NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
+	/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len ); */
+	RTW_PUT_LE16(p2p_ie + p2pielen, devinfo_contentlen);
+	p2pielen += 2;
+
+	/*	Value: */
+	_rtw_memcpy(p2p_ie + p2pielen, devinfo_content, devinfo_contentlen);
+	p2pielen += devinfo_contentlen;
+
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2p_ie, &p2p_ielen);
+	/* p2pielen = build_prov_disc_request_p2p_ie( pwdinfo, pframe, NULL, 0, pwdinfo->tx_prov_disc_info.peerDevAddr); */
+	/* pframe += p2pielen; */
+	pattrib->pktlen += p2p_ielen;
+
+	wpsielen = 0;
+	/*	WPS OUI */
+	*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
+	wpsielen += 4;
+
+	/*	WPS version */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
+	wpsielen += 2;
+
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
+	wpsielen += 2;
+
+	/*	Value: */
+	wpsie[wpsielen++] = WPS_VERSION_1;	/*	Version 1.0 */
+
+	/*	Config Method */
+	/*	Type: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
+	wpsielen += 2;
+
+	/*	Length: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
+	wpsielen += 2;
+
+	/*	Value: */
+	*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->tx_prov_disc_info.wps_config_method_request);
+	wpsielen += 2;
+
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
+
+
+#ifdef CONFIG_WFD
+	wfdielen = build_provdisc_req_wfd_ie(pwdinfo, pframe);
+	pframe += wfdielen;
+	pattrib->pktlen += wfdielen;
+#endif
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	/* dump_mgntframe(padapter, pmgntframe); */
+	if (dump_mgntframe_and_wait_ack(padapter, pmgntframe) != _SUCCESS)
+		RTW_INFO("%s, ack to\n", __func__);
+
+	#if 0
+	if(wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC) {
+		RTW_INFO("waiting for p2p peer key-in PIN CODE\n");
+		rtw_msleep_os(15000); /* 15 sec for key in PIN CODE, workaround for GS2 before issuing Nego Req. */
+	}
+	#endif
+
+}
+
+#ifdef CONFIG_RTW_80211R
+static s32 cfg80211_rtw_update_ft_ies(struct wiphy *wiphy,
+	struct net_device *ndev,
+	struct cfg80211_update_ft_ies_params *ftie)
+{
+	_adapter *padapter = NULL;
+	struct mlme_priv *pmlmepriv = NULL;
+	struct ft_roam_info *pft_roam = NULL;
+	_irqL irqL;
+	u8 *p;
+	u8 *pie = NULL;
+	u32 ie_len = 0;
+
+	if (ndev == NULL)
+		return  -EINVAL;
+
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	pmlmepriv = &(padapter->mlmepriv);
+	pft_roam = &(pmlmepriv->ft_roam);
+
+	p = (u8 *)ftie->ie;
+	if (ftie->ie_len <= sizeof(pft_roam->updated_ft_ies)) {
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		_rtw_memcpy(pft_roam->updated_ft_ies, ftie->ie, ftie->ie_len);
+		pft_roam->updated_ft_ies_len = ftie->ie_len;
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+	} else {
+		RTW_ERR("FTIEs parsing fail!\n");
+		return -EINVAL;
+	}
+
+	if (rtw_ft_roam_status(padapter, RTW_FT_AUTHENTICATED_STA)) {
+		RTW_PRINT("auth success, start reassoc\n");
+		rtw_ft_lock_set_status(padapter, RTW_FT_ASSOCIATING_STA, &irqL);
+		start_clnt_assoc(padapter);
+	}
+
+	return 0;
+}
+#endif
+
+inline void rtw_cfg80211_set_is_roch(_adapter *adapter, bool val)
+{
+	adapter->cfg80211_wdinfo.is_ro_ch = val;
+	rtw_mi_update_iface_status(&(adapter->mlmepriv), 0);
+}
+
+inline bool rtw_cfg80211_get_is_roch(_adapter *adapter)
+{
+	return adapter->cfg80211_wdinfo.is_ro_ch;
+}
+
+inline bool rtw_cfg80211_is_ro_ch_once(_adapter *adapter)
+{
+	return adapter->cfg80211_wdinfo.last_ro_ch_time ? 1 : 0;
+}
+
+inline void rtw_cfg80211_set_last_ro_ch_time(_adapter *adapter)
+{
+	adapter->cfg80211_wdinfo.last_ro_ch_time = rtw_get_current_time();
+
+	if (!adapter->cfg80211_wdinfo.last_ro_ch_time)
+		adapter->cfg80211_wdinfo.last_ro_ch_time++;
+}
+
+inline s32 rtw_cfg80211_get_last_ro_ch_passing_ms(_adapter *adapter)
+{
+	return rtw_get_passing_time_ms(adapter->cfg80211_wdinfo.last_ro_ch_time);
+}
+
+static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+	struct ieee80211_channel *channel,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	enum nl80211_channel_type channel_type,
+#endif
+	unsigned int duration, u64 *cookie)
+{
+	s32 err = 0;
+	u8 remain_ch = (u8) ieee80211_frequency_to_channel(channel->center_freq);
+	u8 union_ch = 0, union_bw = 0, union_offset = 0;
+	u8 i;
+	_adapter *padapter = NULL;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct wifidirect_info *pwdinfo;
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
+	u8 is_p2p_find = _FALSE;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		err = -EINVAL;
+		goto exit;
+	}
+#else
+	struct wireless_dev *wdev;
+
+	if (ndev == NULL) {
+		err = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	pwdev_priv = adapter_wdev_data(padapter);
+	pwdinfo = &padapter->wdinfo;
+	pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+#ifdef CONFIG_CONCURRENT_MODE
+	is_p2p_find = (duration < (pwdinfo->ext_listen_interval)) ? _TRUE : _FALSE;
+#endif
+
+	*cookie = ATOMIC_INC_RETURN(&pcfg80211_wdinfo->ro_ch_cookie_gen);
+
+	RTW_INFO(FUNC_ADPT_FMT"%s ch:%u duration:%d, cookie:0x%llx\n"
+		, FUNC_ADPT_ARG(padapter), wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : ""
+		, remain_ch, duration, *cookie);
+
+	if (rtw_chset_search_ch(adapter_to_chset(padapter), remain_ch) < 0) {
+		RTW_WARN(FUNC_ADPT_FMT" invalid ch:%u\n", FUNC_ADPT_ARG(padapter), remain_ch);
+		err = -EFAULT;
+		goto exit;
+	}
+
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block remain_on_channel request\n");
+		err = -EFAULT;
+		goto exit;
+	}
+#endif
+
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		err = -EFAULT;
+		goto exit;
+	}
+
+	rtw_scan_abort(padapter);
+#ifdef CONFIG_CONCURRENT_MODE
+	/*don't scan_abort during p2p_listen.*/
+	if (is_p2p_find)
+		rtw_mi_buddy_scan_abort(padapter, _TRUE);
+#endif /*CONFIG_CONCURRENT_MODE*/
+
+	if (rtw_cfg80211_get_is_roch(padapter) == _TRUE) {
+		_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
+		p2p_cancel_roch_cmd(padapter, 0, NULL, RTW_CMDF_WAIT_ACK);
+	}
+
+	/* if(!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) && !rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) */
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
+		padapter->wdinfo.listen_channel = remain_ch;
+		RTW_INFO(FUNC_ADPT_FMT" init listen_channel %u\n"
+			, FUNC_ADPT_ARG(padapter), padapter->wdinfo.listen_channel);
+	} else if (rtw_p2p_chk_state(pwdinfo , P2P_STATE_LISTEN)
+		&& (time_after_eq(rtw_get_current_time(), pwdev_priv->probe_resp_ie_update_time)
+			&& rtw_get_passing_time_ms(pwdev_priv->probe_resp_ie_update_time) < 50)
+	) {
+		if (padapter->wdinfo.listen_channel != remain_ch) {
+			padapter->wdinfo.listen_channel = remain_ch;
+			RTW_INFO(FUNC_ADPT_FMT" update listen_channel %u\n"
+				, FUNC_ADPT_ARG(padapter), padapter->wdinfo.listen_channel);
+		}
+	} else {
+		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
+#endif
+	}
+
+	rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
+
+	#ifdef RTW_ROCH_DURATION_ENLARGE
+	if (duration < 400)
+		duration = duration * 3; /* extend from exper */
+	#endif
+
+#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_CONCURRENT_MODE)
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		if (is_p2p_find) /* p2p_find , duration<1000 */
+			duration = duration + pwdinfo->ext_listen_interval;
+		else /* p2p_listen, duration=5000 */
+			duration = pwdinfo->ext_listen_interval + (pwdinfo->ext_listen_interval / 4);
+	}
+#endif /*defined (RTW_ROCH_BACK_OP) && defined(CONFIG_CONCURRENT_MODE) */
+
+	rtw_cfg80211_set_is_roch(padapter, _TRUE);
+	pcfg80211_wdinfo->ro_ch_wdev = wdev;
+	pcfg80211_wdinfo->remain_on_ch_cookie = *cookie;
+	rtw_cfg80211_set_last_ro_ch_time(padapter);
+	_rtw_memcpy(&pcfg80211_wdinfo->remain_on_ch_channel, channel, sizeof(struct ieee80211_channel));
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	pcfg80211_wdinfo->remain_on_ch_type = channel_type;
+	#endif
+	pcfg80211_wdinfo->restore_channel = rtw_get_oper_ch(padapter);
+
+	p2p_roch_cmd(padapter, *cookie, wdev, channel, pcfg80211_wdinfo->remain_on_ch_type,
+		duration, RTW_CMDF_WAIT_ACK);
+
+	rtw_cfg80211_ready_on_channel(wdev, *cookie, channel, channel_type, duration, GFP_KERNEL);
+exit:
+	return err;
+}
+
+static s32 cfg80211_rtw_cancel_remain_on_channel(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+	u64 cookie)
+{
+	s32 err = 0;
+	_adapter *padapter;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct wifidirect_info *pwdinfo;
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		err = -EINVAL;
+		goto exit;
+	}
+#else
+	struct wireless_dev *wdev;
+
+	if (ndev == NULL) {
+		err = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	pwdev_priv = adapter_wdev_data(padapter);
+	pwdinfo = &padapter->wdinfo;
+	pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+
+	RTW_INFO(FUNC_ADPT_FMT"%s cookie:0x%llx\n"
+		, FUNC_ADPT_ARG(padapter), wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : ""
+		, cookie);
+
+	if (rtw_cfg80211_get_is_roch(padapter) == _TRUE) {
+		_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
+		p2p_cancel_roch_cmd(padapter, cookie, wdev, RTW_CMDF_WAIT_ACK);
+	}
+
+exit:
+	return err;
+}
+
+inline int rtw_cfg80211_iface_has_p2p_group_cap(_adapter *adapter)
+{
+	struct wiphy *wiphy = adapter_to_wiphy(adapter);
+	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(adapter);
+
+#if RTW_P2P_GROUP_INTERFACE
+	if (is_primary_adapter(adapter))
+		return 0;
+#endif
+	return 1;
+}
+
+inline int rtw_cfg80211_is_p2p_scan(_adapter *adapter)
+{
+#if RTW_P2P_GROUP_INTERFACE
+	if (rtw_cfg80211_iface_has_p2p_group_cap(adapter))
+#endif
+	{
+		struct wifidirect_info *wdinfo = &adapter->wdinfo;
+
+		return rtw_p2p_chk_state(wdinfo, P2P_STATE_SCAN)
+			|| rtw_p2p_chk_state(wdinfo, P2P_STATE_FIND_PHASE_SEARCH);
+	}
+
+#if RTW_P2P_GROUP_INTERFACE
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wiphy_to_pd_wdev(adapter_to_wiphy(adapter))) /* pd_wdev exist */
+		return rtw_cfg80211_is_scan_by_pd_wdev(adapter);
+	#endif
+	{
+		/*
+		* For 2 RTW_P2P_GROUP_INTERFACE cases:
+		* 1. RTW_DEDICATED_P2P_DEVICE defined but upper layer don't use pd_wdev or
+		* 2. RTW_DEDICATED_P2P_DEVICE not defined
+		*/
+		struct rtw_wdev_priv *wdev_data = adapter_wdev_data(adapter);
+		_irqL irqL;
+		int is_p2p_scan = 0;
+
+		_enter_critical_bh(&wdev_data->scan_req_lock, &irqL);
+		if (wdev_data->scan_request
+			&& wdev_data->scan_request->ssids
+			&& wdev_data->scan_request->ie
+		) {
+			if (_rtw_memcmp(wdev_data->scan_request->ssids->ssid, "DIRECT-", 7)
+				&& rtw_get_p2p_ie((u8 *)wdev_data->scan_request->ie, wdev_data->scan_request->ie_len, NULL, NULL))
+				is_p2p_scan = 1;
+		}
+		_exit_critical_bh(&wdev_data->scan_req_lock, &irqL);
+
+		return is_p2p_scan;
+	}
+#endif
+}
+
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+int rtw_pd_iface_alloc(struct wiphy *wiphy, const char *name, struct wireless_dev **pd_wdev)
+{
+	struct rtw_wiphy_data *wiphy_data = rtw_wiphy_priv(wiphy);
+	struct wireless_dev *wdev = NULL;
+	struct rtw_netdev_priv_indicator *npi;
+	_adapter *primary_adpt = wiphy_to_adapter(wiphy);
+	int ret = 0;
+
+	if (wiphy_data->pd_wdev) {
+		RTW_WARN(FUNC_WIPHY_FMT" pd_wdev already exists\n", FUNC_WIPHY_ARG(wiphy));
+		ret = -EBUSY;
+		goto exit;
+	}
+
+	wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
+	if (!wdev) {
+		RTW_WARN(FUNC_WIPHY_FMT" allocate wdev fail\n", FUNC_WIPHY_ARG(wiphy));
+		ret = -ENOMEM;
+		goto exit;
+	}
+
+	wdev->wiphy = wiphy;
+	wdev->iftype = NL80211_IFTYPE_P2P_DEVICE;
+	_rtw_memcpy(wdev->address, adapter_mac_addr(primary_adpt), ETH_ALEN);
+
+	wiphy_data->pd_wdev = wdev;
+	*pd_wdev = wdev;
+
+	RTW_INFO(FUNC_WIPHY_FMT" pd_wdev:%p, addr="MAC_FMT" added\n"
+		, FUNC_WIPHY_ARG(wiphy), wdev, MAC_ARG(wdev_address(wdev)));
+
+exit:
+	if (ret && wdev) {
+		rtw_mfree((u8 *)wdev, sizeof(struct wireless_dev));
+		wdev = NULL;
+	}
+
+	return ret;
+}
+
+void rtw_pd_iface_free(struct wiphy *wiphy)
+{
+	struct dvobj_priv *dvobj = wiphy_to_dvobj(wiphy);
+	struct rtw_wiphy_data *wiphy_data = rtw_wiphy_priv(wiphy);
+	u8 rtnl_lock_needed;
+
+	if (!wiphy_data->pd_wdev)
+		goto exit;
+
+	RTW_INFO(FUNC_WIPHY_FMT" pd_wdev:%p, addr="MAC_FMT"\n"
+		, FUNC_WIPHY_ARG(wiphy), wiphy_data->pd_wdev
+		, MAC_ARG(wdev_address(wiphy_data->pd_wdev)));
+
+	rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+	if (rtnl_lock_needed)
+		rtnl_lock();
+	cfg80211_unregister_wdev(wiphy_data->pd_wdev);
+	if (rtnl_lock_needed)
+		rtnl_unlock();
+
+	rtw_mfree((u8 *)wiphy_data->pd_wdev, sizeof(struct wireless_dev));
+	wiphy_data->pd_wdev = NULL;
+
+exit:
+	return;
+}
+
+static int cfg80211_rtw_start_p2p_device(struct wiphy *wiphy, struct wireless_dev *wdev)
+{
+	_adapter *adapter = wiphy_to_adapter(wiphy);
+
+	RTW_INFO(FUNC_WIPHY_FMT" wdev=%p\n", FUNC_WIPHY_ARG(wiphy), wdev);
+
+	rtw_p2p_enable(adapter, P2P_ROLE_DEVICE);
+	return 0;
+}
+
+static void cfg80211_rtw_stop_p2p_device(struct wiphy *wiphy, struct wireless_dev *wdev)
+{
+	_adapter *adapter = wiphy_to_adapter(wiphy);
+
+	RTW_INFO(FUNC_WIPHY_FMT" wdev=%p\n", FUNC_WIPHY_ARG(wiphy), wdev);
+
+	if (rtw_cfg80211_is_p2p_scan(adapter))
+		rtw_scan_abort(adapter);
+
+	rtw_p2p_enable(adapter, P2P_ROLE_DISABLE);
+}
+
+inline int rtw_cfg80211_redirect_pd_wdev(struct wiphy *wiphy, u8 *ra, struct wireless_dev **wdev)
+{
+	struct wireless_dev *pd_wdev = wiphy_to_pd_wdev(wiphy);
+
+	if (pd_wdev && pd_wdev != *wdev
+		&& _rtw_memcmp(wdev_address(pd_wdev), ra, ETH_ALEN) == _TRUE
+	) {
+		*wdev = pd_wdev;
+		return 1;
+	}
+	return 0;
+}
+
+inline int rtw_cfg80211_is_scan_by_pd_wdev(_adapter *adapter)
+{
+	struct wiphy *wiphy = adapter_to_wiphy(adapter);
+	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(adapter);
+	struct wireless_dev *wdev = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&wdev_data->scan_req_lock, &irqL);
+	if (wdev_data->scan_request)
+		wdev = wdev_data->scan_request->wdev;
+	_exit_critical_bh(&wdev_data->scan_req_lock, &irqL);
+
+	if (wdev && wdev == wiphy_to_pd_wdev(wiphy))
+		return 1;
+
+	return 0;
+}
+#endif /* RTW_DEDICATED_P2P_DEVICE */
+#endif /* CONFIG_P2P */
+
+inline void rtw_cfg80211_set_is_mgmt_tx(_adapter *adapter, u8 val)
+{
+	struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+
+	wdev_priv->is_mgmt_tx = val;
+	rtw_mi_update_iface_status(&(adapter->mlmepriv), 0);
+}
+
+inline u8 rtw_cfg80211_get_is_mgmt_tx(_adapter *adapter)
+{
+	struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+
+	return wdev_priv->is_mgmt_tx;
+}
+
+static int _cfg80211_rtw_mgmt_tx(_adapter *padapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack)
+{
+	struct xmit_frame	*pmgntframe;
+	struct pkt_attrib	*pattrib;
+	unsigned char	*pframe;
+	int ret = _FAIL;
+	bool ack = _TRUE;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	u8 u_ch = rtw_mi_get_union_chan(padapter);
+	u8 leave_op = 0;
+#ifdef CONFIG_P2P
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif
+
+	rtw_cfg80211_set_is_mgmt_tx(padapter, 1);
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_ScanNotify(padapter, _TRUE);
+#endif
+
+#ifdef CONFIG_P2P
+	if (rtw_cfg80211_get_is_roch(padapter) == _TRUE) {
+		#ifdef CONFIG_CONCURRENT_MODE
+		if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
+			RTW_INFO("%s, extend ro ch time\n", __func__);
+			_set_timer(&padapter->cfg80211_wdinfo.remain_on_ch_timer, pwdinfo->ext_listen_period);
+		}
+		#endif /* CONFIG_CONCURRENT_MODE */
+	}
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+			/* don't set channel, issue frame directly */
+			goto issue_mgmt_frame;
+	}
+#endif /* CONFIG_MCC_MODE */
+
+	if (rtw_mi_check_status(padapter, MI_LINKED)
+		&& tx_ch != u_ch
+	) {
+		rtw_leave_opch(padapter);
+		leave_op = 1;
+
+		#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_P2P) && defined(CONFIG_CONCURRENT_MODE)
+		if (rtw_cfg80211_get_is_roch(padapter)
+			&& ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1
+		) {
+			u16 ext_listen_period;
+
+			if (check_fwstate(&padapter->mlmepriv, _FW_LINKED))
+				ext_listen_period = 500;
+			else
+				ext_listen_period = pwdinfo->ext_listen_period;
+			ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
+			_set_timer(&pwdinfo->ap_p2p_switch_timer, ext_listen_period);
+			RTW_INFO("%s, set switch ch timer, period=%d\n", __func__, ext_listen_period);
+		}
+		#endif /* RTW_ROCH_BACK_OP && CONFIG_P2P && CONFIG_CONCURRENT_MODE */
+	}
+
+	if (tx_ch != rtw_get_oper_ch(padapter))
+		set_channel_bwmode(padapter, tx_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+
+issue_mgmt_frame:
+	/* starting alloc mgmt frame to dump it */
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		/* ret = -ENOMEM; */
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* update attribute */
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(padapter, pattrib);
+
+	if (no_cck && IS_CCK_RATE(pattrib->rate)) {
+		/* force OFDM 6M rate*/
+		pattrib->rate = MGN_6M;
+		pattrib->raid = rtw_get_mgntframe_raid(padapter, WIRELESS_11G);
+	}
+
+	pattrib->retry_ctrl = _FALSE;
+
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+
+	_rtw_memcpy(pframe, (void *)buf, len);
+	pattrib->pktlen = len;
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	/* update seq number */
+	pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
+	pattrib->seqnum = pmlmeext->mgnt_seq;
+	pmlmeext->mgnt_seq++;
+
+#ifdef CONFIG_P2P
+	rtw_xframe_chk_wfd_ie(pmgntframe);
+#endif /* CONFIG_P2P */
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	if (wait_ack) {
+		if (dump_mgntframe_and_wait_ack(padapter, pmgntframe) != _SUCCESS) {
+			ack = _FALSE;
+			ret = _FAIL;
+
+#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s, ack == _FAIL\n", __func__);
+#endif
+		} else {
+
+#ifdef CONFIG_XMIT_ACK
+			if (!MLME_IS_MESH(padapter)) /* TODO: remove this sleep for all mode */
+				rtw_msleep_os(50);
+#endif
+#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("%s, ack=%d, ok!\n", __func__, ack);
+#endif
+			ret = _SUCCESS;
+		}
+	} else {
+		dump_mgntframe(padapter, pmgntframe);
+		ret = _SUCCESS;
+	}
+
+exit:
+	#ifdef CONFIG_P2P
+	if (rtw_cfg80211_get_is_roch(padapter)
+		&& !roch_stay_in_cur_chan(padapter)
+		&& pcfg80211_wdinfo->remain_on_ch_channel.hw_value != u_ch
+	) {
+		/* roch is ongoing, switch back to rch */
+		if (pcfg80211_wdinfo->remain_on_ch_channel.hw_value != tx_ch)
+			set_channel_bwmode(padapter, pcfg80211_wdinfo->remain_on_ch_channel.hw_value
+				, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+	} else
+	#endif
+	if (leave_op) {
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 u_bw = rtw_mi_get_union_bw(padapter);
+			u8 u_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, u_ch, u_offset, u_bw);
+		}
+		rtw_back_opch(padapter);
+	}
+
+	rtw_cfg80211_set_is_mgmt_tx(padapter, 0);
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_ScanNotify(padapter, _FALSE);
+#endif
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ret=%d\n", __func__, ret);
+#endif
+
+	return ret;
+
+}
+
+u8 rtw_mgnt_tx_handler(_adapter *adapter, u8 *buf)
+{
+	u8 rst = H2C_CMD_FAIL;
+	struct mgnt_tx_parm *mgnt_parm = (struct mgnt_tx_parm *)buf;
+
+	if (_cfg80211_rtw_mgmt_tx(adapter, mgnt_parm->tx_ch, mgnt_parm->no_cck,
+		mgnt_parm->buf, mgnt_parm->len, mgnt_parm->wait_ack) == _SUCCESS)
+		rst = H2C_SUCCESS;
+
+	return rst;
+}
+
+static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0)) || defined(COMPAT_KERNEL_RELEASE)
+	struct ieee80211_channel *chan,
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	bool offchan,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	enum nl80211_channel_type channel_type,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+	bool channel_type_valid,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	unsigned int wait,
+	#endif
+	const u8 *buf, size_t len,
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	bool no_cck,
+	#endif
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	bool dont_wait_for_ack,
+	#endif
+#else
+	struct cfg80211_mgmt_tx_params *params,
+#endif
+	u64 *cookie)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(COMPAT_KERNEL_RELEASE)
+	struct ieee80211_channel *chan = params->chan;
+	bool offchan = params->offchan;
+	unsigned int wait = params->wait;
+	const u8 *buf = params->buf;
+	size_t len = params->len;
+	bool no_cck = params->no_cck;
+	bool dont_wait_for_ack = params->dont_wait_for_ack;
+#endif
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 2, 0))
+	bool no_cck = 0;
+#endif
+	int ret = 0;
+	u8 tx_ret;
+	int wait_ack = 1;
+	const u8 *dump_buf = buf;
+	size_t dump_len = len;
+	u32 dump_limit = RTW_MAX_MGMT_TX_CNT;
+	u32 dump_cnt = 0;
+	u32 sleep_ms = 0;
+	u32 retry_guarantee_ms = 0;
+	bool ack = _TRUE;
+	u8 tx_ch;
+	u8 category, action;
+	u8 frame_styp;
+#ifdef CONFIG_P2P
+	u8 is_p2p = 0;
+#endif
+	int type = (-1);
+	systime start = rtw_get_current_time();
+	_adapter *padapter;
+	struct dvobj_priv *dvobj;
+	struct rtw_wdev_priv *pwdev_priv;
+	struct rf_ctl_t *rfctl;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	if (wdev == wiphy_to_pd_wdev(wiphy))
+		padapter = wiphy_to_adapter(wiphy);
+	else
+	#endif
+	if (wdev_to_ndev(wdev))
+		padapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+	else {
+		ret = -EINVAL;
+		goto exit;
+	}
+#else
+	struct wireless_dev *wdev;
+
+	if (ndev == NULL) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	padapter = (_adapter *)rtw_netdev_priv(ndev);
+	wdev = ndev_to_wdev(ndev);
+#endif
+
+	if (chan == NULL) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	rfctl = adapter_to_rfctl(padapter);
+	tx_ch = (u8)ieee80211_frequency_to_channel(chan->center_freq);
+	if (IS_CH_WAITING(rfctl)) {
+		#ifdef CONFIG_DFS_MASTER
+		if (_rtw_rfctl_overlap_radar_detect_ch(rfctl, tx_ch, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+		#endif
+	}
+
+	dvobj = adapter_to_dvobj(padapter);
+	pwdev_priv = adapter_wdev_data(padapter);
+
+	/* cookie generation */
+	*cookie = pwdev_priv->mgmt_tx_cookie++;
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO(FUNC_ADPT_FMT"%s len=%zu, ch=%d"
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		", ch_type=%d"
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		", channel_type_valid=%d"
+		#endif
+		"\n", FUNC_ADPT_ARG(padapter), wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : ""
+		, len, tx_ch
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		, channel_type
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34)) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+		, channel_type_valid
+		#endif
+	);
+#endif /* CONFIG_DEBUG_CFG80211 */
+
+	/* indicate ack before issue frame to avoid racing with rsp frame */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_mgmt_tx_status(wdev, *cookie, buf, len, ack, GFP_KERNEL);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 36))
+	cfg80211_action_tx_status(ndev, *cookie, buf, len, ack, GFP_KERNEL);
+#endif
+
+	frame_styp = le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl) & IEEE80211_FCTL_STYPE;
+	if (IEEE80211_STYPE_PROBE_RESP == frame_styp) {
+#ifdef CONFIG_DEBUG_CFG80211
+		RTW_INFO("RTW_Tx: probe_resp tx_ch=%d, no_cck=%u, da="MAC_FMT"\n", tx_ch, no_cck, MAC_ARG(GetAddr1Ptr(buf)));
+#endif /* CONFIG_DEBUG_CFG80211 */
+		wait_ack = 0;
+		goto dump;
+	}
+#ifdef CONFIG_RTW_MESH
+	else if (frame_styp == RTW_IEEE80211_STYPE_AUTH) {
+		RTW_INFO("RTW_Tx:tx_ch=%d, no_cck=%u, da="MAC_FMT"\n", tx_ch, no_cck, MAC_ARG(GetAddr1Ptr(buf)));
+		if (!rtw_sae_check_frames(padapter, buf, len, _TRUE))
+			RTW_INFO("RTW_Tx:AUTH\n");
+		dump_limit = 1;
+		goto dump;
+	}
+#endif
+
+	if (rtw_action_frame_parse(buf, len, &category, &action) == _FALSE) {
+		RTW_INFO(FUNC_ADPT_FMT" frame_control:0x%02x\n", FUNC_ADPT_ARG(padapter),
+			le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)buf)->frame_ctl));
+		goto exit;
+	}
+
+	RTW_INFO("RTW_Tx:tx_ch=%d, no_cck=%u, da="MAC_FMT"\n", tx_ch, no_cck, MAC_ARG(GetAddr1Ptr(buf)));
+#ifdef CONFIG_P2P
+	type = rtw_p2p_check_frames(padapter, buf, len, _TRUE);
+	if (type >= 0) {
+		is_p2p = 1;
+		no_cck = 1; /* force no CCK for P2P frames */
+		goto dump;
+	}
+#endif
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		type = rtw_mesh_check_frames_tx(padapter, &dump_buf, &dump_len);
+		if (type >= 0) {
+			dump_limit = 1;
+			goto dump;
+		}
+	}
+#endif
+	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
+		RTW_INFO("RTW_Tx:%s\n", action_public_str(action));
+		switch (action) {
+		case ACT_PUBLIC_GAS_INITIAL_REQ:
+		case ACT_PUBLIC_GAS_INITIAL_RSP:
+			sleep_ms = 50;
+			retry_guarantee_ms = RTW_MAX_MGMT_TX_MS_GAS;
+			break;
+		}
+	}
+#ifdef CONFIG_RTW_80211K
+	else if (category == RTW_WLAN_CATEGORY_RADIO_MEAS)
+		RTW_INFO("RTW_Tx: RRM Action\n");
+#endif
+	else
+		RTW_INFO("RTW_Tx:category(%u), action(%u)\n", category, action);
+
+dump:
+
+	rtw_ps_deny(padapter, PS_DENY_MGNT_TX);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EFAULT;
+		goto cancel_ps_deny;
+	}
+
+	while (1) {
+		dump_cnt++;
+
+		rtw_mi_set_scan_deny(padapter, 1000);
+		rtw_mi_scan_abort(padapter, _TRUE);
+		tx_ret = rtw_mgnt_tx_cmd(padapter, tx_ch, no_cck, dump_buf, dump_len, wait_ack, RTW_CMDF_WAIT_ACK);
+		if (tx_ret == _SUCCESS
+			|| (dump_cnt >= dump_limit && rtw_get_passing_time_ms(start) >= retry_guarantee_ms))
+			break;
+
+		if (sleep_ms > 0)
+			rtw_msleep_os(sleep_ms);
+	}
+
+	if (tx_ret != _SUCCESS || dump_cnt > 1) {
+		RTW_INFO(FUNC_ADPT_FMT" %s (%d/%d) in %d ms\n", FUNC_ADPT_ARG(padapter),
+			tx_ret == _SUCCESS ? "OK" : "FAIL", dump_cnt, dump_limit, rtw_get_passing_time_ms(start));
+	}
+
+#ifdef CONFIG_P2P
+	if (is_p2p) {
+		switch (type) {
+		case P2P_GO_NEGO_CONF:
+			if (0) {
+				RTW_INFO(FUNC_ADPT_FMT" Nego confirm. state=%u, status=%u, iaddr="MAC_FMT"\n"
+					, FUNC_ADPT_ARG(padapter), pwdev_priv->nego_info.state, pwdev_priv->nego_info.status
+					, MAC_ARG(pwdev_priv->nego_info.iface_addr));
+			}
+			if (pwdev_priv->nego_info.state == 2
+				&& pwdev_priv->nego_info.status == 0
+				&& rtw_check_invalid_mac_address(pwdev_priv->nego_info.iface_addr, _FALSE) == _FALSE
+			) {
+				_adapter *intended_iface = dvobj_get_adapter_by_addr(dvobj, pwdev_priv->nego_info.iface_addr);
+
+				if (intended_iface) {
+					RTW_INFO(FUNC_ADPT_FMT" Nego confirm. Allow only "ADPT_FMT" to scan for 2000 ms\n"
+						, FUNC_ADPT_ARG(padapter), ADPT_ARG(intended_iface));
+					/* allow only intended_iface to do scan for 2000 ms */
+					rtw_mi_set_scan_deny(padapter, 2000);
+					rtw_clear_scan_deny(intended_iface);
+				}
+			}
+			break;
+		case P2P_INVIT_RESP:
+			if (pwdev_priv->invit_info.flags & BIT(0)
+				&& pwdev_priv->invit_info.status == 0
+			) {
+				RTW_INFO(FUNC_ADPT_FMT" agree with invitation of persistent group\n",
+					FUNC_ADPT_ARG(padapter));
+				#if !RTW_P2P_GROUP_INTERFACE
+				rtw_mi_buddy_set_scan_deny(padapter, 5000);
+				#endif
+				rtw_pwr_wakeup_ex(padapter, 5000);
+			}
+			break;
+		}
+	}
+#endif /* CONFIG_P2P */
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_MGNT_TX);
+
+	if (dump_buf != buf)
+		rtw_mfree((u8 *)dump_buf, dump_len);
+exit:
+	return ret;
+}
+
+static void cfg80211_rtw_mgmt_frame_register(struct wiphy *wiphy,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct wireless_dev *wdev,
+#else
+	struct net_device *ndev,
+#endif
+	u16 frame_type, bool reg)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	struct net_device *ndev = wdev_to_ndev(wdev);
+#endif
+	_adapter *adapter;
+
+	struct rtw_wdev_priv *pwdev_priv;
+
+	if (ndev == NULL)
+		goto exit;
+
+	adapter = (_adapter *)rtw_netdev_priv(ndev);
+	pwdev_priv = adapter_wdev_data(adapter);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO(FUNC_ADPT_FMT" frame_type:%x, reg:%d\n", FUNC_ADPT_ARG(adapter),
+		frame_type, reg);
+#endif
+
+	/* Wait QC Verify */
+	return;
+
+	switch (frame_type) {
+	case IEEE80211_STYPE_PROBE_REQ: /* 0x0040 */
+		SET_CFG80211_REPORT_MGMT(pwdev_priv, IEEE80211_STYPE_PROBE_REQ, reg);
+		break;
+	case IEEE80211_STYPE_ACTION: /* 0x00D0 */
+		SET_CFG80211_REPORT_MGMT(pwdev_priv, IEEE80211_STYPE_ACTION, reg);
+		break;
+	default:
+		break;
+	}
+
+exit:
+	return;
+}
+
+#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+static int cfg80211_rtw_tdls_mgmt(struct wiphy *wiphy,
+	struct net_device *ndev,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	const u8 *peer,
+#else
+	u8 *peer,
+#endif
+	u8 action_code,
+	u8 dialog_token,
+	u16 status_code,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	u32 peer_capability,
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 17, 0))
+	bool initiator,
+#endif
+	const u8 *buf,
+	size_t len)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &pmlmeext->mlmext_info;
+	int ret = 0;
+	struct tdls_txmgmt txmgmt;
+
+	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
+		RTW_INFO("Discard tdls action:%d, since hal doesn't support tdls\n", action_code);
+		goto discard;
+	}
+
+	if (rtw_is_tdls_enabled(padapter) == _FALSE) {
+		RTW_INFO("TDLS is not enabled\n");
+		goto discard;
+	}
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		RTW_INFO("Discard tdls action:%d, let driver to set up direct link\n", action_code);
+		goto discard;
+	}
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	_rtw_memcpy(txmgmt.peer, peer, ETH_ALEN);
+	txmgmt.action_code = action_code;
+	txmgmt.dialog_token = dialog_token;
+	txmgmt.status_code = status_code;
+	txmgmt.len = len;
+	txmgmt.buf = (u8 *)rtw_malloc(txmgmt.len);
+	if (txmgmt.buf == NULL) {
+		ret = -ENOMEM;
+		goto bad;
+	}
+	_rtw_memcpy(txmgmt.buf, (void *)buf, txmgmt.len);
+
+	/* Debug purpose */
+#if 1
+	RTW_INFO("%s %d\n", __FUNCTION__, __LINE__);
+	RTW_INFO("peer:"MAC_FMT", action code:%d, dialog:%d, status code:%d\n",
+		MAC_ARG(txmgmt.peer), txmgmt.action_code,
+		txmgmt.dialog_token, txmgmt.status_code);
+	if (txmgmt.len > 0) {
+		int i = 0;
+		for (; i < len; i++)
+			printk("%02x ", *(txmgmt.buf + i));
+		RTW_INFO("len:%d\n", (u32)txmgmt.len);
+	}
+#endif
+
+	switch (txmgmt.action_code) {
+	case TDLS_SETUP_REQUEST:
+		issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+		break;
+	case TDLS_SETUP_RESPONSE:
+		issue_tdls_setup_rsp(padapter, &txmgmt);
+		break;
+	case TDLS_SETUP_CONFIRM:
+		issue_tdls_setup_cfm(padapter, &txmgmt);
+		break;
+	case TDLS_TEARDOWN:
+		issue_tdls_teardown(padapter, &txmgmt, _TRUE);
+		break;
+	case TDLS_DISCOVERY_REQUEST:
+		issue_tdls_dis_req(padapter, &txmgmt);
+		break;
+	case TDLS_DISCOVERY_RESPONSE:
+		issue_tdls_dis_rsp(padapter, &txmgmt, pmlmeinfo->enc_algo ? _TRUE : _FALSE);
+		break;
+	}
+
+bad:
+	if (txmgmt.buf)
+		rtw_mfree(txmgmt.buf, txmgmt.len);
+
+discard:
+	return ret;
+}
+
+static int cfg80211_rtw_tdls_oper(struct wiphy *wiphy,
+	struct net_device *ndev,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	const u8 *peer,
+#else
+	u8 *peer,
+#endif
+	enum nl80211_tdls_operation oper)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct tdls_txmgmt	txmgmt;
+	struct sta_info *ptdls_sta = NULL;
+
+	RTW_INFO(FUNC_NDEV_FMT", nl80211_tdls_operation:%d\n", FUNC_NDEV_ARG(ndev), oper);
+
+	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
+		RTW_INFO("Discard tdls oper:%d, since hal doesn't support tdls\n", oper);
+		return 0;
+	}
+
+	if (rtw_is_tdls_enabled(padapter) == _FALSE) {
+		RTW_INFO("TDLS is not enabled\n");
+		return 0;
+	}
+
+#ifdef CONFIG_LPS
+	rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1);
+#endif /* CONFIG_LPS */
+
+	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
+	if (peer)
+		_rtw_memcpy(txmgmt.peer, peer, ETH_ALEN);
+
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		/* these two cases are done by driver itself */
+		if (oper == NL80211_TDLS_ENABLE_LINK || oper == NL80211_TDLS_DISABLE_LINK)
+			return 0;
+	}
+
+	switch (oper) {
+	case NL80211_TDLS_DISCOVERY_REQ:
+		issue_tdls_dis_req(padapter, &txmgmt);
+		break;
+	case NL80211_TDLS_SETUP:
+#ifdef CONFIG_WFD
+		if (_AES_ != padapter->securitypriv.dot11PrivacyAlgrthm) {
+			if (padapter->wdinfo.wfd_tdls_weaksec == _TRUE)
+				issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+			else
+				RTW_INFO("[%s] Current link is not AES, SKIP sending the tdls setup request!!\n", __FUNCTION__);
+		} else
+#endif /* CONFIG_WFD */
+		{
+			issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
+		}
+		break;
+	case NL80211_TDLS_TEARDOWN:
+		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), txmgmt.peer);
+		if (ptdls_sta != NULL) {
+			txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
+			issue_tdls_teardown(padapter, &txmgmt, _TRUE);
+		} else
+			RTW_INFO("TDLS peer not found\n");
+		break;
+	case NL80211_TDLS_ENABLE_LINK:
+		RTW_INFO(FUNC_NDEV_FMT", NL80211_TDLS_ENABLE_LINK;mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(peer));
+		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), (u8 *)peer);
+		if (ptdls_sta != NULL) {
+			rtw_tdls_set_link_established(padapter, _TRUE);
+			ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
+			ptdls_sta->state |= _FW_LINKED;
+			rtw_tdls_cmd(padapter, txmgmt.peer, TDLS_ESTABLISHED);
+		}
+		break;
+	case NL80211_TDLS_DISABLE_LINK:
+		RTW_INFO(FUNC_NDEV_FMT", NL80211_TDLS_DISABLE_LINK;mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(peer));
+		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), (u8 *)peer);
+		if (ptdls_sta != NULL) {
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+			rtw_tdls_cmd(padapter, (u8 *)peer, TDLS_TEARDOWN_STA_LOCALLY_POST);
+		}
+		break;
+	}
+	return 0;
+}
+#endif /* CONFIG_TDLS */
+
+#if defined(CONFIG_RTW_MESH) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38))
+
+#if DBG_RTW_CFG80211_MESH_CONF
+#define LEGACY_RATES_STR_LEN (RTW_G_RATES_NUM * 5 + 1)
+int get_legacy_rates_str(struct wiphy *wiphy, enum nl80211_band band, u32 mask, char *buf)
+{
+	int i;
+	int cnt = 0;
+
+	for (i = 0; i < wiphy->bands[band]->n_bitrates; i++) {
+		if (mask & BIT(i)) {
+			cnt += snprintf(buf + cnt, LEGACY_RATES_STR_LEN - cnt -1, "%d.%d "
+				, wiphy->bands[band]->bitrates[i].bitrate / 10
+				, wiphy->bands[band]->bitrates[i].bitrate % 10);
+			if (cnt >= LEGACY_RATES_STR_LEN - 1)
+				break;
+		}
+	}
+
+	return cnt;
+}
+
+void dump_mesh_setup(void *sel, struct wiphy *wiphy, const struct mesh_setup *setup)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *chdef = (struct cfg80211_chan_def *)(&setup->chandef);
+#endif
+	struct ieee80211_channel *chan;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	chan = (struct ieee80211_channel *)chdef->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	chan = (struct ieee80211_channel *)setup->channel;
+#endif
+
+	RTW_PRINT_SEL(sel, "mesh_id:\"%s\", len:%u\n", setup->mesh_id, setup->mesh_id_len);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "sync_method:%u\n", setup->sync_method);
+#endif
+	RTW_PRINT_SEL(sel, "path_sel_proto:%u, path_metric:%u\n", setup->path_sel_proto, setup->path_metric);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	RTW_PRINT_SEL(sel, "auth_id:%u\n", setup->auth_id);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	if (setup->ie && setup->ie_len) {
+		RTW_PRINT_SEL(sel, "ie:%p, len:%u\n", setup->ie, setup->ie_len);
+		dump_ies(RTW_DBGDUMP, setup->ie, setup->ie_len);
+	}
+#else
+	if (setup->vendor_ie && setup->vendor_ie_len) {
+		RTW_PRINT_SEL(sel, "ie:%p, len:%u\n", setup->vendor_ie, setup->vendor_ie_len);
+		dump_ies(RTW_DBGDUMP, setup->vendor_ie, setup->vendor_ie_len);
+	}
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	RTW_PRINT_SEL(sel, "is_authenticated:%d, is_secure:%d\n", setup->is_authenticated, setup->is_secure);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	RTW_PRINT_SEL(sel, "user_mpm:%d\n", setup->user_mpm);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	RTW_PRINT_SEL(sel, "dtim_period:%u, beacon_interval:%u\n", setup->dtim_period, setup->beacon_interval);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	RTW_PRINT_SEL(sel, "center_freq:%u, ch:%u, width:%s, cfreq1:%u, cfreq2:%u\n"
+		, chan->center_freq, chan->hw_value, nl80211_chan_width_str(chdef->width), chdef->center_freq1, chdef->center_freq2);
+#else
+	RTW_PRINT_SEL(sel, "center_freq:%u, ch:%u, channel_type:%s\n"
+		, chan->center_freq, chan->hw_value, nl80211_channel_type_str(setup->channel_type));
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	if (setup->mcast_rate[chan->band]) {
+		RTW_PRINT_SEL(sel, "mcast_rate:%d.%d\n"
+			, wiphy->bands[chan->band]->bitrates[setup->mcast_rate[chan->band] - 1].bitrate / 10
+			, wiphy->bands[chan->band]->bitrates[setup->mcast_rate[chan->band] - 1].bitrate % 10
+		);
+	}
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (setup->basic_rates) {
+		char buf[LEGACY_RATES_STR_LEN] = {0};
+
+		get_legacy_rates_str(wiphy, chan->band, setup->basic_rates, buf);
+		RTW_PRINT_SEL(sel, "basic_rates:%s\n", buf);
+	}
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 9, 0))
+	if (setup->beacon_rate.control[chan->band].legacy) {
+		char buf[LEGACY_RATES_STR_LEN] = {0};
+
+		get_legacy_rates_str(wiphy, chan->band, setup->beacon_rate.control[chan->band].legacy, buf);
+		RTW_PRINT_SEL(sel, "beacon_rate.legacy:%s\n", buf);
+	}
+	if (*((u32 *)&(setup->beacon_rate.control[chan->band].ht_mcs[0]))
+		|| *((u32 *)&(setup->beacon_rate.control[chan->band].ht_mcs[4]))
+		|| *((u16 *)&(setup->beacon_rate.control[chan->band].ht_mcs[8]))
+	) {
+		RTW_PRINT_SEL(sel, "beacon_rate.ht_mcs:"HT_RX_MCS_BMP_FMT"\n"
+			, HT_RX_MCS_BMP_ARG(setup->beacon_rate.control[chan->band].ht_mcs));
+	}
+
+	if (setup->beacon_rate.control[chan->band].vht_mcs[0]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[1]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[2]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[3]
+	) {
+		int i;
+
+		for (i = 0; i < 4; i++) {/* parsing up to 4SS */
+			u16 mcs_mask = setup->beacon_rate.control[chan->band].vht_mcs[i];
+
+			RTW_PRINT_SEL(sel, "beacon_rate.vht_mcs[%d]:%s\n", i
+				, mcs_mask == 0x00FF ? "0~7" : mcs_mask == 0x01FF ? "0~8" : mcs_mask == 0x03FF ? "0~9" : "invalid");
+		}
+	}
+
+	if (setup->beacon_rate.control[chan->band].gi) {
+		RTW_PRINT_SEL(sel, "beacon_rate.gi:%s\n"
+			, setup->beacon_rate.control[chan->band].gi == NL80211_TXRATE_FORCE_SGI ? "SGI" :
+				setup->beacon_rate.control[chan->band].gi == NL80211_TXRATE_FORCE_LGI ? "LGI" : "invalid"
+		);
+	}
+#endif
+}
+
+void dump_mesh_config(void *sel, const struct mesh_config *conf)
+{
+	RTW_PRINT_SEL(sel, "dot11MeshRetryTimeout:%u\n", conf->dot11MeshRetryTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshConfirmTimeout:%u\n", conf->dot11MeshConfirmTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHoldingTimeout:%u\n", conf->dot11MeshHoldingTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshMaxPeerLinks:%u\n", conf->dot11MeshMaxPeerLinks);
+	RTW_PRINT_SEL(sel, "dot11MeshMaxRetries:%u\n", conf->dot11MeshMaxRetries);
+	RTW_PRINT_SEL(sel, "dot11MeshTTL:%u\n", conf->dot11MeshTTL);
+	RTW_PRINT_SEL(sel, "element_ttl:%u\n", conf->element_ttl);
+	RTW_PRINT_SEL(sel, "auto_open_plinks:%d\n", conf->auto_open_plinks);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshNbrOffsetMaxNeighbor:%u\n", conf->dot11MeshNbrOffsetMaxNeighbor);
+#endif
+
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPmaxPREQretries:%u\n", conf->dot11MeshHWMPmaxPREQretries);
+	RTW_PRINT_SEL(sel, "path_refresh_time:%u\n", conf->path_refresh_time);
+	RTW_PRINT_SEL(sel, "min_discovery_timeout:%u\n", conf->min_discovery_timeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPactivePathTimeout:%u\n", conf->dot11MeshHWMPactivePathTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPpreqMinInterval:%u\n", conf->dot11MeshHWMPpreqMinInterval);	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPperrMinInterval:%u\n", conf->dot11MeshHWMPperrMinInterval);
+#endif
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPnetDiameterTraversalTime:%u\n", conf->dot11MeshHWMPnetDiameterTraversalTime);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPRootMode:%u\n", conf->dot11MeshHWMPRootMode);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPRannInterval:%u\n", conf->dot11MeshHWMPRannInterval);
+	RTW_PRINT_SEL(sel, "dot11MeshGateAnnouncementProtocol:%d\n", conf->dot11MeshGateAnnouncementProtocol);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshForwarding:%d\n", conf->dot11MeshForwarding);
+	RTW_PRINT_SEL(sel, "rssi_threshold:%d\n", conf->rssi_threshold);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "ht_opmode:0x%04x\n", conf->ht_opmode);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPactivePathToRootTimeout:%u\n", conf->dot11MeshHWMPactivePathToRootTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMProotInterval:%u\n", conf->dot11MeshHWMProotInterval);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPconfirmationInterval:%u\n", conf->dot11MeshHWMPconfirmationInterval);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	RTW_PRINT_SEL(sel, "power_mode:%s\n", nl80211_mesh_power_mode_str(conf->power_mode));
+	RTW_PRINT_SEL(sel, "dot11MeshAwakeWindowDuration:%u\n", conf->dot11MeshAwakeWindowDuration);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	RTW_PRINT_SEL(sel, "plink_timeout:%u\n", conf->plink_timeout);
+#endif
+}
+#endif /* DBG_RTW_CFG80211_MESH_CONF */
+
+static void rtw_cfg80211_mesh_info_set_profile(struct rtw_mesh_info *minfo, const struct mesh_setup *setup)
+{
+	_rtw_memcpy(minfo->mesh_id, setup->mesh_id, setup->mesh_id_len);
+	minfo->mesh_id_len = setup->mesh_id_len;
+	minfo->mesh_pp_id = setup->path_sel_proto;
+	minfo->mesh_pm_id = setup->path_metric;
+	minfo->mesh_cc_id = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	minfo->mesh_sp_id = setup->sync_method;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	minfo->mesh_auth_id = setup->auth_id;
+#else
+	if (setup->is_authenticated) {
+		u8 *rsn_ie;
+		sint rsn_ie_len;
+		struct rsne_info info;
+		u8 *akm;
+		u8 AKM_SUITE_SAE[4] = {0x00, 0x0F, 0xAC, 0x08};
+
+		rsn_ie = rtw_get_ie(setup->ie, WLAN_EID_RSN, &rsn_ie_len, setup->ie_len);
+		if (!rsn_ie || !rsn_ie_len) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		if (rtw_rsne_info_parse(rsn_ie, rsn_ie_len + 2, &info) != _SUCCESS) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		if (!info.akm_list || !info.akm_cnt) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		akm = info.akm_list;
+		while (akm < info.akm_list + info.akm_cnt * 4) {
+			if (_rtw_memcmp(akm, AKM_SUITE_SAE, 4) == _TRUE) {
+				minfo->mesh_auth_id = 0x01;
+				break;
+			}
+		}
+
+		if (!minfo->mesh_auth_id) {
+			rtw_warn_on(1);
+			return;
+		}
+	}
+#endif
+}
+
+static inline bool chk_mesh_attr(enum nl80211_meshconf_params parm, u32 mask)
+{
+	return (mask >> (parm - 1)) & 0x1;
+}
+
+static void rtw_cfg80211_mesh_cfg_set(_adapter *adapter, const struct mesh_config *conf, u32 mask)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+#if 0 /* driver MPM */
+	if (chk_mesh_attr(NL80211_MESHCONF_RETRY_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_CONFIRM_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_HOLDING_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_MAX_PEER_LINKS, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_MAX_RETRIES, mask));
+#endif
+
+	if (chk_mesh_attr(NL80211_MESHCONF_TTL, mask))
+		mcfg->dot11MeshTTL = conf->dot11MeshTTL;
+	if (chk_mesh_attr(NL80211_MESHCONF_ELEMENT_TTL, mask))
+		mcfg->element_ttl = conf->element_ttl;
+
+#if 0 /* driver MPM */
+	if (chk_mesh_attr(NL80211_MESHCONF_AUTO_OPEN_PLINKS, mask));
+#endif
+
+#if 0 /* TBD: synchronization */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_SYNC_OFFSET_MAX_NEIGHBOR, mask));
+#endif
+#endif
+
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_MAX_PREQ_RETRIES, mask))
+		mcfg->dot11MeshHWMPmaxPREQretries = conf->dot11MeshHWMPmaxPREQretries;
+	if (chk_mesh_attr(NL80211_MESHCONF_PATH_REFRESH_TIME, mask))
+		mcfg->path_refresh_time = conf->path_refresh_time;
+	if (chk_mesh_attr(NL80211_MESHCONF_MIN_DISCOVERY_TIMEOUT, mask))
+		mcfg->min_discovery_timeout = conf->min_discovery_timeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ACTIVE_PATH_TIMEOUT, mask))
+		mcfg->dot11MeshHWMPactivePathTimeout = conf->dot11MeshHWMPactivePathTimeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PREQ_MIN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPpreqMinInterval = conf->dot11MeshHWMPpreqMinInterval;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PERR_MIN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPperrMinInterval = conf->dot11MeshHWMPperrMinInterval;
+#endif
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_NET_DIAM_TRVS_TIME, mask))
+		mcfg->dot11MeshHWMPnetDiameterTraversalTime = conf->dot11MeshHWMPnetDiameterTraversalTime;
+
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ROOTMODE, mask))
+		mcfg->dot11MeshHWMPRootMode = conf->dot11MeshHWMPRootMode;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_GATE_ANNOUNCEMENTS, mask))
+		mcfg->dot11MeshGateAnnouncementProtocol = conf->dot11MeshGateAnnouncementProtocol;
+	/* our current gate annc implementation rides on root annc with gate annc bit in PREQ flags */
+	if (mcfg->dot11MeshGateAnnouncementProtocol
+		&& mcfg->dot11MeshHWMPRootMode <= RTW_IEEE80211_ROOTMODE_ROOT
+	) {
+		mcfg->dot11MeshHWMPRootMode = RTW_IEEE80211_PROACTIVE_RANN;
+		RTW_INFO(ADPT_FMT" enable PROACTIVE_RANN becaue gate annc is needed\n", ADPT_ARG(adapter));
+	}
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_RANN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPRannInterval = conf->dot11MeshHWMPRannInterval;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_FORWARDING, mask))
+		mcfg->dot11MeshForwarding = conf->dot11MeshForwarding;
+
+	if (chk_mesh_attr(NL80211_MESHCONF_RSSI_THRESHOLD, mask))
+		mcfg->rssi_threshold = conf->rssi_threshold;
+#endif
+
+#if 0 /* controlled by driver */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HT_OPMODE, mask));
+#endif
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PATH_TO_ROOT_TIMEOUT, mask))
+		mcfg->dot11MeshHWMPactivePathToRootTimeout = conf->dot11MeshHWMPactivePathToRootTimeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ROOT_INTERVAL, mask))
+		mcfg->dot11MeshHWMProotInterval = conf->dot11MeshHWMProotInterval;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_CONFIRMATION_INTERVAL, mask))
+		mcfg->dot11MeshHWMPconfirmationInterval = conf->dot11MeshHWMPconfirmationInterval;	
+#endif
+
+#if 0 /* TBD */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_POWER_MODE, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_AWAKE_WINDOW, mask));
+#endif
+#endif
+
+#if 0 /* driver MPM */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_PLINK_TIMEOUT, mask));
+#endif
+#endif
+}
+
+u8 *rtw_cfg80211_construct_mesh_beacon_ies(struct wiphy *wiphy, _adapter *adapter
+	, const struct mesh_config *conf, const struct mesh_setup *setup
+	, uint *ies_len)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *chdef = (struct cfg80211_chan_def *)(&setup->chandef);
+#endif
+	struct ieee80211_channel *chan;
+	u8 ch, bw, offset;
+#endif
+	uint len;
+	u8 n_bitrates;
+	u8 ht = 0;
+	u8 vht = 0;
+	u8 *rsn_ie = NULL;
+	sint rsn_ie_len = 0;
+	u8 *ies = NULL, *c;
+	u8 supported_rates[RTW_G_RATES_NUM] = {0};
+	int i;
+
+	*ies_len = 0;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	chan = (struct ieee80211_channel *)chdef->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	chan = (struct ieee80211_channel *)setup->channel;
+#endif
+
+	n_bitrates = wiphy->bands[chan->band]->n_bitrates;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	rtw_get_chbw_from_cfg80211_chan_def(chdef, &ht, &ch, &bw, &offset);
+#else
+	rtw_get_chbw_from_nl80211_channel_type(chan, setup->channel_type, &ht, &ch, &bw, &offset);
+#endif
+	if (!ch)
+		goto exit;
+	
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	vht = ht && ch > 14 && bw >= CHANNEL_WIDTH_80; /* VHT40/VHT20? */
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT" => ch:%u,%u,%u, ht:%u, vht:%u\n"
+		, FUNC_ADPT_ARG(adapter), ch, bw, offset, ht, vht);
+#endif
+
+	rsn_ie = rtw_get_ie(setup->ie, WLAN_EID_RSN, &rsn_ie_len, setup->ie_len);
+	if (rsn_ie && !rsn_ie_len) {
+		rtw_warn_on(1);
+		rsn_ie = NULL;
+	}
+
+	len = _BEACON_IE_OFFSET_
+		+ 2 /* 0-length SSID */
+		+ (n_bitrates >= 8 ? 8 : n_bitrates) + 2 /* Supported Rates */
+		+ 3 /* DS parameter set */
+		+ 6 /* TIM  */
+		+ (n_bitrates > 8 ? n_bitrates - 8 + 2 : 0) /* Extended Supported Rates */
+		+ (rsn_ie ? rsn_ie_len + 2 : 0) /* RSN */
+		#if defined(CONFIG_80211N_HT)
+		+ (ht ? HT_CAP_IE_LEN + 2 + HT_OP_IE_LEN + 2 : 0) /* HT */
+		#endif
+		#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+		+ (vht ? VHT_CAP_IE_LEN + 2 + VHT_OP_IE_LEN + 2 : 0) /* VHT */
+		#endif
+		+ minfo->mesh_id_len + 2 /* Mesh ID */
+		+ 9 /* Mesh configuration */
+		;
+
+	ies = rtw_zmalloc(len);
+	if (!ies)
+		goto exit;
+
+	/* timestamp */
+	c = ies + 8;
+
+	/* beacon interval */
+	RTW_PUT_LE16(c , setup->beacon_interval);
+	c += 2;
+
+	/* capability */
+	if (rsn_ie)
+		*((u16 *)c) |= cpu_to_le16(cap_Privacy);
+	c += 2;
+
+	/* SSID */
+	c = rtw_set_ie(c, WLAN_EID_SSID, 0, NULL, NULL);
+
+	/* Supported Rates */
+	for (i = 0; i < n_bitrates; i++) {
+		supported_rates[i] = wiphy->bands[chan->band]->bitrates[i].bitrate / 5;
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+		if (setup->basic_rates & BIT(i))
+		#else
+		if (rtw_is_basic_rate_mix(supported_rates[i]))
+		#endif
+			supported_rates[i] |= IEEE80211_BASIC_RATE_MASK;
+	}
+	c = rtw_set_ie(c, WLAN_EID_SUPP_RATES, (n_bitrates >= 8 ? 8 : n_bitrates), supported_rates, NULL);
+
+	/* DS parameter set */
+	c = rtw_set_ie(c, WLAN_EID_DS_PARAMS, 1, &ch, NULL);
+
+	/* TIM */
+	*c = WLAN_EID_TIM;
+	*(c + 1) = 4;
+	c += 6;
+	//c = rtw_set_ie(c, _TIM_IE_, 4, NULL, NULL);
+
+	/* Extended Supported Rates */
+	if (n_bitrates > 8)
+		c = rtw_set_ie(c, WLAN_EID_EXT_SUPP_RATES, n_bitrates - 8, supported_rates + 8, NULL);
+
+	/* RSN */
+	if (rsn_ie)
+		c = rtw_set_ie(c, WLAN_EID_RSN, rsn_ie_len, rsn_ie + 2, NULL);
+
+#if defined(CONFIG_80211N_HT)
+	if (ht) {
+		struct ieee80211_sta_ht_cap *sta_ht_cap = &wiphy->bands[chan->band]->ht_cap;
+		u8 ht_cap[HT_CAP_IE_LEN];
+		u8 ht_op[HT_OP_IE_LEN];
+
+		_rtw_memset(ht_cap, 0, HT_CAP_IE_LEN);
+		_rtw_memset(ht_op, 0, HT_OP_IE_LEN);
+
+		/* WLAN_EID_HT_CAP */
+		RTW_PUT_LE16(HT_CAP_ELE_CAP_INFO(ht_cap), sta_ht_cap->cap);
+		SET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(ht_cap, sta_ht_cap->ampdu_factor);
+		SET_HT_CAP_ELE_MIN_MPDU_S_SPACE(ht_cap, sta_ht_cap->ampdu_density);
+		_rtw_memcpy(HT_CAP_ELE_SUP_MCS_SET(ht_cap), &sta_ht_cap->mcs, 16);
+		c = rtw_set_ie(c, WLAN_EID_HT_CAP, HT_CAP_IE_LEN, ht_cap, NULL);
+
+		/* WLAN_EID_HT_OPERATION */
+		SET_HT_OP_ELE_PRI_CHL(ht_op, ch);
+		switch (offset) {
+		case HAL_PRIME_CHNL_OFFSET_LOWER:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCA);
+			break;
+		case HAL_PRIME_CHNL_OFFSET_UPPER:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCB);
+			break;
+		case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
+		default:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCN);
+			break;
+		}
+		if (bw >= CHANNEL_WIDTH_40)
+			SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op, 1);
+		else
+			SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op, 0);
+		c = rtw_set_ie(c, WLAN_EID_HT_OPERATION, HT_OP_IE_LEN, ht_op, NULL);
+	}
+#endif /* defined(CONFIG_80211N_HT) */
+
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	if (vht) {
+		struct ieee80211_sta_vht_cap *sta_vht_cap = &wiphy->bands[chan->band]->vht_cap;
+		u8 vht_cap[VHT_CAP_IE_LEN];
+		u8 vht_op[VHT_OP_IE_LEN];
+		u8 cch = rtw_get_center_ch(ch, bw, offset);
+
+		_rtw_memset(vht_op, 0, VHT_OP_IE_LEN);
+
+		/* WLAN_EID_VHT_CAPABILITY */
+		_rtw_memcpy(vht_cap, &sta_vht_cap->cap, 4);
+		_rtw_memcpy(vht_cap + 4, &sta_vht_cap->vht_mcs, 8);
+		c = rtw_set_ie(c, WLAN_EID_VHT_CAPABILITY, VHT_CAP_IE_LEN, vht_cap, NULL);
+
+		/* WLAN_EID_VHT_OPERATION */
+		if (bw < CHANNEL_WIDTH_80) {
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op, 0);
+		} else if (bw == CHANNEL_WIDTH_80) {
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op, 1);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op, cch);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op, 0);
+		} else {
+			RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(adapter), bw);
+			rtw_warn_on(1);
+			rtw_mfree(ies, len);
+			goto exit;
+		}
+
+		/* Hard code 1 stream, MCS0-7 is a min Basic VHT MCS rates */
+		vht_op[3] = 0xfc;
+		vht_op[4] = 0xff;
+		c = rtw_set_ie(c, WLAN_EID_VHT_OPERATION, VHT_OP_IE_LEN, vht_op, NULL);
+	}
+#endif /* defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)) */
+
+	/* Mesh ID */
+	c = rtw_set_ie_mesh_id(c, NULL, minfo->mesh_id, minfo->mesh_id_len);
+
+	/* Mesh configuration */
+	c = rtw_set_ie_mesh_config(c, NULL
+		, minfo->mesh_pp_id
+		, minfo->mesh_pm_id
+		, minfo->mesh_cc_id
+		, minfo->mesh_sp_id
+		, minfo->mesh_auth_id
+		, 0, 0, 0
+		, 1
+		, 0, 0
+		, mcfg->dot11MeshForwarding
+		, 0, 0, 0
+	);
+
+#if DBG_RTW_CFG80211_MESH_CONF
+	RTW_INFO(FUNC_ADPT_FMT" ies_len:%u\n", FUNC_ADPT_ARG(adapter), len);
+	dump_ies(RTW_DBGDUMP, ies + _BEACON_IE_OFFSET_, len - _BEACON_IE_OFFSET_);
+#endif
+
+exit:
+	if (ies)
+		*ies_len = len;
+	return ies;
+}
+
+static int cfg80211_rtw_get_mesh_config(struct wiphy *wiphy, struct net_device *dev
+	, struct mesh_config *conf)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_cfg *mesh_cfg = &adapter->mesh_cfg;
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+	/* driver MPM */
+	conf->dot11MeshRetryTimeout = 0;
+	conf->dot11MeshConfirmTimeout = 0;
+	conf->dot11MeshHoldingTimeout = 0;
+	conf->dot11MeshMaxPeerLinks = mesh_cfg->max_peer_links;
+	conf->dot11MeshMaxRetries = 0;
+
+	conf->dot11MeshTTL = mesh_cfg->dot11MeshTTL;
+	conf->element_ttl = mesh_cfg->element_ttl;
+
+	/* driver MPM */
+	conf->auto_open_plinks = 0;
+
+	/* TBD: synchronization */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	conf->dot11MeshNbrOffsetMaxNeighbor = 0;
+#endif
+
+	conf->dot11MeshHWMPmaxPREQretries = mesh_cfg->dot11MeshHWMPmaxPREQretries;
+	conf->path_refresh_time = mesh_cfg->path_refresh_time;
+	conf->min_discovery_timeout = mesh_cfg->min_discovery_timeout;
+	conf->dot11MeshHWMPactivePathTimeout = mesh_cfg->dot11MeshHWMPactivePathTimeout;
+	conf->dot11MeshHWMPpreqMinInterval = mesh_cfg->dot11MeshHWMPpreqMinInterval;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	conf->dot11MeshHWMPperrMinInterval = mesh_cfg->dot11MeshHWMPperrMinInterval;
+#endif
+	conf->dot11MeshHWMPnetDiameterTraversalTime = mesh_cfg->dot11MeshHWMPnetDiameterTraversalTime;
+	conf->dot11MeshHWMPRootMode = mesh_cfg->dot11MeshHWMPRootMode;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	conf->dot11MeshHWMPRannInterval = mesh_cfg->dot11MeshHWMPRannInterval;
+#endif
+	conf->dot11MeshGateAnnouncementProtocol = mesh_cfg->dot11MeshGateAnnouncementProtocol;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	conf->dot11MeshForwarding = mesh_cfg->dot11MeshForwarding;
+	conf->rssi_threshold = mesh_cfg->rssi_threshold;
+#endif
+
+	/* TBD */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	conf->ht_opmode = 0xffff;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	conf->dot11MeshHWMPactivePathToRootTimeout = mesh_cfg->dot11MeshHWMPactivePathToRootTimeout;
+	conf->dot11MeshHWMProotInterval = mesh_cfg->dot11MeshHWMProotInterval;
+	conf->dot11MeshHWMPconfirmationInterval = mesh_cfg->dot11MeshHWMPconfirmationInterval;
+#endif
+
+	/* TBD: power save */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	conf->power_mode = NL80211_MESH_POWER_ACTIVE;
+	conf->dot11MeshAwakeWindowDuration = 0;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	conf->plink_timeout = mesh_cfg->plink_timeout;
+#endif
+
+	return ret;
+}
+
+static void rtw_mbss_info_change_notify(_adapter *adapter, bool minfo_changed, bool need_work)
+{
+	if (need_work)
+		rtw_mesh_work(&adapter->mesh_work);
+}
+
+static int cfg80211_rtw_update_mesh_config(struct wiphy *wiphy, struct net_device *dev
+	, u32 mask, const struct mesh_config *nconf)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+	bool minfo_changed = _FALSE, need_work = _FALSE;
+
+	RTW_INFO(FUNC_ADPT_FMT" mask:0x%08x\n", FUNC_ADPT_ARG(adapter), mask);
+
+	rtw_cfg80211_mesh_cfg_set(adapter, nconf, mask);
+	update_beacon(adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE);
+	need_work = rtw_ieee80211_mesh_root_setup(adapter);
+
+	rtw_mbss_info_change_notify(adapter, minfo_changed, need_work);
+
+	return ret;
+}
+
+static int cfg80211_rtw_join_mesh(struct wiphy *wiphy, struct net_device *dev,
+	const struct mesh_config *conf, const struct mesh_setup *setup)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 *ies = NULL;
+	uint ies_len;
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+#if DBG_RTW_CFG80211_MESH_CONF
+	RTW_INFO(FUNC_ADPT_FMT" mesh_setup:\n", FUNC_ADPT_ARG(adapter));
+	dump_mesh_setup(RTW_DBGDUMP, wiphy, setup);
+	RTW_INFO(FUNC_ADPT_FMT" mesh_config:\n", FUNC_ADPT_ARG(adapter));
+	dump_mesh_config(RTW_DBGDUMP, conf);
+#endif
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+
+	/* initialization */
+	rtw_mesh_init_mesh_info(adapter);
+
+	/* apply cfg80211 settings*/
+	rtw_cfg80211_mesh_info_set_profile(&adapter->mesh_info, setup);
+	rtw_cfg80211_mesh_cfg_set(adapter, conf, 0xFFFFFFFF);
+
+	/* apply cfg80211 settings (join only) */
+	rtw_mesh_cfg_init_max_peer_links(adapter, conf->dot11MeshMaxPeerLinks);
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	rtw_mesh_cfg_init_plink_timeout(adapter, conf->plink_timeout);
+	#endif
+
+	rtw_ieee80211_mesh_root_setup(adapter);
+
+	ies = rtw_cfg80211_construct_mesh_beacon_ies(wiphy, adapter, conf, setup, &ies_len);
+	if (!ies) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	/* start mbss */
+	if (rtw_check_beacon_data(adapter, ies,  ies_len) != _SUCCESS) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	
+	rtw_mesh_work(&adapter->mesh_work);
+
+exit:
+	if (ies)
+		rtw_mfree(ies, ies_len);
+	if (ret)
+		rtw_mesh_deinit_mesh_info(adapter);
+
+	return ret;
+}
+
+static int cfg80211_rtw_leave_mesh(struct wiphy *wiphy, struct net_device *dev)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+	rtw_mesh_deinit_mesh_info(adapter);
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
+	return ret;
+}
+
+static int cfg80211_rtw_add_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst, const u8 *next_hop
+	#else
+	, u8 *dst, u8 *next_hop
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	sta = rtw_get_stainfo(stapriv, next_hop);
+	if (!sta) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	mpath = rtw_mesh_path_add(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_mesh_path_fix_nexthop(mpath, sta);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_del_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst
+	#else
+	, u8 *dst
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+
+	if (dst) {
+		if (rtw_mesh_path_del(adapter, dst)) {
+			ret = -ENOENT;
+			goto exit;
+		}
+	} else {
+		rtw_mesh_path_flush_by_iface(adapter);
+	}	
+
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_change_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst, const u8 *next_hop
+	#else
+	, u8 *dst, u8 *next_hop
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	sta = rtw_get_stainfo(stapriv, next_hop);
+	if (!sta) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	mpath = rtw_mesh_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_mesh_path_fix_nexthop(mpath, sta);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static void rtw_cfg80211_mpath_set_pinfo(struct rtw_mesh_path *mpath, u8 *next_hop, struct mpath_info *pinfo)
+{
+	struct sta_info *next_hop_sta = rtw_rcu_dereference(mpath->next_hop);
+
+	if (next_hop_sta)
+		_rtw_memcpy(next_hop, next_hop_sta->cmn.mac_addr, ETH_ALEN);
+	else
+		_rtw_memset(next_hop, 0, ETH_ALEN);
+
+	_rtw_memset(pinfo, 0, sizeof(*pinfo));
+
+	pinfo->generation = mpath->adapter->mesh_info.mesh_paths_generation;
+
+	pinfo->filled = 0
+		| MPATH_INFO_FRAME_QLEN
+		| MPATH_INFO_SN
+		| MPATH_INFO_METRIC
+		| MPATH_INFO_EXPTIME
+		| MPATH_INFO_DISCOVERY_TIMEOUT
+		| MPATH_INFO_DISCOVERY_RETRIES
+		| MPATH_INFO_FLAGS
+		;
+
+	pinfo->frame_qlen = mpath->frame_queue_len;
+	pinfo->sn = mpath->sn;
+	pinfo->metric = mpath->metric;
+	if (rtw_time_after(mpath->exp_time, rtw_get_current_time()))
+		pinfo->exptime = rtw_get_remaining_time_ms(mpath->exp_time);
+	pinfo->discovery_timeout = rtw_systime_to_ms(mpath->discovery_timeout);
+	pinfo->discovery_retries = mpath->discovery_retries;
+	if (mpath->flags & RTW_MESH_PATH_ACTIVE)
+		pinfo->flags |= NL80211_MPATH_FLAG_ACTIVE;
+	if (mpath->flags & RTW_MESH_PATH_RESOLVING)
+		pinfo->flags |= NL80211_MPATH_FLAG_RESOLVING;
+	if (mpath->flags & RTW_MESH_PATH_SN_VALID)
+		pinfo->flags |= NL80211_MPATH_FLAG_SN_VALID;
+	if (mpath->flags & RTW_MESH_PATH_FIXED)
+		pinfo->flags |= NL80211_MPATH_FLAG_FIXED;
+	if (mpath->flags & RTW_MESH_PATH_RESOLVED)
+		pinfo->flags |= NL80211_MPATH_FLAG_RESOLVED;
+}
+
+static int cfg80211_rtw_get_mpath(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mesh_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_cfg80211_mpath_set_pinfo(mpath, next_hop, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_dump_mpath(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mesh_path_lookup_by_idx(adapter, idx);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+	rtw_cfg80211_mpath_set_pinfo(mpath, next_hop, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+static void rtw_cfg80211_mpp_set_pinfo(struct rtw_mesh_path *mpath, u8 *mpp, struct mpath_info *pinfo)
+{
+	_rtw_memcpy(mpp, mpath->mpp, ETH_ALEN);
+
+	_rtw_memset(pinfo, 0, sizeof(*pinfo));
+	pinfo->generation = mpath->adapter->mesh_info.mpp_paths_generation;
+}
+
+static int cfg80211_rtw_get_mpp(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mpp_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_cfg80211_mpp_set_pinfo(mpath, mpp, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_dump_mpp(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mpp_path_lookup_by_idx(adapter, idx);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+	rtw_cfg80211_mpp_set_pinfo(mpath, mpp, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0)) */
+
+#endif /* defined(CONFIG_RTW_MESH) */
+
+#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+static int cfg80211_rtw_sched_scan_start(struct wiphy *wiphy,
+		struct net_device *dev,
+		struct cfg80211_sched_scan_request *request)
+{
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct cfg80211_ssid *ssids;
+	int n_ssids = 0;
+	int interval = 0;
+	int i = 0;
+	u8 ret;
+
+	if (padapter->bup == _FALSE) {
+		RTW_INFO("%s: net device is down.\n", __func__);
+		return -EIO;
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE ||
+		check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE  ||
+		check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("%s: device is busy.\n", __func__);
+		rtw_scan_abort(padapter);
+	}
+
+	if (request == NULL) {
+		RTW_INFO("%s: invalid cfg80211_requests parameters.\n", __func__);
+		return -EINVAL;
+	}
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
+	interval = request->interval;
+	n_ssids = request->n_match_sets;
+	ssids = (struct cfg80211_ssid *)rtw_zmalloc(n_ssids * sizeof(struct cfg80211_ssid));
+	if(ssids == NULL) {
+		RTW_ERR("Fail to allocate ssids for PNO\n");
+		return -ENOMEM;
+	}
+	for (i=0;i<request->n_match_sets;i++) {
+			ssids[i].ssid_len = request->match_sets[i].ssid.ssid_len;
+			memcpy(ssids[i].ssid, request->match_sets[i].ssid.ssid,
+					request->match_sets[i].ssid.ssid_len);
+	}
+#else
+	interval = request->interval;
+	n_ssids = request->n_ssids;
+	ssids = request->ssids;
+#endif
+ret = rtw_android_cfg80211_pno_setup(dev, ssids,
+			n_ssids, interval);
+	if (ret < 0) {
+		RTW_INFO("%s ret: %d\n", __func__, ret);
+		goto exit;
+	}
+
+	ret = rtw_android_pno_enable(dev, _TRUE);
+	if (ret < 0) {
+		RTW_INFO("%s ret: %d\n", __func__, ret);
+		goto exit;
+	}
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_sched_scan_stop(struct wiphy *wiphy,
+		struct net_device *dev)
+{
+	return rtw_android_pno_enable(dev, _FALSE);
+}
+
+int	cfg80211_rtw_suspend(struct wiphy *wiphy, struct cfg80211_wowlan *wow) {
+	RTW_DBG("==> %s\n",__func__);
+	RTW_DBG("<== %s\n",__func__);
+	return 0;
+}
+
+int	cfg80211_rtw_resume(struct wiphy *wiphy) {
+
+	_adapter *padapter;
+	struct pwrctrl_priv *pwrpriv;
+	struct mlme_priv *pmlmepriv;
+	padapter = wiphy_to_adapter(wiphy);
+	pwrpriv = adapter_to_pwrctl(padapter);
+	pmlmepriv = &padapter->mlmepriv;
+	struct sitesurvey_parm parm;
+	int i, len;
+
+
+	RTW_DBG("==> %s\n",__func__);
+	if (pwrpriv->wowlan_last_wake_reason == RX_PNO) {
+
+		struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+		_irqL irqL;
+		int PNOWakeupScanWaitCnt = 0;
+
+		rtw_cfg80211_disconnected(padapter->rtw_wdev, 0, NULL, 0, 1, GFP_ATOMIC);
+
+		rtw_init_sitesurvey_parm(padapter, &parm);
+		for (i=0;i<pwrpriv->pnlo_info->ssid_num && i < RTW_SSID_SCAN_AMOUNT; i++) {
+			len = pwrpriv->pno_ssid_list->node[i].SSID_len;
+			_rtw_memcpy(&parm.ssid[i].Ssid, pwrpriv->pno_ssid_list->node[i].SSID, len);
+			parm->ssid[i].SsidLength = len;
+		}
+		prm->ssid_num = pwrpriv->pnlo_info->ssid_num;
+
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		//This modification fix PNO wakeup reconnect issue with hidden SSID AP.
+		//rtw_sitesurvey_cmd(padapter, NULL);
+		rtw_sitesurvey_cmd(padapter, &parm);
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+		
+		for (PNOWakeupScanWaitCnt = 0; PNOWakeupScanWaitCnt < 10; PNOWakeupScanWaitCnt++) {
+			if(check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _FALSE)
+				break;
+			rtw_msleep_os(1000);
+		}
+		
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		cfg80211_sched_scan_results(padapter->rtw_wdev->wiphy);
+		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+
+	}
+	RTW_DBG("<== %s\n",__func__);
+	return 0;
+	
+}
+#endif /* CONFIG_PNO_SUPPORT */
+
+static int rtw_cfg80211_set_beacon_wpsp2pie(struct net_device *ndev, char *buf, int len)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u8 *wps_ie;
+	u32	p2p_ielen = 0;
+	u8 wps_oui[8] = {0x0, 0x50, 0xf2, 0x04};
+	u8 *p2p_ie;
+	u32	wfd_ielen = 0;
+	u8 *wfd_ie;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+
+	RTW_INFO(FUNC_NDEV_FMT" ielen=%d\n", FUNC_NDEV_ARG(ndev), len);
+
+	if (len > 0) {
+		wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen);
+		if (wps_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("bcn_wps_ielen=%d\n", wps_ielen);
+			#endif
+
+			if (pmlmepriv->wps_beacon_ie) {
+				u32 free_len = pmlmepriv->wps_beacon_ie_len;
+				pmlmepriv->wps_beacon_ie_len = 0;
+				rtw_mfree(pmlmepriv->wps_beacon_ie, free_len);
+				pmlmepriv->wps_beacon_ie = NULL;
+			}
+
+			pmlmepriv->wps_beacon_ie = rtw_malloc(wps_ielen);
+			if (pmlmepriv->wps_beacon_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+
+			_rtw_memcpy(pmlmepriv->wps_beacon_ie, wps_ie, wps_ielen);
+			pmlmepriv->wps_beacon_ie_len = wps_ielen;
+
+			update_beacon(padapter, _VENDOR_SPECIFIC_IE_, wps_oui, _TRUE);
+
+		}
+
+		/* buf += wps_ielen; */
+		/* len -= wps_ielen; */
+
+		#ifdef CONFIG_P2P
+		p2p_ie = rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("bcn_p2p_ielen=%d\n", p2p_ielen);
+			#endif
+
+			if (pmlmepriv->p2p_beacon_ie) {
+				u32 free_len = pmlmepriv->p2p_beacon_ie_len;
+				pmlmepriv->p2p_beacon_ie_len = 0;
+				rtw_mfree(pmlmepriv->p2p_beacon_ie, free_len);
+				pmlmepriv->p2p_beacon_ie = NULL;
+			}
+
+			pmlmepriv->p2p_beacon_ie = rtw_malloc(p2p_ielen);
+			if (pmlmepriv->p2p_beacon_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+
+			_rtw_memcpy(pmlmepriv->p2p_beacon_ie, p2p_ie, p2p_ielen);
+			pmlmepriv->p2p_beacon_ie_len = p2p_ielen;
+
+		}
+		#endif /* CONFIG_P2P */
+
+
+		#ifdef CONFIG_WFD
+		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("bcn_wfd_ielen=%d\n", wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_BEACON_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				return -EINVAL;
+		}
+		#endif /* CONFIG_WFD */
+
+		pmlmeext->bstart_bss = _TRUE;
+
+	}
+
+	return ret;
+
+}
+
+static int rtw_cfg80211_set_probe_resp_wpsp2pie(struct net_device *net, char *buf, int len)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u8 *wps_ie;
+	u32	p2p_ielen = 0;
+	u8 *p2p_ie;
+	u32	wfd_ielen = 0;
+	u8 *wfd_ie;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+#endif
+
+	if (len > 0) {
+		wps_ie = rtw_get_wps_ie(buf, len, NULL, &wps_ielen);
+		if (wps_ie) {
+			uint	attr_contentlen = 0;
+			u16	uconfig_method, *puconfig_method = NULL;
+
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_resp_wps_ielen=%d\n", wps_ielen);
+			#endif
+
+			if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+				u8 sr = 0;
+				rtw_get_wps_attr_content(wps_ie,  wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
+
+				if (sr != 0)
+					RTW_INFO("%s, got sr\n", __func__);
+				else {
+					RTW_INFO("GO mode process WPS under site-survey,  sr no set\n");
+					return ret;
+				}
+			}
+
+			if (pmlmepriv->wps_probe_resp_ie) {
+				u32 free_len = pmlmepriv->wps_probe_resp_ie_len;
+				pmlmepriv->wps_probe_resp_ie_len = 0;
+				rtw_mfree(pmlmepriv->wps_probe_resp_ie, free_len);
+				pmlmepriv->wps_probe_resp_ie = NULL;
+			}
+
+			pmlmepriv->wps_probe_resp_ie = rtw_malloc(wps_ielen);
+			if (pmlmepriv->wps_probe_resp_ie == NULL) {
+				RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+				return -EINVAL;
+
+			}
+
+			/* add PUSH_BUTTON config_method by driver self in wpsie of probe_resp at GO Mode */
+			puconfig_method = (u16 *)rtw_get_wps_attr_content(wps_ie, wps_ielen, WPS_ATTR_CONF_METHOD , NULL, &attr_contentlen);
+			if (puconfig_method != NULL) {
+				/* struct registry_priv *pregistrypriv = &padapter->registrypriv; */
+				struct wireless_dev *wdev = padapter->rtw_wdev;
+
+				#ifdef CONFIG_DEBUG_CFG80211
+				/* printk("config_method in wpsie of probe_resp = 0x%x\n", be16_to_cpu(*puconfig_method)); */
+				#endif
+
+				#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+				/* for WIFI-DIRECT LOGO 4.2.2, AUTO GO can't set PUSH_BUTTON flags */
+				if (wdev->iftype == NL80211_IFTYPE_P2P_GO) {
+					uconfig_method = WPS_CM_PUSH_BUTTON;
+					uconfig_method = cpu_to_be16(uconfig_method);
+
+					*puconfig_method &= ~uconfig_method;
+				}
+				#endif
+			}
+
+			_rtw_memcpy(pmlmepriv->wps_probe_resp_ie, wps_ie, wps_ielen);
+			pmlmepriv->wps_probe_resp_ie_len = wps_ielen;
+
+		}
+
+		/* buf += wps_ielen; */
+		/* len -= wps_ielen; */
+
+		#ifdef CONFIG_P2P
+		p2p_ie = rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen);
+		if (p2p_ie) {
+			u8 is_GO = _FALSE;
+			u32 attr_contentlen = 0;
+			u16 cap_attr = 0;
+
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_resp_p2p_ielen=%d\n", p2p_ielen);
+			#endif
+
+			/* Check P2P Capability ATTR */
+			if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *) &attr_contentlen)) {
+				u8 grp_cap = 0;
+				/* RTW_INFO( "[%s] Got P2P Capability Attr!!\n", __FUNCTION__ ); */
+				cap_attr = le16_to_cpu(cap_attr);
+				grp_cap = (u8)((cap_attr >> 8) & 0xff);
+
+				is_GO = (grp_cap & BIT(0)) ? _TRUE : _FALSE;
+
+				if (is_GO)
+					RTW_INFO("Got P2P Capability Attr, grp_cap=0x%x, is_GO\n", grp_cap);
+			}
+
+
+			if (is_GO == _FALSE) {
+				if (pmlmepriv->p2p_probe_resp_ie) {
+					u32 free_len = pmlmepriv->p2p_probe_resp_ie_len;
+					pmlmepriv->p2p_probe_resp_ie_len = 0;
+					rtw_mfree(pmlmepriv->p2p_probe_resp_ie, free_len);
+					pmlmepriv->p2p_probe_resp_ie = NULL;
+				}
+
+				pmlmepriv->p2p_probe_resp_ie = rtw_malloc(p2p_ielen);
+				if (pmlmepriv->p2p_probe_resp_ie == NULL) {
+					RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+					return -EINVAL;
+
+				}
+				_rtw_memcpy(pmlmepriv->p2p_probe_resp_ie, p2p_ie, p2p_ielen);
+				pmlmepriv->p2p_probe_resp_ie_len = p2p_ielen;
+			} else {
+				if (pmlmepriv->p2p_go_probe_resp_ie) {
+					u32 free_len = pmlmepriv->p2p_go_probe_resp_ie_len;
+					pmlmepriv->p2p_go_probe_resp_ie_len = 0;
+					rtw_mfree(pmlmepriv->p2p_go_probe_resp_ie, free_len);
+					pmlmepriv->p2p_go_probe_resp_ie = NULL;
+				}
+
+				pmlmepriv->p2p_go_probe_resp_ie = rtw_malloc(p2p_ielen);
+				if (pmlmepriv->p2p_go_probe_resp_ie == NULL) {
+					RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+					return -EINVAL;
+
+				}
+				_rtw_memcpy(pmlmepriv->p2p_go_probe_resp_ie, p2p_ie, p2p_ielen);
+				pmlmepriv->p2p_go_probe_resp_ie_len = p2p_ielen;
+			}
+
+		}
+		#endif /* CONFIG_P2P */
+
+
+		#ifdef CONFIG_WFD
+		wfd_ie = rtw_get_wfd_ie(buf, len, NULL, &wfd_ielen);
+		if (wfd_ie) {
+			#ifdef CONFIG_DEBUG_CFG80211
+			RTW_INFO("probe_resp_wfd_ielen=%d\n", wfd_ielen);
+			#endif
+
+			if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_PROBE_RESP_IE, wfd_ie, wfd_ielen) != _SUCCESS)
+				return -EINVAL;
+		}
+		#endif /* CONFIG_WFD */
+
+	}
+
+	return ret;
+
+}
+
+static int rtw_cfg80211_set_assoc_resp_wpsp2pie(struct net_device *net, char *buf, int len)
+{
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u8 *ie;
+	u32 ie_len;
+
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+
+	if (len <= 0)
+		goto exit;
+
+	ie = rtw_get_wps_ie(buf, len, NULL, &ie_len);
+	if (ie && ie_len) {
+		if (pmlmepriv->wps_assoc_resp_ie) {
+			u32 free_len = pmlmepriv->wps_assoc_resp_ie_len;
+
+			pmlmepriv->wps_assoc_resp_ie_len = 0;
+			rtw_mfree(pmlmepriv->wps_assoc_resp_ie, free_len);
+			pmlmepriv->wps_assoc_resp_ie = NULL;
+		}
+
+		pmlmepriv->wps_assoc_resp_ie = rtw_malloc(ie_len);
+		if (pmlmepriv->wps_assoc_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+			return -EINVAL;
+		}
+		_rtw_memcpy(pmlmepriv->wps_assoc_resp_ie, ie, ie_len);
+		pmlmepriv->wps_assoc_resp_ie_len = ie_len;
+	}
+
+	ie = rtw_get_p2p_ie(buf, len, NULL, &ie_len);
+	if (ie && ie_len) {
+		if (pmlmepriv->p2p_assoc_resp_ie) {
+			u32 free_len = pmlmepriv->p2p_assoc_resp_ie_len;
+
+			pmlmepriv->p2p_assoc_resp_ie_len = 0;
+			rtw_mfree(pmlmepriv->p2p_assoc_resp_ie, free_len);
+			pmlmepriv->p2p_assoc_resp_ie = NULL;
+		}
+
+		pmlmepriv->p2p_assoc_resp_ie = rtw_malloc(ie_len);
+		if (pmlmepriv->p2p_assoc_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+			return -EINVAL;
+		}
+		_rtw_memcpy(pmlmepriv->p2p_assoc_resp_ie, ie, ie_len);
+		pmlmepriv->p2p_assoc_resp_ie_len = ie_len;
+	}
+
+#ifdef CONFIG_WFD
+	ie = rtw_get_wfd_ie(buf, len, NULL, &ie_len);
+	if (rtw_mlme_update_wfd_ie_data(pmlmepriv, MLME_ASSOC_RESP_IE, ie, ie_len) != _SUCCESS)
+		return -EINVAL;
+#endif
+
+exit:
+	return ret;
+}
+
+int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len,
+	int type)
+{
+	int ret = 0;
+	uint wps_ielen = 0;
+	u32	p2p_ielen = 0;
+
+#ifdef CONFIG_DEBUG_CFG80211
+	RTW_INFO("%s, ielen=%d\n", __func__, len);
+#endif
+
+	if ((rtw_get_wps_ie(buf, len, NULL, &wps_ielen) && (wps_ielen > 0))
+		#ifdef CONFIG_P2P
+		|| (rtw_get_p2p_ie(buf, len, NULL, &p2p_ielen) && (p2p_ielen > 0))
+		#endif
+	) {
+		if (net != NULL) {
+			switch (type) {
+			case 0x1: /* BEACON */
+				ret = rtw_cfg80211_set_beacon_wpsp2pie(net, buf, len);
+				break;
+			case 0x2: /* PROBE_RESP */
+				ret = rtw_cfg80211_set_probe_resp_wpsp2pie(net, buf, len);
+				#ifdef CONFIG_P2P
+				if (ret == 0)
+					adapter_wdev_data((_adapter *)rtw_netdev_priv(net))->probe_resp_ie_update_time = rtw_get_current_time();
+				#endif
+				break;
+			case 0x4: /* ASSOC_RESP */
+				ret = rtw_cfg80211_set_assoc_resp_wpsp2pie(net, buf, len);
+				break;
+			}
+		}
+	}
+
+	return ret;
+
+}
+
+#ifdef CONFIG_80211N_HT
+static void rtw_cfg80211_init_ht_capab_ex(_adapter *padapter
+	, struct ieee80211_sta_ht_cap *ht_cap, BAND_TYPE band, u8 rf_type)
+{
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
+	u8 stbc_rx_enable = _FALSE;
+
+	rtw_ht_use_default_setting(padapter);
+
+	/* RX LDPC */
+	if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX))
+		ht_cap->cap |= IEEE80211_HT_CAP_LDPC_CODING;
+
+	/* TX STBC */
+	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX))
+		ht_cap->cap |= IEEE80211_HT_CAP_TX_STBC;
+
+	/* RX STBC */
+	if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX)) {
+		/*rtw_rx_stbc 0: disable, bit(0):enable 2.4g, bit(1):enable 5g*/
+		if (band == BAND_ON_2_4G)
+			stbc_rx_enable = (pregistrypriv->rx_stbc & BIT(0)) ? _TRUE : _FALSE;
+		if (band == BAND_ON_5G)
+			stbc_rx_enable = (pregistrypriv->rx_stbc & BIT(1)) ? _TRUE : _FALSE;
+
+		if (stbc_rx_enable) {
+			switch (rf_type) {
+			case RF_1T1R:
+				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/*RX STBC One spatial stream*/
+				break;
+
+			case RF_2T2R:
+			case RF_1T2R:
+				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/* Only one spatial-stream STBC RX is supported */
+				break;
+			case RF_3T3R:
+			case RF_3T4R:
+			case RF_4T4R:
+				ht_cap->cap |= IEEE80211_HT_CAP_RX_STBC_1R;/* Only one spatial-stream STBC RX is supported */
+				break;
+			default:
+				RTW_INFO("[warning] rf_type %d is not expected\n", rf_type);
+				break;
+			}
+		}
+	}
+}
+
+static void rtw_cfg80211_init_ht_capab(_adapter *padapter
+	, struct ieee80211_sta_ht_cap *ht_cap, BAND_TYPE band, u8 rf_type)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	u8 rx_nss = 0;
+
+	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;
+	rtw_cfg80211_init_ht_capab_ex(padapter, ht_cap, band, rf_type);
+
+	/*
+	 *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;
+
+	rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
+	switch (rx_nss) {
+	case 1:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		break;
+	case 2:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		ht_cap->mcs.rx_mask[1] = 0xFF;
+		break;
+	case 3:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		ht_cap->mcs.rx_mask[1] = 0xFF;
+		ht_cap->mcs.rx_mask[2] = 0xFF;
+		break;
+	case 4:
+		ht_cap->mcs.rx_mask[0] = 0xFF;
+		ht_cap->mcs.rx_mask[1] = 0xFF;
+		ht_cap->mcs.rx_mask[2] = 0xFF;
+		ht_cap->mcs.rx_mask[3] = 0xFF;
+		break;
+	default:
+		rtw_warn_on(1);
+		RTW_INFO("%s, error rf_type=%d\n", __func__, rf_type);
+	};
+
+	ht_cap->mcs.rx_highest = cpu_to_le16(
+		rtw_mcs_rate(rf_type
+			, hal_is_bw_support(padapter, CHANNEL_WIDTH_40)
+			, hal_is_bw_support(padapter, CHANNEL_WIDTH_40) ? ht_cap->cap & IEEE80211_HT_CAP_SGI_40 : ht_cap->cap & IEEE80211_HT_CAP_SGI_20
+			, ht_cap->mcs.rx_mask) / 10);
+}
+#endif /* CONFIG_80211N_HT */
+
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+static void rtw_cfg80211_init_vht_capab(_adapter *padapter
+	, struct ieee80211_sta_vht_cap *sta_vht_cap, BAND_TYPE band, u8 rf_type)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	struct registry_priv *regsty = &padapter->registrypriv;
+	struct vht_priv *vhtpriv = &padapter->mlmepriv.vhtpriv;
+	u8 vht_cap_ie[2 + 12] = {0};
+	u8 bw;
+
+	if (!REGSTY_IS_11AC_ENABLE(regsty)
+		|| !hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	) {
+		sta_vht_cap->vht_supported = 0;
+		return;
+	}
+
+	rtw_vht_use_default_setting(padapter);
+	rtw_build_vht_cap_ie(padapter, vht_cap_ie);
+
+	sta_vht_cap->vht_supported = 1;
+
+	_rtw_memcpy(&sta_vht_cap->cap, vht_cap_ie + 2, 4);
+	_rtw_memcpy(&sta_vht_cap->vht_mcs, vht_cap_ie + 2 + 4, 8);
+}
+#endif /* defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)) */
+
+void rtw_cfg80211_init_wdev_data(_adapter *padapter)
+{
+#ifdef CONFIG_CONCURRENT_MODE
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+
+	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
+#endif
+}
+
+void rtw_cfg80211_init_wiphy(_adapter *padapter)
+{
+	u8 rf_type;
+	struct ieee80211_supported_band *band;
+	struct wireless_dev *pwdev = padapter->rtw_wdev;
+	struct wiphy *wiphy = pwdev->wiphy;
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+
+	RTW_INFO("%s:rf_type=%d\n", __func__, rf_type);
+
+	if (IsSupported24G(padapter->registrypriv.wireless_mode)) {
+		band = wiphy->bands[NL80211_BAND_2GHZ];
+		if (band) {
+			#if defined(CONFIG_80211N_HT)
+			rtw_cfg80211_init_ht_capab(padapter, &band->ht_cap, BAND_ON_2_4G, rf_type);
+			#endif
+		}
+	}
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (is_supported_5g(padapter->registrypriv.wireless_mode)) {
+		band = wiphy->bands[NL80211_BAND_5GHZ];
+		if (band) {
+			#if defined(CONFIG_80211N_HT)
+			rtw_cfg80211_init_ht_capab(padapter, &band->ht_cap, BAND_ON_5G, rf_type);
+			#endif
+			#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+			rtw_cfg80211_init_vht_capab(padapter, &band->vht_cap, BAND_ON_5G, rf_type);
+			#endif
+		}
+	}
+#endif
+
+	/* copy mac_addr to wiphy */
+	_rtw_memcpy(wiphy->perm_addr, adapter_mac_addr(padapter), ETH_ALEN);
+
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+struct ieee80211_iface_limit rtw_limits[] = {
+	{
+		.max = 2,
+		.types = BIT(NL80211_IFTYPE_STATION)
+			#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+			| BIT(NL80211_IFTYPE_P2P_CLIENT)
+			#endif
+	},
+	#ifdef CONFIG_AP_MODE
+	{
+		.max = 1,
+		.types = BIT(NL80211_IFTYPE_AP)
+			#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+			| BIT(NL80211_IFTYPE_P2P_GO)
+			#endif
+	},
+	#endif
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	{
+		.max = 1,
+		.types = BIT(NL80211_IFTYPE_P2P_DEVICE)
+	},
+	#endif
+	#if defined(CONFIG_RTW_MESH)
+	{
+		.max = 1,
+		.types = BIT(NL80211_IFTYPE_MESH_POINT)
+	},
+	#endif
+};
+
+struct ieee80211_iface_combination rtw_combinations[] = {
+	{
+		.limits = rtw_limits,
+		.n_limits = ARRAY_SIZE(rtw_limits),
+		#if defined(RTW_DEDICATED_P2P_DEVICE)
+		.max_interfaces = 3,
+		#else
+		.max_interfaces = 2,
+		#endif
+		.num_different_channels = 1,
+	},
+};
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)) */
+
+static void rtw_cfg80211_preinit_wiphy(_adapter *adapter, struct wiphy *wiphy)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
+
+	wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM;
+
+	wiphy->max_scan_ssids = RTW_SSID_SCAN_AMOUNT;
+	wiphy->max_scan_ie_len = RTW_SCAN_IE_LEN_MAX;
+	wiphy->max_num_pmkids = RTW_MAX_NUM_PMKIDS;
+
+#if CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	wiphy->max_acl_mac_addrs = NUM_ACL;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38)) || defined(COMPAT_KERNEL_RELEASE)
+	wiphy->max_remain_on_channel_duration = RTW_MAX_REMAIN_ON_CHANNEL_DURATION;
+#endif
+
+	wiphy->interface_modes =	BIT(NL80211_IFTYPE_STATION)
+								| BIT(NL80211_IFTYPE_ADHOC)
+#ifdef CONFIG_AP_MODE
+								| BIT(NL80211_IFTYPE_AP)
+								#ifdef CONFIG_WIFI_MONITOR
+								| BIT(NL80211_IFTYPE_MONITOR)
+								#endif
+#endif
+#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+								| BIT(NL80211_IFTYPE_P2P_CLIENT)
+								| BIT(NL80211_IFTYPE_P2P_GO)
+								#if defined(RTW_DEDICATED_P2P_DEVICE)
+								| BIT(NL80211_IFTYPE_P2P_DEVICE)
+								#endif
+#endif
+#ifdef CONFIG_RTW_MESH
+								| BIT(NL80211_IFTYPE_MESH_POINT) /* 2.6.26 */
+#endif
+								;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+#ifdef CONFIG_AP_MODE
+	wiphy->mgmt_stypes = rtw_cfg80211_default_mgmt_stypes;
+#endif /* CONFIG_AP_MODE */
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	#ifdef CONFIG_WIFI_MONITOR
+	wiphy->software_iftypes |= BIT(NL80211_IFTYPE_MONITOR);
+	#endif
+#endif
+
+#if defined(RTW_SINGLE_WIPHY) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	wiphy->iface_combinations = rtw_combinations;
+	wiphy->n_iface_combinations = ARRAY_SIZE(rtw_combinations);
+#endif
+
+	wiphy->cipher_suites = rtw_cipher_suites;
+	wiphy->n_cipher_suites = ARRAY_SIZE(rtw_cipher_suites);
+
+	if (IsSupported24G(adapter->registrypriv.wireless_mode))
+		wiphy->bands[NL80211_BAND_2GHZ] = rtw_spt_band_alloc(BAND_ON_2_4G);
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (is_supported_5g(adapter->registrypriv.wireless_mode))
+		wiphy->bands[NL80211_BAND_5GHZ] = rtw_spt_band_alloc(BAND_ON_5G);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38) && LINUX_VERSION_CODE < KERNEL_VERSION(3, 0, 0))
+	wiphy->flags |= WIPHY_FLAG_SUPPORTS_SEPARATE_DEFAULT_KEYS;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
+	wiphy->flags |= WIPHY_FLAG_HAVE_AP_SME;
+	/* remove WIPHY_FLAG_OFFCHAN_TX, because we not support this feature */
+	/* wiphy->flags |= WIPHY_FLAG_OFFCHAN_TX | WIPHY_FLAG_HAVE_AP_SME; */
+#endif
+
+#if defined(CONFIG_PM) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0) && \
+			   LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+	wiphy->flags |= WIPHY_FLAG_SUPPORTS_SCHED_SCAN;
+#ifdef CONFIG_PNO_SUPPORT
+	wiphy->max_sched_scan_ssids = MAX_PNO_LIST_COUNT;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
+	wiphy->max_match_sets = MAX_PNO_LIST_COUNT;
+#endif
+#endif
+#endif
+
+#if defined(CONFIG_PM) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0))
+	wiphy->wowlan = wowlan_stub;
+#else
+	wiphy->wowlan = &wowlan_stub;
+#endif
+#endif
+
+#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	wiphy->flags |= WIPHY_FLAG_SUPPORTS_TDLS;
+#ifndef CONFIG_TDLS_DRIVER_SETUP
+	wiphy->flags |= WIPHY_FLAG_TDLS_EXTERNAL_SETUP;	/* Driver handles key exchange */
+	wiphy->flags |= NL80211_ATTR_HT_CAPABILITY;
+#endif /* CONFIG_TDLS_DRIVER_SETUP */
+#endif /* CONFIG_TDLS */
+
+	if (regsty->power_mgnt != PS_MODE_ACTIVE)
+		wiphy->flags |= WIPHY_FLAG_PS_ON_BY_DEFAULT;
+	else
+		wiphy->flags &= ~WIPHY_FLAG_PS_ON_BY_DEFAULT;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	/* wiphy->flags |= WIPHY_FLAG_SUPPORTS_FW_ROAM; */
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	wiphy->flags |= 0
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+		| WIPHY_FLAG_IBSS_RSN
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+		| WIPHY_FLAG_MESH_AUTH
+		#endif
+		;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	wiphy->features |= 0
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+		| NL80211_FEATURE_USERSPACE_MPM
+		#endif
+		;
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0)) */
+#endif /* CONFIG_RTW_MESH */
+}
+
+#ifdef CONFIG_RFKILL_POLL
+void rtw_cfg80211_init_rfkill(struct wiphy *wiphy)
+{
+	wiphy_rfkill_set_hw_state(wiphy, 0);
+	wiphy_rfkill_start_polling(wiphy);
+}
+
+void rtw_cfg80211_deinit_rfkill(struct wiphy *wiphy)
+{
+	wiphy_rfkill_stop_polling(wiphy);
+}
+
+static void cfg80211_rtw_rfkill_poll(struct wiphy *wiphy)
+{
+	_adapter *padapter = NULL;
+	bool blocked = _FALSE;
+	u8 valid = 0;
+
+	padapter = wiphy_to_adapter(wiphy);
+
+	if (adapter_to_dvobj(padapter)->processing_dev_remove == _TRUE) {
+		/*RTW_INFO("cfg80211_rtw_rfkill_poll: device is removed!\n");*/
+		return;
+	}
+
+	blocked = rtw_hal_rfkill_poll(padapter, &valid);
+	/*RTW_INFO("cfg80211_rtw_rfkill_poll: valid=%d, blocked=%d\n",
+			valid, blocked);*/
+
+	if (valid)
+		wiphy_rfkill_set_hw_state(wiphy, blocked);
+}
+#endif
+
+#if defined(CONFIG_RTW_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+#define SURVEY_INFO_TIME			SURVEY_INFO_CHANNEL_TIME
+#define SURVEY_INFO_TIME_BUSY		SURVEY_INFO_CHANNEL_TIME_BUSY
+#define SURVEY_INFO_TIME_EXT_BUSY	SURVEY_INFO_CHANNEL_TIME_EXT_BUSY
+#define SURVEY_INFO_TIME_RX			SURVEY_INFO_CHANNEL_TIME_RX
+#define SURVEY_INFO_TIME_TX			SURVEY_INFO_CHANNEL_TIME_TX
+#endif
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+static void rtw_cfg80211_set_survey_info_with_find_best_channel(struct wiphy *wiphy
+	, struct net_device *netdev, int idx, struct survey_info *info)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	RT_CHANNEL_INFO *ch_set = rfctl->channel_set;
+	u8 ch_num = rfctl->max_chan_nums;
+	u32 total_rx_cnt = 0;
+	int i;
+
+	s8 noise = -50;		/*channel noise in dBm. This and all following fields are optional */
+	u64 time = 100;		/*amount of time in ms the radio was turn on (on the channel)*/
+	u64 time_busy = 0;	/*amount of time the primary channel was sensed busy*/
+
+	info->filled  = SURVEY_INFO_NOISE_DBM
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+		| SURVEY_INFO_TIME | SURVEY_INFO_TIME_BUSY
+		#endif
+		;
+
+	for (i = 0; i < ch_num; i++)
+		total_rx_cnt += ch_set[i].rx_count;
+
+	time_busy = ch_set[idx].rx_count * time / total_rx_cnt;
+	noise += ch_set[idx].rx_count * 50 / total_rx_cnt;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+	info->channel_time = time;
+	info->channel_time_busy = time_busy;
+	#else
+	info->time = time;
+	info->time_busy = time_busy;
+	#endif
+#endif
+	info->noise = noise;
+
+	/* reset if final channel is got */
+	if (idx == ch_num - 1) {
+		for (i = 0; i < ch_num; i++)
+			ch_set[i].rx_count = 0;
+	}
+}
+#endif /* CONFIG_FIND_BEST_CHANNEL */
+
+#if defined(CONFIG_RTW_ACS) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
+static void rtw_cfg80211_set_survey_info_with_clm(PADAPTER padapter, int idx, struct survey_info *pinfo)
+{
+	s8 noise = -50;			/*channel noise in dBm. This and all following fields are optional */
+	u64 time = SURVEY_TO;	/*amount of time in ms the radio was turn on (on the channel)*/
+	u64 time_busy = 0;		/*amount of time the primary channel was sensed busy*/
+	u8 chan = (u8)idx;
+
+	if ((idx < 0) || (pinfo == NULL))
+		return;
+
+	pinfo->filled  = SURVEY_INFO_NOISE_DBM
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+		| SURVEY_INFO_TIME | SURVEY_INFO_TIME_BUSY
+		#endif
+		;
+
+	time_busy = rtw_acs_get_clm_ratio_by_ch_idx(padapter, chan);
+	noise = rtw_noise_query_by_chan_idx(padapter, chan);
+	/* RTW_INFO("%s: ch-idx:%d time=%llu(ms), time_busy=%llu(ms), noise=%d(dbm)\n", __func__, idx, time, time_busy, noise); */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+	pinfo->channel_time = time;
+	pinfo->channel_time_busy = time_busy;
+	#else
+	pinfo->time = time;
+	pinfo->time_busy = time_busy;
+	#endif
+#endif
+	pinfo->noise = noise;
+}
+#endif
+
+int rtw_hostapd_acs_dump_survey(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info)
+{
+	PADAPTER padapter = (_adapter *)rtw_netdev_priv(netdev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	RT_CHANNEL_INFO *pch_set = rfctl->channel_set;
+	u8 max_chan_nums = rfctl->max_chan_nums;
+	u32 freq = 0;
+	u8 ret = 0;
+	u16 channel = 0;
+
+	if (!netdev || !info) {
+		RTW_INFO("%s: invial parameters.\n", __func__);
+		return -EINVAL;
+	}
+
+	_rtw_memset(info, 0, sizeof(struct survey_info));
+	if (padapter->bup == _FALSE) {
+		RTW_INFO("%s: net device is down.\n", __func__);
+		return -EIO;
+	}
+
+	if (idx >= max_chan_nums)
+		return -ENOENT;
+
+	channel = pch_set[idx].ChannelNum;
+	freq = rtw_ch2freq(channel);
+	info->channel = ieee80211_get_channel(wiphy, freq);
+	/* RTW_INFO("%s: channel %d, freq %d\n", __func__, channel, freq); */
+
+	if (!info->channel)
+		return -EINVAL;
+
+	if (info->channel->flags == IEEE80211_CHAN_DISABLED)
+		return ret;
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	rtw_cfg80211_set_survey_info_with_find_best_channel(wiphy, netdev, idx, info);
+#elif defined(CONFIG_RTW_ACS) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
+	rtw_cfg80211_set_survey_info_with_clm(padapter, idx, info);
+#else
+	RTW_ERR("%s: unknown acs operation!\n", __func__); 
+#endif
+
+	return ret;
+}
+#endif /* defined(CONFIG_RTW_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33)) */
+
+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,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 30))
+	.set_default_mgmt_key = cfg80211_rtw_set_default_mgmt_key,
+#endif
+#if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
+	.set_rekey_data = cfg80211_rtw_set_rekey_data,
+#endif /*CONFIG_GTK_OL*/
+	.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_AP_MODE
+	.add_virtual_intf = cfg80211_rtw_add_virtual_intf,
+	.del_virtual_intf = cfg80211_rtw_del_virtual_intf,
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) && !defined(COMPAT_KERNEL_RELEASE)
+	.add_beacon = cfg80211_rtw_add_beacon,
+	.set_beacon = cfg80211_rtw_set_beacon,
+	.del_beacon = cfg80211_rtw_del_beacon,
+#else
+	.start_ap = cfg80211_rtw_start_ap,
+	.change_beacon = cfg80211_rtw_change_beacon,
+	.stop_ap = cfg80211_rtw_stop_ap,
+#endif
+
+#if CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	.set_mac_acl = cfg80211_rtw_set_mac_acl,
+#endif
+
+	.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,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+	.set_channel = cfg80211_rtw_set_channel,
+#endif
+	/* .auth = cfg80211_rtw_auth, */
+	/* .assoc = cfg80211_rtw_assoc,	 */
+#endif /* CONFIG_AP_MODE */
+
+#if defined(CONFIG_RTW_MESH) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38))
+	.get_mesh_config = cfg80211_rtw_get_mesh_config,
+	.update_mesh_config = cfg80211_rtw_update_mesh_config,
+	.join_mesh = cfg80211_rtw_join_mesh,
+	.leave_mesh = cfg80211_rtw_leave_mesh,
+	.add_mpath = cfg80211_rtw_add_mpath,
+	.del_mpath = cfg80211_rtw_del_mpath,
+	.change_mpath = cfg80211_rtw_change_mpath,
+	.get_mpath = cfg80211_rtw_get_mpath,
+	.dump_mpath = cfg80211_rtw_dump_mpath,
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+	.get_mpp = cfg80211_rtw_get_mpp,
+	.dump_mpp = cfg80211_rtw_dump_mpp,
+	#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	.set_monitor_channel = cfg80211_rtw_set_monitor_channel,
+#endif
+
+#ifdef CONFIG_P2P
+	.remain_on_channel = cfg80211_rtw_remain_on_channel,
+	.cancel_remain_on_channel = cfg80211_rtw_cancel_remain_on_channel,
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	.start_p2p_device = cfg80211_rtw_start_p2p_device,
+	.stop_p2p_device = cfg80211_rtw_stop_p2p_device,
+	#endif
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_RTW_80211R
+	.update_ft_ies = cfg80211_rtw_update_ft_ies,
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	.mgmt_tx = cfg80211_rtw_mgmt_tx,
+	.mgmt_frame_register = cfg80211_rtw_mgmt_frame_register,
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+	.action = cfg80211_rtw_mgmt_tx,
+#endif
+
+#if defined(CONFIG_TDLS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	.tdls_mgmt = cfg80211_rtw_tdls_mgmt,
+	.tdls_oper = cfg80211_rtw_tdls_oper,
+#endif /* CONFIG_TDLS */
+
+#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	.sched_scan_start = cfg80211_rtw_sched_scan_start,
+	.sched_scan_stop = cfg80211_rtw_sched_scan_stop,
+	.suspend = cfg80211_rtw_suspend,
+	.resume = cfg80211_rtw_resume,
+#endif /* CONFIG_PNO_SUPPORT */
+#ifdef CONFIG_RFKILL_POLL
+	.rfkill_poll = cfg80211_rtw_rfkill_poll,
+#endif
+#if defined(CONFIG_RTW_HOSTAPD_ACS) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
+	.dump_survey = rtw_hostapd_acs_dump_survey,
+#endif
+};
+
+struct wiphy *rtw_wiphy_alloc(_adapter *padapter, struct device *dev)
+{
+	struct wiphy *wiphy;
+	struct rtw_wiphy_data *wiphy_data;
+
+	/* wiphy */
+	wiphy = wiphy_new(&rtw_cfg80211_ops, sizeof(struct rtw_wiphy_data));
+	if (!wiphy) {
+		RTW_INFO("Couldn't allocate wiphy device\n");
+		goto exit;
+	}
+	set_wiphy_dev(wiphy, dev);
+
+	/* wiphy_data */
+	wiphy_data = rtw_wiphy_priv(wiphy);
+	wiphy_data->dvobj = adapter_to_dvobj(padapter);
+#ifndef RTW_SINGLE_WIPHY
+	wiphy_data->adapter = padapter;
+#endif
+
+	rtw_cfg80211_preinit_wiphy(padapter, wiphy);
+
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+exit:
+	return wiphy;
+}
+
+void rtw_wiphy_free(struct wiphy *wiphy)
+{
+	if (!wiphy)
+		return;
+
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+	if (wiphy->bands[NL80211_BAND_2GHZ]) {
+		rtw_spt_band_free(wiphy->bands[NL80211_BAND_2GHZ]);
+		wiphy->bands[NL80211_BAND_2GHZ] = NULL;
+	}
+	if (wiphy->bands[NL80211_BAND_5GHZ]) {
+		rtw_spt_band_free(wiphy->bands[NL80211_BAND_5GHZ]);
+		wiphy->bands[NL80211_BAND_5GHZ] = NULL;
+	}
+
+	wiphy_free(wiphy);
+}
+
+int rtw_wiphy_register(struct wiphy *wiphy)
+{
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
+	rtw_cfgvendor_attach(wiphy);
+#endif
+
+	rtw_regd_init(wiphy);
+
+	return wiphy_register(wiphy);
+}
+
+void rtw_wiphy_unregister(struct wiphy *wiphy)
+{
+	RTW_INFO(FUNC_WIPHY_FMT"\n", FUNC_WIPHY_ARG(wiphy));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
+	rtw_cfgvendor_detach(wiphy);
+#endif
+
+	#if defined(RTW_DEDICATED_P2P_DEVICE)
+	rtw_pd_iface_free(wiphy);
+	#endif
+
+	return wiphy_unregister(wiphy);
+}
+
+int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy)
+{
+	int ret = 0;
+	struct net_device *pnetdev = padapter->pnetdev;
+	struct wireless_dev *wdev;
+	struct rtw_wdev_priv *pwdev_priv;
+
+	RTW_INFO("%s(padapter=%p)\n", __func__, padapter);
+
+	/*  wdev */
+	wdev = (struct wireless_dev *)rtw_zmalloc(sizeof(struct wireless_dev));
+	if (!wdev) {
+		RTW_INFO("Couldn't allocate wireless device\n");
+		ret = -ENOMEM;
+		goto exit;
+	}
+	wdev->wiphy = wiphy;
+	wdev->netdev = pnetdev;
+
+	wdev->iftype = NL80211_IFTYPE_STATION;	/* will be init in rtw_hal_init() */
+											/* Must sync with _rtw_init_mlme_priv() */
+											/* pmlmepriv->fw_state = WIFI_STATION_STATE */
+	/* wdev->iftype = NL80211_IFTYPE_MONITOR; */ /* for rtw_setopmode_cmd() in cfg80211_rtw_change_iface() */
+	padapter->rtw_wdev = wdev;
+	pnetdev->ieee80211_ptr = wdev;
+
+	/* init pwdev_priv */
+	pwdev_priv = adapter_wdev_data(padapter);
+	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;
+	_rtw_spinlock_init(&pwdev_priv->scan_req_lock);
+	pwdev_priv->connect_req = NULL;
+	_rtw_spinlock_init(&pwdev_priv->connect_req_lock);
+
+	pwdev_priv->p2p_enabled = _FALSE;
+	pwdev_priv->probe_resp_ie_update_time = rtw_get_current_time();
+	pwdev_priv->provdisc_req_issued = _FALSE;
+	rtw_wdev_invit_info_init(&pwdev_priv->invit_info);
+	rtw_wdev_nego_info_init(&pwdev_priv->nego_info);
+
+	pwdev_priv->bandroid_scan = _FALSE;
+
+	if (padapter->registrypriv.power_mgnt != PS_MODE_ACTIVE)
+		pwdev_priv->power_mgmt = _TRUE;
+	else
+		pwdev_priv->power_mgmt = _FALSE;
+
+	_rtw_mutex_init(&pwdev_priv->roch_mutex);
+
+#ifdef CONFIG_CONCURRENT_MODE
+	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
+#endif
+
+exit:
+	return ret;
+}
+
+void rtw_wdev_free(struct wireless_dev *wdev)
+{
+	if (!wdev)
+		return;
+
+	RTW_INFO("%s(wdev=%p)\n", __func__, wdev);
+
+	if (wdev_to_ndev(wdev)) {
+		_adapter *adapter = (_adapter *)rtw_netdev_priv(wdev_to_ndev(wdev));
+		struct rtw_wdev_priv *wdev_priv = adapter_wdev_data(adapter);
+		_irqL irqL;
+
+		_rtw_spinlock_free(&wdev_priv->scan_req_lock);
+
+		_enter_critical_bh(&wdev_priv->connect_req_lock, &irqL);
+		rtw_wdev_free_connect_req(wdev_priv);
+		_exit_critical_bh(&wdev_priv->connect_req_lock, &irqL);
+		_rtw_spinlock_free(&wdev_priv->connect_req_lock);
+
+		_rtw_mutex_free(&wdev_priv->roch_mutex);
+	}
+
+	rtw_mfree((u8 *)wdev, sizeof(struct wireless_dev));
+}
+
+void rtw_wdev_unregister(struct wireless_dev *wdev)
+{
+	struct net_device *ndev;
+	_adapter *adapter;
+	struct rtw_wdev_priv *pwdev_priv;
+
+	if (!wdev)
+		return;
+
+	RTW_INFO("%s(wdev=%p)\n", __func__, wdev);
+
+	ndev = wdev_to_ndev(wdev);
+	if (!ndev)
+		return;
+
+	adapter = (_adapter *)rtw_netdev_priv(ndev);
+	pwdev_priv = adapter_wdev_data(adapter);
+
+	rtw_cfg80211_indicate_scan_done(adapter, _TRUE);
+
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)) || defined(COMPAT_KERNEL_RELEASE)
+	if (wdev->current_bss) {
+		RTW_INFO(FUNC_ADPT_FMT" clear current_bss by cfg80211_disconnected\n", FUNC_ADPT_ARG(adapter));
+		rtw_cfg80211_indicate_disconnect(adapter, 0, 1);
+	}
+	#endif
+
+	if (pwdev_priv->pmon_ndev) {
+		RTW_INFO("%s, unregister monitor interface\n", __func__);
+		unregister_netdev(pwdev_priv->pmon_ndev);
+	}
+}
+
+int rtw_cfg80211_ndev_res_alloc(_adapter *adapter)
+{
+	int ret = _FAIL;
+
+#if !defined(RTW_SINGLE_WIPHY)
+	struct wiphy *wiphy;
+	struct device *dev = dvobj_to_dev(adapter_to_dvobj(adapter));
+
+	wiphy = rtw_wiphy_alloc(adapter, dev);
+	if (wiphy == NULL)
+		goto exit;
+
+	adapter->wiphy = wiphy;
+#endif
+
+	if (rtw_wdev_alloc(adapter, adapter_to_wiphy(adapter)) == 0)
+		ret = _SUCCESS;
+
+#if !defined(RTW_SINGLE_WIPHY)
+	if (ret != _SUCCESS) {
+		rtw_wiphy_free(wiphy);
+		adapter->wiphy = NULL;
+	}
+#endif
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_ndev_res_free(_adapter *adapter)
+{
+	rtw_wdev_free(adapter->rtw_wdev);
+	adapter->rtw_wdev = NULL;
+#if !defined(RTW_SINGLE_WIPHY)
+	rtw_wiphy_free(adapter_to_wiphy(adapter));
+	adapter->wiphy = NULL;
+#endif
+}
+
+int rtw_cfg80211_ndev_res_register(_adapter *adapter)
+{
+	int ret = _FAIL;
+
+#if !defined(RTW_SINGLE_WIPHY)
+	if (rtw_wiphy_register(adapter_to_wiphy(adapter)) < 0) {
+		RTW_INFO("%s rtw_wiphy_register fail for if%d\n", __func__, (adapter->iface_id + 1));
+		goto exit;
+	}
+
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_init_rfkill(adapter_to_wiphy(adapter));
+#endif
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_ndev_res_unregister(_adapter *adapter)
+{
+	rtw_wdev_unregister(adapter->rtw_wdev);
+}
+
+int rtw_cfg80211_dev_res_alloc(struct dvobj_priv *dvobj)
+{
+	int ret = _FAIL;
+
+#if defined(RTW_SINGLE_WIPHY)
+	struct wiphy *wiphy;
+	struct device *dev = dvobj_to_dev(dvobj);
+
+	wiphy = rtw_wiphy_alloc(dvobj_get_primary_adapter(dvobj), dev);
+	if (wiphy == NULL)
+		goto exit;
+
+	dvobj->wiphy = wiphy;
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_dev_res_free(struct dvobj_priv *dvobj)
+{
+#if defined(RTW_SINGLE_WIPHY)
+	rtw_wiphy_free(dvobj_to_wiphy(dvobj));
+	dvobj->wiphy = NULL;
+#endif
+}
+
+int rtw_cfg80211_dev_res_register(struct dvobj_priv *dvobj)
+{
+	int ret = _FAIL;
+
+#if defined(RTW_SINGLE_WIPHY)
+	if (rtw_wiphy_register(dvobj_to_wiphy(dvobj)) != 0)
+		goto exit;
+
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_init_rfkill(dvobj_to_wiphy(dvobj));
+#endif
+#endif
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_cfg80211_dev_res_unregister(struct dvobj_priv *dvobj)
+{
+#if defined(RTW_SINGLE_WIPHY)
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_deinit_rfkill(dvobj_to_wiphy(dvobj));
+#endif
+	rtw_wiphy_unregister(dvobj_to_wiphy(dvobj));
+#endif
+}
+
+#endif /* CONFIG_IOCTL_CFG80211 */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.h
index 6e6f88d8ac09..6b9b9c6dbb80 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_cfg80211.h
@@ -1,212 +1,399 @@
-/******************************************************************************
- *
- * 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __IOCTL_CFG80211_H__
-#define __IOCTL_CFG80211_H__ 
-
-
-#if defined(RTW_USE_CFG80211_STA_EVENT)
-	#undef CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER
-#endif
-
-struct rtw_wdev_invit_info {
-	u8 state; /* 0: req, 1:rep */
-	u8 peer_mac[ETH_ALEN];
-	u8 active;
-	u8 token;
-	u8 flags;
-	u8 status;
-	u8 req_op_ch;
-	u8 rsp_op_ch;
-};
-
-#define rtw_wdev_invit_info_init(invit_info) \
-	do { \
-		(invit_info)->state = 0xff; \
-		_rtw_memset((invit_info)->peer_mac, 0, ETH_ALEN); \
-		(invit_info)->active = 0xff; \
-		(invit_info)->token = 0; \
-		(invit_info)->flags = 0x00; \
-		(invit_info)->status = 0xff; \
-		(invit_info)->req_op_ch = 0; \
-		(invit_info)->rsp_op_ch = 0; \
-	} while (0)
-
-struct rtw_wdev_nego_info {
-	u8 state; /* 0: req, 1:rep, 2:conf */
-	u8 peer_mac[ETH_ALEN];
-	u8 active;
-	u8 token;
-	u8 status;
-	u8 req_intent;
-	u8 req_op_ch;
-	u8 req_listen_ch;
-	u8 rsp_intent;
-	u8 rsp_op_ch;
-	u8 conf_op_ch;
-};
-
-#define rtw_wdev_nego_info_init(nego_info) \
-	do { \
-		(nego_info)->state = 0xff; \
-		_rtw_memset((nego_info)->peer_mac, 0, ETH_ALEN); \
-		(nego_info)->active = 0xff; \
-		(nego_info)->token = 0; \
-		(nego_info)->status = 0xff; \
-		(nego_info)->req_intent = 0xff; \
-		(nego_info)->req_op_ch = 0; \
-		(nego_info)->req_listen_ch = 0; \
-		(nego_info)->rsp_intent = 0xff; \
-		(nego_info)->rsp_op_ch = 0; \
-		(nego_info)->conf_op_ch = 0; \
-	} while (0)
-
-struct rtw_wdev_priv
-{	
-	struct wireless_dev *rtw_wdev;
-	
-	_adapter *padapter;
-
-	struct cfg80211_scan_request *scan_request;
-	_lock scan_req_lock;
-
-	struct net_device *pmon_ndev;//for monitor interface
-	char ifname_mon[IFNAMSIZ + 1]; //interface name for monitor interface
-
-	u8 p2p_enabled;
-
-	u8 provdisc_req_issued;
-
-	struct rtw_wdev_invit_info invit_info;
-	struct rtw_wdev_nego_info nego_info;
-
-	u8 bandroid_scan;
-	bool block;
-	bool block_scan;
-	bool power_mgmt;
-
-	/* report mgmt_frame registered */
-	u16 report_mgmt;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	ATOMIC_T ro_ch_to;
-	ATOMIC_T switch_ch_to;	
-#endif	
-	
-};
-
-#define wiphy_to_adapter(x) (*((_adapter**)wiphy_priv(x)))
-
-#define wdev_to_ndev(w) ((w)->netdev)
-#define wdev_to_wiphy(w) ((w)->wiphy)
-#define ndev_to_wdev(n) ((n)->ieee80211_ptr)
-
-#define WIPHY_FMT "%s"
-#define WIPHY_ARG(wiphy) wiphy_name(wiphy)
-#define FUNC_WIPHY_FMT "%s("WIPHY_FMT")"
-#define FUNC_WIPHY_ARG(wiphy) __func__, WIPHY_ARG(wiphy)
-
-#define SET_CFG80211_REPORT_MGMT(w, t, v) (w->report_mgmt |= (v?BIT(t >> 4):0))
-#define GET_CFG80211_REPORT_MGMT(w, t) ((w->report_mgmt & BIT(t >> 4)) > 0)
-
-struct wiphy *rtw_wiphy_alloc(_adapter *padapter, struct device *dev);
-void rtw_wiphy_free(struct wiphy *wiphy);
-int rtw_wiphy_register(struct wiphy *wiphy);
-void rtw_wiphy_unregister(struct wiphy *wiphy);
-
-int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy);
-void rtw_wdev_free(struct wireless_dev *wdev);
-void rtw_wdev_unregister(struct wireless_dev *wdev);
-
-int rtw_cfg80211_ndev_res_alloc(_adapter *adapter);
-void rtw_cfg80211_ndev_res_free(_adapter *adapter);
-int rtw_cfg80211_ndev_res_register(_adapter *adapter);
-void rtw_cfg80211_ndev_res_unregister(_adapter *adapter);
-
-int rtw_cfg80211_dev_res_alloc(struct dvobj_priv *dvobj);
-void rtw_cfg80211_dev_res_free(struct dvobj_priv *dvobj);
-int rtw_cfg80211_dev_res_register(struct dvobj_priv *dvobj);
-void rtw_cfg80211_dev_res_unregister(struct dvobj_priv *dvobj);
-
-void rtw_cfg80211_init_wiphy(_adapter *padapter);
-
-void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork);
-void rtw_cfg80211_surveydone_event_callback(_adapter *padapter);
-struct cfg80211_bss *rtw_cfg80211_inform_bss(_adapter *padapter, struct wlan_network *pnetwork);
-int rtw_cfg80211_check_bss(_adapter *padapter);
-void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter);
-void rtw_cfg80211_indicate_connect(_adapter *padapter);
-void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated);
-void rtw_cfg80211_indicate_scan_done(_adapter *adapter, bool aborted);
-u32 rtw_cfg80211_wait_scan_req_empty(_adapter *adapter, u32 timeout_ms);
-
-#ifdef CONFIG_AP_MODE
-void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len);
-void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, unsigned char *da, unsigned short reason);
-#endif //CONFIG_AP_MODE
-
-void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len);
-void rtw_cfg80211_rx_p2p_action_public(_adapter *padapter, u8 *pmgmt_frame, uint frame_len);
-void rtw_cfg80211_rx_action_p2p(_adapter *padapter, u8 *pmgmt_frame, uint frame_len);
-void rtw_cfg80211_rx_action(_adapter *adapter, u8 *frame, uint frame_len, const char*msg);
-void rtw_cfg80211_rx_probe_request(_adapter *padapter, u8 *pmgmt_frame, uint frame_len);
-
-int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len, int type);
-
-bool rtw_cfg80211_pwr_mgmt(_adapter *adapter);
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,4,0))  && !defined(COMPAT_KERNEL_RELEASE)
-#define rtw_cfg80211_rx_mgmt(adapter, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt((adapter)->pnetdev, freq, buf, len, gfp)
-#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3,6,0))
-#define rtw_cfg80211_rx_mgmt(adapter, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt((adapter)->pnetdev, freq, sig_dbm, buf, len, gfp)
-#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3,12,0))
-#define rtw_cfg80211_rx_mgmt(adapter, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt((adapter)->rtw_wdev, freq, sig_dbm, buf, len, gfp)
-#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3 , 18 , 0))
-#define rtw_cfg80211_rx_mgmt(adapter , freq , sig_dbm , buf , len , gfp) cfg80211_rx_mgmt((adapter)->rtw_wdev , freq , sig_dbm , buf , len , 0 , gfp)
-#else
-#define rtw_cfg80211_rx_mgmt(adapter , freq , sig_dbm , buf , len , gfp) cfg80211_rx_mgmt((adapter)->rtw_wdev , freq , sig_dbm , buf , len , 0)
-#endif
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,4,0))  && !defined(COMPAT_KERNEL_RELEASE)
-#define rtw_cfg80211_send_rx_assoc(adapter, bss, buf, len) cfg80211_send_rx_assoc((adapter)->pnetdev, buf, len)
-#else
-#define rtw_cfg80211_send_rx_assoc(adapter, bss, buf, len) cfg80211_send_rx_assoc((adapter)->pnetdev, bss, buf, len)
-#endif
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,6,0))
-#define rtw_cfg80211_mgmt_tx_status(adapter, cookie, buf, len, ack, gfp) cfg80211_mgmt_tx_status((adapter)->pnetdev, cookie, buf, len, ack, gfp)
-#else
-#define rtw_cfg80211_mgmt_tx_status(adapter, cookie, buf, len, ack, gfp) cfg80211_mgmt_tx_status((adapter)->rtw_wdev, cookie, buf, len, ack, gfp)
-#endif
-
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,6,0))
-#define rtw_cfg80211_ready_on_channel(adapter, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel((adapter)->pnetdev, cookie, chan, channel_type, duration, gfp)
-#define rtw_cfg80211_remain_on_channel_expired(adapter, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired((adapter)->pnetdev, cookie, chan, chan_type, gfp)
-#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3,8,0))
-#define rtw_cfg80211_ready_on_channel(adapter, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel((adapter)->rtw_wdev, cookie, chan, channel_type, duration, gfp)
-#define rtw_cfg80211_remain_on_channel_expired(adapter, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired((adapter)->rtw_wdev, cookie, chan, chan_type, gfp)
-#else
-#define rtw_cfg80211_ready_on_channel(adapter, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel((adapter)->rtw_wdev, cookie, chan, duration, gfp)
-#define rtw_cfg80211_remain_on_channel_expired(adapter, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired((adapter)->rtw_wdev, cookie, chan, gfp)
-#endif
-
-#include "rtw_cfgvendor.h"
-
-#endif //__IOCTL_CFG80211_H__
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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__
+
+#define RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT		BIT0
+#define RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT	BIT1
+
+#ifndef RTW_CFG80211_BLOCK_STA_DISCON_EVENT
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
+#define RTW_CFG80211_BLOCK_STA_DISCON_EVENT (RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT)
+#else
+#define RTW_CFG80211_BLOCK_STA_DISCON_EVENT (RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT | RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+#endif
+#endif
+
+#if defined(RTW_USE_CFG80211_STA_EVENT)
+	#undef CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER
+#endif
+
+#ifndef RTW_P2P_GROUP_INTERFACE
+	#define RTW_P2P_GROUP_INTERFACE 0
+#endif
+
+/*
+* (RTW_P2P_GROUP_INTERFACE, RTW_DEDICATED_P2P_DEVICE)
+* (0, 0): wlan0 + p2p0(PD+PG)
+* (1, 0): wlan0(with PD) + dynamic PGs
+* (1, 1): wlan0 (with dynamic PD wdev) + dynamic PGs
+*/
+
+#if RTW_P2P_GROUP_INTERFACE
+	#ifndef CONFIG_RTW_DYNAMIC_NDEV
+		#define CONFIG_RTW_DYNAMIC_NDEV
+	#endif
+	#ifndef RTW_SINGLE_WIPHY
+		#define RTW_SINGLE_WIPHY
+	#endif
+	#ifndef CONFIG_RADIO_WORK
+		#define CONFIG_RADIO_WORK
+	#endif
+	#ifndef RTW_DEDICATED_P2P_DEVICE
+		#define RTW_DEDICATED_P2P_DEVICE
+	#endif
+#endif
+
+#ifndef CONFIG_RADIO_WORK
+#define RTW_ROCH_DURATION_ENLARGE
+#define RTW_ROCH_BACK_OP
+#endif
+
+#if !defined(CONFIG_P2P) && RTW_P2P_GROUP_INTERFACE
+	#error "RTW_P2P_GROUP_INTERFACE can't be enabled when CONFIG_P2P is disabled\n"
+#endif
+
+#if !RTW_P2P_GROUP_INTERFACE && defined(RTW_DEDICATED_P2P_DEVICE)
+	#error "RTW_DEDICATED_P2P_DEVICE can't be enabled when RTW_P2P_GROUP_INTERFACE is disabled\n"
+#endif
+
+#if defined(RTW_DEDICATED_P2P_DEVICE) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 7, 0))
+	#error "RTW_DEDICATED_P2P_DEVICE can't be enabled when kernel < 3.7.0\n"
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
+		#error "CONFIG_RTW_MESH can't be enabled when kernel < 3.10.0\n"
+	#endif
+#endif
+
+struct rtw_wdev_invit_info {
+	u8 state; /* 0: req, 1:rep */
+	u8 peer_mac[ETH_ALEN];
+	u8 group_bssid[ETH_ALEN];
+	u8 active;
+	u8 token;
+	u8 flags;
+	u8 status;
+	u8 req_op_ch;
+	u8 rsp_op_ch;
+};
+
+#define rtw_wdev_invit_info_init(invit_info) \
+	do { \
+		(invit_info)->state = 0xff; \
+		_rtw_memset((invit_info)->peer_mac, 0, ETH_ALEN); \
+		_rtw_memset((invit_info)->group_bssid, 0, ETH_ALEN); \
+		(invit_info)->active = 0xff; \
+		(invit_info)->token = 0; \
+		(invit_info)->flags = 0x00; \
+		(invit_info)->status = 0xff; \
+		(invit_info)->req_op_ch = 0; \
+		(invit_info)->rsp_op_ch = 0; \
+	} while (0)
+
+struct rtw_wdev_nego_info {
+	u8 state; /* 0: req, 1:rep, 2:conf */
+	u8 iface_addr[ETH_ALEN];
+	u8 peer_mac[ETH_ALEN];
+	u8 peer_iface_addr[ETH_ALEN];
+	u8 active;
+	u8 token;
+	u8 status;
+	u8 req_intent;
+	u8 req_op_ch;
+	u8 req_listen_ch;
+	u8 rsp_intent;
+	u8 rsp_op_ch;
+	u8 conf_op_ch;
+};
+
+#define rtw_wdev_nego_info_init(nego_info) \
+	do { \
+		(nego_info)->state = 0xff; \
+		_rtw_memset((nego_info)->iface_addr, 0, ETH_ALEN); \
+		_rtw_memset((nego_info)->peer_mac, 0, ETH_ALEN); \
+		_rtw_memset((nego_info)->peer_iface_addr, 0, ETH_ALEN); \
+		(nego_info)->active = 0xff; \
+		(nego_info)->token = 0; \
+		(nego_info)->status = 0xff; \
+		(nego_info)->req_intent = 0xff; \
+		(nego_info)->req_op_ch = 0; \
+		(nego_info)->req_listen_ch = 0; \
+		(nego_info)->rsp_intent = 0xff; \
+		(nego_info)->rsp_op_ch = 0; \
+		(nego_info)->conf_op_ch = 0; \
+	} while (0)
+
+struct rtw_wdev_priv {
+	struct wireless_dev *rtw_wdev;
+
+	_adapter *padapter;
+
+	#if RTW_CFG80211_BLOCK_STA_DISCON_EVENT
+	u8 not_indic_disco;
+	#endif
+
+	struct cfg80211_scan_request *scan_request;
+	_lock scan_req_lock;
+
+	struct cfg80211_connect_params *connect_req;
+	_lock connect_req_lock;
+
+	struct net_device *pmon_ndev;/* for monitor interface */
+	char ifname_mon[IFNAMSIZ + 1]; /* interface name for monitor interface */
+
+	u8 p2p_enabled;
+	systime probe_resp_ie_update_time;
+
+	u8 provdisc_req_issued;
+
+	struct rtw_wdev_invit_info invit_info;
+	struct rtw_wdev_nego_info nego_info;
+
+	u8 bandroid_scan;
+	bool block;
+	bool block_scan;
+	bool power_mgmt;
+
+	/* report mgmt_frame registered */
+	u16 report_mgmt;
+
+	u8 is_mgmt_tx;
+	u16 mgmt_tx_cookie;
+
+	_mutex roch_mutex;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	ATOMIC_T switch_ch_to;
+#endif
+
+};
+
+bool rtw_cfg80211_is_connect_requested(_adapter *adapter);
+
+#if RTW_CFG80211_BLOCK_STA_DISCON_EVENT
+#define rtw_wdev_not_indic_disco(rtw_wdev_data) ((rtw_wdev_data)->not_indic_disco)
+#define rtw_wdev_set_not_indic_disco(rtw_wdev_data, val) do { (rtw_wdev_data)->not_indic_disco = (val); } while (0)
+#else
+#define rtw_wdev_not_indic_disco(rtw_wdev_data) 0
+#define rtw_wdev_set_not_indic_disco(rtw_wdev_data, val) do {} while (0)
+#endif
+
+#define rtw_wdev_free_connect_req(rtw_wdev_data) \
+	do { \
+		if ((rtw_wdev_data)->connect_req) { \
+			rtw_mfree((u8 *)(rtw_wdev_data)->connect_req, sizeof(*(rtw_wdev_data)->connect_req)); \
+			(rtw_wdev_data)->connect_req = NULL; \
+		} \
+	} while (0)
+
+#define wdev_to_ndev(w) ((w)->netdev)
+#define wdev_to_wiphy(w) ((w)->wiphy)
+#define ndev_to_wdev(n) ((n)->ieee80211_ptr)
+
+struct rtw_wiphy_data {
+	struct dvobj_priv *dvobj;
+
+#ifndef RTW_SINGLE_WIPHY
+	_adapter *adapter;
+#endif
+
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+	struct wireless_dev *pd_wdev; /* P2P device wdev */
+#endif
+};
+
+#define rtw_wiphy_priv(wiphy) ((struct rtw_wiphy_data *)wiphy_priv(wiphy))
+#define wiphy_to_dvobj(wiphy) (((struct rtw_wiphy_data *)wiphy_priv(wiphy))->dvobj)
+#ifdef RTW_SINGLE_WIPHY
+#define wiphy_to_adapter(wiphy) (dvobj_get_primary_adapter(wiphy_to_dvobj(wiphy)))
+#else
+#define wiphy_to_adapter(wiphy) (((struct rtw_wiphy_data *)wiphy_priv(wiphy))->adapter)
+#endif
+
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+#define wiphy_to_pd_wdev(wiphy) (rtw_wiphy_priv(wiphy)->pd_wdev)
+#else
+#define wiphy_to_pd_wdev(wiphy) NULL
+#endif
+
+#define WIPHY_FMT "%s"
+#define WIPHY_ARG(wiphy) wiphy_name(wiphy)
+#define FUNC_WIPHY_FMT "%s("WIPHY_FMT")"
+#define FUNC_WIPHY_ARG(wiphy) __func__, WIPHY_ARG(wiphy)
+
+#define SET_CFG80211_REPORT_MGMT(w, t, v) (w->report_mgmt |= (v ? BIT(t >> 4) : 0))
+#define GET_CFG80211_REPORT_MGMT(w, t) ((w->report_mgmt & BIT(t >> 4)) > 0)
+
+struct wiphy *rtw_wiphy_alloc(_adapter *padapter, struct device *dev);
+void rtw_wiphy_free(struct wiphy *wiphy);
+int rtw_wiphy_register(struct wiphy *wiphy);
+void rtw_wiphy_unregister(struct wiphy *wiphy);
+
+int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy);
+void rtw_wdev_free(struct wireless_dev *wdev);
+void rtw_wdev_unregister(struct wireless_dev *wdev);
+
+int rtw_cfg80211_ndev_res_alloc(_adapter *adapter);
+void rtw_cfg80211_ndev_res_free(_adapter *adapter);
+int rtw_cfg80211_ndev_res_register(_adapter *adapter);
+void rtw_cfg80211_ndev_res_unregister(_adapter *adapter);
+
+int rtw_cfg80211_dev_res_alloc(struct dvobj_priv *dvobj);
+void rtw_cfg80211_dev_res_free(struct dvobj_priv *dvobj);
+int rtw_cfg80211_dev_res_register(struct dvobj_priv *dvobj);
+void rtw_cfg80211_dev_res_unregister(struct dvobj_priv *dvobj);
+
+void rtw_cfg80211_init_wdev_data(_adapter *padapter);
+void rtw_cfg80211_init_wiphy(_adapter *padapter);
+
+void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork);
+void rtw_cfg80211_surveydone_event_callback(_adapter *padapter);
+struct cfg80211_bss *rtw_cfg80211_inform_bss(_adapter *padapter, struct wlan_network *pnetwork);
+int rtw_cfg80211_check_bss(_adapter *padapter);
+void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter);
+void rtw_cfg80211_indicate_connect(_adapter *padapter);
+void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated);
+void rtw_cfg80211_indicate_scan_done(_adapter *adapter, bool aborted);
+u32 rtw_cfg80211_wait_scan_req_empty(_adapter *adapter, u32 timeout_ms);
+
+#ifdef CONFIG_CONCURRENT_MODE
+u8 rtw_cfg80211_scan_via_buddy(_adapter *padapter, struct cfg80211_scan_request *request);
+void rtw_cfg80211_indicate_scan_done_for_buddy(_adapter *padapter, bool bscan_aborted);
+#endif
+
+#ifdef CONFIG_AP_MODE
+void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len);
+void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, const u8 *da, unsigned short reason);
+#endif /* CONFIG_AP_MODE */
+
+#ifdef CONFIG_P2P
+void rtw_cfg80211_set_is_roch(_adapter *adapter, bool val);
+bool rtw_cfg80211_get_is_roch(_adapter *adapter);
+bool rtw_cfg80211_is_ro_ch_once(_adapter *adapter);
+void rtw_cfg80211_set_last_ro_ch_time(_adapter *adapter);
+s32 rtw_cfg80211_get_last_ro_ch_passing_ms(_adapter *adapter);
+
+int rtw_cfg80211_iface_has_p2p_group_cap(_adapter *adapter);
+int rtw_cfg80211_is_p2p_scan(_adapter *adapter);
+#if defined(RTW_DEDICATED_P2P_DEVICE)
+int rtw_cfg80211_redirect_pd_wdev(struct wiphy *wiphy, u8 *ra, struct wireless_dev **wdev);
+int rtw_cfg80211_is_scan_by_pd_wdev(_adapter *adapter);
+int rtw_pd_iface_alloc(struct wiphy *wiphy, const char *name, struct wireless_dev **pd_wdev);
+void rtw_pd_iface_free(struct wiphy *wiphy);
+#endif
+#endif /* CONFIG_P2P */
+
+void rtw_cfg80211_set_is_mgmt_tx(_adapter *adapter, u8 val);
+u8 rtw_cfg80211_get_is_mgmt_tx(_adapter *adapter);
+u8 rtw_mgnt_tx_handler(_adapter *adapter, u8 *buf);
+
+void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len);
+
+void rtw_cfg80211_rx_p2p_action_public(_adapter *padapter, union recv_frame *rframe);
+void rtw_cfg80211_rx_action_p2p(_adapter *padapter, union recv_frame *rframe);
+void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const char *msg);
+void rtw_cfg80211_rx_mframe(_adapter *adapter, union recv_frame *rframe, const char *msg);
+void rtw_cfg80211_rx_probe_request(_adapter *padapter, union recv_frame *rframe);
+
+int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len, int type);
+
+bool rtw_cfg80211_pwr_mgmt(_adapter *adapter);
+#ifdef CONFIG_RTW_80211K
+void rtw_cfg80211_rx_rrm_action(_adapter *adapter, union recv_frame *rframe);
+#endif
+
+#ifdef CONFIG_RFKILL_POLL
+void rtw_cfg80211_init_rfkill(struct wiphy *wiphy);
+void rtw_cfg80211_deinit_rfkill(struct wiphy *wiphy);
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0))  && !defined(COMPAT_KERNEL_RELEASE)
+#define rtw_cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt(wdev_to_ndev(wdev), freq, buf, len, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+#define rtw_cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt(wdev_to_ndev(wdev), freq, sig_dbm, buf, len, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 12, 0))
+#define rtw_cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp) cfg80211_rx_mgmt(wdev, freq, sig_dbm, buf, len, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3 , 18 , 0))
+#define rtw_cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , gfp) cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , 0 , gfp)
+#else
+#define rtw_cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , gfp) cfg80211_rx_mgmt(wdev , freq , sig_dbm , buf , len , 0)
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0))  && !defined(COMPAT_KERNEL_RELEASE)
+#define rtw_cfg80211_send_rx_assoc(adapter, bss, buf, len) cfg80211_send_rx_assoc((adapter)->pnetdev, buf, len)
+#else
+#define rtw_cfg80211_send_rx_assoc(adapter, bss, buf, len) cfg80211_send_rx_assoc((adapter)->pnetdev, bss, buf, len)
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+#define rtw_cfg80211_mgmt_tx_status(wdev, cookie, buf, len, ack, gfp) cfg80211_mgmt_tx_status(wdev_to_ndev(wdev), cookie, buf, len, ack, gfp)
+#else
+#define rtw_cfg80211_mgmt_tx_status(wdev, cookie, buf, len, ack, gfp) cfg80211_mgmt_tx_status(wdev, cookie, buf, len, ack, gfp)
+#endif
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
+#define rtw_cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel(wdev_to_ndev(wdev), cookie, chan, channel_type, duration, gfp)
+#define rtw_cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired(wdev_to_ndev(wdev), cookie, chan, chan_type, gfp)
+#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
+#define rtw_cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)
+#define rtw_cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp)
+#else
+#define rtw_cfg80211_ready_on_channel(wdev, cookie, chan, channel_type, duration, gfp)  cfg80211_ready_on_channel(wdev, cookie, chan, duration, gfp)
+#define rtw_cfg80211_remain_on_channel_expired(wdev, cookie, chan, chan_type, gfp) cfg80211_remain_on_channel_expired(wdev, cookie, chan, gfp)
+#endif
+
+#define rtw_cfg80211_connect_result(wdev, bssid, req_ie, req_ie_len, resp_ie, resp_ie_len, status, gfp) cfg80211_connect_result(wdev_to_ndev(wdev), bssid, req_ie, req_ie_len, resp_ie, resp_ie_len, status, gfp)
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 2, 0))
+#define rtw_cfg80211_disconnected(wdev, reason, ie, ie_len, locally_generated, gfp) cfg80211_disconnected(wdev_to_ndev(wdev), reason, ie, ie_len, gfp)
+#else
+#define rtw_cfg80211_disconnected(wdev, reason, ie, ie_len, locally_generated, gfp) cfg80211_disconnected(wdev_to_ndev(wdev), reason, ie, ie_len, locally_generated, gfp)
+#endif
+
+#ifdef CONFIG_RTW_80211R
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+#define rtw_cfg80211_ft_event(adapter, parm)  cfg80211_ft_event((adapter)->pnetdev, parm)
+#else
+	#error "Cannot support FT for KERNEL_VERSION < 3.10\n"
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+#define rtw_cfg80211_notify_new_peer_candidate(wdev, addr, ie, ie_len, gfp) cfg80211_notify_new_peer_candidate(wdev_to_ndev(wdev), addr, ie, ie_len, gfp)
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+u8 rtw_cfg80211_ch_switch_notify(_adapter *adapter, u8 ch, u8 bw, u8 offset, u8 ht);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 7, 0))
+#define NL80211_BAND_2GHZ IEEE80211_BAND_2GHZ
+#define NL80211_BAND_5GHZ IEEE80211_BAND_5GHZ
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#define NL80211_BAND_60GHZ IEEE80211_BAND_60GHZ
+#endif
+#define NUM_NL80211_BANDS IEEE80211_NUM_BANDS
+#endif
+
+#define rtw_band_to_nl80211_band(band) \
+	(band == BAND_ON_2_4G) ? NL80211_BAND_2GHZ : \
+	(band == BAND_ON_5G) ? NL80211_BAND_5GHZ : NUM_NL80211_BANDS
+
+#include "rtw_cfgvendor.h"
+
+#endif /* __IOCTL_CFG80211_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_linux.c
index 2e9d7e4611c5..2e488347d082 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_linux.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,20 +12,18 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _IOCTL_LINUX_C_
 
 #include <drv_types.h>
 #include <rtw_mp.h>
 #include <rtw_mp_ioctl.h>
 #include "../../hal/phydm/phydm_precomp.h"
+#ifdef RTW_HALMAC
+#include "../../hal/hal_halmac.h"
+#endif
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,27))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27))
 #define  iwe_stream_add_event(a, b, c, d, e)  iwe_stream_add_event(b, c, d, e)
 #define  iwe_stream_add_point(a, b, c, d, e)  iwe_stream_add_point(b, c, d, e)
 #endif
@@ -34,7 +33,7 @@ extern int rtw_ht_enable;
 #endif
 
 
-#define RTL_IOCTL_WPA_SUPPLICANT	SIOCIWFIRSTPRIV+30
+#define RTL_IOCTL_WPA_SUPPLICANT	(SIOCIWFIRSTPRIV+30)
 
 #define SCAN_ITEM_SIZE 768
 #define MAX_CUSTOM_LEN 64
@@ -44,7 +43,7 @@ extern int rtw_ht_enable;
 extern int ui_pid[3];
 #endif
 
-// combo scan
+/* combo scan */
 #define WEXT_CSCAN_AMOUNT 9
 #define WEXT_CSCAN_BUF_LEN		360
 #define WEXT_CSCAN_HEADER		"CSCAN S\x01\x00\x00S\x00"
@@ -63,37 +62,13 @@ extern u8 str_2char2num(u8 hch, u8 lch);
 extern void macstr2num(u8 *dst, u8 *src);
 extern u8 convert_ip_addr(u8 hch, u8 mch, u8 lch);
 
-u32 rtw_rates[] = {1000000,2000000,5500000,11000000,
-	6000000,9000000,12000000,18000000,24000000,36000000,48000000,54000000};
+u32 rtw_rates[] = {1000000, 2000000, 5500000, 11000000,
+	6000000, 9000000, 12000000, 18000000, 24000000, 36000000, 48000000, 54000000};
 
-static const char * const iw_operation_mode[] = 
-{ 
-	"Auto", "Ad-Hoc", "Managed",  "Master", "Repeater", "Secondary", "Monitor" 
+static const char *const iw_operation_mode[] = {
+	"Auto", "Ad-Hoc", "Managed",  "Master", "Repeater", "Secondary", "Monitor"
 };
 
-static int hex2num_i(char c)
-{
-	if (c >= '0' && c <= '9')
-		return c - '0';
-	if (c >= 'a' && c <= 'f')
-		return c - 'a' + 10;
-	if (c >= 'A' && c <= 'F')
-		return c - 'A' + 10;
-	return -1;
-}
-
-static int hex2byte_i(const char *hex)
-{
-	int a, b;
-	a = hex2num_i(*hex++);
-	if (a < 0)
-		return -1;
-	b = hex2num_i(*hex++);
-	if (b < 0)
-		return -1;
-	return (a << 4) | b;
-}
-
 /**
  * hwaddr_aton - Convert ASCII string to MAC address
  * @txt: MAC address as a string (e.g., "00:11:22:33:44:55")
@@ -127,25 +102,25 @@ static void indicate_wx_custom_event(_adapter *padapter, char *msg)
 	union iwreq_data wrqu;
 
 	if (strlen(msg) > IW_CUSTOM_MAX) {
-		DBG_871X("%s strlen(msg):%zu > IW_CUSTOM_MAX:%u\n", __FUNCTION__ , strlen(msg), IW_CUSTOM_MAX);
+		RTW_INFO("%s strlen(msg):%zu > IW_CUSTOM_MAX:%u\n", __FUNCTION__ , strlen(msg), IW_CUSTOM_MAX);
 		return;
 	}
 
-	buff = rtw_zmalloc(IW_CUSTOM_MAX+1);
-	if(!buff)
+	buff = rtw_zmalloc(IW_CUSTOM_MAX + 1);
+	if (!buff)
 		return;
 
 	_rtw_memcpy(buff, msg, strlen(msg));
-		
-	_rtw_memset(&wrqu,0,sizeof(wrqu));
+
+	_rtw_memset(&wrqu, 0, sizeof(wrqu));
 	wrqu.data.length = strlen(msg);
 
-	DBG_871X("%s %s\n", __FUNCTION__, buff);	
+	RTW_INFO("%s %s\n", __FUNCTION__, buff);
 #ifndef CONFIG_IOCTL_CFG80211
 	wireless_send_event(padapter->pnetdev, IWEVCUSTOM, &wrqu, buff);
 #endif
 
-	rtw_mfree(buff, IW_CUSTOM_MAX+1);
+	rtw_mfree(buff, IW_CUSTOM_MAX + 1);
 
 }
 
@@ -157,31 +132,29 @@ static void request_wps_pbc_event(_adapter *padapter)
 
 
 	buff = rtw_malloc(IW_CUSTOM_MAX);
-	if(!buff)
+	if (!buff)
 		return;
-		
+
 	_rtw_memset(buff, 0, IW_CUSTOM_MAX);
-		
-	p=buff;
-		
-	p+=sprintf(p, "WPS_PBC_START.request=TRUE");
-		
-	_rtw_memset(&wrqu,0,sizeof(wrqu));
-		
-	wrqu.data.length = p-buff;
-		
-	wrqu.data.length = (wrqu.data.length<IW_CUSTOM_MAX) ? wrqu.data.length:IW_CUSTOM_MAX;
-
-	DBG_871X("%s\n", __FUNCTION__);
-		
+
+	p = buff;
+
+	p += sprintf(p, "WPS_PBC_START.request=TRUE");
+
+	_rtw_memset(&wrqu, 0, sizeof(wrqu));
+
+	wrqu.data.length = p - buff;
+
+	wrqu.data.length = (wrqu.data.length < IW_CUSTOM_MAX) ? wrqu.data.length : IW_CUSTOM_MAX;
+
+	RTW_INFO("%s\n", __FUNCTION__);
+
 #ifndef CONFIG_IOCTL_CFG80211
 	wireless_send_event(padapter->pnetdev, IWEVCUSTOM, &wrqu, buff);
 #endif
 
-	if(buff)
-	{
+	if (buff)
 		rtw_mfree(buff, IW_CUSTOM_MAX);
-	}
 
 }
 
@@ -189,15 +162,15 @@ static void request_wps_pbc_event(_adapter *padapter)
 void rtw_request_wps_pbc_event(_adapter *padapter)
 {
 #ifdef RTK_DMP_PLATFORM
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,12))
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
 	kobject_uevent(&padapter->pnetdev->dev.kobj, KOBJ_NET_PBC);
 #else
 	kobject_hotplug(&padapter->pnetdev->class_dev.kobj, KOBJ_NET_PBC);
 #endif
 #else
 
-	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.
+	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;
 	}
 
@@ -207,16 +180,16 @@ void rtw_request_wps_pbc_event(_adapter *padapter)
 
 	rtw_led_control(padapter, LED_CTL_START_WPS_BOTTON);
 }
-#endif//#ifdef CONFIG_SUPPORT_HW_WPS_PBC
+#endif/* #ifdef CONFIG_SUPPORT_HW_WPS_PBC */
 
 void indicate_wx_scan_complete_event(_adapter *padapter)
-{	
+{
 	union iwreq_data wrqu;
-	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;	
+	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
 	_rtw_memset(&wrqu, 0, sizeof(union iwreq_data));
 
-	//DBG_871X("+rtw_indicate_wx_scan_complete_event\n");
+	/* RTW_INFO("+rtw_indicate_wx_scan_complete_event\n"); */
 #ifndef CONFIG_IOCTL_CFG80211
 	wireless_send_event(padapter->pnetdev, SIOCGIWSCAN, &wrqu, NULL);
 #endif
@@ -224,30 +197,30 @@ void indicate_wx_scan_complete_event(_adapter *padapter)
 
 
 void rtw_indicate_wx_assoc_event(_adapter *padapter)
-{	
+{
 	union iwreq_data wrqu;
 	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX*)(&(pmlmeinfo->network));
+	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 
 	_rtw_memset(&wrqu, 0, sizeof(union iwreq_data));
-	
-	wrqu.ap_addr.sa_family = ARPHRD_ETHER;	
-	
-	if(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)==_TRUE )
+
+	wrqu.ap_addr.sa_family = ARPHRD_ETHER;
+
+	if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)
 		_rtw_memcpy(wrqu.ap_addr.sa_data, pnetwork->MacAddress, ETH_ALEN);
 	else
 		_rtw_memcpy(wrqu.ap_addr.sa_data, pmlmepriv->cur_network.network.MacAddress, ETH_ALEN);
 
-	DBG_871X_LEVEL(_drv_always_, "assoc success\n");
+	RTW_PRINT("assoc success\n");
 #ifndef CONFIG_IOCTL_CFG80211
 	wireless_send_event(padapter->pnetdev, SIOCGIWAP, &wrqu, NULL);
 #endif
 }
 
 void rtw_indicate_wx_disassoc_event(_adapter *padapter)
-{	
+{
 	union iwreq_data wrqu;
 
 	_rtw_memset(&wrqu, 0, sizeof(union iwreq_data));
@@ -256,24 +229,24 @@ void rtw_indicate_wx_disassoc_event(_adapter *padapter)
 	_rtw_memset(wrqu.ap_addr.sa_data, 0, ETH_ALEN);
 
 #ifndef CONFIG_IOCTL_CFG80211
-	DBG_871X_LEVEL(_drv_always_, "indicate disassoc\n");
+	RTW_PRINT("indicate disassoc\n");
 	wireless_send_event(padapter->pnetdev, SIOCGIWAP, &wrqu, NULL);
 #endif
 }
 
 /*
 uint	rtw_is_cckrates_included(u8 *rate)
-{	
-		u32	i = 0;			
+{
+		u32	i = 0;
 
 		while(rate[i]!=0)
-		{		
-			if  (  (((rate[i]) & 0x7f) == 2)	|| (((rate[i]) & 0x7f) == 4) ||		
-			(((rate[i]) & 0x7f) == 11)  || (((rate[i]) & 0x7f) == 22) )		
-			return _TRUE;	
+		{
+			if  (  (((rate[i]) & 0x7f) == 2)	|| (((rate[i]) & 0x7f) == 4) ||
+			(((rate[i]) & 0x7f) == 11)  || (((rate[i]) & 0x7f) == 22) )
+			return _TRUE;
 			i++;
 		}
-		
+
 		return _FALSE;
 }
 
@@ -285,58 +258,51 @@ uint	rtw_is_cckratesonly_included(u8 *rate)
 	{
 			if  (  (((rate[i]) & 0x7f) != 2) && (((rate[i]) & 0x7f) != 4) &&
 				(((rate[i]) & 0x7f) != 11)  && (((rate[i]) & 0x7f) != 22) )
-			return _FALSE;		
+			return _FALSE;
 			i++;
 	}
-	
+
 	return _TRUE;
 }
 */
 
 static int search_p2p_wfd_ie(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop)
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop)
 {
 #ifdef CONFIG_P2P
 	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
 #ifdef CONFIG_WFD
-	if ( SCAN_RESULT_ALL == pwdinfo->wfd_info->scan_result_type )
-	{
+	if (SCAN_RESULT_ALL == pwdinfo->wfd_info->scan_result_type) {
 
-	}
-	else if ( ( SCAN_RESULT_P2P_ONLY == pwdinfo->wfd_info->scan_result_type ) || 
-		      ( SCAN_RESULT_WFD_TYPE == pwdinfo->wfd_info->scan_result_type ) )
-#endif // CONFIG_WFD
+	} else if ((SCAN_RESULT_P2P_ONLY == pwdinfo->wfd_info->scan_result_type) ||
+		(SCAN_RESULT_WFD_TYPE == pwdinfo->wfd_info->scan_result_type))
+#endif /* CONFIG_WFD */
 	{
-		if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		{
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
 			u32	blnGotP2PIE = _FALSE;
-			
-			//	User is doing the P2P device discovery
-			//	The prefix of SSID should be "DIRECT-" and the IE should contains the P2P IE.
-			//	If not, the driver should ignore this AP and go to the next AP.
 
-			//	Verifying the SSID
-			if ( _rtw_memcmp( pnetwork->network.Ssid.Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN ) )
-			{
+			/*	User is doing the P2P device discovery */
+			/*	The prefix of SSID should be "DIRECT-" and the IE should contains the P2P IE. */
+			/*	If not, the driver should ignore this AP and go to the next AP. */
+
+			/*	Verifying the SSID */
+			if (_rtw_memcmp(pnetwork->network.Ssid.Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN)) {
 				u32	p2pielen = 0;
 
-				//	Verifying the P2P IE
+				/*	Verifying the P2P IE */
 				if (rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen))
 					blnGotP2PIE = _TRUE;
 			}
 
-			if ( blnGotP2PIE == _FALSE )
-			{
+			if (blnGotP2PIE == _FALSE)
 				return _FALSE;
-			}
-			
+
 		}
 	}
 
 #ifdef CONFIG_WFD
-	if ( SCAN_RESULT_WFD_TYPE == pwdinfo->wfd_info->scan_result_type )
-	{
+	if (SCAN_RESULT_WFD_TYPE == pwdinfo->wfd_info->scan_result_type) {
 		u32	blnGotWFD = _FALSE;
 		u8 *wfd_ie;
 		uint wfd_ielen = 0;
@@ -348,71 +314,64 @@ static int search_p2p_wfd_ie(_adapter *padapter,
 
 			wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
 			if (wfd_devinfo) {
-				if ( pwdinfo->wfd_info->wfd_device_type == WFD_DEVINFO_PSINK )
-				{
-					//	the first two bits will indicate the WFD device type
-					if ( ( wfd_devinfo[ 1 ] & 0x03 ) == WFD_DEVINFO_SOURCE )
-					{
-						//	If this device is Miracast PSink device, the scan reuslt should just provide the Miracast source.
+				if (pwdinfo->wfd_info->wfd_device_type == WFD_DEVINFO_PSINK) {
+					/*	the first two bits will indicate the WFD device type */
+					if ((wfd_devinfo[1] & 0x03) == WFD_DEVINFO_SOURCE) {
+						/*	If this device is Miracast PSink device, the scan reuslt should just provide the Miracast source. */
 						blnGotWFD = _TRUE;
 					}
-				}
-				else if ( pwdinfo->wfd_info->wfd_device_type == WFD_DEVINFO_SOURCE )
-				{
-					//	the first two bits will indicate the WFD device type
-					if ( ( wfd_devinfo[ 1 ] & 0x03 ) == WFD_DEVINFO_PSINK )
-					{
-						//	If this device is Miracast source device, the scan reuslt should just provide the Miracast PSink.
-						//	Todo: How about the SSink?!
+				} else if (pwdinfo->wfd_info->wfd_device_type == WFD_DEVINFO_SOURCE) {
+					/*	the first two bits will indicate the WFD device type */
+					if ((wfd_devinfo[1] & 0x03) == WFD_DEVINFO_PSINK) {
+						/*	If this device is Miracast source device, the scan reuslt should just provide the Miracast PSink. */
+						/*	Todo: How about the SSink?! */
 						blnGotWFD = _TRUE;
 					}
 				}
 			}
 		}
-		
-		if ( blnGotWFD == _FALSE )
-		{
+
+		if (blnGotWFD == _FALSE)
 			return _FALSE;
-		}
 	}
-#endif // CONFIG_WFD
+#endif /* CONFIG_WFD */
 
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 	return _TRUE;
 }
- static inline char *iwe_stream_mac_addr_proess(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
-{	
-	/*  AP MAC address  */
+static inline char *iwe_stream_mac_addr_proess(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	/*  AP MAC address */
 	iwe->cmd = SIOCGIWAP;
 	iwe->u.ap_addr.sa_family = ARPHRD_ETHER;
 
 	_rtw_memcpy(iwe->u.ap_addr.sa_data, pnetwork->network.MacAddress, ETH_ALEN);
-	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_ADDR_LEN);	
+	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_ADDR_LEN);
 	return start;
 }
- static inline char * iwe_stream_essid_proess(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
+static inline char *iwe_stream_essid_proess(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
 {
-	
+
 	/* Add the ESSID */
 	iwe->cmd = SIOCGIWESSID;
-	iwe->u.data.flags = 1;	
+	iwe->u.data.flags = 1;
 	iwe->u.data.length = min((u16)pnetwork->network.Ssid.SsidLength, (u16)32);
-	start = iwe_stream_add_point(info, start, stop, iwe, pnetwork->network.Ssid.Ssid);		
+	start = iwe_stream_add_point(info, start, stop, iwe, pnetwork->network.Ssid.Ssid);
 	return start;
 }
 
- static inline char * iwe_stream_chan_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
+static inline char *iwe_stream_chan_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
 {
-	if(pnetwork->network.Configuration.DSConfig<1 /*|| pnetwork->network.Configuration.DSConfig>14*/)
+	if (pnetwork->network.Configuration.DSConfig < 1 /*|| pnetwork->network.Configuration.DSConfig>14*/)
 		pnetwork->network.Configuration.DSConfig = 1;
 
-	 /* Add frequency/channel */
+	/* Add frequency/channel */
 	iwe->cmd = SIOCGIWFREQ;
 	iwe->u.freq.m = rtw_ch2freq(pnetwork->network.Configuration.DSConfig) * 100000;
 	iwe->u.freq.e = 1;
@@ -420,12 +379,12 @@ static int search_p2p_wfd_ie(_adapter *padapter,
 	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_FREQ_LEN);
 	return start;
 }
- static inline char * iwe_stream_mode_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe,u16 cap)
+static inline char *iwe_stream_mode_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe, u16 cap)
 {
 	/* Add mode */
-	if(cap & (WLAN_CAPABILITY_IBSS |WLAN_CAPABILITY_BSS)){
+	if (cap & (WLAN_CAPABILITY_IBSS | WLAN_CAPABILITY_BSS)) {
 		iwe->cmd = SIOCGIWMODE;
 		if (cap & WLAN_CAPABILITY_BSS)
 			iwe->u.mode = IW_MODE_MASTER;
@@ -435,11 +394,11 @@ static int search_p2p_wfd_ie(_adapter *padapter,
 		start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_UINT_LEN);
 	}
 	return start;
- }
- static inline char * iwe_stream_encryption_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe,u16 cap)
-{	
+}
+static inline char *iwe_stream_encryption_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe, u16 cap)
+{
 
 	/* Add encryption capability */
 	iwe->cmd = SIOCGIWENCODE;
@@ -451,64 +410,55 @@ static int search_p2p_wfd_ie(_adapter *padapter,
 	start = iwe_stream_add_point(info, start, stop, iwe, pnetwork->network.Ssid.Ssid);
 	return start;
 
-}	
+}
 
- static inline char * iwe_stream_protocol_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
- {
- 	u16 ht_cap=_FALSE,vht_cap = _FALSE;
+static inline char *iwe_stream_protocol_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	u16 ht_cap = _FALSE, vht_cap = _FALSE;
 	u32 ht_ielen = 0, vht_ielen = 0;
 	char *p;
-	u8 ie_offset = (pnetwork->network.Reserved[0] == 2? 0:12);// Probe Request	
-		
-	//parsing HT_CAP_IE	
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength-ie_offset);	
-	if(p && ht_ielen>0)		
-		ht_cap = _TRUE;			
-
-	#ifdef CONFIG_80211AC_VHT
-	//parsing VHT_CAP_IE
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength-ie_offset);
-	if(p && vht_ielen>0)
-		vht_cap = _TRUE;	
-	#endif
-	 /* Add the protocol name */
+	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12); /* Probe Request	 */
+
+	/* parsing HT_CAP_IE	 */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && ht_ielen > 0)
+		ht_cap = _TRUE;
+
+#ifdef CONFIG_80211AC_VHT
+	/* parsing VHT_CAP_IE */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && vht_ielen > 0)
+		vht_cap = _TRUE;
+#endif
+	/* Add the protocol name */
 	iwe->cmd = SIOCGIWNAME;
-	if ((rtw_is_cckratesonly_included((u8*)&pnetwork->network.SupportedRates)) == _TRUE)		
-	{
-		if(ht_cap == _TRUE)
+	if ((rtw_is_cckratesonly_included((u8 *)&pnetwork->network.SupportedRates)) == _TRUE) {
+		if (ht_cap == _TRUE)
 			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11bn");
 		else
 			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11b");
-	}	
-	else if ((rtw_is_cckrates_included((u8*)&pnetwork->network.SupportedRates)) == _TRUE)	
-	{
-		if(ht_cap == _TRUE)
+	} else if ((rtw_is_cckrates_included((u8 *)&pnetwork->network.SupportedRates)) == _TRUE) {
+		if (ht_cap == _TRUE)
 			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11bgn");
 		else
 			snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11bg");
-	}	
-	else
-	{
-		if(pnetwork->network.Configuration.DSConfig > 14)
-		{
+	} else {
+		if (pnetwork->network.Configuration.DSConfig > 14) {
 			#ifdef CONFIG_80211AC_VHT
-			if(vht_cap == _TRUE){
+			if (vht_cap == _TRUE)
 				snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11AC");
-			}
-			else 
-			#endif	
+			else
+			#endif
 			{
-				if(ht_cap == _TRUE)
+				if (ht_cap == _TRUE)
 					snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11an");
 				else
 					snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11a");
 			}
-		}
-		else
-		{
-			if(ht_cap == _TRUE)
+		} else {
+			if (ht_cap == _TRUE)
 				snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11gn");
 			else
 				snprintf(iwe->u.name, IFNAMSIZ, "IEEE 802.11g");
@@ -516,60 +466,57 @@ static int search_p2p_wfd_ie(_adapter *padapter,
 	}
 	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_CHAR_LEN);
 	return start;
- }
-				
- static inline char * iwe_stream_rate_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
+}
+
+static inline char *iwe_stream_rate_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
 {
 	u32 ht_ielen = 0, vht_ielen = 0;
 	char *p;
-	u16 max_rate=0, rate, ht_cap=_FALSE, vht_cap = _FALSE;
-	u32 i = 0;		
-	u8 bw_40MHz=0, short_GI=0, bw_160MHz=0, vht_highest_rate = 0;
-	u16 mcs_rate=0, vht_data_rate=0;
-	char custom[MAX_CUSTOM_LEN]={0};
-	u8 ie_offset = (pnetwork->network.Reserved[0] == 2? 0:12);// Probe Request	
- 	
-	//parsing HT_CAP_IE	
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength-ie_offset);	
-	if(p && ht_ielen>0)
-	{
+	u16 max_rate = 0, rate, ht_cap = _FALSE, vht_cap = _FALSE;
+	u32 i = 0;
+	u8 bw_40MHz = 0, short_GI = 0, bw_160MHz = 0, vht_highest_rate = 0;
+	u16 mcs_rate = 0, vht_data_rate = 0;
+	char custom[MAX_CUSTOM_LEN] = {0};
+	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12); /* Probe Request	 */
+
+	/* parsing HT_CAP_IE	 */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && ht_ielen > 0) {
 		struct rtw_ieee80211_ht_cap *pht_capie;
-		ht_cap = _TRUE;			
-		pht_capie = (struct rtw_ieee80211_ht_cap *)(p+2);		
+		ht_cap = _TRUE;
+		pht_capie = (struct rtw_ieee80211_ht_cap *)(p + 2);
 		_rtw_memcpy(&mcs_rate , pht_capie->supp_mcs_set, 2);
-		bw_40MHz = (pht_capie->cap_info&IEEE80211_HT_CAP_SUP_WIDTH) ? 1:0;
-		short_GI = (pht_capie->cap_info&(IEEE80211_HT_CAP_SGI_20|IEEE80211_HT_CAP_SGI_40)) ? 1:0;
+		bw_40MHz = (pht_capie->cap_info & IEEE80211_HT_CAP_SUP_WIDTH) ? 1 : 0;
+		short_GI = (pht_capie->cap_info & (IEEE80211_HT_CAP_SGI_20 | IEEE80211_HT_CAP_SGI_40)) ? 1 : 0;
 	}
 
 #ifdef CONFIG_80211AC_VHT
-	//parsing VHT_CAP_IE
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength-ie_offset);
-	if(p && vht_ielen>0)
-	{
+	/* parsing VHT_CAP_IE */
+	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
+	if (p && vht_ielen > 0) {
 		u8	mcs_map[2];
 
-		vht_cap = _TRUE;		
-		bw_160MHz = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p+2);
-		if(bw_160MHz)
-			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI160M(p+2);
+		vht_cap = _TRUE;
+		bw_160MHz = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p + 2);
+		if (bw_160MHz)
+			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI160M(p + 2);
 		else
-			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI80M(p+2);
+			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI80M(p + 2);
 
-		_rtw_memcpy(mcs_map, GET_VHT_CAPABILITY_ELE_TX_MCS(p+2), 2);
+		_rtw_memcpy(mcs_map, GET_VHT_CAPABILITY_ELE_TX_MCS(p + 2), 2);
 
 		vht_highest_rate = rtw_get_vht_highest_rate(mcs_map);
 		vht_data_rate = rtw_vht_mcs_to_data_rate(CHANNEL_WIDTH_80, short_GI, vht_highest_rate);
 	}
-#endif	
-	
-	/*Add basic and extended rates */	
+#endif
+
+	/*Add basic and extended rates */
 	p = custom;
 	p += snprintf(p, MAX_CUSTOM_LEN - (p - custom), " Rates (Mb/s): ");
-	while(pnetwork->network.SupportedRates[i]!=0)
-	{
-		rate = pnetwork->network.SupportedRates[i]&0x7F; 
+	while (pnetwork->network.SupportedRates[i] != 0) {
+		rate = pnetwork->network.SupportedRates[i] & 0x7F;
 		if (rate > max_rate)
 			max_rate = rate;
 		p += snprintf(p, MAX_CUSTOM_LEN - (p - custom),
@@ -577,846 +524,392 @@ static int search_p2p_wfd_ie(_adapter *padapter,
 		i++;
 	}
 #ifdef CONFIG_80211AC_VHT
-	if(vht_cap == _TRUE) {
+	if (vht_cap == _TRUE)
 		max_rate = vht_data_rate;
-	}
 	else
-#endif		
-	if(ht_cap == _TRUE)
-	{
-		if(mcs_rate&0x8000)//MCS15
-		{
-			max_rate = (bw_40MHz) ? ((short_GI)?300:270):((short_GI)?144:130);
-			
-		}
-		else if(mcs_rate&0x0080)//MCS7
-		{
-			max_rate = (bw_40MHz) ? ((short_GI)?150:135):((short_GI)?72:65);
-		}
-		else//default MCS7
-		{
-			//DBG_871X("wx_get_scan, mcs_rate_bitmap=0x%x\n", mcs_rate);
-			max_rate = (bw_40MHz) ? ((short_GI)?150:135):((short_GI)?72:65);
-		}
+#endif
+		if (ht_cap == _TRUE) {
+			if (mcs_rate & 0x8000) /* MCS15 */
+				max_rate = (bw_40MHz) ? ((short_GI) ? 300 : 270) : ((short_GI) ? 144 : 130);
+
+			else if (mcs_rate & 0x0080) /* MCS7 */
+				max_rate = (bw_40MHz) ? ((short_GI) ? 150 : 135) : ((short_GI) ? 72 : 65);
+			else { /* default MCS7 */
+				/* RTW_INFO("wx_get_scan, mcs_rate_bitmap=0x%x\n", mcs_rate); */
+				max_rate = (bw_40MHz) ? ((short_GI) ? 150 : 135) : ((short_GI) ? 72 : 65);
+			}
 
-		max_rate = max_rate*2;//Mbps/2;		
-	}
+			max_rate = max_rate * 2; /* Mbps/2;		 */
+		}
 
 	iwe->cmd = SIOCGIWRATE;
 	iwe->u.bitrate.fixed = iwe->u.bitrate.disabled = 0;
 	iwe->u.bitrate.value = max_rate * 500000;
-	start =iwe_stream_add_event(info, start, stop, iwe, IW_EV_PARAM_LEN);
+	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_PARAM_LEN);
 	return start ;
 }
 
-static inline char * iwe_stream_wpa_wpa2_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
+static inline char *iwe_stream_wpa_wpa2_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
 {
-	int buf_size = MAX_WPA_IE_LEN*2;
-	//u8 pbuf[buf_size]={0};	
+	int buf_size = MAX_WPA_IE_LEN * 2;
+	/* u8 pbuf[buf_size]={0};	 */
 	u8 *pbuf = rtw_zmalloc(buf_size);
 
-	u8 wpa_ie[255]={0},rsn_ie[255]={0};
-	u16 i, wpa_len=0,rsn_len=0;
+	u8 wpa_ie[255] = {0}, rsn_ie[255] = {0};
+	u16 i, wpa_len = 0, rsn_len = 0;
 	u8 *p;
-	sint out_len=0;
-		
-	
-	if(pbuf){
-		p=pbuf;	
-	
-		//parsing WPA/WPA2 IE
-		if (pnetwork->network.Reserved[0] != 2) // Probe Request
-		{	
-			out_len=rtw_get_sec_ie(pnetwork->network.IEs ,pnetwork->network.IELength,rsn_ie,&rsn_len,wpa_ie,&wpa_len);
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: ssid=%s\n",pnetwork->network.Ssid.Ssid));
-			RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: wpa_len=%d rsn_len=%d\n",wpa_len,rsn_len));
-
-			if (wpa_len > 0){
-				
+	sint out_len = 0;
+
+
+	if (pbuf) {
+		p = pbuf;
+
+		/* parsing WPA/WPA2 IE */
+		if (pnetwork->network.Reserved[0] != BSS_TYPE_PROB_REQ) { /* Probe Request */
+			out_len = rtw_get_sec_ie(pnetwork->network.IEs , pnetwork->network.IELength, rsn_ie, &rsn_len, wpa_ie, &wpa_len);
+
+			if (wpa_len > 0) {
+
 				_rtw_memset(pbuf, 0, buf_size);
 				p += sprintf(p, "wpa_ie=");
-				for (i = 0; i < wpa_len; i++) {
+				for (i = 0; i < wpa_len; i++)
 					p += sprintf(p, "%02x", wpa_ie[i]);
-				}
 
 				if (wpa_len > 100) {
 					printk("-----------------Len %d----------------\n", wpa_len);
-					for (i = 0; i < wpa_len; i++) {
+					for (i = 0; i < wpa_len; i++)
 						printk("%02x ", wpa_ie[i]);
-					}
 					printk("\n");
 					printk("-----------------Len %d----------------\n", wpa_len);
 				}
-		
+
 				_rtw_memset(iwe, 0, sizeof(*iwe));
 				iwe->cmd = IWEVCUSTOM;
 				iwe->u.data.length = strlen(pbuf);
-				start = iwe_stream_add_point(info, start, stop, iwe,pbuf);
-				
+				start = iwe_stream_add_point(info, start, stop, iwe, pbuf);
+
 				_rtw_memset(iwe, 0, sizeof(*iwe));
-				iwe->cmd =IWEVGENIE;
+				iwe->cmd = IWEVGENIE;
 				iwe->u.data.length = wpa_len;
-				start = iwe_stream_add_point(info, start, stop, iwe, wpa_ie);			
+				start = iwe_stream_add_point(info, start, stop, iwe, wpa_ie);
 			}
-			if (rsn_len > 0){
-				
+			if (rsn_len > 0) {
+
 				_rtw_memset(pbuf, 0, buf_size);
 				p += sprintf(p, "rsn_ie=");
-				for (i = 0; i < rsn_len; i++) {
+				for (i = 0; i < rsn_len; i++)
 					p += sprintf(p, "%02x", rsn_ie[i]);
-				}
 				_rtw_memset(iwe, 0, sizeof(*iwe));
 				iwe->cmd = IWEVCUSTOM;
 				iwe->u.data.length = strlen(pbuf);
-				start = iwe_stream_add_point(info, start, stop, iwe,pbuf);
-			
+				start = iwe_stream_add_point(info, start, stop, iwe, pbuf);
+
 				_rtw_memset(iwe, 0, sizeof(*iwe));
-				iwe->cmd =IWEVGENIE;
+				iwe->cmd = IWEVGENIE;
 				iwe->u.data.length = rsn_len;
-				start = iwe_stream_add_point(info, start, stop, iwe, rsn_ie);		
+				start = iwe_stream_add_point(info, start, stop, iwe, rsn_ie);
 			}
 		}
-	
-		rtw_mfree(pbuf, buf_size);	
+
+		rtw_mfree(pbuf, buf_size);
 	}
 	return start;
 }
 
-static inline char * iwe_stream_wps_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
-{	
- 	//parsing WPS IE
-	uint cnt = 0,total_ielen;	
-	u8 *wpsie_ptr=NULL;
-	uint wps_ielen = 0;		
-	u8 ie_offset = (pnetwork->network.Reserved[0] == 2? 0:12);
-	
+static inline char *iwe_stream_wps_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
+	/* parsing WPS IE */
+	uint cnt = 0, total_ielen;
+	u8 *wpsie_ptr = NULL;
+	uint wps_ielen = 0;
+	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12);
+
 	u8 *ie_ptr = pnetwork->network.IEs + ie_offset;
-	total_ielen= pnetwork->network.IELength - ie_offset;
+	total_ielen = pnetwork->network.IELength - ie_offset;
 
-	if (pnetwork->network.Reserved[0] == 2) // Probe Request
-	{
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ) { /* Probe Request */
 		ie_ptr = pnetwork->network.IEs;
 		total_ielen = pnetwork->network.IELength;
-	}
-	else     // Beacon or Probe Respones
-	{
+	} else { /* Beacon or Probe Respones */
 		ie_ptr = pnetwork->network.IEs + _FIXED_IE_LENGTH_;
 		total_ielen = pnetwork->network.IELength - _FIXED_IE_LENGTH_;
-	}    
-	while(cnt < total_ielen)
-	{
-		if(rtw_is_wps_ie(&ie_ptr[cnt], &wps_ielen) && (wps_ielen>2))			
-		{
+	}
+	while (cnt < total_ielen) {
+		if (rtw_is_wps_ie(&ie_ptr[cnt], &wps_ielen) && (wps_ielen > 2)) {
 			wpsie_ptr = &ie_ptr[cnt];
-			iwe->cmd =IWEVGENIE;
+			iwe->cmd = IWEVGENIE;
 			iwe->u.data.length = (u16)wps_ielen;
-			start = iwe_stream_add_point(info, start, stop,iwe, wpsie_ptr);						
-		}			
-		cnt+=ie_ptr[cnt+1]+2; //goto next
+			start = iwe_stream_add_point(info, start, stop, iwe, wpsie_ptr);
+		}
+		cnt += ie_ptr[cnt + 1] + 2; /* goto next */
 	}
 	return start;
 }
 
-static inline char * iwe_stream_wapi_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
+static inline char *iwe_stream_wapi_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
 {
 #ifdef CONFIG_WAPI_SUPPORT
 	char *p;
-		
-	if (pnetwork->network.Reserved[0] != 2) // Probe Request
-	{		
-		sint out_len_wapi=0;
+
+	if (pnetwork->network.Reserved[0] != BSS_TYPE_PROB_REQ) { /* Probe Request */
+		sint out_len_wapi = 0;
 		/* here use static for stack size */
-		static u8 buf_wapi[MAX_WAPI_IE_LEN*2]={0};
-		static u8 wapi_ie[MAX_WAPI_IE_LEN]={0};
-		u16 wapi_len=0;
+		static u8 buf_wapi[MAX_WAPI_IE_LEN * 2] = {0};
+		static u8 wapi_ie[MAX_WAPI_IE_LEN] = {0};
+		u16 wapi_len = 0;
 		u16  i;
 
-		out_len_wapi=rtw_get_wapi_ie(pnetwork->network.IEs ,pnetwork->network.IELength,wapi_ie,&wapi_len);
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: ssid=%s\n",pnetwork->network.Ssid.Ssid));
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: wapi_len=%d \n",wapi_len));
+		out_len_wapi = rtw_get_wapi_ie(pnetwork->network.IEs , pnetwork->network.IELength, wapi_ie, &wapi_len);
 
-		DBG_871X("rtw_wx_get_scan: %s ",pnetwork->network.Ssid.Ssid);
-		DBG_871X("rtw_wx_get_scan: ssid = %d ",wapi_len);
+		RTW_INFO("rtw_wx_get_scan: %s ", pnetwork->network.Ssid.Ssid);
+		RTW_INFO("rtw_wx_get_scan: ssid = %d ", wapi_len);
 
 
-		if (wapi_len > 0)
-		{
-			p=buf_wapi;
-			//_rtw_memset(buf_wapi, 0, MAX_WAPI_IE_LEN*2);
+		if (wapi_len > 0) {
+			p = buf_wapi;
+			/* _rtw_memset(buf_wapi, 0, MAX_WAPI_IE_LEN*2); */
 			p += sprintf(p, "wapi_ie=");
-			for (i = 0; i < wapi_len; i++) {
+			for (i = 0; i < wapi_len; i++)
 				p += sprintf(p, "%02x", wapi_ie[i]);
-			}
 
 			_rtw_memset(iwe, 0, sizeof(*iwe));
 			iwe->cmd = IWEVCUSTOM;
 			iwe->u.data.length = strlen(buf_wapi);
-			start = iwe_stream_add_point(info, start, stop, iwe,buf_wapi);
+			start = iwe_stream_add_point(info, start, stop, iwe, buf_wapi);
 
 			_rtw_memset(iwe, 0, sizeof(*iwe));
-			iwe->cmd =IWEVGENIE;
+			iwe->cmd = IWEVGENIE;
 			iwe->u.data.length = wapi_len;
 			start = iwe_stream_add_point(info, start, stop, iwe, wapi_ie);
 		}
 	}
-#endif//#ifdef CONFIG_WAPI_SUPPORT
+#endif/* #ifdef CONFIG_WAPI_SUPPORT */
 	return start;
 }
 
-static inline char *  iwe_stream_rssi_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
+static inline char   *iwe_stream_rssi_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
 {
 	u8 ss, sq;
+	s16 noise = 0;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	
+
 	/* Add quality statistics */
 	iwe->cmd = IWEVQUAL;
-	iwe->u.qual.updated = IW_QUAL_QUAL_UPDATED | IW_QUAL_LEVEL_UPDATED 
-	#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-		| IW_QUAL_NOISE_UPDATED
-	#else
-		| IW_QUAL_NOISE_INVALID
-	#endif
-	#ifdef CONFIG_SIGNAL_DISPLAY_DBM
-		| IW_QUAL_DBM
-	#endif
-	;
+	iwe->u.qual.updated = IW_QUAL_QUAL_UPDATED | IW_QUAL_LEVEL_UPDATED
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+			      | IW_QUAL_NOISE_UPDATED
+#else
+			      | IW_QUAL_NOISE_INVALID
+#endif
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+			      | IW_QUAL_DBM
+#endif
+			      ;
 
-	if ( check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE &&
-		is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)){
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
+	    is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
 		ss = padapter->recvpriv.signal_strength;
 		sq = padapter->recvpriv.signal_qual;
 	} else {
 		ss = pnetwork->network.PhyInfo.SignalStrength;
 		sq = pnetwork->network.PhyInfo.SignalQuality;
 	}
-	
-	
-	#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+
+
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
 	iwe->u.qual.level = (u8) translate_percentage_to_dbm(ss); /* dbm */
-	#else
-	#ifdef CONFIG_SIGNAL_SCALE_MAPPING
+#else
+#ifdef CONFIG_SIGNAL_SCALE_MAPPING
 	iwe->u.qual.level = (u8)ss; /* % */
-	#else
+#else
 	{
 		/* Do signal scale mapping when using percentage as the unit of signal strength, since the scale mapping is skipped in odm */
-		
+
 		HAL_DATA_TYPE *pHal = GET_HAL_DATA(padapter);
-		
-		iwe->u.qual.level = (u8)odm_SignalScaleMapping(&pHal->odmpriv, ss);
-	}	
-	#endif
-	#endif
-	
-	iwe->u.qual.qual = (u8)sq;   // signal quality
 
-	#ifdef CONFIG_PLATFORM_ROCKCHIPS
-	iwe->u.qual.noise = -100; // noise level suggest by zhf@rockchips
-	#else 
-	#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-	{
-		s16 tmp_noise=0;
-		rtw_hal_get_odm_var(padapter, HAL_ODM_NOISE_MONITOR,&(pnetwork->network.Configuration.DSConfig), &(tmp_noise));
-		iwe->u.qual.noise = tmp_noise ;
+		iwe->u.qual.level = (u8)phydm_signal_scale_mapping(&pHal->odmpriv, ss);
+	}
+#endif
+#endif
+
+	iwe->u.qual.qual = (u8)sq;   /* signal quality */
+
+#ifdef CONFIG_PLATFORM_ROCKCHIPS
+	iwe->u.qual.noise = -100; /* noise level suggest by zhf@rockchips */
+#else
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	if (IS_NM_ENABLE(padapter)) {
+		noise = rtw_noise_query_by_chan_num(padapter, pnetwork->network.Configuration.DSConfig);
+		#ifndef CONFIG_SIGNAL_DISPLAY_DBM
+		noise = translate_dbm_to_percentage(noise);/*percentage*/
+		#endif
+		iwe->u.qual.noise = noise;
 	}
-	#else
-	iwe->u.qual.noise = 0; // noise level
-	#endif	
-	#endif //CONFIG_PLATFORM_ROCKCHIPS
-	
-	//DBG_871X("iqual=%d, ilevel=%d, inoise=%d, iupdated=%d\n", iwe.u.qual.qual, iwe.u.qual.level , iwe.u.qual.noise, iwe.u.qual.updated);
+#else
+	iwe->u.qual.noise = 0; /* noise level */
+#endif
+#endif /* CONFIG_PLATFORM_ROCKCHIPS */
+
+	/* RTW_INFO("iqual=%d, ilevel=%d, inoise=%d, iupdated=%d\n", iwe.u.qual.qual, iwe.u.qual.level , iwe.u.qual.noise, iwe.u.qual.updated); */
 
 	start = iwe_stream_add_event(info, start, stop, iwe, IW_EV_QUAL_LEN);
 	return start;
 }
 
-static inline char *  iwe_stream_net_rsv_process(_adapter *padapter,
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop,struct iw_event *iwe)
-{	
+static inline char   *iwe_stream_net_rsv_process(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop, struct iw_event *iwe)
+{
 	u8 buf[32] = {0};
-	u8 * p,*pos;
+	u8 *p, *pos;
 	int len;
 	p = buf;
 	pos = pnetwork->network.Reserved;
-	
+
 	p += sprintf(p, "fm=%02X%02X", pos[1], pos[0]);
 	_rtw_memset(iwe, 0, sizeof(*iwe));
 	iwe->cmd = IWEVCUSTOM;
 	iwe->u.data.length = strlen(buf);
-	start = iwe_stream_add_point(info, start, stop,iwe, buf);
+	start = iwe_stream_add_point(info, start, stop, iwe, buf);
 	return start;
 }
 
-#if 1
-static char *translate_scan(_adapter *padapter, 
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop)
-{	
+static char *translate_scan(_adapter *padapter,
+		struct iw_request_info *info, struct wlan_network *pnetwork,
+		char *start, char *stop)
+{
 	struct iw_event iwe;
 	u16 cap = 0;
 	_rtw_memset(&iwe, 0, sizeof(iwe));
-	
-	if(_FALSE == search_p2p_wfd_ie(padapter,info,pnetwork,start,stop))
+
+	if (_FALSE == search_p2p_wfd_ie(padapter, info, pnetwork, start, stop))
 		return start;
 
-	start = iwe_stream_mac_addr_proess(padapter,info,pnetwork,start,stop,&iwe);	
-	start = iwe_stream_essid_proess(padapter,info,pnetwork,start,stop,&iwe);	
-	start = iwe_stream_protocol_process(padapter,info,pnetwork,start,stop,&iwe);
-	if (pnetwork->network.Reserved[0] == 2) // Probe Request
-	{
+	start = iwe_stream_mac_addr_proess(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_essid_proess(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_protocol_process(padapter, info, pnetwork, start, stop, &iwe);
+	if (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ) /* Probe Request */
 		cap = 0;
-	}
-	else
-	{
+	else {
 		_rtw_memcpy((u8 *)&cap, rtw_get_capability_from_ie(pnetwork->network.IEs), 2);
 		cap = le16_to_cpu(cap);
 	}
 
-	start = iwe_stream_mode_process(padapter,info,pnetwork,start,stop,&iwe,cap);	
-	start = iwe_stream_chan_process(padapter,info,pnetwork,start,stop,&iwe);	
-	start = iwe_stream_encryption_process(padapter,info,pnetwork,start,stop,&iwe,cap);	
-	start = iwe_stream_rate_process(padapter,info,pnetwork,start,stop,&iwe);	
-	start = iwe_stream_wpa_wpa2_process(padapter,info,pnetwork,start,stop,&iwe);
-	start = iwe_stream_wps_process(padapter,info,pnetwork,start,stop,&iwe);
-	start = iwe_stream_wapi_process(padapter,info,pnetwork,start,stop,&iwe);
-	start = iwe_stream_rssi_process(padapter,info,pnetwork,start,stop,&iwe);
-	start = iwe_stream_net_rsv_process(padapter,info,pnetwork,start,stop,&iwe);	
-	
-	return start;	
+	start = iwe_stream_mode_process(padapter, info, pnetwork, start, stop, &iwe, cap);
+	start = iwe_stream_chan_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_encryption_process(padapter, info, pnetwork, start, stop, &iwe, cap);
+	start = iwe_stream_rate_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_wpa_wpa2_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_wps_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_wapi_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_rssi_process(padapter, info, pnetwork, start, stop, &iwe);
+	start = iwe_stream_net_rsv_process(padapter, info, pnetwork, start, stop, &iwe);
+
+	return start;
 }
-#else
-static char *translate_scan(_adapter *padapter, 
-				struct iw_request_info* info, struct wlan_network *pnetwork,
-				char *start, char *stop)
+
+static int wpa_set_auth_algs(struct net_device *dev, u32 value)
 {
-	struct iw_event iwe;
-	u16 cap;
-	u32 ht_ielen = 0, vht_ielen = 0;
-	char custom[MAX_CUSTOM_LEN];
-	char *p;
-	u16 max_rate=0, rate, ht_cap=_FALSE, vht_cap = _FALSE;
-	u32 i = 0;	
-	char	*current_val;
-	long rssi;
-	u8 bw_40MHz=0, short_GI=0, bw_160MHz=0, vht_highest_rate = 0;
-	u16 mcs_rate=0, vht_data_rate=0;
-	u8 ie_offset = (pnetwork->network.Reserved[0] == 2? 0:12);
-	struct registry_priv *pregpriv = &padapter->registrypriv;
-	
-	if(_FALSE == search_p2p_wfd_ie(padapter,info,pnetwork,start,stop))
-		return start;
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	int ret = 0;
 
-	/*  AP MAC address  */
-	iwe.cmd = SIOCGIWAP;
-	iwe.u.ap_addr.sa_family = ARPHRD_ETHER;
+	if ((value & AUTH_ALG_SHARED_KEY) && (value & AUTH_ALG_OPEN_SYSTEM)) {
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_SHARED_KEY and  AUTH_ALG_OPEN_SYSTEM [value:0x%x]\n", value);
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+	} else if (value & AUTH_ALG_SHARED_KEY) {
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_SHARED_KEY  [value:0x%x]\n", value);
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
 
-	_rtw_memcpy(iwe.u.ap_addr.sa_data, pnetwork->network.MacAddress, ETH_ALEN);
-	start = iwe_stream_add_event(info, start, stop, &iwe, IW_EV_ADDR_LEN);
-	
-	/* Add the ESSID */
-	iwe.cmd = SIOCGIWESSID;
-	iwe.u.data.flags = 1;	
-	iwe.u.data.length = min((u16)pnetwork->network.Ssid.SsidLength, (u16)32);
-	start = iwe_stream_add_point(info, start, stop, &iwe, pnetwork->network.Ssid.Ssid);
+#ifdef CONFIG_PLATFORM_MT53XX
+		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+#else
+		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeShared;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Shared;
+#endif
+	} else if (value & AUTH_ALG_OPEN_SYSTEM) {
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_OPEN_SYSTEM\n");
+		/* padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled; */
+		if (padapter->securitypriv.ndisauthtype < Ndis802_11AuthModeWPAPSK) {
+#ifdef CONFIG_PLATFORM_MT53XX
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
+#else
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
+#endif
+		}
 
-	//parsing HT_CAP_IE
-	if (pnetwork->network.Reserved[0] == 2) // Probe Request
-	{
-		p = rtw_get_ie(&pnetwork->network.IEs[0], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength);
-	}
-	else
-	{
-		p = rtw_get_ie(&pnetwork->network.IEs[12], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength-12);
-	}
-	if(p && ht_ielen>0)
-	{
-		struct rtw_ieee80211_ht_cap *pht_capie;
-		ht_cap = _TRUE;			
-		pht_capie = (struct rtw_ieee80211_ht_cap *)(p+2);		
-		_rtw_memcpy(&mcs_rate , pht_capie->supp_mcs_set, 2);
-		bw_40MHz = (pht_capie->cap_info&IEEE80211_HT_CAP_SUP_WIDTH) ? 1:0;
-		short_GI = (pht_capie->cap_info&(IEEE80211_HT_CAP_SGI_20|IEEE80211_HT_CAP_SGI_40)) ? 1:0;
+	} else if (value & AUTH_ALG_LEAP)
+		RTW_INFO("wpa_set_auth_algs, AUTH_ALG_LEAP\n");
+	else {
+		RTW_INFO("wpa_set_auth_algs, error!\n");
+		ret = -EINVAL;
 	}
 
-#ifdef CONFIG_80211AC_VHT
-	//parsing VHT_CAP_IE
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength-ie_offset);
-	if(p && vht_ielen>0)
-	{
-		u8	mcs_map[2];
+	return ret;
 
-		vht_cap = _TRUE;		
-		bw_160MHz = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p+2);
-		if(bw_160MHz)
-			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI160M(p+2);
-		else
-			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI80M(p+2);
+}
 
-		_rtw_memcpy(mcs_map, GET_VHT_CAPABILITY_ELE_TX_MCS(p+2), 2);
+static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
+{
+	int ret = 0;
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#ifdef CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
 
-		vht_highest_rate = rtw_get_vht_highest_rate(mcs_map);
-		vht_data_rate = rtw_vht_mcs_to_data_rate(CHANNEL_WIDTH_80, short_GI, vht_highest_rate);
+
+	param->u.crypt.err = 0;
+	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
+
+	if (param_len < (u32)((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len) {
+		ret =  -EINVAL;
+		goto exit;
 	}
-#endif
 
-	/* Add the protocol name */
-	iwe.cmd = SIOCGIWNAME;
-	if ((rtw_is_cckratesonly_included((u8*)&pnetwork->network.SupportedRates)) == _TRUE)		
-	{
-		if(ht_cap == _TRUE)
-			snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11bn");
-		else
-		snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11b");
-	}	
-	else if ((rtw_is_cckrates_included((u8*)&pnetwork->network.SupportedRates)) == _TRUE)	
-	{
-		if(ht_cap == _TRUE)
-			snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11bgn");
-		else
-			snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11bg");
-	}	
-	else
-	{
-		if(pnetwork->network.Configuration.DSConfig > 14)
-		{
-			if(vht_cap == _TRUE)
-				snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11AC");
-			else if(ht_cap == _TRUE)
-				snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11an");
-			else
-				snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11a");
+	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
+	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) {
+
+		if (param->u.crypt.idx >= WEP_KEYS
+#ifdef CONFIG_IEEE80211W
+		    && param->u.crypt.idx > BIP_MAX_KEYID
+#endif /* CONFIG_IEEE80211W */
+		   ) {
+			ret = -EINVAL;
+			goto exit;
 		}
-		else
+	} else {
+#ifdef CONFIG_WAPI_SUPPORT
+		if (strcmp(param->u.crypt.alg, "SMS4"))
+#endif
 		{
-			if(ht_cap == _TRUE)
-				snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11gn");
-			else
-				snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11g");
+			ret = -EINVAL;
+			goto exit;
 		}
-	}	
+	}
 
-	start = iwe_stream_add_event(info, start, stop, &iwe, IW_EV_CHAR_LEN);
-
-	  /* Add mode */
-	if (pnetwork->network.Reserved[0] == 2) // Probe Request
-	{
-		cap = 0;
-	}
-	else
-	{
-        iwe.cmd = SIOCGIWMODE;
-		_rtw_memcpy((u8 *)&cap, rtw_get_capability_from_ie(pnetwork->network.IEs), 2);
-		cap = le16_to_cpu(cap);
-	}
-
-	if(cap & (WLAN_CAPABILITY_IBSS |WLAN_CAPABILITY_BSS)){
-		if (cap & WLAN_CAPABILITY_BSS)
-			iwe.u.mode = IW_MODE_MASTER;
-		else
-			iwe.u.mode = IW_MODE_ADHOC;
-
-		start = iwe_stream_add_event(info, start, stop, &iwe, IW_EV_UINT_LEN);
-	}
-
-	if(pnetwork->network.Configuration.DSConfig<1 /*|| pnetwork->network.Configuration.DSConfig>14*/)
-		pnetwork->network.Configuration.DSConfig = 1;
-
-	 /* Add frequency/channel */
-	iwe.cmd = SIOCGIWFREQ;
-	iwe.u.freq.m = rtw_ch2freq(pnetwork->network.Configuration.DSConfig) * 100000;
-	iwe.u.freq.e = 1;
-	iwe.u.freq.i = pnetwork->network.Configuration.DSConfig;
-	start = iwe_stream_add_event(info, start, stop, &iwe, IW_EV_FREQ_LEN);
-
-	/* Add encryption capability */
-	iwe.cmd = SIOCGIWENCODE;
-	if (cap & WLAN_CAPABILITY_PRIVACY)
-		iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY;
-	else
-		iwe.u.data.flags = IW_ENCODE_DISABLED;
-	iwe.u.data.length = 0;
-	start = iwe_stream_add_point(info, start, stop, &iwe, pnetwork->network.Ssid.Ssid);
-
-	/*Add basic and extended rates */
-	max_rate = 0;
-	p = custom;
-	p += snprintf(p, MAX_CUSTOM_LEN - (p - custom), " Rates (Mb/s): ");
-	while(pnetwork->network.SupportedRates[i]!=0)
-	{
-		rate = pnetwork->network.SupportedRates[i]&0x7F; 
-		if (rate > max_rate)
-			max_rate = rate;
-		p += snprintf(p, MAX_CUSTOM_LEN - (p - custom),
-			      "%d%s ", rate >> 1, (rate & 1) ? ".5" : "");
-		i++;
-	}
-
-	if(vht_cap == _TRUE) {
-		max_rate = vht_data_rate;
-	}
-	else if(ht_cap == _TRUE)
-	{
-		if(mcs_rate&0x8000)//MCS15
-		{
-			max_rate = (bw_40MHz) ? ((short_GI)?300:270):((short_GI)?144:130);
-			
-		}
-		else if(mcs_rate&0x0080)//MCS7
-		{
-			max_rate = (bw_40MHz) ? ((short_GI)?150:135):((short_GI)?72:65);
-		}
-		else//default MCS7
-		{
-			//DBG_871X("wx_get_scan, mcs_rate_bitmap=0x%x\n", mcs_rate);
-			max_rate = (bw_40MHz) ? ((short_GI)?150:135):((short_GI)?72:65);
-		}
-
-		max_rate = max_rate*2;//Mbps/2;		
-	}
-
-	iwe.cmd = SIOCGIWRATE;
-	iwe.u.bitrate.fixed = iwe.u.bitrate.disabled = 0;
-	iwe.u.bitrate.value = max_rate * 500000;
-	start = iwe_stream_add_event(info, start, stop, &iwe, IW_EV_PARAM_LEN);
-
-	//parsing WPA/WPA2 IE
-	if (pnetwork->network.Reserved[0] != 2) // Probe Request
-	{
-		u8 buf[MAX_WPA_IE_LEN*2];
-		u8 wpa_ie[255],rsn_ie[255];
-		u16 wpa_len=0,rsn_len=0;
-		u8 *p;
-		sint out_len=0;
-		out_len=rtw_get_sec_ie(pnetwork->network.IEs ,pnetwork->network.IELength,rsn_ie,&rsn_len,wpa_ie,&wpa_len);
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: ssid=%s\n",pnetwork->network.Ssid.Ssid));
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: wpa_len=%d rsn_len=%d\n",wpa_len,rsn_len));
-
-		if (wpa_len > 0)
-		{
-			p=buf;
-			_rtw_memset(buf, 0, MAX_WPA_IE_LEN*2);
-			p += sprintf(p, "wpa_ie=");
-			for (i = 0; i < wpa_len; i++) {
-				p += sprintf(p, "%02x", wpa_ie[i]);
-			}
-
-			if (wpa_len > 100) {
-				printk("-----------------Len %d----------------\n", wpa_len);
-				for (i = 0; i < wpa_len; i++) {
-					printk("%02x ", wpa_ie[i]);
-				}
-				printk("\n");
-				printk("-----------------Len %d----------------\n", wpa_len);
-			}
-	
-			_rtw_memset(&iwe, 0, sizeof(iwe));
-			iwe.cmd = IWEVCUSTOM;
-			iwe.u.data.length = strlen(buf);
-			start = iwe_stream_add_point(info, start, stop, &iwe,buf);
-			
-			_rtw_memset(&iwe, 0, sizeof(iwe));
-			iwe.cmd =IWEVGENIE;
-			iwe.u.data.length = wpa_len;
-			start = iwe_stream_add_point(info, start, stop, &iwe, wpa_ie);			
-		}
-		if (rsn_len > 0)
-		{
-			p = buf;
-			_rtw_memset(buf, 0, MAX_WPA_IE_LEN*2);
-			p += sprintf(p, "rsn_ie=");
-			for (i = 0; i < rsn_len; i++) {
-				p += sprintf(p, "%02x", rsn_ie[i]);
-			}
-			_rtw_memset(&iwe, 0, sizeof(iwe));
-			iwe.cmd = IWEVCUSTOM;
-			iwe.u.data.length = strlen(buf);
-			start = iwe_stream_add_point(info, start, stop, &iwe,buf);
-		
-			_rtw_memset(&iwe, 0, sizeof(iwe));
-			iwe.cmd =IWEVGENIE;
-			iwe.u.data.length = rsn_len;
-			start = iwe_stream_add_point(info, start, stop, &iwe, rsn_ie);		
-		}
-	}
-
-	{ //parsing WPS IE
-		uint cnt = 0,total_ielen;	
-		u8 *wpsie_ptr=NULL;
-		uint wps_ielen = 0;		
-
-		u8 *ie_ptr = pnetwork->network.IEs + ie_offset;
-		total_ielen= pnetwork->network.IELength - ie_offset;
-
-		if (pnetwork->network.Reserved[0] == 2) // Probe Request
-		{
-			ie_ptr = pnetwork->network.IEs;
-			total_ielen = pnetwork->network.IELength;
-		}
-		else     // Beacon or Probe Respones
-		{
-			ie_ptr = pnetwork->network.IEs + _FIXED_IE_LENGTH_;
-			total_ielen = pnetwork->network.IELength - _FIXED_IE_LENGTH_;
-		}
-        
-		while(cnt < total_ielen)
-		{
-			if(rtw_is_wps_ie(&ie_ptr[cnt], &wps_ielen) && (wps_ielen>2))			
-			{
-				wpsie_ptr = &ie_ptr[cnt];
-				iwe.cmd =IWEVGENIE;
-				iwe.u.data.length = (u16)wps_ielen;
-				start = iwe_stream_add_point(info, start, stop, &iwe, wpsie_ptr);						
-			}			
-			cnt+=ie_ptr[cnt+1]+2; //goto next
-		}
-	}
-
-#ifdef CONFIG_WAPI_SUPPORT
-	if (pnetwork->network.Reserved[0] != 2) // Probe Request
-	{
-		sint out_len_wapi=0;
-		/* here use static for stack size */
-		static u8 buf_wapi[MAX_WAPI_IE_LEN*2];
-		static u8 wapi_ie[MAX_WAPI_IE_LEN];
-		u16 wapi_len=0;
-		u16  i;
-
-		_rtw_memset(buf_wapi, 0, MAX_WAPI_IE_LEN);
-		_rtw_memset(wapi_ie, 0, MAX_WAPI_IE_LEN);
-
-		out_len_wapi=rtw_get_wapi_ie(pnetwork->network.IEs ,pnetwork->network.IELength,wapi_ie,&wapi_len);
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: ssid=%s\n",pnetwork->network.Ssid.Ssid));
-		RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan: wapi_len=%d \n",wapi_len));
-
-		DBG_871X("rtw_wx_get_scan: %s ",pnetwork->network.Ssid.Ssid);
-		DBG_871X("rtw_wx_get_scan: ssid = %d ",wapi_len);
-
-
-		if (wapi_len > 0)
-		{
-			p=buf_wapi;
-			_rtw_memset(buf_wapi, 0, MAX_WAPI_IE_LEN*2);
-			p += sprintf(p, "wapi_ie=");
-			for (i = 0; i < wapi_len; i++) {
-				p += sprintf(p, "%02x", wapi_ie[i]);
-			}
-
-			_rtw_memset(&iwe, 0, sizeof(iwe));
-			iwe.cmd = IWEVCUSTOM;
-			iwe.u.data.length = strlen(buf_wapi);
-			start = iwe_stream_add_point(info, start, stop, &iwe,buf_wapi);
-
-			_rtw_memset(&iwe, 0, sizeof(iwe));
-			iwe.cmd =IWEVGENIE;
-			iwe.u.data.length = wapi_len;
-			start = iwe_stream_add_point(info, start, stop, &iwe, wapi_ie);
-		}
-	}
-#endif
-
-{
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	u8 ss, sq;
-	
-	/* Add quality statistics */
-	iwe.cmd = IWEVQUAL;
-	iwe.u.qual.updated = IW_QUAL_QUAL_UPDATED | IW_QUAL_LEVEL_UPDATED 
-	#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-		| IW_QUAL_NOISE_UPDATED
-	#else
-		| IW_QUAL_NOISE_INVALID
-	#endif
-	#ifdef CONFIG_SIGNAL_DISPLAY_DBM
-		| IW_QUAL_DBM
-	#endif
-	;
-
-	if ( check_fwstate(pmlmepriv, _FW_LINKED)== _TRUE &&
-		is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)){
-		ss = padapter->recvpriv.signal_strength;
-		sq = padapter->recvpriv.signal_qual;
-	} else {
-		ss = pnetwork->network.PhyInfo.SignalStrength;
-		sq = pnetwork->network.PhyInfo.SignalQuality;
-	}
-	
-	
-	#ifdef CONFIG_SIGNAL_DISPLAY_DBM
-	iwe.u.qual.level = (u8) translate_percentage_to_dbm(ss); /* dbm */
-	#else
-	#ifdef CONFIG_SIGNAL_SCALE_MAPPING
-	iwe.u.qual.level = (u8)ss; /* % */
-	#else
-	{
-		/* Do signal scale mapping when using percentage as the unit of signal strength, since the scale mapping is skipped in odm */
-		
-		HAL_DATA_TYPE *pHal = GET_HAL_DATA(padapter);
-		
-		iwe.u.qual.level = (u8)odm_SignalScaleMapping(&pHal->odmpriv, ss);
-	}
-	#endif
-	#endif
-	
-	iwe.u.qual.qual = (u8)sq;   // signal quality
-
-	#ifdef CONFIG_PLATFORM_ROCKCHIPS
-	iwe.u.qual.noise = -100; // noise level suggest by zhf@rockchips
-	#else 
-	#if defined(CONFIG_SIGNAL_DISPLAY_DBM) && defined(CONFIG_BACKGROUND_NOISE_MONITOR)
-	{
-		s16 tmp_noise=0;
-		rtw_hal_get_odm_var(padapter, HAL_ODM_NOISE_MONITOR,&(pnetwork->network.Configuration.DSConfig), &(tmp_noise));
-		iwe.u.qual.noise = tmp_noise ;
-	}
-	#else
-	iwe.u.qual.noise = 0; // noise level
-	#endif	
-	#endif //CONFIG_PLATFORM_ROCKCHIPS
-	
-	//DBG_871X("iqual=%d, ilevel=%d, inoise=%d, iupdated=%d\n", iwe.u.qual.qual, iwe.u.qual.level , iwe.u.qual.noise, iwe.u.qual.updated);
-
-	start = iwe_stream_add_event(info, start, stop, &iwe, IW_EV_QUAL_LEN);
-}
-
-	{
-		u8 buf[MAX_WPA_IE_LEN];
-		u8 * p,*pos;
-		int len;
-		p = buf;
-		pos = pnetwork->network.Reserved;
-		_rtw_memset(buf, 0, MAX_WPA_IE_LEN);
-		p += sprintf(p, "fm=%02X%02X", pos[1], pos[0]);
-		_rtw_memset(&iwe, 0, sizeof(iwe));
-		iwe.cmd = IWEVCUSTOM;
-		iwe.u.data.length = strlen(buf);
-		start = iwe_stream_add_point(info, start, stop, &iwe, buf);
-	}
-	
-	return start;	
-}
-#endif
-
-static int wpa_set_auth_algs(struct net_device *dev, u32 value)
-{	
-	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
-	int ret = 0;
-
-	if ((value & AUTH_ALG_SHARED_KEY)&&(value & AUTH_ALG_OPEN_SYSTEM))
-	{
-		DBG_871X("wpa_set_auth_algs, AUTH_ALG_SHARED_KEY and  AUTH_ALG_OPEN_SYSTEM [value:0x%x]\n",value);
-		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
-		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
-	} 
-	else if (value & AUTH_ALG_SHARED_KEY)
-	{
-		DBG_871X("wpa_set_auth_algs, AUTH_ALG_SHARED_KEY  [value:0x%x]\n",value);
-		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-
-#ifdef CONFIG_PLATFORM_MT53XX
-		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
-		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
-#else
-		padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeShared;
-		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Shared;
-#endif
-	} 
-	else if(value & AUTH_ALG_OPEN_SYSTEM)
-	{
-		DBG_871X("wpa_set_auth_algs, AUTH_ALG_OPEN_SYSTEM\n");
-		//padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
-		if(padapter->securitypriv.ndisauthtype < Ndis802_11AuthModeWPAPSK)
-		{
-#ifdef CONFIG_PLATFORM_MT53XX
-			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeAutoSwitch;
-			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
-#else
-			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
- 			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
-#endif
-		}
-		
-	}
-	else if(value & AUTH_ALG_LEAP)
-	{
-		DBG_871X("wpa_set_auth_algs, AUTH_ALG_LEAP\n");
-	}
-	else
-	{
-		DBG_871X("wpa_set_auth_algs, error!\n");
-		ret = -EINVAL;
-	}
-
-	return ret;
-	
-}
-
-static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
-{
-	int ret = 0;
-	u32 wep_key_idx, wep_key_len,wep_total_len;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;		
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
-#ifdef CONFIG_P2P
-	struct wifidirect_info* pwdinfo = &padapter->wdinfo;
-#endif //CONFIG_P2P
-
-_func_enter_;
-
-	param->u.crypt.err = 0;
-	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
-
-	if (param_len < (u32) ((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len)
-	{
-		ret =  -EINVAL;
-		goto exit;
-	}
-
-	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
-	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-
-		if (param->u.crypt.idx >= WEP_KEYS
-#ifdef CONFIG_IEEE80211W
-			&& param->u.crypt.idx > BIP_MAX_KEYID
-#endif //CONFIG_IEEE80211W
-			)
-		{
-			ret = -EINVAL;
-			goto exit;
-		}
-	} 
-	else 
-	{
-#ifdef CONFIG_WAPI_SUPPORT
-		if (strcmp(param->u.crypt.alg, "SMS4"))
-#endif
-		{
-			ret = -EINVAL;
-			goto exit;
-		}
-	}
-
-	if (strcmp(param->u.crypt.alg, "WEP") == 0)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("wpa_set_encryption, crypt.alg = WEP\n"));
-		DBG_871X("wpa_set_encryption, crypt.alg = WEP\n");
+	if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+		RTW_INFO("wpa_set_encryption, crypt.alg = WEP\n");
 
 		wep_key_idx = param->u.crypt.idx;
 		wep_key_len = param->u.crypt.key_len;
 
-		if ((wep_key_idx > WEP_KEYS) || (wep_key_len <= 0))
-		{
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
 			ret = -EINVAL;
 			goto exit;
 		}
@@ -1430,484 +923,353 @@ _func_enter_;
 			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
 			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
 
-			if (wep_key_len == 13)
-			{
+			if (wep_key_len == 13) {
 				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
 				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
 			}
 
 			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
 		}
-			
+
 		_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), param->u.crypt.key, wep_key_len);
-			
+
 		psecuritypriv->dot11DefKeylen[wep_key_idx] = wep_key_len;
 
 		psecuritypriv->key_mask |= BIT(wep_key_idx);
 
-		goto exit;		
+		padapter->mlmeextpriv.mlmext_info.key_index = wep_key_idx;
+		goto exit;
 	}
 
-	if(padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) // 802_1x
-	{
-		struct sta_info * psta,*pbcmc_sta;
-		struct sta_priv * pstapriv = &padapter->stapriv;
+	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) == _TRUE) //sta mode
-		{
-			psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));				
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_MP_STATE) == _TRUE) { /* sta mode */
+			psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
 			if (psta == NULL) {
-				//DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail \n"));
-			}
-			else
-			{
-				//Jeff: don't disable ieee8021x_blocked while clearing key
-				if (strcmp(param->u.crypt.alg, "none") != 0) 
+				/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
 					psta->ieee8021x_blocked = _FALSE;
-				
-				if((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled)||
-						(padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
-				{
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
 					psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
-				}		
-
-				if(param->u.crypt.set_tx ==1)//pairwise key
-				{ 
-					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-					
-					if(strcmp(param->u.crypt.alg, "TKIP") == 0)//set mic key
-					{						
-						//DEBUG_ERR(("\nset key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len));
+
+				if (param->u.crypt.set_tx == 1) { /* pairwise key */
+					RTW_INFO(FUNC_ADPT_FMT" set %s PTK idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0) { /* set mic key */
 						_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
 						_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
-						padapter->securitypriv.busetkipkey=_FALSE;
-						//_set_timer(&padapter->securitypriv.tkip_timer, 50);						
+						padapter->securitypriv.busetkipkey = _FALSE;
 					}
-
-					//DEBUG_ERR((" param->u.crypt.key_len=%d\n",param->u.crypt.key_len));
-					DBG_871X(" ~~~~set sta key:unicastkey\n");
-					
-					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
-					
+					psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
 					psta->bpairwise_key_installed = _TRUE;
-					
-				}
-				else//group key
-				{ 					
-					if(strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0)
-					{
-						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,(param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-						//only TKIP group key need to install this
-						if(param->u.crypt.key_len > 16)
-						{
-							_rtw_memcpy(padapter->securitypriv.dot118021XGrptxmickey[param->u.crypt.idx].skey,&(param->u.crypt.key[16]),8);
-							_rtw_memcpy(padapter->securitypriv.dot118021XGrprxmickey[param->u.crypt.idx].skey,&(param->u.crypt.key[24]),8);
+					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
+
+				} else { /* group key */
+					if (strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set %s GTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						/* only TKIP group key need to install this */
+						if (param->u.crypt.key_len > 16) {
+							_rtw_memcpy(padapter->securitypriv.dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
+							_rtw_memcpy(padapter->securitypriv.dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
 						}
-						padapter->securitypriv.binstallGrpkey = _TRUE;	
-						//DEBUG_ERR((" param->u.crypt.key_len=%d\n", param->u.crypt.key_len));
-						DBG_871X(" ~~~~set sta key:groupkey\n");
-	
+						padapter->securitypriv.binstallGrpkey = _TRUE;
+						if (param->u.crypt.idx < 4)
+							_rtw_memcpy(padapter->securitypriv.iv_seq[param->u.crypt.idx], param->u.crypt.seq, 8);
 						padapter->securitypriv.dot118021XGrpKeyid = param->u.crypt.idx;
-	
-						rtw_set_key(padapter,&padapter->securitypriv,param->u.crypt.idx, 1, _TRUE);
-					}
-#ifdef CONFIG_IEEE80211W
-					else if(strcmp(param->u.crypt.alg, "BIP") == 0)
-					{
-						int no;
-						//printk("BIP key_len=%d , index=%d @@@@@@@@@@@@@@@@@@\n", param->u.crypt.key_len, param->u.crypt.idx);
-						//save the IGTK key, length 16 bytes
-						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,(param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-						/*printk("IGTK key below:\n");
-						for(no=0;no<16;no++)
-							printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-						printk("\n");*/
-						padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
-						padapter->securitypriv.binstallBIPkey = _TRUE;
-						DBG_871X(" ~~~~set sta key:IGKT\n");
+						rtw_set_key(padapter, &padapter->securitypriv, param->u.crypt.idx, 1, _TRUE);
+
+					#ifdef CONFIG_IEEE80211W
+					} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set IGTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,
+							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+						psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+						psecuritypriv->dot11wBIPrxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+						psecuritypriv->binstallBIPkey = _TRUE;
+					#endif /* CONFIG_IEEE80211W */
+
 					}
-#endif //CONFIG_IEEE80211W
-					
+
 #ifdef CONFIG_P2P
-					if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
-					{
+					if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_DONE);
-					}
-#endif //CONFIG_P2P
-					
-				}						
-			}
+#endif /* CONFIG_P2P */
 
-			pbcmc_sta=rtw_get_bcmc_stainfo(padapter);
-			if(pbcmc_sta==NULL)
-			{
-				//DEBUG_ERR( ("Set OID_802_11_ADD_KEY: bcmc stainfo is null \n"));
+				}
 			}
-			else
-			{
-				//Jeff: don't disable ieee8021x_blocked while clearing key
-				if (strcmp(param->u.crypt.alg, "none") != 0) 
+
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta == NULL) {
+				/* DEBUG_ERR( ("Set OID_802_11_ADD_KEY: bcmc stainfo is null\n")); */
+			} else {
+				/* Jeff: don't disable ieee8021x_blocked while clearing key */
+				if (strcmp(param->u.crypt.alg, "none") != 0)
 					pbcmc_sta->ieee8021x_blocked = _FALSE;
-				
-				if((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled)||
-						(padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
-				{							
+
+				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
+				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
 					pbcmc_sta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
-				}					
-			}				
+			}
+		} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) { /* adhoc mode */
 		}
-		else if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) //adhoc mode
-		{		
-		}			
 	}
 
 #ifdef CONFIG_WAPI_SUPPORT
 	if (strcmp(param->u.crypt.alg, "SMS4") == 0)
-	{
-		PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
-		PRT_WAPI_STA_INFO	pWapiSta;
-		u8					WapiASUEPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-		u8					WapiAEPNInitialValueSrc[16] = {0x37,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-		u8 					WapiAEMultiCastPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ;
-
-		if(param->u.crypt.set_tx == 1)
-		{
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if(_rtw_memcmp(pWapiSta->PeerMacAddr,param->sta_addr,6))
-				{
-					_rtw_memcpy(pWapiSta->lastTxUnicastPN,WapiASUEPNInitialValueSrc,16);
-
-					pWapiSta->wapiUsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiUsk.dataKey,param->u.crypt.key,16);
-					_rtw_memcpy(pWapiSta->wapiUsk.micKey,param->u.crypt.key+16,16);
-					pWapiSta->wapiUsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiUsk.bTxEnable = true;
-
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue,WapiAEPNInitialValueSrc,16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPN,WapiAEPNInitialValueSrc,16);
-					pWapiSta->wapiUskUpdate.bTxEnable = false;
-					pWapiSta->wapiUskUpdate.bSet = false;
-
-					if (psecuritypriv->sw_encrypt== false || psecuritypriv->sw_decrypt == false)
-					{
-						//set unicast key for ASUE
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiUsk, pWapiSta, false, false);
-					}
-				}
-			}
-		}
-		else
-		{
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if(_rtw_memcmp(pWapiSta->PeerMacAddr,get_bssid(pmlmepriv),6))
-				{
-					pWapiSta->wapiMsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiMsk.dataKey,param->u.crypt.key,16);
-					_rtw_memcpy(pWapiSta->wapiMsk.micKey,param->u.crypt.key+16,16);
-					pWapiSta->wapiMsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiMsk.bTxEnable = false;
-					if(!pWapiSta->bSetkeyOk)
-						pWapiSta->bSetkeyOk = true;
-					pWapiSta->bAuthenticateInProgress = false;
-
-					_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
-
-					if (psecuritypriv->sw_decrypt == false)
-					{
-						//set rx broadcast key for ASUE
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiMsk, pWapiSta, true, false);
-					}
-				}
-
-			}
-		}
-	}
+		rtw_wapi_set_set_encryption(padapter, param);
 #endif
 
 exit:
-	
-_func_exit_;
 
-	return ret;	
+
+	return ret;
 }
 
 static int rtw_set_wpa_ie(_adapter *padapter, char *pie, unsigned short ielen)
 {
-	u8 *buf=NULL, *pos=NULL;	
-	u32 left; 	
+	u8 *buf = NULL, *pos = NULL;
+	u32 left;
 	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
 	int ret = 0;
-	u8 null_addr[]= {0,0,0,0,0,0};
+	u8 null_addr[] = {0, 0, 0, 0, 0, 0};
 #ifdef CONFIG_P2P
-	struct wifidirect_info* pwdinfo = &padapter->wdinfo;
-#endif //CONFIG_P2P
+	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
 
-	if((ielen > MAX_WPA_IE_LEN) || (pie == NULL)){
+	if ((ielen > MAX_WPA_IE_LEN) || (pie == NULL)) {
 		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
-		if(pie == NULL)	
+		if (pie == NULL)
 			return ret;
 		else
 			return -EINVAL;
 	}
 
-	if(ielen)
-	{		
+	if (ielen) {
 		buf = rtw_zmalloc(ielen);
-		if (buf == NULL){
+		if (buf == NULL) {
 			ret =  -ENOMEM;
 			goto exit;
 		}
-	
+
 		_rtw_memcpy(buf, pie , ielen);
 
-		//dump
+		/* dump */
 		{
 			int i;
-			DBG_871X("\n wpa_ie(length:%d):\n", ielen);
-			for(i=0;i<ielen;i=i+8)
-				DBG_871X("0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x \n",buf[i],buf[i+1],buf[i+2],buf[i+3],buf[i+4],buf[i+5],buf[i+6],buf[i+7]);
+			RTW_INFO("\n wpa_ie(length:%d):\n", ielen);
+			for (i = 0; i < ielen; i = i + 8)
+				RTW_INFO("0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x\n", buf[i], buf[i + 1], buf[i + 2], buf[i + 3], buf[i + 4], buf[i + 5], buf[i + 6], buf[i + 7]);
 		}
-	
+
 		pos = buf;
-		if(ielen < RSN_HEADER_LEN){
-			RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("Ie len too short %d\n", ielen));
+		if (ielen < RSN_HEADER_LEN) {
 			ret  = -1;
 			goto exit;
 		}
 
-#if 0
-		pos += RSN_HEADER_LEN;
-		left  = ielen - RSN_HEADER_LEN;
-		
-		if (left >= RSN_SELECTOR_LEN){
-			pos += RSN_SELECTOR_LEN;
-			left -= RSN_SELECTOR_LEN;
-		}		
-		else if (left > 0){
-			RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("Ie length mismatch, %u too much \n", left));
-			ret =-1;
-			goto exit;
-		}
-#endif		
-		
-		if(rtw_parse_wpa_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS)
-		{
-			padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_8021X;
-			padapter->securitypriv.ndisauthtype=Ndis802_11AuthModeWPAPSK;
-			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);	
+		if (rtw_parse_wpa_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);
 		}
-	
-		if(rtw_parse_wpa2_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS)
-		{
-			padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_8021X;
-			padapter->securitypriv.ndisauthtype=Ndis802_11AuthModeWPA2PSK;	
-			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);	
+
+		if (rtw_parse_wpa2_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK;
+			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);
 		}
-			
+
 		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 = _NO_PRIVACY_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+			break;
+		case WPA_CIPHER_WEP40:
+			padapter->securitypriv.dot118021XGrpPrivacy = _WEP40_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
+		case WPA_CIPHER_TKIP:
+			padapter->securitypriv.dot118021XGrpPrivacy = _TKIP_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+			break;
+		case WPA_CIPHER_CCMP:
+			padapter->securitypriv.dot118021XGrpPrivacy = _AES_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+			break;
+		case WPA_CIPHER_WEP104:
+			padapter->securitypriv.dot118021XGrpPrivacy = _WEP104_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
 		}
-			
-		switch(group_cipher)
-		{
-			case WPA_CIPHER_NONE:
-				padapter->securitypriv.dot118021XGrpPrivacy=_NO_PRIVACY_;
-				padapter->securitypriv.ndisencryptstatus=Ndis802_11EncryptionDisabled;
-				break;
-			case WPA_CIPHER_WEP40:
-				padapter->securitypriv.dot118021XGrpPrivacy=_WEP40_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-				break;
-			case WPA_CIPHER_TKIP:
-				padapter->securitypriv.dot118021XGrpPrivacy=_TKIP_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
-				break;
-			case WPA_CIPHER_CCMP:
-				padapter->securitypriv.dot118021XGrpPrivacy=_AES_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
-				break;
-			case WPA_CIPHER_WEP104:	
-				padapter->securitypriv.dot118021XGrpPrivacy=_WEP104_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-				break;
+
+		switch (pairwise_cipher) {
+		case WPA_CIPHER_NONE:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+			break;
+		case WPA_CIPHER_WEP40:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
+		case WPA_CIPHER_TKIP:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _TKIP_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
+			break;
+		case WPA_CIPHER_CCMP:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _AES_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
+			break;
+		case WPA_CIPHER_WEP104:
+			padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
+			break;
 		}
 
-		switch(pairwise_cipher)
-		{
-			case WPA_CIPHER_NONE:
-				padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;
-				padapter->securitypriv.ndisencryptstatus=Ndis802_11EncryptionDisabled;
-				break;
-			case WPA_CIPHER_WEP40:
-				padapter->securitypriv.dot11PrivacyAlgrthm=_WEP40_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-				break;
-			case WPA_CIPHER_TKIP:
-				padapter->securitypriv.dot11PrivacyAlgrthm=_TKIP_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
-				break;
-			case WPA_CIPHER_CCMP:
-				padapter->securitypriv.dot11PrivacyAlgrthm=_AES_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
-				break;
-			case WPA_CIPHER_WEP104:	
-				padapter->securitypriv.dot11PrivacyAlgrthm=_WEP104_;
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
-				break;
+		if (mfp_opt == MFP_INVALID) {
+			RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+			ret = -EINVAL;
+			goto exit;
 		}
-		
+		padapter->securitypriv.mfp_opt = mfp_opt;
+
 		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
-		{//set wps_ie	
-			u16 cnt = 0;	
-			u8 eid, wps_oui[4]={0x0,0x50,0xf2,0x04};
-			 
-			while( cnt < ielen )
-			{
+		{/* set wps_ie	 */
+			u16 cnt = 0;
+			u8 eid, wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
+
+			while (cnt < ielen) {
 				eid = buf[cnt];
-		
-				if((eid==_VENDOR_SPECIFIC_IE_)&&(_rtw_memcmp(&buf[cnt+2], wps_oui, 4)==_TRUE))
-				{
-					DBG_871X("SET WPS_IE\n");
 
-					padapter->securitypriv.wps_ie_len = ((buf[cnt+1]+2) < MAX_WPS_IE_LEN) ? (buf[cnt+1]+2):MAX_WPS_IE_LEN;
+				if ((eid == _VENDOR_SPECIFIC_IE_) && (_rtw_memcmp(&buf[cnt + 2], wps_oui, 4) == _TRUE)) {
+					RTW_INFO("SET WPS_IE\n");
+
+					padapter->securitypriv.wps_ie_len = ((buf[cnt + 1] + 2) < MAX_WPS_IE_LEN) ? (buf[cnt + 1] + 2) : MAX_WPS_IE_LEN;
 
 					_rtw_memcpy(padapter->securitypriv.wps_ie, &buf[cnt], padapter->securitypriv.wps_ie_len);
-					
+
 					set_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS);
-					
+
 #ifdef CONFIG_P2P
-					if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_OK))
-					{
+					if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_OK))
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_ING);
-					}
-#endif //CONFIG_P2P
-					cnt += buf[cnt+1]+2;
-					
+#endif /* CONFIG_P2P */
+					cnt += buf[cnt + 1] + 2;
+
 					break;
 				} else {
-					cnt += buf[cnt+1]+2; //goto next	
-				}				
-			}			
-		}		
-	}
-	
-	//TKIP and AES disallow multicast packets until installing group key
-        if(padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_
-                || padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_WTMIC_
-                || padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)
-                //WPS open need to enable multicast
-                //|| check_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS) == _TRUE)
-                rtw_hal_set_hwreg(padapter, HW_VAR_OFF_RCR_AM, null_addr);
-	
-	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));
- 	
+					cnt += buf[cnt + 1] + 2; /* goto next	 */
+				}
+			}
+		}
+	}
+
+	/* TKIP and AES disallow multicast packets until installing group key */
+	if (padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_
+	    || padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_WTMIC_
+	    || padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)
+		/* WPS open need to enable multicast
+		 * || check_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS) == _TRUE) */
+		rtw_hal_set_hwreg(padapter, HW_VAR_OFF_RCR_AM, null_addr);
+
+
 exit:
 
-	if (buf) rtw_mfree(buf, ielen);
+	if (buf)
+		rtw_mfree(buf, ielen);
 
 	return ret;
 }
 
-static int rtw_wx_get_name(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_name(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u16 cap;
 	u32 ht_ielen = 0;
 	char *p;
-	u8 ht_cap=_FALSE, vht_cap=_FALSE;
+	u8 ht_cap = _FALSE, vht_cap = _FALSE;
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;
-	NDIS_802_11_RATES_EX* prates = NULL;
+	NDIS_802_11_RATES_EX *prates = NULL;
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("cmd_code=%x\n", info->cmd));
 
-	_func_enter_;	
 
-	if (check_fwstate(pmlmepriv, _FW_LINKED|WIFI_ADHOC_MASTER_STATE) == _TRUE)
-	{
-		//parsing HT_CAP_IE
-		p = rtw_get_ie(&pcur_bss->IEs[12], _HT_CAPABILITY_IE_, &ht_ielen, pcur_bss->IELength-12);
-		if(p && ht_ielen>0)
-		{
+	if (check_fwstate(pmlmepriv, _FW_LINKED | WIFI_ADHOC_MASTER_STATE) == _TRUE) {
+		/* parsing HT_CAP_IE */
+		p = rtw_get_ie(&pcur_bss->IEs[12], _HT_CAPABILITY_IE_, &ht_ielen, pcur_bss->IELength - 12);
+		if (p && ht_ielen > 0)
 			ht_cap = _TRUE;
-		}
 
 #ifdef CONFIG_80211AC_VHT
-		if(pmlmepriv->vhtpriv.vht_option == _TRUE)
+		if (pmlmepriv->vhtpriv.vht_option == _TRUE)
 			vht_cap = _TRUE;
 #endif
 
 		prates = &pcur_bss->SupportedRates;
 
-		if (rtw_is_cckratesonly_included((u8*)prates) == _TRUE)
-		{
-			if(ht_cap == _TRUE)
+		if (rtw_is_cckratesonly_included((u8 *)prates) == _TRUE) {
+			if (ht_cap == _TRUE)
 				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bn");
 			else
 				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11b");
-		}
-		else if ((rtw_is_cckrates_included((u8*)prates)) == _TRUE)
-		{
-			if(ht_cap == _TRUE)
+		} else if ((rtw_is_cckrates_included((u8 *)prates)) == _TRUE) {
+			if (ht_cap == _TRUE)
 				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bgn");
 			else
 				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bg");
-		}
-		else
-		{
-			if(pcur_bss->Configuration.DSConfig > 14)
-			{
-			#ifdef CONFIG_80211AC_VHT
-				if(vht_cap == _TRUE){
+		} else {
+			if (pcur_bss->Configuration.DSConfig > 14) {
+#ifdef CONFIG_80211AC_VHT
+				if (vht_cap == _TRUE)
 					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11AC");
-				}
 				else
-			#endif
+#endif
 				{
-					if(ht_cap == _TRUE)
+					if (ht_cap == _TRUE)
 						snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11an");
 					else
 						snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11a");
 				}
-			}
-			else
-			{
-				if(ht_cap == _TRUE)
+			} else {
+				if (ht_cap == _TRUE)
 					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11gn");
 				else
 					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11g");
 			}
 		}
-	}
-	else
-	{
-		//prates = &padapter->registrypriv.dev_network.SupportedRates;
-		//snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11g");
+	} else {
+		/* prates = &padapter->registrypriv.dev_network.SupportedRates; */
+		/* snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11g"); */
 		snprintf(wrqu->name, IFNAMSIZ, "unassociated");
 	}
 
-	_func_exit_;
 
 	return 0;
 }
 
-static int rtw_wx_set_freq(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
-{	
+static int rtw_wx_set_freq(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
@@ -1915,22 +1277,22 @@ static int rtw_wx_set_freq(struct net_device *dev,
 	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
 	int exp = 1, freq = 0, div = 0;
 
-	_func_enter_;
-
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_, ("+rtw_wx_set_freq\n"));
 
+	rtw_ps_deny(padapter, PS_DENY_IOCTL);
+	if (rtw_pwr_wakeup(padapter) == _FALSE)
+		goto exit;
 	if (wrqu->freq.m <= 1000) {
 		if (wrqu->freq.flags == IW_FREQ_AUTO) {
-			if (rtw_ch_set_search_ch(padapter->mlmeextpriv.channel_set, wrqu->freq.m) > 0) {
+			if (rtw_chset_search_ch(adapter_to_chset(padapter), wrqu->freq.m) > 0) {
 				padapter->mlmeextpriv.cur_channel = wrqu->freq.m;
-				DBG_871X("%s: channel is auto, set to channel %d\n", __func__, wrqu->freq.m);
+				RTW_INFO("%s: channel is auto, set to channel %d\n", __func__, wrqu->freq.m);
 			} else {
 				padapter->mlmeextpriv.cur_channel = 1;
-				DBG_871X("%s: channel is auto, Channel Plan don't match just set to channel 1\n", __func__);
+				RTW_INFO("%s: channel is auto, Channel Plan don't match just set to channel 1\n", __func__);
 			}
 		} else {
 			padapter->mlmeextpriv.cur_channel = wrqu->freq.m;
-			DBG_871X("%s: set to channel %d\n", __func__, padapter->mlmeextpriv.cur_channel);
+			RTW_INFO("%s: set to channel %d\n", __func__, padapter->mlmeextpriv.cur_channel);
 		}
 	} else {
 		while (wrqu->freq.e) {
@@ -1940,36 +1302,35 @@ static int rtw_wx_set_freq(struct net_device *dev,
 
 		freq = wrqu->freq.m;
 
-		while (!(freq%10)) {
+		while (!(freq % 10)) {
 			freq /= 10;
 			exp *= 10;
 		}
 
 		/* freq unit is MHz here */
-		div = 1000000/exp;
+		div = 1000000 / exp;
 
 		if (div)
 			freq /= div;
 		else {
-			div = exp/1000000;
+			div = exp / 1000000;
 			freq *= div;
 		}
 
 		/* If freq is invalid, rtw_freq2ch() will return channel 1 */
 		padapter->mlmeextpriv.cur_channel = rtw_freq2ch(freq);
-		DBG_871X("%s: set to channel %d\n", __func__, padapter->mlmeextpriv.cur_channel);
+		RTW_INFO("%s: set to channel %d\n", __func__, padapter->mlmeextpriv.cur_channel);
 	}
-
 	set_channel_bwmode(padapter, padapter->mlmeextpriv.cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+exit:
+	rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
 
-	_func_exit_;
-	
 	return 0;
 }
 
-static int rtw_wx_get_freq(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_freq(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
@@ -1991,17 +1352,16 @@ static int rtw_wx_get_freq(struct net_device *dev,
 }
 
 static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,
-			     union iwreq_data *wrqu, char *b)
+			   union iwreq_data *wrqu, char *b)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType ;
 	int ret = 0;
-	
-	_func_enter_;
-	
-	if(_FAIL == rtw_pwr_wakeup(padapter)) {
-		ret= -EPERM;
+
+
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -EPERM;
 		goto exit;
 	}
 
@@ -2021,226 +1381,189 @@ static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,
 	}
 
 	switch (wrqu->mode) {
-		case IW_MODE_MONITOR:
-			networkType = Ndis802_11Monitor;
+	case IW_MODE_MONITOR:
+		networkType = Ndis802_11Monitor;
 #if 0
-			dev->type = ARPHRD_IEEE80211; /* IEEE 802.11 : 801 */
+		dev->type = ARPHRD_IEEE80211; /* IEEE 802.11 : 801 */
 #endif
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
-			dev->type = ARPHRD_IEEE80211_RADIOTAP; /* IEEE 802.11 + radiotap header : 803 */
-			DBG_871X("set_mode = IW_MODE_MONITOR\n");
+		dev->type = ARPHRD_IEEE80211_RADIOTAP; /* IEEE 802.11 + radiotap header : 803 */
+		RTW_INFO("set_mode = IW_MODE_MONITOR\n");
 #else
-			DBG_871X("kernel version < 2.6.24 not support IW_MODE_MONITOR\n");
+		RTW_INFO("kernel version < 2.6.24 not support IW_MODE_MONITOR\n");
 #endif
-			break;
+		break;
 
-		case IW_MODE_AUTO:
-			networkType = Ndis802_11AutoUnknown;
-			DBG_871X("set_mode = IW_MODE_AUTO\n");	
-			break;				
-		case IW_MODE_ADHOC:		
-			networkType = Ndis802_11IBSS;
-			DBG_871X("set_mode = IW_MODE_ADHOC\n");			
-			break;
-		case IW_MODE_MASTER:		
-			networkType = Ndis802_11APMode;
-			DBG_871X("set_mode = IW_MODE_MASTER\n");
-                        //rtw_setopmode_cmd(padapter, networkType,_TRUE);	
-			break;				
-		case IW_MODE_INFRA:
-			networkType = Ndis802_11Infrastructure;
-			DBG_871X("set_mode = IW_MODE_INFRA\n");			
-			break;
-	
-		default :
-			ret = -EINVAL;;
-			RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("\n Mode: %s is not supported  \n", iw_operation_mode[wrqu->mode]));
-			goto exit;
-	}
-	
-/*	
-	if(Ndis802_11APMode == networkType)
-	{
-		rtw_setopmode_cmd(padapter, networkType,_TRUE);
-	}	
-	else
-	{
-		rtw_setopmode_cmd(padapter, Ndis802_11AutoUnknown,_TRUE);	
+	case IW_MODE_AUTO:
+		networkType = Ndis802_11AutoUnknown;
+		RTW_INFO("set_mode = IW_MODE_AUTO\n");
+		break;
+	case IW_MODE_ADHOC:
+		networkType = Ndis802_11IBSS;
+		RTW_INFO("set_mode = IW_MODE_ADHOC\n");
+		break;
+	case IW_MODE_MASTER:
+		networkType = Ndis802_11APMode;
+		RTW_INFO("set_mode = IW_MODE_MASTER\n");
+		break;
+	case IW_MODE_INFRA:
+		networkType = Ndis802_11Infrastructure;
+		RTW_INFO("set_mode = IW_MODE_INFRA\n");
+		break;
+
+	default:
+		ret = -EINVAL;;
+		goto exit;
 	}
-*/
-	
-	if (rtw_set_802_11_infrastructure_mode(padapter, networkType) ==_FALSE){
+
+	if (rtw_set_802_11_infrastructure_mode(padapter, networkType) == _FALSE) {
 
 		ret = -EPERM;
 		goto exit;
 
 	}
 
-	rtw_setopmode_cmd(padapter, networkType,_TRUE);
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
 
 	if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE)
 		rtw_indicate_connect(padapter);
 
 exit:
-	
-	_func_exit_;
-	
+
+
 	return ret;
-	
+
 }
 
 static int rtw_wx_get_mode(struct net_device *dev, struct iw_request_info *a,
-			     union iwreq_data *wrqu, char *b)
+			   union iwreq_data *wrqu, char *b)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,(" rtw_wx_get_mode \n"));
 
-	_func_enter_;
-	
+
+
 	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-	{
 		wrqu->mode = IW_MODE_INFRA;
-	}
-	else if  ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
-		       (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
-		
-	{
+	else if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
+		 (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
+
 		wrqu->mode = IW_MODE_ADHOC;
-	}
-	else if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-	{
+	else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
 		wrqu->mode = IW_MODE_MASTER;
-	} else if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE)
+	else if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE)
 		wrqu->mode = IW_MODE_MONITOR;
 	else
 		wrqu->mode = IW_MODE_AUTO;
 
-	_func_exit_;
-	
+
 	return 0;
-	
+
 }
 
 
 static int rtw_wx_set_pmkid(struct net_device *dev,
-	                     struct iw_request_info *a,
-			     union iwreq_data *wrqu, char *extra)
+			    struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	u8          j,blInserted = _FALSE;
+	u8          j, blInserted = _FALSE;
 	int         intReturn = _FALSE;
 	struct mlme_priv  *pmlmepriv = &padapter->mlmepriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
-        struct iw_pmksa*  pPMK = ( struct iw_pmksa* ) extra;
-        u8     strZeroMacAddress[ ETH_ALEN ] = { 0x00 };
-        u8     strIssueBssid[ ETH_ALEN ] = { 0x00 };
-        
-/*
-        struct iw_pmksa
-        {
-            __u32   cmd;
-            struct sockaddr bssid;
-            __u8    pmkid[IW_PMKID_LEN];   //IW_PMKID_LEN=16
-        }
-        There are the BSSID information in the bssid.sa_data array.
-        If cmd is IW_PMKSA_FLUSH, it means the wpa_suppplicant wants to clear all the PMKID information.
-        If cmd is IW_PMKSA_ADD, it means the wpa_supplicant wants to add a PMKID/BSSID to driver.
-        If cmd is IW_PMKSA_REMOVE, it means the wpa_supplicant wants to remove a PMKID/BSSID from driver.
-        */
-
-	_rtw_memcpy( strIssueBssid, pPMK->bssid.sa_data, ETH_ALEN);
-        if ( pPMK->cmd == IW_PMKSA_ADD )
-        {
-                DBG_871X( "[rtw_wx_set_pmkid] IW_PMKSA_ADD!\n" );
-                if ( _rtw_memcmp( strIssueBssid, strZeroMacAddress, ETH_ALEN ) == _TRUE )
-                {
-                    return( intReturn );
-                }
-                else
-                {
-                    intReturn = _TRUE;
-                }
+	struct iw_pmksa  *pPMK = (struct iw_pmksa *) extra;
+	u8     strZeroMacAddress[ETH_ALEN] = { 0x00 };
+	u8     strIssueBssid[ETH_ALEN] = { 0x00 };
+
+#if 0
+	struct iw_pmksa {
+		__u32   cmd;
+		struct sockaddr bssid;
+		__u8    pmkid[IW_PMKID_LEN];   /* IW_PMKID_LEN=16 */
+	}
+	There are the BSSID information in the bssid.sa_data array.
+	If cmd is IW_PMKSA_FLUSH, it means the wpa_suppplicant wants to clear all the PMKID information.
+	If cmd is IW_PMKSA_ADD, it means the wpa_supplicant wants to add a PMKID / BSSID to driver.
+	If cmd is IW_PMKSA_REMOVE, it means the wpa_supplicant wants to remove a PMKID / BSSID from driver.
+#endif
+
+	_rtw_memcpy(strIssueBssid, pPMK->bssid.sa_data, ETH_ALEN);
+	if (pPMK->cmd == IW_PMKSA_ADD) {
+		RTW_INFO("[rtw_wx_set_pmkid] IW_PMKSA_ADD!\n");
+		if (_rtw_memcmp(strIssueBssid, strZeroMacAddress, ETH_ALEN) == _TRUE)
+			return intReturn ;
+		else
+			intReturn = _TRUE;
 		blInserted = _FALSE;
-		
-		//overwrite PMKID
-		for(j=0 ; j<NUM_PMKID_CACHE; j++)
-		{
-			if( _rtw_memcmp( psecuritypriv->PMKIDList[j].Bssid, strIssueBssid, ETH_ALEN) ==_TRUE )
-			{ // BSSID is matched, the same AP => rewrite with new PMKID.
-                                
-                                DBG_871X( "[rtw_wx_set_pmkid] BSSID exists in the PMKList.\n" );
-
-				_rtw_memcpy( psecuritypriv->PMKIDList[j].PMKID, pPMK->pmkid, IW_PMKID_LEN);
-                                psecuritypriv->PMKIDList[ j ].bUsed = _TRUE;
-				psecuritypriv->PMKIDIndex = j+1;
+
+		/* overwrite PMKID */
+		for (j = 0 ; j < NUM_PMKID_CACHE; j++) {
+			if (_rtw_memcmp(psecuritypriv->PMKIDList[j].Bssid, strIssueBssid, ETH_ALEN) == _TRUE) {
+				/* BSSID is matched, the same AP => rewrite with new PMKID. */
+
+				RTW_INFO("[rtw_wx_set_pmkid] BSSID exists in the PMKList.\n");
+
+				_rtw_memcpy(psecuritypriv->PMKIDList[j].PMKID, pPMK->pmkid, IW_PMKID_LEN);
+				psecuritypriv->PMKIDList[j].bUsed = _TRUE;
+				psecuritypriv->PMKIDIndex = j + 1;
 				blInserted = _TRUE;
 				break;
-			}	
-	        }
-
-	        if(!blInserted)
-                {
-		    // Find a new entry
-                    DBG_871X( "[rtw_wx_set_pmkid] Use the new entry index = %d for this PMKID.\n",
-                            psecuritypriv->PMKIDIndex );
-
-	            _rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].Bssid, strIssueBssid, ETH_ALEN);
-		    _rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].PMKID, pPMK->pmkid, IW_PMKID_LEN);
-
-                    psecuritypriv->PMKIDList[ psecuritypriv->PMKIDIndex ].bUsed = _TRUE;
-		    psecuritypriv->PMKIDIndex++ ;
-		    if(psecuritypriv->PMKIDIndex==16)
-                    {
-		        psecuritypriv->PMKIDIndex =0;
-                    }
-		}
-        }
-        else if ( pPMK->cmd == IW_PMKSA_REMOVE )
-        {
-                DBG_871X( "[rtw_wx_set_pmkid] IW_PMKSA_REMOVE!\n" );
-                intReturn = _TRUE;
-		for(j=0 ; j<NUM_PMKID_CACHE; j++)
-		{
-			if( _rtw_memcmp( psecuritypriv->PMKIDList[j].Bssid, strIssueBssid, ETH_ALEN) ==_TRUE )
-			{ // BSSID is matched, the same AP => Remove this PMKID information and reset it. 
-                                _rtw_memset( psecuritypriv->PMKIDList[ j ].Bssid, 0x00, ETH_ALEN );
-                                psecuritypriv->PMKIDList[ j ].bUsed = _FALSE;
+			}
+		}
+
+		if (!blInserted) {
+			/* Find a new entry */
+			RTW_INFO("[rtw_wx_set_pmkid] Use the new entry index = %d for this PMKID.\n",
+				 psecuritypriv->PMKIDIndex);
+
+			_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].Bssid, strIssueBssid, ETH_ALEN);
+			_rtw_memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].PMKID, pPMK->pmkid, IW_PMKID_LEN);
+
+			psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].bUsed = _TRUE;
+			psecuritypriv->PMKIDIndex++ ;
+			if (psecuritypriv->PMKIDIndex == 16)
+				psecuritypriv->PMKIDIndex = 0;
+		}
+	} else if (pPMK->cmd == IW_PMKSA_REMOVE) {
+		RTW_INFO("[rtw_wx_set_pmkid] IW_PMKSA_REMOVE!\n");
+		intReturn = _TRUE;
+		for (j = 0 ; j < NUM_PMKID_CACHE; j++) {
+			if (_rtw_memcmp(psecuritypriv->PMKIDList[j].Bssid, strIssueBssid, ETH_ALEN) == _TRUE) {
+				/* BSSID is matched, the same AP => Remove this PMKID information and reset it. */
+				_rtw_memset(psecuritypriv->PMKIDList[j].Bssid, 0x00, ETH_ALEN);
+				psecuritypriv->PMKIDList[j].bUsed = _FALSE;
 				break;
-			}	
-	        }
-        }
-        else if ( pPMK->cmd == IW_PMKSA_FLUSH ) 
-        {
-            DBG_871X( "[rtw_wx_set_pmkid] IW_PMKSA_FLUSH!\n" );
-            _rtw_memset( &psecuritypriv->PMKIDList[ 0 ], 0x00, sizeof( RT_PMKID_LIST ) * NUM_PMKID_CACHE );
-            psecuritypriv->PMKIDIndex = 0;
-            intReturn = _TRUE;
-        }
-    return( intReturn );
-}
-
-static int rtw_wx_get_sens(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+			}
+		}
+	} else if (pPMK->cmd == IW_PMKSA_FLUSH) {
+		RTW_INFO("[rtw_wx_set_pmkid] IW_PMKSA_FLUSH!\n");
+		_rtw_memset(&psecuritypriv->PMKIDList[0], 0x00, sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
+		psecuritypriv->PMKIDIndex = 0;
+		intReturn = _TRUE;
+	}
+	return intReturn ;
+}
+
+static int rtw_wx_get_sens(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
-	#ifdef CONFIG_PLATFORM_ROCKCHIPS
+#ifdef CONFIG_PLATFORM_ROCKCHIPS
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv); 
-	
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
 	/*
 	*  20110311 Commented by Jeff
 	*  For rockchip platform's wpa_driver_wext_get_rssi
 	*/
-	if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
-		//wrqu->sens.value=-padapter->recvpriv.signal_strength;
-		wrqu->sens.value=-padapter->recvpriv.rssi;
-		//DBG_871X("%s: %d\n", __FUNCTION__, wrqu->sens.value);
-		wrqu->sens.fixed = 0; /* no auto select */ 
-	} else 
-	#endif
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		/* wrqu->sens.value=-padapter->recvpriv.signal_strength; */
+		wrqu->sens.value = -padapter->recvpriv.rssi;
+		/* RTW_INFO("%s: %d\n", __FUNCTION__, wrqu->sens.value); */
+		wrqu->sens.fixed = 0; /* no auto select */
+	} else
+#endif
 	{
 		wrqu->sens.value = 0;
 		wrqu->sens.fixed = 0;	/* no auto select */
@@ -2249,20 +1572,19 @@ static int rtw_wx_get_sens(struct net_device *dev,
 	return 0;
 }
 
-static int rtw_wx_get_range(struct net_device *dev, 
-				struct iw_request_info *info, 
-				union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_range(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
 {
 	struct iw_range *range = (struct iw_range *)extra;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 
 	u16 val;
 	int i;
-	
-	_func_enter_;
-	
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_range. cmd_code=%x\n", info->cmd));
+
+
 
 	wrqu->data.length = sizeof(*range);
 	_rtw_memset(range, 0, sizeof(*range));
@@ -2276,17 +1598,17 @@ static int rtw_wx_get_range(struct net_device *dev,
 	 */
 
 	/* ~5 Mb/s real (802.11b) */
-	range->throughput = 5 * 1000 * 1000;     
+	range->throughput = 5 * 1000 * 1000;
 
-	// TODO: Not used in 802.11b?
-//	range->min_nwid;	/* Minimal NWID we are able to set */
-	// TODO: Not used in 802.11b?
-//	range->max_nwid;	/* Maximal NWID we are able to set */
+	/* TODO: Not used in 802.11b?
+	*	range->min_nwid;	 Minimal NWID we are able to set  */
+	/* TODO: Not used in 802.11b?
+	*	range->max_nwid;	 Maximal NWID we are able to set  */
 
-        /* Old Frequency (backward compat - moved lower ) */
-//	range->old_num_channels; 
-//	range->old_num_frequency;
-//	range->old_freq[6]; /* Filler to keep "version" at the same offset */
+	/* Old Frequency (backward compat - moved lower ) */
+	/*	range->old_num_channels;
+	 *	range->old_num_frequency;
+	 * 	range->old_freq[6];  Filler to keep "version" at the same offset  */
 
 	/* signal level threshold range */
 
@@ -2308,7 +1630,7 @@ static int rtw_wx_get_range(struct net_device *dev,
 	range->max_qual.updated = IW_QUAL_ALL_UPDATED; /* Updated all three */
 	range->max_qual.updated |= IW_QUAL_DBM;
 #else /* !CONFIG_SIGNAL_DISPLAY_DBM */
-	//percent values between 0 and 100.
+	/* percent values between 0 and 100. */
 	range->max_qual.level = 100;
 	range->max_qual.noise = 100;
 	range->max_qual.updated = IW_QUAL_ALL_UPDATED; /* Updated all three */
@@ -2339,9 +1661,8 @@ static int rtw_wx_get_range(struct net_device *dev,
 
 	range->num_bitrates = RATE_COUNT;
 
-	for (i = 0; i < RATE_COUNT && i < IW_MAX_BITRATES; i++) {
+	for (i = 0; i < RATE_COUNT && i < IW_MAX_BITRATES; i++)
 		range->bitrate[i] = rtw_rates[i];
-	}
 
 	range->min_frag = MIN_FRAG_THRESHOLD;
 	range->max_frag = MAX_FRAG_THRESHOLD;
@@ -2351,21 +1672,20 @@ static int rtw_wx_get_range(struct net_device *dev,
 	range->we_version_compiled = WIRELESS_EXT;
 	range->we_version_source = 16;
 
-//	range->retry_capa;	/* What retry options are supported */
-//	range->retry_flags;	/* How to decode max/min retry limit */
-//	range->r_time_flags;	/* How to decode max/min retry life */
-//	range->min_retry;	/* Minimal number of retries */
-//	range->max_retry;	/* Maximal number of retries */
-//	range->min_r_time;	/* Minimal retry lifetime */
-//	range->max_r_time;	/* Maximal retry lifetime */
+	/*	range->retry_capa;	 What retry options are supported
+	 *	range->retry_flags;	 How to decode max/min retry limit
+	 *	range->r_time_flags;	 How to decode max/min retry life
+	 *	range->min_retry;	 Minimal number of retries
+	 *	range->max_retry;	 Maximal number of retries
+	 *	range->min_r_time;	 Minimal retry lifetime
+	 *	range->max_r_time;	 Maximal retry lifetime  */
 
-	for (i = 0, val = 0; i < MAX_CHANNEL_NUM; i++) {
+	for (i = 0, val = 0; i < rfctl->max_chan_nums; i++) {
 
-		// Include only legal frequencies for some countries
-		if(pmlmeext->channel_set[i].ChannelNum != 0)
-		{
-			range->freq[val].i = pmlmeext->channel_set[i].ChannelNum;
-			range->freq[val].m = rtw_ch2freq(pmlmeext->channel_set[i].ChannelNum) * 100000;
+		/* Include only legal frequencies for some countries */
+		if (rfctl->channel_set[i].ChannelNum != 0) {
+			range->freq[val].i = rfctl->channel_set[i].ChannelNum;
+			range->freq[val].m = rtw_ch2freq(rfctl->channel_set[i].ChannelNum) * 100000;
 			range->freq[val].e = 1;
 			val++;
 		}
@@ -2377,48 +1697,47 @@ static int rtw_wx_get_range(struct net_device *dev,
 	range->num_channels = val;
 	range->num_frequency = val;
 
-// Commented by Albert 2009/10/13
-// The following code will proivde the security capability to network manager.
-// If the driver doesn't provide this capability to network manager,
-// the WPA/WPA2 routers can't be choosen in the network manager.
+	/* Commented by Albert 2009/10/13
+	 * The following code will proivde the security capability to network manager.
+	 * If the driver doesn't provide this capability to network manager,
+	 * the WPA/WPA2 routers can't be choosen in the network manager. */
 
-/*
-#define IW_SCAN_CAPA_NONE		0x00
-#define IW_SCAN_CAPA_ESSID		0x01
-#define IW_SCAN_CAPA_BSSID		0x02
-#define IW_SCAN_CAPA_CHANNEL	0x04
-#define IW_SCAN_CAPA_MODE		0x08
-#define IW_SCAN_CAPA_RATE		0x10
-#define IW_SCAN_CAPA_TYPE		0x20
-#define IW_SCAN_CAPA_TIME		0x40
-*/
+	/*
+	#define IW_SCAN_CAPA_NONE		0x00
+	#define IW_SCAN_CAPA_ESSID		0x01
+	#define IW_SCAN_CAPA_BSSID		0x02
+	#define IW_SCAN_CAPA_CHANNEL	0x04
+	#define IW_SCAN_CAPA_MODE		0x08
+	#define IW_SCAN_CAPA_RATE		0x10
+	#define IW_SCAN_CAPA_TYPE		0x20
+	#define IW_SCAN_CAPA_TIME		0x40
+	*/
 
 #if WIRELESS_EXT > 17
-	range->enc_capa = IW_ENC_CAPA_WPA|IW_ENC_CAPA_WPA2|
-			  IW_ENC_CAPA_CIPHER_TKIP|IW_ENC_CAPA_CIPHER_CCMP;
+	range->enc_capa = IW_ENC_CAPA_WPA | IW_ENC_CAPA_WPA2 |
+			  IW_ENC_CAPA_CIPHER_TKIP | IW_ENC_CAPA_CIPHER_CCMP;
 #endif
 
-#ifdef IW_SCAN_CAPA_ESSID //WIRELESS_EXT > 21
-	range->scan_capa = IW_SCAN_CAPA_ESSID | IW_SCAN_CAPA_TYPE |IW_SCAN_CAPA_BSSID|
-					IW_SCAN_CAPA_CHANNEL|IW_SCAN_CAPA_MODE|IW_SCAN_CAPA_RATE;
+#ifdef IW_SCAN_CAPA_ESSID /* WIRELESS_EXT > 21 */
+	range->scan_capa = IW_SCAN_CAPA_ESSID | IW_SCAN_CAPA_TYPE | IW_SCAN_CAPA_BSSID |
+		   IW_SCAN_CAPA_CHANNEL | IW_SCAN_CAPA_MODE | IW_SCAN_CAPA_RATE;
 #endif
 
 
-	_func_exit_;
 
 	return 0;
 
 }
 
-//set bssid flow
-//s1. rtw_set_802_11_infrastructure_mode()
-//s2. rtw_set_802_11_authentication_mode()
-//s3. set_802_11_encryption_mode()
-//s4. rtw_set_802_11_bssid()
+/* set bssid flow
+ * s1. rtw_set_802_11_infrastructure_mode()
+ * s2. rtw_set_802_11_authentication_mode()
+ * s3. set_802_11_encryption_mode()
+ * s4. rtw_set_802_11_bssid() */
 static int rtw_wx_set_wap(struct net_device *dev,
-			 struct iw_request_info *info,
-			 union iwreq_data *awrq,
-			 char *extra)
+			  struct iw_request_info *info,
+			  union iwreq_data *awrq,
+			  char *extra)
 {
 	_irqL	irqL;
 	uint ret = 0;
@@ -2431,21 +1750,19 @@ static int rtw_wx_set_wap(struct net_device *dev,
 	struct	wlan_network	*pnetwork = NULL;
 	NDIS_802_11_AUTHENTICATION_MODE	authmode;
 
-	_func_enter_;
-/*
-#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->iface_type > PRIMARY_IFACE)
-	{
-		ret = -EINVAL;
-		goto exit;
-	}
-#endif	
-*/	
+	/*
+	#ifdef CONFIG_CONCURRENT_MODE
+		if(padapter->adapter_type > PRIMARY_IFACE)
+		{
+			ret = -EINVAL;
+			goto exit;
+		}
+	#endif
+	*/
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_UNDER_SURVEY|_FW_UNDER_LINKING) == _TRUE)
-	{
-		DBG_871X("set bssid, but buddy_intf is under scanning or linking\n");
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("set bssid, but buddy_intf is under scanning or linking\n");
 
 		ret = -EINVAL;
 
@@ -2454,52 +1771,46 @@ static int rtw_wx_set_wap(struct net_device *dev,
 #endif
 
 	rtw_ps_deny(padapter, PS_DENY_JOIN);
-	if(_FAIL == rtw_pwr_wakeup(padapter))
-	{
-		ret= -1;
-		goto exit;
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -1;
+		goto cancel_ps_deny;
 	}
-	
-	if(!padapter->bup){
+
+	if (!padapter->bup) {
 		ret = -1;
-		goto exit;
+		goto cancel_ps_deny;
 	}
 
-	
-	if (temp->sa_family != ARPHRD_ETHER){
+
+	if (temp->sa_family != ARPHRD_ETHER) {
 		ret = -EINVAL;
-		goto exit;
+		goto cancel_ps_deny;
 	}
 
 	authmode = padapter->securitypriv.ndisauthtype;
 	_enter_critical_bh(&queue->lock, &irqL);
-       phead = get_list_head(queue);
-       pmlmepriv->pscanned = get_next(phead);
+	phead = get_list_head(queue);
+	pmlmepriv->pscanned = get_next(phead);
 
-	while (1)
-	 {
-			
-		if ((rtw_end_of_queue_search(phead, pmlmepriv->pscanned)) == _TRUE)
-		{
-#if 0		
+	while (1) {
+
+		if ((rtw_end_of_queue_search(phead, pmlmepriv->pscanned)) == _TRUE) {
+#if 0
 			ret = -EINVAL;
-			goto exit;
+			goto cancel_ps_deny;
 
-			if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)
-			{
-	            		rtw_set_802_11_bssid(padapter, temp->sa_data);
-	    			goto exit;                    
-			}
-			else
-			{
+			if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+				rtw_set_802_11_bssid(padapter, temp->sa_data);
+				goto cancel_ps_deny;
+			} else {
 				ret = -EINVAL;
-				goto exit;
+				goto cancel_ps_deny;
 			}
 #endif
 
 			break;
 		}
-	
+
 		pnetwork = LIST_CONTAINOR(pmlmepriv->pscanned, struct wlan_network, list);
 
 		pmlmepriv->pscanned = get_next(pmlmepriv->pscanned);
@@ -2508,363 +1819,325 @@ static int rtw_wx_set_wap(struct net_device *dev,
 
 		src_bssid = temp->sa_data;
 
-		if ((_rtw_memcmp(dst_bssid, src_bssid, ETH_ALEN)) == _TRUE)
-		{			
-			if(!rtw_set_802_11_infrastructure_mode(padapter, pnetwork->network.InfrastructureMode))
-			{
+		if ((_rtw_memcmp(dst_bssid, src_bssid, ETH_ALEN)) == _TRUE) {
+			if (!rtw_set_802_11_infrastructure_mode(padapter, pnetwork->network.InfrastructureMode)) {
 				ret = -1;
 				_exit_critical_bh(&queue->lock, &irqL);
-				goto exit;
+				goto cancel_ps_deny;
 			}
 
-				break;			
+			break;
 		}
 
-	}		
+	}
 	_exit_critical_bh(&queue->lock, &irqL);
-	
+
 	rtw_set_802_11_authentication_mode(padapter, authmode);
-	//set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus);
+	/* set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus); */
 	if (rtw_set_802_11_bssid(padapter, temp->sa_data) == _FALSE) {
 		ret = -1;
-		goto exit;		
-	}	
-	
-exit:
-	
+		goto cancel_ps_deny;
+	}
+
+cancel_ps_deny:
 	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
 
-	_func_exit_;
-	
-	return ret;	
+exit:
+	return ret;
 }
 
-static int rtw_wx_get_wap(struct net_device *dev, 
-			    struct iw_request_info *info, 
-			    union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_wap(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;	
-	
+	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;
+
 	wrqu->ap_addr.sa_family = ARPHRD_ETHER;
-	
+
 	_rtw_memset(wrqu->ap_addr.sa_data, 0, ETH_ALEN);
-	
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_wap\n"));
 
-	_func_enter_;
 
-	if  ( ((check_fwstate(pmlmepriv, _FW_LINKED)) == _TRUE) || 
-			((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) == _TRUE) ||
-			((check_fwstate(pmlmepriv, WIFI_AP_STATE)) == _TRUE) )
-	{
+
+	if (((check_fwstate(pmlmepriv, _FW_LINKED)) == _TRUE) ||
+	    ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) == _TRUE) ||
+	    ((check_fwstate(pmlmepriv, WIFI_AP_STATE)) == _TRUE))
 
 		_rtw_memcpy(wrqu->ap_addr.sa_data, pcur_bss->MacAddress, ETH_ALEN);
-	}
 	else
-	{
-	 	_rtw_memset(wrqu->ap_addr.sa_data, 0, ETH_ALEN);
-	}		
+		_rtw_memset(wrqu->ap_addr.sa_data, 0, ETH_ALEN);
+
 
-	_func_exit_;
-	
 	return 0;
-	
+
 }
 
-static int rtw_wx_set_mlme(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_set_mlme(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 #if 0
-/* SIOCSIWMLME data */
-struct	iw_mlme
-{
-	__u16		cmd; /* IW_MLME_* */
-	__u16		reason_code;
-	struct sockaddr	addr;
-};
+	/* SIOCSIWMLME data */
+	struct	iw_mlme {
+		__u16		cmd; /* IW_MLME_* */
+		__u16		reason_code;
+		struct sockaddr	addr;
+	};
 #endif
 
-	int ret=0;
+	int ret = 0;
 	u16 reason;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_mlme *mlme = (struct iw_mlme *) extra;
 
 
-	if(mlme==NULL)
+	if (mlme == NULL)
 		return -1;
 
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	reason = cpu_to_le16(mlme->reason_code);
 
 
-	DBG_871X("%s, cmd=%d, reason=%d\n", __FUNCTION__, mlme->cmd, reason);
-	
+	RTW_INFO("%s, cmd=%d, reason=%d\n", __FUNCTION__, mlme->cmd, reason);
 
-	switch (mlme->cmd) 
-	{
-		case IW_MLME_DEAUTH:
-				if(!rtw_set_802_11_disassociate(padapter))
-					ret = -1;
-				break;
 
-		case IW_MLME_DISASSOC:
-				if(!rtw_set_802_11_disassociate(padapter))
-					ret = -1;
+	switch (mlme->cmd) {
+	case IW_MLME_DEAUTH:
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
+		break;
 
-				break;
+	case IW_MLME_DISASSOC:
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
 
-		default:
-			return -EOPNOTSUPP;
-	}
+		break;
 
+	default:
+		return -EOPNOTSUPP;
+	}
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_do_disconnect(padapter);
+#endif
 	return ret;
 }
 
 static int rtw_wx_set_scan(struct net_device *dev, struct iw_request_info *a,
-			     union iwreq_data *wrqu, char *extra)
+			   union iwreq_data *wrqu, char *extra)
 {
 	u8 _status = _FALSE;
-	int ret = 0;	
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv= &padapter->mlmepriv;
-	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];
-	_irqL	irqL;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct sitesurvey_parm parm;
+
 #ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);	
-#endif //CONFIG_P2P
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_set_scan\n"));
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P */
 
-_func_enter_;
 
-	#ifdef DBG_IOCTL
-	DBG_871X("DBG_IOCTL %s:%d\n",__FUNCTION__, __LINE__);
-	#endif
-/*
-#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->iface_type > PRIMARY_IFACE)
-	{
-		ret = -1;
-		goto exit;
-	}
-#endif
-*/
-#ifdef CONFIG_MP_INCLUDED
-		if (padapter->registrypriv.mp_mode == 1)
-		{
-				DBG_871X(FUNC_ADPT_FMT ": MP mode block Scan request\n", FUNC_ADPT_ARG(padapter));	
-				ret = -1;
-				goto exit;
-		}
-#ifdef CONFIG_CONCURRENT_MODE
-		if (padapter->pbuddy_adapter) {
-				if (padapter->pbuddy_adapter->registrypriv.mp_mode == 1)
-				{
-					DBG_871X(FUNC_ADPT_FMT ": MP mode block Scan request\n", FUNC_ADPT_ARG(padapter->pbuddy_adapter));
-					ret = -1;
-					goto exit;
-				}
-		}
-#endif //CONFIG_CONCURRENT_MODE
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d\n", __FUNCTION__, __LINE__);
 #endif
 
-	rtw_ps_deny(padapter, PS_DENY_SCAN);
-	if(_FAIL == rtw_pwr_wakeup(padapter))
-	{
-		ret= -1;
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block Scan request\n");
+		ret = -EPERM;
 		goto exit;
 	}
-
-	if (rtw_is_drv_stopped(padapter)) {
-		DBG_871X("%s bDriverStopped=_TRUE\n", __func__);
-		ret= -1;
+#endif
+	if (rtw_is_scan_deny(padapter)) {
+		indicate_wx_scan_complete_event(padapter);
 		goto exit;
 	}
-	
-	if(!padapter->bup){
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
 		ret = -1;
-		goto exit;
+		goto cancel_ps_deny;
 	}
-	
-	if (!rtw_is_hw_init_completed(padapter)) {
+
+	if (!rtw_is_adapter_up(padapter)) {
 		ret = -1;
-		goto exit;
+		goto cancel_ps_deny;
 	}
 
 #ifndef CONFIG_DOSCAN_IN_BUSYTRAFFIC
-	// When Busy Traffic, driver do not site survey. So driver return success.
-	// wpa_supplicant will not issue SIOCSIWSCAN cmd again after scan timeout.
-	// modify by thomas 2011-02-22.
-	if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE
-#ifdef CONFIG_CONCURRENT_MODE
-	|| rtw_get_buddy_bBusyTraffic(padapter) == _TRUE
-#endif //CONFIG_CONCURRENT_MODE
-	)
-	{
+	/* When Busy Traffic, driver do not site survey. So driver return success. */
+	/* wpa_supplicant will not issue SIOCSIWSCAN cmd again after scan timeout. */
+	/* modify by thomas 2011-02-22. */
+	if (rtw_mi_busy_traffic_check(padapter, _FALSE)) {
 		indicate_wx_scan_complete_event(padapter);
-		goto exit;
+		goto cancel_ps_deny;
+	}
+#endif
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
+		RTW_INFO(FUNC_ADPT_FMT" blocking scan for under rson scanning process\n", FUNC_ADPT_ARG(padapter));
+		indicate_wx_scan_complete_event(padapter);
+		goto cancel_ps_deny;
 	}
 #endif
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) && check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+		RTW_INFO("AP mode process WPS\n");
+		indicate_wx_scan_complete_event(padapter);
+		goto cancel_ps_deny;
+	}
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY|_FW_UNDER_LINKING) == _TRUE)
-	{
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
 		indicate_wx_scan_complete_event(padapter);
-		goto exit;
-	} 
+		goto cancel_ps_deny;
+	}
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter,
-		_FW_UNDER_SURVEY|_FW_UNDER_LINKING|WIFI_UNDER_WPS) == _TRUE)
-	{
+	if (rtw_mi_buddy_check_fwstate(padapter,
+		       _FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
+
 		indicate_wx_scan_complete_event(padapter);
-		goto exit;
+		goto cancel_ps_deny;
 	}
 #endif
 
 #ifdef CONFIG_P2P
-	if ( pwdinfo->p2p_state != P2P_STATE_NONE )
-	{
-		rtw_p2p_set_pre_state( pwdinfo, rtw_p2p_state( pwdinfo ) );
+	if (pwdinfo->p2p_state != P2P_STATE_NONE) {
+		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
 		rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_FULL);
 		rtw_free_network_queue(padapter, _TRUE);
 	}
-#endif //CONFIG_P2P
-
-	_rtw_memset(ssid, 0, sizeof(NDIS_802_11_SSID)*RTW_SSID_SCAN_AMOUNT);
+#endif /* CONFIG_P2P */
 
 #if WIRELESS_EXT >= 17
-	if (wrqu->data.length == sizeof(struct iw_scan_req)) 
-	{
+	if (wrqu->data.length == sizeof(struct iw_scan_req)) {
 		struct iw_scan_req *req = (struct iw_scan_req *)extra;
-	
-		if (wrqu->data.flags & IW_SCAN_THIS_ESSID)
-		{
+
+		if (wrqu->data.flags & IW_SCAN_THIS_ESSID) {
 			int len = min((int)req->essid_len, IW_ESSID_MAX_SIZE);
 
-			_rtw_memcpy(ssid[0].Ssid, req->essid, len);
-			ssid[0].SsidLength = len;	
+			rtw_init_sitesurvey_parm(padapter, &parm);
+			_rtw_memcpy(&parm.ssid[0].Ssid, &req->essid, len);
+			parm.ssid[0].SsidLength = len;
+			parm.ssid_num = 1;
 
-			DBG_871X("IW_SCAN_THIS_ESSID, ssid=%s, len=%d\n", req->essid, req->essid_len);
-		
-			_enter_critical_bh(&pmlmepriv->lock, &irqL);				
-		
-			_status = rtw_sitesurvey_cmd(padapter, ssid, 1, NULL, 0);
-		
-			_exit_critical_bh(&pmlmepriv->lock, &irqL);
-			
-		}
-		else if (req->scan_type == IW_SCAN_TYPE_PASSIVE)
-		{
-			DBG_871X("rtw_wx_set_scan, req->scan_type == IW_SCAN_TYPE_PASSIVE\n");
-		}
-		
-	}
-	else
+			RTW_INFO("IW_SCAN_THIS_ESSID, ssid=%s, len=%d\n", req->essid, req->essid_len);
+
+			_status = rtw_set_802_11_bssid_list_scan(padapter, &parm);
+
+		} else if (req->scan_type == IW_SCAN_TYPE_PASSIVE)
+			RTW_INFO("rtw_wx_set_scan, req->scan_type == IW_SCAN_TYPE_PASSIVE\n");
+
+	} else
 #endif
 
-	if(	wrqu->data.length >= WEXT_CSCAN_HEADER_SIZE
-		&& _rtw_memcmp(extra, WEXT_CSCAN_HEADER, WEXT_CSCAN_HEADER_SIZE) == _TRUE
-	)
-	{
-		int len = wrqu->data.length -WEXT_CSCAN_HEADER_SIZE;
-		char *pos = extra+WEXT_CSCAN_HEADER_SIZE;
-		char section;
-		char sec_len;
-		int ssid_index = 0;
-
-		//DBG_871X("%s COMBO_SCAN header is recognized\n", __FUNCTION__);
-		
-		while(len >= 1) {
-			section = *(pos++); len-=1;
-
-			switch(section) {
+		if (wrqu->data.length >= WEXT_CSCAN_HEADER_SIZE
+		    && _rtw_memcmp(extra, WEXT_CSCAN_HEADER, WEXT_CSCAN_HEADER_SIZE) == _TRUE
+		   ) {
+			int len = wrqu->data.length - WEXT_CSCAN_HEADER_SIZE;
+			char *pos = extra + WEXT_CSCAN_HEADER_SIZE;
+			char section;
+			char sec_len;
+			int ssid_index = 0;
+
+			/* RTW_INFO("%s COMBO_SCAN header is recognized\n", __FUNCTION__); */
+			rtw_init_sitesurvey_parm(padapter, &parm);
+
+			while (len >= 1) {
+				section = *(pos++);
+				len -= 1;
+
+				switch (section) {
 				case WEXT_CSCAN_SSID_SECTION:
-					//DBG_871X("WEXT_CSCAN_SSID_SECTION\n");
-					if(len < 1) {
+					/* RTW_INFO("WEXT_CSCAN_SSID_SECTION\n"); */
+					if (len < 1) {
 						len = 0;
 						break;
 					}
-					
-					sec_len = *(pos++); len-=1;
-
-					if(sec_len>0 && sec_len<=len) {
-						ssid[ssid_index].SsidLength = sec_len;
-						_rtw_memcpy(ssid[ssid_index].Ssid, pos, ssid[ssid_index].SsidLength);
-						//DBG_871X("%s COMBO_SCAN with specific ssid:%s, %d\n", __FUNCTION__
-						//	, ssid[ssid_index].Ssid, ssid[ssid_index].SsidLength);
+
+					sec_len = *(pos++);
+					len -= 1;
+
+					if (sec_len > 0 && sec_len <= len) {
+
+						parm.ssid[ssid_index].SsidLength = sec_len;
+						_rtw_memcpy(&parm.ssid[ssid_index].Ssid, pos, sec_len);
+
+						/* RTW_INFO("%s COMBO_SCAN with specific parm.ssid:%s, %d\n", __FUNCTION__ */
+						/*	, parm.ssid[ssid_index].Ssid, parm.ssid[ssid_index].SsidLength); */
 						ssid_index++;
 					}
-					
-					pos+=sec_len; len-=sec_len;
+
+					pos += sec_len;
+					len -= sec_len;
 					break;
-					
-				
+
+
 				case WEXT_CSCAN_CHANNEL_SECTION:
-					//DBG_871X("WEXT_CSCAN_CHANNEL_SECTION\n");
-					pos+=1; len-=1;
+					/* RTW_INFO("WEXT_CSCAN_CHANNEL_SECTION\n"); */
+					pos += 1;
+					len -= 1;
 					break;
 				case WEXT_CSCAN_ACTV_DWELL_SECTION:
-					//DBG_871X("WEXT_CSCAN_ACTV_DWELL_SECTION\n");
-					pos+=2; len-=2;
+					/* RTW_INFO("WEXT_CSCAN_ACTV_DWELL_SECTION\n"); */
+					pos += 2;
+					len -= 2;
 					break;
 				case WEXT_CSCAN_PASV_DWELL_SECTION:
-					//DBG_871X("WEXT_CSCAN_PASV_DWELL_SECTION\n");
-					pos+=2; len-=2;					
+					/* RTW_INFO("WEXT_CSCAN_PASV_DWELL_SECTION\n"); */
+					pos += 2;
+					len -= 2;
 					break;
 				case WEXT_CSCAN_HOME_DWELL_SECTION:
-					//DBG_871X("WEXT_CSCAN_HOME_DWELL_SECTION\n");
-					pos+=2; len-=2;
+					/* RTW_INFO("WEXT_CSCAN_HOME_DWELL_SECTION\n"); */
+					pos += 2;
+					len -= 2;
 					break;
 				case WEXT_CSCAN_TYPE_SECTION:
-					//DBG_871X("WEXT_CSCAN_TYPE_SECTION\n");
-					pos+=1; len-=1;
+					/* RTW_INFO("WEXT_CSCAN_TYPE_SECTION\n"); */
+					pos += 1;
+					len -= 1;
 					break;
-				#if 0
+#if 0
 				case WEXT_CSCAN_NPROBE_SECTION:
-					DBG_871X("WEXT_CSCAN_NPROBE_SECTION\n");
+					RTW_INFO("WEXT_CSCAN_NPROBE_SECTION\n");
 					break;
-				#endif
-				
+#endif
+
 				default:
-					//DBG_871X("Unknown CSCAN section %c\n", section);
-					len = 0; // stop parsing
+					/* RTW_INFO("Unknown CSCAN section %c\n", section); */
+					len = 0; /* stop parsing */
+				}
+				/* RTW_INFO("len:%d\n", len); */
+
 			}
-			//DBG_871X("len:%d\n", len);
-			
-		}
-		
-		//jeff: it has still some scan paramater to parse, we only do this now...
-		_status = rtw_set_802_11_bssid_list_scan(padapter, ssid, RTW_SSID_SCAN_AMOUNT);
-		
-	} else
-	
-	{
-		_status = rtw_set_802_11_bssid_list_scan(padapter, NULL, 0);
-	}
+			parm.ssid_num = ssid_index;
 
-	if(_status == _FALSE)
-		ret = -1;
+			/* jeff: it has still some scan paramater to parse, we only do this now... */
+			_status = rtw_set_802_11_bssid_list_scan(padapter, &parm);
 
-exit:
+		} else
 
-	rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
+			_status = rtw_set_802_11_bssid_list_scan(padapter, NULL);
 
-	#ifdef DBG_IOCTL
-	DBG_871X("DBG_IOCTL %s:%d return %d\n",__FUNCTION__, __LINE__, ret);
-	#endif
+	if (_status == _FALSE)
+		ret = -1;
+
+cancel_ps_deny:
+	rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
 
-_func_exit_;
+exit:
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d return %d\n", __FUNCTION__, __LINE__, ret);
+#endif
 
-	return ret;	
+	return ret;
 }
 
 static int rtw_wx_get_scan(struct net_device *dev, struct iw_request_info *a,
-			     union iwreq_data *wrqu, char *extra)
+			   union iwreq_data *wrqu, char *extra)
 {
 	_irqL	irqL;
 	_list					*plist, *phead;
@@ -2875,77 +2148,57 @@ static int rtw_wx_get_scan(struct net_device *dev, struct iw_request_info *a,
 	char *ev = extra;
 	char *stop = ev + wrqu->data.length;
 	u32 ret = 0;
-	u32 cnt=0;
+	u32 cnt = 0;
 	u32 wait_for_surveydone;
 	sint wait_status;
-#ifdef CONFIG_CONCURRENT_MODE
-	//PADAPTER pbuddy_adapter = padapter->pbuddy_adapter;
-	//struct mlme_priv *pbuddy_mlmepriv = &(pbuddy_adapter->mlmepriv);	
-#endif
+
 #ifdef CONFIG_P2P
-	struct	wifidirect_info*	pwdinfo = &padapter->wdinfo;
-#endif //CONFIG_P2P
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_scan\n"));
-	RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_info_, (" Start of Query SIOCGIWSCAN .\n"));
+	struct	wifidirect_info	*pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
 
-	_func_enter_;
 
-	#ifdef DBG_IOCTL
-	DBG_871X("DBG_IOCTL %s:%d\n",__FUNCTION__, __LINE__);
-	#endif
-/*
-#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->iface_type > PRIMARY_IFACE)
-	{
-		ret = -EINVAL;
-		goto exit;
-	}
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d\n", __FUNCTION__, __LINE__);
 #endif
-*/	
+
 	if (adapter_to_pwrctl(padapter)->brfoffbyhw && rtw_is_drv_stopped(padapter)) {
 		ret = -EINVAL;
 		goto exit;
 	}
-  
+
 #ifdef CONFIG_P2P
-	if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		wait_for_surveydone = 200;
-	}
-	else
-	{
-		//	P2P is disabled
+	else {
+		/*	P2P is disabled */
 		wait_for_surveydone = 100;
 	}
 #else
 	{
 		wait_for_surveydone = 100;
 	}
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
-#if 1 // Wireless Extension use EAGAIN to try
+#if 1 /* Wireless Extension use EAGAIN to try */
 	wait_status = _FW_UNDER_SURVEY
 #ifndef CONFIG_ANDROID
-		| _FW_UNDER_LINKING
+		      | _FW_UNDER_LINKING
 #endif
-	;
+		      ;
 
 	while (check_fwstate(pmlmepriv, wait_status) == _TRUE)
-	{
 		return -EAGAIN;
-	}
 #else
 	wait_status = _FW_UNDER_SURVEY
-		#ifndef CONFIG_ANDROID
-		|_FW_UNDER_LINKING
-		#endif
-	;
+#ifndef CONFIG_ANDROID
+		      | _FW_UNDER_LINKING
+#endif
+		      ;
 
- 	while(check_fwstate(pmlmepriv, wait_status) == _TRUE)
-	{	
+	while (check_fwstate(pmlmepriv, wait_status) == _TRUE) {
 		rtw_msleep_os(30);
 		cnt++;
-		if(cnt > wait_for_surveydone )
+		if (cnt > wait_for_surveydone)
 			break;
 	}
 #endif
@@ -2953,57 +2206,53 @@ static int rtw_wx_get_scan(struct net_device *dev, struct iw_request_info *a,
 
 	phead = get_list_head(queue);
 	plist = get_next(phead);
-       
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
-		if((stop - ev) < SCAN_ITEM_SIZE) {
+		if ((stop - ev) < SCAN_ITEM_SIZE) {
 			ret = -E2BIG;
 			break;
 		}
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
 
-		//report network only if the current channel set contains the channel to which this network belongs
-		if(rtw_ch_set_search_ch(padapter->mlmeextpriv.channel_set, pnetwork->network.Configuration.DSConfig) >= 0
-			&& rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
-			&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
-		)
-		{
-			ev=translate_scan(padapter, a, pnetwork, ev, stop);
-		}
+		/* report network only if the current channel set contains the channel to which this network belongs */
+		if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
+		    && rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
+		    && _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
+		   )
+			ev = translate_scan(padapter, a, pnetwork, ev, stop);
 
 		plist = get_next(plist);
-	
-	}        
+
+	}
 
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-       wrqu->data.length = ev-extra;
+	wrqu->data.length = ev - extra;
 	wrqu->data.flags = 0;
-	
-exit:		
-	
-	_func_exit_;	
-	
-	#ifdef DBG_IOCTL
-	DBG_871X("DBG_IOCTL %s:%d return %d\n",__FUNCTION__, __LINE__, ret);
-	#endif
-	
+
+exit:
+
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d return %d\n", __FUNCTION__, __LINE__, ret);
+#endif
+
 	return ret ;
-	
+
 }
 
-//set ssid flow
-//s1. rtw_set_802_11_infrastructure_mode()
-//s2. set_802_11_authenticaion_mode()
-//s3. set_802_11_encryption_mode()
-//s4. rtw_set_802_11_ssid()
-static int rtw_wx_set_essid(struct net_device *dev, 
-			      struct iw_request_info *a,
-			      union iwreq_data *wrqu, char *extra)
+/* set ssid flow
+ * s1. rtw_set_802_11_infrastructure_mode()
+ * s2. set_802_11_authenticaion_mode()
+ * s3. set_802_11_encryption_mode()
+ * s4. rtw_set_802_11_ssid() */
+static int rtw_wx_set_essid(struct net_device *dev,
+			    struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *extra)
 {
 	_irqL irqL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
@@ -3012,225 +2261,182 @@ static int rtw_wx_set_essid(struct net_device *dev,
 	_list *phead;
 	s8 status = _TRUE;
 	struct wlan_network *pnetwork = NULL;
-	NDIS_802_11_AUTHENTICATION_MODE authmode;	
-	NDIS_802_11_SSID ndis_ssid;	
+	NDIS_802_11_AUTHENTICATION_MODE authmode;
+	NDIS_802_11_SSID ndis_ssid;
 	u8 *dst_ssid, *src_ssid;
 
 	uint ret = 0, len;
 
-	_func_enter_;
-	
-	#ifdef DBG_IOCTL
-	DBG_871X("DBG_IOCTL %s:%d\n",__FUNCTION__, __LINE__);
-	#endif
-	#ifdef CONFIG_WEXT_DONT_JOIN_BYSSID
-	DBG_871X("%s: CONFIG_WEXT_DONT_JOIN_BYSSID be defined!! only allow bssid joining\n", __func__);
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d\n", __FUNCTION__, __LINE__);
+#endif
+#ifdef CONFIG_WEXT_DONT_JOIN_BYSSID
+	RTW_INFO("%s: CONFIG_WEXT_DONT_JOIN_BYSSID be defined!! only allow bssid joining\n", __func__);
 	return -EPERM;
-	#endif
-/*
-#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->iface_type > PRIMARY_IFACE)
-	{
-		ret = -EINVAL;
-		goto exit;
-	}
 #endif
-*/
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, _FW_UNDER_SURVEY|_FW_UNDER_LINKING) == _TRUE)
-	{		
-		DBG_871X("set ssid, but buddy_intf is under scanning or linking\n");
-		
-		ret = -EINVAL;
-		
+#if WIRELESS_EXT <= 20
+	if ((wrqu->essid.length - 1) > IW_ESSID_MAX_SIZE) {
+#else
+	if (wrqu->essid.length > IW_ESSID_MAX_SIZE) {
+#endif
+		ret = -E2BIG;
 		goto exit;
 	}
-#endif
 
-	RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_info_,
-		 ("+rtw_wx_set_essid: fw_state=0x%08x\n", get_fwstate(pmlmepriv)));
+
 
 	rtw_ps_deny(padapter, PS_DENY_JOIN);
-	if(_FAIL == rtw_pwr_wakeup(padapter))
-	{		
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
 		ret = -1;
-		goto exit;
+		goto cancel_ps_deny;
 	}
 
-	if(!padapter->bup){
+	if (!padapter->bup) {
 		ret = -1;
-		goto exit;
+		goto cancel_ps_deny;
 	}
 
-#if WIRELESS_EXT <= 20
-	if ((wrqu->essid.length-1) > IW_ESSID_MAX_SIZE){
-#else
-	if (wrqu->essid.length > IW_ESSID_MAX_SIZE){
-#endif
-		ret= -E2BIG;
-		goto exit;
-	}
-	
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
 		ret = -1;
-		goto exit;
-	}		
-	
+		goto cancel_ps_deny;
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_SURVEY | _FW_UNDER_LINKING)) {
+		RTW_INFO("set ssid, but buddy_intf is under scanning or linking\n");
+		ret = -EINVAL;
+		goto cancel_ps_deny;
+	}
+#endif
 	authmode = padapter->securitypriv.ndisauthtype;
-	DBG_871X("=>%s\n",__FUNCTION__);
-	if (wrqu->essid.flags && wrqu->essid.length)
-	{
-		// Commented by Albert 20100519
-		// We got the codes in "set_info" function of iwconfig source code.
-		//	=========================================
-		//	wrq.u.essid.length = strlen(essid) + 1;
-	  	//	if(we_kernel_version > 20)
-		//		wrq.u.essid.length--;
-		//	=========================================
-		//	That means, if the WIRELESS_EXT less than or equal to 20, the correct ssid len should subtract 1.
+	RTW_INFO("=>%s\n", __FUNCTION__);
+	if (wrqu->essid.flags && wrqu->essid.length) {
+		/* Commented by Albert 20100519 */
+		/* We got the codes in "set_info" function of iwconfig source code. */
+		/*	========================================= */
+		/*	wrq.u.essid.length = strlen(essid) + 1; */
+		/*	if(we_kernel_version > 20) */
+		/*		wrq.u.essid.length--; */
+		/*	========================================= */
+		/*	That means, if the WIRELESS_EXT less than or equal to 20, the correct ssid len should subtract 1. */
 #if WIRELESS_EXT <= 20
-		len = ((wrqu->essid.length-1) < IW_ESSID_MAX_SIZE) ? (wrqu->essid.length-1) : IW_ESSID_MAX_SIZE;
+		len = ((wrqu->essid.length - 1) < IW_ESSID_MAX_SIZE) ? (wrqu->essid.length - 1) : IW_ESSID_MAX_SIZE;
 #else
 		len = (wrqu->essid.length < IW_ESSID_MAX_SIZE) ? wrqu->essid.length : IW_ESSID_MAX_SIZE;
 #endif
 
-		if( wrqu->essid.length != 33 )
-			DBG_871X("ssid=%s, len=%d\n", extra, wrqu->essid.length);
+		if (wrqu->essid.length != 33)
+			RTW_INFO("ssid=%s, len=%d\n", extra, wrqu->essid.length);
 
 		_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));
 		ndis_ssid.SsidLength = len;
-		_rtw_memcpy(ndis_ssid.Ssid, extra, len);		
+		_rtw_memcpy(ndis_ssid.Ssid, extra, len);
 		src_ssid = ndis_ssid.Ssid;
-		
-		RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_info_, ("rtw_wx_set_essid: ssid=[%s]\n", src_ssid));
+
 		_enter_critical_bh(&queue->lock, &irqL);
-	       phead = get_list_head(queue);
-              pmlmepriv->pscanned = get_next(phead);
+		phead = get_list_head(queue);
+		pmlmepriv->pscanned = get_next(phead);
 
-		while (1)
-		{			
-			if (rtw_end_of_queue_search(phead, pmlmepriv->pscanned) == _TRUE)
-			{
-#if 0			
-				if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)
-				{
-	            			rtw_set_802_11_ssid(padapter, &ndis_ssid);
+		while (1) {
+			if (rtw_end_of_queue_search(phead, pmlmepriv->pscanned) == _TRUE) {
+#if 0
+				if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+					rtw_set_802_11_ssid(padapter, &ndis_ssid);
 
-		    			goto exit;                    
-				}
-				else
-				{
-					RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_info_,("rtw_wx_set_ssid(): scanned_queue is empty\n"));
+					goto cancel_ps_deny;
+				} else {
 					ret = -EINVAL;
-					goto exit;
+					goto cancel_ps_deny;
 				}
-#endif			
-			        RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_warning_,
-					 ("rtw_wx_set_essid: scan_q is empty, set ssid to check if scanning again!\n"));
+#endif
 
 				break;
 			}
-	
+
 			pnetwork = LIST_CONTAINOR(pmlmepriv->pscanned, struct wlan_network, list);
 
 			pmlmepriv->pscanned = get_next(pmlmepriv->pscanned);
 
 			dst_ssid = pnetwork->network.Ssid.Ssid;
 
-			RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_info_,
-				 ("rtw_wx_set_essid: dst_ssid=%s\n",
-				  pnetwork->network.Ssid.Ssid));
 
 			if ((_rtw_memcmp(dst_ssid, src_ssid, ndis_ssid.SsidLength) == _TRUE) &&
-				(pnetwork->network.Ssid.SsidLength==ndis_ssid.SsidLength))
-			{
-				RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_info_,
-					 ("rtw_wx_set_essid: find match, set infra mode\n"));
-				
-				if(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)
-				{
-					if(pnetwork->network.InfrastructureMode != pmlmepriv->cur_network.network.InfrastructureMode)
+			    (pnetwork->network.Ssid.SsidLength == ndis_ssid.SsidLength)) {
+
+				if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
+					if (pnetwork->network.InfrastructureMode != pmlmepriv->cur_network.network.InfrastructureMode)
 						continue;
-				}	
-					
-				if (rtw_set_802_11_infrastructure_mode(padapter, pnetwork->network.InfrastructureMode) == _FALSE)
-				{
+				}
+
+				if (rtw_set_802_11_infrastructure_mode(padapter, pnetwork->network.InfrastructureMode) == _FALSE) {
 					ret = -1;
 					_exit_critical_bh(&queue->lock, &irqL);
-					goto exit;
+					goto cancel_ps_deny;
 				}
 
-				break;			
+				break;
 			}
 		}
 		_exit_critical_bh(&queue->lock, &irqL);
-		RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_info_,
-			 ("set ssid: set_802_11_auth. mode=%d\n", authmode));
 		rtw_set_802_11_authentication_mode(padapter, authmode);
-		//set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus);
+		/* set_802_11_encryption_mode(padapter, padapter->securitypriv.ndisencryptstatus); */
 		if (rtw_set_802_11_ssid(padapter, &ndis_ssid) == _FALSE) {
 			ret = -1;
-			goto exit;
-		}	
-	}			
-	
-exit:
+			goto cancel_ps_deny;
+		}
+	}
 
+cancel_ps_deny:
 	rtw_ps_deny_cancel(padapter, PS_DENY_JOIN);
 
-	DBG_871X("<=%s, ret %d\n",__FUNCTION__, ret);
-	
-	#ifdef DBG_IOCTL
-	DBG_871X("DBG_IOCTL %s:%d return %d\n",__FUNCTION__, __LINE__, ret);
-	#endif
-	
-	_func_exit_;
-	
-	return ret;	
+exit:
+	RTW_INFO("<=%s, ret %d\n", __FUNCTION__, ret);
+
+#ifdef DBG_IOCTL
+	RTW_INFO("DBG_IOCTL %s:%d return %d\n", __FUNCTION__, __LINE__, ret);
+#endif
+
+
+	return ret;
 }
 
-static int rtw_wx_get_essid(struct net_device *dev, 
-			      struct iw_request_info *a,
-			      union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_essid(struct net_device *dev,
+			    struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *extra)
 {
-	u32 len,ret = 0;
+	u32 len, ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	WLAN_BSSID_EX  *pcur_bss = &pmlmepriv->cur_network.network;
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,("rtw_wx_get_essid\n"));
 
-	_func_enter_;
 
-	if ( (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
-	      (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE))
-	{
+	if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
 		len = pcur_bss->Ssid.SsidLength;
 
 		wrqu->essid.length = len;
-			
+
 		_rtw_memcpy(extra, pcur_bss->Ssid.Ssid, len);
 
 		wrqu->essid.flags = 1;
-	}
-	else
-	{
+	} else {
 		ret = -1;
 		goto exit;
 	}
 
 exit:
 
-	_func_exit_;
-	
+
 	return ret;
-	
+
 }
 
-static int rtw_wx_set_rate(struct net_device *dev, 
-			      struct iw_request_info *a,
-			      union iwreq_data *wrqu, char *extra)
+static int rtw_wx_set_rate(struct net_device *dev,
+			   struct iw_request_info *a,
+			   union iwreq_data *wrqu, char *extra)
 {
 	int	i, ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
@@ -3238,263 +2444,243 @@ static int rtw_wx_set_rate(struct net_device *dev,
 	u32	target_rate = wrqu->bitrate.value;
 	u32	fixed = wrqu->bitrate.fixed;
 	u32	ratevalue = 0;
-	 u8 mpdatarate[NumRates]={11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 0xff};
+	u8 mpdatarate[NumRates] = {11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 0xff};
 
-_func_enter_;
 
-	RT_TRACE(_module_rtl871x_mlme_c_,_drv_info_,(" rtw_wx_set_rate \n"));
-	RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_info_,("target_rate = %d, fixed = %d\n",target_rate,fixed));
-	
-	if(target_rate == -1){
+
+	if (target_rate == -1) {
 		ratevalue = 11;
 		goto set_rate;
 	}
-	target_rate = target_rate/100000;
+	target_rate = target_rate / 100000;
 
-	switch(target_rate){
-		case 10:
-			ratevalue = 0;
-			break;
-		case 20:
-			ratevalue = 1;
-			break;
-		case 55:
-			ratevalue = 2;
-			break;
-		case 60:
-			ratevalue = 3;
-			break;
-		case 90:
-			ratevalue = 4;
-			break;
-		case 110:
-			ratevalue = 5;
-			break;
-		case 120:
-			ratevalue = 6;
-			break;
-		case 180:
-			ratevalue = 7;
-			break;
-		case 240:
-			ratevalue = 8;
-			break;
-		case 360:
-			ratevalue = 9;
-			break;
-		case 480:
-			ratevalue = 10;
-			break;
-		case 540:
-			ratevalue = 11;
-			break;
-		default:
-			ratevalue = 11;
-			break;
+	switch (target_rate) {
+	case 10:
+		ratevalue = 0;
+		break;
+	case 20:
+		ratevalue = 1;
+		break;
+	case 55:
+		ratevalue = 2;
+		break;
+	case 60:
+		ratevalue = 3;
+		break;
+	case 90:
+		ratevalue = 4;
+		break;
+	case 110:
+		ratevalue = 5;
+		break;
+	case 120:
+		ratevalue = 6;
+		break;
+	case 180:
+		ratevalue = 7;
+		break;
+	case 240:
+		ratevalue = 8;
+		break;
+	case 360:
+		ratevalue = 9;
+		break;
+	case 480:
+		ratevalue = 10;
+		break;
+	case 540:
+		ratevalue = 11;
+		break;
+	default:
+		ratevalue = 11;
+		break;
 	}
 
 set_rate:
 
-	for(i=0; i<NumRates; i++)
-	{
-		if(ratevalue==mpdatarate[i])
-		{
+	for (i = 0; i < NumRates; i++) {
+		if (ratevalue == mpdatarate[i]) {
 			datarates[i] = mpdatarate[i];
-			if(fixed == 0)
+			if (fixed == 0)
 				break;
-		}
-		else{
+		} else
 			datarates[i] = 0xff;
-		}
 
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_info_,("datarate_inx=%d\n",datarates[i]));
 	}
 
-	if( rtw_setdatarate_cmd(padapter, datarates) !=_SUCCESS){
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("rtw_wx_set_rate Fail!!!\n"));
+	if (rtw_setdatarate_cmd(padapter, datarates) != _SUCCESS) {
 		ret = -1;
 	}
 
-_func_exit_;
 
 	return ret;
 }
 
-static int rtw_wx_get_rate(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
-{	
+static int rtw_wx_get_rate(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
 	u16 max_rate = 0;
 
 	max_rate = rtw_get_cur_max_rate((_adapter *)rtw_netdev_priv(dev));
 
-	if(max_rate == 0)
+	if (max_rate == 0)
 		return -EPERM;
-	
+
 	wrqu->bitrate.fixed = 0;	/* no auto select */
 	wrqu->bitrate.value = max_rate * 100000;
 
 	return 0;
 }
 
-static int rtw_wx_set_rts(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_set_rts(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	_func_enter_;
-	
+
 	if (wrqu->rts.disabled)
 		padapter->registrypriv.rts_thresh = 2347;
 	else {
 		if (wrqu->rts.value < 0 ||
 		    wrqu->rts.value > 2347)
 			return -EINVAL;
-		
+
 		padapter->registrypriv.rts_thresh = wrqu->rts.value;
 	}
 
-	DBG_871X("%s, rts_thresh=%d\n", __func__, padapter->registrypriv.rts_thresh);
-	
-	_func_exit_;
-	
+	RTW_INFO("%s, rts_thresh=%d\n", __func__, padapter->registrypriv.rts_thresh);
+
+
 	return 0;
 
 }
 
-static int rtw_wx_get_rts(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_rts(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
-	_func_enter_;
 
-	DBG_871X("%s, rts_thresh=%d\n", __func__, padapter->registrypriv.rts_thresh);	
-	
+
+	RTW_INFO("%s, rts_thresh=%d\n", __func__, padapter->registrypriv.rts_thresh);
+
 	wrqu->rts.value = padapter->registrypriv.rts_thresh;
 	wrqu->rts.fixed = 0;	/* no auto select */
-	//wrqu->rts.disabled = (wrqu->rts.value == DEFAULT_RTS_THRESHOLD);
-	
-	_func_exit_;
-	
+	/* wrqu->rts.disabled = (wrqu->rts.value == DEFAULT_RTS_THRESHOLD); */
+
+
 	return 0;
 }
 
-static int rtw_wx_set_frag(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_set_frag(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	_func_enter_;
-	
+
 	if (wrqu->frag.disabled)
 		padapter->xmitpriv.frag_len = MAX_FRAG_THRESHOLD;
 	else {
 		if (wrqu->frag.value < MIN_FRAG_THRESHOLD ||
 		    wrqu->frag.value > MAX_FRAG_THRESHOLD)
 			return -EINVAL;
-		
+
 		padapter->xmitpriv.frag_len = wrqu->frag.value & ~0x1;
 	}
 
-	DBG_871X("%s, frag_len=%d\n", __func__, padapter->xmitpriv.frag_len);
-	
-	_func_exit_;
-	
+	RTW_INFO("%s, frag_len=%d\n", __func__, padapter->xmitpriv.frag_len);
+
+
 	return 0;
-	
+
 }
 
-static int rtw_wx_get_frag(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_frag(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
-	_func_enter_;
 
-	DBG_871X("%s, frag_len=%d\n", __func__, padapter->xmitpriv.frag_len);
-	
+
+	RTW_INFO("%s, frag_len=%d\n", __func__, padapter->xmitpriv.frag_len);
+
 	wrqu->frag.value = padapter->xmitpriv.frag_len;
 	wrqu->frag.fixed = 0;	/* no auto select */
-	//wrqu->frag.disabled = (wrqu->frag.value == DEFAULT_FRAG_THRESHOLD);
-	
-	_func_exit_;
-	
+	/* wrqu->frag.disabled = (wrqu->frag.value == DEFAULT_FRAG_THRESHOLD); */
+
+
 	return 0;
 }
 
-static int rtw_wx_get_retry(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_get_retry(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
 {
-	//_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev); */
+
 
-	
 	wrqu->retry.value = 7;
 	wrqu->retry.fixed = 0;	/* no auto select */
 	wrqu->retry.disabled = 1;
-	
+
 	return 0;
 
-}	
+}
 
 #if 0
-#define IW_ENCODE_INDEX		0x00FF	/* Token index (if needed) */
-#define IW_ENCODE_FLAGS		0xFF00	/* Flags defined below */
-#define IW_ENCODE_MODE		0xF000	/* Modes defined below */
-#define IW_ENCODE_DISABLED	0x8000	/* Encoding disabled */
-#define IW_ENCODE_ENABLED	0x0000	/* Encoding enabled */
-#define IW_ENCODE_RESTRICTED	0x4000	/* Refuse non-encoded packets */
-#define IW_ENCODE_OPEN		0x2000	/* Accept non-encoded packets */
-#define IW_ENCODE_NOKEY		0x0800  /* Key is write only, so not present */
-#define IW_ENCODE_TEMP		0x0400  /* Temporary key */
-/*
-iwconfig wlan0 key on -> flags = 0x6001 -> maybe it means auto
-iwconfig wlan0 key off -> flags = 0x8800
-iwconfig wlan0 key open -> flags = 0x2800
-iwconfig wlan0 key open 1234567890 -> flags = 0x2000
-iwconfig wlan0 key restricted -> flags = 0x4800
-iwconfig wlan0 key open [3] 1234567890 -> flags = 0x2003
-iwconfig wlan0 key restricted [2] 1234567890 -> flags = 0x4002
-iwconfig wlan0 key open [3] -> flags = 0x2803
-iwconfig wlan0 key restricted [2] -> flags = 0x4802
-*/
+	#define IW_ENCODE_INDEX		0x00FF	/* Token index (if needed) */
+	#define IW_ENCODE_FLAGS		0xFF00	/* Flags defined below */
+	#define IW_ENCODE_MODE		0xF000	/* Modes defined below */
+	#define IW_ENCODE_DISABLED	0x8000	/* Encoding disabled */
+	#define IW_ENCODE_ENABLED	0x0000	/* Encoding enabled */
+	#define IW_ENCODE_RESTRICTED	0x4000	/* Refuse non-encoded packets */
+	#define IW_ENCODE_OPEN		0x2000	/* Accept non-encoded packets */
+	#define IW_ENCODE_NOKEY		0x0800  /* Key is write only, so not present */
+	#define IW_ENCODE_TEMP		0x0400  /* Temporary key */
+	/*
+	iwconfig wlan0 key on->flags = 0x6001->maybe it means auto
+	iwconfig wlan0 key off->flags = 0x8800
+	iwconfig wlan0 key open->flags = 0x2800
+	iwconfig wlan0 key open 1234567890->flags = 0x2000
+	iwconfig wlan0 key restricted->flags = 0x4800
+	iwconfig wlan0 key open [3] 1234567890->flags = 0x2003
+	iwconfig wlan0 key restricted [2] 1234567890->flags = 0x4002
+	iwconfig wlan0 key open [3] -> flags = 0x2803
+	iwconfig wlan0 key restricted [2] -> flags = 0x4802
+	*/
 #endif
 
-static int rtw_wx_set_enc(struct net_device *dev, 
-			    struct iw_request_info *info, 
-			    union iwreq_data *wrqu, char *keybuf)
-{	
+static int rtw_wx_set_enc(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *keybuf)
+{
 	u32 key, ret = 0;
 	u32 keyindex_provided;
-	NDIS_802_11_WEP	 wep;	
+	NDIS_802_11_WEP	 wep;
 	NDIS_802_11_AUTHENTICATION_MODE authmode;
 
 	struct iw_point *erq = &(wrqu->encoding);
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	DBG_871X("+rtw_wx_set_enc, flags=0x%x\n", erq->flags);
+	RTW_INFO("+rtw_wx_set_enc, flags=0x%x\n", erq->flags);
 
 	_rtw_memset(&wep, 0, sizeof(NDIS_802_11_WEP));
-	
+
 	key = erq->flags & IW_ENCODE_INDEX;
-	
-	_func_enter_;	
 
-	if (erq->flags & IW_ENCODE_DISABLED)
-	{
-		DBG_871X("EncryptionDisabled\n");
+
+	if (erq->flags & IW_ENCODE_DISABLED) {
+		RTW_INFO("EncryptionDisabled\n");
 		padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
-		padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;
-		padapter->securitypriv.dot118021XGrpPrivacy=_NO_PRIVACY_;
-		padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_Open; //open system
-  		authmode = Ndis802_11AuthModeOpen;
-		padapter->securitypriv.ndisauthtype=authmode;
-     		
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+		authmode = Ndis802_11AuthModeOpen;
+		padapter->securitypriv.ndisauthtype = authmode;
+
 		goto exit;
 	}
 
@@ -3503,135 +2689,119 @@ static int rtw_wx_set_enc(struct net_device *dev,
 			return -EINVAL;
 		key--;
 		keyindex_provided = 1;
-	} 
-	else
-	{
+	} else {
 		keyindex_provided = 0;
 		key = padapter->securitypriv.dot11PrivacyKeyIndex;
-		DBG_871X("rtw_wx_set_enc, key=%d\n", key);
+		RTW_INFO("rtw_wx_set_enc, key=%d\n", key);
 	}
-	
-	//set authentication mode	
-	if(erq->flags & IW_ENCODE_OPEN)
-	{
-		DBG_871X("rtw_wx_set_enc():IW_ENCODE_OPEN\n");
-		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;//Ndis802_11EncryptionDisabled;
+
+	/* set authentication mode	 */
+	if (erq->flags & IW_ENCODE_OPEN) {
+		RTW_INFO("rtw_wx_set_enc():IW_ENCODE_OPEN\n");
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;/* Ndis802_11EncryptionDisabled; */
 
 #ifdef CONFIG_PLATFORM_MT53XX
 		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
 #else
-		padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_Open;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
 #endif
 
-		padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;
-		padapter->securitypriv.dot118021XGrpPrivacy=_NO_PRIVACY_;
-  		authmode = Ndis802_11AuthModeOpen;
-		padapter->securitypriv.ndisauthtype=authmode;
-	}	
-	else if(erq->flags & IW_ENCODE_RESTRICTED)
-	{		
-		DBG_871X("rtw_wx_set_enc():IW_ENCODE_RESTRICTED\n");
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+		authmode = Ndis802_11AuthModeOpen;
+		padapter->securitypriv.ndisauthtype = authmode;
+	} else if (erq->flags & IW_ENCODE_RESTRICTED) {
+		RTW_INFO("rtw_wx_set_enc():IW_ENCODE_RESTRICTED\n");
 		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;
 
 #ifdef CONFIG_PLATFORM_MT53XX
 		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
 #else
-		padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_Shared;
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Shared;
 #endif
 
-		padapter->securitypriv.dot11PrivacyAlgrthm=_WEP40_;
-		padapter->securitypriv.dot118021XGrpPrivacy=_WEP40_;			
+		padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _WEP40_;
 		authmode = Ndis802_11AuthModeShared;
-		padapter->securitypriv.ndisauthtype=authmode;
-	}
-	else
-	{
-		DBG_871X("rtw_wx_set_enc():erq->flags=0x%x\n", erq->flags);
+		padapter->securitypriv.ndisauthtype = authmode;
+	} else {
+		RTW_INFO("rtw_wx_set_enc():erq->flags=0x%x\n", erq->flags);
 
-		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;//Ndis802_11EncryptionDisabled;
-		padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_Open; //open system
-		padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;
-		padapter->securitypriv.dot118021XGrpPrivacy=_NO_PRIVACY_;
-  		authmode = Ndis802_11AuthModeOpen;
-		padapter->securitypriv.ndisauthtype=authmode;
+		padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption1Enabled;/* Ndis802_11EncryptionDisabled; */
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+		padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+		padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+		authmode = Ndis802_11AuthModeOpen;
+		padapter->securitypriv.ndisauthtype = authmode;
 	}
-	
+
 	wep.KeyIndex = key;
-	if (erq->length > 0)
-	{
+	if (erq->length > 0) {
 		wep.KeyLength = erq->length <= 5 ? 5 : 13;
 
 		wep.Length = wep.KeyLength + FIELD_OFFSET(NDIS_802_11_WEP, KeyMaterial);
-	}
-	else
-	{
+	} else {
 		wep.KeyLength = 0 ;
-		
-		if(keyindex_provided == 1)// set key_id only, no given KeyMaterial(erq->length==0).
-		{
+
+		if (keyindex_provided == 1) { /* set key_id only, no given KeyMaterial(erq->length==0). */
 			padapter->securitypriv.dot11PrivacyKeyIndex = key;
 
-			DBG_871X("(keyindex_provided == 1), keyid=%d, key_len=%d\n", key, padapter->securitypriv.dot11DefKeylen[key]);
+			RTW_INFO("(keyindex_provided == 1), keyid=%d, key_len=%d\n", key, padapter->securitypriv.dot11DefKeylen[key]);
 
-			switch(padapter->securitypriv.dot11DefKeylen[key])
-			{
-				case 5:
-					padapter->securitypriv.dot11PrivacyAlgrthm=_WEP40_;					
-					break;
-				case 13:
-					padapter->securitypriv.dot11PrivacyAlgrthm=_WEP104_;					
-					break;
-				default:
-					padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;					
-					break;
+			switch (padapter->securitypriv.dot11DefKeylen[key]) {
+			case 5:
+				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
+				break;
+			case 13:
+				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
+				break;
+			default:
+				padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+				break;
 			}
-				
+
 			goto exit;
-			
+
 		}
-		
+
 	}
 
 	wep.KeyIndex |= 0x80000000;
 
 	_rtw_memcpy(wep.KeyMaterial, keybuf, wep.KeyLength);
-	
+
 	if (rtw_set_802_11_add_wep(padapter, &wep) == _FALSE) {
-		if(rf_on == pwrpriv->rf_pwrstate )
+		if (rf_on == pwrpriv->rf_pwrstate)
 			ret = -EOPNOTSUPP;
 		goto exit;
-	}	
+	}
 
 exit:
-	
-	_func_exit_;
-	
+
+
 	return ret;
-	
+
 }
 
-static int rtw_wx_get_enc(struct net_device *dev, 
-			    struct iw_request_info *info, 
-			    union iwreq_data *wrqu, char *keybuf)
+static int rtw_wx_get_enc(struct net_device *dev,
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *keybuf)
 {
-	uint key, ret =0;
+	uint key, ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *erq = &(wrqu->encoding);
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 
-	_func_enter_;
-	
-	if(check_fwstate(pmlmepriv, _FW_LINKED) != _TRUE)
-	{
-		 if(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) != _TRUE)
-		 {
-		erq->length = 0;
-		erq->flags |= IW_ENCODE_DISABLED;
-		return 0;
-	}	
-	}	
 
-	
+	if (check_fwstate(pmlmepriv, _FW_LINKED) != _TRUE) {
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) != _TRUE) {
+			erq->length = 0;
+			erq->flags |= IW_ENCODE_DISABLED;
+			return 0;
+		}
+	}
+
+
 	key = erq->flags & IW_ENCODE_INDEX;
 
 	if (key) {
@@ -3639,123 +2809,111 @@ static int rtw_wx_get_enc(struct net_device *dev,
 			return -EINVAL;
 		key--;
 	} else
-	{
 		key = padapter->securitypriv.dot11PrivacyKeyIndex;
-	}	
 
 	erq->flags = key + 1;
 
-	//if(padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeOpen)
-	//{
-	//      erq->flags |= IW_ENCODE_OPEN;
-	//}	  
-	
-	switch(padapter->securitypriv.ndisencryptstatus)
-	{
-		case Ndis802_11EncryptionNotSupported:
-		case Ndis802_11EncryptionDisabled:
+	/* if(padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeOpen) */
+	/* { */
+	/* erq->flags |= IW_ENCODE_OPEN; */
+	/* }	  */
+
+	switch (padapter->securitypriv.ndisencryptstatus) {
+	case Ndis802_11EncryptionNotSupported:
+	case Ndis802_11EncryptionDisabled:
 
 		erq->length = 0;
 		erq->flags |= IW_ENCODE_DISABLED;
-	
+
 		break;
-		
-		case Ndis802_11Encryption1Enabled:					
-		
-		erq->length = padapter->securitypriv.dot11DefKeylen[key];		
 
-		if(erq->length)
-		{
+	case Ndis802_11Encryption1Enabled:
+
+		erq->length = padapter->securitypriv.dot11DefKeylen[key];
+
+		if (erq->length) {
 			_rtw_memcpy(keybuf, padapter->securitypriv.dot11DefKey[key].skey, padapter->securitypriv.dot11DefKeylen[key]);
-		
-		erq->flags |= IW_ENCODE_ENABLED;
 
-			if(padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeOpen)
-			{
-	     			erq->flags |= IW_ENCODE_OPEN;
-			}
-			else if(padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeShared)
-			{
-		erq->flags |= IW_ENCODE_RESTRICTED;
-			}	
-		}	
-		else
-		{
+			erq->flags |= IW_ENCODE_ENABLED;
+
+			if (padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeOpen)
+				erq->flags |= IW_ENCODE_OPEN;
+			else if (padapter->securitypriv.ndisauthtype == Ndis802_11AuthModeShared)
+				erq->flags |= IW_ENCODE_RESTRICTED;
+		} else {
 			erq->length = 0;
 			erq->flags |= IW_ENCODE_DISABLED;
 		}
 
 		break;
 
-		case Ndis802_11Encryption2Enabled:
-		case Ndis802_11Encryption3Enabled:
+	case Ndis802_11Encryption2Enabled:
+	case Ndis802_11Encryption3Enabled:
 
 		erq->length = 16;
 		erq->flags |= (IW_ENCODE_ENABLED | IW_ENCODE_OPEN | IW_ENCODE_NOKEY);
 
 		break;
-	
-		default:
+
+	default:
 		erq->length = 0;
 		erq->flags |= IW_ENCODE_DISABLED;
 
 		break;
-		
+
 	}
-	
-	_func_exit_;
-	
+
+
 	return ret;
-	
-}				     
 
-static int rtw_wx_get_power(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+}
+
+static int rtw_wx_get_power(struct net_device *dev,
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
 {
-	//_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev); */
+
 	wrqu->power.value = 0;
 	wrqu->power.fixed = 0;	/* no auto select */
 	wrqu->power.disabled = 1;
-	
+
 	return 0;
 
 }
 
-static int rtw_wx_set_gen_ie(struct net_device *dev, 
-			     struct iw_request_info *info, 
+static int rtw_wx_set_gen_ie(struct net_device *dev,
+			     struct iw_request_info *info,
 			     union iwreq_data *wrqu, char *extra)
 {
 	int ret;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
-       ret = rtw_set_wpa_ie(padapter, extra, wrqu->data.length);
-	   
+
+	ret = rtw_set_wpa_ie(padapter, extra, wrqu->data.length);
+
 	return ret;
-}	
+}
 
-static int rtw_wx_set_auth(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_set_auth(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_param *param = (struct iw_param*)&(wrqu->param);
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
+	struct iw_param *param = (struct iw_param *)&(wrqu->param);
+	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);
 	u32 value = param->value;
 	int ret = 0;
-	
+
 	switch (param->flags & IW_AUTH_INDEX) {
 
 	case IW_AUTH_WPA_VERSION:
 #ifdef CONFIG_WAPI_SUPPORT
 #ifndef CONFIG_IOCTL_CFG80211
-		 padapter->wapiInfo.bWapiEnable = false;
-		 if(value == IW_AUTH_WAPI_VERSION_1)
-		 {
+		padapter->wapiInfo.bWapiEnable = false;
+		if (value == IW_AUTH_WAPI_VERSION_1) {
 			padapter->wapiInfo.bWapiEnable = true;
 			psecuritypriv->dot11PrivacyAlgrthm = _SMS4_;
 			psecuritypriv->dot118021XGrpPrivacy = _SMS4_;
@@ -3768,20 +2926,20 @@ static int rtw_wx_set_auth(struct net_device *dev,
 #endif
 		break;
 	case IW_AUTH_CIPHER_PAIRWISE:
-		
+
 		break;
 	case IW_AUTH_CIPHER_GROUP:
-		
+
 		break;
 	case IW_AUTH_KEY_MGMT:
 #ifdef CONFIG_WAPI_SUPPORT
 #ifndef CONFIG_IOCTL_CFG80211
-		DBG_871X("rtw_wx_set_auth: IW_AUTH_KEY_MGMT case \n");
-		if(value == IW_AUTH_KEY_MGMT_WAPI_PSK)
+		RTW_INFO("rtw_wx_set_auth: IW_AUTH_KEY_MGMT case\n");
+		if (value == IW_AUTH_KEY_MGMT_WAPI_PSK)
 			padapter->wapiInfo.bWapiPSK = true;
 		else
 			padapter->wapiInfo.bWapiPSK = false;
-		DBG_871X("rtw_wx_set_auth: IW_AUTH_KEY_MGMT bwapipsk %d \n",padapter->wapiInfo.bWapiPSK);
+		RTW_INFO("rtw_wx_set_auth: IW_AUTH_KEY_MGMT bwapipsk %d\n", padapter->wapiInfo.bWapiPSK);
 #endif
 #endif
 		/*
@@ -3789,86 +2947,82 @@ static int rtw_wx_set_auth(struct net_device *dev,
 		 */
 		break;
 
-	case IW_AUTH_TKIP_COUNTERMEASURES:
-        {
-	    if ( param->value )
-            {  // wpa_supplicant is enabling the tkip countermeasure.
-               padapter->securitypriv.btkip_countermeasure = _TRUE; 
-            }
-            else
-            {  // wpa_supplicant is disabling the tkip countermeasure.
-               padapter->securitypriv.btkip_countermeasure = _FALSE; 
-            }
+	case IW_AUTH_TKIP_COUNTERMEASURES: {
+		if (param->value) {
+			/* wpa_supplicant is enabling the tkip countermeasure. */
+			padapter->securitypriv.btkip_countermeasure = _TRUE;
+		} else {
+			/* wpa_supplicant is disabling the tkip countermeasure. */
+			padapter->securitypriv.btkip_countermeasure = _FALSE;
+		}
 		break;
-        }
-	case IW_AUTH_DROP_UNENCRYPTED:
-		{
-			/* HACK:
-			 *
-			 * wpa_supplicant calls set_wpa_enabled when the driver
-			 * is loaded and unloaded, regardless of if WPA is being
-			 * used.  No other calls are made which can be used to
-			 * determine if encryption will be used or not prior to
-			 * association being expected.  If encryption is not being
-			 * used, drop_unencrypted is set to false, else true -- we
-			 * can use this to determine if the CAP_PRIVACY_ON bit should
-			 * be set.
-			 */
-
-			if(padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption1Enabled)
-			{
-				break;//it means init value, or using wep, ndisencryptstatus = Ndis802_11Encryption1Enabled, 
-						// then it needn't reset it;
-			}
-			
-			if(param->value){
-				padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
-				padapter->securitypriv.dot11PrivacyAlgrthm=_NO_PRIVACY_;
-				padapter->securitypriv.dot118021XGrpPrivacy=_NO_PRIVACY_;
-				padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_Open; //open system
-				padapter->securitypriv.ndisauthtype=Ndis802_11AuthModeOpen;
-			}
-			
-			break;
+	}
+	case IW_AUTH_DROP_UNENCRYPTED: {
+		/* HACK:
+		 *
+		 * wpa_supplicant calls set_wpa_enabled when the driver
+		 * is loaded and unloaded, regardless of if WPA is being
+		 * used.  No other calls are made which can be used to
+		 * determine if encryption will be used or not prior to
+		 * association being expected.  If encryption is not being
+		 * used, drop_unencrypted is set to false, else true -- we
+		 * can use this to determine if the CAP_PRIVACY_ON bit should
+		 * be set.
+		 */
+
+		if (padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption1Enabled) {
+			break;/* it means init value, or using wep, ndisencryptstatus = Ndis802_11Encryption1Enabled, */
+			/* then it needn't reset it; */
+		}
+
+		if (param->value) {
+			padapter->securitypriv.ndisencryptstatus = Ndis802_11EncryptionDisabled;
+			padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
+			padapter->securitypriv.dot118021XGrpPrivacy = _NO_PRIVACY_;
+			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
 		}
 
+		break;
+	}
+
 	case IW_AUTH_80211_AUTH_ALG:
 
-		#if defined(CONFIG_ANDROID) || 1
+#if defined(CONFIG_ANDROID) || 1
 		/*
 		 *  It's the starting point of a link layer connection using wpa_supplicant
 		*/
-		if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
+		if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
 			LeaveAllPowerSaveMode(padapter);
-			rtw_disassoc_cmd(padapter, 500, _FALSE);
-			DBG_871X("%s...call rtw_indicate_disconnect\n ",__FUNCTION__);
+			rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
+			RTW_INFO("%s...call rtw_indicate_disconnect\n ", __FUNCTION__);
 			rtw_indicate_disconnect(padapter, 0, _FALSE);
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources_cmd(padapter, _TRUE);
 		}
-		#endif
+#endif
 
 
-		ret = wpa_set_auth_algs(dev, (u32)param->value);		
-	
+		ret = wpa_set_auth_algs(dev, (u32)param->value);
+
 		break;
 
 	case IW_AUTH_WPA_ENABLED:
 
-		//if(param->value)
-		//	padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X; //802.1x
-		//else
-		//	padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open;//open system
-		
-		//_disassociate(priv);
-		
+		/* if(param->value) */
+		/* padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X; */ /* 802.1x */
+		/* else */
+		/* padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_Open; */ /* open system */
+
+		/* _disassociate(priv); */
+
 		break;
 
 	case IW_AUTH_RX_UNENCRYPTED_EAPOL:
-		//ieee->ieee802_1x = param->value;
+		/* ieee->ieee802_1x = param->value; */
 		break;
 
 	case IW_AUTH_PRIVACY_INVOKED:
-		//ieee->privacy_invoked = param->value;
+		/* ieee->privacy_invoked = param->value; */
 		break;
 
 #ifdef CONFIG_WAPI_SUPPORT
@@ -3880,29 +3034,29 @@ static int rtw_wx_set_auth(struct net_device *dev,
 
 	default:
 		return -EOPNOTSUPP;
-		
+
 	}
-	
+
 	return ret;
-	
+
 }
 
-static int rtw_wx_set_enc_ext(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
+static int rtw_wx_set_enc_ext(struct net_device *dev,
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
 	char *alg_name;
 	u32 param_len;
 	struct ieee_param *param = NULL;
 	struct iw_point *pencoding = &wrqu->encoding;
- 	struct iw_encode_ext *pext = (struct iw_encode_ext *)extra;
-	int ret=0;
+	struct iw_encode_ext *pext = (struct iw_encode_ext *)extra;
+	int ret = 0;
 
 	param_len = sizeof(struct ieee_param) + pext->key_len;
 	param = (struct ieee_param *)rtw_malloc(param_len);
 	if (param == NULL)
 		return -1;
-	
+
 	_rtw_memset(param, 0, param_len);
 
 	param->cmd = IEEE_CMD_SET_ENCRYPTION;
@@ -3911,8 +3065,8 @@ static int rtw_wx_set_enc_ext(struct net_device *dev,
 
 	switch (pext->alg) {
 	case IW_ENCODE_ALG_NONE:
-		//todo: remove key 
-		//remove = 1;	
+		/* todo: remove key */
+		/* remove = 1;	 */
 		alg_name = "none";
 		break;
 	case IW_ENCODE_ALG_WEP:
@@ -3928,13 +3082,13 @@ static int rtw_wx_set_enc_ext(struct net_device *dev,
 	case IW_ENCODE_ALG_AES_CMAC:
 		alg_name = "BIP";
 		break;
-#endif //CONFIG_IEEE80211W
+#endif /* CONFIG_IEEE80211W */
 #ifdef CONFIG_WAPI_SUPPORT
 #ifndef CONFIG_IOCTL_CFG80211
 	case IW_ENCODE_ALG_SM4:
-		alg_name= "SMS4";
+		alg_name = "SMS4";
 		_rtw_memcpy(param->sta_addr, pext->addr.sa_data, ETH_ALEN);
-		DBG_871X("rtw_wx_set_enc_ext: SMS4 case \n");
+		RTW_INFO("rtw_wx_set_enc_ext: SMS4 case\n");
 		break;
 #endif
 #endif
@@ -3946,131 +3100,121 @@ static int rtw_wx_set_enc_ext(struct net_device *dev,
 	strncpy((char *)param->u.crypt.alg, alg_name, IEEE_CRYPT_ALG_NAME_LEN);
 
 	if (pext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY)
-	{
 		param->u.crypt.set_tx = 1;
-	}
 
 	/* cliW: WEP does not have group key
-	 * just not checking GROUP key setting 
+	 * just not checking GROUP key setting
 	 */
 	if ((pext->alg != IW_ENCODE_ALG_WEP) &&
-		((pext->ext_flags & IW_ENCODE_EXT_GROUP_KEY)
+	    ((pext->ext_flags & IW_ENCODE_EXT_GROUP_KEY)
 #ifdef CONFIG_IEEE80211W
-		|| (pext->ext_flags & IW_ENCODE_ALG_AES_CMAC)
-#endif //CONFIG_IEEE80211W
-	))
-	{
+	     || (pext->ext_flags & IW_ENCODE_ALG_AES_CMAC)
+#endif /* CONFIG_IEEE80211W */
+	    ))
 		param->u.crypt.set_tx = 0;
-	}
 
-	param->u.crypt.idx = (pencoding->flags&0x00FF) -1 ;
+	param->u.crypt.idx = (pencoding->flags & 0x00FF) - 1 ;
 
-	if (pext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID)
-	{
+	if (pext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID) {
 #ifdef CONFIG_WAPI_SUPPORT
 #ifndef CONFIG_IOCTL_CFG80211
-		if(pext->alg == IW_ENCODE_ALG_SM4)
+		if (pext->alg == IW_ENCODE_ALG_SM4)
 			_rtw_memcpy(param->u.crypt.seq, pext->rx_seq, 16);
 		else
-#endif //CONFIG_IOCTL_CFG80211
-#endif //CONFIG_WAPI_SUPPORT
-		_rtw_memcpy(param->u.crypt.seq, pext->rx_seq, 8);
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_WAPI_SUPPORT */
+			_rtw_memcpy(param->u.crypt.seq, pext->rx_seq, 8);
 	}
 
-	if(pext->key_len)
-	{
+	if (pext->key_len) {
 		param->u.crypt.key_len = pext->key_len;
-		//_rtw_memcpy(param + 1, pext + 1, pext->key_len);
+		/* _rtw_memcpy(param + 1, pext + 1, pext->key_len); */
 		_rtw_memcpy(param->u.crypt.key, pext + 1, pext->key_len);
 	}
 
-	if (pencoding->flags & IW_ENCODE_DISABLED)
-	{
-		//todo: remove key 
-		//remove = 1;
+	if (pencoding->flags & IW_ENCODE_DISABLED) {
+		/* todo: remove key */
+		/* remove = 1; */
 	}
 
 	ret =  wpa_set_encryption(dev, param, param_len);
 
 exit:
-	if(param)
-	{
-		rtw_mfree((u8*)param, param_len);
-	}
+	if (param)
+		rtw_mfree((u8 *)param, param_len);
 
 	return ret;
 }
 
 
-static int rtw_wx_get_nick(struct net_device *dev, 
-			     struct iw_request_info *info, 
-			     union iwreq_data *wrqu, char *extra)
-{	
-	//_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	 //struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	 //struct security_priv *psecuritypriv = &padapter->securitypriv;
+static int rtw_wx_get_nick(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev); */
+	/* struct mlme_priv *pmlmepriv = &(padapter->mlmepriv); */
+	/* struct security_priv *psecuritypriv = &padapter->securitypriv; */
 
-	if(extra)
-	{
+	if (extra) {
 		wrqu->data.length = 14;
 		wrqu->data.flags = 1;
 		_rtw_memcpy(extra, "<WIFI@REALTEK>", 14);
 	}
 
-	//rtw_signal_process(pid, SIGUSR1); //for test
+	/* rtw_signal_process(pid, SIGUSR1); */ /* for test */
 
-	//dump debug info here	
-/*
-	u32 dot11AuthAlgrthm;		// 802.11 auth, could be open, shared, and 8021x
-	u32 dot11PrivacyAlgrthm;	// This specify the privacy for shared auth. algorithm.
-	u32 dot118021XGrpPrivacy;	// This specify the privacy algthm. used for Grp key 
+	/* dump debug info here	 */
+#if 0
+	u32 dot11AuthAlgrthm;		/*  802.11 auth, could be open, shared, and 8021x */
+	u32 dot11PrivacyAlgrthm;	/*  This specify the privacy for shared auth. algorithm. */
+	u32 dot118021XGrpPrivacy;	/*  This specify the privacy algthm. used for Grp key */
 	u32 ndisauthtype;
 	u32 ndisencryptstatus;
-*/
+#endif
 
-	//DBG_871X("auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n", 
-	//		psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm,
-	//		psecuritypriv->ndisauthtype, psecuritypriv->ndisencryptstatus);
-	
-	//DBG_871X("enc_alg=0x%x\n", psecuritypriv->dot11PrivacyAlgrthm);
-	//DBG_871X("auth_type=0x%x\n", psecuritypriv->ndisauthtype);
-	//DBG_871X("enc_type=0x%x\n", psecuritypriv->ndisencryptstatus);
+	/* RTW_INFO("auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n",  */
+	/*		psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm, */
+	/*		psecuritypriv->ndisauthtype, psecuritypriv->ndisencryptstatus); */
+
+	/* RTW_INFO("enc_alg=0x%x\n", psecuritypriv->dot11PrivacyAlgrthm); */
+	/* RTW_INFO("auth_type=0x%x\n", psecuritypriv->ndisauthtype); */
+	/* RTW_INFO("enc_type=0x%x\n", psecuritypriv->ndisencryptstatus); */
 
 #if 0
-	DBG_871X("dbg(0x210)=0x%x\n", rtw_read32(padapter, 0x210));
-	DBG_871X("dbg(0x608)=0x%x\n", rtw_read32(padapter, 0x608));
-	DBG_871X("dbg(0x280)=0x%x\n", rtw_read32(padapter, 0x280));
-	DBG_871X("dbg(0x284)=0x%x\n", rtw_read32(padapter, 0x284));
-	DBG_871X("dbg(0x288)=0x%x\n", rtw_read32(padapter, 0x288));
-	
-	DBG_871X("dbg(0x664)=0x%x\n", rtw_read32(padapter, 0x664));
-
-
-	DBG_871X("\n");
-
-	DBG_871X("dbg(0x430)=0x%x\n", rtw_read32(padapter, 0x430));
-	DBG_871X("dbg(0x438)=0x%x\n", rtw_read32(padapter, 0x438));
-
-	DBG_871X("dbg(0x440)=0x%x\n", rtw_read32(padapter, 0x440));
-	
-	DBG_871X("dbg(0x458)=0x%x\n", rtw_read32(padapter, 0x458));
-	
-	DBG_871X("dbg(0x484)=0x%x\n", rtw_read32(padapter, 0x484));
-	DBG_871X("dbg(0x488)=0x%x\n", rtw_read32(padapter, 0x488));
-	
-	DBG_871X("dbg(0x444)=0x%x\n", rtw_read32(padapter, 0x444));
-	DBG_871X("dbg(0x448)=0x%x\n", rtw_read32(padapter, 0x448));
-	DBG_871X("dbg(0x44c)=0x%x\n", rtw_read32(padapter, 0x44c));
-	DBG_871X("dbg(0x450)=0x%x\n", rtw_read32(padapter, 0x450));
-#endif
-	
+	RTW_INFO("dbg(0x210)=0x%x\n", rtw_read32(padapter, 0x210));
+	RTW_INFO("dbg(0x608)=0x%x\n", rtw_read32(padapter, 0x608));
+	RTW_INFO("dbg(0x280)=0x%x\n", rtw_read32(padapter, 0x280));
+	RTW_INFO("dbg(0x284)=0x%x\n", rtw_read32(padapter, 0x284));
+	RTW_INFO("dbg(0x288)=0x%x\n", rtw_read32(padapter, 0x288));
+
+	RTW_INFO("dbg(0x664)=0x%x\n", rtw_read32(padapter, 0x664));
+
+
+	RTW_INFO("\n");
+
+	RTW_INFO("dbg(0x430)=0x%x\n", rtw_read32(padapter, 0x430));
+	RTW_INFO("dbg(0x438)=0x%x\n", rtw_read32(padapter, 0x438));
+
+	RTW_INFO("dbg(0x440)=0x%x\n", rtw_read32(padapter, 0x440));
+
+	RTW_INFO("dbg(0x458)=0x%x\n", rtw_read32(padapter, 0x458));
+
+	RTW_INFO("dbg(0x484)=0x%x\n", rtw_read32(padapter, 0x484));
+	RTW_INFO("dbg(0x488)=0x%x\n", rtw_read32(padapter, 0x488));
+
+	RTW_INFO("dbg(0x444)=0x%x\n", rtw_read32(padapter, 0x444));
+	RTW_INFO("dbg(0x448)=0x%x\n", rtw_read32(padapter, 0x448));
+	RTW_INFO("dbg(0x44c)=0x%x\n", rtw_read32(padapter, 0x44c));
+	RTW_INFO("dbg(0x450)=0x%x\n", rtw_read32(padapter, 0x450));
+#endif
+
 	return 0;
 
 }
 
 static int rtw_wx_read32(struct net_device *dev,
-                            struct iw_request_info *info,
-                            union iwreq_data *wrqu, char *extra)
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter;
 	struct iw_point *p;
@@ -4089,7 +3233,7 @@ static int rtw_wx_read32(struct net_device *dev,
 	if (0 == len)
 		return -EINVAL;
 
-	ptmp = (u8*)rtw_malloc(len);
+	ptmp = (u8 *)rtw_malloc(len);
 	if (NULL == ptmp)
 		return -ENOMEM;
 
@@ -4103,24 +3247,39 @@ static int rtw_wx_read32(struct net_device *dev,
 	sscanf(ptmp, "%d,%x", &bytes, &addr);
 
 	switch (bytes) {
-		case 1:
-			data32 = rtw_read8(padapter, addr);
-			sprintf(extra, "0x%02X", data32);
-			break;
-		case 2:
-			data32 = rtw_read16(padapter, addr);
-			sprintf(extra, "0x%04X", data32);
-			break;
-		case 4:
-			data32 = rtw_read32(padapter, addr);
-			sprintf(extra, "0x%08X", data32);
-			break;
-		default:
-			DBG_871X(KERN_INFO "%s: usage> read [bytes],[address(hex)]\n", __func__);
-			ret = -EINVAL;
-			goto exit;
+	case 1:
+		data32 = rtw_read8(padapter, addr);
+		sprintf(extra, "0x%02X", data32);
+		break;
+	case 2:
+		data32 = rtw_read16(padapter, addr);
+		sprintf(extra, "0x%04X", data32);
+		break;
+	case 4:
+		data32 = rtw_read32(padapter, addr);
+		sprintf(extra, "0x%08X", data32);
+		break;
+
+	#if defined(CONFIG_SDIO_HCI) && defined(CONFIG_SDIO_INDIRECT_ACCESS) && defined(DBG_SDIO_INDIRECT_ACCESS)
+	case 11:
+		data32 = rtw_sd_iread8(padapter, addr);
+		sprintf(extra, "0x%02X", data32);
+		break;
+	case 12:
+		data32 = rtw_sd_iread16(padapter, addr);
+		sprintf(extra, "0x%04X", data32);
+		break;
+	case 14:
+		data32 = rtw_sd_iread32(padapter, addr);
+		sprintf(extra, "0x%08X", data32);
+		break;
+	#endif
+	default:
+		RTW_INFO("%s: usage> read [bytes],[address(hex)]\n", __func__);
+		ret = -EINVAL;
+		goto exit;
 	}
-	DBG_871X(KERN_INFO "%s: addr=0x%08X data=%s\n", __func__, addr, extra);
+	RTW_INFO("%s: addr=0x%08X data=%s\n", __func__, addr, extra);
 
 exit:
 	rtw_mfree(ptmp, len);
@@ -4129,8 +3288,8 @@ exit:
 }
 
 static int rtw_wx_write32(struct net_device *dev,
-                            struct iw_request_info *info,
-                            union iwreq_data *wrqu, char *extra)
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = (PADAPTER)rtw_netdev_priv(dev);
 
@@ -4145,38 +3304,38 @@ static int rtw_wx_write32(struct net_device *dev,
 	sscanf(extra, "%d,%x,%x", &bytes, &addr, &data32);
 
 	switch (bytes) {
-		case 1:
-			rtw_write8(padapter, addr, (u8)data32);
-			DBG_871X(KERN_INFO "%s: addr=0x%08X data=0x%02X\n", __func__, addr, (u8)data32);
-			break;
-		case 2:
-			rtw_write16(padapter, addr, (u16)data32);
-			DBG_871X(KERN_INFO "%s: addr=0x%08X data=0x%04X\n", __func__, addr, (u16)data32);
-			break;
-		case 4:
-			rtw_write32(padapter, addr, data32);
-			DBG_871X(KERN_INFO "%s: addr=0x%08X data=0x%08X\n", __func__, addr, data32);
-			break;
-		default:
-			DBG_871X(KERN_INFO "%s: usage> write [bytes],[address(hex)],[data(hex)]\n", __func__);
-			return -EINVAL;
+	case 1:
+		rtw_write8(padapter, addr, (u8)data32);
+		RTW_INFO("%s: addr=0x%08X data=0x%02X\n", __func__, addr, (u8)data32);
+		break;
+	case 2:
+		rtw_write16(padapter, addr, (u16)data32);
+		RTW_INFO("%s: addr=0x%08X data=0x%04X\n", __func__, addr, (u16)data32);
+		break;
+	case 4:
+		rtw_write32(padapter, addr, data32);
+		RTW_INFO("%s: addr=0x%08X data=0x%08X\n", __func__, addr, data32);
+		break;
+	default:
+		RTW_INFO("%s: usage> write [bytes],[address(hex)],[data(hex)]\n", __func__);
+		return -EINVAL;
 	}
 
 	return 0;
 }
 
 static int rtw_wx_read_rf(struct net_device *dev,
-                            struct iw_request_info *info,
-                            union iwreq_data *wrqu, char *extra)
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u32 path, addr, data32;
 
 
-	path = *(u32*)extra;
-	addr = *((u32*)extra + 1);
+	path = *(u32 *)extra;
+	addr = *((u32 *)extra + 1);
 	data32 = rtw_hal_read_rfreg(padapter, path, addr, 0xFFFFF);
-//	DBG_871X("%s: path=%d addr=0x%02x data=0x%05x\n", __func__, path, addr, data32);
+	/*	RTW_INFO("%s: path=%d addr=0x%02x data=0x%05x\n", __func__, path, addr, data32); */
 	/*
 	 * IMPORTANT!!
 	 * Only when wireless private ioctl is at odd order,
@@ -4187,48 +3346,64 @@ static int rtw_wx_read_rf(struct net_device *dev,
 	return 0;
 }
 
-static int rtw_wx_write_rf(struct net_device *dev,
-                            struct iw_request_info *info,
-                            union iwreq_data *wrqu, char *extra)
+static int rtw_wx_write_rf(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u32 path, addr, data32;
+
+
+	path = *(u32 *)extra;
+	addr = *((u32 *)extra + 1);
+	data32 = *((u32 *)extra + 2);
+	/*	RTW_INFO("%s: path=%d addr=0x%02x data=0x%05x\n", __func__, path, addr, data32); */
+	rtw_hal_write_rfreg(padapter, path, addr, 0xFFFFF, data32);
+
+	return 0;
+}
+
+static int rtw_wx_priv_null(struct net_device *dev, struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *b)
+{
+	return -1;
+}
+
+#ifdef CONFIG_RTW_80211K
+extern void rm_dbg_cmd(_adapter *padapter, char *s);
+static int rtw_wx_priv_rrm(struct net_device *dev, struct iw_request_info *a,
+			    union iwreq_data *wrqu, char *b)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u32 path, addr, data32;
 
 
-	path = *(u32*)extra;
-	addr = *((u32*)extra + 1);
-	data32 = *((u32*)extra + 2);
-//	DBG_871X("%s: path=%d addr=0x%02x data=0x%05x\n", __func__, path, addr, data32);
-	rtw_hal_write_rfreg(padapter, path, addr, 0xFFFFF, data32);
+	rm_dbg_cmd(padapter, b);
+	wrqu->data.length = strlen(b);
 
 	return 0;
 }
-
-static int rtw_wx_priv_null(struct net_device *dev, struct iw_request_info *a,
-		 union iwreq_data *wrqu, char *b)
-{
-	return -1;
-}
+#endif
 
 static int dummy(struct net_device *dev, struct iw_request_info *a,
 		 union iwreq_data *wrqu, char *b)
 {
-	//_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
-	//struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	/* _adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	 */
+	/* struct mlme_priv *pmlmepriv = &(padapter->mlmepriv); */
+
+	/* RTW_INFO("cmd_code=%x, fwstate=0x%x\n", a->cmd, get_fwstate(pmlmepriv)); */
 
-	//DBG_871X("cmd_code=%x, fwstate=0x%x\n", a->cmd, get_fwstate(pmlmepriv));
-	
 	return -1;
-	
+
 }
 
 static int rtw_wx_set_channel_plan(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				   struct iw_request_info *info,
+				   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	u8 channel_plan_req = (u8) (*((int *)wrqu));
+	u8 channel_plan_req = (u8)(*((int *)wrqu));
 
 	if (_SUCCESS != rtw_set_channel_plan(padapter, channel_plan_req))
 		return -EPERM;
@@ -4237,38 +3412,35 @@ static int rtw_wx_set_channel_plan(struct net_device *dev,
 }
 
 static int rtw_wx_set_mtk_wps_probe_ie(struct net_device *dev,
-		struct iw_request_info *a,
-		union iwreq_data *wrqu, char *b)
+				       struct iw_request_info *a,
+				       union iwreq_data *wrqu, char *b)
 {
 #ifdef CONFIG_PLATFORM_MT53XX
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-	RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_notice_,
-		 ("WLAN IOCTL: cmd_code=%x, fwstate=0x%x\n",
-		  a->cmd, get_fwstate(pmlmepriv)));
 #endif
 	return 0;
 }
 
 static int rtw_wx_get_sensitivity(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *buf)
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *buf)
 {
 #ifdef CONFIG_PLATFORM_MT53XX
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	//	Modified by Albert 20110914
-	//	This is in dbm format for MTK platform.
+	/*	Modified by Albert 20110914 */
+	/*	This is in dbm format for MTK platform. */
 	wrqu->qual.level = padapter->recvpriv.rssi;
-	DBG_871X(" level = %u\n",  wrqu->qual.level );
+	RTW_INFO(" level = %u\n",  wrqu->qual.level);
 #endif
 	return 0;
 }
 
 static int rtw_wx_set_mtk_wps_ie(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+				 struct iw_request_info *info,
+				 union iwreq_data *wrqu, char *extra)
 {
 #ifdef CONFIG_PLATFORM_MT53XX
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
@@ -4279,243 +3451,120 @@ static int rtw_wx_set_mtk_wps_ie(struct net_device *dev,
 #endif
 }
 
-/*
-typedef int (*iw_handler)(struct net_device *dev, struct iw_request_info *info,
-			  union iwreq_data *wrqu, char *extra);
-*/
-/*
- *	For all data larger than 16 octets, we need to use a
- *	pointer to memory allocated in user space.
- */
-static  int rtw_drvext_hdl(struct net_device *dev, struct iw_request_info *info,
-						union iwreq_data *wrqu, char *extra)
-{
-
- #if 0
-struct	iw_point
-{
-  void __user	*pointer;	/* Pointer to the data  (in user space) */
-  __u16		length;		/* number of fields or size in bytes */
-  __u16		flags;		/* Optional params */
-};
- #endif
-
-#ifdef CONFIG_DRVEXT_MODULE
-	u8 res;
-	struct drvext_handler *phandler;	
-	struct drvext_oidparam *poidparam;		
-	int ret;
-	u16 len;
-	u8 *pparmbuf, bset;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *p = &wrqu->data;
-
-	if( (!p->length) || (!p->pointer)){
-		ret = -EINVAL;
-		goto _rtw_drvext_hdl_exit;
-	}
-	
-	
-	bset = (u8)(p->flags&0xFFFF);
-	len = p->length;
-	pparmbuf = (u8*)rtw_malloc(len);
-	if (pparmbuf == NULL){
-		ret = -ENOMEM;
-		goto _rtw_drvext_hdl_exit;
-	}
-	
-	if(bset)//set info
-	{
-		if (copy_from_user(pparmbuf, p->pointer,len)) {
-			rtw_mfree(pparmbuf, len);
-			ret = -EFAULT;
-			goto _rtw_drvext_hdl_exit;
-		}		
-	}
-	else//query info
-	{
-	
-	}
-
-	
-	//
-	poidparam = (struct drvext_oidparam *)pparmbuf;	
-	
-	RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_info_,("drvext set oid subcode [%d], len[%d], InformationBufferLength[%d]\r\n",
-        					 poidparam->subcode, poidparam->len, len));
-
-
-	//check subcode	
-	if ( poidparam->subcode >= MAX_DRVEXT_HANDLERS)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("no matching drvext handlers\r\n"));		
-		ret = -EINVAL;
-		goto _rtw_drvext_hdl_exit;
-	}
-
-
-	if ( poidparam->subcode >= MAX_DRVEXT_OID_SUBCODES)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("no matching drvext subcodes\r\n"));		
-		ret = -EINVAL;
-		goto _rtw_drvext_hdl_exit;
-	}
-
-
-	phandler = drvextoidhandlers + poidparam->subcode;
-
-	if (poidparam->len != phandler->parmsize)
-	{
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_err_,("no matching drvext param size %d vs %d\r\n",			
-						poidparam->len , phandler->parmsize));		
-		ret = -EINVAL;		
-		goto _rtw_drvext_hdl_exit;
-	}
-
-
-	res = phandler->handler(&padapter->drvextpriv, bset, poidparam->data);
-
-	if(res==0)
-	{
-		ret = 0;
-			
-		if (bset == 0x00) {//query info
-			//_rtw_memcpy(p->pointer, pparmbuf, len);
-			if (copy_to_user(p->pointer, pparmbuf, len))
-				ret = -EFAULT;
-		}		
-	}		
-	else
-		ret = -EFAULT;
-
-	
-_rtw_drvext_hdl_exit:	
-	
-	return ret;	
-	
-#endif
-
-	return 0;
-
-}
-
 static void rtw_dbg_mode_hdl(_adapter *padapter, u32 id, u8 *pdata, u32 len)
 {
-	pRW_Reg 	RegRWStruct;
+	pRW_Reg	RegRWStruct;
 	struct rf_reg_param *prfreg;
 	u8 path;
 	u8 offset;
 	u32 value;
 
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
-	switch(id)
-	{
-		case GEN_MP_IOCTL_SUBCODE(MP_START):
-			DBG_871X("871x_driver is only for normal mode, can't enter mp mode\n");
+	switch (id) {
+	case GEN_MP_IOCTL_SUBCODE(MP_START):
+		RTW_INFO("871x_driver is only for normal mode, can't enter mp mode\n");
+		break;
+	case GEN_MP_IOCTL_SUBCODE(READ_REG):
+		RegRWStruct = (pRW_Reg)pdata;
+		switch (RegRWStruct->width) {
+		case 1:
+			RegRWStruct->value = rtw_read8(padapter, RegRWStruct->offset);
 			break;
-		case GEN_MP_IOCTL_SUBCODE(READ_REG):
-			RegRWStruct = (pRW_Reg)pdata;
-			switch (RegRWStruct->width)
-			{
-				case 1:
-					RegRWStruct->value = rtw_read8(padapter, RegRWStruct->offset);
-					break;
-				case 2:
-					RegRWStruct->value = rtw_read16(padapter, RegRWStruct->offset);
-					break;
-				case 4:
-					RegRWStruct->value = rtw_read32(padapter, RegRWStruct->offset);
-					break;
-				default:
-					break;
-			}
-		
+		case 2:
+			RegRWStruct->value = rtw_read16(padapter, RegRWStruct->offset);
 			break;
-		case GEN_MP_IOCTL_SUBCODE(WRITE_REG):
-			RegRWStruct = (pRW_Reg)pdata;
-			switch (RegRWStruct->width)
-			{
-				case 1:
-					rtw_write8(padapter, RegRWStruct->offset, (u8)RegRWStruct->value);
-					break;
-				case 2:
-					rtw_write16(padapter, RegRWStruct->offset, (u16)RegRWStruct->value);
-					break;
-				case 4:
-					rtw_write32(padapter, RegRWStruct->offset, (u32)RegRWStruct->value);
-					break;
-				default:					
-				break;
-			}
-				
+		case 4:
+			RegRWStruct->value = rtw_read32(padapter, RegRWStruct->offset);
+			break;
+		default:
+			break;
+		}
+
+		break;
+	case GEN_MP_IOCTL_SUBCODE(WRITE_REG):
+		RegRWStruct = (pRW_Reg)pdata;
+		switch (RegRWStruct->width) {
+		case 1:
+			rtw_write8(padapter, RegRWStruct->offset, (u8)RegRWStruct->value);
+			break;
+		case 2:
+			rtw_write16(padapter, RegRWStruct->offset, (u16)RegRWStruct->value);
+			break;
+		case 4:
+			rtw_write32(padapter, RegRWStruct->offset, (u32)RegRWStruct->value);
+			break;
+		default:
 			break;
-		case GEN_MP_IOCTL_SUBCODE(READ_RF_REG):
+		}
+
+		break;
+	case GEN_MP_IOCTL_SUBCODE(READ_RF_REG):
 
-			prfreg = (struct rf_reg_param *)pdata;
+		prfreg = (struct rf_reg_param *)pdata;
 
-			path = (u8)prfreg->path;		
-			offset = (u8)prfreg->offset;	
+		path = (u8)prfreg->path;
+		offset = (u8)prfreg->offset;
 
-			value = rtw_hal_read_rfreg(padapter, path, offset, 0xffffffff);
+		value = rtw_hal_read_rfreg(padapter, path, offset, 0xffffffff);
 
-			prfreg->value = value;
+		prfreg->value = value;
 
-			break;			
-		case GEN_MP_IOCTL_SUBCODE(WRITE_RF_REG):
+		break;
+	case GEN_MP_IOCTL_SUBCODE(WRITE_RF_REG):
+
+		prfreg = (struct rf_reg_param *)pdata;
 
-			prfreg = (struct rf_reg_param *)pdata;
+		path = (u8)prfreg->path;
+		offset = (u8)prfreg->offset;
+		value = prfreg->value;
 
-			path = (u8)prfreg->path;
-			offset = (u8)prfreg->offset;	
-			value = prfreg->value;
+		rtw_hal_write_rfreg(padapter, path, offset, 0xffffffff, value);
 
-			rtw_hal_write_rfreg(padapter, path, offset, 0xffffffff, value);
-			
-			break;			
-                case GEN_MP_IOCTL_SUBCODE(TRIGGER_GPIO):
-			DBG_871X("==> trigger gpio 0\n");
-			rtw_hal_set_hwreg(padapter, HW_VAR_TRIGGER_GPIO_0, 0);
-			break;	
+		break;
+	case GEN_MP_IOCTL_SUBCODE(TRIGGER_GPIO):
+		RTW_INFO("==> trigger gpio 0\n");
+		rtw_hal_set_hwreg(padapter, HW_VAR_TRIGGER_GPIO_0, 0);
+		break;
 #ifdef CONFIG_BT_COEXIST
-		case GEN_MP_IOCTL_SUBCODE(SET_DM_BT):			
-			DBG_871X("==> set dm_bt_coexist:%x\n",*(u8 *)pdata);
-			rtw_hal_set_hwreg(padapter, HW_VAR_BT_SET_COEXIST, pdata);
-			break;
-		case GEN_MP_IOCTL_SUBCODE(DEL_BA):
-			DBG_871X("==> delete ba:%x\n",*(u8 *)pdata);
-			rtw_hal_set_hwreg(padapter, HW_VAR_BT_ISSUE_DELBA, pdata);
-			break;
+	case GEN_MP_IOCTL_SUBCODE(SET_DM_BT):
+		RTW_INFO("==> set dm_bt_coexist:%x\n", *(u8 *)pdata);
+		rtw_hal_set_hwreg(padapter, HW_VAR_BT_SET_COEXIST, pdata);
+		break;
+	case GEN_MP_IOCTL_SUBCODE(DEL_BA):
+		RTW_INFO("==> delete ba:%x\n", *(u8 *)pdata);
+		rtw_hal_set_hwreg(padapter, HW_VAR_BT_ISSUE_DELBA, pdata);
+		break;
 #endif
 #ifdef DBG_CONFIG_ERROR_DETECT
-		case GEN_MP_IOCTL_SUBCODE(GET_WIFI_STATUS):							
-			*pdata = rtw_hal_sreset_get_wifi_status(padapter);                   
-			break;
+	case GEN_MP_IOCTL_SUBCODE(GET_WIFI_STATUS):
+		*pdata = rtw_hal_sreset_get_wifi_status(padapter);
+		break;
 #endif
-	
-		default:
-			break;
+
+	default:
+		break;
 	}
-	
-}
 
+}
+#ifdef MP_IOCTL_HDL
 static int rtw_mp_ioctl_hdl(struct net_device *dev, struct iw_request_info *info,
-						union iwreq_data *wrqu, char *extra)
+			    union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 	u32 BytesRead, BytesWritten, BytesNeeded;
 	struct oid_par_priv	oid_par;
 	struct mp_ioctl_handler	*phandler;
 	struct mp_ioctl_param	*poidparam;
-	uint status=0;
+	uint status = 0;
 	u16 len;
 	u8 *pparmbuf = NULL, bset;
 	PADAPTER padapter = (PADAPTER)rtw_netdev_priv(dev);
 	struct iw_point *p = &wrqu->data;
 
-	//DBG_871X("+rtw_mp_ioctl_hdl\n");
+	/* RTW_INFO("+rtw_mp_ioctl_hdl\n"); */
 
-	//mutex_lock(&ioctl_mutex);
+	/* mutex_lock(&ioctl_mutex); */
 
 	if ((!p->length) || (!p->pointer)) {
 		ret = -EINVAL;
@@ -4525,8 +3574,8 @@ static int rtw_mp_ioctl_hdl(struct net_device *dev, struct iw_request_info *info
 	pparmbuf = NULL;
 	bset = (u8)(p->flags & 0xFFFF);
 	len = p->length;
-	pparmbuf = (u8*)rtw_malloc(len);
-	if (pparmbuf == NULL){
+	pparmbuf = (u8 *)rtw_malloc(len);
+	if (pparmbuf == NULL) {
 		ret = -ENOMEM;
 		goto _rtw_mp_ioctl_hdl_exit;
 	}
@@ -4537,70 +3586,58 @@ static int rtw_mp_ioctl_hdl(struct net_device *dev, struct iw_request_info *info
 	}
 
 	poidparam = (struct mp_ioctl_param *)pparmbuf;
-	RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_info_,
-		 ("rtw_mp_ioctl_hdl: subcode [%d], len[%d], buffer_len[%d]\r\n",
-		  poidparam->subcode, poidparam->len, len));
 
 	if (poidparam->subcode >= MAX_MP_IOCTL_SUBCODE) {
-		RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_err_, ("no matching drvext subcodes\r\n"));
 		ret = -EINVAL;
 		goto _rtw_mp_ioctl_hdl_exit;
 	}
 
-	//DBG_871X("%s: %d\n", __func__, poidparam->subcode);
-#ifdef CONFIG_MP_INCLUDED 
-if (padapter->registrypriv.mp_mode == 1)
-{	
-	phandler = mp_ioctl_hdl + poidparam->subcode;
-
-	if ((phandler->paramsize != 0) && (poidparam->len < phandler->paramsize))
-	{
-		RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_err_,
-			 ("no matching drvext param size %d vs %d\r\n",
-			  poidparam->len, phandler->paramsize));
-		ret = -EINVAL;
-		goto _rtw_mp_ioctl_hdl_exit;
-	}
+	/* RTW_INFO("%s: %d\n", __func__, poidparam->subcode); */
+#ifdef CONFIG_MP_INCLUDED
+	if (padapter->registrypriv.mp_mode == 1) {
+		phandler = mp_ioctl_hdl + poidparam->subcode;
 
-	if (phandler->handler)
-	{
-		oid_par.adapter_context = padapter;
-		oid_par.oid = phandler->oid;
-		oid_par.information_buf = poidparam->data;
-		oid_par.information_buf_len = poidparam->len;
-		oid_par.dbg = 0;
-
-		BytesWritten = 0;
-		BytesNeeded = 0;
-
-		if (bset) {
-			oid_par.bytes_rw = &BytesRead;
-			oid_par.bytes_needed = &BytesNeeded;
-			oid_par.type_of_oid = SET_OID;
-		} else {
-			oid_par.bytes_rw = &BytesWritten;
-			oid_par.bytes_needed = &BytesNeeded;
-			oid_par.type_of_oid = QUERY_OID;
+		if ((phandler->paramsize != 0) && (poidparam->len < phandler->paramsize)) {
+			ret = -EINVAL;
+			goto _rtw_mp_ioctl_hdl_exit;
 		}
 
-		status = phandler->handler(&oid_par);
+		if (phandler->handler) {
+			oid_par.adapter_context = padapter;
+			oid_par.oid = phandler->oid;
+			oid_par.information_buf = poidparam->data;
+			oid_par.information_buf_len = poidparam->len;
+			oid_par.dbg = 0;
 
-		//todo:check status, BytesNeeded, etc.
-	}
-	else {
-		DBG_871X("rtw_mp_ioctl_hdl(): err!, subcode=%d, oid=%d, handler=%p\n", 
-			poidparam->subcode, phandler->oid, phandler->handler);
-		ret = -EFAULT;
-		goto _rtw_mp_ioctl_hdl_exit;
-	}
-}
-else
+			BytesWritten = 0;
+			BytesNeeded = 0;
+
+			if (bset) {
+				oid_par.bytes_rw = &BytesRead;
+				oid_par.bytes_needed = &BytesNeeded;
+				oid_par.type_of_oid = SET_OID;
+			} else {
+				oid_par.bytes_rw = &BytesWritten;
+				oid_par.bytes_needed = &BytesNeeded;
+				oid_par.type_of_oid = QUERY_OID;
+			}
+
+			status = phandler->handler(&oid_par);
+
+			/* todo:check status, BytesNeeded, etc. */
+		} else {
+			RTW_INFO("rtw_mp_ioctl_hdl(): err!, subcode=%d, oid=%d, handler=%p\n",
+				poidparam->subcode, phandler->oid, phandler->handler);
+			ret = -EFAULT;
+			goto _rtw_mp_ioctl_hdl_exit;
+		}
+	} else
 #endif
-{
-	rtw_dbg_mode_hdl(padapter, poidparam->subcode, poidparam->data, poidparam->len);
-}
+	{
+		rtw_dbg_mode_hdl(padapter, poidparam->subcode, poidparam->data, poidparam->len);
+	}
 
-	if (bset == 0x00) {//query info
+	if (bset == 0x00) {/* query info */
 		if (copy_to_user(p->pointer, pparmbuf, len))
 			ret = -EFAULT;
 	}
@@ -4615,276 +3652,239 @@ _rtw_mp_ioctl_hdl_exit:
 	if (pparmbuf)
 		rtw_mfree(pparmbuf, len);
 
-	//mutex_unlock(&ioctl_mutex);
+	/* mutex_unlock(&ioctl_mutex); */
 
 	return ret;
 }
-
+#endif
 static int rtw_get_ap_info(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 	int bssid_match, ret = 0;
-	u32 cnt=0, wpa_ielen;
+	u32 cnt = 0, wpa_ielen;
 	_irqL	irqL;
 	_list	*plist, *phead;
 	unsigned char *pbuf;
 	u8 bssid[ETH_ALEN];
 	char data[32];
 	struct wlan_network *pnetwork = NULL;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	_queue *queue = &(pmlmepriv->scanned_queue);
-	struct iw_point *pdata = &wrqu->data;	
+	struct iw_point *pdata = &wrqu->data;
 
-	DBG_871X("+rtw_get_aplist_info\n");
+	RTW_INFO("+rtw_get_aplist_info\n");
 
 	if (rtw_is_drv_stopped(padapter) || (pdata == NULL)) {
-		ret= -EINVAL;
+		ret = -EINVAL;
 		goto exit;
-	}		
-  
- 	while((check_fwstate(pmlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING))) == _TRUE)
-	{	
+	}
+
+	while ((check_fwstate(pmlmepriv, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING))) == _TRUE) {
 		rtw_msleep_os(30);
 		cnt++;
-		if(cnt > 100)
+		if (cnt > 100)
 			break;
 	}
-	
 
-	//pdata->length = 0;//?	
+
+	/* pdata->length = 0; */ /* ?	 */
 	pdata->flags = 0;
-	if(pdata->length>=32)
-	{
-		if(copy_from_user(data, pdata->pointer, 32))
-		{
-			ret= -EINVAL;
+	if (pdata->length >= 32) {
+		if (copy_from_user(data, pdata->pointer, 32)) {
+			ret = -EINVAL;
 			goto exit;
 		}
-	}	
-	else
-	{
-		ret= -EINVAL;
+	} else {
+		ret = -EINVAL;
 		goto exit;
-	}	
+	}
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-	
+
 	phead = get_list_head(queue);
 	plist = get_next(phead);
-       
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
 
-		//if(hwaddr_aton_i(pdata->pointer, bssid)) 
-		if(hwaddr_aton_i(data, bssid)) 
-		{			
-			DBG_871X("Invalid BSSID '%s'.\n", (u8*)data);
+		/* if(hwaddr_aton_i(pdata->pointer, bssid)) */
+		if (hwaddr_aton_i(data, bssid)) {
+			RTW_INFO("Invalid BSSID '%s'.\n", (u8 *)data);
 			_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 			return -EINVAL;
-		}		
-		
-	
-		if(_rtw_memcmp(bssid, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE)//BSSID match, then check if supporting wpa/wpa2
-		{
-			DBG_871X("BSSID:" MAC_FMT "\n", MAC_ARG(bssid));
-			
-			pbuf = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength-12);				
-			if(pbuf && (wpa_ielen>0))
-			{
+		}
+
+
+		if (_rtw_memcmp(bssid, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE) { /* BSSID match, then check if supporting wpa/wpa2 */
+			RTW_INFO("BSSID:" MAC_FMT "\n", MAC_ARG(bssid));
+
+			pbuf = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
+			if (pbuf && (wpa_ielen > 0)) {
 				pdata->flags = 1;
 				break;
 			}
 
-			pbuf = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength-12);
-			if(pbuf && (wpa_ielen>0))
-			{
+			pbuf = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
+			if (pbuf && (wpa_ielen > 0)) {
 				pdata->flags = 2;
 				break;
 			}
-			
+
 		}
 
-		plist = get_next(plist);		
-	
-	}        
+		plist = get_next(plist);
+
+	}
 
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-	if(pdata->length>=34)
-	{
-		if(copy_to_user((u8*)pdata->pointer+32, (u8*)&pdata->flags, 1))
-		{
-			ret= -EINVAL;
+	if (pdata->length >= 34) {
+		if (copy_to_user((u8 *)pdata->pointer + 32, (u8 *)&pdata->flags, 1)) {
+			ret = -EINVAL;
 			goto exit;
 		}
-	}	
-	
+	}
+
 exit:
-	
+
 	return ret;
-		
+
 }
 
 static int rtw_set_pid(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = rtw_netdev_priv(dev);
 	int *pdata = (int *)wrqu;
 	int selector;
 
 	if (rtw_is_drv_stopped(padapter) || (pdata == NULL)) {
-		ret= -EINVAL;
+		ret = -EINVAL;
 		goto exit;
-	}		
-  
-	selector = *pdata;
-	if(selector < 3 && selector >=0) {
-		padapter->pid[selector] = *(pdata+1);
-		#ifdef CONFIG_GLOBAL_UI_PID
-		ui_pid[selector] = *(pdata+1);
-		#endif
-		DBG_871X("%s set pid[%d]=%d\n", __FUNCTION__, selector ,padapter->pid[selector]);
 	}
-	else
-		DBG_871X("%s selector %d error\n", __FUNCTION__, selector);
+
+	selector = *pdata;
+	if (selector < 3 && selector >= 0) {
+		padapter->pid[selector] = *(pdata + 1);
+#ifdef CONFIG_GLOBAL_UI_PID
+		ui_pid[selector] = *(pdata + 1);
+#endif
+		RTW_INFO("%s set pid[%d]=%d\n", __FUNCTION__, selector , padapter->pid[selector]);
+	} else
+		RTW_INFO("%s selector %d error\n", __FUNCTION__, selector);
 
 exit:
-	
+
 	return ret;
-		
+
 }
 
 static int rtw_wps_start(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
 	u32   u32wps_start = 0;
-        unsigned int uintRet = 0;
+	unsigned int uintRet = 0;
 
 	if (RTW_CANNOT_RUN(padapter) || (NULL == pdata)) {
-		ret= -EINVAL;
+		ret = -EINVAL;
 		goto exit;
-	}		
+	}
 
-	uintRet = copy_from_user( ( void* ) &u32wps_start, pdata->pointer, 4 );
-	if ( u32wps_start == 0 )
-	{
+	uintRet = copy_from_user((void *) &u32wps_start, pdata->pointer, 4);
+	if (u32wps_start == 0)
 		u32wps_start = *extra;
-	}
 
-	DBG_871X( "[%s] wps_start = %d\n", __FUNCTION__, u32wps_start );
+	RTW_INFO("[%s] wps_start = %d\n", __FUNCTION__, u32wps_start);
 
-	if ( u32wps_start == 1 ) // WPS Start
-	{
+	if (u32wps_start == 1)   /* WPS Start */
 		rtw_led_control(padapter, LED_CTL_START_WPS);
-	}
-	else if ( u32wps_start == 2 ) // WPS Stop because of wps success
-	{
+	else if (u32wps_start == 2)   /* WPS Stop because of wps success */
 		rtw_led_control(padapter, LED_CTL_STOP_WPS);
-	}
-	else if ( u32wps_start == 3 ) // WPS Stop because of wps fail
-	{
+	else if (u32wps_start == 3)   /* WPS Stop because of wps fail */
 		rtw_led_control(padapter, LED_CTL_STOP_WPS_FAIL);
-	}
 
 #ifdef CONFIG_INTEL_WIDI
 	process_intel_widi_wps_status(padapter, u32wps_start);
-#endif //CONFIG_INTEL_WIDI
-	
+#endif /* CONFIG_INTEL_WIDI */
+
 exit:
-	
+
 	return ret;
-		
+
 }
 
 #ifdef CONFIG_P2P
 static int rtw_wext_p2p_enable(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	enum P2P_ROLE init_role = P2P_ROLE_DISABLE;
 
-	if(*extra == '0' )
+	if (*extra == '0')
 		init_role = P2P_ROLE_DISABLE;
-	else if(*extra == '1')
+	else if (*extra == '1')
 		init_role = P2P_ROLE_DEVICE;
-	else if(*extra == '2')
+	else if (*extra == '2')
 		init_role = P2P_ROLE_CLIENT;
-	else if(*extra == '3')
+	else if (*extra == '3')
 		init_role = P2P_ROLE_GO;
 
-	if(_FAIL == rtw_p2p_enable(padapter, init_role))
-	{
+	if (_FAIL == rtw_p2p_enable(padapter, init_role)) {
 		ret = -EFAULT;
 		goto exit;
 	}
 
-	//set channel/bandwidth
-	if(init_role != P2P_ROLE_DISABLE) 
-	{	
+	/* set channel/bandwidth */
+	if (init_role != P2P_ROLE_DISABLE) {
 		u8 channel, ch_offset;
 		u16 bwmode;
 
-		if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN))
-		{
-			//	Stay at the listen state and wait for discovery.
+		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN)) {
+			/*	Stay at the listen state and wait for discovery. */
 			channel = pwdinfo->listen_channel;
 			pwdinfo->operating_channel = pwdinfo->listen_channel;
 			ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 			bwmode = CHANNEL_WIDTH_20;
 		}
 #ifdef CONFIG_CONCURRENT_MODE
-		else if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
-		{
-			_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-			//struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-			struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-			struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-			
-			_set_timer( &pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_interval );
-			if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-			{
-				pwdinfo->operating_channel = pbuddy_mlmeext->cur_channel;
-				//	How about the ch_offset and bwmode ??
-			}
-			else
-			{
-				pwdinfo->operating_channel = pwdinfo->listen_channel;
-			}
+		else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
+
+			_set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_interval);
 
-			channel = pbuddy_mlmeext->cur_channel;
-			ch_offset = pbuddy_mlmeext->cur_ch_offset;
-			bwmode = pbuddy_mlmeext->cur_bwmode;
+			channel = rtw_mi_get_union_chan(padapter);
+			ch_offset = rtw_mi_get_union_offset(padapter);
+			bwmode = rtw_mi_get_union_bw(padapter);
+
+			pwdinfo->operating_channel = channel;
 		}
 #endif
-		else
-		{
+		else {
 			pwdinfo->operating_channel = pmlmeext->cur_channel;
-		
+
 			channel = pwdinfo->operating_channel;
 			ch_offset = pmlmeext->cur_ch_offset;
-			bwmode = pmlmeext->cur_bwmode;						
+			bwmode = pmlmeext->cur_bwmode;
 		}
 
 		set_channel_bwmode(padapter, channel, ch_offset, bwmode);
@@ -4892,396 +3892,368 @@ static int rtw_wext_p2p_enable(struct net_device *dev,
 
 exit:
 	return ret;
-		
+
 }
 
 static int rtw_p2p_set_go_nego_ssid(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				    struct iw_request_info *info,
+				    union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] ssid = %s, len = %zu\n", __FUNCTION__, extra, strlen(extra));
+	_rtw_memcpy(pwdinfo->nego_ssid, extra, strlen(extra));
+	pwdinfo->nego_ssidlen = strlen(extra);
 
-	DBG_871X( "[%s] ssid = %s, len = %zu\n", __FUNCTION__, extra, strlen( extra ) );
-	_rtw_memcpy( pwdinfo->nego_ssid, extra, strlen( extra ) );
-	pwdinfo->nego_ssidlen = strlen( extra );
-	
 	return ret;
-		
+
 }
 
 
 static int rtw_p2p_set_intent(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
-	int 							ret = 0;
-	_adapter 						*padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info 			*pwdinfo= &(padapter->wdinfo);
+	int							ret = 0;
+	_adapter						*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info			*pwdinfo = &(padapter->wdinfo);
 	u8							intent = pwdinfo->intent;
 
-	extra[ wrqu->data.length ] = 0x00;
+	extra[wrqu->data.length] = 0x00;
 
-	intent = rtw_atoi( extra );
+	intent = rtw_atoi(extra);
 
-	if ( intent <= 15 )
-	{
-		pwdinfo->intent= intent;
-	}
+	if (intent <= 15)
+		pwdinfo->intent = intent;
 	else
-	{
 		ret = -1;
-	}
-	
-	DBG_871X( "[%s] intent = %d\n", __FUNCTION__, intent);
+
+	RTW_INFO("[%s] intent = %d\n", __FUNCTION__, intent);
 
 	return ret;
-		
+
 }
 
 static int rtw_p2p_set_listen_ch(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				 struct iw_request_info *info,
+				 union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-	u8	listen_ch = pwdinfo->listen_channel;	//	Listen channel number
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8	listen_ch = pwdinfo->listen_channel;	/*	Listen channel number */
 
-	extra[ wrqu->data.length ] = 0x00;
-	listen_ch = rtw_atoi( extra );
+	extra[wrqu->data.length] = 0x00;
+	listen_ch = rtw_atoi(extra);
 
-	if ( ( listen_ch == 1 ) || ( listen_ch == 6 ) || ( listen_ch == 11 ) )
-	{
+	if ((listen_ch == 1) || (listen_ch == 6) || (listen_ch == 11)) {
 		pwdinfo->listen_channel = listen_ch;
 		set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-	}
-	else
-	{
+	} else
 		ret = -1;
-	}
-	
-	DBG_871X( "[%s] listen_ch = %d\n", __FUNCTION__, pwdinfo->listen_channel );
-	
+
+	RTW_INFO("[%s] listen_ch = %d\n", __FUNCTION__, pwdinfo->listen_channel);
+
 	return ret;
-		
+
 }
 
 static int rtw_p2p_set_op_ch(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
 {
-//	Commented by Albert 20110524
-//	This function is used to set the operating channel if the driver will become the group owner
+	/*	Commented by Albert 20110524
+	 *	This function is used to set the operating channel if the driver will become the group owner */
 
-	int ret = 0;	
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-	u8	op_ch = pwdinfo->operating_channel;	//	Operating channel number
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	u8	op_ch = pwdinfo->operating_channel;	/*	Operating channel number */
 
-	extra[ wrqu->data.length ] = 0x00;
+	extra[wrqu->data.length] = 0x00;
 
-	op_ch = ( u8 ) rtw_atoi( extra );
-	if ( op_ch > 0 )
-	{
+	op_ch = (u8) rtw_atoi(extra);
+	if (op_ch > 0)
 		pwdinfo->operating_channel = op_ch;
-	}
 	else
-	{
 		ret = -1;
-	}
-	
-	DBG_871X( "[%s] op_ch = %d\n", __FUNCTION__, pwdinfo->operating_channel );
-	
+
+	RTW_INFO("[%s] op_ch = %d\n", __FUNCTION__, pwdinfo->operating_channel);
+
 	return ret;
 
 }
 
 
 static int rtw_p2p_profilefound(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				struct iw_request_info *info,
+				union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-
-	//	Comment by Albert 2010/10/13
-	//	Input data format:
-	//	Ex:  0
-	//	Ex:  1XX:XX:XX:XX:XX:XXYYSSID
-	//	0 => Reflush the profile record list.
-	//	1 => Add the profile list
-	//	XX:XX:XX:XX:XX:XX => peer's MAC Address ( ex: 00:E0:4C:00:00:01 )
-	//	YY => SSID Length
-	//	SSID => SSID for persistence group
-
-	DBG_871X( "[%s] In value = %s, len = %d \n", __FUNCTION__, extra, wrqu->data.length -1);
-
-	
-	//	The upper application should pass the SSID to driver by using this rtw_p2p_profilefound function.
-	if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
-		if ( extra[ 0 ] == '0' )
-		{
-			//	Remove all the profile information of wifidirect_info structure.
-			_rtw_memset( &pwdinfo->profileinfo[ 0 ], 0x00, sizeof( struct profile_info ) * P2P_MAX_PERSISTENT_GROUP_NUM );
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+
+	/*	Comment by Albert 2010/10/13 */
+	/*	Input data format: */
+	/*	Ex:  0 */
+	/*	Ex:  1XX:XX:XX:XX:XX:XXYYSSID */
+	/*	0 => Reflush the profile record list. */
+	/*	1 => Add the profile list */
+	/*	XX:XX:XX:XX:XX:XX => peer's MAC Address ( ex: 00:E0:4C:00:00:01 ) */
+	/*	YY => SSID Length */
+	/*	SSID => SSID for persistence group */
+
+	RTW_INFO("[%s] In value = %s, len = %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+
+	/*	The upper application should pass the SSID to driver by using this rtw_p2p_profilefound function. */
+	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		if (extra[0] == '0') {
+			/*	Remove all the profile information of wifidirect_info structure. */
+			_rtw_memset(&pwdinfo->profileinfo[0], 0x00, sizeof(struct profile_info) * P2P_MAX_PERSISTENT_GROUP_NUM);
 			pwdinfo->profileindex = 0;
-		}
-		else
-		{
-			if ( pwdinfo->profileindex >= P2P_MAX_PERSISTENT_GROUP_NUM )
-		{
+		} else {
+			if (pwdinfo->profileindex >= P2P_MAX_PERSISTENT_GROUP_NUM)
 				ret = -1;
-		}
-		else
-		{
+			else {
 				int jj, kk;
-				
-				//	Add this profile information into pwdinfo->profileinfo
-				//	Ex:  1XX:XX:XX:XX:XX:XXYYSSID
-				for( jj = 0, kk = 1; jj < ETH_ALEN; jj++, kk += 3 )
-				{
-					pwdinfo->profileinfo[ pwdinfo->profileindex ].peermac[ jj ] = key_2char2num(extra[ kk ], extra[ kk+ 1 ]);
-				}
 
-				//pwdinfo->profileinfo[ pwdinfo->profileindex ].ssidlen = ( extra[18] - '0' ) * 10 + ( extra[ 19 ] - '0' );
-				//_rtw_memcpy( pwdinfo->profileinfo[ pwdinfo->profileindex ].ssid, &extra[ 20 ], pwdinfo->profileinfo[ pwdinfo->profileindex ].ssidlen );
+				/*	Add this profile information into pwdinfo->profileinfo */
+				/*	Ex:  1XX:XX:XX:XX:XX:XXYYSSID */
+				for (jj = 0, kk = 1; jj < ETH_ALEN; jj++, kk += 3)
+					pwdinfo->profileinfo[pwdinfo->profileindex].peermac[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+				/* pwdinfo->profileinfo[pwdinfo->profileindex].ssidlen = ( extra[18] - '0' ) * 10 + ( extra[19] - '0' ); */
+				/* _rtw_memcpy( pwdinfo->profileinfo[pwdinfo->profileindex].ssid, &extra[20], pwdinfo->profileinfo[pwdinfo->profileindex].ssidlen ); */
 				pwdinfo->profileindex++;
 			}
 		}
-	}	
-	
+	}
+
 	return ret;
-		
+
 }
 
 static int rtw_p2p_setDN(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 
 
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
-	_rtw_memset( pwdinfo->device_name, 0x00, WPS_MAX_DEVICE_NAME_LEN );
-	_rtw_memcpy( pwdinfo->device_name, extra, wrqu->data.length - 1 );
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+	_rtw_memset(pwdinfo->device_name, 0x00, WPS_MAX_DEVICE_NAME_LEN);
+	_rtw_memcpy(pwdinfo->device_name, extra, wrqu->data.length - 1);
 	pwdinfo->device_name_len = wrqu->data.length - 1;
 
 	return ret;
-		
+
 }
 
 
 static int rtw_p2p_get_status(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct wifidirect_info	*pbuddy_wdinfo = &pbuddy_adapter->wdinfo;
-	struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;	
-#endif
-	
-	if ( padapter->bShowGetP2PState )
-	{
-		DBG_871X( "[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
-				pwdinfo->p2p_peer_interface_addr[ 0 ], pwdinfo->p2p_peer_interface_addr[ 1 ], pwdinfo->p2p_peer_interface_addr[ 2 ],
-				pwdinfo->p2p_peer_interface_addr[ 3 ], pwdinfo->p2p_peer_interface_addr[ 4 ], pwdinfo->p2p_peer_interface_addr[ 5 ]);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	if (padapter->bShowGetP2PState) {
+		RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+			pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+			pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
 	}
 
-	//	Commented by Albert 2010/10/12
-	//	Because of the output size limitation, I had removed the "Role" information.
-	//	About the "Role" information, we will use the new private IOCTL to get the "Role" information.
-	sprintf( extra, "\n\nStatus=%.2d\n", rtw_p2p_state(pwdinfo) );
-	wrqu->data.length = strlen( extra );
+	/*	Commented by Albert 2010/10/12 */
+	/*	Because of the output size limitation, I had removed the "Role" information. */
+	/*	About the "Role" information, we will use the new private IOCTL to get the "Role" information. */
+	sprintf(extra, "\n\nStatus=%.2d\n", rtw_p2p_state(pwdinfo));
+	wrqu->data.length = strlen(extra);
 
 	return ret;
-		
+
 }
 
-//	Commented by Albert 20110520
-//	This function will return the config method description 
-//	This config method description will show us which config method the remote P2P device is intented to use
-//	by sending the provisioning discovery request frame.
+/*	Commented by Albert 20110520
+ *	This function will return the config method description
+ *	This config method description will show us which config method the remote P2P device is intented to use
+ *	by sending the provisioning discovery request frame. */
 
 static int rtw_p2p_get_req_cm(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-	sprintf( extra, "\n\nCM=%s\n", pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req );
-	wrqu->data.length = strlen( extra );
+	sprintf(extra, "\n\nCM=%s\n", pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req);
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 
 static int rtw_p2p_get_role(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
 
-	
-	DBG_871X( "[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
-			pwdinfo->p2p_peer_interface_addr[ 0 ], pwdinfo->p2p_peer_interface_addr[ 1 ], pwdinfo->p2p_peer_interface_addr[ 2 ],
-			pwdinfo->p2p_peer_interface_addr[ 3 ], pwdinfo->p2p_peer_interface_addr[ 4 ], pwdinfo->p2p_peer_interface_addr[ 5 ]);
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+		pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
 
-	sprintf( extra, "\n\nRole=%.2d\n", rtw_p2p_role(pwdinfo) );
-	wrqu->data.length = strlen( extra );
+	sprintf(extra, "\n\nRole=%.2d\n", rtw_p2p_role(pwdinfo));
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 
 static int rtw_p2p_get_peer_ifaddr(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				   struct iw_request_info *info,
+				   union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
-	DBG_871X( "[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
-			pwdinfo->p2p_peer_interface_addr[ 0 ], pwdinfo->p2p_peer_interface_addr[ 1 ], pwdinfo->p2p_peer_interface_addr[ 2 ],
-			pwdinfo->p2p_peer_interface_addr[ 3 ], pwdinfo->p2p_peer_interface_addr[ 4 ], pwdinfo->p2p_peer_interface_addr[ 5 ]);
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+		pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
 
-	sprintf( extra, "\nMAC %.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
-			pwdinfo->p2p_peer_interface_addr[ 0 ], pwdinfo->p2p_peer_interface_addr[ 1 ], pwdinfo->p2p_peer_interface_addr[ 2 ],
-			pwdinfo->p2p_peer_interface_addr[ 3 ], pwdinfo->p2p_peer_interface_addr[ 4 ], pwdinfo->p2p_peer_interface_addr[ 5 ]);
-	wrqu->data.length = strlen( extra );
+	sprintf(extra, "\nMAC %.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
+		pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
+		pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get_peer_devaddr(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				    struct iw_request_info *info,
+				    union iwreq_data *wrqu, char *extra)
 
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-
-	DBG_871X( "[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
-			pwdinfo->rx_prov_disc_info.peerDevAddr[ 0 ], pwdinfo->rx_prov_disc_info.peerDevAddr[ 1 ], 
-			pwdinfo->rx_prov_disc_info.peerDevAddr[ 2 ], pwdinfo->rx_prov_disc_info.peerDevAddr[ 3 ],
-			pwdinfo->rx_prov_disc_info.peerDevAddr[ 4 ], pwdinfo->rx_prov_disc_info.peerDevAddr[ 5 ]);
-	sprintf( extra, "\n%.2X%.2X%.2X%.2X%.2X%.2X",
-			pwdinfo->rx_prov_disc_info.peerDevAddr[ 0 ], pwdinfo->rx_prov_disc_info.peerDevAddr[ 1 ], 
-			pwdinfo->rx_prov_disc_info.peerDevAddr[ 2 ], pwdinfo->rx_prov_disc_info.peerDevAddr[ 3 ],
-			pwdinfo->rx_prov_disc_info.peerDevAddr[ 4 ], pwdinfo->rx_prov_disc_info.peerDevAddr[ 5 ]);
-	wrqu->data.length = strlen( extra );	
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->rx_prov_disc_info.peerDevAddr[0], pwdinfo->rx_prov_disc_info.peerDevAddr[1],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[2], pwdinfo->rx_prov_disc_info.peerDevAddr[3],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[4], pwdinfo->rx_prov_disc_info.peerDevAddr[5]);
+	sprintf(extra, "\n%.2X%.2X%.2X%.2X%.2X%.2X",
+		pwdinfo->rx_prov_disc_info.peerDevAddr[0], pwdinfo->rx_prov_disc_info.peerDevAddr[1],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[2], pwdinfo->rx_prov_disc_info.peerDevAddr[3],
+		pwdinfo->rx_prov_disc_info.peerDevAddr[4], pwdinfo->rx_prov_disc_info.peerDevAddr[5]);
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get_peer_devaddr_by_invitation(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
 
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-
-	DBG_871X( "[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
-			pwdinfo->p2p_peer_device_addr[ 0 ], pwdinfo->p2p_peer_device_addr[ 1 ], 
-			pwdinfo->p2p_peer_device_addr[ 2 ], pwdinfo->p2p_peer_device_addr[ 3 ],
-			pwdinfo->p2p_peer_device_addr[ 4 ], pwdinfo->p2p_peer_device_addr[ 5 ]);
-	sprintf( extra, "\nMAC %.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
-			pwdinfo->p2p_peer_device_addr[ 0 ], pwdinfo->p2p_peer_device_addr[ 1 ], 
-			pwdinfo->p2p_peer_device_addr[ 2 ], pwdinfo->p2p_peer_device_addr[ 3 ],
-			pwdinfo->p2p_peer_device_addr[ 4 ], pwdinfo->p2p_peer_device_addr[ 5 ]);
-	wrqu->data.length = strlen( extra );	
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
+		pwdinfo->p2p_peer_device_addr[0], pwdinfo->p2p_peer_device_addr[1],
+		pwdinfo->p2p_peer_device_addr[2], pwdinfo->p2p_peer_device_addr[3],
+		pwdinfo->p2p_peer_device_addr[4], pwdinfo->p2p_peer_device_addr[5]);
+	sprintf(extra, "\nMAC %.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
+		pwdinfo->p2p_peer_device_addr[0], pwdinfo->p2p_peer_device_addr[1],
+		pwdinfo->p2p_peer_device_addr[2], pwdinfo->p2p_peer_device_addr[3],
+		pwdinfo->p2p_peer_device_addr[4], pwdinfo->p2p_peer_device_addr[5]);
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get_groupid(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
 
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-
-	sprintf( extra, "\n%.2X:%.2X:%.2X:%.2X:%.2X:%.2X %s",
-			pwdinfo->groupid_info.go_device_addr[ 0 ], pwdinfo->groupid_info.go_device_addr[ 1 ], 
-			pwdinfo->groupid_info.go_device_addr[ 2 ], pwdinfo->groupid_info.go_device_addr[ 3 ],
-			pwdinfo->groupid_info.go_device_addr[ 4 ], pwdinfo->groupid_info.go_device_addr[ 5 ],
-			pwdinfo->groupid_info.ssid);
-	wrqu->data.length = strlen( extra );	
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+	sprintf(extra, "\n%.2X:%.2X:%.2X:%.2X:%.2X:%.2X %s",
+		pwdinfo->groupid_info.go_device_addr[0], pwdinfo->groupid_info.go_device_addr[1],
+		pwdinfo->groupid_info.go_device_addr[2], pwdinfo->groupid_info.go_device_addr[3],
+		pwdinfo->groupid_info.go_device_addr[4], pwdinfo->groupid_info.go_device_addr[5],
+		pwdinfo->groupid_info.ssid);
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get_op_ch(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
 
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
 
-	
-	DBG_871X( "[%s] Op_ch = %02x\n", __FUNCTION__, pwdinfo->operating_channel);
-	
-	sprintf( extra, "\n\nOp_ch=%.2d\n", pwdinfo->operating_channel );
-	wrqu->data.length = strlen( extra );
+	RTW_INFO("[%s] Op_ch = %02x\n", __FUNCTION__, pwdinfo->operating_channel);
+
+	sprintf(extra, "\n\nOp_ch=%.2d\n", pwdinfo->operating_channel);
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get_wps_configmethod(struct net_device *dev,
-										struct iw_request_info *info,
-										union iwreq_data *wrqu, char *extra, char *subcmd)
-{ 
-	
+					struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 peerMAC[ETH_ALEN] = { 0x00 };
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	_irqL irqL;
-	_list * plist,*phead;
+	_list *plist, *phead;
 	_queue *queue = &(pmlmepriv->scanned_queue);
 	struct wlan_network *pnetwork = NULL;
 	u8 blnMatch = 0;
@@ -5289,12 +4261,12 @@ static int rtw_p2p_get_wps_configmethod(struct net_device *dev,
 	uint attr_contentlen = 0;
 	u8	attr_content_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
 
-	//	Commented by Albert 20110727
-	//	The input data is the MAC address which the application wants to know its WPS config method.
-	//	After knowing its WPS config method, the application can decide the config method for provisioning discovery.
-	//	Format: iwpriv wlanx p2p_get_wpsCM 00:E0:4C:00:00:05
+	/*	Commented by Albert 20110727 */
+	/*	The input data is the MAC address which the application wants to know its WPS config method. */
+	/*	After knowing its WPS config method, the application can decide the config method for provisioning discovery. */
+	/*	Format: iwpriv wlanx p2p_get_wpsCM 00:E0:4C:00:00:05 */
 
-	DBG_871X("[%s] data = %s\n", __FUNCTION__, subcmd);
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
 
 	macstr2num(peerMAC, subcmd);
 
@@ -5303,23 +4275,21 @@ static int rtw_p2p_get_wps_configmethod(struct net_device *dev,
 	phead = get_list_head(queue);
 	plist = get_next(phead);
 
-	while (1)
-	{
-		if (rtw_end_of_queue_search(phead, plist) == _TRUE) break;
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN))
-		{
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
 			u8 *wpsie;
 			uint	wpsie_len = 0;
 
-			//	The mac address is matched.
+			/*	The mac address is matched. */
 
-			if ( (wpsie=rtw_get_wps_ie_from_scan_queue( &pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0])) )
-			{
+			wpsie = rtw_get_wps_ie_from_scan_queue(&pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0]);
+			if (wpsie) {
 				rtw_get_wps_attr_content(wpsie, wpsie_len, WPS_ATTR_CONF_METHOD, (u8 *)&attr_content, &attr_contentlen);
-				if (attr_contentlen)
-				{
+				if (attr_contentlen) {
 					attr_content = be16_to_cpu(attr_content);
 					sprintf(attr_content_str, "\n\nM=%.4d", attr_content);
 					blnMatch = 1;
@@ -5336,83 +4306,81 @@ static int rtw_p2p_get_wps_configmethod(struct net_device *dev,
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	if (!blnMatch)
-	{
 		sprintf(attr_content_str, "\n\nM=0000");
-	}
 
 	wrqu->data.length = strlen(attr_content_str);
 	_rtw_memcpy(extra, attr_content_str, wrqu->data.length);
 
-	return ret; 
-		
+	return ret;
+
 }
 
 #ifdef CONFIG_WFD
 static int rtw_p2p_get_peer_wfd_port(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				     struct iw_request_info *info,
+				     union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-	DBG_871X( "[%s] p2p_state = %d\n", __FUNCTION__, rtw_p2p_state(pwdinfo) );
+	RTW_INFO("[%s] p2p_state = %d\n", __FUNCTION__, rtw_p2p_state(pwdinfo));
 
-	sprintf( extra, "\n\nPort=%d\n", pwdinfo->wfd_info->peer_rtsp_ctrlport );
-	DBG_871X( "[%s] remote port = %d\n", __FUNCTION__, pwdinfo->wfd_info->peer_rtsp_ctrlport );
-	
-	wrqu->data.length = strlen( extra );
+	sprintf(extra, "\n\nPort=%d\n", pwdinfo->wfd_info->peer_rtsp_ctrlport);
+	RTW_INFO("[%s] remote port = %d\n", __FUNCTION__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
+
+	wrqu->data.length = strlen(extra);
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get_peer_wfd_preferred_connection(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-	sprintf( extra, "\n\nwfd_pc=%d\n", pwdinfo->wfd_info->wfd_pc );
-	DBG_871X( "[%s] wfd_pc = %d\n", __FUNCTION__, pwdinfo->wfd_info->wfd_pc );
+	sprintf(extra, "\n\nwfd_pc=%d\n", pwdinfo->wfd_info->wfd_pc);
+	RTW_INFO("[%s] wfd_pc = %d\n", __FUNCTION__, pwdinfo->wfd_info->wfd_pc);
 
-	wrqu->data.length = strlen( extra );
-	pwdinfo->wfd_info->wfd_pc = _FALSE;	//	Reset the WFD preferred connection to P2P
+	wrqu->data.length = strlen(extra);
+	pwdinfo->wfd_info->wfd_pc = _FALSE;	/*	Reset the WFD preferred connection to P2P */
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get_peer_wfd_session_available(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-	sprintf( extra, "\n\nwfd_sa=%d\n", pwdinfo->wfd_info->peer_session_avail );
-	DBG_871X( "[%s] wfd_sa = %d\n", __FUNCTION__, pwdinfo->wfd_info->peer_session_avail );
+	sprintf(extra, "\n\nwfd_sa=%d\n", pwdinfo->wfd_info->peer_session_avail);
+	RTW_INFO("[%s] wfd_sa = %d\n", __FUNCTION__, pwdinfo->wfd_info->peer_session_avail);
 
-	wrqu->data.length = strlen( extra );
-	pwdinfo->wfd_info->peer_session_avail = _TRUE;	//	Reset the WFD session available
+	wrqu->data.length = strlen(extra);
+	pwdinfo->wfd_info->peer_session_avail = _TRUE;	/*	Reset the WFD session available */
 	return ret;
-		
+
 }
 #endif /* CONFIG_WFD */
 
 static int rtw_p2p_get_go_device_address(struct net_device *dev,
-										 struct iw_request_info *info,
-										 union iwreq_data *wrqu, char *extra, char *subcmd)
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra, char *subcmd)
 {
 
-	int ret = 0;	
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 peerMAC[ETH_ALEN] = { 0x00 };
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
@@ -5426,11 +4394,11 @@ static int rtw_p2p_get_go_device_address(struct net_device *dev,
 	u8 attr_content[100] = { 0x00 };
 	u8 go_devadd_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
 
-	//	Commented by Albert 20121209
-	//	The input data is the GO's interface address which the application wants to know its device address.
-	//	Format: iwpriv wlanx p2p_get2 go_devadd=00:E0:4C:00:00:05
+	/*	Commented by Albert 20121209 */
+	/*	The input data is the GO's interface address which the application wants to know its device address. */
+	/*	Format: iwpriv wlanx p2p_get2 go_devadd=00:E0:4C:00:00:05 */
 
-	DBG_871X("[%s] data = %s\n", __FUNCTION__, subcmd);
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
 
 	macstr2num(peerMAC, subcmd);
 
@@ -5439,39 +4407,35 @@ static int rtw_p2p_get_go_device_address(struct net_device *dev,
 	phead = get_list_head(queue);
 	plist = get_next(phead);
 
-	while (1)
-	{
-		if (rtw_end_of_queue_search(phead, plist) == _TRUE) break;
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN))
-		{
-			//	Commented by Albert 2011/05/18
-			//	Match the device address located in the P2P IE
-			//	This is for the case that the P2P device address is not the same as the P2P interface address.
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			/*	Commented by Albert 2011/05/18 */
+			/*	Match the device address located in the P2P IE */
+			/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
 
 			p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
 			if (p2pie) {
-				while (p2pie)
-				{
-					//	The P2P Device ID attribute is included in the Beacon frame.
-					//	The P2P Device Info attribute is included in the probe response frame.
+				while (p2pie) {
+					/*	The P2P Device ID attribute is included in the Beacon frame. */
+					/*	The P2P Device Info attribute is included in the probe response frame. */
 
 					_rtw_memset(attr_content, 0x00, 100);
-					if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen))
-					{
-						//	Handle the P2P Device ID attribute of Beacon first
+					if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+						/*	Handle the P2P Device ID attribute of Beacon first */
 						blnMatch = 1;
 						break;
 
-					} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen))
-					{
-						//	Handle the P2P Device Info attribute of probe response
+					} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+						/*	Handle the P2P Device Info attribute of probe response */
 						blnMatch = 1;
 						break;
 					}
 
-					//Get the next P2P IE
+					/* Get the next P2P IE */
 					p2pie = rtw_get_p2p_ie(p2pie + p2pielen, BSS_EX_TLV_IES_LEN(&pnetwork->network) - (p2pie + p2pielen - BSS_EX_TLV_IES(&pnetwork->network)), NULL, &p2pielen);
 				}
 			}
@@ -5484,26 +4448,24 @@ static int rtw_p2p_get_go_device_address(struct net_device *dev,
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	if (!blnMatch)
-	{
 		sprintf(go_devadd_str, "\n\ndev_add=NULL");
-	} else
-	{
+	else {
 		sprintf(go_devadd_str, "\n\ndev_add=%.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
-				attr_content[0], attr_content[1], attr_content[2], attr_content[3], attr_content[4], attr_content[5]);
+			attr_content[0], attr_content[1], attr_content[2], attr_content[3], attr_content[4], attr_content[5]);
 	}
 
 	wrqu->data.length = strlen(go_devadd_str);
 	_rtw_memcpy(extra, go_devadd_str, wrqu->data.length);
 
-	return ret; 
-		
+	return ret;
+
 }
 
 static int rtw_p2p_get_device_type(struct net_device *dev,
-								   struct iw_request_info *info,
-								   union iwreq_data *wrqu, char *extra, char *subcmd)
-{ 
-	
+				   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 peerMAC[ETH_ALEN] = { 0x00 };
@@ -5515,14 +4477,14 @@ static int rtw_p2p_get_device_type(struct net_device *dev,
 	u8 blnMatch = 0;
 	u8 dev_type[8] = { 0x00 };
 	uint dev_type_len = 0;
-	u8 dev_type_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };    // +9 is for the str "dev_type=", we have to clear it at wrqu->data.pointer
+	u8 dev_type_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };    /* +9 is for the str "dev_type=", we have to clear it at wrqu->data.pointer */
 
-	//	Commented by Albert 20121209
-	//	The input data is the MAC address which the application wants to know its device type.
-	//	Such user interface could know the device type.
-	//	Format: iwpriv wlanx p2p_get2 dev_type=00:E0:4C:00:00:05
+	/*	Commented by Albert 20121209 */
+	/*	The input data is the MAC address which the application wants to know its device type. */
+	/*	Such user interface could know the device type. */
+	/*	Format: iwpriv wlanx p2p_get2 dev_type=00:E0:4C:00:00:05 */
 
-	DBG_871X("[%s] data = %s\n", __FUNCTION__, subcmd);
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
 
 	macstr2num(peerMAC, subcmd);
 
@@ -5531,23 +4493,21 @@ static int rtw_p2p_get_device_type(struct net_device *dev,
 	phead = get_list_head(queue);
 	plist = get_next(phead);
 
-	while (1)
-	{
-		if (rtw_end_of_queue_search(phead, plist) == _TRUE) break;
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN))
-		{
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
 			u8 *wpsie;
 			uint	wpsie_len = 0;
 
-			//	The mac address is matched.
+			/*	The mac address is matched. */
 
-			if ( (wpsie=rtw_get_wps_ie_from_scan_queue( &pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0])) )
-			{
+			wpsie = rtw_get_wps_ie_from_scan_queue(&pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0]);
+			if (wpsie) {
 				rtw_get_wps_attr_content(wpsie, wpsie_len, WPS_ATTR_PRIMARY_DEV_TYPE, dev_type, &dev_type_len);
-				if (dev_type_len)
-				{
+				if (dev_type_len) {
 					u16	type = 0;
 
 					_rtw_memcpy(&type, dev_type, 2);
@@ -5566,22 +4526,20 @@ static int rtw_p2p_get_device_type(struct net_device *dev,
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	if (!blnMatch)
-	{
 		sprintf(dev_type_str, "\n\nN=00");
-	}
 
 	wrqu->data.length = strlen(dev_type_str);
 	_rtw_memcpy(extra, dev_type_str, wrqu->data.length);
 
-	return ret; 
-		
+	return ret;
+
 }
 
 static int rtw_p2p_get_device_name(struct net_device *dev,
-								   struct iw_request_info *info,
-								   union iwreq_data *wrqu, char *extra, char *subcmd)
-{ 
-	
+				   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra, char *subcmd)
+{
+
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 peerMAC[ETH_ALEN] = { 0x00 };
@@ -5595,12 +4553,12 @@ static int rtw_p2p_get_device_name(struct net_device *dev,
 	uint dev_len = 0;
 	u8 dev_name_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
 
-	//	Commented by Albert 20121225
-	//	The input data is the MAC address which the application wants to know its device name.
-	//	Such user interface could show peer device's device name instead of ssid.
-	//	Format: iwpriv wlanx p2p_get2 devN=00:E0:4C:00:00:05
+	/*	Commented by Albert 20121225 */
+	/*	The input data is the MAC address which the application wants to know its device name. */
+	/*	Such user interface could show peer device's device name instead of ssid. */
+	/*	Format: iwpriv wlanx p2p_get2 devN=00:E0:4C:00:00:05 */
 
-	DBG_871X("[%s] data = %s\n", __FUNCTION__, subcmd);
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
 
 	macstr2num(peerMAC, subcmd);
 
@@ -5609,23 +4567,21 @@ static int rtw_p2p_get_device_name(struct net_device *dev,
 	phead = get_list_head(queue);
 	plist = get_next(phead);
 
-	while (1)
-	{
-		if (rtw_end_of_queue_search(phead, plist) == _TRUE) break;
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN))
-		{
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
 			u8 *wpsie;
 			uint	wpsie_len = 0;
 
-			//	The mac address is matched.
+			/*	The mac address is matched. */
 
-			if ( (wpsie=rtw_get_wps_ie_from_scan_queue( &pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0])) )
-			{
+			wpsie = rtw_get_wps_ie_from_scan_queue(&pnetwork->network.IEs[0], pnetwork->network.IELength, NULL, &wpsie_len, pnetwork->network.Reserved[0]);
+			if (wpsie) {
 				rtw_get_wps_attr_content(wpsie, wpsie_len, WPS_ATTR_DEVICE_NAME, dev_name, &dev_len);
-				if (dev_len)
-				{
+				if (dev_len) {
 					sprintf(dev_name_str, "\n\nN=%s", dev_name);
 					blnMatch = 1;
 				}
@@ -5640,23 +4596,21 @@ static int rtw_p2p_get_device_name(struct net_device *dev,
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	if (!blnMatch)
-	{
 		sprintf(dev_name_str, "\n\nN=0000");
-	}
 
 	wrqu->data.length = strlen(dev_name_str);
 	_rtw_memcpy(extra, dev_name_str, wrqu->data.length);
 
-	return ret; 
-		
+	return ret;
+
 }
 
 static int rtw_p2p_get_invitation_procedure(struct net_device *dev,
-											struct iw_request_info *info,
-											union iwreq_data *wrqu, char *extra, char *subcmd)
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra, char *subcmd)
 {
 
-	int ret = 0;	
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 peerMAC[ETH_ALEN] = { 0x00 };
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
@@ -5670,11 +4624,11 @@ static int rtw_p2p_get_invitation_procedure(struct net_device *dev,
 	u8 attr_content[2] = { 0x00 };
 	u8 inv_proc_str[P2P_PRIVATE_IOCTL_SET_LEN] = { 0x00 };
 
-	//	Commented by Ouden 20121226
-	//	The application wants to know P2P initation procedure is support or not.
-	//	Format: iwpriv wlanx p2p_get2 InvProc=00:E0:4C:00:00:05
+	/*	Commented by Ouden 20121226 */
+	/*	The application wants to know P2P initation procedure is support or not. */
+	/*	Format: iwpriv wlanx p2p_get2 InvProc=00:E0:4C:00:00:05 */
 
-	DBG_871X("[%s] data = %s\n", __FUNCTION__, subcmd);
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, subcmd);
 
 	macstr2num(peerMAC, subcmd);
 
@@ -5683,31 +4637,28 @@ static int rtw_p2p_get_invitation_procedure(struct net_device *dev,
 	phead = get_list_head(queue);
 	plist = get_next(phead);
 
-	while (1)
-	{
-		if (rtw_end_of_queue_search(phead, plist) == _TRUE) break;
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
+			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN))
-		{
-			//	Commented by Albert 20121226
-			//	Match the device address located in the P2P IE
-			//	This is for the case that the P2P device address is not the same as the P2P interface address.
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
+			/*	Commented by Albert 20121226 */
+			/*	Match the device address located in the P2P IE */
+			/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
 
 			p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
 			if (p2pie) {
-				while (p2pie)
-				{
-					//_rtw_memset( attr_content, 0x00, 2);
-					if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_CAPABILITY, attr_content, &attr_contentlen))
-					{
-						//	Handle the P2P capability attribute
+				while (p2pie) {
+					/* _rtw_memset( attr_content, 0x00, 2); */
+					if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_CAPABILITY, attr_content, &attr_contentlen)) {
+						/*	Handle the P2P capability attribute */
 						blnMatch = 1;
 						break;
 
 					}
 
-					//Get the next P2P IE
+					/* Get the next P2P IE */
 					p2pie = rtw_get_p2p_ie(p2pie + p2pielen, BSS_EX_TLV_IES_LEN(&pnetwork->network) - (p2pie + p2pielen - BSS_EX_TLV_IES(&pnetwork->network)), NULL, &p2pielen);
 				}
 			}
@@ -5720,10 +4671,8 @@ static int rtw_p2p_get_invitation_procedure(struct net_device *dev,
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	if (!blnMatch)
-	{
 		sprintf(inv_proc_str, "\nIP=-1");
-	} else
-	{
+	else {
 		if ((attr_content[0] & 0x20) == 0x20)
 			sprintf(inv_proc_str, "\nIP=1");
 		else
@@ -5733,278 +4682,240 @@ static int rtw_p2p_get_invitation_procedure(struct net_device *dev,
 	wrqu->data.length = strlen(inv_proc_str);
 	_rtw_memcpy(extra, inv_proc_str, wrqu->data.length);
 
-	return ret; 
-		
+	return ret;
+
 }
 
 static int rtw_p2p_connect(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	_adapter 				*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-	u8					peerMAC[ ETH_ALEN ] = { 0x00 };
-	int 					jj,kk;
-	u8   					peerMACStr[ ETH_ALEN * 2 ] = { 0x00 };
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					peerMAC[ETH_ALEN] = { 0x00 };
+	int					jj, kk;
+	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	_irqL				irqL;
 	_list					*plist, *phead;
 	_queue				*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
 	uint					uintPeerChannel = 0;
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif // CONFIG_CONCURRENT_MODE	
 
-	//	Commented by Albert 20110304
-	//	The input data contains two informations.
-	//	1. First information is the MAC address which wants to formate with
-	//	2. Second information is the WPS PINCode or "pbc" string for push button method
-	//	Format: 00:E0:4C:00:00:05
-	//	Format: 00:E0:4C:00:00:05
+	/*	Commented by Albert 20110304 */
+	/*	The input data contains two informations. */
+	/*	1. First information is the MAC address which wants to formate with */
+	/*	2. Second information is the WPS PINCode or "pbc" string for push button method */
+	/*	Format: 00:E0:4C:00:00:05 */
+	/*	Format: 00:E0:4C:00:00:05 */
 
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
 
-	if ( pwdinfo->p2p_state == P2P_STATE_NONE )
-	{
-		DBG_871X( "[%s] WiFi Direct is disable!\n", __FUNCTION__ );
+	if (pwdinfo->p2p_state == P2P_STATE_NONE) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
 		return ret;
 	}
 
 #ifdef CONFIG_INTEL_WIDI
 	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
-		DBG_871X( "[%s] WiFi is under survey!\n", __FUNCTION__ );
+		RTW_INFO("[%s] WiFi is under survey!\n", __FUNCTION__);
 		return ret;
 	}
-#endif //CONFIG_INTEL_WIDI	
+#endif /* CONFIG_INTEL_WIDI	 */
 
-	if ( pwdinfo->ui_got_wps_info == P2P_NO_WPSINFO )
-	{
+	if (pwdinfo->ui_got_wps_info == P2P_NO_WPSINFO)
 		return -1;
-	}
-	
-	for( jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3 )
-	{
-		peerMAC[ jj ] = key_2char2num( extra[kk], extra[kk+ 1] );
-	}
+
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		peerMAC[jj] = key_2char2num(extra[kk], extra[kk + 1]);
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	phead = get_list_head(queue);
 	plist = get_next(phead);
-       
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
-		if ( _rtw_memcmp( pnetwork->network.MacAddress, peerMAC, ETH_ALEN ) )
-		{
+		if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
 			if (pnetwork->network.Configuration.DSConfig != 0)
 				uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 			else if (pwdinfo->nego_req_info.peer_ch != 0)
 				uintPeerChannel = pnetwork->network.Configuration.DSConfig = pwdinfo->nego_req_info.peer_ch;
-			else{
+			else {
 				/* Unexpected case */
 				uintPeerChannel = 0;
-				DBG_871X("%s  uintPeerChannel = 0\n", __func__);
+				RTW_INFO("%s  uintPeerChannel = 0\n", __func__);
 			}
 			break;
 		}
 
 		plist = get_next(plist);
-	
+
 	}
 
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-	if ( uintPeerChannel )
-	{
+	if (uintPeerChannel) {
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			_cancel_timer_ex( &pwdinfo->ap_p2p_switch_timer );
-		}
-#endif // CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif /* CONFIG_CONCURRENT_MODE */
+
+		_rtw_memset(&pwdinfo->nego_req_info, 0x00, sizeof(struct tx_nego_req_info));
+		_rtw_memset(&pwdinfo->groupid_info, 0x00, sizeof(struct group_id_info));
 
-		_rtw_memset( &pwdinfo->nego_req_info, 0x00, sizeof( struct tx_nego_req_info ) );
-		_rtw_memset( &pwdinfo->groupid_info, 0x00, sizeof( struct group_id_info ) );
-		
-		pwdinfo->nego_req_info.peer_channel_num[ 0 ] = uintPeerChannel;
-		_rtw_memcpy( pwdinfo->nego_req_info.peerDevAddr, pnetwork->network.MacAddress, ETH_ALEN );
+		pwdinfo->nego_req_info.peer_channel_num[0] = uintPeerChannel;
+		_rtw_memcpy(pwdinfo->nego_req_info.peerDevAddr, pnetwork->network.MacAddress, ETH_ALEN);
 		pwdinfo->nego_req_info.benable = _TRUE;
 
-		_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
-		if ( rtw_p2p_state(pwdinfo) != P2P_STATE_GONEGO_OK )
-		{
-			//	Restore to the listen state if the current p2p state is not nego OK
-			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN );
+		_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+		if (rtw_p2p_state(pwdinfo) != P2P_STATE_GONEGO_OK) {
+			/*	Restore to the listen state if the current p2p state is not nego OK */
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
 		}
 
 		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_ING);
 
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			//	Have to enter the power saving with the AP
-			set_channel_bwmode(padapter, pbuddy_mlmeext->cur_channel, pbuddy_mlmeext->cur_ch_offset, pbuddy_mlmeext->cur_bwmode);
-			
-			issue_nulldata(pbuddy_adapter, NULL, 1, 3, 500);
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
+			u8 union_bw = rtw_mi_get_union_bw(padapter);
+			u8 union_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_leave_opch(padapter);
 		}
-#endif // CONFIG_CONCURRENT_MODE
+#endif /* CONFIG_CONCURRENT_MODE */
 
-		DBG_871X( "[%s] Start PreTx Procedure!\n", __FUNCTION__ );
-		_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
+		RTW_INFO("[%s] Start PreTx Procedure!\n", __FUNCTION__);
+		_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_GO_NEGO_TIMEOUT );
-		}
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_GO_NEGO_TIMEOUT);
 		else
-		{
-			_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_GO_NEGO_TIMEOUT );
-		}
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_GO_NEGO_TIMEOUT);
 #else
-		_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_GO_NEGO_TIMEOUT );
-#endif // CONFIG_CONCURRENT_MODE		
+		_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_GO_NEGO_TIMEOUT);
+#endif /* CONFIG_CONCURRENT_MODE		 */
 
-	}
-	else
-	{
-		DBG_871X( "[%s] Not Found in Scanning Queue~\n", __FUNCTION__ );
+	} else {
+		RTW_INFO("[%s] Not Found in Scanning Queue~\n", __FUNCTION__);
 #ifdef CONFIG_INTEL_WIDI
-		_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
+		_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
 		rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
 		rtw_free_network_queue(padapter, _TRUE);
-		/** 
+		/**
 		 * For WiDi, if we can't find candidate device in scanning queue,
 		 * driver will do scanning itself
 		 */
 		_enter_critical_bh(&pmlmepriv->lock, &irqL);
-		rtw_sitesurvey_cmd(padapter, NULL, 0, NULL, 0);
+		rtw_sitesurvey_cmd(padapter, NULL);
 		_exit_critical_bh(&pmlmepriv->lock, &irqL);
-#endif //CONFIG_INTEL_WIDI 
+#endif /* CONFIG_INTEL_WIDI */
 		ret = -1;
 	}
-exit:	
+exit:
 	return ret;
 }
 
 static int rtw_p2p_invite_req(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	_adapter 					*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct iw_point 			*pdata = &wrqu->data;
-	struct wifidirect_info		*pwdinfo = &( padapter->wdinfo );
-	int 						jj,kk;
-	u8   						peerMACStr[ ETH_ALEN * 2 ] = { 0x00 };
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
+	int						jj, kk;
+	u8						peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
 	_list						*plist, *phead;
 	_queue					*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network		*pnetwork = NULL;
 	uint						uintPeerChannel = 0;
 	u8						attr_content[50] = { 0x00 }, _status = 0;
-	u8 						*p2pie;
+	u8						*p2pie;
 	uint						p2pielen = 0, attr_contentlen = 0;
 	_irqL					irqL;
-	struct tx_invite_req_info*	pinvite_req_info = &pwdinfo->invitereq_info;
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter					*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_priv			*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv		*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif // CONFIG_CONCURRENT_MODE
-	
-	//	Commented by Albert 20120321
-	//	The input data contains two informations.
-	//	1. First information is the P2P device address which you want to send to.	
-	//	2. Second information is the group id which combines with GO's mac address, space and GO's ssid.
-	//	Command line sample: iwpriv wlan0 p2p_set invite="00:11:22:33:44:55 00:E0:4C:00:00:05 DIRECT-xy"
-	//	Format: 00:11:22:33:44:55 00:E0:4C:00:00:05 DIRECT-xy
-
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
-
-	if ( wrqu->data.length <=  37 )
-	{
-		DBG_871X( "[%s] Wrong format!\n", __FUNCTION__ );
+	struct tx_invite_req_info	*pinvite_req_info = &pwdinfo->invitereq_info;
+
+	/*	Commented by Albert 20120321 */
+	/*	The input data contains two informations. */
+	/*	1. First information is the P2P device address which you want to send to.	 */
+	/*	2. Second information is the group id which combines with GO's mac address, space and GO's ssid. */
+	/*	Command line sample: iwpriv wlan0 p2p_set invite="00:11:22:33:44:55 00:E0:4C:00:00:05 DIRECT-xy" */
+	/*	Format: 00:11:22:33:44:55 00:E0:4C:00:00:05 DIRECT-xy */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (wrqu->data.length <=  37) {
+		RTW_INFO("[%s] Wrong format!\n", __FUNCTION__);
 		return ret;
 	}
 
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
-		DBG_871X( "[%s] WiFi Direct is disable!\n", __FUNCTION__ );
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
 		return ret;
-	}
-	else
-	{
-		//	Reset the content of struct tx_invite_req_info
+	} else {
+		/*	Reset the content of struct tx_invite_req_info */
 		pinvite_req_info->benable = _FALSE;
-		_rtw_memset( pinvite_req_info->go_bssid, 0x00, ETH_ALEN );
-		_rtw_memset( pinvite_req_info->go_ssid, 0x00, WLAN_SSID_MAXLEN );
+		_rtw_memset(pinvite_req_info->go_bssid, 0x00, ETH_ALEN);
+		_rtw_memset(pinvite_req_info->go_ssid, 0x00, WLAN_SSID_MAXLEN);
 		pinvite_req_info->ssidlen = 0x00;
 		pinvite_req_info->operating_ch = pwdinfo->operating_channel;
-		_rtw_memset( pinvite_req_info->peer_macaddr, 0x00, ETH_ALEN );
+		_rtw_memset(pinvite_req_info->peer_macaddr, 0x00, ETH_ALEN);
 		pinvite_req_info->token = 3;
 	}
-	
-	for( jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3 )
-	{
-		pinvite_req_info->peer_macaddr[ jj ] = key_2char2num( extra[kk], extra[kk+ 1] );
-	}
+
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		pinvite_req_info->peer_macaddr[jj] = key_2char2num(extra[kk], extra[kk + 1]);
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	phead = get_list_head(queue);
 	plist = get_next(phead);
-       
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
 
-		//	Commented by Albert 2011/05/18
-		//	Match the device address located in the P2P IE
-		//	This is for the case that the P2P device address is not the same as the P2P interface address.
+		/*	Commented by Albert 2011/05/18 */
+		/*	Match the device address located in the P2P IE */
+		/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
 
 		p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
 		if (p2pie) {
-			//	The P2P Device ID attribute is included in the Beacon frame.
-			//	The P2P Device Info attribute is included in the probe response frame.
+			/*	The P2P Device ID attribute is included in the Beacon frame. */
+			/*	The P2P Device Info attribute is included in the probe response frame. */
 
-			if ( rtw_get_p2p_attr_content( p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen) )
-			{
-				//	Handle the P2P Device ID attribute of Beacon first
-				if ( _rtw_memcmp( attr_content, pinvite_req_info->peer_macaddr, ETH_ALEN ) )
-				{
+			if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device ID attribute of Beacon first */
+				if (_rtw_memcmp(attr_content, pinvite_req_info->peer_macaddr, ETH_ALEN)) {
 					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 					break;
 				}
-			}
-			else if ( rtw_get_p2p_attr_content( p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen) )
-			{
-				//	Handle the P2P Device Info attribute of probe response
-				if ( _rtw_memcmp( attr_content, pinvite_req_info->peer_macaddr, ETH_ALEN ) )
-				{
+			} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device Info attribute of probe response */
+				if (_rtw_memcmp(attr_content, pinvite_req_info->peer_macaddr, ETH_ALEN)) {
 					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 					break;
-				}					
+				}
 			}
 
 		}
 
 		plist = get_next(plist);
-	
+
 	}
 
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
@@ -6020,52 +4931,42 @@ static int rtw_p2p_invite_req(struct net_device *dev,
 			u8 *wfd_devinfo;
 			uint wfd_devlen;
 
-			DBG_871X( "[%s] Found WFD IE!\n", __FUNCTION__ );
+			RTW_INFO("[%s] Found WFD IE!\n", __FUNCTION__);
 			wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
 			if (wfd_devinfo) {
 				u16	wfd_devinfo_field = 0;
-				
-				//	Commented by Albert 20120319
-				//	The first two bytes are the WFD device information field of WFD device information subelement.
-				//	In big endian format.
+
+				/*	Commented by Albert 20120319 */
+				/*	The first two bytes are the WFD device information field of WFD device information subelement. */
+				/*	In big endian format. */
 				wfd_devinfo_field = RTW_GET_BE16(wfd_devinfo);
-				if ( wfd_devinfo_field & WFD_DEVINFO_SESSION_AVAIL )
-				{
+				if (wfd_devinfo_field & WFD_DEVINFO_SESSION_AVAIL)
 					pwfd_info->peer_session_avail = _TRUE;
-				}
 				else
-				{
 					pwfd_info->peer_session_avail = _FALSE;
-				}
 			}
 		}
-		
-		if ( _FALSE == pwfd_info->peer_session_avail )
-		{
-			DBG_871X( "[%s] WFD Session not avaiable!\n", __FUNCTION__ );
+
+		if (_FALSE == pwfd_info->peer_session_avail) {
+			RTW_INFO("[%s] WFD Session not avaiable!\n", __FUNCTION__);
 			goto exit;
 		}
 	}
 #endif /* CONFIG_WFD */
 
-	if ( uintPeerChannel )
-	{
+	if (uintPeerChannel) {
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			_cancel_timer_ex( &pwdinfo->ap_p2p_switch_timer );
-		}
-#endif // CONFIG_CONCURRENT_MODE
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif /* CONFIG_CONCURRENT_MODE */
 
-		//	Store the GO's bssid
-		for( jj = 0, kk = 18; jj < ETH_ALEN; jj++, kk += 3 )
-		{
-			pinvite_req_info->go_bssid[ jj ] = key_2char2num( extra[kk], extra[kk+ 1] );
-		}
+		/*	Store the GO's bssid */
+		for (jj = 0, kk = 18; jj < ETH_ALEN; jj++, kk += 3)
+			pinvite_req_info->go_bssid[jj] = key_2char2num(extra[kk], extra[kk + 1]);
 
-		//	Store the GO's ssid
+		/*	Store the GO's ssid */
 		pinvite_req_info->ssidlen = wrqu->data.length - 36;
-		_rtw_memcpy( pinvite_req_info->go_ssid, &extra[ 36 ], (u32) pinvite_req_info->ssidlen );
+		_rtw_memcpy(pinvite_req_info->go_ssid, &extra[36], (u32) pinvite_req_info->ssidlen);
 		pinvite_req_info->benable = _TRUE;
 		pinvite_req_info->peer_ch = uintPeerChannel;
 
@@ -6073,125 +4974,86 @@ static int rtw_p2p_invite_req(struct net_device *dev,
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_TX_INVITE_REQ);
 
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			//	Have to enter the power saving with the AP
-			set_channel_bwmode(padapter, pbuddy_mlmeext->cur_channel, pbuddy_mlmeext->cur_ch_offset, pbuddy_mlmeext->cur_bwmode);
-			
-			issue_nulldata(pbuddy_adapter, NULL, 1, 3, 500);
-		}
-		else
-		{
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
+			u8 union_bw = rtw_mi_get_union_bw(padapter);
+			u8 union_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_leave_opch(padapter);
+
+		} else
 			set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-		}
 #else
 		set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-#endif
+#endif/*CONFIG_CONCURRENT_MODE*/
+
+		_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
 
-		_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-		
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_INVITE_TIMEOUT );
-		}
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_INVITE_TIMEOUT);
 		else
-		{
-			_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_INVITE_TIMEOUT );
-		}
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_INVITE_TIMEOUT);
 #else
-		_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_INVITE_TIMEOUT );
-#endif // CONFIG_CONCURRENT_MODE		
+		_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_INVITE_TIMEOUT);
+#endif /* CONFIG_CONCURRENT_MODE		 */
 
-		
-	}
-	else
-	{
-		DBG_871X( "[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__ );
-	}
+
+	} else
+		RTW_INFO("[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__);
 exit:
-	
+
 	return ret;
-		
+
 }
 
 static int rtw_p2p_set_persistent(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	_adapter 					*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct iw_point 			*pdata = &wrqu->data;
-	struct wifidirect_info		*pwdinfo = &( padapter->wdinfo );
-	int 						jj,kk;
-	u8   						peerMACStr[ ETH_ALEN * 2 ] = { 0x00 };
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
+	int						jj, kk;
+	u8						peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
 	_list						*plist, *phead;
 	_queue					*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network		*pnetwork = NULL;
 	uint						uintPeerChannel = 0;
 	u8						attr_content[50] = { 0x00 }, _status = 0;
-	u8 						*p2pie;
+	u8						*p2pie;
 	uint						p2pielen = 0, attr_contentlen = 0;
 	_irqL					irqL;
-	struct tx_invite_req_info*	pinvite_req_info = &pwdinfo->invitereq_info;
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter					*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_priv			*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv		*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif // CONFIG_CONCURRENT_MODE
-	
-	//	Commented by Albert 20120328
-	//	The input data is 0 or 1
-	//	0: disable persistent group functionality
-	//	1: enable persistent group founctionality
-	
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
-
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
-		DBG_871X( "[%s] WiFi Direct is disable!\n", __FUNCTION__ );
+	struct tx_invite_req_info	*pinvite_req_info = &pwdinfo->invitereq_info;
+
+	/*	Commented by Albert 20120328 */
+	/*	The input data is 0 or 1 */
+	/*	0: disable persistent group functionality */
+	/*	1: enable persistent group founctionality */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
 		return ret;
-	}
-	else
-	{
-		if ( extra[ 0 ] == '0' )	//	Disable the persistent group function.
-		{
+	} else {
+		if (extra[0] == '0')	/*	Disable the persistent group function. */
 			pwdinfo->persistent_supported = _FALSE;
-		}
-		else if ( extra[ 0 ] == '1' )	//	Enable the persistent group function.
-		{
+		else if (extra[0] == '1')	/*	Enable the persistent group function. */
 			pwdinfo->persistent_supported = _TRUE;
-		}
 		else
-		{
 			pwdinfo->persistent_supported = _FALSE;
-		}
 	}
-	printk( "[%s] persistent_supported = %d\n", __FUNCTION__, pwdinfo->persistent_supported );
-	
+	printk("[%s] persistent_supported = %d\n", __FUNCTION__, pwdinfo->persistent_supported);
+
 exit:
-	
-	return ret;
-		
-}
 
-static int hexstr2bin(const char *hex, u8 *buf, size_t len)
-{
-	size_t i;
-	int a;
-	const char *ipos = hex;
-	u8 *opos = buf;
+	return ret;
 
-	for (i = 0; i < len; i++) {
-		a = hex2byte_i(ipos);
-		if (a < 0)
-			return -1;
-		*opos++ = a;
-		ipos += 2;
-	}
-	return 0;
 }
 
 static int uuid_str2bin(const char *str, u8 *bin)
@@ -6229,20 +5091,19 @@ static int uuid_str2bin(const char *str, u8 *bin)
 }
 
 static int rtw_p2p_set_wps_uuid(struct net_device *dev,
-	struct iw_request_info *info,
-	union iwreq_data *wrqu, char *extra)
+				struct iw_request_info *info,
+				union iwreq_data *wrqu, char *extra)
 {
 
 	int ret = 0;
 	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct wifidirect_info			*pwdinfo = &(padapter->wdinfo);
 
-	DBG_871X("[%s] data = %s\n", __FUNCTION__, extra);
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
 
-	if ((36 == strlen(extra)) && (uuid_str2bin(extra, pwdinfo->uuid) == 0)) 
-	{
+	if ((36 == strlen(extra)) && (uuid_str2bin(extra, pwdinfo->uuid) == 0))
 		pwdinfo->external_uuid = 1;
-	} else {
+	else {
 		pwdinfo->external_uuid = 0;
 		ret = -EINVAL;
 	}
@@ -6252,17 +5113,17 @@ static int rtw_p2p_set_wps_uuid(struct net_device *dev,
 }
 #ifdef CONFIG_WFD
 static int rtw_p2p_set_pc(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	_adapter 				*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct iw_point 		*pdata = &wrqu->data;
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-	u8					peerMAC[ ETH_ALEN ] = { 0x00 };
-	int 					jj,kk;
-	u8   					peerMACStr[ ETH_ALEN * 2 ] = { 0x00 };
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point		*pdata = &wrqu->data;
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					peerMAC[ETH_ALEN] = { 0x00 };
+	int					jj, kk;
+	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	_list					*plist, *phead;
 	_queue				*queue	= &(pmlmepriv->scanned_queue);
@@ -6272,83 +5133,69 @@ static int rtw_p2p_set_pc(struct net_device *dev,
 	uint					p2pielen = 0, attr_contentlen = 0;
 	_irqL				irqL;
 	uint					uintPeerChannel = 0;
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif // CONFIG_CONCURRENT_MODE	
-	
-	struct wifi_display_info*	pwfd_info = pwdinfo->wfd_info;
-	
-	//	Commented by Albert 20120512
-	//	1. Input information is the MAC address which wants to know the Preferred Connection bit (PC bit)
-	//	Format: 00:E0:4C:00:00:05
-
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
-
-	if(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-	{
-		DBG_871X( "[%s] WiFi Direct is disable!\n", __FUNCTION__ );
+
+	struct wifi_display_info	*pwfd_info = pwdinfo->wfd_info;
+
+	/*	Commented by Albert 20120512 */
+	/*	1. Input information is the MAC address which wants to know the Preferred Connection bit (PC bit) */
+	/*	Format: 00:E0:4C:00:00:05 */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
 		return ret;
 	}
-	
-	for( jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3 )
-	{
-		peerMAC[ jj ] = key_2char2num( extra[kk], extra[kk+ 1] );
-	}
+
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		peerMAC[jj] = key_2char2num(extra[kk], extra[kk + 1]);
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	phead = get_list_head(queue);
 	plist = get_next(phead);
-       
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
 
-		//	Commented by Albert 2011/05/18
-		//	Match the device address located in the P2P IE
-		//	This is for the case that the P2P device address is not the same as the P2P interface address.
+		/*	Commented by Albert 2011/05/18 */
+		/*	Match the device address located in the P2P IE */
+		/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
 
 		p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
 		if (p2pie) {
-			//	The P2P Device ID attribute is included in the Beacon frame.
-			//	The P2P Device Info attribute is included in the probe response frame.
-			printk( "[%s] Got P2P IE\n", __FUNCTION__ );
-			if ( rtw_get_p2p_attr_content( p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen) )
-			{
-				//	Handle the P2P Device ID attribute of Beacon first
-				printk( "[%s] P2P_ATTR_DEVICE_ID \n", __FUNCTION__ );
-				if ( _rtw_memcmp( attr_content, peerMAC, ETH_ALEN ) )
-				{
+			/*	The P2P Device ID attribute is included in the Beacon frame. */
+			/*	The P2P Device Info attribute is included in the probe response frame. */
+			printk("[%s] Got P2P IE\n", __FUNCTION__);
+			if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device ID attribute of Beacon first */
+				printk("[%s] P2P_ATTR_DEVICE_ID\n", __FUNCTION__);
+				if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
 					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 					break;
 				}
-			}
-			else if ( rtw_get_p2p_attr_content( p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen) )
-			{
-				//	Handle the P2P Device Info attribute of probe response
-				printk( "[%s] P2P_ATTR_DEVICE_INFO \n", __FUNCTION__ );
-				if ( _rtw_memcmp( attr_content, peerMAC, ETH_ALEN ) )
-				{
+			} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+				/*	Handle the P2P Device Info attribute of probe response */
+				printk("[%s] P2P_ATTR_DEVICE_INFO\n", __FUNCTION__);
+				if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
 					uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 					break;
-				}					
+				}
 			}
 
 		}
 
 		plist = get_next(plist);
-	
+
 	}
 
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-	printk( "[%s] channel = %d\n", __FUNCTION__, uintPeerChannel );
+	printk("[%s] channel = %d\n", __FUNCTION__, uintPeerChannel);
 
-	if ( uintPeerChannel )
-	{
+	if (uintPeerChannel) {
 		u8 *wfd_ie;
 		uint wfd_ielen = 0;
 
@@ -6357,170 +5204,147 @@ static int rtw_p2p_set_pc(struct net_device *dev,
 			u8 *wfd_devinfo;
 			uint wfd_devlen;
 
-			DBG_871X( "[%s] Found WFD IE!\n", __FUNCTION__ );
+			RTW_INFO("[%s] Found WFD IE!\n", __FUNCTION__);
 			wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
 			if (wfd_devinfo) {
 				u16	wfd_devinfo_field = 0;
-				
-				//	Commented by Albert 20120319
-				//	The first two bytes are the WFD device information field of WFD device information subelement.
-				//	In big endian format.
+
+				/*	Commented by Albert 20120319 */
+				/*	The first two bytes are the WFD device information field of WFD device information subelement. */
+				/*	In big endian format. */
 				wfd_devinfo_field = RTW_GET_BE16(wfd_devinfo);
-				if ( wfd_devinfo_field & WFD_DEVINFO_PC_TDLS )
-				{
+				if (wfd_devinfo_field & WFD_DEVINFO_PC_TDLS)
 					pwfd_info->wfd_pc = _TRUE;
-				}
 				else
-				{
 					pwfd_info->wfd_pc = _FALSE;
-				}
 			}
 		}
-	}	
-	else
-	{
-		DBG_871X( "[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__ );
-	}
+	} else
+		RTW_INFO("[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__);
 
 exit:
-	
+
 	return ret;
-		
+
 }
 
 static int rtw_p2p_set_wfd_device_type(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	_adapter 					*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct iw_point 			*pdata = &wrqu->data;
-	struct wifidirect_info		*pwdinfo = &( padapter->wdinfo );
+				       struct iw_request_info *info,
+				       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
 	struct wifi_display_info		*pwfd_info = pwdinfo->wfd_info;
-	
-	//	Commented by Albert 20120328
-	//	The input data is 0 or 1
-	//	0: specify to Miracast source device
-	//	1 or others: specify to Miracast sink device (display device)
-	
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
-
-	if ( extra[ 0 ] == '0' )	//	Set to Miracast source device.
-	{
+
+	/*	Commented by Albert 20120328 */
+	/*	The input data is 0 or 1 */
+	/*	0: specify to Miracast source device */
+	/*	1 or others: specify to Miracast sink device (display device) */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (extra[0] == '0')	/*	Set to Miracast source device. */
 		pwfd_info->wfd_device_type = WFD_DEVINFO_SOURCE;
-	}
-	else					//	Set to Miracast sink device.
-	{
+	else					/*	Set to Miracast sink device. */
 		pwfd_info->wfd_device_type = WFD_DEVINFO_PSINK;
-	}
 
 exit:
-	
+
 	return ret;
-		
+
 }
 
 static int rtw_p2p_set_wfd_enable(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
 {
-//	Commented by Kurt 20121206
-//	This function is used to set wfd enabled
+	/*	Commented by Kurt 20121206
+	 *	This function is used to set wfd enabled */
 
-	int ret = 0;	
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 
 	if (*extra == '0')
 		rtw_wfd_enable(padapter, 0);
 	else if (*extra == '1')
 		rtw_wfd_enable(padapter, 1);
 
-	DBG_871X( "[%s] wfd_enable = %d\n", __FUNCTION__, pwdinfo->wfd_info->wfd_enable );
-	
+	RTW_INFO("[%s] wfd_enable = %d\n", __FUNCTION__, pwdinfo->wfd_info->wfd_enable);
+
 	return ret;
-		
+
 }
 
 static int rtw_p2p_set_driver_iface(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				    struct iw_request_info *info,
+				    union iwreq_data *wrqu, char *extra)
 {
-//	Commented by Kurt 20121206
-//	This function is used to set driver iface is WEXT or CFG80211
-	int ret = 0;	
+	/*	Commented by Kurt 20121206
+	 *	This function is used to set driver iface is WEXT or CFG80211 */
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 
-	if(*extra == '1' )
-	{
+	if (*extra == '1') {
 		pwdinfo->driver_interface = DRIVER_WEXT;
-		DBG_871X( "[%s] driver_interface = WEXT\n", __FUNCTION__);
-	}
-	else if(*extra == '2')
-	{
+		RTW_INFO("[%s] driver_interface = WEXT\n", __FUNCTION__);
+	} else if (*extra == '2') {
 		pwdinfo->driver_interface = DRIVER_CFG80211;
-		DBG_871X( "[%s] driver_interface = CFG80211\n", __FUNCTION__);
+		RTW_INFO("[%s] driver_interface = CFG80211\n", __FUNCTION__);
 	}
-	
+
 	return ret;
-		
+
 }
 
-//	To set the WFD session available to enable or disable
+/*	To set the WFD session available to enable or disable */
 static int rtw_p2p_set_sa(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	_adapter 					*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct iw_point 			*pdata = &wrqu->data;
-	struct wifidirect_info		*pwdinfo = &( padapter->wdinfo );
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_point			*pdata = &wrqu->data;
+	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
 	struct wifi_display_info		*pwfd_info = pwdinfo->wfd_info;
-	
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
 
-	if( 0 )
-	{
-		DBG_871X( "[%s] WiFi Direct is disable!\n", __FUNCTION__ );
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (0) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
 		return ret;
-	}
-	else
-	{
-		if ( extra[ 0 ] == '0' )	//	Disable the session available.
-		{
+	} else {
+		if (extra[0] == '0')	/*	Disable the session available. */
 			pwdinfo->session_available = _FALSE;
-		}
-		else if ( extra[ 0 ] == '1' )	//	Enable the session available.
-		{
+		else if (extra[0] == '1')	/*	Enable the session available. */
 			pwdinfo->session_available = _TRUE;
-		}
 		else
-		{
 			pwdinfo->session_available = _FALSE;
-		}
 	}
-	printk( "[%s] session available = %d\n", __FUNCTION__, pwdinfo->session_available );
-	
+	printk("[%s] session available = %d\n", __FUNCTION__, pwdinfo->session_available);
+
 exit:
-	
+
 	return ret;
-		
+
 }
 #endif /* CONFIG_WFD */
 
 static int rtw_p2p_prov_disc(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	int ret = 0;	
-	_adapter 				*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-	u8					peerMAC[ ETH_ALEN ] = { 0x00 };
-	int 					jj,kk;
-	u8   					peerMACStr[ ETH_ALEN * 2 ] = { 0x00 };
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+	u8					peerMAC[ETH_ALEN] = { 0x00 };
+	int					jj, kk;
+	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	_list					*plist, *phead;
 	_queue				*queue	= &(pmlmepriv->scanned_queue);
@@ -6530,147 +5354,118 @@ static int rtw_p2p_prov_disc(struct net_device *dev,
 	u8 *p2pie;
 	uint					p2pielen = 0, attr_contentlen = 0;
 	_irqL				irqL;
-#ifdef CONFIG_CONCURRENT_MODE
-	_adapter				*pbuddy_adapter = padapter->pbuddy_adapter;
-	struct mlme_priv		*pbuddy_mlmepriv = &pbuddy_adapter->mlmepriv;
-	struct mlme_ext_priv	*pbuddy_mlmeext = &pbuddy_adapter->mlmeextpriv;
-#endif // CONFIG_CONCURRENT_MODE	
-
-	//	Commented by Albert 20110301
-	//	The input data contains two informations.
-	//	1. First information is the MAC address which wants to issue the provisioning discovery request frame.
-	//	2. Second information is the WPS configuration method which wants to discovery
-	//	Format: 00:E0:4C:00:00:05_display
-	//	Format: 00:E0:4C:00:00:05_keypad
-	//	Format: 00:E0:4C:00:00:05_pbc
-	//	Format: 00:E0:4C:00:00:05_label
-
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
-
-	if ( pwdinfo->p2p_state == P2P_STATE_NONE )
-	{
-		DBG_871X( "[%s] WiFi Direct is disable!\n", __FUNCTION__ );
+
+	/*	Commented by Albert 20110301 */
+	/*	The input data contains two informations. */
+	/*	1. First information is the MAC address which wants to issue the provisioning discovery request frame. */
+	/*	2. Second information is the WPS configuration method which wants to discovery */
+	/*	Format: 00:E0:4C:00:00:05_display */
+	/*	Format: 00:E0:4C:00:00:05_keypad */
+	/*	Format: 00:E0:4C:00:00:05_pbc */
+	/*	Format: 00:E0:4C:00:00:05_label */
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+
+	if (pwdinfo->p2p_state == P2P_STATE_NONE) {
+		RTW_INFO("[%s] WiFi Direct is disable!\n", __FUNCTION__);
 		return ret;
-	}
-	else
-	{
+	} else {
 #ifdef CONFIG_INTEL_WIDI
 		if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
-			DBG_871X( "[%s] WiFi is under survey!\n", __FUNCTION__ );
+			RTW_INFO("[%s] WiFi is under survey!\n", __FUNCTION__);
 			return ret;
 		}
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-		//	Reset the content of struct tx_provdisc_req_info excluded the wps_config_method_request.
-		_rtw_memset( pwdinfo->tx_prov_disc_info.peerDevAddr, 0x00, ETH_ALEN );
-		_rtw_memset( pwdinfo->tx_prov_disc_info.peerIFAddr, 0x00, ETH_ALEN );
-		_rtw_memset( &pwdinfo->tx_prov_disc_info.ssid, 0x00, sizeof( NDIS_802_11_SSID ) );		
-		pwdinfo->tx_prov_disc_info.peer_channel_num[ 0 ] = 0;
-		pwdinfo->tx_prov_disc_info.peer_channel_num[ 1 ] = 0;
+		/*	Reset the content of struct tx_provdisc_req_info excluded the wps_config_method_request. */
+		_rtw_memset(pwdinfo->tx_prov_disc_info.peerDevAddr, 0x00, ETH_ALEN);
+		_rtw_memset(pwdinfo->tx_prov_disc_info.peerIFAddr, 0x00, ETH_ALEN);
+		_rtw_memset(&pwdinfo->tx_prov_disc_info.ssid, 0x00, sizeof(NDIS_802_11_SSID));
+		pwdinfo->tx_prov_disc_info.peer_channel_num[0] = 0;
+		pwdinfo->tx_prov_disc_info.peer_channel_num[1] = 0;
 		pwdinfo->tx_prov_disc_info.benable = _FALSE;
 	}
-	
-	for( jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3 )
-	{
-		peerMAC[ jj ] = key_2char2num( extra[kk], extra[kk+ 1] );
-	}
 
-	if ( _rtw_memcmp( &extra[ 18 ], "display", 7 ) )
-	{
+	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
+		peerMAC[jj] = key_2char2num(extra[kk], extra[kk + 1]);
+
+	if (_rtw_memcmp(&extra[18], "display", 7))
 		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_DISPLYA;
-	}
-	else if ( _rtw_memcmp( &extra[ 18 ], "keypad", 7 ) )
-	{
+	else if (_rtw_memcmp(&extra[18], "keypad", 7))
 		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_KEYPAD;
-	}
-	else if ( _rtw_memcmp( &extra[ 18 ], "pbc", 3 ) )
-	{
+	else if (_rtw_memcmp(&extra[18], "pbc", 3))
 		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_PUSH_BUTTON;
-	}
-	else if ( _rtw_memcmp( &extra[ 18 ], "label", 5 ) )
-	{
+	else if (_rtw_memcmp(&extra[18], "label", 5))
 		pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_LABEL;
-	}
-	else
-	{
-		DBG_871X( "[%s] Unknown WPS config methodn", __FUNCTION__ );
-		return( ret );
+	else {
+		RTW_INFO("[%s] Unknown WPS config methodn", __FUNCTION__);
+		return ret ;
 	}
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
 	phead = get_list_head(queue);
 	plist = get_next(phead);
-       
-	while(1)
-	{
-		if (rtw_end_of_queue_search(phead,plist)== _TRUE)
+
+	while (1) {
+		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
 
-		if( uintPeerChannel != 0 )
+		if (uintPeerChannel != 0)
 			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
 
-		//	Commented by Albert 2011/05/18
-		//	Match the device address located in the P2P IE
-		//	This is for the case that the P2P device address is not the same as the P2P interface address.
+		/*	Commented by Albert 2011/05/18 */
+		/*	Match the device address located in the P2P IE */
+		/*	This is for the case that the P2P device address is not the same as the P2P interface address. */
 
 		p2pie = rtw_bss_ex_get_p2p_ie(&pnetwork->network, NULL, &p2pielen);
 		if (p2pie) {
-			while ( p2pie )
-			{
-				//	The P2P Device ID attribute is included in the Beacon frame.
-				//	The P2P Device Info attribute is included in the probe response frame.
+			while (p2pie) {
+				/*	The P2P Device ID attribute is included in the Beacon frame. */
+				/*	The P2P Device Info attribute is included in the probe response frame. */
 
-				if ( rtw_get_p2p_attr_content( p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen) )
-				{
-					//	Handle the P2P Device ID attribute of Beacon first
-					if ( _rtw_memcmp( attr_content, peerMAC, ETH_ALEN ) )
-					{
+				if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_ID, attr_content, &attr_contentlen)) {
+					/*	Handle the P2P Device ID attribute of Beacon first */
+					if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
 						uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 						break;
 					}
-				}
-				else if ( rtw_get_p2p_attr_content( p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen) )
-				{
-					//	Handle the P2P Device Info attribute of probe response
-					if ( _rtw_memcmp( attr_content, peerMAC, ETH_ALEN ) )
-					{
+				} else if (rtw_get_p2p_attr_content(p2pie, p2pielen, P2P_ATTR_DEVICE_INFO, attr_content, &attr_contentlen)) {
+					/*	Handle the P2P Device Info attribute of probe response */
+					if (_rtw_memcmp(attr_content, peerMAC, ETH_ALEN)) {
 						uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 						break;
-					}					
+					}
 				}
 
-				//Get the next P2P IE
+				/* Get the next P2P IE */
 				p2pie = rtw_get_p2p_ie(p2pie + p2pielen, BSS_EX_TLV_IES_LEN(&pnetwork->network) - (p2pie + p2pielen - BSS_EX_TLV_IES(&pnetwork->network)), NULL, &p2pielen);
 			}
 
 		}
 
 #ifdef CONFIG_INTEL_WIDI
-		// Some Intel WiDi source may not provide P2P IE, 
-		// so we could only compare mac addr by 802.11 Source Address
-		if( pmlmepriv->widi_state == INTEL_WIDI_STATE_WFD_CONNECTION 
-			&& uintPeerChannel == 0 )
-		{
-			if ( _rtw_memcmp( pnetwork->network.MacAddress, peerMAC, ETH_ALEN ) )
-			{
+		/* Some Intel WiDi source may not provide P2P IE, */
+		/* so we could only compare mac addr by 802.11 Source Address */
+		if (pmlmepriv->widi_state == INTEL_WIDI_STATE_WFD_CONNECTION
+		    && uintPeerChannel == 0) {
+			if (_rtw_memcmp(pnetwork->network.MacAddress, peerMAC, ETH_ALEN)) {
 				uintPeerChannel = pnetwork->network.Configuration.DSConfig;
 				break;
 			}
 		}
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
 		plist = get_next(plist);
-	
+
 	}
 
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-	if ( uintPeerChannel )
-	{
-		#ifdef CONFIG_WFD
+	if (uintPeerChannel) {
+#ifdef CONFIG_WFD
 		if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
 			struct wifi_display_info *pwfd_info = pwdinfo->wfd_info;
 			u8 *wfd_ie;
@@ -6681,245 +5476,193 @@ static int rtw_p2p_prov_disc(struct net_device *dev,
 				u8 *wfd_devinfo;
 				uint wfd_devlen;
 
-				DBG_871X( "[%s] Found WFD IE!\n", __FUNCTION__ );
+				RTW_INFO("[%s] Found WFD IE!\n", __FUNCTION__);
 				wfd_devinfo = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &wfd_devlen);
 				if (wfd_devinfo) {
 					u16	wfd_devinfo_field = 0;
-					
-					//	Commented by Albert 20120319
-					//	The first two bytes are the WFD device information field of WFD device information subelement.
-					//	In big endian format.
+
+					/*	Commented by Albert 20120319 */
+					/*	The first two bytes are the WFD device information field of WFD device information subelement. */
+					/*	In big endian format. */
 					wfd_devinfo_field = RTW_GET_BE16(wfd_devinfo);
-					if ( wfd_devinfo_field & WFD_DEVINFO_SESSION_AVAIL )
-					{
+					if (wfd_devinfo_field & WFD_DEVINFO_SESSION_AVAIL)
 						pwfd_info->peer_session_avail = _TRUE;
-					}
 					else
-					{
 						pwfd_info->peer_session_avail = _FALSE;
-					}
 				}
 			}
-			
-			if ( _FALSE == pwfd_info->peer_session_avail )
-			{
-				DBG_871X( "[%s] WFD Session not avaiable!\n", __FUNCTION__ );
+
+			if (_FALSE == pwfd_info->peer_session_avail) {
+				RTW_INFO("[%s] WFD Session not avaiable!\n", __FUNCTION__);
 				goto exit;
 			}
 		}
-		#endif /* CONFIG_WFD */
-		
-		DBG_871X( "[%s] peer channel: %d!\n", __FUNCTION__, uintPeerChannel );
+#endif /* CONFIG_WFD */
+
+		RTW_INFO("[%s] peer channel: %d!\n", __FUNCTION__, uintPeerChannel);
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			_cancel_timer_ex( &pwdinfo->ap_p2p_switch_timer );
-		}
-#endif // CONFIG_CONCURRENT_MODE
-		_rtw_memcpy( pwdinfo->tx_prov_disc_info.peerIFAddr, pnetwork->network.MacAddress, ETH_ALEN );
-		_rtw_memcpy( pwdinfo->tx_prov_disc_info.peerDevAddr, peerMAC, ETH_ALEN );
-		pwdinfo->tx_prov_disc_info.peer_channel_num[0] = ( u16 ) uintPeerChannel;
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+#endif /* CONFIG_CONCURRENT_MODE */
+		_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerIFAddr, pnetwork->network.MacAddress, ETH_ALEN);
+		_rtw_memcpy(pwdinfo->tx_prov_disc_info.peerDevAddr, peerMAC, ETH_ALEN);
+		pwdinfo->tx_prov_disc_info.peer_channel_num[0] = (u16) uintPeerChannel;
 		pwdinfo->tx_prov_disc_info.benable = _TRUE;
 		rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ);
 
-		if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT))
-		{
-			_rtw_memcpy( &pwdinfo->tx_prov_disc_info.ssid, &pnetwork->network.Ssid, sizeof( NDIS_802_11_SSID ) );
-		}
-		else if(rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
-		{
-			_rtw_memcpy( pwdinfo->tx_prov_disc_info.ssid.Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN );
-			pwdinfo->tx_prov_disc_info.ssid.SsidLength= P2P_WILDCARD_SSID_LEN;
+		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT))
+			_rtw_memcpy(&pwdinfo->tx_prov_disc_info.ssid, &pnetwork->network.Ssid, sizeof(NDIS_802_11_SSID));
+		else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
+			_rtw_memcpy(pwdinfo->tx_prov_disc_info.ssid.Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN);
+			pwdinfo->tx_prov_disc_info.ssid.SsidLength = P2P_WILDCARD_SSID_LEN;
 		}
 
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			//	Have to enter the power saving with the AP
-			set_channel_bwmode(padapter, pbuddy_mlmeext->cur_channel, pbuddy_mlmeext->cur_ch_offset, pbuddy_mlmeext->cur_bwmode);
-			
-			issue_nulldata(pbuddy_adapter, NULL, 1, 3, 500);
-		}
-		else
-		{
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 union_ch = rtw_mi_get_union_chan(padapter);
+			u8 union_bw = rtw_mi_get_union_bw(padapter);
+			u8 union_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			rtw_leave_opch(padapter);
+
+		} else
 			set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-		}
 #else
 		set_channel_bwmode(padapter, uintPeerChannel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
 #endif
 
-		_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
-		
+		_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
+
 #ifdef CONFIG_CONCURRENT_MODE
-		if ( check_fwstate( pbuddy_mlmepriv, _FW_LINKED ) )
-		{
-			_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_PROVISION_TIMEOUT );
-		}
+		if (rtw_mi_check_status(padapter, MI_LINKED))
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_CONCURRENT_PROVISION_TIMEOUT);
 		else
-		{
-			_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT );
-		}
+			_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
 #else
-		_set_timer( &pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT );
-#endif // CONFIG_CONCURRENT_MODE		
-		
-	}
-	else
-	{
-		DBG_871X( "[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__ );
+		_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
+#endif /* CONFIG_CONCURRENT_MODE		 */
+
+	} else {
+		RTW_INFO("[%s] NOT Found in the Scanning Queue!\n", __FUNCTION__);
 #ifdef CONFIG_INTEL_WIDI
-		_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
+		_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
 		rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
-		rtw_free_network_queue(padapter, _TRUE);		
-		_enter_critical_bh(&pmlmepriv->lock, &irqL);				
-		rtw_sitesurvey_cmd(padapter, NULL, 0, NULL, 0);
+		rtw_free_network_queue(padapter, _TRUE);
+		_enter_critical_bh(&pmlmepriv->lock, &irqL);
+		rtw_sitesurvey_cmd(padapter, NULL);
 		_exit_critical_bh(&pmlmepriv->lock, &irqL);
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 	}
 exit:
-	
+
 	return ret;
-		
+
 }
 
-//	Added by Albert 20110328
-//	This function is used to inform the driver the user had specified the pin code value or pbc
-//	to application.
+/*	Added by Albert 20110328
+ *	This function is used to inform the driver the user had specified the pin code value or pbc
+ *	to application. */
 
 static int rtw_p2p_got_wpsinfo(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	_adapter 				*padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct wifidirect_info	*pwdinfo = &( padapter->wdinfo );
-	
-
-	DBG_871X( "[%s] data = %s\n", __FUNCTION__, extra );
-	//	Added by Albert 20110328
-	//	if the input data is P2P_NO_WPSINFO -> reset the wpsinfo
-	//	if the input data is P2P_GOT_WPSINFO_PEER_DISPLAY_PIN -> the utility just input the PIN code got from the peer P2P device.
-	//	if the input data is P2P_GOT_WPSINFO_SELF_DISPLAY_PIN -> the utility just got the PIN code from itself.
-	//	if the input data is P2P_GOT_WPSINFO_PBC -> the utility just determine to use the PBC
-	
-	if ( *extra == '0' )
-	{
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
+
+
+	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
+	/*	Added by Albert 20110328 */
+	/*	if the input data is P2P_NO_WPSINFO -> reset the wpsinfo */
+	/*	if the input data is P2P_GOT_WPSINFO_PEER_DISPLAY_PIN -> the utility just input the PIN code got from the peer P2P device. */
+	/*	if the input data is P2P_GOT_WPSINFO_SELF_DISPLAY_PIN -> the utility just got the PIN code from itself. */
+	/*	if the input data is P2P_GOT_WPSINFO_PBC -> the utility just determine to use the PBC */
+
+	if (*extra == '0')
 		pwdinfo->ui_got_wps_info = P2P_NO_WPSINFO;
-	}
-	else if ( *extra == '1' )
-	{
+	else if (*extra == '1')
 		pwdinfo->ui_got_wps_info = P2P_GOT_WPSINFO_PEER_DISPLAY_PIN;
-	}
-	else if ( *extra == '2' )
-	{
+	else if (*extra == '2')
 		pwdinfo->ui_got_wps_info = P2P_GOT_WPSINFO_SELF_DISPLAY_PIN;
-	}
-	else if ( *extra == '3' )
-	{
+	else if (*extra == '3')
 		pwdinfo->ui_got_wps_info = P2P_GOT_WPSINFO_PBC;
-	}
 	else
-	{
 		pwdinfo->ui_got_wps_info = P2P_NO_WPSINFO;
-	}
-	
+
 	return ret;
-		
+
 }
 
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 static int rtw_p2p_set(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
 {
-	
+
 	int ret = 0;
 #ifdef CONFIG_P2P
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 
-	DBG_871X( "[%s] extra = %s\n", __FUNCTION__, extra );
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, extra);
 
-	if ( _rtw_memcmp( extra, "enable=", 7 ) )
-	{
-		rtw_wext_p2p_enable( dev, info, wrqu, &extra[7] );
-	}
-	else if ( _rtw_memcmp( extra, "setDN=", 6 ) )
-	{
+	if (_rtw_memcmp(extra, "enable=", 7))
+		rtw_wext_p2p_enable(dev, info, wrqu, &extra[7]);
+	else if (_rtw_memcmp(extra, "setDN=", 6)) {
 		wrqu->data.length -= 6;
-		rtw_p2p_setDN( dev, info, wrqu, &extra[6] );
-	}
-	else if ( _rtw_memcmp( extra, "profilefound=", 13 ) )
-	{
+		rtw_p2p_setDN(dev, info, wrqu, &extra[6]);
+	} else if (_rtw_memcmp(extra, "profilefound=", 13)) {
 		wrqu->data.length -= 13;
-		rtw_p2p_profilefound( dev, info, wrqu, &extra[13] );
-	}
-	else if ( _rtw_memcmp( extra, "prov_disc=", 10 ) )
-	{
+		rtw_p2p_profilefound(dev, info, wrqu, &extra[13]);
+	} else if (_rtw_memcmp(extra, "prov_disc=", 10)) {
 		wrqu->data.length -= 10;
-		rtw_p2p_prov_disc( dev, info, wrqu, &extra[10] );
-	}
-	else if ( _rtw_memcmp( extra, "nego=", 5 ) )
-	{
+		rtw_p2p_prov_disc(dev, info, wrqu, &extra[10]);
+	} else if (_rtw_memcmp(extra, "nego=", 5)) {
 		wrqu->data.length -= 5;
-		rtw_p2p_connect( dev, info, wrqu, &extra[5] );
-	}
-	else if ( _rtw_memcmp( extra, "intent=", 7 ) )
-	{
-		//	Commented by Albert 2011/03/23
-		//	The wrqu->data.length will include the null character
-		//	So, we will decrease 7 + 1
+		rtw_p2p_connect(dev, info, wrqu, &extra[5]);
+	} else if (_rtw_memcmp(extra, "intent=", 7)) {
+		/*	Commented by Albert 2011/03/23 */
+		/*	The wrqu->data.length will include the null character */
+		/*	So, we will decrease 7 + 1 */
 		wrqu->data.length -= 8;
-		rtw_p2p_set_intent( dev, info, wrqu, &extra[7] );
-	}
-	else if ( _rtw_memcmp( extra, "ssid=", 5 ) )
-	{
+		rtw_p2p_set_intent(dev, info, wrqu, &extra[7]);
+	} else if (_rtw_memcmp(extra, "ssid=", 5)) {
 		wrqu->data.length -= 5;
-		rtw_p2p_set_go_nego_ssid( dev, info, wrqu, &extra[5] );
-	}
-	else if ( _rtw_memcmp( extra, "got_wpsinfo=", 12 ) )
-	{
+		rtw_p2p_set_go_nego_ssid(dev, info, wrqu, &extra[5]);
+	} else if (_rtw_memcmp(extra, "got_wpsinfo=", 12)) {
 		wrqu->data.length -= 12;
-		rtw_p2p_got_wpsinfo( dev, info, wrqu, &extra[12] );
-	}
-	else if ( _rtw_memcmp( extra, "listen_ch=", 10 ) )
-	{
-		//	Commented by Albert 2011/05/24
-		//	The wrqu->data.length will include the null character
-		//	So, we will decrease (10 + 1)	
+		rtw_p2p_got_wpsinfo(dev, info, wrqu, &extra[12]);
+	} else if (_rtw_memcmp(extra, "listen_ch=", 10)) {
+		/*	Commented by Albert 2011/05/24 */
+		/*	The wrqu->data.length will include the null character */
+		/*	So, we will decrease (10 + 1)	 */
 		wrqu->data.length -= 11;
-		rtw_p2p_set_listen_ch( dev, info, wrqu, &extra[10] );
-	}
-	else if ( _rtw_memcmp( extra, "op_ch=", 6 ) )
-	{
-		//	Commented by Albert 2011/05/24
-		//	The wrqu->data.length will include the null character
-		//	So, we will decrease (6 + 1)	
+		rtw_p2p_set_listen_ch(dev, info, wrqu, &extra[10]);
+	} else if (_rtw_memcmp(extra, "op_ch=", 6)) {
+		/*	Commented by Albert 2011/05/24 */
+		/*	The wrqu->data.length will include the null character */
+		/*	So, we will decrease (6 + 1)	 */
 		wrqu->data.length -= 7;
-		rtw_p2p_set_op_ch( dev, info, wrqu, &extra[6] );
-	}
-	else if ( _rtw_memcmp( extra, "invite=", 7 ) )
-	{
+		rtw_p2p_set_op_ch(dev, info, wrqu, &extra[6]);
+	} else if (_rtw_memcmp(extra, "invite=", 7)) {
 		wrqu->data.length -= 8;
-		rtw_p2p_invite_req( dev, info, wrqu, &extra[7] );
-	}
-	else if ( _rtw_memcmp( extra, "persistent=", 11 ) )
-	{
+		rtw_p2p_invite_req(dev, info, wrqu, &extra[7]);
+	} else if (_rtw_memcmp(extra, "persistent=", 11)) {
 		wrqu->data.length -= 11;
-		rtw_p2p_set_persistent( dev, info, wrqu, &extra[11] );
-	}
-	else if ( _rtw_memcmp ( extra, "uuid=", 5) )
-	{
+		rtw_p2p_set_persistent(dev, info, wrqu, &extra[11]);
+	} else if (_rtw_memcmp(extra, "uuid=", 5)) {
 		wrqu->data.length -= 5;
-		ret = rtw_p2p_set_wps_uuid( dev, info, wrqu, &extra[5] );
+		ret = rtw_p2p_set_wps_uuid(dev, info, wrqu, &extra[5]);
 	}
 
 #ifdef CONFIG_WFD
@@ -6945,66 +5688,48 @@ static int rtw_p2p_set(struct net_device *dev,
 	}
 #endif /* CONFIG_WFD */
 
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 	return ret;
-		
-}
-
-static int rtw_p2p_get(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{
-	
-	int ret = 0;	
-	
-#ifdef CONFIG_P2P
 
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
-	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-
-	if ( padapter->bShowGetP2PState )
-	{
-		DBG_871X( "[%s] extra = %s\n", __FUNCTION__, (char*) wrqu->data.pointer );
-	}
-
-	if ( _rtw_memcmp( wrqu->data.pointer, "status", 6 ) )
-	{
-		rtw_p2p_get_status( dev, info, wrqu, extra );
-	}
-	else if ( _rtw_memcmp( wrqu->data.pointer, "role", 4 ) )
-	{
-		rtw_p2p_get_role( dev, info, wrqu, extra);
-	}
-	else if ( _rtw_memcmp( wrqu->data.pointer, "peer_ifa", 8 ) )
-	{
-		rtw_p2p_get_peer_ifaddr( dev, info, wrqu, extra);
-	}
-	else if ( _rtw_memcmp( wrqu->data.pointer, "req_cm", 6 ) )
-	{
-		rtw_p2p_get_req_cm( dev, info, wrqu, extra);
-	}
-	else if ( _rtw_memcmp( wrqu->data.pointer, "peer_deva", 9 ) )
-	{
-		//	Get the P2P device address when receiving the provision discovery request frame.
-		rtw_p2p_get_peer_devaddr( dev, info, wrqu, extra);
-	}
-	else if ( _rtw_memcmp( wrqu->data.pointer, "group_id", 8 ) )
-	{
-		rtw_p2p_get_groupid( dev, info, wrqu, extra);
-	}
-	else if ( _rtw_memcmp( wrqu->data.pointer, "inv_peer_deva", 13 ) )
-	{
-		//	Get the P2P device address when receiving the P2P Invitation request frame.
-		rtw_p2p_get_peer_devaddr_by_invitation( dev, info, wrqu, extra);
-	}
-	else if ( _rtw_memcmp( wrqu->data.pointer, "op_ch", 5 ) )
-	{
-		rtw_p2p_get_op_ch( dev, info, wrqu, extra);
-	}
+}
+
+static int rtw_p2p_get(struct net_device *dev,
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
+{
+
+	int ret = 0;
+
+#ifdef CONFIG_P2P
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct iw_point *pdata = &wrqu->data;
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+
+	if (padapter->bShowGetP2PState)
+		RTW_INFO("[%s] extra = %s\n", __FUNCTION__, (char *) wrqu->data.pointer);
+
+	if (_rtw_memcmp(wrqu->data.pointer, "status", 6))
+		rtw_p2p_get_status(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "role", 4))
+		rtw_p2p_get_role(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "peer_ifa", 8))
+		rtw_p2p_get_peer_ifaddr(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "req_cm", 6))
+		rtw_p2p_get_req_cm(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "peer_deva", 9)) {
+		/*	Get the P2P device address when receiving the provision discovery request frame. */
+		rtw_p2p_get_peer_devaddr(dev, info, wrqu, extra);
+	} else if (_rtw_memcmp(wrqu->data.pointer, "group_id", 8))
+		rtw_p2p_get_groupid(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "inv_peer_deva", 13)) {
+		/*	Get the P2P device address when receiving the P2P Invitation request frame. */
+		rtw_p2p_get_peer_devaddr_by_invitation(dev, info, wrqu, extra);
+	} else if (_rtw_memcmp(wrqu->data.pointer, "op_ch", 5))
+		rtw_p2p_get_op_ch(dev, info, wrqu, extra);
 
 #ifdef CONFIG_WFD
 	if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST)) {
@@ -7016,16 +5741,16 @@ static int rtw_p2p_get(struct net_device *dev,
 			rtw_p2p_get_peer_wfd_preferred_connection(dev, info, wrqu, extra);
 	}
 #endif /* CONFIG_WFD */
-	
-#endif //CONFIG_P2P
+
+#endif /* CONFIG_P2P */
 
 	return ret;
-		
+
 }
 
 static int rtw_p2p_get2(struct net_device *dev,
-						struct iw_request_info *info,
-						union iwreq_data *wrqu, char *extra)
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
 {
 
 	int ret = 0;
@@ -7035,147 +5760,119 @@ static int rtw_p2p_get2(struct net_device *dev,
 	int length = wrqu->data.length;
 	char *buffer = (u8 *)rtw_malloc(length);
 
-	if (buffer == NULL)
-	{
+	if (buffer == NULL) {
 		ret = -ENOMEM;
 		goto bad;
 	}
 
-	if (copy_from_user(buffer, wrqu->data.pointer, wrqu->data.length))
-	{
+	if (copy_from_user(buffer, wrqu->data.pointer, wrqu->data.length)) {
 		ret = -EFAULT;
 		goto bad;
 	}
 
-	DBG_871X("[%s] buffer = %s\n", __FUNCTION__, buffer);
+	RTW_INFO("[%s] buffer = %s\n", __FUNCTION__, buffer);
 
 	if (_rtw_memcmp(buffer, "wpsCM=", 6))
-	{
 		ret = rtw_p2p_get_wps_configmethod(dev, info, wrqu, extra, &buffer[6]);
-	} else if (_rtw_memcmp(buffer, "devN=", 5))
-	{
+	else if (_rtw_memcmp(buffer, "devN=", 5))
 		ret = rtw_p2p_get_device_name(dev, info, wrqu, extra, &buffer[5]);
-	} else if (_rtw_memcmp(buffer, "dev_type=", 9))
-	{
+	else if (_rtw_memcmp(buffer, "dev_type=", 9))
 		ret = rtw_p2p_get_device_type(dev, info, wrqu, extra, &buffer[9]);
-	} else if (_rtw_memcmp(buffer, "go_devadd=", 10))
-	{
+	else if (_rtw_memcmp(buffer, "go_devadd=", 10))
 		ret = rtw_p2p_get_go_device_address(dev, info, wrqu, extra, &buffer[10]);
-	} else if (_rtw_memcmp(buffer, "InvProc=", 8))
-	{
+	else if (_rtw_memcmp(buffer, "InvProc=", 8))
 		ret = rtw_p2p_get_invitation_procedure(dev, info, wrqu, extra, &buffer[8]);
-	} else
-	{
+	else {
 		snprintf(extra, sizeof("Command not found."), "Command not found.");
 		wrqu->data.length = strlen(extra);
 	}
 
 bad:
 	if (buffer)
-	{
 		rtw_mfree(buffer, length);
-	}
 
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 	return ret;
 
 }
 
 static int rtw_cta_test_start(struct net_device *dev,
-							   struct iw_request_info *info,
-							   union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 	_adapter	*padapter = (_adapter *)rtw_netdev_priv(dev);
-	DBG_871X("%s %s\n", __func__, extra);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
+
+	RTW_INFO("%s %s\n", __func__, extra);
 	if (!strcmp(extra, "1"))
-		padapter->in_cta_test = 1;
+		hal_data->in_cta_test = 1;
 	else
-		padapter->in_cta_test = 0;
+		hal_data->in_cta_test = 0;
+
+	rtw_hal_rcr_set_chk_bssid(padapter, MLME_ACTION_NONE);
 
-	if(padapter->in_cta_test)
-	{
-		u32 v = rtw_read32(padapter, REG_RCR);
-		v &= ~(RCR_CBSSID_DATA | RCR_CBSSID_BCN );//| RCR_ADF
-		rtw_write32(padapter, REG_RCR, v);
-		DBG_871X("enable RCR_ADF\n");
-	}
-	else
-	{
-		u32 v = rtw_read32(padapter, REG_RCR);
-		v |= RCR_CBSSID_DATA | RCR_CBSSID_BCN ;//| RCR_ADF
-		rtw_write32(padapter, REG_RCR, v);
-		DBG_871X("disable RCR_ADF\n");
-	}
 	return ret;
 }
 
-
 extern int rtw_change_ifname(_adapter *padapter, const char *ifname);
 static int rtw_rereg_nd_name(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
 {
-	int ret = 0;	
+	int ret = 0;
 	_adapter *padapter = rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct rereg_nd_name_data *rereg_priv = &padapter->rereg_nd_name_priv;
 	char new_ifname[IFNAMSIZ];
 
-	if(rereg_priv->old_ifname[0] == 0) {
+	if (rereg_priv->old_ifname[0] == 0) {
 		char *reg_ifname;
-#ifdef CONFIG_CONCURRENT_MODE 
+#ifdef CONFIG_CONCURRENT_MODE
 		if (padapter->isprimary)
 			reg_ifname = padapter->registrypriv.ifname;
 		else
 #endif
-		reg_ifname = padapter->registrypriv.if2name;
+			reg_ifname = padapter->registrypriv.if2name;
 
 		strncpy(rereg_priv->old_ifname, reg_ifname, IFNAMSIZ);
-		rereg_priv->old_ifname[IFNAMSIZ-1] = 0;
+		rereg_priv->old_ifname[IFNAMSIZ - 1] = 0;
 	}
 
-	//DBG_871X("%s wrqu->data.length:%d\n", __FUNCTION__, wrqu->data.length);
-	if(wrqu->data.length > IFNAMSIZ)
+	/* RTW_INFO("%s wrqu->data.length:%d\n", __FUNCTION__, wrqu->data.length); */
+	if (wrqu->data.length > IFNAMSIZ)
 		return -EFAULT;
 
-	if ( copy_from_user(new_ifname, wrqu->data.pointer, IFNAMSIZ) ) {
+	if (copy_from_user(new_ifname, wrqu->data.pointer, IFNAMSIZ))
 		return -EFAULT;
-	}
 
-	if( 0 == strcmp(rereg_priv->old_ifname, new_ifname) ) {
+	if (0 == strcmp(rereg_priv->old_ifname, new_ifname))
 		return ret;
-	}
 
-	DBG_871X("%s new_ifname:%s\n", __FUNCTION__, new_ifname);
-	if( 0 != (ret = rtw_change_ifname(padapter, new_ifname)) ) {
+	RTW_INFO("%s new_ifname:%s\n", __FUNCTION__, new_ifname);
+	rtw_set_rtnl_lock_holder(dvobj, current);
+	ret = rtw_change_ifname(padapter, new_ifname);
+	rtw_set_rtnl_lock_holder(dvobj, NULL);
+	if (0 != ret)
 		goto exit;
-	}
 
-	if(_rtw_memcmp(rereg_priv->old_ifname, "disable%d", 9) == _TRUE) {
-		padapter->ledpriv.bRegUseLed= rereg_priv->old_bRegUseLed;
-		rtw_hal_sw_led_init(padapter);
-		//rtw_ips_mode_req(&padapter->pwrctrlpriv, rereg_priv->old_ips_mode);
+	if (_rtw_memcmp(rereg_priv->old_ifname, "disable%d", 9) == _TRUE) {
+		/* rtw_ips_mode_req(&padapter->pwrctrlpriv, rereg_priv->old_ips_mode); */
 	}
 
 	strncpy(rereg_priv->old_ifname, new_ifname, IFNAMSIZ);
-	rereg_priv->old_ifname[IFNAMSIZ-1] = 0;
-	
-	if(_rtw_memcmp(new_ifname, "disable%d", 9) == _TRUE) {
+	rereg_priv->old_ifname[IFNAMSIZ - 1] = 0;
 
-		DBG_871X("%s disable\n", __FUNCTION__);
-		// free network queue for Android's timming issue
+	if (_rtw_memcmp(new_ifname, "disable%d", 9) == _TRUE) {
+
+		RTW_INFO("%s disable\n", __FUNCTION__);
+		/* free network queue for Android's timming issue */
 		rtw_free_network_queue(padapter, _TRUE);
-		
-		// close led
-		rtw_led_control(padapter, LED_CTL_POWER_OFF);
-		rereg_priv->old_bRegUseLed = padapter->ledpriv.bRegUseLed;
-		padapter->ledpriv.bRegUseLed= _FALSE;
-		rtw_hal_sw_led_deinit(padapter);
-		
-		// the interface is being "disabled", we can do deeper IPS
-		//rereg_priv->old_ips_mode = rtw_get_ips_mode_req(&padapter->pwrctrlpriv);
-		//rtw_ips_mode_req(&padapter->pwrctrlpriv, IPS_NORMAL);
+
+		/* the interface is being "disabled", we can do deeper IPS */
+		/* rereg_priv->old_ips_mode = rtw_get_ips_mode_req(&padapter->pwrctrlpriv); */
+		/* rtw_ips_mode_req(&padapter->pwrctrlpriv, IPS_NORMAL); */
 	}
 exit:
 	return ret;
@@ -7185,20 +5882,27 @@ exit:
 #ifdef CONFIG_IOL
 #include <rtw_iol.h>
 #endif
-
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+#include "../../hal/hal_dm_acs.h"
+#endif
 #ifdef DBG_CMD_QUEUE
-u8 dump_cmd_id=0;
+u8 dump_cmd_id = 0;
+#endif
+/*
+#ifdef DBG_DUMP_TSF_BY_PORT
+extern void get_tsf_by_port(_adapter *adapter, u8 *tsftr, u8 hw_port);
 #endif
+*/
 static int rtw_dbg_port(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-{	
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
 	_irqL irqL;
 	int ret = 0;
 	u8 major_cmd, minor_cmd;
 	u16 arg;
 	u32 extra_arg, *pdata, val32;
-	struct sta_info *psta;						
+	struct sta_info *psta;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
@@ -7206,812 +5910,824 @@ static int rtw_dbg_port(struct net_device *dev,
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	
 
-	pdata = (u32*)&wrqu->data;	
+
+	pdata = (u32 *)&wrqu->data;
 
 	val32 = *pdata;
-	arg = (u16)(val32&0x0000ffff);
-	major_cmd = (u8)(val32>>24);
-	minor_cmd = (u8)((val32>>16)&0x00ff);
+	arg = (u16)(val32 & 0x0000ffff);
+	major_cmd = (u8)(val32 >> 24);
+	minor_cmd = (u8)((val32 >> 16) & 0x00ff);
 
-	extra_arg = *(pdata+1);
-	
-	switch(major_cmd)
-	{
-		case 0x70://read_reg
-			switch(minor_cmd)
-			{
-				case 1:
-					DBG_871X("rtw_read8(0x%x)=0x%02x\n", arg, rtw_read8(padapter, arg));
-					break;
-				case 2:
-					DBG_871X("rtw_read16(0x%x)=0x%04x\n", arg, rtw_read16(padapter, arg));
-					break;
-				case 4:
-					DBG_871X("rtw_read32(0x%x)=0x%08x\n", arg, rtw_read32(padapter, arg));
-					break;
-			}			
+	extra_arg = *(pdata + 1);
+
+	switch (major_cmd) {
+	case 0x70: /* read_reg */
+		switch (minor_cmd) {
+		case 1:
+			RTW_INFO("rtw_read8(0x%x)=0x%02x\n", arg, rtw_read8(padapter, arg));
 			break;
-		case 0x71://write_reg
-			switch(minor_cmd)
-			{
-				case 1:
-					rtw_write8(padapter, arg, extra_arg);
-					DBG_871X("rtw_write8(0x%x)=0x%02x\n", arg, rtw_read8(padapter, arg));
-					break;
-				case 2:
-					rtw_write16(padapter, arg, extra_arg);
-					DBG_871X("rtw_write16(0x%x)=0x%04x\n", arg, rtw_read16(padapter, arg));
-					break;
-				case 4:
-					rtw_write32(padapter, arg, extra_arg);
-					DBG_871X("rtw_write32(0x%x)=0x%08x\n", arg, rtw_read32(padapter, arg));
-					break;
-			}			
+		case 2:
+			RTW_INFO("rtw_read16(0x%x)=0x%04x\n", arg, rtw_read16(padapter, arg));
 			break;
-		case 0x72://read_bb
-			DBG_871X("read_bbreg(0x%x)=0x%x\n", arg, rtw_hal_read_bbreg(padapter, arg, 0xffffffff));
+		case 4:
+			RTW_INFO("rtw_read32(0x%x)=0x%08x\n", arg, rtw_read32(padapter, arg));
+			break;
+		}
+		break;
+	case 0x71: /* write_reg */
+		switch (minor_cmd) {
+		case 1:
+			rtw_write8(padapter, arg, extra_arg);
+			RTW_INFO("rtw_write8(0x%x)=0x%02x\n", arg, rtw_read8(padapter, arg));
 			break;
-		case 0x73://write_bb
-			rtw_hal_write_bbreg(padapter, arg, 0xffffffff, extra_arg);
-			DBG_871X("write_bbreg(0x%x)=0x%x\n", arg, rtw_hal_read_bbreg(padapter, arg, 0xffffffff));
+		case 2:
+			rtw_write16(padapter, arg, extra_arg);
+			RTW_INFO("rtw_write16(0x%x)=0x%04x\n", arg, rtw_read16(padapter, arg));
 			break;
-		case 0x74://read_rf
-			DBG_871X("read RF_reg path(0x%02x),offset(0x%x),value(0x%08x)\n",minor_cmd,arg,rtw_hal_read_rfreg(padapter, minor_cmd, arg, 0xffffffff));	
+		case 4:
+			rtw_write32(padapter, arg, extra_arg);
+			RTW_INFO("rtw_write32(0x%x)=0x%08x\n", arg, rtw_read32(padapter, arg));
 			break;
-		case 0x75://write_rf
-			rtw_hal_write_rfreg(padapter, minor_cmd, arg, 0xffffffff, extra_arg);
-			DBG_871X("write RF_reg path(0x%02x),offset(0x%x),value(0x%08x)\n",minor_cmd,arg, rtw_hal_read_rfreg(padapter, minor_cmd, arg, 0xffffffff));
-			break;	
+		}
+		break;
+	case 0x72: /* read_bb */
+		RTW_INFO("read_bbreg(0x%x)=0x%x\n", arg, rtw_hal_read_bbreg(padapter, arg, 0xffffffff));
+		break;
+	case 0x73: /* write_bb */
+		rtw_hal_write_bbreg(padapter, arg, 0xffffffff, extra_arg);
+		RTW_INFO("write_bbreg(0x%x)=0x%x\n", arg, rtw_hal_read_bbreg(padapter, arg, 0xffffffff));
+		break;
+	case 0x74: /* read_rf */
+		RTW_INFO("read RF_reg path(0x%02x),offset(0x%x),value(0x%08x)\n", minor_cmd, arg, rtw_hal_read_rfreg(padapter, minor_cmd, arg, 0xffffffff));
+		break;
+	case 0x75: /* write_rf */
+		rtw_hal_write_rfreg(padapter, minor_cmd, arg, 0xffffffff, extra_arg);
+		RTW_INFO("write RF_reg path(0x%02x),offset(0x%x),value(0x%08x)\n", minor_cmd, arg, rtw_hal_read_rfreg(padapter, minor_cmd, arg, 0xffffffff));
+		break;
 
-		case 0x76:
-			switch(minor_cmd)
+	case 0x76:
+		switch (minor_cmd) {
+		case 0x00: /* normal mode, */
+			padapter->recvpriv.is_signal_dbg = 0;
+			break;
+		case 0x01: /* dbg mode */
+			padapter->recvpriv.is_signal_dbg = 1;
+			extra_arg = extra_arg > 100 ? 100 : extra_arg;
+			padapter->recvpriv.signal_strength_dbg = extra_arg;
+			break;
+		}
+		break;
+	case 0x78: /* IOL test */
+		switch (minor_cmd) {
+		#ifdef CONFIG_IOL
+		case 0x04: { /* LLT table initialization test */
+			u8 page_boundary = 0xf9;
 			{
-				case 0x00: //normal mode, 
-					padapter->recvpriv.is_signal_dbg = 0;
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
 					break;
-				case 0x01: //dbg mode
-					padapter->recvpriv.is_signal_dbg = 1;
-					extra_arg = extra_arg>100?100:extra_arg;
-					padapter->recvpriv.signal_strength_dbg=extra_arg;
+				}
+
+				rtw_IOL_append_LLT_cmd(xmit_frame, page_boundary);
+
+
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 500, 0))
+					ret = -EPERM;
+			}
+		}
+			break;
+		case 0x05: { /* blink LED test */
+			u16 reg = 0x4c;
+			u32 blink_num = 50;
+			u32 blink_delay_ms = 200;
+			int i;
+
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
 					break;
+				}
+
+				for (i = 0; i < blink_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x00, 0xff);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x08, 0xff);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					#else
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x00);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x08);
+					rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
+					#endif
+				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, (blink_delay_ms * blink_num * 2) + 200, 0))
+					ret = -EPERM;
 			}
+		}
 			break;
-		case 0x78: //IOL test
-			switch(minor_cmd)
+
+		case 0x06: { /* continuous wirte byte test */
+			u16 reg = arg;
+			u16 start_value = 0;
+			u32 write_num = extra_arg;
+			int i;
+			u8 final;
+
 			{
-				#ifdef CONFIG_IOL
-				case 0x04: //LLT table initialization test
-				{
-					u8 page_boundary = 0xf9;
-					{
-						struct xmit_frame	*xmit_frame;
+				struct xmit_frame	*xmit_frame;
 
-						if((xmit_frame=rtw_IOL_accquire_xmit_frame(padapter)) == NULL) {
-							ret = -ENOMEM;	
-							break;
-						}
-						
-						rtw_IOL_append_LLT_cmd(xmit_frame, page_boundary);
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
+					break;
+				}
 
+				for (i = 0; i < write_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, i + start_value, 0xFF);
+					#else
+					rtw_IOL_append_WB_cmd(xmit_frame, reg, i + start_value);
+					#endif
+				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000, 0))
+					ret = -EPERM;
+			}
 
-						if(_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 500,0) )
-							ret = -EPERM;
-					}
+			final = rtw_read8(padapter, reg);
+			if (start_value + write_num - 1 == final)
+				RTW_INFO("continuous IOL_CMD_WB_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
+			else
+				RTW_INFO("continuous IOL_CMD_WB_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
+		}
+			break;
+
+		case 0x07: { /* continuous wirte word test */
+			u16 reg = arg;
+			u16 start_value = 200;
+			u32 write_num = extra_arg;
+
+			int i;
+			u16 final;
+
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
+					break;
+				}
+
+				for (i = 0; i < write_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WW_cmd(xmit_frame, reg, i + start_value, 0xFFFF);
+					#else
+					rtw_IOL_append_WW_cmd(xmit_frame, reg, i + start_value);
+					#endif
 				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000, 0))
+					ret = -EPERM;
+			}
+
+			final = rtw_read16(padapter, reg);
+			if (start_value + write_num - 1 == final)
+				RTW_INFO("continuous IOL_CMD_WW_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
+			else
+				RTW_INFO("continuous IOL_CMD_WW_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
+		}
+			break;
+
+		case 0x08: { /* continuous wirte dword test */
+			u16 reg = arg;
+			u32 start_value = 0x110000c7;
+			u32 write_num = extra_arg;
+
+			int i;
+			u32 final;
+
+			{
+				struct xmit_frame	*xmit_frame;
+
+				xmit_frame = rtw_IOL_accquire_xmit_frame(padapter);
+				if (xmit_frame == NULL) {
+					ret = -ENOMEM;
 					break;
-				case 0x05: //blink LED test
-				{
-					u16 reg = 0x4c;
-					u32 blink_num = 50;
-					u32 blink_delay_ms = 200;
-					int i;
-					
-					{
-						struct xmit_frame	*xmit_frame;
-
-						if((xmit_frame=rtw_IOL_accquire_xmit_frame(padapter)) == NULL) {
-							ret = -ENOMEM;	
-							break;
-						}
+				}
 
-						for(i=0;i<blink_num;i++){
-							#ifdef CONFIG_IOL_NEW_GENERATION
-							rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x00,0xff);
-							rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
-							rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x08,0xff);
-							rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
-							#else
-							rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x00);
-							rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
-							rtw_IOL_append_WB_cmd(xmit_frame, reg, 0x08);
-							rtw_IOL_append_DELAY_MS_cmd(xmit_frame, blink_delay_ms);
-							#endif
-						}
-						if(_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, (blink_delay_ms*blink_num*2)+200,0) )
-							ret = -EPERM;
+				for (i = 0; i < write_num; i++) {
+					#ifdef CONFIG_IOL_NEW_GENERATION
+					rtw_IOL_append_WD_cmd(xmit_frame, reg, i + start_value, 0xFFFFFFFF);
+					#else
+					rtw_IOL_append_WD_cmd(xmit_frame, reg, i + start_value);
+					#endif
+				}
+				if (_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000, 0))
+					ret = -EPERM;
+
+			}
+
+			final = rtw_read32(padapter, reg);
+			if (start_value + write_num - 1 == final)
+				RTW_INFO("continuous IOL_CMD_WD_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
+			else
+				RTW_INFO("continuous IOL_CMD_WD_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
+		}
+			break;
+		#endif /* CONFIG_IOL */
+		}
+		break;
+	case 0x79: {
+		/*
+		* dbg 0x79000000 [value], set RESP_TXAGC to + value, value:0~15
+		* dbg 0x79010000 [value], set RESP_TXAGC to - value, value:0~15
+		*/
+		u8 value =  extra_arg & 0x0f;
+		u8 sign = minor_cmd;
+		u16 write_value = 0;
+
+		RTW_INFO("%s set RESP_TXAGC to %s %u\n", __func__, sign ? "minus" : "plus", value);
+
+		if (sign)
+			value = value | 0x10;
+
+		write_value = value | (value << 5);
+		rtw_write16(padapter, 0x6d9, write_value);
+	}
+		break;
+	case 0x7a:
+		receive_disconnect(padapter, pmlmeinfo->network.MacAddress
+				   , WLAN_REASON_EXPIRATION_CHK, _FALSE);
+		break;
+	case 0x7F:
+		switch (minor_cmd) {
+		case 0x0:
+			RTW_INFO("fwstate=0x%x\n", get_fwstate(pmlmepriv));
+			break;
+		case 0x01:
+			RTW_INFO("auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n",
+				psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm,
+				psecuritypriv->ndisauthtype, psecuritypriv->ndisencryptstatus);
+			break;
+		case 0x02:
+			RTW_INFO("pmlmeinfo->state=0x%x\n", pmlmeinfo->state);
+			RTW_INFO("DrvBcnEarly=%d\n", pmlmeext->DrvBcnEarly);
+			RTW_INFO("DrvBcnTimeOut=%d\n", pmlmeext->DrvBcnTimeOut);
+			break;
+		case 0x03:
+			RTW_INFO("qos_option=%d\n", pmlmepriv->qospriv.qos_option);
+#ifdef CONFIG_80211N_HT
+			RTW_INFO("ht_option=%d\n", pmlmepriv->htpriv.ht_option);
+#endif /* CONFIG_80211N_HT */
+			break;
+		case 0x04:
+			RTW_INFO("cur_ch=%d\n", pmlmeext->cur_channel);
+			RTW_INFO("cur_bw=%d\n", pmlmeext->cur_bwmode);
+			RTW_INFO("cur_ch_off=%d\n", pmlmeext->cur_ch_offset);
+
+			RTW_INFO("oper_ch=%d\n", rtw_get_oper_ch(padapter));
+			RTW_INFO("oper_bw=%d\n", rtw_get_oper_bw(padapter));
+			RTW_INFO("oper_ch_offet=%d\n", rtw_get_oper_choffset(padapter));
+
+			break;
+		case 0x05:
+			psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
+			if (psta) {
+				RTW_INFO("SSID=%s\n", cur_network->network.Ssid.Ssid);
+				RTW_INFO("sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+				RTW_INFO("cur_channel=%d, cur_bwmode=%d, cur_ch_offset=%d\n", pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
+				RTW_INFO("rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
+				RTW_INFO("state=0x%x, aid=%d, macid=%d, raid=%d\n",
+					psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
+#ifdef CONFIG_80211N_HT
+				RTW_INFO("qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
+				RTW_INFO("bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n"
+					, psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
+				RTW_INFO("ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
+				RTW_INFO("agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
+#endif /* CONFIG_80211N_HT */
+
+				sta_rx_reorder_ctl_dump(RTW_DBGDUMP, psta);
+			} else
+				RTW_INFO("can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
+			break;
+		case 0x06: {
+				#ifdef DBG_DUMP_TSF_BY_PORT
+				u64 tsf = 0;
+
+				get_tsf_by_port(padapter, (u8 *)&tsf, extra_arg);
+				RTW_INFO(" PORT-%d TSF :%lld\n", extra_arg, tsf);
+				#endif
+		}
+			break;
+		case 0x07:
+			RTW_INFO("bSurpriseRemoved=%s, bDriverStopped=%s\n"
+				, rtw_is_surprise_removed(padapter) ? "True" : "False"
+				, rtw_is_drv_stopped(padapter) ? "True" : "False");
+			break;
+		case 0x08: {
+			struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+			struct recv_priv  *precvpriv = &padapter->recvpriv;
+
+			RTW_INFO("free_xmitbuf_cnt=%d, free_xmitframe_cnt=%d"
+				", free_xmit_extbuf_cnt=%d, free_xframe_ext_cnt=%d"
+				 ", free_recvframe_cnt=%d\n",
+				pxmitpriv->free_xmitbuf_cnt, pxmitpriv->free_xmitframe_cnt,
+				pxmitpriv->free_xmit_extbuf_cnt, pxmitpriv->free_xframe_ext_cnt,
+				 precvpriv->free_recvframe_cnt);
+#ifdef CONFIG_USB_HCI
+			RTW_INFO("rx_urb_pending_cn=%d\n", ATOMIC_READ(&(precvpriv->rx_pending_cnt)));
+#endif
+		}
+			break;
+		case 0x09: {
+			int i;
+			_list	*plist, *phead;
+
+#ifdef CONFIG_AP_MODE
+			RTW_INFO_DUMP("sta_dz_bitmap:", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+			RTW_INFO_DUMP("tim_bitmap:", pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
+#endif
+			_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+			for (i = 0; i < NUM_STA; i++) {
+				phead = &(pstapriv->sta_hash[i]);
+				plist = get_next(phead);
+
+				while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+					psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+
+					plist = get_next(plist);
+
+					if (extra_arg == psta->cmn.aid) {
+						RTW_INFO("sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+						RTW_INFO("rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
+						RTW_INFO("state=0x%x, aid=%d, macid=%d, raid=%d\n",
+							psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
+#ifdef CONFIG_80211N_HT
+						RTW_INFO("qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
+						RTW_INFO("bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n",
+							psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m,
+							psta->htpriv.sgi_40m);
+						RTW_INFO("ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
+						RTW_INFO("agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
+#endif /* CONFIG_80211N_HT */
+
+#ifdef CONFIG_AP_MODE
+						RTW_INFO("capability=0x%x\n", psta->capability);
+						RTW_INFO("flags=0x%x\n", psta->flags);
+						RTW_INFO("wpa_psk=0x%x\n", psta->wpa_psk);
+						RTW_INFO("wpa2_group_cipher=0x%x\n", psta->wpa2_group_cipher);
+						RTW_INFO("wpa2_pairwise_cipher=0x%x\n", psta->wpa2_pairwise_cipher);
+						RTW_INFO("qos_info=0x%x\n", psta->qos_info);
+#endif
+						RTW_INFO("dot118021XPrivacy=0x%x\n", psta->dot118021XPrivacy);
+
+						sta_rx_reorder_ctl_dump(RTW_DBGDUMP, psta);
 					}
+
 				}
-					break;
-					
-				case 0x06: //continuous wirte byte test
-				{
-					u16 reg = arg;
-					u16 start_value = 0;
-					u32 write_num = extra_arg;
-					int i;
-					u8 final;
-					
-					{
-						struct xmit_frame	*xmit_frame;
-
-						if((xmit_frame=rtw_IOL_accquire_xmit_frame(padapter)) == NULL) {
-							ret = -ENOMEM;	
-							break;
-						}
+			}
+
+			_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+		}
+			break;
+
+		case 0x0b: { /* Enable=1, Disable=0 driver control vrtl_carrier_sense. */
+			/* u8 driver_vcs_en; */ /* Enable=1, Disable=0 driver control vrtl_carrier_sense. */
+			/* u8 driver_vcs_type; */ /* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. */
+
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl vcs\n");
+				padapter->driver_vcs_en = 0;
+			} else if (arg == 1) {
+				RTW_INFO("enable driver ctrl vcs = %d\n", extra_arg);
+				padapter->driver_vcs_en = 1;
+
+				if (extra_arg > 2)
+					padapter->driver_vcs_type = 1;
+				else
+					padapter->driver_vcs_type = extra_arg;
+			}
+		}
+			break;
+		case 0x0c: { /* dump rx/tx packet */
+			if (arg == 0) {
+				RTW_INFO("dump rx packet (%d)\n", extra_arg);
+				/* pHalData->bDumpRxPkt =extra_arg;						 */
+				rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DUMP_RXPKT, &(extra_arg));
+			} else if (arg == 1) {
+				RTW_INFO("dump tx packet (%d)\n", extra_arg);
+				rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DUMP_TXPKT, &(extra_arg));
+			}
+		}
+			break;
+		case 0x0e: {
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl rx_ampdu_factor\n");
+				padapter->driver_rx_ampdu_factor = 0xFF;
+			} else if (arg == 1) {
+
+				RTW_INFO("enable driver ctrl rx_ampdu_factor = %d\n", extra_arg);
+
+				if (extra_arg > 0x03)
+					padapter->driver_rx_ampdu_factor = 0xFF;
+				else
+					padapter->driver_rx_ampdu_factor = extra_arg;
+			}
+		}
+			break;
+		#ifdef DBG_CONFIG_ERROR_DETECT
+		case 0x0f: {
+			if (extra_arg == 0) {
+				RTW_INFO("###### silent reset test.......#####\n");
+				rtw_hal_sreset_reset(padapter);
+			} else {
+				HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+				struct sreset_priv *psrtpriv = &pHalData->srestpriv;
+				psrtpriv->dbg_trigger_point = extra_arg;
+			}
+
+		}
+			break;
+		case 0x15: {
+			struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+			RTW_INFO("==>silent resete cnts:%d\n", pwrpriv->ips_enter_cnts);
+		}
+			break;
+
+		#endif
+
+		case 0x10: /* driver version display */
+			dump_drv_version(RTW_DBGDUMP);
+			break;
+		case 0x11: { /* dump linked status */
+			int pre_mode;
+			pre_mode = padapter->bLinkInfoDump;
+			/* linked_info_dump(padapter,extra_arg); */
+			if (extra_arg == 1 || (extra_arg == 0 && pre_mode == 1)) /* not consider pwr_saving 0: */
+				padapter->bLinkInfoDump = extra_arg;
+
+			else if ((extra_arg == 2) || (extra_arg == 0 && pre_mode == 2)) { /* consider power_saving */
+				/* RTW_INFO("linked_info_dump =%s\n", (padapter->bLinkInfoDump)?"enable":"disable") */
+				linked_info_dump(padapter, extra_arg);
+			}
+
+
+
+		}
+			break;
+#ifdef CONFIG_80211N_HT
+		case 0x12: { /* set rx_stbc */
+			struct registry_priv	*pregpriv = &padapter->registrypriv;
+			/* 0: disable, bit(0):enable 2.4g, bit(1):enable 5g, 0x3: enable both 2.4g and 5g */
+			/* default is set to enable 2.4GHZ for IOT issue with bufflao's AP at 5GHZ */
+			if (pregpriv && (extra_arg == 0 || extra_arg == 1 || extra_arg == 2 || extra_arg == 3)) {
+				pregpriv->rx_stbc = extra_arg;
+				RTW_INFO("set rx_stbc=%d\n", pregpriv->rx_stbc);
+			} else
+				RTW_INFO("get rx_stbc=%d\n", pregpriv->rx_stbc);
+
+		}
+			break;
+		case 0x13: { /* set ampdu_enable */
+			struct registry_priv	*pregpriv = &padapter->registrypriv;
+			/* 0: disable, 0x1:enable */
+			if (pregpriv && extra_arg < 2) {
+				pregpriv->ampdu_enable = extra_arg;
+				RTW_INFO("set ampdu_enable=%d\n", pregpriv->ampdu_enable);
+			} else
+				RTW_INFO("get ampdu_enable=%d\n", pregpriv->ampdu_enable);
+
+		}
+			break;
+#endif
+		case 0x14: { /* get wifi_spec */
+			struct registry_priv	*pregpriv = &padapter->registrypriv;
+			RTW_INFO("get wifi_spec=%d\n", pregpriv->wifi_spec);
+
+		}
+			break;
+
+#ifdef DBG_FIXED_CHAN
+		case 0x17: {
+			struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+			printk("===>  Fixed channel to %d\n", extra_arg);
+			pmlmeext->fixed_chan = extra_arg;
+
+		}
+			break;
+#endif
+#ifdef CONFIG_80211N_HT
+		case 0x19: {
+			struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+			/* extra_arg : */
+			/* BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, */
+			/* BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx */
+			if (arg == 0) {
+				RTW_INFO("driver disable LDPC\n");
+				pregistrypriv->ldpc_cap = 0x00;
+			} else if (arg == 1) {
+				RTW_INFO("driver set LDPC cap = 0x%x\n", extra_arg);
+				pregistrypriv->ldpc_cap = (u8)(extra_arg & 0x33);
+			}
+		}
+			break;
+		case 0x1a: {
+			struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+			/* extra_arg : */
+			/* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, */
+			/* BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
+			if (arg == 0) {
+				RTW_INFO("driver disable STBC\n");
+				pregistrypriv->stbc_cap = 0x00;
+			} else if (arg == 1) {
+				RTW_INFO("driver set STBC cap = 0x%x\n", extra_arg);
+				pregistrypriv->stbc_cap = (u8)(extra_arg & 0x33);
+			}
+		}
+			break;
+#endif /* CONFIG_80211N_HT */
+		case 0x1b: {
+			struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl max_rx_rate, reset to default_rate_set\n");
+				init_mlme_default_rate_set(padapter);
+#ifdef CONFIG_80211N_HT
+				pregistrypriv->ht_enable = (u8)rtw_ht_enable;
+#endif /* CONFIG_80211N_HT */
+			} else if (arg == 1) {
 
-						for(i=0;i<write_num;i++){
-							#ifdef CONFIG_IOL_NEW_GENERATION
-							rtw_IOL_append_WB_cmd(xmit_frame, reg, i+start_value,0xFF);
-							#else
-							rtw_IOL_append_WB_cmd(xmit_frame, reg, i+start_value);
-							#endif
-						}
-						if(_SUCCESS != rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000,0))
-							ret = -EPERM;
-					}
+				int i;
+				u8 max_rx_rate;
 
-					if(start_value+write_num-1 == (final=rtw_read8(padapter, reg)) ) {
-						DBG_871X("continuous IOL_CMD_WB_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
-					} else {
-						DBG_871X("continuous IOL_CMD_WB_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
-					}
-				}
-					break;
-					
-				case 0x07: //continuous wirte word test
-				{
-					u16 reg = arg;
-					u16 start_value = 200;
-					u32 write_num = extra_arg;
-				
-					int i;
-					u16 final;
-
-					{
-						struct xmit_frame	*xmit_frame;
-
-						if((xmit_frame=rtw_IOL_accquire_xmit_frame(padapter)) == NULL) {
-							ret = -ENOMEM;	
-							break;
-						}
+				RTW_INFO("enable driver ctrl max_rx_rate = 0x%x\n", extra_arg);
 
-						for(i=0;i<write_num;i++){
-							#ifdef CONFIG_IOL_NEW_GENERATION
-							rtw_IOL_append_WW_cmd(xmit_frame, reg, i+start_value,0xFFFF);
-							#else
-							rtw_IOL_append_WW_cmd(xmit_frame, reg, i+start_value);
-							#endif
-						}
-						if(_SUCCESS !=rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000,0))
-							ret = -EPERM;
-					}
+				max_rx_rate = (u8)extra_arg;
 
-					if(start_value+write_num-1 == (final=rtw_read16(padapter, reg)) ) {
-						DBG_871X("continuous IOL_CMD_WW_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
-					} else {
-						DBG_871X("continuous IOL_CMD_WW_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
+				if (max_rx_rate < 0xc) { /* max_rx_rate < MSC0->B or G -> disable HT */
+#ifdef CONFIG_80211N_HT
+					pregistrypriv->ht_enable = 0;
+#endif /* CONFIG_80211N_HT */
+					for (i = 0; i < NumRates; i++) {
+						if (pmlmeext->datarate[i] > max_rx_rate)
+							pmlmeext->datarate[i] = 0xff;
 					}
+
 				}
-					break;
-					
-				case 0x08: //continuous wirte dword test
-				{
-					u16 reg = arg;
-					u32 start_value = 0x110000c7;
-					u32 write_num = extra_arg;
-				
-					int i;
-					u32 final;
-
-					{
-						struct xmit_frame	*xmit_frame;
-
-						if((xmit_frame=rtw_IOL_accquire_xmit_frame(padapter)) == NULL) {
-							ret = -ENOMEM;	
-							break;
-						}
+#ifdef CONFIG_80211N_HT
+				else if (max_rx_rate < 0x1c) { /* mcs0~mcs15 */
+					u32 mcs_bitmap = 0x0;
 
-						for(i=0;i<write_num;i++){
-							#ifdef CONFIG_IOL_NEW_GENERATION
-							rtw_IOL_append_WD_cmd(xmit_frame, reg, i+start_value,0xFFFFFFFF);
-							#else
-							rtw_IOL_append_WD_cmd(xmit_frame, reg, i+start_value);
-							#endif
-						}
-						if(_SUCCESS !=rtw_IOL_exec_cmds_sync(padapter, xmit_frame, 5000,0))
-							ret = -EPERM;
-							
-					}
+					for (i = 0; i < ((max_rx_rate + 1) - 0xc); i++)
+						mcs_bitmap |= BIT(i);
 
-					if(start_value+write_num-1 == (final=rtw_read32(padapter, reg)) ) {
-						DBG_871X("continuous IOL_CMD_WD_REG to 0x%x %u times Success, start:%u, final:%u\n", reg, write_num, start_value, final);
-					} else {
-						DBG_871X("continuous IOL_CMD_WD_REG to 0x%x %u times Fail, start:%u, final:%u\n", reg, write_num, start_value, final);
-					}
+					set_mcs_rate_by_mask(pmlmeext->default_supported_mcs_set, mcs_bitmap);
 				}
-					break;
-				#endif //CONFIG_IOL
+#endif /* CONFIG_80211N_HT							 */
 			}
+		}
 			break;
-		case 0x79:
-			{
-				/*
-				* dbg 0x79000000 [value], set RESP_TXAGC to + value, value:0~15
-				* dbg 0x79010000 [value], set RESP_TXAGC to - value, value:0~15
-				*/
-				u8 value =  extra_arg & 0x0f;
-				u8 sign = minor_cmd;
-				u16 write_value = 0;
-
-				DBG_871X("%s set RESP_TXAGC to %s %u\n", __func__, sign?"minus":"plus", value);
+		case 0x1c: { /* enable/disable driver control AMPDU Density for peer sta's rx */
+			if (arg == 0) {
+				RTW_INFO("disable driver ctrl ampdu density\n");
+				padapter->driver_ampdu_spacing = 0xFF;
+			} else if (arg == 1) {
 
-				if (sign)
-					value = value | 0x10;
+				RTW_INFO("enable driver ctrl ampdu density = %d\n", extra_arg);
 
-				write_value = value | (value << 5);
-				rtw_write16(padapter, 0x6d9, write_value);
+				if (extra_arg > 0x07)
+					padapter->driver_ampdu_spacing = 0xFF;
+				else
+					padapter->driver_ampdu_spacing = extra_arg;
 			}
+		}
 			break;
-		case 0x7a:
-			receive_disconnect(padapter, pmlmeinfo->network.MacAddress
-				, WLAN_REASON_EXPIRATION_CHK, _FALSE);
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+		case 0x1e: {
+			RTW_INFO("===========================================\n");
+			rtw_noise_measure_curchan(padapter);
+			RTW_INFO("===========================================\n");
+		}
 			break;
-		case 0x7F:
-			switch(minor_cmd)
+#endif
+
+
+#if defined(CONFIG_SDIO_HCI) && defined(CONFIG_SDIO_INDIRECT_ACCESS) && defined(DBG_SDIO_INDIRECT_ACCESS)
+		case 0x1f:
 			{
-				case 0x0:
-					DBG_871X("fwstate=0x%x\n", get_fwstate(pmlmepriv));
-					break;
-				case 0x01:
-					DBG_871X("auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n", 
-						psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm,
-						psecuritypriv->ndisauthtype, psecuritypriv->ndisencryptstatus);
-					break;
-				case 0x02:
-					DBG_871X("pmlmeinfo->state=0x%x\n", pmlmeinfo->state);
-					DBG_871X("DrvBcnEarly=%d\n", pmlmeext->DrvBcnEarly);
-					DBG_871X("DrvBcnTimeOut=%d\n", pmlmeext->DrvBcnTimeOut);
-					break;
-				case 0x03:
-					DBG_871X("qos_option=%d\n", pmlmepriv->qospriv.qos_option);
-#ifdef CONFIG_80211N_HT
-					DBG_871X("ht_option=%d\n", pmlmepriv->htpriv.ht_option);
-#endif //CONFIG_80211N_HT
-					break;
-				case 0x04:
-					DBG_871X("cur_ch=%d\n", pmlmeext->cur_channel);
-					DBG_871X("cur_bw=%d\n", pmlmeext->cur_bwmode);
-					DBG_871X("cur_ch_off=%d\n", pmlmeext->cur_ch_offset);
-
-					DBG_871X("oper_ch=%d\n", rtw_get_oper_ch(padapter));
-					DBG_871X("oper_bw=%d\n", rtw_get_oper_bw(padapter));
-					DBG_871X("oper_ch_offet=%d\n", rtw_get_oper_choffset(padapter));
-				
-					break;
-				case 0x05:
-					psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
-					if(psta)
-					{
-						DBG_871X("SSID=%s\n", cur_network->network.Ssid.Ssid);
-						DBG_871X("sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->hwaddr));
-						DBG_871X("cur_channel=%d, cur_bwmode=%d, cur_ch_offset=%d\n", pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
-						DBG_871X("rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
-						DBG_871X("state=0x%x, aid=%d, macid=%d, raid=%d\n", psta->state, psta->aid, psta->mac_id, psta->raid);
-#ifdef CONFIG_80211N_HT
-						DBG_871X("qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
-						DBG_871X("bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n", psta->bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
-						DBG_871X("ampdu_enable = %d\n", psta->htpriv.ampdu_enable);	
-						DBG_871X("agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
-#endif //CONFIG_80211N_HT
+				int i, j = 0, test_cnts = 0;
+				static u8 test_code = 0x5A;
+				static u32 data_misatch_cnt = 0, d_acc_err_cnt = 0;
 
-						sta_rx_reorder_ctl_dump(RTW_DBGDUMP, psta);
-					}
-					else
-					{							
-						DBG_871X("can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
-					}					
-					break;
-				case 0x06:
-					{						
-					}
-					break;
-				case 0x07:
-					DBG_871X("bSurpriseRemoved=%s, bDriverStopped=%s\n"
-						, rtw_is_surprise_removed(padapter)?"True":"False"
-						, rtw_is_drv_stopped(padapter)?"True":"False");
-					break;
-				case 0x08:
-					{
-						struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-						struct recv_priv  *precvpriv = &padapter->recvpriv;
-						
-						DBG_871X("free_xmitbuf_cnt=%d, free_xmitframe_cnt=%d"
-							", free_xmit_extbuf_cnt=%d, free_xframe_ext_cnt=%d"
-							", free_recvframe_cnt=%d\n",
-							pxmitpriv->free_xmitbuf_cnt, pxmitpriv->free_xmitframe_cnt,
-							pxmitpriv->free_xmit_extbuf_cnt, pxmitpriv->free_xframe_ext_cnt,
-							precvpriv->free_recvframe_cnt);
-						#ifdef CONFIG_USB_HCI
-						DBG_871X("rx_urb_pending_cn=%d\n", ATOMIC_READ(&(precvpriv->rx_pending_cnt)));
-						#endif
-					}
-					break;	
-				case 0x09:
-					{
-						int i;
-						_list	*plist, *phead;
-						
-#ifdef CONFIG_AP_MODE
-						DBG_871X("sta_dz_bitmap=0x%x, tim_bitmap=0x%x\n", pstapriv->sta_dz_bitmap, pstapriv->tim_bitmap);
-#endif						
-						_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-
-						for(i=0; i< NUM_STA; i++)
-						{
-							phead = &(pstapriv->sta_hash[i]);
-							plist = get_next(phead);
-		
-							while ((rtw_end_of_queue_search(phead, plist)) == _FALSE)
-							{
-								psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
-
-								plist = get_next(plist);
-
-								if(extra_arg == psta->aid)
-								{
-									DBG_871X("sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->hwaddr));
-									DBG_871X("rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
-									DBG_871X("state=0x%x, aid=%d, macid=%d, raid=%d\n", psta->state, psta->aid, psta->mac_id, psta->raid);
-#ifdef CONFIG_80211N_HT
-									DBG_871X("qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);	
-									DBG_871X("bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n", psta->bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
-									DBG_871X("ampdu_enable = %d\n", psta->htpriv.ampdu_enable);									
-									DBG_871X("agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
-#endif //CONFIG_80211N_HT
-									
-#ifdef CONFIG_AP_MODE
-									DBG_871X("capability=0x%x\n", psta->capability);
-									DBG_871X("flags=0x%x\n", psta->flags);
-									DBG_871X("wpa_psk=0x%x\n", psta->wpa_psk);
-									DBG_871X("wpa2_group_cipher=0x%x\n", psta->wpa2_group_cipher);
-									DBG_871X("wpa2_pairwise_cipher=0x%x\n", psta->wpa2_pairwise_cipher);
-									DBG_871X("qos_info=0x%x\n", psta->qos_info);
-#endif
-									DBG_871X("dot118021XPrivacy=0x%x\n", psta->dot118021XPrivacy);
-
-									sta_rx_reorder_ctl_dump(RTW_DBGDUMP, psta);
-								}							
-			
-							}
-						}
-	
-						_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+				u32 d_data, i_data;
+				u32 imr;
 
-					}
-					break;
+				test_cnts = extra_arg;
+				for (i = 0; i < test_cnts; i++) {
+					if (RTW_CANNOT_IO(padapter))
+						break;
 
-				case 0x0b: //Enable=1, Disable=0 driver control vrtl_carrier_sense.
-					{
-						//u8 driver_vcs_en; //Enable=1, Disable=0 driver control vrtl_carrier_sense.
-						//u8 driver_vcs_type;//force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1.
+					rtw_write8(padapter, 0x07, test_code);
 
-						if(arg == 0){
-							DBG_871X("disable driver ctrl vcs\n");						
-							padapter->driver_vcs_en = 0;					
-						}
-						else if(arg == 1){							
-							DBG_871X("enable driver ctrl vcs = %d\n", extra_arg);
-							padapter->driver_vcs_en = 1;
-	
-							if(extra_arg>2)
-								padapter->driver_vcs_type = 1;						
-							else
-								padapter->driver_vcs_type = extra_arg;
-						}
-					}
-					break;
-				case 0x0c://dump rx/tx packet
-					{
-						if(arg == 0){
-							DBG_871X("dump rx packet (%d)\n",extra_arg);						
-							//pHalData->bDumpRxPkt =extra_arg;						
-							rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DUMP_RXPKT, &(extra_arg));
-						}
-						else if(arg==1){
-							DBG_871X("dump tx packet (%d)\n",extra_arg);						
-							rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DUMP_TXPKT, &(extra_arg));
-						}
-					}
-					break;
-				case 0x0e:
-					{
-						if(arg == 0){
-							DBG_871X("disable driver ctrl rx_ampdu_factor\n");						
-							padapter->driver_rx_ampdu_factor = 0xFF;
-						}
-						else if(arg == 1){
-							
-							DBG_871X("enable driver ctrl rx_ampdu_factor = %d\n", extra_arg);	
-	
-							if(extra_arg > 0x03)
-								padapter->driver_rx_ampdu_factor = 0xFF;						
-							else
-								padapter->driver_rx_ampdu_factor = extra_arg;
-						}					
-					}
-					break;
-		#ifdef DBG_CONFIG_ERROR_DETECT
-				case 0x0f:
-						{
-							if(extra_arg == 0){	
-								DBG_871X("###### silent reset test.......#####\n");
-								rtw_hal_sreset_reset(padapter);						
-							} else {
-								HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-								struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-								psrtpriv->dbg_trigger_point = extra_arg;
-							}
-							
-						}
-					break;
-				case 0x15:
-					{
-						struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-						DBG_871X("==>silent resete cnts:%d\n",pwrpriv->ips_enter_cnts);
-					}
-					break;	
-					
-		#endif	
+					d_data = rtw_read32(padapter, 0x04);
+					imr =  rtw_read32(padapter, 0x10250014);
+					rtw_write32(padapter, 0x10250014, 0);
+					rtw_msleep_os(50);
 
-				case 0x10:// driver version display
-					dump_drv_version(RTW_DBGDUMP);
-					break;
-				case 0x11://dump linked status
-					{
-						int pre_mode;
-						pre_mode=padapter->bLinkInfoDump;
-						// linked_info_dump(padapter,extra_arg);
-						 if(extra_arg==1 || (extra_arg==0 && pre_mode==1) ) //not consider pwr_saving 0:
-						{
-							padapter->bLinkInfoDump = extra_arg;	
-		
-						}
-						else if( (extra_arg==2 ) || (extra_arg==0 && pre_mode==2))//consider power_saving
-						{		
-						//DBG_871X("linked_info_dump =%s \n", (padapter->bLinkInfoDump)?"enable":"disable")
-							linked_info_dump(padapter,extra_arg);	
-						}
+					i_data = rtw_sd_iread32(padapter, 0x04);
 
+					rtw_write32(padapter, 0x10250014, imr);
 
-						 
-					}					
-					break;
-#ifdef CONFIG_80211N_HT
-				case 0x12: //set rx_stbc
-				{
-					struct registry_priv	*pregpriv = &padapter->registrypriv;
-					// 0: disable, bit(0):enable 2.4g, bit(1):enable 5g, 0x3: enable both 2.4g and 5g
-					//default is set to enable 2.4GHZ for IOT issue with bufflao's AP at 5GHZ
-					if( pregpriv && (extra_arg == 0 || extra_arg == 1|| extra_arg == 2 || extra_arg == 3))
-					{
-						pregpriv->rx_stbc= extra_arg;
-						DBG_871X("set rx_stbc=%d\n",pregpriv->rx_stbc);
+					if (d_data != i_data) {
+						data_misatch_cnt++;
+						RTW_ERR("d_data :0x%08x, i_data : 0x%08x\n", d_data, i_data);
 					}
-					else
-						DBG_871X("get rx_stbc=%d\n",pregpriv->rx_stbc);
-					
-				}
-				break;
-				case 0x13: //set ampdu_enable
-				{
-					struct registry_priv	*pregpriv = &padapter->registrypriv;
-					// 0: disable, 0x1:enable (but wifi_spec should be 0), 0x2: force enable (don't care wifi_spec)
-					if( pregpriv && extra_arg < 3 )
-					{
-						pregpriv->ampdu_enable= extra_arg;
-						DBG_871X("set ampdu_enable=%d\n",pregpriv->ampdu_enable);
+
+					if (test_code != (i_data >> 24)) {
+						d_acc_err_cnt++;
+						rtw_write8(padapter, 0x07, 0xAA);
+						RTW_ERR("test_code :0x%02x, i_data : 0x%08x\n", test_code, i_data);
 					}
-					else
-						DBG_871X("get ampdu_enable=%d\n",pregpriv->ampdu_enable);
-					
+					if ((j++) == 100) {
+						rtw_msleep_os(2000);
+						RTW_INFO(" Indirect access testing..........%d/%d\n", i, test_cnts);
+						j = 0;
+					}
+
+					test_code = ~test_code;
+					rtw_msleep_os(50);
 				}
-				break;
+				RTW_INFO("========Indirect access test=========\n");
+				RTW_INFO(" test_cnts = %d\n", test_cnts);
+				RTW_INFO(" direct & indirect read32 data missatch cnts = %d\n", data_misatch_cnt);
+				RTW_INFO(" indirect rdata is not equal to wdata cnts = %d\n", d_acc_err_cnt);
+				RTW_INFO("========Indirect access test=========\n\n");
+				data_misatch_cnt = d_acc_err_cnt = 0;
+
+			}
+			break;
 #endif
-				case 0x14: //get wifi_spec
-				{
-					struct registry_priv	*pregpriv = &padapter->registrypriv;
-					DBG_871X("get wifi_spec=%d\n",pregpriv->wifi_spec);
-					
+		case 0x20:
+			{
+				if (arg == 0xAA) {
+					u8 page_offset, page_num;
+					u32 page_size = 0;
+					u8 *buffer = NULL;
+					u32 buf_size = 0;
+
+					page_offset = (u8)(extra_arg >> 16);
+					page_num = (u8)(extra_arg & 0xFF);
+					rtw_dump_rsvd_page(RTW_DBGDUMP, padapter, page_offset, page_num);
 				}
-				break;
-				case 0x16:
-				{
-					if(arg == 0xff){
-						rtw_odm_dbg_comp_msg(RTW_DBGDUMP,padapter);
-					}
-					else{
-						u64 dbg_comp = (u64)extra_arg;
-						rtw_odm_dbg_comp_set(padapter, dbg_comp);
-					}
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+				else {
+					u8 fifo_sel;
+					u32 addr, size;
+
+					fifo_sel = (u8)(arg & 0x0F);
+					addr = (extra_arg >> 16) & 0xFFFF;
+					size = extra_arg & 0xFFFF;
+					rtw_dump_fifo(RTW_DBGDUMP, padapter, fifo_sel, addr, size);
 				}
-					break;
-#ifdef DBG_FIXED_CHAN
-				case 0x17:
-					{
-						struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);						
-						printk("===>  Fixed channel to %d \n",extra_arg);
-						pmlmeext->fixed_chan = extra_arg;	
-						
-					}
-					break;
-#endif
-				case 0x18:
-					{
-						printk("===>  Switch USB Mode %d \n",extra_arg);
-						rtw_hal_set_hwreg(padapter, HW_VAR_USB_MODE, (u8 *)&extra_arg);
-					}
-					break;
-#ifdef CONFIG_80211N_HT			
-				case 0x19:
-					{
-						struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-						// extra_arg :
-						// BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, 
-						// BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx
-						if(arg == 0){
-							DBG_871X("driver disable LDPC\n");						
-							pregistrypriv->ldpc_cap = 0x00;
-						}
-						else if(arg == 1){							
-							DBG_871X("driver set LDPC cap = 0x%x\n", extra_arg);
-							pregistrypriv->ldpc_cap = (u8)(extra_arg&0x33);						
-						}						
-					}
-                                        break;
-				case 0x1a:
-					{
-						struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-						// extra_arg :
-						// BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, 
-						// BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx
-						if(arg == 0){
-							DBG_871X("driver disable STBC\n");						
-							pregistrypriv->stbc_cap = 0x00;
-						}
-						else if(arg == 1){							
-							DBG_871X("driver set STBC cap = 0x%x\n", extra_arg);
-							pregistrypriv->stbc_cap = (u8)(extra_arg&0x33);						
-						}						
-					}
-                                        break;
-#endif //CONFIG_80211N_HT
-				case 0x1b:
-					{	
-						struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-						
-						if(arg == 0){
-							DBG_871X("disable driver ctrl max_rx_rate, reset to default_rate_set\n");							
-							init_mlme_default_rate_set(padapter);
-#ifdef CONFIG_80211N_HT						
-							pregistrypriv->ht_enable = (u8)rtw_ht_enable;
-#endif //CONFIG_80211N_HT
-						}
-						else if(arg == 1){
-
-							int i;
-							u8 max_rx_rate;						
-							
-							DBG_871X("enable driver ctrl max_rx_rate = 0x%x\n", extra_arg);	
-
-							max_rx_rate = (u8)extra_arg;
-
-							if(max_rx_rate < 0xc) // max_rx_rate < MSC0 -> B or G -> disable HT
-							{
-#ifdef CONFIG_80211N_HT						
-								pregistrypriv->ht_enable = 0;
-#endif //CONFIG_80211N_HT
-								for(i=0; i<NumRates; i++)
-								{
-									if(pmlmeext->datarate[i] > max_rx_rate)
-										pmlmeext->datarate[i] = 0xff;									
-								}	
-
-							}
-#ifdef CONFIG_80211N_HT	
-							else if(max_rx_rate < 0x1c) // mcs0~mcs15
-							{
-								u32 mcs_bitmap=0x0;
-													
-								for(i=0; i<((max_rx_rate+1)-0xc); i++)
-									mcs_bitmap |= BIT(i);
-								
-								set_mcs_rate_by_mask(pmlmeext->default_supported_mcs_set, mcs_bitmap);
-							}
-#endif //CONFIG_80211N_HT							
-						}											
-					}
-                                        break;
-				case 0x1c: //enable/disable driver control AMPDU Density for peer sta's rx
-					{
-						if(arg == 0){
-							DBG_871X("disable driver ctrl ampdu density\n");						
-							padapter->driver_ampdu_spacing = 0xFF;
-						}
-						else if(arg == 1){
-							
-							DBG_871X("enable driver ctrl ampdu density = %d\n", extra_arg);	
-	
-							if(extra_arg > 0x07)
-								padapter->driver_ampdu_spacing = 0xFF;						
-							else
-								padapter->driver_ampdu_spacing = extra_arg;
-						}
-					}
-					break;
-#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
-				case 0x1e:
-					{
-						HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-						PDM_ODM_T pDM_Odm = &pHalData->odmpriv;
-						u8 chan = rtw_get_oper_ch(padapter);
-						DBG_871X("===========================================\n");
-						ODM_InbandNoise_Monitor(pDM_Odm,_TRUE,0x1e,100);
-						DBG_871X("channel(%d),noise_a = %d, noise_b = %d , noise_all:%d \n", 
-							chan,pDM_Odm->noise_level.noise[ODM_RF_PATH_A], 
-							pDM_Odm->noise_level.noise[ODM_RF_PATH_B],
-							pDM_Odm->noise_level.noise_all);
-						DBG_871X("===========================================\n");
-						
-					}
-					break;
 #endif
-				case 0x23:
-					{
-						DBG_871X("turn %s the bNotifyChannelChange Variable\n",(extra_arg==1)?"on":"off");
-						padapter->bNotifyChannelChange = extra_arg;
-						break;
-					}
-				case 0x24:
-					{
+			}
+			break;
+
+		case 0x23: {
+			RTW_INFO("turn %s the bNotifyChannelChange Variable\n", (extra_arg == 1) ? "on" : "off");
+			padapter->bNotifyChannelChange = extra_arg;
+			break;
+		}
+		case 0x24: {
 #ifdef CONFIG_P2P
-						DBG_871X("turn %s the bShowGetP2PState Variable\n",(extra_arg==1)?"on":"off");
-						padapter->bShowGetP2PState = extra_arg;
-#endif // CONFIG_P2P
-						break;						
-					}
-#ifdef CONFIG_GPIO_API              
-		            case 0x25: //Get GPIO register
-		                    {
-			                    /*
-			                    * dbg 0x7f250000 [gpio_num], Get gpio value, gpio_num:0~7
-			                    */                
-                              
-			                    u8 value;
-			                    DBG_871X("Read GPIO Value  extra_arg = %d\n",extra_arg);
-			                    value = rtw_hal_get_gpio(padapter,extra_arg);
-			                    DBG_871X("Read GPIO Value = %d\n",value);                                        
-			                    break;
-		                    }
-		            case 0x26: //Set GPIO direction
-		                    {
-                                       						
-			                    /* dbg 0x7f26000x [y], Set gpio direction, 
-			                    * x: gpio_num,4~7  y: indicate direction, 0~1  
-			                    */ 
-                                        
-			                    int value;
-			                    DBG_871X("Set GPIO Direction! arg = %d ,extra_arg=%d\n",arg ,extra_arg);
-			                    value = rtw_hal_config_gpio(padapter, arg, extra_arg);
-			                    DBG_871X("Set GPIO Direction %s \n",(value==-1)?"Fail!!!":"Success");
-			                    break;
-					}
-				case 0x27: //Set GPIO output direction value
-					{
-						/*
-						* dbg 0x7f27000x [y], Set gpio output direction value, 
- 						* x: gpio_num,4~7  y: indicate direction, 0~1  
-						*/ 
-                                        
-						int value;
-						DBG_871X("Set GPIO Value! arg = %d ,extra_arg=%d\n",arg ,extra_arg);
-						value = rtw_hal_set_gpio_output_value(padapter,arg,extra_arg);
-						DBG_871X("Set GPIO Value %s \n",(value==-1)?"Fail!!!":"Success");
-						break;
-					}
-#endif          
+			RTW_INFO("turn %s the bShowGetP2PState Variable\n", (extra_arg == 1) ? "on" : "off");
+			padapter->bShowGetP2PState = extra_arg;
+#endif /* CONFIG_P2P */
+			break;
+		}
+#ifdef CONFIG_GPIO_API
+		case 0x25: { /* Get GPIO register */
+			/*
+			* dbg 0x7f250000 [gpio_num], Get gpio value, gpio_num:0~7
+			*/
+
+			u8 value;
+			RTW_INFO("Read GPIO Value  extra_arg = %d\n", extra_arg);
+			value = rtw_hal_get_gpio(padapter, extra_arg);
+			RTW_INFO("Read GPIO Value = %d\n", value);
+			break;
+		}
+		case 0x26: { /* Set GPIO direction */
+
+			/* dbg 0x7f26000x [y], Set gpio direction,
+			* x: gpio_num,4~7  y: indicate direction, 0~1
+			*/
+
+			int value;
+			RTW_INFO("Set GPIO Direction! arg = %d ,extra_arg=%d\n", arg , extra_arg);
+			value = rtw_hal_config_gpio(padapter, arg, extra_arg);
+			RTW_INFO("Set GPIO Direction %s\n", (value == -1) ? "Fail!!!" : "Success");
+			break;
+		}
+		case 0x27: { /* Set GPIO output direction value */
+			/*
+			* dbg 0x7f27000x [y], Set gpio output direction value,
+			* x: gpio_num,4~7  y: indicate direction, 0~1
+			*/
+
+			int value;
+			RTW_INFO("Set GPIO Value! arg = %d ,extra_arg=%d\n", arg , extra_arg);
+			value = rtw_hal_set_gpio_output_value(padapter, arg, extra_arg);
+			RTW_INFO("Set GPIO Value %s\n", (value == -1) ? "Fail!!!" : "Success");
+			break;
+		}
+#endif
 #ifdef DBG_CMD_QUEUE
-				case 0x28:
-					{
-						dump_cmd_id = extra_arg;
-						DBG_871X("dump_cmd_id:%d\n",dump_cmd_id);
-					}
-					break;
-#endif //DBG_CMD_QUEUE
-				case 0xaa:
-					{
-						if((extra_arg & 0x7F)> 0x3F) extra_arg = 0xFF;
-						DBG_871X("chang data rate to :0x%02x\n",extra_arg);
-						padapter->fix_rate = extra_arg;
-					}
-					break;	
-				case 0xdd://registers dump , 0 for mac reg,1 for bb reg, 2 for rf reg
-					{
-						if(extra_arg==0){
-							mac_reg_dump(RTW_DBGDUMP, padapter);
-						}
-						else if(extra_arg==1){
-							bb_reg_dump(RTW_DBGDUMP, padapter);
-						}
-						else if(extra_arg==2){
-							rf_reg_dump(RTW_DBGDUMP, padapter);
-						}
-					}
-					break;		
+		case 0x28: {
+			dump_cmd_id = extra_arg;
+			RTW_INFO("dump_cmd_id:%d\n", dump_cmd_id);
+		}
+			break;
+#endif /* DBG_CMD_QUEUE */
+		case 0xaa: {
+			if ((extra_arg & 0x7F) > 0x3F)
+				extra_arg = 0xFF;
+			RTW_INFO("chang data rate to :0x%02x\n", extra_arg);
+			padapter->fix_rate = extra_arg;
+		}
+			break;
+		case 0xdd: { /* registers dump , 0 for mac reg,1 for bb reg, 2 for rf reg */
+			if (extra_arg == 0)
+				mac_reg_dump(RTW_DBGDUMP, padapter);
+			else if (extra_arg == 1)
+				bb_reg_dump(RTW_DBGDUMP, padapter);
+			else if (extra_arg == 2)
+				rf_reg_dump(RTW_DBGDUMP, padapter);
+			else if (extra_arg == 11)
+				bb_reg_dump_ex(RTW_DBGDUMP, padapter);
+		}
+			break;
 
-				case 0xee:
-					{
-						DBG_871X(" === please control /proc  to trun on/off PHYDM func === \n");
-					}
-					break;
+		case 0xee: {
+			RTW_INFO(" === please control /proc  to trun on/off PHYDM func ===\n");
+		}
+			break;
 
-				case 0xfd:
-					rtw_write8(padapter, 0xc50, arg);
-					DBG_871X("wr(0xc50)=0x%x\n", rtw_read8(padapter, 0xc50));
-					rtw_write8(padapter, 0xc58, arg);
-					DBG_871X("wr(0xc58)=0x%x\n", rtw_read8(padapter, 0xc58));
-					break;
-				case 0xfe:
-					DBG_871X("rd(0xc50)=0x%x\n", rtw_read8(padapter, 0xc50));
-					DBG_871X("rd(0xc58)=0x%x\n", rtw_read8(padapter, 0xc58));
-					break;
-				case 0xff:
-					{
-						DBG_871X("dbg(0x210)=0x%x\n", rtw_read32(padapter, 0x210));
-						DBG_871X("dbg(0x608)=0x%x\n", rtw_read32(padapter, 0x608));
-						DBG_871X("dbg(0x280)=0x%x\n", rtw_read32(padapter, 0x280));
-						DBG_871X("dbg(0x284)=0x%x\n", rtw_read32(padapter, 0x284));
-						DBG_871X("dbg(0x288)=0x%x\n", rtw_read32(padapter, 0x288));
-	
-						DBG_871X("dbg(0x664)=0x%x\n", rtw_read32(padapter, 0x664));
-
-
-						DBG_871X("\n");
-		
-						DBG_871X("dbg(0x430)=0x%x\n", rtw_read32(padapter, 0x430));
-						DBG_871X("dbg(0x438)=0x%x\n", rtw_read32(padapter, 0x438));
-
-						DBG_871X("dbg(0x440)=0x%x\n", rtw_read32(padapter, 0x440));
-	
-						DBG_871X("dbg(0x458)=0x%x\n", rtw_read32(padapter, 0x458));
-	
-						DBG_871X("dbg(0x484)=0x%x\n", rtw_read32(padapter, 0x484));
-						DBG_871X("dbg(0x488)=0x%x\n", rtw_read32(padapter, 0x488));
-	
-						DBG_871X("dbg(0x444)=0x%x\n", rtw_read32(padapter, 0x444));
-						DBG_871X("dbg(0x448)=0x%x\n", rtw_read32(padapter, 0x448));
-						DBG_871X("dbg(0x44c)=0x%x\n", rtw_read32(padapter, 0x44c));
-						DBG_871X("dbg(0x450)=0x%x\n", rtw_read32(padapter, 0x450));
-					}
-					break;
-			}			
+		case 0xfd:
+			rtw_write8(padapter, 0xc50, arg);
+			RTW_INFO("wr(0xc50)=0x%x\n", rtw_read8(padapter, 0xc50));
+			rtw_write8(padapter, 0xc58, arg);
+			RTW_INFO("wr(0xc58)=0x%x\n", rtw_read8(padapter, 0xc58));
 			break;
-		default:
-			DBG_871X("error dbg cmd!\n");
-			break;	
+		case 0xfe:
+			RTW_INFO("rd(0xc50)=0x%x\n", rtw_read8(padapter, 0xc50));
+			RTW_INFO("rd(0xc58)=0x%x\n", rtw_read8(padapter, 0xc58));
+			break;
+		case 0xff: {
+			RTW_INFO("dbg(0x210)=0x%x\n", rtw_read32(padapter, 0x210));
+			RTW_INFO("dbg(0x608)=0x%x\n", rtw_read32(padapter, 0x608));
+			RTW_INFO("dbg(0x280)=0x%x\n", rtw_read32(padapter, 0x280));
+			RTW_INFO("dbg(0x284)=0x%x\n", rtw_read32(padapter, 0x284));
+			RTW_INFO("dbg(0x288)=0x%x\n", rtw_read32(padapter, 0x288));
+
+			RTW_INFO("dbg(0x664)=0x%x\n", rtw_read32(padapter, 0x664));
+
+
+			RTW_INFO("\n");
+
+			RTW_INFO("dbg(0x430)=0x%x\n", rtw_read32(padapter, 0x430));
+			RTW_INFO("dbg(0x438)=0x%x\n", rtw_read32(padapter, 0x438));
+
+			RTW_INFO("dbg(0x440)=0x%x\n", rtw_read32(padapter, 0x440));
+
+			RTW_INFO("dbg(0x458)=0x%x\n", rtw_read32(padapter, 0x458));
+
+			RTW_INFO("dbg(0x484)=0x%x\n", rtw_read32(padapter, 0x484));
+			RTW_INFO("dbg(0x488)=0x%x\n", rtw_read32(padapter, 0x488));
+
+			RTW_INFO("dbg(0x444)=0x%x\n", rtw_read32(padapter, 0x444));
+			RTW_INFO("dbg(0x448)=0x%x\n", rtw_read32(padapter, 0x448));
+			RTW_INFO("dbg(0x44c)=0x%x\n", rtw_read32(padapter, 0x44c));
+			RTW_INFO("dbg(0x450)=0x%x\n", rtw_read32(padapter, 0x450));
+		}
+			break;
+		}
+		break;
+	default:
+		RTW_INFO("error dbg cmd!\n");
+		break;
 	}
-	
+
 
 	return ret;
 
@@ -8019,39 +6735,36 @@ static int rtw_dbg_port(struct net_device *dev,
 
 static int wpa_set_param(struct net_device *dev, u8 name, u32 value)
 {
-	uint ret=0;
+	uint ret = 0;
 	u32 flags;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	
-	switch (name){
+
+	switch (name) {
 	case IEEE_PARAM_WPA_ENABLED:
 
-		padapter->securitypriv.dot11AuthAlgrthm= dot11AuthAlgrthm_8021X; //802.1x
-		
-		//ret = ieee80211_wpa_enable(ieee, value);
-		
-		switch((value)&0xff)
-		{
-			case 1 : //WPA
-			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK; //WPA_PSK
+		padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X; /* 802.1x */
+
+		/* ret = ieee80211_wpa_enable(ieee, value); */
+
+		switch ((value) & 0xff) {
+		case 1: /* WPA */
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK; /* WPA_PSK */
 			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption2Enabled;
-				break;
-			case 2: //WPA2
-			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK; //WPA2_PSK
+			break;
+		case 2: /* WPA2 */
+			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK; /* WPA2_PSK */
 			padapter->securitypriv.ndisencryptstatus = Ndis802_11Encryption3Enabled;
-				break;
+			break;
 		}
-		
-		RT_TRACE(_module_rtl871x_ioctl_os_c,_drv_info_,("wpa_set_param:padapter->securitypriv.ndisauthtype=%d\n", padapter->securitypriv.ndisauthtype));
-		
+
+
 		break;
 
 	case IEEE_PARAM_TKIP_COUNTERMEASURES:
-		//ieee->tkip_countermeasures=value;
+		/* ieee->tkip_countermeasures=value; */
 		break;
 
-	case IEEE_PARAM_DROP_UNENCRYPTED: 
-	{
+	case IEEE_PARAM_DROP_UNENCRYPTED: {
 		/* HACK:
 		 *
 		 * wpa_supplicant calls set_wpa_enabled when the driver
@@ -8063,128 +6776,126 @@ static int wpa_set_param(struct net_device *dev, u8 name, u32 value)
 		 * can use this to determine if the CAP_PRIVACY_ON bit should
 		 * be set.
 		 */
-		 
-#if 0	 
+
+#if 0
 		struct ieee80211_security sec = {
 			.flags = SEC_ENABLED,
 			.enabled = value,
 		};
- 		ieee->drop_unencrypted = value;
+		ieee->drop_unencrypted = value;
 		/* We only change SEC_LEVEL for open mode. Others
 		 * are set by ipw_wpa_set_encryption.
 		 */
 		if (!value) {
 			sec.flags |= SEC_LEVEL;
 			sec.level = SEC_LEVEL_0;
-		}
-		else {
+		} else {
 			sec.flags |= SEC_LEVEL;
 			sec.level = SEC_LEVEL_1;
 		}
 		if (ieee->set_security)
 			ieee->set_security(ieee->dev, &sec);
-#endif		
+#endif
 		break;
 
 	}
-	case IEEE_PARAM_PRIVACY_INVOKED:	
-		
-		//ieee->privacy_invoked=value;
-		
+	case IEEE_PARAM_PRIVACY_INVOKED:
+
+		/* ieee->privacy_invoked=value; */
+
 		break;
 
 	case IEEE_PARAM_AUTH_ALGS:
-		
+
 		ret = wpa_set_auth_algs(dev, value);
-		
+
 		break;
 
 	case IEEE_PARAM_IEEE_802_1X:
-		
-		//ieee->ieee802_1x=value;		
-		
+
+		/* ieee->ieee802_1x=value;		 */
+
 		break;
-		
+
 	case IEEE_PARAM_WPAX_SELECT:
-		
-		// added for WPA2 mixed mode
-		//DBG_871X(KERN_WARNING "------------------------>wpax value = %x\n", value);
+
+		/* added for WPA2 mixed mode */
+		/*RTW_WARN("------------------------>wpax value = %x\n", value);*/
 		/*
 		spin_lock_irqsave(&ieee->wpax_suitlist_lock,flags);
 		ieee->wpax_type_set = 1;
 		ieee->wpax_type_notify = value;
 		spin_unlock_irqrestore(&ieee->wpax_suitlist_lock,flags);
 		*/
-		
+
 		break;
 
-	default:		
+	default:
+
 
 
-		
 		ret = -EOPNOTSUPP;
 
-		
+
 		break;
-	
+
 	}
 
 	return ret;
-	
+
 }
 
 static int wpa_mlme(struct net_device *dev, u32 command, u32 reason)
-{	
+{
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	switch (command)
-	{
-		case IEEE_MLME_STA_DEAUTH:
+	switch (command) {
+	case IEEE_MLME_STA_DEAUTH:
 
-			if(!rtw_set_802_11_disassociate(padapter))
-				ret = -1;		
-			
-			break;
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
 
-		case IEEE_MLME_STA_DISASSOC:
-		
-			if(!rtw_set_802_11_disassociate(padapter))
-				ret = -1;		
-	
-			break;
+		break;
 
-		default:
-			ret = -EOPNOTSUPP;
-			break;
-	}
+	case IEEE_MLME_STA_DISASSOC:
+
+		if (!rtw_set_802_11_disassociate(padapter))
+			ret = -1;
 
+		break;
+
+	default:
+		ret = -EOPNOTSUPP;
+		break;
+	}
+#ifdef CONFIG_RTW_REPEATER_SON
+	rtw_rson_do_disconnect(padapter);
+#endif
 	return ret;
-	
+
 }
 
 static int wpa_supplicant_ioctl(struct net_device *dev, struct iw_point *p)
 {
 	struct ieee_param *param;
-	uint ret=0;
+	uint ret = 0;
 
-	//down(&ieee->wx_sem);	
+	/* down(&ieee->wx_sem);	 */
 
-	if (p->length < sizeof(struct ieee_param) || !p->pointer){
+	if (p->length < sizeof(struct ieee_param) || !p->pointer) {
 		ret = -EINVAL;
 		goto out;
 	}
-	
+
 	param = (struct ieee_param *)rtw_malloc(p->length);
-	if (param == NULL)
-	{
+	if (param == NULL) {
 		ret = -ENOMEM;
 		goto out;
 	}
-	
-	if (copy_from_user(param, p->pointer, p->length))
-	{
-		rtw_mfree((u8*)param, p->length);
+
+	if (copy_from_user(param, p->pointer, p->length)) {
+		rtw_mfree((u8 *)param, p->length);
 		ret = -EFAULT;
 		goto out;
 	}
@@ -8196,8 +6907,8 @@ static int wpa_supplicant_ioctl(struct net_device *dev, struct iw_point *p)
 		break;
 
 	case IEEE_CMD_SET_WPA_IE:
-		//ret = wpa_set_wpa_ie(dev, param, p->length);
-		ret =  rtw_set_wpa_ie((_adapter *)rtw_netdev_priv(dev), (char*)param->u.wpa_ie.data, (u16)param->u.wpa_ie.len);
+		/* ret = wpa_set_wpa_ie(dev, param, p->length); */
+		ret =  rtw_set_wpa_ie((_adapter *)rtw_netdev_priv(dev), (char *)param->u.wpa_ie.data, (u16)param->u.wpa_ie.len);
 		break;
 
 	case IEEE_CMD_SET_ENCRYPTION:
@@ -8209,423 +6920,331 @@ static int wpa_supplicant_ioctl(struct net_device *dev, struct iw_point *p)
 		break;
 
 	default:
-		DBG_871X("Unknown WPA supplicant request: %d\n", param->cmd);
+		RTW_INFO("Unknown WPA supplicant request: %d\n", param->cmd);
 		ret = -EOPNOTSUPP;
 		break;
-		
+
 	}
 
 	if (ret == 0 && copy_to_user(p->pointer, param, p->length))
 		ret = -EFAULT;
 
 	rtw_mfree((u8 *)param, p->length);
-	
+
 out:
-	
-	//up(&ieee->wx_sem);
-	
+
+	/* up(&ieee->wx_sem); */
+
 	return ret;
-	
+
 }
 
 #ifdef CONFIG_AP_MODE
 static int rtw_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
 {
 	int ret = 0;
-	u32 wep_key_idx, wep_key_len,wep_total_len;
-	NDIS_802_11_WEP	 *pwep = NULL;
-	struct sta_info *psta = NULL, *pbcmc_sta = NULL;	
+	u32 wep_key_idx, wep_key_len, wep_total_len;
+	NDIS_802_11_WEP	*pwep = NULL;
+	struct sta_info *psta = NULL, *pbcmc_sta = NULL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
-	struct security_priv* psecuritypriv=&(padapter->securitypriv);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	param->u.crypt.err = 0;
 	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
 
-	//sizeof(struct ieee_param) = 64 bytes;
-	//if (param_len !=  (u32) ((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len)
-	if (param_len !=  sizeof(struct ieee_param) + param->u.crypt.key_len)
-	{
+	/* sizeof(struct ieee_param) = 64 bytes; */
+	/* if (param_len !=  (u32) ((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len) */
+	if (param_len !=  sizeof(struct ieee_param) + param->u.crypt.key_len) {
 		ret =  -EINVAL;
 		goto exit;
 	}
 
 	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
 	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) {
 		if (param->u.crypt.idx >= WEP_KEYS
 #ifdef CONFIG_IEEE80211W
-			&& param->u.crypt.idx > BIP_MAX_KEYID
+		    && param->u.crypt.idx > BIP_MAX_KEYID
 #endif /* CONFIG_IEEE80211W */
-			)
-		{
+		   ) {
 			ret = -EINVAL;
 			goto exit;
-		}	
-	}
-	else 
-	{		
+		}
+	} else {
 		psta = rtw_get_stainfo(pstapriv, param->sta_addr);
-		if(!psta)
-		{
-			//ret = -EINVAL;
-			DBG_871X("rtw_set_encryption(), sta has already been removed or never been added\n");
+		if (!psta) {
+			/* ret = -EINVAL; */
+			RTW_INFO("rtw_set_encryption(), sta has already been removed or never been added\n");
 			goto exit;
-		}			
+		}
 	}
 
-	if (strcmp(param->u.crypt.alg, "none") == 0 && (psta==NULL))
-	{
-		//todo:clear default encryption keys
+	if (strcmp(param->u.crypt.alg, "none") == 0 && (psta == NULL)) {
+		/* todo:clear default encryption keys */
 
 		psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
 		psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
 		psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
 		psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
 
-		DBG_871X("clear default encryption keys, keyid=%d\n", param->u.crypt.idx);
-		
+		RTW_INFO("clear default encryption keys, keyid=%d\n", param->u.crypt.idx);
+
 		goto exit;
 	}
 
 
-	if (strcmp(param->u.crypt.alg, "WEP") == 0 && (psta==NULL))
-	{		
-		DBG_871X("r871x_set_encryption, crypt.alg = WEP\n");
-		
+	if (strcmp(param->u.crypt.alg, "WEP") == 0 && (psta == NULL)) {
+		RTW_INFO("r871x_set_encryption, crypt.alg = WEP\n");
+
 		wep_key_idx = param->u.crypt.idx;
 		wep_key_len = param->u.crypt.key_len;
-					
-		DBG_871X("r871x_set_encryption, wep_key_idx=%d, len=%d\n", wep_key_idx, wep_key_len);
 
-		if((wep_key_idx >= WEP_KEYS) || (wep_key_len<=0))
-		{
+		RTW_INFO("r871x_set_encryption, wep_key_idx=%d, len=%d\n", wep_key_idx, wep_key_len);
+
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
 			ret = -EINVAL;
 			goto exit;
 		}
-			
 
-		if (wep_key_len > 0) 
-		{			
-		 	wep_key_len = wep_key_len <= 5 ? 5 : 13;
+
+		if (wep_key_len > 0) {
+			wep_key_len = wep_key_len <= 5 ? 5 : 13;
 			wep_total_len = wep_key_len + FIELD_OFFSET(NDIS_802_11_WEP, KeyMaterial);
-		 	pwep =(NDIS_802_11_WEP *)rtw_malloc(wep_total_len);
-			if(pwep == NULL){
-				DBG_871X(" r871x_set_encryption: pwep allocate fail !!!\n");
+			pwep = (NDIS_802_11_WEP *)rtw_malloc(wep_total_len);
+			if (pwep == NULL) {
+				RTW_INFO(" r871x_set_encryption: pwep allocate fail !!!\n");
 				goto exit;
 			}
-			
-		 	_rtw_memset(pwep, 0, wep_total_len);
-		
-		 	pwep->KeyLength = wep_key_len;
+
+			_rtw_memset(pwep, 0, wep_total_len);
+
+			pwep->KeyLength = wep_key_len;
 			pwep->Length = wep_total_len;
-			
+
 		}
-		
+
 		pwep->KeyIndex = wep_key_idx;
 
 		_rtw_memcpy(pwep->KeyMaterial,  param->u.crypt.key, pwep->KeyLength);
 
-		if(param->u.crypt.set_tx)
-		{
-			DBG_871X("wep, set_tx=1\n");
+		if (param->u.crypt.set_tx) {
+			RTW_INFO("wep, set_tx=1\n");
 
 			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
 			psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
-			psecuritypriv->dot11PrivacyAlgrthm=_WEP40_;
-			psecuritypriv->dot118021XGrpPrivacy=_WEP40_;
-			
-			if(pwep->KeyLength==13)
-			{
-				psecuritypriv->dot11PrivacyAlgrthm=_WEP104_;
-				psecuritypriv->dot118021XGrpPrivacy=_WEP104_;
+			psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
+			psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
+
+			if (pwep->KeyLength == 13) {
+				psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
+				psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
 			}
 
-		
+
 			psecuritypriv->dot11PrivacyKeyIndex = wep_key_idx;
-			
+
 			_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), pwep->KeyMaterial, pwep->KeyLength);
 
-			psecuritypriv->dot11DefKeylen[wep_key_idx]=pwep->KeyLength;
+			psecuritypriv->dot11DefKeylen[wep_key_idx] = pwep->KeyLength;
 
 			rtw_ap_set_wep_key(padapter, pwep->KeyMaterial, pwep->KeyLength, wep_key_idx, 1);
-		}
-		else
-		{
-			DBG_871X("wep, set_tx=0\n");
-			
-			//don't update "psecuritypriv->dot11PrivacyAlgrthm" and 
-			//"psecuritypriv->dot11PrivacyKeyIndex=keyid", but can rtw_set_key to cam
-					
-		      _rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), pwep->KeyMaterial, pwep->KeyLength);
+		} else {
+			RTW_INFO("wep, set_tx=0\n");
+
+			/* don't update "psecuritypriv->dot11PrivacyAlgrthm" and  */
+			/* "psecuritypriv->dot11PrivacyKeyIndex=keyid", but can rtw_set_key to cam */
 
-			psecuritypriv->dot11DefKeylen[wep_key_idx] = pwep->KeyLength;			
+			_rtw_memcpy(&(psecuritypriv->dot11DefKey[wep_key_idx].skey[0]), pwep->KeyMaterial, pwep->KeyLength);
+
+			psecuritypriv->dot11DefKeylen[wep_key_idx] = pwep->KeyLength;
 
 			rtw_ap_set_wep_key(padapter, pwep->KeyMaterial, pwep->KeyLength, wep_key_idx, 0);
 		}
 
 		goto exit;
-		
+
 	}
 
-	
-	if(!psta && check_fwstate(pmlmepriv, WIFI_AP_STATE)) // //group key
-	{
-		if(param->u.crypt.set_tx ==1)
-		{
-			if(strcmp(param->u.crypt.alg, "WEP") == 0)
-			{
-				DBG_871X("%s, set group_key, WEP\n", __FUNCTION__);
-				
-				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-					
+
+	if (!psta && check_fwstate(pmlmepriv, WIFI_AP_STATE)) /*  */ { /* group key */
+		if (param->u.crypt.set_tx == 1) {
+			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set WEP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
 				psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-				if(param->u.crypt.key_len==13)
-				{						
-						psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-				}
-				
-			}
-			else if(strcmp(param->u.crypt.alg, "TKIP") == 0)
-			{						
-				DBG_871X("%s, set group_key, TKIP\n", __FUNCTION__);
-				
-				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
+				if (param->u.crypt.key_len == 13)
+					psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
 
-				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				
-				//DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len);
-				//set mic key
+			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				/* set mic key */
 				_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
 				_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
-
 				psecuritypriv->busetkipkey = _TRUE;
-											
-			}
-			else if(strcmp(param->u.crypt.alg, "CCMP") == 0)
-			{
-				DBG_871X("%s, set group_key, CCMP\n", __FUNCTION__);
-			
-				psecuritypriv->dot118021XGrpPrivacy = _AES_;
 
-				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-			}
-#ifdef CONFIG_IEEE80211W
-			else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
-				int no;
-				
-				DBG_871X("BIP key_len=%d , index=%d\n", param->u.crypt.key_len, param->u.crypt.idx);
-				/* save the IGTK key, length 16 bytes */
-				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16:param->u.crypt.key_len));
-				/* DBG_871X("IGTK key below:\n");
-				for(no=0;no<16;no++)
-					printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-				DBG_871X("\n"); */
-				padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
-				padapter->securitypriv.binstallBIPkey = _TRUE;
-				DBG_871X(" ~~~~set sta key:IGKT\n");
+			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				psecuritypriv->dot118021XGrpPrivacy = _AES_;
+				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TX IGTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+				psecuritypriv->dot11wBIPtxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psecuritypriv->binstallBIPkey = _TRUE;
 				goto exit;
-			}
-#endif /* CONFIG_IEEE80211W */
-			else
-			{
-				DBG_871X("%s, set group_key, none\n", __FUNCTION__);
-				
+			#endif /* CONFIG_IEEE80211W */
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key, idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx);
 				psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key, not support\n"
+					, FUNC_ADPT_ARG(padapter));
+				goto exit;
 			}
 
 			psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
+			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
+			if (pbcmc_sta) {
+				pbcmc_sta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				pbcmc_sta->ieee8021x_blocked = _FALSE;
+				pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
+			}
 			psecuritypriv->binstallGrpkey = _TRUE;
+			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
 
-			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;//!!!
-								
 			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
-			
-			pbcmc_sta=rtw_get_bcmc_stainfo(padapter);
-			if(pbcmc_sta)
-			{
-				pbcmc_sta->ieee8021x_blocked = _FALSE;
-				pbcmc_sta->dot118021XPrivacy= psecuritypriv->dot118021XGrpPrivacy;//rx will use bmc_sta's dot118021XPrivacy			
-			}	
-						
 		}
 
 		goto exit;
-		
-	}	
 
-	if(psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) // psk/802_1x
-	{
-		if(check_fwstate(pmlmepriv, WIFI_AP_STATE))
-		{
-			if(param->u.crypt.set_tx ==1)
-			{ 
-				_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				
-				if(strcmp(param->u.crypt.alg, "WEP") == 0)
-				{
-					DBG_871X("%s, set pairwise key, WEP\n", __FUNCTION__);
-					
+	}
+
+	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) { /* psk/802_1x */
+		if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
+			if (param->u.crypt.set_tx == 1) {
+				_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+
+				if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" set WEP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
 					psta->dot118021XPrivacy = _WEP40_;
-					if(param->u.crypt.key_len==13)
-					{						
+					if (param->u.crypt.key_len == 13)
 						psta->dot118021XPrivacy = _WEP104_;
-					}
-				}
-				else if(strcmp(param->u.crypt.alg, "TKIP") == 0)
-				{						
-					DBG_871X("%s, set pairwise key, TKIP\n", __FUNCTION__);
-					
+
+				} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" set TKIP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
 					psta->dot118021XPrivacy = _TKIP_;
-				
-					//DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len);
-					//set mic key
+					/* set mic key */
 					_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
 					_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
 					psecuritypriv->busetkipkey = _TRUE;
-											
-				}
-				else if(strcmp(param->u.crypt.alg, "CCMP") == 0)
-				{
 
-					DBG_871X("%s, set pairwise key, CCMP\n", __FUNCTION__);
-					
+				} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" set CCMP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
 					psta->dot118021XPrivacy = _AES_;
-				}
-				else
-				{
-					DBG_871X("%s, set pairwise key, none\n", __FUNCTION__);
-					
-					psta->dot118021XPrivacy = _NO_PRIVACY_;
-				}
-						
-				rtw_ap_set_pairwise_key(padapter, psta);
-					
-				psta->ieee8021x_blocked = _FALSE;
-				
-				psta->bpairwise_key_installed = _TRUE;
-					
-			}			
-			else//group key???
-			{ 
-				if(strcmp(param->u.crypt.alg, "WEP") == 0)
-				{
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-					
-					psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-					if(param->u.crypt.key_len==13)
-					{						
-						psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-					}
-				}
-				else if(strcmp(param->u.crypt.alg, "TKIP") == 0)
-				{						
-					psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
-
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				
-					//DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len);
-					//set mic key
-					_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
-					_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
 
-					psecuritypriv->busetkipkey = _TRUE;
-											
-				}
-				else if(strcmp(param->u.crypt.alg, "CCMP") == 0)
-				{
-					psecuritypriv->dot118021XGrpPrivacy = _AES_;
+				} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" clear pairwise key of "MAC_FMT" idx:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx);
+					psta->dot118021XPrivacy = _NO_PRIVACY_;
 
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len>16 ?16:param->u.crypt.key_len));
-				}
-				else
-				{
-					psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+				} else {
+					RTW_WARN(FUNC_ADPT_FMT" set pairwise key of "MAC_FMT", not support\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+					goto exit;
 				}
 
-				psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
-				psecuritypriv->binstallGrpkey = _TRUE;	
-								
-				psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;//!!!
-								
-				rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
-			
-				pbcmc_sta=rtw_get_bcmc_stainfo(padapter);
-				if(pbcmc_sta)
-				{
-					pbcmc_sta->ieee8021x_blocked = _FALSE;
-					pbcmc_sta->dot118021XPrivacy= psecuritypriv->dot118021XGrpPrivacy;//rx will use bmc_sta's dot118021XPrivacy			
-				}					
+				psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psta->ieee8021x_blocked = _FALSE;
+				psta->bpairwise_key_installed = _TRUE;
+				rtw_ap_set_pairwise_key(padapter, psta);
 
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
 			}
-			
+
 		}
-				
+
 	}
 
 exit:
 
-	if(pwep)
-	{
-		rtw_mfree((u8 *)pwep, wep_total_len);		
-	}	
-	
+	if (pwep)
+		rtw_mfree((u8 *)pwep, wep_total_len);
+
 	return ret;
-	
+
 }
 
 static int rtw_set_beacon(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;	
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	unsigned char *pbuf = param->u.bcn_ie.buf;
 
 
-	DBG_871X("%s, len=%d\n", __FUNCTION__, len);
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
 
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
 	_rtw_memcpy(&pstapriv->max_num_sta, param->u.bcn_ie.reserved, 2);
 
-	if((pstapriv->max_num_sta>NUM_STA) || (pstapriv->max_num_sta<=0))
+	if ((pstapriv->max_num_sta > NUM_STA) || (pstapriv->max_num_sta <= 0))
 		pstapriv->max_num_sta = NUM_STA;
 
 
-	if(rtw_check_beacon_data(padapter, pbuf,  (len-12-2)) == _SUCCESS)// 12 = param header, 2:no packed
+	if (rtw_check_beacon_data(padapter, pbuf, (len - 12 - 2)) == _SUCCESS) /* 12 = param header, 2:no packed */
 		ret = 0;
 	else
 		ret = -EINVAL;
-	
+
 
 	return ret;
-	
+
 }
 
 static int rtw_hostapd_sta_flush(struct net_device *dev)
 {
-	//_irqL irqL;
-	//_list	*phead, *plist;
-	int ret=0;	
-	//struct sta_info *psta = NULL;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
-	//struct sta_priv *pstapriv = &padapter->stapriv;
-
-	DBG_871X("%s\n", __FUNCTION__);
+	/* _irqL irqL; */
+	/* _list	*phead, *plist; */
+	int ret = 0;
+	/* struct sta_info *psta = NULL; */
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	/* struct sta_priv *pstapriv = &padapter->stapriv; */
 
-	flush_all_cam_entry(padapter);	//clear CAM
+	RTW_INFO("%s\n", __FUNCTION__);
 
+	flush_all_cam_entry(padapter);	/* clear CAM */
+#ifdef CONFIG_AP_MODE
 	ret = rtw_sta_flush(padapter, _TRUE);
-
+#endif
 	return ret;
 
 }
@@ -8633,152 +7252,131 @@ static int rtw_hostapd_sta_flush(struct net_device *dev)
 static int rtw_add_sta(struct net_device *dev, struct ieee_param *param)
 {
 	_irqL irqL;
-	int ret=0;	
+	int ret = 0;
 	struct sta_info *psta = NULL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	DBG_871X("rtw_add_sta(aid=%d)=" MAC_FMT "\n", param->u.add_sta.aid, MAC_ARG(param->sta_addr));
-	
-	if(check_fwstate(pmlmepriv, (_FW_LINKED|WIFI_AP_STATE)) != _TRUE)	
-	{
-		return -EINVAL;		
-	}
+	RTW_INFO("rtw_add_sta(aid=%d)=" MAC_FMT "\n", param->u.add_sta.aid, MAC_ARG(param->sta_addr));
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
 
 	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
 	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-		return -EINVAL;	
-	}
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
 
-/*
+#if 0
 	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
-	if(psta)
-	{
-		DBG_871X("rtw_add_sta(), free has been added psta=%p\n", psta);
-		//_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		
-		rtw_free_stainfo(padapter,  psta);		
-		//_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
+	if (psta) {
+		RTW_INFO("rtw_add_sta(), free has been added psta=%p\n", psta);
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);		 */
+		rtw_free_stainfo(padapter,  psta);
+		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
 
 		psta = NULL;
-	}	
-*/
-	//psta = rtw_alloc_stainfo(pstapriv, param->sta_addr);
+	}
+#endif
+	/* psta = rtw_alloc_stainfo(pstapriv, param->sta_addr); */
 	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
-	if(psta)
-	{
-		int flags = param->u.add_sta.flags;			
-		
-		//DBG_871X("rtw_add_sta(), init sta's variables, psta=%p\n", psta);
-		
-		psta->aid = param->u.add_sta.aid;//aid=1~2007
+	if (psta) {
+		int flags = param->u.add_sta.flags;
+
+		/* RTW_INFO("rtw_add_sta(), init sta's variables, psta=%p\n", psta); */
+
+		psta->cmn.aid = param->u.add_sta.aid;/* aid=1~2007 */
 
 		_rtw_memcpy(psta->bssrateset, param->u.add_sta.tx_supp_rates, 16);
-		
-		
-		//check wmm cap.
-		if(WLAN_STA_WME&flags)
+
+
+		/* check wmm cap. */
+		if (WLAN_STA_WME & flags)
 			psta->qos_option = 1;
 		else
 			psta->qos_option = 0;
 
-		if(pmlmepriv->qospriv.qos_option == 0)	
+		if (pmlmepriv->qospriv.qos_option == 0)
 			psta->qos_option = 0;
 
-		
-#ifdef CONFIG_80211N_HT		
-		//chec 802.11n ht cap.
-		if(WLAN_STA_HT&flags)
-		{
+
+#ifdef CONFIG_80211N_HT
+		/* chec 802.11n ht cap. */
+		if (WLAN_STA_HT & flags) {
 			psta->htpriv.ht_option = _TRUE;
 			psta->qos_option = 1;
-			_rtw_memcpy((void*)&psta->htpriv.ht_cap, (void*)&param->u.add_sta.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
-		}
-		else		
-		{
+			_rtw_memcpy((void *)&psta->htpriv.ht_cap, (void *)&param->u.add_sta.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
+		} else
 			psta->htpriv.ht_option = _FALSE;
-		}
-		
-		if(pmlmepriv->htpriv.ht_option == _FALSE)	
+
+		if (pmlmepriv->htpriv.ht_option == _FALSE)
 			psta->htpriv.ht_option = _FALSE;
-#endif		
+#endif
 
 
 		update_sta_info_apmode(padapter, psta);
-		
-		
-	}
-	else
-	{
+
+
+	} else
 		ret = -ENOMEM;
-	}	
-	
+
 	return ret;
-	
+
 }
 
 static int rtw_del_sta(struct net_device *dev, struct ieee_param *param)
 {
 	_irqL irqL;
-	int ret=0;	
+	int ret = 0;
 	struct sta_info *psta = NULL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	DBG_871X("rtw_del_sta=" MAC_FMT "\n", MAC_ARG(param->sta_addr));
-		
-	if(check_fwstate(pmlmepriv, (_FW_LINKED|WIFI_AP_STATE)) != _TRUE)		
-	{
-		return -EINVAL;		
-	}
+	RTW_INFO("rtw_del_sta=" MAC_FMT "\n", MAC_ARG(param->sta_addr));
+
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
 
 	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
 	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-		return -EINVAL;	
-	}
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
 
 	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
-	if(psta)
-	{
-		u8 updated=_FALSE;
-	
-		//DBG_871X("free psta=%p, aid=%d\n", psta, psta->aid);
+	if (psta) {
+		u8 updated = _FALSE;
+
+		/* RTW_INFO("free psta=%p, aid=%d\n", psta, psta->cmn.aid); */
 
 		_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-		if(rtw_is_list_empty(&psta->asoc_list)==_FALSE)
-		{			
+		if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
 			rtw_list_delete(&psta->asoc_list);
 			pstapriv->asoc_list_cnt--;
 			updated = ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
 
 		}
 		_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-		
+
 		associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
-	
+
 		psta = NULL;
-		
-	}
-	else
-	{
-		DBG_871X("rtw_del_sta(), sta has already been removed or never been added\n");
-		
-		//ret = -1;
+
+	} else {
+		RTW_INFO("rtw_del_sta(), sta has already been removed or never been added\n");
+
+		/* ret = -1; */
 	}
-	
-	
+
+
 	return ret;
-	
+
 }
 
 static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;	
+	int ret = 0;
 	struct sta_info *psta = NULL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
@@ -8786,30 +7384,25 @@ static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *par
 	struct ieee_param_ex *param_ex = (struct ieee_param_ex *)param;
 	struct sta_data *psta_data = (struct sta_data *)param_ex->data;
 
-	DBG_871X("rtw_ioctl_get_sta_info, sta_addr: " MAC_FMT "\n", MAC_ARG(param_ex->sta_addr));
+	RTW_INFO("rtw_ioctl_get_sta_info, sta_addr: " MAC_FMT "\n", MAC_ARG(param_ex->sta_addr));
 
-	if(check_fwstate(pmlmepriv, (_FW_LINKED|WIFI_AP_STATE)) != _TRUE)		
-	{
-		return -EINVAL;		
-	}
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
 
 	if (param_ex->sta_addr[0] == 0xff && param_ex->sta_addr[1] == 0xff &&
 	    param_ex->sta_addr[2] == 0xff && param_ex->sta_addr[3] == 0xff &&
-	    param_ex->sta_addr[4] == 0xff && param_ex->sta_addr[5] == 0xff) 
-	{
-		return -EINVAL;	
-	}
+	    param_ex->sta_addr[4] == 0xff && param_ex->sta_addr[5] == 0xff)
+		return -EINVAL;
 
 	psta = rtw_get_stainfo(pstapriv, param_ex->sta_addr);
-	if(psta)
-	{
+	if (psta) {
 #if 0
 		struct {
 			u16 aid;
 			u16 capability;
 			int flags;
 			u32 sta_set;
-			u8 tx_supp_rates[16];	
+			u8 tx_supp_rates[16];
 			u32 tx_supp_rates_len;
 			struct rtw_ieee80211_ht_cap ht_cap;
 			u64	rx_pkts;
@@ -8818,33 +7411,33 @@ static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *par
 			u64	tx_pkts;
 			u64	tx_bytes;
 			u64	tx_drops;
-		} get_sta;		
+		} get_sta;
 #endif
-		psta_data->aid = (u16)psta->aid;
+		psta_data->aid = (u16)psta->cmn.aid;
 		psta_data->capability = psta->capability;
 		psta_data->flags = psta->flags;
 
-/*
-		nonerp_set : BIT(0)
-		no_short_slot_time_set : BIT(1)
-		no_short_preamble_set : BIT(2)
-		no_ht_gf_set : BIT(3)
-		no_ht_set : BIT(4)
-		ht_20mhz_set : BIT(5)
-*/
+		/*
+				nonerp_set : BIT(0)
+				no_short_slot_time_set : BIT(1)
+				no_short_preamble_set : BIT(2)
+				no_ht_gf_set : BIT(3)
+				no_ht_set : BIT(4)
+				ht_20mhz_set : BIT(5)
+		*/
 
-		psta_data->sta_set =((psta->nonerp_set) |
-							(psta->no_short_slot_time_set <<1) |
-							(psta->no_short_preamble_set <<2) |
-							(psta->no_ht_gf_set <<3) |
-							(psta->no_ht_set <<4) |
-							(psta->ht_20mhz_set <<5));
+		psta_data->sta_set = ((psta->nonerp_set) |
+				      (psta->no_short_slot_time_set << 1) |
+				      (psta->no_short_preamble_set << 2) |
+				      (psta->no_ht_gf_set << 3) |
+				      (psta->no_ht_set << 4) |
+				      (psta->ht_20mhz_set << 5));
 
 		psta_data->tx_supp_rates_len =  psta->bssratelen;
 		_rtw_memcpy(psta_data->tx_supp_rates, psta->bssrateset, psta->bssratelen);
 #ifdef CONFIG_80211N_HT
 		_rtw_memcpy(&psta_data->ht_cap, &psta->htpriv.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 		psta_data->rx_pkts = psta->sta_stats.rx_data_pkts;
 		psta_data->rx_bytes = psta->sta_stats.rx_bytes;
 		psta_data->rx_drops = psta->sta_stats.rx_drops;
@@ -8852,13 +7445,10 @@ static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *par
 		psta_data->tx_pkts = psta->sta_stats.tx_pkts;
 		psta_data->tx_bytes = psta->sta_stats.tx_bytes;
 		psta_data->tx_drops = psta->sta_stats.tx_drops;
-		
 
-	}
-	else
-	{
+
+	} else
 		ret = -1;
-	}
 
 	return ret;
 
@@ -8866,52 +7456,41 @@ static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *par
 
 static int rtw_get_sta_wpaie(struct net_device *dev, struct ieee_param *param)
 {
-	int ret=0;	
+	int ret = 0;
 	struct sta_info *psta = NULL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	DBG_871X("rtw_get_sta_wpaie, sta_addr: " MAC_FMT "\n", MAC_ARG(param->sta_addr));
+	RTW_INFO("rtw_get_sta_wpaie, sta_addr: " MAC_FMT "\n", MAC_ARG(param->sta_addr));
 
-	if(check_fwstate(pmlmepriv, (_FW_LINKED|WIFI_AP_STATE)) != _TRUE)		
-	{
-		return -EINVAL;		
-	}
+	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != _TRUE)
+		return -EINVAL;
 
 	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
 	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-		return -EINVAL;	
-	}
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
 
 	psta = rtw_get_stainfo(pstapriv, param->sta_addr);
-	if(psta)
-	{
-		if((psta->wpa_ie[0] == WLAN_EID_RSN) || (psta->wpa_ie[0] == WLAN_EID_GENERIC))
-		{
+	if (psta) {
+		if ((psta->wpa_ie[0] == WLAN_EID_RSN) || (psta->wpa_ie[0] == WLAN_EID_GENERIC)) {
 			int wpa_ie_len;
 			int copy_len;
 
 			wpa_ie_len = psta->wpa_ie[1];
-			
-			copy_len = ((wpa_ie_len+2) > sizeof(psta->wpa_ie)) ? (sizeof(psta->wpa_ie)):(wpa_ie_len+2);
-				
+
+			copy_len = ((wpa_ie_len + 2) > sizeof(psta->wpa_ie)) ? (sizeof(psta->wpa_ie)) : (wpa_ie_len + 2);
+
 			param->u.wpa_ie.len = copy_len;
 
 			_rtw_memcpy(param->u.wpa_ie.reserved, psta->wpa_ie, copy_len);
+		} else {
+			/* ret = -1; */
+			RTW_INFO("sta's wpa_ie is NONE\n");
 		}
-		else
-		{
-			//ret = -1;
-			DBG_871X("sta's wpa_ie is NONE\n");
-		}		
-	}
-	else
-	{
+	} else
 		ret = -1;
-	}
 
 	return ret;
 
@@ -8919,128 +7498,122 @@ static int rtw_get_sta_wpaie(struct net_device *dev, struct ieee_param *param)
 
 static int rtw_set_wps_beacon(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;
-	unsigned char wps_oui[4]={0x0,0x50,0xf2,0x04};
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	int ret = 0;
+	unsigned char wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	int ie_len;
 
-	DBG_871X("%s, len=%d\n", __FUNCTION__, len);
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
 
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
-	ie_len = len-12-2;// 12 = param header, 2:no packed
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
 
 
-	if(pmlmepriv->wps_beacon_ie)
-	{
+	if (pmlmepriv->wps_beacon_ie) {
 		rtw_mfree(pmlmepriv->wps_beacon_ie, pmlmepriv->wps_beacon_ie_len);
-		pmlmepriv->wps_beacon_ie = NULL;			
-	}	
+		pmlmepriv->wps_beacon_ie = NULL;
+	}
 
-	if(ie_len>0)
-	{
+	if (ie_len > 0) {
 		pmlmepriv->wps_beacon_ie = rtw_malloc(ie_len);
 		pmlmepriv->wps_beacon_ie_len = ie_len;
-		if ( pmlmepriv->wps_beacon_ie == NULL) {
-			DBG_871X("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+		if (pmlmepriv->wps_beacon_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
 			return -EINVAL;
 		}
 
 		_rtw_memcpy(pmlmepriv->wps_beacon_ie, param->u.bcn_ie.buf, ie_len);
 
 		update_beacon(padapter, _VENDOR_SPECIFIC_IE_, wps_oui, _TRUE);
-		
+
 		pmlmeext->bstart_bss = _TRUE;
-		
+
 	}
-	
-	
-	return ret;		
+
+
+	return ret;
 
 }
 
 static int rtw_set_wps_probe_resp(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	int ie_len;
 
-	DBG_871X("%s, len=%d\n", __FUNCTION__, len);
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
 
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
-	ie_len = len-12-2;// 12 = param header, 2:no packed
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
 
 
-	if(pmlmepriv->wps_probe_resp_ie)
-	{
+	if (pmlmepriv->wps_probe_resp_ie) {
 		rtw_mfree(pmlmepriv->wps_probe_resp_ie, pmlmepriv->wps_probe_resp_ie_len);
-		pmlmepriv->wps_probe_resp_ie = NULL;			
-	}	
+		pmlmepriv->wps_probe_resp_ie = NULL;
+	}
 
-	if(ie_len>0)
-	{
+	if (ie_len > 0) {
 		pmlmepriv->wps_probe_resp_ie = rtw_malloc(ie_len);
 		pmlmepriv->wps_probe_resp_ie_len = ie_len;
-		if ( pmlmepriv->wps_probe_resp_ie == NULL) {
-			DBG_871X("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+		if (pmlmepriv->wps_probe_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
 			return -EINVAL;
 		}
-		_rtw_memcpy(pmlmepriv->wps_probe_resp_ie, param->u.bcn_ie.buf, ie_len);		
+		_rtw_memcpy(pmlmepriv->wps_probe_resp_ie, param->u.bcn_ie.buf, ie_len);
 	}
-	
-	
+
+
 	return ret;
 
 }
 
 static int rtw_set_wps_assoc_resp(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	int ie_len;
 
-	DBG_871X("%s, len=%d\n", __FUNCTION__, len);
+	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
 
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
-	ie_len = len-12-2;// 12 = param header, 2:no packed
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
 
 
-	if(pmlmepriv->wps_assoc_resp_ie)
-	{
+	if (pmlmepriv->wps_assoc_resp_ie) {
 		rtw_mfree(pmlmepriv->wps_assoc_resp_ie, pmlmepriv->wps_assoc_resp_ie_len);
-		pmlmepriv->wps_assoc_resp_ie = NULL;			
-	}	
+		pmlmepriv->wps_assoc_resp_ie = NULL;
+	}
 
-	if(ie_len>0)
-	{
+	if (ie_len > 0) {
 		pmlmepriv->wps_assoc_resp_ie = rtw_malloc(ie_len);
 		pmlmepriv->wps_assoc_resp_ie_len = ie_len;
-		if ( pmlmepriv->wps_assoc_resp_ie == NULL) {
-			DBG_871X("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
+		if (pmlmepriv->wps_assoc_resp_ie == NULL) {
+			RTW_INFO("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
 			return -EINVAL;
 		}
-		
-		_rtw_memcpy(pmlmepriv->wps_assoc_resp_ie, param->u.bcn_ie.buf, ie_len);		
+
+		_rtw_memcpy(pmlmepriv->wps_assoc_resp_ie, param->u.bcn_ie.buf, ie_len);
 	}
-	
-	
+
+
 	return ret;
 
 }
 
 static int rtw_set_hidden_ssid(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;
+	int ret = 0;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *mlmepriv = &(adapter->mlmepriv);
 	struct mlme_ext_priv	*mlmeext = &(adapter->mlmeextpriv);
@@ -9051,7 +7624,7 @@ static int rtw_set_hidden_ssid(struct net_device *dev, struct ieee_param *param,
 	sint ssid_len = 0;
 	u8 ignore_broadcast_ssid;
 
-	if(check_fwstate(mlmepriv, WIFI_AP_STATE) != _TRUE)
+	if (check_fwstate(mlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EPERM;
 
 	if (param->u.bcn_ie.reserved[0] != 0xea)
@@ -9059,18 +7632,18 @@ static int rtw_set_hidden_ssid(struct net_device *dev, struct ieee_param *param,
 
 	mlmeinfo->hidden_ssid_mode = ignore_broadcast_ssid = param->u.bcn_ie.reserved[1];
 
-	ie_len = len-12-2;// 12 = param header, 2:no packed
+	ie_len = len - 12 - 2; /* 12 = param header, 2:no packed */
 	ssid_ie = rtw_get_ie(param->u.bcn_ie.buf,  WLAN_EID_SSID, &ssid_len, ie_len);
 
 	if (ssid_ie && ssid_len > 0 && ssid_len <= NDIS_802_11_LENGTH_SSID) {
 		WLAN_BSSID_EX *pbss_network = &mlmepriv->cur_network.network;
 		WLAN_BSSID_EX *pbss_network_ext = &mlmeinfo->network;
 
-		_rtw_memcpy(ssid, ssid_ie+2, ssid_len);
+		_rtw_memcpy(ssid, ssid_ie + 2, ssid_len);
 		ssid[ssid_len] = 0x0;
 
-		if(0)
-			DBG_871X(FUNC_ADPT_FMT" ssid:(%s,%d), from ie:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" ssid:(%s,%d), from ie:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
 				ssid, ssid_len,
 				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength,
 				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
@@ -9080,83 +7653,81 @@ static int rtw_set_hidden_ssid(struct net_device *dev, struct ieee_param *param,
 		_rtw_memcpy(pbss_network_ext->Ssid.Ssid, (void *)ssid, ssid_len);
 		pbss_network_ext->Ssid.SsidLength = ssid_len;
 
-		if(0)
-			DBG_871X(FUNC_ADPT_FMT" after ssid:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" after ssid:(%s,%d), (%s,%d)\n", FUNC_ADPT_ARG(adapter),
 				pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength,
 				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
 	}
 
-	DBG_871X(FUNC_ADPT_FMT" ignore_broadcast_ssid:%d, %s,%d\n", FUNC_ADPT_ARG(adapter),
+	RTW_INFO(FUNC_ADPT_FMT" ignore_broadcast_ssid:%d, %s,%d\n", FUNC_ADPT_ARG(adapter),
 		ignore_broadcast_ssid, ssid, ssid_len);
 
 	return ret;
 }
 
+#if CONFIG_RTW_MACADDR_ACL
 static int rtw_ioctl_acl_remove_sta(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);	
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
 	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
 	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-		return -EINVAL;	
-	}
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
 
-	ret = rtw_acl_remove_sta(padapter, param->sta_addr);	
+	ret = rtw_acl_remove_sta(padapter, RTW_ACL_PERIOD_BSS, param->sta_addr);
 
-	return ret;		
+	return ret;
 
 }
 
 static int rtw_ioctl_acl_add_sta(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
 	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
 	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) 
-	{
-		return -EINVAL;	
-	}
+	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
+		return -EINVAL;
 
-	ret = rtw_acl_add_sta(padapter, param->sta_addr);	
+	ret = rtw_acl_add_sta(padapter, RTW_ACL_PERIOD_BSS, param->sta_addr);
 
-	return ret;		
+	return ret;
 
 }
 
 static int rtw_ioctl_set_macaddr_acl(struct net_device *dev, struct ieee_param *param, int len)
 {
-	int ret=0;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);	
+	int ret = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	
-	if(check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
-		return -EINVAL;	
-	
-	rtw_set_macaddr_acl(padapter, param->u.mlme.command);	
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
+		return -EINVAL;
+
+	rtw_set_macaddr_acl(padapter, RTW_ACL_PERIOD_BSS, param->u.mlme.command);
 
 	return ret;
 }
+#endif /* CONFIG_RTW_MACADDR_ACL */
 
 static int rtw_hostapd_ioctl(struct net_device *dev, struct iw_point *p)
 {
 	struct ieee_param *param;
-	int ret=0;
+	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	//DBG_871X("%s\n", __FUNCTION__);
+	/* RTW_INFO("%s\n", __FUNCTION__); */
 
 	/*
 	* this function is expect to call in master mode, which allows no power saving
@@ -9169,119 +7740,110 @@ static int rtw_hostapd_ioctl(struct net_device *dev, struct iw_point *p)
 	}
 
 
-	//if (p->length < sizeof(struct ieee_param) || !p->pointer){
-	if(!p->pointer){
+	/* if (p->length < sizeof(struct ieee_param) || !p->pointer){ */
+	if (!p->pointer) {
 		ret = -EINVAL;
 		goto out;
 	}
-	
+
 	param = (struct ieee_param *)rtw_malloc(p->length);
-	if (param == NULL)
-	{
+	if (param == NULL) {
 		ret = -ENOMEM;
 		goto out;
 	}
-	
-	if (copy_from_user(param, p->pointer, p->length))
-	{
-		rtw_mfree((u8*)param, p->length);
+
+	if (copy_from_user(param, p->pointer, p->length)) {
+		rtw_mfree((u8 *)param, p->length);
 		ret = -EFAULT;
 		goto out;
 	}
 
-	//DBG_871X("%s, cmd=%d\n", __FUNCTION__, param->cmd);
+	/* RTW_INFO("%s, cmd=%d\n", __FUNCTION__, param->cmd); */
+
+	switch (param->cmd) {
+	case RTL871X_HOSTAPD_FLUSH:
+
+		ret = rtw_hostapd_sta_flush(dev);
+
+		break;
+
+	case RTL871X_HOSTAPD_ADD_STA:
+
+		ret = rtw_add_sta(dev, param);
+
+		break;
+
+	case RTL871X_HOSTAPD_REMOVE_STA:
 
-	switch (param->cmd) 
-	{	
-		case RTL871X_HOSTAPD_FLUSH:
+		ret = rtw_del_sta(dev, param);
 
-			ret = rtw_hostapd_sta_flush(dev);
+		break;
 
-			break;
-	
-		case RTL871X_HOSTAPD_ADD_STA:	
-			
-			ret = rtw_add_sta(dev, param);					
-			
-			break;
+	case RTL871X_HOSTAPD_SET_BEACON:
 
-		case RTL871X_HOSTAPD_REMOVE_STA:
+		ret = rtw_set_beacon(dev, param, p->length);
 
-			ret = rtw_del_sta(dev, param);
+		break;
 
-			break;
-	
-		case RTL871X_HOSTAPD_SET_BEACON:
+	case RTL871X_SET_ENCRYPTION:
 
-			ret = rtw_set_beacon(dev, param, p->length);
+		ret = rtw_set_encryption(dev, param, p->length);
 
-			break;
-			
-		case RTL871X_SET_ENCRYPTION:
+		break;
 
-			ret = rtw_set_encryption(dev, param, p->length);
-			
-			break;
-			
-		case RTL871X_HOSTAPD_GET_WPAIE_STA:
+	case RTL871X_HOSTAPD_GET_WPAIE_STA:
 
-			ret = rtw_get_sta_wpaie(dev, param);
-	
-			break;
-			
-		case RTL871X_HOSTAPD_SET_WPS_BEACON:
+		ret = rtw_get_sta_wpaie(dev, param);
 
-			ret = rtw_set_wps_beacon(dev, param, p->length);
+		break;
 
-			break;
+	case RTL871X_HOSTAPD_SET_WPS_BEACON:
 
-		case RTL871X_HOSTAPD_SET_WPS_PROBE_RESP:
+		ret = rtw_set_wps_beacon(dev, param, p->length);
 
-			ret = rtw_set_wps_probe_resp(dev, param, p->length);
-			
-	 		break;
-			
-		case RTL871X_HOSTAPD_SET_WPS_ASSOC_RESP:
+		break;
 
-			ret = rtw_set_wps_assoc_resp(dev, param, p->length);
-			
-	 		break;
+	case RTL871X_HOSTAPD_SET_WPS_PROBE_RESP:
 
-		case RTL871X_HOSTAPD_SET_HIDDEN_SSID:
+		ret = rtw_set_wps_probe_resp(dev, param, p->length);
 
-			ret = rtw_set_hidden_ssid(dev, param, p->length);
+		break;
 
-			break;
+	case RTL871X_HOSTAPD_SET_WPS_ASSOC_RESP:
 
-		case RTL871X_HOSTAPD_GET_INFO_STA:
+		ret = rtw_set_wps_assoc_resp(dev, param, p->length);
 
-			ret = rtw_ioctl_get_sta_data(dev, param, p->length);
+		break;
 
-			break;
-			
-		case RTL871X_HOSTAPD_SET_MACADDR_ACL:
+	case RTL871X_HOSTAPD_SET_HIDDEN_SSID:
 
-			ret = rtw_ioctl_set_macaddr_acl(dev, param, p->length);
+		ret = rtw_set_hidden_ssid(dev, param, p->length);
 
-			break;
+		break;
 
-		case RTL871X_HOSTAPD_ACL_ADD_STA:
+	case RTL871X_HOSTAPD_GET_INFO_STA:
 
-			ret = rtw_ioctl_acl_add_sta(dev, param, p->length);
+		ret = rtw_ioctl_get_sta_data(dev, param, p->length);
 
-			break;
+		break;
 
-		case RTL871X_HOSTAPD_ACL_REMOVE_STA:
+#if CONFIG_RTW_MACADDR_ACL
+	case RTL871X_HOSTAPD_SET_MACADDR_ACL:
+		ret = rtw_ioctl_set_macaddr_acl(dev, param, p->length);
+		break;
+	case RTL871X_HOSTAPD_ACL_ADD_STA:
+		ret = rtw_ioctl_acl_add_sta(dev, param, p->length);
+		break;
+	case RTL871X_HOSTAPD_ACL_REMOVE_STA:
+		ret = rtw_ioctl_acl_remove_sta(dev, param, p->length);
+		break;
+#endif /* CONFIG_RTW_MACADDR_ACL */
 
-			ret = rtw_ioctl_acl_remove_sta(dev, param, p->length);
+	default:
+		RTW_INFO("Unknown hostapd request: %d\n", param->cmd);
+		ret = -EOPNOTSUPP;
+		break;
 
-			break;
-			
-		default:
-			DBG_871X("Unknown hostapd request: %d\n", param->cmd);
-			ret = -EOPNOTSUPP;
-			break;
-		
 	}
 
 	if (ret == 0 && copy_to_user(p->pointer, param, p->length))
@@ -9289,18 +7851,18 @@ static int rtw_hostapd_ioctl(struct net_device *dev, struct iw_point *p)
 
 
 	rtw_mfree((u8 *)param, p->length);
-	
+
 out:
-		
+
 	return ret;
-	
+
 }
 #endif
 
 static int rtw_wx_set_priv(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *awrq,
-				char *extra)
+			   struct iw_request_info *info,
+			   union iwreq_data *awrq,
+			   char *extra)
 {
 
 #ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
@@ -9313,14 +7875,14 @@ static int rtw_wx_set_priv(struct net_device *dev,
 	int i;
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *dwrq = (struct iw_point*)awrq;
+	struct iw_point *dwrq = (struct iw_point *)awrq;
 
-	//RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_notice_, ("+rtw_wx_set_priv\n"));
-	if(dwrq->length == 0)
+	if (dwrq->length == 0)
 		return -EFAULT;
-	
+
 	len = dwrq->length;
-	if (!(ext = rtw_vmalloc(len)))
+	ext = rtw_vmalloc(len);
+	if (!ext)
 		return -ENOMEM;
 
 	if (copy_from_user(ext, dwrq->pointer, len)) {
@@ -9329,138 +7891,126 @@ static int rtw_wx_set_priv(struct net_device *dev,
 	}
 
 
-	//RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_notice_,
-	//	 ("rtw_wx_set_priv: %s req=%s\n",
-	//	  dev->name, ext));
 
-	#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV	
-	if (!(ext_dbg = rtw_vmalloc(len)))
-	{
+#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+	ext_dbg = rtw_vmalloc(len);
+	if (!ext_dbg) {
 		rtw_vmfree(ext, len);
 		return -ENOMEM;
-	}	
-	
+	}
+
 	_rtw_memcpy(ext_dbg, ext, len);
-	#endif
+#endif
 
-	//added for wps2.0 @20110524
-	if(dwrq->flags == 0x8766 && len > 8)
-	{
-		u32 cp_sz;		
+	/* added for wps2.0 @20110524 */
+	if (dwrq->flags == 0x8766 && len > 8) {
+		u32 cp_sz;
 		struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 		u8 *probereq_wpsie = ext;
 		int probereq_wpsie_len = len;
-		u8 wps_oui[4]={0x0,0x50,0xf2,0x04};		
-	
-		if((_VENDOR_SPECIFIC_IE_ == probereq_wpsie[0]) &&
-			(_rtw_memcmp(&probereq_wpsie[2], wps_oui, 4) ==_TRUE))
-		{
-			cp_sz = probereq_wpsie_len>MAX_WPS_IE_LEN ? MAX_WPS_IE_LEN:probereq_wpsie_len;
+		u8 wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
 
-			if(pmlmepriv->wps_probe_req_ie)
-			{
+		if ((_VENDOR_SPECIFIC_IE_ == probereq_wpsie[0]) &&
+		    (_rtw_memcmp(&probereq_wpsie[2], wps_oui, 4) == _TRUE)) {
+			cp_sz = probereq_wpsie_len > MAX_WPS_IE_LEN ? MAX_WPS_IE_LEN : probereq_wpsie_len;
+
+			if (pmlmepriv->wps_probe_req_ie) {
 				u32 free_len = pmlmepriv->wps_probe_req_ie_len;
 				pmlmepriv->wps_probe_req_ie_len = 0;
 				rtw_mfree(pmlmepriv->wps_probe_req_ie, free_len);
-				pmlmepriv->wps_probe_req_ie = NULL;			
-			}	
+				pmlmepriv->wps_probe_req_ie = NULL;
+			}
 
 			pmlmepriv->wps_probe_req_ie = rtw_malloc(cp_sz);
-			if ( pmlmepriv->wps_probe_req_ie == NULL) {
+			if (pmlmepriv->wps_probe_req_ie == NULL) {
 				printk("%s()-%d: rtw_malloc() ERROR!\n", __FUNCTION__, __LINE__);
 				ret =  -EINVAL;
 				goto FREE_EXT;
-			
+
 			}
-			
+
 			_rtw_memcpy(pmlmepriv->wps_probe_req_ie, probereq_wpsie, cp_sz);
-			pmlmepriv->wps_probe_req_ie_len = cp_sz;					
-			
-		}	
-		
+			pmlmepriv->wps_probe_req_ie_len = cp_sz;
+
+		}
+
 		goto FREE_EXT;
-		
+
 	}
 
-	if(	len >= WEXT_CSCAN_HEADER_SIZE
+	if (len >= WEXT_CSCAN_HEADER_SIZE
 		&& _rtw_memcmp(ext, WEXT_CSCAN_HEADER, WEXT_CSCAN_HEADER_SIZE) == _TRUE
-	){
+	) {
 		ret = rtw_wx_set_scan(dev, info, awrq, ext);
 		goto FREE_EXT;
 	}
-	
+
 #ifdef CONFIG_ANDROID
-	//DBG_871X("rtw_wx_set_priv: %s req=%s\n", dev->name, ext);
+	/* RTW_INFO("rtw_wx_set_priv: %s req=%s\n", dev->name, ext); */
 
 	i = rtw_android_cmdstr_to_num(ext);
 
-	switch(i) {
-		case ANDROID_WIFI_CMD_START :
-			indicate_wx_custom_event(padapter, "START");
-			break;
-		case ANDROID_WIFI_CMD_STOP :
-			indicate_wx_custom_event(padapter, "STOP");
-			break;
-		case ANDROID_WIFI_CMD_RSSI :
-			{
-				struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);	
-				struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
+	switch (i) {
+	case ANDROID_WIFI_CMD_START:
+		indicate_wx_custom_event(padapter, "START");
+		break;
+	case ANDROID_WIFI_CMD_STOP:
+		indicate_wx_custom_event(padapter, "STOP");
+		break;
+	case ANDROID_WIFI_CMD_RSSI: {
+		struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+		struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
 
-				if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
-					sprintf(ext, "%s rssi %d", pcur_network->network.Ssid.Ssid, padapter->recvpriv.rssi);
-				} else {
-					sprintf(ext, "OK");
-				}
-			}
-			break;
-		case ANDROID_WIFI_CMD_LINKSPEED :
-			{
-				u16 mbps = rtw_get_cur_max_rate(padapter)/10;
-				sprintf(ext, "LINKSPEED %d", mbps);
-			}
-			break;
-		case ANDROID_WIFI_CMD_MACADDR :
-			sprintf(ext, "MACADDR = " MAC_FMT, MAC_ARG(dev->dev_addr));
-			break;
-		case ANDROID_WIFI_CMD_SCAN_ACTIVE :
-			{
-				//rtw_set_scan_mode(padapter, SCAN_ACTIVE);
-				sprintf(ext, "OK");
-			}
-			break;
-		case ANDROID_WIFI_CMD_SCAN_PASSIVE :
-			{
-				//rtw_set_scan_mode(padapter, SCAN_PASSIVE);
-				sprintf(ext, "OK");
-			}
-			break;
+		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
+			sprintf(ext, "%s rssi %d", pcur_network->network.Ssid.Ssid, padapter->recvpriv.rssi);
+		else
+			sprintf(ext, "OK");
+	}
+		break;
+	case ANDROID_WIFI_CMD_LINKSPEED: {
+		u16 mbps = rtw_get_cur_max_rate(padapter) / 10;
+		sprintf(ext, "LINKSPEED %d", mbps);
+	}
+		break;
+	case ANDROID_WIFI_CMD_MACADDR:
+		sprintf(ext, "MACADDR = " MAC_FMT, MAC_ARG(dev->dev_addr));
+		break;
+	case ANDROID_WIFI_CMD_SCAN_ACTIVE: {
+		/* rtw_set_scan_mode(padapter, SCAN_ACTIVE); */
+		sprintf(ext, "OK");
+	}
+		break;
+	case ANDROID_WIFI_CMD_SCAN_PASSIVE: {
+		/* rtw_set_scan_mode(padapter, SCAN_PASSIVE); */
+		sprintf(ext, "OK");
+	}
+		break;
 
-		case ANDROID_WIFI_CMD_COUNTRY :
-			{
-				char country_code[10];
-				sscanf(ext, "%*s %s", country_code);
-				rtw_set_country(padapter, country_code);
-				sprintf(ext, "OK");
-			}
-			break;
-		default :
-			#ifdef  CONFIG_DEBUG_RTW_WX_SET_PRIV
-			DBG_871X("%s: %s unknowned req=%s\n", __FUNCTION__,
-				dev->name, ext_dbg);
-			#endif
+	case ANDROID_WIFI_CMD_COUNTRY: {
+		char country_code[10];
+		sscanf(ext, "%*s %s", country_code);
+		rtw_set_country(padapter, country_code);
+		sprintf(ext, "OK");
+	}
+		break;
+	default:
+		#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+		RTW_INFO("%s: %s unknowned req=%s\n", __FUNCTION__,
+			dev->name, ext_dbg);
+		#endif
+
+		sprintf(ext, "OK");
 
-			sprintf(ext, "OK");
-		
 	}
 
-	if (copy_to_user(dwrq->pointer, ext, min(dwrq->length, (u16)(strlen(ext)+1)) ) )
+	if (copy_to_user(dwrq->pointer, ext, min(dwrq->length, (u16)(strlen(ext) + 1))))
 		ret = -EFAULT;
 
-	#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
-	DBG_871X("%s: %s req=%s rep=%s dwrq->length=%d, strlen(ext)+1=%d\n", __FUNCTION__,
-		dev->name, ext_dbg ,ext, dwrq->length, (u16)(strlen(ext)+1));
-	#endif
-#endif //end of CONFIG_ANDROID
+#ifdef CONFIG_DEBUG_RTW_WX_SET_PRIV
+	RTW_INFO("%s: %s req=%s rep=%s dwrq->length=%d, strlen(ext)+1=%d\n", __FUNCTION__,
+		dev->name, ext_dbg , ext, dwrq->length, (u16)(strlen(ext) + 1));
+#endif
+#endif /* end of CONFIG_ANDROID */
 
 
 FREE_EXT:
@@ -9470,52 +8020,47 @@ FREE_EXT:
 	rtw_vmfree(ext_dbg, len);
 	#endif
 
-	//DBG_871X("rtw_wx_set_priv: (SIOCSIWPRIV) %s ret=%d\n", 
-	//		dev->name, ret);
+	/* RTW_INFO("rtw_wx_set_priv: (SIOCSIWPRIV) %s ret=%d\n",  */
+	/*		dev->name, ret); */
 
 	return ret;
-	
+
 }
 #ifdef CONFIG_WOWLAN
 static int rtw_wowlan_ctrl(struct net_device *dev,
-						struct iw_request_info *info,
-						union iwreq_data *wrqu, char *extra)
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
-	_adapter *padapter =  (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct wowlan_ioctl_param poidparam;
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct net_device *pnetdev = padapter->pnetdev;
-#ifdef CONFIG_CONCURRENT_MODE
-	struct net_device *pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;	
-#endif
 	struct sta_info	*psta = NULL;
 	int ret = 0;
-	u32 start_time = rtw_get_current_time();
+	systime start_time = rtw_get_current_time();
 	poidparam.subcode = 0;
 
-	DBG_871X("+rtw_wowlan_ctrl: %s\n", extra);
-	
-	if (!check_fwstate(pmlmepriv, _FW_LINKED) && 
-			check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+	RTW_INFO("+rtw_wowlan_ctrl: %s\n", extra);
+
+	if (!check_fwstate(pmlmepriv, _FW_LINKED) &&
+	    check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
 #ifdef CONFIG_PNO_SUPPORT
-			pwrctrlpriv->wowlan_pno_enable = _TRUE;
+		pwrctrlpriv->wowlan_pno_enable = _TRUE;
 #else
-			DBG_871X("[%s] WARNING: Please Connect With AP First!!\n", __func__);
-			goto _rtw_wowlan_ctrl_exit_free;
-#endif //CONFIG_PNO_SUPPORT
+		RTW_INFO("[%s] WARNING: Please Connect With AP First!!\n", __func__);
+		goto _rtw_wowlan_ctrl_exit_free;
+#endif /* CONFIG_PNO_SUPPORT */
 	}
 
 	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
 		rtw_scan_abort(padapter);
 
-	if (_rtw_memcmp(extra, "enable", 6)) {
+	if (_rtw_memcmp(extra, "enable", 6))
 
-		padapter->registrypriv.mp_mode = 1;
 
 		rtw_suspend_common(padapter);
 
-	} else if (_rtw_memcmp(extra, "disable", 7)) {
+	else if (_rtw_memcmp(extra, "disable", 7)) {
 #ifdef CONFIG_USB_HCI
 		RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
 		RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
@@ -9524,82 +8069,21 @@ static int rtw_wowlan_ctrl(struct net_device *dev,
 
 #ifdef CONFIG_PNO_SUPPORT
 		pwrctrlpriv->wowlan_pno_enable = _FALSE;
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 
-		padapter->registrypriv.mp_mode = 0;
 	} else {
-		DBG_871X("[%s] Invalid Parameter.\n", __func__);
+		RTW_INFO("[%s] Invalid Parameter.\n", __func__);
 		goto _rtw_wowlan_ctrl_exit_free;
 	}
-	//mutex_lock(&ioctl_mutex);
+	/* mutex_lock(&ioctl_mutex); */
 _rtw_wowlan_ctrl_exit_free:
-	DBG_871X("-rtw_wowlan_ctrl( subcode = %d)\n", poidparam.subcode);
-	DBG_871X_LEVEL(_drv_always_, "%s in %d ms\n", __func__,
-			rtw_get_passing_time_ms(start_time));
+	RTW_INFO("-rtw_wowlan_ctrl( subcode = %d)\n", poidparam.subcode);
+	RTW_PRINT("%s in %d ms\n", __func__,
+		  rtw_get_passing_time_ms(start_time));
 _rtw_wowlan_ctrl_exit:
 	return ret;
 }
 
-static bool rtw_wowlan_parser_pattern_cmd(u8 *input, char *pattern,
-					  int *pattern_len, char *bit_mask)
-{
-	char *cp = NULL, *end = NULL;
-	size_t len = 0;
-	int pos = 0, mask_pos = 0, res = 0;
-	u8 member[2] = {0};
-
-	cp = strchr(input, '=');
-	if (cp) {
-		*cp = 0;
-		cp++;
-	}
-
-	input = cp;
-
-	while (1) {
-		cp = strchr(input, ':');
-
-		if (cp) {
-			len = strlen(input) - strlen(cp);
-			*cp = 0;
-			cp++;
-		} else {
-			len = 2;
-		}
-
-		if (bit_mask && (strcmp(input, "-") == 0 ||
-				 strcmp(input, "xx") == 0 ||
-				 strcmp(input, "--") == 0)) {
-			/* skip this byte and leave mask bit unset */
-		} else {
-			u8 hex;
-			strncpy(member, input, len);
-			if (!rtw_check_pattern_valid(member, sizeof(member))) {
-				DBG_871X("%s:[ERROR] pattern is invalid!!\n",
-					 __func__);
-				goto error;
-			}
-
-			res = sscanf(member, "%02hhx", &hex);
-			pattern[pos] = hex;
-			mask_pos = pos / 8;
-			if (bit_mask)
-				bit_mask[mask_pos] |= 1 << (pos % 8);
-		}
-
-		pos++;
-		if (!cp)
-			break;
-		input = cp;
-	}
-
-	(*pattern_len) = pos;
-
-	return _TRUE;
-error:
-	return _FALSE;
-}
-
 /*
  * IP filter This pattern if for a frame containing a ip packet:
  * AA:AA:AA:AA:AA:AA:BB:BB:BB:BB:BB:BB:CC:CC:DD:-:-:-:-:-:-:-:-:EE:-:-:FF:FF:FF:FF:GG:GG:GG:GG:HH:HH:II:II
@@ -9612,34 +8096,34 @@ error:
  * F: IP source address ( 192.168.0.4: C0:A8:00:2C )
  * G: IP destination address ( 192.168.0.4: C0:A8:00:2C )
  * H: Source port (1024: 04:00)
- * I: Destination port (1024: 04:00) 
+ * I: Destination port (1024: 04:00)
  */
 
 static int rtw_wowlan_set_pattern(struct net_device *dev,
 				  struct iw_request_info *info,
 				  union iwreq_data *wrqu, char *extra)
 {
-	_adapter *padapter =  (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct wowlan_ioctl_param poidparam;
 	int ret = 0, len = 0, i = 0;
-	u32 start_time = rtw_get_current_time();
+	systime start_time = rtw_get_current_time();
 	u8 input[wrqu->data.length];
 	u8 index = 0;
 
 	poidparam.subcode = 0;
 
 	if (!check_fwstate(pmlmepriv, _FW_LINKED) &&
-			check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+	    check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
 		ret = -EFAULT;
-		DBG_871X("Please Connect With AP First!!\n");
+		RTW_INFO("Please Connect With AP First!!\n");
 		goto _rtw_wowlan_set_pattern_exit;
 	}
 
 	if (wrqu->data.length <= 0) {
 		ret = -EFAULT;
-		DBG_871X("ERROR: parameter length <= 0\n");
+		RTW_INFO("ERROR: parameter length <= 0\n");
 		goto _rtw_wowlan_set_pattern_exit;
 	} else {
 		/* set pattern */
@@ -9650,41 +8134,31 @@ static int rtw_wowlan_set_pattern(struct net_device *dev,
 		rtw_ps_deny(padapter, PS_DENY_IOCTL);
 		LeaveAllPowerSaveModeDirect(padapter);
 		if (strncmp(input, "pattern=", 8) == 0) {
-			if (pwrpriv->wowlan_pattern_idx >= MAX_WKFM_NUM) {
-				DBG_871X("WARNING: priv-pattern is full(%d)\n",
-						MAX_WKFM_NUM);
-				DBG_871X("WARNING: please clean priv-pattern first\n");
+			if (pwrpriv->wowlan_pattern_idx >= MAX_WKFM_CAM_NUM) {
+				RTW_INFO("WARNING: priv-pattern is full(idx: %d)\n",
+					 pwrpriv->wowlan_pattern_idx);
+				RTW_INFO("WARNING: please clean priv-pattern first\n");
 				ret = -EINVAL;
 				goto _rtw_wowlan_set_pattern_exit;
 			} else {
 				index = pwrpriv->wowlan_pattern_idx;
-
 				ret = rtw_wowlan_parser_pattern_cmd(input,
-					pwrpriv->patterns[index].content,
-					&pwrpriv->patterns[index].len,
-					pwrpriv->patterns[index].mask);
+					    pwrpriv->patterns[index].content,
+					    &pwrpriv->patterns[index].len,
+					    pwrpriv->patterns[index].mask);
 
-				if (ret == _TRUE) {
+				if (ret == _TRUE)
 					pwrpriv->wowlan_pattern_idx++;
-					pwrpriv->wowlan_pattern = _TRUE;
-				}
 			}
 		} else if (strncmp(input, "clean", 5) == 0) {
 			poidparam.subcode = WOWLAN_PATTERN_CLEAN;
 			rtw_hal_set_hwreg(padapter,
-					HW_VAR_WOWLAN, (u8 *)&poidparam);
-			pwrpriv->wowlan_pattern = _FALSE;
+					  HW_VAR_WOWLAN, (u8 *)&poidparam);
 		} else if (strncmp(input, "show", 4) == 0) {
-			for (i = 0 ; i < MAX_WKFM_NUM ; i++) {
-				DBG_871X("=======[%d]=======\n", i);
-				rtw_read_from_frame_mask(padapter, i);
-			}
-
-			DBG_871X("********[RTK priv-patterns]*********\n");
-			for (i = 0 ; i < MAX_WKFM_NUM ; i++)
-				rtw_dump_priv_pattern(padapter, i);
+			rtw_wow_pattern_cam_dump(padapter);
+			rtw_wow_pattern_sw_dump(padapter);
 		} else {
-			DBG_871X("ERROR: incorrect parameter!\n");
+			RTW_INFO("ERROR: incorrect parameter!\n");
 			ret = -EINVAL;
 		}
 		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
@@ -9692,26 +8166,26 @@ static int rtw_wowlan_set_pattern(struct net_device *dev,
 _rtw_wowlan_set_pattern_exit:
 	return ret;
 }
-#endif //CONFIG_WOWLAN
+#endif /* CONFIG_WOWLAN */
 
 #ifdef CONFIG_AP_WOWLAN
 static int rtw_ap_wowlan_ctrl(struct net_device *dev,
-						struct iw_request_info *info,
-						union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
-	_adapter *padapter =  (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct wowlan_ioctl_param poidparam;
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct sta_info	*psta = NULL;
 	int ret = 0;
-	u32 start_time = rtw_get_current_time();
+	systime start_time = rtw_get_current_time();
 	poidparam.subcode = 0;
 
-	DBG_871X("+rtw_ap_wowlan_ctrl: %s\n", extra);
+	RTW_INFO("+rtw_ap_wowlan_ctrl: %s\n", extra);
 
 	if (!check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-		DBG_871X("[%s] It is not AP mode!!\n", __func__);
+		RTW_INFO("[%s] It is not AP mode!!\n", __func__);
 		goto _rtw_ap_wowlan_ctrl_exit_free;
 	}
 
@@ -9727,286 +8201,529 @@ static int rtw_ap_wowlan_ctrl(struct net_device *dev,
 #endif
 		rtw_resume_common(padapter);
 	} else {
-		DBG_871X("[%s] Invalid Parameter.\n", __func__);
+		RTW_INFO("[%s] Invalid Parameter.\n", __func__);
 		goto _rtw_ap_wowlan_ctrl_exit_free;
 	}
-	//mutex_lock(&ioctl_mutex);
+	/* mutex_lock(&ioctl_mutex); */
 _rtw_ap_wowlan_ctrl_exit_free:
-	DBG_871X("-rtw_ap_wowlan_ctrl( subcode = %d)\n", poidparam.subcode);
-	DBG_871X_LEVEL(_drv_always_, "%s in %d ms\n", __func__,
-			rtw_get_passing_time_ms(start_time));
+	RTW_INFO("-rtw_ap_wowlan_ctrl( subcode = %d)\n", poidparam.subcode);
+	RTW_PRINT("%s in %d ms\n", __func__,
+		  rtw_get_passing_time_ms(start_time));
 _rtw_ap_wowlan_ctrl_exit:
 	return ret;
 }
-#endif //CONFIG_AP_WOWLAN
+#endif /* CONFIG_AP_WOWLAN */
 
 static int rtw_pm_set(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+		      struct iw_request_info *info,
+		      union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 	unsigned	mode = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X( "[%s] extra = %s\n", __FUNCTION__, extra );
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, extra);
+
+	if (_rtw_memcmp(extra, "lps=", 4)) {
+		sscanf(extra + 4, "%u", &mode);
+		ret = rtw_pm_set_lps(padapter, mode);
+	} else if (_rtw_memcmp(extra, "ips=", 4)) {
+		sscanf(extra + 4, "%u", &mode);
+		ret = rtw_pm_set_ips(padapter, mode);
+	} else if (_rtw_memcmp(extra, "lps_level=", 10)) {
+		if (sscanf(extra + 10, "%u", &mode) > 0)
+			ret = rtw_pm_set_lps_level(padapter, mode);
+	} else
+		ret = -EINVAL;
+
+	return ret;
+}
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
 
-	if ( _rtw_memcmp( extra, "lps=", 4 ) )
-	{
-		sscanf(extra+4, "%u", &mode);	
-		ret = rtw_pm_set_lps(padapter,mode);
+int rtw_vendor_ie_get_raw_data(struct net_device *dev, u32 vendor_ie_num,
+							   char *extra, u32 length)
+{
+	int j;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 vendor_ie_mask = 0;
+	char *pstring;
+
+	if (vendor_ie_num >= WLAN_MAX_VENDOR_IE_NUM) {
+		RTW_INFO("[%s] only support %d vendor ie\n", __func__ ,
+				 WLAN_MAX_VENDOR_IE_NUM);
+		return -EFAULT;
 	}
-	else if ( _rtw_memcmp( extra, "ips=", 4 ) )
-	{
-		sscanf(extra+4, "%u", &mode);
-		ret = rtw_pm_set_ips(padapter,mode);
+
+	if (pmlmepriv->vendor_ielen[vendor_ie_num] == 0) {
+		RTW_INFO("[%s]  Fail, vendor_ie_num: %d is not set\n", __func__,
+				 vendor_ie_num);
+		return -EFAULT;
 	}
-	else{
-		ret = -EINVAL;
+
+	if (length < 2 * pmlmepriv->vendor_ielen[vendor_ie_num] + 5) {
+		RTW_INFO("[%s]  Fail, buffer size is too small\n", __func__);
+		return -EFAULT;
+	}
+
+	vendor_ie_mask = pmlmepriv->vendor_ie_mask[vendor_ie_num];
+	_rtw_memset(extra, 0, length);
+
+	pstring = extra;
+	pstring += sprintf(pstring, "%d,%x,", vendor_ie_num, vendor_ie_mask);
+
+	for (j = 0; j < pmlmepriv->vendor_ielen[vendor_ie_num]; j++)
+		pstring += sprintf(pstring, "%02x", pmlmepriv->vendor_ie[vendor_ie_num][j]);
+
+	length = pstring - extra;
+	return length;
+}
+
+int rtw_vendor_ie_get_data(struct net_device *dev, int vendor_ie_num, char *extra)
+{
+	int j;
+	char *pstring;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 vendor_ie_mask = 0;
+	__u16 length = 0;
+
+	vendor_ie_mask = pmlmepriv->vendor_ie_mask[vendor_ie_num];
+	pstring = extra;
+	pstring += sprintf(pstring , "\nVendor IE num %d , Mask:%x " , vendor_ie_num , vendor_ie_mask);
+
+	if (vendor_ie_mask & WIFI_BEACON_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Beacon]");
+	if (vendor_ie_mask & WIFI_PROBEREQ_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Probe Req]");
+	if (vendor_ie_mask & WIFI_PROBERESP_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Probe Resp]");
+	if (vendor_ie_mask & WIFI_ASSOCREQ_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Assoc Req]");
+	if (vendor_ie_mask & WIFI_ASSOCRESP_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[Assoc Resp]");
+
+	pstring += sprintf(pstring , "\nVendor IE:\n");
+	for (j = 0 ; j < pmlmepriv->vendor_ielen[vendor_ie_num]  ; j++)
+		pstring += sprintf(pstring , "%02x" , pmlmepriv->vendor_ie[vendor_ie_num][j]);
+
+	length = pstring - extra;
+	return length;
+
+}
+
+int rtw_vendor_ie_get(struct net_device *dev, struct iw_request_info *info, union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0, vendor_ie_num = 0, cmdlen;
+	struct iw_point *p;
+	u8 *ptmp;
+
+	p = &wrqu->data;
+	cmdlen = p->length;
+	if (0 == cmdlen)
+		return -EINVAL;
+
+	ptmp = (u8 *)rtw_malloc(cmdlen);
+	if (NULL == ptmp)
+		return -ENOMEM;
+
+	if (copy_from_user(ptmp, p->pointer, cmdlen)) {
+		ret = -EFAULT;
+		goto exit;
+	}
+	ret = sscanf(ptmp , "%d", &vendor_ie_num);
+	if (vendor_ie_num > WLAN_MAX_VENDOR_IE_NUM - 1) {
+		ret = -EFAULT;
+		goto exit;
+	}
+
+	wrqu->data.length = rtw_vendor_ie_get_data(dev, vendor_ie_num, extra);
+
+exit:
+	rtw_mfree(ptmp, cmdlen);
+
+	return 0;
+}
+
+int rtw_vendor_ie_set(struct net_device *dev, struct iw_request_info *info, union iwreq_data *wrqu, char *extra)
+{
+	int ret = 0, i , len = 0 , totoal_ie_len = 0 , total_ie_len_byte = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 vendor_ie_mask = 0;
+	u32 vendor_ie_num = 0;
+	u32 id, elen;
+
+	ret = sscanf(extra, "%d,%x,%*s", &vendor_ie_num , &vendor_ie_mask);
+	if (strrchr(extra , ','))
+		extra = strrchr(extra , ',') + 1;
+	else
+		return -EINVAL;
+	totoal_ie_len = strlen(extra);
+	RTW_INFO("[%s] vendor_ie_num = %d , vendor_ie_mask = %x , vendor_ie = %s , len = %d\n", __func__ , vendor_ie_num , vendor_ie_mask , extra  , totoal_ie_len);
+
+	if (vendor_ie_num  > WLAN_MAX_VENDOR_IE_NUM - 1) {
+		RTW_INFO("[%s] only support %d vendor ie\n", __func__ , WLAN_MAX_VENDOR_IE_NUM);
+		return -EFAULT;
+	}
+
+	if (totoal_ie_len > WLAN_MAX_VENDOR_IE_LEN) {
+		RTW_INFO("[%s] Fail , not support ie length extend %d\n", __func__ , WLAN_MAX_VENDOR_IE_LEN);
+		return -EFAULT;
+	}
+
+	if (vendor_ie_mask == 0) {
+		RTW_INFO("[%s] Clear vendor_ie_num %d group\n", __func__ , vendor_ie_num);
+		goto _clear_path;
+	}
+
+	if (totoal_ie_len % 2 != 0) {
+		RTW_INFO("[%s]  Fail , IE length = %zu is odd\n" , __func__ , strlen(extra));
+		return -EFAULT;
 	}
 
+	if (totoal_ie_len > 0) {
+		for (i = 0  ; i < strlen(extra) ; i += 2) {
+			pmlmepriv->vendor_ie[vendor_ie_num][len] = key_2char2num(extra[i] , extra[i + 1]);
+			if (len == 0) {
+				id = pmlmepriv->vendor_ie[vendor_ie_num][len];
+				if (id != WLAN_EID_VENDOR_SPECIFIC) {
+					RTW_INFO("[%s] Fail , VENDOR SPECIFIC IE ID \"%x\" was not correct\n", __func__ , id);
+					goto _clear_path;
+				}
+			} else if (len == 1) {
+				total_ie_len_byte = (totoal_ie_len / 2) - 2;
+				elen = pmlmepriv->vendor_ie[vendor_ie_num][len];
+				if (elen != total_ie_len_byte) {
+					RTW_INFO("[%s] Fail , Input IE length = \"%d\"(hex:%x) bytes , not match input total IE context length \"%d\" bytes\n", __func__ , elen , elen ,
+						 total_ie_len_byte);
+					goto _clear_path;
+				}
+			}
+			len++;
+		}
+		pmlmepriv->vendor_ielen[vendor_ie_num] = len;
+	} else
+		pmlmepriv->vendor_ielen[vendor_ie_num] = 0;
+
+
+
+	if (vendor_ie_mask & WIFI_BEACON_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Beacon append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_PROBEREQ_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Probe Req append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_PROBERESP_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Probe Resp  append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_ASSOCREQ_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Assoc Req append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_ASSOCRESP_VENDOR_IE_BIT)
+		RTW_INFO("[%s] Assoc Resp append vendor ie\n", __func__);
+
+	pmlmepriv->vendor_ie_mask[vendor_ie_num] = vendor_ie_mask;
+
 	return ret;
+
+_clear_path:
+	_rtw_memset(pmlmepriv->vendor_ie[vendor_ie_num] , 0 , sizeof(u32) * WLAN_MAX_VENDOR_IE_LEN);
+	pmlmepriv->vendor_ielen[vendor_ie_num] = 0;
+	pmlmepriv->vendor_ie_mask[vendor_ie_num] = 0;
+	return -EFAULT;
 }
+#endif
 
 static int rtw_mp_efuse_get(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wdata, char *extra)
+			    struct iw_request_info *info,
+			    union iwreq_data *wdata, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	
+
 	PEFUSE_HAL pEfuseHal;
 	struct iw_point *wrqu;
-	
+
 	u8	*PROMContent = pHalData->efuse_eeprom_data;
-	u8 ips_mode = IPS_NUM; // init invalid value
-	u8 lps_mode = PS_MODE_NUM; // init invalid value
+	u8 ips_mode = IPS_NUM; /* init invalid value */
+	u8 lps_mode = PS_MODE_NUM; /* init invalid value */
 	struct pwrctrl_priv *pwrctrlpriv ;
 	u8 *data = NULL;
 	u8 *rawdata = NULL;
-	char *pch, *ptmp, *token, *tmp[3]={0x00,0x00,0x00};
-	u16 i=0, j=0, mapLen=0, addr=0, cnts=0;
+	char *pch, *ptmp, *token, *tmp[3] = {0x00, 0x00, 0x00};
+	u16 i = 0, j = 0, mapLen = 0, addr = 0, cnts = 0;
 	u16 max_available_len = 0, raw_cursize = 0, raw_maxsize = 0;
+	u16 mask_len;
+	u8 mask_buf[64] = "";
 	int err;
-	#ifdef CONFIG_IOL
-	u8 org_fw_iol = padapter->registrypriv.fw_iol;// 0:Disable, 1:enable, 2:by usb speed
-	#endif
-	
-	wrqu = (struct iw_point*)wdata;
+	char *pextra = NULL;
+#ifdef CONFIG_IOL
+	u8 org_fw_iol = padapter->registrypriv.fw_iol;/* 0:Disable, 1:enable, 2:by usb speed */
+#endif
+
+	wrqu = (struct iw_point *)wdata;
 	pwrctrlpriv = adapter_to_pwrctl(padapter);
 	pEfuseHal = &pHalData->EfuseHal;
 
 	err = 0;
 	data = rtw_zmalloc(EFUSE_BT_MAX_MAP_LEN);
-	if (data == NULL)
-	{
+	if (data == NULL) {
 		err = -ENOMEM;
 		goto exit;
 	}
 	rawdata = rtw_zmalloc(EFUSE_BT_MAX_MAP_LEN);
-	if (rawdata == NULL)
-	{
+	if (rawdata == NULL) {
 		err = -ENOMEM;
 		goto exit;
 	}
 
-	if (copy_from_user(extra, wrqu->pointer, wrqu->length))
-	{
+	if (copy_from_user(extra, wrqu->pointer, wrqu->length)) {
 		err = -EFAULT;
 		goto exit;
 	}
-	#ifdef CONFIG_LPS
-	lps_mode = pwrctrlpriv->power_mgnt;//keep org value
-	rtw_pm_set_lps(padapter,PS_MODE_ACTIVE);
-	#endif	
-	
-	#ifdef CONFIG_IPS	
-	ips_mode = pwrctrlpriv->ips_mode;//keep org value
-	rtw_pm_set_ips(padapter,IPS_NONE);
-	#endif	
-	
+
+	*(extra + wrqu->length) = '\0';
+
+#ifdef CONFIG_LPS
+	lps_mode = pwrctrlpriv->power_mgnt;/* keep org value */
+	rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
+#endif
+
+#ifdef CONFIG_IPS
+	ips_mode = pwrctrlpriv->ips_mode;/* keep org value */
+	rtw_pm_set_ips(padapter, IPS_NONE);
+#endif
+
 	pch = extra;
-	DBG_871X("%s: in=%s\n", __FUNCTION__, extra);
+	RTW_INFO("%s: in=%s\n", __FUNCTION__, extra);
 
 	i = 0;
-	//mac 16 "00e04c871200" rmap,00,2
-	while ((token = strsep(&pch, ",")) != NULL)
-	{
-		if (i > 2) break;
+	/* mac 16 "00e04c871200" rmap,00,2 */
+	while ((token = strsep(&pch, ",")) != NULL) {
+		if (i > 2)
+			break;
 		tmp[i] = token;
 		i++;
 	}
-	#ifdef CONFIG_IOL
-	padapter->registrypriv.fw_iol = 0;// 0:Disable, 1:enable, 2:by usb speed
-	#endif
-	
-	if(strcmp(tmp[0], "status") == 0){
+#ifdef CONFIG_IOL
+	padapter->registrypriv.fw_iol = 0;/* 0:Disable, 1:enable, 2:by usb speed */
+#endif
+
+	if (strcmp(tmp[0], "status") == 0) {
 		sprintf(extra, "Load File efuse=%s,Load File MAC=%s"
 			, pHalData->efuse_file_status == EFUSE_FILE_FAILED ? "FAIL" : "OK"
 			, pHalData->macaddr_file_status == MACADDR_FILE_FAILED ? "FAIL" : "OK"
-		);
-		  goto exit;
-	}
-	else if (strcmp(tmp[0], "drvmap") == 0)
-	{
-		mapLen = EFUSE_MAP_SIZE;
-		
-		sprintf(extra, "\n");
-		for (i = 0; i < EFUSE_MAP_SIZE; i += 16)
-		{
-//			DBG_871X("0x%02x\t", i);
-			sprintf(extra, "%s0x%02x\t", extra, i);
-			for (j=0; j<8; j++) {
-//				DBG_871X("%02X ", data[i+j]);
-				sprintf(extra, "%s%02X ", extra, PROMContent[i+j]);
-			}
-//			DBG_871X("\t");
-			sprintf(extra, "%s\t", extra);
-			for (; j<16; j++) {
-//				DBG_871X("%02X ", data[i+j]);
-				sprintf(extra, "%s%02X ", extra, PROMContent[i+j]);
-			}
-//			DBG_871X("\n");
-			sprintf(extra,"%s\n",extra);
-		}
-//		DBG_871X("\n");
-	}
-	else if (strcmp(tmp[0], "realmap") == 0)
-	{
-		mapLen = EFUSE_MAP_SIZE;
-		if (rtw_efuse_mask_map_read(padapter, EFUSE_WIFI , mapLen, pEfuseHal->fakeEfuseInitMap) == _FAIL)
-		{
-			DBG_871X("%s: read realmap Fail!!\n", __FUNCTION__);
+		       );
+		goto exit;
+	} else if (strcmp(tmp[0], "drvmap") == 0) {
+		static u8 drvmaporder = 0;
+		u8 *efuse;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
+
+		efuse = pHalData->efuse_eeprom_data;
+
+		shift = blksz * drvmaporder;
+		efuse += shift;
+		cnt = mapLen - shift;
+
+		if (cnt > blksz) {
+			cnt = blksz;
+			drvmaporder++;
+		} else
+			drvmaporder = 0;
+
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
+
+	} else if (strcmp(tmp[0], "realmap") == 0) {
+		static u8 order = 0;
+		u8 *efuse;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&mapLen, _FALSE);
+		efuse = pEfuseHal->fakeEfuseInitMap;
+		if (rtw_efuse_mask_map_read(padapter, 0, mapLen, efuse) == _FAIL) {
+			RTW_INFO("%s: read realmap Fail!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
 
-//		DBG_871X("OFFSET\tVALUE(hex)\n");
+#if 0
+		RTW_INFO("OFFSET\tVALUE(hex)\n");
+		for (i = 0; i < mapLen; i += 16) {
+			RTW_INFO("0x%02x\t", i);
+			for (j = 0; j < 8; j++)
+				RTW_INFO("%02X ", efuse[i + j]);
+			RTW_INFO("\t");
+			for (; j < 16; j++)
+				RTW_INFO("%02X ", efuse[i + j]);
+			RTW_INFO("\n");
+		}
+		RTW_INFO("\n");
+#endif
+
+		shift = blksz * order;
+		efuse += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			order++;
+		} else
+			order = 0;
+
 		sprintf(extra, "\n");
-		for (i = 0; i < EFUSE_MAP_SIZE; i += 16)
-		{
-//			DBG_871X("0x%02x\t", i);
-			sprintf(extra, "%s0x%02x\t", extra, i);
-			for (j=0; j<8; j++) {
-//				DBG_871X("%02X ", data[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->fakeEfuseInitMap[i+j]);
-			}
-//			DBG_871X("\t");
-			sprintf(extra, "%s\t", extra);
-			for (; j<16; j++) {
-//				DBG_871X("%02X ", data[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->fakeEfuseInitMap[i+j]);
-			}
-//			DBG_871X("\n");
-			sprintf(extra,"%s\n",extra);
-		}
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
 	} else if (strcmp(tmp[0], "rmap") == 0) {
 		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
-			DBG_871X("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
+			RTW_INFO("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
 			err = -EINVAL;
 			goto exit;
 		}
 
-		// rmap addr cnts
+		/* rmap addr cnts */
 		addr = simple_strtoul(tmp[1], &ptmp, 16);
-		DBG_871X("%s: addr=%x\n", __FUNCTION__, addr);
+		RTW_INFO("%s: addr=%x\n", __FUNCTION__, addr);
 
 		cnts = simple_strtoul(tmp[2], &ptmp, 10);
-		if (cnts == 0)
-		{
-			DBG_871X("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
+		if (cnts == 0) {
+			RTW_INFO("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
 			err = -EINVAL;
 			goto exit;
 		}
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
 
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (PVOID)&max_available_len, _FALSE);
-		if ((addr + cnts) > max_available_len)
-		{
-			DBG_871X("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+		if ((addr + cnts) > max_available_len) {
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EINVAL;
 			goto exit;
 		}
 
-		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_mask_map_read error!\n", __func__);
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_mask_map_read error!\n", __func__);
 			err = -EFAULT;
 			goto exit;
 		}
 
-//		DBG_871X("%s: data={", __FUNCTION__);
+		/*		RTW_INFO("%s: data={", __FUNCTION__); */
 		*extra = 0;
-		for (i=0; i<cnts; i++) {
-//			DBG_871X("0x%02x ", data[i]);
-			sprintf(extra, "%s0x%02X ", extra, data[i]);
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("0x%02x ", data[i]); */
+			pextra += sprintf(pextra, "0x%02X ", data[i]);
 		}
-//		DBG_871X("}\n");
-	}
-	else if (strcmp(tmp[0], "realraw") == 0)
-	{
+		/*		RTW_INFO("}\n"); */
+	} else if (strcmp(tmp[0], "realraw") == 0) {
+		static u8 raw_order = 0;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+
 		addr = 0;
-		mapLen = EFUSE_MAX_SIZE;
-		DBG_871X("EFUSE_MAX_SIZE = %d\n", EFUSE_MAX_SIZE);
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_REAL_CONTENT_LEN , (PVOID)&mapLen, _FALSE);
+		RTW_INFO("Real content len = %d\n",mapLen );
 
 		if (rtw_efuse_access(padapter, _FALSE, addr, mapLen, rawdata) == _FAIL) {
-			DBG_871X("%s: rtw_efuse_access Fail!!\n", __func__);
+			RTW_INFO("%s: rtw_efuse_access Fail!!\n", __func__);
 			err = -EFAULT;
 			goto exit;
 		}
 
-		if (mapLen >= 512)
-			mapLen = 512;
+		_rtw_memset(extra, '\0', strlen(extra));
 
-		_rtw_memset(extra,'\0',strlen(extra));
+		shift = blksz * raw_order;
+		rawdata += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			raw_order++;
+		} else
+			raw_order = 0;
 
-		sprintf(extra, "\n0x00\t");
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
+
+	} else if (strcmp(tmp[0], "btrealraw") == 0) {
+		static u8 bt_raw_order = 0;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
 
-		for (i = 0; i < mapLen ; i++) {
-			sprintf(extra, "%s%02X", extra, rawdata[i]);
-			if ((i & 0xF) == 0xF) {
-				sprintf(extra, "%s\n", extra);
-				sprintf(extra, "%s0x%02x\t", extra, i+1);
-			} else if ((i & 0x7) == 0x7) {
-				sprintf(extra, "%s \t", extra);
-			} else {
-				sprintf(extra, "%s ", extra);
-			}
+		addr = 0;
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_REAL_CONTENT_LEN, (PVOID)&mapLen, _FALSE);
+		RTW_INFO("Real content len = %d\n", mapLen);
+#ifdef RTW_HALMAC
+		if (rtw_efuse_bt_access(padapter, _FALSE, 0, mapLen, rawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access Fail!!\n", __func__);
+			err = -EFAULT;
+			goto exit;
 		}
+#else
+		rtw_write8(padapter, 0x35, 0x1);
 
-	} else if (strcmp(tmp[0], "realrawb") == 0) {
-		addr = 0;
-		mapLen = EFUSE_MAX_SIZE;
-		DBG_871X("EFUSE_MAX_SIZE =%d\n", EFUSE_MAX_SIZE);
-		if (rtw_efuse_access(padapter, _FALSE, addr, mapLen, rawdata) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_access Fail!!\n", __FUNCTION__);
+		if (rtw_efuse_access(padapter, _FALSE, addr, mapLen, rawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access Fail!!\n", __func__);
 			err = -EFAULT;
 			goto exit;
 		}
-		_rtw_memset(extra,'\0',strlen(extra));
-		//		DBG_871X("%s: realraw={\n", __FUNCTION__);
-				sprintf(extra, "\n0x00\t");
-				for (i= 512; i< mapLen; i++)
-				{
-		//			DBG_871X("%02X", rawdata[i]);
-					sprintf(extra, "%s%02X", extra, rawdata[i]);
-					if ((i & 0xF) == 0xF) {
-		//				DBG_871X("\n");
-						sprintf(extra, "%s\n", extra);
-						sprintf(extra, "%s0x%02x\t", extra, i+1);
-					}
-					else if ((i & 0x7) == 0x7){
-		//				DBG_871X("\t");
-						sprintf(extra, "%s \t", extra);
-					} else {
-		//				DBG_871X(" ");
-						sprintf(extra, "%s ", extra);
-					}
-				}
-		//		DBG_871X("}\n");
-	}
-	else if (strcmp(tmp[0], "mac") == 0)
-	{		
+#endif
+		_rtw_memset(extra, '\0', strlen(extra));
+
+		shift = blksz * bt_raw_order;
+		rawdata += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			bt_raw_order++;
+		} else
+			bt_raw_order = 0;
+
+		sprintf(extra, "\n");
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", rawdata[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more (left:%d/%d)\n", mapLen-(shift + cnt), mapLen);
+
+	} else if (strcmp(tmp[0], "mac") == 0) {
 		if (hal_efuse_macaddr_offset(padapter) == -1) {
 			err = -EFAULT;
 			goto exit;
@@ -10017,345 +8734,362 @@ static int rtw_mp_efuse_get(struct net_device *dev,
 
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
 		if ((addr + cnts) > max_available_len) {
-			DBG_871X("%s: addr(0x%02x)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			RTW_INFO("%s: addr(0x%02x)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EFAULT;
 			goto exit;
 		}
 
-		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_mask_map_read error!\n", __func__);
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_mask_map_read error!\n", __func__);
 			err = -EFAULT;
 			goto exit;
 		}
 
-//		DBG_871X("%s: MAC address={", __FUNCTION__);
+		/*		RTW_INFO("%s: MAC address={", __FUNCTION__); */
 		*extra = 0;
-		for (i=0; i<cnts; i++)
-		{
-//			DBG_871X("%02X", data[i]);
-			sprintf(extra, "%s%02X", extra, data[i]);
-			if (i != (cnts-1))
-			{
-//				DBG_871X(":");
-				sprintf(extra,"%s:",extra);
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("%02X", data[i]); */
+			pextra += sprintf(pextra, "%02X", data[i]);
+			if (i != (cnts - 1)) {
+				/*				RTW_INFO(":"); */
+				pextra += sprintf(pextra, ":");
 			}
 		}
-//		DBG_871X("}\n");
-	}
-	else if (strcmp(tmp[0], "vidpid") == 0)
-	{
-		#ifdef CONFIG_RTL8188E
-			#ifdef CONFIG_USB_HCI
-			addr = EEPROM_VID_88EU;
-			#endif
-			#ifdef CONFIG_PCI_HCI
-			addr = EEPROM_VID_88EE;
-			#endif
-		#endif // CONFIG_RTL8188E
+		/*		RTW_INFO("}\n"); */
+	} else if (strcmp(tmp[0], "vidpid") == 0) {
+#ifdef CONFIG_RTL8188E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_88EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_88EE;
+#endif
+#endif /* CONFIG_RTL8188E */
 
-		#ifdef CONFIG_RTL8192E
-			#ifdef CONFIG_USB_HCI
-			addr = EEPROM_VID_8192EU;
-			#endif
-			#ifdef CONFIG_PCI_HCI
-			addr = EEPROM_VID_8192EE;
-			#endif
-		#endif // CONFIG_RTL8192E
-		#ifdef CONFIG_RTL8723B
+#ifdef CONFIG_RTL8192E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8192EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_8192EE;
+#endif
+#endif /* CONFIG_RTL8192E */
+#ifdef CONFIG_RTL8723B
 		addr = EEPROM_VID_8723BU;
-		#endif // CONFIG_RTL8192E
+#endif /* CONFIG_RTL8192E */
 
-		#ifdef CONFIG_RTL8188F
+#ifdef CONFIG_RTL8188F
 		addr = EEPROM_VID_8188FU;
-		#endif /* CONFIG_RTL8188F */
+#endif /* CONFIG_RTL8188F */
 
-		#ifdef CONFIG_RTL8703B
-			#ifdef CONFIG_USB_HCI
-			addr = EEPROM_VID_8703BU;
-			#endif
-		#endif /* CONFIG_RTL8703B */
+#ifdef CONFIG_RTL8188GTV
+		addr = EEPROM_VID_8188GTVU;
+#endif
+
+#ifdef CONFIG_RTL8703B
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8703BU;
+#endif
+#endif /* CONFIG_RTL8703B */
+
+#ifdef CONFIG_RTL8723D
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8723DU;
+#endif /* CONFIG_USB_HCI */
+#endif /* CONFIG_RTL8723D */
 
 		cnts = 4;
 
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
 		if ((addr + cnts) > max_available_len) {
-			DBG_871X("%s: addr(0x%02x)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			RTW_INFO("%s: addr(0x%02x)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EFAULT;
 			goto exit;
 		}
-		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
 
-//		DBG_871X("%s: {VID,PID}={", __FUNCTION__);
+		/*		RTW_INFO("%s: {VID,PID}={", __FUNCTION__); */
 		*extra = 0;
-		for (i=0; i<cnts; i++)
-		{
-//			DBG_871X("0x%02x", data[i]);
-			sprintf(extra, "%s0x%02X", extra, data[i]);
-			if (i != (cnts-1))
-			{
-//				DBG_871X(",");
-				sprintf(extra,"%s,",extra);
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("0x%02x", data[i]); */
+			pextra += sprintf(pextra, "0x%02X", data[i]);
+			if (i != (cnts - 1)) {
+				/*				RTW_INFO(","); */
+				pextra += sprintf(pextra, ",");
 			}
 		}
-//		DBG_871X("}\n");
+		/*		RTW_INFO("}\n"); */
 	} else if (strcmp(tmp[0], "ableraw") == 0) {
-			efuse_GetCurrentSize(padapter, &raw_cursize);
-			raw_maxsize = efuse_GetMaxSize(padapter);
-			sprintf(extra, "[available raw size]= %d bytes\n", raw_maxsize - raw_cursize);
+#ifdef RTW_HALMAC
+		raw_maxsize = efuse_GetavailableSize(padapter);
+#else
+		efuse_GetCurrentSize(padapter, &raw_cursize);
+		raw_maxsize = efuse_GetMaxSize(padapter);
+#endif
+		sprintf(extra, "[available raw size]= %d bytes\n", raw_maxsize - raw_cursize);
 	} else if (strcmp(tmp[0], "btableraw") == 0) {
-			efuse_bt_GetCurrentSize(padapter, &raw_cursize);
-			raw_maxsize = efuse_bt_GetMaxSize(padapter);
-			sprintf(extra, "[available raw size]= %d bytes\n", raw_maxsize - raw_cursize);
+		efuse_bt_GetCurrentSize(padapter, &raw_cursize);
+		raw_maxsize = efuse_bt_GetMaxSize(padapter);
+		sprintf(extra, "[available raw size]= %d bytes\n", raw_maxsize - raw_cursize);
 	} else if (strcmp(tmp[0], "btfmap") == 0) {
 
-		BTEfuse_PowerSwitch(padapter,1,_TRUE);
-				
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+
 		mapLen = EFUSE_BT_MAX_MAP_LEN;
-		if (rtw_BT_efuse_map_read(padapter, 0, mapLen, pEfuseHal->BTEfuseInitMap) == _FAIL)
-		{
-			DBG_871X("%s: rtw_BT_efuse_map_read Fail!!\n", __FUNCTION__);
+		if (rtw_BT_efuse_map_read(padapter, 0, mapLen, pEfuseHal->BTEfuseInitMap) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_read Fail!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
 
-//		DBG_871X("OFFSET\tVALUE(hex)\n");
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
 		sprintf(extra, "\n");
-		for (i=0; i<512; i+=16) // set 512 because the iwpriv's extra size have limit 0x7FF
-		{
-//			DBG_871X("0x%03x\t", i);
-			sprintf(extra, "%s0x%03x\t", extra, i);
-			for (j=0; j<8; j++) {
-//				DBG_871X("%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->BTEfuseInitMap[i+j]);
+		for (i = 0; i < 512; i += 16) { /* set 512 because the iwpriv's extra size have limit 0x7FF */
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->BTEfuseInitMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
 			}
-//			DBG_871X("\t");
-			sprintf(extra,"%s\t",extra);
-			for (; j<16; j++) {
-//				DBG_871X("%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->BTEfuseInitMap[i+j]);
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->BTEfuseInitMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
 			}
-//			DBG_871X("\n");
-			sprintf(extra, "%s\n", extra);
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
 		}
-//		DBG_871X("\n");
-	}
-	else if (strcmp(tmp[0],"btbmap") == 0)
-	{
-		BTEfuse_PowerSwitch(padapter,1,_TRUE);
-		
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "btbmap") == 0) {
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+
 		mapLen = EFUSE_BT_MAX_MAP_LEN;
-		if (rtw_BT_efuse_map_read(padapter, 0, mapLen, pEfuseHal->BTEfuseInitMap) == _FAIL)
-		{
-			DBG_871X("%s: rtw_BT_efuse_map_read Fail!!\n", __FUNCTION__);
+		if (rtw_BT_efuse_map_read(padapter, 0, mapLen, pEfuseHal->BTEfuseInitMap) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_read Fail!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
 
-//		DBG_871X("OFFSET\tVALUE(hex)\n");
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
 		sprintf(extra, "\n");
-		for (i=512; i<1024 ; i+=16)
-		{
-//			DBG_871X("0x%03x\t", i);
-			sprintf(extra, "%s0x%03x\t", extra, i);
-			for (j=0; j<8; j++)
-			{
-//				DBG_871X("%02X ", data[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->BTEfuseInitMap[i+j]);
+		for (i = 512; i < 1024 ; i += 16) {
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", data[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
 			}
-//			DBG_871X("\t");
-			sprintf(extra,"%s\t",extra);
-			for (; j<16; j++) {
-//				DBG_871X("%02X ", data[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->BTEfuseInitMap[i+j]);
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", data[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->BTEfuseInitMap[i+j]);
 			}
-//			DBG_871X("\n");
-			sprintf(extra, "%s\n", extra);
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
 		}
-//		DBG_871X("\n");
-	}
-	else if (strcmp(tmp[0],"btrmap") == 0)
-	{
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-		{
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "btrmap") == 0) {
+		u8 BTStatus;
+
+		rtw_write8(padapter, 0xa3, 0x05); /* For 8723AB ,8821S ? */
+		BTStatus = rtw_read8(padapter, 0xa0);
+
+		RTW_INFO("%s: Check 0xa0 BT Status =0x%x\n", __FUNCTION__, BTStatus);
+		if (BTStatus != 0x04) {
+			sprintf(extra, "BT Status not Active ,can't to read BT eFuse\n");
+			goto exit;
+		}
+
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		BTEfuse_PowerSwitch(padapter,1,_TRUE);
-		
-		// rmap addr cnts
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+
+		/* rmap addr cnts */
 		addr = simple_strtoul(tmp[1], &ptmp, 16);
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
 
 		cnts = simple_strtoul(tmp[2], &ptmp, 10);
-		if (cnts == 0)
-		{
-			DBG_871X("%s: btrmap Fail!! cnts error!\n", __FUNCTION__);
+		if (cnts == 0) {
+			RTW_INFO("%s: btrmap Fail!! cnts error!\n", __FUNCTION__);
 			err = -EINVAL;
 			goto exit;
 		}
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+#ifndef RTW_HALMAC
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
 		if ((addr + cnts) > max_available_len) {
-			DBG_871X("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EFAULT;
 			goto exit;
 		}
-
-		if (rtw_BT_efuse_map_read(padapter, addr, cnts, data) == _FAIL) 
-		{
-			DBG_871X("%s: rtw_BT_efuse_map_read error!!\n", __FUNCTION__);
+#endif
+		if (rtw_BT_efuse_map_read(padapter, addr, cnts, data) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_read error!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
 
 		*extra = 0;
-//		DBG_871X("%s: bt efuse data={", __FUNCTION__);
-		for (i=0; i<cnts; i++)
-		{
-//			DBG_871X("0x%02x ", data[i]);
-			sprintf(extra, "%s 0x%02X ", extra, data[i]);
-		}
-//		DBG_871X("}\n");
-		DBG_871X(FUNC_ADPT_FMT ": BT MAC=[%s]\n", FUNC_ADPT_ARG(padapter), extra);
-	}
-	else if (strcmp(tmp[0], "btffake") == 0)
-	{
-//		DBG_871X("OFFSET\tVALUE(hex)\n");
+		pextra = extra;
+		/*		RTW_INFO("%s: bt efuse data={", __FUNCTION__); */
+		for (i = 0; i < cnts; i++) {
+			/*			RTW_INFO("0x%02x ", data[i]); */
+			pextra += sprintf(pextra, " 0x%02X ", data[i]);
+		}
+		/*		RTW_INFO("}\n"); */
+		RTW_INFO(FUNC_ADPT_FMT ": BT MAC=[%s]\n", FUNC_ADPT_ARG(padapter), extra);
+	} else if (strcmp(tmp[0], "btffake") == 0) {
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
 		sprintf(extra, "\n");
-		for (i=0; i<512; i+=16)
-		{
-//			DBG_871X("0x%03x\t", i);
-			sprintf(extra, "%s0x%03x\t", extra, i);
-			for (j=0; j<8; j++) {
-//				DBG_871X("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+		for (i = 0; i < 512; i += 16) {
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
 			}
-//			DBG_871X("\t");
-			sprintf(extra, "%s\t", extra);
-			for (; j<16; j++) {
-//				DBG_871X("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
 			}
-//			DBG_871X("\n");
-			sprintf(extra, "%s\n", extra);
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
 		}
-//		DBG_871X("\n");
-	}
-	else if (strcmp(tmp[0],"btbfake") == 0)
-	{
-//		DBG_871X("OFFSET\tVALUE(hex)\n");
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "btbfake") == 0) {
+		/*		RTW_INFO("OFFSET\tVALUE(hex)\n"); */
 		sprintf(extra, "\n");
-		for (i=512; i<1024; i+=16)
-		{
-//			DBG_871X("0x%03x\t", i);
-			sprintf(extra, "%s0x%03x\t", extra, i);
-			for (j=0; j<8; j++) {
-//				DBG_871X("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+		for (i = 512; i < 1024; i += 16) {
+			/*			RTW_INFO("0x%03x\t", i); */
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%03x\t", i);
+			for (j = 0; j < 8; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
 			}
-//			DBG_871X("\t");
-			sprintf(extra, "%s\t", extra);
-			for (; j<16; j++) {
-//				DBG_871X("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
+			/*			RTW_INFO("\t"); */
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++) {
+				/*				RTW_INFO("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]); */
+				pextra += sprintf(pextra, "%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
 			}
-//			DBG_871X("\n");
-			sprintf(extra, "%s\n", extra);
-		}
-//		DBG_871X("\n");
-	}
-	else if (strcmp(tmp[0],"wlrfkmap")== 0)
-	{
-//		DBG_871X("OFFSET\tVALUE(hex)\n");
+			/*			RTW_INFO("\n"); */
+			pextra += sprintf(pextra, "\n");
+		}
+		/*		RTW_INFO("\n"); */
+	} else if (strcmp(tmp[0], "wlrfkmap") == 0) {
+		static u8 fk_order = 0;
+		u8 *efuse;
+		u32 shift, cnt;
+		u32 blksz = 0x200; /* The size of one time show, default 512 */
+
+		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&mapLen, _FALSE);
+		efuse = pEfuseHal->fakeEfuseModifiedMap;
+
+		shift = blksz * fk_order;
+		efuse += shift;
+		cnt = mapLen - shift;
+		if (cnt > blksz) {
+			cnt = blksz;
+			fk_order++;
+		} else
+			fk_order = 0;
+
 		sprintf(extra, "\n");
-		for (i=0; i<EFUSE_MAP_SIZE; i+=16)
-		{
-//			DBG_871X("\t0x%02x\t", i);
-			sprintf(extra, "%s0x%02x\t", extra, i);
-			for (j=0; j<8; j++) {
-//				DBG_871X("%02X ", pEfuseHal->fakeEfuseModifiedMap[i+j]);
-				sprintf(extra, "%s%02X ", extra, pEfuseHal->fakeEfuseModifiedMap[i+j]);
-			}
-//			DBG_871X("\t");
-			sprintf(extra, "%s\t", extra);
-			for (; j<16; j++) {
-//				DBG_871X("%02X ", pEfuseHal->fakeEfuseModifiedMap[i+j]);
-				sprintf(extra, "%s %02X", extra, pEfuseHal->fakeEfuseModifiedMap[i+j]);
-			}
-//			DBG_871X("\n");
-			sprintf(extra, "%s\n", extra);
+		for (i = 0; i < cnt; i += 16) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "0x%02x\t", shift + i);
+			for (j = 0; j < 8; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\t");
+			for (; j < 16; j++)
+				pextra += sprintf(pextra, "%02X ", efuse[i + j]);
+			pextra += sprintf(pextra, "\n");
+		}
+		if ((shift + cnt) < mapLen)
+			pextra += sprintf(pextra, "\t...more\n");
+
+	} else if (strcmp(tmp[0], "wlrfkrmap") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			RTW_INFO("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
 		}
-//		DBG_871X("\n");
+		/* rmap addr cnts */
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		RTW_INFO("%s: addr=%x\n", __FUNCTION__, addr);
 
-	}
-	else if (strcmp(tmp[0],"wlrfkrmap")== 0)
-	{
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-				{
-					DBG_871X("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
-					err = -EINVAL;
-					goto exit;
-				}
-				// rmap addr cnts
-				addr = simple_strtoul(tmp[1], &ptmp, 16);
-				DBG_871X("%s: addr=%x\n", __FUNCTION__, addr);
-		
-				cnts = simple_strtoul(tmp[2], &ptmp, 10);
-				if (cnts == 0)
-				{
-					DBG_871X("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
-					err = -EINVAL;
-					goto exit;
-				}
-				DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		
-		//		DBG_871X("%s: data={", __FUNCTION__);
-			*extra = 0;
-			for (i=0; i<cnts; i++) {
-					DBG_871X("wlrfkrmap = 0x%02x \n", pEfuseHal->fakeEfuseModifiedMap[addr+i]);
-					sprintf(extra, "%s0x%02X ", extra, pEfuseHal->fakeEfuseModifiedMap[addr+i]);
-			}
-	}
-	else if (strcmp(tmp[0],"btrfkrmap")== 0)
-	{
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-				{
-					DBG_871X("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
-					err = -EINVAL;
-					goto exit;
-				}
-				// rmap addr cnts
-				addr = simple_strtoul(tmp[1], &ptmp, 16);
-				DBG_871X("%s: addr=%x\n", __FUNCTION__, addr);
-		
-				cnts = simple_strtoul(tmp[2], &ptmp, 10);
-				if (cnts == 0)
-				{
-					DBG_871X("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
-					err = -EINVAL;
-					goto exit;
-				}
-				DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		
-		//		DBG_871X("%s: data={", __FUNCTION__);
-			*extra = 0;
-			for (i=0; i<cnts; i++) {
-					DBG_871X("wlrfkrmap = 0x%02x \n", pEfuseHal->fakeBTEfuseModifiedMap[addr+i]);
-					sprintf(extra, "%s0x%02X ", extra, pEfuseHal->fakeBTEfuseModifiedMap[addr+i]);
-			}
-	}
-	else
-	{
-		 sprintf(extra, "Command not found!");
-	}
+		cnts = simple_strtoul(tmp[2], &ptmp, 10);
+		if (cnts == 0) {
+			RTW_INFO("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+
+		/*		RTW_INFO("%s: data={", __FUNCTION__); */
+		*extra = 0;
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			RTW_INFO("wlrfkrmap = 0x%02x\n", pEfuseHal->fakeEfuseModifiedMap[addr + i]);
+			pextra += sprintf(pextra, "0x%02X ", pEfuseHal->fakeEfuseModifiedMap[addr+i]);
+		}
+	} else if (strcmp(tmp[0], "btrfkrmap") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			RTW_INFO("%s: rmap Fail!! Parameters error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		/* rmap addr cnts */
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		RTW_INFO("%s: addr=%x\n", __FUNCTION__, addr);
+
+		cnts = simple_strtoul(tmp[2], &ptmp, 10);
+		if (cnts == 0) {
+			RTW_INFO("%s: rmap Fail!! cnts error!\n", __FUNCTION__);
+			err = -EINVAL;
+			goto exit;
+		}
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+
+		/*		RTW_INFO("%s: data={", __FUNCTION__); */
+		*extra = 0;
+		pextra = extra;
+		for (i = 0; i < cnts; i++) {
+			RTW_INFO("wlrfkrmap = 0x%02x\n", pEfuseHal->fakeBTEfuseModifiedMap[addr + i]);
+			pextra += sprintf(pextra, "0x%02X ", pEfuseHal->fakeBTEfuseModifiedMap[addr+i]);
+		}
+	} else if (strcmp(tmp[0], "mask") == 0) {
+		*extra = 0;
+		mask_len = sizeof(u8) * rtw_get_efuse_mask_arraylen(padapter);
+		rtw_efuse_mask_array(padapter, mask_buf);
+
+		if (padapter->registrypriv.bFileMaskEfuse == _TRUE)
+			_rtw_memcpy(mask_buf, maskfileBuffer, mask_len);
+
+		sprintf(extra, "\n");
+		pextra = extra + strlen(extra);
+		for (i = 0; i < mask_len; i++)
+			pextra += sprintf(pextra, "0x%02X\n", mask_buf[i]);
+
+	} else
+		sprintf(extra, "Command not found!");
 
 exit:
 	if (data)
@@ -10364,232 +9098,261 @@ exit:
 		rtw_mfree(rawdata, EFUSE_BT_MAX_MAP_LEN);
 	if (!err)
 		wrqu->length = strlen(extra);
-	
-	if (padapter->registrypriv.mp_mode == 0)
-	{
-	#ifdef CONFIG_IPS		
-	rtw_pm_set_ips(padapter, ips_mode);
-#endif // CONFIG_IPS
 
-	#ifdef CONFIG_LPS	
-	rtw_pm_set_lps(padapter, lps_mode);
-#endif // CONFIG_LPS
+	if (padapter->registrypriv.mp_mode == 0) {
+#ifdef CONFIG_IPS
+		rtw_pm_set_ips(padapter, ips_mode);
+#endif /* CONFIG_IPS */
+
+#ifdef CONFIG_LPS
+		rtw_pm_set_lps(padapter, lps_mode);
+#endif /* CONFIG_LPS */
 	}
 
-	#ifdef CONFIG_IOL
-	padapter->registrypriv.fw_iol = org_fw_iol;// 0:Disable, 1:enable, 2:by usb speed
-	#endif
+#ifdef CONFIG_IOL
+	padapter->registrypriv.fw_iol = org_fw_iol;/* 0:Disable, 1:enable, 2:by usb speed */
+#endif
 	return err;
 }
 
+
+#ifdef CONFIG_MP_INCLUDED
 static int rtw_mp_efuse_set(struct net_device *dev,
-			struct iw_request_info *info,
-			union iwreq_data *wdata, char *extra)
+			    struct iw_request_info *info,
+			    union iwreq_data *wdata, char *extra)
 {
 	struct iw_point *wrqu;
 	PADAPTER padapter;
 	struct pwrctrl_priv *pwrctrlpriv ;
 	PHAL_DATA_TYPE pHalData;
 	PEFUSE_HAL pEfuseHal;
+	struct hal_ops *pHalFunc;
+	struct mp_priv *pmp_priv;
 
-	u8 ips_mode = IPS_NUM; // init invalid value
-	u8 lps_mode = PS_MODE_NUM; // init invalid value
-	u32 i=0,j=0, jj, kk;
+	u8 ips_mode = IPS_NUM; /* init invalid value */
+	u8 lps_mode = PS_MODE_NUM; /* init invalid value */
+	u32 i = 0, j = 0, jj, kk;
 	u8 *setdata = NULL;
 	u8 *ShadowMapBT = NULL;
 	u8 *ShadowMapWiFi = NULL;
 	u8 *setrawdata = NULL;
-	char *pch, *ptmp, *token, *tmp[3]={0x00,0x00,0x00};
+	char *pch, *ptmp, *token, *tmp[3] = {0x00, 0x00, 0x00};
 	u16 addr = 0xFF, cnts = 0, BTStatus = 0 , max_available_len = 0;
+	u16 wifimaplen;
 	int err;
+	boolean bcmpchk = _TRUE;
+
 
-	wrqu = (struct iw_point*)wdata;
+	wrqu = (struct iw_point *)wdata;
 	padapter = rtw_netdev_priv(dev);
 	pwrctrlpriv = adapter_to_pwrctl(padapter);
 	pHalData = GET_HAL_DATA(padapter);
 	pEfuseHal = &pHalData->EfuseHal;
+	pHalFunc = &padapter->hal_func;
+	pmp_priv = &padapter->mppriv;
+
 	err = 0;
-	
+
 	if (copy_from_user(extra, wrqu->pointer, wrqu->length))
-			return -EFAULT;
-			
+		return -EFAULT;
+
+	*(extra + wrqu->length) = '\0';
+
+	EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&wifimaplen, _FALSE);
+
 	setdata = rtw_zmalloc(1024);
-	if (setdata == NULL)
-	{
+	if (setdata == NULL) {
 		err = -ENOMEM;
 		goto exit;
 	}
 	ShadowMapBT = rtw_malloc(EFUSE_BT_MAX_MAP_LEN);
-	if (ShadowMapBT == NULL)
-	{
+	if (ShadowMapBT == NULL) {
 		err = -ENOMEM;
 		goto exit;
 	}
-	ShadowMapWiFi = rtw_malloc(EFUSE_MAP_SIZE);
-	if (ShadowMapWiFi == NULL)
-	{
+	ShadowMapWiFi = rtw_malloc(wifimaplen);
+	if (ShadowMapWiFi == NULL) {
 		err = -ENOMEM;
 		goto exit;
 	}
 	setrawdata = rtw_malloc(EFUSE_MAX_SIZE);
-	if (setrawdata == NULL)
-	{
+	if (setrawdata == NULL) {
 		err = -ENOMEM;
 		goto exit;
 	}
 
-	#ifdef CONFIG_LPS
-	lps_mode = pwrctrlpriv->power_mgnt;//keep org value
-	rtw_pm_set_lps(padapter,PS_MODE_ACTIVE);
-	#endif	
-	
-	#ifdef CONFIG_IPS	
-	ips_mode = pwrctrlpriv->ips_mode;//keep org value
-	rtw_pm_set_ips(padapter,IPS_NONE);
-	#endif	
-			
+#ifdef CONFIG_LPS
+	lps_mode = pwrctrlpriv->power_mgnt;/* keep org value */
+	rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
+#endif
+
+#ifdef CONFIG_IPS
+	ips_mode = pwrctrlpriv->ips_mode;/* keep org value */
+	rtw_pm_set_ips(padapter, IPS_NONE);
+#endif
+
 	pch = extra;
-	DBG_871X("%s: in=%s\n", __FUNCTION__, extra);
-	
+	RTW_INFO("%s: in=%s\n", __FUNCTION__, extra);
+
 	i = 0;
-	while ((token = strsep(&pch, ",")) != NULL)
-	{
-		if (i > 2) break;
+	while ((token = strsep(&pch, ",")) != NULL) {
+		if (i > 2)
+			break;
 		tmp[i] = token;
 		i++;
 	}
 
-	// tmp[0],[1],[2]
-	// wmap,addr,00e04c871200
-	if (strcmp(tmp[0], "wmap") == 0)
-	{
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-		{
+	/* tmp[0],[1],[2] */
+	/* wmap,addr,00e04c871200 */
+	if (strcmp(tmp[0], "wmap") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-#if 1
-		// unknown bug workaround, need to fix later
-		addr=0x1ff;
-		rtw_write8(padapter, EFUSE_CTRL+1, (addr & 0xff));
+#ifndef RTW_HALMAC
+		/* unknown bug workaround, need to fix later */
+		addr = 0x1ff;
+		rtw_write8(padapter, EFUSE_CTRL + 1, (addr & 0xff));
 		rtw_msleep_os(10);
-		rtw_write8(padapter, EFUSE_CTRL+2, ((addr >> 8) & 0x03));
+		rtw_write8(padapter, EFUSE_CTRL + 2, ((addr >> 8) & 0x03));
 		rtw_msleep_os(10);
-		rtw_write8(padapter, EFUSE_CTRL+3, 0x72);
+		rtw_write8(padapter, EFUSE_CTRL + 3, 0x72);
 		rtw_msleep_os(10);
 		rtw_read8(padapter, EFUSE_CTRL);
-#endif
+#endif /* RTW_HALMAC */
 
 		addr = simple_strtoul(tmp[1], &ptmp, 16);
 		addr &= 0xFFF;
 
 		cnts = strlen(tmp[2]);
-		if (cnts%2)
-		{
+		if (cnts % 2) {
 			err = -EINVAL;
 			goto exit;
 		}
 		cnts /= 2;
-		if (cnts == 0)
-		{
+		if (cnts == 0) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		DBG_871X("%s: map data=%s\n", __FUNCTION__, tmp[2]);
-				
-		for (jj=0, kk=0; jj<cnts; jj++, kk+=2)
-		{
-			setdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk+1]);
-		}
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: map data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
 
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
 
 		if ((addr + cnts) > max_available_len) {
-			DBG_871X("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EFAULT;
 			goto exit;
 		}
 
-		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
+		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
 		*extra = 0;
-		DBG_871X("%s: after rtw_efuse_map_write to _rtw_memcmp\n", __func__);
-		if (rtw_efuse_mask_map_read(padapter, addr, cnts, ShadowMapWiFi) == _SUCCESS)
-		{
-			if (_rtw_memcmp((void*)ShadowMapWiFi ,(void*)setdata,cnts))
-			{ 
-				DBG_871X("%s: WiFi write map afterf compare success\n", __FUNCTION__);
+		RTW_INFO("%s: after rtw_efuse_map_write to _rtw_memcmp\n", __func__);
+		if (rtw_efuse_mask_map_read(padapter, addr, cnts, ShadowMapWiFi) == _SUCCESS) {
+			if (_rtw_memcmp((void *)ShadowMapWiFi , (void *)setdata, cnts)) {
+				RTW_INFO("%s: WiFi write map afterf compare success\n", __FUNCTION__);
 				sprintf(extra, "WiFi write map compare OK\n");
 				err = 0;
 				goto exit;
-			}
-			else
-			{
+			} else {
 				sprintf(extra, "WiFi write map compare FAIL\n");
-				DBG_871X("%s: WiFi write map compare Fail\n", __FUNCTION__);
+				RTW_INFO("%s: WiFi write map compare Fail\n", __FUNCTION__);
 				err = 0;
 				goto exit;
 			}
 		}
-	}
-	else if (strcmp(tmp[0], "wraw") == 0)
-	{
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-		{
+	} else if (strcmp(tmp[0], "wraw") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		addr = simple_strtoul( tmp[1], &ptmp, 16 );
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
 		addr &= 0xFFF;
 
 		cnts = strlen(tmp[2]);
-		if (cnts%2)
-		{
+		if (cnts % 2) {
 			err = -EINVAL;
 			goto exit;
 		}
 		cnts /= 2;
-		if (cnts == 0)
-		{
+		if (cnts == 0) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		DBG_871X("%s: raw data=%s\n", __FUNCTION__, tmp[2]);
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: raw data=%s\n", __FUNCTION__, tmp[2]);
 
-		for (jj=0, kk=0; jj<cnts; jj++, kk+=2)
-		{
-			setrawdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk+1]);
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setrawdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+
+		if (rtw_efuse_access(padapter, _TRUE, addr, cnts, setrawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+			err = -EFAULT;
+			goto exit;
+		}
+	} else if (strcmp(tmp[0], "btwraw") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
+			err = -EINVAL;
+			goto exit;
 		}
 
-		if (rtw_efuse_access(padapter, _TRUE, addr, cnts, setrawdata) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+		addr = simple_strtoul(tmp[1], &ptmp, 16);
+		addr &= 0xFFF;
+
+		cnts = strlen(tmp[2]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: raw data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setrawdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+#ifdef RTW_HALMAC
+		if (rtw_efuse_bt_access(padapter, _TRUE, addr, cnts, setrawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
-	}
-	else if (strcmp(tmp[0], "mac") == 0)
-	{
-		if (tmp[1]==NULL)
-		{
+#else
+		rtw_write8(padapter, 0x35, 1); /* switch bank 1 (BT)*/
+		if (rtw_efuse_access(padapter, _TRUE, addr, cnts, setrawdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_access error!!\n", __FUNCTION__);
+			rtw_write8(padapter, 0x35, 0); /* switch bank 0 (WiFi)*/
+			err = -EFAULT;
+			goto exit;
+		}
+		rtw_write8(padapter, 0x35, 0); /* switch bank 0 (WiFi)*/
+#endif
+	} else if (strcmp(tmp[0], "mac") == 0) {
+		if (tmp[1] == NULL) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		//mac,00e04c871200
-		
+		/* mac,00e04c871200 */
+
 		if (hal_efuse_macaddr_offset(padapter) == -1) {
 			err = -EFAULT;
 			goto exit;
@@ -10597,223 +9360,208 @@ static int rtw_mp_efuse_set(struct net_device *dev,
 
 		addr = hal_efuse_macaddr_offset(padapter);
 		cnts = strlen(tmp[1]);
-		if (cnts%2)
-		{
+		if (cnts % 2) {
 			err = -EINVAL;
 			goto exit;
 		}
 		cnts /= 2;
-		if (cnts == 0)
-		{
+		if (cnts == 0) {
 			err = -EINVAL;
 			goto exit;
 		}
-		if (cnts > 6)
-		{
-			DBG_871X("%s: error data for mac addr=\"%s\"\n", __FUNCTION__, tmp[1]);
+		if (cnts > 6) {
+			RTW_INFO("%s: error data for mac addr=\"%s\"\n", __FUNCTION__, tmp[1]);
 			err = -EFAULT;
 			goto exit;
 		}
 
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		DBG_871X("%s: MAC address=%s\n", __FUNCTION__, tmp[1]);
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: MAC address=%s\n", __FUNCTION__, tmp[1]);
 
-		for (jj=0, kk=0; jj<cnts; jj++, kk+=2)
-		{
-			setdata[jj] = key_2char2num(tmp[1][kk], tmp[1][kk+1]);
-		}
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
 
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
 
 		if ((addr + cnts) > max_available_len) {
-			DBG_871X("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EFAULT;
 			goto exit;
 		}
 
-		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
+		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
-		}
-	}
-	else if (strcmp(tmp[0], "vidpid") == 0)
-	{
-		if (tmp[1]==NULL)
-		{
+		}
+	} else if (strcmp(tmp[0], "vidpid") == 0) {
+		if (tmp[1] == NULL) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		// pidvid,da0b7881		
-		#ifdef CONFIG_RTL8188E
-			#ifdef CONFIG_USB_HCI
-			addr = EEPROM_VID_88EU;
-			#endif
-			#ifdef CONFIG_PCI_HCI
-			addr = EEPROM_VID_88EE;
-			#endif
-		#endif // CONFIG_RTL8188E
+		/* pidvid,da0b7881		 */
+#ifdef CONFIG_RTL8188E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_88EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_88EE;
+#endif
+#endif /* CONFIG_RTL8188E */
 
-		#ifdef CONFIG_RTL8192E
-			#ifdef CONFIG_USB_HCI
-			addr = EEPROM_VID_8192EU;
-			#endif
-			#ifdef CONFIG_PCI_HCI
-			addr = EEPROM_VID_8192EE;
-			#endif
-		#endif // CONFIG_RTL8188E
+#ifdef CONFIG_RTL8192E
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8192EU;
+#endif
+#ifdef CONFIG_PCI_HCI
+		addr = EEPROM_VID_8192EE;
+#endif
+#endif /* CONFIG_RTL8188E */
 
-		#ifdef CONFIG_RTL8723B
+#ifdef CONFIG_RTL8723B
 		addr = EEPROM_VID_8723BU;
-		#endif
+#endif
 
-		#ifdef CONFIG_RTL8188F
+#ifdef CONFIG_RTL8188F
 		addr = EEPROM_VID_8188FU;
-		#endif
+#endif
+
+#ifdef CONFIG_RTL8188GTV
+		addr = EEPROM_VID_8188GTVU;
+#endif
+
+#ifdef CONFIG_RTL8703B
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8703BU;
+#endif /* CONFIG_USB_HCI */
+#endif /* CONFIG_RTL8703B */
 
-		#ifdef CONFIG_RTL8703B
-			#ifdef CONFIG_USB_HCI
-			addr = EEPROM_VID_8703BU;
-			#endif /* CONFIG_USB_HCI */
-		#endif /* CONFIG_RTL8703B */
+#ifdef CONFIG_RTL8723D
+#ifdef CONFIG_USB_HCI
+		addr = EEPROM_VID_8723DU;
+#endif /* CONFIG_USB_HCI */
+#endif /* CONFIG_RTL8723D */
 
 		cnts = strlen(tmp[1]);
-		if (cnts%2)
-		{
+		if (cnts % 2) {
 			err = -EINVAL;
 			goto exit;
 		}
 		cnts /= 2;
-		if (cnts == 0)
-		{
+		if (cnts == 0) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		DBG_871X("%s: VID/PID=%s\n", __FUNCTION__, tmp[1]);
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: VID/PID=%s\n", __FUNCTION__, tmp[1]);
 
-		for (jj=0, kk=0; jj<cnts; jj++, kk+=2)
-		{
-			setdata[jj] = key_2char2num(tmp[1][kk], tmp[1][kk+1]);
-		}
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
 
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
 		if ((addr + cnts) > max_available_len) {
-			DBG_871X("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EFAULT;
 			goto exit;
 		}
 
-		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
+		if (rtw_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write error!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
-	}
-        else if (strcmp(tmp[0], "wldumpfake") == 0)
-	{
-		if (rtw_efuse_mask_map_read(padapter, 0, EFUSE_MAP_SIZE, pEfuseHal->fakeEfuseModifiedMap) == _SUCCESS) {
-			DBG_871X("%s: WiFi hw efuse dump to Fake map success\n", __func__);
-		} else {
-			DBG_871X("%s: WiFi hw efuse dump to Fake map Fail\n", __func__);
+	} else if (strcmp(tmp[0], "wldumpfake") == 0) {
+		if (wifimaplen > EFUSE_MAX_MAP_LEN)
+			cnts = EFUSE_MAX_MAP_LEN;
+		else
+			cnts = wifimaplen;
+		if (rtw_efuse_mask_map_read(padapter, 0, cnts, pEfuseHal->fakeEfuseModifiedMap) == _SUCCESS)
+			RTW_INFO("%s: WiFi hw efuse dump to Fake map success\n", __func__);
+		else {
+			RTW_INFO("%s: WiFi hw efuse dump to Fake map Fail\n", __func__);
 			err = -EFAULT;
 		}
-	}
-	else if (strcmp(tmp[0], "btwmap") == 0)
-	{
-		rtw_write8(padapter, 0xa3, 0x05); //For 8723AB ,8821S ?
-		BTStatus=rtw_read8(padapter, 0xa0);
-		DBG_871X("%s: btwmap before read 0xa0 BT Status =0x%x \n", __FUNCTION__,BTStatus);
-		if (BTStatus != 0x04)
-		{
-			sprintf(extra, "BT Status not Active Write FAIL\n");
+	} else if (strcmp(tmp[0], "btwmap") == 0) {
+		rtw_write8(padapter, 0xa3, 0x05); /* For 8723AB ,8821S ? */
+		BTStatus = rtw_read8(padapter, 0xa0);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __FUNCTION__, BTStatus);
+		if (BTStatus != 0x04) {
+			sprintf(extra, "BT Status not Active ,can't do Write\n");
 			goto exit;
 		}
 
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-		{
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
 			err = -EINVAL;
 			goto exit;
 		}
-		BTEfuse_PowerSwitch(padapter,1,_TRUE);
-		
-		addr=0x1ff;
-		rtw_write8(padapter, EFUSE_CTRL+1, (addr & 0xff));
+
+#ifndef RTW_HALMAC
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+		addr = 0x1ff;
+		rtw_write8(padapter, EFUSE_CTRL + 1, (addr & 0xff));
 		rtw_msleep_os(10);
-		rtw_write8(padapter, EFUSE_CTRL+2, ((addr >> 8) & 0x03));
+		rtw_write8(padapter, EFUSE_CTRL + 2, ((addr >> 8) & 0x03));
 		rtw_msleep_os(10);
-		rtw_write8(padapter, EFUSE_CTRL+3, 0x72);
+		rtw_write8(padapter, EFUSE_CTRL + 3, 0x72);
 		rtw_msleep_os(10);
 		rtw_read8(padapter, EFUSE_CTRL);
+		BTEfuse_PowerSwitch(padapter, 1, _FALSE);
+#endif /* RTW_HALMAC */
 
 		addr = simple_strtoul(tmp[1], &ptmp, 16);
 		addr &= 0xFFF;
 
 		cnts = strlen(tmp[2]);
-		if (cnts%2)
-		{
+		if (cnts % 2) {
 			err = -EINVAL;
 			goto exit;
 		}
 		cnts /= 2;
-		if (cnts == 0)
-		{
+		if (cnts == 0) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		DBG_871X("%s: BT data=%s\n", __FUNCTION__, tmp[2]);
-
-		for (jj=0, kk=0; jj<cnts; jj++, kk+=2)
-		{
-			setdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk+1]);
-		}
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: BT data=%s\n", __FUNCTION__, tmp[2]);
 
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			setdata[jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+#ifndef RTW_HALMAC
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (PVOID)&max_available_len, _FALSE);
 		if ((addr + cnts) > max_available_len) {
-			DBG_871X("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
+			RTW_INFO("%s: addr(0x%X)+cnts(%d) parameter error!\n", __FUNCTION__, addr, cnts);
 			err = -EFAULT;
 			goto exit;
 		}
-
-		if (rtw_BT_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL)
-		{
-			DBG_871X("%s: rtw_BT_efuse_map_write error!!\n", __FUNCTION__);
+#endif
+		if (rtw_BT_efuse_map_write(padapter, addr, cnts, setdata) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_write error!!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
 		*extra = 0;
-		DBG_871X("%s: after rtw_BT_efuse_map_write to _rtw_memcmp \n", __FUNCTION__);
-		if ( (rtw_BT_efuse_map_read(padapter, addr, cnts, ShadowMapBT ) == _SUCCESS ) )
-		{
-			if (_rtw_memcmp((void*)ShadowMapBT ,(void*)setdata,cnts))
-			{ 
-				DBG_871X("%s: BT write map compare OK BTStatus=0x%x\n", __FUNCTION__,BTStatus);
+		RTW_INFO("%s: after rtw_BT_efuse_map_write to _rtw_memcmp\n", __FUNCTION__);
+		if ((rtw_BT_efuse_map_read(padapter, addr, cnts, ShadowMapBT) == _SUCCESS)) {
+			if (_rtw_memcmp((void *)ShadowMapBT , (void *)setdata, cnts)) {
+				RTW_INFO("%s: BT write map compare OK BTStatus=0x%x\n", __FUNCTION__, BTStatus);
 				sprintf(extra, "BT write map compare OK");
 				err = 0;
 				goto exit;
-			}
-			else
-			{
+			} else {
 				sprintf(extra, "BT write map compare FAIL");
-				DBG_871X("%s: BT write map compare FAIL BTStatus=0x%x\n", __FUNCTION__,BTStatus);
+				RTW_INFO("%s: BT write map compare FAIL BTStatus=0x%x\n", __FUNCTION__, BTStatus);
 				err = 0;
 				goto exit;
 			}
 		}
-	}
-	else if (strcmp(tmp[0], "btwfake") == 0)
-	{
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-		{
+	} else if (strcmp(tmp[0], "btwfake") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
 			err = -EINVAL;
 			goto exit;
 		}
@@ -10822,159 +9570,163 @@ static int rtw_mp_efuse_set(struct net_device *dev,
 		addr &= 0xFFF;
 
 		cnts = strlen(tmp[2]);
-		if (cnts%2)
-		{
+		if (cnts % 2) {
 			err = -EINVAL;
 			goto exit;
 		}
 		cnts /= 2;
-		if (cnts == 0)
-		{
+		if (cnts == 0) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		DBG_871X("%s: BT tmp data=%s\n", __FUNCTION__, tmp[2]);
-				
-		for (jj=0, kk=0; jj<cnts; jj++, kk+=2)
-		{
-			pEfuseHal->fakeBTEfuseModifiedMap[addr+jj] = key_2char2num(tmp[2][kk], tmp[2][kk+1]);
-		}
-	}
-	else if (strcmp(tmp[0], "btdumpfake") == 0)
-	{
-		if (rtw_BT_efuse_map_read(padapter, 0, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _SUCCESS) {
-			DBG_871X("%s: BT read all map success\n", __FUNCTION__);
-		} else {
-			DBG_871X("%s: BT read all map Fail!\n", __FUNCTION__);
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: BT tmp data=%s\n", __FUNCTION__, tmp[2]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			pEfuseHal->fakeBTEfuseModifiedMap[addr + jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
+	} else if (strcmp(tmp[0], "btdumpfake") == 0) {
+		if (rtw_BT_efuse_map_read(padapter, 0, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _SUCCESS)
+			RTW_INFO("%s: BT read all map success\n", __FUNCTION__);
+		else {
+			RTW_INFO("%s: BT read all map Fail!\n", __FUNCTION__);
 			err = -EFAULT;
 		}
-	}
-	else if (strcmp(tmp[0], "btfk2map") == 0)
-	{
+	} else if (strcmp(tmp[0], "btfk2map") == 0) {
 		rtw_write8(padapter, 0xa3, 0x05);
-		BTStatus=rtw_read8(padapter, 0xa0);
-		DBG_871X("%s: btwmap before read 0xa0 BT Status =0x%x \n", __FUNCTION__,BTStatus);
-		if (BTStatus != 0x04)
-		{
+		BTStatus = rtw_read8(padapter, 0xa0);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __FUNCTION__, BTStatus);
+		if (BTStatus != 0x04) {
 			sprintf(extra, "BT Status not Active Write FAIL\n");
 			goto exit;
 		}
-		
-		BTEfuse_PowerSwitch(padapter,1,_TRUE);
-
-		addr=0x1ff;
-		rtw_write8(padapter, EFUSE_CTRL+1, (addr & 0xff));
+#ifndef RTW_HALMAC
+		BTEfuse_PowerSwitch(padapter, 1, _TRUE);
+		addr = 0x1ff;
+		rtw_write8(padapter, EFUSE_CTRL + 1, (addr & 0xff));
 		rtw_msleep_os(10);
-		rtw_write8(padapter, EFUSE_CTRL+2, ((addr >> 8) & 0x03));
+		rtw_write8(padapter, EFUSE_CTRL + 2, ((addr >> 8) & 0x03));
 		rtw_msleep_os(10);
-		rtw_write8(padapter, EFUSE_CTRL+3, 0x72);
+		rtw_write8(padapter, EFUSE_CTRL + 3, 0x72);
 		rtw_msleep_os(10);
 		rtw_read8(padapter, EFUSE_CTRL);
-
+		BTEfuse_PowerSwitch(padapter, 1, _FALSE);
+#endif /* RTW_HALMAC */
 		_rtw_memcpy(pEfuseHal->BTEfuseModifiedMap, pEfuseHal->fakeBTEfuseModifiedMap, EFUSE_BT_MAX_MAP_LEN);
 
-		if (rtw_BT_efuse_map_write(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _FAIL)
-		{
-			DBG_871X("%s: rtw_BT_efuse_map_write error!\n", __FUNCTION__);
+		if (rtw_BT_efuse_map_write(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _FAIL) {
+			RTW_INFO("%s: rtw_BT_efuse_map_write error!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
-		
-		DBG_871X("pEfuseHal->fakeBTEfuseModifiedMap OFFSET\tVALUE(hex)\n");
-		for (i = 0; i < EFUSE_BT_MAX_MAP_LEN; i += 16)
-		{
+
+		RTW_INFO("pEfuseHal->fakeBTEfuseModifiedMap OFFSET\tVALUE(hex)\n");
+		for (i = 0; i < EFUSE_BT_MAX_MAP_LEN; i += 16) {
 			printk("0x%02x\t", i);
-			for (j=0; j<8; j++) {
-				printk("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
-			}
+			for (j = 0; j < 8; j++)
+				printk("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i + j]);
 			printk("\t");
 
-			for (; j<16; j++) {
-				printk("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i+j]);
-			}
+			for (; j < 16; j++)
+				printk("%02X ", pEfuseHal->fakeBTEfuseModifiedMap[i + j]);
 			printk("\n");
 		}
 		printk("\n");
-#if 1		
+#if 1
 		err = -EFAULT;
-		DBG_871X("%s: rtw_BT_efuse_map_read _rtw_memcmp \n", __FUNCTION__);
-		if ( (rtw_BT_efuse_map_read(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseInitMap) == _SUCCESS ) )
-		{ 
-			if (_rtw_memcmp((void*)pEfuseHal->fakeBTEfuseModifiedMap,(void*)pEfuseHal->fakeBTEfuseInitMap,EFUSE_BT_MAX_MAP_LEN))
-			{ 
+		RTW_INFO("%s: rtw_BT_efuse_map_read _rtw_memcmp\n", __FUNCTION__);
+		if ((rtw_BT_efuse_map_read(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseInitMap) == _SUCCESS)) {
+			if (_rtw_memcmp((void *)pEfuseHal->fakeBTEfuseModifiedMap, (void *)pEfuseHal->fakeBTEfuseInitMap, EFUSE_BT_MAX_MAP_LEN)) {
 				sprintf(extra, "BT write map compare OK");
-				DBG_871X("%s: BT write map afterf compare success BTStatus=0x%x \n", __FUNCTION__,BTStatus);
+				RTW_INFO("%s: BT write map afterf compare success BTStatus=0x%x\n", __FUNCTION__, BTStatus);
 				err = 0;
 				goto exit;
-			}
-			else
-			{
+			} else {
 				sprintf(extra, "BT write map compare FAIL");
 				if (rtw_BT_efuse_map_write(padapter, 0x00, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseModifiedMap) == _FAIL)
-				{
-					DBG_871X("%s: rtw_BT_efuse_map_write compare error,retry = %d!\n", __FUNCTION__,i);
-				}
+					RTW_INFO("%s: rtw_BT_efuse_map_write compare error,retry = %d!\n", __FUNCTION__, i);
 
-				if (rtw_BT_efuse_map_read(padapter, EFUSE_BT, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseInitMap) == _SUCCESS)
-				{
-					DBG_871X("pEfuseHal->fakeBTEfuseInitMap OFFSET\tVALUE(hex)\n");
+				if (rtw_BT_efuse_map_read(padapter, EFUSE_BT, EFUSE_BT_MAX_MAP_LEN, pEfuseHal->fakeBTEfuseInitMap) == _SUCCESS) {
+					RTW_INFO("pEfuseHal->fakeBTEfuseInitMap OFFSET\tVALUE(hex)\n");
 
-					for (i = 0; i < EFUSE_BT_MAX_MAP_LEN; i += 16)
-					{
+					for (i = 0; i < EFUSE_BT_MAX_MAP_LEN; i += 16) {
 						printk("0x%02x\t", i);
-						for (j=0; j<8; j++) {
-							printk("%02X ", pEfuseHal->fakeBTEfuseInitMap[i+j]);
-						}
+						for (j = 0; j < 8; j++)
+							printk("%02X ", pEfuseHal->fakeBTEfuseInitMap[i + j]);
 						printk("\t");
-						for (; j<16; j++) {
-							printk("%02X ", pEfuseHal->fakeBTEfuseInitMap[i+j]);
-						}
+						for (; j < 16; j++)
+							printk("%02X ", pEfuseHal->fakeBTEfuseInitMap[i + j]);
 						printk("\n");
 					}
-					printk("\n"); 
+					printk("\n");
 				}
-				DBG_871X("%s: BT write map afterf compare not match to write efuse try write Map again , BTStatus=0x%x\n", __FUNCTION__,BTStatus);	
+				RTW_INFO("%s: BT write map afterf compare not match to write efuse try write Map again , BTStatus=0x%x\n", __FUNCTION__, BTStatus);
 				goto exit;
 			}
 		}
 #endif
 
-	}
-	else if (strcmp(tmp[0], "wlfk2map") == 0)
-	{
-		if (rtw_efuse_map_write(padapter, 0x00, EFUSE_MAP_SIZE, pEfuseHal->fakeEfuseModifiedMap) == _FAIL)
-		{
-			DBG_871X("%s: rtw_efuse_map_write fakeEfuseModifiedMap error!\n", __FUNCTION__);
+	} else if (strcmp(tmp[0], "wlfk2map") == 0) {
+		*extra = 0;
+
+		if (padapter->registrypriv.bFileMaskEfuse != _TRUE && pmp_priv->bloadefusemap == _TRUE) {
+			RTW_INFO("%s: File eFuse mask file not to be loaded\n", __FUNCTION__);
+			sprintf(extra, "Not load eFuse mask file yet, Please use the efuse_mask CMD, now remove the interface !!!!\n");
+			rtw_set_surprise_removed(padapter);
+			err = 0;
+			goto exit;
+		}
+
+		if (wifimaplen > EFUSE_MAX_MAP_LEN)
+			cnts = EFUSE_MAX_MAP_LEN;
+		else
+			cnts = wifimaplen;
+		if (rtw_efuse_map_write(padapter, 0x00, cnts, pEfuseHal->fakeEfuseModifiedMap) == _FAIL) {
+			RTW_INFO("%s: rtw_efuse_map_write fakeEfuseModifiedMap error!\n", __FUNCTION__);
 			err = -EFAULT;
 			goto exit;
 		}
-		*extra = 0;
-		DBG_871X("%s: after rtw_BT_efuse_map_write to _rtw_memcmp\n", __func__);
-		if (rtw_efuse_mask_map_read(padapter, 0x00, EFUSE_MAP_SIZE, ShadowMapWiFi) == _SUCCESS)
-		{
-			if (_rtw_memcmp((void*)ShadowMapWiFi ,(void*)setdata,cnts))
-			{
-				DBG_871X("%s: WiFi write map afterf compare OK\n", __FUNCTION__);
-				sprintf(extra, "WiFi write map compare OK\n");
-				err = 0;
-				goto exit;
-			}
-			else
-			{
-				sprintf(extra, "WiFi write map compare FAIL\n");
-				DBG_871X("%s: WiFi write map compare Fail\n", __FUNCTION__);
-				err = 0;
-				goto exit;
+
+		if (rtw_efuse_mask_map_read(padapter, 0x00, wifimaplen, ShadowMapWiFi) == _SUCCESS) {
+			addr = 0x00;
+			err = _TRUE;
+
+			for (i = 0; i < cnts; i++) {
+				if (padapter->registrypriv.boffefusemask == 0) {
+					if (padapter->registrypriv.bFileMaskEfuse == _TRUE) {
+						if (rtw_file_efuse_IsMasked(padapter, addr + i) == _TRUE)	/*use file efuse mask. */
+							bcmpchk = _FALSE;
+					} else {
+						if (efuse_IsMasked(padapter, addr + i) == _TRUE)
+							bcmpchk = _FALSE;
+					}
+				}
+
+				if (bcmpchk == _TRUE) {
+					RTW_INFO("compare readMapWiFi[0x%02x] = %x, ModifiedMap = %x\n", addr + i, ShadowMapWiFi[ addr + i], pEfuseHal->fakeEfuseModifiedMap[addr + i]);
+					if (_rtw_memcmp((void *) &ShadowMapWiFi[addr + i], (void *)&pEfuseHal->fakeEfuseModifiedMap[addr + i], 1) == _FALSE){
+						err = _FALSE;
+						break;
+					}
+				}
+				bcmpchk = _TRUE;
 			}
 		}
-	}
-	else if (strcmp(tmp[0], "wlwfake") == 0)
-	{
-		if ((tmp[1]==NULL) || (tmp[2]==NULL))
-		{
+
+		if (err) {
+			RTW_INFO("%s: WiFi write map afterf compare OK\n", __FUNCTION__);
+			sprintf(extra, "WiFi write map compare OK\n");
+			err = 0;
+			goto exit;
+		} else {
+			sprintf(extra, "WiFi write map compare FAIL\n");
+			RTW_INFO("%s: WiFi write map compare Fail\n", __FUNCTION__);
+			err = 0;
+			goto exit;
+		}
+	} else if (strcmp(tmp[0], "wlwfake") == 0) {
+		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
 			err = -EINVAL;
 			goto exit;
 		}
@@ -10983,59 +9735,117 @@ static int rtw_mp_efuse_set(struct net_device *dev,
 		addr &= 0xFFF;
 
 		cnts = strlen(tmp[2]);
-		if (cnts%2)
-		{
+		if (cnts % 2) {
 			err = -EINVAL;
 			goto exit;
 		}
 		cnts /= 2;
-		if (cnts == 0)
-		{
+		if (cnts == 0) {
 			err = -EINVAL;
 			goto exit;
 		}
 
-		DBG_871X("%s: addr=0x%X\n", __FUNCTION__, addr);
-		DBG_871X("%s: cnts=%d\n", __FUNCTION__, cnts);
-		DBG_871X("%s: map tmp data=%s\n", __FUNCTION__, tmp[2]);
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: map tmp data=%s\n", __FUNCTION__, tmp[2]);
 
-		for (jj=0, kk=0; jj<cnts; jj++, kk+=2)
-		{
-			pEfuseHal->fakeEfuseModifiedMap[addr+jj] = key_2char2num(tmp[2][kk], tmp[2][kk+1]);
-		}
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			pEfuseHal->fakeEfuseModifiedMap[addr + jj] = key_2char2num(tmp[2][kk], tmp[2][kk + 1]);
 		_rtw_memset(extra, '\0', strlen(extra));
 		sprintf(extra, "wlwfake OK\n");
+
 	}
+	else if (strcmp(tmp[0], "wfakemac") == 0) {
+		if (tmp[1] == NULL) {
+			err = -EINVAL;
+			goto exit;
+		}
+		/* wfakemac,00e04c871200 */
+		if (hal_efuse_macaddr_offset(padapter) == -1) {
+			err = -EFAULT;
+			goto exit;
+		}
+
+		addr = hal_efuse_macaddr_offset(padapter);
+		cnts = strlen(tmp[1]);
+		if (cnts % 2) {
+			err = -EINVAL;
+			goto exit;
+		}
+		cnts /= 2;
+		if (cnts == 0) {
+			err = -EINVAL;
+			goto exit;
+		}
+		if (cnts > 6) {
+			RTW_INFO("%s: error data for mac addr=\"%s\"\n", __FUNCTION__, tmp[1]);
+			err = -EFAULT;
+			goto exit;
+		}
+
+		RTW_INFO("%s: addr=0x%X\n", __FUNCTION__, addr);
+		RTW_INFO("%s: cnts=%d\n", __FUNCTION__, cnts);
+		RTW_INFO("%s: MAC address=%s\n", __FUNCTION__, tmp[1]);
+
+		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2)
+			pEfuseHal->fakeEfuseModifiedMap[addr + jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
+
+		_rtw_memset(extra, '\0', strlen(extra));
+		sprintf(extra, "write mac addr to fake map OK\n");
+	} else if(strcmp(tmp[0], "update") == 0) {
+		RTW_INFO("To Use new eFuse map\n");
+		/*step read efuse/eeprom data and get mac_addr*/
+		rtw_hal_read_chip_info(padapter);
+		/* set mac addr*/
+		rtw_macaddr_cfg(adapter_mac_addr(padapter), get_hal_mac_addr(padapter));
+		_rtw_memcpy(padapter->pnetdev->dev_addr, get_hal_mac_addr(padapter), ETH_ALEN); /* set mac addr to net_device */
+
+#ifdef CONFIG_P2P
+		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+#endif
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_hal_change_macaddr_mbid(padapter, adapter_mac_addr(padapter));
+#else
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, adapter_mac_addr(padapter)); /* set mac addr to mac register */
+#endif
+		/*pHalFunc->hal_deinit(padapter);*/
+		if (pHalFunc->hal_init(padapter) == _FAIL) {
+			err = -EINVAL;
+			goto exit;
+		}
+		_rtw_memset(extra, '\0', strlen(extra));
+		sprintf(extra, "eFuse Update OK\n");
+	} else if (strcmp(tmp[0], "analyze") == 0) {
 
+		rtw_efuse_analyze(padapter, EFUSE_WIFI, 0);
+		_rtw_memset(extra, '\0', strlen(extra));
+		sprintf(extra, "eFuse Analyze OK,please to check kernel log\n");
+	}
 exit:
 	if (setdata)
 		rtw_mfree(setdata, 1024);
 	if (ShadowMapBT)
 		rtw_mfree(ShadowMapBT, EFUSE_BT_MAX_MAP_LEN);
 	if (ShadowMapWiFi)
-		rtw_mfree(ShadowMapWiFi, EFUSE_MAP_SIZE);
+		rtw_mfree(ShadowMapWiFi, wifimaplen);
 	if (setrawdata)
 		rtw_mfree(setrawdata, EFUSE_MAX_SIZE);
-	
+
 	wrqu->length = strlen(extra);
 
-	if (padapter->registrypriv.mp_mode == 0)
-	{
-	#ifdef CONFIG_IPS		
-	rtw_pm_set_ips(padapter, ips_mode);
-        #endif // CONFIG_IPS
+	if (padapter->registrypriv.mp_mode == 0) {
+#ifdef CONFIG_IPS
+		rtw_pm_set_ips(padapter, ips_mode);
+#endif /* CONFIG_IPS */
 
-	#ifdef CONFIG_LPS	
-	rtw_pm_set_lps(padapter, lps_mode);
-        #endif // CONFIG_LPS
+#ifdef CONFIG_LPS
+		rtw_pm_set_lps(padapter, lps_mode);
+#endif /* CONFIG_LPS */
 	}
 
 	return err;
 }
 
-
-#ifdef CONFIG_MP_INCLUDED
-
 #ifdef CONFIG_RTW_CUSTOMER_STR
 static int rtw_mp_customer_str(
 	struct net_device *dev,
@@ -11125,22 +9935,246 @@ static int rtw_mp_customer_str(
 		extra[pos] = 0;
 		pos--;
 	}
-	pos += sprintf(extra + pos, " %s", ret == _SUCCESS ? "OK" : "FAIL");
+	pos += sprintf(extra + pos, " %s", ret == _SUCCESS ? "OK" : "FAIL");
+
+	wrqu->data.length = strlen(extra) + 1;
+
+free_buf:
+	rtw_mfree(pbuf, len);
+	return 0;
+}
+#endif /* CONFIG_RTW_CUSTOMER_STR */
+
+static int rtw_priv_mp_set(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wdata, char *extra)
+{
+
+	struct iw_point *wrqu = (struct iw_point *)wdata;
+	u32 subcmd = wrqu->flags;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (!is_primary_adapter(padapter)) {
+		RTW_INFO("MP mode only primary Adapter support\n");
+		return -EIO;
+	}
+
+	switch (subcmd) {
+	case CTA_TEST:
+		RTW_INFO("set CTA_TEST\n");
+		rtw_cta_test_start(dev, info, wdata, extra);
+		break;
+	case MP_DISABLE_BT_COEXIST:
+		RTW_INFO("set case MP_DISABLE_BT_COEXIST\n");
+		rtw_mp_disable_bt_coexist(dev, info, wdata, extra);
+		break;
+	case MP_IQK:
+		RTW_INFO("set MP_IQK\n");
+		rtw_mp_iqk(dev, info, wrqu, extra);
+		break;
+	case MP_LCK:
+		RTW_INFO("set MP_LCK\n");
+		rtw_mp_lck(dev, info, wrqu, extra);
+	break;
+
+	default:
+		return -EIO;
+	}
+
+	return 0;
+}
+
+static int rtw_priv_mp_get(struct net_device *dev,
+			   struct iw_request_info *info,
+			   union iwreq_data *wdata, char *extra)
+{
+
+	struct iw_point *wrqu = (struct iw_point *)wdata;
+	u32 subcmd = wrqu->flags;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (!is_primary_adapter(padapter)) {
+		RTW_INFO("MP mode only primary Adapter support\n");
+		return -EIO;
+	}
+
+	switch (subcmd) {
+	case MP_START:
+		RTW_INFO("set case mp_start\n");
+		rtw_mp_start(dev, info, wrqu, extra);
+		break;
+	case MP_STOP:
+		RTW_INFO("set case mp_stop\n");
+		rtw_mp_stop(dev, info, wrqu, extra);
+		break;
+	case MP_BANDWIDTH:
+		RTW_INFO("set case mp_bandwidth\n");
+		rtw_mp_bandwidth(dev, info, wrqu, extra);
+		break;
+	case MP_RESET_STATS:
+		RTW_INFO("set case MP_RESET_STATS\n");
+		rtw_mp_reset_stats(dev, info, wrqu, extra);
+		break;
+	case MP_SetRFPathSwh:
+		RTW_INFO("set MP_SetRFPathSwitch\n");
+		rtw_mp_SetRFPath(dev, info, wrqu, extra);
+		break;
+	case WRITE_REG:
+		rtw_mp_write_reg(dev, info, wrqu, extra);
+		break;
+	case WRITE_RF:
+		rtw_mp_write_rf(dev, info, wrqu, extra);
+		break;
+	case MP_PHYPARA:
+		RTW_INFO("mp_get  MP_PHYPARA\n");
+		rtw_mp_phypara(dev, info, wrqu, extra);
+		break;
+	case MP_CHANNEL:
+		RTW_INFO("set case mp_channel\n");
+		rtw_mp_channel(dev , info, wrqu, extra);
+		break;
+    	case  MP_CHL_OFFSET:
+       		RTW_INFO("set case mp_ch_offset\n");
+        	rtw_mp_ch_offset(dev , info, wrqu, extra);
+        	break;
+	case READ_REG:
+		RTW_INFO("mp_get  READ_REG\n");
+		rtw_mp_read_reg(dev, info, wrqu, extra);
+		break;
+	case READ_RF:
+		RTW_INFO("mp_get  READ_RF\n");
+		rtw_mp_read_rf(dev, info, wrqu, extra);
+		break;
+	case MP_RATE:
+		RTW_INFO("set case mp_rate\n");
+		rtw_mp_rate(dev, info, wrqu, extra);
+		break;
+	case MP_TXPOWER:
+		RTW_INFO("set case MP_TXPOWER\n");
+		rtw_mp_txpower(dev, info, wrqu, extra);
+		break;
+	case MP_ANT_TX:
+		RTW_INFO("set case MP_ANT_TX\n");
+		rtw_mp_ant_tx(dev, info, wrqu, extra);
+		break;
+	case MP_ANT_RX:
+		RTW_INFO("set case MP_ANT_RX\n");
+		rtw_mp_ant_rx(dev, info, wrqu, extra);
+		break;
+	case MP_QUERY:
+		rtw_mp_trx_query(dev, info, wrqu, extra);
+		break;
+	case MP_CTX:
+		RTW_INFO("set case MP_CTX\n");
+		rtw_mp_ctx(dev, info, wrqu, extra);
+		break;
+	case MP_ARX:
+		RTW_INFO("set case MP_ARX\n");
+		rtw_mp_arx(dev, info, wrqu, extra);
+		break;
+	case MP_DUMP:
+		RTW_INFO("set case MP_DUMP\n");
+		rtw_mp_dump(dev, info, wrqu, extra);
+		break;
+	case MP_PSD:
+		RTW_INFO("set case MP_PSD\n");
+		rtw_mp_psd(dev, info, wrqu, extra);
+		break;
+	case MP_THER:
+		RTW_INFO("set case MP_THER\n");
+		rtw_mp_thermal(dev, info, wrqu, extra);
+		break;
+	case MP_PwrCtlDM:
+		RTW_INFO("set MP_PwrCtlDM\n");
+		rtw_mp_PwrCtlDM(dev, info, wrqu, extra);
+		break;
+	case MP_QueryDrvStats:
+		RTW_INFO("mp_get MP_QueryDrvStats\n");
+		rtw_mp_QueryDrv(dev, info, wdata, extra);
+		break;
+	case MP_PWRTRK:
+		RTW_INFO("set case MP_PWRTRK\n");
+		rtw_mp_pwrtrk(dev, info, wrqu, extra);
+		break;
+#ifdef CONFIG_MP_INCLUDED
+	case EFUSE_SET:
+		RTW_INFO("set case efuse set\n");
+		rtw_mp_efuse_set(dev, info, wdata, extra);
+		break;
+#endif
+	case EFUSE_GET:
+		RTW_INFO("efuse get EFUSE_GET\n");
+		rtw_mp_efuse_get(dev, info, wdata, extra);
+		break;
+	case MP_GET_TXPOWER_INX:
+		RTW_INFO("mp_get MP_GET_TXPOWER_INX\n");
+		rtw_mp_txpower_index(dev, info, wrqu, extra);
+		break;
+	case MP_GETVER:
+		RTW_INFO("mp_get MP_GETVER\n");
+		rtw_mp_getver(dev, info, wdata, extra);
+		break;
+	case MP_MON:
+		RTW_INFO("mp_get MP_MON\n");
+		rtw_mp_mon(dev, info, wdata, extra);
+		break;
+	case EFUSE_MASK:
+		RTW_INFO("mp_get EFUSE_MASK\n");
+		rtw_efuse_mask_file(dev, info, wdata, extra);
+		break;
+	case  EFUSE_FILE:
+		RTW_INFO("mp_get EFUSE_FILE\n");
+		rtw_efuse_file_map(dev, info, wdata, extra);
+		break;
+	case  MP_TX:
+		RTW_INFO("mp_get MP_TX\n");
+		rtw_mp_tx(dev, info, wdata, extra);
+		break;
+	case  MP_RX:
+		RTW_INFO("mp_get MP_RX\n");
+		rtw_mp_rx(dev, info, wdata, extra);
+		break;
+	case MP_HW_TX_MODE:
+		RTW_INFO("mp_get MP_HW_TX_MODE\n");
+		rtw_mp_hwtx(dev, info, wdata, extra);
+		break;
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	case MP_CUSTOMER_STR:
+		RTW_INFO("customer str\n");
+		rtw_mp_customer_str(dev, info, wdata, extra);
+		break;
+#endif
+	case MP_PWRLMT:
+		RTW_INFO("mp_get MP_SETPWRLMT\n");
+		rtw_mp_pwrlmt(dev, info, wdata, extra);
+		break;
+	case MP_PWRBYRATE:
+		RTW_INFO("mp_get MP_SETPWRBYRATE\n");
+		rtw_mp_pwrbyrate(dev, info, wdata, extra);
+		break;
+	case  BT_EFUSE_FILE:
+		RTW_INFO("mp_get BT EFUSE_FILE\n");
+		rtw_bt_efuse_file_map(dev, info, wdata, extra);
+		break;
+	case  MP_SWRFPath:
+		RTW_INFO("mp_get MP_SWRFPath\n");
+		rtw_mp_switch_rf_path(dev, info, wrqu, extra);
+		break;
+	default:
+		return -EIO;
+	}
 
-	wrqu->data.length = strlen(extra) + 1;
-
-free_buf:
-	rtw_mfree(pbuf, len);
 	return 0;
 }
-#endif /* CONFIG_RTW_CUSTOMER_STR */
+#endif /*#if defined(CONFIG_MP_INCLUDED)*/
+
 
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
 #define DBG_MP_SDIO_INDIRECT_ACCESS 1
 static int rtw_mp_sd_iread(struct net_device *dev
-	, struct iw_request_info *info
-	, struct iw_point *wrqu
-	, char *extra)
+			   , struct iw_request_info *info
+			   , struct iw_point *wrqu
+			   , char *extra)
 {
 	char input[16];
 	u8 width;
@@ -11149,13 +10183,13 @@ static int rtw_mp_sd_iread(struct net_device *dev
 	PADAPTER padapter = rtw_netdev_priv(dev);
 
 	if (wrqu->length > 16) {
-		DBG_871X(FUNC_ADPT_FMT" wrqu->length:%d\n", FUNC_ADPT_ARG(padapter), wrqu->length);
+		RTW_INFO(FUNC_ADPT_FMT" wrqu->length:%d\n", FUNC_ADPT_ARG(padapter), wrqu->length);
 		ret = -EINVAL;
 		goto exit;
 	}
 
 	if (copy_from_user(input, wrqu->pointer, wrqu->length)) {
-		DBG_871X(FUNC_ADPT_FMT" copy_from_user fail\n", FUNC_ADPT_ARG(padapter));
+		RTW_INFO(FUNC_ADPT_FMT" copy_from_user fail\n", FUNC_ADPT_ARG(padapter));
 		ret = -EFAULT;
 		goto exit;
 	}
@@ -11163,19 +10197,19 @@ static int rtw_mp_sd_iread(struct net_device *dev
 	_rtw_memset(extra, 0, wrqu->length);
 
 	if (sscanf(input, "%hhu,%lx", &width, &addr) != 2) {
-		DBG_871X(FUNC_ADPT_FMT" sscanf fail\n", FUNC_ADPT_ARG(padapter));
+		RTW_INFO(FUNC_ADPT_FMT" sscanf fail\n", FUNC_ADPT_ARG(padapter));
 		ret = -EINVAL;
 		goto exit;
 	}
 
 	if (addr > 0x3FFF) {
-		DBG_871X(FUNC_ADPT_FMT" addr:0x%lx\n", FUNC_ADPT_ARG(padapter), addr);
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%lx\n", FUNC_ADPT_ARG(padapter), addr);
 		ret = -EINVAL;
 		goto exit;
 	}
 
 	if (DBG_MP_SDIO_INDIRECT_ACCESS)
-		DBG_871X(FUNC_ADPT_FMT" width:%u, addr:0x%lx\n", FUNC_ADPT_ARG(padapter), width, addr);
+		RTW_INFO(FUNC_ADPT_FMT" width:%u, addr:0x%lx\n", FUNC_ADPT_ARG(padapter), width, addr);
 
 	switch (width) {
 	case 1:
@@ -11201,9 +10235,9 @@ exit:
 }
 
 static int rtw_mp_sd_iwrite(struct net_device *dev
-	, struct iw_request_info *info
-	, struct iw_point *wrqu
-	, char *extra)
+			    , struct iw_request_info *info
+			    , struct iw_point *wrqu
+			    , char *extra)
 {
 	char width;
 	unsigned long addr, data;
@@ -11212,33 +10246,33 @@ static int rtw_mp_sd_iwrite(struct net_device *dev
 	char input[32];
 
 	if (wrqu->length > 32) {
-		DBG_871X(FUNC_ADPT_FMT" wrqu->length:%d\n", FUNC_ADPT_ARG(padapter), wrqu->length);
+		RTW_INFO(FUNC_ADPT_FMT" wrqu->length:%d\n", FUNC_ADPT_ARG(padapter), wrqu->length);
 		ret = -EINVAL;
 		goto exit;
 	}
 
 	if (copy_from_user(input, wrqu->pointer, wrqu->length)) {
-		DBG_871X(FUNC_ADPT_FMT" copy_from_user fail\n", FUNC_ADPT_ARG(padapter));
+		RTW_INFO(FUNC_ADPT_FMT" copy_from_user fail\n", FUNC_ADPT_ARG(padapter));
 		ret = -EFAULT;
 		goto exit;
 	}
-				 
-	_rtw_memset(extra, 0, wrqu->length);	
+
+	_rtw_memset(extra, 0, wrqu->length);
 
 	if (sscanf(input, "%hhu,%lx,%lx", &width, &addr, &data) != 3) {
-		DBG_871X(FUNC_ADPT_FMT" sscanf fail\n", FUNC_ADPT_ARG(padapter));
+		RTW_INFO(FUNC_ADPT_FMT" sscanf fail\n", FUNC_ADPT_ARG(padapter));
 		ret = -EINVAL;
 		goto exit;
 	}
 
 	if (addr > 0x3FFF) {
-		DBG_871X(FUNC_ADPT_FMT" addr:0x%lx\n", FUNC_ADPT_ARG(padapter), addr);
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%lx\n", FUNC_ADPT_ARG(padapter), addr);
 		ret = -EINVAL;
 		goto exit;
 	}
 
 	if (DBG_MP_SDIO_INDIRECT_ACCESS)
-		DBG_871X(FUNC_ADPT_FMT" width:%u, addr:0x%lx, data:0x%lx\n", FUNC_ADPT_ARG(padapter), width, addr, data);
+		RTW_INFO(FUNC_ADPT_FMT" width:%u, addr:0x%lx, data:0x%lx\n", FUNC_ADPT_ARG(padapter), width, addr, data);
 
 	switch (width) {
 	case 1:
@@ -11269,7 +10303,7 @@ exit:
 }
 #endif /* CONFIG_SDIO_INDIRECT_ACCESS */
 
-static int rtw_mp_set(struct net_device *dev,
+static int rtw_priv_set(struct net_device *dev,
 			struct iw_request_info *info,
 			union iwreq_data *wdata, char *extra)
 {
@@ -11278,96 +10312,63 @@ static int rtw_mp_set(struct net_device *dev,
 	PADAPTER padapter = rtw_netdev_priv(dev);
 
 	if (padapter == NULL)
-	{
 		return -ENETDOWN;
-	}
 
-	if((padapter->bup == _FALSE ))
-	{
-		DBG_871X(" %s fail =>(padapter->bup == _FALSE )\n",__FUNCTION__);
+	if (padapter->bup == _FALSE) {
+		RTW_INFO(" %s fail =>(padapter->bup == _FALSE )\n", __FUNCTION__);
 		return -ENETDOWN;
 	}
 
 	if (RTW_CANNOT_RUN(padapter)) {
-		DBG_871X("%s fail =>(bSurpriseRemoved == _TRUE) || ( bDriverStopped == _TRUE)\n", __func__);
+		RTW_INFO("%s fail =>(bSurpriseRemoved == _TRUE) || ( bDriverStopped == _TRUE)\n", __func__);
 		return -ENETDOWN;
-       }
-
-	
-	//_rtw_memset(extra, 0x00, IW_PRIV_SIZE_MASK);
+	}
 
-	if (extra == NULL)
-	{
+	if (extra == NULL) {
 		wrqu->length = 0;
 		return -EIO;
 	}
 
-	switch(subcmd)
-	{
-	case MP_START:
-			DBG_871X("set case mp_start \n");
-			rtw_mp_start (dev,info,wrqu,extra);
-			 break; 
-			 
-	case MP_STOP:
-			DBG_871X("set case mp_stop \n");
-			rtw_mp_stop (dev,info,wrqu,extra);
-			 break; 
-			 
-	case MP_BANDWIDTH:
-			DBG_871X("set case mp_bandwidth \n");
-			rtw_mp_bandwidth (dev,info,wrqu,extra);
-			break;
-				
-	case MP_RESET_STATS:
-			DBG_871X("set case MP_RESET_STATS \n");
-			rtw_mp_reset_stats	(dev,info,wrqu,extra);
-			break;
-	case MP_SetRFPathSwh:		
-			DBG_871X("set MP_SetRFPathSwitch \n");
-			rtw_mp_SetRFPath  (dev,info,wdata,extra);
-			break;
-	case CTA_TEST:
-			DBG_871X("set CTA_TEST\n");
-			rtw_cta_test_start (dev, info, wdata, extra);
-			break;
-	case MP_DISABLE_BT_COEXIST:
-			DBG_871X("set case MP_DISABLE_BT_COEXIST \n");
-			rtw_mp_disable_bt_coexist(dev, info, wdata, extra);
-		break;
+	if (subcmd < MP_NULL) {
+#ifdef CONFIG_MP_INCLUDED
+		rtw_priv_mp_set(dev, info, wdata, extra);
+#endif
+		return 0;
+	}
+
+	switch (subcmd) {
 #ifdef CONFIG_WOWLAN
 	case MP_WOW_ENABLE:
-			DBG_871X("set case MP_WOW_ENABLE: %s\n", extra);
-			
-			rtw_wowlan_ctrl(dev, info, wdata, extra);
-	break;
+		RTW_INFO("set case MP_WOW_ENABLE: %s\n", extra);
+
+		rtw_wowlan_ctrl(dev, info, wdata, extra);
+		break;
 	case MP_WOW_SET_PATTERN:
-			DBG_871X("set case MP_WOW_SET_PATTERN: %s\n", extra);
-			rtw_wowlan_set_pattern(dev, info, wdata, extra);
-	break;
+		RTW_INFO("set case MP_WOW_SET_PATTERN: %s\n", extra);
+		rtw_wowlan_set_pattern(dev, info, wdata, extra);
+		break;
 #endif
 #ifdef CONFIG_AP_WOWLAN
 	case MP_AP_WOW_ENABLE:
-			DBG_871X("set case MP_AP_WOW_ENABLE: %s\n", extra);
-			rtw_ap_wowlan_ctrl(dev, info, wdata, extra);
-	break;
-#endif
-	case MP_IQK:
-		DBG_871X("set MP_IQK\n");
-		rtw_mp_iqk(dev, info, wrqu, extra);
+		RTW_INFO("set case MP_AP_WOW_ENABLE: %s\n", extra);
+		rtw_ap_wowlan_ctrl(dev, info, wdata, extra);
 		break;
-	case MP_LCK:
-		DBG_871X("set MP_LCK\n");
-		rtw_mp_lck(dev, info, wrqu, extra);
+#endif
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	case VENDOR_IE_SET:
+		RTW_INFO("set case VENDOR_IE_SET\n");
+		rtw_vendor_ie_set(dev , info , wdata , extra);
 		break;
+#endif
+	default:
+		return -EIO;
 	}
 
-	  
-	return 0;		
+	return 0;
 }
 
 
-static int rtw_mp_get(struct net_device *dev,
+static int rtw_priv_get(struct net_device *dev,
 			struct iw_request_info *info,
 			union iwreq_data *wdata, char *extra)
 {
@@ -11375,156 +10376,38 @@ static int rtw_mp_get(struct net_device *dev,
 	u32 subcmd = wrqu->flags;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 
-	//DBG_871X("in mp_get extra= %s \n",extra);
 
 	if (padapter == NULL)
-	{
 		return -ENETDOWN;
-	}
-	if((padapter->bup == _FALSE ))
-	{
-		DBG_871X(" %s fail =>(padapter->bup == _FALSE )\n",__FUNCTION__);
+
+	if (padapter->bup == _FALSE) {
+		RTW_INFO(" %s fail =>(padapter->bup == _FALSE )\n", __FUNCTION__);
 		return -ENETDOWN;
 	}
 
 	if (RTW_CANNOT_RUN(padapter)) {
-		DBG_871X("%s fail =>(padapter->bSurpriseRemoved == _TRUE) || ( padapter->bDriverStopped == _TRUE)\n", __func__);
+		RTW_INFO("%s fail =>(padapter->bSurpriseRemoved == _TRUE) || ( padapter->bDriverStopped == _TRUE)\n", __func__);
 		return -ENETDOWN;
-       }
-	
+	}
+
 	if (extra == NULL) {
 		wrqu->length = 0;
 		return -EIO;
 	}
-	
-	switch (subcmd) {
-	case WRITE_REG:
-			rtw_mp_write_reg(dev, info, wrqu, extra);
-			 break;
-			 
-	case WRITE_RF:
-			rtw_mp_write_rf(dev, info, wrqu, extra);
-			 break; 
-			 
-	case MP_PHYPARA:
-			DBG_871X("mp_get  MP_PHYPARA\n");
-			rtw_mp_phypara(dev, info, wrqu, extra);
-			break;
 
-	case MP_CHANNEL:
-			DBG_871X("set case mp_channel\n");
-			rtw_mp_channel(dev , info, wrqu, extra);
-			break;
-			
-	case READ_REG:
-			DBG_871X("mp_get  READ_REG\n");
-			rtw_mp_read_reg(dev, info, wrqu, extra);
-			 break; 
-	case READ_RF:
-			DBG_871X("mp_get  READ_RF\n");
-			rtw_mp_read_rf(dev, info, wrqu, extra);
-			break; 
-			
-	case MP_RATE:
-			DBG_871X("set case mp_rate\n");
-			rtw_mp_rate(dev, info, wrqu, extra);
-			break;
-			
-	case MP_TXPOWER:
-			DBG_871X("set case MP_TXPOWER\n");
-			rtw_mp_txpower(dev, info, wrqu, extra);
-			break;
-			
-	case MP_ANT_TX:
-			DBG_871X("set case MP_ANT_TX\n");
-			rtw_mp_ant_tx(dev, info, wrqu, extra);
-			break;
-			
-	case MP_ANT_RX:
-			DBG_871X("set case MP_ANT_RX\n");
-			rtw_mp_ant_rx(dev, info, wrqu, extra);
-			break;
-			
-	case MP_QUERY:
-			rtw_mp_trx_query(dev, info, wrqu, extra);
-			break;
-					
-	case MP_CTX:
-			DBG_871X("set case MP_CTX\n");
-			rtw_mp_ctx(dev, info, wrqu, extra);
-			break;
-					
-	case MP_ARX:
-			DBG_871X("set case MP_ARX\n");
-			rtw_mp_arx(dev, info, wrqu, extra);
-			break;
-			
-	case EFUSE_GET:
-			DBG_871X("efuse get EFUSE_GET\n");
-			rtw_mp_efuse_get(dev, info, wdata, extra);
-		 break; 
-		 
-	case MP_DUMP:
-			DBG_871X("set case MP_DUMP\n");
-			rtw_mp_dump(dev, info, wrqu, extra);
-		 break; 
-	case MP_PSD:
-			DBG_871X("set case MP_PSD\n");
-			rtw_mp_psd(dev, info, wrqu, extra);
-		 break;
-	case MP_THER:
-			DBG_871X("set case MP_THER\n");
-			rtw_mp_thermal(dev, info, wrqu, extra);
-		break;
-	case MP_PwrCtlDM:
-			DBG_871X("set MP_PwrCtlDM\n");
-			rtw_mp_PwrCtlDM(dev, info, wrqu, extra);
-		break;
-	case MP_QueryDrvStats:		
-			DBG_871X("mp_get MP_QueryDrvStats\n");
-			rtw_mp_QueryDrv(dev, info, wdata, extra);
-			break;
-	case MP_PWRTRK:
-			DBG_871X("set case MP_PWRTRK\n");
-			rtw_mp_pwrtrk(dev, info, wrqu, extra);
-			break;			 
-	case EFUSE_SET:
-			DBG_871X("set case efuse set\n");
-			rtw_mp_efuse_set(dev, info, wdata, extra);
-			break;			 
-	case MP_GET_TXPOWER_INX:
-			DBG_871X("mp_get MP_GET_TXPOWER_INX\n");
-			rtw_mp_txpower_index(dev, info, wrqu, extra);
-			break;
-	case MP_GETVER:
-			DBG_871X("mp_get MP_GETVER\n");
-			rtw_mp_getver(dev, info, wdata, extra);
-			break;
-	case MP_MON:
-			DBG_871X("mp_get MP_MON\n");
-			rtw_mp_mon(dev, info, wdata, extra);
-			break;
-	case EFUSE_MASK:
-			DBG_871X("mp_get EFUSE_MASK\n");
-			rtw_efuse_mask_file(dev, info, wdata, extra);
-			break;
-	case  EFUSE_FILE:
-			DBG_871X("mp_get EFUSE_FILE\n");
-			rtw_efuse_file_map(dev, info, wdata, extra);
-			break;
-	case  MP_TX:
-			DBG_871X("mp_get MP_TX\n");
-			rtw_mp_tx(dev, info, wdata, extra);
-			break;
-	case  MP_RX:
-			DBG_871X("mp_get MP_RX\n");
-			rtw_mp_rx(dev, info, wdata, extra);
-			break;
+	if (subcmd < MP_NULL) {
+#ifdef CONFIG_MP_INCLUDED
+		rtw_priv_mp_get(dev, info, wdata, extra);
+#endif
+		return 0;
+	}
+
+	switch (subcmd) {
 #if defined(CONFIG_RTL8723B)
-	case MP_SetBT:		
-			DBG_871X("set MP_SetBT\n");
-			rtw_mp_SetBT(dev, info, wdata, extra);
-			break;		 
+	case MP_SetBT:
+		RTW_INFO("set MP_SetBT\n");
+		rtw_mp_SetBT(dev, info, wdata, extra);
+		break;
 #endif
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
 	case MP_SD_IREAD:
@@ -11534,23 +10417,25 @@ static int rtw_mp_get(struct net_device *dev,
 		rtw_mp_sd_iwrite(dev, info, wrqu, extra);
 		break;
 #endif
-#ifdef CONFIG_RTW_CUSTOMER_STR
-	case MP_CUSTOMER_STR:
-		RTW_INFO("customer str\n");
-		rtw_mp_customer_str(dev, info, wdata, extra);
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	case VENDOR_IE_GET:
+		RTW_INFO("get case VENDOR_IE_GET\n");
+		rtw_vendor_ie_get(dev , info , wdata , extra);
 		break;
 #endif
+	default:
+		return -EIO;
 	}
 
-	rtw_msleep_os(10); //delay 5ms for sending pkt before exit adb shell operation
-return 0;	
+	rtw_msleep_os(10); /* delay 5ms for sending pkt before exit adb shell operation */
+	return 0;
 }
 
-#endif /*#if defined(CONFIG_MP_INCLUDED)*/
+
 
 static int rtw_wx_tdls_wfd_enable(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
@@ -11559,22 +10444,22 @@ static int rtw_wx_tdls_wfd_enable(struct net_device *dev,
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
-	if ( extra[ 0 ] == '0' )
+	if (extra[0] == '0')
 		rtw_tdls_wfd_enable(padapter, 0);
 	else
 		rtw_tdls_wfd_enable(padapter, 1);
 
 #endif /* CONFIG_WFD */
 #endif /* CONFIG_TDLS */
-	
+
 	return ret;
 }
 
 static int rtw_tdls_weaksec(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
@@ -11583,87 +10468,42 @@ static int rtw_tdls_weaksec(struct net_device *dev,
 	u8 i, j;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
-	if ( extra[ 0 ] == '0' )
+	if (extra[0] == '0')
 		padapter->wdinfo.wfd_tdls_weaksec = 0;
 	else
 		padapter->wdinfo.wfd_tdls_weaksec = 1;
 
 #endif /* CONFIG_TDLS */
-	
+
 	return ret;
 }
 
 
 static int rtw_tdls_enable(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct tdls_info	*ptdlsinfo = &padapter->tdlsinfo;
-	_irqL	 irqL;
-	_list	*plist, *phead;
-	s32	index;
-	struct sta_info *psta = NULL;
-	struct	sta_priv *pstapriv = &padapter->stapriv;
-	u8 tdls_sta[NUM_STA][ETH_ALEN];
-	u8 empty_hwaddr[ETH_ALEN] = { 0x00 };
-	struct tdls_txmgmt txmgmt;
-
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
-
-	_rtw_memset(tdls_sta, 0x00, sizeof(tdls_sta));
-	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-
-	if (extra[ 0 ] == '0') {
-		ptdlsinfo->tdls_enable = 0;
-
-		if(pstapriv->asoc_sta_count==1)
-			return ret;
 
-		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-		for (index=0; index< NUM_STA; index++) {
-			phead = &(pstapriv->sta_hash[index]);
-			plist = get_next(phead);
-			
-			while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
-				psta = LIST_CONTAINOR(plist, struct sta_info ,hash_list);
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
-				plist = get_next(plist);
-
-				if (psta->tdls_sta_state != TDLS_STATE_NONE) {
-					_rtw_memcpy(tdls_sta[index], psta->hwaddr, ETH_ALEN);
-				}
-			}
-		}
-		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
-
-		for (index=0; index< NUM_STA; index++) {
-			if (!_rtw_memcmp(tdls_sta[index], empty_hwaddr, ETH_ALEN)) {
-				DBG_871X("issue tear down to "MAC_FMT"\n", MAC_ARG(tdls_sta[index]));
-				txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
-				_rtw_memcpy(txmgmt.peer, tdls_sta[index], ETH_ALEN);
-				issue_tdls_teardown(padapter, &txmgmt, _TRUE);
-			}
-		}
-		rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
-		rtw_reset_tdls_info(padapter);
-	}	else if (extra[0] == '1') {
-		ptdlsinfo->tdls_enable = 1;
-	}
+	if (extra[0] == '0')
+		rtw_disable_tdls_func(padapter, _TRUE);
+	else if (extra[0] == '1')
+		rtw_enable_tdls_func(padapter);
 #endif /* CONFIG_TDLS */
-	
+
 	return ret;
 }
 
 static int rtw_tdls_setup(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 #ifdef CONFIG_TDLS
@@ -11671,100 +10511,96 @@ static int rtw_tdls_setup(struct net_device *dev,
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_txmgmt txmgmt;
 #ifdef CONFIG_WFD
-	struct wifidirect_info *pwdinfo= &(padapter->wdinfo);
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 #endif /* CONFIG_WFD */
 
-	DBG_871X("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1);
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
 	if (wrqu->data.length - 1 != 17) {
-		DBG_871X("[%s] length:%d != 17\n", __FUNCTION__, (wrqu->data.length -1));
+		RTW_INFO("[%s] length:%d != 17\n", __FUNCTION__, (wrqu->data.length - 1));
 		return ret;
 	}
 
 	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	for( i=0, j=0 ; i < ETH_ALEN; i++, j+=3 ){
-		txmgmt.peer[i]=key_2char2num(*(extra+j), *(extra+j+1));
-	}
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		txmgmt.peer[i] = key_2char2num(*(extra + j), *(extra + j + 1));
 
 #ifdef CONFIG_WFD
 	if (_AES_ != padapter->securitypriv.dot11PrivacyAlgrthm) {
 		/* Weak Security situation with AP. */
-		if (0 == pwdinfo->wfd_tdls_weaksec) 	{
+		if (0 == pwdinfo->wfd_tdls_weaksec)	{
 			/* Can't send the tdls setup request out!! */
-			DBG_871X("[%s] Current link is not AES, "
+			RTW_INFO("[%s] Current link is not AES, "
 				"SKIP sending the tdls setup request!!\n", __FUNCTION__);
-		} else {
+		} else
 			issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
-		}
 	} else
 #endif /* CONFIG_WFD */
 	{
 		issue_tdls_setup_req(padapter, &txmgmt, _TRUE);
 	}
 #endif /* CONFIG_TDLS */
-	
+
 	return ret;
 }
 
 static int rtw_tdls_teardown(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			     struct iw_request_info *info,
+			     union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
 
-	u8 i,j;
+	u8 i, j;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct sta_info *ptdls_sta = NULL;
 	struct tdls_txmgmt txmgmt;
 
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
 	if (wrqu->data.length - 1 != 17 && wrqu->data.length - 1 != 19) {
-		DBG_871X("[%s] length:%d != 17 or 19\n",
-			__FUNCTION__, (wrqu->data.length -1));
+		RTW_INFO("[%s] length:%d != 17 or 19\n",
+			 __FUNCTION__, (wrqu->data.length - 1));
 		return ret;
 	}
 
 	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	for (i=0, j=0; i < ETH_ALEN; i++, j+=3)
-		txmgmt.peer[i]=key_2char2num(*(extra+j), *(extra+j+1));
+	for (i = 0, j = 0; i < ETH_ALEN; i++, j += 3)
+		txmgmt.peer[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+
+	ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), txmgmt.peer);
 
-	ptdls_sta = rtw_get_stainfo( &(padapter->stapriv), txmgmt.peer);
-	
 	if (ptdls_sta != NULL) {
 		txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
 		if (wrqu->data.length - 1 == 19)
 			issue_tdls_teardown(padapter, &txmgmt, _FALSE);
-		else 
+		else
 			issue_tdls_teardown(padapter, &txmgmt, _TRUE);
-	} else {
-		DBG_871X( "TDLS peer not found\n");
-	}
+	} else
+		RTW_INFO("TDLS peer not found\n");
 #endif /* CONFIG_TDLS */
-	
+
 	return ret;
 }
 
 static int rtw_tdls_discovery(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-	
+
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_txmgmt	txmgmt;
-	int i = 0, j=0;
+	int i = 0, j = 0;
 
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
 	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	for( i=0, j=0 ; i < ETH_ALEN; i++, j+=3 ){
-		txmgmt.peer[i]=key_2char2num(*(extra+j), *(extra+j+1));
-	}
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		txmgmt.peer[i] = key_2char2num(*(extra + j), *(extra + j + 1));
 
 	issue_tdls_dis_req(padapter, &txmgmt);
 
@@ -11774,32 +10610,31 @@ static int rtw_tdls_discovery(struct net_device *dev,
 }
 
 static int rtw_tdls_ch_switch(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-#ifdef CONFIG_TDLS_CH_SW	
+#ifdef CONFIG_TDLS_CH_SW
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
 	u8 i, j;
 	struct sta_info *ptdls_sta = NULL;
+	u8 take_care_iqk;
 
-	DBG_8192C( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
-	if (padapter->tdlsinfo.ch_switch_prohibited == _TRUE)
-	{
-		DBG_871X("Can't do TDLS channel switch since ch_switch_prohibited = _TRUE\n");
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("TDLS channel switch is not allowed\n");
 		return ret;
 	}
 
-	for( i=0, j=0 ; i < ETH_ALEN; i++, j+=3 ){
-		pchsw_info->addr[i] = key_2char2num(*(extra+j), *(extra+j+1));
-	}
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		pchsw_info->addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
 
 	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pchsw_info->addr);
-	if( ptdls_sta == NULL )
+	if (ptdls_sta == NULL)
 		return ret;
 
 	pchsw_info->ch_sw_state |= TDLS_CH_SW_INITIATOR_STATE;
@@ -11807,13 +10642,27 @@ static int rtw_tdls_ch_switch(struct net_device *dev,
 	if (ptdls_sta != NULL) {
 		if (pchsw_info->off_ch_num == 0)
 			pchsw_info->off_ch_num = 11;
-	}else {
-		DBG_871X( "TDLS peer not found\n");
-	}
+	} else
+		RTW_INFO("TDLS peer not found\n");
+
+	rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
 
-	
-	//issue_tdls_ch_switch_req(padapter, ptdls_sta);
-	/* DBG_871X("issue tdls ch switch req\n"); */
+	rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
+	if (take_care_iqk == _TRUE) {
+		u8 central_chnl;
+		u8 bw_mode;
+
+		bw_mode = (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20;
+		central_chnl = rtw_get_center_ch(pchsw_info->off_ch_num, bw_mode, pchsw_info->ch_offset);
+		if (rtw_hal_ch_sw_iqk_info_search(padapter, central_chnl, bw_mode) >= 0)
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
+		else
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_PREPARE);
+	} else
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
+
+	/* issue_tdls_ch_switch_req(padapter, ptdls_sta); */
+	/* RTW_INFO("issue tdls ch switch req\n"); */
 
 #endif /* CONFIG_TDLS_CH_SW */
 #endif /* CONFIG_TDLS */
@@ -11822,14 +10671,14 @@ static int rtw_tdls_ch_switch(struct net_device *dev,
 }
 
 static int rtw_tdls_ch_switch_off(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+				  struct iw_request_info *info,
+				  union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-#ifdef CONFIG_TDLS_CH_SW	
-	
+#ifdef CONFIG_TDLS_CH_SW
+
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
 	u8 i, j, mac_addr[ETH_ALEN];
@@ -11837,38 +10686,38 @@ static int rtw_tdls_ch_switch_off(struct net_device *dev,
 	struct tdls_txmgmt txmgmt;
 
 	_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
-	
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
 
-	if (padapter->tdlsinfo.ch_switch_prohibited == _TRUE)
-	{
-		DBG_871X("Can't do TDLS channel switch since ch_switch_prohibited = _TRUE\n");
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
+		RTW_INFO("TDLS channel switch is not allowed\n");
 		return ret;
 	}
 
 	if (wrqu->data.length >= 17) {
-		for (i=0, j=0 ; i < ETH_ALEN; i++, j+=3)
-		mac_addr[i]=key_2char2num(*(extra+j), *(extra+j+1));
-			ptdls_sta = rtw_get_stainfo(&padapter->stapriv, mac_addr);
+		for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+			mac_addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
+		ptdls_sta = rtw_get_stainfo(&padapter->stapriv, mac_addr);
 	}
 
-	if (padapter->mlmeextpriv.cur_channel != rtw_get_oper_ch(padapter)) {	
-		SelectChannel(padapter, padapter->mlmeextpriv.cur_channel);
-	}
+	if (ptdls_sta == NULL)
+		return ret;
+
+	rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END_TO_BASE_CHNL);
 
 	pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE |
-								TDLS_CH_SWITCH_ON_STATE |
-								TDLS_PEER_AT_OFF_STATE);
-	ATOMIC_SET(&pchsw_info->chsw_on, _FALSE);
+				     TDLS_CH_SWITCH_ON_STATE |
+				     TDLS_PEER_AT_OFF_STATE);
 	_rtw_memset(pchsw_info->addr, 0x00, ETH_ALEN);
 
-	if (ptdls_sta != NULL) {
-		ptdls_sta->ch_switch_time = 0;
-		ptdls_sta->ch_switch_timeout = 0;
-		_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
-		_cancel_timer_ex(&ptdls_sta->delay_timer);
-	}
+	ptdls_sta->ch_switch_time = 0;
+	ptdls_sta->ch_switch_timeout = 0;
+	_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
+	_cancel_timer_ex(&ptdls_sta->delay_timer);
+	_cancel_timer_ex(&ptdls_sta->stay_on_base_chnl_timer);
+	_cancel_timer_ex(&ptdls_sta->ch_sw_monitor_timer);
 
+	rtw_pm_set_lps(padapter, PS_MODE_MAX);
 #endif /* CONFIG_TDLS_CH_SW */
 #endif /* CONFIG_TDLS */
 
@@ -11876,20 +10725,20 @@ static int rtw_tdls_ch_switch_off(struct net_device *dev,
 }
 
 static int rtw_tdls_dump_ch(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-#ifdef CONFIG_TDLS_CH_SW	
+#ifdef CONFIG_TDLS_CH_SW
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 
-	DBG_8192C("[%s] dump_stack:%s\n", __FUNCTION__, extra);
+	RTW_INFO("[%s] dump_stack:%s\n", __FUNCTION__, extra);
 
-	extra[ wrqu->data.length ] = 0x00;
-	ptdlsinfo->chsw_info.dump_stack = rtw_atoi( extra );
+	extra[wrqu->data.length] = 0x00;
+	ptdlsinfo->chsw_info.dump_stack = rtw_atoi(extra);
 
 	return ret;
 
@@ -11900,23 +10749,23 @@ static int rtw_tdls_dump_ch(struct net_device *dev,
 }
 
 static int rtw_tdls_off_ch_num(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-#ifdef CONFIG_TDLS_CH_SW	
+#ifdef CONFIG_TDLS_CH_SW
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 
-	DBG_8192C("[%s] off_ch_num:%s\n", __FUNCTION__, extra);
+	RTW_INFO("[%s] off_ch_num:%s\n", __FUNCTION__, extra);
 
-	extra[ wrqu->data.length ] = 0x00;
+	extra[wrqu->data.length] = 0x00;
 	ptdlsinfo->chsw_info.off_ch_num = rtw_atoi(extra);
 
 	return ret;
-	
+
 #endif
 #endif /* CONFIG_TDLS */
 
@@ -11924,76 +10773,88 @@ static int rtw_tdls_off_ch_num(struct net_device *dev,
 }
 
 static int rtw_tdls_ch_offset(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-#ifdef CONFIG_TDLS_CH_SW	
+#ifdef CONFIG_TDLS_CH_SW
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 
-	DBG_8192C("[%s] ch_offset:%s\n", __FUNCTION__, extra);
+	RTW_INFO("[%s] ch_offset:%s\n", __FUNCTION__, extra);
+
+	extra[wrqu->data.length] = 0x00;
+	switch (rtw_atoi(extra)) {
+	case SCA:
+		ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+		break;
+
+	case SCB:
+		ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+		break;
 
-	extra[ wrqu->data.length ] = 0x00;
-	ptdlsinfo->chsw_info.ch_offset = rtw_atoi( extra );
+	default:
+		ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		break;
+	}
 
 	return ret;
 
 #endif
 #endif /* CONFIG_TDLS */
 
-		return ret;
+	return ret;
 }
-	
+
 static int rtw_tdls_pson(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			 struct iw_request_info *info,
+			 union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-	
+
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 i, j, mac_addr[ETH_ALEN];
 	struct sta_info *ptdls_sta = NULL;
 
-	DBG_871X( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
-	for (i=0, j=0; i < ETH_ALEN; i++, j+=3)
-		mac_addr[i]=key_2char2num(*(extra+j), *(extra+j+1));
+	for (i = 0, j = 0; i < ETH_ALEN; i++, j += 3)
+		mac_addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
 
 	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, mac_addr);
 
-	issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->hwaddr, 1, 3, 500);
+	issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 1, 3, 500);
 
 #endif /* CONFIG_TDLS */
 
-		return ret;
+	return ret;
 }
-	
+
 static int rtw_tdls_psoff(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
-	
+
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 i, j, mac_addr[ETH_ALEN];
 	struct sta_info *ptdls_sta = NULL;
-	
-	DBG_8192C( "[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length -1  );
 
-	for (i=0, j=0; i < ETH_ALEN; i++, j+=3)
-		mac_addr[i]=key_2char2num(*(extra+j), *(extra+j+1));
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+
+	for (i = 0, j = 0; i < ETH_ALEN; i++, j += 3)
+		mac_addr[i] = key_2char2num(*(extra + j), *(extra + j + 1));
 
 	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, mac_addr);
 
-	if(ptdls_sta)
-		issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->hwaddr, 0, 3, 500);
+	if (ptdls_sta)
+		issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 0, 3, 500);
 
 #endif /* CONFIG_TDLS */
 
@@ -12001,30 +10862,30 @@ static int rtw_tdls_psoff(struct net_device *dev,
 }
 
 static int rtw_tdls_setip(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_WFD
-	
+
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 	struct wifi_display_info *pwfd_info = ptdlsinfo->wfd_info;
-	u8 i=0, j=0, k=0, tag=0;
+	u8 i = 0, j = 0, k = 0, tag = 0;
 
-	DBG_871X("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
 	while (i < 4) {
-		for (j=0; j < 4; j++) {
-			if (*( extra + j + tag ) == '.' || *( extra + j + tag ) == '\0') {
-				if( j == 1 )
-					pwfd_info->ip_address[i]=convert_ip_addr( '0', '0', *(extra+(j-1)+tag));
-				if( j == 2 )
-					pwfd_info->ip_address[i]=convert_ip_addr( '0', *(extra+(j-2)+tag), *(extra+(j-1)+tag));
-				if( j == 3 )
-					pwfd_info->ip_address[i]=convert_ip_addr( *(extra+(j-3)+tag), *(extra+(j-2)+tag), *(extra+(j-1)+tag));	
+		for (j = 0; j < 4; j++) {
+			if (*(extra + j + tag) == '.' || *(extra + j + tag) == '\0') {
+				if (j == 1)
+					pwfd_info->ip_address[i] = convert_ip_addr('0', '0', *(extra + (j - 1) + tag));
+				if (j == 2)
+					pwfd_info->ip_address[i] = convert_ip_addr('0', *(extra + (j - 2) + tag), *(extra + (j - 1) + tag));
+				if (j == 3)
+					pwfd_info->ip_address[i] = convert_ip_addr(*(extra + (j - 3) + tag), *(extra + (j - 2) + tag), *(extra + (j - 1) + tag));
 
 				tag += j + 1;
 				break;
@@ -12033,11 +10894,11 @@ static int rtw_tdls_setip(struct net_device *dev,
 		i++;
 	}
 
-	DBG_871X( "[%s] Set IP = %u.%u.%u.%u \n", __FUNCTION__, 
-		ptdlsinfo->wfd_info->ip_address[0],
-		ptdlsinfo->wfd_info->ip_address[1],
-		ptdlsinfo->wfd_info->ip_address[2],
-		ptdlsinfo->wfd_info->ip_address[3]);
+	RTW_INFO("[%s] Set IP = %u.%u.%u.%u\n", __FUNCTION__,
+		 ptdlsinfo->wfd_info->ip_address[0],
+		 ptdlsinfo->wfd_info->ip_address[1],
+		 ptdlsinfo->wfd_info->ip_address[2],
+		 ptdlsinfo->wfd_info->ip_address[3]);
 
 #endif /* CONFIG_WFD */
 #endif /* CONFIG_TDLS */
@@ -12046,29 +10907,29 @@ static int rtw_tdls_setip(struct net_device *dev,
 }
 
 static int rtw_tdls_getip(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			  struct iw_request_info *info,
+			  union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_WFD
-	
+
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 	struct wifi_display_info *pwfd_info = ptdlsinfo->wfd_info;
-	
-	DBG_871X( "[%s]\n", __FUNCTION__);
 
-	sprintf( extra, "\n\n%u.%u.%u.%u\n", 
-		pwfd_info->peer_ip_address[0], pwfd_info->peer_ip_address[1], 
-		pwfd_info->peer_ip_address[2], pwfd_info->peer_ip_address[3]);
+	RTW_INFO("[%s]\n", __FUNCTION__);
 
-	DBG_871X( "[%s] IP=%u.%u.%u.%u\n", __FUNCTION__,
-		pwfd_info->peer_ip_address[0], pwfd_info->peer_ip_address[1], 
+	sprintf(extra, "\n\n%u.%u.%u.%u\n",
+		pwfd_info->peer_ip_address[0], pwfd_info->peer_ip_address[1],
 		pwfd_info->peer_ip_address[2], pwfd_info->peer_ip_address[3]);
-	
-	wrqu->data.length = strlen( extra );
+
+	RTW_INFO("[%s] IP=%u.%u.%u.%u\n", __FUNCTION__,
+		 pwfd_info->peer_ip_address[0], pwfd_info->peer_ip_address[1],
+		 pwfd_info->peer_ip_address[2], pwfd_info->peer_ip_address[3]);
+
+	wrqu->data.length = strlen(extra);
 
 #endif /* CONFIG_WFD */
 #endif /* CONFIG_TDLS */
@@ -12077,11 +10938,11 @@ static int rtw_tdls_getip(struct net_device *dev,
 }
 
 static int rtw_tdls_getport(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			    struct iw_request_info *info,
+			    union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_WFD
@@ -12090,28 +10951,28 @@ static int rtw_tdls_getport(struct net_device *dev,
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 	struct wifi_display_info *pwfd_info = ptdlsinfo->wfd_info;
 
-	DBG_871X( "[%s]\n", __FUNCTION__);
+	RTW_INFO("[%s]\n", __FUNCTION__);
 
-	sprintf( extra, "\n\n%d\n", pwfd_info->peer_rtsp_ctrlport );
-	DBG_871X( "[%s] remote port = %d\n",
-		__FUNCTION__, pwfd_info->peer_rtsp_ctrlport );
-	
-	wrqu->data.length = strlen( extra );
+	sprintf(extra, "\n\n%d\n", pwfd_info->peer_rtsp_ctrlport);
+	RTW_INFO("[%s] remote port = %d\n",
+		 __FUNCTION__, pwfd_info->peer_rtsp_ctrlport);
+
+	wrqu->data.length = strlen(extra);
 
 #endif /* CONFIG_WFD */
 #endif /* CONFIG_TDLS */
 
 	return ret;
-		
+
 }
 
 /* WFDTDLS, for sigma test */
 static int rtw_tdls_dis_result(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_WFD
@@ -12119,41 +10980,41 @@ static int rtw_tdls_dis_result(struct net_device *dev,
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 
-	DBG_871X( "[%s]\n", __FUNCTION__);
+	RTW_INFO("[%s]\n", __FUNCTION__);
 
 	if (ptdlsinfo->dev_discovered == _TRUE) {
-		sprintf( extra, "\n\nDis=1\n" );
+		sprintf(extra, "\n\nDis=1\n");
 		ptdlsinfo->dev_discovered = _FALSE;
 	}
-	
-	wrqu->data.length = strlen( extra );
+
+	wrqu->data.length = strlen(extra);
 
 #endif /* CONFIG_WFD */
 #endif /* CONFIG_TDLS */
 
 	return ret;
-		
+
 }
 
 /* WFDTDLS, for sigma test */
 static int rtw_wfd_tdls_status(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			       struct iw_request_info *info,
+			       union iwreq_data *wrqu, char *extra)
 {
-	
-	int ret = 0;	
+
+	int ret = 0;
 
 #ifdef CONFIG_TDLS
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 
-	DBG_871X("[%s]\n", __FUNCTION__);
+	RTW_INFO("[%s]\n", __FUNCTION__);
 
-	sprintf( extra, "\nlink_established:%d \n"
-		"sta_cnt:%d \n"
-		"sta_maximum:%d \n"
-		"cur_channel:%d \n"
+	sprintf(extra, "\nlink_established:%d\n"
+		"sta_cnt:%d\n"
+		"sta_maximum:%d\n"
+		"cur_channel:%d\n"
 		"tdls_enable:%d"
 #ifdef CONFIG_TDLS_CH_SW
 		"ch_sw_state:%08x\n"
@@ -12165,10 +11026,10 @@ static int rtw_wfd_tdls_status(struct net_device *dev,
 #endif
 		,
 		ptdlsinfo->link_established, ptdlsinfo->sta_cnt,
-		ptdlsinfo->sta_maximum, ptdlsinfo->cur_channel, 
-		ptdlsinfo->tdls_enable
+		ptdlsinfo->sta_maximum, ptdlsinfo->cur_channel,
+		rtw_is_tdls_enabled(padapter)
 #ifdef CONFIG_TDLS_CH_SW
-,
+		,
 		ptdlsinfo->chsw_info.ch_sw_state,
 		ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on),
 		ptdlsinfo->chsw_info.off_ch_num,
@@ -12176,21 +11037,21 @@ static int rtw_wfd_tdls_status(struct net_device *dev,
 		ptdlsinfo->chsw_info.ch_offset,
 		ptdlsinfo->chsw_info.delay_switch_back
 #endif
-);
+	       );
 
-	wrqu->data.length = strlen( extra );
+	wrqu->data.length = strlen(extra);
 
 #endif /* CONFIG_TDLS */
 
 	return ret;
-		
-	}
+
+}
 
 static int rtw_tdls_getsta(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
-	{
-	
+			   struct iw_request_info *info,
+			   union iwreq_data *wrqu, char *extra)
+{
+
 	int ret = 0;
 #ifdef CONFIG_TDLS
 	u8 i, j;
@@ -12199,97 +11060,98 @@ static int rtw_tdls_getsta(struct net_device *dev,
 	char charmac[17];
 	struct sta_info *ptdls_sta = NULL;
 
-	DBG_871X("[%s] %s %d\n", __FUNCTION__,
-		(char *)wrqu->data.pointer, wrqu->data.length -1);
+	RTW_INFO("[%s] %s %d\n", __FUNCTION__,
+		 (char *)wrqu->data.pointer, wrqu->data.length - 1);
 
-	if(copy_from_user(charmac, wrqu->data.pointer+9, 17)){
+	if (copy_from_user(charmac, wrqu->data.pointer + 9, 17)) {
 		ret = -EFAULT;
 		goto exit;
 	}
-	
-	DBG_871X("[%s] %d, charmac:%s\n", __FUNCTION__, __LINE__, charmac);
-	for (i=0, j=0 ; i < ETH_ALEN; i++, j+=3)
-		addr[i]=key_2char2num(*(charmac+j), *(charmac+j+1));
 
-	DBG_871X("[%s] %d, charmac:%s, addr:"MAC_FMT"\n",
-		__FUNCTION__, __LINE__, charmac, MAC_ARG(addr));
-	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, addr);	
-	if(ptdls_sta) {
+	RTW_INFO("[%s] %d, charmac:%s\n", __FUNCTION__, __LINE__, charmac);
+	for (i = 0, j = 0 ; i < ETH_ALEN; i++, j += 3)
+		addr[i] = key_2char2num(*(charmac + j), *(charmac + j + 1));
+
+	RTW_INFO("[%s] %d, charmac:%s, addr:"MAC_FMT"\n",
+		 __FUNCTION__, __LINE__, charmac, MAC_ARG(addr));
+	ptdls_sta = rtw_get_stainfo(&padapter->stapriv, addr);
+	if (ptdls_sta) {
 		sprintf(extra, "\n\ntdls_sta_state=0x%08x\n", ptdls_sta->tdls_sta_state);
-		DBG_871X("\n\ntdls_sta_state=%d\n", ptdls_sta->tdls_sta_state);
+		RTW_INFO("\n\ntdls_sta_state=%d\n", ptdls_sta->tdls_sta_state);
 	} else {
 		sprintf(extra, "\n\nNot found this sta\n");
-		DBG_871X("\n\nNot found this sta\n");
+		RTW_INFO("\n\nNot found this sta\n");
 	}
-	wrqu->data.length = strlen( extra );
+	wrqu->data.length = strlen(extra);
 
 #endif /* CONFIG_TDLS */
 exit:
 	return ret;
-		
+
 }
 
 static int rtw_tdls_get_best_ch(struct net_device *dev,
 				struct iw_request_info *info,
 				union iwreq_data *wrqu, char *extra)
 {
-#ifdef CONFIG_FIND_BEST_CHANNEL	
+#ifdef CONFIG_FIND_BEST_CHANNEL
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	u32 i, best_channel_24G = 1, best_channel_5G = 36, index_24G = 0, index_5G = 0;
 
-	for (i=0; pmlmeext->channel_set[i].ChannelNum !=0; i++) {
-		if (pmlmeext->channel_set[i].ChannelNum == 1)
+	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
+		if (rfctl->channel_set[i].ChannelNum == 1)
 			index_24G = i;
-		if (pmlmeext->channel_set[i].ChannelNum == 36)
+		if (rfctl->channel_set[i].ChannelNum == 36)
 			index_5G = i;
 	}
-	
-	for (i=0; pmlmeext->channel_set[i].ChannelNum !=0; i++) {
+
+	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
 		/* 2.4G */
-		if (pmlmeext->channel_set[i].ChannelNum == 6 || pmlmeext->channel_set[i].ChannelNum == 11) {
-			if (pmlmeext->channel_set[i].rx_count < pmlmeext->channel_set[index_24G].rx_count) {
+		if (rfctl->channel_set[i].ChannelNum == 6 || rfctl->channel_set[i].ChannelNum == 11) {
+			if (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_24G].rx_count) {
 				index_24G = i;
-				best_channel_24G = pmlmeext->channel_set[i].ChannelNum;
+				best_channel_24G = rfctl->channel_set[i].ChannelNum;
 			}
 		}
 
 		/* 5G */
-		if (pmlmeext->channel_set[i].ChannelNum >= 36
-			&& pmlmeext->channel_set[i].ChannelNum < 140) {
-			 /* Find primary channel */
-			if (((pmlmeext->channel_set[i].ChannelNum - 36) % 8 == 0)
-				&& (pmlmeext->channel_set[i].rx_count < pmlmeext->channel_set[index_5G].rx_count)) {
+		if (rfctl->channel_set[i].ChannelNum >= 36
+		    && rfctl->channel_set[i].ChannelNum < 140) {
+			/* Find primary channel */
+			if (((rfctl->channel_set[i].ChannelNum - 36) % 8 == 0)
+			    && (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
 				index_5G = i;
-				best_channel_5G = pmlmeext->channel_set[i].ChannelNum;
+				best_channel_5G = rfctl->channel_set[i].ChannelNum;
 			}
 		}
 
-		if (pmlmeext->channel_set[i].ChannelNum >= 149
-			&& pmlmeext->channel_set[i].ChannelNum < 165) {
-			 /* Find primary channel */
-			if (((pmlmeext->channel_set[i].ChannelNum - 149) % 8 == 0)
-				&& (pmlmeext->channel_set[i].rx_count < pmlmeext->channel_set[index_5G].rx_count)) {
+		if (rfctl->channel_set[i].ChannelNum >= 149
+		    && rfctl->channel_set[i].ChannelNum < 165) {
+			/* Find primary channel */
+			if (((rfctl->channel_set[i].ChannelNum - 149) % 8 == 0)
+			    && (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
 				index_5G = i;
-				best_channel_5G = pmlmeext->channel_set[i].ChannelNum;
+				best_channel_5G = rfctl->channel_set[i].ChannelNum;
 			}
 		}
 #if 1 /* debug */
-		DBG_871X("The rx cnt of channel %3d = %d\n", 
-					pmlmeext->channel_set[i].ChannelNum,
-					pmlmeext->channel_set[i].rx_count);
+		RTW_INFO("The rx cnt of channel %3d = %d\n",
+			 rfctl->channel_set[i].ChannelNum,
+			 rfctl->channel_set[i].rx_count);
 #endif
 	}
-	
-	sprintf( extra, "\nbest_channel_24G = %d\n", best_channel_24G );
-	DBG_871X("best_channel_24G = %d\n", best_channel_24G);
+
+	sprintf(extra, "\nbest_channel_24G = %d\n", best_channel_24G);
+	RTW_INFO("best_channel_24G = %d\n", best_channel_24G);
 
 	if (index_5G != 0) {
 		sprintf(extra, "best_channel_5G = %d\n", best_channel_5G);
-		DBG_871X("best_channel_5G = %d\n", best_channel_5G);
+		RTW_INFO("best_channel_5G = %d\n", best_channel_5G);
 	}
 
-	wrqu->data.length = strlen( extra );
+	wrqu->data.length = strlen(extra);
 
 #endif
 
@@ -12298,8 +11160,8 @@ static int rtw_tdls_get_best_ch(struct net_device *dev,
 }
 
 static int rtw_tdls(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+		    struct iw_request_info *info,
+		    union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
@@ -12307,15 +11169,15 @@ static int rtw_tdls(struct net_device *dev,
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	DBG_871X( "[%s] extra = %s\n", __FUNCTION__, extra );
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, extra);
 
 	if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
-		DBG_871X("Discard tdls oper since hal doesn't support tdls\n");
+		RTW_INFO("Discard tdls oper since hal doesn't support tdls\n");
 		return 0;
 	}
 
-	if (padapter->tdlsinfo.tdls_enable == 0) {
-		DBG_871X("tdls haven't enabled\n");
+	if (rtw_is_tdls_enabled(padapter) == _FALSE) {
+		RTW_INFO("TDLS is not enabled\n");
 		return 0;
 	}
 
@@ -12330,30 +11192,30 @@ static int rtw_tdls(struct net_device *dev,
 	}
 
 	if (_rtw_memcmp(extra, "weaksec=", 8)) {
-		wrqu->data.length -=8;
-		rtw_tdls_weaksec( dev, info, wrqu, &extra[8] );
+		wrqu->data.length -= 8;
+		rtw_tdls_weaksec(dev, info, wrqu, &extra[8]);
 		return ret;
-	} else if (_rtw_memcmp( extra, "tdlsenable=", 11)) {
-		wrqu->data.length -=11;
-		rtw_tdls_enable( dev, info, wrqu, &extra[11] );
+	} else if (_rtw_memcmp(extra, "tdlsenable=", 11)) {
+		wrqu->data.length -= 11;
+		rtw_tdls_enable(dev, info, wrqu, &extra[11]);
 		return ret;
 	}
 
 	if (_rtw_memcmp(extra, "setup=", 6)) {
-		wrqu->data.length -=6;
-		rtw_tdls_setup( dev, info, wrqu, &extra[6] );
+		wrqu->data.length -= 6;
+		rtw_tdls_setup(dev, info, wrqu, &extra[6]);
 	} else if (_rtw_memcmp(extra, "tear=", 5)) {
 		wrqu->data.length -= 5;
-		rtw_tdls_teardown( dev, info, wrqu, &extra[5] );
+		rtw_tdls_teardown(dev, info, wrqu, &extra[5]);
 	} else if (_rtw_memcmp(extra, "dis=", 4)) {
 		wrqu->data.length -= 4;
-		rtw_tdls_discovery( dev, info, wrqu, &extra[4] );
+		rtw_tdls_discovery(dev, info, wrqu, &extra[4]);
 	} else if (_rtw_memcmp(extra, "swoff=", 6)) {
 		wrqu->data.length -= 6;
 		rtw_tdls_ch_switch_off(dev, info, wrqu, &extra[6]);
 	} else if (_rtw_memcmp(extra, "sw=", 3)) {
 		wrqu->data.length -= 3;
-		rtw_tdls_ch_switch( dev, info, wrqu, &extra[3] );
+		rtw_tdls_ch_switch(dev, info, wrqu, &extra[3]);
 	} else if (_rtw_memcmp(extra, "dumpstack=", 10)) {
 		wrqu->data.length -= 10;
 		rtw_tdls_dump_ch(dev, info, wrqu, &extra[10]);
@@ -12365,10 +11227,10 @@ static int rtw_tdls(struct net_device *dev,
 		rtw_tdls_ch_offset(dev, info, wrqu, &extra[9]);
 	} else if (_rtw_memcmp(extra, "pson=", 5)) {
 		wrqu->data.length -= 5;
-		rtw_tdls_pson( dev, info, wrqu, &extra[5] );
+		rtw_tdls_pson(dev, info, wrqu, &extra[5]);
 	} else if (_rtw_memcmp(extra, "psoff=", 6)) {
 		wrqu->data.length -= 6;
-		rtw_tdls_psoff( dev, info, wrqu, &extra[6] );
+		rtw_tdls_psoff(dev, info, wrqu, &extra[6]);
 	}
 
 #ifdef CONFIG_WFD
@@ -12376,39 +11238,38 @@ static int rtw_tdls(struct net_device *dev,
 		if (_rtw_memcmp(extra, "setip=", 6)) {
 			wrqu->data.length -= 6;
 			rtw_tdls_setip(dev, info, wrqu, &extra[6]);
-		} else if (_rtw_memcmp(extra, "tprobe=", 6)) {
+		} else if (_rtw_memcmp(extra, "tprobe=", 6))
 			issue_tunneled_probe_req((_adapter *)rtw_netdev_priv(dev));
-		}
 	}
 #endif /* CONFIG_WFD */
 
 #endif /* CONFIG_TDLS */
-	
+
 	return ret;
 }
 
 
 static int rtw_tdls_get(struct net_device *dev,
-				struct iw_request_info *info,
-				union iwreq_data *wrqu, char *extra)
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 
 #ifdef CONFIG_TDLS
 
-	DBG_871X( "[%s] extra = %s\n", __FUNCTION__, (char*) wrqu->data.pointer );
+	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, (char *) wrqu->data.pointer);
 
-	if ( _rtw_memcmp( wrqu->data.pointer, "ip", 2 ) )
-		rtw_tdls_getip( dev, info, wrqu, extra );
+	if (_rtw_memcmp(wrqu->data.pointer, "ip", 2))
+		rtw_tdls_getip(dev, info, wrqu, extra);
 	else if (_rtw_memcmp(wrqu->data.pointer, "port", 4))
-		rtw_tdls_getport( dev, info, wrqu, extra );
+		rtw_tdls_getport(dev, info, wrqu, extra);
 	/* WFDTDLS, for sigma test */
-	else if ( _rtw_memcmp(wrqu->data.pointer, "dis", 3))
-		rtw_tdls_dis_result( dev, info, wrqu, extra );
-	else if ( _rtw_memcmp(wrqu->data.pointer, "status", 6))
-		rtw_wfd_tdls_status( dev, info, wrqu, extra );
-	else if ( _rtw_memcmp(wrqu->data.pointer, "tdls_sta=", 9))
-		rtw_tdls_getsta( dev, info, wrqu, extra );
+	else if (_rtw_memcmp(wrqu->data.pointer, "dis", 3))
+		rtw_tdls_dis_result(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "status", 6))
+		rtw_wfd_tdls_status(dev, info, wrqu, extra);
+	else if (_rtw_memcmp(wrqu->data.pointer, "tdls_sta=", 9))
+		rtw_tdls_getsta(dev, info, wrqu, extra);
 	else if (_rtw_memcmp(wrqu->data.pointer, "best_ch", 7))
 		rtw_tdls_get_best_ch(dev, info, wrqu, extra);
 #endif /* CONFIG_TDLS */
@@ -12422,8 +11283,8 @@ static int rtw_tdls_get(struct net_device *dev,
 
 #ifdef CONFIG_INTEL_WIDI
 static int rtw_widi_set(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
 {
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
@@ -12434,28 +11295,27 @@ static int rtw_widi_set(struct net_device *dev,
 }
 
 static int rtw_widi_set_probe_request(struct net_device *dev,
-                               struct iw_request_info *info,
-                               union iwreq_data *wrqu, char *extra)
+				      struct iw_request_info *info,
+				      union iwreq_data *wrqu, char *extra)
 {
 	int	ret = 0;
 	u8	*pbuf = NULL;
 	_adapter	*padapter = (_adapter *)rtw_netdev_priv(dev);
 
 	pbuf = rtw_malloc(sizeof(l2_msg_t));
-	if(pbuf)
-	{
-		if ( copy_from_user(pbuf, wrqu->data.pointer, wrqu->data.length) )
+	if (pbuf) {
+		if (copy_from_user(pbuf, wrqu->data.pointer, wrqu->data.length))
 			ret = -EFAULT;
-		//_rtw_memcpy(pbuf, wrqu->data.pointer, wrqu->data.length);
+		/* _rtw_memcpy(pbuf, wrqu->data.pointer, wrqu->data.length); */
 
-		if( wrqu->data.flags == 0 )
+		if (wrqu->data.flags == 0)
 			intel_widi_wk_cmd(padapter, INTEL_WIDI_ISSUE_PROB_WK, pbuf, sizeof(l2_msg_t));
-		else if( wrqu->data.flags == 1 )
-			rtw_set_wfd_rds_sink_info( padapter, (l2_msg_t *)pbuf );
+		else if (wrqu->data.flags == 1)
+			rtw_set_wfd_rds_sink_info(padapter, (l2_msg_t *)pbuf);
 	}
 	return ret;
 }
-#endif // CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
 #ifdef CONFIG_MAC_LOOPBACK_DRIVER
 
@@ -12466,14 +11326,14 @@ extern void rtl8188e_cal_txdesc_chksum(struct tx_desc *ptxdesc);
 #ifdef CONFIG_SDIO_HCI || defined(CONFIG_GSPI_HCI)
 extern void rtl8188es_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf);
 #define fill_default_txdesc rtl8188es_fill_default_txdesc
-#endif // CONFIG_SDIO_HCI
-#endif // CONFIG_RTL8188E
+#endif /* CONFIG_SDIO_HCI */
+#endif /* CONFIG_RTL8188E */
 #if defined(CONFIG_RTL8723B)
 extern void rtl8723b_cal_txdesc_chksum(struct tx_desc *ptxdesc);
 #define cal_txdesc_chksum rtl8723b_cal_txdesc_chksum
 extern void rtl8723b_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf);
 #define fill_default_txdesc rtl8723b_fill_default_txdesc
-#endif // CONFIG_RTL8723B
+#endif /* CONFIG_RTL8723B */
 
 #if defined(CONFIG_RTL8703B)
 /* extern void rtl8703b_cal_txdesc_chksum(struct tx_desc *ptxdesc); */
@@ -12482,14 +11342,21 @@ extern void rtl8723b_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf
 #define fill_default_txdesc rtl8703b_fill_default_txdesc
 #endif /* CONFIG_RTL8703B */
 
+#if defined(CONFIG_RTL8723D)
+/* extern void rtl8723d_cal_txdesc_chksum(struct tx_desc *ptxdesc); */
+#define cal_txdesc_chksum rtl8723d_cal_txdesc_chksum
+/* extern void rtl8723d_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf); */
+#define fill_default_txdesc rtl8723d_fill_default_txdesc
+#endif /* CONFIG_RTL8723D */
+
 #if defined(CONFIG_RTL8192E)
 extern void rtl8192e_cal_txdesc_chksum(struct tx_desc *ptxdesc);
 #define cal_txdesc_chksum rtl8192e_cal_txdesc_chksum
 #ifdef CONFIG_SDIO_HCI || defined(CONFIG_GSPI_HCI)
 extern void rtl8192es_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf);
 #define fill_default_txdesc rtl8192es_fill_default_txdesc
-#endif // CONFIG_SDIO_HCI
-#endif //CONFIG_RTL8192E
+#endif /* CONFIG_SDIO_HCI */
+#endif /* CONFIG_RTL8192E */
 
 static s32 initLoopback(PADAPTER padapter)
 {
@@ -12498,7 +11365,8 @@ static s32 initLoopback(PADAPTER padapter)
 
 	if (padapter->ploopback == NULL) {
 		ploopback = (PLOOPBACKDATA)rtw_zmalloc(sizeof(LOOPBACKDATA));
-		if (ploopback == NULL) return -ENOMEM;
+		if (ploopback == NULL)
+			return -ENOMEM;
 
 		_rtw_init_sema(&ploopback->sema, 0);
 		ploopback->bstop = _TRUE;
@@ -12519,7 +11387,7 @@ static void freeLoopback(PADAPTER padapter)
 
 	ploopback = padapter->ploopback;
 	if (ploopback) {
-		rtw_mfree((u8*)ploopback, sizeof(LOOPBACKDATA));
+		rtw_mfree((u8 *)ploopback, sizeof(LOOPBACKDATA));
 		padapter->ploopback = NULL;
 	}
 }
@@ -12531,10 +11399,12 @@ static s32 initpseudoadhoc(PADAPTER padapter)
 
 	networkType = Ndis802_11IBSS;
 	err = rtw_set_802_11_infrastructure_mode(padapter, networkType);
-	if (err == _FALSE) return _FAIL;
+	if (err == _FALSE)
+		return _FAIL;
 
-	err = rtw_setopmode_cmd(padapter, networkType,_TRUE);
-	if (err == _FAIL) return _FAIL;
+	err = rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
+	if (err == _FAIL)
+		return _FAIL;
 
 	return _SUCCESS;
 }
@@ -12555,7 +11425,8 @@ static s32 createpseudoadhoc(PADAPTER padapter)
 
 	authmode = Ndis802_11AuthModeOpen;
 	err = rtw_set_802_11_authentication_mode(padapter, authmode);
-	if (err == _FALSE) return _FAIL;
+	if (err == _FALSE)
+		return _FAIL;
 
 	passoc_ssid = &pmlmepriv->assoc_ssid;
 	_rtw_memset(passoc_ssid, 0, sizeof(NDIS_802_11_SSID));
@@ -12570,52 +11441,48 @@ static s32 createpseudoadhoc(PADAPTER padapter)
 	rtw_generate_random_ibss(pibss);
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
-	pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;
+	/*pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;*/
+	init_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
+
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
 #if 0
 	err = rtw_create_ibss_cmd(padapter, 0);
-	if (err == _FAIL) return _FAIL;
+	if (err == _FAIL)
+		return _FAIL;
 #else
-{
-	struct wlan_network *pcur_network;
-	struct sta_info *psta;
+	{
+		struct wlan_network *pcur_network;
+		struct sta_info *psta;
 
-	//3  create a new psta
-	pcur_network = &pmlmepriv->cur_network;
+		/* 3  create a new psta */
+		pcur_network = &pmlmepriv->cur_network;
 
-	//clear psta in the cur_network, if any
-	psta = rtw_get_stainfo(&padapter->stapriv, pcur_network->network.MacAddress);
-	if (psta) rtw_free_stainfo(padapter, psta);
+		/* clear psta in the cur_network, if any */
+		psta = rtw_get_stainfo(&padapter->stapriv, pcur_network->network.MacAddress);
+		if (psta)
+			rtw_free_stainfo(padapter, psta);
 
-	psta = rtw_alloc_stainfo(&padapter->stapriv, pibss);
-	if (psta == NULL) return _FAIL;
+		psta = rtw_alloc_stainfo(&padapter->stapriv, pibss);
+		if (psta == NULL)
+			return _FAIL;
 
-	//3  join psudo AdHoc
-	pcur_network->join_res = 1;
-	pcur_network->aid = psta->aid = 1;
-	_rtw_memcpy(&pcur_network->network, pdev_network, get_WLAN_BSSID_EX_sz(pdev_network));
+		/* 3  join psudo AdHoc */
+		pcur_network->join_res = 1;
+		pcur_network->aid = psta->cmn.aid = 1;
+		_rtw_memcpy(&pcur_network->network, pdev_network, get_WLAN_BSSID_EX_sz(pdev_network));
 
-	// set msr to WIFI_FW_ADHOC_STATE
-#if 0
-	Set_NETYPE0_MSR(padapter, WIFI_FW_ADHOC_STATE);
-#else
-	{
-		u8 val8;
+		/* set msr to WIFI_FW_ADHOC_STATE */
+		padapter->hw_port = HW_PORT0;
+		Set_MSR(padapter, WIFI_FW_ADHOC_STATE);
 
-		val8 = rtw_read8(padapter, MSR);
-		val8 &= 0xFC; // clear NETYPE0
-		val8 |= WIFI_FW_ADHOC_STATE & 0x3;
-		rtw_write8(padapter, MSR, val8);
 	}
-#endif
-}
 #endif
 
 	return _SUCCESS;
 }
 
-static struct xmit_frame* createloopbackpkt(PADAPTER padapter, u32 size)
+static struct xmit_frame *createloopbackpkt(PADAPTER padapter, u32 size)
 {
 	struct xmit_priv *pxmitpriv;
 	struct xmit_frame *pframe;
@@ -12628,17 +11495,19 @@ static struct xmit_frame* createloopbackpkt(PADAPTER padapter, u32 size)
 	_irqL irqL;
 
 
-	if ((TXDESC_SIZE + WLANHDR_OFFSET + size) > MAX_XMITBUF_SZ) return NULL;
+	if ((TXDESC_SIZE + WLANHDR_OFFSET + size) > MAX_XMITBUF_SZ)
+		return NULL;
 
 	pxmitpriv = &padapter->xmitpriv;
 	pframe = NULL;
 
-	//2 1. allocate xmit frame
+	/* 2 1. allocate xmit frame */
 	pframe = rtw_alloc_xmitframe(pxmitpriv);
-	if (pframe == NULL) return NULL;
+	if (pframe == NULL)
+		return NULL;
 	pframe->padapter = padapter;
 
-	//2 2. allocate xmit buffer
+	/* 2 2. allocate xmit buffer */
 	_enter_critical_bh(&pxmitpriv->lock, &irqL);
 	pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
 	_exit_critical_bh(&pxmitpriv->lock, &irqL);
@@ -12651,10 +11520,10 @@ static struct xmit_frame* createloopbackpkt(PADAPTER padapter, u32 size)
 	pframe->buf_addr = pxmitbuf->pbuf;
 	pxmitbuf->priv_data = pframe;
 
-	//2 3. update_attrib()
+	/* 2 3. update_attrib() */
 	pattrib = &pframe->attrib;
 
-	// init xmitframe attribute
+	/* init xmitframe attribute */
 	_rtw_memset(pattrib, 0, sizeof(struct pkt_attrib));
 
 	pattrib->ether_type = 0x8723;
@@ -12663,45 +11532,43 @@ static struct xmit_frame* createloopbackpkt(PADAPTER padapter, u32 size)
 	_rtw_memset(pattrib->dst, 0xFF, ETH_ALEN);
 	_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 
-//	pattrib->dhcp_pkt = 0;
-//	pattrib->pktlen = 0;
+	/*	pattrib->dhcp_pkt = 0;
+	 *	pattrib->pktlen = 0; */
 	pattrib->ack_policy = 0;
-//	pattrib->pkt_hdrlen = ETH_HLEN;
+	/*	pattrib->pkt_hdrlen = ETH_HLEN; */
 	pattrib->hdrlen = WLAN_HDR_A3_LEN;
 	pattrib->subtype = WIFI_DATA;
 	pattrib->priority = 0;
 	pattrib->qsel = pattrib->priority;
-//	do_queue_select(padapter, pattrib);
+	/*	do_queue_select(padapter, pattrib); */
 	pattrib->nr_frags = 1;
 	pattrib->encrypt = 0;
 	pattrib->bswenc = _FALSE;
 	pattrib->qos_en = _FALSE;
 
 	bmcast = IS_MCAST(pattrib->ra);
-	if (bmcast) {
-		pattrib->mac_id = 1;
+	if (bmcast)
 		pattrib->psta = rtw_get_bcmc_stainfo(padapter);
-	} else {
-		pattrib->mac_id = 0;
+	else
 		pattrib->psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
-	}
 
+	pattrib->mac_id = pattrib->psta->cmn.mac_id;
 	pattrib->pktlen = size;
 	pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->pktlen;
 
-	//2 4. fill TX descriptor
-	desc = (struct tx_desc*)pframe->buf_addr;
+	/* 2 4. fill TX descriptor */
+	desc = (struct tx_desc *)pframe->buf_addr;
 	_rtw_memset(desc, 0, TXDESC_SIZE);
 
-	fill_default_txdesc(pframe, (u8*)desc);
+	fill_default_txdesc(pframe, (u8 *)desc);
 
-	// Hw set sequence number
-	((PTXDESC)desc)->hwseq_en = 0; // HWSEQ_EN, 0:disable, 1:enable
-//	((PTXDESC)desc)->hwseq_sel = 0; // HWSEQ_SEL
+	/* Hw set sequence number */
+	((PTXDESC)desc)->hwseq_en = 0; /* HWSEQ_EN, 0:disable, 1:enable
+ * ((PTXDESC)desc)->hwseq_sel = 0;  */ /* HWSEQ_SEL */
 
 	((PTXDESC)desc)->disdatafb = 1;
 
-	// convert to little endian
+	/* convert to little endian */
 	desc->txdw0 = cpu_to_le32(desc->txdw0);
 	desc->txdw1 = cpu_to_le32(desc->txdw1);
 	desc->txdw2 = cpu_to_le32(desc->txdw2);
@@ -12723,18 +11590,18 @@ static struct xmit_frame* createloopbackpkt(PADAPTER padapter, u32 size)
 
 	cal_txdesc_chksum(desc);
 
-	//2 5. coalesce
+	/* 2 5. coalesce */
 	pkt_start = pframe->buf_addr + TXDESC_SIZE;
 	pkt_end = pkt_start + pattrib->last_txcmdsz;
 
-	//3 5.1. make wlan header, make_wlanhdr()
+	/* 3 5.1. make wlan header, make_wlanhdr() */
 	hdr = (struct rtw_ieee80211_hdr *)pkt_start;
-	SetFrameSubType(&hdr->frame_ctl, pattrib->subtype);
-	_rtw_memcpy(hdr->addr1, pattrib->dst, ETH_ALEN); // DA
-	_rtw_memcpy(hdr->addr2, pattrib->src, ETH_ALEN); // SA
-	_rtw_memcpy(hdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN); // RA, BSSID
+	set_frame_sub_type(&hdr->frame_ctl, pattrib->subtype);
+	_rtw_memcpy(hdr->addr1, pattrib->dst, ETH_ALEN); /* DA */
+	_rtw_memcpy(hdr->addr2, pattrib->src, ETH_ALEN); /* SA */
+	_rtw_memcpy(hdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN); /* RA, BSSID */
 
-	//3 5.2. make payload
+	/* 3 5.2. make payload */
 	ptr = pkt_start + pattrib->hdrlen;
 	get_random_bytes(ptr, pkt_end - ptr);
 
@@ -12762,18 +11629,19 @@ static void printdata(u8 *pbuf, u32 len)
 	u32 i, val;
 
 
-	for (i = 0; (i+4) <= len; i+=4) {
-		printk("%08X", *(u32*)(pbuf + i));
-		if ((i+4) & 0x1F) printk(" ");
-		else printk("\n");
+	for (i = 0; (i + 4) <= len; i += 4) {
+		printk("%08X", *(u32 *)(pbuf + i));
+		if ((i + 4) & 0x1F)
+			printk(" ");
+		else
+			printk("\n");
 	}
 
-	if (i < len)
-	{
+	if (i < len) {
 #ifdef CONFIG_BIG_ENDIAN
 		for (; i < len, i++)
-			printk("%02X", pbuf+i);
-#else // CONFIG_LITTLE_ENDIAN
+			printk("%02X", pbuf + i);
+#else /* CONFIG_LITTLE_ENDIAN */
 #if 0
 		val = 0;
 		_rtw_memcpy(&val, pbuf + i, len - i);
@@ -12783,12 +11651,12 @@ static void printdata(u8 *pbuf, u32 len)
 		u8 n;
 		val = 0;
 		n = len - i;
-		_rtw_memcpy(&val, pbuf+i, n);
+		_rtw_memcpy(&val, pbuf + i, n);
 		sprintf(str, "%08X", val);
 		n = (4 - n) * 2;
-		printk("%8s", str+n);
+		printk("%8s", str + n);
 #endif
-#endif // CONFIG_LITTLE_ENDIAN
+#endif /* CONFIG_LITTLE_ENDIAN */
 	}
 	printk("\n");
 }
@@ -12804,7 +11672,7 @@ static u8 pktcmp(PADAPTER padapter, u8 *txbuf, u32 txsz, u8 *rxbuf, u32 rxsz)
 	u8 fcssize;
 	u8 ret = _FALSE;
 
-	prxstat = (struct recv_stat*)rxbuf;
+	prxstat = (struct recv_stat *)rxbuf;
 	report.rxdw0 = le32_to_cpu(prxstat->rxdw0);
 	report.rxdw1 = le32_to_cpu(prxstat->rxdw1);
 	report.rxdw2 = le32_to_cpu(prxstat->rxdw2);
@@ -12817,43 +11685,42 @@ static u8 pktcmp(PADAPTER padapter, u8 *txbuf, u32 txsz, u8 *rxbuf, u32 rxsz)
 	rxpktsize = prxreport->pktlen;
 
 	phal = GET_HAL_DATA(padapter);
-	if (phal->ReceiveConfig & RCR_APPFCS) fcssize = IEEE80211_FCS_LEN;
-	else fcssize = 0;
+	if (rtw_hal_rcr_check(padapter, RCR_APPFCS))
+		fcssize = IEEE80211_FCS_LEN;
+	else
+		fcssize = 0;
 
 	if ((txsz - TXDESC_SIZE) != (rxpktsize - fcssize)) {
-		DBG_8192C("%s: ERROR! size not match tx/rx=%d/%d !\n",
-			__func__, txsz - TXDESC_SIZE, rxpktsize - fcssize);
+		RTW_INFO("%s: ERROR! size not match tx/rx=%d/%d !\n",
+			 __func__, txsz - TXDESC_SIZE, rxpktsize - fcssize);
 		ret = _FALSE;
 	} else {
-		ret = _rtw_memcmp(txbuf + TXDESC_SIZE,\
-						  rxbuf + RXDESC_SIZE + drvinfosize,\
-						  txsz - TXDESC_SIZE);
-		if (ret == _FALSE) {
-			DBG_8192C("%s: ERROR! pkt content mismatch!\n", __func__);
-		}
+		ret = _rtw_memcmp(txbuf + TXDESC_SIZE, \
+				  rxbuf + RXDESC_SIZE + drvinfosize, \
+				  txsz - TXDESC_SIZE);
+		if (ret == _FALSE)
+			RTW_INFO("%s: ERROR! pkt content mismatch!\n", __func__);
 	}
 
-	if (ret == _FALSE)
-	{
-		DBG_8192C("\n%s: TX PKT total=%d, desc=%d, content=%d\n",
-			__func__, txsz, TXDESC_SIZE, txsz - TXDESC_SIZE);
-		DBG_8192C("%s: TX DESC size=%d\n", __func__, TXDESC_SIZE);
+	if (ret == _FALSE) {
+		RTW_INFO("\n%s: TX PKT total=%d, desc=%d, content=%d\n",
+			 __func__, txsz, TXDESC_SIZE, txsz - TXDESC_SIZE);
+		RTW_INFO("%s: TX DESC size=%d\n", __func__, TXDESC_SIZE);
 		printdata(txbuf, TXDESC_SIZE);
-		DBG_8192C("%s: TX content size=%d\n", __func__, txsz - TXDESC_SIZE);
+		RTW_INFO("%s: TX content size=%d\n", __func__, txsz - TXDESC_SIZE);
 		printdata(txbuf + TXDESC_SIZE, txsz - TXDESC_SIZE);
 
-		DBG_8192C("\n%s: RX PKT read=%d offset=%d(%d,%d) content=%d\n",
+		RTW_INFO("\n%s: RX PKT read=%d offset=%d(%d,%d) content=%d\n",
 			__func__, rxsz, RXDESC_SIZE + drvinfosize, RXDESC_SIZE, drvinfosize, rxpktsize);
-		if (rxpktsize != 0)
-		{
-			DBG_8192C("%s: RX DESC size=%d\n", __func__, RXDESC_SIZE);
+		if (rxpktsize != 0) {
+			RTW_INFO("%s: RX DESC size=%d\n", __func__, RXDESC_SIZE);
 			printdata(rxbuf, RXDESC_SIZE);
-			DBG_8192C("%s: RX drvinfo size=%d\n", __func__, drvinfosize);
+			RTW_INFO("%s: RX drvinfo size=%d\n", __func__, drvinfosize);
 			printdata(rxbuf + RXDESC_SIZE, drvinfosize);
-			DBG_8192C("%s: RX content size=%d\n", __func__, rxpktsize);
+			RTW_INFO("%s: RX content size=%d\n", __func__, rxpktsize);
 			printdata(rxbuf + RXDESC_SIZE + drvinfosize, rxpktsize);
 		} else {
-			DBG_8192C("%s: RX data size=%d\n", __func__, rxsz);
+			RTW_INFO("%s: RX data size=%d\n", __func__, rxsz);
 			printdata(rxbuf, rxsz);
 		}
 	}
@@ -12874,7 +11741,8 @@ thread_return lbk_thread(thread_context context)
 
 	padapter = (PADAPTER)context;
 	ploopback = padapter->ploopback;
-	if (ploopback == NULL) return -1;
+	if (ploopback == NULL)
+		return -1;
 	cnt = 0;
 	ok = 0;
 	fail = 0;
@@ -12885,10 +11753,10 @@ thread_return lbk_thread(thread_context context)
 	do {
 		if (ploopback->size == 0) {
 			get_random_bytes(&pktsize, 4);
-			pktsize = (pktsize % 1535) + 1; // 1~1535
+			pktsize = (pktsize % 1535) + 1; /* 1~1535 */
 		} else
 			pktsize = ploopback->size;
-		
+
 		pxmitframe = createloopbackpkt(padapter, pktsize);
 		if (pxmitframe == NULL) {
 			sprintf(ploopback->msg, "loopback FAIL! 3. create Packet FAIL!");
@@ -12899,11 +11767,11 @@ thread_return lbk_thread(thread_context context)
 		_rtw_memcpy(ploopback->txbuf, pxmitframe->buf_addr, ploopback->txsize);
 		ff_hwaddr = rtw_get_ff_hwaddr(pxmitframe);
 		cnt++;
-		DBG_8192C("%s: wirte port cnt=%d size=%d\n", __func__, cnt, ploopback->txsize);
+		RTW_INFO("%s: wirte port cnt=%d size=%d\n", __func__, cnt, ploopback->txsize);
 		pxmitframe->pxmitbuf->pdata = ploopback->txbuf;
 		rtw_write_port(padapter, ff_hwaddr, ploopback->txsize, (u8 *)pxmitframe->pxmitbuf);
 
-		// wait for rx pkt
+		/* wait for rx pkt */
 		_rtw_down_sema(&ploopback->sema);
 
 		err = pktcmp(padapter, ploopback->txbuf, ploopback->txsize, ploopback->rxbuf, ploopback->rxsize);
@@ -12920,30 +11788,28 @@ thread_return lbk_thread(thread_context context)
 		freeloopbackpkt(padapter, pxmitframe);
 		pxmitframe = NULL;
 
-		if (signal_pending(current)) {
-			flush_signals(current);
-		}
+		flush_signals_thread();
 
 		if ((ploopback->bstop == _TRUE) ||
-			((ploopback->cnt != 0) && (ploopback->cnt == cnt)))
-		{
+		    ((ploopback->cnt != 0) && (ploopback->cnt == cnt))) {
 			u32 ok_rate, fail_rate, all;
 			all = cnt;
-			ok_rate = (ok*100)/all;
-			fail_rate = (fail*100)/all;
-			sprintf(ploopback->msg,\
-					"loopback result: ok=%d%%(%d/%d),error=%d%%(%d/%d)",\
-					ok_rate, ok, all, fail_rate, fail, all);
+			ok_rate = (ok * 100) / all;
+			fail_rate = (fail * 100) / all;
+			sprintf(ploopback->msg, \
+				"loopback result: ok=%d%%(%d/%d),error=%d%%(%d/%d)", \
+				ok_rate, ok, all, fail_rate, fail, all);
 			break;
 		}
 	} while (1);
 
 	ploopback->bstop = _TRUE;
 
-	thread_exit();
+	thread_exit(NULL);
+	return 0;
 }
 
-static void loopbackTest(PADAPTER padapter, u32 cnt, u32 size, u8* pmsg)
+static void loopbackTest(PADAPTER padapter, u32 cnt, u32 size, u8 *pmsg)
 {
 	PLOOPBACKDATA ploopback;
 	u32 len;
@@ -12952,8 +11818,7 @@ static void loopbackTest(PADAPTER padapter, u32 cnt, u32 size, u8* pmsg)
 
 	ploopback = padapter->ploopback;
 
-	if (ploopback)
-	{
+	if (ploopback) {
 		if (ploopback->bstop == _FALSE) {
 			ploopback->bstop = _TRUE;
 			_rtw_up_sema(&ploopback->sema);
@@ -12961,20 +11826,21 @@ static void loopbackTest(PADAPTER padapter, u32 cnt, u32 size, u8* pmsg)
 		len = 0;
 		do {
 			len = strlen(ploopback->msg);
-			if (len) break;
+			if (len)
+				break;
 			rtw_msleep_os(1);
 		} while (1);
-		_rtw_memcpy(pmsg, ploopback->msg, len+1);
+		_rtw_memcpy(pmsg, ploopback->msg, len + 1);
 		freeLoopback(padapter);
 
 		return;
 	}
 
-	// disable dynamic algorithm	
+	/* disable dynamic algorithm	 */
 	rtw_phydm_ability_backup(padapter);
 	rtw_phydm_func_disable_all(padapter);
 
-	// create pseudo ad-hoc connection
+	/* create pseudo ad-hoc connection */
 	err = initpseudoadhoc(padapter);
 	if (err == _FAIL) {
 		sprintf(pmsg, "loopback FAIL! 1.1 init ad-hoc FAIL!");
@@ -12999,16 +11865,16 @@ static void loopbackTest(PADAPTER padapter, u32 cnt, u32 size, u8* pmsg)
 	ploopback->cnt = cnt;
 	ploopback->size = size;
 	ploopback->lbkthread = kthread_run(lbk_thread, padapter, "RTW_LBK_THREAD");
-	if (IS_ERR(padapter->lbkthread))
-	{
+	if (IS_ERR(padapter->lbkthread)) {
 		freeLoopback(padapter);
+		ploopback->lbkthread = NULL;
 		sprintf(pmsg, "loopback start FAIL! cnt=%d", cnt);
 		return;
 	}
 
 	sprintf(pmsg, "loopback start! cnt=%d", cnt);
 }
-#endif // CONFIG_MAC_LOOPBACK_DRIVER
+#endif /* CONFIG_MAC_LOOPBACK_DRIVER */
 
 static int rtw_test(
 	struct net_device *dev,
@@ -13022,55 +11888,57 @@ static int rtw_test(
 	PADAPTER padapter = rtw_netdev_priv(dev);
 
 
-	DBG_871X("+%s\n", __func__);
+	RTW_INFO("+%s\n", __func__);
 	len = wrqu->data.length;
 
-	pbuf = (u8*)rtw_zmalloc(len);
+	pbuf = (u8 *)rtw_zmalloc(len + 1);
 	if (pbuf == NULL) {
-		DBG_871X("%s: no memory!\n", __func__);
+		RTW_INFO("%s: no memory!\n", __func__);
 		return -ENOMEM;
 	}
 
 	if (copy_from_user(pbuf, wrqu->data.pointer, len)) {
-		rtw_mfree(pbuf, len);
-		DBG_871X("%s: copy from user fail!\n", __func__);
+		rtw_mfree(pbuf, len + 1);
+		RTW_INFO("%s: copy from user fail!\n", __func__);
 		return -EFAULT;
 	}
-	DBG_871X("%s: string=\"%s\"\n", __func__, pbuf);
 
-	ptmp = (char*)pbuf;
+	pbuf[len] = '\0';
+
+	RTW_INFO("%s: string=\"%s\"\n", __func__, pbuf);
+
+	ptmp = (char *)pbuf;
 	pch = strsep(&ptmp, delim);
 	if ((pch == NULL) || (strlen(pch) == 0)) {
 		rtw_mfree(pbuf, len);
-		DBG_871X("%s: parameter error(level 1)!\n", __func__);
+		RTW_INFO("%s: parameter error(level 1)!\n", __func__);
 		return -EFAULT;
 	}
 
 #ifdef CONFIG_MAC_LOOPBACK_DRIVER
-	if (strcmp(pch, "loopback") == 0)
-	{
+	if (strcmp(pch, "loopback") == 0) {
 		s32 cnt = 0;
 		u32 size = 64;
 
 		pch = strsep(&ptmp, delim);
 		if ((pch == NULL) || (strlen(pch) == 0)) {
 			rtw_mfree(pbuf, len);
-			DBG_871X("%s: parameter error(level 2)!\n", __func__);
+			RTW_INFO("%s: parameter error(level 2)!\n", __func__);
 			return -EFAULT;
 		}
 
 		sscanf(pch, "%d", &cnt);
-		DBG_871X("%s: loopback cnt=%d\n", __func__, cnt);
+		RTW_INFO("%s: loopback cnt=%d\n", __func__, cnt);
 
 		pch = strsep(&ptmp, delim);
 		if ((pch == NULL) || (strlen(pch) == 0)) {
 			rtw_mfree(pbuf, len);
-			DBG_871X("%s: parameter error(level 2)!\n", __func__);
+			RTW_INFO("%s: parameter error(level 2)!\n", __func__);
 			return -EFAULT;
 		}
 
 		sscanf(pch, "%d", &size);
-		DBG_871X("%s: loopback size=%d\n", __func__, size);
+		RTW_INFO("%s: loopback size=%d\n", __func__, size);
 
 		loopbackTest(padapter, cnt, size, extra);
 		wrqu->data.length = strlen(extra) + 1;
@@ -13096,7 +11964,7 @@ static int rtw_test(
 		u32 tmp;
 		u8 i;
 		u32 pos;
-		s32 ret;
+		u8 ret;
 
 		do {
 			pch = strsep(&ptmp, delim);
@@ -13109,19 +11977,18 @@ static int rtw_test(
 
 		if (count == 0) {
 			rtw_mfree(pbuf, len);
-			DBG_871X("%s: parameter error(level 2)!\n", __func__);
+			RTW_INFO("%s: parameter error(level 2)!\n", __func__);
 			return -EFAULT;
 		}
 
-		ret = rtw_hal_fill_h2c_cmd(padapter, param[0], count-1, &param[1]);
+		ret = rtw_test_h2c_cmd(padapter, param, count);
 
 		pos = sprintf(extra, "H2C ID=0x%02x content=", param[0]);
-		for (i=1; i<count; i++) {
-			pos += sprintf(extra+pos, "%02x,", param[i]);
-		}
+		for (i = 1; i < count; i++)
+			pos += sprintf(extra + pos, "%02x,", param[i]);
 		extra[pos] = 0;
 		pos--;
-		pos += sprintf(extra+pos, " %s", ret==_FAIL?"FAIL":"OK");
+		pos += sprintf(extra + pos, " %s", ret == _FAIL ? "FAIL" : "OK");
 
 		wrqu->data.length = strlen(extra) + 1;
 
@@ -13133,8 +12000,7 @@ free_buf:
 	return 0;
 }
 
-static iw_handler rtw_handlers[] =
-{
+static iw_handler rtw_handlers[] = {
 	NULL,					/* SIOCSIWCOMMIT */
 	rtw_wx_get_name,		/* SIOCGIWNAME */
 	dummy,					/* SIOCSIWNWID */
@@ -13191,7 +12057,7 @@ static iw_handler rtw_handlers[] =
 	NULL,					/* SIOCGIWENCODEEXT */
 	rtw_wx_set_pmkid,		/* SIOCSIWPMKSA */
 	NULL,					/*---hole---*/
-}; 
+};
 
 
 static const struct iw_priv_args rtw_private_args[] = {
@@ -13222,7 +12088,7 @@ static const struct iw_priv_args rtw_private_args[] = {
 		SIOCIWFIRSTPRIV + 0x6,
 		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "wps_start"
 	},
-//for PLATFORM_MT53XX	
+	/* for PLATFORM_MT53XX	 */
 	{
 		SIOCIWFIRSTPRIV + 0x7,
 		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "get_sensitivity"
@@ -13236,7 +12102,7 @@ static const struct iw_priv_args rtw_private_args[] = {
 		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "wps_assoc_req_ie"
 	},
 
-//for RTK_DMP_PLATFORM	
+	/* for RTK_DMP_PLATFORM	 */
 	{
 		SIOCIWFIRSTPRIV + 0xA,
 		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, 0, "channel_plan"
@@ -13245,7 +12111,7 @@ static const struct iw_priv_args rtw_private_args[] = {
 	{
 		SIOCIWFIRSTPRIV + 0xB,
 		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 2, 0, "dbg"
-	},	
+	},
 	{
 		SIOCIWFIRSTPRIV + 0xC,
 		IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 3, 0, "rfw"
@@ -13256,7 +12122,7 @@ static const struct iw_priv_args rtw_private_args[] = {
 	},
 #if 0
 	{
-		SIOCIWFIRSTPRIV + 0xE,0,0, "wowlan_ctrl"
+		SIOCIWFIRSTPRIV + 0xE, 0, 0, "wowlan_ctrl"
 	},
 #endif
 	{
@@ -13273,7 +12139,7 @@ static const struct iw_priv_args rtw_private_args[] = {
 	{
 		SIOCIWFIRSTPRIV + 0x13,
 		IW_PRIV_TYPE_CHAR | 64, IW_PRIV_TYPE_CHAR | 64 , "p2p_get2"
-	},	
+	},
 	{
 		SIOCIWFIRSTPRIV + 0x14,
 		IW_PRIV_TYPE_CHAR  | 64, 0, "tdls"
@@ -13281,18 +12147,23 @@ static const struct iw_priv_args rtw_private_args[] = {
 	{
 		SIOCIWFIRSTPRIV + 0x15,
 		IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024 , "tdls_get"
-	},	
+	},
 	{
 		SIOCIWFIRSTPRIV + 0x16,
 		IW_PRIV_TYPE_CHAR | 64, 0, "pm_set"
 	},
-
+#ifdef CONFIG_RTW_80211K
+	{
+		SIOCIWFIRSTPRIV + 0x17,
+		IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024 , "rrm"
+	},
+#endif
 	{SIOCIWFIRSTPRIV + 0x18, IW_PRIV_TYPE_CHAR | IFNAMSIZ , 0 , "rereg_nd_name"},
 #ifdef CONFIG_MP_INCLUDED
 	{SIOCIWFIRSTPRIV + 0x1A, IW_PRIV_TYPE_CHAR | 1024, 0,  "NULL"},
 	{SIOCIWFIRSTPRIV + 0x1B, IW_PRIV_TYPE_CHAR | 128, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "NULL"},
 #else
-	{SIOCIWFIRSTPRIV + 0x1A, IW_PRIV_TYPE_CHAR | 1024, 0, "efuse_set"},
+	{SIOCIWFIRSTPRIV + 0x1A, IW_PRIV_TYPE_CHAR | 1024, 0,  "NULL"},
 	{SIOCIWFIRSTPRIV + 0x1B, IW_PRIV_TYPE_CHAR | 128, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_get"},
 #endif
 	{
@@ -13309,203 +12180,225 @@ static const struct iw_priv_args rtw_private_args[] = {
 		SIOCIWFIRSTPRIV + 0x1F,
 		IW_PRIV_TYPE_CHAR | 128, 0, "widi_prob_req"
 	},
-#endif // CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
-#ifdef CONFIG_MP_INCLUDED
-	{ SIOCIWFIRSTPRIV + 0x0E, IW_PRIV_TYPE_CHAR | 1024, 0 , ""},  //set 
-	{ SIOCIWFIRSTPRIV + 0x0F, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK , ""},//get
-/* --- sub-ioctls definitions --- */   
-		{ MP_START , IW_PRIV_TYPE_CHAR | 1024, 0, "mp_start" }, //set
-		{ MP_PHYPARA, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_phypara" },//get
-		{ MP_STOP , IW_PRIV_TYPE_CHAR | 1024, 0, "mp_stop" }, //set
-		{ MP_CHANNEL , IW_PRIV_TYPE_CHAR | 1024 , IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_channel" },//get
-		{ MP_BANDWIDTH , IW_PRIV_TYPE_CHAR | 1024, 0, "mp_bandwidth"}, //set
-		{ MP_RATE , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rate" },//get
-		{ MP_RESET_STATS , IW_PRIV_TYPE_CHAR | 1024, 0, "mp_reset_stats"},
-		{ MP_QUERY , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK , "mp_query"}, //get
-		{ READ_REG , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "read_reg" },
-		{ MP_RATE , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rate" },
-		{ READ_RF , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "read_rf" },
-		{ MP_PSD , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_psd"}, 
-		{ MP_DUMP, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_dump" },
-		{ MP_TXPOWER , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_txpower"},
-		{ MP_ANT_TX , IW_PRIV_TYPE_CHAR | 1024,  IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ant_tx"},
-		{ MP_ANT_RX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ant_rx"},
-		{ WRITE_REG , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "write_reg" },
-		{ WRITE_RF , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "write_rf" },
-		{ MP_CTX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ctx"},
-		{ MP_ARX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_arx"},
-		{ MP_THER , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ther"},
-		{ EFUSE_SET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_set" },
-		{ EFUSE_GET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_get" },
-		{ MP_PWRTRK , IW_PRIV_TYPE_CHAR | 1024, 0, "mp_pwrtrk"},
-		{ MP_QueryDrvStats, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_drvquery" },
-		{ MP_IOCTL, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_ioctl"}, // mp_ioctl	
-		{ MP_SetRFPathSwh, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_setrfpath" },		
-		{ MP_PwrCtlDM, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrctldm" },		
-		{ MP_GET_TXPOWER_INX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_get_txpower" },
-		{ MP_GETVER, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_priv_ver" },
-		{ MP_MON, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_mon" },
-		{ EFUSE_MASK, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_mask" },
-		{ EFUSE_FILE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_file" },
-		{ MP_TX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_tx" },
-		{ MP_RX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rx" },
+	{ SIOCIWFIRSTPRIV + 0x0E, IW_PRIV_TYPE_CHAR | 1024, 0 , ""},  /* set  */
+	{ SIOCIWFIRSTPRIV + 0x0F, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK , ""},/* get
+ * --- sub-ioctls definitions --- */
+
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	{ VENDOR_IE_SET, IW_PRIV_TYPE_CHAR | 1024 , 0 , "vendor_ie_set" },
+	{ VENDOR_IE_GET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "vendor_ie_get" },
+#endif
 #if defined(CONFIG_RTL8723B)
-		{ MP_SetBT, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_setbt" },
-        { MP_DISABLE_BT_COEXIST, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_disa_btcoex"},
-#endif
-		{ CTA_TEST, IW_PRIV_TYPE_CHAR | 1024, 0, "cta_test"},
-		{ MP_IQK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_iqk"},
-		{ MP_LCK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_lck"},
-		#ifdef CONFIG_RTW_CUSTOMER_STR
-		{ MP_CUSTOMER_STR, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "customer_str" },
-		#endif
+	{ MP_SetBT, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_setbt" },
+	{ MP_DISABLE_BT_COEXIST, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_disa_btcoex"},
 #endif
 #ifdef CONFIG_WOWLAN
-		{ MP_WOW_ENABLE , IW_PRIV_TYPE_CHAR | 1024, 0, "wow_mode" },
-		{ MP_WOW_SET_PATTERN , IW_PRIV_TYPE_CHAR | 1024, 0, "wow_set_pattern" },
+	{ MP_WOW_ENABLE , IW_PRIV_TYPE_CHAR | 1024, 0, "wow_mode" },
+	{ MP_WOW_SET_PATTERN , IW_PRIV_TYPE_CHAR | 1024, 0, "wow_set_pattern" },
 #endif
 #ifdef CONFIG_AP_WOWLAN
-		{ MP_AP_WOW_ENABLE , IW_PRIV_TYPE_CHAR | 1024, 0, "ap_wow_mode" }, //set 
+	{ MP_AP_WOW_ENABLE , IW_PRIV_TYPE_CHAR | 1024, 0, "ap_wow_mode" }, /* set  */
 #endif
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
-		{ MP_SD_IREAD, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "sd_iread" },
-		{ MP_SD_IWRITE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "sd_iwrite" },
+	{ MP_SD_IREAD, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "sd_iread" },
+	{ MP_SD_IWRITE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "sd_iwrite" },
 #endif
 };
 
-static iw_handler rtw_private_handler[] = 
-{
-	rtw_wx_write32,					//0x00
-	rtw_wx_read32,					//0x01
-	rtw_drvext_hdl,					//0x02
-	rtw_mp_ioctl_hdl,				//0x03
-
-// for MM DTV platform
-	rtw_get_ap_info,					//0x04
-
-	rtw_set_pid,						//0x05
-	rtw_wps_start,					//0x06
 
-// for PLATFORM_MT53XX
-	rtw_wx_get_sensitivity,			//0x07
-	rtw_wx_set_mtk_wps_probe_ie,	//0x08
-	rtw_wx_set_mtk_wps_ie,			//0x09
+static const struct iw_priv_args rtw_mp_private_args[] = {
+	/* --- sub-ioctls definitions --- */
+#ifdef CONFIG_MP_INCLUDED
+	{ MP_START , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_start" },
+	{ MP_PHYPARA, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_phypara" },
+	{ MP_STOP , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_stop" },
+	{ MP_CHANNEL , IW_PRIV_TYPE_CHAR | 1024 , IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_channel" },
+	{ MP_CHL_OFFSET , IW_PRIV_TYPE_CHAR | 1024 , IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ch_offset" },
+	{ MP_BANDWIDTH , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_bandwidth"},
+	{ MP_RATE , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rate" },
+	{ MP_RESET_STATS , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_reset_stats"},
+	{ MP_QUERY , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK , "mp_query"},
+	{ READ_REG , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "read_reg" },
+	{ MP_RATE , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rate" },
+	{ READ_RF , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "read_rf" },
+	{ MP_PSD , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_psd"},
+	{ MP_DUMP, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_dump" },
+	{ MP_TXPOWER , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_txpower"},
+	{ MP_ANT_TX , IW_PRIV_TYPE_CHAR | 1024,  IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ant_tx"},
+	{ MP_ANT_RX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ant_rx"},
+	{ WRITE_REG , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "write_reg" },
+	{ WRITE_RF , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "write_rf" },
+	{ MP_CTX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ctx"},
+	{ MP_ARX , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_arx"},
+	{ MP_THER , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ther"},
+	{ EFUSE_SET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_set" },
+	{ EFUSE_GET, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_get" },
+	{ MP_PWRTRK , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrtrk"},
+	{ MP_QueryDrvStats, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_drvquery" },
+	{ MP_IOCTL, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_ioctl"},
+	{ MP_SetRFPathSwh, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_setrfpath" },
+	{ MP_PwrCtlDM, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrctldm" },
+	{ MP_GET_TXPOWER_INX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_get_txpower" },
+	{ MP_GETVER, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_priv_ver" },
+	{ MP_MON, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_mon" },
+	{ EFUSE_MASK, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_mask" },
+	{ EFUSE_FILE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "efuse_file" },
+	{ MP_TX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_tx" },
+	{ MP_RX, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rx" },
+	{ MP_HW_TX_MODE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_hxtx" },
+	{ MP_PWRLMT, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrlmt" },
+	{ MP_PWRBYRATE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_pwrbyrate" },
+	{ CTA_TEST, IW_PRIV_TYPE_CHAR | 1024, 0, "cta_test"},
+	{ MP_IQK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_iqk"},
+	{ MP_LCK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_lck"},
+	{ BT_EFUSE_FILE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "bt_efuse_file" },
+	{ MP_SWRFPath, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_swrfpath" },
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	{ MP_CUSTOMER_STR, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "customer_str" },
+#endif
 
-// for RTK_DMP_PLATFORM
-// Set Channel depend on the country code
-	rtw_wx_set_channel_plan,		//0x0A
+#endif /* CONFIG_MP_INCLUDED */
+};
 
-	rtw_dbg_port,					//0x0B
-	rtw_wx_write_rf,					//0x0C
-	rtw_wx_read_rf,					//0x0D
-#ifdef CONFIG_MP_INCLUDED
-	rtw_mp_set,					//0x0E
-	rtw_mp_get,					//0x0F
+static iw_handler rtw_private_handler[] = {
+	rtw_wx_write32,					/* 0x00 */
+	rtw_wx_read32,					/* 0x01 */
+	NULL,					/* 0x02 */
+#ifdef MP_IOCTL_HDL
+	rtw_mp_ioctl_hdl,				/* 0x03 */
 #else
-	rtw_wx_priv_null,				//0x0E
-	rtw_wx_priv_null,				//0x0F
+	rtw_wx_priv_null,
 #endif
-	rtw_p2p_set,					//0x10
-	rtw_p2p_get,					//0x11
-	NULL,							//0x12
-	rtw_p2p_get2,					//0x13
+	/* for MM DTV platform */
+	rtw_get_ap_info,					/* 0x04 */
+
+	rtw_set_pid,						/* 0x05 */
+	rtw_wps_start,					/* 0x06 */
+
+	/* for PLATFORM_MT53XX */
+	rtw_wx_get_sensitivity,			/* 0x07 */
+	rtw_wx_set_mtk_wps_probe_ie,	/* 0x08 */
+	rtw_wx_set_mtk_wps_ie,			/* 0x09 */
+
+	/* for RTK_DMP_PLATFORM
+	 * Set Channel depend on the country code */
+	rtw_wx_set_channel_plan,		/* 0x0A */
 
-	rtw_tdls,						//0x14
-	rtw_tdls_get,					//0x15
+	rtw_dbg_port,					/* 0x0B */
+	rtw_wx_write_rf,					/* 0x0C */
+	rtw_wx_read_rf,					/* 0x0D */
 
-	rtw_pm_set,						//0x16
-	rtw_wx_priv_null,				//0x17
-	rtw_rereg_nd_name,				//0x18
-	rtw_wx_priv_null,				//0x19
+	rtw_priv_set,					/*0x0E*/
+	rtw_priv_get,					/*0x0F*/
+
+	rtw_p2p_set,					/* 0x10 */
+	rtw_p2p_get,					/* 0x11 */
+	NULL,							/* 0x12 */
+	rtw_p2p_get2,					/* 0x13 */
+
+	rtw_tdls,						/* 0x14 */
+	rtw_tdls_get,					/* 0x15 */
+
+	rtw_pm_set,						/* 0x16 */
+#ifdef CONFIG_RTW_80211K
+	rtw_wx_priv_rrm,				/* 0x17 */
+#else
+	rtw_wx_priv_null,				/* 0x17 */
+#endif
+	rtw_rereg_nd_name,				/* 0x18 */
+	rtw_wx_priv_null,				/* 0x19 */
 #ifdef CONFIG_MP_INCLUDED
-	rtw_wx_priv_null,				//0x1A
-	rtw_wx_priv_null,				//0x1B
+	rtw_wx_priv_null,				/* 0x1A */
+	rtw_wx_priv_null,				/* 0x1B */
 #else
-	rtw_mp_efuse_set,				//0x1A
-	rtw_mp_efuse_get,				//0x1B
+	rtw_wx_priv_null,				/* 0x1A */
+	rtw_mp_efuse_get,				/* 0x1B */
 #endif
-	NULL,							// 0x1C is reserved for hostapd
-	rtw_test,						// 0x1D
+	NULL,							/* 0x1C is reserved for hostapd */
+	rtw_test,						/* 0x1D */
 #ifdef CONFIG_INTEL_WIDI
-	rtw_widi_set,					//0x1E
-	rtw_widi_set_probe_request,		//0x1F
-#endif // CONFIG_INTEL_WIDI
+	rtw_widi_set,					/* 0x1E */
+	rtw_widi_set_probe_request,		/* 0x1F */
+#endif /* CONFIG_INTEL_WIDI */
 };
 
-
-#if WIRELESS_EXT >= 17	
+#if WIRELESS_EXT >= 17
 static struct iw_statistics *rtw_get_wireless_stats(struct net_device *dev)
 {
-       _adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	   struct iw_statistics *piwstats=&padapter->iwstats;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct iw_statistics *piwstats = &padapter->iwstats;
 	int tmp_level = 0;
 	int tmp_qual = 0;
 	int tmp_noise = 0;
 
-	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) != _TRUE)
-	{
+	if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) != _TRUE) {
 		piwstats->qual.qual = 0;
 		piwstats->qual.level = 0;
 		piwstats->qual.noise = 0;
-		//DBG_871X("No link  level:%d, qual:%d, noise:%d\n", tmp_level, tmp_qual, tmp_noise);
-	}
-	else{
-		#ifdef CONFIG_SIGNAL_DISPLAY_DBM
-		tmp_level = translate_percentage_to_dbm(padapter->recvpriv.signal_strength); 
-		#else
-		#ifdef CONFIG_SIGNAL_SCALE_MAPPING
+		/* RTW_INFO("No link  level:%d, qual:%d, noise:%d\n", tmp_level, tmp_qual, tmp_noise); */
+	} else {
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+		tmp_level = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);
+#else
+#ifdef CONFIG_SIGNAL_SCALE_MAPPING
 		tmp_level = padapter->recvpriv.signal_strength;
-		#else
+#else
 		{
 			/* Do signal scale mapping when using percentage as the unit of signal strength, since the scale mapping is skipped in odm */
-			
+
 			HAL_DATA_TYPE *pHal = GET_HAL_DATA(padapter);
-			
-			tmp_level = (u8)odm_SignalScaleMapping(&pHal->odmpriv, padapter->recvpriv.signal_strength);
+
+			tmp_level = (u8)phydm_signal_scale_mapping(&pHal->odmpriv, padapter->recvpriv.signal_strength);
 		}
-		#endif
-		#endif
-		
+#endif
+#endif
+
 		tmp_qual = padapter->recvpriv.signal_qual;
-		rtw_get_noise(padapter);
-		tmp_noise = padapter->recvpriv.noise;
-		//DBG_871X("level:%d, qual:%d, noise:%d, rssi (%d)\n", tmp_level, tmp_qual, tmp_noise,padapter->recvpriv.rssi);
+		#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+		if (IS_NM_ENABLE(padapter)) {
+			tmp_noise = rtw_noise_measure_curchan(padapter);
+			#ifndef CONFIG_SIGNAL_DISPLAY_DBM
+			tmp_noise = translate_dbm_to_percentage(tmp_noise);/*percentage*/
+			#endif
+		}
+		#endif
+		/* RTW_INFO("level:%d, qual:%d, noise:%d, rssi (%d)\n", tmp_level, tmp_qual, tmp_noise,padapter->recvpriv.rssi); */
 
 		piwstats->qual.level = tmp_level;
 		piwstats->qual.qual = tmp_qual;
 		piwstats->qual.noise = tmp_noise;
 	}
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,14))
-	piwstats->qual.updated = IW_QUAL_ALL_UPDATED ;//|IW_QUAL_DBM;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 14))
+	piwstats->qual.updated = IW_QUAL_ALL_UPDATED ;/* |IW_QUAL_DBM; */
 #else
 #ifdef RTK_DMP_PLATFORM
-	//IW_QUAL_DBM= 0x8, if driver use this flag, wireless extension will show value of dbm.
-	//remove this flag for show percentage 0~100
+	/* IW_QUAL_DBM= 0x8, if driver use this flag, wireless extension will show value of dbm. */
+	/* remove this flag for show percentage 0~100 */
 	piwstats->qual.updated = 0x07;
 #else
 	piwstats->qual.updated = 0x0f;
 #endif
 #endif
 
-	#ifdef CONFIG_SIGNAL_DISPLAY_DBM
+#ifdef CONFIG_SIGNAL_DISPLAY_DBM
 	piwstats->qual.updated = piwstats->qual.updated | IW_QUAL_DBM;
-	#endif
+#endif
 
 	return &padapter->iwstats;
 }
 #endif
 
 #ifdef CONFIG_WIRELESS_EXT
-struct iw_handler_def rtw_handlers_def =
-{
+struct iw_handler_def rtw_handlers_def = {
 	.standard = rtw_handlers,
 	.num_standard = sizeof(rtw_handlers) / sizeof(iw_handler),
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,33)) || defined(CONFIG_WEXT_PRIV)
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 33)) || defined(CONFIG_WEXT_PRIV)
 	.private = rtw_private_handler,
 	.private_args = (struct iw_priv_args *)rtw_private_args,
 	.num_private = sizeof(rtw_private_handler) / sizeof(iw_handler),
- 	.num_private_args = sizeof(rtw_private_args) / sizeof(struct iw_priv_args),
+	.num_private_args = sizeof(rtw_private_args) / sizeof(struct iw_priv_args),
 #endif
 #if WIRELESS_EXT >= 17
 	.get_wireless_stats = rtw_get_wireless_stats,
@@ -13513,9 +12406,9 @@ struct iw_handler_def rtw_handlers_def =
 };
 #endif
 
-// copy from net/wireless/wext.c start
-/* ---------------------------------------------------------------- */
-/*
+/* copy from net/wireless/wext.c start
+ * ----------------------------------------------------------------
+ *
  * Calculate size of private arguments
  */
 static const char iw_priv_type_size[] = {
@@ -13536,7 +12429,7 @@ static int get_priv_size(__u16 args)
 
 	return num * iw_priv_type_size[type];
 }
-// copy from net/wireless/wext.c end
+/* copy from net/wireless/wext.c end */
 
 
 static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq_data)
@@ -13548,10 +12441,10 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 	u8 *output = NULL;
 	u32 output_len = 0;
 	u32 count = 0;
-	u8 *buffer= NULL;
+	u8 *buffer = NULL;
 	u32 buffer_len = 0;
 	char *ptr = NULL;
-	u8 cmdname[17] = {0}; // IFNAMSIZ+1
+	u8 cmdname[17] = {0}; /* IFNAMSIZ+1 */
 	u32 cmdlen;
 	s32 len;
 	u8 *extra = NULL;
@@ -13560,8 +12453,12 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 	s32 k;
 	const iw_handler *priv;		/* Private ioctl */
 	const struct iw_priv_args *priv_args;	/* Private ioctl description */
+	const struct iw_priv_args *mp_priv_args;	/*MP Private ioctl description */
+	const struct iw_priv_args *sel_priv_args;	/*Selected Private ioctl description */
 	u32 num_priv;				/* Number of ioctl */
 	u32 num_priv_args;			/* Number of descriptions */
+	u32 num_mp_priv_args;			/*Number of MP descriptions */
+	u32 num_sel_priv_args;			/*Number of Selected descriptions */
 	iw_handler handler;
 	int temp;
 	int subcmd = 0;				/* sub-ioctl index */
@@ -13572,8 +12469,10 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 	_rtw_memcpy(&wdata, wrq_data, sizeof(wdata));
 
 	input_len = wdata.data.length;
+	if (!input_len)
+		return -EINVAL;
 	input = rtw_zmalloc(input_len);
-	if (NULL == input || input_len == 0)
+	if (NULL == input)
 		return -ENOMEM;
 	if (copy_from_user(input, wdata.data.pointer, input_len)) {
 		err = -EFAULT;
@@ -13590,19 +12489,21 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 
 	sscanf(ptr, "%16s", cmdname);
 	cmdlen = strlen(cmdname);
-	DBG_871X("%s: cmd=%s\n", __func__, cmdname);
+	RTW_INFO("%s: cmd=%s\n", __func__, cmdname);
 
-	// skip command string
+	/* skip command string */
 	if (cmdlen > 0)
-		cmdlen += 1; // skip one space
+		cmdlen += 1; /* skip one space */
 	ptr += cmdlen;
 	len -= cmdlen;
-	DBG_871X("%s: parameters=%s\n", __func__, ptr);
+	RTW_INFO("%s: parameters=%s\n", __func__, ptr);
 
 	priv = rtw_private_handler;
 	priv_args = rtw_private_args;
+	mp_priv_args = rtw_mp_private_args;
 	num_priv = sizeof(rtw_private_handler) / sizeof(iw_handler);
 	num_priv_args = sizeof(rtw_private_args) / sizeof(struct iw_priv_args);
+	num_mp_priv_args = sizeof(rtw_mp_private_args) / sizeof(struct iw_priv_args);
 
 	if (num_priv_args == 0) {
 		err = -EOPNOTSUPP;
@@ -13611,23 +12512,36 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 
 	/* Search the correct ioctl */
 	k = -1;
-	while((++k < num_priv_args) && strcmp(priv_args[k].name, cmdname));
+	sel_priv_args = priv_args;
+	num_sel_priv_args = num_priv_args;
+	while
+	((++k < num_sel_priv_args) && strcmp(sel_priv_args[k].name, cmdname))
+		;
 
 	/* If not found... */
-	if (k == num_priv_args) {
-		err = -EOPNOTSUPP;
-		goto exit;
+	if (k == num_sel_priv_args) {
+		k = -1;
+		sel_priv_args = mp_priv_args;
+		num_sel_priv_args = num_mp_priv_args;
+		while
+		((++k < num_sel_priv_args) && strcmp(sel_priv_args[k].name, cmdname))
+			;
+
+		if (k == num_sel_priv_args) {
+			err = -EOPNOTSUPP;
+			goto exit;
+		}
 	}
 
 	/* Watch out for sub-ioctls ! */
-	if (priv_args[k].cmd < SIOCDEVPRIVATE)
-	{
+	if (sel_priv_args[k].cmd < SIOCDEVPRIVATE) {
 		int j = -1;
 
 		/* Find the matching *real* ioctl */
 		while ((++j < num_priv_args) && ((priv_args[j].name[0] != '\0') ||
-			(priv_args[j].set_args != priv_args[k].set_args) ||
-			(priv_args[j].get_args != priv_args[k].get_args)));
+			 (priv_args[j].set_args != sel_priv_args[k].set_args) ||
+			 (priv_args[j].get_args != sel_priv_args[k].get_args)))
+			;
 
 		/* If not found... */
 		if (j == num_priv_args) {
@@ -13636,7 +12550,7 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 		}
 
 		/* Save sub-ioctl number */
-		subcmd = priv_args[k].cmd;
+		subcmd = sel_priv_args[k].cmd;
 		/* Reserve one int (simplify alignment issues) */
 		offset = sizeof(__u32);
 		/* Use real ioctl definition from now on */
@@ -13649,111 +12563,104 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 		goto exit;
 	}
 
+	if (k >= num_priv_args) {
+		err = -EINVAL;
+		goto exit;
+	}
+
 	/* If we have to set some data */
 	if ((priv_args[k].set_args & IW_PRIV_TYPE_MASK) &&
-		(priv_args[k].set_args & IW_PRIV_SIZE_MASK))
-	{
+	    (priv_args[k].set_args & IW_PRIV_SIZE_MASK)) {
 		u8 *str;
 
-		switch (priv_args[k].set_args & IW_PRIV_TYPE_MASK)
-		{
-			case IW_PRIV_TYPE_BYTE:
-				/* Fetch args */
-				count = 0;
-				do {
-					str = strsep(&ptr, delim);
-					if (NULL == str) break;
-					sscanf(str, "%i", &temp);
-					buffer[count++] = (u8)temp;
-				} while (1);
-				buffer_len = count;
-
-				/* Number of args to fetch */
-				wdata.data.length = count;
-				if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
-					wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
+		switch (priv_args[k].set_args & IW_PRIV_TYPE_MASK) {
+		case IW_PRIV_TYPE_BYTE:
+			/* Fetch args */
+			count = 0;
+			do {
+				str = strsep(&ptr, delim);
+				if (NULL == str)
+					break;
+				sscanf(str, "%i", &temp);
+				buffer[count++] = (u8)temp;
+			} while (1);
+			buffer_len = count;
 
-				break;
+			/* Number of args to fetch */
+			wdata.data.length = count;
+			if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
+				wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
 
-			case IW_PRIV_TYPE_INT:
-				/* Fetch args */
-				count = 0;
-				do {
-					str = strsep(&ptr, delim);
-					if (NULL == str) break;
-					sscanf(str, "%i", &temp);
-					((s32*)buffer)[count++] = (s32)temp;
-				} while (1);
-				buffer_len = count * sizeof(s32);
-
-				/* Number of args to fetch */
-				wdata.data.length = count;
-				if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
-					wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
+			break;
 
-				break;
+		case IW_PRIV_TYPE_INT:
+			/* Fetch args */
+			count = 0;
+			do {
+				str = strsep(&ptr, delim);
+				if (NULL == str)
+					break;
+				sscanf(str, "%i", &temp);
+				((s32 *)buffer)[count++] = (s32)temp;
+			} while (1);
+			buffer_len = count * sizeof(s32);
 
-			case IW_PRIV_TYPE_CHAR:
-				if (len > 0)
-				{
-					/* Size of the string to fetch */
-					wdata.data.length = len;
-					if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
-						wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
+			/* Number of args to fetch */
+			wdata.data.length = count;
+			if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
+				wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
 
-					/* Fetch string */
-					_rtw_memcpy(buffer, ptr, wdata.data.length);
-				}
-				else
-				{
-					wdata.data.length = 1;
-					buffer[0] = '\0';
-				}
-				buffer_len = wdata.data.length;
-				break;
+			break;
 
-			default:
-				DBG_8192C("%s: Not yet implemented...\n", __func__);
-				err = -1;
-				goto exit;
+		case IW_PRIV_TYPE_CHAR:
+			if (len > 0) {
+				/* Size of the string to fetch */
+				wdata.data.length = len;
+				if (wdata.data.length > (priv_args[k].set_args & IW_PRIV_SIZE_MASK))
+					wdata.data.length = priv_args[k].set_args & IW_PRIV_SIZE_MASK;
+
+				/* Fetch string */
+				_rtw_memcpy(buffer, ptr, wdata.data.length);
+			} else {
+				wdata.data.length = 1;
+				buffer[0] = '\0';
+			}
+			buffer_len = wdata.data.length;
+			break;
+
+		default:
+			RTW_INFO("%s: Not yet implemented...\n", __func__);
+			err = -1;
+			goto exit;
 		}
 
 		if ((priv_args[k].set_args & IW_PRIV_SIZE_FIXED) &&
-			(wdata.data.length != (priv_args[k].set_args & IW_PRIV_SIZE_MASK)))
-		{
-			DBG_8192C("%s: The command %s needs exactly %d argument(s)...\n",
-					__func__, cmdname, priv_args[k].set_args & IW_PRIV_SIZE_MASK);
+		    (wdata.data.length != (priv_args[k].set_args & IW_PRIV_SIZE_MASK))) {
+			RTW_INFO("%s: The command %s needs exactly %d argument(s)...\n",
+				__func__, cmdname, priv_args[k].set_args & IW_PRIV_SIZE_MASK);
 			err = -EINVAL;
 			goto exit;
 		}
 	}   /* if args to set */
 	else
-	{
 		wdata.data.length = 0L;
-	}
 
 	/* Those two tests are important. They define how the driver
 	* will have to handle the data */
 	if ((priv_args[k].set_args & IW_PRIV_SIZE_FIXED) &&
-		((get_priv_size(priv_args[k].set_args) + offset) <= IFNAMSIZ))
-	{
+	    ((get_priv_size(priv_args[k].set_args) + offset) <= IFNAMSIZ)) {
 		/* First case : all SET args fit within wrq */
 		if (offset)
 			wdata.mode = subcmd;
 		_rtw_memcpy(wdata.name + offset, buffer, IFNAMSIZ - offset);
-	}
-	else
-	{
+	} else {
 		if ((priv_args[k].set_args == 0) &&
-			(priv_args[k].get_args & IW_PRIV_SIZE_FIXED) &&
-			(get_priv_size(priv_args[k].get_args) <= IFNAMSIZ))
-		{
+		    (priv_args[k].get_args & IW_PRIV_SIZE_FIXED) &&
+		    (get_priv_size(priv_args[k].get_args) <= IFNAMSIZ)) {
 			/* Second case : no SET args, GET args fit within wrq */
 			if (offset)
 				wdata.mode = subcmd;
-		}
-		else
-		{
+		} else {
 			/* Third case : args won't fit in wrq, or variable number of args */
 			if (copy_to_user(wdata.data.pointer, buffer, buffer_len)) {
 				err = -EFAULT;
@@ -13767,14 +12674,13 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 	input = NULL;
 
 	extra_size = 0;
-	if (IW_IS_SET(priv_args[k].cmd))
-	{
+	if (IW_IS_SET(priv_args[k].cmd)) {
 		/* Size of set arguments */
 		extra_size = get_priv_size(priv_args[k].set_args);
 
 		/* Does it fits in iwr ? */
 		if ((priv_args[k].set_args & IW_PRIV_SIZE_FIXED) &&
-			((extra_size + offset) <= IFNAMSIZ))
+		    ((extra_size + offset) <= IFNAMSIZ))
 			extra_size = 0;
 	} else {
 		/* Size of get arguments */
@@ -13782,12 +12688,12 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 
 		/* Does it fits in iwr ? */
 		if ((priv_args[k].get_args & IW_PRIV_SIZE_FIXED) &&
-			(extra_size <= IFNAMSIZ))
+		    (extra_size <= IFNAMSIZ))
 			extra_size = 0;
 	}
 
 	if (extra_size == 0) {
-		extra = (u8*)&wdata;
+		extra = (u8 *)&wdata;
 		rtw_mfree(buffer, 4096);
 		buffer = NULL;
 	} else
@@ -13798,15 +12704,14 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 
 	/* If we have to get some data */
 	if ((priv_args[k].get_args & IW_PRIV_TYPE_MASK) &&
-		(priv_args[k].get_args & IW_PRIV_SIZE_MASK))
-	{
+	    (priv_args[k].get_args & IW_PRIV_SIZE_MASK)) {
 		int j;
 		int n = 0;	/* number of args */
 		u8 str[20] = {0};
 
 		/* Check where is the returned data */
 		if ((priv_args[k].get_args & IW_PRIV_SIZE_FIXED) &&
-			(get_priv_size(priv_args[k].get_args) <= IFNAMSIZ))
+		    (get_priv_size(priv_args[k].get_args) <= IFNAMSIZ))
 			n = priv_args[k].get_args & IW_PRIV_SIZE_MASK;
 		else
 			n = wdata.data.length;
@@ -13817,47 +12722,44 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 			goto exit;
 		}
 
-		switch (priv_args[k].get_args & IW_PRIV_TYPE_MASK)
-		{
-			case IW_PRIV_TYPE_BYTE:
-				/* Display args */
-				for (j = 0; j < n; j++)
-				{
-					sprintf(str, "%d  ", extra[j]);
-					len = strlen(str);
-					output_len = strlen(output);
-					if ((output_len + len + 1) > 4096) {
-						err = -E2BIG;
-						goto exit;
-					}
-					_rtw_memcpy(output+output_len, str, len);
+		switch (priv_args[k].get_args & IW_PRIV_TYPE_MASK) {
+		case IW_PRIV_TYPE_BYTE:
+			/* Display args */
+			for (j = 0; j < n; j++) {
+				sprintf(str, "%d  ", extra[j]);
+				len = strlen(str);
+				output_len = strlen(output);
+				if ((output_len + len + 1) > 4096) {
+					err = -E2BIG;
+					goto exit;
 				}
-				break;
+				_rtw_memcpy(output + output_len, str, len);
+			}
+			break;
 
-			case IW_PRIV_TYPE_INT:
-				/* Display args */
-				for (j = 0; j < n; j++)
-				{
-					sprintf(str, "%d  ", ((__s32*)extra)[j]);
-					len = strlen(str);
-					output_len = strlen(output);
-					if ((output_len + len + 1) > 4096) {
-						err = -E2BIG;
-						goto exit;
-					}
-					_rtw_memcpy(output+output_len, str, len);
+		case IW_PRIV_TYPE_INT:
+			/* Display args */
+			for (j = 0; j < n; j++) {
+				sprintf(str, "%d  ", ((__s32 *)extra)[j]);
+				len = strlen(str);
+				output_len = strlen(output);
+				if ((output_len + len + 1) > 4096) {
+					err = -E2BIG;
+					goto exit;
 				}
-				break;
+				_rtw_memcpy(output + output_len, str, len);
+			}
+			break;
 
-			case IW_PRIV_TYPE_CHAR:
-				/* Display args */
-				_rtw_memcpy(output, extra, n);
-				break;
+		case IW_PRIV_TYPE_CHAR:
+			/* Display args */
+			_rtw_memcpy(output, extra, n);
+			break;
 
-			default:
-				DBG_8192C("%s: Not yet implemented...\n", __func__);
-				err = -1;
-				goto exit;
+		default:
+			RTW_INFO("%s: Not yet implemented...\n", __func__);
+			err = -1;
+			goto exit;
 		}
 
 		output_len = strlen(output) + 1;
@@ -13868,9 +12770,7 @@ static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq
 		}
 	}   /* if args to set */
 	else
-	{
 		wrq_data->data.length = 0;
-	}
 
 exit:
 	if (input)
@@ -13889,10 +12789,10 @@ static int rtw_ioctl_compat_wext_private(struct net_device *dev, struct ifreq *r
 	struct compat_iw_point iwp_compat;
 	union iwreq_data wrq_data;
 	int err = 0;
-	DBG_871X("%s:...\n", __func__);
+	RTW_INFO("%s:...\n", __func__);
 	if (copy_from_user(&iwp_compat, rq->ifr_ifru.ifru_data, sizeof(struct compat_iw_point)))
-			return -EFAULT;
-	
+		return -EFAULT;
+
 	wrq_data.data.pointer = compat_ptr(iwp_compat.pointer);
 	wrq_data.data.length = iwp_compat.length;
 	wrq_data.data.flags = iwp_compat.flags;
@@ -13903,11 +12803,11 @@ static int rtw_ioctl_compat_wext_private(struct net_device *dev, struct ifreq *r
 	iwp_compat.length = wrq_data.data.length;
 	iwp_compat.flags = wrq_data.data.flags;
 	if (copy_to_user(rq->ifr_ifru.ifru_data, &iwp_compat, sizeof(struct compat_iw_point)))
-			return -EFAULT;
+		return -EFAULT;
 
 	return err;
 }
-#endif // CONFIG_COMPAT
+#endif /* CONFIG_COMPAT */
 
 static int rtw_ioctl_standard_wext_private(struct net_device *dev, struct ifreq *rq)
 {
@@ -13916,7 +12816,7 @@ static int rtw_ioctl_standard_wext_private(struct net_device *dev, struct ifreq
 	union iwreq_data wrq_data;
 	int err = 0;
 	iwp = &wrq_data.data;
-	DBG_871X("%s:...\n", __func__);
+	RTW_INFO("%s:...\n", __func__);
 	if (copy_from_user(iwp, rq->ifr_ifru.ifru_data, sizeof(struct iw_point)))
 		return -EFAULT;
 
@@ -13927,49 +12827,50 @@ static int rtw_ioctl_standard_wext_private(struct net_device *dev, struct ifreq
 
 	return err;
 }
- 
+
 static int rtw_ioctl_wext_private(struct net_device *dev, struct ifreq *rq)
 {
 #ifdef CONFIG_COMPAT
-	if(is_compat_task())
-		return rtw_ioctl_compat_wext_private( dev, rq );
+#if (KERNEL_VERSION(4, 6, 0) > LINUX_VERSION_CODE)
+	if (is_compat_task())
+#else
+	if (in_compat_syscall())
+#endif
+		return rtw_ioctl_compat_wext_private(dev, rq);
 	else
-#endif // CONFIG_COMPAT
-		return rtw_ioctl_standard_wext_private( dev, rq );
+#endif /* CONFIG_COMPAT */
+		return rtw_ioctl_standard_wext_private(dev, rq);
 }
 
 int rtw_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
 {
 	struct iwreq *wrq = (struct iwreq *)rq;
-	int ret=0;
+	int ret = 0;
 
-	switch (cmd)
-	{
-		case RTL_IOCTL_WPA_SUPPLICANT:
-			ret = wpa_supplicant_ioctl(dev, &wrq->u.data);
-			break;
+	switch (cmd) {
+	case RTL_IOCTL_WPA_SUPPLICANT:
+		ret = wpa_supplicant_ioctl(dev, &wrq->u.data);
+		break;
 #ifdef CONFIG_AP_MODE
-		case RTL_IOCTL_HOSTAPD:
-			ret = rtw_hostapd_ioctl(dev, &wrq->u.data);
-			break;
+	case RTL_IOCTL_HOSTAPD:
+		ret = rtw_hostapd_ioctl(dev, &wrq->u.data);
+		break;
 #ifdef CONFIG_WIRELESS_EXT
-		case SIOCSIWMODE:
-			ret = rtw_wx_set_mode(dev, NULL, &wrq->u, NULL);
-			break;
+	case SIOCSIWMODE:
+		ret = rtw_wx_set_mode(dev, NULL, &wrq->u, NULL);
+		break;
 #endif
-#endif // CONFIG_AP_MODE
-		case SIOCDEVPRIVATE:				
-			 ret = rtw_ioctl_wext_private(dev, rq);
-			break;
-		case (SIOCDEVPRIVATE+1):
-			ret = rtw_android_priv_cmd(dev, rq, cmd);
-			break;
-		default:
-			ret = -EOPNOTSUPP;
-			break;
+#endif /* CONFIG_AP_MODE */
+	case SIOCDEVPRIVATE:
+		ret = rtw_ioctl_wext_private(dev, rq);
+		break;
+	case (SIOCDEVPRIVATE+1):
+		ret = rtw_android_priv_cmd(dev, rq, cmd);
+		break;
+	default:
+		ret = -EOPNOTSUPP;
+		break;
 	}
 
 	return ret;
 }
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_mp.c
index 2737c7148369..0e482ebeda72 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/ioctl_mp.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #if defined(CONFIG_MP_INCLUDED)
 
 #include <drv_types.h>
@@ -26,7 +22,7 @@
 
 
 #if defined(CONFIG_RTL8723B)
-#include <rtw_bt_mp.h>
+	#include <rtw_bt_mp.h>
 #endif
 
 /*
@@ -39,8 +35,8 @@
  *	2st %d is data to write
  */
 int rtw_mp_write_reg(struct net_device *dev,
-					 struct iw_request_info *info,
-					 struct iw_point *wrqu, char *extra)
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
 {
 	char *pch, *pnext, *ptmp;
 	char *width_str;
@@ -48,11 +44,15 @@ int rtw_mp_write_reg(struct net_device *dev,
 	u32 addr, data;
 	int ret;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	char input[wrqu->length];
+	char input[wrqu->length + 1];
+
+	_rtw_memset(input, 0, sizeof(input));
 
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
+	input[wrqu->length] = '\0';
+
 	_rtw_memset(extra, 0, wrqu->length);
 
 	pch = input;
@@ -82,7 +82,7 @@ int rtw_mp_write_reg(struct net_device *dev,
 		return -EINVAL;
 	/*data = simple_strtoul(pch, &ptmp, 16);*/
 	ret = sscanf(pch, "%x", &data);
-	DBG_871X("data=%x,addr=%x\n", (u32)data, (u32)addr);
+	RTW_INFO("data=%x,addr=%x\n", (u32)data, (u32)addr);
 	ret = 0;
 	width = width_str[0];
 	switch (width) {
@@ -127,10 +127,10 @@ int rtw_mp_write_reg(struct net_device *dev,
  *	%d for data readed
  */
 int rtw_mp_read_reg(struct net_device *dev,
-					struct iw_request_info *info,
-					struct iw_point *wrqu, char *extra)
+		    struct iw_request_info *info,
+		    struct iw_point *wrqu, char *extra)
 {
-	char input[wrqu->length];
+	char input[wrqu->length + 1];
 	char *pch, *pnext, *ptmp;
 	char *width_str;
 	char width;
@@ -138,14 +138,16 @@ int rtw_mp_read_reg(struct net_device *dev,
 	u32 addr = 0, strtout = 0;
 	u32 i = 0, j = 0, ret = 0, data32 = 0;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-
+	char *pextra = extra;
 
 	if (wrqu->length > 128)
 		return -EFAULT;
 
+	_rtw_memset(input, 0, sizeof(input));
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
+	input[wrqu->length] = '\0';
 	_rtw_memset(extra, 0, wrqu->length);
 	_rtw_memset(data, '\0', sizeof(data));
 	_rtw_memset(tmp, '\0', sizeof(tmp));
@@ -167,82 +169,82 @@ int rtw_mp_read_reg(struct net_device *dev,
 
 	switch (width) {
 	case 'b':
-			data32 = rtw_read8(padapter, addr);
-			DBG_871X("%x\n", data32);
-			sprintf(extra, "%d", data32);
-			wrqu->length = strlen(extra);
-			break;
+		data32 = rtw_read8(padapter, addr);
+		RTW_INFO("%x\n", data32);
+		sprintf(extra, "%d", data32);
+		wrqu->length = strlen(extra);
+		break;
 	case 'w':
-			/* 2 bytes*/
-			sprintf(data, "%04x\n", rtw_read16(padapter, addr));
-
-			for (i = 0 ; i <= strlen(data) ; i++) {
-				if (i % 2 == 0) {
-					tmp[j] = ' ';
-					j++;
-				}
-				if (data[i] != '\0')
-					tmp[j] = data[i];
+		/* 2 bytes*/
+		sprintf(data, "%04x\n", rtw_read16(padapter, addr));
 
+		for (i = 0 ; i <= strlen(data) ; i++) {
+			if (i % 2 == 0) {
+				tmp[j] = ' ';
 				j++;
 			}
-			pch = tmp;
-			DBG_871X("pch=%s", pch);
-
-			while (*pch != '\0') {
-				pnext = strpbrk(pch, " ");
-				if (!pnext || ((pnext - tmp) > 4))
-					break;
-					
-				pnext++;
-				if (*pnext != '\0') {
-					/*strtout = simple_strtoul(pnext , &ptmp, 16);*/
-					ret = sscanf(pnext, "%x", &strtout);
-					sprintf(extra, "%s %d" , extra , strtout);
-				} else
-					break;
-				pch = pnext;
-			}
-			wrqu->length = strlen(extra);
-			break;
-	case 'd':
-			/* 4 bytes */
-			sprintf(data, "%08x", rtw_read32(padapter, addr));
-			/*add read data format blank*/
-			for (i = 0 ; i <= strlen(data) ; i++) {
-				if (i % 2 == 0) {
-					tmp[j] = ' ';
-					j++;
-				}
-				if (data[i] != '\0')
-					tmp[j] = data[i];
+			if (data[i] != '\0')
+				tmp[j] = data[i];
+
+			j++;
+		}
+		pch = tmp;
+		RTW_INFO("pch=%s", pch);
+
+		while (*pch != '\0') {
+			pnext = strpbrk(pch, " ");
+			if (!pnext || ((pnext - tmp) > 4))
+				break;
 
+			pnext++;
+			if (*pnext != '\0') {
+				/*strtout = simple_strtoul(pnext , &ptmp, 16);*/
+				ret = sscanf(pnext, "%x", &strtout);
+				pextra += sprintf(pextra, " %d", strtout);
+			} else
+				break;
+			pch = pnext;
+		}
+		wrqu->length = strlen(extra);
+		break;
+	case 'd':
+		/* 4 bytes */
+		sprintf(data, "%08x", rtw_read32(padapter, addr));
+		/*add read data format blank*/
+		for (i = 0 ; i <= strlen(data) ; i++) {
+			if (i % 2 == 0) {
+				tmp[j] = ' ';
 				j++;
 			}
-			pch = tmp;
-			DBG_871X("pch=%s", pch);
-
-			while (*pch != '\0') {
-				pnext = strpbrk(pch, " ");
-				if (!pnext)
-					break;
-
-				pnext++;
-				if (*pnext != '\0') {
-					ret = sscanf(pnext, "%x", &strtout);
-					sprintf(extra, "%s %d" , extra , strtout);
-				} else
-					break;
-				pch = pnext;
-			}
-			wrqu->length = strlen(extra);
-			break;
+			if (data[i] != '\0')
+				tmp[j] = data[i];
 
-	default:
-			wrqu->length = 0;
-			ret = -EINVAL;
-			break;
+			j++;
 		}
+		pch = tmp;
+		RTW_INFO("pch=%s", pch);
+
+		while (*pch != '\0') {
+			pnext = strpbrk(pch, " ");
+			if (!pnext)
+				break;
+
+			pnext++;
+			if (*pnext != '\0') {
+				ret = sscanf(pnext, "%x", &strtout);
+				pextra += sprintf(pextra, " %d", strtout);
+			} else
+				break;
+			pch = pnext;
+		}
+		wrqu->length = strlen(extra);
+		break;
+
+	default:
+		wrqu->length = 0;
+		ret = -EINVAL;
+		break;
+	}
 
 	return ret;
 }
@@ -255,8 +257,8 @@ int rtw_mp_read_reg(struct net_device *dev,
  *	2st %x is data to write
  */
 int rtw_mp_write_rf(struct net_device *dev,
-					struct iw_request_info *info,
-					struct iw_point *wrqu, char *extra)
+		    struct iw_request_info *info,
+		    struct iw_point *wrqu, char *extra)
 {
 
 	u32 path, addr, data;
@@ -301,8 +303,8 @@ int rtw_mp_write_rf(struct net_device *dev,
  *	%d for data readed
  */
 int rtw_mp_read_rf(struct net_device *dev,
-				   struct iw_request_info *info,
-				   struct iw_point *wrqu, char *extra)
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
 {
 	char input[wrqu->length];
 	char *pch, *pnext, *ptmp;
@@ -310,7 +312,8 @@ int rtw_mp_read_rf(struct net_device *dev,
 	u32 path, addr, strtou;
 	u32 ret, i = 0 , j = 0;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	
+	char *pextra = extra;
+
 	if (wrqu->length > 128)
 		return -EFAULT;
 	_rtw_memset(input, 0, wrqu->length);
@@ -339,7 +342,7 @@ int rtw_mp_read_rf(struct net_device *dev,
 		j++;
 	}
 	pch = tmp;
-	DBG_871X("pch=%s", pch);
+	RTW_INFO("pch=%s", pch);
 
 	while (*pch != '\0') {
 		pnext = strpbrk(pch, " ");
@@ -349,7 +352,7 @@ int rtw_mp_read_rf(struct net_device *dev,
 		if (*pnext != '\0') {
 			/*strtou =simple_strtoul(pnext , &ptmp, 16);*/
 			ret = sscanf(pnext, "%x", &strtou);
-			sprintf(extra, "%s %d" , extra , strtou);
+			pextra += sprintf(pextra, " %d", strtou);
 		} else
 			break;
 		pch = pnext;
@@ -361,98 +364,66 @@ int rtw_mp_read_rf(struct net_device *dev,
 
 
 int rtw_mp_start(struct net_device *dev,
-				 struct iw_request_info *info,
-				 struct iw_point *wrqu, char *extra)
+		 struct iw_request_info *info,
+		 struct iw_point *wrqu, char *extra)
 {
+	int ret = 0;
 	u8 val8;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
-	u8 rfreg0;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 
 	rtw_pm_set_ips(padapter, IPS_NONE);
 	LeaveAllPowerSaveMode(padapter);
 
-	if (padapter->registrypriv.mp_mode == 0) {
-		rtw_hal_deinit(padapter);
-		padapter->registrypriv.mp_mode = 1;
-		#ifdef CONFIG_RF_GAIN_OFFSET
-		if (!IS_HARDWARE_TYPE_8814A(padapter))
-			padapter->registrypriv.RegRfKFreeEnable = 1;
-		rtw_hal_read_chip_info(padapter);
-		#endif /*CONFIG_RF_GAIN_OFFSET*/
-		rtw_hal_init(padapter);
-	}
-
-	if (padapter->registrypriv.mp_mode == 0)
-		return -EPERM;
+	if (rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY))
+		rtw_mi_scan_abort(padapter, _FALSE);
 
-	if (padapter->mppriv.mode == MP_OFF) {
-		if (mp_start_test(padapter) == _FAIL)
-			return -EPERM;
-		padapter->mppriv.mode = MP_ON;
-		MPT_PwrCtlDM(padapter, 0);
-	}
-	padapter->mppriv.bmac_filter = _FALSE;
-#ifdef CONFIG_RTL8723B
-#ifdef CONFIG_USB_HCI
-	rtw_write32(padapter, 0x765, 0x0000);
-	rtw_write32(padapter, 0x948, 0x0280);
-#else
-	rtw_write32(padapter, 0x765, 0x0000);
-	rtw_write32(padapter, 0x948, 0x0000);
-#endif
-#ifdef CONFIG_FOR_RTL8723BS_VQ0
-	rtw_write32(padapter, 0x765, 0x0000);
-	rtw_write32(padapter, 0x948, 0x0280);
-#endif
-	rtw_write8(padapter, 0x66, 0x27); /*Open BT uart Log*/
-	rtw_write8(padapter, 0xc50, 0x20); /*for RX init Gain*/
-#endif
+	if (rtw_mp_cmd(padapter, MP_START, RTW_CMDF_WAIT_ACK) != _SUCCESS)
+		ret = -EPERM;
 
-	ODM_Write_DIG(&pHalData->odmpriv, 0x20);
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "mp_start %s\n", ret == 0 ? "ok" : "fail");
+	wrqu->length = strlen(extra);
 
-	return 0;
+	return ret;
 }
 
 
 
 int rtw_mp_stop(struct net_device *dev,
-				struct iw_request_info *info,
-				struct iw_point *wrqu, char *extra)
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra)
 {
+	int ret = 0;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 
-	if (padapter->registrypriv.mp_mode == 1) {
+	if (rtw_mp_cmd(padapter, MP_STOP, RTW_CMDF_WAIT_ACK) != _SUCCESS)
+		ret = -EPERM;
 
-		MPT_DeInitAdapter(padapter);
-		pHalFunc->hal_deinit(padapter);
-		padapter->registrypriv.mp_mode = 0;
-		pHalFunc->hal_init(padapter);
-	}
-
-	if (padapter->mppriv.mode != MP_OFF) {
-		mp_stop_test(padapter);
-		padapter->mppriv.mode = MP_OFF;
-	}
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "mp_stop %s\n", ret == 0 ? "ok" : "fail");
+	wrqu->length = strlen(extra);
 
-	return 0;
+	return ret;
 }
 
 
 int rtw_mp_rate(struct net_device *dev,
-				struct iw_request_info *info,
-				struct iw_point *wrqu, char *extra)
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra)
 {
 	u32 rate = MPT_RATE_1M;
-	u8		input[wrqu->length];
+	u8		input[wrqu->length + 1];
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.MptCtx);
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
 
+	_rtw_memset(input, 0, sizeof(input));
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
+	input[wrqu->length] = '\0';
 	rate = rtw_mpRateParseFunc(padapter, input);
 	padapter->mppriv.rateidx = rate;
 
@@ -474,12 +445,12 @@ int rtw_mp_rate(struct net_device *dev,
 	_rtw_memset(extra, 0, wrqu->length);
 
 	sprintf(extra, "Set data rate to %s index %d" , input, padapter->mppriv.rateidx);
-	DBG_871X("%s: %s rate index=%d\n", __func__, input, padapter->mppriv.rateidx);
+	RTW_INFO("%s: %s rate index=%d\n", __func__, input, padapter->mppriv.rateidx);
 
 	if (padapter->mppriv.rateidx >= DESC_RATEVHTSS4MCS9)
 		return -EINVAL;
 
-	pMptCtx->MptRateIndex = HwRateToMPTRate(padapter->mppriv.rateidx);
+	pMptCtx->mpt_rate_index = HwRateToMPTRate(padapter->mppriv.rateidx);
 	SetDataRate(padapter);
 
 	wrqu->length = strlen(extra);
@@ -488,26 +459,55 @@ int rtw_mp_rate(struct net_device *dev,
 
 
 int rtw_mp_channel(struct net_device *dev,
-				   struct iw_request_info *info,
-				   struct iw_point *wrqu, char *extra)
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
 {
 
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
-	u8		input[wrqu->length];
+	u8		input[wrqu->length + 1];
 	u32	channel = 1;
 	int cur_ch_offset;
 
+	_rtw_memset(input, 0, sizeof(input));
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
+	input[wrqu->length] = '\0';
 	channel = rtw_atoi(input);
-	/*DBG_871X("%s: channel=%d\n", __func__, channel);*/
+	/*RTW_INFO("%s: channel=%d\n", __func__, channel);*/
 	_rtw_memset(extra, 0, wrqu->length);
 	sprintf(extra, "Change channel %d to channel %d", padapter->mppriv.channel , channel);
 	padapter->mppriv.channel = channel;
 	SetChannel(padapter);
-	pHalData->CurrentChannel = channel;
+	pHalData->current_channel = channel;
+
+	wrqu->length = strlen(extra);
+	return 0;
+}
+
+
+int rtw_mp_ch_offset(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	u8		input[wrqu->length + 1];
+	u32	ch_offset = 0;
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	ch_offset = rtw_atoi(input);
+	/*RTW_INFO("%s: channel=%d\n", __func__, channel);*/
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "Change prime channel offset %d to %d", padapter->mppriv.prime_channel_offset , ch_offset);
+	padapter->mppriv.prime_channel_offset = ch_offset;
+	SetChannel(padapter);
 
 	wrqu->length = strlen(extra);
 	return 0;
@@ -515,16 +515,20 @@ int rtw_mp_channel(struct net_device *dev,
 
 
 int rtw_mp_bandwidth(struct net_device *dev,
-					 struct iw_request_info *info,
-					 struct iw_point *wrqu, char *extra)
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
 {
 	u32 bandwidth = 0, sg = 0;
 	int cur_ch_offset;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	u8		input[wrqu->length];
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
 
-	if (sscanf(extra, "40M=%d,shortGI=%d", &bandwidth, &sg) > 0)
-		DBG_871X("%s: bw=%d sg=%d\n", __func__, bandwidth , sg);
+	if (sscanf(input, "40M=%d,shortGI=%d", &bandwidth, &sg) > 0)
+		RTW_INFO("%s: bw=%d sg=%d\n", __func__, bandwidth , sg);
 
 	if (bandwidth == 1)
 		bandwidth = CHANNEL_WIDTH_40;
@@ -533,31 +537,37 @@ int rtw_mp_bandwidth(struct net_device *dev,
 
 	padapter->mppriv.bandwidth = (u8)bandwidth;
 	padapter->mppriv.preamble = sg;
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "Change BW %d to BW %d\n", pHalData->current_channel_bw , bandwidth);
 
 	SetBandwidth(padapter);
-	pHalData->CurrentChannelBW = bandwidth;
-	/*cur_ch_offset =  rtw_get_offset_by_ch(padapter->mppriv.channel);*/
-	/*set_channel_bwmode(padapter, padapter->mppriv.channel, cur_ch_offset, bandwidth);*/
+	pHalData->current_channel_bw = bandwidth;
+
+	wrqu->length = strlen(extra);
 
 	return 0;
 }
 
 
 int rtw_mp_txpower_index(struct net_device *dev,
-						 struct iw_request_info *info,
-						 struct iw_point *wrqu, char *extra)
+			 struct iw_request_info *info,
+			 struct iw_point *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	char input[wrqu->length];
+	char input[wrqu->length + 1];
 	u32 rfpath;
 	u32 txpower_inx;
 
 	if (wrqu->length > 128)
 		return -EFAULT;
 
+	_rtw_memset(input, 0, sizeof(input));
+
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
+	input[wrqu->length] = '\0';
+
 	rfpath = rtw_atoi(input);
 	txpower_inx = mpt_ProQueryCalTxPower(padapter, rfpath);
 	sprintf(extra, " %d", txpower_inx);
@@ -568,15 +578,15 @@ int rtw_mp_txpower_index(struct net_device *dev,
 
 
 int rtw_mp_txpower(struct net_device *dev,
-				   struct iw_request_info *info,
-				   struct iw_point *wrqu, char *extra)
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
 {
 	u32 idx_a = 0, idx_b = 0, idx_c = 0, idx_d = 0, status = 0;
 	int MsetPower = 1;
 	u8		input[wrqu->length];
 
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.MptCtx);
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
 
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
@@ -587,15 +597,15 @@ int rtw_mp_txpower(struct net_device *dev,
 		sprintf(extra, "MP Set power off");
 	} else {
 		if (sscanf(input, "patha=%d,pathb=%d,pathc=%d,pathd=%d", &idx_a, &idx_b, &idx_c, &idx_d) < 3)
-			DBG_871X("Invalid format on line %s ,patha=%d,pathb=%d,pathc=%d,pathd=%d\n", input , idx_a , idx_b , idx_c , idx_d);
+			RTW_INFO("Invalid format on line %s ,patha=%d,pathb=%d,pathc=%d,pathd=%d\n", input , idx_a , idx_b , idx_c , idx_d);
 
 		sprintf(extra, "Set power level path_A:%d path_B:%d path_C:%d path_D:%d", idx_a , idx_b , idx_c , idx_d);
 		padapter->mppriv.txpoweridx = (u8)idx_a;
 
-		pMptCtx->TxPwrLevel[ODM_RF_PATH_A] = (u8)idx_a;
-		pMptCtx->TxPwrLevel[ODM_RF_PATH_B] = (u8)idx_b;
-		pMptCtx->TxPwrLevel[ODM_RF_PATH_C] = (u8)idx_c;
-		pMptCtx->TxPwrLevel[ODM_RF_PATH_D]  = (u8)idx_d;
+		pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)idx_a;
+		pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)idx_b;
+		pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)idx_c;
+		pMptCtx->TxPwrLevel[RF_PATH_D]  = (u8)idx_d;
 		padapter->mppriv.bSetTxPower = 1;
 
 		SetTxPower(padapter);
@@ -607,18 +617,20 @@ int rtw_mp_txpower(struct net_device *dev,
 
 
 int rtw_mp_ant_tx(struct net_device *dev,
-				  struct iw_request_info *info,
-				  struct iw_point *wrqu, char *extra)
+		  struct iw_request_info *info,
+		  struct iw_point *wrqu, char *extra)
 {
 	u8 i;
-	u8		input[wrqu->length];
+	u8		input[wrqu->length + 1];
 	u16 antenna = 0;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
+	_rtw_memset(input, 0, sizeof(input));
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
+	input[wrqu->length] = '\0';
 	sprintf(extra, "switch Tx antenna to %s", input);
 
 	for (i = 0; i < strlen(input); i++) {
@@ -638,11 +650,11 @@ int rtw_mp_ant_tx(struct net_device *dev,
 		}
 	}
 	/*antenna |= BIT(extra[i]-'a');*/
-	DBG_871X("%s: antenna=0x%x\n", __func__, antenna);
+	RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
 	padapter->mppriv.antenna_tx = antenna;
 	padapter->mppriv.antenna_rx = antenna;
-	/*DBG_871X("%s:mppriv.antenna_rx=%d\n", __func__, padapter->mppriv.antenna_tx);*/
-	pHalData->AntennaTxPath = antenna;
+	/*RTW_INFO("%s:mppriv.antenna_rx=%d\n", __func__, padapter->mppriv.antenna_tx);*/
+	pHalData->antenna_tx_path = antenna;
 
 	SetAntenna(padapter);
 
@@ -652,18 +664,21 @@ int rtw_mp_ant_tx(struct net_device *dev,
 
 
 int rtw_mp_ant_rx(struct net_device *dev,
-				  struct iw_request_info *info,
-				  struct iw_point *wrqu, char *extra)
+		  struct iw_request_info *info,
+		  struct iw_point *wrqu, char *extra)
 {
 	u8 i;
 	u16 antenna = 0;
-	u8		input[wrqu->length];
+	u8		input[wrqu->length + 1];
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
+	_rtw_memset(input, 0, sizeof(input));
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
-	/*DBG_871X("%s: input=%s\n", __func__, input);*/
+
+	input[wrqu->length] = '\0';
+	/*RTW_INFO("%s: input=%s\n", __func__, input);*/
 	_rtw_memset(extra, 0, wrqu->length);
 
 	sprintf(extra, "switch Rx antenna to %s", input);
@@ -685,11 +700,11 @@ int rtw_mp_ant_rx(struct net_device *dev,
 		}
 	}
 
-	DBG_871X("%s: antenna=0x%x\n", __func__, antenna);
+	RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
 	padapter->mppriv.antenna_tx = antenna;
 	padapter->mppriv.antenna_rx = antenna;
 	pHalData->AntennaRxPath = antenna;
-	/*DBG_871X("%s:mppriv.antenna_rx=%d\n", __func__, padapter->mppriv.antenna_rx);*/
+	/*RTW_INFO("%s:mppriv.antenna_rx=%d\n", __func__, padapter->mppriv.antenna_rx);*/
 	SetAntenna(padapter);
 	wrqu->length = strlen(extra);
 
@@ -698,34 +713,34 @@ int rtw_mp_ant_rx(struct net_device *dev,
 
 
 int rtw_set_ctx_destAddr(struct net_device *dev,
-						 struct iw_request_info *info,
-						 struct iw_point *wrqu, char *extra)
+			 struct iw_request_info *info,
+			 struct iw_point *wrqu, char *extra)
 {
 	int jj, kk = 0;
 
 	struct pkt_attrib *pattrib;
 	struct mp_priv *pmp_priv;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	
+
 	pmp_priv = &padapter->mppriv;
 	pattrib = &pmp_priv->tx.attrib;
 
 	if (strlen(extra) < 5)
 		return _FAIL;
 
-	DBG_871X("%s: in=%s\n", __func__, extra);
+	RTW_INFO("%s: in=%s\n", __func__, extra);
 	for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
 		pattrib->dst[jj] = key_2char2num(extra[kk], extra[kk + 1]);
 
-	DBG_871X("pattrib->dst:%x %x %x %x %x %x\n", pattrib->dst[0], pattrib->dst[1], pattrib->dst[2], pattrib->dst[3], pattrib->dst[4], pattrib->dst[5]);
+	RTW_INFO("pattrib->dst:%x %x %x %x %x %x\n", pattrib->dst[0], pattrib->dst[1], pattrib->dst[2], pattrib->dst[3], pattrib->dst[4], pattrib->dst[5]);
 	return 0;
 }
 
 
 
 int rtw_mp_ctx(struct net_device *dev,
-			   struct iw_request_info *info,
-			   struct iw_point *wrqu, char *extra)
+	       struct iw_request_info *info,
+	       struct iw_point *wrqu, char *extra)
 {
 	u32 pkTx = 1;
 	int countPkTx = 1, cotuTx = 1, CarrSprTx = 1, scTx = 1, sgleTx = 1, stop = 1;
@@ -743,9 +758,10 @@ int rtw_mp_ctx(struct net_device *dev,
 	if (copy_from_user(extra, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
-	DBG_871X("%s: in=%s\n", __func__, extra);
+	*(extra + wrqu->length) = '\0';
+	RTW_INFO("%s: in=%s\n", __func__, extra);
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->adapter_type == SECONDARY_ADAPTER) {
+	if (!is_primary_adapter(padapter)) {
 		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
 		wrqu->length = strlen(extra);
 		return 0;
@@ -759,12 +775,12 @@ int rtw_mp_ctx(struct net_device *dev,
 	pkTx = strncmp(extra, "background,pkt", 20);
 	stop = strncmp(extra, "stop", 4);
 	if (sscanf(extra, "count=%d,pkt", &count) > 0)
-		DBG_871X("count= %d\n", count);
+		RTW_INFO("count= %d\n", count);
 	if (sscanf(extra, "pktinterval=%d", &pktinterval) > 0)
-		DBG_871X("pktinterval= %d\n", pktinterval);
+		RTW_INFO("pktinterval= %d\n", pktinterval);
 
 	if (sscanf(extra, "pktlen=%d", &pktlen) > 0)
-		DBG_871X("pktlen= %d\n", pktlen);
+		RTW_INFO("pktlen= %d\n", pktlen);
 
 	if (_rtw_memcmp(extra, "destmac=", 8)) {
 		wrqu->length -= 8;
@@ -773,7 +789,7 @@ int rtw_mp_ctx(struct net_device *dev,
 		return 0;
 	}
 
-	/*DBG_871X("%s: count=%d countPkTx=%d cotuTx=%d CarrSprTx=%d scTx=%d sgleTx=%d pkTx=%d stop=%d\n", __func__, count, countPkTx, cotuTx, CarrSprTx, pkTx, sgleTx, scTx, stop);*/
+	/*RTW_INFO("%s: count=%d countPkTx=%d cotuTx=%d CarrSprTx=%d scTx=%d sgleTx=%d pkTx=%d stop=%d\n", __func__, count, countPkTx, cotuTx, CarrSprTx, pkTx, sgleTx, scTx, stop);*/
 	_rtw_memset(extra, '\0', strlen(extra));
 
 	if (pktinterval != 0) {
@@ -792,13 +808,13 @@ int rtw_mp_ctx(struct net_device *dev,
 		bStartTest = 0; /* To set Stop*/
 		pmp_priv->tx.stop = 1;
 		sprintf(extra, "Stop continuous Tx");
-		ODM_Write_DIG(&pHalData->odmpriv, 0x20);
+		odm_write_dig(&pHalData->odmpriv, 0x20);
 	} else {
 		bStartTest = 1;
-		ODM_Write_DIG(&pHalData->odmpriv, 0x7f);
+		odm_write_dig(&pHalData->odmpriv, 0x7f);
 		if (pmp_priv->mode != MP_ON) {
 			if (pmp_priv->tx.stop != 1) {
-				DBG_871X("%s: MP_MODE != ON %d\n", __func__, pmp_priv->mode);
+				RTW_INFO("%s: MP_MODE != ON %d\n", __func__, pmp_priv->mode);
 				return	-EFAULT;
 			}
 		}
@@ -826,36 +842,36 @@ int rtw_mp_ctx(struct net_device *dev,
 
 
 int rtw_mp_disable_bt_coexist(struct net_device *dev,
-							  struct iw_request_info *info,
-							  union iwreq_data *wrqu, char *extra)
+			      struct iw_request_info *info,
+			      union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = (PADAPTER)rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 
-	u8 input[wrqu->data.length];
+	u8 input[wrqu->data.length + 1];
 	u32 bt_coexist;
 
+	_rtw_memset(input, 0, sizeof(input));
+
 	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
 
+	input[wrqu->data.length] = '\0';
+
 	bt_coexist = rtw_atoi(input);
 
 	if (bt_coexist == 0) {
-		RT_TRACE(_module_mp_, _drv_info_,
-				 ("Set OID_RT_SET_DISABLE_BT_COEXIST: disable BT_COEXIST\n"));
-		DBG_871X("Set OID_RT_SET_DISABLE_BT_COEXIST: disable BT_COEXIST\n");
+		RTW_INFO("Set OID_RT_SET_DISABLE_BT_COEXIST: disable BT_COEXIST\n");
 #ifdef CONFIG_BT_COEXIST
 		rtw_btcoex_HaltNotify(padapter);
 		rtw_btcoex_SetManualControl(padapter, _TRUE);
 		/* Force to switch Antenna to WiFi*/
 		rtw_write16(padapter, 0x870, 0x300);
 		rtw_write16(padapter, 0x860, 0x110);
-#endif 
+#endif
 		/* CONFIG_BT_COEXIST */
 	} else {
-		RT_TRACE(_module_mp_, _drv_info_,
-				 ("Set OID_RT_SET_DISABLE_BT_COEXIST: enable BT_COEXIST\n"));
 #ifdef CONFIG_BT_COEXIST
 		rtw_btcoex_SetManualControl(padapter, _FALSE);
 #endif
@@ -866,11 +882,11 @@ int rtw_mp_disable_bt_coexist(struct net_device *dev,
 
 
 int rtw_mp_arx(struct net_device *dev,
-			   struct iw_request_info *info,
-			   struct iw_point *wrqu, char *extra)
+	       struct iw_request_info *info,
+	       struct iw_point *wrqu, char *extra)
 {
 	int bStartRx = 0, bStopRx = 0, bQueryPhy = 0, bQueryMac = 0, bSetBssid = 0;
-	int bmac_filter = 0, bfilter_init = 0, bmon = 0, bSmpCfg = 0;
+	int bmac_filter = 0, bfilter_init = 0, bmon = 0, bSmpCfg = 0, bloopbk = 0;
 	u8		input[wrqu->length];
 	char *pch, *ptmp, *token, *tmp[2] = {0x00, 0x00};
 	u32 i = 0, ii = 0, jj = 0, kk = 0, cnts = 0, ret;
@@ -881,9 +897,9 @@ int rtw_mp_arx(struct net_device *dev,
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
-	DBG_871X("%s: %s\n", __func__, input);
+	RTW_INFO("%s: %s\n", __func__, input);
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->adapter_type == SECONDARY_ADAPTER) {
+	if (!is_primary_adapter(padapter)) {
 		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
 		wrqu->length = strlen(extra);
 		return 0;
@@ -898,6 +914,7 @@ int rtw_mp_arx(struct net_device *dev,
 	bmac_filter = (strncmp(input, "accept_mac", 10) == 0) ? 1 : 0;
 	bmon = (strncmp(input, "mon=", 4) == 0) ? 1 : 0;
 	bSmpCfg = (strncmp(input , "smpcfg=" , 7) == 0) ? 1 : 0;
+	pmppriv->bloopback = (strncmp(input, "loopbk", 6) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
 
 	if (bSetBssid == 1) {
 		pch = input;
@@ -911,15 +928,15 @@ int rtw_mp_arx(struct net_device *dev,
 			cnts = strlen(tmp[1]) / 2;
 			if (cnts < 1)
 				return -EFAULT;
-			DBG_871X("%s: cnts=%d\n", __func__, cnts);
-			DBG_871X("%s: data=%s\n", __func__, tmp[1]);
+			RTW_INFO("%s: cnts=%d\n", __func__, cnts);
+			RTW_INFO("%s: data=%s\n", __func__, tmp[1]);
 			for (jj = 0, kk = 0; jj < cnts ; jj++, kk += 2) {
 				pmppriv->network_macaddr[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
-				DBG_871X("network_macaddr[%d]=%x\n", jj, pmppriv->network_macaddr[jj]);
-			} 
+				RTW_INFO("network_macaddr[%d]=%x\n", jj, pmppriv->network_macaddr[jj]);
+			}
 		} else
 			return -EFAULT;
-			
+
 		pmppriv->bSetRxBssid = _TRUE;
 	}
 
@@ -936,13 +953,13 @@ int rtw_mp_arx(struct net_device *dev,
 			cnts = strlen(tmp[1]) / 2;
 			if (cnts < 1)
 				return -EFAULT;
-			DBG_871X("%s: cnts=%d\n", __func__, cnts);
-			DBG_871X("%s: data=%s\n", __func__, tmp[1]);
+			RTW_INFO("%s: cnts=%d\n", __func__, cnts);
+			RTW_INFO("%s: data=%s\n", __func__, tmp[1]);
 			for (jj = 0, kk = 0; jj < cnts ; jj++, kk += 2) {
 				pmppriv->mac_filter[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
-				DBG_871X("%s mac_filter[%d]=%x\n", __func__, jj, pmppriv->mac_filter[jj]);
-			} 
-		} else 
+				RTW_INFO("%s mac_filter[%d]=%x\n", __func__, jj, pmppriv->mac_filter[jj]);
+			}
+		} else
 			return -EFAULT;
 
 	}
@@ -953,13 +970,14 @@ int rtw_mp_arx(struct net_device *dev,
 	} else if (bStopRx) {
 		SetPacketRx(padapter, bStartRx, _FALSE);
 		pmppriv->bmac_filter = _FALSE;
+		pmppriv->bSetRxBssid = _FALSE;
 		sprintf(extra, "Received packet OK:%d CRC error:%d ,Filter out:%d", padapter->mppriv.rx_pktcount, padapter->mppriv.rx_crcerrpktcount, padapter->mppriv.rx_pktcount_filter_out);
 	} else if (bQueryPhy) {
 		_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
 		rtw_dump_phy_rx_counters(padapter, &rx_counter);
 
-		DBG_871X("%s: OFDM_FA =%d\n", __func__, rx_counter.rx_ofdm_fa);
-		DBG_871X("%s: CCK_FA =%d\n", __func__, rx_counter.rx_cck_fa);
+		RTW_INFO("%s: OFDM_FA =%d\n", __func__, rx_counter.rx_ofdm_fa);
+		RTW_INFO("%s: CCK_FA =%d\n", __func__, rx_counter.rx_cck_fa);
 		sprintf(extra, "Phy Received packet OK:%d CRC error:%d FA Counter: %d", rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error, rx_counter.rx_cck_fa + rx_counter.rx_ofdm_fa);
 
 
@@ -967,7 +985,7 @@ int rtw_mp_arx(struct net_device *dev,
 		_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
 		rtw_dump_mac_rx_counters(padapter, &rx_counter);
 		sprintf(extra, "Mac Received packet OK: %d , CRC error: %d , Drop Packets: %d\n",
-				rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error, rx_counter.rx_pkt_drop);
+			rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error, rx_counter.rx_pkt_drop);
 
 	}
 
@@ -996,6 +1014,14 @@ int rtw_mp_arx(struct net_device *dev,
 		}
 	}
 
+	if (pmppriv->bloopback == _TRUE) {
+		sprintf(extra , "Enter MAC LoopBack mode\n");
+		_rtw_write32(padapter, 0x100, 0xB0106FF);
+		RTW_INFO("0x100 :0x%x" , _rtw_read32(padapter, 0x100));
+		_rtw_write16(padapter, 0x608, 0x30c);
+		RTW_INFO("0x100 :0x%x" , _rtw_read32(padapter, 0x608));
+	}
+
 	wrqu->length = strlen(extra) + 1;
 
 	return 0;
@@ -1003,13 +1029,19 @@ int rtw_mp_arx(struct net_device *dev,
 
 
 int rtw_mp_trx_query(struct net_device *dev,
-					 struct iw_request_info *info,
-					 struct iw_point *wrqu, char *extra)
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
 {
 	u32 txok, txfail, rxok, rxfail, rxfilterout;
 	PADAPTER padapter = rtw_netdev_priv(dev);
+	PMPT_CONTEXT	pMptCtx		=	&(padapter->mppriv.mpt_ctx);
+	RT_PMAC_TX_INFO	PMacTxInfo	=	pMptCtx->PMacTxInfo;
+
+	if (PMacTxInfo.bEnPMacTx == TRUE)
+		txok = hal_mpt_query_phytxok(padapter);
+	else
+		txok = padapter->mppriv.tx.sended;
 
-	txok = padapter->mppriv.tx.sended;
 	txfail = 0;
 	rxok = padapter->mppriv.rx_pktcount;
 	rxfail = padapter->mppriv.rx_crcerrpktcount;
@@ -1026,8 +1058,8 @@ int rtw_mp_trx_query(struct net_device *dev,
 
 
 int rtw_mp_pwrtrk(struct net_device *dev,
-				  struct iw_request_info *info,
-				  struct iw_point *wrqu, char *extra)
+		  struct iw_request_info *info,
+		  struct iw_point *wrqu, char *extra)
 {
 	u8 enable;
 	u32 thermal;
@@ -1068,15 +1100,17 @@ int rtw_mp_pwrtrk(struct net_device *dev,
 
 
 int rtw_mp_psd(struct net_device *dev,
-			   struct iw_request_info *info,
-			   struct iw_point *wrqu, char *extra)
+	       struct iw_request_info *info,
+	       struct iw_point *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	u8		input[wrqu->length];
+	u8		input[wrqu->length + 1];
 
+	_rtw_memset(input, 0, sizeof(input));
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
+	input[wrqu->length] = '\0';
 	strcpy(extra, input);
 
 	wrqu->length = mp_query_psd(padapter, extra);
@@ -1086,8 +1120,8 @@ int rtw_mp_psd(struct net_device *dev,
 
 
 int rtw_mp_thermal(struct net_device *dev,
-				   struct iw_request_info *info,
-				   struct iw_point *wrqu, char *extra)
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
 {
 	u8 val;
 	int bwrite = 1;
@@ -1107,8 +1141,20 @@ int rtw_mp_thermal(struct net_device *dev,
 #ifdef CONFIG_RTL8703B
 	u16 addr = EEPROM_THERMAL_METER_8703B;
 #endif
+#ifdef CONFIG_RTL8723D
+	u16 addr = EEPROM_THERMAL_METER_8723D;
+#endif
 #ifdef CONFIG_RTL8188F
 	u16 addr = EEPROM_THERMAL_METER_8188F;
+#endif
+#ifdef CONFIG_RTL8188GTV
+	u16 addr = EEPROM_THERMAL_METER_8188GTV;
+#endif
+#ifdef CONFIG_RTL8822B
+	u16 addr = EEPROM_THERMAL_METER_8822B;
+#endif
+#ifdef CONFIG_RTL8821C
+	u16 addr = EEPROM_THERMAL_METER_8821C;
 #endif
 	u16 cnt = 1;
 	u16 max_available_size = 0;
@@ -1122,14 +1168,14 @@ int rtw_mp_thermal(struct net_device *dev,
 	GetThermalMeter(padapter, &val);
 
 	if (bwrite == 0) {
-		/*DBG_871X("to write val:%d",val);*/
+		/*RTW_INFO("to write val:%d",val);*/
 		EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (PVOID)&max_available_size, _FALSE);
 		if (2 > max_available_size) {
-			DBG_871X("no available efuse!\n");
+			RTW_INFO("no available efuse!\n");
 			return -EFAULT;
 		}
 		if (rtw_efuse_map_write(padapter, addr, cnt, &val) == _FAIL) {
-			DBG_871X("rtw_efuse_map_write error\n");
+			RTW_INFO("rtw_efuse_map_write error\n");
 			return -EFAULT;
 		}
 		sprintf(extra, " efuse write ok :%d", val);
@@ -1143,8 +1189,8 @@ int rtw_mp_thermal(struct net_device *dev,
 
 
 int rtw_mp_reset_stats(struct net_device *dev,
-					   struct iw_request_info *info,
-					   struct iw_point *wrqu, char *extra)
+		       struct iw_request_info *info,
+		       struct iw_point *wrqu, char *extra)
 {
 	struct mp_priv *pmp_priv;
 	struct pkt_attrib *pattrib;
@@ -1161,13 +1207,17 @@ int rtw_mp_reset_stats(struct net_device *dev,
 	rtw_reset_phy_rx_counters(padapter);
 	rtw_reset_mac_rx_counters(padapter);
 
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "mp_reset_stats ok\n");
+	wrqu->length = strlen(extra);
+
 	return 0;
 }
 
 
 int rtw_mp_dump(struct net_device *dev,
-				struct iw_request_info *info,
-				struct iw_point *wrqu, char *extra)
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra)
 {
 	struct mp_priv *pmp_priv;
 	struct pkt_attrib *pattrib;
@@ -1192,8 +1242,8 @@ int rtw_mp_dump(struct net_device *dev,
 
 
 int rtw_mp_phypara(struct net_device *dev,
-				   struct iw_request_info *info,
-				   struct iw_point *wrqu, char *extra)
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
 {
 
 	PADAPTER padapter = rtw_netdev_priv(dev);
@@ -1204,11 +1254,11 @@ int rtw_mp_phypara(struct net_device *dev,
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
 
-	DBG_871X("%s:iwpriv in=%s\n", __func__, input);
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, input);
 
 	ret = sscanf(input, "xcap=%d", &valxcap);
 
-	pHalData->CrystalCap = (u8)valxcap;
+	pHalData->crystal_cap = (u8)valxcap;
 	hal_set_crystal_cap(padapter , valxcap);
 
 	sprintf(extra, "Set xcap=%d", valxcap);
@@ -1220,35 +1270,106 @@ int rtw_mp_phypara(struct net_device *dev,
 
 
 int rtw_mp_SetRFPath(struct net_device *dev,
-					 struct iw_request_info *info,
-					 union iwreq_data *wrqu, char *extra)
+		     struct iw_request_info *info,
+		     struct iw_point *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	char	input[wrqu->data.length];
+	char	input[wrqu->length];
 	int		bMain = 1, bTurnoff = 1;
+	u8 ret = _TRUE;
 
-	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, input);
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
 		return -EFAULT;
-	DBG_871X("%s:iwpriv in=%s\n", __func__, input);
 
 	bMain = strncmp(input, "1", 2); /* strncmp TRUE is 0*/
 	bTurnoff = strncmp(input, "0", 3); /* strncmp TRUE is 0*/
 
+	_rtw_memset(extra, 0, wrqu->length);
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	if (bMain == 0)
+		ret = rtw_mp_set_antdiv(padapter, _TRUE);
+	else
+		ret = rtw_mp_set_antdiv(padapter, _FALSE);
+	if (ret == _FALSE)
+		RTW_INFO("%s:ANTENNA_DIVERSITY FAIL\n", __func__);
+#endif
+
 	if (bMain == 0) {
 		MP_PHY_SetRFPathSwitch(padapter, _TRUE);
-		DBG_871X("%s:PHY_SetRFPathSwitch=TRUE\n", __func__);
+		RTW_INFO("%s:PHY_SetRFPathSwitch=TRUE\n", __func__);
+		sprintf(extra, "mp_setrfpath Main\n");
+
 	} else if (bTurnoff == 0) {
 		MP_PHY_SetRFPathSwitch(padapter, _FALSE);
-		DBG_871X("%s:PHY_SetRFPathSwitch=FALSE\n", __func__);
+		RTW_INFO("%s:PHY_SetRFPathSwitch=FALSE\n", __func__);
+		sprintf(extra, "mp_setrfpath Aux\n");
+	} else {
+		bMain = MP_PHY_QueryRFPathSwitch(padapter);
+		RTW_INFO("%s:PHY_SetRFPathSwitch = %s\n", __func__, (bMain ? "Main":"Aux"));
+		sprintf(extra, "mp_setrfpath %s\n" , (bMain ? "Main":"Aux"));
 	}
 
+	wrqu->length = strlen(extra);
+
 	return 0;
 }
 
 
+int rtw_mp_switch_rf_path(struct net_device *dev,
+			struct iw_request_info *info,
+			struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct mp_priv *pmp_priv;
+	char	input[wrqu->length];
+	int		bwlg = 1, bwla = 1, btg = 1, bbt=1;
+	u8 ret = 0;
+
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	pmp_priv = &padapter->mppriv;
+
+	RTW_INFO("%s: in=%s\n", __func__, input);
+
+	bwlg = strncmp(input, "WLG", 3); /* strncmp TRUE is 0*/
+	bwla = strncmp(input, "WLA", 3); /* strncmp TRUE is 0*/
+	btg = strncmp(input, "BTG", 3); /* strncmp TRUE is 0*/
+	bbt = strncmp(input, "BT", 3); /* strncmp TRUE is 0*/
+
+	_rtw_memset(extra, 0, wrqu->length);
+#ifdef CONFIG_RTL8821C /* only support for 8821c wlg/wla/btg/bt RF switch path */
+	if (bwlg == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_WLG;
+		sprintf(extra, "switch rf path WLG\n");
+	} else if (bwla == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_WLA;
+		sprintf(extra, "switch rf path WLA\n");
+	} else if (btg == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_BTG;
+		sprintf(extra, "switch rf path BTG\n");
+	} else if (bbt == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_BT;
+		sprintf(extra, "switch rf path BG\n");
+	} else {
+		sprintf(extra, "Error set %s\n", __func__);
+		return -EFAULT;
+	}
+
+	mp_phy_switch_rf_path_set(padapter, &pmp_priv->rf_path_cfg);
+#endif
+
+	wrqu->length = strlen(extra);
+
+	return ret;
+
+}
 int rtw_mp_QueryDrv(struct net_device *dev,
-					struct iw_request_info *info,
-					union iwreq_data *wrqu, char *extra)
+		    struct iw_request_info *info,
+		    union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	char	input[wrqu->data.length];
@@ -1258,12 +1379,12 @@ int rtw_mp_QueryDrv(struct net_device *dev,
 
 	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
-	DBG_871X("%s:iwpriv in=%s\n", __func__, input);
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, input);
 
 	qAutoLoad = strncmp(input, "autoload", 8); /* strncmp TRUE is 0*/
 
 	if (qAutoLoad == 0) {
-		DBG_871X("%s:qAutoLoad\n", __func__);
+		RTW_INFO("%s:qAutoLoad\n", __func__);
 
 		if (pHalData->bautoload_fail_flag)
 			sprintf(extra, "fail");
@@ -1276,8 +1397,8 @@ int rtw_mp_QueryDrv(struct net_device *dev,
 
 
 int rtw_mp_PwrCtlDM(struct net_device *dev,
-					struct iw_request_info *info,
-					struct iw_point *wrqu, char *extra)
+		    struct iw_request_info *info,
+		    struct iw_point *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	u8		input[wrqu->length];
@@ -1322,8 +1443,8 @@ int rtw_mp_lck(struct net_device *dev,
 }
 
 int rtw_mp_getver(struct net_device *dev,
-				  struct iw_request_info *info,
-				  union iwreq_data *wrqu, char *extra)
+		  struct iw_request_info *info,
+		  union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	struct mp_priv *pmp_priv;
@@ -1340,26 +1461,27 @@ int rtw_mp_getver(struct net_device *dev,
 
 
 int rtw_mp_mon(struct net_device *dev,
-			   struct iw_request_info *info,
-			   union iwreq_data *wrqu, char *extra)
+	       struct iw_request_info *info,
+	       union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType;
 	int bstart = 1, bstop = 1;
-	
+
 	networkType = Ndis802_11Infrastructure;
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
 
+	*(extra + wrqu->data.length) = '\0';
 	rtw_pm_set_ips(padapter, IPS_NONE);
 	LeaveAllPowerSaveMode(padapter);
 
 #ifdef CONFIG_MP_INCLUDED
 	if (init_mp_priv(padapter) == _FAIL)
-		DBG_871X("%s: initialize MP private data Fail!\n", __func__);
+		RTW_INFO("%s: initialize MP private data Fail!\n", __func__);
 	padapter->mppriv.channel = 6;
 
 	bstart = strncmp(extra, "start", 5); /* strncmp TRUE is 0*/
@@ -1379,11 +1501,11 @@ int rtw_mp_mon(struct net_device *dev,
 		pHalFunc->hal_deinit(padapter);
 		padapter->registrypriv.mp_mode = 0;
 		pHalFunc->hal_init(padapter);
-		/*rtw_disassoc_cmd(padapter, 0, _TRUE);*/
+		/*rtw_disassoc_cmd(padapter, 0, 0);*/
 		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
-			rtw_disassoc_cmd(padapter, 500, _TRUE);
+			rtw_disassoc_cmd(padapter, 500, 0);
 			rtw_indicate_disconnect(padapter, 0, _FALSE);
-			/*rtw_free_assoc_resources(padapter, 1);*/
+			/*rtw_free_assoc_resources_cmd(padapter, _TRUE);*/
 		}
 		rtw_pm_set_ips(padapter, IPS_NORMAL);
 		sprintf(extra, "monitor mode Stop\n");
@@ -1397,77 +1519,78 @@ int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra)
 {
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	struct mp_priv *pmp_priv = &padapter->mppriv;
-	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.MptCtx);
-
-		switch (pmp_priv->mode) {
-
-		case MP_PACKET_TX:
-						if (bStartTest == 0) {
-							pmp_priv->tx.stop = 1;
-							pmp_priv->mode = MP_ON;
-							sprintf(extra, "Stop continuous Tx");
-						} else if (pmp_priv->tx.stop == 1) {
-							sprintf(extra, "%s\nStart continuous DA=ffffffffffff len=1500 count=%u\n", extra, pmp_priv->tx.count);
-							pmp_priv->tx.stop = 0;
-							SetPacketTx(padapter);
-						} else {
-							return -EFAULT;
-						}
-						return 0;
-		case MP_SINGLE_TONE_TX:
-						if (bStartTest != 0)
-							sprintf(extra, "%s\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.", extra);
-						SetSingleToneTx(padapter, (u8)bStartTest);
-						break;
-		case MP_CONTINUOUS_TX:
-						if (bStartTest != 0)
-							sprintf(extra, "%s\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.", extra);
-						SetContinuousTx(padapter, (u8)bStartTest);
-						break;
-		case MP_CARRIER_SUPPRISSION_TX:
-						if (bStartTest != 0) {
-							if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_11M)
-								sprintf(extra, "%s\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.", extra);
-							else
-								sprintf(extra, "%s\nSpecify carrier suppression but not CCK rate", extra);
-						}
-						SetCarrierSuppressionTx(padapter, (u8)bStartTest);
-						break;
-		case MP_SINGLE_CARRIER_TX:
-					if (bStartTest != 0)
-							sprintf(extra, "%s\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.", extra);
-						SetSingleCarrierTx(padapter, (u8)bStartTest);
-						break;
-
-		default:
-						sprintf(extra, "Error! Continuous-Tx is not on-going.");
-						return -EFAULT;
-		}
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+	char *pextra = extra;
 
-		if (bStartTest == 1 && pmp_priv->mode != MP_ON) {
-			struct mp_priv *pmp_priv = &padapter->mppriv;
+	switch (pmp_priv->mode) {
 
-			if (pmp_priv->tx.stop == 0) {
-				pmp_priv->tx.stop = 1;
-				rtw_msleep_os(5);
-			}
-#ifdef CONFIG_80211N_HT
-			pmp_priv->tx.attrib.ht_en = 1;
-#endif
+	case MP_PACKET_TX:
+		if (bStartTest == 0) {
+			pmp_priv->tx.stop = 1;
+			pmp_priv->mode = MP_ON;
+			sprintf(extra, "Stop continuous Tx");
+		} else if (pmp_priv->tx.stop == 1) {
+			pextra = extra + strlen(extra);
+			pextra += sprintf(pextra, "\nStart continuous DA=ffffffffffff len=1500 count=%u\n", pmp_priv->tx.count);
 			pmp_priv->tx.stop = 0;
-			pmp_priv->tx.count = 1;
 			SetPacketTx(padapter);
 		} else
-			pmp_priv->mode = MP_ON;
+			return -EFAULT;
+		return 0;
+	case MP_SINGLE_TONE_TX:
+		if (bStartTest != 0)
+			strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+		SetSingleToneTx(padapter, (u8)bStartTest);
+		break;
+	case MP_CONTINUOUS_TX:
+		if (bStartTest != 0)
+			strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+		SetContinuousTx(padapter, (u8)bStartTest);
+		break;
+	case MP_CARRIER_SUPPRISSION_TX:
+		if (bStartTest != 0) {
+			if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_11M)
+				strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+			else
+				strcat(extra, "\nSpecify carrier suppression but not CCK rate");
+		}
+		SetCarrierSuppressionTx(padapter, (u8)bStartTest);
+		break;
+	case MP_SINGLE_CARRIER_TX:
+		if (bStartTest != 0)
+			strcat(extra, "\nStart continuous DA=ffffffffffff len=1500\n infinite=yes.");
+		SetSingleCarrierTx(padapter, (u8)bStartTest);
+		break;
+
+	default:
+		sprintf(extra, "Error! Continuous-Tx is not on-going.");
+		return -EFAULT;
+	}
+
+	if (bStartTest == 1 && pmp_priv->mode != MP_ON) {
+		struct mp_priv *pmp_priv = &padapter->mppriv;
+
+		if (pmp_priv->tx.stop == 0) {
+			pmp_priv->tx.stop = 1;
+			rtw_msleep_os(5);
+		}
+#ifdef CONFIG_80211N_HT
+		pmp_priv->tx.attrib.ht_en = 1;
+#endif
+		pmp_priv->tx.stop = 0;
+		pmp_priv->tx.count = 1;
+		SetPacketTx(padapter);
+	} else
+		pmp_priv->mode = MP_ON;
 
 #if defined(CONFIG_RTL8812A)
-			if (IS_HARDWARE_TYPE_8812AU(padapter)) {
-				/* <20130425, Kordan> Turn off OFDM Rx to prevent from CCA causing Tx hang.*/
-				if (pmp_priv->mode == MP_PACKET_TX)
-					PHY_SetBBReg(padapter, rCCAonSec_Jaguar, BIT3, 1);
-				else
-					PHY_SetBBReg(padapter, rCCAonSec_Jaguar, BIT3, 0);
-			}
+	if (IS_HARDWARE_TYPE_8812AU(padapter)) {
+		/* <20130425, Kordan> Turn off OFDM Rx to prevent from CCA causing Tx hang.*/
+		if (pmp_priv->mode == MP_PACKET_TX)
+			phy_set_bb_reg(padapter, rCCAonSec_Jaguar, BIT3, 1);
+		else
+			phy_set_bb_reg(padapter, rCCAonSec_Jaguar, BIT3, 0);
+	}
 #endif
 
 	return 0;
@@ -1475,346 +1598,348 @@ int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra)
 
 
 int rtw_mp_tx(struct net_device *dev,
-			   struct iw_request_info *info,
-			   union iwreq_data *wrqu, char *extra)
+	      struct iw_request_info *info,
+	      union iwreq_data *wrqu, char *extra)
 {
-		PADAPTER padapter = rtw_netdev_priv(dev);
-		HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
-		struct mp_priv *pmp_priv = &padapter->mppriv;
-		PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.MptCtx);
-		struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-
-		u32 bandwidth = 0, sg = 0, channel = 6, txpower = 40, rate = 108, ant = 0, txmode = 1, count = 0;
-		u8 i = 0, j = 0, bStartTest = 1, status = 0, Idx = 0, tmpU1B = 0;
-		u16 antenna = 0;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+	char *pextra = extra;
+	u32 bandwidth = 0, sg = 0, channel = 6, txpower = 40, rate = 108, ant = 0, txmode = 1, count = 0;
+	u8 i = 0, j = 0, bStartTest = 1, status = 0, Idx = 0, tmpU1B = 0;
+	u16 antenna = 0;
 
-		if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
-			return -EFAULT;
-		DBG_871X("extra = %s\n", extra);
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+	RTW_INFO("extra = %s\n", extra);
 #ifdef CONFIG_CONCURRENT_MODE
-			if (padapter->adapter_type == SECONDARY_ADAPTER) {
-				sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
-				wrqu->data.length = strlen(extra);
-				return 0;
-			}
+	if (!is_primary_adapter(padapter)) {
+		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
 #endif
 
-		if (strncmp(extra, "stop", 3) == 0) {
-			bStartTest = 0; /* To set Stop*/
-			pmp_priv->tx.stop = 1;
-			sprintf(extra, "Stop continuous Tx");
-			status = rtw_mp_pretx_proc(padapter, bStartTest, extra);
-			wrqu->data.length = strlen(extra);
-			return status;
-		} else if (strncmp(extra, "count", 5) == 0) {
-				if (sscanf(extra, "count=%d", &count) < 1)
-					DBG_871X("Got Count=%d]\n", count);
-				pmp_priv->tx.count = count;
-				return 0;
-		} else if (strncmp(extra, "setting", 7) == 0) {
-				_rtw_memset(extra, 0, wrqu->data.length);
-				sprintf(extra, "Current Setting :\n Channel:%d", pmp_priv->channel);
-				sprintf(extra, "%s\n Bandwidth:%d", extra, pmp_priv->bandwidth);
-				sprintf(extra, "%s\n Rate index:%d", extra, pmp_priv->rateidx);
-				sprintf(extra, "%s\n TxPower index:%d", extra, pmp_priv->txpoweridx);
-				sprintf(extra, "%s\n Antenna TxPath:%d", extra, pmp_priv->antenna_tx);
-				sprintf(extra, "%s\n Antenna RxPath:%d", extra, pmp_priv->antenna_rx);
-				sprintf(extra, "%s\n MP Mode:%d", extra, pmp_priv->mode);
-				wrqu->data.length = strlen(extra);
-				return 0;
+	if (strncmp(extra, "stop", 3) == 0) {
+		bStartTest = 0; /* To set Stop*/
+		pmp_priv->tx.stop = 1;
+		sprintf(extra, "Stop continuous Tx");
+		status = rtw_mp_pretx_proc(padapter, bStartTest, extra);
+		wrqu->data.length = strlen(extra);
+		return status;
+	} else if (strncmp(extra, "count", 5) == 0) {
+		if (sscanf(extra, "count=%d", &count) < 1)
+			RTW_INFO("Got Count=%d]\n", count);
+		pmp_priv->tx.count = count;
+		return 0;
+	} else if (strncmp(extra, "setting", 7) == 0) {
+		_rtw_memset(extra, 0, wrqu->data.length);
+		pextra += sprintf(pextra, "Current Setting :\n Channel:%d", pmp_priv->channel);
+		pextra += sprintf(pextra, "\n Bandwidth:%d", pmp_priv->bandwidth);
+		pextra += sprintf(pextra, "\n Rate index:%d", pmp_priv->rateidx);
+		pextra += sprintf(pextra, "\n TxPower index:%d", pmp_priv->txpoweridx);
+		pextra += sprintf(pextra, "\n Antenna TxPath:%d", pmp_priv->antenna_tx);
+		pextra += sprintf(pextra, "\n Antenna RxPath:%d", pmp_priv->antenna_rx);
+		pextra += sprintf(pextra, "\n MP Mode:%d", pmp_priv->mode);
+		wrqu->data.length = strlen(extra);
+		return 0;
 #ifdef CONFIG_MP_VHT_HW_TX_MODE
-		} else if (strncmp(extra, "pmact", 5) == 0) {
-				if (strncmp(extra, "pmact=start", 11) == 0) {
-					_rtw_memset(&pMptCtx->PMacTxInfo, 0, sizeof(pMptCtx->PMacTxInfo));
-					pMptCtx->PMacTxInfo.bEnPMacTx = _TRUE;
-
-					if (pMptCtx->bldpc == TRUE)
-						pMptCtx->PMacTxInfo.bLDPC = _TRUE;
-
-					if (pMptCtx->bstbc == TRUE)
-						pMptCtx->PMacTxInfo.bSTBC = _TRUE;
-
-					pMptCtx->PMacTxInfo.bSPreamble = pmp_priv->preamble;
-					pMptCtx->PMacTxInfo.bSGI = pmp_priv->preamble;
-					pMptCtx->PMacTxInfo.BandWidth = pmp_priv->bandwidth;
-					pMptCtx->PMacTxInfo.TX_RATE = HwRateToMPTRate(pmp_priv->rateidx);
-
-					pMptCtx->PMacTxInfo.Mode = pMptCtx->HWTxmode;
-
-					pMptCtx->PMacTxInfo.NDP_sound = FALSE;/*(Adapter.PacketType == NDP_PKT)?TRUE:FALSE;*/
-
-					if (padapter->mppriv.pktInterval == 0)
-						pMptCtx->PMacTxInfo.PacketPeriod = 100;
-					else
-						pMptCtx->PMacTxInfo.PacketPeriod = padapter->mppriv.pktInterval;
-
-					if (padapter->mppriv.pktLength < 1000)
-						pMptCtx->PMacTxInfo.PacketLength = 1000;
-					else
-						pMptCtx->PMacTxInfo.PacketLength = padapter->mppriv.pktLength;
-
-					pMptCtx->PMacTxInfo.PacketPattern  = rtw_random32() % 0xFF;
-
-					if (padapter->mppriv.tx_pktcount != 0)
-						pMptCtx->PMacTxInfo.PacketCount = padapter->mppriv.tx_pktcount;
-
-					pMptCtx->PMacTxInfo.Ntx = 0;
-					for (Idx = 16; Idx < 20; Idx++) {
-						tmpU1B = (padapter->mppriv.antenna_tx >> Idx) & 1;
-						if (tmpU1B)
-							pMptCtx->PMacTxInfo.Ntx++;
-					}
-
-					_rtw_memset(pMptCtx->PMacTxInfo.MacAddress, 0xFF, ETH_ALEN);
-
-					PMAC_Get_Pkt_Param(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
-
-					if (MPT_IS_CCK_RATE(pMptCtx->PMacTxInfo.TX_RATE)) {
-
-						CCK_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
-					} else {
-						PMAC_Nsym_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
-						/* 24 BIT*/
-						L_SIG_generator(pMptCtx->PMacPktInfo.N_sym, &pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
-					}
-					/*	48BIT*/
-					if (MPT_IS_HT_RATE(pMptCtx->PMacTxInfo.TX_RATE))
-						HT_SIG_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
-					else if (MPT_IS_VHT_RATE(pMptCtx->PMacTxInfo.TX_RATE)) {
-						/*	48BIT*/
-						VHT_SIG_A_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
-
-						/*	26/27/29 BIT  & CRC 8 BIT*/
-						VHT_SIG_B_generator(&pMptCtx->PMacTxInfo);
-
-						/* 32 BIT*/
-						VHT_Delimiter_generator(&pMptCtx->PMacTxInfo);
-					}
-
-					mpt_ProSetPMacTx(padapter);
-					sprintf(extra, "Set PMac Tx Mode start\n");
-
-				} else if (strncmp(extra, "pmact,mode=", 11) == 0) {
-						int txmode = 0;
-
-						if (sscanf(extra, "pmact,mode=%d", &txmode) > 0) {
-							if (txmode == 1) {
-								pMptCtx->HWTxmode = CONTINUOUS_TX;
-								sprintf(extra, "\t Config HW Tx mode = CONTINUOUS_TX\n");
-							} else if (txmode == 2) {
-								pMptCtx->HWTxmode = OFDM_Single_Tone_TX;
-								sprintf(extra, "\t Config HW Tx mode = OFDM_Single_Tone_TX\n");
-							} else {
-								pMptCtx->HWTxmode = PACKETS_TX;
-								sprintf(extra, "\t Config HW Tx mode = PACKETS_TX\n");
-							}
-						} else {
-							pMptCtx->HWTxmode = PACKETS_TX;
-							sprintf(extra, "\t Config HW Tx mode=\n 0 = PACKETS_TX\n 1 = CONTINUOUS_TX\n 2 = OFDM_Single_Tone_TX");
-						}
-				} else if (strncmp(extra, "pmact,", 6) == 0) {
-					int PacketPeriod = 0, PacketLength = 0, PacketCout = 0;
-					int bldpc = 0, bstbc = 0;
-
-					if (sscanf(extra, "pmact,period=%d", &PacketPeriod) > 0) {
-							padapter->mppriv.pktInterval = PacketPeriod;
-							DBG_871X("PacketPeriod=%d\n", padapter->mppriv.pktInterval);
-							sprintf(extra, "PacketPeriod [1~255]= %d\n", padapter->mppriv.pktInterval);
-
-					} else if (sscanf(extra, "pmact,length=%d", &PacketLength) > 0) {
-							padapter->mppriv.pktLength = PacketLength;
-							DBG_871X("PacketPeriod=%d\n", padapter->mppriv.pktLength);
-							sprintf(extra, "PacketLength[~65535]=%d\n", padapter->mppriv.pktLength);
-
-					} else if (sscanf(extra, "pmact,count=%d", &PacketCout) > 0) {
-							padapter->mppriv.tx_pktcount = PacketCout;
-							DBG_871X("Packet Cout =%d\n", padapter->mppriv.tx_pktcount);
-							sprintf(extra, "Packet Cout =%d\n", padapter->mppriv.tx_pktcount);
-
-					} else if (sscanf(extra, "pmact,ldpc=%d", &bldpc) > 0) {
-							pMptCtx->bldpc = bldpc;
-							DBG_871X("Set LDPC =%d\n", pMptCtx->bldpc);
-							sprintf(extra, "Set LDPC =%d\n", pMptCtx->bldpc);
-
-					} else if (sscanf(extra, "pmact,stbc=%d", &bstbc) > 0) {
-							pMptCtx->bstbc = bstbc;
-							DBG_871X("Set STBC =%d\n", pMptCtx->bstbc);
-							sprintf(extra, "Set STBC =%d\n", pMptCtx->bstbc);
-					} else
-						sprintf(extra, "\n period={1~255}\n length={1000~65535}\n count={0~}\n ldpc={0/1}\n stbc={0/1}");
+	} else if (strncmp(extra, "pmact", 5) == 0) {
+		if (strncmp(extra, "pmact=", 6) == 0) {
+			_rtw_memset(&pMptCtx->PMacTxInfo, 0, sizeof(pMptCtx->PMacTxInfo));
+			if (strncmp(extra, "pmact=start", 11) == 0) {
+				pMptCtx->PMacTxInfo.bEnPMacTx = _TRUE;
+				sprintf(extra, "Set PMac Tx Mode start\n");
+			} else {
+				pMptCtx->PMacTxInfo.bEnPMacTx = _FALSE;
+				sprintf(extra, "Set PMac Tx Mode Stop\n");
+			}
+			if (pMptCtx->bldpc == TRUE)
+				pMptCtx->PMacTxInfo.bLDPC = _TRUE;
 
-				} else {
-					pMptCtx->PMacTxInfo.bEnPMacTx = FALSE;
-					sprintf(extra, "Set PMac Tx Mode stop\n");
+			if (pMptCtx->bstbc == TRUE)
+				pMptCtx->PMacTxInfo.bSTBC = _TRUE;
 
-				}
+			pMptCtx->PMacTxInfo.bSPreamble = pmp_priv->preamble;
+			pMptCtx->PMacTxInfo.bSGI = pmp_priv->preamble;
+			pMptCtx->PMacTxInfo.BandWidth = pmp_priv->bandwidth;
+			pMptCtx->PMacTxInfo.TX_RATE = HwRateToMPTRate(pmp_priv->rateidx);
 
-				wrqu->data.length = strlen(extra);
-				return 0;
-#endif
-		} else {
+			pMptCtx->PMacTxInfo.Mode = pMptCtx->HWTxmode;
 
-			if (sscanf(extra, "ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d", &channel, &bandwidth, &rate, &txpower, &ant, &txmode) < 6) {
-					DBG_871X("Invalid format [ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d]\n", channel, bandwidth, rate, txpower, ant, txmode);
-					_rtw_memset(extra, 0, wrqu->data.length);
-					sprintf(extra, "\n Please input correct format as bleow:\n");
-					sprintf(extra, "%s\t ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d\n", extra, channel, bandwidth, rate, txpower, ant, txmode);
-					sprintf(extra, "%s\n [ ch : BGN = <1~14> , A or AC = <36~165> ]", extra);
-					sprintf(extra, "%s\n [ bw : Bandwidth: 0 = 20M, 1 = 40M, 2 = 80M ]", extra);
-					sprintf(extra, "%s\n [ rate :	CCK: 1 2 5.5 11M X 2 = < 2 4 11 22 >]", extra);
-					sprintf(extra, "%s\n [		OFDM: 6 9 12 18 24 36 48 54M X 2 = < 12 18 24 36 48 72 96 108>", extra);
-					sprintf(extra, "%s\n [		HT 1S2SS MCS0 ~ MCS15 : < [MCS0]=128 ~ [MCS7]=135 ~ [MCS15]=143 >", extra);
-					sprintf(extra, "%s\n [		HT 3SS MCS16 ~ MCS32 : < [MCS16]=144 ~ [MCS23]=151 ~ [MCS32]=159 >", extra);
-					sprintf(extra, "%s\n [		VHT 1SS MCS0 ~ MCS9 : < [MCS0]=160 ~ [MCS9]=169 >", extra);
-					sprintf(extra, "%s\n [ txpower : 1~63 power index", extra);
-					sprintf(extra, "%s\n [ ant : <A = 1, B = 2, C = 4, D = 8> ,2T ex: AB=3 BC=6 CD=12", extra);
-					sprintf(extra, "%s\n [ txmode : < 0 = CONTINUOUS_TX, 1 = PACKET_TX, 2 = SINGLE_TONE_TX, 3 = CARRIER_SUPPRISSION_TX, 4 = SINGLE_CARRIER_TX>\n", extra);
-					wrqu->data.length = strlen(extra);
-					return status;
+			pMptCtx->PMacTxInfo.NDP_sound = FALSE;/*(Adapter.PacketType == NDP_PKT)?TRUE:FALSE;*/
 
-			} else {
-				DBG_871X("Got format [ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d]\n", channel, bandwidth, rate, txpower, ant, txmode);
-				_rtw_memset(extra, 0, wrqu->data.length);
-				sprintf(extra, "Change Current channel %d to channel %d", padapter->mppriv.channel , channel);
-				padapter->mppriv.channel = channel;
-				SetChannel(padapter);
-				pHalData->CurrentChannel = channel;
-
-				if (bandwidth == 1)
-					bandwidth = CHANNEL_WIDTH_40;
-				else if (bandwidth == 2)
-					bandwidth = CHANNEL_WIDTH_80;
-				sprintf(extra, "%s\nChange Current Bandwidth %d to Bandwidth %d", extra, padapter->mppriv.bandwidth , bandwidth);
-				padapter->mppriv.bandwidth = (u8)bandwidth;
-				padapter->mppriv.preamble = sg;
-				SetBandwidth(padapter);
-				pHalData->CurrentChannelBW = bandwidth;
-
-				sprintf(extra, "%s\nSet power level :%d", extra, txpower);
-				padapter->mppriv.txpoweridx = (u8)txpower;
-				pMptCtx->TxPwrLevel[ODM_RF_PATH_A] = (u8)txpower;
-				pMptCtx->TxPwrLevel[ODM_RF_PATH_B] = (u8)txpower;
-				pMptCtx->TxPwrLevel[ODM_RF_PATH_C] = (u8)txpower;
-				pMptCtx->TxPwrLevel[ODM_RF_PATH_D]  = (u8)txpower;
-
-				DBG_871X("%s: bw=%d sg=%d\n", __func__, bandwidth, sg);
-
-				if (rate <= 0x7f)
-					rate = wifirate2_ratetbl_inx((u8)rate);
-				else if (rate < 0xC8)
-					rate = (rate - 0x80 + MPT_RATE_MCS0);
-					/*HT  rate 0x80(MCS0)  ~ 0x8F(MCS15) ~ 0x9F(MCS31) 128~159
-					VHT1SS~2SS rate 0xA0 (VHT1SS_MCS0 44) ~ 0xB3 (VHT2SS_MCS9 #63) 160~179
-					VHT rate 0xB4 (VHT3SS_MCS0 64) ~ 0xC7 (VHT2SS_MCS9 #83) 180~199
-					else
-					VHT rate 0x90(VHT1SS_MCS0) ~ 0x99(VHT1SS_MCS9) 144~153
-					rate =(rate - MPT_RATE_VHT1SS_MCS0);
-					*/
-				DBG_871X("%s: rate index=%d\n", __func__, rate);
-				if (rate >= MPT_RATE_LAST)
-					return -EINVAL;
-				sprintf(extra, "%s\nSet data rate to %d index %d", extra, padapter->mppriv.rateidx, rate);
-
-				padapter->mppriv.rateidx = rate;
-				pMptCtx->MptRateIndex = rate;
-				SetDataRate(padapter);
-
-				sprintf(extra, "%s\nSet Antenna Path :%d",  extra, ant);
-				switch (ant) {
-				case 1:
-					antenna = ANTENNA_A;
-					break;
-				case 2:
-					antenna = ANTENNA_B;
-					break;
-				case 4:
-					antenna = ANTENNA_C;
-					break;
-				case 8:
-					antenna = ANTENNA_D;
-					break;
-				case 3:
-					antenna = ANTENNA_AB;
-					break;
-				case 5:
-					antenna = ANTENNA_AC;
-					break;
-				case 9:
-					antenna = ANTENNA_AD;
-					break;
-				case 6:
-					antenna = ANTENNA_BC;
-					break;
-				case 10:
-					antenna = ANTENNA_BD;
-					break;
-				case 12:
-					antenna = ANTENNA_CD;
-					break;
-				case 7:
-					antenna = ANTENNA_ABC;
-					break;
-				case 14:
-					antenna = ANTENNA_BCD;
-					break;
-				case 11:
-					antenna = ANTENNA_ABD;
-					break;
-				case 15:
-					antenna = ANTENNA_ABCD;
-					break;
-				}
-				DBG_871X("%s: antenna=0x%x\n", __func__, antenna);
-				padapter->mppriv.antenna_tx = antenna;
-				padapter->mppriv.antenna_rx = antenna;
-				pHalData->AntennaTxPath = antenna;
-				SetAntenna(padapter);
-
-				if (txmode == 0) {
-					pmp_priv->mode = MP_CONTINUOUS_TX;
-				} else if (txmode == 1) {
-					pmp_priv->mode = MP_PACKET_TX;
-					pmp_priv->tx.count = count;
+			if (padapter->mppriv.pktInterval == 0)
+				pMptCtx->PMacTxInfo.PacketPeriod = 100;
+			else
+				pMptCtx->PMacTxInfo.PacketPeriod = padapter->mppriv.pktInterval;
+
+			if (padapter->mppriv.pktLength < 1000)
+				pMptCtx->PMacTxInfo.PacketLength = 1000;
+			else
+				pMptCtx->PMacTxInfo.PacketLength = padapter->mppriv.pktLength;
+
+			pMptCtx->PMacTxInfo.PacketPattern  = rtw_random32() % 0xFF;
+
+			if (padapter->mppriv.tx_pktcount != 0)
+				pMptCtx->PMacTxInfo.PacketCount = padapter->mppriv.tx_pktcount;
+
+			pMptCtx->PMacTxInfo.Ntx = 0;
+			for (Idx = 16; Idx < 20; Idx++) {
+				tmpU1B = (padapter->mppriv.antenna_tx >> Idx) & 1;
+				if (tmpU1B)
+					pMptCtx->PMacTxInfo.Ntx++;
+			}
+
+			_rtw_memset(pMptCtx->PMacTxInfo.MacAddress, 0xFF, ETH_ALEN);
+
+			PMAC_Get_Pkt_Param(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+
+			if (MPT_IS_CCK_RATE(pMptCtx->PMacTxInfo.TX_RATE))
+
+				CCK_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+			else {
+				PMAC_Nsym_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+				/* 24 BIT*/
+				L_SIG_generator(pMptCtx->PMacPktInfo.N_sym, &pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+			}
+			/*	48BIT*/
+			if (MPT_IS_HT_RATE(pMptCtx->PMacTxInfo.TX_RATE))
+				HT_SIG_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+			else if (MPT_IS_VHT_RATE(pMptCtx->PMacTxInfo.TX_RATE)) {
+				/*	48BIT*/
+				VHT_SIG_A_generator(&pMptCtx->PMacTxInfo, &pMptCtx->PMacPktInfo);
+
+				/*	26/27/29 BIT  & CRC 8 BIT*/
+				VHT_SIG_B_generator(&pMptCtx->PMacTxInfo);
+
+				/* 32 BIT*/
+				VHT_Delimiter_generator(&pMptCtx->PMacTxInfo);
+			}
+
+			mpt_ProSetPMacTx(padapter);
+
+		} else if (strncmp(extra, "pmact,mode=", 11) == 0) {
+			int txmode = 0;
+
+			if (sscanf(extra, "pmact,mode=%d", &txmode) > 0) {
+				if (txmode == 1) {
+					pMptCtx->HWTxmode = CONTINUOUS_TX;
+					sprintf(extra, "\t Config HW Tx mode = CONTINUOUS_TX\n");
 				} else if (txmode == 2) {
-					pmp_priv->mode = MP_SINGLE_TONE_TX;
-				} else if (txmode == 3) {
-					pmp_priv->mode = MP_CARRIER_SUPPRISSION_TX;
-				} else if (txmode == 4) {
-					pmp_priv->mode = MP_SINGLE_CARRIER_TX;
+					pMptCtx->HWTxmode = OFDM_Single_Tone_TX;
+					sprintf(extra, "\t Config HW Tx mode = OFDM_Single_Tone_TX\n");
+				} else {
+					pMptCtx->HWTxmode = PACKETS_TX;
+					sprintf(extra, "\t Config HW Tx mode = PACKETS_TX\n");
 				}
-
-			status = rtw_mp_pretx_proc(padapter, bStartTest, extra);
+			} else {
+				pMptCtx->HWTxmode = PACKETS_TX;
+				sprintf(extra, "\t Config HW Tx mode=\n 0 = PACKETS_TX\n 1 = CONTINUOUS_TX\n 2 = OFDM_Single_Tone_TX");
 			}
+		} else if (strncmp(extra, "pmact,", 6) == 0) {
+			int PacketPeriod = 0, PacketLength = 0, PacketCout = 0;
+			int bldpc = 0, bstbc = 0;
+
+			if (sscanf(extra, "pmact,period=%d", &PacketPeriod) > 0) {
+				padapter->mppriv.pktInterval = PacketPeriod;
+				RTW_INFO("PacketPeriod=%d\n", padapter->mppriv.pktInterval);
+				sprintf(extra, "PacketPeriod [1~255]= %d\n", padapter->mppriv.pktInterval);
+
+			} else if (sscanf(extra, "pmact,length=%d", &PacketLength) > 0) {
+				padapter->mppriv.pktLength = PacketLength;
+				RTW_INFO("PacketPeriod=%d\n", padapter->mppriv.pktLength);
+				sprintf(extra, "PacketLength[~65535]=%d\n", padapter->mppriv.pktLength);
+
+			} else if (sscanf(extra, "pmact,count=%d", &PacketCout) > 0) {
+				padapter->mppriv.tx_pktcount = PacketCout;
+				RTW_INFO("Packet Cout =%d\n", padapter->mppriv.tx_pktcount);
+				sprintf(extra, "Packet Cout =%d\n", padapter->mppriv.tx_pktcount);
+
+			} else if (sscanf(extra, "pmact,ldpc=%d", &bldpc) > 0) {
+				pMptCtx->bldpc = bldpc;
+				RTW_INFO("Set LDPC =%d\n", pMptCtx->bldpc);
+				sprintf(extra, "Set LDPC =%d\n", pMptCtx->bldpc);
+
+			} else if (sscanf(extra, "pmact,stbc=%d", &bstbc) > 0) {
+				pMptCtx->bstbc = bstbc;
+				RTW_INFO("Set STBC =%d\n", pMptCtx->bstbc);
+				sprintf(extra, "Set STBC =%d\n", pMptCtx->bstbc);
+			} else
+				sprintf(extra, "\n period={1~255}\n length={1000~65535}\n count={0~}\n ldpc={0/1}\n stbc={0/1}");
 
 		}
 
 		wrqu->data.length = strlen(extra);
-		return status;
+		return 0;
+#endif
+	} else {
+
+		if (sscanf(extra, "ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d", &channel, &bandwidth, &rate, &txpower, &ant, &txmode) < 6) {
+			RTW_INFO("Invalid format [ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d]\n", channel, bandwidth, rate, txpower, ant, txmode);
+			_rtw_memset(extra, 0, wrqu->data.length);
+			pextra += sprintf(pextra, "\n Please input correct format as bleow:\n");
+			pextra += sprintf(pextra, "\t ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d\n", channel, bandwidth, rate, txpower, ant, txmode);
+			pextra += sprintf(pextra, "\n [ ch : BGN = <1~14> , A or AC = <36~165> ]");
+			pextra += sprintf(pextra, "\n [ bw : Bandwidth: 0 = 20M, 1 = 40M, 2 = 80M ]");
+			pextra += sprintf(pextra, "\n [ rate :	CCK: 1 2 5.5 11M X 2 = < 2 4 11 22 >]");
+			pextra += sprintf(pextra, "\n [		OFDM: 6 9 12 18 24 36 48 54M X 2 = < 12 18 24 36 48 72 96 108>");
+			pextra += sprintf(pextra, "\n [		HT 1S2SS MCS0 ~ MCS15 : < [MCS0]=128 ~ [MCS7]=135 ~ [MCS15]=143 >");
+			pextra += sprintf(pextra, "\n [		HT 3SS MCS16 ~ MCS32 : < [MCS16]=144 ~ [MCS23]=151 ~ [MCS32]=159 >");
+			pextra += sprintf(pextra, "\n [		VHT 1SS MCS0 ~ MCS9 : < [MCS0]=160 ~ [MCS9]=169 >");
+			pextra += sprintf(pextra, "\n [ txpower : 1~63 power index");
+			pextra += sprintf(pextra, "\n [ ant : <A = 1, B = 2, C = 4, D = 8> ,2T ex: AB=3 BC=6 CD=12");
+			pextra += sprintf(pextra, "\n [ txmode : < 0 = CONTINUOUS_TX, 1 = PACKET_TX, 2 = SINGLE_TONE_TX, 3 = CARRIER_SUPPRISSION_TX, 4 = SINGLE_CARRIER_TX>\n");
+			wrqu->data.length = strlen(extra);
+			return status;
+
+		} else {
+			char *pextra = extra;
+			RTW_INFO("Got format [ch=%d,bw=%d,rate=%d,pwr=%d,ant=%d,tx=%d]\n", channel, bandwidth, rate, txpower, ant, txmode);
+			_rtw_memset(extra, 0, wrqu->data.length);
+			sprintf(extra, "Change Current channel %d to channel %d", padapter->mppriv.channel , channel);
+			padapter->mppriv.channel = channel;
+			SetChannel(padapter);
+			pHalData->current_channel = channel;
+
+			if (bandwidth == 1)
+				bandwidth = CHANNEL_WIDTH_40;
+			else if (bandwidth == 2)
+				bandwidth = CHANNEL_WIDTH_80;
+			pextra = extra + strlen(pextra);
+			pextra += sprintf(pextra, "\nChange Current Bandwidth %d to Bandwidth %d", padapter->mppriv.bandwidth, bandwidth);
+			padapter->mppriv.bandwidth = (u8)bandwidth;
+			padapter->mppriv.preamble = sg;
+			SetBandwidth(padapter);
+			pHalData->current_channel_bw = bandwidth;
+
+			pextra += sprintf(pextra, "\nSet power level :%d", txpower);
+			padapter->mppriv.txpoweridx = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)txpower;
+			pMptCtx->TxPwrLevel[RF_PATH_D]  = (u8)txpower;
+			SetTxPower(padapter);
+
+			RTW_INFO("%s: bw=%d sg=%d\n", __func__, bandwidth, sg);
+
+			if (rate <= 0x7f)
+				rate = wifirate2_ratetbl_inx((u8)rate);
+			else if (rate < 0xC8)
+				rate = (rate - 0x80 + MPT_RATE_MCS0);
+			/*HT  rate 0x80(MCS0)  ~ 0x8F(MCS15) ~ 0x9F(MCS31) 128~159
+			VHT1SS~2SS rate 0xA0 (VHT1SS_MCS0 44) ~ 0xB3 (VHT2SS_MCS9 #63) 160~179
+			VHT rate 0xB4 (VHT3SS_MCS0 64) ~ 0xC7 (VHT2SS_MCS9 #83) 180~199
+			else
+			VHT rate 0x90(VHT1SS_MCS0) ~ 0x99(VHT1SS_MCS9) 144~153
+			rate =(rate - MPT_RATE_VHT1SS_MCS0);
+			*/
+			RTW_INFO("%s: rate index=%d\n", __func__, rate);
+			if (rate >= MPT_RATE_LAST)
+				return -EINVAL;
+			pextra += sprintf(pextra, "\nSet data rate to %d index %d", padapter->mppriv.rateidx, rate);
+
+			padapter->mppriv.rateidx = rate;
+			pMptCtx->mpt_rate_index = rate;
+			SetDataRate(padapter);
+
+			pextra += sprintf(pextra, "\nSet Antenna Path :%d", ant);
+			switch (ant) {
+			case 1:
+				antenna = ANTENNA_A;
+				break;
+			case 2:
+				antenna = ANTENNA_B;
+				break;
+			case 4:
+				antenna = ANTENNA_C;
+				break;
+			case 8:
+				antenna = ANTENNA_D;
+				break;
+			case 3:
+				antenna = ANTENNA_AB;
+				break;
+			case 5:
+				antenna = ANTENNA_AC;
+				break;
+			case 9:
+				antenna = ANTENNA_AD;
+				break;
+			case 6:
+				antenna = ANTENNA_BC;
+				break;
+			case 10:
+				antenna = ANTENNA_BD;
+				break;
+			case 12:
+				antenna = ANTENNA_CD;
+				break;
+			case 7:
+				antenna = ANTENNA_ABC;
+				break;
+			case 14:
+				antenna = ANTENNA_BCD;
+				break;
+			case 11:
+				antenna = ANTENNA_ABD;
+				break;
+			case 15:
+				antenna = ANTENNA_ABCD;
+				break;
+			}
+			RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
+			padapter->mppriv.antenna_tx = antenna;
+			padapter->mppriv.antenna_rx = antenna;
+			pHalData->antenna_tx_path = antenna;
+			SetAntenna(padapter);
+
+			if (txmode == 0)
+				pmp_priv->mode = MP_CONTINUOUS_TX;
+			else if (txmode == 1) {
+				pmp_priv->mode = MP_PACKET_TX;
+				pmp_priv->tx.count = count;
+			} else if (txmode == 2)
+				pmp_priv->mode = MP_SINGLE_TONE_TX;
+			else if (txmode == 3)
+				pmp_priv->mode = MP_CARRIER_SUPPRISSION_TX;
+			else if (txmode == 4)
+				pmp_priv->mode = MP_SINGLE_CARRIER_TX;
+
+			status = rtw_mp_pretx_proc(padapter, bStartTest, extra);
+		}
+
+	}
+
+	wrqu->data.length = strlen(extra);
+	return status;
 }
 
 
 int rtw_mp_rx(struct net_device *dev,
-			   struct iw_request_info *info,
-			   union iwreq_data *wrqu, char *extra)
+	      struct iw_request_info *info,
+	      union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	struct mp_priv *pmp_priv = &padapter->mppriv;
-	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.MptCtx);
-
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+	char *pextra = extra;
 	u32 bandwidth = 0, sg = 0, channel = 6, ant = 0;
 	u16 antenna = 0;
 	u8 bStartRx = 0;
 
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
-			return -EFAULT;
+		return -EFAULT;
 
 #ifdef CONFIG_CONCURRENT_MODE
-		if (padapter->adapter_type == SECONDARY_ADAPTER) {
-			sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
-			wrqu->data.length = strlen(extra);
-			return 0;
-		}
+	if (!is_primary_adapter(padapter)) {
+		sprintf(extra, "Error: MP mode can't support Virtual Adapter, Please to use main Adapter.\n");
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
 #endif
 
 	if (strncmp(extra, "stop", 4) == 0) {
@@ -1826,36 +1951,38 @@ int rtw_mp_rx(struct net_device *dev,
 		return 0;
 
 	} else if (sscanf(extra, "ch=%d,bw=%d,ant=%d", &channel, &bandwidth, &ant) < 3) {
-		DBG_871X("Invalid format [ch=%d,bw=%d,ant=%d]\n", channel, bandwidth, ant);
+		RTW_INFO("Invalid format [ch=%d,bw=%d,ant=%d]\n", channel, bandwidth, ant);
 		_rtw_memset(extra, 0, wrqu->data.length);
-		sprintf(extra, "\n Please input correct format as bleow:\n");
-		sprintf(extra, "%s\t ch=%d,bw=%d,ant=%d\n", extra, channel, bandwidth, ant);
-		sprintf(extra, "%s\n [ ch : BGN = <1~14> , A or AC = <36~165> ]", extra);
-		sprintf(extra, "%s\n [ bw : Bandwidth: 0 = 20M, 1 = 40M, 2 = 80M ]", extra);
-		sprintf(extra, "%s\n [ ant : <A = 1, B = 2, C = 4, D = 8> ,2T ex: AB=3 BC=6 CD=12", extra);
+		pextra += sprintf(pextra, "\n Please input correct format as bleow:\n");
+		pextra += sprintf(pextra, "\t ch=%d,bw=%d,ant=%d\n", channel, bandwidth, ant);
+		pextra += sprintf(pextra, "\n [ ch : BGN = <1~14> , A or AC = <36~165> ]");
+		pextra += sprintf(pextra, "\n [ bw : Bandwidth: 0 = 20M, 1 = 40M, 2 = 80M ]");
+		pextra += sprintf(pextra, "\n [ ant : <A = 1, B = 2, C = 4, D = 8> ,2T ex: AB=3 BC=6 CD=12");
 		wrqu->data.length = strlen(extra);
 		return 0;
 
 	} else {
+		char *pextra = extra;
 		bStartRx = 1;
-		DBG_871X("Got format [ch=%d,bw=%d,ant=%d]\n", channel, bandwidth, ant);
+		RTW_INFO("Got format [ch=%d,bw=%d,ant=%d]\n", channel, bandwidth, ant);
 		_rtw_memset(extra, 0, wrqu->data.length);
 		sprintf(extra, "Change Current channel %d to channel %d", padapter->mppriv.channel , channel);
 		padapter->mppriv.channel = channel;
 		SetChannel(padapter);
-		pHalData->CurrentChannel = channel;
+		pHalData->current_channel = channel;
 
 		if (bandwidth == 1)
 			bandwidth = CHANNEL_WIDTH_40;
 		else if (bandwidth == 2)
 			bandwidth = CHANNEL_WIDTH_80;
-		sprintf(extra, "%s\nChange Current Bandwidth %d to Bandwidth %d", extra, padapter->mppriv.bandwidth , bandwidth);
+		pextra = extra + strlen(extra);
+		pextra += sprintf(pextra, "\nChange Current Bandwidth %d to Bandwidth %d", padapter->mppriv.bandwidth, bandwidth);
 		padapter->mppriv.bandwidth = (u8)bandwidth;
 		padapter->mppriv.preamble = sg;
 		SetBandwidth(padapter);
-		pHalData->CurrentChannelBW = bandwidth;
+		pHalData->current_channel_bw = bandwidth;
 
-		sprintf(extra, "%s\nSet Antenna Path :%d",  extra, ant);
+		pextra += sprintf(pextra, "\nSet Antenna Path :%d", ant);
 		switch (ant) {
 		case 1:
 			antenna = ANTENNA_A;
@@ -1900,13 +2027,13 @@ int rtw_mp_rx(struct net_device *dev,
 			antenna = ANTENNA_ABCD;
 			break;
 		}
-		DBG_871X("%s: antenna=0x%x\n", __func__, antenna);
+		RTW_INFO("%s: antenna=0x%x\n", __func__, antenna);
 		padapter->mppriv.antenna_tx = antenna;
 		padapter->mppriv.antenna_rx = antenna;
-		pHalData->AntennaTxPath = antenna;
+		pHalData->antenna_tx_path = antenna;
 		SetAntenna(padapter);
 
-		sprintf(extra, "%s\nstart Rx", extra);
+		strcat(extra, "\nstart Rx");
 		SetPacketRx(padapter, bStartRx, _FALSE);
 	}
 	wrqu->data.length = strlen(extra);
@@ -1914,19 +2041,110 @@ int rtw_mp_rx(struct net_device *dev,
 }
 
 
+int rtw_mp_hwtx(struct net_device *dev,
+		struct iw_request_info *info,
+		union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
+
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8821B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	u8		input[wrqu->data.length];
+
+	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	_rtw_memset(&pMptCtx->PMacTxInfo, 0, sizeof(RT_PMAC_TX_INFO));
+	_rtw_memcpy((void *)&pMptCtx->PMacTxInfo, (void *)input, sizeof(RT_PMAC_TX_INFO));
+	_rtw_memset(wrqu->data.pointer, 0, wrqu->data.length);
+
+	if (pMptCtx->PMacTxInfo.bEnPMacTx == 1 && pmp_priv->mode != MP_ON) {
+		sprintf(extra, "MP Tx Running, Please Set PMac Tx Mode Stop\n");
+		RTW_INFO("Error !!! MP Tx Running, Please Set PMac Tx Mode Stop\n");
+	} else {
+		RTW_INFO("To set MAC Tx mode\n");
+		mpt_ProSetPMacTx(padapter);
+		sprintf(extra, "Set PMac Tx Mode OK\n");
+	}
+	wrqu->data.length = strlen(extra);
+#endif
+	return 0;
+
+}
+
+int rtw_mp_pwrlmt(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct registry_priv  *registry_par = &padapter->registrypriv;
+	u8 pwrlimtstat = 0;
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+#ifdef CONFIG_TXPWR_LIMIT
+	pwrlimtstat = registry_par->RegEnableTxPowerLimit;
+	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
+		padapter->registrypriv.RegEnableTxPowerLimit = 0;
+		sprintf(extra, "Turn off Power Limit\n");
+
+	} else if (strncmp(extra, "on", 2) == 0 && strlen(extra) < 3) {
+		padapter->registrypriv.RegEnableTxPowerLimit = 1;
+		sprintf(extra, "Turn on Power Limit\n");
+
+	} else
+#endif
+		sprintf(extra, "Get Power Limit Status:%s\n", (pwrlimtstat == 1) ? "ON" : "OFF");
+
+
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+int rtw_mp_pwrbyrate(struct net_device *dev,
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
+		padapter->registrypriv.RegEnableTxPowerByRate = 0;
+		sprintf(extra, "Turn off Tx Power by Rate\n");
+
+	} else if (strncmp(extra, "on", 2) == 0 && strlen(extra) < 3) {
+		padapter->registrypriv.RegEnableTxPowerByRate = 1;
+		sprintf(extra, "Turn On Tx Power by Rate\n");
+
+	} else {
+		sprintf(extra, "Get Power by Rate Status:%s\n", (padapter->registrypriv.RegEnableTxPowerByRate == 1) ? "ON" : "OFF");
+	}
+
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
 int rtw_efuse_mask_file(struct net_device *dev,
-						struct iw_request_info *info,
-						union iwreq_data *wrqu, char *extra)
+			struct iw_request_info *info,
+			union iwreq_data *wrqu, char *extra)
 {
 	char *rtw_efuse_mask_file_path;
 	u8 Status;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	
+
 	_rtw_memset(maskfileBuffer, 0x00, sizeof(maskfileBuffer));
 
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
 
+	*(extra + wrqu->data.length) = '\0';
 	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
 		padapter->registrypriv.boffefusemask = 1;
 		sprintf(extra, "Turn off Efuse Mask\n");
@@ -1939,18 +2157,63 @@ int rtw_efuse_mask_file(struct net_device *dev,
 		wrqu->data.length = strlen(extra);
 		return 0;
 	}
+	if (strncmp(extra, "data,", 5) == 0) {
+		u8	*pch, *pdata;
+		char	*ptmp, tmp;
+		u8	count = 0;
+		u8	i = 0;
+		u32	datalen = 0;
+
+		ptmp = extra;
+		pch = strsep(&ptmp, ",");
+
+		if ((pch == NULL) || (strlen(pch) == 0)) {
+			RTW_INFO("%s: parameter error(no cmd)!\n", __func__);
+			return -EFAULT;
+		}
+
+		do {
+			pch = strsep(&ptmp, ":");
+			if ((pch == NULL) || (strlen(pch) == 0))
+				break;
+			if (strlen(pch) != 2
+				|| IsHexDigit(*pch) == _FALSE
+				|| IsHexDigit(*(pch + 1)) == _FALSE
+				|| sscanf(pch, "%hhx", &tmp) != 1
+			) {
+				RTW_INFO("%s: invalid 8-bit hex! input format: data,01:23:45:67:89:ab:cd:ef...\n", __func__);
+				return -EFAULT;
+			}
+			maskfileBuffer[count++] = tmp;
+
+		 } while (count < 64);
+
+		for (i = 0; i < count; i++)
+			sprintf(extra, "%s:%02x", extra, maskfileBuffer[i]);
+
+		padapter->registrypriv.bFileMaskEfuse = _TRUE;
+
+		sprintf(extra, "%s\nLoad Efuse Mask data %d hex ok\n", extra, count);
+		wrqu->data.length = strlen(extra);
+		return 0;
+	}
 	rtw_efuse_mask_file_path = extra;
 
 	if (rtw_is_file_readable(rtw_efuse_mask_file_path) == _TRUE) {
-		DBG_871X("%s do rtw_efuse_mask_file_read = %s! ,sizeof maskfileBuffer %zu\n", __func__, rtw_efuse_mask_file_path, sizeof(maskfileBuffer));
+		RTW_INFO("%s do rtw_efuse_mask_file_read = %s! ,sizeof maskfileBuffer %zu\n", __func__, rtw_efuse_mask_file_path, sizeof(maskfileBuffer));
 		Status = rtw_efuse_file_read(padapter, rtw_efuse_mask_file_path, maskfileBuffer, sizeof(maskfileBuffer));
-		if (Status == _TRUE)
+		if (Status == _TRUE) {
 			padapter->registrypriv.bFileMaskEfuse = _TRUE;
-		sprintf(extra, "efuse mask file read OK\n");
+			sprintf(extra, "efuse mask file read OK\n");
+		} else {
+			padapter->registrypriv.bFileMaskEfuse = _FALSE;
+			sprintf(extra, "read efuse mask file FAIL\n");
+			RTW_INFO("%s rtw_efuse_file_read mask fail!\n", __func__);
+		}
 	} else {
 		padapter->registrypriv.bFileMaskEfuse = _FALSE;
 		sprintf(extra, "efuse mask file readable FAIL\n");
-		DBG_871X("%s rtw_is_file_readable fail!\n", __func__);
+		RTW_INFO("%s rtw_is_file_readable fail!\n", __func__);
 	}
 	wrqu->data.length = strlen(extra);
 	return 0;
@@ -1958,31 +2221,74 @@ int rtw_efuse_mask_file(struct net_device *dev,
 
 
 int rtw_efuse_file_map(struct net_device *dev,
-					   struct iw_request_info *info,
-					   union iwreq_data *wrqu, char *extra)
+		       struct iw_request_info *info,
+		       union iwreq_data *wrqu, char *extra)
 {
 	char *rtw_efuse_file_map_path;
 	u8 Status;
 	PEFUSE_HAL pEfuseHal;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+
 	pEfuseHal = &pHalData->EfuseHal;
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
 
 	rtw_efuse_file_map_path = extra;
 
+	_rtw_memset(pEfuseHal->fakeEfuseModifiedMap, 0xFF, EFUSE_MAX_MAP_LEN);
+
 	if (rtw_is_file_readable(rtw_efuse_file_map_path) == _TRUE) {
-		DBG_871X("%s do rtw_efuse_mask_file_read = %s!\n", __func__, rtw_efuse_file_map_path);
+		RTW_INFO("%s do rtw_efuse_mask_file_read = %s!\n", __func__, rtw_efuse_file_map_path);
 		Status = rtw_efuse_file_read(padapter, rtw_efuse_file_map_path, pEfuseHal->fakeEfuseModifiedMap, sizeof(pEfuseHal->fakeEfuseModifiedMap));
-		if (Status == _TRUE)
+		if (Status == _TRUE) {
+			pmp_priv->bloadefusemap = _TRUE;
 			sprintf(extra, "efuse file file_read OK\n");
-		else
+		} else {
+			pmp_priv->bloadefusemap = _FALSE;
 			sprintf(extra, "efuse file file_read FAIL\n");
+		}
 	} else {
 		sprintf(extra, "efuse file readable FAIL\n");
-		DBG_871X("%s rtw_is_file_readable fail!\n", __func__);
+		RTW_INFO("%s rtw_is_file_readable fail!\n", __func__);
+	}
+	wrqu->data.length = strlen(extra);
+	return 0;
+}
+
+int rtw_bt_efuse_file_map(struct net_device *dev,
+				struct iw_request_info *info,
+				union iwreq_data *wrqu, char *extra)
+{
+	char *rtw_efuse_file_map_path;
+	u8 Status;
+	PEFUSE_HAL pEfuseHal;
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+
+	pEfuseHal = &pHalData->EfuseHal;
+	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
+		return -EFAULT;
+
+	rtw_efuse_file_map_path = extra;
+
+	_rtw_memset(pEfuseHal->fakeBTEfuseModifiedMap, 0xFF, EFUSE_BT_MAX_MAP_LEN);
+
+	if (rtw_is_file_readable(rtw_efuse_file_map_path) == _TRUE) {
+		RTW_INFO("%s do rtw_efuse_mask_file_read = %s!\n", __func__, rtw_efuse_file_map_path);
+		Status = rtw_efuse_file_read(padapter, rtw_efuse_file_map_path, pEfuseHal->fakeBTEfuseModifiedMap, sizeof(pEfuseHal->fakeBTEfuseModifiedMap));
+		if (Status == _TRUE) {
+			pmp_priv->bloadBTefusemap = _TRUE;
+			sprintf(extra, "BT efuse file file_read OK\n");
+		} else {
+			pmp_priv->bloadBTefusemap = _FALSE;
+			sprintf(extra, "BT efuse file file_read FAIL\n");
+		}
+	} else {
+		sprintf(extra, "BT efuse file readable FAIL\n");
+		RTW_INFO("%s rtw_is_file_readable fail!\n", __func__);
 	}
 	wrqu->data.length = strlen(extra);
 	return 0;
@@ -1990,15 +2296,15 @@ int rtw_efuse_file_map(struct net_device *dev,
 
 #if defined(CONFIG_RTL8723B)
 int rtw_mp_SetBT(struct net_device *dev,
-				 struct iw_request_info *info,
-				 union iwreq_data *wrqu, char *extra)
+		 struct iw_request_info *info,
+		 union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	struct hal_ops *pHalFunc = &padapter->HalFunc;
+	struct hal_ops *pHalFunc = &padapter->hal_func;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 
 	BT_REQ_CMD	BtReq;
-	PMPT_CONTEXT	pMptCtx = &(padapter->mppriv.MptCtx);
+	PMPT_CONTEXT	pMptCtx = &(padapter->mppriv.mpt_ctx);
 	PBT_RSP_CMD	pBtRsp = (PBT_RSP_CMD)&pMptCtx->mptOutBuf[0];
 	char	input[128];
 	char *pch, *ptmp, *token, *tmp[2] = {0x00, 0x00};
@@ -2013,10 +2319,13 @@ int rtw_mp_SetBT(struct net_device *dev,
 
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
+
 	if (strlen(extra) < 1)
 		return -EFAULT;
 
-	DBG_871X("%s:iwpriv in=%s\n", __func__, extra);
+	RTW_INFO("%s:iwpriv in=%s\n", __func__, extra);
 	ready = strncmp(extra, "ready", 5);
 	testmode = strncmp(extra, "testmode", 8); /* strncmp TRUE is 0*/
 	trxparam = strncmp(extra, "trxparam", 8);
@@ -2029,10 +2338,10 @@ int rtw_mp_SetBT(struct net_device *dev,
 
 	if (strncmp(extra, "dlbt", 4) == 0) {
 		pHalData->LastHMEBoxNum = 0;
-		padapter->bBTFWReady = _FALSE;
+		pHalData->bBTFWReady = _FALSE;
 		rtw_write8(padapter, 0xa3, 0x05);
 		BTStatus = rtw_read8(padapter, 0xa0);
-		DBG_871X("%s: btwmap before read 0xa0 BT Status =0x%x\n", __func__, BTStatus);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __func__, BTStatus);
 		if (BTStatus != 0x04) {
 			sprintf(extra, "BT Status not Active DLFW FAIL\n");
 			goto exit;
@@ -2061,12 +2370,12 @@ int rtw_mp_SetBT(struct net_device *dev,
 		pBTFirmware = (PRT_MP_FIRMWARE)rtw_zmalloc(sizeof(RT_MP_FIRMWARE));
 		if (pBTFirmware == NULL)
 			goto exit;
-		padapter->bBTFWReady = _FALSE;
+		pHalData->bBTFWReady = _FALSE;
 		FirmwareDownloadBT(padapter, pBTFirmware);
 		if (pBTFirmware)
 			rtw_mfree((u8 *)pBTFirmware, sizeof(RT_MP_FIRMWARE));
 
-		DBG_871X("Wait for FirmwareDownloadBT fw boot!\n");
+		RTW_INFO("Wait for FirmwareDownloadBT fw boot!\n");
 		rtw_msleep_os(2000);
 		_rtw_memset(extra, '\0', wrqu->data.length);
 		BtReq.opCodeVer = 1;
@@ -2075,7 +2384,7 @@ int rtw_mp_SetBT(struct net_device *dev,
 		mptbt_BtControlProcess(padapter, &BtReq);
 		rtw_msleep_os(100);
 
-		DBG_8192C("FirmwareDownloadBT ready = 0x%x 0x%x", pMptCtx->mptOutBuf[4], pMptCtx->mptOutBuf[5]);
+		RTW_INFO("FirmwareDownloadBT ready = 0x%x 0x%x", pMptCtx->mptOutBuf[4], pMptCtx->mptOutBuf[5]);
 		if ((pMptCtx->mptOutBuf[4] == 0x00) && (pMptCtx->mptOutBuf[5] == 0x00)) {
 
 			if (padapter->mppriv.bTxBufCkFail == _TRUE)
@@ -2090,10 +2399,10 @@ int rtw_mp_SetBT(struct net_device *dev,
 	}
 	if (strncmp(extra, "dlfw", 4) == 0) {
 		pHalData->LastHMEBoxNum = 0;
-		padapter->bBTFWReady = _FALSE;
+		pHalData->bBTFWReady = _FALSE;
 		rtw_write8(padapter, 0xa3, 0x05);
 		BTStatus = rtw_read8(padapter, 0xa0);
-		DBG_871X("%s: btwmap before read 0xa0 BT Status =0x%x\n", __func__, BTStatus);
+		RTW_INFO("%s: btwmap before read 0xa0 BT Status =0x%x\n", __func__, BTStatus);
 		if (BTStatus != 0x04) {
 			sprintf(extra, "BT Status not Active DLFW FAIL\n");
 			goto exit;
@@ -2123,19 +2432,19 @@ int rtw_mp_SetBT(struct net_device *dev,
 
 #if defined(CONFIG_PLATFORM_SPRD) && (MP_DRIVER == 1)
 		/* Pull up BT reset pin.*/
-		DBG_871X("%s: pull up BT reset pin when bt start mp test\n", __func__);
+		RTW_INFO("%s: pull up BT reset pin when bt start mp test\n", __func__);
 		rtw_wifi_gpio_wlan_ctrl(WLAN_BT_PWDN_ON);
 #endif
-		DBG_871X(" FirmwareDownload!\n");
+		RTW_INFO(" FirmwareDownload!\n");
 
 #if defined(CONFIG_RTL8723B)
 		status = rtl8723b_FirmwareDownload(padapter, _FALSE);
 #endif
-		DBG_871X("Wait for FirmwareDownloadBT fw boot!\n");
+		RTW_INFO("Wait for FirmwareDownloadBT fw boot!\n");
 		rtw_msleep_os(1000);
 #ifdef CONFIG_BT_COEXIST
 		rtw_btcoex_HaltNotify(padapter);
-		DBG_871X("SetBT btcoex HaltNotify !\n");
+		RTW_INFO("SetBT btcoex HaltNotify !\n");
 		/*hal_btcoex1ant_SetAntPath(padapter);*/
 		rtw_btcoex_SetManualControl(padapter, _TRUE);
 #endif
@@ -2146,7 +2455,7 @@ int rtw_mp_SetBT(struct net_device *dev,
 		mptbt_BtControlProcess(padapter, &BtReq);
 		rtw_msleep_os(200);
 
-		DBG_8192C("FirmwareDownloadBT ready = 0x%x 0x%x", pMptCtx->mptOutBuf[4], pMptCtx->mptOutBuf[5]);
+		RTW_INFO("FirmwareDownloadBT ready = 0x%x 0x%x", pMptCtx->mptOutBuf[4], pMptCtx->mptOutBuf[5]);
 		if ((pMptCtx->mptOutBuf[4] == 0x00) && (pMptCtx->mptOutBuf[5] == 0x00)) {
 			if (padapter->mppriv.bTxBufCkFail == _TRUE)
 				sprintf(extra, "check TxBuf Fail.\n");
@@ -2164,7 +2473,7 @@ int rtw_mp_SetBT(struct net_device *dev,
 	}
 
 	if (strncmp(extra, "down", 4) == 0) {
-		DBG_871X("SetBT down for to hal_init !\n");
+		RTW_INFO("SetBT down for to hal_init !\n");
 #ifdef CONFIG_BT_COEXIST
 		rtw_btcoex_SetManualControl(padapter, _FALSE);
 		rtw_btcoex_Initialize(padapter);
@@ -2185,26 +2494,26 @@ int rtw_mp_SetBT(struct net_device *dev,
 		goto exit;
 	}
 	if (strncmp(extra, "disable", 7) == 0) {
-		DBG_871X("SetBT disable !\n");
+		RTW_INFO("SetBT disable !\n");
 		rtw_write32(padapter, 0x6a, (rtw_read32(padapter, 0x6a) & 0xFFFFFFFB));
 		rtw_msleep_os(500);
 		goto exit;
 	}
 	if (strncmp(extra, "enable", 6) == 0) {
-		DBG_871X("SetBT enable !\n");
+		RTW_INFO("SetBT enable !\n");
 		rtw_write32(padapter, 0x6a, (rtw_read32(padapter, 0x6a) | 0x00000004));
 		rtw_msleep_os(500);
 		goto exit;
 	}
 	if (strncmp(extra, "h2c", 3) == 0) {
-		DBG_871X("SetBT h2c !\n");
-		padapter->bBTFWReady = _TRUE;
+		RTW_INFO("SetBT h2c !\n");
+		pHalData->bBTFWReady = _TRUE;
 		rtw_hal_fill_h2c_cmd(padapter, 0x63, 1, u1H2CBtMpOperParm);
 		goto exit;
 	}
 	if (strncmp(extra, "2ant", 4) == 0) {
-		DBG_871X("Set BT 2ant use!\n");
-		PHY_SetMacReg(padapter, 0x67, BIT5, 0x1);
+		RTW_INFO("Set BT 2ant use!\n");
+		phy_set_mac_reg(padapter, 0x67, BIT5, 0x1);
 		rtw_write32(padapter, 0x948, 0000);
 
 		goto exit;
@@ -2240,16 +2549,16 @@ int rtw_mp_SetBT(struct net_device *dev,
 		if (cnts < 1)
 			return -EFAULT;
 
-		DBG_871X("%s: cnts=%d\n", __func__, cnts);
-		DBG_871X("%s: data=%s\n", __func__, tmp[1]);
+		RTW_INFO("%s: cnts=%d\n", __func__, cnts);
+		RTW_INFO("%s: data=%s\n", __func__, tmp[1]);
 
 		for (jj = 0, kk = 0; jj < cnts; jj++, kk += 2) {
 			BtReq.pParamStart[jj] = key_2char2num(tmp[1][kk], tmp[1][kk + 1]);
-			/*			DBG_871X("BtReq.pParamStart[%d]=0x%02x\n", jj, BtReq.pParamStart[jj]);*/
+			/*			RTW_INFO("BtReq.pParamStart[%d]=0x%02x\n", jj, BtReq.pParamStart[jj]);*/
 		}
-	} else 
+	} else
 		return -EFAULT;
-		
+
 	if (testmode == 0) {
 		BtReq.opCodeVer = 1;
 		BtReq.OpCode = 1;
@@ -2261,45 +2570,45 @@ int rtw_mp_SetBT(struct net_device *dev,
 		BtReq.paraLength = cnts / 2;
 	}
 	if (setgen == 0) {
-		DBG_871X("%s: BT_SET_GENERAL\n", __func__);
+		RTW_INFO("%s: BT_SET_GENERAL\n", __func__);
 		BtReq.opCodeVer = 1;
 		BtReq.OpCode = 3;/*BT_SET_GENERAL	3*/
 		BtReq.paraLength = cnts / 2;
 	}
 	if (getgen == 0) {
-		DBG_871X("%s: BT_GET_GENERAL\n", __func__);
+		RTW_INFO("%s: BT_GET_GENERAL\n", __func__);
 		BtReq.opCodeVer = 1;
 		BtReq.OpCode = 4;/*BT_GET_GENERAL	4*/
 		BtReq.paraLength = cnts / 2;
 	}
 	if (readtherm == 0) {
-		DBG_871X("%s: BT_GET_GENERAL\n", __func__);
+		RTW_INFO("%s: BT_GET_GENERAL\n", __func__);
 		BtReq.opCodeVer = 1;
 		BtReq.OpCode = 4;/*BT_GET_GENERAL	4*/
 		BtReq.paraLength = cnts / 2;
 	}
 
 	if (testctrl == 0) {
-		DBG_871X("%s: BT_TEST_CTRL\n", __func__);
+		RTW_INFO("%s: BT_TEST_CTRL\n", __func__);
 		BtReq.opCodeVer = 1;
 		BtReq.OpCode = 5;/*BT_TEST_CTRL	5*/
 		BtReq.paraLength = cnts / 2;
 	}
 
-	DBG_871X("%s: Req opCodeVer=%d OpCode=%d paraLength=%d\n",
-			 __func__, BtReq.opCodeVer, BtReq.OpCode, BtReq.paraLength);
+	RTW_INFO("%s: Req opCodeVer=%d OpCode=%d paraLength=%d\n",
+		 __func__, BtReq.opCodeVer, BtReq.OpCode, BtReq.paraLength);
 
 	if (BtReq.paraLength < 1)
 		goto todo;
 	for (i = 0; i < BtReq.paraLength; i++) {
-		DBG_871X("%s: BtReq.pParamStart[%d] = 0x%02x\n",
-				 __func__, i, BtReq.pParamStart[i]);
+		RTW_INFO("%s: BtReq.pParamStart[%d] = 0x%02x\n",
+			 __func__, i, BtReq.pParamStart[i]);
 	}
 
 todo:
 	_rtw_memset(extra, '\0', wrqu->data.length);
 
-	if (padapter->bBTFWReady == _FALSE) {
+	if (pHalData->bBTFWReady == _FALSE) {
 		sprintf(extra, "BTFWReady = FALSE.\n");
 		goto exit;
 	}
@@ -2321,7 +2630,7 @@ todo:
 
 exit:
 	wrqu->data.length = strlen(extra) + 1;
-	DBG_871X("-%s: output len=%d data=%s\n", __func__, wrqu->data.length, extra);
+	RTW_INFO("-%s: output len=%d data=%s\n", __func__, wrqu->data.length, extra);
 
 	return status;
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/mlme_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/mlme_linux.c
index c9659ed53359..3a7bec18d562 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/mlme_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/mlme_linux.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 
 #define _MLME_OSDEP_C_
@@ -30,17 +26,14 @@ void Linkup_workitem_callback(struct work_struct *work)
 	struct mlme_priv *pmlmepriv = container_of(work, struct mlme_priv, Linkup_workitem);
 	_adapter *padapter = container_of(pmlmepriv, _adapter, mlmepriv);
 
-_func_enter_;
 
-	RT_TRACE(_module_mlme_osdep_c_,_drv_info_,("+ Linkup_workitem_callback\n"));
 
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,12))
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
 	kobject_uevent(&padapter->pnetdev->dev.kobj, KOBJ_LINKUP);
 #else
 	kobject_hotplug(&padapter->pnetdev->class_dev.kobj, KOBJ_LINKUP);
 #endif
 
-_func_exit_;
 }
 
 void Linkdown_workitem_callback(struct work_struct *work)
@@ -48,137 +41,47 @@ void Linkdown_workitem_callback(struct work_struct *work)
 	struct mlme_priv *pmlmepriv = container_of(work, struct mlme_priv, Linkdown_workitem);
 	_adapter *padapter = container_of(pmlmepriv, _adapter, mlmepriv);
 
-_func_enter_;
 
-	RT_TRACE(_module_mlme_osdep_c_,_drv_info_,("+ Linkdown_workitem_callback\n"));
 
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,12))
+#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 12))
 	kobject_uevent(&padapter->pnetdev->dev.kobj, KOBJ_LINKDOWN);
 #else
 	kobject_hotplug(&padapter->pnetdev->class_dev.kobj, KOBJ_LINKDOWN);
 #endif
 
-_func_exit_;
-}
-#endif
-
-
-/*
-void sitesurvey_ctrl_handler(void *FunctionContext)
-{
-	_adapter *adapter = (_adapter *)FunctionContext;
-
-	_sitesurvey_ctrl_handler(adapter);
-
-	_set_timer(&adapter->mlmepriv.sitesurveyctrl.sitesurvey_ctrl_timer, 3000);
-}
-*/
-
-void rtw_join_timeout_handler (void *FunctionContext)
-{
-	_adapter *adapter = (_adapter *)FunctionContext;
-	_rtw_join_timeout_handler(adapter);
 }
-
-
-void _rtw_scan_timeout_handler (void *FunctionContext)
-{
-	_adapter *adapter = (_adapter *)FunctionContext;
-	rtw_scan_timeout_handler(adapter);
-}
-
-
-void _dynamic_check_timer_handlder (void *FunctionContext)
-{
-	_adapter *adapter = (_adapter *)FunctionContext;
-
-#if (MP_DRIVER == 1)
-	if (adapter->registrypriv.mp_mode == 1 && adapter->mppriv.mp_dm ==0) //for MP ODM dynamic Tx power tracking
-	{
-		//DBG_871X("_dynamic_check_timer_handlder mp_dm =0 return \n");
-		_set_timer(&adapter->mlmepriv.dynamic_chk_timer, 2000);
-		return;
-	}
-#endif
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if(adapter->pbuddy_adapter)
-		rtw_dynamic_check_timer_handlder(adapter->pbuddy_adapter);
-#endif //CONFIG_CONCURRENT_MODE
-
-	rtw_dynamic_check_timer_handlder(adapter);
-	
-	_set_timer(&adapter->mlmepriv.dynamic_chk_timer, 2000);
-}
-
-#ifdef CONFIG_SET_SCAN_DENY_TIMER
-void _rtw_set_scan_deny_timer_hdl(void *FunctionContext)
-{
-	_adapter *adapter = (_adapter *)FunctionContext;	 
-	rtw_set_scan_deny_timer_hdl(adapter);
-}
-#endif
-
-
-void rtw_init_mlme_timer(_adapter *padapter)
-{
-	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-	_init_timer(&(pmlmepriv->assoc_timer), padapter->pnetdev, rtw_join_timeout_handler, padapter);
-	//_init_timer(&(pmlmepriv->sitesurveyctrl.sitesurvey_ctrl_timer), padapter->pnetdev, sitesurvey_ctrl_handler, padapter);
-	_init_timer(&(pmlmepriv->scan_to_timer), padapter->pnetdev, _rtw_scan_timeout_handler, padapter);
-
-	#ifdef CONFIG_DFS_MASTER
-	_init_timer(&(pmlmepriv->dfs_master_timer), padapter->pnetdev, rtw_dfs_master_timer_hdl, padapter);
-	#endif
-
-	_init_timer(&(pmlmepriv->dynamic_chk_timer), padapter->pnetdev, _dynamic_check_timer_handlder, padapter);
-
-	#ifdef CONFIG_SET_SCAN_DENY_TIMER
-	_init_timer(&(pmlmepriv->set_scan_deny_timer), padapter->pnetdev, _rtw_set_scan_deny_timer_hdl, padapter);
-	#endif
-
-#ifdef RTK_DMP_PLATFORM
-	_init_workitem(&(pmlmepriv->Linkup_workitem), Linkup_workitem_callback, padapter);
-	_init_workitem(&(pmlmepriv->Linkdown_workitem), Linkdown_workitem_callback, padapter);
 #endif
 
-}
-
 extern void rtw_indicate_wx_assoc_event(_adapter *padapter);
 extern void rtw_indicate_wx_disassoc_event(_adapter *padapter);
 
 void rtw_os_indicate_connect(_adapter *adapter)
 {
 	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
-_func_enter_;	
 
 #ifdef CONFIG_IOCTL_CFG80211
-	if ( (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)==_TRUE ) || 
-		(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)==_TRUE ) )
-	{
+	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
+	    (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
 		rtw_cfg80211_ibss_indicate_connect(adapter);
-	}
 	else
 		rtw_cfg80211_indicate_connect(adapter);
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 	rtw_indicate_wx_assoc_event(adapter);
-	netif_carrier_on(adapter->pnetdev);
+	rtw_netif_carrier_on(adapter->pnetdev);
 
-	if(adapter->pid[2] !=0)
+	if (adapter->pid[2] != 0)
 		rtw_signal_process(adapter->pid[2], SIGALRM);
 
 #ifdef RTK_DMP_PLATFORM
 	_set_workitem(&adapter->mlmepriv.Linkup_workitem);
 #endif
 
-_func_exit_;	
 
 }
 
 extern void indicate_wx_scan_complete_event(_adapter *padapter);
-void rtw_os_indicate_scan_done( _adapter *padapter, bool aborted)
+void rtw_os_indicate_scan_done(_adapter *padapter, bool aborted)
 {
 #ifdef CONFIG_IOCTL_CFG80211
 	rtw_cfg80211_indicate_scan_done(padapter, aborted);
@@ -186,57 +89,49 @@ void rtw_os_indicate_scan_done( _adapter *padapter, bool aborted)
 	indicate_wx_scan_complete_event(padapter);
 }
 
-static RT_PMKID_LIST   backupPMKIDList[ NUM_PMKID_CACHE ];
-void rtw_reset_securitypriv( _adapter *adapter )
+static RT_PMKID_LIST   backupPMKIDList[NUM_PMKID_CACHE];
+void rtw_reset_securitypriv(_adapter *adapter)
 {
 	u8	backupPMKIDIndex = 0;
 	u8	backupTKIPCountermeasure = 0x00;
 	u32	backupTKIPcountermeasure_time = 0;
-	// add for CONFIG_IEEE80211W, none 11w also can use
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
 	_irqL irqL;
 	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	
+
 	_enter_critical_bh(&adapter->security_key_mutex, &irqL);
-	
-	if(adapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)//802.1x
-	{		 
-		// Added by Albert 2009/02/18
-		// 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.
-
-		_rtw_memset( &backupPMKIDList[ 0 ], 0x00, sizeof( RT_PMKID_LIST ) * NUM_PMKID_CACHE );
-
-		_rtw_memcpy( &backupPMKIDList[ 0 ], &adapter->securitypriv.PMKIDList[ 0 ], sizeof( RT_PMKID_LIST ) * NUM_PMKID_CACHE );
+
+	if (adapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) { /* 802.1x */
+		/* Added by Albert 2009/02/18 */
+		/* 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. */
+
+		_rtw_memset(&backupPMKIDList[0], 0x00, sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
+
+		_rtw_memcpy(&backupPMKIDList[0], &adapter->securitypriv.PMKIDList[0], sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
 		backupPMKIDIndex = adapter->securitypriv.PMKIDIndex;
 		backupTKIPCountermeasure = adapter->securitypriv.btkip_countermeasure;
-		backupTKIPcountermeasure_time = adapter->securitypriv.btkip_countermeasure_time;		
-#ifdef CONFIG_IEEE80211W
-		//reset RX BIP packet number
-		pmlmeext->mgnt_80211w_IPN_rx = 0;
-#endif //CONFIG_IEEE80211W
-		_rtw_memset((unsigned char *)&adapter->securitypriv, 0, sizeof (struct security_priv));
-		//_init_timer(&(adapter->securitypriv.tkip_timer),adapter->pnetdev, rtw_use_tkipkey_handler, adapter);
-
-		// Added by Albert 2009/02/18
-		// Restore the PMK information to securitypriv structure for the following connection.
-		_rtw_memcpy( &adapter->securitypriv.PMKIDList[ 0 ], &backupPMKIDList[ 0 ], sizeof( RT_PMKID_LIST ) * NUM_PMKID_CACHE );
+		backupTKIPcountermeasure_time = adapter->securitypriv.btkip_countermeasure_time;
+		_rtw_memset((unsigned char *)&adapter->securitypriv, 0, sizeof(struct security_priv));
+
+		/* Added by Albert 2009/02/18 */
+		/* Restore the PMK information to securitypriv structure for the following connection. */
+		_rtw_memcpy(&adapter->securitypriv.PMKIDList[0], &backupPMKIDList[0], sizeof(RT_PMKID_LIST) * NUM_PMKID_CACHE);
 		adapter->securitypriv.PMKIDIndex = backupPMKIDIndex;
 		adapter->securitypriv.btkip_countermeasure = backupTKIPCountermeasure;
-		adapter->securitypriv.btkip_countermeasure_time = backupTKIPcountermeasure_time;		
+		adapter->securitypriv.btkip_countermeasure_time = backupTKIPcountermeasure_time;
 
 		adapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
 		adapter->securitypriv.ndisencryptstatus = Ndis802_11WEPDisabled;
 
-	}
-	else //reset values in securitypriv 
-	{
-		//if(adapter->mlmepriv.fw_state & WIFI_STATION_STATE)
-		//{
-		struct security_priv *psec_priv=&adapter->securitypriv;
+	} else { /* reset values in securitypriv */
+		/* if(adapter->mlmepriv.fw_state & WIFI_STATION_STATE) */
+		/* { */
+		struct security_priv *psec_priv = &adapter->securitypriv;
 
-		psec_priv->dot11AuthAlgrthm =dot11AuthAlgrthm_Open;  //open system
+		psec_priv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
 		psec_priv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
 		psec_priv->dot11PrivacyKeyIndex = 0;
 
@@ -245,157 +140,79 @@ void rtw_reset_securitypriv( _adapter *adapter )
 
 		psec_priv->ndisauthtype = Ndis802_11AuthModeOpen;
 		psec_priv->ndisencryptstatus = Ndis802_11WEPDisabled;
-		//}
+		/* } */
 	}
-	// add for CONFIG_IEEE80211W, none 11w also can use
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
 	_exit_critical_bh(&adapter->security_key_mutex, &irqL);
 
-	DBG_871X(FUNC_ADPT_FMT" - End to Disconnect\n", FUNC_ADPT_ARG(adapter));
+	RTW_INFO(FUNC_ADPT_FMT" - End to Disconnect\n", FUNC_ADPT_ARG(adapter));
 }
 
 void rtw_os_indicate_disconnect(_adapter *adapter,  u16 reason, u8 locally_generated)
 {
-	//RT_PMKID_LIST   backupPMKIDList[ NUM_PMKID_CACHE ];
+	/* RT_PMKID_LIST   backupPMKIDList[NUM_PMKID_CACHE]; */
 
-_func_enter_;
 
-	netif_carrier_off(adapter->pnetdev); // Do it first for tx broadcast pkt after disconnection issue!
+	rtw_netif_carrier_off(adapter->pnetdev); /* Do it first for tx broadcast pkt after disconnection issue! */
 
 #ifdef CONFIG_IOCTL_CFG80211
 	rtw_cfg80211_indicate_disconnect(adapter,  reason, locally_generated);
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 	rtw_indicate_wx_disassoc_event(adapter);
 
 #ifdef RTK_DMP_PLATFORM
 	_set_workitem(&adapter->mlmepriv.Linkdown_workitem);
 #endif
-	 //modify for CONFIG_IEEE80211W, none 11w also can use the same command
-	 rtw_reset_securitypriv_cmd(adapter);
+	/* modify for CONFIG_IEEE80211W, none 11w also can use the same command */
+	rtw_reset_securitypriv_cmd(adapter);
 
-_func_exit_;
 
 }
 
-void rtw_report_sec_ie(_adapter *adapter,u8 authmode,u8 *sec_ie)
+void rtw_report_sec_ie(_adapter *adapter, u8 authmode, u8 *sec_ie)
 {
 	uint	len;
-	u8	*buff,*p,i;
+	u8	*buff, *p, i;
 	union iwreq_data wrqu;
 
-_func_enter_;
 
-	RT_TRACE(_module_mlme_osdep_c_,_drv_info_,("+rtw_report_sec_ie, authmode=%d\n", authmode));
 
 	buff = NULL;
-	if(authmode==_WPA_IE_ID_)
-	{
-		RT_TRACE(_module_mlme_osdep_c_,_drv_info_,("rtw_report_sec_ie, authmode=%d\n", authmode));
+	if (authmode == _WPA_IE_ID_) {
 
 		buff = rtw_zmalloc(IW_CUSTOM_MAX);
 		if (NULL == buff) {
-			DBG_871X(FUNC_ADPT_FMT ": alloc memory FAIL!!\n",
-				FUNC_ADPT_ARG(adapter));
+			RTW_INFO(FUNC_ADPT_FMT ": alloc memory FAIL!!\n",
+				 FUNC_ADPT_ARG(adapter));
 			return;
 		}
 		p = buff;
 
-		p+=sprintf(p,"ASSOCINFO(ReqIEs=");
+		p += sprintf(p, "ASSOCINFO(ReqIEs=");
 
-		len = sec_ie[1]+2;
-		len = (len < IW_CUSTOM_MAX) ? len:IW_CUSTOM_MAX;
-			
-		for(i=0;i<len;i++){
-			p+=sprintf(p,"%02x",sec_ie[i]);
-		}
+		len = sec_ie[1] + 2;
+		len = (len < IW_CUSTOM_MAX) ? len : IW_CUSTOM_MAX;
+
+		for (i = 0; i < len; i++)
+			p += sprintf(p, "%02x", sec_ie[i]);
 
-		p+=sprintf(p,")");
+		p += sprintf(p, ")");
 
-		_rtw_memset(&wrqu,0,sizeof(wrqu));
+		_rtw_memset(&wrqu, 0, sizeof(wrqu));
 
-		wrqu.data.length=p-buff;
+		wrqu.data.length = p - buff;
 
-		wrqu.data.length = (wrqu.data.length<IW_CUSTOM_MAX) ? wrqu.data.length:IW_CUSTOM_MAX;
+		wrqu.data.length = (wrqu.data.length < IW_CUSTOM_MAX) ? wrqu.data.length : IW_CUSTOM_MAX;
 
 #ifndef CONFIG_IOCTL_CFG80211
-		wireless_send_event(adapter->pnetdev,IWEVCUSTOM,&wrqu,buff);
+		wireless_send_event(adapter->pnetdev, IWEVCUSTOM, &wrqu, buff);
 #endif
 
 		rtw_mfree(buff, IW_CUSTOM_MAX);
 	}
 
-exit:
-
-_func_exit_;
-
-}
-
-void _survey_timer_hdl (void *FunctionContext)
-{
-	_adapter *padapter = (_adapter *)FunctionContext;
-	
-	survey_timer_hdl(padapter);
-}
-
-void _link_timer_hdl (void *FunctionContext)
-{
-	_adapter *padapter = (_adapter *)FunctionContext;
-	link_timer_hdl(padapter);
-}
-
-void _addba_timer_hdl(void *FunctionContext)
-{
-	struct sta_info *psta = (struct sta_info *)FunctionContext;
-	addba_timer_hdl(psta);
-}
-
-#ifdef CONFIG_IEEE80211W
-
-void _sa_query_timer_hdl (void *FunctionContext)
-{
-	struct sta_info *psta = (struct sta_info *)FunctionContext;
-	
-	sa_query_timer_hdl(psta);
-}
-
-void init_dot11w_expire_timer(_adapter *padapter, struct sta_info *psta)
-{
-	_init_timer(&psta->dot11w_expire_timer, padapter->pnetdev, _sa_query_timer_hdl, psta);
-}
-
-#endif //CONFIG_IEEE80211W
-
-void init_addba_retry_timer(_adapter *padapter, struct sta_info *psta)
-{
-
-	_init_timer(&psta->addba_retry_timer, padapter->pnetdev, _addba_timer_hdl, psta);
-}
 
-/*
-void _reauth_timer_hdl(void *FunctionContext)
-{
-	_adapter *padapter = (_adapter *)FunctionContext;
-	reauth_timer_hdl(padapter);
-}
-
-void _reassoc_timer_hdl(void *FunctionContext)
-{
-	_adapter *padapter = (_adapter *)FunctionContext;
-	reassoc_timer_hdl(padapter);
-}
-*/
-
-void init_mlme_ext_timer(_adapter *padapter)
-{	
-	struct	mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-	_init_timer(&pmlmeext->survey_timer, padapter->pnetdev, _survey_timer_hdl, padapter);
-	_init_timer(&pmlmeext->link_timer, padapter->pnetdev, _link_timer_hdl, padapter);
-
-	//_init_timer(&pmlmeext->ADDBA_timer, padapter->pnetdev, _addba_timer_hdl, padapter);
-
-	//_init_timer(&pmlmeext->reauth_timer, padapter->pnetdev, _reauth_timer_hdl, padapter);
-	//_init_timer(&pmlmeext->reassoc_timer, padapter->pnetdev, _reassoc_timer_hdl, padapter);
 }
 
 #ifdef CONFIG_AP_MODE
@@ -405,22 +222,22 @@ void rtw_indicate_sta_assoc_event(_adapter *padapter, struct sta_info *psta)
 	union iwreq_data wrqu;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	if(psta==NULL)
+	if (psta == NULL)
 		return;
 
-	if(psta->aid > NUM_STA)
+	if (psta->cmn.aid > pstapriv->max_aid)
 		return;
 
-	if(pstapriv->sta_aid[psta->aid - 1] != psta)
+	if (pstapriv->sta_aid[psta->cmn.aid - 1] != psta)
 		return;
-	
-	
-	wrqu.addr.sa_family = ARPHRD_ETHER;	
-	
-	_rtw_memcpy(wrqu.addr.sa_data, psta->hwaddr, ETH_ALEN);
-
-	DBG_871X("+rtw_indicate_sta_assoc_event\n");
-	
+
+
+	wrqu.addr.sa_family = ARPHRD_ETHER;
+
+	_rtw_memcpy(wrqu.addr.sa_data, psta->cmn.mac_addr, ETH_ALEN);
+
+	RTW_INFO("+rtw_indicate_sta_assoc_event\n");
+
 #ifndef CONFIG_IOCTL_CFG80211
 	wireless_send_event(padapter->pnetdev, IWEVREGISTERED, &wrqu, NULL);
 #endif
@@ -432,26 +249,26 @@ void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info *psta)
 	union iwreq_data wrqu;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	if(psta==NULL)
+	if (psta == NULL)
 		return;
 
-	if(psta->aid > NUM_STA)
+	if (psta->cmn.aid > pstapriv->max_aid)
 		return;
 
-	if(pstapriv->sta_aid[psta->aid - 1] != psta)
+	if (pstapriv->sta_aid[psta->cmn.aid - 1] != psta)
 		return;
-	
-	
-	wrqu.addr.sa_family = ARPHRD_ETHER;	
-	
-	_rtw_memcpy(wrqu.addr.sa_data, psta->hwaddr, ETH_ALEN);
-
-	DBG_871X("+rtw_indicate_sta_disassoc_event\n");
-	
+
+
+	wrqu.addr.sa_family = ARPHRD_ETHER;
+
+	_rtw_memcpy(wrqu.addr.sa_data, psta->cmn.mac_addr, ETH_ALEN);
+
+	RTW_INFO("+rtw_indicate_sta_disassoc_event\n");
+
 #ifndef CONFIG_IOCTL_CFG80211
 	wireless_send_event(padapter->pnetdev, IWEVEXPIRED, &wrqu, NULL);
 #endif
-	
+
 }
 
 
@@ -462,7 +279,7 @@ static int mgnt_xmit_entry(struct sk_buff *skb, struct net_device *pnetdev)
 	struct hostapd_priv *phostapdpriv = rtw_netdev_priv(pnetdev);
 	_adapter *padapter = (_adapter *)phostapdpriv->padapter;
 
-	//DBG_871X("%s\n", __FUNCTION__);
+	/* RTW_INFO("%s\n", __FUNCTION__); */
 
 	return rtw_hal_hostap_mgnt_xmit_entry(padapter, skb);
 }
@@ -471,44 +288,46 @@ static int mgnt_netdev_open(struct net_device *pnetdev)
 {
 	struct hostapd_priv *phostapdpriv = rtw_netdev_priv(pnetdev);
 
-	DBG_871X("mgnt_netdev_open: MAC Address:" MAC_FMT "\n", MAC_ARG(pnetdev->dev_addr));
+	RTW_INFO("mgnt_netdev_open: MAC Address:" MAC_FMT "\n", MAC_ARG(pnetdev->dev_addr));
 
 
 	init_usb_anchor(&phostapdpriv->anchored);
-	
+
 	rtw_netif_wake_queue(pnetdev);
 
-	netif_carrier_on(pnetdev);
-		
-	//rtw_write16(phostapdpriv->padapter, 0x0116, 0x0100);//only excluding beacon 
-		
-	return 0;	
+	rtw_netif_carrier_on(pnetdev);
+
+	/* rtw_write16(phostapdpriv->padapter, 0x0116, 0x0100); */ /* only excluding beacon */
+
+	return 0;
 }
 static int mgnt_netdev_close(struct net_device *pnetdev)
 {
 	struct hostapd_priv *phostapdpriv = rtw_netdev_priv(pnetdev);
 
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 
 	usb_kill_anchored_urbs(&phostapdpriv->anchored);
 
-	netif_carrier_off(pnetdev);
+	rtw_netif_carrier_off(pnetdev);
 
 	rtw_netif_stop_queue(pnetdev);
 
-	//rtw_write16(phostapdpriv->padapter, 0x0116, 0x3f3f);
-	
-	return 0;	
+	/* rtw_write16(phostapdpriv->padapter, 0x0116, 0x3f3f); */
+
+	return 0;
 }
 
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 static const struct net_device_ops rtl871x_mgnt_netdev_ops = {
 	.ndo_open = mgnt_netdev_open,
-       .ndo_stop = mgnt_netdev_close,
-       .ndo_start_xmit = mgnt_xmit_entry,
-       //.ndo_set_mac_address = r871x_net_set_mac_address,
-       //.ndo_get_stats = r871x_net_get_stats,
-       //.ndo_do_ioctl = r871x_mp_ioctl,
+	.ndo_stop = mgnt_netdev_close,
+	.ndo_start_xmit = mgnt_xmit_entry,
+	#if 0
+	.ndo_set_mac_address = r871x_net_set_mac_address,
+	.ndo_get_stats = r871x_net_get_stats,
+	.ndo_do_ioctl = r871x_mp_ioctl,
+	#endif
 };
 #endif
 
@@ -517,90 +336,85 @@ int hostapd_mode_init(_adapter *padapter)
 	unsigned char mac[ETH_ALEN];
 	struct hostapd_priv *phostapdpriv;
 	struct net_device *pnetdev;
-	
-	pnetdev = rtw_alloc_etherdev(sizeof(struct hostapd_priv));	
+
+	pnetdev = rtw_alloc_etherdev(sizeof(struct hostapd_priv));
 	if (!pnetdev)
-	   return -ENOMEM;
+		return -ENOMEM;
 
-	//SET_MODULE_OWNER(pnetdev);
-       ether_setup(pnetdev);
+	/* SET_MODULE_OWNER(pnetdev); */
+	ether_setup(pnetdev);
+
+	/* pnetdev->type = ARPHRD_IEEE80211; */
 
-	//pnetdev->type = ARPHRD_IEEE80211;
-	
 	phostapdpriv = rtw_netdev_priv(pnetdev);
 	phostapdpriv->pmgnt_netdev = pnetdev;
-	phostapdpriv->padapter= padapter;
+	phostapdpriv->padapter = padapter;
 	padapter->phostapdpriv = phostapdpriv;
-	
-	//pnetdev->init = NULL;
-	
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
 
-	DBG_871X("register rtl871x_mgnt_netdev_ops to netdev_ops\n");
+	/* pnetdev->init = NULL; */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+
+	RTW_INFO("register rtl871x_mgnt_netdev_ops to netdev_ops\n");
 
 	pnetdev->netdev_ops = &rtl871x_mgnt_netdev_ops;
-	
+
 #else
 
 	pnetdev->open = mgnt_netdev_open;
 
-	pnetdev->stop = mgnt_netdev_close;	
-	
+	pnetdev->stop = mgnt_netdev_close;
+
 	pnetdev->hard_start_xmit = mgnt_xmit_entry;
-	
-	//pnetdev->set_mac_address = r871x_net_set_mac_address;
-	
-	//pnetdev->get_stats = r871x_net_get_stats;
 
-	//pnetdev->do_ioctl = r871x_mp_ioctl;
-	
+	/* pnetdev->set_mac_address = r871x_net_set_mac_address; */
+
+	/* pnetdev->get_stats = r871x_net_get_stats; */
+
+	/* pnetdev->do_ioctl = r871x_mp_ioctl; */
+
 #endif
 
-	pnetdev->watchdog_timeo = HZ; /* 1 second timeout */	
+	pnetdev->watchdog_timeo = HZ; /* 1 second timeout */
 
-	//pnetdev->wireless_handlers = NULL;
+	/* pnetdev->wireless_handlers = NULL; */
 
 #ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
 	pnetdev->features |= NETIF_F_IP_CSUM;
-#endif	
+#endif
 
-	
-	
-	if(dev_alloc_name(pnetdev,"mgnt.wlan%d") < 0)
-	{
-		DBG_871X("hostapd_mode_init(): dev_alloc_name, fail! \n");		
-	}
 
 
-	//SET_NETDEV_DEV(pnetdev, pintfpriv->udev);
+	if (dev_alloc_name(pnetdev, "mgnt.wlan%d") < 0)
+		RTW_INFO("hostapd_mode_init(): dev_alloc_name, fail!\n");
+
+
+	/* SET_NETDEV_DEV(pnetdev, pintfpriv->udev); */
 
 
-	mac[0]=0x00;
-	mac[1]=0xe0;
-	mac[2]=0x4c;
-	mac[3]=0x87;
-	mac[4]=0x11;
-	mac[5]=0x12;
-				
+	mac[0] = 0x00;
+	mac[1] = 0xe0;
+	mac[2] = 0x4c;
+	mac[3] = 0x87;
+	mac[4] = 0x11;
+	mac[5] = 0x12;
+
 	_rtw_memcpy(pnetdev->dev_addr, mac, ETH_ALEN);
-	
 
-	netif_carrier_off(pnetdev);
+
+	rtw_netif_carrier_off(pnetdev);
 
 
 	/* Tell the network stack we exist */
-	if (register_netdev(pnetdev) != 0)
-	{
-		DBG_871X("hostapd_mode_init(): register_netdev fail!\n");
-		
-		if(pnetdev)
-      		{	 
+	if (register_netdev(pnetdev) != 0) {
+		RTW_INFO("hostapd_mode_init(): register_netdev fail!\n");
+
+		if (pnetdev)
 			rtw_free_netdev(pnetdev);
-      		}
 	}
-	
+
 	return 0;
-	
+
 }
 
 void hostapd_mode_unload(_adapter *padapter)
@@ -610,9 +424,8 @@ void hostapd_mode_unload(_adapter *padapter)
 
 	unregister_netdev(pnetdev);
 	rtw_free_netdev(pnetdev);
-	
+
 }
 
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/os_intfs.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/os_intfs.c
index 4a2c9c75c26b..0f6de178c90c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/os_intfs.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/os_intfs.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,20 +12,15 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _OS_INTFS_C_
 
 #include <drv_types.h>
 #include <hal_data.h>
 
-#if defined (PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
+#if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
 
-#error "Shall be Linux or Windows, but not both!\n"
+	#error "Shall be Linux or Windows, but not both!\n"
 
 #endif
 
@@ -37,52 +33,99 @@ MODULE_VERSION(DRIVERVERSION);
 /* module param defaults */
 int rtw_chip_version = 0x00;
 int rtw_rfintfs = HWPI;
-int rtw_lbkmode = 0;//RTL8712_AIR_TRX;
+int rtw_lbkmode = 0;/* RTL8712_AIR_TRX; */
 
 
-int rtw_network_mode = Ndis802_11IBSS;//Ndis802_11Infrastructure;//infra, ad-hoc, auto
-//NDIS_802_11_SSID	ssid;
-int rtw_channel = 1;//ad-hoc support requirement
+int rtw_network_mode = Ndis802_11IBSS;/* Ndis802_11Infrastructure; */ /* infra, ad-hoc, auto */
+/* NDIS_802_11_SSID	ssid; */
+int rtw_channel = 1;/* ad-hoc support requirement */
 int rtw_wireless_mode = WIRELESS_MODE_MAX;
 int rtw_vrtl_carrier_sense = AUTO_VCS;
-int rtw_vcs_type = RTS_CTS;//*
-int rtw_rts_thresh = 2347;//*
-int rtw_frag_thresh = 2346;//*
-int rtw_preamble = PREAMBLE_LONG;//long, short, auto
-int rtw_scan_mode = 1;//active, passive
-int rtw_adhoc_tx_pwr = 1;
-int rtw_soft_ap = 0;
-//int smart_ps = 1;
+int rtw_vcs_type = RTS_CTS;
+int rtw_rts_thresh = 2347;
+int rtw_frag_thresh = 2346;
+int rtw_preamble = PREAMBLE_LONG;/* long, short, auto */
+int rtw_scan_mode = 1;/* active, passive */
+/* int smart_ps = 1; */
 #ifdef CONFIG_POWER_SAVING
-int rtw_power_mgnt = PS_MODE_MAX;
-#ifdef CONFIG_IPS_LEVEL_2
-int rtw_ips_mode = IPS_LEVEL_2;
-#else
-int rtw_ips_mode = IPS_NORMAL;
-#endif
-#else
-int rtw_power_mgnt = PS_MODE_ACTIVE;
-int rtw_ips_mode = IPS_NONE;
-#endif
+	int rtw_power_mgnt = PS_MODE_MAX;
+	#ifdef CONFIG_IPS_LEVEL_2
+		int rtw_ips_mode = IPS_LEVEL_2;
+	#else
+		int rtw_ips_mode = IPS_NORMAL;
+	#endif /*CONFIG_IPS_LEVEL_2*/
+
+	#ifdef CONFIG_USB_HCI
+		int rtw_lps_level = LPS_NORMAL; /*USB default LPS level*/
+	#else /*SDIO,PCIE*/
+		#if defined(CONFIG_LPS_PG)
+			/*int rtw_lps_level = LPS_PG;*//*FW not support yet*/
+			int rtw_lps_level = LPS_LCLK;
+		#elif defined(CONFIG_LPS_LCLK)
+			int rtw_lps_level = LPS_LCLK;
+		#else
+			int rtw_lps_level = LPS_NORMAL;
+		#endif
+	#endif/*CONFIG_USB_HCI*/
+#else /* !CONFIG_POWER_SAVING */
+	int rtw_power_mgnt = PS_MODE_ACTIVE;
+	int rtw_ips_mode = IPS_NONE;
+	int rtw_lps_level = LPS_NORMAL;
+#endif /* CONFIG_POWER_SAVING */
+
+
 module_param(rtw_ips_mode, int, 0644);
-MODULE_PARM_DESC(rtw_ips_mode,"The default IPS mode");
+MODULE_PARM_DESC(rtw_ips_mode, "The default IPS mode");
 
+module_param(rtw_lps_level, int, 0644);
+MODULE_PARM_DESC(rtw_lps_level, "The default LPS level");
+
+/* LPS: 
+ * rtw_smart_ps = 0 => TX: pwr bit = 1, RX: PS_Poll
+ * rtw_smart_ps = 1 => TX: pwr bit = 0, RX: PS_Poll
+ * rtw_smart_ps = 2 => TX: pwr bit = 0, RX: NullData with pwr bit = 0
+*/
 int rtw_smart_ps = 2;
 
+int rtw_max_bss_cnt = 0;
+module_param(rtw_max_bss_cnt, int, 0644);
+#ifdef CONFIG_WMMPS_STA	
+/* WMMPS: 
+ * rtw_smart_ps = 0 => Only for fw test
+ * rtw_smart_ps = 1 => Refer to Beacon's TIM Bitmap
+ * rtw_smart_ps = 2 => Don't refer to Beacon's TIM Bitmap
+*/
+int rtw_wmm_smart_ps = 2;
+#endif /* CONFIG_WMMPS_STA */
+
 int rtw_check_fw_ps = 1;
 
 #ifdef CONFIG_TX_EARLY_MODE
-int rtw_early_mode=1;
+int rtw_early_mode = 1;
 #endif
 
-int rtw_usb_rxagg_mode = 2;//USB_RX_AGG_DMA =1,USB_RX_AGG_USB=2
+int rtw_usb_rxagg_mode = 2;/* RX_AGG_DMA=1, RX_AGG_USB=2 */
 module_param(rtw_usb_rxagg_mode, int, 0644);
 
+int rtw_dynamic_agg_enable = 1;
+module_param(rtw_dynamic_agg_enable, int, 0644);
+
+/* set log level when inserting driver module, default log level is _DRV_INFO_ = 4,
+* please refer to "How_to_set_driver_debug_log_level.doc" to set the available level.
+*/
+#ifdef RTW_LOG_LEVEL
+	uint rtw_drv_log_level = (uint)RTW_LOG_LEVEL; /* from Makefile */
+#else
+	uint rtw_drv_log_level = _DRV_INFO_;
+#endif
+module_param(rtw_drv_log_level, uint, 0644);
+MODULE_PARM_DESC(rtw_drv_log_level, "set log level when insert driver module, default log level is _DRV_INFO_ = 4");
+
 int rtw_radio_enable = 1;
 int rtw_long_retry_lmt = 7;
 int rtw_short_retry_lmt = 7;
 int rtw_busy_thresh = 40;
-//int qos_enable = 0; //*
+/* int qos_enable = 0; */ /* * */
 int rtw_ack_policy = NORMAL_ACK;
 
 int rtw_mp_mode = 0;
@@ -96,19 +139,25 @@ MODULE_PARM_DESC(rtw_mp_customer_str, "Whether or not to enable customer str sup
 int rtw_software_encrypt = 0;
 int rtw_software_decrypt = 0;
 
-int rtw_acm_method = 0;// 0:By SW 1:By HW.
+int rtw_acm_method = 0;/* 0:By SW 1:By HW. */
+
+int rtw_wmm_enable = 1;/* default is set to enable the wmm. */
 
-int rtw_wmm_enable = 1;// default is set to enable the wmm.
-int rtw_uapsd_enable = 0;
+#ifdef CONFIG_WMMPS_STA
+/* uapsd (unscheduled automatic power-save delivery) = a kind of wmmps */
+/* 0: NO_LIMIT, 1: TWO_MSDU, 2: FOUR_MSDU, 3: SIX_MSDU */
 int rtw_uapsd_max_sp = NO_LIMIT;
-int rtw_uapsd_acbk_en = 0;
-int rtw_uapsd_acbe_en = 0;
-int rtw_uapsd_acvi_en = 0;
-int rtw_uapsd_acvo_en = 0;
-#ifdef CONFIG_RTL8814A
-int rtw_rfkfree_enable = 2; /* disable kfree */
+/* BIT0: AC_VO UAPSD, BIT1: AC_VI UAPSD, BIT2: AC_BK UAPSD, BIT3: AC_BE UAPSD */
+int rtw_uapsd_ac_enable = 0x0;
+#endif /* CONFIG_WMMPS_STA */
+
+#if defined(CONFIG_RTL8814A)
+	int rtw_pwrtrim_enable = 2; /* disable kfree , rename to power trim disable */
+#elif defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822B)
+	/*PHYDM API, must enable by default*/
+	int rtw_pwrtrim_enable = 1;
 #else
-int rtw_rfkfree_enable = 0; /* Default Enalbe kfree by efuse config */
+	int rtw_pwrtrim_enable = 0; /* Default Enalbe  power trim by efuse config */
 #endif
 
 uint rtw_tx_bw_mode = 0x21;
@@ -117,98 +166,161 @@ MODULE_PARM_DESC(rtw_tx_bw_mode, "The max tx bw for 2.4G and 5G. format is the s
 
 #ifdef CONFIG_80211N_HT
 int rtw_ht_enable = 1;
-// 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz, 4: 80+80MHz
-// 2.4G use bit 0 ~ 3, 5G use bit 4 ~ 7
-// 0x21 means enable 2.4G 40MHz & 5G 80MHz
+/* 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz, 4: 80+80MHz
+* 2.4G use bit 0 ~ 3, 5G use bit 4 ~ 7
+* 0x21 means enable 2.4G 40MHz & 5G 80MHz */
+#ifdef CONFIG_RTW_CUSTOMIZE_BWMODE
+int rtw_bw_mode = CONFIG_RTW_CUSTOMIZE_BWMODE;
+#else
 int rtw_bw_mode = 0x21;
-int rtw_ampdu_enable = 1;//for enable tx_ampdu ,// 0: disable, 0x1:enable (but wifi_spec should be 0), 0x2: force enable (don't care wifi_spec)
-int rtw_rx_stbc = 1;// 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
-int rtw_ampdu_amsdu = 0;// 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on
-// Short GI support Bit Map
-// BIT0 - 20MHz, 0: non-support, 1: support
-// BIT1 - 40MHz, 0: non-support, 1: support
-// BIT2 - 80MHz, 0: non-support, 1: support
-// BIT3 - 160MHz, 0: non-support, 1: support
+#endif
+int rtw_ampdu_enable = 1;/* for enable tx_ampdu , */ /* 0: disable, 0x1:enable */
+int rtw_rx_stbc = 1;/* 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 */
+#if (defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)) && defined(CONFIG_PCI_HCI)
+int rtw_rx_ampdu_amsdu = 2;/* 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on */
+#else
+int rtw_rx_ampdu_amsdu;/* 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on */
+#endif
+/*
+* 2: Follow the AMSDU filed in ADDBA Resp. (Deault)
+* 0: Force the AMSDU filed in ADDBA Resp. to be disabled.
+* 1: Force the AMSDU filed in ADDBA Resp. to be enabled.
+*/
+int rtw_tx_ampdu_amsdu = 2;
+
+static uint rtw_rx_ampdu_sz_limit_1ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS;
+static uint rtw_rx_ampdu_sz_limit_1ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_1ss, uint, &rtw_rx_ampdu_sz_limit_1ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_1ss, "RX AMPDU size limit for 1SS link of each BW, 0xFF: no limitation");
+
+static uint rtw_rx_ampdu_sz_limit_2ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_2SS;
+static uint rtw_rx_ampdu_sz_limit_2ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_2ss, uint, &rtw_rx_ampdu_sz_limit_2ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_2ss, "RX AMPDU size limit for 2SS link of each BW, 0xFF: no limitation");
+
+static uint rtw_rx_ampdu_sz_limit_3ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_3SS;
+static uint rtw_rx_ampdu_sz_limit_3ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_3ss, uint, &rtw_rx_ampdu_sz_limit_3ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_3ss, "RX AMPDU size limit for 3SS link of each BW, 0xFF: no limitation");
+
+static uint rtw_rx_ampdu_sz_limit_4ss[4] = CONFIG_RTW_RX_AMPDU_SZ_LIMIT_4SS;
+static uint rtw_rx_ampdu_sz_limit_4ss_num = 0;
+module_param_array(rtw_rx_ampdu_sz_limit_4ss, uint, &rtw_rx_ampdu_sz_limit_4ss_num, 0644);
+MODULE_PARM_DESC(rtw_rx_ampdu_sz_limit_4ss, "RX AMPDU size limit for 4SS link of each BW, 0xFF: no limitation");
+
+/* Short GI support Bit Map
+* BIT0 - 20MHz, 0: non-support, 1: support
+* BIT1 - 40MHz, 0: non-support, 1: support
+* BIT2 - 80MHz, 0: non-support, 1: support
+* BIT3 - 160MHz, 0: non-support, 1: support */
 int rtw_short_gi = 0xf;
-// BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx
-int rtw_ldpc_cap = 0x00;
-// BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx
+/* BIT0: Enable VHT LDPC Rx, BIT1: Enable VHT LDPC Tx, BIT4: Enable HT LDPC Rx, BIT5: Enable HT LDPC Tx */
+int rtw_ldpc_cap = 0x33;
+/* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
 int rtw_stbc_cap = 0x13;
-// BIT0: Enable VHT Beamformer, BIT1: Enable VHT Beamformee, BIT4: Enable HT Beamformer, BIT5: Enable HT Beamformee
-int rtw_beamform_cap = 0x2;
+/*
+* BIT0: Enable VHT SU Beamformer
+* BIT1: Enable VHT SU Beamformee
+* BIT2: Enable VHT MU Beamformer, depend on VHT SU Beamformer
+* BIT3: Enable VHT MU Beamformee, depend on VHT SU Beamformee
+* BIT4: Enable HT Beamformer
+* BIT5: Enable HT Beamformee
+*/
+int rtw_beamform_cap = BIT(1) | BIT(3);
 int rtw_bfer_rf_number = 0; /*BeamformerCapRfNum Rf path number, 0 for auto, others for manual*/
 int rtw_bfee_rf_number = 0; /*BeamformeeCapRfNum  Rf path number, 0 for auto, others for manual*/
 
-#endif //CONFIG_80211N_HT
+#endif /* CONFIG_80211N_HT */
 
 #ifdef CONFIG_80211AC_VHT
-int rtw_vht_enable = 1; //0:disable, 1:enable, 2:force auto enable
+int rtw_vht_enable = 1; /* 0:disable, 1:enable, 2:force auto enable */
+module_param(rtw_vht_enable, int, 0644);
+
 int rtw_ampdu_factor = 7;
-int rtw_vht_rate_sel = 0;
-#endif //CONFIG_80211AC_VHT
 
-int rtw_lowrate_two_xmit = 1;//Use 2 path Tx to transmit MCS0~7 and legacy mode
+uint rtw_vht_rx_mcs_map = 0xaaaa;
+module_param(rtw_vht_rx_mcs_map, uint, 0644);
+MODULE_PARM_DESC(rtw_vht_rx_mcs_map, "VHT RX MCS map");
+#endif /* CONFIG_80211AC_VHT */
+
+int rtw_lowrate_two_xmit = 1;/* Use 2 path Tx to transmit MCS0~7 and legacy mode */
+
+int rtw_rf_config = RF_TYPE_MAX;
+module_param(rtw_rf_config, int, 0644);
 
-//int rf_config = RF_1T2R;  // 1T2R
-int rtw_rf_config = RF_MAX_TYPE;  //auto
+/* 0: not check in watch dog, 1: check in watch dog  */
+int rtw_check_hw_status = 0;
 
 int rtw_low_power = 0;
 #ifdef CONFIG_WIFI_TEST
-int rtw_wifi_spec = 1;//for wifi test
+	int rtw_wifi_spec = 1;/* for wifi test */
 #else
-int rtw_wifi_spec = 0;
+	int rtw_wifi_spec = 0;
 #endif
 
-int rtw_special_rf_path = 0; //0: 2T2R ,1: only turn on path A 1T1R
+int rtw_special_rf_path = 0; /* 0: 2T2R ,1: only turn on path A 1T1R */
 
 char rtw_country_unspecified[] = {0xFF, 0xFF, 0x00};
 char *rtw_country_code = rtw_country_unspecified;
 module_param(rtw_country_code, charp, 0644);
 MODULE_PARM_DESC(rtw_country_code, "The default country code (in alpha2)");
 
-int rtw_channel_plan = RTW_CHPLAN_MAX;
+int rtw_channel_plan = CONFIG_RTW_CHPLAN;
 module_param(rtw_channel_plan, int, 0644);
 MODULE_PARM_DESC(rtw_channel_plan, "The default chplan ID when rtw_alpha2 is not specified or valid");
 
+static uint rtw_excl_chs[MAX_CHANNEL_NUM] = CONFIG_RTW_EXCL_CHS;
+static int rtw_excl_chs_num = 0;
+module_param_array(rtw_excl_chs, uint, &rtw_excl_chs_num, 0644);
+MODULE_PARM_DESC(rtw_excl_chs, "exclusive channel array");
+
 /*if concurrent softap + p2p(GO) is needed, this param lets p2p response full channel list.
 But Softap must be SHUT DOWN once P2P decide to set up connection and become a GO.*/
 #ifdef CONFIG_FULL_CH_IN_P2P_HANDSHAKE
-int rtw_full_ch_in_p2p_handshake = 1; /* reply full channel list*/
+	int rtw_full_ch_in_p2p_handshake = 1; /* reply full channel list*/
 #else
-int rtw_full_ch_in_p2p_handshake = 0; /* reply only softap channel*/
+	int rtw_full_ch_in_p2p_handshake = 0; /* reply only softap channel*/
 #endif
 
 #ifdef CONFIG_BT_COEXIST
-int rtw_btcoex_enable = 1;
+int rtw_btcoex_enable = 2;
 module_param(rtw_btcoex_enable, int, 0644);
-MODULE_PARM_DESC(rtw_btcoex_enable, "Enable BT co-existence mechanism");
-int rtw_bt_iso = 2;// 0:Low, 1:High, 2:From Efuse
-int rtw_bt_sco = 3;// 0:Idle, 1:None-SCO, 2:SCO, 3:From Counter, 4.Busy, 5.OtherBusy
-int rtw_bt_ampdu =1 ;// 0:Disable BT control A-MPDU, 1:Enable BT control A-MPDU.
-int rtw_ant_num = -1; // <0: undefined, >0: Antenna number
+MODULE_PARM_DESC(rtw_btcoex_enable, "BT co-existence on/off, 0:off, 1:on, 2:by efuse");
+
+int rtw_ant_num = 0;
 module_param(rtw_ant_num, int, 0644);
-MODULE_PARM_DESC(rtw_ant_num, "Antenna number setting");
-#endif
+MODULE_PARM_DESC(rtw_ant_num, "Antenna number setting, 0:by efuse");
 
-int rtw_AcceptAddbaReq = _TRUE;// 0:Reject AP's Add BA req, 1:Accept AP's Add BA req.
+int rtw_bt_iso = 2;/* 0:Low, 1:High, 2:From Efuse */
+int rtw_bt_sco = 3;/* 0:Idle, 1:None-SCO, 2:SCO, 3:From Counter, 4.Busy, 5.OtherBusy */
+int rtw_bt_ampdu = 1 ; /* 0:Disable BT control A-MPDU, 1:Enable BT control A-MPDU. */
+#endif /* CONFIG_BT_COEXIST */
 
-int rtw_antdiv_cfg = 2; // 0:OFF , 1:ON, 2:decide by Efuse config
-int rtw_antdiv_type = 0 ; //0:decide by efuse  1: for 88EE, 1Tx and 1RxCG are diversity.(2 Ant with SPDT), 2:  for 88EE, 1Tx and 2Rx are diversity.( 2 Ant, Tx and RxCG are both on aux port, RxCS is on main port ), 3: for 88EE, 1Tx and 1RxCG are fixed.(1Ant, Tx and RxCG are both on aux port)
+int rtw_AcceptAddbaReq = _TRUE;/* 0:Reject AP's Add BA req, 1:Accept AP's Add BA req. */
 
-int rtw_switch_usb3 = _FALSE; /* _FALSE: doesn't switch, _TRUE: switch from usb2.0 to usb 3.0 */
+int rtw_antdiv_cfg = 2; /* 0:OFF , 1:ON, 2:decide by Efuse config */
+int rtw_antdiv_type = 0
+	; /* 0:decide by efuse  1: for 88EE, 1Tx and 1RxCG are diversity.(2 Ant with SPDT), 2:  for 88EE, 1Tx and 2Rx are diversity.( 2 Ant, Tx and RxCG are both on aux port, RxCS is on main port ), 3: for 88EE, 1Tx and 1RxCG are fixed.(1Ant, Tx and RxCG are both on aux port) */
+
+int rtw_drv_ant_band_switch = 1; /* 0:OFF , 1:ON, Driver control antenna band switch*/
+
+int rtw_single_ant_path; /*0:main ant , 1:aux ant , Fixed single antenna path, default main ant*/
+
+/* 0: doesn't switch, 1: switch from usb2.0 to usb 3.0 2: switch from usb3.0 to usb 2.0 */
+int rtw_switch_usb_mode = 0;
 
 #ifdef CONFIG_USB_AUTOSUSPEND
-int rtw_enusbss = 1;//0:disable,1:enable
+int rtw_enusbss = 1;/* 0:disable,1:enable */
 #else
-int rtw_enusbss = 0;//0:disable,1:enable
+int rtw_enusbss = 0;/* 0:disable,1:enable */
 #endif
 
-int rtw_hwpdn_mode=2;//0:disable,1:enable,2: by EFUSE config
+int rtw_hwpdn_mode = 2; /* 0:disable,1:enable,2: by EFUSE config */
 
 #ifdef CONFIG_HW_PWRP_DETECTION
 int rtw_hwpwrp_detect = 1;
 #else
-int rtw_hwpwrp_detect = 0; //HW power  ping detect 0:disable , 1:enable
+int rtw_hwpwrp_detect = 0; /* HW power  ping detect 0:disable , 1:enable */
 #endif
 
 #ifdef CONFIG_USB_HCI
@@ -219,55 +331,67 @@ int rtw_hw_wps_pbc = 0;
 
 #ifdef CONFIG_TX_MCAST2UNI
 int rtw_mc2u_disable = 0;
-#endif	// CONFIG_TX_MCAST2UNI
+#endif /* CONFIG_TX_MCAST2UNI */
 
 #ifdef CONFIG_80211D
 int rtw_80211d = 0;
 #endif
 
-#ifdef CONFIG_SPECIAL_SETTING_FOR_FUNAI_TV
-int rtw_force_ant = 2;//0 :normal, 1:Main ant, 2:Aux ant
-int rtw_force_igi =0;//0 :normal
-module_param(rtw_force_ant, int, 0644);
-module_param(rtw_force_igi, int, 0644);
+#ifdef CONFIG_PCI_ASPM
+/* CLK_REQ:BIT0 L0s:BIT1 ASPM_L1:BIT2 L1Off:BIT3*/
+int	rtw_pci_aspm_enable = 0x5;
+#else
+int	rtw_pci_aspm_enable;
 #endif
 
 #ifdef CONFIG_QOS_OPTIMIZATION
-int rtw_qos_opt_enable=1;//0: disable,1:enable
+int rtw_qos_opt_enable = 1; /* 0: disable,1:enable */
 #else
-int rtw_qos_opt_enable=0;//0: disable,1:enable
+int rtw_qos_opt_enable = 0; /* 0: disable,1:enable */
 #endif
-module_param(rtw_qos_opt_enable,int,0644);
-
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-int rtw_acs_mode = 1; /*0:disable, 1:enable*/
-module_param(rtw_acs_mode, int, 0644);
+module_param(rtw_qos_opt_enable, int, 0644);
 
+#ifdef CONFIG_RTW_ACS
 int rtw_acs_auto_scan = 0; /*0:disable, 1:enable*/
 module_param(rtw_acs_auto_scan, int, 0644);
 
+int rtw_acs = 1;
+module_param(rtw_acs, int, 0644);
+#endif
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+int rtw_nm = 1;/*noise monitor*/
+module_param(rtw_nm, int, 0644);
 #endif
 
-char* ifname = "wlan%d";
+char *ifname = "wlan%d";
 module_param(ifname, charp, 0644);
 MODULE_PARM_DESC(ifname, "The default name to allocate for first interface");
 
 #ifdef CONFIG_PLATFORM_ANDROID
-char* if2name = "p2p%d";
-#else //CONFIG_PLATFORM_ANDROID
-char* if2name = "wlan%d";
-#endif //CONFIG_PLATFORM_ANDROID
+	char *if2name = "p2p%d";
+#else /* CONFIG_PLATFORM_ANDROID */
+	char *if2name = "wlan%d";
+#endif /* CONFIG_PLATFORM_ANDROID */
 module_param(if2name, charp, 0644);
 MODULE_PARM_DESC(if2name, "The default name to allocate for second interface");
 
-char* rtw_initmac = 0;  // temp mac address if users want to use instead of the mac address in Efuse
+char *rtw_initmac = 0;  /* temp mac address if users want to use instead of the mac address in Efuse */
+
+#ifdef CONFIG_CONCURRENT_MODE
 
-#ifdef CONFIG_MULTI_VIR_IFACES
-int rtw_ext_iface_num  = 1;//primary/secondary iface is excluded
-module_param(rtw_ext_iface_num, int, 0644);
-#endif //CONFIG_MULTI_VIR_IFACES
+	#if (CONFIG_IFACE_NUMBER > 2)
+		int rtw_virtual_iface_num = CONFIG_IFACE_NUMBER - 1;
+		module_param(rtw_virtual_iface_num, int, 0644);
+	#else
+		int rtw_virtual_iface_num = 1;
+	#endif
 
-module_param(rtw_rfkfree_enable, int, 0644);
+#endif
+#ifdef CONFIG_AP_MODE
+u8 rtw_bmc_tx_rate = MGN_UNKNOWN;
+#endif
+module_param(rtw_pwrtrim_enable, int, 0644);
 module_param(rtw_initmac, charp, 0644);
 module_param(rtw_special_rf_path, int, 0644);
 module_param(rtw_chip_version, int, 0644);
@@ -277,6 +401,11 @@ module_param(rtw_network_mode, int, 0644);
 module_param(rtw_channel, int, 0644);
 module_param(rtw_mp_mode, int, 0644);
 module_param(rtw_wmm_enable, int, 0644);
+#ifdef CONFIG_WMMPS_STA
+module_param(rtw_uapsd_max_sp, int, 0644);
+module_param(rtw_uapsd_ac_enable, int, 0644);
+module_param(rtw_wmm_smart_ps, int, 0644);
+#endif /* CONFIG_WMMPS_STA */
 module_param(rtw_vrtl_carrier_sense, int, 0644);
 module_param(rtw_vcs_type, int, 0644);
 module_param(rtw_busy_thresh, int, 0644);
@@ -286,17 +415,15 @@ module_param(rtw_ht_enable, int, 0644);
 module_param(rtw_bw_mode, int, 0644);
 module_param(rtw_ampdu_enable, int, 0644);
 module_param(rtw_rx_stbc, int, 0644);
-module_param(rtw_ampdu_amsdu, int, 0644);
-#endif //CONFIG_80211N_HT
-#ifdef CONFIG_80211AC_VHT
-module_param(rtw_vht_enable, int, 0644);
-#endif //CONFIG_80211AC_VHT
+module_param(rtw_rx_ampdu_amsdu, int, 0644);
+module_param(rtw_tx_ampdu_amsdu, int, 0644);
+#endif /* CONFIG_80211N_HT */
+
 #ifdef CONFIG_BEAMFORMING
 module_param(rtw_beamform_cap, int, 0644);
 #endif
 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);
@@ -306,34 +433,42 @@ module_param(rtw_full_ch_in_p2p_handshake, int, 0644);
 module_param(rtw_antdiv_cfg, int, 0644);
 module_param(rtw_antdiv_type, int, 0644);
 
-module_param(rtw_switch_usb3, int, 0644);
+module_param(rtw_drv_ant_band_switch, int, 0644);
+module_param(rtw_single_ant_path, int, 0644);
+
+module_param(rtw_switch_usb_mode, 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);
+module_param(rtw_check_hw_status, int, 0644);
+
+#ifdef CONFIG_PCI_HCI
+module_param(rtw_pci_aspm_enable, int, 0644);
+#endif
 
 #ifdef CONFIG_TX_EARLY_MODE
 module_param(rtw_early_mode, int, 0644);
 #endif
 #ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
-char *rtw_adaptor_info_caching_file_path= "/data/misc/wifi/rtw_cache";
+char *rtw_adaptor_info_caching_file_path = "/data/misc/wifi/rtw_cache";
 module_param(rtw_adaptor_info_caching_file_path, charp, 0644);
 MODULE_PARM_DESC(rtw_adaptor_info_caching_file_path, "The path of adapter info cache file");
-#endif //CONFIG_ADAPTOR_INFO_CACHING_FILE
+#endif /* CONFIG_ADAPTOR_INFO_CACHING_FILE */
 
 #ifdef CONFIG_LAYER2_ROAMING
-uint rtw_max_roaming_times=2;
+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");
-#endif //CONFIG_LAYER2_ROAMING
+MODULE_PARM_DESC(rtw_max_roaming_times, "The max roaming times to try");
+#endif /* CONFIG_LAYER2_ROAMING */
 
 #ifdef CONFIG_IOL
-int rtw_fw_iol=1;
+int rtw_fw_iol = 1;
 module_param(rtw_fw_iol, int, 0644);
 MODULE_PARM_DESC(rtw_fw_iol, "FW IOL. 0:Disable, 1:enable, 2:by usb speed");
-#endif //CONFIG_IOL
+#endif /* CONFIG_IOL */
 
 #ifdef CONFIG_FILE_FWIMG
 char *rtw_fw_file_path = "/system/etc/firmware/rtlwifi/FW_NIC.BIN";
@@ -348,18 +483,26 @@ MODULE_PARM_DESC(rtw_fw_wow_file_path, "The path of fw for Wake on Wireless imag
 char *rtw_fw_mp_bt_file_path = "";
 module_param(rtw_fw_mp_bt_file_path, charp, 0644);
 MODULE_PARM_DESC(rtw_fw_mp_bt_file_path, "The path of fw for MP-BT image");
-#endif // CONFIG_MP_INCLUDED
-#endif // CONFIG_FILE_FWIMG
+#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
 
 #ifdef CONFIG_TX_MCAST2UNI
 module_param(rtw_mc2u_disable, int, 0644);
-#endif	// CONFIG_TX_MCAST2UNI
+#endif /* CONFIG_TX_MCAST2UNI */
 
 #ifdef CONFIG_80211D
 module_param(rtw_80211d, int, 0644);
 MODULE_PARM_DESC(rtw_80211d, "Enable 802.11d mechanism");
 #endif
 
+#ifdef CONFIG_ADVANCE_OTA
+/*	BIT(0): OTA continuous rotated test within low RSSI,1R CCA in path B
+	BIT(1) & BIT(2): OTA continuous rotated test with low high RSSI */
+/* Experimental environment: shielding room with half of absorber and 2~3 rotation per minute */
+int rtw_advnace_ota;
+module_param(rtw_advnace_ota, int, 0644);
+#endif
+
 uint rtw_notch_filter = 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");
@@ -386,11 +529,17 @@ MODULE_PARM_DESC(rtw_adaptivity_dc_backoff, "DC backoff for Adaptivity");
 
 int rtw_adaptivity_th_l2h_ini = CONFIG_RTW_ADAPTIVITY_TH_L2H_INI;
 module_param(rtw_adaptivity_th_l2h_ini, int, 0644);
-MODULE_PARM_DESC(rtw_adaptivity_th_l2h_ini, "TH_L2H_ini for Adaptivity");
+MODULE_PARM_DESC(rtw_adaptivity_th_l2h_ini, "th_l2h_ini for Adaptivity");
 
 int rtw_adaptivity_th_edcca_hl_diff = CONFIG_RTW_ADAPTIVITY_TH_EDCCA_HL_DIFF;
 module_param(rtw_adaptivity_th_edcca_hl_diff, int, 0644);
-MODULE_PARM_DESC(rtw_adaptivity_th_edcca_hl_diff, "TH_EDCCA_HL_diff for Adaptivity");
+MODULE_PARM_DESC(rtw_adaptivity_th_edcca_hl_diff, "th_edcca_hl_diff for Adaptivity");
+
+#ifdef CONFIG_DFS_MASTER
+uint rtw_dfs_region_domain = CONFIG_RTW_DFS_REGION_DOMAIN;
+module_param(rtw_dfs_region_domain, uint, 0644);
+MODULE_PARM_DESC(rtw_dfs_region_domain, "0:UNKNOWN, 1:FCC, 2:MKK, 3:ETSI");
+#endif
 
 uint rtw_amplifier_type_2g = CONFIG_RTW_AMPLIFIER_TYPE_2G;
 module_param(rtw_amplifier_type_2g, uint, 0644);
@@ -404,6 +553,10 @@ uint rtw_RFE_type = CONFIG_RTW_RFE_TYPE;
 module_param(rtw_RFE_type, uint, 0644);
 MODULE_PARM_DESC(rtw_RFE_type, "default init value:64");
 
+uint rtw_powertracking_type = 64;
+module_param(rtw_powertracking_type, uint, 0644);
+MODULE_PARM_DESC(rtw_powertracking_type, "default init value:64");
+
 uint rtw_GLNA_type = CONFIG_RTW_GLNA_TYPE;
 module_param(rtw_GLNA_type, uint, 0644);
 MODULE_PARM_DESC(rtw_GLNA_type, "default init value:0");
@@ -424,10 +577,6 @@ uint rtw_FileMaskEfuse = 0;
 module_param(rtw_FileMaskEfuse, uint, 0644);
 MODULE_PARM_DESC(rtw_FileMaskEfuse, "default drv Mask Efuse value:0");
 
-uint rtw_kfree = 0;
-module_param(rtw_kfree, uint, 0644);
-MODULE_PARM_DESC(rtw_kfree, "default kfree config value:0");
-
 uint rtw_rxgain_offset_2g = 0;
 module_param(rtw_rxgain_offset_2g, uint, 0644);
 MODULE_PARM_DESC(rtw_rxgain_offset_2g, "default RF Gain 2G Offset value:0");
@@ -444,7 +593,6 @@ uint rtw_rxgain_offset_5gh = 0;
 module_param(rtw_rxgain_offset_5gh, uint, 0644);
 MODULE_PARM_DESC(rtw_rxgain_offset_5gm, "default RF Gain 5GL Offset value:0");
 
-
 uint rtw_pll_ref_clk_sel = CONFIG_RTW_PLL_REF_CLK_SEL;
 module_param(rtw_pll_ref_clk_sel, uint, 0644);
 MODULE_PARM_DESC(rtw_pll_ref_clk_sel, "force pll_ref_clk_sel, 0xF:use autoload value");
@@ -453,9 +601,11 @@ int rtw_tx_pwr_by_rate = CONFIG_TXPWR_BY_RATE_EN;
 module_param(rtw_tx_pwr_by_rate, int, 0644);
 MODULE_PARM_DESC(rtw_tx_pwr_by_rate, "0:Disable, 1:Enable, 2: Depend on efuse");
 
+#ifdef CONFIG_TXPWR_LIMIT
 int rtw_tx_pwr_lmt_enable = CONFIG_TXPWR_LIMIT_EN;
 module_param(rtw_tx_pwr_lmt_enable, int, 0644);
-MODULE_PARM_DESC(rtw_tx_pwr_lmt_enable,"0:Disable, 1:Enable, 2: Depend on efuse");
+MODULE_PARM_DESC(rtw_tx_pwr_lmt_enable, "0:Disable, 1:Enable, 2: Depend on efuse");
+#endif
 
 static int rtw_target_tx_pwr_2g_a[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_A;
 static int rtw_target_tx_pwr_2g_a_num = 0;
@@ -503,28 +653,138 @@ MODULE_PARM_DESC(rtw_target_tx_pwr_5g_d, "5G target tx power (unit:dBm) of RF pa
 char *rtw_phy_file_path = REALTEK_CONFIG_PATH;
 module_param(rtw_phy_file_path, charp, 0644);
 MODULE_PARM_DESC(rtw_phy_file_path, "The path of phy parameter");
-// PHY FILE Bit Map
-// BIT0 - MAC,				0: non-support, 1: support
-// BIT1 - BB,					0: non-support, 1: support
-// BIT2 - BB_PG,				0: non-support, 1: support
-// BIT3 - BB_MP,				0: non-support, 1: support
-// BIT4 - RF,					0: non-support, 1: support
-// BIT5 - RF_TXPWR_TRACK,	0: non-support, 1: support
-// BIT6 - RF_TXPWR_LMT,		0: non-support, 1: support
-int rtw_load_phy_file = (BIT2|BIT6);
+/* PHY FILE Bit Map
+* BIT0 - MAC,				0: non-support, 1: support
+* BIT1 - BB,					0: non-support, 1: support
+* BIT2 - BB_PG,				0: non-support, 1: support
+* BIT3 - BB_MP,				0: non-support, 1: support
+* BIT4 - RF,					0: non-support, 1: support
+* BIT5 - RF_TXPWR_TRACK,	0: non-support, 1: support
+* BIT6 - RF_TXPWR_LMT,		0: non-support, 1: support */
+int rtw_load_phy_file = (BIT2 | BIT6);
 module_param(rtw_load_phy_file, int, 0644);
-MODULE_PARM_DESC(rtw_load_phy_file,"PHY File Bit Map");
+MODULE_PARM_DESC(rtw_load_phy_file, "PHY File Bit Map");
 int rtw_decrypt_phy_file = 0;
 module_param(rtw_decrypt_phy_file, int, 0644);
-MODULE_PARM_DESC(rtw_decrypt_phy_file,"Enable Decrypt PHY File");
+MODULE_PARM_DESC(rtw_decrypt_phy_file, "Enable Decrypt PHY File");
 #endif
 
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#ifdef DFT_TRX_SHARE_MODE
+int rtw_trx_share_mode = DFT_TRX_SHARE_MODE;
+#else
+int rtw_trx_share_mode = 0;
+#endif
+module_param(rtw_trx_share_mode, int, 0644);
+MODULE_PARM_DESC(rtw_trx_share_mode, "TRx FIFO Shared");
+#endif
+
+#ifdef CONFIG_DYNAMIC_SOML
+uint rtw_dynamic_soml_en = 1;
+module_param(rtw_dynamic_soml_en, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_en, "0: disable, 1: enable with default param, 2: enable with specified param.");
+
+uint rtw_dynamic_soml_train_num = 0;
+module_param(rtw_dynamic_soml_train_num, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_train_num, "SOML training number");
+
+uint rtw_dynamic_soml_interval = 0;
+module_param(rtw_dynamic_soml_interval, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_interval, "SOML training interval");
+
+uint rtw_dynamic_soml_period = 0;
+module_param(rtw_dynamic_soml_period, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_period, "SOML training period");
+
+uint rtw_dynamic_soml_delay = 0;
+module_param(rtw_dynamic_soml_delay, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_delay, "SOML training delay");
+#endif
+
+
 int _netdev_open(struct net_device *pnetdev);
-int netdev_open (struct net_device *pnetdev);
-static int netdev_close (struct net_device *pnetdev);
+int netdev_open(struct net_device *pnetdev);
+static int netdev_close(struct net_device *pnetdev);
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 extern int rtw_sdio_set_power(int on);
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+
+#ifdef CONFIG_MCC_MODE
+/* enable MCC mode or not */
+int rtw_en_mcc = 1;
+/* can referece following value before insmod driver */
+int rtw_mcc_ap_bw20_target_tx_tp = MCC_AP_BW20_TARGET_TX_TP;
+int rtw_mcc_ap_bw40_target_tx_tp = MCC_AP_BW40_TARGET_TX_TP;
+int rtw_mcc_ap_bw80_target_tx_tp = MCC_AP_BW80_TARGET_TX_TP;
+int rtw_mcc_sta_bw20_target_tx_tp = MCC_STA_BW20_TARGET_TX_TP;
+int rtw_mcc_sta_bw40_target_tx_tp = MCC_STA_BW40_TARGET_TX_TP;
+int rtw_mcc_sta_bw80_target_tx_tp = MCC_STA_BW80_TARGET_TX_TP;
+int rtw_mcc_single_tx_cri = MCC_SINGLE_TX_CRITERIA;
+int rtw_mcc_policy_table_idx = 0;
+int rtw_mcc_duration = 0;
+int rtw_mcc_enable_runtime_duration = 1;
+module_param(rtw_en_mcc, int, 0644);
+module_param(rtw_mcc_single_tx_cri, int, 0644);
+module_param(rtw_mcc_ap_bw20_target_tx_tp, int, 0644);
+module_param(rtw_mcc_ap_bw40_target_tx_tp, int, 0644);
+module_param(rtw_mcc_ap_bw80_target_tx_tp, int, 0644);
+module_param(rtw_mcc_sta_bw20_target_tx_tp, int, 0644);
+module_param(rtw_mcc_sta_bw40_target_tx_tp, int, 0644);
+module_param(rtw_mcc_sta_bw80_target_tx_tp, int, 0644);
+module_param(rtw_mcc_policy_table_idx, int, 0644);
+module_param(rtw_mcc_duration, int, 0644);
+#endif /*CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_NAPI
+/*following setting should define NAPI in Makefile
+enable napi only = 1, disable napi = 0*/
+int rtw_en_napi = 1;
+module_param(rtw_en_napi, int, 0644);
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+int rtw_napi_threshold = 100; /* unit: Mbps */
+module_param(rtw_napi_threshold, int, 0644);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#ifdef CONFIG_RTW_GRO
+/*following setting should define GRO in Makefile
+enable gro = 1, disable gro = 0*/
+int rtw_en_gro = 1;
+module_param(rtw_en_gro, int, 0644);
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+#ifdef RTW_IQK_FW_OFFLOAD
+int rtw_iqk_fw_offload = 1;
+#else
+int rtw_iqk_fw_offload;
+#endif /* RTW_IQK_FW_OFFLOAD */
+module_param(rtw_iqk_fw_offload, int, 0644);
+
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+int rtw_ch_switch_offload = 0;
+#else
+int rtw_ch_switch_offload;
+#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+module_param(rtw_ch_switch_offload, int, 0644);
+
+#ifdef CONFIG_TDLS
+int rtw_en_tdls = 1;
+module_param(rtw_en_tdls, int, 0644);
+#endif
+
+#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+int rtw_fw_param_init = 1;
+module_param(rtw_fw_param_init, int, 0644);
+#endif
+
+#ifdef CONFIG_WOWLAN
+/*
+ * bit[0]: magic packet wake up
+ * bit[1]: unucast packet(HW/FW unuicast)
+ * bit[2]: deauth wake up
+ */
+uint rtw_wakeup_event = RTW_WAKEUP_EVENT;
+module_param(rtw_wakeup_event, uint, 0644);
+#endif
 
 void rtw_regsty_load_target_tx_power(struct registry_priv *regsty)
 {
@@ -562,17 +822,56 @@ void rtw_regsty_load_target_tx_power(struct registry_priv *regsty)
 #endif /* CONFIG_IEEE80211_BAND_5GHZ */
 }
 
+inline void rtw_regsty_load_excl_chs(struct registry_priv *regsty)
+{
+	int i;
+	int ch_num = 0;
+
+	for (i = 0; i < MAX_CHANNEL_NUM; i++)
+		if (((u8)rtw_excl_chs[i]) != 0)
+			regsty->excl_chs[ch_num++] = (u8)rtw_excl_chs[i];
+
+	if (ch_num < MAX_CHANNEL_NUM)
+		regsty->excl_chs[ch_num] = 0;
+}
+
+#ifdef CONFIG_80211N_HT
+inline void rtw_regsty_init_rx_ampdu_sz_limit(struct registry_priv *regsty)
+{
+	int i, j;
+	uint *sz_limit;
+
+	for (i = 0; i < 4; i++) {
+		if (i == 0)
+			sz_limit = rtw_rx_ampdu_sz_limit_1ss;
+		else if (i == 1)
+			sz_limit = rtw_rx_ampdu_sz_limit_2ss;
+		else if (i == 2)
+			sz_limit = rtw_rx_ampdu_sz_limit_3ss;
+		else if (i == 3)
+			sz_limit = rtw_rx_ampdu_sz_limit_4ss;
+
+		for (j = 0; j < 4; j++)
+			regsty->rx_ampdu_sz_limit_by_nss_bw[i][j] = sz_limit[j];
+	}
+}
+#endif /* CONFIG_80211N_HT */
+
 uint loadparam(_adapter *padapter)
 {
 	uint status = _SUCCESS;
 	struct registry_priv  *registry_par = &padapter->registrypriv;
 
-_func_enter_;
+
+#ifdef CONFIG_RTW_DEBUG
+	if (rtw_drv_log_level >= _DRV_MAX_)
+		rtw_drv_log_level = _DRV_DEBUG_;
+#endif
 
 	registry_par->chip_version = (u8)rtw_chip_version;
 	registry_par->rfintfs = (u8)rtw_rfintfs;
 	registry_par->lbkmode = (u8)rtw_lbkmode;
-	//registry_par->hci = (u8)hci;
+	/* registry_par->hci = (u8)hci; */
 	registry_par->network_mode  = (u8)rtw_network_mode;
 
 	_rtw_memcpy(registry_par->ssid.Ssid, "ANY", 3);
@@ -581,32 +880,30 @@ _func_enter_;
 	registry_par->channel = (u8)rtw_channel;
 	registry_par->wireless_mode = (u8)rtw_wireless_mode;
 
-	if (IsSupported24G(registry_par->wireless_mode) && (!IsSupported5G(registry_par->wireless_mode))
-		&& (registry_par->channel > 14)) {
+	if (IsSupported24G(registry_par->wireless_mode) && (!is_supported_5g(registry_par->wireless_mode))
+	    && (registry_par->channel > 14))
 		registry_par->channel = 1;
-	}
-	else if (IsSupported5G(registry_par->wireless_mode) && (!IsSupported24G(registry_par->wireless_mode))
-		&& (registry_par->channel <= 14)) {
+	else if (is_supported_5g(registry_par->wireless_mode) && (!IsSupported24G(registry_par->wireless_mode))
+		 && (registry_par->channel <= 14))
 		registry_par->channel = 36;
-	}
-	
+
 	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->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->smart_ps = (u8)rtw_smart_ps;
 	registry_par->check_fw_ps = (u8)rtw_check_fw_ps;
 	registry_par->power_mgnt = (u8)rtw_power_mgnt;
 	registry_par->ips_mode = (u8)rtw_ips_mode;
+	registry_par->lps_level = (u8)rtw_lps_level;
 	registry_par->radio_enable = (u8)rtw_radio_enable;
 	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->qos_enable = (u8)rtw_qos_enable;
+	registry_par->busy_thresh = (u16)rtw_busy_thresh;
+	registry_par->max_bss_cnt = (u16)rtw_max_bss_cnt;
+	/* registry_par->qos_enable = (u8)rtw_qos_enable; */
 	registry_par->ack_policy = (u8)rtw_ack_policy;
 	registry_par->mp_mode = (u8)rtw_mp_mode;
 #if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
@@ -617,18 +914,20 @@ _func_enter_;
 
 	registry_par->acm_method = (u8)rtw_acm_method;
 	registry_par->usb_rxagg_mode = (u8)rtw_usb_rxagg_mode;
+	registry_par->dynamic_agg_enable = (u8)rtw_dynamic_agg_enable;
 
-	 //UAPSD
+	/* WMM */
 	registry_par->wmm_enable = (u8)rtw_wmm_enable;
-	registry_par->uapsd_enable = (u8)rtw_uapsd_enable;
-	registry_par->uapsd_max_sp = (u8)rtw_uapsd_max_sp;
-	registry_par->uapsd_acbk_en = (u8)rtw_uapsd_acbk_en;
-	registry_par->uapsd_acbe_en = (u8)rtw_uapsd_acbe_en;
-	registry_par->uapsd_acvi_en = (u8)rtw_uapsd_acvi_en;
-	registry_par->uapsd_acvo_en = (u8)rtw_uapsd_acvo_en;
-
-	registry_par->RegRfKFreeEnable = (u8)rtw_rfkfree_enable;
-	
+
+#ifdef CONFIG_WMMPS_STA
+	/* UAPSD */
+	registry_par->uapsd_max_sp_len= (u8)rtw_uapsd_max_sp;
+	registry_par->uapsd_ac_enable = (u8)rtw_uapsd_ac_enable;
+	registry_par->wmm_smart_ps = (u8)rtw_wmm_smart_ps;
+#endif /* CONFIG_WMMPS_STA */
+
+	registry_par->RegPwrTrimEnable = (u8)rtw_pwrtrim_enable;
+
 	registry_par->tx_bw_mode = (u8)rtw_tx_bw_mode;
 
 #ifdef CONFIG_80211N_HT
@@ -636,19 +935,22 @@ _func_enter_;
 	registry_par->bw_mode = (u8)rtw_bw_mode;
 	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->rx_ampdu_amsdu = (u8)rtw_rx_ampdu_amsdu;
+	registry_par->tx_ampdu_amsdu = (u8)rtw_tx_ampdu_amsdu;
 	registry_par->short_gi = (u8)rtw_short_gi;
 	registry_par->ldpc_cap = (u8)rtw_ldpc_cap;
 	registry_par->stbc_cap = (u8)rtw_stbc_cap;
 	registry_par->beamform_cap = (u8)rtw_beamform_cap;
 	registry_par->beamformer_rf_num = (u8)rtw_bfer_rf_number;
 	registry_par->beamformee_rf_num = (u8)rtw_bfee_rf_number;
+	rtw_regsty_init_rx_ampdu_sz_limit(registry_par);
 #endif
 
 #ifdef CONFIG_80211AC_VHT
 	registry_par->vht_enable = (u8)rtw_vht_enable;
 	registry_par->ampdu_factor = (u8)rtw_ampdu_factor;
-	registry_par->vht_rate_sel = (u8)rtw_vht_rate_sel;
+	registry_par->vht_rx_mcs_map[0] = (u8)(rtw_vht_rx_mcs_map & 0xFF);
+	registry_par->vht_rx_mcs_map[1] = (u8)((rtw_vht_rx_mcs_map & 0xFF00) >> 8);
 #endif
 
 #ifdef CONFIG_TX_EARLY_MODE
@@ -658,6 +960,7 @@ _func_enter_;
 	registry_par->rf_config = (u8)rtw_rf_config;
 	registry_par->low_power = (u8)rtw_low_power;
 
+	registry_par->check_hw_status = (u8)rtw_check_hw_status;
 
 	registry_par->wifi_spec = (u8)rtw_wifi_spec;
 
@@ -666,12 +969,14 @@ _func_enter_;
 		|| is_alpha(rtw_country_code[1]) == _FALSE
 	) {
 		if (rtw_country_code != rtw_country_unspecified)
-			DBG_871X_LEVEL(_drv_err_, "%s discard rtw_country_code not in alpha2\n", __func__);
+			RTW_ERR("%s discard rtw_country_code not in alpha2\n", __func__);
 		_rtw_memset(registry_par->alpha2, 0xFF, 2);
 	} else
 		_rtw_memcpy(registry_par->alpha2, rtw_country_code, 2);
 
 	registry_par->channel_plan = (u8)rtw_channel_plan;
+	rtw_regsty_load_excl_chs(registry_par);
+
 	registry_par->special_rf_path = (u8)rtw_special_rf_path;
 
 	registry_par->full_ch_in_p2p_handshake = (u8)rtw_full_ch_in_p2p_handshake;
@@ -680,36 +985,39 @@ _func_enter_;
 	registry_par->bt_iso = (u8)rtw_bt_iso;
 	registry_par->bt_sco = (u8)rtw_bt_sco;
 	registry_par->bt_ampdu = (u8)rtw_bt_ampdu;
-	registry_par->ant_num = (s8)rtw_ant_num;
+	registry_par->ant_num = (u8)rtw_ant_num;
+	registry_par->single_ant_path = (u8) rtw_single_ant_path;
 #endif
 
 	registry_par->bAcceptAddbaReq = (u8)rtw_AcceptAddbaReq;
 
 	registry_par->antdiv_cfg = (u8)rtw_antdiv_cfg;
 	registry_par->antdiv_type = (u8)rtw_antdiv_type;
-	
-	registry_par->switch_usb3 = (u8)rtw_switch_usb3;
+
+	registry_par->drv_ant_band_switch = (u8) rtw_drv_ant_band_switch;
+
+	registry_par->switch_usb_mode = (u8)rtw_switch_usb_mode;
 
 #ifdef CONFIG_AUTOSUSPEND
-	registry_par->usbss_enable = (u8)rtw_enusbss;//0:disable,1:enable
+	registry_par->usbss_enable = (u8)rtw_enusbss;/* 0:disable,1:enable */
 #endif
 #ifdef SUPPORT_HW_RFOFF_DETECTED
-	registry_par->hwpdn_mode = (u8)rtw_hwpdn_mode;//0:disable,1:enable,2:by EFUSE config
-	registry_par->hwpwrp_detect = (u8)rtw_hwpwrp_detect;//0:disable,1:enable
+	registry_par->hwpdn_mode = (u8)rtw_hwpdn_mode;/* 0:disable,1:enable,2:by EFUSE config */
+	registry_par->hwpwrp_detect = (u8)rtw_hwpwrp_detect;/* 0:disable,1:enable */
 #endif
 
 	registry_par->hw_wps_pbc = (u8)rtw_hw_wps_pbc;
 
 #ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
 	snprintf(registry_par->adaptor_info_caching_file_path, PATH_LENGTH_MAX, "%s", rtw_adaptor_info_caching_file_path);
-	registry_par->adaptor_info_caching_file_path[PATH_LENGTH_MAX-1]=0;
+	registry_par->adaptor_info_caching_file_path[PATH_LENGTH_MAX - 1] = 0;
 #endif
 
 #ifdef CONFIG_LAYER2_ROAMING
 	registry_par->max_roaming_times = (u8)rtw_max_roaming_times;
 #ifdef CONFIG_INTEL_WIDI
 	registry_par->max_roaming_times = (u8)rtw_max_roaming_times + 2;
-#endif // CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 #endif
 
 #ifdef CONFIG_IOL
@@ -725,27 +1033,23 @@ _func_enter_;
 
 	registry_par->notch_filter = (u8)rtw_notch_filter;
 
-#ifdef CONFIG_SPECIAL_SETTING_FOR_FUNAI_TV
-	registry_par->force_ant = (u8)rtw_force_ant;
-	registry_par->force_igi = (u8)rtw_force_igi;
+#ifdef CONFIG_CONCURRENT_MODE
+	registry_par->virtual_iface_num = (u8)rtw_virtual_iface_num;
 #endif
-
-#ifdef CONFIG_MULTI_VIR_IFACES
-	registry_par->ext_iface_num = (u8)rtw_ext_iface_num;
-#endif //CONFIG_MULTI_VIR_IFACES
-
 	registry_par->pll_ref_clk_sel = (u8)rtw_pll_ref_clk_sel;
 
+#ifdef CONFIG_TXPWR_LIMIT
 	registry_par->RegEnableTxPowerLimit = (u8)rtw_tx_pwr_lmt_enable;
+#endif
 	registry_par->RegEnableTxPowerByRate = (u8)rtw_tx_pwr_by_rate;
 
 	rtw_regsty_load_target_tx_power(registry_par);
 
-	registry_par->RegPowerBase = 14;
 	registry_par->TxBBSwing_2G = (s8)rtw_TxBBSwing_2G;
 	registry_par->TxBBSwing_5G = (s8)rtw_TxBBSwing_5G;
 	registry_par->bEn_RFE = 1;
 	registry_par->RFE_Type = (u8)rtw_RFE_type;
+	registry_par->PowerTracking_Type = (u8)rtw_powertracking_type;
 	registry_par->AmplifierType_2G = (u8)rtw_amplifier_type_2g;
 	registry_par->AmplifierType_5G = (u8)rtw_amplifier_type_5g;
 	registry_par->GLNA_Type = (u8)rtw_GLNA_type;
@@ -764,18 +1068,89 @@ _func_enter_;
 	registry_par->adaptivity_th_l2h_ini = (s8)rtw_adaptivity_th_l2h_ini;
 	registry_par->adaptivity_th_edcca_hl_diff = (s8)rtw_adaptivity_th_edcca_hl_diff;
 
+#ifdef CONFIG_DYNAMIC_SOML
+	registry_par->dyn_soml_en = (u8)rtw_dynamic_soml_en;
+	registry_par->dyn_soml_train_num = (u8)rtw_dynamic_soml_train_num;
+	registry_par->dyn_soml_interval = (u8)rtw_dynamic_soml_interval;
+	registry_par->dyn_soml_period = (u8)rtw_dynamic_soml_period;
+	registry_par->dyn_soml_delay = (u8)rtw_dynamic_soml_delay;
+#endif
+
 	registry_par->boffefusemask = (u8)rtw_OffEfuseMask;
 	registry_par->bFileMaskEfuse = (u8)rtw_FileMaskEfuse;
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-	registry_par->acs_mode = (u8)rtw_acs_mode;
+
+#ifdef CONFIG_RTW_ACS
+	registry_par->acs_mode = (u8)rtw_acs;
 	registry_par->acs_auto_scan = (u8)rtw_acs_auto_scan;
+#endif
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	registry_par->nm_mode = (u8)rtw_nm;
 #endif
 	registry_par->reg_rxgain_offset_2g = (u32) rtw_rxgain_offset_2g;
 	registry_par->reg_rxgain_offset_5gl = (u32) rtw_rxgain_offset_5gl;
 	registry_par->reg_rxgain_offset_5gm = (u32) rtw_rxgain_offset_5gm;
 	registry_par->reg_rxgain_offset_5gh = (u32) rtw_rxgain_offset_5gh;
-_func_exit_;
 
+#ifdef CONFIG_DFS_MASTER
+	registry_par->dfs_region_domain = (u8)rtw_dfs_region_domain;
+#endif
+
+#ifdef CONFIG_MCC_MODE
+	registry_par->en_mcc = (u8)rtw_en_mcc;
+	registry_par->rtw_mcc_ap_bw20_target_tx_tp = (u32)rtw_mcc_ap_bw20_target_tx_tp;
+	registry_par->rtw_mcc_ap_bw40_target_tx_tp = (u32)rtw_mcc_ap_bw40_target_tx_tp;
+	registry_par->rtw_mcc_ap_bw80_target_tx_tp = (u32)rtw_mcc_ap_bw80_target_tx_tp;
+	registry_par->rtw_mcc_sta_bw20_target_tx_tp = (u32)rtw_mcc_sta_bw20_target_tx_tp;
+	registry_par->rtw_mcc_sta_bw40_target_tx_tp = (u32)rtw_mcc_sta_bw40_target_tx_tp;
+	registry_par->rtw_mcc_sta_bw80_target_tx_tp = (u32)rtw_mcc_sta_bw80_target_tx_tp;
+	registry_par->rtw_mcc_single_tx_cri = (u32)rtw_mcc_single_tx_cri;
+	registry_par->rtw_mcc_policy_table_idx = rtw_mcc_policy_table_idx;
+	registry_par->rtw_mcc_duration = (u8)rtw_mcc_duration;
+	registry_par->rtw_mcc_enable_runtime_duration = rtw_mcc_enable_runtime_duration;
+#endif /*CONFIG_MCC_MODE */
+
+#ifdef CONFIG_WOWLAN
+	registry_par->wakeup_event = rtw_wakeup_event;
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	registry_par->trx_share_mode = rtw_trx_share_mode;
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	registry_par->pci_aspm_config = rtw_pci_aspm_enable;
+#endif
+
+#ifdef CONFIG_RTW_NAPI
+	registry_par->en_napi = (u8)rtw_en_napi;
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	registry_par->napi_threshold = (u32)rtw_napi_threshold;
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#ifdef CONFIG_RTW_GRO
+	registry_par->en_gro = (u8)rtw_en_gro;
+	if (!registry_par->en_napi && registry_par->en_gro) {
+		registry_par->en_gro = 0;
+		RTW_WARN("Disable GRO because NAPI is not enabled\n");
+	}
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+	registry_par->iqk_fw_offload = (u8)rtw_iqk_fw_offload;
+	registry_par->ch_switch_offload = (u8)rtw_ch_switch_offload;
+
+#ifdef CONFIG_TDLS
+	registry_par->en_tdls = rtw_en_tdls;
+#endif
+
+#ifdef CONFIG_ADVANCE_OTA
+	registry_par->adv_ota = rtw_advnace_ota;
+#endif
+#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
+	registry_par->fw_param_init = rtw_fw_param_init;
+#endif
+#ifdef CONFIG_AP_MODE
+	registry_par->bmc_tx_rate = rtw_bmc_tx_rate;
+#endif
 	return status;
 }
 
@@ -804,26 +1179,26 @@ static int rtw_net_set_mac_address(struct net_device *pnetdev, void *addr)
 
 	/* only the net_device is in down state to permit modifying mac addr */
 	if ((pnetdev->flags & IFF_UP) == _TRUE) {
-		DBG_871X(FUNC_ADPT_FMT": The net_device's is not in down state\n"
-			, FUNC_ADPT_ARG(padapter));
+		RTW_INFO(FUNC_ADPT_FMT": The net_device's is not in down state\n"
+			 , FUNC_ADPT_ARG(padapter));
 
 		return ret;
 	}
 
 	/* if the net_device is linked, it's not permit to modify mac addr */
 	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) ||
-		check_fwstate(pmlmepriv, _FW_LINKED) ||
-		check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
-		DBG_871X(FUNC_ADPT_FMT": The net_device's is not idle currently\n"
-			, FUNC_ADPT_ARG(padapter));
+	    check_fwstate(pmlmepriv, _FW_LINKED) ||
+	    check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
+		RTW_INFO(FUNC_ADPT_FMT": The net_device's is not idle currently\n"
+			 , FUNC_ADPT_ARG(padapter));
 
 		return ret;
 	}
 
 	/* check whether the input mac address is valid to permit modifying mac addr */
 	if (rtw_check_invalid_mac_address(sa->sa_data, _FALSE) == _TRUE) {
-		DBG_871X(FUNC_ADPT_FMT": Invalid Mac Addr for "MAC_FMT"\n"
-			, FUNC_ADPT_ARG(padapter), MAC_ARG(sa->sa_data));
+		RTW_INFO(FUNC_ADPT_FMT": Invalid Mac Addr for "MAC_FMT"\n"
+			 , FUNC_ADPT_ARG(padapter), MAC_ARG(sa->sa_data));
 
 		return ret;
 	}
@@ -831,13 +1206,32 @@ static int rtw_net_set_mac_address(struct net_device *pnetdev, void *addr)
 	_rtw_memcpy(adapter_mac_addr(padapter), sa->sa_data, ETH_ALEN); /* set mac addr to adapter */
 	_rtw_memcpy(pnetdev->dev_addr, sa->sa_data, ETH_ALEN); /* set mac addr to net_device */
 
+#if 0
+	if (rtw_is_hw_init_completed(padapter)) {
+		rtw_ps_deny(padapter, PS_DENY_IOCTL);
+		LeaveAllPowerSaveModeDirect(padapter); /* leave PS mode for guaranteeing to access hw register successfully */
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_hal_change_macaddr_mbid(padapter, sa->sa_data);
+#else
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, sa->sa_data); /* set mac addr to mac register */
+#endif
+
+		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+	}
+#else
 	rtw_ps_deny(padapter, PS_DENY_IOCTL);
 	LeaveAllPowerSaveModeDirect(padapter); /* leave PS mode for guaranteeing to access hw register successfully */
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_hal_change_macaddr_mbid(padapter, sa->sa_data);
+#else
 	rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, sa->sa_data); /* set mac addr to mac register */
+#endif
 	rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
+#endif
 
-	DBG_871X(FUNC_ADPT_FMT": Set Mac Addr to "MAC_FMT" Successfully\n"
-		, FUNC_ADPT_ARG(padapter), MAC_ARG(sa->sa_data));
+	RTW_INFO(FUNC_ADPT_FMT": Set Mac Addr to "MAC_FMT" Successfully\n"
+		 , FUNC_ADPT_ARG(padapter), MAC_ARG(sa->sa_data));
 
 	ret = 0;
 
@@ -850,8 +1244,8 @@ static struct net_device_stats *rtw_net_get_stats(struct net_device *pnetdev)
 	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
 	struct recv_priv *precvpriv = &(padapter->recvpriv);
 
-	padapter->stats.tx_packets = pxmitpriv->tx_pkts;//pxmitpriv->tx_pkts++;
-	padapter->stats.rx_packets = precvpriv->rx_pkts;//precvpriv->rx_pkts++;
+	padapter->stats.tx_packets = pxmitpriv->tx_pkts;/* pxmitpriv->tx_pkts++; */
+	padapter->stats.rx_packets = precvpriv->rx_pkts;/* precvpriv->rx_pkts++; */
 	padapter->stats.tx_dropped = pxmitpriv->tx_drop;
 	padapter->stats.rx_dropped = precvpriv->rx_drop;
 	padapter->stats.tx_bytes = pxmitpriv->tx_bytes;
@@ -860,7 +1254,7 @@ static struct net_device_stats *rtw_net_get_stats(struct net_device *pnetdev)
 	return &padapter->stats;
 }
 
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 /*
  * AC to queue mapping
  *
@@ -895,14 +1289,13 @@ unsigned int rtw_classify8021d(struct sk_buff *skb)
 	return dscp >> 5;
 }
 
- 
-static u16 rtw_select_queue(struct net_device *dev, struct sk_buff *skb
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0) 	
-				, void *accel_priv
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0) 
-				, select_queue_fallback_t fallback
-#endif
 
+static u16 rtw_select_queue(struct net_device *dev, struct sk_buff *skb
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0)
+	, void *accel_priv
+	#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
+	, select_queue_fallback_t fallback
+	#endif
 #endif
 )
 {
@@ -911,10 +1304,8 @@ static u16 rtw_select_queue(struct net_device *dev, struct sk_buff *skb
 
 	skb->priority = rtw_classify8021d(skb);
 
-	if(pmlmepriv->acm_mask != 0)
-	{
+	if (pmlmepriv->acm_mask != 0)
 		skb->priority = qos_acm(pmlmepriv->acm_mask, skb->priority);
-	}
 
 	return rtw_1d_to_queue[skb->priority];
 }
@@ -927,20 +1318,20 @@ u16 rtw_recv_select_queue(struct sk_buff *skb)
 	u32 priority;
 	u8 *pdata = skb->data;
 
-	_rtw_memcpy(&eth_type, pdata+(ETH_ALEN<<1), 2);
+	_rtw_memcpy(&eth_type, pdata + (ETH_ALEN << 1), 2);
 
 	switch (eth_type) {
-		case htons(ETH_P_IP):
+	case htons(ETH_P_IP):
 
-			piphdr = (struct iphdr *)(pdata+ETH_HLEN);
+		piphdr = (struct iphdr *)(pdata + ETH_HLEN);
 
-			dscp = piphdr->tos & 0xfc;
+		dscp = piphdr->tos & 0xfc;
 
-			priority = dscp >> 5;
+		priority = dscp >> 5;
 
-			break;
-		default:
-			priority = 0;
+		break;
+	default:
+		priority = 0;
 	}
 
 	return rtw_1d_to_queue[priority];
@@ -948,32 +1339,43 @@ u16 rtw_recv_select_queue(struct sk_buff *skb)
 }
 
 #endif
-static int rtw_ndev_notifier_call(struct notifier_block * nb, unsigned long state, void *ptr)
-{	
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(3,11,0))
-	struct net_device *dev = netdev_notifier_info_to_dev(ptr);
+
+static u8 is_rtw_ndev(struct net_device *ndev)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+	return ndev->netdev_ops
+		&& ndev->netdev_ops->ndo_do_ioctl
+		&& ndev->netdev_ops->ndo_do_ioctl == rtw_ioctl;
 #else
-	struct net_device *dev = ptr;
+	return ndev->do_ioctl
+		&& ndev->do_ioctl == rtw_ioctl;
 #endif
+}
+
+static int rtw_ndev_notifier_call(struct notifier_block *nb, unsigned long state, void *ptr)
+{
+	struct net_device *ndev;
 
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
-	if (dev->netdev_ops->ndo_do_ioctl == NULL)
+	if (ptr == NULL)
 		return NOTIFY_DONE;
 
-	if (dev->netdev_ops->ndo_do_ioctl != rtw_ioctl)
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	ndev = netdev_notifier_info_to_dev(ptr);
 #else
-	if (dev->do_ioctl == NULL)
+	ndev = ptr;
+#endif
+
+	if (ndev == NULL)
 		return NOTIFY_DONE;
 
-	if (dev->do_ioctl != rtw_ioctl)
-#endif
+	if (!is_rtw_ndev(ndev))
 		return NOTIFY_DONE;
 
-	DBG_871X_LEVEL(_drv_info_, FUNC_NDEV_FMT" state:%lu\n", FUNC_NDEV_ARG(dev), state);
+	RTW_INFO(FUNC_NDEV_FMT" state:%lu\n", FUNC_NDEV_ARG(ndev), state);
 
 	switch (state) {
 	case NETDEV_CHANGENAME:
-		rtw_adapter_proc_replace(dev);
+		rtw_adapter_proc_replace(ndev);
 		break;
 	}
 
@@ -994,15 +1396,14 @@ void rtw_ndev_notifier_unregister(void)
 	unregister_netdevice_notifier(&rtw_ndev_notifier);
 }
 
-
 int rtw_ndev_init(struct net_device *dev)
 {
 	_adapter *adapter = rtw_netdev_priv(dev);
 
-	DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" if%d mac_addr="MAC_FMT"\n"
-		, FUNC_ADPT_ARG(adapter), (adapter->iface_id+1), MAC_ARG(dev->dev_addr));
+	RTW_PRINT(FUNC_ADPT_FMT" if%d mac_addr="MAC_FMT"\n"
+		, FUNC_ADPT_ARG(adapter), (adapter->iface_id + 1), MAC_ARG(dev->dev_addr));
 	strncpy(adapter->old_ifname, dev->name, IFNAMSIZ);
-	adapter->old_ifname[IFNAMSIZ-1] = '\0';
+	adapter->old_ifname[IFNAMSIZ - 1] = '\0';
 	rtw_adapter_proc_init(dev);
 
 	return 0;
@@ -1012,19 +1413,19 @@ void rtw_ndev_uninit(struct net_device *dev)
 {
 	_adapter *adapter = rtw_netdev_priv(dev);
 
-	DBG_871X_LEVEL(_drv_always_, FUNC_ADPT_FMT" if%d\n"
-		, FUNC_ADPT_ARG(adapter), (adapter->iface_id+1));
+	RTW_PRINT(FUNC_ADPT_FMT" if%d\n"
+		  , FUNC_ADPT_ARG(adapter), (adapter->iface_id + 1));
 	rtw_adapter_proc_deinit(dev);
 }
 
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 static const struct net_device_ops rtw_netdev_ops = {
 	.ndo_init = rtw_ndev_init,
 	.ndo_uninit = rtw_ndev_uninit,
 	.ndo_open = netdev_open,
 	.ndo_stop = netdev_close,
 	.ndo_start_xmit = rtw_xmit_entry,
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	.ndo_select_queue	= rtw_select_queue,
 #endif
 	.ndo_set_mac_address = rtw_net_set_mac_address,
@@ -1040,22 +1441,21 @@ int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname)
 #ifdef CONFIG_EASY_REPLACEMENT
 	struct net_device	*TargetNetdev = NULL;
 	_adapter			*TargetAdapter = NULL;
-	struct net 		*devnet = NULL;
+	struct net		*devnet = NULL;
 
-	if(padapter->bDongle == 1)
-	{
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,24))
+	if (padapter->bDongle == 1) {
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
 		TargetNetdev = dev_get_by_name("wlan0");
 #else
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,26))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
 		devnet = pnetdev->nd_net;
-	#else
+#else
 		devnet = dev_net(pnetdev);
-	#endif
+#endif
 		TargetNetdev = dev_get_by_name(devnet, "wlan0");
 #endif
-		if(TargetNetdev) {
-			DBG_871X("Force onboard module driver disappear !!!\n");
+		if (TargetNetdev) {
+			RTW_INFO("Force onboard module driver disappear !!!\n");
 			TargetAdapter = rtw_netdev_priv(TargetNetdev);
 			TargetAdapter->DriverState = DRIVER_DISAPPEAR;
 
@@ -1069,15 +1469,13 @@ int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname)
 			padapter->DriverState = DRIVER_REPLACE_DONGLE;
 		}
 	}
-#endif //CONFIG_EASY_REPLACEMENT
+#endif /* CONFIG_EASY_REPLACEMENT */
 
-	if(dev_alloc_name(pnetdev, ifname) < 0)
-	{
-		RT_TRACE(_module_os_intfs_c_,_drv_err_,("dev_alloc_name, fail! \n"));
-	}
+	if (dev_alloc_name(pnetdev, ifname) < 0)
+		RTW_ERR("dev_alloc_name, fail!\n");
 
-	netif_carrier_off(pnetdev);
-	//rtw_netif_stop_queue(pnetdev);
+	rtw_netif_carrier_off(pnetdev);
+	/* rtw_netif_stop_queue(pnetdev); */
 
 	return 0;
 }
@@ -1098,16 +1496,18 @@ void rtw_hook_if_ops(struct net_device *ndev)
 #endif
 }
 
+#ifdef CONFIG_CONCURRENT_MODE
+static void rtw_hook_vir_if_ops(struct net_device *ndev);
+#endif
 struct net_device *rtw_init_netdev(_adapter *old_padapter)
 {
 	_adapter *padapter;
 	struct net_device *pnetdev;
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("+init_net_dev\n"));
-
-	if(old_padapter != NULL)
+	if (old_padapter != NULL) {
+		rtw_os_ndev_free(old_padapter);
 		pnetdev = rtw_alloc_etherdev_with_old_priv(sizeof(_adapter), (void *)old_padapter);
-	else
+	} else
 		pnetdev = rtw_alloc_etherdev(sizeof(_adapter));
 
 	if (!pnetdev)
@@ -1116,26 +1516,37 @@ struct net_device *rtw_init_netdev(_adapter *old_padapter)
 	padapter = rtw_netdev_priv(pnetdev);
 	padapter->pnetdev = pnetdev;
 
-#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,24)
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24)
 	SET_MODULE_OWNER(pnetdev);
 #endif
 
 	rtw_hook_if_ops(pnetdev);
+#ifdef CONFIG_CONCURRENT_MODE
+	if (!is_primary_adapter(padapter))
+		rtw_hook_vir_if_ops(pnetdev);
+#endif /* CONFIG_CONCURRENT_MODE */
 
 #ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
 	pnetdev->features |= NETIF_F_IP_CSUM;
 #endif
 
-	//pnetdev->tx_timeout = NULL;
-	pnetdev->watchdog_timeo = HZ*3; /* 3 second timeout */
+#ifdef CONFIG_RTW_NETIF_SG
+		pnetdev->features |= NETIF_F_SG;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
+		pnetdev->hw_features |= NETIF_F_SG;
+#endif
+#endif
+
+	/* pnetdev->tx_timeout = NULL; */
+	pnetdev->watchdog_timeo = HZ * 3; /* 3 second timeout */
 
 #ifdef CONFIG_WIRELESS_EXT
 	pnetdev->wireless_handlers = (struct iw_handler_def *)&rtw_handlers_def;
 #endif
 
 #ifdef WIRELESS_SPY
-	//priv->wireless_data.spy_data = &priv->spy_data;
-	//pnetdev->wireless_data = &priv->wireless_data;
+	/* priv->wireless_data.spy_data = &priv->spy_data; */
+	/* pnetdev->wireless_data = &priv->wireless_data; */
 #endif
 
 	return pnetdev;
@@ -1151,15 +1562,15 @@ int rtw_os_ndev_alloc(_adapter *adapter)
 		rtw_warn_on(1);
 		goto exit;
 	}
-	#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 0)
+#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 5, 0)
 	SET_NETDEV_DEV(ndev, dvobj_to_dev(adapter_to_dvobj(adapter)));
-	#endif
+#endif
 
-	#ifdef CONFIG_PCI_HCI
+#ifdef CONFIG_PCI_HCI
 	if (adapter_to_dvobj(adapter)->bdma64)
 		ndev->features |= NETIF_F_HIGHDMA;
 	ndev->irq = adapter_to_dvobj(adapter)->irq;
-	#endif
+#endif
 
 #if defined(CONFIG_IOCTL_CFG80211)
 	if (rtw_cfg80211_ndev_res_alloc(adapter) != _SUCCESS) {
@@ -1189,10 +1600,16 @@ void rtw_os_ndev_free(_adapter *adapter)
 	}
 }
 
-int rtw_os_ndev_register(_adapter *adapter, char *name)
+int rtw_os_ndev_register(_adapter *adapter, const char *name)
 {
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	int ret = _SUCCESS;
 	struct net_device *ndev = adapter->pnetdev;
+	u8 rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+
+#ifdef CONFIG_RTW_NAPI
+	netif_napi_add(ndev, &adapter->napi, rtw_recv_napi_poll, RTL_NAPI_WEIGHT);
+#endif /* CONFIG_RTW_NAPI */
 
 #if defined(CONFIG_IOCTL_CFG80211)
 	if (rtw_cfg80211_ndev_res_register(adapter) != _SUCCESS) {
@@ -1208,10 +1625,16 @@ int rtw_os_ndev_register(_adapter *adapter, char *name)
 	_rtw_memcpy(ndev->dev_addr, adapter_mac_addr(adapter), ETH_ALEN);
 
 	/* Tell the network stack we exist */
-	if (register_netdev(ndev) != 0) {
-		DBG_871X(FUNC_NDEV_FMT" if%d Failed!\n", FUNC_NDEV_ARG(ndev), (adapter->iface_id+1));
-		ret = _FAIL;
-	}
+
+	if (rtnl_lock_needed)
+		ret = (register_netdev(ndev) == 0) ? _SUCCESS : _FAIL;
+	else
+		ret = (register_netdevice(ndev) == 0) ? _SUCCESS : _FAIL;
+
+	if (ret == _SUCCESS)
+		adapter->registered = 1;
+	else
+		RTW_INFO(FUNC_NDEV_FMT" if%d Failed!\n", FUNC_NDEV_ARG(ndev), (adapter->iface_id + 1));
 
 #if defined(CONFIG_IOCTL_CFG80211)
 	if (ret != _SUCCESS) {
@@ -1223,6 +1646,11 @@ int rtw_os_ndev_register(_adapter *adapter, char *name)
 #endif
 
 exit:
+#ifdef CONFIG_RTW_NAPI
+	if (ret != _SUCCESS)
+		netif_napi_del(&adapter->napi);
+#endif /* CONFIG_RTW_NAPI */
+
 	return ret;
 }
 
@@ -1230,7 +1658,7 @@ void rtw_os_ndev_unregister(_adapter *adapter)
 {
 	struct net_device *netdev = NULL;
 
-	if (adapter == NULL)
+	if (adapter == NULL || adapter->registered == 0)
 		return;
 
 	adapter->ndev_unregistering = 1;
@@ -1241,13 +1669,32 @@ void rtw_os_ndev_unregister(_adapter *adapter)
 	rtw_cfg80211_ndev_res_unregister(adapter);
 #endif
 
-	if ((adapter->DriverState != DRIVER_DISAPPEAR) && netdev)
-		unregister_netdev(netdev); /* will call netdev_close() */
+	if ((adapter->DriverState != DRIVER_DISAPPEAR) && netdev) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+		u8 rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+
+		if (rtnl_lock_needed)
+			unregister_netdev(netdev);
+		else
+			unregister_netdevice(netdev);
+	}
 
 #if defined(CONFIG_IOCTL_CFG80211) && !defined(RTW_SINGLE_WIPHY)
+#ifdef CONFIG_RFKILL_POLL
+	rtw_cfg80211_deinit_rfkill(adapter_to_wiphy(adapter));
+#endif
 	rtw_wiphy_unregister(adapter_to_wiphy(adapter));
 #endif
 
+#ifdef CONFIG_RTW_NAPI
+	if (adapter->napi_state == NAPI_ENABLE) {
+		napi_disable(&adapter->napi);
+		adapter->napi_state = NAPI_DISABLE;
+	}
+	netif_napi_del(&adapter->napi);
+#endif /* CONFIG_RTW_NAPI */
+
+	adapter->registered = 0;
 	adapter->ndev_unregistering = 0;
 }
 
@@ -1259,7 +1706,7 @@ void rtw_os_ndev_unregister(_adapter *adapter)
  * Returns:
  * _SUCCESS or _FAIL
  */
-int rtw_os_ndev_init(_adapter *adapter, char *name)
+int rtw_os_ndev_init(_adapter *adapter, const char *name)
 {
 	int ret = _FAIL;
 
@@ -1303,14 +1750,20 @@ int rtw_os_ndevs_alloc(struct dvobj_priv *dvobj)
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 
-		if (i >= IFACE_ID_MAX) {
-			DBG_871X_LEVEL(_drv_err_, "%s %d >= IFACE_ID_MAX\n", __func__, i);
+		if (i >= CONFIG_IFACE_NUMBER) {
+			RTW_ERR("%s %d >= CONFIG_IFACE_NUMBER(%d)\n", __func__, i, CONFIG_IFACE_NUMBER);
 			rtw_warn_on(1);
 			continue;
 		}
 
 		adapter = dvobj->padapters[i];
 		if (adapter && !adapter->pnetdev) {
+
+			#ifdef CONFIG_RTW_DYNAMIC_NDEV
+			if (!is_primary_adapter(adapter))
+				continue;
+			#endif
+
 			status = rtw_os_ndev_alloc(adapter);
 			if (status != _SUCCESS) {
 				rtw_warn_on(1);
@@ -1342,8 +1795,8 @@ void rtw_os_ndevs_free(struct dvobj_priv *dvobj)
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 
-		if (i >= IFACE_ID_MAX) {
-			DBG_871X_LEVEL(_drv_err_, "%s %d >= IFACE_ID_MAX\n", __func__, i);
+		if (i >= CONFIG_IFACE_NUMBER) {
+			RTW_ERR("%s %d >= CONFIG_IFACE_NUMBER(%d)\n", __func__, i, CONFIG_IFACE_NUMBER);
 			rtw_warn_on(1);
 			continue;
 		}
@@ -1365,40 +1818,59 @@ u32 rtw_start_drv_threads(_adapter *padapter)
 {
 	u32 _status = _SUCCESS;
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("+rtw_start_drv_threads\n"));
 
 #ifdef CONFIG_XMIT_THREAD_MODE
 #if defined(CONFIG_SDIO_HCI)
 	if (is_primary_adapter(padapter))
-#endif		
+#endif
 	{
-		padapter->xmitThread = kthread_run(rtw_xmit_thread, padapter, "RTW_XMIT_THREAD");
-		if(IS_ERR(padapter->xmitThread))
-			_status = _FAIL;
+		if (padapter->xmitThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_XMIT_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->xmitThread = kthread_run(rtw_xmit_thread, padapter, "RTW_XMIT_THREAD");
+			if (IS_ERR(padapter->xmitThread)) {
+				padapter->xmitThread = NULL;
+				_status = _FAIL;
+			}
+		}
 	}
-#endif //#ifdef CONFIG_XMIT_THREAD_MODE
+#endif /* #ifdef CONFIG_XMIT_THREAD_MODE */
 
 #ifdef CONFIG_RECV_THREAD_MODE
 	if (is_primary_adapter(padapter)) {
-		padapter->recvThread = kthread_run(rtw_recv_thread, padapter, "RTW_RECV_THREAD");
-		if (IS_ERR(padapter->recvThread))
-			_status = _FAIL;
+		if (padapter->recvThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_RECV_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->recvThread = kthread_run(rtw_recv_thread, padapter, "RTW_RECV_THREAD");
+			if (IS_ERR(padapter->recvThread)) {
+				padapter->recvThread = NULL;
+				_status = _FAIL;
+			}
+		}
 	}
 #endif
 
 	if (is_primary_adapter(padapter)) {
-		padapter->cmdThread = kthread_run(rtw_cmd_thread, padapter, "RTW_CMD_THREAD");
-	        if(IS_ERR(padapter->cmdThread))
-			_status = _FAIL;
-		else
-			_rtw_down_sema(&padapter->cmdpriv.terminate_cmdthread_sema); //wait for cmd_thread to run
+		if (padapter->cmdThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_CMD_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->cmdThread = kthread_run(rtw_cmd_thread, padapter, "RTW_CMD_THREAD");
+			if (IS_ERR(padapter->cmdThread)) {
+				padapter->cmdThread = NULL;
+				_status = _FAIL;
+			}
+			else
+				_rtw_down_sema(&padapter->cmdpriv.start_cmdthread_sema); /* wait for cmd_thread to run */
+		}
 	}
 
 
 #ifdef CONFIG_EVENT_THREAD_MODE
-	padapter->evtThread = kthread_run(event_thread, padapter, "RTW_EVENT_THREAD");
-	if(IS_ERR(padapter->evtThread))
-		_status = _FAIL;
+	if (padapter->evtThread == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT " start RTW_EVENT_THREAD\n", FUNC_ADPT_ARG(padapter));
+		padapter->evtThread = kthread_run(event_thread, padapter, "RTW_EVENT_THREAD");
+		if (IS_ERR(padapter->evtThread)) {
+			padapter->evtThread = NULL;
+			_status = _FAIL;
+		}
+	}
 #endif
 
 	rtw_hal_start_thread(padapter);
@@ -1406,38 +1878,41 @@ u32 rtw_start_drv_threads(_adapter *padapter)
 
 }
 
-void rtw_stop_drv_threads (_adapter *padapter)
+void rtw_stop_drv_threads(_adapter *padapter)
 {
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("+rtw_stop_drv_threads\n"));
 
 	if (is_primary_adapter(padapter))
 		rtw_stop_cmd_thread(padapter);
 
 #ifdef CONFIG_EVENT_THREAD_MODE
-        _rtw_up_sema(&padapter->evtpriv.evt_notify);
-	if(padapter->evtThread){
-		_rtw_down_sema(&padapter->evtpriv.terminate_evtthread_sema);
+	if (padapter->evtThread) {
+		_rtw_up_sema(&padapter->evtpriv.evt_notify);
+		rtw_thread_stop(padapter->evtThread);
+		padapter->evtThread = NULL;
 	}
 #endif
 
 #ifdef CONFIG_XMIT_THREAD_MODE
-	// Below is to termindate tx_thread...
-#if defined(CONFIG_SDIO_HCI) 
-	// Only wake-up primary adapter
+	/* Below is to termindate tx_thread... */
+#if defined(CONFIG_SDIO_HCI)
+	/* Only wake-up primary adapter */
 	if (is_primary_adapter(padapter))
 #endif  /*SDIO_HCI */
 	{
-		_rtw_up_sema(&padapter->xmitpriv.xmit_sema);
-		_rtw_down_sema(&padapter->xmitpriv.terminate_xmitthread_sema);
+		if (padapter->xmitThread) {
+			_rtw_up_sema(&padapter->xmitpriv.xmit_sema);
+			rtw_thread_stop(padapter->xmitThread);
+			padapter->xmitThread = NULL;
+		}
 	}
-	RT_TRACE(_module_os_intfs_c_, _drv_info_, ("\n drv_halt: rtw_xmit_thread can be terminated !\n"));
 #endif
 
 #ifdef CONFIG_RECV_THREAD_MODE
-	if (is_primary_adapter(padapter)) {
+	if (is_primary_adapter(padapter) && padapter->recvThread) {
 		/* Below is to termindate rx_thread... */
 		_rtw_up_sema(&padapter->recvpriv.recv_sema);
-		_rtw_down_sema(&padapter->recvpriv.terminate_recvthread_sema);
+		rtw_thread_stop(padapter->recvThread);
+		padapter->recvThread = NULL;
 	}
 #endif
 
@@ -1448,41 +1923,28 @@ u8 rtw_init_default_value(_adapter *padapter);
 u8 rtw_init_default_value(_adapter *padapter)
 {
 	u8 ret  = _SUCCESS;
-	struct registry_priv* pregistrypriv = &padapter->registrypriv;
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
-	struct mlme_priv *pmlmepriv= &padapter->mlmepriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 
-	//xmit_priv
+	/* xmit_priv */
 	pxmitpriv->vcs_setting = pregistrypriv->vrtl_carrier_sense;
 	pxmitpriv->vcs = pregistrypriv->vcs_type;
 	pxmitpriv->vcs_type = pregistrypriv->vcs_type;
-	//pxmitpriv->rts_thresh = pregistrypriv->rts_thresh;
+	/* pxmitpriv->rts_thresh = pregistrypriv->rts_thresh; */
 	pxmitpriv->frag_len = pregistrypriv->frag_thresh;
 
-	//recv_priv
-
-	//mlme_priv
-	pmlmepriv->scan_mode = SCAN_ACTIVE;
-
-	//qos_priv
-	//pmlmepriv->qospriv.qos_option = pregistrypriv->wmm_enable;
-
-	//ht_priv
-#ifdef CONFIG_80211N_HT
-	pmlmepriv->htpriv.ampdu_enable = _FALSE;//set to disabled
-#endif
-
-	//security_priv
-	//rtw_get_encrypt_decrypt_from_registrypriv(padapter);
+	/* security_priv */
+	/* rtw_get_encrypt_decrypt_from_registrypriv(padapter); */
 	psecuritypriv->binstallGrpkey = _FAIL;
 #ifdef CONFIG_GTK_OL
 	psecuritypriv->binstallKCK_KEK = _FAIL;
-#endif //CONFIG_GTK_OL
-	psecuritypriv->sw_encrypt=pregistrypriv->software_encrypt;
-	psecuritypriv->sw_decrypt=pregistrypriv->software_decrypt;
+#endif /* CONFIG_GTK_OL */
+	psecuritypriv->sw_encrypt = pregistrypriv->software_encrypt;
+	psecuritypriv->sw_decrypt = pregistrypriv->software_decrypt;
 
-	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; //open system
+	psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open; /* open system */
 	psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
 
 	psecuritypriv->dot11PrivacyKeyIndex = 0;
@@ -1492,20 +1954,28 @@ u8 rtw_init_default_value(_adapter *padapter)
 
 	psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
 	psecuritypriv->ndisencryptstatus = Ndis802_11WEPDisabled;
+#ifdef CONFIG_CONCURRENT_MODE
+	psecuritypriv->dot118021x_bmc_cam_id = INVALID_SEC_MAC_CAM_ID;
+#endif
 
 
-	//pwrctrl_priv
+	/* pwrctrl_priv */
 
 
-	//registry_priv
+	/* registry_priv */
 	rtw_init_registrypriv_dev_network(padapter);
 	rtw_update_registrypriv_dev_network(padapter);
 
 
-	//hal_priv
+	/* hal_priv */
 	rtw_hal_def_value_init(padapter);
 
-	//misc.
+#ifdef CONFIG_MCC_MODE
+	/* MCC parameter */
+	rtw_hal_mcc_parameter_init(padapter);
+#endif /* CONFIG_MCC_MODE */
+
+	/* misc. */
 	RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
 	RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
 	padapter->bLinkInfoDump = 0;
@@ -1514,10 +1984,16 @@ u8 rtw_init_default_value(_adapter *padapter)
 	padapter->bShowGetP2PState = 1;
 #endif
 
-	//for debug purpose
+	/* for debug purpose */
 	padapter->fix_rate = 0xFF;
 	padapter->data_fb = 0;
-
+	padapter->fix_bw = 0xFF;
+	padapter->power_offset = 0;
+	padapter->rsvd_page_offset = 0;
+	padapter->rsvd_page_num = 0;
+#ifdef CONFIG_AP_MODE
+	padapter->bmc_tx_rate = pregistrypriv->bmc_tx_rate;
+#endif
 	padapter->driver_tx_bw_mode = pregistrypriv->tx_bw_mode;
 
 	padapter->driver_ampdu_spacing = 0xFF;
@@ -1525,12 +2001,35 @@ u8 rtw_init_default_value(_adapter *padapter)
 	padapter->driver_rx_ampdu_spacing = 0xFF;
 	padapter->fix_rx_ampdu_accept = RX_AMPDU_ACCEPT_INVALID;
 	padapter->fix_rx_ampdu_size = RX_AMPDU_SIZE_INVALID;
+#ifdef CONFIG_TX_AMSDU
+	padapter->tx_amsdu = 2;
+	padapter->tx_amsdu_rate = 400;
+#endif
+	padapter->driver_tx_max_agg_num = 0xFF;
 #ifdef DBG_RX_COUNTER_DUMP
 	padapter->dump_rx_cnt_mode = 0;
 	padapter->drv_rx_cnt_ok = 0;
 	padapter->drv_rx_cnt_crcerror = 0;
 	padapter->drv_rx_cnt_drop = 0;
-#endif	
+#endif
+#ifdef CONFIG_RTW_NAPI
+	padapter->napi_state = NAPI_DISABLE;
+#endif
+	padapter->tsf.sync_port =  MAX_HW_PORT;
+	padapter->tsf.offset = 0;
+
+#ifdef CONFIG_RTW_ACS
+	if (pregistrypriv->acs_mode)
+		rtw_acs_start(padapter);
+	else
+		rtw_acs_stop(padapter);
+#endif
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	if (pregistrypriv->nm_mode)
+		rtw_nm_enable(padapter);
+	else
+		rtw_nm_disable(padapter);
+#endif
 	return ret;
 }
 
@@ -1538,10 +2037,9 @@ struct dvobj_priv *devobj_init(void)
 {
 	struct dvobj_priv *pdvobj = NULL;
 
-	if ((pdvobj = (struct dvobj_priv*)rtw_zmalloc(sizeof(*pdvobj))) == NULL) 
-	{
+	pdvobj = (struct dvobj_priv *)rtw_zmalloc(sizeof(*pdvobj));
+	if (pdvobj == NULL)
 		return NULL;
-	}
 
 	_rtw_mutex_init(&pdvobj->hw_init_mutex);
 	_rtw_mutex_init(&pdvobj->h2c_fwcmd_mutex);
@@ -1564,14 +2062,41 @@ struct dvobj_priv *devobj_init(void)
 	rtw_macid_ctl_init(&pdvobj->macid_ctl);
 	_rtw_spinlock_init(&pdvobj->cam_ctl.lock);
 	_rtw_mutex_init(&pdvobj->cam_ctl.sec_cam_access_mutex);
+#if defined(RTK_129X_PLATFORM) && defined(CONFIG_PCI_HCI)
+	_rtw_spinlock_init(&pdvobj->io_reg_lock);
+#endif
+#ifdef CONFIG_MBSSID_CAM
+	rtw_mbid_cam_init(pdvobj);
+#endif
 
-	return pdvobj;
+#ifdef CONFIG_AP_MODE
+	pdvobj->nr_ap_if = 0;
+	pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL; /* default value is equal to the default beacon_interval (100ms) */
+	_rtw_init_queue(&pdvobj->ap_if_q);
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	rtw_init_timer(&(pdvobj->txbcn_timer), NULL, tx_beacon_timer_handlder, pdvobj);
+#endif
+#endif
 
-}
+	rtw_init_timer(&(pdvobj->dynamic_chk_timer), NULL, rtw_dynamic_check_timer_handlder, pdvobj);
 
-void devobj_deinit(struct dvobj_priv *pdvobj)
-{
-	if(!pdvobj)
+#ifdef CONFIG_MCC_MODE
+	_rtw_mutex_init(&(pdvobj->mcc_objpriv.mcc_mutex));
+	_rtw_spinlock_init(&pdvobj->mcc_objpriv.mcc_lock);
+#endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	pdvobj->en_napi_dynamic = 0;
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+
+
+	return pdvobj;
+
+}
+
+void devobj_deinit(struct dvobj_priv *pdvobj)
+{
+	if (!pdvobj)
 		return;
 
 	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
@@ -1579,6 +2104,11 @@ void devobj_deinit(struct dvobj_priv *pdvobj)
 	rtw_cfg80211_dev_res_free(pdvobj);
 #endif
 
+#ifdef CONFIG_MCC_MODE
+	_rtw_mutex_free(&(pdvobj->mcc_objpriv.mcc_mutex));
+	_rtw_spinlock_free(&pdvobj->mcc_objpriv.mcc_lock);
+#endif /* CONFIG_MCC_MODE */
+
 	_rtw_mutex_free(&pdvobj->hw_init_mutex);
 	_rtw_mutex_free(&pdvobj->h2c_fwcmd_mutex);
 
@@ -1597,21 +2127,68 @@ void devobj_deinit(struct dvobj_priv *pdvobj)
 	_rtw_spinlock_free(&pdvobj->cam_ctl.lock);
 	_rtw_mutex_free(&pdvobj->cam_ctl.sec_cam_access_mutex);
 
-	rtw_mfree((u8*)pdvobj, sizeof(*pdvobj));
-}	
+#if defined(RTK_129X_PLATFORM) && defined(CONFIG_PCI_HCI)
+	_rtw_spinlock_free(&pdvobj->io_reg_lock);
+#endif
+#ifdef CONFIG_MBSSID_CAM
+	rtw_mbid_cam_deinit(pdvobj);
+#endif
+
+	_rtw_spinlock_free(&(pdvobj->ap_if_q.lock));
+
+	rtw_mfree((u8 *)pdvobj, sizeof(*pdvobj));
+}
+
+inline u8 rtw_rtnl_lock_needed(struct dvobj_priv *dvobj)
+{
+	if (dvobj->rtnl_lock_holder && dvobj->rtnl_lock_holder == current)
+		return 0;
+	return 1;
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
+static inline int rtnl_is_locked(void)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 17))
+	if (unlikely(rtnl_trylock())) {
+		rtnl_unlock();
+#else
+	if (unlikely(down_trylock(&rtnl_sem) == 0)) {
+		up(&rtnl_sem);
+#endif
+		return 0;
+	}
+	return 1;
+}
+#endif
+
+inline void rtw_set_rtnl_lock_holder(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl)
+{
+	rtw_warn_on(!rtnl_is_locked());
+
+	if (!thd_hdl || rtnl_is_locked())
+		dvobj->rtnl_lock_holder = thd_hdl;
+
+	if (dvobj->rtnl_lock_holder && 0)
+		RTW_INFO("rtnl_lock_holder: %s:%d\n", current->comm, current->pid);
+}
 
 u8 rtw_reset_drv_sw(_adapter *padapter)
 {
-	u8	ret8=_SUCCESS;
-	struct mlme_priv *pmlmepriv= &padapter->mlmepriv;
+	u8	ret8 = _SUCCESS;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 
-	//hal_priv
-	if( is_primary_adapter(padapter))
+	/* hal_priv */
+	if (is_primary_adapter(padapter))
 		rtw_hal_def_value_init(padapter);
 
 	RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
 	RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
+
+	padapter->tsf.sync_port =  MAX_HW_PORT;
+	padapter->tsf.offset = 0;
+
 	padapter->bLinkInfoDump = 0;
 
 	padapter->xmitpriv.tx_pkts = 0;
@@ -1619,16 +2196,16 @@ u8 rtw_reset_drv_sw(_adapter *padapter)
 
 	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
 
-	//pmlmepriv->LinkDetectInfo.TrafficBusyState = _FALSE;
+	/* pmlmepriv->LinkDetectInfo.TrafficBusyState = _FALSE; */
 	pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
 	pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
 
-	_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY |_FW_UNDER_LINKING);
+	_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING);
 
 #ifdef CONFIG_AUTOSUSPEND
-	#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,22) && LINUX_VERSION_CODE<=KERNEL_VERSION(2,6,34))
-		adapter_to_dvobj(padapter)->pusbdev->autosuspend_disabled = 1;//autosuspend disabled by the user
-	#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 34))
+	adapter_to_dvobj(padapter)->pusbdev->autosuspend_disabled = 1;/* autosuspend disabled by the user */
+#endif
 #endif
 
 #ifdef DBG_CONFIG_ERROR_DETECT
@@ -1637,7 +2214,7 @@ u8 rtw_reset_drv_sw(_adapter *padapter)
 #endif
 	pwrctrlpriv->pwr_state_check_cnts = 0;
 
-	//mlmeextpriv
+	/* mlmeextpriv */
 	mlmeext_set_scan_state(&padapter->mlmeextpriv, SCAN_DISABLE);
 
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
@@ -1651,35 +2228,31 @@ u8 rtw_reset_drv_sw(_adapter *padapter)
 u8 rtw_init_drv_sw(_adapter *padapter)
 {
 
-	u8	ret8=_SUCCESS;
+	u8	ret8 = _SUCCESS;
 
-_func_enter_;
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("+rtw_init_drv_sw\n"));
+
+	_rtw_init_listhead(&padapter->list);
 
 	ret8 = rtw_init_default_value(padapter);
 
-	if ((rtw_init_cmd_priv(&padapter->cmdpriv)) == _FAIL)
-	{
-		RT_TRACE(_module_os_intfs_c_,_drv_err_,("\n Can't init cmd_priv\n"));
-		ret8=_FAIL;
+	if ((rtw_init_cmd_priv(&padapter->cmdpriv)) == _FAIL) {
+		ret8 = _FAIL;
 		goto exit;
 	}
 
-	padapter->cmdpriv.padapter=padapter;
+	padapter->cmdpriv.padapter = padapter;
 
-	if ((rtw_init_evt_priv(&padapter->evtpriv)) == _FAIL)
-	{
-		RT_TRACE(_module_os_intfs_c_,_drv_err_,("\n Can't init evt_priv\n"));
-		ret8=_FAIL;
+	if ((rtw_init_evt_priv(&padapter->evtpriv)) == _FAIL) {
+		ret8 = _FAIL;
 		goto exit;
 	}
 
+	if (is_primary_adapter(padapter))
+		rtw_rfctl_init(padapter);
 
-	if (rtw_init_mlme_priv(padapter) == _FAIL)
-	{
-		RT_TRACE(_module_os_intfs_c_,_drv_err_,("\n Can't init mlme_priv\n"));
-		ret8=_FAIL;
+	if (rtw_init_mlme_priv(padapter) == _FAIL) {
+		ret8 = _FAIL;
 		goto exit;
 	}
 
@@ -1691,58 +2264,57 @@ _func_enter_;
 	rtw_init_cfg80211_wifidirect_info(padapter);
 	#endif
 #ifdef CONFIG_WFD
-	if(rtw_init_wifi_display_info(padapter) == _FAIL)
-		RT_TRACE(_module_os_intfs_c_,_drv_err_,("\n Can't init init_wifi_display_info\n"));
+	if (rtw_init_wifi_display_info(padapter) == _FAIL)
+		RTW_ERR("Can't init init_wifi_display_info\n");
 #endif
 #endif /* CONFIG_P2P */
 
-	if(init_mlme_ext_priv(padapter) == _FAIL)
-	{
-		RT_TRACE(_module_os_intfs_c_,_drv_err_,("\n Can't init mlme_ext_priv\n"));
-		ret8=_FAIL;
+	if (init_mlme_ext_priv(padapter) == _FAIL) {
+		ret8 = _FAIL;
 		goto exit;
 	}
 
 #ifdef CONFIG_TDLS
-	if(rtw_init_tdls_info(padapter) == _FAIL)
-	{
-		DBG_871X("Can't rtw_init_tdls_info\n");
-		ret8=_FAIL;
+	if (rtw_init_tdls_info(padapter) == _FAIL) {
+		RTW_INFO("Can't rtw_init_tdls_info\n");
+		ret8 = _FAIL;
 		goto exit;
 	}
-#endif //CONFIG_TDLS
+#endif /* CONFIG_TDLS */
 
-	if(_rtw_init_xmit_priv(&padapter->xmitpriv, padapter) == _FAIL)
-	{
-		DBG_871X("Can't _rtw_init_xmit_priv\n");
-		ret8=_FAIL;
+#ifdef CONFIG_RTW_MESH
+	rtw_mesh_cfg_init(padapter);
+#endif
+
+	if (_rtw_init_xmit_priv(&padapter->xmitpriv, padapter) == _FAIL) {
+		RTW_INFO("Can't _rtw_init_xmit_priv\n");
+		ret8 = _FAIL;
 		goto exit;
 	}
 
-	if(_rtw_init_recv_priv(&padapter->recvpriv, padapter) == _FAIL)
-	{
-		DBG_871X("Can't _rtw_init_recv_priv\n");
-		ret8=_FAIL;
+	if (_rtw_init_recv_priv(&padapter->recvpriv, padapter) == _FAIL) {
+		RTW_INFO("Can't _rtw_init_recv_priv\n");
+		ret8 = _FAIL;
 		goto exit;
 	}
-	// add for CONFIG_IEEE80211W, none 11w also can use
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
 	_rtw_spinlock_init(&padapter->security_key_mutex);
-	
-	// We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc().
-	//_rtw_memset((unsigned char *)&padapter->securitypriv, 0, sizeof (struct security_priv));
 
-	//_init_timer(&(padapter->securitypriv.tkip_timer), padapter->pifp, rtw_use_tkipkey_handler, padapter);
+	/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
+	/* _rtw_memset((unsigned char *)&padapter->securitypriv, 0, sizeof (struct security_priv)); */
 
-	if(_rtw_init_sta_priv(&padapter->stapriv) == _FAIL)
-	{
-		DBG_871X("Can't _rtw_init_sta_priv\n");
-		ret8=_FAIL;
+	if (_rtw_init_sta_priv(&padapter->stapriv) == _FAIL) {
+		RTW_INFO("Can't _rtw_init_sta_priv\n");
+		ret8 = _FAIL;
 		goto exit;
 	}
 
-	padapter->stapriv.padapter = padapter;
 	padapter->setband = WIFI_FREQUENCY_BAND_AUTO;
 	padapter->fix_rate = 0xFF;
+	padapter->power_offset = 0;
+	padapter->rsvd_page_offset = 0;
+	padapter->rsvd_page_num = 0;
+
 	padapter->data_fb = 0;
 	padapter->fix_rx_ampdu_accept = RX_AMPDU_ACCEPT_INVALID;
 	padapter->fix_rx_ampdu_size = RX_AMPDU_SIZE_INVALID;
@@ -1751,49 +2323,60 @@ _func_enter_;
 	padapter->drv_rx_cnt_ok = 0;
 	padapter->drv_rx_cnt_crcerror = 0;
 	padapter->drv_rx_cnt_drop = 0;
-#endif	
+#endif
 	rtw_init_bcmc_stainfo(padapter);
 
 	rtw_init_pwrctrl_priv(padapter);
 
-	//_rtw_memset((u8 *)&padapter->qospriv, 0, sizeof (struct qos_priv));//move to mlme_priv
+	/* _rtw_memset((u8 *)&padapter->qospriv, 0, sizeof (struct qos_priv)); */ /* move to mlme_priv */
 
 #ifdef CONFIG_MP_INCLUDED
-	if (init_mp_priv(padapter) == _FAIL) {
-		DBG_871X("%s: initialize MP private data Fail!\n", __func__);
-	}
+	if (init_mp_priv(padapter) == _FAIL)
+		RTW_INFO("%s: initialize MP private data Fail!\n", __func__);
 #endif
 
 	rtw_hal_dm_init(padapter);
+#ifdef CONFIG_RTW_SW_LED
 	rtw_hal_sw_led_init(padapter);
-
+#endif
 #ifdef DBG_CONFIG_ERROR_DETECT
 	rtw_hal_sreset_init(padapter);
 #endif
 
 #ifdef CONFIG_INTEL_WIDI
-	if(rtw_init_intel_widi(padapter) == _FAIL)
-	{
-		DBG_871X("Can't rtw_init_intel_widi\n");
-		ret8=_FAIL;
+	if (rtw_init_intel_widi(padapter) == _FAIL) {
+		RTW_INFO("Can't rtw_init_intel_widi\n");
+		ret8 = _FAIL;
 		goto exit;
 	}
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
 #ifdef CONFIG_WAPI_SUPPORT
-	padapter->WapiSupport = true; //set true temp, will revise according to Efuse or Registry value later.
+	padapter->WapiSupport = true; /* set true temp, will revise according to Efuse or Registry value later. */
 	rtw_wapi_init(padapter);
 #endif
 
 #ifdef CONFIG_BR_EXT
 	_rtw_spinlock_init(&padapter->br_ext_lock);
-#endif	// CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
+
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+	rtw_bf_init(padapter);
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	init_rtw_rson_data(adapter_to_dvobj(padapter));
+#endif
+
+#ifdef CONFIG_RTW_80211K
+	rtw_init_rm(padapter);
+#endif
 
 exit:
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("-rtw_init_drv_sw\n"));
 
-	_func_exit_;
 
 	return ret8;
 
@@ -1802,55 +2385,55 @@ exit:
 #ifdef CONFIG_WOWLAN
 void rtw_cancel_dynamic_chk_timer(_adapter *padapter)
 {
-	_cancel_timer_ex(&padapter->mlmepriv.dynamic_chk_timer);
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("rtw_cancel_all_timer:cancel dynamic_chk_timer! \n"));
+	_cancel_timer_ex(&adapter_to_dvobj(padapter)->dynamic_chk_timer);
 }
 #endif
 
 void rtw_cancel_all_timer(_adapter *padapter)
 {
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("+rtw_cancel_all_timer\n"));
 
 	_cancel_timer_ex(&padapter->mlmepriv.assoc_timer);
-	RT_TRACE(_module_os_intfs_c_, _drv_info_, ("rtw_cancel_all_timer:cancel association timer complete!\n"));
-
-	#if 0
-	_cancel_timer_ex(&padapter->securitypriv.tkip_timer);
-	RT_TRACE(_module_os_intfs_c_, _drv_info_, ("rtw_cancel_all_timer:cancel tkip_timer!\n"));
-	#endif
 
 	_cancel_timer_ex(&padapter->mlmepriv.scan_to_timer);
-	RT_TRACE(_module_os_intfs_c_, _drv_info_, ("rtw_cancel_all_timer:cancel scan_to_timer!\n"));
 
-	#ifdef CONFIG_DFS_MASTER
+#ifdef CONFIG_DFS_MASTER
 	_cancel_timer_ex(&padapter->mlmepriv.dfs_master_timer);
-	#endif
-
-	_cancel_timer_ex(&padapter->mlmepriv.dynamic_chk_timer);
-	RT_TRACE(_module_os_intfs_c_, _drv_info_, ("rtw_cancel_all_timer:cancel dynamic_chk_timer!\n"));
+#endif
 
-	// cancel sw led timer
+	_cancel_timer_ex(&adapter_to_dvobj(padapter)->dynamic_chk_timer);
+#ifdef CONFIG_RTW_SW_LED
+	/* cancel sw led timer */
 	rtw_hal_sw_led_deinit(padapter);
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("rtw_cancel_all_timer:cancel DeInitSwLeds! \n"));
-
+#endif
 	_cancel_timer_ex(&(adapter_to_pwrctl(padapter)->pwr_state_check_timer));
 
+#ifdef CONFIG_TX_AMSDU
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_bk_timer);
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_be_timer);
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_vo_timer);
+	_cancel_timer_ex(&padapter->xmitpriv.amsdu_vi_timer);
+#endif
+
 #ifdef CONFIG_IOCTL_CFG80211
 #ifdef CONFIG_P2P
 	_cancel_timer_ex(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
-#endif //CONFIG_P2P
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_P2P */
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 #ifdef CONFIG_SET_SCAN_DENY_TIMER
 	_cancel_timer_ex(&padapter->mlmepriv.set_scan_deny_timer);
 	rtw_clear_scan_deny(padapter);
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("rtw_cancel_all_timer:cancel set_scan_deny_timer! \n"));
 #endif
 
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	_cancel_timer_ex(&padapter->recvpriv.signal_stat_timer);
 #endif
-	//cancel dm timer
+
+#ifdef CONFIG_LPS_RPWM_TIMER
+	_cancel_timer_ex(&(adapter_to_pwrctl(padapter)->pwr_rpwm_timer));
+#endif /* CONFIG_LPS_RPWM_TIMER */
+
+	/* cancel dm timer */
 	rtw_hal_dm_deinit(padapter);
 
 #ifdef CONFIG_PLATFORM_FS_MX61
@@ -1860,46 +2443,48 @@ void rtw_cancel_all_timer(_adapter *padapter)
 
 u8 rtw_free_drv_sw(_adapter *padapter)
 {
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("==>rtw_free_drv_sw"));
 
 #ifdef CONFIG_WAPI_SUPPORT
 	rtw_wapi_free(padapter);
 #endif
 
-	//we can call rtw_p2p_enable here, but:
-	// 1. rtw_p2p_enable may have IO operation
-	// 2. rtw_p2p_enable is bundled with wext interface
+	/* we can call rtw_p2p_enable here, but: */
+	/* 1. rtw_p2p_enable may have IO operation */
+	/* 2. rtw_p2p_enable is bundled with wext interface */
 	#ifdef CONFIG_P2P
 	{
 		struct wifidirect_info *pwdinfo = &padapter->wdinfo;
-		if(!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
-		{
-			_cancel_timer_ex( &pwdinfo->find_phase_timer );
-			_cancel_timer_ex( &pwdinfo->restore_p2p_state_timer );
-			_cancel_timer_ex( &pwdinfo->pre_tx_scan_timer);
-#ifdef CONFIG_CONCURRENT_MODE
-			_cancel_timer_ex( &pwdinfo->ap_p2p_switch_timer );
-#endif // CONFIG_CONCURRENT_MODE
+		if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
+			_cancel_timer_ex(&pwdinfo->find_phase_timer);
+			_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
+			_cancel_timer_ex(&pwdinfo->pre_tx_scan_timer);
+			#ifdef CONFIG_CONCURRENT_MODE
+			_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+			#endif /* CONFIG_CONCURRENT_MODE */
 			rtw_p2p_set_state(pwdinfo, P2P_STATE_NONE);
 		}
 	}
 	#endif
-	// add for CONFIG_IEEE80211W, none 11w also can use
+	/* add for CONFIG_IEEE80211W, none 11w also can use */
 	_rtw_spinlock_free(&padapter->security_key_mutex);
-	
+
 #ifdef CONFIG_BR_EXT
 	_rtw_spinlock_free(&padapter->br_ext_lock);
-#endif	// CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
 
 #ifdef CONFIG_INTEL_WIDI
 	rtw_free_intel_widi(padapter);
-#endif //CONFIG_INTEL_WIDI
+#endif /* CONFIG_INTEL_WIDI */
 
 	free_mlme_ext_priv(&padapter->mlmeextpriv);
 
 #ifdef CONFIG_TDLS
-	//rtw_free_tdls_info(&padapter->tdlsinfo);
-#endif //CONFIG_TDLS
+	/* rtw_free_tdls_info(&padapter->tdlsinfo); */
+#endif /* CONFIG_TDLS */
+
+#ifdef CONFIG_RTW_80211K
+	rtw_free_rm_priv(padapter);
+#endif
 
 	rtw_free_cmd_priv(&padapter->cmdpriv);
 
@@ -1907,93 +2492,134 @@ u8 rtw_free_drv_sw(_adapter *padapter)
 
 	rtw_free_mlme_priv(&padapter->mlmepriv);
 
-	//free_io_queue(padapter);
+	if (is_primary_adapter(padapter))
+		rtw_rfctl_deinit(padapter);
+
+	/* free_io_queue(padapter); */
 
 	_rtw_free_xmit_priv(&padapter->xmitpriv);
 
-	_rtw_free_sta_priv(&padapter->stapriv); //will free bcmc_stainfo here
+	_rtw_free_sta_priv(&padapter->stapriv); /* will free bcmc_stainfo here */
 
 	_rtw_free_recv_priv(&padapter->recvpriv);
 
 	rtw_free_pwrctrl_priv(padapter);
 
-	//rtw_mfree((void *)padapter, sizeof (padapter));
-
-#ifdef CONFIG_DRVEXT_MODULE
-	free_drvext(&padapter->drvextpriv);
-#endif
+	/* rtw_mfree((void *)padapter, sizeof (padapter)); */
 
 	rtw_hal_free_data(padapter);
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("<==rtw_free_drv_sw\n"));
 
-	//free the old_pnetdev
-	if(padapter->rereg_nd_name_priv.old_pnetdev) {
+	/* free the old_pnetdev */
+	if (padapter->rereg_nd_name_priv.old_pnetdev) {
 		free_netdev(padapter->rereg_nd_name_priv.old_pnetdev);
 		padapter->rereg_nd_name_priv.old_pnetdev = NULL;
 	}
 
-	// clear pbuddy_adapter to avoid access wrong pointer.
-	if(padapter->pbuddy_adapter != NULL) {
-		padapter->pbuddy_adapter->pbuddy_adapter = NULL;
-	}
-
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("-rtw_free_drv_sw\n"));
-
 	return _SUCCESS;
 
 }
+void rtw_intf_start(_adapter *adapter)
+{
+	if (adapter->intf_start)
+		adapter->intf_start(adapter);
+}
+void rtw_intf_stop(_adapter *adapter)
+{
+	if (adapter->intf_stop)
+		adapter->intf_stop(adapter);
+}
 
 #ifdef CONFIG_CONCURRENT_MODE
-#ifdef CONFIG_MULTI_VIR_IFACES
 int _netdev_vir_if_open(struct net_device *pnetdev)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
 	_adapter *primary_padapter = GET_PRIMARY_ADAPTER(padapter);
 
-	DBG_871X(FUNC_NDEV_FMT" enter\n", FUNC_NDEV_ARG(pnetdev));
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
 
-	if(!primary_padapter)
+	if (!primary_padapter)
 		goto _netdev_virtual_iface_open_error;
 
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+	if (padapter->bup == _FALSE) {
+		u8 mac[ETH_ALEN];
+
+		/* get mac address from primary_padapter */
+		if (primary_padapter->bup == _FALSE)
+			rtw_macaddr_cfg(adapter_mac_addr(primary_padapter), get_hal_mac_addr(primary_padapter));
+
+		_rtw_memcpy(mac, adapter_mac_addr(primary_padapter), ETH_ALEN);
+
+		/*
+		* If the BIT1 is 0, the address is universally administered.
+		* If it is 1, the address is locally administered
+		*/
+		mac[0] |= BIT(1);
+
+		_rtw_memcpy(adapter_mac_addr(padapter), mac, ETH_ALEN);
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
+		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+		_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
+	}
+#endif /*CONFIG_PLATFORM_INTEL_BYT*/
+
 	if (primary_padapter->bup == _FALSE || !rtw_is_hw_init_completed(primary_padapter))
 		_netdev_open(primary_padapter->pnetdev);
 
-	if(padapter->bup == _FALSE && primary_padapter->bup == _TRUE &&
-		rtw_is_hw_init_completed(primary_padapter))
-	{
-		padapter->bFWReady = primary_padapter->bFWReady;
+	if (padapter->bup == _FALSE && primary_padapter->bup == _TRUE &&
+	    rtw_is_hw_init_completed(primary_padapter)) {
+#if 0 /*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, adapter_mac_addr(padapter)); /* set mac addr to mac register */
+#endif
 
-		if(rtw_start_drv_threads(padapter) == _FAIL)
-		{
+	}
+
+	if (padapter->bup == _FALSE) {
+		if (rtw_start_drv_threads(padapter) == _FAIL)
 			goto _netdev_virtual_iface_open_error;
-		}
+	}
 
-#ifdef CONFIG_IOCTL_CFG80211
-		rtw_cfg80211_init_wiphy(padapter);
+#ifdef CONFIG_RTW_NAPI
+	if (padapter->napi_state == NAPI_DISABLE) {
+		napi_enable(&padapter->napi);
+		padapter->napi_state = NAPI_ENABLE;
+	}
 #endif
 
-		padapter->bup = _TRUE;
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_init_wiphy(padapter);
+	rtw_cfg80211_init_wdev_data(padapter);
+#endif
 
-	}
+	padapter->bup = _TRUE;
 
 	padapter->net_closed = _FALSE;
 
-	_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 2000);
-
 	rtw_netif_wake_queue(pnetdev);
 
-	DBG_871X(FUNC_NDEV_FMT" exit\n", FUNC_NDEV_ARG(pnetdev));
+	RTW_INFO(FUNC_NDEV_FMT" (bup=%d) exit\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+
 	return 0;
 
 _netdev_virtual_iface_open_error:
 
 	padapter->bup = _FALSE;
 
-	netif_carrier_off(pnetdev);
+#ifdef CONFIG_RTW_NAPI
+	if(padapter->napi_state == NAPI_ENABLE) {
+		napi_disable(&padapter->napi);
+		padapter->napi_state = NAPI_DISABLE;
+	}
+#endif
+
+	rtw_netif_carrier_off(pnetdev);
 	rtw_netif_stop_queue(pnetdev);
 
-	return (-1);
+	return -1;
 
 }
 
@@ -2007,8 +2633,8 @@ int netdev_vir_if_open(struct net_device *pnetdev)
 	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
 
 #ifdef CONFIG_AUTO_AP_MODE
-	//if(padapter->iface_id == 2)
-	//	rtw_start_auto_ap(padapter);
+	/* if(padapter->iface_id == 2) */
+	/*	rtw_start_auto_ap(padapter); */
 #endif
 
 	return ret;
@@ -2017,13 +2643,19 @@ int netdev_vir_if_open(struct net_device *pnetdev)
 static int netdev_vir_if_close(struct net_device *pnetdev)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
 	padapter->net_closed = _TRUE;
+	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
 
-	if(pnetdev)
-	{
+	if (pnetdev)
 		rtw_netif_stop_queue(pnetdev);
-	}
+
+#ifdef CONFIG_P2P
+	if (!rtw_p2p_chk_role(&padapter->wdinfo, P2P_ROLE_DISABLE))
+		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
+#endif
 
 #ifdef CONFIG_IOCTL_CFG80211
 	rtw_scan_abort(padapter);
@@ -2034,45 +2666,42 @@ static int netdev_vir_if_close(struct net_device *pnetdev)
 	return 0;
 }
 
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 static const struct net_device_ops rtw_netdev_vir_if_ops = {
-	 .ndo_open = netdev_vir_if_open,
-        .ndo_stop = netdev_vir_if_close,
-        .ndo_start_xmit = rtw_xmit_entry,
-        .ndo_set_mac_address = rtw_net_set_mac_address,
-        .ndo_get_stats = rtw_net_get_stats,
-        .ndo_do_ioctl = rtw_ioctl,
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+	.ndo_init = rtw_ndev_init,
+	.ndo_uninit = rtw_ndev_uninit,
+	.ndo_open = netdev_vir_if_open,
+	.ndo_stop = netdev_vir_if_close,
+	.ndo_start_xmit = rtw_xmit_entry,
+	.ndo_set_mac_address = rtw_net_set_mac_address,
+	.ndo_get_stats = rtw_net_get_stats,
+	.ndo_do_ioctl = rtw_ioctl,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	.ndo_select_queue	= rtw_select_queue,
 #endif
 };
 #endif
 
-void rtw_hook_vir_if_ops(struct net_device *ndev)
+static void rtw_hook_vir_if_ops(struct net_device *ndev)
 {
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 	ndev->netdev_ops = &rtw_netdev_vir_if_ops;
 #else
+	ndev->init = rtw_ndev_init;
+	ndev->uninit = rtw_ndev_uninit;
 	ndev->open = netdev_vir_if_open;
 	ndev->stop = netdev_vir_if_close;
 	ndev->set_mac_address = rtw_net_set_mac_address;
 #endif
 }
-
 _adapter *rtw_drv_add_vir_if(_adapter *primary_padapter,
-	void (*set_intf_ops)(_adapter *primary_padapter,struct _io_ops *pops))
+	void (*set_intf_ops)(_adapter *primary_padapter, struct _io_ops *pops))
 {
 	int res = _FAIL;
 	_adapter *padapter = NULL;
 	struct dvobj_priv *pdvobjpriv;
 	u8 mac[ETH_ALEN];
 
-/*
-	if((primary_padapter->bup == _FALSE) ||
-		(rtw_buddy_adapter_up(primary_padapter) == _FALSE))
-		goto exit;
-*/
-
 	/****** init adapter ******/
 	padapter = (_adapter *)rtw_zvmalloc(sizeof(*padapter));
 	if (padapter == NULL)
@@ -2083,60 +2712,64 @@ _adapter *rtw_drv_add_vir_if(_adapter *primary_padapter,
 
 	_rtw_memcpy(padapter, primary_padapter, sizeof(_adapter));
 
-	//
+	/*  */
 	padapter->bup = _FALSE;
 	padapter->net_closed = _TRUE;
 	padapter->dir_dev = NULL;
 	padapter->dir_odm = NULL;
 
-
-	//set adapter_type/iface type
+	/*set adapter_type/iface type*/
 	padapter->isprimary = _FALSE;
-	padapter->adapter_type = MAX_ADAPTER;
-	padapter->pbuddy_adapter = primary_padapter;
-#if 0
-#ifndef CONFIG_HWPORT_SWAP	//Port0 -> Pri , Port1 -> Sec
-	padapter->iface_type = IFACE_PORT1;
-#else
-	padapter->iface_type = IFACE_PORT0;
-#endif  //CONFIG_HWPORT_SWAP
+	padapter->adapter_type = VIRTUAL_ADAPTER;
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	padapter->hw_port = HW_PORT0;
 #else
-	//extended virtual interfaces always are set to port0
-	padapter->iface_type = IFACE_PORT0;
+	padapter->hw_port = HW_PORT1;
 #endif
 
+
 	/****** hook vir if into dvobj ******/
 	pdvobjpriv = adapter_to_dvobj(padapter);
 	padapter->iface_id = pdvobjpriv->iface_nums;
 	pdvobjpriv->padapters[pdvobjpriv->iface_nums++] = padapter;
 
-	padapter->intf_start = NULL;
-	padapter->intf_stop = NULL;
+	padapter->intf_start = primary_padapter->intf_start;
+	padapter->intf_stop = primary_padapter->intf_stop;
 
-	//step init_io_priv
+	/* step init_io_priv */
 	if ((rtw_init_io_priv(padapter, set_intf_ops)) == _FAIL) {
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("\n Can't init io_reqs\n"));
 		goto free_adapter;
 	}
 
-	//init drv data
-	if(rtw_init_drv_sw(padapter)!= _SUCCESS)
+	/*init drv data*/
+	if (rtw_init_drv_sw(padapter) != _SUCCESS)
 		goto free_drv_sw;
 
 
-	//get mac address from primary_padapter
+	/*get mac address from primary_padapter*/
 	_rtw_memcpy(mac, adapter_mac_addr(primary_padapter), ETH_ALEN);
 
 	/*
 	* If the BIT1 is 0, the address is universally administered.
 	* If it is 1, the address is locally administered
 	*/
-#if 1 /* needs enable MBSSID CAM */
 	mac[0] |= BIT(1);
-	mac[0] |= (padapter->iface_id-1)<<4;
-#endif
+	if (padapter->iface_id > IFACE_ID1)
+		mac[4] ^= BIT(padapter->iface_id);
 
 	_rtw_memcpy(adapter_mac_addr(padapter), mac, ETH_ALEN);
+	/* update mac-address to mbsid-cam cache*/
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
+	RTW_INFO("%s if%d mac_addr : "MAC_FMT"\n", __func__, padapter->iface_id + 1, MAC_ARG(adapter_mac_addr(padapter)));
+#ifdef CONFIG_P2P
+	rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
+#endif
+
+	rtw_led_set_ctl_en_mask_virtual(padapter);
+	rtw_led_set_iface_en(padapter, 1);
 
 	res = _SUCCESS;
 
@@ -2154,31 +2787,40 @@ exit:
 
 void rtw_drv_stop_vir_if(_adapter *padapter)
 {
-	struct net_device *pnetdev=NULL;
+	struct net_device *pnetdev = NULL;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
 	if (padapter == NULL)
 		return;
 
 	pnetdev = padapter->pnetdev;
 
-	rtw_cancel_all_timer(padapter);
+	if (check_fwstate(pmlmepriv, _FW_LINKED))
+		rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
 
-	if (padapter->bup == _TRUE)
-	{
+#ifdef CONFIG_AP_MODE
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+		free_mlme_ap_info(padapter);
+		#ifdef CONFIG_HOSTAPD_MLME
+		hostapd_mode_unload(padapter);
+		#endif
+	}
+#endif
+
+	if (padapter->bup == _TRUE) {
 		#ifdef CONFIG_XMIT_ACK
 		if (padapter->xmitpriv.ack_tx)
 			rtw_ack_tx_done(&padapter->xmitpriv, RTW_SCTX_DONE_DRV_STOP);
 		#endif
 
-		if (padapter->intf_stop)
-		{
-			padapter->intf_stop(padapter);
-		}
+		rtw_intf_stop(padapter);
 
 		rtw_stop_drv_threads(padapter);
 
 		padapter->bup = _FALSE;
 	}
+	/* cancel timer after thread stop */
+	rtw_cancel_all_timer(padapter);
 }
 
 void rtw_drv_free_vir_if(_adapter *padapter)
@@ -2186,8 +2828,7 @@ void rtw_drv_free_vir_if(_adapter *padapter)
 	if (padapter == NULL)
 		return;
 
-	padapter->pbuddy_adapter = NULL;
-
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
 	rtw_free_drv_sw(padapter);
 
 	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
@@ -2196,26 +2837,21 @@ void rtw_drv_free_vir_if(_adapter *padapter)
 	rtw_vmfree((u8 *)padapter, sizeof(_adapter));
 }
 
+
 void rtw_drv_stop_vir_ifaces(struct dvobj_priv *dvobj)
 {
 	int i;
-	//struct dvobj_priv *dvobj = primary_padapter->dvobj;
 
-	for(i=2;i<dvobj->iface_nums;i++)
-	{
+	for (i = VIF_START_ID; i < dvobj->iface_nums; i++)
 		rtw_drv_stop_vir_if(dvobj->padapters[i]);
-	}
 }
 
 void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj)
 {
 	int i;
-	//struct dvobj_priv *dvobj = primary_padapter->dvobj;
 
-	for(i=2;i<dvobj->iface_nums;i++)
-	{
+	for (i = VIF_START_ID; i < dvobj->iface_nums; i++)
 		rtw_drv_free_vir_if(dvobj->padapters[i]);
-	}
 }
 
 void rtw_drv_del_vir_if(_adapter *padapter)
@@ -2229,301 +2865,144 @@ void rtw_drv_del_vir_ifaces(_adapter *primary_padapter)
 	int i;
 	struct dvobj_priv *dvobj = primary_padapter->dvobj;
 
-	for(i=2;i<dvobj->iface_nums;i++)
-	{
+	for (i = VIF_START_ID; i < dvobj->iface_nums; i++)
 		rtw_drv_del_vir_if(dvobj->padapters[i]);
-	}
+
 }
-#endif //CONFIG_MULTI_VIR_IFACES
 
-int _netdev_if2_open(struct net_device *pnetdev)
+#endif /*end of CONFIG_CONCURRENT_MODE*/
+
+/* IPv4, IPv6 IP addr notifier */
+static int rtw_inetaddr_notifier_call(struct notifier_block *nb,
+				      unsigned long action, void *data)
 {
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
-	_adapter *primary_padapter = padapter->pbuddy_adapter;
+	struct in_ifaddr *ifa = (struct in_ifaddr *)data;
+	struct net_device *ndev;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	_adapter *adapter = NULL;
 
-	DBG_871X("+871x_drv - if2_open, bup=%d\n", padapter->bup);
+	if (!ifa || !ifa->ifa_dev || !ifa->ifa_dev->dev)
+		return NOTIFY_DONE;
 
-#ifdef CONFIG_PLATFORM_INTEL_BYT
-	if (padapter->bup == _FALSE)
-	{
-		u8 mac[ETH_ALEN];
+	ndev = ifa->ifa_dev->dev;
 
-		/* get mac address from primary_padapter */
-		if (primary_padapter->bup == _FALSE)
-			rtw_macaddr_cfg(adapter_mac_addr(primary_padapter), get_hal_mac_addr(primary_padapter));
+	if (!is_rtw_ndev(ndev))
+		return NOTIFY_DONE;
 
-		_rtw_memcpy(mac, adapter_mac_addr(primary_padapter), ETH_ALEN);
+	adapter = (_adapter *)rtw_netdev_priv(ifa->ifa_dev->dev);
 
-		/*
-		* If the BIT1 is 0, the address is universally administered.
-		* If it is 1, the address is locally administered
-		*/
-		mac[0] |= BIT(1);
+	if (adapter == NULL)
+		return NOTIFY_DONE;
 
-		_rtw_memcpy(adapter_mac_addr(padapter), mac, ETH_ALEN);
-		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
-		_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+
+	switch (action) {
+	case NETDEV_UP:
+		_rtw_memcpy(pmlmeinfo->ip_addr, &ifa->ifa_address,
+					RTW_IP_ADDR_LEN);
+		RTW_DBG("%s[%s]: up IP: %pI4\n", __func__,
+					ifa->ifa_label, pmlmeinfo->ip_addr);
+	break;
+	case NETDEV_DOWN:
+		_rtw_memset(pmlmeinfo->ip_addr, 0, RTW_IP_ADDR_LEN);
+		RTW_DBG("%s[%s]: down IP: %pI4\n", __func__,
+					ifa->ifa_label, pmlmeinfo->ip_addr);
+	break;
+	default:
+		RTW_DBG("%s: default action\n", __func__);
+	break;
 	}
-#endif //CONFIG_PLATFORM_INTEL_BYT
-
-	if (primary_padapter->bup == _FALSE || !rtw_is_hw_init_completed(primary_padapter))
-		_netdev_open(primary_padapter->pnetdev);
+	return NOTIFY_DONE;
+}
 
-	if(padapter->bup == _FALSE && primary_padapter->bup == _TRUE &&
-		rtw_is_hw_init_completed(primary_padapter))
-	{
-		padapter->bFWReady = primary_padapter->bFWReady;
+#ifdef CONFIG_IPV6
+static int rtw_inet6addr_notifier_call(struct notifier_block *nb,
+				       unsigned long action, void *data)
+{
+	struct inet6_ifaddr *inet6_ifa = data;
+	struct net_device *ndev;
+	struct ipv6_addr *_ipv6_addr = NULL;
+	struct pwrctrl_priv *pwrctl = NULL;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	_adapter *adapter = NULL;
 
-		//if (init_mlme_ext_priv(padapter) == _FAIL)
-		//	goto netdev_if2_open_error;
+	if (!inet6_ifa || !inet6_ifa->idev || !inet6_ifa->idev->dev)
+		return NOTIFY_DONE;
 
+	ndev = inet6_ifa->idev->dev;
 
-		if (rtw_start_drv_threads(padapter) == _FAIL)
-		{
-			goto netdev_if2_open_error;
-		}
+	if (!is_rtw_ndev(ndev))
+		return NOTIFY_DONE;
 
+	adapter = (_adapter *)rtw_netdev_priv(inet6_ifa->idev->dev);
 
-		if (padapter->intf_start)
-		{
-			padapter->intf_start(padapter);
-		}
+	if (adapter == NULL)
+		return NOTIFY_DONE;
 
-#ifdef CONFIG_IOCTL_CFG80211
-		rtw_cfg80211_init_wiphy(padapter);
-#endif
+	pmlmeext =  &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
+	pwrctl = adapter_to_pwrctl(adapter);
 
-		padapter->bup = _TRUE;
+	pmlmeext = &adapter->mlmeextpriv;
+	pmlmeinfo = &pmlmeext->mlmext_info;
 
+	switch (action) {
+	case NETDEV_UP:
+#ifdef CONFIG_WOWLAN
+		pwrctl->wowlan_ns_offload_en = _TRUE;
+#endif
+		_rtw_memcpy(pmlmeinfo->ip6_addr, &inet6_ifa->addr,
+					RTW_IPv6_ADDR_LEN);
+		RTW_DBG("%s: up IPv6 addrs: %pI6\n", __func__,
+					pmlmeinfo->ip6_addr);
+			break;
+	case NETDEV_DOWN:
+#ifdef CONFIG_WOWLAN
+		pwrctl->wowlan_ns_offload_en = _FALSE;
+#endif
+		_rtw_memset(pmlmeinfo->ip6_addr, 0, RTW_IPv6_ADDR_LEN);
+		RTW_DBG("%s: down IPv6 addrs: %pI6\n", __func__,
+					pmlmeinfo->ip6_addr);
+		break;
+	default:
+		RTW_DBG("%s: default action\n", __func__);
+		break;
 	}
+	return NOTIFY_DONE;
+}
+#endif
 
-	padapter->net_closed = _FALSE;
+static struct notifier_block rtw_inetaddr_notifier = {
+	.notifier_call = rtw_inetaddr_notifier_call
+};
 
-	//execute dynamic_chk_timer only on primary interface
-	// secondary interface shares the timer with primary interface.
-	//_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 2000);
+#ifdef CONFIG_IPV6
+static struct notifier_block rtw_inet6addr_notifier = {
+	.notifier_call = rtw_inet6addr_notifier_call
+};
+#endif
 
-	rtw_netif_wake_queue(pnetdev);
+void rtw_inetaddr_notifier_register(void)
+{
+	RTW_INFO("%s\n", __func__);
+	register_inetaddr_notifier(&rtw_inetaddr_notifier);
+#ifdef CONFIG_IPV6
+	register_inet6addr_notifier(&rtw_inet6addr_notifier);
+#endif
+}
 
-	DBG_871X("-871x_drv - if2_open, bup=%d\n", padapter->bup);
-	return 0;
-
-netdev_if2_open_error:
-
-	padapter->bup = _FALSE;
-
-	netif_carrier_off(pnetdev);
-	rtw_netif_stop_queue(pnetdev);
-
-	return (-1);
-
-}
-
-int netdev_if2_open(struct net_device *pnetdev)
-{
-	int ret;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
-	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
-
-	if (pwrctrlpriv->bInSuspend == _TRUE)
-	{
-		DBG_871X("+871x_drv - netdev_if2_open, bInSuspend=%d\n", pwrctrlpriv->bInSuspend);
-		return 0;
-	}
-
-	_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
-	ret = _netdev_if2_open(pnetdev);
-	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
-
-#ifdef CONFIG_AUTO_AP_MODE
-	//if(padapter->iface_id == 2)
-		rtw_start_auto_ap(padapter);
-#endif
-
-	return ret;
-}
-
-static int netdev_if2_close(struct net_device *pnetdev)
-{
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-
-	padapter->net_closed = _TRUE;
-	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
-
-	if(pnetdev)
-	{
-		rtw_netif_stop_queue(pnetdev);
-	}
-
-#ifdef CONFIG_P2P
-	if (!rtw_p2p_chk_role(&padapter->wdinfo, P2P_ROLE_DISABLE))
-		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
-#endif
-
-#ifdef CONFIG_IOCTL_CFG80211
-	rtw_scan_abort(padapter);
-	rtw_cfg80211_wait_scan_req_empty(padapter, 200);
-	adapter_wdev_data(padapter)->bandroid_scan = _FALSE;
-#endif
-
-	return 0;
-}
-
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,29))
-static const struct net_device_ops rtw_netdev_if2_ops = {
-	.ndo_init = rtw_ndev_init,
-	.ndo_uninit = rtw_ndev_uninit,
-	.ndo_open = netdev_if2_open,
-	.ndo_stop = netdev_if2_close,
-	.ndo_start_xmit = rtw_xmit_entry,
-	.ndo_set_mac_address = rtw_net_set_mac_address,
-	.ndo_get_stats = rtw_net_get_stats,
-	.ndo_do_ioctl = rtw_ioctl,
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
-	.ndo_select_queue	= rtw_select_queue,
-#endif
-};
-#endif
-
-void rtw_hook_if2_ops(struct net_device *ndev)
+void rtw_inetaddr_notifier_unregister(void)
 {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
-	ndev->netdev_ops = &rtw_netdev_if2_ops;
-#else
-	ndev->init = rtw_ndev_init;
-	ndev->uninit = rtw_ndev_uninit;
-	ndev->open = netdev_if2_open;
-	ndev->stop = netdev_if2_close;
-	ndev->set_mac_address = rtw_net_set_mac_address;
+	RTW_INFO("%s\n", __func__);
+	unregister_inetaddr_notifier(&rtw_inetaddr_notifier);
+#ifdef CONFIG_IPV6
+	unregister_inet6addr_notifier(&rtw_inet6addr_notifier);
 #endif
 }
 
-_adapter *rtw_drv_if2_init(_adapter *primary_padapter, 
-	void (*set_intf_ops)(_adapter *primary_padapter,struct _io_ops *pops))
-{
-	int res = _FAIL;
-	_adapter *padapter = NULL;
-	struct dvobj_priv *pdvobjpriv;
-	u8 mac[ETH_ALEN];
-
-	/****** init adapter ******/
-	padapter = (_adapter *)rtw_zvmalloc(sizeof(*padapter));
-	if (padapter == NULL)
-		goto exit;
-
-	if (loadparam(padapter) != _SUCCESS)
-		goto free_adapter;
-
-	_rtw_memcpy(padapter, primary_padapter, sizeof(*padapter));
-
-	//
-	padapter->bup = _FALSE;
-	padapter->net_closed = _TRUE;
-	padapter->dir_dev = NULL;
-	padapter->dir_odm = NULL;
-
-	//set adapter_type/iface type
-	padapter->isprimary = _FALSE;
-	padapter->adapter_type = SECONDARY_ADAPTER;
-	padapter->pbuddy_adapter = primary_padapter;
-	padapter->iface_id = IFACE_ID1;
-#ifndef CONFIG_HWPORT_SWAP			//Port0 -> Pri , Port1 -> Sec
-	padapter->iface_type = IFACE_PORT1;
-#else
-	padapter->iface_type = IFACE_PORT0;
-#endif  //CONFIG_HWPORT_SWAP
-
-	/****** hook if2 into dvobj ******/
-	pdvobjpriv = adapter_to_dvobj(padapter);
-	pdvobjpriv->padapters[pdvobjpriv->iface_nums++] = padapter;
-
-	//
-	padapter->intf_start = primary_padapter->intf_start;
-	padapter->intf_stop = primary_padapter->intf_stop;
-
-	//step init_io_priv
-	if ((rtw_init_io_priv(padapter, set_intf_ops)) == _FAIL) {
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("\n Can't init io_reqs\n"));
-		goto free_adapter;
-	}
-
-	//init drv data
-	if(rtw_init_drv_sw(padapter)!= _SUCCESS)
-		goto free_drv_sw;
-
-
-	/* get mac address from primary_padapter */
-	_rtw_memcpy(mac, adapter_mac_addr(primary_padapter), ETH_ALEN);
-
-	/*
-	* If the BIT1 is 0, the address is universally administered.
-	* If it is 1, the address is locally administered
-	*/
-	mac[0] |= BIT(1);
-
-	_rtw_memcpy(adapter_mac_addr(padapter), mac, ETH_ALEN);
-	rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
-
-	primary_padapter->pbuddy_adapter = padapter;
-
-	res = _SUCCESS;
-
-free_drv_sw:
-	if (res != _SUCCESS && padapter)
-		rtw_free_drv_sw(padapter);
-free_adapter:
-	if (res != _SUCCESS && padapter) {
-		rtw_vmfree((u8 *)padapter, sizeof(*padapter));
-		padapter = NULL;
-	}
-exit:
-	return padapter;
-}
-
-void rtw_drv_if2_free(_adapter *if2)
-{
-	_adapter *padapter = if2;
-
-	if (padapter == NULL)
-		return;
-
-	rtw_free_drv_sw(padapter);
-
-	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
-	rtw_os_ndev_free(padapter);
-
-	rtw_vmfree((u8 *)padapter, sizeof(_adapter));
-}
-
-void rtw_drv_if2_stop(_adapter *if2)
-{
-	_adapter *padapter = if2;
-	struct net_device *pnetdev = NULL;
-
-	if (padapter == NULL)
-		return;
-
-	rtw_cancel_all_timer(padapter);
-
-	if (padapter->bup == _TRUE) {
-		#ifdef CONFIG_XMIT_ACK
-		if (padapter->xmitpriv.ack_tx)
-			rtw_ack_tx_done(&padapter->xmitpriv, RTW_SCTX_DONE_DRV_STOP);
-		#endif
-
-		if (padapter->intf_stop)
-		{
-			padapter->intf_stop(padapter);
-		}
-
-		rtw_stop_drv_threads(padapter);
-
-		padapter->bup = _FALSE;
-	}
-}
-#endif //end of CONFIG_CONCURRENT_MODE
-
 int rtw_os_ndevs_register(struct dvobj_priv *dvobj)
 {
 	int i, status = _SUCCESS;
@@ -2540,8 +3019,8 @@ int rtw_os_ndevs_register(struct dvobj_priv *dvobj)
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 
-		if (i >= IFACE_ID_MAX) {
-			DBG_871X_LEVEL(_drv_err_, "%s %d >= IFACE_ID_MAX\n", __func__, i);
+		if (i >= CONFIG_IFACE_NUMBER) {
+			RTW_ERR("%s %d >= CONFIG_IFACE_NUMBER(%d)\n", __func__, i, CONFIG_IFACE_NUMBER);
 			rtw_warn_on(1);
 			continue;
 		}
@@ -2550,6 +3029,11 @@ int rtw_os_ndevs_register(struct dvobj_priv *dvobj)
 		if (adapter) {
 			char *name;
 
+			#ifdef CONFIG_RTW_DYNAMIC_NDEV
+			if (!is_primary_adapter(adapter))
+				continue;
+			#endif
+
 			if (adapter->iface_id == IFACE_ID0)
 				name = regsty->ifname;
 			else if (adapter->iface_id == IFACE_ID1)
@@ -2557,19 +3041,6 @@ int rtw_os_ndevs_register(struct dvobj_priv *dvobj)
 			else
 				name = "wlan%d";
 
-			#ifdef CONFIG_CONCURRENT_MODE
-			switch (adapter->adapter_type) {
-			case SECONDARY_ADAPTER:
-				rtw_hook_if2_ops(adapter->pnetdev);
-				break;
-			#ifdef CONFIG_MULTI_VIR_IFACES
-			case MAX_ADAPTER:
-				rtw_hook_vir_if_ops(adapter->pnetdev);
-				break;
-			#endif
-			}
-			#endif /* CONFIG_CONCURRENT_MODE */
-
 			status = rtw_os_ndev_register(adapter, name);
 
 			if (status != _SUCCESS) {
@@ -2657,31 +3128,31 @@ void netdev_br_init(struct net_device *netdev)
 
 #if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
 	rcu_read_lock();
-#endif	// (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
+#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
 
-	//if(check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE)
+	/* if(check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE) */
 	{
-		//struct net_bridge	*br = netdev->br_port->br;//->dev->dev_addr;
+		/* struct net_bridge	*br = netdev->br_port->br; */ /* ->dev->dev_addr; */
 #if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
 		if (netdev->br_port)
-#else   // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+#else   /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
 		if (rcu_dereference(adapter->pnetdev->rx_handler_data))
-#endif  // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
 		{
 			struct net_device *br_netdev;
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,24))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
 			br_netdev = dev_get_by_name(CONFIG_BR_EXT_BRNAME);
-#else	// (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,24))
+#else	/* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24)) */
 			struct net *devnet = NULL;
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,26))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26))
 			devnet = netdev->nd_net;
-#else	// (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,26))
+#else	/* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26)) */
 			devnet = dev_net(netdev);
-#endif	// (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,26))
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26)) */
 
 			br_netdev = dev_get_by_name(devnet, CONFIG_BR_EXT_BRNAME);
-#endif	// (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,24))
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24)) */
 
 			if (br_netdev) {
 				memcpy(adapter->br_mac, br_netdev->dev_addr, ETH_ALEN);
@@ -2695,9 +3166,9 @@ void netdev_br_init(struct net_device *netdev)
 
 #if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
 	rcu_read_unlock();
-#endif	// (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
+#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
 }
-#endif //CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
 
 int _netdev_open(struct net_device *pnetdev)
 {
@@ -2706,60 +3177,69 @@ int _netdev_open(struct net_device *pnetdev)
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("+871x_drv - dev_open\n"));
-	DBG_871X("+871x_drv - drv_open, bup=%d\n", padapter->bup);
+
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
 
 	padapter->netif_up = _TRUE;
 
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 	rtw_sdio_set_power(1);
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 
-	if(pwrctrlpriv->ps_flag == _TRUE){
+	#ifdef CONFIG_AUTOSUSPEND
+	if (pwrctrlpriv->ps_flag == _TRUE) {
 		padapter->net_closed = _FALSE;
 		goto netdev_open_normal_process;
 	}
+	#endif
 
-	if(padapter->bup == _FALSE)
-	{
+	if (padapter->bup == _FALSE) {
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 		rtw_macaddr_cfg(adapter_mac_addr(padapter),  get_hal_mac_addr(padapter));
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
 		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
 		_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 
 		rtw_clr_surprise_removed(padapter);
 		rtw_clr_drv_stopped(padapter);
 
 		status = rtw_hal_init(padapter);
-		if (status ==_FAIL)
-		{
-			RT_TRACE(_module_os_intfs_c_,_drv_err_,("rtl871x_hal_init(): Can't init h/w!\n"));
+		if (status == _FAIL) {
 			goto netdev_open_error;
 		}
+#if 0/*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
+		rtw_hal_set_hwreg(padapter, HW_VAR_MAC_ADDR, adapter_mac_addr(padapter)); /* set mac addr to mac register */
+#endif
 
-		DBG_871X("MAC Address = "MAC_FMT"\n", MAC_ARG(pnetdev->dev_addr));
+		RTW_INFO("MAC Address = "MAC_FMT"\n", MAC_ARG(pnetdev->dev_addr));
 
-		status=rtw_start_drv_threads(padapter);
-		if(status ==_FAIL)
-		{
-			DBG_871X("Initialize driver software resource Failed!\n");
+#ifndef RTW_HALMAC
+		status = rtw_start_drv_threads(padapter);
+		if (status == _FAIL) {
+			RTW_INFO("Initialize driver software resource Failed!\n");
 			goto netdev_open_error;
 		}
+#endif /* !RTW_HALMAC */
 
-#ifdef CONFIG_DRVEXT_MODULE
-		init_drvext(padapter);
+#ifdef CONFIG_RTW_NAPI
+		if(padapter->napi_state == NAPI_DISABLE) {
+			napi_enable(&padapter->napi);
+			padapter->napi_state = NAPI_ENABLE;
+		}
 #endif
 
-		if (padapter->intf_start)
-		{
-			padapter->intf_start(padapter);
-		}
+#ifndef RTW_HALMAC
+		rtw_intf_start(padapter);
+#endif /* !RTW_HALMAC */
 
 #ifdef CONFIG_IOCTL_CFG80211
 		rtw_cfg80211_init_wiphy(padapter);
+		rtw_cfg80211_init_wdev_data(padapter);
 #endif
 
 		rtw_led_control(padapter, LED_CTL_NO_LINK);
@@ -2768,50 +3248,59 @@ int _netdev_open(struct net_device *pnetdev)
 		pwrctrlpriv->bips_processing = _FALSE;
 
 #ifdef CONFIG_PLATFORM_INTEL_BYT
-#ifdef CONFIG_BT_COEXIST	
+#ifdef CONFIG_BT_COEXIST
 		rtw_btcoex_IpsNotify(padapter, IPS_NONE);
-#endif // CONFIG_BT_COEXIST
-#endif //CONFIG_PLATFORM_INTEL_BYT		
+#endif /* CONFIG_BT_COEXIST */
+#endif /* CONFIG_PLATFORM_INTEL_BYT		 */
 	}
 	padapter->net_closed = _FALSE;
 
-	_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 2000);
+	_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
 
 #ifndef CONFIG_IPS_CHECK_IN_WD
 	rtw_set_pwr_state_check_timer(pwrctrlpriv);
-#endif 
+#endif
 
-	//netif_carrier_on(pnetdev);//call this func when rtw_joinbss_event_callback return success
+	/* rtw_netif_carrier_on(pnetdev); */ /* call this func when rtw_joinbss_event_callback return success */
 	rtw_netif_wake_queue(pnetdev);
 
 #ifdef CONFIG_BR_EXT
 	netdev_br_init(pnetdev);
-#endif	// CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
 
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-	if(is_primary_adapter(padapter) &&  _TRUE == pHalData->EEPROMBluetoothCoexist)
-	{
+	if (is_primary_adapter(padapter) && (_TRUE == pHalData->EEPROMBluetoothCoexist)) {
 		rtw_btcoex_init_socket(padapter);
 		padapter->coex_info.BtMgnt.ExtConfig.HCIExtensionVer = 0x04;
-		rtw_btcoex_SetHciVersion(padapter,0x04);
-	}
-	else
-		DBG_871X("CONFIG_BT_COEXIST: SECONDARY_ADAPTER\n");
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
+		rtw_btcoex_SetHciVersion(padapter, 0x04);
+	} else
+		RTW_INFO("CONFIG_BT_COEXIST: VIRTUAL_ADAPTER\n");
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 
 
 netdev_open_normal_process:
 
-	#ifdef CONFIG_CONCURRENT_MODE
+#ifdef CONFIG_CONCURRENT_MODE
 	{
-		_adapter *sec_adapter = padapter->pbuddy_adapter;
-		if(sec_adapter && (sec_adapter->bup == _FALSE))
-			_netdev_if2_open(sec_adapter->pnetdev);
+		_adapter *sec_adapter = adapter_to_dvobj(padapter)->padapters[IFACE_ID1];
+
+		#ifndef CONFIG_RTW_DYNAMIC_NDEV
+		if (sec_adapter && (sec_adapter->bup == _FALSE))
+			_netdev_vir_if_open(sec_adapter->pnetdev);
+		#endif
 	}
-	#endif
+#endif
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	pwrctrlpriv->radio_on_start_time = rtw_get_current_time();
+	pwrctrlpriv->pwr_saving_start_time = rtw_get_current_time();
+	pwrctrlpriv->pwr_saving_time = 0;
+	pwrctrlpriv->on_time = 0;
+	pwrctrlpriv->tx_time = 0;
+	pwrctrlpriv->rx_time = 0;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("-871x_drv - dev_open\n"));
-	DBG_871X("-871x_drv - drv_open, bup=%d\n", padapter->bup);
+	RTW_INFO("-871x_drv - drv_open, bup=%d\n", padapter->bup);
 
 	return 0;
 
@@ -2819,32 +3308,48 @@ netdev_open_error:
 
 	padapter->bup = _FALSE;
 
-	netif_carrier_off(pnetdev);
+#ifdef CONFIG_RTW_NAPI
+	if(padapter->napi_state == NAPI_ENABLE) {
+		napi_disable(&padapter->napi);
+		padapter->napi_state = NAPI_DISABLE;
+	}
+#endif
+
+	rtw_netif_carrier_off(pnetdev);
 	rtw_netif_stop_queue(pnetdev);
 
-	RT_TRACE(_module_os_intfs_c_,_drv_err_,("-871x_drv - dev_open, fail!\n"));
-	DBG_871X("-871x_drv - drv_open fail, bup=%d\n", padapter->bup);
+	RTW_INFO("-871x_drv - drv_open fail, bup=%d\n", padapter->bup);
 
-	return (-1);
+	return -1;
 
 }
 
 int netdev_open(struct net_device *pnetdev)
 {
-	int ret;
+	int ret = _FALSE;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 
-	if (pwrctrlpriv->bInSuspend == _TRUE)
-	{
-		DBG_871X("+871x_drv - drv_open, bInSuspend=%d\n", pwrctrlpriv->bInSuspend);
+	if (pwrctrlpriv->bInSuspend == _TRUE) {
+		RTW_INFO(" [WARN] "ADPT_FMT" %s  failed, bInSuspend=%d\n", ADPT_ARG(padapter), __func__, pwrctrlpriv->bInSuspend);
 		return 0;
 	}
 
 	_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
-	ret = _netdev_open(pnetdev);
+	if (is_primary_adapter(padapter))
+		ret = _netdev_open(pnetdev);
+#ifdef CONFIG_CONCURRENT_MODE
+	else
+		ret = _netdev_vir_if_open(pnetdev);
+#endif
 	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
 
+
+#ifdef CONFIG_AUTO_AP_MODE
+	if (padapter->iface_id == IFACE_ID2)
+		rtw_start_auto_ap(padapter);
+#endif
+
 	return ret;
 }
 
@@ -2852,103 +3357,97 @@ int netdev_open(struct net_device *pnetdev)
 int  ips_netdrv_open(_adapter *padapter)
 {
 	int status = _SUCCESS;
-	//struct pwrctrl_priv	*pwrpriv = adapter_to_pwrctl(padapter);
-	
+	/* struct pwrctrl_priv	*pwrpriv = adapter_to_pwrctl(padapter); */
+
 	padapter->net_closed = _FALSE;
 
-	DBG_871X("===> %s.........\n",__FUNCTION__);
+	RTW_INFO("===> %s.........\n", __FUNCTION__);
 
 
 	rtw_clr_drv_stopped(padapter);
-	//padapter->bup = _TRUE;
+	/* padapter->bup = _TRUE; */
 
 	status = rtw_hal_init(padapter);
-	if (status ==_FAIL)
-	{
-		RT_TRACE(_module_os_intfs_c_,_drv_err_,("ips_netdrv_open(): Can't init h/w!\n"));
+	if (status == _FAIL) {
 		goto netdev_open_error;
 	}
-
-	if (padapter->intf_start)
-	{
-		padapter->intf_start(padapter);
-	}
+#if 0
+	rtw_restore_mac_addr(padapter);
+#endif
+#ifndef RTW_HALMAC
+	rtw_intf_start(padapter);
+#endif /* !RTW_HALMAC */
 
 #ifndef CONFIG_IPS_CHECK_IN_WD
 	rtw_set_pwr_state_check_timer(adapter_to_pwrctl(padapter));
-#endif		
-  	_set_timer(&padapter->mlmepriv.dynamic_chk_timer,2000);
+#endif
+	_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
 
-	 return _SUCCESS;
+	return _SUCCESS;
 
 netdev_open_error:
-	//padapter->bup = _FALSE;
-	DBG_871X("-ips_netdrv_open - drv_open failure, bup=%d\n", padapter->bup);
+	/* padapter->bup = _FALSE; */
+	RTW_INFO("-ips_netdrv_open - drv_open failure, bup=%d\n", padapter->bup);
 
 	return _FAIL;
 }
 
-
 int rtw_ips_pwr_up(_adapter *padapter)
 {
 	int result;
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 #ifdef DBG_CONFIG_ERROR_DETECT
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-#endif//#ifdef DBG_CONFIG_ERROR_DETECT
-	u32 start_time = rtw_get_current_time();
-	DBG_871X("===>  rtw_ips_pwr_up..............\n");
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+	systime start_time = rtw_get_current_time();
+	RTW_INFO("===>  rtw_ips_pwr_up..............\n");
 
 #if defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
 #ifdef DBG_CONFIG_ERROR_DETECT
 	if (psrtpriv->silent_reset_inprogress == _TRUE)
-#endif//#ifdef DBG_CONFIG_ERROR_DETECT		
-#endif //defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+#endif /* defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS) */
 		rtw_reset_drv_sw(padapter);
 
 	result = ips_netdrv_open(padapter);
 
 	rtw_led_control(padapter, LED_CTL_NO_LINK);
 
- 	DBG_871X("<===  rtw_ips_pwr_up.............. in %dms\n", rtw_get_passing_time_ms(start_time));
+	RTW_INFO("<===  rtw_ips_pwr_up.............. in %dms\n", rtw_get_passing_time_ms(start_time));
 	return result;
 
 }
 
 void rtw_ips_pwr_down(_adapter *padapter)
 {
-	u32 start_time = rtw_get_current_time();
-	DBG_871X("===> rtw_ips_pwr_down...................\n");
+	systime start_time = rtw_get_current_time();
+	RTW_INFO("===> rtw_ips_pwr_down...................\n");
 
 	padapter->net_closed = _TRUE;
 
 	rtw_ips_dev_unload(padapter);
-	DBG_871X("<=== rtw_ips_pwr_down..................... in %dms\n", rtw_get_passing_time_ms(start_time));
+	RTW_INFO("<=== rtw_ips_pwr_down..................... in %dms\n", rtw_get_passing_time_ms(start_time));
 }
 #endif
 void rtw_ips_dev_unload(_adapter *padapter)
 {
-	struct net_device *pnetdev= (struct net_device*)padapter->pnetdev;
+	struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
 	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
-#ifdef DBG_CONFIG_ERROR_DETECT	
+#ifdef DBG_CONFIG_ERROR_DETECT
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-#endif//#ifdef DBG_CONFIG_ERROR_DETECT
-	DBG_871X("====> %s...\n",__FUNCTION__);
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+	RTW_INFO("====> %s...\n", __FUNCTION__);
 
 
 #if defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
 #ifdef DBG_CONFIG_ERROR_DETECT
 	if (psrtpriv->silent_reset_inprogress == _TRUE)
-#endif //#ifdef DBG_CONFIG_ERROR_DETECT		
-#endif //defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
+#endif /* #ifdef DBG_CONFIG_ERROR_DETECT */
+#endif /* defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS) */
 	{
 		rtw_hal_set_hwreg(padapter, HW_VAR_FIFO_CLEARN_UP, 0);
-
-		if (padapter->intf_stop)
-		{
-			padapter->intf_stop(padapter);
-		}
+		rtw_intf_stop(padapter);
 	}
 
 	if (!rtw_is_surprise_removed(padapter))
@@ -2956,22 +3455,23 @@ void rtw_ips_dev_unload(_adapter *padapter)
 
 }
 
-
-int pm_netdev_open(struct net_device *pnetdev,u8 bnormal)
+int pm_netdev_open(struct net_device *pnetdev, u8 bnormal)
 {
 	int status = 0;
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
 
-	if (_TRUE == bnormal)
-	{
+	if (_TRUE == bnormal) {
 		_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
 		status = _netdev_open(pnetdev);
+#if 0
+		rtw_restore_mac_addr(padapter);
+#endif
 		_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
-	}	
+	}
 #ifdef CONFIG_IPS
 	else
-		status =  (_SUCCESS == ips_netdrv_open(padapter))?(0):(-1);
+		status = (_SUCCESS == ips_netdrv_open(padapter)) ? (0) : (-1);
 #endif
 
 	return status;
@@ -2984,112 +3484,106 @@ static int netdev_close(struct net_device *pnetdev)
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("+871x_drv - drv_close\n"));
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
 
+	RTW_INFO(FUNC_NDEV_FMT" , bup=%d\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
 #ifndef CONFIG_PLATFORM_INTEL_BYT
-	if(pwrctl->bInternalAutoSuspend == _TRUE)
-	{
-		//rtw_pwr_wakeup(padapter);
-		if(pwrctl->rf_pwrstate == rf_off)
+	#ifdef CONFIG_AUTOSUSPEND
+	if (pwrctl->bInternalAutoSuspend == _TRUE) {
+		/* rtw_pwr_wakeup(padapter); */
+		if (pwrctl->rf_pwrstate == rf_off)
 			pwrctl->ps_flag = _TRUE;
 	}
+	#endif
 	padapter->net_closed = _TRUE;
 	padapter->netif_up = _FALSE;
 	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
 
-/*	if (!rtw_is_hw_init_completed(padapter)) {
-		DBG_871X("(1)871x_drv - drv_close, bup=%d, hw_init_completed=%s\n", padapter->bup, rtw_is_hw_init_completed(padapter)?"_TRUE":"_FALSE");
+	/*	if (!rtw_is_hw_init_completed(padapter)) {
+			RTW_INFO("(1)871x_drv - drv_close, bup=%d, hw_init_completed=%s\n", padapter->bup, rtw_is_hw_init_completed(padapter)?"_TRUE":"_FALSE");
 
-		rtw_set_drv_stopped(padapter);
+			rtw_set_drv_stopped(padapter);
 
-		rtw_dev_unload(padapter);
-	}
-	else*/
-	if(pwrctl->rf_pwrstate == rf_on){
-		DBG_871X("(2)871x_drv - drv_close, bup=%d, hw_init_completed=%s\n", padapter->bup, rtw_is_hw_init_completed(padapter)?"_TRUE":"_FALSE");
+			rtw_dev_unload(padapter);
+		}
+		else*/
+	if (pwrctl->rf_pwrstate == rf_on) {
+		RTW_INFO("(2)871x_drv - drv_close, bup=%d, hw_init_completed=%s\n", padapter->bup, rtw_is_hw_init_completed(padapter) ? "_TRUE" : "_FALSE");
 
-		//s1.
-		if(pnetdev)
-		{
+		/* s1. */
+		if (pnetdev)
 			rtw_netif_stop_queue(pnetdev);
-		}
 
 #ifndef CONFIG_ANDROID
-		//s2.
+		/* s2. */
 		LeaveAllPowerSaveMode(padapter);
-		rtw_disassoc_cmd(padapter, 500, _FALSE);
-		//s2-2.  indicate disconnect to os
+		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
+		/* s2-2.  indicate disconnect to os */
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
-		//s2-3.
-		rtw_free_assoc_resources(padapter, 1);
-		//s2-4.
-		rtw_free_network_queue(padapter,_TRUE);
+		/* s2-3. */
+		rtw_free_assoc_resources_cmd(padapter, _TRUE);
+		/* s2-4. */
+		rtw_free_network_queue(padapter, _TRUE);
 #endif
-		// Close LED
-		rtw_led_control(padapter, LED_CTL_POWER_OFF);
 	}
 
 #ifdef CONFIG_BR_EXT
-	//if (OPMODE & (WIFI_STATION_STATE | WIFI_ADHOC_STATE))
+	/* if (OPMODE & (WIFI_STATION_STATE | WIFI_ADHOC_STATE)) */
 	{
-		//void nat25_db_cleanup(_adapter *priv);
+		/* void nat25_db_cleanup(_adapter *priv); */
 		nat25_db_cleanup(padapter);
 	}
-#endif	// CONFIG_BR_EXT
+#endif /* CONFIG_BR_EXT */
 
 #ifdef CONFIG_P2P
 	if (!rtw_p2p_chk_role(&padapter->wdinfo, P2P_ROLE_DISABLE))
 		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
-#endif //CONFIG_P2P
+#endif /* CONFIG_P2P */
 
 #ifdef CONFIG_IOCTL_CFG80211
 	rtw_scan_abort(padapter);
 	rtw_cfg80211_wait_scan_req_empty(padapter, 200);
 	adapter_wdev_data(padapter)->bandroid_scan = _FALSE;
-	//padapter->rtw_wdev->iftype = NL80211_IFTYPE_MONITOR; //set this at the end
-#endif //CONFIG_IOCTL_CFG80211
+	/* padapter->rtw_wdev->iftype = NL80211_IFTYPE_MONITOR; */ /* set this at the end */
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 #ifdef CONFIG_WAPI_SUPPORT
 	rtw_wapi_disable_tx(padapter);
 #endif
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
-	if(is_primary_adapter(padapter) &&  _TRUE == pHalData->EEPROMBluetoothCoexist)
+	if (is_primary_adapter(padapter) && (_TRUE == pHalData->EEPROMBluetoothCoexist))
 		rtw_btcoex_close_socket(padapter);
 	else
-		DBG_871X("CONFIG_BT_COEXIST: SECONDARY_ADAPTER\n");
-#endif //CONFIG_BT_COEXIST_SOCKET_TRX
-#else //!CONFIG_PLATFORM_INTEL_BYT
+		RTW_INFO("CONFIG_BT_COEXIST: VIRTUAL_ADAPTER\n");
+#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+#else /* !CONFIG_PLATFORM_INTEL_BYT */
 
-	if (pwrctl->bInSuspend == _TRUE)
-	{
-		DBG_871X("+871x_drv - drv_close, bInSuspend=%d\n", pwrctl->bInSuspend);
+	if (pwrctl->bInSuspend == _TRUE) {
+		RTW_INFO("+871x_drv - drv_close, bInSuspend=%d\n", pwrctl->bInSuspend);
 		return 0;
 	}
 
-	rtw_scan_abort(padapter); // stop scanning process before wifi is going to down
-	#ifdef CONFIG_IOCTL_CFG80211
+	rtw_scan_abort(padapter); /* stop scanning process before wifi is going to down */
+#ifdef CONFIG_IOCTL_CFG80211
 	rtw_cfg80211_wait_scan_req_empty(padapter, 200);
-	#endif
+#endif
 
-	DBG_871X("netdev_close, bips_processing=%d\n", pwrctl->bips_processing);
-	while (pwrctl->bips_processing == _TRUE) // waiting for ips_processing done before call rtw_dev_unload()
-		rtw_msleep_os(1);	
+	RTW_INFO("netdev_close, bips_processing=%d\n", pwrctl->bips_processing);
+	while (pwrctl->bips_processing == _TRUE) /* waiting for ips_processing done before call rtw_dev_unload() */
+		rtw_msleep_os(1);
 
 	rtw_dev_unload(padapter);
 	rtw_sdio_set_power(0);
 
-#endif //!CONFIG_PLATFORM_INTEL_BYT
+#endif /* !CONFIG_PLATFORM_INTEL_BYT */
 
-	RT_TRACE(_module_os_intfs_c_,_drv_info_,("-871x_drv - drv_close\n"));
-	DBG_871X("-871x_drv - drv_close, bup=%d\n", padapter->bup);
+	RTW_INFO("-871x_drv - drv_close, bup=%d\n", padapter->bup);
 
 	return 0;
 
 }
 
-int pm_netdev_close(struct net_device *pnetdev,u8 bnormal)
+int pm_netdev_close(struct net_device *pnetdev, u8 bnormal)
 {
 	int status = 0;
 
@@ -3100,7 +3594,7 @@ int pm_netdev_close(struct net_device *pnetdev,u8 bnormal)
 
 void rtw_ndev_destructor(struct net_device *ndev)
 {
-	DBG_871X(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
 
 #ifdef CONFIG_IOCTL_CFG80211
 	if (ndev->ieee80211_ptr)
@@ -3111,45 +3605,44 @@ void rtw_ndev_destructor(struct net_device *ndev)
 
 #ifdef CONFIG_ARP_KEEP_ALIVE
 struct route_info {
-    struct in_addr dst_addr;
-    struct in_addr src_addr;
-    struct in_addr gateway;
-    unsigned int dev_index;
+	struct in_addr dst_addr;
+	struct in_addr src_addr;
+	struct in_addr gateway;
+	unsigned int dev_index;
 };
 
 static void parse_routes(struct nlmsghdr *nl_hdr, struct route_info *rt_info)
 {
-    struct rtmsg *rt_msg;
-    struct rtattr *rt_attr;
-    int rt_len;
+	struct rtmsg *rt_msg;
+	struct rtattr *rt_attr;
+	int rt_len;
 
-    rt_msg = (struct rtmsg *) NLMSG_DATA(nl_hdr);
-    if ((rt_msg->rtm_family != AF_INET) || (rt_msg->rtm_table != RT_TABLE_MAIN))
-        return;
+	rt_msg = (struct rtmsg *) NLMSG_DATA(nl_hdr);
+	if ((rt_msg->rtm_family != AF_INET) || (rt_msg->rtm_table != RT_TABLE_MAIN))
+		return;
 
-    rt_attr = (struct rtattr *) RTM_RTA(rt_msg);
-    rt_len = RTM_PAYLOAD(nl_hdr);
+	rt_attr = (struct rtattr *) RTM_RTA(rt_msg);
+	rt_len = RTM_PAYLOAD(nl_hdr);
 
-    for (; RTA_OK(rt_attr, rt_len); rt_attr = RTA_NEXT(rt_attr, rt_len)) 
-	{
-        switch (rt_attr->rta_type) {
-        case RTA_OIF:
-		rt_info->dev_index = *(int *) RTA_DATA(rt_attr);
-            break;
-        case RTA_GATEWAY:
-            rt_info->gateway.s_addr = *(u_int *) RTA_DATA(rt_attr);
-            break;
-        case RTA_PREFSRC:
-            rt_info->src_addr.s_addr = *(u_int *) RTA_DATA(rt_attr);
-            break;
-        case RTA_DST:
-            rt_info->dst_addr.s_addr = *(u_int *) RTA_DATA(rt_attr);
-            break;
-        }
-    }
+	for (; RTA_OK(rt_attr, rt_len); rt_attr = RTA_NEXT(rt_attr, rt_len)) {
+		switch (rt_attr->rta_type) {
+		case RTA_OIF:
+			rt_info->dev_index = *(int *) RTA_DATA(rt_attr);
+			break;
+		case RTA_GATEWAY:
+			rt_info->gateway.s_addr = *(u_int *) RTA_DATA(rt_attr);
+			break;
+		case RTA_PREFSRC:
+			rt_info->src_addr.s_addr = *(u_int *) RTA_DATA(rt_attr);
+			break;
+		case RTA_DST:
+			rt_info->dst_addr.s_addr = *(u_int *) RTA_DATA(rt_attr);
+			break;
+		}
+	}
 }
 
-static int route_dump(u32 *gw_addr ,int* gw_index)
+static int route_dump(u32 *gw_addr , int *gw_index)
 {
 	int err = 0;
 	struct socket *sock;
@@ -3165,12 +3658,11 @@ static int route_dump(u32 *gw_addr ,int* gw_index)
 	int size = 0;
 
 	err = sock_create(AF_NETLINK, SOCK_DGRAM, NETLINK_ROUTE, &sock);
-	if (err)
-	{
-		printk( ": Could not create a datagram socket, error = %d\n", -ENXIO);
+	if (err) {
+		printk(": Could not create a datagram socket, error = %d\n", -ENXIO);
 		return err;
 	}
-	
+
 	memset(&nladdr, 0, sizeof(nladdr));
 	nladdr.nl_family = AF_NETLINK;
 
@@ -3200,7 +3692,8 @@ static int route_dump(u32 *gw_addr ,int* gw_index)
 	msg.msg_controllen = 0;
 	msg.msg_flags = MSG_DONTWAIT;
 
-	oldfs = get_fs(); set_fs(KERNEL_DS);
+	oldfs = get_fs();
+	set_fs(KERNEL_DS);
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
 	err = sock_sendmsg(sock, &msg);
 #else
@@ -3217,12 +3710,11 @@ static int route_dump(u32 *gw_addr ,int* gw_index)
 		goto out_sock;
 	}
 
-#if defined(CONFIG_IPV6) || defined (CONFIG_IPV6_MODULE)
+#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
 restart:
 #endif
 
-	for (;;) 
-	{
+	for (;;) {
 		struct nlmsghdr *h;
 
 		iov.iov_base = pg;
@@ -3232,8 +3724,13 @@ restart:
 		iov_iter_init(&msg.msg_iter, READ, &iov, 1, PAGE_SIZE);
 #endif
 
-		oldfs = get_fs(); set_fs(KERNEL_DS);
+		oldfs = get_fs();
+		set_fs(KERNEL_DS);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+		err = sock_recvmsg(sock, &msg, MSG_DONTWAIT);
+#else
 		err = sock_recvmsg(sock, &msg, PAGE_SIZE, MSG_DONTWAIT);
+#endif
 		set_fs(oldfs);
 
 		if (err < 0)
@@ -3244,10 +3741,9 @@ restart:
 			goto out_sock_pg;
 		}
 
-		h = (struct nlmsghdr*) pg;
-		
-		while (NLMSG_OK(h, err)) 
-		{
+		h = (struct nlmsghdr *) pg;
+
+		while (NLMSG_OK(h, err)) {
 			struct route_info rt_info;
 			if (h->nlmsg_type == NLMSG_DONE) {
 				err = 0;
@@ -3255,43 +3751,39 @@ restart:
 			}
 
 			if (h->nlmsg_type == NLMSG_ERROR) {
-				struct nlmsgerr *errm = (struct nlmsgerr*) NLMSG_DATA(h);
+				struct nlmsgerr *errm = (struct nlmsgerr *) NLMSG_DATA(h);
 				err = errm->error;
-				printk( "NLMSG error: %d\n", errm->error);
+				printk("NLMSG error: %d\n", errm->error);
 				goto done;
 			}
 
 			if (h->nlmsg_type == RTM_GETROUTE)
-			{
-				printk( "RTM_GETROUTE: NLMSG: %d\n", h->nlmsg_type);
-			}
+				printk("RTM_GETROUTE: NLMSG: %d\n", h->nlmsg_type);
 			if (h->nlmsg_type != RTM_NEWROUTE) {
-				printk( "NLMSG: %d\n", h->nlmsg_type);
+				printk("NLMSG: %d\n", h->nlmsg_type);
 				err = -EINVAL;
 				goto done;
 			}
 
 			memset(&rt_info, 0, sizeof(struct route_info));
 			parse_routes(h, &rt_info);
-			if(!rt_info.dst_addr.s_addr && rt_info.gateway.s_addr && rt_info.dev_index)
-			{
+			if (!rt_info.dst_addr.s_addr && rt_info.gateway.s_addr && rt_info.dev_index) {
 				*gw_addr = rt_info.gateway.s_addr;
 				*gw_index = rt_info.dev_index;
-				 	
+
 			}
 			h = NLMSG_NEXT(h, err);
 		}
 
-		if (err) 
-		{
-			printk( "!!!Remnant of size %d %d %d\n", err, h->nlmsg_len, h->nlmsg_type);
+		if (err) {
+			printk("!!!Remnant of size %d %d %d\n", err, h->nlmsg_len, h->nlmsg_type);
 			err = -EINVAL;
 			break;
 		}
 	}
 
 done:
-#if defined(CONFIG_IPV6) || defined (CONFIG_IPV6_MODULE)
+#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
 	if (!err && req.g.rtgen_family == AF_INET) {
 		req.g.rtgen_family = AF_INET6;
 
@@ -3308,9 +3800,10 @@ done:
 #endif
 		msg.msg_control = NULL;
 		msg.msg_controllen = 0;
-		msg.msg_flags=MSG_DONTWAIT;
+		msg.msg_flags = MSG_DONTWAIT;
 
-		oldfs = get_fs(); set_fs(KERNEL_DS);
+		oldfs = get_fs();
+		set_fs(KERNEL_DS);
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
 		err = sock_sendmsg(sock, &msg);
 #else
@@ -3332,7 +3825,7 @@ out_sock:
 }
 
 static int arp_query(unsigned char *haddr, u32 paddr,
-             struct net_device *dev)
+		     struct net_device *dev)
 {
 	struct neighbour *neighbor_entry;
 	int	ret = 0;
@@ -3350,36 +3843,33 @@ static int arp_query(unsigned char *haddr, u32 paddr,
 	return ret;
 }
 
-static int get_defaultgw(u32 *ip_addr ,char mac[])
+static int get_defaultgw(u32 *ip_addr , char mac[])
 {
-	int gw_index = 0; // oif device index
-	struct net_device *gw_dev = NULL; //oif device
-	
+	int gw_index = 0; /* oif device index */
+	struct net_device *gw_dev = NULL; /* oif device */
+
 	route_dump(ip_addr, &gw_index);
 
-	if( !(*ip_addr) || !gw_index )
-	{
-		//DBG_871X("No default GW \n");
+	if (!(*ip_addr) || !gw_index) {
+		/* RTW_INFO("No default GW\n"); */
 		return -1;
 	}
 
 	gw_dev = dev_get_by_index(&init_net, gw_index);
 
-	if(gw_dev == NULL)
-	{
-		//DBG_871X("get Oif Device Fail \n");
+	if (gw_dev == NULL) {
+		/* RTW_INFO("get Oif Device Fail\n"); */
 		return -1;
 	}
-	
-	if(!arp_query(mac, *ip_addr, gw_dev))
-	{
-		//DBG_871X( "arp query failed\n");
+
+	if (!arp_query(mac, *ip_addr, gw_dev)) {
+		/* RTW_INFO( "arp query failed\n"); */
 		dev_put(gw_dev);
 		return -1;
-		
+
 	}
 	dev_put(gw_dev);
-	
+
 	return 0;
 }
 
@@ -3387,26 +3877,22 @@ int	rtw_gw_addr_query(_adapter *padapter)
 {
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
-	u32 gw_addr = 0; // default gw address
-	unsigned char gw_mac[32] = {0}; // default gw mac
+	u32 gw_addr = 0; /* default gw address */
+	unsigned char gw_mac[32] = {0}; /* default gw mac */
 	int i;
 	int res;
 
 	res = get_defaultgw(&gw_addr, gw_mac);
-	if(!res)
-	{
-		pmlmepriv->gw_ip[0] = gw_addr&0xff;
-		pmlmepriv->gw_ip[1] = (gw_addr&0xff00)>>8;
-		pmlmepriv->gw_ip[2] = (gw_addr&0xff0000)>>16;
-		pmlmepriv->gw_ip[3] = (gw_addr&0xff000000)>>24;
+	if (!res) {
+		pmlmepriv->gw_ip[0] = gw_addr & 0xff;
+		pmlmepriv->gw_ip[1] = (gw_addr & 0xff00) >> 8;
+		pmlmepriv->gw_ip[2] = (gw_addr & 0xff0000) >> 16;
+		pmlmepriv->gw_ip[3] = (gw_addr & 0xff000000) >> 24;
 		_rtw_memcpy(pmlmepriv->gw_mac_addr, gw_mac, 6);
-		DBG_871X("%s Gateway Mac:\t" MAC_FMT "\n", __FUNCTION__, MAC_ARG(pmlmepriv->gw_mac_addr));
-		DBG_871X("%s Gateway IP:\t" IP_FMT "\n", __FUNCTION__, IP_ARG(pmlmepriv->gw_ip));
-	}
-	else
-	{
-		DBG_871X("Get Gateway IP/MAC fail!\n");
-	}
+		RTW_INFO("%s Gateway Mac:\t" MAC_FMT "\n", __FUNCTION__, MAC_ARG(pmlmepriv->gw_mac_addr));
+		RTW_INFO("%s Gateway IP:\t" IP_FMT "\n", __FUNCTION__, IP_ARG(pmlmepriv->gw_ip));
+	} else
+		RTW_INFO("Get Gateway IP/MAC fail!\n");
 
 	return res;
 }
@@ -3414,83 +3900,75 @@ int	rtw_gw_addr_query(_adapter *padapter)
 
 void rtw_dev_unload(PADAPTER padapter)
 {
-	struct net_device *pnetdev = (struct net_device*)padapter->pnetdev;	
+	struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	struct dvobj_priv *pobjpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &pobjpriv->drv_dbg;
 	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
 	u8 cnt = 0;
 
-	RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("+%s\n",__FUNCTION__));
 
-	if (padapter->bup == _TRUE)
-	{
-		DBG_871X("===> %s\n",__FUNCTION__);
+	if (padapter->bup == _TRUE) {
+		RTW_INFO("==> "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+#ifdef CONFIG_WOWLAN
+#ifdef CONFIG_GPIO_WAKEUP
+		/*default wake up pin change to BT*/
+		RTW_INFO("%s:default wake up pin change to BT\n", __FUNCTION__);
+		rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _FALSE);
+#endif /* CONFIG_GPIO_WAKEUP */
+#endif /* CONFIG_WOWLAN */
 
 		rtw_set_drv_stopped(padapter);
-		#ifdef CONFIG_XMIT_ACK
+#ifdef CONFIG_XMIT_ACK
 		if (padapter->xmitpriv.ack_tx)
 			rtw_ack_tx_done(&padapter->xmitpriv, RTW_SCTX_DONE_DRV_STOP);
-		#endif
+#endif
 
-		if (padapter->intf_stop)
-			padapter->intf_stop(padapter);
-		
-		RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("@ rtw_dev_unload: stop intf complete!\n"));
+		rtw_intf_stop(padapter);
 
+		#ifdef CONFIG_AUTOSUSPEND
 		if (!pwrctl->bInternalAutoSuspend)
+		#endif
+		{
 			rtw_stop_drv_threads(padapter);
 
-		while(ATOMIC_READ(&(pcmdpriv->cmdthd_running)) == _TRUE){
-			if (cnt > 5) {
-				DBG_871X("stop cmdthd timeout\n");
-				break;
-			} else {
-				cnt ++;
-				DBG_871X("cmdthd is running(%d)\n", cnt);
-				rtw_msleep_os(10);
+			if (ATOMIC_READ(&(pcmdpriv->cmdthd_running)) == _TRUE) {
+				RTW_ERR("cmd_thread not stop !!\n");
+				rtw_warn_on(1);
 			}
 		}
-
-		RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("@ %s: stop thread complete!\n",__FUNCTION__));
-
-		//check the status of IPS
-		if(rtw_hal_check_ips_status(padapter) == _TRUE || pwrctl->rf_pwrstate == rf_off) { //check HW status and SW state
-			DBG_871X_LEVEL(_drv_always_, "%s: driver in IPS-FWLPS\n", __func__);
+		/* check the status of IPS */
+		if (rtw_hal_check_ips_status(padapter) == _TRUE || pwrctl->rf_pwrstate == rf_off) { /* check HW status and SW state */
+			RTW_PRINT("%s: driver in IPS-FWLPS\n", __func__);
 			pdbgpriv->dbg_dev_unload_inIPS_cnt++;
-		} else {
-			DBG_871X_LEVEL(_drv_always_, "%s: driver not in IPS\n", __func__);
-		}
+		} else
+			RTW_PRINT("%s: driver not in IPS\n", __func__);
 
 		if (!rtw_is_surprise_removed(padapter)) {
 #ifdef CONFIG_BT_COEXIST
 			rtw_btcoex_IpsNotify(padapter, pwrctl->ips_mode_req);
 #endif
 #ifdef CONFIG_WOWLAN
-			if (pwrctl->bSupportRemoteWakeup == _TRUE && 
-				pwrctl->wowlan_mode ==_TRUE) {
-				DBG_871X_LEVEL(_drv_always_, "%s bSupportRemoteWakeup==_TRUE  do not run rtw_hal_deinit()\n",__FUNCTION__);
-			}
+			if (pwrctl->bSupportRemoteWakeup == _TRUE &&
+			    pwrctl->wowlan_mode == _TRUE)
+				RTW_PRINT("%s bSupportRemoteWakeup==_TRUE  do not run rtw_hal_deinit()\n", __FUNCTION__);
 			else
 #endif
 			{
-				//amy modify 20120221 for power seq is different between driver open and ips
+				/* amy modify 20120221 for power seq is different between driver open and ips */
 				rtw_hal_deinit(padapter);
 			}
 			rtw_set_surprise_removed(padapter);
 		}
-		RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("@ %s: deinit hal complelt!\n",__FUNCTION__));
 
 		padapter->bup = _FALSE;
 
-		DBG_871X("<=== %s\n",__FUNCTION__);
-	}
-	else {
-		RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("%s: bup==_FALSE\n",__FUNCTION__));
-		DBG_871X("%s: bup==_FALSE\n",__FUNCTION__);
+		RTW_INFO("<== "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	} else {
+		RTW_INFO("%s: bup==_FALSE\n", __FUNCTION__);
 	}
-	
-	RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("-%s\n",__FUNCTION__));
+	rtw_cancel_all_timer(padapter);
 }
 
 int rtw_suspend_free_assoc_resource(_adapter *padapter)
@@ -3498,63 +3976,62 @@ int rtw_suspend_free_assoc_resource(_adapter *padapter)
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct net_device *pnetdev = padapter->pnetdev;
 #ifdef CONFIG_P2P
-	struct wifidirect_info*	pwdinfo = &padapter->wdinfo;
-#endif // CONFIG_P2P
+	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
+#endif /* CONFIG_P2P */
 
-	DBG_871X("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
 
 	if (rtw_chk_roam_flags(padapter, RTW_ROAM_ON_RESUME)) {
-		if(check_fwstate(pmlmepriv, WIFI_STATION_STATE)
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
 			&& check_fwstate(pmlmepriv, _FW_LINKED)
-#ifdef CONFIG_P2P
-			&& rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
-#endif // CONFIG_P2P
-			)
-		{
-			DBG_871X("%s %s(" MAC_FMT "), length:%d assoc_ssid.length:%d\n",__FUNCTION__,
-					pmlmepriv->cur_network.network.Ssid.Ssid,
-					MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
-					pmlmepriv->cur_network.network.Ssid.SsidLength,
-					pmlmepriv->assoc_ssid.SsidLength);
+			#ifdef CONFIG_P2P
+			&& (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
+				#if defined(CONFIG_IOCTL_CFG80211) && RTW_P2P_GROUP_INTERFACE
+				|| rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)
+				#endif
+				)
+			#endif /* CONFIG_P2P */
+		) {
+			RTW_INFO("%s %s(" MAC_FMT "), length:%d assoc_ssid.length:%d\n", __FUNCTION__,
+				pmlmepriv->cur_network.network.Ssid.Ssid,
+				MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
+				pmlmepriv->cur_network.network.Ssid.SsidLength,
+				pmlmepriv->assoc_ssid.SsidLength);
 			rtw_set_to_roam(padapter, 1);
 		}
 	}
 
-	if(check_fwstate(pmlmepriv, WIFI_STATION_STATE) && check_fwstate(pmlmepriv, _FW_LINKED))
-	{	
-		rtw_disassoc_cmd(padapter, 0, _FALSE);	
-		//s2-2.  indicate disconnect to os
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) && check_fwstate(pmlmepriv, _FW_LINKED)) {
+		rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
+		/* s2-2.  indicate disconnect to os */
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
 	}
-	#ifdef CONFIG_AP_MODE
-	else if(check_fwstate(pmlmepriv, WIFI_AP_STATE))	
-	{
+#ifdef CONFIG_AP_MODE
+	else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter))
 		rtw_sta_flush(padapter, _TRUE);
-	}
-	#endif
-		
-	//s2-3.
-	rtw_free_assoc_resources(padapter, 1);
+#endif
+
+	/* s2-3. */
+	rtw_free_assoc_resources(padapter, _TRUE);
 
-	//s2-4.
+	/* s2-4. */
 #ifdef CONFIG_AUTOSUSPEND
-	if(is_primary_adapter(padapter) && (!adapter_to_pwrctl(padapter)->bInternalAutoSuspend ))
+	if (is_primary_adapter(padapter) && (!adapter_to_pwrctl(padapter)->bInternalAutoSuspend))
 #endif
 		rtw_free_network_queue(padapter, _TRUE);
 
 	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
-		DBG_871X_LEVEL(_drv_always_, "%s: fw_under_survey\n", __func__);
+		RTW_PRINT("%s: fw_under_survey\n", __func__);
 		rtw_indicate_scan_done(padapter, 1);
 		clr_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
 	}
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
-	{
-		DBG_871X_LEVEL(_drv_always_, "%s: fw_under_linking\n", __FUNCTION__);
+	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+		RTW_PRINT("%s: fw_under_linking\n", __FUNCTION__);
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
 	}
-	
-	DBG_871X("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
 	return _SUCCESS;
 }
 
@@ -3563,426 +4040,354 @@ int rtw_suspend_wow(_adapter *padapter)
 {
 	u8 ch, bw, offset;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct net_device *pnetdev = padapter->pnetdev;
-	#ifdef CONFIG_CONCURRENT_MODE
-	struct net_device *pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;	
-	#endif	
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;	
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct wowlan_ioctl_param poidparam;
 	u8 ps_mode;
 	int ret = _SUCCESS;
 
-	DBG_871X("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
 
 
-	DBG_871X("wowlan_mode: %d\n", pwrpriv->wowlan_mode);
-	DBG_871X("wowlan_pno_enable: %d\n", pwrpriv->wowlan_pno_enable);
+	RTW_INFO("wowlan_mode: %d\n", pwrpriv->wowlan_mode);
+	RTW_INFO("wowlan_pno_enable: %d\n", pwrpriv->wowlan_pno_enable);
 #ifdef CONFIG_P2P_WOWLAN
-	DBG_871X("wowlan_p2p_enable: %d\n", pwrpriv->wowlan_p2p_enable);
+	RTW_INFO("wowlan_p2p_enable: %d\n", pwrpriv->wowlan_p2p_enable);
 #endif
-	
+
 	if (pwrpriv->wowlan_mode == _TRUE) {
-		
-		if(pnetdev)
-			rtw_netif_stop_queue(pnetdev);	
+		rtw_mi_netif_stop_queue(padapter);
 		#ifdef CONFIG_CONCURRENT_MODE
-		if(pbuddy_netdev){
-			netif_carrier_off(pbuddy_netdev);
-			rtw_netif_stop_queue(pbuddy_netdev);
-		}
-		#endif//CONFIG_CONCURRENT_MODE
-		// 0. Power off LED
-		rtw_led_control(padapter, LED_CTL_POWER_OFF);
-		// 1. stop thread
-		rtw_set_drv_stopped(padapter);	/*for stop thread*/
-		rtw_stop_drv_threads(padapter);
-		#ifdef CONFIG_CONCURRENT_MODE	
-		rtw_stop_drv_threads(padapter->pbuddy_adapter);
-		#endif /*CONFIG_CONCURRENT_MODE*/
-		rtw_clr_drv_stopped(padapter);	/*for 32k command*/
+		rtw_mi_buddy_netif_carrier_off(padapter);
+		#endif
 
-		//#ifdef CONFIG_LPS
-		//rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "WOWLAN");
-		//#endif
+		/* 0. Power off LED */
+		rtw_led_control(padapter, LED_CTL_POWER_OFF);
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-		// 2. disable interrupt
-		if (padapter->intf_stop) {
-			padapter->intf_stop(padapter);
-		}
+		/* 2.only for SDIO disable interrupt */
+		rtw_intf_stop(padapter);
 
+		/* 2.1 clean interrupt */
+		rtw_hal_clear_interrupt(padapter);
+#endif /* CONFIG_SDIO_HCI */
 
-		#ifdef CONFIG_CONCURRENT_MODE
-		if (rtw_buddy_adapter_up(padapter)) { //free buddy adapter's resource
-			padapter->pbuddy_adapter->intf_stop(padapter->pbuddy_adapter);
-		}
-		#endif
+		/* 1. stop thread */
+		rtw_set_drv_stopped(padapter);	/*for stop thread*/
+		rtw_mi_stop_drv_threads(padapter);
 
-		// 2.1 clean interupt
-		rtw_hal_clear_interrupt(padapter);
-#endif //CONFIG_SDIO_HCI
+		rtw_clr_drv_stopped(padapter);	/*for 32k command*/
 
-		// 2.2 free irq
-		//sdio_free_irq(adapter_to_dvobj(padapter));
-		if(padapter->intf_free_irq)
-			padapter->intf_free_irq(adapter_to_dvobj(padapter));
+		/* #ifdef CONFIG_LPS */
+		/* rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "WOWLAN"); */
+		/* #endif */
 
-		#ifdef CONFIG_RUNTIME_PORT_SWITCH
+		#ifdef CONFIG_SDIO_HCI
+		/* 2.2 free irq */
+		#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+		sdio_free_irq(adapter_to_dvobj(padapter));
+		#endif
+		#endif/*CONFIG_SDIO_HCI*/
+
+#ifdef CONFIG_RUNTIME_PORT_SWITCH
 		if (rtw_port_switch_chk(padapter)) {
-			DBG_871X(" ### PORT SWITCH ### \n");
+			RTW_INFO(" ### PORT SWITCH ###\n");
 			rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
 		}
-		#endif
+#endif
 
 		poidparam.subcode = WOWLAN_ENABLE;
-		rtw_hal_set_hwreg(padapter,HW_VAR_WOWLAN,(u8 *)&poidparam);
+		rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
 		if (rtw_chk_roam_flags(padapter, RTW_ROAM_ON_RESUME)) {
-			if(check_fwstate(pmlmepriv, WIFI_STATION_STATE)
-				&& check_fwstate(pmlmepriv, _FW_LINKED))
-			{
-				DBG_871X("%s %s(" MAC_FMT "), length:%d assoc_ssid.length:%d\n",__FUNCTION__,
-						pmlmepriv->cur_network.network.Ssid.Ssid,
-						MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
-						pmlmepriv->cur_network.network.Ssid.SsidLength,
-						pmlmepriv->assoc_ssid.SsidLength);
+			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
+			    && check_fwstate(pmlmepriv, _FW_LINKED)) {
+				RTW_INFO("%s %s(" MAC_FMT "), length:%d assoc_ssid.length:%d\n", __FUNCTION__,
+					pmlmepriv->cur_network.network.Ssid.Ssid,
+					MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
+					pmlmepriv->cur_network.network.Ssid.SsidLength,
+					 pmlmepriv->assoc_ssid.SsidLength);
 
 				rtw_set_to_roam(padapter, 0);
 			}
 		}
 
-		DBG_871X_LEVEL(_drv_always_, "%s: wowmode suspending\n", __func__);
+		RTW_PRINT("%s: wowmode suspending\n", __func__);
 
-		if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
-		{
-			DBG_871X_LEVEL(_drv_always_, "%s: fw_under_survey\n", __func__);
+		if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+			RTW_PRINT("%s: fw_under_survey\n", __func__);
 			rtw_indicate_scan_done(padapter, 1);
 			clr_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
 		}
-		
-		if (rtw_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
-			DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-				FUNC_ADPT_ARG(padapter), ch, bw, offset);
+
+#if 1
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			ch =  rtw_mi_get_union_chan(padapter);
+			bw = rtw_mi_get_union_bw(padapter);
+			offset = rtw_mi_get_union_offset(padapter);
+			RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
+				 FUNC_ADPT_ARG(padapter), ch, bw, offset);
 			set_channel_bwmode(padapter, ch, offset, bw);
 		}
-		#ifdef CONFIG_CONCURRENT_MODE
-		if(rtw_buddy_adapter_up(padapter)){ //free buddy adapter's resource
-			rtw_suspend_free_assoc_resource(padapter->pbuddy_adapter);
+#else
+		if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
+			RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
+				 FUNC_ADPT_ARG(padapter), ch, bw, offset);
+			set_channel_bwmode(padapter, ch, offset, bw);
+			rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
 		}
-		#endif	
+#endif
+#ifdef CONFIG_CONCURRENT_MODE
+		rtw_mi_buddy_suspend_free_assoc_resource(padapter);
+#endif
 
-		if(pwrpriv->wowlan_pno_enable) {
-			DBG_871X_LEVEL(_drv_always_, "%s: pno: %d\n", __func__,
-					pwrpriv->wowlan_pno_enable);
+#ifdef CONFIG_BT_COEXIST
+		rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT);
+#endif
+
+		if (pwrpriv->wowlan_pno_enable) {
+			RTW_PRINT("%s: pno: %d\n", __func__,
+				  pwrpriv->wowlan_pno_enable);
 #ifdef CONFIG_FWLPS_IN_IPS
 			rtw_set_fw_in_ips_mode(padapter, _TRUE);
 #endif
 		}
-		#ifdef CONFIG_LPS
-		else
-			rtw_set_ps_mode(padapter, PS_MODE_MAX, 0, 0, "WOWLAN");
-		#endif //#ifdef CONFIG_LPS
+#ifdef CONFIG_LPS
+		else {
+			if (!(pwrpriv->wowlan_dis_lps)) {
+				rtw_wow_lps_level_decide(padapter, _TRUE);
+				RTW_INFO("[WIFIDBG] smart_ps = 2\n");
+				rtw_set_ps_mode(padapter, PS_MODE_MAX, 2, 0, "WOWLAN");
+			}
+		}
+#endif /* #ifdef CONFIG_LPS */
 
-	}
-	else
-	{
-		DBG_871X_LEVEL(_drv_always_, "%s: ### ERROR ### wowlan_mode=%d\n", __FUNCTION__, pwrpriv->wowlan_mode);	
-	}
-	DBG_871X("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	} else
+		RTW_PRINT("%s: ### ERROR ### wowlan_mode=%d\n", __FUNCTION__, pwrpriv->wowlan_mode);
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
 	return ret;
 }
-#endif //#ifdef CONFIG_WOWLAN
+#endif /* #ifdef CONFIG_WOWLAN */
 
 #ifdef CONFIG_AP_WOWLAN
 int rtw_suspend_ap_wow(_adapter *padapter)
 {
 	u8 ch, bw, offset;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct net_device *pnetdev = padapter->pnetdev;
-	#ifdef CONFIG_CONCURRENT_MODE
-	struct net_device *pbuddy_netdev;
-	#endif
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct wowlan_ioctl_param poidparam;
 	u8 ps_mode;
 	int ret = _SUCCESS;
 
-	DBG_871X("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
-	
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
 	pwrpriv->wowlan_ap_mode = _TRUE;
-	
-	DBG_871X("wowlan_ap_mode: %d\n", pwrpriv->wowlan_ap_mode);
-	
-	if(pnetdev)
-		rtw_netif_stop_queue(pnetdev);
-	#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter)) {
-		pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;
-		if (pbuddy_netdev)
-		rtw_netif_stop_queue(pbuddy_netdev);
-	}
-	#endif//CONFIG_CONCURRENT_MODE
-	// 0. Power off LED
-	rtw_led_control(padapter, LED_CTL_POWER_OFF);
-	// 1. stop thread
-	rtw_set_drv_stopped(padapter);	/*for stop thread*/
-	rtw_stop_drv_threads(padapter);
-	#ifdef CONFIG_CONCURRENT_MODE	
-	if (rtw_buddy_adapter_up(padapter))
-		rtw_stop_drv_threads(padapter->pbuddy_adapter);
-	#endif /* CONFIG_CONCURRENT_MODE */
-	rtw_clr_drv_stopped(padapter);	/*for 32k command*/
 
-#ifdef CONFIG_SDIO_HCI
-	// 2. disable interrupt
-	rtw_hal_disable_interrupt(padapter); // It need wait for leaving 32K.
+	RTW_INFO("wowlan_ap_mode: %d\n", pwrpriv->wowlan_ap_mode);
 
-	#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter)) { //free buddy adapter's resource
-		padapter->pbuddy_adapter->intf_stop(padapter->pbuddy_adapter);
-	}
-	#endif
+	rtw_mi_netif_stop_queue(padapter);
+
+	/* 0. Power off LED */
+	rtw_led_control(padapter, LED_CTL_POWER_OFF);
+#ifdef CONFIG_SDIO_HCI
+	/* 2.only for SDIO disable interrupt*/
+	rtw_intf_stop(padapter);
 
-	// 2.1 clean interupt
+	/* 2.1 clean interrupt */
 	rtw_hal_clear_interrupt(padapter);
-#endif //CONFIG_SDIO_HCI
+#endif /* CONFIG_SDIO_HCI */
 
-	// 2.2 free irq
-	if(padapter->intf_free_irq)
-		padapter->intf_free_irq(adapter_to_dvobj(padapter));
+	/* 1. stop thread */
+	rtw_set_drv_stopped(padapter);	/*for stop thread*/
+	rtw_mi_stop_drv_threads(padapter);
+	rtw_clr_drv_stopped(padapter);	/*for 32k command*/
+
+	#ifdef CONFIG_SDIO_HCI
+	/* 2.2 free irq */
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	sdio_free_irq(adapter_to_dvobj(padapter));
+	#endif
+	#endif/*CONFIG_SDIO_HCI*/
 
-	#ifdef CONFIG_RUNTIME_PORT_SWITCH
+#ifdef CONFIG_RUNTIME_PORT_SWITCH
 	if (rtw_port_switch_chk(padapter)) {
-		DBG_871X(" ### PORT SWITCH ### \n");
+		RTW_INFO(" ### PORT SWITCH ###\n");
 		rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
 	}
-	#endif
+#endif
 
 	poidparam.subcode = WOWLAN_AP_ENABLE;
 	rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
 
-	DBG_871X_LEVEL(_drv_always_, "%s: wowmode suspending\n", __func__);
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (check_buddy_fwstate(padapter, WIFI_AP_STATE) == _TRUE) {
-		if (rtw_get_ch_setting_union(padapter->pbuddy_adapter, &ch, &bw, &offset) != 0) {
-			DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-				FUNC_ADPT_ARG(padapter->pbuddy_adapter), ch, bw, offset);
-			set_channel_bwmode(padapter->pbuddy_adapter, ch, offset, bw);
-		}
-		rtw_suspend_free_assoc_resource(padapter);
-	} else {
-		if (rtw_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
-			DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-				FUNC_ADPT_ARG(padapter), ch, bw, offset);
-			set_channel_bwmode(padapter, ch, offset, bw);
-		}
-		rtw_suspend_free_assoc_resource(padapter->pbuddy_adapter);
+	RTW_PRINT("%s: wowmode suspending\n", __func__);
+#if 1
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		ch =  rtw_mi_get_union_chan(padapter);
+		bw = rtw_mi_get_union_bw(padapter);
+		offset = rtw_mi_get_union_offset(padapter);
+		RTW_INFO("back to linked/linking union - ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
+		set_channel_bwmode(padapter, ch, offset, bw);
 	}
 #else
-	if (rtw_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
-		DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-			FUNC_ADPT_ARG(padapter), ch, bw, offset);
-			set_channel_bwmode(padapter, ch, offset, bw);
+	if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
+		RTW_INFO("back to linked/linking union - ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
+		set_channel_bwmode(padapter, ch, offset, bw);
+		rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
+	}
+#endif
+
+	/*FOR ONE AP - TODO :Multi-AP*/
+	{
+		int i;
+		_adapter *iface;
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if ((iface) && rtw_is_adapter_up(iface)) {
+				if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE) == _FALSE)
+					rtw_suspend_free_assoc_resource(iface);
+			}
+		}
+
 	}
+
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT);
 #endif
 
 #ifdef CONFIG_LPS
-	rtw_set_ps_mode(padapter, PS_MODE_MIN, 0, 0, "AP-WOWLAN");
+	if (!(pwrpriv->wowlan_dis_lps)) {
+		rtw_wow_lps_level_decide(padapter, _TRUE);
+		rtw_set_ps_mode(padapter, PS_MODE_MIN, 0, 0, "AP-WOWLAN");
+	}
 #endif
 
-	DBG_871X("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
 	return ret;
 }
-#endif //#ifdef CONFIG_AP_WOWLAN
+#endif /* #ifdef CONFIG_AP_WOWLAN */
 
 
 int rtw_suspend_normal(_adapter *padapter)
 {
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct net_device *pnetdev = padapter->pnetdev;
-	#ifdef CONFIG_CONCURRENT_MODE
-	struct net_device *pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;	
-	#endif	
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	int ret = _SUCCESS;	
-
-	DBG_871X("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));			
-	if(pnetdev){
-		netif_carrier_off(pnetdev);
-		rtw_netif_stop_queue(pnetdev);
-	}		
-#ifdef CONFIG_CONCURRENT_MODE
-	if(rtw_buddy_adapter_up(padapter)){
-		pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;
-		netif_carrier_off(pbuddy_netdev);
-		rtw_netif_stop_queue(pbuddy_netdev);
-	}
-#endif	
+	int ret = _SUCCESS;
 
-	rtw_suspend_free_assoc_resource(padapter);
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if(rtw_buddy_adapter_up(padapter)){
-		rtw_suspend_free_assoc_resource(padapter->pbuddy_adapter);
-	}
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_SUSPEND);
 #endif
+	rtw_mi_netif_caroff_qstop(padapter);
+
+	rtw_mi_suspend_free_assoc_resource(padapter);
+
 	rtw_led_control(padapter, LED_CTL_POWER_OFF);
 
 	if ((rtw_hal_check_ips_status(padapter) == _TRUE)
-		|| (adapter_to_pwrctl(padapter)->rf_pwrstate == rf_off))
-	{
-		DBG_871X_LEVEL(_drv_always_, "%s: ### ERROR #### driver in IPS ####ERROR###!!!\n", __FUNCTION__);	
-		
-	}
-	
+	    || (adapter_to_pwrctl(padapter)->rf_pwrstate == rf_off))
+		RTW_PRINT("%s: ### ERROR #### driver in IPS ####ERROR###!!!\n", __FUNCTION__);
+
+
 #ifdef CONFIG_CONCURRENT_MODE
-	if(rtw_buddy_adapter_up(padapter)){
-		rtw_dev_unload(padapter->pbuddy_adapter);
-	}
+	rtw_set_drv_stopped(padapter);	/*for stop thread*/
+	rtw_stop_cmd_thread(padapter);
+	rtw_drv_stop_vir_ifaces(adapter_to_dvobj(padapter));
 #endif
 	rtw_dev_unload(padapter);
 
-	//sdio_deinit(adapter_to_dvobj(padapter));
-	if(padapter->intf_deinit)
-		padapter->intf_deinit(adapter_to_dvobj(padapter));
+	#ifdef CONFIG_SDIO_HCI
+	sdio_deinit(adapter_to_dvobj(padapter));
 
-	DBG_871X("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	sdio_free_irq(adapter_to_dvobj(padapter));
+	#endif
+	#endif /*CONFIG_SDIO_HCI*/
+
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
 	return ret;
 }
 
 int rtw_suspend_common(_adapter *padapter)
 {
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(psdpriv);
+	struct dvobj_priv *dvobj = padapter->dvobj;
+	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	
+
 	int ret = 0;
-	u32 start_time = rtw_get_current_time();
+	systime start_time = rtw_get_current_time();
+
+	RTW_PRINT(" suspend start\n");
+	RTW_INFO("==> %s (%s:%d)\n", __FUNCTION__, current->comm, current->pid);
 
-	DBG_871X_LEVEL(_drv_always_, " suspend start\n");
-	DBG_871X("==> %s (%s:%d)\n",__FUNCTION__, current->comm, current->pid);
-	
 	pdbgpriv->dbg_suspend_cnt++;
-	
+
 	pwrpriv->bInSuspend = _TRUE;
-	
+
 	while (pwrpriv->bips_processing == _TRUE)
-		rtw_msleep_os(1);		
+		rtw_msleep_os(1);
 
 #ifdef CONFIG_IOL_READ_EFUSE_MAP
-	if(!padapter->bup){
+	if (!padapter->bup) {
 		u8 bMacPwrCtrlOn = _FALSE;
 		rtw_hal_get_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
-		if(bMacPwrCtrlOn)
+		if (bMacPwrCtrlOn)
 			rtw_hal_power_off(padapter);
 	}
 #endif
 
 	if ((!padapter->bup) || RTW_CANNOT_RUN(padapter)) {
-		DBG_871X("%s bup=%d bDriverStopped=%s bSurpriseRemoved = %s\n", __func__
-			, padapter->bup
-			, rtw_is_drv_stopped(padapter)?"True":"False"
-			, rtw_is_surprise_removed(padapter)?"True":"False");
+		RTW_INFO("%s bup=%d bDriverStopped=%s bSurpriseRemoved = %s\n", __func__
+			 , padapter->bup
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
 		pdbgpriv->dbg_suspend_error_cnt++;
 		goto exit;
 	}
 	rtw_ps_deny(padapter, PS_DENY_SUSPEND);
 
-	rtw_cancel_all_timer(padapter);
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->pbuddy_adapter){
-		rtw_cancel_all_timer(padapter->pbuddy_adapter);
-	}
-#endif // CONFIG_CONCURRENT_MODE
-
+	rtw_mi_cancel_all_timer(padapter);
 	LeaveAllPowerSaveModeDirect(padapter);
 
-	rtw_stop_cmd_thread(padapter);
-	
-#ifdef CONFIG_BT_COEXIST
-	// wait for the latest FW to remove this condition.
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
-		rtw_btcoex_SuspendNotify(padapter, 0);
-		DBG_871X("WIFI_AP_STATE\n");
-#ifdef CONFIG_CONCURRENT_MODE
-	} else if (check_buddy_fwstate(padapter, WIFI_AP_STATE)) {
-		rtw_btcoex_SuspendNotify(padapter, 0);
-		DBG_871X("P2P_ROLE_GO\n");
-#endif //CONFIG_CONCURRENT_MODE
-	} else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
-		rtw_btcoex_SuspendNotify(padapter, 1);
-		DBG_871X("STATION\n");
-	}
-#endif // CONFIG_BT_COEXIST
-
 	rtw_ps_deny_cancel(padapter, PS_DENY_SUSPEND);
 
-	if (check_fwstate(pmlmepriv,WIFI_STATION_STATE) == _TRUE
-#ifdef CONFIG_CONCURRENT_MODE
-		&& check_buddy_fwstate(padapter, WIFI_AP_STATE) == _FALSE
-#endif
-	) {
-	#ifdef CONFIG_WOWLAN
-		if (check_fwstate(pmlmepriv, _FW_LINKED)) {
+	if (rtw_mi_check_status(padapter, MI_AP_MODE) == _FALSE) {
+#ifdef CONFIG_WOWLAN
+		if (check_fwstate(pmlmepriv, _FW_LINKED))
 			pwrpriv->wowlan_mode = _TRUE;
-		} else if (pwrpriv->wowlan_pno_enable == _TRUE) {
+		else if (pwrpriv->wowlan_pno_enable == _TRUE)
 			pwrpriv->wowlan_mode |= pwrpriv->wowlan_pno_enable;
-		}
 
-	#ifdef CONFIG_P2P_WOWLAN
-		if(!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE) || P2P_ROLE_DISABLE != padapter->wdinfo.role)
-		{
+#ifdef CONFIG_P2P_WOWLAN
+		if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE) || P2P_ROLE_DISABLE != padapter->wdinfo.role)
 			pwrpriv->wowlan_p2p_mode = _TRUE;
-		}
-		if(_TRUE == pwrpriv->wowlan_p2p_mode)
+		if (_TRUE == pwrpriv->wowlan_p2p_mode)
 			pwrpriv->wowlan_mode |= pwrpriv->wowlan_p2p_mode;
-	#endif //CONFIG_P2P_WOWLAN
+#endif /* CONFIG_P2P_WOWLAN */
 
 		if (pwrpriv->wowlan_mode == _TRUE)
 			rtw_suspend_wow(padapter);
 		else
+#endif /* CONFIG_WOWLAN */
 			rtw_suspend_normal(padapter);
-		
-	#else //CONFIG_WOWLAN
-		rtw_suspend_normal(padapter);
-	#endif //CONFIG_WOWLAN
-	} else if (check_fwstate(pmlmepriv,WIFI_AP_STATE) == _TRUE
-#ifdef CONFIG_CONCURRENT_MODE
-		&& check_buddy_fwstate(padapter, WIFI_AP_STATE) == _FALSE
-#endif
-	) {
-	#ifdef CONFIG_AP_WOWLAN
-		rtw_suspend_ap_wow(padapter);
-	#else
-		rtw_suspend_normal(padapter);
-	#endif //CONFIG_AP_WOWLAN
-#ifdef CONFIG_CONCURRENT_MODE
-	} else if (check_fwstate(pmlmepriv,WIFI_STATION_STATE) == _TRUE
-		&& check_buddy_fwstate(padapter, WIFI_AP_STATE) == _TRUE) {
-	#ifdef CONFIG_AP_WOWLAN
+	} else if (rtw_mi_check_status(padapter, MI_AP_MODE)) {
+#ifdef CONFIG_AP_WOWLAN
 		rtw_suspend_ap_wow(padapter);
-	#else
-		rtw_suspend_normal(padapter);
-	#endif //CONFIG_AP_WOWLAN
-#endif
-	} else {
+#else
 		rtw_suspend_normal(padapter);
+#endif /*CONFIG_AP_WOWLAN*/
 	}
 
 
-	DBG_871X_LEVEL(_drv_always_, "rtw suspend success in %d ms\n",
-		rtw_get_passing_time_ms(start_time));
+	RTW_PRINT("rtw suspend success in %d ms\n",
+		  rtw_get_passing_time_ms(start_time));
 
 exit:
-	DBG_871X("<===  %s return %d.............. in %dms\n", __FUNCTION__
-		, ret, rtw_get_passing_time_ms(start_time));
+	RTW_INFO("<===  %s return %d.............. in %dms\n", __FUNCTION__
+		 , ret, rtw_get_passing_time_ms(start_time));
 
-	return ret;	
+	return ret;
 }
 
 #ifdef CONFIG_WOWLAN
@@ -3991,22 +4396,16 @@ int rtw_resume_process_wow(_adapter *padapter)
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct net_device *pnetdev = padapter->pnetdev;
-	#ifdef CONFIG_CONCURRENT_MODE
-	struct net_device *pbuddy_netdev;	
-	#endif	
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	struct wowlan_ioctl_param poidparam;
 	struct sta_info	*psta = NULL;
 	int ret = _SUCCESS;
-_func_enter_;
 
-	DBG_871X("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
-	
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
 	if (padapter) {
-		pnetdev = padapter->pnetdev;
 		pwrpriv = adapter_to_pwrctl(padapter);
 	} else {
 		pdbgpriv->dbg_resume_error_cnt++;
@@ -4015,189 +4414,142 @@ _func_enter_;
 	}
 
 	if (RTW_CANNOT_RUN(padapter)) {
-		DBG_871X("%s pdapter %p bDriverStopped %s bSurpriseRemoved %s\n"
-				, __func__, padapter
-				, rtw_is_drv_stopped(padapter)?"True":"False"
-				, rtw_is_surprise_removed(padapter)?"True":"False");
+		RTW_INFO("%s pdapter %p bDriverStopped %s bSurpriseRemoved %s\n"
+			 , __func__, padapter
+			 , rtw_is_drv_stopped(padapter) ? "True" : "False"
+			, rtw_is_surprise_removed(padapter) ? "True" : "False");
 		goto exit;
 	}
 
+	pwrpriv->wowlan_in_resume = _TRUE;
 #ifdef CONFIG_PNO_SUPPORT
-	pwrpriv->pno_in_resume = _TRUE;
 #ifdef CONFIG_FWLPS_IN_IPS
-	if(pwrpriv->wowlan_pno_enable)
+	if (pwrpriv->wowlan_pno_enable)
 		rtw_set_fw_in_ips_mode(padapter, _FALSE);
-#endif //CONFIG_FWLPS_IN_IPS
-#endif//CONFIG_PNO_SUPPORT
+#endif /* CONFIG_FWLPS_IN_IPS */
+#endif/* CONFIG_PNO_SUPPORT */
 
-	if (pwrpriv->wowlan_mode == _TRUE){
+	if (pwrpriv->wowlan_mode == _TRUE) {
 #ifdef CONFIG_LPS
-		rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "WOWLAN");
-#endif //CONFIG_LPS
-
-		pwrpriv->bFwCurrentInPSMode = _FALSE;
-
-#ifdef CONFIG_SDIO_HCI
-		if (padapter->intf_stop) {
-			padapter->intf_stop(padapter);
+		if (!(pwrpriv->wowlan_dis_lps)) {
+			rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "WOWLAN");
+			rtw_wow_lps_level_decide(padapter, _FALSE);
 		}
+#endif /* CONFIG_LPS */
 
-		#ifdef CONFIG_CONCURRENT_MODE
-		if (rtw_buddy_adapter_up(padapter)) { //free buddy adapter's resource
-			padapter->pbuddy_adapter->intf_stop(padapter->pbuddy_adapter);
-		}
-		#endif
+		pwrpriv->bFwCurrentInPSMode = _FALSE;
 
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_PCI_HCI)
+		rtw_mi_intf_stop(padapter);
 		rtw_hal_clear_interrupt(padapter);
-#endif //CONFIG_SDIO_HCI
+#endif
 
-		//if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {		
-		if((padapter->intf_alloc_irq) && (padapter->intf_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS)){
+		#ifdef CONFIG_SDIO_HCI
+		#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+		if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {
 			ret = -1;
-			RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("%s: sdio_alloc_irq Failed!!\n", __FUNCTION__));
 			goto exit;
 		}
+		#endif
+		#endif/*CONFIG_SDIO_HCI*/
 
-		//Disable WOW, set H2C command
-		poidparam.subcode=WOWLAN_DISABLE;
-		rtw_hal_set_hwreg(padapter,HW_VAR_WOWLAN,(u8 *)&poidparam);
+		/* Disable WOW, set H2C command */
+		poidparam.subcode = WOWLAN_DISABLE;
+		rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
 
-		#ifdef CONFIG_CONCURRENT_MODE
-		rtw_reset_drv_sw(padapter->pbuddy_adapter);
-		#endif		
+#ifdef CONFIG_CONCURRENT_MODE
+		rtw_mi_buddy_reset_drv_sw(padapter);
+#endif
 
 		psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
-		if (psta) {
+		if (psta)
 			set_sta_rate(padapter, psta);
-		}
 
-	
+
 		rtw_clr_drv_stopped(padapter);
-		DBG_871X("%s: wowmode resuming, DriverStopped:%s\n", __func__, rtw_is_drv_stopped(padapter)?"True":"False");
-		rtw_start_drv_threads(padapter);
+		RTW_INFO("%s: wowmode resuming, DriverStopped:%s\n", __func__, rtw_is_drv_stopped(padapter) ? "True" : "False");
 
-#ifdef CONFIG_CONCURRENT_MODE
-		if (padapter->pbuddy_adapter)
-			rtw_start_drv_threads(padapter->pbuddy_adapter);
-#endif /* CONFIG_CONCURRENT_MODE*/
+		rtw_mi_start_drv_threads(padapter);
 
-		if (padapter->intf_start) {
-			padapter->intf_start(padapter);
-		}
-		#ifdef CONFIG_CONCURRENT_MODE
-		if (rtw_buddy_adapter_up(padapter)) { //free buddy adapter's resource
-			padapter->pbuddy_adapter->intf_start(padapter->pbuddy_adapter);
-		}
+		rtw_mi_intf_start(padapter);
 
-		if (rtw_buddy_adapter_up(padapter)) {
-			pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;
+#ifdef CONFIG_CONCURRENT_MODE
+		rtw_mi_buddy_netif_carrier_on(padapter);
+#endif
 
-			if(pbuddy_netdev){
-				netif_device_attach(pbuddy_netdev);
-				netif_carrier_on(pbuddy_netdev);
-			}
-		}
-		#endif
+		/* start netif queue */
+		rtw_mi_netif_wake_queue(padapter);
 
-		// start netif queue
-		if (pnetdev) {
-			rtw_netif_wake_queue(pnetdev);
-		}
-	}
-	else{
+	} else
 
-		DBG_871X_LEVEL(_drv_always_, "%s: ### ERROR ### wowlan_mode=%d\n", __FUNCTION__, pwrpriv->wowlan_mode);		
-	} 
+		RTW_PRINT("%s: ### ERROR ### wowlan_mode=%d\n", __FUNCTION__, pwrpriv->wowlan_mode);
 
-	if( padapter->pid[1]!=0) {
-		DBG_871X("pid[1]:%d\n",padapter->pid[1]);
+	if (padapter->pid[1] != 0) {
+		RTW_INFO("pid[1]:%d\n", padapter->pid[1]);
 		rtw_signal_process(padapter->pid[1], SIGUSR2);
-	}	
+	}
 
 	if (rtw_chk_roam_flags(padapter, RTW_ROAM_ON_RESUME)) {
-		if (pwrpriv->wowlan_wake_reason == FWDecisionDisconnect ||
-			pwrpriv->wowlan_wake_reason == Rx_DisAssoc ||
-			pwrpriv->wowlan_wake_reason == Rx_DeAuth) {
+		if (pwrpriv->wowlan_wake_reason == FW_DECISION_DISCONNECT ||
+		    pwrpriv->wowlan_wake_reason == RX_DISASSOC||
+		    pwrpriv->wowlan_wake_reason == RX_DEAUTH) {
 
-			DBG_871X("%s: disconnect reason: %02x\n", __func__,
-						pwrpriv->wowlan_wake_reason);
+			RTW_INFO("%s: disconnect reason: %02x\n", __func__,
+				 pwrpriv->wowlan_wake_reason);
 			rtw_indicate_disconnect(padapter, 0, _FALSE);
 
 			rtw_sta_media_status_rpt(padapter,
-				rtw_get_stainfo(&padapter->stapriv,
-					get_bssid(&padapter->mlmepriv)), 0);
+					 rtw_get_stainfo(&padapter->stapriv,
+					 get_bssid(&padapter->mlmepriv)), 0);
 
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources(padapter, _TRUE);
 			pmlmeinfo->state = WIFI_FW_NULL_STATE;
 
 		} else {
-			DBG_871X("%s: do roaming\n", __func__);
+			RTW_INFO("%s: do roaming\n", __func__);
 			rtw_roaming(padapter, NULL);
 		}
 	}
 
-	if (pwrpriv->wowlan_wake_reason == FWDecisionDisconnect) {
-		rtw_lock_ext_suspend_timeout(2000);
-	}
-
-	if (pwrpriv->wowlan_wake_reason == Rx_GTK ||
-		pwrpriv->wowlan_wake_reason == Rx_DisAssoc ||
-		pwrpriv->wowlan_wake_reason == Rx_DeAuth) {
-		rtw_lock_ext_suspend_timeout(8000);
-	}
-
-	if (pwrpriv->wowlan_wake_reason == RX_PNOWakeUp) {
-#ifdef CONFIG_IOCTL_CFG80211
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
-			u8 locally_generated = 1;
-
-			cfg80211_disconnected(padapter->pnetdev, 0, NULL, 0, locally_generated, GFP_ATOMIC);
-#else
-			cfg80211_disconnected(padapter->pnetdev, 0, NULL, 0, GFP_ATOMIC);
-#endif
-#endif /* CONFIG_IOCTL_CFG80211 */
-		rtw_lock_ext_suspend_timeout(10000);
-	}
-
 	if (pwrpriv->wowlan_mode == _TRUE) {
 		pwrpriv->bips_processing = _FALSE;
-		_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 2000);
+		_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
 #ifndef CONFIG_IPS_CHECK_IN_WD
 		rtw_set_pwr_state_check_timer(pwrpriv);
 #endif
-	} else {
-		DBG_871X_LEVEL(_drv_always_, "do not reset timer\n");
-	}
+	} else
+		RTW_PRINT("do not reset timer\n");
 
-	pwrpriv->wowlan_mode =_FALSE;
+	pwrpriv->wowlan_mode = _FALSE;
 
-	// Power On LED
-	rtw_hal_sw_led_init(padapter);
-	if(pwrpriv->wowlan_wake_reason == Rx_DisAssoc ||
-		pwrpriv->wowlan_wake_reason == Rx_DeAuth ||
-		pwrpriv->wowlan_wake_reason == FWDecisionDisconnect)
+	/* Power On LED */
+#ifdef CONFIG_RTW_SW_LED
+
+	if (pwrpriv->wowlan_wake_reason == RX_DISASSOC||
+	    pwrpriv->wowlan_wake_reason == RX_DEAUTH||
+	    pwrpriv->wowlan_wake_reason == FW_DECISION_DISCONNECT)
 		rtw_led_control(padapter, LED_CTL_NO_LINK);
 	else
 		rtw_led_control(padapter, LED_CTL_LINK);
-
-	//clean driver side wake up reason.
+#endif
+	/* clean driver side wake up reason. */
+	pwrpriv->wowlan_last_wake_reason = pwrpriv->wowlan_wake_reason;
 	pwrpriv->wowlan_wake_reason = 0;
 
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_RESUME);
+#endif /* CONFIG_BT_COEXIST */
+
 exit:
-	DBG_871X("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
-_func_exit_;
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
 	return ret;
 }
-#endif //#ifdef CONFIG_WOWLAN
+#endif /* #ifdef CONFIG_WOWLAN */
 
 #ifdef CONFIG_AP_WOWLAN
 int rtw_resume_process_ap_wow(_adapter *padapter)
 {
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct net_device *pnetdev = padapter->pnetdev;
-	#ifdef CONFIG_CONCURRENT_MODE
-	struct net_device *pbuddy_netdev;	
-	#endif	
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
@@ -4205,12 +4557,10 @@ int rtw_resume_process_ap_wow(_adapter *padapter)
 	struct sta_info	*psta = NULL;
 	int ret = _SUCCESS;
 	u8 ch, bw, offset;
-_func_enter_;
 
-	DBG_871X("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
-	
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
 	if (padapter) {
-		pnetdev = padapter->pnetdev;
 		pwrpriv = adapter_to_pwrctl(padapter);
 	} else {
 		pdbgpriv->dbg_resume_error_cnt++;
@@ -4220,301 +4570,245 @@ _func_enter_;
 
 
 #ifdef CONFIG_LPS
-	rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "AP-WOWLAN");
-#endif //CONFIG_LPS
+	if (!(pwrpriv->wowlan_dis_lps)) {
+		rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "AP-WOWLAN");
+		rtw_wow_lps_level_decide(padapter, _FALSE);
+	}
+#endif /* CONFIG_LPS */
 
 	pwrpriv->bFwCurrentInPSMode = _FALSE;
 
 	rtw_hal_disable_interrupt(padapter);
 
 	rtw_hal_clear_interrupt(padapter);
-		
-	//if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {		
-	if((padapter->intf_alloc_irq) && (padapter->intf_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS)){
+
+	#ifdef CONFIG_SDIO_HCI
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {
 		ret = -1;
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("%s: sdio_alloc_irq Failed!!\n", __FUNCTION__));
 		goto exit;
 	}
-
-	//Disable WOW, set H2C command
+	#endif
+	#endif/*CONFIG_SDIO_HCI*/
+	/* Disable WOW, set H2C command */
 	poidparam.subcode = WOWLAN_AP_DISABLE;
 	rtw_hal_set_hwreg(padapter, HW_VAR_WOWLAN, (u8 *)&poidparam);
 	pwrpriv->wowlan_ap_mode = _FALSE;
 
 	rtw_clr_drv_stopped(padapter);
-	DBG_871X("%s: wowmode resuming, DriverStopped:%s\n", __func__, rtw_is_drv_stopped(padapter)?"True":"False");
-	rtw_start_drv_threads(padapter);
+	RTW_INFO("%s: wowmode resuming, DriverStopped:%s\n", __func__, rtw_is_drv_stopped(padapter) ? "True" : "False");
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter))
-		rtw_start_drv_threads(padapter->pbuddy_adapter);
-#endif /* CONFIG_CONCURRENT_MODE */
+	rtw_mi_start_drv_threads(padapter);
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter)) {
-		if (rtw_get_ch_setting_union(padapter->pbuddy_adapter, &ch, &bw, &offset) != 0) {
-			DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-			FUNC_ADPT_ARG(padapter->pbuddy_adapter), ch, bw, offset);
-			set_channel_bwmode(padapter->pbuddy_adapter, ch, offset, bw);
-		}
-	} else {
-		DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-			FUNC_ADPT_ARG(padapter), ch, bw, offset);
+#if 1
+	if (rtw_mi_check_status(padapter, MI_LINKED)) {
+		ch =  rtw_mi_get_union_chan(padapter);
+		bw = rtw_mi_get_union_bw(padapter);
+		offset = rtw_mi_get_union_offset(padapter);
+		RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n", FUNC_ADPT_ARG(padapter), ch, bw, offset);
 		set_channel_bwmode(padapter, ch, offset, bw);
-		rtw_reset_drv_sw(padapter->pbuddy_adapter);
 	}
 #else
-	if (rtw_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
-		DBG_871X(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
-			FUNC_ADPT_ARG(padapter), ch, bw, offset);
+	if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
+		RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n", FUNC_ADPT_ARG(padapter), ch, bw, offset);
 		set_channel_bwmode(padapter, ch, offset, bw);
+		rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
 	}
 #endif
 
-	if (padapter->intf_start) {
-		padapter->intf_start(padapter);
-	}
+	/*FOR ONE AP - TODO :Multi-AP*/
+	{
+		int i;
+		_adapter *iface;
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if ((iface) && rtw_is_adapter_up(iface)) {
+				if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE | _FW_LINKED))
+					rtw_reset_drv_sw(iface);
+			}
+		}
 
-	#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter)) { //free buddy adapter's resource
-		padapter->pbuddy_adapter->intf_start(padapter->pbuddy_adapter);
 	}
-	#endif
+	rtw_mi_intf_start(padapter);
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_buddy_adapter_up(padapter)) {			
-		pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;			
-		if(pbuddy_netdev){
-			rtw_netif_wake_queue(pbuddy_netdev);
-		}
-	}
-#endif
-	
-	// start netif queue
-	if (pnetdev) {
-		rtw_netif_wake_queue(pnetdev);
-	}
+	/* start netif queue */
+	rtw_mi_netif_wake_queue(padapter);
 
-	if( padapter->pid[1]!=0) {
-		DBG_871X("pid[1]:%d\n",padapter->pid[1]);
+	if (padapter->pid[1] != 0) {
+		RTW_INFO("pid[1]:%d\n", padapter->pid[1]);
 		rtw_signal_process(padapter->pid[1], SIGUSR2);
-	}	
-
-	#ifdef CONFIG_RESUME_IN_WORKQUEUE
-	//rtw_unlock_suspend();
-	#endif //CONFIG_RESUME_IN_WORKQUEUE
+	}
 
-	if (pwrpriv->wowlan_wake_reason == AP_WakeUp)
-		rtw_lock_ext_suspend_timeout(8000);
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+	/* rtw_unlock_suspend(); */
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
 
 	pwrpriv->bips_processing = _FALSE;
-	_set_timer(&padapter->mlmepriv.dynamic_chk_timer, 2000);
+	_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
 #ifndef CONFIG_IPS_CHECK_IN_WD
 	rtw_set_pwr_state_check_timer(pwrpriv);
 #endif
-	//clean driver side wake up reason.
+	/* clean driver side wake up reason. */
 	pwrpriv->wowlan_wake_reason = 0;
 
-	// Power On LED
-	rtw_hal_sw_led_init(padapter);
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_RESUME);
+#endif /* CONFIG_BT_COEXIST */
+
+	/* Power On LED */
+#ifdef CONFIG_RTW_SW_LED
+
 	rtw_led_control(padapter, LED_CTL_LINK);
+#endif
 exit:
-	DBG_871X("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
-_func_exit_;
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
 	return ret;
 }
-#endif //#ifdef CONFIG_APWOWLAN
+#endif /* #ifdef CONFIG_APWOWLAN */
+
+void rtw_mi_resume_process_normal(_adapter *padapter)
+{
+	int i;
+	_adapter *iface;
+	struct mlme_priv *pmlmepriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			pmlmepriv = &iface->mlmepriv;
+
+			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+				RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(iface), get_fwstate(pmlmepriv));
+
+				if (rtw_chk_roam_flags(iface, RTW_ROAM_ON_RESUME))
+					rtw_roaming(iface, NULL);
+
+			} else if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
+				RTW_INFO(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(iface), MLME_IS_AP(iface) ? "AP" : "MESH");
+				rtw_ap_restore_network(iface);
+			} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE))
+				RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(iface), get_fwstate(pmlmepriv));
+			else
+				RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(iface), get_fwstate(pmlmepriv));
+		}
+	}
+}
 
 int rtw_resume_process_normal(_adapter *padapter)
 {
 	struct net_device *pnetdev;
-	#ifdef CONFIG_CONCURRENT_MODE
-	struct net_device *pbuddy_netdev;	
-	#endif	
 	struct pwrctrl_priv *pwrpriv;
-	struct mlme_priv *pmlmepriv;
 	struct dvobj_priv *psdpriv;
-	struct debug_priv *pdbgpriv;	
-	
+	struct debug_priv *pdbgpriv;
+
 	int ret = _SUCCESS;
-_func_enter_;
-	
+
 	if (!padapter) {
 		ret = -1;
 		goto exit;
 	}
-	
+
 	pnetdev = padapter->pnetdev;
 	pwrpriv = adapter_to_pwrctl(padapter);
-	pmlmepriv = &padapter->mlmepriv;	
 	psdpriv = padapter->dvobj;
 	pdbgpriv = &psdpriv->drv_dbg;
-	
-	DBG_871X("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
-	// interface init
-	//if (sdio_init(adapter_to_dvobj(padapter)) != _SUCCESS)
-	if((padapter->intf_init)&& (padapter->intf_init(adapter_to_dvobj(padapter)) != _SUCCESS))
-	{
+
+	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
+
+	#ifdef CONFIG_SDIO_HCI
+	/* interface init */
+	if (sdio_init(adapter_to_dvobj(padapter)) != _SUCCESS) {
 		ret = -1;
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("%s: initialize SDIO Failed!!\n", __FUNCTION__));
 		goto exit;
 	}
+	#endif/*CONFIG_SDIO_HCI*/
+
+	rtw_clr_surprise_removed(padapter);
 	rtw_hal_disable_interrupt(padapter);
-	//if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS)
-	if ((padapter->intf_alloc_irq)&&(padapter->intf_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS))
-	{
+
+	#ifdef CONFIG_SDIO_HCI
+	#if !(CONFIG_RTW_SDIO_KEEP_IRQ)
+	if (sdio_alloc_irq(adapter_to_dvobj(padapter)) != _SUCCESS) {
 		ret = -1;
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("%s: sdio_alloc_irq Failed!!\n", __FUNCTION__));
 		goto exit;
 	}
-
-	rtw_reset_drv_sw(padapter);
-	#ifdef CONFIG_CONCURRENT_MODE
-	rtw_reset_drv_sw(padapter->pbuddy_adapter);
 	#endif
-	
+	#endif/*CONFIG_SDIO_HCI*/
+
+	rtw_mi_reset_drv_sw(padapter);
+
 	pwrpriv->bkeepfwalive = _FALSE;
 
-	DBG_871X("bkeepfwalive(%x)\n",pwrpriv->bkeepfwalive);
-	if(pm_netdev_open(pnetdev,_TRUE) != 0) {
+	RTW_INFO("bkeepfwalive(%x)\n", pwrpriv->bkeepfwalive);
+	if (pm_netdev_open(pnetdev, _TRUE) != 0) {
 		ret = -1;
 		pdbgpriv->dbg_resume_error_cnt++;
 		goto exit;
 	}
 
-	netif_device_attach(pnetdev);
-	netif_carrier_on(pnetdev);
-
-	#ifdef CONFIG_CONCURRENT_MODE
-	if(rtw_buddy_adapter_up(padapter)){			
-		pbuddy_netdev = padapter->pbuddy_adapter->pnetdev;				
-		
-		netif_device_attach(pbuddy_netdev);
-		netif_carrier_on(pbuddy_netdev);	
-	}
-	#endif
-	
+	rtw_mi_netif_caron_qstart(padapter);
 
-	if( padapter->pid[1]!=0) {
-		DBG_871X("pid[1]:%d\n",padapter->pid[1]);
+	if (padapter->pid[1] != 0) {
+		RTW_INFO("pid[1]:%d\n", padapter->pid[1]);
 		rtw_signal_process(padapter->pid[1], SIGUSR2);
-	}	
-
-
-	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(pmlmepriv));
-
-		if (rtw_chk_roam_flags(padapter, RTW_ROAM_ON_RESUME))
-			rtw_roaming(padapter, NULL);
-		
-	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_AP_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(pmlmepriv));
-		rtw_ap_restore_network(padapter);
-	} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(pmlmepriv));
-	} else {
-		DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(padapter), get_fwstate(pmlmepriv));
 	}
 
-	#ifdef CONFIG_CONCURRENT_MODE
-	if(rtw_buddy_adapter_up(padapter))
-	{	
-		_adapter *buddy = padapter->pbuddy_adapter;
-		struct mlme_priv *buddy_mlme = &padapter->pbuddy_adapter->mlmepriv;
-		if (check_fwstate(buddy_mlme, WIFI_STATION_STATE)) {
-			DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(buddy), get_fwstate(buddy_mlme));
-
-			if (rtw_chk_roam_flags(buddy, RTW_ROAM_ON_RESUME))
-				rtw_roaming(buddy, NULL);
-		
-		} else if (check_fwstate(buddy_mlme, WIFI_AP_STATE)) {
-			DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_AP_STATE\n", FUNC_ADPT_ARG(buddy), get_fwstate(buddy_mlme));
-			rtw_ap_restore_network(buddy);
-		} else if (check_fwstate(buddy_mlme, WIFI_ADHOC_STATE)) {
-			DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(buddy), get_fwstate(buddy_mlme));
-		} else {
-			DBG_871X(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(buddy), get_fwstate(buddy_mlme));
-		}
-	}
-	#endif
+#ifdef CONFIG_BT_COEXIST
+	rtw_btcoex_SuspendNotify(padapter, BTCOEX_SUSPEND_STATE_RESUME);
+#endif /* CONFIG_BT_COEXIST */
+
+	rtw_mi_resume_process_normal(padapter);
 
 #ifdef CONFIG_RESUME_IN_WORKQUEUE
-	//rtw_unlock_suspend();
-#endif //CONFIG_RESUME_IN_WORKQUEUE
-	DBG_871X("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
+	/* rtw_unlock_suspend(); */
+#endif /* CONFIG_RESUME_IN_WORKQUEUE */
+	RTW_INFO("<== "FUNC_ADPT_FMT" exit....\n", FUNC_ADPT_ARG(padapter));
 
-exit:	
-_func_exit_;
-	return ret;	
+exit:
+	return ret;
 }
 
 int rtw_resume_common(_adapter *padapter)
 {
 	int ret = 0;
-	u32 start_time = rtw_get_current_time();
+	systime start_time = rtw_get_current_time();
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	
-	_func_enter_;
+
 
 	if (pwrpriv->bInSuspend == _FALSE)
 		return 0;
 
-	DBG_871X_LEVEL(_drv_always_, "resume start\n");
-	DBG_871X("==> %s (%s:%d)\n",__FUNCTION__, current->comm, current->pid);	
+	RTW_PRINT("resume start\n");
+	RTW_INFO("==> %s (%s:%d)\n", __FUNCTION__, current->comm, current->pid);
 
-	if (check_fwstate(pmlmepriv,WIFI_STATION_STATE) == _TRUE
-#ifdef CONFIG_CONCURRENT_MODE
-		&& check_buddy_fwstate(padapter, WIFI_AP_STATE) == _FALSE
-#endif
-	) {
-	#ifdef CONFIG_WOWLAN
+	if (rtw_mi_check_status(padapter, WIFI_AP_STATE) == _FALSE) {
+#ifdef CONFIG_WOWLAN
 		if (pwrpriv->wowlan_mode == _TRUE)
 			rtw_resume_process_wow(padapter);
 		else
+#endif
 			rtw_resume_process_normal(padapter);
-	#else
-		rtw_resume_process_normal(padapter);
-	#endif
 
-	} else if (check_fwstate(pmlmepriv,WIFI_AP_STATE) == _TRUE
-#ifdef CONFIG_CONCURRENT_MODE
-		&& check_buddy_fwstate(padapter, WIFI_AP_STATE) == _FALSE
-#endif
-	) {
-	#ifdef CONFIG_AP_WOWLAN
-		rtw_resume_process_ap_wow(padapter);
-	#else
-		rtw_resume_process_normal(padapter);
-	#endif //CONFIG_AP_WOWLAN
-#ifdef CONFIG_CONCURRENT_MODE
-	} else if (check_fwstate(pmlmepriv,WIFI_STATION_STATE) == _TRUE
-		&& check_buddy_fwstate(padapter, WIFI_AP_STATE) == _TRUE) {
-	#ifdef CONFIG_AP_WOWLAN
+	} else if (rtw_mi_check_status(padapter, WIFI_AP_STATE)) {
+#ifdef CONFIG_AP_WOWLAN
 		rtw_resume_process_ap_wow(padapter);
-	#else
-		rtw_resume_process_normal(padapter);
-	#endif //CONFIG_AP_WOWLAN
-#endif
-	} else {
+#else
 		rtw_resume_process_normal(padapter);
+#endif /* CONFIG_AP_WOWLAN */
 	}
 
-	#ifdef CONFIG_BT_COEXIST
-	rtw_btcoex_SuspendNotify(padapter, 0);
-	#endif // CONFIG_BT_COEXIST
-
 	if (pwrpriv) {
 		pwrpriv->bInSuspend = _FALSE;
-	#ifdef CONFIG_PNO_SUPPORT
-		pwrpriv->pno_in_resume = _FALSE;
-	#endif
+		pwrpriv->wowlan_in_resume = _FALSE;
 	}
-	DBG_871X_LEVEL(_drv_always_, "%s:%d in %d ms\n", __FUNCTION__ ,ret,
-		rtw_get_passing_time_ms(start_time));
+	RTW_PRINT("%s:%d in %d ms\n", __FUNCTION__ , ret,
+		  rtw_get_passing_time_ms(start_time));
+
 
-	_func_exit_;
-	
 	return ret;
 }
 
@@ -4531,29 +4825,48 @@ int  rtw_set_gpio_output_value(struct net_device *netdev, u8 gpio_num, bool isHi
 	u8 direction = 0;
 	u8 res = -1;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
-	return rtw_hal_set_gpio_output_value(adapter, gpio_num,isHigh);
+	return rtw_hal_set_gpio_output_value(adapter, gpio_num, isHigh);
 }
 EXPORT_SYMBOL(rtw_set_gpio_output_value);
 
 int rtw_config_gpio(struct net_device *netdev, u8 gpio_num, bool isOutput)
 {
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);	
-	return rtw_hal_config_gpio(adapter,gpio_num,isOutput);	
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
+	return rtw_hal_config_gpio(adapter, gpio_num, isOutput);
 }
 EXPORT_SYMBOL(rtw_config_gpio);
 int rtw_register_gpio_interrupt(struct net_device *netdev, int gpio_num, void(*callback)(u8 level))
 {
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
-	return rtw_hal_register_gpio_interrupt(adapter,gpio_num,callback);
+	return rtw_hal_register_gpio_interrupt(adapter, gpio_num, callback);
 }
 EXPORT_SYMBOL(rtw_register_gpio_interrupt);
 
 int rtw_disable_gpio_interrupt(struct net_device *netdev, int gpio_num)
 {
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(netdev);
-	return rtw_hal_disable_gpio_interrupt(adapter,gpio_num);
+	return rtw_hal_disable_gpio_interrupt(adapter, gpio_num);
 }
 EXPORT_SYMBOL(rtw_disable_gpio_interrupt);
 
-#endif //#ifdef CONFIG_GPIO_API 
+#endif /* #ifdef CONFIG_GPIO_API */
 
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+
+int rtw_vendor_ie_get_api(struct net_device *dev, int ie_num, char *extra,
+		u16 extra_len)
+{
+	int ret = 0;
+
+	ret = rtw_vendor_ie_get_raw_data(dev, ie_num, extra, extra_len);
+	return ret;
+}
+EXPORT_SYMBOL(rtw_vendor_ie_get_api);
+
+int rtw_vendor_ie_set_api(struct net_device *dev, char *extra)
+{
+	return rtw_vendor_ie_set(dev, NULL, NULL, extra);
+}
+EXPORT_SYMBOL(rtw_vendor_ie_set_api);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/recv_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/recv_linux.c
index e37f01483205..f09f9dfbebde 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/recv_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/recv_linux.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,108 +12,146 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _RECV_OSDEP_C_
 
 #include <drv_types.h>
 
+int rtw_os_recvframe_duplicate_skb(_adapter *padapter, union recv_frame *pcloneframe, _pkt *pskb)
+{
+	int res = _SUCCESS;
+	_pkt	*pkt_copy = NULL;
+	struct rx_pkt_attrib *pattrib = &pcloneframe->u.hdr.attrib;
+
+	if (pskb == NULL) {
+		RTW_INFO("%s [WARN] skb == NULL, drop frag frame\n", __func__);
+		return _FAIL;
+	}
+#if 1
+	pkt_copy = rtw_skb_copy(pskb);
+
+	if (pkt_copy == NULL) {
+		RTW_INFO("%s [WARN] rtw_skb_copy fail , drop frag frame\n", __func__);
+		return _FAIL;
+	}
+#else
+	pkt_copy = rtw_skb_clone(pskb);
+
+	if (pkt_copy == NULL) {
+		RTW_INFO("%s [WARN] rtw_skb_clone fail , drop frag frame\n", __func__);
+		return _FAIL;
+	}
+#endif
+	pkt_copy->dev = padapter->pnetdev;
+
+	pcloneframe->u.hdr.pkt = pkt_copy;
+	pcloneframe->u.hdr.rx_head = pkt_copy->head;
+	pcloneframe->u.hdr.rx_data = pkt_copy->data;
+	pcloneframe->u.hdr.rx_end = skb_end_pointer(pkt_copy);
+	pcloneframe->u.hdr.rx_tail = skb_tail_pointer(pkt_copy);
+	pcloneframe->u.hdr.len = pkt_copy->len;
+
+	return res;
+}
+
 int rtw_os_alloc_recvframe(_adapter *padapter, union recv_frame *precvframe, u8 *pdata, _pkt *pskb)
 {
 	int res = _SUCCESS;
 	u8	shift_sz = 0;
 	u32	skb_len, alloc_sz;
-	_pkt	 *pkt_copy = NULL;	
+	_pkt	*pkt_copy = NULL;
 	struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
 
 
-	if(pdata == NULL)
-	{		
+	if (pdata == NULL) {
 		precvframe->u.hdr.pkt = NULL;
 		res = _FAIL;
 		return res;
-	}	
+	}
 
 
-	//	Modified by Albert 20101213
-	//	For 8 bytes IP header alignment.
-	shift_sz = pattrib->qos ? 6:0;//	Qos data, wireless lan header length is 26
+	/*	Modified by Albert 20101213 */
+	/*	For 8 bytes IP header alignment. */
+	shift_sz = pattrib->qos ? 6 : 0; /*	Qos data, wireless lan header length is 26 */
 
 	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.
-		alloc_sz = (skb_len <= 1650) ? 1664:(skb_len + 14);		
-	}
-	else 
-	{
+	/* 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. */
+		alloc_sz = (skb_len <= 1650) ? 1664 : (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.
+		/*	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 = rtw_skb_alloc(alloc_sz);
 
-	if(pkt_copy)
-	{
+	if (pkt_copy) {
 		pkt_copy->dev = padapter->pnetdev;
+		pkt_copy->len = skb_len;
 		precvframe->u.hdr.pkt = pkt_copy;
-		precvframe->u.hdr.rx_head = pkt_copy->data;
+		precvframe->u.hdr.rx_head = pkt_copy->head;
 		precvframe->u.hdr.rx_end = pkt_copy->data + alloc_sz;
-		skb_reserve(pkt_copy, 8 - ((SIZE_PTR)( pkt_copy->data) & 7 ));//force pkt_copy->data at 8-byte alignment address
-		skb_reserve(pkt_copy, shift_sz);//force ip_hdr at 8-byte alignment address according to shift_sz.
+		skb_reserve(pkt_copy, 8 - ((SIZE_PTR)(pkt_copy->data) & 7));  /* force pkt_copy->data at 8-byte alignment address */
+		skb_reserve(pkt_copy, shift_sz);/* force ip_hdr at 8-byte alignment address according to shift_sz. */
 		_rtw_memcpy(pkt_copy->data, pdata, skb_len);
 		precvframe->u.hdr.rx_data = precvframe->u.hdr.rx_tail = pkt_copy->data;
-	}
-	else
-	{
+	} else {
+#if 0
+		{
+			rtw_free_recvframe(precvframe_if2, &precvpriv->free_recv_queue);
+			rtw_enqueue_recvbuf_to_head(precvbuf, &precvpriv->recv_buf_pending_queue);
+
+			/* The case of can't allocate skb is serious and may never be recovered,
+			 once bDriverStopped is enable, this task should be stopped.*/
+			if (!rtw_is_drv_stopped(secondary_padapter))
+#ifdef PLATFORM_LINUX
+				tasklet_schedule(&precvpriv->recv_tasklet);
+#endif
+			return ret;
+		}
+
+#endif
+
 #ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
-		DBG_871X("%s:can not allocate memory for skb copy\n", __FUNCTION__);
+		RTW_INFO("%s:can not allocate memory for skb copy\n", __func__);
 
 		precvframe->u.hdr.pkt = NULL;
 
-		//rtw_free_recvframe(precvframe, pfree_recv_queue);
-		//goto _exit_recvbuf2recvframe;
+		/* rtw_free_recvframe(precvframe, pfree_recv_queue); */
+		/*exit_rtw_os_recv_resource_alloc;*/
 
-		res = _FAIL;	
+		res = _FAIL;
 #else
-		if((pattrib->mfrag == 1)&&(pattrib->frag_num == 0))
-		{				
-			DBG_871X("%s: alloc_skb fail , drop frag frame \n", __FUNCTION__);
-			//rtw_free_recvframe(precvframe, pfree_recv_queue);
+		if ((pattrib->mfrag == 1) && (pattrib->frag_num == 0)) {
+			RTW_INFO("%s: alloc_skb fail , drop frag frame\n", __FUNCTION__);
+			/* rtw_free_recvframe(precvframe, pfree_recv_queue); */
 			res = _FAIL;
 			goto exit_rtw_os_recv_resource_alloc;
 		}
 
-		if(pskb == NULL)
-		{
+		if (pskb == NULL) {
 			res = _FAIL;
 			goto exit_rtw_os_recv_resource_alloc;
 		}
-			
+
 		precvframe->u.hdr.pkt = rtw_skb_clone(pskb);
-		if(precvframe->u.hdr.pkt)
-		{
+		if (precvframe->u.hdr.pkt) {
+			precvframe->u.hdr.pkt->dev = padapter->pnetdev;
 			precvframe->u.hdr.rx_head = precvframe->u.hdr.rx_data = precvframe->u.hdr.rx_tail = pdata;
 			precvframe->u.hdr.rx_end =  pdata + alloc_sz;
-		}
-		else
-		{
-			DBG_871X("%s: rtw_skb_clone fail\n", __FUNCTION__);
-			//rtw_free_recvframe(precvframe, pfree_recv_queue);
-			//goto _exit_recvbuf2recvframe;
+		} else {
+			RTW_INFO("%s: rtw_skb_clone fail\n", __FUNCTION__);
+			/* rtw_free_recvframe(precvframe, pfree_recv_queue); */
+			/*exit_rtw_os_recv_resource_alloc;*/
 			res = _FAIL;
 		}
-#endif			
-	}		
+#endif
+	}
 
 exit_rtw_os_recv_resource_alloc:
 
@@ -122,54 +161,59 @@ exit_rtw_os_recv_resource_alloc:
 
 void rtw_os_free_recvframe(union recv_frame *precvframe)
 {
-	if(precvframe->u.hdr.pkt)
-	{
-		rtw_skb_free(precvframe->u.hdr.pkt);//free skb by driver
-
+	if (precvframe->u.hdr.pkt) {
+		rtw_os_pkt_free(precvframe->u.hdr.pkt);
 		precvframe->u.hdr.pkt = NULL;
 	}
 }
 
-//init os related resource in struct recv_priv
+/* init os related resource in struct recv_priv */
 int rtw_os_recv_resource_init(struct recv_priv *precvpriv, _adapter *padapter)
 {
-	int	res=_SUCCESS;
+	int	res = _SUCCESS;
+
+
+#ifdef CONFIG_RTW_NAPI
+	skb_queue_head_init(&precvpriv->rx_napi_skb_queue);
+#endif /* CONFIG_RTW_NAPI */
 
 	return res;
 }
 
-//alloc os related resource in union recv_frame
+/* alloc os related resource in union recv_frame */
 int rtw_os_recv_resource_alloc(_adapter *padapter, union recv_frame *precvframe)
 {
-	int	res=_SUCCESS;
-	
-	precvframe->u.hdr.pkt_newalloc = precvframe->u.hdr.pkt = NULL;
+	int	res = _SUCCESS;
+
+	precvframe->u.hdr.pkt = NULL;
 
 	return res;
 }
 
-//free os related resource in union recv_frame
+/* free os related resource in union recv_frame */
 void rtw_os_recv_resource_free(struct recv_priv *precvpriv)
 {
 	sint i;
 	union recv_frame *precvframe;
-	precvframe = (union recv_frame*) precvpriv->precv_frame_buf;
+	precvframe = (union recv_frame *) precvpriv->precv_frame_buf;
 
-	for(i=0; i < NR_RECVFRAME; i++)
-	{
-		if(precvframe->u.hdr.pkt)
-		{
-			rtw_skb_free(precvframe->u.hdr.pkt);//free skb by driver
-			precvframe->u.hdr.pkt = NULL;
-		}
+
+#ifdef CONFIG_RTW_NAPI
+	if (skb_queue_len(&precvpriv->rx_napi_skb_queue))
+		RTW_WARN("rx_napi_skb_queue not empty\n");
+	rtw_skb_queue_purge(&precvpriv->rx_napi_skb_queue);
+#endif /* CONFIG_RTW_NAPI */
+
+	for (i = 0; i < NR_RECVFRAME; i++) {
+		rtw_os_free_recvframe(precvframe);
 		precvframe++;
 	}
 }
 
-//alloc os related resource in struct recv_buf
+/* alloc os related resource in struct recv_buf */
 int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf)
 {
-	int res=_SUCCESS;
+	int res = _SUCCESS;
 
 #ifdef CONFIG_USB_HCI
 	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
@@ -177,9 +221,8 @@ int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf)
 
 	precvbuf->irp_pending = _FALSE;
 	precvbuf->purb = usb_alloc_urb(0, GFP_KERNEL);
-	if(precvbuf->purb == NULL){
+	if (precvbuf->purb == NULL)
 		res = _FAIL;
-	}
 
 	precvbuf->pskb = NULL;
 
@@ -191,19 +234,19 @@ int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf)
 
 	precvbuf->len = 0;
 
-	#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
 	precvbuf->pallocated_buf = rtw_usb_buffer_alloc(pusbd, (size_t)precvbuf->alloc_sz, &precvbuf->dma_transfer_addr);
 	precvbuf->pbuf = precvbuf->pallocated_buf;
-	if(precvbuf->pallocated_buf == NULL)
+	if (precvbuf->pallocated_buf == NULL)
 		return _FAIL;
-	#endif //CONFIG_USE_USB_BUFFER_ALLOC_RX
-	
-#endif //CONFIG_USB_HCI
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
+
+#endif /* CONFIG_USB_HCI */
 
 	return res;
 }
 
-//free os related resource in struct recv_buf
+/* free os related resource in struct recv_buf */
 int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf)
 {
 	int ret = _SUCCESS;
@@ -219,29 +262,27 @@ int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf)
 	precvbuf->pallocated_buf =  NULL;
 	precvbuf->dma_transfer_addr = 0;
 
-#endif //CONFIG_USE_USB_BUFFER_ALLOC_RX
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
 
-	if(precvbuf->purb)
-	{
-		//usb_kill_urb(precvbuf->purb);
+	if (precvbuf->purb) {
+		/* usb_kill_urb(precvbuf->purb); */
 		usb_free_urb(precvbuf->purb);
 	}
 
-#endif //CONFIG_USB_HCI
+#endif /* CONFIG_USB_HCI */
 
 
-	if(precvbuf->pskb)
-	{
+	if (precvbuf->pskb) {
 #ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
-		if(rtw_free_skb_premem(precvbuf->pskb)!=0)
+		if (rtw_free_skb_premem(precvbuf->pskb) != 0)
 #endif
-		rtw_skb_free(precvbuf->pskb);
+			rtw_skb_free(precvbuf->pskb);
 	}
 	return ret;
 
 }
 
-_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8 *pdata)
+_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, const u8 *da, const u8 *sa, u8 *msdu ,u16 msdu_len)
 {
 	u16	eth_type;
 	u8	*data_ptr;
@@ -251,60 +292,132 @@ _pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8
 	pattrib = &prframe->u.hdr.attrib;
 
 #ifdef CONFIG_SKB_COPY
-	sub_skb = rtw_skb_alloc(nSubframe_Length + 12);
-	if(sub_skb)
-	{
-		skb_reserve(sub_skb, 12);
-		data_ptr = (u8 *)skb_put(sub_skb, nSubframe_Length);
-		_rtw_memcpy(data_ptr, (pdata + ETH_HLEN), nSubframe_Length);
-	}
-	else
-#endif // CONFIG_SKB_COPY
+	sub_skb = rtw_skb_alloc(msdu_len + 14);
+	if (sub_skb) {
+		skb_reserve(sub_skb, 14);
+		data_ptr = (u8 *)skb_put(sub_skb, msdu_len);
+		_rtw_memcpy(data_ptr, msdu, msdu_len);
+	} else
+#endif /* CONFIG_SKB_COPY */
 	{
 		sub_skb = rtw_skb_clone(prframe->u.hdr.pkt);
-		if(sub_skb)
-		{
-			sub_skb->data = pdata + ETH_HLEN;
-			sub_skb->len = nSubframe_Length;
-			skb_set_tail_pointer(sub_skb, nSubframe_Length);
-		}
-		else
-		{
-			DBG_871X("%s(): rtw_skb_clone() Fail!!!\n",__FUNCTION__);
+		if (sub_skb) {
+			sub_skb->data = msdu;
+			sub_skb->len = msdu_len;
+			skb_set_tail_pointer(sub_skb, msdu_len);
+		} else {
+			RTW_INFO("%s(): rtw_skb_clone() Fail!!!\n", __FUNCTION__);
 			return NULL;
 		}
 	}
 
 	eth_type = RTW_GET_BE16(&sub_skb->data[6]);
 
-	if (sub_skb->len >= 8 &&
-		((_rtw_memcmp(sub_skb->data, rtw_rfc1042_header, SNAP_SIZE) &&
-		  eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) ||
-		 _rtw_memcmp(sub_skb->data, rtw_bridge_tunnel_header, SNAP_SIZE) )) {
+	if (sub_skb->len >= 8
+		&& ((_rtw_memcmp(sub_skb->data, rtw_rfc1042_header, SNAP_SIZE)
+				&& eth_type != ETH_P_AARP && eth_type != ETH_P_IPX)
+			|| _rtw_memcmp(sub_skb->data, rtw_bridge_tunnel_header, SNAP_SIZE))
+	) {
 		/* remove RFC1042 or Bridge-Tunnel encapsulation and replace EtherType */
 		skb_pull(sub_skb, SNAP_SIZE);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pattrib->src, ETH_ALEN);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pattrib->dst, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), sa, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), da, ETH_ALEN);
 	} else {
-		u16 len;
 		/* Leave Ethernet header part of hdr and full payload */
+		u16 len;
+
 		len = htons(sub_skb->len);
 		_rtw_memcpy(skb_push(sub_skb, 2), &len, 2);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pattrib->src, ETH_ALEN);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pattrib->dst, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), sa, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), da, ETH_ALEN);
 	}
 
 	return sub_skb;
 }
 
-#ifdef DBG_UDP_PKT_LOSE_11AC
-#define PAYLOAD_LEN_LOC_OF_IP_HDR 0x10 /*ethernet payload length location of ip header (DA+SA+eth_type+(version&hdr_len)) */	
-#endif
+#ifdef CONFIG_RTW_NAPI
+static int napi_recv(_adapter *padapter, int budget)
+{
+	_pkt *pskb;
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	int work_done = 0;
+	struct registry_priv *pregistrypriv = &padapter->registrypriv;
+	u8 rx_ok;
+
+
+	while ((work_done < budget) &&
+	       (!skb_queue_empty(&precvpriv->rx_napi_skb_queue))) {
+		pskb = skb_dequeue(&precvpriv->rx_napi_skb_queue);
+		if (!pskb)
+			break;
 
-void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, struct rx_pkt_attrib *pattrib)
+		rx_ok = _FALSE;
+
+#ifdef CONFIG_RTW_GRO
+		if (pregistrypriv->en_gro) {
+			if (rtw_napi_gro_receive(&padapter->napi, pskb) != GRO_DROP)
+				rx_ok = _TRUE;
+			goto next;
+		}
+#endif /* CONFIG_RTW_GRO */
+
+		if (rtw_netif_receive_skb(padapter->pnetdev, pskb) == NET_RX_SUCCESS)
+			rx_ok = _TRUE;
+
+next:
+		if (rx_ok == _TRUE) {
+			work_done++;
+			DBG_COUNTER(padapter->rx_logs.os_netif_ok);
+		} else {
+			DBG_COUNTER(padapter->rx_logs.os_netif_err);
+		}
+	}
+
+	return work_done;
+}
+
+int rtw_recv_napi_poll(struct napi_struct *napi, int budget)
 {
-	struct mlme_priv*pmlmepriv = &padapter->mlmepriv;
+	_adapter *padapter = container_of(napi, _adapter, napi);
+	int work_done = 0;
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+
+
+	work_done = napi_recv(padapter, budget);
+	if (work_done < budget) {
+		napi_complete(napi);
+		if (!skb_queue_empty(&precvpriv->rx_napi_skb_queue))
+			napi_schedule(napi);
+	}
+
+	return work_done;
+}
+
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+void dynamic_napi_th_chk (_adapter *adapter)
+{
+
+	if (adapter->registrypriv.en_napi) {
+		struct dvobj_priv *dvobj;
+		struct registry_priv *registry;
+	
+		dvobj = adapter_to_dvobj(adapter);
+		registry = &adapter->registrypriv;
+		if (dvobj->traffic_stat.cur_rx_tp > registry->napi_threshold)
+			dvobj->en_napi_dynamic = 1;
+		else
+			dvobj->en_napi_dynamic = 0;
+	}
+
+}
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#endif /* CONFIG_RTW_NAPI */
+
+void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, union recv_frame *rframe)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
 #ifdef CONFIG_BR_EXT
 	void *br_port = NULL;
 #endif
@@ -312,42 +425,41 @@ void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, struct rx_pkt_attri
 
 	/* Indicat the packets to upper layer */
 	if (pkt) {
-		if(check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
-		{
-		 	_pkt *pskb2=NULL;
-		 	struct sta_info *psta = NULL;
-		 	struct sta_priv *pstapriv = &padapter->stapriv;
-			int bmcast = IS_MCAST(pattrib->dst);
+		struct ethhdr *ehdr = (struct ethhdr *)pkt->data;
+
+		DBG_COUNTER(padapter->rx_logs.os_indicate);
 
-			//DBG_871X("bmcast=%d\n", bmcast);
+		if (MLME_IS_AP(padapter)) {
+			_pkt *pskb2 = NULL;
+			struct sta_info *psta = NULL;
+			struct sta_priv *pstapriv = &padapter->stapriv;
+			int bmcast = IS_MCAST(ehdr->h_dest);
 
-			if (_rtw_memcmp(pattrib->dst, adapter_mac_addr(padapter), ETH_ALEN) == _FALSE)
-			{
-				//DBG_871X("not ap psta=%p, addr=%pM\n", psta, pattrib->dst);
+			/* RTW_INFO("bmcast=%d\n", bmcast); */
 
-				if(bmcast)
-				{
+			if (_rtw_memcmp(ehdr->h_dest, adapter_mac_addr(padapter), ETH_ALEN) == _FALSE) {
+				/* RTW_INFO("not ap psta=%p, addr=%pM\n", psta, ehdr->h_dest); */
+
+				if (bmcast) {
 					psta = rtw_get_bcmc_stainfo(padapter);
 					pskb2 = rtw_skb_clone(pkt);
-				} else {
-					psta = rtw_get_stainfo(pstapriv, pattrib->dst);
-				}
+				} else
+					psta = rtw_get_stainfo(pstapriv, ehdr->h_dest);
 
-				if(psta)
-				{
-					struct net_device *pnetdev= (struct net_device*)padapter->pnetdev;			
+				if (psta) {
+					struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
 
-					//DBG_871X("directly forwarding to the rtw_xmit_entry\n");
+					/* RTW_INFO("directly forwarding to the rtw_xmit_entry\n"); */
 
-					//skb->ip_summed = CHECKSUM_NONE;
-					pkt->dev = pnetdev;				
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+					/* skb->ip_summed = CHECKSUM_NONE; */
+					pkt->dev = pnetdev;
+					#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 					skb_set_queue_mapping(pkt, rtw_recv_select_queue(pkt));
-#endif //LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35)
+					#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35) */
 
 					_rtw_xmit_entry(pkt, pnetdev);
 
-					if(bmcast && (pskb2 != NULL) ) {
+					if (bmcast && (pskb2 != NULL)) {
 						pkt = pskb2;
 						DBG_COUNTER(padapter->rx_logs.os_indicate_ap_mcast);
 					} else {
@@ -355,73 +467,67 @@ void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, struct rx_pkt_attri
 						return;
 					}
 				}
-			}
-			else// to APself
-			{
-				//DBG_871X("to APSelf\n");
+			} else { /* to APself */
+				/* RTW_INFO("to APSelf\n"); */
 				DBG_COUNTER(padapter->rx_logs.os_indicate_ap_self);
 			}
 		}
-		
-#ifdef CONFIG_BR_EXT
-		// Insert NAT2.5 RX here!
-#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-		br_port = padapter->pnetdev->br_port;
-#else   // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-		rcu_read_lock();
-		br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
-		rcu_read_unlock();
-#endif  // (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-
 
-		if( br_port && (check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE) )
-		{
-			int nat25_handle_frame(_adapter *priv, struct sk_buff *skb);
-			if (nat25_handle_frame(padapter, pkt) == -1) {
-				//priv->ext_stats.rx_data_drops++;
-				//DEBUG_ERR("RX DROP: nat25_handle_frame fail!\n");
-				//return FAIL;
-				
-#if 1
-				// bypass this frame to upper layer!!
-#else
-				rtw_skb_free(sub_skb);
-				continue;
-#endif
-			}							
-		}
-#endif	// CONFIG_BR_EXT
-		if( precvpriv->sink_udpport > 0)
-			rtw_sink_rtp_seq_dbg(padapter,pkt);
-#ifdef DBG_UDP_PKT_LOSE_11AC
-		/* After eth_type_trans process , pkt->data pointer will move from ethrnet header to ip header ,  
-		*	we have to check ethernet type , so this debug must be print before eth_type_trans
-		*/
-		if (*((unsigned short *)(pkt->data+ETH_ALEN*2)) == htons(ETH_P_ARP)) {
-			/* ARP Payload length will be 42bytes or 42+18(tailer)=60bytes*/
-			if (pkt->len != 42 && pkt->len != 60) 
-				DBG_871X("Error !!%s,ARP Payload length %u not correct\n" , __func__ , pkt->len);
-		} else if (*((unsigned short *)(pkt->data+ETH_ALEN*2)) == htons(ETH_P_IP)) { 
-			if (be16_to_cpu(*((u16 *)(pkt->data+PAYLOAD_LEN_LOC_OF_IP_HDR))) != (pkt->len)-ETH_HLEN) {
-				DBG_871X("Error !!%s,Payload length not correct\n" , __func__);
-				DBG_871X("%s, IP header describe Total length=%u\n" , __func__ , be16_to_cpu(*((u16 *)(pkt->data+PAYLOAD_LEN_LOC_OF_IP_HDR))));
-				DBG_871X("%s, Pkt real length=%u\n" , __func__ , (pkt->len)-ETH_HLEN);
-			} 
+#ifdef CONFIG_BR_EXT
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE) {
+			/* Insert NAT2.5 RX here! */
+			#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+			br_port = padapter->pnetdev->br_port;
+			#else
+			rcu_read_lock();
+			br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
+			rcu_read_unlock();
+			#endif
+
+			if (br_port) {
+				int nat25_handle_frame(_adapter *priv, struct sk_buff *skb);
+
+				if (nat25_handle_frame(padapter, pkt) == -1) {
+					/* priv->ext_stats.rx_data_drops++; */
+					/* DEBUG_ERR("RX DROP: nat25_handle_frame fail!\n"); */
+					/* return FAIL; */
+
+					#if 1
+					/* bypass this frame to upper layer!! */
+					#else
+					rtw_skb_free(sub_skb);
+					continue;
+					#endif
+				}
+			}
 		}
-#endif
+#endif /* CONFIG_BR_EXT */
+
 		/* After eth_type_trans process , pkt->data pointer will move from ethrnet header to ip header */
 		pkt->protocol = eth_type_trans(pkt, padapter->pnetdev);
 		pkt->dev = padapter->pnetdev;
+		pkt->ip_summed = CHECKSUM_NONE; /* CONFIG_TCP_CSUM_OFFLOAD_RX */
+
+#ifdef CONFIG_RTW_NAPI
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+		if (!skb_queue_empty(&precvpriv->rx_napi_skb_queue)
+			&& !adapter_to_dvobj(padapter)->en_napi_dynamic			
+			)
+			napi_recv(padapter, RTL_NAPI_WEIGHT);
+#endif
 
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_RX
-		if ( (pattrib->tcpchk_valid == 1) && (pattrib->tcp_chkrpt == 1) ) {
-			pkt->ip_summed = CHECKSUM_UNNECESSARY;
-		} else {
-			pkt->ip_summed = CHECKSUM_NONE;
+		if (pregistrypriv->en_napi
+			#ifdef CONFIG_RTW_NAPI_DYNAMIC
+			&& adapter_to_dvobj(padapter)->en_napi_dynamic
+			#endif
+		) {
+			skb_queue_tail(&precvpriv->rx_napi_skb_queue, pkt);
+			#ifndef CONFIG_RTW_NAPI_V2
+			napi_schedule(&padapter->napi);
+			#endif
+			return;
 		}
-#else /* !CONFIG_TCP_CSUM_OFFLOAD_RX */
-		pkt->ip_summed = CHECKSUM_NONE;
-#endif //CONFIG_TCP_CSUM_OFFLOAD_RX
+#endif /* CONFIG_RTW_NAPI */
 
 		ret = rtw_netif_rx(padapter->pnetdev, pkt);
 		if (ret == NET_RX_SUCCESS)
@@ -438,72 +544,56 @@ void rtw_handle_tkip_mic_err(_adapter *padapter, struct sta_info *sta, u8 bgroup
 #endif
 	union iwreq_data wrqu;
 	struct iw_michaelmicfailure    ev;
-	struct mlme_priv*              pmlmepriv  = &padapter->mlmepriv;
-	struct security_priv	*psecuritypriv = &padapter->securitypriv;	
-	u32 cur_time = 0;
+	struct mlme_priv              *pmlmepriv  = &padapter->mlmepriv;
+	struct security_priv	*psecuritypriv = &padapter->securitypriv;
+	systime cur_time = 0;
 
-	if( psecuritypriv->last_mic_err_time == 0 )
-	{
+	if (psecuritypriv->last_mic_err_time == 0)
 		psecuritypriv->last_mic_err_time = rtw_get_current_time();
-	}
-	else
-	{
+	else {
 		cur_time = rtw_get_current_time();
 
-		if( cur_time - psecuritypriv->last_mic_err_time < 60*HZ )
-		{
+		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
-		{
+		} else
 			psecuritypriv->last_mic_err_time = rtw_get_current_time();
-		}
 	}
 
 #ifdef CONFIG_IOCTL_CFG80211
-	if ( bgroup )
-	{
+	if (bgroup)
 		key_type |= NL80211_KEYTYPE_GROUP;
-	}
 	else
-	{
 		key_type |= NL80211_KEYTYPE_PAIRWISE;
-	}
 
-	cfg80211_michael_mic_failure(padapter->pnetdev, sta->hwaddr, key_type, -1, NULL, GFP_ATOMIC);
+	cfg80211_michael_mic_failure(padapter->pnetdev, sta->cmn.mac_addr, key_type, -1, NULL, GFP_ATOMIC);
 #endif
 
-	_rtw_memset( &ev, 0x00, sizeof( ev ) );
-	if ( bgroup )
-	{
-	    ev.flags |= IW_MICFAILURE_GROUP;
-	}
+	_rtw_memset(&ev, 0x00, sizeof(ev));
+	if (bgroup)
+		ev.flags |= IW_MICFAILURE_GROUP;
 	else
-	{
-	    ev.flags |= IW_MICFAILURE_PAIRWISE;
-	}
+		ev.flags |= IW_MICFAILURE_PAIRWISE;
 
 	ev.src_addr.sa_family = ARPHRD_ETHER;
-	_rtw_memcpy(ev.src_addr.sa_data, sta->hwaddr, ETH_ALEN);
+	_rtw_memcpy(ev.src_addr.sa_data, sta->cmn.mac_addr, ETH_ALEN);
 
-	_rtw_memset( &wrqu, 0x00, sizeof( wrqu ) );
-	wrqu.data.length = sizeof( ev );
+	_rtw_memset(&wrqu, 0x00, sizeof(wrqu));
+	wrqu.data.length = sizeof(ev);
 
 #ifndef CONFIG_IOCTL_CFG80211
-	wireless_send_event( padapter->pnetdev, IWEVMICHAELMICFAILURE, &wrqu, (char*) &ev );
+	wireless_send_event(padapter->pnetdev, IWEVMICHAELMICFAILURE, &wrqu, (char *) &ev);
 #endif
 }
 
+#ifdef CONFIG_HOSTAPD_MLME
 void rtw_hostapd_mlme_rx(_adapter *padapter, union recv_frame *precv_frame)
 {
-#ifdef CONFIG_HOSTAPD_MLME
 	_pkt *skb;
 	struct hostapd_priv *phostapdpriv  = padapter->phostapdpriv;
 	struct net_device *pmgnt_netdev = phostapdpriv->pmgnt_netdev;
 
-	RT_TRACE(_module_recv_osdep_c_, _drv_info_, ("+rtw_hostapd_mlme_rx\n"));
 
 	skb = precv_frame->u.hdr.pkt;
 
@@ -514,74 +604,28 @@ void rtw_hostapd_mlme_rx(_adapter *padapter, union recv_frame *precv_frame)
 	skb->tail = precv_frame->u.hdr.rx_tail;
 	skb->len = precv_frame->u.hdr.len;
 
-	//pskb_copy = rtw_skb_copy(skb);
-//	if(skb == NULL) goto _exit;
+	/* pskb_copy = rtw_skb_copy(skb);
+	*	if(skb == NULL) goto _exit; */
 
 	skb->dev = pmgnt_netdev;
 	skb->ip_summed = CHECKSUM_NONE;
 	skb->pkt_type = PACKET_OTHERHOST;
-	//skb->protocol = __constant_htons(0x0019); /*ETH_P_80211_RAW*/
+	/* skb->protocol = __constant_htons(0x0019); ETH_P_80211_RAW */
 	skb->protocol = __constant_htons(0x0003); /*ETH_P_80211_RAW*/
 
-	//DBG_871X("(1)data=0x%x, head=0x%x, tail=0x%x, mac_header=0x%x, len=%d\n", skb->data, skb->head, skb->tail, skb->mac_header, skb->len);
+	/* RTW_INFO("(1)data=0x%x, head=0x%x, tail=0x%x, mac_header=0x%x, len=%d\n", skb->data, skb->head, skb->tail, skb->mac_header, skb->len); */
 
-	//skb->mac.raw = skb->data;
+	/* skb->mac.raw = skb->data; */
 	skb_reset_mac_header(skb);
 
-       //skb_pull(skb, 24);
-       _rtw_memset(skb->cb, 0, sizeof(skb->cb));
+	/* skb_pull(skb, 24); */
+	_rtw_memset(skb->cb, 0, sizeof(skb->cb));
 
 	rtw_netif_rx(pmgnt_netdev, skb);
 
-	precv_frame->u.hdr.pkt = NULL; // set pointer to NULL before rtw_free_recvframe() if call rtw_netif_rx()
-#endif
+	precv_frame->u.hdr.pkt = NULL; /* set pointer to NULL before rtw_free_recvframe() if call rtw_netif_rx() */
 }
-
-#ifdef CONFIG_AUTO_AP_MODE
-static void rtw_os_ksocket_send(_adapter *padapter, union recv_frame *precv_frame)
-{	
-	_pkt *skb = precv_frame->u.hdr.pkt;	
-	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
-	struct sta_info *psta = precv_frame->u.hdr.psta;
-		
-	DBG_871X("eth rx: got eth_type=0x%x\n", pattrib->eth_type);					
-		
-	if (psta && psta->isrc && psta->pid>0)
-	{
-		u16 rx_pid;
-
-		rx_pid = *(u16*)(skb->data+ETH_HLEN);
-			
-		DBG_871X("eth rx(pid=0x%x): sta("MAC_FMT") pid=0x%x\n", 
-			rx_pid, MAC_ARG(psta->hwaddr), psta->pid);
-
-		if(rx_pid == psta->pid)
-		{
-			int i;
-			u16 len = *(u16*)(skb->data+ETH_HLEN+2);
-			//u16 ctrl_type = *(u16*)(skb->data+ETH_HLEN+4);
-
-			//DBG_871X("eth, RC: len=0x%x, ctrl_type=0x%x\n", len, ctrl_type); 
-			DBG_871X("eth, RC: len=0x%x\n", len);
-
-			for(i=0;i<len;i++)
-				DBG_871X("0x%x\n", *(skb->data+ETH_HLEN+4+i));
-				//DBG_871X("0x%x\n", *(skb->data+ETH_HLEN+6+i));
-
-			DBG_871X("eth, RC-end\n"); 
-
-#if 0
-			//send_sz = ksocket_send(padapter->ksock_send, &padapter->kaddr_send, (skb->data+ETH_HLEN+2), len);				
-			rtw_recv_ksocket_send_cmd(padapter, (skb->data+ETH_HLEN+2), len);
-
-			//DBG_871X("ksocket_send size=%d\n", send_sz); 
-#endif			
-		}
-		
-	}		
-
-}
-#endif //CONFIG_AUTO_AP_MODE
+#endif /* CONFIG_HOSTAPD_MLME */
 
 int rtw_recv_monitor(_adapter *padapter, union recv_frame *precv_frame)
 {
@@ -601,7 +645,7 @@ int rtw_recv_monitor(_adapter *padapter, union recv_frame *precv_frame)
 
 	skb = precv_frame->u.hdr.pkt;
 	if (skb == NULL) {
-		DBG_871X("%s :skb==NULL something wrong!!!!\n", __func__);
+		RTW_INFO("%s :skb==NULL something wrong!!!!\n", __func__);
 		goto _recv_drop;
 	}
 
@@ -629,148 +673,38 @@ _recv_drop:
 
 }
 
+inline void rtw_rframe_set_os_pkt(union recv_frame *rframe)
+{
+	_pkt *skb = rframe->u.hdr.pkt;
+
+	skb->data = rframe->u.hdr.rx_data;
+	skb_set_tail_pointer(skb, rframe->u.hdr.len);
+	skb->len = rframe->u.hdr.len;
+}
+
 int rtw_recv_indicatepkt(_adapter *padapter, union recv_frame *precv_frame)
 {
 	struct recv_priv *precvpriv;
 	_queue	*pfree_recv_queue;
-	_pkt *skb;
-	struct mlme_priv*pmlmepriv = &padapter->mlmepriv;
-	struct rx_pkt_attrib *pattrib;
-	
-	if(NULL == precv_frame)
-		goto _recv_indicatepkt_drop;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-	DBG_COUNTER(padapter->rx_logs.os_indicate);
-	pattrib = &precv_frame->u.hdr.attrib;
 	precvpriv = &(padapter->recvpriv);
 	pfree_recv_queue = &(precvpriv->free_recv_queue);
 
-#ifdef CONFIG_DRVEXT_MODULE
-	if (drvext_rx_handler(padapter, precv_frame->u.hdr.rx_data, precv_frame->u.hdr.len) == _SUCCESS)
-	{
-		goto _recv_indicatepkt_drop;
-	}
-#endif
-
-#ifdef CONFIG_WAPI_SUPPORT
-	if (rtw_wapi_check_for_drop(padapter,precv_frame))
-	{
-		WAPI_TRACE(WAPI_ERR, "%s(): Rx Reorder Drop case!!\n", __FUNCTION__);
+	if (precv_frame->u.hdr.pkt == NULL)
 		goto _recv_indicatepkt_drop;
-	}
-#endif
-
-	skb = precv_frame->u.hdr.pkt;
-	if(skb == NULL)
-	{
-		RT_TRACE(_module_recv_osdep_c_,_drv_err_,("rtw_recv_indicatepkt():skb==NULL something wrong!!!!\n"));
-		goto _recv_indicatepkt_drop;
-	}
-
-	RT_TRACE(_module_recv_osdep_c_,_drv_info_,("rtw_recv_indicatepkt():skb != NULL !!!\n"));		
-	RT_TRACE(_module_recv_osdep_c_,_drv_info_,("rtw_recv_indicatepkt():precv_frame->u.hdr.rx_head=%p  precv_frame->hdr.rx_data=%p\n", precv_frame->u.hdr.rx_head, precv_frame->u.hdr.rx_data));
-	RT_TRACE(_module_recv_osdep_c_,_drv_info_,("precv_frame->hdr.rx_tail=%p precv_frame->u.hdr.rx_end=%p precv_frame->hdr.len=%d \n", precv_frame->u.hdr.rx_tail, precv_frame->u.hdr.rx_end, precv_frame->u.hdr.len));
-
-	skb->data = precv_frame->u.hdr.rx_data;
-
-	skb_set_tail_pointer(skb, precv_frame->u.hdr.len);
 
-	skb->len = precv_frame->u.hdr.len;
-
-	RT_TRACE(_module_recv_osdep_c_,_drv_info_,("\n 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 (pattrib->eth_type == 0x888e)
-		DBG_871X_LEVEL(_drv_always_, "recv eapol packet\n");
-
-#ifdef CONFIG_AUTO_AP_MODE	
-#if 1 //for testing
-#if 1
-	if (0x8899 == pattrib->eth_type)
-	{
-		rtw_os_ksocket_send(padapter, precv_frame);
-
-		//goto _recv_indicatepkt_drop;
-	}
-#else
-	if (0x8899 == pattrib->eth_type)
-	{
-		rtw_auto_ap_mode_rx(padapter, precv_frame);
-		
-		goto _recv_indicatepkt_end;
-	}
-#endif
-#endif
-#endif //CONFIG_AUTO_AP_MODE
-
-	/* TODO: move to core */
-	{
-		_pkt *pkt = skb;
-		struct ethhdr *etherhdr = (struct ethhdr *)pkt->data;
-		struct sta_info *sta = precv_frame->u.hdr.psta;
-
-		if (!sta)
-			goto bypass_session_tracker;
-
-		if (ntohs(etherhdr->h_proto) == ETH_P_IP) {
-			u8 *ip = pkt->data + 14;
-
-			if (GET_IPV4_PROTOCOL(ip) == 0x06  /* TCP */
-				&& rtw_st_ctl_chk_reg_s_proto(&sta->st_ctl, 0x06) == _TRUE
-			) {
-				u8 *tcp = ip + GET_IPV4_IHL(ip) * 4;
-
-				if (rtw_st_ctl_chk_reg_rule(&sta->st_ctl, padapter, IPV4_DST(ip), TCP_DST(tcp), IPV4_SRC(ip), TCP_SRC(tcp)) == _TRUE) {
-					if (GET_TCP_SYN(tcp) && GET_TCP_ACK(tcp)) {
-						session_tracker_add_cmd(padapter, sta
-							, IPV4_DST(ip), TCP_DST(tcp)
-							, IPV4_SRC(ip), TCP_SRC(tcp));
-						if (DBG_SESSION_TRACKER)
-							DBG_871X(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" SYN-ACK\n"
-								, FUNC_ADPT_ARG(padapter)
-								, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp))
-								, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp)));
-					}
-					if (GET_TCP_FIN(tcp)) {
-						session_tracker_del_cmd(padapter, sta
-							, IPV4_DST(ip), TCP_DST(tcp)
-							, IPV4_SRC(ip), TCP_SRC(tcp));
-						if (DBG_SESSION_TRACKER)
-							DBG_871X(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" FIN\n"
-								, FUNC_ADPT_ARG(padapter)
-								, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp))
-								, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp)));
-					}
-				}
-
-			}
-		}
-bypass_session_tracker:
-		;
-	}
-
-	rtw_os_recv_indicate_pkt(padapter, skb, pattrib);
+	rtw_os_recv_indicate_pkt(padapter, precv_frame->u.hdr.pkt, precv_frame);
 
 _recv_indicatepkt_end:
-
-	precv_frame->u.hdr.pkt = NULL; // pointers to NULL before rtw_free_recvframe()
-
+	precv_frame->u.hdr.pkt = NULL;
 	rtw_free_recvframe(precv_frame, pfree_recv_queue);
-
-	RT_TRACE(_module_recv_osdep_c_,_drv_info_,("\n rtw_recv_indicatepkt :after rtw_os_recv_indicate_pkt!!!!\n"));
-
-
-        return _SUCCESS;
+	return _SUCCESS;
 
 _recv_indicatepkt_drop:
-
-	 //enqueue back to free_recv_queue
-	 if(precv_frame)
-		 rtw_free_recvframe(precv_frame, pfree_recv_queue);
-
-	 DBG_COUNTER(padapter->rx_logs.os_indicate_err);
-
-	 return _FAIL;
-
+	rtw_free_recvframe(precv_frame, pfree_recv_queue);
+	DBG_COUNTER(padapter->rx_logs.os_indicate_err);
+	return _FAIL;
 }
 
 void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf)
@@ -781,35 +715,19 @@ void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf)
 
 	precvbuf->ref_cnt--;
 
-	//free skb in recv_buf
+	/* free skb in recv_buf */
 	rtw_skb_free(precvbuf->pskb);
 
 	precvbuf->pskb = NULL;
 
-	if(precvbuf->irp_pending == _FALSE)
-	{
+	if (precvbuf->irp_pending == _FALSE)
 		rtw_read_port(padapter, precvpriv->ff_hwaddr, 0, (unsigned char *)precvbuf);
-	}
 
 
 #endif
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-		precvbuf->pskb = NULL;
+	precvbuf->pskb = NULL;
 #endif
 
 }
-void _rtw_reordering_ctrl_timeout_handler (void *FunctionContext);
-void _rtw_reordering_ctrl_timeout_handler (void *FunctionContext)
-{
-	struct recv_reorder_ctrl *preorder_ctrl = (struct recv_reorder_ctrl *)FunctionContext;
-	rtw_reordering_ctrl_timeout_handler(preorder_ctrl);
-}
-
-void rtw_init_recv_timer(struct recv_reorder_ctrl *preorder_ctrl)
-{
-	_adapter *padapter = preorder_ctrl->padapter;
-
-	_init_timer(&(preorder_ctrl->reordering_ctrl_timer), padapter->pnetdev, _rtw_reordering_ctrl_timeout_handler, preorder_ctrl);
-
-}
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rhashtable.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rhashtable.c
new file mode 100644
index 000000000000..e910d6fbcfe6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rhashtable.c
@@ -0,0 +1,845 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Resizable, Scalable, Concurrent Hash Table
+ *
+ * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au>
+ * Copyright (c) 2014-2015 Thomas Graf <tgraf@suug.ch>
+ * Copyright (c) 2008-2014 Patrick McHardy <kaber@trash.net>
+ *
+ * Code partially derived from nft_hash
+ * Rewritten with rehash code from br_multicast plus single list
+ * pointer as suggested by Josh Triplett
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#include <linux/atomic.h>
+#include <linux/kernel.h>
+#include <linux/init.h>
+#include <linux/log2.h>
+#include <linux/sched.h>
+#include <linux/slab.h>
+#include <linux/vmalloc.h>
+#include <linux/mm.h>
+#include <linux/jhash.h>
+#include <linux/random.h>
+#include <linux/err.h>
+#include <linux/export.h>
+
+#define HASH_DEFAULT_SIZE	64UL
+#define HASH_MIN_SIZE		4U
+#define BUCKET_LOCKS_PER_CPU   128UL
+
+static u32 head_hashfn(struct rhashtable *ht,
+		       const struct bucket_table *tbl,
+		       const struct rhash_head *he)
+{
+	return rht_head_hashfn(ht, tbl, he, ht->p);
+}
+
+#ifdef CONFIG_PROVE_LOCKING
+#define ASSERT_RHT_MUTEX(HT) BUG_ON(!lockdep_rht_mutex_is_held(HT))
+
+int lockdep_rht_mutex_is_held(struct rhashtable *ht)
+{
+	return (debug_locks) ? lockdep_is_held(&ht->mutex) : 1;
+}
+
+int lockdep_rht_bucket_is_held(const struct bucket_table *tbl, u32 hash)
+{
+	spinlock_t *lock = rht_bucket_lock(tbl, hash);
+
+	return (debug_locks) ? lockdep_is_held(lock) : 1;
+}
+#else
+#define ASSERT_RHT_MUTEX(HT)
+#endif
+
+
+static int alloc_bucket_locks(struct rhashtable *ht, struct bucket_table *tbl,
+			      gfp_t gfp)
+{
+	unsigned int i, size;
+#if defined(CONFIG_PROVE_LOCKING)
+	unsigned int nr_pcpus = 2;
+#else
+	unsigned int nr_pcpus = num_possible_cpus();
+#endif
+
+	nr_pcpus = min_t(unsigned int, nr_pcpus, 32UL);
+	size = roundup_pow_of_two(nr_pcpus * ht->p.locks_mul);
+
+	/* Never allocate more than 0.5 locks per bucket */
+	size = min_t(unsigned int, size, tbl->size >> 1);
+
+	if (sizeof(spinlock_t) != 0) {
+#ifdef CONFIG_NUMA
+		if (size * sizeof(spinlock_t) > PAGE_SIZE &&
+		    gfp == GFP_KERNEL)
+			tbl->locks = vmalloc(size * sizeof(spinlock_t));
+		else
+#endif
+		tbl->locks = kmalloc_array(size, sizeof(spinlock_t),
+					   gfp);
+		if (!tbl->locks)
+			return -ENOMEM;
+		for (i = 0; i < size; i++)
+			spin_lock_init(&tbl->locks[i]);
+	}
+	tbl->locks_mask = size - 1;
+
+	return 0;
+}
+
+static void bucket_table_free(const struct bucket_table *tbl)
+{
+	if (tbl)
+		kvfree(tbl->locks);
+
+	kvfree(tbl);
+}
+
+static void bucket_table_free_rcu(struct rcu_head *head)
+{
+	bucket_table_free(container_of(head, struct bucket_table, rcu));
+}
+
+static struct bucket_table *bucket_table_alloc(struct rhashtable *ht,
+					       size_t nbuckets,
+					       gfp_t gfp)
+{
+	struct bucket_table *tbl = NULL;
+	size_t size;
+	int i;
+
+	size = sizeof(*tbl) + nbuckets * sizeof(tbl->buckets[0]);
+	if (size <= (PAGE_SIZE << PAGE_ALLOC_COSTLY_ORDER) ||
+	    gfp != GFP_KERNEL)
+		tbl = kzalloc(size, gfp | __GFP_NOWARN | __GFP_NORETRY);
+	if (tbl == NULL && gfp == GFP_KERNEL)
+		tbl = vzalloc(size);
+	if (tbl == NULL)
+		return NULL;
+
+	tbl->size = nbuckets;
+
+	if (alloc_bucket_locks(ht, tbl, gfp) < 0) {
+		bucket_table_free(tbl);
+		return NULL;
+	}
+
+	INIT_LIST_HEAD(&tbl->walkers);
+
+	get_random_bytes(&tbl->hash_rnd, sizeof(tbl->hash_rnd));
+
+	for (i = 0; i < nbuckets; i++)
+		INIT_RHT_NULLS_HEAD(tbl->buckets[i], ht, i);
+
+	return tbl;
+}
+
+static struct bucket_table *rhashtable_last_table(struct rhashtable *ht,
+						  struct bucket_table *tbl)
+{
+	struct bucket_table *new_tbl;
+
+	do {
+		new_tbl = tbl;
+		tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	} while (tbl);
+
+	return new_tbl;
+}
+
+static int rhashtable_rehash_one(struct rhashtable *ht, unsigned int old_hash)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	struct bucket_table *new_tbl = rhashtable_last_table(ht,
+		rht_dereference_rcu(old_tbl->future_tbl, ht));
+	struct rhash_head __rcu **pprev = &old_tbl->buckets[old_hash];
+	int err = -ENOENT;
+	struct rhash_head *head, *next, *entry;
+	spinlock_t *new_bucket_lock;
+	unsigned int new_hash;
+
+	rht_for_each(entry, old_tbl, old_hash) {
+		err = 0;
+		next = rht_dereference_bucket(entry->next, old_tbl, old_hash);
+
+		if (rht_is_a_nulls(next))
+			break;
+
+		pprev = &entry->next;
+	}
+
+	if (err)
+		goto out;
+
+	new_hash = head_hashfn(ht, new_tbl, entry);
+
+	new_bucket_lock = rht_bucket_lock(new_tbl, new_hash);
+
+	spin_lock_nested(new_bucket_lock, SINGLE_DEPTH_NESTING);
+	head = rht_dereference_bucket(new_tbl->buckets[new_hash],
+				      new_tbl, new_hash);
+
+	RCU_INIT_POINTER(entry->next, head);
+
+	rcu_assign_pointer(new_tbl->buckets[new_hash], entry);
+	spin_unlock(new_bucket_lock);
+
+	rcu_assign_pointer(*pprev, next);
+
+out:
+	return err;
+}
+
+static void rhashtable_rehash_chain(struct rhashtable *ht,
+				    unsigned int old_hash)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	spinlock_t *old_bucket_lock;
+
+	old_bucket_lock = rht_bucket_lock(old_tbl, old_hash);
+
+	spin_lock_bh(old_bucket_lock);
+	while (!rhashtable_rehash_one(ht, old_hash))
+		;
+	old_tbl->rehash++;
+	spin_unlock_bh(old_bucket_lock);
+}
+
+static int rhashtable_rehash_attach(struct rhashtable *ht,
+				    struct bucket_table *old_tbl,
+				    struct bucket_table *new_tbl)
+{
+	/* Protect future_tbl using the first bucket lock. */
+	spin_lock_bh(old_tbl->locks);
+
+	/* Did somebody beat us to it? */
+	if (rcu_access_pointer(old_tbl->future_tbl)) {
+		spin_unlock_bh(old_tbl->locks);
+		return -EEXIST;
+	}
+
+	/* Make insertions go into the new, empty table right away. Deletions
+	 * and lookups will be attempted in both tables until we synchronize.
+	 */
+	rcu_assign_pointer(old_tbl->future_tbl, new_tbl);
+
+	/* Ensure the new table is visible to readers. */
+	smp_wmb();
+
+	spin_unlock_bh(old_tbl->locks);
+
+	return 0;
+}
+
+static int rhashtable_rehash_table(struct rhashtable *ht)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	struct bucket_table *new_tbl;
+	struct rhashtable_walker *walker;
+	unsigned int old_hash;
+
+	new_tbl = rht_dereference(old_tbl->future_tbl, ht);
+	if (!new_tbl)
+		return 0;
+
+	for (old_hash = 0; old_hash < old_tbl->size; old_hash++)
+		rhashtable_rehash_chain(ht, old_hash);
+
+	/* Publish the new table pointer. */
+	rcu_assign_pointer(ht->tbl, new_tbl);
+
+	spin_lock(&ht->lock);
+	list_for_each_entry(walker, &old_tbl->walkers, list)
+		walker->tbl = NULL;
+	spin_unlock(&ht->lock);
+
+	/* Wait for readers. All new readers will see the new
+	 * table, and thus no references to the old table will
+	 * remain.
+	 */
+	call_rcu(&old_tbl->rcu, bucket_table_free_rcu);
+
+	return rht_dereference(new_tbl->future_tbl, ht) ? -EAGAIN : 0;
+}
+
+/**
+ * rhashtable_expand - Expand hash table while allowing concurrent lookups
+ * @ht:		the hash table to expand
+ *
+ * A secondary bucket array is allocated and the hash entries are migrated.
+ *
+ * This function may only be called in a context where it is safe to call
+ * synchronize_rcu(), e.g. not within a rcu_read_lock() section.
+ *
+ * The caller must ensure that no concurrent resizing occurs by holding
+ * ht->mutex.
+ *
+ * It is valid to have concurrent insertions and deletions protected by per
+ * bucket locks or concurrent RCU protected lookups and traversals.
+ */
+static int rhashtable_expand(struct rhashtable *ht)
+{
+	struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht);
+	int err;
+
+	ASSERT_RHT_MUTEX(ht);
+
+	old_tbl = rhashtable_last_table(ht, old_tbl);
+
+	new_tbl = bucket_table_alloc(ht, old_tbl->size * 2, GFP_KERNEL);
+	if (new_tbl == NULL)
+		return -ENOMEM;
+
+	err = rhashtable_rehash_attach(ht, old_tbl, new_tbl);
+	if (err)
+		bucket_table_free(new_tbl);
+
+	return err;
+}
+
+/**
+ * rhashtable_shrink - Shrink hash table while allowing concurrent lookups
+ * @ht:		the hash table to shrink
+ *
+ * This function shrinks the hash table to fit, i.e., the smallest
+ * size would not cause it to expand right away automatically.
+ *
+ * The caller must ensure that no concurrent resizing occurs by holding
+ * ht->mutex.
+ *
+ * The caller must ensure that no concurrent table mutations take place.
+ * It is however valid to have concurrent lookups if they are RCU protected.
+ *
+ * It is valid to have concurrent insertions and deletions protected by per
+ * bucket locks or concurrent RCU protected lookups and traversals.
+ */
+static int rhashtable_shrink(struct rhashtable *ht)
+{
+	struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht);
+	unsigned int size;
+	int err;
+
+	ASSERT_RHT_MUTEX(ht);
+
+	size = roundup_pow_of_two(atomic_read(&ht->nelems) * 3 / 2);
+	if (size < ht->p.min_size)
+		size = ht->p.min_size;
+
+	if (old_tbl->size <= size)
+		return 0;
+
+	if (rht_dereference(old_tbl->future_tbl, ht))
+		return -EEXIST;
+
+	new_tbl = bucket_table_alloc(ht, size, GFP_KERNEL);
+	if (new_tbl == NULL)
+		return -ENOMEM;
+
+	err = rhashtable_rehash_attach(ht, old_tbl, new_tbl);
+	if (err)
+		bucket_table_free(new_tbl);
+
+	return err;
+}
+
+static void rht_deferred_worker(struct work_struct *work)
+{
+	struct rhashtable *ht;
+	struct bucket_table *tbl;
+	int err = 0;
+
+	ht = container_of(work, struct rhashtable, run_work);
+	mutex_lock(&ht->mutex);
+
+	tbl = rht_dereference(ht->tbl, ht);
+	tbl = rhashtable_last_table(ht, tbl);
+
+	if (rht_grow_above_75(ht, tbl))
+		rhashtable_expand(ht);
+	else if (ht->p.automatic_shrinking && rht_shrink_below_30(ht, tbl))
+		rhashtable_shrink(ht);
+
+	err = rhashtable_rehash_table(ht);
+
+	mutex_unlock(&ht->mutex);
+
+	if (err)
+		schedule_work(&ht->run_work);
+}
+
+static bool rhashtable_check_elasticity(struct rhashtable *ht,
+					struct bucket_table *tbl,
+					unsigned int hash)
+{
+	unsigned int elasticity = ht->elasticity;
+	struct rhash_head *head;
+
+	rht_for_each(head, tbl, hash)
+		if (!--elasticity)
+			return true;
+
+	return false;
+}
+
+int rhashtable_insert_rehash(struct rhashtable *ht,
+			     struct bucket_table *tbl)
+{
+	struct bucket_table *old_tbl;
+	struct bucket_table *new_tbl;
+	unsigned int size;
+	int err;
+
+	old_tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	size = tbl->size;
+
+	err = -EBUSY;
+
+	if (rht_grow_above_75(ht, tbl))
+		size *= 2;
+	/* Do not schedule more than one rehash */
+	else if (old_tbl != tbl)
+		goto fail;
+
+	err = -ENOMEM;
+
+	new_tbl = bucket_table_alloc(ht, size, GFP_ATOMIC);
+	if (new_tbl == NULL)
+		goto fail;
+
+	err = rhashtable_rehash_attach(ht, tbl, new_tbl);
+	if (err) {
+		bucket_table_free(new_tbl);
+		if (err == -EEXIST)
+			err = 0;
+	} else
+		schedule_work(&ht->run_work);
+
+	return err;
+
+fail:
+	/* Do not fail the insert if someone else did a rehash. */
+	if (likely(rcu_dereference_raw(tbl->future_tbl)))
+		return 0;
+
+	/* Schedule async rehash to retry allocation in process context. */
+	if (err == -ENOMEM)
+		schedule_work(&ht->run_work);
+
+	return err;
+}
+
+struct bucket_table *rhashtable_insert_slow(struct rhashtable *ht,
+					    const void *key,
+					    struct rhash_head *obj,
+					    struct bucket_table *tbl)
+{
+	struct rhash_head *head;
+	unsigned int hash;
+	int err;
+
+	tbl = rhashtable_last_table(ht, tbl);
+	hash = head_hashfn(ht, tbl, obj);
+	spin_lock_nested(rht_bucket_lock(tbl, hash), SINGLE_DEPTH_NESTING);
+
+	err = -EEXIST;
+	if (key && rhashtable_lookup_fast(ht, key, ht->p))
+		goto exit;
+
+	err = -E2BIG;
+	if (unlikely(rht_grow_above_max(ht, tbl)))
+		goto exit;
+
+	err = -EAGAIN;
+	if (rhashtable_check_elasticity(ht, tbl, hash) ||
+	    rht_grow_above_100(ht, tbl))
+		goto exit;
+
+	err = 0;
+
+	head = rht_dereference_bucket(tbl->buckets[hash], tbl, hash);
+
+	RCU_INIT_POINTER(obj->next, head);
+
+	rcu_assign_pointer(tbl->buckets[hash], obj);
+
+	atomic_inc(&ht->nelems);
+
+exit:
+	spin_unlock(rht_bucket_lock(tbl, hash));
+
+	if (err == 0)
+		return NULL;
+	else if (err == -EAGAIN)
+		return tbl;
+	else
+		return ERR_PTR(err);
+}
+
+/**
+ * rhashtable_walk_init - Initialise an iterator
+ * @ht:		Table to walk over
+ * @iter:	Hash table Iterator
+ *
+ * This function prepares a hash table walk.
+ *
+ * Note that if you restart a walk after rhashtable_walk_stop you
+ * may see the same object twice.  Also, you may miss objects if
+ * there are removals in between rhashtable_walk_stop and the next
+ * call to rhashtable_walk_start.
+ *
+ * For a completely stable walk you should construct your own data
+ * structure outside the hash table.
+ *
+ * This function may sleep so you must not call it from interrupt
+ * context or with spin locks held.
+ *
+ * You must call rhashtable_walk_exit if this function returns
+ * successfully.
+ */
+int rhashtable_walk_init(struct rhashtable *ht, struct rhashtable_iter *iter)
+{
+	iter->ht = ht;
+	iter->p = NULL;
+	iter->slot = 0;
+	iter->skip = 0;
+
+	iter->walker = kmalloc(sizeof(*iter->walker), GFP_KERNEL);
+	if (!iter->walker)
+		return -ENOMEM;
+
+	spin_lock(&ht->lock);
+	iter->walker->tbl =
+		rcu_dereference_protected(ht->tbl, lockdep_is_held(&ht->lock));
+	list_add(&iter->walker->list, &iter->walker->tbl->walkers);
+	spin_unlock(&ht->lock);
+
+	return 0;
+}
+
+/**
+ * rhashtable_walk_exit - Free an iterator
+ * @iter:	Hash table Iterator
+ *
+ * This function frees resources allocated by rhashtable_walk_init.
+ */
+void rhashtable_walk_exit(struct rhashtable_iter *iter)
+{
+	spin_lock(&iter->ht->lock);
+	if (iter->walker->tbl)
+		list_del(&iter->walker->list);
+	spin_unlock(&iter->ht->lock);
+	kfree(iter->walker);
+}
+
+/**
+ * rhashtable_walk_start - Start a hash table walk
+ * @iter:	Hash table iterator
+ *
+ * Start a hash table walk.  Note that we take the RCU lock in all
+ * cases including when we return an error.  So you must always call
+ * rhashtable_walk_stop to clean up.
+ *
+ * Returns zero if successful.
+ *
+ * Returns -EAGAIN if resize event occured.  Note that the iterator
+ * will rewind back to the beginning and you may use it immediately
+ * by calling rhashtable_walk_next.
+ */
+int rhashtable_walk_start(struct rhashtable_iter *iter)
+	__acquires(RCU)
+{
+	struct rhashtable *ht = iter->ht;
+
+	rcu_read_lock();
+
+	spin_lock(&ht->lock);
+	if (iter->walker->tbl)
+		list_del(&iter->walker->list);
+	spin_unlock(&ht->lock);
+
+	if (!iter->walker->tbl) {
+		iter->walker->tbl = rht_dereference_rcu(ht->tbl, ht);
+		return -EAGAIN;
+	}
+
+	return 0;
+}
+
+/**
+ * rhashtable_walk_next - Return the next object and advance the iterator
+ * @iter:	Hash table iterator
+ *
+ * Note that you must call rhashtable_walk_stop when you are finished
+ * with the walk.
+ *
+ * Returns the next object or NULL when the end of the table is reached.
+ *
+ * Returns -EAGAIN if resize event occured.  Note that the iterator
+ * will rewind back to the beginning and you may continue to use it.
+ */
+void *rhashtable_walk_next(struct rhashtable_iter *iter)
+{
+	struct bucket_table *tbl = iter->walker->tbl;
+	struct rhashtable *ht = iter->ht;
+	struct rhash_head *p = iter->p;
+
+	if (p) {
+		p = rht_dereference_bucket_rcu(p->next, tbl, iter->slot);
+		goto next;
+	}
+
+	for (; iter->slot < tbl->size; iter->slot++) {
+		int skip = iter->skip;
+
+		rht_for_each_rcu(p, tbl, iter->slot) {
+			if (!skip)
+				break;
+			skip--;
+		}
+
+next:
+		if (!rht_is_a_nulls(p)) {
+			iter->skip++;
+			iter->p = p;
+			return rht_obj(ht, p);
+		}
+
+		iter->skip = 0;
+	}
+
+	iter->p = NULL;
+
+	/* Ensure we see any new tables. */
+	smp_rmb();
+
+	iter->walker->tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (iter->walker->tbl) {
+		iter->slot = 0;
+		iter->skip = 0;
+		return ERR_PTR(-EAGAIN);
+	}
+
+	return NULL;
+}
+
+/**
+ * rhashtable_walk_stop - Finish a hash table walk
+ * @iter:	Hash table iterator
+ *
+ * Finish a hash table walk.
+ */
+void rhashtable_walk_stop(struct rhashtable_iter *iter)
+	__releases(RCU)
+{
+	struct rhashtable *ht;
+	struct bucket_table *tbl = iter->walker->tbl;
+
+	if (!tbl)
+		goto out;
+
+	ht = iter->ht;
+
+	spin_lock(&ht->lock);
+	if (tbl->rehash < tbl->size)
+		list_add(&iter->walker->list, &tbl->walkers);
+	else
+		iter->walker->tbl = NULL;
+	spin_unlock(&ht->lock);
+
+	iter->p = NULL;
+
+out:
+	rcu_read_unlock();
+}
+
+static size_t rounded_hashtable_size(const struct rhashtable_params *params)
+{
+	return max(roundup_pow_of_two(params->nelem_hint * 4 / 3),
+		   (unsigned long)params->min_size);
+}
+
+static u32 rhashtable_jhash2(const void *key, u32 length, u32 seed)
+{
+	return jhash2(key, length, seed);
+}
+
+/**
+ * rhashtable_init - initialize a new hash table
+ * @ht:		hash table to be initialized
+ * @params:	configuration parameters
+ *
+ * Initializes a new hash table based on the provided configuration
+ * parameters. A table can be configured either with a variable or
+ * fixed length key:
+ *
+ * Configuration Example 1: Fixed length keys
+ * struct test_obj {
+ *	int			key;
+ *	void *			my_member;
+ *	struct rhash_head	node;
+ * };
+ *
+ * struct rhashtable_params params = {
+ *	.head_offset = offsetof(struct test_obj, node),
+ *	.key_offset = offsetof(struct test_obj, key),
+ *	.key_len = sizeof(int),
+ *	.hashfn = jhash,
+ *	.nulls_base = (1U << RHT_BASE_SHIFT),
+ * };
+ *
+ * Configuration Example 2: Variable length keys
+ * struct test_obj {
+ *	[...]
+ *	struct rhash_head	node;
+ * };
+ *
+ * u32 my_hash_fn(const void *data, u32 len, u32 seed)
+ * {
+ *	struct test_obj *obj = data;
+ *
+ *	return [... hash ...];
+ * }
+ *
+ * struct rhashtable_params params = {
+ *	.head_offset = offsetof(struct test_obj, node),
+ *	.hashfn = jhash,
+ *	.obj_hashfn = my_hash_fn,
+ * };
+ */
+int rhashtable_init(struct rhashtable *ht,
+		    const struct rhashtable_params *params)
+{
+	struct bucket_table *tbl;
+	size_t size;
+
+	size = HASH_DEFAULT_SIZE;
+
+	if ((!params->key_len && !params->obj_hashfn) ||
+	    (params->obj_hashfn && !params->obj_cmpfn))
+		return -EINVAL;
+
+	if (params->nulls_base && params->nulls_base < (1U << RHT_BASE_SHIFT))
+		return -EINVAL;
+
+	memset(ht, 0, sizeof(*ht));
+	mutex_init(&ht->mutex);
+	spin_lock_init(&ht->lock);
+	memcpy(&ht->p, params, sizeof(*params));
+
+	if (params->min_size)
+		ht->p.min_size = roundup_pow_of_two(params->min_size);
+
+	if (params->max_size)
+		ht->p.max_size = rounddown_pow_of_two(params->max_size);
+
+	if (params->insecure_max_entries)
+		ht->p.insecure_max_entries =
+			rounddown_pow_of_two(params->insecure_max_entries);
+	else
+		ht->p.insecure_max_entries = ht->p.max_size * 2;
+
+	ht->p.min_size = max(ht->p.min_size, HASH_MIN_SIZE);
+
+	if (params->nelem_hint)
+		size = rounded_hashtable_size(&ht->p);
+
+	/* The maximum (not average) chain length grows with the
+	 * size of the hash table, at a rate of (log N)/(log log N).
+	 * The value of 16 is selected so that even if the hash
+	 * table grew to 2^32 you would not expect the maximum
+	 * chain length to exceed it unless we are under attack
+	 * (or extremely unlucky).
+	 *
+	 * As this limit is only to detect attacks, we don't need
+	 * to set it to a lower value as you'd need the chain
+	 * length to vastly exceed 16 to have any real effect
+	 * on the system.
+	 */
+	if (!params->insecure_elasticity)
+		ht->elasticity = 16;
+
+	if (params->locks_mul)
+		ht->p.locks_mul = roundup_pow_of_two(params->locks_mul);
+	else
+		ht->p.locks_mul = BUCKET_LOCKS_PER_CPU;
+
+	ht->key_len = ht->p.key_len;
+	if (!params->hashfn) {
+		ht->p.hashfn = jhash;
+
+		if (!(ht->key_len & (sizeof(u32) - 1))) {
+			ht->key_len /= sizeof(u32);
+			ht->p.hashfn = rhashtable_jhash2;
+		}
+	}
+
+	tbl = bucket_table_alloc(ht, size, GFP_KERNEL);
+	if (tbl == NULL)
+		return -ENOMEM;
+
+	atomic_set(&ht->nelems, 0);
+
+	RCU_INIT_POINTER(ht->tbl, tbl);
+
+	INIT_WORK(&ht->run_work, rht_deferred_worker);
+
+	return 0;
+}
+
+/**
+ * rhashtable_free_and_destroy - free elements and destroy hash table
+ * @ht:		the hash table to destroy
+ * @free_fn:	callback to release resources of element
+ * @arg:	pointer passed to free_fn
+ *
+ * Stops an eventual async resize. If defined, invokes free_fn for each
+ * element to releasal resources. Please note that RCU protected
+ * readers may still be accessing the elements. Releasing of resources
+ * must occur in a compatible manner. Then frees the bucket array.
+ *
+ * This function will eventually sleep to wait for an async resize
+ * to complete. The caller is responsible that no further write operations
+ * occurs in parallel.
+ */
+void rhashtable_free_and_destroy(struct rhashtable *ht,
+				 void (*free_fn)(void *ptr, void *arg),
+				 void *arg)
+{
+	const struct bucket_table *tbl;
+	unsigned int i;
+
+	cancel_work_sync(&ht->run_work);
+
+	mutex_lock(&ht->mutex);
+	tbl = rht_dereference(ht->tbl, ht);
+	if (free_fn) {
+		for (i = 0; i < tbl->size; i++) {
+			struct rhash_head *pos, *next;
+
+			for (pos = rht_dereference(tbl->buckets[i], ht),
+			     next = !rht_is_a_nulls(pos) ?
+					rht_dereference(pos->next, ht) : NULL;
+			     !rht_is_a_nulls(pos);
+			     pos = next,
+			     next = !rht_is_a_nulls(pos) ?
+					rht_dereference(pos->next, ht) : NULL)
+				free_fn(rht_obj(ht, pos), arg);
+		}
+	}
+
+	bucket_table_free(tbl);
+	mutex_unlock(&ht->mutex);
+}
+
+void rhashtable_destroy(struct rhashtable *ht)
+{
+	return rhashtable_free_and_destroy(ht, NULL, NULL);
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rhashtable.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rhashtable.h
new file mode 100644
index 000000000000..d6e7a55037ee
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rhashtable.h
@@ -0,0 +1,828 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Resizable, Scalable, Concurrent Hash Table
+ *
+ * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au>
+ * Copyright (c) 2014-2015 Thomas Graf <tgraf@suug.ch>
+ * Copyright (c) 2008-2014 Patrick McHardy <kaber@trash.net>
+ *
+ * Code partially derived from nft_hash
+ * Rewritten with rehash code from br_multicast plus single list
+ * pointer as suggested by Josh Triplett
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#ifndef _LINUX_RHASHTABLE_H
+#define _LINUX_RHASHTABLE_H
+
+#include <linux/atomic.h>
+#include <linux/compiler.h>
+#include <linux/err.h>
+#include <linux/errno.h>
+#include <linux/jhash.h>
+#include <linux/list_nulls.h>
+#include <linux/workqueue.h>
+#include <linux/mutex.h>
+#include <linux/rcupdate.h>
+
+/*
+ * The end of the chain is marked with a special nulls marks which has
+ * the following format:
+ *
+ * +-------+-----------------------------------------------------+-+
+ * | Base  |                      Hash                           |1|
+ * +-------+-----------------------------------------------------+-+
+ *
+ * Base (4 bits) : Reserved to distinguish between multiple tables.
+ *                 Specified via &struct rhashtable_params.nulls_base.
+ * Hash (27 bits): Full hash (unmasked) of first element added to bucket
+ * 1 (1 bit)     : Nulls marker (always set)
+ *
+ * The remaining bits of the next pointer remain unused for now.
+ */
+#define RHT_BASE_BITS		4
+#define RHT_HASH_BITS		27
+#define RHT_BASE_SHIFT		RHT_HASH_BITS
+
+/* Base bits plus 1 bit for nulls marker */
+#define RHT_HASH_RESERVED_SPACE	(RHT_BASE_BITS + 1)
+
+struct rhash_head {
+	struct rhash_head __rcu		*next;
+};
+
+/**
+ * struct bucket_table - Table of hash buckets
+ * @size: Number of hash buckets
+ * @rehash: Current bucket being rehashed
+ * @hash_rnd: Random seed to fold into hash
+ * @locks_mask: Mask to apply before accessing locks[]
+ * @locks: Array of spinlocks protecting individual buckets
+ * @walkers: List of active walkers
+ * @rcu: RCU structure for freeing the table
+ * @future_tbl: Table under construction during rehashing
+ * @buckets: size * hash buckets
+ */
+struct bucket_table {
+	unsigned int		size;
+	unsigned int		rehash;
+	u32			hash_rnd;
+	unsigned int		locks_mask;
+	spinlock_t		*locks;
+	struct list_head	walkers;
+	struct rcu_head		rcu;
+
+	struct bucket_table __rcu *future_tbl;
+
+	struct rhash_head __rcu	*buckets[] ____cacheline_aligned_in_smp;
+};
+
+/**
+ * struct rhashtable_compare_arg - Key for the function rhashtable_compare
+ * @ht: Hash table
+ * @key: Key to compare against
+ */
+struct rhashtable_compare_arg {
+	struct rhashtable *ht;
+	const void *key;
+};
+
+typedef u32 (*rht_hashfn_t)(const void *data, u32 len, u32 seed);
+typedef u32 (*rht_obj_hashfn_t)(const void *data, u32 len, u32 seed);
+typedef int (*rht_obj_cmpfn_t)(struct rhashtable_compare_arg *arg,
+			       const void *obj);
+
+struct rhashtable;
+
+/**
+ * struct rhashtable_params - Hash table construction parameters
+ * @nelem_hint: Hint on number of elements, should be 75% of desired size
+ * @key_len: Length of key
+ * @key_offset: Offset of key in struct to be hashed
+ * @head_offset: Offset of rhash_head in struct to be hashed
+ * @insecure_max_entries: Maximum number of entries (may be exceeded)
+ * @max_size: Maximum size while expanding
+ * @min_size: Minimum size while shrinking
+ * @nulls_base: Base value to generate nulls marker
+ * @insecure_elasticity: Set to true to disable chain length checks
+ * @automatic_shrinking: Enable automatic shrinking of tables
+ * @locks_mul: Number of bucket locks to allocate per cpu (default: 128)
+ * @hashfn: Hash function (default: jhash2 if !(key_len % 4), or jhash)
+ * @obj_hashfn: Function to hash object
+ * @obj_cmpfn: Function to compare key with object
+ */
+struct rhashtable_params {
+	size_t			nelem_hint;
+	size_t			key_len;
+	size_t			key_offset;
+	size_t			head_offset;
+	unsigned int		insecure_max_entries;
+	unsigned int		max_size;
+	unsigned int		min_size;
+	u32			nulls_base;
+	bool			insecure_elasticity;
+	bool			automatic_shrinking;
+	size_t			locks_mul;
+	rht_hashfn_t		hashfn;
+	rht_obj_hashfn_t	obj_hashfn;
+	rht_obj_cmpfn_t		obj_cmpfn;
+};
+
+/**
+ * struct rhashtable - Hash table handle
+ * @tbl: Bucket table
+ * @nelems: Number of elements in table
+ * @key_len: Key length for hashfn
+ * @elasticity: Maximum chain length before rehash
+ * @p: Configuration parameters
+ * @run_work: Deferred worker to expand/shrink asynchronously
+ * @mutex: Mutex to protect current/future table swapping
+ * @lock: Spin lock to protect walker list
+ */
+struct rhashtable {
+	struct bucket_table __rcu	*tbl;
+	atomic_t			nelems;
+	unsigned int			key_len;
+	unsigned int			elasticity;
+	struct rhashtable_params	p;
+	struct work_struct		run_work;
+	struct mutex                    mutex;
+	spinlock_t			lock;
+};
+
+/**
+ * struct rhashtable_walker - Hash table walker
+ * @list: List entry on list of walkers
+ * @tbl: The table that we were walking over
+ */
+struct rhashtable_walker {
+	struct list_head list;
+	struct bucket_table *tbl;
+};
+
+/**
+ * struct rhashtable_iter - Hash table iterator, fits into netlink cb
+ * @ht: Table to iterate through
+ * @p: Current pointer
+ * @walker: Associated rhashtable walker
+ * @slot: Current slot
+ * @skip: Number of entries to skip in slot
+ */
+struct rhashtable_iter {
+	struct rhashtable *ht;
+	struct rhash_head *p;
+	struct rhashtable_walker *walker;
+	unsigned int slot;
+	unsigned int skip;
+};
+
+static inline unsigned long rht_marker(const struct rhashtable *ht, u32 hash)
+{
+	return NULLS_MARKER(ht->p.nulls_base + hash);
+}
+
+#define INIT_RHT_NULLS_HEAD(ptr, ht, hash) \
+	((ptr) = (typeof(ptr)) rht_marker(ht, hash))
+
+static inline bool rht_is_a_nulls(const struct rhash_head *ptr)
+{
+	return ((unsigned long) ptr & 1);
+}
+
+static inline unsigned long rht_get_nulls_value(const struct rhash_head *ptr)
+{
+	return ((unsigned long) ptr) >> 1;
+}
+
+static inline void *rht_obj(const struct rhashtable *ht,
+			    const struct rhash_head *he)
+{
+	return (char *)he - ht->p.head_offset;
+}
+
+static inline unsigned int rht_bucket_index(const struct bucket_table *tbl,
+					    unsigned int hash)
+{
+	return (hash >> RHT_HASH_RESERVED_SPACE) & (tbl->size - 1);
+}
+
+static inline unsigned int rht_key_hashfn(
+	struct rhashtable *ht, const struct bucket_table *tbl,
+	const void *key, const struct rhashtable_params params)
+{
+	unsigned int hash;
+
+	/* params must be equal to ht->p if it isn't constant. */
+	if (!__builtin_constant_p(params.key_len))
+		hash = ht->p.hashfn(key, ht->key_len, tbl->hash_rnd);
+	else if (params.key_len) {
+		unsigned int key_len = params.key_len;
+
+		if (params.hashfn)
+			hash = params.hashfn(key, key_len, tbl->hash_rnd);
+		else if (key_len & (sizeof(u32) - 1))
+			hash = jhash(key, key_len, tbl->hash_rnd);
+		else
+			hash = jhash2(key, key_len / sizeof(u32),
+				      tbl->hash_rnd);
+	} else {
+		unsigned int key_len = ht->p.key_len;
+
+		if (params.hashfn)
+			hash = params.hashfn(key, key_len, tbl->hash_rnd);
+		else
+			hash = jhash(key, key_len, tbl->hash_rnd);
+	}
+
+	return rht_bucket_index(tbl, hash);
+}
+
+static inline unsigned int rht_head_hashfn(
+	struct rhashtable *ht, const struct bucket_table *tbl,
+	const struct rhash_head *he, const struct rhashtable_params params)
+{
+	const char *ptr = rht_obj(ht, he);
+
+	return likely(params.obj_hashfn) ?
+	       rht_bucket_index(tbl, params.obj_hashfn(ptr, params.key_len ?:
+							    ht->p.key_len,
+						       tbl->hash_rnd)) :
+	       rht_key_hashfn(ht, tbl, ptr + params.key_offset, params);
+}
+
+/**
+ * rht_grow_above_75 - returns true if nelems > 0.75 * table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_75(const struct rhashtable *ht,
+				     const struct bucket_table *tbl)
+{
+	/* Expand table when exceeding 75% load */
+	return atomic_read(&ht->nelems) > (tbl->size / 4 * 3) &&
+	       (!ht->p.max_size || tbl->size < ht->p.max_size);
+}
+
+/**
+ * rht_shrink_below_30 - returns true if nelems < 0.3 * table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_shrink_below_30(const struct rhashtable *ht,
+				       const struct bucket_table *tbl)
+{
+	/* Shrink table beneath 30% load */
+	return atomic_read(&ht->nelems) < (tbl->size * 3 / 10) &&
+	       tbl->size > ht->p.min_size;
+}
+
+/**
+ * rht_grow_above_100 - returns true if nelems > table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_100(const struct rhashtable *ht,
+				      const struct bucket_table *tbl)
+{
+	return atomic_read(&ht->nelems) > tbl->size &&
+		(!ht->p.max_size || tbl->size < ht->p.max_size);
+}
+
+/**
+ * rht_grow_above_max - returns true if table is above maximum
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_max(const struct rhashtable *ht,
+				      const struct bucket_table *tbl)
+{
+	return ht->p.insecure_max_entries &&
+	       atomic_read(&ht->nelems) >= ht->p.insecure_max_entries;
+}
+
+/* The bucket lock is selected based on the hash and protects mutations
+ * on a group of hash buckets.
+ *
+ * A maximum of tbl->size/2 bucket locks is allocated. This ensures that
+ * a single lock always covers both buckets which may both contains
+ * entries which link to the same bucket of the old table during resizing.
+ * This allows to simplify the locking as locking the bucket in both
+ * tables during resize always guarantee protection.
+ *
+ * IMPORTANT: When holding the bucket lock of both the old and new table
+ * during expansions and shrinking, the old bucket lock must always be
+ * acquired first.
+ */
+static inline spinlock_t *rht_bucket_lock(const struct bucket_table *tbl,
+					  unsigned int hash)
+{
+	return &tbl->locks[hash & tbl->locks_mask];
+}
+
+#ifdef CONFIG_PROVE_LOCKING
+int lockdep_rht_mutex_is_held(struct rhashtable *ht);
+int lockdep_rht_bucket_is_held(const struct bucket_table *tbl, u32 hash);
+#else
+static inline int lockdep_rht_mutex_is_held(struct rhashtable *ht)
+{
+	return 1;
+}
+
+static inline int lockdep_rht_bucket_is_held(const struct bucket_table *tbl,
+					     u32 hash)
+{
+	return 1;
+}
+#endif /* CONFIG_PROVE_LOCKING */
+
+int rhashtable_init(struct rhashtable *ht,
+		    const struct rhashtable_params *params);
+
+struct bucket_table *rhashtable_insert_slow(struct rhashtable *ht,
+					    const void *key,
+					    struct rhash_head *obj,
+					    struct bucket_table *old_tbl);
+int rhashtable_insert_rehash(struct rhashtable *ht, struct bucket_table *tbl);
+
+int rhashtable_walk_init(struct rhashtable *ht, struct rhashtable_iter *iter);
+void rhashtable_walk_exit(struct rhashtable_iter *iter);
+int rhashtable_walk_start(struct rhashtable_iter *iter) __acquires(RCU);
+void *rhashtable_walk_next(struct rhashtable_iter *iter);
+void rhashtable_walk_stop(struct rhashtable_iter *iter) __releases(RCU);
+
+void rhashtable_free_and_destroy(struct rhashtable *ht,
+				 void (*free_fn)(void *ptr, void *arg),
+				 void *arg);
+void rhashtable_destroy(struct rhashtable *ht);
+
+#define rht_dereference(p, ht) \
+	rcu_dereference_protected(p, lockdep_rht_mutex_is_held(ht))
+
+#define rht_dereference_rcu(p, ht) \
+	rcu_dereference_check(p, lockdep_rht_mutex_is_held(ht))
+
+#define rht_dereference_bucket(p, tbl, hash) \
+	rcu_dereference_protected(p, lockdep_rht_bucket_is_held(tbl, hash))
+
+#define rht_dereference_bucket_rcu(p, tbl, hash) \
+	rcu_dereference_check(p, lockdep_rht_bucket_is_held(tbl, hash))
+
+#define rht_entry(tpos, pos, member) \
+	({ tpos = container_of(pos, typeof(*tpos), member); 1; })
+
+/**
+ * rht_for_each_continue - continue iterating over hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ */
+#define rht_for_each_continue(pos, head, tbl, hash) \
+	for (pos = rht_dereference_bucket(head, tbl, hash); \
+	     !rht_is_a_nulls(pos); \
+	     pos = rht_dereference_bucket((pos)->next, tbl, hash))
+
+/**
+ * rht_for_each - iterate over hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ */
+#define rht_for_each(pos, tbl, hash) \
+	rht_for_each_continue(pos, (tbl)->buckets[hash], tbl, hash)
+
+/**
+ * rht_for_each_entry_continue - continue iterating over hash chain
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ */
+#define rht_for_each_entry_continue(tpos, pos, head, tbl, hash, member)	\
+	for (pos = rht_dereference_bucket(head, tbl, hash);		\
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	\
+	     pos = rht_dereference_bucket((pos)->next, tbl, hash))
+
+/**
+ * rht_for_each_entry - iterate over hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ */
+#define rht_for_each_entry(tpos, pos, tbl, hash, member)		\
+	rht_for_each_entry_continue(tpos, pos, (tbl)->buckets[hash],	\
+				    tbl, hash, member)
+
+/**
+ * rht_for_each_entry_safe - safely iterate over hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @next:	the &struct rhash_head to use as next in loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive allows for the looped code to
+ * remove the loop cursor from the list.
+ */
+#define rht_for_each_entry_safe(tpos, pos, next, tbl, hash, member)	    \
+	for (pos = rht_dereference_bucket((tbl)->buckets[hash], tbl, hash), \
+	     next = !rht_is_a_nulls(pos) ?				    \
+		       rht_dereference_bucket(pos->next, tbl, hash) : NULL; \
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	    \
+	     pos = next,						    \
+	     next = !rht_is_a_nulls(pos) ?				    \
+		       rht_dereference_bucket(pos->next, tbl, hash) : NULL)
+
+/**
+ * rht_for_each_rcu_continue - continue iterating over rcu hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_rcu_continue(pos, head, tbl, hash)			\
+	for (({barrier(); }),						\
+	     pos = rht_dereference_bucket_rcu(head, tbl, hash);		\
+	     !rht_is_a_nulls(pos);					\
+	     pos = rcu_dereference_raw(pos->next))
+
+/**
+ * rht_for_each_rcu - iterate over rcu hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_rcu(pos, tbl, hash)				\
+	rht_for_each_rcu_continue(pos, (tbl)->buckets[hash], tbl, hash)
+
+/**
+ * rht_for_each_entry_rcu_continue - continue iterating over rcu hash chain
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_entry_rcu_continue(tpos, pos, head, tbl, hash, member) \
+	for (({barrier(); }),						    \
+	     pos = rht_dereference_bucket_rcu(head, tbl, hash);		    \
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	    \
+	     pos = rht_dereference_bucket_rcu(pos->next, tbl, hash))
+
+/**
+ * rht_for_each_entry_rcu - iterate over rcu hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_entry_rcu(tpos, pos, tbl, hash, member)		\
+	rht_for_each_entry_rcu_continue(tpos, pos, (tbl)->buckets[hash],\
+					tbl, hash, member)
+
+static inline int rhashtable_compare(struct rhashtable_compare_arg *arg,
+				     const void *obj)
+{
+	struct rhashtable *ht = arg->ht;
+	const char *ptr = obj;
+
+	return memcmp(ptr + ht->p.key_offset, arg->key, ht->p.key_len);
+}
+
+/**
+ * rhashtable_lookup_fast - search hash table, inlined version
+ * @ht:		hash table
+ * @key:	the pointer to the key
+ * @params:	hash table parameters
+ *
+ * Computes the hash value for the key and traverses the bucket chain looking
+ * for a entry with an identical key. The first matching entry is returned.
+ *
+ * Returns the first entry on which the compare function returned true.
+ */
+static inline void *rhashtable_lookup_fast(
+	struct rhashtable *ht, const void *key,
+	const struct rhashtable_params params)
+{
+	struct rhashtable_compare_arg arg = {
+		.ht = ht,
+		.key = key,
+	};
+	const struct bucket_table *tbl;
+	struct rhash_head *he;
+	unsigned int hash;
+
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+restart:
+	hash = rht_key_hashfn(ht, tbl, key, params);
+	rht_for_each_rcu(he, tbl, hash) {
+		if (params.obj_cmpfn ?
+		    params.obj_cmpfn(&arg, rht_obj(ht, he)) :
+		    rhashtable_compare(&arg, rht_obj(ht, he)))
+			continue;
+		rcu_read_unlock();
+		return rht_obj(ht, he);
+	}
+
+	/* Ensure we see any new tables. */
+	smp_rmb();
+
+	tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (unlikely(tbl))
+		goto restart;
+	rcu_read_unlock();
+
+	return NULL;
+}
+
+/* Internal function, please use rhashtable_insert_fast() instead */
+static inline int __rhashtable_insert_fast(
+	struct rhashtable *ht, const void *key, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	struct rhashtable_compare_arg arg = {
+		.ht = ht,
+		.key = key,
+	};
+	struct bucket_table *tbl, *new_tbl;
+	struct rhash_head *head;
+	spinlock_t *lock;
+	unsigned int elasticity;
+	unsigned int hash;
+	int err;
+
+restart:
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	/* All insertions must grab the oldest table containing
+	 * the hashed bucket that is yet to be rehashed.
+	 */
+	for (;;) {
+		hash = rht_head_hashfn(ht, tbl, obj, params);
+		lock = rht_bucket_lock(tbl, hash);
+		spin_lock_bh(lock);
+
+		if (tbl->rehash <= hash)
+			break;
+
+		spin_unlock_bh(lock);
+		tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	}
+
+	new_tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (unlikely(new_tbl)) {
+		tbl = rhashtable_insert_slow(ht, key, obj, new_tbl);
+		if (!IS_ERR_OR_NULL(tbl))
+			goto slow_path;
+
+		err = PTR_ERR(tbl);
+		goto out;
+	}
+
+	err = -E2BIG;
+	if (unlikely(rht_grow_above_max(ht, tbl)))
+		goto out;
+
+	if (unlikely(rht_grow_above_100(ht, tbl))) {
+slow_path:
+		spin_unlock_bh(lock);
+		err = rhashtable_insert_rehash(ht, tbl);
+		rcu_read_unlock();
+		if (err)
+			return err;
+
+		goto restart;
+	}
+
+	err = -EEXIST;
+	elasticity = ht->elasticity;
+	rht_for_each(head, tbl, hash) {
+		if (key &&
+		    unlikely(!(params.obj_cmpfn ?
+			       params.obj_cmpfn(&arg, rht_obj(ht, head)) :
+			       rhashtable_compare(&arg, rht_obj(ht, head)))))
+			goto out;
+		if (!--elasticity)
+			goto slow_path;
+	}
+
+	err = 0;
+
+	head = rht_dereference_bucket(tbl->buckets[hash], tbl, hash);
+
+	RCU_INIT_POINTER(obj->next, head);
+
+	rcu_assign_pointer(tbl->buckets[hash], obj);
+
+	atomic_inc(&ht->nelems);
+	if (rht_grow_above_75(ht, tbl))
+		schedule_work(&ht->run_work);
+
+out:
+	spin_unlock_bh(lock);
+	rcu_read_unlock();
+
+	return err;
+}
+
+/**
+ * rhashtable_insert_fast - insert object into hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Will take a per bucket spinlock to protect against mutual mutations
+ * on the same bucket. Multiple insertions may occur in parallel unless
+ * they map to the same bucket lock.
+ *
+ * It is safe to call this function from atomic context.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ */
+static inline int rhashtable_insert_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	return __rhashtable_insert_fast(ht, NULL, obj, params);
+}
+
+/**
+ * rhashtable_lookup_insert_fast - lookup and insert object into hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Locks down the bucket chain in both the old and new table if a resize
+ * is in progress to ensure that writers can't remove from the old table
+ * and can't insert to the new table during the atomic operation of search
+ * and insertion. Searches for duplicates in both the old and new table if
+ * a resize is in progress.
+ *
+ * This lookup function may only be used for fixed key hash table (key_len
+ * parameter set). It will BUG() if used inappropriately.
+ *
+ * It is safe to call this function from atomic context.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ */
+static inline int rhashtable_lookup_insert_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	const char *key = rht_obj(ht, obj);
+
+	BUG_ON(ht->p.obj_hashfn);
+
+	return __rhashtable_insert_fast(ht, key + ht->p.key_offset, obj,
+					params);
+}
+
+/**
+ * rhashtable_lookup_insert_key - search and insert object to hash table
+ *				  with explicit key
+ * @ht:		hash table
+ * @key:	key
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Locks down the bucket chain in both the old and new table if a resize
+ * is in progress to ensure that writers can't remove from the old table
+ * and can't insert to the new table during the atomic operation of search
+ * and insertion. Searches for duplicates in both the old and new table if
+ * a resize is in progress.
+ *
+ * Lookups may occur in parallel with hashtable mutations and resizing.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ *
+ * Returns zero on success.
+ */
+static inline int rhashtable_lookup_insert_key(
+	struct rhashtable *ht, const void *key, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	BUG_ON(!ht->p.obj_hashfn || !key);
+
+	return __rhashtable_insert_fast(ht, key, obj, params);
+}
+
+/* Internal function, please use rhashtable_remove_fast() instead */
+static inline int __rhashtable_remove_fast(
+	struct rhashtable *ht, struct bucket_table *tbl,
+	struct rhash_head *obj, const struct rhashtable_params params)
+{
+	struct rhash_head __rcu **pprev;
+	struct rhash_head *he;
+	spinlock_t * lock;
+	unsigned int hash;
+	int err = -ENOENT;
+
+	hash = rht_head_hashfn(ht, tbl, obj, params);
+	lock = rht_bucket_lock(tbl, hash);
+
+	spin_lock_bh(lock);
+
+	pprev = &tbl->buckets[hash];
+	rht_for_each(he, tbl, hash) {
+		if (he != obj) {
+			pprev = &he->next;
+			continue;
+		}
+
+		rcu_assign_pointer(*pprev, obj->next);
+		err = 0;
+		break;
+	}
+
+	spin_unlock_bh(lock);
+
+	return err;
+}
+
+/**
+ * rhashtable_remove_fast - remove object from hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Since the hash chain is single linked, the removal operation needs to
+ * walk the bucket chain upon removal. The removal operation is thus
+ * considerable slow if the hash table is not correctly sized.
+ *
+ * Will automatically shrink the table via rhashtable_expand() if the
+ * shrink_decision function specified at rhashtable_init() returns true.
+ *
+ * Returns zero on success, -ENOENT if the entry could not be found.
+ */
+static inline int rhashtable_remove_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	struct bucket_table *tbl;
+	int err;
+
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	/* Because we have already taken (and released) the bucket
+	 * lock in old_tbl, if we find that future_tbl is not yet
+	 * visible then that guarantees the entry to still be in
+	 * the old tbl if it exists.
+	 */
+	while ((err = __rhashtable_remove_fast(ht, tbl, obj, params)) &&
+	       (tbl = rht_dereference_rcu(tbl->future_tbl, ht)))
+		;
+
+	if (err)
+		goto out;
+
+	atomic_dec(&ht->nelems);
+	if (unlikely(ht->p.automatic_shrinking &&
+		     rht_shrink_below_30(ht, tbl)))
+		schedule_work(&ht->run_work);
+
+out:
+	rcu_read_unlock();
+
+	return err;
+}
+
+#endif /* _LINUX_RHASHTABLE_H */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_android.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_android.c
index 8de7ff72ff36..a3cd6757e090 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_android.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_android.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #ifdef CONFIG_GPIO_WAKEUP
 #include <linux/gpio.h>
@@ -27,9 +23,9 @@
 #if defined(RTW_ENABLE_WIFI_CONTROL_FUNC)
 #include <linux/platform_device.h>
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
-#include <linux/wlan_plat.h>
+	#include <linux/wlan_plat.h>
 #else
-#include <linux/wifi_tiwlan.h>
+	#include <linux/wifi_tiwlan.h>
 #endif
 #endif /* defined(RTW_ENABLE_WIFI_CONTROL_FUNC) */
 
@@ -95,16 +91,17 @@ const char *android_wifi_cmd_str[ANDROID_WIFI_CMD_MAX] = {
 	"HOSTAPD_ACL_REMOVE_STA",
 #if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
 	"GTK_REKEY_OFFLOAD",
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
 /*	Private command for	P2P disable*/
 	"P2P_DISABLE",
+	"SET_AEK",
 	"DRIVER_VERSION"
 };
 
 #ifdef CONFIG_PNO_SUPPORT
 #define PNO_TLV_PREFIX			'S'
 #define PNO_TLV_VERSION			'1'
-#define PNO_TLV_SUBVERSION 		'2'
+#define PNO_TLV_SUBVERSION		'2'
 #define PNO_TLV_RESERVED		'0'
 #define PNO_TLV_TYPE_SSID_IE	'S'
 #define PNO_TLV_TYPE_TIME		'T'
@@ -120,28 +117,28 @@ typedef struct cmd_tlv {
 
 #ifdef CONFIG_PNO_SET_DEBUG
 char pno_in_example[] = {
-		'P', 'N', 'O', 'S', 'E', 'T', 'U', 'P', ' ',
-		'S', '1', '2', '0',
-		'S',	//1
-		0x05,
-		'd', 'l', 'i', 'n', 'k',
-		'S',	//2
-		0x06,
-		'B', 'U', 'F', 'B', 'U','F',
-		'S',	//3
-		0x20,
-		'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '!', '@', '#', '$', '%', '^',
-		'S',	//4
-		0x0a,
-		'!', '@', '#', '$', '%', '^', '&', '*', '(', ')',
-		'T',
-		'0', '5',
-		'R',
-		'2',
-		'M',
-		'2',
-		0x00
-		};
+	'P', 'N', 'O', 'S', 'E', 'T', 'U', 'P', ' ',
+	'S', '1', '2', '0',
+	'S',	/* 1 */
+	0x05,
+	'd', 'l', 'i', 'n', 'k',
+	'S',	/* 2 */
+	0x06,
+	'B', 'U', 'F', 'B', 'U', 'F',
+	'S',	/* 3 */
+	0x20,
+	'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '!', '@', '#', '$', '%', '^',
+	'S',	/* 4 */
+	0x0a,
+	'!', '@', '#', '$', '%', '^', '&', '*', '(', ')',
+	'T',
+	'0', '5',
+	'R',
+	'2',
+	'M',
+	'2',
+	0x00
+};
 #endif /* CONFIG_PNO_SET_DEBUG */
 #endif /* PNO_SUPPORT */
 
@@ -173,18 +170,19 @@ unsigned int oob_irq = 0;
 unsigned int oob_gpio = 0;
 
 #ifdef CONFIG_PNO_SUPPORT
-/* 
+/*
  * rtw_android_pno_setup
- * Description: 
+ * Description:
  * This is used for private command.
- * 
+ *
  * Parameter:
  * net: net_device
  * command: parameters from private command
  * total_len: the length of the command.
  *
  * */
-static int rtw_android_pno_setup(struct net_device *net, char *command, int total_len) {
+static int rtw_android_pno_setup(struct net_device *net, char *command, int total_len)
+{
 	pno_ssid_t pno_ssids_local[MAX_PNO_LIST_COUNT];
 	int res = -1;
 	int nssid = 0;
@@ -194,7 +192,7 @@ static int rtw_android_pno_setup(struct net_device *net, char *command, int tota
 	int pno_time = 0;
 	int pno_repeat = 0;
 	int pno_freq_expo_max = 0;
-	int cmdlen = strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_PNOSETUP_SET]) + 1; 
+	int cmdlen = strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_PNOSETUP_SET]) + 1;
 
 #ifdef CONFIG_PNO_SET_DEBUG
 	int i;
@@ -208,7 +206,7 @@ static int rtw_android_pno_setup(struct net_device *net, char *command, int tota
 #endif
 
 	if (total_len < (cmdlen + sizeof(cmd_tlv_t))) {
-		DBG_871X("%s argument=%d less min size\n", __func__, total_len);
+		RTW_INFO("%s argument=%d less min size\n", __func__, total_len);
 		goto exit_proc;
 	}
 
@@ -218,48 +216,49 @@ static int rtw_android_pno_setup(struct net_device *net, char *command, int tota
 	memset(pno_ssids_local, 0, sizeof(pno_ssids_local));
 
 	if ((cmd_tlv_temp->prefix == PNO_TLV_PREFIX) &&
-		(cmd_tlv_temp->version == PNO_TLV_VERSION) &&
-		(cmd_tlv_temp->subver == PNO_TLV_SUBVERSION)) {
+	    (cmd_tlv_temp->version == PNO_TLV_VERSION) &&
+	    (cmd_tlv_temp->subver == PNO_TLV_SUBVERSION)) {
 
 		str_ptr += sizeof(cmd_tlv_t);
 		tlv_size_left -= sizeof(cmd_tlv_t);
 
-		if ((nssid = rtw_parse_ssid_list_tlv(&str_ptr, pno_ssids_local,
-			MAX_PNO_LIST_COUNT, &tlv_size_left)) <= 0) {
-			DBG_871X("SSID is not presented or corrupted ret=%d\n", nssid);
+		nssid = rtw_parse_ssid_list_tlv(&str_ptr, pno_ssids_local,
+			     MAX_PNO_LIST_COUNT, &tlv_size_left);
+		if (nssid <= 0) {
+			RTW_INFO("SSID is not presented or corrupted ret=%d\n", nssid);
 			goto exit_proc;
 		} else {
 			if ((str_ptr[0] != PNO_TLV_TYPE_TIME) || (tlv_size_left <= 1)) {
-				DBG_871X("%s scan duration corrupted field size %d\n",
-					__func__, tlv_size_left);
+				RTW_INFO("%s scan duration corrupted field size %d\n",
+					 __func__, tlv_size_left);
 				goto exit_proc;
 			}
 			str_ptr++;
 			pno_time = simple_strtoul(str_ptr, &str_ptr, 16);
-			DBG_871X("%s: pno_time=%d\n", __func__, pno_time);
+			RTW_INFO("%s: pno_time=%d\n", __func__, pno_time);
 
 			if (str_ptr[0] != 0) {
 				if ((str_ptr[0] != PNO_TLV_FREQ_REPEAT)) {
-					DBG_871X("%s pno repeat : corrupted field\n",
-						__func__);
+					RTW_INFO("%s pno repeat : corrupted field\n",
+						 __func__);
 					goto exit_proc;
 				}
 				str_ptr++;
 				pno_repeat = simple_strtoul(str_ptr, &str_ptr, 16);
-				DBG_871X("%s :got pno_repeat=%d\n", __FUNCTION__, pno_repeat);
+				RTW_INFO("%s :got pno_repeat=%d\n", __FUNCTION__, pno_repeat);
 				if (str_ptr[0] != PNO_TLV_FREQ_EXPO_MAX) {
-					DBG_871X("%s FREQ_EXPO_MAX corrupted field size\n",
-						__func__);
+					RTW_INFO("%s FREQ_EXPO_MAX corrupted field size\n",
+						 __func__);
 					goto exit_proc;
 				}
 				str_ptr++;
 				pno_freq_expo_max = simple_strtoul(str_ptr, &str_ptr, 16);
-				DBG_871X("%s: pno_freq_expo_max=%d\n",
-					__func__, pno_freq_expo_max);
+				RTW_INFO("%s: pno_freq_expo_max=%d\n",
+					 __func__, pno_freq_expo_max);
 			}
 		}
 	} else {
-		DBG_871X("%s get wrong TLV command\n", __FUNCTION__);
+		RTW_INFO("%s get wrong TLV command\n", __FUNCTION__);
 		goto exit_proc;
 	}
 
@@ -273,18 +272,19 @@ exit_proc:
 	return res;
 }
 
-/* 
+/*
  * rtw_android_cfg80211_pno_setup
- * Description: 
+ * Description:
  * This is used for cfg80211 sched_scan.
- * 
+ *
  * Parameter:
  * net: net_device
  * request: cfg80211_request
  * */
 
 int rtw_android_cfg80211_pno_setup(struct net_device *net,
-		struct cfg80211_ssid *ssids, int n_ssids, int interval) {
+		   struct cfg80211_ssid *ssids, int n_ssids, int interval)
+{
 	int res = -1;
 	int nssid = 0;
 	int pno_time = 0;
@@ -294,7 +294,7 @@ int rtw_android_cfg80211_pno_setup(struct net_device *net,
 	pno_ssid_t pno_ssids_local[MAX_PNO_LIST_COUNT];
 
 	if (n_ssids > MAX_PNO_LIST_COUNT || n_ssids < 0) {
-		DBG_871X("%s: nssids(%d) is invalid.\n", __func__, n_ssids);
+		RTW_INFO("%s: nssids(%d) is invalid.\n", __func__, n_ssids);
 		return -EINVAL;
 	}
 
@@ -305,27 +305,34 @@ int rtw_android_cfg80211_pno_setup(struct net_device *net,
 	for (index = 0 ; index < nssid ; index++) {
 		pno_ssids_local[index].SSID_len = ssids[index].ssid_len;
 		memcpy(pno_ssids_local[index].SSID, ssids[index].ssid,
-				ssids[index].ssid_len);
+		       ssids[index].ssid_len);
 	}
-
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
+	if(ssids)
+		rtw_mfree((u8 *)ssids, (n_ssids * sizeof(struct cfg80211_ssid)));
+#endif
 	pno_time = (interval / 1000);
 
-	DBG_871X("%s: nssids: %d, pno_time=%d\n", __func__, nssid, pno_time);
+	RTW_INFO("%s: nssids: %d, pno_time=%d\n", __func__, nssid, pno_time);
 
 	res = rtw_dev_pno_set(net, pno_ssids_local, nssid, pno_time,
-			pno_repeat, pno_freq_expo_max);
+			      pno_repeat, pno_freq_expo_max);
 
+#ifdef CONFIG_PNO_SET_DEBUG
+	rtw_dev_pno_debug(net);
+#endif
 exit_proc:
 	return res;
 }
 
-int rtw_android_pno_enable(struct net_device *net, int pno_enable) {
+int rtw_android_pno_enable(struct net_device *net, int pno_enable)
+{
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 
 	if (pwrctl) {
 		pwrctl->wowlan_pno_enable = pno_enable;
-		DBG_871X("%s: wowlan_pno_enable: %d\n", __func__, pwrctl->wowlan_pno_enable);
+		RTW_INFO("%s: wowlan_pno_enable: %d\n", __func__, pwrctl->wowlan_pno_enable);
 		if (pwrctl->wowlan_pno_enable == 0) {
 			if (pwrctl->pnlo_info != NULL) {
 				rtw_mfree((u8 *)pwrctl->pnlo_info, sizeof(pno_nlo_info_t));
@@ -339,19 +346,18 @@ int rtw_android_pno_enable(struct net_device *net, int pno_enable) {
 				rtw_mfree((u8 *)pwrctl->pscan_info, sizeof(pno_scan_info_t));
 				pwrctl->pscan_info = NULL;
 			}
-		} 
+		}
 		return 0;
-	} else {
+	} else
 		return -1;
-	}
 }
-#endif //CONFIG_PNO_SUPPORT
+#endif /* CONFIG_PNO_SUPPORT */
 
 int rtw_android_cmdstr_to_num(char *cmdstr)
 {
 	int cmd_num;
-	for(cmd_num=0 ; cmd_num<ANDROID_WIFI_CMD_MAX; cmd_num++)
-		if(0 == strnicmp(cmdstr , android_wifi_cmd_str[cmd_num], strlen(android_wifi_cmd_str[cmd_num])) )
+	for (cmd_num = 0 ; cmd_num < ANDROID_WIFI_CMD_MAX; cmd_num++)
+		if (0 == strnicmp(cmdstr , android_wifi_cmd_str[cmd_num], strlen(android_wifi_cmd_str[cmd_num])))
 			break;
 
 	return cmd_num;
@@ -360,12 +366,12 @@ int rtw_android_cmdstr_to_num(char *cmdstr)
 int rtw_android_get_rssi(struct net_device *net, char *command, int total_len)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);	
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
 	int bytes_written = 0;
 
-	if(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {	
-		bytes_written += snprintf(&command[bytes_written], total_len, "%s rssi %d", 
+	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+		bytes_written += snprintf(&command[bytes_written], total_len, "%s rssi %d",
 			pcur_network->network.Ssid.Ssid, padapter->recvpriv.rssi);
 	}
 
@@ -375,12 +381,12 @@ int rtw_android_get_rssi(struct net_device *net, char *command, int total_len)
 int rtw_android_get_link_speed(struct net_device *net, char *command, int total_len)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);	
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
 	int bytes_written = 0;
 	u16 link_speed = 0;
 
-	link_speed = rtw_get_cur_max_rate(padapter)/10;
+	link_speed = rtw_get_cur_max_rate(padapter) / 10;
 	bytes_written = snprintf(command, total_len, "LinkSpeed %d", link_speed);
 
 	return bytes_written;
@@ -390,7 +396,7 @@ int rtw_android_get_macaddr(struct net_device *net, char *command, int total_len
 {
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
 	int bytes_written = 0;
-	
+
 	bytes_written = snprintf(command, total_len, "Macaddr = "MAC_FMT, MAC_ARG(net->dev_addr));
 	return bytes_written;
 }
@@ -400,19 +406,19 @@ int rtw_android_set_country(struct net_device *net, char *command, int total_len
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
 	char *country_code = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_COUNTRY]) + 1;
 	int ret = _FAIL;
-	
+
 	ret = rtw_set_country(adapter, country_code);
 
-	return (ret==_SUCCESS)?0:-1;
+	return (ret == _SUCCESS) ? 0 : -1;
 }
 
 int rtw_android_get_p2p_dev_addr(struct net_device *net, char *command, int total_len)
 {
 	int bytes_written = 0;
 
-	//We use the same address as our HW MAC address
+	/* We use the same address as our HW MAC address */
 	_rtw_memcpy(command, net->dev_addr, ETH_ALEN);
-	
+
 	bytes_written = ETH_ALEN;
 	return bytes_written;
 }
@@ -422,9 +428,9 @@ int rtw_android_set_block_scan(struct net_device *net, char *command, int total_
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
 	char *block_value = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_BLOCK_SCAN]) + 1;
 
-	#ifdef CONFIG_IOCTL_CFG80211
-	adapter_wdev_data(adapter)->block_scan = (*block_value == '0')?_FALSE:_TRUE;
-	#endif
+#ifdef CONFIG_IOCTL_CFG80211
+	adapter_wdev_data(adapter)->block_scan = (*block_value == '0') ? _FALSE : _TRUE;
+#endif
 
 	return 0;
 }
@@ -434,10 +440,10 @@ int rtw_android_set_block(struct net_device *net, char *command, int total_len)
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
 	char *block_value = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_BLOCK]) + 1;
 
-	#ifdef CONFIG_IOCTL_CFG80211
-	adapter_wdev_data(adapter)->block = (*block_value=='0')?_FALSE:_TRUE;
-	#endif
-	
+#ifdef CONFIG_IOCTL_CFG80211
+	adapter_wdev_data(adapter)->block = (*block_value == '0') ? _FALSE : _TRUE;
+#endif
+
 	return 0;
 }
 
@@ -451,7 +457,7 @@ int rtw_android_setband(struct net_device *net, char *command, int total_len)
 	if (sscanf(arg, "%u", &band) >= 1)
 		ret = rtw_set_band(adapter, band);
 
-	return (ret==_SUCCESS)?0:-1;
+	return (ret == _SUCCESS) ? 0 : -1;
 }
 
 int rtw_android_getband(struct net_device *net, char *command, int total_len)
@@ -492,53 +498,48 @@ int rtw_android_set_miracast_mode(struct net_device *net, char *command, int tot
 		break;
 	}
 	wfd_info->stack_wfd_mode = mode;
-	DBG_871X("stack miracast mode: %s\n", get_miracast_mode_str(wfd_info->stack_wfd_mode));
+	RTW_INFO("stack miracast mode: %s\n", get_miracast_mode_str(wfd_info->stack_wfd_mode));
 
 	ret = _SUCCESS;
 
 exit:
-	return (ret == _SUCCESS)?0:-1;
+	return (ret == _SUCCESS) ? 0 : -1;
 }
 #endif /* CONFIG_WFD */
 
-int get_int_from_command( char* pcmd )
+int get_int_from_command(char *pcmd)
 {
 	int i = 0;
 
-	for( i = 0; i < strlen( pcmd ); i++ )
-	{
-		if ( pcmd[ i ] == '=' )
-		{
-			//	Skip the '=' and space characters.
+	for (i = 0; i < strlen(pcmd); i++) {
+		if (pcmd[i] == '=') {
+			/*	Skip the '=' and space characters. */
 			i += 2;
 			break;
 		}
 	}
-	return ( rtw_atoi( pcmd + i ) );
+	return rtw_atoi(pcmd + i) ;
 }
 
 #if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
 int rtw_gtk_offload(struct net_device *net, u8 *cmd_ptr)
 {
 	int i;
-	//u8 *cmd_ptr = priv_cmd.buf;
-	struct sta_info * psta;
+	/* u8 *cmd_ptr = priv_cmd.buf; */
+	struct sta_info *psta;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct security_priv* psecuritypriv=&(padapter->securitypriv);
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
 	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
-	
-	
-	if (psta == NULL) 
-	{
-		DBG_8192C("%s, : Obtain Sta_info fail \n", __func__);
-	}
-	else
-	{
-		//string command length of "GTK_REKEY_OFFLOAD"
+
+
+	if (psta == NULL)
+		RTW_INFO("%s, : Obtain Sta_info fail\n", __func__);
+	else {
+		/* string command length of "GTK_REKEY_OFFLOAD" */
 		cmd_ptr += 18;
-		
+
 		_rtw_memcpy(psta->kek, cmd_ptr, RTW_KEK_LEN);
 		cmd_ptr += RTW_KEK_LEN;
 		/*
@@ -555,15 +556,47 @@ int rtw_gtk_offload(struct net_device *net, u8 *cmd_ptr)
 		*/
 		_rtw_memcpy(psta->replay_ctr, cmd_ptr, RTW_REPLAY_CTR_LEN);
 		psecuritypriv->binstallKCK_KEK = _TRUE;
-		
-		//printk("\nREPLAY_CTR: ");
-		//for(i=0;i<RTW_REPLAY_CTR_LEN; i++)
-			//printk(" %02x ", psta->replay_ctr[i]);
+
+		/* printk("\nREPLAY_CTR: "); */
+		/* for(i=0;i<RTW_REPLAY_CTR_LEN; i++) */
+		/* printk(" %02x ", psta->replay_ctr[i]); */
 	}
 
 	return _SUCCESS;
 }
-#endif //CONFIG_GTK_OL
+#endif /* CONFIG_GTK_OL */
+
+#ifdef CONFIG_RTW_MESH_AEK
+static int rtw_android_set_aek(struct net_device *ndev, char *command, int total_len)
+{
+#define SET_AEK_DATA_LEN (ETH_ALEN + 32)
+
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	u8 *addr;
+	u8 *aek;
+	int err = 0;
+
+	if (total_len - strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AEK]) - 1 != SET_AEK_DATA_LEN) {
+		err = -EINVAL;
+		goto exit;
+	}
+
+	addr = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AEK]) + 1;
+	aek = addr + ETH_ALEN;
+
+	RTW_PRINT(FUNC_NDEV_FMT" addr="MAC_FMT"\n"
+		, FUNC_NDEV_ARG(ndev), MAC_ARG(addr));
+	if (0)
+		RTW_PRINT(FUNC_NDEV_FMT" aek="KEY_FMT KEY_FMT"\n"
+			, FUNC_NDEV_ARG(ndev), KEY_ARG(aek), KEY_ARG(aek + 16));
+
+	if (rtw_mesh_plink_set_aek(adapter, addr, aek) != _SUCCESS)
+		err = -ENOENT;
+
+exit:
+	return err;
+}
+#endif /* CONFIG_RTW_MESH_AEK */
 
 int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 {
@@ -576,7 +609,7 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 	uint pno_enable = 0;
 #endif
 	android_wifi_priv_cmd priv_cmd;
-	_adapter*	padapter = ( _adapter * ) rtw_netdev_priv(net);
+	_adapter	*padapter = (_adapter *) rtw_netdev_priv(net);
 #ifdef CONFIG_WFD
 	struct wifi_display_info		*pwfd_info;
 #endif
@@ -588,11 +621,15 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		goto exit;
 	}
 	if (padapter->registrypriv.mp_mode == 1) {
-			ret = -EINVAL;
-			goto exit;
+		ret = -EINVAL;
+		goto exit;
 	}
 #ifdef CONFIG_COMPAT
+#if (KERNEL_VERSION(4, 6, 0) > LINUX_VERSION_CODE)
 	if (is_compat_task()) {
+#else
+	if (in_compat_syscall()) {
+#endif
 		/* User space is 32-bit, use compat ioctl */
 		compat_android_wifi_priv_cmd compat_priv_cmd;
 
@@ -605,49 +642,48 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		priv_cmd.total_len = compat_priv_cmd.total_len;
 	} else
 #endif /* CONFIG_COMPAT */
-	if (copy_from_user(&priv_cmd, ifr->ifr_data, sizeof(android_wifi_priv_cmd))) {
-		ret = -EFAULT;
-		goto exit;
-	}
-	if ( padapter->registrypriv.mp_mode == 1) {
+		if (copy_from_user(&priv_cmd, ifr->ifr_data, sizeof(android_wifi_priv_cmd))) {
+			ret = -EFAULT;
+			goto exit;
+		}
+	if (padapter->registrypriv.mp_mode == 1) {
 		ret = -EFAULT;
 		goto exit;
 	}
-	/*DBG_871X("%s priv_cmd.buf=%p priv_cmd.total_len=%d  priv_cmd.used_len=%d\n",__func__,priv_cmd.buf,priv_cmd.total_len,priv_cmd.used_len);*/
+	/*RTW_INFO("%s priv_cmd.buf=%p priv_cmd.total_len=%d  priv_cmd.used_len=%d\n",__func__,priv_cmd.buf,priv_cmd.total_len,priv_cmd.used_len);*/
 	command = rtw_zmalloc(priv_cmd.total_len);
-	if (!command)
-	{
-		DBG_871X("%s: failed to allocate memory\n", __FUNCTION__);
+	if (!command) {
+		RTW_INFO("%s: failed to allocate memory\n", __FUNCTION__);
 		ret = -ENOMEM;
 		goto exit;
 	}
 
-	if (!access_ok(VERIFY_READ, priv_cmd.buf, priv_cmd.total_len)){
-	 	DBG_871X("%s: failed to access memory\n", __FUNCTION__);
+	if (!access_ok(VERIFY_READ, priv_cmd.buf, priv_cmd.total_len)) {
+		RTW_INFO("%s: failed to access memory\n", __FUNCTION__);
 		ret = -EFAULT;
 		goto exit;
-	 }
+	}
 	if (copy_from_user(command, (void *)priv_cmd.buf, priv_cmd.total_len)) {
 		ret = -EFAULT;
 		goto exit;
 	}
 
-	DBG_871X("%s: Android private cmd \"%s\" on %s\n"
-		, __FUNCTION__, command, ifr->ifr_name);
+	RTW_INFO("%s: Android private cmd \"%s\" on %s\n"
+		 , __FUNCTION__, command, ifr->ifr_name);
 
 	cmd_num = rtw_android_cmdstr_to_num(command);
-	
-	switch(cmd_num) {
+
+	switch (cmd_num) {
 	case ANDROID_WIFI_CMD_START:
-		//bytes_written = wl_android_wifi_on(net);
+		/* bytes_written = wl_android_wifi_on(net); */
 		goto response;
 	case ANDROID_WIFI_CMD_SETFWPATH:
 		goto response;
 	}
 
 	if (!g_wifi_on) {
-		DBG_871X("%s: Ignore private cmd \"%s\" - iface %s is down\n"
-			,__FUNCTION__, command, ifr->ifr_name);
+		RTW_INFO("%s: Ignore private cmd \"%s\" - iface %s is down\n"
+			 , __FUNCTION__, command, ifr->ifr_name);
 		ret = 0;
 		goto exit;
 	}
@@ -663,24 +699,24 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		}
 	}
 
-	switch(cmd_num) {
+	switch (cmd_num) {
 
 	case ANDROID_WIFI_CMD_STOP:
-		//bytes_written = wl_android_wifi_off(net);
+		/* bytes_written = wl_android_wifi_off(net); */
 		break;
-		
+
 	case ANDROID_WIFI_CMD_SCAN_ACTIVE:
-		//rtw_set_scan_mode((_adapter *)rtw_netdev_priv(net), SCAN_ACTIVE);
+		/* rtw_set_scan_mode((_adapter *)rtw_netdev_priv(net), SCAN_ACTIVE); */
 #ifdef CONFIG_PLATFORM_MSTAR
 #ifdef CONFIG_IOCTL_CFG80211
 		adapter_wdev_data((_adapter *)rtw_netdev_priv(net))->bandroid_scan = _TRUE;
-#endif //CONFIG_IOCTL_CFG80211
-#endif //CONFIG_PLATFORM_MSTAR
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_PLATFORM_MSTAR */
 		break;
 	case ANDROID_WIFI_CMD_SCAN_PASSIVE:
-		//rtw_set_scan_mode((_adapter *)rtw_netdev_priv(net), SCAN_PASSIVE);
+		/* rtw_set_scan_mode((_adapter *)rtw_netdev_priv(net), SCAN_PASSIVE); */
 		break;
-		
+
 	case ANDROID_WIFI_CMD_RSSI:
 		bytes_written = rtw_android_get_rssi(net, command, priv_cmd.total_len);
 		break;
@@ -699,22 +735,22 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 	case ANDROID_WIFI_CMD_BLOCK:
 		bytes_written = rtw_android_set_block(net, command, priv_cmd.total_len);
 		break;
-		
+
 	case ANDROID_WIFI_CMD_RXFILTER_START:
-		//bytes_written = net_os_set_packet_filter(net, 1);
+		/* bytes_written = net_os_set_packet_filter(net, 1); */
 		break;
 	case ANDROID_WIFI_CMD_RXFILTER_STOP:
-		//bytes_written = net_os_set_packet_filter(net, 0);
+		/* bytes_written = net_os_set_packet_filter(net, 0); */
 		break;
 	case ANDROID_WIFI_CMD_RXFILTER_ADD:
-		//int filter_num = *(command + strlen(CMD_RXFILTER_ADD) + 1) - '0';
-		//bytes_written = net_os_rxfilter_add_remove(net, TRUE, filter_num);
+		/* int filter_num = *(command + strlen(CMD_RXFILTER_ADD) + 1) - '0'; */
+		/* bytes_written = net_os_rxfilter_add_remove(net, TRUE, filter_num); */
 		break;
 	case ANDROID_WIFI_CMD_RXFILTER_REMOVE:
-		//int filter_num = *(command + strlen(CMD_RXFILTER_REMOVE) + 1) - '0';
-		//bytes_written = net_os_rxfilter_add_remove(net, FALSE, filter_num);
+		/* int filter_num = *(command + strlen(CMD_RXFILTER_REMOVE) + 1) - '0'; */
+		/* bytes_written = net_os_rxfilter_add_remove(net, FALSE, filter_num); */
 		break;
-		
+
 	case ANDROID_WIFI_CMD_BTCOEXSCAN_START:
 		/* TBD: BTCOEXSCAN-START */
 		break;
@@ -722,7 +758,7 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		/* TBD: BTCOEXSCAN-STOP */
 		break;
 	case ANDROID_WIFI_CMD_BTCOEXMODE:
-		#if 0
+#if 0
 		uint mode = *(command + strlen(CMD_BTCOEXMODE) + 1) - '0';
 		if (mode == 1)
 			net_os_set_packet_filter(net, 0); /* DHCP starts */
@@ -731,13 +767,13 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 #ifdef WL_CFG80211
 		bytes_written = wl_cfg80211_set_btcoex_dhcp(net, command);
 #endif
-		#endif
+#endif
 		break;
-		
+
 	case ANDROID_WIFI_CMD_SETSUSPENDOPT:
-		//bytes_written = wl_android_set_suspendopt(net, command, priv_cmd.total_len);
+		/* bytes_written = wl_android_set_suspendopt(net, command, priv_cmd.total_len); */
 		break;
-		
+
 	case ANDROID_WIFI_CMD_SETBAND:
 		bytes_written = rtw_android_setband(net, command, priv_cmd.total_len);
 		break;
@@ -749,10 +785,10 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 	case ANDROID_WIFI_CMD_COUNTRY:
 		bytes_written = rtw_android_set_country(net, command, priv_cmd.total_len);
 		break;
-		
+
 #ifdef CONFIG_PNO_SUPPORT
 	case ANDROID_WIFI_CMD_PNOSSIDCLR_SET:
-		//bytes_written = dhd_dev_pno_reset(net);
+		/* bytes_written = dhd_dev_pno_reset(net); */
 		break;
 	case ANDROID_WIFI_CMD_PNOSETUP_SET:
 		bytes_written = rtw_android_pno_setup(net, command, priv_cmd.total_len);
@@ -768,25 +804,24 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		bytes_written = rtw_android_get_p2p_dev_addr(net, command, priv_cmd.total_len);
 		break;
 	case ANDROID_WIFI_CMD_P2P_SET_NOA:
-		//int skip = strlen(CMD_P2P_SET_NOA) + 1;
-		//bytes_written = wl_cfg80211_set_p2p_noa(net, command + skip, priv_cmd.total_len - skip);
+		/* int skip = strlen(CMD_P2P_SET_NOA) + 1; */
+		/* bytes_written = wl_cfg80211_set_p2p_noa(net, command + skip, priv_cmd.total_len - skip); */
 		break;
 	case ANDROID_WIFI_CMD_P2P_GET_NOA:
-		//bytes_written = wl_cfg80211_get_p2p_noa(net, command, priv_cmd.total_len);
+		/* bytes_written = wl_cfg80211_get_p2p_noa(net, command, priv_cmd.total_len); */
 		break;
 	case ANDROID_WIFI_CMD_P2P_SET_PS:
-		//int skip = strlen(CMD_P2P_SET_PS) + 1;
-		//bytes_written = wl_cfg80211_set_p2p_ps(net, command + skip, priv_cmd.total_len - skip);
+		/* int skip = strlen(CMD_P2P_SET_PS) + 1; */
+		/* bytes_written = wl_cfg80211_set_p2p_ps(net, command + skip, priv_cmd.total_len - skip); */
 		break;
-		
+
 #ifdef CONFIG_IOCTL_CFG80211
-	case ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE:
-	{
+	case ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE: {
 		int skip = strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE]) + 3;
 		bytes_written = rtw_cfg80211_set_mgnt_wpsp2pie(net, command + skip, priv_cmd.total_len - skip, *(command + skip - 2) - '0');
 		break;
 	}
-#endif //CONFIG_IOCTL_CFG80211
+#endif /* CONFIG_IOCTL_CFG80211 */
 
 #ifdef CONFIG_WFD
 
@@ -794,115 +829,112 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		bytes_written = rtw_android_set_miracast_mode(net, command, priv_cmd.total_len);
 		break;
 
-	case ANDROID_WIFI_CMD_WFD_ENABLE:
-	{
-		//	Commented by Albert 2012/07/24
-		//	We can enable the WFD function by using the following command:
-		//	wpa_cli driver wfd-enable
+	case ANDROID_WIFI_CMD_WFD_ENABLE: {
+		/*	Commented by Albert 2012/07/24 */
+		/*	We can enable the WFD function by using the following command: */
+		/*	wpa_cli driver wfd-enable */
 
 		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
 			rtw_wfd_enable(padapter, 1);
 		break;
 	}
 
-	case ANDROID_WIFI_CMD_WFD_DISABLE:
-	{
-		//	Commented by Albert 2012/07/24
-		//	We can disable the WFD function by using the following command:
-		//	wpa_cli driver wfd-disable
+	case ANDROID_WIFI_CMD_WFD_DISABLE: {
+		/*	Commented by Albert 2012/07/24 */
+		/*	We can disable the WFD function by using the following command: */
+		/*	wpa_cli driver wfd-disable */
 
 		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
 			rtw_wfd_enable(padapter, 0);
 		break;
 	}
-	case ANDROID_WIFI_CMD_WFD_SET_TCPPORT:
-	{
-		//	Commented by Albert 2012/07/24
-		//	We can set the tcp port number by using the following command:
-		//	wpa_cli driver wfd-set-tcpport = 554
+	case ANDROID_WIFI_CMD_WFD_SET_TCPPORT: {
+		/*	Commented by Albert 2012/07/24 */
+		/*	We can set the tcp port number by using the following command: */
+		/*	wpa_cli driver wfd-set-tcpport = 554 */
 
 		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
 			rtw_wfd_set_ctrl_port(padapter, (u16)get_int_from_command(priv_cmd.buf));
 		break;
 	}
-	case ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT:
-	{
+	case ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT: {
 		break;
 	}
-	case ANDROID_WIFI_CMD_WFD_SET_DEVTYPE:
-	{
-		//	Commented by Albert 2012/08/28
-		//	Specify the WFD device type ( WFD source/primary sink )
+	case ANDROID_WIFI_CMD_WFD_SET_DEVTYPE: {
+		/*	Commented by Albert 2012/08/28 */
+		/*	Specify the WFD device type ( WFD source/primary sink ) */
 
 		pwfd_info = &padapter->wfd_info;
-		if( padapter->wdinfo.driver_interface == DRIVER_CFG80211 )
-		{
-			pwfd_info->wfd_device_type = ( u8 ) get_int_from_command( priv_cmd.buf );
+		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
+			pwfd_info->wfd_device_type = (u8) get_int_from_command(priv_cmd.buf);
 			pwfd_info->wfd_device_type &= WFD_DEVINFO_DUAL;
 		}
 		break;
 	}
 #endif
-	case ANDROID_WIFI_CMD_CHANGE_DTIM:
-		{
+	case ANDROID_WIFI_CMD_CHANGE_DTIM: {
 #ifdef CONFIG_LPS
-			u8 dtim;
-			u8 *ptr =(u8 *) &priv_cmd.buf;
-			
-			ptr += 9;//string command length of  "SET_DTIM";
+		u8 dtim;
+		u8 *ptr = (u8 *) &priv_cmd.buf;
 
-			dtim = rtw_atoi(ptr);
+		ptr += 9;/* string command length of  "SET_DTIM"; */
 
-			DBG_871X("DTIM=%d\n", dtim);
+		dtim = rtw_atoi(ptr);
 
-			rtw_lps_change_dtim_cmd(padapter, dtim);			
-#endif			
-		}		
-		break;
-	case ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL:
-	{
-		padapter->stapriv.acl_list.mode = ( u8 ) get_int_from_command(command);
-		DBG_871X("%s ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL mode:%d\n", __FUNCTION__, padapter->stapriv.acl_list.mode);
+		RTW_INFO("DTIM=%d\n", dtim);
+
+		rtw_lps_change_dtim_cmd(padapter, dtim);
+#endif
+	}
+	break;
+
+#if CONFIG_RTW_MACADDR_ACL
+	case ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL: {
+		rtw_set_macaddr_acl(padapter, RTW_ACL_PERIOD_BSS, get_int_from_command(command));
 		break;
 	}
-	case ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA:
-	{
+	case ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA: {
 		u8 addr[ETH_ALEN] = {0x00};
-		macstr2num(addr, command+strlen("HOSTAPD_ACL_ADD_STA")+3);	// 3 is space bar + "=" + space bar these 3 chars
-		rtw_acl_add_sta(padapter, addr);
+		macstr2num(addr, command + strlen("HOSTAPD_ACL_ADD_STA") + 3);	/* 3 is space bar + "=" + space bar these 3 chars */
+		rtw_acl_add_sta(padapter, RTW_ACL_PERIOD_BSS, addr);
 		break;
 	}
-	case ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA:
-	{
+	case ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA: {
 		u8 addr[ETH_ALEN] = {0x00};
-		macstr2num(addr, command+strlen("HOSTAPD_ACL_REMOVE_STA")+3);	// 3 is space bar + "=" + space bar these 3 chars
-		rtw_acl_remove_sta(padapter, addr);
+		macstr2num(addr, command + strlen("HOSTAPD_ACL_REMOVE_STA") + 3);	/* 3 is space bar + "=" + space bar these 3 chars */
+		rtw_acl_remove_sta(padapter, RTW_ACL_PERIOD_BSS, addr);
 		break;
 	}
+#endif /* CONFIG_RTW_MACADDR_ACL */
 #if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 1, 0))
 	case ANDROID_WIFI_CMD_GTK_REKEY_OFFLOAD:
-		rtw_gtk_offload(net, (u8*)command);
+		rtw_gtk_offload(net, (u8 *)command);
 		break;
-#endif //CONFIG_GTK_OL		
-	case ANDROID_WIFI_CMD_P2P_DISABLE:
-	{
+#endif /* CONFIG_GTK_OL		 */
+	case ANDROID_WIFI_CMD_P2P_DISABLE: {
 #ifdef CONFIG_P2P
-		struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;	
+		struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 		u8 channel, ch_offset;
 		u16 bwmode;
 
 		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
-#endif // CONFIG_P2P
+#endif /* CONFIG_P2P */
 		break;
 	}
-	case ANDROID_WIFI_CMD_DRIVERVERSION:
-	{
+
+#ifdef CONFIG_RTW_MESH_AEK
+	case ANDROID_WIFI_CMD_SET_AEK:
+		bytes_written = rtw_android_set_aek(net, command, priv_cmd.total_len);
+		break;
+#endif
+	
+	case ANDROID_WIFI_CMD_DRIVERVERSION: {
 		bytes_written = strlen(DRIVERVERSION);
-		snprintf(command, bytes_written+1, DRIVERVERSION);
+		snprintf(command, bytes_written + 1, DRIVERVERSION);
 		break;
 	}
 	default:
-		DBG_871X("Unknown PRIVATE command %s - ignored\n", command);
+		RTW_INFO("Unknown PRIVATE command %s - ignored\n", command);
 		snprintf(command, 3, "OK");
 		bytes_written = strlen("OK");
 	}
@@ -912,26 +944,22 @@ response:
 		if ((bytes_written == 0) && (priv_cmd.total_len > 0))
 			command[0] = '\0';
 		if (bytes_written >= priv_cmd.total_len) {
-			DBG_871X("%s: bytes_written = %d\n", __FUNCTION__, bytes_written);
+			RTW_INFO("%s: bytes_written = %d\n", __FUNCTION__, bytes_written);
 			bytes_written = priv_cmd.total_len;
-		} else {
+		} else
 			bytes_written++;
-		}
 		priv_cmd.used_len = bytes_written;
 		if (copy_to_user((void *)priv_cmd.buf, command, bytes_written)) {
-			DBG_871X("%s: failed to copy data to user buffer\n", __FUNCTION__);
+			RTW_INFO("%s: failed to copy data to user buffer\n", __FUNCTION__);
 			ret = -EFAULT;
 		}
-	}
-	else {
+	} else
 		ret = bytes_written;
-	}
 
 exit:
 	rtw_unlock_suspend();
-	if (command) {
+	if (command)
 		rtw_mfree(command, priv_cmd.total_len);
-	}
 
 	return ret;
 }
@@ -957,7 +985,7 @@ int rtw_android_wifictrl_func_add(void)
 
 	ret = wifi_add_dev();
 	if (ret) {
-		DBG_871X("%s: platform_driver_register failed\n", __FUNCTION__);
+		RTW_INFO("%s: platform_driver_register failed\n", __FUNCTION__);
 		return ret;
 	}
 	g_wifidev_registered = 1;
@@ -965,7 +993,7 @@ int rtw_android_wifictrl_func_add(void)
 	/* Waiting callback after platform_driver_register is done or exit with error */
 	if (down_timeout(&wifi_control_sem,  msecs_to_jiffies(1000)) != 0) {
 		ret = -EINVAL;
-		DBG_871X("%s: platform_driver_register timeout\n", __FUNCTION__);
+		RTW_INFO("%s: platform_driver_register timeout\n", __FUNCTION__);
 	}
 
 	return ret;
@@ -973,8 +1001,7 @@ int rtw_android_wifictrl_func_add(void)
 
 void rtw_android_wifictrl_func_del(void)
 {
-	if (g_wifidev_registered)
-	{
+	if (g_wifidev_registered) {
 		wifi_del_dev();
 		g_wifidev_registered = 0;
 	}
@@ -986,14 +1013,14 @@ void *wl_android_prealloc(int section, unsigned long size)
 	if (wifi_control_data && wifi_control_data->mem_prealloc) {
 		alloc_ptr = wifi_control_data->mem_prealloc(section, size);
 		if (alloc_ptr) {
-			DBG_871X("success alloc section %d\n", section);
+			RTW_INFO("success alloc section %d\n", section);
 			if (size != 0L)
 				memset(alloc_ptr, 0, size);
 			return alloc_ptr;
 		}
 	}
 
-	DBG_871X("can't alloc section %d\n", section);
+	RTW_INFO("can't alloc section %d\n", section);
 	return NULL;
 }
 
@@ -1012,10 +1039,9 @@ int wifi_get_irq_number(unsigned long *irq_flags_ptr)
 
 int wifi_set_power(int on, unsigned long msec)
 {
-	DBG_871X("%s = %d\n", __FUNCTION__, on);
-	if (wifi_control_data && wifi_control_data->set_power) {
+	RTW_INFO("%s = %d\n", __FUNCTION__, on);
+	if (wifi_control_data && wifi_control_data->set_power)
 		wifi_control_data->set_power(on);
-	}
 	if (msec)
 		msleep(msec);
 	return 0;
@@ -1024,12 +1050,11 @@ int wifi_set_power(int on, unsigned long msec)
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 int wifi_get_mac_addr(unsigned char *buf)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 	if (!buf)
 		return -EINVAL;
-	if (wifi_control_data && wifi_control_data->get_mac_addr) {
+	if (wifi_control_data && wifi_control_data->get_mac_addr)
 		return wifi_control_data->get_mac_addr(buf);
-	}
 	return -EOPNOTSUPP;
 }
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35)) */
@@ -1037,22 +1062,20 @@ int wifi_get_mac_addr(unsigned char *buf)
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)) || defined(COMPAT_KERNEL_RELEASE)
 void *wifi_get_country_code(char *ccode)
 {
-	DBG_871X("%s\n", __FUNCTION__);
+	RTW_INFO("%s\n", __FUNCTION__);
 	if (!ccode)
 		return NULL;
-	if (wifi_control_data && wifi_control_data->get_country_code) {
-		return wifi_control_data->get_country_code(ccode);
-	}
+	//if (wifi_control_data && wifi_control_data->get_country_code)
+	//	return wifi_control_data->get_country_code(ccode);
 	return NULL;
 }
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)) */
 
 static int wifi_set_carddetect(int on)
 {
-	DBG_871X("%s = %d\n", __FUNCTION__, on);
-	if (wifi_control_data && wifi_control_data->set_carddetect) {
+	RTW_INFO("%s = %d\n", __FUNCTION__, on);
+	if (wifi_control_data && wifi_control_data->set_carddetect)
 		wifi_control_data->set_carddetect(on);
-	}
 	return 0;
 }
 
@@ -1062,33 +1085,31 @@ static int wifi_probe(struct platform_device *pdev)
 		(struct wifi_platform_data *)(pdev->dev.platform_data);
 	int wifi_wake_gpio = 0;
 
-	DBG_871X("## %s\n", __FUNCTION__);
+	RTW_INFO("## %s\n", __FUNCTION__);
 	wifi_irqres = platform_get_resource_byname(pdev, IORESOURCE_IRQ, "bcmdhd_wlan_irq");
 
 	if (wifi_irqres == NULL)
 		wifi_irqres = platform_get_resource_byname(pdev,
-			IORESOURCE_IRQ, "bcm4329_wlan_irq");
+				IORESOURCE_IRQ, "bcm4329_wlan_irq");
 	else
 		wifi_wake_gpio = wifi_irqres->start;
 
 #ifdef CONFIG_GPIO_WAKEUP
-	printk("%s: gpio:%d wifi_wake_gpio:%d\n", __func__,
-			wifi_irqres->start, wifi_wake_gpio);
+	RTW_INFO("%s: gpio:%d wifi_wake_gpio:%d\n", __func__,
+	       (int)wifi_irqres->start, wifi_wake_gpio);
 
 	if (wifi_wake_gpio > 0) {
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 		wifi_configure_gpio();
-#else //CONFIG_PLATFORM_INTEL_BYT
+#else /* CONFIG_PLATFORM_INTEL_BYT */
 		gpio_request(wifi_wake_gpio, "oob_irq");
 		gpio_direction_input(wifi_wake_gpio);
 		oob_irq = gpio_to_irq(wifi_wake_gpio);
-#endif //CONFIG_PLATFORM_INTEL_BYT
-		printk("%s oob_irq:%d\n", __func__, oob_irq);
-	}
-	else if(wifi_irqres)
-	{
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
+	} else if (wifi_irqres) {
 		oob_irq = wifi_irqres->start;
-		printk("%s oob_irq:%d\n", __func__, oob_irq);
+		RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
 	}
 #endif
 	wifi_control_data = wifi_ctrl;
@@ -1106,75 +1127,81 @@ extern PADAPTER g_test_adapter;
 static void shutdown_card(void)
 {
 	u32 addr;
-	u8 tmp8, cnt=0;
+	u8 tmp8, cnt = 0;
 
-	if (NULL == g_test_adapter)
-	{
-		DBG_871X("%s: padapter==NULL\n", __FUNCTION__);
+	if (NULL == g_test_adapter) {
+		RTW_INFO("%s: padapter==NULL\n", __FUNCTION__);
 		return;
 	}
 
 #ifdef CONFIG_FWLPS_IN_IPS
 	LeaveAllPowerSaveMode(g_test_adapter);
-#endif // CONFIG_FWLPS_IN_IPS
+#endif /* CONFIG_FWLPS_IN_IPS */
+
+#ifdef CONFIG_WOWLAN
+#ifdef CONFIG_GPIO_WAKEUP
+	/*default wake up pin change to BT*/
+	RTW_INFO("%s:default wake up pin change to BT\n", __FUNCTION__);
+	rtw_hal_switch_gpio_wl_ctrl(g_test_adapter, WAKEUP_GPIO_IDX, _FALSE);
+#endif /* CONFIG_GPIO_WAKEUP */
+#endif /* CONFIG_WOWLAN */
 
-	// Leave SDIO HCI Suspend
+	/* Leave SDIO HCI Suspend */
 	addr = 0x10250086;
 	rtw_write8(g_test_adapter, addr, 0);
 	do {
 		tmp8 = rtw_read8(g_test_adapter, addr);
 		cnt++;
-		DBG_871X(FUNC_ADPT_FMT ": polling SDIO_HSUS_CTRL(0x%x)=0x%x, cnt=%d\n",
-			FUNC_ADPT_ARG(g_test_adapter), addr, tmp8, cnt);
+		RTW_INFO(FUNC_ADPT_FMT ": polling SDIO_HSUS_CTRL(0x%x)=0x%x, cnt=%d\n",
+			 FUNC_ADPT_ARG(g_test_adapter), addr, tmp8, cnt);
 
 		if (tmp8 & BIT(1))
 			break;
 
-		if (cnt >= 100)
-		{
-			DBG_871X(FUNC_ADPT_FMT ": polling 0x%x[1]==1 FAIL!!\n",
-				FUNC_ADPT_ARG(g_test_adapter), addr);
+		if (cnt >= 100) {
+			RTW_INFO(FUNC_ADPT_FMT ": polling 0x%x[1]==1 FAIL!!\n",
+				 FUNC_ADPT_ARG(g_test_adapter), addr);
 			break;
 		}
 
 		rtw_mdelay_os(10);
 	} while (1);
 
-	// unlock register I/O
+	/* unlock register I/O */
 	rtw_write8(g_test_adapter, 0x1C, 0);
 
-	// enable power down function
-	// 0x04[4] = 1
-	// 0x05[7] = 1
+	/* enable power down function */
+	/* 0x04[4] = 1 */
+	/* 0x05[7] = 1 */
 	addr = 0x04;
 	tmp8 = rtw_read8(g_test_adapter, addr);
 	tmp8 |= BIT(4);
 	rtw_write8(g_test_adapter, addr, tmp8);
-	DBG_871X(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
+	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
 		FUNC_ADPT_ARG(g_test_adapter), addr, rtw_read8(g_test_adapter, addr));
 
 	addr = 0x05;
 	tmp8 = rtw_read8(g_test_adapter, addr);
 	tmp8 |= BIT(7);
 	rtw_write8(g_test_adapter, addr, tmp8);
-	DBG_871X(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
+	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
 		FUNC_ADPT_ARG(g_test_adapter), addr, rtw_read8(g_test_adapter, addr));
 
-	// lock register page0 0x0~0xB read/write
+	/* lock register page0 0x0~0xB read/write */
 	rtw_write8(g_test_adapter, 0x1C, 0x0E);
 
 	rtw_set_surprise_removed(g_test_adapter);
-	DBG_871X(FUNC_ADPT_FMT ": bSurpriseRemoved=%s\n",
-		FUNC_ADPT_ARG(g_test_adapter), rtw_is_surprise_removed(g_test_adapter)?"True":"False");
+	RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=%s\n",
+		FUNC_ADPT_ARG(g_test_adapter), rtw_is_surprise_removed(g_test_adapter) ? "True" : "False");
 }
-#endif // RTW_SUPPORT_PLATFORM_SHUTDOWN
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 
 static int wifi_remove(struct platform_device *pdev)
 {
 	struct wifi_platform_data *wifi_ctrl =
 		(struct wifi_platform_data *)(pdev->dev.platform_data);
 
-	DBG_871X("## %s\n", __FUNCTION__);
+	RTW_INFO("## %s\n", __FUNCTION__);
 	wifi_control_data = wifi_ctrl;
 
 	wifi_set_power(0, 0);	/* Power Off */
@@ -1189,9 +1216,9 @@ static void wifi_shutdown(struct platform_device *pdev)
 {
 	struct wifi_platform_data *wifi_ctrl =
 		(struct wifi_platform_data *)(pdev->dev.platform_data);
-	
 
-	DBG_871X("## %s\n", __FUNCTION__);
+
+	RTW_INFO("## %s\n", __FUNCTION__);
 
 	wifi_control_data = wifi_ctrl;
 
@@ -1199,11 +1226,11 @@ static void wifi_shutdown(struct platform_device *pdev)
 	wifi_set_power(0, 0);	/* Power Off */
 	wifi_set_carddetect(0);	/* CardDetect (1->0) */
 }
-#endif // RTW_SUPPORT_PLATFORM_SHUTDOWN
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 
 static int wifi_suspend(struct platform_device *pdev, pm_message_t state)
 {
-	DBG_871X("##> %s\n", __FUNCTION__);
+	RTW_INFO("##> %s\n", __FUNCTION__);
 #if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 39)) && defined(OOB_INTR_ONLY)
 	bcmsdh_oob_intr_set(0);
 #endif
@@ -1212,7 +1239,7 @@ static int wifi_suspend(struct platform_device *pdev, pm_message_t state)
 
 static int wifi_resume(struct platform_device *pdev)
 {
-	DBG_871X("##> %s\n", __FUNCTION__);
+	RTW_INFO("##> %s\n", __FUNCTION__);
 #if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 39)) && defined(OOB_INTR_ONLY)
 	if (dhd_os_check_if_up(bcmsdh_get_drvdata()))
 		bcmsdh_oob_intr_set(1);
@@ -1228,9 +1255,9 @@ static struct platform_driver wifi_device = {
 	.resume         = wifi_resume,
 #ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
 	.shutdown       = wifi_shutdown,
-#endif // RTW_SUPPORT_PLATFORM_SHUTDOWN
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 	.driver         = {
-	.name   = "bcmdhd_wlan",
+		.name   = "bcmdhd_wlan",
 	}
 };
 
@@ -1240,13 +1267,13 @@ static struct platform_driver wifi_device_legacy = {
 	.suspend        = wifi_suspend,
 	.resume         = wifi_resume,
 	.driver         = {
-	.name   = "bcm4329_wlan",
+		.name   = "bcm4329_wlan",
 	}
 };
 
 static int wifi_add_dev(void)
 {
-	DBG_871X("## Calling platform_driver_register\n");
+	RTW_INFO("## Calling platform_driver_register\n");
 	platform_driver_register(&wifi_device);
 	platform_driver_register(&wifi_device_legacy);
 	return 0;
@@ -1254,7 +1281,7 @@ static int wifi_add_dev(void)
 
 static void wifi_del_dev(void)
 {
-	DBG_871X("## Unregister platform_driver_register\n");
+	RTW_INFO("## Unregister platform_driver_register\n");
 	platform_driver_unregister(&wifi_device);
 	platform_driver_unregister(&wifi_device_legacy);
 }
@@ -1265,29 +1292,30 @@ static void wifi_del_dev(void)
 int wifi_configure_gpio(void)
 {
 	if (gpio_request(oob_gpio, "oob_irq")) {
-		DBG_871X("## %s Cannot request GPIO\n", __FUNCTION__);
+		RTW_INFO("## %s Cannot request GPIO\n", __FUNCTION__);
 		return -1;
 	}
 	gpio_export(oob_gpio, 0);
 	if (gpio_direction_input(oob_gpio)) {
-		DBG_871X("## %s Cannot set GPIO direction input\n", __FUNCTION__);
+		RTW_INFO("## %s Cannot set GPIO direction input\n", __FUNCTION__);
 		return -1;
 	}
-	if ((oob_irq = gpio_to_irq(oob_gpio)) < 0) {
-		DBG_871X("## %s Cannot convert GPIO to IRQ\n", __FUNCTION__);
+	oob_irq = gpio_to_irq(oob_gpio);
+	if (oob_irq < 0) {
+		RTW_INFO("## %s Cannot convert GPIO to IRQ\n", __FUNCTION__);
 		return -1;
 	}
 
-	DBG_871X("## %s OOB_IRQ=%d\n", __FUNCTION__, oob_irq);
+	RTW_INFO("## %s OOB_IRQ=%d\n", __FUNCTION__, oob_irq);
 
 	return 0;
 }
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 void wifi_free_gpio(unsigned int gpio)
 {
 #ifdef CONFIG_PLATFORM_INTEL_BYT
-	if(gpio)
+	if (gpio)
 		gpio_free(gpio);
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 }
-#endif //CONFIG_GPIO_WAKEUP
+#endif /* CONFIG_GPIO_WAKEUP */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.c
index 13e07482483e..3fb74a267bd5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2014 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #include <drv_types.h>
 
@@ -44,12 +40,9 @@
 
 #ifdef DBG_MEM_ALLOC
 extern bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size);
-struct sk_buff *dbg_rtw_cfg80211_vendor_event_alloc(struct wiphy *wiphy, int len, int event_id, gfp_t gfp
-	, const enum mstat_f flags, const char *func, const int line)
+struct sk_buff *dbg_rtw_cfg80211_vendor_event_alloc(struct wiphy *wiphy, struct wireless_dev *wdev, int len, int event_id, gfp_t gfp
+		, const enum mstat_f flags, const char *func, const int line)
 {
-	_adapter *padapter = wiphy_to_adapter(wiphy);
-	struct wireless_dev *wdev = padapter->rtw_wdev;
-
 	struct sk_buff *skb;
 	unsigned int truesize = 0;
 
@@ -59,11 +52,11 @@ struct sk_buff *dbg_rtw_cfg80211_vendor_event_alloc(struct wiphy *wiphy, int len
 	skb = cfg80211_vendor_event_alloc(wiphy, wdev, len, event_id, gfp);
 #endif
 
-	if(skb)
+	if (skb)
 		truesize = skb->truesize;
 
-	if(!skb || truesize < len || match_mstat_sniff_rules(flags, truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, len, skb, truesize);
+	if (!skb || truesize < len || match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, len, skb, truesize);
 
 	rtw_mstat_update(
 		flags
@@ -75,12 +68,12 @@ struct sk_buff *dbg_rtw_cfg80211_vendor_event_alloc(struct wiphy *wiphy, int len
 }
 
 void dbg_rtw_cfg80211_vendor_event(struct sk_buff *skb, gfp_t gfp
-	, const enum mstat_f flags, const char *func, const int line)
+		   , const enum mstat_f flags, const char *func, const int line)
 {
 	unsigned int truesize = skb->truesize;
 
-	if(match_mstat_sniff_rules(flags, truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
 
 	cfg80211_vendor_event(skb, gfp);
 
@@ -92,18 +85,18 @@ void dbg_rtw_cfg80211_vendor_event(struct sk_buff *skb, gfp_t gfp
 }
 
 struct sk_buff *dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb(struct wiphy *wiphy, int len
-	, const enum mstat_f flags, const char *func, const int line)
+		, const enum mstat_f flags, const char *func, const int line)
 {
 	struct sk_buff *skb;
 	unsigned int truesize = 0;
 
 	skb = cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len);
 
-	if(skb)
+	if (skb)
 		truesize = skb->truesize;
 
-	if(!skb || truesize < len || match_mstat_sniff_rules(flags, truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, len, skb, truesize);
+	if (!skb || truesize < len || match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, len, skb, truesize);
 
 	rtw_mstat_update(
 		flags
@@ -115,13 +108,13 @@ struct sk_buff *dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb(struct wiphy *wiphy,
 }
 
 int dbg_rtw_cfg80211_vendor_cmd_reply(struct sk_buff *skb
-	, const enum mstat_f flags, const char *func, const int line)
+	      , const enum mstat_f flags, const char *func, const int line)
 {
 	unsigned int truesize = skb->truesize;
 	int ret;
 
-	if(match_mstat_sniff_rules(flags, truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
 
 	ret = cfg80211_vendor_cmd_reply(skb);
 
@@ -134,24 +127,22 @@ int dbg_rtw_cfg80211_vendor_cmd_reply(struct sk_buff *skb
 	return ret;
 }
 
-#define rtw_cfg80211_vendor_event_alloc(wiphy, len, event_id, gfp) \
-	dbg_rtw_cfg80211_vendor_event_alloc(wiphy, len, event_id, gfp, MSTAT_FUNC_CFG_VENDOR|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
-	
+#define rtw_cfg80211_vendor_event_alloc(wiphy, wdev, len, event_id, gfp) \
+	dbg_rtw_cfg80211_vendor_event_alloc(wiphy, wdev, len, event_id, gfp, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+
 #define rtw_cfg80211_vendor_event(skb, gfp) \
-	dbg_rtw_cfg80211_vendor_event(skb, gfp, MSTAT_FUNC_CFG_VENDOR|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
-	
+	dbg_rtw_cfg80211_vendor_event(skb, gfp, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+
 #define rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len) \
-	dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len, MSTAT_FUNC_CFG_VENDOR|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+	dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
 
 #define rtw_cfg80211_vendor_cmd_reply(skb) \
-		dbg_rtw_cfg80211_vendor_cmd_reply(skb, MSTAT_FUNC_CFG_VENDOR|MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
+	dbg_rtw_cfg80211_vendor_cmd_reply(skb, MSTAT_FUNC_CFG_VENDOR | MSTAT_TYPE_SKB, __FUNCTION__, __LINE__)
 #else
 
 struct sk_buff *rtw_cfg80211_vendor_event_alloc(
-		struct wiphy *wiphy, int len, int event_id, gfp_t gfp)
+	struct wiphy *wiphy, struct wireless_dev *wdev, int len, int event_id, gfp_t gfp)
 {
-	_adapter *padapter = wiphy_to_adapter(wiphy);
-	struct wireless_dev *wdev = padapter->rtw_wdev;
 	struct sk_buff *skb;
 
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 1, 0))
@@ -164,7 +155,7 @@ struct sk_buff *rtw_cfg80211_vendor_event_alloc(
 
 #define rtw_cfg80211_vendor_event(skb, gfp) \
 	cfg80211_vendor_event(skb, gfp)
-	
+
 #define rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len) \
 	cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len)
 
@@ -179,7 +170,7 @@ struct sk_buff *rtw_cfg80211_vendor_event_alloc(
  * be used).
  */
 int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,
-	struct net_device *dev, int event_id, const void  *data, int len)
+	   struct net_device *dev, int event_id, const void  *data, int len)
 {
 	u16 kflags;
 	struct sk_buff *skb;
@@ -187,9 +178,9 @@ int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,
 	kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
 
 	/* Alloc the SKB for vendor_event */
-	skb = rtw_cfg80211_vendor_event_alloc(wiphy, len, event_id, kflags);
+	skb = rtw_cfg80211_vendor_event_alloc(wiphy, ndev_to_wdev(dev), len, event_id, kflags);
 	if (!skb) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(dev));
+		RTW_ERR(FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(dev));
 		return -ENOMEM;
 	}
 
@@ -202,14 +193,14 @@ int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,
 }
 
 static int rtw_cfgvendor_send_cmd_reply(struct wiphy *wiphy,
-	struct net_device *dev, const void  *data, int len)
+			struct net_device *dev, const void  *data, int len)
 {
 	struct sk_buff *skb;
 
 	/* Alloc the SKB for vendor_event */
 	skb = rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, len);
 	if (unlikely(!skb)) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(dev));
+		RTW_ERR(FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(dev));
 		return -ENOMEM;
 	}
 
@@ -219,22 +210,34 @@ static int rtw_cfgvendor_send_cmd_reply(struct wiphy *wiphy,
 	return rtw_cfg80211_vendor_cmd_reply(skb);
 }
 
-#define WIFI_FEATURE_INFRA              0x0001      /* Basic infrastructure mode        */
-#define WIFI_FEATURE_INFRA_5G           0x0002      /* Support for 5 GHz Band           */
-#define WIFI_FEATURE_HOTSPOT            0x0004      /* Support for GAS/ANQP             */
-#define WIFI_FEATURE_P2P                0x0008      /* Wifi-Direct                      */
-#define WIFI_FEATURE_SOFT_AP            0x0010      /* Soft AP                          */
-#define WIFI_FEATURE_GSCAN              0x0020      /* Google-Scan APIs                 */
-#define WIFI_FEATURE_NAN                0x0040      /* Neighbor Awareness Networking    */
-#define WIFI_FEATURE_D2D_RTT            0x0080      /* Device-to-device RTT             */
-#define WIFI_FEATURE_D2AP_RTT           0x0100      /* Device-to-AP RTT                 */
-#define WIFI_FEATURE_BATCH_SCAN         0x0200      /* Batched Scan (legacy)            */
-#define WIFI_FEATURE_PNO                0x0400      /* Preferred network offload        */
-#define WIFI_FEATURE_ADDITIONAL_STA     0x0800      /* Support for two STAs             */
-#define WIFI_FEATURE_TDLS               0x1000      /* Tunnel directed link setup       */
-#define WIFI_FEATURE_TDLS_OFFCHANNEL    0x2000      /* Support for TDLS off channel     */
-#define WIFI_FEATURE_EPR                0x4000      /* Enhanced power reporting         */
-#define WIFI_FEATURE_AP_STA             0x8000      /* Support for AP STA Concurrency   */
+/* Feature enums */
+#define WIFI_FEATURE_INFRA              0x0001      // Basic infrastructure mode
+#define WIFI_FEATURE_INFRA_5G           0x0002      // Support for 5 GHz Band
+#define WIFI_FEATURE_HOTSPOT            0x0004      // Support for GAS/ANQP
+#define WIFI_FEATURE_P2P                0x0008      // Wifi-Direct
+#define WIFI_FEATURE_SOFT_AP            0x0010      // Soft AP
+#define WIFI_FEATURE_GSCAN              0x0020      // Google-Scan APIs
+#define WIFI_FEATURE_NAN                0x0040      // Neighbor Awareness Networking
+#define WIFI_FEATURE_D2D_RTT            0x0080      // Device-to-device RTT
+#define WIFI_FEATURE_D2AP_RTT           0x0100      // Device-to-AP RTT
+#define WIFI_FEATURE_BATCH_SCAN         0x0200      // Batched Scan (legacy)
+#define WIFI_FEATURE_PNO                0x0400      // Preferred network offload
+#define WIFI_FEATURE_ADDITIONAL_STA     0x0800      // Support for two STAs
+#define WIFI_FEATURE_TDLS               0x1000      // Tunnel directed link setup
+#define WIFI_FEATURE_TDLS_OFFCHANNEL    0x2000      // Support for TDLS off channel
+#define WIFI_FEATURE_EPR                0x4000      // Enhanced power reporting
+#define WIFI_FEATURE_AP_STA             0x8000      // Support for AP STA Concurrency
+#define WIFI_FEATURE_LINK_LAYER_STATS   0x10000     // Link layer stats collection
+#define WIFI_FEATURE_LOGGER             0x20000     // WiFi Logger
+#define WIFI_FEATURE_HAL_EPNO           0x40000     // WiFi PNO enhanced
+#define WIFI_FEATURE_RSSI_MONITOR       0x80000     // RSSI Monitor
+#define WIFI_FEATURE_MKEEP_ALIVE        0x100000    // WiFi mkeep_alive
+#define WIFI_FEATURE_CONFIG_NDO         0x200000    // ND offload configure
+#define WIFI_FEATURE_TX_TRANSMIT_POWER  0x400000    // Capture Tx transmit power levels
+#define WIFI_FEATURE_CONTROL_ROAMING    0x800000    // Enable/Disable firmware roaming
+#define WIFI_FEATURE_IE_WHITELIST       0x1000000   // Support Probe IE white listing
+#define WIFI_FEATURE_SCAN_RAND          0x2000000   // Support MAC & Probe Sequence Number randomization
+// Add more features here
 
 #define MAX_FEATURE_SET_CONCURRRENT_GROUPS  3
 
@@ -243,20 +246,25 @@ int rtw_dev_get_feature_set(struct net_device *dev)
 {
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
-	HAL_VERSION *hal_ver = &HalData->VersionID;
+	HAL_VERSION *hal_ver = &HalData->version_id;
 
 	int feature_set = 0;
 
 	feature_set |= WIFI_FEATURE_INFRA;
 
-	if (IS_8814A_SERIES(*hal_ver) || IS_8812_SERIES(*hal_ver) ||
-			IS_8821_SERIES(*hal_ver))
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (is_supported_5g(adapter_to_regsty(adapter)->wireless_mode)
+		&& hal_chk_band_cap(adapter, BAND_CAP_5G)) /* v5.3 has no rtw_init_wireless_mode(), need checking hal spec here */
 		feature_set |= WIFI_FEATURE_INFRA_5G;
+#endif
 
 	feature_set |= WIFI_FEATURE_P2P;
 	feature_set |= WIFI_FEATURE_SOFT_AP;
 
 	feature_set |= WIFI_FEATURE_ADDITIONAL_STA;
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	feature_set |= WIFI_FEATURE_LINK_LAYER_STATS;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
 
 	return feature_set;
 }
@@ -271,7 +279,7 @@ int *rtw_dev_get_feature_set_matrix(struct net_device *dev, int *num)
 	ret = (int *)rtw_malloc(mem_needed);
 
 	if (!ret) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT" failed to allocate %d bytes\n"
+		RTW_ERR(FUNC_NDEV_FMT" failed to allocate %d bytes\n"
 			, FUNC_NDEV_ARG(dev), mem_needed);
 		return ret;
 	}
@@ -279,41 +287,41 @@ int *rtw_dev_get_feature_set_matrix(struct net_device *dev, int *num)
 	feature_set_full = rtw_dev_get_feature_set(dev);
 
 	ret[0] = (feature_set_full & WIFI_FEATURE_INFRA) |
-	         (feature_set_full & WIFI_FEATURE_INFRA_5G) |
-	         (feature_set_full & WIFI_FEATURE_NAN) |
-	         (feature_set_full & WIFI_FEATURE_D2D_RTT) |
-	         (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
-	         (feature_set_full & WIFI_FEATURE_PNO) |
-	         (feature_set_full & WIFI_FEATURE_BATCH_SCAN) |
-	         (feature_set_full & WIFI_FEATURE_GSCAN) |
-	         (feature_set_full & WIFI_FEATURE_HOTSPOT) |
-	         (feature_set_full & WIFI_FEATURE_ADDITIONAL_STA) |
-	         (feature_set_full & WIFI_FEATURE_EPR);
+		 (feature_set_full & WIFI_FEATURE_INFRA_5G) |
+		 (feature_set_full & WIFI_FEATURE_NAN) |
+		 (feature_set_full & WIFI_FEATURE_D2D_RTT) |
+		 (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
+		 (feature_set_full & WIFI_FEATURE_PNO) |
+		 (feature_set_full & WIFI_FEATURE_BATCH_SCAN) |
+		 (feature_set_full & WIFI_FEATURE_GSCAN) |
+		 (feature_set_full & WIFI_FEATURE_HOTSPOT) |
+		 (feature_set_full & WIFI_FEATURE_ADDITIONAL_STA) |
+		 (feature_set_full & WIFI_FEATURE_EPR);
 
 	ret[1] = (feature_set_full & WIFI_FEATURE_INFRA) |
-	         (feature_set_full & WIFI_FEATURE_INFRA_5G) |
-	         /* Not yet verified NAN with P2P */
-	         /* (feature_set_full & WIFI_FEATURE_NAN) | */
-	         (feature_set_full & WIFI_FEATURE_P2P) |
-	         (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
-	         (feature_set_full & WIFI_FEATURE_D2D_RTT) |
-	         (feature_set_full & WIFI_FEATURE_EPR);
+		 (feature_set_full & WIFI_FEATURE_INFRA_5G) |
+		 /* Not yet verified NAN with P2P */
+		 /* (feature_set_full & WIFI_FEATURE_NAN) | */
+		 (feature_set_full & WIFI_FEATURE_P2P) |
+		 (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
+		 (feature_set_full & WIFI_FEATURE_D2D_RTT) |
+		 (feature_set_full & WIFI_FEATURE_EPR);
 
 	ret[2] = (feature_set_full & WIFI_FEATURE_INFRA) |
-	         (feature_set_full & WIFI_FEATURE_INFRA_5G) |
-	         (feature_set_full & WIFI_FEATURE_NAN) |
-	         (feature_set_full & WIFI_FEATURE_D2D_RTT) |
-	         (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
-	         (feature_set_full & WIFI_FEATURE_TDLS) |
-	         (feature_set_full & WIFI_FEATURE_TDLS_OFFCHANNEL) |
-	         (feature_set_full & WIFI_FEATURE_EPR);
+		 (feature_set_full & WIFI_FEATURE_INFRA_5G) |
+		 (feature_set_full & WIFI_FEATURE_NAN) |
+		 (feature_set_full & WIFI_FEATURE_D2D_RTT) |
+		 (feature_set_full & WIFI_FEATURE_D2AP_RTT) |
+		 (feature_set_full & WIFI_FEATURE_TDLS) |
+		 (feature_set_full & WIFI_FEATURE_TDLS_OFFCHANNEL) |
+		 (feature_set_full & WIFI_FEATURE_EPR);
 	*num = MAX_FEATURE_SET_CONCURRRENT_GROUPS;
 
 	return ret;
 }
 
 static int rtw_cfgvendor_get_feature_set(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	int reply;
@@ -323,14 +331,14 @@ static int rtw_cfgvendor_get_feature_set(struct wiphy *wiphy,
 	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), &reply, sizeof(int));
 
 	if (unlikely(err))
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT" Vendor Command reply failed ret:%d \n"
+		RTW_ERR(FUNC_NDEV_FMT" Vendor Command reply failed ret:%d\n"
 			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
 
 	return err;
 }
 
 static int rtw_cfgvendor_get_feature_set_matrix(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct sk_buff *skb;
@@ -340,41 +348,40 @@ static int rtw_cfgvendor_get_feature_set_matrix(struct wiphy *wiphy,
 	reply = rtw_dev_get_feature_set_matrix(wdev_to_ndev(wdev), &num);
 
 	if (!reply) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT" Could not get feature list matrix\n"
+		RTW_ERR(FUNC_NDEV_FMT" Could not get feature list matrix\n"
 			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)));
 		err = -EINVAL;
 		return err;
 	}
 
 	mem_needed = VENDOR_REPLY_OVERHEAD + (ATTRIBUTE_U32_LEN * num) +
-	             ATTRIBUTE_U32_LEN;
+		     ATTRIBUTE_U32_LEN;
 
 	/* Alloc the SKB for vendor_event */
 	skb = rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, mem_needed);
 	if (unlikely(!skb)) {
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(wdev_to_ndev(wdev)));
+		RTW_ERR(FUNC_NDEV_FMT" skb alloc failed", FUNC_NDEV_ARG(wdev_to_ndev(wdev)));
 		err = -ENOMEM;
 		goto exit;
 	}
 
 	nla_put_u32(skb, ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET, num);
-	for (i = 0; i < num; i++) {
+	for (i = 0; i < num; i++)
 		nla_put_u32(skb, ANDR_WIFI_ATTRIBUTE_FEATURE_SET, reply[i]);
-	}
 
 	err =  rtw_cfg80211_vendor_cmd_reply(skb);
 
 	if (unlikely(err))
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT" Vendor Command reply failed ret:%d \n"
+		RTW_ERR(FUNC_NDEV_FMT" Vendor Command reply failed ret:%d\n"
 			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
 exit:
-	rtw_mfree((u8*)reply, sizeof(int)*num);
+	rtw_mfree((u8 *)reply, sizeof(int) * num);
 	return err;
 }
 
 #if defined(GSCAN_SUPPORT) && 0
-int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
-	struct net_device *dev, void  *data, int len, wl_vendor_event_t event)
+int rtw_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
+	struct net_device *dev, void  *data, int len, rtw_vendor_event_t event)
 {
 	u16 kflags;
 	const void *ptr;
@@ -382,20 +389,19 @@ int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
 	int malloc_len, total, iter_cnt_to_send, cnt;
 	gscan_results_cache_t *cache = (gscan_results_cache_t *)data;
 
-	total = len/sizeof(wifi_gscan_result_t);
+	total = len / sizeof(wifi_gscan_result_t);
 	while (total > 0) {
 		malloc_len = (total * sizeof(wifi_gscan_result_t)) + VENDOR_DATA_OVERHEAD;
-		if (malloc_len > NLMSG_DEFAULT_SIZE) {
+		if (malloc_len > NLMSG_DEFAULT_SIZE)
 			malloc_len = NLMSG_DEFAULT_SIZE;
-		}
 		iter_cnt_to_send =
-		   (malloc_len - VENDOR_DATA_OVERHEAD)/sizeof(wifi_gscan_result_t);
+			(malloc_len - VENDOR_DATA_OVERHEAD) / sizeof(wifi_gscan_result_t);
 		total = total - iter_cnt_to_send;
 
 		kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
 
 		/* Alloc the SKB for vendor_event */
-		skb = rtw_cfg80211_vendor_event_alloc(wiphy, malloc_len, event, kflags);
+		skb = rtw_cfg80211_vendor_event_alloc(wiphy, ndev_to_wdev(dev), malloc_len, event, kflags);
 		if (!skb) {
 			WL_ERR(("skb alloc failed"));
 			return -ENOMEM;
@@ -425,8 +431,8 @@ int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
 }
 
 
-static int wl_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -435,7 +441,7 @@ static int wl_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
 
 
 	reply = dhd_dev_pno_get_gscan(bcmcfg_to_prmry_ndev(cfg),
-	   DHD_PNO_GET_CAPABILITIES, NULL, &reply_len);
+			      DHD_PNO_GET_CAPABILITIES, NULL, &reply_len);
 	if (!reply) {
 		WL_ERR(("Could not get capabilities\n"));
 		err = -EINVAL;
@@ -443,17 +449,17 @@ static int wl_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
 	}
 
 	err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
-	        reply, reply_len);
+					    reply, reply_len);
 
 	if (unlikely(err))
-		WL_ERR(("Vendor Command reply failed ret:%d \n", err));
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
 
 	kfree(reply);
 	return err;
 }
 
-static int wl_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0, type, band;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -463,21 +469,20 @@ static int wl_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,
 
 	type = nla_type(data);
 
-	if (type == GSCAN_ATTRIBUTE_BAND) {
+	if (type == GSCAN_ATTRIBUTE_BAND)
 		band = nla_get_u32(data);
-	} else {
+	else
 		return -1;
-	}
 
 	reply = dhd_dev_pno_get_gscan(bcmcfg_to_prmry_ndev(cfg),
-	   DHD_PNO_GET_CHANNEL_LIST, &band, &reply_len);
+			      DHD_PNO_GET_CHANNEL_LIST, &band, &reply_len);
 
 	if (!reply) {
 		WL_ERR(("Could not get channel list\n"));
 		err = -EINVAL;
 		return err;
 	}
-	num_channels =  reply_len/ sizeof(uint32);
+	num_channels =  reply_len / sizeof(uint32);
 	mem_needed = reply_len + VENDOR_REPLY_OVERHEAD + (ATTRIBUTE_U32_LEN * 2);
 
 	/* Alloc the SKB for vendor_event */
@@ -494,14 +499,14 @@ static int wl_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,
 	err =  rtw_cfg80211_vendor_cmd_reply(skb);
 
 	if (unlikely(err))
-		WL_ERR(("Vendor Command reply failed ret:%d \n", err));
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
 exit:
 	kfree(reply);
 	return err;
 }
 
-static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -516,33 +521,32 @@ static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
 	dhd_dev_wait_batch_results_complete(bcmcfg_to_prmry_ndev(cfg));
 	dhd_dev_pno_lock_access_batch_results(bcmcfg_to_prmry_ndev(cfg));
 	results = dhd_dev_pno_get_gscan(bcmcfg_to_prmry_ndev(cfg),
-	             DHD_PNO_GET_BATCH_RESULTS, NULL, &reply_len);
+				DHD_PNO_GET_BATCH_RESULTS, NULL, &reply_len);
 
 	if (!results) {
 		WL_ERR(("No results to send %d\n", err));
 		err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
-		        results, 0);
+						    results, 0);
 
 		if (unlikely(err))
-			WL_ERR(("Vendor Command reply failed ret:%d \n", err));
+			WL_ERR(("Vendor Command reply failed ret:%d\n", err));
 		dhd_dev_pno_unlock_access_batch_results(bcmcfg_to_prmry_ndev(cfg));
 		return err;
 	}
 	num_scan_ids = reply_len & 0xFFFF;
 	num_results = (reply_len & 0xFFFF0000) >> 16;
 	mem_needed = (num_results * sizeof(wifi_gscan_result_t)) +
-	             (num_scan_ids * GSCAN_BATCH_RESULT_HDR_LEN) +
-	             VENDOR_REPLY_OVERHEAD + SCAN_RESULTS_COMPLETE_FLAG_LEN;
+		     (num_scan_ids * GSCAN_BATCH_RESULT_HDR_LEN) +
+		     VENDOR_REPLY_OVERHEAD + SCAN_RESULTS_COMPLETE_FLAG_LEN;
 
 	if (mem_needed > (int32)NLMSG_DEFAULT_SIZE) {
 		mem_needed = (int32)NLMSG_DEFAULT_SIZE;
 		complete = 0;
-	} else {
+	} else
 		complete = 1;
-	}
 
 	WL_TRACE(("complete %d mem_needed %d max_mem %d\n", complete, mem_needed,
-		(int)NLMSG_DEFAULT_SIZE));
+		  (int)NLMSG_DEFAULT_SIZE));
 	/* Alloc the SKB for vendor_event */
 	skb = rtw_cfg80211_vendor_cmd_alloc_reply_skb(wiphy, mem_needed);
 	if (unlikely(!skb)) {
@@ -561,7 +565,7 @@ static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
 		nla_put_u32(skb, GSCAN_ATTRIBUTE_SCAN_ID, iter->scan_id);
 		nla_put_u8(skb, GSCAN_ATTRIBUTE_SCAN_FLAGS, iter->flag);
 		num_results_iter =
-		    (mem_needed - GSCAN_BATCH_RESULT_HDR_LEN)/sizeof(wifi_gscan_result_t);
+			(mem_needed - GSCAN_BATCH_RESULT_HDR_LEN) / sizeof(wifi_gscan_result_t);
 
 		if ((iter->tot_count - iter->tot_consumed) < num_results_iter)
 			num_results_iter = iter->tot_count - iter->tot_consumed;
@@ -571,11 +575,11 @@ static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
 			ptr = &iter->results[iter->tot_consumed];
 			iter->tot_consumed += num_results_iter;
 			nla_put(skb, GSCAN_ATTRIBUTE_SCAN_RESULTS,
-			 num_results_iter * sizeof(wifi_gscan_result_t), ptr);
+				num_results_iter * sizeof(wifi_gscan_result_t), ptr);
 		}
 		nla_nest_end(skb, scan_hdr);
 		mem_needed -= GSCAN_BATCH_RESULT_HDR_LEN +
-		    (num_results_iter * sizeof(wifi_gscan_result_t));
+			      (num_results_iter * sizeof(wifi_gscan_result_t));
 		iter = iter->next;
 	}
 
@@ -585,8 +589,8 @@ static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
 	return rtw_cfg80211_vendor_cmd_reply(skb);
 }
 
-static int wl_cfgvendor_initiate_gscan(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_initiate_gscan(struct wiphy *wiphy,
+		       struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -607,17 +611,16 @@ static int wl_cfgvendor_initiate_gscan(struct wiphy *wiphy,
 		err = dhd_dev_pno_run_gscan(bcmcfg_to_prmry_ndev(cfg), run, flush);
 
 		if (unlikely(err))
-			WL_ERR(("Could not run gscan:%d \n", err));
+			WL_ERR(("Could not run gscan:%d\n", err));
 		return err;
-	} else {
+	} else
 		return -1;
-	}
 
 
 }
 
-static int wl_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -632,17 +635,16 @@ static int wl_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,
 		err = dhd_dev_pno_enable_full_scan_result(bcmcfg_to_prmry_ndev(cfg), real_time);
 
 		if (unlikely(err))
-			WL_ERR(("Could not run gscan:%d \n", err));
+			WL_ERR(("Could not run gscan:%d\n", err));
 
-	} else {
+	} else
 		err = -1;
-	}
 
 	return err;
 }
 
-static int wl_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
+		     struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -668,62 +670,62 @@ static int wl_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
 			break;
 
 		switch (type) {
-			case GSCAN_ATTRIBUTE_BASE_PERIOD:
-				scan_param->scan_fr = nla_get_u32(iter)/1000;
-				break;
-			case GSCAN_ATTRIBUTE_NUM_BUCKETS:
-				scan_param->nchannel_buckets = nla_get_u32(iter);
-				break;
-			case GSCAN_ATTRIBUTE_CH_BUCKET_1:
-			case GSCAN_ATTRIBUTE_CH_BUCKET_2:
-			case GSCAN_ATTRIBUTE_CH_BUCKET_3:
-			case GSCAN_ATTRIBUTE_CH_BUCKET_4:
-			case GSCAN_ATTRIBUTE_CH_BUCKET_5:
-			case GSCAN_ATTRIBUTE_CH_BUCKET_6:
-			case GSCAN_ATTRIBUTE_CH_BUCKET_7:
-				nla_for_each_nested(iter1, iter, tmp1) {
-					type = nla_type(iter1);
-					ch_bucket =
+		case GSCAN_ATTRIBUTE_BASE_PERIOD:
+			scan_param->scan_fr = nla_get_u32(iter) / 1000;
+			break;
+		case GSCAN_ATTRIBUTE_NUM_BUCKETS:
+			scan_param->nchannel_buckets = nla_get_u32(iter);
+			break;
+		case GSCAN_ATTRIBUTE_CH_BUCKET_1:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_2:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_3:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_4:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_5:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_6:
+		case GSCAN_ATTRIBUTE_CH_BUCKET_7:
+			nla_for_each_nested(iter1, iter, tmp1) {
+				type = nla_type(iter1);
+				ch_bucket =
 					scan_param->channel_bucket;
 
-					switch (type) {
-						case GSCAN_ATTRIBUTE_BUCKET_ID:
-						break;
-						case GSCAN_ATTRIBUTE_BUCKET_PERIOD:
-							ch_bucket[j].bucket_freq_multiple =
-							    nla_get_u32(iter1)/1000;
-							break;
-						case GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS:
-							ch_bucket[j].num_channels =
-							     nla_get_u32(iter1);
-							break;
-						case GSCAN_ATTRIBUTE_BUCKET_CHANNELS:
-							nla_for_each_nested(iter2, iter1, tmp2) {
-								if (k >= PFN_SWC_RSSI_WINDOW_MAX)
-									break;
-								ch_bucket[j].chan_list[k] =
-								     nla_get_u32(iter2);
-								k++;
-							}
-							k = 0;
-							break;
-						case GSCAN_ATTRIBUTE_BUCKETS_BAND:
-							ch_bucket[j].band = (uint16)
-							     nla_get_u32(iter1);
-							break;
-						case GSCAN_ATTRIBUTE_REPORT_EVENTS:
-							ch_bucket[j].report_flag = (uint8)
-							     nla_get_u32(iter1);
+				switch (type) {
+				case GSCAN_ATTRIBUTE_BUCKET_ID:
+					break;
+				case GSCAN_ATTRIBUTE_BUCKET_PERIOD:
+					ch_bucket[j].bucket_freq_multiple =
+						nla_get_u32(iter1) / 1000;
+					break;
+				case GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS:
+					ch_bucket[j].num_channels =
+						nla_get_u32(iter1);
+					break;
+				case GSCAN_ATTRIBUTE_BUCKET_CHANNELS:
+					nla_for_each_nested(iter2, iter1, tmp2) {
+						if (k >= PFN_SWC_RSSI_WINDOW_MAX)
 							break;
+						ch_bucket[j].chan_list[k] =
+							nla_get_u32(iter2);
+						k++;
 					}
+					k = 0;
+					break;
+				case GSCAN_ATTRIBUTE_BUCKETS_BAND:
+					ch_bucket[j].band = (uint16)
+							    nla_get_u32(iter1);
+					break;
+				case GSCAN_ATTRIBUTE_REPORT_EVENTS:
+					ch_bucket[j].report_flag = (uint8)
+							   nla_get_u32(iter1);
+					break;
 				}
-				j++;
-				break;
+			}
+			j++;
+			break;
 		}
 	}
 
 	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
-	     DHD_PNO_SCAN_CFG_ID, scan_param, 0) < 0) {
+				      DHD_PNO_SCAN_CFG_ID, scan_param, 0) < 0) {
 		WL_ERR(("Could not set GSCAN scan cfg\n"));
 		err = -EINVAL;
 	}
@@ -733,8 +735,8 @@ static int wl_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
 
 }
 
-static int wl_cfgvendor_hotlist_cfg(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_hotlist_cfg(struct wiphy *wiphy,
+		    struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -746,7 +748,7 @@ static int wl_cfgvendor_hotlist_cfg(struct wiphy *wiphy,
 
 	hotlist_params = (gscan_hotlist_scan_params_t *)kzalloc(len, GFP_KERNEL);
 	if (!hotlist_params) {
-		WL_ERR(("Cannot Malloc mem to parse config commands size - %d bytes \n", len));
+		WL_ERR(("Cannot Malloc mem to parse config commands size - %d bytes\n", len));
 		return -1;
 	}
 
@@ -755,42 +757,42 @@ static int wl_cfgvendor_hotlist_cfg(struct wiphy *wiphy,
 	nla_for_each_attr(iter, data, len, tmp2) {
 		type = nla_type(iter);
 		switch (type) {
-			case GSCAN_ATTRIBUTE_HOTLIST_BSSIDS:
-				pbssid = hotlist_params->bssid;
-				nla_for_each_nested(outer, iter, tmp) {
-					nla_for_each_nested(inner, outer, tmp1) {
-						type = nla_type(inner);
-
-						switch (type) {
-							case GSCAN_ATTRIBUTE_BSSID:
-								memcpy(&(pbssid[j].macaddr),
-								  nla_data(inner), ETHER_ADDR_LEN);
-								break;
-							case GSCAN_ATTRIBUTE_RSSI_LOW:
-								pbssid[j].rssi_reporting_threshold =
-								         (int8) nla_get_u8(inner);
-								break;
-							case GSCAN_ATTRIBUTE_RSSI_HIGH:
-								dummy = (int8) nla_get_u8(inner);
-								break;
-						}
+		case GSCAN_ATTRIBUTE_HOTLIST_BSSIDS:
+			pbssid = hotlist_params->bssid;
+			nla_for_each_nested(outer, iter, tmp) {
+				nla_for_each_nested(inner, outer, tmp1) {
+					type = nla_type(inner);
+
+					switch (type) {
+					case GSCAN_ATTRIBUTE_BSSID:
+						memcpy(&(pbssid[j].macaddr),
+						       nla_data(inner), ETHER_ADDR_LEN);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_LOW:
+						pbssid[j].rssi_reporting_threshold =
+							(int8) nla_get_u8(inner);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_HIGH:
+						dummy = (int8) nla_get_u8(inner);
+						break;
 					}
-					j++;
 				}
-				hotlist_params->nbssid = j;
-				break;
-			case GSCAN_ATTRIBUTE_HOTLIST_FLUSH:
-				flush = nla_get_u8(iter);
-				break;
-			case GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE:
-				hotlist_params->lost_ap_window = nla_get_u32(iter);
-				break;
+				j++;
 			}
+			hotlist_params->nbssid = j;
+			break;
+		case GSCAN_ATTRIBUTE_HOTLIST_FLUSH:
+			flush = nla_get_u8(iter);
+			break;
+		case GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE:
+			hotlist_params->lost_ap_window = nla_get_u32(iter);
+			break;
+		}
 
 	}
 
 	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
-	      DHD_PNO_GEOFENCE_SCAN_CFG_ID, hotlist_params, flush) < 0) {
+		DHD_PNO_GEOFENCE_SCAN_CFG_ID, hotlist_params, flush) < 0) {
 		WL_ERR(("Could not set GSCAN HOTLIST cfg\n"));
 		err = -EINVAL;
 		goto exit;
@@ -799,8 +801,8 @@ exit:
 	kfree(hotlist_params);
 	return err;
 }
-static int wl_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0, tmp, type;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -814,20 +816,20 @@ static int wl_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
 		type = nla_type(iter);
 
 		switch (type) {
-			case GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN:
-				batch_param.bestn = nla_get_u32(iter);
-				break;
-			case GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE:
-				batch_param.mscan = nla_get_u32(iter);
-				break;
-			case GSCAN_ATTRIBUTE_REPORT_THRESHOLD:
-				batch_param.buffer_threshold = nla_get_u32(iter);
-				break;
+		case GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN:
+			batch_param.bestn = nla_get_u32(iter);
+			break;
+		case GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE:
+			batch_param.mscan = nla_get_u32(iter);
+			break;
+		case GSCAN_ATTRIBUTE_REPORT_THRESHOLD:
+			batch_param.buffer_threshold = nla_get_u32(iter);
+			break;
 		}
 	}
 
 	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
-	       DHD_PNO_BATCH_SCAN_CFG_ID, &batch_param, 0) < 0) {
+			      DHD_PNO_BATCH_SCAN_CFG_ID, &batch_param, 0) < 0) {
 		WL_ERR(("Could not set batch cfg\n"));
 		err = -EINVAL;
 		return err;
@@ -836,8 +838,8 @@ static int wl_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
 	return err;
 }
 
-static int wl_cfgvendor_significant_change_cfg(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+static int rtw_cfgvendor_significant_change_cfg(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -849,7 +851,7 @@ static int wl_cfgvendor_significant_change_cfg(struct wiphy *wiphy,
 
 	significant_params = (gscan_swc_params_t *) kzalloc(len, GFP_KERNEL);
 	if (!significant_params) {
-		WL_ERR(("Cannot Malloc mem to parse config commands size - %d bytes \n", len));
+		WL_ERR(("Cannot Malloc mem to parse config commands size - %d bytes\n", len));
 		return -1;
 	}
 
@@ -858,47 +860,47 @@ static int wl_cfgvendor_significant_change_cfg(struct wiphy *wiphy,
 		type = nla_type(iter);
 
 		switch (type) {
-			case GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH:
+		case GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH:
 			flush = nla_get_u8(iter);
 			break;
-			case GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE:
-				significant_params->rssi_window = nla_get_u16(iter);
-				break;
-			case GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE:
-				significant_params->lost_ap_window = nla_get_u16(iter);
-				break;
-			case GSCAN_ATTRIBUTE_MIN_BREACHING:
-				significant_params->swc_threshold = nla_get_u16(iter);
-				break;
-			case GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS:
-				pbssid = significant_params->bssid_elem_list;
-				nla_for_each_nested(outer, iter, tmp) {
-					nla_for_each_nested(inner, outer, tmp1) {
-							switch (nla_type(inner)) {
-								case GSCAN_ATTRIBUTE_BSSID:
-								memcpy(&(pbssid[j].macaddr),
-								     nla_data(inner),
-								     ETHER_ADDR_LEN);
-								break;
-								case GSCAN_ATTRIBUTE_RSSI_HIGH:
-								pbssid[j].rssi_high_threshold =
-								       (int8) nla_get_u8(inner);
-								break;
-								case GSCAN_ATTRIBUTE_RSSI_LOW:
-								pbssid[j].rssi_low_threshold =
-								      (int8) nla_get_u8(inner);
-								break;
-							}
-						}
-					j++;
+		case GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE:
+			significant_params->rssi_window = nla_get_u16(iter);
+			break;
+		case GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE:
+			significant_params->lost_ap_window = nla_get_u16(iter);
+			break;
+		case GSCAN_ATTRIBUTE_MIN_BREACHING:
+			significant_params->swc_threshold = nla_get_u16(iter);
+			break;
+		case GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS:
+			pbssid = significant_params->bssid_elem_list;
+			nla_for_each_nested(outer, iter, tmp) {
+				nla_for_each_nested(inner, outer, tmp1) {
+					switch (nla_type(inner)) {
+					case GSCAN_ATTRIBUTE_BSSID:
+						memcpy(&(pbssid[j].macaddr),
+						       nla_data(inner),
+						       ETHER_ADDR_LEN);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_HIGH:
+						pbssid[j].rssi_high_threshold =
+							(int8) nla_get_u8(inner);
+						break;
+					case GSCAN_ATTRIBUTE_RSSI_LOW:
+						pbssid[j].rssi_low_threshold =
+							(int8) nla_get_u8(inner);
+						break;
+					}
 				}
-				break;
+				j++;
+			}
+			break;
 		}
 	}
 	significant_params->nbssid = j;
 
 	if (dhd_dev_pno_set_cfg_gscan(bcmcfg_to_prmry_ndev(cfg),
-	    DHD_PNO_SIGNIFICANT_SCAN_CFG_ID, significant_params, flush) < 0) {
+		DHD_PNO_SIGNIFICANT_SCAN_CFG_ID, significant_params, flush) < 0) {
 		WL_ERR(("Could not set GSCAN significant cfg\n"));
 		err = -EINVAL;
 		goto exit;
@@ -910,7 +912,7 @@ exit:
 #endif /* GSCAN_SUPPORT */
 
 #if defined(RTT_SUPPORT) && 0
-void wl_cfgvendor_rtt_evt(void *ctx, void *rtt_data)
+void rtw_cfgvendor_rtt_evt(void *ctx, void *rtt_data)
 {
 	struct wireless_dev *wdev = (struct wireless_dev *)ctx;
 	struct wiphy *wiphy;
@@ -931,7 +933,7 @@ void wl_cfgvendor_rtt_evt(void *ctx, void *rtt_data)
 	rtt_list = (struct list_head *)rtt_data;
 	kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
 	/* Alloc the SKB for vendor_event */
-	skb = rtw_cfg80211_vendor_event_alloc(wiphy, tot_len, GOOGLE_RTT_COMPLETE_EVENT, kflags);
+	skb = rtw_cfg80211_vendor_event_alloc(wiphy, wdev, tot_len, GOOGLE_RTT_COMPLETE_EVENT, kflags);
 	if (!skb) {
 		WL_ERR(("skb alloc failed"));
 		goto exit;
@@ -949,7 +951,7 @@ void wl_cfgvendor_rtt_evt(void *ctx, void *rtt_data)
 			rtt_report->addr = rtt_result->peer_mac;
 			rtt_report->num_measurement = 1; /* ONE SHOT */
 			rtt_report->status = rtt_result->err_code;
-			rtt_report->type = (rtt_result->TOF_type == TOF_TYPE_ONE_WAY) ? RTT_ONE_WAY: RTT_TWO_WAY;
+			rtt_report->type = (rtt_result->TOF_type == TOF_TYPE_ONE_WAY) ? RTT_ONE_WAY : RTT_TWO_WAY;
 			rtt_report->peer = rtt_result->target_info->peer;
 			rtt_report->channel = rtt_result->target_info->channel;
 			rtt_report->rssi = rtt_result->avg_rssi;
@@ -974,11 +976,12 @@ exit:
 	return;
 }
 
-static int wl_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev *wdev,
-					const void *data, int len) {
+static int rtw_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev *wdev,
+				       const void *data, int len)
+{
 	int err = 0, rem, rem1, rem2, type;
 	rtt_config_params_t rtt_param;
-	rtt_target_info_t* rtt_target = NULL;
+	rtt_target_info_t *rtt_target = NULL;
 	const struct nlattr *iter, *iter1, *iter2;
 	int8 eabuf[ETHER_ADDR_STR_LEN];
 	int8 chanbuf[CHANSPEC_STR_LEN];
@@ -1015,11 +1018,11 @@ static int wl_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev
 						rtt_target->type = nla_get_u8(iter2);
 						break;
 					case RTT_ATTRIBUTE_TARGET_PEER:
-						rtt_target->peer= nla_get_u8(iter2);
+						rtt_target->peer = nla_get_u8(iter2);
 						break;
 					case RTT_ATTRIBUTE_TARGET_CHAN:
 						memcpy(&rtt_target->channel, nla_data(iter2),
-							sizeof(rtt_target->channel));
+						       sizeof(rtt_target->channel));
 						break;
 					case RTT_ATTRIBUTE_TARGET_MODE:
 						rtt_target->continuous = nla_get_u8(iter2);
@@ -1040,10 +1043,10 @@ static int wl_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev
 				/* convert to chanspec value */
 				rtt_target->chanspec = dhd_rtt_convert_to_chspec(rtt_target->channel);
 				if (rtt_target->chanspec == 0) {
-					WL_ERR(("Channel is not valid \n"));
+					WL_ERR(("Channel is not valid\n"));
 					goto exit;
 				}
-				WL_INFORM(("Target addr %s, Channel : %s for RTT \n",
+				WL_INFORM(("Target addr %s, Channel : %s for RTT\n",
 					bcm_ether_ntoa((const struct ether_addr *)&rtt_target->addr, eabuf),
 					wf_chspec_ntoa(rtt_target->chanspec, chanbuf)));
 				rtt_target++;
@@ -1060,8 +1063,8 @@ exit:
 	return err;
 }
 
-static int wl_cfgvendor_rtt_cancel_config(struct wiphy *wiphy, struct wireless_dev *wdev,
-					const void *data, int len)
+static int rtw_cfgvendor_rtt_cancel_config(struct wiphy *wiphy, struct wireless_dev *wdev,
+		const void *data, int len)
 {
 	int err = 0, rem, type, target_cnt = 0;
 	const struct nlattr *iter;
@@ -1100,8 +1103,8 @@ exit:
 		kfree(mac_list);
 	return err;
 }
-static int wl_cfgvendor_rtt_get_capability(struct wiphy *wiphy, struct wireless_dev *wdev,
-					const void *data, int len)
+static int rtw_cfgvendor_rtt_get_capability(struct wiphy *wiphy, struct wireless_dev *wdev,
+		const void *data, int len)
 {
 	int err = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
@@ -1109,71 +1112,187 @@ static int wl_cfgvendor_rtt_get_capability(struct wiphy *wiphy, struct wireless_
 
 	err = dhd_dev_rtt_capability(bcmcfg_to_prmry_ndev(cfg), &capability);
 	if (unlikely(err)) {
-		WL_ERR(("Vendor Command reply failed ret:%d \n", err));
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
 		goto exit;
 	}
 	err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
-	        &capability, sizeof(capability));
+					    &capability, sizeof(capability));
 
-	if (unlikely(err)) {
-		WL_ERR(("Vendor Command reply failed ret:%d \n", err));
-	}
+	if (unlikely(err))
+		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
 exit:
 	return err;
 }
 
 #endif /* RTT_SUPPORT */
-static int wl_cfgvendor_priv_string_handler(struct wiphy *wiphy,
-	struct wireless_dev *wdev, const void  *data, int len)
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+enum {
+    LSTATS_SUBCMD_GET_INFO = ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START,
+	LSTATS_SUBCMD_SET_INFO,
+	LSTATS_SUBCMD_CLEAR_INFO,
+};
+static void LinkLayerStats(_adapter *padapter)
 {
-	int err = 0;
-	u8 resp[1] = {'\0'};
+	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
+	struct recv_priv		*precvpriv = &(padapter->recvpriv);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	u32 ps_time, trx_total_time;
+	u64 tx_bytes, rx_bytes, trx_total_bytes = 0;
+	u64 tmp = 0;
+	
+	RTW_DBG("%s adapter type : %u\n", __func__, padapter->adapter_type);
 
-	DBG_871X_LEVEL(_drv_always_, FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
-	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), resp, 1);
-	if (unlikely(err))
-		DBG_871X_LEVEL(_drv_err_, FUNC_NDEV_FMT"Vendor Command reply failed ret:%d \n"
-			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
+	tx_bytes = 0;
+	rx_bytes = 0;
+	ps_time = 0;
+	trx_total_time = 0;
 
-	return err;
-#if 0
-	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
-	int err = 0;
-	int data_len = 0;
+	if ( padapter->netif_up == _TRUE ) {
+
+		pwrpriv->on_time = rtw_get_passing_time_ms(pwrpriv->radio_on_start_time);
+
+		if (rtw_mi_check_fwstate(padapter, _FW_LINKED)) {
+			if ( pwrpriv->bpower_saving == _TRUE ) {
+				pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+			}
+		} else {		
+#ifdef CONFIG_IPS
+			if ( pwrpriv->bpower_saving == _TRUE ) {
+				pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+			}
+#else
+			pwrpriv->pwr_saving_time = pwrpriv->on_time;
+#endif
+		}
+
+		ps_time = pwrpriv->pwr_saving_time;
+
+		/* Deviation caused by caculation start time */
+		if ( ps_time > pwrpriv->on_time )
+			ps_time = pwrpriv->on_time;
+
+		tx_bytes = pdvobjpriv->traffic_stat.last_tx_bytes;
+		rx_bytes = pdvobjpriv->traffic_stat.last_rx_bytes;		
+		trx_total_bytes = tx_bytes + rx_bytes;
+
+		trx_total_time = pwrpriv->on_time - ps_time;
+		
+		if ( trx_total_bytes == 0) {
+			pwrpriv->tx_time = 0;
+			pwrpriv->rx_time = 0;
+		} else {
+
+			/* tx_time = (trx_total_time * tx_total_bytes) / trx_total_bytes; */
+			/* rx_time = (trx_total_time * rx_total_bytes) / trx_total_bytes; */
+		
+			tmp = (tx_bytes * trx_total_time);
+			tmp = rtw_division64(tmp, trx_total_bytes);
+			pwrpriv->tx_time = tmp;
 
-	bzero(cfg->ioctl_buf, WLC_IOCTL_MAXLEN);
+			tmp = (rx_bytes * trx_total_time);
+			tmp = rtw_division64(tmp, trx_total_bytes);
+			pwrpriv->rx_time = tmp;		
 
-	if (strncmp((char *)data, BRCM_VENDOR_SCMD_CAPA, strlen(BRCM_VENDOR_SCMD_CAPA)) == 0) {
-		err = wldev_iovar_getbuf(bcmcfg_to_prmry_ndev(cfg), "cap", NULL, 0,
-			cfg->ioctl_buf, WLC_IOCTL_MAXLEN, &cfg->ioctl_buf_sync);
-		if (unlikely(err)) {
-			WL_ERR(("error (%d)\n", err));
-			return err;
 		}
-		data_len = strlen(cfg->ioctl_buf);
-		cfg->ioctl_buf[data_len] = '\0';
+		
+	}
+	else {
+			pwrpriv->on_time = 0;
+			pwrpriv->tx_time = 0;
+			pwrpriv->rx_time = 0;	
 	}
 
-	err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
-		cfg->ioctl_buf, data_len+1);
-	if (unlikely(err))
-		WL_ERR(("Vendor Command reply failed ret:%d \n", err));
-	else
-		WL_INFORM(("Vendor Command reply sent successfully!\n"));
+#ifdef CONFIG_RTW_WIFI_HAL_DEBUG
+		RTW_INFO("- tx_bytes : %llu rx_bytes : %llu total bytes : %llu\n", tx_bytes, rx_bytes, trx_total_bytes);
+		RTW_INFO("- netif_up=%s, on_time : %u ms\n", padapter->netif_up ? "1":"0", pwrpriv->on_time);
+		RTW_INFO("- pwr_saving_time : %u (%u) ms\n", pwrpriv->pwr_saving_time, ps_time);
+		RTW_INFO("- trx_total_time : %u ms\n", trx_total_time);		
+		RTW_INFO("- tx_time : %u ms\n", pwrpriv->tx_time);
+		RTW_INFO("- rx_time : %u ms\n", pwrpriv->rx_time);
+#endif /* CONFIG_RTW_WIFI_HAL_DEBUG */
+
+}
+
+#define DUMMY_TIME_STATICS 99
+static int rtw_cfgvendor_lstats_get_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	_adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	wifi_radio_stat *radio;
+	wifi_iface_stat *iface;
+	char *output;
+
+	output = rtw_malloc(sizeof(wifi_radio_stat) + sizeof(wifi_iface_stat)+1);
+	if (output == NULL) {
+		RTW_DBG("Allocate lstats info buffer fail!\n");
+}
+
+	radio = (wifi_radio_stat *)output;
 
+	radio->num_channels = 0;
+	radio->radio = 1;
+
+	/* to get on_time, tx_time, rx_time */
+	LinkLayerStats(padapter); 
+	
+	radio->on_time = pwrpriv->on_time;
+	radio->tx_time = pwrpriv->tx_time;
+	radio->rx_time = pwrpriv->rx_time;
+	
+	radio->num_tx_levels = 1;
+	radio->tx_time_per_levels = NULL;
+	radio->tx_time_per_levels = (u32*)(output+sizeof(wifi_radio_stat) + sizeof(wifi_iface_stat));
+	*(radio->tx_time_per_levels) = DUMMY_TIME_STATICS;
+
+	radio->on_time_scan = 0;
+	radio->on_time_nbd = 0;
+	radio->on_time_gscan = 0;
+	radio->on_time_pno_scan = 0;
+	radio->on_time_hs20 = 0;
+	#ifdef CONFIG_RTW_WIFI_HAL_DEBUG
+	RTW_INFO("==== %s ====\n", __func__);
+	RTW_INFO("radio->radio : %d\n", (radio->radio));
+	RTW_INFO("pwrpriv->on_time : %u ms\n", (pwrpriv->on_time));
+	RTW_INFO("pwrpriv->tx_time :  %u ms\n", (pwrpriv->tx_time));
+	RTW_INFO("pwrpriv->rx_time :  %u ms\n", (pwrpriv->rx_time));
+	RTW_INFO("radio->on_time :  %u ms\n", (radio->on_time));
+	RTW_INFO("radio->tx_time :  %u ms\n", (radio->tx_time));
+	RTW_INFO("radio->rx_time :  %u ms\n", (radio->rx_time));
+	RTW_INFO("radio->tx_time_per_levels value :  %u ms\n", *(radio->tx_time_per_levels));
+	#endif /* CONFIG_RTW_WIFI_HAL_DEBUG */
+	
+	RTW_DBG(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
+	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), 
+		output, sizeof(wifi_iface_stat) + sizeof(wifi_radio_stat)+1);
+	if (unlikely(err))
+		RTW_ERR(FUNC_NDEV_FMT"Vendor Command reply failed ret:%d \n"
+			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
+	rtw_mfree(output, sizeof(wifi_iface_stat) + sizeof(wifi_radio_stat)+1);
+	return err;
+}
+static int rtw_cfgvendor_lstats_set_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	RTW_INFO("%s\n", __func__);
+	return err;
+}
+static int rtw_cfgvendor_lstats_clear_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	RTW_INFO("%s\n", __func__);
 	return err;
-#endif
 }
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
 
-static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
-	{
-		{
-			.vendor_id = OUI_BRCM,
-			.subcmd = BRCM_VENDOR_SCMD_PRIV_STR
-		},
-		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_priv_string_handler
-	},
+static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 #if defined(GSCAN_SUPPORT) && 0
 	{
 		{
@@ -1181,7 +1300,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_GET_CAPABILITIES
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_gscan_get_capabilities
+		.doit = rtw_cfgvendor_gscan_get_capabilities
 	},
 	{
 		{
@@ -1189,7 +1308,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_SET_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_set_scan_cfg
+		.doit = rtw_cfgvendor_set_scan_cfg
 	},
 	{
 		{
@@ -1197,7 +1316,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_SET_SCAN_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_set_batch_scan_cfg
+		.doit = rtw_cfgvendor_set_batch_scan_cfg
 	},
 	{
 		{
@@ -1205,7 +1324,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_ENABLE_GSCAN
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_initiate_gscan
+		.doit = rtw_cfgvendor_initiate_gscan
 	},
 	{
 		{
@@ -1213,7 +1332,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_enable_full_scan_result
+		.doit = rtw_cfgvendor_enable_full_scan_result
 	},
 	{
 		{
@@ -1221,7 +1340,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_SET_HOTLIST
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_hotlist_cfg
+		.doit = rtw_cfgvendor_hotlist_cfg
 	},
 	{
 		{
@@ -1229,7 +1348,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_significant_change_cfg
+		.doit = rtw_cfgvendor_significant_change_cfg
 	},
 	{
 		{
@@ -1237,7 +1356,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_GET_SCAN_RESULTS
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_gscan_get_batch_results
+		.doit = rtw_cfgvendor_gscan_get_batch_results
 	},
 	{
 		{
@@ -1245,7 +1364,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = GSCAN_SUBCMD_GET_CHANNEL_LIST
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_gscan_get_channel_list
+		.doit = rtw_cfgvendor_gscan_get_channel_list
 	},
 #endif /* GSCAN_SUPPORT */
 #if defined(RTT_SUPPORT) && 0
@@ -1255,7 +1374,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = RTT_SUBCMD_SET_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_rtt_set_config
+		.doit = rtw_cfgvendor_rtt_set_config
 	},
 	{
 		{
@@ -1263,7 +1382,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = RTT_SUBCMD_CANCEL_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_rtt_cancel_config
+		.doit = rtw_cfgvendor_rtt_cancel_config
 	},
 	{
 		{
@@ -1271,13 +1390,39 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 			.subcmd = RTT_SUBCMD_GETCAPABILITY
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_rtt_get_capability
+		.doit = rtw_cfgvendor_rtt_get_capability
 	},
 #endif /* RTT_SUPPORT */
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
 	{
 		{
 			.vendor_id = OUI_GOOGLE,
-			.subcmd = ANDR_WIFI_SUBCMD_GET_FEATURE_SET
+			.subcmd = LSTATS_SUBCMD_GET_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_get_info
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LSTATS_SUBCMD_SET_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_set_info
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LSTATS_SUBCMD_CLEAR_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_clear_info
+	},
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_GET_FEATURE_SET
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
 		.doit = rtw_cfgvendor_get_feature_set
@@ -1285,35 +1430,33 @@ static const struct wiphy_vendor_command rtw_vendor_cmds [] = {
 	{
 		{
 			.vendor_id = OUI_GOOGLE,
-			.subcmd = ANDR_WIFI_SUBCMD_GET_FEATURE_SET_MATRIX
+			.subcmd = WIFI_SUBCMD_GET_FEATURE_SET_MATRIX
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
 		.doit = rtw_cfgvendor_get_feature_set_matrix
 	}
 };
 
-static const struct  nl80211_vendor_cmd_info rtw_vendor_events [] = {
-		{ OUI_BRCM, BRCM_VENDOR_EVENT_UNSPEC },
-		{ OUI_BRCM, BRCM_VENDOR_EVENT_PRIV_STR },
+static const struct  nl80211_vendor_cmd_info rtw_vendor_events[] = {
 #if defined(GSCAN_SUPPORT) && 0
-		{ OUI_GOOGLE, GOOGLE_GSCAN_SIGNIFICANT_EVENT },
-		{ OUI_GOOGLE, GOOGLE_GSCAN_GEOFENCE_FOUND_EVENT },
-		{ OUI_GOOGLE, GOOGLE_GSCAN_BATCH_SCAN_EVENT },
-		{ OUI_GOOGLE, GOOGLE_SCAN_FULL_RESULTS_EVENT },
+	{ OUI_GOOGLE, GSCAN_EVENT_SIGNIFICANT_CHANGE_RESULTS },
+	{ OUI_GOOGLE, GSCAN_EVENT_HOTLIST_RESULTS_FOUND },
+	{ OUI_GOOGLE, GSCAN_EVENT_SCAN_RESULTS_AVAILABLE },
+	{ OUI_GOOGLE, GSCAN_EVENT_FULL_SCAN_RESULTS },
 #endif /* GSCAN_SUPPORT */
 #if defined(RTT_SUPPORT) && 0
-		{ OUI_GOOGLE, GOOGLE_RTT_COMPLETE_EVENT },
+	{ OUI_GOOGLE, RTT_EVENT_COMPLETE },
 #endif /* RTT_SUPPORT */
 #if defined(GSCAN_SUPPORT) && 0
-		{ OUI_GOOGLE, GOOGLE_SCAN_COMPLETE_EVENT },
-		{ OUI_GOOGLE, GOOGLE_GSCAN_GEOFENCE_LOST_EVENT }
+	{ OUI_GOOGLE, GSCAN_EVENT_COMPLETE_SCAN },
+	{ OUI_GOOGLE, GSCAN_EVENT_HOTLIST_RESULTS_LOST }
 #endif /* GSCAN_SUPPORT */
 };
 
 int rtw_cfgvendor_attach(struct wiphy *wiphy)
 {
 
-	DBG_871X("Register RTW cfg80211 vendor cmd(0x%x) interface \n", NL80211_CMD_VENDOR);
+	RTW_INFO("Register RTW cfg80211 vendor cmd(0x%x) interface\n", NL80211_CMD_VENDOR);
 
 	wiphy->vendor_commands	= rtw_vendor_cmds;
 	wiphy->n_vendor_commands = ARRAY_SIZE(rtw_vendor_cmds);
@@ -1325,7 +1468,7 @@ int rtw_cfgvendor_attach(struct wiphy *wiphy)
 
 int rtw_cfgvendor_detach(struct wiphy *wiphy)
 {
-	DBG_871X("Vendor: Unregister RTW cfg80211 vendor interface \n");
+	RTW_INFO("Vendor: Unregister RTW cfg80211 vendor interface\n");
 
 	wiphy->vendor_commands  = NULL;
 	wiphy->vendor_events    = NULL;
@@ -1337,4 +1480,3 @@ int rtw_cfgvendor_detach(struct wiphy *wiphy)
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT) */
 
 #endif /* CONFIG_IOCTL_CFG80211 */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.h
index 7c349e79daa2..f4dec34b10ea 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_cfgvendor.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2014 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,19 +12,12 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #ifndef _RTW_CFGVENDOR_H_
 #define _RTW_CFGVENDOR_H_
 
-#define OUI_BRCM    0x001018
 #define OUI_GOOGLE  0x001A11
-#define BRCM_VENDOR_SUBCMD_PRIV_STR	1
 #define ATTRIBUTE_U32_LEN                  (NLA_HDRLEN  + 4)
 #define VENDOR_ID_OVERHEAD                 ATTRIBUTE_U32_LEN
 #define VENDOR_SUBCMD_OVERHEAD             ATTRIBUTE_U32_LEN
@@ -36,117 +30,154 @@
 #define GSCAN_NUM_RESULTS_HDR_LEN            ATTRIBUTE_U32_LEN
 #define GSCAN_RESULTS_HDR_LEN                (NLA_HDRLEN)
 #define GSCAN_BATCH_RESULT_HDR_LEN  (SCAN_INDEX_HDR_LEN + SCAN_ID_HDR_LEN + \
-									SCAN_FLAGS_HDR_LEN + \
-							        GSCAN_NUM_RESULTS_HDR_LEN + \
-									GSCAN_RESULTS_HDR_LEN)
+				     SCAN_FLAGS_HDR_LEN + \
+				     GSCAN_NUM_RESULTS_HDR_LEN + \
+				     GSCAN_RESULTS_HDR_LEN)
 
 #define VENDOR_REPLY_OVERHEAD       (VENDOR_ID_OVERHEAD + \
-									VENDOR_SUBCMD_OVERHEAD + \
-									VENDOR_DATA_OVERHEAD)
+				     VENDOR_SUBCMD_OVERHEAD + \
+				     VENDOR_DATA_OVERHEAD)
 typedef enum {
-	/* don't use 0 as a valid subcommand */
-	VENDOR_NL80211_SUBCMD_UNSPECIFIED,
+    /* don't use 0 as a valid subcommand */
+    VENDOR_NL80211_SUBCMD_UNSPECIFIED,
+
+    /* define all vendor startup commands between 0x0 and 0x0FFF */
+    VENDOR_NL80211_SUBCMD_RANGE_START = 0x0001,
+    VENDOR_NL80211_SUBCMD_RANGE_END   = 0x0FFF,
+
+    /* define all GScan related commands between 0x1000 and 0x10FF */
+    ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START = 0x1000,
+    ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END   = 0x10FF,
+
+    /* define all NearbyDiscovery related commands between 0x1100 and 0x11FF */
+    ANDROID_NL80211_SUBCMD_NBD_RANGE_START = 0x1100,
+    ANDROID_NL80211_SUBCMD_NBD_RANGE_END   = 0x11FF,
 
-	/* define all vendor startup commands between 0x0 and 0x0FFF */
-	VENDOR_NL80211_SUBCMD_RANGE_START = 0x0001,
-	VENDOR_NL80211_SUBCMD_RANGE_END   = 0x0FFF,
+    /* define all RTT related commands between 0x1100 and 0x11FF */
+    ANDROID_NL80211_SUBCMD_RTT_RANGE_START = 0x1100,
+    ANDROID_NL80211_SUBCMD_RTT_RANGE_END   = 0x11FF,
 
-	/* define all GScan related commands between 0x1000 and 0x10FF */
-	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START = 0x1000,
-	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END   = 0x10FF,
+    ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START = 0x1200,
+    ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END   = 0x12FF,
 
-	/* define all NearbyDiscovery related commands between 0x1100 and 0x11FF */
-	ANDROID_NL80211_SUBCMD_NBD_RANGE_START = 0x1100,
-	ANDROID_NL80211_SUBCMD_NBD_RANGE_END   = 0x11FF,
+    /* define all Logger related commands between 0x1400 and 0x14FF */
+    ANDROID_NL80211_SUBCMD_DEBUG_RANGE_START = 0x1400,
+    ANDROID_NL80211_SUBCMD_DEBUG_RANGE_END   = 0x14FF,
 
-	/* define all RTT related commands between 0x1100 and 0x11FF */
-	ANDROID_NL80211_SUBCMD_RTT_RANGE_START = 0x1100,
-	ANDROID_NL80211_SUBCMD_RTT_RANGE_END   = 0x11FF,
+    /* define all wifi offload related commands between 0x1600 and 0x16FF */
+    ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_START = 0x1600,
+    ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_END   = 0x16FF,
 
-	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START = 0x1200,
-	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END   = 0x12FF,
+    /* define all NAN related commands between 0x1700 and 0x17FF */
+    ANDROID_NL80211_SUBCMD_NAN_RANGE_START = 0x1700,
+    ANDROID_NL80211_SUBCMD_NAN_RANGE_END   = 0x17FF,
 
-	ANDROID_NL80211_SUBCMD_TDLS_RANGE_START = 0x1300,
-	ANDROID_NL80211_SUBCMD_TDLS_RANGE_END	= 0x13FF,
-	/* This is reserved for future usage */
+    /* define all Android Packet Filter related commands between 0x1800 and 0x18FF */
+    ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START = 0x1800,
+    ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_END   = 0x18FF,
+
+    /* This is reserved for future usage */
 
 } ANDROID_VENDOR_SUB_COMMAND;
 
-enum wl_vendor_subcmd {
-	BRCM_VENDOR_SCMD_UNSPEC,
-	BRCM_VENDOR_SCMD_PRIV_STR,
-	GSCAN_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START,
-	GSCAN_SUBCMD_SET_CONFIG,
-	GSCAN_SUBCMD_SET_SCAN_CONFIG,
-	GSCAN_SUBCMD_ENABLE_GSCAN,
-	GSCAN_SUBCMD_GET_SCAN_RESULTS,
-	GSCAN_SUBCMD_SCAN_RESULTS,
-	GSCAN_SUBCMD_SET_HOTLIST,
-	GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG,
-	GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS,
-	GSCAN_SUBCMD_GET_CHANNEL_LIST,
-	ANDR_WIFI_SUBCMD_GET_FEATURE_SET,
-	ANDR_WIFI_SUBCMD_GET_FEATURE_SET_MATRIX,
+enum rtw_vendor_subcmd {
+    GSCAN_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START,
+
+    GSCAN_SUBCMD_SET_CONFIG,                            /* 0x1001 */
+
+    GSCAN_SUBCMD_SET_SCAN_CONFIG,                       /* 0x1002 */
+    GSCAN_SUBCMD_ENABLE_GSCAN,                          /* 0x1003 */
+    GSCAN_SUBCMD_GET_SCAN_RESULTS,                      /* 0x1004 */
+    GSCAN_SUBCMD_SCAN_RESULTS,                          /* 0x1005 */
+
+    GSCAN_SUBCMD_SET_HOTLIST,                           /* 0x1006 */
+
+    GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG,         /* 0x1007 */
+    GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS,              /* 0x1008 */
+    GSCAN_SUBCMD_GET_CHANNEL_LIST,                       /* 0x1009 */
+
+    WIFI_SUBCMD_GET_FEATURE_SET,                         /* 0x100A */
+    WIFI_SUBCMD_GET_FEATURE_SET_MATRIX,                  /* 0x100B */
+    WIFI_SUBCMD_SET_PNO_RANDOM_MAC_OUI,                  /* 0x100C */
+    WIFI_SUBCMD_NODFS_SET,                               /* 0x100D */
+    WIFI_SUBCMD_SET_COUNTRY_CODE,                             /* 0x100E */
+    /* Add more sub commands here */
+    GSCAN_SUBCMD_SET_EPNO_SSID,                          /* 0x100F */
+
+    WIFI_SUBCMD_SET_SSID_WHITE_LIST,                    /* 0x1010 */
+    WIFI_SUBCMD_SET_ROAM_PARAMS,                        /* 0x1011 */
+    WIFI_SUBCMD_ENABLE_LAZY_ROAM,                       /* 0x1012 */
+    WIFI_SUBCMD_SET_BSSID_PREF,                         /* 0x1013 */
+    WIFI_SUBCMD_SET_BSSID_BLACKLIST,                     /* 0x1014 */
+
+    GSCAN_SUBCMD_ANQPO_CONFIG,                          /* 0x1015 */
+    WIFI_SUBCMD_SET_RSSI_MONITOR,                       /* 0x1016 */
+    WIFI_SUBCMD_CONFIG_ND_OFFLOAD,                      /* 0x1017 */
+    /* Add more sub commands here */
+
+    GSCAN_SUBCMD_MAX,
+
 	RTT_SUBCMD_SET_CONFIG = ANDROID_NL80211_SUBCMD_RTT_RANGE_START,
 	RTT_SUBCMD_CANCEL_CONFIG,
 	RTT_SUBCMD_GETCAPABILITY,
-    /* Add more sub commands here */
-    VENDOR_SUBCMD_MAX
+
+    APF_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START,
+    APF_SUBCMD_SET_FILTER,
 };
 
 enum gscan_attributes {
-    GSCAN_ATTRIBUTE_NUM_BUCKETS = 10,
-    GSCAN_ATTRIBUTE_BASE_PERIOD,
-    GSCAN_ATTRIBUTE_BUCKETS_BAND,
-    GSCAN_ATTRIBUTE_BUCKET_ID,
-    GSCAN_ATTRIBUTE_BUCKET_PERIOD,
-    GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS,
-    GSCAN_ATTRIBUTE_BUCKET_CHANNELS,
-    GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN,
-    GSCAN_ATTRIBUTE_REPORT_THRESHOLD,
-    GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE,
-    GSCAN_ATTRIBUTE_BAND = GSCAN_ATTRIBUTE_BUCKETS_BAND,
-
-    GSCAN_ATTRIBUTE_ENABLE_FEATURE = 20,
-    GSCAN_ATTRIBUTE_SCAN_RESULTS_COMPLETE,
-    GSCAN_ATTRIBUTE_FLUSH_FEATURE,
-    GSCAN_ATTRIBUTE_ENABLE_FULL_SCAN_RESULTS,
-    GSCAN_ATTRIBUTE_REPORT_EVENTS,
-    /* remaining reserved for additional attributes */
-    GSCAN_ATTRIBUTE_NUM_OF_RESULTS = 30,
-    GSCAN_ATTRIBUTE_FLUSH_RESULTS,
-    GSCAN_ATTRIBUTE_SCAN_RESULTS,                       /* flat array of wifi_scan_result */
-    GSCAN_ATTRIBUTE_SCAN_ID,                            /* indicates scan number */
-    GSCAN_ATTRIBUTE_SCAN_FLAGS,                         /* indicates if scan was aborted */
-    GSCAN_ATTRIBUTE_AP_FLAGS,                           /* flags on significant change event */
-    GSCAN_ATTRIBUTE_NUM_CHANNELS,
-    GSCAN_ATTRIBUTE_CHANNEL_LIST,
+	GSCAN_ATTRIBUTE_NUM_BUCKETS = 10,
+	GSCAN_ATTRIBUTE_BASE_PERIOD,
+	GSCAN_ATTRIBUTE_BUCKETS_BAND,
+	GSCAN_ATTRIBUTE_BUCKET_ID,
+	GSCAN_ATTRIBUTE_BUCKET_PERIOD,
+	GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS,
+	GSCAN_ATTRIBUTE_BUCKET_CHANNELS,
+	GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN,
+	GSCAN_ATTRIBUTE_REPORT_THRESHOLD,
+	GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE,
+	GSCAN_ATTRIBUTE_BAND = GSCAN_ATTRIBUTE_BUCKETS_BAND,
+
+	GSCAN_ATTRIBUTE_ENABLE_FEATURE = 20,
+	GSCAN_ATTRIBUTE_SCAN_RESULTS_COMPLETE,
+	GSCAN_ATTRIBUTE_FLUSH_FEATURE,
+	GSCAN_ATTRIBUTE_ENABLE_FULL_SCAN_RESULTS,
+	GSCAN_ATTRIBUTE_REPORT_EVENTS,
+	/* remaining reserved for additional attributes */
+	GSCAN_ATTRIBUTE_NUM_OF_RESULTS = 30,
+	GSCAN_ATTRIBUTE_FLUSH_RESULTS,
+	GSCAN_ATTRIBUTE_SCAN_RESULTS,                       /* flat array of wifi_scan_result */
+	GSCAN_ATTRIBUTE_SCAN_ID,                            /* indicates scan number */
+	GSCAN_ATTRIBUTE_SCAN_FLAGS,                         /* indicates if scan was aborted */
+	GSCAN_ATTRIBUTE_AP_FLAGS,                           /* flags on significant change event */
+	GSCAN_ATTRIBUTE_NUM_CHANNELS,
+	GSCAN_ATTRIBUTE_CHANNEL_LIST,
 
 	/* remaining reserved for additional attributes */
 
-    GSCAN_ATTRIBUTE_SSID = 40,
-    GSCAN_ATTRIBUTE_BSSID,
-    GSCAN_ATTRIBUTE_CHANNEL,
-    GSCAN_ATTRIBUTE_RSSI,
-    GSCAN_ATTRIBUTE_TIMESTAMP,
-    GSCAN_ATTRIBUTE_RTT,
-    GSCAN_ATTRIBUTE_RTTSD,
-
-    /* remaining reserved for additional attributes */
-
-    GSCAN_ATTRIBUTE_HOTLIST_BSSIDS = 50,
-    GSCAN_ATTRIBUTE_RSSI_LOW,
-    GSCAN_ATTRIBUTE_RSSI_HIGH,
-    GSCAN_ATTRIBUTE_HOSTLIST_BSSID_ELEM,
-    GSCAN_ATTRIBUTE_HOTLIST_FLUSH,
-
-    /* remaining reserved for additional attributes */
-    GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE = 60,
-    GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE,
-    GSCAN_ATTRIBUTE_MIN_BREACHING,
-    GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS,
-    GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH,
-    GSCAN_ATTRIBUTE_MAX
+	GSCAN_ATTRIBUTE_SSID = 40,
+	GSCAN_ATTRIBUTE_BSSID,
+	GSCAN_ATTRIBUTE_CHANNEL,
+	GSCAN_ATTRIBUTE_RSSI,
+	GSCAN_ATTRIBUTE_TIMESTAMP,
+	GSCAN_ATTRIBUTE_RTT,
+	GSCAN_ATTRIBUTE_RTTSD,
+
+	/* remaining reserved for additional attributes */
+
+	GSCAN_ATTRIBUTE_HOTLIST_BSSIDS = 50,
+	GSCAN_ATTRIBUTE_RSSI_LOW,
+	GSCAN_ATTRIBUTE_RSSI_HIGH,
+	GSCAN_ATTRIBUTE_HOSTLIST_BSSID_ELEM,
+	GSCAN_ATTRIBUTE_HOTLIST_FLUSH,
+
+	/* remaining reserved for additional attributes */
+	GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE = 60,
+	GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE,
+	GSCAN_ATTRIBUTE_MIN_BREACHING,
+	GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS,
+	GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH,
+	GSCAN_ATTRIBUTE_MAX
 };
 
 enum gscan_bucket_attributes {
@@ -183,24 +214,29 @@ enum rtt_attributes {
 	RTT_ATTRIBUTE_TARGET_NUM_RETRY
 };
 
-typedef enum wl_vendor_event {
-	BRCM_VENDOR_EVENT_UNSPEC,
-	BRCM_VENDOR_EVENT_PRIV_STR,
-	GOOGLE_GSCAN_SIGNIFICANT_EVENT,
-	GOOGLE_GSCAN_GEOFENCE_FOUND_EVENT,
-	GOOGLE_GSCAN_BATCH_SCAN_EVENT,
-	GOOGLE_SCAN_FULL_RESULTS_EVENT,
-	GOOGLE_RTT_COMPLETE_EVENT,
-	GOOGLE_SCAN_COMPLETE_EVENT,
-	GOOGLE_GSCAN_GEOFENCE_LOST_EVENT
-} wl_vendor_event_t;
+typedef enum rtw_vendor_event {
+    RTK_RESERVED1,
+    RTK_RESERVED2,
+    GSCAN_EVENT_SIGNIFICANT_CHANGE_RESULTS ,
+    GSCAN_EVENT_HOTLIST_RESULTS_FOUND,
+    GSCAN_EVENT_SCAN_RESULTS_AVAILABLE,
+    GSCAN_EVENT_FULL_SCAN_RESULTS,
+    RTT_EVENT_COMPLETE,
+    GSCAN_EVENT_COMPLETE_SCAN,
+    GSCAN_EVENT_HOTLIST_RESULTS_LOST,
+    GSCAN_EVENT_EPNO_EVENT,
+    GOOGLE_DEBUG_RING_EVENT,
+    GOOGLE_DEBUG_MEM_DUMP_EVENT,
+    GSCAN_EVENT_ANQPO_HOTSPOT_MATCH,
+    GOOGLE_RSSI_MONITOR_EVENT
+} rtw_vendor_event_t;
 
 enum andr_wifi_feature_set_attr {
-    ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET,
-    ANDR_WIFI_ATTRIBUTE_FEATURE_SET
+	ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET,
+	ANDR_WIFI_ATTRIBUTE_FEATURE_SET
 };
 
-typedef enum wl_vendor_gscan_attribute {
+typedef enum rtw_vendor_gscan_attribute {
 	ATTR_START_GSCAN,
 	ATTR_STOP_GSCAN,
 	ATTR_SET_SCAN_BATCH_CFG_ID, /* set batch scan params */
@@ -208,9 +244,9 @@ typedef enum wl_vendor_gscan_attribute {
 	ATTR_SET_SCAN_SIGNIFICANT_CFG_ID, /* set list of bssids, rssi threshold etc.. */
 	ATTR_SET_SCAN_CFG_ID, /* set common scan config params here */
 	ATTR_GET_GSCAN_CAPABILITIES_ID,
-    /* Add more sub commands here */
-    ATTR_GSCAN_MAX
-} wl_vendor_gscan_attribute_t;
+	/* Add more sub commands here */
+	ATTR_GSCAN_MAX
+} rtw_vendor_gscan_attribute_t;
 
 typedef enum gscan_batch_attribute {
 	ATTR_GSCAN_BATCH_BESTN,
@@ -227,20 +263,298 @@ typedef enum gscan_complete_event {
 	WIFI_SCAN_BUFFER_FULL,
 	WIFI_SCAN_COMPLETE
 } gscan_complete_event_t;
+/* wifi_hal.h */
+/* WiFi Common definitions */
+typedef unsigned char byte;
+typedef int wifi_request_id;
+typedef int wifi_channel;                       // indicates channel frequency in MHz
+typedef int wifi_rssi;
+typedef byte mac_addr[6];
+typedef byte oui[3];
+typedef int64_t wifi_timestamp;                 // In microseconds (us)
+typedef int64_t wifi_timespan;                  // In picoseconds  (ps)
+
+struct wifi_info;
+struct wifi_interface_info;
+typedef struct wifi_info *wifi_handle;
+typedef struct wifi_interface_info *wifi_interface_handle;
+
+/* channel operating width */
+typedef enum {
+    WIFI_CHAN_WIDTH_20    = 0,
+    WIFI_CHAN_WIDTH_40    = 1,
+    WIFI_CHAN_WIDTH_80    = 2,
+    WIFI_CHAN_WIDTH_160   = 3,
+    WIFI_CHAN_WIDTH_80P80 = 4,
+    WIFI_CHAN_WIDTH_5     = 5,
+    WIFI_CHAN_WIDTH_10    = 6,
+    WIFI_CHAN_WIDTH_INVALID = -1
+} wifi_channel_width;
+
+typedef int wifi_radio;
+
+typedef struct {
+    wifi_channel_width width;
+    int center_frequency0;
+    int center_frequency1;
+    int primary_frequency;
+} wifi_channel_spec;
+
+typedef enum {
+    WIFI_SUCCESS = 0,
+    WIFI_ERROR_NONE = 0,
+    WIFI_ERROR_UNKNOWN = -1,
+    WIFI_ERROR_UNINITIALIZED = -2,
+    WIFI_ERROR_NOT_SUPPORTED = -3,
+    WIFI_ERROR_NOT_AVAILABLE = -4,              // Not available right now, but try later
+    WIFI_ERROR_INVALID_ARGS = -5,
+    WIFI_ERROR_INVALID_REQUEST_ID = -6,
+    WIFI_ERROR_TIMED_OUT = -7,
+    WIFI_ERROR_TOO_MANY_REQUESTS = -8,          // Too many instances of this request
+    WIFI_ERROR_OUT_OF_MEMORY = -9,
+    WIFI_ERROR_BUSY = -10,
+} wifi_error;
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+#define STATS_MAJOR_VERSION      1
+#define STATS_MINOR_VERSION      0
+#define STATS_MICRO_VERSION      0
+
+typedef enum {
+    WIFI_DISCONNECTED = 0,
+    WIFI_AUTHENTICATING = 1,
+    WIFI_ASSOCIATING = 2,
+    WIFI_ASSOCIATED = 3,
+    WIFI_EAPOL_STARTED = 4,   // if done by firmware/driver
+    WIFI_EAPOL_COMPLETED = 5, // if done by firmware/driver
+} wifi_connection_state;
+
+typedef enum {
+    WIFI_ROAMING_IDLE = 0,
+    WIFI_ROAMING_ACTIVE = 1,
+} wifi_roam_state;
+
+typedef enum {
+    WIFI_INTERFACE_STA = 0,
+    WIFI_INTERFACE_SOFTAP = 1,
+    WIFI_INTERFACE_IBSS = 2,
+    WIFI_INTERFACE_P2P_CLIENT = 3,
+    WIFI_INTERFACE_P2P_GO = 4,
+    WIFI_INTERFACE_NAN = 5,
+    WIFI_INTERFACE_MESH = 6,
+    WIFI_INTERFACE_UNKNOWN = -1
+ } wifi_interface_mode;
+
+#define WIFI_CAPABILITY_QOS          0x00000001     // set for QOS association
+#define WIFI_CAPABILITY_PROTECTED    0x00000002     // set for protected association (802.11 beacon frame control protected bit set)
+#define WIFI_CAPABILITY_INTERWORKING 0x00000004     // set if 802.11 Extended Capabilities element interworking bit is set
+#define WIFI_CAPABILITY_HS20         0x00000008     // set for HS20 association
+#define WIFI_CAPABILITY_SSID_UTF8    0x00000010     // set is 802.11 Extended Capabilities element UTF-8 SSID bit is set
+#define WIFI_CAPABILITY_COUNTRY      0x00000020     // set is 802.11 Country Element is present
+
+typedef struct {
+   wifi_interface_mode mode;     // interface mode
+   u8 mac_addr[6];               // interface mac address (self)
+   wifi_connection_state state;  // connection state (valid for STA, CLI only)
+   wifi_roam_state roaming;      // roaming state
+   u32 capabilities;             // WIFI_CAPABILITY_XXX (self)
+   u8 ssid[33];                  // null terminated SSID
+   u8 bssid[6];                  // bssid
+   u8 ap_country_str[3];         // country string advertised by AP
+   u8 country_str[3];            // country string for this association
+} wifi_interface_link_layer_info;
+
+/* channel information */
+typedef struct {
+   wifi_channel_width width;   // channel width (20, 40, 80, 80+80, 160)
+   wifi_channel center_freq;   // primary 20 MHz channel
+   wifi_channel center_freq0;  // center frequency (MHz) first segment
+   wifi_channel center_freq1;  // center frequency (MHz) second segment
+} wifi_channel_info;
+
+/* wifi rate */
+typedef struct {
+   u32 preamble   :3;   // 0: OFDM, 1:CCK, 2:HT 3:VHT 4..7 reserved
+   u32 nss        :2;   // 0:1x1, 1:2x2, 3:3x3, 4:4x4
+   u32 bw         :3;   // 0:20MHz, 1:40Mhz, 2:80Mhz, 3:160Mhz
+   u32 rateMcsIdx :8;   // OFDM/CCK rate code would be as per ieee std in the units of 0.5mbps
+                        // HT/VHT it would be mcs index
+   u32 reserved  :16;   // reserved
+   u32 bitrate;         // units of 100 Kbps
+} wifi_rate;
+
+/* channel statistics */
+typedef struct {
+   wifi_channel_info channel;  // channel
+   u32 on_time;                // msecs the radio is awake (32 bits number accruing over time)
+   u32 cca_busy_time;          // msecs the CCA register is busy (32 bits number accruing over time)
+} wifi_channel_stat;
+
+// Max number of tx power levels. The actual number vary per device and is specified by |num_tx_levels|
+#define RADIO_STAT_MAX_TX_LEVELS 256
+
+/* radio statistics */
+typedef struct {
+   wifi_radio radio;                      // wifi radio (if multiple radio supported)
+   u32 on_time;                           // msecs the radio is awake (32 bits number accruing over time)
+   u32 tx_time;                           // msecs the radio is transmitting (32 bits number accruing over time)
+   u32 num_tx_levels;                     // number of radio transmit power levels
+   u32* tx_time_per_levels;               // pointer to an array of radio transmit per power levels in
+                                          // msecs accured over time
+   u32 rx_time;                           // msecs the radio is in active receive (32 bits number accruing over time)
+   u32 on_time_scan;                      // msecs the radio is awake due to all scan (32 bits number accruing over time)
+   u32 on_time_nbd;                       // msecs the radio is awake due to NAN (32 bits number accruing over time)
+   u32 on_time_gscan;                     // msecs the radio is awake due to G?scan (32 bits number accruing over time)
+   u32 on_time_roam_scan;                 // msecs the radio is awake due to roam?scan (32 bits number accruing over time)
+   u32 on_time_pno_scan;                  // msecs the radio is awake due to PNO scan (32 bits number accruing over time)
+   u32 on_time_hs20;                      // msecs the radio is awake due to HS2.0 scans and GAS exchange (32 bits number accruing over time)
+   u32 num_channels;                      // number of channels
+   wifi_channel_stat channels[];          // channel statistics
+} wifi_radio_stat;
+
+/**
+ * Packet statistics reporting by firmware is performed on MPDU basi (i.e. counters increase by 1 for each MPDU)
+ * As well, "data packet" in associated comments, shall be interpreted as 802.11 data packet,
+ * that is, 802.11 frame control subtype == 2 and excluding management and control frames.
+ *
+ * As an example, in the case of transmission of an MSDU fragmented in 16 MPDUs which are transmitted
+ * OTA in a 16 units long a-mpdu, for which a block ack is received with 5 bits set:
+ *          tx_mpdu : shall increase by 5
+ *          retries : shall increase by 16
+ *          tx_ampdu : shall increase by 1
+ * data packet counters shall not increase regardless of the number of BAR potentially sent by device for this a-mpdu
+ * data packet counters shall not increase regardless of the number of BA received by device for this a-mpdu
+ *
+ * For each subsequent retransmission of the 11 remaining non ACK'ed mpdus
+ * (regardless of the fact that they are transmitted in a-mpdu or not)
+ *          retries : shall increase by 1
+ *
+ * If no subsequent BA or ACK are received from AP, until packet lifetime expires for those 11 packet that were not ACK'ed
+ *          mpdu_lost : shall increase by 11
+ */
+
+/* per rate statistics */
+typedef struct {
+   wifi_rate rate;     // rate information
+   u32 tx_mpdu;        // number of successfully transmitted data pkts (ACK rcvd)
+   u32 rx_mpdu;        // number of received data pkts
+   u32 mpdu_lost;      // number of data packet losses (no ACK)
+   u32 retries;        // total number of data pkt retries
+   u32 retries_short;  // number of short data pkt retries
+   u32 retries_long;   // number of long data pkt retries
+} wifi_rate_stat;
+
+/* access categories */
+typedef enum {
+   WIFI_AC_VO  = 0,
+   WIFI_AC_VI  = 1,
+   WIFI_AC_BE  = 2,
+   WIFI_AC_BK  = 3,
+   WIFI_AC_MAX = 4,
+} wifi_traffic_ac;
+
+/* wifi peer type */
+typedef enum
+{
+   WIFI_PEER_STA,
+   WIFI_PEER_AP,
+   WIFI_PEER_P2P_GO,
+   WIFI_PEER_P2P_CLIENT,
+   WIFI_PEER_NAN,
+   WIFI_PEER_TDLS,
+   WIFI_PEER_INVALID,
+} wifi_peer_type;
+
+/* per peer statistics */
+typedef struct {
+   wifi_peer_type type;           // peer type (AP, TDLS, GO etc.)
+   u8 peer_mac_address[6];        // mac address
+   u32 capabilities;              // peer WIFI_CAPABILITY_XXX
+   u32 num_rate;                  // number of rates
+   wifi_rate_stat rate_stats[];   // per rate statistics, number of entries  = num_rate
+} wifi_peer_info;
+
+/* Per access category statistics */
+typedef struct {
+   wifi_traffic_ac ac;             // access category (VI, VO, BE, BK)
+   u32 tx_mpdu;                    // number of successfully transmitted unicast data pkts (ACK rcvd)
+   u32 rx_mpdu;                    // number of received unicast data packets
+   u32 tx_mcast;                   // number of succesfully transmitted multicast data packets
+                                   // STA case: implies ACK received from AP for the unicast packet in which mcast pkt was sent
+   u32 rx_mcast;                   // number of received multicast data packets
+   u32 rx_ampdu;                   // number of received unicast a-mpdus; support of this counter is optional
+   u32 tx_ampdu;                   // number of transmitted unicast a-mpdus; support of this counter is optional
+   u32 mpdu_lost;                  // number of data pkt losses (no ACK)
+   u32 retries;                    // total number of data pkt retries
+   u32 retries_short;              // number of short data pkt retries
+   u32 retries_long;               // number of long data pkt retries
+   u32 contention_time_min;        // data pkt min contention time (usecs)
+   u32 contention_time_max;        // data pkt max contention time (usecs)
+   u32 contention_time_avg;        // data pkt avg contention time (usecs)
+   u32 contention_num_samples;     // num of data pkts used for contention statistics
+} wifi_wmm_ac_stat;
+
+/* interface statistics */
+typedef struct {
+   wifi_interface_handle iface;          // wifi interface
+   wifi_interface_link_layer_info info;  // current state of the interface
+   u32 beacon_rx;                        // access point beacon received count from connected AP
+   u64 average_tsf_offset;               // average beacon offset encountered (beacon_TSF - TBTT)
+                                         // The average_tsf_offset field is used so as to calculate the
+                                         // typical beacon contention time on the channel as well may be
+                                         // used to debug beacon synchronization and related power consumption issue
+   u32 leaky_ap_detected;                // indicate that this AP typically leaks packets beyond the driver guard time.
+   u32 leaky_ap_avg_num_frames_leaked;  // average number of frame leaked by AP after frame with PM bit set was ACK'ed by AP
+   u32 leaky_ap_guard_time;              // guard time currently in force (when implementing IEEE power management based on
+                                         // frame control PM bit), How long driver waits before shutting down the radio and
+                                         // after receiving an ACK for a data frame with PM bit set)
+   u32 mgmt_rx;                          // access point mgmt frames received count from connected AP (including Beacon)
+   u32 mgmt_action_rx;                   // action frames received count
+   u32 mgmt_action_tx;                   // action frames transmit count
+   wifi_rssi rssi_mgmt;                  // access Point Beacon and Management frames RSSI (averaged)
+   wifi_rssi rssi_data;                  // access Point Data Frames RSSI (averaged) from connected AP
+   wifi_rssi rssi_ack;                   // access Point ACK RSSI (averaged) from connected AP
+   wifi_wmm_ac_stat ac[WIFI_AC_MAX];     // per ac data packet statistics
+   u32 num_peers;                        // number of peers
+   wifi_peer_info peer_info[];           // per peer statistics
+} wifi_iface_stat;
+
+/* configuration params */
+typedef struct {
+   u32 mpdu_size_threshold;             // threshold to classify the pkts as short or long
+                                        // packet size < mpdu_size_threshold => short
+   u32 aggressive_statistics_gathering; // set for field debug mode. Driver should collect all statistics regardless of performance impact.
+} wifi_link_layer_params;
+
+/* callback for reporting link layer stats */
+typedef struct {
+  void (*on_link_stats_results) (wifi_request_id id, wifi_iface_stat *iface_stat,
+         int num_radios, wifi_radio_stat *radio_stat);
+} wifi_stats_result_handler;
+
+
+/* wifi statistics bitmap  */
+#define WIFI_STATS_RADIO              0x00000001      // all radio statistics
+#define WIFI_STATS_RADIO_CCA          0x00000002      // cca_busy_time (within radio statistics)
+#define WIFI_STATS_RADIO_CHANNELS     0x00000004      // all channel statistics (within radio statistics)
+#define WIFI_STATS_RADIO_SCAN         0x00000008      // all scan statistics (within radio statistics)
+#define WIFI_STATS_IFACE              0x00000010      // all interface statistics
+#define WIFI_STATS_IFACE_TXRATE       0x00000020      // all tx rate statistics (within interface statistics)
+#define WIFI_STATS_IFACE_AC           0x00000040      // all ac statistics (within interface statistics)
+#define WIFI_STATS_IFACE_CONTENTION   0x00000080      // all contention (min, max, avg) statistics (within ac statisctics)
+
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
 
-/* Capture the BRCM_VENDOR_SUBCMD_PRIV_STRINGS* here */
-#define BRCM_VENDOR_SCMD_CAPA	"cap"
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
 extern int rtw_cfgvendor_attach(struct wiphy *wiphy);
 extern int rtw_cfgvendor_detach(struct wiphy *wiphy);
 extern int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,
-                  struct net_device *dev, int event_id, const void  *data, int len);
+	struct net_device *dev, int event_id, const void  *data, int len);
 #if defined(GSCAN_SUPPORT) && 0
-extern int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
-                struct net_device *dev, void  *data, int len, wl_vendor_event_t event);
+extern int rtw_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
+	struct net_device *dev, void  *data, int len, rtw_vendor_event_t event);
 #endif
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT) */
 
 #endif /* _RTW_CFGVENDOR_H_ */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.c
index 552632e6af08..9922ed35439d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,20 +12,13 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 #include <linux/ctype.h>	/* tolower() */
 #include <drv_types.h>
 #include <hal_data.h>
 #include "rtw_proc.h"
-#ifdef CONFIG_BT_COEXIST
 #include <rtw_btcoex.h>
-#endif
 
 #ifdef CONFIG_PROC_DEBUG
 
@@ -37,16 +31,16 @@ inline struct proc_dir_entry *get_rtw_drv_proc(void)
 
 #define RTW_PROC_NAME DRV_NAME
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,9,0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
 #define file_inode(file) ((file)->f_dentry->d_inode)
 #endif
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,10,0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
 #define PDE_DATA(inode) PDE((inode))->data
 #define proc_get_parent_data(inode) PDE((inode))->parent->data
 #endif
 
-#if(LINUX_VERSION_CODE < KERNEL_VERSION(2,6,24))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24))
 #define get_proc_net proc_net
 #else
 #define get_proc_net init_net.proc_net
@@ -56,10 +50,10 @@ inline struct proc_dir_entry *rtw_proc_create_dir(const char *name, struct proc_
 {
 	struct proc_dir_entry *entry;
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,10,0))
-	entry = proc_mkdir_data(name, S_IRUGO|S_IXUGO, parent, data);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	entry = proc_mkdir_data(name, S_IRUGO | S_IXUGO, parent, data);
 #else
-	//entry = proc_mkdir_mode(name, S_IRUGO|S_IXUGO, parent);
+	/* entry = proc_mkdir_mode(name, S_IRUGO|S_IXUGO, parent); */
 	entry = proc_mkdir(name, parent);
 	if (entry)
 		entry->data = data;
@@ -68,15 +62,15 @@ inline struct proc_dir_entry *rtw_proc_create_dir(const char *name, struct proc_
 	return entry;
 }
 
-inline struct proc_dir_entry *rtw_proc_create_entry(const char *name, struct proc_dir_entry *parent, 
+inline struct proc_dir_entry *rtw_proc_create_entry(const char *name, struct proc_dir_entry *parent,
 	const struct file_operations *fops, void * data)
 {
 	struct proc_dir_entry *entry;
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,26))
-	entry = proc_create_data(name,  S_IFREG|S_IRUGO|S_IWUGO, parent, fops, data);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26))
+	entry = proc_create_data(name,  S_IFREG | S_IRUGO | S_IWUGO, parent, fops, data);
 #else
-	entry = create_proc_entry(name, S_IFREG|S_IRUGO|S_IWUGO, parent);
+	entry = create_proc_entry(name, S_IFREG | S_IRUGO | S_IWUGO, parent);
 	if (entry) {
 		entry->data = data;
 		entry->proc_fops = fops;
@@ -122,25 +116,27 @@ static ssize_t proc_set_log_level(struct file *file, const char __user *buffer,
 		return -EFAULT;
 	}
 
+#ifdef CONFIG_RTW_DEBUG
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
 		int num = sscanf(tmp, "%d ", &log_level);
 
-		if( log_level >= _drv_always_ && log_level <= _drv_debug_ )
-		{
-			GlobalDebugLevel= log_level;
-			printk("%d\n", GlobalDebugLevel);
+		if (log_level >= _DRV_NONE_ && log_level <= _DRV_MAX_) {
+			rtw_drv_log_level = log_level;
+			printk("rtw_drv_log_level:%d\n", rtw_drv_log_level);
 		}
-	} else {
+	} else
 		return -EFAULT;
-	}
-	
+#else
+	printk("CONFIG_RTW_DEBUG is disabled\n");
+#endif
+
 	return count;
 }
 
 #ifdef DBG_MEM_ALLOC
 static int proc_get_mstat(struct seq_file *m, void *v)
-{	
+{
 	rtw_mstat_dump(m);
 	return 0;
 }
@@ -164,6 +160,21 @@ static int proc_get_chplan_test(struct seq_file *m, void *v)
 	return 0;
 }
 
+#ifdef RTW_HALMAC
+extern void rtw_halmac_get_version(char *str, u32 len);
+
+static int proc_get_halmac_info(struct seq_file *m, void *v)
+{
+	char ver[30] = {0};
+
+
+	rtw_halmac_get_version(ver, 30);
+	RTW_PRINT_SEL(m, "version: %s\n", ver);
+
+	return 0;
+}
+#endif
+
 /*
 * rtw_drv_proc:
 * init/deinit when register/unregister driver
@@ -178,6 +189,9 @@ const struct rtw_proc_hdl drv_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("country_chplan_map", proc_get_country_chplan_map, NULL),
 	RTW_PROC_HDL_SSEQ("chplan_id_list", proc_get_chplan_id_list, NULL),
 	RTW_PROC_HDL_SSEQ("chplan_test", proc_get_chplan_test, NULL),
+#ifdef RTW_HALMAC
+	RTW_PROC_HDL_SSEQ("halmac_info", proc_get_halmac_info, NULL),
+#endif /* RTW_HALMAC */
 };
 
 const int drv_proc_hdls_num = sizeof(drv_proc_hdls) / sizeof(struct rtw_proc_hdl);
@@ -369,90 +383,86 @@ static int proc_get_sdio_local_reg_dump(struct seq_file *m, void *v)
 
 	return 0;
 }
-#endif /* CONFIG_SDIO_HCI */
-
-static int proc_get_mac_reg_dump(struct seq_file *m, void *v)
+static int proc_get_sdio_card_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	mac_reg_dump(m, adapter);
+	dump_sdio_card_info(m, adapter_to_dvobj(adapter));
 
 	return 0;
 }
+#endif /* CONFIG_SDIO_HCI */
 
-static int proc_get_bb_reg_dump(struct seq_file *m, void *v)
+static int proc_get_fw_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	bb_reg_dump(m, adapter);
-
+	rtw_dump_fw_info(m, adapter);
 	return 0;
 }
-
-static int proc_get_rf_reg_dump(struct seq_file *m, void *v)
+static int proc_get_mac_reg_dump(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	rf_reg_dump(m, adapter);
+	mac_reg_dump(m, adapter);
 
 	return 0;
 }
 
-static int proc_get_dump_tx_rate_bmp(struct seq_file *m, void *v)
+static int proc_get_bb_reg_dump(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	dump_tx_rate_bmp(m, adapter_to_dvobj(adapter));
+	bb_reg_dump(m, adapter);
 
 	return 0;
 }
 
-static int proc_get_dump_adapters_status(struct seq_file *m, void *v)
+static int proc_get_bb_reg_dump_ex(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	dump_adapters_status(m, adapter_to_dvobj(adapter));
+	bb_reg_dump_ex(m, adapter);
 
 	return 0;
 }
 
-#ifdef CONFIG_RTW_CUSTOMER_STR
-static int proc_get_customer_str(struct seq_file *m, void *v)
+static int proc_get_rf_reg_dump(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 cstr[RTW_CUSTOMER_STR_LEN];
 
-	rtw_ps_deny(adapter, PS_DENY_IOCTL);
-	if (rtw_pwr_wakeup(adapter) == _FAIL)
-		goto exit;
+	rf_reg_dump(m, adapter);
 
-	if (rtw_hal_customer_str_read(adapter, cstr) != _SUCCESS)
-		goto exit;
+	return 0;
+}
 
-	RTW_PRINT_SEL(m, RTW_CUSTOMER_STR_FMT"\n", RTW_CUSTOMER_STR_ARG(cstr));
+#ifdef CONFIG_RTW_LED
+int proc_get_led_config(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_led_config(m, adapter);
 
-exit:
-	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
 	return 0;
 }
-#endif /* CONFIG_RTW_CUSTOMER_STR */
 
-//gpio setting
-#ifdef CONFIG_GPIO_API
-static ssize_t proc_set_config_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_led_config(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[32]={0}; 
-	int num=0,gpio_pin=0,gpio_mode=0;//gpio_mode:0 input  1:output;
-	
-	if (count < 2)
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32];
+	u8 strategy;
+	u8 iface_en_mask;
+
+	if (count < 1)
 		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
@@ -461,62 +471,40 @@ static ssize_t proc_set_config_gpio(struct file *file, const char __user *buffer
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		num	=sscanf(tmp, "%d %d",&gpio_pin,&gpio_mode);
-		DBG_871X("num=%d gpio_pin=%d mode=%d\n",num,gpio_pin,gpio_mode);
-      		padapter->pre_gpio_pin=gpio_pin;
-
-		if(gpio_mode==0 || gpio_mode==1  )
-			rtw_hal_config_gpio(padapter, gpio_pin,gpio_mode);	
-	}
-	return count;
 
-}
-static ssize_t proc_set_gpio_output_value(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[32]={0}; 
-	int num=0,gpio_pin=0,pin_mode=0;//pin_mode: 1 high         0:low
-	
-	if (count < 2)
-		return -EFAULT;
+		int num = sscanf(tmp, "%hhu %hhx", &strategy, &iface_en_mask);
 
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
+		if (num >= 1)
+			rtw_led_set_strategy(adapter, strategy);
+		if (num >= 2)
+			rtw_led_set_iface_en_mask(adapter, iface_en_mask);
 	}
 
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		num	=sscanf(tmp, "%d %d",&gpio_pin,&pin_mode);
-		DBG_871X("num=%d gpio_pin=%d pin_high=%d\n",num,gpio_pin,pin_mode);
-		padapter->pre_gpio_pin=gpio_pin;
-		
-		if(pin_mode==0 || pin_mode==1  )
-			rtw_hal_set_gpio_output_value(padapter, gpio_pin,pin_mode);	
-	}
 	return count;
 }
-static int proc_get_gpio(struct seq_file *m, void *v)
+#endif /* CONFIG_RTW_LED */
+
+#ifdef CONFIG_AP_MODE
+int proc_get_aid_status(struct seq_file *m, void *v)
 {
-	u8 gpioreturnvalue=0;
 	struct net_device *dev = m->private;
-	
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	if(!padapter)	
-		return -EFAULT;
-	gpioreturnvalue = rtw_hal_get_gpio(padapter, padapter->pre_gpio_pin);
-	DBG_871X_SEL_NL(m, "get_gpio %d:%d \n",padapter->pre_gpio_pin ,gpioreturnvalue);
-	
-	return 0;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
+	dump_aid_status(m, adapter);
+
+	return 0;
 }
-static ssize_t proc_set_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+
+ssize_t proc_set_aid_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[32]={0}; 
-	int num=0,gpio_pin=0;
-	
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+
+	char tmp[32];
+	u8 rr;
+	u16 started_aid;
+
 	if (count < 1)
 		return -EFAULT;
 
@@ -526,74 +514,83 @@ static ssize_t proc_set_gpio(struct file *file, const char __user *buffer, size_
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		num	=sscanf(tmp, "%d",&gpio_pin);
-		DBG_871X("num=%d gpio_pin=%d\n",num,gpio_pin);
-		padapter->pre_gpio_pin=gpio_pin;
-		
+
+		int num = sscanf(tmp, "%hhu %hu", &rr, &started_aid);
+
+		if (num >= 1)
+			stapriv->rr_aid = rr ? 1 : 0;
+		if (num >= 2) {
+			started_aid = started_aid % (stapriv->max_aid + 1);
+			stapriv->started_aid = started_aid ? started_aid : 1;
+		}
 	}
-		return count;
+
+	return count;
 }
-#endif
-static int proc_get_current_tx_rate(struct seq_file *m, void *v)
+#endif /* CONFIG_AP_MODE */
+
+static int proc_get_dump_tx_rate_bmp(struct seq_file *m, void *v)
 {
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_tx_rate_bmp(m, adapter_to_dvobj(adapter));
+
+	return 0;
+}
 
+static int proc_get_dump_adapters_status(struct seq_file *m, void *v)
+{
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	u8 i;
-	u8 null_addr[ETH_ALEN] = {0};
-	u8 *macaddr;
-	u8 current_rate_id = 0;
 
-	DBG_871X_SEL_NL(m, "%-5s %-4s %-17s %-7s\n"
-		, "macid", "if_g", "macaddr", "tx_rate");
+	dump_adapters_status(m, adapter_to_dvobj(adapter));
 
-	for (i = 0; i < macid_ctl->num; i++) {
-		if (rtw_macid_is_used(macid_ctl, i) || macid_ctl->h2c_msr[i]) {
-			if (macid_ctl->sta[i])
-				macaddr = macid_ctl->sta[i]->hwaddr;
-			else
-				macaddr = null_addr;
-			current_rate_id = rtw_get_current_tx_rate(adapter, i);
-			if (!rtw_macid_is_bmc(macid_ctl, i)) {
-				DBG_871X_SEL_NL(m, "%5u %4u "MAC_FMT" %s\n"
-				, i
-				, rtw_macid_get_if_g(macid_ctl, i)
-				, MAC_ARG(macaddr)
-				, HDATA_RATE(current_rate_id)
-				);
-			}
+	return 0;
+}
 
+#ifdef CONFIG_RTW_CUSTOMER_STR
+static int proc_get_customer_str(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 cstr[RTW_CUSTOMER_STR_LEN];
 
-		}
-	}
+	rtw_ps_deny(adapter, PS_DENY_IOCTL);
+	if (rtw_pwr_wakeup(adapter) == _FAIL)
+		goto exit;
 
+	if (rtw_hal_customer_str_read(adapter, cstr) != _SUCCESS)
+		goto exit;
 
-return 0;
+	RTW_PRINT_SEL(m, RTW_CUSTOMER_STR_FMT"\n", RTW_CUSTOMER_STR_ARG(cstr));
 
+exit:
+	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+	return 0;
 }
+#endif /* CONFIG_RTW_CUSTOMER_STR */
 
-
-static int proc_get_linked_info_dump(struct seq_file *m, void *v)
+#ifdef CONFIG_SCAN_BACKOP
+static int proc_get_backop_flags_sta(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	if(padapter)	
-		DBG_871X_SEL_NL(m, "linked_info_dump :%s \n", (padapter->bLinkInfoDump)?"enable":"disable");
-	
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_sta(mlmeext));
+
 	return 0;
 }
 
-
-static ssize_t proc_set_linked_info_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 
-	char tmp[32]={0}; 
-	int mode=0,pre_mode=0;
-	int num=0;	
+	char tmp[32];
+	u8 flags;
 
 	if (count < 1)
 		return -EFAULT;
@@ -603,79 +600,40 @@ static ssize_t proc_set_linked_info_dump(struct file *file, const char __user *b
 		return -EFAULT;
 	}
 
-	pre_mode=padapter->bLinkInfoDump;
-	DBG_871X("pre_mode=%d\n", pre_mode);
-
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		num	=sscanf(tmp, "%d ", &mode);
-		DBG_871X("num=%d mode=%d\n",num,mode);
+		int num = sscanf(tmp, "%hhx", &flags);
 
-		if(num!=1)
-		{
-			DBG_871X("argument number is wrong\n");
-				return -EFAULT;
-		}
-	
-		if(mode==1 || (mode==0 && pre_mode==1) ) //not consider pwr_saving 0:
-		{
-			padapter->bLinkInfoDump = mode;	
-		
-		}
-		else if( (mode==2 ) || (mode==0 && pre_mode==2))//consider power_saving
-		{		
-			//DBG_871X("linked_info_dump =%s \n", (padapter->bLinkInfoDump)?"enable":"disable")
-			linked_info_dump(padapter,mode);	
-		}
+		if (num == 1)
+			mlmeext_assign_scan_backop_flags_sta(mlmeext, flags);
 	}
+
 	return count;
 }
 
-static int proc_get_mac_qinfo(struct seq_file *m, void *v)
+#ifdef CONFIG_AP_MODE
+static int proc_get_backop_flags_ap(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 
-	rtw_hal_get_hwreg(adapter, HW_VAR_DUMP_MAC_QUEUE_INFO, (u8 *)m);
-
-	return 0;
-}
+	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_ap(mlmeext));
 
-int proc_get_wifi_spec(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct registry_priv	*pregpriv = &padapter->registrypriv;
-	
-	DBG_871X_SEL_NL(m,"wifi_spec=%d\n",pregpriv->wifi_spec);
 	return 0;
 }
 
-static int proc_get_chan_plan(struct seq_file *m, void *v)
+static ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
+	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 
-	dump_cur_chset(m, adapter);
-
-	return 0;
-}
-
-static ssize_t proc_set_chan_plan(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	u8 chan_plan = RTW_CHPLAN_MAX;
-
-	if (!padapter)
-		return -EFAULT;
+	u8 flags;
 
 	if (count < 1)
-	{
-		DBG_871X("argument size is less than 1\n");
 		return -EFAULT;
-	}	
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
@@ -683,36 +641,37 @@ static ssize_t proc_set_chan_plan(struct file *file, const char __user *buffer,
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		int num = sscanf(tmp, "%hhx", &chan_plan);
-		if (num !=  1)
-			return count;
-	}
 
-	rtw_set_channel_plan(padapter, chan_plan);
+		int num = sscanf(tmp, "%hhx", &flags);
+
+		if (num == 1)
+			mlmeext_assign_scan_backop_flags_ap(mlmeext, flags);
+	}
 
 	return count;
 }
+#endif /* CONFIG_AP_MODE */
 
-static int proc_get_country_code(struct seq_file *m, void *v)
+#ifdef CONFIG_RTW_MESH
+static int proc_get_backop_flags_mesh(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 
-	if (adapter->mlmepriv.country_ent)
-		dump_country_chplan(m, adapter->mlmepriv.country_ent);
-	else
-		DBG_871X_SEL_NL(m, "unspecified\n");
+	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_mesh(mlmeext));
 
 	return 0;
 }
 
-static ssize_t proc_set_country_code(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_backop_flags_mesh(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
 	char tmp[32];
-	char alpha2[2];
-	int num;
+	u8 flags;
 
 	if (count < 1)
 		return -EFAULT;
@@ -722,31 +681,30 @@ static ssize_t proc_set_country_code(struct file *file, const char __user *buffe
 		return -EFAULT;
 	}
 
-	if (!buffer || copy_from_user(tmp, buffer, count))
-		goto exit;
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-	num = sscanf(tmp, "%c%c", &alpha2[0], &alpha2[1]);
-	if (num !=	2)
-		return count;
+		int num = sscanf(tmp, "%hhx", &flags);
 
-	rtw_set_country(padapter, alpha2);
+		if (num == 1)
+			mlmeext_assign_scan_backop_flags_mesh(mlmeext, flags);
+	}
 
-exit:
 	return count;
 }
+#endif /* CONFIG_RTW_MESH */
 
-#ifdef CONFIG_DFS_MASTER
-ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+#endif /* CONFIG_SCAN_BACKOP */
+
+/* gpio setting */
+#ifdef CONFIG_GPIO_API
+static ssize_t proc_set_config_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *mlme = &adapter->mlmepriv;
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-	char tmp[32];
-	u8 ch, bw = CHANNEL_WIDTH_20, offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	int ms = -1;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32] = {0};
+	int num = 0, gpio_pin = 0, gpio_mode = 0; /* gpio_mode:0 input  1:output; */
 
-	if (count < 1)
+	if (count < 2)
 		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
@@ -755,33 +713,24 @@ ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, si
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		num	= sscanf(tmp, "%d %d", &gpio_pin, &gpio_mode);
+		RTW_INFO("num=%d gpio_pin=%d mode=%d\n", num, gpio_pin, gpio_mode);
+		padapter->pre_gpio_pin = gpio_pin;
 
-		int num = sscanf(tmp, "%hhu %hhu %hhu %d", &ch, &bw, &offset, &ms);
+		if (gpio_mode == 0 || gpio_mode == 1)
+			rtw_hal_config_gpio(padapter, gpio_pin, gpio_mode);
+	}
+	return count;
 
-		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
-			goto exit;
-
-		if (bw == CHANNEL_WIDTH_20)
-			rtw_chset_update_non_ocp_ms(mlmeext->channel_set
-				, ch, bw, HAL_PRIME_CHNL_OFFSET_DONT_CARE, ms);
-		else
-			rtw_chset_update_non_ocp_ms(mlmeext->channel_set
-				, ch, bw, offset, ms);
-	}
-
-exit:
-	return count;
 }
-
-ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_gpio_output_value(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-	char tmp[32];
-	u8 fake_radar_detect_cnt = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32] = {0};
+	int num = 0, gpio_pin = 0, pin_mode = 0; /* pin_mode: 1 high         0:low */
 
-	if (count < 1)
+	if (count < 2)
 		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
@@ -790,46 +739,38 @@ ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		num	= sscanf(tmp, "%d %d", &gpio_pin, &pin_mode);
+		RTW_INFO("num=%d gpio_pin=%d pin_high=%d\n", num, gpio_pin, pin_mode);
+		padapter->pre_gpio_pin = gpio_pin;
 
-		int num = sscanf(tmp, "%hhu", &fake_radar_detect_cnt);
-
-		if (num < 1)
-			goto exit;
-
-		rfctl->dbg_dfs_master_fake_radar_detect_cnt = fake_radar_detect_cnt;
+		if (pin_mode == 0 || pin_mode == 1)
+			rtw_hal_set_gpio_output_value(padapter, gpio_pin, pin_mode);
 	}
-
-exit:
 	return count;
 }
-#endif /* CONFIG_DFS_MASTER */
-
-static int proc_get_udpport(struct seq_file *m, void *v)
+static int proc_get_gpio(struct seq_file *m, void *v)
 {
+	u8 gpioreturnvalue = 0;
 	struct net_device *dev = m->private;
+
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	if (!padapter)
+		return -EFAULT;
+	gpioreturnvalue = rtw_hal_get_gpio(padapter, padapter->pre_gpio_pin);
+	RTW_PRINT_SEL(m, "get_gpio %d:%d\n", padapter->pre_gpio_pin, gpioreturnvalue);
 
-	DBG_871X_SEL_NL(m,"%d\n",precvpriv->sink_udpport);	
 	return 0;
+
 }
-static ssize_t proc_set_udpport(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct recv_priv *precvpriv = &(padapter->recvpriv);
-	int sink_udpport = 0;	
-	char tmp[32];
-	
-	
-	if (!padapter)
-		return -EFAULT;
+	char tmp[32] = {0};
+	int num = 0, gpio_pin = 0;
 
 	if (count < 1)
-	{
-		DBG_871X("argument size is less than 1\n");
 		return -EFAULT;
-	}	
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
@@ -837,171 +778,157 @@ static ssize_t proc_set_udpport(struct file *file, const char __user *buffer, si
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%d", &sink_udpport);
-
-		if (num !=  1) {
-			DBG_871X("invalid input parameter number!\n");
-			return count;
-		}
+		num	= sscanf(tmp, "%d", &gpio_pin);
+		RTW_INFO("num=%d gpio_pin=%d\n", num, gpio_pin);
+		padapter->pre_gpio_pin = gpio_pin;
 
 	}
-	precvpriv->sink_udpport = sink_udpport;
-	
 	return count;
-
 }
+#endif
 
-static int proc_get_macid_info(struct seq_file *m, void *v)
+static ssize_t proc_set_rx_info_msg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	u8 chip_type = rtw_get_chip_type(adapter);
-	u8 i;
-	u8 null_addr[ETH_ALEN] = {0};
-	u8 *macaddr;
-
-	DBG_871X_SEL_NL(m, "max_num:%u\n", macid_ctl->num);
-	DBG_871X_SEL_NL(m, "\n");
-
-	DBG_871X_SEL_NL(m, "used:\n");
-	dump_macid_map(m, &macid_ctl->used, macid_ctl->num);
-	DBG_871X_SEL_NL(m, "\n");
 
-	RTW_PRINT_SEL(m, "%-3s %-3s %-4s %-4s %-17s %-6s %-3s"
-		, "id", "bmc", "if_g", "ch_g", "macaddr", "bw", "vht");
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	char tmp[32] = {0};
+	int phy_info_flag = 0;
 
-	if (chip_type == RTL8814A)
-		_RTW_PRINT_SEL(m, " %-10s", "rate_bmp1");
+	if (!padapter)
+		return -EFAULT;
 
-	_RTW_PRINT_SEL(m, " %-10s %s\n", "rate_bmp0", "status");
+	if (count < 1) {
+		RTW_INFO("argument size is less than 1\n");
+		return -EFAULT;
+	}
 
-	for (i = 0; i < macid_ctl->num; i++) {
-		if (rtw_macid_is_used(macid_ctl, i)
-			|| macid_ctl->h2c_msr[i]
-		) {
-			if (macid_ctl->sta[i])
-				macaddr = macid_ctl->sta[i]->hwaddr;
-			else
-				macaddr = null_addr;
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
 
-			RTW_PRINT_SEL(m, "%3u %3u %4d %4d "MAC_FMT" %6s %3u"
-				, i
-				, rtw_macid_is_bmc(macid_ctl, i)
-				, rtw_macid_get_if_g(macid_ctl, i)
-				, rtw_macid_get_ch_g(macid_ctl, i)
-				, MAC_ARG(macaddr)
-				, ch_width_str(macid_ctl->bw[i])
-				, macid_ctl->vht_en[i]
-			);
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%d", &phy_info_flag);
 
-			if (chip_type == RTL8814A)
-				_RTW_PRINT_SEL(m, " 0x%08X", macid_ctl->rate_bmp1[i]);
+		precvpriv->store_law_data_flag = (BOOLEAN) phy_info_flag;
 
-			_RTW_PRINT_SEL(m, " 0x%08X "H2C_MSR_FMT" %s\n"
-				, macid_ctl->rate_bmp0[i]
-				, H2C_MSR_ARG(&macid_ctl->h2c_msr[i])
-				, rtw_macid_is_used(macid_ctl, i) ? "" : "[unused]"
-			);
-		}
+		/*RTW_INFO("precvpriv->store_law_data_flag = %d\n",( BOOLEAN )(precvpriv->store_law_data_flag));*/
 	}
+	return count;
+}
+static int proc_get_rx_info_msg(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
+	rtw_hal_set_odm_var(padapter, HAL_ODM_RX_Dframe_INFO, m, _FALSE);
 	return 0;
 }
-
-static int proc_get_sec_cam(struct seq_file *m, void *v)
+static int proc_get_tx_info_msg(struct seq_file *m, void *v)
 {
+	_irqL irqL;
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *psta;
+	u8 bc_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	int i;
+	_list	*plist, *phead;
+	u8 current_rate_id = 0, current_sgi = 0;
 
-	DBG_871X_SEL_NL(m, "sec_cap:0x%02x\n", cam_ctl->sec_cap);
-	DBG_871X_SEL_NL(m, "flags:0x%08x\n", cam_ctl->flags);
-	DBG_871X_SEL_NL(m, "\n");
+	char *BW, *status;
 
-	DBG_871X_SEL_NL(m, "max_num:%u\n", cam_ctl->num);
-	DBG_871X_SEL_NL(m, "used:\n");
-	dump_sec_cam_map(m, &cam_ctl->used, cam_ctl->num);
-	DBG_871X_SEL_NL(m, "\n");
+	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
-	DBG_871X_SEL_NL(m, "reg_scr:0x%04x\n", rtw_read16(adapter, 0x680));
-	DBG_871X_SEL_NL(m, "\n");
+	if (MLME_IS_STA(padapter))
+		status = "station mode";
+	else if (MLME_IS_AP(padapter))
+		status = "AP mode";
+	else if (MLME_IS_MESH(padapter))
+		status = "mesh mode";
+	else
+		status = " ";
+	_RTW_PRINT_SEL(m, "status=%s\n", status);
+	for (i = 0; i < NUM_STA; i++) {
+		phead = &(pstapriv->sta_hash[i]);
+		plist = get_next(phead);
 
-	dump_sec_cam(m, adapter);
+		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 
-	return 0;
-}
+			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
 
-static ssize_t proc_set_sec_cam(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
-	char tmp[32] = {0};
-	char cmd[4];
-	u8 id;
+			plist = get_next(plist);
 
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
+			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6)  !=  _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) != _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), 6) != _TRUE)) {
 
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
+				switch (psta->cmn.bw_mode) {
 
-		/* c <id>: clear specific cam entry */
-		/* wfc <id>: write specific cam entry from cam cache */
+				case CHANNEL_WIDTH_20:
+					BW = "20M";
+					break;
 
-		int num = sscanf(tmp, "%s %hhu", cmd, &id);
+				case CHANNEL_WIDTH_40:
+					BW = "40M";
+					break;
 
-		if (num < 2)
-			return count;
+				case CHANNEL_WIDTH_80:
+					BW = "80M";
+					break;
 
-		if (id >= cam_ctl->num) {
-			DBG_871X_LEVEL(_drv_err_, FUNC_ADPT_FMT" invalid id:%u\n", FUNC_ADPT_ARG(adapter), id);
-			return count;
-		}
+				case CHANNEL_WIDTH_160:
+					BW = "160M";
+					break;
 
-		if (strcmp("c", cmd) == 0) {
-			_clear_cam_entry(adapter, id);
-			adapter->securitypriv.hw_decrypted = _FALSE; /* temporarily set this for TX path to use SW enc */
-		} else if (strcmp("wfc", cmd) == 0) {
-			write_cam_from_cache(adapter, id);
+				default:
+					BW = "";
+					break;
+				}
+				current_rate_id = rtw_get_current_tx_rate(adapter, psta);
+				current_sgi = rtw_get_current_tx_sgi(adapter, psta);
+
+				RTW_PRINT_SEL(m, "==============================\n");
+				_RTW_PRINT_SEL(m, "macaddr=" MAC_FMT"\n", MAC_ARG(psta->cmn.mac_addr));
+				_RTW_PRINT_SEL(m, "Tx_Data_Rate=%s\n", HDATA_RATE(current_rate_id));
+				_RTW_PRINT_SEL(m, "BW=%s,sgi=%u\n", BW, current_sgi);
+
+			}
 		}
 	}
 
-	return count;
+	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+
+	return 0;
+
 }
 
-static int proc_get_sec_cam_cache(struct seq_file *m, void *v)
+
+static int proc_get_linked_info_dump(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
-	u8 i;
-
-	DBG_871X_SEL_NL(m, "SW sec cam cache:\n");
-	dump_sec_cam_ent_title(m, 1);
-	for (i = 0; i < cam_ctl->num; i++) {
-		if (dvobj->cam_cache[i].ctrl != 0)
-			dump_sec_cam_ent(m, &dvobj->cam_cache[i], i);
-	}
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	if (padapter)
+		RTW_PRINT_SEL(m, "linked_info_dump :%s\n", (padapter->bLinkInfoDump) ? "enable" : "disable");
 
 	return 0;
 }
 
-static ssize_t proc_set_change_bss_chbw(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+
+static ssize_t proc_set_linked_info_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *mlme = &(adapter->mlmepriv);
-	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
-	char tmp[32];
-	u8 ch, bw = CHANNEL_WIDTH_20, offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32] = {0};
+	int mode = 0, pre_mode = 0;
+	int num = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1011,42 +938,50 @@ static ssize_t proc_set_change_bss_chbw(struct file *file, const char __user *bu
 		return -EFAULT;
 	}
 
+	pre_mode = padapter->bLinkInfoDump;
+	RTW_INFO("pre_mode=%d\n", pre_mode);
+
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%hhu %hhu %hhu", &ch, &bw, &offset);
+		num	= sscanf(tmp, "%d ", &mode);
+		RTW_INFO("num=%d mode=%d\n", num, mode);
 
-		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
-			goto exit;
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
+		}
 
-		if (check_fwstate(mlme, WIFI_AP_STATE) && check_fwstate(mlme, WIFI_ASOC_STATE))
-			rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_WAIT_ACK, ch, bw, offset);
-	}
+		if (mode == 1 || (mode == 0 && pre_mode == 1)) /* not consider pwr_saving 0: */
+			padapter->bLinkInfoDump = mode;
 
-exit:
+		else if ((mode == 2) || (mode == 0 && pre_mode == 2)) { /* consider power_saving */
+			/* RTW_INFO("linked_info_dump =%s\n", (padapter->bLinkInfoDump)?"enable":"disable") */
+			linked_info_dump(padapter, mode);
+		}
+	}
 	return count;
 }
 
-static int proc_get_tx_bw_mode(struct seq_file *m, void *v)
+
+static int proc_get_sta_tp_dump(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-	RTW_PRINT_SEL(m, "0x%02x\n", adapter->driver_tx_bw_mode);
-	RTW_PRINT_SEL(m, "2.4G:%s\n", ch_width_str(ADAPTER_TX_BW_2G(adapter)));
-	RTW_PRINT_SEL(m, "5G:%s\n", ch_width_str(ADAPTER_TX_BW_5G(adapter)));
+	if (padapter)
+		RTW_PRINT_SEL(m, "sta_tp_dump :%s\n", (padapter->bsta_tp_dump) ? "enable" : "disable");
 
 	return 0;
 }
 
-static ssize_t proc_set_tx_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_sta_tp_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
-	struct mlme_priv *mlme = &(adapter->mlmepriv);
-	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
-	char tmp[32];
-	u8 bw_mode;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32] = {0};
+	int mode = 0;
+	int num = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1058,272 +993,253 @@ static ssize_t proc_set_tx_bw_mode(struct file *file, const char __user *buffer,
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		u8 update = _FALSE;
-		int num = sscanf(tmp, "%hhx", &bw_mode);
-
-		if (num < 1 || bw_mode == adapter->driver_tx_bw_mode)
-			goto exit;
-
-		if ((MLME_STATE(adapter) & WIFI_ASOC_STATE)
-			&& ((mlmeext->cur_channel <= 14 && BW_MODE_2G(bw_mode) != ADAPTER_TX_BW_2G(adapter))
-				|| (mlmeext->cur_channel >= 36 && BW_MODE_5G(bw_mode) != ADAPTER_TX_BW_5G(adapter)))
-		) {
-			/* RA mask update needed */
-			update = _TRUE;
-		}
-		adapter->driver_tx_bw_mode = bw_mode;
-
-		if (update == _TRUE) {
-			struct sta_info *sta;
-			int i;
+		num	= sscanf(tmp, "%d ", &mode);
 
-			for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
-				sta = macid_ctl->sta[i];
-				if (sta && !is_broadcast_mac_addr(sta->hwaddr))
-					rtw_dm_ra_mask_wk_cmd(adapter, (u8 *)sta);
-			}
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
 		}
+		if (padapter)
+			padapter->bsta_tp_dump = mode;
 	}
-
-exit:
 	return count;
 }
 
-static int proc_get_hal_txpwr_info(struct seq_file *m, void *v)
+static int proc_get_sta_tp_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
-
-	if (hal_is_band_support(adapter, BAND_ON_2_4G))
-		dump_hal_txpwr_info_2g(m, adapter, hal_spec->rfpath_num, hal_spec->max_tx_cnt);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-	if (hal_is_band_support(adapter, BAND_ON_5G))
-		dump_hal_txpwr_info_5g(m, adapter, hal_spec->rfpath_num, hal_spec->max_tx_cnt);
-#endif
+	if (padapter)
+		rtw_sta_traffic_info(m, padapter);
 
 	return 0;
 }
 
-static int proc_get_target_tx_power(struct seq_file *m, void *v)
+static int proc_get_turboedca_ctrl(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 
-	dump_target_tx_power(m, adapter);
+	if (hal_data)
+		RTW_PRINT_SEL(m, "Turbo-EDCA :%s\n", (hal_data->dis_turboedca) ? "Disable" : "Enable");
 
 	return 0;
 }
 
-static int proc_get_tx_power_by_rate(struct seq_file *m, void *v)
+static ssize_t proc_set_turboedca_ctrl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 
-	dump_tx_power_by_rate(m, adapter);
+	char tmp[32] = {0};
+	int mode = 0, num = 0;
 
-	return 0;
-}
+	if (count < 1)
+		return -EFAULT;
 
-static int proc_get_tx_power_limit(struct seq_file *m, void *v)
+	if (count > sizeof(tmp))
+		return -EFAULT;
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		num	= sscanf(tmp, "%d ", &mode);
+
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
+		}
+		hal_data->dis_turboedca = mode;
+	}
+	return count;
+}
+#ifdef CONFIG_WOWLAN
+static int proc_get_wow_lps_ctrl(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 
-	dump_tx_power_limit(m, adapter);
+	if (pwrctl)
+		RTW_PRINT_SEL(m, "WOW lps :%s\n", (pwrctl->wowlan_dis_lps) ? "Disable" : "Enable");
 
 	return 0;
 }
 
-static int proc_get_tx_power_ext_info(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-
-	dump_tx_power_ext_info(m, adapter);
-
-	return 0;
-}
-
-static ssize_t proc_set_tx_power_ext_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_wow_lps_ctrl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 
 	char tmp[32] = {0};
-	char cmd[16] = {0};
+	int mode = 0, num = 0;
 
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
+	if (count < 1)
 		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%s", cmd);
-
-		if (num < 1)
-			return count;
 
-		phy_free_filebuf_mask(adapter, LOAD_BB_PG_PARA_FILE | LOAD_RF_TXPWR_LMT_PARA_FILE);
+	if (count > sizeof(tmp))
+		return -EFAULT;
 
-		rtw_ps_deny(adapter, PS_DENY_IOCTL);
-		LeaveAllPowerSaveModeDirect(adapter);
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		if (strcmp("default", cmd) == 0)
-			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_default_tx_power_ext_info)), adapter);
-		else
-			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_tx_power_ext_info)), adapter);
+		num	= sscanf(tmp, "%d ", &mode);
 
-		rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+		if (num != 1) {
+			RTW_INFO("argument number is wrong\n");
+			return -EFAULT;
+		}
+		pwrctl->wowlan_dis_lps = mode;
+		RTW_INFO("WOW lps :%s\n", (pwrctl->wowlan_dis_lps) ? "Disable" : "Enable");
 	}
-
 	return count;
 }
+#endif
 
-static void *proc_start_tx_power_idx(struct seq_file *m, loff_t *pos)
+static int proc_get_mac_qinfo(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 path = ((*pos) & 0xFF00) >> 8;
-	u8 rs = *pos & 0xFF;
 
-	if (path >= RF_PATH_MAX)
-		return NULL;
+	rtw_hal_get_hwreg(adapter, HW_VAR_DUMP_MAC_QUEUE_INFO, (u8 *)m);
 
-	return pos;
+	return 0;
 }
-static void proc_stop_tx_power_idx(struct seq_file *m, void *v)
+
+int proc_get_wifi_spec(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv	*pregpriv = &padapter->registrypriv;
+
+	RTW_PRINT_SEL(m, "wifi_spec=%d\n", pregpriv->wifi_spec);
+	return 0;
 }
 
-static void *proc_next_tx_power_idx(struct seq_file *m, void *v, loff_t *pos)
+static int proc_get_chan_plan(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 path = ((*pos) & 0xFF00) >> 8;
-	u8 rs = *pos & 0xFF;
-
-	rs++;
-	if (rs >= RATE_SECTION_NUM) {
-		rs = 0;
-		path++;
-	}
-
-	if (path >= RF_PATH_MAX)
-		return NULL;
 
-	*pos = (path << 8) | rs;
+	dump_cur_chset(m, adapter);
 
-	return pos;
+	return 0;
 }
 
-static int proc_get_tx_power_idx(struct seq_file *m, void *v)
+static ssize_t proc_set_chan_plan(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	u32 pos = *((loff_t *)(v));
-	u8 path = (pos & 0xFF00) >> 8;
-	u8 rs = pos & 0xFF;
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 chan_plan = RTW_CHPLAN_UNSPECIFIED;
 
-	if (0)
-		RTW_INFO("%s path=%u, rs=%u\n", __func__, path, rs);
+	if (!padapter)
+		return -EFAULT;
 
-	if (path == RF_PATH_A && rs == CCK)
-		dump_tx_power_idx_title(m, adapter);
-	dump_tx_power_idx_by_path_rs(m, adapter, path, rs);
+	if (count < 1) {
+		RTW_INFO("argument size is less than 1\n");
+		return -EFAULT;
+	}
 
-	return 0;
-}
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
 
-static struct seq_operations seq_ops_tx_power_idx = {
-	.start = proc_start_tx_power_idx,
-	.stop  = proc_stop_tx_power_idx,
-	.next  = proc_next_tx_power_idx,
-	.show  = proc_get_tx_power_idx,
-};
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%hhx", &chan_plan);
+		if (num !=  1)
+			return count;
+	}
 
-#ifdef CONFIG_RF_GAIN_OFFSET
-static int proc_get_kfree_flag(struct seq_file *m, void *v)
+	rtw_set_channel_plan(padapter, chan_plan);
+
+	return count;
+}
+
+static int proc_get_country_code(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 
-	DBG_871X_SEL_NL(m, "0x%02x\n", kfree_data->flag);
+	if (rfctl->country_ent)
+		dump_country_chplan(m, rfctl->country_ent);
+	else
+		RTW_PRINT_SEL(m, "unspecified\n");
 
 	return 0;
 }
 
-static ssize_t proc_set_kfree_flag(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_country_code(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
-	char tmp[32] = {0};
-	u8 flag;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	char alpha2[2];
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
 		return -EFAULT;
 	}
 
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhx", &flag);
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
 
-		if (num < 1)
-			return count;
+	num = sscanf(tmp, "%c%c", &alpha2[0], &alpha2[1]);
+	if (num !=	2)
+		return count;
 
-		kfree_data->flag = flag;
-	}
+	rtw_set_country(padapter, alpha2);
 
+exit:
 	return count;
 }
 
-static int proc_get_kfree_bb_gain(struct seq_file *m, void *v)
+#if CONFIG_RTW_MACADDR_ACL
+static int proc_get_macaddr_acl(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
-	u8 i, j;
-
-	 for (i = 0; i < BB_GAIN_NUM; i++) {
-		if (i == 0)
-			DBG_871X_SEL(m, "2G: ");
-		else if (i == 1)
-			DBG_871X_SEL(m, "5GLB1: ");
-		else if (i == 2)
-			DBG_871X_SEL(m, "5GLB2: ");
-		else if (i == 3)
-			DBG_871X_SEL(m, "5GMB1: ");
-		else if (i == 4)
-			DBG_871X_SEL(m, "5GMB2: ");
-		else if (i == 5)
-			DBG_871X_SEL(m, "5GHB: ");
-
-		for (j = 0; j < hal_data->NumTotalRFPath; j++)
-			DBG_871X_SEL(m, "%d ", kfree_data->bb_gain[i][j]);
-		DBG_871X_SEL(m, "\n");
-	}
 
+	dump_macaddr_acl(m, adapter);
 	return 0;
 }
 
-static ssize_t proc_set_kfree_bb_gain(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_macaddr_acl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
-	char tmp[BB_GAIN_NUM * RF_PATH_MAX] = {0};
-	u8 path, chidx;
-	s8 bb_gain[BB_GAIN_NUM];
-	char ch_band_Group[6];
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	char tmp[17 * NUM_ACL + 32] = {0};
+	u8 period;
+	char cmd[32];
+	u8 mode;
+	u8 addr[ETH_ALEN];
+
+#define MAC_ACL_CMD_MODE	0
+#define MAC_ACL_CMD_ADD		1
+#define MAC_ACL_CMD_DEL		2
+#define MAC_ACL_CMD_CLR		3
+#define MAC_ACL_CMD_NUM		4
+	
+	static const char * const mac_acl_cmd_str[] = {
+		"mode",
+		"add",
+		"del",
+		"clr",
+	};
+	u8 cmd_id = MAC_ACL_CMD_NUM;
+
+	if (count < 1)
+		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
@@ -1331,71 +1247,134 @@ static ssize_t proc_set_kfree_bb_gain(struct file *file, const char __user *buff
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		/*
+		* <period> mode <mode> <macaddr> [<macaddr>]
+		* <period> mode <mode>
+		* <period> add <macaddr> [<macaddr>]
+		* <period> del <macaddr> [<macaddr>]
+		* <period> clr
+		*/
 		char *c, *next;
-		int i = 0;
+		int i;
+		u8 is_bcast;
 
 		next = tmp;
 		c = strsep(&next, " \t");
+		if (!c || sscanf(c, "%hhu", &period) != 1)
+			goto exit;
 
-		if (sscanf(c, "%s", ch_band_Group) != 1) {
-			DBG_871X("Error Head Format, channel Group select\n,Please input:\t 2G , 5GLB1 , 5GLB2 , 5GMB1 , 5GMB2 , 5GHB\n");
-			return count;
+		if (period >= RTW_ACL_PERIOD_NUM) {
+			RTW_WARN(FUNC_ADPT_FMT" invalid period:%u", FUNC_ADPT_ARG(adapter), period);
+			goto exit;
 		}
-		if (strcmp("2G", ch_band_Group) == 0)
-			chidx = BB_GAIN_2G;
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-		else if (strcmp("5GLB1", ch_band_Group) == 0)
-			chidx = BB_GAIN_5GLB1;
-		else if (strcmp("5GLB2", ch_band_Group) == 0)
-			chidx = BB_GAIN_5GLB2;
-		else if (strcmp("5GMB1", ch_band_Group) == 0)
-			chidx = BB_GAIN_5GMB1;
-		else if (strcmp("5GMB2", ch_band_Group) == 0)
-			chidx = BB_GAIN_5GMB2;
-		else if (strcmp("5GHB", ch_band_Group) == 0)
-			chidx = BB_GAIN_5GHB;
-#endif /*CONFIG_IEEE80211_BAND_5GHZ*/
-		else {
-			DBG_871X("Error Head Format, channel Group select\n,Please input:\t 2G , 5GLB1 , 5GLB2 , 5GMB1 , 5GMB2 , 5GHB\n");
-			return count;
+
+		c = strsep(&next, " \t");
+		if (!c || sscanf(c, "%s", cmd) != 1)
+			goto exit;
+
+		for (i = 0; i < MAC_ACL_CMD_NUM; i++)
+			if (strcmp(mac_acl_cmd_str[i], cmd) == 0)
+				cmd_id = i;
+
+		switch (cmd_id) {
+		case MAC_ACL_CMD_MODE:
+			c = strsep(&next, " \t");
+			if (!c || sscanf(c, "%hhu", &mode) != 1)
+				goto exit;
+
+			if (mode >= RTW_ACL_MODE_MAX) {
+				RTW_WARN(FUNC_ADPT_FMT" invalid mode:%u", FUNC_ADPT_ARG(adapter), mode);
+				goto exit;
+			}
+			break;
+
+		case MAC_ACL_CMD_ADD:
+		case MAC_ACL_CMD_DEL:
+			break;
+
+		case MAC_ACL_CMD_CLR:
+			/* clear settings */
+			rtw_macaddr_acl_clear(adapter, period);
+			goto exit;
+
+		default:
+			RTW_WARN(FUNC_ADPT_FMT" invalid cmd:\"%s\"", FUNC_ADPT_ARG(adapter), cmd);
+			goto exit;
 		}
+
+		/* check for macaddr list */
 		c = strsep(&next, " \t");
+		if (!c && cmd_id == MAC_ACL_CMD_MODE) {
+			/* set mode only  */
+			rtw_set_macaddr_acl(adapter, period, mode);
+			goto exit;
+		}
+
+		if (cmd_id == MAC_ACL_CMD_MODE) {
+			/* set mode and entire macaddr list */
+			rtw_macaddr_acl_clear(adapter, period);
+			rtw_set_macaddr_acl(adapter, period, mode);
+		}
 
 		while (c != NULL) {
-			if (sscanf(c, "%hhx", &bb_gain[i]) != 1)
+			if (sscanf(c, MAC_SFMT, MAC_SARG(addr)) != 6)
 				break;
 
-			kfree_data->bb_gain[chidx][i] = bb_gain[i];
-			DBG_871X("%s,kfree_data->bb_gain[%d][%d]=%x\n", __func__, chidx, i, kfree_data->bb_gain[chidx][i]);
-
+			is_bcast = is_broadcast_mac_addr(addr);
+			if (is_bcast
+				|| rtw_check_invalid_mac_address(addr, 0) == _FALSE
+			) {
+				if (cmd_id == MAC_ACL_CMD_DEL) {
+					rtw_acl_remove_sta(adapter, period, addr);
+					if (is_bcast)
+						break;
+				 } else if (!is_bcast)
+					rtw_acl_add_sta(adapter, period, addr);
+			}
+		
 			c = strsep(&next, " \t");
-			i++;
 		}
-
 	}
 
+exit:
 	return count;
-
 }
+#endif /* CONFIG_RTW_MACADDR_ACL */
 
-static int proc_get_kfree_thermal(struct seq_file *m, void *v)
+#if CONFIG_RTW_PRE_LINK_STA
+static int proc_get_pre_link_sta(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
-
-	DBG_871X_SEL(m, "%d\n", kfree_data->thermal);
 
+	dump_pre_link_sta_ctl(m, &adapter->stapriv);
 	return 0;
 }
 
-static ssize_t proc_set_kfree_thermal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_pre_link_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
-	char tmp[32] = {0};
-	s8 thermal;
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	char tmp[17 * RTW_PRE_LINK_STA_NUM + 32] = {0};
+	char arg0[16] = {0};
+	u8 addr[ETH_ALEN];
+
+#define PRE_LINK_STA_CMD_RESET	0
+#define PRE_LINK_STA_CMD_ADD	1
+#define PRE_LINK_STA_CMD_DEL	2
+#define PRE_LINK_STA_CMD_NUM	3
+
+	static const char * const pre_link_sta_cmd_str[] = {
+		"reset",
+		"add",
+		"del"
+	};
+	u8 cmd_id = PRE_LINK_STA_CMD_NUM;
+
+	if (count < 1)
+		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
 		rtw_warn_on(1);
@@ -1403,59 +1382,1717 @@ static ssize_t proc_set_kfree_thermal(struct file *file, const char __user *buff
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		/* cmd [<macaddr>] */
+		char *c, *next;
+		int i;
 
-		int num = sscanf(tmp, "%hhd", &thermal);
+		next = tmp;
+		c = strsep(&next, " \t");
 
-		if (num < 1)
-			return count;
+		if (sscanf(c, "%s", arg0) != 1)
+			goto exit;
 
-		kfree_data->thermal = thermal;
-	}
+		for (i = 0; i < PRE_LINK_STA_CMD_NUM; i++)
+			if (strcmp(pre_link_sta_cmd_str[i], arg0) == 0)
+				cmd_id = i;
 
-	return count;
-}
+		switch (cmd_id) {
+		case PRE_LINK_STA_CMD_RESET:
+			rtw_pre_link_sta_ctl_reset(&adapter->stapriv);
+			goto exit;
+		case PRE_LINK_STA_CMD_ADD:
+		case PRE_LINK_STA_CMD_DEL:
+			break;
+		default:
+			goto exit;
+		}
 
-static ssize_t proc_set_tx_gain_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter;
-	char tmp[32] = {0};
-	u8 rf_path;
+		/* macaddr list */
+		c = strsep(&next, " \t");
+		while (c != NULL) {
+			if (sscanf(c, MAC_SFMT, MAC_SARG(addr)) != 6)
+				break;
+
+			if (rtw_check_invalid_mac_address(addr, 0) == _FALSE) {
+				if (cmd_id == PRE_LINK_STA_CMD_ADD)
+					rtw_pre_link_sta_add(&adapter->stapriv, addr);
+				else
+					rtw_pre_link_sta_del(&adapter->stapriv, addr);
+			}
+
+			c = strsep(&next, " \t");
+		}
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_PRE_LINK_STA */
+
+static int proc_get_ch_sel_policy(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "%-16s\n", "same_band_prefer");
+
+	RTW_PRINT_SEL(m, "%16u\n", rfctl->ch_sel_same_band_prefer);
+
+	return 0;
+}
+
+static ssize_t proc_set_ch_sel_policy(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 sb_prefer;
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%hhu", &sb_prefer);
+	if (num >=	1)
+		rfctl->ch_sel_same_band_prefer = sb_prefer;
+
+exit:
+	return count;
+}
+
+#ifdef CONFIG_DFS_MASTER
+int proc_get_dfs_master_test_case(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "%-24s %-19s\n", "radar_detect_trigger_non", "choose_dfs_ch_first");
+	RTW_PRINT_SEL(m, "%24hhu %19hhu\n"
+		, rfctl->dbg_dfs_master_radar_detect_trigger_non
+		, rfctl->dbg_dfs_master_choose_dfs_ch_first
+	);
+
+	return 0;
+}
+
+ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 radar_detect_trigger_non;
+	u8 choose_dfs_ch_first;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%hhu %hhu", &radar_detect_trigger_non, &choose_dfs_ch_first);
+
+		if (num >= 1)
+			rfctl->dbg_dfs_master_radar_detect_trigger_non = radar_detect_trigger_non;
+		if (num >= 2)
+			rfctl->dbg_dfs_master_choose_dfs_ch_first = choose_dfs_ch_first;
+	}
+
+	return count;
+}
+
+ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 ch, bw = CHANNEL_WIDTH_20, offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int ms = -1;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhu %hhu %d", &ch, &bw, &offset, &ms);
+
+		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
+			goto exit;
+
+		if (bw == CHANNEL_WIDTH_20)
+			rtw_chset_update_non_ocp_ms(rfctl->channel_set
+				, ch, bw, HAL_PRIME_CHNL_OFFSET_DONT_CARE, ms);
+		else
+			rtw_chset_update_non_ocp_ms(rfctl->channel_set
+				, ch, bw, offset, ms);
+	}
+
+exit:
+	return count;
+}
+
+ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 fake_radar_detect_cnt = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu", &fake_radar_detect_cnt);
+
+		if (num < 1)
+			goto exit;
+
+		rfctl->dbg_dfs_master_fake_radar_detect_cnt = fake_radar_detect_cnt;
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_dfs_ch_sel_d_flags(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "0x%02x\n", rfctl->dfs_ch_sel_d_flags);
+
+	return 0;
+}
+
+static ssize_t proc_set_dfs_ch_sel_d_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 d_flags;
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%hhx", &d_flags);
+	if (num !=	1)
+		goto exit;
+
+	rfctl->dfs_ch_sel_d_flags = d_flags;
+
+exit:
+	return count;
+}
+#endif /* CONFIG_DFS_MASTER */
+
+#ifdef CONFIG_80211N_HT
+int proc_get_rx_ampdu_size_limit(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_regsty_rx_ampdu_size_limit(m, adapter);
+
+	return 0;
+}
+
+ssize_t proc_set_rx_ampdu_size_limit(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv *regsty = adapter_to_regsty(adapter);
+	char tmp[32];
+	u8 nss;
+	u8 limit_by_bw[4] = {0xFF};
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int i;
+		int num = sscanf(tmp, "%hhu %hhu %hhu %hhu %hhu"
+			, &nss, &limit_by_bw[0], &limit_by_bw[1], &limit_by_bw[2], &limit_by_bw[3]);
+
+		if (num < 2)
+			goto exit;
+		if (nss == 0 || nss > 4)
+			goto exit;
+
+		for (i = 0; i < num - 1; i++)
+			regsty->rx_ampdu_sz_limit_by_nss_bw[nss - 1][i] = limit_by_bw[i];
+
+		rtw_rx_ampdu_apply(adapter);
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_80211N_HT */
+
+static int proc_get_udpport(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+
+	RTW_PRINT_SEL(m, "%d\n", precvpriv->sink_udpport);
+	return 0;
+}
+static ssize_t proc_set_udpport(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct recv_priv *precvpriv = &(padapter->recvpriv);
+	int sink_udpport = 0;
+	char tmp[32];
+
+
+	if (!padapter)
+		return -EFAULT;
+
+	if (count < 1) {
+		RTW_INFO("argument size is less than 1\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%d", &sink_udpport);
+
+		if (num !=  1) {
+			RTW_INFO("invalid input parameter number!\n");
+			return count;
+		}
+
+	}
+	precvpriv->sink_udpport = sink_udpport;
+
+	return count;
+
+}
+
+static int proc_get_mi_ap_bc_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	u8 i;
+
+	for (i = 0; i < dvobj->iface_nums; i++)
+		RTW_PRINT_SEL(m, "iface_id:%d, mac_id && sec_cam_id = %d\n", i, macid_ctl->iface_bmc[i]);
+
+	return 0;
+}
+static int proc_get_macid_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	u8 i;
+	u8 null_addr[ETH_ALEN] = {0};
+	u8 *macaddr;
+
+	RTW_PRINT_SEL(m, "max_num:%u\n", macid_ctl->num);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "used:\n");
+	dump_macid_map(m, &macid_ctl->used, macid_ctl->num);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "%-3s %-3s %-5s %-4s %-17s %-6s %-3s"
+		, "id", "bmc", "ifbmp", "ch_g", "macaddr", "bw", "vht");
+
+	if (hal_spec->tx_nss_num > 2)
+		_RTW_PRINT_SEL(m, " %-10s", "rate_bmp1");
+
+	_RTW_PRINT_SEL(m, " %-10s %s\n", "rate_bmp0", "status");
+
+	for (i = 0; i < macid_ctl->num; i++) {
+		if (rtw_macid_is_used(macid_ctl, i)
+			|| macid_ctl->h2c_msr[i]
+		) {
+			if (macid_ctl->sta[i])
+				macaddr = macid_ctl->sta[i]->cmn.mac_addr;
+			else
+				macaddr = null_addr;
+
+			RTW_PRINT_SEL(m, "%3u %3u  0x%02x %4d "MAC_FMT" %6s %3u"
+				, i
+				, rtw_macid_is_bmc(macid_ctl, i)
+				, rtw_macid_get_iface_bmp(macid_ctl, i)
+				, rtw_macid_get_ch_g(macid_ctl, i)
+				, MAC_ARG(macaddr)
+				, ch_width_str(macid_ctl->bw[i])
+				, macid_ctl->vht_en[i]
+			);
+
+			if (hal_spec->tx_nss_num > 2)
+				_RTW_PRINT_SEL(m, " 0x%08X", macid_ctl->rate_bmp1[i]);
+
+			_RTW_PRINT_SEL(m, " 0x%08X "H2C_MSR_FMT" %s\n"
+				, macid_ctl->rate_bmp0[i]
+				, H2C_MSR_ARG(&macid_ctl->h2c_msr[i])
+				, rtw_macid_is_used(macid_ctl, i) ? "" : "[unused]"
+			);
+		}
+	}
+
+	return 0;
+}
+
+static int proc_get_sec_cam(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+
+	RTW_PRINT_SEL(m, "sec_cap:0x%02x\n", cam_ctl->sec_cap);
+	RTW_PRINT_SEL(m, "flags:0x%08x\n", cam_ctl->flags);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "max_num:%u\n", cam_ctl->num);
+	RTW_PRINT_SEL(m, "used:\n");
+	dump_sec_cam_map(m, &cam_ctl->used, cam_ctl->num);
+	RTW_PRINT_SEL(m, "\n");
+
+	RTW_PRINT_SEL(m, "reg_scr:0x%04x\n", rtw_read16(adapter, 0x680));
+	RTW_PRINT_SEL(m, "\n");
+
+	dump_sec_cam(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_sec_cam(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
+	char tmp[32] = {0};
+	char cmd[4];
+	u8 id_1 = 0, id_2 = 0;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		/* c <id_1>: clear specific cam entry */
+		/* wfc <id_1>: write specific cam entry from cam cache */
+		/* sw <id_1> <id_2>: sec_cam 1/2 swap */
+
+		int num = sscanf(tmp, "%s %hhu %hhu", cmd, &id_1, &id_2);
+
+		if (num < 2)
+			return count;
+
+		if ((id_1 >= cam_ctl->num) || (id_2 >= cam_ctl->num)) {
+			RTW_ERR(FUNC_ADPT_FMT" invalid id_1:%u id_2:%u\n", FUNC_ADPT_ARG(adapter), id_1, id_2);
+			return count;
+		}
+
+		if (strcmp("c", cmd) == 0) {
+			_clear_cam_entry(adapter, id_1);
+			adapter->securitypriv.hw_decrypted = _FALSE; /* temporarily set this for TX path to use SW enc */
+		} else if (strcmp("wfc", cmd) == 0)
+			write_cam_from_cache(adapter, id_1);
+		else if (strcmp("sw", cmd) == 0)
+			rtw_sec_cam_swap(adapter, id_1, id_2);
+		else if (strcmp("cdk", cmd) == 0)
+			rtw_clean_dk_section(adapter);
+#ifdef DBG_SEC_CAM_MOVE
+		else if (strcmp("sgd", cmd) == 0)
+			rtw_hal_move_sta_gk_to_dk(adapter);
+		else if (strcmp("rsd", cmd) == 0)
+			rtw_hal_read_sta_dk_key(adapter, id_1);
+#endif
+	}
+
+	return count;
+}
+
+static int proc_get_sec_cam_cache(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_sec_cam_cache(m, adapter);
+	return 0;
+}
+
+static ssize_t proc_set_change_bss_chbw(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
+	char tmp[32];
+	s16 ch;
+	s8 bw = -1, offset = -1;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hd %hhd %hhd", &ch, &bw, &offset);
+
+		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
+			goto exit;
+
+		if ((MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))
+			&& check_fwstate(mlme, WIFI_ASOC_STATE))
+			rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_WAIT_ACK, ch, bw, offset);
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_tx_bw_mode(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "0x%02x\n", adapter->driver_tx_bw_mode);
+	RTW_PRINT_SEL(m, "2.4G:%s\n", ch_width_str(ADAPTER_TX_BW_2G(adapter)));
+	RTW_PRINT_SEL(m, "5G:%s\n", ch_width_str(ADAPTER_TX_BW_5G(adapter)));
+
+	return 0;
+}
+
+static ssize_t proc_set_tx_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
+	char tmp[32];
+	u8 bw_mode;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		u8 update = _FALSE;
+		int num = sscanf(tmp, "%hhx", &bw_mode);
+
+		if (num < 1 || bw_mode == adapter->driver_tx_bw_mode)
+			goto exit;
+
+		if ((MLME_STATE(adapter) & WIFI_ASOC_STATE)
+			&& ((mlmeext->cur_channel <= 14 && BW_MODE_2G(bw_mode) != ADAPTER_TX_BW_2G(adapter))
+				|| (mlmeext->cur_channel >= 36 && BW_MODE_5G(bw_mode) != ADAPTER_TX_BW_5G(adapter)))
+		) {
+			/* RA mask update needed */
+			update = _TRUE;
+		}
+		adapter->driver_tx_bw_mode = bw_mode;
+
+		if (update == _TRUE) {
+			struct sta_info *sta;
+			int i;
+
+			for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
+				sta = macid_ctl->sta[i];
+				if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr))
+					rtw_dm_ra_mask_wk_cmd(adapter, (u8 *)sta);
+			}
+		}
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_hal_txpwr_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+
+	if (hal_is_band_support(adapter, BAND_ON_2_4G))
+		dump_hal_txpwr_info_2g(m, adapter, hal_spec->rfpath_num_2g, hal_spec->max_tx_cnt);
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (hal_is_band_support(adapter, BAND_ON_5G))
+		dump_hal_txpwr_info_5g(m, adapter, hal_spec->rfpath_num_5g, hal_spec->max_tx_cnt);
+#endif
+
+	return 0;
+}
+
+static int proc_get_target_tx_power(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_target_tx_power(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_tx_power_by_rate(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_tx_power_by_rate(m, adapter);
+
+	return 0;
+}
+
+#ifdef CONFIG_TXPWR_LIMIT
+static int proc_get_tx_power_limit(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_txpwr_lmt(m, adapter);
+
+	return 0;
+}
+#endif /* CONFIG_TXPWR_LIMIT */
+
+static int proc_get_tx_power_ext_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_tx_power_ext_info(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_tx_power_ext_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32] = {0};
+	char cmd[16] = {0};
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%s", cmd);
+
+		if (num < 1)
+			return count;
+
+		#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
+		phy_free_filebuf_mask(adapter, LOAD_BB_PG_PARA_FILE | LOAD_RF_TXPWR_LMT_PARA_FILE);
+		#endif
+
+		rtw_ps_deny(adapter, PS_DENY_IOCTL);
+		if (rtw_pwr_wakeup(adapter) == _FALSE)
+			goto clear_ps_deny;
+
+		if (strcmp("default", cmd) == 0)
+			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_default_tx_power_ext_info)), adapter);
+		else
+			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_tx_power_ext_info)), adapter);
+
+clear_ps_deny:
+		rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+	}
+
+	return count;
+}
+
+static void *proc_start_tx_power_idx(struct seq_file *m, loff_t *pos)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 path = ((*pos) & 0xFF00) >> 8;
+	u8 rs = *pos & 0xFF;
+
+	if (path >= RF_PATH_MAX)
+		return NULL;
+
+	return pos;
+}
+static void proc_stop_tx_power_idx(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+}
+
+static void *proc_next_tx_power_idx(struct seq_file *m, void *v, loff_t *pos)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 path = ((*pos) & 0xFF00) >> 8;
+	u8 rs = *pos & 0xFF;
+
+	rs++;
+	if (rs >= RATE_SECTION_NUM) {
+		rs = 0;
+		path++;
+	}
+
+	if (path >= RF_PATH_MAX)
+		return NULL;
+
+	*pos = (path << 8) | rs;
+
+	return pos;
+}
+
+static int proc_get_tx_power_idx(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u32 pos = *((loff_t *)(v));
+	u8 path = (pos & 0xFF00) >> 8;
+	u8 rs = pos & 0xFF;
+
+	if (0)
+		RTW_INFO("%s path=%u, rs=%u\n", __func__, path, rs);
+
+	if (path == RF_PATH_A && rs == CCK)
+		dump_tx_power_idx_title(m, adapter);
+	dump_tx_power_idx_by_path_rs(m, adapter, path, rs);
+
+	return 0;
+}
+
+static struct seq_operations seq_ops_tx_power_idx = {
+	.start = proc_start_tx_power_idx,
+	.stop  = proc_stop_tx_power_idx,
+	.next  = proc_next_tx_power_idx,
+	.show  = proc_get_tx_power_idx,
+};
+
+#ifdef CONFIG_RF_POWER_TRIM
+static int proc_get_kfree_flag(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+
+	RTW_PRINT_SEL(m, "0x%02x\n", kfree_data->flag);
+
+	return 0;
+}
+
+static ssize_t proc_set_kfree_flag(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	char tmp[32] = {0};
+	u8 flag;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &flag);
+
+		if (num < 1)
+			return count;
+
+		kfree_data->flag = flag;
+	}
+
+	return count;
+}
+
+static int proc_get_kfree_bb_gain(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	u8 i, j;
+
+	for (i = 0; i < BB_GAIN_NUM; i++) {
+		if (i == 0)
+			_RTW_PRINT_SEL(m, "2G: ");
+		else if (i == 1)
+			_RTW_PRINT_SEL(m, "5GLB1: ");
+		else if (i == 2)
+			_RTW_PRINT_SEL(m, "5GLB2: ");
+		else if (i == 3)
+			_RTW_PRINT_SEL(m, "5GMB1: ");
+		else if (i == 4)
+			_RTW_PRINT_SEL(m, "5GMB2: ");
+		else if (i == 5)
+			_RTW_PRINT_SEL(m, "5GHB: ");
+
+		for (j = 0; j < hal_data->NumTotalRFPath; j++)
+			_RTW_PRINT_SEL(m, "%d ", kfree_data->bb_gain[i][j]);
+		_RTW_PRINT_SEL(m, "\n");
+	}
+
+	return 0;
+}
+
+static ssize_t proc_set_kfree_bb_gain(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	char tmp[BB_GAIN_NUM * RF_PATH_MAX] = {0};
+	u8 path, chidx;
+	s8 bb_gain[BB_GAIN_NUM];
+	char ch_band_Group[6];
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		char *c, *next;
+		int i = 0;
+
+		next = tmp;
+		c = strsep(&next, " \t");
+
+		if (sscanf(c, "%s", ch_band_Group) != 1) {
+			RTW_INFO("Error Head Format, channel Group select\n,Please input:\t 2G , 5GLB1 , 5GLB2 , 5GMB1 , 5GMB2 , 5GHB\n");
+			return count;
+		}
+		if (strcmp("2G", ch_band_Group) == 0)
+			chidx = BB_GAIN_2G;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		else if (strcmp("5GLB1", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GLB1;
+		else if (strcmp("5GLB2", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GLB2;
+		else if (strcmp("5GMB1", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GMB1;
+		else if (strcmp("5GMB2", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GMB2;
+		else if (strcmp("5GHB", ch_band_Group) == 0)
+			chidx = BB_GAIN_5GHB;
+#endif /*CONFIG_IEEE80211_BAND_5GHZ*/
+		else {
+			RTW_INFO("Error Head Format, channel Group select\n,Please input:\t 2G , 5GLB1 , 5GLB2 , 5GMB1 , 5GMB2 , 5GHB\n");
+			return count;
+		}
+		c = strsep(&next, " \t");
+
+		while (c != NULL) {
+			if (sscanf(c, "%hhx", &bb_gain[i]) != 1)
+				break;
+
+			kfree_data->bb_gain[chidx][i] = bb_gain[i];
+			RTW_INFO("%s,kfree_data->bb_gain[%d][%d]=%x\n", __func__, chidx, i, kfree_data->bb_gain[chidx][i]);
+
+			c = strsep(&next, " \t");
+			i++;
+		}
+
+	}
+
+	return count;
+
+}
+
+static int proc_get_kfree_thermal(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+
+	_RTW_PRINT_SEL(m, "%d\n", kfree_data->thermal);
+
+	return 0;
+}
+
+static ssize_t proc_set_kfree_thermal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
+	char tmp[32] = {0};
+	s8 thermal;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhd", &thermal);
+
+		if (num < 1)
+			return count;
+
+		kfree_data->thermal = thermal;
+	}
+
+	return count;
+}
+
+static ssize_t proc_set_tx_gain_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter;
+	char tmp[32] = {0};
+	u8 rf_path;
 	s8 offset;
 
-	adapter = (_adapter *)rtw_netdev_priv(dev);
-	if (!adapter)
+	adapter = (_adapter *)rtw_netdev_priv(dev);
+	if (!adapter)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		u8 write_value;
+		int num = sscanf(tmp, "%hhu %hhd", &rf_path, &offset);
+
+		if (num < 2)
+			return count;
+
+		RTW_INFO("write rf_path:%u tx gain offset:%d\n", rf_path, offset);
+		rtw_rf_set_tx_gain_offset(adapter, rf_path, offset);
+	}
+
+	return count;
+}
+#endif /* CONFIG_RF_POWER_TRIM */
+
+#ifdef CONFIG_BT_COEXIST
+ssize_t proc_set_btinfo_evt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 btinfo[8];
+
+	if (count < 6)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = 0;
+
+		_rtw_memset(btinfo, 0, 8);
+
+		num = sscanf(tmp, "%hhx %hhx %hhx %hhx %hhx %hhx %hhx %hhx"
+			, &btinfo[0], &btinfo[1], &btinfo[2], &btinfo[3]
+			, &btinfo[4], &btinfo[5], &btinfo[6], &btinfo[7]);
+
+		if (num < 6)
+			return -EINVAL;
+
+		btinfo[1] = num - 2;
+
+		rtw_btinfo_cmd(padapter, btinfo, btinfo[1] + 2);
+	}
+
+	return count;
+}
+
+static u8 btreg_read_type = 0;
+static u16 btreg_read_addr = 0;
+static int btreg_read_error = 0;
+static u8 btreg_write_type = 0;
+static u16 btreg_write_addr = 0;
+static int btreg_write_error = 0;
+
+static u8 *btreg_type[] = {
+	"rf",
+	"modem",
+	"bluewize",
+	"vendor",
+	"le"
+};
+
+static int btreg_parse_str(char const *input, u8 *type, u16 *addr, u16 *val)
+{
+	u32 num;
+	u8 str[80] = {0};
+	u8 t = 0;
+	u32 a, v;
+	u8 i, n;
+	u8 *p;
+
+
+	num = sscanf(input, "%s %x %x", str, &a, &v);
+	if (num < 2) {
+		RTW_INFO("%s: INVALID input!(%s)\n", __FUNCTION__, input);
+		return -EINVAL;
+	}
+	if ((num < 3) && val) {
+		RTW_INFO("%s: INVALID input!(%s)\n", __FUNCTION__, input);
+		return -EINVAL;
+	}
+
+	/* convert to lower case for following type compare */
+	p = str;
+	for (; *p; ++p)
+		*p = tolower(*p);
+	n = sizeof(btreg_type) / sizeof(btreg_type[0]);
+	for (i = 0; i < n; i++) {
+		if (!strcmp(str, btreg_type[i])) {
+			t = i;
+			break;
+		}
+	}
+	if (i == n) {
+		RTW_INFO("%s: unknown type(%s)!\n", __FUNCTION__, str);
+		return -EINVAL;
+	}
+
+	switch (t) {
+	case 0:
+		/* RF */
+		if (a & 0xFFFFFF80) {
+			RTW_INFO("%s: INVALID address(0x%X) for type %s(%d)!\n",
+				 __FUNCTION__, a, btreg_type[t], t);
+			return -EINVAL;
+		}
+		break;
+	case 1:
+		/* Modem */
+		if (a & 0xFFFFFE00) {
+			RTW_INFO("%s: INVALID address(0x%X) for type %s(%d)!\n",
+				 __FUNCTION__, a, btreg_type[t], t);
+			return -EINVAL;
+		}
+		break;
+	default:
+		/* Others(Bluewize, Vendor, LE) */
+		if (a & 0xFFFFF000) {
+			RTW_INFO("%s: INVALID address(0x%X) for type %s(%d)!\n",
+				 __FUNCTION__, a, btreg_type[t], t);
+			return -EINVAL;
+		}
+		break;
+	}
+
+	if (val) {
+		if (v & 0xFFFF0000) {
+			RTW_INFO("%s: INVALID value(0x%x)!\n", __FUNCTION__, v);
+			return -EINVAL;
+		}
+		*val = (u16)v;
+	}
+
+	*type = (u8)t;
+	*addr = (u16)a;
+
+	return 0;
+}
+
+int proc_get_btreg_read(struct seq_file *m, void *v)
+{
+	struct net_device *dev;
+	PADAPTER padapter;
+	u16 ret;
+	u32 data;
+
+
+	if (btreg_read_error)
+		return btreg_read_error;
+
+	dev = m->private;
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	ret = rtw_btcoex_btreg_read(padapter, btreg_read_type, btreg_read_addr, &data);
+	if (CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X = 0x%08x\n", btreg_type[btreg_read_type], btreg_read_addr, data);
+	else
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X read fail. error code = 0x%04x.\n", btreg_type[btreg_read_type], btreg_read_addr, ret);
+
+	return 0;
+}
+
+ssize_t proc_set_btreg_read(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	PADAPTER padapter;
+	u8 tmp[80] = {0};
+	u32 num;
+	int err;
+
+
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	num = count;
+	if (num > (sizeof(tmp) - 1))
+		num = (sizeof(tmp) - 1);
+
+	if (copy_from_user(tmp, buffer, num)) {
+		RTW_INFO(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+	/* [Coverity] sure tmp end with '\0'(string terminal) */
+	tmp[sizeof(tmp) - 1] = 0;
+
+	err = btreg_parse_str(tmp, &btreg_read_type, &btreg_read_addr, NULL);
+	if (err)
+		goto exit;
+
+	RTW_INFO(FUNC_ADPT_FMT ": addr=(%s)0x%X\n",
+		FUNC_ADPT_ARG(padapter), btreg_type[btreg_read_type], btreg_read_addr);
+
+exit:
+	btreg_read_error = err;
+
+	return count;
+}
+
+int proc_get_btreg_write(struct seq_file *m, void *v)
+{
+	struct net_device *dev;
+	PADAPTER padapter;
+	u16 ret;
+	u32 data;
+
+
+	if (btreg_write_error < 0)
+		return btreg_write_error;
+	else if (btreg_write_error > 0) {
+		RTW_PRINT_SEL(m, "BTREG write: (%s)0x%04X write fail. error code = 0x%04x.\n", btreg_type[btreg_write_type], btreg_write_addr, btreg_write_error);
+		return 0;
+	}
+
+	dev = m->private;
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	ret = rtw_btcoex_btreg_read(padapter, btreg_write_type, btreg_write_addr, &data);
+	if (CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X = 0x%08x\n", btreg_type[btreg_write_type], btreg_write_addr, data);
+	else
+		RTW_PRINT_SEL(m, "BTREG read: (%s)0x%04X read fail. error code = 0x%04x.\n", btreg_type[btreg_write_type], btreg_write_addr, ret);
+
+	return 0;
+}
+
+ssize_t proc_set_btreg_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	PADAPTER padapter;
+	u8 tmp[80] = {0};
+	u32 num;
+	u16 val;
+	u16 ret;
+	int err;
+
+
+	padapter = (PADAPTER)rtw_netdev_priv(dev);
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	num = count;
+	if (num > (sizeof(tmp) - 1))
+		num = (sizeof(tmp) - 1);
+
+	if (copy_from_user(tmp, buffer, num)) {
+		RTW_INFO(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
+			 FUNC_ADPT_ARG(padapter));
+		err = -EFAULT;
+		goto exit;
+	}
+
+	err = btreg_parse_str(tmp, &btreg_write_type, &btreg_write_addr, &val);
+	if (err)
+		goto exit;
+
+	RTW_INFO(FUNC_ADPT_FMT ": Set (%s)0x%X = 0x%x\n",
+		FUNC_ADPT_ARG(padapter), btreg_type[btreg_write_type], btreg_write_addr, val);
+
+	ret = rtw_btcoex_btreg_write(padapter, btreg_write_type, btreg_write_addr, val);
+	if (!CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
+		err = ret;
+
+exit:
+	btreg_write_error = err;
+
+	return count;
+}
+#endif /* CONFIG_BT_COEXIST */
+
+#ifdef CONFIG_MBSSID_CAM
+int proc_get_mbid_cam_cache(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_mbid_cam_cache_dump(m, __func__, adapter);
+	rtw_mbid_cam_dump(m, __func__, adapter);
+	return 0;
+}
+#endif /* CONFIG_MBSSID_CAM */
+
+int proc_get_mac_addr(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_hal_dump_macaddr(m, adapter);
+	return 0;
+}
+
+static int proc_get_skip_band(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int bandskip;
+
+	bandskip = RTW_GET_SCAN_BAND_SKIP(adapter);
+	RTW_PRINT_SEL(m, "bandskip:0x%02x\n", bandskip);
+	return 0;
+}
+
+static ssize_t proc_set_skip_band(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[6];
+	u8 skip_band;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu", &skip_band);
+
+		if (num < 1)
+			return -EINVAL;
+
+		if (1 == skip_band)
+			RTW_SET_SCAN_BAND_SKIP(padapter, BAND_24G);
+		else if (2 == skip_band)
+			RTW_SET_SCAN_BAND_SKIP(padapter, BAND_5G);
+		else if (3 == skip_band)
+			RTW_CLR_SCAN_BAND_SKIP(padapter, BAND_24G);
+		else if (4 == skip_band)
+			RTW_CLR_SCAN_BAND_SKIP(padapter, BAND_5G);
+	}
+	return count;
+
+}
+
+#ifdef CONFIG_RTW_ACS
+static int proc_get_chan_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_acs_chan_info_dump(m, adapter);
+	return 0;
+}
+
+static int proc_get_best_chan(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (IS_ACS_ENABLE(adapter))
+		rtw_acs_info_dump(m, adapter);
+	else
+		_RTW_PRINT_SEL(m,"ACS disabled\n");
+	return 0;
+}
+
+static ssize_t proc_set_acs(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+#ifdef CONFIG_RTW_ACS_DBG
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 acs_state = 0;
+	u16 scan_ch_ms= 0, acs_scan_ch_ms = 0;
+	u8 scan_type = SCAN_ACTIVE, igi= 0, bw = 0;
+	u8 acs_scan_type = SCAN_ACTIVE, acs_igi= 0, acs_bw = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhu %hu %hhx %hhu",
+			&acs_state, &scan_type, &scan_ch_ms, &igi, &bw);
+
+		if (num < 1)
+			return -EINVAL;
+
+		if (acs_state)
+			rtw_acs_start(padapter);
+		else
+			rtw_acs_stop(padapter);
+		num = num -1;
+
+		if(num) {
+			if (num-- > 0)
+				acs_scan_type = scan_type;
+			if (num-- > 0)
+				acs_scan_ch_ms = scan_ch_ms;
+			if (num-- > 0)
+				acs_igi = igi;
+			if (num-- > 0)
+				acs_bw = bw;
+			rtw_acs_adv_setting(padapter, acs_scan_type, acs_scan_ch_ms, acs_igi, acs_bw);
+		}
+	}
+#endif /*CONFIG_RTW_ACS_DBG*/
+	return count;
+}
+#endif /*CONFIG_RTW_ACS*/
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+static int proc_get_nm(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_noise_info_dump(m, adapter);
+	return 0;
+}
+
+static ssize_t proc_set_nm(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 nm_state = 0;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu", &nm_state);
+
+		if (num < 1)
+			return -EINVAL;
+
+		if (nm_state)
+			rtw_nm_enable(padapter);
+		else
+			rtw_nm_disable(padapter);
+
+	}
+	return count;
+}
+#endif /*CONFIG_RTW_ACS*/
+
+static int proc_get_hal_spec(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_hal_spec(m, adapter);
+	return 0;
+}
+
+static int proc_get_phy_cap(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_dump_phy_cap(m, adapter);
+	rtw_dump_drv_phy_cap(m, adapter);
+	rtw_get_dft_phy_cap(m, adapter);
+	return 0;
+}
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+#include "../../hal/hal_halmac.h"
+static int proc_get_trx_share_mode(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_trx_share_mode(m, adapter);
+	return 0;
+}
+#endif
+
+static int proc_dump_rsvd_page(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_dump_rsvd_page(m, adapter, adapter->rsvd_page_offset, adapter->rsvd_page_num);
+	return 0;
+}
+static ssize_t proc_set_rsvd_page_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 page_offset, page_num;
+
+	if (count < 2)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhu", &page_offset, &page_num);
+
+		if (num < 2)
+			return -EINVAL;
+		padapter->rsvd_page_offset = page_offset;
+		padapter->rsvd_page_num = page_num;
+	}
+	return count;
+}
+
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+static int proc_dump_fifo(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	rtw_dump_fifo(m, adapter, adapter->fifo_sel, adapter->fifo_addr, adapter->fifo_size);
+	return 0;
+}
+static ssize_t proc_set_fifo_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u8 fifo_sel = 0;
+	u32 fifo_addr = 0;
+	u32 fifo_size = 0;
+
+	if (count < 3)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %x %d", &fifo_sel, &fifo_addr, &fifo_size);
+
+		if (num < 3)
+			return -EINVAL;
+
+		padapter->fifo_sel = fifo_sel;
+		padapter->fifo_addr = fifo_addr;
+		padapter->fifo_size = fifo_size;
+	}
+	return count;
+}
+#endif
+
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+int proc_dump_pattern_cam(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	int i;
+	struct  rtl_wow_pattern context;
+
+	for (i = 0 ; i < pwrpriv->wowlan_pattern_idx; i++) {
+		rtw_wow_pattern_read_cam_ent(padapter, i, &context);
+		rtw_dump_wow_pattern(m, &context, i);
+	}
+
+	return 0;
+}
+#endif
+
+static int proc_get_napi_info(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv *pregistrypriv = &adapter->registrypriv;
+	u8 napi = 0, gro = 0;
+	u32 weight = 0;
+	struct dvobj_priv *d;
+	d = adapter_to_dvobj(adapter);
+
+
+#ifdef CONFIG_RTW_NAPI
+	if (pregistrypriv->en_napi) {
+		napi = 1;
+		weight = RTL_NAPI_WEIGHT;
+	}
+
+#ifdef CONFIG_RTW_GRO
+	if (pregistrypriv->en_gro)
+		gro = 1;
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
+	if (napi) {
+		RTW_PRINT_SEL(m, "NAPI enable, weight=%d\n", weight);
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+		RTW_PRINT_SEL(m, "Dynamaic NAPI mechanism is on, current NAPI %s\n",
+			      d->en_napi_dynamic ? "enable" : "disable");
+		RTW_PRINT_SEL(m, "Dynamaic NAPI info:\n"
+				 "\ttcp_rx_threshold = %d Mbps\n"
+				 "\tcur_rx_tp = %d Mbps\n",
+			      pregistrypriv->napi_threshold,
+			      d->traffic_stat.cur_rx_tp);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+	} else {
+		RTW_PRINT_SEL(m, "NAPI disable\n");
+	}
+	RTW_PRINT_SEL(m, "GRO %s\n", gro?"enable":"disable");
+
+	return 0;
+
+}
+
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+static ssize_t proc_set_napi_th(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	struct _ADAPTER *adapter = (struct _ADAPTER *)rtw_netdev_priv(dev);
+	struct registry_priv *registry = &adapter->registrypriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	PADAPTER iface = NULL;
+	char tmp[32] = {0};
+	int thrshld = 0;
+	int num = 0, i = 0;
+
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	RTW_INFO("%s: Last threshold = %d Mbps\n", __FUNCTION__, registry->napi_threshold);
+
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {	
+			if (buffer && !copy_from_user(tmp, buffer, count)) {
+				registry = &iface->registrypriv;
+				num = sscanf(tmp, "%d", &thrshld);
+				if (num > 0) {
+					if (thrshld > 0)
+						registry->napi_threshold = thrshld;
+				}
+			}
+		}
+	}
+	RTW_INFO("%s: New threshold = %d Mbps\n", __FUNCTION__, registry->napi_threshold);
+	RTW_INFO("%s: Current RX throughput = %d Mbps\n",
+		 __FUNCTION__, adapter_to_dvobj(adapter)->traffic_stat.cur_rx_tp);
+
+	return count;
+}
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+
+
+ssize_t proc_set_dynamic_agg_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	int enable = 0, i = 0;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
 		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+		PADAPTER iface = NULL;
+		int num = sscanf(tmp, "%d", &enable);
+
+		if (num !=  1) {
+			RTW_INFO("invalid parameter!\n");
+			return count;
+		}
+
+		RTW_INFO("dynamic_agg_enable:%d\n", enable);
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface)
+				iface->registrypriv.dynamic_agg_enable = enable;
+		}
+
+	}
+
+	return count;
+
+}
+
+static int proc_get_dynamic_agg_enable(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct registry_priv *pregistrypriv = &adapter->registrypriv;
+
+	RTW_PRINT_SEL(m, "dynamic_agg_enable:%d\n", pregistrypriv->dynamic_agg_enable);
+
+	return 0;
+}
+
+#ifdef CONFIG_RTW_MESH
+static int proc_get_mesh_peer_sel_policy(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
+	dump_mesh_peer_sel_policy(m, adapter);
 
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		u8 write_value;
-		int num = sscanf(tmp, "%hhu %hhd", &rf_path, &offset);
+	return 0;
+}
 
-		if (num < 2)
-			return count;
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+static int proc_get_mesh_peer_blacklist(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-		DBG_871X("write rf_path:%u tx gain offset:%d\n", rf_path, offset);
-		rtw_rf_set_tx_gain_offset(adapter, rf_path, offset);
+	if (MLME_IS_MESH(adapter)) {
+		dump_mesh_peer_blacklist_settings(m, adapter);
+		if (MLME_IS_ASOC(adapter))
+			dump_mesh_peer_blacklist(m, adapter);
 	}
 
-	return count;
+	return 0;
 }
-#endif /* CONFIG_RF_GAIN_OFFSET */
 
-#ifdef CONFIG_BT_COEXIST
-ssize_t proc_set_btinfo_evt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_mesh_peer_blacklist(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	u8 btinfo[8];
 
-	if (count < 6)
+	if (count < 1)
 		return -EFAULT;
 
 	if (count > sizeof(tmp)) {
@@ -1464,292 +3101,208 @@ ssize_t proc_set_btinfo_evt(struct file *file, const char __user *buffer, size_t
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		int num = 0;
-
-		_rtw_memset(btinfo, 0, 8);
-		
-		num = sscanf(tmp, "%hhx %hhx %hhx %hhx %hhx %hhx %hhx %hhx"
-			, &btinfo[0], &btinfo[1], &btinfo[2], &btinfo[3]
-			, &btinfo[4], &btinfo[5], &btinfo[6], &btinfo[7]);
-
-		if (num < 6)
-			return -EINVAL;
-
-		btinfo[1] = num-2;
-
-		rtw_btinfo_cmd(padapter, btinfo, btinfo[1]+2);
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u32 conf_timeout_ms;
+		u32 blacklist_timeout_ms;
+		int num = sscanf(tmp, "%u %u", &conf_timeout_ms, &blacklist_timeout_ms);
+
+		if (num >= 1)
+			peer_sel_policy->peer_conf_timeout_ms = conf_timeout_ms;
+		if (num >= 2)
+			peer_sel_policy->peer_blacklist_timeout_ms = blacklist_timeout_ms;
 	}
-	
+
+exit:
 	return count;
 }
+#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
 
-static u8 btreg_read_type = 0;
-static u16 btreg_read_addr = 0;
-static int btreg_read_error = 0;
-static u8 btreg_write_type = 0;
-static u16 btreg_write_addr = 0;
-static int btreg_write_error = 0;
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+static int proc_get_mesh_cto_mgate_require(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-static u8 *btreg_type[] = {
-	"rf",
-	"modem",
-	"bluewize",
-	"vendor",
-	"le"
-};
+	if (MLME_IS_MESH(adapter))
+		RTW_PRINT_SEL(m, "%u\n", adapter->mesh_cfg.peer_sel_policy.cto_mgate_require);
 
-static int btreg_parse_str(char *input, u8 *type, u16 *addr, u16 *val)
-{
-	u32 num;
-	u8 str[80] = {0};
-	u8 t = 0;
-	u32 a, v;
-	u8 i, n;
-	u8 *p;
+	return 0;
+}
 
+static ssize_t proc_set_mesh_cto_mgate_require(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
 
-	num = sscanf(input, "%s %x %x", str, &a, &v);
-	if (num < 2) {
-		DBG_871X("%s: INVALID input!(%s)\n", __FUNCTION__, input);
-		return -EINVAL;
-	}
-	if ((num < 3) && val) {
-		DBG_871X("%s: INVALID input!(%s)\n", __FUNCTION__, input);
-		return -EINVAL;
-	}
+	if (count < 1)
+		return -EFAULT;
 
-	/* convert to lower case for following type compare */
-	p = str;
-	for ( ; *p; ++p)
-		*p = tolower(*p);
-	n = sizeof(btreg_type)/sizeof(btreg_type[0]);
-	for (i = 0; i < n; i++) {
-		if (!strcmp(str, btreg_type[i])) {
-			t = i;
-			break;
-		}
-	}
-	if (i == n) {
-		DBG_871X("%s: unknown type(%s)!\n", __FUNCTION__, str);
-		return -EINVAL;
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
 	}
 
-	switch (t) {
-	case 0:
-		/* RF */
-		if (a & 0xFFFFFF80) {
-			DBG_871X("%s: INVALID address(0x%X) for type %s(%d)!\n",
-				__FUNCTION__, a, btreg_type[t], t);
-			return -EINVAL;
-		}
-		break;
-	case 1:
-		/* Modem */
-		if (a & 0xFFFFFE00) {
-			DBG_871X("%s: INVALID address(0x%X) for type %s(%d)!\n",
-				__FUNCTION__, a, btreg_type[t], t);
-			return -EINVAL;
-		}
-		break;
-	default:
-		/* Others(Bluewize, Vendor, LE) */
-		if (a & 0xFFFFF000) {
-			DBG_871X("%s: INVALID address(0x%X) for type %s(%d)!\n",
-				__FUNCTION__, a, btreg_type[t], t);
-			return -EINVAL;
-		}
-		break;
-	}
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u8 require;
+		int num = sscanf(tmp, "%hhu", &require);
 
-	if (val) {
-		if (v & 0xFFFF0000) {
-			DBG_871X("%s: INVALID value(0x%x)!\n", __FUNCTION__, v);
-			return -EINVAL;
-		}
-		*val = (u16)v;
+		if (num >= 1)
+			peer_sel_policy->cto_mgate_require = require;
 	}
 
-	*type = (u8)t;
-	*addr = (u16)a;
-
-	return 0;
+exit:
+	return count;
 }
 
-int proc_get_btreg_read(struct seq_file *m, void *v)
+static int proc_get_mesh_cto_mgate_blacklist(struct seq_file *m, void *v)
 {
-	struct net_device *dev;
-	PADAPTER padapter;
-	u16 ret;
-	u32 data;
-
-
-	if (btreg_read_error)
-		return btreg_read_error;
-
-	dev = m->private;
-	padapter = (PADAPTER)rtw_netdev_priv(dev);
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	ret = rtw_btcoex_btreg_read(padapter, btreg_read_type, btreg_read_addr, &data);
-	if (CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
-		DBG_871X_SEL_NL(m, "BTREG read: (%s)0x%04X = 0x%08x\n", btreg_type[btreg_read_type], btreg_read_addr, data);
-	else
-		DBG_871X_SEL_NL(m, "BTREG read: (%s)0x%04X read fail. error code = 0x%04x.\n", btreg_type[btreg_read_type], btreg_read_addr, ret);
+	if (MLME_IS_MESH(adapter)) {
+		dump_mesh_cto_mgate_blacklist_settings(m, adapter);
+		if (MLME_IS_ASOC(adapter))
+			dump_mesh_cto_mgate_blacklist(m, adapter);
+	}
 
 	return 0;
 }
 
-ssize_t proc_set_btreg_read(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_mesh_cto_mgate_blacklist(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	PADAPTER padapter;
-	u8 tmp[80] = {0};
-	u32 num;
-	int err;
-
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
 
-	padapter = (PADAPTER)rtw_netdev_priv(dev);
+	if (count < 1)
+		return -EFAULT;
 
-	if (NULL == buffer) {
-		DBG_871X(FUNC_ADPT_FMT ": input buffer is NULL!\n",
-			FUNC_ADPT_ARG(padapter));
-		err = -EFAULT;
-		goto exit;
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
 	}
 
-	if (count < 1) {
-		DBG_871X(FUNC_ADPT_FMT ": input length is 0!\n",
-			FUNC_ADPT_ARG(padapter));
-		err = -EFAULT;
-		goto exit;
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u32 conf_timeout_ms;
+		u32 blacklist_timeout_ms;
+		int num = sscanf(tmp, "%u %u", &conf_timeout_ms, &blacklist_timeout_ms);
+
+		if (num >= 1)
+			peer_sel_policy->cto_mgate_conf_timeout_ms = conf_timeout_ms;
+		if (num >= 2)
+			peer_sel_policy->cto_mgate_blacklist_timeout_ms = blacklist_timeout_ms;
 	}
 
-	num = count;
-	if (num > (sizeof(tmp) - 1))
-		num = (sizeof(tmp) - 1);
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
 
-	if (copy_from_user(tmp, buffer, num)) {
-		DBG_871X(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
-			FUNC_ADPT_ARG(padapter));
-		err = -EFAULT;
-		goto exit;
-	}
+static int proc_get_mesh_networks(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	err = btreg_parse_str(tmp, &btreg_read_type, &btreg_read_addr, NULL);
-	if (err)
-		goto exit;
+	dump_mesh_networks(m, adapter);
 
-	DBG_871X(FUNC_ADPT_FMT ": addr=(%s)0x%X\n",
-		FUNC_ADPT_ARG(padapter), btreg_type[btreg_read_type], btreg_read_addr);
+	return 0;
+}
 
-exit:
-	btreg_read_error = err;
+static int proc_get_mesh_plink_ctl(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	return count;
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_plink_ctl(m, adapter);
+
+	return 0;
 }
 
-int proc_get_btreg_write(struct seq_file *m, void *v)
+static int proc_get_mesh_known_gates(struct seq_file *m, void *v)
 {
-	struct net_device *dev;
-	PADAPTER padapter;
-	u16 ret;
-	u32 data;
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
+	if (MLME_IS_MESH(adapter))
+		dump_known_gates(m, adapter);
 
-	if (btreg_write_error < 0)
-		return btreg_write_error;
-	else if (btreg_write_error > 0) {
-		DBG_871X_SEL_NL(m, "BTREG write: (%s)0x%04X write fail. error code = 0x%04x.\n", btreg_type[btreg_write_type], btreg_write_addr, btreg_write_error);
-		return 0;
-	}
+	return 0;
+}
 
-	dev = m->private;
-	padapter = (PADAPTER)rtw_netdev_priv(dev);
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+static int proc_get_mesh_b2u_flags(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	ret = rtw_btcoex_btreg_read(padapter, btreg_write_type, btreg_write_addr, &data);
-	if (CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
-		DBG_871X_SEL_NL(m, "BTREG read: (%s)0x%04X = 0x%08x\n", btreg_type[btreg_write_type], btreg_write_addr, data);
-	else
-		DBG_871X_SEL_NL(m, "BTREG read: (%s)0x%04X read fail. error code = 0x%04x.\n", btreg_type[btreg_write_type], btreg_write_addr, ret);
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_b2u_flags(m, adapter);
 
 	return 0;
 }
 
-ssize_t proc_set_btreg_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_mesh_b2u_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	PADAPTER padapter;
-	u8 tmp[80] = {0};
-	u32 num;
-	u16 val;
-	u16 ret;
-	int err;
-
-
-	padapter = (PADAPTER)rtw_netdev_priv(dev);
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
 
-	if (NULL == buffer) {
-		DBG_871X(FUNC_ADPT_FMT ": input buffer is NULL!\n",
-			FUNC_ADPT_ARG(padapter));
-		err = -EFAULT;
-		goto exit;
-	}
+	if (count < 1)
+		return -EFAULT;
 
-	if (count < 1) {
-		DBG_871X(FUNC_ADPT_FMT ": input length is 0!\n",
-			FUNC_ADPT_ARG(padapter));
-		err = -EFAULT;
-		goto exit;
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
 	}
 
-	num = count;
-	if (num > (sizeof(tmp) - 1))
-		num = (sizeof(tmp) - 1);
-
-	if (copy_from_user(tmp, buffer, num)) {
-		DBG_871X(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
-			FUNC_ADPT_ARG(padapter));
-		err = -EFAULT;
-		goto exit;
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+		u8 msrc, mfwd;
+		int num = sscanf(tmp, "%hhx %hhx", &msrc, &mfwd);
+
+		if (num >= 1)
+			mcfg->b2u_flags_msrc = msrc;
+		if (num >= 2)
+			mcfg->b2u_flags_mfwd = mfwd;
 	}
 
-	err = btreg_parse_str(tmp, &btreg_write_type, &btreg_write_addr, &val);
-	if (err)
-		goto exit;
-
-	DBG_871X(FUNC_ADPT_FMT ": Set (%s)0x%X = 0x%x\n",
-		FUNC_ADPT_ARG(padapter), btreg_type[btreg_write_type], btreg_write_addr, val);
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
 
-	ret = rtw_btcoex_btreg_write(padapter, btreg_write_type, btreg_write_addr, val);
-	if (!CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET(ret, BT_STATUS_BT_OP_SUCCESS))
-		err = ret;
+static int proc_get_mesh_stats(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-exit:
-	btreg_write_error = err;
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_stats(m, adapter);
 
-	return count;
+	return 0;
 }
-#endif /* CONFIG_BT_COEXIST */
 
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
-static int proc_get_best_chan(struct seq_file *m, void *v)
+static int proc_get_mesh_gate_timeout(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 best_24g_ch = 0, best_5g_ch = 0;
 
-	rtw_hal_get_odm_var(adapter, HAL_ODM_AUTO_CHNL_SEL, &(best_24g_ch), &(best_5g_ch));
+	if (MLME_IS_MESH(adapter))
+		RTW_PRINT_SEL(m, "%u factor\n",
+			       adapter->mesh_cfg.path_gate_timeout_factor);
 
-	DBG_871X_SEL_NL(m, "Best 2.4G CH:%u\n", best_24g_ch);
-	DBG_871X_SEL_NL(m, "Best 5G CH:%u\n", best_5g_ch);
 	return 0;
 }
 
-static ssize_t  proc_set_acs(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static ssize_t proc_set_mesh_gate_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	u8 acs_satae = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1758,32 +3311,45 @@ static ssize_t  proc_set_acs(struct file *file, const char __user *buffer, size_
 		rtw_warn_on(1);
 		return -EFAULT;
 	}
+
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+		u32 timeout;
+		int num = sscanf(tmp, "%u", &timeout);
 
-		int num = sscanf(tmp, "%hhu", &acs_satae);
-		
 		if (num < 1)
-			return -EINVAL;
-
-		if (1 == acs_satae)
-			rtw_acs_start(padapter, _TRUE);
-		else
-			rtw_acs_start(padapter, _FALSE);
+			goto exit;
 
+		mcfg->path_gate_timeout_factor = timeout;
 	}
+
+exit:
 	return count;
 }
-#endif
 
-static int proc_get_hal_spec(struct seq_file *m, void *v)
+static int proc_get_mesh_gate_state(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	u8 cto_mgate = 0;
+
+	if (MLME_IS_MESH(adapter)) {
+		if (rtw_mesh_is_primary_gate(adapter))
+			RTW_PRINT_SEL(m, "PG\n");
+		else if (mcfg->dot11MeshGateAnnouncementProtocol)
+			RTW_PRINT_SEL(m, "G\n");
+		else if (rtw_mesh_gate_num(adapter))
+			RTW_PRINT_SEL(m, "C\n");
+		else
+			RTW_PRINT_SEL(m, "N\n");
+	}
 
-	dump_hal_spec(m, adapter);
 	return 0;
 }
 
+#endif /* CONFIG_RTW_MESH */
+
 /*
 * rtw_adapter_proc:
 * init/deinit when register/unregister net_device
@@ -1809,18 +3375,28 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("scan_abort", proc_get_scan_abort, NULL),
 #ifdef CONFIG_SCAN_BACKOP
 	RTW_PROC_HDL_SSEQ("backop_flags_sta", proc_get_backop_flags_sta, proc_set_backop_flags_sta),
+	#ifdef CONFIG_AP_MODE
 	RTW_PROC_HDL_SSEQ("backop_flags_ap", proc_get_backop_flags_ap, proc_set_backop_flags_ap),
+	#endif
+	#ifdef CONFIG_RTW_MESH
+	RTW_PROC_HDL_SSEQ("backop_flags_mesh", proc_get_backop_flags_mesh, proc_set_backop_flags_mesh),
+	#endif
+#endif
+#ifdef CONFIG_RTW_REPEATER_SON
+	RTW_PROC_HDL_SSEQ("rson_data", proc_get_rson_data, proc_set_rson_data),
 #endif
 	RTW_PROC_HDL_SSEQ("survey_info", proc_get_survey_info, proc_set_survey_info),
 	RTW_PROC_HDL_SSEQ("ap_info", proc_get_ap_info, NULL),
 	RTW_PROC_HDL_SSEQ("trx_info", proc_get_trx_info, proc_reset_trx_info),
+	RTW_PROC_HDL_SSEQ("tx_power_offset", proc_get_tx_power_offset, proc_set_tx_power_offset),
 	RTW_PROC_HDL_SSEQ("rate_ctl", proc_get_rate_ctl, proc_set_rate_ctl),
-	RTW_PROC_HDL_SSEQ("dis_pwt_ctl", proc_get_dis_pwt, proc_set_dis_pwt),
+	RTW_PROC_HDL_SSEQ("bw_ctl", proc_get_bw_ctl, proc_set_bw_ctl),
 	RTW_PROC_HDL_SSEQ("mac_qinfo", proc_get_mac_qinfo, NULL),
 	RTW_PROC_HDL_SSEQ("macid_info", proc_get_macid_info, NULL),
+	RTW_PROC_HDL_SSEQ("bcmc_info", proc_get_mi_ap_bc_info, NULL),
 	RTW_PROC_HDL_SSEQ("sec_cam", proc_get_sec_cam, proc_set_sec_cam),
 	RTW_PROC_HDL_SSEQ("sec_cam_cache", proc_get_sec_cam_cache, NULL),
-	RTW_PROC_HDL_SSEQ("suspend_info", proc_get_suspend_resume_info, NULL),
+	RTW_PROC_HDL_SSEQ("ps_dbg_info", proc_get_ps_dbg_info, proc_set_ps_dbg_info),
 	RTW_PROC_HDL_SSEQ("wifi_spec", proc_get_wifi_spec, NULL),
 #ifdef CONFIG_LAYER2_ROAMING
 	RTW_PROC_HDL_SSEQ("roam_flags", proc_get_roam_flags, proc_set_roam_flags),
@@ -1828,21 +3404,34 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("roam_tgt_addr", NULL, proc_set_roam_tgt_addr),
 #endif /* CONFIG_LAYER2_ROAMING */
 
+#ifdef CONFIG_RTW_80211R
+	RTW_PROC_HDL_SSEQ("ft_flags", proc_get_ft_flags, proc_set_ft_flags),
+#endif
+
 #ifdef CONFIG_SDIO_HCI
 	RTW_PROC_HDL_SSEQ("sd_f0_reg_dump", proc_get_sd_f0_reg_dump, NULL),
 	RTW_PROC_HDL_SSEQ("sdio_local_reg_dump", proc_get_sdio_local_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("sdio_card_info", proc_get_sdio_card_info, NULL),
 #endif /* CONFIG_SDIO_HCI */
 
 	RTW_PROC_HDL_SSEQ("fwdl_test_case", NULL, proc_set_fwdl_test_case),
 	RTW_PROC_HDL_SSEQ("del_rx_ampdu_test_case", NULL, proc_set_del_rx_ampdu_test_case),
 	RTW_PROC_HDL_SSEQ("wait_hiq_empty", NULL, proc_set_wait_hiq_empty),
+	RTW_PROC_HDL_SSEQ("sta_linking_test", NULL, proc_set_sta_linking_test),
 
 	RTW_PROC_HDL_SSEQ("mac_reg_dump", proc_get_mac_reg_dump, NULL),
 	RTW_PROC_HDL_SSEQ("bb_reg_dump", proc_get_bb_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("bb_reg_dump_ex", proc_get_bb_reg_dump_ex, NULL),
 	RTW_PROC_HDL_SSEQ("rf_reg_dump", proc_get_rf_reg_dump, NULL),
 
+#ifdef CONFIG_RTW_LED
+	RTW_PROC_HDL_SSEQ("led_config", proc_get_led_config, proc_set_led_config),
+#endif
+
 #ifdef CONFIG_AP_MODE
+	RTW_PROC_HDL_SSEQ("aid_status", proc_get_aid_status, proc_set_aid_status),
 	RTW_PROC_HDL_SSEQ("all_sta_info", proc_get_all_sta_info, NULL),
+	RTW_PROC_HDL_SSEQ("bmc_tx_rate", proc_get_bmc_tx_rate, proc_set_bmc_tx_rate),
 #endif /* CONFIG_AP_MODE */
 
 #ifdef DBG_MEMORY_LEAK
@@ -1854,24 +3443,29 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 #endif
 
 	RTW_PROC_HDL_SSEQ("rx_signal", proc_get_rx_signal, proc_set_rx_signal),
-	RTW_PROC_HDL_SSEQ("hw_info", proc_get_hw_status, NULL),
+	RTW_PROC_HDL_SSEQ("hw_info", proc_get_hw_status, proc_set_hw_status),
 
 #ifdef CONFIG_80211N_HT
 	RTW_PROC_HDL_SSEQ("ht_enable", proc_get_ht_enable, proc_set_ht_enable),
 	RTW_PROC_HDL_SSEQ("bw_mode", proc_get_bw_mode, proc_set_bw_mode),
 	RTW_PROC_HDL_SSEQ("ampdu_enable", proc_get_ampdu_enable, proc_set_ampdu_enable),
-	RTW_PROC_HDL_SSEQ("rx_stbc", proc_get_rx_stbc, proc_set_rx_stbc),
 	RTW_PROC_HDL_SSEQ("rx_ampdu", proc_get_rx_ampdu, proc_set_rx_ampdu),
+	RTW_PROC_HDL_SSEQ("rx_ampdu_size_limit", proc_get_rx_ampdu_size_limit, proc_set_rx_ampdu_size_limit),
 	RTW_PROC_HDL_SSEQ("rx_ampdu_factor", proc_get_rx_ampdu_factor, proc_set_rx_ampdu_factor),
 	RTW_PROC_HDL_SSEQ("rx_ampdu_density", proc_get_rx_ampdu_density, proc_set_rx_ampdu_density),
 	RTW_PROC_HDL_SSEQ("tx_ampdu_density", proc_get_tx_ampdu_density, proc_set_tx_ampdu_density),
+#ifdef CONFIG_TX_AMSDU
+	RTW_PROC_HDL_SSEQ("tx_amsdu", proc_get_tx_amsdu, proc_set_tx_amsdu),
+	RTW_PROC_HDL_SSEQ("tx_amsdu_rate", proc_get_tx_amsdu_rate, proc_set_tx_amsdu_rate),
+#endif
 #endif /* CONFIG_80211N_HT */
+	RTW_PROC_HDL_SSEQ("tx_max_agg_num", proc_get_tx_max_agg_num, proc_set_tx_max_agg_num),
 
 	RTW_PROC_HDL_SSEQ("en_fwps", proc_get_en_fwps, proc_set_en_fwps),
 	RTW_PROC_HDL_SSEQ("mac_rptbuf", proc_get_mac_rptbuf, NULL),
 
-	//RTW_PROC_HDL_SSEQ("path_rssi", proc_get_two_path_rssi, NULL),
-	//RTW_PROC_HDL_SSEQ("rssi_disp",proc_get_rssi_disp, proc_set_rssi_disp),
+	/* RTW_PROC_HDL_SSEQ("path_rssi", proc_get_two_path_rssi, NULL),
+	* 	RTW_PROC_HDL_SSEQ("rssi_disp",proc_get_rssi_disp, proc_set_rssi_disp), */
 
 #ifdef CONFIG_BT_COEXIST
 	RTW_PROC_HDL_SSEQ("btcoex_dbg", proc_get_btcoex_dbg, proc_set_btcoex_dbg),
@@ -1879,13 +3473,22 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("btinfo_evt", NULL, proc_set_btinfo_evt),
 	RTW_PROC_HDL_SSEQ("btreg_read", proc_get_btreg_read, proc_set_btreg_read),
 	RTW_PROC_HDL_SSEQ("btreg_write", proc_get_btreg_write, proc_set_btreg_write),
+#ifdef CONFIG_RF4CE_COEXIST
+	RTW_PROC_HDL_SSEQ("rf4ce_state", proc_get_rf4ce_state, proc_set_rf4ce_state),
+#endif
 #endif /* CONFIG_BT_COEXIST */
 
 #if defined(DBG_CONFIG_ERROR_DETECT)
 	RTW_PROC_HDL_SSEQ("sreset", proc_get_sreset, proc_set_sreset),
 #endif /* DBG_CONFIG_ERROR_DETECT */
+	RTW_PROC_HDL_SSEQ("trx_info_debug", proc_get_trx_info_debug, NULL),
 	RTW_PROC_HDL_SSEQ("linked_info_dump", proc_get_linked_info_dump, proc_set_linked_info_dump),
-	RTW_PROC_HDL_SSEQ("current_tx_rate", proc_get_current_tx_rate, NULL),
+	RTW_PROC_HDL_SSEQ("sta_tp_dump", proc_get_sta_tp_dump, proc_set_sta_tp_dump),
+	RTW_PROC_HDL_SSEQ("sta_tp_info", proc_get_sta_tp_info, NULL),
+	RTW_PROC_HDL_SSEQ("dis_turboedca", proc_get_turboedca_ctrl, proc_set_turboedca_ctrl),
+	RTW_PROC_HDL_SSEQ("tx_info_msg", proc_get_tx_info_msg, NULL),
+	RTW_PROC_HDL_SSEQ("rx_info_msg", proc_get_rx_info_msg, proc_set_rx_info_msg),
+
 #ifdef CONFIG_GPIO_API
 	RTW_PROC_HDL_SSEQ("gpio_info", proc_get_gpio, proc_set_gpio),
 	RTW_PROC_HDL_SSEQ("gpio_set_output_value", NULL, proc_set_gpio_output_value),
@@ -1898,10 +3501,31 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("int_logs", proc_get_int_logs, NULL),
 #endif
 
+#ifdef CONFIG_DBG_RF_CAL
+	RTW_PROC_HDL_SSEQ("iqk", proc_get_iqk_info, proc_set_iqk),
+	RTW_PROC_HDL_SSEQ("lck", proc_get_lck_info, proc_set_lck),
+#endif
+
 #ifdef CONFIG_PCI_HCI
 	RTW_PROC_HDL_SSEQ("rx_ring", proc_get_rx_ring, NULL),
 	RTW_PROC_HDL_SSEQ("tx_ring", proc_get_tx_ring, NULL),
+#ifdef DBG_TXBD_DESC_DUMP
+	RTW_PROC_HDL_SSEQ("tx_ring_ext", proc_get_tx_ring_ext, proc_set_tx_ring_ext),
+#endif
+	RTW_PROC_HDL_SSEQ("pci_aspm", proc_get_pci_aspm, NULL),
+#endif
+
+#ifdef CONFIG_WOWLAN
+	RTW_PROC_HDL_SSEQ("wow_pattern_info", proc_get_pattern_info, proc_set_pattern_info),
+	RTW_PROC_HDL_SSEQ("wow_wakeup_event", proc_get_wakeup_event,
+			  proc_set_wakeup_event),
+	RTW_PROC_HDL_SSEQ("wowlan_last_wake_reason", proc_get_wakeup_reason, NULL),
+#ifdef CONFIG_WOW_PATTERN_HW_CAM
+	RTW_PROC_HDL_SSEQ("wow_pattern_cam", proc_dump_pattern_cam, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("dis_wow_lps", proc_get_wow_lps_ctrl, proc_set_wow_lps_ctrl),
 #endif
+
 #ifdef CONFIG_GPIO_WAKEUP
 	RTW_PROC_HDL_SSEQ("wowlan_gpio_info", proc_get_wowlan_gpio_info, proc_set_wowlan_gpio_info),
 #endif
@@ -1910,10 +3534,18 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 #endif
 	RTW_PROC_HDL_SSEQ("country_code", proc_get_country_code, proc_set_country_code),
 	RTW_PROC_HDL_SSEQ("chan_plan", proc_get_chan_plan, proc_set_chan_plan),
+#if CONFIG_RTW_MACADDR_ACL
+	RTW_PROC_HDL_SSEQ("macaddr_acl", proc_get_macaddr_acl, proc_set_macaddr_acl),
+#endif
+#if CONFIG_RTW_PRE_LINK_STA
+	RTW_PROC_HDL_SSEQ("pre_link_sta", proc_get_pre_link_sta, proc_set_pre_link_sta),
+#endif
+	RTW_PROC_HDL_SSEQ("ch_sel_policy", proc_get_ch_sel_policy, proc_set_ch_sel_policy),
 #ifdef CONFIG_DFS_MASTER
 	RTW_PROC_HDL_SSEQ("dfs_master_test_case", proc_get_dfs_master_test_case, proc_set_dfs_master_test_case),
 	RTW_PROC_HDL_SSEQ("update_non_ocp", NULL, proc_set_update_non_ocp),
 	RTW_PROC_HDL_SSEQ("radar_detect", NULL, proc_set_radar_detect),
+	RTW_PROC_HDL_SSEQ("dfs_ch_sel_d_flags", proc_get_dfs_ch_sel_d_flags, proc_set_dfs_ch_sel_d_flags),
 #endif
 	RTW_PROC_HDL_SSEQ("new_bcn_max", proc_get_new_bcn_max, proc_set_new_bcn_max),
 	RTW_PROC_HDL_SSEQ("sink_udpport", proc_get_udpport, proc_set_udpport),
@@ -1925,10 +3557,12 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("hal_txpwr_info", proc_get_hal_txpwr_info, NULL),
 	RTW_PROC_HDL_SSEQ("target_tx_power", proc_get_target_tx_power, NULL),
 	RTW_PROC_HDL_SSEQ("tx_power_by_rate", proc_get_tx_power_by_rate, NULL),
+#ifdef CONFIG_TXPWR_LIMIT
 	RTW_PROC_HDL_SSEQ("tx_power_limit", proc_get_tx_power_limit, NULL),
+#endif
 	RTW_PROC_HDL_SSEQ("tx_power_ext_info", proc_get_tx_power_ext_info, proc_set_tx_power_ext_info),
 	RTW_PROC_HDL_SEQ("tx_power_idx", &seq_ops_tx_power_idx, NULL),
-#ifdef CONFIG_RF_GAIN_OFFSET
+#ifdef CONFIG_RF_POWER_TRIM
 	RTW_PROC_HDL_SSEQ("tx_gain_offset", NULL, proc_set_tx_gain_offset),
 	RTW_PROC_HDL_SSEQ("kfree_flag", proc_get_kfree_flag, proc_set_kfree_flag),
 	RTW_PROC_HDL_SSEQ("kfree_bb_gain", proc_get_kfree_bb_gain, proc_set_kfree_bb_gain),
@@ -1936,15 +3570,25 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 #endif
 #ifdef CONFIG_POWER_SAVING
 	RTW_PROC_HDL_SSEQ("ps_info", proc_get_ps_info, NULL),
+#ifdef CONFIG_WMMPS_STA
+	RTW_PROC_HDL_SSEQ("wmmps_info", proc_get_wmmps_info, proc_set_wmmps_info),
+#endif /* CONFIG_WMMPS_STA */	
 #endif
 #ifdef CONFIG_TDLS
 	RTW_PROC_HDL_SSEQ("tdls_info", proc_get_tdls_info, NULL),
+	RTW_PROC_HDL_SSEQ("tdls_enable", proc_get_tdls_enable, proc_set_tdls_enable),
 #endif
 	RTW_PROC_HDL_SSEQ("monitor", proc_get_monitor, proc_set_monitor),
 
-#ifdef CONFIG_AUTO_CHNL_SEL_NHM
+#ifdef CONFIG_RTW_ACS
 	RTW_PROC_HDL_SSEQ("acs", proc_get_best_chan, proc_set_acs),
+	RTW_PROC_HDL_SSEQ("chan_info", proc_get_chan_info, NULL),
 #endif
+
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	RTW_PROC_HDL_SSEQ("noise_monitor", proc_get_nm, proc_set_nm),
+#endif
+
 #ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
 	RTW_PROC_HDL_SSEQ("rtkm_info", proc_get_rtkm_info, NULL),
 #endif
@@ -1954,7 +3598,70 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("11w_tx_deauth", proc_get_tx_deauth, proc_set_tx_deauth),
 	RTW_PROC_HDL_SSEQ("11w_tx_auth", proc_get_tx_auth, proc_set_tx_auth),
 #endif /* CONFIG_IEEE80211W */
+
+#ifdef CONFIG_MBSSID_CAM
+	RTW_PROC_HDL_SSEQ("mbid_cam", proc_get_mbid_cam_cache, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("mac_addr", proc_get_mac_addr, NULL),
+	RTW_PROC_HDL_SSEQ("skip_band", proc_get_skip_band, proc_set_skip_band),
 	RTW_PROC_HDL_SSEQ("hal_spec", proc_get_hal_spec, NULL),
+
+	RTW_PROC_HDL_SSEQ("rx_stat", proc_get_rx_stat, NULL),
+
+	RTW_PROC_HDL_SSEQ("tx_stat", proc_get_tx_stat, NULL),
+	/**** PHY Capability ****/
+	RTW_PROC_HDL_SSEQ("phy_cap", proc_get_phy_cap, NULL),
+
+	RTW_PROC_HDL_SSEQ("rx_stbc", proc_get_rx_stbc, proc_set_rx_stbc),
+	RTW_PROC_HDL_SSEQ("stbc_cap", proc_get_stbc_cap, proc_set_stbc_cap),
+	RTW_PROC_HDL_SSEQ("ldpc_cap", proc_get_ldpc_cap, proc_set_ldpc_cap),
+#ifdef CONFIG_BEAMFORMING
+	RTW_PROC_HDL_SSEQ("txbf_cap", proc_get_txbf_cap, proc_set_txbf_cap),
+#endif
+
+#ifdef CONFIG_SUPPORT_TRX_SHARED
+	RTW_PROC_HDL_SSEQ("trx_share_mode", proc_get_trx_share_mode, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("napi_info", proc_get_napi_info, NULL),
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	RTW_PROC_HDL_SSEQ("napi_th", proc_get_napi_info, proc_set_napi_th),
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+
+	RTW_PROC_HDL_SSEQ("rsvd_page", proc_dump_rsvd_page, proc_set_rsvd_page_info),
+
+#ifdef CONFIG_SUPPORT_FIFO_DUMP
+	RTW_PROC_HDL_SSEQ("fifo_dump", proc_dump_fifo, proc_set_fifo_info),
+#endif
+	RTW_PROC_HDL_SSEQ("fw_info", proc_get_fw_info, NULL),
+
+#ifdef DBG_XMIT_BLOCK
+	RTW_PROC_HDL_SSEQ("xmit_block", proc_get_xmit_block, proc_set_xmit_block),
+#endif
+
+	RTW_PROC_HDL_SSEQ("ack_timeout", proc_get_ack_timeout, proc_set_ack_timeout),
+
+	RTW_PROC_HDL_SSEQ("dynamic_agg_enable", proc_get_dynamic_agg_enable, proc_set_dynamic_agg_enable),
+	RTW_PROC_HDL_SSEQ("fw_offload", proc_get_fw_offload, proc_set_fw_offload),
+
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	RTW_PROC_HDL_SSEQ("mesh_peer_blacklist", proc_get_mesh_peer_blacklist, proc_set_mesh_peer_blacklist),
+	#endif
+	#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	RTW_PROC_HDL_SSEQ("mesh_cto_mgate_require", proc_get_mesh_cto_mgate_require, proc_set_mesh_cto_mgate_require),
+	RTW_PROC_HDL_SSEQ("mesh_cto_mgate_blacklist", proc_get_mesh_cto_mgate_blacklist, proc_set_mesh_cto_mgate_blacklist),
+	#endif
+	RTW_PROC_HDL_SSEQ("mesh_peer_sel_policy", proc_get_mesh_peer_sel_policy, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_networks", proc_get_mesh_networks, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_plink_ctl", proc_get_mesh_plink_ctl, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_known_gates", proc_get_mesh_known_gates, NULL),
+	#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	RTW_PROC_HDL_SSEQ("mesh_b2u_flags", proc_get_mesh_b2u_flags, proc_set_mesh_b2u_flags),
+	#endif
+	RTW_PROC_HDL_SSEQ("mesh_stats", proc_get_mesh_stats, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_gate_timeout_factor", proc_get_mesh_gate_timeout, proc_set_mesh_gate_timeout),
+	RTW_PROC_HDL_SSEQ("mesh_gate_state", proc_get_mesh_gate_state, NULL),
+#endif
 };
 
 const int adapter_proc_hdls_num = sizeof(adapter_proc_hdls) / sizeof(struct rtw_proc_hdl);
@@ -2011,123 +3718,6 @@ static const struct file_operations rtw_adapter_proc_sseq_fops = {
 	.write = rtw_adapter_proc_write,
 };
 
-int proc_get_odm_dbg_comp(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-
-	rtw_odm_dbg_comp_msg(m, adapter);
-
-	return 0;
-}
-
-ssize_t proc_set_odm_dbg_comp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[32];
-
-	u64 dbg_comp;
-
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%llx", &dbg_comp);
-
-		if (num != 1)
-			return count;
-
-		rtw_odm_dbg_comp_set(adapter, dbg_comp);
-	}
-
-	return count;
-}
-
-int proc_get_odm_dbg_level(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-
-	rtw_odm_dbg_level_msg(m, adapter);
-
-	return 0;
-}
-
-ssize_t proc_set_odm_dbg_level(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[32];
-
-	u32 dbg_level;
-
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%u", &dbg_level);
-
-		if (num != 1)
-			return count;
-
-		rtw_odm_dbg_level_set(adapter, dbg_level);
-	}
-
-	return count;
-}
-
-int proc_get_odm_ability(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-
-	rtw_odm_ability_msg(m, adapter);
-
-	return 0;
-}
-
-ssize_t proc_set_odm_ability(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[32];
-
-	u32 ability;
-
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%x", &ability);
-
-		if (num != 1)
-			return count;
-
-		rtw_odm_ability_set(adapter, ability);
-	}
-
-	return count;
-}
-
 int proc_get_odm_adaptivity(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
@@ -2143,11 +3733,11 @@ ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, si
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	u32 TH_L2H_ini;
-	u32 TH_L2H_ini_mode2;
-	s8 TH_EDCCA_HL_diff;
-	s8 TH_EDCCA_HL_diff_mode2;
-	u8 EDCCA_enable;
+	u32 th_l2h_ini;
+	u32 th_l2h_ini_mode2;
+	s8 th_edcca_hl_diff;
+	s8 th_edcca_hl_diff_mode2;
+	u8 edcca_enable;
 
 	if (count < 1)
 		return -EFAULT;
@@ -2159,14 +3749,14 @@ ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, si
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%x %hhd %x %hhd %hhu", &TH_L2H_ini, &TH_EDCCA_HL_diff, &TH_L2H_ini_mode2, &TH_EDCCA_HL_diff_mode2, &EDCCA_enable);
+		int num = sscanf(tmp, "%x %hhd %x %hhd %hhu", &th_l2h_ini, &th_edcca_hl_diff, &th_l2h_ini_mode2, &th_edcca_hl_diff_mode2, &edcca_enable);
 
 		if (num != 5)
 			return count;
 
-		rtw_odm_adaptivity_parm_set(padapter, (s8)TH_L2H_ini, TH_EDCCA_HL_diff, (s8)TH_L2H_ini_mode2, TH_EDCCA_HL_diff_mode2, EDCCA_enable);
+		rtw_odm_adaptivity_parm_set(padapter, (s8)th_l2h_ini, th_edcca_hl_diff, (s8)th_l2h_ini_mode2, th_edcca_hl_diff_mode2, edcca_enable);
 	}
-	
+
 	return count;
 }
 
@@ -2177,14 +3767,12 @@ int proc_get_phydm_cmd(struct seq_file *m, void *v)
 {
 	struct net_device *netdev;
 	PADAPTER padapter;
-	PHAL_DATA_TYPE pHalData;
-	PDM_ODM_T phydm;
+	struct dm_struct *phydm;
 
 
 	netdev = m->private;
 	padapter = (PADAPTER)rtw_netdev_priv(netdev);
-	pHalData = GET_HAL_DATA(padapter);
-	phydm = &pHalData->odmpriv;
+	phydm = adapter_to_phydm(padapter);
 
 	if (NULL == phydm_msg) {
 		phydm_msg = rtw_zmalloc(PHYDM_MSG_LEN);
@@ -2194,7 +3782,7 @@ int proc_get_phydm_cmd(struct seq_file *m, void *v)
 		phydm_cmd(phydm, NULL, 0, 0, phydm_msg, PHYDM_MSG_LEN);
 	}
 
-	DBG_871X_SEL(m, "%s\n", phydm_msg);
+	_RTW_PRINT_SEL(m, "%s\n", phydm_msg);
 
 	rtw_mfree(phydm_msg, PHYDM_MSG_LEN);
 	phydm_msg = NULL;
@@ -2206,15 +3794,13 @@ ssize_t proc_set_phydm_cmd(struct file *file, const char __user *buffer, size_t
 {
 	struct net_device *netdev;
 	PADAPTER padapter;
-	PHAL_DATA_TYPE pHalData;
-	PDM_ODM_T phydm;
+	struct dm_struct *phydm;
 	char tmp[64] = {0};
 
 
-	netdev = (struct net_device*)data;
+	netdev = (struct net_device *)data;
 	padapter = (PADAPTER)rtw_netdev_priv(netdev);
-	pHalData = GET_HAL_DATA(padapter);
-	phydm = &pHalData->odmpriv;
+	phydm = adapter_to_phydm(padapter);
 
 	if (count < 1)
 		return -EFAULT;
@@ -2227,9 +3813,8 @@ ssize_t proc_set_phydm_cmd(struct file *file, const char __user *buffer, size_t
 			phydm_msg = rtw_zmalloc(PHYDM_MSG_LEN);
 			if (NULL == phydm_msg)
 				return -ENOMEM;
-		} else {
+		} else
 			_rtw_memset(phydm_msg, 0, PHYDM_MSG_LEN);
-		}
 
 		phydm_cmd(phydm, tmp, count, 1, phydm_msg, PHYDM_MSG_LEN);
 
@@ -2247,9 +3832,6 @@ ssize_t proc_set_phydm_cmd(struct file *file, const char __user *buffer, size_t
 * init/deinit when register/unregister net_device, along with rtw_adapter_proc
 */
 const struct rtw_proc_hdl odm_proc_hdls[] = {
-	RTW_PROC_HDL_SSEQ("dbg_comp", proc_get_odm_dbg_comp, proc_set_odm_dbg_comp),
-	RTW_PROC_HDL_SSEQ("dbg_level", proc_get_odm_dbg_level, proc_set_odm_dbg_level),
-	RTW_PROC_HDL_SSEQ("ability", proc_get_odm_ability, proc_set_odm_ability),
 	RTW_PROC_HDL_SSEQ("adaptivity", proc_get_odm_adaptivity, proc_set_odm_adaptivity),
 	RTW_PROC_HDL_SSEQ("cmd", proc_get_phydm_cmd, proc_set_phydm_cmd),
 };
@@ -2376,6 +3958,143 @@ void rtw_odm_proc_deinit(_adapter	*adapter)
 	}
 }
 
+#ifdef CONFIG_MCC_MODE
+/*
+* rtw_mcc_proc:
+* init/deinit when register/unregister net_device, along with rtw_adapter_proc
+*/
+const struct rtw_proc_hdl mcc_proc_hdls[] = {
+	RTW_PROC_HDL_SSEQ("mcc_info", proc_get_mcc_info, NULL),
+	RTW_PROC_HDL_SSEQ("mcc_enable", proc_get_mcc_info, proc_set_mcc_enable),
+	RTW_PROC_HDL_SSEQ("mcc_duration", proc_get_mcc_info, proc_set_mcc_duration),
+	RTW_PROC_HDL_SSEQ("mcc_single_tx_criteria", proc_get_mcc_info, proc_set_mcc_single_tx_criteria),
+	RTW_PROC_HDL_SSEQ("mcc_ap_bw20_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw20_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_ap_bw40_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw40_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_ap_bw80_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw80_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_sta_bw20_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw20_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_sta_bw40_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw40_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_sta_bw80_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw80_target_tp),
+	RTW_PROC_HDL_SSEQ("mcc_policy_table", proc_get_mcc_policy_table, NULL),
+};
+
+const int mcc_proc_hdls_num = sizeof(mcc_proc_hdls) / sizeof(struct rtw_proc_hdl);
+
+static int rtw_mcc_proc_open(struct inode *inode, struct file *file)
+{
+	ssize_t index = (ssize_t)PDE_DATA(inode);
+	const struct rtw_proc_hdl *hdl = mcc_proc_hdls + index;
+	void *private = proc_get_parent_data(inode);
+
+	if (hdl->type == RTW_PROC_HDL_TYPE_SEQ) {
+		int res = seq_open(file, hdl->u.seq_op);
+
+		if (res == 0)
+			((struct seq_file *)file->private_data)->private = private;
+
+		return res;
+	} else if (hdl->type == RTW_PROC_HDL_TYPE_SSEQ) {
+		int (*show)(struct seq_file *, void *) = hdl->u.show ? hdl->u.show : proc_get_dummy;
+
+		return single_open(file, show, private);
+	} else {
+		return -EROFS;
+	}
+}
+
+static ssize_t rtw_mcc_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)
+{
+	ssize_t index = (ssize_t)PDE_DATA(file_inode(file));
+	const struct rtw_proc_hdl *hdl = mcc_proc_hdls + index;
+	ssize_t (*write)(struct file *, const char __user *, size_t, loff_t *, void *) = hdl->write;
+
+	if (write)
+		return write(file, buffer, count, pos, ((struct seq_file *)file->private_data)->private);
+
+	return -EROFS;
+}
+
+static const struct file_operations rtw_mcc_proc_seq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_mcc_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = seq_release,
+	.write = rtw_mcc_proc_write,
+};
+
+static const struct file_operations rtw_mcc_proc_sseq_fops = {
+	.owner = THIS_MODULE,
+	.open = rtw_mcc_proc_open,
+	.read = seq_read,
+	.llseek = seq_lseek,
+	.release = single_release,
+	.write = rtw_mcc_proc_write,
+};
+
+struct proc_dir_entry *rtw_mcc_proc_init(struct net_device *dev)
+{
+	struct proc_dir_entry *dir_mcc = NULL;
+	struct proc_dir_entry *entry = NULL;
+	_adapter	*adapter = rtw_netdev_priv(dev);
+	ssize_t i;
+
+	if (adapter->dir_dev == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (adapter->dir_mcc != NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	dir_mcc = rtw_proc_create_dir("mcc", adapter->dir_dev, dev);
+	if (dir_mcc == NULL) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	adapter->dir_mcc = dir_mcc;
+
+	for (i = 0; i < mcc_proc_hdls_num; i++) {
+		if (mcc_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SEQ)
+			entry = rtw_proc_create_entry(mcc_proc_hdls[i].name, dir_mcc, &rtw_mcc_proc_seq_fops, (void *)i);
+		else if (mcc_proc_hdls[i].type == RTW_PROC_HDL_TYPE_SSEQ)
+			entry = rtw_proc_create_entry(mcc_proc_hdls[i].name, dir_mcc, &rtw_mcc_proc_sseq_fops, (void *)i);
+		else
+			entry = NULL;
+
+		if (!entry) {
+			rtw_warn_on(1);
+			goto exit;
+		}
+	}
+
+exit:
+	return dir_mcc;
+}
+
+void rtw_mcc_proc_deinit(_adapter	*adapter)
+{
+	struct proc_dir_entry *dir_mcc = NULL;
+	int i;
+
+	dir_mcc = adapter->dir_mcc;
+
+	if (dir_mcc == NULL) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	for (i = 0; i < mcc_proc_hdls_num; i++)
+		remove_proc_entry(mcc_proc_hdls[i].name, dir_mcc);
+
+	remove_proc_entry("mcc", adapter->dir_dev);
+
+	adapter->dir_mcc = NULL;
+}
+#endif /* CONFIG_MCC_MODE */
+
 struct proc_dir_entry *rtw_adapter_proc_init(struct net_device *dev)
 {
 	struct proc_dir_entry *drv_proc = get_rtw_drv_proc();
@@ -2419,6 +4138,10 @@ struct proc_dir_entry *rtw_adapter_proc_init(struct net_device *dev)
 
 	rtw_odm_proc_init(dev);
 
+#ifdef CONFIG_MCC_MODE
+	rtw_mcc_proc_init(dev);
+#endif /* CONFIG_MCC_MODE */
+
 exit:
 	return dir_dev;
 }
@@ -2442,6 +4165,10 @@ void rtw_adapter_proc_deinit(struct net_device *dev)
 
 	rtw_odm_proc_deinit(adapter);
 
+#ifdef CONFIG_MCC_MODE
+	rtw_mcc_proc_deinit(adapter);
+#endif /* CONFIG_MCC_MODE */
+
 	remove_proc_entry(dev->name, drv_proc);
 
 	adapter->dir_dev = NULL;
@@ -2466,6 +4193,10 @@ void rtw_adapter_proc_replace(struct net_device *dev)
 
 	rtw_odm_proc_deinit(adapter);
 
+#ifdef CONFIG_MCC_MODE
+	rtw_mcc_proc_deinit(adapter);
+#endif /* CONIG_MCC_MODE */
+
 	remove_proc_entry(adapter->old_ifname, drv_proc);
 
 	adapter->dir_dev = NULL;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.h
index 0ab929c51f25..bdeace1928ee 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_proc.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #ifndef __RTW_PROC_H__
 #define __RTW_PROC_H__
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_rhashtable.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_rhashtable.c
new file mode 100644
index 000000000000..3bbdc3c9140c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_rhashtable.c
@@ -0,0 +1,75 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#ifdef CONFIG_RTW_MESH /* for now, only promised for kernel versions we support mesh */
+
+#include <drv_types.h>
+
+int rtw_rhashtable_walk_enter(rtw_rhashtable *ht, rtw_rhashtable_iter *iter)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+	return rhashtable_walk_init((ht), (iter), GFP_ATOMIC);
+#else
+	/* kernel >= 4.4.0 rhashtable_walk_init use GFP_KERNEL to alloc, spin_lock for assignment */
+	iter->ht = ht;
+	iter->p = NULL;
+	iter->slot = 0;
+	iter->skip = 0;
+
+	iter->walker = kmalloc(sizeof(*iter->walker), GFP_ATOMIC);
+	if (!iter->walker)
+		return -ENOMEM;
+
+	spin_lock(&ht->lock);
+	iter->walker->tbl =
+		rcu_dereference_protected(ht->tbl, lockdep_is_held(&ht->lock));
+	list_add(&iter->walker->list, &iter->walker->tbl->walkers);
+	spin_unlock(&ht->lock);
+
+	return 0;
+#endif
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25))
+static inline int is_vmalloc_addr(const void *x)
+{
+#ifdef CONFIG_MMU
+	unsigned long addr = (unsigned long)x;
+
+	return addr >= VMALLOC_START && addr < VMALLOC_END;
+#else
+	return 0;
+#endif
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25)) */
+
+void kvfree(const void *addr)
+{
+	if (is_vmalloc_addr(addr))
+		vfree(addr);
+	else
+		kfree(addr);
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0)) */
+
+#include "rhashtable.c"
+
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0)) */
+
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_rhashtable.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_rhashtable.h
new file mode 100644
index 000000000000..a79cecc17007
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/rtw_rhashtable.h
@@ -0,0 +1,56 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_RHASHTABLE_H__
+#define __RTW_RHASHTABLE_H__
+
+#ifdef CONFIG_RTW_MESH /* for now, only promised for kernel versions we support mesh */
+
+/* directly reference rhashtable in kernel */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0))
+#include <linux/rhashtable.h>
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0)) */
+
+/* Use rhashtable from kernel 4.4 */
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+#define NULLS_MARKER(value) (1UL | (((long)value) << 1))
+#endif
+#include "rhashtable.h"
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0)) */
+
+typedef struct rhashtable rtw_rhashtable;
+typedef struct rhash_head rtw_rhash_head;
+typedef struct rhashtable_params rtw_rhashtable_params;
+
+#define rtw_rhashtable_init(ht, params) rhashtable_init(ht, params)
+
+typedef struct rhashtable_iter rtw_rhashtable_iter;
+
+int rtw_rhashtable_walk_enter(rtw_rhashtable *ht, rtw_rhashtable_iter *iter);
+#define rtw_rhashtable_walk_exit(iter) rhashtable_walk_exit(iter)
+#define rtw_rhashtable_walk_start(iter) rhashtable_walk_start(iter)
+#define rtw_rhashtable_walk_next(iter) rhashtable_walk_next(iter)
+#define rtw_rhashtable_walk_stop(iter) rhashtable_walk_stop(iter)
+
+#define rtw_rhashtable_free_and_destroy(ht, free_fn, arg) rhashtable_free_and_destroy((ht), (free_fn), (arg))
+#define rtw_rhashtable_lookup_fast(ht, key, params) rhashtable_lookup_fast((ht), (key), (params))
+#define rtw_rhashtable_lookup_insert_fast(ht, obj, params) rhashtable_lookup_insert_fast((ht), (obj), (params))
+#define rtw_rhashtable_remove_fast(ht, obj, params) rhashtable_remove_fast((ht), (obj), (params))
+
+#endif /* CONFIG_RTW_MESH */
+
+#endif /* __RTW_RHASHTABLE_H__ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_intf.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_intf.c
index c6cc1aa8322f..dbeef0ab926a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_intf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_intf.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _HCI_INTF_C_
 
 #include <drv_types.h>
@@ -27,6 +23,10 @@
 #error "CONFIG_SDIO_HCI shall be on!\n"
 #endif
 
+#ifdef CONFIG_RTL8822B
+#include <rtl8822b_hal.h>	/* rtl8822bs_set_hal_ops() */
+#endif /* CONFIG_RTL8822B */
+
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 #ifdef CONFIG_ACPI
 #include <linux/acpi.h>
@@ -34,7 +34,7 @@
 #include "rtw_android.h"
 #endif
 static int wlan_en_gpio = -1;
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 
 #ifndef dev_to_sdio_func
 #define dev_to_sdio_func(d)     container_of(d, struct sdio_func, dev)
@@ -44,22 +44,21 @@ static int wlan_en_gpio = -1;
 static struct mmc_host *mmc_host = NULL;
 #endif
 
-static const struct sdio_device_id sdio_ids[] =
-{
+static const struct sdio_device_id sdio_ids[] = {
 #ifdef CONFIG_RTL8723B
-	{ SDIO_DEVICE(0x024c, 0xB723),.driver_data = RTL8723B},
+	{ SDIO_DEVICE(0x024c, 0xB723), .driver_data = RTL8723B},
 #endif
 #ifdef CONFIG_RTL8188E
-	{ SDIO_DEVICE(0x024c, 0x8179),.driver_data = RTL8188E},
-#endif //CONFIG_RTL8188E
+	{ SDIO_DEVICE(0x024c, 0x8179), .driver_data = RTL8188E},
+#endif /* CONFIG_RTL8188E */
 
 #ifdef CONFIG_RTL8821A
-	{ SDIO_DEVICE(0x024c, 0x8821),.driver_data = RTL8821},
-#endif //CONFIG_RTL8821A
+	{ SDIO_DEVICE(0x024c, 0x8821), .driver_data = RTL8821},
+#endif /* CONFIG_RTL8821A */
 
 #ifdef CONFIG_RTL8192E
-	{ SDIO_DEVICE(0x024c, 0x818B),.driver_data = RTL8192E},
-#endif //CONFIG_RTL8192E
+	{ SDIO_DEVICE(0x024c, 0x818B), .driver_data = RTL8192E},
+#endif /* CONFIG_RTL8192E */
 
 #ifdef CONFIG_RTL8703B
 	{ SDIO_DEVICE(0x024c, 0xB703), .driver_data = RTL8703B},
@@ -69,6 +68,24 @@ static const struct sdio_device_id sdio_ids[] =
 	{SDIO_DEVICE(0x024c, 0xF179), .driver_data = RTL8188F},
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+	{SDIO_DEVICE(0x024c, 0x018C), .driver_data = RTL8188GTV},
+#endif
+
+#ifdef CONFIG_RTL8822B
+	{SDIO_DEVICE(0x024c, 0xB822), .driver_data = RTL8822B},
+#endif
+
+#ifdef CONFIG_RTL8723D
+	{ SDIO_DEVICE(0x024c, 0xD723), .driver_data = RTL8723D},
+	{ SDIO_DEVICE(0x024c, 0xD724), .driver_data = RTL8723D},
+#endif
+
+#ifdef CONFIG_RTL8821C
+	{SDIO_DEVICE(0x024C, 0xB821), .driver_data = RTL8821C},
+	{SDIO_DEVICE(0x024C, 0xC821), .driver_data = RTL8821C},
+#endif
+
 #if defined(RTW_ENABLE_WIFI_CONTROL_FUNC) /* temporarily add this to accept all sdio wlan id */
 	{ SDIO_DEVICE_CLASS(SDIO_CLASS_WLAN) },
 #endif
@@ -83,13 +100,13 @@ static int rtw_sdio_resume(struct device *dev);
 static int rtw_sdio_suspend(struct device *dev);
 extern void rtw_dev_unload(PADAPTER padapter);
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,29)) 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 static const struct dev_pm_ops rtw_sdio_pm_ops = {
 	.suspend	= rtw_sdio_suspend,
 	.resume	= rtw_sdio_resume,
 };
 #endif
-	
+
 struct sdio_drv_priv {
 	struct sdio_driver r871xs_drv;
 	int drv_registered;
@@ -98,13 +115,18 @@ struct sdio_drv_priv {
 static struct sdio_drv_priv sdio_drvpriv = {
 	.r871xs_drv.probe = rtw_drv_init,
 	.r871xs_drv.remove = rtw_dev_remove,
-	.r871xs_drv.name = (char*)DRV_NAME,
+	.r871xs_drv.name = (char *)DRV_NAME,
 	.r871xs_drv.id_table = sdio_ids,
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,29)) 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 	.r871xs_drv.drv = {
 		.pm = &rtw_sdio_pm_ops,
 	}
-	#endif
+#endif
+};
+
+static struct rtw_if_operations sdio_ops = {
+	.read		= rtw_sdio_raw_read,
+	.write		= rtw_sdio_raw_write,
 };
 
 static void sd_sync_int_hdl(struct sdio_func *func)
@@ -113,13 +135,13 @@ static void sd_sync_int_hdl(struct sdio_func *func)
 
 	psdpriv = sdio_get_drvdata(func);
 
-	if (!psdpriv->padapters[IFACE_ID0]) {
-		DBG_871X("%s if1 == NULL\n", __func__);
+	if (!dvobj_get_primary_adapter(psdpriv)) {
+		RTW_INFO("%s primary adapter == NULL\n", __func__);
 		return;
 	}
 
 	rtw_sdio_set_irq_thd(psdpriv, current);
-	sd_int_hdl(psdpriv->padapters[IFACE_ID0]);
+	sd_int_hdl(dvobj_get_primary_adapter(psdpriv));
 	rtw_sdio_set_irq_thd(psdpriv, NULL);
 }
 
@@ -135,46 +157,41 @@ int sdio_alloc_irq(struct dvobj_priv *dvobj)
 	sdio_claim_host(func);
 
 	err = sdio_claim_irq(func, &sd_sync_int_hdl);
-	if (err)
-	{
+	if (err) {
 		dvobj->drv_dbg.dbg_sdio_alloc_irq_error_cnt++;
-		printk(KERN_CRIT "%s: sdio_claim_irq FAIL(%d)!\n", __func__, err);
-	}
-	else
-	{
+		RTW_PRINT("%s: sdio_claim_irq FAIL(%d)!\n", __func__, err);
+	} else {
 		dvobj->drv_dbg.dbg_sdio_alloc_irq_cnt++;
 		dvobj->irq_alloc = 1;
 	}
 
 	sdio_release_host(func);
 
-	return err?_FAIL:_SUCCESS;
+	return err ? _FAIL : _SUCCESS;
 }
 
 void sdio_free_irq(struct dvobj_priv *dvobj)
 {
-    PSDIO_DATA psdio_data;
-    struct sdio_func *func;
-    int err;
-
-    if (dvobj->irq_alloc) {
-        psdio_data = &dvobj->intf_data;
-        func = psdio_data->func;
-
-        if (func) {
-            sdio_claim_host(func);
-            err = sdio_release_irq(func);
-            if (err)
-            {
+	PSDIO_DATA psdio_data;
+	struct sdio_func *func;
+	int err;
+
+	if (dvobj->irq_alloc) {
+		psdio_data = &dvobj->intf_data;
+		func = psdio_data->func;
+
+		if (func) {
+			sdio_claim_host(func);
+			err = sdio_release_irq(func);
+			if (err) {
 				dvobj->drv_dbg.dbg_sdio_free_irq_error_cnt++;
-				DBG_871X_LEVEL(_drv_err_,"%s: sdio_release_irq FAIL(%d)!\n", __func__, err);
-            }
-            else
-            	dvobj->drv_dbg.dbg_sdio_free_irq_cnt++;
-            sdio_release_host(func);
-        }
-        dvobj->irq_alloc = 0;
-    }
+				RTW_ERR("%s: sdio_release_irq FAIL(%d)!\n", __func__, err);
+			} else
+				dvobj->drv_dbg.dbg_sdio_free_irq_cnt++;
+			sdio_release_host(func);
+		}
+		dvobj->irq_alloc = 0;
+	}
 }
 
 #ifdef CONFIG_GPIO_WAKEUP
@@ -183,10 +200,9 @@ extern unsigned int oob_gpio;
 static irqreturn_t gpio_hostwakeup_irq_thread(int irq, void *data)
 {
 	PADAPTER padapter = (PADAPTER)data;
-	DBG_871X_LEVEL(_drv_always_, "gpio_hostwakeup_irq_thread\n");
+	RTW_PRINT("gpio_hostwakeup_irq_thread\n");
 	/* Disable interrupt before calling handler */
-	//disable_irq_nosync(oob_irq);
-	rtw_lock_suspend_timeout(HZ/2);
+	/* disable_irq_nosync(oob_irq); */
 #ifdef CONFIG_PLATFORM_ARM_SUN6I
 	return 0;
 #else
@@ -200,11 +216,11 @@ static u8 gpio_hostwakeup_alloc_irq(PADAPTER padapter)
 	u32 status = 0;
 
 	if (oob_irq == 0) {
-		DBG_871X("oob_irq ZERO!\n");
+		RTW_INFO("oob_irq ZERO!\n");
 		return _FAIL;
 	}
 
-	DBG_871X("%s : oob_irq = %d\n", __func__, oob_irq);
+	RTW_INFO("%s : oob_irq = %d\n", __func__, oob_irq);
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
 	status = IRQF_NO_SUSPEND;
@@ -219,13 +235,12 @@ static u8 gpio_hostwakeup_alloc_irq(PADAPTER padapter)
 		status, "rtw_wifi_gpio_wakeup", padapter);
 
 	if (err < 0) {
-		DBG_871X("Oops: can't allocate gpio irq %d err:%d\n", oob_irq, err);
+		RTW_INFO("Oops: can't allocate gpio irq %d err:%d\n", oob_irq, err);
 		return _FALSE;
-	} else {
-		DBG_871X("allocate gpio irq %d ok\n", oob_irq);
-	}
-	
-#ifndef CONFIG_PLATFORM_ARM_SUN8I	
+	} else
+		RTW_INFO("allocate gpio irq %d ok\n", oob_irq);
+
+#ifndef CONFIG_PLATFORM_ARM_SUN8I
 	enable_irq_wake(oob_irq);
 #endif
 	return _SUCCESS;
@@ -237,7 +252,7 @@ static void gpio_hostwakeup_free_irq(PADAPTER padapter)
 
 	if (oob_irq == 0)
 		return;
-		
+
 #ifndef CONFIG_PLATFORM_ARM_SUN8I
 	disable_irq_wake(oob_irq);
 #endif
@@ -245,75 +260,147 @@ static void gpio_hostwakeup_free_irq(PADAPTER padapter)
 }
 #endif
 
-static u32 sdio_init(struct dvobj_priv *dvobj)
+void dump_sdio_card_info(void *sel, struct dvobj_priv *dvobj)
+{
+	PSDIO_DATA psdio_data = &dvobj->intf_data;
+
+	RTW_PRINT_SEL(sel, "== SDIO Card Info ==\n");
+	RTW_PRINT_SEL(sel, "  clock: %d Hz\n", psdio_data->clock);
+
+	RTW_PRINT_SEL(sel, "  timing spec: ");
+	switch (psdio_data->timing) {
+	case MMC_TIMING_LEGACY:
+		_RTW_PRINT_SEL(sel, "legacy");
+		break;
+	case MMC_TIMING_MMC_HS:
+		_RTW_PRINT_SEL(sel, "mmc high-speed");
+		break;
+	case MMC_TIMING_SD_HS:
+		_RTW_PRINT_SEL(sel, "sd high-speed");
+		break;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)
+	#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
+	case MMC_TIMING_UHS_SDR12:
+		_RTW_PRINT_SEL(sel, "sd uhs SDR12");
+		break;
+	case MMC_TIMING_UHS_SDR25:
+		_RTW_PRINT_SEL(sel, "sd uhs SDR25");
+		break;
+	#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0) */
+
+	case MMC_TIMING_UHS_SDR50:
+		_RTW_PRINT_SEL(sel, "sd uhs SDR50");
+		break;
+
+	#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0)
+	case MMC_TIMING_MMC_DDR52:
+		_RTW_PRINT_SEL(sel, "mmc DDR52");
+		break;
+	#endif
+
+	case MMC_TIMING_UHS_SDR104:
+		_RTW_PRINT_SEL(sel, "sd uhs SDR104");
+		break;
+	case MMC_TIMING_UHS_DDR50:
+		_RTW_PRINT_SEL(sel, "sd uhs DDR50");
+		break;
+
+	#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0)
+	case MMC_TIMING_MMC_HS200:
+		_RTW_PRINT_SEL(sel, "mmc HS200");
+		break;
+	#endif
+
+	#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0)
+	case MMC_TIMING_MMC_HS400:
+		_RTW_PRINT_SEL(sel, "mmc HS400");
+		break;
+	#endif
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0) */
+	default:
+		_RTW_PRINT_SEL(sel, "unknown(%d)", psdio_data->timing);
+		break;
+	}
+	_RTW_PRINT_SEL(sel, "\n");
+
+	RTW_PRINT_SEL(sel, "  sd3_bus_mode: %s\n", (psdio_data->sd3_bus_mode) ? "TRUE" : "FALSE");
+	RTW_PRINT_SEL(sel, "================\n");
+}
+
+#define SDIO_CARD_INFO_DUMP(dvobj)	dump_sdio_card_info(RTW_DBGDUMP, dvobj)
+
+u32 sdio_init(struct dvobj_priv *dvobj)
 {
 	PSDIO_DATA psdio_data;
 	struct sdio_func *func;
 	int err;
 
-_func_enter_;
 
 	psdio_data = &dvobj->intf_data;
 	func = psdio_data->func;
 
-	//3 1. init SDIO bus
+	/* 3 1. init SDIO bus */
 	sdio_claim_host(func);
 
 	err = sdio_enable_func(func);
 	if (err) {
 		dvobj->drv_dbg.dbg_sdio_init_error_cnt++;
-		DBG_8192C(KERN_CRIT "%s: sdio_enable_func FAIL(%d)!\n", __func__, err);
+		RTW_PRINT("%s: sdio_enable_func FAIL(%d)!\n", __func__, err);
 		goto release;
 	}
 
 	err = sdio_set_block_size(func, 512);
 	if (err) {
 		dvobj->drv_dbg.dbg_sdio_init_error_cnt++;
-		DBG_8192C(KERN_CRIT "%s: sdio_set_block_size FAIL(%d)!\n", __func__, err);
+		RTW_PRINT("%s: sdio_set_block_size FAIL(%d)!\n", __func__, err);
 		goto release;
 	}
 	psdio_data->block_transfer_len = 512;
 	psdio_data->tx_block_mode = 1;
 	psdio_data->rx_block_mode = 1;
 
+	psdio_data->timing = func->card->host->ios.timing;
+	psdio_data->clock = func->card->host->ios.clock;
+
+	psdio_data->sd3_bus_mode = _FALSE;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)
+	if (psdio_data->timing <= MMC_TIMING_UHS_DDR50
+		#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
+		&& psdio_data->timing >= MMC_TIMING_UHS_SDR12
+		#else
+		&& psdio_data->timing >= MMC_TIMING_UHS_SDR50
+		#endif
+	)
+		psdio_data->sd3_bus_mode = _TRUE;
+#endif
+	SDIO_CARD_INFO_DUMP(dvobj);
+
+
 release:
 	sdio_release_host(func);
 
 exit:
-_func_exit_;
 
-	if (err) return _FAIL;
+	if (err)
+		return _FAIL;
 	return _SUCCESS;
 }
 
-static void sdio_deinit(struct dvobj_priv *dvobj)
+void sdio_deinit(struct dvobj_priv *dvobj)
 {
 	struct sdio_func *func;
 	int err;
 
 
-	RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("+sdio_deinit\n"));
 
 	func = dvobj->intf_data.func;
 
 	if (func) {
 		sdio_claim_host(func);
 		err = sdio_disable_func(func);
-		if (err)
-		{
+		if (err) {
 			dvobj->drv_dbg.dbg_sdio_deinit_error_cnt++;
-			DBG_8192C(KERN_ERR "%s: sdio_disable_func(%d)\n", __func__, err);
-		}
-
-		if (dvobj->irq_alloc) {
-			err = sdio_release_irq(func);
-			if (err)
-			{
-				dvobj->drv_dbg.dbg_sdio_free_irq_error_cnt++;
-				DBG_8192C(KERN_ERR "%s: sdio_release_irq(%d)\n", __func__, err);
-			}
-			else
-				dvobj->drv_dbg.dbg_sdio_free_irq_cnt++;
+			RTW_ERR("%s: sdio_disable_func(%d)\n", __func__, err);
 		}
 
 		sdio_release_host(func);
@@ -327,7 +414,7 @@ static void rtw_decide_chip_type_by_device_id(struct dvobj_priv *dvobj, const st
 #if defined(CONFIG_RTL8188E)
 	if (dvobj->chip_type == RTL8188E) {
 		dvobj->HardwareType = HARDWARE_TYPE_RTL8188ES;
-		DBG_871X("CHIP TYPE: RTL8188E\n");
+		RTW_INFO("CHIP TYPE: RTL8188E\n");
 	}
 #endif
 
@@ -339,28 +426,56 @@ static void rtw_decide_chip_type_by_device_id(struct dvobj_priv *dvobj, const st
 #if defined(CONFIG_RTL8821A)
 	if (dvobj->chip_type == RTL8821) {
 		dvobj->HardwareType = HARDWARE_TYPE_RTL8821S;
-		DBG_871X("CHIP TYPE: RTL8821A\n");
+		RTW_INFO("CHIP TYPE: RTL8821A\n");
 	}
 #endif
 
 #if defined(CONFIG_RTL8192E)
 	if (dvobj->chip_type == RTL8192E) {
 		dvobj->HardwareType = HARDWARE_TYPE_RTL8192ES;
-		DBG_871X("CHIP TYPE: RTL8192E\n");
+		RTW_INFO("CHIP TYPE: RTL8192E\n");
 	}
 #endif
 
 #if defined(CONFIG_RTL8703B)
 	if (dvobj->chip_type == RTL8703B) {
 		dvobj->HardwareType = HARDWARE_TYPE_RTL8703BS;
-		DBG_871X("CHIP TYPE: RTL8703B\n");
+		RTW_INFO("CHIP TYPE: RTL8703B\n");
+	}
+#endif
+
+#if defined(CONFIG_RTL8723D)
+	if (dvobj->chip_type == RTL8723D) {
+		dvobj->HardwareType = HARDWARE_TYPE_RTL8723DS;
+		RTW_INFO("CHIP TYPE: RTL8723D\n");
 	}
 #endif
 
 #if defined(CONFIG_RTL8188F)
 	if (dvobj->chip_type == RTL8188F) {
 		dvobj->HardwareType = HARDWARE_TYPE_RTL8188FS;
-		DBG_871X("CHIP TYPE: RTL8188F\n");
+		RTW_INFO("CHIP TYPE: RTL8188F\n");
+	}
+#endif
+
+#if defined(CONFIG_RTL8188GTV)
+	if (dvobj->chip_type == RTL8188GTV) {
+		dvobj->HardwareType = HARDWARE_TYPE_RTL8188GTVS;
+		RTW_INFO("CHIP TYPE: RTL8188GTV\n");
+	}
+#endif
+
+#if defined(CONFIG_RTL8822B)
+	if (dvobj->chip_type == RTL8822B) {
+		dvobj->HardwareType = HARDWARE_TYPE_RTL8822BS;
+		RTW_INFO("CHIP TYPE: RTL8822B\n");
+	}
+#endif
+
+#if defined(CONFIG_RTL8821C)
+	if (dvobj->chip_type == RTL8821C) {
+		dvobj->HardwareType = HARDWARE_TYPE_RTL8821CS;
+		RTW_INFO("CHIP TYPE: RTL8821C\n");
 	}
 #endif
 }
@@ -370,11 +485,11 @@ static struct dvobj_priv *sdio_dvobj_init(struct sdio_func *func, const struct s
 	int status = _FAIL;
 	struct dvobj_priv *dvobj = NULL;
 	PSDIO_DATA psdio;
-_func_enter_;
 
-	if((dvobj = devobj_init()) == NULL) {
+	dvobj = devobj_init();
+	if (dvobj == NULL)
 		goto exit;
-	}
+	dvobj->intf_ops = &sdio_ops;
 
 	sdio_set_drvdata(func, dvobj);
 
@@ -382,7 +497,6 @@ _func_enter_;
 	psdio->func = func;
 
 	if (sdio_init(dvobj) != _SUCCESS) {
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("%s: initialize SDIO Failed!\n", __FUNCTION__));
 		goto free_dvobj;
 	}
 
@@ -395,35 +509,33 @@ _func_enter_;
 free_dvobj:
 	if (status != _SUCCESS && dvobj) {
 		sdio_set_drvdata(func, NULL);
-		
+
 		devobj_deinit(dvobj);
-		
+
 		dvobj = NULL;
 	}
 exit:
-_func_exit_;
 	return dvobj;
 }
 
 static void sdio_dvobj_deinit(struct sdio_func *func)
 {
 	struct dvobj_priv *dvobj = sdio_get_drvdata(func);
-_func_enter_;
 
 	sdio_set_drvdata(func, NULL);
 	if (dvobj) {
 		sdio_deinit(dvobj);
+		sdio_free_irq(dvobj);
 		devobj_deinit(dvobj);
 	}
 
-_func_exit_;
 	return;
 }
 
 u8 rtw_set_hal_ops(PADAPTER padapter)
 {
-	//alloc memory for HAL DATA
-	if(rtw_hal_data_init(padapter) == _FAIL)
+	/* alloc memory for HAL DATA */
+	if (rtw_hal_data_init(padapter) == _FAIL)
 		return _FAIL;
 
 #if defined(CONFIG_RTL8188E)
@@ -451,12 +563,34 @@ u8 rtw_set_hal_ops(PADAPTER padapter)
 		rtl8703bs_set_hal_ops(padapter);
 #endif
 
+#if defined(CONFIG_RTL8723D)
+	if (rtw_get_chip_type(padapter) == RTL8723D)
+		rtl8723ds_set_hal_ops(padapter);
+#endif
+
 #if defined(CONFIG_RTL8188F)
 	if (rtw_get_chip_type(padapter) == RTL8188F)
 		rtl8188fs_set_hal_ops(padapter);
 #endif
 
-	if( rtw_hal_ops_check(padapter) == _FAIL)
+#if defined(CONFIG_RTL8188GTV)
+	if (rtw_get_chip_type(padapter) == RTL8188GTV)
+		rtl8188gtvs_set_hal_ops(padapter);
+#endif
+
+#if defined(CONFIG_RTL8822B)
+	if (rtw_get_chip_type(padapter) == RTL8822B)
+		rtl8822bs_set_hal_ops(padapter);
+#endif
+
+#if defined(CONFIG_RTL8821C)
+	if (rtw_get_chip_type(padapter) == RTL8821C) {
+		if (rtl8821cs_set_hal_ops(padapter) == _FAIL)
+			return _FAIL;
+	}
+#endif
+
+	if (rtw_hal_ops_check(padapter) == _FAIL)
 		return _FAIL;
 
 	if (hal_spec_init(padapter) == _FAIL)
@@ -468,31 +602,31 @@ u8 rtw_set_hal_ops(PADAPTER padapter)
 static void sd_intf_start(PADAPTER padapter)
 {
 	if (padapter == NULL) {
-		DBG_8192C(KERN_ERR "%s: padapter is NULL!\n", __func__);
+		RTW_ERR("%s: padapter is NULL!\n", __func__);
 		return;
 	}
 
-	// hal dep
+	/* hal dep */
 	rtw_hal_enable_interrupt(padapter);
 }
 
 static void sd_intf_stop(PADAPTER padapter)
 {
 	if (padapter == NULL) {
-		DBG_8192C(KERN_ERR "%s: padapter is NULL!\n", __func__);
+		RTW_ERR("%s: padapter is NULL!\n", __func__);
 		return;
 	}
 
-	// hal dep
+	/* hal dep */
 	rtw_hal_disable_interrupt(padapter);
 }
 
 
 #ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
 PADAPTER g_test_adapter = NULL;
-#endif // RTW_SUPPORT_PLATFORM_SHUTDOWN
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 
-_adapter *rtw_sdio_if1_init(struct dvobj_priv *dvobj)
+_adapter *rtw_sdio_primary_adapter_init(struct dvobj_priv *dvobj)
 {
 	int status = _FAIL;
 	PADAPTER padapter = NULL;
@@ -506,7 +640,7 @@ _adapter *rtw_sdio_if1_init(struct dvobj_priv *dvobj)
 
 #ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
 	g_test_adapter = padapter;
-#endif // RTW_SUPPORT_PLATFORM_SHUTDOWN
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 	padapter->dvobj = dvobj;
 
 	rtw_set_drv_stopped(padapter);/*init*/
@@ -514,36 +648,26 @@ _adapter *rtw_sdio_if1_init(struct dvobj_priv *dvobj)
 	dvobj->padapters[dvobj->iface_nums++] = padapter;
 	padapter->iface_id = IFACE_ID0;
 
-#if defined(CONFIG_CONCURRENT_MODE)
-	//set adapter_type/iface type for primary padapter
+	/* set adapter_type/iface type for primary padapter */
 	padapter->isprimary = _TRUE;
-	padapter->adapter_type = PRIMARY_ADAPTER;	
-	#ifndef CONFIG_HWPORT_SWAP
-	padapter->iface_type = IFACE_PORT0;
-	#else
-	padapter->iface_type = IFACE_PORT1;
-	#endif
+	padapter->adapter_type = PRIMARY_ADAPTER;
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	padapter->hw_port = HW_PORT0;
+#else
+	padapter->hw_port = HW_PORT0;
 #endif
 
-	//3 3. init driver special setting, interface, OS and hardware relative
+	/* 3 3. init driver special setting, interface, OS and hardware relative */
 
-	//4 3.1 set hardware operation functions
-	if (rtw_set_hal_ops(padapter)== _FAIL)
+	/* 4 3.1 set hardware operation functions */
+	if (rtw_set_hal_ops(padapter) == _FAIL)
 		goto free_hal_data;
 
-	//3 5. initialize Chip version
+	/* 3 5. initialize Chip version */
 	padapter->intf_start = &sd_intf_start;
 	padapter->intf_stop = &sd_intf_stop;
 
-	padapter->intf_init = &sdio_init;
-	padapter->intf_deinit = &sdio_deinit;
-	padapter->intf_alloc_irq = &sdio_alloc_irq;
-	padapter->intf_free_irq = &sdio_free_irq;
-
-	if (rtw_init_io_priv(padapter, sdio_set_intf_ops) == _FAIL)
-	{
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_,
-			("rtw_drv_init: Can't init io_priv\n"));
+	if (rtw_init_io_priv(padapter, sdio_set_intf_ops) == _FAIL) {
 		goto free_hal_data;
 	}
 
@@ -553,36 +677,40 @@ _adapter *rtw_sdio_if1_init(struct dvobj_priv *dvobj)
 
 #ifdef CONFIG_BT_COEXIST
 	rtw_btcoex_Initialize(padapter);
-#endif // CONFIG_BT_COEXIST
+#endif
+	rtw_btcoex_wifionly_initialize(padapter);
 
-	//3 6. read efuse/eeprom data
-	rtw_hal_read_chip_info(padapter);
+	/* 3 6. read efuse/eeprom data */
+	if (rtw_hal_read_chip_info(padapter) == _FAIL)
+		goto free_hal_data;
 
-	//3 7. init driver common data
+	/* 3 7. init driver common data */
 	if (rtw_init_drv_sw(padapter) == _FAIL) {
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_,
-			 ("rtw_drv_init: Initialize driver software resource Failed!\n"));
 		goto free_hal_data;
 	}
 
-	//3 8. get WLan MAC address
-	// set mac addr
+	/* 3 8. get WLan MAC address */
+	/* set mac addr */
 	rtw_macaddr_cfg(adapter_mac_addr(padapter),  get_hal_mac_addr(padapter));
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	rtw_mbid_camid_alloc(padapter, adapter_mac_addr(padapter));
+#endif
 #ifdef CONFIG_P2P
 	rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
 #endif /* CONFIG_P2P */
 
 	rtw_hal_disable_interrupt(padapter);
 
-	DBG_871X("bDriverStopped:%s, bSurpriseRemoved:%s, bup:%d, hw_init_completed:%d\n"
-		, rtw_is_drv_stopped(padapter)?"True":"False"
-		, rtw_is_surprise_removed(padapter)?"True":"False"
+	RTW_INFO("bDriverStopped:%s, bSurpriseRemoved:%s, bup:%d, hw_init_completed:%d\n"
+		, rtw_is_drv_stopped(padapter) ? "True" : "False"
+		, rtw_is_surprise_removed(padapter) ? "True" : "False"
 		, padapter->bup
 		, rtw_get_hw_init_completed(padapter)
 	);
-	
+
 	status = _SUCCESS;
-	
+
 free_hal_data:
 	if (status != _SUCCESS && padapter->HalData)
 		rtw_hal_free_data(padapter);
@@ -596,54 +724,60 @@ exit:
 	return padapter;
 }
 
-static void rtw_sdio_if1_deinit(_adapter *if1)
+static void rtw_sdio_primary_adapter_deinit(_adapter *padapter)
 {
-	struct mlme_priv *pmlmepriv= &if1->mlmepriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
-	if(check_fwstate(pmlmepriv, _FW_LINKED))
-		rtw_disassoc_cmd(if1, 0, _FALSE);
+	if (check_fwstate(pmlmepriv, _FW_LINKED))
+		rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
 
 #ifdef CONFIG_AP_MODE
-	free_mlme_ap_info(if1);
-	#ifdef CONFIG_HOSTAPD_MLME
-	hostapd_mode_unload(if1);
-	#endif
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
+		free_mlme_ap_info(padapter);
+		#ifdef CONFIG_HOSTAPD_MLME
+		hostapd_mode_unload(padapter);
+		#endif
+	}
 #endif
 
 #ifdef CONFIG_GPIO_WAKEUP
-#ifdef CONFIG_PLATFORM_ARM_SUN6I 
-        sw_gpio_eint_set_enable(gpio_eint_wlan, 0);
-        sw_gpio_irq_free(eint_wlan_handle);
-#else  
-	gpio_hostwakeup_free_irq(if1);
+#ifdef CONFIG_PLATFORM_ARM_SUN6I
+	sw_gpio_eint_set_enable(gpio_eint_wlan, 0);
+	sw_gpio_irq_free(eint_wlan_handle);
+#else
+	gpio_hostwakeup_free_irq(padapter);
 #endif
 #endif
 
-	rtw_cancel_all_timer(if1);
+	/*rtw_cancel_all_timer(if1);*/
 
 #ifdef CONFIG_WOWLAN
-	adapter_to_pwrctl(if1)->wowlan_mode=_FALSE;
-	DBG_871X_LEVEL(_drv_always_, "%s wowlan_mode:%d\n", __func__, adapter_to_pwrctl(if1)->wowlan_mode);
-#endif //CONFIG_WOWLAN
+	adapter_to_pwrctl(padapter)->wowlan_mode = _FALSE;
+	RTW_PRINT("%s wowlan_mode:%d\n", __func__, adapter_to_pwrctl(padapter)->wowlan_mode);
+#endif /* CONFIG_WOWLAN */
 
-	rtw_dev_unload(if1);
-	DBG_871X("+r871xu_dev_remove, hw_init_completed=%d\n", rtw_get_hw_init_completed(if1));
+	rtw_dev_unload(padapter);
+	RTW_INFO("+r871xu_dev_remove, hw_init_completed=%d\n", rtw_get_hw_init_completed(padapter));
 
-	rtw_free_drv_sw(if1);
+	rtw_free_drv_sw(padapter);
 
 	/* TODO: use rtw_os_ndevs_deinit instead at the first stage of driver's dev deinit function */
-	rtw_os_ndev_free(if1);
+	rtw_os_ndev_free(padapter);
+
+#ifdef RTW_HALMAC
+	rtw_halmac_deinit_adapter(adapter_to_dvobj(padapter));
+#endif /* RTW_HALMAC */
 
-	rtw_vmfree((u8 *)if1, sizeof(_adapter));
+	rtw_vmfree((u8 *)padapter, sizeof(_adapter));
 
 #ifdef CONFIG_PLATFORM_RTD2880B
-	DBG_871X("wlan link down\n");
+	RTW_INFO("wlan link down\n");
 	rtd2885_wlan_netlink_sendMsg("linkdown", "8712");
 #endif
 
 #ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
 	g_test_adapter = NULL;
-#endif // RTW_SUPPORT_PLATFORM_SHUTDOWN
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 }
 
 /*
@@ -657,15 +791,18 @@ static int rtw_drv_init(
 	const struct sdio_device_id *id)
 {
 	int status = _FAIL;
+#ifdef CONFIG_CONCURRENT_MODE
+	int i;
+#endif
 	struct net_device *pnetdev;
-	PADAPTER if1 = NULL, if2 = NULL;
+	PADAPTER padapter = NULL;
 	struct dvobj_priv *dvobj;
 
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 
 #ifdef CONFIG_ACPI
-        acpi_handle handle;
-        struct acpi_device *adev;
+	acpi_handle handle;
+	struct acpi_device *adev;
 #endif
 
 #if defined(CONFIG_ACPI) && defined(CONFIG_GPIO_WAKEUP)
@@ -674,119 +811,118 @@ static int rtw_drv_init(
 	if (handle) {
 		/* Dont try to do acpi pm for the wifi module */
 		if (!handle || acpi_bus_get_device(handle, &adev))
-			DBG_871X("Could not get acpi pointer!\n");
+			RTW_INFO("Could not get acpi pointer!\n");
 		else {
 			adev->flags.power_manageable = 0;
-			DBG_871X("Disabling ACPI power management support!\n");
+			RTW_INFO("Disabling ACPI power management support!\n");
 		}
 		oob_gpio = acpi_get_gpio_by_index(&func->dev, 0, NULL);
-		DBG_871X("rtw_drv_init: ACPI_HANDLE found oob_gpio %d!\n", oob_gpio);
+		RTW_INFO("rtw_drv_init: ACPI_HANDLE found oob_gpio %d!\n", oob_gpio);
 		wifi_configure_gpio();
-	}
-	else
-		DBG_871X("rtw_drv_init: ACPI_HANDLE NOT found!\n");
+	} else
+		RTW_INFO("rtw_drv_init: ACPI_HANDLE NOT found!\n");
 #endif
 
 #if defined(CONFIG_ACPI)
 	if (&func->dev && ACPI_HANDLE(&func->dev)) {
 		wlan_en_gpio = acpi_get_gpio_by_index(&func->dev, 1, NULL);
-		DBG_871X("rtw_drv_init: ACPI_HANDLE found wlan_en %d!\n", wlan_en_gpio);
-	}
-	else
-		DBG_871X("rtw_drv_init: ACPI_HANDLE NOT found!\n");
+		RTW_INFO("rtw_drv_init: ACPI_HANDLE found wlan_en %d!\n", wlan_en_gpio);
+	} else
+		RTW_INFO("rtw_drv_init: ACPI_HANDLE NOT found!\n");
 #endif
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
 
 
-	RT_TRACE(_module_hci_intfs_c_, _drv_info_,
-		("+rtw_drv_init: vendor=0x%04x device=0x%04x class=0x%02x\n",
-		func->vendor, func->device, func->class));
 
-	if ((dvobj = sdio_dvobj_init(func, id)) == NULL) {
-		RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("initialize device object priv Failed!\n"));
+	dvobj = sdio_dvobj_init(func, id);
+	if (dvobj == NULL) {
 		goto exit;
 	}
 
-	if ((if1 = rtw_sdio_if1_init(dvobj)) == NULL) {
-		DBG_871X("rtw_init_primary_adapter Failed!\n");
+	padapter = rtw_sdio_primary_adapter_init(dvobj);
+	if (padapter == NULL) {
+		RTW_INFO("rtw_init_primary_adapter Failed!\n");
 		goto free_dvobj;
 	}
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if ((if2 = rtw_drv_if2_init(if1, sdio_set_intf_ops)) == NULL) {
-		goto free_if1;
+	if (padapter->registrypriv.virtual_iface_num > (CONFIG_IFACE_NUMBER - 1))
+		padapter->registrypriv.virtual_iface_num = (CONFIG_IFACE_NUMBER - 1);
+
+	for (i = 0; i < padapter->registrypriv.virtual_iface_num; i++) {
+		if (rtw_drv_add_vir_if(padapter, sdio_set_intf_ops) == NULL) {
+			RTW_INFO("rtw_drv_add_iface failed! (%d)\n", i);
+			goto free_if_vir;
+		}
 	}
 #endif
 
-	//dev_alloc_name && register_netdev
+	/* dev_alloc_name && register_netdev */
 	if (rtw_os_ndevs_init(dvobj) != _SUCCESS)
-		goto free_if2;
+		goto free_if_vir;
 
 #ifdef CONFIG_HOSTAPD_MLME
-	hostapd_mode_init(if1);
+	hostapd_mode_init(padapter);
 #endif
 
 #ifdef CONFIG_PLATFORM_RTD2880B
-	DBG_871X("wlan link up\n");
+	RTW_INFO("wlan link up\n");
 	rtd2885_wlan_netlink_sendMsg("linkup", "8712");
 #endif
 
 	if (sdio_alloc_irq(dvobj) != _SUCCESS)
 		goto os_ndevs_deinit;
 
-#ifdef	CONFIG_GPIO_WAKEUP
+#ifdef CONFIG_GPIO_WAKEUP
 #ifdef CONFIG_PLATFORM_ARM_SUN6I
-        eint_wlan_handle = sw_gpio_irq_request(gpio_eint_wlan, TRIG_EDGE_NEGATIVE,(peint_handle)gpio_hostwakeup_irq_thread, NULL);
-        if (!eint_wlan_handle) {
-               DBG_871X( "%s: request irq failed\n",__func__);
-               return -1;
-  }
+	eint_wlan_handle = sw_gpio_irq_request(gpio_eint_wlan, TRIG_EDGE_NEGATIVE, (peint_handle)gpio_hostwakeup_irq_thread, NULL);
+	if (!eint_wlan_handle) {
+		RTW_INFO("%s: request irq failed\n", __func__);
+		return -1;
+	}
 #else
-	gpio_hostwakeup_alloc_irq(if1);
+	gpio_hostwakeup_alloc_irq(padapter);
 #endif
 #endif
 
 #ifdef CONFIG_GLOBAL_UI_PID
-	if(ui_pid[1]!=0) {
-		DBG_871X("ui_pid[1]:%d\n",ui_pid[1]);
+	if (ui_pid[1] != 0) {
+		RTW_INFO("ui_pid[1]:%d\n", ui_pid[1]);
 		rtw_signal_process(ui_pid[1], SIGUSR2);
 	}
 #endif
 
-	RT_TRACE(_module_hci_intfs_c_,_drv_err_,("-871x_drv - drv_init, success!\n"));
 
 	status = _SUCCESS;
 
 os_ndevs_deinit:
 	if (status != _SUCCESS)
 		rtw_os_ndevs_deinit(dvobj);
-free_if2:
-	if(status != _SUCCESS && if2) {
+free_if_vir:
+	if (status != _SUCCESS) {
 		#ifdef CONFIG_CONCURRENT_MODE
-		rtw_drv_if2_stop(if2);
-		rtw_drv_if2_free(if2);
+		rtw_drv_stop_vir_ifaces(dvobj);
+		rtw_drv_free_vir_ifaces(dvobj);
 		#endif
 	}
-free_if1:
-	if (status != _SUCCESS && if1) {
-		rtw_sdio_if1_deinit(if1);
-	}
+
+	if (status != _SUCCESS && padapter)
+		rtw_sdio_primary_adapter_deinit(padapter);
+
 free_dvobj:
 	if (status != _SUCCESS)
 		sdio_dvobj_deinit(func);
 exit:
-	return status == _SUCCESS?0:-ENODEV;
+	return status == _SUCCESS ? 0 : -ENODEV;
 }
 
 static void rtw_dev_remove(struct sdio_func *func)
 {
 	struct dvobj_priv *dvobj = sdio_get_drvdata(func);
 	struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(dvobj);
-	PADAPTER padapter = dvobj->padapters[IFACE_ID0];
+	PADAPTER padapter = dvobj_get_primary_adapter(dvobj);
 
-_func_enter_;
 
-	RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("+rtw_dev_remove\n"));
 
 	dvobj->processing_dev_remove = _TRUE;
 
@@ -802,7 +938,7 @@ _func_enter_;
 		sdio_release_host(func);
 		if (err == -ENOMEDIUM) {
 			rtw_set_surprise_removed(padapter);
-			DBG_871X(KERN_NOTICE "%s: device had been removed!\n", __func__);
+			RTW_INFO("%s: device had been removed!\n", __func__);
 		}
 	}
 
@@ -810,43 +946,42 @@ _func_enter_;
 	rtw_unregister_early_suspend(pwrctl);
 #endif
 
-	if (padapter->bFWReady == _TRUE) {
+	if (GET_HAL_DATA(padapter)->bFWReady == _TRUE) {
 		rtw_ps_deny(padapter, PS_DENY_DRV_REMOVE);
 		rtw_pm_set_ips(padapter, IPS_NONE);
 		rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
 		LeaveAllPowerSaveMode(padapter);
 	}
 	rtw_set_drv_stopped(padapter);	/*for stop thread*/
+	rtw_stop_cmd_thread(padapter);
 #ifdef CONFIG_CONCURRENT_MODE
-	rtw_drv_if2_stop(dvobj->padapters[IFACE_ID1]);
+	rtw_drv_stop_vir_ifaces(dvobj);
 #endif
 
 #ifdef CONFIG_BT_COEXIST
-	#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	if (GET_HAL_DATA(padapter)->EEPROMBluetoothCoexist)
 		rtw_btcoex_close_socket(padapter);
-	#endif
+#endif
 	rtw_btcoex_HaltNotify(padapter);
 #endif
 
-	rtw_sdio_if1_deinit(padapter);
+	rtw_sdio_primary_adapter_deinit(padapter);
 
 #ifdef CONFIG_CONCURRENT_MODE
-	rtw_drv_if2_free(dvobj->padapters[IFACE_ID1]);
+	rtw_drv_free_vir_ifaces(dvobj);
 #endif
 
 	sdio_dvobj_deinit(func);
 
-	RT_TRACE(_module_hci_intfs_c_, _drv_notice_, ("-rtw_dev_remove\n"));
 
-_func_exit_;
 }
-extern int pm_netdev_open(struct net_device *pnetdev,u8 bnormal);
-extern int pm_netdev_close(struct net_device *pnetdev,u8 bnormal);
+extern int pm_netdev_open(struct net_device *pnetdev, u8 bnormal);
+extern int pm_netdev_close(struct net_device *pnetdev, u8 bnormal);
 
 static int rtw_sdio_suspend(struct device *dev)
 {
-	struct sdio_func *func =dev_to_sdio_func(dev);
+	struct sdio_func *func = dev_to_sdio_func(dev);
 	struct dvobj_priv *psdpriv = sdio_get_drvdata(func);
 	struct pwrctrl_priv *pwrpriv = NULL;
 	_adapter *padapter = NULL;
@@ -858,45 +993,44 @@ static int rtw_sdio_suspend(struct device *dev)
 		goto exit;
 
 	pwrpriv = dvobj_to_pwrctl(psdpriv);
-	padapter = psdpriv->padapters[IFACE_ID0];
+	padapter = dvobj_get_primary_adapter(psdpriv);
 	pdbgpriv = &psdpriv->drv_dbg;
 	if (rtw_is_drv_stopped(padapter)) {
-		DBG_871X("%s bDriverStopped == _TRUE\n", __func__);
+		RTW_INFO("%s bDriverStopped == _TRUE\n", __func__);
 		goto exit;
 	}
 
-	if (pwrpriv->bInSuspend == _TRUE)
-	{
-		DBG_871X("%s bInSuspend = %d\n", __func__, pwrpriv->bInSuspend);
+	if (pwrpriv->bInSuspend == _TRUE) {
+		RTW_INFO("%s bInSuspend = %d\n", __func__, pwrpriv->bInSuspend);
 		pdbgpriv->dbg_suspend_error_cnt++;
 		goto exit;
 	}
 
-	ret = rtw_suspend_common(padapter);		
+	ret = rtw_suspend_common(padapter);
 
 exit:
-#ifdef CONFIG_RTW_SDIO_PM_KEEP_POWER 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,34))
-	//Android 4.0 don't support WIFI close power
-	//or power down or clock will close after wifi resume,
-	//this is sprd's bug in Android 4.0, but sprd don't
-	//want to fix it.
-	//we have test power under 8723as, power consumption is ok
+#ifdef CONFIG_RTW_SDIO_PM_KEEP_POWER
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34))
+	/* Android 4.0 don't support WIFI close power */
+	/* or power down or clock will close after wifi resume, */
+	/* this is sprd's bug in Android 4.0, but sprd don't */
+	/* want to fix it. */
+	/* we have test power under 8723as, power consumption is ok */
 	if (func) {
 		mmc_pm_flag_t pm_flag = 0;
 		pm_flag = sdio_get_host_pm_caps(func);
-		DBG_871X("cmd: %s: suspend: PM flag = 0x%x\n", sdio_func_id(func), pm_flag);
+		RTW_INFO("cmd: %s: suspend: PM flag = 0x%x\n", sdio_func_id(func), pm_flag);
 		if (!(pm_flag & MMC_PM_KEEP_POWER)) {
-			DBG_871X("%s: cannot remain alive while host is suspended\n", sdio_func_id(func));
+			RTW_INFO("%s: cannot remain alive while host is suspended\n", sdio_func_id(func));
 			if (pdbgpriv)
 				pdbgpriv->dbg_suspend_error_cnt++;
 			return -ENOSYS;
 		} else {
-			DBG_871X("cmd: suspend with MMC_PM_KEEP_POWER\n");
+			RTW_INFO("cmd: suspend with MMC_PM_KEEP_POWER\n");
 			sdio_set_host_pm_flags(func, MMC_PM_KEEP_POWER);
 		}
 	}
-#endif	
+#endif
 #endif
 	return ret;
 }
@@ -905,68 +1039,55 @@ int rtw_resume_process(_adapter *padapter)
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
-		
-	if (pwrpriv->bInSuspend == _FALSE)
-	{
+
+	if (pwrpriv->bInSuspend == _FALSE) {
 		pdbgpriv->dbg_resume_error_cnt++;
-		DBG_871X("%s bInSuspend = %d\n", __FUNCTION__, pwrpriv->bInSuspend);
+		RTW_INFO("%s bInSuspend = %d\n", __FUNCTION__, pwrpriv->bInSuspend);
 		return -1;
 	}
-	
+
 	return rtw_resume_common(padapter);
 }
 
 static int rtw_sdio_resume(struct device *dev)
 {
-	struct sdio_func *func =dev_to_sdio_func(dev);
+	struct sdio_func *func = dev_to_sdio_func(dev);
 	struct dvobj_priv *psdpriv = sdio_get_drvdata(func);
 	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(psdpriv);
-	_adapter *padapter = psdpriv->padapters[IFACE_ID0];
+	_adapter *padapter = dvobj_get_primary_adapter(psdpriv);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	int ret = 0;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 
-	DBG_871X("==> %s (%s:%d)\n",__FUNCTION__, current->comm, current->pid);
+	RTW_INFO("==> %s (%s:%d)\n", __FUNCTION__, current->comm, current->pid);
 
 	pdbgpriv->dbg_resume_cnt++;
 
-	if(pwrpriv->bInternalAutoSuspend)
-	{
- 		ret = rtw_resume_process(padapter);
-	}
-	else
-	{
 #ifdef CONFIG_PLATFORM_INTEL_BYT
-		if(0)
+	if (0)
 #else
-		if(pwrpriv->wowlan_mode || pwrpriv->wowlan_ap_mode)
+	if (pwrpriv->wowlan_mode || pwrpriv->wowlan_ap_mode)
 #endif
-		{
-			rtw_resume_lock_suspend();			
+	{
+		rtw_resume_lock_suspend();
+		ret = rtw_resume_process(padapter);
+		rtw_resume_unlock_suspend();
+	} else {
+#ifdef CONFIG_RESUME_IN_WORKQUEUE
+		rtw_resume_in_workqueue(pwrpriv);
+#else
+		if (rtw_is_earlysuspend_registered(pwrpriv)) {
+			/* jeff: bypass resume here, do in late_resume */
+			rtw_set_do_late_resume(pwrpriv, _TRUE);
+		} else {
+			rtw_resume_lock_suspend();
 			ret = rtw_resume_process(padapter);
 			rtw_resume_unlock_suspend();
 		}
-		else
-		{
-#ifdef CONFIG_RESUME_IN_WORKQUEUE
-			rtw_resume_in_workqueue(pwrpriv);
-#else			
-			if (rtw_is_earlysuspend_registered(pwrpriv))
-			{
-				/* jeff: bypass resume here, do in late_resume */
-				rtw_set_do_late_resume(pwrpriv, _TRUE);
-			}	
-			else
-			{
-				rtw_resume_lock_suspend();			
-				ret = rtw_resume_process(padapter);
-				rtw_resume_unlock_suspend();
-			}
 #endif
-		}
 	}
 	pmlmeext->last_scan_time = rtw_get_current_time();
-	DBG_871X("<========  %s return %d\n", __FUNCTION__, ret);
+	RTW_INFO("<========  %s return %d\n", __FUNCTION__, ret);
 	return ret;
 
 }
@@ -975,16 +1096,19 @@ static int rtw_drv_entry(void)
 {
 	int ret = 0;
 
-	DBG_871X_LEVEL(_drv_always_, "module init start\n");
+	RTW_PRINT("module init start\n");
 	dump_drv_version(RTW_DBGDUMP);
 #ifdef BTCOEXVERSION
-	DBG_871X_LEVEL(_drv_always_, DRV_NAME" BT-Coex version = %s\n", BTCOEXVERSION);
-#endif // BTCOEXVERSION
+	RTW_PRINT(DRV_NAME" BT-Coex version = %s\n", BTCOEXVERSION);
+#endif /* BTCOEXVERSION */
+
+#ifndef CONFIG_PLATFORM_INTEL_BYT
+	rtw_android_wifictrl_func_add();
+#endif /* !CONFIG_PLATFORM_INTEL_BYT */
 
 	ret = platform_wifi_power_on();
-	if (ret)
-	{
-		DBG_871X("%s: power on failed!!(%d)\n", __FUNCTION__, ret);
+	if (ret) {
+		RTW_INFO("%s: power on failed!!(%d)\n", __FUNCTION__, ret);
 		ret = -1;
 		goto exit;
 	}
@@ -993,34 +1117,32 @@ static int rtw_drv_entry(void)
 	rtw_suspend_lock_init();
 	rtw_drv_proc_init();
 	rtw_ndev_notifier_register();
+	rtw_inetaddr_notifier_register();
 
 	ret = sdio_register_driver(&sdio_drvpriv.r871xs_drv);
-	if (ret != 0)
-	{
+	if (ret != 0) {
 		sdio_drvpriv.drv_registered = _FALSE;
 		rtw_suspend_lock_uninit();
 		rtw_drv_proc_deinit();
 		rtw_ndev_notifier_unregister();
-		DBG_871X("%s: register driver failed!!(%d)\n", __FUNCTION__, ret);
+		rtw_inetaddr_notifier_unregister();
+		RTW_INFO("%s: register driver failed!!(%d)\n", __FUNCTION__, ret);
 		goto poweroff;
 	}
 
-#ifndef CONFIG_PLATFORM_INTEL_BYT
-	rtw_android_wifictrl_func_add();
-#endif //!CONFIG_PLATFORM_INTEL_BYT
 	goto exit;
 
 poweroff:
 	platform_wifi_power_off();
 
 exit:
-	DBG_871X_LEVEL(_drv_always_, "module init ret=%d\n", ret);
+	RTW_PRINT("module init ret=%d\n", ret);
 	return ret;
 }
 
 static void rtw_drv_halt(void)
 {
-	DBG_871X_LEVEL(_drv_always_, "module exit start\n");
+	RTW_PRINT("module exit start\n");
 
 	sdio_drvpriv.drv_registered = _FALSE;
 
@@ -1033,8 +1155,9 @@ static void rtw_drv_halt(void)
 	rtw_suspend_lock_uninit();
 	rtw_drv_proc_deinit();
 	rtw_ndev_notifier_unregister();
+	rtw_inetaddr_notifier_unregister();
 
-	DBG_871X_LEVEL(_drv_always_, "module exit success\n");
+	RTW_PRINT("module exit success\n");
 
 	rtw_mstat_dump(RTW_DBGDUMP);
 }
@@ -1043,16 +1166,19 @@ static void rtw_drv_halt(void)
 int rtw_sdio_set_power(int on)
 {
 
-	if(wlan_en_gpio >= 0){
-		if(on)
-			gpio_set_value(wlan_en_gpio,1);
+	if (wlan_en_gpio >= 0) {
+		if (on)
+			gpio_set_value(wlan_en_gpio, 1);
 		else
-			gpio_set_value(wlan_en_gpio,0);
+			gpio_set_value(wlan_en_gpio, 0);
 	}
 
 	return 0;
 }
-#endif //CONFIG_PLATFORM_INTEL_BYT
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+
+//module_init(rtw_drv_entry);
+//module_exit(rtw_drv_halt);
 
 #include "rtw_version.h"
 #include <linux/rfkill-wlan.h>
@@ -1070,10 +1196,10 @@ int rockchip_wifi_init_module_rtkwifi(void)
     printk("=======================================================\n");
     printk("==== Launching Wi-Fi driver! (Powered by Rockchip) ====\n");
     printk("=======================================================\n");
-    printk("Realtek 8189FS SDIO WiFi driver (Powered by Rockchip,Ver %s) init.\n", DRIVERVERSION);
+    printk("Realtek 8723DS SDIO WiFi driver (Powered by Rockchip,Ver %s) init.\n", DRIVERVERSION);
 
     rockchip_wifi_power(1);
-    rockchip_wifi_set_carddetect(1);    
+    rockchip_wifi_set_carddetect(1);
 
     return rtw_drv_entry();
 }
@@ -1088,7 +1214,7 @@ void rockchip_wifi_exit_module_rtkwifi(void)
     printk("=======================================================\n");
     printk("==== Dislaunching Wi-Fi driver! (Powered by Rockchip) ====\n");
     printk("=======================================================\n");
-    printk("Realtek 8189FS SDIO WiFi driver (Powered by Rockchip,Ver %s) init.\n", DRIVERVERSION);
+    printk("Realtek 8723DS SDIO WiFi driver (Powered by Rockchip,Ver %s) init.\n", DRIVERVERSION);
 
     rtw_drv_halt();
 
@@ -1108,6 +1234,3 @@ EXPORT_SYMBOL(rockchip_wifi_init_module_rtkwifi);
 EXPORT_SYMBOL(rockchip_wifi_exit_module_rtkwifi);
 #endif
 #endif
-//module_init(rtw_drv_entry);
-//module_exit(rtw_drv_halt);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_ops_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_ops_linux.c
index 0ea81f150e15..465cb1f440c3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_ops_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/sdio_ops_linux.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,15 +12,19 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *******************************************************************************/
+ *****************************************************************************/
 #define _SDIO_OPS_LINUX_C_
 
 #include <drv_types.h>
 
+inline bool rtw_is_sdio30(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	PSDIO_DATA psdio_data = &dvobj->intf_data;
+
+	return (psdio_data->sd3_bus_mode) ? _TRUE : _FALSE;
+}
+
 static bool rtw_sdio_claim_host_needed(struct sdio_func *func)
 {
 	struct dvobj_priv *dvobj = sdio_get_drvdata(func);
@@ -36,28 +41,27 @@ inline void rtw_sdio_set_irq_thd(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl)
 
 	sdio_data->sys_sdio_irq_thd = thd_hdl;
 }
-
-u8 sd_f0_read8(struct intf_hdl *pintfhdl,u32 addr, s32 *err)
+#ifndef RTW_HALMAC
+u8 sd_f0_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err)
 {
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	u8 v=0;
+
+	u8 v = 0;
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return v;
-	}	
-	
+	}
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -67,9 +71,8 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 	if (err && *err)
-		DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
+		RTW_ERR("%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
 
-_func_exit_;
 
 	return v;
 }
@@ -79,20 +82,19 @@ void sd_f0_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
+
 	struct sdio_func *func;
 	bool claim_needed;
-	
-_func_enter_;
+
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return;
-	}	
-	
+	}
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -102,9 +104,8 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 	if (err && *err)
-		DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, *err, addr, v);
+		RTW_ERR("%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, *err, addr, v);
 
-_func_exit_;
 }
 
 /*
@@ -118,30 +119,28 @@ s32 _sd_cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
 
-	int err=0, i;
+	int err = 0, i;
 	struct sdio_func *func;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
 	}
-	
+
 	func = psdio->func;
 
 	for (i = 0; i < cnt; i++) {
-		pdata[i] = sdio_readb(func, addr+i, &err);
+		pdata[i] = sdio_readb(func, addr + i, &err);
 		if (err) {
-			DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x\n", __func__, err, addr+i);
+			RTW_ERR("%s: FAIL!(%d) addr=0x%05x\n", __func__, err, addr + i);
 			break;
 		}
 	}
 
-_func_exit_;
 
 	return err;
 }
@@ -156,21 +155,20 @@ s32 sd_cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	int err=0, i;
+
+	int err = 0, i;
 	struct sdio_func *func;
-	bool claim_needed;	
+	bool claim_needed;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
-	}	
-	
+	}
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -180,7 +178,6 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 
-_func_exit_;
 
 	return err;
 }
@@ -195,31 +192,29 @@ s32 _sd_cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	int err=0, i;
+
+	int err = 0, i;
 	struct sdio_func *func;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
 	}
-	
+
 	func = psdio->func;
 
 	for (i = 0; i < cnt; i++) {
-		sdio_writeb(func, pdata[i], addr+i, &err);
+		sdio_writeb(func, pdata[i], addr + i, &err);
 		if (err) {
-			DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, err, addr+i, pdata[i]);
+			RTW_ERR("%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, err, addr + i, pdata[i]);
 			break;
 		}
 	}
 
-_func_exit_;
 
 	return err;
 }
@@ -234,21 +229,20 @@ s32 sd_cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	int err=0, i;
+
+	int err = 0, i;
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
 	}
-	
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -258,7 +252,6 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 
-_func_exit_;
 
 	return err;
 }
@@ -269,27 +262,25 @@ u8 _sd_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err)
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
 
-	u8 v=0;
+	u8 v = 0;
 	struct sdio_func *func;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return v;
 	}
-	
+
 	func = psdio->func;
 
 	v = sdio_readb(func, addr, err);
 
 	if (err && *err)
-		DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
+		RTW_ERR("%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
 
-_func_exit_;
 
 	return v;
 }
@@ -299,21 +290,20 @@ u8 sd_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	u8 v=0;
+
+	u8 v = 0;
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return v;
 	}
-	
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -323,9 +313,8 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 	if (err && *err)
-		DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
+		RTW_ERR("%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
 
-_func_exit_;
 
 	return v;
 }
@@ -335,21 +324,20 @@ u16 sd_read16(struct intf_hdl *pintfhdl, u32 addr, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	u16 v=0;
+
+	u16 v = 0;
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return v;
 	}
-		
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -359,9 +347,8 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 	if (err && *err)
-		DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
+		RTW_ERR("%s: FAIL!(%d) addr=0x%05x\n", __func__, *err, addr);
 
-_func_exit_;
 
 	return  v;
 }
@@ -371,63 +358,56 @@ u32 _sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	u32 v=0;
+
+	u32 v = 0;
 	struct sdio_func *func;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return v;
 	}
-		
+
 	func = psdio->func;
 
 	v = sdio_readl(func, addr, err);
 
-	if (err && *err)
-	{
+	if (err && *err) {
 		int i;
 
-		DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x\n", __func__, *err, addr, v);
+		RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x\n", __func__, *err, addr, v);
 
 		*err = 0;
-		for(i=0; i<SD_IO_TRY_CNT; i++)
-		{
-			//sdio_claim_host(func);
+		for (i = 0; i < SD_IO_TRY_CNT; i++) {
+			/* sdio_claim_host(func); */
 			v = sdio_readl(func, addr, err);
-			//sdio_release_host(func);
-			if (*err == 0){
+			/* sdio_release_host(func); */
+			if (*err == 0) {
 				rtw_reset_continual_io_error(psdiodev);
 				break;
-			}
-			else{
-				DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
-				if(( -ESHUTDOWN == *err ) || ( -ENODEV == *err))
-				{			
+			} else {
+				RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+				if ((-ESHUTDOWN == *err) || (-ENODEV == *err))
 					rtw_set_surprise_removed(padapter);
-				}
 
-				if(rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE ){
+				if (rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE) {
 					rtw_set_surprise_removed(padapter);
 					break;
-				}						
-					
+				}
+
 			}
 		}
 
-		if (i==SD_IO_TRY_CNT)
-			DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+		if (i == SD_IO_TRY_CNT)
+			RTW_ERR("%s: FAIL!(%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
 		else
-			DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+			RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
 
 	}
 
-_func_exit_;
 
 	return  v;
 }
@@ -437,21 +417,20 @@ u32 sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	u32 v=0;
+
+	u32 v = 0;
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return v;
 	}
-	
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -461,43 +440,41 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 
-	if (err && *err)
-	{
+	if (err && *err) {
 		int i;
 
-		DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x\n", __func__, *err, addr, v);
+		RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x\n", __func__, *err, addr, v);
 
 		*err = 0;
-		for(i=0; i<SD_IO_TRY_CNT; i++)
-		{
-			if (claim_needed) sdio_claim_host(func);
+		for (i = 0; i < SD_IO_TRY_CNT; i++) {
+			if (claim_needed)
+				sdio_claim_host(func);
 			v = sdio_readl(func, addr, err);
-			if (claim_needed) sdio_release_host(func);
-			
-			if (*err == 0){
+			if (claim_needed)
+				sdio_release_host(func);
+
+			if (*err == 0) {
 				rtw_reset_continual_io_error(psdiodev);
 				break;
-			}else{				
-				DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
-				if(( -ESHUTDOWN == *err ) || ( -ENODEV == *err)){			
+			} else {
+				RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+				if ((-ESHUTDOWN == *err) || (-ENODEV == *err))
 					rtw_set_surprise_removed(padapter);
-				}
 
-				if(rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE ){
+				if (rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE) {
 					rtw_set_surprise_removed(padapter);
 					break;
 				}
 			}
 		}
 
-		if (i==SD_IO_TRY_CNT)
-			DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+		if (i == SD_IO_TRY_CNT)
+			RTW_ERR("%s: FAIL!(%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
 		else
-			DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+			RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
 
 	}
 
-_func_exit_;
 
 	return  v;
 }
@@ -507,21 +484,20 @@ void sd_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
+
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return ;
 	}
-	
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -531,9 +507,8 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 	if (err && *err)
-		DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, *err, addr, v);
+		RTW_ERR("%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, *err, addr, v);
 
-_func_exit_;
 }
 
 void sd_write16(struct intf_hdl *pintfhdl, u32 addr, u16 v, s32 *err)
@@ -541,20 +516,19 @@ void sd_write16(struct intf_hdl *pintfhdl, u32 addr, u16 v, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
+
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return ;
 	}
-	
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -564,9 +538,8 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 	if (err && *err)
-		DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x val=0x%04x\n", __func__, *err, addr, v);
+		RTW_ERR("%s: FAIL!(%d) addr=0x%05x val=0x%04x\n", __func__, *err, addr, v);
 
-_func_exit_;
 }
 
 void _sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err)
@@ -574,57 +547,52 @@ void _sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
+
 	struct sdio_func *func;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return ;
 	}
-	
+
 	func = psdio->func;
 
 	sdio_writel(func, v, addr, err);
 
-	if (err && *err)
-	{
+	if (err && *err) {
 		int i;
 
-		DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x val=0x%08x\n", __func__, *err, addr, v);
+		RTW_ERR("%s: (%d) addr=0x%05x val=0x%08x\n", __func__, *err, addr, v);
 
 		*err = 0;
-		for(i=0; i<SD_IO_TRY_CNT; i++)
-		{
+		for (i = 0; i < SD_IO_TRY_CNT; i++) {
 			sdio_writel(func, v, addr, err);
-			if (*err == 0){
+			if (*err == 0) {
 				rtw_reset_continual_io_error(psdiodev);
 				break;
-			}else{				
-				DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
-				if(( -ESHUTDOWN == *err ) || ( -ENODEV == *err)){			
+			} else {
+				RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+				if ((-ESHUTDOWN == *err) || (-ENODEV == *err))
 					rtw_set_surprise_removed(padapter);
-				}
 
-				if(rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE ){
+				if (rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE) {
 					rtw_set_surprise_removed(padapter);
 					break;
 				}
 			}
 		}
 
-		if (i==SD_IO_TRY_CNT)
-			DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
+		if (i == SD_IO_TRY_CNT)
+			RTW_ERR("%s: FAIL!(%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
 		else
-			DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
+			RTW_ERR("%s: (%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
 
 	}
 
-_func_exit_;
 }
 
 void sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err)
@@ -635,16 +603,15 @@ void sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err)
 	struct sdio_func *func;
 	bool claim_needed;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
 
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return ;
 	}
-	
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -654,42 +621,41 @@ _func_enter_;
 	if (claim_needed)
 		sdio_release_host(func);
 
-	if (err && *err)
-	{
+	if (err && *err) {
 		int i;
 
-		DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x val=0x%08x\n", __func__, *err, addr, v);
+		RTW_ERR("%s: (%d) addr=0x%05x val=0x%08x\n", __func__, *err, addr, v);
 
 		*err = 0;
-		for(i=0; i<SD_IO_TRY_CNT; i++)
-		{
-			if (claim_needed) sdio_claim_host(func);
+		for (i = 0; i < SD_IO_TRY_CNT; i++) {
+			if (claim_needed)
+				sdio_claim_host(func);
 			sdio_writel(func, v, addr, err);
-			if (claim_needed) sdio_release_host(func);
-			if (*err == 0){
+			if (claim_needed)
+				sdio_release_host(func);
+			if (*err == 0) {
 				rtw_reset_continual_io_error(psdiodev);
 				break;
-			}else{				
-				DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
-				if(( -ESHUTDOWN == *err ) || ( -ENODEV == *err)){			
+			} else {
+				RTW_ERR("%s: (%d) addr=0x%05x, val=0x%x, try_cnt=%d\n", __func__, *err, addr, v, i);
+				if ((-ESHUTDOWN == *err) || (-ENODEV == *err))
 					rtw_set_surprise_removed(padapter);
-				}
 
-				if(rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE ){
+				if (rtw_inc_and_chk_continual_io_error(psdiodev) == _TRUE) {
 					rtw_set_surprise_removed(padapter);
 					break;
 				}
 			}
 		}
 
-		if (i==SD_IO_TRY_CNT)
-			DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
+		if (i == SD_IO_TRY_CNT)
+			RTW_ERR("%s: FAIL!(%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
 		else
-			DBG_871X(KERN_ERR "%s: (%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
+			RTW_ERR("%s: (%d) addr=0x%05x val=0x%08x, try_cnt=%d\n", __func__, *err, addr, v, i);
 	}
 
-_func_exit_;
 }
+#endif /* !RTW_HALMAC */
 
 /*
  * Use CMD53 to read data from SDIO device.
@@ -711,33 +677,30 @@ s32 _sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
-	int err= -EPERM;
+
+	int err = -EPERM;
 	struct sdio_func *func;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
-	
+
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
 	}
-		
+
 	func = psdio->func;
 
-	if (unlikely((cnt==1) || (cnt==2)))
-	{
+	if (unlikely((cnt == 1) || (cnt == 2))) {
 		int i;
-		u8 *pbuf = (u8*)pdata;
+		u8 *pbuf = (u8 *)pdata;
 
-		for (i = 0; i < cnt; i++)
-		{
-			*(pbuf+i) = sdio_readb(func, addr+i, &err);
+		for (i = 0; i < cnt; i++) {
+			*(pbuf + i) = sdio_readb(func, addr + i, &err);
 
 			if (err) {
-				DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x\n", __func__, err, addr);
+				RTW_ERR("%s: FAIL!(%d) addr=0x%05x\n", __func__, err, addr);
 				break;
 			}
 		}
@@ -745,11 +708,12 @@ _func_enter_;
 	}
 
 	err = sdio_memcpy_fromio(func, pdata, addr, cnt);
-	if (err) {
-		DBG_871X(KERN_ERR "%s: FAIL(%d)! ADDR=%#x Size=%d\n", __func__, err, addr, cnt);
-	}
+	if (err)
+		RTW_ERR("%s: FAIL(%d)! ADDR=%#x Size=%d\n", __func__, err, addr, cnt);
+
+	if (err == (-ESHUTDOWN) || err == (-ENODEV) || err == (-ENOMEDIUM) || err == (-ETIMEDOUT))
+		rtw_set_surprise_removed(padapter);
 
-_func_exit_;
 
 	return err;
 }
@@ -767,23 +731,22 @@ _func_exit_;
  *	0		Success
  *	others	Fail
  */
-s32 sd_read(struct intf_hdl * pintfhdl, u32 addr, u32 cnt, void *pdata)
+s32 sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)
 {
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
-	PSDIO_DATA psdio;	
-	
+	PSDIO_DATA psdio;
+
 	struct sdio_func *func;
 	bool claim_needed;
-	s32 err= -EPERM;
-	
-_func_enter_;
+	s32 err = -EPERM;
+
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
-	
+
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
 	}
 	func = psdio->func;
@@ -794,7 +757,6 @@ _func_enter_;
 	err = _sd_read(pintfhdl, addr, cnt, pdata);
 	if (claim_needed)
 		sdio_release_host(func);
-_func_exit_;
 	return err;
 }
 
@@ -818,34 +780,31 @@ s32 _sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)
 	PADAPTER padapter;
 	struct dvobj_priv *psdiodev;
 	PSDIO_DATA psdio;
-	
+
 	struct sdio_func *func;
 	u32 size;
-	s32 err=-EPERM;
+	s32 err = -EPERM;
 
-_func_enter_;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
-	
+
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
 	}
-	
+
 	func = psdio->func;
-//	size = sdio_align_size(func, cnt);
+	/*	size = sdio_align_size(func, cnt); */
 
-	if (unlikely((cnt==1) || (cnt==2)))
-	{
+	if (unlikely((cnt == 1) || (cnt == 2))) {
 		int i;
-		u8 *pbuf = (u8*)pdata;
+		u8 *pbuf = (u8 *)pdata;
 
-		for (i = 0; i < cnt; i++)
-		{
-			sdio_writeb(func, *(pbuf+i), addr+i, &err);
+		for (i = 0; i < cnt; i++) {
+			sdio_writeb(func, *(pbuf + i), addr + i, &err);
 			if (err) {
-				DBG_871X(KERN_ERR "%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, err, addr, *(pbuf+i));
+				RTW_ERR("%s: FAIL!(%d) addr=0x%05x val=0x%02x\n", __func__, err, addr, *(pbuf + i));
 				break;
 			}
 		}
@@ -855,11 +814,9 @@ _func_enter_;
 
 	size = cnt;
 	err = sdio_memcpy_toio(func, addr, pdata, size);
-	if (err) {
-		DBG_871X(KERN_ERR "%s: FAIL(%d)! ADDR=%#x Size=%d(%d)\n", __func__, err, addr, cnt, size);
-	}
+	if (err)
+		RTW_ERR("%s: FAIL(%d)! ADDR=%#x Size=%d(%d)\n", __func__, err, addr, cnt, size);
 
-_func_exit_;
 
 	return err;
 }
@@ -885,17 +842,16 @@ s32 sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)
 
 	struct sdio_func *func;
 	bool claim_needed;
-	s32 err=-EPERM;
-_func_enter_;
+	s32 err = -EPERM;
 	padapter = pintfhdl->padapter;
 	psdiodev = pintfhdl->pintf_dev;
 	psdio = &psdiodev->intf_data;
-	
+
 	if (rtw_is_surprise_removed(padapter)) {
-		//DBG_871X(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__);
+		/* RTW_INFO(" %s (padapter->bSurpriseRemoved ||adapter->pwrctrlpriv.pnp_bstop_trx)!!!\n",__FUNCTION__); */
 		return err;
 	}
-	
+
 	func = psdio->func;
 	claim_needed = rtw_sdio_claim_host_needed(func);
 
@@ -904,7 +860,262 @@ _func_enter_;
 	err = _sd_write(pintfhdl, addr, cnt, pdata);
 	if (claim_needed)
 		sdio_release_host(func);
-_func_exit_;
 	return err;
 }
 
+#if 1
+/*#define RTW_SDIO_DUMP*/
+
+/**
+ *	Returns driver error code,
+ *	0	no error
+ *	-1	Level 1 error, critical error and can't be recovered
+ *	-2	Level 2 error, normal error, retry to recover is possible
+ */
+static int linux_io_err_to_drv_err(int err)
+{
+	if (!err)
+		return 0;
+
+	/* critical error */
+	if ((err == -ESHUTDOWN) ||
+	    (err == -ENODEV) ||
+	    (err == -ENOMEDIUM))
+		return -1;
+
+	/* other error */
+	return -2;
+}
+
+/**
+ *	rtw_sdio_raw_read - Read from SDIO device
+ *	@d: driver object private data
+ *	@addr: address to read
+ *	@buf: buffer to store the data
+ *	@len: number of bytes to read
+ *	@fixed:
+ *
+ *	Reads from the address space of a SDIO device.
+ *	Return value indicates if the transfer succeeded or not.
+ */
+int __must_check rtw_sdio_raw_read(struct dvobj_priv *d, unsigned int addr,
+				   void *buf, size_t len, bool fixed)
+{
+	int error = -EPERM;
+	bool f0, cmd52;
+	struct sdio_func *func;
+	bool claim_needed;
+	u32 offset, i;
+
+
+	func = dvobj_to_sdio_func(d);
+	claim_needed = rtw_sdio_claim_host_needed(func);
+	f0 = RTW_SDIO_ADDR_F0_CHK(addr);
+	cmd52 = RTW_SDIO_ADDR_CMD52_CHK(addr);
+
+	/*
+	 * Mask addr to remove driver defined bit and
+	 * make sure addr is in valid range
+	 */
+	if (f0)
+		addr &= 0xFFF;
+	else
+		addr &= 0x1FFFF;
+
+#ifdef RTW_SDIO_DUMP
+	if (f0)
+		dev_dbg(&func->dev, "rtw_sdio: READ F0\n");
+	else if (cmd52)
+		dev_dbg(&func->dev, "rtw_sdio: READ use CMD52\n");
+	else
+		dev_dbg(&func->dev, "rtw_sdio: READ use CMD53\n");
+
+	dev_dbg(&func->dev, "rtw_sdio: READ from 0x%05x\n", addr);
+#endif /* RTW_SDIO_DUMP */
+
+	if (claim_needed)
+		sdio_claim_host(func);
+
+	if (f0) {
+		offset = addr;
+		for (i = 0; i < len; i++, offset++) {
+			((u8 *)buf)[i] = sdio_f0_readb(func, offset, &error);
+			if (error)
+				break;
+#if 0
+			dev_info(&func->dev, "%s: sdio f0 read 52 addr 0x%x, byte 0x%02x\n",
+				 __func__, offset, ((u8 *)buf)[i]);
+#endif
+		}
+	} else {
+		if (cmd52) {
+#ifdef RTW_SDIO_IO_DBG
+			dev_info(&func->dev, "%s: sdio read 52 addr 0x%x, %zu bytes\n",
+				 __func__, addr, len);
+#endif
+			offset = addr;
+			for (i = 0; i < len; i++) {
+				((u8 *)buf)[i] = sdio_readb(func, offset, &error);
+				if (error)
+					break;
+#if 0
+				dev_info(&func->dev, "%s: sdio read 52 addr 0x%x, byte 0x%02x\n",
+					 __func__, offset, ((u8 *)buf)[i]);
+#endif
+				if (!fixed)
+					offset++;
+			}
+		} else {
+#ifdef RTW_SDIO_IO_DBG
+			dev_info(&func->dev, "%s: sdio read 53 addr 0x%x, %zu bytes\n",
+				 __func__, addr, len);
+#endif
+			if (fixed)
+				error = sdio_readsb(func, buf, addr, len);
+			else
+				error = sdio_memcpy_fromio(func, buf, addr, len);
+		}
+	}
+
+	if (claim_needed)
+		sdio_release_host(func);
+
+#ifdef RTW_SDIO_DUMP
+	print_hex_dump(KERN_DEBUG, "rtw_sdio: READ ",
+		       DUMP_PREFIX_OFFSET, 16, 1,
+		       buf, len, false);
+#endif /* RTW_SDIO_DUMP */
+
+	if (WARN_ON(error)) {
+		dev_err(&func->dev, "%s: sdio read failed (%d)\n", __func__, error);
+#ifndef RTW_SDIO_DUMP
+		if (f0)
+			dev_err(&func->dev, "rtw_sdio: READ F0\n");
+		if (cmd52)
+			dev_err(&func->dev, "rtw_sdio: READ use CMD52\n");
+		else
+			dev_err(&func->dev, "rtw_sdio: READ use CMD53\n");
+		dev_err(&func->dev, "rtw_sdio: READ from 0x%05x, %zu bytes\n", addr, len);
+		print_hex_dump(KERN_ERR, "rtw_sdio: READ ",
+			       DUMP_PREFIX_OFFSET, 16, 1,
+			       buf, len, false);
+#endif /* !RTW_SDIO_DUMP */
+	}
+
+	return linux_io_err_to_drv_err(error);
+}
+
+/**
+ *	rtw_sdio_raw_write - Write to SDIO device
+ *	@d: driver object private data
+ *	@addr: address to write
+ *	@buf: buffer that contains the data to write
+ *	@len: number of bytes to write
+ *	@fixed: address is fixed(FIFO) or incremented
+ *
+ *	Writes to the address space of a SDIO device.
+ *	Return value indicates if the transfer succeeded or not.
+ */
+int __must_check rtw_sdio_raw_write(struct dvobj_priv *d, unsigned int addr,
+				    void *buf, size_t len, bool fixed)
+{
+	int error = -EPERM;
+	bool f0, cmd52;
+	struct sdio_func *func;
+	bool claim_needed;
+	u32 offset, i;
+
+
+	func = dvobj_to_sdio_func(d);
+	claim_needed = rtw_sdio_claim_host_needed(func);
+	f0 = RTW_SDIO_ADDR_F0_CHK(addr);
+	cmd52 = RTW_SDIO_ADDR_CMD52_CHK(addr);
+
+	/*
+	 * Mask addr to remove driver defined bit and
+	 * make sure addr is in valid range
+	 */
+	if (f0)
+		addr &= 0xFFF;
+	else
+		addr &= 0x1FFFF;
+
+#ifdef RTW_SDIO_DUMP
+	if (f0)
+		dev_dbg(&func->dev, "rtw_sdio: WRITE F0\n");
+	else if (cmd52)
+		dev_dbg(&func->dev, "rtw_sdio: WRITE use CMD52\n");
+	else
+		dev_dbg(&func->dev, "rtw_sdio: WRITE use CMD53\n");
+	dev_dbg(&func->dev, "rtw_sdio: WRITE to 0x%05x\n", addr);
+	print_hex_dump(KERN_DEBUG, "rtw_sdio: WRITE ",
+		       DUMP_PREFIX_OFFSET, 16, 1,
+		       buf, len, false);
+#endif /* RTW_SDIO_DUMP */
+
+	if (claim_needed)
+		sdio_claim_host(func);
+
+	if (f0) {
+		offset = addr;
+		for (i = 0; i < len; i++, offset++) {
+			sdio_f0_writeb(func, ((u8 *)buf)[i], offset, &error);
+			if (error)
+				break;
+#if 0
+			dev_info(&func->dev, "%s: sdio f0 write 52 addr 0x%x, byte 0x%02x\n",
+				 __func__, offset, ((u8 *)buf)[i]);
+#endif
+		}
+	} else {
+		if (cmd52) {
+#ifdef RTW_SDIO_IO_DBG
+			dev_info(&func->dev, "%s: sdio write 52 addr 0x%x, %zu bytes\n",
+				 __func__, addr, len);
+#endif
+			offset = addr;
+			for (i = 0; i < len; i++) {
+				sdio_writeb(func, ((u8 *)buf)[i], offset, &error);
+				if (error)
+					break;
+#if 0
+				dev_info(&func->dev, "%s: sdio write 52 addr 0x%x, byte 0x%02x\n",
+					 __func__, offset, ((u8 *)buf)[i]);
+#endif
+				if (!fixed)
+					offset++;
+			}
+		} else {
+#ifdef RTW_SDIO_IO_DBG
+			dev_info(&func->dev, "%s: sdio write 53 addr 0x%x, %zu bytes\n",
+				 __func__, addr, len);
+#endif
+			if (fixed)
+				error = sdio_writesb(func, addr, buf, len);
+			else
+				error = sdio_memcpy_toio(func, addr, buf, len);
+		}
+	}
+
+	if (claim_needed)
+		sdio_release_host(func);
+
+	if (WARN_ON(error)) {
+		dev_err(&func->dev, "%s: sdio write failed (%d)\n", __func__, error);
+#ifndef RTW_SDIO_DUMP
+		if (f0)
+			dev_err(&func->dev, "rtw_sdio: WRITE F0\n");
+		if (cmd52)
+			dev_err(&func->dev, "rtw_sdio: WRITE use CMD52\n");
+		else
+			dev_err(&func->dev, "rtw_sdio: WRITE use CMD53\n");
+		dev_err(&func->dev, "rtw_sdio: WRITE to 0x%05x, %zu bytes\n", addr, len);
+		print_hex_dump(KERN_ERR, "rtw_sdio: WRITE ",
+			       DUMP_PREFIX_OFFSET, 16, 1,
+			       buf, len, false);
+#endif /* !RTW_SDIO_DUMP */
+	}
+
+	return linux_io_err_to_drv_err(error);
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/wifi_regd.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/wifi_regd.c
index 1adcfe6d10e1..74e6e5afd9e3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/wifi_regd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/wifi_regd.c
@@ -1,7 +1,16 @@
 /* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2009-2010  Realtek Corporation.
+ * Copyright(c) 2009-2010 - 2017 Realtek Corporation.
+ *
+ * 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.
  *
  *****************************************************************************/
 
@@ -15,7 +24,7 @@ static struct country_code_to_enum_rd allCountries[] = {
 	{COUNTRY_CODE_USER, "RD"},
 };
 
-/* 
+/*
  * REG_RULE(freq start, freq end, bandwidth, max gain, eirp, reg_flags)
  */
 
@@ -36,115 +45,110 @@ static struct country_code_to_enum_rd allCountries[] = {
 /* 2G chan 12 - chan 13, PASSIV SCAN */
 #define RTW_2GHZ_CH12_13	\
 	REG_RULE(2467-10, 2472+10, 40, 0, 20,	\
-	NL80211_RRF_PASSIVE_SCAN)
+		 NL80211_RRF_PASSIVE_SCAN)
 
 /* 2G chan 14, PASSIVS SCAN, NO OFDM (B only) */
 #define RTW_2GHZ_CH14	\
 	REG_RULE(2484-10, 2484+10, 40, 0, 20,	\
-	NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_OFDM)
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_OFDM)
 
 /* 5G chan 36 - chan 64 */
 #define RTW_5GHZ_5150_5350	\
 	REG_RULE(5150-10, 5350+10, 40, 0, 30,	\
-	NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
 
 /* 5G chan 100 - chan 165 */
 #define RTW_5GHZ_5470_5850	\
 	REG_RULE(5470-10, 5850+10, 40, 0, 30, \
-	NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
 
 /* 5G chan 149 - chan 165 */
 #define RTW_5GHZ_5725_5850	\
 	REG_RULE(5725-10, 5850+10, 40, 0, 30, \
-	NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
 
 /* 5G chan 36 - chan 165 */
 #define RTW_5GHZ_5150_5850	\
 	REG_RULE(5150-10, 5850+10, 40, 0, 30,	\
-	NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
+		 NL80211_RRF_PASSIVE_SCAN | NL80211_RRF_NO_IBSS)
 
 static const struct ieee80211_regdomain rtw_regdom_rd = {
 	.n_reg_rules = 3,
 	.alpha2 = "99",
 	.reg_rules = {
-		      RTW_2GHZ_CH01_11,
-		      RTW_2GHZ_CH12_13,
-		      RTW_5GHZ_5150_5850,
-		      }
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_5GHZ_5150_5850,
+	}
 };
 
 static const struct ieee80211_regdomain rtw_regdom_11 = {
 	.n_reg_rules = 1,
 	.alpha2 = "99",
 	.reg_rules = {
-		      RTW_2GHZ_CH01_11,
-		      }
+		RTW_2GHZ_CH01_11,
+	}
 };
 
 static const struct ieee80211_regdomain rtw_regdom_12_13 = {
 	.n_reg_rules = 2,
 	.alpha2 = "99",
 	.reg_rules = {
-		      RTW_2GHZ_CH01_11,
-		      RTW_2GHZ_CH12_13,
-		      }
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+	}
 };
 
 static const struct ieee80211_regdomain rtw_regdom_no_midband = {
 	.n_reg_rules = 3,
 	.alpha2 = "99",
 	.reg_rules = {
-		      RTW_2GHZ_CH01_11,
-		      RTW_5GHZ_5150_5350,
-		      RTW_5GHZ_5725_5850,
-		      }
+		RTW_2GHZ_CH01_11,
+		RTW_5GHZ_5150_5350,
+		RTW_5GHZ_5725_5850,
+	}
 };
 
 static const struct ieee80211_regdomain rtw_regdom_60_64 = {
 	.n_reg_rules = 3,
 	.alpha2 = "99",
 	.reg_rules = {
-		      RTW_2GHZ_CH01_11,
-		      RTW_2GHZ_CH12_13,
-		      RTW_5GHZ_5725_5850,
-		      }
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_5GHZ_5725_5850,
+	}
 };
 
 static const struct ieee80211_regdomain rtw_regdom_14_60_64 = {
 	.n_reg_rules = 4,
 	.alpha2 = "99",
 	.reg_rules = {
-		      RTW_2GHZ_CH01_11,
-		      RTW_2GHZ_CH12_13,
-		      RTW_2GHZ_CH14,
-		      RTW_5GHZ_5725_5850,
-		      }
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_2GHZ_CH14,
+		RTW_5GHZ_5725_5850,
+	}
 };
 
 static const struct ieee80211_regdomain rtw_regdom_14 = {
 	.n_reg_rules = 3,
 	.alpha2 = "99",
 	.reg_rules = {
-		      RTW_2GHZ_CH01_11,
-		      RTW_2GHZ_CH12_13,
-		      RTW_2GHZ_CH14,
-		      }
+		RTW_2GHZ_CH01_11,
+		RTW_2GHZ_CH12_13,
+		RTW_2GHZ_CH14,
+	}
 };
 
 #if 0
 static struct rtw_regulatory *rtw_regd;
 #endif
 
-static bool _rtw_is_radar_freq(u16 center_freq)
-{
-	return (center_freq >= 5260 && center_freq <= 5700);
-}
-
-#if 0 // not_yet
+#if 0 /* not_yet */
 static void _rtw_reg_apply_beaconing_flags(struct wiphy *wiphy,
-					   enum nl80211_reg_initiator initiator)
+		enum nl80211_reg_initiator initiator)
 {
-	enum ieee80211_band band;
+	enum nl80211_band band;
 	struct ieee80211_supported_band *sband;
 	const struct ieee80211_reg_rule *reg_rule;
 	struct ieee80211_channel *ch;
@@ -152,7 +156,7 @@ static void _rtw_reg_apply_beaconing_flags(struct wiphy *wiphy,
 	u32 bandwidth = 0;
 	int r;
 
-	for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
+	for (band = 0; band < NUM_NL80211_BANDS; band++) {
 
 		if (!wiphy->bands[band])
 			continue;
@@ -161,7 +165,7 @@ static void _rtw_reg_apply_beaconing_flags(struct wiphy *wiphy,
 
 		for (i = 0; i < sband->n_channels; i++) {
 			ch = &sband->channels[i];
-			if (_rtw_is_radar_freq(ch->center_freq) ||
+			if (rtw_is_dfs_ch(ch->hw_value) ||
 			    (ch->flags & IEEE80211_CHAN_RADAR))
 				continue;
 			if (initiator == NL80211_REGDOM_SET_BY_COUNTRY_IE) {
@@ -185,11 +189,11 @@ static void _rtw_reg_apply_beaconing_flags(struct wiphy *wiphy,
 				    (reg_rule->flags &
 				     NL80211_RRF_PASSIVE_SCAN))
 					ch->flags &=
-					    ~IEEE80211_CHAN_PASSIVE_SCAN;
+						~IEEE80211_CHAN_PASSIVE_SCAN;
 			} else {
 				if (ch->beacon_found)
 					ch->flags &= ~(IEEE80211_CHAN_NO_IBSS |
-						       IEEE80211_CHAN_PASSIVE_SCAN);
+						IEEE80211_CHAN_PASSIVE_SCAN);
 			}
 		}
 	}
@@ -197,8 +201,8 @@ static void _rtw_reg_apply_beaconing_flags(struct wiphy *wiphy,
 
 /* Allows active scan scan on Ch 12 and 13 */
 static void _rtw_reg_apply_active_scan_flags(struct wiphy *wiphy,
-					     enum nl80211_reg_initiator
-					     initiator)
+		enum nl80211_reg_initiator
+		initiator)
 {
 	struct ieee80211_supported_band *sband;
 	struct ieee80211_channel *ch;
@@ -206,9 +210,9 @@ static void _rtw_reg_apply_active_scan_flags(struct wiphy *wiphy,
 	u32 bandwidth = 0;
 	int r;
 
-	if (!wiphy->bands[IEEE80211_BAND_2GHZ])
+	if (!wiphy->bands[NL80211_BAND_2GHZ])
 		return;
-	sband = wiphy->bands[IEEE80211_BAND_2GHZ];
+	sband = wiphy->bands[NL80211_BAND_2GHZ];
 
 	/*
 	 * If no country IE has been received always enable active scan
@@ -249,66 +253,13 @@ static void _rtw_reg_apply_active_scan_flags(struct wiphy *wiphy,
 }
 #endif
 
-/*
- * Always apply Radar/DFS rules on
- * freq range 5260 MHz - 5700 MHz
- */
-static void _rtw_reg_apply_radar_flags(struct wiphy *wiphy)
+void rtw_regd_apply_flags(struct wiphy *wiphy)
 {
-	struct ieee80211_supported_band *sband;
-	struct ieee80211_channel *ch;
-	unsigned int i;
-
-	if (!wiphy->bands[IEEE80211_BAND_5GHZ])
-		return;
-
-	sband = wiphy->bands[IEEE80211_BAND_5GHZ];
-
-	for (i = 0; i < sband->n_channels; i++) {
-		ch = &sband->channels[i];
-		if (!_rtw_is_radar_freq(ch->center_freq))
-			continue;
-#ifdef CONFIG_DFS
-		#if defined(CONFIG_DFS_MASTER) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0))
-		if (!(ch->flags & IEEE80211_CHAN_DISABLED)) {
-			ch->flags |= IEEE80211_CHAN_RADAR;
-			#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,14,0))
-			ch->flags |= (IEEE80211_CHAN_NO_IBSS|IEEE80211_CHAN_PASSIVE_SCAN);
-			#else
-			ch->flags |= IEEE80211_CHAN_NO_IR;
-			#endif
-		}
-		#endif
-#endif //CONFIG_DFS
-
-#if 0
-		/*
-		 * We always enable radar detection/DFS on this
-		 * frequency range. Additionally we also apply on
-		 * this frequency range:
-		 * - If STA mode does not yet have DFS supports disable
-		 *  active scanning
-		 * - If adhoc mode does not support DFS yet then disable
-		 *  adhoc in the frequency.
-		 * - If AP mode does not yet support radar detection/DFS
-		 *  do not allow AP mode
-		 */
-		if (!(ch->flags & IEEE80211_CHAN_DISABLED))
-			ch->flags |= IEEE80211_CHAN_RADAR |
-			    IEEE80211_CHAN_NO_IBSS |
-			    IEEE80211_CHAN_PASSIVE_SCAN;
-#endif
-	}
-}
-
-static void _rtw_reg_apply_flags(struct wiphy *wiphy)
-{
-#if 1				// by channel plan
 	_adapter *padapter = wiphy_to_adapter(wiphy);
-	u8 channel_plan = padapter->mlmepriv.ChannelPlan;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	RT_CHANNEL_INFO *channel_set = pmlmeext->channel_set;
-	u8 max_chan_nums = pmlmeext->max_chan_nums;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	u8 channel_plan = rfctl->ChannelPlan;
+	RT_CHANNEL_INFO *channel_set = rfctl->channel_set;
+	u8 max_chan_nums = rfctl->max_chan_nums;
 
 	struct ieee80211_supported_band *sband;
 	struct ieee80211_channel *ch;
@@ -316,8 +267,8 @@ static void _rtw_reg_apply_flags(struct wiphy *wiphy)
 	u16 channel;
 	u32 freq;
 
-	// all channels disable
-	for (i = 0; i < IEEE80211_NUM_BANDS; i++) {
+	/* all channels disable */
+	for (i = 0; i < NUM_NL80211_BANDS; i++) {
 		sband = wiphy->bands[i];
 
 		if (sband) {
@@ -330,120 +281,48 @@ static void _rtw_reg_apply_flags(struct wiphy *wiphy)
 		}
 	}
 
-	// channels apply by channel plans.
+	/* channels apply by channel plans. */
 	for (i = 0; i < max_chan_nums; i++) {
 		channel = channel_set[i].ChannelNum;
 		freq = rtw_ch2freq(channel);
 
 		ch = ieee80211_get_channel(wiphy, freq);
-		if (ch) {
-			if (channel_set[i].ScanType == SCAN_PASSIVE) {
-				#if defined(CONFIG_DFS_MASTER) && (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
-				ch->flags = 0;
-				#elif (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
-				ch->flags = (IEEE80211_CHAN_NO_IBSS|IEEE80211_CHAN_PASSIVE_SCAN);
-				#else
-				ch->flags = IEEE80211_CHAN_NO_IR;
-				#endif
-			}
-			else {
-				ch->flags = 0;
-			}
-		}
-	}
-
-#else
-	struct ieee80211_supported_band *sband;
-	struct ieee80211_channel *ch;
-	unsigned int i, j;
-	u16 channels[37] =
-	    { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56,
-		60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140,
-		149, 153,
-		157, 161, 165
-	};
-	u16 channel;
-	u32 freq;
-
-	for (i = 0; i < IEEE80211_NUM_BANDS; i++) {
-		sband = wiphy->bands[i];
-
-		if (sband)
-			for (j = 0; j < sband->n_channels; j++) {
-				ch = &sband->channels[j];
-
-				if (ch)
-					ch->flags = IEEE80211_CHAN_DISABLED;
-			}
-	}
+		if (!ch)
+			continue;
 
-	for (i = 0; i < 37; i++) {
-		channel = channels[i];
-		freq = rtw_ch2freq(channel);
+		if (channel_set[i].ScanType == SCAN_PASSIVE
+			#if defined(CONFIG_DFS_MASTER)
+			&& rtw_odm_dfs_domain_unknown(padapter)
+			#endif
+		) {
+			#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+			ch->flags = (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
+			#else
+			ch->flags = IEEE80211_CHAN_NO_IR;
+			#endif
+		} else
+			ch->flags = 0;
 
-		ch = ieee80211_get_channel(wiphy, freq);
-		if (ch) {
-			if (channel <= 11)
-				ch->flags = 0;
-			else
-				ch->flags = 0;	//IEEE80211_CHAN_PASSIVE_SCAN;
+		#ifdef CONFIG_DFS
+		if (rtw_is_dfs_ch(ch->hw_value)
+			#if defined(CONFIG_DFS_MASTER)
+			&& rtw_odm_dfs_domain_unknown(padapter)
+			#endif
+		) {
+			ch->flags |= IEEE80211_CHAN_RADAR;
+			#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+			ch->flags |= (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
+			#else
+			ch->flags |= IEEE80211_CHAN_NO_IR;
+			#endif
 		}
-		//printk("%s: freq %d(%d) flag 0x%02X \n", __func__, freq, channel, ch->flags);
+		#endif /* CONFIG_DFS */
 	}
-#endif
-}
-
-static void _rtw_reg_apply_world_flags(struct wiphy *wiphy,
-				       enum nl80211_reg_initiator initiator,
-				       struct rtw_regulatory *reg)
-{
-	//_rtw_reg_apply_beaconing_flags(wiphy, initiator);
-	//_rtw_reg_apply_active_scan_flags(wiphy, initiator);
-	return;
-}
-
-static int _rtw_reg_notifier_apply(struct wiphy *wiphy,
-				   struct regulatory_request *request,
-				   struct rtw_regulatory *reg)
-{
-
-	/* Hard code flags */
-	_rtw_reg_apply_flags(wiphy);
-
-	/* We always apply this */
-	_rtw_reg_apply_radar_flags(wiphy);
-
-	switch (request->initiator) {
-	case NL80211_REGDOM_SET_BY_DRIVER:
-		DBG_8192C("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_DRIVER");
-		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
-					   reg);
-		break;
-	case NL80211_REGDOM_SET_BY_CORE:
-		DBG_8192C("%s: %s\n", __func__,
-			  "NL80211_REGDOM_SET_BY_CORE to DRV");
-		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
-					   reg);
-		break;
-	case NL80211_REGDOM_SET_BY_USER:
-		DBG_8192C("%s: %s\n", __func__,
-			  "NL80211_REGDOM_SET_BY_USER to DRV");
-		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
-					   reg);
-		break;
-	case NL80211_REGDOM_SET_BY_COUNTRY_IE:
-		DBG_8192C("%s: %s\n", __func__,
-			  "NL80211_REGDOM_SET_BY_COUNTRY_IE");
-		_rtw_reg_apply_world_flags(wiphy, request->initiator, reg);
-		break;
-	}
-
-	return 0;
 }
 
 static const struct ieee80211_regdomain *_rtw_regdomain_select(struct
-							       rtw_regulatory
-							       *reg)
+		rtw_regulatory
+		*reg)
 {
 #if 0
 	switch (reg->country_code) {
@@ -456,59 +335,60 @@ static const struct ieee80211_regdomain *_rtw_regdomain_select(struct
 #endif
 }
 
-void _rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
+static void rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
 {
-	struct rtw_regulatory *reg = NULL;
-
-	DBG_8192C("%s\n", __func__);
+	switch (request->initiator) {
+	case NL80211_REGDOM_SET_BY_DRIVER:
+		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_DRIVER");
+		break;
+	case NL80211_REGDOM_SET_BY_CORE:
+		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_CORE");
+		break;
+	case NL80211_REGDOM_SET_BY_USER:
+		RTW_INFO("%s: %s alpha2:%c%c\n", __func__, "NL80211_REGDOM_SET_BY_USER"
+			, request->alpha2[0], request->alpha2[1]);
+		rtw_set_country(wiphy_to_adapter(wiphy), request->alpha2);
+		break;
+	case NL80211_REGDOM_SET_BY_COUNTRY_IE:
+		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_COUNTRY_IE");
+		break;
+	}
 
-	_rtw_reg_notifier_apply(wiphy, request, reg);
+	rtw_regd_apply_flags(wiphy);
 }
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,9,0))
-int rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
-#else
-void rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
-#endif
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
+static int rtw_reg_notifier_return(struct wiphy *wiphy, struct regulatory_request *request)
 {
-	_rtw_reg_notifier(wiphy, request);
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,9,0))
+	rtw_reg_notifier(wiphy, request);
 	return 0;
-	#endif
-}
-
-void rtw_reg_notify_by_driver(_adapter *adapter)
-{
-	if ((adapter->rtw_wdev != NULL) && (adapter->rtw_wdev->wiphy)) {
-		struct regulatory_request request;
-		request.initiator = NL80211_REGDOM_SET_BY_DRIVER;
-		rtw_reg_notifier(adapter->rtw_wdev->wiphy, &request);
-	}
 }
+#endif
 
 static void _rtw_regd_init_wiphy(struct rtw_regulatory *reg, struct wiphy *wiphy)
 {
 	const struct ieee80211_regdomain *regd;
 
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
+	wiphy->reg_notifier = rtw_reg_notifier_return;
+#else
 	wiphy->reg_notifier = rtw_reg_notifier;
+#endif
 
-	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,14,0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
 	wiphy->flags |= WIPHY_FLAG_CUSTOM_REGULATORY;
 	wiphy->flags &= ~WIPHY_FLAG_STRICT_REGULATORY;
 	wiphy->flags &= ~WIPHY_FLAG_DISABLE_BEACON_HINTS;
-	#else
+#else
 	wiphy->regulatory_flags |= REGULATORY_CUSTOM_REG;
 	wiphy->regulatory_flags &= ~REGULATORY_STRICT_REG;
 	wiphy->regulatory_flags &= ~REGULATORY_DISABLE_BEACON_HINTS;
-	#endif
-	
+#endif
+
 	regd = _rtw_regdomain_select(reg);
 	wiphy_apply_custom_regulatory(wiphy, regd);
 
-	/* Hard code flags */
-	_rtw_reg_apply_flags(wiphy);
-	_rtw_reg_apply_radar_flags(wiphy);
-	_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER, reg);
+	rtw_regd_apply_flags(wiphy);
 }
 
 static struct country_code_to_enum_rd *_rtw_regd_find_country(u16 countrycode)
@@ -522,14 +402,12 @@ static struct country_code_to_enum_rd *_rtw_regd_find_country(u16 countrycode)
 	return NULL;
 }
 
-int rtw_regd_init(_adapter * padapter)
+int rtw_regd_init(struct wiphy *wiphy)
 {
-	struct wiphy *wiphy = padapter->rtw_wdev->wiphy;
-
 #if 0
 	if (rtw_regd == NULL) {
 		rtw_regd = (struct rtw_regulatory *)
-		    rtw_malloc(sizeof(struct rtw_regulatory));
+			   rtw_malloc(sizeof(struct rtw_regulatory));
 
 		rtw_regd->alpha2[0] = '9';
 		rtw_regd->alpha2[1] = '9';
@@ -537,13 +415,12 @@ int rtw_regd_init(_adapter * padapter)
 		rtw_regd->country_code = COUNTRY_CODE_USER;
 	}
 
-	DBG_8192C("%s: Country alpha2 being used: %c%c\n",
-		  __func__, rtw_regd->alpha2[0], rtw_regd->alpha2[1]);
+	RTW_INFO("%s: Country alpha2 being used: %c%c\n",
+		 __func__, rtw_regd->alpha2[0], rtw_regd->alpha2[1]);
 #endif
 
 	_rtw_regd_init_wiphy(NULL, wiphy);
 
 	return 0;
 }
-#endif //CONFIG_IOCTL_CFG80211
-
+#endif /* CONFIG_IOCTL_CFG80211 */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/xmit_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/xmit_linux.c
index b30ebc1ac389..a2888961a646 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/xmit_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/linux/xmit_linux.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 #define _XMIT_OSDEP_C_
 
 #include <drv_types.h>
@@ -25,52 +21,45 @@
 
 uint rtw_remainder_len(struct pkt_file *pfile)
 {
-	return (pfile->buf_len - ((SIZE_PTR)(pfile->cur_addr) - (SIZE_PTR)(pfile->buf_start)));
+	return pfile->buf_len - ((SIZE_PTR)(pfile->cur_addr) - (SIZE_PTR)(pfile->buf_start));
 }
 
-void _rtw_open_pktfile (_pkt *pktptr, struct pkt_file *pfile)
+void _rtw_open_pktfile(_pkt *pktptr, struct pkt_file *pfile)
 {
-_func_enter_;
 
 	pfile->pkt = pktptr;
 	pfile->cur_addr = pfile->buf_start = pktptr->data;
 	pfile->pkt_len = pfile->buf_len = pktptr->len;
 
 	pfile->cur_buffer = pfile->buf_start ;
-	
-_func_exit_;
+
 }
 
-uint _rtw_pktfile_read (struct pkt_file *pfile, u8 *rmem, uint rlen)
-{	
+uint _rtw_pktfile_read(struct pkt_file *pfile, u8 *rmem, uint rlen)
+{
 	uint	len = 0;
-	
-_func_enter_;
 
-       len =  rtw_remainder_len(pfile);
-      	len = (rlen > len)? len: rlen;
 
-       if(rmem)
-	  skb_copy_bits(pfile->pkt, pfile->buf_len-pfile->pkt_len, rmem, len);
+	len =  rtw_remainder_len(pfile);
+	len = (rlen > len) ? len : rlen;
+
+	if (rmem)
+		skb_copy_bits(pfile->pkt, pfile->buf_len - pfile->pkt_len, rmem, len);
 
-       pfile->cur_addr += len;
-       pfile->pkt_len -= len;
-	   
-_func_exit_;	       		
+	pfile->cur_addr += len;
+	pfile->pkt_len -= len;
 
-	return len;	
+
+	return len;
 }
 
 sint rtw_endofpktfile(struct pkt_file *pfile)
 {
-_func_enter_;
 
 	if (pfile->pkt_len == 0) {
-_func_exit_;
 		return _TRUE;
 	}
 
-_func_exit_;
 
 	return _FALSE;
 }
@@ -81,37 +70,35 @@ void rtw_set_tx_chksum_offload(_pkt *pkt, struct pkt_attrib *pattrib)
 #ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
 	struct sk_buff *skb = (struct sk_buff *)pkt;
 	pattrib->hw_tcp_csum = 0;
-	
+
 	if (skb->ip_summed == CHECKSUM_PARTIAL) {
-		if (skb_shinfo(skb)->nr_frags == 0)
-		{	
-                        const struct iphdr *ip = ip_hdr(skb);
-                        if (ip->protocol == IPPROTO_TCP) {
-                                // TCP checksum offload by HW
-                                DBG_871X("CHECKSUM_PARTIAL TCP\n");
-                                pattrib->hw_tcp_csum = 1;
-                                //skb_checksum_help(skb);
-                        } else if (ip->protocol == IPPROTO_UDP) {
-                                //DBG_871X("CHECKSUM_PARTIAL UDP\n");
-#if 1                       
-                                skb_checksum_help(skb);
+		if (skb_shinfo(skb)->nr_frags == 0) {
+			const struct iphdr *ip = ip_hdr(skb);
+			if (ip->protocol == IPPROTO_TCP) {
+				/* TCP checksum offload by HW */
+				RTW_INFO("CHECKSUM_PARTIAL TCP\n");
+				pattrib->hw_tcp_csum = 1;
+				/* skb_checksum_help(skb); */
+			} else if (ip->protocol == IPPROTO_UDP) {
+				/* RTW_INFO("CHECKSUM_PARTIAL UDP\n"); */
+#if 1
+				skb_checksum_help(skb);
 #else
-                                // Set UDP checksum = 0 to skip checksum check
-                                struct udphdr *udp = skb_transport_header(skb);
-                                udp->check = 0;
+				/* Set UDP checksum = 0 to skip checksum check */
+				struct udphdr *udp = skb_transport_header(skb);
+				udp->check = 0;
 #endif
-                        } else {
-				DBG_871X("%s-%d TCP CSUM offload Error!!\n", __FUNCTION__, __LINE__);
-                                WARN_ON(1);     /* we need a WARN() */
-			    }
+			} else {
+				RTW_INFO("%s-%d TCP CSUM offload Error!!\n", __FUNCTION__, __LINE__);
+				WARN_ON(1);     /* we need a WARN() */
+			}
+		} else { /* IP fragmentation case */
+			RTW_INFO("%s-%d nr_frags != 0, using skb_checksum_help(skb);!!\n", __FUNCTION__, __LINE__);
+			skb_checksum_help(skb);
 		}
-		else { // IP fragmentation case
-			DBG_871X("%s-%d nr_frags != 0, using skb_checksum_help(skb);!!\n", __FUNCTION__, __LINE__);
-                	skb_checksum_help(skb);
-		}		
 	}
-#endif	
-	
+#endif
+
 }
 
 int rtw_os_xmit_resource_alloc(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 alloc_sz, u8 flag)
@@ -123,57 +110,51 @@ int rtw_os_xmit_resource_alloc(_adapter *padapter, struct xmit_buf *pxmitbuf, u3
 
 		pxmitbuf->pallocated_buf = rtw_usb_buffer_alloc(pusbd, (size_t)alloc_sz, &pxmitbuf->dma_transfer_addr);
 		pxmitbuf->pbuf = pxmitbuf->pallocated_buf;
-		if(pxmitbuf->pallocated_buf == NULL)
+		if (pxmitbuf->pallocated_buf == NULL)
 			return _FAIL;
-#else // CONFIG_USE_USB_BUFFER_ALLOC_TX
-		
+#else /* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+
 		pxmitbuf->pallocated_buf = rtw_zmalloc(alloc_sz);
 		if (pxmitbuf->pallocated_buf == NULL)
-		{
 			return _FAIL;
-		}
 
 		pxmitbuf->pbuf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitbuf->pallocated_buf), XMITBUF_ALIGN_SZ);
 
-#endif // CONFIG_USE_USB_BUFFER_ALLOC_TX
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_TX */
 	}
 
 	if (flag) {
 #ifdef CONFIG_USB_HCI
 		int i;
-		for(i=0; i<8; i++)
-	      	{
-	      		pxmitbuf->pxmit_urb[i] = usb_alloc_urb(0, GFP_KERNEL);
-	             if(pxmitbuf->pxmit_urb[i] == NULL) 
-	             {
-	             	DBG_871X("pxmitbuf->pxmit_urb[i]==NULL");
-		       	return _FAIL;	 
-	             }
-	      	}
+		for (i = 0; i < 8; i++) {
+			pxmitbuf->pxmit_urb[i] = usb_alloc_urb(0, GFP_KERNEL);
+			if (pxmitbuf->pxmit_urb[i] == NULL) {
+				RTW_INFO("pxmitbuf->pxmit_urb[i]==NULL");
+				return _FAIL;
+			}
+		}
 #endif
 	}
 
-	return _SUCCESS;	
+	return _SUCCESS;
 }
 
-void rtw_os_xmit_resource_free(_adapter *padapter, struct xmit_buf *pxmitbuf,u32 free_sz, u8 flag)
+void rtw_os_xmit_resource_free(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 free_sz, u8 flag)
 {
 	if (flag) {
 #ifdef CONFIG_USB_HCI
 		int i;
 
-		for(i=0; i<8; i++)
-		{
-			if(pxmitbuf->pxmit_urb[i])
-			{
-				//usb_kill_urb(pxmitbuf->pxmit_urb[i]);
+		for (i = 0; i < 8; i++) {
+			if (pxmitbuf->pxmit_urb[i]) {
+				/* usb_kill_urb(pxmitbuf->pxmit_urb[i]); */
 				usb_free_urb(pxmitbuf->pxmit_urb[i]);
 			}
 		}
 #endif
 	}
 
-	if (free_sz > 0 ) {
+	if (free_sz > 0) {
 #ifdef CONFIG_USE_USB_BUFFER_ALLOC_TX
 		struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
 		struct usb_device	*pusbd = pdvobjpriv->pusbdev;
@@ -181,10 +162,10 @@ void rtw_os_xmit_resource_free(_adapter *padapter, struct xmit_buf *pxmitbuf,u32
 		rtw_usb_buffer_free(pusbd, (size_t)free_sz, pxmitbuf->pallocated_buf, pxmitbuf->dma_transfer_addr);
 		pxmitbuf->pallocated_buf =  NULL;
 		pxmitbuf->dma_transfer_addr = 0;
-#else	// CONFIG_USE_USB_BUFFER_ALLOC_TX
-		if(pxmitbuf->pallocated_buf)
+#else	/* CONFIG_USE_USB_BUFFER_ALLOC_TX */
+		if (pxmitbuf->pallocated_buf)
 			rtw_mfree(pxmitbuf->pallocated_buf, free_sz);
-#endif	// CONFIG_USE_USB_BUFFER_ALLOC_TX
+#endif /* CONFIG_USE_USB_BUFFER_ALLOC_TX */
 	}
 }
 
@@ -192,52 +173,72 @@ void dump_os_queue(void *sel, _adapter *padapter)
 {
 	struct net_device *ndev = padapter->pnetdev;
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	int i;
 
-	for (i=0;i<4;i++) {
-		DBG_871X_SEL_NL(sel, "os_queue[%d]:%s\n"
-			, i, __netif_subqueue_stopped(ndev, i)?"stopped":"waked");
+	for (i = 0; i < 4; i++) {
+		RTW_PRINT_SEL(sel, "os_queue[%d]:%s\n"
+			, i, __netif_subqueue_stopped(ndev, i) ? "stopped" : "waked");
 	}
 #else
-	DBG_871X_SEL_NL(sel, "os_queue:%s\n"
-			, netif_queue_stopped(ndev)?"stopped":"waked");
+	RTW_PRINT_SEL(sel, "os_queue:%s\n"
+		      , netif_queue_stopped(ndev) ? "stopped" : "waked");
 #endif
 }
 
 #define WMM_XMIT_THRESHOLD	(NR_XMITFRAME*2/5)
 
-inline static bool rtw_os_need_wake_queue(_adapter *padapter, u16 qidx)
+static inline bool rtw_os_need_wake_queue(_adapter *padapter, u16 qidx)
 {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 
 	if (padapter->registrypriv.wifi_spec) {
 		if (pxmitpriv->hwxmits[qidx].accnt < WMM_XMIT_THRESHOLD)
 			return _TRUE;
+#ifdef DBG_CONFIG_ERROR_DETECT
+#ifdef DBG_CONFIG_ERROR_RESET
+	} else if (rtw_hal_sreset_inprogress(padapter) == _TRUE) {
+		return _FALSE;
+#endif/* #ifdef DBG_CONFIG_ERROR_RESET */
+#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
 	} else {
+#ifdef CONFIG_MCC_MODE
+		if (MCC_EN(padapter)) {
+			if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)
+			    && MCC_STOP(padapter))
+				return _FALSE;
+		}
+#endif /* CONFIG_MCC_MODE */
 		return _TRUE;
 	}
 	return _FALSE;
 #else
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(padapter)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)
+		    && MCC_STOP(padapter))
+			return _FALSE;
+	}
+#endif /* CONFIG_MCC_MODE */
 	return _TRUE;
 #endif
 }
 
-inline static bool rtw_os_need_stop_queue(_adapter *padapter, u16 qidx)
+static inline bool rtw_os_need_stop_queue(_adapter *padapter, u16 qidx)
 {
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	if (padapter->registrypriv.wifi_spec) {
 		/* No free space for Tx, tx_worker is too slow */
 		if (pxmitpriv->hwxmits[qidx].accnt > WMM_XMIT_THRESHOLD)
 			return _TRUE;
 	} else {
-		if(pxmitpriv->free_xmitframe_cnt<=4)
+		if (pxmitpriv->free_xmitframe_cnt <= 4)
 			return _TRUE;
 	}
 #else
-	if(pxmitpriv->free_xmitframe_cnt<=4)
+	if (pxmitpriv->free_xmitframe_cnt <= 4)
 		return _TRUE;
 #endif
 	return _FALSE;
@@ -245,19 +246,19 @@ inline static bool rtw_os_need_stop_queue(_adapter *padapter, u16 qidx)
 
 void rtw_os_pkt_complete(_adapter *padapter, _pkt *pkt)
 {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	u16	qidx;
 
 	qidx = skb_get_queue_mapping(pkt);
 	if (rtw_os_need_wake_queue(padapter, qidx)) {
 		if (DBG_DUMP_OS_QUEUE_CTL)
-			DBG_871X(FUNC_ADPT_FMT": netif_wake_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), qidx);
+			RTW_INFO(FUNC_ADPT_FMT": netif_wake_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), qidx);
 		netif_wake_subqueue(padapter->pnetdev, qidx);
 	}
 #else
 	if (rtw_os_need_wake_queue(padapter, 0)) {
 		if (DBG_DUMP_OS_QUEUE_CTL)
-			DBG_871X(FUNC_ADPT_FMT": netif_wake_queue\n", FUNC_ADPT_ARG(padapter));
+			RTW_INFO(FUNC_ADPT_FMT": netif_wake_queue\n", FUNC_ADPT_ARG(padapter));
 		netif_wake_queue(padapter->pnetdev);
 	}
 #endif
@@ -267,7 +268,7 @@ void rtw_os_pkt_complete(_adapter *padapter, _pkt *pkt)
 
 void rtw_os_xmit_complete(_adapter *padapter, struct xmit_frame *pxframe)
 {
-	if(pxframe->pkt)
+	if (pxframe->pkt)
 		rtw_os_pkt_complete(padapter, pxframe->pkt);
 
 	pxframe->pkt = NULL;
@@ -275,16 +276,11 @@ void rtw_os_xmit_complete(_adapter *padapter, struct xmit_frame *pxframe)
 
 void rtw_os_xmit_schedule(_adapter *padapter)
 {
-	_adapter *pri_adapter = padapter;
-
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	if(!padapter)
-		return;
+	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(padapter);
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if(padapter->adapter_type > PRIMARY_ADAPTER)
-		pri_adapter = padapter->pbuddy_adapter;
-#endif
+	if (!padapter)
+		return;
 
 	if (_rtw_queue_empty(&padapter->xmitpriv.pending_xmitbuf_queue) == _FALSE)
 		_rtw_up_sema(&pri_adapter->xmitpriv.xmit_sema);
@@ -294,19 +290,24 @@ void rtw_os_xmit_schedule(_adapter *padapter)
 	_irqL  irqL;
 	struct xmit_priv *pxmitpriv;
 
-	if(!padapter)
+	if (!padapter)
 		return;
 
 	pxmitpriv = &padapter->xmitpriv;
 
 	_enter_critical_bh(&pxmitpriv->lock, &irqL);
 
-	if(rtw_txframes_pending(padapter))	
-	{
+	if (rtw_txframes_pending(padapter))
 		tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
-	}
 
 	_exit_critical_bh(&pxmitpriv->lock, &irqL);
+	
+#if defined(CONFIG_PCI_HCI) && defined(CONFIG_XMIT_THREAD_MODE)
+	if (_rtw_queue_empty(&padapter->xmitpriv.pending_xmitbuf_queue) == _FALSE)
+		_rtw_up_sema(&padapter->xmitpriv.xmit_sema);
+#endif
+	
+
 #endif
 }
 
@@ -314,20 +315,20 @@ static bool rtw_check_xmit_resource(_adapter *padapter, _pkt *pkt)
 {
 	bool busy = _FALSE;
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	u16	qidx;
 
 	qidx = skb_get_queue_mapping(pkt);
 	if (rtw_os_need_stop_queue(padapter, qidx)) {
 		if (DBG_DUMP_OS_QUEUE_CTL)
-			DBG_871X(FUNC_ADPT_FMT": netif_stop_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), qidx);
+			RTW_INFO(FUNC_ADPT_FMT": netif_stop_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), qidx);
 		netif_stop_subqueue(padapter->pnetdev, qidx);
 		busy = _TRUE;
 	}
 #else
 	if (rtw_os_need_stop_queue(padapter, 0)) {
 		if (DBG_DUMP_OS_QUEUE_CTL)
-			DBG_871X(FUNC_ADPT_FMT": netif_stop_queue\n", FUNC_ADPT_ARG(padapter));
+			RTW_INFO(FUNC_ADPT_FMT": netif_stop_queue\n", FUNC_ADPT_ARG(padapter));
 		rtw_netif_stop_queue(padapter->pnetdev);
 		busy = _TRUE;
 	}
@@ -337,24 +338,24 @@ static bool rtw_check_xmit_resource(_adapter *padapter, _pkt *pkt)
 
 void rtw_os_wake_queue_at_free_stainfo(_adapter *padapter, int *qcnt_freed)
 {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	int i;
 
-	for (i=0;i<4;i++) {
+	for (i = 0; i < 4; i++) {
 		if (qcnt_freed[i] == 0)
 			continue;
 
-		if(rtw_os_need_wake_queue(padapter, i)) {
+		if (rtw_os_need_wake_queue(padapter, i)) {
 			if (DBG_DUMP_OS_QUEUE_CTL)
-				DBG_871X(FUNC_ADPT_FMT": netif_wake_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), i);
+				RTW_INFO(FUNC_ADPT_FMT": netif_wake_subqueue[%d]\n", FUNC_ADPT_ARG(padapter), i);
 			netif_wake_subqueue(padapter->pnetdev, i);
 		}
 	}
 #else
 	if (qcnt_freed[0] || qcnt_freed[1] || qcnt_freed[2] || qcnt_freed[3]) {
-		if(rtw_os_need_wake_queue(padapter, 0)) {
+		if (rtw_os_need_wake_queue(padapter, 0)) {
 			if (DBG_DUMP_OS_QUEUE_CTL)
-				DBG_871X(FUNC_ADPT_FMT": netif_wake_queue\n", FUNC_ADPT_ARG(padapter));
+				RTW_INFO(FUNC_ADPT_FMT": netif_wake_queue\n", FUNC_ADPT_ARG(padapter));
 			netif_wake_queue(padapter->pnetdev);
 		}
 	}
@@ -372,8 +373,8 @@ int rtw_mlcst2unicst(_adapter *padapter, struct sk_buff *skb)
 	struct sta_info *psta = NULL;
 	u8 chk_alive_num = 0;
 	char chk_alive_list[NUM_STA];
-	u8 bc_addr[6]={0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-	u8 null_addr[6]={0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	u8 bc_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
 
 	int i;
 	s32	res;
@@ -383,34 +384,31 @@ int rtw_mlcst2unicst(_adapter *padapter, struct sk_buff *skb)
 	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 	phead = &pstapriv->asoc_list;
 	plist = get_next(phead);
-	
-	//free sta asoc_queue
+
+	/* free sta asoc_queue */
 	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 		int stainfo_offset;
 		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
 		plist = get_next(plist);
 
 		stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
-		if (stainfo_offset_valid(stainfo_offset)) {
+		if (stainfo_offset_valid(stainfo_offset))
 			chk_alive_list[chk_alive_num++] = stainfo_offset;
-		}
 	}
 	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 
 	for (i = 0; i < chk_alive_num; i++) {
 		psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
-		if(!(psta->state &_FW_LINKED))
-		{
+		if (!(psta->state & _FW_LINKED)) {
 			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_ignore_fw_linked);
-			continue;		
+			continue;
 		}
-		
-		/* avoid come from STA1 and send back STA1 */ 
-		if (_rtw_memcmp(psta->hwaddr, &skb->data[6], 6) == _TRUE
-			|| _rtw_memcmp(psta->hwaddr, null_addr, 6) == _TRUE
-			|| _rtw_memcmp(psta->hwaddr, bc_addr, 6) == _TRUE
-		)
-		{
+
+		/* avoid come from STA1 and send back STA1 */
+		if (_rtw_memcmp(psta->cmn.mac_addr, &skb->data[6], 6) == _TRUE
+			|| _rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) == _TRUE
+			|| _rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6) == _TRUE
+		) {
 			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_ignore_self);
 			continue;
 		}
@@ -420,27 +418,27 @@ int rtw_mlcst2unicst(_adapter *padapter, struct sk_buff *skb)
 		newskb = rtw_skb_copy(skb);
 
 		if (newskb) {
-			_rtw_memcpy(newskb->data, psta->hwaddr, 6);
+			_rtw_memcpy(newskb->data, psta->cmn.mac_addr, 6);
 			res = rtw_xmit(padapter, &newskb);
 			if (res < 0) {
 				DBG_COUNTER(padapter->tx_logs.os_tx_m2u_entry_err_xmit);
-				DBG_871X("%s()-%d: rtw_xmit() return error! res=%d\n", __FUNCTION__, __LINE__, res);
+				RTW_INFO("%s()-%d: rtw_xmit() return error! res=%d\n", __FUNCTION__, __LINE__, res);
 				pxmitpriv->tx_drop++;
 				rtw_skb_free(newskb);
 			}
 		} else {
 			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_entry_err_skb);
-			DBG_871X("%s-%d: rtw_skb_copy() failed!\n", __FUNCTION__, __LINE__);
+			RTW_INFO("%s-%d: rtw_skb_copy() failed!\n", __FUNCTION__, __LINE__);
 			pxmitpriv->tx_drop++;
-			//rtw_skb_free(skb);
-			return _FALSE;	// Caller shall tx this multicast frame via normal way.
+			/* rtw_skb_free(skb); */
+			return _FALSE;	/* Caller shall tx this multicast frame via normal way. */
 		}
 	}
 
 	rtw_skb_free(skb);
 	return _TRUE;
 }
-#endif	// CONFIG_TX_MCAST2UNI
+#endif /* CONFIG_TX_MCAST2UNI */
 
 
 int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
@@ -450,27 +448,23 @@ int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
 #ifdef CONFIG_TX_MCAST2UNI
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	extern int rtw_mc2u_disable;
-#endif	// CONFIG_TX_MCAST2UNI	
+#endif /* CONFIG_TX_MCAST2UNI	 */
 	s32 res = 0;
-#if (LINUX_VERSION_CODE>=KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	u16 queue;
 #endif
 
-_func_enter_;
 
-	if(padapter->registrypriv.mp_mode)
-	{
-		DBG_871X("MP_TX_DROP_OS_FRAME\n");
+	if (padapter->registrypriv.mp_mode) {
+		RTW_INFO("MP_TX_DROP_OS_FRAME\n");
 		goto drop_packet;
 	}
 	DBG_COUNTER(padapter->tx_logs.os_tx);
-	RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_, ("+xmit_enry\n"));
 
 	if (rtw_if_up(padapter) == _FALSE) {
 		DBG_COUNTER(padapter->tx_logs.os_tx_err_up);
-		RT_TRACE(_module_xmit_osdep_c_, _drv_err_, ("rtw_xmit_entry: rtw_if_up fail\n"));
 		#ifdef DBG_TX_DROP_FRAME
-		DBG_871X("DBG_TX_DROP_FRAME %s if_up fail\n", __FUNCTION__);
+		RTW_INFO("DBG_TX_DROP_FRAME %s if_up fail\n", __FUNCTION__);
 		#endif
 		goto drop_packet;
 	}
@@ -478,49 +472,44 @@ _func_enter_;
 	rtw_check_xmit_resource(padapter, pkt);
 
 #ifdef CONFIG_TX_MCAST2UNI
-	if ( !rtw_mc2u_disable
-		&& check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE
-		&& ( IP_MCAST_MAC(pkt->data)
+	if (!rtw_mc2u_disable
+		&& MLME_IS_AP(padapter)
+		&& (IP_MCAST_MAC(pkt->data)
 			|| ICMPV6_MCAST_MAC(pkt->data)
 			#ifdef CONFIG_TX_BCAST2UNI
 			|| is_broadcast_mac_addr(pkt->data)
 			#endif
 			)
 		&& (padapter->registrypriv.wifi_spec == 0)
-		)
-	{
-		if ( pxmitpriv->free_xmitframe_cnt > (NR_XMITFRAME/4) ) {
+	) {
+		if (pxmitpriv->free_xmitframe_cnt > (NR_XMITFRAME / 4)) {
 			res = rtw_mlcst2unicst(padapter, pkt);
-			if (res == _TRUE) {
+			if (res == _TRUE)
 				goto exit;
-			}
 		} else {
-			//DBG_871X("Stop M2U(%d, %d)! ", pxmitpriv->free_xmitframe_cnt, pxmitpriv->free_xmitbuf_cnt);
-			//DBG_871X("!m2u );
+			/* RTW_INFO("Stop M2U(%d, %d)! ", pxmitpriv->free_xmitframe_cnt, pxmitpriv->free_xmitbuf_cnt); */
+			/* RTW_INFO("!m2u ); */
 			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_stop);
 		}
-	}	
-#endif	// CONFIG_TX_MCAST2UNI	
+	}
+#endif /* CONFIG_TX_MCAST2UNI	 */
 
 	res = rtw_xmit(padapter, &pkt);
 	if (res < 0) {
 		#ifdef DBG_TX_DROP_FRAME
-		DBG_871X("DBG_TX_DROP_FRAME %s rtw_xmit fail\n", __FUNCTION__);
+		RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit fail\n", __FUNCTION__);
 		#endif
 		goto drop_packet;
 	}
 
-	RT_TRACE(_module_xmit_osdep_c_, _drv_info_, ("rtw_xmit_entry: tx_pkts=%d\n", (u32)pxmitpriv->tx_pkts));
 	goto exit;
 
 drop_packet:
 	pxmitpriv->tx_drop++;
 	rtw_os_pkt_complete(padapter, pkt);
-	RT_TRACE(_module_xmit_osdep_c_, _drv_notice_, ("rtw_xmit_entry: drop, tx_drop=%d\n", (u32)pxmitpriv->tx_drop));
 
 exit:
 
-_func_exit_;
 
 	return 0;
 }
@@ -546,4 +535,3 @@ int rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
 
 	return ret;
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/osdep_service.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/osdep_service.c
index caf6dbb92fb2..54984b6d9301 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/osdep_service.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/os_dep/osdep_service.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *                                        
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
  * 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.
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 
 
 #define _OSDEP_SERVICE_C_
@@ -38,101 +34,102 @@ atomic_t _malloc_size = ATOMIC_INIT(0);
 * Translate the OS dependent @param error_code to OS independent RTW_STATUS_CODE
 * @return: one of RTW_STATUS_CODE
 */
-inline int RTW_STATUS_CODE(int error_code){
-	if(error_code >=0)
+inline int RTW_STATUS_CODE(int error_code)
+{
+	if (error_code >= 0)
 		return _SUCCESS;
 
-	switch(error_code) {
-		//case -ETIMEDOUT:
-		//	return RTW_STATUS_TIMEDOUT;
-		default:
-			return _FAIL;
+	switch (error_code) {
+	/* case -ETIMEDOUT: */
+	/*	return RTW_STATUS_TIMEDOUT; */
+	default:
+		return _FAIL;
 	}
 }
 #else
-inline int RTW_STATUS_CODE(int error_code){
+inline int RTW_STATUS_CODE(int error_code)
+{
 	return error_code;
 }
 #endif
 
-u32 rtw_atoi(u8* s)
+u32 rtw_atoi(u8 *s)
 {
 
-	int num=0,flag=0;
+	int num = 0, flag = 0;
 	int i;
-	for(i=0;i<=strlen(s);i++)
-	{
-	  if(s[i] >= '0' && s[i] <= '9')
-		 num = num * 10 + s[i] -'0';
-	  else if(s[0] == '-' && i==0) 
-		 flag =1;
-	  else 
-		  break;
-	 }
+	for (i = 0; i <= strlen(s); i++) {
+		if (s[i] >= '0' && s[i] <= '9')
+			num = num * 10 + s[i] - '0';
+		else if (s[0] == '-' && i == 0)
+			flag = 1;
+		else
+			break;
+	}
 
-	if(flag == 1)
-	   num = num * -1;
+	if (flag == 1)
+		num = num * -1;
 
-	 return(num); 
+	return num;
 
 }
 
-inline u8* _rtw_vmalloc(u32 sz)
+inline void *_rtw_vmalloc(u32 sz)
 {
-	u8 	*pbuf;
-#ifdef PLATFORM_LINUX	
+	void *pbuf;
+#ifdef PLATFORM_LINUX
 	pbuf = vmalloc(sz);
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	pbuf = malloc(sz,M_DEVBUF,M_NOWAIT);	
-#endif	
-	
+	pbuf = malloc(sz, M_DEVBUF, M_NOWAIT);
+#endif
+
 #ifdef PLATFORM_WINDOWS
-	NdisAllocateMemoryWithTag(&pbuf,sz, RT_TAG);	
+	NdisAllocateMemoryWithTag(&pbuf, sz, RT_TAG);
 #endif
 
 #ifdef DBG_MEMORY_LEAK
 #ifdef PLATFORM_LINUX
-	if ( pbuf != NULL) {
+	if (pbuf != NULL) {
 		atomic_inc(&_malloc_cnt);
 		atomic_add(sz, &_malloc_size);
 	}
 #endif
 #endif /* DBG_MEMORY_LEAK */
 
-	return pbuf;	
+	return pbuf;
 }
 
-inline u8* _rtw_zvmalloc(u32 sz)
+inline void *_rtw_zvmalloc(u32 sz)
 {
-	u8 	*pbuf;
+	void *pbuf;
 #ifdef PLATFORM_LINUX
 	pbuf = _rtw_vmalloc(sz);
 	if (pbuf != NULL)
 		memset(pbuf, 0, sz);
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	pbuf = malloc(sz,M_DEVBUF,M_ZERO|M_NOWAIT);	
-#endif	
+	pbuf = malloc(sz, M_DEVBUF, M_ZERO | M_NOWAIT);
+#endif
 #ifdef PLATFORM_WINDOWS
-	NdisAllocateMemoryWithTag(&pbuf,sz, RT_TAG);
+	NdisAllocateMemoryWithTag(&pbuf, sz, RT_TAG);
 	if (pbuf != NULL)
 		NdisFillMemory(pbuf, sz, 0);
 #endif
 
-	return pbuf;	
+	return pbuf;
 }
 
-inline void _rtw_vmfree(u8 *pbuf, u32 sz)
+inline void _rtw_vmfree(void *pbuf, u32 sz)
 {
-#ifdef	PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 	vfree(pbuf);
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	free(pbuf,M_DEVBUF);	
-#endif	
+	free(pbuf, M_DEVBUF);
+#endif
 #ifdef PLATFORM_WINDOWS
-	NdisFreeMemory(pbuf,sz, 0);
+	NdisFreeMemory(pbuf, sz, 0);
 #endif
 
 #ifdef DBG_MEMORY_LEAK
@@ -143,135 +140,134 @@ inline void _rtw_vmfree(u8 *pbuf, u32 sz)
 #endif /* DBG_MEMORY_LEAK */
 }
 
-u8* _rtw_malloc(u32 sz)
+void *_rtw_malloc(u32 sz)
 {
-
-	u8 	*pbuf=NULL;
+	void *pbuf = NULL;
 
 #ifdef PLATFORM_LINUX
 #ifdef RTK_DMP_PLATFORM
-	if(sz > 0x4000)
-		pbuf = (u8 *)dvr_malloc(sz);
+	if (sz > 0x4000)
+		pbuf = dvr_malloc(sz);
 	else
-#endif		
-		pbuf = kmalloc(sz,in_interrupt() ? GFP_ATOMIC : GFP_KERNEL); 		
+#endif
+		pbuf = kmalloc(sz, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	pbuf = malloc(sz,M_DEVBUF,M_NOWAIT);	
-#endif		
+	pbuf = malloc(sz, M_DEVBUF, M_NOWAIT);
+#endif
 #ifdef PLATFORM_WINDOWS
 
-	NdisAllocateMemoryWithTag(&pbuf,sz, RT_TAG);
+	NdisAllocateMemoryWithTag(&pbuf, sz, RT_TAG);
 
 #endif
 
 #ifdef DBG_MEMORY_LEAK
 #ifdef PLATFORM_LINUX
-	if ( pbuf != NULL) {
+	if (pbuf != NULL) {
 		atomic_inc(&_malloc_cnt);
 		atomic_add(sz, &_malloc_size);
 	}
 #endif
 #endif /* DBG_MEMORY_LEAK */
 
-	return pbuf;	
-	
+	return pbuf;
+
 }
 
 
-u8* _rtw_zmalloc(u32 sz)
+void *_rtw_zmalloc(u32 sz)
 {
 #ifdef PLATFORM_FREEBSD
-	return malloc(sz,M_DEVBUF,M_ZERO|M_NOWAIT);
-#else // PLATFORM_FREEBSD
-	u8 	*pbuf = _rtw_malloc(sz);
+	return malloc(sz, M_DEVBUF, M_ZERO | M_NOWAIT);
+#else /* PLATFORM_FREEBSD */
+	void *pbuf = _rtw_malloc(sz);
 
 	if (pbuf != NULL) {
 
 #ifdef PLATFORM_LINUX
 		memset(pbuf, 0, sz);
-#endif	
-	
+#endif
+
 #ifdef PLATFORM_WINDOWS
 		NdisFillMemory(pbuf, sz, 0);
 #endif
 
 	}
 
-	return pbuf;	
-#endif // PLATFORM_FREEBSD
+	return pbuf;
+#endif /* PLATFORM_FREEBSD */
 }
 
-void	_rtw_mfree(u8 *pbuf, u32 sz)
+void _rtw_mfree(void *pbuf, u32 sz)
 {
 
-#ifdef	PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 #ifdef RTK_DMP_PLATFORM
-	if(sz > 0x4000)
+	if (sz > 0x4000)
 		dvr_free(pbuf);
 	else
 #endif
 		kfree(pbuf);
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	free(pbuf,M_DEVBUF);	
-#endif		
+	free(pbuf, M_DEVBUF);
+#endif
 #ifdef PLATFORM_WINDOWS
 
-	NdisFreeMemory(pbuf,sz, 0);
+	NdisFreeMemory(pbuf, sz, 0);
 
 #endif
-	
+
 #ifdef DBG_MEMORY_LEAK
 #ifdef PLATFORM_LINUX
 	atomic_dec(&_malloc_cnt);
 	atomic_sub(sz, &_malloc_size);
 #endif
 #endif /* DBG_MEMORY_LEAK */
-	
+
 }
 
 #ifdef PLATFORM_FREEBSD
-//review again
-struct sk_buff * dev_alloc_skb(unsigned int size)
+/* review again */
+struct sk_buff *dev_alloc_skb(unsigned int size)
 {
-	struct sk_buff *skb=NULL;
-    	u8 *data=NULL;
-	
-	//skb = (struct sk_buff *)_rtw_zmalloc(sizeof(struct sk_buff)); // for skb->len, etc.
-	skb = (struct sk_buff *)_rtw_malloc(sizeof(struct sk_buff));
-	if(!skb)
+	struct sk_buff *skb = NULL;
+	u8 *data = NULL;
+
+	/* skb = _rtw_zmalloc(sizeof(struct sk_buff)); */ /* for skb->len, etc. */
+	skb = _rtw_malloc(sizeof(struct sk_buff));
+	if (!skb)
 		goto out;
 	data = _rtw_malloc(size);
-	if(!data)
+	if (!data)
 		goto nodata;
 
-	skb->head = (unsigned char*)data;
-	skb->data = (unsigned char*)data;
-	skb->tail = (unsigned char*)data;
-	skb->end = (unsigned char*)data + size;
+	skb->head = (unsigned char *)data;
+	skb->data = (unsigned char *)data;
+	skb->tail = (unsigned char *)data;
+	skb->end = (unsigned char *)data + size;
 	skb->len = 0;
-	//printf("%s()-%d: skb=%p, skb->head = %p\n", __FUNCTION__, __LINE__, skb, skb->head);
+	/* printf("%s()-%d: skb=%p, skb->head = %p\n", __FUNCTION__, __LINE__, skb, skb->head); */
 
 out:
 	return skb;
 nodata:
-	_rtw_mfree((u8 *)skb, sizeof(struct sk_buff));
+	_rtw_mfree(skb, sizeof(struct sk_buff));
 	skb = NULL;
-goto out;
-	
+	goto out;
+
 }
 
 void dev_kfree_skb_any(struct sk_buff *skb)
 {
-	//printf("%s()-%d: skb->head = %p\n", __FUNCTION__, __LINE__, skb->head);
-	if(skb->head)
+	/* printf("%s()-%d: skb->head = %p\n", __FUNCTION__, __LINE__, skb->head); */
+	if (skb->head)
 		_rtw_mfree(skb->head, 0);
-	//printf("%s()-%d: skb = %p\n", __FUNCTION__, __LINE__, skb);
-	if(skb)
-		_rtw_mfree((u8 *)skb, 0);
+	/* printf("%s()-%d: skb = %p\n", __FUNCTION__, __LINE__, skb); */
+	if (skb)
+		_rtw_mfree(skb, 0);
 }
 struct sk_buff *skb_clone(const struct sk_buff *skb)
 {
@@ -317,19 +313,59 @@ inline struct sk_buff *_rtw_skb_clone(struct sk_buff *skb)
 	return skb_clone(skb);
 #endif /* PLATFORM_FREEBSD */
 }
-
-inline int _rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb)
+inline struct sk_buff *_rtw_pskb_copy(struct sk_buff *skb)
 {
 #ifdef PLATFORM_LINUX
-	skb->dev = ndev;
-	return netif_rx(skb);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
+	return pskb_copy(skb, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+#else
+	return skb_clone(skb, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
+#endif
 #endif /* PLATFORM_LINUX */
 
 #ifdef PLATFORM_FREEBSD
-	return (*ndev->if_input)(ndev, skb);
+	return NULL;
 #endif /* PLATFORM_FREEBSD */
 }
 
+inline int _rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb)
+{
+#if defined(PLATFORM_LINUX)
+	skb->dev = ndev;
+	return netif_rx(skb);
+#elif defined(PLATFORM_FREEBSD)
+	return (*ndev->if_input)(ndev, skb);
+#else
+	rtw_warn_on(1);
+	return -1;
+#endif
+}
+
+#ifdef CONFIG_RTW_NAPI
+inline int _rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb)
+{
+#if defined(PLATFORM_LINUX)
+	skb->dev = ndev;
+	return netif_receive_skb(skb);
+#else
+	rtw_warn_on(1);
+	return -1;
+#endif
+}
+
+#ifdef CONFIG_RTW_GRO
+inline gro_result_t _rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb)
+{
+#if defined(PLATFORM_LINUX)
+	return napi_gro_receive(napi, skb);
+#else
+	rtw_warn_on(1);
+	return -1;
+#endif
+}
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
+
 void _rtw_skb_queue_purge(struct sk_buff_head *list)
 {
 	struct sk_buff *skb;
@@ -342,22 +378,22 @@ void _rtw_skb_queue_purge(struct sk_buff_head *list)
 inline void *_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma)
 {
 #ifdef PLATFORM_LINUX
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	return usb_alloc_coherent(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);
 #else
 	return usb_buffer_alloc(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);
 #endif
 #endif /* PLATFORM_LINUX */
-	
+
 #ifdef PLATFORM_FREEBSD
-	return (malloc(size, M_USBDEV, M_NOWAIT | M_ZERO));
+	return malloc(size, M_USBDEV, M_NOWAIT | M_ZERO);
 #endif /* PLATFORM_FREEBSD */
 }
 inline void _rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma)
 {
 #ifdef PLATFORM_LINUX
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
-	usb_free_coherent(dev, size, addr, dma); 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
+	usb_free_coherent(dev, size, addr, dma);
 #else
 	usb_buffer_free(dev, size, addr, dma);
 #endif
@@ -372,10 +408,10 @@ inline void _rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr
 #if defined(DBG_MEM_ALLOC)
 
 struct rtw_mem_stat {
-	ATOMIC_T alloc; // the memory bytes we allocate currently
-	ATOMIC_T peak; // the peak memory bytes we allocate 
-	ATOMIC_T alloc_cnt; // the alloc count for alloc currently
-	ATOMIC_T alloc_err_cnt; // the error times we fail to allocate memory
+	ATOMIC_T alloc; /* the memory bytes we allocate currently */
+	ATOMIC_T peak; /* the peak memory bytes we allocate */
+	ATOMIC_T alloc_cnt; /* the alloc count for alloc currently */
+	ATOMIC_T alloc_err_cnt; /* the error times we fail to allocate memory */
 };
 
 struct rtw_mem_stat rtw_mem_type_stat[mstat_tf_idx(MSTAT_TYPE_MAX)];
@@ -408,56 +444,54 @@ void rtw_mstat_dump(void *sel)
 #ifdef RTW_MEM_FUNC_STAT
 	int value_f[4][mstat_ff_idx(MSTAT_FUNC_MAX)];
 #endif
-	
+
 	int vir_alloc, vir_peak, vir_alloc_err, phy_alloc, phy_peak, phy_alloc_err;
 	int tx_alloc, tx_peak, tx_alloc_err, rx_alloc, rx_peak, rx_alloc_err;
 
-	for(i=0;i<mstat_tf_idx(MSTAT_TYPE_MAX);i++) {
+	for (i = 0; i < mstat_tf_idx(MSTAT_TYPE_MAX); i++) {
 		value_t[0][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].alloc));
 		value_t[1][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].peak));
 		value_t[2][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].alloc_cnt));
 		value_t[3][i] = ATOMIC_READ(&(rtw_mem_type_stat[i].alloc_err_cnt));
 	}
 
-	#ifdef RTW_MEM_FUNC_STAT
-	for(i=0;i<mstat_ff_idx(MSTAT_FUNC_MAX);i++) {
+#ifdef RTW_MEM_FUNC_STAT
+	for (i = 0; i < mstat_ff_idx(MSTAT_FUNC_MAX); i++) {
 		value_f[0][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].alloc));
 		value_f[1][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].peak));
 		value_f[2][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].alloc_cnt));
 		value_f[3][i] = ATOMIC_READ(&(rtw_mem_func_stat[i].alloc_err_cnt));
 	}
-	#endif
+#endif
 
-	DBG_871X_SEL_NL(sel, "===================== MSTAT =====================\n");
-	DBG_871X_SEL_NL(sel, "%4s %10s %10s %10s %10s\n", "TAG", "alloc", "peak", "aloc_cnt", "err_cnt");
-	DBG_871X_SEL_NL(sel, "-------------------------------------------------\n");
-	for(i=0;i<mstat_tf_idx(MSTAT_TYPE_MAX);i++) {
-		DBG_871X_SEL_NL(sel, "%4s %10d %10d %10d %10d\n", MSTAT_TYPE_str[i], value_t[0][i], value_t[1][i], value_t[2][i], value_t[3][i]);
-	}
-	#ifdef RTW_MEM_FUNC_STAT
-	DBG_871X_SEL_NL(sel, "-------------------------------------------------\n");
-	for(i=0;i<mstat_ff_idx(MSTAT_FUNC_MAX);i++) {
-		DBG_871X_SEL_NL(sel, "%4s %10d %10d %10d %10d\n", MSTAT_FUNC_str[i], value_f[0][i], value_f[1][i], value_f[2][i], value_f[3][i]);
-	}
-	#endif
+	RTW_PRINT_SEL(sel, "===================== MSTAT =====================\n");
+	RTW_PRINT_SEL(sel, "%4s %10s %10s %10s %10s\n", "TAG", "alloc", "peak", "aloc_cnt", "err_cnt");
+	RTW_PRINT_SEL(sel, "-------------------------------------------------\n");
+	for (i = 0; i < mstat_tf_idx(MSTAT_TYPE_MAX); i++)
+		RTW_PRINT_SEL(sel, "%4s %10d %10d %10d %10d\n", MSTAT_TYPE_str[i], value_t[0][i], value_t[1][i], value_t[2][i], value_t[3][i]);
+#ifdef RTW_MEM_FUNC_STAT
+	RTW_PRINT_SEL(sel, "-------------------------------------------------\n");
+	for (i = 0; i < mstat_ff_idx(MSTAT_FUNC_MAX); i++)
+		RTW_PRINT_SEL(sel, "%4s %10d %10d %10d %10d\n", MSTAT_FUNC_str[i], value_f[0][i], value_f[1][i], value_f[2][i], value_f[3][i]);
+#endif
 }
 
 void rtw_mstat_update(const enum mstat_f flags, const MSTAT_STATUS status, u32 sz)
 {
-	static u32 update_time = 0;
+	static systime update_time = 0;
 	int peak, alloc;
 	int i;
 
 	/* initialization */
-	if(!update_time) {
-		for(i=0;i<mstat_tf_idx(MSTAT_TYPE_MAX);i++) {
+	if (!update_time) {
+		for (i = 0; i < mstat_tf_idx(MSTAT_TYPE_MAX); i++) {
 			ATOMIC_SET(&(rtw_mem_type_stat[i].alloc), 0);
 			ATOMIC_SET(&(rtw_mem_type_stat[i].peak), 0);
 			ATOMIC_SET(&(rtw_mem_type_stat[i].alloc_cnt), 0);
 			ATOMIC_SET(&(rtw_mem_type_stat[i].alloc_err_cnt), 0);
 		}
 		#ifdef RTW_MEM_FUNC_STAT
-		for(i=0;i<mstat_ff_idx(MSTAT_FUNC_MAX);i++) {
+		for (i = 0; i < mstat_ff_idx(MSTAT_FUNC_MAX); i++) {
 			ATOMIC_SET(&(rtw_mem_func_stat[i].alloc), 0);
 			ATOMIC_SET(&(rtw_mem_func_stat[i].peak), 0);
 			ATOMIC_SET(&(rtw_mem_func_stat[i].alloc_cnt), 0);
@@ -466,44 +500,44 @@ void rtw_mstat_update(const enum mstat_f flags, const MSTAT_STATUS status, u32 s
 		#endif
 	}
 
-	switch(status) {
-		case MSTAT_ALLOC_SUCCESS:
-			ATOMIC_INC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_cnt));
-			alloc = ATOMIC_ADD_RETURN(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc), sz);
-			peak=ATOMIC_READ(&(rtw_mem_type_stat[mstat_tf_idx(flags)].peak));
-			if (peak<alloc)
-				ATOMIC_SET(&(rtw_mem_type_stat[mstat_tf_idx(flags)].peak), alloc);
-
-			#ifdef RTW_MEM_FUNC_STAT
-			ATOMIC_INC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_cnt));
-			alloc = ATOMIC_ADD_RETURN(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc), sz);
-			peak=ATOMIC_READ(&(rtw_mem_func_stat[mstat_ff_idx(flags)].peak));
-			if (peak<alloc)
-				ATOMIC_SET(&(rtw_mem_func_stat[mstat_ff_idx(flags)].peak), alloc);
-			#endif
-			break;
+	switch (status) {
+	case MSTAT_ALLOC_SUCCESS:
+		ATOMIC_INC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_cnt));
+		alloc = ATOMIC_ADD_RETURN(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc), sz);
+		peak = ATOMIC_READ(&(rtw_mem_type_stat[mstat_tf_idx(flags)].peak));
+		if (peak < alloc)
+			ATOMIC_SET(&(rtw_mem_type_stat[mstat_tf_idx(flags)].peak), alloc);
 
-		case MSTAT_ALLOC_FAIL:
-			ATOMIC_INC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_err_cnt));
-			#ifdef RTW_MEM_FUNC_STAT
-			ATOMIC_INC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_err_cnt));
-			#endif
-			break;
+		#ifdef RTW_MEM_FUNC_STAT
+		ATOMIC_INC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_cnt));
+		alloc = ATOMIC_ADD_RETURN(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc), sz);
+		peak = ATOMIC_READ(&(rtw_mem_func_stat[mstat_ff_idx(flags)].peak));
+		if (peak < alloc)
+			ATOMIC_SET(&(rtw_mem_func_stat[mstat_ff_idx(flags)].peak), alloc);
+		#endif
+		break;
 
-		case MSTAT_FREE:
-			ATOMIC_DEC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_cnt));
-			ATOMIC_SUB(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc), sz);
-			#ifdef RTW_MEM_FUNC_STAT
-			ATOMIC_DEC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_cnt));
-			ATOMIC_SUB(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc), sz);
-			#endif
-			break;
+	case MSTAT_ALLOC_FAIL:
+		ATOMIC_INC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_err_cnt));
+		#ifdef RTW_MEM_FUNC_STAT
+		ATOMIC_INC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_err_cnt));
+		#endif
+		break;
+
+	case MSTAT_FREE:
+		ATOMIC_DEC(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc_cnt));
+		ATOMIC_SUB(&(rtw_mem_type_stat[mstat_tf_idx(flags)].alloc), sz);
+		#ifdef RTW_MEM_FUNC_STAT
+		ATOMIC_DEC(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc_cnt));
+		ATOMIC_SUB(&(rtw_mem_func_stat[mstat_ff_idx(flags)].alloc), sz);
+		#endif
+		break;
 	};
 
-	//if (rtw_get_passing_time_ms(update_time) > 5000) {
-	//	rtw_mstat_dump(RTW_DBGDUMP);
-		update_time=rtw_get_current_time();
-	//}
+	/* if (rtw_get_passing_time_ms(update_time) > 5000) { */
+	/*	rtw_mstat_dump(RTW_DBGDUMP); */
+	update_time = rtw_get_current_time();
+	/* } */
 }
 
 #ifndef SIZE_MAX
@@ -520,47 +554,47 @@ struct mstat_sniff_rule mstat_sniff_rules[] = {
 	{MSTAT_TYPE_PHY, 4097, SIZE_MAX},
 };
 
-int mstat_sniff_rule_num = sizeof(mstat_sniff_rules)/sizeof(struct mstat_sniff_rule);
+int mstat_sniff_rule_num = sizeof(mstat_sniff_rules) / sizeof(struct mstat_sniff_rule);
 
 bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size)
 {
 	int i;
-	for (i = 0; i<mstat_sniff_rule_num; i++) {
+	for (i = 0; i < mstat_sniff_rule_num; i++) {
 		if (mstat_sniff_rules[i].flags == flags
-				&& mstat_sniff_rules[i].lb <= size
-				&& mstat_sniff_rules[i].hb >= size)
+			&& mstat_sniff_rules[i].lb <= size
+			&& mstat_sniff_rules[i].hb >= size)
 			return _TRUE;
 	}
 
 	return _FALSE;
 }
 
-inline u8* dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8  *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
-	
-	p=_rtw_vmalloc((sz));
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+
+	p = _rtw_vmalloc((sz));
 
 	rtw_mstat_update(
 		flags
 		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
 		, sz
 	);
-	
+
 	return p;
 }
 
-inline u8* dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8 *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
 
-	p=_rtw_zvmalloc((sz)); 
+	p = _rtw_zvmalloc((sz));
 
 	rtw_mstat_update(
 		flags
@@ -571,13 +605,13 @@ inline u8* dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func,
 	return p;
 }
 
-inline void dbg_rtw_vmfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void dbg_rtw_vmfree(void *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
 
 	if (match_mstat_sniff_rules(flags, sz))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
 
-	_rtw_vmfree((pbuf), (sz)); 
+	_rtw_vmfree((pbuf), (sz));
 
 	rtw_mstat_update(
 		flags
@@ -586,14 +620,14 @@ inline void dbg_rtw_vmfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const cha
 	);
 }
 
-inline u8* dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line) 
+inline void *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8 *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
 
-	p=_rtw_malloc((sz));
+	p = _rtw_malloc((sz));
 
 	rtw_mstat_update(
 		flags
@@ -604,12 +638,12 @@ inline u8* dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, co
 	return p;
 }
 
-inline u8* dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8 *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
 
 	p = _rtw_zmalloc((sz));
 
@@ -622,10 +656,10 @@ inline u8* dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, c
 	return p;
 }
 
-inline void dbg_rtw_mfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void dbg_rtw_mfree(void *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
 	if (match_mstat_sniff_rules(flags, sz))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
 
 	_rtw_mfree((pbuf), (sz));
 
@@ -636,18 +670,18 @@ inline void dbg_rtw_mfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const char
 	);
 }
 
-inline struct sk_buff * dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, int line)
+inline struct sk_buff *dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, int line)
 {
 	struct sk_buff *skb;
 	unsigned int truesize = 0;
 
 	skb = _rtw_skb_alloc(size);
 
-	if(skb)
+	if (skb)
 		truesize = skb->truesize;
 
-	if(!skb || truesize < size || match_mstat_sniff_rules(flags, truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, size, skb, truesize);
+	if (!skb || truesize < size || match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d), skb:%p, truesize=%u\n", func, line, __FUNCTION__, size, skb, truesize);
 
 	rtw_mstat_update(
 		flags
@@ -662,8 +696,8 @@ inline void dbg_rtw_skb_free(struct sk_buff *skb, const enum mstat_f flags, cons
 {
 	unsigned int truesize = skb->truesize;
 
-	if(match_mstat_sniff_rules(flags, truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
 
 	_rtw_skb_free(skb);
 
@@ -679,13 +713,13 @@ inline struct sk_buff *dbg_rtw_skb_copy(const struct sk_buff *skb, const enum ms
 	struct sk_buff *skb_cp;
 	unsigned int truesize = skb->truesize;
 	unsigned int cp_truesize = 0;
-	
+
 	skb_cp = _rtw_skb_copy(skb);
-	if(skb_cp)
+	if (skb_cp)
 		cp_truesize = skb_cp->truesize;
 
-	if(!skb_cp || cp_truesize < truesize || match_mstat_sniff_rules(flags, cp_truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%u), skb_cp:%p, cp_truesize=%u\n", func, line, __FUNCTION__, truesize, skb_cp, cp_truesize);
+	if (!skb_cp || cp_truesize < truesize || match_mstat_sniff_rules(flags, cp_truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u), skb_cp:%p, cp_truesize=%u\n", func, line, __FUNCTION__, truesize, skb_cp, cp_truesize);
 
 	rtw_mstat_update(
 		flags
@@ -703,11 +737,11 @@ inline struct sk_buff *dbg_rtw_skb_clone(struct sk_buff *skb, const enum mstat_f
 	unsigned int cl_truesize = 0;
 
 	skb_cl = _rtw_skb_clone(skb);
-	if(skb_cl)
+	if (skb_cl)
 		cl_truesize = skb_cl->truesize;
 
-	if(!skb_cl || cl_truesize < truesize || match_mstat_sniff_rules(flags, cl_truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%u), skb_cl:%p, cl_truesize=%u\n", func, line, __FUNCTION__, truesize, skb_cl, cl_truesize);
+	if (!skb_cl || cl_truesize < truesize || match_mstat_sniff_rules(flags, cl_truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u), skb_cl:%p, cl_truesize=%u\n", func, line, __FUNCTION__, truesize, skb_cl, cl_truesize);
 
 	rtw_mstat_update(
 		flags
@@ -723,11 +757,51 @@ inline int dbg_rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb, const enum mstat
 	int ret;
 	unsigned int truesize = skb->truesize;
 
-	if(match_mstat_sniff_rules(flags, truesize))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
 
 	ret = _rtw_netif_rx(ndev, skb);
-	
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+
+	return ret;
+}
+
+#ifdef CONFIG_RTW_NAPI
+inline int dbg_rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)
+{
+	int ret;
+	unsigned int truesize = skb->truesize;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	ret = _rtw_netif_receive_skb(ndev, skb);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, truesize
+	);
+
+	return ret;
+}
+
+#ifdef CONFIG_RTW_GRO
+inline gro_result_t dbg_rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)
+{
+	int ret;
+	unsigned int truesize = skb->truesize;
+
+	if (match_mstat_sniff_rules(flags, truesize))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s, truesize=%u\n", func, line, __FUNCTION__, truesize);
+
+	ret = _rtw_napi_gro_receive(napi, skb);
+
 	rtw_mstat_update(
 		flags
 		, MSTAT_FREE
@@ -736,6 +810,8 @@ inline int dbg_rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb, const enum mstat
 
 	return ret;
 }
+#endif /* CONFIG_RTW_GRO */
+#endif /* CONFIG_RTW_NAPI */
 
 inline void dbg_rtw_skb_queue_purge(struct sk_buff_head *list, enum mstat_f flags, const char *func, int line)
 {
@@ -750,11 +826,11 @@ inline void *dbg_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_a
 {
 	void *p;
 
-	if(match_mstat_sniff_rules(flags, size))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%zu)\n", func, line, __FUNCTION__, size);
+	if (match_mstat_sniff_rules(flags, size))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%zu)\n", func, line, __FUNCTION__, size);
 
 	p = _rtw_usb_buffer_alloc(dev, size, dma);
-	
+
 	rtw_mstat_update(
 		flags
 		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
@@ -767,8 +843,8 @@ inline void *dbg_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_a
 inline void dbg_rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma, const enum mstat_f flags, const char *func, int line)
 {
 
-	if(match_mstat_sniff_rules(flags, size))
-		DBG_871X("DBG_MEM_ALLOC %s:%d %s(%zu)\n", func, line, __FUNCTION__, size);
+	if (match_mstat_sniff_rules(flags, size))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%zu)\n", func, line, __FUNCTION__, size);
 
 	_rtw_usb_buffer_free(dev, size, addr, dma);
 
@@ -782,36 +858,79 @@ inline void dbg_rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *a
 
 #endif /* defined(DBG_MEM_ALLOC) */
 
-void* rtw_malloc2d(int h, int w, size_t size)
+void *rtw_malloc2d(int h, int w, size_t size)
 {
 	int j;
 
-	void **a = (void **) rtw_zmalloc( h*sizeof(void *) + h*w*size );
-	if(a == NULL)
-	{
-		DBG_871X("%s: alloc memory fail!\n", __FUNCTION__);
+	void **a = (void **) rtw_zmalloc(h * sizeof(void *) + h * w * size);
+	if (a == NULL) {
+		RTW_INFO("%s: alloc memory fail!\n", __FUNCTION__);
 		return NULL;
 	}
 
-	for( j=0; j<h; j++ )
-		a[j] = ((char *)(a+h)) + j*w*size;
+	for (j = 0; j < h; j++)
+		a[j] = ((char *)(a + h)) + j * w * size;
 
 	return a;
 }
 
 void rtw_mfree2d(void *pbuf, int h, int w, int size)
 {
-	rtw_mfree((u8 *)pbuf, h*sizeof(void*) + w*h*size);
+	rtw_mfree((u8 *)pbuf, h * sizeof(void *) + w * h * size);
+}
+
+inline void rtw_os_pkt_free(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	rtw_skb_free(pkt);
+#elif defined(PLATFORM_FREEBSD)
+	m_freem(pkt);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline _pkt *rtw_os_pkt_copy(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	return rtw_skb_copy(pkt);
+#elif defined(PLATFORM_FREEBSD)
+	return m_dup(pkt, M_NOWAIT);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void *rtw_os_pkt_data(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	return pkt->data;
+#elif defined(PLATFORM_FREEBSD)
+	return pkt->m_data;
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline u32 rtw_os_pkt_len(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	return pkt->len;
+#elif defined(PLATFORM_FREEBSD)
+	return pkt->m_pkthdr.len;
+#else
+	#error "TBD\n"
+#endif
 }
 
 void _rtw_memcpy(void *dst, const void *src, u32 sz)
 {
 
-#if defined (PLATFORM_LINUX)|| defined (PLATFORM_FREEBSD)
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_FREEBSD)
 
 	memcpy(dst, src, sz);
 
-#endif	
+#endif
 
 #ifdef PLATFORM_WINDOWS
 
@@ -826,15 +945,15 @@ inline void _rtw_memmove(void *dst, const void *src, u32 sz)
 #if defined(PLATFORM_LINUX)
 	memmove(dst, src, sz);
 #else
-	#warning "no implementation\n"
+	#error "TBD\n"
 #endif
 }
 
 int	_rtw_memcmp(const void *dst, const void *src, u32 sz)
 {
 
-#if defined (PLATFORM_LINUX)|| defined (PLATFORM_FREEBSD)
-//under Linux/GNU/GLibc, the return value of memcmp for two same mem. chunk is 0
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_FREEBSD)
+	/* under Linux/GNU/GLibc, the return value of memcmp for two same mem. chunk is 0 */
 
 	if (!(memcmp(dst, src, sz)))
 		return _TRUE;
@@ -844,32 +963,33 @@ int	_rtw_memcmp(const void *dst, const void *src, u32 sz)
 
 
 #ifdef PLATFORM_WINDOWS
-//under Windows, the return value of NdisEqualMemory for two same mem. chunk is 1
-	
-	if (NdisEqualMemory (dst, src, sz))
+	/* under Windows, the return value of NdisEqualMemory for two same mem. chunk is 1 */
+
+	if (NdisEqualMemory(dst, src, sz))
 		return _TRUE;
 	else
 		return _FALSE;
 
-#endif	
-	
-	
-	
+#endif
+
+
+
 }
 
 void _rtw_memset(void *pbuf, int c, u32 sz)
 {
 
-#if defined (PLATFORM_LINUX)|| defined (PLATFORM_FREEBSD)
+#if defined(PLATFORM_LINUX) || defined (PLATFORM_FREEBSD)
 
-        memset(pbuf, c, sz);
+	memset(pbuf, c, sz);
 
 #endif
 
 #ifdef PLATFORM_WINDOWS
 #if 0
 	NdisZeroMemory(pbuf, sz);
-	if (c != 0) memset(pbuf, c, sz);
+	if (c != 0)
+		memset(pbuf, c, sz);
 #else
 	NdisFillMemory(pbuf, sz, c);
 #endif
@@ -879,11 +999,11 @@ void _rtw_memset(void *pbuf, int c, u32 sz)
 
 #ifdef PLATFORM_FREEBSD
 static inline void __list_add(_list *pnew, _list *pprev, _list *pnext)
- {
-         pnext->prev = pnew;
-         pnew->next = pnext;
-         pnew->prev = pprev;
-         pprev->next = pnew;
+{
+	pnext->prev = pnew;
+	pnew->next = pnext;
+	pnew->prev = pprev;
+	pprev->next = pnew;
 }
 #endif /* PLATFORM_FREEBSD */
 
@@ -893,17 +1013,17 @@ void _rtw_init_listhead(_list *list)
 
 #ifdef PLATFORM_LINUX
 
-        INIT_LIST_HEAD(list);
+	INIT_LIST_HEAD(list);
 
 #endif
 
 #ifdef PLATFORM_FREEBSD
-         list->next = list;
-         list->prev = list;
+	list->next = list;
+	list->prev = list;
 #endif
 #ifdef PLATFORM_WINDOWS
 
-        NdisInitializeListHead(list);
+	NdisInitializeListHead(list);
 
 #endif
 
@@ -911,7 +1031,7 @@ void _rtw_init_listhead(_list *list)
 
 
 /*
-For the following list_xxx operations, 
+For the following list_xxx operations,
 caller must guarantee the atomic context.
 Otherwise, there will be racing condition.
 */
@@ -945,7 +1065,7 @@ u32	rtw_is_list_empty(_list *phead)
 
 #endif
 
-	
+
 }
 
 void rtw_list_insert_head(_list *plist, _list *phead)
@@ -967,36 +1087,113 @@ void rtw_list_insert_head(_list *plist, _list *phead)
 void rtw_list_insert_tail(_list *plist, _list *phead)
 {
 
-#ifdef PLATFORM_LINUX	
-	
+#ifdef PLATFORM_LINUX
+
 	list_add_tail(plist, phead);
-	
+
 #endif
 #ifdef PLATFORM_FREEBSD
-	
+
 	__list_add(plist, phead->prev, phead);
-	
-#endif	
+
+#endif
 #ifdef PLATFORM_WINDOWS
 
-  InsertTailList(phead, plist);
+	InsertTailList(phead, plist);
 
-#endif		
-	
+#endif
+
+}
+
+inline void rtw_list_splice(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	list_splice(list, head);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_list_splice_init(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	list_splice_init(list, head);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_list_splice_tail(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27))
+	if (!list_empty(list))
+		__list_splice(list, head);
+	#else
+	list_splice_tail(list, head);
+	#endif
+#else
+	#error "TBD\n"
+#endif
 }
 
-void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc)
+inline void rtw_hlist_head_init(rtw_hlist_head *h)
 {
-	_adapter *adapter = (_adapter *)padapter;	
+#ifdef PLATFORM_LINUX
+	INIT_HLIST_HEAD(h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_add_head(rtw_hlist_node *n, rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	hlist_add_head(n, h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_del(rtw_hlist_node *n)
+{
+#ifdef PLATFORM_LINUX
+	hlist_del(n);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_add_head_rcu(rtw_hlist_node *n, rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	hlist_add_head_rcu(n, h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_del_rcu(rtw_hlist_node *n)
+{
+#ifdef PLATFORM_LINUX
+	hlist_del_rcu(n);
+#else
+	#error "TBD\n"
+#endif
+}
+
+void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc, void *ctx)
+{
+	_adapter *adapter = (_adapter *)padapter;
 
 #ifdef PLATFORM_LINUX
-	_init_timer(ptimer, adapter->pnetdev, pfunc, adapter);
+	_init_timer(ptimer, adapter->pnetdev, pfunc, ctx);
 #endif
 #ifdef PLATFORM_FREEBSD
-	_init_timer(ptimer, adapter->pifp, pfunc, adapter->mlmepriv.nic_hdl);
+	_init_timer(ptimer, adapter->pifp, pfunc, ctx);
 #endif
 #ifdef PLATFORM_WINDOWS
-	_init_timer(ptimer, adapter->hndis_adapter, pfunc, adapter->mlmepriv.nic_hdl);
+	_init_timer(ptimer, adapter->hndis_adapter, pfunc, ctx);
 #endif
 }
 
@@ -1020,12 +1217,12 @@ void _rtw_init_sema(_sema	*sema, int init_val)
 #endif
 #ifdef PLATFORM_OS_XP
 
-	KeInitializeSemaphore(sema, init_val,  SEMA_UPBND); // count=0;
+	KeInitializeSemaphore(sema, init_val,  SEMA_UPBND); /* count=0; */
 
 #endif
-	
+
 #ifdef PLATFORM_OS_CE
-	if(*sema == NULL)
+	if (*sema == NULL)
 		*sema = CreateSemaphore(NULL, init_val, SEMA_UPBND, NULL);
 #endif
 
@@ -1049,18 +1246,18 @@ void _rtw_up_sema(_sema	*sema)
 
 	up(sema);
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
 	sema_post(sema);
 #endif
 #ifdef PLATFORM_OS_XP
 
-	KeReleaseSemaphore(sema, IO_NETWORK_INCREMENT, 1,  FALSE );
+	KeReleaseSemaphore(sema, IO_NETWORK_INCREMENT, 1,  FALSE);
 
 #endif
 
 #ifdef PLATFORM_OS_CE
-	ReleaseSemaphore(*sema,  1,  NULL );
+	ReleaseSemaphore(*sema,  1,  NULL);
 #endif
 }
 
@@ -1068,40 +1265,76 @@ u32 _rtw_down_sema(_sema *sema)
 {
 
 #ifdef PLATFORM_LINUX
-	
+
 	if (down_interruptible(sema))
 		return _FAIL;
 	else
 		return _SUCCESS;
 
-#endif    	
+#endif
 #ifdef PLATFORM_FREEBSD
 	sema_wait(sema);
 	return  _SUCCESS;
 #endif
 #ifdef PLATFORM_OS_XP
 
-	if(STATUS_SUCCESS == KeWaitForSingleObject(sema, Executive, KernelMode, TRUE, NULL))
+	if (STATUS_SUCCESS == KeWaitForSingleObject(sema, Executive, KernelMode, TRUE, NULL))
 		return  _SUCCESS;
 	else
 		return _FAIL;
 #endif
 
 #ifdef PLATFORM_OS_CE
-	if(WAIT_OBJECT_0 == WaitForSingleObject(*sema, INFINITE ))
-		return _SUCCESS; 
+	if (WAIT_OBJECT_0 == WaitForSingleObject(*sema, INFINITE))
+		return _SUCCESS;
 	else
 		return _FAIL;
 #endif
 }
 
+inline void thread_exit(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	complete_and_exit(comp, 0);
+#endif
+
+#ifdef PLATFORM_FREEBSD
+	printf("%s", "RTKTHREAD_exit");
+#endif
 
+#ifdef PLATFORM_OS_CE
+	ExitThread(STATUS_SUCCESS);
+#endif
+
+#ifdef PLATFORM_OS_XP
+	PsTerminateSystemThread(STATUS_SUCCESS);
+#endif
+}
+
+inline void _rtw_init_completion(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	init_completion(comp);
+#endif
+}
+inline void _rtw_wait_for_comp_timeout(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	wait_for_completion_timeout(comp, msecs_to_jiffies(3000));
+#endif
+}
+inline void _rtw_wait_for_comp(_completion *comp)
+{
+#ifdef PLATFORM_LINUX
+	wait_for_completion(comp);
+#endif
+}
 
 void	_rtw_mutex_init(_mutex *pmutex)
 {
 #ifdef PLATFORM_LINUX
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
 	mutex_init(pmutex);
 #else
 	init_MUTEX(pmutex);
@@ -1109,7 +1342,7 @@ void	_rtw_mutex_init(_mutex *pmutex)
 
 #endif
 #ifdef PLATFORM_FREEBSD
-	mtx_init(pmutex, "", NULL, MTX_DEF|MTX_RECURSE);
+	mtx_init(pmutex, "", NULL, MTX_DEF | MTX_RECURSE);
 #endif
 #ifdef PLATFORM_OS_XP
 
@@ -1118,7 +1351,7 @@ void	_rtw_mutex_init(_mutex *pmutex)
 #endif
 
 #ifdef PLATFORM_OS_CE
-	*pmutex =  CreateMutex( NULL, _FALSE, NULL);
+	*pmutex =  CreateMutex(NULL, _FALSE, NULL);
 #endif
 }
 
@@ -1127,9 +1360,9 @@ void	_rtw_mutex_free(_mutex *pmutex)
 {
 #ifdef PLATFORM_LINUX
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
 	mutex_destroy(pmutex);
-#else	
+#else
 #endif
 
 #ifdef PLATFORM_FREEBSD
@@ -1154,52 +1387,50 @@ void	_rtw_spinlock_init(_lock *plock)
 
 	spin_lock_init(plock);
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-		mtx_init(plock, "", NULL, MTX_DEF|MTX_RECURSE);
+	mtx_init(plock, "", NULL, MTX_DEF | MTX_RECURSE);
 #endif
 #ifdef PLATFORM_WINDOWS
 
 	NdisAllocateSpinLock(plock);
 
 #endif
-	
+
 }
 
 void	_rtw_spinlock_free(_lock *plock)
 {
 #ifdef PLATFORM_FREEBSD
-	 mtx_destroy(plock);
+	mtx_destroy(plock);
 #endif
-	
+
 #ifdef PLATFORM_WINDOWS
 
 	NdisFreeSpinLock(plock);
 
 #endif
-	
+
 }
 #ifdef PLATFORM_FREEBSD
 extern PADAPTER prtw_lock;
 
-void rtw_mtx_lock(_lock *plock){
-	if(prtw_lock){
+void rtw_mtx_lock(_lock *plock)
+{
+	if (prtw_lock)
 		mtx_lock(&prtw_lock->glock);
-	}
-	else{
-		printf("%s prtw_lock==NULL",__FUNCTION__);
-	}
+	else
+		printf("%s prtw_lock==NULL", __FUNCTION__);
 }
-void rtw_mtx_unlock(_lock *plock){
-	if(prtw_lock){
+void rtw_mtx_unlock(_lock *plock)
+{
+	if (prtw_lock)
 		mtx_unlock(&prtw_lock->glock);
-	}
-	else{
-		printf("%s prtw_lock==NULL",__FUNCTION__);
-	}
-	
+	else
+		printf("%s prtw_lock==NULL", __FUNCTION__);
+
 }
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 
 
 void	_rtw_spinlock(_lock	*plock)
@@ -1218,7 +1449,7 @@ void	_rtw_spinlock(_lock	*plock)
 	NdisAcquireSpinLock(plock);
 
 #endif
-	
+
 }
 
 void	_rtw_spinunlock(_lock *plock)
@@ -1231,7 +1462,7 @@ void	_rtw_spinunlock(_lock *plock)
 #endif
 #ifdef PLATFORM_FREEBSD
 	mtx_unlock(plock);
-#endif	
+#endif
 #ifdef PLATFORM_WINDOWS
 
 	NdisReleaseSpinLock(plock);
@@ -1250,13 +1481,13 @@ void	_rtw_spinlock_ex(_lock	*plock)
 #endif
 #ifdef PLATFORM_FREEBSD
 	mtx_lock(plock);
-#endif	
+#endif
 #ifdef PLATFORM_WINDOWS
 
 	NdisDprAcquireSpinLock(plock);
 
 #endif
-	
+
 }
 
 void	_rtw_spinunlock_ex(_lock *plock)
@@ -1269,7 +1500,7 @@ void	_rtw_spinunlock_ex(_lock *plock)
 #endif
 #ifdef PLATFORM_FREEBSD
 	mtx_unlock(plock);
-#endif	
+#endif
 #ifdef PLATFORM_WINDOWS
 
 	NdisDprReleaseSpinLock(plock);
@@ -1292,7 +1523,7 @@ void _rtw_deinit_queue(_queue *pqueue)
 
 u32	  _rtw_queue_empty(_queue	*pqueue)
 {
-	return (rtw_is_list_empty(&(pqueue->queue)));
+	return rtw_is_list_empty(&(pqueue->queue));
 }
 
 
@@ -1305,12 +1536,12 @@ u32 rtw_end_of_queue_search(_list *head, _list *plist)
 }
 
 
-u32	rtw_get_current_time(void)
+systime _rtw_get_current_time(void)
 {
-	
+
 #ifdef PLATFORM_LINUX
 	return jiffies;
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
 	struct timeval tvp;
 	getmicrotime(&tvp);
@@ -1319,92 +1550,95 @@ u32	rtw_get_current_time(void)
 #ifdef PLATFORM_WINDOWS
 	LARGE_INTEGER	SystemTime;
 	NdisGetCurrentSystemTime(&SystemTime);
-	return (u32)(SystemTime.LowPart);// count of 100-nanosecond intervals 
+	return SystemTime.LowPart;/* count of 100-nanosecond intervals */
 #endif
 }
 
-inline u32 rtw_systime_to_ms(u32 systime)
+inline u32 _rtw_systime_to_ms(systime stime)
 {
 #ifdef PLATFORM_LINUX
-	return systime * 1000 / HZ;
-#endif	
+	return jiffies_to_msecs(stime);
+#endif
 #ifdef PLATFORM_FREEBSD
-	return systime * 1000;
-#endif	
+	return stime * 1000;
+#endif
 #ifdef PLATFORM_WINDOWS
-	return systime / 10000 ; 
+	return stime / 10000 ;
 #endif
 }
 
-inline u32 rtw_ms_to_systime(u32 ms)
+inline systime _rtw_ms_to_systime(u32 ms)
 {
 #ifdef PLATFORM_LINUX
-	return ms * HZ / 1000;
-#endif	
+	return msecs_to_jiffies(ms);
+#endif
 #ifdef PLATFORM_FREEBSD
-	return ms /1000;
-#endif	
+	return ms / 1000;
+#endif
 #ifdef PLATFORM_WINDOWS
-	return ms * 10000 ; 
+	return ms * 10000 ;
 #endif
 }
 
-// the input parameter start use the same unit as returned by rtw_get_current_time
-inline s32 rtw_get_passing_time_ms(u32 start)
+inline systime _rtw_us_to_systime(u32 us)
 {
 #ifdef PLATFORM_LINUX
-	return rtw_systime_to_ms(jiffies-start);
-#endif
-#ifdef PLATFORM_FREEBSD
-	return rtw_systime_to_ms(rtw_get_current_time());
-#endif	
-#ifdef PLATFORM_WINDOWS
-	LARGE_INTEGER	SystemTime;
-	NdisGetCurrentSystemTime(&SystemTime);
-	return rtw_systime_to_ms((u32)(SystemTime.LowPart) - start) ;
+	return usecs_to_jiffies(us);
+#else
+	#error "TBD\n"
 #endif
 }
 
-inline s32 rtw_get_time_interval_ms(u32 start, u32 end)
+/* the input parameter start use the same unit as returned by rtw_get_current_time */
+inline s32 _rtw_get_passing_time_ms(systime start)
+{
+	return _rtw_systime_to_ms(_rtw_get_current_time() - start);
+}
+
+inline s32 _rtw_get_remaining_time_ms(systime end)
+{
+	return _rtw_systime_to_ms(end - _rtw_get_current_time());
+}
+
+inline s32 _rtw_get_time_interval_ms(systime start, systime end)
+{
+	return _rtw_systime_to_ms(end - start);
+}
+
+inline bool _rtw_time_after(systime a, systime b)
 {
 #ifdef PLATFORM_LINUX
-	return rtw_systime_to_ms(end-start);
-#endif
-#ifdef PLATFORM_FREEBSD
-	return rtw_systime_to_ms(rtw_get_current_time());
-#endif	
-#ifdef PLATFORM_WINDOWS
-	return rtw_systime_to_ms(end-start);
+	return time_after(a, b);
+#else
+	#error "TBD\n"
 #endif
 }
-	
 
-void rtw_sleep_schedulable(int ms)	
+void rtw_sleep_schedulable(int ms)
 {
 
 #ifdef PLATFORM_LINUX
 
-    u32 delta;
-    
-    delta = (ms * HZ)/1000;//(ms)
-    if (delta == 0) {
-        delta = 1;// 1 ms
-    }
-    set_current_state(TASK_INTERRUPTIBLE);
-    if (schedule_timeout(delta) != 0) {
-        return ;
-    }
-    return;
+	u32 delta;
+
+	delta = (ms * HZ) / 1000; /* (ms) */
+	if (delta == 0) {
+		delta = 1;/* 1 ms */
+	}
+	set_current_state(TASK_INTERRUPTIBLE);
+	if (schedule_timeout(delta) != 0)
+		return ;
+	return;
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	DELAY(ms*1000);
+	DELAY(ms * 1000);
 	return ;
-#endif	
-	
+#endif
+
 #ifdef PLATFORM_WINDOWS
 
-	NdisMSleep(ms*1000); //(us)*1000=(ms)
+	NdisMSleep(ms * 1000); /* (us)*1000=(ms) */
 
 #endif
 
@@ -1415,23 +1649,23 @@ void rtw_msleep_os(int ms)
 {
 
 #ifdef PLATFORM_LINUX
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
 	if (ms < 20) {
 		unsigned long us = ms * 1000UL;
 		usleep_range(us, us + 1000UL);
 	} else
-	#endif
-  	msleep((unsigned int)ms);
+#endif
+		msleep((unsigned int)ms);
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-       //Delay for delay microseconds 
-	DELAY(ms*1000);
+	/* Delay for delay microseconds */
+	DELAY(ms * 1000);
 	return ;
-#endif	
+#endif
 #ifdef PLATFORM_WINDOWS
 
-	NdisMSleep(ms*1000); //(us)*1000=(ms)
+	NdisMSleep(ms * 1000); /* (us)*1000=(ms) */
 
 #endif
 
@@ -1441,26 +1675,26 @@ void rtw_usleep_os(int us)
 {
 #ifdef PLATFORM_LINUX
 
-	// msleep((unsigned int)us);
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
-	usleep_range(us, us + 1);	
-	#else
-	if ( 1 < (us/1000) )
-      		msleep(1);
-      else
-		msleep( (us/1000) + 1);
-	#endif
+	/* msleep((unsigned int)us); */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36))
+	usleep_range(us, us + 1);
+#else
+	if (1 < (us / 1000))
+		msleep(1);
+	else
+		msleep((us / 1000) + 1);
+#endif
 #endif
 
 #ifdef PLATFORM_FREEBSD
-	//Delay for delay microseconds 
+	/* Delay for delay microseconds */
 	DELAY(us);
 
 	return ;
-#endif	
+#endif
 #ifdef PLATFORM_WINDOWS
 
-	NdisMSleep(us); //(us)
+	NdisMSleep(us); /* (us) */
 
 #endif
 
@@ -1471,23 +1705,23 @@ void rtw_usleep_os(int us)
 #ifdef DBG_DELAY_OS
 void _rtw_mdelay_os(int ms, const char *func, const int line)
 {
-	#if 0
-	if(ms>10)
-		DBG_871X("%s:%d %s(%d)\n", func, line, __FUNCTION__, ms);
-		rtw_msleep_os(ms);
+#if 0
+	if (ms > 10)
+		RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, ms);
+	rtw_msleep_os(ms);
 	return;
-	#endif
+#endif
 
 
-	DBG_871X("%s:%d %s(%d)\n", func, line, __FUNCTION__, ms);
+	RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, ms);
 
 #if defined(PLATFORM_LINUX)
 
-   	mdelay((unsigned long)ms); 
+	mdelay((unsigned long)ms);
 
 #elif defined(PLATFORM_WINDOWS)
 
-	NdisStallExecution(ms*1000); //(us)*1000=(ms)
+	NdisStallExecution(ms * 1000); /* (us)*1000=(ms) */
 
 #endif
 
@@ -1496,25 +1730,25 @@ void _rtw_mdelay_os(int ms, const char *func, const int line)
 void _rtw_udelay_os(int us, const char *func, const int line)
 {
 
-	#if 0
-	if(us > 1000) {
-	DBG_871X("%s:%d %s(%d)\n", func, line, __FUNCTION__, us);
+#if 0
+	if (us > 1000) {
+		RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, us);
 		rtw_usleep_os(us);
 		return;
 	}
-	#endif 
+#endif
+
+
+	RTW_INFO("%s:%d %s(%d)\n", func, line, __FUNCTION__, us);
 
 
-	DBG_871X("%s:%d %s(%d)\n", func, line, __FUNCTION__, us);
-	
-	
 #if defined(PLATFORM_LINUX)
 
-      udelay((unsigned long)us); 
+	udelay((unsigned long)us);
 
 #elif defined(PLATFORM_WINDOWS)
 
-	NdisStallExecution(us); //(us)
+	NdisStallExecution(us); /* (us) */
 
 #endif
 
@@ -1525,16 +1759,16 @@ void rtw_mdelay_os(int ms)
 
 #ifdef PLATFORM_LINUX
 
-   	mdelay((unsigned long)ms); 
+	mdelay((unsigned long)ms);
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	DELAY(ms*1000);
+	DELAY(ms * 1000);
 	return ;
-#endif	
+#endif
 #ifdef PLATFORM_WINDOWS
 
-	NdisStallExecution(ms*1000); //(us)*1000=(ms)
+	NdisStallExecution(ms * 1000); /* (us)*1000=(ms) */
 
 #endif
 
@@ -1545,17 +1779,17 @@ void rtw_udelay_os(int us)
 
 #ifdef PLATFORM_LINUX
 
-      udelay((unsigned long)us); 
+	udelay((unsigned long)us);
 
-#endif	
+#endif
 #ifdef PLATFORM_FREEBSD
-	//Delay for delay microseconds 
+	/* Delay for delay microseconds */
 	DELAY(us);
 	return ;
-#endif		
+#endif
 #ifdef PLATFORM_WINDOWS
 
-	NdisStallExecution(us); //(us)
+	NdisStallExecution(us); /* (us) */
 
 #endif
 
@@ -1575,293 +1809,294 @@ void rtw_yield_os(void)
 #endif
 }
 
+bool rtw_macaddr_is_larger(const u8 *a, const u8 *b)
+{
+	u32 va, vb;
+
+	va = be32_to_cpu(*((u32 *)a));
+	vb = be32_to_cpu(*((u32 *)b));
+	if (va > vb)
+		return 1;
+	else if (va < vb)
+		return 0;
+
+	return be16_to_cpu(*((u16 *)(a + 4))) > be16_to_cpu(*((u16 *)(b + 4)));
+}
+
 #define RTW_SUSPEND_LOCK_NAME "rtw_wifi"
-#define RTW_SUSPEND_EXT_LOCK_NAME "rtw_wifi_ext"
-#define RTW_SUSPEND_RX_LOCK_NAME "rtw_wifi_rx"
 #define RTW_SUSPEND_TRAFFIC_LOCK_NAME "rtw_wifi_traffic"
 #define RTW_SUSPEND_RESUME_LOCK_NAME "rtw_wifi_resume"
-#define RTW_RESUME_SCAN_LOCK_NAME "rtw_wifi_scan"
 #ifdef CONFIG_WAKELOCK
 static struct wake_lock rtw_suspend_lock;
-static struct wake_lock rtw_suspend_ext_lock;
-static struct wake_lock rtw_suspend_rx_lock;
 static struct wake_lock rtw_suspend_traffic_lock;
 static struct wake_lock rtw_suspend_resume_lock;
-static struct wake_lock rtw_resume_scan_lock;
 #elif defined(CONFIG_ANDROID_POWER)
-static android_suspend_lock_t rtw_suspend_lock ={
+static android_suspend_lock_t rtw_suspend_lock = {
 	.name = RTW_SUSPEND_LOCK_NAME
 };
-static android_suspend_lock_t rtw_suspend_ext_lock ={
-	.name = RTW_SUSPEND_EXT_LOCK_NAME
-};
-static android_suspend_lock_t rtw_suspend_rx_lock ={
-	.name = RTW_SUSPEND_RX_LOCK_NAME
-};
-static android_suspend_lock_t rtw_suspend_traffic_lock ={
+static android_suspend_lock_t rtw_suspend_traffic_lock = {
 	.name = RTW_SUSPEND_TRAFFIC_LOCK_NAME
 };
-static android_suspend_lock_t rtw_suspend_resume_lock ={
+static android_suspend_lock_t rtw_suspend_resume_lock = {
 	.name = RTW_SUSPEND_RESUME_LOCK_NAME
 };
-static android_suspend_lock_t rtw_resume_scan_lock ={
-	.name = RTW_RESUME_SCAN_LOCK_NAME
-};
 #endif
 
 inline void rtw_suspend_lock_init(void)
 {
-	#ifdef CONFIG_WAKELOCK
+#ifdef CONFIG_WAKELOCK
 	wake_lock_init(&rtw_suspend_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_LOCK_NAME);
-	wake_lock_init(&rtw_suspend_ext_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_EXT_LOCK_NAME);
-	wake_lock_init(&rtw_suspend_rx_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_RX_LOCK_NAME);
 	wake_lock_init(&rtw_suspend_traffic_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_TRAFFIC_LOCK_NAME);
 	wake_lock_init(&rtw_suspend_resume_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_RESUME_LOCK_NAME);
-	wake_lock_init(&rtw_resume_scan_lock, WAKE_LOCK_SUSPEND, RTW_RESUME_SCAN_LOCK_NAME);
-	#elif defined(CONFIG_ANDROID_POWER)
+#elif defined(CONFIG_ANDROID_POWER)
 	android_init_suspend_lock(&rtw_suspend_lock);
-	android_init_suspend_lock(&rtw_suspend_ext_lock);
-	android_init_suspend_lock(&rtw_suspend_rx_lock);
 	android_init_suspend_lock(&rtw_suspend_traffic_lock);
 	android_init_suspend_lock(&rtw_suspend_resume_lock);
-	android_init_suspend_lock(&rtw_resume_scan_lock);
-	#endif
+#endif
 }
 
 inline void rtw_suspend_lock_uninit(void)
 {
-	#ifdef CONFIG_WAKELOCK
+#ifdef CONFIG_WAKELOCK
 	wake_lock_destroy(&rtw_suspend_lock);
-	wake_lock_destroy(&rtw_suspend_ext_lock);
-	wake_lock_destroy(&rtw_suspend_rx_lock);
 	wake_lock_destroy(&rtw_suspend_traffic_lock);
 	wake_lock_destroy(&rtw_suspend_resume_lock);
-	wake_lock_destroy(&rtw_resume_scan_lock);
-	#elif defined(CONFIG_ANDROID_POWER)
+#elif defined(CONFIG_ANDROID_POWER)
 	android_uninit_suspend_lock(&rtw_suspend_lock);
-	android_uninit_suspend_lock(&rtw_suspend_ext_lock);
-	android_uninit_suspend_lock(&rtw_suspend_rx_lock);
 	android_uninit_suspend_lock(&rtw_suspend_traffic_lock);
 	android_uninit_suspend_lock(&rtw_suspend_resume_lock);
-	android_uninit_suspend_lock(&rtw_resume_scan_lock);
-	#endif
+#endif
 }
 
 inline void rtw_lock_suspend(void)
 {
-	#ifdef CONFIG_WAKELOCK
+#ifdef CONFIG_WAKELOCK
 	wake_lock(&rtw_suspend_lock);
-	#elif defined(CONFIG_ANDROID_POWER)
+#elif defined(CONFIG_ANDROID_POWER)
 	android_lock_suspend(&rtw_suspend_lock);
-	#endif
+#endif
 
-	#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
-	//DBG_871X("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count);
-	#endif
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
 }
 
 inline void rtw_unlock_suspend(void)
 {
-	#ifdef CONFIG_WAKELOCK
+#ifdef CONFIG_WAKELOCK
 	wake_unlock(&rtw_suspend_lock);
-	#elif defined(CONFIG_ANDROID_POWER)
+#elif defined(CONFIG_ANDROID_POWER)
 	android_unlock_suspend(&rtw_suspend_lock);
-	#endif
+#endif
 
-	#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
-	//DBG_871X("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count);
-	#endif
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
 }
 
 inline void rtw_resume_lock_suspend(void)
 {
-	#ifdef CONFIG_WAKELOCK
+#ifdef CONFIG_WAKELOCK
 	wake_lock(&rtw_suspend_resume_lock);
-	#elif defined(CONFIG_ANDROID_POWER)
+#elif defined(CONFIG_ANDROID_POWER)
 	android_lock_suspend(&rtw_suspend_resume_lock);
-	#endif
+#endif
 
-	#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
-	//DBG_871X("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count);
-	#endif
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
 }
 
 inline void rtw_resume_unlock_suspend(void)
 {
-	#ifdef CONFIG_WAKELOCK
+#ifdef CONFIG_WAKELOCK
 	wake_unlock(&rtw_suspend_resume_lock);
-	#elif defined(CONFIG_ANDROID_POWER)
+#elif defined(CONFIG_ANDROID_POWER)
 	android_unlock_suspend(&rtw_suspend_resume_lock);
-	#endif
+#endif
 
-	#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
-	//DBG_871X("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count);
-	#endif
+#if  defined(CONFIG_WAKELOCK) || defined(CONFIG_ANDROID_POWER)
+	/* RTW_INFO("####%s: suspend_lock_count:%d####\n", __FUNCTION__, rtw_suspend_lock.stat.count); */
+#endif
 }
 
 inline void rtw_lock_suspend_timeout(u32 timeout_ms)
 {
-	#ifdef CONFIG_WAKELOCK
+#ifdef CONFIG_WAKELOCK
 	wake_lock_timeout(&rtw_suspend_lock, rtw_ms_to_systime(timeout_ms));
-	#elif defined(CONFIG_ANDROID_POWER)
+#elif defined(CONFIG_ANDROID_POWER)
 	android_lock_suspend_auto_expire(&rtw_suspend_lock, rtw_ms_to_systime(timeout_ms));
-	#endif
+#endif
 }
 
-inline void rtw_lock_ext_suspend_timeout(u32 timeout_ms)
+
+inline void rtw_lock_traffic_suspend_timeout(u32 timeout_ms)
 {
-	#ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_suspend_ext_lock, rtw_ms_to_systime(timeout_ms));
-	#elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_suspend_ext_lock, rtw_ms_to_systime(timeout_ms));
-	#endif
-	//DBG_871X("EXT lock timeout:%d\n", timeout_ms);
+#ifdef CONFIG_WAKELOCK
+	wake_lock_timeout(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
+#elif defined(CONFIG_ANDROID_POWER)
+	android_lock_suspend_auto_expire(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
+#endif
+	/* RTW_INFO("traffic lock timeout:%d\n", timeout_ms); */
 }
 
-inline void rtw_lock_rx_suspend_timeout(u32 timeout_ms)
+inline void rtw_set_bit(int nr, unsigned long *addr)
 {
-	#ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_suspend_rx_lock, rtw_ms_to_systime(timeout_ms));
-	#elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_suspend_rx_lock, rtw_ms_to_systime(timeout_ms));
-	#endif
-	//DBG_871X("RX lock timeout:%d\n", timeout_ms);
+#ifdef PLATFORM_LINUX
+	set_bit(nr, addr);
+#else
+	#error "TBD\n";
+#endif
 }
 
-
-inline void rtw_lock_traffic_suspend_timeout(u32 timeout_ms)
+inline void rtw_clear_bit(int nr, unsigned long *addr)
 {
-	#ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
-	#elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
-	#endif
-	//DBG_871X("traffic lock timeout:%d\n", timeout_ms);
+#ifdef PLATFORM_LINUX
+	clear_bit(nr, addr);
+#else
+	#error "TBD\n";
+#endif
 }
 
-inline void rtw_lock_resume_scan_timeout(u32 timeout_ms)
+inline int rtw_test_and_clear_bit(int nr, unsigned long *addr)
 {
-	#ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_resume_scan_lock, rtw_ms_to_systime(timeout_ms));
-	#elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_resume_scan_lock, rtw_ms_to_systime(timeout_ms));
-	#endif
-	//DBG_871X("resume scan lock:%d\n", timeout_ms);
+#ifdef PLATFORM_LINUX
+	return test_and_clear_bit(nr, addr);
+#else
+	#error "TBD\n";
+#endif
 }
 
 inline void ATOMIC_SET(ATOMIC_T *v, int i)
 {
-	#ifdef PLATFORM_LINUX
-	atomic_set(v,i);
-	#elif defined(PLATFORM_WINDOWS)
-	*v=i;// other choice????
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_set_int(v,i);
-	#endif
+#ifdef PLATFORM_LINUX
+	atomic_set(v, i);
+#elif defined(PLATFORM_WINDOWS)
+	*v = i; /* other choice???? */
+#elif defined(PLATFORM_FREEBSD)
+	atomic_set_int(v, i);
+#endif
 }
 
 inline int ATOMIC_READ(ATOMIC_T *v)
 {
-	#ifdef PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 	return atomic_read(v);
-	#elif defined(PLATFORM_WINDOWS)
-	return *v; // other choice????
-	#elif defined(PLATFORM_FREEBSD)
+#elif defined(PLATFORM_WINDOWS)
+	return *v; /* other choice???? */
+#elif defined(PLATFORM_FREEBSD)
 	return atomic_load_acq_32(v);
-	#endif
+#endif
 }
 
 inline void ATOMIC_ADD(ATOMIC_T *v, int i)
 {
-	#ifdef PLATFORM_LINUX
-	atomic_add(i,v);
-	#elif defined(PLATFORM_WINDOWS)
-	InterlockedAdd(v,i);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_add_int(v,i);
-	#endif
+#ifdef PLATFORM_LINUX
+	atomic_add(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	InterlockedAdd(v, i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, i);
+#endif
 }
 inline void ATOMIC_SUB(ATOMIC_T *v, int i)
 {
-	#ifdef PLATFORM_LINUX
-	atomic_sub(i,v);
-	#elif defined(PLATFORM_WINDOWS)
-	InterlockedAdd(v,-i);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_subtract_int(v,i);
-	#endif
+#ifdef PLATFORM_LINUX
+	atomic_sub(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	InterlockedAdd(v, -i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, i);
+#endif
 }
 
 inline void ATOMIC_INC(ATOMIC_T *v)
 {
-	#ifdef PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 	atomic_inc(v);
-	#elif defined(PLATFORM_WINDOWS)
+#elif defined(PLATFORM_WINDOWS)
 	InterlockedIncrement(v);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_add_int(v,1);
-	#endif
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, 1);
+#endif
 }
 
 inline void ATOMIC_DEC(ATOMIC_T *v)
 {
-	#ifdef PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 	atomic_dec(v);
-	#elif defined(PLATFORM_WINDOWS)
+#elif defined(PLATFORM_WINDOWS)
 	InterlockedDecrement(v);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_subtract_int(v,1);
-	#endif
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, 1);
+#endif
 }
 
 inline int ATOMIC_ADD_RETURN(ATOMIC_T *v, int i)
 {
-	#ifdef PLATFORM_LINUX
-	return atomic_add_return(i,v);
-	#elif defined(PLATFORM_WINDOWS)
-	return InterlockedAdd(v,i);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_add_int(v,i);
+#ifdef PLATFORM_LINUX
+	return atomic_add_return(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	return InterlockedAdd(v, i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, i);
 	return atomic_load_acq_32(v);
-	#endif
+#endif
 }
 
 inline int ATOMIC_SUB_RETURN(ATOMIC_T *v, int i)
 {
-	#ifdef PLATFORM_LINUX
-	return atomic_sub_return(i,v);
-	#elif defined(PLATFORM_WINDOWS)
-	return InterlockedAdd(v,-i);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_subtract_int(v,i);
+#ifdef PLATFORM_LINUX
+	return atomic_sub_return(i, v);
+#elif defined(PLATFORM_WINDOWS)
+	return InterlockedAdd(v, -i);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, i);
 	return atomic_load_acq_32(v);
-	#endif
+#endif
 }
 
 inline int ATOMIC_INC_RETURN(ATOMIC_T *v)
 {
-	#ifdef PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 	return atomic_inc_return(v);
-	#elif defined(PLATFORM_WINDOWS)
+#elif defined(PLATFORM_WINDOWS)
 	return InterlockedIncrement(v);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_add_int(v,1);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_add_int(v, 1);
 	return atomic_load_acq_32(v);
-	#endif
+#endif
 }
 
 inline int ATOMIC_DEC_RETURN(ATOMIC_T *v)
 {
-	#ifdef PLATFORM_LINUX
+#ifdef PLATFORM_LINUX
 	return atomic_dec_return(v);
-	#elif defined(PLATFORM_WINDOWS)
+#elif defined(PLATFORM_WINDOWS)
 	return InterlockedDecrement(v);
-	#elif defined(PLATFORM_FREEBSD)
-	atomic_subtract_int(v,1);
+#elif defined(PLATFORM_FREEBSD)
+	atomic_subtract_int(v, 1);
 	return atomic_load_acq_32(v);
-	#endif
+#endif
 }
 
+inline bool ATOMIC_INC_UNLESS(ATOMIC_T *v, int u)
+{
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 15))
+	return atomic_add_unless(v, 1, u);
+#else
+	/* only make sure not exceed after this function */
+	if (ATOMIC_INC_RETURN(v) > u) {
+		ATOMIC_DEC(v);
+		return 0;
+	}
+	return 1;
+#endif
+#else
+	#error "TBD\n"
+#endif
+}
 
 #ifdef PLATFORM_LINUX
 /*
@@ -1880,11 +2115,10 @@ static int openFile(struct file **fpp, const char *path, int flag, int mode)
 	if (IS_ERR(fp)) {
 		*fpp = NULL;
 		return PTR_ERR(fp);
-	}
-	else {
-		*fpp=fp; 
+	} else {
+		*fpp = fp;
 		return 0;
-	}	
+	}
 }
 
 /*
@@ -1892,15 +2126,15 @@ static int openFile(struct file **fpp, const char *path, int flag, int mode)
 * @param fp the pointer of struct file to close
 * @return always 0
 */
-static int closeFile(struct file *fp) 
-{ 
-	filp_close(fp,NULL);
-	return 0; 
+static int closeFile(struct file *fp)
+{
+	filp_close(fp, NULL);
+	return 0;
 }
 
-static int readFile(struct file *fp,char *buf,int len) 
-{ 
-	int rlen=0, sum=0;
+static int readFile(struct file *fp, char *buf, int len)
+{
+	int rlen = 0, sum = 0;
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
 	if (!(fp->f_mode & FMODE_CAN_READ))
@@ -1909,36 +2143,38 @@ static int readFile(struct file *fp,char *buf,int len)
 #endif
 		return -EPERM;
 
-	while(sum<len) {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
-		rlen = __vfs_read(fp, buf+sum, len-sum, &fp->f_pos);
+	while (sum < len) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+		rlen = kernel_read(fp, buf + sum, len - sum, &fp->f_pos);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+		rlen = __vfs_read(fp, buf + sum, len - sum, &fp->f_pos);
 #else
-		rlen = fp->f_op->read(fp, buf+sum, len-sum, &fp->f_pos);
+		rlen = fp->f_op->read(fp, buf + sum, len - sum, &fp->f_pos);
 #endif
-		if(rlen>0)
-			sum+=rlen;
-		else if(0 != rlen)
+		if (rlen > 0)
+			sum += rlen;
+		else if (0 != rlen)
 			return rlen;
 		else
 			break;
 	}
-	
+
 	return  sum;
 
 }
 
-static int writeFile(struct file *fp,char *buf,int len) 
-{ 
-	int wlen=0, sum=0;
-	
-	if (!fp->f_op || !fp->f_op->write) 
-		return -EPERM; 
-
-	while(sum<len) {
-		wlen=fp->f_op->write(fp,buf+sum,len-sum, &fp->f_pos);
-		if(wlen>0)
-			sum+=wlen;
-		else if(0 != wlen)
+static int writeFile(struct file *fp, char *buf, int len)
+{
+	int wlen = 0, sum = 0;
+
+	if (!fp->f_op || !fp->f_op->write)
+		return -EPERM;
+
+	while (sum < len) {
+		wlen = fp->f_op->write(fp, buf + sum, len - sum, &fp->f_pos);
+		if (wlen > 0)
+			sum += wlen;
+		else if (0 != wlen)
 			return wlen;
 		else
 			break;
@@ -1955,22 +2191,22 @@ static int writeFile(struct file *fp,char *buf,int len)
 * @return Linux specific error code
 */
 static int isFileReadable(const char *path, u32 *sz)
-{ 
+{
 	struct file *fp;
 	int ret = 0;
 	mm_segment_t oldfs;
 	char buf;
- 
-	fp=filp_open(path, O_RDONLY, 0); 
-	if(IS_ERR(fp)) {
+
+	fp = filp_open(path, O_RDONLY, 0);
+	if (IS_ERR(fp))
 		ret = PTR_ERR(fp);
-	}
 	else {
-		oldfs = get_fs(); set_fs(get_ds());
-		
-		if(1!=readFile(fp, &buf, 1))
+		oldfs = get_fs();
+		set_fs(get_ds());
+
+		if (1 != readFile(fp, &buf, 1))
 			ret = PTR_ERR(fp);
-		
+
 		if (ret == 0 && sz) {
 			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
 			*sz = i_size_read(fp->f_path.dentry->d_inode);
@@ -1980,8 +2216,8 @@ static int isFileReadable(const char *path, u32 *sz)
 		}
 
 		set_fs(oldfs);
-		filp_close(fp,NULL);
-	}	
+		filp_close(fp, NULL);
+	}
 	return ret;
 }
 
@@ -1994,26 +2230,27 @@ static int isFileReadable(const char *path, u32 *sz)
 */
 static int retriveFromFile(const char *path, u8 *buf, u32 sz)
 {
-	int ret =-1;
+	int ret = -1;
 	mm_segment_t oldfs;
 	struct file *fp;
 
-	if(path && buf) {
-		if( 0 == (ret=openFile(&fp,path, O_RDONLY, 0)) ){
-			DBG_871X("%s openFile path:%s fp=%p\n",__FUNCTION__, path ,fp);
+	if (path && buf) {
+		ret = openFile(&fp, path, O_RDONLY, 0);
+		if (0 == ret) {
+			RTW_INFO("%s openFile path:%s fp=%p\n", __FUNCTION__, path , fp);
 
-			oldfs = get_fs(); set_fs(get_ds());
-			ret=readFile(fp, buf, sz);
+			oldfs = get_fs();
+			set_fs(get_ds());
+			ret = readFile(fp, buf, sz);
 			set_fs(oldfs);
 			closeFile(fp);
-			
-			DBG_871X("%s readFile, ret:%d\n",__FUNCTION__, ret);
-			
-		} else {
-			DBG_871X("%s openFile path:%s Fail, ret:%d\n",__FUNCTION__, path, ret);
-		}
+
+			RTW_INFO("%s readFile, ret:%d\n", __FUNCTION__, ret);
+
+		} else
+			RTW_INFO("%s openFile path:%s Fail, ret:%d\n", __FUNCTION__, path, ret);
 	} else {
-		DBG_871X("%s NULL pointer\n",__FUNCTION__);
+		RTW_INFO("%s NULL pointer\n", __FUNCTION__);
 		ret =  -EINVAL;
 	}
 	return ret;
@@ -2028,31 +2265,32 @@ static int retriveFromFile(const char *path, u8 *buf, u32 sz)
 */
 static int storeToFile(const char *path, u8 *buf, u32 sz)
 {
-	int ret =0;
+	int ret = 0;
 	mm_segment_t oldfs;
 	struct file *fp;
-	
-	if(path && buf) {
-		if( 0 == (ret=openFile(&fp, path, O_CREAT|O_WRONLY, 0666)) ) {
-			DBG_871X("%s openFile path:%s fp=%p\n",__FUNCTION__, path ,fp);
 
-			oldfs = get_fs(); set_fs(get_ds());
-			ret=writeFile(fp, buf, sz);
+	if (path && buf) {
+		ret = openFile(&fp, path, O_CREAT | O_WRONLY, 0666);
+		if (0 == ret) {
+			RTW_INFO("%s openFile path:%s fp=%p\n", __FUNCTION__, path , fp);
+
+			oldfs = get_fs();
+			set_fs(get_ds());
+			ret = writeFile(fp, buf, sz);
 			set_fs(oldfs);
 			closeFile(fp);
 
-			DBG_871X("%s writeFile, ret:%d\n",__FUNCTION__, ret);
-			
-		} else {
-			DBG_871X("%s openFile path:%s Fail, ret:%d\n",__FUNCTION__, path, ret);
-		}	
+			RTW_INFO("%s writeFile, ret:%d\n", __FUNCTION__, ret);
+
+		} else
+			RTW_INFO("%s openFile path:%s Fail, ret:%d\n", __FUNCTION__, path, ret);
 	} else {
-		DBG_871X("%s NULL pointer\n",__FUNCTION__);
+		RTW_INFO("%s NULL pointer\n", __FUNCTION__);
 		ret =  -EINVAL;
 	}
 	return ret;
 }
-#endif //PLATFORM_LINUX
+#endif /* PLATFORM_LINUX */
 
 /*
 * Test if the specifi @param path is a file and readable
@@ -2067,7 +2305,7 @@ int rtw_is_file_readable(const char *path)
 	else
 		return _FALSE;
 #else
-	//Todo...
+	/* Todo... */
 	return _FALSE;
 #endif
 }
@@ -2101,10 +2339,10 @@ int rtw_is_file_readable_with_size(const char *path, u32 *sz)
 int rtw_retrieve_from_file(const char *path, u8 *buf, u32 sz)
 {
 #ifdef PLATFORM_LINUX
-	int ret =retriveFromFile(path, buf, sz);
-	return ret>=0?ret:0;
+	int ret = retriveFromFile(path, buf, sz);
+	return ret >= 0 ? ret : 0;
 #else
-	//Todo...
+	/* Todo... */
 	return 0;
 #endif
 }
@@ -2119,10 +2357,10 @@ int rtw_retrieve_from_file(const char *path, u8 *buf, u32 sz)
 int rtw_store_to_file(const char *path, u8 *buf, u32 sz)
 {
 #ifdef PLATFORM_LINUX
-	int ret =storeToFile(path, buf, sz);
-	return ret>=0?ret:0;
+	int ret = storeToFile(path, buf, sz);
+	return ret >= 0 ? ret : 0;
 #else
-	//Todo...
+	/* Todo... */
 	return 0;
 #endif
 }
@@ -2133,17 +2371,17 @@ struct net_device *rtw_alloc_etherdev_with_old_priv(int sizeof_priv, void *old_p
 	struct net_device *pnetdev;
 	struct rtw_netdev_priv_indicator *pnpi;
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	pnetdev = alloc_etherdev_mq(sizeof(struct rtw_netdev_priv_indicator), 4);
 #else
 	pnetdev = alloc_etherdev(sizeof(struct rtw_netdev_priv_indicator));
 #endif
 	if (!pnetdev)
 		goto RETURN;
-	
+
 	pnpi = netdev_priv(pnetdev);
-	pnpi->priv=old_priv;
-	pnpi->sizeof_priv=sizeof_priv;
+	pnpi->priv = old_priv;
+	pnpi->sizeof_priv = sizeof_priv;
 
 RETURN:
 	return pnetdev;
@@ -2154,38 +2392,38 @@ struct net_device *rtw_alloc_etherdev(int sizeof_priv)
 	struct net_device *pnetdev;
 	struct rtw_netdev_priv_indicator *pnpi;
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,35))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	pnetdev = alloc_etherdev_mq(sizeof(struct rtw_netdev_priv_indicator), 4);
 #else
 	pnetdev = alloc_etherdev(sizeof(struct rtw_netdev_priv_indicator));
 #endif
 	if (!pnetdev)
 		goto RETURN;
-	
+
 	pnpi = netdev_priv(pnetdev);
-	
+
 	pnpi->priv = rtw_zvmalloc(sizeof_priv);
 	if (!pnpi->priv) {
 		free_netdev(pnetdev);
 		pnetdev = NULL;
 		goto RETURN;
 	}
-	
-	pnpi->sizeof_priv=sizeof_priv;
+
+	pnpi->sizeof_priv = sizeof_priv;
 RETURN:
 	return pnetdev;
 }
 
-void rtw_free_netdev(struct net_device * netdev)
+void rtw_free_netdev(struct net_device *netdev)
 {
 	struct rtw_netdev_priv_indicator *pnpi;
-	
-	if(!netdev)
+
+	if (!netdev)
 		goto RETURN;
-	
+
 	pnpi = netdev_priv(netdev);
 
-	if(!pnpi->priv)
+	if (!pnpi->priv)
 		goto RETURN;
 
 	free_netdev(netdev);
@@ -2194,37 +2432,36 @@ RETURN:
 	return;
 }
 
-/*
-* Jeff: this function should be called under ioctl (rtnl_lock is accquired) while 
-* LINUX_VERSION_CODE < KERNEL_VERSION(2,6,26)
-*/
 int rtw_change_ifname(_adapter *padapter, const char *ifname)
 {
+	struct dvobj_priv *dvobj;
 	struct net_device *pnetdev;
 	struct net_device *cur_pnetdev;
 	struct rereg_nd_name_data *rereg_priv;
 	int ret;
+	u8 rtnl_lock_needed;
 
-	if(!padapter)
+	if (!padapter)
 		goto error;
 
+	dvobj = adapter_to_dvobj(padapter);
 	cur_pnetdev = padapter->pnetdev;
 	rereg_priv = &padapter->rereg_nd_name_priv;
-	
-	//free the old_pnetdev
-	if(rereg_priv->old_pnetdev) {
+
+	/* free the old_pnetdev */
+	if (rereg_priv->old_pnetdev) {
 		free_netdev(rereg_priv->old_pnetdev);
 		rereg_priv->old_pnetdev = NULL;
 	}
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,26))
-	if(!rtnl_is_locked())
+	rtnl_lock_needed = rtw_rtnl_lock_needed(dvobj);
+
+	if (rtnl_lock_needed)
 		unregister_netdev(cur_pnetdev);
 	else
-#endif
 		unregister_netdevice(cur_pnetdev);
 
-	rereg_priv->old_pnetdev=cur_pnetdev;
+	rereg_priv->old_pnetdev = cur_pnetdev;
 
 	pnetdev = rtw_init_netdev(padapter);
 	if (!pnetdev)  {
@@ -2238,56 +2475,53 @@ int rtw_change_ifname(_adapter *padapter, const char *ifname)
 
 	_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,26))
-	if(!rtnl_is_locked())
+	if (rtnl_lock_needed)
 		ret = register_netdev(pnetdev);
 	else
-#endif
 		ret = register_netdevice(pnetdev);
 
-	if ( ret != 0) {
-		RT_TRACE(_module_hci_intfs_c_,_drv_err_,("register_netdev() failed\n"));
+	if (ret != 0) {
 		goto error;
 	}
 
 	return 0;
 
 error:
-	
+
 	return -1;
-	
+
 }
 #endif
 
 #ifdef PLATFORM_FREEBSD
 /*
- * Copy a buffer from userspace and write into kernel address 
+ * Copy a buffer from userspace and write into kernel address
  * space.
  *
- * This emulation just calls the FreeBSD copyin function (to 
+ * This emulation just calls the FreeBSD copyin function (to
  * copy data from user space buffer into a kernel space buffer)
  * and is designed to be used with the above io_write_wrapper.
  *
  * This function should return the number of bytes not copied.
- * I.e. success results in a zero value. 
+ * I.e. success results in a zero value.
  * Negative error values are not returned.
  */
 unsigned long
 copy_from_user(void *to, const void *from, unsigned long n)
-{      
-        if ( copyin(from, to, n) != 0 ) {
-                /* Any errors will be treated as a failure
-                   to copy any of the requested bytes */
-                return n;
-        }
+{
+	if (copyin(from, to, n) != 0) {
+		/* Any errors will be treated as a failure
+		   to copy any of the requested bytes */
+		return n;
+	}
 
-        return 0;
+	return 0;
 }
 
 unsigned long
 copy_to_user(void *to, const void *from, unsigned long n)
 {
-	if ( copyout(from, to, n) != 0 ) {
+	if (copyout(from, to, n) != 0) {
 		/* Any errors will be treated as a failure
 		   to copy any of the requested bytes */
 		return n;
@@ -2305,35 +2539,35 @@ copy_to_user(void *to, const void *from, unsigned long n)
  *
  * usb_register and usb_deregister simply call these functions.
  */
-int 
+int
 usb_register(struct usb_driver *driver)
 {
-        rtw_usb_linux_register(driver);
-        return 0;
+	rtw_usb_linux_register(driver);
+	return 0;
 }
 
 
-int 
+int
 usb_deregister(struct usb_driver *driver)
 {
-        rtw_usb_linux_deregister(driver);
-        return 0;
+	rtw_usb_linux_deregister(driver);
+	return 0;
 }
 
 void module_init_exit_wrapper(void *arg)
 {
-        int (*func)(void) = arg;
-        func();
-        return;
+	int (*func)(void) = arg;
+	func();
+	return;
 }
 
-#endif //PLATFORM_FREEBSD
+#endif /* PLATFORM_FREEBSD */
 
 #ifdef CONFIG_PLATFORM_SPRD
-#ifdef do_div
-#undef do_div
-#endif
-#include <asm-generic/div64.h>
+	#ifdef do_div
+		#undef do_div
+	#endif
+	#include <asm-generic/div64.h>
 #endif
 
 u64 rtw_modular64(u64 x, u64 y)
@@ -2341,9 +2575,9 @@ u64 rtw_modular64(u64 x, u64 y)
 #ifdef PLATFORM_LINUX
 	return do_div(x, y);
 #elif defined(PLATFORM_WINDOWS)
-	return (x % y);
+	return x % y;
 #elif defined(PLATFORM_FREEBSD)
-	return (x %y);
+	return x % y;
 #endif
 }
 
@@ -2353,28 +2587,28 @@ u64 rtw_division64(u64 x, u64 y)
 	do_div(x, y);
 	return x;
 #elif defined(PLATFORM_WINDOWS)
-	return (x / y);
+	return x / y;
 #elif defined(PLATFORM_FREEBSD)
-	return (x / y);
+	return x / y;
 #endif
 }
 
 inline u32 rtw_random32(void)
 {
 #ifdef PLATFORM_LINUX
-	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,8,0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
 	return prandom_u32();
-	#elif (LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,18))
+#elif (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 18))
 	u32 random_int;
-	get_random_bytes( &random_int , 4 );
+	get_random_bytes(&random_int , 4);
 	return random_int;
-	#else
+#else
 	return random32();
-	#endif
+#endif
 #elif defined(PLATFORM_WINDOWS)
-	#error "to be implemented\n"
+#error "to be implemented\n"
 #elif defined(PLATFORM_FREEBSD)
-	#error "to be implemented\n"
+#error "to be implemented\n"
 #endif
 }
 
@@ -2437,7 +2671,7 @@ keep_ori:
  */
 inline bool rtw_cbuf_full(struct rtw_cbuf *cbuf)
 {
-	return (cbuf->write == cbuf->read-1)? _TRUE : _FALSE;
+	return (cbuf->write == cbuf->read - 1) ? _TRUE : _FALSE;
 }
 
 /**
@@ -2448,7 +2682,7 @@ inline bool rtw_cbuf_full(struct rtw_cbuf *cbuf)
  */
 inline bool rtw_cbuf_empty(struct rtw_cbuf *cbuf)
 {
-	return (cbuf->write == cbuf->read)? _TRUE : _FALSE;
+	return (cbuf->write == cbuf->read) ? _TRUE : _FALSE;
 }
 
 /**
@@ -2465,9 +2699,9 @@ bool rtw_cbuf_push(struct rtw_cbuf *cbuf, void *buf)
 		return _FAIL;
 
 	if (0)
-		DBG_871X("%s on %u\n", __func__, cbuf->write);
+		RTW_INFO("%s on %u\n", __func__, cbuf->write);
 	cbuf->bufs[cbuf->write] = buf;
-	cbuf->write = (cbuf->write+1)%cbuf->size;
+	cbuf->write = (cbuf->write + 1) % cbuf->size;
 
 	return _SUCCESS;
 }
@@ -2486,9 +2720,9 @@ void *rtw_cbuf_pop(struct rtw_cbuf *cbuf)
 		return NULL;
 
 	if (0)
-		DBG_871X("%s on %u\n", __func__, cbuf->read);
+		RTW_INFO("%s on %u\n", __func__, cbuf->read);
 	buf = cbuf->bufs[cbuf->read];
-	cbuf->read = (cbuf->read+1)%cbuf->size;
+	cbuf->read = (cbuf->read + 1) % cbuf->size;
 
 	return buf;
 }
@@ -2503,7 +2737,7 @@ struct rtw_cbuf *rtw_cbuf_alloc(u32 size)
 {
 	struct rtw_cbuf *cbuf;
 
-	cbuf = (struct rtw_cbuf *)rtw_malloc(sizeof(*cbuf) + sizeof(void*)*size);
+	cbuf = (struct rtw_cbuf *)rtw_malloc(sizeof(*cbuf) + sizeof(void *) * size);
 
 	if (cbuf) {
 		cbuf->write = cbuf->read = 0;
@@ -2519,7 +2753,7 @@ struct rtw_cbuf *rtw_cbuf_alloc(u32 size)
  */
 void rtw_cbuf_free(struct rtw_cbuf *cbuf)
 {
-	rtw_mfree((u8*)cbuf, sizeof(*cbuf) + sizeof(void*)*cbuf->size);
+	rtw_mfree((u8 *)cbuf, sizeof(*cbuf) + sizeof(void *) * cbuf->size);
 }
 
 /**
@@ -2611,6 +2845,167 @@ exit:
 	return val;
 }
 
+int rtw_blacklist_add(_queue *blist, const u8 *addr, u32 timeout_ms)
+{
+	struct blacklist_ent *ent;
+	_list *list, *head;
+	u8 exist = _FALSE, timeout = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			exist = _TRUE;
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time))
+				timeout = _TRUE;
+			ent->exp_time = rtw_get_current_time()
+				+ rtw_ms_to_systime(timeout_ms);
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	if (exist == _FALSE) {
+		ent = rtw_malloc(sizeof(struct blacklist_ent));
+		if (ent) {
+			_rtw_memcpy(ent->addr, addr, ETH_ALEN);
+			ent->exp_time = rtw_get_current_time()
+				+ rtw_ms_to_systime(timeout_ms);
+			rtw_list_insert_tail(&ent->list, head);
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return (exist == _TRUE && timeout == _FALSE) ? RTW_ALREADY : (ent ? _SUCCESS : _FAIL);
+}
+
+int rtw_blacklist_del(_queue *blist, const u8 *addr)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+	u8 exist = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+			exist = _TRUE;
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return exist == _TRUE ? _SUCCESS : RTW_ALREADY;
+}
+
+int rtw_blacklist_search(_queue *blist, const u8 *addr)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+	u8 exist = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+				rtw_list_delete(&ent->list);
+				rtw_mfree(ent, sizeof(struct blacklist_ent));
+			} else
+				exist = _TRUE;
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return exist;
+}
+
+void rtw_blacklist_flush(_queue *blist)
+{
+	struct blacklist_ent *ent;
+	_list *list, *head;
+	_list tmp;
+
+	_rtw_init_listhead(&tmp);
+
+	enter_critical_bh(&blist->lock);
+	rtw_list_splice_init(&blist->queue, &tmp);
+	exit_critical_bh(&blist->lock);
+
+	head = &tmp;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+		rtw_list_delete(&ent->list);
+		rtw_mfree(ent, sizeof(struct blacklist_ent));
+	}
+}
+
+void dump_blacklist(void *sel, _queue *blist, const char *title)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+
+	if (rtw_end_of_queue_search(head, list) == _FALSE) {
+		if (title)
+			RTW_PRINT_SEL(sel, "%s:\n", title);
+	
+		while (rtw_end_of_queue_search(head, list) == _FALSE) {
+			ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+			list = get_next(list);
+
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time))
+				RTW_PRINT_SEL(sel, MAC_FMT" expired\n", MAC_ARG(ent->addr));
+			else
+				RTW_PRINT_SEL(sel, MAC_FMT" %u\n", MAC_ARG(ent->addr)
+					, rtw_get_remaining_time_ms(ent->exp_time));
+		}
+
+	}
+	exit_critical_bh(&blist->lock);
+}
+
 /**
 * is_null -
 *
@@ -2625,6 +3020,15 @@ inline BOOLEAN is_null(char c)
 		return _FALSE;
 }
 
+inline BOOLEAN is_all_null(char *c, int len)
+{
+	for (; len > 0; len--)
+		if (c[len - 1] != '\0')
+			return _FALSE;
+
+	return _TRUE;
+}
+
 /**
 * is_eol -
 *
@@ -2691,3 +3095,43 @@ inline char alpha_to_upper(char c)
 	return c;
 }
 
+int hex2num_i(char c)
+{
+	if (c >= '0' && c <= '9')
+		return c - '0';
+	if (c >= 'a' && c <= 'f')
+		return c - 'a' + 10;
+	if (c >= 'A' && c <= 'F')
+		return c - 'A' + 10;
+	return -1;
+}
+
+int hex2byte_i(const char *hex)
+{
+	int a, b;
+	a = hex2num_i(*hex++);
+	if (a < 0)
+		return -1;
+	b = hex2num_i(*hex++);
+	if (b < 0)
+		return -1;
+	return (a << 4) | b;
+}
+
+int hexstr2bin(const char *hex, u8 *buf, size_t len)
+{
+	size_t i;
+	int a;
+	const char *ipos = hex;
+	u8 *opos = buf;
+
+	for (i = 0; i < len; i++) {
+		a = hex2byte_i(ipos);
+		if (a < 0)
+			return -1;
+		*opos++ = a;
+		ipos += 2;
+	}
+	return 0;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/custom_country_chplan.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/custom_country_chplan.h
index 8c70e65f725a..30322fa85a6b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/custom_country_chplan.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/custom_country_chplan.h
@@ -1,29 +1,23 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-
-#error "You have defined CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP to use a customized map of your own instead of the default one"
-#error "Before removing these error notifications, please make sure regulatory certification requirements of your target markets"
-
-static const struct country_chplan CUSTOMIZED_country_chplan_map[] = {
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0xFF), /* Taiwan */
-};
-
-static const u16 CUSTOMIZED_country_chplan_map_sz = sizeof(CUSTOMIZED_country_chplan_map)/sizeof(struct country_chplan);
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#error "You have defined CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP to use a customized map of your own instead of the default one"
+#error "Before removing these error notifications, please make sure regulatory certification requirements of your target markets"
+
+static const struct country_chplan CUSTOMIZED_country_chplan_map[] = {
+	COUNTRY_CHPLAN_ENT("TW", 0x76, 1, 0x3FF), /* Taiwan */
+};
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUN50IW1P1_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUN50IW1P1_sdio.c
index aec9cdbb2560..76df77886d70 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUN50IW1P1_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUN50IW1P1_sdio.c
@@ -1,91 +1,87 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-/*
- * Description:
- *	This file can be applied to following platforms:
- *	CONFIG_PLATFORM_ARM_SUN50IW1P1
- */
-#include <drv_types.h>
-#ifdef CONFIG_GPIO_WAKEUP
-#include <linux/gpio.h>
-#endif
-
-#ifdef CONFIG_MMC
-#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
-extern void sunxi_mmc_rescan_card(unsigned ids);
-extern void sunxi_wlan_set_power(int on);
-extern int sunxi_wlan_get_bus_index(void);
-extern int sunxi_wlan_get_oob_irq(void);
-extern int sunxi_wlan_get_oob_irq_flags(void);
-#endif
-#ifdef CONFIG_GPIO_WAKEUP
-extern unsigned int oob_irq;
-#endif
-#endif // CONFIG_MMC
-
-/*
- * Return:
- *	0:	power on successfully
- *	others: power on failed
- */
-int platform_wifi_power_on(void)
-{
-	int ret = 0;
-
-#ifdef CONFIG_MMC
-{
-
-#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
-	int wlan_bus_index = sunxi_wlan_get_bus_index();
-	if(wlan_bus_index < 0)
-		return wlan_bus_index;
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 can be applied to following platforms:
+ *	CONFIG_PLATFORM_ARM_SUN50IW1P1
+ */
+#include <drv_types.h>
+#ifdef CONFIG_GPIO_WAKEUP
+#include <linux/gpio.h>
+#endif
 
-	sunxi_wlan_set_power(1);
-	mdelay(100);
-	sunxi_mmc_rescan_card(wlan_bus_index);
-#endif
-	DBG_871X("%s: power up, rescan card.\n", __FUNCTION__);
-
-#ifdef CONFIG_GPIO_WAKEUP
-#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
-	oob_irq = sunxi_wlan_get_oob_irq();
-#endif
-#endif // CONFIG_GPIO_WAKEUP
-}
-#endif // CONFIG_MMC
-
-	return ret;
-}
-
-void platform_wifi_power_off(void)
-{
-#ifdef CONFIG_MMC
-#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
-	int wlan_bus_index = sunxi_wlan_get_bus_index();
-	if(wlan_bus_index < 0)
+#ifdef CONFIG_MMC
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+extern void sunxi_mmc_rescan_card(unsigned ids);
+extern void sunxi_wlan_set_power(int on);
+extern int sunxi_wlan_get_bus_index(void);
+extern int sunxi_wlan_get_oob_irq(void);
+extern int sunxi_wlan_get_oob_irq_flags(void);
+#endif
+#ifdef CONFIG_GPIO_WAKEUP
+extern unsigned int oob_irq;
+#endif
+#endif /* CONFIG_MMC */
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#ifdef CONFIG_MMC
+	{
+
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+		int wlan_bus_index = sunxi_wlan_get_bus_index();
+		if (wlan_bus_index < 0)
+			return wlan_bus_index;
+
+		sunxi_wlan_set_power(1);
+		mdelay(100);
+		sunxi_mmc_rescan_card(wlan_bus_index);
+#endif
+		RTW_INFO("%s: power up, rescan card.\n", __FUNCTION__);
+
+#ifdef CONFIG_GPIO_WAKEUP
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+		oob_irq = sunxi_wlan_get_oob_irq();
+#endif
+#endif /* CONFIG_GPIO_WAKEUP */
+	}
+#endif /* CONFIG_MMC */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#ifdef CONFIG_MMC
+#if defined(CONFIG_PLATFORM_ARM_SUN50IW1P1)
+	int wlan_bus_index = sunxi_wlan_get_bus_index();
+	if (wlan_bus_index < 0)
 		return;
 
-	sunxi_mmc_rescan_card(wlan_bus_index);
-	mdelay(100);
-	sunxi_wlan_set_power(0);
-#endif
-	DBG_871X("%s: remove card, power off.\n", __FUNCTION__);
-#endif // CONFIG_MMC
-}
+	sunxi_mmc_rescan_card(wlan_bus_index);
+	mdelay(100);
+	sunxi_wlan_set_power(0);
+#endif
+	RTW_INFO("%s: remove card, power off.\n", __FUNCTION__);
+#endif /* CONFIG_MMC */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNnI_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNnI_sdio.c
index 64f93a201141..11e0736b31c0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNnI_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNnI_sdio.c
@@ -1,135 +1,131 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-/*
- * Description:
- *	This file can be applied to following platforms:
- *	CONFIG_PLATFORM_ARM_SUN6I
- *	CONFIG_PLATFORM_ARM_SUN7I
- *	CONFIG_PLATFORM_ARM_SUN8I
- */
-#include <drv_types.h>
-#include <mach/sys_config.h>
-#ifdef CONFIG_GPIO_WAKEUP
-#include <linux/gpio.h>
-#endif
-
-#ifdef CONFIG_MMC
-static int sdc_id = -1;
-static signed int gpio_eint_wlan = -1;
-static u32 eint_wlan_handle = 0;
-
-#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
-extern void sw_mci_rescan_card(unsigned id, unsigned insert);
-#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
-extern void sunxi_mci_rescan_card(unsigned id, unsigned insert);
-#endif
-
-#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
-extern int get_rf_mod_type(void);
-#else
-extern int wifi_pm_get_mod_type(void);
-#endif
-
-extern void wifi_pm_power(int on);
-#ifdef CONFIG_GPIO_WAKEUP
-extern unsigned int oob_irq;
-#endif
-#endif // CONFIG_MMC
-
-/*
- * Return:
- *	0:	power on successfully
- *	others: power on failed
- */
-int platform_wifi_power_on(void)
-{
-	int ret = 0;
-
-#ifdef CONFIG_MMC
-{
-	script_item_u val;
-	script_item_value_type_e type;
-
-#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
-	unsigned int mod_sel = get_rf_mod_type();
-#else
-	unsigned int mod_sel = wifi_pm_get_mod_type();
-#endif
-
-	type = script_get_item("wifi_para", "wifi_sdc_id", &val);
-	if (SCIRPT_ITEM_VALUE_TYPE_INT!=type) {
-		DBG_871X("get wifi_sdc_id failed\n");
-		ret = -1;
-	} else {
-		sdc_id = val.val;
-		DBG_871X("----- %s sdc_id: %d, mod_sel: %d\n", __FUNCTION__, sdc_id, mod_sel);
-
-#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
-		sw_mci_rescan_card(sdc_id, 1);
-#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
-		sunxi_mci_rescan_card(sdc_id, 1);
-#endif
-		mdelay(100);
-		wifi_pm_power(1);
-
-		DBG_871X("%s: power up, rescan card.\n", __FUNCTION__);
-	}
-
-#ifdef CONFIG_GPIO_WAKEUP
-#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
-	type = script_get_item("wifi_para", "wl_host_wake", &val);
-#else
-#ifdef CONFIG_RTL8723B
-	type = script_get_item("wifi_para", "rtl8723bs_wl_host_wake", &val);
-#endif
-#ifdef CONFIG_RTL8188E
-	type = script_get_item("wifi_para", "rtl8189es_host_wake", &val);
-#endif
-#endif /* CONFIG_PLATFORM_ARM_SUN8I_W5P1 */
-	if (SCIRPT_ITEM_VALUE_TYPE_PIO != type) {
-		DBG_871X("No definition of wake up host PIN\n");
-		ret = -1;
-	} else {
-		gpio_eint_wlan = val.gpio.gpio;
-#ifdef CONFIG_PLATFORM_ARM_SUN8I
-		oob_irq = gpio_to_irq(gpio_eint_wlan);
-#endif
-	}
-#endif // CONFIG_GPIO_WAKEUP
-}
-#endif // CONFIG_MMC
-
-	return ret;
-}
-
-void platform_wifi_power_off(void)
-{
-#ifdef CONFIG_MMC
-#if defined(CONFIG_PLATFORM_ARM_SUN6I) ||defined(CONFIG_PLATFORM_ARM_SUN7I)
-	sw_mci_rescan_card(sdc_id, 0);
-#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
-	sunxi_mci_rescan_card(sdc_id, 0);
-#endif
-	mdelay(100);
-	wifi_pm_power(0);
-
-	DBG_871X("%s: remove card, power off.\n", __FUNCTION__);
-#endif // CONFIG_MMC
-}
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 can be applied to following platforms:
+ *	CONFIG_PLATFORM_ARM_SUN6I
+ *	CONFIG_PLATFORM_ARM_SUN7I
+ *	CONFIG_PLATFORM_ARM_SUN8I
+ */
+#include <drv_types.h>
+#include <mach/sys_config.h>
+#ifdef CONFIG_GPIO_WAKEUP
+#include <linux/gpio.h>
+#endif
+
+#ifdef CONFIG_MMC
+static int sdc_id = -1;
+static signed int gpio_eint_wlan = -1;
+static u32 eint_wlan_handle = 0;
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+extern void sw_mci_rescan_card(unsigned id, unsigned insert);
+#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
+extern void sunxi_mci_rescan_card(unsigned id, unsigned insert);
+#endif
+
+#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
+extern int get_rf_mod_type(void);
+#else
+extern int wifi_pm_get_mod_type(void);
+#endif
+
+extern void wifi_pm_power(int on);
+#ifdef CONFIG_GPIO_WAKEUP
+extern unsigned int oob_irq;
+#endif
+#endif /* CONFIG_MMC */
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#ifdef CONFIG_MMC
+	{
+		script_item_u val;
+		script_item_value_type_e type;
+
+#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
+		unsigned int mod_sel = get_rf_mod_type();
+#else
+		unsigned int mod_sel = wifi_pm_get_mod_type();
+#endif
+
+		type = script_get_item("wifi_para", "wifi_sdc_id", &val);
+		if (SCIRPT_ITEM_VALUE_TYPE_INT != type) {
+			RTW_INFO("get wifi_sdc_id failed\n");
+			ret = -1;
+		} else {
+			sdc_id = val.val;
+			RTW_INFO("----- %s sdc_id: %d, mod_sel: %d\n", __FUNCTION__, sdc_id, mod_sel);
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+			sw_mci_rescan_card(sdc_id, 1);
+#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
+			sunxi_mci_rescan_card(sdc_id, 1);
+#endif
+			mdelay(100);
+			wifi_pm_power(1);
+
+			RTW_INFO("%s: power up, rescan card.\n", __FUNCTION__);
+		}
+
+#ifdef CONFIG_GPIO_WAKEUP
+#ifdef CONFIG_PLATFORM_ARM_SUN8I_W5P1
+		type = script_get_item("wifi_para", "wl_host_wake", &val);
+#else
+#ifdef CONFIG_RTL8723B
+		type = script_get_item("wifi_para", "rtl8723bs_wl_host_wake", &val);
+#endif
+#ifdef CONFIG_RTL8188E
+		type = script_get_item("wifi_para", "rtl8189es_host_wake", &val);
+#endif
+#endif /* CONFIG_PLATFORM_ARM_SUN8I_W5P1 */
+		if (SCIRPT_ITEM_VALUE_TYPE_PIO != type) {
+			RTW_INFO("No definition of wake up host PIN\n");
+			ret = -1;
+		} else {
+			gpio_eint_wlan = val.gpio.gpio;
+#ifdef CONFIG_PLATFORM_ARM_SUN8I
+			oob_irq = gpio_to_irq(gpio_eint_wlan);
+#endif
+		}
+#endif /* CONFIG_GPIO_WAKEUP */
+	}
+#endif /* CONFIG_MMC */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#ifdef CONFIG_MMC
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+	sw_mci_rescan_card(sdc_id, 0);
+#elif defined(CONFIG_PLATFORM_ARM_SUN8I)
+	sunxi_mci_rescan_card(sdc_id, 0);
+#endif
+	mdelay(100);
+	wifi_pm_power(0);
+
+	RTW_INFO("%s: remove card, power off.\n", __FUNCTION__);
+#endif /* CONFIG_MMC */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_sdio.c
index 5bc888dc4ac3..c1937844918d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_sdio.c
@@ -1,95 +1,91 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#include <drv_types.h>
-
-#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
-#ifdef CONFIG_WITS_EVB_V13
-#define SDIOID	0
-#else // !CONFIG_WITS_EVB_V13
-#define SDIOID (CONFIG_CHIP_ID==1123 ? 3 : 1)
-#endif // !CONFIG_WITS_EVB_V13
-
-#define SUNXI_SDIO_WIFI_NUM_RTL8189ES  10
-extern void sunximmc_rescan_card(unsigned id, unsigned insert);
-extern int mmc_pm_get_mod_type(void);
-extern int mmc_pm_gpio_ctrl(char* name, int level);
-/*
- *	rtl8189es_shdn	= port:PH09<1><default><default><0>
- *	rtl8189es_wakeup	= port:PH10<1><default><default><1>
- *	rtl8189es_vdd_en  = port:PH11<1><default><default><0>
- *	rtl8189es_vcc_en  = port:PH12<1><default><default><0>
- */
-
-int rtl8189es_sdio_powerup(void)
-{
-	mmc_pm_gpio_ctrl("rtl8189es_vdd_en", 1);
-	udelay(100);
-	mmc_pm_gpio_ctrl("rtl8189es_vcc_en", 1);
-	udelay(50);
-	mmc_pm_gpio_ctrl("rtl8189es_shdn", 1);
-	return 0;
-}
-
-int rtl8189es_sdio_poweroff(void)
-{
-	mmc_pm_gpio_ctrl("rtl8189es_shdn", 0);
-	mmc_pm_gpio_ctrl("rtl8189es_vcc_en", 0);
-	mmc_pm_gpio_ctrl("rtl8189es_vdd_en", 0);
-	return 0;
-}
-#endif // CONFIG_MMC_SUNXI_POWER_CONTROL
-
-/*
- * Return:
- *	0:	power on successfully
- *	others:	power on failed
- */
-int platform_wifi_power_on(void)
-{
-	int ret = 0;
-#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
-	unsigned int mod_sel = mmc_pm_get_mod_type();
-#endif // CONFIG_MMC_SUNXI_POWER_CONTROL
-
-
-#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
-	if (mod_sel == SUNXI_SDIO_WIFI_NUM_RTL8189ES) {
-		rtl8189es_sdio_powerup();
-		sunximmc_rescan_card(SDIOID, 1);
-		printk("[rtl8189es] %s: power up, rescan card.\n", __FUNCTION__);
-	} else {
-		ret = -1;
-		printk("[rtl8189es] %s: mod_sel = %d is incorrect.\n", __FUNCTION__, mod_sel);
-	}
-#endif // CONFIG_MMC_SUNXI_POWER_CONTROL
-
-	return ret;
-}
-
-void platform_wifi_power_off(void)
-{
-#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
-	sunximmc_rescan_card(SDIOID, 0);
-#ifdef CONFIG_RTL8188E
-	rtl8189es_sdio_poweroff();
-	printk("[rtl8189es] %s: remove card, power off.\n", __FUNCTION__);
-#endif // CONFIG_RTL8188E
-#endif // CONFIG_MMC_SUNXI_POWER_CONTROL
-}
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+#ifdef CONFIG_WITS_EVB_V13
+	#define SDIOID	0
+#else /* !CONFIG_WITS_EVB_V13 */
+	#define SDIOID (CONFIG_CHIP_ID == 1123 ? 3 : 1)
+#endif /* !CONFIG_WITS_EVB_V13 */
+
+#define SUNXI_SDIO_WIFI_NUM_RTL8189ES  10
+extern void sunximmc_rescan_card(unsigned id, unsigned insert);
+extern int mmc_pm_get_mod_type(void);
+extern int mmc_pm_gpio_ctrl(char *name, int level);
+/*
+ *	rtl8189es_shdn	= port:PH09<1><default><default><0>
+ *	rtl8189es_wakeup	= port:PH10<1><default><default><1>
+ *	rtl8189es_vdd_en  = port:PH11<1><default><default><0>
+ *	rtl8189es_vcc_en  = port:PH12<1><default><default><0>
+ */
+
+int rtl8189es_sdio_powerup(void)
+{
+	mmc_pm_gpio_ctrl("rtl8189es_vdd_en", 1);
+	udelay(100);
+	mmc_pm_gpio_ctrl("rtl8189es_vcc_en", 1);
+	udelay(50);
+	mmc_pm_gpio_ctrl("rtl8189es_shdn", 1);
+	return 0;
+}
+
+int rtl8189es_sdio_poweroff(void)
+{
+	mmc_pm_gpio_ctrl("rtl8189es_shdn", 0);
+	mmc_pm_gpio_ctrl("rtl8189es_vcc_en", 0);
+	mmc_pm_gpio_ctrl("rtl8189es_vdd_en", 0);
+	return 0;
+}
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+	unsigned int mod_sel = mmc_pm_get_mod_type();
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+
+
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+	if (mod_sel == SUNXI_SDIO_WIFI_NUM_RTL8189ES) {
+		rtl8189es_sdio_powerup();
+		sunximmc_rescan_card(SDIOID, 1);
+		printk("[rtl8189es] %s: power up, rescan card.\n", __FUNCTION__);
+	} else {
+		ret = -1;
+		printk("[rtl8189es] %s: mod_sel = %d is incorrect.\n", __FUNCTION__, mod_sel);
+	}
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#ifdef CONFIG_MMC_SUNXI_POWER_CONTROL
+	sunximmc_rescan_card(SDIOID, 0);
+#ifdef CONFIG_RTL8188E
+	rtl8189es_sdio_poweroff();
+	printk("[rtl8189es] %s: remove card, power off.\n", __FUNCTION__);
+#endif /* CONFIG_RTL8188E */
+#endif /* CONFIG_MMC_SUNXI_POWER_CONTROL */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_usb.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_usb.c
index 5352313a7883..caf6a6ecabd7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_usb.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_SUNxI_usb.c
@@ -1,142 +1,137 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-/*
- * Description:
- *	This file can be applied to following platforms:
- *	CONFIG_PLATFORM_ARM_SUNXI Series platform 
- *	
- */
- 
-#include <drv_types.h>
-#include <mach/sys_config.h>
-
-#ifdef CONFIG_PLATFORM_ARM_SUNxI
-extern int sw_usb_disable_hcd(__u32 usbc_no);
-extern int sw_usb_enable_hcd(__u32 usbc_no);
-static int usb_wifi_host = 2;
-#endif
-
-#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
-extern int sw_usb_disable_hcd(__u32 usbc_no);
-extern int sw_usb_enable_hcd(__u32 usbc_no);
-extern void wifi_pm_power(int on);
-static script_item_u item;
-#endif
-
-#ifdef CONFIG_PLATFORM_ARM_SUN8I
-extern int sunxi_usb_disable_hcd(__u32 usbc_no);
-extern int sunxi_usb_enable_hcd(__u32 usbc_no);
-extern void wifi_pm_power(int on);
-static script_item_u item;
-#endif
-
-
-int platform_wifi_power_on(void)
-{
-	int ret = 0;
-
-#ifdef CONFIG_PLATFORM_ARM_SUNxI
-#ifndef CONFIG_RTL8723A
-	{
-		/* ----------get usb_wifi_usbc_num------------- */
-		ret = script_parser_fetch("usb_wifi_para", "usb_wifi_usbc_num", (int *)&usb_wifi_host, 64);
-		if(ret != 0){
-			DBG_8192C("ERR: script_parser_fetch usb_wifi_usbc_num failed\n");
-			ret = -ENOMEM;
-			goto exit;
-		}
-		DBG_8192C("sw_usb_enable_hcd: usbc_num = %d\n", usb_wifi_host);
-		sw_usb_enable_hcd(usb_wifi_host);
-	}
-#endif //CONFIG_RTL8723A
-#endif //CONFIG_PLATFORM_ARM_SUNxI
-
-#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
-	{
-		script_item_value_type_e type;
-
-		type = script_get_item("wifi_para", "wifi_usbc_id", &item);
-		if(SCIRPT_ITEM_VALUE_TYPE_INT != type){
-			printk("ERR: script_get_item wifi_usbc_id failed\n");
-			ret = -ENOMEM;
-			goto exit;
-		}
-
-		printk("sw_usb_enable_hcd: usbc_num = %d\n", item.val);
-		wifi_pm_power(1);
-		mdelay(10);
-	
-		#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
-		sw_usb_enable_hcd(item.val);
-		#endif
-	}
-#endif //defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
-
-#if defined(CONFIG_PLATFORM_ARM_SUN8I)
-	{
-		script_item_value_type_e type;
-
-		type = script_get_item("wifi_para", "wifi_usbc_id", &item);
-		if(SCIRPT_ITEM_VALUE_TYPE_INT != type){
-			printk("ERR: script_get_item wifi_usbc_id failed\n");
-			ret = -ENOMEM;
-			goto exit;
-		}
-
-		printk("sw_usb_enable_hcd: usbc_num = %d\n", item.val);
-		wifi_pm_power(1);
-		mdelay(10);
-	
-		#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
-		sunxi_usb_enable_hcd(item.val);
-		#endif
-	}
-#endif //CONFIG_PLATFORM_ARM_SUN8I
-
-exit:
-	return ret;
-}
-
-void platform_wifi_power_off(void)
-{
-
-#ifdef CONFIG_PLATFORM_ARM_SUNxI
-#ifndef CONFIG_RTL8723A
-	DBG_8192C("sw_usb_disable_hcd: usbc_num = %d\n", usb_wifi_host);
-	sw_usb_disable_hcd(usb_wifi_host);
-#endif //ifndef CONFIG_RTL8723A
-#endif	//CONFIG_PLATFORM_ARM_SUNxI
-
-#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
-	#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
-	sw_usb_disable_hcd(item.val);
-	#endif
-	wifi_pm_power(0);
-#endif //defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
-
-#if defined(CONFIG_PLATFORM_ARM_SUN8I)
-	#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
-	sunxi_usb_disable_hcd(item.val);
-	#endif
-	wifi_pm_power(0);
-#endif //defined(CONFIG_PLATFORM_ARM_SUN8I) 
-
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 can be applied to following platforms:
+ *	CONFIG_PLATFORM_ARM_SUNXI Series platform
+ *
+ */
+
+#include <drv_types.h>
+#include <mach/sys_config.h>
+
+#ifdef CONFIG_PLATFORM_ARM_SUNxI
+extern int sw_usb_disable_hcd(__u32 usbc_no);
+extern int sw_usb_enable_hcd(__u32 usbc_no);
+static int usb_wifi_host = 2;
+#endif
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+extern int sw_usb_disable_hcd(__u32 usbc_no);
+extern int sw_usb_enable_hcd(__u32 usbc_no);
+extern void wifi_pm_power(int on);
+static script_item_u item;
+#endif
+
+#ifdef CONFIG_PLATFORM_ARM_SUN8I
+extern int sunxi_usb_disable_hcd(__u32 usbc_no);
+extern int sunxi_usb_enable_hcd(__u32 usbc_no);
+extern void wifi_pm_power(int on);
+static script_item_u item;
+#endif
+
+
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#ifdef CONFIG_PLATFORM_ARM_SUNxI
+#ifndef CONFIG_RTL8723A
+	{
+		/* ----------get usb_wifi_usbc_num------------- */
+		ret = script_parser_fetch("usb_wifi_para", "usb_wifi_usbc_num", (int *)&usb_wifi_host, 64);
+		if (ret != 0) {
+			RTW_INFO("ERR: script_parser_fetch usb_wifi_usbc_num failed\n");
+			ret = -ENOMEM;
+			goto exit;
+		}
+		RTW_INFO("sw_usb_enable_hcd: usbc_num = %d\n", usb_wifi_host);
+		sw_usb_enable_hcd(usb_wifi_host);
+	}
+#endif /* CONFIG_RTL8723A */
+#endif /* CONFIG_PLATFORM_ARM_SUNxI */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+	{
+		script_item_value_type_e type;
+
+		type = script_get_item("wifi_para", "wifi_usbc_id", &item);
+		if (SCIRPT_ITEM_VALUE_TYPE_INT != type) {
+			printk("ERR: script_get_item wifi_usbc_id failed\n");
+			ret = -ENOMEM;
+			goto exit;
+		}
+
+		printk("sw_usb_enable_hcd: usbc_num = %d\n", item.val);
+		wifi_pm_power(1);
+		mdelay(10);
+
+#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+		sw_usb_enable_hcd(item.val);
+#endif
+	}
+#endif /* defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I) */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN8I)
+	{
+		script_item_value_type_e type;
+
+		type = script_get_item("wifi_para", "wifi_usbc_id", &item);
+		if (SCIRPT_ITEM_VALUE_TYPE_INT != type) {
+			printk("ERR: script_get_item wifi_usbc_id failed\n");
+			ret = -ENOMEM;
+			goto exit;
+		}
+
+		printk("sw_usb_enable_hcd: usbc_num = %d\n", item.val);
+		wifi_pm_power(1);
+		mdelay(10);
+
+#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+		sunxi_usb_enable_hcd(item.val);
+#endif
+	}
+#endif /* CONFIG_PLATFORM_ARM_SUN8I */
+
+exit:
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+
+#ifdef CONFIG_PLATFORM_ARM_SUNxI
+#ifndef CONFIG_RTL8723A
+	RTW_INFO("sw_usb_disable_hcd: usbc_num = %d\n", usb_wifi_host);
+	sw_usb_disable_hcd(usb_wifi_host);
+#endif /* ifndef CONFIG_RTL8723A */
+#endif /* CONFIG_PLATFORM_ARM_SUNxI */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I)
+	#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+	sw_usb_disable_hcd(item.val);
+	#endif
+	wifi_pm_power(0);
+#endif /* defined(CONFIG_PLATFORM_ARM_SUN6I) || defined(CONFIG_PLATFORM_ARM_SUN7I) */
+
+#if defined(CONFIG_PLATFORM_ARM_SUN8I)
+	#if !(defined(CONFIG_RTL8723A)) && !(defined(CONFIG_RTL8723B))
+	sunxi_usb_disable_hcd(item.val);
+	#endif
+	wifi_pm_power(0);
+#endif /* defined(CONFIG_PLATFORM_ARM_SUN8I) */
+
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_WMT_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_WMT_sdio.c
index 62e5825886cb..b4f59209b4ee 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_WMT_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ARM_WMT_sdio.c
@@ -1,51 +1,47 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#include <drv_types.h>
-#include <mach/wmt_iomux.h>
-#include <linux/gpio.h>
-
-extern void wmt_detect_sdio2(void);
-extern void force_remove_sdio2(void);
-
-int platform_wifi_power_on(void)
-{
-	int err = 0;
-	err = gpio_request(WMT_PIN_GP62_SUSGPIO1, "wifi_chip_en");
-	if (err < 0){
-		printk("request gpio for rtl8188eu failed!\n");
-		return err;
-	}
-	gpio_direction_output(WMT_PIN_GP62_SUSGPIO1, 0);//pull sus_gpio1 to 0 to open vcc_wifi.
-	printk("power on rtl8189.\n");
-	msleep(500);
-	wmt_detect_sdio2();
-	printk("[rtl8189es] %s: new card, power on.\n", __FUNCTION__);
-	return err;
-}
-
-void platform_wifi_power_off(void)
-{
-	force_remove_sdio2();
-
-	gpio_direction_output(WMT_PIN_GP62_SUSGPIO1, 1);//pull sus_gpio1 to 1 to close vcc_wifi.
-	printk("power off rtl8189.\n");
-	gpio_free(WMT_PIN_GP62_SUSGPIO1);
-	printk("[rtl8189es] %s: remove card, power off.\n", __FUNCTION__);
-}
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 <mach/wmt_iomux.h>
+#include <linux/gpio.h>
+
+extern void wmt_detect_sdio2(void);
+extern void force_remove_sdio2(void);
+
+int platform_wifi_power_on(void)
+{
+	int err = 0;
+	err = gpio_request(WMT_PIN_GP62_SUSGPIO1, "wifi_chip_en");
+	if (err < 0) {
+		printk("request gpio for rtl8188eu failed!\n");
+		return err;
+	}
+	gpio_direction_output(WMT_PIN_GP62_SUSGPIO1, 0);/* pull sus_gpio1 to 0 to open vcc_wifi. */
+	printk("power on rtl8189.\n");
+	msleep(500);
+	wmt_detect_sdio2();
+	printk("[rtl8189es] %s: new card, power on.\n", __FUNCTION__);
+	return err;
+}
+
+void platform_wifi_power_off(void)
+{
+	force_remove_sdio2();
+
+	gpio_direction_output(WMT_PIN_GP62_SUSGPIO1, 1);/* pull sus_gpio1 to 1 to close vcc_wifi. */
+	printk("power off rtl8189.\n");
+	gpio_free(WMT_PIN_GP62_SUSGPIO1);
+	printk("[rtl8189es] %s: remove card, power off.\n", __FUNCTION__);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_RTK_DMP_usb.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_RTK_DMP_usb.c
index 533143381b86..cd15f96d157a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_RTK_DMP_usb.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_RTK_DMP_usb.c
@@ -1,36 +1,31 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#include <drv_types.h>
-
-int platform_wifi_power_on(void)
-{
-	int ret = 0;
-	u32 tmp;
-	tmp=readl((volatile unsigned int*)0xb801a608);
-	tmp &= 0xffffff00;
-	tmp |= 0x55;
-	writel(tmp,(volatile unsigned int*)0xb801a608);//write dummy register for 1055
-	return ret;
-}
-
-void platform_wifi_power_off(void)
-{
-}
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+	u32 tmp;
+	tmp = readl((volatile unsigned int *)0xb801a608);
+	tmp &= 0xffffff00;
+	tmp |= 0x55;
+	writel(tmp, (volatile unsigned int *)0xb801a608); /* write dummy register for 1055 */
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_aml_s905_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_aml_s905_sdio.c
new file mode 100644
index 000000000000..1ce4e06fd2d4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_aml_s905_sdio.c
@@ -0,0 +1,55 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/printk.h>		/* pr_info(() */
+#include <linux/delay.h>		/* msleep() */
+#include "platform_aml_s905_sdio.h"	/* sdio_reinit() and etc */
+
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+	ret = wifi_setup_dt();
+	if (ret) {
+		pr_err("%s: setup dt failed!!(%d)\n", __func__, ret);
+		return -1;
+	}
+#endif /* kernel < 3.14.0 */
+
+#if 0 /* Seems redundancy? Already done before insert driver */
+	pr_info("######%s:\n", __func__);
+	extern_wifi_set_enable(0);
+	msleep(500);
+	extern_wifi_set_enable(1);
+	msleep(500);
+	sdio_reinit();
+#endif
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+	wifi_teardown_dt();
+#endif /* kernel < 3.14.0 */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_aml_s905_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_aml_s905_sdio.h
new file mode 100644
index 000000000000..f8cebf1073a5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_aml_s905_sdio.h
@@ -0,0 +1,29 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_AML_S905_SDIO_H__
+#define __PLATFORM_AML_S905_SDIO_H__
+
+#include <linux/version.h>	/* Linux vresion */
+
+extern void sdio_reinit(void);
+extern void extern_wifi_set_enable(int is_on);
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+extern void wifi_teardown_dt(void);
+extern int wifi_setup_dt(void);
+#endif /* kernel < 3.14.0 */
+
+#endif /* __PLATFORM_AML_S905_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_arm_act_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_arm_act_sdio.c
index 539bb178c584..a106b36aa290 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_arm_act_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_arm_act_sdio.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2013 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
  *
  * 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
@@ -11,12 +12,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  * more details.
  *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
+ *****************************************************************************/
 /*
  * Description:
  *	This file can be applied to following platforms:
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_hisilicon_hi3798_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_hisilicon_hi3798_sdio.c
new file mode 100644
index 000000000000..4ecbcf0add29
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_hisilicon_hi3798_sdio.c
@@ -0,0 +1,111 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/delay.h>		/* mdelay() */
+#include <mach/hardware.h>		/* __io_address(), readl(), writel() */
+#include "platform_hisilicon_hi3798_sdio.h"	/* HI_S32() and etc. */
+
+typedef enum hi_GPIO_DIR_E {
+	HI_DIR_OUT = 0,
+	HI_DIR_IN  = 1,
+} HI_GPIO_DIR_E;
+
+#define RTL_REG_ON_GPIO		(4*8 + 3)
+
+#define REG_BASE_CTRL		__io_address(0xf8a20008)
+
+int gpio_wlan_reg_on = RTL_REG_ON_GPIO;
+#if 0
+module_param(gpio_wlan_reg_on, uint, 0644);
+MODULE_PARM_DESC(gpio_wlan_reg_on, "wlan reg_on gpio num (default:gpio4_3)");
+#endif
+
+static int hi_gpio_set_value(u32 gpio, u32 value)
+{
+	HI_S32 s32Status;
+
+	s32Status = HI_DRV_GPIO_SetDirBit(gpio, HI_DIR_OUT);
+	if (s32Status != HI_SUCCESS) {
+		pr_err("gpio(%d) HI_DRV_GPIO_SetDirBit HI_DIR_OUT failed\n",
+			gpio);
+		return -1;
+	}
+
+	s32Status = HI_DRV_GPIO_WriteBit(gpio, value);
+	if (s32Status != HI_SUCCESS) {
+		pr_err("gpio(%d) HI_DRV_GPIO_WriteBit value(%d) failed\n",
+			gpio, value);
+		return -1;
+	}
+
+	return 0;
+}
+
+static int hisi_wlan_set_carddetect(bool present)
+{
+	u32 regval;
+	u32 mask;
+
+
+#ifndef CONFIG_HISI_SDIO_ID
+	return;
+#endif
+	pr_info("SDIO ID=%d\n", CONFIG_HISI_SDIO_ID);
+#if (CONFIG_HISI_SDIO_ID == 1)
+	mask = 1;
+#elif (CONFIG_HISI_SDIO_ID == 0)
+	mask = 2;
+#endif
+
+	regval = readl(REG_BASE_CTRL);
+	if (present) {
+		pr_info("====== Card detection to detect SDIO card! ======\n");
+		/* set card_detect low to detect card */
+		regval |= mask;
+	} else {
+		pr_info("====== Card detection to remove SDIO card! ======\n");
+		/* set card_detect high to remove card */
+		regval &= ~(mask);
+	}
+	writel(regval, REG_BASE_CTRL);
+
+	return 0;
+}
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+
+	hi_gpio_set_value(gpio_wlan_reg_on, 1);
+	mdelay(100);
+	hisi_wlan_set_carddetect(1);
+	mdelay(2000);
+	pr_info("======== set_carddetect delay 2s! ========\n");
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	hisi_wlan_set_carddetect(0);
+	mdelay(100);
+	hi_gpio_set_value(gpio_wlan_reg_on, 0);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_hisilicon_hi3798_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_hisilicon_hi3798_sdio.h
new file mode 100644
index 000000000000..07a4e6a6e62b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_hisilicon_hi3798_sdio.h
@@ -0,0 +1,29 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_HISILICON_HI3798_SDIO_H__
+#define __PLATFORM_HISILICON_HI3798_SDIO_H__
+
+typedef unsigned int	HI_U32;
+
+typedef int		HI_S32;
+
+#define HI_SUCCESS	0
+#define HI_FAILURE	(-1)
+
+extern HI_S32 HI_DRV_GPIO_SetDirBit(HI_U32 u32GpioNo, HI_U32 u32DirBit);
+extern HI_S32 HI_DRV_GPIO_WriteBit(HI_U32 u32GpioNo, HI_U32 u32BitValue);
+
+#endif /* __PLATFORM_HISILICON_HI3798_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.c
index 6352cc598b94..5230c5bdf949 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.c
@@ -1,42 +1,36 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef CONFIG_PLATFORM_OPS
-
-#include <linux/rfkill-wlan.h>
-extern unsigned int oob_irq;
-
-/*
- * Return:
- *	0:	power on successfully
- *	others: power on failed
- */
-int platform_wifi_power_on(void)
-{
-	int ret = 0;
-
-	oob_irq = rockchip_wifi_get_oob_irq();
-
-	return ret;
-}
-
-void platform_wifi_power_off(void)
-{
-}
-#endif // !CONFIG_PLATFORM_OPS
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 CONFIG_PLATFORM_OPS
+#include <linux/rfkill-wlan.h>
+extern unsigned int oob_irq;
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+	oob_irq = rockchip_wifi_get_oob_irq();
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+}
+#endif /* !CONFIG_PLATFORM_OPS */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.h
index bd2e6683c342..6f8588e8670b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_ops.h
@@ -1,31 +1,27 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#ifndef __PLATFORM_OPS_H__
-#define __PLATFORM_OPS_H__
-
-/*
- * Return:
- *	0:	power on successfully
- *	others: power on failed
- */
-int platform_wifi_power_on(void);
-void platform_wifi_power_off(void);
-
-#endif // __PLATFORM_OPS_H__
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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 __PLATFORM_OPS_H__
+#define __PLATFORM_OPS_H__
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void);
+void platform_wifi_power_off(void);
+
+#endif /* __PLATFORM_OPS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_sprd_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_sprd_sdio.c
index a4e2502fe5b9..4a0240f491a7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_sprd_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_sprd_sdio.c
@@ -1,89 +1,85 @@
-/******************************************************************************
- *
- * Copyright(c) 2013 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.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
- *
- *
- ******************************************************************************/
-#include <drv_types.h>
-
-extern void sdhci_bus_scan(void);
-#ifndef ANDROID_2X
-extern int sdhci_device_attached(void);
-#endif
-
-/*
- * Return:
- *	0:	power on successfully
- *	others:	power on failed
- */
-int platform_wifi_power_on(void)
-{
-	int ret = 0;
-
-
-#ifdef CONFIG_RTL8188E
-	rtw_wifi_gpio_wlan_ctrl(WLAN_POWER_ON);
-#endif // CONFIG_RTL8188E
-
-	/* Pull up pwd pin, make wifi leave power down mode. */
-	rtw_wifi_gpio_init();
-	rtw_wifi_gpio_wlan_ctrl(WLAN_PWDN_ON);
-
-#if (MP_DRIVER == 1) && (defined(CONFIG_RTL8723A)||defined(CONFIG_RTL8723B))
-	// Pull up BT reset pin.
-	rtw_wifi_gpio_wlan_ctrl(WLAN_BT_PWDN_ON);
-#endif
-	rtw_mdelay_os(5);
-
-	sdhci_bus_scan();
-#ifdef CONFIG_RTL8723B
-	//YJ,test,130305
-	rtw_mdelay_os(1000);
-#endif
-#ifdef ANDROID_2X
-	rtw_mdelay_os(200);
-#else // !ANDROID_2X
-	if (1) {
-		int i = 0;
-
-		for (i = 0; i <= 50; i++) {
-			msleep(10);
-			if (sdhci_device_attached())
-				break;
-			printk("%s delay times:%d\n", __func__, i);
-		}
-	}
-#endif // !ANDROID_2X
-
-	return ret;
-}
-
-void platform_wifi_power_off(void)
-{
-	/* Pull down pwd pin, make wifi enter power down mode. */
-	rtw_wifi_gpio_wlan_ctrl(WLAN_PWDN_OFF);
-	rtw_mdelay_os(5);
-	rtw_wifi_gpio_deinit();
-
-#ifdef CONFIG_RTL8188E
-	rtw_wifi_gpio_wlan_ctrl(WLAN_POWER_OFF);
-#endif // CONFIG_RTL8188E
-
-#ifdef CONFIG_WOWLAN
-	if(mmc_host)
-		mmc_host->pm_flags &= ~MMC_PM_KEEP_POWER;
-#endif // CONFIG_WOWLAN
-}
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2013 - 2017 Realtek Corporation.
+ *
+ * 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>
+
+extern void sdhci_bus_scan(void);
+#ifndef ANDROID_2X
+extern int sdhci_device_attached(void);
+#endif
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+
+#ifdef CONFIG_RTL8188E
+	rtw_wifi_gpio_wlan_ctrl(WLAN_POWER_ON);
+#endif /* CONFIG_RTL8188E */
+
+	/* Pull up pwd pin, make wifi leave power down mode. */
+	rtw_wifi_gpio_init();
+	rtw_wifi_gpio_wlan_ctrl(WLAN_PWDN_ON);
+
+#if (MP_DRIVER == 1) && (defined(CONFIG_RTL8723A) || defined(CONFIG_RTL8723B))
+	/* Pull up BT reset pin. */
+	rtw_wifi_gpio_wlan_ctrl(WLAN_BT_PWDN_ON);
+#endif
+	rtw_mdelay_os(5);
+
+	sdhci_bus_scan();
+#ifdef CONFIG_RTL8723B
+	/* YJ,test,130305 */
+	rtw_mdelay_os(1000);
+#endif
+#ifdef ANDROID_2X
+	rtw_mdelay_os(200);
+#else /* !ANDROID_2X */
+	if (1) {
+		int i = 0;
+
+		for (i = 0; i <= 50; i++) {
+			msleep(10);
+			if (sdhci_device_attached())
+				break;
+			printk("%s delay times:%d\n", __func__, i);
+		}
+	}
+#endif /* !ANDROID_2X */
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	/* Pull down pwd pin, make wifi enter power down mode. */
+	rtw_wifi_gpio_wlan_ctrl(WLAN_PWDN_OFF);
+	rtw_mdelay_os(5);
+	rtw_wifi_gpio_deinit();
+
+#ifdef CONFIG_RTL8188E
+	rtw_wifi_gpio_wlan_ctrl(WLAN_POWER_OFF);
+#endif /* CONFIG_RTL8188E */
+
+#ifdef CONFIG_WOWLAN
+	if (mmc_host)
+		mmc_host->pm_flags &= ~MMC_PM_KEEP_POWER;
+#endif /* CONFIG_WOWLAN */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_zte_zx296716_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_zte_zx296716_sdio.c
new file mode 100644
index 000000000000..abd82a0ca28e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_zte_zx296716_sdio.c
@@ -0,0 +1,54 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/printk.h>		/* pr_info(() */
+#include <linux/delay.h>		/* msleep() */
+#include "platform_zte_zx296716_sdio.h"	/* sdio_reinit() and etc */
+
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+	pr_info("######%s: disable--1--\n", __func__);
+	extern_wifi_set_enable(0);
+	/*msleep(500);*/ /* add in function:extern_wifi_set_enable */
+	pr_info("######%s: enable--2---\n", __func__);
+	extern_wifi_set_enable(1);
+	/*msleep(500);*/
+	sdio_reinit();
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	int card_val;
+
+	pr_info("######%s:\n", __func__);
+#ifdef CONFIG_A16T03_BOARD
+	card_val = sdio_host_is_null();
+	if (card_val)
+		remove_card();
+#endif /* CONFIG_A16T03_BOARD */
+	extern_wifi_set_enable(0);
+
+	/*msleep(500);*/
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_zte_zx296716_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_zte_zx296716_sdio.h
new file mode 100644
index 000000000000..a03647ccf664
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8189fs/platform/platform_zte_zx296716_sdio.h
@@ -0,0 +1,26 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_ZTE_ZX296716_SDIO_H__
+#define __PLATFORM_ZTE_ZX296716_SDIO_H__
+
+extern void sdio_reinit(void);
+extern void extern_wifi_set_enable(int val);
+#ifdef CONFIG_A16T03_BOARD
+extern int sdio_host_is_null(void);
+extern void remove_card(void);
+#endif /* CONFIG_A16T03_BOARD */
+
+#endif /* __PLATFORM_ZTE_ZX296716_SDIO_H__ */

commit 0d2ae680e606383937eceab78e04e802117510b4
Author: Caesar Wang <wxt@rock-chips.com>
Date:   Wed Jun 12 16:02:22 2019 +0800

    arm64: dts: rockchip: sound collation on rk3399-sapphire-excavator board
    
    The original order of sound cards registration were really messy......
    
    The hdmi is the first sound card by default.
    for linux:
    [    1.870252] ALSA device list:
    [    1.871548]   #0: rockchip,hdmi
    [    1.871863]   #1: realtek,rt5651-codec
    [    1.872248]   #2: ROCKCHIP,SPDIF
    
    Then after adding this patch,   the sound cards as below:
    [    1.863328] ALSA device list:
    [    1.863601]   #0: realtek,rt5651-codec
    [    1.863942]   #1: rockchip,hdmi
    [    1.864236]   #2: ROCKCHIP,SPDIF
    
    Change-Id: I884df2752e84d95dbddba9b23c7dbd778ffb9357
    Signed-off-by: Caesar Wang <wxt@rock-chips.com>

diff --git a/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi b/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi
index cb8292e40607..9b19576a7d43 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3399-excavator-sapphire.dtsi
@@ -70,6 +70,7 @@
 	};
 
 	rt5651-sound {
+		status = "okay";
 		compatible = "simple-audio-card";
 		simple-audio-card,format = "i2s";
 		simple-audio-card,name = "realtek,rt5651-codec";
@@ -90,6 +91,34 @@
 		};
 	};
 
+	dw_hdmi_audio: dw-hdmi-audio {
+		status = "disabled";
+		compatible = "rockchip,dw-hdmi-audio";
+		#sound-dai-cells = <0>;
+	};
+
+	dp_sound: dp-sound {
+		status = "disabled";
+		compatible = "rockchip,cdndp-sound";
+		rockchip,cpu = <&spdif>;
+		rockchip,codec = <&cdn_dp 1>;
+	};
+
+	hdmi_sound: hdmi-sound {
+		status = "okay";
+		compatible = "simple-audio-card";
+		simple-audio-card,format = "i2s";
+		simple-audio-card,mclk-fs = <256>;
+		simple-audio-card,name = "rockchip,hdmi";
+
+		simple-audio-card,cpu {
+			sound-dai = <&i2s2>;
+		};
+		simple-audio-card,codec {
+			sound-dai = <&hdmi>;
+		};
+	};
+
 	spdif-sound {
 		status = "okay";
 		compatible = "simple-audio-card";
diff --git a/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts b/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
index f474e3b255d6..ecd40b1e02b6 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399-sapphire-excavator-linux.dts
@@ -157,10 +157,6 @@
 		};
 	};
 
-	hdmi_sound: hdmi-sound {
-		status = "okay";
-	};
-
 	ext_cam_clk: external-camera-clock {
 		compatible = "fixed-clock";
 		clock-frequency = <27000000>;
diff --git a/arch/arm64/boot/dts/rockchip/rk3399-sapphire.dtsi b/arch/arm64/boot/dts/rockchip/rk3399-sapphire.dtsi
index 7babf3b6045a..fc0e9f029e5d 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-sapphire.dtsi
+++ b/arch/arm64/boot/dts/rockchip/rk3399-sapphire.dtsi
@@ -94,34 +94,6 @@
 		#clock-cells = <0>;
 	};
 
-	dw_hdmi_audio: dw-hdmi-audio {
-		status = "disabled";
-		compatible = "rockchip,dw-hdmi-audio";
-		#sound-dai-cells = <0>;
-	};
-
-	dp_sound: dp-sound {
-		status = "disabled";
-		compatible = "rockchip,cdndp-sound";
-		rockchip,cpu = <&spdif>;
-		rockchip,codec = <&cdn_dp 1>;
-	};
-
-	hdmi_sound: hdmi-sound {
-		status = "disabled";
-		compatible = "simple-audio-card";
-		simple-audio-card,format = "i2s";
-		simple-audio-card,mclk-fs = <256>;
-		simple-audio-card,name = "rockchip,hdmi";
-
-		simple-audio-card,cpu {
-			sound-dai = <&i2s2>;
-		};
-		simple-audio-card,codec {
-			sound-dai = <&hdmi>;
-		};
-	};
-
 	sdio_pwrseq: sdio-pwrseq {
 		compatible = "mmc-pwrseq-simple";
 		clocks = <&rk808 1>;

commit ee4161d2fd867e5759fa4f332967d0b37cf5728e
Author: William Wu <william.wu@rock-chips.com>
Date:   Mon Jun 10 19:12:55 2019 +0800

    usb: gadget: uvc: support streaming bulk transfer
    
    This patch adds bulk endpoint for uvc to be used as
    video streaming transfer. By default, the uvc gadget
    still uses isoc endpoint for video streaming.
    
    The important difference between the bulk and isoc
    method is that, alt-settings in a video streaming
    interface are supported only for isoc endpoints as
    there are different alt-settings for zero-bandwidth
    and full-bandwidth use-cases, but the same is not
    true for bulk endpoints, as they support only a single
    alt-setting.
    
    How to use:
    1. Enable the bulk transfer:
       echo 1 >  /config/usb-gadget/g1/functions/uvc.name/streaming_bulk
    
    2. Disable the bulk transfer:
       echo 0 >  /config/usb-gadget/g1/functions/uvc.name/streaming_bulk
    
    3. Testing the uvc bulk function transfer:
       device: run the uvc-gadget program
       # uvc-gadget -b -u /dev/video<uvc video node #> -v /dev/video<vivid video node #>
    
       where uvc-gadget is this program:
            http://git.ideasonboard.org/uvc-gadget.git
    
       with these patches:
    
            http://www.spinics.net/lists/linux-usb/msg99220.html
    
    Change-Id: Ifedfe3f5c4354dd2bdf07382290107e9bcc89f59
    Signed-off-by: William Wu <william.wu@rock-chips.com>

diff --git a/drivers/usb/gadget/function/f_uvc.c b/drivers/usb/gadget/function/f_uvc.c
index b1c755069451..0ef3bb695619 100644
--- a/drivers/usb/gadget/function/f_uvc.c
+++ b/drivers/usb/gadget/function/f_uvc.c
@@ -125,6 +125,18 @@ static struct usb_interface_descriptor uvc_streaming_intf_alt0 = {
 	.iInterface		= 0,
 };
 
+static struct usb_interface_descriptor uvc_bulk_streaming_intf_alt0 = {
+	.bLength		= USB_DT_INTERFACE_SIZE,
+	.bDescriptorType	= USB_DT_INTERFACE,
+	.bInterfaceNumber	= UVC_INTF_VIDEO_STREAMING,
+	.bAlternateSetting	= 0,
+	.bNumEndpoints		= 1,
+	.bInterfaceClass	= USB_CLASS_VIDEO,
+	.bInterfaceSubClass	= UVC_SC_VIDEOSTREAMING,
+	.bInterfaceProtocol	= 0x00,
+	.iInterface		= 0,
+};
+
 static struct usb_interface_descriptor uvc_streaming_intf_alt1 = {
 	.bLength		= USB_DT_INTERFACE_SIZE,
 	.bDescriptorType	= USB_DT_INTERFACE,
@@ -148,6 +160,16 @@ static struct usb_endpoint_descriptor uvc_fs_streaming_ep = {
 	 */
 };
 
+static struct usb_endpoint_descriptor uvc_fs_bulk_streaming_ep = {
+	.bLength		= USB_DT_ENDPOINT_SIZE,
+	.bDescriptorType	= USB_DT_ENDPOINT,
+	.bEndpointAddress	= USB_DIR_IN,
+	.bmAttributes		= USB_ENDPOINT_XFER_BULK,
+	/* The wMaxPacketSize and bInterval values will be initialized from
+	 * module parameters.
+	 */
+};
+
 static struct usb_endpoint_descriptor uvc_hs_streaming_ep = {
 	.bLength		= USB_DT_ENDPOINT_SIZE,
 	.bDescriptorType	= USB_DT_ENDPOINT,
@@ -159,6 +181,16 @@ static struct usb_endpoint_descriptor uvc_hs_streaming_ep = {
 	 */
 };
 
+static struct usb_endpoint_descriptor uvc_hs_bulk_streaming_ep = {
+	.bLength		= USB_DT_ENDPOINT_SIZE,
+	.bDescriptorType	= USB_DT_ENDPOINT,
+	.bEndpointAddress	= USB_DIR_IN,
+	.bmAttributes		= USB_ENDPOINT_XFER_BULK,
+	/* The wMaxPacketSize and bInterval values will be initialized from
+	 * module parameters.
+	 */
+};
+
 static struct usb_endpoint_descriptor uvc_ss_streaming_ep = {
 	.bLength		= USB_DT_ENDPOINT_SIZE,
 	.bDescriptorType	= USB_DT_ENDPOINT,
@@ -171,6 +203,17 @@ static struct usb_endpoint_descriptor uvc_ss_streaming_ep = {
 	 */
 };
 
+static struct usb_endpoint_descriptor uvc_ss_bulk_streaming_ep = {
+	.bLength		= USB_DT_ENDPOINT_SIZE,
+	.bDescriptorType	= USB_DT_ENDPOINT,
+
+	.bEndpointAddress	= USB_DIR_IN,
+	.bmAttributes		= USB_ENDPOINT_XFER_BULK,
+	/* The wMaxPacketSize and bInterval values will be initialized from
+	 * module parameters.
+	 */
+};
+
 static struct usb_ss_ep_comp_descriptor uvc_ss_streaming_comp = {
 	.bLength		= sizeof(uvc_ss_streaming_comp),
 	.bDescriptorType	= USB_DT_SS_ENDPOINT_COMP,
@@ -179,18 +222,36 @@ static struct usb_ss_ep_comp_descriptor uvc_ss_streaming_comp = {
 	 */
 };
 
+static struct usb_ss_ep_comp_descriptor uvc_ss_bulk_streaming_comp = {
+	.bLength		= sizeof(uvc_ss_bulk_streaming_comp),
+	.bDescriptorType	= USB_DT_SS_ENDPOINT_COMP,
+	/* The bMaxBurst, bmAttributes and wBytesPerInterval values will be
+	 * initialized from module parameters.
+	 */
+};
+
 static const struct usb_descriptor_header * const uvc_fs_streaming[] = {
 	(struct usb_descriptor_header *) &uvc_streaming_intf_alt1,
 	(struct usb_descriptor_header *) &uvc_fs_streaming_ep,
 	NULL,
 };
 
+static const struct usb_descriptor_header * const uvc_fs_bulk_streaming[] = {
+	(struct usb_descriptor_header *)&uvc_fs_bulk_streaming_ep,
+	NULL,
+};
+
 static const struct usb_descriptor_header * const uvc_hs_streaming[] = {
 	(struct usb_descriptor_header *) &uvc_streaming_intf_alt1,
 	(struct usb_descriptor_header *) &uvc_hs_streaming_ep,
 	NULL,
 };
 
+static const struct usb_descriptor_header * const uvc_hs_bulk_streaming[] = {
+	(struct usb_descriptor_header *)&uvc_hs_bulk_streaming_ep,
+	NULL,
+};
+
 static const struct usb_descriptor_header * const uvc_ss_streaming[] = {
 	(struct usb_descriptor_header *) &uvc_streaming_intf_alt1,
 	(struct usb_descriptor_header *) &uvc_ss_streaming_ep,
@@ -198,6 +259,11 @@ static const struct usb_descriptor_header * const uvc_ss_streaming[] = {
 	NULL,
 };
 
+static const struct usb_descriptor_header * const uvc_ss_bulk_streaming[] = {
+	(struct usb_descriptor_header *)&uvc_ss_bulk_streaming_ep,
+	(struct usb_descriptor_header *)&uvc_ss_bulk_streaming_comp,
+	NULL,
+};
 void uvc_set_trace_param(unsigned int trace)
 {
 	uvc_gadget_trace_param = trace;
@@ -272,15 +338,27 @@ static int
 uvc_function_get_alt(struct usb_function *f, unsigned interface)
 {
 	struct uvc_device *uvc = to_uvc(f);
+	struct f_uvc_opts *opts;
 
 	INFO(f->config->cdev, "uvc_function_get_alt(%u)\n", interface);
 
+	opts = fi_to_f_uvc_opts(f->fi);
+
 	if (interface == uvc->control_intf)
 		return 0;
 	else if (interface != uvc->streaming_intf)
 		return -EINVAL;
-	else
+	else if (!opts->streaming_bulk)
 		return uvc->video.ep->enabled ? 1 : 0;
+	else
+		/*
+		 * Alt settings in an interface are supported only for
+		 * ISOC endpoints as there are different alt-settings for
+		 * zero-bandwidth and full-bandwidth cases, but the same
+		 * is not true for BULK endpoints, as they have a single
+		 * alt-setting.
+		 */
+		return 0;
 }
 
 static int
@@ -290,10 +368,13 @@ uvc_function_set_alt(struct usb_function *f, unsigned interface, unsigned alt)
 	struct usb_composite_dev *cdev = f->config->cdev;
 	struct v4l2_event v4l2_event;
 	struct uvc_event *uvc_event = (void *)&v4l2_event.u.data;
+	struct f_uvc_opts *opts;
 	int ret;
 
 	INFO(cdev, "uvc_function_set_alt(%u, %u)\n", interface, alt);
 
+	opts = fi_to_f_uvc_opts(f->fi);
+
 	if (interface == uvc->control_intf) {
 		if (alt)
 			return -EINVAL;
@@ -322,49 +403,89 @@ uvc_function_set_alt(struct usb_function *f, unsigned interface, unsigned alt)
 	if (interface != uvc->streaming_intf)
 		return -EINVAL;
 
-	/* TODO
-	if (usb_endpoint_xfer_bulk(&uvc->desc.vs_ep))
-		return alt ? -EINVAL : 0;
-	*/
+	if (!opts->streaming_bulk) {
+		switch (alt) {
+		case 0:
+			if (uvc->state != UVC_STATE_STREAMING)
+				return 0;
+
+			if (uvc->video.ep)
+				usb_ep_disable(uvc->video.ep);
+
+			memset(&v4l2_event, 0, sizeof(v4l2_event));
+			v4l2_event.type = UVC_EVENT_STREAMOFF;
+			v4l2_event_queue(&uvc->vdev, &v4l2_event);
 
-	switch (alt) {
-	case 0:
-		if (uvc->state != UVC_STATE_STREAMING)
+			uvc->state = UVC_STATE_CONNECTED;
 			return 0;
 
-		if (uvc->video.ep)
-			usb_ep_disable(uvc->video.ep);
+		case 1:
+			if (uvc->state != UVC_STATE_CONNECTED)
+				return 0;
 
-		memset(&v4l2_event, 0, sizeof(v4l2_event));
-		v4l2_event.type = UVC_EVENT_STREAMOFF;
-		v4l2_event_queue(&uvc->vdev, &v4l2_event);
+			if (!uvc->video.ep)
+				return -EINVAL;
 
-		uvc->state = UVC_STATE_CONNECTED;
-		return 0;
+			INFO(cdev, "reset UVC\n");
+			usb_ep_disable(uvc->video.ep);
 
-	case 1:
-		if (uvc->state != UVC_STATE_CONNECTED)
-			return 0;
+			ret = config_ep_by_speed(f->config->cdev->gadget,
+						 &uvc->func, uvc->video.ep);
+			if (ret)
+				return ret;
+			usb_ep_enable(uvc->video.ep);
 
-		if (!uvc->video.ep)
-			return -EINVAL;
+			memset(&v4l2_event, 0, sizeof(v4l2_event));
+			v4l2_event.type = UVC_EVENT_STREAMON;
+			v4l2_event_queue(&uvc->vdev, &v4l2_event);
+			return USB_GADGET_DELAYED_STATUS;
 
-		INFO(cdev, "reset UVC\n");
-		usb_ep_disable(uvc->video.ep);
+		default:
+			return -EINVAL;
+		}
+	} else {
+		switch (uvc->state) {
+		case UVC_STATE_CONNECTED:
+			if (uvc->video.ep &&
+			    !uvc->video.ep->enabled) {
+				/*
+				 * Enable the video streaming endpoint,
+				 * but don't change the 'uvc->state'.
+				 */
+				ret = config_ep_by_speed(cdev->gadget,
+							 &uvc->func,
+							 uvc->video.ep);
+				if (ret)
+					return ret;
+				ret = usb_ep_enable(uvc->video.ep);
+				if (ret)
+					return ret;
+			} else {
+				memset(&v4l2_event, 0, sizeof(v4l2_event));
+				v4l2_event.type = UVC_EVENT_STREAMON;
+				v4l2_event_queue(&uvc->vdev, &v4l2_event);
+
+				uvc->state = UVC_STATE_STREAMING;
+			}
+			return 0;
 
-		ret = config_ep_by_speed(f->config->cdev->gadget,
-				&(uvc->func), uvc->video.ep);
-		if (ret)
-			return ret;
-		usb_ep_enable(uvc->video.ep);
+		case UVC_STATE_STREAMING:
+			if (uvc->video.ep &&
+			    uvc->video.ep->enabled) {
+				ret = usb_ep_disable(uvc->video.ep);
+				if (ret)
+					return ret;
+			}
 
-		memset(&v4l2_event, 0, sizeof(v4l2_event));
-		v4l2_event.type = UVC_EVENT_STREAMON;
-		v4l2_event_queue(&uvc->vdev, &v4l2_event);
-		return USB_GADGET_DELAYED_STATUS;
+			memset(&v4l2_event, 0, sizeof(v4l2_event));
+			v4l2_event.type = UVC_EVENT_STREAMOFF;
+			v4l2_event_queue(&uvc->vdev, &v4l2_event);
+			uvc->state = UVC_STATE_CONNECTED;
+			return 0;
 
-	default:
-		return -EINVAL;
+		default:
+			return -EINVAL;
+		}
 	}
 }
 
@@ -462,32 +583,45 @@ uvc_copy_descriptors(struct uvc_device *uvc, enum usb_device_speed speed)
 	const struct uvc_descriptor_header * const *uvc_streaming_cls;
 	const struct usb_descriptor_header * const *uvc_streaming_std;
 	const struct usb_descriptor_header * const *src;
+	struct usb_interface_descriptor *streaming_intf_alt0;
 	struct usb_descriptor_header **dst;
 	struct usb_descriptor_header **hdr;
+	struct f_uvc_opts *opts;
 	unsigned int control_size;
 	unsigned int streaming_size;
 	unsigned int n_desc;
 	unsigned int bytes;
 	void *mem;
 
+	opts = fi_to_f_uvc_opts(uvc->func.fi);
+
 	switch (speed) {
 	case USB_SPEED_SUPER:
 		uvc_control_desc = uvc->desc.ss_control;
 		uvc_streaming_cls = uvc->desc.ss_streaming;
-		uvc_streaming_std = uvc_ss_streaming;
+		if (!opts->streaming_bulk)
+			uvc_streaming_std = uvc_ss_streaming;
+		else
+			uvc_streaming_std = uvc_ss_bulk_streaming;
 		break;
 
 	case USB_SPEED_HIGH:
 		uvc_control_desc = uvc->desc.fs_control;
 		uvc_streaming_cls = uvc->desc.hs_streaming;
-		uvc_streaming_std = uvc_hs_streaming;
+		if (!opts->streaming_bulk)
+			uvc_streaming_std = uvc_hs_streaming;
+		else
+			uvc_streaming_std = uvc_hs_bulk_streaming;
 		break;
 
 	case USB_SPEED_FULL:
 	default:
 		uvc_control_desc = uvc->desc.fs_control;
 		uvc_streaming_cls = uvc->desc.fs_streaming;
-		uvc_streaming_std = uvc_fs_streaming;
+		if (!opts->streaming_bulk)
+			uvc_streaming_std = uvc_fs_streaming;
+		else
+			uvc_streaming_std = uvc_fs_bulk_streaming;
 		break;
 	}
 
@@ -507,12 +641,17 @@ uvc_copy_descriptors(struct uvc_device *uvc, enum usb_device_speed speed)
 	 * uvc_{fs|hs}_streaming
 	 */
 
+	if (!opts->streaming_bulk)
+		streaming_intf_alt0 = &uvc_streaming_intf_alt0;
+	else
+		streaming_intf_alt0 = &uvc_bulk_streaming_intf_alt0;
+
 	/* Count descriptors and compute their size. */
 	control_size = 0;
 	streaming_size = 0;
 	bytes = uvc_iad.bLength + uvc_control_intf.bLength
 	      + uvc_control_ep.bLength + uvc_control_cs_ep.bLength
-	      + uvc_streaming_intf_alt0.bLength;
+	      + streaming_intf_alt0->bLength;
 
 	if (speed == USB_SPEED_SUPER) {
 		bytes += uvc_ss_control_comp.bLength;
@@ -562,7 +701,7 @@ uvc_copy_descriptors(struct uvc_device *uvc, enum usb_device_speed speed)
 		UVC_COPY_DESCRIPTOR(mem, dst, &uvc_ss_control_comp);
 
 	UVC_COPY_DESCRIPTOR(mem, dst, &uvc_control_cs_ep);
-	UVC_COPY_DESCRIPTOR(mem, dst, &uvc_streaming_intf_alt0);
+	UVC_COPY_DESCRIPTOR(mem, dst, streaming_intf_alt0);
 
 	uvc_streaming_header = mem;
 	UVC_COPY_DESCRIPTORS(mem, dst,
@@ -587,15 +726,24 @@ uvc_function_bind(struct usb_configuration *c, struct usb_function *f)
 	struct usb_ep *ep;
 	struct f_uvc_opts *opts;
 	int ret = -EINVAL;
+	u8 address;
 
 	INFO(cdev, "uvc_function_bind\n");
 
 	opts = fi_to_f_uvc_opts(f->fi);
 	/* Sanity check the streaming endpoint module parameters.
 	 */
-	opts->streaming_interval = clamp(opts->streaming_interval, 1U, 16U);
-	opts->streaming_maxpacket = clamp(opts->streaming_maxpacket, 1U, 3072U);
-	opts->streaming_maxburst = min(opts->streaming_maxburst, 15U);
+	if (!opts->streaming_bulk) {
+		opts->streaming_interval = clamp(opts->streaming_interval,
+						 1U, 16U);
+		opts->streaming_maxpacket = clamp(opts->streaming_maxpacket,
+						  1U, 3072U);
+		opts->streaming_maxburst = min(opts->streaming_maxburst, 15U);
+	} else {
+		opts->streaming_maxpacket = clamp(opts->streaming_maxpacket,
+						  1U, 1024U);
+		opts->streaming_maxburst = min(opts->streaming_maxburst, 15U);
+	}
 
 	/* For SS, wMaxPacketSize has to be 1024 if bMaxBurst is not 0 */
 	if (opts->streaming_maxburst &&
@@ -622,21 +770,37 @@ uvc_function_bind(struct usb_configuration *c, struct usb_function *f)
 		max_packet_size = opts->streaming_maxpacket / 3;
 	}
 
-	uvc_fs_streaming_ep.wMaxPacketSize =
-		cpu_to_le16(min(opts->streaming_maxpacket, 1023U));
-	uvc_fs_streaming_ep.bInterval = opts->streaming_interval;
+	if (!opts->streaming_bulk) {
+		uvc_fs_streaming_ep.wMaxPacketSize =
+			cpu_to_le16(min(opts->streaming_maxpacket, 1023U));
+		uvc_fs_streaming_ep.bInterval = opts->streaming_interval;
+
+		uvc_hs_streaming_ep.wMaxPacketSize =
+			cpu_to_le16(max_packet_size |
+				    ((max_packet_mult - 1) << 11));
+		uvc_hs_streaming_ep.bInterval = opts->streaming_interval;
+
+		uvc_ss_streaming_ep.wMaxPacketSize =
+			cpu_to_le16(max_packet_size);
+		uvc_ss_streaming_ep.bInterval = opts->streaming_interval;
+		uvc_ss_streaming_comp.bmAttributes = max_packet_mult - 1;
+		uvc_ss_streaming_comp.bMaxBurst = opts->streaming_maxburst;
+		uvc_ss_streaming_comp.wBytesPerInterval =
+			cpu_to_le16(max_packet_size * max_packet_mult *
+				    (opts->streaming_maxburst + 1));
+	} else {
+		uvc_fs_bulk_streaming_ep.wMaxPacketSize =
+			cpu_to_le16(min(opts->streaming_maxpacket, 64U));
 
-	uvc_hs_streaming_ep.wMaxPacketSize =
-		cpu_to_le16(max_packet_size | ((max_packet_mult - 1) << 11));
-	uvc_hs_streaming_ep.bInterval = opts->streaming_interval;
+		uvc_hs_bulk_streaming_ep.wMaxPacketSize =
+			cpu_to_le16(min(opts->streaming_maxpacket, 512U));
 
-	uvc_ss_streaming_ep.wMaxPacketSize = cpu_to_le16(max_packet_size);
-	uvc_ss_streaming_ep.bInterval = opts->streaming_interval;
-	uvc_ss_streaming_comp.bmAttributes = max_packet_mult - 1;
-	uvc_ss_streaming_comp.bMaxBurst = opts->streaming_maxburst;
-	uvc_ss_streaming_comp.wBytesPerInterval =
-		cpu_to_le16(max_packet_size * max_packet_mult *
-			    (opts->streaming_maxburst + 1));
+		uvc_ss_bulk_streaming_ep.wMaxPacketSize =
+			cpu_to_le16(max_packet_size);
+		uvc_ss_streaming_comp.bMaxBurst = opts->streaming_maxburst;
+		uvc_ss_streaming_comp.wBytesPerInterval =
+			cpu_to_le16(max_packet_size * opts->streaming_maxburst);
+	}
 
 	/* Allocate endpoints. */
 	ep = usb_ep_autoconfig(cdev->gadget, &uvc_control_ep);
@@ -646,23 +810,57 @@ uvc_function_bind(struct usb_configuration *c, struct usb_function *f)
 	}
 	uvc->control_ep = ep;
 
-	if (gadget_is_superspeed(c->cdev->gadget))
-		ep = usb_ep_autoconfig_ss(cdev->gadget, &uvc_ss_streaming_ep,
-					  &uvc_ss_streaming_comp);
-	else if (gadget_is_dualspeed(cdev->gadget))
-		ep = usb_ep_autoconfig(cdev->gadget, &uvc_hs_streaming_ep);
-	else
-		ep = usb_ep_autoconfig(cdev->gadget, &uvc_fs_streaming_ep);
+	if (gadget_is_superspeed(c->cdev->gadget)) {
+		if (!opts->streaming_bulk)
+			ep = usb_ep_autoconfig_ss(cdev->gadget,
+						  &uvc_ss_streaming_ep,
+						  &uvc_ss_streaming_comp);
+		else
+			ep = usb_ep_autoconfig_ss(cdev->gadget,
+						  &uvc_ss_bulk_streaming_ep,
+						  &uvc_ss_bulk_streaming_comp);
+	} else if (gadget_is_dualspeed(cdev->gadget)) {
+		if (!opts->streaming_bulk) {
+			ep = usb_ep_autoconfig(cdev->gadget,
+					       &uvc_hs_streaming_ep);
+		} else {
+			ep = usb_ep_autoconfig(cdev->gadget,
+					       &uvc_hs_bulk_streaming_ep);
+			/*
+			 * In ep_matches(), it will set wMaxPacketSize to 64
+			 * bytes if ep is Bulk and ep_comp is NULL for hs/fs
+			 * bulk maxpacket. So we need to set hs bulk maxpacket
+			 * 512 bytes again here.
+			 */
+			uvc_hs_bulk_streaming_ep.wMaxPacketSize =
+				cpu_to_le16(min(opts->streaming_maxpacket,
+						512U));
+		}
+	} else {
+		if (!opts->streaming_bulk)
+			ep = usb_ep_autoconfig(cdev->gadget,
+					       &uvc_fs_streaming_ep);
+		else
+			ep = usb_ep_autoconfig(cdev->gadget,
+					       &uvc_fs_bulk_streaming_ep);
+	}
 
 	if (!ep) {
 		INFO(cdev, "Unable to allocate streaming EP\n");
 		goto error;
 	}
 	uvc->video.ep = ep;
+	address = uvc->video.ep->address;
 
-	uvc_fs_streaming_ep.bEndpointAddress = uvc->video.ep->address;
-	uvc_hs_streaming_ep.bEndpointAddress = uvc->video.ep->address;
-	uvc_ss_streaming_ep.bEndpointAddress = uvc->video.ep->address;
+	if (!opts->streaming_bulk) {
+		uvc_fs_streaming_ep.bEndpointAddress = address;
+		uvc_hs_streaming_ep.bEndpointAddress = address;
+		uvc_ss_streaming_ep.bEndpointAddress = address;
+	} else {
+		uvc_fs_bulk_streaming_ep.bEndpointAddress = address;
+		uvc_hs_bulk_streaming_ep.bEndpointAddress = address;
+		uvc_ss_bulk_streaming_ep.bEndpointAddress = address;
+	}
 
 	us = usb_gstrings_attach(cdev, uvc_function_strings,
 				 ARRAY_SIZE(uvc_en_us_strings));
@@ -673,8 +871,12 @@ uvc_function_bind(struct usb_configuration *c, struct usb_function *f)
 	uvc_iad.iFunction = us[UVC_STRING_CONTROL_IDX].id;
 	uvc_control_intf.iInterface = us[UVC_STRING_CONTROL_IDX].id;
 	ret = us[UVC_STRING_STREAMING_IDX].id;
-	uvc_streaming_intf_alt0.iInterface = ret;
-	uvc_streaming_intf_alt1.iInterface = ret;
+	if (!opts->streaming_bulk) {
+		uvc_streaming_intf_alt0.iInterface = ret;
+		uvc_streaming_intf_alt1.iInterface = ret;
+	} else {
+		uvc_bulk_streaming_intf_alt0.iInterface = ret;
+	}
 
 	/* Allocate interface IDs. */
 	if ((ret = usb_interface_id(c, f)) < 0)
@@ -685,8 +887,14 @@ uvc_function_bind(struct usb_configuration *c, struct usb_function *f)
 
 	if ((ret = usb_interface_id(c, f)) < 0)
 		goto error;
-	uvc_streaming_intf_alt0.bInterfaceNumber = ret;
-	uvc_streaming_intf_alt1.bInterfaceNumber = ret;
+
+	if (!opts->streaming_bulk) {
+		uvc_streaming_intf_alt0.bInterfaceNumber = ret;
+		uvc_streaming_intf_alt1.bInterfaceNumber = ret;
+	} else {
+		uvc_bulk_streaming_intf_alt0.bInterfaceNumber = ret;
+	}
+
 	uvc->streaming_intf = ret;
 
 	/* Copy descriptors */
@@ -735,6 +943,8 @@ uvc_function_bind(struct usb_configuration *c, struct usb_function *f)
 	if (ret < 0)
 		goto error;
 
+	if (opts->streaming_bulk)
+		uvc->video.max_payload_size = uvc->video.imagesize;
 	/* Register a V4L2 device. */
 	ret = uvc_register_video(uvc);
 	if (ret < 0) {
diff --git a/drivers/usb/gadget/function/u_uvc.h b/drivers/usb/gadget/function/u_uvc.h
index 025c2ae4e177..35e03eb75abd 100644
--- a/drivers/usb/gadget/function/u_uvc.h
+++ b/drivers/usb/gadget/function/u_uvc.h
@@ -24,6 +24,7 @@ DECLARE_UVC_EXTENSION_UNIT_DESCRIPTOR(1, 1);
 
 struct f_uvc_opts {
 	struct usb_function_instance			func_inst;
+	bool						streaming_bulk;
 	unsigned int					uvc_gadget_trace_param;
 	unsigned int					streaming_interval;
 	unsigned int					streaming_maxpacket;
diff --git a/drivers/usb/gadget/function/uvc_configfs.c b/drivers/usb/gadget/function/uvc_configfs.c
index 26c6ba150193..997650739655 100644
--- a/drivers/usb/gadget/function/uvc_configfs.c
+++ b/drivers/usb/gadget/function/uvc_configfs.c
@@ -2253,6 +2253,8 @@ UVC_ATTR(f_uvc_opts_, cname, cname)
 
 #define identity_conv(x) (x)
 
+UVCG_OPTS_ATTR(streaming_bulk, streaming_bulk, identity_conv,
+	       kstrtou8, u8, identity_conv, 1);
 UVCG_OPTS_ATTR(streaming_interval, streaming_interval, identity_conv,
 	       kstrtou8, u8, identity_conv, 16);
 UVCG_OPTS_ATTR(streaming_maxpacket, streaming_maxpacket, le16_to_cpu,
@@ -2265,6 +2267,7 @@ UVCG_OPTS_ATTR(streaming_maxburst, streaming_maxburst, identity_conv,
 #undef UVCG_OPTS_ATTR
 
 static struct configfs_attribute *uvc_attrs[] = {
+	&f_uvc_opts_attr_streaming_bulk,
 	&f_uvc_opts_attr_streaming_interval,
 	&f_uvc_opts_attr_streaming_maxpacket,
 	&f_uvc_opts_attr_streaming_maxburst,
diff --git a/drivers/usb/gadget/function/uvc_v4l2.c b/drivers/usb/gadget/function/uvc_v4l2.c
index 81f1d614fbe6..8bc9b506898e 100644
--- a/drivers/usb/gadget/function/uvc_v4l2.c
+++ b/drivers/usb/gadget/function/uvc_v4l2.c
@@ -207,11 +207,21 @@ uvc_v4l2_streamon(struct file *file, void *fh, enum v4l2_buf_type type)
 		return ret;
 
 	/*
-	 * Complete the alternate setting selection setup phase now that
-	 * userspace is ready to provide video frames.
+	 * Alt settings in an interface are supported only
+	 * for ISOC endpoints as there are different alt-
+	 * settings for zero-bandwidth and full-bandwidth
+	 * cases, but the same is not true for BULK endpoints,
+	 * as they have a single alt-setting.
 	 */
-	uvc_function_setup_continue(uvc);
-	uvc->state = UVC_STATE_STREAMING;
+	if (!usb_endpoint_xfer_bulk(video->ep->desc)) {
+		/*
+		 * Complete the alternate setting selection
+		 * setup phase now that userspace is ready
+		 * to provide video frames.
+		 */
+		uvc_function_setup_continue(uvc);
+		uvc->state = UVC_STATE_STREAMING;
+	}
 
 	return 0;
 }
diff --git a/drivers/usb/gadget/function/uvc_video.c b/drivers/usb/gadget/function/uvc_video.c
index 0f01c04d7cbd..f1acfcaaa92e 100644
--- a/drivers/usb/gadget/function/uvc_video.c
+++ b/drivers/usb/gadget/function/uvc_video.c
@@ -241,9 +241,14 @@ uvc_video_alloc_requests(struct uvc_video *video)
 
 	BUG_ON(video->req_size);
 
-	req_size = video->ep->maxpacket
-		 * max_t(unsigned int, video->ep->maxburst, 1)
-		 * (video->ep->mult);
+	if (!usb_endpoint_xfer_bulk(video->ep->desc)) {
+		req_size = video->ep->maxpacket
+			 * max_t(unsigned int, video->ep->maxburst, 1)
+			 * (video->ep->mult);
+	} else {
+		req_size = video->ep->maxpacket
+			 * max_t(unsigned int, video->ep->maxburst, 1);
+	}
 
 	for (i = 0; i < UVC_NUM_REQUESTS; ++i) {
 		video->req_buffer[i] = kmalloc(req_size, GFP_KERNEL);

commit cf92d82ac54a07553928d4648c7547a75a58cfdd
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Tue Jun 11 21:42:40 2019 +0800

    rk: ARM: support build [z]boot.img from existing boot.img
    
    The existing boot.img from $(BOOT_IMG).
    
    Change-Id: I3751e56ee88b3ece03999dc68c7c2595807bcbf7
    Signed-off-by: Tao Huang <huangtao@rock-chips.com>

diff --git a/arch/arm/Makefile b/arch/arm/Makefile
index be86c70b8dfe..aa3dc2a11747 100644
--- a/arch/arm/Makefile
+++ b/arch/arm/Makefile
@@ -393,6 +393,33 @@ ifdef CONFIG_DRM
 LOGO := $(notdir $(wildcard $(srctree)/logo.bmp))
 LOGO_KERNEL := $(notdir $(wildcard $(srctree)/logo_kernel.bmp))
 endif
+
+make_boot_img := \
+	$(srctree)/scripts/mkbootimg \
+		--kernel $(objtree)/arch/arm/boot/Image \
+		--second resource.img \
+		-o boot.img && \
+	echo '  Image:  boot.img (with Image resource.img) is ready'; \
+	$(srctree)/scripts/mkbootimg \
+		--kernel $(objtree)/arch/arm/boot/zImage \
+		--second resource.img \
+		-o zboot.img && \
+	echo '  Image:  zboot.img (with zImage resource.img) is ready'
+
+repack_boot_img := \
+	$(srctree)/scripts/repack-bootimg \
+		--boot_img $(BOOT_IMG) --out out \
+		--kernel $(objtree)/arch/arm/boot/Image \
+		--second resource.img \
+		-o boot.img && \
+	echo '  Image:  boot.img ($(BOOT_IMG) + Image + resource.img) is ready'; \
+	$(srctree)/scripts/repack-bootimg \
+		--boot_img $(BOOT_IMG) --out out \
+		--kernel $(objtree)/arch/arm/boot/zImage \
+		--second resource.img \
+		-o zboot.img && \
+	echo '  Image:  zboot.img ($(BOOT_IMG) + zImage + resource.img) is ready'
+
 %.img: %.dtb kernel.img $(LOGO) $(LOGO_KERNEL)
 	$(Q) if [ -f $(srctree)/$(LOGO) -a -e $(srctree)/scripts/bmpconvert ]; then $(srctree)/scripts/bmpconvert $(srctree)/$(LOGO); fi
 	$(Q) if [ -f $(srctree)/$(LOGO_KERNEL) -a -e $(srctree)/scripts/bmpconvert ]; then $(srctree)/scripts/bmpconvert $(srctree)/$(LOGO_KERNEL); fi
@@ -400,17 +427,7 @@ endif
 	$(Q) if [ -f $(srctree)/$(LOGO_KERNEL) -a "$(srctree)" != "$(objtree)" ]; then cp -a $(srctree)/$(LOGO_KERNEL) $(objtree)/; fi
 	$(Q)scripts/resource_tool $(objtree)/arch/arm/boot/dts/$*.dtb $(LOGO) $(LOGO_KERNEL)
 	@echo '  Image:  resource.img (with $*.dtb $(LOGO) $(LOGO_KERNEL)) is ready'
-	$(Q) if [ -x $(srctree)/scripts/mkbootimg ]; then \
-		$(srctree)/scripts/mkbootimg \
-			--kernel $(objtree)/arch/arm/boot/Image \
-			--second resource.img \
-			-o boot.img && \
-		echo '  Image:  boot.img (with Image resource.img) is ready'; \
-		$(srctree)/scripts/mkbootimg \
-			--kernel $(objtree)/arch/arm/boot/zImage \
-			--second resource.img \
-			-o zboot.img && \
-		echo '  Image:  zboot.img (with zImage resource.img) is ready'; \
-	fi
+	$(Q) if [ -f "$(BOOT_IMG)" -a -x $(srctree)/scripts/repack-bootimg ]; then $(repack_boot_img); elif [ -x $(srctree)/scripts/mkbootimg ]; then $(make_boot_img); fi
 
+CLEAN_DIRS += out
 CLEAN_FILES += boot.img kernel.img resource.img zboot.img

commit 234ac80951dbcf5056b16fcd85ef3d07616826aa
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Tue Jun 11 17:40:43 2019 +0800

    rk: arm64: support build [z]boot.img from existing boot.img
    
    The existing boot.img from $(BOOT_IMG).
    
    Change-Id: Iaf78185546200acb10ae13f541197722149624e1
    Signed-off-by: Tao Huang <huangtao@rock-chips.com>

diff --git a/arch/arm64/Makefile b/arch/arm64/Makefile
index 47b84864220c..4cdadc24d1af 100644
--- a/arch/arm64/Makefile
+++ b/arch/arm64/Makefile
@@ -187,6 +187,20 @@ make_boot_img := \
 		-o zboot.img && \
 	echo '  Image:  zboot.img (with Image.lz4 $(if $(RAMDISK_IMG),'ramdisk.img ')resource.img) is ready'
 
+repack_boot_img := \
+	$(srctree)/scripts/repack-bootimg \
+		--boot_img $(BOOT_IMG) --out out \
+		--kernel $(objtree)/arch/arm64/boot/Image \
+		--second resource.img \
+		-o boot.img && \
+	echo '  Image:  boot.img ($(BOOT_IMG) + Image + resource.img) is ready'; \
+	$(srctree)/scripts/repack-bootimg \
+		--boot_img $(BOOT_IMG) --out out \
+		--kernel $(objtree)/arch/arm64/boot/Image.lz4 \
+		--second resource.img \
+		-o zboot.img && \
+	echo '  Image:  zboot.img ($(BOOT_IMG) + Image.lz4 + resource.img) is ready'
+
 %.img: rockchip/%.dtb kernel.img $(LOGO) $(LOGO_KERNEL)
 	$(Q) if [ -f $(srctree)/$(LOGO) -a -e $(srctree)/scripts/bmpconvert ]; then $(srctree)/scripts/bmpconvert $(srctree)/$(LOGO); fi
 	$(Q) if [ -f $(srctree)/$(LOGO_KERNEL) -a -e $(srctree)/scripts/bmpconvert ]; then $(srctree)/scripts/bmpconvert $(srctree)/$(LOGO_KERNEL); fi
@@ -194,6 +208,7 @@ make_boot_img := \
 	$(Q) if [ -f $(srctree)/$(LOGO_KERNEL) -a "$(srctree)" != "$(objtree)" ]; then cp -a $(srctree)/$(LOGO_KERNEL) $(objtree)/; fi
 	$(Q)scripts/resource_tool $(objtree)/arch/arm64/boot/dts/rockchip/$*.dtb $(LOGO) $(LOGO_KERNEL)
 	@echo '  Image:  resource.img (with $*.dtb $(LOGO) $(LOGO_KERNEL)) is ready'
-	$(Q) if [ -x $(srctree)/scripts/mkbootimg ]; then $(make_boot_img); fi
+	$(Q) if [ -f "$(BOOT_IMG)" -a -x $(srctree)/scripts/repack-bootimg ]; then $(repack_boot_img); elif [ -x $(srctree)/scripts/mkbootimg ]; then $(make_boot_img); fi
 
+CLEAN_DIRS += out
 CLEAN_FILES += boot.img kernel.img resource.img zboot.img

commit 28aa47d2693790fe1cdcad37002d08280746e093
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Tue Jun 11 17:30:56 2019 +0800

    rk: scripts: add repack-bootimg
    
    Also add unpack_bootimg and update mkbootimg
    
    AOSP 96fd8874ef8e ("Check DTB image size for boot image header version 2 and above")
    
    Change-Id: I4582913b21f711c84d62bed0ffd024b583a094f7
    Signed-off-by: Tao Huang <huangtao@rock-chips.com>

diff --git a/scripts/mkbootimg b/scripts/mkbootimg
index fda9af0d28fb..934f28e43029 100755
--- a/scripts/mkbootimg
+++ b/scripts/mkbootimg
@@ -62,7 +62,13 @@ def get_recovery_dtbo_offset(args):
 
 
 def write_header(args):
+    BOOT_IMAGE_HEADER_V1_SIZE = 1648
+    BOOT_IMAGE_HEADER_V2_SIZE = 1660
     BOOT_MAGIC = 'ANDROID!'.encode()
+
+    if (args.header_version > 2):
+        raise ValueError('Boot header version %d not supported' % args.header_version)
+
     args.output.write(pack('8s', BOOT_MAGIC))
     args.output.write(pack('10I',
         filesize(args.kernel),                          # size in bytes
@@ -85,6 +91,8 @@ def write_header(args):
 
     if args.header_version > 0:
         update_sha(sha, args.recovery_dtbo)
+    if args.header_version > 1:
+        update_sha(sha, args.dtb)
 
     img_id = pack('32s', sha.digest())
 
@@ -97,8 +105,20 @@ def write_header(args):
             args.output.write(pack('Q', get_recovery_dtbo_offset(args))) # recovery dtbo offset
         else:
             args.output.write(pack('Q', 0)) # Will be set to 0 for devices without a recovery dtbo
-        args.output.write(pack('I', args.output.tell() + 4))         # size of boot header
 
+    # Populate boot image header size for header versions 1 and 2.
+    if args.header_version == 1:
+        args.output.write(pack('I', BOOT_IMAGE_HEADER_V1_SIZE))
+    elif args.header_version == 2:
+        args.output.write(pack('I', BOOT_IMAGE_HEADER_V2_SIZE))
+
+    if args.header_version > 1:
+
+        if filesize(args.dtb) == 0:
+            raise ValueError("DTB image must not be empty.")
+
+        args.output.write(pack('I', filesize(args.dtb)))   # size in bytes
+        args.output.write(pack('Q', args.base + args.dtb_offset)) # dtb physical load address
     pad_file(args.output, args.pagesize)
     return img_id
 
@@ -161,7 +181,11 @@ def parse_cmdline():
                         required=True)
     parser.add_argument('--ramdisk', help='path to the ramdisk', type=FileType('rb'))
     parser.add_argument('--second', help='path to the 2nd bootloader', type=FileType('rb'))
-    parser.add_argument('--recovery_dtbo', help='path to the recovery DTBO', type=FileType('rb'))
+    parser.add_argument('--dtb', help='path to dtb', type=FileType('rb'))
+    recovery_dtbo_group = parser.add_mutually_exclusive_group()
+    recovery_dtbo_group.add_argument('--recovery_dtbo', help='path to the recovery DTBO', type=FileType('rb'))
+    recovery_dtbo_group.add_argument('--recovery_acpio', help='path to the recovery ACPIO',
+                                     type=FileType('rb'), metavar='RECOVERY_ACPIO', dest='recovery_dtbo')
     parser.add_argument('--cmdline', help='extra arguments to be passed on the '
                         'kernel command line', default='', action=ValidateStrLenAction, maxlen=1536)
     parser.add_argument('--base', help='base address', type=parse_int, default=0x10000000)
@@ -169,6 +193,8 @@ def parse_cmdline():
     parser.add_argument('--ramdisk_offset', help='ramdisk offset', type=parse_int, default=0x01000000)
     parser.add_argument('--second_offset', help='2nd bootloader offset', type=parse_int,
                         default=0x00f00000)
+    parser.add_argument('--dtb_offset', help='dtb offset', type=parse_int, default=0x01f00000)
+
     parser.add_argument('--os_version', help='operating system version', type=parse_os_version,
                         default=0)
     parser.add_argument('--os_patch_level', help='operating system patch level',
@@ -193,6 +219,8 @@ def write_data(args):
 
     if args.header_version > 0:
         write_padded_file(args.output, args.recovery_dtbo, args.pagesize)
+    if args.header_version > 1:
+        write_padded_file(args.output, args.dtb, args.pagesize)
 
 def main():
     args = parse_cmdline()
diff --git a/scripts/repack-bootimg b/scripts/repack-bootimg
new file mode 100755
index 000000000000..a4f0298c449b
--- /dev/null
+++ b/scripts/repack-bootimg
@@ -0,0 +1,160 @@
+#!/bin/bash
+# SPDX-License-Identifier: GPL-2.0
+# Copyright (c) 2019 Fuzhou Rockchip Electronics Co., Ltd.
+set -e
+
+usage() {
+	cat >&2 << USAGE
+usage: $0 [-h] [-z] --boot_img BOOT_IMG [--out OUT] [--kernel KERNEL] [--ramdisk RAMDISK] [--second SECOND] [--dtb DTB ] [--recovery_dtbo RECOVERY_DTBO] -o OUTPUT
+
+optional arguments:
+  -h, --help            show this help message and exit
+  -z                    pack compressed kernel image
+  --boot_img BOOT_IMG   path to the original boot image
+  --out OUT             path to out binaries (default: out)
+  --kernel KERNEL       path to the new kernel
+  --ramdisk RAMDISK     path to the new ramdisk
+  --second SECOND       path to the new 2nd bootloader (default: resource.img)
+  --dtb DTB             path to the new dtb
+  --recovery_dtbo RECOVERY_DTBO
+                        path to the new recovery DTBO
+  -o OUTPUT, --output OUTPUT
+                        output file name
+USAGE
+}
+
+# Parse command-line arguments
+while [ $# -gt 0 ]; do
+	case $1 in
+		--boot_img)
+			boot_img=$2
+			shift 2
+			;;
+		--out)
+			out=$2
+			shift 2
+			;;
+		--kernel)
+			kernel=$2
+			shift 2
+			;;
+		--ramdisk)
+			ramdisk=$2
+			shift 2
+			;;
+		--second)
+			second=$2
+			shift 2
+			;;
+		--dtb)
+			dtb=$2
+			shift 2
+			;;
+		--recovery_dtbo)
+			recovery_dtbo=$2
+			shift 2
+			;;
+		-h)
+			usage
+			exit 0
+			;;
+		--help)
+			usage
+			exit 0
+			;;
+		-z)
+			compressed_kernel=y
+			shift
+			;;
+		-o)
+			output=$2
+			shift 2
+			;;
+		--output)
+			output=$2
+			shift 2
+			;;
+		*)
+			shift
+			;;
+        esac
+done
+
+if [ "$boot_img" == "" -o ! -e "$boot_img" ]; then
+	echo "No boot img"
+	usage
+	exit 1
+fi
+
+if [ "$output" == "" ]; then
+	echo "No output file name"
+	usage
+	exit 1
+fi
+
+srctree=${srctree-"."}
+objtree=${objtree-"."}
+out=${out-"out"}
+if [ "$($srctree/scripts/config --state CONFIG_ARM64)" == "y" ]; then
+	if [ "$compressed_kernel" == "y" ]; then
+		default_kernel=arch/arm64/boot/Image.lz4
+	else
+		default_kernel=arch/arm64/boot/Image
+	fi
+else
+	if [ "$compressed_kernel" == "y" ]; then
+		default_kernel=arch/arm/boot/zImage
+	else
+		default_kernel=arch/arm/boot/Image
+	fi
+fi
+kernel=${kernel-$objtree/$default_kernel}
+second=${second-$objtree/resource.img}
+ramdisk=${ramdisk-$out/ramdisk}
+dtb=${dtb-$out/dtb}
+recovery_dtbo=${recovery_dtbo-$out/recovery_dtbo}
+log="$out/unpack.log"
+
+mkdir -p $out
+$srctree/scripts/unpack_bootimg --boot_img $boot_img --out $out > $log
+
+cmdline=$(grep -a "^command line args: " $log | tr '\0' '\n'| sed "s/^command line args: //")
+extra_cmdline=$(grep -a "^additional command line args: " $log | tr '\0' '\n'| sed "s/^additional command line args: //")
+version=$(grep -a "^boot image header version: " $log | sed "s/^boot image header version: //")
+
+os_version_patch_level=$(grep -a "^os version and patch level: " $log | sed "s/^os version and patch level: //")
+
+v=$(($os_version_patch_level >> 11))
+a=$(($v >> 14))
+b=$((($v >> 7) & 0x7f))
+c=$(($v & 0x7f))
+os_version=$(printf '%d.%d.%d' $a $b $c)
+
+v=$(($os_version_patch_level & 0x7ff))
+y=$((($v >> 4) + 2000))
+m=$((($v & 15)))
+os_patch_level=$(printf '%d-%02d-01' $y $m)
+
+dtb_size=$(grep -a "^dtb size: " $log | sed "s/^dtb size: //")
+dtb_size=${dtb_size:-0}
+if [ $dtb_size -gt 0 -a -e "$dtb" ]; then
+	DTB="--dtb $dtb"
+fi
+
+recovery_dtbo_size=$(grep -a "^recovery dtbo size: " $log | sed "s/^recovery dtbo size: //")
+recovery_dtbo_size=${recovery_dtbo_size:-0}
+if [ $recovery_dtbo_size -gt 0 -a -e "$recovery_dtbo" ]; then
+	RECOVERY_DTBO="--recovery_dtbo $recovery_dtbo"
+fi
+
+$srctree/scripts/mkbootimg \
+--kernel $kernel \
+--second $second \
+--ramdisk $ramdisk \
+$DTB \
+$RECOVERY_DTBO \
+--cmdline "${cmdline}${extra_cmdline}" \
+--header_version $version \
+--os_version $os_version \
+--os_patch_level $os_patch_level \
+--output $output
diff --git a/scripts/unpack_bootimg b/scripts/unpack_bootimg
new file mode 100755
index 000000000000..789bf5e6d906
--- /dev/null
+++ b/scripts/unpack_bootimg
@@ -0,0 +1,152 @@
+#!/usr/bin/env python
+# Copyright 2018, The Android Open Source Project
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+#     http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+"""unpacks the bootimage.
+
+Extracts the kernel, ramdisk, second bootloader, dtb and recovery dtbo images.
+"""
+
+from __future__ import print_function
+from argparse import ArgumentParser, FileType
+from struct import unpack
+import os
+
+
+def create_out_dir(dir_path):
+    """creates a directory 'dir_path' if it does not exist"""
+    if not os.path.exists(dir_path):
+        os.makedirs(dir_path)
+
+
+def extract_image(offset, size, bootimage, extracted_image_name):
+    """extracts an image from the bootimage"""
+    bootimage.seek(offset)
+    with open(extracted_image_name, 'wb') as file_out:
+        file_out.write(bootimage.read(size))
+
+
+def get_number_of_pages(image_size, page_size):
+    """calculates the number of pages required for the image"""
+    return (image_size + page_size - 1) / page_size
+
+
+def unpack_bootimage(args):
+    """extracts kernel, ramdisk, second bootloader and recovery dtbo"""
+    boot_magic = unpack('8s', args.boot_img.read(8))
+    print('boot_magic: %s' % boot_magic)
+    kernel_ramdisk_second_info = unpack('10I', args.boot_img.read(10 * 4))
+    print('kernel_size: %s' % kernel_ramdisk_second_info[0])
+    print('kernel load address: %#x' % kernel_ramdisk_second_info[1])
+    print('ramdisk size: %s' % kernel_ramdisk_second_info[2])
+    print('ramdisk load address: %#x' % kernel_ramdisk_second_info[3])
+    print('second bootloader size: %s' % kernel_ramdisk_second_info[4])
+    print('second bootloader load address: %#x' % kernel_ramdisk_second_info[5])
+    print('kernel tags load address: %#x' % kernel_ramdisk_second_info[6])
+    print('page size: %s' % kernel_ramdisk_second_info[7])
+    print('boot image header version: %s' % kernel_ramdisk_second_info[8])
+    print('os version and patch level: %s' % kernel_ramdisk_second_info[9])
+
+    product_name = unpack('16s', args.boot_img.read(16))
+    print('product name: %s' % product_name)
+    cmdline = unpack('512s', args.boot_img.read(512))
+    print('command line args: %s' % cmdline)
+
+    args.boot_img.read(32)  # ignore SHA
+
+    extra_cmdline = unpack('1024s', args.boot_img.read(1024))
+    print('additional command line args: %s' % extra_cmdline)
+
+    kernel_size = kernel_ramdisk_second_info[0]
+    ramdisk_size = kernel_ramdisk_second_info[2]
+    second_size = kernel_ramdisk_second_info[4]
+    page_size = kernel_ramdisk_second_info[7]
+    version = kernel_ramdisk_second_info[8]
+    if version > 0:
+        recovery_dtbo_size = unpack('I', args.boot_img.read(1 * 4))[0]
+        print('recovery dtbo size: %s' % recovery_dtbo_size)
+        recovery_dtbo_offset = unpack('Q', args.boot_img.read(8))[0]
+        print('recovery dtbo offset: %#x' % recovery_dtbo_offset)
+        boot_header_size = unpack('I', args.boot_img.read(4))[0]
+        print('boot header size: %s' % boot_header_size)
+    else:
+        recovery_dtbo_size = 0
+    if version > 1:
+        dtb_size = unpack('I', args.boot_img.read(4))[0]
+        print('dtb size: %s' % dtb_size)
+        dtb_load_address = unpack('Q', args.boot_img.read(8))[0]
+        print('dtb address: %#x' % dtb_load_address)
+    else:
+        dtb_size = 0
+
+
+    # The first page contains the boot header
+    num_header_pages = 1
+
+    num_kernel_pages = get_number_of_pages(kernel_size, page_size)
+    kernel_offset = page_size * num_header_pages  # header occupies a page
+    image_info_list = [(kernel_offset, kernel_size, 'kernel')]
+
+    num_ramdisk_pages = get_number_of_pages(ramdisk_size, page_size)
+    ramdisk_offset = page_size * (num_header_pages + num_kernel_pages
+                                 ) # header + kernel
+    image_info_list.append((ramdisk_offset, ramdisk_size, 'ramdisk'))
+
+    if second_size > 0:
+        second_offset = page_size * (
+                num_header_pages + num_kernel_pages + num_ramdisk_pages
+                )  # header + kernel + ramdisk
+        image_info_list.append((second_offset, second_size, 'second'))
+
+    if recovery_dtbo_size > 0:
+        image_info_list.append((recovery_dtbo_offset, recovery_dtbo_size,
+                                'recovery_dtbo'))
+    if dtb_size > 0:
+        num_second_pages = get_number_of_pages(second_size, page_size)
+        num_recovery_dtbo_pages = get_number_of_pages(recovery_dtbo_size, page_size)
+        dtb_offset = page_size * (
+            num_header_pages + num_kernel_pages + num_ramdisk_pages + num_second_pages +
+            num_recovery_dtbo_pages
+        )
+
+        image_info_list.append((dtb_offset, dtb_size, 'dtb'))
+
+    for image_info in image_info_list:
+        extract_image(image_info[0], image_info[1], args.boot_img,
+                      os.path.join(args.out, image_info[2]))
+
+
+def parse_cmdline():
+    """parse command line arguments"""
+    parser = ArgumentParser(
+        description='Unpacks boot.img/recovery.img, extracts the kernel,'
+        'ramdisk, second bootloader, recovery dtbo and dtb')
+    parser.add_argument(
+        '--boot_img',
+        help='path to boot image',
+        type=FileType('rb'),
+        required=True)
+    parser.add_argument('--out', help='path to out binaries', default='out')
+    return parser.parse_args()
+
+
+def main():
+    """parse arguments and unpack boot image"""
+    args = parse_cmdline()
+    create_out_dir(args.out)
+    unpack_bootimage(args)
+
+
+if __name__ == '__main__':
+    main()

commit b0d48dba0caf1e6aa55e0a5076bb97c729a2db33
Author: Kees Cook <keescook@chromium.org>
Date:   Mon Jun 5 21:52:30 2017 -0700

    UPSTREAM: arm64, vdso: Define vdso_{start,end} as array
    
    Adjust vdso_{start|end} to be char arrays to avoid compile-time analysis
    that flags "too large" memcmp() calls with CONFIG_FORTIFY_SOURCE.
    
    Cc: Jisheng Zhang <jszhang@marvell.com>
    Acked-by: Catalin Marinas <catalin.marinas@arm.com>
    Suggested-by: Mark Rutland <mark.rutland@arm.com>
    Signed-off-by: Kees Cook <keescook@chromium.org>
    Signed-off-by: Will Deacon <will.deacon@arm.com>
    (cherry picked from commit dbbb08f500d6146398b794fdc68a8e811366b451)
    
    Change-Id: Ibec1756944779b7da3965855697ee2d797f6c611
    Signed-off-by: Randy Li <randy.li@rock-chips.com>

diff --git a/arch/arm64/kernel/vdso.c b/arch/arm64/kernel/vdso.c
index 46fa4de29fb1..a6f1df69c0c3 100644
--- a/arch/arm64/kernel/vdso.c
+++ b/arch/arm64/kernel/vdso.c
@@ -36,7 +36,7 @@
 #include <asm/vdso.h>
 #include <asm/vdso_datapage.h>
 
-extern char vdso_start, vdso_end;
+extern char vdso_start[], vdso_end[];
 static unsigned long vdso_pages;
 static struct page **vdso_pagelist;
 
@@ -116,14 +116,14 @@ static int __init vdso_init(void)
 	int i;
 	unsigned long pfn;
 
-	if (memcmp(&vdso_start, "\177ELF", 4)) {
+	if (memcmp(vdso_start, "\177ELF", 4)) {
 		pr_err("vDSO is not a valid ELF object!\n");
 		return -EINVAL;
 	}
 
-	vdso_pages = (&vdso_end - &vdso_start) >> PAGE_SHIFT;
+	vdso_pages = (vdso_end - vdso_start) >> PAGE_SHIFT;
 	pr_info("vdso: %ld pages (%ld code @ %p, %ld data @ %p)\n",
-		vdso_pages + 1, vdso_pages, &vdso_start, 1L, vdso_data);
+		vdso_pages + 1, vdso_pages, vdso_start, 1L, vdso_data);
 
 	/* Allocate the vDSO pagelist, plus a page for the data. */
 	vdso_pagelist = kcalloc(vdso_pages + 1, sizeof(struct page *),
@@ -136,7 +136,7 @@ static int __init vdso_init(void)
 
 
 	/* Grab the vDSO code pages. */
-	pfn = sym_to_pfn(&vdso_start);
+	pfn = sym_to_pfn(vdso_start);
 
 	for (i = 0; i < vdso_pages; i++)
 		vdso_pagelist[i + 1] = pfn_to_page(pfn + i);

commit 27a1523ff14e4c378f2cb3b07b9345aba24894bd
Author: Shixiang Zheng <shixiang.zheng@rock-chips.com>
Date:   Tue Jun 11 15:39:34 2019 +0800

    scripts/bmpconvert: 8bit bmp file should not convert to 24bit
    
    8bit logo convert to 24bit enlarge triple buffer size which
    some chips can't reserve.
    
    Change-Id: I769602f9d04e46a039d7a9158e25c1bb2067df32
    Signed-off-by: Shixiang Zheng <shixiang.zheng@rock-chips.com>

diff --git a/scripts/bmpconvert b/scripts/bmpconvert
index 8363429e929c..d660bb4c762e 100755
--- a/scripts/bmpconvert
+++ b/scripts/bmpconvert
@@ -40,12 +40,6 @@ class BMPFile:
         if self.biSize > 40:
             self.read_other(self.biSize-40)
 
-        if self.biBitCount == 8:
-            for i in range(256):
-                self.color_map.append(
-                    [unpack("<B", self.file.read(1))[0], unpack("<B", self.file.read(1))[0],
-                     unpack("<B", self.file.read(1))[0]])
-                self.file.read(1)
         if self.biBitCount == 16 and self.biCompression == 3:
             for i in range(4):
                 self.bf_map.append(
@@ -59,14 +53,7 @@ class BMPFile:
             else:
                 self.bmp16bit_to_24bit()
         elif self.biBitCount == 8:
-            if self.biCompression == 1:
-                # print("8bit rle file not convert")
-                self.file.close()
-                return
-            elif self.biCompression == 0:
-                self.bmp8bit_to_24bit()
-            else:
-                print("err! bit_count is 8 while bit_compressoion is wrong")
+                # Not convert 8bit bmp logo to 24 bit
                 self.file.close()
                 return
         else:

commit 9c7fdd3d6d2a2cdacb9750e730772f2e5b5eb94d
Author: Yao Xiao <xiaoyao@rock-chips.com>
Date:   Thu Jun 6 17:11:03 2019 +0800

    net: rockchip_wlan: update cywdhd to "1.363.125.15 (r)"
    
    Change-Id: Ibc20ffbab407f3be98a501875894e4804d727cc8
    Signed-off-by: Yao Xiao <xiaoyao@rock-chips.com>

diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Kconfig b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Kconfig
index da2a8120a234..c99cda4cc7a8 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Kconfig
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Kconfig
@@ -1,3 +1,4 @@
+# SPDX-License-Identifier: GPL-2.0
 config BCMDHD
 	tristate "Broadcom FullMAC wireless cards support"
 	---help---
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile
index a8f4207ec32d..2b321e9192e5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/Makefile
@@ -1,41 +1,32 @@
 # SPDX-License-Identifier: GPL-2.0
 # cywdhd
+#################
+# Usage and porting guide for this Makefile
+#################
+# 1 Default to the module external build, that is, no need to copy the driver into the kernel source tree
+#  Build with:
+#       make KDIR=/path/to/your/kernel
+# 2 Default to x86 build: Build the x86 driver without any modification outside of kernel
+# 3 Just change the 'DHD_PLATFORM=imx' and the IMx OOB version can work!
+# 4 Copy DHD_PLATFORM=imx as the start point and create your own name
+
 #####################
 # SDIO Basic feature
 #####################
-CONFIG_BCMDHD := y
-CONFIG_CFG80211 := y
-CONFIG_BCMDHD_SDIO := y
-CONFIG_BCMDHD_OOB := y
-CONFIG_BCM43455 := y
-CONFIG_PLAT_ROCKCHIP := y
 
 DHDCFLAGS += -Wall -Wstrict-prototypes -Dlinux -DLINUX -DBCMDRIVER            \
 	-DBCMDONGLEHOST -DUNRELEASEDCHIP -DBCMDMA32 -DBCMFILEIMAGE            \
-	-DDHDTHREAD -DSHOW_EVENTS -DBCMDBG -DWLP2P                            \
+	-DSHOW_EVENTS -DBCMDBG -DWLP2P                                        \
 	-DWIFI_ACT_FRAME -DARP_OFFLOAD_SUPPORT                                \
 	-DKEEP_ALIVE -DCSCAN -DPKT_FILTER_SUPPORT                             \
 	-DEMBEDDED_PLATFORM -DPNO_SUPPORT                                     \
 	-DDHD_DONOT_FORWARD_BCMEVENT_AS_NETWORK_PKT                           \
-	-DCUSTOMER_HW2 -DGET_CUSTOM_MAC_ENABLE
+	-DCUSTOMER_HW2 -DSDTEST
 
 #################
 # Common feature
 #################
-ifneq ($(CONFIG_BCMDHD_SDIO),)
-  DHDCFLAGS += -DBDC -DDHD_BCMEVENTS -DMMC_SDIO_ABORT
-  DHDCFLAGS += -DBCMSDIO -DBCMLXSDMMC -DUSE_SDIOFIFO_IOVAR
-  DHDCFLAGS += -DPROP_TXSTATUS
-endif
-
-ifneq ($(CONFIG_BCMDHD_OOB),)
-  DHDCFLAGS += -DOOB_INTR_ONLY -DCUSTOMER_OOB -DHW_OOB
-else
-  DHDCFLAGS += -DSDIO_ISR_THREAD
-endif
-
 DHDCFLAGS += -DWL_CFG80211
-DHDCFLAGS += -DWL_VIRTUAL_APSTA #-DWL_WIRELESS_EXT
 # Print out kernel panic point of file and line info when assertion happened
 DHDCFLAGS += -DBCMASSERT_LOG
 
@@ -44,11 +35,17 @@ DHDCFLAGS += -DCUSTOM_KEEP_ALIVE_SETTING=28000
 
 DHDCFLAGS += -DVSDB
 
+# Fix __DATE__ & __TIME__ error on gcc version 4.9 or later
+GCCVERSION = $(shell $(CC) -dumpversion | cut -f1-2 -d.)
+ifeq ($(shell expr $(GCCVERSION) \>= 4.9),1)
+  DHDCFLAGS += -Wno-error=date-time
+endif
+
 # For p2p connection issue
 DHDCFLAGS += -DWL_SCB_TIMEOUT=10
 
 # TDLS enable
-DHDCFLAGS += -DWLTDLS -DWLTDLS_AUTO_ENABLE
+DHDCFLAGS += -DWLTDLS
 # For TDLS tear down inactive time 40 sec
 DHDCFLAGS += -DCUSTOM_TDLS_IDLE_MODE_SETTING=40000
 # for TDLS RSSI HIGH for establishing TDLS link
@@ -63,6 +60,8 @@ DHDCFLAGS += -DENABLE_FW_ROAM_SUSPEND
 # Roaming trigger
 DHDCFLAGS += -DCUSTOM_ROAM_TRIGGER_SETTING=-75
 DHDCFLAGS += -DCUSTOM_ROAM_DELTA_SETTING=10
+# Voice Enterprise
+DHDCFLAGS += -DWLFBT
 # Set PM 2 always regardless suspend/resume
 DHDCFLAGS += -DSUPPORT_PM2_ONLY
 
@@ -72,7 +71,7 @@ DHDCFLAGS += -DMIRACAST_AMPDU_SIZE=8
 #Vendor Extension
 DHDCFLAGS += -DWL_VENDOR_EXT_SUPPORT
 #Gscan
-DHDCFLAGS += -DGSCAN_SUPPORT
+# DHDCFLAGS += -DGSCAN_SUPPORT
 #RTT
 DHDCFLAGS += -DRTT_SUPPORT -DRTT_DEBUG
 
@@ -101,9 +100,6 @@ DHDCFLAGS += -DIOCTL_RESP_TIMEOUT=5000
 # Prevent rx thread monopolize
 DHDCFLAGS += -DWAIT_DEQUEUE
 
-# Config PM Control
-DHDCFLAGS += -DCONFIG_CONTROL_PM
-
 # idle count
 DHDCFLAGS += -DDHD_USE_IDLECOUNT
 
@@ -121,63 +117,117 @@ DHDCFLAGS += -DCUSTOM_FORCE_NODFS_FLAG
 
 
 # SoftAP
-DHDCFLAGS += -DDISABLE_11H_SOFTAP
 DHDCFLAGS += -DSET_RANDOM_MAC_SOFTAP
 DHDCFLAGS += -DWL_CFG80211_ACL
 
-#Disable FRAMEBURST on VSDB
-DHDCFLAGS += -DDISABLE_FRAMEBURST_VSDB
-
-
-#Rochip Platform
-ifneq ($(CONFIG_PLAT_ROCKCHIP),)
-DHDCFLAGS += -DCONFIG_PLAT_ROCKCHIP
-DHDCFLAGS += -DDHD_OF_SUPPORT
-endif
-
 ##########################
 # driver type
 # m: module type driver
 # y: built-in type driver
 ##########################
-DRIVER_TYPE ?= $(CONFIG_BCMDHD)
+DRIVER_TYPE ?= m
 
 #########################
 # Chip dependent feature
 #########################
 
-ifneq ($(filter y, $(CONFIG_BCM4354) $(CONFIG_BCM4356) $(CONFIG_BCM43455)),)
-  DHDCFLAGS += -DUSE_WL_TXBF
-  DHDCFLAGS += -DUSE_WL_FRAMEBURST
-  DHDCFLAGS += -DCUSTOM_DPC_CPUCORE=0
-  DHDCFLAGS += -DPROP_TXSTATUS_VSDB
-  DHDCFLAGS += -DCUSTOM_PSPRETEND_THR=30
-  DHDCFLAGS += -DMAX_AP_CLIENT_CNT=10
-  DHDCFLAGS += -DMAX_GO_CLIENT_CNT=5
+DHDCFLAGS += -DUSE_WL_TXBF
+# DHDCFLAGS += -DUSE_WL_FRAMEBURST
+DHDCFLAGS += -DCUSTOM_DPC_CPUCORE=0
+DHDCFLAGS += -DPROP_TXSTATUS_VSDB
+DHDCFLAGS += -DCUSTOM_PSPRETEND_THR=30
 # New Features
-  DHDCFLAGS += -DWL11U
-  DHDCFLAGS += -DMFP
-  DHDCFLAGS += -DDHD_ENABLE_LPC
-  DHDCFLAGS += -DCUSTOM_COUNTRY_CODE
-  DHDCFLAGS += -DSAR_SUPPORT
-# debug info
-  DHDCFLAGS += -DDHD_WAKE_STATUS
+DHDCFLAGS += -DWL11U
+DHDCFLAGS += -DMFP
+# The LPC would have the Tx 5G tput drop around 10Mbps but saving powers
+# DHDCFLAGS += -DDHD_ENABLE_LPC
+DHDCFLAGS += -DCUSTOM_COUNTRY_CODE
+
+### Platform dependent START
+DHD_PLATFORM ?= rockchip
+
+ifeq ($(DHD_PLATFORM), rockchip)
+  CONFIG_BCMDHD_SDIO = y
+  CONFIG_BCMDHD_OOB = y
+
+  ## We only add here for the flags in our rockchip code
+  DHDCFLAGS += -DCUSTOM_SDIO_F2_BLKSIZE=256
+  DHDCFLAGS += -DDHD_OF_SUPPORT 
+  DHDCFLAGS += -DCONFIG_PLAT_ROCKCHIP
+ifeq ($(CONFIG_BCMDHD_OOB),y)
+DHDCFLAGS += -DOOB_INTR_ONLY -DCUSTOMER_OOB -DHW_OOB
+ifeq ($(CONFIG_BCMDHD_DISABLE_WOWLAN),y)
+DHDCFLAGS += -DDISABLE_WOWLAN
+endif
+else
+DHDCFLAGS += -DSDIO_ISR_THREAD
+endif
+endif
+
+ifeq ($(DHD_PLATFORM), ingenic)
+  CONFIG_BCMDHD_SDIO = y
+  ## We only add here for the flags in our generic code
+  DHDCFLAGS += -DOOB_INTR_ONLY -DHW_OOB
+  DHDCFLAGS += -DCUSTOM_SDIO_F2_BLKSIZE=128
+  DHDCFLAGS += -DDHD_OF_SUPPORT -DCUSTOMER_OOB
+  DHDCFLAGS += -DLOAD_DHD_WITH_FW_ALIVE
+  FW_ALIVE = 1
+endif
+
+
+ifeq ($(DHD_PLATFORM), imx_android)
+  CONFIG_BCMDHD_SDIO = y
+# Config DTS support
+  DHDCFLAGS += -DCONFIG_DTS
+# for iMX platform
+  DHDCFLAGS += -DCUSTOMER_IMX
+  DHDCFLAGS += -DOOB_INTR_ONLY -DHW_OOB
+  DHDCFLAGS += -DANDROID_SDIO_RESET
+# The flags only worked for supported host
+# Remove it if you found the dhdsdio_rxglom erros
+  DHDCFLAGS += -DCUSTOM_RXCHAIN=1
+endif
+
+ifeq ($(DHD_PLATFORM), imx)
+  CONFIG_BCMDHD_SDIO = y
+# Config DTS support
+  DHDCFLAGS += -DCONFIG_DTS
+# for iMX platform
+  DHDCFLAGS += -DCUSTOMER_IMX
+  DHDCFLAGS += -DOOB_INTR_ONLY -DHW_OOB
+# The flags only worked for supported host
+# Remove it if you found the dhdsdio_rxglom erros
+  DHDCFLAGS += -DCUSTOM_RXCHAIN=1
+endif
+
+ifeq ($(CONFIG_BCMDHD_PCIE), y)
+  CONFIG_BCMDHD_PCIE = y
+else
+ifeq ($(CONFIG_BCMDHD_USB), y)
+  CONFIG_BCMDHD_USB = y
+else
+  CONFIG_BCMDHD_SDIO = y
+endif
+endif
+
+### Platform dependent END
+
 ifneq ($(CONFIG_BCMDHD_SDIO),)
+  DHDCFLAGS += -DBDC -DTOE -DDHD_BCMEVENTS -DMMC_SDIO_ABORT
+  DHDCFLAGS += -DBCMSDIO -DBCMLXSDMMC -DUSE_SDIOFIFO_IOVAR
+  DHDCFLAGS += -DPROP_TXSTATUS
   DHDCFLAGS += -DCUSTOM_AMPDU_MPDU=16
   DHDCFLAGS += -DCUSTOM_AMPDU_BA_WSIZE=64
 # tput enhancement
-  DHDCFLAGS += -DCUSTOM_GLOM_SETTING=8 -DCUSTOM_RXCHAIN=1
-  DHDCFLAGS += -DUSE_DYNAMIC_F2_BLKSIZE -DDYNAMIC_F2_BLKSIZE_FOR_NONLEGACY=128
-  DHDCFLAGS += -DBCMSDIOH_TXGLOM -DCUSTOM_TXGLOM=1 -DBCMSDIOH_TXGLOM_HIGHSPEED
+  DHDCFLAGS += -DCUSTOM_GLOM_SETTING=8
+  DHDCFLAGS += -DBCMSDIOH_TXGLOM -DCUSTOM_TXGLOM=1
   DHDCFLAGS += -DDHDTCPACK_SUPPRESS
   DHDCFLAGS += -DRXFRAME_THREAD
-  DHDCFLAGS += -DREPEAT_READFRAME
   DHDCFLAGS += -DCUSTOM_MAX_TXGLOM_SIZE=31
   DHDCFLAGS += -DMAX_HDR_READ=128
   DHDCFLAGS += -DDHD_FIRSTREAD=128
   # bcn_timeout
   DHDCFLAGS += -DCUSTOM_BCN_TIMEOUT=5
-  DHDCFLAGS += -DWLFC_STATE_PREALLOC
  endif
 
 ifneq ($(CONFIG_BCMDHD_PCIE),)
@@ -191,42 +241,26 @@ ifneq ($(CONFIG_BCMDHD_PCIE),)
   DHDCFLAGS += -DCUSTOM_DHD_WATCHDOG_MS=0
   DHDCFLAGS += -DMAX_CNTL_TX_TIMEOUT=1
   DHDCFLAGS += -DSUPPORT_LINKDOWN_RECOVERY
-  endif
+endif
+
+ifneq ($(CONFIG_BCMDHD_USB),)
+  DHDCFLAGS += -DBDC -DTOE
+  DHDCFLAGS += -DDHD_BCMEVENTS -DSHOW_EVENTS -DSHOW_LOGTRACE
+  DHDCFLAGS += -DBCMDHDUSB -DBCMDBUS -DBCMTRXV2 -DDBUS_USB_LOOPBACK
+  DHDCFLAGS += -DPROP_TXSTATUS
+  DHDCFLAGS += -DLIMIT_BORROW
+endif
+
 ifeq ($(CONFIG_DHD_USE_STATIC_BUF),y)
   DHDCFLAGS += -DDHD_USE_STATIC_IOCTLBUF
 endif
-  DHDCFLAGS += -DDONGLE_ENABLE_ISOLATION
 # Print 802.1X packets
-  DHDCFLAGS += -DDHD_8021X_DUMP
+DHDCFLAGS += -DDHD_8021X_DUMP
 # Print DHCP packets
-  DHDCFLAGS += -DDHD_DHCP_DUMP
-endif
-
+DHDCFLAGS += -DDHD_DHCP_DUMP
 
-ifneq ($(CONFIG_BCM4339),)
-  DHDCFLAGS += -DBCM4339_CHIP -DHW_OOB
 
-  # tput enhancement
-  DHDCFLAGS += -DCUSTOM_GLOM_SETTING=8 -DCUSTOM_RXCHAIN=1
-  DHDCFLAGS += -DUSE_DYNAMIC_F2_BLKSIZE -DDYNAMIC_F2_BLKSIZE_FOR_NONLEGACY=128
-  DHDCFLAGS += -DBCMSDIOH_TXGLOM -DCUSTOM_TXGLOM=1 -DBCMSDIOH_TXGLOM_HIGHSPEED
-  DHDCFLAGS += -DDHDTCPACK_SUPPRESS
-  DHDCFLAGS += -DUSE_WL_TXBF
-  DHDCFLAGS += -DUSE_WL_FRAMEBURST
-  DHDCFLAGS += -DRXFRAME_THREAD
-  DHDCFLAGS += -DCUSTOM_AMPDU_BA_WSIZE=64
-  DHDCFLAGS += -DCUSTOM_DPC_CPUCORE=0
-  DHDCFLAGS += -DPROP_TXSTATUS_VSDB
-  DHDCFLAGS += -DCUSTOM_MAX_TXGLOM_SIZE=40
-
-  # New Features
-  DHDCFLAGS += -DWL11U
-  DHDCFLAGS += -DDHD_ENABLE_LPC
-  DHDCFLAGS += -DCUSTOM_PSPRETEND_THR=30
-endif
-
-
-#EXTRA_LDFLAGS += --strip-debug
+EXTRA_LDFLAGS += --strip-debug
 
 ifeq ($(DRIVER_TYPE),y)
   DHDCFLAGS += -DENABLE_INSMOD_NO_FW_LOAD
@@ -236,6 +270,24 @@ endif
 ## Attend to fix the suspend/resume -16 error issue, refer to SWDHD-409
 DHDCFLAGS += -DSUSPEND16
 
+
+## Flags merged from Linux build
+DHDCFLAGS += -DCUSTOMER_IPCAM -DWL11ULB -DWL_NAN -DWL_SUPPORT_AUTO_CHANNEL -DWL_VIRTUAL_APSTA
+
+## Flags that may depends on Linux kernel versions
+DHDCFLAGS += -DTSQ_MULTIPLIER=10
+
+## Flags maybe useful but disable it
+
+# The WLFC AC queue credit borrow
+# DHDCFLAGS += -DLIMIT_BORROW
+
+# Advanced IBSS features
+# DHDCFLAGS += -DWLAIBSS -DWLAIBSS_PS
+
+# p2P service discovery offload
+# DHDCFLAGS += -DWL_SDO
+
 EXTRA_CFLAGS += $(DHDCFLAGS) -DDHD_DEBUG
 EXTRA_CFLAGS += -DSRCBASE=\"$(src)\"
 EXTRA_CFLAGS += -I$(src)/include/ -I$(src)/
@@ -246,7 +298,14 @@ DHDOFILES := dhd_pno.o dhd_common.o dhd_ip.o dhd_custom_gpio.o \
 	bcmutils.o bcmwifi_channels.o hndpmu.o linux_osl.o sbutils.o siutils.o \
 	wl_android.o wl_cfg80211.o wl_cfgp2p.o wl_cfg_btcoex.o wldev_common.o wl_linux_mon.o  \
 	dhd_linux_platdev.o dhd_pno.o dhd_rtt.o dhd_linux_wq.o wl_cfg_btcoex.o \
-        hnd_pktq.o hnd_pktpool.o wl_cfgvendor.o dhd_debug_linux.o bcmxtlv.o dhd_debug.o bcm_app_utils.o
+        hnd_pktq.o hnd_pktpool.o wl_cfgvendor.o dhd_debug_linux.o bcmxtlv.o dhd_debug.o bcm_app_utils.o \
+	wl_cfgnan.o
+
+ifeq ($(FW_ALIVE), 1)
+  DHDCFLAGS += -DLOAD_DHD_WITH_FW_ALIVE
+  DHDOFILES += dhd_chip_info.o
+endif
+
 
 ifneq ($(CONFIG_BCMDHD_SDIO),)
   DHDOFILES += bcmsdh.o bcmsdh_linux.o bcmsdh_sdmmc.o bcmsdh_sdmmc_linux.o
@@ -258,13 +317,18 @@ ifneq ($(CONFIG_BCMDHD_PCIE),)
   DHDOFILES += pcie_core.o
 endif
 
-ifneq ($(CONFIG_PLAT_ROCKCHIP),)
+ifneq ($(CONFIG_BCMDHD_USB),)
+  DHDOFILES += dbus.o dbus_usb.o dbus_usb_linux.o
+  DHDOFILES += dhd_cdc.o dhd_wlfc.o
+endif
+
+ifeq ($(DHD_PLATFORM), rockchip)
 DHDOFILES += dhd_gpio.o
 DHDOFILES += rkversion.o
 endif
 
-bcmdhd-objs := $(DHDOFILES)
-obj-$(DRIVER_TYPE)   += bcmdhd.o
+cywdhd-objs := $(DHDOFILES)
+obj-$(DRIVER_TYPE)   += cywdhd.o
 
 all:
 	@echo "$(MAKE) --no-print-directory -C $(KDIR) SUBDIRS=$(CURDIR) modules"
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/aiutils.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/aiutils.c
index 2de4a66f3fd5..7eadfb1cc724 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/aiutils.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/aiutils.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines for accessing chip-specific features
  * of the SiliconBackplane-based Broadcom chips.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -25,7 +26,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: aiutils.c 526024 2015-01-13 03:59:33Z $
+ * $Id: aiutils.c 708487 2018-10-31 05:33:14Z $
  */
 #include <bcm_cfg.h>
 #include <typedefs.h>
@@ -39,6 +40,12 @@
 
 #include "siutils_priv.h"
 
+
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+#include <bcmdevs.h>
+#include <dhd_chip_info.h>
+#endif
+
 #define BCM47162_DMP() (0)
 #define BCM5357_DMP() (0)
 #define BCM53573_DMP() (0)
@@ -142,6 +149,33 @@ ai_scan(si_t *sih, void *regs, uint devid)
 	chipcregs_t *cc = (chipcregs_t *)regs;
 	uint32 erombase, *eromptr, *eromlim;
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	if(alive == FW_ALIVE_MAGIC) {
+		switch(card_dev) {
+			case BCM43430_CHIP_ID:
+				sii->numcores = ai_core_43430;
+				sii->oob_router = oob_router_43430;
+				memcpy(&cores_info->coreid, &bcm43430_coreid, sii->numcores * 4);
+				memcpy(&cores_info->coresba, &bcm43430_coresba, sii->numcores * 4);
+				memcpy(&cores_info->coresba_size, &bcm43430_coresba_size, sii->numcores * 4);
+				memcpy(&cores_info->wrapba, &bcm43430_wrapba, sii->numcores * 4);
+				memcpy(&cores_info->cia, &bcm43430_cia, sii->numcores * 4);
+				if(card_rev == 2) {
+					memcpy(&cores_info->cib, &bcm43436_cib, sii->numcores * 4);
+				} else {
+					memcpy(&cores_info->cib, &bcm43430_cib, sii->numcores * 4);
+				}
+				break;
+
+			default:
+				break;
+
+		}
+
+		return;
+	}
+#endif
+
 	erombase = R_REG(sii->osh, &cc->eromptr);
 
 	switch (BUSTYPE(sih->bustype)) {
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcm_app_utils.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcm_app_utils.c
index 907d0411faa2..8c46ed08a508 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcm_app_utils.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcm_app_utils.c
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines used by kernel or app-level.
  * Contents are wifi-specific, used by any kernel or app-level
  * software that might want wifi things as it grows.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmevent.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmevent.c
index 681b4c50e486..82aa4fb98c78 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmevent.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmevent.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * bcmevent read-only data shared by kernel or app layers
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -165,6 +166,9 @@ static const bcmevent_name_str_t bcmevent_names[] = {
 #if defined(BT_WIFI_HANDOVER) || defined(WL_TBOW)
 	BCMEVENT_NAME(WLC_E_BT_WIFI_HANDOVER_REQ),
 #endif
+#ifdef WLFBT
+	BCMEVENT_NAME(WLC_E_FBT_AUTH_REQ_IND),
+#endif /* WLFBT */
 	BCMEVENT_NAME(WLC_E_AUTHORIZED),
 	BCMEVENT_NAME(WLC_E_PROBREQ_MSG_RX),
 	BCMEVENT_NAME(WLC_E_CSA_START_IND),
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh.c
index 378c4e42e1ed..cda847b63bc8 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  *  BCMSDH interface glue
  *  implement bcmsdh API for SDIOH driver
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_linux.c
index 7f3f143680b3..32dd930a37cf 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_linux.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SDIO access interface for drivers - linux specific (pci only)
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -84,7 +85,7 @@ typedef struct bcmsdh_os_info {
 } bcmsdh_os_info_t;
 
 /* debugging macros */
-#define SDLX_MSG(x)		printf x
+#define SDLX_MSG(x)
 
 /**
  * Checks to see if vendor and device IDs match a supported SDIO Host Controller.
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc.c
index ddb5d117069d..bc302abc75ea 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BCMSDH Function Driver for the native SDIO/MMC driver in the Linux Kernel
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Proprietary,Open:>>
  *
- * $Id: bcmsdh_sdmmc.c 666459 2017-08-22 06:08:52Z $
+ * $Id: bcmsdh_sdmmc.c 707694 2018-09-06 02:49:19Z $
  */
 #include <typedefs.h>
 
@@ -62,7 +63,15 @@ static void IRQHandler(struct sdio_func *func);
 static void IRQHandlerF2(struct sdio_func *func);
 #endif /* !defined(OOB_INTR_ONLY) */
 static int sdioh_sdmmc_get_cisaddr(sdioh_info_t *sd, uint32 regaddr);
+
+#if defined(ANDROID_SDIO_RESET)
 extern int sdio_reset_comm(struct mmc_card *card);
+#else
+static int sdio_reset_comm(struct mmc_card *card)
+{
+	return 0;
+}
+#endif /* ANDROID_SDIO_RESET */
 
 #define DEFAULT_SDIO_F2_BLKSIZE		512
 #ifndef CUSTOM_SDIO_F2_BLKSIZE
@@ -84,7 +93,7 @@ uint sd_divisor = 2;			/* Default 48MHz/2 = 24MHz */
 uint sd_power = 1;		/* Default to SD Slot powered ON */
 uint sd_clock = 1;		/* Default to SD Clock turned ON */
 uint sd_hiok = FALSE;	/* Don't use hi-speed mode by default */
-uint sd_msglevel = SDH_ERROR_VAL;
+uint sd_msglevel = 0x01;
 uint sd_use_dma = TRUE;
 
 #ifndef CUSTOM_RXCHAIN
@@ -1398,7 +1407,8 @@ sdioh_start(sdioh_info_t *sd, int stage)
 			and enable the fucntion 1 for in preparation for
 			downloading the code
 		*/
-		/* sdio_reset_comm() - has been fixed in latest kernel/msm.git for Linux
+		/* sdio_reset_comm() For Android kernel only
+		   has been fixed in latest kernel/msm.git for Linux
 		   2.6.27. The implementation prior to that is buggy, and needs broadcom's
 		   patch for it
 		*/
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc_linux.c
index a10bf5073057..ed7303ad2aa8 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdh_sdmmc_linux.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BCMSDH Function Driver for the native SDIO/MMC driver in the Linux Kernel
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Proprietary,Open:>>
  *
- * $Id: bcmsdh_sdmmc_linux.c 665039 2017-05-12 08:38:09Z $
+ * $Id: bcmsdh_sdmmc_linux.c 708487 2018-10-31 05:33:14Z $
  */
 
 #include <typedefs.h>
@@ -44,6 +45,11 @@
 #include <bcmsdh_sdmmc.h>
 #include <dhd_dbg.h>
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+#include <dhd_chip_info.h>
+#endif
+
+
 #if !defined(SDIO_VENDOR_ID_BROADCOM)
 #define SDIO_VENDOR_ID_BROADCOM		0x02d0
 #endif /* !defined(SDIO_VENDOR_ID_BROADCOM) */
@@ -107,6 +113,10 @@ static int sdioh_probe(struct sdio_func *func)
 	osl_t *osh = NULL;
 	sdioh_info_t *sdioh = NULL;
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	int ready = 0;
+#endif
+
 	sd_err(("bus num (host idx)=%d, slot num (rca)=%d\n", host_idx, rca));
 	adapter = dhd_wifi_platform_get_adapter(SDIO_BUS, host_idx, rca);
 	if (adapter  != NULL)
@@ -130,6 +140,17 @@ static int sdioh_probe(struct sdio_func *func)
 		 sd_err(("%s: sdioh_attach failed\n", __FUNCTION__));
 		 goto fail;
 	 }
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	sdioh_cfg_read(sdioh, SDIO_FUNC_0, SDIOD_CCCR_IORDY, (uint8 *)&ready);
+
+	sd_info(("%s, %d, ready = %08x\n", __func__, __LINE__, ready));
+	if(ready == (SDIO_FUNC_READY_1|SDIO_FUNC_READY_2)) {
+		alive = FW_ALIVE_MAGIC;	//func->card->nr_parts;
+		card_dev = func->card->cis.device;
+	}
+
+	sd_info(("nr_parts = %08x, card_dev = %08x\n", alive, card_dev));
+#endif
 	 sdioh->bcmsdh = bcmsdh_probe(osh, &func->dev, sdioh, adapter, SDIO_BUS, host_idx, rca);
 	 if (sdioh->bcmsdh == NULL) {
 		 sd_err(("%s: bcmsdh_probe failed\n", __FUNCTION__));
@@ -166,7 +187,6 @@ static void sdioh_remove(struct sdio_func *func)
 
 extern int cis_chipvendor;
 extern unsigned short cis_device;
-
 static int bcmsdh_sdmmc_probe(struct sdio_func *func,
                               const struct sdio_device_id *id)
 {
@@ -196,6 +216,7 @@ static int bcmsdh_sdmmc_probe(struct sdio_func *func,
 			tuple = tuple->next;
 		}
 	}
+
 	/* 4318 doesn't have function 2 */
 	if ((func->num == 2) || (func->num == 1 && func->device == 0x4))
 		ret = sdioh_probe(func);
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdspi_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdspi_linux.c
index b7091e5985f9..04aa1e5e160c 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdspi_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmsdspi_linux.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom SPI Host Controller Driver - Linux Per-port
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmspibrcm.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmspibrcm.c
index d8591b796039..6c4566e827dd 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmspibrcm.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmspibrcm.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom BCMSDH to gSPI Protocol Conversion Layer
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmutils.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmutils.c
index c001378bea17..af41a50b830a 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmutils.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmutils.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Driver O/S-independent utility routines
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: bcmutils.c 674349 2017-10-19 07:59:24Z $
+ * $Id: bcmutils.c 692666 2018-07-30 08:58:07Z $
  */
 
 #include <bcm_cfg.h>
@@ -3612,3 +3613,66 @@ dll_pool_free_tail(dll_pool_t * dll_pool_p, void * elem_p)
 }
 
 #endif 
+
+/* calculate partial checksum */
+static uint32
+ip_cksum_partial(uint32 sum, uint8 *val8, uint32 count)
+{
+	uint32 i;
+	uint16 *val16 = (uint16 *)val8;
+
+	ASSERT(val8 != NULL);
+	/* partial chksum calculated on 16-bit values */
+	ASSERT((count % 2) == 0);
+
+	count /= 2;
+
+	for (i = 0; i < count; i++) {
+		sum += *val16++;
+	}
+	return sum;
+}
+
+/* calculate IP checksum */
+static uint16
+ip_cksum(uint32 sum, uint8 *val8, uint32 count)
+{
+	uint16 *val16 = (uint16 *)val8;
+
+	ASSERT(val8 != NULL);
+
+	while (count > 1) {
+		sum += *val16++;
+		count -= 2;
+	}
+	/*  add left-over byte, if any */
+	if (count > 0) {
+		sum += (*(uint8 *)val16);
+	}
+
+	/*  fold 32-bit sum to 16 bits */
+	sum = (sum >> 16) + (sum & 0xffff);
+	sum += (sum >> 16);
+	return ((uint16)~sum);
+}
+
+/* calculate IPv4 header checksum
+ * - input ip points to IP header in network order
+ * - output cksum is in network order
+ */
+uint16
+ipv4_hdr_cksum(uint8 *ip, int ip_len)
+{
+	uint32 sum = 0;
+	uint8 *ptr = ip;
+
+	ASSERT(ip != NULL);
+	ASSERT(ip_len >= IPV4_MIN_HEADER_LEN);
+
+	/* partial cksum skipping the hdr_chksum field */
+	sum = ip_cksum_partial(sum, ptr, OFFSETOF(struct ipv4_hdr, hdr_chksum));
+	ptr += OFFSETOF(struct ipv4_hdr, hdr_chksum) + 2;
+
+	/* return calculated chksum */
+	return ip_cksum(sum, ptr, ip_len - OFFSETOF(struct ipv4_hdr, src_ip));
+}
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.c
index 83475223f312..0d30842d48fb 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.c
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines used by kernel or app-level.
  * Contents are wifi-specific, used by any kernel or app-level
  * software that might want wifi things as it grows.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.h
index 8e78c2c1227b..e493e51434ba 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_channels.h
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines for WL and Apps
  * This header file housing the define and function prototype use by
  * both the wl driver, tools & Apps.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_rates.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_rates.h
index 412fd8fba1f5..47296da61d72 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_rates.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmwifi_rates.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Indices for 802.11 a/b/g/n/ac 1-3 chain symmetric transmit rates
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmxtlv.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmxtlv.c
index 90023b2f2977..c5556eaf67e4 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmxtlv.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/bcmxtlv.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Driver O/S-independent utility routines
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus.c
new file mode 100644
index 000000000000..41981478c955
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus.c
@@ -0,0 +1,2501 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/** @file dbus.c
+ *
+ * Hides details of USB / SDIO / SPI interfaces and OS details. It is intended to shield details and
+ * provide the caller with one common bus interface for all dongle devices. In practice, it is only
+ * used for USB interfaces. DBUS is not a protocol, but an abstraction layer.
+ *
+ * Copyright (C) 1999-2018, Broadcom Corporation
+ * 
+ *      Unless you and Broadcom execute a separate written software license
+ * agreement governing use of this software, this software is licensed to you
+ * under the terms of the GNU General Public License version 2 (the "GPL"),
+ * available at http://www.broadcom.com/licenses/GPLv2.php, with the
+ * following added to such license:
+ * 
+ *      As a special exception, the copyright holders of this software give you
+ * permission to link this software with independent modules, and to copy and
+ * distribute the resulting executable under terms of your choice, provided that
+ * you also meet, for each linked independent module, the terms and conditions of
+ * the license of that module.  An independent module is a module which is not
+ * derived from this software.  The special exception does not apply to any
+ * modifications of the software.
+ * 
+ *      Notwithstanding the above, under no circumstances may you combine this
+ * software in any way with any other Broadcom software provided under a license
+ * other than the GPL, without Broadcom's express prior written consent.
+ *
+ *
+ * <<Broadcom-WL-IPTag/Open:>>
+ *
+ * $Id: dbus.c 553311 2015-04-29 10:23:08Z $
+ */
+
+
+#include "osl.h"
+#include "dbus.h"
+#include <bcmutils.h>
+
+#if defined(BCM_DNGL_EMBEDIMAGE)
+#include <bcmsrom_fmt.h>
+#include <trxhdr.h>
+#include <usbrdl.h>
+#include <bcmendian.h>
+#include <zutil.h>
+#include <sbpcmcia.h>
+#include <bcmnvram.h>
+#include <bcmdevs.h>
+#elif defined(BCM_REQUEST_FW)
+#include <bcmsrom_fmt.h>
+#include <trxhdr.h>
+#include <usbrdl.h>
+#include <bcmendian.h>
+#include <sbpcmcia.h>
+#include <bcmnvram.h>
+#include <bcmdevs.h>
+#endif /* #if defined(BCM_DNGL_EMBEDIMAGE) */
+#if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX)
+#include <linux/usb.h>
+#endif /* EHCI_FASTPATH_TX || EHCI_FASTPATH_RX */
+
+
+#if defined(BCM_DNGL_EMBEDIMAGE)
+/* zlib file format field ids etc from gzio.c */
+#define Z_DEFLATED     8
+#define ASCII_FLAG     0x01 /* bit 0 set: file probably ascii text */
+#define HEAD_CRC       0x02 /* bit 1 set: header CRC present */
+#define EXTRA_FIELD    0x04 /* bit 2 set: extra field present */
+#define ORIG_NAME      0x08 /* bit 3 set: original file name present */
+#define COMMENT        0x10 /* bit 4 set: file comment present */
+#define RESERVED       0xE0 /* bits 5..7: reserved */
+
+#ifdef WL_FW_DECOMP
+#define UNZIP_ENAB(info)  1
+#else
+#define UNZIP_ENAB(info)  0
+
+#ifdef inflateInit2
+#undef inflateInit2
+#define inflateInit2(a, b)  Z_ERRNO
+#endif
+#define inflate(a, b)       Z_STREAM_ERROR
+#define inflateEnd(a)       do {} while (0)
+#define crc32(a, b, c)      -1
+#define free(a)             do {} while (0)
+#endif /* WL_FW_DECOMP */
+
+#elif defined(BCM_REQUEST_FW)
+#ifndef VARS_MAX
+#define VARS_MAX            8192
+#endif
+#endif /* #if defined(BCM_DNGL_EMBEDIMAGE) */
+
+#ifdef DBUS_USB_LOOPBACK
+extern bool is_loopback_pkt(void *buf);
+extern int matches_loopback_pkt(void *buf);
+#endif
+
+/** General info for all BUS types */
+typedef struct dbus_irbq {
+	dbus_irb_t *head;
+	dbus_irb_t *tail;
+	int cnt;
+} dbus_irbq_t;
+
+/**
+ * This private structure dbus_info_t is also declared in dbus_usb_linux.c.
+ * All the fields must be consistent in both declarations.
+ */
+typedef struct dbus_info {
+	dbus_pub_t   pub; /* MUST BE FIRST */
+
+	void        *cbarg;
+	dbus_callbacks_t *cbs; /* callbacks to higher level, e.g. dhd_linux.c */
+	void        *bus_info;
+	dbus_intf_t *drvintf;  /* callbacks to lower level, e.g. dbus_usb.c or dbus_usb_linux.c */
+	uint8       *fw;
+	int         fwlen;
+	uint32      errmask;
+	int         rx_low_watermark;  /* avoid rx overflow by filling rx with free IRBs */
+	int         tx_low_watermark;
+	bool        txoff;
+	bool        txoverride;   /* flow control related */
+	bool        rxoff;
+	bool        tx_timer_ticking;
+
+
+	dbus_irbq_t *rx_q;
+	dbus_irbq_t *tx_q;
+
+#ifdef EHCI_FASTPATH_RX
+	atomic_t    rx_outstanding;
+#endif
+	uint8        *nvram;
+	int          nvram_len;
+	uint8        *image;  /* buffer for combine fw and nvram */
+	int          image_len;
+	uint8        *orig_fw;
+	int          origfw_len;
+	int          decomp_memsize;
+	dbus_extdl_t extdl;
+	int          nvram_nontxt;
+#if defined(BCM_REQUEST_FW)
+	void         *firmware;
+	void         *nvfile;
+#endif
+} dbus_info_t;
+
+struct exec_parms {
+	union {
+		/* Can consolidate same params, if need be, but this shows
+		 * group of parameters per function
+		 */
+		struct {
+			dbus_irbq_t  *q;
+			dbus_irb_t   *b;
+		} qenq;
+
+		struct {
+			dbus_irbq_t  *q;
+		} qdeq;
+	};
+};
+
+#define EXEC_RXLOCK(info, fn, a) \
+	info->drvintf->exec_rxlock(dbus_info->bus_info, ((exec_cb_t)fn), ((struct exec_parms *) a))
+
+#define EXEC_TXLOCK(info, fn, a) \
+	info->drvintf->exec_txlock(dbus_info->bus_info, ((exec_cb_t)fn), ((struct exec_parms *) a))
+
+/*
+ * Callbacks common for all BUS
+ */
+static void dbus_if_send_irb_timeout(void *handle, dbus_irb_tx_t *txirb);
+static void dbus_if_send_irb_complete(void *handle, dbus_irb_tx_t *txirb, int status);
+static void dbus_if_recv_irb_complete(void *handle, dbus_irb_rx_t *rxirb, int status);
+static void dbus_if_errhandler(void *handle, int err);
+static void dbus_if_ctl_complete(void *handle, int type, int status);
+static void dbus_if_state_change(void *handle, int state);
+static void *dbus_if_pktget(void *handle, uint len, bool send);
+static void dbus_if_pktfree(void *handle, void *p, bool send);
+static struct dbus_irb *dbus_if_getirb(void *cbarg, bool send);
+static void dbus_if_rxerr_indicate(void *handle, bool on);
+
+/** functions in this file that are called by lower DBUS levels, e.g. dbus_usb.c */
+static dbus_intf_callbacks_t dbus_intf_cbs = {
+	dbus_if_send_irb_timeout,
+	dbus_if_send_irb_complete,
+	dbus_if_recv_irb_complete,
+	dbus_if_errhandler,
+	dbus_if_ctl_complete,
+	dbus_if_state_change,
+	NULL,			/* isr */
+	NULL,			/* dpc */
+	NULL,			/* watchdog */
+	dbus_if_pktget,
+	dbus_if_pktfree,
+	dbus_if_getirb,
+	dbus_if_rxerr_indicate
+};
+
+/*
+ * Need global for probe() and disconnect() since
+ * attach() is not called at probe and detach()
+ * can be called inside disconnect()
+ */
+static dbus_intf_t     *g_busintf = NULL;
+static probe_cb_t      probe_cb = NULL;
+static disconnect_cb_t disconnect_cb = NULL;
+static void            *probe_arg = NULL;
+static void            *disc_arg = NULL;
+
+#if defined(BCM_REQUEST_FW)
+int8 *nonfwnvram = NULL; /* stand-alone multi-nvram given with driver load */
+int nonfwnvramlen = 0;
+#endif /* #if defined(BCM_REQUEST_FW) */
+
+static void* q_enq(dbus_irbq_t *q, dbus_irb_t *b);
+static void* q_enq_exec(struct exec_parms *args);
+static dbus_irb_t*q_deq(dbus_irbq_t *q);
+static void* q_deq_exec(struct exec_parms *args);
+static int   dbus_tx_timer_init(dbus_info_t *dbus_info);
+static int   dbus_tx_timer_start(dbus_info_t *dbus_info, uint timeout);
+static int   dbus_tx_timer_stop(dbus_info_t *dbus_info);
+static int   dbus_irbq_init(dbus_info_t *dbus_info, dbus_irbq_t *q, int nq, int size_irb);
+static int   dbus_irbq_deinit(dbus_info_t *dbus_info, dbus_irbq_t *q, int size_irb);
+static int   dbus_rxirbs_fill(dbus_info_t *dbus_info);
+static int   dbus_send_irb(dbus_pub_t *pub, uint8 *buf, int len, void *pkt, void *info);
+static void  dbus_disconnect(void *handle);
+static void *dbus_probe(void *arg, const char *desc, uint32 bustype, uint32 hdrlen);
+
+#if (defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW))
+#if defined(BCM_REQUEST_FW)
+extern char * dngl_firmware;
+extern unsigned int dngl_fwlen;
+#endif  /* #if defined(BCM_REQUEST_FW) */
+static int dbus_get_nvram(dbus_info_t *dbus_info);
+static int dbus_jumbo_nvram(dbus_info_t *dbus_info);
+static int dbus_otp(dbus_info_t *dbus_info, uint16 *boardtype, uint16 *boardrev);
+static int dbus_select_nvram(dbus_info_t *dbus_info, int8 *jumbonvram, int jumbolen,
+uint16 boardtype, uint16 boardrev, int8 **nvram, int *nvram_len);
+#ifndef BCM_REQUEST_FW
+static int dbus_zlib_decomp(dbus_info_t *dbus_info);
+extern void *dbus_zlib_calloc(int num, int size);
+extern void dbus_zlib_free(void *ptr);
+#endif
+#endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
+
+/* function */
+void
+dbus_flowctrl_tx(void *dbi, bool on)
+{
+	dbus_info_t *dbus_info = dbi;
+
+	if (dbus_info == NULL)
+		return;
+
+	DBUSTRACE(("%s on %d\n", __FUNCTION__, on));
+
+	if (dbus_info->txoff == on)
+		return;
+
+	dbus_info->txoff = on;
+
+	if (dbus_info->cbs && dbus_info->cbs->txflowcontrol)
+		dbus_info->cbs->txflowcontrol(dbus_info->cbarg, on);
+}
+
+/**
+ * if lower level DBUS signaled a rx error, more free rx IRBs should be allocated or flow control
+ * should kick in to make more free rx IRBs available.
+ */
+static void
+dbus_if_rxerr_indicate(void *handle, bool on)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+
+	DBUSTRACE(("%s, on %d\n", __FUNCTION__, on));
+
+	if (dbus_info == NULL)
+		return;
+
+	if (dbus_info->txoverride == on)
+		return;
+
+	dbus_info->txoverride = on;	/* flow control */
+
+	if (!on)
+		dbus_rxirbs_fill(dbus_info);
+
+}
+
+/** q_enq()/q_deq() are executed with protection via exec_rxlock()/exec_txlock() */
+static void*
+q_enq(dbus_irbq_t *q, dbus_irb_t *b)
+{
+	ASSERT(q->tail != b);
+	ASSERT(b->next == NULL);
+	b->next = NULL;
+	if (q->tail) {
+		q->tail->next = b;
+		q->tail = b;
+	} else
+		q->head = q->tail = b;
+
+	q->cnt++;
+
+	return b;
+}
+
+static void*
+q_enq_exec(struct exec_parms *args)
+{
+	return q_enq(args->qenq.q, args->qenq.b);
+}
+
+static dbus_irb_t*
+q_deq(dbus_irbq_t *q)
+{
+	dbus_irb_t *b;
+
+	b = q->head;
+	if (b) {
+		q->head = q->head->next;
+		b->next = NULL;
+
+		if (q->head == NULL)
+			q->tail = q->head;
+
+		q->cnt--;
+	}
+	return b;
+}
+
+static void*
+q_deq_exec(struct exec_parms *args)
+{
+	return q_deq(args->qdeq.q);
+}
+
+/**
+ * called during attach phase. Status @ Dec 2012: this function does nothing since for all of the
+ * lower DBUS levels dbus_info->drvintf->tx_timer_init is NULL.
+ */
+static int
+dbus_tx_timer_init(dbus_info_t *dbus_info)
+{
+	if (dbus_info && dbus_info->drvintf && dbus_info->drvintf->tx_timer_init)
+		return dbus_info->drvintf->tx_timer_init(dbus_info->bus_info);
+	else
+		return DBUS_ERR;
+}
+
+static int
+dbus_tx_timer_start(dbus_info_t *dbus_info, uint timeout)
+{
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (dbus_info->tx_timer_ticking)
+		return DBUS_OK;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->tx_timer_start) {
+		if (dbus_info->drvintf->tx_timer_start(dbus_info->bus_info, timeout) == DBUS_OK) {
+			dbus_info->tx_timer_ticking = TRUE;
+			return DBUS_OK;
+		}
+	}
+
+	return DBUS_ERR;
+}
+
+static int
+dbus_tx_timer_stop(dbus_info_t *dbus_info)
+{
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (!dbus_info->tx_timer_ticking)
+		return DBUS_OK;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->tx_timer_stop) {
+		if (dbus_info->drvintf->tx_timer_stop(dbus_info->bus_info) == DBUS_OK) {
+			dbus_info->tx_timer_ticking = FALSE;
+			return DBUS_OK;
+		}
+	}
+
+	return DBUS_ERR;
+}
+
+/** called during attach phase. */
+static int
+dbus_irbq_init(dbus_info_t *dbus_info, dbus_irbq_t *q, int nq, int size_irb)
+{
+	int i;
+	dbus_irb_t *irb;
+
+	ASSERT(q);
+	ASSERT(dbus_info);
+
+	for (i = 0; i < nq; i++) {
+		/* MALLOC dbus_irb_tx or dbus_irb_rx, but cast to simple dbus_irb_t linkedlist */
+		irb = (dbus_irb_t *) MALLOC(dbus_info->pub.osh, size_irb);
+		if (irb == NULL) {
+			ASSERT(irb);
+			return DBUS_ERR;
+		}
+		bzero(irb, size_irb);
+
+		/* q_enq() does not need to go through EXEC_xxLOCK() during init() */
+		q_enq(q, irb);
+	}
+
+	return DBUS_OK;
+}
+
+/** called during detach phase or when attach failed */
+static int
+dbus_irbq_deinit(dbus_info_t *dbus_info, dbus_irbq_t *q, int size_irb)
+{
+	dbus_irb_t *irb;
+
+	ASSERT(q);
+	ASSERT(dbus_info);
+
+	/* q_deq() does not need to go through EXEC_xxLOCK()
+	 * during deinit(); all callbacks are stopped by this time
+	 */
+	while ((irb = q_deq(q)) != NULL) {
+		MFREE(dbus_info->pub.osh, irb, size_irb);
+	}
+
+	if (q->cnt)
+		DBUSERR(("deinit: q->cnt=%d > 0\n", q->cnt));
+	return DBUS_OK;
+}
+
+/** multiple code paths require the rx queue to be filled with more free IRBs */
+static int
+dbus_rxirbs_fill(dbus_info_t *dbus_info)
+{
+	int err = DBUS_OK;
+
+#ifdef EHCI_FASTPATH_RX
+	while (atomic_read(&dbus_info->rx_outstanding) < 100)
+	{
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+		/* NOCOPY force new packet allocation */
+		optimize_submit_rx_request(&dbus_info->pub, 1, NULL, NULL);
+#else
+		/* Copy mode - allocate own buffer to be reused */
+		void *buf = MALLOC(dbus_info->pub.osh, 4000); /* usbos_info->rxbuf_len */
+		optimize_submit_rx_request(&dbus_info->pub, 1, NULL, buf);
+#endif /* BCM_RPC_NOCOPY || BCM_RPC_RXNOCOPY */
+		atomic_inc(&dbus_info->rx_outstanding);
+	}
+#else /* EHCI_FASTPATH_RX */
+
+	dbus_irb_rx_t *rxirb;
+	struct exec_parms args;
+
+	ASSERT(dbus_info);
+	if (dbus_info->pub.busstate != DBUS_STATE_UP) {
+		DBUSERR(("dbus_rxirbs_fill: DBUS not up \n"));
+		return DBUS_ERR;
+	} else if (!dbus_info->drvintf || (dbus_info->drvintf->recv_irb == NULL)) {
+		/* Lower edge bus interface does not support recv_irb().
+		 * No need to pre-submit IRBs in this case.
+		 */
+		return DBUS_ERR;
+	}
+
+	/* The dongle recv callback is freerunning without lock. So multiple callbacks(and this
+	 *  refill) can run in parallel. While the rxoff condition is triggered outside,
+	 *  below while loop has to check and abort posting more to avoid RPC rxq overflow.
+	 */
+	args.qdeq.q = dbus_info->rx_q;
+	while ((!dbus_info->rxoff) &&
+	       (rxirb = (EXEC_RXLOCK(dbus_info, q_deq_exec, &args))) != NULL) {
+		err = dbus_info->drvintf->recv_irb(dbus_info->bus_info, rxirb);
+		if (err == DBUS_ERR_RXDROP || err == DBUS_ERR_RXFAIL) {
+			/* Add the the free rxirb back to the queue
+			 * and wait till later
+			 */
+			bzero(rxirb, sizeof(dbus_irb_rx_t));
+			args.qenq.q = dbus_info->rx_q;
+			args.qenq.b = (dbus_irb_t *) rxirb;
+			EXEC_RXLOCK(dbus_info, q_enq_exec, &args);
+			break;
+		} else if (err != DBUS_OK) {
+			int i = 0;
+			while (i++ < 100) {
+				DBUSERR(("%s :: memory leak for rxirb note?\n", __FUNCTION__));
+			}
+		}
+	}
+#endif /* EHCI_FASTPATH_RX */
+	return err;
+} /* dbus_rxirbs_fill */
+
+/** called when the DBUS interface state changed. */
+void
+dbus_flowctrl_rx(dbus_pub_t *pub, bool on)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	if (dbus_info == NULL)
+		return;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info->rxoff == on)
+		return;
+
+	dbus_info->rxoff = on;
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP) {
+		if (!on) {
+			/* post more irbs, resume rx if necessary */
+			dbus_rxirbs_fill(dbus_info);
+			if (dbus_info && dbus_info->drvintf->recv_resume) {
+				dbus_info->drvintf->recv_resume(dbus_info->bus_info);
+			}
+		} else {
+			/* ??? cancell posted irbs first */
+
+			if (dbus_info && dbus_info->drvintf->recv_stop) {
+				dbus_info->drvintf->recv_stop(dbus_info->bus_info);
+			}
+		}
+	}
+}
+
+/**
+ * Several code paths in this file want to send a buffer to the dongle. This function handles both
+ * sending of a buffer or a pkt.
+ */
+static int
+dbus_send_irb(dbus_pub_t *pub, uint8 *buf, int len, void *pkt, void *info)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_OK;
+#ifndef EHCI_FASTPATH_TX
+	dbus_irb_tx_t *txirb = NULL;
+	int txirb_pending;
+	struct exec_parms args;
+#endif /* EHCI_FASTPATH_TX */
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP ||
+		dbus_info->pub.busstate == DBUS_STATE_SLEEP) {
+#ifdef EHCI_FASTPATH_TX
+		struct ehci_qtd *qtd;
+		int token = EHCI_QTD_SET_CERR(3);
+		int len;
+
+		ASSERT(buf == NULL); /* Not handled */
+		ASSERT(pkt != NULL);
+
+		qtd = optimize_ehci_qtd_alloc(GFP_KERNEL);
+
+		if (qtd == NULL)
+			return DBUS_ERR;
+
+		len = PKTLEN(pub->osh, pkt);
+
+		len = ROUNDUP(len, sizeof(uint32));
+
+
+		optimize_qtd_fill_with_rpc(pub, 0, qtd, pkt, token, len);
+		err = optimize_submit_async(qtd, 0);
+
+		if (err) {
+			optimize_ehci_qtd_free(qtd);
+			err = DBUS_ERR_TXDROP;
+		}
+
+#else
+		args.qdeq.q = dbus_info->tx_q;
+		if (dbus_info->drvintf)
+			txirb = EXEC_TXLOCK(dbus_info, q_deq_exec, &args);
+
+		if (txirb == NULL) {
+			DBUSERR(("Out of tx dbus_bufs\n"));
+			return DBUS_ERR;
+		}
+
+		if (pkt != NULL) {
+			txirb->pkt = pkt;
+			txirb->buf = NULL;
+			txirb->len = 0;
+		} else if (buf != NULL) {
+			txirb->pkt = NULL;
+			txirb->buf = buf;
+			txirb->len = len;
+		} else {
+			ASSERT(0); /* Should not happen */
+		}
+		txirb->info = info;
+		txirb->arg = NULL;
+		txirb->retry_count = 0;
+
+		if (dbus_info->drvintf && dbus_info->drvintf->send_irb) {
+			/* call lower DBUS level send_irb function */
+			err = dbus_info->drvintf->send_irb(dbus_info->bus_info, txirb);
+			if (err == DBUS_ERR_TXDROP) {
+				/* tx fail and no completion routine to clean up, reclaim irb NOW */
+				DBUSERR(("%s: send_irb failed, status = %d\n", __FUNCTION__, err));
+				bzero(txirb, sizeof(dbus_irb_tx_t));
+				args.qenq.q = dbus_info->tx_q;
+				args.qenq.b = (dbus_irb_t *) txirb;
+				EXEC_TXLOCK(dbus_info, q_enq_exec, &args);
+			} else {
+				dbus_tx_timer_start(dbus_info, DBUS_TX_TIMEOUT_INTERVAL);
+				txirb_pending = dbus_info->pub.ntxq - dbus_info->tx_q->cnt;
+				if (txirb_pending > (dbus_info->tx_low_watermark * 3)) {
+					dbus_flowctrl_tx(dbus_info, TRUE);
+				}
+			}
+		}
+#endif /* EHCI_FASTPATH_TX */
+	} else {
+		err = DBUS_ERR_TXFAIL;
+		DBUSTRACE(("%s: bus down, send_irb failed\n", __FUNCTION__));
+	}
+
+	return err;
+} /* dbus_send_irb */
+
+#if (defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW))
+
+/**
+ * Before downloading a firmware image into the dongle, the validity of the image must be checked.
+ */
+static int
+check_file(osl_t *osh, unsigned char *headers)
+{
+	struct trx_header *trx;
+	int actual_len = -1;
+
+	/* Extract trx header */
+	trx = (struct trx_header *)headers;
+	if (ltoh32(trx->magic) != TRX_MAGIC) {
+		printf("Error: trx bad hdr %x\n", ltoh32(trx->magic));
+		return -1;
+	}
+
+	headers += SIZEOF_TRX(trx);
+
+	/* TRX V1: get firmware len */
+	/* TRX V2: get firmware len and DSG/CFG lengths */
+	if (ltoh32(trx->flag_version) & TRX_UNCOMP_IMAGE) {
+		actual_len = ltoh32(trx->offsets[TRX_OFFSETS_DLFWLEN_IDX]) +
+		                     SIZEOF_TRX(trx);
+#ifdef BCMTRXV2
+		if (ISTRX_V2(trx)) {
+			actual_len += ltoh32(trx->offsets[TRX_OFFSETS_DSG_LEN_IDX]) +
+				ltoh32(trx->offsets[TRX_OFFSETS_CFG_LEN_IDX]);
+		}
+#endif
+		return actual_len;
+	}  else {
+		printf("compressed image\n");
+	}
+
+	return -1;
+}
+
+/**
+ * It is easy for the user to pass one jumbo nvram file to the driver than a set of smaller files.
+ * The 'jumbo nvram' file format is essentially a set of nvram files. Before commencing firmware
+ * download, the dongle needs to be probed so that the correct nvram contents within the jumbo nvram
+ * file is selected.
+ */
+static int
+dbus_jumbo_nvram(dbus_info_t *dbus_info)
+{
+	int8 *nvram = NULL;
+	int nvram_len = 0;
+	int ret = DBUS_OK;
+	uint16 boardrev = 0xFFFF;
+	uint16 boardtype = 0xFFFF;
+
+	/* read the otp for boardrev & boardtype
+	* if boardtype/rev are present in otp
+	* select nvram data for that boardtype/rev
+	*/
+	dbus_otp(dbus_info, &boardtype, &boardrev);
+
+	ret = dbus_select_nvram(dbus_info, dbus_info->extdl.vars, dbus_info->extdl.varslen,
+		boardtype, boardrev, &nvram, &nvram_len);
+
+	if (ret == DBUS_JUMBO_BAD_FORMAT)
+			return DBUS_ERR_NVRAM;
+	else if (ret == DBUS_JUMBO_NOMATCH &&
+		(boardtype != 0xFFFF || boardrev  != 0xFFFF)) {
+			DBUSERR(("No matching NVRAM for boardtype 0x%02x boardrev 0x%02x\n",
+				boardtype, boardrev));
+			return DBUS_ERR_NVRAM;
+	}
+	dbus_info->nvram = nvram;
+	dbus_info->nvram_len =  nvram_len;
+
+	return DBUS_OK;
+}
+
+/** before commencing fw download, the correct NVRAM image to download has to be picked */
+static int
+dbus_get_nvram(dbus_info_t *dbus_info)
+{
+	int len, i;
+	struct trx_header *hdr;
+	int	actual_fwlen;
+	uint32 img_offset = 0;
+
+	dbus_info->nvram_len = 0;
+	if (dbus_info->extdl.varslen) {
+		if (DBUS_OK != dbus_jumbo_nvram(dbus_info))
+			return DBUS_ERR_NVRAM;
+		DBUSERR(("NVRAM %d bytes downloaded\n", dbus_info->nvram_len));
+	}
+#if defined(BCM_REQUEST_FW)
+	else if (nonfwnvram) {
+		dbus_info->nvram = nonfwnvram;
+		dbus_info->nvram_len = nonfwnvramlen;
+		DBUSERR(("NVRAM %d bytes downloaded\n", dbus_info->nvram_len));
+	}
+#endif
+	if (dbus_info->nvram) {
+		uint8 nvram_words_pad = 0;
+		/* Validate the format/length etc of the file */
+		if ((actual_fwlen = check_file(dbus_info->pub.osh, dbus_info->fw)) <= 0) {
+			DBUSERR(("%s: bad firmware format!\n", __FUNCTION__));
+			return DBUS_ERR_NVRAM;
+		}
+
+		if (!dbus_info->nvram_nontxt) {
+			/* host supplied nvram could be in .txt format
+			* with all the comments etc...
+			*/
+			dbus_info->nvram_len = process_nvram_vars(dbus_info->nvram,
+				dbus_info->nvram_len);
+		}
+		if (dbus_info->nvram_len % 4)
+			nvram_words_pad = 4 - dbus_info->nvram_len % 4;
+
+		len = actual_fwlen + dbus_info->nvram_len + nvram_words_pad;
+		dbus_info->image = MALLOC(dbus_info->pub.osh, len);
+		dbus_info->image_len = len;
+		if (dbus_info->image == NULL) {
+			DBUSERR(("%s: malloc failed!\n", __FUNCTION__));
+			return DBUS_ERR_NVRAM;
+		}
+		hdr = (struct trx_header *)dbus_info->fw;
+		/* Step1: Copy trx header + firmwre */
+		img_offset = SIZEOF_TRX(hdr) + hdr->offsets[TRX_OFFSETS_DLFWLEN_IDX];
+		bcopy(dbus_info->fw, dbus_info->image, img_offset);
+		/* Step2: Copy NVRAM + pad */
+		bcopy(dbus_info->nvram, (uint8 *)(dbus_info->image + img_offset),
+			dbus_info->nvram_len);
+		img_offset += dbus_info->nvram_len;
+		if (nvram_words_pad) {
+			bzero(&dbus_info->image[img_offset],
+				nvram_words_pad);
+			img_offset += nvram_words_pad;
+		}
+#ifdef BCMTRXV2
+		/* Step3: Copy DSG/CFG for V2 */
+		if (ISTRX_V2(hdr) &&
+			(hdr->offsets[TRX_OFFSETS_DSG_LEN_IDX] ||
+			hdr->offsets[TRX_OFFSETS_CFG_LEN_IDX])) {
+
+			bcopy(dbus_info->fw + SIZEOF_TRX(hdr) +
+				hdr->offsets[TRX_OFFSETS_DLFWLEN_IDX] +
+				hdr->offsets[TRX_OFFSETS_NVM_LEN_IDX],
+				dbus_info->image + img_offset,
+				hdr->offsets[TRX_OFFSETS_DSG_LEN_IDX] +
+				hdr->offsets[TRX_OFFSETS_CFG_LEN_IDX]);
+
+			img_offset += hdr->offsets[TRX_OFFSETS_DSG_LEN_IDX] +
+				hdr->offsets[TRX_OFFSETS_CFG_LEN_IDX];
+		}
+#endif /* BCMTRXV2 */
+		/* Step4: update TRX header for nvram size */
+		hdr = (struct trx_header *)dbus_info->image;
+		hdr->len = htol32(len);
+		/* Pass the actual fw len */
+		hdr->offsets[TRX_OFFSETS_NVM_LEN_IDX] =
+			htol32(dbus_info->nvram_len + nvram_words_pad);
+		/* Calculate CRC over header */
+		hdr->crc32 = hndcrc32((uint8 *)&hdr->flag_version,
+			SIZEOF_TRX(hdr) - OFFSETOF(struct trx_header, flag_version),
+			CRC32_INIT_VALUE);
+
+		/* Calculate CRC over data */
+		for (i = SIZEOF_TRX(hdr); i < len; ++i)
+				hdr->crc32 = hndcrc32((uint8 *)&dbus_info->image[i], 1, hdr->crc32);
+		hdr->crc32 = htol32(hdr->crc32);
+	} else {
+		dbus_info->image = dbus_info->fw;
+		dbus_info->image_len = (uint32)dbus_info->fwlen;
+	}
+
+	return DBUS_OK;
+} /* dbus_get_nvram */
+
+/**
+ * during driver initialization ('attach') or after PnP 'resume', firmware needs to be loaded into
+ * the dongle
+ */
+static int
+dbus_do_download(dbus_info_t *dbus_info)
+{
+	int err = DBUS_OK;
+#ifndef BCM_REQUEST_FW
+	int decomp_override = 0;
+#endif
+#ifdef BCM_REQUEST_FW
+	uint16 boardrev = 0xFFFF, boardtype = 0xFFFF;
+	int8 *temp_nvram;
+	int temp_len;
+#endif
+
+#if defined(BCM_DNGL_EMBEDIMAGE)
+	if (dbus_info->extdl.fw && (dbus_info->extdl.fwlen > 0)) {
+		dbus_info->fw = (uint8 *)dbus_info->extdl.fw;
+		dbus_info->fwlen = dbus_info->extdl.fwlen;
+		DBUSERR(("dbus_do_download: using override firmmware %d bytes\n",
+			dbus_info->fwlen));
+	} else
+		dbus_bus_fw_get(dbus_info->bus_info, &dbus_info->fw, &dbus_info->fwlen,
+			&decomp_override);
+
+	if (!dbus_info->fw) {
+		DBUSERR(("dbus_do_download: devid 0x%x / %d not supported\n",
+			dbus_info->pub.attrib.devid, dbus_info->pub.attrib.devid));
+		return DBUS_ERR;
+	}
+#elif defined(BCM_REQUEST_FW)
+	dbus_info->firmware = dbus_get_fw_nvfile(dbus_info->pub.attrib.devid,
+		dbus_info->pub.attrib.chiprev, &dbus_info->fw, &dbus_info->fwlen,
+		DBUS_FIRMWARE, 0, 0);
+	if (!dbus_info->firmware)
+		return DBUS_ERR;
+#endif /* defined(BCM_DNGL_EMBEDIMAGE) */
+
+	dbus_info->image = dbus_info->fw;
+	dbus_info->image_len = (uint32)dbus_info->fwlen;
+
+#ifndef BCM_REQUEST_FW
+	if (UNZIP_ENAB(dbus_info) && !decomp_override) {
+		err = dbus_zlib_decomp(dbus_info);
+		if (err) {
+			DBUSERR(("dbus_attach: fw decompress fail %d\n", err));
+			return err;
+		}
+	}
+#endif
+
+#if defined(BCM_REQUEST_FW)
+	/* check if firmware is appended with nvram file */
+	err = dbus_otp(dbus_info, &boardtype, &boardrev);
+	/* check if nvram is provided as separte file */
+	nonfwnvram = NULL;
+	nonfwnvramlen = 0;
+	dbus_info->nvfile = dbus_get_fw_nvfile(dbus_info->pub.attrib.devid,
+		dbus_info->pub.attrib.chiprev, (void *)&temp_nvram, &temp_len,
+		DBUS_NVFILE, boardtype, boardrev);
+	if (dbus_info->nvfile) {
+		int8 *tmp = MALLOC(dbus_info->pub.osh, temp_len);
+		if (tmp) {
+			bcopy(temp_nvram, tmp, temp_len);
+			nonfwnvram = tmp;
+			nonfwnvramlen = temp_len;
+		} else {
+			err = DBUS_ERR;
+			goto fail;
+		}
+	}
+#endif /* defined(BCM_REQUEST_FW) */
+
+	err = dbus_get_nvram(dbus_info);
+	if (err) {
+		DBUSERR(("dbus_do_download: fail to get nvram %d\n", err));
+		return err;
+	}
+
+
+	if (dbus_info->drvintf->dlstart && dbus_info->drvintf->dlrun) {
+		err = dbus_info->drvintf->dlstart(dbus_info->bus_info,
+			dbus_info->image, dbus_info->image_len);
+
+		if (err == DBUS_OK)
+			err = dbus_info->drvintf->dlrun(dbus_info->bus_info);
+	} else
+		err = DBUS_ERR;
+
+	if (dbus_info->nvram) {
+		MFREE(dbus_info->pub.osh, dbus_info->image, dbus_info->image_len);
+		dbus_info->image = dbus_info->fw;
+		dbus_info->image_len = (uint32)dbus_info->fwlen;
+	}
+
+#ifndef BCM_REQUEST_FW
+	if (UNZIP_ENAB(dbus_info) && (!decomp_override) && dbus_info->orig_fw) {
+		MFREE(dbus_info->pub.osh, dbus_info->fw, dbus_info->decomp_memsize);
+		dbus_info->image = dbus_info->fw = dbus_info->orig_fw;
+		dbus_info->image_len = dbus_info->fwlen = dbus_info->origfw_len;
+	}
+#endif
+
+#if defined(BCM_REQUEST_FW)
+fail:
+	if (dbus_info->firmware) {
+		dbus_release_fw_nvfile(dbus_info->firmware);
+		dbus_info->firmware = NULL;
+	}
+	if (dbus_info->nvfile) {
+		dbus_release_fw_nvfile(dbus_info->nvfile);
+		dbus_info->nvfile = NULL;
+	}
+	if (nonfwnvram) {
+		MFREE(dbus_info->pub.osh, nonfwnvram, nonfwnvramlen);
+		nonfwnvram = NULL;
+		nonfwnvramlen = 0;
+	}
+#endif
+	return err;
+} /* dbus_do_download */
+
+#endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
+
+/** required for DBUS deregistration */
+static void
+dbus_disconnect(void *handle)
+{
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (disconnect_cb)
+		disconnect_cb(disc_arg);
+}
+
+/**
+ * This function is called when the sent irb times out without a tx response status.
+ * DBUS adds reliability by resending timed out IRBs DBUS_TX_RETRY_LIMIT times.
+ */
+static void
+dbus_if_send_irb_timeout(void *handle, dbus_irb_tx_t *txirb)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+
+	if ((dbus_info == NULL) || (dbus_info->drvintf == NULL) || (txirb == NULL)) {
+		return;
+	}
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	return;
+
+} /* dbus_if_send_irb_timeout */
+
+/**
+ * When lower DBUS level signals that a send IRB completed, either successful or not, the higher
+ * level (e.g. dhd_linux.c) has to be notified, and transmit flow control has to be evaluated.
+ */
+static void BCMFASTPATH
+dbus_if_send_irb_complete(void *handle, dbus_irb_tx_t *txirb, int status)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+	int txirb_pending;
+	struct exec_parms args;
+	void *pktinfo;
+
+	if ((dbus_info == NULL) || (txirb == NULL)) {
+		return;
+	}
+
+	DBUSTRACE(("%s: status = %d\n", __FUNCTION__, status));
+
+	dbus_tx_timer_stop(dbus_info);
+
+	/* re-queue BEFORE calling send_complete which will assume that this irb
+	   is now available.
+	 */
+	pktinfo = txirb->info;
+	bzero(txirb, sizeof(dbus_irb_tx_t));
+	args.qenq.q = dbus_info->tx_q;
+	args.qenq.b = (dbus_irb_t *) txirb;
+	EXEC_TXLOCK(dbus_info, q_enq_exec, &args);
+
+	if (dbus_info->pub.busstate != DBUS_STATE_DOWN) {
+		if ((status == DBUS_OK) || (status == DBUS_ERR_NODEVICE)) {
+			if (dbus_info->cbs && dbus_info->cbs->send_complete)
+				dbus_info->cbs->send_complete(dbus_info->cbarg, pktinfo,
+					status);
+
+			if (status == DBUS_OK) {
+				txirb_pending = dbus_info->pub.ntxq - dbus_info->tx_q->cnt;
+				if (txirb_pending)
+					dbus_tx_timer_start(dbus_info, DBUS_TX_TIMEOUT_INTERVAL);
+				if ((txirb_pending < dbus_info->tx_low_watermark) &&
+					dbus_info->txoff && !dbus_info->txoverride) {
+					dbus_flowctrl_tx(dbus_info, OFF);
+				}
+			}
+		} else {
+			DBUSERR(("%s: %d WARNING freeing orphan pkt %p\n", __FUNCTION__, __LINE__,
+				pktinfo));
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_TXNOCOPY) || defined(BCM_RPC_TOC)
+			if (pktinfo)
+				if (dbus_info->cbs && dbus_info->cbs->send_complete)
+					dbus_info->cbs->send_complete(dbus_info->cbarg, pktinfo,
+						status);
+#else
+			dbus_if_pktfree(dbus_info, (void*)pktinfo, TRUE);
+#endif /* defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_TXNOCOPY) || defined(BCM_RPC_TOC) */
+		}
+	} else {
+		DBUSERR(("%s: %d WARNING freeing orphan pkt %p\n", __FUNCTION__, __LINE__,
+			pktinfo));
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_TXNOCOPY) || defined(BCM_RPC_TOC)
+		if (pktinfo)
+			if (dbus_info->cbs && dbus_info->cbs->send_complete)
+				dbus_info->cbs->send_complete(dbus_info->cbarg, pktinfo,
+					status);
+#else
+		dbus_if_pktfree(dbus_info, (void*)pktinfo, TRUE);
+#endif /* defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_TXNOCOPY) defined(BCM_RPC_TOC) */
+	}
+} /* dbus_if_send_irb_complete */
+
+/**
+ * When lower DBUS level signals that a receive IRB completed, either successful or not, the higher
+ * level (e.g. dhd_linux.c) has to be notified, and fresh free receive IRBs may have to be given
+ * to lower levels.
+ */
+static void BCMFASTPATH
+dbus_if_recv_irb_complete(void *handle, dbus_irb_rx_t *rxirb, int status)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+	int rxirb_pending;
+	struct exec_parms args;
+
+	if ((dbus_info == NULL) || (rxirb == NULL)) {
+		return;
+	}
+	DBUSTRACE(("%s\n", __FUNCTION__));
+	if (dbus_info->pub.busstate != DBUS_STATE_DOWN &&
+		dbus_info->pub.busstate != DBUS_STATE_SLEEP) {
+		if (status == DBUS_OK) {
+			if ((rxirb->buf != NULL) && (rxirb->actual_len > 0)) {
+#ifdef DBUS_USB_LOOPBACK
+				if (is_loopback_pkt(rxirb->buf)) {
+					matches_loopback_pkt(rxirb->buf);
+				} else
+#endif
+				if (dbus_info->cbs && dbus_info->cbs->recv_buf) {
+					dbus_info->cbs->recv_buf(dbus_info->cbarg, rxirb->buf,
+					rxirb->actual_len);
+				}
+			} else if (rxirb->pkt != NULL) {
+				if (dbus_info->cbs && dbus_info->cbs->recv_pkt)
+					dbus_info->cbs->recv_pkt(dbus_info->cbarg, rxirb->pkt);
+			} else {
+				ASSERT(0); /* Should not happen */
+			}
+
+			rxirb_pending = dbus_info->pub.nrxq - dbus_info->rx_q->cnt - 1;
+			if ((rxirb_pending <= dbus_info->rx_low_watermark) &&
+				!dbus_info->rxoff) {
+				DBUSTRACE(("Low watermark so submit more %d <= %d \n",
+					dbus_info->rx_low_watermark, rxirb_pending));
+				dbus_rxirbs_fill(dbus_info);
+			} else if (dbus_info->rxoff)
+				DBUSTRACE(("rx flow controlled. not filling more. cut_rxq=%d\n",
+					dbus_info->rx_q->cnt));
+		} else if (status == DBUS_ERR_NODEVICE) {
+			DBUSERR(("%s: %d status = %d, buf %p\n", __FUNCTION__, __LINE__, status,
+				rxirb->buf));
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+			if (rxirb->buf) {
+				PKTFRMNATIVE(dbus_info->pub.osh, rxirb->buf);
+				PKTFREE(dbus_info->pub.osh, rxirb->buf, FALSE);
+			}
+#endif /* BCM_RPC_NOCOPY || BCM_RPC_TXNOCOPY || BCM_RPC_TOC */
+		} else {
+			if (status != DBUS_ERR_RXZLP)
+				DBUSERR(("%s: %d status = %d, buf %p\n", __FUNCTION__, __LINE__,
+					status, rxirb->buf));
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+			if (rxirb->buf) {
+				PKTFRMNATIVE(dbus_info->pub.osh, rxirb->buf);
+				PKTFREE(dbus_info->pub.osh, rxirb->buf, FALSE);
+			}
+#endif /* BCM_RPC_NOCOPY || BCM_RPC_TXNOCOPY || BCM_RPC_TOC */
+		}
+	} else {
+		DBUSTRACE(("%s: DBUS down, ignoring recv callback. buf %p\n", __FUNCTION__,
+			rxirb->buf));
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+		if (rxirb->buf) {
+			PKTFRMNATIVE(dbus_info->pub.osh, rxirb->buf);
+			PKTFREE(dbus_info->pub.osh, rxirb->buf, FALSE);
+		}
+#endif /* BCM_RPC_NOCOPY || BCM_RPC_TXNOCOPY || BCM_RPC_TOC */
+	}
+	if (dbus_info->rx_q != NULL) {
+		bzero(rxirb, sizeof(dbus_irb_rx_t));
+		args.qenq.q = dbus_info->rx_q;
+		args.qenq.b = (dbus_irb_t *) rxirb;
+		EXEC_RXLOCK(dbus_info, q_enq_exec, &args);
+	} else
+		MFREE(dbus_info->pub.osh, rxirb, sizeof(dbus_irb_tx_t));
+} /* dbus_if_recv_irb_complete */
+
+/**
+ *  Accumulate errors signaled by lower DBUS levels and signal them to higher (e.g. dhd_linux.c)
+ *  level.
+ */
+static void
+dbus_if_errhandler(void *handle, int err)
+{
+	dbus_info_t *dbus_info = handle;
+	uint32 mask = 0;
+
+	if (dbus_info == NULL)
+		return;
+
+	switch (err) {
+		case DBUS_ERR_TXFAIL:
+			dbus_info->pub.stats.tx_errors++;
+			mask |= ERR_CBMASK_TXFAIL;
+			break;
+		case DBUS_ERR_TXDROP:
+			dbus_info->pub.stats.tx_dropped++;
+			mask |= ERR_CBMASK_TXFAIL;
+			break;
+		case DBUS_ERR_RXFAIL:
+			dbus_info->pub.stats.rx_errors++;
+			mask |= ERR_CBMASK_RXFAIL;
+			break;
+		case DBUS_ERR_RXDROP:
+			dbus_info->pub.stats.rx_dropped++;
+			mask |= ERR_CBMASK_RXFAIL;
+			break;
+		default:
+			break;
+	}
+
+	if (dbus_info->cbs && dbus_info->cbs->errhandler && (dbus_info->errmask & mask))
+		dbus_info->cbs->errhandler(dbus_info->cbarg, err);
+}
+
+/**
+ * When lower DBUS level signals control IRB completed, higher level (e.g. dhd_linux.c) has to be
+ * notified.
+ */
+static void
+dbus_if_ctl_complete(void *handle, int type, int status)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+
+	if (dbus_info == NULL)
+		return;
+
+	if (dbus_info->pub.busstate != DBUS_STATE_DOWN) {
+		if (dbus_info->cbs && dbus_info->cbs->ctl_complete)
+			dbus_info->cbs->ctl_complete(dbus_info->cbarg, type, status);
+	}
+}
+
+/**
+ * Rx related functionality (flow control, posting of free IRBs to rx queue) is dependent upon the
+ * bus state. When lower DBUS level signals a change in the interface state, take appropriate action
+ * and forward the signaling to the higher (e.g. dhd_linux.c) level.
+ */
+static void
+dbus_if_state_change(void *handle, int state)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+	int old_state;
+
+	if (dbus_info == NULL)
+		return;
+
+	if (dbus_info->pub.busstate == state)
+		return;
+	old_state = dbus_info->pub.busstate;
+	if (state == DBUS_STATE_DISCONNECT) {
+		DBUSERR(("DBUS disconnected\n"));
+	}
+
+	/* Ignore USB SUSPEND while not up yet */
+	if (state == DBUS_STATE_SLEEP && old_state != DBUS_STATE_UP)
+		return;
+
+	DBUSTRACE(("dbus state change from %d to to %d\n", old_state, state));
+
+	/* Don't update state if it's PnP firmware re-download */
+	if (state != DBUS_STATE_PNP_FWDL)
+		dbus_info->pub.busstate = state;
+	else
+		dbus_flowctrl_rx(handle, FALSE);
+	if (state == DBUS_STATE_SLEEP)
+		dbus_flowctrl_rx(handle, TRUE);
+	if (state == DBUS_STATE_UP) {
+		dbus_rxirbs_fill(dbus_info);
+		dbus_flowctrl_rx(handle, FALSE);
+	}
+
+	if (dbus_info->cbs && dbus_info->cbs->state_change)
+		dbus_info->cbs->state_change(dbus_info->cbarg, state);
+}
+
+/** Forward request for packet from lower DBUS layer to higher layer (e.g. dhd_linux.c) */
+static void *
+dbus_if_pktget(void *handle, uint len, bool send)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+	void *p = NULL;
+
+	if (dbus_info == NULL)
+		return NULL;
+
+	if (dbus_info->cbs && dbus_info->cbs->pktget)
+		p = dbus_info->cbs->pktget(dbus_info->cbarg, len, send);
+	else
+		ASSERT(0);
+
+	return p;
+}
+
+/** Forward request to free packet from lower DBUS layer to higher layer (e.g. dhd_linux.c) */
+static void
+dbus_if_pktfree(void *handle, void *p, bool send)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) handle;
+
+	if (dbus_info == NULL)
+		return;
+
+	if (dbus_info->cbs && dbus_info->cbs->pktfree)
+		dbus_info->cbs->pktfree(dbus_info->cbarg, p, send);
+	else
+		ASSERT(0);
+}
+
+/** Lower DBUS level requests either a send or receive IRB */
+static struct dbus_irb*
+dbus_if_getirb(void *cbarg, bool send)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) cbarg;
+	struct exec_parms args;
+	struct dbus_irb *irb;
+
+	if ((dbus_info == NULL) || (dbus_info->pub.busstate != DBUS_STATE_UP))
+		return NULL;
+
+	if (send == TRUE) {
+		args.qdeq.q = dbus_info->tx_q;
+		irb = EXEC_TXLOCK(dbus_info, q_deq_exec, &args);
+	} else {
+		args.qdeq.q = dbus_info->rx_q;
+		irb = EXEC_RXLOCK(dbus_info, q_deq_exec, &args);
+	}
+
+	return irb;
+}
+
+/**
+ * Called as part of DBUS bus registration. Calls back into higher level (e.g. dhd_linux.c) probe
+ * function.
+ */
+static void *
+dbus_probe(void *arg, const char *desc, uint32 bustype, uint32 hdrlen)
+{
+	if (probe_cb) {
+		disc_arg = probe_cb(probe_arg, desc, bustype, hdrlen);
+		return disc_arg;
+	}
+
+	return (void *)DBUS_ERR;
+}
+
+/**
+ * As part of initialization, higher level (e.g. dhd_linux.c) requests DBUS to prepare for
+ * action.
+ */
+int
+dbus_register(int vid, int pid, probe_cb_t prcb,
+	disconnect_cb_t discb, void *prarg, void *param1, void *param2)
+{
+	int err;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	probe_cb = prcb;
+	disconnect_cb = discb;
+	probe_arg = prarg;
+
+	err = dbus_bus_register(vid, pid, dbus_probe, /* call lower DBUS level register function */
+		dbus_disconnect, NULL, &g_busintf, param1, param2);
+
+	return err;
+}
+
+int
+dbus_deregister()
+{
+	int ret;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	probe_cb = NULL;
+	ret = dbus_bus_deregister();
+	disconnect_cb = NULL;
+	probe_arg = NULL;
+
+	return ret;
+
+}
+
+/** As part of initialization, data structures have to be allocated and initialized */
+dbus_pub_t *
+dbus_attach(osl_t *osh, int rxsize, int nrxq, int ntxq, void *cbarg,
+	dbus_callbacks_t *cbs, dbus_extdl_t *extdl, struct shared_info *sh)
+{
+	dbus_info_t *dbus_info;
+	int err;
+
+	if ((g_busintf == NULL) || (g_busintf->attach == NULL) || (cbs == NULL))
+		return NULL;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if ((nrxq <= 0) || (ntxq <= 0))
+		return NULL;
+
+	dbus_info = MALLOC(osh, sizeof(dbus_info_t));
+	if (dbus_info == NULL)
+		return NULL;
+
+	bzero(dbus_info, sizeof(dbus_info_t));
+
+	/* BUS-specific driver interface (at a lower DBUS level) */
+	dbus_info->drvintf = g_busintf;
+	dbus_info->cbarg = cbarg;
+	dbus_info->cbs = cbs;
+
+	dbus_info->pub.sh = sh;
+	dbus_info->pub.osh = osh;
+	dbus_info->pub.rxsize = rxsize;
+
+#ifdef EHCI_FASTPATH_RX
+	atomic_set(&dbus_info->rx_outstanding, 0);
+#endif
+
+	dbus_info->pub.nrxq = nrxq;
+	dbus_info->rx_low_watermark = nrxq / 2;	/* keep enough posted rx urbs */
+	dbus_info->pub.ntxq = ntxq;
+	dbus_info->tx_low_watermark = ntxq / 4;	/* flow control when too many tx urbs posted */
+
+	dbus_info->tx_q = MALLOC(osh, sizeof(dbus_irbq_t));
+	if (dbus_info->tx_q == NULL)
+		goto error;
+	else {
+		bzero(dbus_info->tx_q, sizeof(dbus_irbq_t));
+		err = dbus_irbq_init(dbus_info, dbus_info->tx_q, ntxq, sizeof(dbus_irb_tx_t));
+		if (err != DBUS_OK)
+			goto error;
+	}
+
+	dbus_info->rx_q = MALLOC(osh, sizeof(dbus_irbq_t));
+	if (dbus_info->rx_q == NULL)
+		goto error;
+	else {
+		bzero(dbus_info->rx_q, sizeof(dbus_irbq_t));
+		err = dbus_irbq_init(dbus_info, dbus_info->rx_q, nrxq, sizeof(dbus_irb_rx_t));
+		if (err != DBUS_OK)
+			goto error;
+	}
+
+
+	dbus_info->bus_info = (void *)g_busintf->attach(&dbus_info->pub,
+		dbus_info, &dbus_intf_cbs);
+	if (dbus_info->bus_info == NULL)
+		goto error;
+
+	dbus_tx_timer_init(dbus_info);
+
+#if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+	/* Need to copy external image for re-download */
+	if (extdl && extdl->fw && (extdl->fwlen > 0)) {
+		dbus_info->extdl.fw = MALLOC(osh, extdl->fwlen);
+		if (dbus_info->extdl.fw) {
+			bcopy(extdl->fw, dbus_info->extdl.fw, extdl->fwlen);
+			dbus_info->extdl.fwlen = extdl->fwlen;
+		}
+	}
+
+	if (extdl && extdl->vars && (extdl->varslen > 0)) {
+		dbus_info->extdl.vars = MALLOC(osh, extdl->varslen);
+		if (dbus_info->extdl.vars) {
+			bcopy(extdl->vars, dbus_info->extdl.vars, extdl->varslen);
+			dbus_info->extdl.varslen = extdl->varslen;
+		}
+	}
+
+	if (dbus_download_firmware(&dbus_info->pub) != DBUS_OK)
+		goto error;
+#endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
+
+	return (dbus_pub_t *)dbus_info;
+
+error:
+	dbus_detach((dbus_pub_t *)dbus_info);
+	return NULL;
+} /* dbus_attach */
+
+void
+dbus_detach(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	osl_t *osh;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return;
+
+	dbus_tx_timer_stop(dbus_info);
+
+	osh = pub->osh;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->detach)
+		 dbus_info->drvintf->detach((dbus_pub_t *)dbus_info, dbus_info->bus_info);
+
+	if (dbus_info->tx_q) {
+		dbus_irbq_deinit(dbus_info, dbus_info->tx_q, sizeof(dbus_irb_tx_t));
+		MFREE(osh, dbus_info->tx_q, sizeof(dbus_irbq_t));
+		dbus_info->tx_q = NULL;
+	}
+
+	if (dbus_info->rx_q) {
+		dbus_irbq_deinit(dbus_info, dbus_info->rx_q, sizeof(dbus_irb_rx_t));
+		MFREE(osh, dbus_info->rx_q, sizeof(dbus_irbq_t));
+		dbus_info->rx_q = NULL;
+	}
+
+
+	if (dbus_info->extdl.fw && (dbus_info->extdl.fwlen > 0)) {
+		MFREE(osh, dbus_info->extdl.fw, dbus_info->extdl.fwlen);
+		dbus_info->extdl.fw = NULL;
+		dbus_info->extdl.fwlen = 0;
+	}
+
+	if (dbus_info->extdl.vars && (dbus_info->extdl.varslen > 0)) {
+		MFREE(osh, dbus_info->extdl.vars, dbus_info->extdl.varslen);
+		dbus_info->extdl.vars = NULL;
+		dbus_info->extdl.varslen = 0;
+	}
+
+	MFREE(osh, dbus_info, sizeof(dbus_info_t));
+} /* dbus_detach */
+
+#if (defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW))
+
+int dbus_download_firmware(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_OK;
+
+	DBUSTRACE(("%s: state %d\n", __FUNCTION__, dbus_info->pub.busstate));
+
+	if (dbus_info->drvintf->dlneeded) {
+		if (dbus_info->drvintf->dlneeded(dbus_info->bus_info)) {
+			dbus_info->pub.busstate = DBUS_STATE_DL_PENDING;
+			err = dbus_do_download(dbus_info);
+			if (err == DBUS_OK) {
+				dbus_info->pub.busstate = DBUS_STATE_DL_DONE;
+			} else {
+				DBUSERR(("%s: download failed (%d)\n", __FUNCTION__, err));
+			}
+		}
+	}
+
+	return err;
+}
+
+#endif /* BCM_DNGL_EMBEDIMAGE || BCM_REQUEST_FW */
+
+/**
+ * higher layer requests us to 'up' the interface to the dongle. Prerequisite is that firmware (not
+ * bootloader) must be active in the dongle.
+ */
+int
+dbus_up(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_OK;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if ((dbus_info->pub.busstate == DBUS_STATE_DL_DONE) ||
+		(dbus_info->pub.busstate == DBUS_STATE_DOWN) ||
+		(dbus_info->pub.busstate == DBUS_STATE_SLEEP)) {
+		if (dbus_info->drvintf && dbus_info->drvintf->up) {
+			err = dbus_info->drvintf->up(dbus_info->bus_info);
+
+			if (err == DBUS_OK) {
+				dbus_rxirbs_fill(dbus_info);
+			}
+		}
+	} else
+		err = DBUS_ERR;
+
+	return err;
+}
+
+/** higher layer requests us to 'down' the interface to the dongle. */
+int
+dbus_down(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	dbus_tx_timer_stop(dbus_info);
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP ||
+		dbus_info->pub.busstate == DBUS_STATE_SLEEP) {
+		if (dbus_info->drvintf && dbus_info->drvintf->down)
+			return dbus_info->drvintf->down(dbus_info->bus_info);
+	}
+
+	return DBUS_ERR;
+}
+
+int
+dbus_shutdown(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->shutdown)
+		return dbus_info->drvintf->shutdown(dbus_info->bus_info);
+
+	return DBUS_OK;
+}
+
+int
+dbus_stop(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP ||
+		dbus_info->pub.busstate == DBUS_STATE_SLEEP) {
+		if (dbus_info->drvintf && dbus_info->drvintf->stop)
+			return dbus_info->drvintf->stop(dbus_info->bus_info);
+	}
+
+	return DBUS_ERR;
+}
+
+int dbus_send_txdata(dbus_pub_t *dbus, void *pktbuf)
+{
+#ifdef BCMSDIO
+	return dbus_send_pkt(dbus, pktbuf, NULL /* pktinfo */);
+#else
+	return dbus_send_pkt(dbus, pktbuf, pktbuf /* pktinfo */);
+#endif
+}
+
+int
+dbus_send_buf(dbus_pub_t *pub, uint8 *buf, int len, void *info)
+{
+	return dbus_send_irb(pub, buf, len, NULL, info);
+}
+
+int
+dbus_send_pkt(dbus_pub_t *pub, void *pkt, void *info)
+{
+	return dbus_send_irb(pub, NULL, 0, pkt, info);
+}
+
+int
+dbus_send_ctl(dbus_pub_t *pub, uint8 *buf, int len)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP ||
+		dbus_info->pub.busstate == DBUS_STATE_SLEEP) {
+		if (dbus_info->drvintf && dbus_info->drvintf->send_ctl)
+			return dbus_info->drvintf->send_ctl(dbus_info->bus_info, buf, len);
+	}
+
+	return DBUS_ERR;
+}
+
+int
+dbus_recv_ctl(dbus_pub_t *pub, uint8 *buf, int len)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	if ((dbus_info == NULL) || (buf == NULL))
+		return DBUS_ERR;
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP ||
+		dbus_info->pub.busstate == DBUS_STATE_SLEEP) {
+		if (dbus_info->drvintf && dbus_info->drvintf->recv_ctl)
+			return dbus_info->drvintf->recv_ctl(dbus_info->bus_info, buf, len);
+	}
+
+	return DBUS_ERR;
+}
+
+/** Only called via RPC (Dec 2012) */
+int
+dbus_recv_bulk(dbus_pub_t *pub, uint32 ep_idx)
+{
+#ifdef EHCI_FASTPATH_RX
+	/* 2nd bulk in not supported for EHCI_FASTPATH_RX */
+	ASSERT(0);
+#else
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	dbus_irb_rx_t *rxirb;
+	struct exec_parms args;
+	int status;
+
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	args.qdeq.q = dbus_info->rx_q;
+	if (dbus_info->pub.busstate == DBUS_STATE_UP) {
+		if (dbus_info->drvintf && dbus_info->drvintf->recv_irb_from_ep) {
+			if ((rxirb = (EXEC_RXLOCK(dbus_info, q_deq_exec, &args))) != NULL) {
+				status = dbus_info->drvintf->recv_irb_from_ep(dbus_info->bus_info,
+					rxirb, ep_idx);
+				if (status == DBUS_ERR_RXDROP) {
+					bzero(rxirb, sizeof(dbus_irb_rx_t));
+					args.qenq.q = dbus_info->rx_q;
+					args.qenq.b = (dbus_irb_t *) rxirb;
+					EXEC_RXLOCK(dbus_info, q_enq_exec, &args);
+				}
+			}
+		}
+	}
+#endif /* EHCI_FASTPATH_RX */
+
+	return DBUS_ERR;
+}
+
+/** only called by dhd_cdc.c (Dec 2012) */
+int
+dbus_poll_intr(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	int status = DBUS_ERR;
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP) {
+		if (dbus_info->drvintf && dbus_info->drvintf->recv_irb_from_ep) {
+			status = dbus_info->drvintf->recv_irb_from_ep(dbus_info->bus_info,
+				NULL, 0xff);
+		}
+	}
+	return status;
+}
+
+/** called by nobody (Dec 2012) */
+void *
+dbus_pktget(dbus_pub_t *pub, int len)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	if ((dbus_info == NULL) || (len < 0))
+		return NULL;
+
+	return PKTGET(dbus_info->pub.osh, len, TRUE);
+}
+
+/** called by nobody (Dec 2012) */
+void
+dbus_pktfree(dbus_pub_t *pub, void* pkt)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	if ((dbus_info == NULL) || (pkt == NULL))
+		return;
+
+	PKTFREE(dbus_info->pub.osh, pkt, TRUE);
+}
+
+/** called by nobody (Dec 2012) */
+int
+dbus_get_stats(dbus_pub_t *pub, dbus_stats_t *stats)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	if ((dbus_info == NULL) || (stats == NULL))
+		return DBUS_ERR;
+
+	bcopy(&dbus_info->pub.stats, stats, sizeof(dbus_stats_t));
+
+	return DBUS_OK;
+}
+
+int
+dbus_get_attrib(dbus_pub_t *pub, dbus_attrib_t *attrib)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_ERR;
+
+	if ((dbus_info == NULL) || (attrib == NULL))
+		return DBUS_ERR;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->get_attrib) {
+		err = dbus_info->drvintf->get_attrib(dbus_info->bus_info,
+		&dbus_info->pub.attrib);
+	}
+
+	bcopy(&dbus_info->pub.attrib, attrib, sizeof(dbus_attrib_t));
+	return err;
+}
+
+int
+dbus_get_device_speed(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+
+	if (dbus_info == NULL)
+		return INVALID_SPEED;
+
+	return (dbus_info->pub.device_speed);
+}
+
+int
+dbus_set_config(dbus_pub_t *pub, dbus_config_t *config)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_ERR;
+
+	if ((dbus_info == NULL) || (config == NULL))
+		return DBUS_ERR;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->set_config) {
+		err = dbus_info->drvintf->set_config(dbus_info->bus_info,
+			config);
+
+		if ((config->config_id == DBUS_CONFIG_ID_AGGR_LIMIT) &&
+			(!err) &&
+			(dbus_info->pub.busstate == DBUS_STATE_UP)) {
+			dbus_rxirbs_fill(dbus_info);
+		}
+	}
+
+	return err;
+}
+
+int
+dbus_get_config(dbus_pub_t *pub, dbus_config_t *config)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_ERR;
+
+	if ((dbus_info == NULL) || (config == NULL))
+		return DBUS_ERR;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->get_config) {
+		err = dbus_info->drvintf->get_config(dbus_info->bus_info,
+		config);
+	}
+
+	return err;
+}
+
+int
+dbus_set_errmask(dbus_pub_t *pub, uint32 mask)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_OK;
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	dbus_info->errmask = mask;
+	return err;
+}
+
+int
+dbus_pnp_resume(dbus_pub_t *pub, int *fw_reload)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_ERR;
+	bool fwdl = FALSE;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (dbus_info->pub.busstate == DBUS_STATE_UP) {
+		return DBUS_OK;
+	}
+
+
+#if defined(BCM_DNGL_EMBEDIMAGE)
+	if (dbus_info->drvintf->device_exists &&
+		dbus_info->drvintf->device_exists(dbus_info->bus_info)) {
+		if (dbus_info->drvintf->dlneeded) {
+			if (dbus_info->drvintf->dlneeded(dbus_info->bus_info)) {
+				err = dbus_do_download(dbus_info);
+				if (err == DBUS_OK) {
+					fwdl = TRUE;
+				}
+				if (dbus_info->pub.busstate == DBUS_STATE_DL_DONE)
+					dbus_up(&dbus_info->pub);
+			}
+		}
+	} else {
+		return DBUS_ERR;
+	}
+#endif /* BCM_DNGL_EMBEDIMAGE */
+
+	if (dbus_info->drvintf->pnp) {
+		err = dbus_info->drvintf->pnp(dbus_info->bus_info,
+			DBUS_PNP_RESUME);
+	}
+
+	if (dbus_info->drvintf->recv_needed) {
+		if (dbus_info->drvintf->recv_needed(dbus_info->bus_info)) {
+			/* Refill after sleep/hibernate */
+			dbus_rxirbs_fill(dbus_info);
+		}
+	}
+
+#if defined(BCM_DNGL_EMBEDIMAGE)
+	if (fwdl == TRUE) {
+		dbus_if_state_change(dbus_info, DBUS_STATE_PNP_FWDL);
+	}
+#endif /* BCM_DNGL_EMBEDIMAGE */
+
+	if (fw_reload)
+		*fw_reload = fwdl;
+
+	return err;
+} /* dbus_pnp_resume */
+
+int
+dbus_pnp_sleep(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_ERR;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	dbus_tx_timer_stop(dbus_info);
+
+	if (dbus_info->drvintf && dbus_info->drvintf->pnp) {
+		err = dbus_info->drvintf->pnp(dbus_info->bus_info,
+			DBUS_PNP_SLEEP);
+	}
+
+	return err;
+}
+
+int
+dbus_pnp_disconnect(dbus_pub_t *pub)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_ERR;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	dbus_tx_timer_stop(dbus_info);
+
+	if (dbus_info->drvintf && dbus_info->drvintf->pnp) {
+		err = dbus_info->drvintf->pnp(dbus_info->bus_info,
+			DBUS_PNP_DISCONNECT);
+	}
+
+	return err;
+}
+
+int
+dbus_iovar_op(dbus_pub_t *pub, const char *name,
+	void *params, int plen, void *arg, int len, bool set)
+{
+	dbus_info_t *dbus_info = (dbus_info_t *) pub;
+	int err = DBUS_ERR;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (dbus_info == NULL)
+		return DBUS_ERR;
+
+	if (dbus_info->drvintf && dbus_info->drvintf->iovar_op) {
+		err = dbus_info->drvintf->iovar_op(dbus_info->bus_info,
+			name, params, plen, arg, len, set);
+	}
+
+	return err;
+}
+
+
+void *
+dhd_dbus_txq(const dbus_pub_t *pub)
+{
+	return NULL;
+}
+
+uint
+dhd_dbus_hdrlen(const dbus_pub_t *pub)
+{
+	return 0;
+}
+
+void *
+dbus_get_devinfo(dbus_pub_t *pub)
+{
+	return pub->dev_info;
+}
+
+#if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+
+static int
+dbus_otp(dbus_info_t *dbus_info, uint16 *boardtype, uint16 *boardrev)
+{
+	uint32 value = 0;
+	uint8 *cis;
+	uint16 *otpinfo;
+	uint32 i;
+	bool standard_cis = TRUE;
+	uint8 tup, tlen;
+	bool btype_present = FALSE;
+	bool brev_present = FALSE;
+	int ret;
+	int devid;
+	uint16 btype = 0;
+	uint16 brev = 0;
+	uint32 otp_size = 0, otp_addr = 0, otp_sw_rgn = 0;
+
+	if (dbus_info == NULL || dbus_info->drvintf == NULL ||
+		dbus_info->drvintf->readreg == NULL)
+		return DBUS_ERR;
+
+	devid = dbus_info->pub.attrib.devid;
+
+	if ((devid == BCM43234_CHIP_ID) || (devid == BCM43235_CHIP_ID) ||
+		(devid == BCM43236_CHIP_ID)) {
+
+		otp_size = BCM_OTP_SIZE_43236;
+		otp_sw_rgn = BCM_OTP_SW_RGN_43236;
+		otp_addr = BCM_OTP_ADDR_43236;
+
+	} else {
+		return DBUS_ERR_NVRAM;
+	}
+
+	cis = MALLOC(dbus_info->pub.osh, otp_size * 2);
+	if (cis == NULL)
+		return DBUS_ERR;
+
+	otpinfo = (uint16 *) cis;
+
+	for (i = 0; i < otp_size; i++) {
+
+		ret = dbus_info->drvintf->readreg(dbus_info->bus_info,
+			otp_addr + ((otp_sw_rgn + i) << 1), 2, &value);
+
+		if (ret != DBUS_OK) {
+			MFREE(dbus_info->pub.osh, cis, otp_size * 2);
+			return ret;
+		}
+		otpinfo[i] = (uint16) value;
+	}
+
+	for (i = 0; i < (otp_size << 1); ) {
+
+		if (standard_cis) {
+			tup = cis[i++];
+			if (tup == CISTPL_NULL || tup == CISTPL_END)
+				tlen = 0;
+			else
+				tlen = cis[i++];
+		} else {
+			if (cis[i] == CISTPL_NULL || cis[i] == CISTPL_END) {
+				tlen = 0;
+				tup = cis[i];
+			} else {
+				tlen = cis[i];
+				tup = CISTPL_BRCM_HNBU;
+			}
+			++i;
+		}
+
+		if (tup == CISTPL_END || (i + tlen) >= (otp_size << 1)) {
+			break;
+		}
+
+		switch (tup) {
+
+		case CISTPL_BRCM_HNBU:
+
+			switch (cis[i]) {
+
+			case HNBU_BOARDTYPE:
+
+				btype = (uint16) ((cis[i + 2] << 8) + cis[i + 1]);
+				btype_present = TRUE;
+				DBUSTRACE(("%s: HNBU_BOARDTYPE = 0x%2x\n", __FUNCTION__,
+					(uint32)btype));
+				break;
+
+			case HNBU_BOARDREV:
+
+				if (tlen == 2)
+					brev = (uint16) cis[i + 1];
+				else
+					brev = (uint16) ((cis[i + 2] << 8) + cis[i + 1]);
+				brev_present = TRUE;
+				DBUSTRACE(("%s: HNBU_BOARDREV =  0x%2x\n", __FUNCTION__,
+					(uint32)*boardrev));
+				break;
+
+			case HNBU_HNBUCIS:
+				DBUSTRACE(("%s: HNBU_HNBUCIS\n", __FUNCTION__));
+				tlen++;
+				standard_cis = FALSE;
+				break;
+			}
+			break;
+		}
+
+		i += tlen;
+	}
+
+	MFREE(dbus_info->pub.osh, cis, otp_size * 2);
+
+	if (btype_present == TRUE && brev_present == TRUE) {
+		*boardtype = btype;
+		*boardrev = brev;
+		DBUSERR(("otp boardtype = 0x%2x boardrev = 0x%2x\n",
+			*boardtype, *boardrev));
+
+		return DBUS_OK;
+	}
+	else
+		return DBUS_ERR;
+} /* dbus_otp */
+
+static int
+dbus_select_nvram(dbus_info_t *dbus_info, int8 *jumbonvram, int jumbolen,
+uint16 boardtype, uint16 boardrev, int8 **nvram, int *nvram_len)
+{
+	/* Multi board nvram file format is contenation of nvram info with \r
+	*  The file format for two contatenated set is
+	*  \nBroadcom Jumbo Nvram file\nfirst_set\nsecond_set\nthird_set\n
+	*/
+	uint8 *nvram_start = NULL, *nvram_end = NULL;
+	uint8 *nvram_start_prev = NULL, *nvram_end_prev = NULL;
+	uint16 btype = 0, brev = 0;
+	int len  = 0;
+	char *field;
+
+	*nvram = NULL;
+	*nvram_len = 0;
+
+	if (strncmp(BCM_JUMBO_START, jumbonvram, strlen(BCM_JUMBO_START))) {
+		/* single nvram file in the native format */
+		DBUSTRACE(("%s: Non-Jumbo NVRAM File \n", __FUNCTION__));
+		*nvram = jumbonvram;
+		*nvram_len = jumbolen;
+		return DBUS_OK;
+	} else {
+		DBUSTRACE(("%s: Jumbo NVRAM File \n", __FUNCTION__));
+	}
+
+	/* sanity test the end of the config sets for proper ending */
+	if (jumbonvram[jumbolen - 1] != BCM_JUMBO_NVRAM_DELIMIT ||
+		jumbonvram[jumbolen - 2] != '\0') {
+		DBUSERR(("%s: Bad Jumbo NVRAM file format\n", __FUNCTION__));
+		return DBUS_JUMBO_BAD_FORMAT;
+	}
+
+	dbus_info->nvram_nontxt = DBUS_NVRAM_NONTXT;
+
+	nvram_start = jumbonvram;
+
+	while (*nvram_start != BCM_JUMBO_NVRAM_DELIMIT && len < jumbolen) {
+
+		/* consume the  first file info line
+		* \nBroadcom Jumbo Nvram file\nfile1\n ...
+		*/
+		len ++;
+		nvram_start ++;
+	}
+
+	nvram_end = nvram_start;
+
+	/* search for "boardrev=0xabcd" and "boardtype=0x1234" information in
+	* the concatenated nvram config files /sets
+	*/
+
+	while (len < jumbolen) {
+
+		if (*nvram_end == '\0') {
+			/* end of a config set is marked by multiple null characters */
+			len ++;
+			nvram_end ++;
+			DBUSTRACE(("%s: NULL chr len = %d char = 0x%x\n", __FUNCTION__,
+				len, *nvram_end));
+			continue;
+
+		} else if (*nvram_end == BCM_JUMBO_NVRAM_DELIMIT) {
+
+			/* config set delimiter is reached */
+			/* check if next config set is present or not
+			*  return  if next config is not present
+			*/
+
+			/* start search the next config set */
+			nvram_start_prev = nvram_start;
+			nvram_end_prev = nvram_end;
+
+			nvram_end ++;
+			nvram_start = nvram_end;
+			btype = brev = 0;
+			DBUSTRACE(("%s: going to next record len = %d "
+					"char = 0x%x \n", __FUNCTION__, len, *nvram_end));
+			len ++;
+			if (len >= jumbolen) {
+
+				*nvram = nvram_start_prev;
+				*nvram_len = (int)(nvram_end_prev - nvram_start_prev);
+
+				DBUSTRACE(("%s: no more len = %d nvram_end = 0x%p",
+					__FUNCTION__, len, nvram_end));
+
+				return DBUS_JUMBO_NOMATCH;
+
+			} else {
+				continue;
+			}
+
+		} else {
+
+			DBUSTRACE(("%s: config str = %s\n", __FUNCTION__, nvram_end));
+
+			if (bcmp(nvram_end, "boardtype", strlen("boardtype")) == 0) {
+
+				field = strchr(nvram_end, '=');
+				field++;
+				btype = (uint16)bcm_strtoul(field, NULL, 0);
+
+				DBUSTRACE(("%s: btype = 0x%x boardtype = 0x%x \n", __FUNCTION__,
+					btype, boardtype));
+			}
+
+			if (bcmp(nvram_end, "boardrev", strlen("boardrev")) == 0) {
+
+				field = strchr(nvram_end, '=');
+				field++;
+				brev = (uint16)bcm_strtoul(field, NULL, 0);
+
+				DBUSTRACE(("%s: brev = 0x%x boardrev = 0x%x \n", __FUNCTION__,
+					brev, boardrev));
+			}
+			if (btype == boardtype && brev == boardrev) {
+				/* locate nvram config set end - ie.find '\r' char */
+				while (*nvram_end != BCM_JUMBO_NVRAM_DELIMIT)
+					nvram_end ++;
+				*nvram = nvram_start;
+				*nvram_len = (int) (nvram_end - nvram_start);
+				DBUSTRACE(("found len = %d nvram_start = 0x%p "
+					"nvram_end = 0x%p\n", *nvram_len, nvram_start, nvram_end));
+				return DBUS_OK;
+			}
+
+			len += (strlen(nvram_end) + 1);
+			nvram_end += (strlen(nvram_end) + 1);
+		}
+	}
+	return DBUS_JUMBO_NOMATCH;
+} /* dbus_select_nvram */
+
+#if defined(BCM_DNGL_EMBEDIMAGE)
+
+/* store the global osh handle */
+static osl_t *osl_handle = NULL;
+
+/** this function is a combination of trx.c and bcmdl.c plus dbus adaptation */
+static int
+dbus_zlib_decomp(dbus_info_t *dbus_info)
+{
+
+	int method, flags, len, status;
+	unsigned int uncmp_len, uncmp_crc, dec_crc, crc_init;
+	struct trx_header *trx, *newtrx;
+	unsigned char *file = NULL;
+	unsigned char gz_magic[2] = {0x1f, 0x8b}; /* gzip magic header */
+	z_stream d_stream;
+	unsigned char unused;
+	int actual_len = -1;
+	unsigned char *headers;
+	unsigned int trxhdrsize, nvramsize, decomp_memsize, i;
+
+	(void)actual_len;
+	(void)unused;
+	(void)crc_init;
+
+	osl_handle = dbus_info->pub.osh;
+	dbus_info->orig_fw = NULL;
+
+	headers = dbus_info->fw;
+	/* Extract trx header */
+	trx = (struct trx_header *)headers;
+	trxhdrsize = sizeof(struct trx_header);
+
+	if (ltoh32(trx->magic) != TRX_MAGIC) {
+		DBUSERR(("%s: Error: trx bad hdr %x\n", __FUNCTION__,
+			ltoh32(trx->magic)));
+		return -1;
+	}
+
+	headers += sizeof(struct trx_header);
+
+	if (ltoh32(trx->flag_version) & TRX_UNCOMP_IMAGE) {
+		actual_len = ltoh32(trx->offsets[TRX_OFFSETS_DLFWLEN_IDX]) +
+		                     sizeof(struct trx_header);
+		DBUSERR(("%s: not a compressed image\n", __FUNCTION__));
+		return 0;
+	} else {
+		/* Extract the gzip header info */
+		if ((*headers++ != gz_magic[0]) || (*headers++ != gz_magic[1])) {
+			DBUSERR(("%s: Error: gzip bad hdr\n", __FUNCTION__));
+			return -1;
+		}
+
+		method = (int) *headers++;
+		flags = (int) *headers++;
+
+		if (method != Z_DEFLATED || (flags & RESERVED) != 0) {
+			DBUSERR(("%s: Error: gzip bad hdr not a Z_DEFLATED file\n", __FUNCTION__));
+			return -1;
+		}
+	}
+
+	/* Discard time, xflags and OS code: */
+	for (len = 0; len < 6; len++)
+		unused = *headers++;
+
+	if ((flags & EXTRA_FIELD) != 0) { /* skip the extra field */
+		len = (uint32) *headers++;
+		len += ((uint32)*headers++)<<8;
+		/* len is garbage if EOF but the loop below will quit anyway */
+		while (len-- != 0) unused = *headers++;
+	}
+
+	if ((flags & ORIG_NAME) != 0) { /* skip the original file name */
+		while (*headers++ && (*headers != 0));
+	}
+
+	if ((flags & COMMENT) != 0) {   /* skip the .gz file comment */
+		while (*headers++ && (*headers != 0));
+	}
+
+	if ((flags & HEAD_CRC) != 0) {  /* skip the header crc */
+		for (len = 0; len < 2; len++) unused = *headers++;
+	}
+
+	headers++;
+
+
+	/* create space for the uncompressed file */
+	/* the space is for trx header, uncompressed image  and nvram file */
+	/* with typical compression of 0.6, space double of firmware should be ok */
+
+	decomp_memsize = dbus_info->fwlen * 2;
+	dbus_info->decomp_memsize = decomp_memsize;
+	if (!(file = MALLOC(osl_handle, decomp_memsize))) {
+		DBUSERR(("%s: check_file : failed malloc\n", __FUNCTION__));
+		goto err;
+	}
+
+	bzero(file, decomp_memsize);
+
+	/* Initialise the decompression struct */
+	d_stream.next_in = NULL;
+	d_stream.avail_in = 0;
+	d_stream.next_out = NULL;
+	d_stream.avail_out = decomp_memsize - trxhdrsize;
+	d_stream.zalloc = (alloc_func)0;
+	d_stream.zfree = (free_func)0;
+	if (inflateInit2(&d_stream, -15) != Z_OK) {
+		DBUSERR(("%s: Err: inflateInit2\n", __FUNCTION__));
+		goto err;
+	}
+
+	/* Inflate the code */
+	d_stream.next_in = headers;
+	d_stream.avail_in = ltoh32(trx->len);
+	d_stream.next_out = (unsigned char*)(file + trxhdrsize);
+
+	status = inflate(&d_stream, Z_SYNC_FLUSH);
+
+	if (status != Z_STREAM_END)	{
+		DBUSERR(("%s: Error: decompression failed\n", __FUNCTION__));
+		goto err;
+	}
+
+	uncmp_crc = *d_stream.next_in++;
+	uncmp_crc |= *d_stream.next_in++<<8;
+	uncmp_crc |= *d_stream.next_in++<<16;
+	uncmp_crc |= *d_stream.next_in++<<24;
+
+	uncmp_len = *d_stream.next_in++;
+	uncmp_len |= *d_stream.next_in++<<8;
+	uncmp_len |= *d_stream.next_in++<<16;
+	uncmp_len |= *d_stream.next_in++<<24;
+
+	actual_len = (int) (d_stream.next_in - (unsigned char *)trx);
+
+	inflateEnd(&d_stream);
+
+	/* Do a CRC32 on the uncompressed data */
+	crc_init = crc32(0L, Z_NULL, 0);
+	dec_crc = crc32(crc_init, file + trxhdrsize, uncmp_len);
+
+	if (dec_crc != uncmp_crc) {
+		DBUSERR(("%s: decompression: bad crc check \n", __FUNCTION__));
+		goto err;
+	}
+	else {
+		DBUSTRACE(("%s: decompression: good crc check \n", __FUNCTION__));
+	}
+
+	/* rebuild the new trx header and calculate crc */
+	newtrx = (struct trx_header *)file;
+	newtrx->magic = trx->magic;
+	/* add the uncompressed image flag */
+	newtrx->flag_version = trx->flag_version;
+	newtrx->flag_version  |= htol32(TRX_UNCOMP_IMAGE);
+	newtrx->offsets[TRX_OFFSETS_DLFWLEN_IDX] = htol32(uncmp_len);
+	newtrx->offsets[TRX_OFFSETS_JUMPTO_IDX] = trx->offsets[TRX_OFFSETS_JUMPTO_IDX];
+	newtrx->offsets[TRX_OFFSETS_NVM_LEN_IDX] = trx->offsets[TRX_OFFSETS_NVM_LEN_IDX];
+
+	nvramsize = ltoh32(trx->offsets[TRX_OFFSETS_NVM_LEN_IDX]);
+
+	/* the original firmware has nvram file appended */
+	/* copy the nvram file to uncompressed firmware */
+
+	if (nvramsize) {
+		if (nvramsize + uncmp_len > decomp_memsize) {
+			DBUSERR(("%s: nvram cannot be accomodated\n", __FUNCTION__));
+			goto err;
+		}
+		bcopy(d_stream.next_in, &file[uncmp_len], nvramsize);
+		uncmp_len += nvramsize;
+	}
+
+	/* add trx header size to uncmp_len */
+	uncmp_len += trxhdrsize;
+	uncmp_len = ROUNDUP(uncmp_len, 4096);
+	newtrx->len	= htol32(uncmp_len);
+
+	/* Calculate CRC over header */
+	newtrx->crc32 = hndcrc32((uint8 *)&newtrx->flag_version,
+	sizeof(struct trx_header) - OFFSETOF(struct trx_header, flag_version),
+	CRC32_INIT_VALUE);
+
+	/* Calculate CRC over data */
+	for (i = trxhdrsize; i < (uncmp_len); ++i)
+				newtrx->crc32 = hndcrc32((uint8 *)&file[i], 1, newtrx->crc32);
+	newtrx->crc32 = htol32(newtrx->crc32);
+
+	dbus_info->orig_fw = dbus_info->fw;
+	dbus_info->origfw_len = dbus_info->fwlen;
+	dbus_info->image = dbus_info->fw = file;
+	dbus_info->image_len = dbus_info->fwlen = uncmp_len;
+
+	return 0;
+
+err:
+	if (file)
+		free(file);
+	return -1;
+} /* dbus_zlib_decomp */
+
+void *
+dbus_zlib_calloc(int num, int size)
+{
+	uint *ptr;
+	uint totalsize;
+
+	if (osl_handle == NULL)
+		return NULL;
+
+	totalsize = (num * (size + 1));
+
+	ptr  = MALLOC(osl_handle, totalsize);
+
+	if (ptr == NULL)
+		return NULL;
+	bzero(ptr, totalsize);
+
+	/* store the size in the first integer space */
+
+	ptr[0] = totalsize;
+
+	return ((void *) &ptr[1]);
+}
+
+void
+dbus_zlib_free(void *ptr)
+{
+	uint totalsize;
+	uchar *memptr = (uchar *)ptr;
+
+	if (ptr && osl_handle) {
+		memptr -= sizeof(uint);
+		totalsize = *(uint *) memptr;
+		MFREE(osl_handle, memptr, totalsize);
+	}
+}
+
+#endif /* #if defined(BCM_DNGL_EMBEDIMAGE) */
+#endif /* #if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
+
+
+#ifdef LINUX_EXTERNAL_MODULE_DBUS
+
+static int __init
+bcm_dbus_module_init(void)
+{
+	printf("Inserting bcm_dbus module \n");
+	return 0;
+}
+
+static void __exit
+bcm_dbus_module_exit(void)
+{
+	printf("Removing bcm_dbus module \n");
+	return;
+}
+
+EXPORT_SYMBOL(dbus_pnp_sleep);
+EXPORT_SYMBOL(dbus_register);
+EXPORT_SYMBOL(dbus_get_devinfo);
+EXPORT_SYMBOL(dbus_detach);
+EXPORT_SYMBOL(dbus_get_attrib);
+EXPORT_SYMBOL(dbus_down);
+EXPORT_SYMBOL(dbus_pnp_resume);
+EXPORT_SYMBOL(dbus_set_config);
+EXPORT_SYMBOL(dbus_flowctrl_rx);
+EXPORT_SYMBOL(dbus_up);
+EXPORT_SYMBOL(dbus_get_device_speed);
+EXPORT_SYMBOL(dbus_send_pkt);
+EXPORT_SYMBOL(dbus_recv_ctl);
+EXPORT_SYMBOL(dbus_attach);
+EXPORT_SYMBOL(dbus_deregister);
+
+MODULE_LICENSE("GPL");
+
+module_init(bcm_dbus_module_init);
+module_exit(bcm_dbus_module_exit);
+
+#endif  /* #ifdef LINUX_EXTERNAL_MODULE_DBUS */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus_usb.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus_usb.c
new file mode 100644
index 000000000000..eb204d763091
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus_usb.c
@@ -0,0 +1,1228 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Dongle BUS interface for USB, OS independent
+ *
+ * Copyright (C) 1999-2018, Broadcom Corporation
+ * 
+ *      Unless you and Broadcom execute a separate written software license
+ * agreement governing use of this software, this software is licensed to you
+ * under the terms of the GNU General Public License version 2 (the "GPL"),
+ * available at http://www.broadcom.com/licenses/GPLv2.php, with the
+ * following added to such license:
+ * 
+ *      As a special exception, the copyright holders of this software give you
+ * permission to link this software with independent modules, and to copy and
+ * distribute the resulting executable under terms of your choice, provided that
+ * you also meet, for each linked independent module, the terms and conditions of
+ * the license of that module.  An independent module is a module which is not
+ * derived from this software.  The special exception does not apply to any
+ * modifications of the software.
+ * 
+ *      Notwithstanding the above, under no circumstances may you combine this
+ * software in any way with any other Broadcom software provided under a license
+ * other than the GPL, without Broadcom's express prior written consent.
+ *
+ *
+ * <<Broadcom-WL-IPTag/Open:>>
+ *
+ * $Id: dbus_usb.c 565557 2015-06-22 19:29:44Z $
+ */
+
+/**
+ * @file @brief
+ * This file contains DBUS code that is USB, but not OS specific. DBUS is a Broadcom proprietary
+ * host specific abstraction layer.
+ */
+
+#include <osl.h>
+#include <bcmdefs.h>
+#include <bcmutils.h>
+#include <dbus.h>
+#include <usbrdl.h>
+#include <bcmdevs.h>
+#include <bcmendian.h>
+
+#if defined(BCM_DNGL_EMBEDIMAGE)
+#ifdef EMBED_IMAGE_43236b
+#include "rtecdc_43236b.h"
+#endif /* EMBED_IMAGE_43236b */
+#ifdef EMBED_IMAGE_43526a
+#include "rtecdc_43526a.h"
+#endif /* EMBED_IMAGE_43526a */
+#ifdef EMBED_IMAGE_43526b
+#include "rtecdc_43526b.h"
+#endif /* EMBED_IMAGE_43526b */
+#ifdef EMBED_IMAGE_43242a0
+#include "rtecdc_43242a0.h"
+#endif /* EMBED_IMAGE_43242a0 */
+#ifdef EMBED_IMAGE_43143a0
+#include "rtecdc_43143a0.h"
+#endif /* EMBED_IMAGE_43143a0 */
+#ifdef EMBED_IMAGE_43143b0
+#include "rtecdc_43143b0.h"
+#endif /* EMBED_IMAGE_43143b0 */
+#ifdef EMBED_IMAGE_4350a0
+#include "rtecdc_4350a0.h"
+#endif /* EMBED_IMAGE_4350a0 */
+#ifdef EMBED_IMAGE_4350b0
+#include "rtecdc_4350b0.h"
+#endif /* EMBED_IMAGE_4350b0 */
+#ifdef EMBED_IMAGE_4350b1
+#include "rtecdc_4350b1.h"
+#endif /* EMBED_IMAGE_4350b1 */
+#ifdef EMBED_IMAGE_4350c0
+#include "rtecdc_4350c0.h"
+#endif /* EMBED_IMAGE_4350c0 */
+#ifdef EMBED_IMAGE_4350c1
+#include "rtecdc_4350c1.h"
+#endif /* EMBED_IMAGE_4350c1 */
+#ifdef EMBED_IMAGE_43556b1
+#include "rtecdc_43556b1.h"
+#endif /* EMBED_IMAGE_43556b1 */
+#ifdef EMBED_IMAGE_43569a0
+#include "rtecdc_43569a0.h"
+#endif /* EMBED_IMAGE_43569a0 */
+#ifdef EMBED_IMAGE_GENERIC
+#include "rtecdc.h"
+#endif
+#endif /* BCM_DNGL_EMBEDIMAGE */
+
+
+#define USB_DLIMAGE_RETRY_TIMEOUT    3000    /* retry Timeout */
+#define USB_SFLASH_DLIMAGE_SPINWAIT  150     /* in unit of ms */
+#define USB_SFLASH_DLIMAGE_LIMIT     2000    /* spinwait limit (ms) */
+#define POSTBOOT_ID                  0xA123  /* ID to detect if dongle has boot up */
+#define USB_RESETCFG_SPINWAIT        1       /* wait after resetcfg (ms) */
+#define USB_DEV_ISBAD(u)             (u->pub->attrib.devid == 0xDEAD)
+#define USB_DLGO_SPINWAIT            100     /* wait after DL_GO (ms) */
+#define TEST_CHIP                    0x4328
+
+typedef struct {
+	dbus_pub_t  *pub;
+
+	void        *cbarg;
+	dbus_intf_callbacks_t *cbs;  /** callbacks into higher DBUS level (dbus.c) */
+	dbus_intf_t *drvintf;
+	void        *usbosl_info;
+	uint32      rdlram_base_addr;
+	uint32      rdlram_size;
+} usb_info_t;
+
+/*
+ * Callbacks common to all USB
+ */
+static void dbus_usb_disconnect(void *handle);
+static void dbus_usb_send_irb_timeout(void *handle, dbus_irb_tx_t *txirb);
+static void dbus_usb_send_irb_complete(void *handle, dbus_irb_tx_t *txirb, int status);
+static void dbus_usb_recv_irb_complete(void *handle, dbus_irb_rx_t *rxirb, int status);
+static void dbus_usb_errhandler(void *handle, int err);
+static void dbus_usb_ctl_complete(void *handle, int type, int status);
+static void dbus_usb_state_change(void *handle, int state);
+static struct dbus_irb* dbus_usb_getirb(void *handle, bool send);
+static void dbus_usb_rxerr_indicate(void *handle, bool on);
+static int dbus_usb_resetcfg(usb_info_t *usbinfo);
+static int dbus_usb_iovar_op(void *bus, const char *name,
+	void *params, int plen, void *arg, int len, bool set);
+static int dbus_iovar_process(usb_info_t* usbinfo, const char *name,
+                 void *params, int plen, void *arg, int len, bool set);
+static int dbus_usb_doiovar(usb_info_t *bus, const bcm_iovar_t *vi, uint32 actionid,
+	const char *name, void *params, int plen, void *arg, int len, int val_size);
+static int dhdusb_downloadvars(usb_info_t *bus, void *arg, int len);
+
+static int dbus_usb_dl_writeimage(usb_info_t *usbinfo, uint8 *fw, int fwlen);
+static int dbus_usb_dlstart(void *bus, uint8 *fw, int len);
+static bool dbus_usb_dlneeded(void *bus);
+static int dbus_usb_dlrun(void *bus);
+static int dbus_usb_rdl_dwnld_state(usb_info_t *usbinfo);
+
+#ifdef BCM_DNGL_EMBEDIMAGE
+static bool dbus_usb_device_exists(void *bus);
+#endif
+
+/* OS specific */
+extern bool dbus_usbos_dl_cmd(void *info, uint8 cmd, void *buffer, int buflen);
+extern int dbus_usbos_wait(void *info, uint16 ms);
+extern int dbus_write_membytes(usb_info_t *usbinfo, bool set, uint32 address,
+	uint8 *data, uint size);
+extern bool dbus_usbos_dl_send_bulk(void *info, void *buffer, int len);
+extern int dbus_usbos_loopback_tx(void *usbos_info_ptr, int cnt, int size);
+
+/**
+ * These functions are called by the lower DBUS level (dbus_usb_os.c) to notify this DBUS level
+ * (dbus_usb.c) of an event.
+ */
+static dbus_intf_callbacks_t dbus_usb_intf_cbs = {
+	dbus_usb_send_irb_timeout,
+	dbus_usb_send_irb_complete,
+	dbus_usb_recv_irb_complete,
+	dbus_usb_errhandler,
+	dbus_usb_ctl_complete,
+	dbus_usb_state_change,
+	NULL,			/* isr */
+	NULL,			/* dpc */
+	NULL,			/* watchdog */
+	NULL,			/* dbus_if_pktget */
+	NULL, 			/* dbus_if_pktfree */
+	dbus_usb_getirb,
+	dbus_usb_rxerr_indicate
+};
+
+/* IOVar table */
+enum {
+	IOV_SET_DOWNLOAD_STATE = 1,
+	IOV_MEMBYTES,
+	IOV_VARS,
+	IOV_LOOPBACK_TX
+};
+
+const bcm_iovar_t dhdusb_iovars[] = {
+	{"vars",	IOV_VARS,	0,	IOVT_BUFFER,	0 },
+	{"dwnldstate",	IOV_SET_DOWNLOAD_STATE,	0,	IOVT_BOOL,	0 },
+	{"membytes",	IOV_MEMBYTES,	0,	IOVT_BUFFER,	2 * sizeof(int) },
+	{"usb_lb_txfer", IOV_LOOPBACK_TX, 0,    IOVT_BUFFER,    2 * sizeof(int) },
+	{NULL, 0, 0, 0, 0 }
+};
+
+/*
+ * Need global for probe() and disconnect() since
+ * attach() is not called at probe and detach()
+ * can be called inside disconnect()
+ */
+static probe_cb_t	probe_cb = NULL;
+static disconnect_cb_t	disconnect_cb = NULL;
+static void		*probe_arg = NULL;
+static void		*disc_arg = NULL;
+static dbus_intf_t	*g_dbusintf = NULL;
+static dbus_intf_t	dbus_usb_intf; /** functions called by higher layer DBUS into lower layer */
+
+/*
+ * dbus_intf_t common to all USB
+ * These functions override dbus_usb_<os>.c.
+ */
+static void *dbus_usb_attach(dbus_pub_t *pub, void *cbarg, dbus_intf_callbacks_t *cbs);
+static void dbus_usb_detach(dbus_pub_t *pub, void *info);
+static void * dbus_usb_probe(void *arg, const char *desc, uint32 bustype, uint32 hdrlen);
+
+/* functions */
+
+/**
+ * As part of DBUS initialization/registration, the higher level DBUS (dbus.c) needs to know what
+ * lower level DBUS functions to call (in both dbus_usb.c and dbus_usb_os.c).
+ */
+static void *
+dbus_usb_probe(void *arg, const char *desc, uint32 bustype, uint32 hdrlen)
+{
+	DBUSTRACE(("%s(): \n", __FUNCTION__));
+	if (probe_cb) {
+
+		if (g_dbusintf != NULL) {
+			/* First, initialize all lower-level functions as default
+			 * so that dbus.c simply calls directly to dbus_usb_os.c.
+			 */
+			bcopy(g_dbusintf, &dbus_usb_intf, sizeof(dbus_intf_t));
+
+			/* Second, selectively override functions we need, if any. */
+			dbus_usb_intf.attach = dbus_usb_attach;
+			dbus_usb_intf.detach = dbus_usb_detach;
+			dbus_usb_intf.iovar_op = dbus_usb_iovar_op;
+			dbus_usb_intf.dlstart = dbus_usb_dlstart;
+			dbus_usb_intf.dlneeded = dbus_usb_dlneeded;
+			dbus_usb_intf.dlrun = dbus_usb_dlrun;
+#ifdef BCM_DNGL_EMBEDIMAGE
+			dbus_usb_intf.device_exists = dbus_usb_device_exists;
+#endif
+		}
+
+		disc_arg = probe_cb(probe_arg, "DBUS USB", USB_BUS, hdrlen);
+		return disc_arg;
+	}
+
+	return NULL;
+}
+
+/**
+ * On return, *intf contains this or lower-level DBUS functions to be called by higher
+ * level (dbus.c)
+ */
+int
+dbus_bus_register(int vid, int pid, probe_cb_t prcb,
+	disconnect_cb_t discb, void *prarg, dbus_intf_t **intf, void *param1, void *param2)
+{
+	int err;
+
+	DBUSTRACE(("%s(): \n", __FUNCTION__));
+	probe_cb = prcb;
+	disconnect_cb = discb;
+	probe_arg = prarg;
+
+	*intf = &dbus_usb_intf;
+
+	err = dbus_bus_osl_register(vid, pid, dbus_usb_probe,
+		dbus_usb_disconnect, NULL, &g_dbusintf, param1, param2);
+
+	ASSERT(g_dbusintf);
+	return err;
+}
+
+int
+dbus_bus_deregister()
+{
+	DBUSTRACE(("%s(): \n", __FUNCTION__));
+	return dbus_bus_osl_deregister();
+}
+
+/** initialization consists of registration followed by 'attach'. */
+void *
+dbus_usb_attach(dbus_pub_t *pub, void *cbarg, dbus_intf_callbacks_t *cbs)
+{
+	usb_info_t *usb_info;
+
+	DBUSTRACE(("%s(): \n", __FUNCTION__));
+
+	if ((g_dbusintf == NULL) || (g_dbusintf->attach == NULL))
+		return NULL;
+
+	/* Sanity check for BUS_INFO() */
+	ASSERT(OFFSETOF(usb_info_t, pub) == 0);
+
+	usb_info = MALLOC(pub->osh, sizeof(usb_info_t));
+	if (usb_info == NULL)
+		return NULL;
+
+	bzero(usb_info, sizeof(usb_info_t));
+
+	usb_info->pub = pub;
+	usb_info->cbarg = cbarg;
+	usb_info->cbs = cbs;
+
+	usb_info->usbosl_info = (dbus_pub_t *)g_dbusintf->attach(pub,
+		usb_info, &dbus_usb_intf_cbs);
+	if (usb_info->usbosl_info == NULL) {
+		MFREE(pub->osh, usb_info, sizeof(usb_info_t));
+		return NULL;
+	}
+
+	/* Save USB OS-specific driver entry points */
+	usb_info->drvintf = g_dbusintf;
+
+	pub->bus = usb_info;
+#if  !defined(BCM_DNGL_EMBEDIMAGE) && !defined(BCM_REQUEST_FW)
+
+	if (!dbus_usb_resetcfg(usb_info)) {
+	usb_info->pub->busstate = DBUS_STATE_DL_DONE;
+	}
+#endif
+	/* Return Lower layer info */
+	return (void *) usb_info->usbosl_info;
+}
+
+void
+dbus_usb_detach(dbus_pub_t *pub, void *info)
+{
+	usb_info_t *usb_info = (usb_info_t *) pub->bus;
+	osl_t *osh = pub->osh;
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->drvintf && usb_info->drvintf->detach)
+		usb_info->drvintf->detach(pub, usb_info->usbosl_info);
+
+	MFREE(osh, usb_info, sizeof(usb_info_t));
+}
+
+void
+dbus_usb_disconnect(void *handle)
+{
+	DBUSTRACE(("%s(): \n", __FUNCTION__));
+	if (disconnect_cb)
+		disconnect_cb(disc_arg);
+}
+
+/**
+ * When the lower DBUS level (dbus_usb_os.c) signals this event, the higher DBUS level has to be
+ * notified.
+ */
+static void
+dbus_usb_send_irb_timeout(void *handle, dbus_irb_tx_t *txirb)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->cbs && usb_info->cbs->send_irb_timeout)
+		usb_info->cbs->send_irb_timeout(usb_info->cbarg, txirb);
+}
+
+/**
+ * When the lower DBUS level (dbus_usb_os.c) signals this event, the higher DBUS level has to be
+ * notified.
+ */
+static void
+dbus_usb_send_irb_complete(void *handle, dbus_irb_tx_t *txirb, int status)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->cbs && usb_info->cbs->send_irb_complete)
+		usb_info->cbs->send_irb_complete(usb_info->cbarg, txirb, status);
+}
+
+/**
+ * When the lower DBUS level (dbus_usb_os.c) signals this event, the higher DBUS level has to be
+ * notified.
+ */
+static void
+dbus_usb_recv_irb_complete(void *handle, dbus_irb_rx_t *rxirb, int status)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->cbs && usb_info->cbs->recv_irb_complete)
+		usb_info->cbs->recv_irb_complete(usb_info->cbarg, rxirb, status);
+}
+
+/** Lower DBUS level (dbus_usb_os.c) requests a free IRB. Pass this on to the higher DBUS level. */
+static struct dbus_irb*
+dbus_usb_getirb(void *handle, bool send)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	if (usb_info == NULL)
+		return NULL;
+
+	if (usb_info->cbs && usb_info->cbs->getirb)
+		return usb_info->cbs->getirb(usb_info->cbarg, send);
+
+	return NULL;
+}
+
+/**
+ * When the lower DBUS level (dbus_usb_os.c) signals this event, the higher DBUS level has to be
+ * notified.
+ */
+static void
+dbus_usb_rxerr_indicate(void *handle, bool on)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->cbs && usb_info->cbs->rxerr_indicate)
+		usb_info->cbs->rxerr_indicate(usb_info->cbarg, on);
+}
+
+/**
+ * When the lower DBUS level (dbus_usb_os.c) signals this event, the higher DBUS level has to be
+ * notified.
+ */
+static void
+dbus_usb_errhandler(void *handle, int err)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->cbs && usb_info->cbs->errhandler)
+		usb_info->cbs->errhandler(usb_info->cbarg, err);
+}
+
+/**
+ * When the lower DBUS level (dbus_usb_os.c) signals this event, the higher DBUS level has to be
+ * notified.
+ */
+static void
+dbus_usb_ctl_complete(void *handle, int type, int status)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->cbs && usb_info->cbs->ctl_complete)
+		usb_info->cbs->ctl_complete(usb_info->cbarg, type, status);
+}
+
+/**
+ * When the lower DBUS level (dbus_usb_os.c) signals this event, the higher DBUS level has to be
+ * notified.
+ */
+static void
+dbus_usb_state_change(void *handle, int state)
+{
+	usb_info_t *usb_info = (usb_info_t *) handle;
+
+	if (usb_info == NULL)
+		return;
+
+	if (usb_info->cbs && usb_info->cbs->state_change)
+		usb_info->cbs->state_change(usb_info->cbarg, state);
+}
+
+/** called by higher DBUS level (dbus.c) */
+static int
+dbus_usb_iovar_op(void *bus, const char *name,
+	void *params, int plen, void *arg, int len, bool set)
+{
+	int err = DBUS_OK;
+
+	err = dbus_iovar_process((usb_info_t*)bus, name, params, plen, arg, len, set);
+	return err;
+}
+
+/** process iovar request from higher DBUS level */
+static int
+dbus_iovar_process(usb_info_t* usbinfo, const char *name,
+                 void *params, int plen, void *arg, int len, bool set)
+{
+	const bcm_iovar_t *vi = NULL;
+	int bcmerror = 0;
+	int val_size;
+	uint32 actionid;
+
+	DBUSTRACE(("%s: Enter\n", __FUNCTION__));
+
+	ASSERT(name);
+	ASSERT(len >= 0);
+
+	/* Get MUST have return space */
+	ASSERT(set || (arg && len));
+
+	/* Set does NOT take qualifiers */
+	ASSERT(!set || (!params && !plen));
+
+	/* Look up var locally; if not found pass to host driver */
+	if ((vi = bcm_iovar_lookup(dhdusb_iovars, name)) == NULL) {
+		/* Not Supported */
+		bcmerror = BCME_UNSUPPORTED;
+		DBUSTRACE(("%s: IOVAR %s is not supported\n", name, __FUNCTION__));
+		goto exit;
+
+	}
+
+	DBUSTRACE(("%s: %s %s, len %d plen %d\n", __FUNCTION__,
+	         name, (set ? "set" : "get"), len, plen));
+
+	/* set up 'params' pointer in case this is a set command so that
+	 * the convenience int and bool code can be common to set and get
+	 */
+	if (params == NULL) {
+		params = arg;
+		plen = len;
+	}
+
+	if (vi->type == IOVT_VOID)
+		val_size = 0;
+	else if (vi->type == IOVT_BUFFER)
+		val_size = len;
+	else
+		/* all other types are integer sized */
+		val_size = sizeof(int);
+
+	actionid = set ? IOV_SVAL(vi->varid) : IOV_GVAL(vi->varid);
+	bcmerror = dbus_usb_doiovar(usbinfo, vi, actionid,
+		name, params, plen, arg, len, val_size);
+
+exit:
+	return bcmerror;
+} /* dbus_iovar_process */
+
+static int
+dbus_usb_doiovar(usb_info_t *bus, const bcm_iovar_t *vi, uint32 actionid, const char *name,
+                void *params, int plen, void *arg, int len, int val_size)
+{
+	int bcmerror = 0;
+	int32 int_val = 0;
+	int32 int_val2 = 0;
+	bool bool_val = 0;
+
+	DBUSTRACE(("%s: Enter, action %d name %s params %p plen %d arg %p len %d val_size %d\n",
+	           __FUNCTION__, actionid, name, params, plen, arg, len, val_size));
+
+	if ((bcmerror = bcm_iovar_lencheck(vi, arg, len, IOV_ISSET(actionid))) != 0)
+		goto exit;
+
+	if (plen >= (int)sizeof(int_val))
+		bcopy(params, &int_val, sizeof(int_val));
+
+	if (plen >= (int)sizeof(int_val) * 2)
+		bcopy((void*)((uintptr)params + sizeof(int_val)), &int_val2, sizeof(int_val2));
+
+	bool_val = (int_val != 0) ? TRUE : FALSE;
+
+	switch (actionid) {
+
+	case IOV_SVAL(IOV_MEMBYTES):
+	case IOV_GVAL(IOV_MEMBYTES):
+	{
+		uint32 address;
+		uint size, dsize;
+		uint8 *data;
+
+		bool set = (actionid == IOV_SVAL(IOV_MEMBYTES));
+
+		ASSERT(plen >= 2*sizeof(int));
+
+		address = (uint32)int_val;
+		BCM_REFERENCE(address);
+		bcopy((char *)params + sizeof(int_val), &int_val, sizeof(int_val));
+		size = (uint)int_val;
+
+		/* Do some validation */
+		dsize = set ? plen - (2 * sizeof(int)) : len;
+		if (dsize < size) {
+			DBUSTRACE(("%s: error on %s membytes, addr 0x%08x size %d dsize %d\n",
+			           __FUNCTION__, (set ? "set" : "get"), address, size, dsize));
+			bcmerror = BCME_BADARG;
+			break;
+		}
+		DBUSTRACE(("%s: Request to %s %d bytes at address 0x%08x\n", __FUNCTION__,
+		          (set ? "write" : "read"), size, address));
+
+		/* Generate the actual data pointer */
+		data = set ? (uint8*)params + 2 * sizeof(int): (uint8*)arg;
+
+		/* Call to do the transfer */
+		bcmerror = dbus_usb_dl_writeimage(BUS_INFO(bus, usb_info_t), data, size);
+	}
+		break;
+
+
+	case IOV_SVAL(IOV_SET_DOWNLOAD_STATE):
+
+		if (bool_val == TRUE) {
+			bcmerror = dbus_usb_dlneeded(bus);
+			dbus_usb_rdl_dwnld_state(BUS_INFO(bus, usb_info_t));
+		} else {
+			usb_info_t *usbinfo = BUS_INFO(bus, usb_info_t);
+			bcmerror = dbus_usb_dlrun(bus);
+			usbinfo->pub->busstate = DBUS_STATE_DL_DONE;
+		}
+		break;
+
+	case IOV_SVAL(IOV_VARS):
+		bcmerror = dhdusb_downloadvars(BUS_INFO(bus, usb_info_t), arg, len);
+		break;
+#ifdef DBUS_USB_LOOPBACK
+	case IOV_SVAL(IOV_LOOPBACK_TX):
+			bcmerror = dbus_usbos_loopback_tx(BUS_INFO(bus, usb_info_t), int_val,
+			  int_val2);
+			break;
+#endif
+	default:
+		bcmerror = BCME_UNSUPPORTED;
+		break;
+	}
+
+exit:
+	return bcmerror;
+} /* dbus_usb_doiovar */
+
+/** higher DBUS level (dbus.c) wants to set NVRAM variables in dongle */
+static int
+dhdusb_downloadvars(usb_info_t *bus, void *arg, int len)
+{
+	int bcmerror = 0;
+	uint32 varsize;
+	uint32 varaddr;
+	uint32 varsizew;
+
+	if (!len) {
+		bcmerror = BCME_BUFTOOSHORT;
+		goto err;
+	}
+
+	/* RAM size is not set. Set it at dbus_usb_dlneeded */
+	if (!bus->rdlram_size)
+		bcmerror = BCME_ERROR;
+
+	/* Even if there are no vars are to be written, we still need to set the ramsize. */
+	varsize = len ? ROUNDUP(len, 4) : 0;
+	varaddr = (bus->rdlram_size - 4) - varsize;
+
+	/* Write the vars list */
+	DBUSTRACE(("WriteVars: @%x varsize=%d\n", varaddr, varsize));
+	bcmerror = dbus_write_membytes(bus->usbosl_info, TRUE, (varaddr + bus->rdlram_base_addr),
+		arg, varsize);
+
+	/* adjust to the user specified RAM */
+	DBUSTRACE(("Usable memory size: %d\n", bus->rdlram_size));
+	DBUSTRACE(("Vars are at %d, orig varsize is %d\n", varaddr, varsize));
+
+	varsize = ((bus->rdlram_size - 4) - varaddr);
+
+	/*
+	 * Determine the length token:
+	 * Varsize, converted to words, in lower 16-bits, checksum in upper 16-bits.
+	 */
+	if (bcmerror) {
+		varsizew = 0;
+	} else {
+		varsizew = varsize / 4;
+		varsizew = (~varsizew << 16) | (varsizew & 0x0000FFFF);
+		varsizew = htol32(varsizew);
+	}
+
+	DBUSTRACE(("New varsize is %d, length token=0x%08x\n", varsize, varsizew));
+
+	/* Write the length token to the last word */
+	bcmerror = dbus_write_membytes(bus->usbosl_info, TRUE, ((bus->rdlram_size - 4) +
+		bus->rdlram_base_addr), (uint8*)&varsizew, 4);
+err:
+	return bcmerror;
+} /* dbus_usb_doiovar */
+
+/**
+ * After downloading firmware into dongle and starting it, we need to know if the firmware is
+ * indeed up and running.
+ */
+static int
+dbus_usb_resetcfg(usb_info_t *usbinfo)
+{
+	void *osinfo;
+	bootrom_id_t id;
+	uint16 waittime = 0;
+
+	uint32 starttime = 0;
+	uint32 endtime = 0;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (usbinfo == NULL)
+		return DBUS_ERR;
+
+	osinfo = usbinfo->usbosl_info;
+	ASSERT(osinfo);
+
+	/* Give dongle chance to boot */
+	dbus_usbos_wait(osinfo, USB_SFLASH_DLIMAGE_SPINWAIT);
+	waittime = USB_SFLASH_DLIMAGE_SPINWAIT;
+	while (waittime < USB_DLIMAGE_RETRY_TIMEOUT) {
+
+		starttime = OSL_SYSUPTIME();
+
+		id.chip = 0xDEAD;       /* Get the ID */
+		dbus_usbos_dl_cmd(osinfo, DL_GETVER, &id, sizeof(bootrom_id_t));
+		id.chip = ltoh32(id.chip);
+
+		endtime = OSL_SYSUPTIME();
+		waittime += (endtime - starttime);
+
+		if (id.chip == POSTBOOT_ID)
+			break;
+	}
+
+	if (id.chip == POSTBOOT_ID) {
+		DBUSERR(("%s: download done. Bootup time = %d ms postboot chip 0x%x/rev 0x%x\n",
+			__FUNCTION__, waittime, id.chip, id.chiprev));
+
+		dbus_usbos_dl_cmd(osinfo, DL_RESETCFG, &id, sizeof(bootrom_id_t));
+
+		dbus_usbos_wait(osinfo, USB_RESETCFG_SPINWAIT);
+		return DBUS_OK;
+	} else {
+		DBUSERR(("%s: Cannot talk to Dongle. Wait time = %d ms. Firmware is not UP \n",
+			__FUNCTION__, waittime));
+		return DBUS_ERR;
+	}
+
+	return DBUS_OK;
+}
+
+/** before firmware download, the dongle has to be prepared to receive the fw image */
+static int
+dbus_usb_rdl_dwnld_state(usb_info_t *usbinfo)
+{
+	void *osinfo = usbinfo->usbosl_info;
+	rdl_state_t state;
+	int err = DBUS_OK;
+
+	/* 1) Prepare USB boot loader for runtime image */
+	dbus_usbos_dl_cmd(osinfo, DL_START, &state, sizeof(rdl_state_t));
+
+	state.state = ltoh32(state.state);
+	state.bytes = ltoh32(state.bytes);
+
+	/* 2) Check we are in the Waiting state */
+	if (state.state != DL_WAITING) {
+		DBUSERR(("%s: Failed to DL_START\n", __FUNCTION__));
+		err = DBUS_ERR;
+		goto fail;
+	}
+
+fail:
+	return err;
+}
+
+/**
+ * Dongle contains bootcode in ROM but firmware is (partially) contained in dongle RAM. Therefore,
+ * firmware has to be downloaded into dongle RAM.
+ */
+static int
+dbus_usb_dl_writeimage(usb_info_t *usbinfo, uint8 *fw, int fwlen)
+{
+	osl_t *osh = usbinfo->pub->osh;
+	void *osinfo = usbinfo->usbosl_info;
+	unsigned int sendlen, sent, dllen;
+	char *bulkchunk = NULL, *dlpos;
+	rdl_state_t state;
+	int err = DBUS_OK;
+	bootrom_id_t id;
+	uint16 wait, wait_time;
+	uint32 dl_trunk_size = RDL_CHUNK;
+
+	if (BCM4350_CHIP(usbinfo->pub->attrib.devid))
+		dl_trunk_size = RDL_CHUNK_MAX;
+
+	while (!bulkchunk) {
+		bulkchunk = MALLOC(osh, dl_trunk_size);
+		if (dl_trunk_size == RDL_CHUNK)
+			break;
+		if (!bulkchunk) {
+			dl_trunk_size /= 2;
+			if (dl_trunk_size < RDL_CHUNK)
+				dl_trunk_size = RDL_CHUNK;
+		}
+	}
+
+	if (bulkchunk == NULL) {
+		err = DBUS_ERR;
+		goto fail;
+	}
+
+	sent = 0;
+	dlpos = fw;
+	dllen = fwlen;
+
+	/* Get chip id and rev */
+	id.chip = usbinfo->pub->attrib.devid;
+	id.chiprev = usbinfo->pub->attrib.chiprev;
+
+	DBUSTRACE(("enter %s: fwlen=%d\n", __FUNCTION__, fwlen));
+
+	dbus_usbos_dl_cmd(osinfo, DL_GETSTATE, &state, sizeof(rdl_state_t));
+
+	/* 3) Load the image */
+	while ((sent < dllen)) {
+		/* Wait until the usb device reports it received all the bytes we sent */
+
+		if (sent < dllen) {
+			if ((dllen-sent) < dl_trunk_size)
+				sendlen = dllen-sent;
+			else
+				sendlen = dl_trunk_size;
+
+			/* simply avoid having to send a ZLP by ensuring we never have an even
+			 * multiple of 64
+			 */
+			if (!(sendlen % 64))
+				sendlen -= 4;
+
+			/* send data */
+			memcpy(bulkchunk, dlpos, sendlen);
+			if (!dbus_usbos_dl_send_bulk(osinfo, bulkchunk, sendlen)) {
+				err = DBUS_ERR;
+				goto fail;
+			}
+
+			dlpos += sendlen;
+			sent += sendlen;
+			DBUSTRACE(("%s: sendlen %d\n", __FUNCTION__, sendlen));
+		}
+
+		wait = 0;
+		wait_time = USB_SFLASH_DLIMAGE_SPINWAIT;
+		while (!dbus_usbos_dl_cmd(osinfo, DL_GETSTATE, &state,
+			sizeof(rdl_state_t))) {
+			if ((id.chip == 43236) && (id.chiprev == 0)) {
+				DBUSERR(("%s: 43236a0 SFlash delay, waiting for dongle crc check "
+					 "completion!!!\n", __FUNCTION__));
+				dbus_usbos_wait(osinfo, wait_time);
+				wait += wait_time;
+				if (wait >= USB_SFLASH_DLIMAGE_LIMIT) {
+					DBUSERR(("%s: DL_GETSTATE Failed xxxx\n", __FUNCTION__));
+					err = DBUS_ERR;
+					goto fail;
+					break;
+				}
+			} else {
+				DBUSERR(("%s: DL_GETSTATE Failed xxxx\n", __FUNCTION__));
+				err = DBUS_ERR;
+				goto fail;
+			}
+		}
+
+		state.state = ltoh32(state.state);
+		state.bytes = ltoh32(state.bytes);
+
+		/* restart if an error is reported */
+		if ((state.state == DL_BAD_HDR) || (state.state == DL_BAD_CRC)) {
+			DBUSERR(("%s: Bad Hdr or Bad CRC\n", __FUNCTION__));
+			err = DBUS_ERR;
+			goto fail;
+		}
+
+	}
+fail:
+	if (bulkchunk)
+		MFREE(osh, bulkchunk, dl_trunk_size);
+
+	return err;
+} /* dbus_usb_dl_writeimage */
+
+/** Higher level DBUS layer (dbus.c) requests this layer to download image into dongle */
+static int
+dbus_usb_dlstart(void *bus, uint8 *fw, int len)
+{
+	usb_info_t *usbinfo = BUS_INFO(bus, usb_info_t);
+	int err;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (usbinfo == NULL)
+		return DBUS_ERR;
+
+	if (USB_DEV_ISBAD(usbinfo))
+		return DBUS_ERR;
+
+	err = dbus_usb_rdl_dwnld_state(usbinfo);
+
+	if (DBUS_OK == err) {
+	err = dbus_usb_dl_writeimage(usbinfo, fw, len);
+	if (err == DBUS_OK)
+		usbinfo->pub->busstate = DBUS_STATE_DL_DONE;
+	else
+		usbinfo->pub->busstate = DBUS_STATE_DL_PENDING;
+	} else
+		usbinfo->pub->busstate = DBUS_STATE_DL_PENDING;
+
+	return err;
+}
+
+static bool
+dbus_usb_update_chipinfo(usb_info_t *usbinfo, uint32 chip)
+{
+	bool retval = TRUE;
+	/* based on the CHIP Id, store the ram size which is needed for NVRAM download. */
+	switch (chip) {
+
+		case 0x4319:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_4319;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_4319;
+			break;
+
+		case 0x4329:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_4329;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_4329;
+			break;
+
+		case 43234:
+		case 43235:
+		case 43236:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_43236;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_43236;
+			break;
+
+		case 0x4328:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_4328;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_4328;
+			break;
+
+		case 0x4322:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_4322;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_4322;
+			break;
+
+		case 0x4360:
+		case 0xAA06:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_4360;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_4360;
+			break;
+
+		case 43242:
+		case 43243:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_43242;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_43242;
+			break;
+
+		case 43143:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_43143;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_43143;
+			break;
+
+		case 0x4350:
+		case 43556:
+		case 43558:
+		case 43569:
+			usbinfo->rdlram_size = RDL_RAM_SIZE_4350;
+			usbinfo->rdlram_base_addr = RDL_RAM_BASE_4350;
+			break;
+
+		case POSTBOOT_ID:
+			break;
+
+		default:
+			DBUSERR(("%s: Chip 0x%x Ram size is not known\n", __FUNCTION__, chip));
+			retval = FALSE;
+			break;
+
+	}
+
+	return retval;
+} /* dbus_usb_update_chipinfo */
+
+/** higher DBUS level (dbus.c) wants to know if firmware download is required. */
+static bool
+dbus_usb_dlneeded(void *bus)
+{
+	usb_info_t *usbinfo = BUS_INFO(bus, usb_info_t);
+	void *osinfo;
+	bootrom_id_t id;
+	bool dl_needed = TRUE;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (usbinfo == NULL)
+		return FALSE;
+
+	osinfo = usbinfo->usbosl_info;
+	ASSERT(osinfo);
+
+	/* Check if firmware downloaded already by querying runtime ID */
+	id.chip = 0xDEAD;
+	dbus_usbos_dl_cmd(osinfo, DL_GETVER, &id, sizeof(bootrom_id_t));
+
+	id.chip = ltoh32(id.chip);
+	id.chiprev = ltoh32(id.chiprev);
+
+	if (FALSE == dbus_usb_update_chipinfo(usbinfo, id.chip)) {
+		dl_needed = FALSE;
+		goto exit;
+	}
+
+	DBUSERR(("%s: chip 0x%x rev 0x%x\n", __FUNCTION__, id.chip, id.chiprev));
+	if (id.chip == POSTBOOT_ID) {
+		/* This code is  needed to support two enumerations on USB1.1 scenario */
+		DBUSERR(("%s: Firmware already downloaded\n", __FUNCTION__));
+
+		dbus_usbos_dl_cmd(osinfo, DL_RESETCFG, &id, sizeof(bootrom_id_t));
+		dl_needed = FALSE;
+		if (usbinfo->pub->busstate == DBUS_STATE_DL_PENDING)
+			usbinfo->pub->busstate = DBUS_STATE_DL_DONE;
+	} else {
+		usbinfo->pub->attrib.devid = id.chip;
+		usbinfo->pub->attrib.chiprev = id.chiprev;
+	}
+
+exit:
+	return dl_needed;
+}
+
+/** After issuing firmware download, higher DBUS level (dbus.c) wants to start the firmware. */
+static int
+dbus_usb_dlrun(void *bus)
+{
+	usb_info_t *usbinfo = BUS_INFO(bus, usb_info_t);
+	void *osinfo;
+	rdl_state_t state;
+	int err = DBUS_OK;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (usbinfo == NULL)
+		return DBUS_ERR;
+
+	if (USB_DEV_ISBAD(usbinfo))
+		return DBUS_ERR;
+
+	osinfo = usbinfo->usbosl_info;
+	ASSERT(osinfo);
+
+	/* Check we are runnable */
+	dbus_usbos_dl_cmd(osinfo, DL_GETSTATE, &state, sizeof(rdl_state_t));
+
+	state.state = ltoh32(state.state);
+	state.bytes = ltoh32(state.bytes);
+
+	/* Start the image */
+	if (state.state == DL_RUNNABLE) {
+		DBUSTRACE(("%s: Issue DL_GO\n", __FUNCTION__));
+		dbus_usbos_dl_cmd(osinfo, DL_GO, &state, sizeof(rdl_state_t));
+
+		if (usbinfo->pub->attrib.devid == TEST_CHIP)
+			dbus_usbos_wait(osinfo, USB_DLGO_SPINWAIT);
+
+		dbus_usb_resetcfg(usbinfo);
+		/* The Donlge may go for re-enumeration. */
+	} else {
+		DBUSERR(("%s: Dongle not runnable\n", __FUNCTION__));
+		err = DBUS_ERR;
+	}
+
+	return err;
+}
+
+/**
+ * As preparation for firmware download, higher DBUS level (dbus.c) requests the firmware image
+ * to be used for the type of dongle detected. Directly called by dbus.c (so not via a callback
+ * construction)
+ */
+void
+dbus_bus_fw_get(void *bus, uint8 **fw, int *fwlen, int *decomp)
+{
+	usb_info_t *usbinfo = BUS_INFO(bus, usb_info_t);
+	unsigned int devid;
+	unsigned int crev;
+
+	devid = usbinfo->pub->attrib.devid;
+	crev = usbinfo->pub->attrib.chiprev;
+
+	*fw = NULL;
+	*fwlen = 0;
+
+	switch (devid) {
+	case BCM43236_CHIP_ID:
+	case BCM43235_CHIP_ID:
+	case BCM43234_CHIP_ID:
+	case BCM43238_CHIP_ID: {
+		if (crev == 3 || crev == 2 || crev == 1) {
+#ifdef EMBED_IMAGE_43236b
+			*fw = (uint8 *)dlarray_43236b;
+			*fwlen = sizeof(dlarray_43236b);
+
+#endif
+		}
+		} break;
+	case BCM4360_CHIP_ID:
+	case BCM4352_CHIP_ID:
+	case BCM43526_CHIP_ID:
+#ifdef EMBED_IMAGE_43526a
+		if (crev <= 2) {
+			*fw = (uint8 *)dlarray_43526a;
+			*fwlen = sizeof(dlarray_43526a);
+		}
+#endif
+#ifdef EMBED_IMAGE_43526b
+		if (crev > 2) {
+			*fw = (uint8 *)dlarray_43526b;
+			*fwlen = sizeof(dlarray_43526b);
+		}
+#endif
+		break;
+
+	case BCM43242_CHIP_ID:
+#ifdef EMBED_IMAGE_43242a0
+		*fw = (uint8 *)dlarray_43242a0;
+		*fwlen = sizeof(dlarray_43242a0);
+#endif
+		break;
+
+	case BCM43143_CHIP_ID:
+#ifdef EMBED_IMAGE_43143a0
+		*fw = (uint8 *)dlarray_43143a0;
+		*fwlen = sizeof(dlarray_43143a0);
+#endif
+#ifdef EMBED_IMAGE_43143b0
+		*fw = (uint8 *)dlarray_43143b0;
+		*fwlen = sizeof(dlarray_43143b0);
+#endif
+		break;
+
+	case BCM4350_CHIP_ID:
+	case BCM4354_CHIP_ID:
+	case BCM43556_CHIP_ID:
+	case BCM43558_CHIP_ID:
+	case BCM43566_CHIP_ID:
+	case BCM43568_CHIP_ID:
+	case BCM43570_CHIP_ID:
+	case BCM4358_CHIP_ID:
+#ifdef EMBED_IMAGE_4350a0
+		if (crev == 0) {
+			*fw = (uint8 *)dlarray_4350a0;
+			*fwlen = sizeof(dlarray_4350a0);
+		}
+#endif
+#ifdef EMBED_IMAGE_4350b0
+		if (crev == 1) {
+			*fw = (uint8 *)dlarray_4350b0;
+			*fwlen = sizeof(dlarray_4350b0);
+		}
+#endif
+#ifdef EMBED_IMAGE_4350b1
+		if (crev == 2) {
+			*fw = (uint8 *)dlarray_4350b1;
+			*fwlen = sizeof(dlarray_4350b1);
+		}
+#endif
+#ifdef EMBED_IMAGE_43556b1
+		if (crev == 2) {
+			*fw = (uint8 *)dlarray_43556b1;
+			*fwlen = sizeof(dlarray_43556b1);
+		}
+#endif
+#ifdef EMBED_IMAGE_4350c0
+		if (crev == 3) {
+			*fw = (uint8 *)dlarray_4350c0;
+			*fwlen = sizeof(dlarray_4350c0);
+		}
+#endif /* EMBED_IMAGE_4350c0 */
+#ifdef EMBED_IMAGE_4350c1
+		if (crev == 4) {
+			*fw = (uint8 *)dlarray_4350c1;
+			*fwlen = sizeof(dlarray_4350c1);
+		}
+#endif /* EMBED_IMAGE_4350c1 */
+		break;
+	case BCM43569_CHIP_ID:
+#ifdef EMBED_IMAGE_43569a0
+		if (crev == 0) {
+			*fw = (uint8 *)dlarray_43569a0;
+			*fwlen = sizeof(dlarray_43569a0);
+		}
+#endif /* EMBED_IMAGE_43569a0 */
+		break;
+	default:
+#ifdef EMBED_IMAGE_GENERIC
+		*fw = (uint8 *)dlarray;
+		*fwlen = sizeof(dlarray);
+#endif
+		break;
+	}
+} /* dbus_bus_fw_get */
+
+#ifdef BCM_DNGL_EMBEDIMAGE
+static bool
+dbus_usb_device_exists(void *bus)
+{
+	usb_info_t *usbinfo = BUS_INFO(bus, usb_info_t);
+	void *osinfo;
+	bootrom_id_t id;
+
+	DBUSTRACE(("%s\n", __FUNCTION__));
+
+	if (usbinfo == NULL)
+		return FALSE;
+
+	osinfo = usbinfo->usbosl_info;
+	ASSERT(osinfo);
+
+	id.chip = 0xDEAD;
+	/* Query device to see if we get a response */
+	dbus_usbos_dl_cmd(osinfo, DL_GETVER, &id, sizeof(bootrom_id_t));
+
+	usbinfo->pub->attrib.devid = id.chip;
+	if (id.chip == 0xDEAD)
+		return FALSE;
+	else
+		return TRUE;
+}
+#endif /* BCM_DNGL_EMBEDIMAGE */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus_usb_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus_usb_linux.c
new file mode 100644
index 000000000000..ad464ec9daa1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dbus_usb_linux.c
@@ -0,0 +1,4600 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Dongle BUS interface
+ * USB Linux Implementation
+ *
+ * Copyright (C) 1999-2018, Broadcom Corporation
+ * 
+ *      Unless you and Broadcom execute a separate written software license
+ * agreement governing use of this software, this software is licensed to you
+ * under the terms of the GNU General Public License version 2 (the "GPL"),
+ * available at http://www.broadcom.com/licenses/GPLv2.php, with the
+ * following added to such license:
+ * 
+ *      As a special exception, the copyright holders of this software give you
+ * permission to link this software with independent modules, and to copy and
+ * distribute the resulting executable under terms of your choice, provided that
+ * you also meet, for each linked independent module, the terms and conditions of
+ * the license of that module.  An independent module is a module which is not
+ * derived from this software.  The special exception does not apply to any
+ * modifications of the software.
+ * 
+ *      Notwithstanding the above, under no circumstances may you combine this
+ * software in any way with any other Broadcom software provided under a license
+ * other than the GPL, without Broadcom's express prior written consent.
+ *
+ *
+ * <<Broadcom-WL-IPTag/Open:>>
+ *
+ * $Id: dbus_usb_linux.c 708808 2018-11-27 03:12:35Z $
+ */
+
+/**
+ * @file @brief
+ * This file contains DBUS code that is USB *and* OS (Linux) specific. DBUS is a Broadcom
+ * proprietary host specific abstraction layer.
+ */
+
+#include <typedefs.h>
+#include <osl.h>
+
+/**
+ * DBUS_LINUX_RXDPC is created for router platform performance tuning. A separate thread is created
+ * to handle USB RX and avoid the call chain getting too long and enhance cache hit rate.
+ *
+ * DBUS_LINUX_RXDPC setting is in wlconfig file.
+ */
+
+/*
+ * If DBUS_LINUX_RXDPC is off, spin_lock_bh() for CTFPOOL in
+ * linux_osl.c has to be changed to spin_lock_irqsave() because
+ * PKTGET/PKTFREE are no longer in bottom half.
+ *
+ * Right now we have another queue rpcq in wl_linux.c. Maybe we
+ * can eliminate that one to reduce the overhead.
+ *
+ * Enabling 2nd EP and DBUS_LINUX_RXDPC causing traffic from
+ * both EP's to be queued in the same rx queue. If we want
+ * RXDPC to work with 2nd EP. The EP for RPC call return
+ * should bypass the dpc and go directly up.
+ */
+
+/* #define DBUS_LINUX_RXDPC */
+
+/* Dbus histogram for ntxq, nrxq, dpc parameter tuning */
+/* #define DBUS_LINUX_HIST */
+
+#include <usbrdl.h>
+#include <bcmendian.h>
+#include <linux/init.h>
+#include <linux/kernel.h>
+#include <linux/slab.h>
+#include <linux/usb.h>
+#include <linux/skbuff.h>
+#include <linux/netdevice.h>
+#include <linux/random.h>
+#include <linux/spinlock.h>
+#include <linux/list.h>
+#include <asm/uaccess.h>
+#include <asm/unaligned.h>
+#include <dbus.h>
+#include <bcmutils.h>
+#include <bcmdevs.h>
+#include <linux/usb.h>
+#include <usbrdl.h>
+#include <linux/firmware.h>
+#ifdef DBUS_LINUX_RXDPC
+#include <linux/sched.h>
+#endif
+
+#if defined(USBOS_THREAD) || defined(USBOS_TX_THREAD)
+
+/**
+ * The usb-thread is designed to provide currency on multiprocessors and SMP linux kernels. On the
+ * dual cores platform, the WLAN driver, without threads, executed only on CPU0. The driver consumed
+ * almost of 100% on CPU0, while CPU1 remained idle. The behavior was observed on Broadcom's STB.
+ *
+ * The WLAN driver consumed most of CPU0 and not CPU1 because tasklets/queues, software irq, and
+ * hardware irq are executing from CPU0, only. CPU0 became the system's bottle-neck. TPUT is lower
+ * and system's responsiveness is slower.
+ *
+ * To improve system responsiveness and TPUT usb-thread was implemented. The system's threads could
+ * be scheduled to run on any core. One core could be processing data in the usb-layer and the other
+ * core could be processing data in the wl-layer.
+ *
+ * For further info see [WlThreadAndUsbThread] Twiki.
+ */
+
+#include <linux/kthread.h>
+#include <linux/interrupt.h>
+#include <linux/irq.h>
+#include <asm/hardirq.h>
+#include <linux/list.h>
+#include <linux_osl.h>
+#endif /* USBOS_THREAD || USBOS_TX_THREAD */
+
+
+#ifdef DBUS_LINUX_RXDPC
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 25))
+#define RESCHED()   _cond_resched()
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 0))
+#define RESCHED()   cond_resched()
+#else
+#define RESCHED()   __cond_resched()
+#endif /* LINUX_VERSION_CODE  */
+#endif	/* DBUS_LINUX_RXDPC */
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 0))
+#define KERNEL26
+#endif
+
+/**
+ * Starting with the 3.10 kernel release, dynamic PM support for USB is present whenever
+ * the kernel was built with CONFIG_PM_RUNTIME enabled. The CONFIG_USB_SUSPEND option has
+ * been eliminated.
+ */
+#if ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 21)) && defined(CONFIG_USB_SUSPEND)) \
+	|| ((LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0)) && defined(CONFIG_PM_RUNTIME))
+/* For USB power management support, see Linux kernel: Documentation/usb/power-management.txt */
+#define USB_SUSPEND_AVAILABLE
+#endif
+
+/* Define alternate fw/nvram paths used in Android */
+#define CONFIG_ANDROID_BCMDHD_FW_PATH "broadcom/dhd/firmware/fw.bin.trx"
+#define CONFIG_ANDROID_BCMDHD_NVRAM_PATH "broadcom/dhd/nvrams/nvm.txt"
+
+static inline int usb_submit_urb_linux(struct urb *urb)
+{
+
+#ifdef BCM_MAX_URB_LEN
+	if (urb && (urb->transfer_buffer_length > BCM_MAX_URB_LEN)) {
+		DBUSERR(("URB transfer length=%d exceeded %d ra=%p\n", urb->transfer_buffer_length,
+		BCM_MAX_URB_LEN, __builtin_return_address(0)));
+		return DBUS_ERR;
+	}
+#endif
+
+#ifdef KERNEL26
+	return usb_submit_urb(urb, GFP_ATOMIC);
+#else
+	return usb_submit_urb(urb);
+#endif
+
+}
+
+#define USB_SUBMIT_URB(urb) usb_submit_urb_linux(urb)
+
+#ifdef KERNEL26
+
+#define USB_ALLOC_URB()				usb_alloc_urb(0, GFP_ATOMIC)
+#define USB_UNLINK_URB(urb)			(usb_kill_urb(urb))
+#define USB_FREE_URB(urb)			(usb_free_urb(urb))
+#define USB_REGISTER()				usb_register(&dbus_usbdev)
+#define USB_DEREGISTER()			usb_deregister(&dbus_usbdev)
+
+#ifdef USB_SUSPEND_AVAILABLE
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 33))
+#define USB_AUTOPM_SET_INTERFACE(intf)		usb_autopm_set_interface(intf)
+#else
+#define USB_ENABLE_AUTOSUSPEND(udev)		usb_enable_autosuspend(udev)
+#define USB_DISABLE_AUTOSUSPEND(udev)       usb_disable_autosuspend(udev)
+#endif  /* LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 33))  */
+
+#define USB_AUTOPM_GET_INTERFACE(intf)		usb_autopm_get_interface(intf)
+#define USB_AUTOPM_PUT_INTERFACE(intf)		usb_autopm_put_interface(intf)
+#define USB_AUTOPM_GET_INTERFACE_ASYNC(intf)	usb_autopm_get_interface_async(intf)
+#define USB_AUTOPM_PUT_INTERFACE_ASYNC(intf)	usb_autopm_put_interface_async(intf)
+#define USB_MARK_LAST_BUSY(dev)			usb_mark_last_busy(dev)
+
+#else /* USB_SUSPEND_AVAILABLE */
+
+#define USB_AUTOPM_GET_INTERFACE(intf)		do {} while (0)
+#define USB_AUTOPM_PUT_INTERFACE(intf)		do {} while (0)
+#define USB_AUTOPM_GET_INTERFACE_ASYNC(intf)	do {} while (0)
+#define USB_AUTOPM_PUT_INTERFACE_ASYNC(intf)	do {} while (0)
+#define USB_MARK_LAST_BUSY(dev)			do {} while (0)
+#endif /* USB_SUSPEND_AVAILABLE */
+
+#define USB_CONTROL_MSG(dev, pipe, request, requesttype, value, index, data, size, timeout) \
+	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), \
+	(data), (size), (timeout))
+#define USB_BULK_MSG(dev, pipe, data, len, actual_length, timeout) \
+	usb_bulk_msg((dev), (pipe), (data), (len), (actual_length), (timeout))
+#define USB_BUFFER_ALLOC(dev, size, mem, dma)	usb_buffer_alloc(dev, size, mem, dma)
+#define USB_BUFFER_FREE(dev, size, data, dma)	usb_buffer_free(dev, size, data, dma)
+
+#ifdef WL_URB_ZPKT
+#define URB_QUEUE_BULK   URB_ZERO_PACKET
+#else
+#define URB_QUEUE_BULK   0
+#endif /* WL_URB_ZPKT */
+
+#define CALLBACK_ARGS		struct urb *urb, struct pt_regs *regs
+#define CALLBACK_ARGS_DATA	urb, regs
+#define CONFIGDESC(usb)		(&((usb)->actconfig)->desc)
+#define IFPTR(usb, idx)		((usb)->actconfig->interface[idx])
+#define IFALTS(usb, idx)	(IFPTR((usb), (idx))->altsetting[0])
+#define IFDESC(usb, idx)	IFALTS((usb), (idx)).desc
+#define IFEPDESC(usb, idx, ep)	(IFALTS((usb), (idx)).endpoint[ep]).desc
+#ifdef DBUS_LINUX_RXDPC
+#define DAEMONIZE(a)		daemonize(a); allow_signal(SIGKILL); allow_signal(SIGTERM);
+#define SET_NICE(n)		set_user_nice(current, n)
+#endif
+#else /* KERNEL26 */
+
+#define USB_ALLOC_URB()				usb_alloc_urb(0)
+#define USB_UNLINK_URB(urb)			usb_unlink_urb(urb)
+#define USB_FREE_URB(urb)			(usb_free_urb(urb))
+#define USB_REGISTER()				usb_register(&dbus_usbdev)
+#define USB_DEREGISTER()			usb_deregister(&dbus_usbdev)
+#define USB_AUTOPM_GET_INTERFACE(intf)		do {} while (0)
+#define USB_AUTOPM_GET_INTERFACE_ASYNC(intf)	do {} while (0)
+#define USB_AUTOPM_PUT_INTERFACE_ASYNC(intf)	do {} while (0)
+#define USB_MARK_LAST_BUSY(dev)			do {} while (0)
+
+#define USB_CONTROL_MSG(dev, pipe, request, requesttype, value, index, data, size, timeout) \
+	usb_control_msg((dev), (pipe), (request), (requesttype), (value), (index), \
+	(data), (size), (timeout))
+#define USB_BUFFER_ALLOC(dev, size, mem, dma)  kmalloc(size, mem)
+#define USB_BUFFER_FREE(dev, size, data, dma)  kfree(data)
+
+#ifdef WL_URB_ZPKT
+#define URB_QUEUE_BULK   USB_QUEUE_BULK|URB_ZERO_PACKET
+#else
+#define URB_QUEUE_BULK   0
+#endif /*  WL_URB_ZPKT */
+
+#define CALLBACK_ARGS		struct urb *urb
+#define CALLBACK_ARGS_DATA	urb
+#define CONFIGDESC(usb)		((usb)->actconfig)
+#define IFPTR(usb, idx)		(&(usb)->actconfig->interface[idx])
+#define IFALTS(usb, idx)	((usb)->actconfig->interface[idx].altsetting[0])
+#define IFDESC(usb, idx)	IFALTS((usb), (idx))
+#define IFEPDESC(usb, idx, ep)	(IFALTS((usb), (idx)).endpoint[ep])
+
+#ifdef DBUS_LINUX_RXDPC
+#define DAEMONIZE(a)    daemonize();
+#define SET_NICE(n)     do {current->nice = (n);} while (0)
+#endif /* DBUS_LINUX_RXDPC */
+
+#endif /* KERNEL26 */
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 31))
+#define USB_SPEED_SUPER		5
+#endif  /* #if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 31)) */
+
+#define CONTROL_IF   0
+#define BULK_IF      0
+
+#ifdef BCMUSBDEV_COMPOSITE
+#define USB_COMPIF_MAX       4
+
+#define USB_CLASS_WIRELESS	0xe0
+#define USB_CLASS_MISC		0xef
+#define USB_SUBCLASS_COMMON	0x02
+#define USB_PROTO_IAD		0x01
+#define USB_PROTO_VENDOR	0xff
+
+#define USB_QUIRK_NO_SET_INTF   0x04 /* device does not support set_interface */
+#endif /* BCMUSBDEV_COMPOSITE */
+
+#define USB_SYNC_WAIT_TIMEOUT  300  /* ms */
+
+/* Private data kept in skb */
+#define SKB_PRIV(skb, idx)  (&((void **)skb->cb)[idx])
+#define SKB_PRIV_URB(skb)   (*(struct urb **)SKB_PRIV(skb, 0))
+
+#ifndef DBUS_USB_RXQUEUE_BATCH_ADD
+/* items to add each time within limit */
+#define DBUS_USB_RXQUEUE_BATCH_ADD            8
+#endif
+
+#ifndef DBUS_USB_RXQUEUE_LOWER_WATERMARK
+/* add a new batch req to rx queue when waiting item count reduce to this number */
+#define DBUS_USB_RXQUEUE_LOWER_WATERMARK      4
+#endif
+
+enum usbos_suspend_state {
+	USBOS_SUSPEND_STATE_DEVICE_ACTIVE = 0, /* Device is busy, won't allow suspend */
+	USBOS_SUSPEND_STATE_SUSPEND_PENDING,   /* Device is idle, can be suspended */
+	                                       /* Wating PM to suspend */
+	USBOS_SUSPEND_STATE_SUSPENDED          /* Device suspended */
+};
+
+enum usbos_request_state {
+	USBOS_REQUEST_STATE_UNSCHEDULED = 0,	/* USB TX request not scheduled */
+	USBOS_REQUEST_STATE_SCHEDULED,		/* USB TX request given to TX thread */
+	USBOS_REQUEST_STATE_SUBMITTED		/* USB TX request submitted */
+};
+
+typedef struct {
+	uint32 notification;
+	uint32 reserved;
+} intr_t;
+
+typedef struct {
+	dbus_pub_t *pub;
+
+	void *cbarg;
+	dbus_intf_callbacks_t *cbs;
+
+	/* Imported */
+	struct usb_device *usb;	/* USB device pointer from OS */
+	struct urb *intr_urb; /* URB for interrupt endpoint */
+	struct list_head req_rxfreeq;
+	struct list_head req_txfreeq;
+	struct list_head req_rxpostedq;	/* Posted down to USB driver for RX */
+	struct list_head req_txpostedq;	/* Posted down to USB driver for TX */
+	spinlock_t rxfree_lock; /* Lock for rx free list */
+	spinlock_t txfree_lock; /* Lock for tx free list */
+	spinlock_t rxposted_lock; /* Lock for rx posted list */
+	spinlock_t txposted_lock; /* Lock for tx posted list */
+	uint rx_pipe, tx_pipe, intr_pipe, rx_pipe2; /* Pipe numbers for USB I/O */
+	uint rxbuf_len;
+
+	struct list_head req_rxpendingq; /* RXDPC: Pending for dpc to send up */
+	spinlock_t rxpending_lock;	/* RXDPC: Lock for rx pending list */
+	long dpc_pid;
+	struct semaphore dpc_sem;
+	struct completion dpc_exited;
+	int rxpending;
+#if defined(DBUS_LINUX_HIST)
+	int	dpc_cnt, dpc_pktcnt, dpc_maxpktcnt;
+#endif
+
+	struct urb               *ctl_urb;
+	int                      ctl_in_pipe, ctl_out_pipe;
+	struct usb_ctrlrequest   ctl_write;
+	struct usb_ctrlrequest   ctl_read;
+	struct semaphore         ctl_lock;     /* Lock for CTRL transfers via tx_thread */
+#ifdef USBOS_TX_THREAD
+	enum usbos_request_state ctl_state;
+#endif /* USBOS_TX_THREAD */
+
+	spinlock_t rxlock;      /* Lock for rxq management */
+	spinlock_t txlock;      /* Lock for txq management */
+
+	int intr_size;          /* Size of interrupt message */
+	int interval;           /* Interrupt polling interval */
+	intr_t intr;            /* Data buffer for interrupt endpoint */
+
+	int maxps;
+	atomic_t txposted;
+	atomic_t rxposted;
+	atomic_t txallocated;
+	atomic_t rxallocated;
+	bool rxctl_deferrespok;	/* Get a response for setup from dongle */
+
+	wait_queue_head_t wait;
+	bool waitdone;
+	int sync_urb_status;
+
+	struct urb *blk_urb; /* Used for downloading embedded image */
+
+#if defined(DBUS_LINUX_HIST)
+	int *txposted_hist;
+	int *rxposted_hist;
+#endif
+#ifdef USBOS_THREAD
+	spinlock_t              ctrl_lock;
+	spinlock_t              usbos_list_lock;
+	struct list_head        usbos_list;
+	struct list_head        usbos_free_list;
+	atomic_t                usbos_list_cnt;
+	wait_queue_head_t       usbos_queue_head;
+	struct task_struct      *usbos_kt;
+#endif /* USBOS_THREAD */
+
+#ifdef USBOS_TX_THREAD
+	spinlock_t              usbos_tx_list_lock;
+	struct list_head	usbos_tx_list;
+	wait_queue_head_t	usbos_tx_queue_head;
+	struct task_struct      *usbos_tx_kt;
+#endif /* USBOS_TX_THREAD */
+
+	struct dma_pool *qtd_pool; /* QTD pool for USB optimization only */
+	int tx_ep, rx_ep, rx2_ep;  /* EPs for USB optimization */
+	struct usb_device *usb_device; /* USB device for optimization */
+#if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX) /** Linux USB AP related */
+	spinlock_t fastpath_lock;
+#endif
+} usbos_info_t;
+
+typedef struct urb_req {
+	void         *pkt;
+	int          buf_len;
+	struct urb   *urb;
+	void         *arg;
+	usbos_info_t *usbinfo;
+	struct list_head urb_list;
+} urb_req_t;
+
+#ifdef USBOS_THREAD
+typedef struct usbos_list_entry {
+	struct list_head    list;   /* must be first */
+	void               *urb_context;
+	int                 urb_length;
+	int                 urb_status;
+} usbos_list_entry_t;
+
+static void* dbus_usbos_thread_init(usbos_info_t *usbos_info);
+static void  dbus_usbos_thread_deinit(usbos_info_t *usbos_info);
+static void  dbus_usbos_dispatch_schedule(CALLBACK_ARGS);
+static int   dbus_usbos_thread_func(void *data);
+#endif /* USBOS_THREAD */
+
+#ifdef USBOS_TX_THREAD
+void* dbus_usbos_tx_thread_init(usbos_info_t *usbos_info);
+void  dbus_usbos_tx_thread_deinit(usbos_info_t *usbos_info);
+int   dbus_usbos_tx_thread_func(void *data);
+#endif /* USBOS_TX_THREAD */
+
+/* Shared Function prototypes */
+bool dbus_usbos_dl_cmd(usbos_info_t *usbinfo, uint8 cmd, void *buffer, int buflen);
+int dbus_usbos_wait(usbos_info_t *usbinfo, uint16 ms);
+bool dbus_usbos_dl_send_bulk(usbos_info_t *usbinfo, void *buffer, int len);
+int dbus_write_membytes(usbos_info_t *usbinfo, bool set, uint32 address, uint8 *data, uint size);
+
+/* Local function prototypes */
+static void dbus_usbos_send_complete(CALLBACK_ARGS);
+#ifdef DBUS_LINUX_RXDPC
+static void dbus_usbos_recv_dpc(usbos_info_t *usbos_info);
+static int dbus_usbos_dpc_thread(void *data);
+#endif /* DBUS_LINUX_RXDPC */
+static void dbus_usbos_recv_complete(CALLBACK_ARGS);
+static int  dbus_usbos_errhandler(void *bus, int err);
+static int  dbus_usbos_state_change(void *bus, int state);
+static void dbusos_stop(usbos_info_t *usbos_info);
+
+#ifdef KERNEL26
+static int dbus_usbos_probe(struct usb_interface *intf, const struct usb_device_id *id);
+static void dbus_usbos_disconnect(struct usb_interface *intf);
+#if defined(USB_SUSPEND_AVAILABLE)
+static int dbus_usbos_resume(struct usb_interface *intf);
+static int dbus_usbos_suspend(struct usb_interface *intf, pm_message_t message);
+/* at the moment, used for full dongle host driver only */
+static int dbus_usbos_reset_resume(struct usb_interface *intf);
+#endif /* USB_SUSPEND_AVAILABLE */
+#else /* KERNEL26 */
+static void *dbus_usbos_probe(struct usb_device *usb, unsigned int ifnum,
+	const struct usb_device_id *id);
+static void dbus_usbos_disconnect(struct usb_device *usb, void *ptr);
+#endif /* KERNEL26 */
+
+#ifdef USB_TRIGGER_DEBUG
+static bool dbus_usbos_ctl_send_debugtrig(usbos_info_t *usbinfo);
+#endif /* USB_TRIGGER_DEBUG */
+
+#ifdef KEEPIF_ON_DEVICE_RESET
+enum usb_dev_status {
+	USB_DEVICE_INIT = 0,
+	USB_DEVICE_RESETTED = 1,
+	USB_DEVICE_DISCONNECTED = 2,
+	USB_DEVICE_PROBED
+};
+static int dbus_usbos_usbreset_func(void *data);
+#endif /* KEEPIF_ON_DEVICE_RESET */
+
+/**
+ * have to disable missing-field-initializers warning as last element {} triggers it
+ * and different versions of kernel have different number of members so it is impossible
+ * to specify the initializer. BTW issuing the warning here is bug og GCC as  universal
+ * zero {0} specified in C99 standard as correct way of initialization of struct to all zeros
+ */
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == \
+	4 && __GNUC_MINOR__ >= 6))
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wmissing-field-initializers"
+#endif
+
+static struct usb_device_id devid_table[] = {
+	{ USB_DEVICE(BCM_DNGL_VID, 0x0000) }, /* Configurable via register() */
+#if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_4328) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_4322) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_4319) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_43236) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_43143) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_43242) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_4360) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_4350) },
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BL_PID_43569) },
+#endif
+#ifdef EXTENDED_VID_PID
+	EXTENDED_VID_PID,
+#endif /* EXTENDED_VID_PID */
+	{ USB_DEVICE(BCM_DNGL_VID, BCM_DNGL_BDC_PID) }, /* Default BDC */
+	{ USB_DEVICE(CY_DNGL_VID, BCM_DNGL_BDC_PID) },  /* CY Default BDC */
+	{ }
+};
+
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == \
+	4 && __GNUC_MINOR__ >= 6))
+#pragma GCC diagnostic pop
+#endif
+
+MODULE_DEVICE_TABLE(usb, devid_table);
+
+/** functions called by the Linux kernel USB subsystem */
+static struct usb_driver dbus_usbdev = {
+	name:           "dbus_usbdev",
+	probe:          dbus_usbos_probe,
+	disconnect:     dbus_usbos_disconnect,
+	id_table:       devid_table,
+#if defined(USB_SUSPEND_AVAILABLE)
+	suspend:        dbus_usbos_suspend,
+	resume:         dbus_usbos_resume,
+	reset_resume:	dbus_usbos_reset_resume,
+	/* Linux USB core will allow autosuspend for devices bound to this driver */
+	supports_autosuspend: 1
+#endif /* USB_SUSPEND_AVAILABLE */
+};
+
+/**
+ * This stores USB info during Linux probe callback since attach() is not called yet at this point
+ */
+typedef struct {
+	void    *usbos_info;
+	struct usb_device *usb; /* USB device pointer from OS */
+	uint    rx_pipe;   /* Pipe numbers for USB I/O */
+	uint    tx_pipe;   /* Pipe numbers for USB I/O */
+	uint    intr_pipe; /* Pipe numbers for USB I/O */
+	uint    rx_pipe2;  /* Pipe numbers for USB I/O */
+	int     intr_size; /* Size of interrupt message */
+	int     interval;  /* Interrupt polling interval */
+	bool    dldone;
+	int     vid;
+	int     pid;
+	bool    dereged;
+	bool    disc_cb_done;
+	DEVICE_SPEED    device_speed;
+	enum usbos_suspend_state suspend_state;
+	struct usb_interface     *intf;
+#ifdef KEEPIF_ON_DEVICE_RESET
+	bool                  keepif_on_devreset; /* if need keep network interface on dev reset */
+	bool                  dev_resetted; /* if dev reset event occured */
+	enum dbus_state       busstate_bf_devreset; /* busstate before devreset */
+	atomic_t              usbdev_stat; /* device status: resetted? disconnected? re-probed? */
+	wait_queue_head_t     usbreset_queue_head; /* kernel thread waiting queue */
+	struct task_struct    *usbreset_kt; /* kernel thread handle dev reset/probe event */
+#endif /* KEEPIF_ON_DEVICE_RESET */
+} probe_info_t;
+
+/*
+ * USB Linux dbus_intf_t
+ */
+static void dbus_usbos_init_info(void);
+static void *dbus_usbos_intf_attach(dbus_pub_t *pub, void *cbarg, dbus_intf_callbacks_t *cbs);
+static void dbus_usbos_intf_detach(dbus_pub_t *pub, void *info);
+static int  dbus_usbos_intf_send_irb(void *bus, dbus_irb_tx_t *txirb);
+static int  dbus_usbos_intf_recv_irb(void *bus, dbus_irb_rx_t *rxirb);
+static int  dbus_usbos_intf_recv_irb_from_ep(void *bus, dbus_irb_rx_t *rxirb, uint32 ep_idx);
+static int  dbus_usbos_intf_cancel_irb(void *bus, dbus_irb_tx_t *txirb);
+static int  dbus_usbos_intf_send_ctl(void *bus, uint8 *buf, int len);
+static int  dbus_usbos_intf_recv_ctl(void *bus, uint8 *buf, int len);
+static int  dbus_usbos_intf_get_attrib(void *bus, dbus_attrib_t *attrib);
+static int  dbus_usbos_intf_up(void *bus);
+static int  dbus_usbos_intf_down(void *bus);
+static int  dbus_usbos_intf_stop(void *bus);
+static int  dbus_usbos_readreg(void *bus, uint32 regaddr, int datalen, uint32 *value);
+extern int dbus_usbos_loopback_tx(void *usbos_info_ptr, int cnt, int size);
+int dbus_usbos_writereg(void *bus, uint32 regaddr, int datalen, uint32 data);
+#if defined(DBUS_LINUX_HIST)
+static void dbus_usbos_intf_dump(void *bus, struct bcmstrbuf *b);
+#endif 
+static int  dbus_usbos_intf_set_config(void *bus, dbus_config_t *config);
+static bool dbus_usbos_intf_recv_needed(void *bus);
+static void *dbus_usbos_intf_exec_rxlock(void *bus, exec_cb_t cb, struct exec_parms *args);
+static void *dbus_usbos_intf_exec_txlock(void *bus, exec_cb_t cb, struct exec_parms *args);
+#ifdef BCMUSBDEV_COMPOSITE
+static int dbus_usbos_intf_wlan(struct usb_device *usb);
+#endif /* BCMUSBDEV_COMPOSITE */
+
+/** functions called by dbus_usb.c */
+static dbus_intf_t dbus_usbos_intf = {
+	.attach = dbus_usbos_intf_attach,
+	.detach = dbus_usbos_intf_detach,
+	.up = dbus_usbos_intf_up,
+	.down = dbus_usbos_intf_down,
+	.send_irb = dbus_usbos_intf_send_irb,
+	.recv_irb = dbus_usbos_intf_recv_irb,
+	.cancel_irb = dbus_usbos_intf_cancel_irb,
+	.send_ctl = dbus_usbos_intf_send_ctl,
+	.recv_ctl = dbus_usbos_intf_recv_ctl,
+	.get_stats = NULL,
+	.get_attrib = dbus_usbos_intf_get_attrib,
+	.remove = NULL,
+	.resume = NULL,
+	.suspend = NULL,
+	.stop = dbus_usbos_intf_stop,
+	.reset = NULL,
+	.pktget = NULL,
+	.pktfree = NULL,
+	.iovar_op = NULL,
+#if defined(DBUS_LINUX_HIST)
+	.dump = dbus_usbos_intf_dump,
+#else
+	.dump = NULL,
+#endif 
+	.set_config = dbus_usbos_intf_set_config,
+	.get_config = NULL,
+	.device_exists = NULL,
+	.dlneeded = NULL,
+	.dlstart = NULL,
+	.dlrun = NULL,
+	.recv_needed = dbus_usbos_intf_recv_needed,
+	.exec_rxlock = dbus_usbos_intf_exec_rxlock,
+	.exec_txlock = dbus_usbos_intf_exec_txlock,
+
+	.tx_timer_init = NULL,
+	.tx_timer_start = NULL,
+	.tx_timer_stop = NULL,
+
+	.sched_dpc = NULL,
+	.lock = NULL,
+	.unlock = NULL,
+	.sched_probe_cb = NULL,
+
+	.shutdown = NULL,
+
+	.recv_stop = NULL,
+	.recv_resume = NULL,
+
+	.recv_irb_from_ep = dbus_usbos_intf_recv_irb_from_ep,
+	.readreg = dbus_usbos_readreg
+};
+
+static probe_info_t    g_probe_info;
+static probe_cb_t      probe_cb = NULL;
+static disconnect_cb_t disconnect_cb = NULL;
+static void            *probe_arg = NULL;
+static void            *disc_arg = NULL;
+
+#if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX)
+
+#define EHCI_PAGE_SIZE    4096
+
+/* Copies of structures located elsewhere. */
+
+typedef struct {
+	dbus_pub_t *pub;
+
+	void *cbarg;
+	dbus_intf_callbacks_t *cbs;
+	dbus_intf_t *drvintf;
+	void *usbosl_info;
+} usb_info_t;
+
+/** General info for all BUS */
+typedef struct dbus_irbq {
+	dbus_irb_t *head;
+	dbus_irb_t *tail;
+	int cnt;
+} dbus_irbq_t;
+
+/**
+ * This private structure dbus_info_t is also declared in dbus.c.
+ * All the fields must be consistent in both declarations.
+ */
+typedef struct dbus_info {
+	dbus_pub_t pub; /* MUST BE FIRST */
+
+	void *cbarg;
+	dbus_callbacks_t *cbs;
+	void *bus_info;
+	dbus_intf_t *drvintf;
+	uint8 *fw;
+	int fwlen;
+	uint32 errmask;
+	int rx_low_watermark;
+	int tx_low_watermark;
+	bool txoff;
+	bool txoverride;
+	bool rxoff;
+	bool tx_timer_ticking;
+	dbus_irbq_t *rx_q;
+	dbus_irbq_t *tx_q;
+
+#ifdef EHCI_FASTPATH_RX
+	atomic_t rx_outstanding;
+#endif
+	uint8 *nvram;
+	int	nvram_len;
+	uint8 *image;	/* buffer for combine fw and nvram */
+	int image_len;
+	uint8 *orig_fw;
+	int origfw_len;
+	int decomp_memsize;
+	dbus_extdl_t extdl;
+	int nvram_nontxt;
+} dbus_info_t;
+
+static atomic_t s_tx_pending;
+
+static int optimize_init(usbos_info_t *usbos_info, struct usb_device *usb, int out,
+	int in, int in2);
+static int optimize_deinit(usbos_info_t *usbos_info, struct usb_device *usb);
+#endif  /* #if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX) */
+
+
+static volatile int loopback_rx_cnt, loopback_tx_cnt;
+int loopback_size;
+bool is_loopback_pkt(void *buf);
+int matches_loopback_pkt(void *buf);
+
+/**
+ * multiple code paths in this file dequeue a URB request, this function makes sure that it happens
+ * in a concurrency save manner. Don't call this from a sleepable process context.
+ */
+static urb_req_t * BCMFASTPATH
+dbus_usbos_qdeq(struct list_head *urbreq_q, spinlock_t *lock)
+{
+	unsigned long flags;
+	urb_req_t *req;
+
+	ASSERT(urbreq_q != NULL);
+
+	spin_lock_irqsave(lock, flags);
+
+	if (list_empty(urbreq_q)) {
+		req = NULL;
+	} else {
+		ASSERT(urbreq_q->next != NULL);
+		ASSERT(urbreq_q->next != urbreq_q);
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wcast-qual"
+#endif
+		req = list_entry(urbreq_q->next, urb_req_t, urb_list);
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic pop
+#endif
+		list_del_init(&req->urb_list);
+	}
+
+	spin_unlock_irqrestore(lock, flags);
+
+	return req;
+}
+
+static void BCMFASTPATH
+dbus_usbos_qenq(struct list_head *urbreq_q, urb_req_t *req, spinlock_t *lock)
+{
+	unsigned long flags;
+
+	spin_lock_irqsave(lock, flags);
+
+	list_add_tail(&req->urb_list, urbreq_q);
+
+	spin_unlock_irqrestore(lock, flags);
+}
+
+/**
+ * multiple code paths in this file remove a URB request from a list, this function makes sure that
+ * it happens in a concurrency save manner. Don't call this from a sleepable process context.
+ * Is quite similar to dbus_usbos_qdeq(), I wonder why this function is needed.
+ */
+static void
+dbus_usbos_req_del(urb_req_t *req, spinlock_t *lock)
+{
+	unsigned long flags;
+
+	spin_lock_irqsave(lock, flags);
+
+	list_del_init(&req->urb_list);
+
+	spin_unlock_irqrestore(lock, flags);
+}
+
+
+/**
+ * Driver requires a pool of URBs to operate. This function is called during
+ * initialization (attach phase), allocates a number of URBs, and puts them
+ * on the free (req_rxfreeq and req_txfreeq) queue
+ */
+static int
+dbus_usbos_urbreqs_alloc(usbos_info_t *usbos_info, uint32 count, bool is_rx)
+{
+	int i;
+	int allocated = 0;
+	int err = DBUS_OK;
+
+	for (i = 0; i < count; i++) {
+		urb_req_t *req;
+
+		req = MALLOC(usbos_info->pub->osh, sizeof(urb_req_t));
+		if (req == NULL) {
+			DBUSERR(("%s: MALLOC req failed\n", __FUNCTION__));
+			err = DBUS_ERR_NOMEM;
+			goto fail;
+		}
+		bzero(req, sizeof(urb_req_t));
+
+		req->urb = USB_ALLOC_URB();
+		if (req->urb == NULL) {
+			DBUSERR(("%s: USB_ALLOC_URB req->urb failed\n", __FUNCTION__));
+			err = DBUS_ERR_NOMEM;
+			goto fail;
+		}
+
+		INIT_LIST_HEAD(&req->urb_list);
+
+		if (is_rx) {
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+			/* don't allocate now. Do it on demand */
+			req->pkt = NULL;
+#else
+			/* pre-allocate  buffers never to be released */
+			req->pkt = MALLOC(usbos_info->pub->osh, usbos_info->rxbuf_len);
+			if (req->pkt == NULL) {
+				DBUSERR(("%s: MALLOC req->pkt failed\n", __FUNCTION__));
+				err = DBUS_ERR_NOMEM;
+				goto fail;
+			}
+#endif
+			req->buf_len = usbos_info->rxbuf_len;
+			dbus_usbos_qenq(&usbos_info->req_rxfreeq, req, &usbos_info->rxfree_lock);
+		} else {
+			req->buf_len = 0;
+			dbus_usbos_qenq(&usbos_info->req_txfreeq, req, &usbos_info->txfree_lock);
+		}
+		allocated++;
+		continue;
+
+fail:
+		if (req) {
+			if (is_rx && req->pkt) {
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+				/* req->pkt is NULL in "NOCOPY" mode */
+#else
+				MFREE(usbos_info->pub->osh, req->pkt, req->buf_len);
+#endif
+			}
+			if (req->urb) {
+				USB_FREE_URB(req->urb);
+			}
+			MFREE(usbos_info->pub->osh, req, sizeof(urb_req_t));
+		}
+		break;
+	}
+
+	atomic_add(allocated, is_rx ? &usbos_info->rxallocated : &usbos_info->txallocated);
+
+	if (is_rx) {
+		DBUSTRACE(("%s: add %d (total %d) rx buf, each has %d bytes\n", __FUNCTION__,
+			allocated, atomic_read(&usbos_info->rxallocated), usbos_info->rxbuf_len));
+	} else {
+		DBUSTRACE(("%s: add %d (total %d) tx req\n", __FUNCTION__,
+			allocated, atomic_read(&usbos_info->txallocated)));
+	}
+
+	return err;
+} /* dbus_usbos_urbreqs_alloc */
+
+/** Typically called during detach or when attach failed. Don't call until all URBs unlinked */
+static int
+dbus_usbos_urbreqs_free(usbos_info_t *usbos_info, bool is_rx)
+{
+	int rtn = 0;
+	urb_req_t *req;
+	struct list_head *req_q;
+	spinlock_t *lock;
+
+	if (is_rx) {
+		req_q = &usbos_info->req_rxfreeq;
+		lock = &usbos_info->rxfree_lock;
+	} else {
+		req_q = &usbos_info->req_txfreeq;
+		lock = &usbos_info->txfree_lock;
+	}
+	while ((req = dbus_usbos_qdeq(req_q, lock)) != NULL) {
+
+		if (is_rx) {
+			if (req->pkt) {
+				/* We do MFREE instead of PKTFREE because the pkt has been
+				 * converted to native already
+				 */
+				MFREE(usbos_info->pub->osh, req->pkt, req->buf_len);
+				req->pkt = NULL;
+				req->buf_len = 0;
+			}
+		} else {
+			/* sending req should not be assigned pkt buffer */
+			ASSERT(req->pkt == NULL);
+		}
+
+		if (req->urb) {
+			USB_FREE_URB(req->urb);
+			req->urb = NULL;
+		}
+		MFREE(usbos_info->pub->osh, req, sizeof(urb_req_t));
+
+		rtn++;
+	}
+	return rtn;
+} /* dbus_usbos_urbreqs_free */
+
+/**
+ * called by Linux kernel on URB completion. Upper DBUS layer (dbus_usb.c) has to be notified of
+ * send completion.
+ */
+void
+dbus_usbos_send_complete(CALLBACK_ARGS)
+{
+	urb_req_t *req = urb->context;
+	dbus_irb_tx_t *txirb = req->arg;
+	usbos_info_t *usbos_info = req->usbinfo;
+	unsigned long flags;
+	int status = DBUS_OK;
+	int txposted;
+
+	USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+
+	spin_lock_irqsave(&usbos_info->txlock, flags);
+
+	dbus_usbos_req_del(req, &usbos_info->txposted_lock);
+	txposted = atomic_dec_return(&usbos_info->txposted);
+#if defined(DBUS_LINUX_HIST)
+	if (usbos_info->txposted_hist) {
+		usbos_info->txposted_hist[txposted]++;
+	}
+#endif 
+	if (unlikely (txposted < 0)) {
+		DBUSERR(("%s ERROR: txposted is negative (%d)!!\n", __FUNCTION__, txposted));
+	}
+	spin_unlock_irqrestore(&usbos_info->txlock, flags);
+
+	if (unlikely (urb->status)) {
+		status = DBUS_ERR_TXFAIL;
+		DBUSTRACE(("txfail status %d\n", urb->status));
+	}
+
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+	/* sending req should not be assigned pkt buffer */
+	ASSERT(req->pkt == NULL);
+#endif
+	/*  txirb should always be set, except for ZLP. ZLP is reusing this callback function. */
+	if (txirb != NULL) {
+		if (txirb->send_buf != NULL) {
+			MFREE(usbos_info->pub->osh, txirb->send_buf, req->buf_len);
+			txirb->send_buf = NULL;
+			req->buf_len = 0;
+		}
+		if (likely (usbos_info->cbarg && usbos_info->cbs)) {
+			if (likely (usbos_info->cbs->send_irb_complete != NULL))
+			    usbos_info->cbs->send_irb_complete(usbos_info->cbarg, txirb, status);
+		}
+	}
+
+	dbus_usbos_qenq(&usbos_info->req_txfreeq, req, &usbos_info->txfree_lock);
+} /* dbus_usbos_send_complete */
+
+/**
+ * In order to receive USB traffic from the dongle, we need to supply the Linux kernel with a free
+ * URB that is going to contain received data.
+ */
+static int BCMFASTPATH
+dbus_usbos_recv_urb_submit(usbos_info_t *usbos_info, dbus_irb_rx_t *rxirb, uint32 ep_idx)
+{
+	urb_req_t *req;
+	int ret = DBUS_OK;
+	unsigned long flags;
+	void *p;
+	uint rx_pipe;
+	int rxposted;
+
+	BCM_REFERENCE(rxposted);
+
+	if (!(req = dbus_usbos_qdeq(&usbos_info->req_rxfreeq, &usbos_info->rxfree_lock))) {
+		DBUSTRACE(("%s No free URB!\n", __FUNCTION__));
+		return DBUS_ERR_RXDROP;
+	}
+
+	spin_lock_irqsave(&usbos_info->rxlock, flags);
+
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+	req->pkt = rxirb->pkt = PKTGET(usbos_info->pub->osh, req->buf_len, FALSE);
+	if (!rxirb->pkt) {
+		DBUSERR(("%s: PKTGET failed\n", __FUNCTION__));
+		dbus_usbos_qenq(&usbos_info->req_rxfreeq, req, &usbos_info->rxfree_lock);
+		ret = DBUS_ERR_RXDROP;
+		goto fail;
+	}
+	/* consider the packet "native" so we don't count it as MALLOCED in the osl */
+	PKTTONATIVE(usbos_info->pub->osh, req->pkt);
+	rxirb->buf = NULL;
+	p = PKTDATA(usbos_info->pub->osh, req->pkt);
+#else
+	if (req->buf_len != usbos_info->rxbuf_len) {
+		ASSERT(req->pkt);
+		MFREE(usbos_info->pub->osh, req->pkt, req->buf_len);
+		DBUSTRACE(("%s: replace rx buff: old len %d, new len %d\n", __FUNCTION__,
+			req->buf_len, usbos_info->rxbuf_len));
+		req->buf_len = 0;
+		req->pkt = MALLOC(usbos_info->pub->osh, usbos_info->rxbuf_len);
+		if (req->pkt == NULL) {
+			DBUSERR(("%s: MALLOC req->pkt failed\n", __FUNCTION__));
+			ret = DBUS_ERR_NOMEM;
+			goto fail;
+		}
+		req->buf_len = usbos_info->rxbuf_len;
+	}
+	rxirb->buf = req->pkt;
+	p = rxirb->buf;
+#endif /* defined(BCM_RPC_NOCOPY) */
+	rxirb->buf_len = req->buf_len;
+	req->usbinfo = usbos_info;
+	req->arg = rxirb;
+	if (ep_idx == 0) {
+		rx_pipe = usbos_info->rx_pipe;
+	} else {
+		rx_pipe = usbos_info->rx_pipe2;
+		ASSERT(usbos_info->rx_pipe2);
+	}
+	/* Prepare the URB */
+	usb_fill_bulk_urb(req->urb, usbos_info->usb, rx_pipe,
+		p,
+		rxirb->buf_len,
+		(usb_complete_t)dbus_usbos_recv_complete, req);
+		req->urb->transfer_flags |= URB_QUEUE_BULK;
+
+	if ((ret = USB_SUBMIT_URB(req->urb))) {
+		DBUSERR(("%s USB_SUBMIT_URB failed. status %d\n", __FUNCTION__, ret));
+		dbus_usbos_qenq(&usbos_info->req_rxfreeq, req, &usbos_info->rxfree_lock);
+		ret = DBUS_ERR_RXFAIL;
+		goto fail;
+	}
+	rxposted = atomic_inc_return(&usbos_info->rxposted);
+#if defined(DBUS_LINUX_HIST)
+	if (usbos_info->rxposted_hist) {
+		usbos_info->rxposted_hist[rxposted]++;
+	}
+#endif 
+
+	dbus_usbos_qenq(&usbos_info->req_rxpostedq, req, &usbos_info->rxposted_lock);
+fail:
+	spin_unlock_irqrestore(&usbos_info->rxlock, flags);
+	return ret;
+} /* dbus_usbos_recv_urb_submit */
+
+#ifdef DBUS_LINUX_RXDPC
+
+static void BCMFASTPATH
+dbus_usbos_recv_dpc(usbos_info_t *usbos_info)
+{
+	urb_req_t *req = NULL;
+	dbus_irb_rx_t *rxirb = NULL;
+	int dbus_status = DBUS_OK;
+	bool killed = (g_probe_info.suspend_state == USBOS_SUSPEND_STATE_SUSPEND_PENDING) ? 1 : 0;
+
+#if defined(DBUS_LINUX_HIST)
+	int cnt = 0;
+
+	usbos_info->dpc_cnt++;
+#endif 
+
+	while ((req = dbus_usbos_qdeq(&usbos_info->req_rxpendingq,
+		&usbos_info->rxpending_lock)) != NULL) {
+		struct urb *urb = req->urb;
+		rxirb = req->arg;
+
+		/* Handle errors */
+		if (urb->status) {
+			/*
+			 * Linux 2.4 disconnect: -ENOENT or -EILSEQ for CRC error; rmmod: -ENOENT
+			 * Linux 2.6 disconnect: -EPROTO, rmmod: -ESHUTDOWN
+			 */
+			if ((urb->status == -ENOENT && (!killed)) || urb->status == -ESHUTDOWN) {
+				/* NOTE: unlink() can not be called from URB callback().
+				 * Do not call dbusos_stop() here.
+				 */
+				dbus_usbos_state_change(usbos_info, DBUS_STATE_DOWN);
+			} else if (urb->status == -EPROTO) {
+			} else {
+				DBUSERR(("%s rx error %d\n", __FUNCTION__, urb->status));
+				dbus_usbos_errhandler(usbos_info, DBUS_ERR_RXFAIL);
+			}
+
+			/* On error, don't submit more URBs yet */
+			DBUSERR(("%s %d rx error %d\n", __FUNCTION__, __LINE__, urb->status));
+			rxirb->buf = NULL;
+			rxirb->actual_len = 0;
+			dbus_status = DBUS_ERR_RXFAIL;
+			goto fail;
+		}
+
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+		/* detach the packet from the req */
+		req->pkt = NULL;
+#endif
+		/* Make the skb represent the received urb */
+		rxirb->actual_len = urb->actual_length;
+
+fail:
+		usbos_info->rxpending--;
+#if defined(DBUS_LINUX_HIST)
+		cnt++;
+#endif 
+		if (usbos_info->cbarg && usbos_info->cbs &&
+			usbos_info->cbs->recv_irb_complete) {
+			usbos_info->cbs->recv_irb_complete(usbos_info->cbarg, rxirb, dbus_status);
+		}
+		dbus_usbos_qenq(&usbos_info->req_rxfreeq, req, &usbos_info->rxfree_lock);
+	}
+
+#if defined(DBUS_LINUX_HIST)
+	usbos_info->dpc_pktcnt += cnt;
+	usbos_info->dpc_maxpktcnt = MAX(cnt, usbos_info->dpc_maxpktcnt);
+#endif 
+#ifdef DBUS_LINUX_HIST
+	{
+		static unsigned long last_dump = 0;
+
+		/* dump every 20 sec */
+		if (jiffies > (last_dump + 20*HZ)) {
+			dbus_usbos_intf_dump(usbos_info, NULL);
+			last_dump = jiffies;
+		}
+	}
+#endif /* DBUS_LINUX_HIST */
+} /* dbus_usbos_recv_dpc */
+
+static int BCMFASTPATH
+dbus_usbos_dpc_thread(void *data)
+{
+	usbos_info_t *usbos_info = (usbos_info_t*)data;
+
+	DAEMONIZE("dbus_rx_dpc");
+	/* High priority for short response time. We will yield by ourselves. */
+	/* SET_NICE(-10); */
+
+	/* Run until signal received */
+	while (1) {
+		if (down_interruptible(&usbos_info->dpc_sem) == 0) {
+			dbus_usbos_recv_dpc(usbos_info);
+			RESCHED();
+		} else
+			break;
+	}
+
+	complete_and_exit(&usbos_info->dpc_exited, 0);
+	return 0;
+}
+
+#endif /* DBUS_LINUX_RXDPC */
+
+/**
+ * Called by worked thread when a 'receive URB' completed or Linux kernel when it returns a URB to
+ * this driver.
+ */
+static void BCMFASTPATH
+dbus_usbos_recv_complete_handle(urb_req_t *req, int len, int status)
+{
+#ifdef DBUS_LINUX_RXDPC
+	usbos_info_t *usbos_info = req->usbinfo;
+	unsigned long flags;
+	int rxallocated, rxposted;
+
+	spin_lock_irqsave(&usbos_info->rxlock, flags);
+	/* detach the packet from the queue */
+	dbus_usbos_req_del(req, &usbos_info->rxposted_lock);
+	rxposted = atomic_dec_return(&usbos_info->rxposted);
+	rxallocated = atomic_read(&usbos_info->rxallocated);
+
+	/* Enqueue to rxpending queue */
+	usbos_info->rxpending++;
+	dbus_usbos_qenq(&usbos_info->req_rxpendingq, req, &usbos_info->rxpending_lock);
+	spin_unlock_irqrestore(&usbos_info->rxlock, flags);
+
+#error "RX req/buf appending-mode not verified for DBUS_LINUX_RXDPC because it was disabled"
+	if ((rxallocated < usbos_info->pub->nrxq) && (!status) &&
+		(rxposted == DBUS_USB_RXQUEUE_LOWER_WATERMARK)) {
+			DBUSTRACE(("%s: need more rx buf: rxallocated %d rxposted %d!\n",
+				__FUNCTION__, rxallocated, rxposted));
+			dbus_usbos_urbreqs_alloc(usbos_info,
+				MIN(DBUS_USB_RXQUEUE_BATCH_ADD,
+				usbos_info->pub->nrxq - rxallocated), TRUE);
+	}
+#error "Please verify above code works if you happened to enable DBUS_LINUX_RXDPC!!"
+
+	/* Wake up dpc for further processing */
+	ASSERT(usbos_info->dpc_pid >= 0);
+	up(&usbos_info->dpc_sem);
+#else
+	dbus_irb_rx_t *rxirb = req->arg;
+	usbos_info_t *usbos_info = req->usbinfo;
+	unsigned long flags;
+	int rxallocated, rxposted;
+	int dbus_status = DBUS_OK;
+	bool killed = (g_probe_info.suspend_state == USBOS_SUSPEND_STATE_SUSPEND_PENDING) ? 1 : 0;
+
+	spin_lock_irqsave(&usbos_info->rxlock, flags);
+	dbus_usbos_req_del(req, &usbos_info->rxposted_lock);
+	rxposted = atomic_dec_return(&usbos_info->rxposted);
+	rxallocated = atomic_read(&usbos_info->rxallocated);
+	spin_unlock_irqrestore(&usbos_info->rxlock, flags);
+
+	if ((rxallocated < usbos_info->pub->nrxq) && (!status) &&
+		(rxposted == DBUS_USB_RXQUEUE_LOWER_WATERMARK)) {
+			DBUSTRACE(("%s: need more rx buf: rxallocated %d rxposted %d!\n",
+				__FUNCTION__, rxallocated, rxposted));
+			dbus_usbos_urbreqs_alloc(usbos_info,
+				MIN(DBUS_USB_RXQUEUE_BATCH_ADD,
+				usbos_info->pub->nrxq - rxallocated), TRUE);
+	}
+
+	/* Handle errors */
+	if (status) {
+		/*
+		 * Linux 2.4 disconnect: -ENOENT or -EILSEQ for CRC error; rmmod: -ENOENT
+		 * Linux 2.6 disconnect: -EPROTO, rmmod: -ESHUTDOWN
+		 */
+		if ((status == -ENOENT && (!killed))|| status == -ESHUTDOWN) {
+			/* NOTE: unlink() can not be called from URB callback().
+			 * Do not call dbusos_stop() here.
+			 */
+			DBUSTRACE(("%s rx error %d\n", __FUNCTION__, status));
+			dbus_usbos_state_change(usbos_info, DBUS_STATE_DOWN);
+		} else if (status == -EPROTO) {
+			DBUSTRACE(("%s rx error %d\n", __FUNCTION__, status));
+		} else if (killed && (status == -EHOSTUNREACH || status == -ENOENT)) {
+			/* Device is suspended */
+		} else {
+			DBUSTRACE(("%s rx error %d\n", __FUNCTION__, status));
+			dbus_usbos_errhandler(usbos_info, DBUS_ERR_RXFAIL);
+		}
+
+		/* On error, don't submit more URBs yet */
+		rxirb->buf = NULL;
+		rxirb->actual_len = 0;
+		dbus_status = DBUS_ERR_RXFAIL;
+		goto fail;
+	}
+
+	/* Make the skb represent the received urb */
+	rxirb->actual_len = len;
+
+	if (rxirb->actual_len < sizeof(uint32)) {
+		DBUSTRACE(("small pkt len %d, process as ZLP\n", rxirb->actual_len));
+		dbus_status = DBUS_ERR_RXZLP;
+	}
+
+fail:
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+	/* detach the packet from the queue */
+	req->pkt = NULL;
+#endif /* BCM_RPC_NOCOPY || BCM_RPC_RXNOCOPY */
+
+	if (usbos_info->cbarg && usbos_info->cbs) {
+		if (usbos_info->cbs->recv_irb_complete) {
+			usbos_info->cbs->recv_irb_complete(usbos_info->cbarg, rxirb, dbus_status);
+		}
+	}
+
+	dbus_usbos_qenq(&usbos_info->req_rxfreeq, req, &usbos_info->rxfree_lock);
+#endif /* DBUS_LINUX_RXDPC */
+
+	/* Mark the interface as busy to reset USB autosuspend timer */
+	USB_MARK_LAST_BUSY(usbos_info->usb);
+} /* dbus_usbos_recv_complete_handle */
+
+/** called by Linux kernel when it returns a URB to this driver */
+static void
+dbus_usbos_recv_complete(CALLBACK_ARGS)
+{
+#ifdef USBOS_THREAD
+	dbus_usbos_dispatch_schedule(CALLBACK_ARGS_DATA);
+#else /*  !USBOS_THREAD */
+	dbus_usbos_recv_complete_handle(urb->context, urb->actual_length, urb->status);
+#endif /*  USBOS_THREAD */
+}
+
+
+/**
+ * If Linux notifies our driver that a control read or write URB has completed, we should notify
+ * the DBUS layer above us (dbus_usb.c in this case).
+ */
+static void
+dbus_usbos_ctl_complete(usbos_info_t *usbos_info, int type, int urbstatus)
+{
+	int status = DBUS_ERR;
+
+	if (usbos_info == NULL)
+		return;
+
+	switch (urbstatus) {
+		case 0:
+			status = DBUS_OK;
+		break;
+		case -EINPROGRESS:
+		case -ENOENT:
+		default:
+#ifdef INTR_EP_ENABLE
+			DBUSERR(("%s:%d fail status %d bus:%d susp:%d intr:%d ctli:%d ctlo:%d\n",
+				__FUNCTION__, type, urbstatus,
+				usbos_info->pub->busstate, g_probe_info.suspend_state,
+				usbos_info->intr_urb_submitted, usbos_info->ctlin_urb_submitted,
+				usbos_info->ctlout_urb_submitted));
+#else
+			DBUSERR(("%s: failed with status %d\n", __FUNCTION__, urbstatus));
+			status = DBUS_ERR;
+		break;
+#endif /* INTR_EP_ENABLE */
+	}
+
+	if (usbos_info->cbarg && usbos_info->cbs) {
+		if (usbos_info->cbs->ctl_complete)
+			usbos_info->cbs->ctl_complete(usbos_info->cbarg, type, status);
+	}
+}
+
+/** called by Linux */
+static void
+dbus_usbos_ctlread_complete(CALLBACK_ARGS)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *)urb->context;
+
+	ASSERT(urb);
+	usbos_info = (usbos_info_t *)urb->context;
+
+	dbus_usbos_ctl_complete(usbos_info, DBUS_CBCTL_READ, urb->status);
+
+#ifdef USBOS_THREAD
+	if (usbos_info->rxctl_deferrespok) {
+		usbos_info->ctl_read.bRequestType = USB_DIR_IN | USB_TYPE_CLASS |
+		USB_RECIP_INTERFACE;
+		usbos_info->ctl_read.bRequest = 1;
+	}
+#endif
+
+	up(&usbos_info->ctl_lock);
+
+	USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+}
+
+/** called by Linux */
+static void
+dbus_usbos_ctlwrite_complete(CALLBACK_ARGS)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *)urb->context;
+
+	ASSERT(urb);
+	usbos_info = (usbos_info_t *)urb->context;
+
+	dbus_usbos_ctl_complete(usbos_info, DBUS_CBCTL_WRITE, urb->status);
+
+#ifdef USBOS_TX_THREAD
+	usbos_info->ctl_state = USBOS_REQUEST_STATE_UNSCHEDULED;
+#endif /* USBOS_TX_THREAD */
+
+	up(&usbos_info->ctl_lock);
+
+	USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+}
+
+#ifdef INTR_EP_ENABLE
+/** called by Linux */
+static void
+dbus_usbos_intr_complete(CALLBACK_ARGS)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *)urb->context;
+	bool killed = (g_probe_info.suspend_state == USBOS_SUSPEND_STATE_SUSPEND_PENDING) ? 1 : 0;
+
+	if (usbos_info == NULL || usbos_info->pub == NULL)
+		return;
+	if ((urb->status == -ENOENT && (!killed)) || urb->status == -ESHUTDOWN ||
+		urb->status == -ENODEV) {
+		dbus_usbos_state_change(usbos_info, DBUS_STATE_DOWN);
+	}
+
+	if (usbos_info->pub->busstate == DBUS_STATE_DOWN) {
+		DBUSERR(("%s: intr cb when DBUS down, ignoring\n", __FUNCTION__));
+		return;
+	}
+	dbus_usbos_ctl_complete(usbos_info, DBUS_CBINTR_POLL, urb->status);
+}
+#endif	/* INTR_EP_ENABLE */
+
+/**
+ * when the bus is going to sleep or halt, the Linux kernel requires us to take ownership of our
+ * URBs again. Multiple code paths in this file require a list of URBs to be cancelled in a
+ * concurrency save manner.
+ */
+static void
+dbus_usbos_unlink(struct list_head *urbreq_q, spinlock_t *lock)
+{
+	urb_req_t *req;
+
+	/* dbus_usbos_recv_complete() adds req back to req_freeq */
+	while ((req = dbus_usbos_qdeq(urbreq_q, lock)) != NULL) {
+		ASSERT(req->urb != NULL);
+		USB_UNLINK_URB(req->urb);
+	}
+}
+
+/** multiple code paths in this file require the bus to stop */
+static void
+dbus_usbos_cancel_all_urbs(usbos_info_t *usbos_info)
+{
+	int rxposted, txposted;
+
+	DBUSTRACE(("%s: unlink all URBs\n", __FUNCTION__));
+
+#ifdef USBOS_TX_THREAD
+	usbos_info->ctl_state = USBOS_REQUEST_STATE_UNSCHEDULED;
+
+	/* Yield the CPU to TX thread so all pending requests are submitted */
+	while (!list_empty(&usbos_info->usbos_tx_list)) {
+		wake_up_interruptible(&usbos_info->usbos_tx_queue_head);
+		OSL_SLEEP(10);
+	}
+#endif /* USBOS_TX_THREAD */
+
+	/* tell Linux kernel to cancel a single intr, ctl and blk URB */
+	if (usbos_info->intr_urb)
+		USB_UNLINK_URB(usbos_info->intr_urb);
+	if (usbos_info->ctl_urb)
+		USB_UNLINK_URB(usbos_info->ctl_urb);
+	if (usbos_info->blk_urb)
+		USB_UNLINK_URB(usbos_info->blk_urb);
+
+	dbus_usbos_unlink(&usbos_info->req_txpostedq, &usbos_info->txposted_lock);
+	dbus_usbos_unlink(&usbos_info->req_rxpostedq, &usbos_info->rxposted_lock);
+
+	/* Wait until the callbacks for all submitted URBs have been called, because the
+	 * handler needs to know is an USB suspend is in progress.
+	 */
+	SPINWAIT((atomic_read(&usbos_info->txposted) != 0 ||
+		atomic_read(&usbos_info->rxposted) != 0), 10000);
+
+	txposted = atomic_read(&usbos_info->txposted);
+	rxposted = atomic_read(&usbos_info->rxposted);
+	if (txposted != 0 || rxposted != 0) {
+		DBUSERR(("%s ERROR: REQs posted, rx=%d tx=%d!\n",
+			__FUNCTION__, rxposted, txposted));
+	}
+} /* dbus_usbos_cancel_all_urbs */
+
+/** multiple code paths require the bus to stop */
+static void
+dbusos_stop(usbos_info_t *usbos_info)
+{
+	urb_req_t *req;
+	int rxposted;
+	req = NULL;
+	BCM_REFERENCE(req);
+
+	ASSERT(usbos_info);
+
+#ifdef USB_TRIGGER_DEBUG
+	dbus_usbos_ctl_send_debugtrig(usbos_info);
+#endif /* USB_TRIGGER_DEBUG */
+	dbus_usbos_state_change(usbos_info, DBUS_STATE_DOWN);
+
+	dbus_usbos_cancel_all_urbs(usbos_info);
+
+#ifdef USBOS_THREAD
+	/* yield the CPU to rx packet thread */
+	while (1) {
+		if (atomic_read(&usbos_info->usbos_list_cnt) <= 0)	break;
+		wake_up_interruptible(&usbos_info->usbos_queue_head);
+		OSL_SLEEP(3);
+	}
+#endif /* USBOS_THREAD */
+
+	rxposted = atomic_read(&usbos_info->rxposted);
+	if (rxposted > 0) {
+		DBUSERR(("%s ERROR: rx REQs posted=%d in stop!\n", __FUNCTION__,
+			rxposted));
+	}
+
+	ASSERT(atomic_read(&usbos_info->txposted) == 0 && rxposted == 0);
+
+#ifdef DBUS_LINUX_RXDPC
+	/* Stop the dpc thread */
+	if (usbos_info->dpc_pid >= 0) {
+		KILL_PROC(usbos_info->dpc_pid, SIGTERM);
+		wait_for_completion(&usbos_info->dpc_exited);
+	}
+
+	/* Move pending reqs to free queue so they can be freed */
+	while ((req = dbus_usbos_qdeq(&usbos_info->req_rxpendingq,
+		&usbos_info->rxpending_lock)) != NULL) {
+		dbus_usbos_qenq(&usbos_info->req_rxfreeq, req,
+			&usbos_info->rxfree_lock);
+	}
+#endif /* DBUS_LINUX_RXDPC */
+} /* dbusos_stop */
+
+#if defined(USB_SUSPEND_AVAILABLE)
+
+/**
+ * Linux kernel sports a 'USB auto suspend' feature. See: http://lwn.net/Articles/373550/
+ * The suspend method is called by the Linux kernel to warn the driver that the device is going to
+ * be suspended.  If the driver returns a negative error code, the suspend will be aborted. If the
+ * driver returns 0, it must cancel all outstanding URBs (usb_kill_urb()) and not submit any more.
+ */
+static int
+dbus_usbos_suspend(struct usb_interface *intf,
+            pm_message_t message)
+{
+	DBUSERR(("%s suspend state: %d\n", __FUNCTION__, g_probe_info.suspend_state));
+	/* DHD for full dongle model */
+	g_probe_info.suspend_state = USBOS_SUSPEND_STATE_SUSPEND_PENDING;
+	dbus_usbos_state_change((usbos_info_t*)g_probe_info.usbos_info, DBUS_STATE_SLEEP);
+	dbus_usbos_cancel_all_urbs((usbos_info_t*)g_probe_info.usbos_info);
+	g_probe_info.suspend_state = USBOS_SUSPEND_STATE_SUSPENDED;
+
+	return 0;
+}
+
+/**
+ * The resume method is called to tell the driver that the device has been resumed and the driver
+ * can return to normal operation.  URBs may once more be submitted.
+ */
+static int dbus_usbos_resume(struct usb_interface *intf)
+{
+	DBUSERR(("%s Device resumed\n", __FUNCTION__));
+
+	dbus_usbos_state_change((usbos_info_t*)g_probe_info.usbos_info, DBUS_STATE_UP);
+	g_probe_info.suspend_state = USBOS_SUSPEND_STATE_DEVICE_ACTIVE;
+	return 0;
+}
+
+/**
+* This function is directly called by the Linux kernel, when the suspended device has been reset
+* instead of being resumed
+*/
+static int dbus_usbos_reset_resume(struct usb_interface *intf)
+{
+	DBUSERR(("%s Device reset resumed\n", __FUNCTION__));
+
+#ifdef KEEPIF_ON_DEVICE_RESET
+	if (g_probe_info.keepif_on_devreset) {
+		atomic_set(&g_probe_info.usbdev_stat, USB_DEVICE_RESETTED);
+		wake_up_interruptible(&g_probe_info.usbreset_queue_head);
+	} else
+#endif /* KEEPIF_ON_DEVICE_RESET */
+	{
+		/* The device may have lost power, so a firmware download may be required */
+		dbus_usbos_state_change((usbos_info_t*)g_probe_info.usbos_info,
+			DBUS_STATE_DL_NEEDED);
+		g_probe_info.suspend_state = USBOS_SUSPEND_STATE_DEVICE_ACTIVE;
+	}
+
+	return 0;
+}
+
+#endif /* USB_SUSPEND_AVAILABLE */
+
+/**
+ * Called by Linux kernel at initialization time, kernel wants to know if our driver will accept the
+ * caller supplied USB interface. Note that USB drivers are bound to interfaces, and not to USB
+ * devices.
+ */
+#ifdef KERNEL26
+static int
+dbus_usbos_probe(struct usb_interface *intf, const struct usb_device_id *id)
+#else
+static void *
+dbus_usbos_probe(struct usb_device *usb, unsigned int ifnum, const struct usb_device_id *id)
+#endif /* KERNEL26 */
+{
+	int ep;
+	struct usb_endpoint_descriptor *endpoint;
+	int ret = 0;
+#ifdef KERNEL26
+	struct usb_device *usb = interface_to_usbdev(intf);
+#else
+	int claimed = 0;
+#endif
+	int num_of_eps;
+#ifdef BCMUSBDEV_COMPOSITE
+	int wlan_if = -1;
+	bool intr_ep = FALSE;
+#endif /* BCMUSBDEV_COMPOSITE */
+
+#ifdef BCMUSBDEV_COMPOSITE
+	wlan_if = dbus_usbos_intf_wlan(usb);
+#ifdef KERNEL26
+	if ((wlan_if >= 0) && (IFPTR(usb, wlan_if) == intf)) {
+#else
+	if (wlan_if == ifnum) {
+#endif /* KERNEL26 */
+#endif /* BCMUSBDEV_COMPOSITE */
+		g_probe_info.usb = usb;
+		g_probe_info.dldone = TRUE;
+#ifdef BCMUSBDEV_COMPOSITE
+	} else {
+		DBUSTRACE(("dbus_usbos_probe: skip probe for non WLAN interface\n"));
+		ret = BCME_UNSUPPORTED;
+		goto fail;
+	}
+#endif /* BCMUSBDEV_COMPOSITE */
+
+#ifdef KERNEL26
+	g_probe_info.intf = intf;
+#endif /* KERNEL26 */
+
+#ifdef BCMUSBDEV_COMPOSITE
+	if (IFDESC(usb, wlan_if).bInterfaceNumber > USB_COMPIF_MAX) {
+#else
+	if (IFDESC(usb, CONTROL_IF).bInterfaceNumber) {
+#endif /* BCMUSBDEV_COMPOSITE */
+		ret = -1;
+		goto fail;
+	}
+	if (id != NULL) {
+		g_probe_info.vid = id->idVendor;
+		g_probe_info.pid = id->idProduct;
+	}
+
+#ifdef KERNEL26
+	usb_set_intfdata(intf, &g_probe_info);
+#endif
+
+	/* Check that the device supports only one configuration */
+	if (usb->descriptor.bNumConfigurations != 1) {
+		ret = -1;
+		goto fail;
+	}
+
+	if (usb->descriptor.bDeviceClass != USB_CLASS_VENDOR_SPEC) {
+#ifdef BCMUSBDEV_COMPOSITE
+		if ((usb->descriptor.bDeviceClass != USB_CLASS_MISC) &&
+			(usb->descriptor.bDeviceClass != USB_CLASS_WIRELESS)) {
+#endif /* BCMUSBDEV_COMPOSITE */
+			ret = -1;
+			goto fail;
+#ifdef BCMUSBDEV_COMPOSITE
+		}
+#endif /* BCMUSBDEV_COMPOSITE */
+	}
+
+	/*
+	 * Only the BDC interface configuration is supported:
+	 *	Device class: USB_CLASS_VENDOR_SPEC
+	 *	if0 class: USB_CLASS_VENDOR_SPEC
+	 *	if0/ep0: control
+	 *	if0/ep1: bulk in
+	 *	if0/ep2: bulk out (ok if swapped with bulk in)
+	 */
+	if (CONFIGDESC(usb)->bNumInterfaces != 1) {
+#ifdef BCMUSBDEV_COMPOSITE
+		if (CONFIGDESC(usb)->bNumInterfaces > USB_COMPIF_MAX) {
+#endif /* BCMUSBDEV_COMPOSITE */
+			ret = -1;
+			goto fail;
+#ifdef BCMUSBDEV_COMPOSITE
+		}
+#endif /* BCMUSBDEV_COMPOSITE */
+	}
+
+	/* Check interface */
+#ifndef KERNEL26
+#ifdef BCMUSBDEV_COMPOSITE
+	if (usb_interface_claimed(IFPTR(usb, wlan_if))) {
+#else
+	if (usb_interface_claimed(IFPTR(usb, CONTROL_IF))) {
+#endif /* BCMUSBDEV_COMPOSITE */
+		ret = -1;
+		goto fail;
+	}
+#endif /* !KERNEL26 */
+
+#ifdef BCMUSBDEV_COMPOSITE
+	if ((IFDESC(usb, wlan_if).bInterfaceClass != USB_CLASS_VENDOR_SPEC ||
+		IFDESC(usb, wlan_if).bInterfaceSubClass != 2 ||
+		IFDESC(usb, wlan_if).bInterfaceProtocol != 0xff) &&
+		(IFDESC(usb, wlan_if).bInterfaceClass != USB_CLASS_MISC ||
+		IFDESC(usb, wlan_if).bInterfaceSubClass != USB_SUBCLASS_COMMON ||
+		IFDESC(usb, wlan_if).bInterfaceProtocol != USB_PROTO_IAD)) {
+			DBUSERR(("%s: invalid control interface: class %d, subclass %d, proto %d\n",
+				__FUNCTION__,
+				IFDESC(usb, wlan_if).bInterfaceClass,
+				IFDESC(usb, wlan_if).bInterfaceSubClass,
+				IFDESC(usb, wlan_if).bInterfaceProtocol));
+#else
+	if (IFDESC(usb, CONTROL_IF).bInterfaceClass != USB_CLASS_VENDOR_SPEC ||
+		IFDESC(usb, CONTROL_IF).bInterfaceSubClass != 2 ||
+		IFDESC(usb, CONTROL_IF).bInterfaceProtocol != 0xff) {
+			DBUSERR(("%s: invalid control interface: class %d, subclass %d, proto %d\n",
+				__FUNCTION__,
+				IFDESC(usb, CONTROL_IF).bInterfaceClass,
+				IFDESC(usb, CONTROL_IF).bInterfaceSubClass,
+				IFDESC(usb, CONTROL_IF).bInterfaceProtocol));
+#endif /* BCMUSBDEV_COMPOSITE */
+			ret = -1;
+			goto fail;
+	}
+
+	/* Check control endpoint */
+#ifdef BCMUSBDEV_COMPOSITE
+	endpoint = &IFEPDESC(usb, wlan_if, 0);
+#else
+	endpoint = &IFEPDESC(usb, CONTROL_IF, 0);
+#endif /* BCMUSBDEV_COMPOSITE */
+	if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) != USB_ENDPOINT_XFER_INT) {
+#ifdef BCMUSBDEV_COMPOSITE
+		if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) !=
+			USB_ENDPOINT_XFER_BULK) {
+#endif /* BCMUSBDEV_COMPOSITE */
+			DBUSERR(("%s: invalid control endpoint %d\n",
+				__FUNCTION__, endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK));
+			ret = -1;
+			goto fail;
+#ifdef BCMUSBDEV_COMPOSITE
+		}
+#endif /* BCMUSBDEV_COMPOSITE */
+	}
+
+#ifdef BCMUSBDEV_COMPOSITE
+	if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) == USB_ENDPOINT_XFER_INT) {
+#endif /* BCMUSBDEV_COMPOSITE */
+		g_probe_info.intr_pipe =
+			usb_rcvintpipe(usb, endpoint->bEndpointAddress & USB_ENDPOINT_NUMBER_MASK);
+#ifdef BCMUSBDEV_COMPOSITE
+		intr_ep = TRUE;
+	}
+#endif /* BCMUSBDEV_COMPOSITE */
+
+#ifndef KERNEL26
+	/* Claim interface */
+#ifdef BCMUSBDEV_COMPOSITE
+	usb_driver_claim_interface(&dbus_usbdev, IFPTR(usb, wlan_if), &g_probe_info);
+#else
+	usb_driver_claim_interface(&dbus_usbdev, IFPTR(usb, CONTROL_IF), &g_probe_info);
+#endif /* BCMUSBDEV_COMPOSITE */
+	claimed = 1;
+#endif /* !KERNEL26 */
+	g_probe_info.rx_pipe = 0;
+	g_probe_info.rx_pipe2 = 0;
+	g_probe_info.tx_pipe = 0;
+#ifdef BCMUSBDEV_COMPOSITE
+	if (intr_ep)
+		ep = 1;
+	else
+		ep = 0;
+	num_of_eps = IFDESC(usb, wlan_if).bNumEndpoints - 1;
+#else
+	num_of_eps = IFDESC(usb, BULK_IF).bNumEndpoints - 1;
+#endif /* BCMUSBDEV_COMPOSITE */
+
+	if ((num_of_eps != 2) && (num_of_eps != 3)) {
+#ifdef BCMUSBDEV_COMPOSITE
+		if (num_of_eps > 7)
+#endif /* BCMUSBDEV_COMPOSITE */
+			ASSERT(0);
+	}
+	/* Check data endpoints and get pipes */
+#ifdef BCMUSBDEV_COMPOSITE
+	for (; ep <= num_of_eps; ep++) {
+		endpoint = &IFEPDESC(usb, wlan_if, ep);
+#else
+	for (ep = 1; ep <= num_of_eps; ep++) {
+		endpoint = &IFEPDESC(usb, BULK_IF, ep);
+#endif /* BCMUSBDEV_COMPOSITE */
+		if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) !=
+		    USB_ENDPOINT_XFER_BULK) {
+			DBUSERR(("%s: invalid data endpoint %d\n",
+			           __FUNCTION__, ep));
+			ret = -1;
+			goto fail;
+		}
+
+		if ((endpoint->bEndpointAddress & USB_ENDPOINT_DIR_MASK) == USB_DIR_IN) {
+			/* direction: dongle->host */
+			if (!g_probe_info.rx_pipe) {
+				g_probe_info.rx_pipe = usb_rcvbulkpipe(usb,
+					(endpoint->bEndpointAddress & USB_ENDPOINT_NUMBER_MASK));
+			} else {
+				g_probe_info.rx_pipe2 = usb_rcvbulkpipe(usb,
+					(endpoint->bEndpointAddress & USB_ENDPOINT_NUMBER_MASK));
+			}
+
+		} else
+			g_probe_info.tx_pipe = usb_sndbulkpipe(usb, (endpoint->bEndpointAddress &
+			     USB_ENDPOINT_NUMBER_MASK));
+	}
+
+	/* Allocate interrupt URB and data buffer */
+	/* RNDIS says 8-byte intr, our old drivers used 4-byte */
+#ifdef BCMUSBDEV_COMPOSITE
+	g_probe_info.intr_size = (IFEPDESC(usb, wlan_if, 0).wMaxPacketSize == 16) ? 8 : 4;
+	g_probe_info.interval = IFEPDESC(usb, wlan_if, 0).bInterval;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 21))
+	usb->quirks |= USB_QUIRK_NO_SET_INTF;
+#endif
+#else
+	g_probe_info.intr_size = (IFEPDESC(usb, CONTROL_IF, 0).wMaxPacketSize == 16) ? 8 : 4;
+	g_probe_info.interval = IFEPDESC(usb, CONTROL_IF, 0).bInterval;
+#endif /* BCMUSBDEV_COMPOSITE */
+
+#ifndef KERNEL26
+	/* usb_fill_int_urb does the interval decoding in 2.6 */
+	if (usb->speed == USB_SPEED_HIGH)
+		g_probe_info.interval = 1 << (g_probe_info.interval - 1);
+#endif
+	if (usb->speed == USB_SPEED_SUPER) {
+		g_probe_info.device_speed = SUPER_SPEED;
+		DBUSERR(("super speed device detected\n"));
+	} else if (usb->speed == USB_SPEED_HIGH) {
+		g_probe_info.device_speed = HIGH_SPEED;
+		DBUSERR(("high speed device detected\n"));
+	} else {
+		g_probe_info.device_speed = FULL_SPEED;
+		DBUSERR(("full speed device detected\n"));
+	}
+#ifdef KEEPIF_ON_DEVICE_RESET
+	if (g_probe_info.keepif_on_devreset && g_probe_info.dev_resetted) {
+		atomic_set(&g_probe_info.usbdev_stat, USB_DEVICE_PROBED);
+		wake_up_interruptible(&g_probe_info.usbreset_queue_head);
+	} else
+#endif /* KEEPIF_ON_DEVICE_RESET */
+	if (g_probe_info.dereged == FALSE && probe_cb) {
+		disc_arg = probe_cb(probe_arg, "", USB_BUS, 0);
+	}
+
+	g_probe_info.disc_cb_done = FALSE;
+
+#ifdef KERNEL26
+	intf->needs_remote_wakeup = 1;
+#endif /* KERNEL26 */
+
+	/* Success */
+#ifdef KERNEL26
+	return DBUS_OK;
+#else
+	usb_inc_dev_use(usb);
+	return &g_probe_info;
+#endif
+
+fail:
+#ifdef BCMUSBDEV_COMPOSITE
+	if (ret != BCME_UNSUPPORTED)
+#endif /* BCMUSBDEV_COMPOSITE */
+		DBUSERR(("%s: failed with errno %d\n", __FUNCTION__, ret));
+#ifndef KERNEL26
+	if (claimed)
+#ifdef BCMUSBDEV_COMPOSITE
+		usb_driver_release_interface(&dbus_usbdev, IFPTR(usb, wlan_if));
+#else
+		usb_driver_release_interface(&dbus_usbdev, IFPTR(usb, CONTROL_IF));
+#endif /* BCMUSBDEV_COMPOSITE */
+#endif /* !KERNEL26 */
+
+#ifdef KERNEL26
+	usb_set_intfdata(intf, NULL);
+	return ret;
+#else
+	return NULL;
+#endif
+} /* dbus_usbos_probe */
+
+/** Called by Linux kernel, is the counter part of dbus_usbos_probe() */
+#ifdef KERNEL26
+static void
+dbus_usbos_disconnect(struct usb_interface *intf)
+#else
+static void
+dbus_usbos_disconnect(struct usb_device *usb, void *ptr)
+#endif
+{
+#ifdef KERNEL26
+	struct usb_device *usb = interface_to_usbdev(intf);
+	probe_info_t *probe_usb_init_data = usb_get_intfdata(intf);
+#else
+	probe_info_t *probe_usb_init_data = (probe_info_t *) ptr;
+#endif
+	usbos_info_t *usbos_info;
+
+	if (probe_usb_init_data) {
+		usbos_info = (usbos_info_t *) probe_usb_init_data->usbos_info;
+		if (usbos_info) {
+			if ((probe_usb_init_data->dereged == FALSE) && disconnect_cb && disc_arg) {
+				bool remove_if = TRUE;
+#ifdef KEEPIF_ON_DEVICE_RESET
+				if (g_probe_info.keepif_on_devreset)
+					remove_if = FALSE;
+#endif /* KEEPIF_ON_DEVICE_RESET */
+				if (remove_if) {
+					disconnect_cb(disc_arg);
+					disc_arg = NULL;
+					probe_usb_init_data->disc_cb_done = TRUE;
+				}
+			}
+		}
+	}
+
+	if (usb) {
+#ifndef KERNEL26
+#ifdef BCMUSBDEV_COMPOSITE
+		usb_driver_release_interface(&dbus_usbdev, IFPTR(usb, wlan_if));
+#else
+		usb_driver_release_interface(&dbus_usbdev, IFPTR(usb, CONTROL_IF));
+#endif /* BCMUSBDEV_COMPOSITE */
+		usb_dec_dev_use(usb);
+#endif /* !KERNEL26 */
+	}
+
+#ifdef KEEPIF_ON_DEVICE_RESET
+	if (g_probe_info.keepif_on_devreset && (!g_probe_info.dev_resetted)) {
+		atomic_set(&g_probe_info.usbdev_stat, USB_DEVICE_DISCONNECTED);
+		wake_up_interruptible(&g_probe_info.usbreset_queue_head);
+	}
+#endif /* KEEPIF_ON_DEVICE_RESET */
+} /* dbus_usbos_disconnect */
+
+#define LOOPBACK_PKT_START 0xBABE1234
+
+bool is_loopback_pkt(void *buf)
+{
+
+	uint32 *buf_ptr = (uint32 *) buf;
+
+	if (*buf_ptr == LOOPBACK_PKT_START)
+		return TRUE;
+	return FALSE;
+
+}
+
+int matches_loopback_pkt(void *buf)
+{
+	int i, j;
+	unsigned char *cbuf = (unsigned char *) buf;
+
+	for (i = 4; i < loopback_size; i++) {
+		if (cbuf[i] != (i % 256)) {
+			printf("%s: mismatch at i=%d %d : ", __FUNCTION__, i, cbuf[i]);
+			for (j = i; ((j < i+ 16) && (j < loopback_size)); j++) {
+				printf("%d ", cbuf[j]);
+			}
+			printf("\n");
+			return 0;
+		}
+	}
+	loopback_rx_cnt++;
+	return 1;
+}
+
+int dbus_usbos_loopback_tx(void *usbos_info_ptr, int cnt, int size)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) usbos_info_ptr;
+	unsigned char *buf;
+	int j;
+	void* p = NULL;
+	int rc, last_rx_cnt;
+	int tx_failed_cnt;
+	int max_size = 1650;
+	int usb_packet_size = 512;
+	int min_packet_size = 10;
+
+	if (size % usb_packet_size == 0) {
+		size = size - 1;
+		DBUSERR(("%s: overriding size=%d \n", __FUNCTION__, size));
+	}
+
+	if (size < min_packet_size) {
+		size = min_packet_size;
+		DBUSERR(("%s: overriding size=%d\n", __FUNCTION__, min_packet_size));
+	}
+	if (size > max_size) {
+		size = max_size;
+		DBUSERR(("%s: overriding size=%d\n", __FUNCTION__, max_size));
+	}
+
+	loopback_tx_cnt = 0;
+	loopback_rx_cnt = 0;
+	tx_failed_cnt = 0;
+	loopback_size   = size;
+
+	while (loopback_tx_cnt < cnt) {
+		uint32 *x;
+		int pkt_size = loopback_size;
+
+		p = PKTGET(usbos_info->pub->osh, pkt_size, TRUE);
+		if (p == NULL) {
+			DBUSERR(("%s:%d Failed to allocate packet sz=%d\n",
+			       __FUNCTION__, __LINE__, pkt_size));
+			return BCME_ERROR;
+		}
+		x = (uint32*) PKTDATA(usbos_info->pub->osh, p);
+		*x = LOOPBACK_PKT_START;
+		buf = (unsigned char*) x;
+		for (j = 4; j < pkt_size; j++) {
+			buf[j] = j % 256;
+		}
+		rc = dbus_send_buf(usbos_info->pub, buf, pkt_size, p);
+		if (rc != BCME_OK) {
+			DBUSERR(("%s:%d Freeing packet \n", __FUNCTION__, __LINE__));
+			PKTFREE(usbos_info->pub->osh, p, TRUE);
+			dbus_usbos_wait(usbos_info, 1);
+			tx_failed_cnt++;
+		} else {
+			loopback_tx_cnt++;
+			tx_failed_cnt = 0;
+		}
+		if (tx_failed_cnt == 5) {
+			DBUSERR(("%s : Failed to send loopback packets cnt=%d loopback_tx_cnt=%d\n",
+			 __FUNCTION__, cnt, loopback_tx_cnt));
+			break;
+		}
+	}
+	printf("Transmitted %d loopback packets of size %d\n", loopback_tx_cnt, loopback_size);
+
+	last_rx_cnt = loopback_rx_cnt;
+	while (loopback_rx_cnt < loopback_tx_cnt) {
+		dbus_usbos_wait(usbos_info, 1);
+		if (loopback_rx_cnt <= last_rx_cnt) {
+			DBUSERR(("%s: Matched rx cnt stuck at %d \n", __FUNCTION__, last_rx_cnt));
+			return BCME_ERROR;
+		}
+		last_rx_cnt = loopback_rx_cnt;
+	}
+	printf("Received %d loopback packets of size %d\n", loopback_tx_cnt, loopback_size);
+
+	return BCME_OK;
+} /* dbus_usbos_loopback_tx */
+
+/**
+ * Higher layer (dbus_usb.c) wants to transmit an I/O Request Block
+ *     @param[in] txirb txirb->pkt, if non-zero, contains a single or a chain of packets
+ */
+static int
+dbus_usbos_intf_send_irb(void *bus, dbus_irb_tx_t *txirb)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	urb_req_t *req, *req_zlp = NULL;
+	int ret = DBUS_OK;
+	unsigned long flags;
+	void *pkt;
+	uint32 buffer_length;
+	uint8 *buf;
+
+	if ((usbos_info == NULL) || !usbos_info->tx_pipe) {
+		return DBUS_ERR;
+	}
+
+	if (txirb->pkt != NULL) {
+		buffer_length = pkttotlen(usbos_info->pub->osh, txirb->pkt);
+		/* In case of multiple packets the values below may be overwritten */
+		txirb->send_buf = NULL;
+		buf = PKTDATA(usbos_info->pub->osh, txirb->pkt);
+	} else { /* txirb->buf != NULL */
+		ASSERT(txirb->buf != NULL);
+		ASSERT(txirb->send_buf == NULL);
+		buffer_length = txirb->len;
+		buf = txirb->buf;
+	}
+
+	if (!(req = dbus_usbos_qdeq(&usbos_info->req_txfreeq, &usbos_info->txfree_lock))) {
+		DBUSERR(("%s No free URB!\n", __FUNCTION__));
+		return DBUS_ERR_TXDROP;
+	}
+
+	/* If not using standard Linux kernel functionality for handling Zero Length Packet(ZLP),
+	 * the dbus needs to generate ZLP when length is multiple of MaxPacketSize.
+	 */
+#ifndef WL_URB_ZPKT
+	if (!(buffer_length % usbos_info->maxps)) {
+		if (!(req_zlp =
+			dbus_usbos_qdeq(&usbos_info->req_txfreeq, &usbos_info->txfree_lock))) {
+			DBUSERR(("%s No free URB for ZLP!\n", __FUNCTION__));
+			dbus_usbos_qenq(&usbos_info->req_txfreeq, req, &usbos_info->txfree_lock);
+			return DBUS_ERR_TXDROP;
+		}
+
+		/* No txirb, so that dbus_usbos_send_complete can differentiate between
+		 * DATA and ZLP.
+		 */
+		req_zlp->arg = NULL;
+		req_zlp->usbinfo = usbos_info;
+		req_zlp->buf_len = 0;
+
+		usb_fill_bulk_urb(req_zlp->urb, usbos_info->usb, usbos_info->tx_pipe, NULL,
+			0, (usb_complete_t)dbus_usbos_send_complete, req_zlp);
+
+		req_zlp->urb->transfer_flags |= URB_QUEUE_BULK;
+	}
+#endif /* !WL_URB_ZPKT */
+
+#ifndef USBOS_TX_THREAD
+	/* Disable USB autosuspend until this request completes, request USB resume if needed.
+	 * Because this call runs asynchronously, there is no guarantee the bus is resumed before
+	 * the URB is submitted, and the URB might be dropped. Use USBOS_TX_THREAD to avoid
+	 * this.
+	 */
+	USB_AUTOPM_GET_INTERFACE_ASYNC(g_probe_info.intf);
+#endif /* !USBOS_TX_THREAD */
+
+	spin_lock_irqsave(&usbos_info->txlock, flags);
+
+	req->arg = txirb;
+	req->usbinfo = usbos_info;
+	req->buf_len = 0;
+
+	/* Prepare the URB */
+	if (txirb->pkt != NULL) {
+		uint32 pktlen;
+		uint8 *transfer_buf;
+
+		/* For multiple packets, allocate contiguous buffer and copy packet data to it */
+		if (PKTNEXT(usbos_info->pub->osh, txirb->pkt)) {
+			transfer_buf = MALLOC(usbos_info->pub->osh, buffer_length);
+			if (!transfer_buf) {
+				ret = DBUS_ERR_TXDROP;
+				DBUSERR(("fail to alloc to usb buffer\n"));
+				goto fail;
+			}
+
+			pkt = txirb->pkt;
+			txirb->send_buf = transfer_buf;
+			req->buf_len = buffer_length;
+
+			while (pkt) {
+				pktlen = PKTLEN(usbos_info->pub->osh, pkt);
+				bcopy(PKTDATA(usbos_info->pub->osh, pkt), transfer_buf, pktlen);
+				transfer_buf += pktlen;
+				pkt = PKTNEXT(usbos_info->pub->osh, pkt);
+			}
+
+			ASSERT(((uint8 *) txirb->send_buf + buffer_length) == transfer_buf);
+
+			/* Overwrite buf pointer with pointer to allocated contiguous transfer_buf
+			 */
+			buf = txirb->send_buf;
+		}
+	}
+
+	usb_fill_bulk_urb(req->urb, usbos_info->usb, usbos_info->tx_pipe, buf,
+		buffer_length, (usb_complete_t)dbus_usbos_send_complete, req);
+
+	req->urb->transfer_flags |= URB_QUEUE_BULK;
+
+#ifdef USBOS_TX_THREAD
+	/* Enqueue TX request, the TX thread will resume the bus if needed and submit
+	 * it asynchronously
+	 */
+	dbus_usbos_qenq(&usbos_info->usbos_tx_list, req, &usbos_info->usbos_tx_list_lock);
+	if (req_zlp != NULL) {
+		dbus_usbos_qenq(&usbos_info->usbos_tx_list, req_zlp,
+			&usbos_info->usbos_tx_list_lock);
+	}
+	spin_unlock_irqrestore(&usbos_info->txlock, flags);
+
+	wake_up_interruptible(&usbos_info->usbos_tx_queue_head);
+	return DBUS_OK;
+#else
+	if ((ret = USB_SUBMIT_URB(req->urb))) {
+		ret = DBUS_ERR_TXDROP;
+		goto fail;
+	}
+
+	dbus_usbos_qenq(&usbos_info->req_txpostedq, req, &usbos_info->txposted_lock);
+	atomic_inc(&usbos_info->txposted);
+
+	if (req_zlp != NULL) {
+		if ((ret = USB_SUBMIT_URB(req_zlp->urb))) {
+			DBUSERR(("failed to submit ZLP URB!\n"));
+			ASSERT(0);
+			ret = DBUS_ERR_TXDROP;
+			goto fail2;
+		}
+
+		dbus_usbos_qenq(&usbos_info->req_txpostedq, req_zlp, &usbos_info->txposted_lock);
+		/* Also increment txposted for zlp packet, as it will be decremented in
+		 * dbus_usbos_send_complete()
+		 */
+		atomic_inc(&usbos_info->txposted);
+	}
+
+	spin_unlock_irqrestore(&usbos_info->txlock, flags);
+	return DBUS_OK;
+#endif /* USBOS_TX_THREAD */
+
+fail:
+	if (txirb->send_buf != NULL) {
+		MFREE(usbos_info->pub->osh, txirb->send_buf, req->buf_len);
+		txirb->send_buf = NULL;
+		req->buf_len = 0;
+	}
+	dbus_usbos_qenq(&usbos_info->req_txfreeq, req, &usbos_info->txfree_lock);
+#ifndef USBOS_TX_THREAD
+fail2:
+#endif
+	if (req_zlp != NULL) {
+		dbus_usbos_qenq(&usbos_info->req_txfreeq, req_zlp, &usbos_info->txfree_lock);
+	}
+
+	spin_unlock_irqrestore(&usbos_info->txlock, flags);
+
+#ifndef USBOS_TX_THREAD
+	USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+#endif /* !USBOS_TX_THREAD */
+
+	return ret;
+} /* dbus_usbos_intf_send_irb */
+
+/** Higher layer (dbus_usb.c) recycles a received (and used) packet. */
+static int
+dbus_usbos_intf_recv_irb(void *bus, dbus_irb_rx_t *rxirb)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	int ret = DBUS_OK;
+
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+	ret = dbus_usbos_recv_urb_submit(usbos_info, rxirb, 0);
+	return ret;
+}
+
+static int
+dbus_usbos_intf_recv_irb_from_ep(void *bus, dbus_irb_rx_t *rxirb, uint32 ep_idx)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	int ret = DBUS_OK;
+
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+#ifdef INTR_EP_ENABLE
+		/* By specifying the ep_idx value of 0xff, the cdc layer is asking to
+		* submit an interrupt URB
+		*/
+		if (rxirb == NULL && ep_idx == 0xff) {
+			/* submit intr URB */
+			if ((ret = USB_SUBMIT_URB(usbos_info->intr_urb)) < 0) {
+				DBUSERR(("%s intr USB_SUBMIT_URB failed, status %d\n",
+					__FUNCTION__, ret));
+			}
+			return ret;
+		}
+#else
+		if (rxirb == NULL) {
+			return DBUS_ERR;
+		}
+#endif /* INTR_EP_ENABLE */
+
+	ret = dbus_usbos_recv_urb_submit(usbos_info, rxirb, ep_idx);
+	return ret;
+}
+
+/** Higher layer (dbus_usb.c) want to cancel an IRB */
+static int
+dbus_usbos_intf_cancel_irb(void *bus, dbus_irb_tx_t *txirb)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+	return DBUS_ERR;
+}
+
+/** Only one CTL transfer can be pending at any time. This function may block. */
+static int
+dbus_usbos_intf_send_ctl(void *bus, uint8 *buf, int len)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	uint16 size;
+#ifndef USBOS_TX_THREAD
+	int status;
+#endif /* USBOS_TX_THREAD */
+
+	if ((usbos_info == NULL) || (buf == NULL) || (len == 0))
+		return DBUS_ERR;
+
+	if (usbos_info->ctl_urb == NULL)
+		return DBUS_ERR;
+
+	/* Block until a pending CTL transfer has completed */
+	if (down_interruptible(&usbos_info->ctl_lock) != 0) {
+		return DBUS_ERR_TXCTLFAIL;
+	}
+
+#ifdef USBOS_TX_THREAD
+	ASSERT(usbos_info->ctl_state == USBOS_REQUEST_STATE_UNSCHEDULED);
+#else
+	/* Disable USB autosuspend until this request completes, request USB resume if needed.
+	 * Because this call runs asynchronously, there is no guarantee the bus is resumed before
+	 * the URB is submitted, and the URB might be dropped. Use USBOS_TX_THREAD to avoid
+	 * this.
+	 */
+	USB_AUTOPM_GET_INTERFACE_ASYNC(g_probe_info.intf);
+#endif /* USBOS_TX_THREAD */
+
+	size = len;
+	usbos_info->ctl_write.wLength = cpu_to_le16p(&size);
+	usbos_info->ctl_urb->transfer_buffer_length = size;
+
+	usb_fill_control_urb(usbos_info->ctl_urb,
+		usbos_info->usb,
+		usb_sndctrlpipe(usbos_info->usb, 0),
+		(unsigned char *) &usbos_info->ctl_write,
+		buf, size, (usb_complete_t)dbus_usbos_ctlwrite_complete, usbos_info);
+
+#ifdef USBOS_TX_THREAD
+	/* Enqueue CTRL request for transmission by the TX thread. The
+	 * USB bus will first be resumed if needed.
+	 */
+	usbos_info->ctl_state = USBOS_REQUEST_STATE_SCHEDULED;
+	wake_up_interruptible(&usbos_info->usbos_tx_queue_head);
+#else
+	status = USB_SUBMIT_URB(usbos_info->ctl_urb);
+	if (status < 0) {
+		DBUSERR(("%s: usb_submit_urb failed %d\n", __FUNCTION__, status));
+		up(&usbos_info->ctl_lock);
+
+		USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+
+		return DBUS_ERR_TXCTLFAIL;
+	}
+#endif /* USBOS_TX_THREAD */
+
+	return DBUS_OK;
+} /* dbus_usbos_intf_send_ctl */
+
+/** This function does not seem to be called by anyone, including dbus_usb.c */
+static int
+dbus_usbos_intf_recv_ctl(void *bus, uint8 *buf, int len)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	int status;
+	uint16 size;
+
+	if ((usbos_info == NULL) || (buf == NULL) || (len == 0))
+		return DBUS_ERR;
+
+	if (usbos_info->ctl_urb == NULL)
+		return DBUS_ERR;
+
+	/* Block until a pending CTRL transfer has completed */
+	if (down_interruptible(&usbos_info->ctl_lock) != 0) {
+		return DBUS_ERR_TXCTLFAIL;
+	}
+
+	/* Disable USB autosuspend until this request completes, request USB resume if needed. */
+	USB_AUTOPM_GET_INTERFACE_ASYNC(g_probe_info.intf);
+
+	size = len;
+	usbos_info->ctl_read.wLength = cpu_to_le16p(&size);
+	usbos_info->ctl_urb->transfer_buffer_length = size;
+
+	if (usbos_info->rxctl_deferrespok) {
+		/* BMAC model */
+		usbos_info->ctl_read.bRequestType = USB_DIR_IN | USB_TYPE_VENDOR |
+			USB_RECIP_INTERFACE;
+		usbos_info->ctl_read.bRequest = DL_DEFER_RESP_OK;
+	} else {
+		/* full dongle model */
+		usbos_info->ctl_read.bRequestType = USB_DIR_IN | USB_TYPE_CLASS |
+			USB_RECIP_INTERFACE;
+		usbos_info->ctl_read.bRequest = 1;
+	}
+
+	usb_fill_control_urb(usbos_info->ctl_urb,
+		usbos_info->usb,
+		usb_rcvctrlpipe(usbos_info->usb, 0),
+		(unsigned char *) &usbos_info->ctl_read,
+		buf, size, (usb_complete_t)dbus_usbos_ctlread_complete, usbos_info);
+
+	status = USB_SUBMIT_URB(usbos_info->ctl_urb);
+	if (status < 0) {
+		DBUSERR(("%s: usb_submit_urb failed %d\n", __FUNCTION__, status));
+		up(&usbos_info->ctl_lock);
+
+		USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+
+		return DBUS_ERR_RXCTLFAIL;
+	}
+
+	return DBUS_OK;
+}
+
+static int
+dbus_usbos_intf_get_attrib(void *bus, dbus_attrib_t *attrib)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+
+	if ((usbos_info == NULL) || (attrib == NULL))
+		return DBUS_ERR;
+
+	attrib->bustype = DBUS_USB;
+	attrib->vid = g_probe_info.vid;
+	attrib->pid = g_probe_info.pid;
+
+	attrib->devid = g_probe_info.pid;
+
+	attrib->nchan = 1;
+
+	/* MaxPacketSize for USB hi-speed bulk out is 512 bytes
+	 * and 64-bytes for full-speed.
+	 * When sending pkt > MaxPacketSize, Host SW breaks it
+	 * up into multiple packets.
+	 */
+	attrib->mtu = usbos_info->maxps;
+
+	return DBUS_OK;
+}
+
+/** Called by higher layer (dbus_usb.c) when it wants to 'up' the USB interface to the dongle */
+static int
+dbus_usbos_intf_up(void *bus)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	uint16 ifnum;
+#ifdef BCMUSBDEV_COMPOSITE
+	int wlan_if = 0;
+#endif
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+	if (usbos_info->usb == NULL)
+		return DBUS_ERR;
+
+#if defined(INTR_EP_ENABLE)
+	/* full dongle use intr EP, bmac doesn't use it */
+	if (usbos_info->intr_urb) {
+		int ret;
+
+		usb_fill_int_urb(usbos_info->intr_urb, usbos_info->usb,
+			usbos_info->intr_pipe, &usbos_info->intr,
+			usbos_info->intr_size, (usb_complete_t)dbus_usbos_intr_complete,
+			usbos_info, usbos_info->interval);
+
+		if ((ret = USB_SUBMIT_URB(usbos_info->intr_urb))) {
+			DBUSERR(("%s USB_SUBMIT_URB failed with status %d\n", __FUNCTION__, ret));
+			return DBUS_ERR;
+		}
+	}
+#endif	
+
+	if (usbos_info->ctl_urb) {
+		usbos_info->ctl_in_pipe = usb_rcvctrlpipe(usbos_info->usb, 0);
+		usbos_info->ctl_out_pipe = usb_sndctrlpipe(usbos_info->usb, 0);
+
+#ifdef BCMUSBDEV_COMPOSITE
+		wlan_if = dbus_usbos_intf_wlan(usbos_info->usb);
+		ifnum = cpu_to_le16(IFDESC(usbos_info->usb, wlan_if).bInterfaceNumber);
+#else
+		ifnum = cpu_to_le16(IFDESC(usbos_info->usb, CONTROL_IF).bInterfaceNumber);
+#endif /* BCMUSBDEV_COMPOSITE */
+		/* CTL Write */
+		usbos_info->ctl_write.bRequestType =
+			USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_INTERFACE;
+		usbos_info->ctl_write.bRequest = 0;
+		usbos_info->ctl_write.wValue = cpu_to_le16(0);
+		usbos_info->ctl_write.wIndex = cpu_to_le16p(&ifnum);
+
+		/* CTL Read */
+		usbos_info->ctl_read.bRequestType =
+			USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE;
+		usbos_info->ctl_read.bRequest = 1;
+		usbos_info->ctl_read.wValue = cpu_to_le16(0);
+		usbos_info->ctl_read.wIndex = cpu_to_le16p(&ifnum);
+	}
+
+	/* Success, indicate usbos_info is fully up */
+	dbus_usbos_state_change(usbos_info, DBUS_STATE_UP);
+
+	return DBUS_OK;
+} /* dbus_usbos_intf_up */
+
+static int
+dbus_usbos_intf_down(void *bus)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+	dbusos_stop(usbos_info);
+	return DBUS_OK;
+}
+
+static int
+dbus_usbos_intf_stop(void *bus)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+	dbusos_stop(usbos_info);
+	return DBUS_OK;
+}
+
+#if defined(DBUS_LINUX_HIST)
+static void
+dbus_usbos_intf_dump(void *bus, struct bcmstrbuf *b)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	int i = 0, j = 0, rxposted, txposted;
+
+	rxposted = atomic_read(&usbos_info->rxposted);
+	txposted = atomic_read(&usbos_info->txposted);
+	if (b) {
+		bcm_bprintf(b, "\ndbus linux dump\n");
+		bcm_bprintf(b, "txposted %d rxposted %d\n",
+			txposted, rxposted);
+
+		bcm_bprintf(b, "RXDPC: dpc_cnt %d dpc_pktcnt %d dpc_maxpktcnt %d avg_dpc_pktcnt\n",
+			usbos_info->dpc_cnt, usbos_info->dpc_pktcnt,
+			usbos_info->dpc_maxpktcnt, usbos_info->dpc_cnt ?
+			(usbos_info->dpc_pktcnt/usbos_info->dpc_cnt):1);
+
+		/* Histogram */
+		bcm_bprintf(b, "txposted\n");
+	} else {
+		printf("\ndbus linux dump\n");
+		printf("txposted %d rxposted %d\n",
+			txposted, rxposted);
+		printf("RXDPC: dpc_cnt %d dpc_pktcnt %d dpc_maxpktcnt %d avg_dpc_pktcnt %d\n",
+			usbos_info->dpc_cnt, usbos_info->dpc_pktcnt,
+			usbos_info->dpc_maxpktcnt, usbos_info->dpc_cnt ?
+			(usbos_info->dpc_pktcnt/usbos_info->dpc_cnt):1);
+
+		/* Histogram */
+		printf("txposted\n");
+	}
+
+	for (i = 0; i < usbos_info->pub->ntxq; i++) {
+		if (usbos_info->txposted_hist == NULL) {
+			break;
+		}
+		if (usbos_info->txposted_hist[i]) {
+			if (b)
+				bcm_bprintf(b, "%d: %d ", i, usbos_info->txposted_hist[i]);
+			else
+				printf("%d: %d ", i, usbos_info->txposted_hist[i]);
+			j++;
+			if (j % 10 == 0) {
+				if (b)
+					bcm_bprintf(b, "\n");
+				else
+					printf("\n");
+			}
+		}
+	}
+
+	j = 0;
+	if (b)
+		bcm_bprintf(b, "\nrxposted\n");
+	else
+		printf("\nrxposted\n");
+	for (i = 0; i < usbos_info->pub->nrxq; i++) {
+		if (usbos_info->rxposted_hist == NULL) {
+			break;
+		}
+		if (usbos_info->rxposted_hist[i]) {
+			if (b)
+				bcm_bprintf(b, "%d: %d ", i, usbos_info->rxposted_hist[i]);
+			else
+				printf("%d: %d ", i, usbos_info->rxposted_hist[i]);
+			j++;
+			if (j % 10 == 0) {
+				if (b)
+					bcm_bprintf(b, "\n");
+				else
+					printf("\n");
+			}
+		}
+	}
+	if (b)
+		bcm_bprintf(b, "\n");
+	else
+		printf("\n");
+
+	return;
+}
+#endif 
+
+/** Called by higher layer (dbus_usb.c) */
+static int
+dbus_usbos_intf_set_config(void *bus, dbus_config_t *config)
+{
+	int err = DBUS_ERR;
+	usbos_info_t* usbos_info = bus;
+
+	if (config->config_id == DBUS_CONFIG_ID_RXCTL_DEFERRES) {
+		usbos_info->rxctl_deferrespok = config->rxctl_deferrespok;
+		err = DBUS_OK;
+	}
+#ifdef KEEPIF_ON_DEVICE_RESET
+	else if (config->config_id == DBUS_CONFIG_ID_KEEPIF_ON_DEVRESET) {
+		g_probe_info.keepif_on_devreset = config->general_param ? TRUE : FALSE;
+		err = DBUS_OK;
+	}
+#endif /* KEEPIF_ON_DEVICE_RESET */
+	else if (config->config_id == DBUS_CONFIG_ID_AGGR_LIMIT) {
+#ifndef BCM_FD_AGGR
+		/* DBUS_CONFIG_ID_AGGR_LIMIT shouldn't be called after probe stage */
+		ASSERT(disc_arg == NULL);
+#endif /* BCM_FD_AGGR */
+		ASSERT(config->aggr_param.maxrxsf > 0);
+		ASSERT(config->aggr_param.maxrxsize > 0);
+		if (config->aggr_param.maxrxsize > usbos_info->rxbuf_len) {
+			int state = usbos_info->pub->busstate;
+			dbus_usbos_unlink(&usbos_info->req_rxpostedq, &usbos_info->rxposted_lock);
+			while (atomic_read(&usbos_info->rxposted)) {
+				DBUSTRACE(("%s rxposted is %d, delay 1 ms\n", __FUNCTION__,
+					atomic_read(&usbos_info->rxposted)));
+				dbus_usbos_wait(usbos_info, 1);
+			}
+			usbos_info->rxbuf_len = config->aggr_param.maxrxsize;
+			dbus_usbos_state_change(usbos_info, state);
+		}
+		err = DBUS_OK;
+	}
+
+	return err;
+}
+
+#ifdef EHCI_FASTPATH_TX
+
+/**
+ * In some cases, the code must submit an URB and wait for its completion.
+ * Related: dbus_usbos_sync_complete()
+ */
+static int
+dbus_usbos_sync_wait(usbos_info_t *usbinfo, uint16 time)
+{
+	int ret;
+	int err = DBUS_OK;
+	int ms = time;
+
+	ret = wait_event_interruptible_timeout(usbinfo->wait,
+		usbinfo->waitdone == TRUE, (ms * HZ / 1000));
+
+	if ((usbinfo->waitdone == FALSE) || (usbinfo->sync_urb_status)) {
+		DBUSERR(("%s: timeout(%d) or urb err=0x%x\n",
+			__FUNCTION__, ret, usbinfo->sync_urb_status));
+		err = DBUS_ERR;
+		BCM_REFERENCE(ret);
+	}
+	usbinfo->waitdone = FALSE;
+	return err;
+}
+
+
+#endif /* EHCI_FASTPATH_TX */
+
+/** Called by dbus_usb.c when it wants to download firmware into the dongle */
+bool
+dbus_usbos_dl_cmd(usbos_info_t *usbinfo, uint8 cmd, void *buffer, int buflen)
+{
+	int transferred;
+	int index = 0;
+	char *tmpbuf;
+
+	if ((usbinfo == NULL) || (buffer == NULL) || (buflen == 0))
+		return FALSE;
+
+	tmpbuf = (char *) MALLOC(usbinfo->pub->osh, buflen);
+	if (!tmpbuf) {
+		DBUSERR(("%s: Unable to allocate memory \n", __FUNCTION__));
+		return FALSE;
+	}
+
+#ifdef BCM_REQUEST_FW
+	if (cmd == DL_GO) {
+		index = 1;
+	}
+#endif
+
+	/* Disable USB autosuspend until this request completes, request USB resume if needed. */
+	USB_AUTOPM_GET_INTERFACE(g_probe_info.intf);
+
+	transferred = USB_CONTROL_MSG(usbinfo->usb, usb_rcvctrlpipe(usbinfo->usb, 0),
+		cmd, (USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_INTERFACE),
+		0, index,
+		(void*) tmpbuf, buflen, USB_CTRL_EP_TIMEOUT);
+	if (transferred == buflen) {
+		memcpy(buffer, tmpbuf, buflen);
+	} else {
+		DBUSERR(("%s: usb_control_msg failed %d\n", __FUNCTION__, transferred));
+	}
+
+	USB_AUTOPM_PUT_INTERFACE(g_probe_info.intf);
+
+	MFREE(usbinfo->pub->osh, tmpbuf, buflen);
+	return (transferred == buflen);
+}
+
+/**
+ * Called by dbus_usb.c when it wants to download a buffer into the dongle (e.g. as part of the
+ * download process, when writing nvram variables).
+ */
+int
+dbus_write_membytes(usbos_info_t* usbinfo, bool set, uint32 address, uint8 *data, uint size)
+{
+	hwacc_t hwacc;
+	int write_bytes = 4;
+	int status;
+	int retval = 0;
+
+	DBUSTRACE(("Enter:%s\n", __FUNCTION__));
+
+	/* Read is not supported */
+	if (set == 0) {
+		DBUSERR(("Currently read is not supported!!\n"));
+		return -1;
+	}
+
+	USB_AUTOPM_GET_INTERFACE(g_probe_info.intf);
+
+	hwacc.cmd = DL_CMD_WRHW;
+	hwacc.addr = address;
+
+	DBUSTRACE(("Address:%x size:%d", hwacc.addr, size));
+	do {
+		if (size >= 4) {
+			write_bytes = 4;
+		} else if (size >= 2) {
+			write_bytes = 2;
+		} else {
+			write_bytes = 1;
+		}
+
+		hwacc.len = write_bytes;
+
+		while (size >= write_bytes) {
+			hwacc.data = *((unsigned int*)data);
+
+			status = USB_CONTROL_MSG(usbinfo->usb, usb_sndctrlpipe(usbinfo->usb, 0),
+				DL_WRHW, (USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_INTERFACE),
+				1, 0, (char *)&hwacc, sizeof(hwacc_t), USB_CTRL_EP_TIMEOUT);
+
+			if (status < 0) {
+				retval = -1;
+				DBUSERR((" Ctrl write hwacc failed w/status %d @ address:%x \n",
+					status, hwacc.addr));
+				goto err;
+			}
+
+			hwacc.addr += write_bytes;
+			data += write_bytes;
+			size -= write_bytes;
+		}
+	} while (size > 0);
+
+err:
+	USB_AUTOPM_PUT_INTERFACE(g_probe_info.intf);
+
+	return retval;
+}
+
+int
+dbus_usbos_readreg(void *bus, uint32 regaddr, int datalen, uint32 *value)
+{
+	usbos_info_t *usbinfo = (usbos_info_t *) bus;
+	int ret = DBUS_OK;
+	int transferred;
+	uint32 cmd;
+	hwacc_t	hwacc;
+
+	if (usbinfo == NULL)
+		return DBUS_ERR;
+
+	if (datalen == 1)
+		cmd = DL_RDHW8;
+	else if (datalen == 2)
+		cmd = DL_RDHW16;
+	else
+		cmd = DL_RDHW32;
+
+	USB_AUTOPM_GET_INTERFACE(g_probe_info.intf);
+
+	transferred = USB_CONTROL_MSG(usbinfo->usb, usb_rcvctrlpipe(usbinfo->usb, 0),
+		cmd, (USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_INTERFACE),
+		(uint16)(regaddr), (uint16)(regaddr >> 16),
+		(void *) &hwacc, sizeof(hwacc_t), USB_CTRL_EP_TIMEOUT);
+
+	if (transferred >= sizeof(hwacc_t)) {
+		*value = hwacc.data;
+	} else {
+		DBUSERR(("%s: usb_control_msg failed %d\n", __FUNCTION__, transferred));
+		ret = DBUS_ERR;
+	}
+
+	USB_AUTOPM_PUT_INTERFACE(g_probe_info.intf);
+
+	return ret;
+}
+
+int
+dbus_usbos_writereg(void *bus, uint32 regaddr, int datalen, uint32 data)
+{
+	usbos_info_t *usbinfo = (usbos_info_t *) bus;
+	int ret = DBUS_OK;
+	int transferred;
+	uint32 cmd = DL_WRHW;
+	hwacc_t	hwacc;
+
+	if (usbinfo == NULL)
+		return DBUS_ERR;
+
+	USB_AUTOPM_GET_INTERFACE(g_probe_info.intf);
+
+	hwacc.cmd = DL_WRHW;
+	hwacc.addr = regaddr;
+	hwacc.data = data;
+	hwacc.len = datalen;
+
+	transferred = USB_CONTROL_MSG(usbinfo->usb, usb_sndctrlpipe(usbinfo->usb, 0),
+		cmd, (USB_DIR_OUT| USB_TYPE_VENDOR | USB_RECIP_INTERFACE),
+		1, 0,
+		(void *) &hwacc, sizeof(hwacc_t), USB_CTRL_EP_TIMEOUT);
+
+	if (transferred != sizeof(hwacc_t)) {
+		DBUSERR(("%s: usb_control_msg failed %d\n", __FUNCTION__, transferred));
+		ret = DBUS_ERR;
+	}
+
+	USB_AUTOPM_PUT_INTERFACE(g_probe_info.intf);
+
+	return ret;
+}
+
+int
+dbus_usbos_wait(usbos_info_t *usbinfo, uint16 ms)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 0))
+	if (in_interrupt())
+		mdelay(ms);
+	else
+		msleep_interruptible(ms);
+#else
+	wait_ms(ms);
+#endif
+	return DBUS_OK;
+}
+
+/** Called by dbus_usb.c as part of the firmware download process */
+bool
+dbus_usbos_dl_send_bulk(usbos_info_t *usbinfo, void *buffer, int len)
+{
+#ifdef EHCI_FASTPATH_TX
+	int ret = DBUS_ERR;
+
+	struct ehci_qtd *qtd = optimize_ehci_qtd_alloc(GFP_KERNEL);
+	int token = EHCI_QTD_SET_CERR(3);
+
+	if (qtd == NULL)
+		goto fail;
+
+	optimize_qtd_fill_with_data(usbinfo->pub, 0, qtd, buffer, token, len);
+	optimize_submit_async(qtd, 0);
+
+	ret = dbus_usbos_sync_wait(usbinfo, USB_SYNC_WAIT_TIMEOUT);
+
+	return (ret == DBUS_OK);
+fail:
+	return FALSE;
+#else
+	bool ret = TRUE;
+	int status;
+	int transferred = 0;
+
+	if (usbinfo == NULL)
+		return DBUS_ERR;
+
+	USB_AUTOPM_GET_INTERFACE(g_probe_info.intf);
+
+	status = USB_BULK_MSG(usbinfo->usb, usbinfo->tx_pipe,
+		buffer, len,
+		&transferred, USB_BULK_EP_TIMEOUT);
+
+	if (status < 0) {
+		DBUSERR(("%s: usb_bulk_msg failed %d\n", __FUNCTION__, status));
+		ret = FALSE;
+	}
+
+	USB_AUTOPM_PUT_INTERFACE(g_probe_info.intf);
+
+	return ret;
+#endif /* EHCI_FASTPATH_TX */
+}
+
+static bool
+dbus_usbos_intf_recv_needed(void *bus)
+{
+	return FALSE;
+}
+
+/**
+ * Higher layer (dbus_usb.c) wants to execute a function on the condition that the rx spin lock has
+ * been acquired.
+ */
+static void*
+dbus_usbos_intf_exec_rxlock(void *bus, exec_cb_t cb, struct exec_parms *args)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	void *ret;
+	unsigned long flags;
+
+	if (usbos_info == NULL)
+		return NULL;
+
+	spin_lock_irqsave(&usbos_info->rxlock, flags);
+	ret = cb(args);
+	spin_unlock_irqrestore(&usbos_info->rxlock, flags);
+
+	return ret;
+}
+
+static void*
+dbus_usbos_intf_exec_txlock(void *bus, exec_cb_t cb, struct exec_parms *args)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+	void *ret;
+	unsigned long flags;
+
+	if (usbos_info == NULL)
+		return NULL;
+
+	spin_lock_irqsave(&usbos_info->txlock, flags);
+	ret = cb(args);
+	spin_unlock_irqrestore(&usbos_info->txlock, flags);
+
+	return ret;
+}
+
+/**
+ * if an error condition was detected in this module, the higher DBUS layer (dbus_usb.c) has to
+ * be notified.
+ */
+int
+dbus_usbos_errhandler(void *bus, int err)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+	if (usbos_info->cbarg && usbos_info->cbs) {
+		if (usbos_info->cbs->errhandler)
+			usbos_info->cbs->errhandler(usbos_info->cbarg, err);
+	}
+
+	return DBUS_OK;
+}
+
+/**
+ * if a change in bus state was detected in this module, the higher DBUS layer (dbus_usb.c) has to
+ * be notified.
+ */
+int
+dbus_usbos_state_change(void *bus, int state)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) bus;
+
+	if (usbos_info == NULL)
+		return DBUS_ERR;
+
+	if (usbos_info->cbarg && usbos_info->cbs) {
+		if (usbos_info->cbs->state_change)
+			usbos_info->cbs->state_change(usbos_info->cbarg, state);
+	}
+
+	usbos_info->pub->busstate = state;
+	return DBUS_OK;
+}
+
+int
+dbus_bus_osl_register(int vid, int pid, probe_cb_t prcb,
+	disconnect_cb_t discb, void *prarg, dbus_intf_t **intf, void *param1, void *param2)
+{
+	bzero(&g_probe_info, sizeof(probe_info_t));
+
+	probe_cb = prcb;
+	disconnect_cb = discb;
+	probe_arg = prarg;
+
+	devid_table[0].idVendor = vid;
+	devid_table[0].idProduct = pid;
+
+	*intf = &dbus_usbos_intf;
+
+	USB_REGISTER();
+
+#ifdef KEEPIF_ON_DEVICE_RESET
+	init_waitqueue_head(&g_probe_info.usbreset_queue_head);
+	atomic_set(&g_probe_info.usbdev_stat, USB_DEVICE_INIT);
+	g_probe_info.usbreset_kt = kthread_create(dbus_usbos_usbreset_func,
+		&g_probe_info, "usbreset-thread");
+	ASSERT(!IS_ERR(g_probe_info.usbreset_kt));
+	wake_up_process(g_probe_info.usbreset_kt);
+#endif /* KEEPIF_ON_DEVICE_RESET */
+
+	return DBUS_ERR_NODEVICE;
+}
+
+int
+dbus_bus_osl_deregister()
+{
+	g_probe_info.dereged = TRUE;
+
+#ifdef KEEPIF_ON_DEVICE_RESET
+	wake_up_interruptible(&g_probe_info.usbreset_queue_head);
+	kthread_stop(g_probe_info.usbreset_kt);
+#endif /* KEEPIF_ON_DEVICE_RESET */
+
+	if (disconnect_cb && disc_arg && (g_probe_info.disc_cb_done == FALSE)) {
+		disconnect_cb(disc_arg);
+		disc_arg = NULL;
+	}
+
+	USB_DEREGISTER();
+
+	return DBUS_OK;
+}
+
+static void
+dbus_usbos_init_info(void)
+{
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+
+	if (!usbos_info) {
+		return;
+	}
+
+	/* Update USB Info */
+	usbos_info->usb = g_probe_info.usb;
+	usbos_info->rx_pipe = g_probe_info.rx_pipe;
+	usbos_info->rx_pipe2 = g_probe_info.rx_pipe2;
+	usbos_info->tx_pipe = g_probe_info.tx_pipe;
+	usbos_info->intr_pipe = g_probe_info.intr_pipe;
+	usbos_info->intr_size = g_probe_info.intr_size;
+	usbos_info->interval = g_probe_info.interval;
+	usbos_info->pub->device_speed = g_probe_info.device_speed;
+	usbos_info->pub->dev_info = g_probe_info.usb;
+	if (usbos_info->rx_pipe2) {
+		usbos_info->pub->attrib.has_2nd_bulk_in_ep = 1;
+	} else {
+		usbos_info->pub->attrib.has_2nd_bulk_in_ep = 0;
+	}
+
+	if (usbos_info->tx_pipe)
+		usbos_info->maxps = usb_maxpacket(usbos_info->usb,
+			usbos_info->tx_pipe, usb_pipeout(usbos_info->tx_pipe));
+}
+
+void *
+dbus_usbos_intf_attach(dbus_pub_t *pub, void *cbarg, dbus_intf_callbacks_t *cbs)
+{
+	usbos_info_t *usbos_info;
+
+	if (g_probe_info.dldone == FALSE) {
+		DBUSERR(("%s: err device not downloaded!\n", __FUNCTION__));
+		return NULL;
+	}
+
+	/* Sanity check for BUS_INFO() */
+	ASSERT(OFFSETOF(usbos_info_t, pub) == 0);
+
+	usbos_info = MALLOC(pub->osh, sizeof(usbos_info_t));
+	if (usbos_info == NULL)
+		return NULL;
+
+	bzero(usbos_info, sizeof(usbos_info_t));
+
+	usbos_info->pub = pub;
+	usbos_info->cbarg = cbarg;
+	usbos_info->cbs = cbs;
+
+	/* Needed for disconnect() */
+	g_probe_info.usbos_info = usbos_info;
+	dbus_usbos_init_info();
+
+	INIT_LIST_HEAD(&usbos_info->req_rxfreeq);
+	INIT_LIST_HEAD(&usbos_info->req_txfreeq);
+	INIT_LIST_HEAD(&usbos_info->req_rxpostedq);
+	INIT_LIST_HEAD(&usbos_info->req_txpostedq);
+	spin_lock_init(&usbos_info->rxfree_lock);
+	spin_lock_init(&usbos_info->txfree_lock);
+	spin_lock_init(&usbos_info->rxposted_lock);
+	spin_lock_init(&usbos_info->txposted_lock);
+	spin_lock_init(&usbos_info->rxlock);
+	spin_lock_init(&usbos_info->txlock);
+
+	atomic_set(&usbos_info->rxposted, 0);
+	atomic_set(&usbos_info->txposted, 0);
+
+#ifdef DBUS_LINUX_RXDPC
+	INIT_LIST_HEAD(&usbos_info->req_rxpendingq);
+	spin_lock_init(&usbos_info->rxpending_lock);
+#endif /* DBUS_LINUX_RXDPC */
+
+#if defined(DBUS_LINUX_HIST)
+	usbos_info->txposted_hist = MALLOC(pub->osh, (usbos_info->pub->ntxq+1) * sizeof(int));
+	if (usbos_info->txposted_hist) {
+		bzero(usbos_info->txposted_hist, (usbos_info->pub->ntxq+1) * sizeof(int));
+	}
+	usbos_info->rxposted_hist = MALLOC(pub->osh, (usbos_info->pub->nrxq+1) * sizeof(int));
+	if (usbos_info->rxposted_hist) {
+		bzero(usbos_info->rxposted_hist, (usbos_info->pub->nrxq+1) * sizeof(int));
+	}
+#endif
+#ifdef USB_DISABLE_INT_EP
+	usbos_info->intr_urb = NULL;
+#else
+	if (!(usbos_info->intr_urb = USB_ALLOC_URB())) {
+		DBUSERR(("%s: usb_alloc_urb (tx) failed\n", __FUNCTION__));
+		goto fail;
+	}
+#endif
+
+	if (!(usbos_info->ctl_urb = USB_ALLOC_URB())) {
+		DBUSERR(("%s: usb_alloc_urb (tx) failed\n", __FUNCTION__));
+		goto fail;
+	}
+
+	init_waitqueue_head(&usbos_info->wait);
+
+	if (!(usbos_info->blk_urb = USB_ALLOC_URB())) {	/* for embedded image downloading */
+		DBUSERR(("%s: usb_alloc_urb (tx) failed\n", __FUNCTION__));
+		goto fail;
+	}
+
+	usbos_info->rxbuf_len = (uint)usbos_info->pub->rxsize;
+
+
+#ifdef DBUS_LINUX_RXDPC		/* Initialize DPC thread */
+	sema_init(&usbos_info->dpc_sem, 0);
+	init_completion(&usbos_info->dpc_exited);
+	usbos_info->dpc_pid = kernel_thread(dbus_usbos_dpc_thread, usbos_info, 0);
+	if (usbos_info->dpc_pid < 0) {
+		DBUSERR(("%s: failed to create dpc thread\n", __FUNCTION__));
+		goto fail;
+	}
+#endif /* DBUS_LINUX_RXDPC */
+
+	atomic_set(&usbos_info->txallocated, 0);
+	if (DBUS_OK != dbus_usbos_urbreqs_alloc(usbos_info,
+		usbos_info->pub->ntxq, FALSE)) {
+		goto fail;
+	}
+
+	atomic_set(&usbos_info->rxallocated, 0);
+	if (DBUS_OK != dbus_usbos_urbreqs_alloc(usbos_info,
+#ifdef CTFPOOL
+		usbos_info->pub->nrxq,
+#else
+		MIN(DBUS_USB_RXQUEUE_BATCH_ADD, usbos_info->pub->nrxq),
+#endif
+		TRUE)) {
+		goto fail;
+	}
+
+	sema_init(&usbos_info->ctl_lock, 1);
+
+#ifdef USBOS_THREAD
+	if (dbus_usbos_thread_init(usbos_info) == NULL)
+		goto fail;
+#endif /* USBOS_THREAD */
+
+#ifdef USBOS_TX_THREAD
+	if (dbus_usbos_tx_thread_init(usbos_info) == NULL)
+		goto fail;
+#endif /* USBOS_TX_THREAD */
+
+#if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX)
+	spin_lock_init(&usbos_info->fastpath_lock);
+	if (optimize_init(usbos_info, usbos_info->usb, usbos_info->tx_pipe,
+		usbos_info->rx_pipe, usbos_info->rx_pipe2) != 0) {
+		DBUSERR(("%s: optimize_init failed!\n", __FUNCTION__));
+		goto fail;
+	}
+
+#endif /* EHCI_FASTPATH_TX || EHCI_FASTPATH_RX */
+
+	return (void *) usbos_info;
+fail:
+#ifdef DBUS_LINUX_RXDPC
+	if (usbos_info->dpc_pid >= 0) {
+		KILL_PROC(usbos_info->dpc_pid, SIGTERM);
+		wait_for_completion(&usbos_info->dpc_exited);
+	}
+#endif /* DBUS_LINUX_RXDPC */
+	if (usbos_info->intr_urb) {
+		USB_FREE_URB(usbos_info->intr_urb);
+		usbos_info->intr_urb = NULL;
+	}
+
+	if (usbos_info->ctl_urb) {
+		USB_FREE_URB(usbos_info->ctl_urb);
+		usbos_info->ctl_urb = NULL;
+	}
+
+#if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+	if (usbos_info->blk_urb) {
+		USB_FREE_URB(usbos_info->blk_urb);
+		usbos_info->blk_urb = NULL;
+	}
+#endif
+
+	dbus_usbos_urbreqs_free(usbos_info, TRUE);
+	atomic_set(&usbos_info->rxallocated, 0);
+	dbus_usbos_urbreqs_free(usbos_info, FALSE);
+	atomic_set(&usbos_info->txallocated, 0);
+
+	g_probe_info.usbos_info = NULL;
+
+	MFREE(pub->osh, usbos_info, sizeof(usbos_info_t));
+	return NULL;
+} /* dbus_usbos_intf_attach */
+
+void
+dbus_usbos_intf_detach(dbus_pub_t *pub, void *info)
+{
+	usbos_info_t *usbos_info = (usbos_info_t *) info;
+	osl_t *osh = pub->osh;
+
+	if (usbos_info == NULL) {
+		return;
+	}
+
+#ifdef USBOS_TX_THREAD
+	dbus_usbos_tx_thread_deinit(usbos_info);
+#endif /* USBOS_TX_THREAD */
+
+#if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX)
+	optimize_deinit(usbos_info, usbos_info->usb);
+#endif
+	/* Must unlink all URBs prior to driver unload;
+	 * otherwise an URB callback can occur after driver
+	 * has been de-allocated and rmmod'd
+	 */
+	dbusos_stop(usbos_info);
+
+	if (usbos_info->intr_urb) {
+		USB_FREE_URB(usbos_info->intr_urb);
+		usbos_info->intr_urb = NULL;
+	}
+
+	if (usbos_info->ctl_urb) {
+		USB_FREE_URB(usbos_info->ctl_urb);
+		usbos_info->ctl_urb = NULL;
+	}
+
+	if (usbos_info->blk_urb) {
+		USB_FREE_URB(usbos_info->blk_urb);
+		usbos_info->blk_urb = NULL;
+	}
+
+	dbus_usbos_urbreqs_free(usbos_info, TRUE);
+	atomic_set(&usbos_info->rxallocated, 0);
+	dbus_usbos_urbreqs_free(usbos_info, FALSE);
+	atomic_set(&usbos_info->txallocated, 0);
+
+#if defined(DBUS_LINUX_HIST)
+	if (usbos_info->txposted_hist) {
+		MFREE(osh, usbos_info->txposted_hist, (usbos_info->pub->ntxq+1) * sizeof(int));
+	}
+	if (usbos_info->rxposted_hist) {
+		MFREE(osh, usbos_info->rxposted_hist, (usbos_info->pub->nrxq+1) * sizeof(int));
+	}
+#endif 
+#ifdef USBOS_THREAD
+	dbus_usbos_thread_deinit(usbos_info);
+#endif /* USBOS_THREAD */
+
+	g_probe_info.usbos_info = NULL;
+	MFREE(osh, usbos_info, sizeof(usbos_info_t));
+} /* dbus_usbos_intf_detach */
+
+
+#ifdef USBOS_TX_THREAD
+
+void*
+dbus_usbos_tx_thread_init(usbos_info_t *usbos_info)
+{
+	spin_lock_init(&usbos_info->usbos_tx_list_lock);
+	INIT_LIST_HEAD(&usbos_info->usbos_tx_list);
+	init_waitqueue_head(&usbos_info->usbos_tx_queue_head);
+
+	usbos_info->usbos_tx_kt = kthread_create(dbus_usbos_tx_thread_func,
+		usbos_info, "usb-tx-thread");
+
+	if (IS_ERR(usbos_info->usbos_tx_kt)) {
+		DBUSERR(("Thread Creation failed\n"));
+		return (NULL);
+	}
+
+	usbos_info->ctl_state = USBOS_REQUEST_STATE_UNSCHEDULED;
+	wake_up_process(usbos_info->usbos_tx_kt);
+
+	return (usbos_info->usbos_tx_kt);
+}
+
+void
+dbus_usbos_tx_thread_deinit(usbos_info_t *usbos_info)
+{
+	urb_req_t *req;
+
+	if (usbos_info->usbos_tx_kt) {
+		wake_up_interruptible(&usbos_info->usbos_tx_queue_head);
+		kthread_stop(usbos_info->usbos_tx_kt);
+	}
+
+	/* Move pending requests to free queue so they can be freed */
+	while ((req = dbus_usbos_qdeq(
+		&usbos_info->usbos_tx_list, &usbos_info->usbos_tx_list_lock)) != NULL) {
+		dbus_usbos_qenq(&usbos_info->req_txfreeq, req, &usbos_info->txfree_lock);
+	}
+}
+
+/**
+ * Allow USB in-band resume to block by submitting CTRL and DATA URBs on a separate thread.
+ */
+int
+dbus_usbos_tx_thread_func(void *data)
+{
+	usbos_info_t  *usbos_info = (usbos_info_t *)data;
+	urb_req_t     *req;
+	dbus_irb_tx_t *txirb;
+	int           ret;
+	unsigned long flags;
+
+#ifdef WL_THREADNICE
+	set_user_nice(current, WL_THREADNICE);
+#endif
+
+	while (1) {
+		/* Wait until there are URBs to submit */
+		wait_event_interruptible_timeout(
+			usbos_info->usbos_tx_queue_head,
+			!list_empty(&usbos_info->usbos_tx_list) ||
+			usbos_info->ctl_state == USBOS_REQUEST_STATE_SCHEDULED,
+			100);
+
+		if (kthread_should_stop())
+			break;
+
+		/* Submit CTRL URB if needed */
+		if (usbos_info->ctl_state == USBOS_REQUEST_STATE_SCHEDULED) {
+
+			/* Disable USB autosuspend until this request completes. If the
+			 * interface was suspended, this call blocks until it has been resumed.
+			 */
+			USB_AUTOPM_GET_INTERFACE(g_probe_info.intf);
+
+			usbos_info->ctl_state = USBOS_REQUEST_STATE_SUBMITTED;
+
+			ret = USB_SUBMIT_URB(usbos_info->ctl_urb);
+			if (ret != 0) {
+				DBUSERR(("%s CTRL USB_SUBMIT_URB failed, status %d\n",
+					__FUNCTION__, ret));
+
+				usbos_info->ctl_state = USBOS_REQUEST_STATE_UNSCHEDULED;
+				up(&usbos_info->ctl_lock);
+
+				USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+			}
+		}
+
+		/* Submit all available TX URBs */
+		while ((req = dbus_usbos_qdeq(&usbos_info->usbos_tx_list,
+			&usbos_info->usbos_tx_list_lock)) != NULL) {
+
+			/* Disable USB autosuspend until this request completes. If the
+			 * interface was suspended, this call blocks until it has been resumed.
+			 */
+			USB_AUTOPM_GET_INTERFACE(g_probe_info.intf);
+
+			spin_lock_irqsave(&usbos_info->txlock, flags);
+
+			ret = USB_SUBMIT_URB(req->urb);
+			if (ret == 0) {
+				/* URB submitted successfully */
+				dbus_usbos_qenq(&usbos_info->req_txpostedq, req,
+					&usbos_info->txposted_lock);
+				atomic_inc(&usbos_info->txposted);
+			} else {
+				/* Submitting the URB failed. */
+				DBUSERR(("%s TX USB_SUBMIT_URB failed, status %d\n",
+					__FUNCTION__, ret));
+
+				USB_AUTOPM_PUT_INTERFACE_ASYNC(g_probe_info.intf);
+			}
+
+			spin_unlock_irqrestore(&usbos_info->txlock, flags);
+
+			if (ret != 0) {
+				/* Cleanup and notify higher layers */
+				dbus_usbos_qenq(&usbos_info->req_txfreeq, req,
+					&usbos_info->txfree_lock);
+
+				txirb = req->arg;
+				if (txirb->send_buf) {
+					MFREE(usbos_info->pub->osh, txirb->send_buf, req->buf_len);
+					txirb->send_buf = NULL;
+					req->buf_len = 0;
+				}
+
+				if (likely (usbos_info->cbarg && usbos_info->cbs)) {
+					if (likely (usbos_info->cbs->send_irb_complete != NULL))
+						usbos_info->cbs->send_irb_complete(
+							usbos_info->cbarg, txirb, DBUS_ERR_TXDROP);
+				}
+			}
+		}
+	}
+
+	return 0;
+} /* dbus_usbos_tx_thread_func */
+
+#endif /* USBOS_TX_THREAD */
+
+#ifdef USBOS_THREAD
+
+/**
+ * Increase system performance by creating a USB thread that runs parallel to other system
+ * activity.
+ */
+static void*
+dbus_usbos_thread_init(usbos_info_t *usbos_info)
+{
+	usbos_list_entry_t  *entry;
+	unsigned long       flags, ii;
+
+	spin_lock_init(&usbos_info->usbos_list_lock);
+	spin_lock_init(&usbos_info->ctrl_lock);
+	INIT_LIST_HEAD(&usbos_info->usbos_list);
+	INIT_LIST_HEAD(&usbos_info->usbos_free_list);
+	init_waitqueue_head(&usbos_info->usbos_queue_head);
+	atomic_set(&usbos_info->usbos_list_cnt, 0);
+
+
+	for (ii = 0; ii < (usbos_info->pub->nrxq + usbos_info->pub->ntxq); ii++) {
+		entry = MALLOC(usbos_info->pub->osh, sizeof(usbos_list_entry_t));
+		if (entry) {
+			spin_lock_irqsave(&usbos_info->usbos_list_lock, flags);
+			list_add_tail((struct list_head*) entry, &usbos_info->usbos_free_list);
+			spin_unlock_irqrestore(&usbos_info->usbos_list_lock, flags);
+		} else {
+			DBUSERR(("Failed to create list\n"));
+		}
+	}
+
+	usbos_info->usbos_kt = kthread_create(dbus_usbos_thread_func,
+		usbos_info, "usb-thread");
+
+	if (IS_ERR(usbos_info->usbos_kt)) {
+		DBUSERR(("Thread Creation failed\n"));
+		return (NULL);
+	}
+
+	wake_up_process(usbos_info->usbos_kt);
+
+	return (usbos_info->usbos_kt);
+}
+
+static void
+dbus_usbos_thread_deinit(usbos_info_t *usbos_info)
+{
+	struct list_head    *cur, *next;
+	usbos_list_entry_t  *entry;
+	unsigned long       flags;
+
+	if (usbos_info->usbos_kt) {
+		wake_up_interruptible(&usbos_info->usbos_queue_head);
+		kthread_stop(usbos_info->usbos_kt);
+	}
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wcast-qual"
+#endif
+	list_for_each_safe(cur, next, &usbos_info->usbos_list)
+	{
+		entry = list_entry(cur, struct usbos_list_entry, list);
+		/* detach this entry from the list and then free the entry */
+		spin_lock_irqsave(&usbos_info->usbos_list_lock, flags);
+		list_del(cur);
+		MFREE(usbos_info->pub->osh, entry, sizeof(usbos_list_entry_t));
+		spin_unlock_irqrestore(&usbos_info->usbos_list_lock, flags);
+	}
+
+	list_for_each_safe(cur, next, &usbos_info->usbos_free_list)
+	{
+		entry = list_entry(cur, struct usbos_list_entry, list);
+		/* detach this entry from the list and then free the entry */
+		spin_lock_irqsave(&usbos_info->usbos_list_lock, flags);
+		list_del(cur);
+		MFREE(usbos_info->pub->osh, entry, sizeof(usbos_list_entry_t));
+		spin_unlock_irqrestore(&usbos_info->usbos_list_lock, flags);
+	}
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic pop
+#endif
+}
+
+/** Process completed URBs in a worker thread */
+static int
+dbus_usbos_thread_func(void *data)
+{
+	usbos_info_t        *usbos_info = (usbos_info_t *)data;
+	usbos_list_entry_t  *entry;
+	struct list_head    *cur, *next;
+	unsigned long       flags;
+
+#ifdef WL_THREADNICE
+	set_user_nice(current, WL_THREADNICE);
+#endif
+
+	while (1) {
+		/* If the list is empty, then go to sleep */
+		wait_event_interruptible_timeout
+		(usbos_info->usbos_queue_head,
+			atomic_read(&usbos_info->usbos_list_cnt) > 0,
+			100);
+
+		if (kthread_should_stop())
+			break;
+
+		spin_lock_irqsave(&usbos_info->usbos_list_lock, flags);
+
+		/* For each entry on the list, process it.  Remove the entry from
+		* the list when done.
+		*/
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wcast-qual"
+#endif
+		list_for_each_safe(cur, next, &usbos_info->usbos_list)
+		{
+			urb_req_t           *req;
+			int                 len;
+			int                 stat;
+			usbos_info_t        *usbos_info_local;
+
+			entry = list_entry(cur, struct usbos_list_entry, list);
+			if (entry == NULL)
+				break;
+
+			req = entry->urb_context;
+			len = entry->urb_length;
+			stat = entry->urb_status;
+			usbos_info_local = req->usbinfo;
+
+			/* detach this entry from the list and attach it to the free list */
+			list_del_init(cur);
+			spin_unlock_irqrestore(&usbos_info_local->usbos_list_lock, flags);
+
+			dbus_usbos_recv_complete_handle(req, len, stat);
+
+			spin_lock_irqsave(&usbos_info_local->usbos_list_lock, flags);
+
+			list_add_tail(cur, &usbos_info_local->usbos_free_list);
+
+			atomic_dec(&usbos_info_local->usbos_list_cnt);
+		}
+
+		spin_unlock_irqrestore(&usbos_info->usbos_list_lock, flags);
+
+	}
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic pop
+#endif
+
+	return 0;
+} /* dbus_usbos_thread_func */
+
+/** Called on Linux calling URB callback, see dbus_usbos_recv_complete() */
+static void
+dbus_usbos_dispatch_schedule(CALLBACK_ARGS)
+{
+	urb_req_t           *req = urb->context;
+	usbos_info_t        *usbos_info = req->usbinfo;
+	usbos_list_entry_t  *entry;
+	unsigned long       flags;
+	struct list_head    *cur;
+
+	spin_lock_irqsave(&usbos_info->usbos_list_lock, flags);
+
+	cur   = usbos_info->usbos_free_list.next;
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wcast-qual"
+#endif
+	entry = list_entry(cur, struct usbos_list_entry, list);
+#if defined(STRICT_GCC_WARNINGS) && defined(__GNUC__)
+#pragma GCC diagnostic pop
+#endif
+
+	/* detach this entry from the free list and prepare it insert it to use list */
+	list_del_init(cur);
+
+	if (entry) {
+		entry->urb_context = urb->context;
+		entry->urb_length  = urb->actual_length;
+		entry->urb_status  = urb->status;
+
+		atomic_inc(&usbos_info->usbos_list_cnt);
+		list_add_tail(cur, &usbos_info->usbos_list);
+	} else {
+		DBUSERR(("!!!!!!OUT OF MEMORY!!!!!!!\n"));
+	}
+
+	spin_unlock_irqrestore(&usbos_info->usbos_list_lock, flags);
+
+	/* thread */
+	wake_up_interruptible(&usbos_info->usbos_queue_head);
+} /* dbus_usbos_dispatch_schedule */
+
+#endif /* USBOS_THREAD */
+
+#ifdef USB_TRIGGER_DEBUG
+static bool
+dbus_usbos_ctl_send_debugtrig(usbos_info_t* usbinfo)
+{
+	bootrom_id_t id;
+
+	if (usbinfo == NULL)
+		return FALSE;
+
+	id.chip = 0xDEAD;
+
+	dbus_usbos_dl_cmd(usbinfo, DL_DBGTRIG, &id, sizeof(bootrom_id_t));
+
+	/* ignore the result for now */
+	return TRUE;
+}
+#endif /* USB_TRIGGER_DEBUG */
+
+
+#if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX)
+
+/** New optimized code for USB AP. EHCI fastpath specific function. */
+void inline optimize_ehci_qtd_init(struct ehci_qtd *qtd, dma_addr_t dma)
+{
+	memset(qtd, 0, sizeof(*qtd));
+	wmb();
+	qtd->qtd_self = dma;
+	qtd->qtd_status = cpu_to_le32(EHCI_QTD_HALTED);
+	qtd->qtd_next = EHCI_NULL;
+	qtd->qtd_altnext = EHCI_NULL;
+	qtd->obj_next = NULL;
+	qtd->rpc = NULL;
+	/* qtd->buff = NULL; */
+	qtd->xacterrs = EHCI_QTD_XACTERR_MAX;
+	wmb();
+}
+
+/** EHCI fastpath specific function */
+struct ehci_qtd *optimize_ehci_qtd_alloc(gfp_t flags)
+{
+	struct ehci_qtd		*qtd;
+	dma_addr_t		dma;
+
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+
+	struct dma_pool *pool = usbos_info->qtd_pool;
+
+	qtd = dma_pool_alloc(pool, flags, &dma);
+	if (qtd != NULL) {
+		optimize_ehci_qtd_init(qtd, dma);
+	}
+
+	return qtd;
+}
+
+/** EHCI fastpath specific function */
+void optimize_ehci_qtd_free(struct ehci_qtd *qtd)
+{
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+	struct dma_pool *pool = usbos_info->qtd_pool;
+	dma_pool_free(pool, qtd, qtd->qtd_self);
+}
+
+/**
+ * EHCI fastpath specific function. Loosely follows qtd_copy_status
+ * Greatly simplified as there are only three options: normal, short read, and disaster
+ */
+static int BCMFASTPATH get_qtd_status(struct ehci_qtd *qtd, int token, int *actual_length)
+{
+	int	status = -EINPROGRESS;
+
+	*actual_length += qtd->length - EHCI_QTD_GET_BYTES(token);
+
+	/* Short read is not an error */
+	if (unlikely (SHORT_READ_Q (token)))
+		status = -EREMOTEIO;
+
+	/* Check for serious problems */
+	if (token & EHCI_QTD_HALTED) {
+		status = -EPROTO;
+		if (token & (EHCI_QTD_BABBLE | EHCI_QTD_MISSEDMICRO | EHCI_QTD_BUFERR |
+			EHCI_QTD_XACTERR))
+			printk("EHCI Fastpath: Serious USB issue qtd %p token %08x --> status %d\n",
+				qtd, token, status);
+	}
+
+	return status;
+}
+
+static void dump_qtd(struct ehci_qtd *qtd)
+{
+	printk("qtd_next %08x qtd_altnext %08x qtd_status %08x\n", qtd->qtd_next,
+		qtd->qtd_altnext, qtd->qtd_status);
+}
+
+static void dump_qh(struct ehci_qh *qh)
+{
+	struct ehci_qtd *qtd = (struct ehci_qtd *)(qh->qh_curqtd | 0xa0000000);
+	printk("EHCI Fastpath: QH %p Dump\n", qh);
+	printk("qtd_next %08x info1 %08x info2 %08x current %08x\n", qh->qh_link, qh->qh_endp,
+		qh->qh_endphub, qh->qh_curqtd);
+	printk("overlay\n");
+	dump_qtd((struct ehci_qtd *)&qh->ow_next);
+	while ((((int)qtd)&EHCI_NULL) == 0)
+	{
+		printk("QTD %p\n", qtd);
+		dump_qtd((struct ehci_qtd *)qtd);
+		qtd = (struct ehci_qtd *)(qtd->qtd_next | 0xa0000000);
+	}
+}
+
+
+/**
+ * EHCI fastpath specific function.
+ * This code assumes the caller holding a lock
+ * It is currently called from scan_async that should have the lock
+ * Lock shall be dropped around the actual completion, then reacquired
+ * This is a clean implementation of the qh_completions()
+ */
+static void BCMFASTPATH ehci_bypass_callback(int pipeindex, struct ehci_qh *qh, spinlock_t *lock)
+{
+							/* Loop variables */
+	struct ehci_qtd		*qtd, 			/* current QTD */
+				*end = qh->dummy, 	/* "afterend" */
+				*next;
+	int			stopped;
+
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+
+	/* printk("EHCI Fastpath: callback pipe %d QH %p lock %p\n", pipeindex, qh, lock); */
+
+	/*
+	 * This code should not require any interlocking with QTD additions
+	 * The additions never touch QH, we should never touch 'end'
+	 * Note that QTD additions will keep 'end' in place
+	 */
+	for (qtd = qh->first_qtd; qtd != end; qtd = next)
+	{
+		u32		status;		/* Status bits from QTD */
+
+		/* Get the status bits from the QTD */
+		rmb();
+		status = hc32_to_cpu(qtd->qtd_status);
+
+		if ((status & EHCI_QTD_ACTIVE) == 0) {
+			if (unlikely((status & EHCI_QTD_HALTED) != 0)) {
+				/* Retry transaction errors until we
+				 * reach the software xacterr limit
+				 */
+				if ((status & EHCI_QTD_XACTERR) &&
+					EHCI_QTD_GET_CERR(status) == 0 &&
+					--qtd->xacterrs > 0) {
+					/* Reset the token in the qtd and the
+					 * qh overlay (which still contains
+					 * the qtd) so that we pick up from
+					 * where we left off
+					 */
+					printk("EHCI Fastpath: detected XactErr "
+						"qtd %p len %d/%d retry %d\n",
+						qtd, qtd->length - EHCI_QTD_GET_BYTES(status),
+						qtd->length,
+						EHCI_QTD_XACTERR_MAX - qtd->xacterrs);
+
+					status &= ~EHCI_QTD_HALTED;
+					status |= EHCI_QTD_ACTIVE | EHCI_QTD_SET_CERR(3);
+					qtd->qtd_status = cpu_to_le32(status);
+					wmb();
+					qh->ow_status = cpu_to_le32(status);
+
+					break;
+				}
+
+				/* QTD processing was aborted - highly unlikely (never seen, so not
+				 * tested). In very new 2.6, we can retry. In 2.4 and older 2.6,
+				 * life sucks (the USB stack does the same)
+				 */
+				printk("EHCI Fastpath: QTD halted\n");
+				dump_qh(qh);
+				stopped = 1;
+			}
+		} else {
+			/* Inactive QTD is an afterend, finished the list */
+			break;
+		}
+
+		/* Remove the QTD from software QH. This should be done before dropping the lock
+		 * in for upper layer
+		 */
+		next = qtd->obj_next;
+		qh->first_qtd = next;
+
+		/* Upper layer processing. */
+		if (EHCI_QTD_GET_PID(status) == 0)  /* OUT (host->dongle) pipe */
+		{
+			if (qtd->rpc == NULL)
+			{
+				usbos_info->waitdone = TRUE;
+				wake_up_interruptible(&usbos_info->wait);
+				usbos_info->sync_urb_status = 0;
+			} else {
+
+
+
+				/* usb_info_t *usb_info = (usb_info_t *) handle; */
+				usb_info_t *usb_info = (usb_info_t *) usbos_info->cbarg;
+				/* if(usb_info && usb_info->cbs && usb_info->cbs->send_irb_complete)
+				 * usb_info->cbs->send_irb_complete(usb_info->cbarg, txirb, status);
+				 */
+
+				dbus_info_t *dbus_info = (dbus_info_t *)usb_info->cbarg;
+
+				/* Free the coalesce buffer, if multi-buffer packet only. Do not
+				 * rely on buff, as it might not even exist
+				 */
+				if (PKTNEXT(usbos_info->pub->osh, qtd->rpc)) {
+					/* printk("k-Freeing %p\n", qtd->buff); */
+					kfree(qtd->buff);
+				}
+
+				if (dbus_info->cbs && dbus_info->cbs->send_complete)
+				{
+					atomic_dec(&s_tx_pending);
+					spin_unlock(lock);
+					/* printk("Sending to RPC qtd %p\n", qtd); */
+#if !(defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_TXNOCOPY) || defined(BCM_RPC_TOC))
+	#error Configuration not supported; read dbus_if_send_irb_complete for guidelines
+#endif
+					dbus_info->cbs->send_complete(dbus_info->cbarg, qtd->rpc,
+						0);
+					if ((atomic_read(&s_tx_pending) < 16) &&
+						dbus_info->txoff && !dbus_info->txoverride) {
+						dbus_flowctrl_tx(dbus_info, OFF);
+					}
+					spin_lock(lock);
+
+					/* Things could have happened while the lock was gone,
+					 * resync to the hardware
+					 */
+					next = qh->first_qtd;
+					end = qh->dummy;
+				}
+			}
+
+			optimize_ehci_qtd_free(qtd);
+		} else {   /* IN (dongle->host) pipe */
+			/* Simulates the upstream travel */
+			usb_info_t *usb_info = (usb_info_t *) usbos_info->cbarg;
+			dbus_info_t *dbus_info = (dbus_info_t *)usb_info->cbarg;
+			/* unsigned long       flags; */
+			int actual_length = 0;
+
+			/* All our reads must be short */
+			if (!SHORT_READ_Q (status)) ASSERT(0);
+
+			/* Done with hardware, convert status to error codes */
+			status = get_qtd_status(qtd, status, &actual_length);
+
+			switch (status) {
+			/* success */
+			case 0:
+			case -EINPROGRESS:
+			case -EREMOTEIO:
+				status = 0;
+				break;
+
+			case -ECONNRESET:		/* canceled */
+			case -ENOENT:
+			case -EPROTO:
+				DBUSERR(("%s: ehci unlink. status %x\n", __FUNCTION__, status));
+				break;
+			}
+
+			if (g_probe_info.dereged) {
+				printk("%s: DBUS deregistering, ignoring recv callback\n",
+					__FUNCTION__);
+				return;
+			}
+
+			dma_unmap_single(
+				usbos_info->usb->bus->controller,
+				(dma_addr_t)qtd->qtd_buffer_hi[0],
+				actual_length,
+				DMA_FROM_DEVICE);
+
+
+			if (dbus_info->pub.busstate != DBUS_STATE_DOWN) {
+				if (status == 0) {
+					void *buf = qtd->rpc;
+
+					ASSERT(buf != NULL);
+					spin_unlock(lock);
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+					/* Note that these ifdefs are indirectly coming from
+					 * dbus_usbos_recv_urb_submit The code itself is from
+					 * dbus_if_recv_irb_complete that makes the decision
+					 * at runtime, yet it is only pkt or buf depending on
+					 * the NOCOPY setup, never both :-)
+					 */
+					if (dbus_info->cbs && dbus_info->cbs->recv_pkt)
+						dbus_info->cbs->recv_pkt(dbus_info->cbarg, buf);
+#else
+					if (actual_length > 0) {
+						if (dbus_info->cbs && dbus_info->cbs->recv_buf)
+							dbus_info->cbs->recv_buf(dbus_info->cbarg,
+							buf, actual_length);
+					}
+#endif
+					spin_lock(lock);
+
+					/* Things could have happened while the lock was gone,
+					 * resync to the hardware
+					 */
+					next = qh->first_qtd;
+					end = qh->dummy;
+
+					/* Reinitialize this qtd since it will be reused. */
+					optimize_ehci_qtd_init(qtd, qtd->qtd_self);
+
+#if defined(BCM_RPC_NOCOPY) || defined(BCM_RPC_RXNOCOPY)
+					/* Note that these ifdefs are coming from
+					 * dbus_usbos_recv_urb_submit. In the NOCOPY configuration,
+					 * force an allocation of a new packet
+					 */
+					optimize_submit_rx_request(&dbus_info->pub, 1, qtd, NULL);
+
+#else
+					/* In the copy mode, simply reuse the buffer; upper level
+					 * had already consumed the data
+					 */
+					optimize_submit_rx_request(&dbus_info->pub, 1, qtd, buf);
+#endif
+					/* Not to free this qtd because it will be reused. */
+					continue;
+				}
+			} else {
+				printk("%s: DBUS down, ignoring recv callback\n", __FUNCTION__);
+			}
+			optimize_ehci_qtd_free(qtd);
+		}
+	}
+} /* ehci_bypass_callback */
+
+/** EHCI fastpath specific function */
+static void optimize_urb_callback(struct urb *urb)
+{
+	struct usb_ctrlrequest *req = urb->context;
+
+	kfree(req);
+	USB_FREE_URB(urb);
+}
+
+/**
+ * EHCI fastpath specific function. Shall be called under an external lock (currently RPC_TP_LOCK)
+ */
+static int optimize_submit_urb(struct usb_device *usb, void *ptr, int request)
+{
+	struct usb_ctrlrequest *req;
+	struct urb *urb;
+
+	if ((urb = USB_ALLOC_URB()) == NULL) {
+		printk("EHCI Fastpath: Error allocating URB in optimize_EP!");
+		return -ENOMEM;
+	}
+
+	if ((req = kmalloc(sizeof(struct usb_ctrlrequest), GFP_ATOMIC)) == NULL) {
+		printk("EHCI Fastpath: Failed to allocate memory for control request in"
+			" optimize_EP!");
+		USB_FREE_URB(urb);
+		return -ENOMEM;
+	}
+
+	req->bRequestType = (USB_TYPE_VENDOR | USB_RECIP_OTHER);
+	req->bRequest = request;
+
+	/* Use this instead of a buffer */
+	req->wValue = ((int)ptr & 0xffff);
+	req->wIndex = ((((int)ptr)>>16) & 0xffff);
+	req->wLength = 0;
+
+	printk("EHCI Fastpath: usb_dev %p\n", usb);
+	printk("EHCI Fastpath: bus %p\n", usb->bus);
+	printk("EHCI Fastpath: Hub %p\n", usb->bus->root_hub);
+
+	usb_fill_control_urb(
+		urb,
+		usb->bus->root_hub,
+		usb_sndctrlpipe(usb->bus->root_hub, 0),
+		(void *)req,
+		NULL,
+		0,
+		optimize_urb_callback,
+		req);
+
+	USB_SUBMIT_URB(urb);
+
+	if (urb->status != 0) {
+		printk("EHCI Fastpath: Cannot submit URB in optimize_EP: %d\n", urb->status);
+	}
+
+	return urb->status;
+} /* optimize_submit_urb */
+
+/** EHCI fastpath specific function */
+static int epnum(int pipe)
+{
+	int epn = usb_pipeendpoint(pipe);
+	if (usb_pipein (pipe))
+		epn |= 0x10;
+	return epn;
+}
+
+/** EHCI fastpath specific function */
+static int optimize_init(usbos_info_t *usbos_info, struct usb_device *usb, int out, int in, int in2)
+{
+	int retval = -EPIPE;
+
+	atomic_set(&s_tx_pending, 0);
+	/* atomic_set(&s_rx_pending, 0); */
+
+	usbos_info->tx_ep = epnum(out);
+	usbos_info->rx_ep = epnum(in);
+	usbos_info->rx2_ep = epnum(in2);
+	usbos_info->usb_device = usb;
+
+	/* printk("EHCI Fastpath: Create pool %p %p %p\n", usb, usb->bus, usb->bus->controller); */
+
+	/* QTDs for bulk transfers - separate pool */
+	usbos_info->qtd_pool = dma_pool_create("usbnet_qtd",
+		usb->bus->controller,
+		sizeof(struct ehci_qtd),
+		EHCI_QTD_ALIGN /* byte alignment (for hw parts) */,
+		4096 /* can't cross 4K */);
+	if (!usbos_info->qtd_pool) {
+		printk("EHCI Fastpath: Cannot create the QTD pool\n");
+		goto fail;
+	}
+
+	/* detaching the EP */
+	if (optimize_submit_urb(usb, usb, EHCI_SET_BYPASS_DEV) != 0)
+		goto fail;
+	optimize_submit_urb(usb, ehci_bypass_callback, EHCI_SET_BYPASS_CB);
+	optimize_submit_urb(usb, usbos_info->qtd_pool, EHCI_SET_BYPASS_POOL);
+#ifdef EHCI_FASTPATH_TX
+	optimize_submit_urb(usb, (void*)((0<<16)|usbos_info->tx_ep), EHCI_FASTPATH);
+#endif
+#ifdef EHCI_FASTPATH_RX
+	optimize_submit_urb(usb, (void*)((1<<16)|usbos_info->rx_ep),   EHCI_FASTPATH);
+#endif
+
+	/* getting the QH */
+	printk("EHCI Fastpath: EP in %d EP in2 %d EP out %d\n", usbos_info->rx_ep,
+		usbos_info->rx2_ep, usbos_info->tx_ep);
+
+	return 0;
+
+fail:
+	return retval;
+} /* optimize_submit_urb */
+
+/** EHCI fastpath specific function */
+static int optimize_deinit_qtds(struct ehci_qh *qh, int coalesce_buf)
+{
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+	struct ehci_qtd *qtd, *end, *next;
+	unsigned long	flags;
+
+	if (qh == NULL)
+		return 0;
+
+	end = qh->dummy;
+
+	printk("%s %d. qh = %p\n", __func__, __LINE__, qh);
+
+	spin_lock_irqsave(&usbos_info->fastpath_lock, flags);
+	for (qtd = qh->first_qtd; qtd != end; qtd = next) {
+		next = qtd->obj_next;
+		qh->first_qtd = next;
+
+		/* Free the coalesce buffer, if multi-buffer packet only. Do not
+		 * rely on buff, as it might not even exist
+		 */
+		if (coalesce_buf && PKTNEXT(usbos_info->pub->osh, qtd->rpc)) {
+			printk("k-Freeing %p, ", qtd->buff);
+			kfree(qtd->buff);
+		}
+		printk("freeing qtd %p\n", qtd);
+
+		optimize_ehci_qtd_free(qtd);
+	}
+	spin_unlock_irqrestore(&usbos_info->fastpath_lock, flags);
+
+	return 0;
+}
+
+static BCMFASTPATH struct ehci_qh *get_ep(usbos_info_t *usbos_info, int ep)
+{
+#ifdef KERNEL26
+	struct usb_host_endpoint *epp = NULL;
+	switch (ep)
+	{
+	case 0: epp = usbos_info->usb_device->ep_out[usbos_info->tx_ep&0xf]; break;
+	case 1: epp = usbos_info->usb_device->ep_in[usbos_info->rx_ep&0xf]; break;
+	case 2: epp = usbos_info->usb_device->ep_in[usbos_info->rx2_ep&0xf]; break;
+	default: ASSERT(0);
+	}
+	if (epp != NULL)
+		return (struct ehci_qh *)epp->hcpriv;
+	else return NULL;
+#else
+	switch (ep)
+	{
+	case 0: return (struct ehci_qh *)(((struct hcd_dev*)(usbos_info->
+		usb_device->hcpriv))->ep[usbos_info->tx_ep]);
+	case 1: return (struct ehci_qh *)(((struct hcd_dev*)(usbos_info->
+		usb_device->hcpriv))->ep[usbos_info->rx_ep]);
+	case 2: return (struct ehci_qh *)(((struct hcd_dev*)(usbos_info->
+		usb_device->hcpriv))->ep[usbos_info->rx2_ep]);
+	default: ASSERT(0);
+	}
+	return NULL;
+#endif /* KERNEL26 */
+}
+
+/** EHCI fastpath specific function */
+int optimize_deinit(usbos_info_t *usbos_info, struct usb_device *usb)
+{
+	optimize_deinit_qtds(get_ep(usbos_info, 0), 1);
+	optimize_deinit_qtds(get_ep(usbos_info, 1), 0);
+#if defined(EHCI_FASTPATH_TX) || defined(EHCI_FASTPATH_RX)
+	optimize_submit_urb(usb, (void *)0, EHCI_CLR_EP_BYPASS);
+#endif
+	dma_pool_destroy(usbos_info->qtd_pool);
+	return 0;
+}
+
+/** EHCI fastpath specific function. Reassemble the segmented packet */
+static int BCMFASTPATH optimize_gather(const dbus_pub_t *pub, void *pkt, void **buf)
+{
+	int len = 0;
+
+	void *transfer_buf = kmalloc(pkttotlen(pub->osh, pkt),
+		GFP_ATOMIC);
+	*buf = transfer_buf;
+
+	if (!transfer_buf) {
+		printk("fail to alloc to usb buffer\n");
+		return 0;
+	}
+
+	while (pkt) {
+		int pktlen = PKTLEN(pub->osh, pkt);
+		bcopy(PKTDATA(pub->osh, pkt), transfer_buf, pktlen);
+		transfer_buf += pktlen;
+		len += pktlen;
+		pkt = PKTNEXT(pub->osh, pkt);
+	}
+
+	/* printk("Coalesced a %d-byte buffer\n", len); */
+
+	return len;
+}
+
+/** EHCI fastpath specific function */
+int BCMFASTPATH optimize_qtd_fill_with_rpc(const dbus_pub_t *pub, int epn,
+	struct ehci_qtd *qtd, void *rpc, int token, int len)
+{
+	void *data = NULL;
+
+	if (len == 0)
+		return optimize_qtd_fill_with_data(pub, epn, qtd, data, token, len);
+
+	ASSERT(rpc != NULL);
+	data = PKTDATA(pub->osh, rpc);
+	qtd->rpc = rpc;
+
+	if (PKTNEXT(pub->osh, rpc)) {
+		len = optimize_gather(pub, rpc, &data);
+		qtd->buff = data;
+	}
+
+	return optimize_qtd_fill_with_data(pub, epn, qtd, data, token, len);
+}
+
+/** EHCI fastpath specific function. Fill the QTD from the data buffer */
+int BCMFASTPATH optimize_qtd_fill_with_data(const dbus_pub_t *pub, int epn,
+	struct ehci_qtd *qtd, void *data, int token, int len)
+{
+	int		i, bytes_fit, page_offset;
+	dma_addr_t	addr = 0;
+
+	/* struct usb_host_endpoint *ep = get_ep(epn); */
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+
+	token |= (EHCI_QTD_ACTIVE | EHCI_QTD_IOC); /* Allow execution, force interrupt */
+
+	if (len > 0) {
+		addr = dma_map_single(
+			usbos_info->usb->bus->controller,
+			data,
+			len,
+			EHCI_QTD_GET_PID(token) ? DMA_FROM_DEVICE : DMA_TO_DEVICE);
+	}
+
+	qtd->qtd_buffer[0] = cpu_to_hc32((u32)addr);
+	/* Here qtd->qtd_buffer_hi[0] is leveraged to store addr value, which
+	 * is needed when invoking dma_unmap_single() in ehci_bypass_callback().
+	 * This is valid for EHCI 32bit only.
+	 */
+	qtd->qtd_buffer_hi[0] = cpu_to_hc32((u32)addr);
+	page_offset = (addr & (EHCI_PAGE_SIZE-1));
+	bytes_fit = EHCI_PAGE_SIZE - page_offset;
+	addr -= page_offset;
+	if (len < bytes_fit)
+		bytes_fit = len;
+	else {
+		addr +=  EHCI_PAGE_SIZE;
+
+		for (i = 1; bytes_fit < len && i < EHCI_QTD_NBUFFERS; i++) {
+			qtd->qtd_buffer[i] = cpu_to_hc32((u32)addr);
+			qtd->qtd_buffer_hi[i] = 0;
+			addr += EHCI_PAGE_SIZE;
+			if ((bytes_fit + EHCI_PAGE_SIZE) < len)
+				bytes_fit += EHCI_PAGE_SIZE;
+			else
+				bytes_fit = len;
+		}
+
+		if (bytes_fit != len)
+		{
+			ASSERT(0);
+		}
+	}
+	qtd->qtd_status = cpu_to_hc32((bytes_fit << 16) | token);
+	qtd->length = bytes_fit;
+
+	return bytes_fit;
+} /* optimize_qtd_fill_with_data */
+
+
+/**
+ * EHCI fastpath specific function. Reimplementation of qh_append_tds(). Returns nonzero if too many
+ * requests pending.
+ */
+int BCMFASTPATH optimize_submit_async(struct ehci_qtd *qtd, int epn)
+{
+	/* Clean implementation along the lines of qh_append_tds() */
+
+	struct ehci_qtd		*afterend; /* Element at the end of the QTD chain (after the
+					    * last useful one, "after-end")
+					    */
+	dma_addr_t		hw_addr;
+	__hc32			status;
+	unsigned long	flags;
+
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+	struct ehci_qh *qh = get_ep(usbos_info, epn);
+	usb_info_t *usb_info = (usb_info_t *) usbos_info->cbarg;
+	dbus_info_t *dbus_info = (dbus_info_t *)usb_info->cbarg;
+
+	/* printk("Submit qtd %p to pipe %d (%p)\n", qtd, epn, qh); */
+	if (qh == NULL)
+	{
+		printk("EHCI Fastpath: Attempt of optimized submit to a non-optimized pipe\n");
+		return -1;
+	}
+
+	spin_lock_irqsave(&usbos_info->fastpath_lock, flags);
+
+	/* Limit outstanding - for rpc behavior only */
+	/* printk("QH qtd_status %08x\n", qh->hw->qtd_status); */
+
+	if ((qtd->qtd_status & (1<<8)) == 0)
+	{
+		atomic_inc(&s_tx_pending);
+		if (atomic_read(&s_tx_pending) > 16*2) /* (dbus_info->tx_low_watermark * 3)) */
+			dbus_flowctrl_tx(dbus_info, TRUE);
+	}
+
+	ASSERT(qh != NULL);
+
+
+	/*
+	 * Standard list processing trick:
+	 *   * old "afterend" is filled with the incoming data while still HALTed
+	 *   * new element is appended and prepared to serve as new afterend
+	 *   * now old afterend is activated
+	 * This way, HW never races the SW - no semaphores are necessary, as long as this function
+	 * is not reentered for the same QH
+	 */
+
+	/* Make new QTD to be HALTed, wait for it to actually happen */
+	status = qtd->qtd_status;
+	qtd->qtd_status = cpu_to_le32(EHCI_QTD_HALTED);
+	wmb();
+
+	/* Now copy all information from the new QTD to the old afterend,
+	 * except the own HW address
+	 */
+	afterend = qh->dummy;
+	hw_addr = afterend->qtd_self;
+	*afterend = *qtd;
+	afterend->qtd_self = hw_addr;
+
+	/* The new QTD is ready to serve as a new afterend, append it */
+	qh->dummy = qtd;
+	afterend->qtd_next = qtd->qtd_self;
+	afterend->qtd_altnext = qtd->qtd_self;  /* Always assume short read. Harmless in our case */
+	afterend->obj_next = qtd;
+
+	/* Wait for writes to happen and enable the old afterend (now containing the QTD data) */
+	wmb();
+	afterend->qtd_status = status;
+	wmb();
+
+	spin_unlock_irqrestore(&usbos_info->fastpath_lock, flags);
+
+	return 0;
+} /* optimize_submit_async */
+
+void BCMFASTPATH optimize_submit_rx_request(const dbus_pub_t *pub, int epn, struct ehci_qtd *qtd_in,
+                                            void *buf)
+{
+	usbos_info_t *usbos_info = g_probe_info.usbos_info;
+	int len = usbos_info->rxbuf_len;
+	void *pkt;
+	struct ehci_qtd *qtd;
+	int token = EHCI_QTD_SET_CERR(3) | EHCI_QTD_SET_PID(1);
+
+	if (qtd_in == NULL) {
+		qtd = optimize_ehci_qtd_alloc(GFP_KERNEL);
+		if (!qtd) {
+			printk("EHCI Fastpath: Out of QTDs\n");
+			return;
+		}
+	} else {
+		qtd = qtd_in;
+	}
+
+	if (buf == NULL)
+	{
+		/* NOCOPY, allocate own packet */
+		/* Follow dbus_usbos_recv_urb_submit */
+		pkt = PKTGET(usbos_info->pub->osh, len, FALSE);
+		if (pkt == NULL) {
+			printk("%s: PKTGET failed\n", __FUNCTION__);
+			optimize_ehci_qtd_free(qtd);
+			return;
+		}
+		/* consider the packet "native" so we don't count it as MALLOCED in the osl */
+		PKTTONATIVE(usbos_info->pub->osh, pkt);
+		qtd->rpc = pkt;
+		buf = PKTDATA(usbos_info->pub->osh, pkt);
+
+	} else {
+		qtd->rpc = buf;
+	}
+
+	optimize_qtd_fill_with_data(pub, epn, qtd, buf, token, len);
+	optimize_submit_async(qtd, epn);
+} /* optimize_submit_rx_request */
+
+#endif /* EHCI_FASTPATH_TX || EHCI_FASTPATH_RX */
+
+#ifdef BCM_REQUEST_FW
+
+struct request_fw_context {
+	const struct firmware *firmware;
+	struct semaphore lock;
+};
+
+/*
+ * Callback for dbus_request_firmware().
+ */
+static void
+dbus_request_firmware_done(const struct firmware *firmware, void *ctx)
+{
+	struct request_fw_context *context = (struct request_fw_context*)ctx;
+
+	/* Store the received firmware handle in the context and wake requester */
+	context->firmware = firmware;
+	up(&context->lock);
+}
+
+/*
+ * Send a firmware request and wait for completion.
+ *
+ * The use of the asynchronous version of request_firmware() is needed to avoid
+ * kernel oopses when we just come out of system hibernate.
+ */
+static int
+dbus_request_firmware(const char *name, const struct firmware **firmware)
+{
+	struct request_fw_context *context;
+	int ret;
+
+	context = kzalloc(sizeof(*context), GFP_KERNEL);
+	if (!context)
+		return -ENOMEM;
+
+	sema_init(&context->lock, 0);
+
+	ret = request_firmware_nowait(THIS_MODULE, true, name, &g_probe_info.usb->dev,
+	                              GFP_KERNEL, context, dbus_request_firmware_done);
+	if (ret) {
+		kfree(context);
+		return ret;
+	}
+
+	/* Wait for completion */
+	if (down_interruptible(&context->lock) != 0) {
+		kfree(context);
+		return -ERESTARTSYS;
+	}
+
+	*firmware = context->firmware;
+	kfree(context);
+
+	return *firmware != NULL ? 0 : -ENOENT;
+}
+
+static void *
+dbus_get_fwfile(int devid, int chiprev, uint8 **fw, int *fwlen, uint16 boardtype, uint16 boardrev)
+{
+	const struct firmware *firmware = NULL;
+	s8 file_name[64];
+	int ret;
+
+	snprintf(file_name, sizeof(file_name), "%s", CONFIG_ANDROID_BCMDHD_FW_PATH);
+
+	ret = dbus_request_firmware(file_name, &firmware);
+	if (ret) {
+		DBUSERR(("fail to request firmware %s\n", file_name));
+		return NULL;
+	}
+
+	*fwlen = firmware->size;
+	*fw = (uint8 *)firmware->data;
+	return (void *)firmware;
+
+}
+
+static void *
+dbus_get_nvfile(int devid, int chiprev, uint8 **fw, int *fwlen, uint16 boardtype, uint16 boardrev)
+{
+	const struct firmware *firmware = NULL;
+	s8 file_name[64];
+	int ret;
+
+	snprintf(file_name, sizeof(file_name), "%s", CONFIG_ANDROID_BCMDHD_NVRAM_PATH);
+
+	ret = dbus_request_firmware(file_name, &firmware);
+	if (ret) {
+		DBUSERR(("fail to request nvram %s\n", file_name));
+
+
+		if (ret) {
+			DBUSERR(("fail to request nvram %s\n", file_name));
+			return NULL;
+		}
+	}
+
+	*fwlen = firmware->size;
+	*fw = (uint8 *)firmware->data;
+	return (void *)firmware;
+}
+
+void *
+dbus_get_fw_nvfile(int devid, int chiprev, uint8 **fw, int *fwlen, int type, uint16 boardtype,
+	uint16 boardrev)
+{
+	switch (type) {
+		case DBUS_FIRMWARE:
+			return dbus_get_fwfile(devid, chiprev, fw, fwlen, boardtype, boardrev);
+		case DBUS_NVFILE:
+			return dbus_get_nvfile(devid, chiprev, fw, fwlen, boardtype, boardrev);
+		default:
+			return NULL;
+	}
+}
+
+void
+dbus_release_fw_nvfile(void *firmware)
+{
+	release_firmware((struct firmware *)firmware);
+}
+#endif /* BCM_REQUEST_FW */
+
+#ifdef BCMUSBDEV_COMPOSITE
+/**
+ * For a composite device the interface order is not guaranteed, scan the device struct for the WLAN
+ * interface.
+ */
+static int
+dbus_usbos_intf_wlan(struct usb_device *usb)
+{
+	int i, num_of_eps, ep, intf_wlan = -1;
+	int num_intf = CONFIGDESC(usb)->bNumInterfaces;
+	struct usb_endpoint_descriptor *endpoint;
+
+	for (i = 0; i < num_intf; i++) {
+		if (IFDESC(usb, i).bInterfaceClass != USB_CLASS_VENDOR_SPEC)
+			continue;
+		num_of_eps = IFDESC(usb, i).bNumEndpoints;
+
+		for (ep = 0; ep < num_of_eps; ep++) {
+			endpoint = &IFEPDESC(usb, i, ep);
+			if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) ==
+				USB_ENDPOINT_XFER_BULK) {
+				intf_wlan = i;
+				break;
+			}
+		}
+		if (ep < num_of_eps)
+			break;
+	}
+
+	return intf_wlan;
+}
+#endif /* BCMUSBDEV_COMPOSITE */
+
+#ifdef KEEPIF_ON_DEVICE_RESET
+/* if keepif_on_devreset is set, and reset_resume or disconnect got called, we need de-register or
+ * register the usb driver to OS again; but this operation can't be called inside the reset_resume
+ * or disconnect callback, so introduce a kernel thread to do these work
+ */
+static int
+dbus_usbos_usbreset_func(void *data)
+{
+	enum usb_dev_status flag = USB_DEVICE_INIT;
+	usbos_info_t *usbos_info;
+
+	while (1) {
+		wait_event_interruptible_timeout(g_probe_info.usbreset_queue_head,
+			atomic_read(&g_probe_info.usbdev_stat), 100); /* 100 ms */
+
+		if (kthread_should_stop())
+			break;
+		if (!(usbos_info = g_probe_info.usbos_info))
+			continue;
+		if (!(flag = atomic_read(&g_probe_info.usbdev_stat)))
+			continue;
+
+		usbos_info = g_probe_info.usbos_info;
+		flag = atomic_read(&g_probe_info.usbdev_stat);
+		atomic_set(&g_probe_info.usbdev_stat, USB_DEVICE_INIT);
+
+		if ((flag == USB_DEVICE_RESETTED) || (flag == USB_DEVICE_DISCONNECTED)) {
+			DBUSERR(("Device reset, re-register USB driver\n"));
+			g_probe_info.dev_resetted = TRUE;
+			g_probe_info.busstate_bf_devreset = usbos_info->pub->busstate;
+			dbus_usbos_state_change(usbos_info, DBUS_STATE_DOWN);
+
+			g_probe_info.dereged = TRUE;
+			USB_DEREGISTER();
+			USB_REGISTER();
+			g_probe_info.dereged = FALSE;
+		} else if (flag == USB_DEVICE_PROBED) {
+			DBUSERR(("Device probed, but no need to initialize higher layer\n"));
+			g_probe_info.dev_resetted = FALSE;
+			dbus_usbos_init_info();
+			/* The device may have lost power, so a firmware download may be required */
+			dbus_usbos_state_change(usbos_info,
+				DBUS_STATE_DL_NEEDED);
+			g_probe_info.suspend_state = USBOS_SUSPEND_STATE_DEVICE_ACTIVE;
+			dbus_usbos_state_change(usbos_info,
+				g_probe_info.busstate_bf_devreset);
+		}
+	}
+	return 0;
+}
+#endif /* KEEPIF_ON_DEVICE_RESET */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd.h
index 67d3134e5573..22dc2dbe7030 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd.h
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Header file describing the internal (inter-module) DHD interfaces.
  *
  * Provides type definitions and function prototypes used to link the
  * DHD OS, bus, and protocol modules.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -393,6 +394,9 @@ typedef struct dhd_pub {
 	 * please do NOT merge it back from other branches !!!
 	 */
 
+#ifdef BCMDBUS
+	struct dbus_pub *dbus;
+#endif
 
 	/* Internal dhd items */
 	bool up;		/* Driver up/down (to OS) */
@@ -1364,7 +1368,9 @@ extern char fw_path2[MOD_PARAM_PATHLEN];
 
 /* Flag to indicate if we should download firmware on driver load */
 extern uint dhd_download_fw_on_driverload;
+#ifndef BCMDBUS
 extern int allow_delay_fwdl;
+#endif /* !BCMDBUS */
 
 
 extern void dhd_wait_for_event(dhd_pub_t *dhd, bool *lockvar);
@@ -1470,6 +1476,10 @@ extern void dhd_os_general_spin_unlock(dhd_pub_t *pub, unsigned long flags);
 
 extern void dhd_dump_to_kernelog(dhd_pub_t *dhdp);
 
+#ifdef BCMDBUS
+extern void dhd_bus_dump(dhd_pub_t *dhdp, struct bcmstrbuf *strbuf);
+extern void dhd_bus_clearcounts(dhd_pub_t *dhdp);
+#endif /* BCMDBUS */
 
 #ifdef DHD_L2_FILTER
 extern int dhd_get_parp_status(dhd_pub_t *dhdp, uint32 idx);
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.c
index 1c2be05d93ae..9668b046090d 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BT-AMP support routines
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -38,7 +39,11 @@
 #include <proto/bt_amp_hci.h>
 #include <dngl_stats.h>
 #include <dhd.h>
+#ifdef BCMDBUS
+#include <dbus.h>
+#else
 #include <dhd_bus.h>
+#endif
 #include <dhd_proto.h>
 #include <dhdioctl.h>
 #include <dhd_dbg.h>
@@ -86,7 +91,11 @@ dhd_bta_flush_hcidata(dhd_pub_t *pub, uint16 llh)
 	struct pktq *q;
 	uint count = 0;
 
+#ifdef BCMDBUS
+	q = dhd_dbus_txq(pub->dbus);
+#else
 	q = dhd_bus_txq(pub->bus);
+#endif /* BCMDBUS */
 	if (q == NULL)
 		return;
 
@@ -102,6 +111,9 @@ dhd_bta_flush_hcidata(dhd_pub_t *pub, uint16 llh)
 			void *pkt = pktq_pdeq(q, prec);
 			int ifidx;
 
+#ifdef BCMDBUS
+			PKTPULL(pub->osh, pkt, dhd_dbus_hdrlen(pub->dbus));
+#endif /* BCMDBUS */
 			dhd_prot_hdrpull(pub, &ifidx, pkt, NULL, NULL);
 
 			if (PKTLEN(pub->osh, pkt) >= RFC1042_HDR_LEN) {
@@ -129,6 +141,9 @@ dhd_bta_flush_hcidata(dhd_pub_t *pub, uint16 llh)
 			}
 
 			dhd_prot_hdrpush(pub, ifidx, pkt);
+#ifdef BCMDBUS
+			PKTPUSH(pub->osh, pkt, dhd_dbus_hdrlen(pub->dbus));
+#endif /* BCMDBUS */
 
 			if (head_pkt == NULL)
 				head_pkt = pkt;
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.h
index dcb5e658c45c..243ecb2ddb13 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bta.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BT-AMP support routines
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bus.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bus.h
index 8eccbaea235c..1ba78c5d7ff1 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bus.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_bus.h
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Header file describing the internal (inter-module) DHD interfaces.
  *
  * Provides type definitions and function prototypes used to link the
  * DHD OS, bus, and protocol modules.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_buzzz.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_buzzz.h
index e349a3f451dd..5695028e4b31 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_buzzz.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_buzzz.h
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 #ifndef _DHD_BUZZZ_H_INCLUDED_
 #define _DHD_BUZZZ_H_INCLUDED_
 
 /*
  * Broadcom logging system - Empty implementaiton
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cdc.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cdc.c
index ad20e0776456..e60e82be0ee2 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cdc.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cdc.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD Protocol Module for CDC and BDC.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: dhd_cdc.c 581085 2015-08-21 09:04:22Z $
+ * $Id: dhd_cdc.c 708487 2018-10-31 05:33:14Z $
  *
  * BDC is like CDC, except it includes a header for data packets to convey
  * packet priority over the bus, and flags (e.g. to indicate checksum status
@@ -41,7 +42,11 @@
 #include <dngl_stats.h>
 #include <dhd.h>
 #include <dhd_proto.h>
+#ifdef BCMDBUS
+#include <dbus.h>
+#else
 #include <dhd_bus.h>
+#endif /* BCMDBUS */
 #include <dhd_dbg.h>
 
 
@@ -50,6 +55,10 @@
 #include <dhd_wlfc.h>
 #endif
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+#include <dhd_chip_info.h>
+#endif
+
 #ifdef DHD_ULP
 #include <dhd_ulp.h>
 #endif /* DHD_ULP */
@@ -68,15 +77,24 @@ typedef struct dhd_prot {
 	uint16 reqid;
 	uint8 pending;
 	uint32 lastcmd;
+#ifdef BCMDBUS
+	uint ctl_completed;
+#endif
 	uint8 bus_header[BUS_HEADER_LEN];
 	cdc_ioctl_t msg;
 	unsigned char buf[WLC_IOCTL_MAXLEN + ROUND_UP_MARGIN];
 } dhd_prot_t;
 
+#if defined(BCMDBUS)
+extern int dhd_dbus_txdata(dhd_pub_t *dhdp, void *pktbuf);
+#endif
 
 static int
 dhdcdc_msg(dhd_pub_t *dhd)
 {
+#ifdef BCMDBUS
+	int timeout = 0;
+#endif /* BCMDBUS */
 	int err = 0;
 	dhd_prot_t *prot = dhd->prot;
 	int len = ltoh32(prot->msg.len) + sizeof(cdc_ioctl_t);
@@ -93,8 +111,51 @@ dhdcdc_msg(dhd_pub_t *dhd)
 		len = CDC_MAX_MSG_SIZE;
 
 	/* Send request */
+#ifdef BCMDBUS
+	DHD_OS_IOCTL_RESP_LOCK(dhd);
+	prot->ctl_completed = FALSE;
+	err = dbus_send_ctl(dhd->dbus, (void *)&prot->msg, len);
+	if (err) {
+		DHD_ERROR(("dbus_send_ctl error=0x%x\n", err));
+		DHD_OS_IOCTL_RESP_UNLOCK(dhd);
+		DHD_OS_WAKE_UNLOCK(dhd);
+		return err;
+	}
+#else
 	err = dhd_bus_txctl(dhd->bus, (uchar*)&prot->msg, len);
+#endif
 
+#ifdef BCMDBUS
+	timeout = dhd_os_ioctl_resp_wait(dhd, &prot->ctl_completed);
+	if ((!timeout) || (!prot->ctl_completed)) {
+		DHD_ERROR(("Txctl timeout %d ctl_completed %d\n",
+			timeout, prot->ctl_completed));
+		DHD_ERROR(("Txctl wait timed out\n"));
+		err = -1;
+	}
+	DHD_OS_IOCTL_RESP_UNLOCK(dhd);
+#endif
+#if defined(BCMDBUS) && defined(INTR_EP_ENABLE)
+	/* If the ctl write is successfully completed, wait for an acknowledgement
+	* that indicates that it is now ok to do ctl read from the dongle
+	*/
+	if (err != -1) {
+		DHD_OS_IOCTL_RESP_LOCK(dhd);
+		prot->ctl_completed = FALSE;
+		if (dbus_poll_intr(dhd->dbus)) {
+			DHD_ERROR(("dbus_poll_intr not submitted\n"));
+		} else {
+			/* interrupt polling is sucessfully submitted. Wait for dongle to send
+			* interrupt
+			*/
+			timeout = dhd_os_ioctl_resp_wait(dhd, &prot->ctl_completed);
+			if (!timeout) {
+				DHD_ERROR(("intr poll wait timed out\n"));
+			}
+		}
+		DHD_OS_IOCTL_RESP_UNLOCK(dhd);
+	}
+#endif /* defined(BCMDBUS) && defined(INTR_EP_ENABLE) */
 	DHD_OS_WAKE_UNLOCK(dhd);
 	return err;
 }
@@ -102,6 +163,9 @@ dhdcdc_msg(dhd_pub_t *dhd)
 static int
 dhdcdc_cmplt(dhd_pub_t *dhd, uint32 id, uint32 len)
 {
+#ifdef BCMDBUS
+	int timeout = 0;
+#endif /* BCMDBUS */
 	int ret;
 	int cdc_len = len + sizeof(cdc_ioctl_t);
 	dhd_prot_t *prot = dhd->prot;
@@ -110,12 +174,38 @@ dhdcdc_cmplt(dhd_pub_t *dhd, uint32 id, uint32 len)
 
 
 	do {
+#ifdef BCMDBUS
+		DHD_OS_IOCTL_RESP_LOCK(dhd);
+		prot->ctl_completed = FALSE;
+		ret = dbus_recv_ctl(dhd->dbus, (uchar*)&prot->msg, cdc_len);
+		if (ret) {
+			DHD_ERROR(("dbus_recv_ctl error=0x%x(%d)\n", ret, ret));
+			DHD_OS_IOCTL_RESP_UNLOCK(dhd);
+			goto done;
+		}
+		timeout = dhd_os_ioctl_resp_wait(dhd, &prot->ctl_completed);
+		if ((!timeout) || (!prot->ctl_completed)) {
+			DHD_ERROR(("Rxctl timeout %d ctl_completed %d\n",
+				timeout, prot->ctl_completed));
+			ret = -1;
+			DHD_OS_IOCTL_RESP_UNLOCK(dhd);
+
+			goto done;
+		}
+		DHD_OS_IOCTL_RESP_UNLOCK(dhd);
+
+		ret = cdc_len;
+#else
 		ret = dhd_bus_rxctl(dhd->bus, (uchar*)&prot->msg, cdc_len);
+#endif /* BCMDBUS */
 		if (ret < 0)
 			break;
 	} while (CDC_IOC_ID(ltoh32(prot->msg.flags)) != id);
 
 
+#ifdef BCMDBUS
+done:
+#endif /* BCMDBUS */
 	return ret;
 }
 
@@ -285,6 +375,25 @@ done:
 	return ret;
 }
 
+#ifdef BCMDBUS
+int
+dhd_prot_ctl_complete(dhd_pub_t *dhd)
+{
+	dhd_prot_t *prot;
+
+	if (dhd == NULL)
+		return BCME_ERROR;
+
+	prot = dhd->prot;
+
+	ASSERT(prot);
+	DHD_OS_IOCTL_RESP_LOCK(dhd);
+	prot->ctl_completed = TRUE;
+	dhd_os_ioctl_resp_wake(dhd);
+	DHD_OS_IOCTL_RESP_UNLOCK(dhd);
+	return 0;
+}
+#endif /* BCMDBUS */
 
 int
 dhd_prot_ioctl(dhd_pub_t *dhd, int ifidx, wl_ioctl_t * ioc, void * buf, int len)
@@ -477,6 +586,12 @@ dhd_prot_hdrpull(dhd_pub_t *dhd, int *ifidx, void *pktbuf, uchar *reorder_buf_in
 		dhd_wlfc_parse_header_info(dhd, pktbuf, (data_offset << 2),
 			reorder_buf_info, reorder_info_len);
 
+#ifdef BCMDBUS
+#ifndef DHD_WLFC_THREAD
+		dhd_wlfc_commit_packets(dhd,
+			(f_commitpkt_t)dhd_dbus_txdata, (void *)dhd, NULL, FALSE);
+#endif /* DHD_WLFC_THREAD */
+#endif /* BCMDBUS */
 	}
 #endif /* PROP_TXSTATUS */
 
@@ -555,10 +670,27 @@ dhd_sync_with_dongle(dhd_pub_t *dhd)
 	if (ret < 0)
 		goto done;
 
+#if defined(BCMDBUS) && defined(BCMDHDUSB)
+	/* dbus_set_revinfo(dhd->dbus, revinfo.chipnum, revinfo.chiprev); */
+#endif /* BCMDBUS && BCMDHDUSB */
 
 	dhd_process_cid_mac(dhd, TRUE);
 
-	ret = dhd_preinit_ioctls(dhd);
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	if(alive == FW_ALIVE_MAGIC) {
+		char buf[WLC_IOCTL_SMLEN];
+
+		memset(buf, 0, sizeof(buf));
+		bcm_mkiovar("cur_etheraddr", 0, 0, buf, sizeof(buf));
+		if ((ret = dhd_wl_ioctl_cmd(dhd, WLC_GET_VAR, buf, sizeof(buf), FALSE, 0)) < 0) {
+		DHD_ERROR(("%s: can't get MAC address , error=%d\n", __FUNCTION__, ret));
+		}
+	/* Update public MAC address after reading from Firmware */
+		memcpy(dhd->mac.octet, buf, ETHER_ADDR_LEN);
+
+	} else
+#endif
+		ret = dhd_preinit_ioctls(dhd);
 
 	if (!ret)
 		dhd_process_cid_mac(dhd, FALSE);
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.c
index 9bcc2b9638a6..be1f4251b8ff 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 driver - Dongle Host Driver (DHD) related
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.h
index 260ff0cefc7d..9ef581b2124f 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg80211.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 driver - Dongle Host Driver (DHD) related
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg_vendor.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg_vendor.c
index 4ba3827d421a..7aefed424246 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg_vendor.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_cfg_vendor.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 vendor command/event handlers of DHD
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_chip_info.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_chip_info.c
new file mode 100644
index 000000000000..cbaa7c1ef07b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_chip_info.c
@@ -0,0 +1,38 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+#include "dhd_chip_info.h"
+
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+int alive = 0;
+int card_dev = 0;
+
+
+uint32	bcm43430_coreid[] = {
+0x00000800,0x00000812,0x00000829,0x0000082a,0x0000080e,0x00000240};
+uint32  bcm43430_coresba[] = {
+0x18000000,0x18001000,0x18002000,0x18003000,0x18004000,0x19000000};
+uint32  bcm43430_coresba_size[] = {
+0x00001000,0x00001000,0x00001000,0x00001000,0x00001000,0x01000000};
+uint32  bcm43430_wrapba[] = {
+0x18100000,0x18101000,0x18102000,0x18103000,0x18104000,0x18106000};
+uint32  bcm43430_cia[] = {
+0x4bf80001,0x4bf81201,0x4bf82901,0x4bf82a01,0x4bf80e01,0x43b24001};
+uint32  bcm43430_cib[] = {
+0x31004211,0x27004211,0x15004211,0x09004211,0x16080401,0x00080201};
+
+uint32  bcm43436_cib[] = {
+0x31004211,0x27004211,0x18004211,0x0b004211,0x19080401,0x00080201};
+
+
+int sii_pub_43430[] = {
+0x00000001,0x00000003,0x00000829,0x00000015,0x00000002,0x00000031,0x10400000,0x0000001e,
+0x00000018,0x39d25f18,0x00000000,0x00000000,0x00000000,0x00000000,0x00000000,0x0000a9a6,
+0x00000000,0x00000003,0x30c21b01,0x00000000,0x00000000,0x00000000,
+};
+
+int sii_pub_43436[] = {
+0x00000001,0x00000003,0x00000829,0x00000018,0x00000002,0x00000031,0x10400000,0x0000001e,
+0x00000018,0x39d25f18,0x00000000,0x00000000,0x00000000,0x00000000,0x00000000,0x0000a9a6,
+0x00000002,0x00000004,0x40c01b01,0x00000000,0x00000000,0x00000000,
+};
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_chip_info.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_chip_info.h
new file mode 100644
index 000000000000..1e0c822acfb5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_chip_info.h
@@ -0,0 +1,44 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+#ifndef __dhd_chip_info_h__
+#define __dhd_chip_info_h__
+
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+
+#include <typedefs.h>
+
+#define chip_info_dump 0
+
+#define ai_core_43341 7
+#define oob_router_43341 0x18108000
+
+#define ai_core_43430 6
+#define oob_router_43430 0x18107000
+#define FW_ALIVE_MAGIC 0x151515
+
+extern int alive;
+extern int card_dev;
+extern int card_rev;
+
+extern uint32	bcm43341_coreid[];
+extern uint32	bcm43341_coresba[];
+extern uint32	bcm43341_coresba_size[];
+extern uint32	bcm43341_coresba2_size[];
+extern uint32	bcm43341_wrapba[];
+extern uint32	bcm43341_cia[];
+extern uint32	bcm43341_cib[];
+
+extern uint32	bcm43430_coreid[];
+extern uint32	bcm43430_coresba[];
+extern uint32	bcm43430_coresba_size[];
+extern uint32	bcm43430_wrapba[];
+extern uint32	bcm43430_cia[];
+extern uint32	bcm43430_cib[];
+extern uint32	bcm43436_cib[];
+
+extern int	sii_pub_43341[];
+extern int	sii_pub_43430[];
+extern int	sii_pub_43436[];
+
+#endif	//LOAD_DHD_WITH_FW_ALIVE
+
+#endif	//__dhd_chip_info_h__
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_common.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_common.c
index abf812b19a67..c25ffa2cf83f 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_common.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_common.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD), common DHD core.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: dhd_common.c 674559 2017-10-27 03:07:31Z $
+ * $Id: dhd_common.c 692262 2018-07-04 09:30:26Z $
  */
 #include <typedefs.h>
 #include <osl.h>
@@ -47,7 +48,11 @@
 #include <dhd_flowring.h>
 #endif
 
+#ifdef BCMDBUS
+#include <dbus.h>
+#else
 #include <dhd_bus.h>
+#endif /* BCMDBUS */
 #include <dhd_proto.h>
 #include <dhd_dbg.h>
 #include <dhd_debug.h>
@@ -89,7 +94,7 @@
 extern void htsf_update(struct dhd_info *dhd, void *data);
 #endif
 
-int dhd_msg_level = DHD_ERROR_VAL | DHD_MSGTRACE_VAL | DHD_FWLOG_VAL;
+int dhd_msg_level = DHD_ERROR_VAL | DHD_MSGTRACE_VAL | DHD_EVENT_VAL | DHD_FWLOG_VAL;
 
 
 #if defined(WL_WLC_SHIM)
@@ -160,6 +165,9 @@ static int traffic_mgmt_add_dwm_filter(dhd_pub_t *dhd,
 	trf_mgmt_filter_list_t * trf_mgmt_filter_list, int len);
 #endif
 
+#ifdef HOST_FLAG
+extern int hostsleep;
+#endif
 
 /* IOVar table */
 enum {
@@ -504,6 +512,11 @@ dhd_wl_ioctl(dhd_pub_t *dhd_pub, int ifidx, wl_ioctl_t *ioc, void *buf, int len)
 	int ret = BCME_ERROR;
 	unsigned long flags;
 
+#ifdef HOST_FLAG
+	int hostsleep_set = 0;
+	int hostsleep_val = 0;
+	char *psleep = NULL;
+#endif
 #ifdef KEEPIF_ON_DEVICE_RESET
 		if (ioc->cmd == WLC_GET_VAR) {
 			dbus_config_t config;
@@ -550,9 +563,42 @@ dhd_wl_ioctl(dhd_pub_t *dhd_pub, int ifidx, wl_ioctl_t *ioc, void *buf, int len)
 			}
 		}
 #else
+#ifdef HOST_FLAG
+		/*save hostsleep val first, if ioctl success, set hostsleep to val*/
+		if (ioc->cmd == WLC_SET_VAR) {
+			psleep = strstr(ioc->buf, "hostsleep");
+			if (psleep) {
+				hostsleep_set = 1;
+				memcpy(&hostsleep_val, psleep + strlen("hostsleep") + 1, sizeof(hostsleep_val));
+				printf("###hostsleep: cmd = %d, hostsleep_val = %d, buf = %s\n",
+					ioc->cmd, hostsleep_val, (char *)ioc->buf);
+			}
+		}
+		/* block all cmd, expect hostsleep remove */
+		if (hostsleep && (!hostsleep_set || hostsleep_val)) {
+			printf("%s: block all none hostsleep clr cmd\n", __FUNCTION__);
+			dhd_os_proto_unblock(dhd_pub);
+			return BCME_EPERM;
+		} else if (hostsleep_set && hostsleep_val) {
+			printf("%s: set dhd hostsleep 1\n", __FUNCTION__);
+			hostsleep = 1;
+		}
+#endif
 		ret = dhd_prot_ioctl(dhd_pub, ifidx, ioc, buf, len);
 #endif /* defined(WL_WLC_SHIM) */
 
+#ifdef HOST_FLAG
+		if (hostsleep_set) {
+			if (hostsleep_val && ret) { // reset hostsleep if host_sleep 1 set failed
+				printf("%s: reset hostsleep\n", __FUNCTION__);
+				hostsleep = 0;
+			} else if (!hostsleep_val && !ret) { // clear hostsleep if host_sleep 0 set successfully
+				printf("%s: clear hostsleep\n", __FUNCTION__);
+				hostsleep = 0;
+			}
+		}
+#endif
+
 		if (ret && dhd_pub->up) {
 			/* Send hang event only if dhd_open() was success */
 			dhd_os_check_hang(dhd_pub, ifidx, ret);
@@ -683,10 +729,12 @@ dhd_doiovar(dhd_pub_t *dhd_pub, const bcm_iovar_t *vi, uint32 actionid, const ch
 		bcopy(&int_val, arg, val_size);
 		break;
 
+#ifndef BCMDBUS
 	case IOV_GVAL(IOV_WDTICK):
 		int_val = (int32)dhd_watchdog_ms;
 		bcopy(&int_val, arg, val_size);
 		break;
+#endif
 
 	case IOV_SVAL(IOV_WDTICK):
 		if (!dhd_pub->up) {
@@ -705,6 +753,7 @@ dhd_doiovar(dhd_pub_t *dhd_pub, const bcm_iovar_t *vi, uint32 actionid, const ch
 		bcmerror = dhd_dump(dhd_pub, arg, len);
 		break;
 
+#ifndef BCMDBUS
 #ifdef DHD_DEBUG
 	case IOV_GVAL(IOV_DCONSOLE_POLL):
 		int_val = (int32)dhd_console_ms;
@@ -720,6 +769,7 @@ dhd_doiovar(dhd_pub_t *dhd_pub, const bcm_iovar_t *vi, uint32 actionid, const ch
 			bcmerror = dhd_bus_console_in(dhd_pub, arg, len - 1);
 		break;
 #endif /* DHD_DEBUG */
+#endif /* BCMDBUS */
 
 	case IOV_SVAL(IOV_CLEARCOUNTS):
 		dhd_pub->tx_packets = dhd_pub->rx_packets = 0;
@@ -1598,11 +1648,21 @@ dhd_ioctl(dhd_pub_t * dhd_pub, dhd_ioctl_t *ioc, void * buf, uint buflen)
 
 		/* if still not found, try bus module */
 		if (ioc->cmd == DHD_GET_VAR) {
+#ifdef BCMDBUS
+			bcmerror = dbus_iovar_op(dhd_pub->dbus, buf,
+				arg, arglen, buf, buflen, IOV_GET);
+#else
 			bcmerror = dhd_bus_iovar_op(dhd_pub, buf,
 				arg, arglen, buf, buflen, IOV_GET);
+#endif
 		} else {
+#ifdef BCMDBUS
+			bcmerror = dbus_iovar_op(dhd_pub->dbus, buf,
+				NULL, 0, arg, arglen, IOV_SET);
+#else
 			bcmerror = dhd_bus_iovar_op(dhd_pub, buf,
 				NULL, 0, arg, arglen, IOV_SET);
+#endif
 		}
 
 		break;
@@ -2096,7 +2156,7 @@ wl_host_event(dhd_pub_t *dhd_pub, int *ifidx, void *pktdata,
 			dhd_ifname2idx(dhd_pub->info, event->ifname),
 			&event->addr.octet);
 		break;
-#if defined(DHD_FW_COREDUMP)
+#if !defined(BCMDBUS) && defined(DHD_FW_COREDUMP)
 	case WLC_E_PSM_WATCHDOG:
 		DHD_ERROR(("%s: WLC_E_PSM_WATCHDOG event received : \n", __FUNCTION__));
 		if (dhd_socram_dump(dhd_pub->bus) != BCME_OK) {
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_custom_gpio.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_custom_gpio.c
index ca3c51197d6d..078fccfd9df7 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_custom_gpio.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_custom_gpio.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Customer code to add GPIO control during WLAN start/stop
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_dbg.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_dbg.h
index 77b64aa7f614..e0fe8899cc08 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_dbg.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_dbg.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Debug/trace/assert driver definitions for Dongle Host Driver.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.c
index daa0c4deb44c..59600c3d3594 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD debugability support
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.h
index f2e191c4ff33..4130fb2ee7c7 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD debugability header file
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug_linux.c
index 11f0c4ad4ba5..8d6f5e18ca93 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_debug_linux.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD debugability Linux os layer
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.c
index 5fb587d2b176..3cb93bb91c7d 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.c
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /**
  * @file Broadcom Dongle Host Driver (DHD), Flow ring specific code at top level
  *
  * Flow rings are transmit traffic (=propagating towards antenna) related entities
  *
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.h
index b17dbbe69473..b8a8c56189c3 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_flowring.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /**
  * @file Header file describing the flow rings DHD interfaces.
  *
@@ -6,7 +7,7 @@
  * Provides type definitions and function prototypes used to create, delete and manage flow rings at
  * high level.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c
index f7c1bbd66197..71c83e05a954 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_gpio.c
@@ -1,4 +1,5 @@
 /* SPDX-License-Identifier: GPL-2.0 */
+/* SPDX-License-Identifier: GPL-2.0 */
 
 #include <osl.h>
 #include <dhd_linux.h>
@@ -33,7 +34,7 @@ struct resource dhd_wlan_resources = {
 		.name	= "bcmdhd_wlan_irq",
 		.start	= 0,
 		.end	= 0,
-		.flags	= IORESOURCE_IRQ | IORESOURCE_IRQ_SHAREABLE,
+		.flags	= IORESOURCE_IRQ | IORESOURCE_IRQ_SHAREABLE	| IORESOURCE_IRQ_HIGHLEVEL,
 };
 
 static struct cntry_locales_custom brcm_wlan_translate_custom_table[] = {
@@ -105,7 +106,6 @@ static void *dhd_wlan_get_country_code(char *ccode
 int dhd_wlan_init_plat_data(void)
 {
     uint irq;
-	int irq_flags = -1;
 
     irq = rockchip_wifi_get_oob_irq();
 
@@ -114,13 +114,5 @@ int dhd_wlan_init_plat_data(void)
     dhd_wlan_resources.start = irq;
     dhd_wlan_resources.end = irq;
 
-	irq_flags = rockchip_wifi_get_oob_irq_flag();
-	if (irq_flags == 1)
-		dhd_wlan_resources.flags |= IORESOURCE_IRQ_HIGHLEVEL;
-	else if (irq_flags == 0)
-		dhd_wlan_resources.flags |= IORESOURCE_IRQ_LOWLEVEL;
-	else
-		pr_warn("%s: unknown oob irqflags !\n", __func__);
-
 	return 0;
 }
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.c
index a363ee72edcb..a1a38d7f0e66 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * IP Packet Parser Module.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.h
index 9a22c8ca1a7b..687cbad113fa 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_ip.h
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Header file describing the common ip parser function.
  *
  * Provides type definitions and function prototypes used to parse ip packet.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c
index ab17c018bb86..5e4e5b2d5f15 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD), Linux-specific network interface
  * Basically selected code segments from usb-cdc.c and usb-rndis.c
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -25,7 +26,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: dhd_linux.c 674559 2017-10-27 03:07:31Z $
+ * $Id: dhd_linux.c 692262 2018-07-04 09:30:26Z $
  */
 
 #include <typedefs.h>
@@ -36,6 +37,9 @@
 #include <event_log.h>
 #endif /* SHOW_LOGTRACE */
 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0))
+#include <linux/sched/types.h>
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0) */
 
 #include <linux/init.h>
 #include <linux/kernel.h>
@@ -135,6 +139,9 @@ extern void register_page_corrupt_cb(page_corrupt_cb_t cb, void* handle);
 #include <linux/notifier.h>
 #include <linux/workqueue.h>
 #include <asm/atomic.h>
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0))
+#include <linux/cpuhotplug.h>
+#endif
 
 #if !defined(DHD_LB_PRIMARY_CPUS)
 #define DHD_LB_PRIMARY_CPUS     0x0 /* Big CPU coreids mask */
@@ -144,6 +151,10 @@ extern void register_page_corrupt_cb(page_corrupt_cb_t cb, void* handle);
 #define DHD_LB_SECONDARY_CPUS   0xFE /* Little CPU coreids mask */
 #endif
 
+#if (NR_CPUS > 8)
+#undef NR_CPUS
+#define NR_CPUS 8
+#endif
 #define HIST_BIN_SIZE	8
 
 #if defined(DHD_LB_RXP)
@@ -231,6 +242,10 @@ static u32 vendor_oui = CONFIG_DHD_SET_RANDOM_MAC_VAL;
 
 
 
+#ifdef HOST_FLAG
+int hostsleep = 0;
+#endif
+
 const uint8 wme_fifo2ac[] = { 0, 1, 2, 3, 1, 1 };
 const uint8 prio2fifo[8] = { 1, 0, 0, 1, 2, 2, 3, 3 };
 #define WME_PRIO2AC(prio)  wme_fifo2ac[prio2fifo[(prio)]]
@@ -276,7 +291,18 @@ static void dhd_hang_process(void *dhd_info, void *event_data, u8 event);
 MODULE_LICENSE("GPL and additional rights");
 #endif /* LinuxVer */
 
+#ifdef BCMDBUS
+#include <dbus.h>
+extern int dhd_bus_init(dhd_pub_t *dhdp, bool enforce_mutex);
+extern void dhd_bus_stop(struct dhd_bus *bus, bool enforce_mutex);
+extern void dhd_bus_unregister(void);
+
+#ifdef BCMSDIO
+extern bool dhd_bus_dpc(struct dhd_bus *bus);
+#endif /* BCMSDIO */
+#else
 #include <dhd_bus.h>
+#endif /* BCMDBUS */
 
 #ifdef DHD_ULP
 #include <dhd_ulp.h>
@@ -479,6 +505,10 @@ typedef struct dhd_info {
 #ifdef PROP_TXSTATUS
 	spinlock_t	wlfc_spinlock;
 
+#ifdef BCMDBUS
+	ulong		wlfc_lock_flags;
+	ulong		wlfc_pub_lock_flags;
+#endif
 #endif /* PROP_TXSTATUS */
 #ifdef WLMEDIA_HTSF
 	htsf_t  htsf;
@@ -494,10 +524,14 @@ typedef struct dhd_info {
 	spinlock_t	sdlock;
 	spinlock_t	txqlock;
 	spinlock_t	dhd_lock;
+#ifdef BCMDBUS
+	ulong		txqlock_flags;
+#else
 
 	struct semaphore sdsem;
 	tsk_ctl_t	thr_dpc_ctl;
 	tsk_ctl_t	thr_wdt_ctl;
+#endif /* BCMDBUS */
 
 	tsk_ctl_t	thr_rxf_ctl;
 	spinlock_t	rxf_lock;
@@ -590,7 +624,11 @@ typedef struct dhd_info {
 	cpumask_var_t cpumask_primary, cpumask_secondary; /* configuration */
 	cpumask_var_t cpumask_primary_new, cpumask_secondary_new; /* temp */
 
+#if (LINUX_VERSION_CODE  >= KERNEL_VERSION(4, 10, 0))
+	struct hlist_node node_online;
+#else
 	struct notifier_block cpu_notifier;
+#endif
 
 	/* Tasklet to handle Tx Completion packet freeing */
 	struct tasklet_struct tx_compl_tasklet;
@@ -663,6 +701,10 @@ typedef struct dhd_info {
 #endif /* DHD_LB */
 
 #if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+#if defined(BCMDBUS)
+	struct task_struct *fw_download_task;
+	struct semaphore fw_download_lock;
+#endif /* BCMDBUS */
 #endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
 	struct net_device *monitor_dev; /* monitor pseudo device */
 	uint monitor_type;   /* monitor pseudo device */
@@ -759,8 +801,7 @@ uint dhd_console_ms = 0;
 module_param(dhd_console_ms, uint, 0644);
 #endif /* defined(DHD_DEBUG) */
 
-//uint dhd_slpauto = TRUE;
-uint dhd_slpauto = FALSE;
+uint dhd_slpauto = TRUE;
 module_param(dhd_slpauto, uint, 0);
 
 #ifdef PKT_FILTER_SUPPORT
@@ -994,6 +1035,31 @@ void dhd_select_cpu_candidacy(dhd_info_t *dhd)
 	return;
 }
 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0))
+int dhd_cpuhp_online(unsigned int cpu, struct hlist_node *node)
+{
+	dhd_info_t *dhd = hlist_entry_safe(node, dhd_info_t,
+				node_online);
+
+	DHD_INFO(("%s: cpu=%d\n", __func__, cpu));
+	DHD_LB_STATS_INCR(dhd->cpu_online_cnt[cpu]);
+	cpumask_set_cpu(cpu, dhd->cpumask_curr_avail);
+	dhd_select_cpu_candidacy(dhd);
+	return 0;
+}
+
+int dhd_cpuhp_dead(unsigned int cpu, struct hlist_node *node)
+{
+	dhd_info_t *dhd = hlist_entry_safe(node, dhd_info_t,
+				node_online);
+
+	DHD_INFO(("%s: cpu=%d\n", __func__, cpu));
+	DHD_LB_STATS_INCR(dhd->cpu_offline_cnt[cpu]);
+	cpumask_clear_cpu(cpu, dhd->cpumask_curr_avail);
+	dhd_select_cpu_candidacy(dhd);
+	return 0;
+}
+#else
 /*
  * Function to handle CPU Hotplug notifications.
  * One of the task it does is to trigger the CPU Candidacy algorithm
@@ -1026,6 +1092,7 @@ dhd_cpu_callback(struct notifier_block *nfb, unsigned long action, void *hcpu)
 
 	return NOTIFY_OK;
 }
+#endif
 
 #if defined(DHD_LB_STATS)
 void dhd_lb_stats_init(dhd_pub_t *dhdp)
@@ -1342,9 +1409,11 @@ module_param(dhd_pktgen_len, uint, 0);
 
 
 
+#ifndef BCMDBUS
 /* Allow delayed firmware download for debug purpose */
 int allow_delay_fwdl = FALSE;
 module_param(allow_delay_fwdl, int, 0);
+#endif /* !BCMDBUS */
 
 /* Flag to indicate whether FW download has succeeded */
 bool dhd_fw_downloaded = FALSE;
@@ -1378,7 +1447,9 @@ int dhd_monitor_uninit(void);
 struct iw_statistics *dhd_get_wireless_stats(struct net_device *dev);
 #endif /* defined(WL_WIRELESS_EXT) */
 
+#ifndef BCMDBUS
 static void dhd_dpc(ulong data);
+#endif
 /* forward decl */
 extern int dhd_wait_pend8021x(struct net_device *dev);
 void dhd_os_wd_timer_extend(void *bus, bool extend);
@@ -1390,6 +1461,9 @@ void dhd_os_wd_timer_extend(void *bus, bool extend);
 static int dhd_toe_get(dhd_info_t *dhd, int idx, uint32 *toe_ol);
 static int dhd_toe_set(dhd_info_t *dhd, int idx, uint32 toe_ol);
 #endif /* TOE */
+#ifdef BCMDBUS
+int dhd_dbus_txdata(dhd_pub_t *dhdp, void *pktbuf);
+#endif
 
 static int dhd_wl_host_event(dhd_info_t *dhd, int *ifidx, void *pktdata,
                              wl_event_msg_t *event_ptr, void **data_ptr);
@@ -2890,6 +2964,409 @@ dhd_bssidx2bssid(dhd_pub_t *dhdp, int idx)
 	return NULL;
 }
 
+#ifdef BCMDBUS
+#define DBUS_NRXQ	50
+#define DBUS_NTXQ	100
+
+static void
+dhd_dbus_send_complete(void *handle, void *info, int status)
+{
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+	void *pkt = info;
+
+	if ((dhd == NULL) || (pkt == NULL))
+		return;
+
+	if (status == DBUS_OK) {
+		dhd->pub.dstats.tx_packets++;
+	} else {
+		DHD_ERROR(("TX error=%d\n", status));
+		dhd->pub.dstats.tx_errors++;
+	}
+#ifdef PROP_TXSTATUS
+	if (DHD_PKTTAG_WLFCPKT(PKTTAG(pkt)) &&
+		(dhd_wlfc_txcomplete(&dhd->pub, pkt, status == 0) != WLFC_UNSUPPORTED)) {
+		return;
+	}
+#endif /* PROP_TXSTATUS */
+	PKTFREE(dhd->pub.osh, pkt, TRUE);
+}
+
+static void
+dhd_dbus_recv_pkt(void *handle, void *pkt)
+{
+	uchar reorder_info_buf[WLHOST_REORDERDATA_TOTLEN];
+	uint reorder_info_len;
+	uint pkt_count;
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+	int ifidx = 0;
+
+	if (dhd == NULL)
+		return;
+
+	/* If the protocol uses a data header, check and remove it */
+	if (dhd_prot_hdrpull(&dhd->pub, &ifidx, pkt, reorder_info_buf,
+		&reorder_info_len) != 0) {
+		DHD_ERROR(("rx protocol error\n"));
+		PKTFREE(dhd->pub.osh, pkt, FALSE);
+		dhd->pub.rx_errors++;
+		return;
+	}
+
+	if (reorder_info_len) {
+		/* Reordering info from the firmware */
+		dhd_process_pkt_reorder_info(&dhd->pub, reorder_info_buf, reorder_info_len,
+			&pkt, &pkt_count);
+		if (pkt_count == 0)
+			return;
+	}
+	else {
+		pkt_count = 1;
+	}
+	dhd_rx_frame(&dhd->pub, ifidx, pkt, pkt_count, 0);
+}
+
+static void
+dhd_dbus_recv_buf(void *handle, uint8 *buf, int len)
+{
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+	void *pkt;
+
+	if (dhd == NULL)
+		return;
+
+	if ((pkt = PKTGET(dhd->pub.osh, len, FALSE)) == NULL) {
+		DHD_ERROR(("PKTGET (rx) failed=%d\n", len));
+		return;
+	}
+
+	bcopy(buf, PKTDATA(dhd->pub.osh, pkt), len);
+	dhd_dbus_recv_pkt(dhd, pkt);
+}
+
+static void
+dhd_dbus_txflowcontrol(void *handle, bool onoff)
+{
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+	bool wlfc_enabled = FALSE;
+
+	if (dhd == NULL)
+		return;
+
+#ifdef PROP_TXSTATUS
+	wlfc_enabled = (dhd_wlfc_flowcontrol(&dhd->pub, onoff, !onoff) != WLFC_UNSUPPORTED);
+#endif
+
+	if (!wlfc_enabled) {
+		dhd_txflowcontrol(&dhd->pub, ALL_INTERFACES, onoff);
+	}
+}
+
+static void
+dhd_dbus_errhandler(void *handle, int err)
+{
+}
+
+static void
+dhd_dbus_ctl_complete(void *handle, int type, int status)
+{
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+
+	if (dhd == NULL)
+		return;
+
+	if (type == DBUS_CBCTL_READ) {
+		if (status == DBUS_OK)
+			dhd->pub.rx_ctlpkts++;
+		else
+			dhd->pub.rx_ctlerrs++;
+	} else if (type == DBUS_CBCTL_WRITE) {
+		if (status == DBUS_OK)
+			dhd->pub.tx_ctlpkts++;
+		else
+			dhd->pub.tx_ctlerrs++;
+	}
+
+	dhd_prot_ctl_complete(&dhd->pub);
+}
+
+static void
+dhd_dbus_state_change(void *handle, int state)
+{
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+
+	if (dhd == NULL)
+		return;
+
+	switch (state) {
+
+		case DBUS_STATE_DL_NEEDED:
+#if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+#if defined(BCMDBUS)
+			DHD_TRACE(("%s: firmware request\n", __FUNCTION__));
+			up(&dhd->fw_download_lock);
+#endif /* BCMDBUS */
+#else
+			DHD_ERROR(("%s: firmware request cannot be handled\n", __FUNCTION__));
+#endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
+			break;
+		case DBUS_STATE_DOWN:
+			DHD_TRACE(("%s: DBUS is down\n", __FUNCTION__));
+			dhd->pub.busstate = DHD_BUS_DOWN;
+			break;
+		case DBUS_STATE_UP:
+			DHD_TRACE(("%s: DBUS is up\n", __FUNCTION__));
+			dhd->pub.busstate = DHD_BUS_DATA;
+			break;
+		default:
+			break;
+	}
+
+	DHD_TRACE(("%s: DBUS current state=%d\n", __FUNCTION__, state));
+}
+
+static void *
+dhd_dbus_pktget(void *handle, uint len, bool send)
+{
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+	void *p = NULL;
+
+	if (dhd == NULL)
+		return NULL;
+
+	if (send == TRUE) {
+		dhd_os_sdlock_txq(&dhd->pub);
+		p = PKTGET(dhd->pub.osh, len, TRUE);
+		dhd_os_sdunlock_txq(&dhd->pub);
+	} else {
+		dhd_os_sdlock_rxq(&dhd->pub);
+		p = PKTGET(dhd->pub.osh, len, FALSE);
+		dhd_os_sdunlock_rxq(&dhd->pub);
+	}
+
+	return p;
+}
+
+static void
+dhd_dbus_pktfree(void *handle, void *p, bool send)
+{
+	dhd_info_t *dhd = (dhd_info_t *)handle;
+
+	if (dhd == NULL)
+		return;
+
+	if (send == TRUE) {
+#ifdef PROP_TXSTATUS
+		if (DHD_PKTTAG_WLFCPKT(PKTTAG(p)) &&
+			(dhd_wlfc_txcomplete(&dhd->pub, p, FALSE) != WLFC_UNSUPPORTED)) {
+			return;
+		}
+#endif /* PROP_TXSTATUS */
+
+		dhd_os_sdlock_txq(&dhd->pub);
+		PKTFREE(dhd->pub.osh, p, TRUE);
+		dhd_os_sdunlock_txq(&dhd->pub);
+	} else {
+		dhd_os_sdlock_rxq(&dhd->pub);
+		PKTFREE(dhd->pub.osh, p, FALSE);
+		dhd_os_sdunlock_rxq(&dhd->pub);
+	}
+}
+
+#ifdef BCM_FD_AGGR
+
+static void
+dbus_rpcth_tx_complete(void *ctx, void *pktbuf, int status)
+{
+	dhd_info_t *dhd = (dhd_info_t *)ctx;
+	void *tmp;
+
+	while (pktbuf && dhd) {
+		tmp = PKTNEXT(dhd->pub.osh, pktbuf);
+		PKTSETNEXT(dhd->pub.osh, pktbuf, NULL);
+		dhd_dbus_send_complete(ctx, pktbuf, status);
+		pktbuf = tmp;
+	}
+}
+static void
+dbus_rpcth_rx_pkt(void *context, rpc_buf_t *rpc_buf)
+{
+	dhd_dbus_recv_pkt(context, rpc_buf);
+}
+
+static void
+dbus_rpcth_rx_aggrpkt(void *context, void *rpc_buf)
+{
+	dhd_info_t *dhd = (dhd_info_t *)context;
+
+	if (dhd == NULL)
+		return;
+
+	/* all the de-aggregated packets are delivered back to function dbus_rpcth_rx_pkt()
+	* as cloned packets
+	*/
+	bcm_rpc_dbus_recv_aggrpkt(dhd->rpc_th, rpc_buf,
+		bcm_rpc_buf_len_get(dhd->rpc_th, rpc_buf));
+
+	/* free the original packet */
+	dhd_dbus_pktfree(context, rpc_buf, FALSE);
+}
+
+static void
+dbus_rpcth_rx_aggrbuf(void *context, uint8 *buf, int len)
+{
+	dhd_info_t *dhd = (dhd_info_t *)context;
+
+	if (dhd == NULL)
+		return;
+
+	if (dhd->fdaggr & BCM_FDAGGR_D2H_ENABLED) {
+		bcm_rpc_dbus_recv_aggrbuf(dhd->rpc_th, buf, len);
+	}
+	else {
+		dhd_dbus_recv_buf(context, buf, len);
+	}
+
+}
+
+static void
+dhd_rpcth_watchdog(ulong data)
+{
+	dhd_info_t *dhd = (dhd_info_t *)data;
+
+	if (dhd->pub.dongle_reset) {
+		return;
+	}
+
+	dhd->rpcth_timer_active = FALSE;
+	/* release packets in the aggregation queue */
+	bcm_rpc_tp_watchdog(dhd->rpc_th);
+}
+
+static int
+dhd_fdaggr_ioctl(dhd_pub_t *dhd_pub, int ifindex, wl_ioctl_t *ioc, void *buf, int len)
+{
+	int bcmerror = 0;
+	void *rpc_th;
+
+	rpc_th = dhd_pub->info->rpc_th;
+
+	if (!strcmp("rpc_agg", ioc->buf)) {
+		uint32 rpc_agg;
+		uint32 rpc_agg_host;
+		uint32 rpc_agg_dngl;
+
+		if (ioc->set) {
+			memcpy(&rpc_agg, ioc->buf + strlen("rpc_agg") + 1, sizeof(uint32));
+			rpc_agg_host = rpc_agg & BCM_RPC_TP_HOST_AGG_MASK;
+			if (rpc_agg_host)
+				bcm_rpc_tp_agg_set(rpc_th, rpc_agg_host, TRUE);
+			else
+				bcm_rpc_tp_agg_set(rpc_th, BCM_RPC_TP_HOST_AGG_MASK, FALSE);
+			bcmerror = dhd_wl_ioctl(dhd_pub, ifindex, ioc, buf, len);
+			if (bcmerror < 0) {
+				DHD_ERROR(("usb aggregation not supported\n"));
+			} else {
+				dhd_pub->info->fdaggr = 0;
+				if (rpc_agg & BCM_RPC_TP_HOST_AGG_MASK)
+					dhd_pub->info->fdaggr |= BCM_FDAGGR_H2D_ENABLED;
+				if (rpc_agg & BCM_RPC_TP_DNGL_AGG_MASK)
+					dhd_pub->info->fdaggr |= BCM_FDAGGR_D2H_ENABLED;
+			}
+		} else {
+			rpc_agg_host = bcm_rpc_tp_agg_get(rpc_th);
+			bcmerror = dhd_wl_ioctl(dhd_pub, ifindex, ioc, buf, len);
+			if (!bcmerror) {
+				memcpy(&rpc_agg_dngl, buf, sizeof(uint32));
+				rpc_agg = (rpc_agg_host & BCM_RPC_TP_HOST_AGG_MASK) |
+					(rpc_agg_dngl & BCM_RPC_TP_DNGL_AGG_MASK);
+				memcpy(buf, &rpc_agg, sizeof(uint32));
+			}
+		}
+	} else if (!strcmp("rpc_host_agglimit", ioc->buf)) {
+		uint8 sf;
+		uint16 bytes;
+		uint32 agglimit;
+
+		if (ioc->set) {
+			memcpy(&agglimit, ioc->buf + strlen("rpc_host_agglimit") + 1,
+				sizeof(uint32));
+			sf = agglimit >> 16;
+			bytes = agglimit & 0xFFFF;
+			bcm_rpc_tp_agg_limit_set(rpc_th, sf, bytes);
+		} else {
+			bcm_rpc_tp_agg_limit_get(rpc_th, &sf, &bytes);
+			agglimit = (uint32)((sf << 16) + bytes);
+			memcpy(buf, &agglimit, sizeof(uint32));
+		}
+
+	} else {
+		bcmerror = dhd_wl_ioctl(dhd_pub, ifindex, ioc, buf, len);
+	}
+	return bcmerror;
+}
+#endif /* BCM_FD_AGGR */
+
+static dbus_callbacks_t dhd_dbus_cbs = {
+#ifdef BCM_FD_AGGR
+	dbus_rpcth_tx_complete,
+	dbus_rpcth_rx_aggrbuf,
+	dbus_rpcth_rx_aggrpkt,
+#else
+	dhd_dbus_send_complete,
+	dhd_dbus_recv_buf,
+	dhd_dbus_recv_pkt,
+#endif
+	dhd_dbus_txflowcontrol,
+	dhd_dbus_errhandler,
+	dhd_dbus_ctl_complete,
+	dhd_dbus_state_change,
+	dhd_dbus_pktget,
+	dhd_dbus_pktfree
+};
+
+void
+dhd_bus_dump(dhd_pub_t *dhdp, struct bcmstrbuf *strbuf)
+{
+	bcm_bprintf(strbuf, "Bus USB\n");
+}
+
+void
+dhd_bus_clearcounts(dhd_pub_t *dhdp)
+{
+}
+
+bool
+dhd_bus_dpc(struct dhd_bus *bus)
+{
+	return FALSE;
+}
+
+int
+dhd_dbus_txdata(dhd_pub_t *dhdp, void *pktbuf)
+{
+
+	if (dhdp->txoff)
+		return BCME_EPERM;
+#ifdef BCM_FD_AGGR
+	if (((dhd_info_t *)(dhdp->info))->fdaggr & BCM_FDAGGR_H2D_ENABLED)
+
+	{
+		dhd_info_t *dhd;
+		int ret;
+		dhd = (dhd_info_t *)(dhdp->info);
+		ret = bcm_rpc_tp_buf_send(dhd->rpc_th, pktbuf);
+		if (dhd->rpcth_timer_active == FALSE) {
+			dhd->rpcth_timer_active = TRUE;
+			mod_timer(&dhd->rpcth_timer, jiffies + BCM_RPC_TP_HOST_TMOUT * HZ / 1000);
+		}
+		return ret;
+	} else
+#endif /* BCM_FD_AGGR */
+	return dbus_send_txdata(dhdp->dbus, pktbuf);
+}
+
+#endif /* BCMDBUS */
 
 static void
 _dhd_set_multicast_list(dhd_info_t *dhd, int ifidx)
@@ -3457,7 +3934,11 @@ dhd_os_wlfc_block(dhd_pub_t *pub)
 {
 	dhd_info_t *di = (dhd_info_t *)(pub->info);
 	ASSERT(di != NULL);
+#ifdef BCMDBUS
+	spin_lock_irqsave(&di->wlfc_spinlock, di->wlfc_lock_flags);
+#else
 	spin_lock_bh(&di->wlfc_spinlock);
+#endif
 	return 1;
 }
 
@@ -3467,7 +3948,11 @@ dhd_os_wlfc_unblock(dhd_pub_t *pub)
 	dhd_info_t *di = (dhd_info_t *)(pub->info);
 
 	ASSERT(di != NULL);
+#ifdef BCMDBUS
+	spin_unlock_irqrestore(&di->wlfc_spinlock, di->wlfc_lock_flags);
+#else
 	spin_unlock_bh(&di->wlfc_spinlock);
+#endif
 	return 1;
 }
 
@@ -3713,6 +4198,19 @@ __dhd_sendpkt(dhd_pub_t *dhdp, int ifidx, void *pktbuf)
 #if defined(DHD_8021X_DUMP)
 	dhd_tx_dump(dhdp->osh, pktbuf);
 #endif
+#ifdef BCMDBUS
+#ifdef PROP_TXSTATUS
+	if (dhd_wlfc_commit_packets(dhdp, (f_commitpkt_t)dhd_dbus_txdata,
+		dhdp, pktbuf, TRUE) == WLFC_UNSUPPORTED) {
+		/* non-proptxstatus way */
+		ret = dhd_dbus_txdata(dhdp, pktbuf);
+	}
+#else
+	ret = dhd_dbus_txdata(dhdp, pktbuf);
+#endif /* PROP_TXSTATUS */
+	if (ret)
+		PKTCFREE(dhdp->osh, pktbuf, TRUE);
+#else
 #ifdef PROP_TXSTATUS
 	{
 		if (dhd_wlfc_commit_packets(dhdp, (f_commitpkt_t)dhd_bus_txdata,
@@ -3733,6 +4231,8 @@ __dhd_sendpkt(dhd_pub_t *dhdp, int ifidx, void *pktbuf)
 #endif /* BCMPCIE */
 #endif /* PROP_TXSTATUS */
 
+#endif /* BCMDBUS */
+
 	return ret;
 }
 
@@ -4027,6 +4527,15 @@ dhd_start_xmit(struct sk_buff *skb, struct net_device *net)
 		}
 	}
 #endif /* DHDTCPACK_SUPPRESS */
+#ifdef HOST_FLAG
+	if (hostsleep) {
+		printf("%s (%d): hostsleep = %d, tx_dropped = %lu\n",__FUNCTION__, __LINE__,
+			hostsleep, ifp->stats.tx_dropped);
+		PKTFREE(dhd->pub.osh, pktbuf, TRUE);
+		ret = BCME_TXFAIL;
+		goto done;
+	}
+#endif
 
 	ret = __dhd_sendpkt(&dhd->pub, ifidx, pktbuf);
 
@@ -4532,7 +5041,7 @@ dhd_rx_frame(dhd_pub_t *dhdp, int ifidx, void *pktbuf, int numpkt, uint8 chan)
 			}
 
 			if (numpkt != 1) {
-				DHD_INFO(("%s: Got BRCM event packet in a chained packet.\n",
+				DHD_ERROR(("%s: Got BRCM event packet in a chained packet.\n",
 				__FUNCTION__));
 			}
 #ifdef DHD_DONOT_FORWARD_BCMEVENT_AS_NETWORK_PKT
@@ -4570,8 +5079,12 @@ dhd_rx_frame(dhd_pub_t *dhdp, int ifidx, void *pktbuf, int numpkt, uint8 chan)
 #endif /* PROP_TXSTATUS */
 		}
 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 8, 0))
+#else
+
 		if (ifp->net)
 			ifp->net->last_rx = jiffies;
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 8, 0) */
 
 		if (ntoh16(skb->protocol) != ETHER_TYPE_BRCM) {
 			dhdp->dstats.rx_bytes += skb->len;
@@ -4704,6 +5217,7 @@ dhd_get_stats(struct net_device *net)
 	return &ifp->stats;
 }
 
+#ifndef BCMDBUS
 static int
 dhd_watchdog_thread(void *data)
 {
@@ -5098,6 +5612,7 @@ dhd_sched_dpc(dhd_pub_t *dhdp)
 		DHD_OS_WAKE_UNLOCK(dhdp);
 	}
 }
+#endif /* BCMDBUS */
 
 static void
 dhd_sched_rxf(dhd_pub_t *dhdp, void *skb)
@@ -5150,6 +5665,39 @@ dhd_sched_rxf(dhd_pub_t *dhdp, void *skb)
 }
 
 #if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+#if defined(BCMDBUS)
+static int
+fw_download_thread_func(void *data)
+{
+	dhd_info_t *dhd = (dhd_info_t *)data;
+	int ret;
+
+	while (1) {
+		/* Wait for start trigger */
+		if (down_interruptible(&dhd->fw_download_lock) != 0)
+			return -ERESTARTSYS;
+
+		if (kthread_should_stop())
+			break;
+
+		DHD_TRACE(("%s: initiating firmware check and download\n", __FUNCTION__));
+		if (dbus_download_firmware(dhd->pub.dbus) == DBUS_OK) {
+			if ((ret = dbus_up(dhd->pub.dbus)) == 0) {
+#ifdef PROP_TXSTATUS
+				/* Need to deinitialise WLFC to allow re-initialisation later. */
+				dhd_wlfc_deinit(&dhd->pub);
+#endif /* PROP_TXSTATUS */
+				/* Resynchronise with the dongle. This also re-initialises WLFC. */
+				if ((ret = dhd_sync_with_dongle(&dhd->pub)) < 0) {
+					DHD_ERROR(("%s: failed with code %d\n", __FUNCTION__, ret));
+				}
+			}
+		}
+	}
+
+	return 0;
+}
+#endif /* BCMDBUS */
 #endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
 
 #ifdef TOE
@@ -5376,12 +5924,12 @@ static bool dhd_check_hang(struct net_device *net, dhd_pub_t *dhdp, int error)
 		return FALSE;
 
 	dhd = (dhd_info_t *)dhdp->info;
-#if !defined(BCMPCIE)
+#if (!defined(BCMDBUS) && !defined(BCMPCIE))
 	if (dhd->thr_dpc_ctl.thr_pid < 0) {
 		DHD_ERROR(("%s : skipped due to negative pid - unloading?\n", __FUNCTION__));
 		return FALSE;
 	}
-#endif 
+#endif /* BCMDBUS */
 #ifdef DHD_FW_COREDUMP
 	if (error == -ETIMEDOUT && dhdp->busstate != DHD_BUS_DOWN) {
 		if (dhd_os_socram_dump(net, &dump_len) == BCME_OK) {
@@ -5428,6 +5976,7 @@ int dhd_ioctl_process(dhd_pub_t *pub, int ifidx, dhd_ioctl_t *ioc, void *data_bu
 		goto done;
 	}
 
+#ifndef BCMDBUS
 	/* send to dongle (must be up, and wl). */
 	if (pub->busstate == DHD_BUS_DOWN || pub->busstate == DHD_BUS_LOAD) {
 		if (allow_delay_fwdl) {
@@ -5447,6 +5996,7 @@ int dhd_ioctl_process(dhd_pub_t *pub, int ifidx, dhd_ioctl_t *ioc, void *data_bu
 		bcmerror = BCME_DONGLE_DOWN;
 		goto done;
 	}
+#endif /* BCMDBUS */
 
 	/*
 	 * Flush the TX queue if required for proper message serialization:
@@ -5757,7 +6307,7 @@ dhd_stop(struct net_device *net)
 #endif /* OEM_ANDROID && CONFIG_IPV6 */
 				dhd_net_if_unlock_local(dhd);
 			}
-			cancel_work_sync(dhd->dhd_deferred_wq);
+			//cancel_work_sync(dhd->dhd_deferred_wq);
 #if defined(DHD_LB) && defined(DHD_LB_RXP)
 			__skb_queue_purge(&dhd->rx_pend_queue);
 #endif /* DHD_LB && DHD_LB_RXP */
@@ -5918,6 +6468,7 @@ dhd_open(struct net_device *net)
 
 		if (dhd->pub.busstate != DHD_BUS_DATA) {
 
+#ifndef BCMDBUS
 			/* try to bring up bus */
 			DHD_PERIM_UNLOCK(&dhd->pub);
 			ret = dhd_bus_start(&dhd->pub);
@@ -5927,6 +6478,18 @@ dhd_open(struct net_device *net)
 				ret = -1;
 				goto exit;
 			}
+#else /* BCMDBUS */
+			if ((ret = dbus_up(dhd->pub.dbus)) != 0) {
+				goto exit;
+			} else {
+				dhd->pub.busstate = DHD_BUS_DATA;
+			}
+
+			if ((ret = dhd_sync_with_dongle(&dhd->pub)) < 0) {
+				DHD_ERROR(("%s: failed with code %d\n", __FUNCTION__, ret));
+				goto exit;
+			}
+#endif /* BCMDBUS */
 
 		}
 
@@ -6217,9 +6780,17 @@ dhd_allocate_if(dhd_pub_t *dhdpub, int ifidx, char *name,
 
 #ifdef WL_CFG80211
 	if (ifidx == 0)
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0))
+                ifp->net->priv_destructor = free_netdev;
+#else
 		ifp->net->destructor = free_netdev;
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0) */
 	else
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0))
+                ifp->net->priv_destructor = dhd_netdev_free;
+#else
 		ifp->net->destructor = dhd_netdev_free;
+#endif
 #else
 	ifp->net->destructor = free_netdev;
 #endif /* WL_CFG80211 */
@@ -6435,7 +7006,11 @@ dhd_init_logstrs_array(dhd_event_log_t *temp)
 		DHD_ERROR(("%s: Failed to allocate memory \n", __FUNCTION__));
 		goto fail;
 	}
-	if (vfs_read(filep, raw_fmts, logstrs_size, &filep->f_pos) !=	logstrs_size) {
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0))
+       if (vfs_read(filep, raw_fmts, logstrs_size, &filep->f_pos) != logstrs_size) {
+#else
+       if (kernel_read(filep, raw_fmts, logstrs_size, &filep->f_pos) != logstrs_size) {
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0)) */
 		DHD_ERROR(("%s: Failed to read file %s", __FUNCTION__, logstrs_path));
 		goto fail;
 	}
@@ -6578,7 +7153,11 @@ dhd_read_map(char *fname, uint32 *ramstart, uint32 *rodata_start,
 
 	while (count != ALL_MAP_VAL)
 	{
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0))
 		error = vfs_read(filep, raw_fmts, read_size, (&filep->f_pos));
+#else
+                error = kernel_read(filep, raw_fmts, read_size, (&filep->f_pos));
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0)) */
 		if (error < 0) {
 			DHD_ERROR(("%s: read failed %s err:%d \n", __FUNCTION__,
 				map_file_path, error));
@@ -6695,7 +7274,11 @@ dhd_init_static_strs_array(dhd_event_log_t *temp, char *str_file, char *map_file
 		goto fail;
 	}
 
-	error = vfs_read(filep, raw_fmts, logstrs_size, (&filep->f_pos));
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0))
+        error = vfs_read(filep, raw_fmts, logstrs_size, (&filep->f_pos));
+#else
+        error = kernel_read(filep, raw_fmts, logstrs_size, (&filep->f_pos));
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0)) */
 	if (error != logstrs_size) {
 		DHD_ERROR(("%s: %s read failed %d \n", __FUNCTION__, str_file, error));
 		goto fail;
@@ -6734,6 +7317,30 @@ fail:
 }
 
 #endif /* SHOW_LOGTRACE */
+#ifdef DHD_LB
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0))
+
+static enum cpuhp_state dhd_cpuhp_online_state;
+
+static int
+dhd_cpuhp_init(osl_t *osh, dhd_info_t *dhd)
+{
+	int ret = 0;
+
+	ret = cpuhp_setup_state_multi(CPUHP_AP_ONLINE_DYN, "net/wireless/dhd:online",
+			dhd_cpuhp_online, dhd_cpuhp_dead);
+	if (ret < 0) {
+		DHD_ERROR(("%s(): cpuhp_setup_state_multi() online failed, ret=%d\n",
+			__FUNCTION__, ret));
+		return ret;
+	}
+	dhd_cpuhp_online_state = ret;
+	cpuhp_state_add_instance_nocalls(dhd_cpuhp_online_state,
+		&dhd->node_online);
+	return ret;
+}
+#endif
+#endif
 
 
 dhd_pub_t *
@@ -6754,9 +7361,9 @@ dhd_attach(osl_t *osh, struct dhd_bus *bus, uint bus_hdrlen)
 	DHD_ERROR(("%s\n", driver_target));
 #endif /* STBLINUX */
 	/* will implement get_ids for DBUS later */
-#if defined(BCMSDIO)
+#if !defined(BCMDBUS) && defined(BCMSDIO)
 	dhd_bus_get_ids(bus, &bus_type, &bus_num, &slot_num);
-#endif 
+#endif /* !defined(BCMDBUS) && defined(BCMSDIO) */
 	adapter = dhd_wifi_platform_get_adapter(bus_type, bus_num, slot_num);
 
 	/* Allocate primary dhd_info */
@@ -6788,6 +7395,7 @@ dhd_attach(osl_t *osh, struct dhd_bus *bus, uint bus_hdrlen)
 		dhd->pub.dhd_cspec.country_abbrev, &dhd->pub.dhd_cspec,
 		dhd->pub.dhd_cflags);
 #endif /* CUSTOM_COUNTRY_CODE */
+#ifndef BCMDBUS
 	dhd->thr_dpc_ctl.thr_pid = DHD_PID_KT_TL_INVALID;
 	dhd->thr_wdt_ctl.thr_pid = DHD_PID_KT_INVALID;
 
@@ -6803,6 +7411,7 @@ dhd_attach(osl_t *osh, struct dhd_bus *bus, uint bus_hdrlen)
 	 * solution
 	 */
 	dhd_update_fw_nv_path(dhd);
+#endif /* BCMDBUS */
 
 	/* Link to info module */
 	dhd->pub.info = dhd;
@@ -6957,6 +7566,7 @@ dhd_attach(osl_t *osh, struct dhd_bus *bus, uint bus_hdrlen)
 	}
 
 
+#ifndef BCMDBUS
 
 	/* Set up the watchdog timer */
 	init_timer(&dhd->timer);
@@ -6991,6 +7601,7 @@ dhd_attach(osl_t *osh, struct dhd_bus *bus, uint bus_hdrlen)
 		/* Initialize RXF thread */
 		PROC_START(dhd_rxf_thread, dhd, &dhd->thr_rxf_ctl, 0, "dhd_rxf");
 	}
+#endif /* BCMDBUS */
 
 	dhd_state |= DHD_ATTACH_STATE_THREADS_CREATED;
 
@@ -7043,6 +7654,10 @@ dhd_attach(osl_t *osh, struct dhd_bus *bus, uint bus_hdrlen)
 #endif /* DHDTCPACK_SUPPRESS */
 
 #if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+#if defined(BCMDBUS)
+	sema_init(&dhd->fw_download_lock, 0);
+	dhd->fw_download_task = kthread_run(fw_download_thread_func, dhd, "fwdl-thread");
+#endif /* BCMDBUS */
 #endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
 
 	dhd_state |= DHD_ATTACH_STATE_DONE;
@@ -7070,17 +7685,24 @@ dhd_attach(osl_t *osh, struct dhd_bus *bus, uint bus_hdrlen)
 		 * CPU Hotplug framework to change the CPU for each job dynamically
 		 * using candidacy algorithm.
 		 */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0))
+		dhd_cpuhp_init(osh, dhd);
+#else
 		dhd->cpu_notifier.notifier_call = dhd_cpu_callback;
 		register_cpu_notifier(&dhd->cpu_notifier); /* Register a callback */
+#endif
 	} else {
 		/*
 		 * We are unable to initialize CPU masks, so candidacy algorithm
 		 * won't run, but still Load Balancing will be honoured based
 		 * on the CPUs allocated for a given job statically during init
 		 */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0))
+#else
 		dhd->cpu_notifier.notifier_call = NULL;
 		DHD_ERROR(("%s(): dhd_cpumasks_init failed CPUs for JOB would be static\n",
 			__FUNCTION__));
+#endif
 	}
 
 
@@ -7139,13 +7761,24 @@ int dhd_get_fw_mode(dhd_info_t *dhdinfo)
 	return DHD_FLAG_STA_MODE;
 }
 
-extern int rkwifi_set_firmware(char *fw, char *nvram);
+#ifndef BCMDBUS
 int cis_chipvendor = 0;
 unsigned short cis_device = 0;
-char cis_fw_43455_path[] = "/system/etc/firmware/fw_cyw43455.bin";
-char cis_nv_43455_path[] = "/system/etc/firmware/nvram_cyw43455.txt";
-char cis_fw_4354_path[] = "/system/etc/firmware/fw_cyw4354.bin";
-char cis_nv_4354_path[] = "/system/etc/firmware/nvram_cyw4354.txt";
+char fw_path[1024] = {0};
+char nv_path[1024] = {0};
+
+#define DEFAULT_BCMDHD_FW_PATH "/system/etc/firmware/"
+#define DEFAULT_BCMDHD_NVRAM_PATH "/system/etc/firmware/"
+
+#define FW_CYW43364 "fw_cyw43364.bin"
+#define FW_CYW43438 "fw_cyw43438.bin"
+#define FW_CYW43455 "fw_cyw43455.bin"
+#define FW_CYW4354 "fw_cyw4354.bin"
+
+#define NVRAM_CYW43364 "nvram_azw432.txt"
+#define NVRAM_CYW43438 "nvram_azw372.txt"
+#define NVRAM_CYW43455 "nvram_azw256.txt"
+#define NVRAM_CYW4354 "nvram_azw235.txt"
 
 bool dhd_update_fw_nv_path(dhd_info_t *dhdinfo)
 {
@@ -7154,10 +7787,7 @@ bool dhd_update_fw_nv_path(dhd_info_t *dhdinfo)
 	const char *fw = NULL;
 	const char *nv = NULL;
 	wifi_adapter_info_t *adapter = dhdinfo->adapter;
-#ifdef CONFIG_PLAT_ROCKCHIP
-	char firmware[100] = {0};
-	char nvram[100] = {0};
-#endif /* CONFIG_PLAT_ROCKCHIP */
+
 
 	/* Update firmware and nvram path. The path may be from adapter info or module parameter
 	 * The path from adapter info is used for initialization only (as it won't change).
@@ -7170,12 +7800,6 @@ bool dhd_update_fw_nv_path(dhd_info_t *dhdinfo)
 	 */
 
 	/* set default firmware and nvram path for built-in type driver */
-
-#ifdef CONFIG_PLAT_ROCKCHIP
-    rkwifi_set_firmware(firmware, nvram);
-    nv = nvram;
-    fw = firmware;
-#else /* CONFIG_PLAT_ROCKCHIP */
 	if (!dhd_download_fw_on_driverload) {
 #ifdef CONFIG_BCMDHD_FW_PATH
 		fw = CONFIG_BCMDHD_FW_PATH;
@@ -7184,7 +7808,6 @@ bool dhd_update_fw_nv_path(dhd_info_t *dhdinfo)
 		nv = CONFIG_BCMDHD_NVRAM_PATH;
 #endif /* CONFIG_BCMDHD_NVRAM_PATH */
 	}
-#endif /* CONFIG_PLAT_ROCKCHIP */
 
 	/* check if we need to initialize the path */
 	if (dhdinfo->fw_path[0] == '\0') {
@@ -7206,18 +7829,41 @@ bool dhd_update_fw_nv_path(dhd_info_t *dhdinfo)
 	if (nvram_path[0] != '\0')
 		nv = nvram_path;
 
-	if (cis_device == BCM43455_CHIP_ID) {
-		DHD_ERROR(("Adding 43455 firmware and NVRAM path by CIS\n"
+	if (cis_device == BCM43455_CHIP_ID && cis_chipvendor == 0x81) {
+		sprintf(fw_path, "%s%s", DEFAULT_BCMDHD_FW_PATH, FW_CYW43455);
+		sprintf(nv_path, "%s%s", DEFAULT_BCMDHD_NVRAM_PATH, NVRAM_CYW43455);
+		DHD_ERROR(("Adding CYW43455 firmware and NVRAM path by CIS\n"
+			"\tfirmware path: %s\n"
+			"\tNVRAM path:    %s\n", fw_path, nv_path));
+		
+		fw = fw_path;
+		nv = nv_path;
+	} else if (cis_device == BCM43430_CHIP_ID) {
+		if (cis_chipvendor == 0x81) {
+			sprintf(fw_path, "%s%s", DEFAULT_BCMDHD_FW_PATH, FW_CYW43438);
+			sprintf(nv_path, "%s%s", DEFAULT_BCMDHD_NVRAM_PATH, NVRAM_CYW43438);
+			DHD_ERROR(("Adding CYW43438 firmware and NVRAM path by CIS\n"
 			"\tfirmware path: %s\n"
-			"\tNVRAM path:    %s\n", cis_fw_43455_path, cis_nv_43455_path));
-		fw = cis_fw_43455_path;
-		nv = cis_nv_43455_path;
+			"\tNVRAM path:    %s\n", fw_path, nv_path));
+			fw = fw_path;
+			nv = nv_path;
+		} else {
+			sprintf(fw_path, "%s%s", DEFAULT_BCMDHD_FW_PATH, FW_CYW43364);
+			sprintf(nv_path, "%s%s", DEFAULT_BCMDHD_NVRAM_PATH, NVRAM_CYW43364);
+			DHD_ERROR(("Adding CYW43364 firmware and NVRAM path by CIS\n"
+			"\tfirmware path: %s\n"
+			"\tNVRAM path:    %s\n", fw_path, nv_path));
+			fw = fw_path;
+			nv = nv_path;
+		}
 	} else if (cis_device == BCM4354_CHIP_ID) {
+		sprintf(fw_path, "%s%s", DEFAULT_BCMDHD_FW_PATH, FW_CYW4354);
+		sprintf(nv_path, "%s%s", DEFAULT_BCMDHD_NVRAM_PATH, NVRAM_CYW4354);
 		DHD_ERROR(("Adding 4354 firmware and NVRAM path by CIS\n"
 			"\tfirmware path: %s\n"
-			"\tNVRAM path:    %s\n", cis_fw_4354_path, cis_nv_4354_path));
-		fw = cis_fw_4354_path;
-		nv = cis_nv_4354_path;
+			"\tNVRAM path:    %s\n", fw_path, nv_path));
+		fw = fw_path;
+		nv = nv_path;
 	}
 
 	if (fw && fw[0] != '\0') {
@@ -7276,7 +7922,7 @@ dhd_bus_start(dhd_pub_t *dhdp)
 
 	/* try to download image and nvram to the dongle */
 	if  (dhd->pub.busstate == DHD_BUS_DOWN && dhd_update_fw_nv_path(dhd)) {
-		DHD_ERROR(("%s download fw %s, nv %s\n", __FUNCTION__, dhd->fw_path, dhd->nv_path));
+		DHD_INFO(("%s download fw %s, nv %s\n", __FUNCTION__, dhd->fw_path, dhd->nv_path));
 		ret = dhd_bus_download_firmware(dhd->pub.bus, dhd->pub.osh,
 		                                dhd->fw_path, dhd->nv_path);
 		if (ret < 0) {
@@ -7407,6 +8053,7 @@ dhd_bus_start(dhd_pub_t *dhdp)
 	DHD_PERIM_UNLOCK(dhdp);
 	return 0;
 }
+#endif /* BCMDBUS */
 #ifdef WLTDLS
 int _dhd_tdls_enable(dhd_pub_t *dhd, bool tdls_on, bool auto_on, struct ether_addr *mac)
 {
@@ -7557,7 +8204,7 @@ void dhd_tdls_update_peer_info(struct net_device *dev, bool connect, uint8 *da)
 	}
 }
 #endif /* PCIE_FULL_DONGLE */
-#endif 
+#endif /* BCMDBUS */
 
 bool dhd_is_concurrent_mode(dhd_pub_t *dhd)
 {
@@ -7702,14 +8349,14 @@ dhd_preinit_ioctls(dhd_pub_t *dhd)
 	int32 amsdu_aggsf = 0;
 #endif
 
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 #ifdef PROP_TXSTATUS
 	int wlfc_enable = TRUE;
 #ifndef DISABLE_11N
 	uint32 hostreorder = 1;
 #endif /* DISABLE_11N */
 #endif /* PROP_TXSTATUS */
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #ifndef PCIE_FULL_DONGLE
 	uint32 wl_ap_isolate;
 #endif /* PCIE_FULL_DONGLE */
@@ -8089,12 +8736,10 @@ dhd_preinit_ioctls(dhd_pub_t *dhd)
 	}
 #endif /* defined(KEEP_ALIVE) */
 
-#if (0)
 	if ((ret = dhd_apply_default_clm(dhd, clm_path)) < 0) {
 		DHD_ERROR(("%s: CLM set failed. Abort initialization.\n", __FUNCTION__));
 		goto done;
 	}
-#endif
 
 #ifdef USE_WL_TXBF
 	if ((ret = dhd_iovar(dhd, 0, "txbf", (char *)&txbf, sizeof(txbf), NULL, 0, TRUE)) < 0) {
@@ -8397,7 +9042,7 @@ dhd_preinit_ioctls(dhd_pub_t *dhd)
 	dhd_txglom_enable(dhd, TRUE);
 #endif /* defined(BCMSDIO) */
 
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 #ifdef PROP_TXSTATUS
 	if (disable_proptx ||
 #ifdef PROP_TXSTATUS_VSDB
@@ -9045,7 +9690,16 @@ dhd_bus_detach(dhd_pub_t *dhdp)
 				dhd_prot_stop(&dhd->pub);
 
 				/* Stop the bus module */
+#ifdef BCMDBUS
+				/* Force Dongle terminated */
+				if (dhd_wl_ioctl_cmd(dhdp, WLC_TERMINATED, NULL, 0, TRUE, 0) < 0)
+					DHD_ERROR(("%s Setting WLC_TERMINATED failed\n",
+						__FUNCTION__));
+				dbus_stop(dhd->pub.dbus);
+				dhd->pub.busstate = DHD_BUS_DOWN;
+#else
 				dhd_bus_stop(dhd->pub.bus, TRUE);
+#endif /* BCMDBUS */
 			}
 
 #if defined(OOB_INTR_ONLY) || defined(BCMPCIE_OOB_HOST_WAKE)
@@ -9104,6 +9758,13 @@ void dhd_detach(dhd_pub_t *dhdp)
 #endif
 
 #if defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW)
+#if defined(BCMDBUS)
+	if (dhd->fw_download_task) {
+		up(&dhd->fw_download_lock);
+		kthread_stop(dhd->fw_download_task);
+		dhd->fw_download_task = NULL;
+	}
+#endif /* BCMDBUS */
 #endif /* defined(BCM_DNGL_EMBEDIMAGE) || defined(BCM_REQUEST_FW) */
 
 #ifdef PROP_TXSTATUS
@@ -9245,6 +9906,9 @@ void dhd_detach(dhd_pub_t *dhdp)
 	if (timer_valid)
 		del_timer_sync(&dhd->timer);
 
+#ifdef BCMDBUS
+	tasklet_kill(&dhd->tasklet);
+#else
 	if (dhd->dhd_state & DHD_ATTACH_STATE_THREADS_CREATED) {
 		if (dhd->thr_wdt_ctl.thr_pid >= 0) {
 			PROC_STOP(&dhd->thr_wdt_ctl);
@@ -9263,6 +9927,7 @@ void dhd_detach(dhd_pub_t *dhdp)
 #endif /* DHD_LB_RXP */
 		}
 	}
+#endif /* BCMDBUS */
 
 #if defined(DHD_LB)
 	/* Kill the Load Balancing Tasklets */
@@ -9274,9 +9939,15 @@ void dhd_detach(dhd_pub_t *dhdp)
 	tasklet_disable(&dhd->rx_compl_tasklet);
 	tasklet_kill(&dhd->rx_compl_tasklet);
 #endif /* DHD_LB_RXC */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0))
+	cpuhp_state_remove_instance(dhd_cpuhp_online_state, &dhd->node_online);
+	cpuhp_remove_multi_state(dhd_cpuhp_online_state);
+#else
 	if (dhd->cpu_notifier.notifier_call != NULL)
 		unregister_cpu_notifier(&dhd->cpu_notifier);
+#endif
 	dhd_cpumasks_deinit(dhd);
+
 #endif /* DHD_LB */
 
 #ifdef WL_CFG80211
@@ -9289,6 +9960,12 @@ void dhd_detach(dhd_pub_t *dhdp)
 	dhd_deferred_work_deinit(dhd->dhd_deferred_wq);
 	dhd->dhd_deferred_wq = NULL;
 
+#ifdef BCMDBUS
+	if (dhdp->dbus) {
+		dbus_detach(dhdp->dbus);
+		dhdp->dbus = NULL;
+	}
+#endif /* BCMDBUS */
 #ifdef SHOW_LOGTRACE
 	if (dhdp->dbg)
 		dhd_os_dbg_detach(dhdp);
@@ -9458,18 +10135,18 @@ dhd_module_cleanup(void)
 {
 	DHD_TRACE(("%s: Enter\n", __FUNCTION__));
 
+#ifdef BCMDBUS
+	dbus_deregister();
+#else
 	dhd_bus_unregister();
+#endif /* BCMDBUS */
 
 	wl_android_exit();
 
 	dhd_wifi_platform_unregister_drv();
 }
 
-#ifdef CONFIG_PLAT_ROCKCHIP
-static void 
-#else /* CONFIG_PLAT_ROCKCHIP */
 static void __exit
-#endif /* CONFIG_PLAT_ROCKCHIP */
 dhd_module_exit(void)
 {
 	dhd_buzzz_detach();
@@ -9477,11 +10154,7 @@ dhd_module_exit(void)
 	unregister_reboot_notifier(&dhd_reboot_notifier);
 }
 
-#ifdef CONFIG_PLAT_ROCKCHIP
-static int 
-#else /* CONFIG_PLAT_ROCKCHIP */
 static int __init
-#endif /* CONFIG_PLAT_ROCKCHIP */
 dhd_module_init(void)
 {
 	int err;
@@ -9549,6 +10222,121 @@ dhd_reboot_callback(struct notifier_block *this, unsigned long code, void *unuse
 	return NOTIFY_DONE;
 }
 
+#ifdef BCMDBUS
+
+/*
+ * hdrlen is space to reserve in pkt headroom for DBUS
+ */
+void *
+dhd_dbus_probe_cb(void *arg, const char *desc, uint32 bustype, uint32 hdrlen)
+{
+	osl_t *osh;
+	int ret = 0;
+	dbus_attrib_t attrib;
+	dhd_pub_t *pub = NULL;
+
+	DHD_TRACE(("%s: Enter\n", __FUNCTION__));
+
+	/* Ask the OS interface part for an OSL handle */
+	if (!(osh = osl_attach(NULL, bustype, TRUE))) {
+		DHD_ERROR(("%s: OSL attach failed\n", __FUNCTION__));
+		ret = -ENOMEM;
+		goto fail;
+	}
+
+	/* Attach to the dhd/OS interface */
+	if (!(pub = dhd_attach(osh, NULL /* bus */, hdrlen))) {
+		DHD_ERROR(("%s: dhd_attach failed\n", __FUNCTION__));
+		ret = -ENXIO;
+		goto fail;
+	}
+
+	/* Ok, finish the attach to the OS network interface */
+	if (dhd_register_if(pub, 0, TRUE) != 0) {
+		DHD_ERROR(("%s: dhd_register_if failed\n", __FUNCTION__));
+		ret = -ENXIO;
+		goto fail;
+	}
+
+	pub->dbus = dbus_attach(osh, pub->rxsz, DBUS_NRXQ, DBUS_NTXQ,
+		pub->info, &dhd_dbus_cbs, NULL, NULL);
+	if (pub->dbus) {
+		dbus_get_attrib(pub->dbus, &attrib);
+		DHD_ERROR(("DBUS: vid=0x%x pid=0x%x devid=0x%x bustype=0x%x mtu=%d\n",
+			attrib.vid, attrib.pid, attrib.devid, attrib.bustype, attrib.mtu));
+	} else {
+		ret = -ENXIO;
+		goto fail;
+	}
+#ifdef BCM_FD_AGGR
+	pub->info->rpc_th = bcm_rpc_tp_attach(osh, (void *)pub->dbus);
+	if (!pub->info->rpc_th) {
+		DHD_ERROR(("%s: bcm_rpc_tp_attach failed\n", __FUNCTION__));
+		ret = -ENXIO;
+		goto fail;
+	}
+
+	pub->info->rpc_osh = rpc_osl_attach(osh);
+	if (!pub->info->rpc_osh) {
+		DHD_ERROR(("%s: rpc_osl_attach failed\n", __FUNCTION__));
+		bcm_rpc_tp_detach(pub->info->rpc_th);
+		pub->info->rpc_th = NULL;
+		ret = -ENXIO;
+		goto fail;
+	}
+	/* Set up the aggregation release timer */
+	init_timer(&pub->info->rpcth_timer);
+	pub->info->rpcth_timer.data = (ulong)pub->info;
+	pub->info->rpcth_timer.function = dhd_rpcth_watchdog;
+	pub->info->rpcth_timer_active = FALSE;
+
+	bcm_rpc_tp_register_cb(pub->info->rpc_th, NULL, pub->info,
+		dbus_rpcth_rx_pkt, pub->info, pub->info->rpc_osh);
+#endif /* BCM_FD_AGGR */
+
+	/* This is passed to dhd_dbus_disconnect_cb */
+	return pub->info;
+fail:
+	/* Release resources in reverse order */
+	if (osh) {
+		if (pub) {
+			dhd_detach(pub);
+			dhd_free(pub);
+		}
+		osl_detach(osh);
+	}
+
+	BCM_REFERENCE(ret);
+	return NULL;
+}
+
+void
+dhd_dbus_disconnect_cb(void *arg)
+{
+	dhd_info_t *dhd = (dhd_info_t *)arg;
+	dhd_pub_t *pub;
+	osl_t *osh;
+
+	if (dhd == NULL)
+		return;
+
+	pub = &dhd->pub;
+	osh = pub->osh;
+#ifdef BCM_FD_AGGR
+	del_timer_sync(&dhd->rpcth_timer);
+	bcm_rpc_tp_deregister_cb(dhd->rpc_th);
+	rpc_osl_detach(dhd->rpc_osh);
+	bcm_rpc_tp_detach(dhd->rpc_th);
+#endif
+	dhd_detach(pub);
+	dhd_free(pub);
+
+	if (MALLOCED(osh)) {
+		DHD_ERROR(("%s: MEMORY LEAK %d bytes\n", __FUNCTION__, MALLOCED(osh)));
+	}
+	osl_detach(osh);
+}
+#endif /* BCMDBUS */
 
 #ifdef CONFIG_PLAT_ROCKCHIP
 #include <linux/rfkill-wlan.h>
@@ -9611,7 +10399,6 @@ void rockchip_wifi_exit_module_rkwifi(void)
     printk("=======================================================\n");
     dhd_module_exit();
 }
-
 #ifdef CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP
 late_initcall(rockchip_wifi_init_module_rkwifi);
 module_exit(rockchip_wifi_exit_module_rkwifi);
@@ -9619,7 +10406,6 @@ module_exit(rockchip_wifi_exit_module_rkwifi);
 EXPORT_SYMBOL(rockchip_wifi_init_module_rkwifi);
 EXPORT_SYMBOL(rockchip_wifi_exit_module_rkwifi);
 #endif /* CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP */
-
 #else /* CONFIG_PLAT_ROCKCHIP */
 
 #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 0)
@@ -9784,6 +10570,7 @@ dhd_os_busbusy_wake(dhd_pub_t *pub)
 void
 dhd_os_wd_timer_extend(void *bus, bool extend)
 {
+#ifndef BCMDBUS
 	dhd_pub_t *pub = bus;
 	dhd_info_t *dhd = (dhd_info_t *)pub->info;
 
@@ -9791,12 +10578,14 @@ dhd_os_wd_timer_extend(void *bus, bool extend)
 		dhd_os_wd_timer(bus, WATCHDOG_EXTEND_INTERVAL);
 	else
 		dhd_os_wd_timer(bus, dhd->default_wd_interval);
+#endif /* !BCMDBUS */
 }
 
 
 void
 dhd_os_wd_timer(void *bus, uint wdtick)
 {
+#ifndef BCMDBUS
 	dhd_pub_t *pub = bus;
 	dhd_info_t *dhd = (dhd_info_t *)pub->info;
 	unsigned long flags;
@@ -9831,6 +10620,7 @@ dhd_os_wd_timer(void *bus, uint wdtick)
 		dhd->wd_timer_valid = TRUE;
 	}
 	DHD_GENERAL_UNLOCK(pub, flags);
+#endif /* BCMDBUS */
 }
 
 void *
@@ -9856,11 +10646,20 @@ dhd_os_get_image_block(char *buf, int len, void *image)
 {
 	struct file *fp = (struct file *)image;
 	int rdlen;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+        loff_t pos = 0;
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0)) */
 
 	if (!image)
 		return 0;
 
-	rdlen = kernel_read(fp, fp->f_pos, buf, len);
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0))
+        rdlen = kernel_read(fp, fp->f_pos, buf, len);
+#else
+        pos = fp->f_pos;
+        rdlen = kernel_read(fp, buf, len, &pos);
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0)) */
+
 	if (rdlen > 0)
 		fp->f_pos += rdlen;
 
@@ -9881,10 +10680,14 @@ dhd_os_sdlock(dhd_pub_t *pub)
 
 	dhd = (dhd_info_t *)(pub->info);
 
+#ifndef BCMDBUS
 	if (dhd_dpc_prio >= 0)
 		down(&dhd->sdsem);
 	else
 		spin_lock_bh(&dhd->sdlock);
+#else
+	spin_lock_bh(&dhd->sdlock);
+#endif /* BCMDBUS */
 }
 
 void
@@ -9894,10 +10697,14 @@ dhd_os_sdunlock(dhd_pub_t *pub)
 
 	dhd = (dhd_info_t *)(pub->info);
 
+#ifndef BCMDBUS
 	if (dhd_dpc_prio >= 0)
 		up(&dhd->sdsem);
 	else
 		spin_unlock_bh(&dhd->sdlock);
+#else
+	spin_unlock_bh(&dhd->sdlock);
+#endif /* BCMDBUS */
 }
 
 void
@@ -9906,7 +10713,11 @@ dhd_os_sdlock_txq(dhd_pub_t *pub)
 	dhd_info_t *dhd;
 
 	dhd = (dhd_info_t *)(pub->info);
+#ifdef BCMDBUS
+	spin_lock_irqsave(&dhd->txqlock, dhd->txqlock_flags);
+#else
 	spin_lock_bh(&dhd->txqlock);
+#endif
 }
 
 void
@@ -9915,7 +10726,11 @@ dhd_os_sdunlock_txq(dhd_pub_t *pub)
 	dhd_info_t *dhd;
 
 	dhd = (dhd_info_t *)(pub->info);
+#ifdef BCMDBUS
+	spin_unlock_irqrestore(&dhd->txqlock, dhd->txqlock_flags);
+#else
 	spin_unlock_bh(&dhd->txqlock);
+#endif
 }
 
 void
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.h
index 72fc950ca1e2..e2b58be04cac 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD Linux header file (dhd_linux exports for cfg80211 and other components)
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_platdev.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_platdev.c
index 963117d82285..c92185bd225a 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_platdev.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_platdev.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux platform device for DHD WLAN adapter
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -42,6 +43,9 @@
 #if defined(CONFIG_WIFI_CONTROL_FUNC)
 #include <linux/wlan_plat.h>
 #endif
+#ifdef BCMDBUS
+#include <dbus.h>
+#endif
 #ifdef CONFIG_DTS
 #include<linux/regulator/consumer.h>
 #include<linux/of_gpio.h>
@@ -63,9 +67,9 @@ static bool is_power_on = FALSE;
 #if !defined(CONFIG_DTS)
 #if defined(DHD_OF_SUPPORT)
 static bool dts_enabled = TRUE;
-extern int dhd_wlan_init_plat_data(void);
 extern struct resource dhd_wlan_resources;
 extern struct wifi_platform_data dhd_wlan_control;
+extern int dhd_wlan_init_plat_data(void);
 #else
 static bool dts_enabled = FALSE;
 struct resource dhd_wlan_resources = {0};
@@ -195,6 +199,31 @@ int wifi_platform_set_power(wifi_adapter_info_t *adapter, bool on, unsigned long
 	return err;
 }
 
+#if defined(CUSTOMER_IMX)
+extern void wifi_card_detect(bool);
+int wifi_platform_bus_enumerate(wifi_adapter_info_t *adapter, bool device_present)
+{
+	int err = 0;
+	struct wifi_platform_data *plat_data;
+
+	if (!adapter) {
+		pr_err("!!!! %s: failed!  adapter variable is NULL!!!!!\n", __FUNCTION__);
+		return -EINVAL;
+	}
+
+	DHD_ERROR(("%s device present %d\n", __FUNCTION__, device_present));
+
+	if (!adapter->wifi_plat_data) {
+		wifi_card_detect(device_present); /* hook for card_detect */
+	} else {
+		plat_data = adapter->wifi_plat_data;
+		if (plat_data->set_carddetect)
+			err = plat_data->set_carddetect(device_present);
+	}
+
+	return 0; /* force success status returned */
+}
+#else
 int wifi_platform_bus_enumerate(wifi_adapter_info_t *adapter, bool device_present)
 {
 	int err = 0;
@@ -211,6 +240,7 @@ int wifi_platform_bus_enumerate(wifi_adapter_info_t *adapter, bool device_presen
 	return err;
 
 }
+#endif /* CUSTOMER_IMX */
 
 int wifi_platform_get_mac_addr(wifi_adapter_info_t *adapter, unsigned char *buf)
 {
@@ -457,10 +487,10 @@ static int wifi_ctrlfunc_register_drv(void)
 	if (dts_enabled) {
 		struct resource *resource;
 
-        wifi_plat_dev_probe_ret = dhd_wlan_init_plat_data();
+		wifi_plat_dev_probe_ret = dhd_wlan_init_plat_data();
 
-        if (wifi_plat_dev_probe_ret)
-            return wifi_plat_dev_probe_ret;
+		if (wifi_plat_dev_probe_ret)
+		    return wifi_plat_dev_probe_ret;
 
 		adapter->wifi_plat_data = (void *)&dhd_wlan_control;
 		resource = &dhd_wlan_resources;
@@ -802,16 +832,49 @@ static int dhd_wifi_platform_load_sdio(void)
 }
 #endif /* BCMSDIO */
 
+#ifdef BCMDBUS
+/* User-specified vid/pid */
+int dhd_vid = 0xa5c;
+int dhd_pid = 0x48f;
+module_param(dhd_vid, int, 0);
+module_param(dhd_pid, int, 0);
+void *dhd_dbus_probe_cb(void *arg, const char *desc, uint32 bustype, uint32 hdrlen);
+void dhd_dbus_disconnect_cb(void *arg);
+
+static int dhd_wifi_platform_load_usb(void)
+{
+	int err = 0;
+
+	if (dhd_vid < 0 || dhd_vid > 0xffff) {
+		DHD_ERROR(("%s: invalid dhd_vid 0x%x\n", __FUNCTION__, dhd_vid));
+		return -EINVAL;
+	}
+	if (dhd_pid < 0 || dhd_pid > 0xffff) {
+		DHD_ERROR(("%s: invalid dhd_pid 0x%x\n", __FUNCTION__, dhd_pid));
+		return -EINVAL;
+	}
+
+	err = dbus_register(dhd_vid, dhd_pid, dhd_dbus_probe_cb, dhd_dbus_disconnect_cb,
+		NULL, NULL, NULL);
+
+	/* Device not detected */
+	if (err == DBUS_ERR_NODEVICE)
+		err = DBUS_OK;
+
+	return err;
+}
+#else /* BCMDBUS */
 static int dhd_wifi_platform_load_usb(void)
 {
 	return 0;
 }
+#endif /* BCMDBUS */
 
 static int dhd_wifi_platform_load()
 {
 	int err = 0;
 
-	wl_android_init();
+		wl_android_init();
 
 	if ((err = dhd_wifi_platform_load_usb()))
 		goto end;
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_sched.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_sched.c
index 88c0cce635bd..1a2cd59fee21 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_sched.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_sched.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Expose some of the kernel scheduler routines
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.c
index abbfe48f88f3..2097a9ac58ba 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD), Generic work queue framework
  * Generic interface to handle dhd deferred work events
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.h
index 37f633b09123..69f7969f4974 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_linux_wq.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD), Generic work queue framework
  * Generic interface to handle dhd deferred work events
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_msgbuf.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_msgbuf.c
index 53354c3697e3..267aba474e47 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_msgbuf.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_msgbuf.c
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /**
  * @file definition of host message ring functionality
  * Provides type definitions and function prototypes used to link the
  * DHD OS, bus, and protocol modules.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -41,7 +42,11 @@
 #include <dhd.h>
 #include <dhd_proto.h>
 
+#ifdef BCMDBUS
+#include <dbus.h>
+#else
 #include <dhd_bus.h>
+#endif /* BCMDBUS */
 
 #include <dhd_dbg.h>
 #include <siutils.h>
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.c
index 9b501c3f3d62..b04467dd871a 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD Bus Module for PCIE
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.h
index 4bad18a86393..807122967d29 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux DHD Bus Module for PCIE
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie_linux.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie_linux.c
index 2bddc3cd50c3..75efb1694850 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pcie_linux.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux DHD Bus Module for PCIE
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.c
index 324036429783..9d8ae2f83fd3 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD)
  * Prefered Network Offload and Wi-Fi Location Service(WLS) code.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.h
index d3a5e3a2c366..db49bdc9208b 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_pno.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Header file of Broadcom Dongle Host Driver (DHD)
  * Prefered Network Offload code and Wi-Fi Location Service(WLS) code.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_proto.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_proto.h
index 6221b6e696dd..2d790789ef80 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_proto.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_proto.h
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Header file describing the internal (inter-module) DHD interfaces.
  *
  * Provides type definitions and function prototypes used to link the
  * DHD OS, bus, and protocol modules.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.c
index 21ea0d01b520..f181be539d00 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD), RTT
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.h
index 6d2c375a8858..8ac9be8bd9b5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_rtt.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD), RTT
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c
index fb6988b4c6f2..011ffc493521 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_sdio.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD Bus Module for SDIO
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: dhd_sdio.c 674349 2017-10-19 07:59:24Z $
+ * $Id: dhd_sdio.c 708487 2018-10-31 05:33:14Z $
  */
 
 #include <typedefs.h>
@@ -67,6 +68,10 @@
 #include <dhdioctl.h>
 #include <sdiovar.h>
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+#include <dhd_chip_info.h>
+#endif
+
 #ifdef PROP_TXSTATUS
 #include <dhd_wlfc.h>
 #endif
@@ -1542,7 +1547,7 @@ dhdsdio_bussleep(dhd_bus_t *bus, bool sleep)
 
 		/* Change state */
 		bus->sleeping = TRUE;
-#if defined(SUPPORT_P2P_GO_PS)  || defined(SUSPEND16)
+#if defined(SUPPORT_P2P_GO_PS) || defined(SUSPEND16)
 		wake_up(&bus->bus_sleep);
 #endif /* LINUX && SUPPORT_P2P_GO_PS */
 	} else {
@@ -6018,16 +6023,12 @@ dhdsdio_isr(void *arg)
 	bcmsdh_intr_disable(sdh);
 	bus->intdis = TRUE;
 
-#if defined(SDIO_ISR_THREAD)
-	DHD_TRACE(("Calling dhdsdio_dpc() from %s\n", __FUNCTION__));
 	DHD_OS_WAKE_LOCK(bus->dhd);
-	dhdsdio_dpc(bus);
+	if (dhdsdio_dpc(bus)) {
+		bus->dpc_sched = TRUE;
+		dhd_sched_dpc(bus->dhd);
+	}
 	DHD_OS_WAKE_UNLOCK(bus->dhd);
-#else
-	bus->dpc_sched = TRUE;
-	dhd_sched_dpc(bus->dhd);
-
-#endif /* defined(SDIO_ISR_THREAD) */
 
 }
 
@@ -6046,6 +6047,9 @@ dhdsdio_dpc(dhd_bus_t *bus)
 	unsigned long flags;
 	DHD_TRACE(("%s: Enter\n", __FUNCTION__));
 
+	if (in_irq())
+		return TRUE;
+
 	dhd_os_sdlock(bus->dhd);
 	DHD_GENERAL_LOCK(bus->dhd, flags);
 	if (bus->dhd->busstate == DHD_BUS_DOWN) {
@@ -7272,14 +7276,19 @@ dhdsdio_probe_attach(struct dhd_bus *bus, osl_t *osh, void *sdh, void *regsva,
 
 
 
-	bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR, DHD_INIT_CLKCTL1, &err);
-	if (!err)
-		clkctl = bcmsdh_cfg_read(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR, &err);
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	if(alive != FW_ALIVE_MAGIC)
+#endif
+	{
+		bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR, DHD_INIT_CLKCTL1, &err);
+		if (!err)
+			clkctl = bcmsdh_cfg_read(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR, &err);
 
-	if (err || ((clkctl & ~SBSDIO_AVBITS) != DHD_INIT_CLKCTL1)) {
-		DHD_ERROR(("dhdsdio_probe: ChipClkCSR access: err %d wrote 0x%02x read 0x%02x\n",
-		           err, DHD_INIT_CLKCTL1, clkctl));
-		goto fail;
+		if (err || ((clkctl & ~SBSDIO_AVBITS) != DHD_INIT_CLKCTL1)) {
+			DHD_ERROR(("dhdsdio_probe: ChipClkCSR access: err %d wrote 0x%02x read 0x%02x\n",
+				   err, DHD_INIT_CLKCTL1, clkctl));
+			goto fail;
+		}
 	}
 
 #ifdef DHD_DEBUG
@@ -7340,6 +7349,11 @@ dhdsdio_probe_attach(struct dhd_bus *bus, osl_t *osh, void *sdh, void *regsva,
 		bus->sih->socitype, bus->sih->chip, bus->sih->chiprev, bus->sih->chippkg));
 #endif /* DHD_DEBUG */
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	card_dev = bus->sih->chip;
+	card_rev = bus->sih->chiprev;
+#endif
+
 
 	bcmsdh_chipinfo(sdh, bus->sih->chip, bus->sih->chiprev);
 
@@ -7628,7 +7642,16 @@ dhdsdio_download_firmware(struct dhd_bus *bus, osl_t *osh, void *sdh)
 	/* Download the firmware */
 	dhdsdio_clkctl(bus, CLK_AVAIL, FALSE);
 
-	ret = _dhdsdio_download_firmware(bus);
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	if(alive == FW_ALIVE_MAGIC) {
+		ret = 0;
+		bus->alp_only = FALSE;
+		bus->dhd->busstate = DHD_BUS_LOAD;
+		DHD_ERROR(("skip download FW and nv\n"));
+	}
+	else
+#endif
+		ret = _dhdsdio_download_firmware(bus);
 
 	dhdsdio_clkctl(bus, CLK_SDONLY, FALSE);
 
@@ -7808,7 +7831,7 @@ dhdsdio_suspend(void *context)
 #endif /* SUPPORT_P2P_GO_PS */
 	ret = dhd_os_check_wakelock(bus->dhd);
 #if defined(SUPPORT_P2P_GO_PS) || defined(SUSPEND16)
-	if (SLPAUTO_ENAB(bus) && (!ret) && (bus->dhd->up) && (bus->dhd->op_mode != DHD_FLAG_HOSTAP_MODE)) {
+	if ((ret) && (bus->dhd->up) && (bus->dhd->op_mode != DHD_FLAG_HOSTAP_MODE)) {
 		if (wait_event_timeout(bus->bus_sleep, bus->sleeping, wait_time) == 0) {
 			if (!bus->sleeping) {
 				return 1;
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.c
index 10652361a6f2..0a2f6dc69712 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * DHD PROP_TXSTATUS Module.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -38,7 +39,12 @@
 #include <dngl_stats.h>
 #include <dhd.h>
 
+#ifdef BCMDBUS /* an abstraction layer that hides details of the underlying bus, eg \
+	Linux USB */
+#include <dbus.h>
+#else
 #include <dhd_bus.h>
+#endif /* BCMDBUS */
 
 #include <dhd_dbg.h>
 
@@ -66,6 +72,9 @@
 #define WLFC_THREAD_RETRY_WAIT_MS          10000   /* 10 sec */
 #endif /* defined (DHD_WLFC_THREAD) */
 
+#if defined(BCMDBUS)
+extern int dhd_dbus_txdata(dhd_pub_t *dhdp, void *pktbuf);
+#endif
 
 #ifdef PROP_TXSTATUS
 
@@ -997,6 +1006,8 @@ _dhd_wlfc_send_signalonly_packet(athost_wl_status_info_t* ctx, wlfc_mac_descript
 
 #if defined(BCMPCIE)
 		rc = dhd_bus_txdata(dhdp->bus, p, ctx->host_ifidx);
+#elif defined(BCMDBUS)
+		rc = dhd_dbus_txdata(dhdp, p);
 #else
 		rc = dhd_bus_txdata(dhdp->bus, p);
 #endif
@@ -1617,6 +1628,7 @@ _dhd_wlfc_pktq_flush(athost_wl_status_info_t* ctx, struct pktq *pq,
 		ASSERT(pq->len == 0);
 } /* _dhd_wlfc_pktq_flush */
 
+#ifndef BCMDBUS
 
 /** !BCMDBUS specific function. Dequeues a packet from the caller supplied queue. */
 static void*
@@ -1724,6 +1736,8 @@ _dhd_wlfc_cleanup_txq(dhd_pub_t *dhd, f_processpkt_t fn, void *arg)
 	}
 } /* _dhd_wlfc_cleanup_txq */
 
+#endif /* !BCMDBUS */
+
 /** called during eg detach */
 void
 _dhd_wlfc_cleanup(dhd_pub_t *dhd, f_processpkt_t fn, void *arg)
@@ -1741,8 +1755,10 @@ _dhd_wlfc_cleanup(dhd_pub_t *dhd, f_processpkt_t fn, void *arg)
 	/*
 	*  flush sequence should be txq -> psq -> hanger/afq, hanger has to be last one
 	*/
+#ifndef BCMDBUS
 	/* flush bus->txq */
 	_dhd_wlfc_cleanup_txq(dhd, fn, arg);
+#endif /* BCMDBUS */
 
 	/* flush psq, search all entries, include nodes as well as interfaces */
 	total_entries = sizeof(wlfc->destination_entries)/sizeof(wlfc_mac_descriptor_t);
@@ -2464,6 +2480,7 @@ _dhd_wlfc_fifocreditback_indicate(dhd_pub_t *dhd, uint8* credits)
 	return BCME_OK;
 } /* _dhd_wlfc_fifocreditback_indicate */
 
+#ifndef BCMDBUS
 
 /** !BCMDBUS specific function */
 static void
@@ -2541,6 +2558,8 @@ _dhd_wlfc_suppress_txq(dhd_pub_t *dhd, f_processpkt_t fn, void *arg)
 	}
 } /* _dhd_wlfc_suppress_txq */
 
+#endif /* !BCMDBUS */
+
 static int
 _dhd_wlfc_dbg_senum_check(dhd_pub_t *dhd, uint8 *value)
 {
@@ -3063,10 +3082,12 @@ dhd_wlfc_parse_header_info(dhd_pub_t *dhd, void* pktbuf, int tlv_hdr_len, uchar
 				_dhd_wlfc_interface_update(dhd, value, type);
 			}
 
+#ifndef BCMDBUS
 			if (entry && WLFC_GET_REORDERSUPP(dhd->wlfc_mode)) {
 				/* suppress all packets for this mac entry from bus->txq */
 				_dhd_wlfc_suppress_txq(dhd, _dhd_wlfc_entrypkt_fn, entry);
 			}
+#endif /* !BCMDBUS */
 		} /* while */
 
 		if (remainder != 0 && wlfc) {
@@ -3394,6 +3415,15 @@ dhd_wlfc_commit_packets(dhd_pub_t *dhdp, f_commitpkt_t fcommit, void* commit_ctx
 
 	ctx = (athost_wl_status_info_t*)dhdp->wlfc_state;
 
+#ifdef BCMDBUS
+	if (!dhdp->up || (dhdp->busstate == DHD_BUS_DOWN)) {
+		if (pktbuf) {
+			PKTFREE(ctx->osh, pktbuf, TRUE);
+			rc = BCME_OK;
+		}
+		goto exit;
+	}
+#endif
 
 	if (dhdp->proptxstatus_module_ignore) {
 		if (pktbuf) {
@@ -3580,10 +3610,17 @@ dhd_wlfc_init(dhd_pub_t *dhd)
 		DHD_INFO(("%s: query wlfc_mode succeed, fw_caps=0x%x\n", __FUNCTION__, fw_caps));
 
 		if (WLFC_IS_OLD_DEF(fw_caps)) {
+#ifdef BCMDBUS
+			mode = WLFC_MODE_HANGER;
+#else
 			/* enable proptxtstatus v2 by default */
 			mode = WLFC_MODE_AFQ;
+#endif /* BCMDBUS */
 		} else {
 			WLFC_SET_AFQ(mode, WLFC_GET_AFQ(fw_caps));
+#ifdef BCMDBUS
+			WLFC_SET_AFQ(mode, 0);
+#endif /* BCMDBUS */
 			WLFC_SET_REUSESEQ(mode, WLFC_GET_REUSESEQ(fw_caps));
 			WLFC_SET_REORDERSUPP(mode, WLFC_GET_REORDERSUPP(fw_caps));
 		}
@@ -3664,7 +3701,9 @@ dhd_wlfc_cleanup_txq(dhd_pub_t *dhd, f_processpkt_t fn, void *arg)
 		return WLFC_UNSUPPORTED;
 	}
 
+#ifndef BCMDBUS
 	_dhd_wlfc_cleanup_txq(dhd, fn, arg);
+#endif /* !BCMDBUS */
 
 	dhd_os_wlfc_unblock(dhd);
 
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.h
index f95969c0bc95..ba0a0719975e 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dhd_wlfc.h
@@ -1,5 +1,6 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -111,8 +112,13 @@ typedef struct wlfc_hanger {
 
 #define WLFC_PSQ_LEN			2048
 
+#ifdef BCMDBUS
+#define WLFC_FLOWCONTROL_HIWATER	512
+#define WLFC_FLOWCONTROL_LOWATER	(WLFC_FLOWCONTROL_HIWATER / 4)
+#else
 #define WLFC_FLOWCONTROL_HIWATER	(2048 - 256)
 #define WLFC_FLOWCONTROL_LOWATER	256
+#endif
 
 #if (WLFC_FLOWCONTROL_HIWATER >= (WLFC_PSQ_LEN - 256))
 #undef WLFC_FLOWCONTROL_HIWATER
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_stats.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_stats.h
index dd6338724a1d..87ecd97e34ac 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_stats.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_stats.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Common stats definitions for clients of dongle
  * ports
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_wlhdr.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_wlhdr.h
index 96da42e5f570..85f3d188fe24 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_wlhdr.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/dngl_wlhdr.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Dongle WL Header definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktpool.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktpool.c
index 5b0da6114f19..0d0ae1c83bf0 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktpool.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktpool.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND generic packet pool operation primitives
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktq.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktq.c
index 8bc636e00c2f..12505e80da98 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktq.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hnd_pktq.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND generic pktq operation primitives
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hndpmu.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hndpmu.c
index 25018874abe4..920930d2b573 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hndpmu.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/hndpmu.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines for accessing PMU corerev specific features
  * of the SiliconBackplane-based Broadcom chips.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/aidmp.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/aidmp.h
index bd49c982691f..9088b5725ea8 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/aidmp.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/aidmp.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom AMBA Interconnect definitions.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_cfg.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_cfg.h
index 12e3cb2ca27a..1afc6f67d575 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_cfg.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_cfg.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BCM common config options
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_mpool_pub.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_mpool_pub.h
index 1e9a3ced5a9e..e046b6bc26e3 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_mpool_pub.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_mpool_pub.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Memory pools library, Public interface
  *
@@ -35,7 +36,7 @@
  *              and instrumentation on top of the heap, without modifying the heap
  *              allocation implementation.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_ring.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_ring.h
index 72dfc4290086..1a529fc0355c 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_ring.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcm_ring.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 #ifndef __bcm_ring_included__
 #define __bcm_ring_included__
 
@@ -81,7 +82,7 @@
  * private L1 data cache.
  * +----------------------------------------------------------------------------
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmcdc.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmcdc.h
index a7d3d4af6e39..a5caaedd70fb 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmcdc.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmcdc.h
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * CDC network driver ioctl/indication encoding
  * Broadcom 802.11abg Networking Device Driver
  *
  * Definitions subject to change without notice.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdefs.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdefs.h
index 125a28e0371f..f380a5cb7bbc 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdefs.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdefs.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc system wide definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdevs.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdevs.h
index 9d0823a83d9e..d8f1effba7d8 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdevs.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmdevs.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom device-specific manifest constants.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: bcmdevs.h 596448 2015-11-01 13:29:01Z $
+ * $Id: bcmdevs.h 708808 2018-11-27 03:12:35Z $
  */
 
 #ifndef	_BCMDEVS_H
@@ -55,6 +56,7 @@
 #define	VENDOR_BROADCOM_SDIO	0x00BF
 
 /* DONGLE VID/PIDs */
+#define CY_DNGL_VID             0x04b4
 #define BCM_DNGL_VID		0x0a5c
 #define BCM_DNGL_BL_PID_4328	0xbd12
 #define BCM_DNGL_BL_PID_4322	0xbd13
@@ -77,6 +79,7 @@
 #define BCM_DNGL_BL_PID_4354	0xbd26
 #define BCM_DNGL_BL_PID_43569   0xbd27
 #define BCM_DNGL_BL_PID_43909	0xbd28
+#define BCM_DNGL_BL_PID_4373    0xbd29
 
 #define BCM_DNGL_BDC_PID	0x0bdc
 #define BCM_DNGL_JTAG_PID	0x4a44
@@ -275,6 +278,10 @@
 #define BCM4356_D11AC2G_ID	0x43ed		/* 4356 802.11ac 2.4G device */
 #define BCM4356_D11AC5G_ID	0x43ee		/* 4356 802.11ac 5G device */
 
+#define BCM4373_D11AC_ID	0x4418		/* 4373 802.11ac dualband device */
+#define BCM4373_D11AC2G_ID	0x4419		/* 4373 802.11ac 2.4G device */
+#define BCM4373_D11AC5G_ID	0x441a		/* 4373 802.11ac 5G device */
+
 #define	BCMGPRS_UART_ID		0x4333		/* Uart id used by 4306/gprs card */
 #define	BCMGPRS2_UART_ID	0x4344		/* Uart id used by 4306/gprs card */
 #define FPGA_JTAGM_ID		0x43f0		/* FPGA jtagm device id */
@@ -313,6 +320,7 @@
 #define	BCM4716_DEVICE_ID	0x4722		/* 4716 base devid */
 #define	BCM47XX_USB30H_ID	0x472a		/* 47xx usb 3.0 host */
 #define	BCM47XX_USB30D_ID	0x472b		/* 47xx usb 3.0 device */
+#define BCM47XX_USBHUB_ID	0x472c		/* 47xx usb hub */
 #define BCM47XX_SMBUS_EMU_ID	0x47fe		/* 47xx emulated SMBus device */
 #define	BCM47XX_XOR_EMU_ID	0x47ff		/* 47xx emulated XOR engine */
 #define	EPI41210_DEVICE_ID	0xa0fa		/* bcm4210 */
@@ -479,6 +487,7 @@
 #define BCM53573_CHIP(chipid)	(CHIPID(chipid) == BCM53573_CHIP_ID)
 #define BCM53573_CHIP_GRPID	BCM53573_CHIP_ID
 #define	BCM43012_CHIP_ID	0xA804		/* 43012 chipcommon chipid */
+#define BCM4373_CHIP_ID		0x4373		/* 4373 chipcommon chipid */
 
 /* Package IDs */
 #define	BCM4303_PKG_ID		2		/* 4303 package id */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmendian.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmendian.h
index 00adedf1cd97..22d48432f0a9 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmendian.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmendian.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Byte order utilities
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmmsgbuf.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmmsgbuf.h
index ca0bb21483db..286d3e996c0c 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmmsgbuf.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmmsgbuf.h
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * MSGBUF network driver ioctl/indication encoding
  * Broadcom 802.11abg Networking Device Driver
  *
  * Definitions subject to change without notice.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmnvram.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmnvram.h
index 7f6c51be3e04..8561dec7b299 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmnvram.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmnvram.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * NVRAM variable manipulation
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcie.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcie.h
index cd97c7267c81..9d1e6e4a1550 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcie.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcie.h
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom PCIE
  * Software-specific definitions shared between device and host side
  * Explains the shared area between host and dongle
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcispi.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcispi.h
index b3502ea7b884..6935c1d60eb5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcispi.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmpcispi.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom PCI-SPI Host Controller Register Definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmperf.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmperf.h
index 09e607fc9b74..f88d1eccaddc 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmperf.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmperf.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Performance counters software interface.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdbus.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdbus.h
index 88635f1eaec2..1503583cadef 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdbus.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdbus.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Definitions for API from sdio common code (bcmsdh) to individual
  * host controller drivers.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh.h
index 2717a9097d0d..22b62ba5175c 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh.h
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SDIO host client driver interface of Broadcom HNBU
  *     export functions to client drivers
  *     abstract OS and BUS specific details of SDIO
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh_sdmmc.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh_sdmmc.h
index b706289b0e85..aef85f2f17c2 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh_sdmmc.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdh_sdmmc.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BCMSDH Function Driver for the native SDIO/MMC driver in the Linux Kernel
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -30,12 +31,12 @@
 #ifndef __BCMSDH_SDMMC_H__
 #define __BCMSDH_SDMMC_H__
 
-#define sd_err(x)	do { if (sd_msglevel & SDH_ERROR_VAL) printf x; } while (0)
-#define sd_trace(x)	do { if (sd_msglevel & SDH_TRACE_VAL) printf x; } while (0)
-#define sd_info(x)	do { if (sd_msglevel & SDH_INFO_VAL) printf x; } while (0)
-#define sd_debug(x)	do { if (sd_msglevel & SDH_DEBUG_VAL) printf x; } while (0)
-#define sd_data(x)	do { if (sd_msglevel & SDH_DATA_VAL) printf x; } while (0)
-#define sd_ctrl(x)	do { if (sd_msglevel & SDH_CTRL_VAL) printf x; } while (0)
+#define sd_err(x)
+#define sd_trace(x)
+#define sd_info(x)
+#define sd_debug(x)
+#define sd_data(x)
+#define sd_ctrl(x)
 
 
 #define sd_sync_dma(sd, read, nbytes)
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdpcm.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdpcm.h
index 78f212ad80f8..4a10112b73c2 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdpcm.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdpcm.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom SDIO/PCMCIA
  * Software-specific definitions shared between device and host side
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdspi.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdspi.h
index 537876c3696d..0abf7dc18907 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdspi.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdspi.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SD-SPI Protocol Conversion - BCMSDH->SPI Translation Layer
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdstd.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdstd.h
index ff3b0d1f2750..33c0d4198d80 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdstd.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsdstd.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  *  'Standard' SDIO HOST CONTROLLER driver
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspi.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspi.h
index 9b4bd2d8ac0d..3e26e55930ea 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspi.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspi.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom SPI Low-Level Hardware Driver API
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspibrcm.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspibrcm.h
index e9735ffc621a..20f1ba07326f 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspibrcm.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmspibrcm.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SD-SPI Protocol Conversion - BCMSDH->gSPI Translation Layer
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_fmt.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_fmt.h
index 2eabfaf62709..0a56962ebf10 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_fmt.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_fmt.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SROM format definition.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_tbl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_tbl.h
index acc9b91c98da..4b692d5f9512 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_tbl.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmsrom_tbl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Table that encodes the srom formats for PCI/PCIe NICs.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmutils.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmutils.h
index 0a0bff823654..24b2eac107ca 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmutils.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/bcmutils.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc useful os-independent macros and functions.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: bcmutils.h 569587 2015-07-08 16:41:50Z $
+ * $Id: bcmutils.h 696078 2018-08-15 09:24:11Z $
  */
 
 #ifndef	_bcmutils_h_
@@ -1111,6 +1112,7 @@ extern void bcm_uint64_right_shift(uint32* r, uint32 a_high, uint32 a_low, uint3
 
 void bcm_add_64(uint32* r_hi, uint32* r_lo, uint32 offset);
 void bcm_sub_64(uint32* r_hi, uint32* r_lo, uint32 offset);
+uint16 ipv4_hdr_cksum(uint8 *ip, int ip_len);
 
 /* calculate checksum for ip header, tcp / udp header / data */
 uint16 bcm_ip_cksum(uint8 *buf, uint32 len, uint32 sum);
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/brcm_nl80211.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/brcm_nl80211.h
index 43d66609a3a7..e2ddf228defb 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/brcm_nl80211.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/brcm_nl80211.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Definitions for nl80211 vendor command/event access to host driver
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dbus.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dbus.h
index e14405dce088..ca26a5ceea2a 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dbus.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dbus.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Dongle BUS interface Abstraction layer
  *   target serial buses like USB, SDIO, SPI, etc.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/devctrl_if/wlioctl_defs.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/devctrl_if/wlioctl_defs.h
index 7a54625a1daf..398ebc0e8440 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/devctrl_if/wlioctl_defs.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/devctrl_if/wlioctl_defs.h
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Custom OID/ioctl definitions for
  * Broadcom 802.11abg Networking Device Driver
  *
  * Definitions subject to change without notice.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dhdioctl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dhdioctl.h
index 71221f2b600e..34a8f2b5afb4 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dhdioctl.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/dhdioctl.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Definitions for ioctls to access DHD iovars.
  * Based on wlioctl.h (for Broadcom 802.11abg driver).
@@ -5,7 +6,7 @@
  *
  * Definitions subject to change without notice.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/epivers.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/epivers.h
index b7bf8e12e4f5..3b4af47d3eae 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/epivers.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/epivers.h
@@ -1,5 +1,6 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -35,17 +36,17 @@
 
 #define	EPI_RC_NUMBER		125
 
-#define	EPI_INCREMENTAL_NUMBER	7
+#define	EPI_INCREMENTAL_NUMBER	15
 
 #define	EPI_BUILD_NUMBER	0
 
-#define	EPI_VERSION		1, 363, 125, 7
+#define	EPI_VERSION		1, 363, 125, 15
 
 #define	EPI_VERSION_NUM		0x0116b7d0
 
 #define EPI_VERSION_DEV		1.363.125
 
 /* Driver Version String, ASCII, 32 chars max */
-#define	EPI_VERSION_STR		"1.363.125.7 (r)"
+#define	EPI_VERSION_STR		"1.363.125.15 (r)"
 
 #endif /* _epivers_h_ */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_log.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_log.h
index 7d9ee636e2cf..ef6cfa302180 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_log.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_log.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * EVENT_LOG system definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_trace.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_trace.h
index 3907503e1d9d..46f7e61e86f6 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_trace.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/event_trace.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Trace log blocks sent over HBUS
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_armtrap.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_armtrap.h
index e9ee8ff47581..ba755d9cccdf 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_armtrap.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_armtrap.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND arm trap handling.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_cons.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_cons.h
index 7b2b90a67cc4..415976e2f3c0 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_cons.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_cons.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Console support for RTE - for host use only.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_debug.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_debug.h
index 113ec10058cf..a5b3520e41fc 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_debug.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_debug.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND Run Time Environment debug info area
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktpool.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktpool.h
index 8c3a76143278..e414bed3188c 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktpool.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktpool.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND generic packet pool operation primitives
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktq.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktq.h
index f555100e7ed4..c129bc9057db 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktq.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hnd_pktq.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND generic pktq operation primitives
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndpmu.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndpmu.h
index d9c2774a121d..8975e2d638ea 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndpmu.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndpmu.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND SiliconBackplane PMU support.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndsoc.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndsoc.h
index aa32105d2b12..cd3904cf4525 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndsoc.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/hndsoc.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom HND chip & on-chip-interconnect-related definitions.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linux_osl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linux_osl.h
index 9c19f765de6a..40c3f041554a 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linux_osl.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linux_osl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux OS Independent Layer
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -481,8 +482,9 @@ extern int osl_error(int bcmerror);
 #define PKTSETID(skb, id)       ({BCM_REFERENCE(skb); BCM_REFERENCE(id);})
 #define PKTSHRINK(osh, m)		({BCM_REFERENCE(osh); m;})
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)) && defined(TSQ_MULTIPLIER)
-#define PKTORPHAN(skb)          osl_pkt_orphan_partial(skb)
-extern void osl_pkt_orphan_partial(struct sk_buff *skb);
+//#define PKTORPHAN(skb)          osl_pkt_orphan_partial(skb)
+//extern void osl_pkt_orphan_partial(struct sk_buff *skb);
+#define PKTORPHAN(skb)          skb_orphan(skb)
 #else
 #define PKTORPHAN(skb)          ({BCM_REFERENCE(skb); 0;})
 #endif /* LINUX VERSION >= 3.6 */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linuxver.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linuxver.h
index feaeed425ee2..7747c78a8dcf 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linuxver.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/linuxver.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux-specific abstractions to gain some independence from linux kernel versions.
  * Pave over some 2.2 versus 2.4 versus 2.6 kernel differences.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -39,6 +40,9 @@
 
 #include <typedefs.h>
 #include <linux/version.h>
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
+#include <linux/sched/signal.h>
+#endif
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 0))
 #include <linux/config.h>
 #else
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/miniopt.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/miniopt.h
index 6722351436e3..b7c9fdfe3b97 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/miniopt.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/miniopt.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Command line options parser.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/msgtrace.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/msgtrace.h
index 00e2b0f46bf8..03d8fb1ed5b4 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/msgtrace.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/msgtrace.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Trace messages sent over HBUS
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl.h
index e18dde27c0bc..371b81323c4a 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * OS Abstraction Layer
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_decl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_decl.h
index 3c147ef2c921..b74551dc9b9c 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_decl.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_decl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * osl forward declarations
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_ext.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_ext.h
index 13d59b6a2f1f..da2fb87370a7 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_ext.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/osl_ext.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * OS Abstraction Layer Extension - the APIs defined by the "extension" API
  * are only supported by a subset of all operating systems.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_end.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_end.h
index 4827c709af26..175fae15fae5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_end.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_end.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Declare directives for structure packing. No padding will be provided
  * between the members of packed structures, and therefore, there is no
@@ -15,7 +16,7 @@
  * #include <packed_section_end.h>
  *
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_start.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_start.h
index 9beb45d5e082..57e159a76fce 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_start.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/packed_section_start.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Declare directives for structure packing. No padding will be provided
  * between the members of packed structures, and therefore, there is no
@@ -15,7 +16,7 @@
  * #include <packed_section_end.h>
  *
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcicfg.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcicfg.h
index e4672031240f..35eda1b62b46 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcicfg.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcicfg.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * pcicfg.h: PCI configuration constants and structures.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcie_core.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcie_core.h
index 5ea5d7569dd8..a961dbfbf6d6 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcie_core.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/pcie_core.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BCM43XX PCIE core hardware definitions.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11.h
index ca8684b0fecc..fee41c5fcee7 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental types and constants relating to 802.11
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11_bta.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11_bta.h
index 981acd896860..da8b9db820d7 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11_bta.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11_bta.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BT-AMP (BlueTooth Alternate Mac and Phy) 802.11 PAL (Protocol Adaptation Layer)
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11e.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11e.h
index c0ad8e452b82..cac1071a2708 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11e.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.11e.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * 802.11e protocol header file
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.1d.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.1d.h
index 85fd7e4a2fae..79f5545b6773 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.1d.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.1d.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental types and constants relating to 802.1D
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.3.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.3.h
index d834cb741f39..57a90f37b684 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.3.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/802.3.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental constants relating to 802.3
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmdhcp.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmdhcp.h
index 90d3c01617f0..26185765c711 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmdhcp.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmdhcp.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental constants relating to DHCP Protocol
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmeth.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmeth.h
index 97f893546b77..97fbbc1aa631 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmeth.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmeth.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Ethernettype  protocol definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmevent.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmevent.h
index 3afc3178a705..84baaceaf4d2 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmevent.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmevent.h
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Event  protocol definitions
  *
  * Dependencies: proto/bcmeth.h
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmip.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmip.h
index fdfd83c9ea9d..d9d9f9ca2bf7 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmip.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmip.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental constants relating to IP Protocol
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmipv6.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmipv6.h
index f446e47bf296..4c7af737d56e 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmipv6.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmipv6.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental constants relating to Neighbor Discovery Protocol
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmtcp.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmtcp.h
index 931a1a6f8fcf..ed32bee6f5b4 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmtcp.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmtcp.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental constants relating to TCP Protocol
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmudp.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmudp.h
index ae0e8d1226db..e83145f491b5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmudp.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bcmudp.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental constants relating to UDP Protocol
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bt_amp_hci.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bt_amp_hci.h
index 1a3ccaf83003..ea4ce3d793c5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bt_amp_hci.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/bt_amp_hci.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BT-AMP (BlueTooth Alternate Mac and Phy) HCI (Host/Controller Interface)
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/eapol.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/eapol.h
index e28496dc5f09..8d7983357e9a 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/eapol.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/eapol.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * 802.1x EAPOL definitions
  *
@@ -5,7 +6,7 @@
  * IEEE Std 802.1X-2001
  * IEEE 802.1X RADIUS Usage Guidelines
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/ethernet.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/ethernet.h
index d3a2e97c26b0..8d4242977813 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/ethernet.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/ethernet.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * From FreeBSD 2.2.7: Fundamental constants relating to ethernet.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_set.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_set.h
index 3e0a129bbbd6..05f5ba8b1c9f 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_set.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_set.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * EVENT_LOG system definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_tag.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_tag.h
index 5b0a641a666f..a96ba320dfa4 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_tag.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/event_log_tag.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * EVENT_LOG system definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/nan.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/nan.h
new file mode 100644
index 000000000000..b078c32a5dc5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/nan.h
@@ -0,0 +1,355 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Fundamental types and constants relating to WFA NAN
+ * (Neighbor Awareness Networking)
+ *
+ * Copyright (C) 1999-2018, Broadcom Corporation
+ * 
+ *      Unless you and Broadcom execute a separate written software license
+ * agreement governing use of this software, this software is licensed to you
+ * under the terms of the GNU General Public License version 2 (the "GPL"),
+ * available at http://www.broadcom.com/licenses/GPLv2.php, with the
+ * following added to such license:
+ * 
+ *      As a special exception, the copyright holders of this software give you
+ * permission to link this software with independent modules, and to copy and
+ * distribute the resulting executable under terms of your choice, provided that
+ * you also meet, for each linked independent module, the terms and conditions of
+ * the license of that module.  An independent module is a module which is not
+ * derived from this software.  The special exception does not apply to any
+ * modifications of the software.
+ * 
+ *      Notwithstanding the above, under no circumstances may you combine this
+ * software in any way with any other Broadcom software provided under a license
+ * other than the GPL, without Broadcom's express prior written consent.
+ *
+ * <<Broadcom-WL-IPTag/Open:>>
+ *
+ * $Id: nan.h 581725 2015-08-25 10:43:26Z $
+ */
+#ifndef _NAN_H_
+#define _NAN_H_
+
+#include <typedefs.h>
+#include <proto/802.11.h>
+
+
+/* This marks the start of a packed structure section. */
+#include <packed_section_start.h>
+
+/* WiFi NAN OUI values */
+#define NAN_OUI            WFA_OUI     /* WiFi OUI */
+/* For oui_type field identifying the type and version of the NAN IE. */
+#define NAN_OUI_TYPE       0x13        /* Type/Version */
+/* IEEE 802.11 vendor specific information element. (Same as P2P_IE_ID.) */
+#define NAN_IE_ID          0xdd
+
+/* Same as P2P_PUB_AF_CATEGORY and DOT11_ACTION_CAT_PUBLIC */
+#define NAN_PUB_AF_CATEGORY     0x04
+/* IEEE 802.11 Public Action Frame Vendor Specific. (Same as P2P_PUB_AF_ACTION.) */
+#define NAN_PUB_AF_ACTION       0x09
+/* Number of octents in hash of service name. (Same as P2P_WFDS_HASH_LEN.) */
+#define NAN_SVC_HASH_LEN    6
+/* Size of fixed length part of nan_pub_act_frame_t before attributes. */
+#define NAN_PUB_ACT_FRAME_FIXED_LEN 6
+/* Number of octents in master rank value. */
+#define NAN_MASTER_RANK_LEN     8
+/* NAN public action frame header size */
+#define NAN_PUB_ACT_FRAME_HDR_SIZE (OFFSETOF(nan_pub_act_frame_t, data))
+/* NAN network ID */
+#define NAN_NETWORK_ID		"\x51\x6F\x9A\x01\x00\x00"
+/* Service Control Type length */
+#define NAN_SVC_CONTROL_TYPE_LEN	2
+/* Binding Bitmap length */
+#define NAN_BINDING_BITMAP_LEN		2
+/* Service Response Filter (SRF) control field masks */
+#define NAN_SRF_BLOOM_MASK		0x01
+#define NAN_SRF_INCLUDE_MASK		0x02
+#define NAN_SRF_INDEX_MASK		0x0C
+/* SRF Bloom Filter index shift */
+#define NAN_SRF_BLOOM_SHIFT	2
+#define NAN_SRF_INCLUDE_SHIFT	1
+/* Mask for CRC32 output, used in hash function for NAN bloom filter */
+#define NAN_BLOOM_CRC32_MASK	0xFFFF
+
+/* Attribute TLV header size */
+#define NAN_ATTR_ID_OFF		0
+#define NAN_ATTR_LEN_OFF	1
+#define NAN_ATTR_DATA_OFF	3
+
+#define NAN_ATTR_ID_LEN		 1	/* ID field length */
+#define NAN_ATTR_LEN_LEN	 2	/* Length field length */
+#define NAN_ATTR_HDR_LEN	 3	/* ID + 2-byte length field */
+#define NAN_ENTRY_CTRL_LEN       1      /* Entry control field length from FAM attribute */
+#define NAN_MAP_ID_LEN           1	/* MAP ID length to signify band */
+#define NAN_OPERATING_CLASS_LEN  1	/* operating class field length from NAN FAM */
+#define NAN_CHANNEL_NUM_LEN      1	/* channel number field length 1 byte */
+
+#define NAN_MAP_ID_2G   2  /* NAN Further Avail Map ID for band 2.4G */
+#define NAN_MAP_ID_5G   5  /* NAN Further Avail Map ID for band 5G */
+#define NAN_MAP_NUM_IDS 2  /* Max number of NAN Further Avail Map IDs supported */
+
+#define NAN_AVAIL_ENTRY_LEN_RES0 7      /* Avail entry len in FAM attribute for resolution 16TU */
+#define NAN_AVAIL_ENTRY_LEN_RES1 5      /* Avail entry len in FAM attribute for resolution 32TU */
+#define NAN_AVAIL_ENTRY_LEN_RES2 4      /* Avail entry len in FAM attribute for resolution 64TU */
+
+/* Vendor-specific public action frame for NAN */
+typedef BWL_PRE_PACKED_STRUCT struct nan_pub_act_frame_s {
+	/* NAN_PUB_AF_CATEGORY 0x04 */
+	uint8 category_id;
+	/* NAN_PUB_AF_ACTION 0x09 */
+	uint8 action_field;
+	/* NAN_OUI 0x50-6F-9A */
+	uint8 oui[DOT11_OUI_LEN];
+	/* NAN_OUI_TYPE 0x13 */
+	uint8 oui_type;
+	/* One or more NAN Attributes follow */
+	uint8 data[1];
+} BWL_POST_PACKED_STRUCT nan_pub_act_frame_t;
+
+/* NAN attributes as defined in the nan spec */
+enum {
+	NAN_ATTR_MASTER_IND = 0,
+	NAN_ATTR_CLUSTER = 1,
+	NAN_ATTR_SVC_ID_LIST = 2,
+	NAN_ATTR_SVC_DESCRIPTOR = 3,
+	NAN_ATTR_CONN_CAP = 4,
+	NAN_ATTR_INFRA = 5,
+	NAN_ATTR_P2P = 6,
+	NAN_ATTR_IBSS = 7,
+	NAN_ATTR_MESH = 8,
+	NAN_ATTR_FURTHER_NAN_SD = 9,
+	NAN_ATTR_FURTHER_AVAIL = 10,
+	NAN_ATTR_COUNTRY_CODE = 11,
+	NAN_ATTR_RANGING = 12,
+	NAN_ATTR_CLUSTER_DISC = 13,
+	NAN_ATTR_VENDOR_SPECIFIC = 221
+};
+
+enum wifi_nan_avail_resolution {
+	NAN_AVAIL_RES_16_TU = 0,
+	NAN_AVAIL_RES_32_TU = 1,
+	NAN_AVAIL_RES_64_TU = 2,
+	NAN_AVAIL_RES_INVALID = 255
+};
+
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_ie_s {
+	uint8	id;		/* IE ID: NAN_IE_ID 0xDD */
+	uint8	len;		/* IE length */
+	uint8	oui[DOT11_OUI_LEN]; /* NAN_OUI 50:6F:9A */
+	uint8	oui_type;	/* NAN_OUI_TYPE 0x13 */
+	uint8	attr[1];	/* var len attributes */
+} BWL_POST_PACKED_STRUCT wifi_nan_ie_t;
+
+#define NAN_IE_HDR_SIZE	(OFFSETOF(wifi_nan_ie_t, attr))
+
+/* master indication record  */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_master_ind_attr_s {
+	uint8	id;
+	uint16	len;
+	uint8	master_preference;
+	uint8	random_factor;
+} BWL_POST_PACKED_STRUCT wifi_nan_master_ind_attr_t;
+
+/* cluster attr record  */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_cluster_attr_s {
+	uint8	id;
+	uint16	len;
+	uint8   amr[NAN_MASTER_RANK_LEN];
+	uint8   hop_count;
+	/* Anchor Master Beacon Transmission Time */
+	uint32  ambtt;
+} BWL_POST_PACKED_STRUCT wifi_nan_cluster_attr_t;
+
+/*  container for service ID records  */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_svc_id_attr_s {
+	uint8	id;
+	uint16	len;
+	uint8	svcid[NAN_SVC_HASH_LEN]; /* 6*len of srvc IDs */
+} BWL_POST_PACKED_STRUCT wifi_nan_svc_id_attr_t;
+
+/* service_control bitmap for wifi_nan_svc_descriptor_attr_t below */
+#define NAN_SC_PUBLISH 0x0
+#define NAN_SC_SUBSCRIBE 0x1
+#define NAN_SC_FOLLOWUP 0x2
+/* Set to 1 if a Matching Filter field is included in descriptors. */
+#define NAN_SC_MATCHING_FILTER_PRESENT 0x4
+/* Set to 1 if a Service Response Filter field is included in descriptors. */
+#define NAN_SC_SR_FILTER_PRESENT 0x8
+/* Set to 1 if a Service Info field is included in descriptors. */
+#define NAN_SC_SVC_INFO_PRESENT 0x10
+/* range is close proximity only */
+#define NAN_SC_RANGE_LIMITED 0x20
+/* Set to 1 if binding bitamp is present in descriptors */
+#define NAN_SC_BINDING_BITMAP_PRESENT 0x40
+
+/* Service descriptor */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_svc_descriptor_attr_s {
+	/* Attribute ID - 0x03. */
+	uint8 id;
+	/* Length of the following fields in the attribute */
+	uint16 len;
+	/* Hash of the Service Name */
+	uint8 svc_hash[NAN_SVC_HASH_LEN];
+	/* Publish or subscribe instance id */
+	uint8 instance_id;
+	/* Requestor Instance ID */
+	uint8 requestor_id;
+	/* Service Control Bitmask. Also determines what data follows. */
+	uint8 svc_control;
+	/* Optional fields follow */
+} BWL_POST_PACKED_STRUCT wifi_nan_svc_descriptor_attr_t;
+
+/* IBSS attribute */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_ibss_attr_s {
+	/* Attribute ID - 0x07. */
+	uint8 id;
+	/* Length of the following fields in the attribute */
+	uint16 len;
+	/* BSSID of the ibss */
+	struct ether_addr bssid;
+	/*
+	 map control:, bits:
+	[0-3]: Id for associated further avail map attribute
+	[4-5]: avail interval duration: 0:16ms; 1:32ms; 2:64ms; 3:reserved
+	[6] : repeat : 0 - applies to next DW, 1: 16 intervals max? wtf?
+	[7] : reserved
+	*/
+	uint8 map_ctrl;
+	/* avail. intervals bitmap, var len  */
+	uint8 avail_bmp[1];
+} BWL_POST_PACKED_STRUCT wifi_nan_ibss_attr_t;
+
+/* Further Availability MAP attr  */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_favail_attr_s {
+	/* Attribute ID - 0x0A. */
+	uint8 id;
+	/* Length of the following fields in the attribute */
+	uint16 len;
+	/* MAP id: val [0..15], values[16-255] reserved */
+	uint8 map_id;
+	/*  availibility entry, var len */
+	uint8 avil_entry[1];
+} BWL_POST_PACKED_STRUCT wifi_nan_favail_attr_t;
+
+/* Further Availability MAP attr  */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_avail_entry_s {
+	/*
+	 entry control
+	 [0-1]: avail interval duration: 0:16ms; 1:32ms; 2:64ms;
+	 [2:7] reserved
+	*/
+	uint8 entry_ctrl;
+	/* operating class: freq band etc IEEE 802.11 */
+	uint8 opclass;
+	/* channel number */
+	uint8 chan;
+	/*  avail bmp, var len */
+	uint8 avail_bmp[1];
+} BWL_POST_PACKED_STRUCT wifi_nan_avail_entry_t;
+
+/* Map control Field */
+#define NAN_MAPCTRL_IDMASK	0x7
+#define NAN_MAPCTRL_DURSHIFT	4
+#define NAN_MAPCTRL_DURMASK	0x30
+#define NAN_MAPCTRL_REPEAT	0x40
+#define NAN_MAPCTRL_REPEATSHIFT	6
+
+#define NAN_VENDOR_TYPE_RTT	0
+#define NAN_VENDOR_TYPE_P2P	1
+
+/* Vendor Specific Attribute */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_vendor_attr_s {
+	uint8	id;		/* 0xDD */
+	uint16	len;		/* IE length */
+	uint8	oui[DOT11_OUI_LEN]; /* 00-90-4C */
+	uint8	type;		/* attribute type */
+	uint8	attr[1];	/* var len attributes */
+} BWL_POST_PACKED_STRUCT wifi_nan_vendor_attr_t;
+
+#define NAN_VENDOR_HDR_SIZE	(OFFSETOF(wifi_nan_vendor_attr_t, attr))
+
+/* p2p operation attribute */
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_p2p_op_attr_s {
+	/* Attribute ID - 0x06. */
+	uint8 id;
+	/* Length of the following fields in the attribute */
+	uint16 len;
+	/* P2P device role */
+	uint8 dev_role;
+	/* BSSID of the ibss */
+	struct ether_addr p2p_dev_addr;
+	/*
+	map control:, bits:
+	[0-3]: Id for associated further avail map attribute
+	[4-5]: avail interval duration: 0:16ms; 1:32ms; 2:64ms; 3:reserved
+	[6] : repeat : 0 - applies to next DW, 1: 16 intervals max? wtf?
+	[7] : reserved
+	*/
+	uint8 map_ctrl;
+	/* avail. intervals bitmap */
+	uint8 avail_bmp[1];
+} BWL_POST_PACKED_STRUCT wifi_nan_p2p_op_attr_t;
+
+/* ranging attribute */
+#define NAN_RANGING_MAP_CTRL_ID_SHIFT 0
+#define NAN_RANGING_MAP_CTRL_ID_MASK 0x0F
+#define NAN_RANGING_MAP_CTRL_DUR_SHIFT 4
+#define NAN_RANGING_MAP_CTRL_DUR_MASK 0x30
+#define NAN_RANGING_MAP_CTRL_REPEAT_SHIFT 6
+#define NAN_RANGING_MAP_CTRL_REPEAT_MASK 0x40
+#define NAN_RANGING_MAP_CTRL_REPEAT_DW(_ctrl) (((_ctrl) & \
+	NAN_RANGING_MAP_CTRL_DUR_MASK) ? 16 : 1)
+#define NAN_RANGING_MAP_CTRL(_id, _dur, _repeat) (\
+	(((_id) << NAN_RANGING_MAP_CTRL_ID_SHIFT) & \
+		 NAN_RANGING_MAP_CTRL_ID_MASK) | \
+	(((_dur) << NAN_RANGING_MAP_CTRL_DUR_SHIFT) & \
+		NAN_RANGING_MAP_CTRL_DUR_MASK) | \
+	(((_repeat) << NAN_RANGING_MAP_CTRL_REPEAT_SHIFT) & \
+		 NAN_RANGING_MAP_CTRL_REPEAT_MASK))
+
+enum {
+	NAN_RANGING_PROTO_FTM = 0
+};
+
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_ranging_attr_s {
+	uint8 id;						/* 0x0C */
+	uint16 len; 					/* length that follows */
+	struct ether_addr dev_addr;		/* device mac address */
+
+	/*
+	map control:, bits:
+	[0-3]: Id for associated further avail map attribute
+	[4-5]: avail interval duration: 0:16ms; 1:32ms; 2:64ms; 3:reserved
+	[6] : repeat : 0 - applies to next DW, 1: 16 intervals max? wtf?
+	[7] : reserved
+	*/
+	uint8 map_ctrl;
+
+	uint8 protocol;					/* FTM = 0 */
+	uint32 avail_bmp;				/* avail interval bitmap */
+} BWL_POST_PACKED_STRUCT wifi_nan_ranging_attr_t;
+
+#define NAN_CONN_CAPABILITY_WFD		0x0001
+#define NAN_CONN_CAPABILITY_WFDS		0x0002
+#define NAN_CONN_CAPABILITY_TDLS		0x0004
+#define NAN_CONN_CAPABILITY_INFRA	0x0008
+#define NAN_CONN_CAPABILITY_IBSS		0x0010
+#define NAN_CONN_CAPABILITY_MESH		0x0020
+
+typedef BWL_PRE_PACKED_STRUCT struct wifi_nan_conn_cap_attr_s {
+	/* Attribute ID - 0x04. */
+	uint8 id;
+	/* Length of the following fields in the attribute */
+	uint16	len;
+	uint16	conn_cap_bmp;	/* Connection capability bitmap */
+} BWL_POST_PACKED_STRUCT wifi_nan_conn_cap_attr_t;
+
+#define NAN_SLOT_RES_16TU 16
+#define NAN_SLOT_RES_32TU 32
+#define NAN_SLOT_RES_64TU 64
+
+/* This marks the end of a packed structure section. */
+#include <packed_section_end.h>
+
+#endif /* _NAN_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/p2p.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/p2p.h
index 747265b9a2c2..9df322d117f1 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/p2p.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/p2p.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental types and constants relating to WFA P2P (aka WiFi Direct)
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/sdspi.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/sdspi.h
index ca6e96eac051..6a45d3ca39f6 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/sdspi.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/sdspi.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SD-SPI Protocol Standard
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/vlan.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/vlan.h
index 062119d1faf2..c74b1e507a57 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/vlan.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/vlan.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * 802.1Q VLAN protocol definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wpa.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wpa.h
index c45920e64033..edd1cc78aae3 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wpa.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wpa.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Fundamental types and constants relating to WPA
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wps.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wps.h
index aa4cc1b9f0e0..5c61e3d23773 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wps.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/proto/wps.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * WPS IE definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/rte_ioctl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/rte_ioctl.h
index 2176c90d469f..0d852a362dd5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/rte_ioctl.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/rte_ioctl.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * HND Run Time Environment ioctl.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbchipc.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbchipc.h
index 24b3010e8f84..f571e7e7983b 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbchipc.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbchipc.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SiliconBackplane Chipcommon core hardware definitions.
  *
@@ -7,7 +8,7 @@
  *
  * $Id: sbchipc.h 603826 2015-12-03 08:57:00Z $
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbconfig.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbconfig.h
index ad9c408cd344..81916ae73faf 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbconfig.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbconfig.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom SiliconBackplane hardware register definitions.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbhnddma.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbhnddma.h
index d66a0b6172ae..69a0cf2107b6 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbhnddma.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbhnddma.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Generic Broadcom Home Networking Division (HND) DMA engine HW interface
  * This supports the following chips: BCM42xx, 44xx, 47xx .
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbpcmcia.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbpcmcia.h
index 121d22c4cec9..b431d7641694 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbpcmcia.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbpcmcia.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BCM43XX Sonics SiliconBackplane PCMCIA core hardware definitions.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdio.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdio.h
index 68707c4d489e..d9a8eb361526 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdio.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdio.h
@@ -1,10 +1,11 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SDIO device core hardware definitions.
  * sdio is a portion of the pcmcia core in core rev 3 - rev 8
  *
  * SDIO core support 1bit, 4 bit SDIO mode as well as SPI mode.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdpcmdev.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdpcmdev.h
index 8c5fd56705a5..bb6465b6b390 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdpcmdev.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsdpcmdev.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom SiliconBackplane SDIO/PCMCIA hardware-specific
  * device core support
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsocram.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsocram.h
index fba899daa463..2179bd211cc7 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsocram.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsocram.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * BCM47XX Sonics SiliconBackplane embedded ram core
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsysmem.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsysmem.h
index af99cde25a36..12cdb5db1467 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsysmem.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sbsysmem.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SiliconBackplane System Memory core
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdio.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdio.h
index 2bb33667872b..9f2ac3fcfa69 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdio.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdio.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SDIO spec header file
  * Protocol and standard (common) device definitions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdioh.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdioh.h
index f37c5f62aef7..3c4ea7e93c54 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdioh.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdioh.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SDIO Host Controller Spec header file
  * Register map and definitions for the Standard Host Controller
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdiovar.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdiovar.h
index 4f1d82d7ab0f..57d1318dffcf 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdiovar.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/sdiovar.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Structure used by apps whose drivers access SDIO drivers.
  * Pulled out separately so dhdu and wlu can both use it.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/siutils.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/siutils.h
index fae2349f4096..989066740303 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/siutils.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/siutils.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines for accessing the SOC Interconnects
  * of Broadcom HNBU chips.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/spid.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/spid.h
index 8fdefa43778b..86923bcaf395 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/spid.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/spid.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * SPI device spec header file
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/trxhdr.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/trxhdr.h
index 50cd3c1ac952..3da8cb6cff81 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/trxhdr.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/trxhdr.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * TRX image file header format.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/typedefs.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/typedefs.h
index 2a1aa5c11b2c..a13fc425f090 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/typedefs.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/typedefs.h
@@ -1,5 +1,6 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/usbrdl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/usbrdl.h
new file mode 100644
index 000000000000..075d174e5406
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/usbrdl.h
@@ -0,0 +1,135 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Broadcom USB remote download definitions
+ *
+ * Copyright (C) 1999-2018, Broadcom Corporation
+ * 
+ *      Unless you and Broadcom execute a separate written software license
+ * agreement governing use of this software, this software is licensed to you
+ * under the terms of the GNU General Public License version 2 (the "GPL"),
+ * available at http://www.broadcom.com/licenses/GPLv2.php, with the
+ * following added to such license:
+ * 
+ *      As a special exception, the copyright holders of this software give you
+ * permission to link this software with independent modules, and to copy and
+ * distribute the resulting executable under terms of your choice, provided that
+ * you also meet, for each linked independent module, the terms and conditions of
+ * the license of that module.  An independent module is a module which is not
+ * derived from this software.  The special exception does not apply to any
+ * modifications of the software.
+ * 
+ *      Notwithstanding the above, under no circumstances may you combine this
+ * software in any way with any other Broadcom software provided under a license
+ * other than the GPL, without Broadcom's express prior written consent.
+ *
+ *
+ * <<Broadcom-WL-IPTag/Open:>>
+ *
+ * $Id: usbrdl.h 708672 2018-11-16 02:34:41Z $
+ */
+
+#ifndef _USB_RDL_H
+#define _USB_RDL_H
+
+/* Control messages: bRequest values */
+#define DL_GETSTATE		0	/* returns the rdl_state_t struct */
+#define DL_CHECK_CRC		1	/* currently unused */
+#define DL_GO			2	/* execute downloaded image */
+#define DL_START		3	/* initialize dl state */
+#define DL_REBOOT		4	/* reboot the device in 2 seconds */
+#define DL_GETVER		5	/* returns the bootrom_id_t struct */
+#define DL_GO_PROTECTED		6	/* execute the downloaded code and set reset event
+					 * to occur in 2 seconds.  It is the responsibility
+					 * of the downloaded code to clear this event
+					 */
+#define DL_EXEC			7	/* jump to a supplied address */
+#define DL_RESETCFG		8	/* To support single enum on dongle
+					 * - Not used by bootloader
+					 */
+#define DL_DEFER_RESP_OK	9	/* Potentially defer the response to setup
+					 * if resp unavailable
+					 */
+#define DL_CHGSPD		0x0A
+
+#define	DL_HWCMD_MASK		0xfc	/* Mask for hardware read commands: */
+#define	DL_RDHW			0x10	/* Read a hardware address (Ctl-in) */
+#define	DL_RDHW32		0x10	/* Read a 32 bit word */
+#define	DL_RDHW16		0x11	/* Read 16 bits */
+#define	DL_RDHW8		0x12	/* Read an 8 bit byte */
+#define	DL_WRHW			0x14	/* Write a hardware address (Ctl-out) */
+#define DL_WRHW_BLK		0x13	/* Block write to hardware access */
+
+#define DL_CMD_WRHW		2
+
+
+/* states */
+#define DL_WAITING	0	/* waiting to rx first pkt that includes the hdr info */
+#define DL_READY	1	/* hdr was good, waiting for more of the compressed image */
+#define DL_BAD_HDR	2	/* hdr was corrupted */
+#define DL_BAD_CRC	3	/* compressed image was corrupted */
+#define DL_RUNNABLE	4	/* download was successful, waiting for go cmd */
+#define DL_START_FAIL	5	/* failed to initialize correctly */
+#define DL_NVRAM_TOOBIG	6	/* host specified nvram data exceeds DL_NVRAM value */
+#define DL_IMAGE_TOOBIG	7	/* download image too big (exceeds DATA_START for rdl) */
+
+#define TIMEOUT		5000	/* Timeout for usb commands */
+
+struct bcm_device_id {
+	char	*name;
+	uint32	vend;
+	uint32	prod;
+};
+
+typedef struct {
+	uint32	state;
+	uint32	bytes;
+} rdl_state_t;
+
+typedef struct {
+	uint32	chip;		/* Chip id */
+	uint32	chiprev;	/* Chip rev */
+	uint32  ramsize;    /* Size of RAM */
+	uint32  remapbase;   /* Current remap base address */
+	uint32  boardtype;   /* Type of board */
+	uint32  boardrev;    /* Board revision */
+} bootrom_id_t;
+
+/* struct for backplane & jtag accesses */
+typedef struct {
+	uint32	cmd;		/* tag to identify the cmd */
+	uint32	addr;		/* backplane address for write */
+	uint32	len;		/* length of data: 1, 2, 4 bytes */
+	uint32	data;		/* data to write */
+} hwacc_t;
+
+
+/* struct for querying nvram params from bootloader */
+#define QUERY_STRING_MAX 32
+typedef struct {
+	uint32  cmd;                    /* tag to identify the cmd */
+	char    var[QUERY_STRING_MAX];  /* param name */
+} nvparam_t;
+
+typedef void (*exec_fn_t)(void *sih);
+
+#define USB_CTRL_IN (USB_TYPE_VENDOR | 0x80 | USB_RECIP_INTERFACE)
+#define USB_CTRL_OUT (USB_TYPE_VENDOR | 0 | USB_RECIP_INTERFACE)
+
+#define USB_CTRL_EP_TIMEOUT 500 /* Timeout used in USB control_msg transactions. */
+#define USB_BULK_EP_TIMEOUT 500 /* Timeout used in USB bulk transactions. */
+
+#define RDL_CHUNK_MAX	(64 * 1024)  /* max size of each dl transfer */
+#define RDL_CHUNK	1500  /* size of each dl transfer */
+
+/* bootloader makes special use of trx header "offsets" array */
+#define TRX_OFFSETS_DLFWLEN_IDX	0	/* Size of the fw; used in uncompressed case */
+#define TRX_OFFSETS_JUMPTO_IDX	1	/* RAM address for jumpto after download */
+#define TRX_OFFSETS_NVM_LEN_IDX	2	/* Length of appended NVRAM data */
+#ifdef BCMTRXV2
+#define TRX_OFFSETS_DSG_LEN_IDX	3	/* Length of digital signature for the first image */
+#define TRX_OFFSETS_CFG_LEN_IDX	4	/* Length of config region, which is not digitally signed */
+#endif /* BCMTRXV2 */
+
+#define TRX_OFFSETS_DLBASE_IDX  0       /* RAM start address for download */
+
+#endif  /* _USB_RDL_H */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlfc_proto.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlfc_proto.h
index a2d60f41f423..3bf81031f0de 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlfc_proto.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlfc_proto.h
@@ -1,5 +1,6 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl.h
index 2e0940179e79..176b832a75af 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Custom OID/ioctl definitions for
  *
@@ -6,7 +7,7 @@
  *
  * Definitions subject to change without notice.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -27,7 +28,7 @@
  * other than the GPL, without Broadcom's express prior written consent.
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: wlioctl.h 606700 2015-12-16 12:15:50Z $
+ * $Id: wlioctl.h 692666 2018-07-30 08:58:07Z $
  */
 
 #ifndef _wlioctl_h_
@@ -8505,6 +8506,14 @@ typedef struct {
 } wl_roam_channel_list_t;
 #endif 
 
+#ifdef MFP
+/* values for IOV_MFP arg */
+enum {
+    WL_MFP_NONE = 0,
+    WL_MFP_CAPABLE,
+    WL_MFP_REQUIRED
+};
+#endif /* MFP */
 
 /*
  * WOWL unassociated mode power svae pattern.
@@ -8527,4 +8536,71 @@ typedef struct wl_peer_rssi {
 	struct ether_addr ea;
 } wl_peer_rssi_t;
 
+#define GPIO_WAKE_PAYLOAD_MAXSIZE	1024
+#define MAX_GPIO_WAKE_INT_SIZE		(sizeof(wl_gpio_wake_int_t)+GPIO_WAKE_PAYLOAD_MAXSIZE-1)
+
+enum {
+	GPIO_WAKE_PROTO_TCP = 0,
+	GPIO_WAKE_PROTO_RAW,
+};
+
+typedef struct wl_gpio_wake_int_s {
+	uint8 enable;
+	uint8 proto;
+	uint8 idx;
+	uint16 data_len;
+	uint8 data[1];
+} wl_gpio_wake_int_t;
+
+/*
+ * DHCP lease time renew offload definitions
+ */
+
+/* common iovar struct */
+typedef struct wl_dltro {
+	uint8 subcmd_id;	/* subcommand id */
+	uint8 pad;
+	uint16 len;		/* total length of data[] */
+	uint8 data[1];		/* subcommand data */
+} wl_dltro_t;
+
+
+/* Subcommand ids */
+#define WL_DLTRO_SUBCMD_CONNECT     0   /* DLTRO connection info */
+#define WL_DLTRO_SUBCMD_PARAM       1   /* DLTRO parameter info */
+#define WL_DLTRO_SUBCMD_MAX_DLTRO   2   /* Max DLTRO supported */
+
+/* WL_DLTRO_SUBCMD_CONNECT subcommand data
+ * Invoke with unique 'index' for each DLTRO connection
+ */
+typedef struct wl_dltro_connect {
+	uint8 index;        /* DLTRO connection index, 0 to max-1 */
+	uint8 ip_addr_type;	/* 0 - IPv4, 1 - IPv6 */
+	uint8 offload_type; /* 0 - Client, 1 - Server */
+	uint8 pad;
+	uint32 tid;         /* Transaction id */
+	uint32 timer_val;   /* DHCP lease time remaining */
+	uint32 time_before_expiry; /* Time before expiry for DHCP lease renewal */
+	uint32 len;         /* Length of the variable data */
+	uint8 data[1];      /* Variable length field containing DLTRO packet */
+} wl_dltro_connect_t;
+
+/* WL_DLTRO_SUBCMD_PARAM subcommand data
+ * Invoke with unique 'index' for each DLTRO connection
+ */
+typedef struct wl_dltro_param {
+	uint8 index;        /* DLTRO connection index, 0 to max-1 */
+	uint8 retry;        /* Number of retries */
+} wl_dltro_param_t;
+
+/* WL_DLTRO_SUBCMD_PARAM subcommand data to GET configured info for specific index */
+typedef struct wl_dltro_get_param {
+	uint8 index;        /* DLTRO connection index, 0 to max-1 */
+} wl_dltro_get_param_t;
+
+/* WL_DLTRO_SUBCMD_MAX_DLTRO subcommand data */
+typedef struct wl_dltro_max_dltro {
+	uint8 max;	/* Max DLTRO supported */
+} wl_dltro_max_dltro_t;
+
 #endif /* _wlioctl_h_ */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl_utils.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl_utils.h
index 38eded4b4e10..13c7dd358bb5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl_utils.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/include/wlioctl_utils.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Custom OID/ioctl related helper functions.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/linux_osl.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/linux_osl.c
index bca930d53744..922bfa672f84 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/linux_osl.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/linux_osl.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux OS Independent Layer
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -1982,7 +1983,12 @@ osl_os_get_image_block(char *buf, int len, void *image)
 	if (!image)
 		return 0;
 
-	rdlen = kernel_read(fp, fp->f_pos, buf, len);
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0))
+        rdlen = kernel_read(fp, fp->f_pos, buf, len);
+#else
+        rdlen = kernel_read(fp, buf, len, (loff_t *)fp->f_pos);
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0)) */
+
 	if (rdlen > 0)
 		fp->f_pos += rdlen;
 
@@ -2485,6 +2491,7 @@ osl_sec_dma_free_consistent(osl_t *osh, void *va, uint size, dmaaddr_t pa)
 
 #endif /* BCM_SECURE_DMA */
 
+#if 0
 #if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0) && defined(TSQ_MULTIPLIER)
 #include <linux/kallsyms.h>
 #include <net/sock.h>
@@ -2519,3 +2526,4 @@ osl_pkt_orphan_partial(struct sk_buff *skb)
 	atomic_sub(fraction, &skb->sk->sk_wmem_alloc);
 }
 #endif /* LINUX_VERSION >= 3.6.0 && TSQ_MULTIPLIER */
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/pcie_core.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/pcie_core.c
index 53c90b8d3a49..10be426818dd 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/pcie_core.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/pcie_core.c
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /** @file pcie_core.c
  *
  * Contains PCIe related functions that are shared between different driver models (e.g. firmware
  * builds, DHD builds, BMAC builds), in order to avoid code duplication.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/rkversion.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/rkversion.c
index e16f292031fb..dfa5c78882cb 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/rkversion.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/rkversion.c
@@ -1,4 +1,5 @@
 /* SPDX-License-Identifier: GPL-2.0 */
+/* SPDX-License-Identifier: GPL-2.0 */
 /* rk_wifi_config.c
  *
  * RKWIFI driver version.
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/sbutils.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/sbutils.c
index 25c6cfd0a1b2..b9d844f927d8 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/sbutils.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/sbutils.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines for accessing chip-specific features
  * of the SiliconBackplane-based Broadcom chips.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils.c
index 7d37a06d2d46..30532b987701 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils.c
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Misc utility routines for accessing chip-specific features
  * of the SiliconBackplane-based Broadcom chips.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -25,7 +26,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: siutils.c 666543 2017-08-25 07:42:40Z $
+ * $Id: siutils.c 708487 2018-10-31 05:33:14Z $
  */
 
 #include <bcm_cfg.h>
@@ -54,6 +55,10 @@
 #endif /* BCMSDIO */
 #include <hndpmu.h>
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+#include <dhd_chip_info.h>
+#endif
+
 #ifdef BCM_SDRBL
 #include <hndcpu.h>
 #endif /* BCM_SDRBL */
@@ -282,6 +287,20 @@ si_buscore_setup(si_info_t *sii, chipcregs_t *cc, uint bustype, uint32 savewin,
 	uint i;
 	uint pciidx, pcieidx, pcirev, pcierev;
 
+#ifdef LOAD_DHD_WITH_FW_ALIVE
+	if(alive == FW_ALIVE_MAGIC) {
+		switch(card_dev) {
+			case BCM43430_CHIP_ID:
+				if(card_rev == 2)
+					memcpy(&sii->pub, &sii_pub_43436, sizeof(sii->pub));
+				else
+					memcpy(&sii->pub, &sii_pub_43430, sizeof(sii->pub));
+				break;
+		}
+		return true;
+	}
+#endif
+
 	/* first, enable backplane timeouts */
 	if (CHIPTYPE(sii->pub.socitype) == SOCI_AI)
 		ai_enable_backplane_timeouts(&sii->pub);
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils_priv.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils_priv.h
index 0dc02211e1b7..af21b33912d1 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils_priv.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/siutils_priv.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Include file private to the SOC Interconnect support files.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/uamp_api.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/uamp_api.h
index 7fe81a859430..39628102034e 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/uamp_api.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/uamp_api.h
@@ -1,9 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  *  Name:       uamp_api.h
  *
  *  Description: Universal AMP API
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.c
index 1d7cc0f39b2b..4e894d931ac0 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 driver - Android related functions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -134,6 +135,9 @@
 
 #define	CMD_HAPD_MAC_FILTER	"HAPD_MAC_FILTER"
 
+#ifdef WLFBT
+#define CMD_GET_FTKEY      "GET_FTKEY"
+#endif
 
 
 #define CMD_ROAM_OFFLOAD			"SETROAMOFFLOAD"
@@ -2523,6 +2527,12 @@ wl_handle_private_cmd(struct net_device *net, char *command, u32 cmd_len)
 		bytes_written = wl_cfg80211_set_wps_p2p_ie(net, command + skip,
 			priv_cmd.total_len - skip, *(command + skip - 2) - '0');
 	}
+#ifdef WLFBT
+	else if (strnicmp(command, CMD_GET_FTKEY, strlen(CMD_GET_FTKEY)) == 0) {
+		wl_cfg80211_get_fbt_key(command);
+		bytes_written = FBT_KEYLEN;
+	}
+#endif /* WLFBT */
 #endif /* WL_CFG80211 */
 	else if (strnicmp(command, CMD_OKC_SET_PMK, strlen(CMD_OKC_SET_PMK)) == 0)
 		bytes_written = wl_android_set_pmk(net, command, priv_cmd.total_len);
@@ -2663,6 +2673,24 @@ wl_handle_private_cmd(struct net_device *net, char *command, u32 cmd_len)
 	return bytes_written;
 }
 
+#if 0
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0))
+static int
+wl_genl_register_family_with_ops_groups(struct genl_family *family,
+       const struct genl_ops *ops, size_t n_ops,
+       const struct genl_multicast_group *mcgrps,
+       size_t n_mcgrps)
+{
+       family->module = THIS_MODULE;
+       family->ops = ops;
+       family->n_ops = n_ops;
+       family->mcgrps = mcgrps;
+       family->n_mcgrps = n_mcgrps;
+       return genl_register_family(family);
+}
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0) */
+#endif
+
 int wl_android_init(void)
 {
 	int ret = 0;
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.h
index f2edd83ad943..529f71ea7329 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_android.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 driver - Android related functions
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.c
index 18348e6eaa44..90067d6469fd 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 driver
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -24,7 +25,7 @@
  *
  * <<Broadcom-WL-IPTag/Open:>>
  *
- * $Id: wl_cfg80211.c 674373 2017-10-20 07:05:57Z $
+ * $Id: wl_cfg80211.c 708612 2018-11-13 06:14:10Z $
  */
 /* */
 #include <typedefs.h>
@@ -611,6 +612,9 @@ static void wl_update_hidden_ap_ie(struct wl_bss_info *bi, const u8 *ie_stream,
 static s32 wl_mrg_ie(struct bcm_cfg80211 *cfg, u8 *ie_stream, u16 ie_size);
 static s32 wl_cp_ie(struct bcm_cfg80211 *cfg, u8 *dst, u16 dst_size);
 static u32 wl_get_ielen(struct bcm_cfg80211 *cfg);
+#ifdef MFP
+static int wl_cfg80211_get_rsn_capa(bcm_tlv_t *wpa2ie, u8* capa);
+#endif
 
 #ifdef WL11U
 bcm_tlv_t *
@@ -923,12 +927,23 @@ static struct ieee80211_supported_band __wl_band_5ghz_a = {
 	.n_bitrates = wl_a_rates_size
 };
 
+#if defined(WLFBT)
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+#define WLAN_AKM_SUITE_FT_8021X         0x000FAC03
+#define WLAN_AKM_SUITE_FT_PSK           0x000FAC04
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0)) */
+#define WLAN_CIPHER_SUITE_PMK           0x00904C00
+#endif /* WLFBT */
+
 static const u32 __wl_cipher_suites[] = {
 	WLAN_CIPHER_SUITE_WEP40,
 	WLAN_CIPHER_SUITE_WEP104,
 	WLAN_CIPHER_SUITE_TKIP,
 	WLAN_CIPHER_SUITE_CCMP,
 	WLAN_CIPHER_SUITE_AES_CMAC,
+#if defined(WLFBT) && defined(WLAN_CIPHER_SUITE_PMK)
+	WLAN_CIPHER_SUITE_PMK,
+#endif
 };
 
 #ifdef WL_SUPPORT_ACS
@@ -1454,7 +1469,10 @@ wl_cfg80211_add_virtual_iface(struct wiphy *wiphy,
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
 	unsigned char name_assign_type,
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0)) */
-	enum nl80211_iftype type, u32 *flags,
+        enum nl80211_iftype type,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+        u32 *flags,
+#endif
 	struct vif_params *params)
 {
 	s32 err = -ENODEV;
@@ -1473,11 +1491,11 @@ wl_cfg80211_add_virtual_iface(struct wiphy *wiphy,
 	bcm_struct_cfgdev *new_cfgdev;
 #endif /* WL_VIRTUAL_APSTA */
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 	s32 up = 1;
 	dhd_pub_t *dhd;
 	bool enabled;
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 #if defined(SUPPORT_AP_POWERSAVE)
 	dhd_pub_t *dhd;
@@ -1487,9 +1505,9 @@ wl_cfg80211_add_virtual_iface(struct wiphy *wiphy,
 		return ERR_PTR(-EINVAL);
 
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 	dhd = (dhd_pub_t *)(cfg->pub);
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 #if defined(SUPPORT_AP_POWERSAVE)
 	dhd = (dhd_pub_t *)(cfg->pub);
@@ -1570,10 +1588,10 @@ wl_cfg80211_add_virtual_iface(struct wiphy *wiphy,
 		ASSERT(cfg->p2p); /* ensure expectation of p2p initialization */
 
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 		if (!dhd)
 			return ERR_PTR(-ENODEV);
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 		if (!cfg->p2p)
 			return ERR_PTR(-ENODEV);
@@ -1596,7 +1614,7 @@ wl_cfg80211_add_virtual_iface(struct wiphy *wiphy,
 
 		wl_cfg80211_scan_abort(cfg);
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 		if (!cfg->wlfc_on && !disable_proptx) {
 			dhd_wlfc_get_enable(dhd, &enabled);
 			if (!enabled && dhd->op_mode != DHD_FLAG_HOSTAP_MODE &&
@@ -1608,7 +1626,7 @@ wl_cfg80211_add_virtual_iface(struct wiphy *wiphy,
 			}
 			cfg->wlfc_on = true;
 		}
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 
 		/* Dual p2p doesn't support multiple P2PGO interfaces,
@@ -1776,14 +1794,14 @@ wl_cfg80211_add_virtual_iface(struct wiphy *wiphy,
 			memset(cfg->p2p->vir_ifname, '\0', IFNAMSIZ);
 			wl_to_p2p_bss_bssidx(cfg, cfg_type) = -1;
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 			dhd_wlfc_get_enable(dhd, &enabled);
 		if (enabled && cfg->wlfc_on && dhd->op_mode != DHD_FLAG_HOSTAP_MODE &&
 			dhd->op_mode != DHD_FLAG_IBSS_MODE) {
 			dhd_wlfc_deinit(dhd);
 			cfg->wlfc_on = false;
 		}
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 		}
 	}
@@ -1923,7 +1941,11 @@ wl_cfg80211_del_virtual_iface(struct wiphy *wiphy, bcm_struct_cfgdev *cfgdev)
 
 static s32
 wl_cfg80211_change_virtual_iface(struct wiphy *wiphy, struct net_device *ndev,
-	enum nl80211_iftype type, u32 *flags,
+        enum nl80211_iftype type,
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0))
+        u32 *flags,
+#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0) */
+
 	struct vif_params *params)
 {
 	s32 ap = 0;
@@ -2136,10 +2158,10 @@ static s32 wl_cfg80211_handle_ifdel(struct bcm_cfg80211 *cfg, wl_if_event_info *
 	s32 type = -1;
 	s32 bssidx = -1;
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 	dhd_pub_t *dhd =  (dhd_pub_t *)(cfg->pub);
 	bool enabled;
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 
 	bssidx = if_event_info->bssidx;
@@ -2169,14 +2191,14 @@ static s32 wl_cfg80211_handle_ifdel(struct bcm_cfg80211 *cfg, wl_if_event_info *
 		}
 
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 		dhd_wlfc_get_enable(dhd, &enabled);
 		if (enabled && cfg->wlfc_on && dhd->op_mode != DHD_FLAG_HOSTAP_MODE &&
 			dhd->op_mode != DHD_FLAG_IBSS_MODE) {
 			dhd_wlfc_deinit(dhd);
 			cfg->wlfc_on = false;
 		}
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 	}
 
@@ -3793,6 +3815,42 @@ static s32 wl_cfg80211_leave_ibss(struct wiphy *wiphy, struct net_device *dev)
 	return err;
 }
 
+#ifdef MFP
+static int wl_cfg80211_get_rsn_capa(bcm_tlv_t *wpa2ie, u8* capa)
+{
+	u16 suite_count;
+	wpa_suite_mcast_t *mcast;
+	wpa_suite_ucast_t *ucast;
+	u16 len;
+	wpa_suite_auth_key_mgmt_t *mgmt;
+
+	if (!wpa2ie)
+		return -1;
+
+	len = wpa2ie->len;
+	mcast = (wpa_suite_mcast_t *)&wpa2ie->data[WPA2_VERSION_LEN];
+	if ((len -= WPA_SUITE_LEN) <= 0)
+		return BCME_BADLEN;
+	ucast = (wpa_suite_ucast_t *)&mcast[1];
+	suite_count = ltoh16_ua(&ucast->count);
+	if ((suite_count > NL80211_MAX_NR_CIPHER_SUITES) ||
+		(len -= (WPA_IE_SUITE_COUNT_LEN +
+		(WPA_SUITE_LEN * suite_count))) <= 0)
+		return BCME_BADLEN;
+	mgmt = (wpa_suite_auth_key_mgmt_t *)&ucast->list[suite_count];
+	suite_count = ltoh16_ua(&mgmt->count);
+
+	if ((suite_count > NL80211_MAX_NR_CIPHER_SUITES) ||
+		(len -= (WPA_IE_SUITE_COUNT_LEN +
+		(WPA_SUITE_LEN * suite_count))) >= RSN_CAP_LEN) {
+		capa[0] = *(u8 *)&mgmt->list[suite_count];
+		capa[1] = *((u8 *)&mgmt->list[suite_count] + 1);
+	} else
+		return BCME_BADLEN;
+
+	return 0;
+}
+#endif /* MFP */
 
 static s32
 wl_set_wpa_version(struct net_device *dev, struct cfg80211_connect_params *sme)
@@ -3969,6 +4027,11 @@ wl_set_key_mgmt(struct net_device *dev, struct cfg80211_connect_params *sme)
 	s32 val = 0;
 	s32 err = 0;
 	s32 bssidx;
+#ifdef MFP
+	s32 mfp = WL_MFP_NONE;
+	bcm_tlv_t *wpa2_ie;
+	u8 rsn_cap[2];
+#endif /* MFP */
 
 	if ((bssidx = wl_get_bssidx_by_wdev(cfg, dev->ieee80211_ptr)) < 0) {
 		WL_ERR(("Find p2p index from wdev(%p) failed\n", dev->ieee80211_ptr));
@@ -4001,9 +4064,27 @@ wl_set_key_mgmt(struct net_device *dev, struct cfg80211_connect_params *sme)
 			case WLAN_AKM_SUITE_8021X:
 				val = WPA2_AUTH_UNSPECIFIED;
 				break;
+#ifdef MFP
+			case WL_AKM_SUITE_SHA256_1X:
+				val = WPA2_AUTH_1X_SHA256;
+				break;
+			case WL_AKM_SUITE_SHA256_PSK:
+				val = WPA2_AUTH_PSK_SHA256;
+				break;
+#endif /* MFP */
 			case WLAN_AKM_SUITE_PSK:
 				val = WPA2_AUTH_PSK;
 				break;
+#if defined(WLFBT) && defined(WLAN_AKM_SUITE_FT_8021X)
+			case WLAN_AKM_SUITE_FT_8021X:
+				val = WPA2_AUTH_UNSPECIFIED | WPA2_AUTH_FT;
+				break;
+#endif
+#if defined(WLFBT) && defined(WLAN_AKM_SUITE_FT_PSK)
+			case WLAN_AKM_SUITE_FT_PSK:
+				val = WPA2_AUTH_PSK | WPA2_AUTH_FT;
+				break;
+#endif
 			default:
 				WL_ERR(("invalid cipher group (%d)\n",
 					sme->crypto.cipher_group));
@@ -4011,6 +4092,33 @@ wl_set_key_mgmt(struct net_device *dev, struct cfg80211_connect_params *sme)
 			}
 		}
 
+#ifdef MFP
+		if (((wpa2_ie = bcm_parse_tlvs((u8 *)sme->ie, sme->ie_len,
+			DOT11_MNG_RSN_ID)) != NULL) &&
+			(wl_cfg80211_get_rsn_capa(wpa2_ie, rsn_cap) == 0)) {
+				/* Check for MFP cap in the RSN capability field */
+				if (rsn_cap[0] & RSN_CAP_MFPR) {
+					mfp = WL_MFP_REQUIRED;
+				} else if (rsn_cap[0] & RSN_CAP_MFPC) {
+					mfp = WL_MFP_CAPABLE;
+				}
+		}
+		err = wldev_iovar_setint(dev, "mfp", mfp);
+		if (unlikely(err)) {
+			if (!mfp && (err == BCME_UNSUPPORTED)) {
+				/* For non-mfp cases, if firmware doesn't support MFP
+				 * ignore the failure and proceed ahead.
+				 */
+				WL_DBG(("fw doesn't support mfp \n"));
+				err = 0;
+			} else {
+				WL_ERR(("mfp set failed ret:%d \n", err));
+				return err;
+			}
+		} else {
+			WL_DBG(("mfp set to 0x%x \n", mfp));
+		}
+#endif /* MFP */
 
 		WL_DBG(("setting wpa_auth to 0x%x\n", val));
 
@@ -4868,6 +4976,37 @@ wl_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
 		val = AES_ENABLED;
 		WL_DBG(("WLAN_CIPHER_SUITE_CCMP\n"));
 		break;
+#if defined(WLFBT) && defined(WLAN_CIPHER_SUITE_PMK)
+	case WLAN_CIPHER_SUITE_PMK: {
+		int j;
+		wsec_pmk_t pmk;
+		char keystring[WSEC_MAX_PSK_LEN + 1];
+		char* charptr = keystring;
+		uint len;
+		struct wl_security *sec;
+
+		sec = wl_read_prof(cfg, dev, WL_PROF_SEC);
+		if (sec->wpa_auth == WLAN_AKM_SUITE_8021X) {
+			err = wldev_iovar_setbuf(dev, "okc_info_pmk", (void *)params->key,
+				WSEC_MAX_PSK_LEN / 2, keystring, sizeof(keystring), NULL);
+			if (err) {
+				/* could fail in case that 'okc' is not supported */
+				WL_INFORM(("Setting 'okc_info_pmk' failed, err=%d\n", err));
+			}
+		}
+		/* copy the raw hex key to the appropriate format */
+		for (j = 0; j < (WSEC_MAX_PSK_LEN / 2); j++) {
+			charptr += snprintf(charptr, sizeof(keystring), "%02x", params->key[j]);
+		}
+		len = strlen(keystring);
+		pmk.key_len = htod16(len);
+		bcopy(keystring, pmk.key, len);
+		pmk.flags = htod16(WSEC_PASSPHRASE);
+		err = wldev_ioctl(dev, WLC_SET_WSEC_PMK, &pmk, sizeof(pmk), true);
+		if (err)
+			return err;
+	} break;
+#endif /* WLFBT && WLAN_CIPHER_SUITE_PMK */
 	default:
 		WL_ERR(("Invalid cipher (0x%x)\n", params->cipher));
 		return -EINVAL;
@@ -4931,8 +5070,10 @@ wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
 	}
 	WL_DBG(("Enter\n"));
 
+#ifndef MFP
 	if ((key_idx >= DOT11_MAX_DEFAULT_KEYS) && (key_idx < DOT11_MAX_DEFAULT_KEYS+2))
 		return -EINVAL;
+#endif
 
 	RETURN_EIO_IF_NOT_UP(cfg);
 	memset(&key, 0, sizeof(key));
@@ -5023,8 +5164,12 @@ static s32
 wl_cfg80211_config_default_mgmt_key(struct wiphy *wiphy,
 	struct net_device *dev, u8 key_idx)
 {
+#ifdef MFP
+	return 0;
+#else
 	WL_INFORM(("Not supported\n"));
 	return -EOPNOTSUPP;
+#endif /* MFP */
 }
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
@@ -5333,6 +5478,32 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
 #endif /* DHD_CLEAR_ON_SUSPEND */
 
 
+#ifdef CUS_11321
+	{
+		struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+		struct net_device *ndev = bcmcfg_to_prmry_ndev(cfg);
+		u8 gpiopol = 0; // 0:Set active high when wake up, 1:Set active low when wake up
+		char strclear[6] = "clear";
+		u32 wowl = WL_WOWL_DIS | WL_WOWL_BCN | WL_WOWL_GTK_FAILURE | WL_WOWL_RETR |
+			WL_WOWL_TCPKEEP_TIME | WL_WOWL_TCPKEEP_DATA;
+
+		/* enable ARPOE */
+		wldev_iovar_setint(ndev, "arpoe", 1);
+		wldev_iovar_setint(ndev, "arp_ol", 0xf);
+		wldev_iovar_setint(ndev, "arp_peerage", 1000000);
+
+		/* enable GTKOE */
+		wldev_iovar_setint(ndev, "wake_event_enable", 4);
+
+		/* enable WOWL */
+		wldev_iovar_setint(ndev, "wowl_gpiopol", gpiopol);
+		wldev_iovar_setbuf(ndev, "wowl_wakeind", strclear, sizeof(strclear),
+			cfg->ioctl_buf, WLC_IOCTL_MAXLEN, &cfg->ioctl_buf_sync);
+		wldev_iovar_setint(ndev, "wowl", wowl);
+		wldev_iovar_setint(ndev, "wowl_activate", 1);
+	}
+#endif
+
 	return err;
 }
 
@@ -6714,6 +6885,10 @@ wl_validate_wpa2ie(struct net_device *dev, bcm_tlv_t *wpa2ie, s32 bssidx)
 	wpa_suite_auth_key_mgmt_t *mgmt;
 	wpa_pmkid_list_t *pmkid;
 	int cnt = 0;
+#ifdef MFP
+	int mfp = 0;
+	struct bcm_cfg80211 *cfg = g_bcm_cfg;
+#endif /* MFP */
 
 	u16 suite_count;
 	u8 rsn_cap[2];
@@ -6786,6 +6961,14 @@ wl_validate_wpa2ie(struct net_device *dev, bcm_tlv_t *wpa2ie, s32 bssidx)
 		case RSN_AKM_PSK:
 				wpa_auth |= WPA2_AUTH_PSK;
 				break;
+#ifdef MFP
+			case RSN_AKM_MFP_PSK:
+				wpa_auth |= WPA2_AUTH_PSK_SHA256;
+				break;
+			case RSN_AKM_MFP_1X:
+				wpa_auth |= WPA2_AUTH_1X_SHA256;
+			break;
+#endif /* MFP */
 		default:
 			WL_ERR(("No Key Mgmt Info\n"));
 		}
@@ -6801,6 +6984,23 @@ wl_validate_wpa2ie(struct net_device *dev, bcm_tlv_t *wpa2ie, s32 bssidx)
 			wme_bss_disable = 1;
 		}
 
+#ifdef MFP
+	if (rsn_cap[0] & RSN_CAP_MFPR) {
+		WL_DBG(("MFP Required \n"));
+		mfp = WL_MFP_REQUIRED;
+		/* Our firmware has requirement that WPA2_AUTH_PSK/WPA2_AUTH_UNSPECIFIED
+		 * be set, if SHA256 OUI is to be included in the rsn ie.
+		 */
+		if (wpa_auth & WPA2_AUTH_PSK_SHA256) {
+			wpa_auth |= WPA2_AUTH_PSK;
+		} else if (wpa_auth & WPA2_AUTH_1X_SHA256) {
+			wpa_auth |= WPA2_AUTH_UNSPECIFIED;
+		}
+	} else if (rsn_cap[0] & RSN_CAP_MFPC) {
+		WL_DBG(("MFP Capable \n"));
+		mfp = WL_MFP_CAPABLE;
+	}
+#endif /* MFP */
 
 		/* set wme_bss_disable to sync RSN Capabilities */
 		err = wldev_iovar_setint_bsscfg(dev, "wme_bss_disable", wme_bss_disable, bssidx);
@@ -6824,6 +7024,19 @@ wl_validate_wpa2ie(struct net_device *dev, bcm_tlv_t *wpa2ie, s32 bssidx)
 		/* so don't bother to send down this info to firmware */
 	}
 
+#ifdef MFP
+	len -= WPA2_PMKID_COUNT_LEN;
+	if (len >= WPA_SUITE_LEN) {
+		err = wldev_iovar_setbuf_bsscfg(dev, "bip",
+		(void *)((u8 *)&mgmt->list[suite_count] + RSN_CAP_LEN + WPA2_PMKID_COUNT_LEN),
+		WPA_SUITE_LEN,
+		cfg->ioctl_buf, WLC_IOCTL_SMLEN, bssidx, &cfg->ioctl_buf_sync);
+		if (err < 0) {
+			WL_ERR(("bip set error %d\n", err));
+			return BCME_ERROR;
+		}
+	}
+#endif
 
 	/* set auth */
 	err = wldev_iovar_setint_bsscfg(dev, "auth", auth, bssidx);
@@ -6839,6 +7052,17 @@ wl_validate_wpa2ie(struct net_device *dev, bcm_tlv_t *wpa2ie, s32 bssidx)
 		return BCME_ERROR;
 	}
 
+#ifdef MFP
+	if (mfp) {
+		/* This needs to go after wsec otherwise the wsec command will
+		 * overwrite the values set by MFP
+		 */
+		if ((err = wldev_iovar_setint_bsscfg(dev, "mfp", mfp, bssidx)) < 0) {
+			WL_ERR(("MFP Setting failed. ret = %d \n", err));
+			return err;
+		}
+	}
+#endif /* MFP */
 
 	/* set upper-layer auth */
 	err = wldev_iovar_setint_bsscfg(dev, "wpa_auth", wpa_auth, bssidx);
@@ -7758,6 +7982,7 @@ wl_cfg80211_stop_ap(
 	int ap = 0;
 	s32 bssidx = 0;
 	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+	struct net_device *primary_ndev = bcmcfg_to_prmry_ndev(cfg);
 	s32 is_rsdb_supported = BCME_ERROR;
 	dhd_pub_t *dhd = (dhd_pub_t *)(cfg->pub);
 
@@ -7796,37 +8021,64 @@ wl_cfg80211_stop_ap(
 	}
 
 	if (dev_role == NL80211_IFTYPE_AP) {
-		/*
-		 * Bring down the AP interface by changing role to STA.
-		 * Don't do a down or "WLC_SET_AP 0" since the shared
-		 * interface may be still running
-		 */
-		if (is_rsdb_supported) {
-			if ((err = wl_cfg80211_add_del_bss(cfg, dev,
-				bssidx, NL80211_IFTYPE_STATION, 0, NULL)) < 0) {
-				if ((err = wldev_ioctl(dev, WLC_SET_AP, &ap, sizeof(s32),
-					true)) < 0) {
-					WL_ERR(("setting AP mode failed %d \n", err));
+		if (bssidx == 0) {
+			/*
+			 * Bring down the AP interface by changing role to STA.
+			 * Don't do a down or "WLC_SET_AP 0" since the shared
+			 * interface may be still running
+			 */
+			if (is_rsdb_supported) {
+				if ((err = wl_cfg80211_add_del_bss(cfg, dev,
+					bssidx, NL80211_IFTYPE_STATION, 0, NULL)) < 0) {
+					if ((err = wldev_ioctl(dev, WLC_SET_AP, &ap, sizeof(s32),
+						true)) < 0) {
+						WL_ERR(("setting AP mode failed %d \n", err));
+						err = -ENOTSUPP;
+						goto exit;
+					}
+				}
+			} else if (is_rsdb_supported == 0) {
+				if (dev == primary_ndev) {
+					err = wldev_ioctl(dev, WLC_DOWN, &ap, sizeof(s32), true);
+					if (err < 0) {
+						WL_ERR(("WLC_DOWN error (%d)\n", err));
+						err = -ENOTSUPP;
+						goto exit;
+					}
+
+					err = wldev_ioctl(dev, WLC_SET_AP, &ap, sizeof(s32), true);
+					if (err < 0) {
+						WL_ERR(("SET AP error %d\n", err));
+						err = -ENOTSUPP;
+						goto exit;
+					}
+
+					err = wldev_ioctl(dev, WLC_UP, &ap, sizeof(s32), true);
+					if (err < 0) {
+						WL_ERR(("WLC_UP error (%d)\n", err));
+						err = -ENOTSUPP;
+						goto exit;
+					}
+				}
+
+				err = wldev_ioctl(dev, WLC_SET_INFRA, &infra, sizeof(s32), true);
+				if (err < 0) {
+					WL_ERR(("SET INFRA error %d\n", err));
 					err = -ENOTSUPP;
 					goto exit;
 				}
+				err = wldev_ioctl(dev, WLC_UP, &ap, sizeof(s32), true);
+				if (unlikely(err)) {
+					WL_ERR(("WLC_UP error (%d)\n", err));
+					err = -EINVAL;
+					goto exit;
+				}
 			}
-		} else if (is_rsdb_supported == 0) {
-			if ((err = wldev_ioctl(dev, WLC_SET_AP, &ap, sizeof(s32), true)) < 0) {
-				WL_ERR(("setting AP mode failed %d \n", err));
-				err = -ENOTSUPP;
-				goto exit;
-			}
-			err = wldev_ioctl(dev, WLC_SET_INFRA, &infra, sizeof(s32), true);
-			if (err < 0) {
-				WL_ERR(("SET INFRA error %d\n", err));
-				err = -ENOTSUPP;
-				goto exit;
-			}
-			err = wldev_ioctl(dev, WLC_UP, &ap, sizeof(s32), true);
-			if (unlikely(err)) {
-				WL_ERR(("WLC_UP error (%d)\n", err));
-				err = -EINVAL;
+		} else if (cfg->cfgdev_bssidx && (bssidx == cfg->cfgdev_bssidx)) {
+			WL_DBG(("Stop SoftAP on virtual Interface bssidx:%d \n", bssidx));
+			if ((err = wl_cfg80211_add_del_bss(cfg, dev,
+                    bssidx, NL80211_IFTYPE_STATION, 0, NULL)) < 0) {
+				WL_ERR(("wl add_del_bss returned error:%d\n", err));
 				goto exit;
 			}
 		}
@@ -8737,8 +8989,6 @@ static s32 wl_setup_wiphy(struct wireless_dev *wdev, struct device *sdiofunc_dev
 	/* If this is not provided cfg stack will get disconnect
 	 * during suspend.
 	 */
-
-#if (1)
 	brcm_wowlan_config = kmalloc(sizeof(struct cfg80211_wowlan), GFP_KERNEL);
 	if (brcm_wowlan_config) {
 		brcm_wowlan_config->disconnect = true;
@@ -8755,7 +9005,6 @@ static s32 wl_setup_wiphy(struct wireless_dev *wdev, struct device *sdiofunc_dev
 		WL_ERR(("Can not allocate memory for brcm_wowlan_config,"
 					" So wiphy->wowlan_config is set to NULL\n"));
 	}
-#endif
 	wdev->wiphy->wowlan_config = brcm_wowlan_config;
 #else
 	wdev->wiphy->wowlan.flags = WIPHY_WOWLAN_ANY;
@@ -9380,15 +9629,17 @@ wl_notify_connect_status(struct bcm_cfg80211 *cfg, bcm_struct_cfgdev *cfgdev,
 			wl_cfg80211_cancel_scan(cfg);
 
 			/* Explicitly calling unlink to remove BSS in CFG */
-			wiphy = bcmcfg_to_wiphy(cfg);
-			ssid = (struct wlc_ssid *)wl_read_prof(cfg, ndev, WL_PROF_SSID);
-			bssid = (u8 *)wl_read_prof(cfg, ndev, WL_PROF_BSSID);
-			if (ssid && bssid) {
-				bss = cfg80211_get_bss(wiphy, NULL, bssid,
-					ssid->SSID, ssid->SSID_len, WLAN_CAPABILITY_ESS,
-					WLAN_CAPABILITY_ESS);
-				if (bss) {
-					cfg80211_unlink_bss(wiphy, bss);
+			if (wl_cfgp2p_vif_created(cfg)) {
+				wiphy = bcmcfg_to_wiphy(cfg);
+				ssid = (struct wlc_ssid *)wl_read_prof(cfg, ndev, WL_PROF_SSID);
+				bssid = (u8 *)wl_read_prof(cfg, ndev, WL_PROF_BSSID);
+				if (ssid && bssid) {
+					bss = cfg80211_get_bss(wiphy, NULL, bssid,
+						ssid->SSID, ssid->SSID_len, WLAN_CAPABILITY_ESS,
+						WLAN_CAPABILITY_ESS);
+					if (bss) {
+						cfg80211_unlink_bss(wiphy, bss);
+					}
 				}
 			}
 
@@ -9893,14 +10144,22 @@ wl_bss_roaming_done(struct bcm_cfg80211 *cfg, struct net_device *ndev,
 	struct wl_connect_info *conn_info = wl_to_conn(cfg);
 	s32 err = 0;
 	u8 *curbssid;
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39))
+#if (((LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39)) || \
+       defined(WL_COMPAT_WIRELESS)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0)))
 	struct wiphy *wiphy = bcmcfg_to_wiphy(cfg);
 	struct ieee80211_supported_band *band;
 	struct ieee80211_channel *notify_channel = NULL;
 	u32 *channel;
 	u32 freq;
-#endif 
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0))
+        struct cfg80211_roam_info info;
+#endif
 
+#ifdef WLFBT
+	uint32 data_len = 0;
+	if (data)
+		data_len = ntoh32(e->datalen);
+#endif /* WLFBT */
 
 	wl_get_assoc_ies(cfg, ndev);
 	wl_update_prof(cfg, ndev, NULL, (const void *)(e->addr.octet), WL_PROF_BSSID);
@@ -9908,7 +10167,8 @@ wl_bss_roaming_done(struct bcm_cfg80211 *cfg, struct net_device *ndev,
 	wl_update_bss_info(cfg, ndev, true);
 	wl_update_pmklist(ndev, cfg->pmk_list, err);
 
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39))
+#if (((LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39)) || \
+        defined(WL_COMPAT_WIRELESS)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0)))
 	/* channel info for cfg80211_roamed introduced in 2.6.39-rc1 */
 	channel = (u32 *)wl_read_prof(cfg, ndev, WL_PROF_CHAN);
 	if (*channel <= CH_MAX_2G_CHANNEL)
@@ -9918,16 +10178,36 @@ wl_bss_roaming_done(struct bcm_cfg80211 *cfg, struct net_device *ndev,
 	freq = ieee80211_channel_to_frequency(*channel, band->band);
 	notify_channel = ieee80211_get_channel(wiphy, freq);
 #endif 
+#ifdef WLFBT
+	/* back up the given FBT key for the further supplicant request,
+	 * currently not checking the FBT is enabled for current BSS in DHD,
+	 * because the supplicant decides to take it or not.
+	 */
+	if (data && (data_len == FBT_KEYLEN)) {
+		memcpy(cfg->fbt_key, data, FBT_KEYLEN);
+	}
+#endif /* WLFBT */
 	printk("wl_bss_roaming_done succeeded to " MACDBG "\n",
 		MAC2STRDBG((const u8*)(&e->addr)));
 
-	cfg80211_roamed(ndev,
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39))
-		notify_channel,
+#if ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32)) && \
+       (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 39)))
+       cfg80211_roamed(ndev, curbssid, conn_info->req_ie, conn_info->req_ie_len,
+               conn_info->resp_ie, conn_info->resp_ie_len, GFP_KERNEL);
+#elif (((LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 39)) || \
+       defined(WL_COMPAT_WIRELESS)) && (LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0)))
+       cfg80211_roamed(ndev, notify_channel, curbssid, conn_info->req_ie,
+              conn_info->req_ie_len, conn_info->resp_ie, conn_info->resp_ie_len,
+               GFP_KERNEL);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0))
+       info.bssid = curbssid;
+       info.req_ie = conn_info->req_ie;
+       info.req_ie_len = conn_info->req_ie_len;
+       info.resp_ie = conn_info->resp_ie;
+       info.resp_ie_len = conn_info->resp_ie_len;
+
+       cfg80211_roamed(ndev, &info, GFP_KERNEL);
 #endif
-		curbssid,
-		conn_info->req_ie, conn_info->req_ie_len,
-		conn_info->resp_ie, conn_info->resp_ie_len, GFP_KERNEL);
 	WL_DBG(("Report roaming result\n"));
 
 	wl_set_drv_status(cfg, CONNECTED, ndev);
@@ -12032,9 +12312,9 @@ static s32 wl_init_priv(struct bcm_cfg80211 *cfg)
 	cfg->active_scan = true;
 	cfg->rf_blocked = false;
 	cfg->vsdb_mode = false;
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 	cfg->wlfc_on = false;
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 	cfg->roam_flags |= WL_ROAM_OFF_ON_CONCURRENT;
 	cfg->disable_roam_event = false;
 	cfg->cfgdev_bssidx = -1;
@@ -13133,9 +13413,9 @@ static s32 __wl_cfg80211_down(struct bcm_cfg80211 *cfg)
 	struct net_device *p2p_net = cfg->p2p_net;
 #endif 
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 	dhd_pub_t *dhd =  (dhd_pub_t *)(cfg->pub);
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 	WL_DBG(("In\n"));
 	/* Delete pm_enable_work */
@@ -13148,7 +13428,7 @@ static s32 __wl_cfg80211_down(struct bcm_cfg80211 *cfg)
 	if (cfg->p2p_supported) {
 		wl_clr_p2p_status(cfg, GO_NEG_PHASE);
 #ifdef PROP_TXSTATUS_VSDB
-#if defined(BCMSDIO)
+#if defined(BCMSDIO) || defined(BCMDBUS)
 		if (wl_cfgp2p_vif_created(cfg)) {
 			bool enabled = false;
 			dhd_wlfc_get_enable(dhd, &enabled);
@@ -13158,7 +13438,7 @@ static s32 __wl_cfg80211_down(struct bcm_cfg80211 *cfg)
 				cfg->wlfc_on = false;
 			}
 		}
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 #endif /* PROP_TXSTATUS_VSDB */
 	}
 
@@ -15336,6 +15616,13 @@ wl_get_public_action(void *frame, u32 frame_len, u8 *ret_action)
 	return BCME_OK;
 }
 
+#ifdef WLFBT
+void
+wl_cfg80211_get_fbt_key(uint8 *key)
+{
+	memcpy(key, g_bcm_cfg->fbt_key, FBT_KEYLEN);
+}
+#endif /* WLFBT */
 
 static int
 wl_cfg80211_delayed_roam(struct bcm_cfg80211 *cfg, struct net_device *ndev,
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.h
index 06a6f20e602d..b4d04b6c6584 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg80211.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 driver
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
@@ -488,6 +489,9 @@ struct parsed_ies {
 /* Max length of Interworking element */
 #define IW_IES_MAX_BUF_LEN 		9
 #endif
+#ifdef WLFBT
+#define FBT_KEYLEN		32
+#endif
 #define MAX_EVENT_BUF_NUM 16
 typedef struct wl_eventmsg_buf {
     u16 num;
@@ -566,9 +570,9 @@ struct bcm_cfg80211 {
 	bool pwr_save;
 	bool roam_on;		/* on/off switch for self-roaming */
 	bool scan_tried;	/* indicates if first scan attempted */
-#if defined(BCMSDIO) || defined(BCMPCIE)
+#if defined(BCMSDIO) || defined(BCMDBUS) || defined(BCMPCIE)
 	bool wlfc_on;
-#endif 
+#endif /* defined(BCMSDIO) || defined(BCMDBUS) */
 	bool vsdb_mode;
 #define WL_ROAM_OFF_ON_CONCURRENT		0x0001
 #define WL_ROAM_OFF_REVERT				0x0002
@@ -626,6 +630,9 @@ struct bcm_cfg80211 {
 	bcm_struct_cfgdev *bss_cfgdev;  /* For DUAL STA/STA+AP */
 	s32 cfgdev_bssidx;
 	bool bss_pending_op;		/* indicate where there is a pending IF operation */
+#ifdef WLFBT
+	uint8 fbt_key[FBT_KEYLEN];
+#endif
 	int roam_offload;
 #ifdef WL_NAN
 	bool nan_enable;
@@ -1167,7 +1174,20 @@ wl_get_netinfo_by_wdev(struct bcm_cfg80211 *cfg, struct wireless_dev *wdev)
 	 (!_sme->crypto.n_ciphers_pairwise) && \
 	 (!_sme->crypto.cipher_group))
 
+#ifdef WLFBT
+#if defined(WLAN_AKM_SUITE_FT_8021X) && defined(WLAN_AKM_SUITE_FT_PSK)
+#define IS_AKM_SUITE_FT(sec) (sec->wpa_auth == WLAN_AKM_SUITE_FT_8021X || \
+	sec->wpa_auth == WLAN_AKM_SUITE_FT_PSK)
+#elif defined(WLAN_AKM_SUITE_FT_8021X)
+#define IS_AKM_SUITE_FT(sec) (sec->wpa_auth == WLAN_AKM_SUITE_FT_8021X)
+#elif defined(WLAN_AKM_SUITE_FT_PSK)
+#define IS_AKM_SUITE_FT(sec) (sec->wpa_auth == WLAN_AKM_SUITE_FT_PSK)
+#else
 #define IS_AKM_SUITE_FT(sec) false
+#endif /* WLAN_AKM_SUITE_FT_8021X && WLAN_AKM_SUITE_FT_PSK */
+#else
+#define IS_AKM_SUITE_FT(sec) false
+#endif /* WLFBT */
 
 #define IS_AKM_SUITE_CCKM(sec) false
 
@@ -1279,6 +1299,9 @@ extern int wl_cfg80211_set_mgmt_vndr_ies(struct bcm_cfg80211 *cfg,
 	bcm_struct_cfgdev *cfgdev, s32 bssidx, s32 pktflag,
 	const u8 *vndr_ie, u32 vndr_ie_len);
 
+#ifdef WLFBT
+extern void wl_cfg80211_get_fbt_key(uint8 *key);
+#endif
 
 /* Action frame specific functions */
 extern u8 wl_get_action_category(void *frame, u32 frame_len);
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg_btcoex.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg_btcoex.c
index dbc41ed57cd3..cf5897a7a8b0 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg_btcoex.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfg_btcoex.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 driver - Dongle Host Driver (DHD) related
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgnan.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgnan.c
new file mode 100644
index 000000000000..e8ede6342383
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgnan.c
@@ -0,0 +1,2127 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Neighbor Awareness Networking
+ *
+ * Copyright (C) 1999-2018, Broadcom Corporation
+ * 
+ *      Unless you and Broadcom execute a separate written software license
+ * agreement governing use of this software, this software is licensed to you
+ * under the terms of the GNU General Public License version 2 (the "GPL"),
+ * available at http://www.broadcom.com/licenses/GPLv2.php, with the
+ * following added to such license:
+ * 
+ *      As a special exception, the copyright holders of this software give you
+ * permission to link this software with independent modules, and to copy and
+ * distribute the resulting executable under terms of your choice, provided that
+ * you also meet, for each linked independent module, the terms and conditions of
+ * the license of that module.  An independent module is a module which is not
+ * derived from this software.  The special exception does not apply to any
+ * modifications of the software.
+ * 
+ *      Notwithstanding the above, under no circumstances may you combine this
+ * software in any way with any other Broadcom software provided under a license
+ * other than the GPL, without Broadcom's express prior written consent.
+ *
+ * <<Broadcom-WL-IPTag/Open:>>
+ *
+ * $Id: wl_cfgnan.c 559906 2015-05-29 02:42:35Z $
+ */
+
+#include <bcmutils.h>
+#include <bcmendian.h>
+#include <bcmwifi_channels.h>
+#include <proto/nan.h>
+
+#include <wl_cfg80211.h>
+#include <wl_android.h>
+#include <wl_cfgnan.h>
+
+#ifdef WL_NAN_DEBUG
+static u8 g_nan_debug = true;
+#endif /* WL_NAN_DEBUG */
+
+static nan_cmd_t nan_cmds [] = {
+	{ "NAN_START", wl_cfgnan_start_handler },
+	{ "NAN_STOP", wl_cfgnan_stop_handler },
+	{ "NAN_SUPPORT", wl_cfgnan_support_handler },
+	{ "NAN_STATUS", wl_cfgnan_status_handler },
+	{ "NAN_PUBLISH", wl_cfgnan_pub_handler },
+	{ "NAN_SUBSCRIBE", wl_cfgnan_sub_handler },
+	{ "NAN_CANCEL_PUBLISH", wl_cfgnan_cancel_pub_handler },
+	{ "NAN_CANCEL_SUBSCRIBE", wl_cfgnan_cancel_sub_handler },
+	{ "NAN_TRANSMIT", wl_cfgnan_transmit_handler },
+	{ "NAN_SET_CONFIG", wl_cfgnan_set_config_handler },
+	{ "NAN_GET_CONFIG", NULL },
+	{ "NAN_RTT_CONFIG", wl_cfgnan_rtt_config_handler },
+	{ "NAN_RTT_FIND", wl_cfgnan_rtt_find_handler },
+#ifdef WL_NAN_DEBUG
+	{ "NAN_DEBUG", wl_cfgnan_debug_handler },
+#endif /* WL_NAN_DEBUG */
+#ifdef NAN_P2P_CONFIG
+	{ "NAN_ADD_CONF", wl_cfgnan_p2p_ie_add_handler },
+	{ "NAN_ENABLE_CONF", wl_cfgnan_p2p_ie_enable_handler },
+	{ "NAN_DEL_CONF", wl_cfgnan_p2p_ie_del_handler },
+#endif /* NAN_P2P_CONFIG */
+	{ NULL, NULL },
+};
+
+static nan_config_attr_t nan_config_attrs [] = {
+	{ "ATTR_MASTER", WL_NAN_XTLV_MASTER_PREF },
+	{ "ATTR_ID", WL_NAN_XTLV_CLUSTER_ID },
+	{ "ATTR_ADDR", WL_NAN_XTLV_IF_ADDR },
+	{ "ATTR_ROLE", WL_NAN_XTLV_ROLE },
+	{ "ATTR_BCN_INT", WL_NAN_XTLV_BCN_INTERVAL },
+	{ "ATTR_CHAN", WL_NAN_XTLV_MAC_CHANSPEC },
+	{ "ATTR_TX_RATE", WL_NAN_XTLV_MAC_TXRATE },
+	{ "ATTR_DW_LEN", WL_NAN_XTLV_DW_LEN },
+	{ {0}, 0 }
+};
+
+#ifdef WL_NAN_DEBUG
+void print_event_name(u32 event_num)
+{
+	char *event_name = NULL;
+
+	switch (event_num) {
+	case WL_NAN_EVENT_START:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_START);
+		break;
+	case WL_NAN_EVENT_JOIN:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_JOIN);
+		break;
+	case WL_NAN_EVENT_ROLE:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_ROLE);
+		break;
+	case WL_NAN_EVENT_SCAN_COMPLETE:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_SCAN_COMPLETE);
+		break;
+	case WL_NAN_EVENT_DISCOVERY_RESULT:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_DISCOVERY_RESULT);
+		break;
+	case WL_NAN_EVENT_REPLIED:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_REPLIED);
+		break;
+	case WL_NAN_EVENT_TERMINATED:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_TERMINATED);
+		break;
+	case WL_NAN_EVENT_RECEIVE:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_RECEIVE);
+		break;
+	case WL_NAN_EVENT_STATUS_CHG:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_STATUS_CHG);
+		break;
+	case WL_NAN_EVENT_MERGE:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_MERGE);
+		break;
+	case WL_NAN_EVENT_STOP:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_STOP);
+		break;
+	case WL_NAN_EVENT_P2P:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_P2P);
+		break;
+	case WL_NAN_EVENT_WINDOW_BEGIN_P2P:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_WINDOW_BEGIN_P2P);
+		break;
+	case WL_NAN_EVENT_WINDOW_BEGIN_MESH:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_WINDOW_BEGIN_MESH);
+		break;
+	case WL_NAN_EVENT_WINDOW_BEGIN_IBSS:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_WINDOW_BEGIN_IBSS);
+		break;
+	case WL_NAN_EVENT_WINDOW_BEGIN_RANGING:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_WINDOW_BEGIN_RANGING);
+		break;
+	case WL_NAN_EVENT_INVALID:
+		event_name = NAME_TO_STR(WL_NAN_EVENT_INVALID);
+		break;
+	default:
+		break;
+	}
+	if (event_name) {
+		WL_DBG((" event name: %s \n", event_name));
+	} else {
+		WL_DBG(("Unknown event %d\n", event_num));
+	}
+}
+#endif /* WL_NAN_DEBUG */
+
+int
+wl_cfgnan_set_vars_cbfn(void *ctx, uint8 *buf, uint16 type, uint16 len)
+{
+	wl_nan_tlv_data_t *ndata = ((wl_nan_tlv_data_t *)(ctx));
+	int ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+
+	WL_DBG((" enter, xtlv_type: 0x%x \n", type));
+
+	switch (type) {
+	case WL_NAN_XTLV_ENABLED:
+		memcpy(&ndata->enabled, buf, len);
+		break;
+	case WL_NAN_XTLV_MASTER_PREF:
+		/*
+		 * master role and preference  mac has them as two u8's,
+		 *
+		 * masterpref: val & 0x0ff
+		 * rnd_factor: val >> 8
+		 */
+		memcpy(&ndata->master_pref, buf, len);
+		break;
+	case WL_NAN_XTLV_IF_ADDR:
+		memcpy(&ndata->mac_addr, buf, len);
+		break;
+	case WL_NAN_XTLV_CLUSTER_ID:
+		memcpy(&ndata->clus_id, buf, len);
+		break;
+	case WL_NAN_XTLV_ROLE:
+		/*  nan device role, master, master-sync nosync etc  */
+		memcpy(&ndata->dev_role, buf, len);
+		break;
+	case WL_NAN_XTLV_MAC_CHANSPEC:
+		memcpy(&ndata->chanspec, buf, len);
+		if (wf_chspec_valid(ndata->chanspec)) {
+			wf_chspec_ntoa(ndata->chanspec, buf);
+			WL_DBG((" chanspec: %s 0x%x \n", buf, ndata->chanspec));
+		} else {
+			WL_DBG((" chanspec: 0x%x is not valid \n", ndata->chanspec));
+		}
+		break;
+	case WL_NAN_XTLV_MAC_AMR:
+		memcpy(ndata->amr, buf, len);
+		break;
+	case WL_NAN_XTLV_MAC_AMBTT:
+		memcpy(&ndata->ambtt, buf, len);
+		break;
+	case WL_NAN_XTLV_MAC_HOPCNT:
+		memcpy(&ndata->hop_count, buf, len);
+		break;
+	case WL_NAN_XTLV_INSTANCE_ID:
+		memcpy(&ndata->inst_id, buf, len);
+		break;
+	case WL_NAN_XTLV_SVC_NAME:
+		memcpy(ndata->svc_name, buf, len);
+		break;
+	case WL_NAN_XTLV_SVC_PARAMS:
+		memcpy(&ndata->params, buf, len);
+		break;
+	case WL_NAN_XTLV_MAC_STATUS:
+		memcpy(&ndata->nstatus, buf, len);
+		break;
+	case WL_NAN_XTLV_PUBLR_ID:
+		memcpy(&ndata->pub_id, buf, len);
+		break;
+	case WL_NAN_XTLV_SUBSCR_ID:
+		memcpy(&ndata->sub_id, buf, len);
+		break;
+	case WL_NAN_XTLV_MAC_ADDR:
+		memcpy(&ndata->mac_addr, buf, len);
+		break;
+	case WL_NAN_XTLV_VNDR:
+		ndata->vend_info.dlen = len;
+		ndata->vend_info.data = kzalloc(ndata->vend_info.dlen, kflags);
+		if (!ndata->vend_info.data) {
+			WL_ERR((" memory allocation failed \n"));
+			ret = -ENOMEM;
+			goto fail;
+		}
+		if (ndata->vend_info.data && ndata->vend_info.dlen) {
+			memcpy(ndata->vend_info.data, buf, len);
+		}
+		break;
+	case WL_NAN_XTLV_SVC_INFO:
+		ndata->svc_info.dlen = len;
+		ndata->svc_info.data = kzalloc(ndata->svc_info.dlen, kflags);
+		if (!ndata->svc_info.data) {
+			WL_ERR((" memory allocation failed \n"));
+			ret = -ENOMEM;
+			goto fail;
+		}
+		if (ndata->svc_info.data && ndata->svc_info.dlen) {
+			memcpy(ndata->svc_info.data, buf, len);
+		}
+		break;
+	case WL_NAN_XTLV_PEER_INSTANCE_ID:
+		memcpy(&ndata->peer_inst_id, buf, len);
+		break;
+	case WL_NAN_XTLV_NAN_SCANPARAMS:
+		memcpy(&ndata->scan_params, buf, len);
+		break;
+	case WL_NAN_XTLV_ZERO:
+		/* don't parse empty space in the buffer */
+		ret = BCME_ERROR;
+		break;
+
+	default:
+		break;
+	}
+
+fail:
+	return ret;
+}
+
+int
+wl_cfgnan_enable_events(struct net_device *ndev, struct bcm_cfg80211 *cfg)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	uint8 *pxtlv;
+	u32 event_mask = 0;
+	s32 ret = BCME_OK;
+	u16 start, end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	ret = wl_add_remove_eventmsg(ndev, WLC_E_NAN, true);
+	if (unlikely(ret)) {
+		WL_ERR((" nan event enable failed, error = %d \n", ret));
+		goto fail;
+	}
+#ifdef WL_NAN_DEBUG
+	if (g_nan_debug) {
+		/* enable all nan events */
+		event_mask = NAN_EVENT_MASK_ALL;
+	} else
+#endif /* WL_NAN_DEBUG */
+	{
+		/* enable only selected nan events to avoid unnecessary host wake up */
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_START);
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_JOIN);
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_DISCOVERY_RESULT);
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_RECEIVE);
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_TERMINATED);
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_STOP);
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_CLEAR_BIT);
+#ifdef NAN_P2P_CONFIG
+		event_mask |= NAN_EVENT_BIT(WL_NAN_EVENT_P2P);
+#endif /* NAN_P2P_CONFIG */
+		event_mask = htod32(event_mask);
+	}
+
+	start = end = NAN_IOCTL_BUF_SIZE;
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_EVENT_MASK);
+	pxtlv = nanioc->data;
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_EVENT_MASK,
+		sizeof(event_mask), &event_mask, BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	nanioc->len = start - end;
+	nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan event selective enable failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan event selective enable successful \n"));
+	}
+
+	ret = wl_add_remove_eventmsg(ndev, WLC_E_PROXD, true);
+	if (unlikely(ret)) {
+		WL_ERR((" proxd event enable failed, error = %d \n", ret));
+		goto fail;
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_enable_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	uint8 *pxtlv;
+	s32 ret = BCME_OK;
+	u16 start, end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+	uint8 val;
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan 1
+	 *
+	 * wpa_cli: DRIVER NAN_ENABLE
+	 */
+
+	/* nan enable */
+	val = 1;
+	start = end = NAN_IOCTL_BUF_SIZE;
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_ENABLE);
+	pxtlv = nanioc->data;
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_ENABLED,
+		sizeof(val), &val, BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	nanioc->len = start - end;
+	nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan enable failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		cfg->nan_enable = true;
+		WL_DBG((" nan enable successful \n"));
+	}
+
+	/* enable nan events */
+	ret = wl_cfgnan_enable_events(ndev, cfg);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_start_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	struct ether_addr cluster_id = ether_null;
+	uint8 *pxtlv;
+	s32 ret = BCME_OK;
+	u16 start, end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+	uint8 val;
+
+	if (cfg->nan_enable != true) {
+		ret = wl_cfgnan_enable_handler(ndev, cfg, cmd, cmd_data);
+		if (unlikely(ret)) {
+			goto fail;
+		}
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan join -start
+	 *
+	 * wpa_cli: DRIVER NAN_START
+	 */
+
+	/* nan join */
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	val = 1;
+	start = end = NAN_IOCTL_BUF_SIZE;
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_NAN_JOIN);
+	pxtlv = nanioc->data;
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_CLUSTER_ID,
+		ETHER_ADDR_LEN, &cluster_id, BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_START,
+		sizeof(val), &val, BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	nanioc->len = start - end;
+	nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan join failed, error = %d \n", ret));
+		goto fail;
+	}
+
+	WL_DBG((" nan join successful \n"));
+	cfg->nan_running = true;
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_stop_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	struct ether_addr cluster_id = ether_null;
+	uint8 *pxtlv;
+	s32 ret = BCME_OK;
+	u16 start, end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+	uint8 nan_enable = FALSE;
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan stop
+	 *     wl nan 0
+	 *
+	 * wpa_cli: DRIVER NAN_STOP
+	 */
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	if (cfg->nan_running == true) {
+		/* nan stop */
+
+		start = end = NAN_IOCTL_BUF_SIZE;
+		nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+		nanioc->id = htod16(WL_NAN_CMD_STOP);
+		pxtlv = nanioc->data;
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_CLUSTER_ID,
+			ETHER_ADDR_LEN, &cluster_id, BCM_XTLV_OPTION_ALIGN32);
+		if (unlikely(ret)) {
+			goto fail;
+		}
+		nanioc->len = start - end;
+		nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+		ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+			cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+		if (unlikely(ret)) {
+			WL_ERR((" nan stop failed, error = %d \n", ret));
+			goto fail;
+		} else {
+			cfg->nan_running = false;
+			WL_DBG((" nan stop successful \n"));
+		}
+	}
+
+	/* nan disable */
+	if (cfg->nan_enable == true) {
+		memset(nanioc, 0, nanioc_size);
+		start = end = NAN_IOCTL_BUF_SIZE;
+		nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+		nanioc->id = htod16(WL_NAN_CMD_ENABLE);
+		pxtlv = nanioc->data;
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_ENABLED,
+			sizeof(nan_enable), &nan_enable, BCM_XTLV_OPTION_ALIGN32);
+		if (unlikely(ret)) {
+			goto fail;
+		}
+		nanioc->len = start - end;
+		nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+		ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+			cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+		if (unlikely(ret)) {
+			WL_ERR((" nan disable failed, error = %d \n", ret));
+			goto fail;
+		} else {
+			cfg->nan_enable = false;
+			WL_DBG((" nan disable successful \n"));
+		}
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_support_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	uint8 *pxtlv;
+	s32 ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan
+	 *
+	 * wpa_cli: DRIVER NAN_SUPPORT
+	 */
+
+	/* nan support */
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_ENABLE);
+	pxtlv = nanioc->data;
+	nanioc->len = htod16(BCM_XTLV_HDR_SIZE + 1);
+	nanioc_size = sizeof(wl_nan_ioc_t) + sizeof(bcm_xtlv_t);
+	ret = wldev_iovar_getbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_SMLEN, &cfg->ioctl_buf_sync);
+	if (unlikely(ret)) {
+		WL_ERR((" nan is not supported, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan is supported \n"));
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_status_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	wl_nan_ioc_t *ioc_ret = NULL;
+	char *ptr = cmd;
+	char *end = cmd + size;
+	wl_nan_tlv_data_t tlv_data;
+	s32 ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan status
+	 *
+	 * wpa_cli: DRIVER NAN_STATUS
+	 */
+
+	/* nan status */
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_STATUS);
+	nanioc->len = NAN_IOCTL_BUF_SIZE;
+	nanioc_size = sizeof(wl_nan_ioc_t) + sizeof(bcm_xtlv_t);
+	ret = wldev_iovar_getbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan status failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan status successful \n"));
+	}
+
+	/* unpack the tlvs */
+	memset(&tlv_data, 0, sizeof(tlv_data));
+	ioc_ret = (wl_nan_ioc_t *)cfg->ioctl_buf;
+	if (!ioc_ret) {
+		goto fail;
+	}
+#ifdef WL_NAN_DEBUG
+	if (g_nan_debug) {
+		prhex(" nanioc->data: ", (uint8 *)ioc_ret->data, ioc_ret->len);
+	}
+#endif /* WL_NAN_DEBUG */
+	bcm_unpack_xtlv_buf(&tlv_data, ioc_ret->data, ioc_ret->len,
+		BCM_XTLV_OPTION_ALIGN32, wl_cfgnan_set_vars_cbfn);
+
+	ptr += snprintf(ptr, end-ptr, ROLE_PREFIX"%d", tlv_data.dev_role);
+	ptr += snprintf(ptr, end-ptr, " " AMR_PREFIX);
+	ptr += bcm_format_hex(ptr, tlv_data.amr, NAN_MASTER_RANK_LEN);
+	ptr += snprintf(ptr, end-ptr, " " CLUS_ID_PREFIX MACF, ETHER_TO_MACF(tlv_data.clus_id));
+	ptr += snprintf(ptr, end-ptr, " " AMBTT_PREFIX"0x%x", tlv_data.ambtt);
+	ptr += snprintf(ptr, end-ptr, " " HOP_COUNT_PREFIX"%d", tlv_data.hop_count);
+
+	/* nan scan param */
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_SCAN_PARAMS);
+	nanioc->len = NAN_IOCTL_BUF_SIZE;
+	nanioc_size = sizeof(wl_nan_ioc_t) + sizeof(bcm_xtlv_t);
+	ret = wldev_iovar_getbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan scan params failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan scan params successful \n"));
+	}
+
+	if (tlv_data.svc_info.data) {
+		kfree(tlv_data.svc_info.data);
+		tlv_data.svc_info.data = NULL;
+		tlv_data.svc_info.dlen = 0;
+	}
+	if (tlv_data.vend_info.data) {
+		kfree(tlv_data.vend_info.data);
+		tlv_data.vend_info.data = NULL;
+		tlv_data.vend_info.dlen = 0;
+	}
+	/* unpack the tlvs */
+	memset(&tlv_data, 0, sizeof(tlv_data));
+	ioc_ret = (wl_nan_ioc_t *)cfg->ioctl_buf;
+	ASSERT(ioc_ret != NULL);
+#ifdef WL_NAN_DEBUG
+	if (g_nan_debug) {
+		prhex(" nanioc->data: ", (uint8 *)ioc_ret->data, ioc_ret->len);
+	}
+#endif /* WL_NAN_DEBUG */
+	bcm_unpack_xtlv_buf(&tlv_data, ioc_ret->data, ioc_ret->len,
+		BCM_XTLV_OPTION_ALIGN32, wl_cfgnan_set_vars_cbfn);
+
+	ptr += snprintf(ptr, end-ptr, " " SCAN_PERIOD_PREFIX"%d",
+		tlv_data.scan_params.ms_dur);
+	ptr += snprintf(ptr, end-ptr, " " SCAN_INTERVAL_PREFIX"%d",
+		tlv_data.scan_params.ms_intvl*512);
+
+	if (ptr > end) {
+		WL_ERR(("Buffer overflow. userspace string truncated: %s, len: %zu\n",
+			cmd, strlen(cmd)));
+	}
+
+	WL_DBG((" formatted string for userspace: %s, len: %zu \n",
+		cmd, strlen(cmd)));
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+	if (tlv_data.svc_info.data) {
+		kfree(tlv_data.svc_info.data);
+		tlv_data.svc_info.data = NULL;
+		tlv_data.svc_info.dlen = 0;
+	}
+	if (tlv_data.vend_info.data) {
+		kfree(tlv_data.vend_info.data);
+		tlv_data.vend_info.data = NULL;
+		tlv_data.vend_info.dlen = 0;
+	}
+
+	return ret;
+}
+
+
+#ifdef NAN_P2P_CONFIG
+
+static void
+wl_p2p_nan_ioctl_make_header(wl_p2p_nan_ioc_t *p2p_nanioc, uint16 cmd_id, uint16 len)
+{
+	p2p_nanioc->version = htod16(WL_P2P_NAN_IOCTL_VERSION);
+	p2p_nanioc->id = cmd_id;
+	p2p_nanioc->len = htod16(len);
+}
+
+static int
+wl_p2p_nan_do_get_ioctl(struct net_device *ndev, struct bcm_cfg80211 *cfg,
+	wl_p2p_nan_ioc_t *p2p_nanioc, uint16 alloc_size)
+{
+	wl_p2p_nan_ioc_t *iocresp = NULL;
+	int res;
+	uint8 *val;
+	/*  send getbuf p2p nan iovar */
+	res = wldev_iovar_getbuf(ndev, "p2p_nan", p2p_nanioc, alloc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+
+	if (res == BCME_OK) {
+		iocresp = (wl_p2p_nan_ioc_t *)cfg->ioctl_buf;
+		if (iocresp == NULL) {
+			res = BCME_ERROR;
+			return res;
+		}
+		switch (iocresp->id) {
+			case WL_P2P_NAN_CMD_ENABLE:
+				val = iocresp->data;
+				WL_ERR(("wl p2p_nan status is %s\n",
+					*val == 1? "Enabled":"Disabled"));
+				break;
+			case WL_P2P_NAN_CMD_CONFIG: {
+				wl_p2p_nan_config_t *p_p2p_nan_cfg =
+					(wl_p2p_nan_config_t *)iocresp->data;
+				WL_ERR(("wl p2p nan ie len = %u\n", p_p2p_nan_cfg->ie_len));
+				prhex("P2P IE", p_p2p_nan_cfg->ie, p_p2p_nan_cfg->ie_len);
+			}
+			break;
+			default:
+			WL_ERR(("Unknown command %d\n", iocresp->id));
+			break;
+		}
+	}
+	return res;
+}
+
+
+int wl_cfgnan_p2p_ie_enable_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char* buf, int size, nan_cmd_data_t *cmd_data)
+{
+	int res = BCME_OK;
+	wl_p2p_nan_ioc_t *p2p_nanioc;
+	uint16 alloc_size = OFFSETOF(wl_p2p_nan_ioc_t, data) + P2P_NAN_IOC_BUFSZ;
+	void *pdata = NULL;
+	uint8 val;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	p2p_nanioc = kzalloc(alloc_size, kflags);
+	if (p2p_nanioc == NULL) {
+		WL_ERR((" memory allocation failed \n"));
+		return BCME_NOMEM;
+	}
+
+	wl_p2p_nan_ioctl_make_header(p2p_nanioc, WL_P2P_NAN_CMD_ENABLE, sizeof(uint8));
+
+	if (cmd_data->p2p_info.data == NULL) { /* get  */
+		res = wl_p2p_nan_do_get_ioctl(ndev, cfg, p2p_nanioc, alloc_size);
+	} else {	/* set */
+
+		val =  (uint8) cmd_data->p2p_info.data[0];
+		pdata = p2p_nanioc->data;
+		memcpy(pdata, &val, sizeof(uint8));
+		res = wldev_iovar_setbuf(ndev, "p2p_nan", p2p_nanioc,
+			alloc_size, cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	}
+
+	kfree(p2p_nanioc);
+	return res;
+}
+int wl_cfgnan_p2p_ie_add_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	int res = BCME_OK;
+	int ie_len, data_len;
+	wl_p2p_nan_ioc_t *p2p_nanioc;
+	uint16 alloc_size = OFFSETOF(wl_p2p_nan_ioc_t, data) + cmd_data->p2p_info.dlen;
+	wl_p2p_nan_config_t *p_p2p_nan_cfg;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+
+	p2p_nanioc = kzalloc(alloc_size, kflags);
+	if (p2p_nanioc == NULL)
+		return BCME_NOMEM;
+
+	cmd_data->p2p_info.dlen /= 2;	/* Number of hex values will be half of ascii */
+	wl_p2p_nan_ioctl_make_header(p2p_nanioc, WL_P2P_NAN_CMD_CONFIG, P2P_NAN_IOC_BUFSZ);
+
+	if (cmd_data->p2p_info.data == NULL) { /* get */
+		wl_p2p_nan_do_get_ioctl(ndev, cfg, p2p_nanioc, alloc_size);
+	} else {
+		ie_len = cmd_data->p2p_info.dlen;
+		data_len = OFFSETOF(wl_p2p_nan_config_t, ie) + ie_len;
+
+		p_p2p_nan_cfg = (wl_p2p_nan_config_t *)p2p_nanioc->data;
+		p_p2p_nan_cfg->version = WL_P2P_NAN_CONFIG_VERSION;
+		p_p2p_nan_cfg->len = data_len;
+		p_p2p_nan_cfg->ie_len = ie_len;
+
+	if (!wl_cfg80211_hex_str_to_bin
+		(p_p2p_nan_cfg->ie, (int)p_p2p_nan_cfg->ie_len, (uchar*)cmd_data->p2p_info.data)) {
+		res = BCME_BADARG;
+		goto fail;
+	}
+	p2p_nanioc->len = htod16(data_len);
+
+	res = wldev_iovar_setbuf(ndev, "p2p_nan", p2p_nanioc, alloc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	}
+fail:
+	kfree(p2p_nanioc);
+	return res;
+}
+int wl_cfgnan_p2p_ie_del_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	int res = BCME_OK;
+	wl_p2p_nan_ioc_t *p2p_nanioc;
+	uint16 alloc_size = OFFSETOF(wl_p2p_nan_ioc_t, data);
+
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	p2p_nanioc = kzalloc(alloc_size, kflags);
+	if (p2p_nanioc == NULL) {
+		WL_ERR((" Memory is not enough\n"));
+		return BCME_NOMEM;
+	}
+	wl_p2p_nan_ioctl_make_header(p2p_nanioc, WL_P2P_NAN_CMD_DEL_CONFIG, 0);
+	res = wldev_iovar_setbuf(ndev, "p2p_nan", p2p_nanioc, alloc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	kfree(p2p_nanioc);
+	return res;
+}
+
+#endif /* NAN_P2P_CONFIG */
+
+/*
+ *  packs user data (in hex string) into tlv record
+ *  advances tlv pointer to next xtlv slot
+ *  buflen is used for tlv_buf space check
+ */
+static int
+get_ie_data(uchar *data_str, uchar *ie_data, int len)
+{
+	uchar *src, *dest;
+	uchar val;
+	int idx;
+	char hexstr[3];
+
+	src = data_str;
+	dest = ie_data;
+
+	for (idx = 0; idx < len; idx++) {
+		hexstr[0] = src[0];
+		hexstr[1] = src[1];
+		hexstr[2] = '\0';
+
+#ifdef BCMDRIVER
+		val = (uchar) simple_strtoul(hexstr, NULL, 16);
+#else
+		val = (uchar) strtoul(hexstr, NULL, 16);
+#endif
+
+		*dest++ = val;
+		src += 2;
+	}
+
+	return 0;
+}
+
+int
+wl_cfgnan_pub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	wl_nan_disc_params_t params;
+	s32 ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+	uint8 *pxtlv;
+	u16 start, end;
+	uchar *buf = NULL;
+
+	/*
+	 * proceed only if mandatory arguments are present - publisher id,
+	 * service hash
+	 */
+	if ((!cmd_data->pub_id) || (!cmd_data->svc_hash.data) ||
+		(!cmd_data->svc_hash.dlen)) {
+		WL_ERR((" mandatory arguments are not present \n"));
+		return -EINVAL;
+	}
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan publish 10 NAN123 -info <hex_string
+	 *     wl nan publish 10 NAN123 -info <hex_string -period 1 -ttl 0xffffffff
+	 *
+	 * wpa_cli: DRIVER NAN_PUBLISH PUB_ID=10 SVC_HASH=NAN123
+	 *          SVC_INFO=<hex_string>
+	 *          DRIVER NAN_PUBLISH PUB_ID=10 SVC_HASH=NAN123
+	 *          SVC_INFO=<hex_string> PUB_PR=1 PUB_INT=0xffffffff
+	 */
+
+	/* nan publish */
+	start = end = NAN_IOCTL_BUF_SIZE;
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_PUBLISH);
+	pxtlv = nanioc->data;
+
+	/* disovery parameters */
+	if (cmd_data->pub_pr) {
+		params.period = cmd_data->pub_pr;
+	} else {
+		params.period = 1;
+	}
+	if (cmd_data->pub_int) {
+		params.ttl = cmd_data->pub_int;
+	} else {
+		params.ttl = WL_NAN_TTL_UNTIL_CANCEL;
+	}
+	params.flags = 0;
+	if (cmd_data->flags & WL_NAN_PUB_UNSOLICIT) {
+		params.flags |= WL_NAN_PUB_UNSOLICIT;
+		WL_DBG((" nan publish type - unsolicited\n"));
+	}
+	if (cmd_data->flags & WL_NAN_PUB_SOLICIT) {
+		params.flags |= WL_NAN_PUB_SOLICIT;
+		WL_DBG((" nan publish type - solicited\n"));
+	}
+	if (!params.flags) {
+		params.flags = WL_NAN_PUB_BOTH; /* default. */
+	}
+	params.instance_id = (wl_nan_instance_id_t)cmd_data->pub_id;
+	memcpy((char *)params.svc_hash, cmd_data->svc_hash.data,
+		cmd_data->svc_hash.dlen);
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_SVC_PARAMS,
+		sizeof(params), &params, BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	if (cmd_data->svc_info.data && cmd_data->svc_info.dlen) {
+		uint16 len = cmd_data->svc_info.dlen/2;
+
+		WL_DBG((" optional svc_info present, pack it \n"));
+		buf = kzalloc(len, kflags);
+		if (!buf) {
+			WL_ERR((" memory allocation failed \n"));
+			ret = -ENOMEM;
+			goto fail;
+		}
+		if (get_ie_data((uchar*)cmd_data->svc_info.data, buf, len)) {
+			goto fail;
+		}
+
+		ret = bcm_pack_xtlv_entry(&pxtlv,
+			&end, WL_NAN_XTLV_SVC_INFO, len, buf, BCM_XTLV_OPTION_ALIGN32);
+		if (unlikely(ret)) {
+			goto fail;
+		}
+	}
+
+	nanioc->len = start - end;
+	nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan publish failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan publish successful \n"));
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+	if (buf) {
+		kfree(buf);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_sub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	bcm_xtlvbuf_t tbuf;
+	wl_nan_disc_params_t params;
+	s32 ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+
+	/*
+	 * proceed only if mandatory arguments are present - subscriber id,
+	 * service hash
+	 */
+	if ((!cmd_data->sub_id) || (!cmd_data->svc_hash.data) ||
+		(!cmd_data->svc_hash.dlen)) {
+		WL_ERR((" mandatory arguments are not present \n"));
+		return -EINVAL;
+	}
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	bcm_xtlv_buf_init(&tbuf, nanioc->data,
+		BCM_XTLV_HDR_SIZE + sizeof(params), BCM_XTLV_OPTION_ALIGN32);
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan subscribe 10 NAN123
+	 *
+	 * wpa_cli: DRIVER NAN_SUBSCRIBE SUB_ID=10 SVC_HASH=NAN123
+	 */
+
+	/* nan subscribe */
+	params.period = 1;
+	params.ttl = WL_NAN_TTL_UNTIL_CANCEL;
+	params.flags = 0;
+	if (cmd_data->flags & WL_NAN_SUB_ACTIVE) {
+		params.flags = WL_NAN_SUB_ACTIVE;
+		WL_DBG((" nan subscribe type - Active\n"));
+	}
+	params.instance_id = (wl_nan_instance_id_t)cmd_data->sub_id;
+	memcpy((char *)params.svc_hash, cmd_data->svc_hash.data,
+		cmd_data->svc_hash.dlen);
+	bcm_xtlv_put_data(&tbuf, WL_NAN_XTLV_SVC_PARAMS, &params, sizeof(params));
+
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_SUBSCRIBE);
+	nanioc->len = htod16(bcm_xtlv_buf_len(&tbuf));
+	nanioc_size = sizeof(wl_nan_ioc_t) + bcm_xtlv_buf_len(&tbuf);
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan subscribe failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan subscribe successful \n"));
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_cancel_pub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	bcm_xtlvbuf_t tbuf;
+	wl_nan_disc_params_t params;
+	s32 ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+
+	/* proceed only if mandatory argument is present - publisher id */
+	if (!cmd_data->pub_id) {
+		WL_ERR((" mandatory argument is not present \n"));
+		return -EINVAL;
+	}
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	bcm_xtlv_buf_init(&tbuf, nanioc->data,
+		BCM_XTLV_HDR_SIZE + sizeof(params), BCM_XTLV_OPTION_ALIGN32);
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan cancel_publish 10
+	 *
+	 * wpa_cli: DRIVER NAN_CANCEL_PUBLISH PUB_ID=10
+	 */
+
+	bcm_xtlv_put_data(&tbuf, WL_NAN_XTLV_INSTANCE_ID, &cmd_data->pub_id,
+		sizeof(wl_nan_instance_id_t));
+
+	/* nan cancel publish */
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_CANCEL_PUBLISH);
+	nanioc->len = htod16(bcm_xtlv_buf_len(&tbuf));
+	nanioc_size = sizeof(wl_nan_ioc_t) + bcm_xtlv_buf_len(&tbuf);
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan cancel publish failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan cancel publish successful \n"));
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_cancel_sub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	bcm_xtlvbuf_t tbuf;
+	wl_nan_disc_params_t params;
+	s32 ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+
+	/* proceed only if mandatory argument is present - subscriber id */
+	if (!cmd_data->sub_id) {
+		WL_ERR((" mandatory argument is not present \n"));
+		return -EINVAL;
+	}
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	bcm_xtlv_buf_init(&tbuf, nanioc->data,
+		BCM_XTLV_HDR_SIZE + sizeof(params), BCM_XTLV_OPTION_ALIGN32);
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan cancel_subscribe 10
+	 *
+	 * wpa_cli: DRIVER NAN_CANCEL_SUBSCRIBE PUB_ID=10
+	 */
+
+	bcm_xtlv_put_data(&tbuf, WL_NAN_XTLV_INSTANCE_ID, &cmd_data->sub_id,
+		sizeof(wl_nan_instance_id_t));
+
+	/* nan cancel subscribe */
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_CANCEL_SUBSCRIBE);
+	nanioc->len = htod16(bcm_xtlv_buf_len(&tbuf));
+	nanioc_size = sizeof(wl_nan_ioc_t) + bcm_xtlv_buf_len(&tbuf);
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan cancel subscribe failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan cancel subscribe successful \n"));
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_transmit_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	uint8 *pxtlv;
+	s32 ret = BCME_OK;
+	u16 start, end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+	uchar *buf = NULL;
+
+	/*
+	 * proceed only if mandatory arguments are present - subscriber id,
+	 * publisher id, mac address
+	 */
+	if ((!cmd_data->local_id) || (!cmd_data->remote_id) ||
+		ETHER_ISNULLADDR(&cmd_data->mac_addr.octet)) {
+		WL_ERR((" mandatory arguments are not present \n"));
+		return -EINVAL;
+	}
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan trasnmit <sub_id> <pub_id> <mac_addr> -info <hex_string>
+	 *
+	 * wpa_cli: DRIVER NAN_TRANSMIT SUB_ID=<sub_id> PUB_ID=<pub_id>
+	 *          MAC_ADDR=<mac_addr> SVC_INFO=<hex_string>
+	 */
+
+	/* nan transmit */
+	start = end = NAN_IOCTL_BUF_SIZE;
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_TRANSMIT);
+	pxtlv = nanioc->data;
+
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_INSTANCE_ID,
+		sizeof(cmd_data->local_id), &cmd_data->local_id,
+		BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_REQUESTOR_ID,
+		sizeof(cmd_data->remote_id), &cmd_data->remote_id,
+		BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_MAC_ADDR,
+		ETHER_ADDR_LEN, &cmd_data->mac_addr.octet,
+		BCM_XTLV_OPTION_ALIGN32);
+	if (unlikely(ret)) {
+		goto fail;
+	}
+	if (cmd_data->svc_info.data && cmd_data->svc_info.dlen) {
+		uint16 len = cmd_data->svc_info.dlen/2;
+
+		WL_DBG((" optional svc_info present, pack it \n"));
+		buf = kzalloc(len, kflags);
+		if (!buf) {
+			WL_ERR((" memory allocation failed \n"));
+			ret = -ENOMEM;
+			goto fail;
+		}
+		if (get_ie_data((uchar*)cmd_data->svc_info.data, buf, len)) {
+			goto fail;
+		}
+
+		ret = bcm_pack_xtlv_entry(&pxtlv,
+			&end, WL_NAN_XTLV_SVC_INFO, len, buf,
+			BCM_XTLV_OPTION_ALIGN32);
+		if (unlikely(ret)) {
+			goto fail;
+		}
+	}
+
+	nanioc->len = start - end;
+	nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan transmit failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan transmit successful \n"));
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+	if (buf) {
+		kfree(buf);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_set_config_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ioc_t *nanioc = NULL;
+	uint8 *pxtlv;
+	s32 ret = BCME_OK;
+	u16 start, end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	uint16 nanioc_size = sizeof(wl_nan_ioc_t) + NAN_IOCTL_BUF_SIZE;
+
+	if (cfg->nan_running == true) {
+		WL_ERR((" Stop nan (NAN_STOP) before issuing NAN_CONFIG command\n"));
+		return BCME_ERROR;
+	}
+
+	if (cfg->nan_enable != true) {
+		ret = wl_cfgnan_enable_handler(ndev, cfg, cmd, cmd_data);
+		if (unlikely(ret)) {
+			goto fail;
+		}
+	}
+
+	nanioc = kzalloc(nanioc_size, kflags);
+	if (!nanioc) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl nan <attr> <value> (wl nan role 1)
+	 *
+	 * wpa_cli: DRIVER NAN_CONFIG_SET ATTR=<attr> <value>...<value>
+	 *
+	 * wpa_cli: DRIVER NAN_SET_CONFIG ATTR=ATTR_ROLE ROLE=1
+	 */
+
+	/* nan set config */
+	start = end = NAN_IOCTL_BUF_SIZE;
+	nanioc->version = htod16(WL_NAN_IOCTL_VERSION);
+	nanioc->id = htod16(WL_NAN_CMD_ATTR);
+	pxtlv = nanioc->data;
+
+	switch (cmd_data->attr.type) {
+	case WL_NAN_XTLV_ROLE:
+		WL_DBG((" set nan ROLE = %#x\n", cmd_data->role));
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_ROLE,
+			sizeof(cmd_data->role), &cmd_data->role,
+			BCM_XTLV_OPTION_ALIGN32);
+		break;
+	case WL_NAN_XTLV_MASTER_PREF:
+		WL_DBG((" set nan MASTER PREF = %#x\n", cmd_data->master_pref));
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_MASTER_PREF,
+			sizeof(cmd_data->master_pref), &cmd_data->master_pref,
+			BCM_XTLV_OPTION_ALIGN32);
+		break;
+	case WL_NAN_XTLV_DW_LEN:
+		WL_DBG((" set nan DW LEN = %#x\n", cmd_data->dw_len));
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_DW_LEN,
+			sizeof(cmd_data->dw_len), &cmd_data->dw_len,
+			BCM_XTLV_OPTION_ALIGN32);
+		break;
+	case WL_NAN_XTLV_CLUSTER_ID:
+		WL_DBG((" set nan CLUSTER ID "));
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_CLUSTER_ID,
+			sizeof(cmd_data->clus_id), &cmd_data->clus_id,
+			BCM_XTLV_OPTION_ALIGN32);
+		break;
+	case WL_NAN_XTLV_IF_ADDR:
+		WL_DBG((" set nan IFADDR "));
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_IF_ADDR,
+			sizeof(cmd_data->if_addr), &cmd_data->if_addr,
+			BCM_XTLV_OPTION_ALIGN32);
+		break;
+	case WL_NAN_XTLV_MAC_CHANSPEC:
+		WL_DBG((" set nan CHANSPEC = %#x\n", cmd_data->chanspec));
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_MAC_CHANSPEC,
+			sizeof(cmd_data->chanspec), &cmd_data->chanspec,
+			BCM_XTLV_OPTION_ALIGN32);
+		break;
+	case WL_NAN_XTLV_BCN_INTERVAL:
+		WL_DBG((" set nan BCN_INTERVAL = %#x\n", cmd_data->beacon_int));
+		ret = bcm_pack_xtlv_entry(&pxtlv, &end, WL_NAN_XTLV_BCN_INTERVAL,
+			sizeof(cmd_data->beacon_int), &cmd_data->beacon_int,
+			BCM_XTLV_OPTION_ALIGN32);
+		break;
+	case WL_NAN_XTLV_MAC_TXRATE:
+	default:
+		ret = -EINVAL;
+		break;
+	}
+	if (unlikely(ret)) {
+		WL_ERR((" unsupported attribute, attr = %s (%d) \n",
+			cmd_data->attr.name, cmd_data->attr.type));
+		goto fail;
+	}
+
+	nanioc->len = start - end;
+	nanioc_size = sizeof(wl_nan_ioc_t) + nanioc->len;
+	ret = wldev_iovar_setbuf(ndev, "nan", nanioc, nanioc_size,
+		cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan set config failed, error = %d \n", ret));
+		goto fail;
+	} else {
+		WL_DBG((" nan set config successful \n"));
+	}
+
+fail:
+	if (nanioc) {
+		kfree(nanioc);
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_rtt_config_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	wl_nan_ranging_config_t rtt_config;
+	s32 ret = BCME_OK;
+
+	/* proceed only if mandatory argument is present - channel */
+	if (!cmd_data->chanspec) {
+		WL_ERR((" mandatory argument is not present \n"));
+		return -EINVAL;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl proxd_nancfg 44/80 128 32 ff:ff:ff:ff:ff:ff 1
+	 *
+	 * wpa_cli: DRIVER NAN_RTT_CONFIG CHAN=44/80
+	 */
+
+	memset(&rtt_config, 0, sizeof(rtt_config));
+	rtt_config.chanspec = cmd_data->chanspec;
+	rtt_config.timeslot = 128;
+	rtt_config.duration = 32;
+	memcpy(&rtt_config.allow_mac, &ether_bcast, ETHER_ADDR_LEN);
+	rtt_config.flags = 1;
+
+	ret = wldev_iovar_setbuf(ndev, "proxd_nancfg", &rtt_config,
+		sizeof(wl_nan_ranging_config_t), cfg->ioctl_buf,
+		WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan rtt config failed, error = %d \n", ret));
+	} else {
+		WL_DBG((" nan rtt config successful \n"));
+	}
+
+	return ret;
+}
+
+int
+wl_cfgnan_rtt_find_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	void *iovbuf;
+	wl_nan_ranging_list_t *rtt_list;
+	s32 iovbuf_size = NAN_RTT_IOVAR_BUF_SIZE;
+	s32 ret = BCME_OK;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+
+	/*
+	 * proceed only if mandatory arguments are present - channel, bitmap,
+	 * mac address
+	 */
+	if ((!cmd_data->chanspec) || (!cmd_data->bmap) ||
+		ETHER_ISNULLADDR(&cmd_data->mac_addr.octet)) {
+		WL_ERR((" mandatory arguments are not present \n"));
+		return -EINVAL;
+	}
+
+	iovbuf = kzalloc(iovbuf_size, kflags);
+	if (!iovbuf) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+
+	/*
+	 * command to test
+	 *
+	 * wl: wl proxd_nanfind 1 44/80 <mac_addr> 0x300 5 6 1
+	 *
+	 * wpa_cli: DRIVER NAN_RTT_FIND MAC_ADDR=<mac_addr> CHAN=44/80 BMAP=0x300
+	 *
+	 */
+	rtt_list = (wl_nan_ranging_list_t *)iovbuf;
+	rtt_list->count = 1;
+	rtt_list->num_peers_done = 0;
+	rtt_list->num_dws = 1;
+	rtt_list->rp[0].chanspec = cmd_data->chanspec;
+	memcpy(&rtt_list->rp[0].ea, &cmd_data->mac_addr,
+		sizeof(struct ether_addr));
+	rtt_list->rp[0].abitmap = cmd_data->bmap;
+	rtt_list->rp[0].frmcnt = 5;
+	rtt_list->rp[0].retrycnt = 6;
+	rtt_list->rp[0].flags = 1;
+
+	iovbuf_size = sizeof(wl_nan_ranging_list_t) +
+		sizeof(wl_nan_ranging_peer_t);
+	ret = wldev_iovar_setbuf(ndev, "proxd_nanfind", iovbuf,
+		iovbuf_size, cfg->ioctl_buf, WLC_IOCTL_MEDLEN, NULL);
+	if (unlikely(ret)) {
+		WL_ERR((" nan rtt find failed, error = %d \n", ret));
+	} else {
+		WL_DBG((" nan rtt find successful \n"));
+	}
+
+	if (iovbuf) {
+		kfree(iovbuf);
+	}
+
+	return ret;
+}
+
+#ifdef WL_NAN_DEBUG
+int
+wl_cfgnan_debug_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data)
+{
+	/*
+	 * command to test
+	 *
+	 * wpa_cli: DRIVER NAN_DEBUG DEBUG=1
+	 *
+	 */
+
+	g_nan_debug = cmd_data->debug_flag;
+
+	/* reconfigure nan events */
+	return wl_cfgnan_enable_events(ndev, cfg);
+}
+#endif /* WL_NAN_DEBUG */
+
+static int wl_cfgnan_config_attr(char *buf, nan_config_attr_t *attr)
+{
+	s32 ret = BCME_OK;
+	nan_config_attr_t *nanc = NULL;
+
+	/* only one attribute at a time */
+	for (nanc = &nan_config_attrs[0]; strlen(nanc->name) != 0; nanc++) {
+		if (!strncmp(nanc->name, buf, strlen(nanc->name))) {
+			strncpy((char *)attr->name, buf, strlen(nanc->name));
+			attr->type = nanc->type;
+			ret = strlen(nanc->name);
+			break;
+		}
+	}
+
+	return ret;
+}
+
+static int wl_cfgnan_parse_args(char *buf, nan_cmd_data_t *cmd_data)
+{
+	s32 ret = BCME_OK;
+	char *token = buf;
+	char delim[] = " ";
+
+	while ((buf != NULL) && (token != NULL)) {
+		if (!strncmp(buf, PUB_ID_PREFIX, strlen(PUB_ID_PREFIX))) {
+			buf += strlen(PUB_ID_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->pub_id = simple_strtoul(token, NULL, 10);
+			cmd_data->local_id ? (cmd_data->remote_id = cmd_data->pub_id) :
+				(cmd_data->local_id = cmd_data->pub_id);
+			if (NAN_INVALID_ID(cmd_data->pub_id)) {
+				WL_ERR((" invalid publisher id, pub_id = %d \n",
+					cmd_data->pub_id));
+				ret = -EINVAL;
+				goto fail;
+			}
+#ifdef NAN_P2P_CONFIG
+		} else if (!strncmp(buf, P2P_IE_PREFIX, strlen(P2P_IE_PREFIX))) {
+			buf += strlen(P2P_IE_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->p2p_info.data = token;
+			cmd_data->p2p_info.dlen = strlen(token);
+		} else if (!strncmp(buf, IE_EN_PREFIX, strlen(IE_EN_PREFIX))) {
+			buf += strlen(IE_EN_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->p2p_info.data = token;
+			cmd_data->p2p_info.dlen = strlen(token);
+#endif /* NAN_P2P_CONFIG */
+		} else if (!strncmp(buf, SUB_ID_PREFIX, strlen(SUB_ID_PREFIX))) {
+			buf += strlen(SUB_ID_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->sub_id = simple_strtoul(token, NULL, 10);
+			cmd_data->local_id ? (cmd_data->remote_id = cmd_data->sub_id) :
+				(cmd_data->local_id = cmd_data->sub_id);
+			if (NAN_INVALID_ID(cmd_data->sub_id)) {
+				WL_ERR((" invalid subscriber id, sub_id = %d \n",
+					cmd_data->sub_id));
+				ret = -EINVAL;
+				goto fail;
+			}
+		} else if (!strncmp(buf, MAC_ADDR_PREFIX, strlen(MAC_ADDR_PREFIX))) {
+			buf += strlen(MAC_ADDR_PREFIX);
+			token = strsep(&buf, delim);
+			if (!wl_cfg80211_ether_atoe(token, &cmd_data->mac_addr)) {
+				WL_ERR((" invalid mac address, mac_addr = "MACDBG "\n",
+					MAC2STRDBG(cmd_data->mac_addr.octet)));
+				ret = -EINVAL;
+				goto fail;
+			}
+		} else if (!strncmp(buf, SVC_HASH_PREFIX, strlen(SVC_HASH_PREFIX))) {
+			buf += strlen(SVC_HASH_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->svc_hash.data = token;
+			cmd_data->svc_hash.dlen = WL_NAN_SVC_HASH_LEN;
+		} else if (!strncmp(buf, SVC_INFO_PREFIX, strlen(SVC_INFO_PREFIX))) {
+			buf += strlen(SVC_INFO_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->svc_info.data = token;
+			cmd_data->svc_info.dlen = strlen(token);
+		} else if (!strncmp(buf, CHAN_PREFIX, strlen(CHAN_PREFIX))) {
+			buf += strlen(CHAN_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->chanspec = wf_chspec_aton(token);
+			cmd_data->chanspec = wl_chspec_host_to_driver(cmd_data->chanspec);
+			if (NAN_INVALID_CHANSPEC(cmd_data->chanspec)) {
+				WL_ERR((" invalid chanspec, chanspec = 0x%04x \n",
+					cmd_data->chanspec));
+				ret = -EINVAL;
+				goto fail;
+			}
+		} else if (!strncmp(buf, BITMAP_PREFIX, strlen(BITMAP_PREFIX))) {
+			buf += strlen(BITMAP_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->bmap = simple_strtoul(token, NULL, 16);
+		} else if (!strncmp(buf, ATTR_PREFIX, strlen(ATTR_PREFIX))) {
+			buf += strlen(ATTR_PREFIX);
+			token = strsep(&buf, delim);
+			if (!wl_cfgnan_config_attr(token, &cmd_data->attr)) {
+				WL_ERR((" invalid attribute, attr = %s \n",
+					cmd_data->attr.name));
+				ret = -EINVAL;
+				goto fail;
+			}
+		} else if (!strncmp(buf, ROLE_PREFIX, strlen(ROLE_PREFIX))) {
+			buf += strlen(ROLE_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->role = simple_strtoul(token, NULL, 10);
+			if (NAN_INVALID_ROLE(cmd_data->role)) {
+				WL_ERR((" invalid role, role = %d \n", cmd_data->role));
+				ret = -EINVAL;
+				goto fail;
+			}
+		} else if (!strncmp(buf, MASTER_PREF_PREFIX,
+			strlen(MASTER_PREF_PREFIX))) {
+			buf += strlen(MASTER_PREF_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->master_pref = simple_strtoul(token, NULL, 10);
+		} else if (!strncmp(buf, CLUS_ID_PREFIX, strlen(CLUS_ID_PREFIX))) {
+			buf += strlen(CLUS_ID_PREFIX);
+			token = strsep(&buf, delim);
+			if (!wl_cfg80211_ether_atoe(token, &cmd_data->clus_id)) {
+				WL_ERR((" invalid cluster id, CLUS_ID = "MACDBG "\n",
+					MAC2STRDBG(cmd_data->clus_id.octet)));
+				ret = -EINVAL;
+				goto fail;
+			}
+		} else if (!strncmp(buf, IF_ADDR_PREFIX, strlen(IF_ADDR_PREFIX))) {
+			buf += strlen(IF_ADDR_PREFIX);
+			token = strsep(&buf, delim);
+			if (!wl_cfg80211_ether_atoe(token, &cmd_data->if_addr)) {
+				WL_ERR((" invalid cluster id, IF_ADDR = "MACDBG "\n",
+					MAC2STRDBG(cmd_data->if_addr.octet)));
+				ret = -EINVAL;
+				goto fail;
+			}
+		} else if (!strncmp(buf, BCN_INTERVAL_PREFIX,
+			strlen(BCN_INTERVAL_PREFIX))) {
+			buf += strlen(BCN_INTERVAL_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->beacon_int = simple_strtoul(token, NULL, 10);
+		} else if (!strncmp(buf, PUB_PR_PREFIX, strlen(PUB_PR_PREFIX))) {
+			buf += strlen(PUB_PR_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->pub_pr = simple_strtoul(token, NULL, 10);
+		} else if (!strncmp(buf, PUB_INT_PREFIX, strlen(PUB_INT_PREFIX))) {
+			buf += strlen(PUB_INT_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->pub_int = simple_strtoul(token, NULL, 10);
+		} else if (!strncmp(buf, DW_LEN_PREFIX, strlen(DW_LEN_PREFIX))) {
+			buf += strlen(DW_LEN_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->dw_len = simple_strtoul(token, NULL, 10);
+		} else if (!strncmp(buf, DEBUG_PREFIX, strlen(DEBUG_PREFIX))) {
+			buf += strlen(DEBUG_PREFIX);
+			token = strsep(&buf, delim);
+			cmd_data->debug_flag = simple_strtoul(token, NULL, 10);
+		} else if (!strncmp(buf, ACTIVE_OPTION, strlen(ACTIVE_OPTION))) {
+			buf += strlen(ACTIVE_OPTION);
+			token = strsep(&buf, delim);
+			cmd_data->flags |= WL_NAN_SUB_ACTIVE;
+		} else if (!strncmp(buf, SOLICITED_OPTION, strlen(SOLICITED_OPTION))) {
+			buf += strlen(SOLICITED_OPTION);
+			token = strsep(&buf, delim);
+			cmd_data->flags |= WL_NAN_PUB_SOLICIT;
+		} else if (!strncmp(buf, UNSOLICITED_OPTION, strlen(UNSOLICITED_OPTION))) {
+			buf += strlen(UNSOLICITED_OPTION);
+			token = strsep(&buf, delim);
+			cmd_data->flags |= WL_NAN_PUB_UNSOLICIT;
+		} else {
+			WL_ERR((" unknown token, token = %s, buf = %s \n", token, buf));
+			ret = -EINVAL;
+			goto fail;
+		}
+	}
+
+fail:
+	return ret;
+}
+
+int
+wl_cfgnan_cmd_handler(struct net_device *ndev, struct bcm_cfg80211 *cfg,
+	char *cmd, int cmd_len)
+{
+	nan_cmd_data_t cmd_data;
+	u8 *buf = cmd;
+	u8 *cmd_name = NULL;
+	nan_cmd_t *nanc = NULL;
+	int buf_len = 0;
+	int ret = BCME_OK;
+
+	cmd_name = strsep((char **)&buf, " ");
+	if (buf) {
+		buf_len = strlen(buf);
+	}
+
+	WL_DBG((" cmd_name: %s, buf_len: %d, buf: %s \n", cmd_name, buf_len, buf));
+
+	memset(&cmd_data, 0, sizeof(cmd_data));
+	ret = wl_cfgnan_parse_args(buf, &cmd_data);
+	if (unlikely(ret)) {
+		WL_ERR((" argument parsing failed with error (%d), buf = %s \n",
+			ret, buf));
+		goto fail;
+	}
+
+	for (nanc = nan_cmds; nanc->name; nanc++) {
+		if (strncmp(nanc->name, cmd_name, strlen(nanc->name)) == 0) {
+			ret = (*nanc->func)(ndev, cfg, cmd, cmd_len, &cmd_data);
+			if (ret < BCME_OK) {
+				WL_ERR((" command (%s) failed with error (%d) \n",
+					cmd_name, ret));
+			}
+		}
+	}
+
+fail:
+	return ret;
+}
+
+s32
+wl_cfgnan_notify_proxd_status(struct bcm_cfg80211 *cfg,
+	bcm_struct_cfgdev *cfgdev, const wl_event_msg_t *event, void *data)
+{
+	s32 ret = BCME_OK;
+	wl_nan_ranging_event_data_t *rdata;
+	s32 status;
+	u16 data_len;
+	s32 event_type;
+	s32 event_num;
+	u8 *buf = NULL;
+	u32 buf_len;
+	u8 *ptr, *end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	s32 i;
+
+	if (!event || !data) {
+		WL_ERR((" event data is NULL \n"));
+		return -EINVAL;
+	}
+
+	status = ntoh32(event->reason);
+	event_type = ntoh32(event->event_type);
+	event_num = ntoh32(event->reason);
+	data_len = ntoh32(event->datalen);
+
+	WL_DBG((" proxd event: type: %d num: %d len: %d \n",
+		event_type, event_num, data_len));
+
+	if (NAN_INVALID_PROXD_EVENT(event_num)) {
+		WL_ERR((" unsupported event, num: %d \n", event_num));
+		return -EINVAL;
+	}
+
+#ifdef WL_NAN_DEBUG
+	if (g_nan_debug) {
+		WL_DBG((" event name: WLC_E_PROXD_NAN_EVENT \n"));
+		WL_DBG((" event data: \n"));
+		prhex(NULL, data, data_len);
+	}
+#endif /* WL_NAN_DEBUG */
+
+	if (data_len < sizeof(wl_nan_ranging_event_data_t)) {
+		WL_ERR((" wrong data len \n"));
+		return -EINVAL;
+	}
+
+	rdata = (wl_nan_ranging_event_data_t *)data;
+
+	WL_DBG((" proxd event: count:%d success_count:%d mode:%d \n",
+		rdata->count, rdata->success_count, rdata->mode));
+
+#ifdef WL_NAN_DEBUG
+	if (g_nan_debug) {
+		prhex(" event data: ", data, data_len);
+	}
+#endif /* WL_NAN_DEBUG */
+
+	buf_len = NAN_IOCTL_BUF_SIZE;
+	buf = kzalloc(buf_len, kflags);
+	if (!buf) {
+		WL_ERR((" memory allocation failed \n"));
+		return -ENOMEM;
+	}
+	end = buf + buf_len;
+
+	for (i = 0; i < rdata->count; i++) {
+		if (&rdata->rr[i] == NULL) {
+			ret = -EINVAL;
+			goto fail;
+		}
+
+		ptr = buf;
+		WL_DBG((" ranging data for mac:"MACDBG" \n",
+			MAC2STRDBG(rdata->rr[i].ea.octet)));
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " MAC_ADDR_PREFIX MACF
+			" "STATUS_PREFIX"%s", EVENT_RTT_STATUS_STR,
+			ETHER_TO_MACF(rdata->rr[i].ea), (rdata->rr[i].status == 1) ?
+			"success" : "fail");
+
+		if (rdata->rr[i].status == 1) {
+			/* add tsf and distance only if status is success */
+			ptr += snprintf(ptr, end-ptr, " "TIMESTAMP_PREFIX"0x%x "
+				DISTANCE_PREFIX"%d.%04d", rdata->rr[i].timestamp,
+				rdata->rr[i].distance >> 4,
+				((rdata->rr[i].distance & 0x0f) * 625));
+		}
+		if (ptr > end) {
+			WL_ERR(("Buffer overflow. userspace string truncated: %s, len: %zu\n",
+				buf, strlen(buf)));
+		}
+
+	}
+
+fail:
+	if (buf) {
+		kfree(buf);
+	}
+
+	return ret;
+}
+
+s32
+wl_cfgnan_notify_nan_status(struct bcm_cfg80211 *cfg,
+	bcm_struct_cfgdev *cfgdev, const wl_event_msg_t *event, void *data)
+{
+	s32 ret = BCME_OK;
+	u16 data_len;
+	u32 event_num;
+	s32 event_type;
+	nan_event_hdr_t nan_hdr;
+	wl_nan_tlv_data_t tlv_data;
+	u8 *buf = NULL;
+	u32 buf_len;
+	u8 *ptr, *end;
+	u16 kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+
+	if (!event || !data) {
+		WL_ERR((" event data is NULL \n"));
+		return -EINVAL;
+	}
+
+	event_type = ntoh32(event->event_type);
+	event_num = ntoh32(event->reason);
+	data_len = ntoh32(event->datalen);
+	memset(&nan_hdr, 0, sizeof(nan_event_hdr_t));
+	nan_hdr.event_subtype = event_num;
+
+	WL_DBG((" nan event: type: %d num: %d len: %d \n",
+		event_type, event_num, data_len));
+
+	if (NAN_INVALID_EVENT(event_num)) {
+		WL_ERR((" unsupported event, num: %d \n", event_num));
+		return -EINVAL;
+	}
+
+#ifdef WL_NAN_DEBUG
+	if (g_nan_debug) {
+		print_event_name(event_num);
+		WL_DBG((" event data: \n"));
+		prhex(NULL, data, data_len);
+	}
+#endif /* WL_NAN_DEBUG */
+
+	/* unpack the tlvs */
+	memset(&tlv_data, 0, sizeof(wl_nan_tlv_data_t));
+	bcm_unpack_xtlv_buf(&tlv_data, data, data_len,
+		BCM_XTLV_OPTION_ALIGN32, wl_cfgnan_set_vars_cbfn);
+
+	/*
+	 * send as preformatted hex string
+	 *
+	 * EVENT_NAN <event_type> <tlv_hex_string>
+	 */
+
+	buf_len = NAN_IOCTL_BUF_SIZE;
+	buf = ptr = kzalloc(buf_len, kflags);
+	if (!buf) {
+		WL_ERR((" memory allocation failed \n"));
+		ret = -ENOMEM;
+		goto fail;
+	}
+	end = buf + buf_len;
+
+	switch (event_num) {
+	case WL_NAN_EVENT_START:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " CLUS_ID_PREFIX MACF,
+			NAN_EVENT_STR_STARTED, ETHER_TO_MACF(tlv_data.nstatus.cid));
+		break;
+	case WL_NAN_EVENT_JOIN:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " CLUS_ID_PREFIX MACF,
+			NAN_EVENT_STR_JOINED, ETHER_TO_MACF(tlv_data.nstatus.cid));
+		break;
+	case WL_NAN_EVENT_STOP:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " CLUS_ID_PREFIX MACF,
+			NAN_EVENT_STR_STOPPED, ETHER_TO_MACF(tlv_data.nstatus.cid));
+		break;
+	case WL_NAN_EVENT_ROLE:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s "ROLE_PREFIX "%d "
+			CLUS_ID_PREFIX MACF, NAN_EVENT_STR_ROLE_CHANGE,
+			tlv_data.nstatus.role, ETHER_TO_MACF(tlv_data.nstatus.cid));
+		break;
+	case WL_NAN_EVENT_DISCOVERY_RESULT:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " PUB_ID_PREFIX"%d "
+			SUB_ID_PREFIX"%d " MAC_ADDR_PREFIX MACF,
+			NAN_EVENT_STR_SDF_RX, tlv_data.pub_id, tlv_data.sub_id,
+			ETHER_TO_MACF(tlv_data.mac_addr));
+		if (tlv_data.svc_info.data && tlv_data.svc_info.dlen) {
+			WL_DBG((" service info present \n"));
+			if ((strlen(ptr) + tlv_data.svc_info.dlen) >= buf_len) {
+				WL_ERR((" service info length = %d\n",
+					tlv_data.svc_info.dlen));
+				WL_ERR((" insufficent buffer to copy service info \n"));
+				ret = -EOVERFLOW;
+				goto fail;
+			}
+			ptr += snprintf(ptr, end-ptr, " %s", SVC_INFO_PREFIX);
+			ptr += bcm_format_hex(ptr, tlv_data.svc_info.data,
+				tlv_data.svc_info.dlen);
+		} else {
+			WL_DBG((" service info not present \n"));
+		}
+
+		if (tlv_data.vend_info.data && tlv_data.vend_info.dlen) {
+			struct ether_addr *ea;
+			u8 *temp_data = tlv_data.vend_info.data;
+			uint32 bitmap;
+			u16 dlen = tlv_data.vend_info.dlen;
+			chanspec_t chanspec;
+			uint8 mapcontrol;
+			uint8 proto;
+
+			WL_DBG((" vendor info present \n"));
+			if ((*temp_data != NAN_ATTR_VENDOR_SPECIFIC) ||
+				(dlen < NAN_VENDOR_HDR_SIZE)) {
+				WL_ERR((" error in vendor info attribute \n"));
+				ret = -EINVAL;
+				goto fail;
+			} else {
+				WL_DBG((" vendor info not present \n"));
+			}
+
+			if (*(temp_data + 6) == NAN_VENDOR_TYPE_RTT) {
+				temp_data += NAN_VENDOR_HDR_SIZE;
+				ea = (struct ether_addr *)temp_data;
+				temp_data += ETHER_ADDR_LEN;
+				mapcontrol = *temp_data++;
+				proto = *temp_data++;
+				bitmap = *(uint32 *)temp_data;
+				temp_data += 4;
+				chanspec = *(chanspec_t *)temp_data;
+				ptr += snprintf(ptr, end-ptr,
+					" "BITMAP_PREFIX"0x%x "CHAN_PREFIX"%d/%s",
+					bitmap, wf_chspec_ctlchan(chanspec),
+					wf_chspec_to_bw_str(chanspec));
+				WL_DBG((" bitmap: 0x%x channel: %d bandwidth: %s \n", bitmap,
+					wf_chspec_ctlchan(chanspec),
+					wf_chspec_to_bw_str(chanspec)));
+			}
+		}
+		break;
+	case WL_NAN_EVENT_REPLIED:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " PUB_ID_PREFIX"%d "
+				MAC_ADDR_PREFIX MACF, NAN_EVENT_STR_REPLIED,
+				tlv_data.pub_id, ETHER_TO_MACF(tlv_data.mac_addr));
+		break;
+	case WL_NAN_EVENT_TERMINATED:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " PUB_ID_PREFIX"%d ",
+			NAN_EVENT_STR_TERMINATED, tlv_data.pub_id);
+		break;
+	case WL_NAN_EVENT_RECEIVE:
+		ptr += snprintf(ptr, end-ptr,
+			SUPP_EVENT_PREFIX"%s " INSTANCE_ID_PREFIX"%d "
+			REMOTE_INSTANCE_ID_PREFIX"%d " MAC_ADDR_PREFIX MACF,
+			NAN_EVENT_STR_FOLLOWUP_RX, tlv_data.inst_id,
+			tlv_data.peer_inst_id, ETHER_TO_MACF(tlv_data.mac_addr));
+		if (tlv_data.svc_info.data && tlv_data.svc_info.dlen) {
+			WL_DBG((" service info present \n"));
+			if ((strlen(ptr) + tlv_data.svc_info.dlen) >= buf_len) {
+				WL_ERR((" service info length = %d\n",
+					tlv_data.svc_info.dlen));
+				WL_ERR((" insufficent buffer to copy service info \n"));
+				ret = -EOVERFLOW;
+				goto fail;
+			}
+			ptr += snprintf(ptr, end-ptr, " %s", SVC_INFO_PREFIX);
+			ptr += bcm_format_hex(ptr, tlv_data.svc_info.data,
+				tlv_data.svc_info.dlen);
+		} else {
+			WL_DBG((" service info not present \n"));
+		}
+		break;
+	case WL_NAN_EVENT_SCAN_COMPLETE:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " CLUS_ID_PREFIX MACF,
+			NAN_EVENT_STR_SCAN_COMPLETE, ETHER_TO_MACF(tlv_data.nstatus.cid));
+		break;
+	case WL_NAN_EVENT_STATUS_CHG:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " CLUS_ID_PREFIX MACF,
+			NAN_EVENT_STR_STATUS_CHANGE, ETHER_TO_MACF(tlv_data.nstatus.cid));
+		break;
+	case WL_NAN_EVENT_MERGE:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s " CLUS_ID_PREFIX MACF,
+			NAN_EVENT_STR_MERGED, ETHER_TO_MACF(tlv_data.nstatus.cid));
+		break;
+#ifdef NAN_P2P_CONFIG
+	case WL_NAN_EVENT_P2P:
+		ptr += snprintf(ptr, end-ptr, SUPP_EVENT_PREFIX"%s "
+				MAC_ADDR_PREFIX MACF, NAN_EVENT_STR_P2P_RX,
+				ETHER_TO_MACF(tlv_data.mac_addr));
+		if (tlv_data.vend_info.data && tlv_data.vend_info.dlen) {
+			u8 *data = tlv_data.vend_info.data;
+			u16 dlen = tlv_data.vend_info.dlen;
+
+			WL_DBG((" vendor info present %d  dlen  = %d\n",
+				*(data + 6), (dlen - (NAN_VENDOR_HDR_SIZE+1))));
+			if ((*data != NAN_ATTR_VENDOR_SPECIFIC) ||
+				(dlen < NAN_VENDOR_HDR_SIZE)) {
+				WL_ERR((" error in vendor info attribute \n"));
+				ret = -EINVAL;
+				goto fail;
+			} else {
+				WL_DBG((" vendor info present \n"));
+			}
+
+			if (*(data + 6) == NAN_VENDOR_TYPE_P2P) {
+				data += NAN_VENDOR_HDR_SIZE;
+				ptr += snprintf(ptr, end-ptr, " %s", P2P_IE_PREFIX);
+				ptr += bcm_format_hex(ptr, data, (dlen - (NAN_VENDOR_HDR_SIZE)));
+			}
+		}
+		break;
+#endif /* NAN_P2P_CONFIG */
+	default:
+		WL_ERR((" unknown event \n"));
+		break;
+	}
+	if (ptr > end) {
+		WL_ERR(("Buffer overflow. userspace string truncated: %s, len: %zu\n",
+			buf, strlen(buf)));
+	}
+
+
+fail:
+	if (buf) {
+		kfree(buf);
+	}
+	if (tlv_data.svc_info.data) {
+		kfree(tlv_data.svc_info.data);
+		tlv_data.svc_info.data = NULL;
+		tlv_data.svc_info.dlen = 0;
+	}
+	if (tlv_data.vend_info.data) {
+		kfree(tlv_data.vend_info.data);
+		tlv_data.vend_info.data = NULL;
+		tlv_data.vend_info.dlen = 0;
+	}
+
+	return ret;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgnan.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgnan.h
new file mode 100644
index 000000000000..0298fa6f568c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgnan.h
@@ -0,0 +1,227 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Neighbor Awareness Networking
+ *
+ * Copyright (C) 1999-2018, Broadcom Corporation
+ * 
+ *      Unless you and Broadcom execute a separate written software license
+ * agreement governing use of this software, this software is licensed to you
+ * under the terms of the GNU General Public License version 2 (the "GPL"),
+ * available at http://www.broadcom.com/licenses/GPLv2.php, with the
+ * following added to such license:
+ * 
+ *      As a special exception, the copyright holders of this software give you
+ * permission to link this software with independent modules, and to copy and
+ * distribute the resulting executable under terms of your choice, provided that
+ * you also meet, for each linked independent module, the terms and conditions of
+ * the license of that module.  An independent module is a module which is not
+ * derived from this software.  The special exception does not apply to any
+ * modifications of the software.
+ * 
+ *      Notwithstanding the above, under no circumstances may you combine this
+ * software in any way with any other Broadcom software provided under a license
+ * other than the GPL, without Broadcom's express prior written consent.
+ *
+ * <<Broadcom-WL-IPTag/Open:>>
+ *
+ * $Id: wl_cfgnan.h 559906 2015-05-29 02:42:35Z $
+ */
+
+#ifndef _wl_cfgnan_h_
+#define _wl_cfgnan_h_
+
+#define NAN_IOCTL_BUF_SIZE			512
+#define NAN_EVENT_NAME_MAX_LEN		40
+#define NAN_CONFIG_ATTR_MAX_LEN		24
+#define NAN_RTT_IOVAR_BUF_SIZE		1024
+#define WL_NAN_EVENT_CLEAR_BIT		32
+#define NAN_EVENT_MASK_ALL			0x7fffffff
+
+#define NAN_INVALID_ID(id)	(id > 255)
+#define NAN_INVALID_ROLE(role)	(role > WL_NAN_ROLE_ANCHOR_MASTER)
+#define NAN_INVALID_CHANSPEC(chanspec)	((chanspec == INVCHANSPEC) || \
+	(chanspec == 0))
+#define NAN_INVALID_EVENT(num)	((num < WL_NAN_EVENT_START) || \
+	(num >= WL_NAN_EVENT_INVALID))
+#define NAN_INVALID_PROXD_EVENT(num)	(num != WLC_E_PROXD_NAN_EVENT)
+#define NAN_EVENT_BIT(event) (1U << (event - WL_NAN_EVENT_START))
+#define NAME_TO_STR(name) #name
+
+#define SUPP_EVENT_PREFIX		"CTRL-EVENT-"
+#define EVENT_RTT_STATUS_STR	"NAN-RTT-STATUS"
+
+#define TIMESTAMP_PREFIX	"TSF="			/* timestamp */
+#define AMR_PREFIX			"AMR="			/* anchor master rank */
+#define DISTANCE_PREFIX		"DIST="			/* distance */
+#define ATTR_PREFIX			"ATTR="			/* attribute */
+#define ROLE_PREFIX			"ROLE="			/* role */
+#define CHAN_PREFIX			"CHAN="			/* channel */
+#define BITMAP_PREFIX		"BMAP="			/* bitmap */
+#define DEBUG_PREFIX		"DEBUG="		/* debug enable/disable flag */
+#define DW_LEN_PREFIX		"DW_LEN="		/* discovery window length */
+#define DW_INT_PREFIX		"DW_INT="		/* discovery window interval */
+#define STATUS_PREFIX		"STATUS="		/* status */
+#define PUB_ID_PREFIX		"PUB_ID="		/* publisher id */
+#define SUB_ID_PREFIX		"SUB_ID="		/* subscriber id */
+#define INSTANCE_ID_PREFIX		"LOCAL_ID="		/* Instance id */
+#define REMOTE_INSTANCE_ID_PREFIX		"PEER_ID="		/* Peer id */
+
+#ifdef NAN_P2P_CONFIG
+#define P2P_IE_PREFIX		"P2P_IE="		/* p2p ie  id */
+#define IE_EN_PREFIX		"ENBLE_IE="		/* enable p2p ie  */
+#endif
+#define PUB_PR_PREFIX		"PUB_PR="		/* publish period */
+#define PUB_INT_PREFIX		"PUB_INT="		/* publish interval (ttl) */
+#define CLUS_ID_PREFIX		"CLUS_ID="		/* cluster id */
+#define IF_ADDR_PREFIX		"IF_ADDR="		/* IF address */
+#define MAC_ADDR_PREFIX		"MAC_ADDR="		/* mac address */
+#define SVC_HASH_PREFIX		"SVC_HASH="		/* service hash */
+#define SVC_INFO_PREFIX		"SVC_INFO="		/* service information */
+#define HOP_COUNT_PREFIX	"HOP_COUNT="	/* hop count */
+#define MASTER_PREF_PREFIX	"MASTER_PREF="	/* master preference */
+#define ACTIVE_OPTION		"ACTIVE"		/* Active Subscribe. */
+#define SOLICITED_OPTION	"SOLICITED"		/* Solicited Publish. */
+#define UNSOLICITED_OPTION	"UNSOLICITED"	/* Unsolicited Publish. */
+/* anchor master beacon transmission time */
+#define AMBTT_PREFIX		"AMBTT="
+/* passive scan period for cluster merge */
+#define SCAN_PERIOD_PREFIX	"SCAN_PERIOD="
+/* passive scan interval for cluster merge */
+#define SCAN_INTERVAL_PREFIX	"SCAN_INTERVAL="
+#define BCN_INTERVAL_PREFIX		"BCN_INTERVAL="
+
+#define NAN_EVENT_STR_STARTED               "NAN-STARTED"
+#define NAN_EVENT_STR_JOINED                "NAN-JOINED"
+#define NAN_EVENT_STR_ROLE_CHANGE           "NAN-ROLE-CHANGE"
+#define NAN_EVENT_STR_SCAN_COMPLETE         "NAN-SCAN-COMPLETE"
+#define NAN_EVENT_STR_SDF_RX                "NAN-SDF-RX"
+#define NAN_EVENT_STR_REPLIED               "NAN-REPLIED"
+#define NAN_EVENT_STR_TERMINATED            "NAN-TERMINATED"
+#define NAN_EVENT_STR_FOLLOWUP_RX           "NAN-FOLLOWUP-RX"
+#define NAN_EVENT_STR_STATUS_CHANGE         "NAN-STATUS-CHANGE"
+#define NAN_EVENT_STR_MERGED                "NAN-MERGED"
+#define NAN_EVENT_STR_STOPPED               "NAN-STOPPED"
+#define NAN_EVENT_STR_P2P_RX                "NAN-P2P-RX"
+#define NAN_EVENT_STR_WINDOW_BEGUN_P2P      "NAN-WINDOW-BEGUN-P2P"
+#define NAN_EVENT_STR_WINDOW_BEGUN_MESH     "NAN-WINDOW-BEGUN-MESH"
+#define NAN_EVENT_STR_WINDOW_BEGUN_IBSS     "NAN-WINDOW-BEGUN-IBSS"
+#define NAN_EVENT_STR_WINDOW_BEGUN_RANGING  "NAN-WINDOW-BEGUN-RANGING"
+#define NAN_EVENT_STR_INVALID               "NAN-INVALID"
+
+typedef struct nan_str_data {
+	u8 *data;
+	u32 dlen;
+} nan_str_data_t;
+
+typedef struct nan_config_attr {
+	char name[NAN_CONFIG_ATTR_MAX_LEN];	/* attribute name */
+	u16 type;							/* attribute xtlv type */
+} nan_config_attr_t;
+
+typedef struct nan_cmd_data {
+	nan_config_attr_t attr;			/* set config attributes */
+	nan_str_data_t svc_hash;		/* service hash */
+	nan_str_data_t svc_info;		/* service information */
+	nan_str_data_t p2p_info;		/* p2p information */
+	struct ether_addr mac_addr;		/* mac address */
+	struct ether_addr clus_id;		/* cluster id */
+	struct ether_addr if_addr;		/* if addr */
+	u32 beacon_int;					/* beacon interval */
+	u32 pub_int;					/* publish interval (ttl) */
+	u32 pub_pr;						/* publish period */
+	u32 bmap;						/* bitmap */
+	u32 role;						/* role */
+	u16 pub_id;						/* publisher id */
+	u16 sub_id;						/* subscriber id */
+	u16 local_id;					/* Local id */
+	u16 remote_id;					/* Remote id */
+	uint32 flags;					/* Flag bits */
+	u16 dw_len;						/* discovery window length */
+	u16 master_pref;				/* master preference */
+	chanspec_t chanspec;			/* channel */
+	u8 debug_flag;					/* debug enable/disable flag */
+} nan_cmd_data_t;
+
+typedef int (nan_func_t)(struct net_device *ndev, struct bcm_cfg80211 *cfg,
+	char *cmd, int size, nan_cmd_data_t *cmd_data);
+
+typedef struct nan_cmd {
+	const char *name;					/* command name */
+	nan_func_t *func;					/* command hadler */
+} nan_cmd_t;
+
+typedef struct nan_event_hdr {
+	u16 event_subtype;
+	u32 flags;							/* future use */
+} nan_event_hdr_t;
+
+typedef struct wl_nan_tlv_data {
+	wl_nan_status_t nstatus;			/* status data */
+	wl_nan_disc_params_t params;		/* discovery parameters */
+	struct ether_addr mac_addr;			/* peer mac address */
+	struct ether_addr clus_id;			/* cluster id */
+	nan_str_data_t svc_info;			/* service info */
+	nan_str_data_t vend_info;			/* vendor info */
+	/* anchor master beacon transmission time */
+	u32 ambtt;
+	u32 dev_role;						/* device role */
+	u16 inst_id;						/* instance id */
+	u16 peer_inst_id;					/* Peer instance id */
+	u16 pub_id;							/* publisher id */
+	u16 sub_id;							/* subscriber id */
+	u16 master_pref;					/* master preference */
+	chanspec_t chanspec;				/* channel */
+	u8 amr[NAN_MASTER_RANK_LEN];		/* anchor master role */
+	u8 svc_name[WL_NAN_SVC_HASH_LEN];	/* service name */
+	u8 hop_count;						/* hop count */
+	u8 enabled;							/* nan status flag */
+	nan_scan_params_t scan_params;		/* scan_param */
+} wl_nan_tlv_data_t;
+
+extern int wl_cfgnan_set_vars_cbfn(void *ctx, uint8 *tlv_buf,
+	uint16 type, uint16 len);
+extern int wl_cfgnan_enable_events(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg);
+extern int wl_cfgnan_start_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_stop_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_support_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_status_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_pub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_p2p_ie_add_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_p2p_ie_enable_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_p2p_ie_del_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+
+extern int wl_cfgnan_sub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_cancel_pub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_cancel_sub_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_transmit_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_set_config_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_rtt_config_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+extern int wl_cfgnan_rtt_find_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+#ifdef WL_NAN_DEBUG
+extern int wl_cfgnan_debug_handler(struct net_device *ndev,
+	struct bcm_cfg80211 *cfg, char *cmd, int size, nan_cmd_data_t *cmd_data);
+#endif /* WL_NAN_DEBUG */
+extern int wl_cfgnan_cmd_handler(struct net_device *dev,
+	struct bcm_cfg80211 *cfg, char *cmd, int cmd_len);
+extern s32 wl_cfgnan_notify_nan_status(struct bcm_cfg80211 *cfg,
+	bcm_struct_cfgdev *cfgdev, const wl_event_msg_t *e, void *data);
+extern s32 wl_cfgnan_notify_proxd_status(struct bcm_cfg80211 *cfg,
+	bcm_struct_cfgdev *cfgdev, const wl_event_msg_t *e, void *data);
+
+#endif	/* _wl_cfgnan_h_ */
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.c
index 5c893d32ac77..6467e3619fe5 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfgp2p driver
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.h
index 1310b9231eb2..9474f2e29382 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgp2p.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfgp2p driver
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.c
index 30d73cdee16f..bd380025de8f 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 Vendor Extension Code
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.h
index 151650c90abb..ceb6f82f50bf 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_cfgvendor.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux cfg80211 Vendor Extension Code
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_dbg.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_dbg.h
index 8d0a44045757..ba0a4455781c 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_dbg.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_dbg.h
@@ -1,8 +1,9 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Minimal debug/trace/assert driver definitions for
  * Broadcom 802.11 Networking Adapter.
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.c
index ff1e840a14f4..51d7d2d50aa2 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux Wireless Extensions support
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.h
index 484d9bb43818..29d920f93037 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_iw.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux Wireless Extensions support
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_linux_mon.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_linux_mon.c
index 755f3d97ec1b..4ded0e9a7755 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_linux_mon.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_linux_mon.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Broadcom Dongle Host Driver (DHD), Linux monitor network interface
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_roam.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_roam.c
index 4f98c9db52ef..810e685e2bb1 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_roam.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wl_roam.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Linux roam cache
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.c b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.c
index 0bf26b2bfcf7..2d756569a7ff 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.c
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.c
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Common function shared by Linux WEXT, cfg80211 and p2p drivers
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you
diff --git a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.h b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.h
index 2cdd36f4273a..ce7b4b32dc5d 100644
--- a/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.h
+++ b/drivers/net/wireless/rockchip_wlan/cywdhd/bcmdhd/wldev_common.h
@@ -1,7 +1,8 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Common function shared by Linux WEXT, cfg80211 and p2p drivers
  *
- * Copyright (C) 1999-2017, Broadcom Corporation
+ * Copyright (C) 1999-2018, Broadcom Corporation
  * 
  *      Unless you and Broadcom execute a separate written software license
  * agreement governing use of this software, this software is licensed to you

commit 70b14d6e19e49a2417c3eda1ad7460bce1eef2b6
Author: Yao Xiao <xiaoyao@rock-chips.com>
Date:   Thu Jun 6 16:36:34 2019 +0800

    net: rockchip_wlan: update rtl8723ds to v5.6.5_31752-2e2e
    
    Change-Id: I3a1b64e9054ec36592473f059fe2373188cbc455
    Signed-off-by: Yao Xiao <xiaoyao@rock-chips.com>

diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/Makefile b/drivers/net/wireless/rockchip_wlan/rtl8723ds/Makefile
old mode 100644
new mode 100755
index 82d957c5df6d..9948579b9cec
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/Makefile
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/Makefile
@@ -37,9 +37,12 @@ CONFIG_RTL8723B = n
 CONFIG_RTL8814A = n
 CONFIG_RTL8723C = n
 CONFIG_RTL8188F = n
+CONFIG_RTL8188GTV = n
 CONFIG_RTL8822B = n
 CONFIG_RTL8723D = y
 CONFIG_RTL8821C = n
+CONFIG_RTL8710B = n
+CONFIG_RTL8192F = n
 ######################### Interface ###########################
 CONFIG_USB_HCI = n
 CONFIG_PCI_HCI = n
@@ -50,7 +53,6 @@ CONFIG_MP_INCLUDED = y
 CONFIG_POWER_SAVING = y
 CONFIG_USB_AUTOSUSPEND = n
 CONFIG_HW_PWRP_DETECTION = n
-CONFIG_WIFI_TEST = n
 CONFIG_BT_COEXIST = y
 CONFIG_INTEL_WIDI = n
 CONFIG_WAPI_SUPPORT = n
@@ -73,8 +75,13 @@ CONFIG_MCC_MODE = n
 CONFIG_APPEND_VENDOR_IE_ENABLE = n
 CONFIG_RTW_NAPI = y
 CONFIG_RTW_GRO = y
+CONFIG_RTW_NETIF_SG = y
+CONFIG_TX_CSUM_OFFLOAD = n
 CONFIG_RTW_IPCAM_APPLICATION = n
 CONFIG_RTW_REPEATER_SON = n
+CONFIG_RTW_WIFI_HAL = n
+CONFIG_ICMP_VOQ = n
+CONFIG_IP_R_MONITOR = n #arp VOQ and high rate
 ########################## Debug ###########################
 CONFIG_RTW_DEBUG = y
 # default log level is _DRV_INFO_ = 4,
@@ -82,13 +89,20 @@ CONFIG_RTW_DEBUG = y
 CONFIG_RTW_LOG_LEVEL = 2
 ######################## Wake On Lan ##########################
 CONFIG_WOWLAN = y
-CONFIG_WAKEUP_TYPE = 0x7 #bit2: deauth, bit1: unicast, bit0: magic pkt.
-CONFIG_GPIO_WAKEUP = y
+#bit2: deauth, bit1: unicast, bit0: magic pkt.
+CONFIG_WAKEUP_TYPE = 0x7
+#bit0: disBBRF off, #bit1: Wireless remote controller (WRC)
+CONFIG_SUSPEND_TYPE = 0
+CONFIG_WOW_STA_MIX = n
+CONFIG_GPIO_WAKEUP = n
 CONFIG_WAKEUP_GPIO_IDX = default
-CONFIG_HIGH_ACTIVE = n
+CONFIG_HIGH_ACTIVE_DEV2HST = n
+######### only for USB #########
+CONFIG_ONE_PIN_GPIO = n
+CONFIG_HIGH_ACTIVE_HST2DEV = n
 CONFIG_PNO_SUPPORT = n
 CONFIG_PNO_SET_DEBUG = n
-CONFIG_AP_WOWLAN = y
+CONFIG_AP_WOWLAN = n
 ######### Notify SDIO Host Keep Power During Syspend ##########
 CONFIG_RTW_SDIO_PM_KEEP_POWER = y
 ###################### MP HW TX MODE FOR VHT #######################
@@ -137,22 +151,30 @@ CONFIG_PLATFORM_ACTIONS_ATV5201 = n
 CONFIG_PLATFORM_ACTIONS_ATM705X = n
 CONFIG_PLATFORM_ARM_SUN50IW1P1 = n
 CONFIG_PLATFORM_ARM_RTD299X = n
+CONFIG_PLATFORM_ARM_LGE = n
 CONFIG_PLATFORM_ARM_SPREADTRUM_6820 = n
 CONFIG_PLATFORM_ARM_SPREADTRUM_8810 = n
 CONFIG_PLATFORM_ARM_WMT = n
 CONFIG_PLATFORM_TI_DM365 = n
 CONFIG_PLATFORM_MOZART = n
 CONFIG_PLATFORM_RTK119X = n
+CONFIG_PLATFORM_RTK119X_AM = n
 CONFIG_PLATFORM_RTK129X = n
+CONFIG_PLATFORM_RTK390X = n
 CONFIG_PLATFORM_NOVATEK_NT72668 = n
 CONFIG_PLATFORM_HISILICON = n
+CONFIG_PLATFORM_HISILICON_HI3798 = n
 CONFIG_PLATFORM_NV_TK1 = n
+CONFIG_PLATFORM_NV_TK1_UBUNTU = n
 CONFIG_PLATFORM_RTL8197D = n
-###############################################################
+CONFIG_PLATFORM_AML_S905 = n
+CONFIG_PLATFORM_ZTE_ZX296716 = n
+########### CUSTOMER ################################
+CONFIG_CUSTOMER_HUAWEI_GENERAL = n
 
 CONFIG_DRVEXT_MODULE = n
 
-export TopDIR ?= $(src)
+export TopDIR ?= $(shell pwd)
 
 ########### COMMON  #################################
 ifeq ($(CONFIG_GSPI_HCI), y)
@@ -184,7 +206,8 @@ _OS_INTFS_FILES :=	os_dep/osdep_service.o \
 			os_dep/linux/rtw_cfgvendor.o \
 			os_dep/linux/wifi_regd.o \
 			os_dep/linux/rtw_android.o \
-			os_dep/linux/rtw_proc.o
+			os_dep/linux/rtw_proc.o \
+			os_dep/linux/rtw_rhashtable.o
 
 ifeq ($(CONFIG_MP_INCLUDED), y)
 _OS_INTFS_FILES += os_dep/linux/ioctl_mp.o
@@ -212,6 +235,7 @@ _HAL_INTFS_FILES :=	hal/hal_intf.o \
 			hal/hal_mp.o \
 			hal/hal_mcc.o \
 			hal/hal_hci/hal_$(HCI_NAME).o \
+			hal/led/hal_led.o \
 			hal/led/hal_$(HCI_NAME)_led.o
 
 
@@ -219,28 +243,7 @@ EXTRA_CFLAGS += -I$(src)/platform
 _PLATFORM_FILES := platform/platform_ops.o
 
 EXTRA_CFLAGS += -I$(src)/hal/btc
-_BTC_FILES += hal/btc/halbtc8723bwifionly.o \
-				hal/btc/halbtc8822bwifionly.o \
-				hal/btc/halbtc8821cwifionly.o
-ifeq ($(CONFIG_BT_COEXIST), y)
-_BTC_FILES += hal/btc/halbtc8192e1ant.o \
-				hal/btc/halbtc8192e2ant.o \
-				hal/btc/halbtc8723b1ant.o \
-				hal/btc/halbtc8723b2ant.o \
-				hal/btc/halbtc8812a1ant.o \
-				hal/btc/halbtc8812a2ant.o \
-				hal/btc/halbtc8821a1ant.o \
-				hal/btc/halbtc8821a2ant.o \
-				hal/btc/halbtc8703b1ant.o \
-				hal/btc/halbtc8723d1ant.o \
-				hal/btc/halbtc8723d2ant.o \
-				hal/btc/halbtc8822b1ant.o \
-				hal/btc/halbtc8822b2ant.o \
-				hal/btc/halbtc8821c1ant.o \
-				hal/btc/halbtc8821c2ant.o
-endif
-
-include $(TopDIR)/hal/phydm/phydm.mk
+
 ########### HAL_RTL8188E #################################
 ifeq ($(CONFIG_RTL8188E), y)
 
@@ -355,6 +358,11 @@ ifeq ($(CONFIG_SDIO_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8192E_SDIO.o
 endif
 
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8192e1ant.o \
+				hal/btc/halbtc8192e2ant.o
+endif
+
 endif
 
 ########### HAL_RTL8812A_RTL8821A #################################
@@ -451,6 +459,17 @@ _HAL_INTFS_FILES +=	hal/rtl8812a/hal8821a_fw.o
 		
 endif
 
+ifeq ($(CONFIG_BT_COEXIST), y)
+ifeq ($(CONFIG_RTL8812A), y)
+_BTC_FILES += hal/btc/halbtc8812a1ant.o \
+				hal/btc/halbtc8812a2ant.o
+endif
+ifeq ($(CONFIG_RTL8821A), y)
+_BTC_FILES += hal/btc/halbtc8821a1ant.o \
+				hal/btc/halbtc8821a2ant.o
+endif
+endif
+
 endif
 
 ########### HAL_RTL8723B #################################
@@ -503,6 +522,12 @@ ifeq ($(CONFIG_SDIO_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723B_SDIO.o
 endif
 
+_BTC_FILES += hal/btc/halbtc8723bwifionly.o
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8723b1ant.o \
+				hal/btc/halbtc8723b2ant.o
+endif
+
 endif
 
 ########### HAL_RTL8814A #################################
@@ -613,6 +638,10 @@ ifeq ($(CONFIG_PCI_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8703B_PCIE.o
 endif
 
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8703b1ant.o
+endif
+
 endif
 
 ########### HAL_RTL8723D #################################
@@ -667,6 +696,11 @@ ifeq ($(CONFIG_PCI_HCI), y)
 _HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723D_PCIE.o
 endif
 
+ifeq ($(CONFIG_BT_COEXIST), y)
+_BTC_FILES += hal/btc/halbtc8723d1ant.o \
+				hal/btc/halbtc8723d2ant.o
+endif
+
 endif
 
 ########### HAL_RTL8188F #################################
@@ -719,16 +753,183 @@ endif
 
 endif
 
+########### HAL_RTL8188GTV #################################
+ifeq ($(CONFIG_RTL8188GTV), y)
+
+RTL871X = rtl8188gtv
+ifeq ($(CONFIG_USB_HCI), y)
+MODULE_NAME = 8188gtvu
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 8189gtvs
+endif
+
+EXTRA_CFLAGS += -DCONFIG_RTL8188GTV
+
+_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
+					hal/$(RTL871X)/Hal8188GTVPwrSeq.o\
+					hal/$(RTL871X)/$(RTL871X)_sreset.o
+
+_HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
+			hal/$(RTL871X)/$(RTL871X)_phycfg.o \
+			hal/$(RTL871X)/$(RTL871X)_rf6052.o \
+			hal/$(RTL871X)/$(RTL871X)_dm.o \
+			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
+			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8188gtv_fw.o
+
+_HAL_INTFS_FILES +=	\
+			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
+
+ifeq ($(CONFIG_PCI_HCI), y)
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
+else
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
+endif
+
+ifeq ($(CONFIG_USB_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188GTV_USB.o
+endif
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188GTV_SDIO.o
+endif
+
+endif
+
 ########### HAL_RTL8822B #################################
 ifeq ($(CONFIG_RTL8822B), y)
-include $(TopDIR)/rtl8822b.mk
+RTL871X := rtl8822b
+ifeq ($(CONFIG_USB_HCI), y)
+ifeq ($(CONFIG_BT_COEXIST), n)
+MODULE_NAME = 8812bu
+else
+MODULE_NAME = 88x2bu
+endif
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+MODULE_NAME = 88x2be
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 88x2bs
 endif
 
+endif
 ########### HAL_RTL8821C #################################
 ifeq ($(CONFIG_RTL8821C), y)
-include $(TopDIR)/rtl8821c.mk
+RTL871X := rtl8821c
+ifeq ($(CONFIG_USB_HCI), y)
+MODULE_NAME = 8821cu
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+MODULE_NAME = 8821ce
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 8821cs
+endif
+
+endif
+
+########### HAL_RTL8710B #################################
+ifeq ($(CONFIG_RTL8710B), y)
+
+RTL871X = rtl8710b
+ifeq ($(CONFIG_USB_HCI), y)
+MODULE_NAME = 8710bu
+MODULE_SUB_NAME = 8710bu
+endif
+
+EXTRA_CFLAGS += -DCONFIG_RTL8710B
+
+_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
+					hal/$(RTL871X)/Hal8710BPwrSeq.o\
+					hal/$(RTL871X)/$(RTL871X)_sreset.o
+
+_HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
+			hal/$(RTL871X)/$(RTL871X)_phycfg.o \
+			hal/$(RTL871X)/$(RTL871X)_rf6052.o \
+			hal/$(RTL871X)/$(RTL871X)_dm.o \
+			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
+			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8710b_fw.o \
+			hal/$(RTL871X)/$(RTL871X)_lps_poff.o
+
+
+_HAL_INTFS_FILES +=	\
+			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_led.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_xmit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_recv.o
+
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
+
+ifeq ($(CONFIG_USB_HCI), y)
+_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8710B_USB.o
+endif
+
+endif
+
+########### HAL_RTL8192F #################################
+ifeq ($(CONFIG_RTL8192F), y)
+
+RTL871X = rtl8192f
+ifeq ($(CONFIG_USB_HCI), y)
+MODULE_NAME = 8192fu
+MODULE_SUB_NAME = 8192fu
+endif
+ifeq ($(CONFIG_PCI_HCI), y)
+MODULE_NAME = 8192fe
+MODULE_SUB_NAME = 8192fe
+endif
+ifeq ($(CONFIG_SDIO_HCI), y)
+MODULE_NAME = 8192fs
+MODULE_SUB_NAME = 8192fs
+endif
+
+EXTRA_CFLAGS += -DCONFIG_RTL8192F
+
+_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
+					hal/$(RTL871X)/Hal8192FPwrSeq.o\
+					hal/$(RTL871X)/$(RTL871X)_sreset.o
+
+_HAL_INTFS_FILES +=	hal/$(RTL871X)/$(RTL871X)_hal_init.o \
+			hal/$(RTL871X)/$(RTL871X)_phycfg.o \
+			hal/$(RTL871X)/$(RTL871X)_rf6052.o \
+			hal/$(RTL871X)/$(RTL871X)_dm.o \
+			hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
+			hal/$(RTL871X)/$(RTL871X)_cmd.o \
+			hal/$(RTL871X)/hal8192f_fw.o \
+			hal/$(RTL871X)/$(RTL871X)_lps_poff.o
+
+
+_HAL_INTFS_FILES +=	\
+			hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_led.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_xmit.o \
+			hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_recv.o
+			
+ifeq ($(CONFIG_PCI_HCI), y)
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
+else
+_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
+endif
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+_HAL_INTFS_FILES += hal/efuse/$(RTL871X)/HalEfuseMask8192F_SDIO.o
+endif
+
+ifeq ($(CONFIG_USB_HCI), y)
+_HAL_INTFS_FILES += hal/efuse/$(RTL871X)/HalEfuseMask8192F_USB.o
+endif
+
+ifeq ($(CONFIG_PCI_HCI), y)
+_HAL_INTFS_FILES += hal/efuse/$(RTL871X)/HalEfuseMask8192F_PCIE.o
 endif
 
+endif
 ########### AUTO_CFG  #################################
 
 ifeq ($(CONFIG_AUTOCFG_CP), y)
@@ -770,10 +971,6 @@ ifeq ($(CONFIG_HW_PWRP_DETECTION), y)
 EXTRA_CFLAGS += -DCONFIG_HW_PWRP_DETECTION
 endif
 
-ifeq ($(CONFIG_WIFI_TEST), y)
-EXTRA_CFLAGS += -DCONFIG_WIFI_TEST
-endif
-
 ifeq ($(CONFIG_BT_COEXIST), y)
 EXTRA_CFLAGS += -DCONFIG_BT_COEXIST
 endif
@@ -796,8 +993,8 @@ ifneq ($(USER_EFUSE_MAP_PATH),)
 EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"$(USER_EFUSE_MAP_PATH)\"
 else ifeq ($(MODULE_NAME), 8189es)
 EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"/system/etc/wifi/wifi_efuse_8189e.map\"
-else ifeq ($(MODULE_NAME), 8723ds)
-EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"/vendor/etc/firmware/wifi_efuse_8723ds.map\"
+else ifeq ($(MODULE_NAME), 8723bs)
+EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"/system/etc/wifi/wifi_efuse_8723bs.map\"
 else
 EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"/system/etc/wifi/wifi_efuse_$(MODULE_NAME).map\"
 endif
@@ -876,6 +1073,10 @@ endif
 
 ifeq ($(CONFIG_WOWLAN), y)
 EXTRA_CFLAGS += -DCONFIG_WOWLAN -DRTW_WAKEUP_EVENT=$(CONFIG_WAKEUP_TYPE)
+EXTRA_CFLAGS += -DRTW_SUSPEND_TYPE=$(CONFIG_SUSPEND_TYPE)
+ifeq ($(CONFIG_WOW_STA_MIX), y)
+EXTRA_CFLAGS += -DRTW_WOW_STA_MIX
+endif
 ifeq ($(CONFIG_SDIO_HCI), y)
 EXTRA_CFLAGS += -DCONFIG_RTW_SDIO_PM_KEEP_POWER
 endif
@@ -897,13 +1098,22 @@ endif
 
 ifeq ($(CONFIG_GPIO_WAKEUP), y)
 EXTRA_CFLAGS += -DCONFIG_GPIO_WAKEUP
-ifeq ($(CONFIG_HIGH_ACTIVE), y)
-EXTRA_CFLAGS += -DHIGH_ACTIVE=1
+ifeq ($(CONFIG_ONE_PIN_GPIO), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_ONE_PIN_GPIO
+endif
+ifeq ($(CONFIG_HIGH_ACTIVE_DEV2HST), y)
+EXTRA_CFLAGS += -DHIGH_ACTIVE_DEV2HST=1
 else
-EXTRA_CFLAGS += -DHIGH_ACTIVE=0
+EXTRA_CFLAGS += -DHIGH_ACTIVE_DEV2HST=0
 endif
 endif
 
+ifeq ($(CONFIG_HIGH_ACTIVE_HST2DEV), y)
+EXTRA_CFLAGS += -DHIGH_ACTIVE_HST2DEV=1
+else
+EXTRA_CFLAGS += -DHIGH_ACTIVE_HST2DEV=0
+endif
+
 ifneq ($(CONFIG_WAKEUP_GPIO_IDX), default)
 EXTRA_CFLAGS += -DWAKEUP_GPIO_IDX=$(CONFIG_WAKEUP_GPIO_IDX)
 endif
@@ -956,6 +1166,31 @@ EXTRA_CFLAGS += -DCONFIG_WIFI_MONITOR
 endif
 endif
 
+ifeq ($(CONFIG_RTW_NETIF_SG), y)
+EXTRA_CFLAGS += -DCONFIG_RTW_NETIF_SG
+endif
+
+ifeq ($(CONFIG_TX_CSUM_OFFLOAD), y)
+EXTRA_CFLAGS += -DCONFIG_TX_CSUM_OFFLOAD
+endif
+
+ifeq ($(CONFIG_ICMP_VOQ), y)
+EXTRA_CFLAGS += -DCONFIG_ICMP_VOQ
+endif
+
+ifeq ($(CONFIG_IP_R_MONITOR), y)
+EXTRA_CFLAGS += -DCONFIG_IP_R_MONITOR
+endif
+
+ifeq ($(CONFIG_RTW_WIFI_HAL), y)
+#EXTRA_CFLAGS += -DCONFIG_RTW_WIFI_HAL_DEBUG
+EXTRA_CFLAGS += -DCONFIG_RTW_WIFI_HAL
+EXTRA_CFLAGS += -DCONFIG_RTW_CFGVEDNOR_LLSTATS
+EXTRA_CFLAGS += -DCONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+EXTRA_CFLAGS += -DCONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+EXTRA_CFLAGS += -DCONFIG_RTW_CFGVENDOR_WIFI_LOGGER
+endif
+
 ifeq ($(CONFIG_MP_VHT_HW_TX_MODE), y)
 EXTRA_CFLAGS += -DCONFIG_MP_VHT_HW_TX_MODE
 ifeq ($(CONFIG_PLATFORM_I386_PC), y)
@@ -978,6 +1213,9 @@ endif
 
 EXTRA_CFLAGS += -DDM_ODM_SUPPORT_TYPE=0x04
 
+#WIFIDBG
+EXTRA_CFLAGS += -DCONFIG_AIRKISS
+
 ifeq ($(CONFIG_PLATFORM_I386_PC), y)
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
@@ -1003,17 +1241,26 @@ EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
 EXTRA_CFLAGS += -DRTW_VENDOR_EXT_SUPPORT
 EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
 ARCH ?= arm
-# for ubuntu environment
-#CROSS_COMPILE ?=
-#KVER := $(shell uname -r)
-#KSRC := /lib/modules/$(KVER)/build
-#MODDESTDIR := /lib/modules/$(KVER)/kernel/drivers/net/wireless/
-#INSTALL_PREFIX :=
+
 CROSS_COMPILE := /mnt/newdisk/android_sdk/nvidia_tk1/android_L/prebuilts/gcc/linux-x86/arm/arm-eabi-4.8/bin/arm-eabi-
 KSRC :=/mnt/newdisk/android_sdk/nvidia_tk1/android_L/out/target/product/shieldtablet/obj/KERNEL/
 MODULE_NAME = wlan
 endif
 
+ifeq ($(CONFIG_PLATFORM_NV_TK1_UBUNTU), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_NV_TK1
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+
+ARCH ?= arm
+
+CROSS_COMPILE ?=
+KVER := $(shell uname -r)
+KSRC := /lib/modules/$(KVER)/build
+MODDESTDIR := /lib/modules/$(KVER)/kernel/drivers/net/wireless/
+INSTALL_PREFIX :=
+endif
+
 ifeq ($(CONFIG_PLATFORM_ACTIONS_ATM702X), y)
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID -DCONFIG_PLATFORM_ACTIONS_ATM702X
 #ARCH := arm
@@ -1116,7 +1363,6 @@ endif
 
 ifeq ($(CONFIG_PLATFORM_ANDROID_INTEL_X86), y)
 EXTRA_CFLAGS += -DCONFIG_PLATFORM_ANDROID_INTEL_X86
-EXTRA_CFLAGS += -DCONFIG_PLATFORM_INTEL_CHT_ANDROID60 # Kernel 3.14 but has been applied some 4.3 patch
 EXTRA_CFLAGS += -DCONFIG_PLATFORM_INTEL_BYT
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
@@ -1342,13 +1588,11 @@ EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
 # default setting for Power control
 EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
-EXTRA_CFLAGS += -DRTW_SUPPORT_PLATFORM_SHUTDOWN
-EXTRA_CFLAGS += -DCONFIG_RESUME_IN_WORKQUEUE
 # default setting for Special function
 ARCH := arm
 CROSS_COMPILE := /home/android_sdk/Rockchip/Rk3188/prebuilts/gcc/linux-x86/arm/arm-eabi-4.6/bin/arm-eabi-
 KSRC := /home/android_sdk/Rockchip/Rk3188/kernel
-MODULE_NAME := 8723ds
+MODULE_NAME := rtl8723ds
 endif
 
 ifeq ($(CONFIG_PLATFORM_ARM_RK3066), y)
@@ -1554,10 +1798,9 @@ endif
 
 ifeq ($(CONFIG_PLATFORM_ARM_RTD299X), y)
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
-EXTRA_CFLAGS += -DUSB_XMITBUF_ALIGN_SZ=1024 -DUSB_PACKET_OFFSET_SZ=0
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
-ifeq ($(CONFIG_ANDROID), y)
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+ifeq ($(CONFIG_ANDROID), y)
 # Enable this for Android 5.0
 EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
 endif
@@ -1565,6 +1808,32 @@ endif
 INSTALL_PREFIX :=
 endif
 
+ifeq ($(CONFIG_PLATFORM_ARM_RTD299X_LG), y)
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DRTW_P2P_GROUP_INTERFACE=1
+EXTRA_CFLAGS += -DCONFIG_IFACE_NUMBER=3
+#EXTRA_CFLAGS += -DCONFIG_FIX_HWPORT
+EXTRA_CFLAGS += -DLGE_PRIVATE
+EXTRA_CFLAGS += -DPURE_SUPPLICANT
+EXTRA_CFLAGS += -DCONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP -DCONFIG_RTW_IOCTL_SET_COUNTRY
+EXTRA_CFLAGS += -DDBG_RX_DFRAME_RAW_DATA
+EXTRA_CFLAGS += -DRTW_REDUCE_SCAN_SWITCH_CH_TIME
+ARCH ?= arm
+KVER ?=
+
+ifneq ($(PLATFORM), WEBOS)
+$(info PLATFORM is empty)
+CROSS_COMPILE ?= /mnt/newdisk/LGE/arm-lg115x-linux-gnueabi-4.8-2016.03-x86_64/bin/arm-lg115x-linux-gnueabi-
+KSRC ?= /mnt/newdisk/LGE/linux-rockhopper_k3lp_drd4tv_423
+endif
+
+CROSS_COMPILE ?=
+KSRC ?= $(LINUX_SRC)
+INSTALL_PREFIX ?=
+endif
+
 ifeq ($(CONFIG_PLATFORM_HISILICON), y)
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_HISILICON
 ifeq ($(SUPPORT_CONCURRENT),y)
@@ -1581,6 +1850,42 @@ ifeq ($(KSRC),)
 endif
 endif
 
+ifeq ($(CONFIG_PLATFORM_HISILICON_HI3798), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON_HI3798
+#EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON_HI3798_MV200_HDMI_DONGLE
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+# default setting for Android
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
+EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
+# default setting for Android 5.x and later
+#EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+
+# If system could power on and recognize Wi-Fi SDIO automatically,
+# platfrom operations are not necessary.
+#ifeq ($(CONFIG_SDIO_HCI), y)
+#EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
+#_PLATFORM_FILES += platform/platform_hisilicon_hi3798_sdio.o
+#EXTRA_CFLAGS += -DCONFIG_HISI_SDIO_ID=1
+#endif
+
+ARCH ?= arm
+CROSS_COMPILE ?= /HiSTBAndroidV600R003C00SPC021_git_0512/device/hisilicon/bigfish/sdk/tools/linux/toolchains/arm-histbv310-linux/bin/arm-histbv310-linux-
+ifndef KSRC
+KSRC := /HiSTBAndroidV600R003C00SPC021_git_0512/device/hisilicon/bigfish/sdk/source/kernel/linux-3.18.y
+KSRC += O=/HiSTBAndroidV600R003C00SPC021_git_0512/out/target/product/Hi3798MV200/obj/KERNEL_OBJ
+endif
+
+ifeq ($(CONFIG_RTL8822B), y)
+ifeq ($(CONFIG_SDIO_HCI), y)
+CONFIG_RTL8822BS ?= m
+USER_MODULE_NAME := rtl8822bs
+endif
+endif
+
+endif
+
 # Platform setting
 ifeq ($(CONFIG_PLATFORM_ARM_SPREADTRUM_6820), y)
 ifeq ($(CONFIG_ANDROID_2X), y)
@@ -1634,7 +1939,6 @@ EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
 EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
 # default setting for Android 4.1, 4.2
 EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
-EXTRA_CFLAGS += -DCONFIG_IFACE_NUMBER=3
 EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
 #EXTRA_CFLAGS +=  -DCONFIG_QOS_OPTIMIZATION
 EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
@@ -1660,6 +1964,26 @@ MODULE_NAME := 8192eu
 
 endif
 
+ifeq ($(CONFIG_PLATFORM_RTK119X_AM), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_RTK119X_AM
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE -DCONFIG_FULL_CH_IN_P2P_HANDSHAKE
+EXTRA_CFLAGS += -DCONFIG_IFACE_NUMBER=3
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+
+ifeq ($(CONFIG_USB_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
+endif
+
+ARCH := arm
+
+#CROSS_COMPILE := arm-linux-gnueabihf-
+KVER  := 3.10.24
+#KSRC :=
+CROSS_COMPILE :=
+endif
+
 ifeq ($(CONFIG_PLATFORM_RTK129X), y)
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
 EXTRA_CFLAGS += -DRTK_129X_PLATFORM
@@ -1696,6 +2020,22 @@ CROSS_COMPILE := /home/android_sdk/DHC/trunk-6.0.0_r1-QA160627/phoenix/toolchain
 KSRC := /home/android_sdk/DHC/trunk-6.0.0_r1-QA160627/linux-kernel
 endif
 
+ifeq ($(CONFIG_PLATFORM_RTK390X), y)
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_RTK390X
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
+EXTRA_CFLAGS += -DCONFIG_RTW_NETIF_SG
+ifeq ($(CONFIG_USB_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
+endif
+
+ARCH:=rlx
+
+CROSS_COMPILE:=mips-linux-
+KSRC:= /home/realtek/share/Develop/IPCAM_SDK/RealSil/rts3901_sdk_v1.2_vanilla/linux-3.10
+
+endif
+
 ifeq ($(CONFIG_PLATFORM_NOVATEK_NT72668), y)
 EXTRA_CFLAGS += -DCONFIG_PLATFORM_NOVATEK_NT72668
 EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
@@ -1729,6 +2069,77 @@ CROSS_COMPILE:= $(DIR_LINUX)/../toolchain/rsdk-1.5.5-5281-EB-2.6.30-0.9.30.3-110
 KSRC := $(DIR_LINUX)
 endif
 
+ifeq ($(CONFIG_PLATFORM_AML_S905), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_AML_S905
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -fno-pic
+# default setting for Android
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
+EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
+# default setting for Android 5.x and later
+EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
+_PLATFORM_FILES += platform/platform_aml_s905_sdio.o
+endif
+
+ARCH ?= arm64
+CROSS_COMPILE ?= /4.4_S905L_8822bs_compile/gcc-linaro-aarch64-linux-gnu-4.9-2014.09_linux/bin/aarch64-linux-gnu-
+ifndef KSRC
+KSRC := /4.4_S905L_8822bs_compile/common
+# To locate output files in a separate directory.
+KSRC += O=/4.4_S905L_8822bs_compile/KERNEL_OBJ
+endif
+
+ifeq ($(CONFIG_RTL8822B), y)
+ifeq ($(CONFIG_SDIO_HCI), y)
+CONFIG_RTL8822BS ?= m
+USER_MODULE_NAME := 8822bs
+endif
+endif
+
+endif
+
+ifeq ($(CONFIG_PLATFORM_ZTE_ZX296716), y)
+EXTRA_CFLAGS += -Wno-error=date-time
+EXTRA_CFLAGS += -DCONFIG_PLATFORM_ZTE_ZX296716
+EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
+# default setting for Android
+EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
+EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
+EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
+# default setting for Android 5.x and later
+#EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
+
+ifeq ($(CONFIG_SDIO_HCI), y)
+# mark this temporarily
+#EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
+#_PLATFORM_FILES += platform/platform_zte_zx296716_sdio.o
+endif
+
+ARCH ?= arm64
+CROSS_COMPILE ?=
+KSRC ?=
+
+ifeq ($(CONFIG_RTL8822B), y)
+ifeq ($(CONFIG_SDIO_HCI), y)
+CONFIG_RTL8822BS ?= m
+USER_MODULE_NAME := 8822bs
+endif
+endif
+
+endif
+
+########### CUSTOMER ################################
+ifeq ($(CONFIG_CUSTOMER_HUAWEI_GENERAL), y)
+CONFIG_CUSTOMER_HUAWEI = y
+endif
+
+ifeq ($(CONFIG_CUSTOMER_HUAWEI), y)
+EXTRA_CFLAGS += -DCONFIG_HUAWEI_PROC
+endif
+
 ifeq ($(CONFIG_MULTIDRV), y)
 
 ifeq ($(CONFIG_SDIO_HCI), y)
@@ -1753,6 +2164,19 @@ endif
 
 ifneq ($(KERNELRELEASE),)
 
+########### this part for *.mk ############################
+include $(src)/hal/phydm/phydm.mk
+
+########### HAL_RTL8822B #################################
+ifeq ($(CONFIG_RTL8822B), y)
+include $(src)/rtl8822b.mk
+endif
+
+########### HAL_RTL8821C #################################
+ifeq ($(CONFIG_RTL8821C), y)
+include $(src)/rtl8821c.mk
+endif
+
 rtk_core :=	core/rtw_cmd.o \
 		core/rtw_security.o \
 		core/rtw_debug.o \
@@ -1767,9 +2191,13 @@ rtk_core :=	core/rtw_cmd.o \
 		core/rtw_vht.o \
 		core/rtw_pwrctrl.o \
 		core/rtw_rf.o \
+		core/rtw_chplan.o \
 		core/rtw_recv.o \
 		core/rtw_sta_mgt.o \
 		core/rtw_ap.o \
+		core/mesh/rtw_mesh.o \
+		core/mesh/rtw_mesh_pathtbl.o \
+		core/mesh/rtw_mesh_hwmp.o \
 		core/rtw_xmit.o	\
 		core/rtw_p2p.o \
 		core/rtw_rson.o \
@@ -1877,7 +2305,7 @@ clean:
 	cd hal ; rm -fr */*/*.mod.c */*/*.mod */*/*.o */*/.*.cmd */*/*.ko
 	cd hal ; rm -fr */*.mod.c */*.mod */*.o */.*.cmd */*.ko
 	cd hal ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
-	cd core/efuse ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
+	cd core ; rm -fr */*.mod.c */*.mod */*.o */.*.cmd */*.ko
 	cd core ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
 	cd os_dep/linux ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
 	cd os_dep ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/efuse/rtw_efuse.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/efuse/rtw_efuse.c
index 83d6c441de5a..e5aec4d49342 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/efuse/rtw_efuse.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/efuse/rtw_efuse.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -62,7 +63,7 @@ BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
 	if (pAdapter->registrypriv.boffefusemask)
 		return FALSE;
 
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#ifdef CONFIG_USB_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		return (IS_MASKED(8188E, _MUSB, Offset)) ? TRUE : FALSE;
@@ -99,6 +100,10 @@ BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
 	if (IS_HARDWARE_TYPE_8188F(pAdapter))
 		return (IS_MASKED(8188F, _MUSB, Offset)) ? TRUE : FALSE;
 #endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return (IS_MASKED(8188GTV, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
 #if defined(CONFIG_RTL8822B)
 	if (IS_HARDWARE_TYPE_8822B(pAdapter))
 		return (IS_MASKED(8822B, _MUSB, Offset)) ? TRUE : FALSE;
@@ -107,13 +112,22 @@ BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
 	if (IS_HARDWARE_TYPE_8723D(pAdapter))
 		return (IS_MASKED(8723D, _MUSB, Offset)) ? TRUE : FALSE;
 #endif
-
+#if defined(CONFIG_RTL8710B)
+	if (IS_HARDWARE_TYPE_8710B(pAdapter))
+		return (IS_MASKED(8710B, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
 #if defined(CONFIG_RTL8821C)
 	if (IS_HARDWARE_TYPE_8821CU(pAdapter))
 		return (IS_MASKED(8821C, _MUSB, Offset)) ? TRUE : FALSE;
 #endif
 
-#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FU(pAdapter))
+		return (IS_MASKED(8192F, _MUSB, Offset)) ? TRUE : FALSE;
+#endif
+#endif /*CONFIG_USB_HCI*/
+
+#ifdef CONFIG_PCI_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		return (IS_MASKED(8188E, _MPCIE, Offset)) ? TRUE : FALSE;
@@ -147,7 +161,13 @@ BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
 		return (IS_MASKED(8821C, _MPCIE, Offset)) ? TRUE : FALSE;
 #endif
 
-#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FE(pAdapter))
+		return (IS_MASKED(8192F, _MPCIE, Offset)) ? TRUE : FALSE;
+#endif
+#endif /*CONFIG_PCI_HCI*/
+
+#ifdef CONFIG_SDIO_HCI
 #ifdef CONFIG_RTL8188E_SDIO
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		return (IS_MASKED(8188E, _MSDIO, Offset)) ? TRUE : FALSE;
@@ -156,10 +176,14 @@ BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
 	if (IS_HARDWARE_TYPE_8723BS(pAdapter))
 		return (IS_MASKED(8723B, _MSDIO, Offset)) ? TRUE : FALSE;
 #endif
-#ifdef CONFIG_RTL8188F_SDIO
+#ifdef CONFIG_RTL8188F
 	if (IS_HARDWARE_TYPE_8188F(pAdapter))
 		return (IS_MASKED(8188F, _MSDIO, Offset)) ? TRUE : FALSE;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return (IS_MASKED(8188GTV, _MSDIO, Offset)) ? TRUE : FALSE;
+#endif
 #ifdef CONFIG_RTL8192E
 	if (IS_HARDWARE_TYPE_8192ES(pAdapter))
 		return (IS_MASKED(8192E, _MSDIO, Offset)) ? TRUE : FALSE;
@@ -176,7 +200,11 @@ BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
 	if (IS_HARDWARE_TYPE_8822B(pAdapter))
 		return (IS_MASKED(8822B, _MSDIO, Offset)) ? TRUE : FALSE;
 #endif
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FS(pAdapter))
+		return (IS_MASKED(8192F, _MSDIO, Offset)) ? TRUE : FALSE;
 #endif
+#endif /*CONFIG_SDIO_HCI*/
 
 	return FALSE;
 }
@@ -185,7 +213,7 @@ void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
 
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#ifdef CONFIG_USB_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		GET_MASK_ARRAY(8188E, _MUSB, pArray);
@@ -214,6 +242,10 @@ void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
 	if (IS_HARDWARE_TYPE_8188F(pAdapter))
 		GET_MASK_ARRAY(8188F, _MUSB, pArray);
 #endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		GET_MASK_ARRAY(8188GTV, _MUSB, pArray);
+#endif
 #if defined(CONFIG_RTL8814A)
 	if (IS_HARDWARE_TYPE_8814A(pAdapter))
 		GET_MASK_ARRAY(8814A, _MUSB, pArray);
@@ -226,9 +258,13 @@ void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
 	if (IS_HARDWARE_TYPE_8821CU(pAdapter))
 		GET_MASK_ARRAY(8821C, _MUSB, pArray);
 #endif
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FU(pAdapter))
+		GET_MASK_ARRAY(8192F, _MUSB, pArray);
+#endif
+#endif /*CONFIG_USB_HCI*/
 
-
-#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+#ifdef CONFIG_PCI_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		GET_MASK_ARRAY(8188E, _MPCIE, pArray);
@@ -261,9 +297,13 @@ void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
 	if (IS_HARDWARE_TYPE_8821CE(pAdapter))
 		GET_MASK_ARRAY(8821C, _MPCIE, pArray);
 #endif
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FE(pAdapter))
+		GET_MASK_ARRAY(8192F, _MPCIE, pArray);
+#endif
+#endif /*CONFIG_PCI_HCI*/
 
-
-#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+#ifdef CONFIG_SDIO_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		GET_MASK_ARRAY(8188E, _MSDIO, pArray);
@@ -276,6 +316,10 @@ void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
 	if (IS_HARDWARE_TYPE_8188F(pAdapter))
 		GET_MASK_ARRAY(8188F, _MSDIO, pArray);
 #endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		GET_MASK_ARRAY(8188GTV, _MSDIO, pArray);
+#endif
 #if defined(CONFIG_RTL8192E)
 	if (IS_HARDWARE_TYPE_8192ES(pAdapter))
 		GET_MASK_ARRAY(8192E, _MSDIO, pArray);
@@ -292,14 +336,18 @@ void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
 	if (IS_HARDWARE_TYPE_8822B(pAdapter))
 		GET_MASK_ARRAY(8822B , _MSDIO, pArray);
 #endif
-#endif /*#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE*/
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FS(pAdapter))
+		GET_MASK_ARRAY(8192F, _MSDIO, pArray);
+#endif
+#endif /*CONFIG_SDIO_HCI*/
 }
 
 u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#ifdef CONFIG_USB_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		return GET_MASK_ARRAY_LEN(8188E, _MUSB);
@@ -328,6 +376,10 @@ u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
 	if (IS_HARDWARE_TYPE_8188F(pAdapter))
 		return GET_MASK_ARRAY_LEN(8188F, _MUSB);
 #endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188GTV, _MUSB);
+#endif
 #if defined(CONFIG_RTL8814A)
 	if (IS_HARDWARE_TYPE_8814A(pAdapter))
 		return GET_MASK_ARRAY_LEN(8814A, _MUSB);
@@ -340,9 +392,13 @@ u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
 	if (IS_HARDWARE_TYPE_8821CU(pAdapter))
 		return GET_MASK_ARRAY_LEN(8821C, _MUSB);
 #endif
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FU(pAdapter))
+		return GET_MASK_ARRAY_LEN(8192F, _MUSB);
+#endif
+#endif /*CONFIG_USB_HCI*/
 
-
-#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+#ifdef CONFIG_PCI_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		return GET_MASK_ARRAY_LEN(8188E, _MPCIE);
@@ -375,9 +431,13 @@ u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
 	if (IS_HARDWARE_TYPE_8821CE(pAdapter))
 		return GET_MASK_ARRAY_LEN(8821C, _MPCIE);
 #endif
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FE(pAdapter))
+		return GET_MASK_ARRAY_LEN(8192F, _MPCIE);
+#endif
+#endif /*CONFIG_PCI_HCI*/
 
-
-#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+#ifdef CONFIG_SDIO_HCI
 #if defined(CONFIG_RTL8188E)
 	if (IS_HARDWARE_TYPE_8188E(pAdapter))
 		return GET_MASK_ARRAY_LEN(8188E, _MSDIO);
@@ -390,6 +450,10 @@ u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
 	if (IS_HARDWARE_TYPE_8188F(pAdapter))
 		return GET_MASK_ARRAY_LEN(8188F, _MSDIO);
 #endif
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
+		return GET_MASK_ARRAY_LEN(8188GTV, _MSDIO);
+#endif
 #if defined(CONFIG_RTL8192E)
 	if (IS_HARDWARE_TYPE_8192ES(pAdapter))
 		return GET_MASK_ARRAY_LEN(8192E, _MSDIO);
@@ -406,7 +470,11 @@ u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
 	if (IS_HARDWARE_TYPE_8822B(pAdapter))
 		return GET_MASK_ARRAY_LEN(8822B, _MSDIO);
 #endif
+#if defined(CONFIG_RTL8192F)
+	if (IS_HARDWARE_TYPE_8192FS(pAdapter))
+		return GET_MASK_ARRAY_LEN(8192F, _MSDIO);
 #endif
+#endif/*CONFIG_SDIO_HCI*/
 	return 0;
 }
 
@@ -577,7 +645,7 @@ void rtw_efuse_analyze(PADAPTER	padapter, u8 Type, u8 Fake)
 	for (bank = startBank; bank <= endBank; bank++) {
 		if (!hal_EfuseSwitchToBank(padapter, bank, bPseudoTest)) {
 			RTW_INFO("EFUSE_SwitchToBank() Fail!!\n");
-			return;
+			goto out_free_buffer;
 		}
 
 		eFuse_Addr = bank * EFUSE_MAX_BANK_SIZE;
@@ -586,7 +654,7 @@ void rtw_efuse_analyze(PADAPTER	padapter, u8 Type, u8 Fake)
 
 		if (efuseHeader == 0xFF && bank == startBank && Fake != TRUE) {
 			RTW_INFO("Non-PGed Efuse\n");
-			return;
+			goto out_free_buffer;
 		}
 		RTW_INFO("EFUSE_REAL_CONTENT_LEN = %d\n", maprawlen);
 
@@ -719,10 +787,57 @@ void rtw_efuse_analyze(PADAPTER	padapter, u8 Type, u8 Fake)
 			);
 		}
 	_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
+
+out_free_buffer:
 	if (eFuseWord)
 		rtw_mfree((u8 *)eFuseWord, EFUSE_MAX_SECTION_NUM * (EFUSE_MAX_WORD_UNIT * 2));
 }
 
+VOID efuse_PreUpdateAction(
+	PADAPTER	pAdapter,
+	pu4Byte	BackupRegs)
+{
+	if (IS_HARDWARE_TYPE_8812AU(pAdapter) || IS_HARDWARE_TYPE_8822BU(pAdapter)) {
+		/* <20131115, Kordan> Turn off Rx to prevent from being busy when writing the EFUSE. (Asked by Chunchu.)*/
+		BackupRegs[0] = phy_query_mac_reg(pAdapter, REG_RCR, bMaskDWord);
+		BackupRegs[1] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord);
+		BackupRegs[2] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord);
+#ifdef CONFIG_RTL8812A
+		BackupRegs[3] = phy_query_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord);
+#endif
+		PlatformEFIOWrite4Byte(pAdapter, REG_RCR, 0x1);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+1, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+2, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+3, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+4, 0);
+		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+5, 0);
+#ifdef CONFIG_RTL8812A
+		/* <20140410, Kordan> 0x11 = 0x4E, lower down LX_SPS0 voltage. (Asked by Chunchu)*/
+		phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskByte1, 0x4E);
+#endif
+		RTW_INFO(" %s , done\n", __func__);
+
+		}
+}
+
+
+VOID efuse_PostUpdateAction(
+	PADAPTER	pAdapter,
+	pu4Byte	BackupRegs)
+{
+	if (IS_HARDWARE_TYPE_8812AU(pAdapter) || IS_HARDWARE_TYPE_8822BU(pAdapter)) {
+		/* <20131115, Kordan> Turn on Rx and restore the registers. (Asked by Chunchu.)*/
+		phy_set_mac_reg(pAdapter, REG_RCR, bMaskDWord, BackupRegs[0]);
+		phy_set_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord, BackupRegs[1]);
+		phy_set_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord, BackupRegs[2]);
+#ifdef CONFIG_RTL8812A
+		phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord, BackupRegs[3]);
+#endif
+	RTW_INFO(" %s , done\n", __func__);
+	}
+}
+
 
 #ifdef RTW_HALMAC
 #include "../../hal/hal_halmac.h"
@@ -945,19 +1060,25 @@ u8 rtw_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
 	u8 *efuse = NULL;
 	u32 size, i;
 	int err;
+	u32	backupRegs[4] = {0};
+	u8 status = _SUCCESS;
 
+	efuse_PreUpdateAction(adapter, backupRegs);
 
 	d = adapter_to_dvobj(adapter);
 	err = rtw_halmac_get_logical_efuse_size(d, &size);
-	if (err)
-		return _FAIL;
-
+	if (err) {
+		status = _FAIL;
+		goto exit;
+	}
 	/* size error handle */
 	if ((addr + cnts) > size) {
 		if (addr < size)
 			cnts = size - addr;
-		else
-			return _FAIL;
+		else {
+			status = _FAIL;
+			goto exit;
+		}
 	}
 
 	if (cnts > 16)
@@ -967,18 +1088,24 @@ u8 rtw_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
 		err = rtw_halmac_read_logical_efuse_map(d, efuse, size, NULL, 0);
 		if (err) {
 			rtw_mfree(efuse, size);
-			return _FAIL;
+			status = _FAIL;
+			goto exit;
 		}
 
 		_rtw_memcpy(data, efuse + addr, cnts);
 		rtw_mfree(efuse, size);
 	} else {
 		err = rtw_halmac_read_logical_efuse(d, addr, cnts, data);
-		if (err)
-			return _FAIL;
+		if (err) {
+			status = _FAIL;
+			goto exit;
+		}
 	}
+	status = _SUCCESS;
+exit:
+	efuse_PostUpdateAction(adapter, backupRegs);
 
-	return _SUCCESS;
+	return status;
 }
 
 u8 rtw_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
@@ -989,23 +1116,34 @@ u8 rtw_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
 	int err;
 	u8 mask_buf[64] = "";
 	u16 mask_len = sizeof(u8) * rtw_get_efuse_mask_arraylen(adapter);
+	u32 backupRegs[4] = {0};
+	u8 status = _SUCCESS;;
+
+	efuse_PreUpdateAction(adapter, backupRegs);
 
 	d = adapter_to_dvobj(adapter);
 	err = rtw_halmac_get_logical_efuse_size(d, &size);
-	if (err)
-		return _FAIL;
+	if (err) {
+		status = _FAIL;
+		goto exit;
+	}
 
-	if ((addr + cnts) > size)
-		return _FAIL;
+	if ((addr + cnts) > size) {
+		status = _FAIL;
+		goto exit;
+	}
 
 	efuse = rtw_zmalloc(size);
-	if (!efuse)
-		return _FAIL;
+	if (!efuse) {
+		status = _FAIL;
+		goto exit;
+	}
 
 	err = rtw_halmac_read_logical_efuse_map(d, efuse, size, NULL, 0);
 	if (err) {
 		rtw_mfree(efuse, size);
-		return _FAIL;
+		status = _FAIL;
+		goto exit;
 	}
 
 	_rtw_memcpy(efuse + addr, data, cnts);
@@ -1030,12 +1168,16 @@ u8 rtw_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
 
 	if (err) {
 		rtw_mfree(efuse, size);
-		return _FAIL;
+		status = _FAIL;
+		goto exit;
 	}
 
 	rtw_mfree(efuse, size);
+	status = _SUCCESS;
+exit :
+	efuse_PostUpdateAction(adapter, backupRegs);
 
-	return _SUCCESS;
+	return status;
 }
 
 int Efuse_PgPacketRead(PADAPTER adapter, u8 offset, u8 *data, BOOLEAN test)
@@ -1525,61 +1667,23 @@ hal_EfusePgPacketWriteData(
 	return _TRUE;
 }
 
-
-#define EFUSE_CTRL				0x30		/* E-Fuse Control. */
-
-/*  11/16/2008 MH Read one byte from real Efuse. */
-u8
-efuse_OneByteRead(
-	IN	PADAPTER	pAdapter,
-	IN	u16			addr,
-	IN	u8			*data,
-	IN	BOOLEAN		bPseudoTest)
+u8 efuse_OneByteRead(struct _ADAPTER *a, u16 addr, u8 *data, u8 bPseudoTest)
 {
-	u32	tmpidx = 0;
-	u8	bResult;
-	u8	readbyte;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-
-	if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
-	    (IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
-	    (IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
-	   ) {
-		/* <20130121, Kordan> For SMIC EFUSE specificatoin. */
-		/* 0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8])	 */
-		/* phy_set_mac_reg(pAdapter, 0x34, BIT11, 0); */
-		rtw_write16(pAdapter, 0x34, rtw_read16(pAdapter, 0x34) & (~BIT11));
-	}
-
-	/* -----------------e-fuse reg ctrl --------------------------------- */
-	/* address			 */
-	rtw_write8(pAdapter, EFUSE_CTRL + 1, (u8)(addr & 0xff));
-	rtw_write8(pAdapter, EFUSE_CTRL + 2, ((u8)((addr >> 8) & 0x03)) |
-		   (rtw_read8(pAdapter, EFUSE_CTRL + 2) & 0xFC));
-
-	/* rtw_write8(pAdapter, EFUSE_CTRL+3,  0x72); */ /* read cmd	 */
-	/* Write bit 32 0 */
-	readbyte = rtw_read8(pAdapter, EFUSE_CTRL + 3);
-	rtw_write8(pAdapter, EFUSE_CTRL + 3, (readbyte & 0x7f));
+		struct dvobj_priv *d;
+		int err;
+		u8 ret = _TRUE;
 
-	while (!(0x80 & rtw_read8(pAdapter, EFUSE_CTRL + 3)) && (tmpidx < 1000)) {
-		rtw_mdelay_os(1);
-		tmpidx++;
-	}
-	if (tmpidx < 100) {
-		*data = rtw_read8(pAdapter, EFUSE_CTRL);
-		bResult = _TRUE;
-	} else {
-		*data = 0xff;
-		bResult = _FALSE;
-		RTW_INFO("%s: [ERROR] addr=0x%x bResult=%d time out 1s !!!\n", __FUNCTION__, addr, bResult);
-		RTW_INFO("%s: [ERROR] EFUSE_CTRL =0x%08x !!!\n", __FUNCTION__, rtw_read32(pAdapter, EFUSE_CTRL));
-	}
+		d = adapter_to_dvobj(a);
+		err = rtw_halmac_read_physical_efuse(d, addr, 1, data);
+		if (err) {
+			RTW_ERR("%s: addr=0x%x FAIL!!!\n", __FUNCTION__, addr);
+			ret = _FALSE;
+		}
 
-	return bResult;
+		return ret;
+	
 }
 
-
 static u16
 hal_EfuseGetCurrentSize_BT(
 	PADAPTER	padapter,
@@ -1719,47 +1823,6 @@ u8 EfusePgPacketWrite_BT(
 #define EFUSE_CTRL			REG_EFUSE_CTRL		/* E-Fuse Control. */
 /* ------------------------------------------------------------------------------ */
 
-VOID efuse_PreUpdateAction(
-	PADAPTER	pAdapter,
-	pu4Byte	BackupRegs)
-{
-#if defined(CONFIG_RTL8812A)
-	if (IS_HARDWARE_TYPE_8812AU(pAdapter)) {
-		/* <20131115, Kordan> Turn off Rx to prevent from being busy when writing the EFUSE. (Asked by Chunchu.)*/
-		BackupRegs[0] = phy_query_mac_reg(pAdapter, REG_RCR, bMaskDWord);
-		BackupRegs[1] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord);
-		BackupRegs[2] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord);
-		BackupRegs[3] = phy_query_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord);
-
-		PlatformEFIOWrite4Byte(pAdapter, REG_RCR, 0x1);
-		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0, 0);
-		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+1, 0);
-		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+2, 0);
-		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+3, 0);
-		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+4, 0);
-		PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+5, 0);
-
-		/* <20140410, Kordan> 0x11 = 0x4E, lower down LX_SPS0 voltage. (Asked by Chunchu)*/
-		phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskByte1, 0x4E);
-		}
-#endif
-}
-
-VOID efuse_PostUpdateAction(
-	PADAPTER	pAdapter,
-	pu4Byte	BackupRegs)
-{
-#if defined(CONFIG_RTL8812A)
-	if (IS_HARDWARE_TYPE_8812AU(pAdapter)) {
-		/* <20131115, Kordan> Turn on Rx and restore the registers. (Asked by Chunchu.)*/
-		phy_set_mac_reg(pAdapter, REG_RCR, bMaskDWord, BackupRegs[0]);
-		phy_set_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord, BackupRegs[1]);
-		phy_set_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord, BackupRegs[2]);
-		phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord, BackupRegs[3]);
-	}
-#endif
-}
-
 
 BOOLEAN
 Efuse_Read1ByteFromFakeContent(
@@ -2004,6 +2067,14 @@ efuse_OneByteRead(
 		return bResult;
 	}
 
+#ifdef CONFIG_RTL8710B
+	/* <20171208, Peter>, Dont do the following write16(0x34) */
+	if (IS_HARDWARE_TYPE_8710B(pAdapter)) {
+		bResult = pAdapter->hal_func.efuse_indirect_read4(pAdapter, addr, data);
+		return bResult;
+	}
+#endif
+
 	if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
 	    (IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
 	    (IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
@@ -2694,31 +2765,6 @@ EFUSE_ShadowWrite(
 
 }	/* EFUSE_ShadowWrite */
 
-VOID
-Efuse_InitSomeVar(
-	IN		PADAPTER	pAdapter
-);
-VOID
-Efuse_InitSomeVar(
-	IN		PADAPTER	pAdapter
-)
-{
-	u8 i;
-
-	_rtw_memset((PVOID)&fakeEfuseContent[0], 0xff, EFUSE_MAX_HW_SIZE);
-	_rtw_memset((PVOID)&fakeEfuseInitMap[0], 0xff, EFUSE_MAX_MAP_LEN);
-	_rtw_memset((PVOID)&fakeEfuseModifiedMap[0], 0xff, EFUSE_MAX_MAP_LEN);
-
-	for (i = 0; i < EFUSE_MAX_BT_BANK; i++)
-		_rtw_memset((PVOID)&BTEfuseContent[i][0], EFUSE_MAX_HW_SIZE, 0xff);
-	_rtw_memset((PVOID)&BTEfuseInitMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
-	_rtw_memset((PVOID)&BTEfuseModifiedMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
-
-	for (i = 0; i < EFUSE_MAX_BT_BANK; i++)
-		_rtw_memset((PVOID)&fakeBTEfuseContent[i][0], 0xff, EFUSE_MAX_HW_SIZE);
-	_rtw_memset((PVOID)&fakeBTEfuseInitMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
-	_rtw_memset((PVOID)&fakeBTEfuseModifiedMap[0], 0xff, EFUSE_BT_MAX_MAP_LEN);
-}
 #endif /* !RTW_HALMAC */
 /*-----------------------------------------------------------------------------
  * Function:	efuse_ShadowRead1Byte
@@ -3036,7 +3082,7 @@ u8 rtw_efuse_file_read(PADAPTER padapter, u8 *filepatch, u8 *buf, u32 len)
 		return _FALSE;
 
 	count = rtw_retrieve_from_file(filepatch, ptmpbuf, bufsize);
-	if (count <= 100) {
+	if (count <= 90) {
 		rtw_mfree(ptmpbuf, bufsize);
 		RTW_ERR("%s, filepatch %s, size=%d, FAIL!!\n", __FUNCTION__, filepatch, count);
 		return _FALSE;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh.c
new file mode 100644
index 000000000000..56bafd223e6e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh.c
@@ -0,0 +1,4102 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_C_
+
+#ifdef CONFIG_RTW_MESH
+#include <drv_types.h>
+
+const char *_rtw_mesh_plink_str[] = {
+	"UNKNOWN",
+	"LISTEN",
+	"OPN_SNT",
+	"OPN_RCVD",
+	"CNF_RCVD",
+	"ESTAB",
+	"HOLDING",
+	"BLOCKED",
+};
+
+const char *_rtw_mesh_ps_str[] = {
+	"UNKNOWN",
+	"ACTIVE",
+	"LSLEEP",
+	"DSLEEP",
+};
+
+const char *_action_self_protected_str[] = {
+	"ACT_SELF_PROTECTED_RSVD",
+	"MESH_OPEN",
+	"MESH_CONF",
+	"MESH_CLOSE",
+	"MESH_GK_INFORM",
+	"MESH_GK_ACK",
+};
+
+inline u8 *rtw_set_ie_mesh_id(u8 *buf, u32 *buf_len, const char *mesh_id, u8 id_len)
+{
+	return rtw_set_ie(buf, WLAN_EID_MESH_ID, id_len, mesh_id, buf_len);
+}
+
+inline u8 *rtw_set_ie_mesh_config(u8 *buf, u32 *buf_len
+	, u8 path_sel_proto, u8 path_sel_metric, u8 congest_ctl_mode, u8 sync_method, u8 auth_proto
+	, u8 num_of_peerings, bool cto_mgate, bool cto_as
+	, bool accept_peerings, bool mcca_sup, bool mcca_en, bool forwarding
+	, bool mbca_en, bool tbtt_adj, bool ps_level)
+{
+
+	u8 conf[7] = {0};
+
+	SET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(conf, path_sel_proto);
+	SET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(conf, path_sel_metric);
+	SET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(conf, congest_ctl_mode);
+	SET_MESH_CONF_ELE_SYNC_METHOD_ID(conf, sync_method);
+	SET_MESH_CONF_ELE_AUTH_PROTO_ID(conf, auth_proto);
+
+	SET_MESH_CONF_ELE_CTO_MGATE(conf, cto_mgate);
+	SET_MESH_CONF_ELE_NUM_OF_PEERINGS(conf, num_of_peerings);
+	SET_MESH_CONF_ELE_CTO_AS(conf, cto_as);
+
+	SET_MESH_CONF_ELE_ACCEPT_PEERINGS(conf, accept_peerings);
+	SET_MESH_CONF_ELE_MCCA_SUP(conf, mcca_sup);
+	SET_MESH_CONF_ELE_MCCA_EN(conf, mcca_en);
+	SET_MESH_CONF_ELE_FORWARDING(conf, forwarding);
+	SET_MESH_CONF_ELE_MBCA_EN(conf, mbca_en);
+	SET_MESH_CONF_ELE_TBTT_ADJ(conf, tbtt_adj);
+	SET_MESH_CONF_ELE_PS_LEVEL(conf, ps_level);
+
+	return rtw_set_ie(buf, WLAN_EID_MESH_CONFIG, 7, conf, buf_len);
+}
+
+inline u8 *rtw_set_ie_mpm(u8 *buf, u32 *buf_len
+	, u8 proto_id, u16 llid, u16 *plid, u16 *reason, u8 *chosen_pmk)
+{
+	u8 data[24] = {0};
+	u8 *pos = data;
+
+	RTW_PUT_LE16(pos, proto_id);
+	pos += 2;
+
+	RTW_PUT_LE16(pos, llid);
+	pos += 2;
+
+	if (plid) {
+		RTW_PUT_LE16(pos, *plid);
+		pos += 2;
+	}
+
+	if (reason) {
+		RTW_PUT_LE16(pos, *reason);
+		pos += 2;
+	}
+
+	if (chosen_pmk) {
+		_rtw_memcpy(pos, chosen_pmk, 16);
+		pos += 16;
+	}
+
+	return rtw_set_ie(buf, WLAN_EID_MPM, pos - data, data, buf_len);
+}
+
+bool rtw_bss_is_forwarding(WLAN_BSSID_EX *bss)
+{
+	u8 *ie;
+	int ie_len;
+	bool ret = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7)
+		goto exit;
+
+	ret = GET_MESH_CONF_ELE_FORWARDING(ie + 2);
+
+exit:
+	return ret;
+}
+
+bool rtw_bss_is_cto_mgate(WLAN_BSSID_EX *bss)
+{
+	u8 *ie;
+	int ie_len;
+	bool ret = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7)
+		goto exit;
+
+	ret = GET_MESH_CONF_ELE_CTO_MGATE(ie + 2);
+
+exit:
+	return ret;
+}
+
+int rtw_bss_is_same_mbss(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b)
+{
+	int ret = 0;
+	u8 *a_mconf_ie, *b_mconf_ie;
+	sint a_mconf_ie_len, b_mconf_ie_len;
+
+	if (a->InfrastructureMode != Ndis802_11_mesh)
+		goto exit;
+	a_mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(a), WLAN_EID_MESH_CONFIG, &a_mconf_ie_len, BSS_EX_TLV_IES_LEN(a));
+	if (!a_mconf_ie || a_mconf_ie_len != 7)
+		goto exit;
+	if (b->InfrastructureMode != Ndis802_11_mesh)
+		goto exit;
+	b_mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(b), WLAN_EID_MESH_CONFIG, &b_mconf_ie_len, BSS_EX_TLV_IES_LEN(b));
+	if (!b_mconf_ie || b_mconf_ie_len != 7)
+		goto exit;
+
+	if (a->mesh_id.SsidLength != b->mesh_id.SsidLength
+		|| _rtw_memcmp(a->mesh_id.Ssid, b->mesh_id.Ssid, a->mesh_id.SsidLength) == _FALSE)
+		goto exit;
+
+	if (_rtw_memcmp(a_mconf_ie + 2, b_mconf_ie + 2, 5) == _FALSE)
+		goto exit;
+
+	ret = 1;
+
+exit:
+	return ret;
+}
+
+int rtw_bss_is_candidate_mesh_peer(WLAN_BSSID_EX *self, WLAN_BSSID_EX *target, u8 ch, u8 add_peer)
+{
+	int ret = 0;
+	u8 *mconf_ie;
+	sint mconf_ie_len;
+	int i, j;
+
+	if (!rtw_bss_is_same_mbss(self, target))
+		goto exit;
+
+	if (ch && self->Configuration.DSConfig != target->Configuration.DSConfig)
+		goto exit;
+
+	if (add_peer) {
+		/* Accept additional mesh peerings */
+		mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(target), WLAN_EID_MESH_CONFIG, &mconf_ie_len, BSS_EX_TLV_IES_LEN(target));
+		if (!mconf_ie || mconf_ie_len != 7)
+			goto exit;
+		if (GET_MESH_CONF_ELE_ACCEPT_PEERINGS(mconf_ie + 2) == 0)
+			goto exit;
+	}
+
+	/* BSSBasicRateSet */
+	for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
+		if (target->SupportedRates[i] == 0)
+			break;	
+		if (target->SupportedRates[i] & 0x80) {
+			u8 match = 0;
+
+			if (!ch) {
+				/* off-channel, check target with our hardcode capability */
+				if (target->Configuration.DSConfig > 14)
+					match = rtw_is_basic_rate_ofdm(target->SupportedRates[i]);
+				else
+					match = rtw_is_basic_rate_mix(target->SupportedRates[i]);
+			} else { 
+				for (j = 0; j < NDIS_802_11_LENGTH_RATES_EX; j++) {
+					if (self->SupportedRates[j] == 0)
+						break;
+					if (self->SupportedRates[j] == target->SupportedRates[i]) {
+						match = 1;
+						break;
+					}
+				}
+			}
+			if (!match)
+				goto exit;
+		}
+	}
+
+
+	/* BSSBasicMCSSet */
+
+	/* 802.1X connected to AS ? */
+
+	ret = 1;
+
+exit:
+	return ret;
+}
+
+void rtw_mesh_bss_peering_status(WLAN_BSSID_EX *bss, u8 *nop, u8 *accept)
+{
+	u8 *ie;
+	int ie_len;
+
+	if (nop)
+		*nop = 0;
+	if (accept)
+		*accept = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7)
+		goto exit;
+
+	if (nop)
+		*nop = GET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2);
+	if (accept)
+		*accept = GET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2);
+
+exit:
+	return;
+}
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+void rtw_mesh_update_scanned_acnode_status(_adapter *adapter, struct wlan_network *scanned)
+{
+	bool acnode;
+	u8 nop, accept;
+
+	rtw_mesh_bss_peering_status(&scanned->network, &nop, &accept);
+
+	acnode = !nop && accept;
+
+	if (acnode && scanned->acnode_stime == 0) {
+		scanned->acnode_stime = rtw_get_current_time();
+		if (scanned->acnode_stime == 0)
+			scanned->acnode_stime++;
+	} else if (!acnode) {
+		scanned->acnode_stime = 0;
+		scanned->acnode_notify_etime = 0;
+	}
+}
+
+bool rtw_mesh_scanned_is_acnode_confirmed(_adapter *adapter, struct wlan_network *scanned)
+{
+	return scanned->acnode_stime
+			&& rtw_get_passing_time_ms(scanned->acnode_stime)
+				> adapter->mesh_cfg.peer_sel_policy.acnode_conf_timeout_ms;
+}
+
+static bool rtw_mesh_scanned_is_acnode_allow_notify(_adapter *adapter, struct wlan_network *scanned)
+{
+	return scanned->acnode_notify_etime
+			&& rtw_time_after(scanned->acnode_notify_etime, rtw_get_current_time());
+}
+
+bool rtw_mesh_acnode_prevent_allow_sacrifice(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	bool allow = 0;
+
+	if (!mcfg->peer_sel_policy.acnode_prevent
+		|| mcfg->max_peer_links <= 1
+		|| stapriv->asoc_list_cnt < mcfg->max_peer_links)
+		goto exit;
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	if (rtw_mesh_cto_mgate_required(adapter))
+		goto exit;
+#endif
+
+	allow = 1;
+
+exit:
+	return allow;
+}
+
+static bool rtw_mesh_acnode_candidate_exist(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	_queue *queue = &(mlme->scanned_queue);
+	_list *head, *list;
+	_irqL irqL;
+	struct wlan_network *scanned = NULL;
+	struct sta_info *sta = NULL;
+	bool need = 0;
+
+	_enter_critical_bh(&(mlme->scanned_queue.lock), &irqL);
+
+	head = get_list_head(queue);
+	list = get_next(head);
+	while (!rtw_end_of_queue_search(head, list)) {
+		scanned = LIST_CONTAINOR(list, struct wlan_network, list);
+		list = get_next(list);
+
+		if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
+			&& rtw_mesh_scanned_is_acnode_confirmed(adapter, scanned)
+			&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
+			#if CONFIG_RTW_MACADDR_ACL
+			&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
+			#endif
+			&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
+			#if CONFIG_RTW_MESH_PEER_BLACKLIST
+			&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
+			#endif
+			#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+			&& rtw_mesh_cto_mgate_network_filter(adapter, scanned)
+			#endif
+		) {
+			need = 1;
+			break;
+		}
+	}
+
+	_exit_critical_bh(&(mlme->scanned_queue.lock), &irqL);
+
+exit:
+	return need;
+}
+
+static int rtw_mesh_acnode_prevent_sacrifice_chk(_adapter *adapter, struct sta_info **sac, struct sta_info *com)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	int updated = 0;
+
+	/*
+	* TODO: compare next_hop reference cnt of forwarding info
+	* don't sacrifice working next_hop or choose sta with least cnt
+	*/
+
+	if (*sac == NULL) {
+		updated = 1;
+		goto exit;
+	}
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	if (mcfg->peer_sel_policy.cto_mgate_require
+		&& !mcfg->dot11MeshGateAnnouncementProtocol
+	) {
+		if (IS_CTO_MGATE_CONF_TIMEOUT(com->plink)) {
+			if (!IS_CTO_MGATE_CONF_TIMEOUT((*sac)->plink)) {
+				/* blacklist > not blacklist */
+				updated = 1;
+				goto exit;
+			}
+		} else if (!IS_CTO_MGATE_CONF_DISABLED(com->plink)) {
+			if (IS_CTO_MGATE_CONF_DISABLED((*sac)->plink)) {
+				/* confirming > disabled */
+				updated = 1;
+				goto exit;
+			}
+		}
+	}
+#endif
+
+exit:
+	if (updated)
+		*sac = com;
+
+	return updated;
+}
+
+struct sta_info *_rtw_mesh_acnode_prevent_pick_sacrifice(_adapter *adapter)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	_list *head, *list;
+	struct sta_info *sta, *sacrifice = NULL;
+	u8 nop;
+
+	head = &stapriv->asoc_list;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
+		list = get_next(list);
+
+		if (!sta->plink || !sta->plink->scanned) {
+			rtw_warn_on(1);
+			continue;
+		}
+
+		rtw_mesh_bss_peering_status(&sta->plink->scanned->network, &nop, NULL);
+		if (nop < 2)
+			continue;
+
+		rtw_mesh_acnode_prevent_sacrifice_chk(adapter, &sacrifice, sta);
+	}
+
+	return sacrifice;
+}
+
+struct sta_info *rtw_mesh_acnode_prevent_pick_sacrifice(_adapter *adapter)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sacrifice = NULL;
+
+	enter_critical_bh(&stapriv->asoc_list_lock);
+
+	sacrifice = _rtw_mesh_acnode_prevent_pick_sacrifice(adapter);
+
+	exit_critical_bh(&stapriv->asoc_list_lock);
+
+	return sacrifice;
+}
+
+static void rtw_mesh_acnode_rsvd_chk(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	u8 acnode_rsvd = 0;
+
+	if (rtw_mesh_acnode_prevent_allow_sacrifice(adapter)
+		&& rtw_mesh_acnode_prevent_pick_sacrifice(adapter)
+		&& rtw_mesh_acnode_candidate_exist(adapter))
+		acnode_rsvd = 1;
+
+	if (plink_ctl->acnode_rsvd != acnode_rsvd) {
+		plink_ctl->acnode_rsvd = acnode_rsvd;
+		RTW_INFO(FUNC_ADPT_FMT" acnode_rsvd = %d\n", FUNC_ADPT_ARG(adapter), plink_ctl->acnode_rsvd);
+		update_beacon(adapter, WLAN_EID_MESH_CONFIG, NULL, 1);
+	}
+}
+
+static void rtw_mesh_acnode_set_notify_etime(_adapter *adapter, u8 *rframe_whdr)
+{
+	if (adapter->mesh_info.plink_ctl.acnode_rsvd) {
+		struct wlan_network *scanned = rtw_find_network(&adapter->mlmepriv.scanned_queue, get_addr2_ptr(rframe_whdr));
+
+		if (rtw_mesh_scanned_is_acnode_confirmed(adapter, scanned)) {
+			scanned->acnode_notify_etime = rtw_get_current_time()
+				+ rtw_ms_to_systime(adapter->mesh_cfg.peer_sel_policy.acnode_notify_timeout_ms);
+			if (scanned->acnode_notify_etime == 0)
+				scanned->acnode_notify_etime++;
+		}
+	}
+}
+
+void dump_mesh_acnode_prevent_settings(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+	RTW_PRINT_SEL(sel, "%-6s %-12s %-14s\n"
+		, "enable", "conf_timeout", "nofity_timeout");
+	RTW_PRINT_SEL(sel, "%6u %12u %14u\n"
+		, peer_sel_policy->acnode_prevent
+		, peer_sel_policy->acnode_conf_timeout_ms
+		, peer_sel_policy->acnode_notify_timeout_ms);
+}
+#endif /* CONFIG_RTW_MESH_ACNODE_PREVENT */
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_peer_blacklist_add(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_add(&plink_ctl->peer_blacklist, addr
+		, mcfg->peer_sel_policy.peer_blacklist_timeout_ms);
+}
+
+int rtw_mesh_peer_blacklist_del(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_del(&plink_ctl->peer_blacklist, addr);
+}
+
+int rtw_mesh_peer_blacklist_search(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_search(&plink_ctl->peer_blacklist, addr);
+}
+
+void rtw_mesh_peer_blacklist_flush(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	rtw_blacklist_flush(&plink_ctl->peer_blacklist);
+}
+
+void dump_mesh_peer_blacklist(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	dump_blacklist(sel, &plink_ctl->peer_blacklist, "blacklist");
+}
+
+void dump_mesh_peer_blacklist_settings(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+	RTW_PRINT_SEL(sel, "%-12s %-17s\n"
+		, "conf_timeout", "blacklist_timeout");
+	RTW_PRINT_SEL(sel, "%12u %17u\n"
+		, peer_sel_policy->peer_conf_timeout_ms
+		, peer_sel_policy->peer_blacklist_timeout_ms);
+}
+#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+u8 rtw_mesh_cto_mgate_required(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	return mcfg->peer_sel_policy.cto_mgate_require
+		&& !rtw_bss_is_cto_mgate(&(mlmeext->mlmext_info.network));
+}
+
+u8 rtw_mesh_cto_mgate_network_filter(_adapter *adapter, struct wlan_network *scanned)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	return !rtw_mesh_cto_mgate_required(adapter)
+			|| (rtw_bss_is_cto_mgate(&scanned->network)
+				&& !rtw_mesh_cto_mgate_blacklist_search(adapter, scanned->network.MacAddress));
+}
+
+int rtw_mesh_cto_mgate_blacklist_add(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_add(&plink_ctl->cto_mgate_blacklist, addr
+		, mcfg->peer_sel_policy.cto_mgate_blacklist_timeout_ms);
+}
+
+int rtw_mesh_cto_mgate_blacklist_del(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_del(&plink_ctl->cto_mgate_blacklist, addr);
+}
+
+int rtw_mesh_cto_mgate_blacklist_search(_adapter *adapter, const u8 *addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	return rtw_blacklist_search(&plink_ctl->cto_mgate_blacklist, addr);
+}
+
+void rtw_mesh_cto_mgate_blacklist_flush(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	rtw_blacklist_flush(&plink_ctl->cto_mgate_blacklist);
+}
+
+void dump_mesh_cto_mgate_blacklist(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	dump_blacklist(sel, &plink_ctl->cto_mgate_blacklist, "blacklist");
+}
+
+void dump_mesh_cto_mgate_blacklist_settings(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+	RTW_PRINT_SEL(sel, "%-12s %-17s\n"
+		, "conf_timeout", "blacklist_timeout");
+	RTW_PRINT_SEL(sel, "%12u %17u\n"
+		, peer_sel_policy->cto_mgate_conf_timeout_ms
+		, peer_sel_policy->cto_mgate_blacklist_timeout_ms);
+}
+
+static void rtw_mesh_cto_mgate_blacklist_chk(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	_queue *blist = &plink_ctl->cto_mgate_blacklist;
+	_list *list, *head;
+	struct blacklist_ent *ent = NULL;
+	struct wlan_network *scanned = NULL;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+			continue;
+		}
+
+		scanned = rtw_find_network(&adapter->mlmepriv.scanned_queue, ent->addr);
+		if (!scanned)
+			continue;
+
+		if (rtw_bss_is_forwarding(&scanned->network)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+}
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+void rtw_chk_candidate_peer_notify(_adapter *adapter, struct wlan_network *scanned)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	bool acnode = 0;
+
+	if (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl))
+		goto exit;
+
+	if (plink_ctl->num >= RTW_MESH_MAX_PEER_CANDIDATES)
+		goto exit;
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	if (plink_ctl->acnode_rsvd) {
+		acnode = rtw_mesh_scanned_is_acnode_confirmed(adapter, scanned);
+		if (acnode && !rtw_mesh_scanned_is_acnode_allow_notify(adapter, scanned))
+			goto exit;
+	}
+#endif
+
+	/* wpa_supplicant's auto peer will initiate peering when candidate peer is reported without max_peer_links consideration */
+	if (plink_ctl->num >= mcfg->max_peer_links + acnode ? 1 : 0)
+		goto exit;
+
+	if (rtw_get_passing_time_ms(scanned->last_scanned) >= mcfg->peer_sel_policy.scanr_exp_ms
+		|| (mcfg->rssi_threshold && mcfg->rssi_threshold > scanned->network.Rssi)
+		|| !rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
+		#if CONFIG_RTW_MACADDR_ACL
+		|| rtw_access_ctrl(adapter, scanned->network.MacAddress) == _FALSE
+		#endif
+		|| rtw_mesh_plink_get(adapter, scanned->network.MacAddress)
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		|| rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
+		#endif
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		|| !rtw_mesh_cto_mgate_network_filter(adapter, scanned)
+		#endif
+	)
+		goto exit;
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	if (acnode) {
+		scanned->acnode_notify_etime = 0;
+		RTW_INFO(FUNC_ADPT_FMT" acnode "MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(scanned->network.MacAddress));
+	}
+#endif
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_notify_new_peer_candidate(adapter->rtw_wdev
+		, scanned->network.MacAddress
+		, BSS_EX_TLV_IES(&scanned->network)
+		, BSS_EX_TLV_IES_LEN(&scanned->network)
+		, GFP_ATOMIC
+	);
+#endif
+
+exit:
+	return;
+}
+
+void rtw_mesh_peer_status_chk(_adapter *adapter)
+{
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *plink;
+	_list *head, *list;
+	struct sta_info *sta = NULL;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	int stainfo_offset;
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	u8 cto_mgate, forwarding, mgate;
+#endif
+	u8 flush;
+	s8 flush_list[NUM_STA];
+	u8 flush_num = 0;
+	int i;
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	if (rtw_mesh_cto_mgate_required(adapter)) {
+		/* active scan on operating channel */
+		issue_probereq_ex(adapter, &adapter->mlmepriv.cur_network.network.mesh_id, NULL, 0, 0, 0, 0);
+	}
+#endif
+
+	enter_critical_bh(&(plink_ctl->lock));
+
+	/* check established peers */
+	enter_critical_bh(&stapriv->asoc_list_lock);
+
+	head = &stapriv->asoc_list;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
+		list = get_next(list);
+
+		if (!sta->plink || !sta->plink->scanned) {
+			rtw_warn_on(1);
+			continue;
+		}
+		plink = sta->plink;
+		flush = 0;
+
+		/* remove unsuitable peer */
+		if (!rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &plink->scanned->network, 1, 0)
+			#if CONFIG_RTW_MACADDR_ACL
+			|| rtw_access_ctrl(adapter, plink->addr) == _FALSE
+			#endif
+		) {
+			flush = 1;
+			goto flush_add;
+		}
+
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		cto_mgate = rtw_bss_is_cto_mgate(&(plink->scanned->network));
+		forwarding = rtw_bss_is_forwarding(&(plink->scanned->network));
+		mgate = rtw_mesh_gate_search(minfo->mesh_paths, sta->cmn.mac_addr);
+
+		/* CTO_MGATE required, remove peer without CTO_MGATE */
+		if (rtw_mesh_cto_mgate_required(adapter) && !cto_mgate) {
+			flush = 1;
+			goto flush_add;
+		}
+
+		/* cto_mgate_conf status update */
+		if (IS_CTO_MGATE_CONF_DISABLED(plink)) {
+			if (cto_mgate && !forwarding && !mgate)
+				SET_CTO_MGATE_CONF_END_TIME(plink, mcfg->peer_sel_policy.cto_mgate_conf_timeout_ms);
+			else
+				rtw_mesh_cto_mgate_blacklist_del(adapter, sta->cmn.mac_addr);
+		} else {
+			/* cto_mgate_conf ongoing */
+			if (cto_mgate && !forwarding && !mgate) {
+				if (IS_CTO_MGATE_CONF_TIMEOUT(plink)) {
+					rtw_mesh_cto_mgate_blacklist_add(adapter, sta->cmn.mac_addr);
+
+					/* CTO_MGATE required, remove peering can't achieve CTO_MGATE */
+					if (rtw_mesh_cto_mgate_required(adapter)) {
+						flush = 1;
+						goto flush_add;
+					}	
+				}
+			} else {
+				SET_CTO_MGATE_CONF_DISABLED(plink);
+				rtw_mesh_cto_mgate_blacklist_del(adapter, sta->cmn.mac_addr);
+			}
+		}
+		#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+flush_add:
+		if (flush) {
+			rtw_list_delete(&sta->asoc_list);
+			stapriv->asoc_list_cnt--;
+			STA_SET_MESH_PLINK(sta, NULL);
+
+			stainfo_offset = rtw_stainfo_offset(stapriv, sta);
+			if (stainfo_offset_valid(stainfo_offset))
+				flush_list[flush_num++] = stainfo_offset;
+			else
+				rtw_warn_on(1);
+		}
+	}
+
+	exit_critical_bh(&stapriv->asoc_list_lock);
+
+	/* check non-established peers */
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		plink = &plink_ctl->ent[i];
+		if (plink->valid != _TRUE || plink->plink_state == RTW_MESH_PLINK_ESTAB)
+			continue;
+
+		/* remove unsuitable peer */
+		if (!rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &plink->scanned->network, 1, 1)
+			#if CONFIG_RTW_MACADDR_ACL
+			|| rtw_access_ctrl(adapter, plink->addr) == _FALSE
+			#endif
+		) {
+			_rtw_mesh_expire_peer_ent(adapter, plink);
+			continue;
+		}
+
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		/* peer confirm check timeout, add to black list */
+		if (IS_PEER_CONF_TIMEOUT(plink)) {
+			rtw_mesh_peer_blacklist_add(adapter, plink->addr);
+			_rtw_mesh_expire_peer_ent(adapter, plink);
+		}
+		#endif
+	}
+
+	exit_critical_bh(&(plink_ctl->lock));
+
+	if (flush_num) {
+		u8 sta_addr[ETH_ALEN];
+		u8 updated = _FALSE;
+
+		for (i = 0; i < flush_num; i++) {
+			sta = rtw_get_stainfo_by_offset(stapriv, flush_list[i]);
+			_rtw_memcpy(sta_addr, sta->cmn.mac_addr, ETH_ALEN);
+
+			updated |= ap_free_sta(adapter, sta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _FALSE);
+			rtw_mesh_expire_peer(adapter, sta_addr);
+		}
+
+		associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
+	}
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	/* loop cto_mgate_blacklist to remove ent according to scan_r */
+	rtw_mesh_cto_mgate_blacklist_chk(adapter);
+#endif
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	rtw_mesh_acnode_rsvd_chk(adapter);
+#endif
+
+	return;
+}
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+static u8 rtw_mesh_offch_cto_mgate_required(_adapter *adapter)
+{
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	_queue *queue = &(mlme->scanned_queue);
+	_list *head, *pos;
+	struct wlan_network *scanned = NULL;
+	u8 ret = 0;
+
+	if (!rtw_mesh_cto_mgate_required(adapter))
+		goto exit;
+
+	enter_critical_bh(&(mlme->scanned_queue.lock));
+
+	head = get_list_head(queue);
+	pos = get_next(head);
+	while (!rtw_end_of_queue_search(head, pos)) {
+		scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
+
+		if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
+			&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
+			#if CONFIG_RTW_MACADDR_ACL
+			&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
+			#endif
+			&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
+			&& rtw_bss_is_cto_mgate(&scanned->network)
+			#if CONFIG_RTW_MESH_PEER_BLACKLIST
+			&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
+			#endif
+			&& !rtw_mesh_cto_mgate_blacklist_search(adapter, scanned->network.MacAddress)
+		)
+			break;
+
+		pos = get_next(pos);
+	}
+
+	if (rtw_end_of_queue_search(head, pos))
+		ret = 1;
+
+	exit_critical_bh(&(mlme->scanned_queue.lock));
+
+exit:
+	return ret;
+#else
+	return 0;
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+}
+
+u8 rtw_mesh_offch_candidate_accepted(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	u8 ret = 0;
+
+	if (!adapter->mesh_cfg.peer_sel_policy.offch_cand)
+		goto exit;
+
+	ret = MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)
+		&& (!plink_ctl->num || rtw_mesh_offch_cto_mgate_required(adapter))
+		;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (ret) {
+		struct mi_state mstate_no_self;
+
+		rtw_mi_status_no_self(adapter, &mstate_no_self);
+		if (MSTATE_STA_LD_NUM(&mstate_no_self))
+			ret = 0;
+	}
+#endif
+
+exit:
+	return ret;
+}
+
+/*
+ * this function is called under off channel candidate is required 
+ * the channel with maximum candidate count is selected
+*/
+u8 rtw_mesh_select_operating_ch(_adapter *adapter)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	_queue *queue = &(mlme->scanned_queue);
+	_list *head, *pos;
+	_irqL irqL;
+	struct wlan_network *scanned = NULL;
+	int i;
+	/* statistics for candidate accept peering */
+	u8 cand_ap_cnt[MAX_CHANNEL_NUM] = {0};
+	u8 max_cand_ap_ch = 0;
+	u8 max_cand_ap_cnt = 0;
+	/* statistics for candidate including not accept peering */
+	u8 cand_cnt[MAX_CHANNEL_NUM] = {0};
+	u8 max_cand_ch = 0;
+	u8 max_cand_cnt = 0;
+
+	_enter_critical_bh(&(mlme->scanned_queue.lock), &irqL);
+
+	head = get_list_head(queue);
+	pos = get_next(head);
+	while (!rtw_end_of_queue_search(head, pos)) {
+		scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
+		pos = get_next(pos);
+
+		if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
+			&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
+			#if CONFIG_RTW_MACADDR_ACL
+			&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
+			#endif
+			&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 0, 0)
+			#if CONFIG_RTW_MESH_PEER_BLACKLIST
+			&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
+			#endif
+			#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+			&& rtw_mesh_cto_mgate_network_filter(adapter, scanned)
+			#endif
+		) {
+			int ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, scanned->network.Configuration.DSConfig);
+
+			if (ch_set_idx >= 0
+				&& !CH_IS_NON_OCP(&rfctl->channel_set[ch_set_idx])
+			) {
+				u8 nop, accept;
+
+				rtw_mesh_bss_peering_status(&scanned->network, &nop, &accept);
+				cand_cnt[ch_set_idx]++;
+				if (max_cand_cnt < cand_cnt[ch_set_idx]) {
+					max_cand_cnt = cand_cnt[ch_set_idx];
+					max_cand_ch = rfctl->channel_set[ch_set_idx].ChannelNum;
+				}
+				if (accept) {
+					cand_ap_cnt[ch_set_idx]++;
+					if (max_cand_ap_cnt < cand_ap_cnt[ch_set_idx]) {
+						max_cand_ap_cnt = cand_ap_cnt[ch_set_idx];
+						max_cand_ap_ch = rfctl->channel_set[ch_set_idx].ChannelNum;
+					}
+				}
+			}
+		}
+	}
+
+	_exit_critical_bh(&(mlme->scanned_queue.lock), &irqL);
+
+	return max_cand_ap_ch ? max_cand_ap_ch : max_cand_ch;
+}
+
+void dump_mesh_offch_cand_settings(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+	RTW_PRINT_SEL(sel, "%-6s %-11s\n"
+		, "enable", "find_int_ms");
+	RTW_PRINT_SEL(sel, "%6u %11u\n"
+		, peer_sel_policy->offch_cand, peer_sel_policy->offch_find_int_ms);
+}
+#endif /* CONFIG_RTW_MESH_OFFCH_CAND */
+
+void dump_mesh_peer_sel_policy(void *sel, _adapter *adapter)
+{
+	struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+
+	RTW_PRINT_SEL(sel, "%-12s\n", "scanr_exp_ms");
+	RTW_PRINT_SEL(sel, "%12u\n", peer_sel_policy->scanr_exp_ms);
+}
+
+void dump_mesh_networks(void *sel, _adapter *adapter)
+{
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+#define NSTATE_TITLE_FMT_ACN " %-5s"
+#define NSTATE_VALUE_FMT_ACN " %5d"
+#define NSTATE_TITLE_ARG_ACN , "acn"
+#define NSTATE_VALUE_ARG_ACN , (acn_ms < 99999 ? acn_ms : 99999)
+#else
+#define NSTATE_TITLE_FMT_ACN ""
+#define NSTATE_VALUE_FMT_ACN ""
+#define NSTATE_TITLE_ARG_ACN
+#define NSTATE_VALUE_ARG_ACN
+#endif
+
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	_queue *queue = &(mlme->scanned_queue);
+	struct wlan_network	*network;
+	_list *list, *head;
+	u8 same_mbss;
+	u8 candidate;
+	struct mesh_plink_ent *plink;
+	u8 blocked;
+	u8 established;
+	s32 age_ms;
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	s32 acn_ms;
+#endif
+	u8 *mesh_conf_ie;
+	sint mesh_conf_ie_len;
+	struct wlan_network **mesh_networks;
+	u8 mesh_network_cnt = 0;
+	int i;
+
+	mesh_networks = rtw_zvmalloc(mlme->max_bss_cnt * sizeof(struct wlan_network *));
+	if (!mesh_networks)
+		return;
+
+	enter_critical_bh(&queue->lock);
+	head = get_list_head(queue);
+	list = get_next(head);
+
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		network = LIST_CONTAINOR(list, struct wlan_network, list);
+		list = get_next(list);
+
+		if (network->network.InfrastructureMode != Ndis802_11_mesh)
+			continue;
+
+		mesh_conf_ie = rtw_get_ie(BSS_EX_TLV_IES(&network->network), WLAN_EID_MESH_CONFIG
+			, &mesh_conf_ie_len, BSS_EX_TLV_IES_LEN(&network->network));
+		if (!mesh_conf_ie || mesh_conf_ie_len != 7)
+			continue;
+
+		mesh_networks[mesh_network_cnt++] = network;
+	}
+
+	exit_critical_bh(&queue->lock);
+
+	RTW_PRINT_SEL(sel, "  %-17s %-3s %-4s %-5s %-32s %-3s %-3s %-3s"
+		NSTATE_TITLE_FMT_ACN
+		"\n"
+		, "bssid", "ch", "rssi", "age", "mesh_id", "nop", "fwd", "cto"
+		NSTATE_TITLE_ARG_ACN
+	);
+
+	for (i = 0; i < mesh_network_cnt; i++) {
+		network = mesh_networks[i];
+
+		if (network->network.InfrastructureMode != Ndis802_11_mesh)
+			continue;
+
+		mesh_conf_ie = rtw_get_ie(BSS_EX_TLV_IES(&network->network), WLAN_EID_MESH_CONFIG
+			, &mesh_conf_ie_len, BSS_EX_TLV_IES_LEN(&network->network));
+		if (!mesh_conf_ie || mesh_conf_ie_len != 7)
+			continue;
+
+		age_ms = rtw_get_passing_time_ms(network->last_scanned);
+		#if CONFIG_RTW_MESH_ACNODE_PREVENT
+		if (network->acnode_stime == 0)
+			acn_ms = 0;
+		else
+			acn_ms = rtw_get_passing_time_ms(network->acnode_stime);
+		#endif
+		same_mbss = 0;
+		candidate = 0;
+		plink = NULL;
+		blocked = 0;
+		established = 0;
+
+		if (MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)) {
+			plink = rtw_mesh_plink_get(adapter, network->network.MacAddress);
+			if (plink && plink->plink_state == RTW_MESH_PLINK_ESTAB)
+				established = 1;
+			else if (plink && plink->plink_state == RTW_MESH_PLINK_BLOCKED)
+				blocked = 1;
+			else if (plink)
+				;
+			else if (rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &network->network, 0, 1))
+				candidate = 1;
+			else if (rtw_bss_is_same_mbss(&mlme->cur_network.network, &network->network))
+				same_mbss = 1;
+		}
+
+		RTW_PRINT_SEL(sel, "%c "MAC_FMT" %3d %4ld %5d %-32s %c%2u %3u %c%c "
+			NSTATE_VALUE_FMT_ACN
+			"\n"
+			, established ? 'E' : (blocked ? 'B' : (plink ? 'N' : (candidate ? 'C' : (same_mbss ? 'S' : ' '))))
+			, MAC_ARG(network->network.MacAddress)
+			, network->network.Configuration.DSConfig
+			, network->network.Rssi
+			, age_ms < 99999 ? age_ms : 99999
+			, network->network.mesh_id.Ssid
+			, GET_MESH_CONF_ELE_ACCEPT_PEERINGS(mesh_conf_ie + 2) ? '+' : ' '
+			, GET_MESH_CONF_ELE_NUM_OF_PEERINGS(mesh_conf_ie + 2)
+			, GET_MESH_CONF_ELE_FORWARDING(mesh_conf_ie + 2)
+			, GET_MESH_CONF_ELE_CTO_MGATE(mesh_conf_ie + 2) ? 'G' : ' '
+			, GET_MESH_CONF_ELE_CTO_AS(mesh_conf_ie + 2) ? 'A' : ' '
+			NSTATE_VALUE_ARG_ACN
+		);
+	}
+
+	rtw_vmfree(mesh_networks, mlme->max_bss_cnt * sizeof(struct wlan_network *));
+}
+
+void rtw_mesh_adjust_chbw(u8 req_ch, u8 *req_bw, u8 *req_offset)
+{
+	if (req_ch >= 5 && req_ch <= 9) {
+		/* prevent secondary channel offset mismatch */
+		if (*req_bw > CHANNEL_WIDTH_20) {
+			*req_bw = CHANNEL_WIDTH_20;
+			*req_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+		}
+	}
+}
+
+int rtw_sae_check_frames(_adapter *adapter, const u8 *buf, u32 len, u8 tx)
+{
+	const u8 *frame_body = buf + sizeof(struct rtw_ieee80211_hdr_3addr);
+	u16 alg;
+	u16 seq;
+	u16 status;
+	int ret = 0;
+
+	alg = RTW_GET_LE16(frame_body);
+	if (alg != 3)
+		goto exit;
+
+	seq = RTW_GET_LE16(frame_body + 2);
+	status = RTW_GET_LE16(frame_body + 4);
+
+	RTW_INFO("RTW_%s:AUTH alg:0x%04x, seq:0x%04x, status:0x%04x\n"
+		, (tx == _TRUE) ? "Tx" : "Rx", alg, seq, status);
+
+	ret = 1;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	if (tx && seq == 1)
+		rtw_mesh_plink_set_peer_conf_timeout(adapter, GetAddr1Ptr(buf));
+#endif
+
+exit:
+	return ret;
+}
+
+#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+#ifdef CONFIG_RTW_MESH_AEK
+static int rtw_mpm_ampe_dec(_adapter *adapter, struct mesh_plink_ent *plink
+	, u8 *fhead, size_t flen, u8* fbody, u8 *mic_ie, u8 *ampe_buf)
+{	
+	int ret = _FAIL, verify_ret;
+	const u8 *aad[] = {adapter_mac_addr(adapter), plink->addr, fbody};
+	const size_t aad_len[] = {ETH_ALEN, ETH_ALEN, mic_ie - fbody};
+	u8 *iv_crypt;
+	size_t iv_crypt_len = flen - (mic_ie + 2 - fhead);
+
+	iv_crypt = rtw_malloc(iv_crypt_len);
+	if (!iv_crypt)
+		goto exit;
+
+	_rtw_memcpy(iv_crypt, mic_ie + 2, iv_crypt_len);
+
+	verify_ret = aes_siv_decrypt(plink->aek, iv_crypt, iv_crypt_len
+		, 3, aad, aad_len, ampe_buf);
+
+	rtw_mfree(iv_crypt, iv_crypt_len);
+
+	if (verify_ret) {
+		RTW_WARN("verify error, aek_valid=%u\n", plink->aek_valid);
+		goto exit;
+	} else if (*ampe_buf != WLAN_EID_AMPE) {
+		RTW_WARN("plaintext is not AMPE IE\n");
+		goto exit;
+	} else if (AES_BLOCK_SIZE + 2 + *(ampe_buf + 1) > iv_crypt_len) {
+		RTW_WARN("plaintext AMPE IE length is not valid\n");
+		goto exit;
+	}
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+static int rtw_mpm_ampe_enc(_adapter *adapter, struct mesh_plink_ent *plink
+	, u8* fbody, u8 *mic_ie, u8 *ampe_buf, bool inverse)
+{
+	int ret = _FAIL, protect_ret;
+	const u8 *aad[3];
+	const size_t aad_len[3] = {ETH_ALEN, ETH_ALEN, mic_ie - fbody};
+	u8 *ampe_ie;
+	size_t ampe_ie_len = *(ampe_buf + 1) + 2; /* including id & len */
+
+	if (inverse) {
+		aad[0] = plink->addr;
+		aad[1] = adapter_mac_addr(adapter);
+	} else {
+		aad[0] = adapter_mac_addr(adapter);
+		aad[1] = plink->addr;
+	}
+	aad[2] = fbody;
+
+	ampe_ie = rtw_malloc(ampe_ie_len);
+	if (!ampe_ie)
+		goto exit;
+
+	_rtw_memcpy(ampe_ie, ampe_buf, ampe_ie_len);
+
+	protect_ret = aes_siv_encrypt(plink->aek, ampe_ie, ampe_ie_len
+		, 3, aad, aad_len, mic_ie + 2);
+
+	rtw_mfree(ampe_ie, ampe_ie_len);
+
+	if (protect_ret) {
+		RTW_WARN("protect error, aek_valid=%u\n", plink->aek_valid);
+		goto exit;
+	}
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+#endif /* CONFIG_RTW_MESH_AEK */
+
+static int rtw_mpm_tx_ies_sync_bss(_adapter *adapter, struct mesh_plink_ent *plink
+	, u8 *fhead, size_t flen, u8* fbody, u8 tlv_ies_offset, u8 *mpm_ie, u8 *mic_ie
+	, u8 **nbuf, size_t *nlen)
+{
+	int ret = _FAIL;
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
+	WLAN_BSSID_EX *network = &(mlmeinfo->network);
+	uint left;
+	u8 *pos;
+
+	uint mpm_ielen = *(mpm_ie + 1);
+	u8 *fpos;
+	u8 *new_buf = NULL;
+	size_t new_len = 0;
+
+	u8 *new_fhead;
+	size_t new_flen;
+	u8 *new_fbody;
+	u8 *new_mic_ie;
+
+#ifdef CONFIG_RTW_MESH_AEK
+	u8 *ampe_buf = NULL;
+	size_t ampe_buf_len = 0;
+
+	/* decode */
+	if (mic_ie) {
+		ampe_buf_len = flen - (mic_ie + 2 + AES_BLOCK_SIZE - fhead);
+		ampe_buf = rtw_malloc(ampe_buf_len);
+		if (!ampe_buf)
+			goto exit;
+
+		if (rtw_mpm_ampe_dec(adapter, plink, fhead, flen, fbody, mic_ie, ampe_buf) != _SUCCESS)
+			goto exit;
+
+		if (*(ampe_buf + 1) >= 68) {
+			_rtw_memcpy(plink->sel_pcs, ampe_buf + 2, 4);
+			_rtw_memcpy(plink->l_nonce, ampe_buf + 6, 32);
+			_rtw_memcpy(plink->p_nonce, ampe_buf + 38, 32);
+		}
+	}
+#endif
+
+	/* count for new frame length  */
+	new_len = sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset;
+	left = BSS_EX_TLV_IES_LEN(network);
+	pos = BSS_EX_TLV_IES(network);
+	while (left >= 2) {
+		u8 id, elen;
+	
+		id = *pos++;
+		elen = *pos++;
+		left -= 2;
+
+		if (elen > left)
+			break;
+
+		switch (id) {
+		case WLAN_EID_SSID:
+		case WLAN_EID_DS_PARAMS:
+		case WLAN_EID_TIM:
+			break;
+		default:
+			new_len += 2 + elen;
+		}
+
+		left -= elen;
+		pos += elen;
+	}
+	new_len += mpm_ielen + 2;
+	if (mic_ie)
+		new_len += AES_BLOCK_SIZE + 2 + ampe_buf_len;
+
+	/* alloc new frame */
+	new_buf = rtw_malloc(new_len);
+	if (!new_buf) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	/* build new frame  */
+	_rtw_memcpy(new_buf, fhead, sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset);
+	new_fhead = new_buf;
+	new_flen = new_len;
+	new_fbody = new_fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	fpos = new_fbody + tlv_ies_offset;
+	left = BSS_EX_TLV_IES_LEN(network);
+	pos = BSS_EX_TLV_IES(network);
+	while (left >= 2) {
+		u8 id, elen;
+	
+		id = *pos++;
+		elen = *pos++;
+		left -= 2;
+
+		if (elen > left)
+			break;
+
+		switch (id) {
+		case WLAN_EID_SSID:
+		case WLAN_EID_DS_PARAMS:
+		case WLAN_EID_TIM:
+			break;
+		default:
+			fpos = rtw_set_ie(fpos, id, elen, pos, NULL);
+			if (id == WLAN_EID_MESH_CONFIG)
+				fpos = rtw_set_ie(fpos, WLAN_EID_MPM, mpm_ielen, mpm_ie + 2, NULL);
+		}
+
+		left -= elen;
+		pos += elen;
+	}
+	if (mic_ie) {
+		new_mic_ie = fpos;
+		*fpos++ = WLAN_EID_MIC;
+		*fpos++ = AES_BLOCK_SIZE;
+	}
+
+#ifdef CONFIG_RTW_MESH_AEK
+	/* encode */
+	if (mic_ie) {
+		int enc_ret = rtw_mpm_ampe_enc(adapter, plink, new_fbody, new_mic_ie, ampe_buf, 0);
+		if (enc_ret != _SUCCESS)
+			goto exit;
+	}
+#endif
+
+	*nlen = new_len;
+	*nbuf = new_buf;
+
+	ret = _SUCCESS;
+
+exit:
+	if (ret != _SUCCESS && new_buf)
+		rtw_mfree(new_buf, new_len);
+
+#ifdef CONFIG_RTW_MESH_AEK
+	if (ampe_buf)
+		rtw_mfree(ampe_buf, ampe_buf_len);
+#endif
+
+	return ret;
+}
+#endif /* CONFIG_RTW_MPM_TX_IES_SYNC_BSS */
+
+struct mpm_frame_info {
+	u8 *aid;
+	u16 aid_v;
+	u8 *pid;
+	u16 pid_v;
+	u8 *llid;
+	u16 llid_v;
+	u8 *plid;
+	u16 plid_v;
+	u8 *reason;
+	u16 reason_v;
+	u8 *chosen_pmk;
+};
+
+/*
+* pid:00000 llid:00000 chosen_pmk:0x00000000000000000000000000000000
+* aid:00000 pid:00000 llid:00000 plid:00000 chosen_pmk:0x00000000000000000000000000000000
+* pid:00000 llid:00000 plid:00000 reason:00000 chosen_pmk:0x00000000000000000000000000000000
+*/
+#define MPM_LOG_BUF_LEN 92 /* this length is limited for legal combination */
+static void rtw_mpm_info_msg(struct mpm_frame_info *mpm_info, u8 *mpm_log_buf)
+{
+	int cnt = 0;
+
+	if (mpm_info->aid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "aid:%u ", mpm_info->aid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->pid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "pid:%u ", mpm_info->pid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->llid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "llid:%u ", mpm_info->llid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->plid) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "plid:%u ", mpm_info->plid_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->reason) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "reason:%u ", mpm_info->reason_v);
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+	if (mpm_info->chosen_pmk) {
+		cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "chosen_pmk:0x"KEY_FMT, KEY_ARG(mpm_info->chosen_pmk));
+		if (cnt >= MPM_LOG_BUF_LEN - 1)
+			goto exit;
+	}
+
+exit:
+	return;
+}
+
+static int rtw_mpm_check_frames(_adapter *adapter, u8 action, const u8 **buf, size_t *len, u8 tx)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *plink = NULL;
+	u8 *nbuf = NULL;
+	size_t nlen = 0;
+	u8 *fhead = (u8 *)*buf;
+	size_t flen = *len;
+	u8 *peer_addr = tx ? GetAddr1Ptr(fhead) : get_addr2_ptr(fhead);
+	u8 *frame_body = fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
+	struct mpm_frame_info mpm_info;
+	u8 tlv_ies_offset;
+	u8 *mpm_ie = NULL;
+	uint mpm_ielen = 0;
+	u8 *mic_ie = NULL;
+	uint mic_ielen = 0;
+	int ret = 0;
+	u8 mpm_log_buf[MPM_LOG_BUF_LEN] = {0};
+
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_OPEN)
+		tlv_ies_offset = 4;
+	else if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF)
+		tlv_ies_offset = 6;
+	else if (action == RTW_ACT_SELF_PROTECTED_MESH_CLOSE)
+		tlv_ies_offset = 2;
+	else {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	plink = rtw_mesh_plink_get(adapter, peer_addr);
+	if (!plink && (tx == _TRUE || action == RTW_ACT_SELF_PROTECTED_MESH_CONF)) {
+		/* warning message if no plink when: 1.TX all MPM or 2.RX CONF */
+		RTW_WARN("RTW_%s:%s without plink of "MAC_FMT"\n"
+			, (tx == _TRUE) ? "Tx" : "Rx", action_self_protected_str(action), MAC_ARG(peer_addr));
+		goto exit;
+	}
+
+	_rtw_memset(&mpm_info, 0, sizeof(struct mpm_frame_info));
+
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF) {
+		mpm_info.aid = (u8 *)frame_body + 4;
+		mpm_info.aid_v = RTW_GET_LE16(mpm_info.aid);
+	}
+
+	mpm_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+		, WLAN_EID_MPM, &mpm_ielen
+		, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+	if (!mpm_ie || mpm_ielen < 2 + 2)
+		goto exit;
+
+	mpm_info.pid = mpm_ie + 2;
+	mpm_info.pid_v = RTW_GET_LE16(mpm_info.pid);
+	mpm_info.llid = mpm_info.pid + 2;
+	mpm_info.llid_v = RTW_GET_LE16(mpm_info.llid);
+
+	switch (action) {
+	case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
+		/* pid:2, llid:2, (chosen_pmk:16) */
+		if (mpm_info.pid_v == 0 && mpm_ielen == 4)
+			;
+		else if (mpm_info.pid_v == 1 && mpm_ielen == 20)
+			mpm_info.chosen_pmk = mpm_info.llid + 2;
+		else
+			goto exit;
+		break;
+	case RTW_ACT_SELF_PROTECTED_MESH_CONF:
+		/* pid:2, llid:2, plid:2, (chosen_pmk:16) */
+		mpm_info.plid = mpm_info.llid + 2;
+		mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
+		if (mpm_info.pid_v == 0 && mpm_ielen == 6)
+			;
+		else if (mpm_info.pid_v == 1 && mpm_ielen == 22)
+			mpm_info.chosen_pmk = mpm_info.plid + 2;
+		else
+			goto exit;
+		break;
+	case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
+		/* pid:2, llid:2, (plid:2), reason:2, (chosen_pmk:16) */
+		if (mpm_info.pid_v == 0 && mpm_ielen == 6) {
+			/* MPM, without plid */
+			mpm_info.reason = mpm_info.llid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+		} else if (mpm_info.pid_v == 0 && mpm_ielen == 8) {
+			/* MPM, with plid */
+			mpm_info.plid = mpm_info.llid + 2;
+			mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
+			mpm_info.reason = mpm_info.plid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+		} else if (mpm_info.pid_v == 1 && mpm_ielen == 22) {
+			/* AMPE, without plid */
+			mpm_info.reason = mpm_info.llid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+			mpm_info.chosen_pmk = mpm_info.reason + 2;
+		} else if (mpm_info.pid_v == 1 && mpm_ielen == 24) {
+			/* AMPE, with plid */
+			mpm_info.plid = mpm_info.llid + 2;
+			mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
+			mpm_info.reason = mpm_info.plid + 2;
+			mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
+			mpm_info.chosen_pmk = mpm_info.reason + 2;
+		} else
+			goto exit;
+		break;
+	};
+
+	if (mpm_info.pid_v == 1) {
+		mic_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+			, WLAN_EID_MIC, &mic_ielen
+			, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		if (!mic_ie || mic_ielen != AES_BLOCK_SIZE)
+			goto exit;
+	}
+
+#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+	if ((action == RTW_ACT_SELF_PROTECTED_MESH_OPEN || action == RTW_ACT_SELF_PROTECTED_MESH_CONF)
+		&& tx == _TRUE
+	) {
+#define DBG_RTW_MPM_TX_IES_SYNC_BSS 0
+
+		if (mpm_info.pid_v == 1 && (!plink || !MESH_PLINK_AEK_VALID(plink))) {
+			RTW_WARN("AEK not ready, IEs can't sync with BSS\n");
+			goto bypass_sync_bss;
+		}
+
+		if (DBG_RTW_MPM_TX_IES_SYNC_BSS) {
+			RTW_INFO(FUNC_ADPT_FMT" before:\n", FUNC_ADPT_ARG(adapter));
+			dump_ies(RTW_DBGDUMP
+				, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+				, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		}
+
+		rtw_mpm_tx_ies_sync_bss(adapter, plink
+			, fhead, flen, frame_body, tlv_ies_offset, mpm_ie, mic_ie
+			, &nbuf, &nlen);
+		if (!nbuf)
+			goto exit;
+
+		/* update pointer & len for new frame */
+		fhead = nbuf;
+		flen = nlen;
+		frame_body = fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
+		if (mpm_info.pid_v == 1) {
+			mic_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+				, WLAN_EID_MIC, &mic_ielen
+				, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		}
+
+		if (DBG_RTW_MPM_TX_IES_SYNC_BSS) {
+			RTW_INFO(FUNC_ADPT_FMT" after:\n", FUNC_ADPT_ARG(adapter));
+			dump_ies(RTW_DBGDUMP
+				, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
+				, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
+		}
+	}
+bypass_sync_bss:
+#endif /* CONFIG_RTW_MPM_TX_IES_SYNC_BSS */
+
+	if (!plink)
+		goto mpm_log;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_OPEN) {
+		if (tx)
+			rtw_mesh_plink_set_peer_conf_timeout(adapter, peer_addr);
+
+	} else
+#endif
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_CLOSE) {
+		if (tx && mpm_info.reason && mpm_info.reason_v == WLAN_REASON_MESH_MAX_PEERS) {
+			if (rtw_mesh_scanned_is_acnode_confirmed(adapter, plink->scanned)
+				&& rtw_mesh_acnode_prevent_allow_sacrifice(adapter)
+			) {
+				struct sta_info *sac = rtw_mesh_acnode_prevent_pick_sacrifice(adapter);
+
+				if (sac) {
+					struct sta_priv *stapriv = &adapter->stapriv;
+					_irqL irqL;
+					u8 sta_addr[ETH_ALEN];
+					u8 updated = _FALSE;
+
+					_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+					if (!rtw_is_list_empty(&sac->asoc_list)) {
+						rtw_list_delete(&sac->asoc_list);
+						stapriv->asoc_list_cnt--;
+						STA_SET_MESH_PLINK(sac, NULL);
+					}
+					_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+					RTW_INFO(FUNC_ADPT_FMT" sacrifice "MAC_FMT" for acnode\n"
+						, FUNC_ADPT_ARG(adapter), MAC_ARG(sac->cmn.mac_addr));
+
+					_rtw_memcpy(sta_addr, sac->cmn.mac_addr, ETH_ALEN);
+					updated = ap_free_sta(adapter, sac, 0, 0, 1);
+					rtw_mesh_expire_peer(stapriv->padapter, sta_addr);
+
+					associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
+				}
+			}
+		}
+	} else
+#endif
+	if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF) {
+		_irqL irqL;
+		u8 *ies = NULL;
+		u16 ies_len = 0;
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL);
+
+		plink = _rtw_mesh_plink_get(adapter, peer_addr);
+		if (!plink)
+			goto release_plink_ctl;
+
+		if (tx == _FALSE) {
+			ies = plink->rx_conf_ies;
+			ies_len = plink->rx_conf_ies_len;
+			plink->rx_conf_ies = NULL;
+			plink->rx_conf_ies_len = 0;
+
+			plink->llid = mpm_info.plid_v;
+			plink->plid = mpm_info.llid_v;
+			plink->peer_aid = mpm_info.aid_v;
+			if (mpm_info.pid_v == 1)
+				_rtw_memcpy(plink->chosen_pmk, mpm_info.chosen_pmk, 16);
+		}
+		#ifdef CONFIG_RTW_MESH_DRIVER_AID
+		else {
+			ies = plink->tx_conf_ies;
+			ies_len = plink->tx_conf_ies_len;
+			plink->tx_conf_ies = NULL;
+			plink->tx_conf_ies_len = 0;
+		}
+		#endif
+
+		if (ies && ies_len)
+			rtw_mfree(ies, ies_len);
+
+		#ifndef CONFIG_RTW_MESH_DRIVER_AID
+		if (tx == _TRUE)
+			goto release_plink_ctl; /* no need to copy tx conf ies */
+		#endif
+
+		/* copy mesh confirm IEs */
+		if (mpm_info.pid_v == 1) /* not include MIC & encrypted AMPE */
+			ies_len = (mic_ie - fhead) - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
+		else
+			ies_len = flen - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
+
+		ies = rtw_zmalloc(ies_len);
+		if (ies) {
+			_rtw_memcpy(ies, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + 2, ies_len);
+			if (tx == _FALSE) {
+				plink->rx_conf_ies = ies;
+				plink->rx_conf_ies_len = ies_len;
+			}
+			#ifdef CONFIG_RTW_MESH_DRIVER_AID	
+			else {
+				plink->tx_conf_ies = ies;
+				plink->tx_conf_ies_len = ies_len;
+			}
+			#endif
+		}
+
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL);
+	}
+
+mpm_log:
+	rtw_mpm_info_msg(&mpm_info, mpm_log_buf);
+	RTW_INFO("RTW_%s:%s %s\n"
+		, (tx == _TRUE) ? "Tx" : "Rx"
+		, action_self_protected_str(action)
+		, mpm_log_buf
+	);
+
+	ret = 1;
+
+exit:
+	if (nbuf) {
+		if (ret == 1) {
+			*buf = nbuf;
+			*len = nlen;
+		} else
+			rtw_mfree(nbuf, nlen);
+	}
+
+	return ret;
+}
+
+static int rtw_mesh_check_frames(_adapter *adapter, const u8 **buf, size_t *len, u8 tx)
+{
+	int is_mesh_frame = -1;
+	const u8 *frame_body;
+	u8 category, action;
+
+	frame_body = *buf + sizeof(struct rtw_ieee80211_hdr_3addr);
+	category = frame_body[0];
+
+	if (category == RTW_WLAN_CATEGORY_SELF_PROTECTED) {
+		action = frame_body[1];
+		switch (action) {
+		case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
+		case RTW_ACT_SELF_PROTECTED_MESH_CONF:
+		case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
+			rtw_mpm_check_frames(adapter, action, buf, len, tx);
+			is_mesh_frame = action;
+			break;
+		case RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM:
+		case RTW_ACT_SELF_PROTECTED_MESH_GK_ACK:
+			RTW_INFO("RTW_%s:%s\n", (tx == _TRUE) ? "Tx" : "Rx", action_self_protected_str(action));
+			is_mesh_frame = action;
+			break;
+		default:
+			break;
+		};
+	}
+
+exit:
+	return is_mesh_frame;
+}
+
+int rtw_mesh_check_frames_tx(_adapter *adapter, const u8 **buf, size_t *len)
+{
+	return rtw_mesh_check_frames(adapter, buf, len, _TRUE);
+}
+
+int rtw_mesh_check_frames_rx(_adapter *adapter, const u8 *buf, size_t len)
+{
+	return rtw_mesh_check_frames(adapter, &buf, &len, _FALSE);
+}
+
+int rtw_mesh_on_auth(_adapter *adapter, union recv_frame *rframe)
+{
+	u8 *whdr = rframe->u.hdr.rx_data;
+
+#if CONFIG_RTW_MACADDR_ACL
+	if (rtw_access_ctrl(adapter, get_addr2_ptr(whdr)) == _FALSE)
+		return _SUCCESS;
+#endif
+
+	if (!rtw_mesh_plink_get(adapter, get_addr2_ptr(whdr))) {
+		#if CONFIG_RTW_MESH_ACNODE_PREVENT
+		rtw_mesh_acnode_set_notify_etime(adapter, whdr);
+		#endif
+
+		if (adapter_to_rfctl(adapter)->offch_state == OFFCHS_NONE)
+			issue_probereq(adapter, &adapter->mlmepriv.cur_network.network.mesh_id, get_addr2_ptr(whdr));
+
+		/* only peer being added (checked by notify conditions) is allowed */
+		return _SUCCESS;
+	}
+
+	rtw_cfg80211_rx_mframe(adapter, rframe, NULL);
+	return _SUCCESS;
+}
+
+unsigned int on_action_self_protected(_adapter *adapter, union recv_frame *rframe)
+{
+	unsigned int ret = _FAIL;
+	struct sta_info *sta = NULL;
+	u8 *pframe = rframe->u.hdr.rx_data;
+	uint frame_len = rframe->u.hdr.len;
+	u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+	u8 category;
+	u8 action;
+
+	/* check RA matches or not */
+	if (!_rtw_memcmp(adapter_mac_addr(adapter), GetAddr1Ptr(pframe), ETH_ALEN))
+		goto exit;
+
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_SELF_PROTECTED)
+		goto exit;
+
+	action = frame_body[1];
+	switch (action) {
+	case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
+	case RTW_ACT_SELF_PROTECTED_MESH_CONF:
+	case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
+	case RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM:
+	case RTW_ACT_SELF_PROTECTED_MESH_GK_ACK:
+		if (!(MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)))
+			goto exit;
+#ifdef CONFIG_IOCTL_CFG80211
+		#if CONFIG_RTW_MACADDR_ACL
+		if (rtw_access_ctrl(adapter, get_addr2_ptr(pframe)) == _FALSE)
+			goto exit;
+		#endif
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		if (rtw_mesh_cto_mgate_required(adapter)
+			/* only peer being added (checked by notify conditions) is allowed */
+			&& !rtw_mesh_plink_get(adapter, get_addr2_ptr(pframe)))
+			goto exit;
+		#endif
+		rtw_cfg80211_rx_action(adapter, rframe, NULL);
+		ret = _SUCCESS;
+#endif /* CONFIG_IOCTL_CFG80211 */
+		break;
+	default:
+		break;
+	}
+
+exit:
+	return ret;
+}
+
+const u8 ae_to_mesh_ctrl_len[] = {
+	6,
+	12, /* MESH_FLAGS_AE_A4 */
+	18, /* MESH_FLAGS_AE_A5_A6 */
+	0,
+};
+
+unsigned int on_action_mesh(_adapter *adapter, union recv_frame *rframe)
+{
+	unsigned int ret = _FAIL;
+	struct sta_info *sta = NULL;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u8 *pframe = rframe->u.hdr.rx_data;
+	uint frame_len = rframe->u.hdr.len;
+	u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+	u8 category;
+	u8 action;
+
+	if (!MLME_IS_MESH(adapter))
+		goto exit;
+
+	/* check stainfo exist? */
+
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_MESH)
+		goto exit;
+
+	action = frame_body[1];
+	switch (action) {
+	case RTW_ACT_MESH_HWMP_PATH_SELECTION:
+		rtw_mesh_rx_path_sel_frame(adapter, rframe);
+		ret = _SUCCESS;
+		break;
+	default:
+		break;
+	}
+
+exit:
+	return ret;
+}
+
+bool rtw_mesh_update_bss_peering_status(_adapter *adapter, WLAN_BSSID_EX *bss)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	u8 num_of_peerings = stapriv->asoc_list_cnt;
+	bool accept_peerings = stapriv->asoc_list_cnt < mcfg->max_peer_links;
+	u8 *ie;
+	int ie_len;
+	bool updated = 0;
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	accept_peerings |= plink_ctl->acnode_rsvd;
+#endif
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len, BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (GET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2) != num_of_peerings) {
+		SET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2, num_of_peerings);
+		updated = 1;
+	}
+
+	if (GET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2) != accept_peerings) {
+		SET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2, accept_peerings);
+		updated = 1;
+	}
+
+exit:
+	return updated;
+}
+
+bool rtw_mesh_update_bss_formation_info(_adapter *adapter, WLAN_BSSID_EX *bss)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u8 cto_mgate = (minfo->num_gates || mcfg->dot11MeshGateAnnouncementProtocol);
+	u8 cto_as = 0;
+	u8 *ie;
+	int ie_len;
+	bool updated = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (GET_MESH_CONF_ELE_CTO_MGATE(ie + 2) != cto_mgate) {
+		SET_MESH_CONF_ELE_CTO_MGATE(ie + 2, cto_mgate);
+		updated = 1;
+	}
+
+	if (GET_MESH_CONF_ELE_CTO_AS(ie + 2) != cto_as) {
+		SET_MESH_CONF_ELE_CTO_AS(ie + 2, cto_as);
+		updated = 1;
+	}
+
+exit:
+	return updated;
+}
+
+bool rtw_mesh_update_bss_forwarding_state(_adapter *adapter, WLAN_BSSID_EX *bss)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	u8 forward = mcfg->dot11MeshForwarding;
+	u8 *ie;
+	int ie_len;
+	bool updated = 0;
+
+	ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
+			BSS_EX_TLV_IES_LEN(bss));
+	if (!ie || ie_len != 7) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (GET_MESH_CONF_ELE_FORWARDING(ie + 2) != forward) {
+		SET_MESH_CONF_ELE_FORWARDING(ie + 2, forward);
+		updated = 1;
+	}
+
+exit:
+	return updated;
+}
+
+struct mesh_plink_ent *_rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	int i;
+
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			ent = &plink_ctl->ent[i];
+			break;
+		}
+	}
+
+exit:
+	return ent;
+}
+
+struct mesh_plink_ent *rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent;
+}
+
+struct mesh_plink_ent *rtw_mesh_plink_get_no_estab_by_idx(_adapter *adapter, u8 idx)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	int i, j = 0;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& plink_ctl->ent[i].plink_state != RTW_MESH_PLINK_ESTAB
+		) {
+			if (j == idx) {
+				ent = &plink_ctl->ent[i];
+				break;
+			}
+			j++;
+		}
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+	return ent;
+}
+
+int _rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	u8 exist = _FALSE;
+	int i;
+
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			ent = &plink_ctl->ent[i];
+			exist = _TRUE;
+			break;
+		}
+
+		if (ent == NULL && plink_ctl->ent[i].valid == _FALSE)
+			ent = &plink_ctl->ent[i];
+	}
+
+	if (exist == _FALSE && ent) {
+		_rtw_memcpy(ent->addr, hwaddr, ETH_ALEN);
+		ent->valid = _TRUE;
+		#ifdef CONFIG_RTW_MESH_AEK
+		ent->aek_valid = 0;
+		#endif
+		ent->llid = 0;
+		ent->plid = 0;
+		_rtw_memset(ent->chosen_pmk, 0, 16);
+		#ifdef CONFIG_RTW_MESH_AEK
+		_rtw_memset(ent->sel_pcs, 0, 4);
+		_rtw_memset(ent->l_nonce, 0, 32);
+		_rtw_memset(ent->p_nonce, 0, 32);
+		#endif
+		ent->plink_state = RTW_MESH_PLINK_LISTEN;
+		#ifndef CONFIG_RTW_MESH_DRIVER_AID
+		ent->aid = 0;
+		#endif
+		ent->peer_aid = 0;
+		SET_PEER_CONF_DISABLED(ent);
+		SET_CTO_MGATE_CONF_DISABLED(ent);
+		plink_ctl->num++;
+	}
+
+exit:
+	return exist == _TRUE ? RTW_ALREADY : (ent ? _SUCCESS : _FAIL);
+}
+
+int rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	_irqL irqL;
+	int ret;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ret = _rtw_mesh_plink_add(adapter, hwaddr);
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+	return ret;
+}
+
+int rtw_mesh_plink_set_state(_adapter *adapter, const u8 *hwaddr, u8 state)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	if (ent)
+		ent->plink_state = state;
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent ? _SUCCESS : _FAIL;
+}
+
+#ifdef CONFIG_RTW_MESH_AEK
+int rtw_mesh_plink_set_aek(_adapter *adapter, const u8 *hwaddr, const u8 *aek)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	if (ent) {
+		_rtw_memcpy(ent->aek, aek, 32);
+		ent->aek_valid = 1;
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent ? _SUCCESS : _FAIL;
+}
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_plink_set_peer_conf_timeout(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	ent = _rtw_mesh_plink_get(adapter, hwaddr);
+	if (ent) {
+		if (IS_PEER_CONF_DISABLED(ent))
+			SET_PEER_CONF_END_TIME(ent, mcfg->peer_sel_policy.peer_conf_timeout_ms);
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return ent ? _SUCCESS : _FAIL;
+}
+#endif
+
+void _rtw_mesh_plink_del_ent(_adapter *adapter, struct mesh_plink_ent *ent)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+
+	ent->valid = _FALSE;
+	#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	if (ent->tx_conf_ies && ent->tx_conf_ies_len)
+		rtw_mfree(ent->tx_conf_ies, ent->tx_conf_ies_len);
+	ent->tx_conf_ies = NULL;
+	ent->tx_conf_ies_len = 0;
+	#endif
+	if (ent->rx_conf_ies && ent->rx_conf_ies_len)
+		rtw_mfree(ent->rx_conf_ies, ent->rx_conf_ies_len);
+	ent->rx_conf_ies = NULL;
+	ent->rx_conf_ies_len = 0;
+	if (ent->scanned)
+		ent->scanned = NULL;
+	plink_ctl->num--;
+}
+
+int rtw_mesh_plink_del(_adapter *adapter, const u8 *hwaddr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent = NULL;
+	u8 exist = _FALSE;
+	int i;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		if (plink_ctl->ent[i].valid == _TRUE
+			&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
+		) {
+			ent = &plink_ctl->ent[i];
+			exist = _TRUE;
+			break;
+		}
+	}
+
+	if (exist == _TRUE)
+		_rtw_mesh_plink_del_ent(adapter, ent);
+
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+exit:
+	return exist == _TRUE ? _SUCCESS : RTW_ALREADY;
+}
+
+void rtw_mesh_plink_ctl_init(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	int i;
+
+	_rtw_spinlock_init(&plink_ctl->lock);
+	plink_ctl->num = 0;
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++)
+		plink_ctl->ent[i].valid = _FALSE;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	_rtw_init_queue(&plink_ctl->peer_blacklist);
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	_rtw_init_queue(&plink_ctl->cto_mgate_blacklist);
+#endif
+}
+
+void rtw_mesh_plink_ctl_deinit(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent;
+	int i;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
+		ent = &plink_ctl->ent[i];
+		#ifdef CONFIG_RTW_MESH_DRIVER_AID
+		if (ent->tx_conf_ies && ent->tx_conf_ies_len)
+			rtw_mfree(ent->tx_conf_ies, ent->tx_conf_ies_len);
+		#endif
+		if (ent->rx_conf_ies && ent->rx_conf_ies_len)
+			rtw_mfree(ent->rx_conf_ies, ent->rx_conf_ies_len);
+	}
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+	_rtw_spinlock_free(&plink_ctl->lock);
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	rtw_mesh_peer_blacklist_flush(adapter);
+	_rtw_deinit_queue(&plink_ctl->peer_blacklist);
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	rtw_mesh_cto_mgate_blacklist_flush(adapter);
+	_rtw_deinit_queue(&plink_ctl->cto_mgate_blacklist);
+#endif
+}
+
+void dump_mesh_plink_ctl(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *ent;
+	int i;
+
+	RTW_PRINT_SEL(sel, "num:%u\n", plink_ctl->num);
+	#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	RTW_PRINT_SEL(sel, "acnode_rsvd:%u\n", plink_ctl->acnode_rsvd);
+	#endif
+
+	for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++)  {
+		ent = &plink_ctl->ent[i];
+		if (!ent->valid)
+			continue;
+
+		RTW_PRINT_SEL(sel, "\n");
+		RTW_PRINT_SEL(sel, "peer:"MAC_FMT"\n", MAC_ARG(ent->addr));
+		RTW_PRINT_SEL(sel, "plink_state:%s\n", rtw_mesh_plink_str(ent->plink_state));
+
+		#ifdef CONFIG_RTW_MESH_AEK
+		if (ent->aek_valid)
+			RTW_PRINT_SEL(sel, "aek:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->aek), KEY_ARG(ent->aek + 16));
+		#endif
+
+		RTW_PRINT_SEL(sel, "llid:%u, plid:%u\n", ent->llid, ent->plid);
+		#ifndef CONFIG_RTW_MESH_DRIVER_AID
+		RTW_PRINT_SEL(sel, "aid:%u\n", ent->aid);
+		#endif
+		RTW_PRINT_SEL(sel, "peer_aid:%u\n", ent->peer_aid);
+
+		RTW_PRINT_SEL(sel, "chosen_pmk:"KEY_FMT"\n", KEY_ARG(ent->chosen_pmk));
+
+		#ifdef CONFIG_RTW_MESH_AEK
+		RTW_PRINT_SEL(sel, "sel_pcs:%02x%02x%02x%02x\n"
+			, ent->sel_pcs[0], ent->sel_pcs[1], ent->sel_pcs[2], ent->sel_pcs[3]);
+		RTW_PRINT_SEL(sel, "l_nonce:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->l_nonce), KEY_ARG(ent->l_nonce + 16));
+		RTW_PRINT_SEL(sel, "p_nonce:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->p_nonce), KEY_ARG(ent->p_nonce + 16));
+		#endif
+
+		#ifdef CONFIG_RTW_MESH_DRIVER_AID
+		RTW_PRINT_SEL(sel, "tx_conf_ies:%p, len:%u\n", ent->tx_conf_ies, ent->tx_conf_ies_len);
+		#endif
+		RTW_PRINT_SEL(sel, "rx_conf_ies:%p, len:%u\n", ent->rx_conf_ies, ent->rx_conf_ies_len);
+		RTW_PRINT_SEL(sel, "scanned:%p\n", ent->scanned);
+
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		if (!IS_PEER_CONF_DISABLED(ent)) {
+			if (!IS_PEER_CONF_TIMEOUT(ent))
+				RTW_PRINT_SEL(sel, "peer_conf:%d\n", rtw_systime_to_ms(ent->peer_conf_end_time - rtw_get_current_time()));
+			else
+				RTW_PRINT_SEL(sel, "peer_conf:TIMEOUT\n");
+		}
+		#endif
+
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		if (!IS_CTO_MGATE_CONF_DISABLED(ent)) {
+			if (!IS_CTO_MGATE_CONF_TIMEOUT(ent))
+				RTW_PRINT_SEL(sel, "cto_mgate_conf:%d\n", rtw_systime_to_ms(ent->cto_mgate_conf_end_time - rtw_get_current_time()));
+			else
+				RTW_PRINT_SEL(sel, "cto_mgate_conf:TIMEOUT\n");
+		}
+		#endif
+	}
+}
+
+/* this function is called with plink_ctl being locked */
+int rtw_mesh_peer_establish(_adapter *adapter, struct mesh_plink_ent *plink, struct sta_info *sta)
+{
+#ifndef DBG_RTW_MESH_PEER_ESTABLISH
+#define DBG_RTW_MESH_PEER_ESTABLISH 0
+#endif
+
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	u8 *tlv_ies;
+	u16 tlv_ieslen;
+	struct rtw_ieee802_11_elems elems;
+	_irqL irqL;
+	int i;
+	int ret = _FAIL;
+
+	if (!plink->rx_conf_ies || !plink->rx_conf_ies_len) {
+		RTW_INFO(FUNC_ADPT_FMT" no rx confirm from sta "MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+	if (plink->rx_conf_ies_len < 4) {
+		RTW_INFO(FUNC_ADPT_FMT" confirm from sta "MAC_FMT" too short\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	if (!plink->tx_conf_ies || !plink->tx_conf_ies_len) {
+		RTW_INFO(FUNC_ADPT_FMT" no tx confirm to sta "MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+	if (plink->tx_conf_ies_len < 4) {
+		RTW_INFO(FUNC_ADPT_FMT" confirm to sta "MAC_FMT" too short\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+#endif
+
+	tlv_ies = plink->rx_conf_ies + 4;
+	tlv_ieslen = plink->rx_conf_ies_len - 4;
+
+	if (DBG_RTW_MESH_PEER_ESTABLISH)
+		dump_ies(RTW_DBGDUMP, tlv_ies, tlv_ieslen);
+
+	if (rtw_ieee802_11_parse_elems(tlv_ies, tlv_ieslen, &elems, 1) == ParseFailed) {
+		RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" sent invalid confirm\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+		goto exit;
+	}
+
+	SET_PEER_CONF_DISABLED(plink);
+	if (rtw_bss_is_cto_mgate(&plink->scanned->network)
+		&& !rtw_bss_is_forwarding(&plink->scanned->network))
+		SET_CTO_MGATE_CONF_END_TIME(plink, mcfg->peer_sel_policy.cto_mgate_conf_timeout_ms);
+	else
+		SET_CTO_MGATE_CONF_DISABLED(plink);
+
+	sta->state &= (~WIFI_FW_AUTH_SUCCESS);
+	sta->state |= WIFI_FW_ASSOC_STATE;
+
+	rtw_ap_parse_sta_capability(adapter, sta, plink->rx_conf_ies);
+
+	if (rtw_ap_parse_sta_supported_rates(adapter, sta, tlv_ies, tlv_ieslen) != _STATS_SUCCESSFUL_)
+		goto exit;
+	
+	if (rtw_ap_parse_sta_security_ie(adapter, sta, &elems) != _STATS_SUCCESSFUL_)
+		goto exit;
+
+	rtw_ap_parse_sta_wmm_ie(adapter, sta, tlv_ies, tlv_ieslen);
+#ifdef CONFIG_RTS_FULL_BW
+	/*check vendor IE*/
+	rtw_parse_sta_vendor_ie_8812(adapter, sta, tlv_ies, tlv_ieslen);
+#endif/*CONFIG_RTS_FULL_BW*/
+
+	rtw_ap_parse_sta_ht_ie(adapter, sta, &elems);
+	rtw_ap_parse_sta_vht_ie(adapter, sta, &elems);
+
+	/* AID */
+#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	sta->cmn.aid = RTW_GET_LE16(plink->tx_conf_ies + 2);
+#else
+	sta->cmn.aid = plink->aid;
+#endif
+	stapriv->sta_aid[sta->cmn.aid - 1] = sta;
+	RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" aid:%u\n"
+		, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr), sta->cmn.aid);
+
+	sta->state &= (~WIFI_FW_ASSOC_STATE);
+	sta->state |= WIFI_FW_ASSOC_SUCCESS;
+
+	sta->local_mps = RTW_MESH_PS_ACTIVE;
+
+	rtw_ewma_err_rate_init(&sta->metrics.err_rate);
+	rtw_ewma_err_rate_add(&sta->metrics.err_rate, 1);
+	/* init data_rate to 1M */
+	sta->metrics.data_rate = 10;
+
+	_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+	if (rtw_is_list_empty(&sta->asoc_list)) {
+		STA_SET_MESH_PLINK(sta, plink);
+		/* TBD: up layer timeout mechanism */
+		/* sta->expire_to = mcfg->plink_timeout / 2; */
+		rtw_list_insert_tail(&sta->asoc_list, &stapriv->asoc_list);
+		stapriv->asoc_list_cnt++;
+	}
+	_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	bss_cap_update_on_sta_join(adapter, sta);
+	sta_info_update(adapter, sta);
+	report_add_sta_event(adapter, sta->cmn.mac_addr);
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+void rtw_mesh_expire_peer_notify(_adapter *adapter, const u8 *peer_addr)
+{
+	u8 null_ssid[2] = {0, 0};
+
+#ifdef CONFIG_IOCTL_CFG80211
+	rtw_cfg80211_notify_new_peer_candidate(adapter->rtw_wdev
+		, peer_addr
+		, null_ssid
+		, 2
+		, GFP_ATOMIC
+	);
+#endif
+
+exit:
+	return;
+}
+
+static u8 *rtw_mesh_construct_peer_mesh_close(_adapter *adapter, struct mesh_plink_ent *plink, u16 reason, u32 *len)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u8 *frame = NULL, *pos;
+	u32 flen;
+	struct rtw_ieee80211_hdr *whdr;
+
+	if (minfo->mesh_auth_id && !MESH_PLINK_AEK_VALID(plink))
+		goto exit;
+
+	flen = sizeof(struct rtw_ieee80211_hdr_3addr)
+		+ 2 /* category, action */
+		+ 2 + minfo->mesh_id_len /* mesh id */
+		+ 2 + 8 + (minfo->mesh_auth_id ? 16 : 0) /* mpm */
+		+ (minfo->mesh_auth_id ? 2 + AES_BLOCK_SIZE : 0) /* mic */
+		+ (minfo->mesh_auth_id ? 70 : 0) /* ampe */
+		;
+
+	pos = frame = rtw_zmalloc(flen);
+	if (!frame)
+		goto exit;
+
+	whdr = (struct rtw_ieee80211_hdr *)frame;
+	_rtw_memcpy(whdr->addr1, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memcpy(whdr->addr2, plink->addr, ETH_ALEN);
+	_rtw_memcpy(whdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
+
+	set_frame_sub_type(frame, WIFI_ACTION);
+
+	pos += sizeof(struct rtw_ieee80211_hdr_3addr);
+	*(pos++) = RTW_WLAN_CATEGORY_SELF_PROTECTED;
+	*(pos++) = RTW_ACT_SELF_PROTECTED_MESH_CLOSE;
+
+	pos = rtw_set_ie_mesh_id(pos, NULL, minfo->mesh_id, minfo->mesh_id_len);
+
+	pos = rtw_set_ie_mpm(pos, NULL
+		, minfo->mesh_auth_id ? 1 : 0
+		, plink->plid
+		, &plink->llid
+		, &reason
+		, minfo->mesh_auth_id ? plink->chosen_pmk : NULL);
+
+#ifdef CONFIG_RTW_MESH_AEK
+	if (minfo->mesh_auth_id) {
+		u8 ampe_buf[70];
+		int enc_ret;
+
+		*pos = WLAN_EID_MIC;
+		*(pos + 1) = AES_BLOCK_SIZE;
+
+		ampe_buf[0] = WLAN_EID_AMPE;
+		ampe_buf[1] = 68;
+		_rtw_memcpy(ampe_buf + 2, plink->sel_pcs, 4);
+		_rtw_memcpy(ampe_buf + 6, plink->p_nonce, 32);
+		_rtw_memcpy(ampe_buf + 38, plink->l_nonce, 32);
+
+		enc_ret = rtw_mpm_ampe_enc(adapter, plink
+			, frame + sizeof(struct rtw_ieee80211_hdr_3addr)
+			, pos, ampe_buf, 1);
+		if (enc_ret != _SUCCESS) {
+			rtw_mfree(frame, flen);
+			frame = NULL;
+			goto exit;
+		}
+	}
+#endif
+
+	*len = flen;
+
+exit:
+	return frame;
+}
+
+void _rtw_mesh_expire_peer_ent(_adapter *adapter, struct mesh_plink_ent *plink)
+{
+#if defined(CONFIG_RTW_MESH_STA_DEL_DISASOC)
+	_rtw_mesh_plink_del_ent(adapter, plink);
+	rtw_cfg80211_indicate_sta_disassoc(adapter, plink->addr, 0);
+#else
+	u8 *frame = NULL;
+	u32 flen;
+
+	if (plink->plink_state == RTW_MESH_PLINK_ESTAB)
+		frame = rtw_mesh_construct_peer_mesh_close(adapter, plink, WLAN_REASON_MESH_CLOSE, &flen);
+
+	if (frame) {
+		struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+		struct wireless_dev *wdev = adapter->rtw_wdev;
+		s32 freq = rtw_ch2freq(mlmeext->cur_channel);
+
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, flen, GFP_ATOMIC);
+		#else
+		cfg80211_rx_action(adapter->pnetdev, freq, frame, flen, GFP_ATOMIC);
+		#endif
+
+		rtw_mfree(frame, flen);
+	} else {
+		rtw_mesh_expire_peer_notify(adapter, plink->addr);
+		RTW_INFO(FUNC_ADPT_FMT" set "MAC_FMT" plink unknown\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(plink->addr));
+		plink->plink_state = RTW_MESH_PLINK_UNKNOWN;
+	}
+#endif
+}
+
+void rtw_mesh_expire_peer(_adapter *adapter, const u8 *peer_addr)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+	struct mesh_plink_ent *plink;
+	_irqL irqL;
+
+	_enter_critical_bh(&(plink_ctl->lock), &irqL);
+
+	plink = _rtw_mesh_plink_get(adapter, peer_addr);
+	if (!plink)
+		goto exit;
+
+	_rtw_mesh_expire_peer_ent(adapter, plink);
+
+exit:
+	_exit_critical_bh(&(plink_ctl->lock), &irqL);
+}
+
+u8 rtw_mesh_ps_annc(_adapter *adapter, u8 ps)
+{
+	_irqL irqL;
+	_list *head, *list;
+	struct sta_info *sta;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u8 sta_alive_num = 0, i;
+	char sta_alive_list[NUM_STA];
+	u8 annc_cnt = 0;
+
+	if (rtw_linked_check(adapter) == _FALSE)
+		goto exit;
+
+	_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	head = &stapriv->asoc_list;
+	list = get_next(head);
+	while ((rtw_end_of_queue_search(head, list)) == _FALSE) {
+		int stainfo_offset;
+
+		sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
+		list = get_next(list);
+
+		stainfo_offset = rtw_stainfo_offset(stapriv, sta);
+		if (stainfo_offset_valid(stainfo_offset))
+			sta_alive_list[sta_alive_num++] = stainfo_offset;
+	}
+	_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	for (i = 0; i < sta_alive_num; i++) {
+		sta = rtw_get_stainfo_by_offset(stapriv, sta_alive_list[i]);
+		if (!sta)
+			continue;
+
+		issue_qos_nulldata(adapter, sta->cmn.mac_addr, 7, ps, 3, 500);
+		annc_cnt++;
+	}
+
+exit:
+	return annc_cnt;
+}
+
+static void mpath_tx_tasklet_hdl(void *priv)
+{
+	_adapter *adapter = (_adapter *)priv;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct xmit_frame *xframe;
+	_list *list, *head;
+	_list tmp;
+	u32 tmp_len;
+	s32 res;
+
+	_rtw_init_listhead(&tmp);
+
+	while (1) {
+		tmp_len = 0;
+		enter_critical_bh(&minfo->mpath_tx_queue.lock);
+		if (minfo->mpath_tx_queue_len) {
+			rtw_list_splice_init(&minfo->mpath_tx_queue.queue, &tmp);
+			tmp_len = minfo->mpath_tx_queue_len;
+			minfo->mpath_tx_queue_len = 0;
+		}
+		exit_critical_bh(&minfo->mpath_tx_queue.lock);
+
+		if (!tmp_len)
+			break;
+
+		head = &tmp;
+		list = get_next(head);
+		while (rtw_end_of_queue_search(head, list) == _FALSE) {
+			xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+			list = get_next(list);
+			rtw_list_delete(&xframe->list);
+			res = rtw_xmit_posthandle(adapter, xframe, xframe->pkt);
+			if (res < 0) {
+				#ifdef DBG_TX_DROP_FRAME
+				RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit fail\n", __FUNCTION__);
+				#endif
+				adapter->xmitpriv.tx_drop++;
+			}
+		}
+	}
+}
+
+static void rtw_mpath_tx_queue_flush(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct xmit_frame *xframe;
+	_list *list, *head;
+	_list tmp;
+
+	_rtw_init_listhead(&tmp);
+
+	enter_critical_bh(&minfo->mpath_tx_queue.lock);
+	rtw_list_splice_init(&minfo->mpath_tx_queue.queue, &tmp);
+	minfo->mpath_tx_queue_len = 0;
+	exit_critical_bh(&minfo->mpath_tx_queue.lock);
+
+	head = &tmp;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+		rtw_list_delete(&xframe->list);
+		rtw_free_xmitframe(&adapter->xmitpriv, xframe);
+	}
+}
+
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+#if defined(CONFIG_SLUB)
+#include <linux/slub_def.h>
+#elif defined(CONFIG_SLAB)
+#include <linux/slab_def.h>
+#endif
+typedef struct kmem_cache rtw_mcache;
+#endif
+
+rtw_mcache *rtw_mcache_create(const char *name, size_t size)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	return kmem_cache_create(name, size, 0, 0, NULL);
+#else
+	#error "TBD\n";
+#endif
+}
+
+void rtw_mcache_destroy(rtw_mcache *s)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	kmem_cache_destroy(s);
+#else
+	#error "TBD\n";
+#endif
+}
+
+void *_rtw_mcache_alloc(rtw_mcache *cachep)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	return kmem_cache_alloc(cachep, GFP_ATOMIC);
+#else
+	#error "TBD\n";
+#endif
+}
+
+void _rtw_mcache_free(rtw_mcache *cachep, void *objp)
+{
+#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
+	kmem_cache_free(cachep, objp);
+#else
+	#error "TBD\n";
+#endif
+}
+
+#ifdef DBG_MEM_ALLOC
+inline void *dbg_rtw_mcache_alloc(rtw_mcache *cachep, const enum mstat_f flags, const char *func, const int line)
+{
+	void *p;
+	u32 sz = cachep->size;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u)\n", func, line, __func__, sz);
+
+	p = _rtw_mcache_alloc(cachep);
+
+	rtw_mstat_update(
+		flags
+		, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
+		, sz
+	);
+
+	return p;
+}
+
+inline void dbg_rtw_mcache_free(rtw_mcache *cachep, void *pbuf, const enum mstat_f flags, const char *func, const int line)
+{
+	u32 sz = cachep->size;
+
+	if (match_mstat_sniff_rules(flags, sz))
+		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u)\n", func, line, __func__, sz);
+
+	_rtw_mcache_free(cachep, pbuf);
+
+	rtw_mstat_update(
+		flags
+		, MSTAT_FREE
+		, sz
+	);
+}
+
+#define rtw_mcache_alloc(cachep) dbg_rtw_mcache_alloc(cachep, MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#define rtw_mcache_free(cachep, objp) dbg_rtw_mcache_free(cachep, objp, MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
+#else
+#define rtw_mcache_alloc(cachep) _rtw_mcache_alloc(cachep)
+#define rtw_mcache_free(cachep, objp) _rtw_mcache_free(cachep, objp)
+#endif /* DBG_MEM_ALLOC */
+
+/* Mesh Received Cache */
+#define RTW_MRC_BUCKETS			256 /* must be a power of 2 */
+#define RTW_MRC_QUEUE_MAX_LEN	4
+#define RTW_MRC_TIMEOUT_MS		(3 * 1000)
+
+/**
+ * struct rtw_mrc_entry - entry in the Mesh Received Cache
+ *
+ * @seqnum: mesh sequence number of the frame
+ * @exp_time: expiration time of the entry
+ * @msa: mesh source address of the frame
+ * @list: hashtable list pointer
+ *
+ * The Mesh Received Cache keeps track of the latest received frames that
+ * have been received by a mesh interface and discards received frames
+ * that are found in the cache.
+ */
+struct rtw_mrc_entry {
+	rtw_hlist_node list;
+	systime exp_time;
+	u32 seqnum;
+	u8 msa[ETH_ALEN];
+};
+
+struct rtw_mrc {
+	rtw_hlist_head bucket[RTW_MRC_BUCKETS];
+	u32 idx_mask;
+	rtw_mcache *cache;
+};
+
+static int rtw_mrc_init(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	char cache_name[IFNAMSIZ + 8 + 1];
+	int i;
+
+	minfo->mrc = rtw_malloc(sizeof(struct rtw_mrc));
+	if (!minfo->mrc)
+		return -ENOMEM;
+	minfo->mrc->idx_mask = RTW_MRC_BUCKETS - 1;
+	for (i = 0; i < RTW_MRC_BUCKETS; i++)
+		rtw_hlist_head_init(&minfo->mrc->bucket[i]);
+
+	sprintf(cache_name, "rtw_mrc_%s", ADPT_ARG(adapter));
+	minfo->mrc->cache = rtw_mcache_create(cache_name, sizeof(struct rtw_mrc_entry));
+
+	return 0;
+}
+
+static void rtw_mrc_free(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mrc *mrc = minfo->mrc;
+	struct rtw_mrc_entry *p;
+	rtw_hlist_node *np, *n;
+	int i;
+
+	if (!mrc)
+		return;
+
+	for (i = 0; i < RTW_MRC_BUCKETS; i++) {
+		rtw_hlist_for_each_entry_safe(p, np, n, &mrc->bucket[i], list) {
+			rtw_hlist_del(&p->list);
+			rtw_mcache_free(mrc->cache, p);
+		}
+	}
+
+	rtw_mcache_destroy(mrc->cache);
+
+	rtw_mfree(mrc, sizeof(struct rtw_mrc));
+	minfo->mrc = NULL;
+}
+
+/**
+ * rtw_mrc_check - Check frame in mesh received cache and add if absent.
+ *
+ * @adapter:	interface
+ * @msa:		mesh source address
+ * @seq:		mesh seq number
+ *
+ * Returns: 0 if the frame is not in the cache, nonzero otherwise.
+ *
+ * Checks using the mesh source address and the mesh sequence number if we have
+ * received this frame lately. If the frame is not in the cache, it is added to
+ * it.
+ */
+static int rtw_mrc_check(_adapter *adapter, const u8 *msa, u32 seq)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mrc *mrc = minfo->mrc;
+	int entries = 0;
+	u8 idx;
+	struct rtw_mrc_entry *p;
+	rtw_hlist_node *np, *n;
+	u8 timeout;
+
+	if (!mrc)
+		return -1;
+
+	idx = seq & mrc->idx_mask;
+	rtw_hlist_for_each_entry_safe(p, np, n, &mrc->bucket[idx], list) {
+		++entries;
+		timeout = rtw_time_after(rtw_get_current_time(), p->exp_time);
+		if (timeout || entries == RTW_MRC_QUEUE_MAX_LEN) {
+			if (!timeout)
+				minfo->mshstats.mrc_del_qlen++;
+
+			rtw_hlist_del(&p->list);
+			rtw_mcache_free(mrc->cache, p);
+			--entries;
+		} else if ((seq == p->seqnum) && _rtw_memcmp(msa, p->msa, ETH_ALEN) == _TRUE)
+			return -1;
+	}
+
+	p = rtw_mcache_alloc(mrc->cache);
+	if (!p)
+		return 0;
+
+	p->seqnum = seq;
+	p->exp_time = rtw_get_current_time() + rtw_ms_to_systime(RTW_MRC_TIMEOUT_MS);
+	_rtw_memcpy(p->msa, msa, ETH_ALEN);
+	rtw_hlist_add_head(&p->list, &mrc->bucket[idx]);
+	return 0;
+}
+
+static int rtw_mesh_decache(_adapter *adapter, const u8 *msa, u32 seq)
+{
+	return rtw_mrc_check(adapter, msa, seq);
+}
+
+#ifndef RTW_MESH_SCAN_RESULT_EXP_MS
+#define RTW_MESH_SCAN_RESULT_EXP_MS (10 * 1000)
+#endif
+
+#ifndef RTW_MESH_ACNODE_PREVENT
+#define RTW_MESH_ACNODE_PREVENT 0
+#endif
+#ifndef RTW_MESH_ACNODE_CONF_TIMEOUT_MS
+#define RTW_MESH_ACNODE_CONF_TIMEOUT_MS (20 * 1000)
+#endif
+#ifndef RTW_MESH_ACNODE_NOTIFY_TIMEOUT_MS
+#define RTW_MESH_ACNODE_NOTIFY_TIMEOUT_MS (2 * 1000)
+#endif
+
+#ifndef RTW_MESH_OFFCH_CAND
+#define RTW_MESH_OFFCH_CAND 1
+#endif
+#ifndef RTW_MESH_OFFCH_CAND_FIND_INT_MS
+#define RTW_MESH_OFFCH_CAND_FIND_INT_MS (10 * 1000)
+#endif
+
+#ifndef RTW_MESH_PEER_CONF_TIMEOUT_MS
+#define RTW_MESH_PEER_CONF_TIMEOUT_MS (20 * 1000)
+#endif
+#ifndef RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS
+#define RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS (20 * 1000)
+#endif
+
+#ifndef RTW_MESH_CTO_MGATE_REQUIRE
+#define RTW_MESH_CTO_MGATE_REQUIRE 0
+#endif
+#ifndef RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS
+#define RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS (20 * 1000)
+#endif
+#ifndef RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS
+#define RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS (20 * 1000)
+#endif
+
+void rtw_mesh_cfg_init_peer_sel_policy(struct rtw_mesh_cfg *mcfg)
+{
+	struct mesh_peer_sel_policy *sel_policy = &mcfg->peer_sel_policy;
+
+	sel_policy->scanr_exp_ms = RTW_MESH_SCAN_RESULT_EXP_MS;
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	sel_policy->acnode_prevent = RTW_MESH_ACNODE_PREVENT;
+	sel_policy->acnode_conf_timeout_ms = RTW_MESH_ACNODE_CONF_TIMEOUT_MS;
+	sel_policy->acnode_notify_timeout_ms = RTW_MESH_ACNODE_NOTIFY_TIMEOUT_MS;
+#endif
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+	sel_policy->offch_cand = RTW_MESH_OFFCH_CAND;
+	sel_policy->offch_find_int_ms = RTW_MESH_OFFCH_CAND_FIND_INT_MS;
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	sel_policy->peer_conf_timeout_ms = RTW_MESH_PEER_CONF_TIMEOUT_MS;
+	sel_policy->peer_blacklist_timeout_ms = RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS;
+#endif
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	sel_policy->cto_mgate_require = RTW_MESH_CTO_MGATE_REQUIRE;
+	sel_policy->cto_mgate_conf_timeout_ms = RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS;
+	sel_policy->cto_mgate_blacklist_timeout_ms = RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS;
+#endif
+}
+
+void rtw_mesh_cfg_init(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	mcfg->max_peer_links = RTW_MESH_MAX_PEER_LINKS;
+	mcfg->plink_timeout = RTW_MESH_PEER_LINK_TIMEOUT;
+
+	mcfg->dot11MeshTTL = RTW_MESH_TTL;
+	mcfg->element_ttl = RTW_MESH_DEFAULT_ELEMENT_TTL;
+	mcfg->dot11MeshHWMPmaxPREQretries = RTW_MESH_MAX_PREQ_RETRIES;
+	mcfg->path_refresh_time = RTW_MESH_PATH_REFRESH_TIME;
+	mcfg->min_discovery_timeout = RTW_MESH_MIN_DISCOVERY_TIMEOUT;
+	mcfg->dot11MeshHWMPactivePathTimeout = RTW_MESH_PATH_TIMEOUT;
+	mcfg->dot11MeshHWMPpreqMinInterval = RTW_MESH_PREQ_MIN_INT;
+	mcfg->dot11MeshHWMPperrMinInterval = RTW_MESH_PERR_MIN_INT;
+	mcfg->dot11MeshHWMPnetDiameterTraversalTime = RTW_MESH_DIAM_TRAVERSAL_TIME;
+	mcfg->dot11MeshHWMPRootMode = RTW_IEEE80211_ROOTMODE_NO_ROOT;
+	mcfg->dot11MeshHWMPRannInterval = RTW_MESH_RANN_INTERVAL;
+	mcfg->dot11MeshGateAnnouncementProtocol = _FALSE;
+	mcfg->dot11MeshForwarding = _TRUE;
+	mcfg->rssi_threshold = 0;
+	mcfg->dot11MeshHWMPactivePathToRootTimeout = RTW_MESH_PATH_TO_ROOT_TIMEOUT;
+	mcfg->dot11MeshHWMProotInterval = RTW_MESH_ROOT_INTERVAL;
+	mcfg->dot11MeshHWMPconfirmationInterval = RTW_MESH_ROOT_CONFIRMATION_INTERVAL;
+	mcfg->path_gate_timeout_factor = 3;
+	rtw_mesh_cfg_init_peer_sel_policy(mcfg);
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	mcfg->sane_metric_delta = RTW_MESH_SANE_METRIC_DELTA;
+	mcfg->max_root_add_chk_cnt = RTW_MESH_MAX_ROOT_ADD_CHK_CNT;
+#endif
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	mcfg->b2u_flags_msrc = 0;
+	mcfg->b2u_flags_mfwd = RTW_MESH_B2U_GA_UCAST;
+#endif
+}
+
+void rtw_mesh_cfg_init_max_peer_links(_adapter *adapter, u8 stack_conf)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	mcfg->max_peer_links = RTW_MESH_MAX_PEER_LINKS;
+
+	if (mcfg->max_peer_links > stack_conf)
+		mcfg->max_peer_links = stack_conf;
+}
+
+void rtw_mesh_cfg_init_plink_timeout(_adapter *adapter, u32 stack_conf)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	mcfg->plink_timeout = stack_conf;
+}
+
+void rtw_mesh_init_mesh_info(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+
+	_rtw_memset(minfo, 0, sizeof(struct rtw_mesh_info));
+
+	rtw_mesh_plink_ctl_init(adapter);
+	
+	minfo->last_preq = rtw_get_current_time();
+	/* minfo->last_sn_update = rtw_get_current_time(); */
+	minfo->next_perr = rtw_get_current_time();
+	
+	ATOMIC_SET(&minfo->mpaths, 0);
+	rtw_mesh_pathtbl_init(adapter);
+
+	_rtw_init_queue(&minfo->mpath_tx_queue);
+	tasklet_init(&minfo->mpath_tx_tasklet
+		, (void(*)(unsigned long))mpath_tx_tasklet_hdl
+		, (unsigned long)adapter);
+
+	rtw_mrc_init(adapter);
+
+	_rtw_init_listhead(&minfo->preq_queue.list);
+	_rtw_spinlock_init(&minfo->mesh_preq_queue_lock);
+	
+	rtw_init_timer(&adapter->mesh_path_timer, adapter, rtw_ieee80211_mesh_path_timer, adapter);
+	rtw_init_timer(&adapter->mesh_path_root_timer, adapter, rtw_ieee80211_mesh_path_root_timer, adapter);
+	rtw_init_timer(&adapter->mesh_atlm_param_req_timer, adapter, rtw_mesh_atlm_param_req_timer, adapter);
+	_init_workitem(&adapter->mesh_work, rtw_mesh_work_hdl, NULL);
+}
+
+void rtw_mesh_deinit_mesh_info(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+
+	tasklet_kill(&minfo->mpath_tx_tasklet);
+	rtw_mpath_tx_queue_flush(adapter);
+	_rtw_deinit_queue(&adapter->mesh_info.mpath_tx_queue);
+
+	rtw_mrc_free(adapter);
+
+	rtw_mesh_pathtbl_unregister(adapter);
+
+	rtw_mesh_plink_ctl_deinit(adapter);
+
+	_cancel_workitem_sync(&adapter->mesh_work);
+	_cancel_timer_ex(&adapter->mesh_path_timer);
+	_cancel_timer_ex(&adapter->mesh_path_root_timer);
+	_cancel_timer_ex(&adapter->mesh_atlm_param_req_timer);
+}
+
+/**
+ * rtw_mesh_nexthop_resolve - lookup next hop; conditionally start path discovery
+ *
+ * @skb: 802.11 frame to be sent
+ * @sdata: network subif the frame will be sent through
+ *
+ * Lookup next hop for given skb and start path discovery if no
+ * forwarding information is found.
+ *
+ * Returns: 0 if the next hop was found and -ENOENT if the frame was queued.
+ * skb is freeed here if no mpath could be allocated.
+ */
+int rtw_mesh_nexthop_resolve(_adapter *adapter,
+			struct xmit_frame *xframe)
+{
+	struct pkt_attrib *attrib = &xframe->attrib;
+	struct rtw_mesh_path *mpath;
+	struct xmit_frame *xframe_to_free = NULL;
+	u8 *target_addr = attrib->mda;
+	int err = 0;
+	int ret = _SUCCESS;
+
+	rtw_rcu_read_lock();
+	err = rtw_mesh_nexthop_lookup(adapter, target_addr, attrib->msa, attrib->ra);
+	if (!err)
+		goto endlookup;
+
+	/* no nexthop found, start resolving */
+	mpath = rtw_mesh_path_lookup(adapter, target_addr);
+	if (!mpath) {
+		mpath = rtw_mesh_path_add(adapter, target_addr);
+		if (IS_ERR(mpath)) {
+			xframe->pkt = NULL; /* free pkt outside */
+			rtw_mesh_path_discard_frame(adapter, xframe);
+			err = PTR_ERR(mpath);
+			ret = _FAIL;
+			goto endlookup;
+		}
+	}
+
+	if (!(mpath->flags & RTW_MESH_PATH_RESOLVING))
+		rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START);
+
+	enter_critical_bh(&mpath->frame_queue.lock);
+
+	if (mpath->frame_queue_len >= RTW_MESH_FRAME_QUEUE_LEN) {
+		xframe_to_free = LIST_CONTAINOR(get_next(get_list_head(&mpath->frame_queue)), struct xmit_frame, list);
+		rtw_list_delete(&(xframe_to_free->list));
+		mpath->frame_queue_len--;
+	}
+
+	rtw_list_insert_tail(&xframe->list, get_list_head(&mpath->frame_queue));
+	mpath->frame_queue_len++;
+
+	exit_critical_bh(&mpath->frame_queue.lock);
+
+	ret = RTW_RA_RESOLVING;
+	if (xframe_to_free)
+		rtw_mesh_path_discard_frame(adapter, xframe_to_free);
+
+endlookup:
+	rtw_rcu_read_unlock();
+	return ret;
+}
+
+/**
+ * rtw_mesh_nexthop_lookup - put the appropriate next hop on a mesh frame. Calling
+ * this function is considered "using" the associated mpath, so preempt a path
+ * refresh if this mpath expires soon.
+ *
+ * @skb: 802.11 frame to be sent
+ * @sdata: network subif the frame will be sent through
+ *
+ * Returns: 0 if the next hop was found. Nonzero otherwise.
+ */
+int rtw_mesh_nexthop_lookup(_adapter *adapter,
+	const u8 *mda, const u8 *msa, u8 *ra)
+{
+	struct rtw_mesh_path *mpath;
+	struct sta_info *next_hop;
+	const u8 *target_addr = mda;
+	int err = -ENOENT;
+
+	rtw_rcu_read_lock();
+	mpath = rtw_mesh_path_lookup(adapter, target_addr);
+
+	if (!mpath || !(mpath->flags & RTW_MESH_PATH_ACTIVE))
+		goto endlookup;
+
+	if (rtw_time_after(rtw_get_current_time(),
+		       mpath->exp_time -
+		       rtw_ms_to_systime(adapter->mesh_cfg.path_refresh_time)) &&
+	    _rtw_memcmp(adapter_mac_addr(adapter), msa, ETH_ALEN) == _TRUE &&
+	    !(mpath->flags & RTW_MESH_PATH_RESOLVING) &&
+	    !(mpath->flags & RTW_MESH_PATH_FIXED)) {
+		rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH);
+	}
+
+	next_hop = rtw_rcu_dereference(mpath->next_hop);
+	if (next_hop) {
+		_rtw_memcpy(ra, next_hop->cmn.mac_addr, ETH_ALEN);
+		err = 0;
+	}
+
+endlookup:
+	rtw_rcu_read_unlock();
+	return err;
+}
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+static bool rtw_mesh_data_bmc_to_uc(_adapter *adapter
+	, const u8 *da, const u8 *sa, const u8 *mda, const u8 *msa
+	, u8 ae_need, const u8 *ori_ta, u8 mfwd_ttl
+	, _list *b2u_list, u8 *b2u_num, u32 *b2u_mseq)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct xmit_priv *xmitpriv = &adapter->xmitpriv;
+	_irqL irqL;
+	_list *head, *list;
+	struct sta_info *sta;
+	char b2u_sta_id[NUM_STA];
+	u8 b2u_sta_num = 0;
+	bool bmc_need = _FALSE;
+	int i;
+
+	_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+	head = &stapriv->asoc_list;
+	list = get_next(head);
+
+	while ((rtw_end_of_queue_search(head, list)) == _FALSE) {
+		int stainfo_offset;
+
+		sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
+		list = get_next(list);
+	
+		stainfo_offset = rtw_stainfo_offset(stapriv, sta);
+		if (stainfo_offset_valid(stainfo_offset))
+			b2u_sta_id[b2u_sta_num++] = stainfo_offset;
+	}
+	_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+
+	if (!b2u_sta_num)
+		goto exit;
+
+	for (i = 0; i < b2u_sta_num; i++) {
+		struct xmit_frame *b2uframe;
+		struct pkt_attrib *attrib;
+
+		sta = rtw_get_stainfo_by_offset(stapriv, b2u_sta_id[i]);
+		if (!(sta->state & _FW_LINKED)
+			|| _rtw_memcmp(sta->cmn.mac_addr, msa, ETH_ALEN) == _TRUE
+			|| (ori_ta && _rtw_memcmp(sta->cmn.mac_addr, ori_ta, ETH_ALEN) == _TRUE)
+			|| is_broadcast_mac_addr(sta->cmn.mac_addr)
+			|| is_zero_mac_addr(sta->cmn.mac_addr))
+			continue;
+
+		b2uframe = rtw_alloc_xmitframe(xmitpriv);
+		if (!b2uframe) {
+			bmc_need = _TRUE;
+			break;
+		}
+
+		if ((*b2u_num)++ == 0 && !ori_ta) {
+			*b2u_mseq = (cpu_to_le32(adapter->mesh_info.mesh_seqnum));
+			adapter->mesh_info.mesh_seqnum++;
+		}
+
+		attrib = &b2uframe->attrib;
+
+		attrib->mb2u = 1;
+		attrib->mseq = *b2u_mseq;
+		attrib->mfwd_ttl = ori_ta ? mfwd_ttl : 0;
+		_rtw_memcpy(attrib->ra, sta->cmn.mac_addr, ETH_ALEN);
+		_rtw_memcpy(attrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
+		_rtw_memcpy(attrib->mda, mda, ETH_ALEN);
+		_rtw_memcpy(attrib->msa, msa, ETH_ALEN);
+		_rtw_memcpy(attrib->dst, da, ETH_ALEN);
+		_rtw_memcpy(attrib->src, sa, ETH_ALEN);
+		attrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
+
+		rtw_list_insert_tail(&b2uframe->list, b2u_list);
+	}
+
+exit:
+	return bmc_need;
+}
+
+void dump_mesh_b2u_flags(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+	RTW_PRINT_SEL(sel, "%4s %4s\n", "msrc", "mfwd");
+	RTW_PRINT_SEL(sel, "0x%02x 0x%02x\n", mcfg->b2u_flags_msrc, mcfg->b2u_flags_mfwd);
+}
+#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
+
+int rtw_mesh_addr_resolve(_adapter *adapter, struct xmit_frame *xframe, _pkt *pkt, _list *b2u_list)
+{
+	struct pkt_file pktfile;
+	struct ethhdr etherhdr;
+	struct pkt_attrib *attrib;
+	struct rtw_mesh_path *mpath = NULL, *mppath = NULL;
+	u8 is_da_mcast;
+	u8 ae_need;
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	bool bmc_need = _TRUE;
+	u8 b2u_num = 0;
+	u32 b2u_mseq = 0;
+#endif
+	int res = _SUCCESS;
+
+	_rtw_open_pktfile(pkt, &pktfile);
+	if (_rtw_pktfile_read(&pktfile, (u8 *)&etherhdr, ETH_HLEN) != ETH_HLEN) {
+		res = _FAIL;
+		goto exit;
+	}
+	
+	xframe->pkt = pkt;
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	_rtw_init_listhead(b2u_list);
+#endif
+
+	is_da_mcast = IS_MCAST(etherhdr.h_dest);
+	if (!is_da_mcast) {
+		struct sta_info *next_hop; 
+		bool mpp_lookup = 1;
+	
+		mpath = rtw_mesh_path_lookup(adapter, etherhdr.h_dest);
+		if (mpath) {
+			mpp_lookup = 0;
+			next_hop = rtw_rcu_dereference(mpath->next_hop);
+			if (!next_hop
+				|| !(mpath->flags & (RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVING))
+			) {
+				/* mpath is not valid, search mppath */
+				mpp_lookup = 1;
+			}
+		}
+
+		if (mpp_lookup) {
+			mppath = rtw_mpp_path_lookup(adapter, etherhdr.h_dest);
+			if (mppath)
+				mppath->exp_time = rtw_get_current_time();
+		}
+
+		if (mppath && mpath)
+			rtw_mesh_path_del(adapter, mpath->dst);
+
+		ae_need = _rtw_memcmp(adapter_mac_addr(adapter), etherhdr.h_source, ETH_ALEN) == _FALSE
+			|| (mppath && _rtw_memcmp(mppath->mpp, etherhdr.h_dest, ETH_ALEN) == _FALSE);
+	} else {
+		ae_need = _rtw_memcmp(adapter_mac_addr(adapter), etherhdr.h_source, ETH_ALEN) == _FALSE;
+
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (rtw_msrc_b2u_policy_chk(adapter->mesh_cfg.b2u_flags_msrc, etherhdr.h_dest)) {
+			bmc_need = rtw_mesh_data_bmc_to_uc(adapter
+				, etherhdr.h_dest, etherhdr.h_source
+				, etherhdr.h_dest, adapter_mac_addr(adapter), ae_need, NULL, 0
+				, b2u_list, &b2u_num, &b2u_mseq);
+			if (bmc_need == _FALSE) {
+				res = RTW_BMC_NO_NEED;
+				goto exit;
+			}
+		}
+		#endif
+	}
+
+	attrib = &xframe->attrib;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (b2u_num) {
+		attrib->mb2u = 1;
+		attrib->mseq = b2u_mseq;
+	} else
+		attrib->mb2u = 0;
+#endif
+
+	attrib->mfwd_ttl = 0;
+	_rtw_memcpy(attrib->dst, etherhdr.h_dest, ETH_ALEN);
+	_rtw_memcpy(attrib->src, etherhdr.h_source, ETH_ALEN);
+	_rtw_memcpy(attrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
+
+	if (is_da_mcast) {
+		attrib->mesh_frame_mode = ae_need ? MESH_BMCAST_PX_DATA : MESH_BMCAST_DATA;
+		_rtw_memcpy(attrib->ra, attrib->dst, ETH_ALEN);
+		_rtw_memcpy(attrib->msa, adapter_mac_addr(adapter), ETH_ALEN);
+	} else {
+		attrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
+		_rtw_memcpy(attrib->mda, (mppath && ae_need) ? mppath->mpp : attrib->dst, ETH_ALEN);
+		_rtw_memcpy(attrib->msa, adapter_mac_addr(adapter), ETH_ALEN);
+		/* RA needs to be resolved */
+		res = rtw_mesh_nexthop_resolve(adapter, xframe);
+	}
+
+exit:
+	return res;
+}
+
+s8 rtw_mesh_tx_set_whdr_mctrl_len(u8 mesh_frame_mode, struct pkt_attrib *attrib)
+{
+	u8 ret = 0;
+	switch (mesh_frame_mode) {
+	case MESH_UCAST_DATA:
+		attrib->hdrlen = WLAN_HDR_A4_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN. no ext addr. */
+		attrib->meshctrl_len = 6;
+		break;
+	case MESH_BMCAST_DATA:
+		attrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN. no ext addr. */
+		attrib->meshctrl_len = 6;
+		break;
+	case MESH_UCAST_PX_DATA:
+		attrib->hdrlen = WLAN_HDR_A4_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN + extaddr1 + extaddr2. */
+		attrib->meshctrl_len = 18;
+		break;
+	case MESH_BMCAST_PX_DATA:
+		attrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
+		/* mesh flag + mesh TTL + Mesh SN + extaddr1 */
+		attrib->meshctrl_len = 12;
+		break;
+	default:
+		RTW_WARN("Invalid mesh frame mode:%u\n", mesh_frame_mode);
+		ret = -1;
+		break;
+	}				
+
+	return ret;
+}
+
+void rtw_mesh_tx_build_mctrl(_adapter *adapter, struct pkt_attrib *attrib, u8 *buf)
+{
+	struct rtw_ieee80211s_hdr *mctrl = (struct rtw_ieee80211s_hdr *)buf;
+
+	_rtw_memset(mctrl, 0, XATTRIB_GET_MCTRL_LEN(attrib));
+
+	if (attrib->mfwd_ttl
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		|| attrib->mb2u
+		#endif
+	) {
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (!attrib->mfwd_ttl)
+			mctrl->ttl = adapter->mesh_cfg.dot11MeshTTL;
+		else
+		#endif
+			mctrl->ttl = attrib->mfwd_ttl;
+
+		mctrl->seqnum = (cpu_to_le32(attrib->mseq));
+	} else {
+		mctrl->ttl = adapter->mesh_cfg.dot11MeshTTL;
+		mctrl->seqnum = (cpu_to_le32(adapter->mesh_info.mesh_seqnum));
+		adapter->mesh_info.mesh_seqnum++;
+	}
+
+	switch (attrib->mesh_frame_mode){
+	case MESH_UCAST_DATA:
+	case MESH_BMCAST_DATA:
+		break;
+	case MESH_UCAST_PX_DATA:
+		mctrl->flags |= MESH_FLAGS_AE_A5_A6;
+		_rtw_memcpy(mctrl->eaddr1, attrib->dst, ETH_ALEN);
+		_rtw_memcpy(mctrl->eaddr2, attrib->src, ETH_ALEN);
+		break;
+	case MESH_BMCAST_PX_DATA:
+		mctrl->flags |= MESH_FLAGS_AE_A4;
+		_rtw_memcpy(mctrl->eaddr1, attrib->src, ETH_ALEN);
+		break;
+	case MESH_MHOP_UCAST_ACT:
+		/* TBD */
+		break;
+	case MESH_MHOP_BMCAST_ACT:
+		/* TBD */
+		break;
+	default:
+		break;
+	}
+}
+
+u8 rtw_mesh_tx_build_whdr(_adapter *adapter, struct pkt_attrib *attrib
+	, u16 *fctrl, struct rtw_ieee80211_hdr *whdr)
+{
+	switch (attrib->mesh_frame_mode) {
+	case MESH_UCAST_DATA:		/* 1, 1, RA, TA, mDA(=DA),	mSA(=SA) */
+	case MESH_UCAST_PX_DATA:	/* 1, 1, RA, TA, mDA,		mSA,		[DA, SA] */
+		SetToDs(fctrl);
+		SetFrDs(fctrl);
+		_rtw_memcpy(whdr->addr1, attrib->ra, ETH_ALEN);
+		_rtw_memcpy(whdr->addr2, attrib->ta, ETH_ALEN);
+		_rtw_memcpy(whdr->addr3, attrib->mda, ETH_ALEN);
+		_rtw_memcpy(whdr->addr4, attrib->msa, ETH_ALEN);
+		break;
+	case MESH_BMCAST_DATA:		/* 0, 1, RA(DA), TA, mSA(SA) */
+	case MESH_BMCAST_PX_DATA:	/* 0, 1, RA(DA), TA, mSA,		[SA] */
+		SetFrDs(fctrl);
+		_rtw_memcpy(whdr->addr1, attrib->ra, ETH_ALEN);
+		_rtw_memcpy(whdr->addr2, attrib->ta, ETH_ALEN);
+		_rtw_memcpy(whdr->addr3, attrib->msa, ETH_ALEN);
+		break;
+	case MESH_MHOP_UCAST_ACT:
+		/* TBD */
+		RTW_INFO("MESH_MHOP_UCAST_ACT\n");
+		break;
+	case MESH_MHOP_BMCAST_ACT:
+		/* TBD */
+		RTW_INFO("MESH_MHOP_BMCAST_ACT\n");
+		break;
+	default:
+		RTW_WARN("Invalid mesh frame mode\n");
+		break;
+	}
+	
+	return 0;
+}
+
+int rtw_mesh_rx_data_validate_hdr(_adapter *adapter, union recv_frame *rframe, struct sta_info **sta)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	u8 *whdr = get_recvframe_data(rframe);
+	u8 is_ra_bmc = 0;
+	u8 a4_shift = 0;
+	u8 ps;
+	u8 *qc;
+	u8 mps_mode = RTW_MESH_PS_UNKNOWN;
+	sint ret = _FAIL;
+
+	if (!(MLME_STATE(adapter) & WIFI_ASOC_STATE))
+		goto exit;
+
+	if (!rattrib->qos)
+		goto exit;
+
+	switch (rattrib->to_fr_ds) {
+	case 1:
+		if (!IS_MCAST(GetAddr1Ptr(whdr)))
+			goto exit;
+		*sta = rtw_get_stainfo(stapriv, get_addr2_ptr(whdr));
+		if (*sta == NULL) {
+			ret = _SUCCESS; /* return _SUCCESS to drop at sta checking */
+			goto exit;
+		}
+		_rtw_memcpy(rattrib->ra, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->ta, get_addr2_ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->mda, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->msa, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
+		_rtw_memcpy(rattrib->dst, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->src, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
+		_rtw_memcpy(rattrib->bssid, get_addr2_ptr(whdr), ETH_ALEN);
+		is_ra_bmc = 1;
+		break;
+	case 3:
+		if (IS_MCAST(GetAddr1Ptr(whdr)))
+			goto exit;
+		*sta = rtw_get_stainfo(stapriv, get_addr2_ptr(whdr));
+		if (*sta == NULL) {
+			ret = _SUCCESS; /* return _SUCCESS to drop at sta checking */
+			goto exit;
+		}
+		_rtw_memcpy(rattrib->ra, GetAddr1Ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->ta, get_addr2_ptr(whdr), ETH_ALEN);
+		_rtw_memcpy(rattrib->mda, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
+		_rtw_memcpy(rattrib->msa, GetAddr4Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
+		_rtw_memcpy(rattrib->dst, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
+		_rtw_memcpy(rattrib->src, GetAddr4Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
+		_rtw_memcpy(rattrib->bssid, get_addr2_ptr(whdr), ETH_ALEN);
+		a4_shift = ETH_ALEN;
+		break;
+	default:
+		goto exit;
+	}
+
+	qc = whdr + WLAN_HDR_A3_LEN + a4_shift;
+	ps = GetPwrMgt(whdr);
+	mps_mode = ps ? (is_ra_bmc || (get_mps_lv(qc)) ? RTW_MESH_PS_DSLEEP : RTW_MESH_PS_LSLEEP) : RTW_MESH_PS_ACTIVE;
+
+	if (ps) {
+		if (!((*sta)->state & WIFI_SLEEP_STATE))
+			stop_sta_xmit(adapter, *sta);
+	} else {
+		if ((*sta)->state & WIFI_SLEEP_STATE)
+			wakeup_sta_to_xmit(adapter, *sta);
+	}
+
+	if (is_ra_bmc)
+		(*sta)->nonpeer_mps = mps_mode;
+	else {
+		(*sta)->peer_mps = mps_mode;
+		if (mps_mode != RTW_MESH_PS_ACTIVE && (*sta)->nonpeer_mps == RTW_MESH_PS_ACTIVE)
+			(*sta)->nonpeer_mps = RTW_MESH_PS_DSLEEP;
+	}
+
+	if (get_frame_sub_type(whdr) & BIT(6)) {
+		/* No data, will not indicate to upper layer, temporily count it here */
+		count_rx_stats(adapter, rframe, *sta);
+		ret = RTW_RX_HANDLED;
+		goto exit;
+	}
+
+	rattrib->mesh_ctrl_present = get_mctrl_present(qc) ? 1 : 0;
+	if (!rattrib->mesh_ctrl_present)
+		goto exit;
+
+	ret = _SUCCESS;
+
+exit:
+	return ret;
+}
+
+int rtw_mesh_rx_data_validate_mctrl(_adapter *adapter, union recv_frame *rframe
+	, const struct rtw_ieee80211s_hdr *mctrl, const u8 *mda, const u8 *msa
+	, u8 *mctrl_len
+	, const u8 **da, const u8 **sa)
+{
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	u8 mlen;
+	u8 ae;
+	int ret = _SUCCESS;
+
+	ae = mctrl->flags & MESH_FLAGS_AE;
+	mlen = ae_to_mesh_ctrl_len[ae];
+	switch (rattrib->to_fr_ds) {
+	case 1:
+		*da = mda;
+		if (ae == MESH_FLAGS_AE_A4)
+			*sa = mctrl->eaddr1;
+		else if (ae == 0)
+			*sa = msa;
+		else
+			ret = _FAIL;
+		break;
+	case 3:
+		if (ae == MESH_FLAGS_AE_A5_A6) {
+			*da = mctrl->eaddr1;
+			*sa = mctrl->eaddr2;
+		} else if (ae == 0) {
+			*da = mda;
+			*sa = msa;
+		} else
+			ret = _FAIL;
+		break;
+	default:
+		ret = _FAIL;
+	}
+
+	if (ret == _FAIL) {
+		#ifdef DBG_RX_DROP_FRAME
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" invalid tfDS:%u AE:%u combination ra="MAC_FMT" ta="MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), rattrib->to_fr_ds, ae, MAC_ARG(rattrib->ra), MAC_ARG(rattrib->ta));
+		#endif
+		*mctrl_len = 0;
+	} else
+		*mctrl_len = mlen;
+
+	return ret;	
+}
+
+inline int rtw_mesh_rx_validate_mctrl_non_amsdu(_adapter *adapter, union recv_frame *rframe)
+{
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	const u8 *da, *sa;
+	int ret;
+
+	ret = rtw_mesh_rx_data_validate_mctrl(adapter, rframe
+			, (struct rtw_ieee80211s_hdr *)(get_recvframe_data(rframe) + rattrib->hdrlen + rattrib->iv_len)
+			, rattrib->mda, rattrib->msa
+			, &rattrib->mesh_ctrl_len
+			, &da, &sa);
+
+	if (ret == _SUCCESS) {
+		_rtw_memcpy(rattrib->dst, da, ETH_ALEN);
+		_rtw_memcpy(rattrib->src, sa, ETH_ALEN);
+	}
+
+	return ret;
+}
+
+/**
+ * rtw_mesh_rx_nexthop_resolve - lookup next hop; conditionally start path discovery
+ *
+ * @skb: 802.11 frame to be sent
+ * @sdata: network subif the frame will be sent through
+ *
+ * Lookup next hop for given skb and start path discovery if no
+ * forwarding information is found.
+ *
+ * Returns: 0 if the next hop was found and -ENOENT if the frame was queued.
+ * skb is freeed here if no mpath could be allocated.
+ */
+static int rtw_mesh_rx_nexthop_resolve(_adapter *adapter,
+	const u8 *mda, const u8 *msa, u8 *ra)
+{
+	struct rtw_mesh_path *mpath;
+	struct xmit_frame *xframe_to_free = NULL;
+	int err = 0;
+	int ret = _SUCCESS;
+
+	rtw_rcu_read_lock();
+	err = rtw_mesh_nexthop_lookup(adapter, mda, msa, ra);
+	if (!err)
+		goto endlookup;
+
+	/* no nexthop found, start resolving */
+	mpath = rtw_mesh_path_lookup(adapter, mda);
+	if (!mpath) {
+		mpath = rtw_mesh_path_add(adapter, mda);
+		if (IS_ERR(mpath)) {
+			err = PTR_ERR(mpath);
+			ret = _FAIL;
+			goto endlookup;
+		}
+	}
+
+	if (!(mpath->flags & RTW_MESH_PATH_RESOLVING))
+		rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START);
+
+	ret = _FAIL;
+
+endlookup:
+	rtw_rcu_read_unlock();
+	return ret;
+}
+
+#define RTW_MESH_DECACHE_BMC 1
+#define RTW_MESH_DECACHE_UC 0
+
+#define RTW_MESH_FORWARD_MDA_SELF_COND 0
+#define DBG_RTW_MESH_FORWARD_MDA_SELF_COND 0
+int rtw_mesh_rx_msdu_act_check(union recv_frame *rframe
+	, const u8 *mda, const u8 *msa
+	, const u8 *da, const u8 *sa
+	, struct rtw_ieee80211s_hdr *mctrl
+	, struct xmit_frame **fwd_frame, _list *b2u_list)
+{
+	_adapter *adapter = rframe->u.hdr.adapter;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
+	struct rtw_mesh_path *mppath;
+	u8 is_mda_bmc = IS_MCAST(mda); 
+	u8 is_mda_self = !is_mda_bmc && _rtw_memcmp(mda, adapter_mac_addr(adapter), ETH_ALEN);
+	struct xmit_frame *xframe;
+	struct pkt_attrib *xattrib;
+	u8 fwd_ra[ETH_ALEN] = {0};
+	u8 fwd_mpp[ETH_ALEN] = {0}; /* forward to other gate */
+	u32 fwd_mseq;
+	int act = 0;
+	u8 ae_need;
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	bool bmc_need = _TRUE;
+	u8 b2u_num = 0;
+#endif
+
+	/* fwd info lifetime update */
+	#if 0
+	if (!is_mda_self)
+		mDA(A3) fwinfo.lifetime
+	mSA(A4) fwinfo.lifetime
+	Precursor-to-mDA(A2) fwinfo.lifetime
+	#endif
+
+	/* update/create pxoxy info for SA, mSA */
+	if ((mctrl->flags & MESH_FLAGS_AE)
+		&& sa != msa && _rtw_memcmp(sa, msa, ETH_ALEN) == _FALSE
+	) {
+		const u8 *proxied_addr = sa;
+		const u8 *mpp_addr = msa;
+
+		rtw_rcu_read_lock();
+		mppath = rtw_mpp_path_lookup(adapter, proxied_addr);
+		if (!mppath)
+			rtw_mpp_path_add(adapter, proxied_addr, mpp_addr);
+		else {
+			enter_critical_bh(&mppath->state_lock);
+			if (_rtw_memcmp(mppath->mpp, mpp_addr, ETH_ALEN) == _FALSE)
+				_rtw_memcpy(mppath->mpp, mpp_addr, ETH_ALEN);
+			mppath->exp_time = rtw_get_current_time();
+			exit_critical_bh(&mppath->state_lock);
+		}
+		rtw_rcu_read_unlock();
+	}
+
+	/* mSA is self, need no further process */
+	if (_rtw_memcmp(msa, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
+		goto exit;
+
+	fwd_mseq = le32_to_cpu(mctrl->seqnum);
+
+	/* check duplicate MSDU from mSA */
+	if (((RTW_MESH_DECACHE_BMC && is_mda_bmc)
+			|| (RTW_MESH_DECACHE_UC && !is_mda_bmc))
+		&& rtw_mesh_decache(adapter, msa, fwd_mseq)
+	) {
+		minfo->mshstats.dropped_frames_duplicate++;
+		goto exit;
+	}
+
+	if (is_mda_bmc) {
+		/* mDA is bmc addr */
+		act |= RTW_RX_MSDU_ACT_INDICATE;
+		if (!mcfg->dot11MeshForwarding)
+			goto exit;
+		goto fwd_chk;
+
+	} else if (!is_mda_self) {
+		/* mDA is unicast but not self */
+		if (!mcfg->dot11MeshForwarding) {
+			rtw_mesh_path_error_tx(adapter
+				, adapter->mesh_cfg.element_ttl
+				, mda, 0
+				, WLAN_REASON_MESH_PATH_NOFORWARD
+				, rattrib->ta
+			);
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" mDA("MAC_FMT") not self, !dot11MeshForwarding\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(mda));
+			#endif
+			goto exit;
+		}
+
+		if (rtw_mesh_rx_nexthop_resolve(adapter, mda, msa, fwd_ra) != _SUCCESS) {
+			/* mDA is unknown */
+			rtw_mesh_path_error_tx(adapter
+				, adapter->mesh_cfg.element_ttl
+				, mda, 0
+				, WLAN_REASON_MESH_PATH_NOFORWARD
+				, rattrib->ta
+			);
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" mDA("MAC_FMT") unknown\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(mda));
+			#endif
+			minfo->mshstats.dropped_frames_no_route++;
+			goto exit;
+
+		} else {
+			/* mDA is known in fwd info */
+			#if 0
+			if	(TA is not in precursors)
+				goto exit;
+			#endif
+			goto fwd_chk;
+		}
+
+	} else {
+		/* mDA is self */
+		#if RTW_MESH_FORWARD_MDA_SELF_COND
+		if (da == mda
+			|| _rtw_memcmp(da, adapter_mac_addr(adapter), ETH_ALEN)
+		) {
+			/* DA is self, indicate */
+			act |= RTW_RX_MSDU_ACT_INDICATE;
+			goto exit;
+		}
+
+		if (rtw_get_iface_by_macddr(adapter, da)) {
+			/* DA is buddy, indicate */
+			act |= RTW_RX_MSDU_ACT_INDICATE;
+			#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+			RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is buddy("ADPT_FMT")\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(da), ADPT_ARG(rtw_get_iface_by_macddr(adapter, da)));
+			#endif
+			goto exit;
+		}
+
+		/* DA is not self or buddy */
+		if (rtw_mesh_nexthop_lookup(adapter, da, msa, fwd_ra) == 0) {
+			/* DA is known in fwd info */
+			if (!mcfg->dot11MeshForwarding) {
+				/* path error to? */
+				#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+				RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") not self, !dot11MeshForwarding\n"
+					, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
+				#endif
+				goto exit;
+			}
+			mda = da;
+			#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+			RTW_INFO(FUNC_ADPT_FMT" fwd to DA("MAC_FMT"), fwd_RA("MAC_FMT")\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(fwd_ra));
+			#endif
+			goto fwd_chk;
+		}
+
+		rtw_rcu_read_lock();
+		mppath = rtw_mpp_path_lookup(adapter, da);
+		if (mppath) {
+			if (_rtw_memcmp(mppath->mpp, adapter_mac_addr(adapter), ETH_ALEN) == _FALSE) {
+				/* DA is proxied by others */
+				if (!mcfg->dot11MeshForwarding) {
+					/* path error to? */
+					#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+					RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), !dot11MeshForwarding\n"
+						, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp));
+					#endif
+					rtw_rcu_read_unlock();
+					goto exit;
+				}
+				_rtw_memcpy(fwd_mpp, mppath->mpp, ETH_ALEN);
+				mda = fwd_mpp;
+				msa = adapter_mac_addr(adapter);
+				rtw_rcu_read_unlock();
+
+				/* resolve RA */
+				if (rtw_mesh_nexthop_lookup(adapter, mda, msa, fwd_ra) != 0) {
+					minfo->mshstats.dropped_frames_no_route++;
+					#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+					RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), RA resolve fail\n"
+						, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp));
+					#endif
+					goto exit;
+				}
+				#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+				RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), fwd_RA("MAC_FMT")\n"
+					, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp), MAC_ARG(fwd_ra));
+				#endif
+				goto fwd_chk; /*  forward to other gate */
+			} else {
+				#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+				RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by self\n"
+					, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
+				#endif
+			}
+		}
+		rtw_rcu_read_unlock();
+
+		if (!mppath) {
+			#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
+			RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") unknown\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
+			#endif
+			/* DA is unknown */
+			#if 0 /* TODO: flags with AE bit */
+			rtw_mesh_path_error_tx(adapter
+				, adapter->mesh_cfg.element_ttl
+				, mda, adapter->mesh_info.last_sn_update
+				, WLAN_REASON_MESH_PATH_NOPROXY
+				, msa
+			);
+			#endif
+		}
+
+		/*
+		* indicate to DS for both cases:
+		* 1.) DA is proxied by self
+		* 2.) DA is unknown
+		*/
+		#endif /* RTW_MESH_FORWARD_MDA_SELF_COND */
+		act |= RTW_RX_MSDU_ACT_INDICATE;
+		goto exit;
+	}
+
+fwd_chk:
+
+	if (adapter->stapriv.asoc_list_cnt <= 1)
+		goto exit;
+
+	if (mctrl->ttl == 1) {
+		minfo->mshstats.dropped_frames_ttl++;
+		if (!act) {
+			#ifdef DBG_RX_DROP_FRAME
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" ttl reaches 0, not forwarding\n"
+				, FUNC_ADPT_ARG(adapter));
+			#endif
+		}
+		goto exit;
+	}
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	_rtw_init_listhead(b2u_list);
+#endif
+
+	ae_need = _rtw_memcmp(da , mda, ETH_ALEN) == _FALSE
+		|| _rtw_memcmp(sa , msa, ETH_ALEN) == _FALSE;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (is_mda_bmc
+		&& rtw_mfwd_b2u_policy_chk(mcfg->b2u_flags_mfwd, mda, rattrib->to_fr_ds == 3)
+	) {
+		bmc_need = rtw_mesh_data_bmc_to_uc(adapter
+			, da, sa, mda, msa, ae_need, rframe->u.hdr.psta->cmn.mac_addr, mctrl->ttl - 1
+			, b2u_list, &b2u_num, &fwd_mseq);
+	}
+
+	if (bmc_need == _TRUE)
+#endif
+	{
+		xframe = rtw_alloc_xmitframe(&adapter->xmitpriv);
+		if (!xframe) {
+			#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME "FUNC_ADPT_FMT" rtw_alloc_xmitframe fail\n"
+				, FUNC_ADPT_ARG(adapter));
+			#endif
+			goto exit;
+		}
+
+		xattrib = &xframe->attrib;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (b2u_num)
+			xattrib->mb2u = 1;
+		else
+			xattrib->mb2u = 0;
+#endif
+		xattrib->mfwd_ttl = mctrl->ttl - 1;
+		xattrib->mseq = fwd_mseq;
+		_rtw_memcpy(xattrib->dst, da, ETH_ALEN);
+		_rtw_memcpy(xattrib->src, sa, ETH_ALEN);
+		_rtw_memcpy(xattrib->mda, mda, ETH_ALEN);
+		_rtw_memcpy(xattrib->msa, msa, ETH_ALEN);
+		_rtw_memcpy(xattrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
+
+		if (is_mda_bmc) {
+			xattrib->mesh_frame_mode = ae_need ? MESH_BMCAST_PX_DATA : MESH_BMCAST_DATA;
+			_rtw_memcpy(xattrib->ra, mda, ETH_ALEN);
+		} else {
+			xattrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
+			_rtw_memcpy(xattrib->ra, fwd_ra, ETH_ALEN);
+		}
+
+		*fwd_frame = xframe;
+	}
+
+	act |= RTW_RX_MSDU_ACT_FORWARD;
+	if (is_mda_bmc)
+		minfo->mshstats.fwded_mcast++;
+	else
+		minfo->mshstats.fwded_unicast++;
+	minfo->mshstats.fwded_frames++;
+
+exit:
+	return act;
+}
+
+void dump_mesh_stats(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_stats *stats = &minfo->mshstats;
+
+	RTW_PRINT_SEL(sel, "fwd_bmc:%u\n", stats->fwded_mcast);
+	RTW_PRINT_SEL(sel, "fwd_uc:%u\n", stats->fwded_unicast);
+
+	RTW_PRINT_SEL(sel, "drop_ttl:%u\n", stats->dropped_frames_ttl);
+	RTW_PRINT_SEL(sel, "drop_no_route:%u\n", stats->dropped_frames_no_route);
+	RTW_PRINT_SEL(sel, "drop_congestion:%u\n", stats->dropped_frames_congestion);
+	RTW_PRINT_SEL(sel, "drop_dup:%u\n", stats->dropped_frames_duplicate);
+
+	RTW_PRINT_SEL(sel, "mrc_del_qlen:%u\n", stats->mrc_del_qlen);
+}
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh.h
new file mode 100644
index 000000000000..4554f22f83b8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh.h
@@ -0,0 +1,535 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_H_
+#define __RTW_MESH_H_
+
+#ifndef CONFIG_AP_MODE
+	#error "CONFIG_RTW_MESH can't be enabled when CONFIG_AP_MODE is not defined\n"
+#endif
+
+#define RTW_MESH_TTL				31
+#define RTW_MESH_PERR_MIN_INT			100
+#define RTW_MESH_DEFAULT_ELEMENT_TTL		31
+#define RTW_MESH_RANN_INTERVAL			5000
+#define RTW_MESH_PATH_TO_ROOT_TIMEOUT		6000
+#define RTW_MESH_DIAM_TRAVERSAL_TIME		50
+#define RTW_MESH_PATH_TIMEOUT			5000
+#define RTW_MESH_PREQ_MIN_INT			10
+#define RTW_MESH_MAX_PREQ_RETRIES		4
+#define RTW_MESH_MIN_DISCOVERY_TIMEOUT 		(2 * RTW_MESH_DIAM_TRAVERSAL_TIME)
+#define RTW_MESH_ROOT_CONFIRMATION_INTERVAL	2000
+#define RTW_MESH_PATH_REFRESH_TIME		1000
+#define RTW_MESH_ROOT_INTERVAL			5000
+
+#define RTW_MESH_SANE_METRIC_DELTA		100
+#define RTW_MESH_MAX_ROOT_ADD_CHK_CNT		2
+
+#define RTW_MESH_PLINK_UNKNOWN	0
+#define RTW_MESH_PLINK_LISTEN	1
+#define RTW_MESH_PLINK_OPN_SNT	2
+#define RTW_MESH_PLINK_OPN_RCVD 3
+#define RTW_MESH_PLINK_CNF_RCVD 4
+#define RTW_MESH_PLINK_ESTAB	5
+#define RTW_MESH_PLINK_HOLDING	6
+#define RTW_MESH_PLINK_BLOCKED	7
+
+extern const char *_rtw_mesh_plink_str[];
+#define rtw_mesh_plink_str(s) ((s <= RTW_MESH_PLINK_BLOCKED) ? _rtw_mesh_plink_str[s] : _rtw_mesh_plink_str[RTW_MESH_PLINK_UNKNOWN])
+
+#define RTW_MESH_PS_UNKNOWN 0
+#define RTW_MESH_PS_ACTIVE 1
+#define RTW_MESH_PS_LSLEEP 2
+#define RTW_MESH_PS_DSLEEP 3
+
+extern const char *_rtw_mesh_ps_str[];
+#define rtw_mesh_ps_str(mps) ((mps <= RTW_MESH_PS_DSLEEP) ? _rtw_mesh_ps_str[mps] : _rtw_mesh_ps_str[RTW_MESH_PS_UNKNOWN])
+
+#define GET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(_iec)		LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 0, 0, 8)
+#define GET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(_iec)		LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 1, 0, 8)
+#define GET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(_iec)	LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 2, 0, 8)
+#define GET_MESH_CONF_ELE_SYNC_METHOD_ID(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 3, 0, 8)
+#define GET_MESH_CONF_ELE_AUTH_PROTO_ID(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 4, 0, 8)
+
+#define GET_MESH_CONF_ELE_MESH_FORMATION(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 0, 8)
+#define GET_MESH_CONF_ELE_CTO_MGATE(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 0, 1)
+#define GET_MESH_CONF_ELE_NUM_OF_PEERINGS(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 1, 6)
+#define GET_MESH_CONF_ELE_CTO_AS(_iec)					LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 7, 1)
+
+#define GET_MESH_CONF_ELE_MESH_CAP(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 0, 8)
+#define GET_MESH_CONF_ELE_ACCEPT_PEERINGS(_iec)			LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 0, 1)
+#define GET_MESH_CONF_ELE_MCCA_SUP(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 1, 1)
+#define GET_MESH_CONF_ELE_MCCA_EN(_iec)					LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 2, 1)
+#define GET_MESH_CONF_ELE_FORWARDING(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 3, 1)
+#define GET_MESH_CONF_ELE_MBCA_EN(_iec)					LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 4, 1)
+#define GET_MESH_CONF_ELE_TBTT_ADJ(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 5, 1)
+#define GET_MESH_CONF_ELE_PS_LEVEL(_iec)				LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 6, 1)
+
+#define SET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 0, 0, 8, _val)
+#define SET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(_iec, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 1, 0, 8, _val)
+#define SET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(_iec, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 2, 0, 8, _val)
+#define SET_MESH_CONF_ELE_SYNC_METHOD_ID(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 3, 0, 8, _val)
+#define SET_MESH_CONF_ELE_AUTH_PROTO_ID(_iec, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 4, 0, 8, _val)
+
+#define SET_MESH_CONF_ELE_CTO_MGATE(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 0, 1, _val)
+#define SET_MESH_CONF_ELE_NUM_OF_PEERINGS(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 1, 6, _val)
+#define SET_MESH_CONF_ELE_CTO_AS(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 7, 1, _val)
+
+#define SET_MESH_CONF_ELE_ACCEPT_PEERINGS(_iec, _val)		SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 0, 1, _val)
+#define SET_MESH_CONF_ELE_MCCA_SUP(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 1, 1, _val)
+#define SET_MESH_CONF_ELE_MCCA_EN(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 2, 1, _val)
+#define SET_MESH_CONF_ELE_FORWARDING(_iec, _val)			SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 3, 1, _val)
+#define SET_MESH_CONF_ELE_MBCA_EN(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 4, 1, _val)
+#define SET_MESH_CONF_ELE_TBTT_ADJ(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 5, 1, _val)
+#define SET_MESH_CONF_ELE_PS_LEVEL(_iec, _val)				SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 6, 1, _val)
+
+/* Mesh flags */
+#define MESH_FLAGS_AE		0x3 /* mask */
+#define MESH_FLAGS_AE_A4 	0x1
+#define MESH_FLAGS_AE_A5_A6	0x2
+
+/* Max number of paths */
+#define RTW_MESH_MAX_PATHS 1024
+
+#define RTW_PREQ_Q_F_START	0x1
+#define RTW_PREQ_Q_F_REFRESH	0x2
+#define RTW_PREQ_Q_F_CHK	0x4
+#define RTW_PREQ_Q_F_PEER_AKA	0x8
+struct rtw_mesh_preq_queue {
+	_list list;
+	u8 dst[ETH_ALEN];
+	u8 flags;
+};
+
+extern const u8 ae_to_mesh_ctrl_len[];
+
+enum mesh_frame_type {
+	MESH_UCAST_DATA		= 0x0,
+	MESH_BMCAST_DATA	= 0x1,
+	MESH_UCAST_PX_DATA	= 0x2,
+	MESH_BMCAST_PX_DATA	= 0x3,
+	MESH_MHOP_UCAST_ACT	= 0x4,
+	MESH_MHOP_BMCAST_ACT	= 0x5,
+};
+
+enum mpath_sel_frame_type {
+	MPATH_PREQ = 0,
+	MPATH_PREP,
+	MPATH_PERR,
+	MPATH_RANN
+};
+
+/**
+ * enum rtw_mesh_deferred_task_flags - mesh deferred tasks
+ *
+ *
+ *
+ * @RTW_MESH_WORK_HOUSEKEEPING: run the periodic mesh housekeeping tasks
+ * @RTW_MESH_WORK_ROOT: the mesh root station needs to send a frame
+ * @RTW_MESH_WORK_DRIFT_ADJUST: time to compensate for clock drift relative to other
+ * mesh nodes
+ * @RTW_MESH_WORK_MBSS_CHANGED: rebuild beacon and notify driver of BSS changes
+ */
+enum rtw_mesh_deferred_task_flags {
+	RTW_MESH_WORK_HOUSEKEEPING,
+	RTW_MESH_WORK_ROOT,
+	RTW_MESH_WORK_DRIFT_ADJUST,
+	RTW_MESH_WORK_MBSS_CHANGED,
+};
+
+#define RTW_MESH_MAX_PEER_CANDIDATES 15 /* aid consideration */
+#define RTW_MESH_MAX_PEER_LINKS 8
+#define RTW_MESH_PEER_LINK_TIMEOUT 20
+
+#define RTW_MESH_PEER_CONF_DISABLED 0 /* special time value means no confirmation ongoing */
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+#define IS_PEER_CONF_DISABLED(plink) ((plink)->peer_conf_end_time == RTW_MESH_PEER_CONF_DISABLED)
+#define IS_PEER_CONF_TIMEOUT(plink)(!IS_PEER_CONF_DISABLED(plink) && rtw_time_after(rtw_get_current_time(), (plink)->peer_conf_end_time))
+#define SET_PEER_CONF_DISABLED(plink) (plink)->peer_conf_end_time = RTW_MESH_PEER_CONF_DISABLED
+#define SET_PEER_CONF_END_TIME(plink, timeout_ms) \
+	do { \
+		(plink)->peer_conf_end_time = rtw_get_current_time() + rtw_ms_to_systime(timeout_ms); \
+		if ((plink)->peer_conf_end_time == RTW_MESH_PEER_CONF_DISABLED) \
+			(plink)->peer_conf_end_time++; \
+	} while (0)
+#else
+#define IS_PEER_CONF_DISABLED(plink) 1
+#define IS_PEER_CONF_TIMEOUT(plink) 0
+#define SET_PEER_CONF_DISABLED(plink) do {} while (0)
+#define SET_PEER_CONF_END_TIME(plink, timeout_ms) do {} while (0)
+#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
+
+#define RTW_MESH_CTO_MGATE_CONF_DISABLED 0 /* special time value means no confirmation ongoing */
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+#define IS_CTO_MGATE_CONF_DISABLED(plink) ((plink)->cto_mgate_conf_end_time == RTW_MESH_CTO_MGATE_CONF_DISABLED)
+#define IS_CTO_MGATE_CONF_TIMEOUT(plink)(!IS_CTO_MGATE_CONF_DISABLED(plink) && rtw_time_after(rtw_get_current_time(), (plink)->cto_mgate_conf_end_time))
+#define SET_CTO_MGATE_CONF_DISABLED(plink) (plink)->cto_mgate_conf_end_time = RTW_MESH_CTO_MGATE_CONF_DISABLED
+#define SET_CTO_MGATE_CONF_END_TIME(plink, timeout_ms) \
+	do { \
+		(plink)->cto_mgate_conf_end_time = rtw_get_current_time() + rtw_ms_to_systime(timeout_ms); \
+		if ((plink)->cto_mgate_conf_end_time == RTW_MESH_CTO_MGATE_CONF_DISABLED) \
+			(plink)->cto_mgate_conf_end_time++; \
+	} while (0)
+#else
+#define IS_CTO_MGATE_CONF_DISABLED(plink) 1
+#define IS_CTO_MGATE_CONF_TIMEOUT(plink) 0
+#define SET_CTO_MGATE_CONF_DISABLED(plink) do {} while (0)
+#define SET_CTO_MGATE_CONF_END_TIME(plink, timeout_ms) do {} while (0)
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+struct mesh_plink_ent {
+	u8 valid;
+	u8 addr[ETH_ALEN];
+	u8 plink_state;
+
+#ifdef CONFIG_RTW_MESH_AEK
+	u8 aek_valid;
+	u8 aek[32];
+#endif
+
+	u16 llid;
+	u16 plid;
+#ifndef CONFIG_RTW_MESH_DRIVER_AID
+	u16 aid; /* aid assigned from upper layer */
+#endif
+	u16 peer_aid; /* aid assigned from peer */
+
+	u8 chosen_pmk[16];
+
+#ifdef CONFIG_RTW_MESH_AEK
+	u8 sel_pcs[4];
+	u8 l_nonce[32];
+	u8 p_nonce[32];
+#endif
+
+#ifdef CONFIG_RTW_MESH_DRIVER_AID
+	u8 *tx_conf_ies;
+	u16 tx_conf_ies_len;
+#endif
+	u8 *rx_conf_ies;
+	u16 rx_conf_ies_len;
+
+	struct wlan_network *scanned;
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	systime peer_conf_end_time;
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	systime cto_mgate_conf_end_time;
+#endif
+};
+
+#ifdef CONFIG_RTW_MESH_AEK
+#define MESH_PLINK_AEK_VALID(ent) ent->aek_valid
+#else
+#define MESH_PLINK_AEK_VALID(ent) 0
+#endif
+
+struct mesh_plink_pool {
+	_lock lock;
+	u8 num; /* current ent being used */
+	struct mesh_plink_ent ent[RTW_MESH_MAX_PEER_CANDIDATES];
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	u8 acnode_rsvd;
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	_queue peer_blacklist;
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	_queue cto_mgate_blacklist;
+#endif
+};
+
+struct mesh_peer_sel_policy {
+	u32 scanr_exp_ms;
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	u8 acnode_prevent;
+	u32 acnode_conf_timeout_ms;
+	u32 acnode_notify_timeout_ms;
+#endif
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+	u8 offch_cand;
+	u32 offch_find_int_ms; /* 0 means no offch find triggerred by driver self*/
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	u32 peer_conf_timeout_ms;
+	u32 peer_blacklist_timeout_ms;
+#endif
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	u8 cto_mgate_require;
+	u32 cto_mgate_conf_timeout_ms;
+	u32 cto_mgate_blacklist_timeout_ms;
+#endif
+};
+
+/* b2u flags */
+#define RTW_MESH_B2U_ALL		BIT0
+#define RTW_MESH_B2U_GA_UCAST	BIT1 /* Group addressed unicast frame, forward only */
+#define RTW_MESH_B2U_BCAST		BIT2
+#define RTW_MESH_B2U_IP_MCAST	BIT3
+
+#define rtw_msrc_b2u_policy_chk(flags, mda) ( \
+	(flags & RTW_MESH_B2U_ALL) \
+	|| ((flags & RTW_MESH_B2U_BCAST) && is_broadcast_mac_addr(mda)) \
+	|| ((flags & RTW_MESH_B2U_IP_MCAST) && (IP_MCAST_MAC(mda) || ICMPV6_MCAST_MAC(mda))) \
+	)
+
+#define rtw_mfwd_b2u_policy_chk(flags, mda, ucst) ( \
+	(flags & RTW_MESH_B2U_ALL) \
+	|| ((flags & RTW_MESH_B2U_GA_UCAST) && ucst) \
+	|| ((flags & RTW_MESH_B2U_BCAST) && is_broadcast_mac_addr(mda)) \
+	|| ((flags & RTW_MESH_B2U_IP_MCAST) && (IP_MCAST_MAC(mda) || ICMPV6_MCAST_MAC(mda))) \
+	)
+
+/**
+ * @sane_metric_delta: Controlling if trigger additional path check mechanism
+ * @max_root_add_chk_cnt: The retry cnt to send additional root confirmation
+ *	PREQ through old(last) path
+ */
+struct rtw_mesh_cfg {
+	u8 max_peer_links; /* peering limit */
+	u32 plink_timeout; /* seconds */
+
+	u8 dot11MeshTTL;
+	u8 element_ttl;
+	u32 path_refresh_time;
+	u16 dot11MeshHWMPpreqMinInterval;
+	u16 dot11MeshHWMPnetDiameterTraversalTime;
+	u32 dot11MeshHWMPactivePathTimeout;
+	u8 dot11MeshHWMPmaxPREQretries;
+	u16 min_discovery_timeout;
+	u16 dot11MeshHWMPconfirmationInterval;
+	u16 dot11MeshHWMPperrMinInterval;
+	u8 dot11MeshHWMPRootMode;
+	BOOLEAN dot11MeshForwarding;
+	s32 rssi_threshold; /* in dBm, 0: no specified */
+	u16 dot11MeshHWMPRannInterval;
+	BOOLEAN dot11MeshGateAnnouncementProtocol;
+	u32 dot11MeshHWMPactivePathToRootTimeout;
+	u16 dot11MeshHWMProotInterval;
+	u8 path_gate_timeout_factor;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	u16 sane_metric_delta;
+	u8 max_root_add_chk_cnt;
+#endif
+
+	struct mesh_peer_sel_policy peer_sel_policy;
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	u8 b2u_flags_msrc;
+	u8 b2u_flags_mfwd;
+#endif
+};
+
+struct rtw_mesh_stats {
+	u32 fwded_mcast;		/* Mesh forwarded multicast frames */
+	u32 fwded_unicast;		/* Mesh forwarded unicast frames */
+	u32 fwded_frames;		/* Mesh total forwarded frames */
+	u32 dropped_frames_ttl;	/* Not transmitted since mesh_ttl == 0*/
+	u32 dropped_frames_no_route;	/* Not transmitted, no route found */
+	u32 dropped_frames_congestion;/* Not forwarded due to congestion */
+	u32 dropped_frames_duplicate;
+
+	u32 mrc_del_qlen; /* MRC entry deleted cause by queue length limit */
+};
+
+struct rtw_mrc;
+
+struct rtw_mesh_info {
+	u8 mesh_id[NDIS_802_11_LENGTH_SSID];
+	size_t mesh_id_len;
+	/* Active Path Selection Protocol Identifier */
+	u8 mesh_pp_id;
+	/* Active Path Selection Metric Identifier */
+	u8 mesh_pm_id;
+	/* Congestion Control Mode Identifier */
+	u8 mesh_cc_id;
+	/* Synchronization Protocol Identifier */
+	u8 mesh_sp_id;
+	/* Authentication Protocol Identifier */
+	u8 mesh_auth_id;
+
+	struct mesh_plink_pool plink_ctl;
+
+	u32 mesh_seqnum;
+	/* MSTA's own hwmp sequence number */
+	u32 sn;
+	systime last_preq;
+	systime last_sn_update;
+	systime next_perr;
+	/* Last used Path Discovery ID */
+	u32 preq_id;
+	
+	ATOMIC_T mpaths;
+	struct rtw_mesh_table *mesh_paths;
+	struct rtw_mesh_table *mpp_paths;
+	int mesh_paths_generation;
+	int mpp_paths_generation;
+
+	int num_gates;
+	struct rtw_mesh_path *max_addr_gate;
+	bool max_addr_gate_is_larger_than_self;
+
+	struct rtw_mesh_stats mshstats;
+
+	_queue mpath_tx_queue;
+	u32 mpath_tx_queue_len;
+	struct tasklet_struct mpath_tx_tasklet;
+
+	struct rtw_mrc *mrc;
+
+	_lock mesh_preq_queue_lock;
+	struct rtw_mesh_preq_queue preq_queue;
+	int preq_queue_len;
+};
+
+extern const char *_action_self_protected_str[];
+#define action_self_protected_str(action) ((action < RTW_ACT_SELF_PROTECTED_NUM) ? _action_self_protected_str[action] : _action_self_protected_str[0])
+
+u8 *rtw_set_ie_mesh_id(u8 *buf, u32 *buf_len, const char *mesh_id, u8 id_len);
+u8 *rtw_set_ie_mesh_config(u8 *buf, u32 *buf_len
+	, u8 path_sel_proto, u8 path_sel_metric, u8 congest_ctl_mode, u8 sync_method, u8 auth_proto
+	, u8 num_of_peerings, bool cto_mgate, bool cto_as
+	, bool accept_peerings, bool mcca_sup, bool mcca_en, bool forwarding
+	, bool mbca_en, bool tbtt_adj, bool ps_level);
+
+int rtw_bss_is_same_mbss(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b);
+int rtw_bss_is_candidate_mesh_peer(WLAN_BSSID_EX *self, WLAN_BSSID_EX *target, u8 ch, u8 add_peer);
+
+void rtw_chk_candidate_peer_notify(_adapter *adapter, struct wlan_network *scanned);
+
+void rtw_mesh_peer_status_chk(_adapter *adapter);
+
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+void rtw_mesh_update_scanned_acnode_status(_adapter *adapter, struct wlan_network *scanned);
+bool rtw_mesh_scanned_is_acnode_confirmed(_adapter *adapter, struct wlan_network *scanned);
+bool rtw_mesh_acnode_prevent_allow_sacrifice(_adapter *adapter);
+struct sta_info *rtw_mesh_acnode_prevent_pick_sacrifice(_adapter *adapter);
+void dump_mesh_acnode_prevent_settings(void *sel, _adapter *adapter);
+#endif
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+u8 rtw_mesh_offch_candidate_accepted(_adapter *adapter);
+u8 rtw_mesh_select_operating_ch(_adapter *adapter);
+void dump_mesh_offch_cand_settings(void *sel, _adapter *adapter);
+#endif
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_peer_blacklist_add(_adapter *adapter, const u8 *addr);
+int rtw_mesh_peer_blacklist_del(_adapter *adapter, const u8 *addr);
+int rtw_mesh_peer_blacklist_search(_adapter *adapter, const u8 *addr);
+void rtw_mesh_peer_blacklist_flush(_adapter *adapter);
+void dump_mesh_peer_blacklist(void *sel, _adapter *adapter);
+void dump_mesh_peer_blacklist_settings(void *sel, _adapter *adapter);
+#endif
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+u8 rtw_mesh_cto_mgate_required(_adapter *adapter);
+u8 rtw_mesh_cto_mgate_network_filter(_adapter *adapter, struct wlan_network *scanned);
+int rtw_mesh_cto_mgate_blacklist_add(_adapter *adapter, const u8 *addr);
+int rtw_mesh_cto_mgate_blacklist_del(_adapter *adapter, const u8 *addr);
+int rtw_mesh_cto_mgate_blacklist_search(_adapter *adapter, const u8 *addr);
+void rtw_mesh_cto_mgate_blacklist_flush(_adapter *adapter);
+void dump_mesh_cto_mgate_blacklist(void *sel, _adapter *adapter);
+void dump_mesh_cto_mgate_blacklist_settings(void *sel, _adapter *adapter);
+#endif
+void dump_mesh_peer_sel_policy(void *sel, _adapter *adapter);
+void dump_mesh_networks(void *sel, _adapter *adapter);
+
+void rtw_mesh_adjust_chbw(u8 req_ch, u8 *req_bw, u8 *req_offset);
+
+int rtw_sae_check_frames(_adapter *adapter, const u8 *buf, u32 len, u8 tx);
+int rtw_mesh_check_frames_tx(_adapter *adapter, const u8 **buf, size_t *len);
+int rtw_mesh_check_frames_rx(_adapter *adapter, const u8 *buf, size_t len);
+
+int rtw_mesh_on_auth(_adapter *adapter, union recv_frame *rframe);
+unsigned int on_action_self_protected(_adapter *adapter, union recv_frame *rframe);
+
+bool rtw_mesh_update_bss_peering_status(_adapter *adapter, WLAN_BSSID_EX *bss);
+bool rtw_mesh_update_bss_formation_info(_adapter *adapter, WLAN_BSSID_EX *bss);
+bool rtw_mesh_update_bss_forwarding_state(_adapter *adapter, WLAN_BSSID_EX *bss);
+
+struct mesh_plink_ent *_rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr);
+struct mesh_plink_ent *rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr);
+struct mesh_plink_ent *rtw_mesh_plink_get_no_estab_by_idx(_adapter *adapter, u8 idx);
+int _rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr);
+int rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr);
+int rtw_mesh_plink_set_state(_adapter *adapter, const u8 *hwaddr, u8 state);
+#ifdef CONFIG_RTW_MESH_AEK
+int rtw_mesh_plink_set_aek(_adapter *adapter, const u8 *hwaddr, const u8 *aek);
+#endif
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+int rtw_mesh_plink_set_peer_conf_timeout(_adapter *adapter, const u8 *hwaddr);
+#endif
+void _rtw_mesh_plink_del_ent(_adapter *adapter, struct mesh_plink_ent *ent);
+int rtw_mesh_plink_del(_adapter *adapter, const u8 *hwaddr);
+void rtw_mesh_plink_ctl_init(_adapter *adapter);
+void rtw_mesh_plink_ctl_deinit(_adapter *adapter);
+void dump_mesh_plink_ctl(void *sel, _adapter *adapter);
+
+int rtw_mesh_peer_establish(_adapter *adapter, struct mesh_plink_ent *plink, struct sta_info *sta);
+void _rtw_mesh_expire_peer_ent(_adapter *adapter, struct mesh_plink_ent *plink);
+void rtw_mesh_expire_peer(_adapter *adapter, const u8 *peer_addr);
+u8 rtw_mesh_ps_annc(_adapter *adapter, u8 ps);
+
+unsigned int on_action_mesh(_adapter *adapter, union recv_frame *rframe);
+
+void rtw_mesh_cfg_init(_adapter *adapter);
+void rtw_mesh_cfg_init_max_peer_links(_adapter *adapter, u8 stack_conf);
+void rtw_mesh_cfg_init_plink_timeout(_adapter *adapter, u32 stack_conf);
+void rtw_mesh_init_mesh_info(_adapter *adapter);
+void rtw_mesh_deinit_mesh_info(_adapter *adapter);
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+void dump_mesh_b2u_flags(void *sel, _adapter *adapter);
+#endif
+
+int rtw_mesh_addr_resolve(_adapter *adapter, struct xmit_frame *xframe, _pkt *pkt, _list *b2u_list);
+
+s8 rtw_mesh_tx_set_whdr_mctrl_len(u8 mesh_frame_mode, struct pkt_attrib *attrib);
+void rtw_mesh_tx_build_mctrl(_adapter *adapter, struct pkt_attrib *attrib, u8 *buf);
+u8 rtw_mesh_tx_build_whdr(_adapter *adapter, struct pkt_attrib *attrib
+	, u16 *fctrl, struct rtw_ieee80211_hdr *whdr);
+
+int rtw_mesh_rx_data_validate_hdr(_adapter *adapter, union recv_frame *rframe, struct sta_info **sta);
+int rtw_mesh_rx_data_validate_mctrl(_adapter *adapter, union recv_frame *rframe
+	, const struct rtw_ieee80211s_hdr *mctrl, const u8 *mda, const u8 *msa
+	, u8 *mctrl_len, const u8 **da, const u8 **sa);
+int rtw_mesh_rx_validate_mctrl_non_amsdu(_adapter *adapter, union recv_frame *rframe);
+
+int rtw_mesh_rx_msdu_act_check(union recv_frame *rframe
+	, const u8 *mda, const u8 *msa
+	, const u8 *da, const u8 *sa
+	, struct rtw_ieee80211s_hdr *mctrl
+	, struct xmit_frame **fwd_frame, _list *b2u_list);
+
+void dump_mesh_stats(void *sel, _adapter *adapter);
+
+#if defined(PLATFORM_LINUX) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
+#define rtw_lockdep_assert_held(l) lockdep_assert_held(l)
+#define rtw_lockdep_is_held(l) lockdep_is_held(l)
+#else
+#error "TBD\n"
+#endif
+
+#include "rtw_mesh_pathtbl.h"
+#include "rtw_mesh_hwmp.h"
+#endif /* __RTW_MESH_H_ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_hwmp.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_hwmp.c
new file mode 100644
index 000000000000..f25e14eb1a8e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_hwmp.c
@@ -0,0 +1,1666 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HWMP_C_
+
+#ifdef CONFIG_RTW_MESH
+#include <drv_types.h>
+#include <hal_data.h>
+
+#define RTW_TEST_FRAME_LEN	8192
+#define RTW_MAX_METRIC	0xffffffff
+#define RTW_ARITH_SHIFT	8
+#define RTW_LINK_FAIL_THRESH 95
+#define RTW_MAX_PREQ_QUEUE_LEN	64
+#define RTW_ATLM_REQ_CYCLE 1000
+
+#define rtw_ilog2(n)			\
+(					\
+	(n) < 2 ? 0 :			\
+	(n) & (1ULL << 63) ? 63 :	\
+	(n) & (1ULL << 62) ? 62 :	\
+	(n) & (1ULL << 61) ? 61 :	\
+	(n) & (1ULL << 60) ? 60 :	\
+	(n) & (1ULL << 59) ? 59 :	\
+	(n) & (1ULL << 58) ? 58 :	\
+	(n) & (1ULL << 57) ? 57 :	\
+	(n) & (1ULL << 56) ? 56 :	\
+	(n) & (1ULL << 55) ? 55 :	\
+	(n) & (1ULL << 54) ? 54 :	\
+	(n) & (1ULL << 53) ? 53 :	\
+	(n) & (1ULL << 52) ? 52 :	\
+	(n) & (1ULL << 51) ? 51 :	\
+	(n) & (1ULL << 50) ? 50 :	\
+	(n) & (1ULL << 49) ? 49 :	\
+	(n) & (1ULL << 48) ? 48 :	\
+	(n) & (1ULL << 47) ? 47 :	\
+	(n) & (1ULL << 46) ? 46 :	\
+	(n) & (1ULL << 45) ? 45 :	\
+	(n) & (1ULL << 44) ? 44 :	\
+	(n) & (1ULL << 43) ? 43 :	\
+	(n) & (1ULL << 42) ? 42 :	\
+	(n) & (1ULL << 41) ? 41 :	\
+	(n) & (1ULL << 40) ? 40 :	\
+	(n) & (1ULL << 39) ? 39 :	\
+	(n) & (1ULL << 38) ? 38 :	\
+	(n) & (1ULL << 37) ? 37 :	\
+	(n) & (1ULL << 36) ? 36 :	\
+	(n) & (1ULL << 35) ? 35 :	\
+	(n) & (1ULL << 34) ? 34 :	\
+	(n) & (1ULL << 33) ? 33 :	\
+	(n) & (1ULL << 32) ? 32 :	\
+	(n) & (1ULL << 31) ? 31 :	\
+	(n) & (1ULL << 30) ? 30 :	\
+	(n) & (1ULL << 29) ? 29 :	\
+	(n) & (1ULL << 28) ? 28 :	\
+	(n) & (1ULL << 27) ? 27 :	\
+	(n) & (1ULL << 26) ? 26 :	\
+	(n) & (1ULL << 25) ? 25 :	\
+	(n) & (1ULL << 24) ? 24 :	\
+	(n) & (1ULL << 23) ? 23 :	\
+	(n) & (1ULL << 22) ? 22 :	\
+	(n) & (1ULL << 21) ? 21 :	\
+	(n) & (1ULL << 20) ? 20 :	\
+	(n) & (1ULL << 19) ? 19 :	\
+	(n) & (1ULL << 18) ? 18 :	\
+	(n) & (1ULL << 17) ? 17 :	\
+	(n) & (1ULL << 16) ? 16 :	\
+	(n) & (1ULL << 15) ? 15 :	\
+	(n) & (1ULL << 14) ? 14 :	\
+	(n) & (1ULL << 13) ? 13 :	\
+	(n) & (1ULL << 12) ? 12 :	\
+	(n) & (1ULL << 11) ? 11 :	\
+	(n) & (1ULL << 10) ? 10 :	\
+	(n) & (1ULL <<  9) ?  9 :	\
+	(n) & (1ULL <<  8) ?  8 :	\
+	(n) & (1ULL <<  7) ?  7 :	\
+	(n) & (1ULL <<  6) ?  6 :	\
+	(n) & (1ULL <<  5) ?  5 :	\
+	(n) & (1ULL <<  4) ?  4 :	\
+	(n) & (1ULL <<  3) ?  3 :	\
+	(n) & (1ULL <<  2) ?  2 :	\
+	1				\
+)
+
+enum rtw_mpath_frame_type {
+	RTW_MPATH_PREQ = 0,
+	RTW_MPATH_PREP,
+	RTW_MPATH_PERR,
+	RTW_MPATH_RANN
+};
+
+static inline u32 rtw_u32_field_get(const u8 *preq_elem, int shift, BOOLEAN ae)
+{
+	if (ae)
+		shift += 6;
+	return LE_BITS_TO_4BYTE(preq_elem + shift, 0, 32);
+}
+
+static inline u16 rtw_u16_field_get(const u8 *preq_elem, int shift, BOOLEAN ae)
+{
+	if (ae)
+		shift += 6;
+	return LE_BITS_TO_2BYTE(preq_elem + shift, 0, 16);
+}
+
+/* HWMP IE processing macros */
+#define RTW_AE_F			(1<<6)
+#define RTW_AE_F_SET(x)			(*x & RTW_AE_F)
+#define RTW_PREQ_IE_FLAGS(x)		(*(x))
+#define RTW_PREQ_IE_HOPCOUNT(x)		(*(x + 1))
+#define RTW_PREQ_IE_TTL(x)		(*(x + 2))
+#define RTW_PREQ_IE_PREQ_ID(x)		rtw_u32_field_get(x, 3, 0)
+#define RTW_PREQ_IE_ORIG_ADDR(x)	(x + 7)
+#define RTW_PREQ_IE_ORIG_SN(x)		rtw_u32_field_get(x, 13, 0)
+#define RTW_PREQ_IE_LIFETIME(x)		rtw_u32_field_get(x, 17, RTW_AE_F_SET(x))
+#define RTW_PREQ_IE_METRIC(x) 		rtw_u32_field_get(x, 21, RTW_AE_F_SET(x))
+#define RTW_PREQ_IE_TARGET_F(x)		(*(RTW_AE_F_SET(x) ? x + 32 : x + 26))
+#define RTW_PREQ_IE_TARGET_ADDR(x) 	(RTW_AE_F_SET(x) ? x + 33 : x + 27)
+#define RTW_PREQ_IE_TARGET_SN(x) 	rtw_u32_field_get(x, 33, RTW_AE_F_SET(x))
+
+#define RTW_PREP_IE_FLAGS(x)		RTW_PREQ_IE_FLAGS(x)
+#define RTW_PREP_IE_HOPCOUNT(x)		RTW_PREQ_IE_HOPCOUNT(x)
+#define RTW_PREP_IE_TTL(x)		RTW_PREQ_IE_TTL(x)
+#define RTW_PREP_IE_ORIG_ADDR(x)	(RTW_AE_F_SET(x) ? x + 27 : x + 21)
+#define RTW_PREP_IE_ORIG_SN(x)		rtw_u32_field_get(x, 27, RTW_AE_F_SET(x))
+#define RTW_PREP_IE_LIFETIME(x)		rtw_u32_field_get(x, 13, RTW_AE_F_SET(x))
+#define RTW_PREP_IE_METRIC(x)		rtw_u32_field_get(x, 17, RTW_AE_F_SET(x))
+#define RTW_PREP_IE_TARGET_ADDR(x)	(x + 3)
+#define RTW_PREP_IE_TARGET_SN(x)	rtw_u32_field_get(x, 9, 0)
+
+#define RTW_PERR_IE_TTL(x)		(*(x))
+#define RTW_PERR_IE_TARGET_FLAGS(x)	(*(x + 2))
+#define RTW_PERR_IE_TARGET_ADDR(x)	(x + 3)
+#define RTW_PERR_IE_TARGET_SN(x)	rtw_u32_field_get(x, 9, 0)
+#define RTW_PERR_IE_TARGET_RCODE(x)	rtw_u16_field_get(x, 13, 0)
+
+#define RTW_TU_TO_SYSTIME(x)	(rtw_us_to_systime((x) * 1024))
+#define RTW_TU_TO_EXP_TIME(x)	(rtw_get_current_time() + RTW_TU_TO_SYSTIME(x))
+#define RTW_MSEC_TO_TU(x) (x*1000/1024)
+#define RTW_SN_GT(x, y) ((s32)(y - x) < 0)
+#define RTW_SN_LT(x, y) ((s32)(x - y) < 0)
+#define RTW_MAX_SANE_SN_DELTA 32
+
+static inline u32 RTW_SN_DELTA(u32 x, u32 y)
+{
+	return x >= y ? x - y : y - x;
+}
+
+#define rtw_net_traversal_jiffies(adapter) \
+	rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPnetDiameterTraversalTime)
+#define rtw_default_lifetime(adapter) \
+	RTW_MSEC_TO_TU(adapter->mesh_cfg.dot11MeshHWMPactivePathTimeout)
+#define rtw_min_preq_int_jiff(adapter) \
+	(rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPpreqMinInterval))
+#define rtw_max_preq_retries(adapter) (adapter->mesh_cfg.dot11MeshHWMPmaxPREQretries)
+#define rtw_disc_timeout_jiff(adapter) \
+	rtw_ms_to_systime(adapter->mesh_cfg.min_discovery_timeout)
+#define rtw_root_path_confirmation_jiffies(adapter) \
+	rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPconfirmationInterval)
+
+static inline BOOLEAN rtw_ether_addr_equal(const u8 *addr1, const u8 *addr2)
+{
+	return _rtw_memcmp(addr1, addr2, ETH_ALEN);
+}
+
+#ifdef PLATFORM_LINUX
+#define rtw_print_ratelimit()	printk_ratelimit()
+#define rtw_mod_timer(ptimer, expires) mod_timer(&(ptimer)->timer, expires)
+#else
+
+#endif
+
+#define RTW_MESH_EWMA_PRECISION 20
+#define RTW_MESH_EWMA_WEIGHT_RCP 8
+#define RTW_TOTAL_PKT_MIN_THRESHOLD 1
+inline void rtw_ewma_err_rate_init(struct rtw_ewma_err_rate *e)
+{
+	e->internal = 0;
+}
+inline unsigned long rtw_ewma_err_rate_read(struct rtw_ewma_err_rate *e)
+{
+	return e->internal >> (RTW_MESH_EWMA_PRECISION);
+}
+inline void rtw_ewma_err_rate_add(struct rtw_ewma_err_rate *e,
+				  unsigned long val)
+{
+	unsigned long internal = e->internal;
+	unsigned long weight_rcp = rtw_ilog2(RTW_MESH_EWMA_WEIGHT_RCP);
+	unsigned long precision = RTW_MESH_EWMA_PRECISION;
+
+	(e->internal) = internal ? (((internal << weight_rcp) - internal) +
+			(val << precision)) >> weight_rcp :
+			(val << precision);
+}
+
+static const u8 bcast_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+static int rtw_mesh_path_sel_frame_tx(enum rtw_mpath_frame_type mpath_action, u8 flags,
+				      const u8 *originator_addr, u32 originator_sn,
+				      u8 target_flags, const u8 *target,
+				      u32 target_sn, const u8 *da, u8 hopcount, u8 ttl,
+				      u32 lifetime, u32 metric, u32 preq_id, 
+				      _adapter *adapter)
+{
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct xmit_frame *pmgntframe = NULL;
+	struct rtw_ieee80211_hdr *pwlanhdr = NULL;
+	struct pkt_attrib *pattrib = NULL;
+	u8 category = RTW_WLAN_CATEGORY_MESH;
+	u8 action = RTW_ACT_MESH_HWMP_PATH_SELECTION;
+	u16 *fctrl = NULL;
+	u8 *pos, ie_len;
+
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return -1;
+
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pos = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pos;
+
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pos, WIFI_ACTION);
+
+	pos += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	pos = rtw_set_fixed_ie(pos, 1, &(category), &(pattrib->pktlen));
+	pos = rtw_set_fixed_ie(pos, 1, &(action), &(pattrib->pktlen));
+
+	switch (mpath_action) {
+	case RTW_MPATH_PREQ:
+		RTW_HWMP_DBG("sending PREQ to "MAC_FMT"\n", MAC_ARG(target));
+		ie_len = 37;
+		pattrib->pktlen += (ie_len + 2);
+		*pos++ = WLAN_EID_PREQ;
+		break;
+	case RTW_MPATH_PREP:
+		RTW_HWMP_DBG("sending PREP to "MAC_FMT"\n", MAC_ARG(originator_addr));
+		ie_len = 31;
+		pattrib->pktlen += (ie_len + 2);
+		*pos++ = WLAN_EID_PREP;
+		break;
+	case RTW_MPATH_RANN:
+		RTW_HWMP_DBG("sending RANN from "MAC_FMT"\n", MAC_ARG(originator_addr));
+		ie_len = sizeof(struct rtw_ieee80211_rann_ie);
+		pattrib->pktlen += (ie_len + 2);
+		*pos++ = WLAN_EID_RANN;
+		break;
+	default:
+		rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
+		rtw_free_xmitframe(pxmitpriv, pmgntframe);
+		return _FAIL;
+	}
+	*pos++ = ie_len;
+	*pos++ = flags;
+	*pos++ = hopcount;
+	*pos++ = ttl;
+	if (mpath_action == RTW_MPATH_PREP) {
+		_rtw_memcpy(pos, target, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(target_sn);
+		pos += 4;
+	} else {
+		if (mpath_action == RTW_MPATH_PREQ) {
+			*(u32 *)pos = cpu_to_le32(preq_id);
+			pos += 4;
+		}
+		_rtw_memcpy(pos, originator_addr, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(originator_sn);
+		pos += 4;
+	}
+	*(u32 *)pos = cpu_to_le32(lifetime);
+	pos += 4;
+	*(u32 *)pos = cpu_to_le32(metric);
+	pos += 4;
+	if (mpath_action == RTW_MPATH_PREQ) {
+		*pos++ = 1; /* support only 1 destination now */
+		*pos++ = target_flags;
+		_rtw_memcpy(pos, target, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(target_sn);
+		pos += 4;
+	} else if (mpath_action == RTW_MPATH_PREP) {
+		_rtw_memcpy(pos, originator_addr, ETH_ALEN);
+		pos += ETH_ALEN;
+		*(u32 *)pos = cpu_to_le32(originator_sn);
+		pos += 4;
+	}
+
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	dump_mgntframe(adapter, pmgntframe);
+	return 0;
+}
+
+int rtw_mesh_path_error_tx(_adapter *adapter,
+			   u8 ttl, const u8 *target, u32 target_sn,
+			   u16 perr_reason_code, const u8 *ra)
+{
+
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct xmit_frame *pmgntframe = NULL;
+	struct rtw_ieee80211_hdr *pwlanhdr = NULL;
+	struct pkt_attrib *pattrib = NULL;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u8 category = RTW_WLAN_CATEGORY_MESH;
+	u8 action = RTW_ACT_MESH_HWMP_PATH_SELECTION;
+	u8 *pos, ie_len;
+	u16 *fctrl = NULL;
+
+	if (rtw_time_before(rtw_get_current_time(), minfo->next_perr))
+		return -1;
+
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL)
+		return -1;
+
+	pattrib = &pmgntframe->attrib;
+	update_mgntframe_attrib(adapter, pattrib);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+	pos = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pos;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pos, WIFI_ACTION);
+
+	pos += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	pos = rtw_set_fixed_ie(pos, 1, &(category), &(pattrib->pktlen));
+	pos = rtw_set_fixed_ie(pos, 1, &(action), &(pattrib->pktlen));
+
+	ie_len = 15;
+	pattrib->pktlen += (2 + ie_len);
+	*pos++ = WLAN_EID_PERR;
+	*pos++ = ie_len;
+	/* ttl */
+	*pos++ = ttl;
+	/* The Number of Destinations N */
+	*pos++ = 1;
+	/* Flags format | B7 | B6 | B5:B0 | = | rsvd | AE | rsvd | */
+	*pos = 0;
+	pos++;
+	_rtw_memcpy(pos, target, ETH_ALEN);
+	pos += ETH_ALEN;
+	*(u32 *)pos = cpu_to_le32(target_sn);
+	pos += 4;
+	*(u16 *)pos = cpu_to_le16(perr_reason_code);
+
+	adapter->mesh_info.next_perr = RTW_TU_TO_EXP_TIME(
+				adapter->mesh_cfg.dot11MeshHWMPperrMinInterval);
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	/* Send directly. Rewrite it if deferred tx is needed */
+	dump_mgntframe(adapter, pmgntframe);
+
+	RTW_HWMP_DBG("TX PERR toward "MAC_FMT", ra = "MAC_FMT"\n", MAC_ARG(target), MAC_ARG(ra));
+	
+	return 0;
+}
+
+static u32 rtw_get_vht_bitrate(u8 mcs, u8 bw, u8 nss, u8 sgi)
+{
+	static const u32 base[4][10] = {
+		{   6500000,
+		   13000000,
+		   19500000,
+		   26000000,
+		   39000000,
+		   52000000,
+		   58500000,
+		   65000000,
+		   78000000,
+		/* not in the spec, but some devices use this: */
+		   86500000,
+		},
+		{  13500000,
+		   27000000,
+		   40500000,
+		   54000000,
+		   81000000,
+		  108000000,
+		  121500000,
+		  135000000,
+		  162000000,
+		  180000000,
+		},
+		{  29300000,
+		   58500000,
+		   87800000,
+		  117000000,
+		  175500000,
+		  234000000,
+		  263300000,
+		  292500000,
+		  351000000,
+		  390000000,
+		},
+		{  58500000,
+		  117000000,
+		  175500000,
+		  234000000,
+		  351000000,
+		  468000000,
+		  526500000,
+		  585000000,
+		  702000000,
+		  780000000,
+		},
+	};
+	u32 bitrate;
+	int bw_idx;
+
+	if (mcs > 9) {
+		RTW_HWMP_INFO("Invalid mcs = %d\n", mcs);
+		return 0;
+	}
+
+	if (nss > 4 || nss < 1) {
+		RTW_HWMP_INFO("Now only support nss = 1, 2, 3, 4\n");
+	}
+
+	switch (bw) {
+	case CHANNEL_WIDTH_160:
+		bw_idx = 3;
+		break;
+	case CHANNEL_WIDTH_80:
+		bw_idx = 2;
+		break;
+	case CHANNEL_WIDTH_40:
+		bw_idx = 1;
+		break;
+	case CHANNEL_WIDTH_20:
+		bw_idx = 0;
+		break;
+	default:
+		RTW_HWMP_INFO("bw = %d currently not supported\n", bw);
+		return 0;
+	}
+
+	bitrate = base[bw_idx][mcs];
+	bitrate *= nss;
+
+	if (sgi)
+		bitrate = (bitrate / 9) * 10;
+
+	/* do NOT round down here */
+	return (bitrate + 50000) / 100000;
+}
+
+static u32 rtw_get_ht_bitrate(u8 mcs, u8 bw, u8 sgi)
+{
+	int modulation, streams, bitrate;
+
+	/* the formula below does only work for MCS values smaller than 32 */
+	if (mcs >= 32) {
+		RTW_HWMP_INFO("Invalid mcs = %d\n", mcs);
+		return 0;
+	}
+
+	if (bw > 1) {
+		RTW_HWMP_INFO("Now HT only support bw = 0(20Mhz), 1(40Mhz)\n");
+		return 0;
+	}
+
+	modulation = mcs & 7;
+	streams = (mcs >> 3) + 1;
+
+	bitrate = (bw == 1) ? 13500000 : 6500000;
+
+	if (modulation < 4)
+		bitrate *= (modulation + 1);
+	else if (modulation == 4)
+		bitrate *= (modulation + 2);
+	else
+		bitrate *= (modulation + 3);
+
+	bitrate *= streams;
+
+	if (sgi)
+		bitrate = (bitrate / 9) * 10;
+
+	/* do NOT round down here */
+	return (bitrate + 50000) / 100000;
+}
+
+/**
+ * @bw: 0(20Mhz), 1(40Mhz), 2(80Mhz), 3(160Mhz)
+ * @rate_idx: DESC_RATEXXXX & 0x7f
+ * @sgi: DESC_RATEXXXX >> 7
+ * Returns: bitrate in 100kbps
+ */
+static u32 rtw_desc_rate_to_bitrate(u8 bw, u8 rate_idx, u8 sgi)
+{
+	u32 bitrate;
+
+	if (rate_idx <= DESC_RATE54M){
+		u16 ofdm_rate[12] = {10, 20, 55, 110,
+			60, 90, 120, 180, 240, 360, 480, 540};
+		bitrate = ofdm_rate[rate_idx];
+	} else if ((DESC_RATEMCS0 <= rate_idx) &&
+		   (rate_idx <= DESC_RATEMCS31)) {
+		u8 mcs = rate_idx - DESC_RATEMCS0;
+		bitrate = rtw_get_ht_bitrate(mcs, bw, sgi);
+	} else if ((DESC_RATEVHTSS1MCS0 <= rate_idx) &&
+		   (rate_idx <= DESC_RATEVHTSS4MCS9)) {
+		u8 mcs = (rate_idx - DESC_RATEVHTSS1MCS0) % 10;
+		u8 nss = ((rate_idx - DESC_RATEVHTSS1MCS0) / 10) + 1;
+		bitrate = rtw_get_vht_bitrate(mcs, bw, nss, sgi);
+	} else {
+		/* 60Ghz ??? */
+		bitrate = 1;
+	}
+
+	return bitrate;
+}
+
+static u32 rtw_airtime_link_metric_get(_adapter *adapter, struct sta_info *sta)
+{
+	struct dm_struct *dm = adapter_to_phydm(adapter);
+	int device_constant = phydm_get_plcp(dm, sta->cmn.mac_id) << RTW_ARITH_SHIFT;
+	u32 test_frame_len = RTW_TEST_FRAME_LEN << RTW_ARITH_SHIFT;
+	u32 s_unit = 1 << RTW_ARITH_SHIFT;
+	u32 err;
+	u16 rate;
+	u32 tx_time, estimated_retx;
+	u64 result;
+	/* The fail_avg should <= 100 here */
+	u32 fail_avg = (u32)rtw_ewma_err_rate_read(&sta->metrics.err_rate);
+
+	if (fail_avg > RTW_LINK_FAIL_THRESH)
+		return RTW_MAX_METRIC;
+
+	rate = sta->metrics.data_rate;
+	/* rate unit is 100Kbps, min rate = 10 */
+	if (rate < 10) {
+		RTW_HWMP_INFO("rate = %d\n", rate);
+		return RTW_MAX_METRIC;
+	}
+
+	err = (fail_avg << RTW_ARITH_SHIFT) / 100;
+
+	/* test_frame_len*10 to adjust the unit of rate(100kbps/unit) */
+	tx_time = (device_constant + 10 * test_frame_len / rate);
+	estimated_retx = ((1 << (2 * RTW_ARITH_SHIFT)) / (s_unit - err));
+	result = (tx_time * estimated_retx) >> (2 * RTW_ARITH_SHIFT);
+	/* Convert us to 0.01 TU(10.24us). x/10.24 = x*100/1024 */
+	result = (result * 100) >> 10;
+
+	return (u32)result;
+}
+
+void rtw_ieee80211s_update_metric(_adapter *adapter, u8 mac_id,
+				  u8 per, u8 rate,
+				  u8 bw, u8 total_pkt)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *sta;
+	u8 rate_idx;
+	u8 sgi;
+
+	sta = macid_ctl->sta[mac_id];
+	if (!sta)
+		return;
+
+	/* if RA, use reported rate */
+	if (adapter->fix_rate == 0xff) {
+		rate_idx = rate & 0x7f;
+		sgi = rate >> 7;
+	} else {
+		rate_idx = adapter->fix_rate & 0x7f;
+		sgi = adapter->fix_rate >> 7;
+	}
+	sta->metrics.data_rate = rtw_desc_rate_to_bitrate(bw, rate_idx, sgi);
+
+	if (total_pkt < RTW_TOTAL_PKT_MIN_THRESHOLD)
+		return;
+
+	/* TBD: sta->metrics.overhead = phydm_get_plcp(void *dm_void, u16 macid); */
+	sta->metrics.total_pkt = total_pkt;
+
+	rtw_ewma_err_rate_add(&sta->metrics.err_rate, per);
+	if (rtw_ewma_err_rate_read(&sta->metrics.err_rate) > 
+			RTW_LINK_FAIL_THRESH)
+		rtw_mesh_plink_broken(sta);
+}
+
+static void rtw_hwmp_preq_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const u8 *preq_elem, u32 originator_metric)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_path *path = NULL;
+	const u8 *target_addr, *originator_addr;
+	const u8 *da;
+	u8 target_flags, ttl, flags, to_gate_ask = 0;
+	u32 originator_sn, target_sn, lifetime, target_metric = 0;
+	BOOLEAN reply = _FALSE;
+	BOOLEAN forward = _TRUE;
+	BOOLEAN preq_is_gate;
+
+	/* Update target SN, if present */
+	target_addr = RTW_PREQ_IE_TARGET_ADDR(preq_elem);
+	originator_addr = RTW_PREQ_IE_ORIG_ADDR(preq_elem);
+	target_sn = RTW_PREQ_IE_TARGET_SN(preq_elem);
+	originator_sn = RTW_PREQ_IE_ORIG_SN(preq_elem);
+	target_flags = RTW_PREQ_IE_TARGET_F(preq_elem);
+	/* PREQ gate announcements */
+	flags = RTW_PREQ_IE_FLAGS(preq_elem);
+	preq_is_gate = !!(flags & RTW_IEEE80211_PREQ_IS_GATE_FLAG);
+
+	RTW_HWMP_DBG("received PREQ from "MAC_FMT"\n", MAC_ARG(originator_addr));
+
+	if (rtw_ether_addr_equal(target_addr, adapter_mac_addr(adapter))) {
+		RTW_HWMP_DBG("PREQ is for us\n");
+#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
+		rtw_rcu_read_lock();
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			if (preq_is_gate)
+				rtw_mesh_path_add_gate(path);
+			else if (path->is_gate) {
+				enter_critical_bh(&path->state_lock);
+				rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+				exit_critical_bh(&path->state_lock);
+			}
+		}
+		path = NULL;
+		rtw_rcu_read_unlock();
+#endif
+		forward = _FALSE;
+		reply = _TRUE;
+		to_gate_ask = 1;
+		target_metric = 0;
+		if (rtw_time_after(rtw_get_current_time(), minfo->last_sn_update +
+					rtw_net_traversal_jiffies(adapter)) ||
+		    rtw_time_before(rtw_get_current_time(), minfo->last_sn_update)) {
+			++minfo->sn;
+			minfo->last_sn_update = rtw_get_current_time();
+		}
+		target_sn = minfo->sn;
+	} else if (is_broadcast_mac_addr(target_addr) &&
+		   (target_flags & RTW_IEEE80211_PREQ_TO_FLAG)) {
+		rtw_rcu_read_lock();
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			if (flags & RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG) {
+				reply = _TRUE;
+				target_addr = adapter_mac_addr(adapter);
+				target_sn = ++minfo->sn;
+				target_metric = 0;
+				minfo->last_sn_update = rtw_get_current_time();
+			}
+
+			if (preq_is_gate) {
+				lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
+				path->gate_ann_int = lifetime;
+				path->gate_asked = false;
+				rtw_mesh_path_add_gate(path);
+			} else if (path->is_gate) {
+				enter_critical_bh(&path->state_lock);
+				rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+				exit_critical_bh(&path->state_lock);
+			}
+		}
+		rtw_rcu_read_unlock();
+	} else {
+		rtw_rcu_read_lock();
+#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			if (preq_is_gate)
+				rtw_mesh_path_add_gate(path);
+			else if (path->is_gate) {
+				enter_critical_bh(&path->state_lock);
+				rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+				exit_critical_bh(&path->state_lock);
+			}
+		}
+		path = NULL;
+#endif
+		path = rtw_mesh_path_lookup(adapter, target_addr);
+		if (path) {
+			if ((!(path->flags & RTW_MESH_PATH_SN_VALID)) ||
+					RTW_SN_LT(path->sn, target_sn)) {
+				path->sn = target_sn;
+				path->flags |= RTW_MESH_PATH_SN_VALID;
+			} else if ((!(target_flags & RTW_IEEE80211_PREQ_TO_FLAG)) &&
+					(path->flags & RTW_MESH_PATH_ACTIVE)) {
+				reply = _TRUE;
+				target_metric = path->metric;
+				target_sn = path->sn;
+				/* Case E2 of sec 13.10.9.3 IEEE 802.11-2012*/
+				target_flags |= RTW_IEEE80211_PREQ_TO_FLAG;
+			}
+		}
+		rtw_rcu_read_unlock();
+	}
+
+	if (reply) {
+		lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
+		ttl = mshcfg->element_ttl;
+		if (ttl != 0 && !to_gate_ask) {
+			RTW_HWMP_DBG("replying to the PREQ\n");
+			rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, 0, originator_addr,
+						   originator_sn, 0, target_addr,
+						   target_sn, mgmt->addr2, 0, ttl,
+						   lifetime, target_metric, 0,
+						   adapter);
+		} else if (ttl != 0 && to_gate_ask) {
+			RTW_HWMP_DBG("replying to the PREQ (PREQ for us)\n");
+			if (mshcfg->dot11MeshGateAnnouncementProtocol) {
+				/* BIT 7 is used to identify the prep is from mesh gate */
+				to_gate_ask = RTW_IEEE80211_PREQ_IS_GATE_FLAG | BIT(7);
+			} else {
+				to_gate_ask = 0;
+			}
+
+			rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, to_gate_ask, originator_addr,
+						   originator_sn, 0, target_addr,
+						   target_sn, mgmt->addr2, 0, ttl,
+						   lifetime, target_metric, 0,
+						   adapter);
+		} else {
+			minfo->mshstats.dropped_frames_ttl++;
+		}
+	}
+
+	if (forward && mshcfg->dot11MeshForwarding) {
+		u32 preq_id;
+		u8 hopcount;
+
+		ttl = RTW_PREQ_IE_TTL(preq_elem);
+		lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
+		if (ttl <= 1) {
+			minfo->mshstats.dropped_frames_ttl++;
+			return;
+		}
+		RTW_HWMP_DBG("forwarding the PREQ from "MAC_FMT"\n", MAC_ARG(originator_addr));
+		--ttl;
+		preq_id = RTW_PREQ_IE_PREQ_ID(preq_elem);
+		hopcount = RTW_PREQ_IE_HOPCOUNT(preq_elem) + 1;
+		da = (path && path->is_root) ?
+			path->rann_snd_addr : bcast_addr;
+
+		if (flags & RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG) {
+			target_addr = RTW_PREQ_IE_TARGET_ADDR(preq_elem);
+			target_sn = RTW_PREQ_IE_TARGET_SN(preq_elem);
+		}
+
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, originator_addr,
+					   originator_sn, target_flags, target_addr,
+					   target_sn, da, hopcount, ttl, lifetime,
+					   originator_metric, preq_id, adapter);
+		if (!is_multicast_mac_addr(da))
+			minfo->mshstats.fwded_unicast++;
+		else
+			minfo->mshstats.fwded_mcast++;
+		minfo->mshstats.fwded_frames++;
+	}
+}
+
+static inline struct sta_info *
+rtw_next_hop_deref_protected(struct rtw_mesh_path *path)
+{
+	return rtw_rcu_dereference_protected(path->next_hop,
+					 rtw_lockdep_is_held(&path->state_lock));
+}
+
+static void rtw_hwmp_prep_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const u8 *prep_elem, u32 metric)
+{
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
+	struct rtw_mesh_path *path;
+	const u8 *target_addr, *originator_addr;
+	u8 ttl, hopcount, flags;
+	u8 next_hop[ETH_ALEN];
+	u32 target_sn, originator_sn, lifetime;
+
+	RTW_HWMP_DBG("received PREP from "MAC_FMT"\n",
+		  MAC_ARG(RTW_PREP_IE_TARGET_ADDR(prep_elem)));
+
+	originator_addr = RTW_PREP_IE_ORIG_ADDR(prep_elem);
+	if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter))) {
+		/* destination, no forwarding required */
+		rtw_rcu_read_lock();
+		target_addr = RTW_PREP_IE_TARGET_ADDR(prep_elem);
+		path = rtw_mesh_path_lookup(adapter, target_addr);
+		if (path && path->gate_asked) {
+			flags = RTW_PREP_IE_FLAGS(prep_elem);
+			if (flags & BIT(7)) {
+				enter_critical_bh(&path->state_lock);
+				path->gate_asked = false;
+				exit_critical_bh(&path->state_lock);
+				if (!(flags & RTW_IEEE80211_PREQ_IS_GATE_FLAG)) {
+					enter_critical_bh(&path->state_lock);
+					rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+					exit_critical_bh(&path->state_lock);
+				}
+			}
+		}
+
+		rtw_rcu_read_unlock();
+		return;
+	}
+
+	if (!mshcfg->dot11MeshForwarding)
+		return;
+
+	ttl = RTW_PREP_IE_TTL(prep_elem);
+	if (ttl <= 1) {
+		mshstats->dropped_frames_ttl++;
+		return;
+	}
+
+	rtw_rcu_read_lock();
+	path = rtw_mesh_path_lookup(adapter, originator_addr);
+	if (path)
+		enter_critical_bh(&path->state_lock);
+	else
+		goto fail;
+	if (!(path->flags & RTW_MESH_PATH_ACTIVE)) {
+		exit_critical_bh(&path->state_lock);
+		goto fail;
+	}
+	_rtw_memcpy(next_hop, rtw_next_hop_deref_protected(path)->cmn.mac_addr, ETH_ALEN);
+	exit_critical_bh(&path->state_lock);
+	--ttl;
+	flags = RTW_PREP_IE_FLAGS(prep_elem);
+	lifetime = RTW_PREP_IE_LIFETIME(prep_elem);
+	hopcount = RTW_PREP_IE_HOPCOUNT(prep_elem) + 1;
+	target_addr = RTW_PREP_IE_TARGET_ADDR(prep_elem);
+	target_sn = RTW_PREP_IE_TARGET_SN(prep_elem);
+	originator_sn = RTW_PREP_IE_ORIG_SN(prep_elem);
+
+	rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, flags, originator_addr, originator_sn, 0,
+				   target_addr, target_sn, next_hop, hopcount,
+				   ttl, lifetime, metric, 0, adapter);
+	rtw_rcu_read_unlock();
+
+	mshstats->fwded_unicast++;
+	mshstats->fwded_frames++;
+	return;
+
+fail:
+	rtw_rcu_read_unlock();
+	mshstats->dropped_frames_no_route++;
+}
+
+static void rtw_hwmp_perr_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const u8 *perr_elem)
+{
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
+	struct rtw_mesh_path *path;
+	u8 ttl;
+	const u8 *ta, *target_addr;
+	u32 target_sn;
+	u16 perr_reason_code;
+
+	ta = mgmt->addr2;
+	ttl = RTW_PERR_IE_TTL(perr_elem);
+	if (ttl <= 1) {
+		mshstats->dropped_frames_ttl++;
+		return;
+	}
+	ttl--;
+	target_addr = RTW_PERR_IE_TARGET_ADDR(perr_elem);
+	target_sn = RTW_PERR_IE_TARGET_SN(perr_elem);
+	perr_reason_code = RTW_PERR_IE_TARGET_RCODE(perr_elem);
+
+	RTW_HWMP_DBG("received PERR toward target "MAC_FMT"\n", MAC_ARG(target_addr));
+
+	rtw_rcu_read_lock();
+	path = rtw_mesh_path_lookup(adapter, target_addr);
+	if (path) {
+		struct sta_info *sta;
+
+		enter_critical_bh(&path->state_lock);
+		sta = rtw_next_hop_deref_protected(path);
+		if (path->flags & RTW_MESH_PATH_ACTIVE &&
+		    rtw_ether_addr_equal(ta, sta->cmn.mac_addr) &&
+		    !(path->flags & RTW_MESH_PATH_FIXED) &&
+		    (!(path->flags & RTW_MESH_PATH_SN_VALID) ||
+		    RTW_SN_GT(target_sn, path->sn)  || target_sn == 0)) {
+			path->flags &= ~RTW_MESH_PATH_ACTIVE;
+			if (target_sn != 0)
+				path->sn = target_sn;
+			else
+				path->sn += 1;
+			exit_critical_bh(&path->state_lock);
+			if (!mshcfg->dot11MeshForwarding)
+				goto endperr;
+			rtw_mesh_path_error_tx(adapter, ttl, target_addr,
+					       target_sn, perr_reason_code,
+					       bcast_addr);
+		} else
+			exit_critical_bh(&path->state_lock);
+	}
+endperr:
+	rtw_rcu_read_unlock();
+}
+
+static void rtw_hwmp_rann_frame_process(_adapter *adapter,
+					struct rtw_ieee80211_hdr_3addr *mgmt,
+					const struct rtw_ieee80211_rann_ie *rann)
+{
+	struct sta_info *sta;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
+	struct rtw_mesh_path *path;
+	u8 ttl, flags, hopcount;
+	const u8 *originator_addr;
+	u32 originator_sn, metric, metric_txsta, interval;
+	BOOLEAN root_is_gate;
+
+	ttl = rann->rann_ttl;
+	flags = rann->rann_flags;
+	root_is_gate = !!(flags & RTW_RANN_FLAG_IS_GATE);
+	originator_addr = rann->rann_addr;
+	originator_sn = le32_to_cpu(rann->rann_seq);
+	interval = le32_to_cpu(rann->rann_interval);
+	hopcount = rann->rann_hopcount;
+	hopcount++;
+	metric = le32_to_cpu(rann->rann_metric);
+
+	/*  Ignore our own RANNs */
+	if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter)))
+		return;
+
+	RTW_HWMP_DBG("received RANN from "MAC_FMT" via neighbour "MAC_FMT" (is_gate=%d)\n",
+		  MAC_ARG(originator_addr), MAC_ARG(mgmt->addr2), root_is_gate);
+
+	rtw_rcu_read_lock();
+	sta = rtw_get_stainfo(pstapriv, mgmt->addr2);
+	if (!sta) {
+		rtw_rcu_read_unlock();
+		return;
+	}
+
+	metric_txsta = rtw_airtime_link_metric_get(adapter, sta);
+
+	path = rtw_mesh_path_lookup(adapter, originator_addr);
+	if (!path) {
+		path = rtw_mesh_path_add(adapter, originator_addr);
+		if (IS_ERR(path)) {
+			rtw_rcu_read_unlock();
+			mshstats->dropped_frames_no_route++;
+			return;
+		}
+	}
+
+	if (!(RTW_SN_LT(path->sn, originator_sn)) &&
+	    !(path->sn == originator_sn && metric < path->rann_metric)) {
+		rtw_rcu_read_unlock();
+		return;
+	}
+
+	if ((!(path->flags & (RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVING)) ||
+	     (rtw_time_after(rtw_get_current_time(), path->last_preq_to_root +
+				  rtw_root_path_confirmation_jiffies(adapter)) ||
+	     rtw_time_before(rtw_get_current_time(), path->last_preq_to_root))) &&
+	     !(path->flags & RTW_MESH_PATH_FIXED) && (ttl != 0)) {
+		u8 preq_node_flag = RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH;
+
+		RTW_HWMP_DBG("time to refresh root path "MAC_FMT"\n",
+			  MAC_ARG(originator_addr));
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+		if (RTW_SN_LT(path->sn, originator_sn) &&
+		    (path->rann_metric + mshcfg->sane_metric_delta < metric) &&
+		    _rtw_memcmp(bcast_addr, path->rann_snd_addr, ETH_ALEN) == _FALSE) {
+			RTW_HWMP_DBG("Trigger additional check for root "
+				     "confirm PREQ. rann_snd_addr = "MAC_FMT
+				     "add_chk_rann_snd_addr= "MAC_FMT"\n",
+					MAC_ARG(mgmt->addr2),
+					MAC_ARG(path->rann_snd_addr));
+			_rtw_memcpy(path->add_chk_rann_snd_addr,
+				    path->rann_snd_addr, ETH_ALEN);
+			preq_node_flag |= RTW_PREQ_Q_F_CHK;
+			
+		}
+#endif
+		rtw_mesh_queue_preq(path, preq_node_flag);
+		path->last_preq_to_root = rtw_get_current_time();
+	}
+
+	path->sn = originator_sn;
+	path->rann_metric = metric + metric_txsta;
+	path->is_root = _TRUE;
+	/* Recording RANNs sender address to send individually
+	 * addressed PREQs destined for root mesh STA */
+	_rtw_memcpy(path->rann_snd_addr, mgmt->addr2, ETH_ALEN);
+
+	if (root_is_gate) {
+		path->gate_ann_int = interval;
+		path->gate_asked = false;
+		rtw_mesh_path_add_gate(path);
+	} else if (path->is_gate) {
+		enter_critical_bh(&path->state_lock);
+		rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
+		exit_critical_bh(&path->state_lock);
+	}
+
+	if (ttl <= 1) {
+		mshstats->dropped_frames_ttl++;
+		rtw_rcu_read_unlock();
+		return;
+	}
+	ttl--;
+
+	if (mshcfg->dot11MeshForwarding) {
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_RANN, flags, originator_addr,
+					   originator_sn, 0, NULL, 0, bcast_addr,
+					   hopcount, ttl, interval,
+					   metric + metric_txsta, 0, adapter);
+	}
+
+	rtw_rcu_read_unlock();
+}
+
+static u32 rtw_hwmp_route_info_get(_adapter *adapter,
+				   struct rtw_ieee80211_hdr_3addr *mgmt,
+				   const u8 *hwmp_ie, enum rtw_mpath_frame_type action)
+{
+	struct rtw_mesh_path *path;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	BOOLEAN fresh_info;
+	const u8 *originator_addr, *ta;
+	u32 originator_sn, originator_metric;
+	unsigned long originator_lifetime, exp_time;
+	u32 last_hop_metric, new_metric;
+	BOOLEAN process = _TRUE;
+
+	rtw_rcu_read_lock();
+	sta = rtw_get_stainfo(pstapriv, mgmt->addr2);
+	if (!sta) {
+		rtw_rcu_read_unlock();
+		return 0;
+	}
+
+	last_hop_metric = rtw_airtime_link_metric_get(adapter, sta);
+	/* Update and check originator routing info */
+	fresh_info = _TRUE;
+
+	switch (action) {
+	case RTW_MPATH_PREQ:
+		originator_addr = RTW_PREQ_IE_ORIG_ADDR(hwmp_ie);
+		originator_sn = RTW_PREQ_IE_ORIG_SN(hwmp_ie);
+		originator_lifetime = RTW_PREQ_IE_LIFETIME(hwmp_ie);
+		originator_metric = RTW_PREQ_IE_METRIC(hwmp_ie);
+		break;
+	case RTW_MPATH_PREP:
+		/* Note: For coding, the naming is not consist with spec */
+		originator_addr = RTW_PREP_IE_TARGET_ADDR(hwmp_ie);
+		originator_sn = RTW_PREP_IE_TARGET_SN(hwmp_ie);
+		originator_lifetime = RTW_PREP_IE_LIFETIME(hwmp_ie);
+		originator_metric = RTW_PREP_IE_METRIC(hwmp_ie);
+		break;
+	default:
+		rtw_rcu_read_unlock();
+		return 0;
+	}
+	new_metric = originator_metric + last_hop_metric;
+	if (new_metric < originator_metric)
+		new_metric = RTW_MAX_METRIC;
+	exp_time = RTW_TU_TO_EXP_TIME(originator_lifetime);
+
+	if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter))) {
+		process = _FALSE;
+		fresh_info = _FALSE;
+	} else {
+		path = rtw_mesh_path_lookup(adapter, originator_addr);
+		if (path) {
+			enter_critical_bh(&path->state_lock);
+			if (path->flags & RTW_MESH_PATH_FIXED)
+				fresh_info = _FALSE;
+			else if ((path->flags & RTW_MESH_PATH_ACTIVE) &&
+			    (path->flags & RTW_MESH_PATH_SN_VALID)) {
+				if (RTW_SN_GT(path->sn, originator_sn) ||
+				    (path->sn == originator_sn &&
+				     new_metric >= path->metric)) {
+					process = _FALSE;
+					fresh_info = _FALSE;
+				}
+			} else if (!(path->flags & RTW_MESH_PATH_ACTIVE)) {
+				BOOLEAN have_sn, newer_sn, bounced;
+
+				have_sn = path->flags & RTW_MESH_PATH_SN_VALID;
+				newer_sn = have_sn && RTW_SN_GT(originator_sn, path->sn);
+				bounced = have_sn &&
+					  (RTW_SN_DELTA(originator_sn, path->sn) >
+							RTW_MAX_SANE_SN_DELTA);
+
+				if (!have_sn || newer_sn) {
+				} else if (bounced) {
+				} else {
+					process = _FALSE;
+					fresh_info = _FALSE;
+				}
+			}
+		} else {
+			path = rtw_mesh_path_add(adapter, originator_addr);
+			if (IS_ERR(path)) {
+				rtw_rcu_read_unlock();
+				return 0;
+			}
+			enter_critical_bh(&path->state_lock);
+		}
+
+		if (fresh_info) {
+			rtw_mesh_path_assign_nexthop(path, sta);
+			path->flags |= RTW_MESH_PATH_SN_VALID;
+			path->metric = new_metric;
+			path->sn = originator_sn;
+			path->exp_time = rtw_time_after(path->exp_time, exp_time)
+					  ?  path->exp_time : exp_time;
+			rtw_mesh_path_activate(path);
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+			if (path->is_root && (action == RTW_MPATH_PREP)) {
+				_rtw_memcpy(path->rann_snd_addr, 
+				mgmt->addr2, ETH_ALEN);
+				path->rann_metric = new_metric;
+			}
+#endif
+			exit_critical_bh(&path->state_lock);
+			rtw_mesh_path_tx_pending(path);
+		} else
+			exit_critical_bh(&path->state_lock);
+	}
+
+	/* Update and check transmitter routing info */
+	ta = mgmt->addr2;
+	if (rtw_ether_addr_equal(originator_addr, ta))
+		fresh_info = _FALSE;
+	else {
+		fresh_info = _TRUE;
+
+		path = rtw_mesh_path_lookup(adapter, ta);
+		if (path) {
+			enter_critical_bh(&path->state_lock);
+			if ((path->flags & RTW_MESH_PATH_FIXED) ||
+				((path->flags & RTW_MESH_PATH_ACTIVE) &&
+					(last_hop_metric > path->metric)))
+				fresh_info = _FALSE;
+		} else {
+			path = rtw_mesh_path_add(adapter, ta);
+			if (IS_ERR(path)) {
+				rtw_rcu_read_unlock();
+				return 0;
+			}
+			enter_critical_bh(&path->state_lock);
+		}
+
+		if (fresh_info) {
+			rtw_mesh_path_assign_nexthop(path, sta);
+			path->metric = last_hop_metric;
+			path->exp_time = rtw_time_after(path->exp_time, exp_time)
+					  ?  path->exp_time : exp_time;
+			rtw_mesh_path_activate(path);
+			exit_critical_bh(&path->state_lock);
+			rtw_mesh_path_tx_pending(path);
+		} else
+			exit_critical_bh(&path->state_lock);
+	}
+
+	rtw_rcu_read_unlock();
+
+	return process ? new_metric : 0;
+}
+
+static void rtw_mesh_rx_hwmp_frame_cnts(_adapter *adapter, u8 *addr)
+{
+	struct sta_info *sta;
+
+	sta = rtw_get_stainfo(&adapter->stapriv, addr);
+	if (sta)
+		sta->sta_stats.rx_hwmp_pkts++;
+}
+
+void rtw_mesh_rx_path_sel_frame(_adapter *adapter, union recv_frame *rframe)
+{
+	struct mesh_plink_ent *plink = NULL;
+	struct rtw_ieee802_11_elems elems;
+	u32 path_metric;
+	struct rx_pkt_attrib *attrib = &rframe->u.hdr.attrib;
+	u8 *pframe = rframe->u.hdr.rx_data, *start;
+	uint frame_len = rframe->u.hdr.len, left;
+	struct rtw_ieee80211_hdr_3addr *frame_hdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
+	u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+	ParseRes parse_res;
+
+	plink = rtw_mesh_plink_get(adapter, get_addr2_ptr(pframe));
+	if (!plink || plink->plink_state != RTW_MESH_PLINK_ESTAB)
+		return;
+
+	rtw_mesh_rx_hwmp_frame_cnts(adapter, get_addr2_ptr(pframe));
+
+	/* Mesh action frame IE offset = 2 */
+	attrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	left = frame_len - attrib->hdrlen - attrib->iv_len - attrib->icv_len - 2;
+	start = pframe + attrib->hdrlen + 2;
+
+	parse_res = rtw_ieee802_11_parse_elems(start, left, &elems, 1);
+	if (parse_res == ParseFailed)
+		RTW_HWMP_INFO(FUNC_ADPT_FMT" Path Select Frame ParseFailed\n"
+			, FUNC_ADPT_ARG(adapter));
+	else if (parse_res == ParseUnknown)
+		RTW_HWMP_INFO(FUNC_ADPT_FMT" Path Select Frame ParseUnknown\n"
+			, FUNC_ADPT_ARG(adapter));
+
+	if (elems.preq) {
+		if (elems.preq_len != 37)
+			/* Right now we support just 1 destination and no AE */
+			return;
+		path_metric = rtw_hwmp_route_info_get(adapter, frame_hdr, elems.preq,
+						  MPATH_PREQ);
+		if (path_metric)
+			rtw_hwmp_preq_frame_process(adapter, frame_hdr, elems.preq,
+						path_metric);
+	}
+	if (elems.prep) {
+		if (elems.prep_len != 31)
+			/* Right now we support no AE */
+			return;
+		path_metric = rtw_hwmp_route_info_get(adapter, frame_hdr, elems.prep,
+						  MPATH_PREP);
+		if (path_metric)
+			rtw_hwmp_prep_frame_process(adapter, frame_hdr, elems.prep,
+						path_metric);
+	}
+	if (elems.perr) {
+		if (elems.perr_len != 15)
+			/* Right now we support only one destination per PERR */
+			return;
+		rtw_hwmp_perr_frame_process(adapter, frame_hdr, elems.perr);
+	}
+	if (elems.rann)
+		rtw_hwmp_rann_frame_process(adapter, frame_hdr, (struct rtw_ieee80211_rann_ie *)elems.rann);
+}
+
+void rtw_mesh_queue_preq(struct rtw_mesh_path *path, u8 flags)
+{
+	_adapter *adapter = path->adapter;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_preq_queue *preq_node;
+
+	preq_node = rtw_malloc(sizeof(struct rtw_mesh_preq_queue));
+	if (!preq_node) {
+		RTW_HWMP_INFO("could not allocate PREQ node\n");
+		return;
+	}
+
+	enter_critical_bh(&minfo->mesh_preq_queue_lock);
+	if (minfo->preq_queue_len == RTW_MAX_PREQ_QUEUE_LEN) {
+		exit_critical_bh(&minfo->mesh_preq_queue_lock);
+		rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
+		if (rtw_print_ratelimit())
+			RTW_HWMP_INFO("PREQ node queue full\n");
+		return;
+	}
+
+	_rtw_spinlock(&path->state_lock);
+	if (path->flags & RTW_MESH_PATH_REQ_QUEUED) {
+		_rtw_spinunlock(&path->state_lock);
+		exit_critical_bh(&minfo->mesh_preq_queue_lock);
+		rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
+		return;
+	}
+
+	_rtw_memcpy(preq_node->dst, path->dst, ETH_ALEN);
+	preq_node->flags = flags;
+
+	path->flags |= RTW_MESH_PATH_REQ_QUEUED;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	if (flags & RTW_PREQ_Q_F_CHK)
+		path->flags |= RTW_MESH_PATH_ROOT_ADD_CHK;
+#endif
+	if (flags & RTW_PREQ_Q_F_PEER_AKA)
+		path->flags |= RTW_MESH_PATH_PEER_AKA;
+	_rtw_spinunlock(&path->state_lock);
+
+	rtw_list_insert_tail(&preq_node->list, &minfo->preq_queue.list);
+	++minfo->preq_queue_len;
+	exit_critical_bh(&minfo->mesh_preq_queue_lock);
+
+	if (rtw_time_after(rtw_get_current_time(), minfo->last_preq + rtw_min_preq_int_jiff(adapter)))
+		rtw_mesh_work(&adapter->mesh_work);
+
+	else if (rtw_time_before(rtw_get_current_time(), minfo->last_preq)) {
+		/* systime wrapped around issue */
+		minfo->last_preq = rtw_get_current_time() - rtw_min_preq_int_jiff(adapter) - 1;
+		rtw_mesh_work(&adapter->mesh_work);
+	} else
+		rtw_mod_timer(&adapter->mesh_path_timer, minfo->last_preq +
+					rtw_min_preq_int_jiff(adapter) + 1);
+}
+
+static const u8 *rtw_hwmp_preq_da(struct rtw_mesh_path *path,
+			    BOOLEAN is_root_add_chk, BOOLEAN da_is_peer)
+{
+	const u8 *da;
+
+	if (da_is_peer)
+		da = path->dst;
+	else if (path->is_root)
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+		da = is_root_add_chk ? path->add_chk_rann_snd_addr:
+				       path->rann_snd_addr;
+#else
+		da = path->rann_snd_addr;
+#endif
+	else
+		da = bcast_addr;
+
+	return da;
+}
+
+void rtw_mesh_path_start_discovery(_adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_preq_queue *preq_node;
+	struct rtw_mesh_path *path;
+	u8 ttl, target_flags = 0;
+	const u8 *da;
+	u32 lifetime;
+	u8 flags = 0;
+	BOOLEAN is_root_add_chk = _FALSE;
+	BOOLEAN da_is_peer;
+
+	enter_critical_bh(&minfo->mesh_preq_queue_lock);
+	if (!minfo->preq_queue_len ||
+		rtw_time_before(rtw_get_current_time(), minfo->last_preq +
+				rtw_min_preq_int_jiff(adapter))) {
+		exit_critical_bh(&minfo->mesh_preq_queue_lock);
+		return;
+	}
+
+	preq_node = rtw_list_first_entry(&minfo->preq_queue.list,
+			struct rtw_mesh_preq_queue, list);
+	rtw_list_delete(&preq_node->list); /* list_del_init(&preq_node->list); */
+	--minfo->preq_queue_len;
+	exit_critical_bh(&minfo->mesh_preq_queue_lock);
+
+	rtw_rcu_read_lock();
+	path = rtw_mesh_path_lookup(adapter, preq_node->dst);
+	if (!path)
+		goto enddiscovery;
+
+	enter_critical_bh(&path->state_lock);
+	if (path->flags & (RTW_MESH_PATH_DELETED | RTW_MESH_PATH_FIXED)) {
+		exit_critical_bh(&path->state_lock);
+		goto enddiscovery;
+	}
+	path->flags &= ~RTW_MESH_PATH_REQ_QUEUED;
+	if (preq_node->flags & RTW_PREQ_Q_F_START) {
+		if (path->flags & RTW_MESH_PATH_RESOLVING) {
+			exit_critical_bh(&path->state_lock);
+			goto enddiscovery;
+		} else {
+			path->flags &= ~RTW_MESH_PATH_RESOLVED;
+			path->flags |= RTW_MESH_PATH_RESOLVING;
+			path->discovery_retries = 0;
+			path->discovery_timeout = rtw_disc_timeout_jiff(adapter);
+		}
+	} else if (!(path->flags & RTW_MESH_PATH_RESOLVING) ||
+			path->flags & RTW_MESH_PATH_RESOLVED) {
+		path->flags &= ~RTW_MESH_PATH_RESOLVING;
+		exit_critical_bh(&path->state_lock);
+		goto enddiscovery;
+	}
+
+	minfo->last_preq = rtw_get_current_time();
+
+	if (rtw_time_after(rtw_get_current_time(), minfo->last_sn_update +
+				rtw_net_traversal_jiffies(adapter)) ||
+	    rtw_time_before(rtw_get_current_time(), minfo->last_sn_update)) {
+		++minfo->sn;
+		minfo->last_sn_update = rtw_get_current_time();
+	}
+	lifetime = rtw_default_lifetime(adapter);
+	ttl = mshcfg->element_ttl;
+	if (ttl == 0) {
+		minfo->mshstats.dropped_frames_ttl++;
+		exit_critical_bh(&path->state_lock);
+		goto enddiscovery;
+	}
+
+	if (preq_node->flags & RTW_PREQ_Q_F_REFRESH)
+		target_flags |= RTW_IEEE80211_PREQ_TO_FLAG;
+	else
+		target_flags &= ~RTW_IEEE80211_PREQ_TO_FLAG;
+
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	is_root_add_chk = !!(path->flags & RTW_MESH_PATH_ROOT_ADD_CHK);
+#endif
+	da_is_peer = !!(path->flags & RTW_MESH_PATH_PEER_AKA);
+	exit_critical_bh(&path->state_lock);
+
+	da = rtw_hwmp_preq_da(path, is_root_add_chk, da_is_peer);
+
+#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
+	flags = (mshcfg->dot11MeshGateAnnouncementProtocol)
+		? RTW_IEEE80211_PREQ_IS_GATE_FLAG : 0;
+#endif
+	rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, adapter_mac_addr(adapter), minfo->sn,
+				   target_flags, path->dst, path->sn, da, 0,
+				   ttl, lifetime, 0, minfo->preq_id++, adapter);
+	rtw_mod_timer(&path->timer, rtw_get_current_time() + path->discovery_timeout);
+
+enddiscovery:
+	rtw_rcu_read_unlock();
+	rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
+}
+
+void rtw_mesh_path_timer(void *ctx)
+{
+	struct rtw_mesh_path *path = (void *) ctx;
+	_adapter *adapter = path->adapter;
+	int ret;
+	u8 retry = 0;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+#endif
+	/* TBD: Proctect for suspend */
+#if 0
+	if (suspending)
+		return;
+#endif
+	enter_critical_bh(&path->state_lock);
+	if (path->flags & RTW_MESH_PATH_RESOLVED ||
+			(!(path->flags & RTW_MESH_PATH_RESOLVING))) {
+		path->flags &= ~(RTW_MESH_PATH_RESOLVING |
+				 RTW_MESH_PATH_RESOLVED |
+				 RTW_MESH_PATH_ROOT_ADD_CHK |
+				 RTW_MESH_PATH_PEER_AKA);
+		exit_critical_bh(&path->state_lock);
+	} else if (path->discovery_retries < rtw_max_preq_retries(adapter)) {
+		++path->discovery_retries;
+		path->discovery_timeout *= 2;
+		path->flags &= ~RTW_MESH_PATH_REQ_QUEUED;
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+		if (path->discovery_retries > mshcfg->max_root_add_chk_cnt)
+			path->flags &= ~RTW_MESH_PATH_ROOT_ADD_CHK;
+#endif
+		if (path->gate_asked)
+			retry |= RTW_PREQ_Q_F_REFRESH;
+
+		exit_critical_bh(&path->state_lock);
+		rtw_mesh_queue_preq(path, retry);
+	} else {
+		path->flags &= ~(RTW_MESH_PATH_RESOLVING |
+				  RTW_MESH_PATH_RESOLVED |
+				  RTW_MESH_PATH_REQ_QUEUED |
+				  RTW_MESH_PATH_ROOT_ADD_CHK |
+				  RTW_MESH_PATH_PEER_AKA);
+		path->exp_time = rtw_get_current_time();
+		exit_critical_bh(&path->state_lock);
+		if (!path->is_gate && rtw_mesh_gate_num(adapter) > 0) {
+			ret = rtw_mesh_path_send_to_gates(path);
+			if (ret)
+				RTW_HWMP_DBG("no gate was reachable\n");
+		} else
+			rtw_mesh_path_flush_pending(path);
+	}
+}
+
+
+void rtw_mesh_path_tx_root_frame(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	u32 interval = mshcfg->dot11MeshHWMPRannInterval;
+	u8 flags, target_flags = 0;
+
+	flags = (mshcfg->dot11MeshGateAnnouncementProtocol)
+			? RTW_RANN_FLAG_IS_GATE : 0;
+
+	switch (mshcfg->dot11MeshHWMPRootMode) {
+	case RTW_IEEE80211_PROACTIVE_RANN:
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_RANN, flags, adapter_mac_addr(adapter),
+					   ++minfo->sn, 0, NULL, 0, bcast_addr,
+					   0, mshcfg->element_ttl,
+					   interval, 0, 0, adapter);
+		break;
+	case RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP:
+		flags |= RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG;
+	case RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP:
+		interval = mshcfg->dot11MeshHWMPactivePathToRootTimeout;
+		target_flags |= RTW_IEEE80211_PREQ_TO_FLAG |
+				RTW_IEEE80211_PREQ_USN_FLAG;
+		rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, adapter_mac_addr(adapter),
+					   ++minfo->sn, target_flags,
+					   (u8 *) bcast_addr, 0, bcast_addr,
+					   0, mshcfg->element_ttl, interval,
+					   0, minfo->preq_id++, adapter);
+		break;
+	default:
+		RTW_HWMP_INFO("Proactive mechanism not supported\n");
+		return;
+	}
+}
+
+void rtw_mesh_work(_workitem *work)
+{
+	/* use kernel global workqueue */
+	_set_workitem(work);
+}
+
+void rtw_ieee80211_mesh_path_timer(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
+	rtw_mesh_work(&adapter->mesh_work);
+}
+
+void rtw_ieee80211_mesh_path_root_timer(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
+
+	rtw_set_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
+
+	rtw_mesh_work(&adapter->mesh_work);
+}
+
+static void rtw_ieee80211_mesh_rootpath(_adapter *adapter)
+{
+	u32 interval;
+
+	rtw_mesh_path_tx_root_frame(adapter);
+
+	if (adapter->mesh_cfg.dot11MeshHWMPRootMode == RTW_IEEE80211_PROACTIVE_RANN)
+		interval = adapter->mesh_cfg.dot11MeshHWMPRannInterval;
+	else
+		interval = adapter->mesh_cfg.dot11MeshHWMProotInterval;
+
+	rtw_mod_timer(&adapter->mesh_path_root_timer,
+		  RTW_TU_TO_EXP_TIME(interval));
+}
+
+BOOLEAN rtw_ieee80211_mesh_root_setup(_adapter *adapter)
+{
+	BOOLEAN root_enabled = _FALSE;
+
+	if (adapter->mesh_cfg.dot11MeshHWMPRootMode > RTW_IEEE80211_ROOTMODE_ROOT) {
+		rtw_set_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
+		root_enabled = _TRUE;
+	}
+	else {
+		rtw_clear_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
+		/* stop running timer */
+		_cancel_timer_ex(&adapter->mesh_path_root_timer);
+		root_enabled = _FALSE;
+	}
+
+	return root_enabled;
+}
+
+void rtw_mesh_work_hdl(_workitem *work)
+{
+	_adapter *adapter = container_of(work, _adapter, mesh_work);
+
+	while(adapter->mesh_info.preq_queue_len) {
+		if (rtw_time_after(rtw_get_current_time(),
+		       adapter->mesh_info.last_preq + rtw_min_preq_int_jiff(adapter)))
+		       /* It will consume preq_queue_len */
+		       rtw_mesh_path_start_discovery(adapter);
+		else {
+			struct rtw_mesh_info *minfo = &adapter->mesh_info;
+
+			rtw_mod_timer(&adapter->mesh_path_timer,
+				minfo->last_preq + rtw_min_preq_int_jiff(adapter) + 1);
+			break;
+		}
+	}
+
+	if (rtw_test_and_clear_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags))
+		rtw_ieee80211_mesh_rootpath(adapter);
+}
+
+#ifndef RTW_PER_CMD_SUPPORT_FW
+static void rtw_update_metric_directly(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	u8 i;
+
+	for (i = 0; i < macid_ctl->num; i++) {
+		u8 role;
+		role = GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[i]);
+		if (role == H2C_MSR_ROLE_MESH) {
+			struct sta_info *sta = macid_ctl->sta[i];
+			u8 rate_idx, sgi, bw;
+			u32 rate;
+
+			if (!sta)
+				continue;
+			rate_idx = rtw_get_current_tx_rate(adapter, sta);
+			sgi = rtw_get_current_tx_sgi(adapter, sta);
+			bw = sta->cmn.bw_mode;
+			rate = rtw_desc_rate_to_bitrate(bw, rate_idx, sgi);
+			sta->metrics.data_rate = rate;
+		}
+	}
+}
+#endif
+
+void rtw_mesh_atlm_param_req_timer(void *ctx)
+{
+	_adapter *adapter = (_adapter *)ctx;
+	u8 ret = _FAIL;
+
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	ret = rtw_req_per_cmd(adapter);
+	if (ret == _FAIL)
+		RTW_HWMP_INFO("rtw_req_per_cmd fail\n");
+#else
+	rtw_update_metric_directly(adapter);
+#endif
+	_set_timer(&adapter->mesh_atlm_param_req_timer, RTW_ATLM_REQ_CYCLE);
+}
+
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_hwmp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_hwmp.h
new file mode 100644
index 000000000000..1702bf22f4df
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_hwmp.h
@@ -0,0 +1,61 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_HWMP_H_
+#define __RTW_MESH_HWMP_H_
+
+#ifndef DBG_RTW_HWMP
+#define DBG_RTW_HWMP 0
+#endif
+#if DBG_RTW_HWMP
+#define RTW_HWMP_DBG(fmt, arg...) RTW_PRINT(fmt, ##arg)
+#else
+#define RTW_HWMP_DBG(fmt, arg...) RTW_DBG(fmt, ##arg)
+#endif
+
+#ifndef INFO_RTW_HWMP
+#define INFO_RTW_HWMP 0
+#endif
+#if INFO_RTW_HWMP
+#define RTW_HWMP_INFO(fmt, arg...) RTW_PRINT(fmt, ##arg)
+#else
+#define RTW_HWMP_INFO(fmt, arg...) RTW_INFO(fmt, ##arg)
+#endif
+
+
+void rtw_ewma_err_rate_init(struct rtw_ewma_err_rate *e);
+unsigned long rtw_ewma_err_rate_read(struct rtw_ewma_err_rate *e);
+void rtw_ewma_err_rate_add(struct rtw_ewma_err_rate *e, unsigned long val);
+int rtw_mesh_path_error_tx(_adapter *adapter,
+			   u8 ttl, const u8 *target, u32 target_sn,
+			   u16 target_rcode, const u8 *ra);
+void rtw_ieee80211s_update_metric(_adapter *adapter, u8 mac_id,
+				  u8 per, u8 rate,
+				  u8 bw, u8 total_pkt);
+void rtw_mesh_rx_path_sel_frame(_adapter *adapter, union recv_frame *rframe);
+void rtw_mesh_queue_preq(struct rtw_mesh_path *mpath, u8 flags);
+void rtw_mesh_path_start_discovery(_adapter *adapter);
+void rtw_mesh_path_timer(void *ctx);
+void rtw_mesh_path_tx_root_frame(_adapter *adapter);
+void rtw_mesh_work_hdl(_workitem *work);
+void rtw_ieee80211_mesh_path_timer(void *ctx);
+void rtw_ieee80211_mesh_path_root_timer(void *ctx);
+BOOLEAN rtw_ieee80211_mesh_root_setup(_adapter *adapter);
+void rtw_mesh_work(_workitem *work);
+void rtw_mesh_atlm_param_req_timer(void *ctx);
+
+#endif /* __RTW_MESH_HWMP_H_ */
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_pathtbl.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_pathtbl.c
new file mode 100644
index 000000000000..fdb9143c3b4c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_pathtbl.c
@@ -0,0 +1,1238 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_PATHTBL_C_
+
+#ifdef CONFIG_RTW_MESH
+#include <drv_types.h>
+#include <linux/jhash.h>
+
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+static void rtw_mpath_free_rcu(struct rtw_mesh_path *mpath)
+{
+	kfree_rcu(mpath, rcu);
+	rtw_mstat_update(MSTAT_TYPE_PHY, MSTAT_FREE, sizeof(struct rtw_mesh_path));
+}
+#else
+static void rtw_mpath_free_rcu_callback(rtw_rcu_head *head)
+{
+	struct rtw_mesh_path *mpath;
+
+	mpath = container_of(head, struct rtw_mesh_path, rcu);
+	rtw_mfree(mpath, sizeof(struct rtw_mesh_path));
+}
+
+static void rtw_mpath_free_rcu(struct rtw_mesh_path *mpath)
+{
+	call_rcu(&mpath->rcu, rtw_mpath_free_rcu_callback);
+}
+#endif
+#endif /* PLATFORM_LINUX */
+
+static void rtw_mesh_path_free_rcu(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath);
+
+static u32 rtw_mesh_table_hash(const void *addr, u32 len, u32 seed)
+{
+	/* Use last four bytes of hw addr as hash index */
+	return jhash_1word(*(u32 *)(addr+2), seed);
+}
+
+static const rtw_rhashtable_params rtw_mesh_rht_params = {
+	.nelem_hint = 2,
+	.automatic_shrinking = true,
+	.key_len = ETH_ALEN,
+	.key_offset = offsetof(struct rtw_mesh_path, dst),
+	.head_offset = offsetof(struct rtw_mesh_path, rhash),
+	.hashfn = rtw_mesh_table_hash,
+};
+
+static inline bool rtw_mpath_expired(struct rtw_mesh_path *mpath)
+{
+	return (mpath->flags & RTW_MESH_PATH_ACTIVE) &&
+	       rtw_time_after(rtw_get_current_time(), mpath->exp_time) &&
+	       !(mpath->flags & RTW_MESH_PATH_FIXED);
+}
+
+static void rtw_mesh_path_rht_free(void *ptr, void *tblptr)
+{
+	struct rtw_mesh_path *mpath = ptr;
+	struct rtw_mesh_table *tbl = tblptr;
+
+	rtw_mesh_path_free_rcu(tbl, mpath);
+}
+
+static struct rtw_mesh_table *rtw_mesh_table_alloc(void)
+{
+	struct rtw_mesh_table *newtbl;
+
+	newtbl = rtw_malloc(sizeof(struct rtw_mesh_table));
+	if (!newtbl)
+		return NULL;
+
+	rtw_hlist_head_init(&newtbl->known_gates);
+	ATOMIC_SET(&newtbl->entries,  0);
+	_rtw_spinlock_init(&newtbl->gates_lock);
+
+	return newtbl;
+}
+
+static void rtw_mesh_table_free(struct rtw_mesh_table *tbl)
+{
+	rtw_rhashtable_free_and_destroy(&tbl->rhead,
+				    rtw_mesh_path_rht_free, tbl);
+	rtw_mfree(tbl, sizeof(struct rtw_mesh_table));
+}
+
+/**
+ *
+ * rtw_mesh_path_assign_nexthop - update mesh path next hop
+ *
+ * @mpath: mesh path to update
+ * @sta: next hop to assign
+ *
+ * Locking: mpath->state_lock must be held when calling this function
+ */
+void rtw_mesh_path_assign_nexthop(struct rtw_mesh_path *mpath, struct sta_info *sta)
+{
+	struct xmit_frame *xframe;
+	_list *list, *head;
+
+	rtw_rcu_assign_pointer(mpath->next_hop, sta);
+
+	enter_critical_bh(&mpath->frame_queue.lock);
+	head = &mpath->frame_queue.queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+		_rtw_memcpy(xframe->attrib.ra, sta->cmn.mac_addr, ETH_ALEN);
+	}
+
+	exit_critical_bh(&mpath->frame_queue.lock);
+}
+
+static void rtw_prepare_for_gate(struct xmit_frame *xframe, char *dst_addr,
+			     struct rtw_mesh_path *gate_mpath)
+{
+	struct pkt_attrib *attrib = &xframe->attrib;
+	char *next_hop;
+
+	if (attrib->mesh_frame_mode == MESH_UCAST_DATA)
+		attrib->mesh_frame_mode = MESH_UCAST_PX_DATA;
+
+	/* update next hop */
+	rtw_rcu_read_lock();
+	next_hop = rtw_rcu_dereference(gate_mpath->next_hop)->cmn.mac_addr;
+	_rtw_memcpy(attrib->ra, next_hop, ETH_ALEN);
+	rtw_rcu_read_unlock();
+	_rtw_memcpy(attrib->mda, dst_addr, ETH_ALEN);
+}
+
+/**
+ *
+ * rtw_mesh_path_move_to_queue - Move or copy frames from one mpath queue to another
+ *
+ * This function is used to transfer or copy frames from an unresolved mpath to
+ * a gate mpath.  The function also adds the Address Extension field and
+ * updates the next hop.
+ *
+ * If a frame already has an Address Extension field, only the next hop and
+ * destination addresses are updated.
+ *
+ * The gate mpath must be an active mpath with a valid mpath->next_hop.
+ *
+ * @mpath: An active mpath the frames will be sent to (i.e. the gate)
+ * @from_mpath: The failed mpath
+ * @copy: When true, copy all the frames to the new mpath queue.  When false,
+ * move them.
+ */
+static void rtw_mesh_path_move_to_queue(struct rtw_mesh_path *gate_mpath,
+				    struct rtw_mesh_path *from_mpath,
+				    bool copy)
+{
+	struct xmit_frame *fskb;
+	_list *list, *head;
+	_list failq;
+	u32 failq_len;
+	_irqL flags;
+
+	if (rtw_warn_on(gate_mpath == from_mpath))
+		return;
+	if (rtw_warn_on(!gate_mpath->next_hop))
+		return;
+
+	_rtw_init_listhead(&failq);
+
+	_enter_critical_bh(&from_mpath->frame_queue.lock, &flags);
+	rtw_list_splice_init(&from_mpath->frame_queue.queue, &failq);
+	failq_len = from_mpath->frame_queue_len;
+	from_mpath->frame_queue_len = 0;
+	_exit_critical_bh(&from_mpath->frame_queue.lock, &flags);
+
+	head = &failq;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		if (gate_mpath->frame_queue_len >= RTW_MESH_FRAME_QUEUE_LEN) {
+			RTW_MPATH_DBG(FUNC_ADPT_FMT" mpath queue for gate %pM is full!\n"
+				, FUNC_ADPT_ARG(gate_mpath->adapter), gate_mpath->dst);
+			break;
+		}
+
+		fskb = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+
+		rtw_list_delete(&fskb->list);
+		failq_len--;
+		rtw_prepare_for_gate(fskb, gate_mpath->dst, gate_mpath);
+		_enter_critical_bh(&gate_mpath->frame_queue.lock, &flags);
+		rtw_list_insert_tail(&fskb->list, get_list_head(&gate_mpath->frame_queue));
+		gate_mpath->frame_queue_len++;
+		_exit_critical_bh(&gate_mpath->frame_queue.lock, &flags);
+
+		#if 0 /* TODO: copy */
+		skb = rtw_skb_copy(fskb);
+		if (rtw_warn_on(!skb))
+			break;
+
+		rtw_prepare_for_gate(skb, gate_mpath->dst, gate_mpath);
+		skb_queue_tail(&gate_mpath->frame_queue, skb);
+
+		if (copy)
+			continue;
+
+		__skb_unlink(fskb, &failq);
+		rtw_skb_free(fskb);
+		#endif
+	}
+
+	RTW_MPATH_DBG(FUNC_ADPT_FMT" mpath queue for gate %pM has %d frames\n"
+		, FUNC_ADPT_ARG(gate_mpath->adapter), gate_mpath->dst, gate_mpath->frame_queue_len);
+
+	if (!copy)
+		return;
+
+	_enter_critical_bh(&from_mpath->frame_queue.lock, &flags);
+	rtw_list_splice(&failq, &from_mpath->frame_queue.queue);
+	from_mpath->frame_queue_len += failq_len;
+	_exit_critical_bh(&from_mpath->frame_queue.lock, &flags);
+}
+
+
+static struct rtw_mesh_path *rtw_mpath_lookup(struct rtw_mesh_table *tbl, const u8 *dst)
+{
+	struct rtw_mesh_path *mpath;
+
+	if (!tbl)
+		return NULL;
+
+	mpath = rtw_rhashtable_lookup_fast(&tbl->rhead, dst, rtw_mesh_rht_params);
+
+	if (mpath && rtw_mpath_expired(mpath)) {
+		enter_critical_bh(&mpath->state_lock);
+		mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
+		exit_critical_bh(&mpath->state_lock);
+	}
+	return mpath;
+}
+
+/**
+ * rtw_mesh_path_lookup - look up a path in the mesh path table
+ * @sdata: local subif
+ * @dst: hardware address (ETH_ALEN length) of destination
+ *
+ * Returns: pointer to the mesh path structure, or NULL if not found
+ *
+ * Locking: must be called within a read rcu section.
+ */
+struct rtw_mesh_path *
+rtw_mesh_path_lookup(_adapter *adapter, const u8 *dst)
+{
+	return rtw_mpath_lookup(adapter->mesh_info.mesh_paths, dst);
+}
+
+struct rtw_mesh_path *
+rtw_mpp_path_lookup(_adapter *adapter, const u8 *dst)
+{
+	return rtw_mpath_lookup(adapter->mesh_info.mpp_paths, dst);
+}
+
+static struct rtw_mesh_path *
+__rtw_mesh_path_lookup_by_idx(struct rtw_mesh_table *tbl, int idx)
+{
+	int i = 0, ret;
+	struct rtw_mesh_path *mpath = NULL;
+	rtw_rhashtable_iter iter;
+
+	if (!tbl)
+		return NULL;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return NULL;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto err;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		if (i++ == idx)
+			break;
+	}
+err:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+
+	if (IS_ERR(mpath) || !mpath)
+		return NULL;
+
+	if (rtw_mpath_expired(mpath)) {
+		enter_critical_bh(&mpath->state_lock);
+		mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
+		exit_critical_bh(&mpath->state_lock);
+	}
+	return mpath;
+}
+
+/**
+ * rtw_mesh_path_lookup_by_idx - look up a path in the mesh path table by its index
+ * @idx: index
+ * @sdata: local subif, or NULL for all entries
+ *
+ * Returns: pointer to the mesh path structure, or NULL if not found.
+ *
+ * Locking: must be called within a read rcu section.
+ */
+struct rtw_mesh_path *
+rtw_mesh_path_lookup_by_idx(_adapter *adapter, int idx)
+{
+	return __rtw_mesh_path_lookup_by_idx(adapter->mesh_info.mesh_paths, idx);
+}
+
+void dump_mpath(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_path *mpath;
+	int idx = 0;
+	char dst[ETH_ALEN];
+	char next_hop[ETH_ALEN];
+	u32 sn, metric, qlen;
+	u32 exp_ms = 0, dto_ms;
+	u8 drty;
+	enum rtw_mesh_path_flags flags;
+
+	RTW_PRINT_SEL(sel, "%-17s %-17s %-10s %-10s %-4s %-6s %-6s %-4s flags\n"
+		, "dst", "next_hop", "sn", "metric", "qlen", "exp_ms", "dto_ms", "drty"
+	);
+
+	do {
+		rtw_rcu_read_lock();
+
+		mpath = rtw_mesh_path_lookup_by_idx(adapter, idx);
+		if (mpath) {
+			_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+			_rtw_memcpy(next_hop, mpath->next_hop->cmn.mac_addr, ETH_ALEN);
+			sn = mpath->sn;
+			metric = mpath->metric;
+			qlen = mpath->frame_queue_len;
+			if (rtw_time_after(mpath->exp_time, rtw_get_current_time()))
+				exp_ms = rtw_get_remaining_time_ms(mpath->exp_time);
+			dto_ms = rtw_systime_to_ms(mpath->discovery_timeout);
+			drty = mpath->discovery_retries;
+			flags = mpath->flags;
+		}
+
+		rtw_rcu_read_unlock();
+
+		if (mpath) {
+			RTW_PRINT_SEL(sel, MAC_FMT" "MAC_FMT" %10u %10u %4u %6u %6u %4u%s%s%s%s%s\n"
+				, MAC_ARG(dst), MAC_ARG(next_hop), sn, metric, qlen
+				, exp_ms < 999999 ? exp_ms : 999999
+				, dto_ms < 999999 ? dto_ms : 999999
+				, drty
+				, (flags & RTW_MESH_PATH_ACTIVE) ? " ACT" : ""
+				, (flags & RTW_MESH_PATH_RESOLVING) ? " RSVING" : ""
+				, (flags & RTW_MESH_PATH_SN_VALID) ? " SN_VALID" : ""
+				, (flags & RTW_MESH_PATH_FIXED) ?  " FIXED" : ""
+				, (flags & RTW_MESH_PATH_RESOLVED) ? " RSVED" : ""
+			);
+		}
+
+		idx++;
+	} while (mpath);
+}
+
+/**
+ * rtw_mpp_path_lookup_by_idx - look up a path in the proxy path table by its index
+ * @idx: index
+ * @sdata: local subif, or NULL for all entries
+ *
+ * Returns: pointer to the proxy path structure, or NULL if not found.
+ *
+ * Locking: must be called within a read rcu section.
+ */
+struct rtw_mesh_path *
+rtw_mpp_path_lookup_by_idx(_adapter *adapter, int idx)
+{
+	return __rtw_mesh_path_lookup_by_idx(adapter->mesh_info.mpp_paths, idx);
+}
+
+/**
+ * rtw_mesh_path_add_gate - add the given mpath to a mesh gate to our path table
+ * @mpath: gate path to add to table
+ */
+int rtw_mesh_path_add_gate(struct rtw_mesh_path *mpath)
+{
+	struct rtw_mesh_cfg *mcfg;
+	struct rtw_mesh_info *minfo;
+	struct rtw_mesh_table *tbl;
+	int err, ori_num_gates;
+
+	rtw_rcu_read_lock();
+	tbl = mpath->adapter->mesh_info.mesh_paths;
+	if (!tbl) {
+		err = -ENOENT;
+		goto err_rcu;
+	}
+
+	enter_critical_bh(&mpath->state_lock);
+	mcfg = &mpath->adapter->mesh_cfg;
+	mpath->gate_timeout = rtw_get_current_time() +
+			      rtw_ms_to_systime(mcfg->path_gate_timeout_factor *
+					        mpath->gate_ann_int);
+	if (mpath->is_gate) {
+		err = -EEXIST;
+		exit_critical_bh(&mpath->state_lock);
+		goto err_rcu;
+	}
+
+	minfo = &mpath->adapter->mesh_info;
+	mpath->is_gate = true;
+	_rtw_spinlock(&tbl->gates_lock);
+	ori_num_gates = minfo->num_gates;
+	minfo->num_gates++;
+	rtw_hlist_add_head_rcu(&mpath->gate_list, &tbl->known_gates);
+
+	if (ori_num_gates == 0
+		|| rtw_macaddr_is_larger(mpath->dst, minfo->max_addr_gate->dst)
+	) {
+		minfo->max_addr_gate = mpath;
+		minfo->max_addr_gate_is_larger_than_self =
+			rtw_macaddr_is_larger(mpath->dst, adapter_mac_addr(mpath->adapter));
+	}
+
+	_rtw_spinunlock(&tbl->gates_lock);
+
+	exit_critical_bh(&mpath->state_lock);
+
+	if (ori_num_gates == 0) {
+		update_beacon(mpath->adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE);
+		#if CONFIG_RTW_MESH_CTO_MGATE_CARRIER
+		if (!rtw_mesh_cto_mgate_required(mpath->adapter))
+			rtw_netif_carrier_on(mpath->adapter->pnetdev);
+		#endif
+	}
+
+	RTW_MPATH_DBG(
+		  FUNC_ADPT_FMT" Mesh path: Recorded new gate: %pM. %d known gates\n",
+		  FUNC_ADPT_ARG(mpath->adapter),
+		  mpath->dst, mpath->adapter->mesh_info.num_gates);
+	err = 0;
+err_rcu:
+	rtw_rcu_read_unlock();
+	return err;
+}
+
+/**
+ * rtw_mesh_gate_del - remove a mesh gate from the list of known gates
+ * @tbl: table which holds our list of known gates
+ * @mpath: gate mpath
+ */
+void rtw_mesh_gate_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath)
+{
+	struct rtw_mesh_cfg *mcfg;
+	struct rtw_mesh_info *minfo;
+	int ori_num_gates;
+
+	rtw_lockdep_assert_held(&mpath->state_lock);
+	if (!mpath->is_gate)
+		return;
+
+	mcfg = &mpath->adapter->mesh_cfg;
+	minfo = &mpath->adapter->mesh_info;
+
+	mpath->is_gate = false;
+	enter_critical_bh(&tbl->gates_lock);
+	rtw_hlist_del_rcu(&mpath->gate_list);
+	ori_num_gates = minfo->num_gates;
+	minfo->num_gates--;
+
+	if (ori_num_gates == 1) {
+		minfo->max_addr_gate = NULL;
+		minfo->max_addr_gate_is_larger_than_self = 0;
+	} else if (minfo->max_addr_gate == mpath) {
+		struct rtw_mesh_path *gate, *max_addr_gate = NULL;
+		rtw_hlist_node *node;
+
+		rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+			if (!max_addr_gate || rtw_macaddr_is_larger(gate->dst, max_addr_gate->dst))
+				max_addr_gate = gate;
+		}
+		minfo->max_addr_gate = max_addr_gate;
+		minfo->max_addr_gate_is_larger_than_self =
+			rtw_macaddr_is_larger(max_addr_gate->dst, adapter_mac_addr(mpath->adapter));
+	}
+
+	exit_critical_bh(&tbl->gates_lock);
+
+	if (ori_num_gates == 1) {
+		update_beacon(mpath->adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE);
+		#if CONFIG_RTW_MESH_CTO_MGATE_CARRIER
+		if (rtw_mesh_cto_mgate_required(mpath->adapter))
+			rtw_netif_carrier_off(mpath->adapter->pnetdev);
+		#endif
+	}
+
+	RTW_MPATH_DBG(
+		  FUNC_ADPT_FMT" Mesh path: Deleted gate: %pM. %d known gates\n",
+		  FUNC_ADPT_ARG(mpath->adapter),
+		  mpath->dst, mpath->adapter->mesh_info.num_gates);
+}
+
+/**
+ * rtw_mesh_gate_search - search a mesh gate from the list of known gates
+ * @tbl: table which holds our list of known gates
+ * @addr: address of gate
+ */
+bool rtw_mesh_gate_search(struct rtw_mesh_table *tbl, const u8 *addr)
+{
+	struct rtw_mesh_path *gate;
+	rtw_hlist_node *node;
+	bool exist = 0;
+
+	rtw_rcu_read_lock();
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		if (_rtw_memcmp(gate->dst, addr, ETH_ALEN) == _TRUE) {
+			exist = 1;
+			break;
+		}
+	}
+
+	rtw_rcu_read_unlock();
+
+	return exist;
+}
+
+/**
+ * rtw_mesh_gate_num - number of gates known to this interface
+ * @sdata: subif data
+ */
+int rtw_mesh_gate_num(_adapter *adapter)
+{
+	return adapter->mesh_info.num_gates;
+}
+
+bool rtw_mesh_is_primary_gate(_adapter *adapter)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+
+	return mcfg->dot11MeshGateAnnouncementProtocol
+		&& !minfo->max_addr_gate_is_larger_than_self;
+}
+
+void dump_known_gates(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_table *tbl;
+	struct rtw_mesh_path *gate;
+	rtw_hlist_node *node;
+
+	if (!rtw_mesh_gate_num(adapter))
+		goto exit;
+
+	rtw_rcu_read_lock();
+
+	tbl = minfo->mesh_paths;
+	if (!tbl)
+		goto unlock;
+
+	RTW_PRINT_SEL(sel, "num:%d\n", rtw_mesh_gate_num(adapter));
+
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		RTW_PRINT_SEL(sel, "%c"MAC_FMT"\n"
+			, gate == minfo->max_addr_gate ? '*' : ' '
+			, MAC_ARG(gate->dst));
+	}
+
+unlock:
+	rtw_rcu_read_unlock();
+exit:
+	return;
+}
+
+static
+struct rtw_mesh_path *rtw_mesh_path_new(_adapter *adapter,
+				const u8 *dst)
+{
+	struct rtw_mesh_path *new_mpath;
+
+	new_mpath = rtw_zmalloc(sizeof(struct rtw_mesh_path));
+	if (!new_mpath)
+		return NULL;
+
+	_rtw_memcpy(new_mpath->dst, dst, ETH_ALEN);
+	_rtw_memset(new_mpath->rann_snd_addr, 0xFF, ETH_ALEN);
+	new_mpath->is_root = false;
+	new_mpath->adapter = adapter;
+	new_mpath->flags = 0;
+	new_mpath->gate_asked = false;
+	_rtw_init_queue(&new_mpath->frame_queue);
+	new_mpath->frame_queue_len = 0;
+	new_mpath->exp_time = rtw_get_current_time();
+	_rtw_spinlock_init(&new_mpath->state_lock);
+	rtw_init_timer(&new_mpath->timer, adapter, rtw_mesh_path_timer, new_mpath);
+
+	return new_mpath;
+}
+
+/**
+ * rtw_mesh_path_add - allocate and add a new path to the mesh path table
+ * @dst: destination address of the path (ETH_ALEN length)
+ * @sdata: local subif
+ *
+ * Returns: 0 on success
+ *
+ * State: the initial state of the new path is set to 0
+ */
+struct rtw_mesh_path *rtw_mesh_path_add(_adapter *adapter,
+				const u8 *dst)
+{
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
+	struct rtw_mesh_path *mpath, *new_mpath;
+	int ret;
+
+	if (!tbl)
+		return ERR_PTR(-ENOTSUPP);
+
+	if (_rtw_memcmp(dst, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
+		/* never add ourselves as neighbours */
+		return ERR_PTR(-ENOTSUPP);
+
+	if (is_multicast_mac_addr(dst))
+		return ERR_PTR(-ENOTSUPP);
+
+	if (ATOMIC_INC_UNLESS(&adapter->mesh_info.mpaths, RTW_MESH_MAX_MPATHS) == 0)
+		return ERR_PTR(-ENOSPC);
+
+	new_mpath = rtw_mesh_path_new(adapter, dst);
+	if (!new_mpath)
+		return ERR_PTR(-ENOMEM);
+
+	do {
+		ret = rtw_rhashtable_lookup_insert_fast(&tbl->rhead,
+						    &new_mpath->rhash,
+						    rtw_mesh_rht_params);
+
+		if (ret == -EEXIST)
+			mpath = rtw_rhashtable_lookup_fast(&tbl->rhead,
+						       dst,
+						       rtw_mesh_rht_params);
+
+	} while (unlikely(ret == -EEXIST && !mpath));
+
+	if (ret && ret != -EEXIST)
+		return ERR_PTR(ret);
+
+	/* At this point either new_mpath was added, or we found a
+	 * matching entry already in the table; in the latter case
+	 * free the unnecessary new entry.
+	 */
+	if (ret == -EEXIST) {
+		rtw_mfree(new_mpath, sizeof(struct rtw_mesh_path));
+		new_mpath = mpath;
+	}
+	adapter->mesh_info.mesh_paths_generation++;
+	return new_mpath;
+}
+
+int rtw_mpp_path_add(_adapter *adapter,
+		 const u8 *dst, const u8 *mpp)
+{
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mpp_paths;
+	struct rtw_mesh_path *new_mpath;
+	int ret;
+
+	if (!tbl)
+		return -ENOTSUPP;
+
+	if (_rtw_memcmp(dst, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
+		/* never add ourselves as neighbours */
+		return -ENOTSUPP;
+
+	if (is_multicast_mac_addr(dst))
+		return -ENOTSUPP;
+
+	new_mpath = rtw_mesh_path_new(adapter, dst);
+
+	if (!new_mpath)
+		return -ENOMEM;
+
+	_rtw_memcpy(new_mpath->mpp, mpp, ETH_ALEN);
+	ret = rtw_rhashtable_lookup_insert_fast(&tbl->rhead,
+					    &new_mpath->rhash,
+					    rtw_mesh_rht_params);
+
+	adapter->mesh_info.mpp_paths_generation++;
+	return ret;
+}
+
+void dump_mpp(void *sel, _adapter *adapter)
+{
+	struct rtw_mesh_path *mpath;
+	int idx = 0;
+	char dst[ETH_ALEN];
+	char mpp[ETH_ALEN];
+
+	RTW_PRINT_SEL(sel, "%-17s %-17s\n", "dst", "mpp");
+
+	do {
+		rtw_rcu_read_lock();
+
+		mpath = rtw_mpp_path_lookup_by_idx(adapter, idx);
+		if (mpath) {
+			_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+			_rtw_memcpy(mpp, mpath->mpp, ETH_ALEN);
+		}
+
+		rtw_rcu_read_unlock();
+
+		if (mpath) {
+			RTW_PRINT_SEL(sel, MAC_FMT" "MAC_FMT"\n"
+				, MAC_ARG(dst), MAC_ARG(mpp));
+		}
+
+		idx++;
+	} while (mpath);
+}
+
+/**
+ * rtw_mesh_plink_broken - deactivates paths and sends perr when a link breaks
+ *
+ * @sta: broken peer link
+ *
+ * This function must be called from the rate control algorithm if enough
+ * delivery errors suggest that a peer link is no longer usable.
+ */
+void rtw_mesh_plink_broken(struct sta_info *sta)
+{
+	_adapter *adapter = sta->padapter;
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
+	static const u8 bcast[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		if (rtw_rcu_access_pointer(mpath->next_hop) == sta &&
+		    mpath->flags & RTW_MESH_PATH_ACTIVE &&
+		    !(mpath->flags & RTW_MESH_PATH_FIXED)) {
+			enter_critical_bh(&mpath->state_lock);
+			mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
+			++mpath->sn;
+			exit_critical_bh(&mpath->state_lock);
+			rtw_mesh_path_error_tx(adapter,
+				adapter->mesh_cfg.element_ttl,
+				mpath->dst, mpath->sn,
+				WLAN_REASON_MESH_PATH_DEST_UNREACHABLE, bcast);
+		}
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+static void rtw_mesh_path_free_rcu(struct rtw_mesh_table *tbl,
+			       struct rtw_mesh_path *mpath)
+{
+	_adapter *adapter = mpath->adapter;
+
+	enter_critical_bh(&mpath->state_lock);
+	mpath->flags |= RTW_MESH_PATH_RESOLVING | RTW_MESH_PATH_DELETED;
+	rtw_mesh_gate_del(tbl, mpath);
+	exit_critical_bh(&mpath->state_lock);
+	_cancel_timer_ex(&mpath->timer);
+	ATOMIC_DEC(&adapter->mesh_info.mpaths);
+	ATOMIC_DEC(&tbl->entries);
+	_rtw_spinlock_free(&mpath->state_lock);
+
+	rtw_mesh_path_flush_pending(mpath);
+
+	rtw_mpath_free_rcu(mpath);
+}
+
+static void __rtw_mesh_path_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath)
+{
+	rtw_rhashtable_remove_fast(&tbl->rhead, &mpath->rhash, rtw_mesh_rht_params);
+	rtw_mesh_path_free_rcu(tbl, mpath);
+}
+
+/**
+ * rtw_mesh_path_flush_by_nexthop - Deletes mesh paths if their next hop matches
+ *
+ * @sta: mesh peer to match
+ *
+ * RCU notes: this function is called when a mesh plink transitions from
+ * PLINK_ESTAB to any other state, since PLINK_ESTAB state is the only one that
+ * allows path creation. This will happen before the sta can be freed (because
+ * sta_info_destroy() calls this) so any reader in a rcu read block will be
+ * protected against the plink disappearing.
+ */
+void rtw_mesh_path_flush_by_nexthop(struct sta_info *sta)
+{
+	_adapter *adapter = sta->padapter;
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+
+		if (rtw_rcu_access_pointer(mpath->next_hop) == sta)
+			__rtw_mesh_path_del(tbl, mpath);
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+static void rtw_mpp_flush_by_proxy(_adapter *adapter,
+			       const u8 *proxy)
+{
+	struct rtw_mesh_table *tbl = adapter->mesh_info.mpp_paths;
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+
+		if (_rtw_memcmp(mpath->mpp, proxy, ETH_ALEN) == _TRUE)
+			__rtw_mesh_path_del(tbl, mpath);
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+static void rtw_table_flush_by_iface(struct rtw_mesh_table *tbl)
+{
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+	
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		__rtw_mesh_path_del(tbl, mpath);
+	}
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+/**
+ * rtw_mesh_path_flush_by_iface - Deletes all mesh paths associated with a given iface
+ *
+ * This function deletes both mesh paths as well as mesh portal paths.
+ *
+ * @sdata: interface data to match
+ *
+ */
+void rtw_mesh_path_flush_by_iface(_adapter *adapter)
+{
+	rtw_table_flush_by_iface(adapter->mesh_info.mesh_paths);
+	rtw_table_flush_by_iface(adapter->mesh_info.mpp_paths);
+}
+
+/**
+ * rtw_table_path_del - delete a path from the mesh or mpp table
+ *
+ * @tbl: mesh or mpp path table
+ * @sdata: local subif
+ * @addr: dst address (ETH_ALEN length)
+ *
+ * Returns: 0 if successful
+ */
+static int rtw_table_path_del(struct rtw_mesh_table *tbl,
+			  const u8 *addr)
+{
+	struct rtw_mesh_path *mpath;
+
+	if (!tbl)
+		return -ENXIO;
+
+	rtw_rcu_read_lock();
+	mpath = rtw_rhashtable_lookup_fast(&tbl->rhead, addr, rtw_mesh_rht_params);
+	if (!mpath) {
+		rtw_rcu_read_unlock();
+		return -ENXIO;
+	}
+
+	__rtw_mesh_path_del(tbl, mpath);
+	rtw_rcu_read_unlock();
+	return 0;
+}
+
+
+/**
+ * rtw_mesh_path_del - delete a mesh path from the table
+ *
+ * @addr: dst address (ETH_ALEN length)
+ * @sdata: local subif
+ *
+ * Returns: 0 if successful
+ */
+int rtw_mesh_path_del(_adapter *adapter, const u8 *addr)
+{
+	int err;
+
+	/* flush relevant mpp entries first */
+	rtw_mpp_flush_by_proxy(adapter, addr);
+
+	err = rtw_table_path_del(adapter->mesh_info.mesh_paths, addr);
+	adapter->mesh_info.mesh_paths_generation++;
+	return err;
+}
+
+/**
+ * rtw_mesh_path_tx_pending - sends pending frames in a mesh path queue
+ *
+ * @mpath: mesh path to activate
+ *
+ * Locking: the state_lock of the mpath structure must NOT be held when calling
+ * this function.
+ */
+void rtw_mesh_path_tx_pending(struct rtw_mesh_path *mpath)
+{
+	if (mpath->flags & RTW_MESH_PATH_ACTIVE) {
+		struct rtw_mesh_info *minfo = &mpath->adapter->mesh_info;
+		_list q;
+		u32 q_len = 0;
+
+		_rtw_init_listhead(&q);
+
+		/* move to local queue */
+		enter_critical_bh(&mpath->frame_queue.lock);
+		if (mpath->frame_queue_len) {
+			rtw_list_splice_init(&mpath->frame_queue.queue, &q);
+			q_len = mpath->frame_queue_len;
+			mpath->frame_queue_len = 0;
+		}
+		exit_critical_bh(&mpath->frame_queue.lock);
+
+		if (q_len) {
+			/* move to mpath_tx_queue */
+			enter_critical_bh(&minfo->mpath_tx_queue.lock);
+			rtw_list_splice_tail(&q, &minfo->mpath_tx_queue.queue);
+			minfo->mpath_tx_queue_len += q_len;
+			exit_critical_bh(&minfo->mpath_tx_queue.lock);
+
+			/* schedule mpath_tx_tasklet */
+			tasklet_hi_schedule(&minfo->mpath_tx_tasklet);
+		}
+	}
+}
+
+/**
+ * rtw_mesh_path_send_to_gates - sends pending frames to all known mesh gates
+ *
+ * @mpath: mesh path whose queue will be emptied
+ *
+ * If there is only one gate, the frames are transferred from the failed mpath
+ * queue to that gate's queue.  If there are more than one gates, the frames
+ * are copied from each gate to the next.  After frames are copied, the
+ * mpath queues are emptied onto the transmission queue.
+ */
+int rtw_mesh_path_send_to_gates(struct rtw_mesh_path *mpath)
+{
+	_adapter *adapter = mpath->adapter;
+	struct rtw_mesh_table *tbl;
+	struct rtw_mesh_path *from_mpath = mpath;
+	struct rtw_mesh_path *gate;
+	bool copy = false;
+	rtw_hlist_node *node;
+
+	tbl = adapter->mesh_info.mesh_paths;
+	if (!tbl)
+		return 0;
+
+	rtw_rcu_read_lock();
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		if (gate->flags & RTW_MESH_PATH_ACTIVE) {
+			RTW_MPATH_DBG(FUNC_ADPT_FMT" Forwarding to %pM\n",
+				FUNC_ADPT_ARG(adapter), gate->dst);
+			rtw_mesh_path_move_to_queue(gate, from_mpath, copy);
+			from_mpath = gate;
+			copy = true;
+		} else {
+			RTW_MPATH_DBG(
+				  FUNC_ADPT_FMT" Not forwarding to %pM (flags %#x)\n",
+				  FUNC_ADPT_ARG(adapter), gate->dst, gate->flags);
+		}
+	}
+
+	rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
+		RTW_MPATH_DBG(FUNC_ADPT_FMT" Sending to %pM\n",
+			FUNC_ADPT_ARG(adapter), gate->dst);
+		rtw_mesh_path_tx_pending(gate);
+	}
+	rtw_rcu_read_unlock();
+
+	return (from_mpath == mpath) ? -EHOSTUNREACH : 0;
+}
+
+/**
+ * rtw_mesh_path_discard_frame - discard a frame whose path could not be resolved
+ *
+ * @skb: frame to discard
+ * @sdata: network subif the frame was to be sent through
+ *
+ * Locking: the function must me called within a rcu_read_lock region
+ */
+void rtw_mesh_path_discard_frame(_adapter *adapter,
+			     struct xmit_frame *xframe)
+{
+	rtw_free_xmitframe(&adapter->xmitpriv, xframe);
+	adapter->mesh_info.mshstats.dropped_frames_no_route++;
+}
+
+/**
+ * rtw_mesh_path_flush_pending - free the pending queue of a mesh path
+ *
+ * @mpath: mesh path whose queue has to be freed
+ *
+ * Locking: the function must me called within a rcu_read_lock region
+ */
+void rtw_mesh_path_flush_pending(struct rtw_mesh_path *mpath)
+{
+	struct xmit_frame *xframe;
+	_list *list, *head;
+	_list tmp;
+
+	_rtw_init_listhead(&tmp);
+
+	enter_critical_bh(&mpath->frame_queue.lock);
+	rtw_list_splice_init(&mpath->frame_queue.queue, &tmp);
+	mpath->frame_queue_len = 0;
+	exit_critical_bh(&mpath->frame_queue.lock);
+
+	head = &tmp;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+		list = get_next(list);
+		rtw_list_delete(&xframe->list);
+		rtw_mesh_path_discard_frame(mpath->adapter, xframe);
+	}
+}
+
+/**
+ * rtw_mesh_path_fix_nexthop - force a specific next hop for a mesh path
+ *
+ * @mpath: the mesh path to modify
+ * @next_hop: the next hop to force
+ *
+ * Locking: this function must be called holding mpath->state_lock
+ */
+void rtw_mesh_path_fix_nexthop(struct rtw_mesh_path *mpath, struct sta_info *next_hop)
+{
+	enter_critical_bh(&mpath->state_lock);
+	rtw_mesh_path_assign_nexthop(mpath, next_hop);
+	mpath->sn = 0xffff;
+	mpath->metric = 0;
+	mpath->hop_count = 0;
+	mpath->exp_time = 0;
+	mpath->flags = RTW_MESH_PATH_FIXED | RTW_MESH_PATH_SN_VALID;
+	rtw_mesh_path_activate(mpath);
+	exit_critical_bh(&mpath->state_lock);
+	rtw_ewma_err_rate_init(&next_hop->metrics.err_rate);
+	/* init it at a low value - 0 start is tricky */
+	rtw_ewma_err_rate_add(&next_hop->metrics.err_rate, 1);
+	rtw_mesh_path_tx_pending(mpath);
+}
+
+int rtw_mesh_pathtbl_init(_adapter *adapter)
+{
+	struct rtw_mesh_table *tbl_path, *tbl_mpp;
+	int ret;
+
+	tbl_path = rtw_mesh_table_alloc();
+	if (!tbl_path)
+		return -ENOMEM;
+
+	tbl_mpp = rtw_mesh_table_alloc();
+	if (!tbl_mpp) {
+		ret = -ENOMEM;
+		goto free_path;
+	}
+
+	rtw_rhashtable_init(&tbl_path->rhead, &rtw_mesh_rht_params);
+	rtw_rhashtable_init(&tbl_mpp->rhead, &rtw_mesh_rht_params);
+
+	adapter->mesh_info.mesh_paths = tbl_path;
+	adapter->mesh_info.mpp_paths = tbl_mpp;
+
+	return 0;
+
+free_path:
+	rtw_mesh_table_free(tbl_path);
+	return ret;
+}
+
+static
+void rtw_mesh_path_tbl_expire(_adapter *adapter,
+			  struct rtw_mesh_table *tbl)
+{
+	struct rtw_mesh_path *mpath;
+	rtw_rhashtable_iter iter;
+	int ret;
+
+	if (!tbl)
+		return;
+
+	ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
+	if (ret)
+		return;
+
+	ret = rtw_rhashtable_walk_start(&iter);
+	if (ret && ret != -EAGAIN)
+		goto out;
+
+	while ((mpath = rtw_rhashtable_walk_next(&iter))) {
+		if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
+			continue;
+		if (IS_ERR(mpath))
+			break;
+		if ((!(mpath->flags & RTW_MESH_PATH_RESOLVING)) &&
+		    (!(mpath->flags & RTW_MESH_PATH_FIXED)) &&
+		     rtw_time_after(rtw_get_current_time(), mpath->exp_time + RTW_MESH_PATH_EXPIRE))
+			__rtw_mesh_path_del(tbl, mpath);
+
+		if (mpath->is_gate &&  /* need not to deal with non-gate case */
+		    rtw_time_after(rtw_get_current_time(), mpath->gate_timeout)) {
+			RTW_MPATH_DBG(FUNC_ADPT_FMT"mpath [%pM] expired systime is %lu systime is %lu\n",
+				      FUNC_ADPT_ARG(adapter), mpath->dst,
+				      mpath->gate_timeout, rtw_get_current_time());
+			enter_critical_bh(&mpath->state_lock);
+			if (mpath->gate_asked) { /* asked gate before */
+				rtw_mesh_gate_del(tbl, mpath);
+				exit_critical_bh(&mpath->state_lock);
+			} else {
+				mpath->gate_asked = true;
+				mpath->gate_timeout = rtw_get_current_time() + rtw_ms_to_systime(mpath->gate_ann_int);
+				exit_critical_bh(&mpath->state_lock);
+				rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH);
+				RTW_MPATH_DBG(FUNC_ADPT_FMT"mpath [%pM] ask mesh gate existence (is_root=%d)\n",
+				      FUNC_ADPT_ARG(adapter), mpath->dst, mpath->is_root);
+			}
+		}
+	}
+
+out:
+	rtw_rhashtable_walk_stop(&iter);
+	rtw_rhashtable_walk_exit(&iter);
+}
+
+void rtw_mesh_path_expire(_adapter *adapter)
+{
+	rtw_mesh_path_tbl_expire(adapter, adapter->mesh_info.mesh_paths);
+	rtw_mesh_path_tbl_expire(adapter, adapter->mesh_info.mpp_paths);
+}
+
+void rtw_mesh_pathtbl_unregister(_adapter *adapter)
+{
+	if (adapter->mesh_info.mesh_paths) {
+		rtw_mesh_table_free(adapter->mesh_info.mesh_paths);
+		adapter->mesh_info.mesh_paths = NULL;
+	}
+
+	if (adapter->mesh_info.mpp_paths) {
+		rtw_mesh_table_free(adapter->mesh_info.mpp_paths);
+		adapter->mesh_info.mpp_paths = NULL;
+	}
+}
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_pathtbl.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_pathtbl.h
new file mode 100644
index 000000000000..0d6b3c7d0096
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/mesh/rtw_mesh_pathtbl.h
@@ -0,0 +1,209 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_MESH_PATHTBL_H_
+#define __RTW_MESH_PATHTBL_H_
+
+#ifndef DBG_RTW_MPATH
+#define DBG_RTW_MPATH 1
+#endif
+#if DBG_RTW_MPATH
+#define RTW_MPATH_DBG(fmt, arg...) RTW_PRINT(fmt, ##arg)
+#else
+#define RTW_MPATH_DBG(fmt, arg...) do {} while (0)
+#endif
+
+/**
+ * enum rtw_mesh_path_flags - mesh path flags
+ *
+ * @RTW_MESH_PATH_ACTIVE: the mesh path can be used for forwarding
+ * @RTW_MESH_PATH_RESOLVING: the discovery process is running for this mesh path
+ * @RTW_MESH_PATH_SN_VALID: the mesh path contains a valid destination sequence
+ *	number
+ * @RTW_MESH_PATH_FIXED: the mesh path has been manually set and should not be
+ *	modified
+ * @RTW_MESH_PATH_RESOLVED: the mesh path can has been resolved
+ * @RTW_MESH_PATH_REQ_QUEUED: there is an unsent path request for this destination
+ *	already queued up, waiting for the discovery process to start.
+ * @RTW_MESH_PATH_DELETED: the mesh path has been deleted and should no longer
+ *	be used
+ * @RTW_MESH_PATH_ROOT_ADD_CHK: root additional check in root mode.
+ *	With this flag, It will try the last used rann_snd_addr
+ * @RTW_MESH_PATH_PEER_AKA: only used toward a peer, only used in active keep
+ *	alive mechanism. PREQ's da = path dst
+ * 
+ * RTW_MESH_PATH_RESOLVED is used by the mesh path timer to
+ * decide when to stop or cancel the mesh path discovery.
+ */
+enum rtw_mesh_path_flags {
+	RTW_MESH_PATH_ACTIVE =	BIT(0),
+	RTW_MESH_PATH_RESOLVING =	BIT(1),
+	RTW_MESH_PATH_SN_VALID =	BIT(2),
+	RTW_MESH_PATH_FIXED	=	BIT(3),
+	RTW_MESH_PATH_RESOLVED =	BIT(4),
+	RTW_MESH_PATH_REQ_QUEUED =	BIT(5),
+	RTW_MESH_PATH_DELETED =	BIT(6),
+	RTW_MESH_PATH_ROOT_ADD_CHK =	BIT(7),
+	RTW_MESH_PATH_PEER_AKA =	BIT(8),
+};
+
+/**
+ * struct rtw_mesh_path - mesh path structure
+ *
+ * @dst: mesh path destination mac address
+ * @mpp: mesh proxy mac address
+ * @rhash: rhashtable list pointer
+ * @gate_list: list pointer for known gates list
+ * @sdata: mesh subif
+ * @next_hop: mesh neighbor to which frames for this destination will be
+ *	forwarded
+ * @timer: mesh path discovery timer
+ * @frame_queue: pending queue for frames sent to this destination while the
+ *	path is unresolved
+ * @rcu: rcu head for freeing mesh path
+ * @sn: target sequence number
+ * @metric: current metric to this destination
+ * @hop_count: hops to destination
+ * @exp_time: in jiffies, when the path will expire or when it expired
+ * @discovery_timeout: timeout (lapse in jiffies) used for the last discovery
+ *	retry
+ * @discovery_retries: number of discovery retries
+ * @flags: mesh path flags, as specified on &enum rtw_mesh_path_flags
+ * @state_lock: mesh path state lock used to protect changes to the
+ * mpath itself.  No need to take this lock when adding or removing
+ * an mpath to a hash bucket on a path table.
+ * @rann_snd_addr: the RANN sender address
+ * @rann_metric: the aggregated path metric towards the root node
+ * @last_preq_to_root: Timestamp of last PREQ sent to root
+ * @is_root: the destination station of this path is a root node
+ * @is_gate: the destination station of this path is a mesh gate
+ *
+ *
+ * The dst address is unique in the mesh path table. Since the mesh_path is
+ * protected by RCU, deleting the next_hop STA must remove / substitute the
+ * mesh_path structure and wait until that is no longer reachable before
+ * destroying the STA completely.
+ */
+struct rtw_mesh_path {
+	u8 dst[ETH_ALEN];
+	u8 mpp[ETH_ALEN];	/* used for MPP or MAP */
+	rtw_rhash_head rhash;
+	rtw_hlist_node gate_list;
+	_adapter *adapter;
+	struct sta_info __rcu *next_hop;
+	_timer timer;
+	_queue frame_queue;
+	u32 frame_queue_len;
+	rtw_rcu_head rcu;
+	u32 sn;
+	u32 metric;
+	u8 hop_count;
+	systime exp_time;
+	systime discovery_timeout;
+	systime gate_timeout;
+	u32 gate_ann_int;    /* gate announce interval */
+	u8 discovery_retries;
+	enum rtw_mesh_path_flags flags;
+	_lock state_lock;
+	u8 rann_snd_addr[ETH_ALEN];
+#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
+	u8 add_chk_rann_snd_addr[ETH_ALEN];
+#endif
+	u32 rann_metric;
+	unsigned long last_preq_to_root;
+	bool is_root;
+	bool is_gate;
+	bool gate_asked;
+};
+
+/**
+ * struct rtw_mesh_table
+ *
+ * @known_gates: list of known mesh gates and their mpaths by the station. The
+ * gate's mpath may or may not be resolved and active.
+ * @gates_lock: protects updates to known_gates
+ * @rhead: the rhashtable containing struct mesh_paths, keyed by dest addr
+ * @entries: number of entries in the table
+ */
+struct rtw_mesh_table {
+	rtw_hlist_head known_gates;
+	_lock gates_lock;
+	rtw_rhashtable rhead;
+	ATOMIC_T entries;
+};
+
+#define RTW_MESH_PATH_EXPIRE (600 * HZ)
+
+/* Maximum number of paths per interface */
+#define RTW_MESH_MAX_MPATHS		1024
+
+/* Number of frames buffered per destination for unresolved destinations */
+#define RTW_MESH_FRAME_QUEUE_LEN	10
+
+int rtw_mesh_nexthop_lookup(_adapter *adapter,
+	const u8 *mda, const u8 *msa, u8 *ra);
+int rtw_mesh_nexthop_resolve(_adapter *adapter,
+			 struct xmit_frame *xframe);
+
+struct rtw_mesh_path *rtw_mesh_path_lookup(_adapter *adapter,
+				   const u8 *dst);
+struct rtw_mesh_path *rtw_mpp_path_lookup(_adapter *adapter,
+				  const u8 *dst);
+int rtw_mpp_path_add(_adapter *adapter,
+		 const u8 *dst, const u8 *mpp);
+void dump_mpp(void *sel, _adapter *adapter);
+
+struct rtw_mesh_path *
+rtw_mesh_path_lookup_by_idx(_adapter *adapter, int idx);
+void dump_mpath(void *sel, _adapter *adapter);
+
+struct rtw_mesh_path *
+rtw_mpp_path_lookup_by_idx(_adapter *adapter, int idx);
+void rtw_mesh_path_fix_nexthop(struct rtw_mesh_path *mpath, struct sta_info *next_hop);
+void rtw_mesh_path_expire(_adapter *adapter);
+
+struct rtw_mesh_path *
+rtw_mesh_path_add(_adapter *adapter, const u8 *dst);
+
+int rtw_mesh_path_add_gate(struct rtw_mesh_path *mpath);
+void rtw_mesh_gate_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath);
+bool rtw_mesh_gate_search(struct rtw_mesh_table *tbl, const u8 *addr);
+int rtw_mesh_path_send_to_gates(struct rtw_mesh_path *mpath);
+int rtw_mesh_gate_num(_adapter *adapter);
+bool rtw_mesh_is_primary_gate(_adapter *adapter);
+void dump_known_gates(void *sel, _adapter *adapter);
+
+void rtw_mesh_plink_broken(struct sta_info *sta);
+
+void rtw_mesh_path_assign_nexthop(struct rtw_mesh_path *mpath, struct sta_info *sta);
+void rtw_mesh_path_flush_pending(struct rtw_mesh_path *mpath);
+void rtw_mesh_path_tx_pending(struct rtw_mesh_path *mpath);
+int rtw_mesh_pathtbl_init(_adapter *adapter);
+void rtw_mesh_pathtbl_unregister(_adapter *adapter);
+int rtw_mesh_path_del(_adapter *adapter, const u8 *addr);
+
+void rtw_mesh_path_flush_by_nexthop(struct sta_info *sta);
+void rtw_mesh_path_discard_frame(_adapter *adapter,
+			     struct xmit_frame *xframe);
+
+static inline void rtw_mesh_path_activate(struct rtw_mesh_path *mpath)
+{
+	mpath->flags |= RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVED;
+}
+
+void rtw_mesh_path_flush_by_iface(_adapter *adapter);
+
+#endif /* __RTW_MESH_PATHTBL_H_ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ap.c
index ff49410dc0ba..289b57e9dfd2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ap.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ap.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -27,13 +28,10 @@ extern unsigned char	WFD_OUI[];
 
 void init_mlme_ap_info(_adapter *padapter)
 {
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
 	_rtw_spinlock_init(&pmlmepriv->bcn_update_lock);
-
 	/* pmlmeext->bstart_bss = _FALSE; */
-
 }
 
 void free_mlme_ap_info(_adapter *padapter)
@@ -45,6 +43,49 @@ void free_mlme_ap_info(_adapter *padapter)
 
 }
 
+/*
+* Set TIM IE
+* return length of total TIM IE
+*/
+u8 rtw_set_tim_ie(u8 dtim_cnt, u8 dtim_period
+	, const u8 *tim_bmp, u8 tim_bmp_len, u8 *tim_ie)
+{
+	u8 *p = tim_ie;
+	u8 i, n1, n2;
+	u8 bmp_len;
+
+	if (rtw_bmp_not_empty(tim_bmp, tim_bmp_len)) {
+		/* find the first nonzero octet in tim_bitmap */
+		for (i = 0; i < tim_bmp_len; i++)
+			if (tim_bmp[i])
+				break;
+		n1 = i & 0xFE;
+	
+		/* find the last nonzero octet in tim_bitmap, except octet 0 */
+		for (i = tim_bmp_len - 1; i > 0; i--)
+			if (tim_bmp[i])
+				break;
+		n2 = i;
+		bmp_len = n2 - n1 + 1;
+	} else {
+		n1 = n2 = 0;
+		bmp_len = 1;
+	}
+
+	*p++ = WLAN_EID_TIM;
+	*p++ = 2 + 1 + bmp_len;
+	*p++ = dtim_cnt;
+	*p++ = dtim_period;
+	*p++ = (rtw_bmp_is_set(tim_bmp, tim_bmp_len, 0) ? BIT0 : 0) | n1;
+	_rtw_memcpy(p, tim_bmp + n1, bmp_len);
+
+#if 0
+	RTW_INFO("n1:%u, n2:%u, bmp_offset:%u, bmp_len:%u\n", n1, n2, n1 / 2, bmp_len);
+	RTW_INFO_DUMP("tim_ie: ", tim_ie + 2, 2 + 1 + bmp_len);
+#endif
+	return 2 + 2 + 1 + bmp_len;
+}
+
 static void update_BCNTIM(_adapter *padapter)
 {
 	struct sta_priv *pstapriv = &padapter->stapriv;
@@ -57,15 +98,12 @@ static void update_BCNTIM(_adapter *padapter)
 
 
 	/* update TIM IE */
-	/* if(pstapriv->tim_bitmap) */
+	/* if(rtw_tim_map_anyone_be_set(padapter, pstapriv->tim_bitmap)) */
 #endif
 	if (_TRUE) {
 		u8 *p, *dst_ie, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
-		u16 tim_bitmap_le;
 		uint offset, tmp_len, tim_ielen, tim_ie_offset, remainder_ielen;
 
-		tim_bitmap_le = cpu_to_le16(pstapriv->tim_bitmap);
-
 		p = rtw_get_ie(pie + _FIXED_IE_LENGTH_, _TIM_IE_, &tim_ielen, pnetwork_mlmeext->IELength - _FIXED_IE_LENGTH_);
 		if (p != NULL && tim_ielen > 0) {
 			tim_ielen += 2;
@@ -112,39 +150,8 @@ static void update_BCNTIM(_adapter *padapter)
 				_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
 		}
 
-		*dst_ie++ = _TIM_IE_;
-
-		if ((pstapriv->tim_bitmap & 0xff00) && (pstapriv->tim_bitmap & 0x00fe))
-			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) {
-			u8 pvb = 0;
-
-			if (pstapriv->tim_bitmap & 0x00fe)
-				pvb = (u8)tim_bitmap_le;
-			else if (pstapriv->tim_bitmap & 0xff00)
-				pvb = (u8)(tim_bitmap_le >> 8);
-			else
-				pvb = (u8)tim_bitmap_le;
-
-			*dst_ie++ = pvb;
-
-		} else if (tim_ielen == 5) {
-			_rtw_memcpy(dst_ie, &tim_bitmap_le, 2);
-			dst_ie += 2;
-		}
+		/* append TIM IE */
+		dst_ie += rtw_set_tim_ie(0, 1, pstapriv->tim_bitmap, pstapriv->aid_bmp_len, dst_ie);
 
 		/*copy remainder IE*/
 		if (pbackup_remainder_ie) {
@@ -285,6 +292,12 @@ u8 chk_sta_is_alive(struct sta_info *psta)
 #if 0
 		if (psta->state & WIFI_SLEEP_STATE)
 			ret = _TRUE;
+#endif
+#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(psta->padapter) &&
+		    (psta->sta_stats.last_rx_hwmp_pkts !=
+		     psta->sta_stats.rx_hwmp_pkts))
+			ret = _TRUE;
 #endif
 	} else
 		ret = _TRUE;
@@ -294,6 +307,83 @@ u8 chk_sta_is_alive(struct sta_info *psta)
 	return ret;
 }
 
+/**
+ * issue_aka_chk_frame - issue active keep alive check frame
+ *	aka = active keep alive
+ */
+static int issue_aka_chk_frame(_adapter *adapter, struct sta_info *psta)
+{
+	int ret = _FAIL;
+	u8 *target_addr = psta->cmn.mac_addr;
+
+	if (MLME_IS_AP(adapter)) {
+		/* issue null data to check sta alive */
+		if (psta->state & WIFI_SLEEP_STATE)
+			ret = issue_nulldata(adapter, target_addr, 0, 1, 50);
+		else
+			ret = issue_nulldata(adapter, target_addr, 0, 3, 50);
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		struct rtw_mesh_path *mpath;
+
+		rtw_rcu_read_lock();
+		mpath = rtw_mesh_path_lookup(adapter, target_addr);
+		if (!mpath) {
+			mpath = rtw_mesh_path_add(adapter, target_addr);
+			if (IS_ERR(mpath)) {
+				rtw_rcu_read_unlock();
+				RTW_ERR(FUNC_ADPT_FMT" rtw_mesh_path_add for "MAC_FMT" fail.\n",
+					FUNC_ADPT_ARG(adapter), MAC_ARG(target_addr));
+				return _FAIL;
+			}
+		}
+		if (mpath->flags & RTW_MESH_PATH_ACTIVE)
+			ret = _SUCCESS;
+		else {
+			u8 flags = RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_PEER_AKA;
+			/* issue PREQ to check peer alive */
+			rtw_mesh_queue_preq(mpath, flags);
+			ret = _FALSE;
+		}
+		rtw_rcu_read_unlock();
+	}
+#endif
+	return ret;
+}
+
+#ifdef RTW_CONFIG_RFREG18_WA
+static void rtw_check_restore_rf18(_adapter *padapter)
+{
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	u32 reg;
+	u8 union_ch = 0, union_bw = 0, union_offset = 0, setchbw = _FALSE;
+		
+	reg = rtw_hal_read_rfreg(padapter, 0, 0x18, 0x3FF);
+	if ((reg & 0xFF) == 0)
+			setchbw = _TRUE;
+	reg = rtw_hal_read_rfreg(padapter, 1, 0x18, 0x3FF);
+	if ((reg & 0xFF) == 0)
+			setchbw = _TRUE;
+
+	if (setchbw) {
+		if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)) {
+			RTW_INFO("Hit RF(0x18)=0!! restore original channel setting.\n");
+			union_ch =  pmlmeext->cur_channel;
+			union_offset = pmlmeext->cur_ch_offset ;
+			union_bw = pmlmeext->cur_bwmode;
+		} else {
+			RTW_INFO("Hit RF(0x18)=0!! set ch(%x) offset(%x) bwmode(%x)\n", union_ch, union_offset, union_bw);
+		}
+		/*	Initial the channel_bw setting procedure.	*/
+		pHalData->current_channel = 0;
+		set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+	}
+}
+#endif
+
 void	expire_timeout_chk(_adapter *padapter)
 {
 	_irqL irqL;
@@ -305,6 +395,22 @@ void	expire_timeout_chk(_adapter *padapter)
 	char chk_alive_list[NUM_STA];
 	int i;
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)
+		&& check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE)
+	) {
+		struct rtw_mesh_cfg *mcfg = &padapter->mesh_cfg;
+
+		rtw_mesh_path_expire(padapter);
+
+		/* TBD: up layer timeout mechanism */
+		/* if (!mcfg->plink_timeout)
+			return; */
+#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+		return;
+#endif
+	}
+#endif
 
 #ifdef CONFIG_MCC_MODE
 	/*	then driver may check fail due to not recv client's frame under sitesurvey,
@@ -322,8 +428,8 @@ void	expire_timeout_chk(_adapter *padapter)
 	/* check auth_queue */
 #ifdef DBG_EXPIRATION_CHK
 	if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
-		RTW_INFO(FUNC_NDEV_FMT" auth_list, cnt:%u\n"
-			, FUNC_NDEV_ARG(padapter->pnetdev), pstapriv->auth_list_cnt);
+		RTW_INFO(FUNC_ADPT_FMT" auth_list, cnt:%u\n"
+			, FUNC_ADPT_ARG(padapter), pstapriv->auth_list_cnt);
 	}
 #endif
 	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
@@ -344,9 +450,8 @@ void	expire_timeout_chk(_adapter *padapter)
 				rtw_list_delete(&psta->auth_list);
 				pstapriv->auth_list_cnt--;
 
-				RTW_INFO("auth expire %02X%02X%02X%02X%02X%02X\n",
-					psta->cmn.mac_addr[0], psta->cmn.mac_addr[1], psta->cmn.mac_addr[2],
-					psta->cmn.mac_addr[3], psta->cmn.mac_addr[4], psta->cmn.mac_addr[5]);
+				RTW_INFO(FUNC_ADPT_FMT" auth expire "MAC_FMT"\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
 
 				_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
 
@@ -372,8 +477,8 @@ void	expire_timeout_chk(_adapter *padapter)
 	/* check asoc_queue */
 #ifdef DBG_EXPIRATION_CHK
 	if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
-		RTW_INFO(FUNC_NDEV_FMT" asoc_list, cnt:%u\n"
-			, FUNC_NDEV_ARG(padapter->pnetdev), pstapriv->asoc_list_cnt);
+		RTW_INFO(FUNC_ADPT_FMT" asoc_list, cnt:%u\n"
+			, FUNC_ADPT_ARG(padapter), pstapriv->asoc_list_cnt);
 	}
 #endif
 	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
@@ -496,35 +601,29 @@ void	expire_timeout_chk(_adapter *padapter)
 					/* RTW_INFO("alive chk, sta:" MAC_FMT " is at ps mode!\n", MAC_ARG(psta->cmn.mac_addr)); */
 
 					/* to update bcn with tim_bitmap for this station */
-					pstapriv->tim_bitmap |= BIT(psta->cmn.aid);
+					rtw_tim_map_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 					update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
 
 					if (!pmlmeext->active_keep_alive_check)
 						continue;
 				}
 			}
-#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
-			if (pmlmeext->active_keep_alive_check) {
+
+			{
 				int stainfo_offset;
 
 				stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
 				if (stainfo_offset_valid(stainfo_offset))
 					chk_alive_list[chk_alive_num++] = stainfo_offset;
-
 				continue;
 			}
-#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
-			rtw_list_delete(&psta->asoc_list);
-			pstapriv->asoc_list_cnt--;
-			RTW_INFO("asoc expire "MAC_FMT", state=0x%x\n", MAC_ARG(psta->cmn.mac_addr), psta->state);
-			updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
 		} 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)
 			   ) {
-				RTW_INFO("%s sta:"MAC_FMT", sleepq_len:%u, free_xmitframe_cnt:%u, asoc_list_cnt:%u, clear sleep_q\n", __func__
-					 , MAC_ARG(psta->cmn.mac_addr)
+				RTW_INFO(FUNC_ADPT_FMT" sta:"MAC_FMT", sleepq_len:%u, free_xmitframe_cnt:%u, asoc_list_cnt:%u, clear sleep_q\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
 					, psta->sleepq_len, padapter->xmitpriv.free_xmitframe_cnt, pstapriv->asoc_list_cnt);
 				wakeup_sta_to_xmit(padapter, psta);
 			}
@@ -533,92 +632,127 @@ void	expire_timeout_chk(_adapter *padapter)
 
 	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 
-#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 	if (chk_alive_num) {
-
+#if defined(CONFIG_ACTIVE_KEEP_ALIVE_CHECK)
 		u8 backup_ch = 0, backup_bw = 0, backup_offset = 0;
-		u8 union_ch = 0, union_bw, union_offset;
-		u8 switch_channel = _TRUE;
+		u8 union_ch = 0, union_bw = 0, union_offset = 0;
+		u8 switch_channel_by_drv = _TRUE;
 		struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+#endif
+		char del_asoc_list[NUM_STA];
 
-		if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
-			|| pmlmeext->cur_channel != union_ch)
-			goto bypass_active_keep_alive;
+		_rtw_memset(del_asoc_list, NUM_STA, NUM_STA);
 
-#ifdef CONFIG_MCC_MODE
-		if (MCC_EN(padapter)) {
-			/* driver doesn't switch channel under MCC */
-			if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
-				switch_channel = _FALSE;
-		}
-#endif
-		/* switch to correct channel of current network  before issue keep-alive frames */
-		if (switch_channel == _TRUE && rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
-			backup_ch = rtw_get_oper_ch(padapter);
-			backup_bw = rtw_get_oper_bw(padapter);
-			backup_offset = rtw_get_oper_choffset(padapter);
-			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+		#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+		if (pmlmeext->active_keep_alive_check) {
+			#ifdef CONFIG_MCC_MODE
+			if (MCC_EN(padapter)) {
+				/* driver doesn't switch channel under MCC */
+				if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+					switch_channel_by_drv = _FALSE;
+			}
+			#endif
+
+			if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
+				|| pmlmeext->cur_channel != union_ch)
+				switch_channel_by_drv = _FALSE;
+
+			/* switch to correct channel of current network  before issue keep-alive frames */
+			if (switch_channel_by_drv == _TRUE && rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
+				backup_ch = rtw_get_oper_ch(padapter);
+				backup_bw = rtw_get_oper_bw(padapter);
+				backup_offset = rtw_get_oper_choffset(padapter);
+				set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+			}
 		}
+		#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
 
-		/* issue null data to check sta alive*/
+		/* check loop */
 		for (i = 0; i < chk_alive_num; i++) {
+			#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 			int ret = _FAIL;
+			#endif
 
 			psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
-#ifdef CONFIG_ATMEL_RC_PATCH
+
+			#ifdef CONFIG_ATMEL_RC_PATCH
 			if (_rtw_memcmp(pstapriv->atmel_rc_pattern, psta->cmn.mac_addr, ETH_ALEN) == _TRUE)
 				continue;
 			if (psta->flag_atmel_rc)
 				continue;
-#endif
+			#endif
+
 			if (!(psta->state & _FW_LINKED))
 				continue;
 
-			if (psta->state & WIFI_SLEEP_STATE)
-				ret = issue_nulldata(padapter, psta->cmn.mac_addr, 0, 1, 50);
-			else
-				ret = issue_nulldata(padapter, psta->cmn.mac_addr, 0, 3, 50);
+			#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+			if (pmlmeext->active_keep_alive_check) {
+				/* issue active keep alive frame to check */
+				ret = issue_aka_chk_frame(padapter, psta);
 
-			psta->keep_alive_trycnt++;
-			if (ret == _SUCCESS) {
-				RTW_INFO("asoc check, sta(" MAC_FMT ") is alive\n", MAC_ARG(psta->cmn.mac_addr));
-				psta->expire_to = pstapriv->expire_to;
-				psta->keep_alive_trycnt = 0;
-				continue;
-			} else if (psta->keep_alive_trycnt <= 3) {
-				RTW_INFO("ack check for asoc expire, keep_alive_trycnt=%d\n", psta->keep_alive_trycnt);
-				psta->expire_to = 1;
-				continue;
+				psta->keep_alive_trycnt++;
+				if (ret == _SUCCESS) {
+					RTW_INFO(FUNC_ADPT_FMT" asoc check, "MAC_FMT" is alive\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+					psta->expire_to = pstapriv->expire_to;
+					psta->keep_alive_trycnt = 0;
+					continue;
+				} else if (psta->keep_alive_trycnt <= 3) {
+					RTW_INFO(FUNC_ADPT_FMT" asoc check, "MAC_FMT" keep_alive_trycnt=%d\n"
+						, FUNC_ADPT_ARG(padapter) , MAC_ARG(psta->cmn.mac_addr), psta->keep_alive_trycnt);
+					psta->expire_to = 1;
+					continue;
+				}
 			}
+			#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
 
 			psta->keep_alive_trycnt = 0;
-			RTW_INFO("asoc expire "MAC_FMT", state=0x%x\n", MAC_ARG(psta->cmn.mac_addr), psta->state);
+			del_asoc_list[i] = chk_alive_list[i];
 			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 			if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
 				rtw_list_delete(&psta->asoc_list);
 				pstapriv->asoc_list_cnt--;
-				updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_DEAUTH_LEAVING, _TRUE);
+				STA_SET_MESH_PLINK(psta, NULL);
 			}
 			_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
 		}
 
-		/* back to the original operation channel */
-		if (switch_channel && backup_ch > 0)
-			set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
+		/* delete loop */
+		for (i = 0; i < chk_alive_num; i++) {
+			u8 sta_addr[ETH_ALEN];
+
+			if (del_asoc_list[i] >= NUM_STA)
+				continue;
+
+			psta = rtw_get_stainfo_by_offset(pstapriv, del_asoc_list[i]);
+			_rtw_memcpy(sta_addr, psta->cmn.mac_addr, ETH_ALEN);
 
-bypass_active_keep_alive:
-		;
+			RTW_INFO(FUNC_ADPT_FMT" asoc expire "MAC_FMT", state=0x%x\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr), psta->state);
+			updated |= ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_DEAUTH_LEAVING, _FALSE);
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter))
+				rtw_mesh_expire_peer(padapter, sta_addr);
+			#endif
+		}
+
+		#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+		if (pmlmeext->active_keep_alive_check) {
+			/* back to the original operation channel */
+			if (switch_channel_by_drv == _TRUE && backup_ch > 0)
+				set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
+		}
+		#endif
 	}
-#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
 
+#ifdef RTW_CONFIG_RFREG18_WA
+	rtw_check_restore_rf18(padapter);
+#endif
 	associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
 }
 
 void rtw_ap_update_sta_ra_info(_adapter *padapter, struct sta_info *psta)
 {
-	int i;
-	u8 rf_type;
 	unsigned char sta_band = 0;
 	u64 tx_ra_bitmap = 0;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
@@ -805,8 +939,9 @@ _exit:
 
 void rtw_init_bmc_sta_tx_rate(_adapter *padapter, struct sta_info *psta)
 {
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+#ifdef CONFIG_BMC_TX_LOW_RATE
 	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+#endif
 	u8 rate_idx = 0;
 	u8 brate_table[] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M,
 		MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M};
@@ -845,7 +980,12 @@ void update_bmc_sta(_adapter *padapter)
 
 	if (psta) {
 		psta->cmn.aid = 0;/* default set to 0 */
-		psta->qos_option = 0;
+#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter))
+			psta->qos_option = 1;
+		else
+#endif
+			psta->qos_option = 0;
 #ifdef CONFIG_80211N_HT
 		psta->htpriv.ht_option = _FALSE;
 #endif /* CONFIG_80211N_HT */
@@ -935,7 +1075,7 @@ void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta)
 
 	/*alloc macid when call rtw_alloc_stainfo(),release macid when call rtw_free_stainfo()*/
 
-	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
+	if (!MLME_IS_MESH(padapter) && psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
 		psta->ieee8021x_blocked = _TRUE;
 	else
 		psta->ieee8021x_blocked = _FALSE;
@@ -959,6 +1099,10 @@ void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta)
 		else
 			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
 
+		if (phtpriv_sta->op_present
+			&& !GET_HT_OP_ELE_STA_CHL_WIDTH(phtpriv_sta->ht_op))
+			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
+
 		if (psta->ht_40mhz_intolerant)
 			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
 
@@ -1038,17 +1182,20 @@ void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta)
 	rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
 
 	_enter_critical_bh(&psta->lock, &irqL);
-	psta->state |= _FW_LINKED;
-	_exit_critical_bh(&psta->lock, &irqL);
 
+	/* Check encryption */
+	if (!MLME_IS_MESH(padapter) && psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
+		psta->state |= WIFI_UNDER_KEY_HANDSHAKE;
 
+	psta->state |= _FW_LINKED;
+
+	_exit_critical_bh(&psta->lock, &irqL);
 }
 
 static void update_ap_info(_adapter *padapter, struct sta_info *psta)
 {
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 #ifdef CONFIG_80211N_HT
 	struct ht_priv	*phtpriv_ap = &pmlmepriv->htpriv;
@@ -1099,7 +1246,7 @@ static void update_ap_info(_adapter *padapter, struct sta_info *psta)
 
 static void rtw_set_hw_wmm_param(_adapter *padapter)
 {
-	u8	ACI, ACM, AIFS, ECWMin, ECWMax, aSifsTime;
+	u8	AIFS, ECWMin, ECWMax, aSifsTime;
 	u8	acm_mask;
 	u16	TXOP;
 	u32	acParm, i;
@@ -1110,11 +1257,13 @@ static void rtw_set_hw_wmm_param(_adapter *padapter)
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 
 	acm_mask = 0;
-
-	if (is_supported_5g(pmlmeext->cur_wireless_mode) ||
-	    (pmlmeext->cur_wireless_mode & WIRELESS_11_24N))
+#ifdef CONFIG_80211N_HT
+	if (pregpriv->ht_enable &&
+		(is_supported_5g(pmlmeext->cur_wireless_mode) ||
+	    (pmlmeext->cur_wireless_mode & WIRELESS_11_24N)))
 		aSifsTime = 16;
 	else
+#endif /* CONFIG_80211N_HT */
 		aSifsTime = 10;
 
 	if (pmlmeinfo->WMM_enable == 0) {
@@ -1244,12 +1393,11 @@ static void rtw_set_hw_wmm_param(_adapter *padapter)
 	}
 
 }
-
+#ifdef CONFIG_80211N_HT
 static void update_hw_ht_param(_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);
 
@@ -1289,7 +1437,7 @@ static void update_hw_ht_param(_adapter *padapter)
 	/* pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3; */
 
 }
-
+#endif /* CONFIG_80211N_HT */
 static void rtw_ap_check_scan(_adapter *padapter)
 {
 	_irqL	irqL;
@@ -1380,9 +1528,9 @@ static void rtw_ap_check_scan(_adapter *padapter)
 	}
 
 	_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-
+#ifdef CONFIG_80211N_HT
 	pmlmepriv->num_sta_no_ht = 0; /* reset to 0 after ap do scanning*/
-
+#endif
 }
 
 void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter)
@@ -1414,10 +1562,58 @@ void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter)
 	update_ap_info(adapter, sta);
 }
 
+#ifdef CONFIG_FW_HANDLE_TXBCN
+bool rtw_ap_nums_check(_adapter *adapter)
+{
+	if (rtw_ap_get_nums(adapter) < CONFIG_LIMITED_AP_NUM)
+		return _TRUE;
+	return _FALSE;
+}
+u8 rtw_ap_allocate_vapid(struct dvobj_priv *dvobj)
+{
+	u8 vap_id;
+
+	for (vap_id = 0; vap_id < CONFIG_LIMITED_AP_NUM; vap_id++) {
+		if (!(dvobj->vap_map & BIT(vap_id)))
+			break;
+	}
+
+	if (vap_id < CONFIG_LIMITED_AP_NUM)
+		dvobj->vap_map |= BIT(vap_id);
+
+	return vap_id;
+}
+u8 rtw_ap_release_vapid(struct dvobj_priv *dvobj, u8 vap_id)
+{
+	if (vap_id >= CONFIG_LIMITED_AP_NUM) {
+		RTW_ERR("%s - vapid(%d) failed\n", __func__, vap_id);
+		rtw_warn_on(1);
+		return _FAIL;
+	}
+	dvobj->vap_map &= ~ BIT(vap_id);
+	return _SUCCESS;
+}
+#endif
+static void _rtw_iface_undersurvey_chk(const char *func, _adapter *adapter)
+{
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mlme_priv *pmlmepriv;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if ((iface) && rtw_is_adapter_up(iface)) {
+			pmlmepriv = &iface->mlmepriv;
+			if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
+				RTW_ERR("%s ("ADPT_FMT") under survey\n", func, ADPT_ARG(iface));
+		}
+	}
+}
 void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
 {
 #define DUMP_ADAPTERS_STATUS 0
-	u8 self_action = MLME_ACTION_UNKNOWN;
+	u8 mlme_act = MLME_ACTION_UNKNOWN;
 	u8 val8;
 	u16 bcn_interval;
 	u32	acparm;
@@ -1429,28 +1625,29 @@ void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX *pnetwork_mlmeext = &(pmlmeinfo->network);
 	struct dvobj_priv *pdvobj = padapter->dvobj;
-	s16 req_ch = -1, req_bw = -1, req_offset = -1;
-	bool ch_setting_changed = _FALSE;
+	s16 req_ch = REQ_CH_NONE, req_bw = REQ_BW_NONE, req_offset = REQ_OFFSET_NONE;
 	u8 ch_to_set = 0, bw_to_set, offset_to_set;
 	u8 doiqk = _FALSE;
 	/* use for check ch bw offset can be allowed or not */
 	u8 chbw_allow = _TRUE;
-
-	if (MLME_IS_AP(padapter))
-		self_action = MLME_AP_STARTED;
-	else if (MLME_IS_MESH(padapter))
-		self_action = MLME_MESH_STARTED;
-	else
-		rtw_warn_on(1);
+	int i;
+	u8 ifbmp_ch_changed = 0;
 
 	if (parm->req_ch != 0) {
 		/* bypass other setting, go checking ch, bw, offset */
+		mlme_act = MLME_OPCH_SWITCH;
 		req_ch = parm->req_ch;
 		req_bw = parm->req_bw;
 		req_offset = parm->req_offset;
 		goto chbw_decision;
 	} else {
-		/* inform this request comes from upper layer */
+		/* request comes from upper layer */
+		if (MLME_IS_AP(padapter))
+			mlme_act = MLME_AP_STARTED;
+		else if (MLME_IS_MESH(padapter))
+			mlme_act = MLME_MESH_STARTED;
+		else
+			rtw_warn_on(1);
 		req_ch = 0;
 		_rtw_memcpy(pnetwork_mlmeext, pnetwork, pnetwork->Length);
 	}
@@ -1488,7 +1685,9 @@ void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
 
 	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 != _WEP40_) && (psecuritypriv->dot11PrivacyAlgrthm != _WEP104_))
+		if ((psecuritypriv->dot11PrivacyAlgrthm != _WEP40_) && (psecuritypriv->dot11PrivacyAlgrthm != _WEP104_)
+			&& !MLME_IS_MESH(padapter) /* mesh group key is set before this function */
+		)
 			flush_all_cam_entry(padapter);	/* clear CAM */
 	}
 
@@ -1498,21 +1697,6 @@ void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
 	/* Set BSSID REG */
 	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pnetwork->MacAddress);
 
-	/* Set EDCA param reg */
-#ifdef CONFIG_CONCURRENT_MODE
-	acparm = 0x005ea42b;
-#else
-	acparm = 0x002F3217; /* VO */
-#endif
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acparm));
-	acparm = 0x005E4317; /* VI */
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acparm));
-	/* acparm = 0x00105320; */ /* BE */
-	acparm = 0x005ea42b;
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
-	acparm = 0x0000A444; /* BK */
-	rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acparm));
-
 	/* Set Security */
 	val8 = (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) ? 0xcc : 0xcf;
 	rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
@@ -1520,19 +1704,32 @@ void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
 	/* Beacon Control related register */
 	rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&bcn_interval));
 
+	rtw_hal_rcr_set_chk_bssid(padapter, mlme_act);
+
 chbw_decision:
-	ch_setting_changed = rtw_ap_chbw_decision(padapter, req_ch, req_bw, req_offset
-		     , &ch_to_set, &bw_to_set, &offset_to_set, &chbw_allow);
+	ifbmp_ch_changed = rtw_ap_chbw_decision(padapter, parm->ifbmp, parm->excl_ifbmp
+						, req_ch, req_bw, req_offset
+						, &ch_to_set, &bw_to_set, &offset_to_set, &chbw_allow);
+
+	for (i = 0; i < pdvobj->iface_nums; i++) {
+		if (!(parm->ifbmp & BIT(i)) || !pdvobj->padapters[i])
+			continue;
 
-	/* let pnetwork_mlme == pnetwork_mlmeext */
-	_rtw_memcpy(pnetwork, pnetwork_mlmeext, pnetwork_mlmeext->Length);
+		/* let pnetwork_mlme == pnetwork_mlmeext */
+		_rtw_memcpy(&(pdvobj->padapters[i]->mlmepriv.cur_network.network)
+			, &(pdvobj->padapters[i]->mlmeextpriv.mlmext_info.network)
+			, pdvobj->padapters[i]->mlmeextpriv.mlmext_info.network.Length);
 
-	rtw_start_bss_hdl_after_chbw_decided(padapter);
+		rtw_start_bss_hdl_after_chbw_decided(pdvobj->padapters[i]);
+
+		/* Set EDCA param reg after update cur_wireless_mode & update_capinfo */
+		if (pregpriv->wifi_spec == 1)
+			rtw_set_hw_wmm_param(pdvobj->padapters[i]);
+	}
 
 #if defined(CONFIG_DFS_MASTER)
-	rtw_dfs_master_status_apply(padapter, self_action);
+	rtw_dfs_rd_en_decision(padapter, mlme_act, parm->excl_ifbmp);
 #endif
-	rtw_hal_rcr_set_chk_bssid(padapter, self_action);
 
 #ifdef CONFIG_MCC_MODE
 	if (MCC_EN(padapter)) {
@@ -1554,8 +1751,10 @@ chbw_decision:
 	rtw_hal_mcc_issue_null_data(padapter, chbw_allow, 1);
 #endif /* CONFIG_MCC_MODE */
 
-	doiqk = _TRUE;
-	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+	if (!IS_CH_WAITING(adapter_to_rfctl(padapter))) {
+		doiqk = _TRUE;
+		rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
+	}
 
 	if (ch_to_set != 0) {
 		set_channel_bwmode(padapter, ch_to_set, offset_to_set, bw_to_set);
@@ -1570,81 +1769,124 @@ chbw_decision:
 	rtw_hal_set_mcc_setting_start_bss_network(padapter, chbw_allow);
 #endif
 
-	if (ch_setting_changed == _TRUE
-		&& (MLME_IS_GO(padapter) || MLME_IS_MESH(padapter)) /* pure AP is not needed*/
-		&& check_fwstate(pmlmepriv, WIFI_ASOC_STATE)
-	) {
-		#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
-		rtw_cfg80211_ch_switch_notify(padapter
-			, pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset
-			, pmlmepriv->htpriv.ht_option);
-		#endif
+#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	for (i = 0; i < pdvobj->iface_nums; i++) {
+		if (!(ifbmp_ch_changed & BIT(i)) || !pdvobj->padapters[i])
+			continue;
+
+		/* pure AP is not needed*/
+		if (MLME_IS_GO(pdvobj->padapters[i])
+			|| MLME_IS_MESH(pdvobj->padapters[i])
+		) {
+			u8 ht_option = 0;
+
+			#ifdef CONFIG_80211N_HT
+			ht_option = pdvobj->padapters[i]->mlmepriv.htpriv.ht_option;
+			#endif
+
+			rtw_cfg80211_ch_switch_notify(pdvobj->padapters[i]
+				, pdvobj->padapters[i]->mlmeextpriv.cur_channel
+				, pdvobj->padapters[i]->mlmeextpriv.cur_bwmode
+				, pdvobj->padapters[i]->mlmeextpriv.cur_ch_offset
+				, ht_option);
+		}
 	}
+#endif /* defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0)) */
 
 	if (DUMP_ADAPTERS_STATUS) {
 		RTW_INFO(FUNC_ADPT_FMT" done\n", FUNC_ADPT_ARG(padapter));
 		dump_adapters_status(RTW_DBGDUMP , adapter_to_dvobj(padapter));
 	}
 
+#ifdef CONFIG_MCC_MODE
 update_beacon:
-	/* update beacon content only if bstart_bss is _TRUE */
-	if (_TRUE == pmlmeext->bstart_bss) {
+#endif
 
-		_irqL irqL;
+	for (i = 0; i < pdvobj->iface_nums; i++) {
+		struct mlme_priv *mlme;
 
-		if ((ATOMIC_READ(&pmlmepriv->olbc) == _TRUE) || (ATOMIC_READ(&pmlmepriv->olbc_ht) == _TRUE)) {
-			/* AP is not starting a 40 MHz BSS in presence of an 802.11g BSS. */
+		if (!(parm->ifbmp & BIT(i)) || !pdvobj->padapters[i])
+			continue;
 
-			pmlmepriv->ht_op_mode &= (~HT_INFO_OPERATION_MODE_OP_MODE_MASK);
-			pmlmepriv->ht_op_mode |= OP_MODE_MAY_BE_LEGACY_STAS;
-			update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
+		/* update beacon content only if bstart_bss is _TRUE */
+		if (pdvobj->padapters[i]->mlmeextpriv.bstart_bss != _TRUE)
+			continue;
+
+		mlme = &(pdvobj->padapters[i]->mlmepriv);
+
+		#ifdef CONFIG_80211N_HT
+		if ((ATOMIC_READ(&mlme->olbc) == _TRUE) || (ATOMIC_READ(&mlme->olbc_ht) == _TRUE)) {
+			/* AP is not starting a 40 MHz BSS in presence of an 802.11g BSS. */
+			mlme->ht_op_mode &= (~HT_INFO_OPERATION_MODE_OP_MODE_MASK);
+			mlme->ht_op_mode |= OP_MODE_MAY_BE_LEGACY_STAS;
+			update_beacon(pdvobj->padapters[i], _HT_ADD_INFO_IE_, NULL, _FALSE);
 		}
+		#endif
 
-		update_beacon(padapter, _TIM_IE_, NULL, _FALSE);
+		update_beacon(pdvobj->padapters[i], _TIM_IE_, NULL, _FALSE);
+	}
+
+	if (mlme_act != MLME_OPCH_SWITCH
+		&& pmlmeext->bstart_bss == _TRUE
+	) {
+#ifdef CONFIG_SUPPORT_MULTI_BCN
+		_irqL irqL;
 
-#ifdef CONFIG_SWTIMER_BASED_TXBCN
 		_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
 		if (rtw_is_list_empty(&padapter->list)) {
+			#ifdef CONFIG_FW_HANDLE_TXBCN
+			padapter->vap_id = rtw_ap_allocate_vapid(pdvobj);
+			#endif
 			rtw_list_insert_tail(&padapter->list, get_list_head(&pdvobj->ap_if_q));
 			pdvobj->nr_ap_if++;
 			pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL / pdvobj->nr_ap_if;
 		}
 		_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
 
+		#ifdef CONFIG_SWTIMER_BASED_TXBCN
+		rtw_ap_set_mbid_num(padapter, pdvobj->nr_ap_if);
 		rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pdvobj->inter_bcn_space));
+		#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
 
-#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
+#endif /*CONFIG_SUPPORT_MULTI_BCN*/
 
+		#ifdef CONFIG_HW_P0_TSF_SYNC
+		correct_TSF(padapter, mlme_act);
+		#endif
 	}
 
 	rtw_scan_wait_completed(padapter);
 
+	_rtw_iface_undersurvey_chk(__func__, padapter);
 	/* send beacon */
-	if (!rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY)) {
-
-		/*update_beacon(padapter, _TIM_IE_, NULL, _TRUE);*/
-
+	ResumeTxBeacon(padapter);
+	{
 #if !defined(CONFIG_INTERRUPT_BASED_TXBCN)
-#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_PCI_BCN_POLLING)
 #ifdef CONFIG_SWTIMER_BASED_TXBCN
-		if (pdvobj->nr_ap_if == 1) {
+		if (pdvobj->nr_ap_if == 1
+			&& mlme_act != MLME_OPCH_SWITCH
+		) {
 			RTW_INFO("start SW BCN TIMER!\n");
 			_set_timer(&pdvobj->txbcn_timer, bcn_interval);
 		}
 #else
-		/* other case will  tx beacon when bcn interrupt coming in. */
-		if (send_beacon(padapter) == _FAIL)
-			RTW_INFO("issue_beacon, fail!\n");
+		for (i = 0; i < pdvobj->iface_nums; i++) {
+			if (!(parm->ifbmp & BIT(i)) || !pdvobj->padapters[i])
+				continue;
+
+			if (send_beacon(pdvobj->padapters[i]) == _FAIL)
+				RTW_INFO(ADPT_FMT" issue_beacon, fail!\n", ADPT_ARG(pdvobj->padapters[i]));
+		}
 #endif
 #endif
 #endif /* !defined(CONFIG_INTERRUPT_BASED_TXBCN) */
-	}
 
-	/*Set EDCA param reg after update cur_wireless_mode & update_capinfo*/
-	if (pregpriv->wifi_spec == 1)
-		rtw_set_hw_wmm_param(padapter);
-
-	/*pmlmeext->bstart_bss = _TRUE;*/
+#ifdef CONFIG_FW_HANDLE_TXBCN
+		if (mlme_act != MLME_OPCH_SWITCH)
+			rtw_ap_mbid_bcn_en(padapter, padapter->vap_id);
+#endif
+	}
 }
 
 int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
@@ -1656,23 +1898,23 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 	u16 cap, ht_cap = _FALSE;
 	uint ie_len = 0;
 	int group_cipher, pairwise_cipher;
+	u8 mfp_opt = MFP_NO;
 	u8	channel, network_type, supportRate[NDIS_802_11_LENGTH_RATES_EX];
 	int supportRateNum = 0;
 	u8 OUI1[] = {0x00, 0x50, 0xf2, 0x01};
-	u8 wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
 	u8 WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
+	HT_CAP_AMPDU_DENSITY best_ampdu_density;
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	WLAN_BSSID_EX *pbss_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
-	struct sta_priv *pstapriv = &padapter->stapriv;
 	u8 *ie = pbss_network->IEs;
 	u8 vht_cap = _FALSE;
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	u8 rf_num = 0;
-
+	int ret_rm;
 	/* SSID */
 	/* Supported rates */
 	/* DS Params */
@@ -1700,7 +1942,9 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 	_rtw_memcpy(ie, pbuf, pbss_network->IELength);
 
 
-	if (pbss_network->InfrastructureMode != Ndis802_11APMode) {
+	if (pbss_network->InfrastructureMode != Ndis802_11APMode
+		&& pbss_network->InfrastructureMode != Ndis802_11_mesh
+	) {
 		rtw_warn_on(1);
 		return _FAIL;
 	}
@@ -1735,6 +1979,18 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 #endif
 	}
 
+#ifdef CONFIG_RTW_MESH
+	/* Mesh ID */
+	if (MLME_IS_MESH(padapter)) {
+		p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, WLAN_EID_MESH_ID, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+		if (p && ie_len > 0) {
+			_rtw_memset(&pbss_network->mesh_id, 0, sizeof(NDIS_802_11_SSID));
+			_rtw_memcpy(pbss_network->mesh_id.Ssid, (p + 2), ie_len);
+			pbss_network->mesh_id.SsidLength = ie_len;
+		}
+	}
+#endif
+
 	/* chnnel */
 	channel = 0;
 	pbss_network->Configuration.Length = 0;
@@ -1749,6 +2005,13 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 	/* get supported rates */
 	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
 	if (p !=  NULL) {
+		if (padapter->registrypriv.wireless_mode == WIRELESS_11B) {
+			ret_rm = rtw_remove_ie_g_rate(ie , &len, _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_);
+			RTW_DBG("%s, rtw_remove_ie_g_rate=%d\n", __FUNCTION__,ret_rm);
+			ie_len = ie_len - ret_rm;
+			pbss_network->IELength=pbss_network->IELength - ret_rm;
+		}
+		RTW_DBG("%s, ie_len=%u\n", __FUNCTION__, ie_len);
 		_rtw_memcpy(supportRate, p + 2, ie_len);
 		supportRateNum = ie_len;
 	}
@@ -1756,8 +2019,15 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 	/* get ext_supported rates */
 	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, &ie_len, pbss_network->IELength - _BEACON_IE_OFFSET_);
 	if (p !=  NULL) {
-		_rtw_memcpy(supportRate + supportRateNum, p + 2, ie_len);
-		supportRateNum += ie_len;
+		if (padapter->registrypriv.wireless_mode == WIRELESS_11B) {
+			pbss_network->IELength = pbss_network->IELength-*(p+1) -2;
+			ret_rm = rtw_ies_remove_ie(ie , &len,_BEACON_IE_OFFSET_,
+					_EXT_SUPPORTEDRATES_IE_,NULL,0);
+			RTW_DBG("%s, remove_ie of ext_supported rates =%d\n", __FUNCTION__, ret_rm);
+		} else {
+			_rtw_memcpy(supportRate + supportRateNum, p + 2, ie_len);
+			supportRateNum += ie_len;
+		}
 
 	}
 
@@ -1768,8 +2038,16 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 
 	/* parsing ERP_IE */
 	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _ERPINFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if (p && ie_len > 0)
-		ERP_IE_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)p);
+	if (p && ie_len > 0)  {
+		if(padapter->registrypriv.wireless_mode == WIRELESS_11B ) {
+
+			pbss_network->IELength = pbss_network->IELength - *(p+1) - 2;
+			ret_rm = rtw_ies_remove_ie(ie , &len, _BEACON_IE_OFFSET_, _ERPINFO_IE_,NULL,0);
+			RTW_DBG("%s, remove_ie of ERP_IE=%d\n", __FUNCTION__, ret_rm);
+		} else 
+			ERP_IE_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)p);
+
+	}
 
 	/* update privacy/security */
 	if (cap & BIT(4))
@@ -1786,9 +2064,9 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 	psecuritypriv->wpa2_pairwise_cipher = _NO_PRIVACY_;
 	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
 	if (p && ie_len > 0) {
-		if (rtw_parse_wpa2_ie(p, ie_len + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+		if (rtw_parse_wpa2_ie(p, ie_len + 2, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
 			psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-
+			psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK;
 			psecuritypriv->dot8021xalg = 1;/* psk,  todo:802.1x */
 			psecuritypriv->wpa_psk |= BIT(1);
 
@@ -1846,7 +2124,7 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 		if ((p) && (_rtw_memcmp(p + 2, OUI1, 4))) {
 			if (rtw_parse_wpa_ie(p, ie_len + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
 				psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-
+				psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPAPSK;
 				psecuritypriv->dot8021xalg = 1;/* psk,  todo:802.1x */
 
 				psecuritypriv->wpa_psk |= BIT(0);
@@ -1902,9 +2180,26 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 
 	}
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		/* MFP is mandatory for secure mesh */
+		if (padapter->mesh_info.mesh_auth_id)
+			mfp_opt = MFP_REQUIRED;
+	} else
+#endif
+	if (mfp_opt == MFP_INVALID) {
+		RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+		return _FAIL;
+	}
+	psecuritypriv->mfp_opt = mfp_opt;
+
 	/* wmm */
 	ie_len = 0;
 	pmlmepriv->qospriv.qos_option = 0;
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		pmlmepriv->qospriv.qos_option = 1;
+#endif
 	if (pregistrypriv->wmm_enable) {
 		for (p = ie + _BEACON_IE_OFFSET_; ; p += (ie_len + 2)) {
 			p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));
@@ -1919,6 +2214,8 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 				*(p + 18) &= ~BIT(4); /* VI */
 				*(p + 22) &= ~BIT(4); /* VO */
 
+				WMM_param_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)p);
+
 				break;
 			}
 
@@ -1927,126 +2224,138 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 		}
 	}
 #ifdef CONFIG_80211N_HT
-	/* parsing HT_CAP_IE */
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if (p && ie_len > 0) {
-		u8 rf_type = 0;
-		HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor = MAX_AMPDU_FACTOR_64K;
-		struct rtw_ieee80211_ht_cap *pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
-
-		if (0) {
-			RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE from upper layer:\n", FUNC_ADPT_ARG(padapter));
-			dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
-		}
+	if(padapter->registrypriv.ht_enable &&
+		is_supported_ht(padapter->registrypriv.wireless_mode)) {
+		/* parsing HT_CAP_IE */
+		p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+		if (p && ie_len > 0) {
+			u8 rf_type = 0;
+			HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor = MAX_AMPDU_FACTOR_64K;
+			struct rtw_ieee80211_ht_cap *pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
+
+			if (0) {
+				RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE from upper layer:\n", FUNC_ADPT_ARG(padapter));
+				dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
+			}
 
-		pHT_caps_ie = p;
+			pHT_caps_ie = p;
 
-		ht_cap = _TRUE;
-		network_type |= WIRELESS_11_24N;
+			ht_cap = _TRUE;
+			network_type |= WIRELESS_11_24N;
 
-		rtw_ht_use_default_setting(padapter);
+			rtw_ht_use_default_setting(padapter);
 
-		/* Update HT Capabilities Info field */
-		if (pmlmepriv->htpriv.sgi_20m == _FALSE)
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_20);
+			/* Update HT Capabilities Info field */
+			if (pmlmepriv->htpriv.sgi_20m == _FALSE)
+				pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_20);
 
-		if (pmlmepriv->htpriv.sgi_40m == _FALSE)
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_40);
+			if (pmlmepriv->htpriv.sgi_40m == _FALSE)
+				pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_40);
 
-		if (!TEST_FLAG(pmlmepriv->htpriv.ldpc_cap, LDPC_HT_ENABLE_RX))
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_LDPC_CODING);
+			if (!TEST_FLAG(pmlmepriv->htpriv.ldpc_cap, LDPC_HT_ENABLE_RX))
+				pht_cap->cap_info &= ~(IEEE80211_HT_CAP_LDPC_CODING);
 
-		if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_TX_STBC);
+			if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
+				pht_cap->cap_info &= ~(IEEE80211_HT_CAP_TX_STBC);
 
-		if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_RX))
-			pht_cap->cap_info &= ~(IEEE80211_HT_CAP_RX_STBC_3R);
+			if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_RX))
+				pht_cap->cap_info &= ~(IEEE80211_HT_CAP_RX_STBC_3R);
 
-		/* Update A-MPDU Parameters field */
-		pht_cap->ampdu_params_info &= ~(IEEE80211_HT_CAP_AMPDU_FACTOR | IEEE80211_HT_CAP_AMPDU_DENSITY);
+			/* Update A-MPDU Parameters field */
+			pht_cap->ampdu_params_info &= ~(IEEE80211_HT_CAP_AMPDU_FACTOR | IEEE80211_HT_CAP_AMPDU_DENSITY);
 
-		if ((psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_CCMP) ||
-		    (psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_CCMP))
-			pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & (0x07 << 2));
-		else
-			pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & 0x00);
+			if ((psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_CCMP) ||
+				(psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_CCMP)) {
+				rtw_hal_get_def_var(padapter, HW_VAR_BEST_AMPDU_DENSITY, &best_ampdu_density);
+				pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & (best_ampdu_density << 2));
+			} else
+				pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & 0x00);
 
-		rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
-		pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_FACTOR & max_rx_ampdu_factor); /* set  Max Rx AMPDU size  to 64K */
+			rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
+			pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_FACTOR & max_rx_ampdu_factor); /* set  Max Rx AMPDU size  to 64K */
 
-		_rtw_memcpy(&(pmlmeinfo->HT_caps), pht_cap, sizeof(struct HT_caps_element));
+			_rtw_memcpy(&(pmlmeinfo->HT_caps), pht_cap, sizeof(struct HT_caps_element));
 
-		/* Update Supported MCS Set field */
-		{
-			struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
-			u8 rx_nss = 0;
-			int i;
+			/* Update Supported MCS Set field */
+			{
+				struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+				u8 rx_nss = 0;
+				int i;
 
-			rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
-			rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
+				rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+				rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
 
-			/* RX MCS Bitmask */
-			switch (rx_nss) {
-			case 1:
-				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_1R);
-				break;
-			case 2:
-				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_2R);
-				break;
-			case 3:
-				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_3R);
-				break;
-			case 4:
-				set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_4R);
-				break;
-			default:
-				RTW_WARN("rf_type:%d or rx_nss:%u is not expected\n", rf_type, hal_spec->rx_nss_num);
+				/* RX MCS Bitmask */
+				switch (rx_nss) {
+				case 1:
+					set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_1R);
+					break;
+				case 2:
+					set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_2R);
+					break;
+				case 3:
+					set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_3R);
+					break;
+				case 4:
+					set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_4R);
+					break;
+				default:
+					RTW_WARN("rf_type:%d or rx_nss:%u is not expected\n", rf_type, hal_spec->rx_nss_num);
+				}
+				for (i = 0; i < 10; i++)
+					*(HT_CAP_ELE_RX_MCS_MAP(pht_cap) + i) &= padapter->mlmeextpriv.default_supported_mcs_set[i];
 			}
-			for (i = 0; i < 10; i++)
-				*(HT_CAP_ELE_RX_MCS_MAP(pht_cap) + i) &= padapter->mlmeextpriv.default_supported_mcs_set[i];
-		}
 
 #ifdef CONFIG_BEAMFORMING
-		/* Use registry value to enable HT Beamforming. */
-		/* ToDo: use configure file to set these capability. */
-		pht_cap->tx_BF_cap_info = 0;
-
-		/* HT Beamformer */
-		if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
-			/* Transmit NDP Capable */
-			SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(pht_cap, 1);
-			/* Explicit Compressed Steering Capable */
-			SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pht_cap, 1);
-			/* Compressed Steering Number Antennas */
-			SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, 1);
-			rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
-			SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pht_cap, rf_num);
-		}
+			/* Use registry value to enable HT Beamforming. */
+			/* ToDo: use configure file to set these capability. */
+			pht_cap->tx_BF_cap_info = 0;
+
+			/* HT Beamformer */
+			if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
+				/* Transmit NDP Capable */
+				SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(pht_cap, 1);
+				/* Explicit Compressed Steering Capable */
+				SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pht_cap, 1);
+				/* Compressed Steering Number Antennas */
+				SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, 1);
+				rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
+				SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pht_cap, rf_num);
+			}
 
-		/* HT Beamformee */
-		if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) {
-			/* Receive NDP Capable */
-			SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(pht_cap, 1);
-			/* Explicit Compressed Beamforming Feedback Capable */
-			SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pht_cap, 2);
-			rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
-			SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, rf_num);
-		}
+			/* HT Beamformee */
+			if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) {
+				/* Receive NDP Capable */
+				SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(pht_cap, 1);
+				/* Explicit Compressed Beamforming Feedback Capable */
+				SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pht_cap, 2);
+				rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
+				SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, rf_num);
+			}
 #endif /* CONFIG_BEAMFORMING */
 
-		_rtw_memcpy(&pmlmepriv->htpriv.ht_cap, p + 2, ie_len);
+			_rtw_memcpy(&pmlmepriv->htpriv.ht_cap, p + 2, ie_len);
 
-		if (0) {
-			RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE driver masked:\n", FUNC_ADPT_ARG(padapter));
-			dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
+			if (0) {
+				RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE driver masked:\n", FUNC_ADPT_ARG(padapter));
+				dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
+			}
 		}
-	}
 
-	/* parsing HT_INFO_IE */
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if (p && ie_len > 0)
-		pHT_info_ie = p;
+		/* parsing HT_INFO_IE */
+		p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+		if (p && ie_len > 0) {
+			pHT_info_ie = p;
+			if (channel == 0)
+				pbss_network->Configuration.DSConfig = GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2);
+			else if (channel != GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2)) {
+				RTW_INFO(FUNC_ADPT_FMT" ch inconsistent, DSSS:%u, HT primary:%u\n"
+					, FUNC_ADPT_ARG(padapter), channel, GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2));
+			}
+		}
+	}
 #endif /* CONFIG_80211N_HT */
+
 	switch (network_type) {
 	case WIRELESS_11B:
 		pbss_network->NetworkTypeInUse = Ndis802_11DS;
@@ -2077,7 +2386,9 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 	}
 
 	/* ht_cap	 */
-	if (pregistrypriv->ht_enable && ht_cap == _TRUE) {
+	if (padapter->registrypriv.ht_enable &&
+		is_supported_ht(padapter->registrypriv.wireless_mode) && ht_cap == _TRUE) {
+
 		pmlmepriv->htpriv.ht_option = _TRUE;
 		pmlmepriv->qospriv.qos_option = 1;
 
@@ -2090,30 +2401,43 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 #endif
 
 #ifdef CONFIG_80211AC_VHT
+	pmlmepriv->ori_vht_en = 0;
+	pmlmepriv->vhtpriv.vht_option = _FALSE;
 
-	/* Parsing VHT CAP IE */
-	p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
-	if (p && ie_len > 0)
-		vht_cap = _TRUE;
-	/* Parsing VHT OPERATION IE */
+	if (pmlmepriv->htpriv.ht_option == _TRUE
+		&& pbss_network->Configuration.DSConfig > 14
+		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
+		&& is_supported_vht(pregistrypriv->wireless_mode)
+		&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+	) {
+		/* Parsing VHT CAP IE */
+		p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
+		if (p && ie_len > 0)
+			vht_cap = _TRUE;
 
+		/* Parsing VHT OPERATION IE */
 
-	pmlmepriv->vhtpriv.vht_option = _FALSE;
-	/* if channel in 5G band, then add vht ie . */
-	if ((pbss_network->Configuration.DSConfig > 14)
-	    && (pmlmepriv->htpriv.ht_option == _TRUE)
-	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
-	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
-	   ) {
-		if (vht_cap == _TRUE)
+		if (vht_cap == _TRUE
+			&& MLME_IS_MESH(padapter) /* allow only mesh temporarily before VHT IE checking is ready */
+		) {
+			rtw_check_for_vht20(padapter, ie + _BEACON_IE_OFFSET_, pbss_network->IELength - _BEACON_IE_OFFSET_);
+			pmlmepriv->ori_vht_en = 1;
 			pmlmepriv->vhtpriv.vht_option = _TRUE;
-		else if (REGSTY_IS_11AC_AUTO(pregistrypriv))
+		} else if (REGSTY_IS_11AC_AUTO(pregistrypriv)) {
+			rtw_vht_ies_detach(padapter, pbss_network);
 			rtw_vht_ies_attach(padapter, pbss_network);
+		}
 	}
+
+	if (pmlmepriv->vhtpriv.vht_option == _FALSE)
+		rtw_vht_ies_detach(padapter, pbss_network);
 #endif /* CONFIG_80211AC_VHT */
 
-	if(pbss_network->Configuration.DSConfig <= 14 && padapter->registrypriv.wifi_spec == 1) {
+#ifdef CONFIG_80211N_HT
+	if(padapter->registrypriv.ht_enable &&
+					is_supported_ht(padapter->registrypriv.wireless_mode) &&
+		pbss_network->Configuration.DSConfig <= 14 && padapter->registrypriv.wifi_spec == 1 &&
+		pbss_network->IELength + 10 <= MAX_IE_SZ) {
 		uint len = 0;
 
 		SET_EXT_CAPABILITY_ELE_BSS_COEXIST(pmlmepriv->ext_capab_ie_data, 1);
@@ -2121,11 +2445,12 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 		rtw_set_ie(pbss_network->IEs + pbss_network->IELength, EID_EXTCapability, 8, pmlmepriv->ext_capab_ie_data, &len);
 		pbss_network->IELength += pmlmepriv->ext_capab_ie_len;
 	}
+#endif /* CONFIG_80211N_HT */
 
 	pbss_network->Length = get_WLAN_BSSID_EX_sz((WLAN_BSSID_EX *)pbss_network);
 
 	rtw_ies_get_chbw(pbss_network->IEs + _BEACON_IE_OFFSET_, pbss_network->IELength - _BEACON_IE_OFFSET_
-		, &pmlmepriv->ori_ch, &pmlmepriv->ori_bw, &pmlmepriv->ori_offset);
+		, &pmlmepriv->ori_ch, &pmlmepriv->ori_bw, &pmlmepriv->ori_offset, 1, 1);
 	rtw_warn_on(pmlmepriv->ori_ch == 0);
 
 	{
@@ -2161,14 +2486,24 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)
 }
 
 #if CONFIG_RTW_MACADDR_ACL
-void rtw_macaddr_acl_init(_adapter *adapter)
+void rtw_macaddr_acl_init(_adapter *adapter, u8 period)
 {
 	struct sta_priv *stapriv = &adapter->stapriv;
-	struct wlan_acl_pool *acl = &stapriv->acl_list;
-	_queue *acl_node_q = &acl->acl_node_q;
+	struct wlan_acl_pool *acl;
+	_queue *acl_node_q;
 	int i;
 	_irqL irqL;
 
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
+	_rtw_spinlock_init(&(acl_node_q->lock));
+
 	_enter_critical_bh(&(acl_node_q->lock), &irqL);
 	_rtw_init_listhead(&(acl_node_q->queue));
 	acl->num = 0;
@@ -2180,15 +2515,23 @@ void rtw_macaddr_acl_init(_adapter *adapter)
 	_exit_critical_bh(&(acl_node_q->lock), &irqL);
 }
 
-void rtw_macaddr_acl_deinit(_adapter *adapter)
+static void _rtw_macaddr_acl_deinit(_adapter *adapter, u8 period, bool clear_only)
 {
 	struct sta_priv *stapriv = &adapter->stapriv;
-	struct wlan_acl_pool *acl = &stapriv->acl_list;
-	_queue *acl_node_q = &acl->acl_node_q;
+	struct wlan_acl_pool *acl;
+	_queue *acl_node_q;
 	_irqL irqL;
 	_list *head, *list;
 	struct rtw_wlan_acl_node *acl_node;
 
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
 	_enter_critical_bh(&(acl_node_q->lock), &irqL);
 	head = get_list_head(acl_node_q);
 	list = get_next(head);
@@ -2204,24 +2547,42 @@ void rtw_macaddr_acl_deinit(_adapter *adapter)
 	}
 	_exit_critical_bh(&(acl_node_q->lock), &irqL);
 
+	if (!clear_only)
+		_rtw_spinlock_free(&(acl_node_q->lock));
+
 	rtw_warn_on(acl->num);
 	acl->mode = RTW_ACL_MODE_DISABLED;
 }
 
-void rtw_set_macaddr_acl(_adapter *adapter, int mode)
+void rtw_macaddr_acl_deinit(_adapter *adapter, u8 period)
+{
+	_rtw_macaddr_acl_deinit(adapter, period, 0);
+}
+
+void rtw_macaddr_acl_clear(_adapter *adapter, u8 period)
+{
+	_rtw_macaddr_acl_deinit(adapter, period, 1);
+}
+
+void rtw_set_macaddr_acl(_adapter *adapter, u8 period, int mode)
 {
 	struct sta_priv *stapriv = &adapter->stapriv;
-	struct wlan_acl_pool *acl = &stapriv->acl_list;
+	struct wlan_acl_pool *acl;
 
-	RTW_INFO(FUNC_ADPT_FMT" mode=%d\n", FUNC_ADPT_ARG(adapter), mode);
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		return;
+	}
 
-	acl->mode = mode;
+	acl = &stapriv->acl_list[period];
+
+	RTW_INFO(FUNC_ADPT_FMT" p=%u, mode=%d\n"
+		, FUNC_ADPT_ARG(adapter), period, mode);
 
-	if (mode == RTW_ACL_MODE_DISABLED)
-		rtw_macaddr_acl_deinit(adapter);
+	acl->mode = mode;
 }
 
-int rtw_acl_add_sta(_adapter *adapter, const u8 *addr)
+int rtw_acl_add_sta(_adapter *adapter, u8 period, const u8 *addr)
 {
 	_irqL irqL;
 	_list *list, *head;
@@ -2229,8 +2590,17 @@ int rtw_acl_add_sta(_adapter *adapter, const u8 *addr)
 	int i = -1, ret = 0;
 	struct rtw_wlan_acl_node *acl_node;
 	struct sta_priv *stapriv = &adapter->stapriv;
-	struct wlan_acl_pool *acl = &stapriv->acl_list;
-	_queue *acl_node_q = &acl->acl_node_q;
+	struct wlan_acl_pool *acl;
+	_queue *acl_node_q;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		ret = -1;
+		goto exit;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
 
 	_enter_critical_bh(&(acl_node_q->lock), &irqL);
 
@@ -2277,26 +2647,34 @@ release_lock:
 	if (!existed && (i < 0 || i >= NUM_ACL))
 		ret = -1;
 
-	RTW_INFO(FUNC_ADPT_FMT" "MAC_FMT" %s (acl_num=%d)\n"
-		 , FUNC_ADPT_ARG(adapter), MAC_ARG(addr)
+	RTW_INFO(FUNC_ADPT_FMT" p=%u "MAC_FMT" %s (acl_num=%d)\n"
+		 , FUNC_ADPT_ARG(adapter), period, MAC_ARG(addr)
 		, (existed ? "existed" : ((i < 0 || i >= NUM_ACL) ? "no room" : "added"))
 		 , acl->num);
-
+exit:
 	return ret;
 }
 
-int rtw_acl_remove_sta(_adapter *adapter, const u8 *addr)
+int rtw_acl_remove_sta(_adapter *adapter, u8 period, const u8 *addr)
 {
 	_irqL irqL;
 	_list *list, *head;
 	int ret = 0;
 	struct rtw_wlan_acl_node *acl_node;
 	struct sta_priv *stapriv = &adapter->stapriv;
-	struct wlan_acl_pool *acl = &stapriv->acl_list;
-	_queue	*acl_node_q = &acl->acl_node_q;
+	struct wlan_acl_pool *acl;
+	_queue	*acl_node_q;
 	u8 is_baddr = is_broadcast_mac_addr(addr);
 	u8 match = 0;
 
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
 	_enter_critical_bh(&(acl_node_q->lock), &irqL);
 
 	head = get_list_head(acl_node_q);
@@ -2318,51 +2696,59 @@ int rtw_acl_remove_sta(_adapter *adapter, const u8 *addr)
 
 	_exit_critical_bh(&(acl_node_q->lock), &irqL);
 
-	RTW_INFO(FUNC_ADPT_FMT" "MAC_FMT" %s (acl_num=%d)\n"
-		 , FUNC_ADPT_ARG(adapter), MAC_ARG(addr)
+	RTW_INFO(FUNC_ADPT_FMT" p=%u "MAC_FMT" %s (acl_num=%d)\n"
+		 , FUNC_ADPT_ARG(adapter), period, MAC_ARG(addr)
 		 , is_baddr ? "clear all" : (match ? "match" : "no found")
 		 , acl->num);
 
+exit:
 	return ret;
 }
 #endif /* CONFIG_RTW_MACADDR_ACL */
 
-u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta)
+u8 rtw_ap_set_sta_key(_adapter *adapter, const u8 *addr, u8 alg, const u8 *key, u8 keyid, u8 gk)
 {
-	struct cmd_obj			*ph2c;
-	struct set_stakey_parm	*psetstakey_para;
-	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
+	struct cmd_priv *cmdpriv = &adapter->cmdpriv;
+	struct cmd_obj *cmd;
+	struct set_stakey_parm *param;
 	u8	res = _SUCCESS;
 
-	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
-	if (ph2c == NULL) {
+	cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (cmd == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	psetstakey_para = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
-	if (psetstakey_para == NULL) {
-		rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
+	param = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
+	if (param == NULL) {
+		rtw_mfree((u8 *) cmd, sizeof(struct cmd_obj));
 		res = _FAIL;
 		goto exit;
 	}
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, psetstakey_para, _SetStaKey_CMD_);
-
+	init_h2fwcmd_w_parm_no_rsp(cmd, param, _SetStaKey_CMD_);
 
-	psetstakey_para->algorithm = (u8)psta->dot118021XPrivacy;
+	_rtw_memcpy(param->addr, addr, ETH_ALEN);
+	param->algorithm = alg;
+	param->keyid = keyid;
+	_rtw_memcpy(param->key, key, 16);
+	param->gk = gk;
 
-	_rtw_memcpy(psetstakey_para->addr, psta->cmn.mac_addr, ETH_ALEN);
-
-	_rtw_memcpy(psetstakey_para->key, &psta->dot118021x_UncstKey, 16);
-
-
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+	res = rtw_enqueue_cmd(cmdpriv, cmd);
 
 exit:
-
 	return res;
+}
 
+u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta)
+{
+	return rtw_ap_set_sta_key(padapter
+		, psta->cmn.mac_addr
+		, psta->dot118021XPrivacy
+		, psta->dot118021x_UncstKey.skey
+		, 0
+		, 0
+	);
 }
 
 static int rtw_ap_set_key(_adapter *padapter, u8 *key, u8 alg, int keyid, u8 set_tx)
@@ -2479,7 +2865,7 @@ u8 rtw_ap_bmc_frames_hdl(_adapter *padapter)
 
 	_enter_critical_bh(&pxmitpriv->lock, &irqL);
 
-	if ((pstapriv->tim_bitmap & BIT(0)) && (psta_bmc->sleepq_len > 0)) {
+	if ((rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) && (psta_bmc->sleepq_len > 0)) {
 		int tx_counts = 0;
 
 		_update_beacon(padapter, _TIM_IE_, NULL, _FALSE, "update TIM with TIB=1");
@@ -2524,11 +2910,11 @@ u8 rtw_ap_bmc_frames_hdl(_adapter *padapter)
 
 			/*RTW_INFO("sleepq_len of bmc_sta = %d\n", psta_bmc->sleepq_len);*/
 
-			if (pstapriv->tim_bitmap & BIT(0))
+			if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0))
 				update_tim = _TRUE;
 
-			pstapriv->tim_bitmap &= ~BIT(0);
-			pstapriv->sta_dz_bitmap &= ~BIT(0);
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
 
 			if (update_tim == _TRUE) {
 				RTW_INFO("clear TIB\n");
@@ -2562,7 +2948,7 @@ static void associated_stainfo_update(_adapter *padapter, struct sta_info *psta,
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
 	RTW_INFO("%s: "MAC_FMT", updated_type=0x%x\n", __func__, MAC_ARG(psta->cmn.mac_addr), sta_info_type);
-
+#ifdef CONFIG_80211N_HT
 	if (sta_info_type & STA_INFO_UPDATE_BW) {
 
 		if ((psta->flags & WLAN_STA_HT) && !psta->ht_20mhz_set) {
@@ -2575,7 +2961,7 @@ static void associated_stainfo_update(_adapter *padapter, struct sta_info *psta,
 			}
 		}
 	}
-
+#endif /* CONFIG_80211N_HT */
 	/*
 		if (sta_info_type & STA_INFO_UPDATE_RATE) {
 
@@ -2664,6 +3050,7 @@ static void update_bcn_htcap_ie(_adapter *padapter)
 
 static void update_bcn_htinfo_ie(_adapter *padapter)
 {
+#ifdef CONFIG_80211N_HT
 	/*
 	u8 beacon_updated = _FALSE;
 	u32 sta_info_update_type = STA_INFO_UPDATE_NONE;
@@ -2742,7 +3129,7 @@ static void update_bcn_htinfo_ie(_adapter *padapter)
 	}
 
 	/*associated_clients_update(padapter, beacon_updated, sta_info_update_type);*/
-
+#endif /* CONFIG_80211N_HT */
 }
 
 static void update_bcn_rsn_ie(_adapter *padapter)
@@ -2858,6 +3245,7 @@ void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *ta
 	_irqL irqL;
 	struct mlme_priv *pmlmepriv;
 	struct mlme_ext_priv *pmlmeext;
+	bool updated = 1; /* treat as upadated by default */
 
 	if (!padapter)
 		return;
@@ -2895,6 +3283,14 @@ void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *ta
 		update_bcn_ext_capab_ie(padapter);
 		break;
 
+#ifdef CONFIG_RTW_MESH
+	case WLAN_EID_MESH_CONFIG:
+		updated = rtw_mesh_update_bss_peering_status(padapter, &(pmlmeext->mlmext_info.network));
+		updated |= rtw_mesh_update_bss_formation_info(padapter, &(pmlmeext->mlmext_info.network));
+		updated |= rtw_mesh_update_bss_forwarding_state(padapter, &(pmlmeext->mlmext_info.network));
+		break;
+#endif
+
 	case _VENDOR_SPECIFIC_IE_:
 		update_bcn_vendor_spec_ie(padapter, oui);
 		break;
@@ -2904,13 +3300,14 @@ void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *ta
 		break;
 	}
 
-	pmlmepriv->update_bcn = _TRUE;
+	if (updated)
+		pmlmepriv->update_bcn = _TRUE;
 
 	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
 
 #ifndef CONFIG_INTERRUPT_BASED_TXBCN
-#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
-	if (tx) {
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_PCI_BCN_POLLING)
+	if (tx && updated) {
 		/* send_beacon(padapter); */ /* send_beacon must execute on TSR level */
 		if (0)
 			RTW_INFO(FUNC_ADPT_FMT" ie_id:%u - %s\n", FUNC_ADPT_ARG(padapter), ie_id, tag);
@@ -2996,25 +3393,23 @@ void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field)
 	if (psta == NULL)
 		return;
 
-	e_field = (ctrl_field & BIT(0)) ? 1 : 0;
-	m_field = (ctrl_field & BIT(1)) ? 1 : 0;
+	e_field = (ctrl_field & BIT(0)) ? 1 : 0; /*SM Power Save Enabled*/
+	m_field = (ctrl_field & BIT(1)) ? 1 : 0; /*SM Mode, 0:static SMPS, 1:dynamic SMPS*/
 
 	if (e_field) {
-
-		/* enable */
-		/* 0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
-
-		if (m_field) /*mode*/
-			psta->htpriv.smps_cap = 1;
+		if (m_field) { /*mode*/
+			psta->htpriv.smps_cap = WLAN_HT_CAP_SM_PS_DYNAMIC;
+			RTW_ERR("Don't support dynamic SMPS\n");
+		}
 		else
-			psta->htpriv.smps_cap = 0;
+			psta->htpriv.smps_cap = WLAN_HT_CAP_SM_PS_STATIC;
 	} else {
 		/*disable*/
-		psta->htpriv.smps_cap = 3;
+		psta->htpriv.smps_cap = WLAN_HT_CAP_SM_PS_DISABLED;
 	}
 
-	rtw_dm_ra_mask_wk_cmd(padapter, (u8 *)psta);
-
+	if (psta->htpriv.smps_cap != WLAN_HT_CAP_SM_PS_DYNAMIC)
+		rtw_ssmps_wk_cmd(padapter, psta, e_field, 1);
 }
 
 /*
@@ -3243,58 +3638,80 @@ void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta)
 	}
 
 #ifdef CONFIG_80211N_HT
-	if (psta->flags & WLAN_STA_HT) {
-		u16 ht_capab = le16_to_cpu(psta->htpriv.ht_cap.cap_info);
+	if(padapter->registrypriv.ht_enable &&
+		is_supported_ht(padapter->registrypriv.wireless_mode)) {
+		if (psta->flags & WLAN_STA_HT) {
+			u16 ht_capab = le16_to_cpu(psta->htpriv.ht_cap.cap_info);
 
-		RTW_INFO("HT: STA " MAC_FMT " HT Capabilities Info: 0x%04x\n",
-			MAC_ARG(psta->cmn.mac_addr), ht_capab);
+			RTW_INFO("HT: STA " MAC_FMT " HT Capabilities Info: 0x%04x\n",
+				MAC_ARG(psta->cmn.mac_addr), ht_capab);
 
-		if (psta->no_ht_set) {
-			psta->no_ht_set = 0;
-			pmlmepriv->num_sta_no_ht--;
-		}
+			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++;
+			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++;
+				}
+				RTW_INFO("%s STA " MAC_FMT " - no "
+					 "greenfield, num of non-gf stations %d\n",
+					 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
+					 pmlmepriv->num_sta_ht_no_gf);
+			}
+
+			if ((ht_capab & IEEE80211_HT_CAP_SUP_WIDTH) == 0) {
+				if (!psta->ht_20mhz_set) {
+					psta->ht_20mhz_set = 1;
+					pmlmepriv->num_sta_ht_20mhz++;
+				}
+				RTW_INFO("%s STA " MAC_FMT " - 20 MHz HT, "
+					 "num of 20MHz HT STAs %d\n",
+					 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
+					 pmlmepriv->num_sta_ht_20mhz);
 			}
-			RTW_INFO("%s STA " MAC_FMT " - no "
-				 "greenfield, num of non-gf stations %d\n",
-				 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
-				 pmlmepriv->num_sta_ht_no_gf);
-		}
 
-		if ((ht_capab & IEEE80211_HT_CAP_SUP_WIDTH) == 0) {
-			if (!psta->ht_20mhz_set) {
-				psta->ht_20mhz_set = 1;
-				pmlmepriv->num_sta_ht_20mhz++;
+			if (((ht_capab & RTW_IEEE80211_HT_CAP_40MHZ_INTOLERANT) != 0) &&
+				(psta->ht_40mhz_intolerant == 0)) {
+				psta->ht_40mhz_intolerant = 1;
+				pmlmepriv->num_sta_40mhz_intolerant++;
+				RTW_INFO("%s STA " MAC_FMT " - 40MHZ_INTOLERANT, ",
+					   __FUNCTION__, MAC_ARG(psta->cmn.mac_addr));
 			}
-			RTW_INFO("%s STA " MAC_FMT " - 20 MHz HT, "
-				 "num of 20MHz HT STAs %d\n",
-				 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
-				 pmlmepriv->num_sta_ht_20mhz);
-		}
 
-	} else {
-		if (!psta->no_ht_set) {
-			psta->no_ht_set = 1;
-			pmlmepriv->num_sta_no_ht++;
+		} else {
+			if (!psta->no_ht_set) {
+				psta->no_ht_set = 1;
+				pmlmepriv->num_sta_no_ht++;
+			}
+			if (pmlmepriv->htpriv.ht_option == _TRUE) {
+				RTW_INFO("%s STA " MAC_FMT
+					 " - no HT, num of non-HT stations %d\n",
+					 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
+					 pmlmepriv->num_sta_no_ht);
+			}
 		}
-		if (pmlmepriv->htpriv.ht_option == _TRUE) {
-			RTW_INFO("%s STA " MAC_FMT
-				 " - no HT, num of non-HT stations %d\n",
-				 __FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
-				 pmlmepriv->num_sta_no_ht);
+
+		if (rtw_ht_operation_update(padapter) > 0) {
+			update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
+			update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
+			beacon_updated = _TRUE;
 		}
 	}
+#endif /* CONFIG_80211N_HT */
 
-	if (rtw_ht_operation_update(padapter) > 0) {
-		update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
-		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		struct sta_priv *pstapriv = &padapter->stapriv;
+
+		update_beacon(padapter, WLAN_EID_MESH_CONFIG, NULL, _FALSE);
+		if (pstapriv->asoc_list_cnt == 1)
+			_set_timer(&padapter->mesh_atlm_param_req_timer, 0);
 		beacon_updated = _TRUE;
 	}
-#endif /* CONFIG_80211N_HT */
+#endif
 
 	if (beacon_updated)
 		update_beacon(padapter, 0xFF, NULL, _TRUE);
@@ -3316,8 +3733,8 @@ u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta)
 	if (!psta)
 		return beacon_updated;
 
-	if (pstapriv->tim_bitmap & BIT(psta->cmn.aid)) {
-		pstapriv->tim_bitmap &= (~ BIT(psta->cmn.aid));
+	if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
+		rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 		beacon_updated = _TRUE;
 		update_beacon(padapter, _TIM_IE_, NULL, _FALSE);
 	}
@@ -3363,12 +3780,29 @@ u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta)
 		pmlmepriv->num_sta_ht_20mhz--;
 	}
 
+	if (psta->ht_40mhz_intolerant) {
+		psta->ht_40mhz_intolerant = 0;
+		if (pmlmepriv->num_sta_40mhz_intolerant > 0)
+			pmlmepriv->num_sta_40mhz_intolerant--;
+		else
+			rtw_warn_on(1);
+	}
+
 	if (rtw_ht_operation_update(padapter) > 0) {
 		update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE);
 		update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE);
 	}
 #endif /* CONFIG_80211N_HT */
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		update_beacon(padapter, WLAN_EID_MESH_CONFIG, NULL, _FALSE);
+		if (pstapriv->asoc_list_cnt == 0)
+			_cancel_timer_ex(&padapter->mesh_atlm_param_req_timer);
+		beacon_updated = _TRUE;
+	}
+#endif
+
 	if (beacon_updated == _TRUE)
 		update_beacon(padapter, 0xFF, NULL, _TRUE);
 
@@ -3387,9 +3821,6 @@ u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reaso
 {
 	_irqL irqL;
 	u8 beacon_updated = _FALSE;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct sta_priv *pstapriv = &padapter->stapriv;
 
 	if (!psta)
 		return beacon_updated;
@@ -3404,25 +3835,33 @@ u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reaso
 
 #endif /* CONFIG_80211N_HT */
 
-		issue_deauth(padapter, psta->cmn.mac_addr, reason);
+		if (!MLME_IS_MESH(padapter))
+			issue_deauth(padapter, psta->cmn.mac_addr, reason);
 	}
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_mesh_path_flush_by_nexthop(psta);
+#endif
+
 #ifdef CONFIG_BEAMFORMING
 	beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_LEAVE, psta->cmn.mac_addr, ETH_ALEN, 1);
 #endif
 
+#ifdef CONFIG_80211N_HT
 	psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
 	psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
+#endif
 
 	/* clear cam entry / key */
 	rtw_clearstakey_cmd(padapter, psta, enqueue);
 
 
 	_enter_critical_bh(&psta->lock, &irqL);
-	psta->state &= ~_FW_LINKED;
+	psta->state &= ~(_FW_LINKED | WIFI_UNDER_KEY_HANDSHAKE);
 	_exit_critical_bh(&psta->lock, &irqL);
 
-	{
+	if (!MLME_IS_MESH(padapter)) {
 #ifdef CONFIG_IOCTL_CFG80211
 		#ifdef COMPAT_KERNEL_RELEASE
 		rtw_cfg80211_indicate_sta_disassoc(padapter, psta->cmn.mac_addr, reason);
@@ -3436,14 +3875,9 @@ u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reaso
 #endif
 	}
 
-	report_del_sta_event(padapter, psta->cmn.mac_addr, reason, enqueue, _FALSE);
-
 	beacon_updated = bss_cap_update_on_sta_leave(padapter, psta);
 
-	/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);					 */
-	rtw_free_stainfo(padapter, psta);
-	/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
-
+	report_del_sta_event(padapter, psta->cmn.mac_addr, reason, enqueue, _FALSE);
 
 	return beacon_updated;
 
@@ -3492,8 +3926,6 @@ int rtw_sta_flush(_adapter *padapter, bool enqueue)
 	int ret = 0;
 	struct sta_info *psta = NULL;
 	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 flush_num = 0;
 	char flush_list[NUM_STA];
@@ -3516,6 +3948,7 @@ int rtw_sta_flush(_adapter *padapter, bool enqueue)
 
 		rtw_list_delete(&psta->asoc_list);
 		pstapriv->asoc_list_cnt--;
+		STA_SET_MESH_PLINK(psta, NULL);
 
 		stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
 		if (stainfo_offset_valid(stainfo_offset))
@@ -3527,11 +3960,20 @@ int rtw_sta_flush(_adapter *padapter, bool enqueue)
 
 	/* call ap_free_sta() for each sta picked */
 	for (i = 0; i < flush_num; i++) {
+		u8 sta_addr[ETH_ALEN];
+
 		psta = rtw_get_stainfo_by_offset(pstapriv, flush_list[i]);
+		_rtw_memcpy(sta_addr, psta->cmn.mac_addr, ETH_ALEN);
+
 		ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, enqueue);
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter))
+			rtw_mesh_expire_peer(padapter, sta_addr);
+		#endif
 	}
 
-	issue_deauth(padapter, bc_addr, WLAN_REASON_DEAUTH_LEAVING);
+	if (!MLME_IS_MESH(padapter))
+		issue_deauth(padapter, bc_addr, WLAN_REASON_DEAUTH_LEAVING);
 
 	associated_clients_update(padapter, _TRUE, STA_INFO_UPDATE_ALL);
 
@@ -3592,9 +4034,7 @@ void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta)
 /* restore hw setting from sw data structures */
 void rtw_ap_restore_network(_adapter *padapter)
 {
-	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct sta_info *psta;
 	struct security_priv *psecuritypriv = &(padapter->securitypriv);
@@ -3604,7 +4044,10 @@ void rtw_ap_restore_network(_adapter *padapter)
 	char chk_alive_list[NUM_STA];
 	int i;
 
-	rtw_setopmode_cmd(padapter, Ndis802_11APMode, _FALSE);
+	rtw_setopmode_cmd(padapter
+		, MLME_IS_AP(padapter) ? Ndis802_11APMode : Ndis802_11_mesh
+		, RTW_CMDF_DIRECTLY
+	);
 
 	set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
 
@@ -3660,7 +4103,9 @@ void start_ap_mode(_adapter *padapter)
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+#ifdef CONFIG_CONCURRENT_MODE
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#endif
 
 	pmlmepriv->update_bcn = _FALSE;
 
@@ -3701,13 +4146,9 @@ void start_ap_mode(_adapter *padapter)
 	psecuritypriv->dot118021x_bmc_cam_id = INVALID_SEC_MAC_CAM_ID;
 #endif
 
-	for (i = 0 ;  i < NUM_STA ; i++)
+	for (i = 0 ;  i < pstapriv->max_aid; i++)
 		pstapriv->sta_aid[i] = NULL;
 
-#if CONFIG_RTW_MACADDR_ACL
-	rtw_macaddr_acl_init(padapter);
-#endif
-
 	psta = rtw_get_bcmc_stainfo(padapter);
 	/*_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);*/
 	if (psta)
@@ -3743,11 +4184,13 @@ void rtw_ap_bcmc_sta_flush(_adapter *padapter)
 void stop_ap_mode(_adapter *padapter)
 {
 	u8 self_action = MLME_ACTION_UNKNOWN;
-	_irqL irqL;
 	struct sta_info *psta = NULL;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+#ifdef CONFIG_SUPPORT_MULTI_BCN
 	struct dvobj_priv *pdvobj = padapter->dvobj;
+	_irqL irqL;
+#endif
 
 	RTW_INFO("%s -"ADPT_FMT"\n", __func__, ADPT_ARG(padapter));
 
@@ -3769,14 +4212,14 @@ void stop_ap_mode(_adapter *padapter)
 	padapter->securitypriv.ndisencryptstatus = Ndis802_11WEPDisabled;
 
 #ifdef CONFIG_DFS_MASTER
-	rtw_dfs_master_status_apply(padapter, self_action);
+	rtw_dfs_rd_en_decision(padapter, self_action, 0);
 #endif
 
 	/* free scan queue */
 	rtw_free_network_queue(padapter, _TRUE);
 
 #if CONFIG_RTW_MACADDR_ACL
-	rtw_macaddr_acl_deinit(padapter);
+	rtw_macaddr_acl_clear(padapter, RTW_ACL_PERIOD_BSS);
 #endif
 
 	rtw_sta_flush(padapter, _TRUE);
@@ -3795,22 +4238,35 @@ void stop_ap_mode(_adapter *padapter)
 
 	rtw_free_mlme_priv_ie_data(pmlmepriv);
 
-#ifdef CONFIG_SWTIMER_BASED_TXBCN
+#ifdef CONFIG_SUPPORT_MULTI_BCN
 	if (pmlmeext->bstart_bss == _TRUE) {
+		#ifdef CONFIG_FW_HANDLE_TXBCN
+		u8 free_apid = CONFIG_LIMITED_AP_NUM;
+		#endif
+
 		_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
 		pdvobj->nr_ap_if--;
 		if (pdvobj->nr_ap_if > 0)
 			pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL / pdvobj->nr_ap_if;
 		else
 			pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL;
-
+		#ifdef CONFIG_FW_HANDLE_TXBCN
+		rtw_ap_release_vapid(pdvobj, padapter->vap_id);
+		free_apid = padapter->vap_id;
+		padapter->vap_id = CONFIG_LIMITED_AP_NUM;
+		#endif
 		rtw_list_delete(&padapter->list);
 		_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
+		#ifdef CONFIG_FW_HANDLE_TXBCN
+		rtw_ap_mbid_bcn_dis(padapter, free_apid);
+		#endif
 
+		#ifdef CONFIG_SWTIMER_BASED_TXBCN
 		rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pdvobj->inter_bcn_space));
 
 		if (pdvobj->nr_ap_if == 0)
 			_cancel_timer_ex(&pdvobj->txbcn_timer);
+		#endif
 	}
 #endif
 
@@ -3818,6 +4274,10 @@ void stop_ap_mode(_adapter *padapter)
 
 	rtw_hal_rcr_set_chk_bssid(padapter, self_action);
 
+#ifdef CONFIG_HW_P0_TSF_SYNC
+	correct_TSF(padapter, self_action);
+#endif
+
 #ifdef CONFIG_BT_COEXIST
 	rtw_btcoex_MediaStatusNotify(padapter, 0); /* disconnect */
 #endif
@@ -3950,244 +4410,527 @@ void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw,
 #endif /* CONFIG_80211N_HT */
 }
 
-bool rtw_ap_chbw_decision(_adapter *adapter, s16 req_ch, s8 req_bw, s8 req_offset
-			  , u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow)
+static u8 rtw_ap_update_chbw_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp
+	, u8 cur_ie_ch[], u8 cur_ie_bw[], u8 cur_ie_offset[]
+	, u8 dec_ch[], u8 dec_bw[], u8 dec_offset[]
+	, const char *caller)
 {
-	u8 cur_ie_ch, cur_ie_bw, cur_ie_offset;
-	u8 dec_ch, dec_bw, dec_offset;
-	u8 u_ch = 0, u_offset, u_bw;
-	bool changed = _FALSE;
-	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
-	WLAN_BSSID_EX *network = &(mlmeext->mlmext_info.network);
-	struct mi_state mstate;
-	bool set_u_ch = _FALSE, set_dec_ch = _FALSE;
-
-	rtw_ies_get_chbw(BSS_EX_TLV_IES(network), BSS_EX_TLV_IES_LEN(network)
-		, &cur_ie_ch, &cur_ie_bw, &cur_ie_offset);
+	_adapter *iface;
+	struct mlme_ext_priv *mlmeext;
+	WLAN_BSSID_EX *network;
+	u8 ifbmp_ch_changed = 0;
+	int i;
 
-#ifdef CONFIG_MCC_MODE
-	if (MCC_EN(adapter)) {
-		if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
-			/* check channel settings are the same */
-			if (cur_ie_ch == mlmeext->cur_channel
-				&& cur_ie_bw == mlmeext->cur_bwmode
-					&& cur_ie_offset == mlmeext->cur_ch_offset) {
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (!(ifbmp & BIT(i)) || !dvobj->padapters)
+			continue;
 
+		iface = dvobj->padapters[i];
+		mlmeext = &(iface->mlmeextpriv);
 
-					RTW_INFO(FUNC_ADPT_FMT"req ch settings are the same as current ch setting, go to exit\n"
-						, FUNC_ADPT_ARG(adapter));
+		if (MLME_IS_ASOC(iface)) {
+			RTW_INFO(FUNC_ADPT_FMT" %u,%u,%u => %u,%u,%u%s\n", caller, ADPT_ARG(iface)
+				, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset
+				, dec_ch[i], dec_bw[i], dec_offset[i]
+				, MLME_IS_OPCH_SW(iface) ? " OPCH_SW" : "");
+		} else {
+			RTW_INFO(FUNC_ADPT_FMT" %u,%u,%u => %u,%u,%u%s\n", caller, ADPT_ARG(iface)
+				, cur_ie_ch[i], cur_ie_bw[i], cur_ie_offset[i]
+				, dec_ch[i], dec_bw[i], dec_offset[i]
+				, MLME_IS_OPCH_SW(iface) ? " OPCH_SW" : "");
+		}
+	}
 
-					*chbw_allow = _FALSE;
-					goto exit;
-			} else {
-					RTW_INFO(FUNC_ADPT_FMT"request channel settings are not the same as current channel setting(%d,%d,%d,%d,%d,%d), restart MCC\n"
-						, FUNC_ADPT_ARG(adapter)
-						, cur_ie_ch, cur_ie_bw, cur_ie_bw
-						, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (!(ifbmp & BIT(i)) || !dvobj->padapters)
+			continue;
 
-				rtw_hal_set_mcc_setting_disconnect(adapter);
+		iface = dvobj->padapters[i];
+		mlmeext = &(iface->mlmeextpriv);
+		network = &(mlmeext->mlmext_info.network);
+
+		/* ch setting differs from mlmeext.network IE */
+		if (cur_ie_ch[i] != dec_ch[i]
+			|| cur_ie_bw[i] != dec_bw[i]
+			|| cur_ie_offset[i] != dec_offset[i])
+			ifbmp_ch_changed |= BIT(i);
+
+		/* ch setting differs from existing one */
+		if (MLME_IS_ASOC(iface)
+			&& (mlmeext->cur_channel != dec_ch[i]
+				|| mlmeext->cur_bwmode != dec_bw[i]
+				|| mlmeext->cur_ch_offset != dec_offset[i])
+		) {
+			if (rtw_linked_check(iface) == _TRUE) {
+				#ifdef CONFIG_SPCT_CH_SWITCH
+				if (1)
+					rtw_ap_inform_ch_switch(iface, dec_ch[i], dec_offset[i]);
+				else
+				#endif
+					rtw_sta_flush(iface, _FALSE);
 			}
-		}	
+		}
+
+		mlmeext->cur_channel = dec_ch[i];
+		mlmeext->cur_bwmode = dec_bw[i];
+		mlmeext->cur_ch_offset = dec_offset[i];
+
+		rtw_ap_update_bss_chbw(iface, network, dec_ch[i], dec_bw[i], dec_offset[i]);
 	}
-#endif /* CONFIG_MCC_MODE */
 
-	/* use chbw of cur_ie updated with specifying req as temporary decision */
-	dec_ch = (req_ch <= 0) ? cur_ie_ch : req_ch;
-	dec_bw = (req_bw < 0) ? cur_ie_bw : req_bw;
-	dec_offset = (req_offset < 0) ? cur_ie_offset : req_offset;
+	return ifbmp_ch_changed;
+}
 
-	rtw_mi_status_no_self(adapter, &mstate);
-	RTW_INFO(FUNC_ADPT_FMT" ld_sta_num:%u, lg_sta_num%u, ap_num:%u, mesh_num:%u\n"
-		, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate), MSTATE_STA_LG_NUM(&mstate)
-		, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate));
+static u8 rtw_ap_ch_specific_chk(_adapter *adapter, u8 ch, u8 *bw, u8 *offset, const char *caller)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	RT_CHANNEL_INFO *chset = adapter_to_chset(adapter);
+	u8 ret = _SUCCESS;
 
-	if (MSTATE_STA_LD_NUM(&mstate) || MSTATE_AP_NUM(&mstate) || MSTATE_MESH_NUM(&mstate)) {
-		/* has linked STA or AP/Mesh mode, follow */
+	if (rtw_chset_search_ch(chset, ch) < 0) {
+		RTW_WARN("%s ch:%u doesn't fit in chplan\n", caller, ch);
+		ret = _FAIL;
+		goto exit;
+	}
 
-		rtw_warn_on(!rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset));
+	rtw_adjust_chbw(adapter, ch, bw, offset);
 
-		RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
-		RTW_INFO(FUNC_ADPT_FMT" req: %d,%d,%d\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
+	if (!rtw_get_offset_by_chbw(ch, *bw, offset)) {
+		RTW_WARN("%s %u,%u has no valid offset\n", caller, ch, *bw);
+		ret = _FAIL;
+		goto exit;
+	}
 
-		rtw_adjust_chbw(adapter, u_ch, &dec_bw, &dec_offset);
-#ifdef CONFIG_MCC_MODE
-		if (MCC_EN(adapter)) {
-			if (!rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch, dec_bw, dec_offset)) {
-				mlmeext->cur_channel = *ch = dec_ch;
-				mlmeext->cur_bwmode = *bw = dec_bw;
-				mlmeext->cur_ch_offset = *offset = dec_offset;
-				/* channel bw offset can not be allowed, need MCC */
-				*chbw_allow = _FALSE;
-				RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
-					 , *ch, *bw, *offset);
-				goto exit;
-			} else
-				/* channel bw offset can be allowed, not need MCC */
-				*chbw_allow = _TRUE;
+	while (!rtw_chset_is_chbw_valid(chset, ch, *bw, *offset)
+		|| (rtw_odm_dfs_domain_unknown(dvobj) && rtw_is_dfs_chbw(ch, *bw, *offset))
+	) {
+		if (*bw > CHANNEL_WIDTH_20)
+			(*bw)--;
+		if (*bw == CHANNEL_WIDTH_20) {
+			*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			break;
 		}
-#endif /* CONFIG_MCC_MODE */
-		rtw_sync_chbw(&dec_ch, &dec_bw, &dec_offset
-			      , &u_ch, &u_bw, &u_offset);
+	}
 
-		rtw_ap_update_bss_chbw(adapter, network, dec_ch, dec_bw, dec_offset);
+	if (rtw_odm_dfs_domain_unknown(dvobj) && rtw_is_dfs_chbw(ch, *bw, *offset)) {
+		RTW_WARN("%s DFS channel %u can't be used\n", caller, ch);
+		ret = _FAIL;
+		goto exit;
+	}
 
-		set_u_ch = _TRUE;
-	} else if (MSTATE_STA_LG_NUM(&mstate)) {
-		/* has linking STA */
+exit:
+	return ret;
+}
+
+static bool rtw_ap_choose_chbw(_adapter *adapter, u8 sel_ch, u8 max_bw, u8 cur_ch
+	, u8 *ch, u8 *bw, u8 *offset, u8 mesh_only, const char *caller)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	bool ch_avail = _FALSE;
+
+#if defined(CONFIG_DFS_MASTER)
+	if (!rtw_odm_dfs_domain_unknown(dvobj)) {
+		if (rfctl->radar_detected
+			&& rfctl->dbg_dfs_choose_dfs_ch_first
+		) {
+			ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
+						, ch, bw, offset
+						, RTW_CHF_2G | RTW_CHF_NON_DFS
+						, cur_ch
+						, rfctl->ch_sel_same_band_prefer, mesh_only);
+			if (ch_avail == _TRUE) {
+				RTW_INFO("%s choose 5G DFS channel for debug\n", caller);
+				goto exit;
+			}
+		}
 
-		rtw_warn_on(!rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset));
+		if (rfctl->radar_detected
+			&& rfctl->dfs_ch_sel_d_flags
+		) {
+			ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
+						, ch, bw, offset
+						, rfctl->dfs_ch_sel_d_flags
+						, cur_ch
+						, rfctl->ch_sel_same_band_prefer, mesh_only);
+			if (ch_avail == _TRUE) {
+				RTW_INFO("%s choose with dfs_ch_sel_d_flags:0x%02x for debug\n"
+					, caller, rfctl->dfs_ch_sel_d_flags);
+				goto exit;
+			}
+		}
 
-		RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
-		RTW_INFO(FUNC_ADPT_FMT" req: %d,%d,%d\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
+		ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
+					, ch, bw, offset
+					, 0
+					, cur_ch
+					, rfctl->ch_sel_same_band_prefer, mesh_only);
+	} else
+#endif /* defined(CONFIG_DFS_MASTER) */
+	{
+		ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
+					, ch, bw, offset
+					, RTW_CHF_DFS
+					, cur_ch
+					, rfctl->ch_sel_same_band_prefer, mesh_only);
+	}
 
-		rtw_adjust_chbw(adapter, dec_ch, &dec_bw, &dec_offset);
+exit:
+	if (ch_avail == _FALSE)
+		RTW_WARN("%s no available channel\n", caller);
 
-		if (rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch, dec_bw, dec_offset)) {
+	return ch_avail;
+}
 
-			rtw_sync_chbw(&dec_ch, &dec_bw, &dec_offset
-				      , &u_ch, &u_bw, &u_offset);
+u8 rtw_ap_chbw_decision(_adapter *adapter, u8 ifbmp, u8 excl_ifbmp
+	, s16 req_ch, s8 req_bw, s8 req_offset
+	, u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	RT_CHANNEL_INFO *chset = adapter_to_chset(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	bool ch_avail = _FALSE;
+	u8 cur_ie_ch[CONFIG_IFACE_NUMBER] = {0};
+	u8 cur_ie_bw[CONFIG_IFACE_NUMBER] = {0};
+	u8 cur_ie_offset[CONFIG_IFACE_NUMBER] = {0};
+	u8 dec_ch[CONFIG_IFACE_NUMBER] = {0};
+	u8 dec_bw[CONFIG_IFACE_NUMBER] = {0};
+	u8 dec_offset[CONFIG_IFACE_NUMBER] = {0};
+	u8 u_ch = 0, u_bw = 0, u_offset = 0;
+	struct mlme_ext_priv *mlmeext;
+	WLAN_BSSID_EX *network;
+	struct mi_state mstate;
+	struct mi_state mstate_others;
+	bool set_u_ch = _FALSE;
+	u8 ifbmp_others = 0xFF & ~ifbmp & ~excl_ifbmp;
+	u8 ifbmp_ch_changed = 0;
+	bool ifbmp_all_mesh = 0;
+	_adapter *iface;
+	int i;
 
-			rtw_ap_update_bss_chbw(adapter, network, dec_ch, dec_bw, dec_offset);
+#ifdef CONFIG_RTW_MESH
+	for (i = 0; i < dvobj->iface_nums; i++)
+		if ((ifbmp & BIT(i)) && dvobj->padapters)
+			if (!MLME_IS_MESH(dvobj->padapters[i]))
+				break;
+	ifbmp_all_mesh = i >= dvobj->iface_nums ? 1 : 0;
+#endif
 
-			set_u_ch = _TRUE;
+	RTW_INFO("%s ifbmp:0x%02x excl_ifbmp:0x%02x req:%d,%d,%d\n", __func__
+		, ifbmp, excl_ifbmp, req_ch, req_bw, req_offset);
+	rtw_mi_status_by_ifbmp(dvobj, ifbmp, &mstate);
+	rtw_mi_status_by_ifbmp(dvobj, ifbmp_others, &mstate_others);
+	RTW_INFO("%s others ld_sta_num:%u, lg_sta_num:%u, ap_num:%u, mesh_num:%u\n"
+		, __func__, MSTATE_STA_LD_NUM(&mstate_others), MSTATE_STA_LG_NUM(&mstate_others)
+		, MSTATE_AP_NUM(&mstate_others), MSTATE_MESH_NUM(&mstate_others));
 
-			/* channel bw offset can be allowed, not need MCC */
-			*chbw_allow = _TRUE;
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
+			continue;
+		iface = dvobj->padapters[i];
+		mlmeext = &(iface->mlmeextpriv);
+		network = &(mlmeext->mlmext_info.network);
+
+		/* get current IE channel settings */
+		rtw_ies_get_chbw(BSS_EX_TLV_IES(network), BSS_EX_TLV_IES_LEN(network)
+			, &cur_ie_ch[i], &cur_ie_bw[i], &cur_ie_offset[i], 1, 1);
+
+		/* prepare temporary channel setting decision */
+		if (req_ch == 0) {
+			/* request comes from upper layer, use cur_ie values */
+			dec_ch[i] = cur_ie_ch[i];
+			dec_bw[i] = cur_ie_bw[i];
+			dec_offset[i] = cur_ie_offset[i];
 		} else {
+			/* use chbw of cur_ie updated with specifying req as temporary decision */
+			dec_ch[i] = (req_ch <= REQ_CH_NONE) ? cur_ie_ch[i] : req_ch;
+			if (req_bw <= REQ_BW_NONE) {
+				if (req_bw == REQ_BW_ORI)
+					dec_bw[i] = iface->mlmepriv.ori_bw;
+				else
+					dec_bw[i] = cur_ie_bw[i];
+			} else
+				dec_bw[i] = req_bw;
+			dec_offset[i] = (req_offset <= REQ_OFFSET_NONE) ? cur_ie_offset[i] : req_offset;
+		}
+	}
+
+	if (MSTATE_STA_LD_NUM(&mstate_others) || MSTATE_STA_LG_NUM(&mstate_others)
+		|| MSTATE_AP_NUM(&mstate_others) || MSTATE_MESH_NUM(&mstate_others)
+	) {
+		/* has linked/linking STA or has AP/Mesh mode */
+		rtw_warn_on(!rtw_mi_get_ch_setting_union_by_ifbmp(dvobj, ifbmp_others, &u_ch, &u_bw, &u_offset));
+		RTW_INFO("%s others union:%u,%u,%u\n", __func__, u_ch, u_bw, u_offset);
+	}
+
 #ifdef CONFIG_MCC_MODE
-			if (MCC_EN(adapter)) {
-				mlmeext->cur_channel = *ch = dec_ch;
-				mlmeext->cur_bwmode = *bw = dec_bw;
-				mlmeext->cur_ch_offset = *offset = dec_offset;
+	if (MCC_EN(adapter) && req_ch == 0) {
+		if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
+			u8 if_id = adapter->iface_id;
+
+			mlmeext = &(adapter->mlmeextpriv);
+
+			/* check channel settings are the same */
+			if (cur_ie_ch[if_id] == mlmeext->cur_channel
+				&& cur_ie_bw[if_id] == mlmeext->cur_bwmode
+				&& cur_ie_offset[if_id] == mlmeext->cur_ch_offset) {
+
+				RTW_INFO(FUNC_ADPT_FMT"req ch settings are the same as current ch setting, go to exit\n"
+					, FUNC_ADPT_ARG(adapter));
 
-				/* channel bw offset can not be allowed, need MCC */
 				*chbw_allow = _FALSE;
-				RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
-					 , *ch, *bw, *offset);
 				goto exit;
+			} else {
+				RTW_INFO(FUNC_ADPT_FMT"request channel settings are not the same as current channel setting(%d,%d,%d,%d,%d,%d), restart MCC\n"
+					, FUNC_ADPT_ARG(adapter)
+					, cur_ie_ch[if_id], cur_ie_bw[if_id], cur_ie_offset[if_id]
+					, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+
+				rtw_hal_set_mcc_setting_disconnect(adapter);
 			}
+		}	
+	}
 #endif /* CONFIG_MCC_MODE */
-			/* set this for possible ch change when join down*/
-			set_fwstate(&adapter->mlmepriv, WIFI_OP_CH_SWITCHING);
+
+	if (MSTATE_STA_LG_NUM(&mstate_others) && !MSTATE_STA_LD_NUM(&mstate_others)) {
+		/* has linking STA but no linked STA */
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
+				continue;
+			iface = dvobj->padapters[i];
+
+			rtw_adjust_chbw(iface, dec_ch[i], &dec_bw[i], &dec_offset[i]);
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(iface))
+				rtw_mesh_adjust_chbw(dec_ch[i], &dec_bw[i], &dec_offset[i]);
+			#endif
+
+			if (rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch[i], dec_bw[i], dec_offset[i])) {
+				rtw_chset_sync_chbw(chset
+					, &dec_ch[i], &dec_bw[i], &dec_offset[i]
+					, &u_ch, &u_bw, &u_offset);
+				set_u_ch = _TRUE;
+
+				/* channel bw offset can be allowed, not need MCC */
+				*chbw_allow = _TRUE;
+			} else {
+				#ifdef CONFIG_MCC_MODE
+				if (MCC_EN(iface)) {
+					mlmeext = &(iface->mlmeextpriv);
+					mlmeext->cur_channel = *ch = dec_ch[i];
+					mlmeext->cur_bwmode = *bw = dec_bw[i];
+					mlmeext->cur_ch_offset = *offset = dec_offset[i];
+
+					/* channel bw offset can not be allowed, need MCC */
+					*chbw_allow = _FALSE;
+					RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(iface)
+						 , *ch, *bw, *offset);
+					goto exit;
+				}
+				#endif /* CONFIG_MCC_MODE */
+
+				/* set this for possible ch change when join down*/
+				set_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING);
+			}
 		}
-	} else {
-		/* single AP/Mesh mode */
 
-		RTW_INFO(FUNC_ADPT_FMT" req: %d,%d,%d\n", FUNC_ADPT_ARG(adapter), req_ch, req_bw, req_offset);
+	} else if (MSTATE_STA_LD_NUM(&mstate_others)
+		|| MSTATE_AP_NUM(&mstate_others) || MSTATE_MESH_NUM(&mstate_others)
+	) {
+		/* has linked STA mode or AP/Mesh mode */
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
+				continue;
+			iface = dvobj->padapters[i];
 
-		/* check temporary decision first */
-		rtw_adjust_chbw(adapter, dec_ch, &dec_bw, &dec_offset);
-		if (!rtw_get_offset_by_chbw(dec_ch, dec_bw, &dec_offset)) {
-			if (req_ch == -1 || req_bw == -1)
-				goto choose_chbw;
-			RTW_WARN(FUNC_ADPT_FMT" req: %u,%u has no valid offset\n", FUNC_ADPT_ARG(adapter), dec_ch, dec_bw);
-			*chbw_allow = _FALSE;
-			goto exit;
+			rtw_adjust_chbw(iface, u_ch, &dec_bw[i], &dec_offset[i]);
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(iface))
+				rtw_mesh_adjust_chbw(u_ch, &dec_bw[i], &dec_offset[i]);
+			#endif
+
+			#ifdef CONFIG_MCC_MODE
+			if (MCC_EN(iface)) {
+				if (!rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch[i], dec_bw[i], dec_offset[i])) {
+					mlmeext = &(iface->mlmeextpriv);
+					mlmeext->cur_channel = *ch = dec_ch[i] = cur_ie_ch[i];
+					mlmeext->cur_bwmode = *bw = dec_bw[i] = cur_ie_bw[i];
+					mlmeext->cur_ch_offset = *offset = dec_offset[i] = cur_ie_offset[i];
+					/* channel bw offset can not be allowed, need MCC */
+					*chbw_allow = _FALSE;
+					RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(iface)
+						 , *ch, *bw, *offset);
+					goto exit;
+				} else
+					/* channel bw offset can be allowed, not need MCC */
+					*chbw_allow = _TRUE;
+			}
+			#endif /* CONFIG_MCC_MODE */
+
+			if (req_ch == 0 && dec_bw[i] > u_bw
+				&& rtw_is_dfs_chbw(u_ch, u_bw, u_offset)
+			) {
+				/* request comes from upper layer, prevent from additional channel waiting */
+				dec_bw[i] = u_bw;
+				if (dec_bw[i] == CHANNEL_WIDTH_20)
+					dec_offset[i] = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			}
+
+			/* follow */
+			rtw_chset_sync_chbw(chset
+				, &dec_ch[i], &dec_bw[i], &dec_offset[i]
+				, &u_ch, &u_bw, &u_offset);
 		}
 
-		if (!rtw_chset_is_chbw_valid(adapter_to_chset(adapter), dec_ch, dec_bw, dec_offset)) {
-			if (req_ch == -1 || req_bw == -1)
-				goto choose_chbw;
-			RTW_WARN(FUNC_ADPT_FMT" req: %u,%u,%u doesn't fit in chplan\n", FUNC_ADPT_ARG(adapter), dec_ch, dec_bw, dec_offset);
-			*chbw_allow = _FALSE;
-			goto exit;
+		set_u_ch = _TRUE;
+
+	} else {
+		/* autonomous decision */
+		u8 ori_ch = 0;
+		u8 max_bw;
+
+		/* autonomous decision, not need MCC */
+		*chbw_allow = _TRUE;
+
+		if (req_ch <= REQ_CH_NONE) /* channel is not specified */
+			goto choose_chbw;
+
+		/* get tmp dec union of ifbmp */
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
+				continue;
+			if (u_ch == 0) {
+				u_ch = dec_ch[i];
+				u_bw = dec_bw[i];
+				u_offset = dec_offset[i];
+				rtw_adjust_chbw(adapter, u_ch, &u_bw, &u_offset);
+				rtw_get_offset_by_chbw(u_ch, u_bw, &u_offset);
+			} else {
+				u8 tmp_ch = dec_ch[i];
+				u8 tmp_bw = dec_bw[i];
+				u8 tmp_offset = dec_offset[i];
+				
+				rtw_adjust_chbw(adapter, tmp_ch, &tmp_bw, &tmp_offset);
+				rtw_get_offset_by_chbw(tmp_ch, tmp_bw, &tmp_offset);
+
+				rtw_warn_on(!rtw_is_chbw_grouped(u_ch, u_bw, u_offset, tmp_ch, tmp_bw, tmp_offset));
+				rtw_sync_chbw(&tmp_ch, &tmp_bw, &tmp_offset, &u_ch, &u_bw, &u_offset);
+			}
 		}
 
-		if (rtw_odm_dfs_domain_unknown(adapter) && rtw_is_dfs_chbw(dec_ch, dec_bw, dec_offset)) {
-			if (req_ch >= 0)
-				RTW_WARN(FUNC_ADPT_FMT" DFS channel %u,%u,%u can't be used\n", FUNC_ADPT_ARG(adapter), dec_ch, dec_bw, dec_offset);
+		#ifdef CONFIG_RTW_MESH
+		/* if ifbmp are all mesh, apply bw restriction */
+		if (ifbmp_all_mesh)
+			rtw_mesh_adjust_chbw(u_ch, &u_bw, &u_offset);
+		#endif
+
+		RTW_INFO("%s ifbmp:0x%02x tmp union:%u,%u,%u\n", __func__, ifbmp, u_ch, u_bw, u_offset);
+
+		/* check if tmp dec union is usable */
+		if (rtw_ap_ch_specific_chk(adapter, u_ch, &u_bw, &u_offset, __func__) == _FAIL) {
+			/* channel can't be used */
 			if (req_ch > 0) {
 				/* specific channel and not from IE => don't change channel setting */
-				*chbw_allow = _FALSE;
 				goto exit;
 			}
 			goto choose_chbw;
-		}
-
-		if (rtw_chset_is_ch_non_ocp(adapter_to_chset(adapter), dec_ch, dec_bw, dec_offset) == _FALSE)
+		} else if (rtw_chset_is_chbw_non_ocp(chset, u_ch, u_bw, u_offset)) {
+			RTW_WARN("%s DFS channel %u,%u under non ocp\n", __func__, u_ch, u_bw);
+			if (req_ch > 0 && req_bw > REQ_BW_NONE) {
+				/* change_chbw with specific channel and specific bw, goto update_bss_chbw directly */
+				goto update_bss_chbw;
+			}
+		} else
 			goto update_bss_chbw;
 
 choose_chbw:
-		if (req_bw < 0)
-			req_bw = cur_ie_bw;
+		req_ch = req_ch > 0 ? req_ch : 0;
+		max_bw = req_bw > REQ_BW_NONE ? req_bw : CHANNEL_WIDTH_20;
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
+				continue;
+			iface = dvobj->padapters[i];
+			mlmeext = &(iface->mlmeextpriv);
+
+			if (req_bw <= REQ_BW_NONE) {
+				if (req_bw == REQ_BW_ORI) {
+					if (max_bw < iface->mlmepriv.ori_bw)
+						max_bw = iface->mlmepriv.ori_bw;
+				} else {
+					if (max_bw < cur_ie_bw[i])
+						max_bw = cur_ie_bw[i];
+				}
+			}
 
-#if defined(CONFIG_DFS_MASTER)
-		if (!rtw_odm_dfs_domain_unknown(adapter)) {
-			/* choose 5G DFS channel for debug */
-			if (adapter_to_rfctl(adapter)->dbg_dfs_master_choose_dfs_ch_first
-				&& rtw_choose_shortest_waiting_ch(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, RTW_CHF_2G | RTW_CHF_NON_DFS) == _TRUE)
-				RTW_INFO(FUNC_ADPT_FMT" choose 5G DFS channel for debug\n", FUNC_ADPT_ARG(adapter));
-			else if (adapter_to_rfctl(adapter)->dfs_ch_sel_d_flags
-				&& rtw_choose_shortest_waiting_ch(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, adapter_to_rfctl(adapter)->dfs_ch_sel_d_flags) == _TRUE)
-				RTW_INFO(FUNC_ADPT_FMT" choose with dfs_ch_sel_d_flags:0x%02x for debug\n", FUNC_ADPT_ARG(adapter), adapter_to_rfctl(adapter)->dfs_ch_sel_d_flags);
-			else if (rtw_choose_shortest_waiting_ch(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, 0) == _FALSE) {
-				RTW_WARN(FUNC_ADPT_FMT" no available channel\n", FUNC_ADPT_ARG(adapter));
-				*chbw_allow = _FALSE;
-				goto exit;
+			if (MSTATE_AP_NUM(&mstate) || MSTATE_MESH_NUM(&mstate)) {
+				if (ori_ch == 0)
+					ori_ch = mlmeext->cur_channel;
+				else if (ori_ch != mlmeext->cur_channel)
+					rtw_warn_on(1);
+			} else {
+				if (ori_ch == 0)
+					ori_ch = cur_ie_ch[i];
+				else if (ori_ch != cur_ie_ch[i])
+					rtw_warn_on(1);
 			}
-		} else
-#endif /* defined(CONFIG_DFS_MASTER) */
-		if (rtw_choose_shortest_waiting_ch(adapter, req_bw, &dec_ch, &dec_bw, &dec_offset, RTW_CHF_DFS) == _FALSE) {
-			RTW_WARN(FUNC_ADPT_FMT" no available channel\n", FUNC_ADPT_ARG(adapter));
-			*chbw_allow = _FALSE;
-			goto exit;
 		}
 
-update_bss_chbw:
-		rtw_ap_update_bss_chbw(adapter, network, dec_ch, dec_bw, dec_offset);
+		ch_avail = rtw_ap_choose_chbw(adapter, req_ch, max_bw
+			, ori_ch, &u_ch, &u_bw, &u_offset, ifbmp_all_mesh, __func__);
+		if (ch_avail == _FALSE)
+			goto exit;
 
-		/* channel bw offset can be allowed for single AP, not need MCC */
-		*chbw_allow = _TRUE;
-		set_dec_ch = _TRUE;
-	}
+update_bss_chbw:
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
+				continue;
+			iface = dvobj->padapters[i];
 
-	if (rtw_mi_check_fwstate(adapter, _FW_UNDER_SURVEY)) {
-		/* scanning, leave ch setting to scan state machine */
-		set_u_ch = set_dec_ch = _FALSE;
-	}
+			dec_ch[i] = u_ch;
+			if (dec_bw[i] > u_bw)
+				dec_bw[i] = u_bw;
+			if (dec_bw[i] == CHANNEL_WIDTH_20)
+				dec_offset[i] = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			else
+				dec_offset[i] = u_offset;
 
-	if (mlmeext->cur_channel != dec_ch
-	    || mlmeext->cur_bwmode != dec_bw
-	    || mlmeext->cur_ch_offset != dec_offset)
-		changed = _TRUE;
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(iface))
+				rtw_mesh_adjust_chbw(dec_ch[i], &dec_bw[i], &dec_offset[i]);
+			#endif
+		}
 
-	if (changed == _TRUE && rtw_linked_check(adapter) == _TRUE) {
-#ifdef CONFIG_SPCT_CH_SWITCH
-		if (1)
-			rtw_ap_inform_ch_switch(adapter, dec_ch, dec_offset);
-		else
-#endif
-			rtw_sta_flush(adapter, _FALSE);
+		set_u_ch = _TRUE;
 	}
 
-	mlmeext->cur_channel = dec_ch;
-	mlmeext->cur_bwmode = dec_bw;
-	mlmeext->cur_ch_offset = dec_offset;
+	ifbmp_ch_changed = rtw_ap_update_chbw_by_ifbmp(dvobj, ifbmp
+							, cur_ie_ch, cur_ie_bw, cur_ie_offset
+							, dec_ch, dec_bw, dec_offset
+							, __func__);
 
 	if (u_ch != 0)
-		RTW_INFO(FUNC_ADPT_FMT" union: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
+		RTW_INFO("%s union:%u,%u,%u\n", __func__, u_ch, u_bw, u_offset);
 
-	RTW_INFO(FUNC_ADPT_FMT" dec: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), dec_ch, dec_bw, dec_offset);
+	if (rtw_mi_check_fwstate(adapter, _FW_UNDER_SURVEY)) {
+		/* scanning, leave ch setting to scan state machine */
+		set_u_ch = _FALSE;
+	}
 
 	if (set_u_ch == _TRUE) {
 		*ch = u_ch;
 		*bw = u_bw;
 		*offset = u_offset;
-	} else if (set_dec_ch == _TRUE) {
-		*ch = dec_ch;
-		*bw = dec_bw;
-		*offset = dec_offset;
 	}
 exit:
-	return changed;
+	return ifbmp_ch_changed;
 }
 
-u8 rtw_ap_sta_linking_state_check(_adapter *adapter)
+u8 rtw_ap_sta_states_check(_adapter *adapter)
 {
 	struct sta_info *psta;
-	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct sta_priv *pstapriv = &adapter->stapriv;
-	int i;
 	_list *plist, *phead;
 	_irqL irqL;
 	u8 rst = _FALSE;
@@ -4202,9 +4945,16 @@ u8 rtw_ap_sta_linking_state_check(_adapter *adapter)
 	phead = &pstapriv->asoc_list;
 	plist = get_next(phead);
 	while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+
 		psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
 		plist = get_next(plist);
-		if (!(psta->state &_FW_LINKED)) {
+
+		if (!(psta->state & _FW_LINKED)) {
+			RTW_INFO(ADPT_FMT"- SoftAP/Mesh - sta under linking, its state = 0x%x\n", ADPT_ARG(adapter), psta->state);
+			rst = _TRUE;
+			break;
+		} else if (psta->state & WIFI_UNDER_KEY_HANDSHAKE) {
+			RTW_INFO(ADPT_FMT"- SoftAP/Mesh - sta under key handshaking, its state = 0x%x\n", ADPT_ARG(adapter), psta->state);
 			rst = _TRUE;
 			break;
 		}
@@ -4342,9 +5092,7 @@ void tx_beacon_handlder(struct dvobj_priv *pdvobj)
 #endif
 		/* bypass TX BCN queue if op ch is switching/waiting */
 		if (!check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
-			#ifdef CONFIG_DFS_MASTER
 			&& !IS_CH_WAITING(adapter_to_rfctl(padapter))
-			#endif
 		) {
 			/*update_beacon(padapter, _TIM_IE_, NULL, _FALSE);*/
 			/*issue_beacon(padapter, 0);*/
@@ -4385,7 +5133,7 @@ void rtw_ap_parse_sta_capability(_adapter *adapter, struct sta_info *sta, u8 *ca
 
 u16 rtw_ap_parse_sta_supported_rates(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len)
 {
-	u8 rate_set[16];
+	u8 rate_set[12];
 	u8 rate_num;
 	int i;
 	u16 status = _STATS_SUCCESSFUL_;
@@ -4425,6 +5173,7 @@ u16 rtw_ap_parse_sta_security_ie(_adapter *adapter, struct sta_info *sta, struct
 	u8 *wpa_ie;
 	int wpa_ie_len;
 	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
 	u16 status = _STATS_SUCCESSFUL_;
 
 	sta->dot8021xalg = 0;
@@ -4439,7 +5188,7 @@ u16 rtw_ap_parse_sta_security_ie(_adapter *adapter, struct sta_info *sta, struct
 		wpa_ie = elems->rsn_ie;
 		wpa_ie_len = elems->rsn_ie_len;
 
-		if (rtw_parse_wpa2_ie(wpa_ie - 2, wpa_ie_len + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+		if (rtw_parse_wpa2_ie(wpa_ie - 2, wpa_ie_len + 2, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
 			sta->dot8021xalg = 1;/* psk, todo:802.1x */
 			sta->wpa_psk |= BIT(1);
 
@@ -4479,6 +5228,18 @@ u16 rtw_ap_parse_sta_security_ie(_adapter *adapter, struct sta_info *sta, struct
 		wpa_ie_len = 0;
 	}
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		/* MFP is mandatory for secure mesh */
+		if (adapter->mesh_info.mesh_auth_id)
+			sta->flags |= WLAN_STA_MFP;
+	} else
+#endif
+	if ((sec->mfp_opt == MFP_REQUIRED && mfp_opt == MFP_NO) || mfp_opt == MFP_INVALID) 
+		status = WLAN_STATUS_ROBUST_MGMT_FRAME_POLICY_VIOLATION;
+	else if (sec->mfp_opt >= MFP_OPTIONAL && mfp_opt >= MFP_OPTIONAL)
+		sta->flags |= WLAN_STA_MFP;
+
 	if (status != _STATS_SUCCESSFUL_)
 		goto exit;
 
@@ -4569,6 +5330,13 @@ void rtw_ap_parse_sta_wmm_ie(_adapter *adapter, struct sta_info *sta, u8 *tlv_ie
 	if (!mlme->qospriv.qos_option)
 		goto exit;
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		/* QoS is mandatory in mesh */
+		sta->flags |= WLAN_STA_WME;
+	}
+#endif
+
 	p = rtw_get_ie_ex(tlv_ies, tlv_ies_len, WLAN_EID_VENDOR_SPECIFIC, WMM_IE, 6, NULL, NULL);
 	if (!p)
 		goto exit;
@@ -4625,6 +5393,11 @@ void rtw_ap_parse_sta_ht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_
 		sta->flags |= WLAN_STA_HT;
 		sta->flags |= WLAN_STA_WME;
 		_rtw_memcpy(&sta->htpriv.ht_cap, elems->ht_capabilities, sizeof(struct rtw_ieee80211_ht_cap));
+
+		if (elems->ht_operation && elems->ht_operation_len == HT_OP_IE_LEN) {
+			_rtw_memcpy(sta->htpriv.ht_op, elems->ht_operation, HT_OP_IE_LEN);
+			sta->htpriv.op_present = 1;
+		}
 	}
 exit:
 #endif
@@ -4643,14 +5416,19 @@ void rtw_ap_parse_sta_vht_ie(_adapter *adapter, struct sta_info *sta, struct rtw
 		goto exit;
 
 	_rtw_memset(&sta->vhtpriv, 0, sizeof(struct vht_priv));
-	if (elems->vht_capabilities && elems->vht_capabilities_len == 12) {
+	if (elems->vht_capabilities && elems->vht_capabilities_len == VHT_CAP_IE_LEN) {
 		sta->flags |= WLAN_STA_VHT;
-		_rtw_memcpy(sta->vhtpriv.vht_cap, elems->vht_capabilities, 12);
+		_rtw_memcpy(sta->vhtpriv.vht_cap, elems->vht_capabilities, VHT_CAP_IE_LEN);
+
+		if (elems->vht_operation && elems->vht_operation_len== VHT_OP_IE_LEN) {
+			_rtw_memcpy(sta->vhtpriv.vht_op, elems->vht_operation, VHT_OP_IE_LEN);
+			sta->vhtpriv.op_present = 1;
+		}
 
-		if (elems->vht_op_mode_notify && elems->vht_op_mode_notify_len == 1)
+		if (elems->vht_op_mode_notify && elems->vht_op_mode_notify_len == 1) {
 			_rtw_memcpy(&sta->vhtpriv.vht_op_mode_notify, elems->vht_op_mode_notify, 1);
-		else /* for Frame without Operating Mode notify ie; default: 80M */
-			sta->vhtpriv.vht_op_mode_notify = CHANNEL_WIDTH_80;
+			sta->vhtpriv.notify_present = 1;
+		}
 	}
 exit:
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_beamforming.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_beamforming.c
index 95c800555592..e6d79ae5265e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_beamforming.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_beamforming.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -1068,22 +1069,20 @@ static void _bfer_remove_entry(PADAPTER adapter, struct beamformer_entry *entry)
 
 static u8 _bfer_set_entry_gid(PADAPTER adapter, u8 *addr, u8 *gid, u8 *position)
 {
-	struct beamformer_entry *bfer = NULL;
-
+	struct beamformer_entry bfer;
 
-	bfer = _bfer_get_entry_by_addr(adapter, addr);
-	if (!bfer) {
-		RTW_INFO("%s: Cannot find BFer entry!!\n", __FUNCTION__);
-		return _FAIL;
-	}
+	memset(&bfer, 0, sizeof(bfer));
+	memcpy(bfer.mac_addr, addr, ETH_ALEN);
 
 	/* Parsing Membership Status Array */
-	_rtw_memcpy(bfer->gid_valid, gid, 8);
+	memcpy(bfer.gid_valid, gid, 8);
+
 	/* Parsing User Position Array */
-	_rtw_memcpy(bfer->user_position, position, 16);
+	memcpy(bfer.user_position, position, 16);
 
 	/* Config HW GID table */
-	rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_GID_TABLE, (u8*)&bfer, sizeof(struct beamformer_entry *), 1);
+	rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_GID_TABLE, (u8 *) &bfer,
+			sizeof(bfer), 1);
 
 	return _SUCCESS;
 }
@@ -1794,6 +1793,7 @@ void rtw_bf_init(PADAPTER adapter)
 	info->beamformee_mu_reg_maping = 0;
 	info->first_mu_bfee_index = 0xFF;
 	info->mu_bfer_curidx = 0xFF;
+	info->cur_csi_rpt_rate = HALMAC_OFDM24;
 
 	_sounding_init(&info->sounding_info);
 	rtw_init_timer(&info->sounding_timer, adapter, _sounding_timer_handler, adapter);
@@ -1832,7 +1832,7 @@ void rtw_bf_cmd_hdl(PADAPTER adapter, u8 type, u8 *pbuf)
 		break;
 
 	case BEAMFORMING_CTRL_SET_GID_TABLE:
-		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_SET_GID_TABLE, *(void**)pbuf);
+		rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_SET_GID_TABLE, pbuf);
 		break;
 
 	case BEAMFORMING_CTRL_SET_CSI_REPORT:
@@ -2917,7 +2917,7 @@ u32	rtw_beamforming_get_report_frame(PADAPTER	 Adapter, union recv_frame *precv_
 	u32	ret = _SUCCESS;
 #if (BEAMFORMING_SUPPORT == 1)
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 	ret = beamforming_get_report_frame(pDM_Odm, precv_frame);
 
@@ -2964,7 +2964,7 @@ void	rtw_beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_f
 {
 #if (BEAMFORMING_SUPPORT == 1)
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 	beamforming_get_ndpa_frame(pDM_Odm, precv_frame);
 
@@ -3040,7 +3040,7 @@ void	rtw_beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_f
 void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 #if (BEAMFORMING_SUPPORT == 1) /*(BEAMFORMING_SUPPORT == 1)- for PHYDM beamfoming*/
 	switch (type) {
@@ -3048,7 +3048,7 @@ void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf)
 		struct sta_info	*psta = (PVOID)pbuf;
 		u16			staIdx = psta->cmn.mac_id;
 
-		beamforming_enter(pDM_Odm, staIdx);
+		beamforming_enter(pDM_Odm, staIdx, adapter_mac_addr(psta->padapter));
 		break;
 	}
 	case BEAMFORMING_CTRL_LEAVE:
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_br_ext.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_br_ext.c
index 6509df3dd875..5e64a8f3edac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_br_ext.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_br_ext.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -301,7 +302,7 @@ static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char
 	return 0;
 }
 
-
+#ifdef SUPPORT_RX_UNI2MCAST
 static void convert_ipv6_mac_to_mc(struct sk_buff *skb)
 {
 	struct ipv6hdr *iph = (struct ipv6hdr *)(skb->data + ETH_HLEN);
@@ -319,6 +320,7 @@ static void convert_ipv6_mac_to_mc(struct sk_buff *skb)
 #endif
 }
 #endif /* CL_IPV6_PASS */
+#endif /* SUPPORT_RX_UNI2MCAST */
 
 
 static __inline__ int __nat25_network_hash(unsigned char *networkAddr)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_bt_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_bt_mp.c
index 9b4fc2432506..f198cbb2ce88 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_bt_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_bt_mp.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex.c
index d1d8355a94af..7a88a7d6ef01 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -437,7 +438,6 @@ u8 rtw_btcoex_LPS_Leave(PADAPTER padapter)
 
 	if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
 		rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "BTCOEX");
-		LPS_RF_ON_check(padapter, 100);
 		pwrpriv->bpower_saving = _FALSE;
 	}
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex_wifionly.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex_wifionly.c
index e26b3a0499b5..ed3cfc750240 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex_wifionly.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_btcoex_wifionly.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -26,6 +27,11 @@ void rtw_btcoex_wifionly_scan_notify(PADAPTER padapter)
 	hal_btcoex_wifionly_scan_notify(padapter);
 }
 
+void rtw_btcoex_wifionly_connect_notify(PADAPTER padapter)
+{
+	hal_btcoex_wifionly_connect_notify(padapter);
+}
+
 void rtw_btcoex_wifionly_hw_config(PADAPTER padapter)
 {
 	hal_btcoex_wifionly_hw_config(padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_chplan.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_chplan.c
new file mode 100644
index 000000000000..aae17888b77b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_chplan.c
@@ -0,0 +1,1194 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2018 Realtek Corporation.
+ *
+ * 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_CHPLAN_C_
+
+#include <drv_types.h>
+
+#define RTW_DOMAIN_MAP_VER	"37e"
+#define RTW_COUNTRY_MAP_VER	"21"
+
+#ifdef LEGACY_CHANNEL_PLAN_REF
+/********************************************************
+ChannelPlan definitions
+*********************************************************/
+static RT_CHANNEL_PLAN legacy_channel_plan[] = {
+	/* 0x00, RTW_CHPLAN_FCC */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 32},
+	/* 0x01, RTW_CHPLAN_IC */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 31},
+	/* 0x02, RTW_CHPLAN_ETSI */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 32},
+	/* 0x03, RTW_CHPLAN_SPAIN */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
+	/* 0x04, RTW_CHPLAN_FRANCE */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
+	/* 0x05, RTW_CHPLAN_MKK */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
+	/* 0x06, RTW_CHPLAN_MKK1 */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
+	/* 0x07, RTW_CHPLAN_ISRAEL */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64}, 21},
+	/* 0x08, RTW_CHPLAN_TELEC */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 36, 40, 44, 48, 52, 56, 60, 64}, 22},
+	/* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14}, 14},
+	/* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
+	/* 0x0B, RTW_CHPLAN_TAIWAN */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 26},
+	/* 0x0C, RTW_CHPLAN_CHINA */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 149, 153, 157, 161, 165}, 18},
+	/* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */	{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165}, 24},
+	/* 0x0E, RTW_CHPLAN_KOREA */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165}, 31},
+	/* 0x0F, RTW_CHPLAN_TURKEY */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64}, 19},
+	/* 0x10, RTW_CHPLAN_JAPAN */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 32},
+	/* 0x11, RTW_CHPLAN_FCC_NO_DFS */				{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 149, 153, 157, 161, 165}, 20},
+	/* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */				{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48}, 17},
+	/* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165}, 37},
+	/* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 56, 60, 64, 149, 153, 157, 161, 165}, 19},
+};
+#endif
+
+enum rtw_rd_2g {
+	RTW_RD_2G_NULL = 0,
+	RTW_RD_2G_WORLD = 1,	/* Worldwird 13 */
+	RTW_RD_2G_ETSI1 = 2,	/* Europe */
+	RTW_RD_2G_FCC1 = 3,		/* US */
+	RTW_RD_2G_MKK1 = 4,		/* Japan */
+	RTW_RD_2G_ETSI2 = 5,	/* France */
+	RTW_RD_2G_GLOBAL = 6,	/* Global domain */
+	RTW_RD_2G_MKK2 = 7,		/* Japan */
+	RTW_RD_2G_FCC2 = 8,		/* US */
+	RTW_RD_2G_IC1 = 9,		/* Canada */
+	RTW_RD_2G_WORLD1 = 10,	/* Worldwide 11 */
+	RTW_RD_2G_KCC1 = 11,	/* Korea */
+	RTW_RD_2G_IC2 = 12,		/* Canada */
+
+	RTW_RD_2G_MAX,
+};
+
+enum rtw_rd_5g {
+	RTW_RD_5G_NULL = 0,		/*	*/
+	RTW_RD_5G_ETSI1 = 1,	/* Europe */
+	RTW_RD_5G_ETSI2 = 2,	/* Australia, New Zealand */
+	RTW_RD_5G_ETSI3 = 3,	/* Russia */
+	RTW_RD_5G_FCC1 = 4,		/* US */
+	RTW_RD_5G_FCC2 = 5,		/* FCC w/o DFS Channels */
+	RTW_RD_5G_FCC3 = 6,		/* Bolivia, Chile, El Salvador, Venezuela */
+	RTW_RD_5G_FCC4 = 7,		/* Venezuela */
+	RTW_RD_5G_FCC5 = 8,		/* China */
+	RTW_RD_5G_FCC6 = 9,		/*	*/
+	RTW_RD_5G_FCC7 = 10,	/* US(w/o Weather radar) */
+	RTW_RD_5G_IC1 = 11,		/* Canada(w/o Weather radar) */
+	RTW_RD_5G_KCC1 = 12,	/* Korea */
+	RTW_RD_5G_MKK1 = 13,	/* Japan */
+	RTW_RD_5G_MKK2 = 14,	/* Japan (W52, W53) */
+	RTW_RD_5G_MKK3 = 15,	/* Japan (W56) */
+	RTW_RD_5G_NCC1 = 16,	/* Taiwan, (w/o Weather radar) */
+	RTW_RD_5G_NCC2 = 17,	/* Taiwan, Band2, Band4 */
+	RTW_RD_5G_NCC3 = 18,	/* Taiwan w/o DFS, Band4 only */
+	RTW_RD_5G_ETSI4 = 19,	/* Europe w/o DFS, Band1 only */
+	RTW_RD_5G_ETSI5 = 20,	/* Australia, New Zealand(w/o Weather radar) */
+	RTW_RD_5G_FCC8 = 21,	/* Latin America */
+	RTW_RD_5G_ETSI6 = 22,	/* Israel, Bahrain, Egypt, India, China, Malaysia */
+	RTW_RD_5G_ETSI7 = 23,	/* China */
+	RTW_RD_5G_ETSI8 = 24,	/* Jordan */
+	RTW_RD_5G_ETSI9 = 25,	/* Lebanon */
+	RTW_RD_5G_ETSI10 = 26,	/* Qatar */
+	RTW_RD_5G_ETSI11 = 27,	/* Russia */
+	RTW_RD_5G_NCC4 = 28,	/* Taiwan, (w/o Weather radar) */
+	RTW_RD_5G_ETSI12 = 29,	/* Indonesia */
+	RTW_RD_5G_FCC9 = 30,	/* (w/o Weather radar) */
+	RTW_RD_5G_ETSI13 = 31,	/* (w/o Weather radar) */
+	RTW_RD_5G_FCC10 = 32,	/* Argentina(w/o Weather radar) */
+	RTW_RD_5G_MKK4 = 33,	/* Japan (W52) */
+	RTW_RD_5G_ETSI14 = 34,	/* Russia */
+	RTW_RD_5G_FCC11 = 35,	/* US(include CH144) */
+	RTW_RD_5G_ETSI15 = 36,	/* Malaysia */
+	RTW_RD_5G_MKK5 = 37,	/* Japan */
+	RTW_RD_5G_ETSI16 = 38,	/* Europe */
+	RTW_RD_5G_ETSI17 = 39,	/* Europe */
+	RTW_RD_5G_FCC12 = 40,	/* FCC */
+	RTW_RD_5G_FCC13 = 41,	/* FCC */
+	RTW_RD_5G_FCC14 = 42,	/* FCC w/o Weather radar(w/o 5600~5650MHz) */
+	RTW_RD_5G_FCC15 = 43,	/* FCC w/o Band3 */
+	RTW_RD_5G_FCC16 = 44,	/* FCC w/o Band3 */
+	RTW_RD_5G_ETSI18 = 45,	/* ETSI w/o DFS Band2&3 */
+	RTW_RD_5G_ETSI19 = 46,	/* Europe */
+	RTW_RD_5G_FCC17 = 47,	/* FCC w/o Weather radar(w/o 5600~5650MHz) */
+	RTW_RD_5G_ETSI20 = 48,	/* Europe */
+	RTW_RD_5G_IC2 = 49,		/* Canada(w/o Weather radar), include ch144 */
+	RTW_RD_5G_ETSI21 = 50,	/* Australia, New Zealand(w/o Weather radar) */
+	RTW_RD_5G_FCC18 = 51,	/*  */
+	RTW_RD_5G_WORLD = 52,	/* Worldwide */
+	RTW_RD_5G_CHILE1 = 53,	/* Chile */
+	RTW_RD_5G_ACMA1 = 54,	/* Australia, New Zealand (w/o Weather radar) (w/o Ch120~Ch128) */
+	RTW_RD_5G_WORLD1 = 55,	/* 5G Worldwide Band1&2 */
+	RTW_RD_5G_CHILE2 = 56,	/* Chile (Band2,Band3) */
+	RTW_RD_5G_KCC2 = 57,	/* Korea (New standard) */
+
+	/* === Below are driver defined for legacy channel plan compatible, DON'T assign index ==== */
+	RTW_RD_5G_OLD_FCC1,
+	RTW_RD_5G_OLD_NCC1,
+	RTW_RD_5G_OLD_KCC1,
+
+	RTW_RD_5G_MAX,
+};
+
+struct ch_list_t {
+	u8 *len_ch;
+};
+
+#define CH_LIST_ENT(_len, arg...) \
+	{.len_ch = (u8[_len + 1]) {_len, ##arg}, }
+
+#define CH_LIST_LEN(_ch_list) (_ch_list.len_ch[0])
+#define CH_LIST_CH(_ch_list, _i) (_ch_list.len_ch[_i + 1])
+
+struct chplan_ent_t {
+	u8 rd_2g;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	u8 rd_5g;
+#endif
+	u8 regd; /* value of REGULATION_TXPWR_LMT */
+};
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+#define CHPLAN_ENT(i2g, i5g, regd) {i2g, i5g, regd}
+#else
+#define CHPLAN_ENT(i2g, i5g, regd) {i2g, regd}
+#endif
+
+static struct ch_list_t RTW_ChannelPlan2G[] = {
+	/* 0, RTW_RD_2G_NULL */		CH_LIST_ENT(0),
+	/* 1, RTW_RD_2G_WORLD */	CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 2, RTW_RD_2G_ETSI1 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 3, RTW_RD_2G_FCC1 */		CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
+	/* 4, RTW_RD_2G_MKK1 */		CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
+	/* 5, RTW_RD_2G_ETSI2 */		CH_LIST_ENT(4, 10, 11, 12, 13),
+	/* 6, RTW_RD_2G_GLOBAL */	CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
+	/* 7, RTW_RD_2G_MKK2 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 8, RTW_RD_2G_FCC2 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 9, RTW_RD_2G_IC1 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 10, RTW_RD_2G_WORLD1 */	CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
+	/* 11, RTW_RD_2G_KCC1 */	CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
+	/* 12, RTW_RD_2G_IC2 */		CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
+};
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+static struct ch_list_t RTW_ChannelPlan5G[] = {
+	/* 0, RTW_RD_5G_NULL */		CH_LIST_ENT(0),
+	/* 1, RTW_RD_5G_ETSI1 */		CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 2, RTW_RD_5G_ETSI2 */		CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 3, RTW_RD_5G_ETSI3 */		CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 149, 153, 157, 161, 165),
+	/* 4, RTW_RD_5G_FCC1 */		CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 5, RTW_RD_5G_FCC2 */		CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
+	/* 6, RTW_RD_5G_FCC3 */		CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 7, RTW_RD_5G_FCC4 */		CH_LIST_ENT(12, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161),
+	/* 8, RTW_RD_5G_FCC5 */		CH_LIST_ENT(5, 149, 153, 157, 161, 165),
+	/* 9, RTW_RD_5G_FCC6 */		CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 10, RTW_RD_5G_FCC7 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 11, RTW_RD_5G_IC1 */		CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 12, RTW_RD_5G_KCC1 */	CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161),
+	/* 13, RTW_RD_5G_MKK1 */	CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 14, RTW_RD_5G_MKK2 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 15, RTW_RD_5G_MKK3 */	CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 16, RTW_RD_5G_NCC1 */	CH_LIST_ENT(16, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 17, RTW_RD_5G_NCC2 */	CH_LIST_ENT(8, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 18, RTW_RD_5G_NCC3 */	CH_LIST_ENT(5, 149, 153, 157, 161, 165),
+	/* 19, RTW_RD_5G_ETSI4 */	CH_LIST_ENT(4, 36, 40, 44, 48),
+	/* 20, RTW_RD_5G_ETSI5 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 21, RTW_RD_5G_FCC8 */	CH_LIST_ENT(4, 149, 153, 157, 161),
+	/* 22, RTW_RD_5G_ETSI6 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 23, RTW_RD_5G_ETSI7 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 24, RTW_RD_5G_ETSI8 */	CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
+	/* 25, RTW_RD_5G_ETSI9 */	CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
+	/* 26, RTW_RD_5G_ETSI10 */	CH_LIST_ENT(5, 149, 153, 157, 161, 165),
+	/* 27, RTW_RD_5G_ETSI11 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 28, RTW_RD_5G_NCC4 */	CH_LIST_ENT(17, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 29, RTW_RD_5G_ETSI12 */	CH_LIST_ENT(4, 149, 153, 157, 161),
+	/* 30, RTW_RD_5G_FCC9 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 31, RTW_RD_5G_ETSI13 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
+	/* 32, RTW_RD_5G_FCC10 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161),
+	/* 33, RTW_RD_5G_MKK4 */	CH_LIST_ENT(4, 36, 40, 44, 48),
+	/* 34, RTW_RD_5G_ETSI14 */	CH_LIST_ENT(11, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140),
+	/* 35, RTW_RD_5G_FCC11 */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 36, RTW_RD_5G_ETSI15 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 149, 153, 157, 161, 165),
+	/* 37, RTW_RD_5G_MKK5 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 38, RTW_RD_5G_ETSI16 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 39, RTW_RD_5G_ETSI17 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 40, RTW_RD_5G_FCC12*/	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 41, RTW_RD_5G_FCC13 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 42, RTW_RD_5G_FCC14 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 43, RTW_RD_5G_FCC15 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 44, RTW_RD_5G_FCC16 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 45, RTW_RD_5G_ETSI18 */	CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
+	/* 46, RTW_RD_5G_ETSI19 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 47, RTW_RD_5G_FCC17 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
+	/* 48, RTW_RD_5G_ETSI20 */	CH_LIST_ENT(9, 52, 56, 60, 64, 149, 153, 157, 161, 165),
+	/* 49, RTW_RD_5G_IC2 */		CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 50, RTW_RD_5G_ETSI21 */	CH_LIST_ENT(13, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 51, RTW_RD_5G_FCC18 */	CH_LIST_ENT(8, 100, 104, 108, 112, 116, 132, 136, 140),
+	/* 52, RTW_RD_5G_WORLD */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 53, RTW_RD_5G_CHILE1 */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
+	/* 54, RTW_RD_5G_ACMA1 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
+	/* 55, RTW_RD_5G_WORLD1 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
+	/* 56, RTW_RD_5G_CHILE2 */	CH_LIST_ENT(16, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144),
+	/* 57, RTW_RD_5G_KCC2 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
+
+	/* === Below are driver defined for legacy channel plan compatible, NO static index assigned ==== */
+	/* RTW_RD_5G_OLD_FCC1 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
+	/* RTW_RD_5G_OLD_NCC1 */	CH_LIST_ENT(15, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
+	/* RTW_RD_5G_OLD_KCC1 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165),
+};
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
+
+static struct chplan_ent_t RTW_ChannelPlanMap[RTW_CHPLAN_MAX] = {
+	/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_KCC1,		TXPWR_LMT_FCC),		/* 0x00, RTW_CHPLAN_FCC */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_FCC1,	TXPWR_LMT_FCC),		/* 0x01, RTW_CHPLAN_IC */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x02, RTW_CHPLAN_ETSI */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x03, RTW_CHPLAN_SPAIN */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x04, RTW_CHPLAN_FRANCE */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x05, RTW_CHPLAN_MKK */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x06, RTW_CHPLAN_MKK1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI),	/* 0x07, RTW_CHPLAN_ISRAEL */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_FCC6,		TXPWR_LMT_MKK),		/* 0x08, RTW_CHPLAN_TELEC */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_NCC1,	TXPWR_LMT_FCC),		/* 0x0B, RTW_CHPLAN_TAIWAN */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI),	/* 0x0C, RTW_CHPLAN_CHINA */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC3,		TXPWR_LMT_WW),		/* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */ /* ETSI:Singapore, India. FCC:Mexico => WW */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_KCC1,	TXPWR_LMT_ETSI),	/* 0x0E, RTW_CHPLAN_KOREA */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI),	/* 0x0F, RTW_CHPLAN_TURKEY */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_MKK),		/* 0x10, RTW_CHPLAN_JAPAN */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x11, RTW_CHPLAN_FCC_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC7,		TXPWR_LMT_MKK),		/* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC1,		TXPWR_LMT_WW),		/* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC2,		TXPWR_LMT_FCC),		/* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC7,		TXPWR_LMT_ETSI),	/* 0x15, RTW_CHPLAN_ETSI_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NCC1,		TXPWR_LMT_ETSI),	/* 0x16, RTW_CHPLAN_KOREA_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_FCC7,		TXPWR_LMT_MKK),		/* 0x17, RTW_CHPLAN_JAPAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI),	/* 0x18, RTW_CHPLAN_PAKISTAN_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x19, RTW_CHPLAN_TAIWAN2_NO_DFS */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1A, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1B, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1C, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1D, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1E, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_FCC1,		TXPWR_LMT_WW),		/* 0x1F, RTW_CHPLAN_WORLD_WIDE_ONLY_5G */
+
+	/* ===== 0x20 ~ 0x7F, new channel plan ===== */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x20, RTW_CHPLAN_WORLD_NULL */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x21, RTW_CHPLAN_ETSI1_NULL */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NULL,		TXPWR_LMT_FCC),		/* 0x22, RTW_CHPLAN_FCC1_NULL */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x23, RTW_CHPLAN_MKK1_NULL */
+	CHPLAN_ENT(RTW_RD_2G_ETSI2,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x24, RTW_CHPLAN_ETSI2_NULL */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC),		/* 0x25, RTW_CHPLAN_FCC1_FCC1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x26, RTW_CHPLAN_WORLD_ETSI1 */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK1,		TXPWR_LMT_MKK),		/* 0x27, RTW_CHPLAN_MKK1_MKK1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_KCC1,		TXPWR_LMT_KCC),		/* 0x28, RTW_CHPLAN_WORLD_KCC1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x29, RTW_CHPLAN_WORLD_FCC2 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_NULL,		TXPWR_LMT_FCC),		/* 0x2A, RTW_CHPLAN_FCC2_NULL */
+	CHPLAN_ENT(RTW_RD_2G_IC1,		RTW_RD_5G_IC2,		TXPWR_LMT_IC),		/* 0x2B, RTW_CHPLAN_IC1_IC2 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x2C, RTW_CHPLAN_MKK2_NULL */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_CHILE1,	TXPWR_LMT_CHILE),	/* 0x2D, RTW_CHPLAN_WORLD_CHILE1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD1,	RTW_RD_5G_WORLD1,	TXPWR_LMT_WW),		/* 0x2E, RTW_CHPLAN_WORLD1_WORLD1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_CHILE2,	TXPWR_LMT_CHILE),	/* 0x2F, RTW_CHPLAN_WORLD_CHILE2 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC3,		TXPWR_LMT_FCC),		/* 0x30, RTW_CHPLAN_WORLD_FCC3 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC4,		TXPWR_LMT_FCC),		/* 0x31, RTW_CHPLAN_WORLD_FCC4 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x32, RTW_CHPLAN_WORLD_FCC5 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC6,		TXPWR_LMT_FCC),		/* 0x33, RTW_CHPLAN_WORLD_FCC6 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x34, RTW_CHPLAN_FCC1_FCC7 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI2,	TXPWR_LMT_ETSI),	/* 0x35, RTW_CHPLAN_WORLD_ETSI2 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI3,	TXPWR_LMT_ETSI),	/* 0x36, RTW_CHPLAN_WORLD_ETSI3 */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK2,		TXPWR_LMT_MKK),		/* 0x37, RTW_CHPLAN_MKK1_MKK2 */
+	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK3,		TXPWR_LMT_MKK),		/* 0x38, RTW_CHPLAN_MKK1_MKK3 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC1,		TXPWR_LMT_FCC),		/* 0x39, RTW_CHPLAN_FCC1_NCC1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x3A, RTW_CHPLAN_ETSI1_ETSI1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ACMA1,	TXPWR_LMT_ACMA),	/* 0x3B, RTW_CHPLAN_ETSI1_ACMA1 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI6,	TXPWR_LMT_ETSI),	/* 0x3C, RTW_CHPLAN_ETSI1_ETSI6 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI12,	TXPWR_LMT_ETSI),	/* 0x3D, RTW_CHPLAN_ETSI1_ETSI12 */
+	CHPLAN_ENT(RTW_RD_2G_KCC1,		RTW_RD_5G_KCC2,		TXPWR_LMT_KCC),		/* 0x3E, RTW_CHPLAN_KCC1_KCC2 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC11,	TXPWR_LMT_FCC),		/* 0x3F, RTW_CHPLAN_FCC1_FCC11*/
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC2,		TXPWR_LMT_FCC),		/* 0x40, RTW_CHPLAN_FCC1_NCC2 */
+	CHPLAN_ENT(RTW_RD_2G_GLOBAL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x41, RTW_CHPLAN_GLOBAL_NULL */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI4,	TXPWR_LMT_ETSI),	/* 0x42, RTW_CHPLAN_ETSI1_ETSI4 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x43, RTW_CHPLAN_FCC1_FCC2 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC3,		TXPWR_LMT_FCC),		/* 0x44, RTW_CHPLAN_FCC1_NCC3 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ACMA1,	TXPWR_LMT_ACMA),	/* 0x45, RTW_CHPLAN_WORLD_ACMA1 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC8,		TXPWR_LMT_FCC),		/* 0x46, RTW_CHPLAN_FCC1_FCC8 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI6,	TXPWR_LMT_ETSI),	/* 0x47, RTW_CHPLAN_WORLD_ETSI6 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI7,	TXPWR_LMT_ETSI),	/* 0x48, RTW_CHPLAN_WORLD_ETSI7 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI8,	TXPWR_LMT_ETSI),	/* 0x49, RTW_CHPLAN_WORLD_ETSI8 */
+	CHPLAN_ENT(RTW_RD_2G_IC2,		RTW_RD_5G_IC2,		TXPWR_LMT_IC),		/* 0x4A, RTW_CHPLAN_IC2_IC2 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4B, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4C, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4D, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4E, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4F, */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI9,	TXPWR_LMT_ETSI),	/* 0x50, RTW_CHPLAN_WORLD_ETSI9 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI10,	TXPWR_LMT_ETSI),	/* 0x51, RTW_CHPLAN_WORLD_ETSI10 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI11,	TXPWR_LMT_ETSI),	/* 0x52, RTW_CHPLAN_WORLD_ETSI11 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC4,		TXPWR_LMT_FCC),		/* 0x53, RTW_CHPLAN_FCC1_NCC4 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI12,	TXPWR_LMT_ETSI),	/* 0x54, RTW_CHPLAN_WORLD_ETSI12 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC9,		TXPWR_LMT_FCC),		/* 0x55, RTW_CHPLAN_FCC1_FCC9 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI13,	TXPWR_LMT_ETSI),	/* 0x56, RTW_CHPLAN_WORLD_ETSI13 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC10,	TXPWR_LMT_FCC),		/* 0x57, RTW_CHPLAN_FCC1_FCC10 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK4,		TXPWR_LMT_MKK),		/* 0x58, RTW_CHPLAN_MKK2_MKK4 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI14,	TXPWR_LMT_ETSI),	/* 0x59, RTW_CHPLAN_WORLD_ETSI14 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5A, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5B, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5C, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5D, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5E, */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5F, */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x60, RTW_CHPLAN_FCC1_FCC5 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x61, RTW_CHPLAN_FCC2_FCC7 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC),		/* 0x62, RTW_CHPLAN_FCC2_FCC1 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI15,	TXPWR_LMT_ETSI),	/* 0x63, RTW_CHPLAN_WORLD_ETSI15 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK5,		TXPWR_LMT_MKK),		/* 0x64, RTW_CHPLAN_MKK2_MKK5 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI16,	TXPWR_LMT_ETSI),	/* 0x65, RTW_CHPLAN_ETSI1_ETSI16 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC14,	TXPWR_LMT_FCC),		/* 0x66, RTW_CHPLAN_FCC1_FCC14 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x67, RTW_CHPLAN_FCC1_FCC12 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC14,	TXPWR_LMT_FCC),		/* 0x68, RTW_CHPLAN_FCC2_FCC14 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x69, RTW_CHPLAN_FCC2_FCC12 */
+	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI17,	TXPWR_LMT_ETSI),	/* 0x6A, RTW_CHPLAN_ETSI1_ETSI17 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC16,	TXPWR_LMT_FCC),		/* 0x6B, RTW_CHPLAN_WORLD_FCC16 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC13,	TXPWR_LMT_FCC),		/* 0x6C, RTW_CHPLAN_WORLD_FCC13 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC15,	TXPWR_LMT_FCC),		/* 0x6D, RTW_CHPLAN_FCC2_FCC15 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x6E, RTW_CHPLAN_WORLD_FCC12 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI8,	TXPWR_LMT_ETSI),	/* 0x6F, RTW_CHPLAN_NULL_ETSI8 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI18,	TXPWR_LMT_ETSI),	/* 0x70, RTW_CHPLAN_NULL_ETSI18 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI17,	TXPWR_LMT_ETSI),	/* 0x71, RTW_CHPLAN_NULL_ETSI17 */
+	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI19,	TXPWR_LMT_ETSI),	/* 0x72, RTW_CHPLAN_NULL_ETSI19 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x73, RTW_CHPLAN_WORLD_FCC7 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC17,	TXPWR_LMT_FCC),		/* 0x74, RTW_CHPLAN_FCC2_FCC17 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI20,	TXPWR_LMT_ETSI),	/* 0x75, RTW_CHPLAN_WORLD_ETSI20 */
+	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC11,	TXPWR_LMT_FCC),		/* 0x76, RTW_CHPLAN_FCC2_FCC11 */
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI21,	TXPWR_LMT_ETSI),	/* 0x77, RTW_CHPLAN_WORLD_ETSI21 */
+	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC18,	TXPWR_LMT_FCC),		/* 0x78, RTW_CHPLAN_FCC1_FCC18 */
+	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK1,		TXPWR_LMT_MKK),		/* 0x79, RTW_CHPLAN_MKK2_MKK1 */
+};
+
+static struct chplan_ent_t RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE =
+	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC);		/* 0x7F, Realtek Define */
+
+u8 rtw_chplan_get_default_regd(u8 id)
+{
+	u8 regd;
+
+	if (id == RTW_CHPLAN_REALTEK_DEFINE)
+		regd = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.regd;
+	else
+		regd = RTW_ChannelPlanMap[id].regd;
+
+	return regd;
+}
+
+bool rtw_chplan_is_empty(u8 id)
+{
+	struct chplan_ent_t *chplan_map;
+
+	if (id == RTW_CHPLAN_REALTEK_DEFINE)
+		chplan_map = &RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE;
+	else
+		chplan_map = &RTW_ChannelPlanMap[id];
+
+	if (chplan_map->rd_2g == RTW_RD_2G_NULL
+		#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		&& chplan_map->rd_5g == RTW_RD_5G_NULL
+		#endif
+	)
+		return _TRUE;
+
+	return _FALSE;
+}
+
+bool rtw_regsty_is_excl_chs(struct registry_priv *regsty, u8 ch)
+{
+	int i;
+
+	for (i = 0; i < MAX_CHANNEL_NUM; i++) {
+		if (regsty->excl_chs[i] == 0)
+			break;
+		if (regsty->excl_chs[i] == ch)
+			return _TRUE;
+	}
+	return _FALSE;
+}
+
+inline static u8 rtw_rd_5g_band1_passive(u8 rtw_rd_5g)
+{
+	u8 passive = 0;
+
+	switch (rtw_rd_5g) {
+	case RTW_RD_5G_FCC13:
+	case RTW_RD_5G_FCC16:
+	case RTW_RD_5G_ETSI18:
+	case RTW_RD_5G_ETSI19:
+	case RTW_RD_5G_WORLD:
+	case RTW_RD_5G_WORLD1:
+		passive = 1;
+	};
+
+	return passive;
+}
+
+inline static u8 rtw_rd_5g_band4_passive(u8 rtw_rd_5g)
+{
+	u8 passive = 0;
+
+	switch (rtw_rd_5g) {
+	case RTW_RD_5G_MKK5:
+	case RTW_RD_5G_ETSI16:
+	case RTW_RD_5G_ETSI18:
+	case RTW_RD_5G_ETSI19:
+	case RTW_RD_5G_WORLD:
+		passive = 1;
+	};
+
+	return passive;
+}
+
+u8 init_channel_set(_adapter *padapter, u8 ChannelPlan, RT_CHANNEL_INFO *channel_set)
+{
+	struct registry_priv *regsty = adapter_to_regsty(padapter);
+	u8	index, chanset_size = 0;
+	u8	b5GBand = _FALSE, b2_4GBand = _FALSE;
+	u8	rd_2g = 0, rd_5g = 0;
+#ifdef CONFIG_DFS_MASTER
+	int i;
+#endif
+
+	if (!rtw_is_channel_plan_valid(ChannelPlan)) {
+		RTW_ERR("ChannelPlan ID 0x%02X error !!!!!\n", ChannelPlan);
+		return chanset_size;
+	}
+
+	_rtw_memset(channel_set, 0, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
+
+	if (IsSupported24G(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_2G))
+		b2_4GBand = _TRUE;
+
+	if (is_supported_5g(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_5G))
+		b5GBand = _TRUE;
+
+	if (b2_4GBand == _FALSE && b5GBand == _FALSE) {
+		RTW_WARN("HW band_cap has no intersection with SW wireless_mode setting\n");
+		return chanset_size;
+	}
+
+	if (b2_4GBand) {
+		if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
+			rd_2g = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.rd_2g;
+		else
+			rd_2g = RTW_ChannelPlanMap[ChannelPlan].rd_2g;
+
+		for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan2G[rd_2g]); index++) {
+			if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan2G[rd_2g], index)) == _TRUE)
+				continue;
+
+			if (chanset_size >= MAX_CHANNEL_NUM) {
+				RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
+				break;
+			}
+
+			channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan2G[rd_2g], index);
+
+			if (ChannelPlan == RTW_CHPLAN_GLOBAL_DOAMIN
+				|| rd_2g == RTW_RD_2G_GLOBAL
+			) {
+				/* Channel 1~11 is active, and 12~14 is passive */
+				if (channel_set[chanset_size].ChannelNum >= 1 && channel_set[chanset_size].ChannelNum <= 11)
+					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+				else if ((channel_set[chanset_size].ChannelNum  >= 12 && channel_set[chanset_size].ChannelNum  <= 14))
+					channel_set[chanset_size].ScanType  = SCAN_PASSIVE;
+			} else if (ChannelPlan == RTW_CHPLAN_WORLD_WIDE_13
+				|| ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G
+				|| rd_2g == RTW_RD_2G_WORLD
+			) {
+				/* channel 12~13, passive scan */
+				if (channel_set[chanset_size].ChannelNum <= 11)
+					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+				else
+					channel_set[chanset_size].ScanType = SCAN_PASSIVE;
+			} else
+				channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+
+			chanset_size++;
+		}
+	}
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (b5GBand) {
+		if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
+			rd_5g = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.rd_5g;
+		else
+			rd_5g = RTW_ChannelPlanMap[ChannelPlan].rd_5g;
+
+		for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan5G[rd_5g]); index++) {
+			if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan5G[rd_5g], index)) == _TRUE)
+				continue;
+			#ifndef CONFIG_DFS
+			if (rtw_is_dfs_ch(CH_LIST_CH(RTW_ChannelPlan5G[rd_5g], index)))
+				continue;
+			#endif
+
+			if (chanset_size >= MAX_CHANNEL_NUM) {
+				RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
+				break;
+			}
+
+			channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan5G[rd_5g], index);
+
+			if ((ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G) /* all channels passive */
+				|| (rtw_is_5g_band1(channel_set[chanset_size].ChannelNum)
+					&& rtw_rd_5g_band1_passive(rd_5g)) /* band1 passive */
+				|| (rtw_is_5g_band4(channel_set[chanset_size].ChannelNum)
+					&& rtw_rd_5g_band4_passive(rd_5g)) /* band4 passive */
+				|| (rtw_is_dfs_ch(channel_set[chanset_size].ChannelNum)) /* DFS channel(band2, 3) passive */
+			)
+				channel_set[chanset_size].ScanType = SCAN_PASSIVE;
+			else
+				channel_set[chanset_size].ScanType = SCAN_ACTIVE;
+
+			chanset_size++;
+		}
+	}
+
+	#ifdef CONFIG_DFS_MASTER
+	for (i = 0; i < chanset_size; i++)
+		channel_set[i].non_ocp_end_time = rtw_get_current_time();
+	#endif
+#endif /* CONFIG_IEEE80211_BAND_5GHZ */
+
+	if (chanset_size)
+		RTW_INFO(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, ch num:%d\n"
+			, FUNC_ADPT_ARG(padapter), ChannelPlan, chanset_size);
+	else
+		RTW_WARN(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, final chset has no channel\n"
+			, FUNC_ADPT_ARG(padapter), ChannelPlan);
+
+	return chanset_size;
+}
+
+#ifdef CONFIG_80211AC_VHT
+#define COUNTRY_CHPLAN_ASSIGN_EN_11AC(_val) , .en_11ac = (_val)
+#else
+#define COUNTRY_CHPLAN_ASSIGN_EN_11AC(_val)
+#endif
+
+#if RTW_DEF_MODULE_REGULATORY_CERT
+#define COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_val) , .def_module_flags = (_val)
+#else
+#define COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_val)
+#endif
+
+/* has def_module_flags specified, used by common map and HAL dfference map */
+#define COUNTRY_CHPLAN_ENT(_alpha2, _chplan, _en_11ac, _def_module_flags) \
+	{.alpha2 = (_alpha2), .chplan = (_chplan) \
+		COUNTRY_CHPLAN_ASSIGN_EN_11AC(_en_11ac) \
+		COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_def_module_flags) \
+	}
+
+#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
+
+#include "../platform/custom_country_chplan.h"
+
+#elif RTW_DEF_MODULE_REGULATORY_CERT
+
+/* leave def_module_flags empty, def_module_flags check is done on country_chplan_map */
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AE_HMC_M2) /* 2013 certify */
+static const struct country_chplan RTL8821AE_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CL", 0x30, 1, 0), /* Chile */
+	COUNTRY_CHPLAN_ENT("CN", 0x51, 1, 0), /* China */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("MY", 0x47, 1, 0), /* Malaysia */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AU) /* 2014 certify */
+static const struct country_chplan RTL8821AU_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0), /* Russia(fac/gost), Kaliningrad */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AENF_NGFF) /* 2014 certify */
+static const struct country_chplan RTL8812AENF_NGFF_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AEBT_HMC) /* 2013 certify */
+static const struct country_chplan RTL8812AEBT_HMC_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0), /* Russia(fac/gost), Kaliningrad */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8188EE_HMC_M2) /* 2012 certify */
+static const struct country_chplan RTL8188EE_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0), /* Barbados */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0), /* Haiti */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0), /* Seychelles */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+	COUNTRY_CHPLAN_ENT("VC", 0x34, 1, 0), /* Saint Vincent and the Grenadines */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BE_HMC_M2) /* 2013 certify */
+static const struct country_chplan RTL8723BE_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("BS", 0x34, 1, 0), /* Bahamas */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BS_NGFF1216) /* 2014 certify */
+static const struct country_chplan RTL8723BS_NGFF1216_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0), /* Barbados */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0), /* Haiti */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8192EEBT_HMC_M2) /* 2013 certify */
+static const struct country_chplan RTL8192EEBT_HMC_M2_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
+	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0), /* Seychelles */
+	COUNTRY_CHPLAN_ENT("ST", 0x34, 1, 0), /* Sao Tome and Principe */
+	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723DE_NGFF1630) /* 2016 certify */
+static const struct country_chplan RTL8723DE_NGFF1630_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("CA", 0x2A, 1, 0), /* Canada */
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8822BE) /* 2016 certify */
+static const struct country_chplan RTL8822BE_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+};
+#endif
+
+#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821CE) /* 2016 certify */
+static const struct country_chplan RTL8821CE_country_chplan_exc_map[] = {
+	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
+};
+#endif
+
+/**
+ * rtw_def_module_get_chplan_from_country -
+ * @country_code: string of country code
+ * @return:
+ * Return NULL for case referring to common map
+ */
+static const struct country_chplan *rtw_def_module_get_chplan_from_country(const char *country_code)
+{
+	const struct country_chplan *ent = NULL;
+	const struct country_chplan *hal_map = NULL;
+	u16 hal_map_sz = 0;
+	int i;
+
+	/* TODO: runtime selection for multi driver */
+#if (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AE_HMC_M2)
+	hal_map = RTL8821AE_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8821AE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AU)
+	hal_map = RTL8821AU_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8821AU_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AENF_NGFF)
+	hal_map = RTL8812AENF_NGFF_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8812AENF_NGFF_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AEBT_HMC)
+	hal_map = RTL8812AEBT_HMC_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8812AEBT_HMC_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8188EE_HMC_M2)
+	hal_map = RTL8188EE_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8188EE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BE_HMC_M2)
+	hal_map = RTL8723BE_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8723BE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BS_NGFF1216)
+	hal_map = RTL8723BS_NGFF1216_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8723BS_NGFF1216_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8192EEBT_HMC_M2)
+	hal_map = RTL8192EEBT_HMC_M2_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8192EEBT_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723DE_NGFF1630)
+	hal_map = RTL8723DE_NGFF1630_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8723DE_NGFF1630_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8822BE)
+	hal_map = RTL8822BE_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8822BE_country_chplan_exc_map) / sizeof(struct country_chplan);
+#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821CE)
+	hal_map = RTL8821CE_country_chplan_exc_map;
+	hal_map_sz = sizeof(RTL8821CE_country_chplan_exc_map) / sizeof(struct country_chplan);
+#endif
+
+	if (hal_map == NULL || hal_map_sz == 0)
+		goto exit;
+
+	for (i = 0; i < hal_map_sz; i++) {
+		if (strncmp(country_code, hal_map[i].alpha2, 2) == 0) {
+			ent = &hal_map[i];
+			break;
+		}
+	}
+
+exit:
+	return ent;
+}
+#endif /* CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP or RTW_DEF_MODULE_REGULATORY_CERT */
+
+static const struct country_chplan country_chplan_map[] = {
+	COUNTRY_CHPLAN_ENT("AD", 0x26, 1, 0x000), /* Andorra */
+	COUNTRY_CHPLAN_ENT("AE", 0x35, 1, 0x7FB), /* United Arab Emirates */
+	COUNTRY_CHPLAN_ENT("AF", 0x42, 1, 0x000), /* Afghanistan */
+	COUNTRY_CHPLAN_ENT("AG", 0x76, 1, 0x000), /* Antigua & Barbuda */
+	COUNTRY_CHPLAN_ENT("AI", 0x26, 1, 0x000), /* Anguilla(UK) */
+	COUNTRY_CHPLAN_ENT("AL", 0x26, 1, 0x7F1), /* Albania */
+	COUNTRY_CHPLAN_ENT("AM", 0x26, 1, 0x6B0), /* Armenia */
+	COUNTRY_CHPLAN_ENT("AN", 0x76, 1, 0x7F1), /* Netherlands Antilles */
+	COUNTRY_CHPLAN_ENT("AO", 0x47, 1, 0x6E0), /* Angola */
+	COUNTRY_CHPLAN_ENT("AQ", 0x26, 1, 0x000), /* Antarctica */
+	COUNTRY_CHPLAN_ENT("AR", 0x61, 1, 0x7F3), /* Argentina */
+	COUNTRY_CHPLAN_ENT("AS", 0x76, 1, 0x000), /* American Samoa */
+	COUNTRY_CHPLAN_ENT("AT", 0x26, 1, 0x7FB), /* Austria */
+	COUNTRY_CHPLAN_ENT("AU", 0x45, 1, 0x7FB), /* Australia */
+	COUNTRY_CHPLAN_ENT("AW", 0x76, 1, 0x0B0), /* Aruba */
+	COUNTRY_CHPLAN_ENT("AZ", 0x26, 1, 0x7F1), /* Azerbaijan */
+	COUNTRY_CHPLAN_ENT("BA", 0x26, 1, 0x7F1), /* Bosnia & Herzegovina */
+	COUNTRY_CHPLAN_ENT("BB", 0x76, 1, 0x650), /* Barbados */
+	COUNTRY_CHPLAN_ENT("BD", 0x26, 1, 0x7F1), /* Bangladesh */
+	COUNTRY_CHPLAN_ENT("BE", 0x26, 1, 0x7FB), /* Belgium */
+	COUNTRY_CHPLAN_ENT("BF", 0x26, 1, 0x6B0), /* Burkina Faso */
+	COUNTRY_CHPLAN_ENT("BG", 0x26, 1, 0x7F1), /* Bulgaria */
+	COUNTRY_CHPLAN_ENT("BH", 0x48, 1, 0x7F1), /* Bahrain */
+	COUNTRY_CHPLAN_ENT("BI", 0x26, 1, 0x6B0), /* Burundi */
+	COUNTRY_CHPLAN_ENT("BJ", 0x26, 1, 0x6B0), /* Benin */
+	COUNTRY_CHPLAN_ENT("BM", 0x76, 1, 0x600), /* Bermuda (UK) */
+	COUNTRY_CHPLAN_ENT("BN", 0x47, 1, 0x610), /* Brunei */
+	COUNTRY_CHPLAN_ENT("BO", 0x73, 1, 0x7F1), /* Bolivia */
+	COUNTRY_CHPLAN_ENT("BR", 0x62, 1, 0x7F1), /* Brazil */
+	COUNTRY_CHPLAN_ENT("BS", 0x76, 1, 0x620), /* Bahamas */
+	COUNTRY_CHPLAN_ENT("BT", 0x26, 1, 0x000), /* Bhutan */
+	COUNTRY_CHPLAN_ENT("BV", 0x26, 1, 0x000), /* Bouvet Island (Norway) */
+	COUNTRY_CHPLAN_ENT("BW", 0x35, 1, 0x6F1), /* Botswana */
+	COUNTRY_CHPLAN_ENT("BY", 0x26, 1, 0x7F1), /* Belarus */
+	COUNTRY_CHPLAN_ENT("BZ", 0x76, 1, 0x000), /* Belize */
+	COUNTRY_CHPLAN_ENT("CA", 0x2B, 1, 0x7FB), /* Canada */
+	COUNTRY_CHPLAN_ENT("CC", 0x26, 1, 0x000), /* Cocos (Keeling) Islands (Australia) */
+	COUNTRY_CHPLAN_ENT("CD", 0x26, 1, 0x6B0), /* Congo, Republic of the */
+	COUNTRY_CHPLAN_ENT("CF", 0x26, 1, 0x6B0), /* Central African Republic */
+	COUNTRY_CHPLAN_ENT("CG", 0x26, 1, 0x6B0), /* Congo, Democratic Republic of the. Zaire */
+	COUNTRY_CHPLAN_ENT("CH", 0x26, 1, 0x7FB), /* Switzerland */
+	COUNTRY_CHPLAN_ENT("CI", 0x26, 1, 0x7F1), /* Cote d'Ivoire */
+	COUNTRY_CHPLAN_ENT("CK", 0x26, 1, 0x000), /* Cook Islands */
+	COUNTRY_CHPLAN_ENT("CL", 0x2D, 1, 0x7F1), /* Chile */
+	COUNTRY_CHPLAN_ENT("CM", 0x26, 1, 0x6B0), /* Cameroon */
+	COUNTRY_CHPLAN_ENT("CN", 0x48, 1, 0x7FB), /* China */
+	COUNTRY_CHPLAN_ENT("CO", 0x76, 1, 0x7F1), /* Colombia */
+	COUNTRY_CHPLAN_ENT("CR", 0x76, 1, 0x7F1), /* Costa Rica */
+	COUNTRY_CHPLAN_ENT("CV", 0x26, 1, 0x6B0), /* Cape Verde */
+	COUNTRY_CHPLAN_ENT("CX", 0x45, 1, 0x000), /* Christmas Island (Australia) */
+	COUNTRY_CHPLAN_ENT("CY", 0x26, 1, 0x7FB), /* Cyprus */
+	COUNTRY_CHPLAN_ENT("CZ", 0x26, 1, 0x7FB), /* Czech Republic */
+	COUNTRY_CHPLAN_ENT("DE", 0x26, 1, 0x7FB), /* Germany */
+	COUNTRY_CHPLAN_ENT("DJ", 0x26, 1, 0x680), /* Djibouti */
+	COUNTRY_CHPLAN_ENT("DK", 0x26, 1, 0x7FB), /* Denmark */
+	COUNTRY_CHPLAN_ENT("DM", 0x76, 1, 0x000), /* Dominica */
+	COUNTRY_CHPLAN_ENT("DO", 0x76, 1, 0x7F1), /* Dominican Republic */
+	COUNTRY_CHPLAN_ENT("DZ", 0x26, 1, 0x7F1), /* Algeria */
+	COUNTRY_CHPLAN_ENT("EC", 0x76, 1, 0x7F1), /* Ecuador */
+	COUNTRY_CHPLAN_ENT("EE", 0x26, 1, 0x7FB), /* Estonia */
+	COUNTRY_CHPLAN_ENT("EG", 0x47, 1, 0x7F1), /* Egypt */
+	COUNTRY_CHPLAN_ENT("EH", 0x47, 1, 0x680), /* Western Sahara */
+	COUNTRY_CHPLAN_ENT("ER", 0x26, 1, 0x000), /* Eritrea */
+	COUNTRY_CHPLAN_ENT("ES", 0x26, 1, 0x7FB), /* Spain, Canary Islands, Ceuta, Melilla */
+	COUNTRY_CHPLAN_ENT("ET", 0x26, 1, 0x4B0), /* Ethiopia */
+	COUNTRY_CHPLAN_ENT("FI", 0x26, 1, 0x7FB), /* Finland */
+	COUNTRY_CHPLAN_ENT("FJ", 0x76, 1, 0x600), /* Fiji */
+	COUNTRY_CHPLAN_ENT("FK", 0x26, 1, 0x000), /* Falkland Islands (Islas Malvinas) (UK) */
+	COUNTRY_CHPLAN_ENT("FM", 0x76, 1, 0x000), /* Micronesia, Federated States of (USA) */
+	COUNTRY_CHPLAN_ENT("FO", 0x26, 1, 0x000), /* Faroe Islands (Denmark) */
+	COUNTRY_CHPLAN_ENT("FR", 0x26, 1, 0x7FB), /* France */
+	COUNTRY_CHPLAN_ENT("GA", 0x26, 1, 0x6B0), /* Gabon */
+	COUNTRY_CHPLAN_ENT("GB", 0x26, 1, 0x7FB), /* Great Britain (United Kingdom; England) */
+	COUNTRY_CHPLAN_ENT("GD", 0x76, 1, 0x0B0), /* Grenada */
+	COUNTRY_CHPLAN_ENT("GE", 0x26, 1, 0x600), /* Georgia */
+	COUNTRY_CHPLAN_ENT("GF", 0x26, 1, 0x080), /* French Guiana */
+	COUNTRY_CHPLAN_ENT("GG", 0x26, 1, 0x000), /* Guernsey (UK) */
+	COUNTRY_CHPLAN_ENT("GH", 0x26, 1, 0x7F1), /* Ghana */
+	COUNTRY_CHPLAN_ENT("GI", 0x26, 1, 0x600), /* Gibraltar (UK) */
+	COUNTRY_CHPLAN_ENT("GL", 0x26, 1, 0x600), /* Greenland (Denmark) */
+	COUNTRY_CHPLAN_ENT("GM", 0x26, 1, 0x6B0), /* Gambia */
+	COUNTRY_CHPLAN_ENT("GN", 0x26, 1, 0x610), /* Guinea */
+	COUNTRY_CHPLAN_ENT("GP", 0x26, 1, 0x600), /* Guadeloupe (France) */
+	COUNTRY_CHPLAN_ENT("GQ", 0x26, 1, 0x6B0), /* Equatorial Guinea */
+	COUNTRY_CHPLAN_ENT("GR", 0x26, 1, 0x7FB), /* Greece */
+	COUNTRY_CHPLAN_ENT("GS", 0x26, 1, 0x000), /* South Georgia and the Sandwich Islands (UK) */
+	COUNTRY_CHPLAN_ENT("GT", 0x61, 1, 0x7F1), /* Guatemala */
+	COUNTRY_CHPLAN_ENT("GU", 0x76, 1, 0x600), /* Guam (USA) */
+	COUNTRY_CHPLAN_ENT("GW", 0x26, 1, 0x6B0), /* Guinea-Bissau */
+	COUNTRY_CHPLAN_ENT("GY", 0x44, 1, 0x000), /* Guyana */
+	COUNTRY_CHPLAN_ENT("HK", 0x35, 1, 0x7FB), /* Hong Kong */
+	COUNTRY_CHPLAN_ENT("HM", 0x45, 1, 0x000), /* Heard and McDonald Islands (Australia) */
+	COUNTRY_CHPLAN_ENT("HN", 0x32, 1, 0x7F1), /* Honduras */
+	COUNTRY_CHPLAN_ENT("HR", 0x26, 1, 0x7F9), /* Croatia */
+	COUNTRY_CHPLAN_ENT("HT", 0x76, 1, 0x650), /* Haiti */
+	COUNTRY_CHPLAN_ENT("HU", 0x26, 1, 0x7FB), /* Hungary */
+	COUNTRY_CHPLAN_ENT("ID", 0x3D, 0, 0x7F3), /* Indonesia */
+	COUNTRY_CHPLAN_ENT("IE", 0x26, 1, 0x7FB), /* Ireland */
+	COUNTRY_CHPLAN_ENT("IL", 0x47, 1, 0x7F1), /* Israel */
+	COUNTRY_CHPLAN_ENT("IM", 0x26, 1, 0x000), /* Isle of Man (UK) */
+	COUNTRY_CHPLAN_ENT("IN", 0x48, 1, 0x7F1), /* India */
+	COUNTRY_CHPLAN_ENT("IO", 0x26, 1, 0x000), /* British Indian Ocean Territory (UK) */
+	COUNTRY_CHPLAN_ENT("IQ", 0x26, 1, 0x000), /* Iraq */
+	COUNTRY_CHPLAN_ENT("IR", 0x26, 0, 0x000), /* Iran */
+	COUNTRY_CHPLAN_ENT("IS", 0x26, 1, 0x7FB), /* Iceland */
+	COUNTRY_CHPLAN_ENT("IT", 0x26, 1, 0x7FB), /* Italy */
+	COUNTRY_CHPLAN_ENT("JE", 0x26, 1, 0x000), /* Jersey (UK) */
+	COUNTRY_CHPLAN_ENT("JM", 0x32, 1, 0x7F1), /* Jamaica */
+	COUNTRY_CHPLAN_ENT("JO", 0x49, 1, 0x7FB), /* Jordan */
+	COUNTRY_CHPLAN_ENT("JP", 0x27, 1, 0x7FF), /* Japan- Telec */
+	COUNTRY_CHPLAN_ENT("KE", 0x47, 1, 0x7F9), /* Kenya */
+	COUNTRY_CHPLAN_ENT("KG", 0x26, 1, 0x7F1), /* Kyrgyzstan */
+	COUNTRY_CHPLAN_ENT("KH", 0x26, 1, 0x7F1), /* Cambodia */
+	COUNTRY_CHPLAN_ENT("KI", 0x26, 1, 0x000), /* Kiribati */
+	COUNTRY_CHPLAN_ENT("KM", 0x26, 1, 0x000), /* Comoros */
+	COUNTRY_CHPLAN_ENT("KN", 0x76, 1, 0x000), /* Saint Kitts and Nevis */
+	COUNTRY_CHPLAN_ENT("KR", 0x3E, 1, 0x7FB), /* South Korea */
+	COUNTRY_CHPLAN_ENT("KW", 0x47, 1, 0x7FB), /* Kuwait */
+	COUNTRY_CHPLAN_ENT("KY", 0x76, 1, 0x000), /* Cayman Islands (UK) */
+	COUNTRY_CHPLAN_ENT("KZ", 0x26, 1, 0x700), /* Kazakhstan */
+	COUNTRY_CHPLAN_ENT("LA", 0x26, 1, 0x000), /* Laos */
+	COUNTRY_CHPLAN_ENT("LB", 0x26, 1, 0x7F1), /* Lebanon */
+	COUNTRY_CHPLAN_ENT("LC", 0x76, 1, 0x000), /* Saint Lucia */
+	COUNTRY_CHPLAN_ENT("LI", 0x26, 1, 0x7FB), /* Liechtenstein */
+	COUNTRY_CHPLAN_ENT("LK", 0x26, 1, 0x7F1), /* Sri Lanka */
+	COUNTRY_CHPLAN_ENT("LR", 0x26, 1, 0x6B0), /* Liberia */
+	COUNTRY_CHPLAN_ENT("LS", 0x26, 1, 0x7F1), /* Lesotho */
+	COUNTRY_CHPLAN_ENT("LT", 0x26, 1, 0x7FB), /* Lithuania */
+	COUNTRY_CHPLAN_ENT("LU", 0x26, 1, 0x7FB), /* Luxembourg */
+	COUNTRY_CHPLAN_ENT("LV", 0x26, 1, 0x7FB), /* Latvia */
+	COUNTRY_CHPLAN_ENT("LY", 0x26, 1, 0x000), /* Libya */
+	COUNTRY_CHPLAN_ENT("MA", 0x47, 1, 0x7F1), /* Morocco */
+	COUNTRY_CHPLAN_ENT("MC", 0x26, 1, 0x7FB), /* Monaco */
+	COUNTRY_CHPLAN_ENT("MD", 0x26, 1, 0x7F1), /* Moldova */
+	COUNTRY_CHPLAN_ENT("ME", 0x26, 1, 0x7F1), /* Montenegro */
+	COUNTRY_CHPLAN_ENT("MF", 0x76, 1, 0x000), /* Saint Martin */
+	COUNTRY_CHPLAN_ENT("MG", 0x26, 1, 0x620), /* Madagascar */
+	COUNTRY_CHPLAN_ENT("MH", 0x76, 1, 0x000), /* Marshall Islands (USA) */
+	COUNTRY_CHPLAN_ENT("MK", 0x26, 1, 0x7F1), /* Republic of Macedonia (FYROM) */
+	COUNTRY_CHPLAN_ENT("ML", 0x26, 1, 0x6B0), /* Mali */
+	COUNTRY_CHPLAN_ENT("MM", 0x26, 1, 0x000), /* Burma (Myanmar) */
+	COUNTRY_CHPLAN_ENT("MN", 0x26, 1, 0x000), /* Mongolia */
+	COUNTRY_CHPLAN_ENT("MO", 0x35, 1, 0x600), /* Macau */
+	COUNTRY_CHPLAN_ENT("MP", 0x76, 1, 0x000), /* Northern Mariana Islands (USA) */
+	COUNTRY_CHPLAN_ENT("MQ", 0x26, 1, 0x640), /* Martinique (France) */
+	COUNTRY_CHPLAN_ENT("MR", 0x26, 1, 0x6A0), /* Mauritania */
+	COUNTRY_CHPLAN_ENT("MS", 0x26, 1, 0x000), /* Montserrat (UK) */
+	COUNTRY_CHPLAN_ENT("MT", 0x26, 1, 0x7FB), /* Malta */
+	COUNTRY_CHPLAN_ENT("MU", 0x26, 1, 0x6B0), /* Mauritius */
+	COUNTRY_CHPLAN_ENT("MV", 0x47, 1, 0x000), /* Maldives */
+	COUNTRY_CHPLAN_ENT("MW", 0x26, 1, 0x6B0), /* Malawi */
+	COUNTRY_CHPLAN_ENT("MX", 0x61, 1, 0x7F1), /* Mexico */
+	COUNTRY_CHPLAN_ENT("MY", 0x63, 1, 0x7F1), /* Malaysia */
+	COUNTRY_CHPLAN_ENT("MZ", 0x26, 1, 0x7F1), /* Mozambique */
+	COUNTRY_CHPLAN_ENT("NA", 0x26, 1, 0x700), /* Namibia */
+	COUNTRY_CHPLAN_ENT("NC", 0x26, 1, 0x000), /* New Caledonia */
+	COUNTRY_CHPLAN_ENT("NE", 0x26, 1, 0x6B0), /* Niger */
+	COUNTRY_CHPLAN_ENT("NF", 0x45, 1, 0x000), /* Norfolk Island (Australia) */
+	COUNTRY_CHPLAN_ENT("NG", 0x75, 1, 0x7F9), /* Nigeria */
+	COUNTRY_CHPLAN_ENT("NI", 0x76, 1, 0x7F1), /* Nicaragua */
+	COUNTRY_CHPLAN_ENT("NL", 0x26, 1, 0x7FB), /* Netherlands */
+	COUNTRY_CHPLAN_ENT("NO", 0x26, 1, 0x7FB), /* Norway */
+	COUNTRY_CHPLAN_ENT("NP", 0x48, 1, 0x6F0), /* Nepal */
+	COUNTRY_CHPLAN_ENT("NR", 0x26, 1, 0x000), /* Nauru */
+	COUNTRY_CHPLAN_ENT("NU", 0x45, 1, 0x000), /* Niue */
+	COUNTRY_CHPLAN_ENT("NZ", 0x45, 1, 0x7FB), /* New Zealand */
+	COUNTRY_CHPLAN_ENT("OM", 0x26, 1, 0x7F9), /* Oman */
+	COUNTRY_CHPLAN_ENT("PA", 0x76, 1, 0x7F1), /* Panama */
+	COUNTRY_CHPLAN_ENT("PE", 0x76, 1, 0x7F1), /* Peru */
+	COUNTRY_CHPLAN_ENT("PF", 0x26, 1, 0x000), /* French Polynesia (France) */
+	COUNTRY_CHPLAN_ENT("PG", 0x35, 1, 0x7F1), /* Papua New Guinea */
+	COUNTRY_CHPLAN_ENT("PH", 0x35, 1, 0x7F1), /* Philippines */
+	COUNTRY_CHPLAN_ENT("PK", 0x51, 1, 0x7F1), /* Pakistan */
+	COUNTRY_CHPLAN_ENT("PL", 0x26, 1, 0x7FB), /* Poland */
+	COUNTRY_CHPLAN_ENT("PM", 0x26, 1, 0x000), /* Saint Pierre and Miquelon (France) */
+	COUNTRY_CHPLAN_ENT("PR", 0x76, 1, 0x7F1), /* Puerto Rico */
+	COUNTRY_CHPLAN_ENT("PT", 0x26, 1, 0x7FB), /* Portugal */
+	COUNTRY_CHPLAN_ENT("PW", 0x76, 1, 0x000), /* Palau */
+	COUNTRY_CHPLAN_ENT("PY", 0x76, 1, 0x7F1), /* Paraguay */
+	COUNTRY_CHPLAN_ENT("QA", 0x35, 1, 0x7F9), /* Qatar */
+	COUNTRY_CHPLAN_ENT("RE", 0x26, 1, 0x000), /* Reunion (France) */
+	COUNTRY_CHPLAN_ENT("RO", 0x26, 1, 0x7F1), /* Romania */
+	COUNTRY_CHPLAN_ENT("RS", 0x26, 1, 0x7F1), /* Serbia, Kosovo */
+	COUNTRY_CHPLAN_ENT("RU", 0x59, 1, 0x7FB), /* Russia(fac/gost), Kaliningrad */
+	COUNTRY_CHPLAN_ENT("RW", 0x26, 1, 0x0B0), /* Rwanda */
+	COUNTRY_CHPLAN_ENT("SA", 0x35, 1, 0x7FB), /* Saudi Arabia */
+	COUNTRY_CHPLAN_ENT("SB", 0x26, 1, 0x000), /* Solomon Islands */
+	COUNTRY_CHPLAN_ENT("SC", 0x76, 1, 0x690), /* Seychelles */
+	COUNTRY_CHPLAN_ENT("SE", 0x26, 1, 0x7FB), /* Sweden */
+	COUNTRY_CHPLAN_ENT("SG", 0x35, 1, 0x7FB), /* Singapore */
+	COUNTRY_CHPLAN_ENT("SH", 0x26, 1, 0x000), /* Saint Helena (UK) */
+	COUNTRY_CHPLAN_ENT("SI", 0x26, 1, 0x7FB), /* Slovenia */
+	COUNTRY_CHPLAN_ENT("SJ", 0x26, 1, 0x000), /* Svalbard (Norway) */
+	COUNTRY_CHPLAN_ENT("SK", 0x26, 1, 0x7FB), /* Slovakia */
+	COUNTRY_CHPLAN_ENT("SL", 0x26, 1, 0x6B0), /* Sierra Leone */
+	COUNTRY_CHPLAN_ENT("SM", 0x26, 1, 0x000), /* San Marino */
+	COUNTRY_CHPLAN_ENT("SN", 0x26, 1, 0x7F1), /* Senegal */
+	COUNTRY_CHPLAN_ENT("SO", 0x26, 1, 0x000), /* Somalia */
+	COUNTRY_CHPLAN_ENT("SR", 0x74, 1, 0x000), /* Suriname */
+	COUNTRY_CHPLAN_ENT("ST", 0x76, 1, 0x680), /* Sao Tome and Principe */
+	COUNTRY_CHPLAN_ENT("SV", 0x30, 1, 0x7F1), /* El Salvador */
+	COUNTRY_CHPLAN_ENT("SX", 0x76, 1, 0x000), /* Sint Marteen */
+	COUNTRY_CHPLAN_ENT("SZ", 0x26, 1, 0x020), /* Swaziland */
+	COUNTRY_CHPLAN_ENT("TC", 0x26, 1, 0x000), /* Turks and Caicos Islands (UK) */
+	COUNTRY_CHPLAN_ENT("TD", 0x26, 1, 0x6B0), /* Chad */
+	COUNTRY_CHPLAN_ENT("TF", 0x26, 1, 0x680), /* French Southern and Antarctic Lands (FR Southern Territories) */
+	COUNTRY_CHPLAN_ENT("TG", 0x26, 1, 0x6B0), /* Togo */
+	COUNTRY_CHPLAN_ENT("TH", 0x35, 1, 0x7F1), /* Thailand */
+	COUNTRY_CHPLAN_ENT("TJ", 0x26, 1, 0x640), /* Tajikistan */
+	COUNTRY_CHPLAN_ENT("TK", 0x45, 1, 0x000), /* Tokelau */
+	COUNTRY_CHPLAN_ENT("TM", 0x26, 1, 0x000), /* Turkmenistan */
+	COUNTRY_CHPLAN_ENT("TN", 0x47, 1, 0x7F1), /* Tunisia */
+	COUNTRY_CHPLAN_ENT("TO", 0x26, 1, 0x000), /* Tonga */
+	COUNTRY_CHPLAN_ENT("TR", 0x26, 1, 0x7F1), /* Turkey, Northern Cyprus */
+	COUNTRY_CHPLAN_ENT("TT", 0x76, 1, 0x3F1), /* Trinidad & Tobago */
+	COUNTRY_CHPLAN_ENT("TV", 0x21, 0, 0x000), /* Tuvalu */
+	COUNTRY_CHPLAN_ENT("TW", 0x76, 1, 0x7FF), /* Taiwan */
+	COUNTRY_CHPLAN_ENT("TZ", 0x26, 1, 0x6F0), /* Tanzania */
+	COUNTRY_CHPLAN_ENT("UA", 0x36, 1, 0x7FB), /* Ukraine */
+	COUNTRY_CHPLAN_ENT("UG", 0x26, 1, 0x6F1), /* Uganda */
+	COUNTRY_CHPLAN_ENT("US", 0x76, 1, 0x7FF), /* United States of America (USA) */
+	COUNTRY_CHPLAN_ENT("UY", 0x30, 1, 0x7F1), /* Uruguay */
+	COUNTRY_CHPLAN_ENT("UZ", 0x47, 1, 0x6F0), /* Uzbekistan */
+	COUNTRY_CHPLAN_ENT("VA", 0x26, 1, 0x000), /* Holy See (Vatican City) */
+	COUNTRY_CHPLAN_ENT("VC", 0x76, 1, 0x010), /* Saint Vincent and the Grenadines */
+	COUNTRY_CHPLAN_ENT("VE", 0x30, 1, 0x7F1), /* Venezuela */
+	COUNTRY_CHPLAN_ENT("VG", 0x76, 1, 0x000), /* British Virgin Islands (UK) */
+	COUNTRY_CHPLAN_ENT("VI", 0x76, 1, 0x000), /* United States Virgin Islands (USA) */
+	COUNTRY_CHPLAN_ENT("VN", 0x35, 1, 0x7F1), /* Vietnam */
+	COUNTRY_CHPLAN_ENT("VU", 0x26, 1, 0x000), /* Vanuatu */
+	COUNTRY_CHPLAN_ENT("WF", 0x26, 1, 0x000), /* Wallis and Futuna (France) */
+	COUNTRY_CHPLAN_ENT("WS", 0x76, 1, 0x000), /* Samoa */
+	COUNTRY_CHPLAN_ENT("YE", 0x26, 1, 0x040), /* Yemen */
+	COUNTRY_CHPLAN_ENT("YT", 0x26, 1, 0x680), /* Mayotte (France) */
+	COUNTRY_CHPLAN_ENT("ZA", 0x35, 1, 0x7F1), /* South Africa */
+	COUNTRY_CHPLAN_ENT("ZM", 0x26, 1, 0x6B0), /* Zambia */
+	COUNTRY_CHPLAN_ENT("ZW", 0x26, 1, 0x7F1), /* Zimbabwe */
+};
+
+/*
+* rtw_get_chplan_from_country -
+* @country_code: string of country code
+*
+* Return pointer of struct country_chplan entry or NULL when unsupported country_code is given
+*/
+const struct country_chplan *rtw_get_chplan_from_country(const char *country_code)
+{
+#if RTW_DEF_MODULE_REGULATORY_CERT
+	const struct country_chplan *exc_ent = NULL;
+#endif
+	const struct country_chplan *ent = NULL;
+	const struct country_chplan *map = NULL;
+	u16 map_sz = 0;
+	char code[2];
+	int i;
+
+	code[0] = alpha_to_upper(country_code[0]);
+	code[1] = alpha_to_upper(country_code[1]);
+
+#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
+	map = CUSTOMIZED_country_chplan_map;
+	map_sz = sizeof(CUSTOMIZED_country_chplan_map) / sizeof(struct country_chplan);
+#else
+	#if RTW_DEF_MODULE_REGULATORY_CERT
+	exc_ent = rtw_def_module_get_chplan_from_country(code);
+	#endif
+	map = country_chplan_map;
+	map_sz = sizeof(country_chplan_map) / sizeof(struct country_chplan);
+#endif
+
+	for (i = 0; i < map_sz; i++) {
+		if (strncmp(code, map[i].alpha2, 2) == 0) {
+			ent = &map[i];
+			break;
+		}
+	}
+
+	#if RTW_DEF_MODULE_REGULATORY_CERT
+	if (!ent || !(COUNTRY_CHPLAN_DEF_MODULE_FALGS(ent) & RTW_DEF_MODULE_REGULATORY_CERT))
+		exc_ent = ent = NULL;
+	if (exc_ent)
+		ent = exc_ent;
+	#endif
+
+	return ent;
+}
+
+void dump_country_chplan(void *sel, const struct country_chplan *ent)
+{
+	RTW_PRINT_SEL(sel, "\"%c%c\", 0x%02X%s\n"
+		, ent->alpha2[0], ent->alpha2[1], ent->chplan
+		, COUNTRY_CHPLAN_EN_11AC(ent) ? " ac" : ""
+	);
+}
+
+void dump_country_chplan_map(void *sel)
+{
+	const struct country_chplan *ent;
+	u8 code[2];
+
+#if RTW_DEF_MODULE_REGULATORY_CERT
+	RTW_PRINT_SEL(sel, "RTW_DEF_MODULE_REGULATORY_CERT:0x%x\n", RTW_DEF_MODULE_REGULATORY_CERT);
+#endif
+#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
+	RTW_PRINT_SEL(sel, "CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP\n");
+#endif
+
+	for (code[0] = 'A'; code[0] <= 'Z'; code[0]++) {
+		for (code[1] = 'A'; code[1] <= 'Z'; code[1]++) {
+			ent = rtw_get_chplan_from_country(code);
+			if (!ent)
+				continue;
+
+			dump_country_chplan(sel, ent);
+		}
+	}
+}
+
+void dump_chplan_id_list(void *sel)
+{
+	u8 first = 1;
+	int i;
+
+	for (i = 0; i < RTW_CHPLAN_MAX; i++) {
+		if (!rtw_is_channel_plan_valid(i))
+			continue;
+
+		if (first) {
+			RTW_PRINT_SEL(sel, "0x%02X ", i);
+			first = 0;
+		} else
+			_RTW_PRINT_SEL(sel, "0x%02X ", i);
+	}
+
+	_RTW_PRINT_SEL(sel, "0x7F\n");
+}
+
+void dump_chplan_test(void *sel)
+{
+	int i, j;
+
+	/* check invalid channel */
+	for (i = 0; i < RTW_RD_2G_MAX; i++) {
+		for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan2G[i]); j++) {
+			if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan2G[i], j)) == 0)
+				RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan2G[i], j), i, j);
+		}
+	}
+
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	for (i = 0; i < RTW_RD_5G_MAX; i++) {
+		for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan5G[i]); j++) {
+			if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan5G[i], j)) == 0)
+				RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan5G[i], j), i, j);
+		}
+	}
+#endif
+}
+
+void dump_chplan_ver(void *sel)
+{
+	RTW_PRINT_SEL(sel, "%s-%s\n", RTW_DOMAIN_MAP_VER, RTW_COUNTRY_MAP_VER);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_chplan.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_chplan.h
new file mode 100644
index 000000000000..1819fd13f81e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_chplan.h
@@ -0,0 +1,182 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2018 Realtek Corporation.
+ *
+ * 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_CHPLAN_H__
+#define __RTW_CHPLAN_H__
+
+enum rtw_chplan_id {
+	/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
+	RTW_CHPLAN_FCC = 0x00,
+	RTW_CHPLAN_IC = 0x01,
+	RTW_CHPLAN_ETSI = 0x02,
+	RTW_CHPLAN_SPAIN = 0x03,
+	RTW_CHPLAN_FRANCE = 0x04,
+	RTW_CHPLAN_MKK = 0x05,
+	RTW_CHPLAN_MKK1 = 0x06,
+	RTW_CHPLAN_ISRAEL = 0x07,
+	RTW_CHPLAN_TELEC = 0x08,
+	RTW_CHPLAN_GLOBAL_DOAMIN = 0x09,
+	RTW_CHPLAN_WORLD_WIDE_13 = 0x0A,
+	RTW_CHPLAN_TAIWAN = 0x0B,
+	RTW_CHPLAN_CHINA = 0x0C,
+	RTW_CHPLAN_SINGAPORE_INDIA_MEXICO = 0x0D,
+	RTW_CHPLAN_KOREA = 0x0E,
+	RTW_CHPLAN_TURKEY = 0x0F,
+	RTW_CHPLAN_JAPAN = 0x10,
+	RTW_CHPLAN_FCC_NO_DFS = 0x11,
+	RTW_CHPLAN_JAPAN_NO_DFS = 0x12,
+	RTW_CHPLAN_WORLD_WIDE_5G = 0x13,
+	RTW_CHPLAN_TAIWAN_NO_DFS = 0x14,
+
+	/* ===== 0x20 ~ 0x7F, new channel plan ===== */
+	RTW_CHPLAN_WORLD_NULL = 0x20,
+	RTW_CHPLAN_ETSI1_NULL = 0x21,
+	RTW_CHPLAN_FCC1_NULL = 0x22,
+	RTW_CHPLAN_MKK1_NULL = 0x23,
+	RTW_CHPLAN_ETSI2_NULL = 0x24,
+	RTW_CHPLAN_FCC1_FCC1 = 0x25,
+	RTW_CHPLAN_WORLD_ETSI1 = 0x26,
+	RTW_CHPLAN_MKK1_MKK1 = 0x27,
+	RTW_CHPLAN_WORLD_KCC1 = 0x28,
+	RTW_CHPLAN_WORLD_FCC2 = 0x29,
+	RTW_CHPLAN_FCC2_NULL = 0x2A,
+	RTW_CHPLAN_IC1_IC2 = 0x2B,
+	RTW_CHPLAN_MKK2_NULL = 0x2C,
+	RTW_CHPLAN_WORLD_CHILE1= 0x2D,
+	RTW_CHPLAN_WORLD1_WORLD1 = 0x2E,
+	RTW_CHPLAN_WORLD_CHILE2 = 0x2F,
+	RTW_CHPLAN_WORLD_FCC3 = 0x30,
+	RTW_CHPLAN_WORLD_FCC4 = 0x31,
+	RTW_CHPLAN_WORLD_FCC5 = 0x32,
+	RTW_CHPLAN_WORLD_FCC6 = 0x33,
+	RTW_CHPLAN_FCC1_FCC7 = 0x34,
+	RTW_CHPLAN_WORLD_ETSI2 = 0x35,
+	RTW_CHPLAN_WORLD_ETSI3 = 0x36,
+	RTW_CHPLAN_MKK1_MKK2 = 0x37,
+	RTW_CHPLAN_MKK1_MKK3 = 0x38,
+	RTW_CHPLAN_FCC1_NCC1 = 0x39,
+	RTW_CHPLAN_ETSI1_ETSI1 = 0x3A,
+	RTW_CHPLAN_ETSI1_ACMA1 = 0x3B,
+	RTW_CHPLAN_ETSI1_ETSI6 = 0x3C,
+	RTW_CHPLAN_ETSI1_ETSI12 = 0x3D,
+	RTW_CHPLAN_KCC1_KCC2 = 0x3E,
+	RTW_CHPLAN_FCC1_FCC11 = 0x3F,
+	RTW_CHPLAN_FCC1_NCC2 = 0x40,
+	RTW_CHPLAN_GLOBAL_NULL = 0x41,
+	RTW_CHPLAN_ETSI1_ETSI4 = 0x42,
+	RTW_CHPLAN_FCC1_FCC2 = 0x43,
+	RTW_CHPLAN_FCC1_NCC3 = 0x44,
+	RTW_CHPLAN_WORLD_ACMA1 = 0x45,
+	RTW_CHPLAN_FCC1_FCC8 = 0x46,
+	RTW_CHPLAN_WORLD_ETSI6 = 0x47,
+	RTW_CHPLAN_WORLD_ETSI7 = 0x48,
+	RTW_CHPLAN_WORLD_ETSI8 = 0x49,
+	RTW_CHPLAN_IC2_IC2 = 0x4A,
+	RTW_CHPLAN_WORLD_ETSI9 = 0x50,
+	RTW_CHPLAN_WORLD_ETSI10 = 0x51,
+	RTW_CHPLAN_WORLD_ETSI11 = 0x52,
+	RTW_CHPLAN_FCC1_NCC4 = 0x53,
+	RTW_CHPLAN_WORLD_ETSI12 = 0x54,
+	RTW_CHPLAN_FCC1_FCC9 = 0x55,
+	RTW_CHPLAN_WORLD_ETSI13 = 0x56,
+	RTW_CHPLAN_FCC1_FCC10 = 0x57,
+	RTW_CHPLAN_MKK2_MKK4 = 0x58,
+	RTW_CHPLAN_WORLD_ETSI14 = 0x59,
+	RTW_CHPLAN_FCC1_FCC5 = 0x60,
+	RTW_CHPLAN_FCC2_FCC7 = 0x61,
+	RTW_CHPLAN_FCC2_FCC1 = 0x62,
+	RTW_CHPLAN_WORLD_ETSI15 = 0x63,
+	RTW_CHPLAN_MKK2_MKK5 = 0x64,
+	RTW_CHPLAN_ETSI1_ETSI16 = 0x65,
+	RTW_CHPLAN_FCC1_FCC14 = 0x66,
+	RTW_CHPLAN_FCC1_FCC12 = 0x67,
+	RTW_CHPLAN_FCC2_FCC14 = 0x68,
+	RTW_CHPLAN_FCC2_FCC12 = 0x69,
+	RTW_CHPLAN_ETSI1_ETSI17 = 0x6A,
+	RTW_CHPLAN_WORLD_FCC16 = 0x6B,
+	RTW_CHPLAN_WORLD_FCC13 = 0x6C,
+	RTW_CHPLAN_FCC2_FCC15 = 0x6D,
+	RTW_CHPLAN_WORLD_FCC12 = 0x6E,
+	RTW_CHPLAN_NULL_ETSI8 = 0x6F,
+	RTW_CHPLAN_NULL_ETSI18 = 0x70,
+	RTW_CHPLAN_NULL_ETSI17 = 0x71,
+	RTW_CHPLAN_NULL_ETSI19 = 0x72,
+	RTW_CHPLAN_WORLD_FCC7 = 0x73,
+	RTW_CHPLAN_FCC2_FCC17 = 0x74,
+	RTW_CHPLAN_WORLD_ETSI20 = 0x75,
+	RTW_CHPLAN_FCC2_FCC11 = 0x76,
+	RTW_CHPLAN_WORLD_ETSI21 = 0x77,
+	RTW_CHPLAN_FCC1_FCC18 = 0x78,
+	RTW_CHPLAN_MKK2_MKK1 = 0x79,
+
+	RTW_CHPLAN_MAX,
+	RTW_CHPLAN_REALTEK_DEFINE = 0x7F,
+	RTW_CHPLAN_UNSPECIFIED = 0xFF,
+};
+
+u8 rtw_chplan_get_default_regd(u8 id);
+bool rtw_chplan_is_empty(u8 id);
+#define rtw_is_channel_plan_valid(chplan) (((chplan) < RTW_CHPLAN_MAX || (chplan) == RTW_CHPLAN_REALTEK_DEFINE) && !rtw_chplan_is_empty(chplan))
+#define rtw_is_legacy_channel_plan(chplan) ((chplan) < 0x20)
+
+struct _RT_CHANNEL_INFO;
+u8 init_channel_set(_adapter *padapter, u8 ChannelPlan, struct _RT_CHANNEL_INFO *channel_set);
+
+#define IS_ALPHA2_NO_SPECIFIED(_alpha2) ((*((u16 *)(_alpha2))) == 0xFFFF)
+
+#define RTW_MODULE_RTL8821AE_HMC_M2		BIT0	/* RTL8821AE(HMC + M.2) */
+#define RTW_MODULE_RTL8821AU			BIT1	/* RTL8821AU */
+#define RTW_MODULE_RTL8812AENF_NGFF		BIT2	/* RTL8812AENF(8812AE+8761)_NGFF */
+#define RTW_MODULE_RTL8812AEBT_HMC		BIT3	/* RTL8812AEBT(8812AE+8761)_HMC */
+#define RTW_MODULE_RTL8188EE_HMC_M2		BIT4	/* RTL8188EE(HMC + M.2) */
+#define RTW_MODULE_RTL8723BE_HMC_M2		BIT5	/* RTL8723BE(HMC + M.2) */
+#define RTW_MODULE_RTL8723BS_NGFF1216	BIT6	/* RTL8723BS(NGFF1216) */
+#define RTW_MODULE_RTL8192EEBT_HMC_M2	BIT7	/* RTL8192EEBT(8192EE+8761AU)_(HMC + M.2) */
+#define RTW_MODULE_RTL8723DE_NGFF1630	BIT8	/* RTL8723DE(NGFF1630) */
+#define RTW_MODULE_RTL8822BE			BIT9	/* RTL8822BE */
+#define RTW_MODULE_RTL8821CE			BIT10	/* RTL8821CE */
+
+struct country_chplan {
+	char alpha2[2];
+	u8 chplan;
+#ifdef CONFIG_80211AC_VHT
+	u8 en_11ac;
+#endif
+#if RTW_DEF_MODULE_REGULATORY_CERT
+	u16 def_module_flags; /* RTW_MODULE_RTLXXX */
+#endif
+};
+
+#ifdef CONFIG_80211AC_VHT
+#define COUNTRY_CHPLAN_EN_11AC(_ent) ((_ent)->en_11ac)
+#else
+#define COUNTRY_CHPLAN_EN_11AC(_ent) 0
+#endif
+
+#if RTW_DEF_MODULE_REGULATORY_CERT
+#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) ((_ent)->def_module_flags)
+#else
+#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) 0
+#endif
+
+const struct country_chplan *rtw_get_chplan_from_country(const char *country_code);
+
+void dump_country_chplan(void *sel, const struct country_chplan *ent);
+void dump_country_chplan_map(void *sel);
+void dump_chplan_id_list(void *sel);
+void dump_chplan_test(void *sel);
+void dump_chplan_ver(void *sel);
+
+#endif /* __RTW_CHPLAN_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_cmd.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_cmd.c
index d223e749cdd9..48e5d6b10e99 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_cmd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_cmd.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -452,7 +453,7 @@ u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
 
 #ifdef CONFIG_CONCURRENT_MODE
 	/* change pcmdpriv to primary's pcmdpriv */
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
+	if (!is_primary_adapter(padapter))
 		pcmdpriv = &(GET_PRIMARY_ADAPTER(padapter)->cmdpriv);
 #endif
 
@@ -502,8 +503,6 @@ void rtw_cmd_clr_isr(struct	cmd_priv *pcmdpriv)
 
 void rtw_free_cmd_obj(struct cmd_obj *pcmd)
 {
-	struct drvextra_cmd_parm *extra_parm = NULL;
-
 	if (pcmd->parmbuf != NULL) {
 		/* free parmbuf in cmd_obj */
 		rtw_mfree((unsigned char *)pcmd->parmbuf, pcmd->cmdsz);
@@ -517,7 +516,6 @@ void rtw_free_cmd_obj(struct cmd_obj *pcmd)
 
 	/* free cmd_obj */
 	rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
-
 }
 
 
@@ -621,6 +619,10 @@ _next:
 				if (extra_parm && extra_parm->pbuf && extra_parm->size > 0)
 					rtw_mfree(extra_parm->pbuf, extra_parm->size);
 			}
+			#ifdef CONFIG_DFS
+			else if (pcmd->cmdcode == GEN_CMD_CODE(_SetChannelSwitch))
+				adapter_to_rfctl(padapter)->csa_ch = 0;
+			#endif
 			goto post_process;
 		}
 
@@ -717,6 +719,10 @@ post_process:
 			if (extra_parm->pbuf && extra_parm->size > 0)
 				rtw_mfree(extra_parm->pbuf, extra_parm->size);
 		}
+		#ifdef CONFIG_DFS
+		else if (pcmd->cmdcode == GEN_CMD_CODE(_SetChannelSwitch))
+			adapter_to_rfctl(padapter)->csa_ch = 0;
+		#endif
 
 		_enter_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
 		if (pcmd->sctx) {
@@ -863,9 +869,6 @@ u8 rtw_sitesurvey_cmd(_adapter *padapter, struct sitesurvey_parm *pparm)
 	struct sitesurvey_parm	*psurveyPara;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
-#endif /* CONFIG_P2P */
 
 #ifdef CONFIG_LPS
 	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
@@ -1218,12 +1221,11 @@ void rtw_readtssi_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
 }
 
 static u8 rtw_createbss_cmd(_adapter  *adapter, int flags, bool adhoc
-			    , s16 req_ch, s8 req_bw, s8 req_offset)
+	, u8 ifbmp, u8 excl_ifbmp, s16 req_ch, s8 req_bw, s8 req_offset)
 {
 	struct cmd_obj *cmdobj;
 	struct createbss_parm *parm;
 	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
-	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct submit_ctx sctx;
 	u8 res = _SUCCESS;
 
@@ -1246,6 +1248,8 @@ static u8 rtw_createbss_cmd(_adapter  *adapter, int flags, bool adhoc
 		parm->adhoc = 1;
 	} else {
 		parm->adhoc = 0;
+		parm->ifbmp = ifbmp;
+		parm->excl_ifbmp = excl_ifbmp;
 		parm->req_ch = req_ch;
 		parm->req_bw = req_bw;
 		parm->req_offset = req_offset;
@@ -1291,7 +1295,8 @@ inline u8 rtw_create_ibss_cmd(_adapter *adapter, int flags)
 {
 	return rtw_createbss_cmd(adapter, flags
 		, 1
-		, 0, -1, -1 /* for now, adhoc doesn't support ch,bw,offset request */
+		, 0, 0
+		, 0, REQ_BW_NONE, REQ_OFFSET_NONE /* for now, adhoc doesn't support ch,bw,offset request */
 	);
 }
 
@@ -1299,18 +1304,57 @@ inline u8 rtw_startbss_cmd(_adapter *adapter, int flags)
 {
 	return rtw_createbss_cmd(adapter, flags
 		, 0
-		, 0, -1, -1 /* excute entire AP setup cmd */
+		, BIT(adapter->iface_id), 0
+		, 0, REQ_BW_NONE, REQ_OFFSET_NONE /* excute entire AP setup cmd */
 	);
 }
 
-inline u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, s16 req_ch, s8 req_bw, s8 req_offset)
+inline u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags
+	, u8 ifbmp, u8 excl_ifbmp, s16 req_ch, s8 req_bw, s8 req_offset)
 {
 	return rtw_createbss_cmd(adapter, flags
 		, 0
+		, ifbmp, excl_ifbmp
 		, req_ch, req_bw, req_offset
 	);
 }
 
+#ifdef CONFIG_RTW_80211R
+static void rtw_ft_validate_akm_type(_adapter  *padapter,
+	struct wlan_network *pnetwork)
+{
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u32 tmp_len;
+	u8 *ptmp;
+
+	/*IEEE802.11-2012 Std. Table 8-101-AKM suite selectors*/
+	if (rtw_ft_valid_akm(padapter, psecuritypriv->rsn_akm_suite_type)) {
+		ptmp = rtw_get_ie(&pnetwork->network.IEs[12], 
+				_MDIE_, &tmp_len, (pnetwork->network.IELength-12));
+		if (ptmp) {
+			pft_roam->mdid = *(u16 *)(ptmp+2);
+			pft_roam->ft_cap = *(ptmp+4);
+
+			RTW_INFO("FT: target " MAC_FMT " mdid=(0x%2x), capacity=(0x%2x)\n", 
+				MAC_ARG(pnetwork->network.MacAddress), pft_roam->mdid, pft_roam->ft_cap);
+			rtw_ft_set_flags(padapter, RTW_FT_PEER_EN);
+
+			if (rtw_ft_otd_roam_en(padapter))
+				rtw_ft_set_flags(padapter, RTW_FT_PEER_OTD_EN);
+		} else {
+			/* Don't use FT roaming if target AP cannot support FT */
+			rtw_ft_clr_flags(padapter, (RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN));
+			rtw_ft_reset_status(padapter);
+		}
+	} else {
+		/* It could be a non-FT connection */
+		rtw_ft_clr_flags(padapter, (RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN));
+		rtw_ft_reset_status(padapter);
+	}	
+}
+#endif
+
 u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork)
 {
 	u8	*auth, res = _SUCCESS;
@@ -1334,9 +1378,6 @@ u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork)
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	u32 tmp_len;
 	u8 *ptmp = NULL;
-#ifdef CONFIG_RTW_80211R
-	struct _ft_priv			*pftpriv = &pmlmepriv->ftpriv;
-#endif
 
 	rtw_led_control(padapter, LED_CTL_START_TO_LINK);
 
@@ -1377,6 +1418,13 @@ u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork)
 
 	pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pnetwork->network.IEs, pnetwork->network.IELength);
 
+#ifdef CONFIG_80211AC_VHT
+	/* save AP beamform_cap info for BCM IOT issue */
+	if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM)
+		pvhtpriv->ap_is_mu_bfer =
+			get_vht_mu_bfer_cap(pnetwork->network.IEs,
+				pnetwork->network.IELength);
+#endif
 	/*
 		Modified by Arvin 2015/05/13
 		Solution for allocating a new WLAN_BSSID_EX to avoid race condition issue between disconnect and joinbss
@@ -1413,7 +1461,11 @@ u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork)
 	if (pmlmepriv->assoc_by_bssid == _FALSE)
 		_rtw_memcpy(&pmlmepriv->assoc_bssid[0], &pnetwork->network.MacAddress[0], ETH_ALEN);
 
-	psecnetwork->IELength = rtw_restruct_sec_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0], pnetwork->network.IELength);
+	/* copy fixed ie */
+	_rtw_memcpy(psecnetwork->IEs, pnetwork->network.IEs, 12);
+	psecnetwork->IELength = 12;
+
+	psecnetwork->IELength += rtw_restruct_sec_ie(padapter, psecnetwork->IEs + psecnetwork->IELength);
 
 
 	pqospriv->qos_option = 0;
@@ -1434,65 +1486,42 @@ u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork)
 
 #ifdef CONFIG_80211N_HT
 	phtpriv->ht_option = _FALSE;
-	ptmp = rtw_get_ie(&pnetwork->network.IEs[12], _HT_CAPABILITY_IE_, &tmp_len, pnetwork->network.IELength - 12);
-	if (pregistrypriv->ht_enable && ptmp && tmp_len > 0) {
-		/*	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 ((padapter->securitypriv.dot11PrivacyAlgrthm != _WEP40_) &&
-		    (padapter->securitypriv.dot11PrivacyAlgrthm != _WEP104_) &&
-		    (padapter->securitypriv.dot11PrivacyAlgrthm != _TKIP_)) {
-			rtw_ht_use_default_setting(padapter);
-
-			/* rtw_restructure_ht_ie */
-			rtw_restructure_ht_ie(padapter, &pnetwork->network.IEs[12], &psecnetwork->IEs[0],
-				pnetwork->network.IELength - 12, &psecnetwork->IELength,
-				pnetwork->network.Configuration.DSConfig);
+	if (pregistrypriv->ht_enable && is_supported_ht(pregistrypriv->wireless_mode)) {
+		ptmp = rtw_get_ie(&pnetwork->network.IEs[12], _HT_CAPABILITY_IE_, &tmp_len, pnetwork->network.IELength - 12);
+		if (ptmp && tmp_len > 0) {
+			/*	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 ((padapter->securitypriv.dot11PrivacyAlgrthm != _WEP40_) &&
+			    (padapter->securitypriv.dot11PrivacyAlgrthm != _WEP104_) &&
+			    (padapter->securitypriv.dot11PrivacyAlgrthm != _TKIP_)) {
+				rtw_ht_use_default_setting(padapter);
+
+				/* rtw_restructure_ht_ie */
+				rtw_restructure_ht_ie(padapter, &pnetwork->network.IEs[12], &psecnetwork->IEs[0],
+					pnetwork->network.IELength - 12, &psecnetwork->IELength,
+					pnetwork->network.Configuration.DSConfig);
+			}
 		}
 	}
 
 #ifdef CONFIG_80211AC_VHT
 	pvhtpriv->vht_option = _FALSE;
 	if (phtpriv->ht_option
-	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
-	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
-	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
-	   ) {
+		&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
+		&& is_supported_vht(pregistrypriv->wireless_mode)
+		&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
+	) {
 		rtw_restructure_vht_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0],
 			pnetwork->network.IELength, &psecnetwork->IELength);
 	}
 #endif
+#endif /* CONFIG_80211N_HT */
 
 	rtw_append_exented_cap(padapter, &psecnetwork->IEs[0], &psecnetwork->IELength);
 
-#endif /* CONFIG_80211N_HT */
-
 #ifdef CONFIG_RTW_80211R
-	/*IEEE802.11-2012 Std. Table 8-101—AKM suite selectors*/
-	if ((rtw_chk_ft_flags(padapter, RTW_FT_STA_SUPPORTED)) &&
-		((psecuritypriv->rsn_akm_suite_type == 3) || (psecuritypriv->rsn_akm_suite_type == 4))
-		) {
-		ptmp = rtw_get_ie(&pnetwork->network.IEs[12], _MDIE_, &tmp_len, pnetwork->network.IELength-12);
-		if (ptmp) {
-			_rtw_memcpy(&pftpriv->mdid, ptmp+2, 2);
-			pftpriv->ft_cap = *(ptmp+4);
-
-			RTW_INFO("FT: Target AP "MAC_FMT" MDID=(0x%2x), capacity=(0x%2x)\n", MAC_ARG(pnetwork->network.MacAddress), pftpriv->mdid, pftpriv->ft_cap);
-			rtw_set_ft_flags(padapter, RTW_FT_SUPPORTED);
-			if ((rtw_chk_ft_flags(padapter, RTW_FT_STA_OVER_DS_SUPPORTED)) && (pftpriv->ft_roam_on_expired == _FALSE) && (pftpriv->ft_cap & 0x01))
-				rtw_set_ft_flags(padapter, RTW_FT_OVER_DS_SUPPORTED);
-		} else {
-				/*Don't use FT roaming if Target AP cannot support FT*/
-				RTW_INFO("FT: Target AP "MAC_FMT" could not support FT\n", MAC_ARG(pnetwork->network.MacAddress));
-				rtw_clr_ft_flags(padapter, RTW_FT_SUPPORTED|RTW_FT_OVER_DS_SUPPORTED);
-				rtw_reset_ft_status(padapter);
-		}
-	} else {
-		/*It could be a non-FT connection*/
-		RTW_INFO("FT: non-FT rtw_joinbss_cmd\n");
-		rtw_clr_ft_flags(padapter, RTW_FT_SUPPORTED|RTW_FT_OVER_DS_SUPPORTED);
-		rtw_reset_ft_status(padapter);
-	}
+	rtw_ft_validate_akm_type(padapter, pnetwork);
 #endif
 
 #if 0
@@ -1548,8 +1577,6 @@ u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, int flags) /* for
 	struct submit_ctx sctx;
 	u8 res = _SUCCESS;
 
-
-
 	/* prepare cmd parameter */
 	param = (struct disconnect_parm *)rtw_zmalloc(sizeof(*param));
 	if (param == NULL) {
@@ -1592,39 +1619,55 @@ exit:
 	return res;
 }
 
-u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, bool enqueue)
+u8 rtw_setopmode_cmd(_adapter  *adapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, u8 flags)
 {
-	struct	cmd_obj	*ph2c;
-	struct	setopmode_parm *psetop;
-
-	struct	cmd_priv   *pcmdpriv = &padapter->cmdpriv;
-	u8	res = _SUCCESS;
-
-	psetop = (struct setopmode_parm *)rtw_zmalloc(sizeof(struct setopmode_parm));
+	struct cmd_obj *cmdobj;
+	struct setopmode_parm *parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
+	u8 res = _SUCCESS;
 
-	if (psetop == NULL) {
+	/* prepare cmd parameter */
+	parm = (struct setopmode_parm *)rtw_zmalloc(sizeof(*parm));
+	if (parm == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
-	psetop->mode = (u8)networktype;
+	parm->mode = (u8)networktype;
 
-	if (enqueue) {
-		ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
-		if (ph2c == NULL) {
-			rtw_mfree((u8 *)psetop, sizeof(*psetop));
+	if (flags & RTW_CMDF_DIRECTLY) {
+		/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
+		if (H2C_SUCCESS != setopmode_hdl(adapter, (u8 *)parm))
 			res = _FAIL;
+		rtw_mfree((u8 *)parm, sizeof(*parm));
+	} else {
+		/* need enqueue, prepare cmd_obj and enqueue */
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
+		if (cmdobj == NULL) {
+			res = _FAIL;
+			rtw_mfree((u8 *)parm, sizeof(*parm));
 			goto exit;
 		}
 
-		init_h2fwcmd_w_parm_no_rsp(ph2c, psetop, _SetOpMode_CMD_);
-		res = rtw_enqueue_cmd(pcmdpriv, ph2c);
-	} else {
-		setopmode_hdl(padapter, (u8 *)psetop);
-		rtw_mfree((u8 *)psetop, sizeof(*psetop));
-	}
-exit:
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, _SetOpMode_CMD_);
 
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			cmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 2000);
+		}
+
+		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
 
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+		}
+	}
+
+exit:
 	return res;
 }
 
@@ -1653,9 +1696,10 @@ u8 rtw_setstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 key_type, bool
 	else
 		GET_ENCRY_ALGO(psecuritypriv, sta, psetstakey_para->algorithm, _FALSE);
 
-	if (key_type == GROUP_KEY)
+	if (key_type == GROUP_KEY) {
 		_rtw_memcpy(&psetstakey_para->key, &psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey, 16);
-	else if (key_type == UNICAST_KEY)
+		psetstakey_para->gk = 1;
+	} else if (key_type == UNICAST_KEY)
 		_rtw_memcpy(&psetstakey_para->key, &sta->dot118021x_UncstKey, 16);
 #ifdef CONFIG_TDLS
 	else if (key_type == TDLS_KEY) {
@@ -1703,8 +1747,6 @@ u8 rtw_clearstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 enqueue)
 	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;
 	s16 cam_id = 0;
 	u8	res = _SUCCESS;
 
@@ -1985,41 +2027,58 @@ exit:
 
 }
 
-u8 rtw_free_assoc_resources_cmd(_adapter *padapter)
+void free_assoc_resources_hdl(_adapter *padapter, u8 lock_scanned_queue)
 {
-	struct cmd_obj		*ph2c;
+	rtw_free_assoc_resources(padapter, lock_scanned_queue);
+}
+
+u8 rtw_free_assoc_resources_cmd(_adapter *padapter, u8 lock_scanned_queue, int flags)
+{
+	struct cmd_obj *cmd;
 	struct drvextra_cmd_parm  *pdrvextra_cmd_parm;
 	struct cmd_priv	*pcmdpriv = &padapter->cmdpriv;
+	struct submit_ctx sctx;
 	u8	res = _SUCCESS;
 
-
-	ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
-	if (ph2c == NULL) {
-		res = _FAIL;
-		goto exit;
-	}
-
-	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
-	if (pdrvextra_cmd_parm == NULL) {
-		rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
-		res = _FAIL;
-		goto exit;
+	if (flags & RTW_CMDF_DIRECTLY) {
+		free_assoc_resources_hdl(padapter, lock_scanned_queue);
 	}
+	else {
+		cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (cmd == NULL) {
+			res = _FAIL;
+			goto exit;
+		}
 
-	pdrvextra_cmd_parm->ec_id = FREE_ASSOC_RESOURCES;
-	pdrvextra_cmd_parm->type = 0;
-	pdrvextra_cmd_parm->size = 0;
-	pdrvextra_cmd_parm->pbuf = NULL;
+		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (pdrvextra_cmd_parm == NULL) {
+			rtw_mfree((unsigned char *)cmd, sizeof(struct cmd_obj));
+			res = _FAIL;
+			goto exit;
+		}
 
-	init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+		pdrvextra_cmd_parm->ec_id = FREE_ASSOC_RESOURCES;
+		pdrvextra_cmd_parm->type = lock_scanned_queue;
+		pdrvextra_cmd_parm->size = 0;
+		pdrvextra_cmd_parm->pbuf = NULL;
 
+		init_h2fwcmd_w_parm_no_rsp(cmd, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+		if (flags & RTW_CMDF_WAIT_ACK) {
+			cmd->sctx = &sctx;
+			rtw_sctx_init(&sctx, 2000);
+		}
 
-	/* rtw_enqueue_cmd(pcmdpriv, ph2c);	 */
-	res = rtw_enqueue_cmd(pcmdpriv, ph2c);
+		res = rtw_enqueue_cmd(pcmdpriv, cmd);
 
+		if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmd->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+		}
+	}
 exit:
-
-
 	return res;
 
 }
@@ -2136,7 +2195,6 @@ u8 _rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, const struct cou
 	struct cmd_obj *cmdobj;
 	struct	SetChannelPlan_param *parm;
 	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
-	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct submit_ctx sctx;
 	u8 res = _SUCCESS;
 
@@ -2195,12 +2253,29 @@ u8 _rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, const struct cou
 			if (sctx.status == RTW_SCTX_SUBMITTED)
 				cmdobj->sctx = NULL;
 			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status != RTW_SCTX_DONE_SUCCESS)
+				res = _FAIL;
 		}
-	}
 
-exit:
+		/* allow set channel plan when cmd_thread is not running */
+		if (res != _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
+			parm = (struct SetChannelPlan_param *)rtw_zmalloc(sizeof(*parm));
+			if (parm == NULL) {
+				res = _FAIL;
+				goto exit;
+			}
+			parm->country_ent = country_ent;
+			parm->channel_plan = chplan;
 
+			if (H2C_SUCCESS != set_chplan_hdl(adapter, (u8 *)parm))
+				res = _FAIL;
+			else
+				res = _SUCCESS;
+			rtw_mfree((u8 *)parm, sizeof(*parm));
+		}
+	}
 
+exit:
 	return res;
 }
 
@@ -2266,54 +2341,34 @@ exit:
 	return res;
 }
 
-u8 rtw_set_csa_cmd(_adapter *padapter, u8 new_ch_no)
+u8 rtw_set_csa_cmd(_adapter *adapter)
 {
-	struct	cmd_obj	*pcmdobj;
-	struct	SetChannelSwitch_param *setChannelSwitch_param;
-	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct	cmd_priv   *pcmdpriv = &padapter->cmdpriv;
-
+	struct cmd_obj *cmdobj;
+	struct cmd_priv *cmdpriv = &adapter->cmdpriv;
 	u8	res = _SUCCESS;
 
-
-
-	pcmdobj = (struct	cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
-	if (pcmdobj == NULL) {
-		res = _FAIL;
-		goto exit;
-	}
-
-	setChannelSwitch_param = (struct SetChannelSwitch_param *)rtw_zmalloc(sizeof(struct	SetChannelSwitch_param));
-	if (setChannelSwitch_param == NULL) {
-		rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
+	cmdobj = rtw_zmalloc(sizeof(struct cmd_obj));
+	if (cmdobj == NULL) {
 		res = _FAIL;
 		goto exit;
 	}
 
-	setChannelSwitch_param->new_ch_no = new_ch_no;
-
-	init_h2fwcmd_w_parm_no_rsp(pcmdobj, setChannelSwitch_param, GEN_CMD_CODE(_SetChannelSwitch));
-	res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
+	init_h2fwcmd_w_parm_no_parm_rsp(cmdobj, GEN_CMD_CODE(_SetChannelSwitch));
+	res = rtw_enqueue_cmd(cmdpriv, cmdobj);
 
 exit:
-
-
 	return res;
 }
 
 u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option)
 {
+	u8 res = _SUCCESS;
+#ifdef CONFIG_TDLS
 	struct	cmd_obj	*pcmdobj;
 	struct	TDLSoption_param	*TDLSoption;
 	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct	cmd_priv   *pcmdpriv = &padapter->cmdpriv;
 
-	u8	res = _SUCCESS;
-
-
-#ifdef CONFIG_TDLS
-
-
 	pcmdobj = (struct	cmd_obj *)rtw_zmalloc(sizeof(struct	cmd_obj));
 	if (pcmdobj == NULL) {
 		res = _FAIL;
@@ -2335,11 +2390,8 @@ u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option)
 	init_h2fwcmd_w_parm_no_rsp(pcmdobj, TDLSoption, GEN_CMD_CODE(_TDLS));
 	res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
 
-#endif /* CONFIG_TDLS */
-
 exit:
-
-
+#endif /* CONFIG_TDLS */
 
 	return res;
 }
@@ -2378,6 +2430,600 @@ exit:
 	return res;
 }
 
+u8 rtw_periodic_tsf_update_end_cmd(_adapter *adapter)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *parm;
+	struct cmd_priv *cmdpriv = &adapter->cmdpriv;
+	u8 res = _SUCCESS;
+
+	cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (cmdobj == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (parm == NULL) {
+		rtw_mfree((unsigned char *)cmdobj, sizeof(struct cmd_obj));
+		res = _FAIL;
+		goto exit;
+	}
+
+	parm->ec_id = PERIOD_TSF_UPDATE_END_WK_CID;
+	parm->type = 0;
+	parm->size = 0;
+	parm->pbuf = NULL;
+
+	init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+	res = rtw_enqueue_cmd(cmdpriv, cmdobj);
+
+exit:
+	return res;
+}
+u8 rtw_ssmps_wk_hdl(_adapter *adapter, struct ssmps_cmd_parm *ssmp_param)
+{
+	u8 res = _SUCCESS;
+	struct sta_info *sta = ssmp_param->sta;
+	u8 smps = ssmp_param->smps;
+
+	if (sta == NULL)
+		return _FALSE;
+
+	if (smps)
+		rtw_ssmps_enter(adapter, sta);
+	else
+		rtw_ssmps_leave(adapter, sta);
+	return res;
+}
+
+u8 rtw_ssmps_wk_cmd(_adapter *adapter, struct sta_info *sta, u8 smps, u8 enqueue)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *cmd_parm;
+	struct ssmps_cmd_parm *ssmp_param;
+	struct cmd_priv	*pcmdpriv = &adapter->cmdpriv;
+	u8	res = _SUCCESS;
+
+	if (enqueue) {
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (cmdobj == NULL) {
+			res = _FAIL;
+			goto exit;
+		}
+
+		cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (cmd_parm == NULL) {
+			rtw_mfree((unsigned char *)cmdobj, sizeof(struct cmd_obj));
+			res = _FAIL;
+			goto exit;
+		}
+
+		ssmp_param = (struct ssmps_cmd_parm *)rtw_zmalloc(sizeof(struct ssmps_cmd_parm));
+		if (ssmp_param == NULL) {
+			rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
+			rtw_mfree((u8 *)cmd_parm, sizeof(struct drvextra_cmd_parm));
+			res = _FAIL;
+			goto exit;
+		}
+
+		ssmp_param->smps = smps;
+		ssmp_param->sta = sta;
+
+		cmd_parm->ec_id = SSMPS_WK_CID;
+		cmd_parm->type = 0;
+		cmd_parm->size = sizeof(struct ssmps_cmd_parm);
+		cmd_parm->pbuf = (u8 *)ssmp_param;
+
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+	} else {
+		struct ssmps_cmd_parm tmp_ssmp_param;
+
+		tmp_ssmp_param.smps = smps;
+		tmp_ssmp_param.sta = sta;
+		rtw_ssmps_wk_hdl(adapter, &tmp_ssmp_param);
+	}
+
+exit:
+	return res;
+}
+
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+u8 _ssmps_chk_by_tp(_adapter *adapter, u8 from_timer)
+{
+	u8 enter_smps = _FALSE;
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *psta;
+	u32 tx_tp_mbits, rx_tp_mbits;
+
+	if (!MLME_IS_STA(adapter) ||
+		!hal_is_mimo_support(adapter) ||
+		!pmlmeext->ssmps_en ||
+		(pmlmeext->cur_channel > 14)
+	)
+		return enter_smps;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL) {
+		RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
+		rtw_warn_on(1);
+		return enter_smps;
+	}
+
+	if (psta->cmn.mimo_type == RF_1T1R)
+		return enter_smps;
+
+	tx_tp_mbits = psta->sta_stats.tx_tp_kbits >> 10;
+	rx_tp_mbits = psta->sta_stats.rx_tp_kbits >> 10;
+
+	#ifdef DBG_STATIC_SMPS
+	if (pmlmeext->ssmps_test) {
+		enter_smps = (pmlmeext->ssmps_test_en == 1) ? _TRUE : _FALSE;
+	}
+	else
+	#endif
+	{
+		if ((tx_tp_mbits <= pmlmeext->ssmps_tx_tp_th) &&
+			(rx_tp_mbits <= pmlmeext->ssmps_rx_tp_th))
+			enter_smps = _TRUE;
+		else
+			enter_smps = _FALSE;
+	}
+
+	if (1) {
+		RTW_INFO(FUNC_ADPT_FMT" tx_tp:%d [%d], rx_tp:%d [%d] , SSMPS enter :%s\n",
+			FUNC_ADPT_ARG(adapter),
+			tx_tp_mbits, pmlmeext->ssmps_tx_tp_th,
+			rx_tp_mbits, pmlmeext->ssmps_rx_tp_th,
+			(enter_smps == _TRUE) ? "True" : "False");
+		#ifdef DBG_STATIC_SMPS
+		RTW_INFO(FUNC_ADPT_FMT" test:%d test_en:%d\n",
+			FUNC_ADPT_ARG(adapter),
+			pmlmeext->ssmps_test,
+			pmlmeext->ssmps_test_en);
+		#endif
+	}
+
+	if (enter_smps) {
+		if (!from_timer && psta->cmn.sm_ps != SM_PS_STATIC)
+			rtw_ssmps_enter(adapter, psta);
+	} else {
+		if (!from_timer && psta->cmn.sm_ps != SM_PS_DISABLE)
+			rtw_ssmps_leave(adapter, psta);
+		else {
+			u8 ps_change = _FALSE;
+
+			if (enter_smps && psta->cmn.sm_ps != SM_PS_STATIC)
+				ps_change = _TRUE;
+			else if (!enter_smps && psta->cmn.sm_ps != SM_PS_DISABLE)
+				ps_change = _TRUE;
+
+			if (ps_change)
+				rtw_ssmps_wk_cmd(adapter, psta, enter_smps, 1);
+		}
+	}
+
+	return enter_smps;
+}
+#endif /*CONFIG_SUPPORT_STATIC_SMPS*/
+
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+void rtw_ctrl_txss_update_mimo_type(_adapter *adapter, struct sta_info *sta)
+{
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	pmlmeext->txss_momi_type_bk = sta->cmn.mimo_type;
+}
+
+u8 rtw_ctrl_txss(_adapter *adapter, struct sta_info *sta, u8 tx_1ss)
+{
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	enum bb_path txpath = BB_PATH_A | BB_PATH_B;
+	enum bb_path rxpath = BB_PATH_A | BB_PATH_B;
+	u8 tx2path = _FALSE;
+	u8 lps_changed = _FALSE;
+	u8 rst = _SUCCESS;
+
+	if (pmlmeext->txss_1ss == tx_1ss)
+		return _FALSE;
+
+	if (pwrpriv->bLeisurePs && pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
+		lps_changed = _TRUE;
+		LPS_Leave(adapter, "LPS_CTRL_TXSS");
+	}
+
+	RTW_INFO(ADPT_FMT" STA [" MAC_FMT "] set tx to %d ss\n",
+		ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr),
+		(tx_1ss) ? 1 : rtw_get_sta_tx_nss(adapter, sta));
+
+	/*ra re-registed*/
+	sta->cmn.mimo_type = (tx_1ss) ? RF_1T1R : pmlmeext->txss_momi_type_bk;
+	rtw_phydm_ra_registed(adapter, sta);
+
+	/*configure trx mode*/
+	rtw_hal_get_rf_path(adapter_to_dvobj(adapter), NULL, &txpath, &rxpath);
+	txpath = (tx_1ss) ? BB_PATH_A : txpath;
+	if (phydm_api_trx_mode(adapter_to_phydm(adapter), txpath, rxpath, tx2path) == FALSE)
+		rst = _FALSE;
+
+	pmlmeext->txss_1ss = tx_1ss;
+
+	if (lps_changed)
+		LPS_Enter(adapter, "LPS_CTRL_TXSS");
+
+	return rst;
+}
+
+u8 rtw_ctrl_txss_wk_hdl(_adapter *adapter, struct txss_cmd_parm *txss_param)
+{
+	if (!txss_param->sta)
+		return _FALSE;
+
+	return rtw_ctrl_txss(adapter, txss_param->sta, txss_param->tx_1ss);
+}
+
+u8 rtw_ctrl_txss_wk_cmd(_adapter *adapter, struct sta_info *sta, u8 tx_1ss, u8 flag)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *cmd_parm;
+	struct txss_cmd_parm *txss_param;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
+	u8	res = _SUCCESS;
+
+	txss_param = (struct txss_cmd_parm *)rtw_zmalloc(sizeof(struct txss_cmd_parm));
+	if (txss_param == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	txss_param->tx_1ss = tx_1ss;
+	txss_param->sta = sta;
+
+	if (flag & RTW_CMDF_DIRECTLY) {
+		res = rtw_ctrl_txss_wk_hdl(adapter, txss_param);
+		rtw_mfree((u8 *)txss_param, sizeof(*txss_param));
+	} else {
+		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		if (cmdobj == NULL) {
+			res = _FAIL;
+			goto exit;
+		}
+
+		cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (cmd_parm == NULL) {
+			rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
+			res = _FAIL;
+			goto exit;
+		}
+
+		cmd_parm->ec_id = TXSS_WK_CID;
+		cmd_parm->type = 0;
+		cmd_parm->size = sizeof(struct txss_cmd_parm);
+		cmd_parm->pbuf = (u8 *)txss_param;
+
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+		if (flag & RTW_CMDF_WAIT_ACK) {
+			cmdobj->sctx = &sctx;
+			rtw_sctx_init(&sctx, 10 * 1000);
+		}
+
+		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+		if (res == _SUCCESS && (flag & RTW_CMDF_WAIT_ACK)) {
+			rtw_sctx_wait(&sctx, __func__);
+			_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status == RTW_SCTX_SUBMITTED)
+				cmdobj->sctx = NULL;
+			_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
+			if (sctx.status != RTW_SCTX_DONE_SUCCESS)
+				res = _FAIL;
+		}
+	}
+
+exit:
+	return res;
+}
+
+void rtw_ctrl_tx_ss_by_tp(_adapter *adapter, u8 from_timer)
+{
+	u8 tx_1ss  = _FALSE; /*change tx from 2ss to 1ss*/
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *psta;
+	u32 tx_tp_mbits;
+
+	if (!MLME_IS_STA(adapter) ||
+		!hal_is_mimo_support(adapter) ||
+		!pmlmeext->txss_ctrl_en
+	)
+		return;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL) {
+		RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
+		rtw_warn_on(1);
+		return;
+	}
+
+	tx_tp_mbits = psta->sta_stats.tx_tp_kbits >> 10;
+	if (tx_tp_mbits >= pmlmeext->txss_tp_th) {
+		tx_1ss = _FALSE;
+	} else {
+		if (pmlmeext->txss_tp_chk_cnt && --pmlmeext->txss_tp_chk_cnt)
+			tx_1ss = _FALSE;
+		else
+			tx_1ss = _TRUE;
+	}
+
+	if (1) {
+		RTW_INFO(FUNC_ADPT_FMT" tx_tp:%d [%d] tx_1ss(%d):%s\n",
+			FUNC_ADPT_ARG(adapter),
+			tx_tp_mbits, pmlmeext->txss_tp_th,
+			pmlmeext->txss_tp_chk_cnt,
+			(tx_1ss == _TRUE) ? "True" : "False");
+	}
+
+	if (pmlmeext->txss_1ss != tx_1ss) {
+		if (from_timer)
+			rtw_ctrl_txss_wk_cmd(adapter, psta, tx_1ss, 0);
+		else
+			rtw_ctrl_txss(adapter, psta, tx_1ss);
+	}
+}
+#ifdef DBG_CTRL_TXSS
+void dbg_ctrl_txss(_adapter *adapter, u8 tx_1ss)
+{
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *psta;
+
+	if (!MLME_IS_STA(adapter) ||
+		!hal_is_mimo_support(adapter)
+	)
+		return;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL) {
+		RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
+		rtw_warn_on(1);
+		return;
+	}
+
+	rtw_ctrl_txss(adapter, psta, tx_1ss);
+}
+#endif
+#endif /*CONFIG_CTRL_TXSS_BY_TP*/
+
+#ifdef CONFIG_LPS
+#ifdef CONFIG_LPS_CHK_BY_TP
+#ifdef LPS_BCN_CNT_MONITOR
+static u8 _bcn_cnt_expected(struct sta_info *psta)
+{
+	_adapter *adapter = psta->padapter;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8 dtim = rtw_get_bcn_dtim_period(adapter);
+	u8 bcn_cnt = 0;
+
+	if ((pmlmeinfo->bcn_interval !=0) && (dtim != 0))
+		bcn_cnt = 2000 / pmlmeinfo->bcn_interval / dtim * 4 / 5; /*2s*/
+	if (0)
+		RTW_INFO("%s bcn_cnt:%d\n", bcn_cnt);
+
+	if (bcn_cnt == 0) {
+		RTW_ERR(FUNC_ADPT_FMT" bcn_cnt == 0\n", FUNC_ADPT_ARG(adapter));
+		rtw_warn_on(1);
+	}
+
+	return bcn_cnt;
+}
+#endif
+u8 _lps_chk_by_tp(_adapter *adapter, u8 from_timer)
+{
+	u8 enter_ps = _FALSE;
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *psta;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	u32 tx_tp_mbits, rx_tp_mbits, bi_tp_mbits;
+	u8 rx_bcn_cnt;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+	if (psta == NULL) {
+		RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
+		rtw_warn_on(1);
+		return enter_ps;
+	}
+
+	rx_bcn_cnt = rtw_get_bcn_cnt(psta->padapter);
+	psta->sta_stats.acc_tx_bytes = psta->sta_stats.tx_bytes;
+	psta->sta_stats.acc_rx_bytes = psta->sta_stats.rx_bytes;
+
+#if 1
+	tx_tp_mbits = psta->sta_stats.tx_tp_kbits >> 10;
+	rx_tp_mbits = psta->sta_stats.rx_tp_kbits >> 10;
+	bi_tp_mbits = tx_tp_mbits + rx_tp_mbits;
+#else
+	tx_tp_mbits = psta->sta_stats.smooth_tx_tp_kbits >> 10;
+	rx_tp_mbits = psta->sta_stats.smooth_rx_tp_kbits >> 10;
+	bi_tp_mbits = tx_tp_mbits + rx_tp_mbits;
+#endif
+
+	if ((bi_tp_mbits >= pwrpriv->lps_bi_tp_th) ||
+		(tx_tp_mbits >= pwrpriv->lps_tx_tp_th) ||
+		(rx_tp_mbits >= pwrpriv->lps_rx_tp_th)) {
+		enter_ps = _FALSE;
+		pwrpriv->lps_chk_cnt = pwrpriv->lps_chk_cnt_th;
+	}
+	else {
+#ifdef LPS_BCN_CNT_MONITOR
+		u8 bcn_cnt = _bcn_cnt_expected(psta);
+
+		if (bcn_cnt && (rx_bcn_cnt < bcn_cnt)) {
+			pwrpriv->lps_chk_cnt = 2;
+			RTW_ERR(FUNC_ADPT_FMT" BCN_CNT:%d(%d) invalid\n",
+				FUNC_ADPT_ARG(adapter), rx_bcn_cnt, bcn_cnt);
+		}
+#endif
+
+		if (pwrpriv->lps_chk_cnt && --pwrpriv->lps_chk_cnt)
+			enter_ps = _FALSE;
+		else
+			enter_ps = _TRUE;
+	}
+
+	if (1) {
+		RTW_INFO(FUNC_ADPT_FMT" tx_tp:%d [%d], rx_tp:%d [%d], bi_tp:%d [%d], enter_ps(%d):%s\n",
+			FUNC_ADPT_ARG(adapter),
+			tx_tp_mbits, pwrpriv->lps_tx_tp_th,
+			rx_tp_mbits, pwrpriv->lps_rx_tp_th,
+			bi_tp_mbits, pwrpriv->lps_bi_tp_th,
+			pwrpriv->lps_chk_cnt,
+			(enter_ps == _TRUE) ? "True" : "False");
+		RTW_INFO(FUNC_ADPT_FMT" tx_pkt_cnt :%d [%d], rx_pkt_cnt :%d [%d]\n",
+			FUNC_ADPT_ARG(adapter),
+			pmlmepriv->LinkDetectInfo.NumTxOkInPeriod,
+			pwrpriv->lps_tx_pkts,
+			pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod,
+			pwrpriv->lps_rx_pkts);
+		if (!adapter->bsta_tp_dump)
+			RTW_INFO(FUNC_ADPT_FMT" bcn_cnt:%d (per-%d second)\n",
+			FUNC_ADPT_ARG(adapter),
+			rx_bcn_cnt,
+			2);
+	}
+
+	if (enter_ps) {
+		if (!from_timer)
+			LPS_Enter(adapter, "TRAFFIC_IDLE");
+	} else {
+		if (!from_timer)
+			LPS_Leave(adapter, "TRAFFIC_BUSY");
+		else {
+			#ifdef CONFIG_CONCURRENT_MODE
+			#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
+			if (adapter->hw_port == HW_PORT0)
+			#endif
+			#endif
+				rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_TRAFFIC_BUSY, 1);
+		}
+	}
+
+	return enter_ps;
+}
+#endif
+
+static u8 _lps_chk_by_pkt_cnts(_adapter *padapter, u8 from_timer, u8 bBusyTraffic)
+{		
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u8	bEnterPS = _FALSE;
+
+	/* check traffic for  powersaving. */
+	if (((pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod + pmlmepriv->LinkDetectInfo.NumTxOkInPeriod) > 8) ||
+		#ifdef CONFIG_LPS_SLOW_TRANSITION
+		(pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 2)
+		#else /* CONFIG_LPS_SLOW_TRANSITION */
+		(pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4)
+		#endif /* CONFIG_LPS_SLOW_TRANSITION */
+	) {
+		#ifdef DBG_RX_COUNTER_DUMP
+		if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
+			RTW_INFO("(-)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
+		#endif
+
+		bEnterPS = _FALSE;
+		#ifdef CONFIG_LPS_SLOW_TRANSITION
+		if (bBusyTraffic == _TRUE) {
+			if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount <= 4)
+				pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 4;
+
+			pmlmepriv->LinkDetectInfo.TrafficTransitionCount++;
+
+			/* RTW_INFO("Set TrafficTransitionCount to %d\n", pmlmepriv->LinkDetectInfo.TrafficTransitionCount); */
+
+			if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount > 30/*TrafficTransitionLevel*/)
+				pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 30;
+		}
+		#endif /* CONFIG_LPS_SLOW_TRANSITION */
+	} else {
+		#ifdef DBG_RX_COUNTER_DUMP
+		if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
+			RTW_INFO("(+)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
+		#endif
+
+		#ifdef CONFIG_LPS_SLOW_TRANSITION
+		if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount >= 2)
+			pmlmepriv->LinkDetectInfo.TrafficTransitionCount -= 2;
+		else
+			pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
+
+		if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount == 0)
+			bEnterPS = _TRUE;
+		#else /* CONFIG_LPS_SLOW_TRANSITION */
+			bEnterPS = _TRUE;
+		#endif /* CONFIG_LPS_SLOW_TRANSITION */
+	}
+
+	#ifdef CONFIG_DYNAMIC_DTIM
+	if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount == 8)
+		bEnterPS = _FALSE;
+
+	RTW_INFO("LowPowerTransitionCount=%d\n", pmlmepriv->LinkDetectInfo.LowPowerTransitionCount);
+	#endif /* CONFIG_DYNAMIC_DTIM */
+
+	/* LeisurePS only work in infra mode. */
+	if (bEnterPS) {
+		if (!from_timer) {
+			#ifdef CONFIG_DYNAMIC_DTIM
+			if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount < 8)
+				adapter_to_pwrctl(padapter)->dtim = 1;
+			else
+				adapter_to_pwrctl(padapter)->dtim = 3;
+			#endif /* CONFIG_DYNAMIC_DTIM */
+			LPS_Enter(padapter, "TRAFFIC_IDLE");
+		} else {
+			/* do this at caller */
+			/* rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 1); */
+			/* rtw_hal_dm_watchdog_in_lps(padapter); */
+		}
+
+		#ifdef CONFIG_DYNAMIC_DTIM
+		if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
+			pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
+		#endif /* CONFIG_DYNAMIC_DTIM */
+	} else {
+		#ifdef CONFIG_DYNAMIC_DTIM
+		if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount != 8)
+			pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
+		else
+			pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
+		#endif /* CONFIG_DYNAMIC_DTIM */
+
+		if (!from_timer)
+			LPS_Leave(padapter, "TRAFFIC_BUSY");
+		else {
+			#ifdef CONFIG_CONCURRENT_MODE
+			#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
+			if (padapter->hw_port == HW_PORT0)
+			#endif
+			#endif
+				rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_TRAFFIC_BUSY, 1);
+		}
+	}
+
+	return bEnterPS;
+}
+#endif /* CONFIG_LPS */
+
 /* from_timer == 1 means driver is in LPS */
 u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 {
@@ -2394,8 +3040,9 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 	struct tdls_txmgmt txmgmt;
 	u8 baddr[ETH_ALEN] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
 #endif /* CONFIG_TDLS */
-
+#ifdef CONFIG_TRAFFIC_PROTECT
 	RT_LINK_DETECT_T *link_detect = &pmlmepriv->LinkDetectInfo;
+#endif
 
 #ifdef CONFIG_BT_COEXIST
 	if (padapter->registrypriv.wifi_spec != 1) {
@@ -2471,110 +3118,27 @@ u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
 #endif /* CONFIG_TDLS_AUTOSETUP */
 #endif /* CONFIG_TDLS */
 
-#ifdef CONFIG_LPS
-		/* check traffic for  powersaving. */
-		if (((pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod + pmlmepriv->LinkDetectInfo.NumTxOkInPeriod) > 8) ||
-#ifdef CONFIG_LPS_SLOW_TRANSITION
-		    (pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 2)
-#else /* CONFIG_LPS_SLOW_TRANSITION */
-		    (pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4)
-#endif /* CONFIG_LPS_SLOW_TRANSITION */
-		   ) {
-#ifdef DBG_RX_COUNTER_DUMP
-			if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
-				RTW_INFO("(-)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+		_ssmps_chk_by_tp(padapter, from_timer);
 #endif
-			bEnterPS = _FALSE;
-#ifdef CONFIG_LPS_SLOW_TRANSITION
-			if (bBusyTraffic == _TRUE) {
-				if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount <= 4)
-					pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 4;
-
-				pmlmepriv->LinkDetectInfo.TrafficTransitionCount++;
-
-				/* RTW_INFO("Set TrafficTransitionCount to %d\n", pmlmepriv->LinkDetectInfo.TrafficTransitionCount); */
-
-				if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount > 30/*TrafficTransitionLevel*/)
-					pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 30;
-			}
-#endif /* CONFIG_LPS_SLOW_TRANSITION */
-
-		} else {
-#ifdef DBG_RX_COUNTER_DUMP
-			if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
-				RTW_INFO("(+)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+		rtw_ctrl_tx_ss_by_tp(padapter, from_timer);
 #endif
-#ifdef CONFIG_LPS_SLOW_TRANSITION
-			if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount >= 2)
-				pmlmepriv->LinkDetectInfo.TrafficTransitionCount -= 2;
-			else
-				pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
-
-			if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount == 0)
-				bEnterPS = _TRUE;
-#else /* CONFIG_LPS_SLOW_TRANSITION */
-			bEnterPS = _TRUE;
-#endif /* CONFIG_LPS_SLOW_TRANSITION */
-		}
 
-#ifdef CONFIG_DYNAMIC_DTIM
-		if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount == 8)
-			bEnterPS = _FALSE;
-
-		RTW_INFO("LowPowerTransitionCount=%d\n", pmlmepriv->LinkDetectInfo.LowPowerTransitionCount);
-#endif /* CONFIG_DYNAMIC_DTIM */
-
-		/* LeisurePS only work in infra mode. */
-		if (bEnterPS) {
-			if (!from_timer) {
-#ifdef CONFIG_DYNAMIC_DTIM
-				if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount < 8)
-					adapter_to_pwrctl(padapter)->dtim = 1;
-				else
-					adapter_to_pwrctl(padapter)->dtim = 3;
-#endif /* CONFIG_DYNAMIC_DTIM */
-				LPS_Enter(padapter, "TRAFFIC_IDLE");
-			} else {
-				/* do this at caller */
-				/* rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 1); */
-				/* rtw_hal_dm_watchdog_in_lps(padapter); */
-			}
-#ifdef CONFIG_DYNAMIC_DTIM
-			if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
-				pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
-#endif /* CONFIG_DYNAMIC_DTIM */
-		} else {
-#ifdef CONFIG_DYNAMIC_DTIM
-			if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount != 8)
-				pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
+#ifdef CONFIG_LPS
+		if (adapter_to_pwrctl(padapter)->bLeisurePs && MLME_IS_STA(padapter)) {
+			#ifdef CONFIG_LPS_CHK_BY_TP
+			if (adapter_to_pwrctl(padapter)->lps_chk_by_tp)
+				bEnterPS = _lps_chk_by_tp(padapter, from_timer);
 			else
-				pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
-#endif /* CONFIG_DYNAMIC_DTIM			 */
-			if (!from_timer)
-				LPS_Leave(padapter, "TRAFFIC_BUSY");
-			else {
-#ifdef CONFIG_CONCURRENT_MODE
-				#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
-				if (padapter->hw_port == HW_PORT0)
-				#endif
-#endif
-					rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_TRAFFIC_BUSY, 1);
-			}
+			#endif /*CONFIG_LPS_CHK_BY_TP*/
+				bEnterPS = _lps_chk_by_pkt_cnts(padapter, from_timer, bBusyTraffic);
 		}
-
 #endif /* CONFIG_LPS */
+
 	} else {
 #ifdef CONFIG_LPS
-		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-		int n_assoc_iface = 0;
-		int i;
-
-		for (i = 0; i < dvobj->iface_nums; i++) {
-			if (check_fwstate(&(dvobj->padapters[i]->mlmepriv), WIFI_ASOC_STATE))
-				n_assoc_iface++;
-		}
-
-		if (!from_timer && n_assoc_iface == 0)
+		if (!from_timer && rtw_mi_get_assoc_if_num(padapter) == 0)
 			LPS_Leave(padapter, "NON_LINKED");
 #endif
 	}
@@ -2611,6 +3175,9 @@ static void dynamic_update_bcn_check(_adapter *padapter)
 	if (!padapter->registrypriv.wifi_spec)
 		return;
 
+	if (!padapter->registrypriv.ht_enable || !is_supported_ht(padapter->registrypriv.wireless_mode))
+		return;
+
 	if (!MLME_IS_AP(padapter))
 		return;
 
@@ -2620,7 +3187,7 @@ static void dynamic_update_bcn_check(_adapter *padapter)
 
 		if (count % 10 == 0) {
 			count = 1;
-
+#ifdef CONFIG_80211N_HT
 			if (_FALSE == ATOMIC_READ(&pmlmepriv->olbc)
 				&& _FALSE == ATOMIC_READ(&pmlmepriv->olbc_ht)) {
 
@@ -2629,8 +3196,10 @@ static void dynamic_update_bcn_check(_adapter *padapter)
 					update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE);
 				}
 			}
+#endif /* CONFIG_80211N_HT */
 		}
 
+#ifdef CONFIG_80211N_HT
 		/* In 2s, there are any legacy AP, update HT info, and then reset count  */
 
 		if (_FALSE != ATOMIC_READ(&pmlmepriv->olbc)
@@ -2645,18 +3214,21 @@ static void dynamic_update_bcn_check(_adapter *padapter)
 			ATOMIC_SET(&pmlmepriv->olbc_ht, _FALSE);
 			count = 0;
 		}
-
+#endif /* CONFIG_80211N_HT */
 		count ++;
 	}
 }
 void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter)
 {
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-
 	#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
 	#ifdef CONFIG_AP_MODE
-	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter))
+	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
 		expire_timeout_chk(padapter);
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter) && MLME_IS_ASOC(padapter))
+			rtw_mesh_peer_status_chk(padapter);
+		#endif
+	}
 	#endif
 	#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
 	dynamic_update_bcn_check(padapter);
@@ -2675,6 +3247,11 @@ void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter)
 	#endif /* !RTW_BEAMFORMING_VERSION_2 */
 	#endif
 
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+        rtw_cfgvendor_rssi_monitor_evt(padapter);
+#endif
+
+
 }
 void rtw_dynamic_chk_wk_hdl(_adapter *padapter)
 {
@@ -2710,6 +3287,7 @@ void rtw_dynamic_chk_wk_hdl(_adapter *padapter)
 	rtw_hal_mcc_sw_status_check(padapter);
 #endif /* CONFIG_MCC_MODE */
 
+	rtw_hal_periodic_tsf_update_chk(padapter);
 }
 
 #ifdef CONFIG_LPS
@@ -3109,11 +3687,6 @@ void reset_securitypriv_hdl(_adapter *padapter)
 	rtw_reset_securitypriv(padapter);
 }
 
-void free_assoc_resources_hdl(_adapter *padapter)
-{
-	rtw_free_assoc_resources(padapter, 1);
-}
-
 #ifdef CONFIG_P2P
 u8 p2p_protocol_wk_cmd(_adapter *padapter, int intCmdType)
 {
@@ -3252,6 +3825,10 @@ inline u8 p2p_cancel_roch_cmd(_adapter *adapter, u64 cookie, struct wireless_dev
 	return _p2p_roch_cmd(adapter, cookie, wdev, NULL, 0, 0, flags);
 }
 
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_IOCTL_CFG80211 
 inline u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack, u8 flags)
 {
 	struct cmd_obj *cmdobj;
@@ -3323,9 +3900,7 @@ inline u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf,
 exit:
 	return res;
 }
-
-#endif /* CONFIG_IOCTL_CFG80211 */
-#endif /* CONFIG_P2P */
+#endif
 
 u8 rtw_ps_cmd(_adapter *padapter)
 {
@@ -3336,7 +3911,7 @@ u8 rtw_ps_cmd(_adapter *padapter)
 	u8	res = _SUCCESS;
 
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
+	if (!is_primary_adapter(padapter))
 		goto exit;
 #endif
 
@@ -3368,6 +3943,96 @@ exit:
 
 }
 
+#ifdef CONFIG_DFS
+void rtw_dfs_ch_switch_hdl(struct dvobj_priv *dvobj)
+{
+	struct rf_ctl_t *rfctl = dvobj_to_rfctl(dvobj);
+	_adapter *pri_adapter = dvobj_get_primary_adapter(dvobj);
+	u8 ifbmp_m = rtw_mi_get_ap_mesh_ifbmp(pri_adapter);
+	u8 ifbmp_s = rtw_mi_get_ld_sta_ifbmp(pri_adapter);
+	s16 req_ch;
+
+	rtw_hal_macid_sleep_all_used(pri_adapter);
+
+	if (rtw_chset_search_ch(rfctl->channel_set, rfctl->csa_ch) >= 0
+		&& !rtw_chset_is_ch_non_ocp(rfctl->channel_set, rfctl->csa_ch)
+	) {
+		/* CSA channel available and valid */
+		req_ch = rfctl->csa_ch;
+		RTW_INFO("%s valid CSA ch%u\n", __func__, rfctl->csa_ch);
+	} else if (ifbmp_m) {
+		/* no available or valid CSA channel, having AP/MESH ifaces */
+		req_ch = REQ_CH_NONE;
+		RTW_INFO("%s ch sel by AP/MESH ifaces\n", __func__);
+	} else {
+		/* no available or valid CSA channel and no AP/MESH ifaces */
+		if (!IsSupported24G(dvobj_to_regsty(dvobj)->wireless_mode)
+			#ifdef CONFIG_DFS_MASTER
+			|| rfctl->radar_detected
+			#endif
+		)
+			req_ch = 36;
+		else
+			req_ch = 1;
+		RTW_INFO("%s switch to ch%d\n", __func__, req_ch);
+	}
+
+	/*  issue deauth for all asoc STA ifaces */
+	if (ifbmp_s) {
+		_adapter *iface;
+		int i;
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface || !(ifbmp_s & BIT(iface->iface_id)))
+				continue;
+			set_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING);
+
+			/* TODO: true op ch switching */
+			issue_deauth(iface, get_bssid(&iface->mlmepriv), WLAN_REASON_DEAUTH_LEAVING);
+		}
+	}
+
+#ifdef CONFIG_AP_MODE
+	if (ifbmp_m) {
+		/* trigger channel selection without consideraton of asoc STA ifaces */
+		rtw_change_bss_chbw_cmd(dvobj_get_primary_adapter(dvobj), RTW_CMDF_DIRECTLY
+			, ifbmp_m, ifbmp_s, req_ch, REQ_BW_ORI, REQ_OFFSET_NONE);
+	} else
+#endif
+	{
+		/* no AP/MESH iface, switch DFS status and channel directly */
+		rtw_warn_on(req_ch <= 0);
+		#ifdef CONFIG_DFS_MASTER
+		rtw_dfs_rd_en_decision(pri_adapter, MLME_OPCH_SWITCH, ifbmp_s);
+		#endif
+		set_channel_bwmode(pri_adapter, req_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+	}
+
+	/* make asoc STA ifaces disconnect */
+	/* TODO: true op ch switching */
+	if (ifbmp_s) {
+		_adapter *iface;
+		int i;
+	
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (!iface || !(ifbmp_s & BIT(iface->iface_id)))
+				continue;
+			rtw_disassoc_cmd(iface, 0, RTW_CMDF_DIRECTLY);
+			rtw_indicate_disconnect(iface, 0, _FALSE);
+			rtw_free_assoc_resources(iface, _TRUE);
+			rtw_free_network_queue(iface, _TRUE);
+		}
+	}
+
+	rfctl->csa_ch = 0;
+
+	rtw_hal_macid_wakeup_all_used(pri_adapter);
+	rtw_mi_os_xmit_schedule(pri_adapter);
+}
+#endif /* CONFIG_DFS */
+
 #ifdef CONFIG_AP_MODE
 
 static void rtw_chk_hi_queue_hdl(_adapter *padapter)
@@ -3392,11 +4057,11 @@ static void rtw_chk_hi_queue_hdl(_adapter *padapter)
 		if (empty == _SUCCESS) {
 			bool update_tim = _FALSE;
 
-			if (pstapriv->tim_bitmap & BIT(0))
+			if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0))
 				update_tim = _TRUE;
 
-			pstapriv->tim_bitmap &= ~BIT(0);
-			pstapriv->sta_dz_bitmap &= ~BIT(0);
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
 
 			if (update_tim == _TRUE)
 				_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "bmc sleepq and HIQ empty");
@@ -3443,18 +4108,18 @@ exit:
 }
 
 #ifdef CONFIG_DFS_MASTER
-u8 rtw_dfs_master_hdl(_adapter *adapter)
+u8 rtw_dfs_rd_hdl(_adapter *adapter)
 {
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-	struct mlme_priv *mlme = &adapter->mlmepriv;
 
-	if (!rfctl->dfs_master_enabled)
+	if (!rfctl->radar_detect_enabled)
 		goto exit;
 
-	if (rtw_get_on_cur_ch_time(adapter) == 0
-		|| rtw_get_passing_time_ms(rtw_get_on_cur_ch_time(adapter)) < 300
+	if (dvobj->oper_channel != rfctl->radar_detect_ch
+		|| rtw_get_passing_time_ms(rtw_get_on_oper_ch_time(adapter)) < 300
 	) {
-		/* offchannel , bypass radar detect */
+		/* offchannel, bypass radar detect */
 		goto cac_status_chk;
 	}
 
@@ -3463,98 +4128,102 @@ u8 rtw_dfs_master_hdl(_adapter *adapter)
 		goto cac_status_chk;
 	}
 
-	if (!rfctl->dbg_dfs_master_fake_radar_detect_cnt
+	if (!rfctl->dbg_dfs_fake_radar_detect_cnt
 		&& rtw_odm_radar_detect(adapter) != _TRUE)
 		goto cac_status_chk;
 
-	if (rfctl->dbg_dfs_master_fake_radar_detect_cnt != 0) {
-		RTW_INFO(FUNC_ADPT_FMT" fake radar detect, cnt:%d\n", FUNC_ADPT_ARG(adapter)
-			, rfctl->dbg_dfs_master_fake_radar_detect_cnt);
-		rfctl->dbg_dfs_master_fake_radar_detect_cnt--;
+	if (!rfctl->dbg_dfs_fake_radar_detect_cnt
+		&& rfctl->dbg_dfs_radar_detect_trigger_non
+	) {
+		/* radar detect debug mode, trigger no mlme flow */
+		RTW_INFO("%s radar detected on test mode, trigger no mlme flow\n", __func__);
+		goto cac_status_chk;
 	}
 
-	if (rfctl->dbg_dfs_master_radar_detect_trigger_non) {
-		/* radar detect debug mode, trigger no mlme flow */
-		if (0)
-			RTW_INFO(FUNC_ADPT_FMT" radar detected, trigger no mlme flow for debug\n", FUNC_ADPT_ARG(adapter));
-	} else {
-		/* TODO: move timer to rfctl */
-		struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-		int i;
+	if (rfctl->dbg_dfs_fake_radar_detect_cnt != 0) {
+		RTW_INFO("%s fake radar detected, cnt:%d\n", __func__
+			, rfctl->dbg_dfs_fake_radar_detect_cnt);
+		rfctl->dbg_dfs_fake_radar_detect_cnt--;
+	} else
+		RTW_INFO("%s radar detected\n", __func__);
 
-		for (i = 0; i < dvobj->iface_nums; i++) {
-			if (!dvobj->padapters[i])
-				continue;
-			if (check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE)
-				&& check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_ASOC_STATE))
-				break;
-		}
+	rfctl->radar_detected = 1;
 
-		if (i >= dvobj->iface_nums) {
-			/* what? */
-			rtw_warn_on(1);
-		} else {
-			rtw_chset_update_non_ocp(rfctl->channel_set
-				, rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
-			rfctl->radar_detected = 1;
+	rtw_chset_update_non_ocp(rfctl->channel_set
+		, rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
 
-			/* trigger channel selection */
-			rtw_change_bss_chbw_cmd(dvobj->padapters[i], RTW_CMDF_DIRECTLY, -1, dvobj->padapters[i]->mlmepriv.ori_bw, -1);
-		}
+	rtw_dfs_ch_switch_hdl(dvobj);
 
-		if (rfctl->dfs_master_enabled)
-			goto set_timer;
-		goto exit;
-	}
+	if (rfctl->radar_detect_enabled)
+		goto set_timer;
+	goto exit;
 
 cac_status_chk:
 
-	if (!IS_CH_WAITING(rfctl) && !IS_CAC_STOPPED(rfctl)) {
+	if (!IS_CAC_STOPPED(rfctl)
+		&& ((IS_UNDER_CAC(rfctl) && rfctl->cac_force_stop)
+			|| !IS_CH_WAITING(rfctl)
+			)
+	) {
 		u8 pause = 0x00;
 
 		rtw_hal_set_hwreg(adapter, HW_VAR_TXPAUSE, &pause);
 		rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
 
 		if (rtw_mi_check_fwstate(adapter, WIFI_UNDER_LINKING|WIFI_SITE_MONITOR) == _FALSE) {
+			u8 doiqk = _TRUE;
+			u8 u_ch, u_bw, u_offset;
+
+			rtw_hal_set_hwreg(adapter , HW_VAR_DO_IQK , &doiqk);
+
+			if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset))
+				set_channel_bwmode(adapter, u_ch, u_offset, u_bw);
+			else
+				rtw_warn_on(1);
+
+			doiqk = _FALSE;
+			rtw_hal_set_hwreg(adapter , HW_VAR_DO_IQK , &doiqk);
+
 			ResumeTxBeacon(adapter);
 			rtw_mi_tx_beacon_hdl(adapter);
 		}
 	}
 
 set_timer:
-	_set_timer(&mlme->dfs_master_timer, DFS_MASTER_TIMER_MS);
+	_set_timer(&rfctl->radar_detect_timer
+		, rtw_odm_radar_detect_polling_int_ms(dvobj));
 
 exit:
 	return H2C_SUCCESS;
 }
 
-u8 rtw_dfs_master_cmd(_adapter *adapter, bool enqueue)
+u8 rtw_dfs_rd_cmd(_adapter *adapter, bool enqueue)
 {
 	struct cmd_obj *cmdobj;
-	struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct drvextra_cmd_parm *parm;
+	struct cmd_priv *cmdpriv = &adapter->cmdpriv;
 	u8 res = _FAIL;
 
 	if (enqueue) {
-		cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+		cmdobj = rtw_zmalloc(sizeof(struct cmd_obj));
 		if (cmdobj == NULL)
 			goto exit;
 
-		pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
-		if (pdrvextra_cmd_parm == NULL) {
-			rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
+		parm = rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+		if (parm == NULL) {
+			rtw_mfree(cmdobj, sizeof(struct cmd_obj));
 			goto exit;
 		}
 
-		pdrvextra_cmd_parm->ec_id = DFS_MASTER_WK_CID;
-		pdrvextra_cmd_parm->type = 0;
-		pdrvextra_cmd_parm->size = 0;
-		pdrvextra_cmd_parm->pbuf = NULL;
+		parm->ec_id = DFS_RADAR_DETECT_WK_CID;
+		parm->type = 0;
+		parm->size = 0;
+		parm->pbuf = NULL;
 
-		init_h2fwcmd_w_parm_no_rsp(cmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
-		res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+		init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
+		res = rtw_enqueue_cmd(cmdpriv, cmdobj);
 	} else {
-		rtw_dfs_master_hdl(adapter);
+		rtw_dfs_rd_hdl(adapter);
 		res = _SUCCESS;
 	}
 
@@ -3562,24 +4231,25 @@ exit:
 	return res;
 }
 
-void rtw_dfs_master_timer_hdl(void *ctx)
+void rtw_dfs_rd_timer_hdl(void *ctx)
 {
-	_adapter *adapter = (_adapter *)ctx;
+	struct rf_ctl_t *rfctl = (struct rf_ctl_t *)ctx;
+	struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
 
-	rtw_dfs_master_cmd(adapter, _TRUE);
+	rtw_dfs_rd_cmd(dvobj_get_primary_adapter(dvobj), _TRUE);
 }
 
-void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset)
+static void rtw_dfs_rd_enable(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset, bool bypass_cac)
 {
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
+	_adapter *adapter = dvobj_get_primary_adapter(dvobj);
 
-	/* TODO: move timer to rfctl */
-	adapter = GET_PRIMARY_ADAPTER(adapter);
+	RTW_INFO("%s on %u,%u,%u\n", __func__, ch, bw, offset);
 
-	RTW_INFO(FUNC_ADPT_FMT" on %u,%u,%u\n", FUNC_ADPT_ARG(adapter), ch, bw, offset);
-
-	if (rtw_is_cac_reset_needed(adapter, ch, bw, offset) == _TRUE)
-		rtw_reset_cac(adapter, ch, bw, offset);
+	if (bypass_cac)
+		rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
+	else if (rtw_is_cac_reset_needed(rfctl, ch, bw, offset) == _TRUE)
+		rtw_reset_cac(rfctl, ch, bw, offset);
 
 	rfctl->radar_detect_by_others = _FALSE;
 	rfctl->radar_detect_ch = ch;
@@ -3591,10 +4261,14 @@ void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset)
 	if (IS_CH_WAITING(rfctl))
 		StopTxBeacon(adapter);
 
-	if (!rfctl->dfs_master_enabled) {
-		RTW_INFO(FUNC_ADPT_FMT" set dfs_master_enabled\n", FUNC_ADPT_ARG(adapter));
-		rfctl->dfs_master_enabled = 1;
-		_set_timer(&adapter->mlmepriv.dfs_master_timer, DFS_MASTER_TIMER_MS);
+	if (!rfctl->radar_detect_enabled) {
+		RTW_INFO("%s set radar_detect_enabled\n", __func__);
+		rfctl->radar_detect_enabled = 1;
+		#ifdef CONFIG_LPS
+		LPS_Leave(adapter, "RADAR_DETECT_EN");
+		#endif
+		_set_timer(&rfctl->radar_detect_timer
+			, rtw_odm_radar_detect_polling_int_ms(dvobj));
 
 		if (rtw_rfctl_overlap_radar_detect_ch(rfctl)) {
 			if (IS_CH_WAITING(rfctl)) {
@@ -3607,27 +4281,24 @@ void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset)
 	}
 }
 
-void rtw_dfs_master_disable(_adapter *adapter, u8 ch, u8 bw, u8 offset, bool by_others)
+static void rtw_dfs_rd_disable(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset, bool by_others)
 {
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-
-	/* TODO: move timer to rfctl */
-	adapter = GET_PRIMARY_ADAPTER(adapter);
+	_adapter *adapter = dvobj_get_primary_adapter(rfctl_to_dvobj(rfctl));
 
 	rfctl->radar_detect_by_others = by_others;
 
-	if (rfctl->dfs_master_enabled) {
+	if (rfctl->radar_detect_enabled) {
 		bool overlap_radar_detect_ch = rtw_rfctl_overlap_radar_detect_ch(rfctl);
 
-		RTW_INFO(FUNC_ADPT_FMT" clear dfs_master_enabled\n", FUNC_ADPT_ARG(adapter));
+		RTW_INFO("%s clear radar_detect_enabled\n", __func__);
 
-		rfctl->dfs_master_enabled = 0;
+		rfctl->radar_detect_enabled = 0;
 		rfctl->radar_detected = 0;
 		rfctl->radar_detect_ch = 0;
 		rfctl->radar_detect_bw = 0;
 		rfctl->radar_detect_offset = 0;
 		rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
-		_cancel_timer_ex(&adapter->mlmepriv.dfs_master_timer);
+		_cancel_timer_ex(&rfctl->radar_detect_timer);
 
 		if (rtw_mi_check_fwstate(adapter, WIFI_UNDER_LINKING|WIFI_SITE_MONITOR) == _FALSE) {
 			ResumeTxBeacon(adapter);
@@ -3649,71 +4320,75 @@ void rtw_dfs_master_disable(_adapter *adapter, u8 ch, u8 bw, u8 offset, bool by_
 	}
 }
 
-void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action)
+void rtw_dfs_rd_en_decision(_adapter *adapter, u8 mlme_act, u8 excl_ifbmp)
 {
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 	struct mi_state mstate;
+	u8 ifbmp;
 	u8 u_ch, u_bw, u_offset;
 	bool ld_sta_in_dfs = _FALSE;
 	bool sync_ch = _FALSE; /* _FALSE: asign channel directly */
 	bool needed = _FALSE;
 
-	rtw_mi_status_no_self(adapter, &mstate);
-	rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset);
-	if (u_ch != 0)
-		sync_ch = _TRUE;
-
-	switch (self_action) {
-	case MLME_STA_CONNECTING:
-		MSTATE_STA_LG_NUM(&mstate)++;
-		break;
-	case MLME_STA_CONNECTED:
-		MSTATE_STA_LD_NUM(&mstate)++;
-		break;
-	case MLME_STA_DISCONNECTED:
-		break;
+	if (mlme_act == MLME_OPCH_SWITCH
+		|| mlme_act == MLME_ACTION_NONE
+	) {
+		ifbmp = ~excl_ifbmp;
+		rtw_mi_status_by_ifbmp(dvobj, ifbmp, &mstate);
+		rtw_mi_get_ch_setting_union_by_ifbmp(dvobj, ifbmp, &u_ch, &u_bw, &u_offset);
+	} else {
+		ifbmp = ~excl_ifbmp & ~BIT(adapter->iface_id);
+		rtw_mi_status_by_ifbmp(dvobj, ifbmp, &mstate);
+		rtw_mi_get_ch_setting_union_by_ifbmp(dvobj, ifbmp, &u_ch, &u_bw, &u_offset);
+		if (u_ch != 0)
+			sync_ch = _TRUE;
+
+		switch (mlme_act) {
+		case MLME_STA_CONNECTING:
+			MSTATE_STA_LG_NUM(&mstate)++;
+			break;
+		case MLME_STA_CONNECTED:
+			MSTATE_STA_LD_NUM(&mstate)++;
+			break;
+		case MLME_STA_DISCONNECTED:
+			break;
 #ifdef CONFIG_AP_MODE
-	case MLME_AP_STARTED:
-		MSTATE_AP_NUM(&mstate)++;
-		break;
-	case MLME_AP_STOPPED:
-		break;
+		case MLME_AP_STARTED:
+			MSTATE_AP_NUM(&mstate)++;
+			break;
+		case MLME_AP_STOPPED:
+			break;
 #endif
 #ifdef CONFIG_RTW_MESH
-	case MLME_MESH_STARTED:
-		MSTATE_MESH_NUM(&mstate)++;
-		break;
-	case MLME_MESH_STOPPED:
-		break;
+		case MLME_MESH_STARTED:
+			MSTATE_MESH_NUM(&mstate)++;
+			break;
+		case MLME_MESH_STOPPED:
+			break;
 #endif
-	case MLME_ACTION_NONE:
-		/* caller without effect of decision */
-		break;
-	default:
-		rtw_warn_on(1);
-		break;
-	}
-
-	if (sync_ch == _TRUE) {
-		if (!rtw_is_chbw_grouped(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset)) {
-			RTW_INFO(FUNC_ADPT_FMT" can't sync %u,%u,%u with %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
-				, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset);
-			goto apply;
+		default:
+			rtw_warn_on(1);
+			break;
 		}
 
-		rtw_sync_chbw(&mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
-			, &u_ch, &u_bw, &u_offset);
-	} else {
-		u_ch = mlmeext->cur_channel;
-		u_bw = mlmeext->cur_bwmode;
-		u_offset = mlmeext->cur_ch_offset;
-	}
+		if (sync_ch == _TRUE) {
+			if (!MLME_IS_OPCH_SW(adapter)) {
+				if (!rtw_is_chbw_grouped(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset)) {
+					RTW_INFO(FUNC_ADPT_FMT" can't sync %u,%u,%u with %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
+						, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset);
+					goto apply;
+				}
 
-	if (MSTATE_STA_LD_NUM(&mstate) > 0) {
-		/* rely on AP on which STA mode connects */
-		if (rtw_is_dfs_chbw(u_ch, u_bw, u_offset))
-			ld_sta_in_dfs = _TRUE;
-		goto apply;
+				rtw_sync_chbw(&mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
+					, &u_ch, &u_bw, &u_offset);
+			}
+		} else {
+			u_ch = mlmeext->cur_channel;
+			u_bw = mlmeext->cur_bwmode;
+			u_offset = mlmeext->cur_ch_offset;
+		}
 	}
 
 	if (MSTATE_STA_LG_NUM(&mstate) > 0) {
@@ -3721,6 +4396,19 @@ void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action)
 		goto apply;
 	}
 
+	if (MSTATE_STA_LD_NUM(&mstate) > 0) {
+		if (rtw_is_dfs_chbw(u_ch, u_bw, u_offset)) {
+			/*
+			* if operate as slave w/o radar detect,
+			* rely on AP on which STA mode connects
+			*/
+			if (IS_DFS_SLAVE_WITH_RD(rfctl) && !rtw_odm_dfs_domain_unknown(dvobj))
+				needed = _TRUE;
+			ld_sta_in_dfs = _TRUE;
+		}
+		goto apply;
+	}
+
 	if (!MSTATE_AP_NUM(&mstate) && !MSTATE_MESH_NUM(&mstate)) {
 		/* No working AP/Mesh mode */
 		goto apply;
@@ -3731,17 +4419,46 @@ void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action)
 
 apply:
 
-	RTW_INFO(FUNC_ADPT_FMT" needed:%d, self_action:%u\n"
-		, FUNC_ADPT_ARG(adapter), needed, self_action);
+	RTW_INFO(FUNC_ADPT_FMT" needed:%d, mlme_act:%u, excl_ifbmp:0x%02x\n"
+		, FUNC_ADPT_ARG(adapter), needed, mlme_act, excl_ifbmp);
 	RTW_INFO(FUNC_ADPT_FMT" ld_sta_num:%u, lg_sta_num:%u, ap_num:%u, mesh_num:%u, %u,%u,%u\n"
 		, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate), MSTATE_STA_LG_NUM(&mstate)
 		, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate)
 		, u_ch, u_bw, u_offset);
 
 	if (needed == _TRUE)
-		rtw_dfs_master_enable(adapter, u_ch, u_bw, u_offset);
+		rtw_dfs_rd_enable(rfctl, u_ch, u_bw, u_offset, ld_sta_in_dfs);
 	else
-		rtw_dfs_master_disable(adapter, u_ch, u_bw, u_offset, ld_sta_in_dfs);
+		rtw_dfs_rd_disable(rfctl, u_ch, u_bw, u_offset, ld_sta_in_dfs);
+}
+
+u8 rtw_dfs_rd_en_decision_cmd(_adapter *adapter)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *parm;
+	struct cmd_priv *cmdpriv = &adapter->cmdpriv;
+	u8 res = _FAIL;
+
+	cmdobj = rtw_zmalloc(sizeof(struct cmd_obj));
+	if (cmdobj == NULL)
+		goto exit;
+
+	parm = rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (parm == NULL) {
+		rtw_mfree(cmdobj, sizeof(struct cmd_obj));
+		goto exit;
+	}
+
+	parm->ec_id = DFS_RADAR_DETECT_EN_DEC_WK_CID;
+	parm->type = 0;
+	parm->size = 0;
+	parm->pbuf = NULL;
+
+	init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
+	res = rtw_enqueue_cmd(cmdpriv, cmdobj);
+
+exit:
+	return res;
 }
 #endif /* CONFIG_DFS_MASTER */
 
@@ -3950,13 +4667,16 @@ static s32 rtw_mp_cmd_hdl(_adapter *padapter, u8 mp_cmd_id)
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	int ret = H2C_SUCCESS;
 	uint status = _SUCCESS;
-	u8 rfreg0;
 
 	if (mp_cmd_id == MP_START) {
 		if (padapter->registrypriv.mp_mode == 0) {
 			rtw_intf_stop(padapter);
 			rtw_hal_deinit(padapter);
 			padapter->registrypriv.mp_mode = 1;
+#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
+		padapter->mppriv.CureFuseBTCoex = pHalData->EEPROMBluetoothCoexist;
+		pHalData->EEPROMBluetoothCoexist = _FALSE;
+#endif
 #ifdef CONFIG_RF_POWER_TRIM
 			if (!IS_HARDWARE_TYPE_8814A(padapter) && !IS_HARDWARE_TYPE_8822B(padapter)) {
 				padapter->registrypriv.RegPwrTrimEnable = 1;
@@ -3964,11 +4684,22 @@ static s32 rtw_mp_cmd_hdl(_adapter *padapter, u8 mp_cmd_id)
 			}
 #endif /*CONFIG_RF_POWER_TRIM*/
 			rtw_reset_drv_sw(padapter);
+#ifdef CONFIG_NEW_NETDEV_HDL
+			if (!rtw_is_hw_init_completed(padapter)) {
+				status = rtw_hal_init(padapter);
+				if (status == _FAIL) {
+					ret = H2C_REJECTED;
+					goto exit;
+				}
+				rtw_hal_iface_init(padapter);
+			}
+#else
 			status = rtw_hal_init(padapter);
 			if (status == _FAIL) {
 				ret = H2C_REJECTED;
 				goto exit;
 			}
+#endif /*CONFIG_NEW_NETDEV_HDL*/
 #ifndef RTW_HALMAC
 			rtw_intf_start(padapter);
 #endif /* !RTW_HALMAC */
@@ -4014,12 +4745,26 @@ static s32 rtw_mp_cmd_hdl(_adapter *padapter, u8 mp_cmd_id)
 			rtw_intf_stop(padapter);
 			rtw_hal_deinit(padapter);
 			padapter->registrypriv.mp_mode = 0;
+#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
+			pHalData->EEPROMBluetoothCoexist = padapter->mppriv.CureFuseBTCoex;
+#endif
 			rtw_reset_drv_sw(padapter);
+#ifdef CONFIG_NEW_NETDEV_HDL
+			if (!rtw_is_hw_init_completed(padapter)) {
+				status = rtw_hal_init(padapter);
+				if (status == _FAIL) {
+					ret = H2C_REJECTED;
+					goto exit;
+				}
+				rtw_hal_iface_init(padapter);
+			}
+#else
 			status = rtw_hal_init(padapter);
 			if (status == _FAIL) {
 				ret = H2C_REJECTED;
 				goto exit;
 			}
+#endif /*CONFIG_NEW_NETDEV_HDL*/
 #ifndef RTW_HALMAC
 			rtw_intf_start(padapter);
 #endif /* !RTW_HALMAC */
@@ -4581,6 +5326,69 @@ exit:
 	return;
 }
 
+#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
+static s32 rtw_req_per_cmd_hdl(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct macid_bmp req_macid_bmp, *macid_bmp;
+	u8 i, ret = _FAIL;
+
+	macid_bmp = &macid_ctl->if_g[adapter->iface_id];
+	_rtw_memcpy(&req_macid_bmp, macid_bmp, sizeof(struct macid_bmp));
+
+	/* Clear none mesh's macid */
+	for (i = 0; i < macid_ctl->num; i++) {
+		u8 role;
+		role = GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[i]);
+		if (role != H2C_MSR_ROLE_MESH)
+			rtw_macid_map_clr(&req_macid_bmp, i);
+	}
+
+	/* group_macid: always be 0 in NIC, so only pass macid_bitmap.m0
+	 * rpt_type: 0 includes all info in 1, use 0 for now 
+	 * macid_bitmap: pass m0 only for NIC
+	 */
+	ret = rtw_hal_set_req_per_rpt_cmd(adapter, 0, 0, req_macid_bmp.m0);
+
+	return ret;
+}
+
+u8 rtw_req_per_cmd(_adapter *adapter)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	struct submit_ctx sctx;
+	u8 res = _SUCCESS;
+
+	parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (parm == NULL) {
+		res = _FAIL;
+		goto exit;
+	}
+
+	parm->ec_id = REQ_PER_CMD_WK_CID;
+	parm->type = 0;
+	parm->size = 0;
+	parm->pbuf = NULL;
+
+	cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
+	if (cmdobj == NULL) {
+		res = _FAIL;
+		rtw_mfree((u8 *)parm, sizeof(*parm));
+		goto exit;
+	}
+
+	init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
+
+	res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+
+exit:
+	return res;
+}
+#endif
+
 u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 	int ret = H2C_SUCCESS;
@@ -4652,7 +5460,7 @@ u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)
 		reset_securitypriv_hdl(padapter);
 		break;
 	case FREE_ASSOC_RESOURCES:
-		free_assoc_resources_hdl(padapter);
+		free_assoc_resources_hdl(padapter, (u8)pdrvextra_cmd->type);
 		break;
 	case C2H_WK_CID:
 		switch (pdrvextra_cmd->type) {
@@ -4686,8 +5494,11 @@ u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)
 		break;
 #endif
 #ifdef CONFIG_DFS_MASTER
-	case DFS_MASTER_WK_CID:
-		rtw_dfs_master_hdl(padapter);
+	case DFS_RADAR_DETECT_WK_CID:
+		rtw_dfs_rd_hdl(padapter);
+		break;
+	case DFS_RADAR_DETECT_EN_DEC_WK_CID:
+		rtw_dfs_rd_en_decision(padapter, MLME_ACTION_NONE, 0);
 		break;
 #endif
 	case SESSION_TRACKER_WK_CID:
@@ -4696,6 +5507,9 @@ u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)
 	case EN_HW_UPDATE_TSF_WK_CID:
 		rtw_hal_set_hwreg(padapter, HW_VAR_EN_HW_UPDATE_TSF, NULL);
 		break;
+	case PERIOD_TSF_UPDATE_END_WK_CID:
+		rtw_hal_periodic_tsf_update_chk(padapter);
+		break;
 	case TEST_H2C_CID:
 		rtw_hal_fill_h2c_cmd(padapter, pdrvextra_cmd->pbuf[0], pdrvextra_cmd->size - 1, &pdrvextra_cmd->pbuf[1]);
 		break;
@@ -4721,6 +5535,27 @@ u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)
 		ret = rtw_mgnt_tx_handler(padapter, pdrvextra_cmd->pbuf);
 		break;
 #endif /* CONFIG_IOCTL_CFG80211 */
+#ifdef CONFIG_MCC_MODE
+	case MCC_SET_DURATION_WK_CID:
+		ret = rtw_set_mcc_duration_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
+		break;
+#endif /* CONFIG_MCC_MODE */
+#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
+	case REQ_PER_CMD_WK_CID:
+		ret = rtw_req_per_cmd_hdl(padapter);
+		break;
+#endif
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+	case SSMPS_WK_CID :
+		rtw_ssmps_wk_hdl(padapter, (struct ssmps_cmd_parm *)pdrvextra_cmd->pbuf);
+		break;
+#endif
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+	case TXSS_WK_CID :
+		rtw_ctrl_txss_wk_hdl(padapter, (struct txss_cmd_parm *)pdrvextra_cmd->pbuf);
+		break;
+#endif
+
 	default:
 		break;
 	}
@@ -4800,7 +5635,6 @@ void rtw_joinbss_cmd_callback(_adapter	*padapter,  struct cmd_obj *pcmd)
 void rtw_create_ibss_post_hdl(_adapter *padapter, int status)
 {
 	_irqL irqL;
-	struct sta_info *psta = NULL;
 	struct wlan_network *pwlan = NULL;
 	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	WLAN_BSSID_EX *pdev_network = &padapter->registrypriv.dev_network;
@@ -4847,7 +5681,6 @@ void rtw_create_ibss_post_hdl(_adapter *padapter, int status)
 
 createbss_cmd_fail:
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
-exit:
 	return;
 }
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_debug.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_debug.c
index cdb9c690f270..08b900843b50 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_debug.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_debug.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -129,6 +130,18 @@ void dump_drv_cfg(void *sel)
 	RTW_PRINT_SEL(sel, "CONFIG_RTW_80211R\n");
 #endif
 
+#ifdef CONFIG_RTW_NETIF_SG
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_NETIF_SG\n");
+#endif
+
+#ifdef CONFIG_RTW_WIFI_HAL
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_WIFI_HAL\n");
+#endif
+
+#ifdef CONFIG_RTW_TPT_MODE
+	RTW_PRINT_SEL(sel, "CONFIG_RTW_TPT_MODE\n");
+#endif 
+
 #ifdef CONFIG_USB_HCI
 #ifdef CONFIG_SUPPORT_USB_INT
 	RTW_PRINT_SEL(sel, "CONFIG_SUPPORT_USB_INT\n");
@@ -168,6 +181,21 @@ void dump_drv_cfg(void *sel)
 #ifdef CONFIG_PCI_HCI
 #endif
 
+	RTW_PRINT_SEL(sel, "CONFIG_IFACE_NUMBER = %d\n", CONFIG_IFACE_NUMBER);
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+	RTW_PRINT_SEL(sel, "CONFIG_MI_WITH_MBSSID_CAM\n");
+#endif
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	RTW_PRINT_SEL(sel, "CONFIG_SWTIMER_BASED_TXBCN\n");
+#endif
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	RTW_PRINT_SEL(sel, "CONFIG_FW_HANDLE_TXBCN\n");
+	RTW_PRINT_SEL(sel, "CONFIG_LIMITED_AP_NUM = %d\n", CONFIG_LIMITED_AP_NUM);
+#endif
+#ifdef CONFIG_CLIENT_PORT_CFG
+	RTW_PRINT_SEL(sel, "CONFIG_CLIENT_PORT_CFG\n");
+#endif
+
 	RTW_PRINT_SEL(sel, "\n=== XMIT-INFO ===\n");
 	RTW_PRINT_SEL(sel, "NR_XMITFRAME = %d\n", NR_XMITFRAME);
 	RTW_PRINT_SEL(sel, "NR_XMITBUFF = %d\n", NR_XMITBUFF);
@@ -258,7 +286,7 @@ void mac_reg_dump(void *sel, _adapter *adapter)
 #endif /* CONFIG_RTL8814A */
 
 
-#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) ||defined(CONFIG_RTL8192F)
 	for (i = 0x1000; i < 0x1800; i += 4) {
 		if (j % 4 == 1)
 			RTW_PRINT_SEL(sel, "0x%04x", i);
@@ -266,7 +294,8 @@ void mac_reg_dump(void *sel, _adapter *adapter)
 		if ((j++) % 4 == 0)
 			_RTW_PRINT_SEL(sel, "\n");
 	}
-#endif /* CONFIG_RTL8822B */
+#endif /* CONFIG_RTL8822B  or 8821c or 8192f*/
+
 }
 
 void bb_reg_dump(void *sel, _adapter *adapter)
@@ -295,7 +324,7 @@ void bb_reg_dump(void *sel, _adapter *adapter)
 
 void bb_reg_dump_ex(void *sel, _adapter *adapter)
 {
-	int i, j = 1;
+	int i;
 
 	RTW_PRINT_SEL(sel, "======= BB REG =======\n");
 	for (i = 0x800; i < 0x1000; i += 4) {
@@ -414,11 +443,25 @@ void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
 	int i;
 	_adapter *iface;
 	u8 u_ch, u_bw, u_offset;
-
+#if (defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)) || defined(CONFIG_CLIENT_PORT_CFG)
+	char str_val[64] = {'\0'};
+#endif
 	dump_mi_status(sel, dvobj);
 
+#if defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)
+	RTW_PRINT_SEL(sel, "[AP] LIMITED_AP_NUM:%d\n", CONFIG_LIMITED_AP_NUM);
+	RTW_PRINT_SEL(sel, "[AP] vap_map:0x%02x\n", dvobj->vap_map);
+#endif
+#ifdef CONFIG_HW_P0_TSF_SYNC
+	RTW_PRINT_SEL(sel, "[AP] p0 tsf sync port = %d\n", dvobj->p0_tsf.sync_port);
+	RTW_PRINT_SEL(sel, "[AP] p0 tsf timer offset = %d\n", dvobj->p0_tsf.offset);
+#endif
+#ifdef CONFIG_CLIENT_PORT_CFG
+	RTW_PRINT_SEL(sel, "[CLT] clt_num = %d\n", dvobj->clt_port.num);
+	RTW_PRINT_SEL(sel, "[CLT] clt_map = 0x%02x\n", dvobj->clt_port.bmp);
+#endif
 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-	RTW_PRINT_SEL(sel, "default port id:%d\n\n", dvobj->default_port_id);
+	RTW_PRINT_SEL(sel, "[MI] default port id:%d\n\n", dvobj->dft.port_id);
 #endif /* CONFIG_FW_MULTI_PORT_SUPPORT */
 
 	RTW_PRINT_SEL(sel, "dev status:%s%s\n\n"
@@ -443,14 +486,40 @@ void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
 #define P2P_INFO_VALUE_FMT	""
 #define P2P_INFO_VALUE_ARG
 #define P2P_INFO_DASH
+#endif
+
+#ifdef DBG_TSF_UPDATE
+#define TSF_PAUSE_TIME_TITLE_FMT " %-5s"
+#define TSF_PAUSE_TIME_TITLE_ARG , "tsfup"
+#define TSF_PAUSE_TIME_VALUE_FMT " %5d"
+#define TSF_PAUSE_TIME_VALUE_ARG , ((iface->mlmeextpriv.tsf_update_required && iface->mlmeextpriv.tsf_update_pause_stime) ? (rtw_get_passing_time_ms(iface->mlmeextpriv.tsf_update_pause_stime) > 99999 ? 99999 : rtw_get_passing_time_ms(iface->mlmeextpriv.tsf_update_pause_stime)) : 0)
+#else
+#define TSF_PAUSE_TIME_TITLE_FMT ""
+#define TSF_PAUSE_TIME_TITLE_ARG
+#define TSF_PAUSE_TIME_VALUE_FMT ""
+#define TSF_PAUSE_TIME_VALUE_ARG
+#endif
+
+#if (defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)) || defined(CONFIG_CLIENT_PORT_CFG)
+#define INFO_FMT	" %-4s"
+#define INFO_ARG	, "info"
+#define INFO_CNT_FMT	" %-20s"
+#define INFO_CNT_ARG	, str_val
+#else
+#define INFO_FMT	""
+#define INFO_ARG
+#define INFO_CNT_FMT	""
+#define INFO_CNT_ARG
 #endif
 
 	RTW_PRINT_SEL(sel, "%-2s %-15s %c %-3s %-3s %-3s %-17s %-4s %-7s"
 		P2P_INFO_TITLE_FMT
-		" %s\n"
+		TSF_PAUSE_TIME_TITLE_FMT
+		" %s"INFO_FMT"\n"
 		, "id", "ifname", ' ', "bup", "nup", "ncd", "macaddr", "port", "ch"
 		P2P_INFO_TITLE_ARG
-		, "status");
+		TSF_PAUSE_TIME_TITLE_ARG
+		, "status"INFO_ARG);
 
 	RTW_PRINT_SEL(sel, "---------------------------------------------------------------"
 		P2P_INFO_DASH
@@ -459,21 +528,64 @@ void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
 		if (iface) {
+			#if (defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)) || defined(CONFIG_CLIENT_PORT_CFG)
+			_rtw_memset(&str_val, '\0', sizeof(str_val));
+			#endif
+			#if defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)
+			if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
+				u8 len;
+				char *p = str_val;
+				char tmp_str[10] = {'\0'};
+
+				len = snprintf(tmp_str, sizeof(tmp_str), "%s", "ap_id:");
+				strncpy(p, tmp_str, len);
+				p += len;
+				_rtw_memset(&tmp_str, '\0', sizeof(tmp_str));
+				#ifdef DBG_HW_PORT
+				len = snprintf(tmp_str, sizeof(tmp_str), "%d (%d,%d)", iface->vap_id, iface->hw_port, iface->client_port);
+				#else
+				len = snprintf(tmp_str, sizeof(tmp_str), "%d", iface->vap_id);
+				#endif
+				strncpy(p, tmp_str, len);
+			}
+			#endif
+			#ifdef CONFIG_CLIENT_PORT_CFG
+			if (MLME_IS_STA(iface)) {
+				u8 len;
+				char *p = str_val;
+				char tmp_str[10] = {'\0'};
+
+				len = snprintf(tmp_str, sizeof(tmp_str), "%s", "c_pid:");
+				strncpy(p, tmp_str, len);
+				p += len;
+				_rtw_memset(&tmp_str, '\0', sizeof(tmp_str));
+				#ifdef DBG_HW_PORT
+				len = snprintf(tmp_str, sizeof(tmp_str), "%d (%d,%d)", iface->client_port, iface->hw_port, iface->client_port);
+				#else
+				len = snprintf(tmp_str, sizeof(tmp_str), "%d", iface->client_port);
+				#endif
+				strncpy(p, tmp_str, len);
+			}
+			#endif
+
 			RTW_PRINT_SEL(sel, "%2d %-15s %c %3u %3u %3u "MAC_FMT" %4hhu %3u,%u,%u"
 				P2P_INFO_VALUE_FMT
-				" "MLME_STATE_FMT"\n"
+				TSF_PAUSE_TIME_VALUE_FMT
+				" "MLME_STATE_FMT" " INFO_CNT_FMT"\n"
 				, i, iface->registered ? ADPT_ARG(iface) : NULL
 				, iface->registered ? 'R' : ' '
 				, iface->bup
 				, iface->netif_up
 				, iface->net_closed
 				, MAC_ARG(adapter_mac_addr(iface))
-				, get_hw_port(iface)
+				, rtw_hal_get_port(iface)
 				, iface->mlmeextpriv.cur_channel
 				, iface->mlmeextpriv.cur_bwmode
 				, iface->mlmeextpriv.cur_ch_offset
 				P2P_INFO_VALUE_ARG
+				TSF_PAUSE_TIME_VALUE_ARG
 				, MLME_STATE_ARG(iface)
+				INFO_CNT_ARG
 			);
 		}
 	}
@@ -488,11 +600,12 @@ void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
 		, u_ch, u_bw, u_offset
 	);
 
-	RTW_PRINT_SEL(sel, "%55s %3u,%u,%u\n"
+	RTW_PRINT_SEL(sel, "%55s %3u,%u,%u offch_state:%d\n"
 		, "oper:"
 		, dvobj->oper_channel
 		, dvobj->oper_bwmode
 		, dvobj->oper_ch_offset
+		, rfctl->offch_state
 	);
 
 #ifdef CONFIG_DFS_MASTER
@@ -509,24 +622,11 @@ void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
 		else {
 			u32 non_ocp_ms;
 			u32 cac_ms;
-			u8 dfs_domain = rtw_odm_get_dfs_domain(dvobj_get_primary_adapter(dvobj));
+			u8 dfs_domain = rtw_odm_get_dfs_domain(dvobj);
 
 			_RTW_PRINT_SEL(sel, ", domain:%u", dfs_domain);
 
-			for (i = 0; i < dvobj->iface_nums; i++) {
-				if (!dvobj->padapters[i])
-					continue;
-				if (check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE)
-					&& check_fwstate(&dvobj->padapters[i]->mlmepriv, WIFI_ASOC_STATE))
-					break;
-			}
-
-			if (i >= dvobj->iface_nums) {
-				RTW_PRINT_SEL(sel, "DFS master enable without AP/Mesh mode???");
-				goto end_dfs_master;
-			}
-
-			rtw_get_ch_waiting_ms(dvobj->padapters[i]
+			rtw_get_ch_waiting_ms(rfctl
 				, rfctl->radar_detect_ch
 				, rfctl->radar_detect_bw
 				, rfctl->radar_detect_offset
@@ -693,7 +793,6 @@ int proc_get_read_reg(struct seq_file *m, void *v)
 
 ssize_t proc_set_read_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = data;
 	char tmp[16];
 	u32 addr, len;
 
@@ -749,9 +848,9 @@ int proc_get_rx_stat(struct seq_file *m, void *v)
 
 			if (pstats == NULL)
 				continue;
-			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6) !=  _TRUE)
-				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) != _TRUE)
-				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), 6) != _TRUE)) {
+			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) !=  _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), ETH_ALEN) != _TRUE)) {
 				RTW_PRINT_SEL(m, "MAC :\t\t"MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
 				RTW_PRINT_SEL(m, "data_rx_cnt :\t%llu\n", sta_rx_data_uc_pkts(psta) - pstats->last_rx_data_uc_pkts);
 				pstats->last_rx_data_uc_pkts = sta_rx_data_uc_pkts(psta);
@@ -779,9 +878,12 @@ int proc_get_tx_stat(struct seq_file *m, void *v)
 	_list	*plist, *phead;
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct sta_info *psta = NULL, *sta_rec[NUM_STA];
+	struct sta_info *psta = NULL;
+	u8 sta_mac[NUM_STA][ETH_ALEN] = {{0}};
+	uint mac_id[NUM_STA];
 	struct stainfo_stats	*pstats = NULL;
 	struct sta_priv	*pstapriv = &(adapter->stapriv);
+	struct sta_priv	*pstapriv_primary = &(GET_PRIMARY_ADAPTER(adapter))->stapriv;
 	u32 i, macid_rec_idx = 0;
 	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 	u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
@@ -789,40 +891,54 @@ int proc_get_tx_stat(struct seq_file *m, void *v)
 
 	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 	for (i = 0; i < NUM_STA; i++) {
-		sta_rec[i] = NULL;
 		phead = &(pstapriv->sta_hash[i]);
 		plist = get_next(phead);
 		while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
 			psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
 			plist = get_next(plist);
-			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6) !=  _TRUE)
-				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) != _TRUE)
-				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), 6) != _TRUE)) {
-				sta_rec[macid_rec_idx++] = psta;
+			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) !=  _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), ETH_ALEN) != _TRUE)) {
+				_rtw_memcpy(&sta_mac[macid_rec_idx][0], psta->cmn.mac_addr, ETH_ALEN);
+				mac_id[macid_rec_idx] = psta->cmn.mac_id;
+				macid_rec_idx++;
 			}
 		}
 	}
 	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 	for (i = 0; i < macid_rec_idx; i++) {
-		pstats = &(sta_rec[i]->sta_stats);
-		if (pstats == NULL)
-			continue;
-		pstapriv->c2h_sta = sta_rec[i];
-		rtw_hal_reqtxrpt(adapter, sta_rec[i]->cmn.mac_id);
+		_rtw_memcpy(pstapriv_primary->c2h_sta_mac, &sta_mac[i][0], ETH_ALEN);
+		pstapriv_primary->c2h_adapter_id = adapter->iface_id;
 		rtw_sctx_init(&gotc2h, 60);
-		pstapriv->gotc2h = &gotc2h;
+		pstapriv_primary->gotc2h = &gotc2h;
+		rtw_hal_reqtxrpt(adapter, mac_id[i]);
 		if (rtw_sctx_wait(&gotc2h, __func__)) {
-			RTW_PRINT_SEL(m, "MAC :\t\t"MAC_FMT "\n", MAC_ARG(sta_rec[i]->cmn.mac_addr));
-			RTW_PRINT_SEL(m, "data_sent_cnt :\t%u\n", pstats->tx_ok_cnt + pstats->tx_fail_cnt);
-			RTW_PRINT_SEL(m, "success_cnt :\t%u\n", pstats->tx_ok_cnt);
-			RTW_PRINT_SEL(m, "failure_cnt :\t%u\n", pstats->tx_fail_cnt);
-			RTW_PRINT_SEL(m, "retry_cnt :\t%u\n\n", pstats->tx_retry_cnt);
+			psta = rtw_get_stainfo(pstapriv, &sta_mac[i][0]);
+			if(psta) {
+				pstats = &psta->sta_stats;
+#ifndef ROKU_PRIVATE
+				RTW_PRINT_SEL(m, "data_sent_cnt :\t%u\n", pstats->tx_ok_cnt + pstats->tx_fail_cnt);
+				RTW_PRINT_SEL(m, "success_cnt :\t%u\n", pstats->tx_ok_cnt);
+				RTW_PRINT_SEL(m, "failure_cnt :\t%u\n", pstats->tx_fail_cnt);
+				RTW_PRINT_SEL(m, "retry_cnt :\t%u\n\n", pstats->tx_retry_cnt);
+#else
+				RTW_PRINT_SEL(m, "MAC: " MAC_FMT " sent: %u fail: %u retry: %u\n",
+				MAC_ARG(&sta_mac[i][0]), pstats->tx_ok_cnt, pstats->tx_fail_cnt, pstats->tx_retry_cnt);
+#endif /* ROKU_PRIVATE */
+
+			} else
+				RTW_PRINT_SEL(m, "STA is gone\n");
 		} else {
+			//to avoid c2h modify counters
+			pstapriv_primary->gotc2h = NULL;
+			_rtw_memset(pstapriv_primary->c2h_sta_mac, 0, ETH_ALEN);
+			pstapriv_primary->c2h_adapter_id = CONFIG_IFACE_NUMBER;
 			RTW_PRINT_SEL(m, "Warming : Query timeout, operation abort!!\n");
-			RTW_PRINT_SEL(m, "\n");
-			pstapriv->c2h_sta = NULL;
 			break;
 		}
+		pstapriv_primary->gotc2h = NULL;
+		_rtw_memset(pstapriv_primary->c2h_sta_mac, 0, ETH_ALEN);
+		pstapriv_primary->c2h_adapter_id = CONFIG_IFACE_NUMBER;
 	}
 	return 0;
 }
@@ -927,11 +1043,11 @@ int proc_get_roam_param(struct seq_file *m, void *v)
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *mlme = &adapter->mlmepriv;
 
-	RTW_PRINT_SEL(m, "%12s %12s %11s %14s\n", "rssi_diff_th", "scanr_exp_ms", "scan_int_ms", "rssi_threshold");
-	RTW_PRINT_SEL(m, "%-12u %-12u %-11u %-14u\n"
+	RTW_PRINT_SEL(m, "%12s %15s %26s %16s\n", "rssi_diff_th", "scanr_exp_ms", "scan_interval(unit:2 sec)", "rssi_threshold");
+	RTW_PRINT_SEL(m, "%-15u %-13u %-27u %-11u\n"
 		, mlme->roam_rssi_diff_th
 		, mlme->roam_scanr_exp_ms
-		, mlme->roam_scan_int_ms
+		, mlme->roam_scan_int
 		, mlme->roam_rssi_threshold
 	);
 
@@ -947,7 +1063,7 @@ ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t
 	char tmp[32];
 	u8 rssi_diff_th;
 	u32 scanr_exp_ms;
-	u32 scan_int_ms;
+	u32 scan_int;
 	u8 rssi_threshold;
 
 	if (count < 1)
@@ -960,14 +1076,14 @@ ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%hhu %u %u %hhu", &rssi_diff_th, &scanr_exp_ms, &scan_int_ms, &rssi_threshold);
+		int num = sscanf(tmp, "%hhu %u %u %hhu", &rssi_diff_th, &scanr_exp_ms, &scan_int, &rssi_threshold);
 
 		if (num >= 1)
 			mlme->roam_rssi_diff_th = rssi_diff_th;
 		if (num >= 2)
 			mlme->roam_scanr_exp_ms = scanr_exp_ms;
 		if (num >= 3)
-			mlme->roam_scan_int_ms = scan_int_ms;
+			mlme->roam_scan_int = scan_int;
 		if (num >= 4)
 			mlme->roam_rssi_threshold = rssi_threshold;
 	}
@@ -1026,7 +1142,7 @@ ssize_t proc_set_ft_flags(struct file *file, const char __user *buffer, size_t c
 		int num = sscanf(tmp, "%hhx", &flags);
 
 		if (num == 1)
-			adapter->mlmepriv.ftpriv.ft_flags = flags;
+			adapter->mlmepriv.ft_roam.ft_flags = flags;
 	}
 
 	return count;
@@ -1038,7 +1154,7 @@ int proc_get_ft_flags(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	RTW_PRINT_SEL(m, "0x%02x\n", adapter->mlmepriv.ftpriv.ft_flags);
+	RTW_PRINT_SEL(m, "0x%02x\n", adapter->mlmepriv.ft_roam.ft_flags);
 
 	return 0;
 }
@@ -1222,87 +1338,6 @@ int proc_get_scan_abort(struct seq_file *m, void *v)
 	return 0;
 }
 
-#ifdef CONFIG_SCAN_BACKOP
-int proc_get_backop_flags_sta(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_sta(mlmeext));
-
-	return 0;
-}
-
-ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	char tmp[32];
-	u8 flags;
-
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhx", &flags);
-
-		if (num == 1)
-			mlmeext_assign_scan_backop_flags_sta(mlmeext, flags);
-	}
-
-	return count;
-}
-
-int proc_get_backop_flags_ap(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_ap(mlmeext));
-
-	return 0;
-}
-
-ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
-
-	char tmp[32];
-	u8 flags;
-
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhx", &flags);
-
-		if (num == 1)
-			mlmeext_assign_scan_backop_flags_ap(mlmeext, flags);
-	}
-
-	return count;
-}
-
-#endif /* CONFIG_SCAN_BACKOP */
-
 #ifdef CONFIG_RTW_REPEATER_SON
 int proc_get_rson_data(struct seq_file *m, void *v)
 {
@@ -1366,6 +1401,11 @@ int proc_get_survey_info(struct seq_file *m, void *v)
 	char flag_str[64];
 	int ielen = 0;
 	u32 wpsielen = 0;
+#ifdef CONFIG_RTW_MESH
+	const char *ssid_title_str = "ssid/mesh_id";
+#else
+	const char *ssid_title_str = "ssid";
+#endif
 
 	_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 	phead = get_list_head(queue);
@@ -1379,7 +1419,7 @@ int proc_get_survey_info(struct seq_file *m, void *v)
 	rtw_rson_show_survey_info(m, plist, phead);
 #else
 
-	RTW_PRINT_SEL(m, "%5s  %-17s  %3s  %-3s  %-4s  %-4s  %5s  %32s  %32s\n", "index", "bssid", "ch", "RSSI", "SdBm", "Noise", "age", "flag", "ssid");
+	RTW_PRINT_SEL(m, "%5s  %-17s  %3s  %-3s  %-4s  %-4s  %5s  %32s  %32s\n", "index", "bssid", "ch", "RSSI", "SdBm", "Noise", "age", "flag", ssid_title_str);
 	while (1) {
 		if (rtw_end_of_queue_search(phead, plist) == _TRUE)
 			break;
@@ -1411,19 +1451,21 @@ int proc_get_survey_info(struct seq_file *m, void *v)
 			(ie_wpa2) ? "[WPA2]" : "",
 			(!ie_wpa && !ie_wpa && ie_cap & BIT(4)) ? "[WEP]" : "",
 			(ie_wps) ? "[WPS]" : "",
-			(pnetwork->network.InfrastructureMode == Ndis802_11IBSS) ? "[IBSS]" : "",
+			(pnetwork->network.InfrastructureMode == Ndis802_11IBSS) ? "[IBSS]" :
+				(pnetwork->network.InfrastructureMode == Ndis802_11_mesh) ? "[MESH]" : "",
 			(ie_cap & BIT(0)) ? "[ESS]" : "",
 			(ie_p2p) ? "[P2P]" : "");
 		RTW_PRINT_SEL(m, "%5d  "MAC_FMT"  %3d  %3d  %4d  %4d    %5d  %32s  %32s\n",
-			      ++index,
-			      MAC_ARG(pnetwork->network.MacAddress),
-			      pnetwork->network.Configuration.DSConfig,
-			      (int)pnetwork->network.Rssi,
-			      notify_signal,
-			      notify_noise,
+			++index,
+			MAC_ARG(pnetwork->network.MacAddress),
+			pnetwork->network.Configuration.DSConfig,
+			(int)pnetwork->network.Rssi,
+			notify_signal,
+			notify_noise,
 			rtw_get_passing_time_ms(pnetwork->last_scanned),
-			      flag_str,
-			      pnetwork->network.Ssid.Ssid);
+			flag_str,
+			pnetwork->network.InfrastructureMode == Ndis802_11_mesh ? pnetwork->network.mesh_id.Ssid : pnetwork->network.Ssid.Ssid
+		);
 		plist = get_next(plist);
 	}
 #endif
@@ -1435,17 +1477,26 @@ _exit:
 
 ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	_irqL irqL;
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	bool need_indicate_scan_done = _FALSE;
 	u8 _status = _FALSE;
-	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];
-
+	u8 ssc_chk;
 	if (count < 1)
 		return -EFAULT;
 
+#if 1
+	ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
+	if (ssc_chk != SS_ALLOW)
+		goto exit;
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	if (_FAIL == rtw_pwr_wakeup(padapter))
+		goto cancel_ps_deny;
+	if (!rtw_is_adapter_up(padapter)) {
+		RTW_INFO("scan abort!! adapter cannot use\n");
+		goto cancel_ps_deny;
+	}
+#else
 #ifdef CONFIG_MP_INCLUDED
 	if (rtw_mp_mode_check(padapter)) {
 		RTW_INFO("MP mode block Scan request\n");
@@ -1486,6 +1537,7 @@ ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_
 		RTW_INFO("scan abort!! buddy_fwstate check failed\n");
 		goto cancel_ps_deny;
 	}
+#endif
 #endif
 	_status = rtw_set_802_11_bssid_list_scan(padapter, NULL);
 
@@ -1494,6 +1546,68 @@ cancel_ps_deny:
 exit:
 	return count;
 }
+#ifdef ROKU_PRIVATE
+int proc_get_infra_ap(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	struct sta_info *psta;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct ht_priv_infra_ap *phtpriv = &pmlmepriv->htpriv_infra_ap;
+#ifdef CONFIG_80211AC_VHT
+	struct vht_priv_infra_ap *pvhtpriv = &pmlmepriv->vhtpriv_infra_ap;
+#endif
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+		psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
+		if (psta) {
+			unsigned int i, j;
+			unsigned int Rx_ss = 0, Tx_ss = 0;
+			struct recv_reorder_ctrl *preorder_ctrl;
+
+			RTW_PRINT_SEL(m, "SSID=%s\n", pmlmeinfo->network.Ssid.Ssid);
+			RTW_PRINT_SEL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
+			RTW_PRINT_SEL(m, "Supported rate=");
+			for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
+				if (pmlmeinfo->SupportedRates_infra_ap[i] == 0)
+					break;
+				RTW_PRINT_SEL(m, " 0x%x", pmlmeinfo->SupportedRates_infra_ap[i]);
+			}
+			RTW_PRINT_SEL(m, "\n");
+#ifdef CONFIG_80211N_HT
+			if (pmlmeinfo->ht_vht_received & BIT(0)) {
+				RTW_PRINT_SEL(m, "Supported MCS set=");
+				for (i = 0; i < 16 ; i++)
+					RTW_PRINT_SEL(m, " 0x%02x",  phtpriv->MCS_set_infra_ap[i]);
+				RTW_PRINT_SEL(m, "\n");
+				RTW_PRINT_SEL(m, "highest supported data rate=0x%x\n", phtpriv->rx_highest_data_rate_infra_ap);
+				RTW_PRINT_SEL(m, "HT_supported_channel_width_set=0x%x\n", phtpriv->channel_width_infra_ap);
+				RTW_PRINT_SEL(m, "sgi_20m=%d, sgi_40m=%d\n", phtpriv->sgi_20m_infra_ap, phtpriv->sgi_40m_infra_ap);
+				RTW_PRINT_SEL(m, "ldpc_cap=0x%x, stbc_cap=0x%x\n", phtpriv->ldpc_cap_infra_ap, phtpriv->stbc_cap_infra_ap);
+				RTW_PRINT_SEL(m, "HT_number_of_stream=%d\n", phtpriv->Rx_ss_infra_ap);
+			}
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+			if (pmlmeinfo->ht_vht_received & BIT(1)) {
+				RTW_PRINT_SEL(m, "VHT_supported_channel_width_set=0x%x\n", pvhtpriv->channel_width_infra_ap);
+				RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", pvhtpriv->ldpc_cap_infra_ap, pvhtpriv->stbc_cap_infra_ap, pvhtpriv->beamform_cap_infra_ap);
+				RTW_PRINT_SEL(m, "Rx_vht_mcs_map=0x%x, Tx_vht_mcs_map=0x%x\n", *(u16 *)pvhtpriv->vht_mcs_map_infra_ap, *(u16 *)pvhtpriv->vht_mcs_map_tx_infra_ap);
+				RTW_PRINT_SEL(m, "VHT_number_of_stream=%d\n", pvhtpriv->number_of_streams_infra_ap);
+			}
+#endif
+		} else
+			RTW_PRINT_SEL(m, "can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
+	} else
+		RTW_PRINT_SEL(m, "this only applies to STA mode\n");
+	return 0;
+}
+
+#endif /* ROKU_PRIVATE */
 
 int proc_get_ap_info(struct seq_file *m, void *v)
 {
@@ -1503,8 +1617,14 @@ int proc_get_ap_info(struct seq_file *m, void *v)
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
+	/* ap vendor */
+	char vendor[VENDOR_NAME_LEN] = {0};
+	get_assoc_AP_Vendor(vendor,pmlmeinfo->assoc_AP_vendor);
+	RTW_PRINT_SEL(m,"AP Vendor %s\n", vendor);
+
 	psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
 	if (psta) {
 		RTW_PRINT_SEL(m, "SSID=%s\n", cur_network->network.Ssid.Ssid);
@@ -1526,7 +1646,6 @@ int proc_get_ap_info(struct seq_file *m, void *v)
 		RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", psta->vhtpriv.ldpc_cap, psta->vhtpriv.stbc_cap, psta->vhtpriv.beamform_cap);
 		RTW_PRINT_SEL(m, "vht_mcs_map=0x%x, vht_highest_rate=0x%x, vht_ampdu_len=%d\n", *(u16 *)psta->vhtpriv.vht_mcs_map, psta->vhtpriv.vht_highest_rate, psta->vhtpriv.ampdu_len);
 #endif
-
 		sta_rx_reorder_ctl_dump(m, psta);
 	} else
 		RTW_PRINT_SEL(m, "can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
@@ -1550,7 +1669,7 @@ ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t
 	if (buffer && !copy_from_user(cmd, buffer, count)) {
 		int num = sscanf(cmd, "%hhx", &cnt);
 
-		if (0 == cnt) {
+		if (num == 1 && cnt == 0) {
 			precvpriv->dbg_rx_ampdu_drop_count = 0;
 			precvpriv->dbg_rx_ampdu_forced_indicate_count = 0;
 			precvpriv->dbg_rx_ampdu_loss_count = 0;
@@ -1572,6 +1691,14 @@ int proc_get_trx_info(struct seq_file *m, void *v)
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	struct recv_priv  *precvpriv = &padapter->recvpriv;
 	struct hw_xmit *phwxmit;
+	u16 vo_params[4], vi_params[4], be_params[4], bk_params[4];
+
+	padapter->hal_func.read_wmmedca_reg(padapter, vo_params, vi_params, be_params, bk_params);
+
+	RTW_PRINT_SEL(m, "wmm_edca_vo, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", vo_params[0], vo_params[1], vo_params[2], vo_params[3]);
+	RTW_PRINT_SEL(m, "wmm_edca_vi, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", vi_params[0], vi_params[1], vi_params[2], vi_params[3]);
+	RTW_PRINT_SEL(m, "wmm_edca_be, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", be_params[0], be_params[1], be_params[2], be_params[3]);
+	RTW_PRINT_SEL(m, "wmm_edca_bk, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", bk_params[0], bk_params[1], bk_params[2], bk_params[3]);
 
 	dump_os_queue(m, padapter);
 
@@ -1610,43 +1737,6 @@ int proc_get_trx_info(struct seq_file *m, void *v)
 	return 0;
 }
 
-int proc_get_dis_pwt(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 dis_pwt = 0;
-	rtw_hal_get_def_var(padapter, HAL_DEF_DBG_DIS_PWT, &(dis_pwt));
-	RTW_PRINT_SEL(m, " Tx Power training mode:%s\n", (dis_pwt == _TRUE) ? "Disable" : "Enable");
-	return 0;
-}
-ssize_t proc_set_dis_pwt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
-{
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	char tmp[4] = {0};
-	u8 dis_pwt = 0;
-
-	if (count < 1)
-		return -EFAULT;
-
-	if (count > sizeof(tmp)) {
-		rtw_warn_on(1);
-		return -EFAULT;
-	}
-
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhx", &dis_pwt);
-		RTW_INFO("Set Tx Power training mode:%s\n", (dis_pwt == _TRUE) ? "Disable" : "Enable");
-
-		if (num >= 1)
-			rtw_hal_set_def_var(padapter, HAL_DEF_DBG_DIS_PWT, &(dis_pwt));
-	}
-
-	return count;
-
-}
-
 int proc_get_rate_ctl(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
@@ -1669,14 +1759,21 @@ int proc_get_rate_ctl(struct seq_file *m, void *v)
 	return 0;
 }
 
+#ifdef 	CONFIG_PHDYM_FW_FIXRATE
+void phydm_fw_fix_rate(void *dm_void, u8 en, u8	macid, u8 bw, u8 rate);
+#endif
 ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	char tmp[32];
-	u8 fix_rate;
-	u8 data_fb;
+	u8 fix_rate = 0xFF;
+#ifdef 	CONFIG_PHDYM_FW_FIXRATE
+	u8 bw = 0;
+#else
+	u8 data_fb = 0;
+#endif
 
 	if (count < 1)
 		return -EFAULT;
@@ -1687,7 +1784,56 @@ ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t c
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
+#ifdef 	CONFIG_PHDYM_FW_FIXRATE
+		struct dm_struct *dm = adapter_to_phydm(adapter);
+		u8 en = 1, macid = 255;
+		_irqL	irqL;
+		_list	*plist, *phead;
+		struct sta_info *psta = NULL;
+		struct sta_priv	*pstapriv = &(adapter->stapriv);
+		u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+		u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+		uint mac_id[NUM_STA];
+		int i, macid_rec_idx = 0;
+		int num = sscanf(tmp, "%hhx %hhu %hhu", &fix_rate, &bw, &macid);
+
+		if (num < 1) {
+			RTW_INFO("Invalid input!! \"ex: echo <rate> <bw> <macid> > /proc/.../rate_ctl\"\n");
+			return count;
+		}
+
+		if ((fix_rate == 0) || (fix_rate == 0xFF))
+			en = 0;
+			
+		if (macid != 255) {
+			RTW_INFO("Call phydm_fw_fix_rate()--en[%d] mac_id[%d] bw[%d] fix_rate[%d]\n", en, macid, bw, fix_rate);
+			phydm_fw_fix_rate(dm, en, macid, bw, fix_rate);
+			return count;
+		}
+
+		/*	no specific macid, apply to all macids except bc/mc macid */
+		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
+		for (i = 0; i < NUM_STA; i++) {
+			phead = &(pstapriv->sta_hash[i]);
+			plist = get_next(phead);
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
+				plist = get_next(plist);
+				if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) !=  _TRUE)
+					&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
+					&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), ETH_ALEN) != _TRUE)) {
+						mac_id[macid_rec_idx] = psta->cmn.mac_id;
+						macid_rec_idx++;
+				}
+			}
+		}
+		_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
+		for (i = 0; i < macid_rec_idx; i++) {
+			RTW_INFO("Call phydm_fw_fix_rate()--en[%d] mac_id[%d] bw[%d] fix_rate[%d]\n", en, mac_id[i], bw, fix_rate);
+			phydm_fw_fix_rate(dm, en, mac_id[i], bw, fix_rate);
+		}
+#else
 		int num = sscanf(tmp, "%hhx %hhu", &fix_rate, &data_fb);
 
 		if (num >= 1) {
@@ -1704,6 +1850,7 @@ ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t c
 		}
 		if (num >= 2)
 			adapter->data_fb = data_fb ? 1 : 0;
+#endif
 	}
 
 	return count;
@@ -1714,8 +1861,6 @@ int proc_get_bmc_tx_rate(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
-	struct sta_info *psta = NULL;
 
 	if (!MLME_IS_AP(adapter) && !MLME_IS_MESH(adapter)) {
 		RTW_PRINT_SEL(m, "[ERROR] Not in SoftAP/Mesh mode !!\n");
@@ -1730,7 +1875,6 @@ ssize_t proc_set_bmc_tx_rate(struct file *file, const char __user *buffer, size_
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	char tmp[32];
 	u8 bmc_tx_rate;
 
@@ -1759,7 +1903,6 @@ ssize_t proc_set_bmc_tx_rate(struct file *file, const char __user *buffer, size_
 int proc_get_tx_power_offset(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
-	int i;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
 	RTW_PRINT_SEL(m, "Tx power offset - %u\n", adapter->power_offset);
@@ -1876,9 +2019,10 @@ ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_
 
 		int num = sscanf(tmp, "%hhx", &dump_rx_cnt_mode);
 
-		rtw_dump_phy_rxcnts_preprocess(adapter, dump_rx_cnt_mode);
-		adapter->dump_rx_cnt_mode = dump_rx_cnt_mode;
-
+		if (num == 1) {
+			rtw_dump_phy_rxcnts_preprocess(adapter, dump_rx_cnt_mode);
+			adapter->dump_rx_cnt_mode = dump_rx_cnt_mode;
+		}
 	}
 
 	return count;
@@ -1910,10 +2054,7 @@ bool rtw_fwdl_test_trigger_wintint_rdy_fail(void)
 
 ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	int num;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1924,7 +2065,7 @@ ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, si
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count))
-		num = sscanf(tmp, "%hhu %hhu", &fwdl_test_chksum_fail, &fwdl_test_wintint_rdy_fail);
+		sscanf(tmp, "%hhu %hhu", &fwdl_test_chksum_fail, &fwdl_test_wintint_rdy_fail);
 
 	return count;
 }
@@ -1943,10 +2084,7 @@ bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void)
 
 ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	int num;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1957,35 +2095,21 @@ ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *bu
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count))
-		num = sscanf(tmp, "%hhu", &del_rx_ampdu_test_no_tx_fail);
+		sscanf(tmp, "%hhu", &del_rx_ampdu_test_no_tx_fail);
 
 	return count;
 }
 
-#ifdef CONFIG_DFS_MASTER
-int proc_get_dfs_master_test_case(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-
-	RTW_PRINT_SEL(m, "%-24s %-19s\n", "radar_detect_trigger_non", "choose_dfs_ch_first");
-	RTW_PRINT_SEL(m, "%24hhu %19hhu\n"
-		, rfctl->dbg_dfs_master_radar_detect_trigger_non
-		, rfctl->dbg_dfs_master_choose_dfs_ch_first
-	);
+static u32 g_wait_hiq_empty_ms = 0;
 
-	return 0;
+u32 rtw_get_wait_hiq_empty_ms(void)
+{
+	return g_wait_hiq_empty_ms;
 }
 
-ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = data;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	char tmp[32];
-	u8 radar_detect_trigger_non;
-	u8 choose_dfs_ch_first;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1995,32 +2119,34 @@ ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buff
 		return -EFAULT;
 	}
 
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		int num = sscanf(tmp, "%hhu %hhu", &radar_detect_trigger_non, &choose_dfs_ch_first);
-
-		if (num >= 1)
-			rfctl->dbg_dfs_master_radar_detect_trigger_non = radar_detect_trigger_non;
-		if (num >= 2)
-			rfctl->dbg_dfs_master_choose_dfs_ch_first = choose_dfs_ch_first;
-	}
+	if (buffer && !copy_from_user(tmp, buffer, count))
+		sscanf(tmp, "%u", &g_wait_hiq_empty_ms);
 
 	return count;
 }
-#endif /* CONFIG_DFS_MASTER */
 
-static u32 g_wait_hiq_empty_ms = 0;
+static systime sta_linking_test_start_time = 0;
+static u32 sta_linking_test_wait_ms = 0;
+static u8 sta_linking_test_force_fail = 0;
 
-u32 rtw_get_wait_hiq_empty_ms(void)
+void rtw_sta_linking_test_set_start(void)
 {
-	return g_wait_hiq_empty_ms;
+	sta_linking_test_start_time = rtw_get_current_time();
 }
 
-ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+bool rtw_sta_linking_test_wait_done(void)
+{
+	return rtw_get_passing_time_ms(sta_linking_test_start_time) >= sta_linking_test_wait_ms;
+}
+
+bool rtw_sta_linking_test_force_fail(void)
+{
+	return sta_linking_test_force_fail;
+}
+
+ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
-	int num;
 
 	if (count < 1)
 		return -EFAULT;
@@ -2030,35 +2156,36 @@ ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, si
 		return -EFAULT;
 	}
 
-	if (buffer && !copy_from_user(tmp, buffer, count))
-		num = sscanf(tmp, "%u", &g_wait_hiq_empty_ms);
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		u32 wait_ms = 0;
+		u8 force_fail = 0;
+		int num = sscanf(tmp, "%u %hhu", &wait_ms, &force_fail);
+
+		if (num >= 1)
+			sta_linking_test_wait_ms = wait_ms;
+		if (num >= 2)
+			sta_linking_test_force_fail = force_fail;
+	}
 
 	return count;
 }
 
-static systime sta_linking_test_start_time = 0;
-static u32 sta_linking_test_wait_ms = 0;
-static u8 sta_linking_test_force_fail = 0;
-
-void rtw_sta_linking_test_set_start(void)
-{
-	sta_linking_test_start_time = rtw_get_current_time();
-}
+#ifdef CONFIG_AP_MODE
+static u16 ap_linking_test_force_auth_fail = 0;
+static u16 ap_linking_test_force_asoc_fail = 0;
 
-bool rtw_sta_linking_test_wait_done(void)
+u16 rtw_ap_linking_test_force_auth_fail(void)
 {
-	return rtw_get_passing_time_ms(sta_linking_test_start_time) >= sta_linking_test_wait_ms;
+	return ap_linking_test_force_auth_fail;
 }
 
-bool rtw_sta_linking_test_force_fail(void)
+u16 rtw_ap_linking_test_force_asoc_fail(void)
 {
-	return sta_linking_test_force_fail;
+	return ap_linking_test_force_asoc_fail;
 }
 
-ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_ap_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = data;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
 
 	if (count < 1)
@@ -2070,18 +2197,19 @@ ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer,
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		u32 wait_ms = 0;
-		u8 force_fail = 0;
-		int num = sscanf(tmp, "%u %hhu", &wait_ms, &force_fail);
+		u16 force_auth_fail = 0;
+		u16 force_asoc_fail = 0;
+		int num = sscanf(tmp, "%hu %hu", &force_auth_fail, &force_asoc_fail);
 
 		if (num >= 1)
-			sta_linking_test_wait_ms = wait_ms;
+			ap_linking_test_force_auth_fail = force_auth_fail;
 		if (num >= 2)
-			sta_linking_test_force_fail = force_fail;
+			ap_linking_test_force_asoc_fail = force_asoc_fail;
 	}
 
 	return count;
 }
+#endif /* CONFIG_AP_MODE */
 
 int proc_get_ps_dbg_info(struct seq_file *m, void *v)
 {
@@ -2143,7 +2271,7 @@ ssize_t proc_set_ps_dbg_info(struct file *file, const char __user *buffer, size_
 
 		int num = sscanf(tmp, "%hhx", &ps_dbg_cmd_id);
 
-		if (ps_dbg_cmd_id == 1) /*Clean all*/
+		if (num == 1 && ps_dbg_cmd_id == 1) /*Clean all*/
 			_rtw_memset(pdbgpriv, 0, sizeof(struct debug_priv));
 
 	}
@@ -2459,7 +2587,7 @@ ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t
 
 		int num = sscanf(tmp, "%d ", &enable);
 
-		if (regsty && enable <= 1) {
+		if (num == 1 && regsty && enable <= 1) {
 			regsty->check_hw_status = enable;
 			RTW_INFO("check_hw_status=%d\n", regsty->check_hw_status);
 		}
@@ -2468,14 +2596,68 @@ ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t
 	return count;
 }
 
-int proc_get_trx_info_debug(struct seq_file *m, void *v)
+#ifdef CONFIG_HUAWEI_PROC
+int proc_get_huawei_trx_info(struct seq_file *sel, void *v)
 {
-	struct net_device *dev = m->private;
+	struct net_device *dev = sel->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct dm_struct *dm = adapter_to_phydm(padapter);
+	struct sta_info *psta;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct ra_sta_info *ra_info;
+	u8 curr_tx_sgi = _FALSE;
+	u8 curr_tx_rate = 0;
+	u8 mac_id;
+#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
+	u8 isCCKrate, rf_path;
+	PHAL_DATA_TYPE	pHalData =  GET_HAL_DATA(padapter);
+	struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
+#endif
 
-	int i;
+	if (!dm->is_linked) {
+		RTW_PRINT_SEL(sel, "NO link\n\n");
+		return 0;
+	}
+
+	/*============  tx info ============	*/
+	for (mac_id = 0; mac_id < macid_ctl->num; mac_id++) {
+		if (rtw_macid_is_used(macid_ctl, mac_id) && !rtw_macid_is_bmc(macid_ctl, mac_id)) {
+			psta = macid_ctl->sta[mac_id];
+			if (!psta)
+				continue;
+
+			RTW_PRINT_SEL(sel, "STA [" MAC_FMT "]\n", MAC_ARG(psta->cmn.mac_addr));
+
+			ra_info = &psta->cmn.ra_info;
+			curr_tx_sgi = rtw_get_current_tx_sgi(padapter, psta);
+			curr_tx_rate = rtw_get_current_tx_rate(padapter, psta);
+			RTW_PRINT_SEL(sel, "curr_tx_rate : %s (%s)\n",
+					HDATA_RATE(curr_tx_rate), (curr_tx_sgi) ? "S" : "L");
+			RTW_PRINT_SEL(sel, "curr_tx_bw : %s\n", ch_width_str(ra_info->curr_tx_bw));
+		}
+	}
+
+	/*============  rx info ============	*/
+	RTW_PRINT_SEL(sel, "rx_rate : %s\n", HDATA_RATE(dm->rx_rate));
+#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
+	isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
+
+	for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
+		if (!isCCKrate)
+			_RTW_PRINT_SEL(sel , "RF_PATH_%d : rx_ofdm_pwr:%d(dBm), rx_ofdm_snr:%d(dB)\n",
+				rf_path, psample_pkt_rssi->ofdm_pwr[rf_path], psample_pkt_rssi->ofdm_snr[rf_path]);
+	}
+#endif
+	RTW_PRINT_SEL(sel, "\n");
+	return 0;
+}
+#endif /* CONFIG_HUAWEI_PROC */
 
+int proc_get_trx_info_debug(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
 	/*============  tx info ============	*/
 	rtw_hal_get_def_var(padapter, HW_DEF_RA_INFO_DUMP, m);
@@ -2483,7 +2665,6 @@ int proc_get_trx_info_debug(struct seq_file *m, void *v)
 	/*============  rx info ============	*/
 	rtw_hal_set_odm_var(padapter, HAL_ODM_RX_INFO_DUMP, m, _FALSE);
 
-
 	return 0;
 }
 
@@ -2491,14 +2672,11 @@ int proc_get_rx_signal(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
 	RTW_PRINT_SEL(m, "rssi:%d\n", padapter->recvpriv.rssi);
-	/* RTW_PRINT_SEL(m, "rxpwdb:%d\n", padapter->recvpriv.rxpwdb); */
-	RTW_PRINT_SEL(m, "signal_strength:%u\n", padapter->recvpriv.signal_strength);
-	RTW_PRINT_SEL(m, "signal_qual:%u\n", padapter->recvpriv.signal_qual);
 #ifdef CONFIG_MP_INCLUDED
 	if (padapter->registrypriv.mp_mode == 1) {
+		struct dm_struct *odm = adapter_to_phydm(padapter);
 		if (padapter->mppriv.antenna_rx == ANTENNA_A)
 			RTW_PRINT_SEL(m, "Antenna: A\n");
 		else if (padapter->mppriv.antenna_rx == ANTENNA_B)
@@ -2515,9 +2693,16 @@ int proc_get_rx_signal(struct seq_file *m, void *v)
 			RTW_PRINT_SEL(m, "Antenna: CD\n");
 		else
 			RTW_PRINT_SEL(m, "Antenna: __\n");
+
+		RTW_PRINT_SEL(m, "rx_rate = %s\n", HDATA_RATE(odm->rx_rate));
 		return 0;
-	}
+	} else 
 #endif
+	{
+		/* RTW_PRINT_SEL(m, "rxpwdb:%d\n", padapter->recvpriv.rxpwdb); */
+		RTW_PRINT_SEL(m, "signal_strength:%u\n", padapter->recvpriv.signal_strength);
+		RTW_PRINT_SEL(m, "signal_qual:%u\n", padapter->recvpriv.signal_qual);
+	}
 #ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
 	rtw_odm_get_perpkt_rssi(m, padapter);
 	rtw_get_raw_rssi_info(m, padapter);
@@ -2544,9 +2729,12 @@ ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t
 
 		int num = sscanf(tmp, "%u %u", &is_signal_dbg, &signal_strength);
 
+		if (num < 1)
+			return count;
+
 		is_signal_dbg = is_signal_dbg == 0 ? 0 : 1;
 
-		if (is_signal_dbg && num != 2)
+		if (is_signal_dbg && num < 2)
 			return count;
 
 		signal_strength = signal_strength > 100 ? 100 : signal_strength;
@@ -2564,6 +2752,36 @@ ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t
 	return count;
 
 }
+
+int proc_get_mac_rptbuf(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	u16 i;
+	u16 mac_id;
+	u32 shcut_addr = 0;
+	u32 read_addr = 0;
+#ifdef CONFIG_RTL8814A
+	RTW_PRINT_SEL(m, "TX ShortCut:\n");
+	for (mac_id = 0; mac_id < 64; mac_id++) {
+		rtw_write16(padapter, 0x140, 0x662 | ((mac_id & BIT5) >> 5));
+		shcut_addr = 0x8000;
+		shcut_addr = shcut_addr | ((mac_id & 0x1f) << 7);
+		RTW_PRINT_SEL(m, "mac_id=%d, 0x140=%x =>\n", mac_id, 0x662 | ((mac_id & BIT5) >> 5));
+		for (i = 0; i < 30; i++) {
+			read_addr = 0;
+			read_addr = shcut_addr | (i << 2);
+			RTW_PRINT_SEL(m, "i=%02d: MAC_%04x= %08x ", i, read_addr, rtw_read32(padapter, read_addr));
+			if (!((i + 1) % 4))
+				RTW_PRINT_SEL(m, "\n");
+			if (i == 29)
+				RTW_PRINT_SEL(m, "\n");
+		}
+	}
+#endif /* CONFIG_RTL8814A */
+	return 0;
+}
+
 #ifdef CONFIG_80211N_HT
 
 int proc_get_ht_enable(struct seq_file *m, void *v)
@@ -2598,7 +2816,7 @@ ssize_t proc_set_ht_enable(struct file *file, const char __user *buffer, size_t
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if (pregpriv && mode < 2) {
+		if ( num == 1 && pregpriv && mode < 2) {
 			pregpriv->ht_enable = mode;
 			RTW_INFO("ht_enable=%d\n", pregpriv->ht_enable);
 		}
@@ -2644,11 +2862,9 @@ ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t co
 		bw_5g = mode >> 4;
 		bw_2g = mode & 0x0f;
 
-		if (pregpriv && bw_2g <= 4 && bw_5g <= 4) {
-
+		if (num == 1 && pregpriv && bw_2g <= 4 && bw_5g <= 4) {
 			pregpriv->bw_mode = mode;
 			printk("bw_mode=0x%x\n", mode);
-
 		}
 	}
 
@@ -2688,7 +2904,7 @@ ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if (pregpriv && mode < 2) {
+		if (num == 1 && pregpriv && mode < 2) {
 			pregpriv->ampdu_enable = mode;
 			printk("ampdu_enable=%d\n", mode);
 		}
@@ -2699,34 +2915,6 @@ ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size
 
 }
 
-int proc_get_mac_rptbuf(struct seq_file *m, void *v)
-{
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	u16 i;
-	u16 mac_id;
-	u32 shcut_addr = 0;
-	u32 read_addr = 0;
-#ifdef CONFIG_RTL8814A
-	RTW_PRINT_SEL(m, "TX ShortCut:\n");
-	for (mac_id = 0; mac_id < 64; mac_id++) {
-		rtw_write16(padapter, 0x140, 0x662 | ((mac_id & BIT5) >> 5));
-		shcut_addr = 0x8000;
-		shcut_addr = shcut_addr | ((mac_id & 0x1f) << 7);
-		RTW_PRINT_SEL(m, "mac_id=%d, 0x140=%x =>\n", mac_id, 0x662 | ((mac_id & BIT5) >> 5));
-		for (i = 0; i < 30; i++) {
-			read_addr = 0;
-			read_addr = shcut_addr | (i << 2);
-			RTW_PRINT_SEL(m, "i=%02d: MAC_%04x= %08x ", i, read_addr, rtw_read32(padapter, read_addr));
-			if (!((i + 1) % 4))
-				RTW_PRINT_SEL(m, "\n");
-			if (i == 29)
-				RTW_PRINT_SEL(m, "\n");
-		}
-	}
-#endif /* CONFIG_RTL8814A */
-	return 0;
-}
 
 void dump_regsty_rx_ampdu_size_limit(void *sel, _adapter *adapter)
 {
@@ -2775,9 +2963,6 @@ ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t c
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct registry_priv	*pregpriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	char tmp[32];
 	u8 accept;
 	u8 size;
@@ -2802,9 +2987,9 @@ ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t c
 		rtw_rx_ampdu_apply(padapter);
 	}
 
-exit:
 	return count;
 }
+
 int proc_get_rx_ampdu_factor(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
@@ -3085,8 +3270,6 @@ int proc_get_en_fwps(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 	if (pregpriv)
 		RTW_PRINT_SEL(m, "check_fw_ps = %d , 1:enable get FW PS state , 0: disable get FW PS state\n"
@@ -3100,8 +3283,6 @@ ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t co
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	char tmp[32];
 	u32 mode;
 
@@ -3117,7 +3298,7 @@ ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t co
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if (pregpriv &&  mode < 2) {
+		if (num == 1 && pregpriv &&  mode < 2) {
 			pregpriv->check_fw_ps = mode;
 			RTW_INFO("pregpriv->check_fw_ps=%d\n", pregpriv->check_fw_ps);
 		}
@@ -3182,7 +3363,9 @@ void rtw_get_dft_phy_cap(void *sel, _adapter *adapter)
 	#ifdef CONFIG_80211AC_VHT
 	rtw_vht_use_default_setting(adapter);
 	#endif
+	#ifdef CONFIG_80211N_HT
 	rtw_dump_dft_phy_cap(sel, adapter);
+	#endif
 }
 
 void rtw_dump_drv_phy_cap(void *sel, _adapter *adapter)
@@ -3197,7 +3380,7 @@ void rtw_dump_drv_phy_cap(void *sel, _adapter *adapter)
 	RTW_PRINT_SEL(sel, "[DRV CAP] Tx Path Num Index : %d\n", (phy_spec->trx_cap >> 8) & 0xFF);/*Tx Path Num Index	[15:8]*/
 	RTW_PRINT_SEL(sel, "[DRV CAP] Rx Path Num Index : %d\n", (phy_spec->trx_cap & 0xFF));/*Rx Path Num Index	[7:0]*/
 	#endif
-
+	#ifdef CONFIG_80211N_HT
 	RTW_PRINT_SEL(sel, "[DRV CAP] STBC Capability : 0x%02x\n", pregistry_priv->stbc_cap);
 	RTW_PRINT_SEL(sel, "[DRV CAP] VHT STBC Tx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT1)) ? "V" : "X"); /*BIT1: Enable VHT STBC Tx*/
 	RTW_PRINT_SEL(sel, "[DRV CAP] VHT STBC Rx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT0)) ? "V" : "X"); /*BIT0: Enable VHT STBC Rx*/
@@ -3209,6 +3392,7 @@ void rtw_dump_drv_phy_cap(void *sel, _adapter *adapter)
 	RTW_PRINT_SEL(sel, "[DRV CAP] VHT LDPC Rx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT0)) ? "V" : "X"); /*BIT0: Enable VHT LDPC Rx*/
 	RTW_PRINT_SEL(sel, "[DRV CAP] HT LDPC Tx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT5)) ? "V" : "X"); /*BIT5: Enable HT LDPC Tx*/
 	RTW_PRINT_SEL(sel, "[DRV CAP] HT LDPC Rx : %s\n\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT4)) ? "V" : "X"); /*BIT4: Enable HT LDPC Rx*/
+	#endif /* CONFIG_80211N_HT */
 	#ifdef CONFIG_BEAMFORMING
 	#if 0
 	RTW_PRINT_SEL(sel, "[DRV CAP] TxBF parameter : 0x%08x\n", phy_spec->txbf_param);
@@ -3271,7 +3455,7 @@ ssize_t proc_set_stbc_cap(struct file *file, const char __user *buffer, size_t c
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if (pregpriv) {
+		if (num == 1 && pregpriv) {
 			pregpriv->stbc_cap = mode;
 			RTW_INFO("stbc_cap = 0x%02x\n", mode);
 		}
@@ -3311,7 +3495,7 @@ ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t co
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if (pregpriv && (mode == 0 || mode == 1 || mode == 2 || mode == 3)) {
+		if (num == 1 && pregpriv && (mode == 0 || mode == 1 || mode == 2 || mode == 3)) {
 			pregpriv->rx_stbc = mode;
 			printk("rx_stbc=%d\n", mode);
 		}
@@ -3352,7 +3536,7 @@ ssize_t proc_set_ldpc_cap(struct file *file, const char __user *buffer, size_t c
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if (pregpriv) {
+		if (num == 1 && pregpriv) {
 			pregpriv->ldpc_cap = mode;
 			RTW_INFO("ldpc_cap = 0x%02x\n", mode);
 		}
@@ -3393,7 +3577,7 @@ ssize_t proc_set_txbf_cap(struct file *file, const char __user *buffer, size_t c
 
 		int num = sscanf(tmp, "%d ", &mode);
 
-		if (pregpriv) {
+		if (num == 1 && pregpriv) {
 			pregpriv->beamform_cap = mode;
 			RTW_INFO("beamform_cap = 0x%02x\n", mode);
 		}
@@ -3468,7 +3652,8 @@ int proc_get_all_sta_info(struct seq_file *m, void *v)
 	int i;
 	_list	*plist, *phead;
 
-	RTW_PRINT_SEL(m, "sta_dz_bitmap=0x%x, tim_bitmap=0x%x\n", pstapriv->sta_dz_bitmap, pstapriv->tim_bitmap);
+	RTW_MAP_DUMP_SEL(m, "sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+	RTW_MAP_DUMP_SEL(m, "tim_bitmap=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
 
 	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
@@ -3488,6 +3673,10 @@ int proc_get_all_sta_info(struct seq_file *m, void *v)
 				RTW_PRINT_SEL(m, "rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
 				RTW_PRINT_SEL(m, "state=0x%x, aid=%d, macid=%d, raid=%d\n",
 					psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
+#ifdef CONFIG_RTS_FULL_BW
+				if(psta->vendor_8812)
+					RTW_PRINT_SEL(m,"Vendor Realtek 8812\n");
+#endif/*CONFIG_RTS_FULL_BW*/
 #ifdef CONFIG_80211N_HT
 				RTW_PRINT_SEL(m, "qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
 				RTW_PRINT_SEL(m, "bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n"
@@ -3496,6 +3685,11 @@ int proc_get_all_sta_info(struct seq_file *m, void *v)
 				RTW_PRINT_SEL(m, "tx_amsdu_enable = %d\n", psta->htpriv.tx_amsdu_enable);
 				RTW_PRINT_SEL(m, "agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
 #endif /* CONFIG_80211N_HT */
+#ifdef CONFIG_80211AC_VHT
+				RTW_PRINT_SEL(m, "vht_en=%d, vht_sgi_80m=%d\n", psta->vhtpriv.vht_option, psta->vhtpriv.sgi_80m);
+				RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", psta->vhtpriv.ldpc_cap, psta->vhtpriv.stbc_cap, psta->vhtpriv.beamform_cap);
+				RTW_PRINT_SEL(m, "vht_mcs_map=0x%x, vht_highest_rate=0x%x, vht_ampdu_len=%d\n", *(u16 *)psta->vhtpriv.vht_mcs_map, psta->vhtpriv.vht_highest_rate, psta->vhtpriv.ampdu_len);
+#endif
 				RTW_PRINT_SEL(m, "sleepq_len=%d\n", psta->sleepq_len);
 				RTW_PRINT_SEL(m, "sta_xmitpriv.vo_q_qcnt=%d\n", psta->sta_xmitpriv.vo_q.qcnt);
 				RTW_PRINT_SEL(m, "sta_xmitpriv.vi_q_qcnt=%d\n", psta->sta_xmitpriv.vi_q.qcnt);
@@ -3522,11 +3716,17 @@ int proc_get_all_sta_info(struct seq_file *m, void *v)
 				RTW_PRINT_SEL(m, "rx_uc_bytes=%llu\n", sta_rx_uc_bytes(psta));
 				RTW_PRINT_SEL(m, "rx_mc_bytes=%llu\n", psta->sta_stats.rx_mc_bytes);
 				RTW_PRINT_SEL(m, "rx_bc_bytes=%llu\n", psta->sta_stats.rx_bc_bytes);
-				RTW_PRINT_SEL(m, "rx_avg_tp =%d (Bps)\n", psta->cmn.rx_moving_average_tp);
+				if (psta->sta_stats.rx_tp_kbits >> 10)
+					RTW_PRINT_SEL(m, "rx_tp =%d (Mbps)\n", psta->sta_stats.rx_tp_kbits >> 10);
+				else
+					RTW_PRINT_SEL(m, "rx_tp =%d (Kbps)\n", psta->sta_stats.rx_tp_kbits);
 
 				RTW_PRINT_SEL(m, "tx_data_pkts=%llu\n", psta->sta_stats.tx_pkts);
 				RTW_PRINT_SEL(m, "tx_bytes=%llu\n", psta->sta_stats.tx_bytes);
-				RTW_PRINT_SEL(m, "tx_avg_tp =%d (MBps)\n", psta->cmn.tx_moving_average_tp);
+				if (psta->sta_stats.tx_tp_kbits >> 10)
+					RTW_PRINT_SEL(m, "tx_tp =%d (Mbps)\n", psta->sta_stats.tx_tp_kbits >> 10);
+				else
+					RTW_PRINT_SEL(m, "tx_tp =%d (Kbps)\n", psta->sta_stats.tx_tp_kbits);
 #ifdef CONFIG_RTW_80211K
 				RTW_PRINT_SEL(m, "rm_en_cap="RM_CAP_FMT"\n", RM_CAP_ARG(psta->rm_en_cap));
 #endif
@@ -3591,7 +3791,6 @@ int proc_get_best_channel(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	u32 i, best_channel_24G = 1, best_channel_5G = 36, index_24G = 0, index_5G = 0;
 
 	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
@@ -3647,7 +3846,6 @@ ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	char tmp[32];
 
 	if (count < 1)
@@ -3824,14 +4022,11 @@ int proc_get_sreset(struct seq_file *m, void *v)
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 
 	if (psrtpriv->dbg_sreset_ctrl == _TRUE) {
 		RTW_PRINT_SEL(m, "self_dect_tx_cnt:%llu\n", psrtpriv->self_dect_tx_cnt);
 		RTW_PRINT_SEL(m, "self_dect_rx_cnt:%llu\n", psrtpriv->self_dect_rx_cnt);
 		RTW_PRINT_SEL(m, "self_dect_fw_cnt:%llu\n", psrtpriv->self_dect_fw_cnt);
-		RTW_PRINT_SEL(m, "self_dect_scan_cnt:%llu\n", psrtpriv->self_dect_scan_cnt);
-		RTW_PRINT_SEL(m, "txbuf_empty_cnt:%llu\n", psrtpriv->txbuf_empty_cnt);
 		RTW_PRINT_SEL(m, "tx_dma_status_cnt:%llu\n", psrtpriv->tx_dma_status_cnt);
 		RTW_PRINT_SEL(m, "rx_dma_status_cnt:%llu\n", psrtpriv->rx_dma_status_cnt);
 		RTW_PRINT_SEL(m, "self_dect_case:%d\n", psrtpriv->self_dect_case);
@@ -3861,9 +4056,12 @@ ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t cou
 
 		int num = sscanf(tmp, "%d", &trigger_point);
 
+		if (num < 1)
+			return count;
+
 		if (trigger_point == SRESET_TGP_NULL)
 			rtw_hal_sreset_reset(padapter);
-		else if (trigger_point == 99)
+		else if (trigger_point == SRESET_TGP_INFO)
 			psrtpriv->dbg_sreset_ctrl = _TRUE;
 		else
 			sreset_set_trigger_point(padapter, trigger_point);
@@ -3876,91 +4074,245 @@ ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t cou
 
 #ifdef CONFIG_PCI_HCI
 
-int proc_get_pci_aspm(struct seq_file *m, void *v)
+ssize_t proc_set_pci_bridge_conf_space(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
-	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct pci_priv	*pcipriv = &(pdvobjpriv->pcipriv);
-	u8 tmp8 = 0;
-	u16 tmp16 = 0;
-	u32 tmp32 = 0;
-	u8 l1_idle = 0;
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv       *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct pci_dev  *pdev = pdvobjpriv->ppcidev;
+	struct pci_dev  *bridge_pdev = pdev->bus->self;
 
+	char tmp[32] = { 0 };
+	int num;
 
-	RTW_PRINT_SEL(m, "***** ASPM Capability *****\n");
+	u32 reg = 0, value = 0;
 
-	pci_read_config_dword(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCAP, &tmp32);
+	if (count < 1)
+		return -EFAULT;
 
-	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp32&PCI_EXP_LNKCAP_CLKPM) ? "Enable" : "Disable");
-	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp32&BIT10) ? "Enable" : "Disable");
-	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp32&BIT11) ? "Enable" : "Disable");
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
 
-	tmp8 = rtw_hal_pci_l1off_capability(padapter);
-	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", tmp8 ? "Enable" : "Disable");
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-	RTW_PRINT_SEL(m, "***** ASPM CTRL Reg *****\n");
+		num = sscanf(tmp, "%x %x", &reg, &value);
+		if (num != 2) {
+			RTW_INFO("invalid parameter!\n");
+			return count;
+		}
 
-	pci_read_config_word(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCTL, &tmp16);
+		if (reg >= 0x1000) {
+			RTW_INFO("invalid register!\n");
+			return count;
+		}
 
-	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp16&PCI_EXP_LNKCTL_CLKREQ_EN) ? "Enable" : "Disable");
-	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp16&BIT0) ? "Enable" : "Disable");
-	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp16&BIT1) ? "Enable" : "Disable");
+		if (value > 0xFF) {
+			RTW_INFO("invalid value! Only one byte\n");
+			return count;
+		}
 
-	tmp8 = rtw_hal_pci_l1off_nic_support(padapter);
-	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", tmp8 ? "Enable" : "Disable");
+		RTW_INFO(FUNC_ADPT_FMT ": register 0x%x value 0x%x\n",
+			FUNC_ADPT_ARG(padapter), reg, value);
 
-	RTW_PRINT_SEL(m, "***** ASPM Backdoor *****\n");
+		pci_write_config_byte(bridge_pdev, reg, value);
+	}
+	return count;
+}
 
-	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
-	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp8 & BIT4) ? "Enable" : "Disable");
 
-	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x70f);
-	l1_idle = tmp8 & 0x38;
-	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp8&BIT7) ? "Enable" : "Disable");
+int proc_get_pci_bridge_conf_space(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	struct dvobj_priv       *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct pci_dev  *pdev = pdvobjpriv->ppcidev;
+	struct pci_dev  *bridge_pdev = pdev->bus->self;
 
-	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
-	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp8 & BIT3) ? "Enable" : "Disable");
+	u32 tmp[4] = { 0 };
+	u32 i, j;
 
-	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x718);
-	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", (tmp8 & BIT5) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "\n*****  PCI Host Device Configuration Space*****\n\n");
 
-	RTW_PRINT_SEL(m, "********* MISC **********\n");
-	RTW_PRINT_SEL(m, "ASPM L1 Idel Time: 0x%x\n", l1_idle>>3);
-	RTW_PRINT_SEL(m, "*************************\n");
+	for (i = 0; i < 0x1000; i += 0x10) {
+		for (j = 0 ; j < 4 ; j++)
+			pci_read_config_dword(bridge_pdev, i + j * 4, tmp+j);
 
+		RTW_PRINT_SEL(m, "%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
+			i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
+			tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
+			tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
+			tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
+	}
 	return 0;
 }
 
-int proc_get_rx_ring(struct seq_file *m, void *v)
+
+ssize_t proc_set_pci_conf_space(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
-	_irqL irqL;
-	struct net_device *dev = m->private;
-	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
-	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-	struct recv_priv *precvpriv = &padapter->recvpriv;
-	struct rtw_rx_ring *rx_ring = &precvpriv->rx_ring[RX_MPDU_QUEUE];
-	int i, j;
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv       *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct pci_dev  *pdev = pdvobjpriv->ppcidev;
 
-	RTW_PRINT_SEL(m, "rx ring (%p)\n", rx_ring);
-	RTW_PRINT_SEL(m, "  dma: 0x%08x\n", (int) rx_ring->dma);
-	RTW_PRINT_SEL(m, "  idx: %d\n", rx_ring->idx);
+	char tmp[32] = { 0 };
+	int num;
 
-	_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
-	for (i = 0; i < precvpriv->rxringcount; i++) {
-#ifdef CONFIG_TRX_BD_ARCH
-		struct rx_buf_desc *entry = &rx_ring->buf_desc[i];
-#else
-		struct recv_stat *entry = &rx_ring->desc[i];
-#endif
-		struct sk_buff *skb = rx_ring->rx_buf[i];
+	u32 reg = 0, value = 0;
 
-		RTW_PRINT_SEL(m, "  desc[%03d]: %p, rx_buf[%03d]: 0x%08x\n",
-			i, entry, i, cpu_to_le32(*((dma_addr_t *)skb->cb)));
+	if (count < 1)
+		return -EFAULT;
 
-		for (j = 0; j < sizeof(*entry) / 4; j++) {
-			if ((j % 4) == 0)
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		num = sscanf(tmp, "%x %x", &reg, &value);
+
+		if (num != 2) {
+			RTW_INFO("invalid parameter!\n");
+			return count;
+		}
+
+
+		if (reg >= 0x1000) {
+			RTW_INFO("invalid register!\n");
+			return count;
+		}
+
+		if (value > 0xFF) {
+			RTW_INFO("invalid value! Only one byte\n");
+			return count;
+		}
+
+		RTW_INFO(FUNC_ADPT_FMT ": register 0x%x value 0x%x\n",
+			FUNC_ADPT_ARG(padapter), reg, value);
+
+		pci_write_config_byte(pdev, reg, value);
+
+
+	}
+	return count;
+}
+
+
+int proc_get_pci_conf_space(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	struct dvobj_priv       *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct pci_dev  *pdev = pdvobjpriv->ppcidev;
+	struct pci_dev  *bridge_pdev = pdev->bus->self;
+
+	u32 tmp[4] = { 0 };
+	u32 i, j;
+
+	RTW_PRINT_SEL(m, "\n*****  PCI Device Configuration Space *****\n\n");
+
+	for (i = 0; i < 0x1000; i += 0x10) {
+		for (j = 0 ; j < 4 ; j++)
+			pci_read_config_dword(pdev, i + j * 4, tmp+j);
+
+		RTW_PRINT_SEL(m, "%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
+			i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
+			tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
+			tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
+			tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
+	}
+
+	return 0;
+}
+
+
+int proc_get_pci_aspm(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	struct pci_priv	*pcipriv = &(pdvobjpriv->pcipriv);
+	u8 tmp8 = 0;
+	u16 tmp16 = 0;
+	u32 tmp32 = 0;
+	u8 l1_idle = 0;
+
+
+	RTW_PRINT_SEL(m, "***** ASPM Capability *****\n");
+
+	pci_read_config_dword(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCAP, &tmp32);
+
+	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp32&PCI_EXP_LNKCAP_CLKPM) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp32&BIT10) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp32&BIT11) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_l1off_capability(padapter);
+	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", tmp8 ? "Enable" : "Disable");
+
+	RTW_PRINT_SEL(m, "***** ASPM CTRL Reg *****\n");
+
+	pci_read_config_word(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCTL, &tmp16);
+
+	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp16&PCI_EXP_LNKCTL_CLKREQ_EN) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp16&BIT0) ? "Enable" : "Disable");
+	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp16&BIT1) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_l1off_nic_support(padapter);
+	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", tmp8 ? "Enable" : "Disable");
+
+	RTW_PRINT_SEL(m, "***** ASPM Backdoor *****\n");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
+	RTW_PRINT_SEL(m, "CLK REQ:	%s\n", (tmp8 & BIT4) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x70f);
+	l1_idle = tmp8 & 0x38;
+	RTW_PRINT_SEL(m, "ASPM L0s:	%s\n", (tmp8&BIT7) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
+	RTW_PRINT_SEL(m, "ASPM L1:	%s\n", (tmp8 & BIT3) ? "Enable" : "Disable");
+
+	tmp8 = rtw_hal_pci_dbi_read(padapter, 0x718);
+	RTW_PRINT_SEL(m, "ASPM L1OFF:	%s\n", (tmp8 & BIT5) ? "Enable" : "Disable");
+
+	RTW_PRINT_SEL(m, "********* MISC **********\n");
+	RTW_PRINT_SEL(m, "ASPM L1 Idel Time: 0x%x\n", l1_idle>>3);
+	RTW_PRINT_SEL(m, "*************************\n");
+
+	return 0;
+}
+
+int proc_get_rx_ring(struct seq_file *m, void *v)
+{
+	_irqL irqL;
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
+	struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	struct rtw_rx_ring *rx_ring = &precvpriv->rx_ring[RX_MPDU_QUEUE];
+	int i, j;
+
+	RTW_PRINT_SEL(m, "rx ring (%p)\n", rx_ring);
+	RTW_PRINT_SEL(m, "  dma: 0x%08x\n", (int) rx_ring->dma);
+	RTW_PRINT_SEL(m, "  idx: %d\n", rx_ring->idx);
+
+	_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
+	for (i = 0; i < precvpriv->rxringcount; i++) {
+#ifdef CONFIG_TRX_BD_ARCH
+		struct rx_buf_desc *entry = &rx_ring->buf_desc[i];
+#else
+		struct recv_stat *entry = &rx_ring->desc[i];
+#endif
+		struct sk_buff *skb = rx_ring->rx_buf[i];
+
+		RTW_PRINT_SEL(m, "  desc[%03d]: %p, rx_buf[%03d]: 0x%08x\n",
+			i, entry, i, cpu_to_le32(*((dma_addr_t *)skb->cb)));
+
+		for (j = 0; j < sizeof(*entry) / 4; j++) {
+			if ((j % 4) == 0)
 				RTW_PRINT_SEL(m, "  0x%03x", j);
 
 			RTW_PRINT_SEL(m, " 0x%08x ", ((int *) entry)[j]);
@@ -4311,7 +4663,7 @@ ssize_t proc_set_wakeup_event(struct file *file, const char __user *buffer,
 	else
 		return -EFAULT;
 
-	if (wakeup_event <= 0x07) {
+	if (num == 1 && wakeup_event <= 0x07) {
 		registry_par->wakeup_event = wakeup_event;
 
 		if (wakeup_event & BIT(1))
@@ -4380,6 +4732,11 @@ ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,
 
 		num = sscanf(tmp, "%u", &is_high_active);
 
+		if (num != 1) {
+			RTW_INFO("Invalid format\n");
+			return count;
+		}
+
 		is_high_active = is_high_active == 0 ? 0 : 1;
 
 		pwrpriv->is_high_active = is_high_active;
@@ -4394,6 +4751,7 @@ ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,
 			rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
 		#else
 		val8 = (pwrpriv->is_high_active == 0) ? 1 : 0;
+		rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
 		rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
 		#endif
 		rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
@@ -4439,7 +4797,7 @@ int proc_get_p2p_wowlan_info(struct seq_file *m, void *v)
 	return 0;
 }
 #endif /* CONFIG_P2P_WOWLAN */
-
+#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
 int proc_get_new_bcn_max(struct seq_file *m, void *v)
 {
 	extern int new_bcn_max;
@@ -4466,14 +4824,14 @@ ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_
 
 	return count;
 }
-
+#endif
 #ifdef CONFIG_POWER_SAVING
 int proc_get_ps_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	u8 ips_mode = pwrpriv->ips_mode;
+	u8 ips_mode = pwrpriv->ips_mode_req;
 	u8 lps_mode = pwrpriv->power_mgnt;
 	u8 lps_level = pwrpriv->lps_level;
 	char *str = "";
@@ -4530,7 +4888,60 @@ int proc_get_ps_info(struct seq_file *m, void *v)
 	return 0;
 }
 
-#ifdef CONFIG_WMMPS_STA	
+ssize_t proc_set_ps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	struct _ADAPTER *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	char tmp[8];
+	int num = 0;
+	int mode = 0;
+	int en = 0;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%d %d", &mode, &en);
+	if (num >  2) {
+		RTW_ERR("%s: invalid parameter!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	if (num == 1 && mode == 0) {
+		/* back to original LPS/IPS Mode */
+		RTW_INFO("%s: back to original LPS/IPS Mode\n", __FUNCTION__);
+
+		rtw_pm_set_lps(adapter, adapter->registrypriv.power_mgnt);
+		
+		rtw_pm_set_ips(adapter, adapter->registrypriv.ips_mode);
+
+		goto exit;
+	}
+	
+	if (mode == 1) { 
+		/* LPS */
+		RTW_INFO("%s: LPS: %s, en=%d\n", __FUNCTION__, (en == 0) ? "disable":"enable", en);	
+		if (rtw_pm_set_lps(adapter, en) != 0 )
+			RTW_ERR("%s: invalid parameter, mode=%d, level=%d\n", __FUNCTION__, mode, en);
+		
+	} else if (mode == 2) {
+		/* IPS */
+		RTW_INFO("%s: IPS: %s, en=%d\n", __FUNCTION__, (en == 0) ? "disable":"enable", en);	
+		if (rtw_pm_set_ips(adapter, en) != 0 )
+			RTW_ERR("%s: invalid parameter, mode=%d, level=%d\n", __FUNCTION__, mode, en);
+	} else
+		RTW_ERR("%s: invalid parameter, mode = %d!\n", __FUNCTION__, mode);
+
+exit:
+	return count;
+}
+
+#ifdef CONFIG_WMMPS_STA
 int proc_get_wmmps_info(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
@@ -4590,18 +5001,18 @@ ssize_t proc_set_wmmps_info(struct file *file, const char __user *buffer, size_t
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
 		int num = sscanf(tmp, "%hhu %hhx", &uapsd_max_sp_len_setting, &uapsd_ac_setting);
-		
+
 		if (pregpriv) {
-			if (num >= 1){	
+			if (num >= 1) {
 				pregpriv->uapsd_max_sp_len = uapsd_max_sp_len_setting;
 				RTW_INFO("uapsd_max_sp_len = %d\n", pregpriv->uapsd_max_sp_len);
 			}
 
-			if (num >= 2){
+			if (num >= 2) {
 				pregpriv->uapsd_ac_enable = uapsd_ac_setting;
 				RTW_INFO("uapsd_ac_enable = 0x%02x\n", pregpriv->uapsd_ac_enable);
 			}
-		}	
+		}
 	}
 
 	return count;
@@ -4642,11 +5053,11 @@ ssize_t proc_set_tdls_enable(struct file *file, const char __user *buffer, size_
 
 		int num = sscanf(tmp, "%d ", &en_tdls);
 
-		if (pregpriv) {
+		if (num == 1 && pregpriv) {
 			if (en_tdls > 0)
 				rtw_enable_tdls_func(padapter);
 			else
-				rtw_disable_tdls_func(padapter, _FALSE);
+				rtw_disable_tdls_func(padapter, _TRUE);
 		}
 	}
 
@@ -5065,7 +5476,6 @@ int proc_get_monitor(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
 	if (WIFI_MONITOR_STATE == get_fwstate(pmlmepriv)) {
 		RTW_PRINT_SEL(m, "Monitor mode : Enable\n");
@@ -5262,6 +5672,32 @@ ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t
 	return count;
 }
 
+ssize_t proc_set_tx_auth_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	int i = 0;
+	u8 ap_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		for(i=0;i<ETH_ALEN;i++){
+			ap_addr[i] = key_2char2num(tmp[i*2], tmp[i*2 + 1]);
+		}
+		//RTW_ERR("tmp: %s\n", tmp);
+
+		RTW_ERR("ap_addr: [%02x:%02x:%02x:%02x:%02x:%02x]\n", ap_addr[0], ap_addr[1], ap_addr[2], ap_addr[3], ap_addr[4], ap_addr[5]);
+	}
+
+	RTW_ERR("proc_set_tx_auth_monitor\n");
+	//issue_auth_for_monitor(padapter, (struct sta_info *)bc_addr, 0);
+	issue_auth_for_monitor(padapter, ap_addr, 0);
+
+	return count;
+}
+
 #ifdef CONFIG_IEEE80211W
 ssize_t proc_set_tx_sa_query(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
@@ -5298,11 +5734,11 @@ ssize_t proc_set_tx_sa_query(struct file *file, const char __user *buffer, size_
 	}
 
 	if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-	    && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && padapter->securitypriv.binstallBIPkey == _TRUE) {
+	    && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
 		RTW_INFO("STA:"MAC_FMT"\n", MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
 		/* TX unicast sa_query to AP */
 		issue_action_SA_Query(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, 0, (u8)key_type);
-	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE && padapter->securitypriv.binstallBIPkey == _TRUE) {
+	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
 		/* TX unicast sa_query to every client STA */
 		_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 		for (index = 0; index < NUM_STA; index++) {
@@ -5387,6 +5823,7 @@ ssize_t proc_set_tx_deauth(struct file *file, const char __user *buffer, size_t
 		/* TX unicast deauth to AP */
 		issue_deauth_11w(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, (u8)key_type);
 	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+		u8 updated = _FALSE;
 
 		if (key_type == 3)
 			issue_deauth_11w(padapter, bc_addr, 0, IEEE80211W_RIGHT_KEY);
@@ -5415,24 +5852,22 @@ ssize_t proc_set_tx_deauth(struct file *file, const char __user *buffer, size_t
 
 					psta = rtw_get_stainfo(pstapriv, &mac_addr[index][0]);
 					if (psta && key_type != IEEE80211W_WRONG_KEY && key_type != IEEE80211W_NO_KEY) {
-						u8 updated = _FALSE;
-
 						_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
 						if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
 							rtw_list_delete(&psta->asoc_list);
 							pstapriv->asoc_list_cnt--;
-							updated = ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
+							updated |= ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
 
 						}
 						_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-
-						associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
 					}
 
 					RTW_INFO("STA[%u]:"MAC_FMT"\n", index , MAC_ARG(&mac_addr[index][0]));
 				}
 			}
 		}
+
+		associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
 	}
 
 	return count;
@@ -5507,6 +5942,48 @@ int proc_get_tx_auth(struct seq_file *m, void *v)
 }
 #endif /* CONFIG_IEEE80211W */
 
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
+static u32 phase_idx;
+int proc_get_pathb_phase(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+
+	RTW_PRINT_SEL(m, "PathB phase index =%d\n", phase_idx);
+	return 0;
+}
+
+ssize_t proc_set_pathb_phase(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[255];
+	int num;
+	u32 tmp_idx;
+
+	if (NULL == buffer) {
+		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		num = sscanf(tmp, "%u", &tmp_idx);
+		if ((tmp_idx < 0) || (tmp_idx > 11)) {
+			RTW_INFO(FUNC_ADPT_FMT "Invalid input value\n", FUNC_ADPT_ARG(padapter));
+			return count;
+		}
+		phase_idx = tmp_idx;
+		rtw_hal_set_pathb_phase(padapter, phase_idx);
+	}
+	return count;
+}
+#endif
+
 #ifdef CONFIG_MCC_MODE
 int proc_get_mcc_info(struct seq_file *m, void *v)
 {
@@ -5527,18 +6004,12 @@ int proc_get_mcc_policy_table(struct seq_file *m, void *v)
 	return 0;
 }
 
-ssize_t proc_set_mcc_policy_table(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[255];
-	s32 mcc_policy_table_idx;
-	u32 mcc_duration;
-	u32 mcc_tsf_sync_offset;
-	u32 mcc_start_time_offset;
-	u32 mcc_interval;
-	s32 mcc_guard_offset0;
-	s32 mcc_guard_offset1;
+	u32 en_mcc = 0;
 
 	if (NULL == buffer) {
 		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
@@ -5557,53 +6028,35 @@ ssize_t proc_set_mcc_policy_table(struct file *file, const char __user *buffer,
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		#if 1
 		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 		_adapter *iface = NULL;
 		u8 i = 0;
-		int num = sscanf(tmp, "%d %u %u %u %u %d %d"
-			, &mcc_policy_table_idx, &mcc_duration, &mcc_tsf_sync_offset, &mcc_start_time_offset
-			, &mcc_interval, &mcc_guard_offset0, &mcc_guard_offset1);
+		int num = sscanf(tmp, "%u", &en_mcc);
 
-		if (num < 7) {
-			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 7\n", FUNC_ADPT_ARG(padapter));
+		if (num < 1) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
 			return -EINVAL;
 		}
-#if 0
-		RTW_INFO("mcc_policy_table_idx:%d\n", mcc_policy_table_idx);
-		RTW_INFO("mcc_duration:%d\n", mcc_duration);
-		RTW_INFO("mcc_tsf_sync_offset:%d\n", mcc_tsf_sync_offset);
-		RTW_INFO("mcc_start_time_offset:%d\n", mcc_start_time_offset);
-		RTW_INFO("mcc_interval:%d\n", mcc_interval);
-		RTW_INFO("mcc_guard_offset0:%d\n", mcc_guard_offset0);
-		RTW_INFO("mcc_guard_offset1:%d\n", mcc_guard_offset1);
-#endif
+
+		RTW_INFO("%s: en_mcc = %d\n", __func__, en_mcc);
+
 		for (i = 0; i < dvobj->iface_nums; i++) {
 			iface = dvobj->padapters[i];
 			if (!iface)
 				continue;
-			iface->registrypriv.rtw_mcc_policy_table_idx = mcc_policy_table_idx;
-			iface->registrypriv.rtw_mcc_duration = mcc_duration;
-			iface->registrypriv.rtw_mcc_tsf_sync_offset = mcc_tsf_sync_offset;
-			iface->registrypriv.rtw_mcc_start_time_offset = mcc_start_time_offset;
-			iface->registrypriv.rtw_mcc_interval = mcc_interval;
-			iface->registrypriv.rtw_mcc_guard_offset0 = mcc_guard_offset0;
-			iface->registrypriv.rtw_mcc_guard_offset1 = mcc_guard_offset1;
+			iface->registrypriv.en_mcc = en_mcc;
 		}
-
-		rtw_hal_mcc_update_switch_channel_policy_table(padapter);
-		#endif
 	}
 
 	return count;
 }
 
-ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_mcc_duration(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[255];
-	u32 en_mcc = 0;
+	u32 enable_runtime_duration = 0, mcc_duration = 0;
 
 	if (NULL == buffer) {
 		RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
@@ -5622,23 +6075,26 @@ ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-		_adapter *iface = NULL;
-		u8 i = 0;
-		int num = sscanf(tmp, "%u", &en_mcc);
+		int num = sscanf(tmp, "%u %u", &enable_runtime_duration, &mcc_duration);
 
 		if (num < 1) {
 			RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
 			return -EINVAL;
 		}
 
-		RTW_INFO("%s: en_mcc = %d\n", __func__, en_mcc);
+		if (num > 2) {
+			RTW_INFO(FUNC_ADPT_FMT ": input parameters > 2\n", FUNC_ADPT_ARG(padapter));
+			return -EINVAL;
+		}
 
-		for (i = 0; i < dvobj->iface_nums; i++) {
-			iface = dvobj->padapters[i];
-			if (!iface)
-				continue;
-			iface->registrypriv.en_mcc = en_mcc;
+		if (num >= 1) {
+			SET_MCC_RUNTIME_DURATION(padapter, enable_runtime_duration);
+			RTW_INFO("runtime duration:%s\n", enable_runtime_duration ? "enable":"disable");
+		}
+
+		if (num == 2) {
+			RTW_INFO("mcc duration:%d\n", mcc_duration);
+			rtw_set_mcc_duration_cmd(padapter, MCC_DURATION_DIRECET, mcc_duration);
 		}
 	}
 
@@ -5946,7 +6402,10 @@ int proc_get_ack_timeout(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	u8 ack_timeout_val, ack_timeout_val_cck;
+	u8 ack_timeout_val;
+#ifdef CONFIG_RTL8821C
+	u8 ack_timeout_val_cck;
+#endif
 
 	ack_timeout_val = rtw_read8(padapter, REG_ACKTO);
 
@@ -6003,14 +6462,14 @@ ssize_t proc_set_ack_timeout(struct file *file, const char __user *buffer, size_
 	return count;
 }
 
-ssize_t proc_set_iqk_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+ssize_t proc_set_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
 	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
 	char tmp[32];
-	u32 enable = 0;
+	u32 iqk_offload_enable = 0, ch_switch_offload_enable = 0;
 
 	if (buffer == NULL) {
 		RTW_INFO("input buffer is NULL!\n");
@@ -6029,23 +6488,26 @@ ssize_t proc_set_iqk_fw_offload(struct file *file, const char __user *buffer, si
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		int num = sscanf(tmp, "%d", &enable);
+		int num = sscanf(tmp, "%d %d", &iqk_offload_enable, &ch_switch_offload_enable);
 
-		if (num < 1) {
+		if (num < 2) {
 			RTW_INFO("input parameters < 1\n");
 			return -EINVAL;
 		}
 
-		if (hal->RegIQKFWOffload != enable) {
-			hal->RegIQKFWOffload = enable;
+		if (hal->RegIQKFWOffload != iqk_offload_enable) {
+			hal->RegIQKFWOffload = iqk_offload_enable;
 			rtw_hal_update_iqk_fw_offload_cap(pri_adapter);
 		}
+
+		if (hal->ch_switch_offload != ch_switch_offload_enable)
+			hal->ch_switch_offload = ch_switch_offload_enable;
 	}
 
 	return count;
 }
 
-int proc_get_iqk_fw_offload(struct seq_file *m, void *v)
+int proc_get_fw_offload(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
@@ -6053,8 +6515,181 @@ int proc_get_iqk_fw_offload(struct seq_file *m, void *v)
 
 
 	RTW_PRINT_SEL(m, "IQK FW offload:%s\n", hal->RegIQKFWOffload?"enable":"disable");
+	RTW_PRINT_SEL(m, "Channel switch FW offload:%s\n", hal->ch_switch_offload?"enable":"disable");
+	return 0;
+}
+#ifdef CONFIG_FW_HANDLE_TXBCN
+extern void rtw_hal_set_fw_ap_bcn_offload_cmd(_adapter *adapter, bool fw_bcn_en, u8 tbtt_rpt_map);
+ssize_t proc_set_fw_tbtt_rpt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+	u32 fw_tbtt_rpt, fw_bcn_offload;
+
+
+	if (buffer == NULL) {
+		RTW_INFO("input buffer is NULL!\n");
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO("input length is 0!\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO("input length is too large\n");
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%d %x",&fw_bcn_offload, &fw_tbtt_rpt);
+
+		if (num < 2) {
+			RTW_INFO("input parameters < 2\n");
+			return -EINVAL;
+		}
+		rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, fw_bcn_offload, fw_tbtt_rpt);
+	}
+
+	return count;
+}
+
+int proc_get_fw_tbtt_rpt(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	RTW_PRINT_SEL(m, "FW BCN offload:%s\n", dvobj->fw_bcn_offload ? "enable" : "disable");
+	RTW_PRINT_SEL(m, "FW TBTT RPT:%x\n", dvobj->vap_tbtt_rpt_map);
+	return 0;
+}
+
+#endif
+
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+ssize_t proc_set_txss_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	char tmp[32];
+	u32 enable = 0;
+	u32 txss_tx_tp = 0;
+	int txss_chk_cnt = 0;
+
+	if (buffer == NULL) {
+		RTW_INFO("input buffer is NULL!\n");
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO("input length is 0!\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO("input length is too large\n");
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u %u %d",
+			&enable, &txss_tx_tp, &txss_chk_cnt);
+
+		if (num < 1) {
+			RTW_INFO("input parameters < 1\n");
+			return -EINVAL;
+		}
+		pmlmeext->txss_ctrl_en = enable;
+
+		if (txss_tx_tp)
+			pmlmeext->txss_tp_th = txss_tx_tp;
+		if (txss_chk_cnt)
+			pmlmeext->txss_tp_chk_cnt = txss_chk_cnt;
+
+		RTW_INFO("%s txss_ctl_en :%s , txss_tp_th:%d, tp_chk_cnt:%d\n",
+			__func__, pmlmeext->txss_tp_th ? "Y" : "N",
+			pmlmeext->txss_tp_th, pmlmeext->txss_tp_chk_cnt);
+
+	}
+
+	return count;
+}
+
+int proc_get_txss_tp(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	RTW_PRINT_SEL(m, "TXSS  Control - %s\n", pmlmeext->txss_ctrl_en ? "enable" : "disable");
+	RTW_PRINT_SEL(m, "TXSS  Tx TP TH - %d\n", pmlmeext->txss_tp_th);
+	RTW_PRINT_SEL(m, "TXSS  check cnt - %d\n", pmlmeext->txss_tp_chk_cnt);
+
 	return 0;
 }
+#ifdef DBG_CTRL_TXSS
+ssize_t proc_set_txss_ctrl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	char tmp[32];
+	u32 tx_1ss = 0;
+
+	if (buffer == NULL) {
+		RTW_INFO("input buffer is NULL!\n");
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO("input length is 0!\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO("input length is too large\n");
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u",	&tx_1ss);
+
+		if (num < 1) {
+			RTW_INFO("input parameters < 1\n");
+			return -EINVAL;
+		}
+
+		pmlmeext->txss_ctrl_en = _FALSE;
+
+		dbg_ctrl_txss(adapter, tx_1ss);
+
+		RTW_INFO("%s set tx to  1ss :%s\n", __func__, tx_1ss ? "Y" : "N");
+	}
+
+	return count;
+}
+
+int proc_get_txss_ctrl(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	RTW_PRINT_SEL(m, "TXSS  1ss - %s\n", pmlmeext->txss_1ss ? "Y" : "N");
+
+	return 0;
+}
+#endif
+#endif
 
 #ifdef CONFIG_DBG_RF_CAL
 int proc_get_iqk_info(struct seq_file *m, void *v)
@@ -6084,6 +6719,11 @@ ssize_t proc_set_iqk(struct file *file, const char __user *buffer, size_t count,
 
 		int num = sscanf(tmp, "%d %d %d", &recovery, &clear, &segment);
 
+		if (num != 3) {
+			RTW_INFO("Invalid format\n");
+			return count;
+		}
+
 		rtw_hal_iqk_test(padapter, recovery, clear, segment);
 	}
 
@@ -6118,6 +6758,11 @@ ssize_t proc_set_lck(struct file *file, const char __user *buffer, size_t count,
 
 		int num = sscanf(tmp, "%d", &trigger);
 
+		if (num != 1) {
+			RTW_INFO("Invalid format\n");
+			return count;
+		}
+
 		rtw_hal_lck_test(padapter);
 	}
 
@@ -6125,19 +6770,185 @@ ssize_t proc_set_lck(struct file *file, const char __user *buffer, size_t count,
 }
 #endif /* CONFIG_DBG_RF_CAL */
 
+#ifdef CONFIG_LPS_CHK_BY_TP
+ssize_t proc_set_lps_chk_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	char tmp[32];
+	u32 enable = 0;
+	u32 lps_tx_tp = 0, lps_rx_tp = 0, lps_bi_tp = 0;
+	int lps_chk_cnt_th = 0;
+	u32 lps_tx_pkts = 0, lps_rx_pkts = 0;
+
+	if (buffer == NULL) {
+		RTW_INFO("input buffer is NULL!\n");
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO("input length is 0!\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO("input length is too large\n");
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u %u %u %u %d %u %u",
+			&enable, &lps_tx_tp, &lps_rx_tp, &lps_bi_tp,
+			&lps_chk_cnt_th, &lps_tx_pkts, &lps_rx_pkts);
+
+		if (num < 1) {
+			RTW_INFO("input parameters < 1\n");
+			return -EINVAL;
+		}
+		pwrpriv->lps_chk_by_tp = enable;
+
+		if (lps_tx_tp) {
+			pwrpriv->lps_tx_tp_th = lps_tx_tp;
+			pwrpriv->lps_rx_tp_th = lps_tx_tp;
+			pwrpriv->lps_bi_tp_th = lps_tx_tp;
+		}
+		if (lps_rx_tp)
+			pwrpriv->lps_rx_tp_th = lps_rx_tp;
+		if (lps_bi_tp)
+			pwrpriv->lps_bi_tp_th = lps_bi_tp;
+
+		if (lps_chk_cnt_th)
+			pwrpriv->lps_chk_cnt_th = lps_chk_cnt_th;
+
+		if (lps_tx_pkts)
+			pwrpriv->lps_tx_pkts = lps_tx_pkts;
+
+		if (lps_rx_pkts)
+			pwrpriv->lps_rx_pkts = lps_rx_pkts;
+
+		RTW_INFO("%s lps_chk_by_tp:%s , lps_tx_tp_th:%d, lps_tx_tp_th:%d, lps_bi_tp:%d\n",
+			__func__, pwrpriv->lps_chk_by_tp ? "Y" : "N",
+			pwrpriv->lps_tx_tp_th, pwrpriv->lps_tx_tp_th, pwrpriv->lps_bi_tp_th);
+		RTW_INFO("%s lps_chk_cnt_th:%d , lps_tx_pkts:%d, lps_rx_pkts:%d\n",
+			__func__, pwrpriv->lps_chk_cnt_th, pwrpriv->lps_tx_pkts, pwrpriv->lps_rx_pkts);
+	}
+
+	return count;
+}
+
+int proc_get_lps_chk_tp(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+
+	RTW_PRINT_SEL(m, "LPS chk by tp - %s\n", pwrpriv->lps_chk_by_tp ? "enable" : "disable");
+	RTW_PRINT_SEL(m, "LPS Tx TP TH - %d(Mbps)\n", pwrpriv->lps_tx_tp_th);
+	RTW_PRINT_SEL(m, "LPS Rx TP TH - %d(Mbps)\n", pwrpriv->lps_rx_tp_th);
+	RTW_PRINT_SEL(m, "LPS BI TP TH - %d(Mbps)\n", pwrpriv->lps_bi_tp_th);
+
+	RTW_PRINT_SEL(m, "LPS CHK CNT - %d\n", pwrpriv->lps_chk_cnt_th);
+	RTW_PRINT_SEL(m, "LPS Tx PKTs - %d\n", pwrpriv->lps_tx_pkts);
+	RTW_PRINT_SEL(m, "LPS Rx PKTs - %d\n", pwrpriv->lps_rx_pkts);
+	return 0;
+}
+#endif /*CONFIG_LPS_CHK_BY_TP*/
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+ssize_t proc_set_smps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	char tmp[32];
+	u32 enable = 0;
+	u32 smps_en, smps_tx_tp = 0, smps_rx_tp = 0;
+	u32 smps_test = 0, smps_test_en = 0;
+
+	if (buffer == NULL) {
+		RTW_INFO("input buffer is NULL!\n");
+		return -EFAULT;
+	}
+
+	if (count < 1) {
+		RTW_INFO("input length is 0!\n");
+		return -EFAULT;
+	}
+
+	if (count > sizeof(tmp)) {
+		RTW_INFO("input length is too large\n");
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%u %u %u %u %u", &smps_en, &smps_tx_tp, &smps_rx_tp,
+			&smps_test, &smps_test_en);
+
+		if (num < 1) {
+			RTW_INFO("input parameters < 1\n");
+			return -EINVAL;
+		}
+
+		pmlmeext->ssmps_en = smps_en;
+		if (smps_tx_tp) {
+			pmlmeext->ssmps_tx_tp_th= smps_tx_tp;
+			pmlmeext->ssmps_rx_tp_th= smps_tx_tp;
+		}
+		if (smps_rx_tp)
+			pmlmeext->ssmps_rx_tp_th = smps_rx_tp;
+
+		#ifdef DBG_STATIC_SMPS
+		if (num > 3) {
+			pmlmeext->ssmps_test = smps_test;
+			pmlmeext->ssmps_test_en = smps_test_en;
+		}
+		#endif
+		RTW_INFO("SM PS : %s tx_tp_th:%d, rx_tp_th:%d\n",
+			(smps_en) ? "Enable" : "Disable",
+			pmlmeext->ssmps_tx_tp_th,
+			pmlmeext->ssmps_rx_tp_th);
+		#ifdef DBG_STATIC_SMPS
+		RTW_INFO("SM PS : %s ssmps_test_en:%d\n",
+			(smps_test) ? "Enable" : "Disable",
+			pmlmeext->ssmps_test_en);
+		#endif
+	}
+
+	return count;
+}
+
+int proc_get_smps(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	RTW_PRINT_SEL(m, "Static SMPS %s\n", pmlmeext->ssmps_en ? "enable" : "disable");
+	RTW_PRINT_SEL(m, "Tx TP TH %d\n", pmlmeext->ssmps_tx_tp_th);
+	RTW_PRINT_SEL(m, "Rx TP TH %d\n", pmlmeext->ssmps_rx_tp_th);
+	#ifdef DBG_STATIC_SMPS
+	RTW_PRINT_SEL(m, "test %d, test_en:%d\n", pmlmeext->ssmps_test, pmlmeext->ssmps_test_en);
+	#endif
+	return 0;
+}
+#endif /*CONFIG_SUPPORT_STATIC_SMPS*/
+
 #endif /* CONFIG_PROC_DEBUG */
 #define RTW_BUFDUMP_BSIZE		16
 #if 1
 inline void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
 					bool _idx_show, const u8 *_hexdata, int _hexdatalen)
 {
+#ifdef CONFIG_RTW_DEBUG
 	int __i;
 	u8 *ptr = (u8 *)_hexdata;
 
 	if (_loglevel <= rtw_drv_log_level) {
 		if (_titlestring) {
 			if (sel == RTW_DBGDUMP)
-				_RTW_PRINT_SEL(sel, "%s", DRIVER_PREFIX);
+				RTW_PRINT("");
 			_RTW_PRINT_SEL(sel, "%s", _titlestring);
 			if (_hexdatalen >= RTW_BUFDUMP_BSIZE)
 				_RTW_PRINT_SEL(sel, "\n");
@@ -6146,16 +6957,17 @@ inline void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
 		for (__i = 0; __i < _hexdatalen; __i++) {
 			if (((__i % RTW_BUFDUMP_BSIZE) == 0) && (_hexdatalen >= RTW_BUFDUMP_BSIZE)) {
 				if (sel == RTW_DBGDUMP)
-					_RTW_PRINT_SEL(sel, "%s", DRIVER_PREFIX);
+					RTW_PRINT("");
 				if (_idx_show)
 					_RTW_PRINT_SEL(sel, "0x%03X: ", __i);
 			}
 			_RTW_PRINT_SEL(sel, "%02X%s", ptr[__i], (((__i + 1) % 4) == 0) ? "  " : " ");
-			if (((__i + 1) % RTW_BUFDUMP_BSIZE) == 0)
+			if ((__i + 1 < _hexdatalen) && ((__i + 1) % RTW_BUFDUMP_BSIZE) == 0)
 				_RTW_PRINT_SEL(sel, "\n");
 		}
 		_RTW_PRINT_SEL(sel, "\n");
 	}
+#endif
 }
 #else
 inline void _RTW_STR_DUMP_SEL(void *sel, char *str_out)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_eeprom.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_eeprom.c
index d48996e86182..dde4b639d74a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_eeprom.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_eeprom.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ieee80211.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ieee80211.c
index bc95728db3a7..c56ef3d230cf 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ieee80211.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ieee80211.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -127,6 +128,19 @@ int rtw_get_bit_value_from_ieee_value(u8 val)
 	}
 	return 0;
 }
+uint rtw_get_cckrate_size(u8 *rate, u32 rate_length)
+{
+	int i = 0;
+	while(i < rate_length){
+		RTW_DBG("%s, rate[%d]=%u\n", __FUNCTION__, i, rate[i]);
+		if (((rate[i] & 0x7f) == 2) || ((rate[i] & 0x7f) == 4) ||
+			((rate[i] & 0x7f) == 11)  || ((rate[i] & 0x7f) == 22))
+			i++;
+		else
+			break;
+	}
+	return i;
+}
 
 uint	rtw_is_cckrates_included(u8 *rate)
 {
@@ -191,7 +205,7 @@ u8 *rtw_set_ie
 	u8 *pbuf,
 	sint index,
 	uint len,
-	u8 *source,
+	const u8 *source,
 	uint *frlen /* frame length */
 )
 {
@@ -202,7 +216,8 @@ u8 *rtw_set_ie
 	if (len > 0)
 		_rtw_memcpy((void *)(pbuf + 2), (void *)source, len);
 
-	*frlen = *frlen + (len + 2);
+	if (frlen)
+		*frlen = *frlen + (len + 2);
 
 	return pbuf + len + 2;
 }
@@ -223,9 +238,9 @@ inline u8 secondary_ch_offset_to_hal_ch_offset(u8 ch_offset)
 	if (ch_offset == SCN)
 		return HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 	else if (ch_offset == SCA)
-		return HAL_PRIME_CHNL_OFFSET_UPPER;
-	else if (ch_offset == SCB)
 		return HAL_PRIME_CHNL_OFFSET_LOWER;
+	else if (ch_offset == SCB)
+		return HAL_PRIME_CHNL_OFFSET_UPPER;
 
 	return HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 }
@@ -235,9 +250,9 @@ inline u8 hal_ch_offset_to_secondary_ch_offset(u8 ch_offset)
 	if (ch_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE)
 		return SCN;
 	else if (ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
-		return SCB;
-	else if (ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
 		return SCA;
+	else if (ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
+		return SCB;
 
 	return SCN;
 }
@@ -263,10 +278,10 @@ inline u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl,
 /*----------------------------------------------------------------------------
 index: the information element id index, limit is the limit for search
 -----------------------------------------------------------------------------*/
-u8 *rtw_get_ie(u8 *pbuf, sint index, sint *len, sint limit)
+u8 *rtw_get_ie(const u8 *pbuf, sint index, sint *len, sint limit)
 {
 	sint tmp, i;
-	u8 *p;
+	const u8 *p;
 	if (limit < 1) {
 		return NULL;
 	}
@@ -277,7 +292,7 @@ u8 *rtw_get_ie(u8 *pbuf, sint index, sint *len, sint limit)
 	while (1) {
 		if (*p == index) {
 			*len = *(p + 1);
-			return p;
+			return (u8 *)p;
 		} else {
 			tmp = *(p + 1);
 			p += (tmp + 2);
@@ -301,17 +316,17 @@ u8 *rtw_get_ie(u8 *pbuf, sint index, sint *len, sint limit)
  *
  * Returns: The address of the specific IE found, or NULL
  */
-u8 *rtw_get_ie_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len, u8 *ie, uint *ielen)
+u8 *rtw_get_ie_ex(const u8 *in_ie, uint in_len, u8 eid, const u8 *oui, u8 oui_len, u8 *ie, uint *ielen)
 {
 	uint cnt;
-	u8 *target_ie = NULL;
+	const u8 *target_ie = NULL;
 
 
 	if (ielen)
 		*ielen = 0;
 
 	if (!in_ie || in_len <= 0)
-		return target_ie;
+		return (u8 *)target_ie;
 
 	cnt = 0;
 
@@ -333,7 +348,7 @@ u8 *rtw_get_ie_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len, u8 *ie, u
 
 	}
 
-	return target_ie;
+	return (u8 *)target_ie;
 }
 
 /**
@@ -380,6 +395,52 @@ exit:
 	return ret;
 }
 
+ /* Returns:  remove size OR  _FAIL: not updated*/
+int rtw_remove_ie_g_rate(u8 *ie, uint *ie_len, uint offset, u8 eid)
+{
+	int ret = _FAIL;
+	u8 *tem_target_ie;
+	u8 *target_ie;
+	u32 target_ielen,temp_target_ielen,cck_rate_size,rm_size;
+	u8 *start;
+	uint search_len;
+	u8 *remain_ies;
+	uint remain_len;
+	if (!ie || !ie_len || *ie_len <= offset)
+		goto exit;
+
+	start = ie + offset;
+	search_len = *ie_len - offset;
+
+	while (1) {
+		tem_target_ie=rtw_get_ie(start,eid,&temp_target_ielen,search_len);
+		
+		/*if(tem_target_ie)
+			RTW_INFO("%s, tem_target_ie=%u\n", __FUNCTION__,*tem_target_ie);*/
+		if (tem_target_ie && temp_target_ielen) {
+			cck_rate_size = rtw_get_cckrate_size((tem_target_ie+2), temp_target_ielen);
+			rm_size = temp_target_ielen - cck_rate_size;
+			RTW_DBG("%s,cck_rate_size=%u rm_size=%u\n", __FUNCTION__, cck_rate_size, rm_size);
+			temp_target_ielen=temp_target_ielen + 2;/*org size of  Supposrted Rates(include id + length)*/
+			/*RTW_INFO("%s, temp_target_ielen=%u\n", __FUNCTION__,temp_target_ielen);*/
+			remain_ies = tem_target_ie + temp_target_ielen;
+			remain_len = search_len - (remain_ies - start);
+			target_ielen=cck_rate_size;/*discount g mode rate 6, 9 12,18Mbps,id , length*/
+			*(tem_target_ie+1)=target_ielen;/*set new length to Supposrted Rates*/
+			target_ie=tem_target_ie+target_ielen + 2;/*set target ie to address of rate 6Mbps */
+	
+			_rtw_memmove(target_ie, remain_ies, remain_len);
+			*ie_len = *ie_len - rm_size;
+			ret = rm_size;
+
+			start = target_ie;
+			search_len = remain_len;
+		} else
+			break;
+	}
+exit:
+	return ret;
+}
 void rtw_set_supported_rate(u8 *SupportedRates, uint mode)
 {
 
@@ -495,7 +556,7 @@ int rtw_generate_ie(struct registry_priv *pregistrypriv)
 
 #ifdef CONFIG_80211N_HT
 	/* HT Cap. */
-	if (((pregistrypriv->wireless_mode & WIRELESS_11_5N) || (pregistrypriv->wireless_mode & WIRELESS_11_24N))
+	if (is_supported_ht(pregistrypriv->wireless_mode)
 	    && (pregistrypriv->ht_enable == _TRUE)) {
 		/* todo: */
 	}
@@ -674,79 +735,150 @@ int rtw_parse_wpa_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwis
 
 }
 
-int rtw_parse_wpa2_ie(u8 *rsn_ie, int rsn_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x)
+int rtw_rsne_info_parse(const u8 *ie, uint ie_len, struct rsne_info *info)
 {
-	int i, ret = _SUCCESS;
-	int left, count;
-	u8 *pos;
-	u8 SUITE_1X[4] = {0x00, 0x0f, 0xac, 0x01};
+	const u8 *pos = ie;
+	u16 cnt;
 
-	if (rsn_ie_len <= 0) {
-		/* No RSN IE - fail silently */
-		return _FAIL;
-	}
+	_rtw_memset(info, 0, sizeof(struct rsne_info));
 
+	if (ie + ie_len < pos + 4)
+		goto err;
 
-	if ((*rsn_ie != _WPA2_IE_ID_) || (*(rsn_ie + 1) != (u8)(rsn_ie_len - 2)))
-		return _FAIL;
+	if (*ie != WLAN_EID_RSN || *(ie + 1) != ie_len - 2)
+		goto err;
+	pos += 2 + 2;
 
-	pos = rsn_ie;
+	/* Group CS */
+	if (ie + ie_len < pos + 4) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->gcs = (u8 *)pos;
 	pos += 4;
-	left = rsn_ie_len - 4;
 
-	/* group_cipher */
-	if (left >= RSN_SELECTOR_LEN) {
+	/* Pairwise CS */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	cnt = RTW_GET_LE16(pos);
+	pos += 2;
+	if (ie + ie_len < pos + 4 * cnt) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->pcs_cnt = cnt;
+	info->pcs_list = (u8 *)pos;
+	pos += 4 * cnt;
 
-		*group_cipher = rtw_get_wpa2_cipher_suite(pos);
+	/* AKM */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	cnt = RTW_GET_LE16(pos);
+	pos += 2;
+	if (ie + ie_len < pos + 4 * cnt) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->akm_cnt = cnt;
+	info->akm_list = (u8 *)pos;
+	pos += 4 * cnt;
 
-		pos += RSN_SELECTOR_LEN;
-		left -= RSN_SELECTOR_LEN;
+	/* RSN cap */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->cap = (u8 *)pos;
+	pos += 2;
 
-	} else if (left > 0) {
-		return _FAIL;
+	/* PMKID */
+	if (ie + ie_len < pos + 2) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	cnt = RTW_GET_LE16(pos);
+	pos += 2;
+	if (ie + ie_len < pos + 16 * cnt) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
 	}
+	info->pmkid_cnt = cnt;
+	info->pmkid_list = (u8 *)pos;
+	pos += 16 * cnt;
 
-	/* pairwise_cipher */
-	if (left >= 2) {
-		/* count = le16_to_cpu(*(u16*)pos); */
-		count = RTW_GET_LE16(pos);
-		pos += 2;
-		left -= 2;
+	/* Group Mgmt CS */
+	if (ie + ie_len < pos + 4) {
+		if (ie + ie_len != pos)
+			goto err;
+		goto exit;
+	}
+	info->gmcs = (u8 *)pos;
 
-		if (count == 0 || left < count * RSN_SELECTOR_LEN) {
-			return _FAIL;
-		}
+exit:
+	return _SUCCESS;
 
-		for (i = 0; i < count; i++) {
-			*pairwise_cipher |= rtw_get_wpa2_cipher_suite(pos);
+err:
+	info->err = 1;
+	return _FAIL;
+}
 
-			pos += RSN_SELECTOR_LEN;
-			left -= RSN_SELECTOR_LEN;
-		}
+int rtw_parse_wpa2_ie(u8 *rsn_ie, int rsn_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x, u8 *mfp_opt)
+{
+	struct rsne_info info;
+	int i, ret = _SUCCESS;
+	u8 SUITE_1X[4] = {0x00, 0x0f, 0xac, 0x01};
 
-	} else if (left == 1) {
+	ret = rtw_rsne_info_parse(rsn_ie, rsn_ie_len, &info);
+	if (ret != _SUCCESS)
+		goto exit;
 
-		return _FAIL;
+	if (group_cipher) {
+		if (info.gcs)
+			*group_cipher = rtw_get_wpa2_cipher_suite(info.gcs);
+		else
+			*group_cipher = 0;
+	}
+
+	if (pairwise_cipher) {
+		*pairwise_cipher = 0;
+		for (i = 0; i < info.pcs_cnt; i++)
+			*pairwise_cipher |= rtw_get_wpa2_cipher_suite(info.pcs_list + 4 * i);
 	}
 
 	if (is_8021x) {
-		if (left >= 6) {
-			pos += 2;
-			if (_rtw_memcmp(pos, SUITE_1X, 4) == 1) {
-				*is_8021x = 1;
-			}
-		}
+		*is_8021x = 0;
+		/* here only check the first AKM suite */
+		if (info.akm_cnt && _rtw_memcmp(SUITE_1X, info.akm_list, 4) == _TRUE)
+			*is_8021x = 1;
 	}
 
-	return ret;
+	if (mfp_opt) {
+		*mfp_opt = MFP_NO;
+		if (info.cap)
+			*mfp_opt = GET_RSN_CAP_MFP_OPTION(info.cap);
+	}
 
+exit:
+	return ret;
 }
 
 /* #ifdef CONFIG_WAPI_SUPPORT */
 int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len)
 {
 	int len = 0;
-	u8 authmode, i;
+	u8 authmode;
 	uint	cnt;
 	u8 wapi_oui1[4] = {0x0, 0x14, 0x72, 0x01};
 	u8 wapi_oui2[4] = {0x0, 0x14, 0x72, 0x02};
@@ -789,7 +921,7 @@ int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len)
 
 int rtw_get_sec_ie(u8 *in_ie, uint in_len, u8 *rsn_ie, u16 *rsn_len, u8 *wpa_ie, u16 *wpa_len)
 {
-	u8 authmode, sec_idx, i;
+	u8 authmode, sec_idx;
 	u8 wpa_oui[4] = {0x0, 0x50, 0xf2, 0x01};
 	uint	cnt;
 
@@ -881,10 +1013,10 @@ u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps
  *
  * Returns: The address of the WPS IE found, or NULL
  */
-u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
+u8 *rtw_get_wps_ie(const u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
 {
 	uint cnt;
-	u8 *wpsie_ptr = NULL;
+	const u8 *wpsie_ptr = NULL;
 	u8 eid, wps_oui[4] = {0x00, 0x50, 0xf2, 0x04};
 
 	if (wps_ielen)
@@ -892,11 +1024,11 @@ u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
 
 	if (!in_ie) {
 		rtw_warn_on(1);
-		return wpsie_ptr;
+		return (u8 *)wpsie_ptr;
 	}
 
 	if (in_len <= 0)
-		return wpsie_ptr;
+		return (u8 *)wpsie_ptr;
 
 	cnt = 0;
 
@@ -923,7 +1055,7 @@ u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
 
 	}
 
-	return wpsie_ptr;
+	return (u8 *)wpsie_ptr;
 }
 
 /**
@@ -1238,6 +1370,24 @@ ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
 			elems->rm_en_cap = pos;
 			elems->rm_en_cap_len = elen;
 			break;
+#ifdef CONFIG_RTW_MESH
+		case WLAN_EID_PREQ:
+			elems->preq = pos;
+			elems->preq_len = elen;
+			break;
+		case WLAN_EID_PREP:
+			elems->prep = pos;
+			elems->prep_len = elen;
+			break;
+		case WLAN_EID_PERR:
+			elems->perr = pos;
+			elems->perr_len = elen;
+			break;
+		case WLAN_EID_RANN:
+			elems->rann = pos;
+			elems->rann_len = elen;
+			break;
+#endif
 		default:
 			unknown++;
 			if (!show_errors)
@@ -1408,12 +1558,13 @@ void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr)
 	/* Use the mac address stored in the Efuse */
 	if (hw_mac_addr) {
 		_rtw_memcpy(mac, hw_mac_addr, ETH_ALEN);
+		//goto err_chk;
 	}
+    if (!rockchip_wifi_mac_addr(mac)) {
+                printk("get mac address from flash=[%02x:%02x:%02x:%02x:%02x:%02x]\n", mac[0], mac[1],
+                mac[2], mac[3], mac[4], mac[5]);
+    }
 
-	if (!rockchip_wifi_mac_addr(mac)) {
-		printk("get mac address from flash=[%02x:%02x:%02x:%02x:%02x:%02x]\n", mac[0], mac[1],
-		mac[2], mac[3], mac[4], mac[5]);
-	}
 
 err_chk:
 	if (rtw_check_invalid_mac_address(mac, _TRUE) == _TRUE) {
@@ -1439,40 +1590,70 @@ err_chk:
 }
 
 #ifdef CONFIG_80211N_HT
-void dump_ht_cap_ie_content(void *sel, u8 *buf, u32 buf_len)
+void dump_ht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len)
 {
-	if (buf_len != 26) {
-		RTW_PRINT_SEL(sel, "Invalid HT capability IE len:%d != %d\n", buf_len, 26);
+	if (buf_len != HT_CAP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid HT capability IE len:%d != %d\n", buf_len, HT_CAP_IE_LEN);
 		return;
 	}
 
-	RTW_PRINT_SEL(sel, "HT Capabilities Info:%02x%02x\n", *(buf), *(buf + 1));
+	RTW_PRINT_SEL(sel, "cap_info:%02x%02x:%s\n", *(buf), *(buf + 1)
+		, GET_HT_CAP_ELE_CHL_WIDTH(buf) ? " 40MHz" : " 20MHz");
 	RTW_PRINT_SEL(sel, "A-MPDU Parameters:"HT_AMPDU_PARA_FMT"\n"
 		      , HT_AMPDU_PARA_ARG(HT_CAP_ELE_AMPDU_PARA(buf)));
 	RTW_PRINT_SEL(sel, "Supported MCS Set:"HT_SUP_MCS_SET_FMT"\n"
 		      , HT_SUP_MCS_SET_ARG(HT_CAP_ELE_SUP_MCS_SET(buf)));
 }
 
-void dump_ht_cap_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_ht_cap_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8 *pos = (u8 *)ie;
-	u16 id;
-	u16 len;
-
-	u8 *ht_cap_ie;
+	const u8 *ht_cap_ie;
 	sint ht_cap_ielen;
 
-	ht_cap_ie = rtw_get_ie(ie, _HT_CAPABILITY_IE_, &ht_cap_ielen, ie_len);
+	ht_cap_ie = rtw_get_ie(ie, WLAN_EID_HT_CAP, &ht_cap_ielen, ie_len);
 	if (!ie || ht_cap_ie != ie)
 		return;
 
 	dump_ht_cap_ie_content(sel, ht_cap_ie + 2, ht_cap_ielen);
 }
+
+const char *const _ht_sc_offset_str[] = {
+	"SCN",
+	"SCA",
+	"SC-RSVD",
+	"SCB",
+};
+
+void dump_ht_op_ie_content(void *sel, const u8 *buf, u32 buf_len)
+{
+	if (buf_len != HT_OP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid HT operation IE len:%d != %d\n", buf_len, HT_OP_IE_LEN);
+		return;
+	}
+
+	RTW_PRINT_SEL(sel, "ch:%u%s %s\n"
+		, GET_HT_OP_ELE_PRI_CHL(buf)
+		, GET_HT_OP_ELE_STA_CHL_WIDTH(buf) ? "" : " 20MHz only"
+		, ht_sc_offset_str(GET_HT_OP_ELE_2ND_CHL_OFFSET(buf))
+	);
+}
+
+void dump_ht_op_ie(void *sel, const u8 *ie, u32 ie_len)
+{
+	const u8 *ht_op_ie;
+	sint ht_op_ielen;
+
+	ht_op_ie = rtw_get_ie(ie, WLAN_EID_HT_OPERATION, &ht_op_ielen, ie_len);
+	if (!ie || ht_op_ie != ie)
+		return;
+
+	dump_ht_op_ie_content(sel, ht_op_ie + 2, ht_op_ielen);
+}
 #endif /* CONFIG_80211N_HT */
 
-void dump_ies(void *sel, u8 *buf, u32 buf_len)
+void dump_ies(void *sel, const u8 *buf, u32 buf_len)
 {
-	u8 *pos = (u8 *)buf;
+	const u8 *pos = buf;
 	u8 id, len;
 
 	while (pos - buf + 1 < buf_len) {
@@ -1482,6 +1663,11 @@ void dump_ies(void *sel, u8 *buf, u32 buf_len)
 		RTW_PRINT_SEL(sel, "%s ID:%u, LEN:%u\n", __FUNCTION__, id, len);
 #ifdef CONFIG_80211N_HT
 		dump_ht_cap_ie(sel, pos, len + 2);
+		dump_ht_op_ie(sel, pos, len + 2);
+#endif
+#ifdef CONFIG_80211AC_VHT
+		dump_vht_cap_ie(sel, pos, len + 2);
+		dump_vht_op_ie(sel, pos, len + 2);
 #endif
 		dump_wps_ie(sel, pos, len + 2);
 #ifdef CONFIG_P2P
@@ -1495,13 +1681,13 @@ void dump_ies(void *sel, u8 *buf, u32 buf_len)
 	}
 }
 
-void dump_wps_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_wps_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8 *pos = (u8 *)ie;
+	const u8 *pos = ie;
 	u16 id;
 	u16 len;
 
-	u8 *wps_ie;
+	const u8 *wps_ie;
 	uint wps_ielen;
 
 	wps_ie = rtw_get_wps_ie(ie, ie_len, NULL, &wps_ielen);
@@ -1527,8 +1713,10 @@ void dump_wps_ie(void *sel, u8 *ie, u32 ie_len)
  * @ch: pointer of ch, used as output
  * @bw: pointer of bw, used as output
  * @offset: pointer of offset, used as output
+ * @ht: check HT IEs
+ * @vht: check VHT IEs, if true imply ht is true
  */
-void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset)
+void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht)
 {
 	u8 *p;
 	int	ie_len;
@@ -1542,7 +1730,7 @@ void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset)
 		*ch = *(p + 2);
 
 #ifdef CONFIG_80211N_HT
-	{
+	if (ht || vht) {
 		u8 *ht_cap_ie, *ht_op_ie;
 		int ht_cap_ielen, ht_op_ielen;
 
@@ -1575,44 +1763,29 @@ void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset)
 				}
 			}
 		}
-	}
-#endif /* CONFIG_80211N_HT */
+
 #ifdef CONFIG_80211AC_VHT
-	{
-		u8 *vht_op_ie;
-		int vht_op_ielen;
-
-		vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
-		if (vht_op_ie && vht_op_ielen) {
-			/* enable VHT 80 before check enable HT40 or not */
-			if (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2)  >=  1) {
-				/* for HT40, enable VHT80 */
-				if (*bw == CHANNEL_WIDTH_40)
+		if (vht) {
+			u8 *vht_op_ie;
+			int vht_op_ielen;
+
+			vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
+			if (vht_op_ie && vht_op_ielen) {
+				if (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2) >= 1)
 					*bw = CHANNEL_WIDTH_80;
-				/* for HT20, enable VHT20 */
-				else if (*bw == CHANNEL_WIDTH_20) {
-					/* modify VHT OP IE */
-					SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 0);
-					/* reset to 0 for VHT20 */
-					SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, 0);
-					SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
-				}
-			} else {
-				/*
-				  VHT OP WIDTH = 0  under HT20/HT40
-				  if REGSTY_BW_5G(pregistrypriv) < CHANNEL_WIDTH_80 in rtw_build_vht_operation_ie
-				*/
 			}
 		}
+#endif /* CONFIG_80211AC_VHT */
+
 	}
-#endif
+#endif /* CONFIG_80211N_HT */
 }
 
-void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset)
+void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht)
 {
 	rtw_ies_get_chbw(bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)
 		, bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)
-		, ch, bw, offset);
+		, ch, bw, offset, ht, vht);
 
 	if (*ch == 0)
 		*ch = bss->Configuration.DSConfig;
@@ -1679,7 +1852,7 @@ void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
 		if (*g_bw == CHANNEL_WIDTH_40 || *g_bw == CHANNEL_WIDTH_80)
 			*req_offset = *g_offset;
 		else if (*g_bw == CHANNEL_WIDTH_20)
-			*req_offset = rtw_get_offset_by_ch(*req_ch);
+			rtw_get_offset_by_chbw(*req_ch, *req_bw, req_offset);
 
 		if (*req_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
 			RTW_ERR("%s req 80MHz BW without offset, down to 20MHz\n", __func__);
@@ -1691,7 +1864,7 @@ void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
 		if (*g_bw == CHANNEL_WIDTH_40 || *g_bw == CHANNEL_WIDTH_80)
 			*req_offset = *g_offset;
 		else if (*g_bw == CHANNEL_WIDTH_20)
-			*req_offset = rtw_get_offset_by_ch(*req_ch);
+			rtw_get_offset_by_chbw(*req_ch, *req_bw, req_offset);
 
 		if (*req_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
 			RTW_ERR("%s req 40MHz BW without offset, down to 20MHz\n", __func__);
@@ -1724,7 +1897,7 @@ u32 rtw_get_p2p_merged_ies_len(u8 *in_ie, u32 in_len)
 	PNDIS_802_11_VARIABLE_IEs	pIE;
 	u8 OUI[4] = { 0x50, 0x6f, 0x9a, 0x09 };
 	int i = 0;
-	int j = 0, len = 0;
+	int len = 0;
 
 	while (i < in_len) {
 		pIE = (PNDIS_802_11_VARIABLE_IEs)(in_ie + i);
@@ -1779,13 +1952,13 @@ int rtw_p2p_merge_ies(u8 *in_ie, u32 in_len, u8 *merge_ie)
 	return 0;
 }
 
-void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_p2p_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8 *pos = (u8 *)ie;
+	const u8 *pos = ie;
 	u8 id;
 	u16 len;
 
-	u8 *p2p_ie;
+	const u8 *p2p_ie;
 	uint p2p_ielen;
 
 	p2p_ie = rtw_get_p2p_ie(ie, ie_len, NULL, &p2p_ielen);
@@ -1813,10 +1986,10 @@ void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len)
  *
  * Returns: The address of the P2P IE found, or NULL
  */
-u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
+u8 *rtw_get_p2p_ie(const u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
 {
 	uint cnt;
-	u8 *p2p_ie_ptr = NULL;
+	const u8 *p2p_ie_ptr = NULL;
 	u8 eid, p2p_oui[4] = {0x50, 0x6F, 0x9A, 0x09};
 
 	if (p2p_ielen)
@@ -1824,11 +1997,11 @@ u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
 
 	if (!in_ie || in_len < 0) {
 		rtw_warn_on(1);
-		return p2p_ie_ptr;
+		return (u8 *)p2p_ie_ptr;
 	}
 
 	if (in_len <= 0)
-		return p2p_ie_ptr;
+		return (u8 *)p2p_ie_ptr;
 
 	cnt = 0;
 
@@ -1855,7 +2028,7 @@ u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
 
 	}
 
-	return p2p_ie_ptr;
+	return (u8 *)p2p_ie_ptr;
 }
 
 /**
@@ -2123,13 +2296,13 @@ void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
 	}
 }
 
-void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len)
+void dump_wfd_ie(void *sel, const u8 *ie, u32 ie_len)
 {
-	u8 *pos = (u8 *)ie;
+	const u8 *pos = ie;
 	u8 id;
 	u16 len;
 
-	u8 *wfd_ie;
+	const u8 *wfd_ie;
 	uint wfd_ielen;
 
 	wfd_ie = rtw_get_wfd_ie(ie, ie_len, NULL, &wfd_ielen);
@@ -2157,10 +2330,10 @@ void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len)
  *
  * Returns: The address of the P2P IE found, or NULL
  */
-u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
+u8 *rtw_get_wfd_ie(const u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
 {
 	uint cnt;
-	u8 *wfd_ie_ptr = NULL;
+	const u8 *wfd_ie_ptr = NULL;
 	u8 eid, wfd_oui[4] = {0x50, 0x6F, 0x9A, 0x0A};
 
 	if (wfd_ielen)
@@ -2168,11 +2341,11 @@ u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
 
 	if (!in_ie || in_len < 0) {
 		rtw_warn_on(1);
-		return wfd_ie_ptr;
+		return (u8 *)wfd_ie_ptr;
 	}
 
 	if (in_len <= 0)
-		return wfd_ie_ptr;
+		return (u8 *)wfd_ie_ptr;
 
 	cnt = 0;
 
@@ -2199,7 +2372,7 @@ u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
 
 	}
 
-	return wfd_ie_ptr;
+	return (u8 *)wfd_ie_ptr;
 }
 
 /**
@@ -2514,7 +2687,7 @@ int rtw_get_cipher_info(struct wlan_network *pnetwork)
 		pbuf = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
 
 		if (pbuf && (wpa_ielen > 0)) {
-			if (_SUCCESS == rtw_parse_wpa2_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x)) {
+			if (_SUCCESS == rtw_parse_wpa2_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x, NULL)) {
 				pnetwork->BcnInfo.pairwise_cipher = pairwise_cipher;
 				pnetwork->BcnInfo.group_cipher = group_cipher;
 				pnetwork->BcnInfo.is_8021x = is8021x;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_io.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_io.c
index cb8e6b8c0ed9..212b2f8c9314 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_io.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_io.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -419,9 +420,13 @@ u32 _rtw_write_port_and_wait(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem, int
 
 	ret = _rtw_write_port(adapter, addr, cnt, pmem);
 
-	if (ret == _SUCCESS)
+	if (ret == _SUCCESS) {
 		ret = rtw_sctx_wait(&sctx, __func__);
 
+		if (ret != _SUCCESS)
+			pxmitbuf->sctx = NULL;
+	}
+
 	return ret;
 }
 
@@ -484,39 +489,192 @@ void rtw_reset_continual_io_error(struct dvobj_priv *dvobj)
 }
 
 #ifdef DBG_IO
+#define RTW_IO_SNIFF_TYPE_RANGE	0 /* specific address range is accessed */
+#define RTW_IO_SNIFF_TYPE_EN	1 /* part or all sniffed range is enabled */
+#define RTW_IO_SNIFF_TYPE_DIS	2 /* part or all sniffed range is disabled */
+
+struct rtw_io_sniff_ent {
+	u8 chip;
+	u8 hci;
+	u32 addr;
+	u8 type;
+	union {
+		u32 end_addr;
+		u32 mask;
+	} u;
+	char *tag;
+};
+
+const char *rtw_io_sniff_ent_get_tag(const struct rtw_io_sniff_ent *ent)
+{
+	return ent->tag;
+}
+
+#define RTW_IO_SNIFF_RANGE_ENT(_chip, _hci, _addr, _end_addr, _tag) \
+	{.chip = _chip, .hci = _hci, .addr = _addr, .u.end_addr = _end_addr, .tag = _tag, .type = RTW_IO_SNIFF_TYPE_RANGE,}
+
+#define RTW_IO_SNIFF_EN_ENT(_chip, _hci, _addr, _mask, _tag) \
+	{.chip = _chip, .hci = _hci, .addr = _addr, .u.mask = _mask, .tag = _tag, .type = RTW_IO_SNIFF_TYPE_EN,}
 
-u32 read_sniff_ranges[][2] = {
-	/* {0x520, 0x523}, */
+#define RTW_IO_SNIFF_DIS_ENT(_chip, _hci, _addr, _mask, _tag) \
+	{.chip = _chip, .hci = _hci, .addr = _addr, .u.mask = _mask, .tag = _tag, .type = RTW_IO_SNIFF_TYPE_DIS,}
+
+const struct rtw_io_sniff_ent read_sniff[] = {
+#ifdef DBG_IO_HCI_EN_CHK
+	RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_SDIO, 0x02, 0x1FC, "SDIO 0x02[8:2] not all 0"),
+	RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_USB, 0x02, 0x1E0, "USB 0x02[8:5] not all 0"),
+	RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_PCIE, 0x02, 0x01C, "PCI 0x02[4:2] not all 0"),
+#endif
+#ifdef DBG_IO_SNIFF_EXAMPLE
+	RTW_IO_SNIFF_RANGE_ENT(MAX_CHIP_TYPE, 0, 0x522, 0x522, "read TXPAUSE"),
+	RTW_IO_SNIFF_DIS_ENT(MAX_CHIP_TYPE, 0, 0x02, 0x3, "0x02[1:0] not all 1"),
+#endif
 };
 
-u32 write_sniff_ranges[][2] = {
-	/* {0x520, 0x523}, */
-	/* {0x4c, 0x4c}, */
+const int read_sniff_num = sizeof(read_sniff) / sizeof(struct rtw_io_sniff_ent);
+
+const struct rtw_io_sniff_ent write_sniff[] = {
+#ifdef DBG_IO_HCI_EN_CHK
+	RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_SDIO, 0x02, 0x1FC, "SDIO 0x02[8:2] not all 0"),
+	RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_USB, 0x02, 0x1E0, "USB 0x02[8:5] not all 0"),
+	RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_PCIE, 0x02, 0x01C, "PCI 0x02[4:2] not all 0"),
+#endif
+#ifdef DBG_IO_SNIFF_EXAMPLE
+	RTW_IO_SNIFF_RANGE_ENT(MAX_CHIP_TYPE, 0, 0x522, 0x522, "write TXPAUSE"),
+	RTW_IO_SNIFF_DIS_ENT(MAX_CHIP_TYPE, 0, 0x02, 0x3, "0x02[1:0] not all 1"),
+#endif
 };
 
-int read_sniff_num = sizeof(read_sniff_ranges) / sizeof(u32) / 2;
-int write_sniff_num = sizeof(write_sniff_ranges) / sizeof(u32) / 2;
+const int write_sniff_num = sizeof(write_sniff) / sizeof(struct rtw_io_sniff_ent);
+
+static bool match_io_sniff_ranges(_adapter *adapter
+	, const struct rtw_io_sniff_ent *sniff, int i, u32 addr, u16 len)
+{
+
+	/* check if IO range after sniff end address */
+	if (addr > sniff->u.end_addr)
+		return 0;
+
+	return 1;
+}
+
+static bool match_io_sniff_en(_adapter *adapter
+	, const struct rtw_io_sniff_ent *sniff, int i, u32 addr, u8 len, u32 val)
+{
+	u8 sniff_len;
+	u8 shift;
+	u32 mask;
+	bool ret = 0;
+
+	/* check if IO range after sniff end address */
+	sniff_len = 4;
+	while (!(sniff->u.mask & (0xFF << ((sniff_len - 1) * 8)))) {
+		sniff_len--;
+		if (sniff_len == 0)
+			goto exit;
+	}
+	if (sniff->addr + sniff_len <= addr)
+		goto exit;
+
+	if (sniff->addr > addr) {
+		shift = (sniff->addr - addr) * 8;
+		mask = sniff->u.mask << shift;
+	} else if (sniff->addr < addr) {
+		shift = (addr - sniff->addr) * 8;
+		mask = sniff->u.mask >> shift;
+	} else {
+		shift = 0;
+		mask = sniff->u.mask;
+	}
+
+	if (sniff->type == RTW_IO_SNIFF_TYPE_DIS) {
+		if (len == 4)
+			mask &= 0xFFFFFFFF;
+		else if (len == 3)
+			mask &= 0x00FFFFFF;
+		else if (len == 2)
+			mask &= 0x0000FFFF;
+		else if (len == 1)
+			mask &= 0x000000FF;
+		else
+			mask &= 0x00000000;
+	}
+	
+	if ((sniff->type == RTW_IO_SNIFF_TYPE_EN && (mask & val))
+		|| (sniff->type == RTW_IO_SNIFF_TYPE_DIS && (mask & val) != mask)
+	) {
+		ret = 1;
+		if (0)
+			RTW_INFO(FUNC_ADPT_FMT" addr:0x%x len:%u val:0x%x i:%d sniff_len:%u shift:%u mask:0x%x\n"
+				, FUNC_ADPT_ARG(adapter), addr, len, val, i, sniff_len, shift, mask);
+	}
+
+exit:
+	return ret;
+}
+
+static bool match_io_sniff(_adapter *adapter
+	, const struct rtw_io_sniff_ent *sniff, int i, u32 addr, u8 len, u32 val)
+{
+	bool ret = 0;
+
+	if (sniff->chip != MAX_CHIP_TYPE
+		&& sniff->chip != rtw_get_chip_type(adapter))
+		goto exit;
+	if (sniff->hci
+		&& !(sniff->hci & rtw_get_intf_type(adapter)))
+		goto exit;
+	if (sniff->addr >= addr + len) /* IO range below sniff start address */
+		goto exit;
+
+	switch (sniff->type) {
+	case RTW_IO_SNIFF_TYPE_RANGE:
+		ret = match_io_sniff_ranges(adapter, sniff, i, addr, len);
+		break;
+	case RTW_IO_SNIFF_TYPE_EN:
+	case RTW_IO_SNIFF_TYPE_DIS:
+		if (len == 1 || len == 2 || len == 4)
+			ret = match_io_sniff_en(adapter, sniff, i, addr, len, val);
+		break;
+	default:
+		rtw_warn_on(1);
+		break;
+	}
+
+exit:
+	return ret;
+}
 
-bool match_read_sniff_ranges(u32 addr, u16 len)
+const struct rtw_io_sniff_ent *match_read_sniff(_adapter *adapter
+	, u32 addr, u16 len, u32 val)
 {
 	int i;
+	bool ret = 0;
+
 	for (i = 0; i < read_sniff_num; i++) {
-		if (addr + len > read_sniff_ranges[i][0] && addr <= read_sniff_ranges[i][1])
-			return _TRUE;
+		ret = match_io_sniff(adapter, &read_sniff[i], i, addr, len, val);
+		if (ret)
+			goto exit;
 	}
 
-	return _FALSE;
+exit:
+	return ret ? &read_sniff[i] : NULL;
 }
 
-bool match_write_sniff_ranges(u32 addr, u16 len)
+const struct rtw_io_sniff_ent *match_write_sniff(_adapter *adapter
+	, u32 addr, u16 len, u32 val)
 {
 	int i;
+	bool ret = 0;
+
 	for (i = 0; i < write_sniff_num; i++) {
-		if (addr + len > write_sniff_ranges[i][0] && addr <= write_sniff_ranges[i][1])
-			return _TRUE;
+		ret = match_io_sniff(adapter, &write_sniff[i], i, addr, len, val);
+		if (ret)
+			goto exit;
 	}
 
-	return _FALSE;
+exit:
+	return ret ? &write_sniff[i] : NULL;
 }
 
 struct rf_sniff_ent {
@@ -538,7 +696,7 @@ struct rf_sniff_ent rf_write_sniff_ranges[] = {
 int rf_read_sniff_num = sizeof(rf_read_sniff_ranges) / sizeof(struct rf_sniff_ent);
 int rf_write_sniff_num = sizeof(rf_write_sniff_ranges) / sizeof(struct rf_sniff_ent);
 
-bool match_rf_read_sniff_ranges(u8 path, u32 addr, u32 mask)
+bool match_rf_read_sniff_ranges(_adapter *adapter, u8 path, u32 addr, u32 mask)
 {
 	int i;
 
@@ -551,7 +709,7 @@ bool match_rf_read_sniff_ranges(u8 path, u32 addr, u32 mask)
 	return _FALSE;
 }
 
-bool match_rf_write_sniff_ranges(u8 path, u32 addr, u32 mask)
+bool match_rf_write_sniff_ranges(_adapter *adapter, u8 path, u32 addr, u32 mask)
 {
 	int i;
 
@@ -567,9 +725,12 @@ bool match_rf_write_sniff_ranges(u8 path, u32 addr, u32 mask)
 u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u8 val = _rtw_read8(adapter, addr);
+	const struct rtw_io_sniff_ent *ent = match_read_sniff(adapter, addr, 1, val);
 
-	if (match_read_sniff_ranges(addr, 1))
-		RTW_INFO("DBG_IO %s:%d rtw_read8(0x%04x) return 0x%02x\n", caller, line, addr, val);
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_read8(0x%04x) return 0x%02x %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return val;
 }
@@ -577,9 +738,12 @@ u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line
 u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u16 val = _rtw_read16(adapter, addr);
+	const struct rtw_io_sniff_ent *ent = match_read_sniff(adapter, addr, 2, val);
 
-	if (match_read_sniff_ranges(addr, 2))
-		RTW_INFO("DBG_IO %s:%d rtw_read16(0x%04x) return 0x%04x\n", caller, line, addr, val);
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_read16(0x%04x) return 0x%04x %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return val;
 }
@@ -587,38 +751,57 @@ u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int li
 u32 dbg_rtw_read32(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u32 val = _rtw_read32(adapter, addr);
+	const struct rtw_io_sniff_ent *ent = match_read_sniff(adapter, addr, 4, val);
 
-	if (match_read_sniff_ranges(addr, 4))
-		RTW_INFO("DBG_IO %s:%d rtw_read32(0x%04x) return 0x%08x\n", caller, line, addr, val);
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_read32(0x%04x) return 0x%08x %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return val;
 }
 
 int dbg_rtw_write8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 1))
-		RTW_INFO("DBG_IO %s:%d rtw_write8(0x%04x, 0x%02x)\n", caller, line, addr, val);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(adapter, addr, 1, val);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_write8(0x%04x, 0x%02x) %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_write8(adapter, addr, val);
 }
 int dbg_rtw_write16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 2))
-		RTW_INFO("DBG_IO %s:%d rtw_write16(0x%04x, 0x%04x)\n", caller, line, addr, val);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(adapter, addr, 2, val);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_write16(0x%04x, 0x%04x) %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_write16(adapter, addr, val);
 }
 int dbg_rtw_write32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 4))
-		RTW_INFO("DBG_IO %s:%d rtw_write32(0x%04x, 0x%08x)\n", caller, line, addr, val);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(adapter, addr, 4, val);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_write32(0x%04x, 0x%08x) %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_write32(adapter, addr, val);
 }
 int dbg_rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *data, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, length))
-		RTW_INFO("DBG_IO %s:%d rtw_writeN(0x%04x, %u)\n", caller, line, addr, length);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(adapter, addr, length, 0);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_writeN(0x%04x, %u) %s\n"
+			, caller, line, addr, length, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_writeN(adapter, addr, length, data);
 }
@@ -629,8 +812,12 @@ u8 dbg_rtw_sd_f0_read8(_adapter *adapter, u32 addr, const char *caller, const in
 	u8 val = _rtw_sd_f0_read8(adapter, addr);
 
 #if 0
-	if (match_read_sniff_ranges(addr, 1))
-		RTW_INFO("DBG_IO %s:%d rtw_sd_f0_read8(0x%04x) return 0x%02x\n", caller, line, addr, val);
+	const struct rtw_io_sniff_ent *ent = match_read_sniff(adapter, addr, 1, val);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_sd_f0_read8(0x%04x) return 0x%02x %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 #endif
 
 	return val;
@@ -640,9 +827,12 @@ u8 dbg_rtw_sd_f0_read8(_adapter *adapter, u32 addr, const char *caller, const in
 u8 dbg_rtw_sd_iread8(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u8 val = rtw_sd_iread8(adapter, addr);
+	const struct rtw_io_sniff_ent *ent = match_read_sniff(adapter, addr, 1, val);
 
-	if (match_read_sniff_ranges(addr, 1))
-		RTW_INFO("DBG_IO %s:%d rtw_sd_iread8(0x%04x) return 0x%02x\n", caller, line, addr, val);
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iread8(0x%04x) return 0x%02x %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return val;
 }
@@ -650,9 +840,12 @@ u8 dbg_rtw_sd_iread8(_adapter *adapter, u32 addr, const char *caller, const int
 u16 dbg_rtw_sd_iread16(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u16 val = _rtw_sd_iread16(adapter, addr);
+	const struct rtw_io_sniff_ent *ent = match_read_sniff(adapter, addr, 2, val);
 
-	if (match_read_sniff_ranges(addr, 2))
-		RTW_INFO("DBG_IO %s:%d rtw_sd_iread16(0x%04x) return 0x%04x\n", caller, line, addr, val);
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iread16(0x%04x) return 0x%04x %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return val;
 }
@@ -660,31 +853,46 @@ u16 dbg_rtw_sd_iread16(_adapter *adapter, u32 addr, const char *caller, const in
 u32 dbg_rtw_sd_iread32(_adapter *adapter, u32 addr, const char *caller, const int line)
 {
 	u32 val = _rtw_sd_iread32(adapter, addr);
+	const struct rtw_io_sniff_ent *ent = match_read_sniff(adapter, addr, 4, val);
 
-	if (match_read_sniff_ranges(addr, 4))
-		RTW_INFO("DBG_IO %s:%d rtw_sd_iread32(0x%04x) return 0x%08x\n", caller, line, addr, val);
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iread32(0x%04x) return 0x%08x %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return val;
 }
 
 int dbg_rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 1))
-		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite8(0x%04x, 0x%02x)\n", caller, line, addr, val);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(adapter, addr, 1, val);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite8(0x%04x, 0x%02x) %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_sd_iwrite8(adapter, addr, val);
 }
 int dbg_rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 2))
-		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite16(0x%04x, 0x%04x)\n", caller, line, addr, val);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(adapter, addr, 2, val);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite16(0x%04x, 0x%04x) %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_sd_iwrite16(adapter, addr, val);
 }
 int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 4))
-		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite32(0x%04x, 0x%08x)\n", caller, line, addr, val);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(adapter, addr, 4, val);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite32(0x%04x, 0x%08x) %s\n"
+			, caller, line, addr, val, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_sd_iwrite32(adapter, addr, val);
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_query.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_query.c
index 6f7613ecd9b0..d878b4cb4315 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_query.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_query.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_rtl.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_rtl.c
index 5d9e76b604f5..8126ddc5c193 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_rtl.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_rtl.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_set.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_set.c
index c3da5a0fb049..b346f7d68261 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_set.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_ioctl_set.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -42,7 +43,9 @@ u8 rtw_validate_bssid(u8 *bssid)
 
 u8 rtw_validate_ssid(NDIS_802_11_SSID *ssid)
 {
+#ifdef CONFIG_VALIDATE_SSID
 	u8	 i;
+#endif
 	u8	ret = _TRUE;
 
 
@@ -106,10 +109,17 @@ u8 rtw_do_join(_adapter *padapter)
 		if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _FALSE
 		    || rtw_to_roam(padapter) > 0
 		   ) {
-			/* submit site_survey_cmd */
-			ret = rtw_sitesurvey_cmd(padapter, &parm);
-			if (_SUCCESS != ret) {
+			u8 ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
+
+			if ((ssc_chk == SS_ALLOW) || (ssc_chk == SS_DENY_BUSY_TRAFFIC) ){
+				/* submit site_survey_cmd */
+				ret = rtw_sitesurvey_cmd(padapter, &parm);
+				if (_SUCCESS != ret)
+					pmlmepriv->to_join = _FALSE;
+			} else {
+				/*if (ssc_chk == SS_DENY_BUDDY_UNDER_SURVEY)*/
 				pmlmepriv->to_join = _FALSE;
+				ret = _FAIL;
 			}
 		} else {
 			pmlmepriv->to_join = _FALSE;
@@ -155,26 +165,22 @@ u8 rtw_do_join(_adapter *padapter)
 				/* can't associate ; reset under-linking			 */
 				_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
 
-#if 0
-				if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)) {
-					if (_rtw_memcmp(pmlmepriv->cur_network.network.Ssid.Ssid, pmlmepriv->assoc_ssid.Ssid, pmlmepriv->assoc_ssid.SsidLength)) {
-						/* for funk to do roaming */
-						/* funk will reconnect, but funk will not sitesurvey before reconnect */
-						if (pmlmepriv->sitesurveyctrl.traffic_busy == _FALSE)
-							rtw_sitesurvey_cmd(padapter, &parm);
-					}
-
-				}
-#endif
-
 				/* when set_ssid/set_bssid for rtw_do_join(), but there are no desired bss in scanning queue */
 				/* we try to issue sitesurvey firstly			 */
 				if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _FALSE
 				    || rtw_to_roam(padapter) > 0
 				   ) {
-					/* RTW_INFO("rtw_do_join() when   no desired bss in scanning queue\n"); */
-					ret = rtw_sitesurvey_cmd(padapter, &parm);
-					if (_SUCCESS != ret) {
+					u8 ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
+
+					if ((ssc_chk == SS_ALLOW) || (ssc_chk == SS_DENY_BUSY_TRAFFIC)){
+						/* RTW_INFO(("rtw_do_join() when   no desired bss in scanning queue\n"); */
+						ret = rtw_sitesurvey_cmd(padapter, &parm);
+						if (_SUCCESS != ret)
+							pmlmepriv->to_join = _FALSE;
+					} else {
+						/*if (ssc_chk == SS_DENY_BUDDY_UNDER_SURVEY) {
+						} else {*/
+						ret = _FAIL;
 						pmlmepriv->to_join = _FALSE;
 					}
 				} else {
@@ -307,7 +313,7 @@ u8 rtw_set_802_11_bssid(_adapter *padapter, u8 *bssid)
 			if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 				rtw_indicate_disconnect(padapter, 0, _FALSE);
 
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
 
 			if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
 				_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
@@ -344,7 +350,6 @@ u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid)
 {
 	_irqL irqL;
 	u8 status = _SUCCESS;
-	u32 cur_time = 0;
 
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct wlan_network *pnetwork = &pmlmepriv->cur_network;
@@ -379,7 +384,7 @@ u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid)
 					if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 						rtw_indicate_disconnect(padapter, 0, _FALSE);
 
-					rtw_free_assoc_resources(padapter, 1);
+					rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
 
 					if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
 						_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
@@ -400,7 +405,7 @@ u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid)
 			if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
 				rtw_indicate_disconnect(padapter, 0, _FALSE);
 
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
 
 			if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
 				_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
@@ -442,7 +447,6 @@ u8 rtw_set_802_11_connect(_adapter *padapter, u8 *bssid, NDIS_802_11_SSID *ssid)
 {
 	_irqL irqL;
 	u8 status = _SUCCESS;
-	u32 cur_time = 0;
 	bool bssid_valid = _TRUE;
 	bool ssid_valid = _TRUE;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
@@ -520,8 +524,10 @@ u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter,
 	if (*pold_state != networktype) {
 		/* RTW_INFO("change mode, old_mode=%d, new_mode=%d, fw_state=0x%x\n", *pold_state, networktype, get_fwstate(pmlmepriv)); */
 
-		if (*pold_state == Ndis802_11APMode) {
-			/* change to other mode from Ndis802_11APMode			 */
+		if (*pold_state == Ndis802_11APMode
+			|| *pold_state == Ndis802_11_mesh
+		) {
+			/* change to other mode from Ndis802_11APMode/Ndis802_11_mesh */
 			cur_network->join_res = -1;
 			ap2sta_mode = _TRUE;
 #ifdef CONFIG_NATIVEAP_MLME
@@ -536,7 +542,7 @@ u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter,
 
 		if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
 		    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE))
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
 
 		if ((*pold_state == Ndis802_11Infrastructure) || (*pold_state == Ndis802_11IBSS)) {
 			if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
@@ -569,6 +575,13 @@ u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter,
 
 			break;
 
+#ifdef CONFIG_RTW_MESH
+		case Ndis802_11_mesh:
+			set_fwstate(pmlmepriv, WIFI_MESH_STATE);
+			start_ap_mode(padapter);
+			break;
+#endif
+
 		case Ndis802_11AutoUnknown:
 		case Ndis802_11InfrastructureMax:
 			break;
@@ -603,7 +616,7 @@ u8 rtw_set_802_11_disassociate(_adapter *padapter)
 		rtw_disassoc_cmd(padapter, 0, 0);
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
 		/* modify for CONFIG_IEEE80211W, none 11w can use it */
-		rtw_free_assoc_resources_cmd(padapter);
+		rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
 		if (_FAIL == rtw_pwr_wakeup(padapter))
 			RTW_INFO("%s(): rtw_pwr_wakeup fail !!!\n", __FUNCTION__);
 	}
@@ -751,374 +764,6 @@ exit:
 
 }
 
-u8 rtw_set_802_11_remove_wep(_adapter *padapter, u32 keyindex)
-{
-
-	u8 ret = _SUCCESS;
-
-
-	if (keyindex >= 0x80000000 || padapter == NULL) {
-
-		ret = _FALSE;
-		goto exit;
-
-	} else {
-		int res;
-		struct security_priv *psecuritypriv = &(padapter->securitypriv);
-		if (keyindex < 4) {
-
-			_rtw_memset(&psecuritypriv->dot11DefKey[keyindex], 0, 16);
-
-			res = rtw_set_key(padapter, psecuritypriv, keyindex, 0, _TRUE);
-
-			psecuritypriv->dot11DefKeylen[keyindex] = 0;
-
-			if (res == _FAIL)
-				ret = _FAIL;
-
-		} else
-			ret = _FAIL;
-
-	}
-
-exit:
-
-
-	return ret;
-
-}
-
-u8 rtw_set_802_11_add_key(_adapter *padapter, NDIS_802_11_KEY *key)
-{
-
-	uint	encryptionalgo;
-	u8 *pbssid;
-	struct sta_info *stainfo;
-	u8	bgroup = _FALSE;
-	u8	bgrouptkey = _FALSE;/* can be remove later */
-	u8	ret = _SUCCESS;
-
-
-	if (((key->KeyIndex & 0x80000000) == 0) && ((key->KeyIndex & 0x40000000) > 0)) {
-
-		/* It is invalid to clear bit 31 and set bit 30. If the miniport driver encounters this combination, */
-		/* it must fail the request and return NDIS_STATUS_INVALID_DATA. */
-		ret = _FAIL;
-		goto exit;
-	}
-
-	if (key->KeyIndex & 0x40000000) {
-		/* Pairwise key */
-
-
-		pbssid = get_bssid(&padapter->mlmepriv);
-		stainfo = rtw_get_stainfo(&padapter->stapriv, pbssid);
-
-		if ((stainfo != NULL) && (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)) {
-			encryptionalgo = stainfo->dot118021XPrivacy;
-		} else {
-			encryptionalgo = padapter->securitypriv.dot11PrivacyAlgrthm;
-		}
-
-
-
-
-		if (key->KeyIndex & 0x000000FF) {
-			/* The key index is specified in the lower 8 bits by values of zero to 255. */
-			/* The key index should be set to zero for a Pairwise key, and the driver should fail with */
-			/* NDIS_STATUS_INVALID_DATA if the lower 8 bits is not zero */
-			ret = _FAIL;
-			goto exit;
-		}
-
-		/* check BSSID */
-		if (IS_MAC_ADDRESS_BROADCAST(key->BSSID) == _TRUE) {
-
-			ret = _FALSE;
-			goto exit;
-		}
-
-		/* Check key length for TKIP. */
-		/* if(encryptionAlgorithm == RT_ENC_TKIP_ENCRYPTION && key->KeyLength != 32) */
-		if ((encryptionalgo == _TKIP_) && (key->KeyLength != 32)) {
-			ret = _FAIL;
-			goto exit;
-
-		}
-
-		/* Check key length for AES. */
-		if ((encryptionalgo == _AES_) && (key->KeyLength != 16)) {
-			/* For our supplicant, EAPPkt9x.vxd, cannot differentiate TKIP and AES case. */
-			if (key->KeyLength == 32)
-				key->KeyLength = 16;
-			else {
-				ret = _FAIL;
-				goto exit;
-			}
-		}
-
-		/* Check key length for WEP. For NDTEST, 2005.01.27, by rcnjko. -> modify checking condition*/
-		if (((encryptionalgo == _WEP40_) && (key->KeyLength != 5)) || ((encryptionalgo == _WEP104_) && (key->KeyLength != 13))) {
-			ret = _FAIL;
-			goto exit;
-		}
-
-		bgroup = _FALSE;
-
-		/* Check the pairwise key. Added by Annie, 2005-07-06. */
-
-	} else {
-		/* Group key - KeyIndex(BIT30==0) */
-
-
-		/* when add wep key through add key and didn't assigned encryption type before */
-		if ((padapter->securitypriv.ndisauthtype <= 3) && (padapter->securitypriv.dot118021XGrpPrivacy == 0)) {
-
-			switch (key->KeyLength) {
-			case 5:
-				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP40_;
-				break;
-			case 13:
-				padapter->securitypriv.dot11PrivacyAlgrthm = _WEP104_;
-				break;
-			default:
-				padapter->securitypriv.dot11PrivacyAlgrthm = _NO_PRIVACY_;
-				break;
-			}
-
-			encryptionalgo = padapter->securitypriv.dot11PrivacyAlgrthm;
-
-
-		} else {
-			encryptionalgo = padapter->securitypriv.dot118021XGrpPrivacy;
-
-		}
-
-		if ((check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE) == _TRUE) && (IS_MAC_ADDRESS_BROADCAST(key->BSSID) == _FALSE)) {
-			ret = _FAIL;
-			goto exit;
-		}
-
-		/* Check key length for TKIP */
-		if ((encryptionalgo == _TKIP_) && (key->KeyLength != 32)) {
-
-			ret = _FAIL;
-			goto exit;
-
-		} else if (encryptionalgo == _AES_ && (key->KeyLength != 16 && key->KeyLength != 32)) {
-
-			/* Check key length for AES */
-			/* For NDTEST, we allow keylen=32 in this case. 2005.01.27, by rcnjko. */
-			ret = _FAIL;
-			goto exit;
-		}
-
-		/* Change the key length for EAPPkt9x.vxd. Added by Annie, 2005-11-03. */
-		if ((encryptionalgo ==  _AES_) && (key->KeyLength == 32)) {
-			key->KeyLength = 16;
-		}
-
-		if (key->KeyIndex & 0x8000000) /* error ??? 0x8000_0000 */
-			bgrouptkey = _TRUE;
-
-		if ((check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE) == _TRUE) && (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE))
-			bgrouptkey = _TRUE;
-
-		bgroup = _TRUE;
-
-
-	}
-
-	/* If WEP encryption algorithm, just call rtw_set_802_11_add_wep(). */
-	if ((padapter->securitypriv.dot11AuthAlgrthm != dot11AuthAlgrthm_8021X) && (encryptionalgo == _WEP40_  || encryptionalgo == _WEP104_)) {
-		u8 ret;
-		u32 keyindex;
-		u32 len = FIELD_OFFSET(NDIS_802_11_KEY, KeyMaterial) + key->KeyLength;
-		NDIS_802_11_WEP *wep = &padapter->securitypriv.ndiswep;
-
-
-		wep->Length = len;
-		keyindex = key->KeyIndex & 0x7fffffff;
-		wep->KeyIndex = keyindex ;
-		wep->KeyLength = key->KeyLength;
-
-
-		_rtw_memcpy(wep->KeyMaterial, key->KeyMaterial, key->KeyLength);
-		_rtw_memcpy(&(padapter->securitypriv.dot11DefKey[keyindex].skey[0]), key->KeyMaterial, key->KeyLength);
-
-		padapter->securitypriv.dot11DefKeylen[keyindex] = key->KeyLength;
-		padapter->securitypriv.dot11PrivacyKeyIndex = keyindex;
-
-		ret = rtw_set_802_11_add_wep(padapter, wep);
-
-		goto exit;
-
-	}
-
-	if (key->KeyIndex & 0x20000000) {
-		/* SetRSC */
-		if (bgroup == _TRUE) {
-			NDIS_802_11_KEY_RSC keysrc = key->KeyRSC & 0x00FFFFFFFFFFFFULL;
-			_rtw_memcpy(&padapter->securitypriv.dot11Grprxpn, &keysrc, 8);
-		} else {
-			NDIS_802_11_KEY_RSC keysrc = key->KeyRSC & 0x00FFFFFFFFFFFFULL;
-			_rtw_memcpy(&padapter->securitypriv.dot11Grptxpn, &keysrc, 8);
-		}
-
-	}
-
-	/* Indicate this key idx is used for TX */
-	/* Save the key in KeyMaterial */
-	if (bgroup == _TRUE) { /* Group transmit key */
-		int res;
-
-		if (bgrouptkey == _TRUE)
-			padapter->securitypriv.dot118021XGrpKeyid = (u8)key->KeyIndex;
-
-		if ((key->KeyIndex & 0x3) == 0) {
-			ret = _FAIL;
-			goto exit;
-		}
-
-		_rtw_memset(&padapter->securitypriv.dot118021XGrpKey[(u8)((key->KeyIndex) & 0x03)], 0, 16);
-		_rtw_memset(&padapter->securitypriv.dot118021XGrptxmickey[(u8)((key->KeyIndex) & 0x03)], 0, 16);
-		_rtw_memset(&padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)], 0, 16);
-
-		if ((key->KeyIndex & 0x10000000)) {
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrptxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 16, 8);
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 24, 8);
-
-
-		} else {
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrptxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 24, 8);
-			_rtw_memcpy(&padapter->securitypriv.dot118021XGrprxmickey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial + 16, 8);
-
-
-		}
-
-		/* set group key by index */
-		_rtw_memcpy(&padapter->securitypriv.dot118021XGrpKey[(u8)((key->KeyIndex) & 0x03)], key->KeyMaterial, key->KeyLength);
-
-		key->KeyIndex = key->KeyIndex & 0x03;
-
-		padapter->securitypriv.binstallGrpkey = _TRUE;
-
-		padapter->securitypriv.bcheck_grpkey = _FALSE;
-
-
-		res = rtw_set_key(padapter, &padapter->securitypriv, key->KeyIndex, 1, _TRUE);
-
-		if (res == _FAIL)
-			ret = _FAIL;
-
-		goto exit;
-
-	} else { /* Pairwise Key */
-		u8 res;
-
-		pbssid = get_bssid(&padapter->mlmepriv);
-		stainfo = rtw_get_stainfo(&padapter->stapriv , pbssid);
-
-		if (stainfo != NULL) {
-			_rtw_memset(&stainfo->dot118021x_UncstKey, 0, 16); /* clear keybuffer */
-
-			_rtw_memcpy(&stainfo->dot118021x_UncstKey, key->KeyMaterial, 16);
-
-			if (encryptionalgo == _TKIP_) {
-				padapter->securitypriv.busetkipkey = _FALSE;
-
-				/* if TKIP, save the Receive/Transmit MIC key in KeyMaterial[128-255] */
-				if ((key->KeyIndex & 0x10000000)) {
-					_rtw_memcpy(&stainfo->dot11tkiptxmickey, key->KeyMaterial + 16, 8);
-					_rtw_memcpy(&stainfo->dot11tkiprxmickey, key->KeyMaterial + 24, 8);
-
-				} else {
-					_rtw_memcpy(&stainfo->dot11tkiptxmickey, key->KeyMaterial + 24, 8);
-					_rtw_memcpy(&stainfo->dot11tkiprxmickey, key->KeyMaterial + 16, 8);
-
-				}
-
-			} else if (encryptionalgo == _AES_) {
-
-			}
-
-
-			/* Set key to CAM through H2C command */
-#if 0
-			if (bgrouptkey) { /* never go to here */
-				res = rtw_setstakey_cmd(padapter, stainfo, GROUP_KEY, _TRUE);
-			} else {
-				res = rtw_setstakey_cmd(padapter, stainfo, UNICAST_KEY, _TRUE);
-			}
-#else
-
-			res = rtw_setstakey_cmd(padapter, stainfo, UNICAST_KEY, _TRUE);
-#endif
-
-			if (res == _FALSE)
-				ret = _FAIL;
-
-		}
-
-	}
-
-exit:
-
-
-	return ret;
-}
-
-u8 rtw_set_802_11_remove_key(_adapter	*padapter, NDIS_802_11_REMOVE_KEY *key)
-{
-
-	uint				encryptionalgo;
-	u8 *pbssid;
-	struct sta_info *stainfo;
-	u8	bgroup = (key->KeyIndex & 0x4000000) > 0 ? _FALSE : _TRUE;
-	u8	keyIndex = (u8)key->KeyIndex & 0x03;
-	u8	ret = _SUCCESS;
-
-
-	if ((key->KeyIndex & 0xbffffffc) > 0) {
-		ret = _FAIL;
-		goto exit;
-	}
-
-	if (bgroup == _TRUE) {
-		encryptionalgo = padapter->securitypriv.dot118021XGrpPrivacy;
-		/* clear group key by index */
-		/* NdisZeroMemory(Adapter->MgntInfo.SecurityInfo.KeyBuf[keyIndex], MAX_WEP_KEY_LEN); */
-		/* Adapter->MgntInfo.SecurityInfo.KeyLen[keyIndex] = 0; */
-
-		_rtw_memset(&padapter->securitypriv.dot118021XGrpKey[keyIndex], 0, 16);
-
-		/* ! \todo Send a H2C Command to Firmware for removing this Key in CAM Entry. */
-
-	} else {
-
-		pbssid = get_bssid(&padapter->mlmepriv);
-		stainfo = rtw_get_stainfo(&padapter->stapriv , pbssid);
-		if (stainfo != NULL) {
-			encryptionalgo = stainfo->dot118021XPrivacy;
-
-			/* clear key by BSSID */
-			_rtw_memset(&stainfo->dot118021x_UncstKey, 0, 16);
-
-			/* ! \todo Send a H2C Command to Firmware for disable this Key in CAM Entry. */
-
-		} else {
-			ret = _FAIL;
-			goto exit;
-		}
-	}
-
-exit:
-
-
-	return _TRUE;
-
-}
-
 /*
 * rtw_get_cur_max_rate -
 * @adapter: pointer to _adapter structure
@@ -1127,10 +772,13 @@ exit:
 */
 u16 rtw_get_cur_max_rate(_adapter *adapter)
 {
+	int j;
 	int	i = 0;
 	u16	rate = 0, max_rate = 0;
 	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 	WLAN_BSSID_EX	*pcur_bss = &pmlmepriv->cur_network.network;
+	int	sta_bssrate_len = 0;
+	unsigned char	sta_bssrate[NumRates];
 	struct sta_info *psta = NULL;
 	u8	short_GI = 0;
 #ifdef CONFIG_80211N_HT
@@ -1170,16 +818,38 @@ u16 rtw_get_cur_max_rate(_adapter *adapter)
 	else
 #endif /* CONFIG_80211N_HT */
 	{
+		/*station mode show :station && ap support rate; softap :show ap support rate*/	
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+			get_rate_set(adapter, sta_bssrate, &sta_bssrate_len);/*get sta rate and length*/
+
+
 		while ((pcur_bss->SupportedRates[i] != 0) && (pcur_bss->SupportedRates[i] != 0xFF)) {
-			rate = pcur_bss->SupportedRates[i] & 0x7F;
-			if (rate > max_rate)
-				max_rate = rate;
+			rate = pcur_bss->SupportedRates[i] & 0x7F;/*AP support rates*/
+			/*RTW_INFO("%s rate=%02X \n", __func__, rate);*/
+
+			/*check STA  support rate or not */
+			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+				for (j = 0; j < sta_bssrate_len; j++) {
+					/* Avoid the proprietary data rate (22Mbps) of Handlink WSG-4000 AP */
+					if ((rate | IEEE80211_BASIC_RATE_MASK)
+					    == (sta_bssrate[j] | IEEE80211_BASIC_RATE_MASK)) {
+						if (rate > max_rate) {
+							max_rate = rate;
+						}
+						break;
+					}
+				}
+			} else {
+			
+				if (rate > max_rate)
+					max_rate = rate;
+
+			}
 			i++;
 		}
 
 		max_rate = max_rate * 10 / 2;
 	}
-
 	return max_rate;
 }
 
@@ -1209,9 +879,6 @@ int rtw_set_scan_mode(_adapter *adapter, RT_SCAN_TYPE scan_mode)
 */
 int rtw_set_channel_plan(_adapter *adapter, u8 channel_plan)
 {
-	struct registry_priv *pregistrypriv = &adapter->registrypriv;
-	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-
 	/* handle by cmd_thread to sync with scan operation */
 	return rtw_set_chplan_cmd(adapter, RTW_CMDF_WAIT_ACK, channel_plan, 1);
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_iol.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_iol.c
index aafac3fc234e..8eb2fb06e8d4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_iol.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_iol.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -301,24 +302,36 @@ int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value)
 #ifdef DBG_IO
 int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 1))
-		RTW_INFO("DBG_IO %s:%d IOL_WB(0x%04x, 0x%02x)\n", caller, line, addr, value);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(xmit_frame->padapter, addr, 1, value);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d IOL_WB(0x%04x, 0x%02x) %s\n"
+			, caller, line, addr, value, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_IOL_append_WB_cmd(xmit_frame, addr, value);
 }
 
 int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 2))
-		RTW_INFO("DBG_IO %s:%d IOL_WW(0x%04x, 0x%04x)\n", caller, line, addr, value);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(xmit_frame->padapter, addr, 2, value);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d IOL_WW(0x%04x, 0x%04x) %s\n"
+			, caller, line, addr, value, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_IOL_append_WW_cmd(xmit_frame, addr, value);
 }
 
 int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line)
 {
-	if (match_write_sniff_ranges(addr, 4))
-		RTW_INFO("DBG_IO %s:%d IOL_WD(0x%04x, 0x%08x)\n", caller, line, addr, value);
+	const struct rtw_io_sniff_ent *ent = match_write_sniff(xmit_frame->padapter, addr, 4, value);
+
+	if (ent) {
+		RTW_INFO("DBG_IO %s:%d IOL_WD(0x%04x, 0x%08x) %s\n"
+			, caller, line, addr, value, rtw_io_sniff_ent_get_tag(ent));
+	}
 
 	return _rtw_IOL_append_WD_cmd(xmit_frame, addr, value);
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mem.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mem.c
index d9f5652f9df8..4f241751050e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mem.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mem.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mi.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mi.c
index 641908aaef5e..53c56096114d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mi.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mi.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -27,6 +28,7 @@ void rtw_mi_update_union_chan_inf(_adapter *adapter, u8 ch, u8 offset , u8 bw)
 	iface_state->union_offset = offset;
 }
 
+#ifdef DBG_IFACE_STATUS
 #ifdef CONFIG_P2P
 static u8 _rtw_mi_p2p_listen_scan_chk(_adapter *adapter)
 {
@@ -46,6 +48,8 @@ static u8 _rtw_mi_p2p_listen_scan_chk(_adapter *adapter)
 	return p2p_listen_scan_state;
 }
 #endif
+#endif
+
 u8 rtw_mi_stayin_union_ch_chk(_adapter *adapter)
 {
 	u8 rst = _TRUE;
@@ -104,9 +108,8 @@ u8 rtw_mi_stayin_union_band_chk(_adapter *adapter)
 }
 
 /* Find union about ch, bw, ch_offset of all linked/linking interfaces */
-int _rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset, bool include_self)
+int rtw_mi_get_ch_setting_union_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp, u8 *ch, u8 *bw, u8 *offset)
 {
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	_adapter *iface;
 	struct mlme_ext_priv *mlmeext;
 	int i;
@@ -124,6 +127,9 @@ int _rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset,
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
+		if (!iface || !(ifbmp & BIT(iface->iface_id)))
+			continue;
+
 		mlmeext = &iface->mlmeextpriv;
 
 		if (!check_fwstate(&iface->mlmepriv, _FW_LINKED | _FW_UNDER_LINKING))
@@ -132,9 +138,6 @@ int _rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset,
 		if (check_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING))
 			continue;
 
-		if (include_self == _FALSE && adapter == iface)
-			continue;
-
 		if (num == 0) {
 			ch_ret = mlmeext->cur_channel;
 			bw_ret = mlmeext->cur_bwmode;
@@ -173,22 +176,17 @@ int _rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset,
 
 inline int rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 {
-	return _rtw_mi_get_ch_setting_union(adapter, ch, bw, offset, 1);
+	return rtw_mi_get_ch_setting_union_by_ifbmp(adapter_to_dvobj(adapter), 0xFF, ch, bw, offset);
 }
 
 inline int rtw_mi_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 {
-	return _rtw_mi_get_ch_setting_union(adapter, ch, bw, offset, 0);
+	return rtw_mi_get_ch_setting_union_by_ifbmp(adapter_to_dvobj(adapter), 0xFF & ~BIT(adapter->iface_id), ch, bw, offset);
 }
 
-#define MI_STATUS_SELF_ONLY		0
-#define MI_STATUS_OTHERS_ONLY	1
-#define MI_STATUS_ALL			2
-
 /* For now, not return union_ch/bw/offset */
-void _rtw_mi_status(_adapter *adapter, struct mi_state *mstate, u8 target_sel)
+void rtw_mi_status_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp, struct mi_state *mstate)
 {
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	_adapter *iface;
 	int i;
 
@@ -196,10 +194,7 @@ void _rtw_mi_status(_adapter *adapter, struct mi_state *mstate, u8 target_sel)
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
-
-		if (target_sel == MI_STATUS_SELF_ONLY && iface != adapter)
-			continue;
-		if (target_sel == MI_STATUS_OTHERS_ONLY && iface == adapter)
+		if (!iface || !(ifbmp & BIT(iface->iface_id)))
 			continue;
 
 		if (check_fwstate(&iface->mlmepriv, WIFI_STATION_STATE) == _TRUE) {
@@ -211,17 +206,26 @@ void _rtw_mi_status(_adapter *adapter, struct mi_state *mstate, u8 target_sel)
 				if (iface->tdlsinfo.link_established == _TRUE)
 					MSTATE_TDLS_LD_NUM(mstate)++;
 				#endif
+				#ifdef CONFIG_P2P
+				if (MLME_IS_GC(iface))
+					MSTATE_P2P_GC_NUM(mstate)++;
+				#endif
 			}
 			if (check_fwstate(&iface->mlmepriv, _FW_UNDER_LINKING) == _TRUE)
 				MSTATE_STA_LG_NUM(mstate)++;
 
 #ifdef CONFIG_AP_MODE
-		} else if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE
-			&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
-		) {
-			MSTATE_AP_NUM(mstate)++;
-			if (iface->stapriv.asoc_sta_count > 2)
-				MSTATE_AP_LD_NUM(mstate)++;
+		} else if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE ) {
+			if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
+				MSTATE_AP_NUM(mstate)++;
+				if (iface->stapriv.asoc_sta_count > 2)
+					MSTATE_AP_LD_NUM(mstate)++;
+				#ifdef CONFIG_P2P
+				if (MLME_IS_GO(iface))
+					MSTATE_P2P_GO_NUM(mstate)++;
+				#endif
+			} else
+				MSTATE_AP_STARTING_NUM(mstate)++;
 #endif
 
 		} else if (check_fwstate(&iface->mlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) == _TRUE
@@ -261,23 +265,26 @@ void _rtw_mi_status(_adapter *adapter, struct mi_state *mstate, u8 target_sel)
 			MSTATE_ROCH_NUM(mstate)++;
 		#endif
 #endif /* CONFIG_IOCTL_CFG80211 */
-
+#ifdef CONFIG_P2P
+		if (MLME_IS_PD(iface))
+			MSTATE_P2P_DV_NUM(mstate)++;
+#endif
 	}
 }
 
 inline void rtw_mi_status(_adapter *adapter, struct mi_state *mstate)
 {
-	return _rtw_mi_status(adapter, mstate, MI_STATUS_ALL);
+	return rtw_mi_status_by_ifbmp(adapter_to_dvobj(adapter), 0xFF, mstate);
 }
 
 inline void rtw_mi_status_no_self(_adapter *adapter, struct mi_state *mstate)
 {
-	return _rtw_mi_status(adapter, mstate, MI_STATUS_OTHERS_ONLY);
+	return rtw_mi_status_by_ifbmp(adapter_to_dvobj(adapter), 0xFF & ~BIT(adapter->iface_id), mstate);
 }
 
 inline void rtw_mi_status_no_others(_adapter *adapter, struct mi_state *mstate)
 {
-	return _rtw_mi_status(adapter, mstate, MI_STATUS_SELF_ONLY);
+	return rtw_mi_status_by_ifbmp(adapter_to_dvobj(adapter), BIT(adapter->iface_id), mstate);
 }
 
 /* For now, not handle union_ch/bw/offset */
@@ -321,6 +328,7 @@ void dump_mi_status(void *sel, struct dvobj_priv *dvobj)
 #endif
 #ifdef CONFIG_AP_MODE
 	RTW_PRINT_SEL(sel, "ap_num:%d\n", DEV_AP_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "starting_ap_num:%d\n", DEV_AP_STARTING_NUM(dvobj));
 	RTW_PRINT_SEL(sel, "linked_ap_num:%d\n", DEV_AP_LD_NUM(dvobj));
 #endif
 	RTW_PRINT_SEL(sel, "adhoc_num:%d\n", DEV_ADHOC_NUM(dvobj));
@@ -330,9 +338,11 @@ void dump_mi_status(void *sel, struct dvobj_priv *dvobj)
 	RTW_PRINT_SEL(sel, "linked_mesh_num:%d\n", DEV_MESH_LD_NUM(dvobj));
 #endif
 #ifdef CONFIG_P2P
-	RTW_PRINT_SEL(sel, "p2p_device_num:%d\n", rtw_mi_stay_in_p2p_mode(dvobj->padapters[IFACE_ID0]));
+	RTW_PRINT_SEL(sel, "p2p_device_num:%d\n", DEV_P2P_DV_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "p2p_gc_num:%d\n", DEV_P2P_GC_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "p2p_go_num:%d\n", DEV_P2P_GO_NUM(dvobj));
 #endif
-	RTW_PRINT_SEL(sel, "scan_num:%d\n", DEV_STA_NUM(dvobj));
+	RTW_PRINT_SEL(sel, "scan_num:%d\n", DEV_SCAN_NUM(dvobj));
 	RTW_PRINT_SEL(sel, "under_wps_num:%d\n", DEV_WPS_NUM(dvobj));
 #if defined(CONFIG_IOCTL_CFG80211)
 	#if defined(CONFIG_P2P)
@@ -358,9 +368,7 @@ inline void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state)
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct mi_state *iface_state = &dvobj->iface_state;
 	struct mi_state tmp_mstate;
-	u8 i;
 	u8 u_ch, u_offset, u_bw;
-	_adapter *iface;
 
 	if (state == WIFI_MONITOR_STATE
 		|| state == 0xFFFFFFFF
@@ -637,18 +645,33 @@ void rtw_mi_buddy_scan_abort(_adapter *adapter, bool bwait)
 	_rtw_mi_process(adapter, _TRUE, &in_data, _rtw_mi_scan_abort);
 }
 
-static u8 _rtw_mi_start_drv_threads(_adapter *adapter, void *data)
+static u32 _rtw_mi_start_drv_threads(_adapter *adapter, bool exclude_self)
 {
-	rtw_start_drv_threads(adapter);
-	return _TRUE;
+	int i;
+	_adapter *iface = NULL;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u32 _status = _SUCCESS;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {
+			if ((exclude_self) && (iface == adapter))
+				continue;
+			if (rtw_start_drv_threads(iface) == _FAIL) {
+				_status = _FAIL;
+				break;
+			}
+		}
+	}
+	return _status;
 }
-void rtw_mi_start_drv_threads(_adapter *adapter)
+u32 rtw_mi_start_drv_threads(_adapter *adapter)
 {
-	_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_start_drv_threads);
+	return _rtw_mi_start_drv_threads(adapter, _FALSE);
 }
-void rtw_mi_buddy_start_drv_threads(_adapter *adapter)
+u32 rtw_mi_buddy_start_drv_threads(_adapter *adapter)
 {
-	_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_start_drv_threads);
+	return _rtw_mi_start_drv_threads(adapter, _TRUE);
 }
 
 static void _rtw_mi_stop_drv_threads(_adapter *adapter, bool exclude_self)
@@ -659,10 +682,11 @@ static void _rtw_mi_stop_drv_threads(_adapter *adapter, bool exclude_self)
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
-		if ((iface) && (iface->bup == _TRUE))
+		if (iface) {
 			if ((exclude_self) && (iface == adapter))
 				continue;
-		rtw_stop_drv_threads(iface);
+			rtw_stop_drv_threads(iface);
+		}
 	}
 }
 void rtw_mi_stop_drv_threads(_adapter *adapter)
@@ -730,6 +754,30 @@ void rtw_mi_buddy_intf_stop(_adapter *adapter)
 	_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_intf_stop);
 }
 
+#ifdef CONFIG_NEW_NETDEV_HDL
+static u8 _rtw_mi_hal_iface_init(_adapter *padapter, void *data)
+{
+	if (rtw_hal_iface_init(padapter) == _SUCCESS)
+		return _TRUE;
+	return _FALSE;
+}
+u8 rtw_mi_hal_iface_init(_adapter *padapter)
+{
+	int i;
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	u8 ret = _TRUE;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface && iface->netif_up)
+			rtw_hal_iface_init(padapter);
+	}
+	return ret;
+}
+#endif
+
 static u8 _rtw_mi_suspend_free_assoc_resource(_adapter *padapter, void *data)
 {
 	return rtw_suspend_free_assoc_resource(padapter);
@@ -846,7 +894,6 @@ u8 _rtw_mi_busy_traffic_check(_adapter *padapter, void *data)
 		if (check_sc_interval) {
 			/* Miracast can't do AP scan*/
 			passtime = rtw_get_passing_time_ms(pmlmepriv->lastscantime);
-			pmlmepriv->lastscantime = rtw_get_current_time();
 			if (passtime > BUSY_TRAFFIC_SCAN_DENY_PERIOD) {
 				RTW_INFO(ADPT_FMT" bBusyTraffic == _TRUE\n", ADPT_ARG(padapter));
 				return _TRUE;
@@ -1071,20 +1118,6 @@ u8 rtw_mi_buddy_dynamic_check_timer_handlder(_adapter *padapter)
 	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_dynamic_check_timer_handlder);
 }
 
-static u8 _rtw_mi_dev_unload(_adapter *adapter, void *data)
-{
-	rtw_dev_unload(adapter);
-	return _TRUE;
-}
-u8 rtw_mi_dev_unload(_adapter *padapter)
-{
-	return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_dev_unload);
-}
-u8 rtw_mi_buddy_dev_unload(_adapter *padapter)
-{
-	return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_dev_unload);
-}
-
 static u8 _rtw_mi_dynamic_chk_wk_hdl(_adapter *adapter, void *data)
 {
 	rtw_iface_dynamic_chk_wk_hdl(adapter);
@@ -1145,6 +1178,29 @@ u8 rtw_mi_sreset_adapter_hdl(_adapter *padapter, u8 bstart)
 
 	return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_sreset_adapter_hdl);
 }
+
+#if defined(DBG_CONFIG_ERROR_RESET) && defined(CONFIG_CONCURRENT_MODE)
+void rtw_mi_ap_info_restore(_adapter *adapter)
+{
+	int i;
+	_adapter *iface;
+	struct mlme_priv *pmlmepriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {
+			pmlmepriv = &iface->mlmepriv;
+
+			if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
+				RTW_INFO(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(iface), MLME_IS_AP(iface) ? "AP" : "MESH");
+				rtw_iface_bcmc_sec_cam_map_restore(iface);
+			}
+		}
+	}
+}
+#endif /*#if defined(DBG_CONFIG_ERROR_RESET) && defined(CONFIG_CONCURRENT_MODE)*/
+
 u8 rtw_mi_buddy_sreset_adapter_hdl(_adapter *padapter, u8 bstart)
 {
 	u8 in_data = bstart;
@@ -1158,7 +1214,7 @@ static u8 _rtw_mi_tx_beacon_hdl(_adapter *adapter, void *data)
 	) {
 		adapter->mlmepriv.update_bcn = _TRUE;
 #ifndef CONFIG_INTERRUPT_BASED_TXBCN
-#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_PCI_BCN_POLLING)
 		tx_beacon_hdl(adapter, NULL);
 #endif
 #endif
@@ -1244,7 +1300,7 @@ _adapter *rtw_get_iface_by_id(_adapter *padapter, u8 iface_id)
 	return  dvobj->padapters[iface_id];
 }
 
-_adapter *rtw_get_iface_by_macddr(_adapter *padapter, u8 *mac_addr)
+_adapter *rtw_get_iface_by_macddr(_adapter *padapter, const u8 *mac_addr)
 {
 	int i;
 	_adapter *iface = NULL;
@@ -1336,9 +1392,10 @@ void rtw_dbg_skb_process(_adapter *padapter, union recv_frame *precvframe, union
 static s32 _rtw_mi_buddy_clone_bcmc_packet(_adapter *adapter, union recv_frame *precvframe, u8 *pphy_status, union recv_frame *pcloneframe)
 {
 	s32 ret = _SUCCESS;
+#ifdef CONFIG_SKB_ALLOCATED
 	u8 *pbuf = precvframe->u.hdr.rx_data;
+#endif
 	struct rx_pkt_attrib *pattrib = NULL;
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(adapter);
 
 	if (pcloneframe) {
 		pcloneframe->u.hdr.adapter = adapter;
@@ -1433,6 +1490,45 @@ _adapter *rtw_mi_get_ap_adapter(_adapter *padapter)
 }
 #endif
 
+u8 rtw_mi_get_ld_sta_ifbmp(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	int i;
+	_adapter *iface = NULL;
+	u8 ifbmp = 0;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		if (MLME_IS_STA(iface) && MLME_IS_ASOC(iface))
+			ifbmp |= BIT(i);
+	}
+
+	return ifbmp;
+}
+
+u8 rtw_mi_get_ap_mesh_ifbmp(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	int i;
+	_adapter *iface = NULL;
+	u8 ifbmp = 0;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		if (CHK_MLME_STATE(iface, WIFI_AP_STATE | WIFI_MESH_STATE)
+			&& MLME_IS_ASOC(iface))
+			ifbmp |= BIT(i);
+	}
+
+	return ifbmp;
+}
+
 void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b)
 {
 #ifdef CONFIG_CONCURRENT_MODE
@@ -1458,3 +1554,19 @@ void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b)
 #endif
 }
 
+u8 rtw_mi_get_assoc_if_num(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 n_assoc_iface = 0;
+#if 1
+	u8 i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		if (check_fwstate(&(dvobj->padapters[i]->mlmepriv), WIFI_ASOC_STATE))
+			n_assoc_iface++;
+	}
+#else
+	n_assoc_iface = DEV_STA_LD_NUM(dvobj) + DEV_AP_NUM(dvobj) + DEV_ADHOC_NUM(dvobj) + DEV_MESH_NUM(dvobj);
+#endif
+	return n_assoc_iface;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme.c
index 736b9241b8a4..e9bc384b8479 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -27,10 +28,6 @@ void rtw_init_mlme_timer(_adapter *padapter)
 	rtw_init_timer(&(pmlmepriv->assoc_timer), padapter, rtw_join_timeout_handler, padapter);
 	rtw_init_timer(&(pmlmepriv->scan_to_timer), padapter, rtw_scan_timeout_handler, padapter);
 
-#ifdef CONFIG_DFS_MASTER
-	rtw_init_timer(&(pmlmepriv->dfs_master_timer), padapter, rtw_dfs_master_timer_hdl, padapter);
-#endif
-
 #ifdef CONFIG_SET_SCAN_DENY_TIMER
 	rtw_init_timer(&(pmlmepriv->set_scan_deny_timer), padapter, rtw_set_scan_deny_timer_hdl, padapter);
 #endif
@@ -47,6 +44,7 @@ sint	_rtw_init_mlme_priv(_adapter *padapter)
 	u8	*pbuf;
 	struct wlan_network	*pnetwork;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	sint	res = _SUCCESS;
 
 
@@ -65,11 +63,7 @@ sint	_rtw_init_mlme_priv(_adapter *padapter)
 	pmlmepriv->nic_hdl = (u8 *)padapter;
 
 	pmlmepriv->pscanned = NULL;
-	/*pmlmepriv->fw_state = WIFI_STATION_STATE; */ /*Must sync with rtw_wdev_alloc()*/
-	/*init_fwstate(pmlmepriv, WIFI_STATION_STATE);*/
-	init_fwstate(pmlmepriv, WIFI_NULL_STATE);/*assigned interface role(STA/AP) must after execute set_opmode*/
-
-	/* wdev->iftype = NL80211_IFTYPE_STATION*/
+	init_fwstate(pmlmepriv, WIFI_STATION_STATE);
 	pmlmepriv->cur_network.network.InfrastructureMode = Ndis802_11AutoUnknown;
 	pmlmepriv->scan_mode = SCAN_ACTIVE; /* 1: active, 0: pasive. Maybe someday we should rename this varable to "active_mode" (Jeff) */
 
@@ -81,7 +75,15 @@ sint	_rtw_init_mlme_priv(_adapter *padapter)
 
 	_rtw_memset(&pmlmepriv->assoc_ssid, 0, sizeof(NDIS_802_11_SSID));
 
-	pbuf = rtw_zvmalloc(MAX_BSS_CNT * (sizeof(struct wlan_network)));
+	if (padapter->registrypriv.max_bss_cnt != 0)
+		pmlmepriv->max_bss_cnt = padapter->registrypriv.max_bss_cnt;
+	else if (rfctl->max_chan_nums <= MAX_CHANNEL_NUM_2G)
+		pmlmepriv->max_bss_cnt = MAX_BSS_CNT;
+	else
+		pmlmepriv->max_bss_cnt = MAX_BSS_CNT + MAX_BSS_CNT;
+
+
+	pbuf = rtw_zvmalloc(pmlmepriv->max_bss_cnt * (sizeof(struct wlan_network)));
 
 	if (pbuf == NULL) {
 		res = _FAIL;
@@ -91,7 +93,7 @@ sint	_rtw_init_mlme_priv(_adapter *padapter)
 
 	pnetwork = (struct wlan_network *)pbuf;
 
-	for (i = 0; i < MAX_BSS_CNT; i++) {
+	for (i = 0; i < pmlmepriv->max_bss_cnt; i++) {
 		_rtw_init_listhead(&(pnetwork->list));
 
 		rtw_list_insert_tail(&(pnetwork->list), &(pmlmepriv->free_bss_pool.queue));
@@ -110,7 +112,7 @@ sint	_rtw_init_mlme_priv(_adapter *padapter)
 #ifdef CONFIG_LAYER2_ROAMING
 #define RTW_ROAM_SCAN_RESULT_EXP_MS (5*1000)
 #define RTW_ROAM_RSSI_DIFF_TH 10
-#define RTW_ROAM_SCAN_INTERVAL_MS (10*1000)
+#define RTW_ROAM_SCAN_INTERVAL (5)    /* 5*(2 second)*/
 #define RTW_ROAM_RSSI_THRESHOLD 70
 
 	pmlmepriv->roam_flags = 0
@@ -125,16 +127,20 @@ sint	_rtw_init_mlme_priv(_adapter *padapter)
 
 	pmlmepriv->roam_scanr_exp_ms = RTW_ROAM_SCAN_RESULT_EXP_MS;
 	pmlmepriv->roam_rssi_diff_th = RTW_ROAM_RSSI_DIFF_TH;
-	pmlmepriv->roam_scan_int_ms = RTW_ROAM_SCAN_INTERVAL_MS;
+	pmlmepriv->roam_scan_int 	 = RTW_ROAM_SCAN_INTERVAL;
 	pmlmepriv->roam_rssi_threshold = RTW_ROAM_RSSI_THRESHOLD;
+	pmlmepriv->need_to_roam = _FALSE;
+	pmlmepriv->last_roaming = rtw_get_current_time();
 #endif /* CONFIG_LAYER2_ROAMING */
 
 #ifdef CONFIG_RTW_80211R
-	memset(&pmlmepriv->ftpriv, 0, sizeof(ft_priv));
-	pmlmepriv->ftpriv.ft_flags = 0
-		| RTW_FT_STA_SUPPORTED
-		| RTW_FT_STA_OVER_DS_SUPPORTED
-		;
+	rtw_ft_info_init(&pmlmepriv->ft_roam);
+#endif
+#ifdef CONFIG_LAYER2_ROAMING
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+	rtw_roam_nb_info_init(padapter);
+	pmlmepriv->ch_cnt = 0;
+#endif	
 #endif
 	rtw_init_mlme_timer(padapter);
 
@@ -292,6 +298,7 @@ exit:
 
 void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
 {
+	_adapter *adapter = mlme_to_adapter(pmlmepriv);
 	if (NULL == pmlmepriv) {
 		rtw_warn_on(1);
 		goto exit;
@@ -302,7 +309,7 @@ void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
 		rtw_mfree_mlme_priv_lock(pmlmepriv);
 
 		if (pmlmepriv->free_bss_buf)
-			rtw_vmfree(pmlmepriv->free_bss_buf, MAX_BSS_CNT * sizeof(struct wlan_network));
+			rtw_vmfree(pmlmepriv->free_bss_buf, pmlmepriv->max_bss_cnt * sizeof(struct wlan_network));
 	}
 exit:
 	return;
@@ -379,6 +386,11 @@ struct	wlan_network *_rtw_alloc_network(struct	mlme_priv *pmlmepriv) /* (_queue
 	pnetwork->network_type = 0;
 	pnetwork->fixed = _FALSE;
 	pnetwork->last_scanned = rtw_get_current_time();
+#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
+	pnetwork->acnode_stime = 0;
+	pnetwork->acnode_notify_etime = 0;
+#endif
+
 	pnetwork->aid = 0;
 	pnetwork->join_res = 0;
 
@@ -458,53 +470,6 @@ exit:
 	return;
 }
 
-
-/*
-	return the wlan_network with the matching addr
-
-	Shall be calle under atomic context... to avoid possible racing condition...
-*/
-struct wlan_network *_rtw_find_network(_queue *scanned_queue, u8 *addr)
-{
-
-	/* _irqL irqL; */
-	_list	*phead, *plist;
-	struct	wlan_network *pnetwork = NULL;
-	u8 zero_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
-
-
-	if (_rtw_memcmp(zero_addr, addr, ETH_ALEN)) {
-		pnetwork = NULL;
-		goto exit;
-	}
-
-	/* _enter_critical_bh(&scanned_queue->lock, &irqL); */
-
-	phead = get_list_head(scanned_queue);
-	plist = get_next(phead);
-
-	while (plist != phead) {
-		pnetwork = LIST_CONTAINOR(plist, struct wlan_network , list);
-
-		if (_rtw_memcmp(addr, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE)
-			break;
-
-		plist = get_next(plist);
-	}
-
-	if (plist == phead)
-		pnetwork = NULL;
-
-	/* _exit_critical_bh(&scanned_queue->lock, &irqL); */
-
-exit:
-
-
-	return pnetwork;
-
-}
-
-
 void _rtw_free_network_queue(_adapter *padapter, u8 isfreeall)
 {
 	_irqL irqL;
@@ -645,14 +610,44 @@ void rtw_free_network_queue(_adapter *dev, u8 isfreeall)
 	_rtw_free_network_queue(dev, isfreeall);
 }
 
-/*
-	return the wlan_network with the matching addr
+struct wlan_network *_rtw_find_network(_queue *scanned_queue, const u8 *addr)
+{
+	_list	*phead, *plist;
+	struct	wlan_network *pnetwork = NULL;
+	u8 zero_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
 
-	Shall be calle under atomic context... to avoid possible racing condition...
-*/
-struct	wlan_network *rtw_find_network(_queue *scanned_queue, u8 *addr)
+	if (_rtw_memcmp(zero_addr, addr, ETH_ALEN)) {
+		pnetwork = NULL;
+		goto exit;
+	}
+
+	phead = get_list_head(scanned_queue);
+	plist = get_next(phead);
+
+	while (plist != phead) {
+		pnetwork = LIST_CONTAINOR(plist, struct wlan_network , list);
+
+		if (_rtw_memcmp(addr, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE)
+			break;
+
+		plist = get_next(plist);
+	}
+
+	if (plist == phead)
+		pnetwork = NULL;
+
+exit:
+	return pnetwork;
+}
+
+struct wlan_network *rtw_find_network(_queue *scanned_queue, const u8 *addr)
 {
-	struct	wlan_network *pnetwork = _rtw_find_network(scanned_queue, addr);
+	struct	wlan_network *pnetwork;
+	_irqL irqL;
+
+	 _enter_critical_bh(&scanned_queue->lock, &irqL);
+	pnetwork = _rtw_find_network(scanned_queue, addr);
+	_exit_critical_bh(&scanned_queue->lock, &irqL);
 
 	return pnetwork;
 }
@@ -704,15 +699,35 @@ int is_same_network(WLAN_BSSID_EX *src, WLAN_BSSID_EX *dst, u8 feature)
 		return _TRUE;
 #endif
 
-	return ((src->Ssid.SsidLength == dst->Ssid.SsidLength) &&
-		/*	(src->Configuration.DSConfig == dst->Configuration.DSConfig) && */
-		((_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN)) == _TRUE) &&
-		((_rtw_memcmp(src->Ssid.Ssid, dst->Ssid.Ssid, src->Ssid.SsidLength)) == _TRUE) &&
-		((s_cap & WLAN_CAPABILITY_IBSS) ==
-		 (d_cap & WLAN_CAPABILITY_IBSS)) &&
-		((s_cap & WLAN_CAPABILITY_BSS) ==
-		 (d_cap & WLAN_CAPABILITY_BSS)));
-
+	/* Wi-Fi driver doesn't consider the situation of BCN and ProbRsp sent from the same hidden AP, 
+	  * it considers these two packets are sent from different AP. 
+	  * Therefore, the scan queue may store two scan results of the same hidden AP, likes below.
+	  *
+	  *  index            bssid              ch    RSSI   SdBm  Noise   age          flag             ssid
+	  *    1    00:e0:4c:55:50:01    153   -73     -73        0     7044   [WPS][ESS]     RTK5G
+	  *    3    00:e0:4c:55:50:01    153   -73     -73        0     7044   [WPS][ESS]
+	  *
+	  * Original rules will compare Ssid, SsidLength, MacAddress, s_cap, d_cap at the same time.
+	  * Wi-Fi driver will assume that the BCN and ProbRsp sent from the same hidden AP are the same network
+	  * after we add an additional rule to compare SsidLength and Ssid.
+	  * It means the scan queue will not store two scan results of the same hidden AP, it only store ProbRsp.
+	  * For customer request.
+	  */
+	  
+	if (((_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN)) == _TRUE) &&
+		((s_cap & WLAN_CAPABILITY_IBSS) == (d_cap & WLAN_CAPABILITY_IBSS)) &&
+		((s_cap & WLAN_CAPABILITY_BSS) == (d_cap & WLAN_CAPABILITY_BSS))) {
+		if ((src->Ssid.SsidLength == dst->Ssid.SsidLength) && 
+			(((_rtw_memcmp(src->Ssid.Ssid, dst->Ssid.Ssid, src->Ssid.SsidLength)) == _TRUE) || //Case of normal AP
+			(is_all_null(src->Ssid.Ssid, src->Ssid.SsidLength) == _TRUE || is_all_null(dst->Ssid.Ssid, dst->Ssid.SsidLength) == _TRUE))) //Case of hidden AP
+			return _TRUE;
+		else if ((src->Ssid.SsidLength == 0 || dst->Ssid.SsidLength == 0)) //Case of hidden AP
+			return _TRUE;
+		else
+			return _FALSE;
+	} else {
+		return _FALSE;
+	}
 }
 
 struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network)
@@ -734,7 +749,7 @@ struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_n
 
 	if (plist == phead)
 		found = NULL;
-exit:
+
 	return found;
 }
 
@@ -773,7 +788,7 @@ struct	wlan_network	*rtw_get_oldest_wlan_network(_queue *scanned_queue)
 		pwlan = LIST_CONTAINOR(plist, struct wlan_network, list);
 
 		if (pwlan->fixed != _TRUE) {
-			if (oldest == NULL || time_after(oldest->last_scanned, pwlan->last_scanned))
+			if (oldest == NULL || rtw_time_after(oldest->last_scanned, pwlan->last_scanned))
 				oldest = pwlan;
 		}
 
@@ -786,14 +801,15 @@ struct	wlan_network	*rtw_get_oldest_wlan_network(_queue *scanned_queue)
 void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src,
 		    _adapter *padapter, bool update_ie)
 {
+#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
 	u8 ss_ori = dst->PhyInfo.SignalStrength;
 	u8 sq_ori = dst->PhyInfo.SignalQuality;
-	long rssi_ori = dst->Rssi;
-
 	u8 ss_smp = src->PhyInfo.SignalStrength;
-	u8 sq_smp = src->PhyInfo.SignalQuality;
 	long rssi_smp = src->Rssi;
+#endif
+	long rssi_ori = dst->Rssi;
 
+	u8 sq_smp = src->PhyInfo.SignalQuality;
 	u8 ss_final;
 	u8 sq_final;
 	long rssi_final;
@@ -920,22 +936,21 @@ Caller must hold pmlmepriv->lock first.
 
 
 */
-void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
+bool rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 {
 	_irqL irqL;
 	_list	*plist, *phead;
 	ULONG	bssid_ex_sz;
 	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
-	struct mlme_ext_priv	*pmlmeext = &(adapter->mlmeextpriv);
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
 #endif /* CONFIG_P2P */
 	_queue	*queue	= &(pmlmepriv->scanned_queue);
 	struct wlan_network	*pnetwork = NULL;
-	struct wlan_network	*oldest = NULL;
+	struct wlan_network	*choice = NULL;
 	int target_find = 0;
 	u8 feature = 0;
-
+	bool update_ie = _FALSE;
 
 	_enter_critical_bh(&queue->lock, &irqL);
 	phead = get_list_head(queue);
@@ -973,14 +988,27 @@ void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 		}
 
 		if (rtw_roam_flags(adapter)) {
-			/* TODO: don't  select netowrk in the same ess as oldest if it's new enough*/
+			/* TODO: don't  select netowrk in the same ess as choice if it's new enough*/
 		}
+		if (pnetwork->fixed) {
+			plist = get_next(plist);
+			continue;
+		}
+			
 #ifdef CONFIG_RSSI_PRIORITY
-		if ((oldest == NULL) || (pnetwork->network.PhyInfo.SignalStrength < oldest->network.PhyInfo.SignalStrength))
-			oldest = pnetwork;
+		if ((choice == NULL) || (pnetwork->network.PhyInfo.SignalStrength < choice->network.PhyInfo.SignalStrength))
+			#ifdef CONFIG_RTW_MESH
+			if (!MLME_IS_MESH(adapter) || !MLME_IS_ASOC(adapter)
+				|| !rtw_bss_is_same_mbss(&pmlmepriv->cur_network.network, &pnetwork->network))
+			#endif
+				choice = pnetwork;
 #else
-		if (oldest == NULL || time_after(oldest->last_scanned, pnetwork->last_scanned))
-			oldest = pnetwork;
+		if (choice == NULL || rtw_time_after(choice->last_scanned, pnetwork->last_scanned))
+			#ifdef CONFIG_RTW_MESH
+			if (!MLME_IS_MESH(adapter) || !MLME_IS_ASOC(adapter)
+				|| !rtw_bss_is_same_mbss(&pmlmepriv->cur_network.network, &pnetwork->network))
+			#endif
+				choice = pnetwork;
 #endif
 		plist = get_next(plist);
 
@@ -992,12 +1020,12 @@ void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 	/* if (rtw_end_of_queue_search(phead,plist)== _TRUE) { */
 	if (!target_find) {
 		if (_rtw_queue_empty(&(pmlmepriv->free_bss_pool)) == _TRUE) {
-			/* If there are no more slots, expire the oldest */
-			/* list_del_init(&oldest->list); */
-			pnetwork = oldest;
-			if (pnetwork == NULL) {
-				goto exit;
-			}
+			/* If there are no more slots, expire the choice */
+			/* list_del_init(&choice->list); */
+			pnetwork = choice;
+			if (pnetwork == NULL)
+				goto unlock_scan_queue;
+
 #ifdef CONFIG_RSSI_PRIORITY
 		RTW_DBG("%s => ssid:%s ,bssid:"MAC_FMT"  will be deleted from scanned_queue (rssi:%ld , ss:%d)\n",
 			__func__, pnetwork->network.Ssid.Ssid, MAC_ARG(pnetwork->network.MacAddress), pnetwork->network.Rssi, pnetwork->network.PhyInfo.SignalStrength);
@@ -1014,6 +1042,10 @@ void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 			/* variable initialize */
 			pnetwork->fixed = _FALSE;
 			pnetwork->last_scanned = rtw_get_current_time();
+			#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
+			pnetwork->acnode_stime = 0;
+			pnetwork->acnode_notify_etime = 0;
+			#endif
 
 			pnetwork->network_type = 0;
 			pnetwork->aid = 0;
@@ -1026,10 +1058,8 @@ void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 			/* Otherwise just pull from the free list */
 
 			pnetwork = rtw_alloc_network(pmlmepriv); /* will update scan_time */
-
-			if (pnetwork == NULL) {
-				goto exit;
-			}
+			if (pnetwork == NULL)
+				goto unlock_scan_queue;
 
 			bssid_ex_sz = get_WLAN_BSSID_EX_sz(target);
 			target->Length = bssid_ex_sz;
@@ -1052,7 +1082,9 @@ void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 		 * 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;
+		#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
+		systime last_scanned = pnetwork->last_scanned;
+		#endif
 
 		pnetwork->last_scanned = rtw_get_current_time();
 
@@ -1060,30 +1092,53 @@ void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
 		if ((pnetwork->network.IELength > target->IELength) && (target->Reserved[0] == BSS_TYPE_BCN))
 			update_ie = _FALSE;
 
-		/* probe resp(3) > beacon(1) > probe req(2) */
-		if ((target->Reserved[0] != BSS_TYPE_PROB_REQ) &&
-		    (target->Reserved[0] >= pnetwork->network.Reserved[0])
-		   )
+		if (MLME_IS_MESH(adapter)
+			/* probe resp(3) > beacon(1) > probe req(2) */
+			|| (target->Reserved[0] != BSS_TYPE_PROB_REQ
+				&& target->Reserved[0] >= pnetwork->network.Reserved[0])
+		)
 			update_ie = _TRUE;
 		else
 			update_ie = _FALSE;
 
+		#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
+		if (!MLME_IS_MESH(adapter) || !MLME_IS_ASOC(adapter)
+			|| pnetwork->network.Configuration.DSConfig != target->Configuration.DSConfig
+			|| rtw_get_passing_time_ms(last_scanned) > adapter->mesh_cfg.peer_sel_policy.scanr_exp_ms
+			|| !rtw_bss_is_same_mbss(&pnetwork->network, target)
+		) {
+			pnetwork->acnode_stime = 0;
+			pnetwork->acnode_notify_etime = 0;
+		}
+		#endif
 		update_network(&(pnetwork->network), target, adapter, update_ie);
 	}
 
-exit:
+	#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
+	if (MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter))
+		rtw_mesh_update_scanned_acnode_status(adapter, pnetwork);
+	#endif
+
+unlock_scan_queue:
 	_exit_critical_bh(&queue->lock, &irqL);
 
+#ifdef CONFIG_RTW_MESH
+	if (pnetwork && MLME_IS_MESH(adapter)
+		&& check_fwstate(pmlmepriv, WIFI_ASOC_STATE)
+		&& !check_fwstate(pmlmepriv, WIFI_SITE_MONITOR)
+	)
+		rtw_chk_candidate_peer_notify(adapter, pnetwork);
+#endif
+
+	return update_ie;
 }
 
 void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork);
 void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)
 {
-	_irqL irqL;
-	struct	mlme_priv	*pmlmepriv = &(((_adapter *)adapter)->mlmepriv);
+	bool update_ie;
 	/* _queue	*queue	= &(pmlmepriv->scanned_queue); */
 
-
 	/* _enter_critical_bh(&queue->lock, &irqL); */
 
 #if defined(CONFIG_P2P) && defined(CONFIG_P2P_REMOVE_GROUP_INFO)
@@ -1094,9 +1149,11 @@ void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)
 	if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
 		rtw_bss_ex_del_wfd_ie(pnetwork);
 
-	update_current_network(adapter, pnetwork);
+	/* Wi-Fi driver will update the current network if the scan result of the connected AP be updated by scan. */
+	update_ie = rtw_update_scanned_network(adapter, pnetwork);
 
-	rtw_update_scanned_network(adapter, pnetwork);
+	if (update_ie)
+		update_current_network(adapter, pnetwork);
 
 	/* _exit_critical_bh(&queue->lock, &irqL); */
 
@@ -1215,7 +1272,7 @@ void rtw_survey_event_callback(_adapter	*adapter, u8 *pbuf)
 
 			_rtw_memcpy(pmlmepriv->cur_network.network.IEs, pnetwork->IEs, 8);
 			_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-			ibss_wlan = rtw_find_network(&pmlmepriv->scanned_queue,  pnetwork->MacAddress);
+			ibss_wlan = _rtw_find_network(&pmlmepriv->scanned_queue,  pnetwork->MacAddress);
 			if (ibss_wlan) {
 				_rtw_memcpy(ibss_wlan->network.IEs , pnetwork->IEs, 8);
 				_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
@@ -1323,13 +1380,15 @@ void rtw_surveydone_event_callback(_adapter	*adapter, u8 *pbuf)
 				RTW_INFO("try_to_join, but select scanning queue fail, to_roam:%d\n", rtw_to_roam(adapter));
 
 				if (rtw_to_roam(adapter) != 0) {
+					u8 ssc_chk = rtw_sitesurvey_condition_check(adapter, _FALSE);
 
 					rtw_init_sitesurvey_parm(adapter, &parm);
 					_rtw_memcpy(&parm.ssid[0], &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
 					parm.ssid_num = 1;
 
 					if (rtw_dec_to_roam(adapter) == 0
-					    || _SUCCESS != rtw_sitesurvey_cmd(adapter, &parm)
+						|| (ssc_chk != SS_ALLOW && ssc_chk != SS_DENY_BUSY_TRAFFIC)
+						|| _SUCCESS != rtw_sitesurvey_cmd(adapter, &parm)
 					   ) {
 						rtw_set_to_roam(adapter, 0);
 #ifdef CONFIG_INTEL_WIDI
@@ -1339,7 +1398,7 @@ void rtw_surveydone_event_callback(_adapter	*adapter, u8 *pbuf)
 							RTW_INFO("change to widi listen\n");
 						}
 #endif /* CONFIG_INTEL_WIDI */
-						rtw_free_assoc_resources(adapter, 1);
+						rtw_free_assoc_resources(adapter, _TRUE);
 						rtw_indicate_disconnect(adapter, 0, _FALSE);
 					} else
 						pmlmepriv->to_join = _TRUE;
@@ -1354,12 +1413,8 @@ void rtw_surveydone_event_callback(_adapter	*adapter, u8 *pbuf)
 			    && check_fwstate(pmlmepriv, _FW_LINKED)) {
 				if (rtw_select_roaming_candidate(pmlmepriv) == _SUCCESS) {
 #ifdef CONFIG_RTW_80211R
-					if (rtw_chk_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED)) {
-						start_clnt_ft_action(adapter, (u8 *)pmlmepriv->roam_network->network.MacAddress);
-					} else {
-						/*wait a little time to retrieve packets buffered in the current ap while scan*/
-						_set_timer(&pmlmeext->ft_roam_timer, 30);
-					}
+					rtw_ft_start_roam(adapter,
+						(u8 *)pmlmepriv->roam_network->network.MacAddress);
 #else
 					receive_disconnect(adapter, pmlmepriv->cur_network.network.MacAddress
 						, WLAN_REASON_ACTIVE_ROAM, _FALSE);
@@ -1403,6 +1458,143 @@ void rtw_surveydone_event_callback(_adapter	*adapter, u8 *pbuf)
 	rtw_cfg80211_indicate_scan_done_for_buddy(adapter, _FALSE);
 #endif
 
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_OFFCH_CAND
+	if (rtw_mesh_offch_candidate_accepted(adapter)) {
+		u8 ch;
+
+		ch = rtw_mesh_select_operating_ch(adapter);
+		if (ch && pmlmepriv->cur_network.network.Configuration.DSConfig != ch) {
+			u8 ifbmp = rtw_mi_get_ap_mesh_ifbmp(adapter);
+
+			if (ifbmp) {
+				/* switch to selected channel */
+				rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_DIRECTLY, ifbmp, 0, ch, REQ_BW_ORI, REQ_OFFSET_NONE);
+				issue_probereq_ex(adapter, &pmlmepriv->cur_network.network.mesh_id, NULL, 0, 0, 0, 0);
+			} else
+				rtw_warn_on(1);
+		}
+	}
+	#endif
+#endif /* CONFIG_RTW_MESH */
+}
+
+u8 _rtw_sitesurvey_condition_check(const char *caller, _adapter *adapter, bool check_sc_interval)
+{
+	u8 ss_condition = SS_ALLOW;
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+#ifdef DBG_LA_MODE
+	struct registry_priv *registry_par = &adapter->registrypriv;
+#endif
+
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(adapter)) {
+		RTW_INFO("%s ("ADPT_FMT") MP mode block Scan request\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_MP_MODE;
+		goto _exit;
+	}
+#endif
+
+#ifdef DBG_LA_MODE
+	if(registry_par->la_mode_en == 1 && MLME_IS_ASOC(adapter)) {
+		RTW_INFO("%s ("ADPT_FMT") LA debug mode block Scan request\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_LA_MODE;
+		goto _exit;
+	}
+#endif
+
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (adapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
+		RTW_INFO("%s ("ADPT_FMT") blocking scan for under rson scanning process\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_RSON_SCANING;
+		goto _exit;
+	}
+#endif
+#ifdef CONFIG_IOCTL_CFG80211
+	if (adapter_wdev_data(adapter)->block_scan == _TRUE) {
+		RTW_INFO("%s ("ADPT_FMT") wdev_priv.block_scan is set\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_BLOCK_SCAN;
+		goto _exit;
+	}
+#endif
+
+	if (adapter_to_dvobj(adapter)->scan_deny == _TRUE) {
+		RTW_INFO("%s ("ADPT_FMT") tpt mode, scan deny!\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_BLOCK_SCAN;
+		goto _exit;
+	}
+
+	if (rtw_is_scan_deny(adapter)) {
+		RTW_INFO("%s ("ADPT_FMT") : scan deny\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_BY_DRV;
+		goto _exit;
+	}
+
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE)){
+		if(check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
+			RTW_INFO("%s ("ADPT_FMT") : scan abort!! AP mode process WPS\n", caller, ADPT_ARG(adapter));
+			ss_condition = SS_DENY_SELF_AP_UNDER_WPS;
+			goto _exit;
+		} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+			RTW_INFO("%s ("ADPT_FMT") : scan abort!!AP mode under linking (fwstate=0x%x)\n",
+				caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
+			ss_condition = SS_DENY_SELF_AP_UNDER_LINKING;
+			goto _exit;
+		} else if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+			RTW_INFO("%s ("ADPT_FMT") : scan abort!!AP mode under survey (fwstate=0x%x)\n",
+				caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
+			ss_condition = SS_DENY_SELF_AP_UNDER_SURVEY;
+			goto _exit;
+		}
+	} else {
+		if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+			RTW_INFO("%s ("ADPT_FMT") : scan abort!!STA mode under linking (fwstate=0x%x)\n",
+				caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
+			ss_condition = SS_DENY_SELF_STA_UNDER_LINKING;
+			goto _exit;
+		} else if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
+			RTW_INFO("%s ("ADPT_FMT") : scan abort!!STA mode under survey (fwstate=0x%x)\n",
+				caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
+			ss_condition = SS_DENY_SELF_STA_UNDER_SURVEY;
+			goto _exit;
+		}
+	}
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(adapter, _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
+		RTW_INFO("%s ("ADPT_FMT") : scan abort!! buddy_intf under linking or wps\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_BUDDY_UNDER_LINK_WPS;
+		goto _exit;
+
+	} else if (rtw_mi_buddy_check_fwstate(adapter, _FW_UNDER_SURVEY)) {
+		RTW_INFO("%s ("ADPT_FMT") : scan abort!! buddy_intf under survey\n", caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_BUDDY_UNDER_SURVEY;
+		goto _exit;
+	}
+#endif /* CONFIG_CONCURRENT_MODE */
+
+	if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE) {
+		RTW_INFO("%s ("ADPT_FMT") : scan abort!! BusyTraffic\n",
+			 caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_BUSY_TRAFFIC;
+		goto _exit;
+	}
+	/*
+	 * Rule for Android.
+	 * If scan interval > BUSY_TRAFFIC_SCAN_DENY_PERIOD,
+	 * it is a periodical background scan.
+	 * Skip background scan when other interface is busy.
+	 */
+	if ((rtw_get_passing_time_ms(pmlmepriv->lastscantime) > BUSY_TRAFFIC_SCAN_DENY_PERIOD)
+	    && rtw_mi_buddy_busy_traffic_check(adapter, _FALSE)) {
+		RTW_INFO("%s ("ADPT_FMT") : scan abort!! others BusyTraffic\n",
+			 caller, ADPT_ARG(adapter));
+		ss_condition = SS_DENY_BUSY_TRAFFIC;
+		goto _exit;
+	}
+
+_exit :
+	return ss_condition;
 }
 
 void rtw_dummy_event_callback(_adapter *adapter , u8 *pbuf)
@@ -1458,12 +1650,11 @@ void rtw_reset_rx_info(_adapter *adapter)
 /*
 *rtw_free_assoc_resources: the caller has to lock pmlmepriv->lock
 */
-void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue)
+void rtw_free_assoc_resources(_adapter *adapter, u8 lock_scanned_queue)
 {
 	_irqL irqL;
 	struct wlan_network *pwlan = NULL;
 	struct	mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct	sta_priv *pstapriv = &adapter->stapriv;
 	struct wlan_network *tgt_network = &pmlmepriv->cur_network;
 
 
@@ -1481,18 +1672,15 @@ void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue)
 		psta = rtw_get_stainfo(&adapter->stapriv, tgt_network->network.MacAddress);
 
 #ifdef CONFIG_TDLS
-		if (ptdlsinfo->link_established == _TRUE) {
+		rtw_free_all_tdls_sta(adapter, _TRUE);
+		rtw_reset_tdls_info(adapter);
+
+		if (ptdlsinfo->link_established == _TRUE)
 			rtw_tdls_cmd(adapter, NULL, TDLS_RS_RCR);
-			rtw_reset_tdls_info(adapter);
-			rtw_free_all_stainfo(adapter);
-			/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
-		} else
 #endif /* CONFIG_TDLS */
-		{
-			/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
-			rtw_free_stainfo(adapter,  psta);
-		}
 
+		/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
+		rtw_free_stainfo(adapter, psta);
 		/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
 
 	}
@@ -1513,26 +1701,27 @@ void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue)
 	if (lock_scanned_queue)
 		_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 
-	pwlan = _rtw_find_same_network(&pmlmepriv->scanned_queue, tgt_network);
-	if ((pwlan)  && (!check_fwstate(pmlmepriv, WIFI_UNDER_WPS))) {
-		pwlan->fixed = _FALSE;
+	if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS) || (pmlmepriv->wpa_phase == _TRUE)){
+		RTW_INFO("Dont free disconnecting network of scanned_queue due to uner %s %s phase\n\n",
+			check_fwstate(pmlmepriv, WIFI_UNDER_WPS) ? "WPS" : "",
+			(pmlmepriv->wpa_phase == _TRUE) ? "WPA" : "");
+	} else {
+		pwlan = _rtw_find_same_network(&pmlmepriv->scanned_queue, tgt_network);
+		if (pwlan) {
+			pwlan->fixed = _FALSE;
 
-		RTW_INFO("free disconnecting network of scanned_queue\n");
-		rtw_free_network_nolock(adapter, pwlan);
+			RTW_INFO("Free disconnecting network of scanned_queue\n");
+			rtw_free_network_nolock(adapter, pwlan);
 #ifdef CONFIG_P2P
-		if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
-			rtw_mi_set_scan_deny(adapter, 2000);
-			/* rtw_clear_scan_deny(adapter);			 */
-		}
+			if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
+				rtw_set_scan_deny(adapter, 2000);
+				/* rtw_clear_scan_deny(adapter); */
+			}
 #endif /* CONFIG_P2P */
-	} else {
-		if (pwlan == NULL)
-			RTW_INFO("free disconnecting network of scanned_queue failed due to pwlan== NULL\n\n");
-		if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
-			RTW_INFO("donot free disconnecting network of scanned_queue when WIFI_UNDER_WPS\n\n");
+		} else
+			RTW_ERR("Free disconnecting network of scanned_queue failed due to pwlan == NULL\n\n");
 	}
 
-
 	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) && (adapter->stapriv.asoc_sta_count == 1))
 	    /*||check_fwstate(pmlmepriv, WIFI_STATION_STATE)*/) {
 		if (pwlan)
@@ -1555,9 +1744,6 @@ void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue)
 void rtw_indicate_connect(_adapter *padapter)
 {
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
-
-
 
 	pmlmepriv->to_join = _FALSE;
 
@@ -1590,18 +1776,21 @@ void rtw_indicate_connect(_adapter *padapter)
 */
 void rtw_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)
 {
-	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX	*cur_network = &(pmlmeinfo->network);
+#ifdef CONFIG_WAPI_SUPPORT
 	struct sta_info *psta;
 	struct sta_priv *pstapriv = &padapter->stapriv;
+#endif
 	u8 *wps_ie = NULL;
 	uint wpsie_len = 0;
 
+	if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
+		pmlmepriv->wpa_phase = _TRUE;
 
-
-	_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS);
+	_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS | WIFI_OP_CH_SWITCHING | WIFI_UNDER_KEY_HANDSHAKE);
 
 	/* force to clear cur_network_scanned's SELECTED REGISTRAR */
 	if (pmlmepriv->cur_network_scanned) {
@@ -1730,7 +1919,6 @@ static u32 _rtw_wait_scan_done(_adapter *adapter, u8 abort, u32 timeout_ms)
 void rtw_scan_wait_completed(_adapter *adapter)
 {
 	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
 	struct ss_res *ss = &pmlmeext->sitesurvey_res;
 
 	_rtw_wait_scan_done(adapter, _FALSE, ss->scan_timeout_ms);
@@ -1755,6 +1943,55 @@ void rtw_scan_abort(_adapter *adapter)
 	rtw_scan_abort_timeout(adapter, 200);
 }
 
+static u32 _rtw_wait_join_done(_adapter *adapter, u8 abort, u32 timeout_ms)
+{
+	systime start;
+	u32 pass_ms;
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+
+	start = rtw_get_current_time();
+
+	pmlmeext->join_abort = abort;
+	if (abort)
+		set_link_timer(pmlmeext, 1);
+
+	while (rtw_get_passing_time_ms(start) <= timeout_ms
+		&& (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)
+			#ifdef CONFIG_IOCTL_CFG80211
+			|| rtw_cfg80211_is_connect_requested(adapter)
+			#endif
+			)
+	) {
+		if (RTW_CANNOT_RUN(adapter))
+			break;
+
+		RTW_INFO(FUNC_ADPT_FMT" linking...\n", FUNC_ADPT_ARG(adapter));
+		rtw_msleep_os(20);
+	}
+
+	if (abort) {
+		if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)
+			#ifdef CONFIG_IOCTL_CFG80211
+			|| rtw_cfg80211_is_connect_requested(adapter)
+			#endif
+		) {
+			if (!RTW_CANNOT_RUN(adapter))
+				RTW_INFO(FUNC_ADPT_FMT" waiting for join_abort time out!\n", FUNC_ADPT_ARG(adapter));
+		}
+	}
+
+	pmlmeext->join_abort = 0;
+	pass_ms = rtw_get_passing_time_ms(start);
+
+	return pass_ms;
+}
+
+u32 rtw_join_abort_timeout(_adapter *adapter, u32 timeout_ms)
+{
+	return _rtw_wait_join_done(adapter, _TRUE, timeout_ms);
+}
+
 static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wlan_network *pnetwork)
 {
 	int i;
@@ -1762,6 +1999,10 @@ static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wl
 	struct recv_reorder_ctrl *preorder_ctrl;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+#ifdef CONFIG_RTS_FULL_BW
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
+#endif/*CONFIG_RTS_FULL_BW*/
 
 	psta = rtw_get_stainfo(pstapriv, pnetwork->network.MacAddress);
 	if (psta == NULL)
@@ -1772,18 +2013,6 @@ static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wl
 
 		psta->cmn.aid  = pnetwork->join_res;
 
-#if 0 /* alloc macid when call rtw_alloc_stainfo(), and release macid when call rtw_free_stainfo() */
-#ifdef CONFIG_CONCURRENT_MODE
-
-		if (PRIMARY_ADAPTER == padapter->adapter_type)
-			psta->cmn.mac_id = 0;
-		else
-			psta->cmn.mac_id = 2;
-#else
-		psta->cmn.mac_id = 0;
-#endif
-#endif /* removed */
-
 		update_sta_info(padapter, psta);
 
 		/* update station supportRate */
@@ -1799,28 +2028,34 @@ static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wl
 
 		/* security related */
 #ifdef CONFIG_RTW_80211R
-		if ((padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) && (psta->ft_pairwise_key_installed == _FALSE)) {
+		if ((padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
+			&& (psta->ft_pairwise_key_installed == _FALSE)) {
 #else
 		if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
 #endif
+			u8 *ie;
+			sint ie_len;
+			u8 mfp_opt = MFP_NO;
+
 			padapter->securitypriv.binstallGrpkey = _FALSE;
 			padapter->securitypriv.busetkipkey = _FALSE;
 			padapter->securitypriv.bgrpkey_handshake = _FALSE;
 
+			ie = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, WLAN_EID_RSN
+				, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
+			if (ie && ie_len > 0
+				&& rtw_parse_wpa2_ie(ie, ie_len + 2, NULL, NULL, NULL, &mfp_opt) == _SUCCESS
+			) {
+				if (padapter->securitypriv.mfp_opt >= MFP_OPTIONAL && mfp_opt >= MFP_OPTIONAL)
+					psta->flags |= WLAN_STA_MFP;
+			}
+
 			psta->ieee8021x_blocked = _TRUE;
 			psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
 
 			_rtw_memset((u8 *)&psta->dot118021x_UncstKey, 0, sizeof(union Keytype));
-
 			_rtw_memset((u8 *)&psta->dot11tkiprxmickey, 0, sizeof(union Keytype));
 			_rtw_memset((u8 *)&psta->dot11tkiptxmickey, 0, sizeof(union Keytype));
-
-			_rtw_memset((u8 *)&psta->dot11txpn, 0, sizeof(union pn48));
-			psta->dot11txpn.val = psta->dot11txpn.val + 1;
-#ifdef CONFIG_IEEE80211W
-			_rtw_memset((u8 *)&psta->dot11wtxpn, 0, sizeof(union pn48));
-#endif /* CONFIG_IEEE80211W */
-			_rtw_memset((u8 *)&psta->dot11rxpn, 0, sizeof(union pn48));
 		}
 
 		/*	Commented by Albert 2012/07/21 */
@@ -1853,7 +2088,9 @@ static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wl
 #ifdef	CONFIG_RTW_80211K
 	_rtw_memcpy(&psta->rm_en_cap, pnetwork->network.PhyInfo.rm_en_cap, 5);
 #endif
-
+#ifdef CONFIG_RTS_FULL_BW
+	rtw_parse_sta_vendor_ie_8812(padapter, psta, BSS_EX_TLV_IES(&cur_network->network), BSS_EX_TLV_IES_LEN(&cur_network->network));
+#endif
 	return psta;
 
 }
@@ -1863,12 +2100,12 @@ static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wl
 static void rtw_joinbss_update_network(_adapter *padapter, struct wlan_network *ptarget_wlan, struct wlan_network  *pnetwork)
 {
 	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
+	sint tmp_fw_state = 0x0;
 
 	RTW_INFO("%s\n", __FUNCTION__);
 
-
-
 	/* why not use ptarget_wlan?? */
 	_rtw_memcpy(&cur_network->network, &pnetwork->network, pnetwork->network.Length);
 	/* some IEs in pnetwork is wrong, so we should use ptarget_wlan IEs */
@@ -1902,13 +2139,15 @@ static void rtw_joinbss_update_network(_adapter *padapter, struct wlan_network *
 
 	switch (pnetwork->network.InfrastructureMode) {
 	case Ndis802_11Infrastructure:
+		/* Check encryption */
+		if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
+			tmp_fw_state = tmp_fw_state | WIFI_UNDER_KEY_HANDSHAKE;
+
+		if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
+			tmp_fw_state = tmp_fw_state | WIFI_UNDER_WPS;
+
+		init_fwstate(pmlmepriv, WIFI_STATION_STATE | tmp_fw_state);
 
-		if (pmlmepriv->fw_state & WIFI_UNDER_WPS)
-			/*pmlmepriv->fw_state = WIFI_STATION_STATE|WIFI_UNDER_WPS;*/
-			init_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_UNDER_WPS);
-		else
-			/*pmlmepriv->fw_state = WIFI_STATION_STATE;*/
-			init_fwstate(pmlmepriv, WIFI_STATION_STATE);
 		break;
 	case Ndis802_11IBSS:
 		/*pmlmepriv->fw_state = WIFI_ADHOC_STATE;*/
@@ -1936,9 +2175,9 @@ static void rtw_joinbss_update_network(_adapter *padapter, struct wlan_network *
  * if join_res > 0, update "cur_network->network" from "pnetwork->network" if (ptarget_wlan !=NULL).
  */
 /* #define REJOIN */
-void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
+void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf, u16 status)
 {
-	_irqL irqL, irqL2;
+	_irqL irqL;
 	static u8 retry = 0;
 	struct sta_info *ptarget_sta = NULL, *pcur_sta = NULL;
 	struct	sta_priv *pstapriv = &adapter->stapriv;
@@ -1978,9 +2217,8 @@ void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
 	the_same_macaddr = _rtw_memcmp(pnetwork->network.MacAddress, cur_network->network.MacAddress, ETH_ALEN);
 
 	pnetwork->network.Length = get_WLAN_BSSID_EX_sz(&pnetwork->network);
-	if (pnetwork->network.Length > sizeof(WLAN_BSSID_EX)) {
-		goto ignore_joinbss_callback;
-	}
+	if (pnetwork->network.Length > sizeof(WLAN_BSSID_EX))
+		goto exit;
 
 	_enter_critical_bh(&pmlmepriv->lock, &irqL);
 
@@ -1995,9 +2233,9 @@ void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
 			/* s1. find ptarget_wlan */
 			if (check_fwstate(pmlmepriv, _FW_LINKED)) {
 				if (the_same_macaddr == _TRUE)
-					ptarget_wlan = rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
+					ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
 				else {
-					pcur_wlan = rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
+					pcur_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
 					if (pcur_wlan)
 						pcur_wlan->fixed = _FALSE;
 
@@ -2008,7 +2246,7 @@ void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
 						/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
 					}
 
-					ptarget_wlan = rtw_find_network(&pmlmepriv->scanned_queue, pnetwork->network.MacAddress);
+					ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, pnetwork->network.MacAddress);
 					if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
 						if (ptarget_wlan)
 							ptarget_wlan->fixed = _TRUE;
@@ -2062,9 +2300,10 @@ void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
 
 	} else if (pnetwork->join_res == -4) {
 		rtw_reset_securitypriv(adapter);
+		pmlmepriv->join_status = status;
 		_set_timer(&pmlmepriv->assoc_timer, 1);
 
-		/* rtw_free_assoc_resources(adapter, 1); */
+		/* rtw_free_assoc_resources(adapter, _TRUE); */
 
 		if ((check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) == _TRUE) {
 			_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
@@ -2087,9 +2326,9 @@ void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
 			rtw_indicate_connect(adapter);
 		} else {
 #endif
-
+			pmlmepriv->join_status = status;
 			_set_timer(&pmlmepriv->assoc_timer, 1);
-			/* rtw_free_assoc_resources(adapter, 1); */
+			/* rtw_free_assoc_resources(adapter, _TRUE); */
 			_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
 
 #ifdef REJOIN
@@ -2100,6 +2339,9 @@ void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)
 
 ignore_joinbss_callback:
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+
+exit:
+	return;
 }
 
 void rtw_joinbss_event_callback(_adapter *adapter, u8 *pbuf)
@@ -2260,34 +2502,39 @@ void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf)
 
 			rtw_sta_media_status_rpt(adapter, psta, 1);
 
+#ifdef CONFIG_MCC_MODE
+			rtw_hal_mcc_update_macid_bitmap(adapter, psta->cmn.mac_id, _TRUE);
+#endif /* CONFIG_MCC_MODE */
+
 #ifndef CONFIG_AUTO_AP_MODE
 			ap_sta_info_defer_update(adapter, psta);
 
-			/* report to upper layer */
-			RTW_INFO("indicate_sta_assoc_event to upper layer - hostapd\n");
-#ifdef CONFIG_IOCTL_CFG80211
-			_enter_critical_bh(&psta->lock, &irqL);
-			if (psta->passoc_req && psta->assoc_req_len > 0) {
-				passoc_req = rtw_zmalloc(psta->assoc_req_len);
-				if (passoc_req) {
-					assoc_req_len = psta->assoc_req_len;
-					_rtw_memcpy(passoc_req, psta->passoc_req, assoc_req_len);
-
-					rtw_mfree(psta->passoc_req , psta->assoc_req_len);
-					psta->passoc_req = NULL;
-					psta->assoc_req_len = 0;
+			if (!MLME_IS_MESH(adapter)) {
+				/* report to upper layer */
+				RTW_INFO("indicate_sta_assoc_event to upper layer - hostapd\n");
+				#ifdef CONFIG_IOCTL_CFG80211
+				_enter_critical_bh(&psta->lock, &irqL);
+				if (psta->passoc_req && psta->assoc_req_len > 0) {
+					passoc_req = rtw_zmalloc(psta->assoc_req_len);
+					if (passoc_req) {
+						assoc_req_len = psta->assoc_req_len;
+						_rtw_memcpy(passoc_req, psta->passoc_req, assoc_req_len);
+
+						rtw_mfree(psta->passoc_req , psta->assoc_req_len);
+						psta->passoc_req = NULL;
+						psta->assoc_req_len = 0;
+					}
 				}
-			}
-			_exit_critical_bh(&psta->lock, &irqL);
-
-			if (passoc_req && assoc_req_len > 0) {
-				rtw_cfg80211_indicate_sta_assoc(adapter, passoc_req, assoc_req_len);
+				_exit_critical_bh(&psta->lock, &irqL);
 
-				rtw_mfree(passoc_req, assoc_req_len);
+				if (passoc_req && assoc_req_len > 0) {
+					rtw_cfg80211_indicate_sta_assoc(adapter, passoc_req, assoc_req_len);
+					rtw_mfree(passoc_req, assoc_req_len);
+				}
+				#else /* !CONFIG_IOCTL_CFG80211	 */
+				rtw_indicate_sta_assoc_event(adapter, psta);
+				#endif /* !CONFIG_IOCTL_CFG80211 */
 			}
-#else /* !CONFIG_IOCTL_CFG80211	 */
-			rtw_indicate_sta_assoc_event(adapter, psta);
-#endif /* !CONFIG_IOCTL_CFG80211 */
 #endif /* !CONFIG_AUTO_AP_MODE */
 
 #ifdef CONFIG_BEAMFORMING
@@ -2323,7 +2570,7 @@ void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf)
 	    (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)) {
 		if (adapter->stapriv.asoc_sta_count == 2) {
 			_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-			ptarget_wlan = rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
+			ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
 			pmlmepriv->cur_network_scanned = ptarget_wlan;
 			if (ptarget_wlan)
 				ptarget_wlan->fixed = _TRUE;
@@ -2344,6 +2591,9 @@ void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf)
 #endif
 
 exit:
+#ifdef CONFIG_RTS_FULL_BW
+	rtw_set_rts_bw(adapter);
+#endif/*CONFIG_RTS_FULL_BW*/
 	return;
 }
 
@@ -2378,7 +2628,46 @@ void rtw_sta_timeout_event_callback(_adapter *adapter, u8 *pbuf)
 #endif /* CONFIG_IEEE80211W */
 
 #ifdef CONFIG_RTW_80211R
-void rtw_update_ft_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
+void rtw_ft_info_init(struct ft_roam_info *pft)
+{
+	_rtw_memset(pft, 0, sizeof(struct ft_roam_info));
+	pft->ft_flags = 0
+		| RTW_FT_EN
+		| RTW_FT_OTD_EN
+#ifdef CONFIG_RTW_BTM_ROAM
+		| RTW_FT_BTM_ROAM
+#endif
+		;
+	pft->ft_updated_bcn = _FALSE;
+}
+
+u8 rtw_ft_chk_roaming_candidate(
+	_adapter *padapter, struct wlan_network *competitor)
+{
+	u8 *pmdie;
+	u32 mdie_len = 0;
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+
+	if (!(pmdie = rtw_get_ie(&competitor->network.IEs[12],
+			_MDIE_, &mdie_len, competitor->network.IELength-12)))
+		return _FALSE;
+
+	if (!_rtw_memcmp(&pft_roam->mdid, (pmdie+2), 2))
+		return _FALSE;
+
+	/*The candidate don't support over-the-DS*/
+	if (rtw_ft_valid_otd_candidate(padapter, pmdie)) {
+		RTW_INFO("FT: ignore the candidate("
+			MAC_FMT ") for over-the-DS\n", 
+			MAC_ARG(competitor->network.MacAddress));
+			rtw_ft_clr_flags(padapter, RTW_FT_PEER_OTD_EN);
+		return _FALSE;	
+	}
+
+	return _TRUE;
+}
+
+void rtw_ft_update_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
 {
 	struct sta_priv		*pstapriv = &padapter->stapriv;
 	struct sta_info		*psta = NULL;
@@ -2395,37 +2684,31 @@ void rtw_update_ft_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
 
 		psta->ieee8021x_blocked = _TRUE;
 		psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
-		psta->dot11txpn.val = psta->dot11txpn.val + 1;
 
 		_rtw_memset((u8 *)&psta->dot118021x_UncstKey, 0, sizeof(union Keytype));
 		_rtw_memset((u8 *)&psta->dot11tkiprxmickey, 0, sizeof(union Keytype));
 		_rtw_memset((u8 *)&psta->dot11tkiptxmickey, 0, sizeof(union Keytype));
-		_rtw_memset((u8 *)&psta->dot11txpn, 0, sizeof(union pn48));
-#ifdef CONFIG_IEEE80211W
-		_rtw_memset((u8 *)&psta->dot11wtxpn, 0, sizeof(union pn48));
-#endif
-		_rtw_memset((u8 *)&psta->dot11rxpn, 0, sizeof(union pn48));
 	}
 
 }
 
 void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf)
 {
-	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
-	struct stassoc_event	*pstassoc = (struct stassoc_event *)pbuf;
-	ft_priv	*pftpriv = &pmlmepriv->ftpriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct stassoc_event *pstassoc = (struct stassoc_event *)pbuf;
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&(pmlmeinfo->network);
 	struct cfg80211_ft_event_params ft_evt_parms;
 	_irqL irqL;
 
 	_rtw_memset(&ft_evt_parms, 0, sizeof(ft_evt_parms));
-	rtw_update_ft_stainfo(padapter, pnetwork);
-	ft_evt_parms.ies_len = pftpriv->ft_event.ies_len;
+	rtw_ft_update_stainfo(padapter, pnetwork);
+	ft_evt_parms.ies_len = pft_roam->ft_event.ies_len;
 	ft_evt_parms.ies =  rtw_zmalloc(ft_evt_parms.ies_len);
 	if (ft_evt_parms.ies)
-		_rtw_memcpy((void *)ft_evt_parms.ies, pftpriv->ft_event.ies, ft_evt_parms.ies_len);
+		_rtw_memcpy((void *)ft_evt_parms.ies, pft_roam->ft_event.ies, ft_evt_parms.ies_len);
 	 else
 		goto err_2;
 
@@ -2435,17 +2718,14 @@ void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf)
 	else
 		goto err_1;
 
-	ft_evt_parms.ric_ies = pftpriv->ft_event.ric_ies;
-	ft_evt_parms.ric_ies_len = pftpriv->ft_event.ric_ies_len;
-
-	_enter_critical_bh(&pmlmepriv->lock, &irqL);
-	rtw_set_ft_status(padapter, RTW_FT_AUTHENTICATED_STA);
-	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+	ft_evt_parms.ric_ies = pft_roam->ft_event.ric_ies;
+	ft_evt_parms.ric_ies_len = pft_roam->ft_event.ric_ies_len;
 
+	rtw_ft_lock_set_status(padapter, RTW_FT_AUTHENTICATED_STA, &irqL);
 	rtw_cfg80211_ft_event(padapter, &ft_evt_parms);
 	RTW_INFO("%s: to "MAC_FMT"\n", __func__, MAC_ARG(ft_evt_parms.target_ap));
 
-	rtw_mfree((u8 *)pftpriv->ft_event.target_ap, ETH_ALEN);
+	rtw_mfree((u8 *)pft_roam->ft_event.target_ap, ETH_ALEN);
 err_1:
 	rtw_mfree((u8 *)ft_evt_parms.ies, ft_evt_parms.ies_len);
 err_2:
@@ -2453,6 +2733,77 @@ err_2:
 }
 #endif
 
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+void rtw_roam_nb_info_init(_adapter *padapter)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	
+	_rtw_memset(&pnb->nb_rpt, 0, sizeof(pnb->nb_rpt));
+	_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
+	_rtw_memset(&pnb->roam_target_addr, 0, ETH_ALEN);
+	pnb->nb_rpt_valid = _FALSE;
+	pnb->nb_rpt_ch_list_num = 0;
+	pnb->preference_en = _FALSE;
+	pnb->nb_rpt_is_same = _TRUE;
+	pnb->last_nb_rpt_entries = 0;
+#ifdef CONFIG_RTW_WNM
+	rtw_init_timer(&pnb->roam_scan_timer, 
+		padapter, rtw_wnm_roam_scan_hdl, 
+		padapter);
+#endif
+}
+
+u8 rtw_roam_nb_scan_list_set(
+	_adapter *padapter, struct sitesurvey_parm *pparm)
+{
+	u8 ret = _FALSE;
+	u32 i;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct roam_nb_info *pnb = &(pmlmepriv->nb_info);
+
+	if (!rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE))
+		return ret;
+
+	if (!pmlmepriv->need_to_roam)
+		return ret;
+
+	if ((!pmlmepriv->nb_info.nb_rpt_valid) || (!pnb->nb_rpt_ch_list_num))
+		return ret;
+
+	if (!pparm)
+		return ret;
+
+	rtw_init_sitesurvey_parm(padapter, pparm);
+	if (rtw_roam_busy_scan(padapter, pnb)) {
+		pparm->ch_num = 1;
+		pparm->ch[pmlmepriv->ch_cnt].hw_value = 
+			pnb->nb_rpt_ch_list[pmlmepriv->ch_cnt].hw_value;
+		pmlmepriv->ch_cnt++;
+		ret = _TRUE;
+		if (pmlmepriv->ch_cnt == pnb->nb_rpt_ch_list_num) {
+			pmlmepriv->nb_info.nb_rpt_valid = _FALSE;
+			pmlmepriv->ch_cnt = 0;
+		}
+		goto set_bssid_list;
+	}
+
+	pparm->ch_num = (pnb->nb_rpt_ch_list_num > RTW_CHANNEL_SCAN_AMOUNT)?
+		(RTW_CHANNEL_SCAN_AMOUNT):(pnb->nb_rpt_ch_list_num);
+	for (i=0; i<pparm->ch_num; i++) {
+		pparm->ch[i].hw_value = pnb->nb_rpt_ch_list[i].hw_value;
+		pparm->ch[i].flags = RTW_IEEE80211_CHAN_PASSIVE_SCAN;
+	}
+
+	pmlmepriv->nb_info.nb_rpt_valid = _FALSE;
+	pmlmepriv->ch_cnt = 0;		
+	ret = _TRUE;
+
+set_bssid_list:
+	rtw_set_802_11_bssid_list_scan(padapter, pparm);
+	return ret;
+}
+#endif
+
 void rtw_sta_mstatus_disc_rpt(_adapter *adapter, u8 mac_id)
 {
 	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
@@ -2508,15 +2859,15 @@ void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 	u8 *pibss = NULL;
 	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);
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
 
 	RTW_INFO("%s(mac_id=%d)=" MAC_FMT "\n", __func__, pstadel->mac_id, MAC_ARG(pstadel->macaddr));
 	rtw_sta_mstatus_disc_rpt(adapter, pstadel->mac_id);
 
+#ifdef CONFIG_MCC_MODE
+	rtw_hal_mcc_update_macid_bitmap(adapter, pstadel->mac_id, _FALSE);
+#endif /* CONFIG_MCC_MODE */
+
 	psta = rtw_get_stainfo(&adapter->stapriv, pstadel->macaddr);
 
 	if (psta == NULL) {
@@ -2527,6 +2878,11 @@ void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 	if (psta)
 		rtw_wfd_st_switch(psta, 0);
 
+	if (MLME_IS_MESH(adapter)) {
+		rtw_free_stainfo(adapter, psta);
+		goto exit;
+	}
+
 	if (MLME_IS_AP(adapter)) {
 #ifdef CONFIG_IOCTL_CFG80211
 #ifdef COMPAT_KERNEL_RELEASE
@@ -2536,7 +2892,9 @@ void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 #endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 37)) || defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER) */
 #endif /* CONFIG_IOCTL_CFG80211 */
 
-		return;
+		rtw_free_stainfo(adapter, psta);
+
+		goto exit;
 	}
 
 	mlmeext_sta_del_event_callback(adapter);
@@ -2550,10 +2908,10 @@ void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 
 #ifdef CONFIG_LAYER2_ROAMING
 #ifdef CONFIG_RTW_80211R
-		if (reason == WLAN_REASON_EXPIRATION_CHK && rtw_chk_roam_flags(adapter, RTW_ROAM_ON_EXPIRED))
-			pmlmepriv->ftpriv.ft_roam_on_expired = _TRUE;
+		if (rtw_ft_roam_expired(adapter, reason))
+			pmlmepriv->ft_roam.ft_roam_on_expired = _TRUE;
 		else
-			pmlmepriv->ftpriv.ft_roam_on_expired = _FALSE;
+			pmlmepriv->ft_roam.ft_roam_on_expired = _FALSE;
 #endif
 		if (adapter->registrypriv.wifi_spec == 1)
 			roam = _FALSE;
@@ -2579,18 +2937,9 @@ void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 
 		rtw_free_uc_swdec_pending_queue(adapter);
 
-		rtw_free_assoc_resources(adapter, 1);
+		rtw_free_assoc_resources(adapter, _TRUE);
 		rtw_free_mlme_priv_ie_data(pmlmepriv);
 
-		_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-		/* remove the network entry in scanned_queue */
-		pwlan = rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);
-		if ((pwlan)  && (!check_fwstate(pmlmepriv, WIFI_UNDER_WPS))) {
-			pwlan->fixed = _FALSE;
-			rtw_free_network_nolock(adapter, pwlan);
-		}
-		_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
-
 		rtw_indicate_disconnect(adapter, *(u16 *)pstadel->rsvd, pstadel->locally_generated);
 #ifdef CONFIG_INTEL_WIDI
 		if (!rtw_to_roam(adapter))
@@ -2611,8 +2960,8 @@ void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 			/* rtw_indicate_disconnect(adapter); */ /* removed@20091105 */
 			_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
 			/* free old ibss network */
-			/* pwlan = rtw_find_network(&pmlmepriv->scanned_queue, pstadel->macaddr); */
-			pwlan = rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);
+			/* pwlan = _rtw_find_network(&pmlmepriv->scanned_queue, pstadel->macaddr); */
+			pwlan = _rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);
 			if (pwlan) {
 				pwlan->fixed = _FALSE;
 				rtw_free_network_nolock(adapter, pwlan);
@@ -2644,8 +2993,11 @@ void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
 	}
 
 	_exit_critical_bh(&pmlmepriv->lock, &irqL2);
-
-
+exit:
+	#ifdef CONFIG_RTS_FULL_BW
+	rtw_set_rts_bw(adapter);
+	#endif/*CONFIG_RTS_FULL_BW*/
+	return;
 }
 
 
@@ -2723,10 +3075,10 @@ void rtw_join_timeout_handler(void *ctx)
 #endif /* CONFIG_INTEL_WIDI */
 				RTW_INFO("%s We've try roaming but fail\n", __FUNCTION__);
 #ifdef CONFIG_RTW_80211R
-				rtw_clr_ft_flags(adapter, RTW_FT_SUPPORTED|RTW_FT_OVER_DS_SUPPORTED);
-				rtw_reset_ft_status(adapter);
+				rtw_ft_clr_flags(adapter, RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN);
+				rtw_ft_reset_status(adapter);
 #endif
-				rtw_indicate_disconnect(adapter, 0, _FALSE);
+				rtw_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
 				break;
 			}
 		}
@@ -2734,16 +3086,18 @@ void rtw_join_timeout_handler(void *ctx)
 	} else
 #endif
 	{
-		rtw_indicate_disconnect(adapter, 0, _FALSE);
+		rtw_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
 		free_scanqueue(pmlmepriv);/* ??? */
 
 #ifdef CONFIG_IOCTL_CFG80211
 		/* indicate disconnect for the case that join_timeout and check_fwstate != FW_LINKED */
-		rtw_cfg80211_indicate_disconnect(adapter, 0, _FALSE);
+		rtw_cfg80211_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
 #endif /* CONFIG_IOCTL_CFG80211 */
 
 	}
 
+	pmlmepriv->join_status = 0; /* reset */
+
 	_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
 
@@ -2785,9 +3139,11 @@ void rtw_scan_timeout_handler(void *ctx)
 
 void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason)
 {
-	struct mlme_priv *mlme = &adapter->mlmepriv;
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+#if defined(CONFIG_RTW_MESH) && defined(CONFIG_DFS_MASTER)
+#if CONFIG_RTW_MESH_OFFCH_CAND 
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+#endif
+#endif
 	u8 u_ch;
 	u32 interval_ms = 0xffffffff; /* 0xffffffff: special value to make min() works well, also means no auto scan */
 
@@ -2795,16 +3151,29 @@ void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason)
 	rtw_mi_get_ch_setting_union(adapter, &u_ch, NULL, NULL);
 
 	if (hal_chk_bw_cap(adapter, BW_CAP_40M)
-	    && is_client_associated_to_ap(adapter) == _TRUE
-	    && u_ch >= 1 && u_ch <= 14
-	    && adapter->registrypriv.wifi_spec
-	    /* TODO: AP Connected is 40MHz capability? */
-	   ) {
+		&& is_client_associated_to_ap(adapter) == _TRUE
+		&& u_ch >= 1 && u_ch <= 14
+		&& adapter->registrypriv.wifi_spec
+		/* TODO: AP Connected is 40MHz capability? */
+	) {
 		interval_ms = rtw_min(interval_ms, 60 * 1000);
 		*reason |= RTW_AUTO_SCAN_REASON_2040_BSS;
 	}
 
-exit:
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_OFFCH_CAND
+	if (adapter->mesh_cfg.peer_sel_policy.offch_find_int_ms
+		&& rtw_mesh_offch_candidate_accepted(adapter)
+		#ifdef CONFIG_DFS_MASTER
+		&& (!rfctl->radar_detect_ch || (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl)))
+		#endif
+	) {
+		interval_ms = rtw_min(interval_ms, adapter->mesh_cfg.peer_sel_policy.offch_find_int_ms);
+		*reason |= RTW_AUTO_SCAN_REASON_MESH_OFFCH_CAND;
+	}
+	#endif
+#endif /* CONFIG_RTW_MESH */
+
 	if (interval_ms == 0xffffffff)
 		interval_ms = 0;
 
@@ -2817,8 +3186,25 @@ void rtw_drv_scan_by_self(_adapter *padapter, u8 reason)
 	struct sitesurvey_parm parm;
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	int i;
+#if 1
+	u8 ssc_chk;
 
+	ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
+	if( ssc_chk == SS_DENY_BUSY_TRAFFIC) {
+		#ifdef CONFIG_LAYER2_ROAMING
+		if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE) && pmlmepriv->need_to_roam == _TRUE)
+			RTW_INFO(FUNC_ADPT_FMT" need to roam, don't care BusyTraffic\n", FUNC_ADPT_ARG(padapter));
+		else
+		#endif
+			RTW_INFO(FUNC_ADPT_FMT" exit BusyTraffic\n", FUNC_ADPT_ARG(padapter));
+			goto exit;
+	}
+	else if (ssc_chk != SS_ALLOW)
+		goto exit;
 
+	if (!rtw_is_adapter_up(padapter))
+		goto exit;
+#else
 	if (rtw_is_scan_deny(padapter))
 		goto exit;
 
@@ -2850,6 +3236,7 @@ void rtw_drv_scan_by_self(_adapter *padapter, u8 reason)
 		RTW_INFO(FUNC_ADPT_FMT", but buddy_intf is under scanning or linking or wps_phase\n", FUNC_ADPT_ARG(padapter));
 		goto exit;
 	}
+#endif
 #endif
 
 	RTW_INFO(FUNC_ADPT_FMT" reason:0x%02x\n", FUNC_ADPT_ARG(padapter), reason);
@@ -2866,6 +3253,12 @@ void rtw_drv_scan_by_self(_adapter *padapter, u8 reason)
 		goto exit;
 	}
 
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+	if ((reason == RTW_AUTO_SCAN_REASON_ROAM) 
+		&& (rtw_roam_nb_scan_list_set(padapter, &parm)))
+		goto exit;
+#endif
+
 	rtw_set_802_11_bssid_list_scan(padapter, NULL);
 exit:
 	return;
@@ -2987,7 +3380,8 @@ static void collect_sta_traffic_statistics(_adapter *adapter)
 {
 	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
 	struct sta_info *sta;
-	u16 curr_tx_mbytes = 0, curr_rx_mbytes = 0;
+	u64 curr_tx_bytes = 0, curr_rx_bytes = 0;
+	u32 curr_tx_mbytes = 0, curr_rx_mbytes = 0;
 	int i;
 
 	for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
@@ -3002,16 +3396,24 @@ static void collect_sta_traffic_statistics(_adapter *adapter)
 			if (sta->sta_stats.last_rx_mc_bytes > sta->sta_stats.rx_mc_bytes)
 				sta->sta_stats.last_rx_mc_bytes = sta->sta_stats.rx_mc_bytes;
 
-			curr_tx_mbytes = ((sta->sta_stats.tx_bytes - sta->sta_stats.last_tx_bytes) >> 20) / 2; /*MBps*/
-			curr_rx_mbytes = ((sta->sta_stats.rx_bytes - sta->sta_stats.last_rx_bytes) >> 20) / 2; /*MBps*/
-			sta->sta_stats.tx_tp_mbytes = curr_tx_mbytes;
-			sta->sta_stats.rx_tp_mbytes = curr_rx_mbytes;
+			curr_tx_bytes = sta->sta_stats.tx_bytes - sta->sta_stats.last_tx_bytes;
+			curr_rx_bytes = sta->sta_stats.rx_bytes - sta->sta_stats.last_rx_bytes;
+			sta->sta_stats.tx_tp_kbits = (curr_tx_bytes * 8 / 2) >> 10;/*Kbps*/
+			sta->sta_stats.rx_tp_kbits = (curr_rx_bytes * 8 / 2) >> 10;/*Kbps*/
+
+			sta->sta_stats.smooth_tx_tp_kbits = (sta->sta_stats.smooth_tx_tp_kbits * 6 / 10) + (sta->sta_stats.tx_tp_kbits * 4 / 10);/*Kbps*/
+			sta->sta_stats.smooth_rx_tp_kbits = (sta->sta_stats.smooth_rx_tp_kbits * 6 / 10) + (sta->sta_stats.rx_tp_kbits * 4 / 10);/*Kbps*/
+
+			curr_tx_mbytes = (curr_tx_bytes / 2) >> 20;/*MBps*/
+			curr_rx_mbytes = (curr_rx_bytes / 2) >> 20;/*MBps*/
 
 			sta->cmn.tx_moving_average_tp =
-				(sta->cmn.tx_moving_average_tp / 10) + (curr_tx_mbytes * 9 / 10);
+				(sta->cmn.tx_moving_average_tp / 10) + (curr_tx_mbytes * 9 / 10); /*MBps*/
 
 			sta->cmn.rx_moving_average_tp =
-				(sta->cmn.rx_moving_average_tp / 10) + (curr_rx_mbytes * 9 /10);
+				(sta->cmn.rx_moving_average_tp / 10) + (curr_rx_mbytes * 9 /10); /*MBps*/
+
+			rtw_collect_bcn_info(sta->padapter);
 
 			if (adapter->bsta_tp_dump)
 				dump_sta_traffic(RTW_DBGDUMP, adapter, sta);
@@ -3062,8 +3464,8 @@ static void collect_traffic_statistics(_adapter *padapter)
 	pdvobjpriv->traffic_stat.last_tx_bytes = pdvobjpriv->traffic_stat.tx_bytes;
 	pdvobjpriv->traffic_stat.last_rx_bytes = pdvobjpriv->traffic_stat.rx_bytes;
 
-	pdvobjpriv->traffic_stat.cur_tx_tp = (u32)(pdvobjpriv->traffic_stat.cur_tx_bytes * 8 / 2 / 1024 / 1024);
-	pdvobjpriv->traffic_stat.cur_rx_tp = (u32)(pdvobjpriv->traffic_stat.cur_rx_bytes * 8 / 2 / 1024 / 1024);
+	pdvobjpriv->traffic_stat.cur_tx_tp = (u32)(pdvobjpriv->traffic_stat.cur_tx_bytes * 8 / 2 / 1024 / 1024);/*Mbps*/
+	pdvobjpriv->traffic_stat.cur_rx_tp = (u32)(pdvobjpriv->traffic_stat.cur_rx_bytes * 8 / 2 / 1024 / 1024);/*Mbps*/
 
 	#ifdef DBG_TRAFFIC_STATISTIC
 	RTW_INFO("\n========================\n");
@@ -3073,9 +3475,16 @@ static void collect_traffic_statistics(_adapter *padapter)
 	RTW_INFO("last_tx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_tx_bytes);
 	RTW_INFO("last_rx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_rx_bytes);
 
-	RTW_INFO("cur_tx_tp:%d\n", pdvobjpriv->traffic_stat.cur_tx_tp);
-	RTW_INFO("cur_rx_tp:%d\n", pdvobjpriv->traffic_stat.cur_rx_tp);
+	RTW_INFO("cur_tx_tp:%d (Mbps)\n", pdvobjpriv->traffic_stat.cur_tx_tp);
+	RTW_INFO("cur_rx_tp:%d (Mbps)\n", pdvobjpriv->traffic_stat.cur_rx_tp);
 	#endif
+
+#ifdef CONFIG_RTW_NAPI
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+	dynamic_napi_th_chk (padapter);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
+#endif
+	
 }
 
 void rtw_dynamic_check_timer_handlder(void *ctx)
@@ -3153,11 +3562,16 @@ static int rtw_check_roaming_candidate(struct mlme_priv *mlme
 {
 	int updated = _FALSE;
 	_adapter *adapter = container_of(mlme, _adapter, mlmepriv);
-#ifdef CONFIG_RTW_80211R
-	ft_priv *pftpriv = &mlme->ftpriv;
-	u32 mdie_len = 0;
-	u8 *ptmp = NULL;
-#endif
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	RT_CHANNEL_INFO *chset = rfctl->channel_set;
+	u8 ch = competitor->network.Configuration.DSConfig;
+
+	if (rtw_chset_search_ch(chset, ch) < 0)
+		goto exit;
+	if (IS_DFS_SLAVE_WITH_RD(rfctl)
+		&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
+		&& rtw_chset_is_ch_non_ocp(chset, ch))
+		goto exit;
 
 #if defined(CONFIG_RTW_REPEATER_SON) &&  (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
 	if (rtw_rson_isupdate_roamcan(mlme, candidate, competitor))
@@ -3177,23 +3591,9 @@ static int rtw_check_roaming_candidate(struct mlme_priv *mlme
 #endif
 
 #ifdef CONFIG_RTW_80211R
-	if (rtw_chk_ft_flags(adapter, RTW_FT_SUPPORTED)) {
-		ptmp = rtw_get_ie(&competitor->network.IEs[12], _MDIE_, &mdie_len, competitor->network.IELength-12);
-		if (ptmp) {
-			if (!_rtw_memcmp(&pftpriv->mdid, ptmp+2, 2))
-				goto exit;
-
-			/*The candidate don't support over-the-DS*/
-			if (rtw_chk_ft_flags(adapter, RTW_FT_STA_OVER_DS_SUPPORTED)) {
-				if ((rtw_chk_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED) && !(*(ptmp+4) & 0x01)) ||
-					(!rtw_chk_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED) && (*(ptmp+4) & 0x01))) {
-					RTW_INFO("FT: ignore the candidate(" MAC_FMT ") for over-the-DS\n", MAC_ARG(competitor->network.MacAddress));
-					rtw_clr_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED);
-					goto exit;
-				}
-			}
-		} else
-			goto exit;
+	if (rtw_ft_chk_flags(adapter, RTW_FT_PEER_EN)) {
+		if (rtw_ft_chk_roaming_candidate(adapter, competitor) == _FALSE)
+		goto exit;
 	}
 #endif
 
@@ -3217,6 +3617,13 @@ static int rtw_check_roaming_candidate(struct mlme_priv *mlme
 	if (rtw_get_passing_time_ms(competitor->last_scanned) >= mlme->roam_scanr_exp_ms)
 		goto exit;
 
+#if defined(CONFIG_RTW_80211R) && defined(CONFIG_RTW_WNM)
+	if (rtw_wnm_btm_diff_bss(adapter) && 
+		rtw_wnm_btm_roam_candidate(adapter, competitor)) {
+		goto update;
+	}	
+#endif
+
 	if (competitor->network.Rssi - mlme->cur_network_scanned->network.Rssi < mlme->roam_rssi_diff_th)
 		goto exit;
 
@@ -3243,8 +3650,6 @@ int rtw_select_roaming_candidate(struct mlme_priv *mlme)
 	_queue	*queue	= &(mlme->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
 	struct	wlan_network	*candidate = NULL;
-	u8		bSupportAntDiv = _FALSE;
-
 
 	if (mlme->cur_network_scanned == NULL) {
 		rtw_warn_on(1);
@@ -3334,8 +3739,15 @@ static int rtw_check_join_candidate(struct mlme_priv *mlme
 {
 	int updated = _FALSE;
 	_adapter *adapter = container_of(mlme, _adapter, mlmepriv);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	RT_CHANNEL_INFO *chset = rfctl->channel_set;
+	u8 ch = competitor->network.Configuration.DSConfig;
 
-	if (rtw_chset_search_ch(adapter_to_chset(adapter), competitor->network.Configuration.DSConfig) < 0)
+	if (rtw_chset_search_ch(chset, ch) < 0)
+		goto exit;
+	if (IS_DFS_SLAVE_WITH_RD(rfctl)
+		&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
+		&& rtw_chset_is_ch_non_ocp(chset, ch))
 		goto exit;
 
 #if defined(CONFIG_RTW_REPEATER_SON) &&  (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
@@ -3425,8 +3837,9 @@ int rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv)
 	_queue	*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
 	struct	wlan_network	*candidate = NULL;
+#ifdef CONFIG_ANTENNA_DIVERSITY
 	u8		bSupportAntDiv = _FALSE;
-
+#endif
 
 	adapter = (_adapter *)pmlmepriv->nic_hdl;
 
@@ -3497,7 +3910,7 @@ candidate_exist:
 		{
 			rtw_disassoc_cmd(adapter, 0, 0);
 			rtw_indicate_disconnect(adapter, 0, _FALSE);
-			rtw_free_assoc_resources(adapter, 0);
+			rtw_free_assoc_resources_cmd(adapter, _TRUE, 0);
 		}
 	}
 
@@ -3572,7 +3985,6 @@ sint rtw_set_key(_adapter *adapter, struct security_priv *psecuritypriv, sint ke
 	struct cmd_obj		*pcmd;
 	struct setkey_parm	*psetkeyparm;
 	struct cmd_priv		*pcmdpriv = &(adapter->cmdpriv);
-	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
 	sint	res = _SUCCESS;
 
 
@@ -3609,12 +4021,10 @@ sint rtw_set_key(_adapter *adapter, struct security_priv *psecuritypriv, sint ke
 	case _TKIP_:
 		keylen = 16;
 		_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
-		psetkeyparm->grpkey = 1;
 		break;
 	case _AES_:
 		keylen = 16;
 		_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
-		psetkeyparm->grpkey = 1;
 		break;
 	default:
 		res = _FAIL;
@@ -3863,108 +4273,90 @@ static int SecIsInPMKIDList(_adapter *Adapter, u8 *bssid)
 
 }
 
-/*
- * 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(_adapter *adapter, int iEntry, u8 *ie, uint ie_len)
+static int rtw_rsn_sync_pmkid(_adapter *adapter, u8 *ie, uint ie_len, int i_ent)
 {
 	struct security_priv *sec = &adapter->securitypriv;
+	struct rsne_info info;
+	u8 gm_cs[4];
+	int i;
 
-	if (ie[13] > 20) {
-		int i;
-		u16 pmkid_cnt = RTW_GET_LE16(ie + 14 + 20);
-		if (pmkid_cnt == 1 && _rtw_memcmp(ie + 14 + 20 + 2, &sec->PMKIDList[iEntry].PMKID, 16)) {
-			RTW_INFO(FUNC_ADPT_FMT" has carried the same PMKID:"KEY_FMT"\n"
-				, FUNC_ADPT_ARG(adapter), KEY_ARG(&sec->PMKIDList[iEntry].PMKID));
-			goto exit;
-		}
-
-		RTW_INFO(FUNC_ADPT_FMT" remove original PMKID, count:%u\n"
-			 , FUNC_ADPT_ARG(adapter), pmkid_cnt);
-
-		for (i = 0; i < pmkid_cnt; i++)
-			RTW_INFO("    "KEY_FMT"\n", KEY_ARG(ie + 14 + 20 + 2 + i * 16));
+	rtw_rsne_info_parse(ie, ie_len, &info);
 
-		ie_len -= 2 + pmkid_cnt * 16;
-		ie[13] = 20;
+	if (info.err) {
+		RTW_WARN(FUNC_ADPT_FMT" rtw_rsne_info_parse error\n"
+			, FUNC_ADPT_ARG(adapter));
+		return 0;
 	}
 
-	if (ie[13] <= 20) {
-		/* The RSN IE didn't include the PMK ID, append the PMK information */
-
-		RTW_INFO(FUNC_ADPT_FMT" append PMKID:"KEY_FMT"\n"
-			, FUNC_ADPT_ARG(adapter), KEY_ARG(&sec->PMKIDList[iEntry].PMKID));
-
-		RTW_PUT_LE16(&ie[ie_len], 1);
-		ie_len += 2;
-
-		_rtw_memcpy(&ie[ie_len], &sec->PMKIDList[iEntry].PMKID, 16);
-		ie_len += 16;
+	if (i_ent < 0 && info.pmkid_cnt == 0)
+		goto exit;
 
-		ie[13] += 18;/* PMKID length = 2+16 */
+	if (i_ent >= 0 && info.pmkid_cnt == 1 && _rtw_memcmp(info.pmkid_list, sec->PMKIDList[i_ent].PMKID, 16)) {
+		RTW_INFO(FUNC_ADPT_FMT" has carried the same PMKID:"KEY_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), KEY_ARG(&sec->PMKIDList[i_ent].PMKID));
+		goto exit;
 	}
 
-exit:
-	return ie_len;
-}
-
-static int rtw_remove_pmkid(_adapter *adapter, u8 *ie, uint ie_len)
-{
-	struct security_priv *sec = &adapter->securitypriv;
-	int i;
-	u16 pmkid_cnt = RTW_GET_LE16(ie + 14 + 20);
-
-	if (ie[13] <= 20)
-		goto exit;
+	/* bakcup group mgmt cs */
+	if (info.gmcs)
+		_rtw_memcpy(gm_cs, info.gmcs, 4);
 
-	RTW_INFO(FUNC_ADPT_FMT" remove original PMKID, count:%u\n"
-		 , FUNC_ADPT_ARG(adapter), pmkid_cnt);
+	if (info.pmkid_cnt) {
+		RTW_INFO(FUNC_ADPT_FMT" remove original PMKID, count:%u\n"
+			 , FUNC_ADPT_ARG(adapter), info.pmkid_cnt);
+		for (i = 0; i < info.pmkid_cnt; i++)
+			RTW_INFO("    "KEY_FMT"\n", KEY_ARG(info.pmkid_list + i * 16));
+	}
 
-	for (i = 0; i < pmkid_cnt; i++)
-		RTW_INFO("    "KEY_FMT"\n", KEY_ARG(ie + 14 + 20 + 2 + i * 16));
+	if (i_ent >= 0) {
+		RTW_INFO(FUNC_ADPT_FMT" append PMKID:"KEY_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), KEY_ARG(sec->PMKIDList[i_ent].PMKID));
 
-	ie_len -= 2 + pmkid_cnt * 16;
-	ie[13] = 20;
+		info.pmkid_cnt = 1; /* update new pmkid_cnt */
+		_rtw_memcpy(info.pmkid_list, sec->PMKIDList[i_ent].PMKID, 16);
+	} else
+		info.pmkid_cnt = 0; /* update new pmkid_cnt */
+
+	RTW_PUT_LE16(info.pmkid_list - 2, info.pmkid_cnt);
+	if (info.gmcs)
+		_rtw_memcpy(info.pmkid_list + 16 * info.pmkid_cnt, gm_cs, 4);
+
+	ie_len = 1 + 1 + 2 + 4
+		+ 2 + 4 * info.pcs_cnt
+		+ 2 + 4 * info.akm_cnt
+		+ 2
+		+ 2 + 16 * info.pmkid_cnt
+		+ (info.gmcs ? 4 : 0)
+		;
+	
+	ie[1] = (u8)(ie_len - 2);
 
 exit:
 	return ie_len;
 }
 
-sint rtw_restruct_sec_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len)
+sint rtw_restruct_sec_ie(_adapter *adapter, u8 *out_ie)
 {
-	u8 authmode = 0x0, securitytype, match;
-	u8 sec_ie[255], uncst_oui[4], bkup_ie[255];
-	u8 wpa_oui[4] = {0x0, 0x50, 0xf2, 0x01};
-	uint	ielength, cnt, remove_cnt;
+	u8 authmode = 0x0;
+	uint	ielength = 0;
 	int iEntry;
 
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct security_priv *psecuritypriv = &adapter->securitypriv;
 	uint	ndisauthmode = psecuritypriv->ndisauthtype;
-	uint ndissecuritytype = psecuritypriv->ndisencryptstatus;
-
 
-
-	/* copy fixed ie only */
-	_rtw_memcpy(out_ie, in_ie, 12);
-	ielength = 12;
 	if ((ndisauthmode == Ndis802_11AuthModeWPA) || (ndisauthmode == Ndis802_11AuthModeWPAPSK))
 		authmode = _WPA_IE_ID_;
 	if ((ndisauthmode == Ndis802_11AuthModeWPA2) || (ndisauthmode == Ndis802_11AuthModeWPA2PSK))
 		authmode = _WPA2_IE_ID_;
 
 	if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
-		_rtw_memcpy(out_ie + ielength, psecuritypriv->wps_ie, psecuritypriv->wps_ie_len);
+		_rtw_memcpy(out_ie, psecuritypriv->wps_ie, psecuritypriv->wps_ie_len);
+		ielength = psecuritypriv->wps_ie_len;
 
-		ielength += psecuritypriv->wps_ie_len;
 	} else if ((authmode == _WPA_IE_ID_) || (authmode == _WPA2_IE_ID_)) {
 		/* copy RSN or SSN		 */
-		_rtw_memcpy(&out_ie[ielength], &psecuritypriv->supplicant_ie[0], psecuritypriv->supplicant_ie[1] + 2);
+		_rtw_memcpy(out_ie, psecuritypriv->supplicant_ie, psecuritypriv->supplicant_ie[1] + 2);
 		/* debug for CONFIG_IEEE80211W
 		{
 			int jj;
@@ -3973,20 +4365,15 @@ sint rtw_restruct_sec_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len)
 				printk(" %02x ", psecuritypriv->supplicant_ie[jj]);
 			printk("\n");
 		}*/
-		ielength += psecuritypriv->supplicant_ie[1] + 2;
+		ielength = psecuritypriv->supplicant_ie[1] + 2;
 		rtw_report_sec_ie(adapter, authmode, psecuritypriv->supplicant_ie);
 	}
 
-	iEntry = SecIsInPMKIDList(adapter, pmlmepriv->assoc_bssid);
-	if (iEntry < 0) {
-		if (authmode == _WPA2_IE_ID_)
-			ielength = rtw_remove_pmkid(adapter, out_ie, ielength);
-	} else {
-		if (authmode == _WPA2_IE_ID_)
-			ielength = rtw_append_pmkid(adapter, iEntry, out_ie, ielength);
+	if (authmode == WLAN_EID_RSN) {
+		iEntry = SecIsInPMKIDList(adapter, pmlmepriv->assoc_bssid);
+		ielength = rtw_rsn_sync_pmkid(adapter, out_ie, ielength, iEntry);
 	}
 
-
 	return ielength;
 }
 
@@ -4187,15 +4574,23 @@ void	rtw_ht_use_default_setting(_adapter *padapter)
 	/* Beamforming setting */
 	CLEAR_FLAGS(phtpriv->beamform_cap);
 #ifdef CONFIG_BEAMFORMING
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&bHwSupportBeamformer);
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&bHwSupportBeamformee);
-	if (TEST_FLAG(pregistrypriv->beamform_cap, BIT4) && bHwSupportBeamformer) {
-		SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
-		RTW_INFO("[HT] HAL Support Beamformer\n");
-	}
-	if (TEST_FLAG(pregistrypriv->beamform_cap, BIT5) && bHwSupportBeamformee) {
-		SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
-		RTW_INFO("[HT] HAL Support Beamformee\n");
+#ifdef RTW_BEAMFORMING_VERSION_2
+	/* only enable beamforming in STA client mode */
+	if (MLME_IS_STA(padapter) && !MLME_IS_GC(padapter)
+				  && !MLME_IS_ADHOC(padapter)
+				  && !MLME_IS_MESH(padapter))
+#endif
+	{
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&bHwSupportBeamformer);
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&bHwSupportBeamformee);
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT4) && bHwSupportBeamformer) {
+			SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
+			RTW_INFO("[HT] HAL Support Beamformer\n");
+		}
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT5) && bHwSupportBeamformee) {
+			SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
+			RTW_INFO("[HT] HAL Support Beamformee\n");
+		}
 	}
 #endif /* CONFIG_BEAMFORMING */
 }
@@ -4213,7 +4608,7 @@ void rtw_build_wmm_ie_ht(_adapter *padapter, u8 *out_ie, uint *pout_len)
 		padapter->mlmepriv.qospriv.qos_option = 1;
 	}
 }
-
+#if defined(CONFIG_80211N_HT)
 /* the fucntion is >= passive_level */
 unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len, u8 channel)
 {
@@ -4223,7 +4618,7 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 	HT_CAP_AMPDU_DENSITY best_ampdu_density;
 	unsigned char *p, *pframe;
 	struct rtw_ieee80211_ht_cap ht_capie;
-	u8	cbw40_enable = 0, rf_type = 0, operation_bw = 0, rf_num = 0, rx_stbc_nss = 0, rx_nss = 0;
+	u8	cbw40_enable = 0, rf_type = 0, rf_num = 0, rx_stbc_nss = 0, rx_nss = 0;
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv		*phtpriv = &pmlmepriv->htpriv;
@@ -4245,36 +4640,7 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 	if (phtpriv->sgi_20m)
 		ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_20;
 
-	/* Get HT BW */
-	if (in_ie == NULL) {
-		/* TDLS: TODO 20/40 issue */
-		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-			operation_bw = padapter->mlmeextpriv.cur_bwmode;
-			if (operation_bw > CHANNEL_WIDTH_40)
-				operation_bw = CHANNEL_WIDTH_40;
-		} else
-			/* TDLS: TODO 40? */
-			operation_bw = CHANNEL_WIDTH_40;
-	} else {
-		p = rtw_get_ie(in_ie, _HT_ADD_INFO_IE_, &ielen, in_len);
-		if (p && (ielen == sizeof(struct ieee80211_ht_addt_info))) {
-			struct HT_info_element *pht_info = (struct HT_info_element *)(p + 2);
-			if (pht_info->infos[0] & BIT(2)) {
-				switch (pht_info->infos[0] & 0x3) {
-				case 1:
-				case 3:
-					operation_bw = CHANNEL_WIDTH_40;
-					break;
-				default:
-					operation_bw = CHANNEL_WIDTH_20;
-					break;
-				}
-			} else
-				operation_bw = CHANNEL_WIDTH_20;
-		}
-	}
-
-	/* to disable 40M Hz support while gd_bw_40MHz_en = 0 */
+	/* check if 40MHz is allowed according to hal cap and registry */
 	if (hal_chk_bw_cap(padapter, BW_CAP_40M)) {
 		if (channel > 14) {
 			if (REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
@@ -4285,10 +4651,61 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 		}
 	}
 
-	if ((cbw40_enable == 1) && (operation_bw == CHANNEL_WIDTH_40)) {
-		ht_capie.cap_info |= IEEE80211_HT_CAP_SUP_WIDTH;
-		if (phtpriv->sgi_40m)
-			ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_40;
+	if (cbw40_enable) {
+		struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+		RT_CHANNEL_INFO *chset = rfctl->channel_set;
+		u8 oper_bw = CHANNEL_WIDTH_20, oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+
+		if (in_ie == NULL) {
+			/* TDLS: TODO 20/40 issue */
+			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+				oper_bw = padapter->mlmeextpriv.cur_bwmode;
+				if (oper_bw > CHANNEL_WIDTH_40)
+					oper_bw = CHANNEL_WIDTH_40;
+			} else
+				/* TDLS: TODO 40? */
+				oper_bw = CHANNEL_WIDTH_40;
+		} else {
+			p = rtw_get_ie(in_ie, WLAN_EID_HT_OPERATION, &ielen, in_len);
+			if (p && ielen == HT_OP_IE_LEN) {
+				if (GET_HT_OP_ELE_STA_CHL_WIDTH(p + 2)) {
+					switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(p + 2)) {
+					case SCA:
+						oper_bw = CHANNEL_WIDTH_40;
+						oper_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+						break;
+					case SCB:
+						oper_bw = CHANNEL_WIDTH_40;
+						oper_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+						break;
+					}
+				}
+			}
+		}
+
+		/* adjust bw to fit in channel plan setting */
+		if (oper_bw == CHANNEL_WIDTH_40
+			&& oper_offset != HAL_PRIME_CHNL_OFFSET_DONT_CARE /* check this because TDLS has no info to set offset */
+			&& (!rtw_chset_is_chbw_valid(chset, channel, oper_bw, oper_offset)
+				|| (IS_DFS_SLAVE_WITH_RD(rfctl)
+					&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
+					&& rtw_chset_is_chbw_non_ocp(chset, channel, oper_bw, oper_offset))
+				)
+		) {
+			oper_bw = CHANNEL_WIDTH_20;
+			oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+			rtw_warn_on(!rtw_chset_is_chbw_valid(chset, channel, oper_bw, oper_offset));
+			if (IS_DFS_SLAVE_WITH_RD(rfctl) && !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl)))
+				rtw_warn_on(rtw_chset_is_chbw_non_ocp(chset, channel, oper_bw, oper_offset));
+		}
+
+		if (oper_bw == CHANNEL_WIDTH_40) {
+			ht_capie.cap_info |= IEEE80211_HT_CAP_SUP_WIDTH;
+			if (phtpriv->sgi_40m)
+				ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_40;
+		}
+
+		cbw40_enable = oper_bw == CHANNEL_WIDTH_40 ? 1 : 0;
 	}
 
 	/* todo: disable SM power save mode */
@@ -4332,7 +4749,7 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 		break;
 	case 2:
 		#ifdef CONFIG_DISABLE_MCS13TO15
-		if (((cbw40_enable == 1) && (operation_bw == CHANNEL_WIDTH_40)) && (pregistrypriv->wifi_spec != 1))
+		if (cbw40_enable && pregistrypriv->wifi_spec != 1)
 			set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_2R_13TO15_OFF);
 		else
 		#endif
@@ -4418,7 +4835,7 @@ unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, ui
 #ifdef CONFIG_80211AC_VHT
 		/* IOT action suggested by Yu Chen 2017/3/3 */
 		if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) &&
-			!GET_VHT_CAPABILITY_ELE_MU_BFER(&pvhtpriv->beamform_cap))
+			!pvhtpriv->ap_is_mu_bfer)
 			rf_num = (rf_num >= 2 ? 2 : rf_num);
 #endif
 		SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(&ht_capie, rf_num);
@@ -4586,6 +5003,7 @@ void rtw_update_ht_cap(_adapter *padapter, u8 *pie, uint ie_len, u8 channel)
 	/*  */
 	pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3;
 }
+#endif
 
 #ifdef CONFIG_TDLS
 void rtw_issue_addbareq_cmd_tdls(_adapter *padapter, struct xmit_frame *pxmitframe)
@@ -4618,6 +5036,7 @@ void rtw_issue_addbareq_cmd_tdls(_adapter *padapter, struct xmit_frame *pxmitfra
 }
 #endif /* CONFIG_TDLS */
 
+#ifdef CONFIG_80211N_HT
 void rtw_issue_addbareq_cmd(_adapter *padapter, struct xmit_frame *pxmitframe)
 {
 	u8 issued;
@@ -4668,7 +5087,7 @@ void rtw_issue_addbareq_cmd(_adapter *padapter, struct xmit_frame *pxmitframe)
 	}
 
 }
-
+#endif /* CONFIG_80211N_HT */
 void rtw_append_exented_cap(_adapter *padapter, u8 *out_ie, uint *pout_len)
 {
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
@@ -4687,6 +5106,9 @@ void rtw_append_exented_cap(_adapter *padapter, u8 *out_ie, uint *pout_len)
 	if (pvhtpriv->vht_option)
 		SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(cap_content, 1);
 #endif /* CONFIG_80211AC_VHT */
+#ifdef CONFIG_RTW_WNM
+	rtw_wnm_set_ext_cap_btm(cap_content, 1);
+#endif
 	/*
 		From 802.11 specification,if a STA does not support any of capabilities defined
 		in the Extended Capabilities element, then the STA is not required to
@@ -4756,8 +5178,8 @@ void _rtw_roaming(_adapter *padapter, struct wlan_network *tgt_network)
 				else {
 					RTW_INFO("%s(%d) -to roaming fail, indicate_disconnect\n", __FUNCTION__, __LINE__);
 #ifdef CONFIG_RTW_80211R
-					rtw_clr_ft_flags(padapter, RTW_FT_SUPPORTED|RTW_FT_OVER_DS_SUPPORTED);
-					rtw_reset_ft_status(padapter);
+					rtw_ft_clr_flags(padapter, RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN);
+					rtw_ft_reset_status(padapter);
 #endif
 					rtw_indicate_disconnect(padapter, 0, _FALSE);
 					break;
@@ -4774,8 +5196,10 @@ bool rtw_adjust_chbw(_adapter *adapter, u8 req_ch, u8 *req_bw, u8 *req_offset)
 	struct registry_priv *regsty = adapter_to_regsty(adapter);
 	u8 allowed_bw;
 
-	if (req_ch <= 14)
+	if (req_ch < 14)
 		allowed_bw = REGSTY_BW_2G(regsty);
+	else if (req_ch == 14)
+		allowed_bw = CHANNEL_WIDTH_20;
 	else
 		allowed_bw = REGSTY_BW_5G(regsty);
 
@@ -4907,3 +5331,17 @@ inline void rtw_wfd_st_switch(struct sta_info *sta, bool on)
 		rtw_st_ctl_unregister(&sta->st_ctl, SESSION_TRACKER_REG_ID_WFD);
 #endif
 }
+
+void dump_arp_pkt(void *sel, u8 *da, u8 *sa, u8 *arp, bool tx)
+{
+	RTW_PRINT_SEL(sel, "%s ARP da="MAC_FMT", sa="MAC_FMT"\n"
+		, tx ? "send" : "recv", MAC_ARG(da), MAC_ARG(sa));
+	RTW_PRINT_SEL(sel, "htype=%u, ptype=0x%04x, hlen=%u, plen=%u, oper=%u\n"
+		, GET_ARP_HTYPE(arp), GET_ARP_PTYPE(arp), GET_ARP_HLEN(arp)
+		, GET_ARP_PLEN(arp), GET_ARP_OPER(arp));
+	RTW_PRINT_SEL(sel, "sha="MAC_FMT", spa="IP_FMT"\n"
+		, MAC_ARG(ARP_SENDER_MAC_ADDR(arp)), IP_ARG(ARP_SENDER_IP_ADDR(arp)));
+	RTW_PRINT_SEL(sel, "tha="MAC_FMT", tpa="IP_FMT"\n"
+		, MAC_ARG(ARP_TARGET_MAC_ADDR(arp)), IP_ARG(ARP_TARGET_IP_ADDR(arp)));
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme_ext.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme_ext.c
index 004b1604df1b..0064367af2a7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme_ext.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mlme_ext.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -85,7 +86,10 @@ struct action_handler OnAction_tbl[] = {
 	{RTW_WLAN_CATEGORY_WNM, "ACTION_WNM", &on_action_wnm},
 #endif
 	{RTW_WLAN_CATEGORY_UNPROTECTED_WNM, "ACTION_UNPROTECTED_WNM", &DoReserved},
-	{RTW_WLAN_CATEGORY_SELF_PROTECTED, "ACTION_SELF_PROTECTED", &DoReserved},
+#ifdef CONFIG_RTW_MESH
+	{RTW_WLAN_CATEGORY_MESH, "ACTION_MESH", &on_action_mesh},
+	{RTW_WLAN_CATEGORY_SELF_PROTECTED, "ACTION_SELF_PROTECTED", &on_action_self_protected},
+#endif
 	{RTW_WLAN_CATEGORY_WMM, "ACTION_WMM", &OnAction_wmm},
 	{RTW_WLAN_CATEGORY_VHT, "ACTION_VHT", &OnAction_vht},
 	{RTW_WLAN_CATEGORY_P2P, "ACTION_P2P", &OnAction_p2p},
@@ -111,306 +115,6 @@ unsigned char RSN_TKIP_CIPHER[4] = {0x00, 0x0f, 0xac, 0x02};
 
 extern unsigned char REALTEK_96B_IE[];
 
-#ifdef LEGACY_CHANNEL_PLAN_REF
-/********************************************************
-ChannelPlan definitions
-*********************************************************/
-static RT_CHANNEL_PLAN legacy_channel_plan[] = {
-	/* 0x00, RTW_CHPLAN_FCC */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 32},
-	/* 0x01, RTW_CHPLAN_IC */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 31},
-	/* 0x02, RTW_CHPLAN_ETSI */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 32},
-	/* 0x03, RTW_CHPLAN_SPAIN */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 0x04, RTW_CHPLAN_FRANCE */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 0x05, RTW_CHPLAN_MKK */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 0x06, RTW_CHPLAN_MKK1 */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 0x07, RTW_CHPLAN_ISRAEL */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64}, 21},
-	/* 0x08, RTW_CHPLAN_TELEC */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 36, 40, 44, 48, 52, 56, 60, 64}, 22},
-	/* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14}, 14},
-	/* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-	/* 0x0B, RTW_CHPLAN_TAIWAN */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 26},
-	/* 0x0C, RTW_CHPLAN_CHINA */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 149, 153, 157, 161, 165}, 18},
-	/* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */	{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165}, 24},
-	/* 0x0E, RTW_CHPLAN_KOREA */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165}, 31},
-	/* 0x0F, RTW_CHPLAN_TURKEY */					{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64}, 19},
-	/* 0x10, RTW_CHPLAN_JAPAN */						{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 32},
-	/* 0x11, RTW_CHPLAN_FCC_NO_DFS */				{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 149, 153, 157, 161, 165}, 20},
-	/* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */				{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48}, 17},
-	/* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165}, 37},
-	/* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */			{{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 56, 60, 64, 149, 153, 157, 161, 165}, 19},
-};
-#endif
-
-static struct ch_list_t RTW_ChannelPlan2G[] = {
-	/* 0, RTW_RD_2G_NULL */		CH_LIST_ENT(0),
-	/* 1, RTW_RD_2G_WORLD */	CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
-	/* 2, RTW_RD_2G_ETSI1 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
-	/* 3, RTW_RD_2G_FCC1 */		CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
-	/* 4, RTW_RD_2G_MKK1 */		CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
-	/* 5, RTW_RD_2G_ETSI2 */		CH_LIST_ENT(4, 10, 11, 12, 13),
-	/* 6, RTW_RD_2G_GLOBAL */	CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
-	/* 7, RTW_RD_2G_MKK2 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
-	/* 8, RTW_RD_2G_FCC2 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
-	/* 9, RTW_RD_2G_IC1 */		CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
-};
-
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-static struct ch_list_t RTW_ChannelPlan5G[] = {
-	/* 0, RTW_RD_5G_NULL */		CH_LIST_ENT(0),
-	/* 1, RTW_RD_5G_ETSI1 */		CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
-	/* 2, RTW_RD_5G_ETSI2 */		CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 3, RTW_RD_5G_ETSI3 */		CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 149, 153, 157, 161, 165),
-	/* 4, RTW_RD_5G_FCC1 */		CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 5, RTW_RD_5G_FCC2 */		CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
-	/* 6, RTW_RD_5G_FCC3 */		CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
-	/* 7, RTW_RD_5G_FCC4 */		CH_LIST_ENT(12, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161),
-	/* 8, RTW_RD_5G_FCC5 */		CH_LIST_ENT(5, 149, 153, 157, 161, 165),
-	/* 9, RTW_RD_5G_FCC6 */		CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
-	/* 10, RTW_RD_5G_FCC7 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 11, RTW_RD_5G_IC1 */		CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 12, RTW_RD_5G_KCC1 */	CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161),
-	/* 13, RTW_RD_5G_MKK1 */	CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
-	/* 14, RTW_RD_5G_MKK2 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
-	/* 15, RTW_RD_5G_MKK3 */	CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
-	/* 16, RTW_RD_5G_NCC1 */	CH_LIST_ENT(16, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 17, RTW_RD_5G_NCC2 */	CH_LIST_ENT(8, 56, 60, 64, 149, 153, 157, 161, 165),
-	/* 18, RTW_RD_5G_NCC3 */	CH_LIST_ENT(5, 149, 153, 157, 161, 165),
-	/* 19, RTW_RD_5G_ETSI4 */	CH_LIST_ENT(4, 36, 40, 44, 48),
-	/* 20, RTW_RD_5G_ETSI5 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 21, RTW_RD_5G_FCC8 */	CH_LIST_ENT(4, 149, 153, 157, 161),
-	/* 22, RTW_RD_5G_ETSI6 */	CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
-	/* 23, RTW_RD_5G_ETSI7 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
-	/* 24, RTW_RD_5G_ETSI8 */	CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
-	/* 25, RTW_RD_5G_ETSI9 */	CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
-	/* 26, RTW_RD_5G_ETSI10 */	CH_LIST_ENT(5, 149, 153, 157, 161, 165),
-	/* 27, RTW_RD_5G_ETSI11 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 28, RTW_RD_5G_NCC4 */	CH_LIST_ENT(17, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 29, RTW_RD_5G_ETSI12 */	CH_LIST_ENT(4, 149, 153, 157, 161),
-	/* 30, RTW_RD_5G_FCC9 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 31, RTW_RD_5G_ETSI13 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
-	/* 32, RTW_RD_5G_FCC10 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161),
-	/* 33, RTW_RD_5G_MKK4 */	CH_LIST_ENT(4, 36, 40, 44, 48),
-	/* 34, RTW_RD_5G_ETSI14 */	CH_LIST_ENT(11, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140),
-	/* 35, RTW_RD_5G_FCC11 */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
-	/* 36, RTW_RD_5G_ETSI15 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 149, 153, 157, 161, 165),
-	/* 37, RTW_RD_5G_MKK5 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 38, RTW_RD_5G_ETSI16 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 39, RTW_RD_5G_ETSI17 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 40, RTW_RD_5G_FCC12*/	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 41, RTW_RD_5G_FCC13 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 42, RTW_RD_5G_FCC14 */	CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 43, RTW_RD_5G_FCC15 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
-	/* 44, RTW_RD_5G_FCC16 */	CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
-	/* 45, RTW_RD_5G_ETSI18 */	CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
-	/* 46, RTW_RD_5G_ETSI19 */	CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 47, RTW_RD_5G_FCC17 */	CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
-	/* 48, RTW_RD_5G_ETSI20 */	CH_LIST_ENT(9, 52, 56, 60, 64, 149, 153, 157, 161, 165),
-	/* 49, RTW_RD_5G_IC2 */		CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 144, 149, 153, 157, 161, 165),
-	/* 50, RTW_RD_5G_ETSI21 */	CH_LIST_ENT(13, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
-	/* 51, RTW_RD_5G_FCC18 */	CH_LIST_ENT(8, 100, 104, 108, 112, 116, 132, 136, 140),
-	/* 52, RTW_RD_5G_WORLD */	CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
-
-	/* === Below are driver defined for legacy channel plan compatible, NO static index assigned ==== */
-	/* RTW_RD_5G_OLD_FCC1 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
-	/* RTW_RD_5G_OLD_NCC1 */	CH_LIST_ENT(15, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
-	/* RTW_RD_5G_OLD_KCC1 */	CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165),
-};
-#endif /* CONFIG_IEEE80211_BAND_5GHZ */
-
-static RT_CHANNEL_PLAN_MAP	RTW_ChannelPlanMap[] = {
-	/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_KCC1,		TXPWR_LMT_FCC),		/* 0x00, RTW_CHPLAN_FCC */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_FCC1,	TXPWR_LMT_FCC),		/* 0x01, RTW_CHPLAN_IC */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x02, RTW_CHPLAN_ETSI */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x03, RTW_CHPLAN_SPAIN */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x04, RTW_CHPLAN_FRANCE */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x05, RTW_CHPLAN_MKK */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x06, RTW_CHPLAN_MKK1 */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI),	/* 0x07, RTW_CHPLAN_ISRAEL */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_FCC6,		TXPWR_LMT_MKK),		/* 0x08, RTW_CHPLAN_TELEC */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_NCC1,	TXPWR_LMT_FCC),		/* 0x0B, RTW_CHPLAN_TAIWAN */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI),	/* 0x0C, RTW_CHPLAN_CHINA */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC3,		TXPWR_LMT_WW),		/* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */ /* ETSI:Singapore, India. FCC:Mexico => WW */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_OLD_KCC1,	TXPWR_LMT_ETSI),	/* 0x0E, RTW_CHPLAN_KOREA */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC6,		TXPWR_LMT_ETSI),	/* 0x0F, RTW_CHPLAN_TURKEY */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI1,	TXPWR_LMT_MKK),		/* 0x10, RTW_CHPLAN_JAPAN */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x11, RTW_CHPLAN_FCC_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_FCC7,		TXPWR_LMT_MKK),		/* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC1,		TXPWR_LMT_WW),		/* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC2,		TXPWR_LMT_FCC),		/* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC7,		TXPWR_LMT_ETSI),	/* 0x15, RTW_CHPLAN_ETSI_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NCC1,		TXPWR_LMT_ETSI),	/* 0x16, RTW_CHPLAN_KOREA_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_FCC7,		TXPWR_LMT_MKK),		/* 0x17, RTW_CHPLAN_JAPAN_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_FCC5,		TXPWR_LMT_ETSI),	/* 0x18, RTW_CHPLAN_PAKISTAN_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x19, RTW_CHPLAN_TAIWAN2_NO_DFS */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1A, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1B, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1C, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1D, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x1E, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_FCC1,		TXPWR_LMT_WW),		/* 0x1F, RTW_CHPLAN_WORLD_WIDE_ONLY_5G */
-
-	/* ===== 0x20 ~ 0x7F, new channel plan ===== */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x20, RTW_CHPLAN_WORLD_NULL */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x21, RTW_CHPLAN_ETSI1_NULL */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NULL,		TXPWR_LMT_FCC),		/* 0x22, RTW_CHPLAN_FCC1_NULL */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_NULL,		TXPWR_LMT_MKK),		/* 0x23, RTW_CHPLAN_MKK1_NULL */
-	CHPLAN_ENT(RTW_RD_2G_ETSI2,		RTW_RD_5G_NULL,		TXPWR_LMT_ETSI),	/* 0x24, RTW_CHPLAN_ETSI2_NULL */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC),		/* 0x25, RTW_CHPLAN_FCC1_FCC1 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI1,	TXPWR_LMT_ETSI),	/* 0x26, RTW_CHPLAN_WORLD_ETSI1 */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK1,		TXPWR_LMT_MKK),		/* 0x27, RTW_CHPLAN_MKK1_MKK1 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_KCC1,		TXPWR_LMT_KCC),		/* 0x28, RTW_CHPLAN_WORLD_KCC1 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x29, RTW_CHPLAN_WORLD_FCC2 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_NULL,		TXPWR_LMT_FCC),		/* 0x2A, RTW_CHPLAN_FCC2_NULL */
-	CHPLAN_ENT(RTW_RD_2G_IC1,		RTW_RD_5G_IC2,		TXPWR_LMT_IC),		/* 0x2B, RTW_CHPLAN_IC1_IC2 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x2C, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x2D, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x2E, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x2F, */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC3,		TXPWR_LMT_FCC),		/* 0x30, RTW_CHPLAN_WORLD_FCC3 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC4,		TXPWR_LMT_FCC),		/* 0x31, RTW_CHPLAN_WORLD_FCC4 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x32, RTW_CHPLAN_WORLD_FCC5 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC6,		TXPWR_LMT_FCC),		/* 0x33, RTW_CHPLAN_WORLD_FCC6 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x34, RTW_CHPLAN_FCC1_FCC7 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI2,	TXPWR_LMT_ETSI),	/* 0x35, RTW_CHPLAN_WORLD_ETSI2 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI3,	TXPWR_LMT_ETSI),	/* 0x36, RTW_CHPLAN_WORLD_ETSI3 */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK2,		TXPWR_LMT_MKK),		/* 0x37, RTW_CHPLAN_MKK1_MKK2 */
-	CHPLAN_ENT(RTW_RD_2G_MKK1,		RTW_RD_5G_MKK3,		TXPWR_LMT_MKK),		/* 0x38, RTW_CHPLAN_MKK1_MKK3 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC1,		TXPWR_LMT_FCC),		/* 0x39, RTW_CHPLAN_FCC1_NCC1 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3A, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3B, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3C, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3D, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3E, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x3F, */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC2,		TXPWR_LMT_FCC),		/* 0x40, RTW_CHPLAN_FCC1_NCC2 */
-	CHPLAN_ENT(RTW_RD_2G_GLOBAL,	RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x41, RTW_CHPLAN_GLOBAL_NULL */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI4,	TXPWR_LMT_ETSI),	/* 0x42, RTW_CHPLAN_ETSI1_ETSI4 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC2,		TXPWR_LMT_FCC),		/* 0x43, RTW_CHPLAN_FCC1_FCC2 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC3,		TXPWR_LMT_FCC),		/* 0x44, RTW_CHPLAN_FCC1_NCC3 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI5,	TXPWR_LMT_ETSI),	/* 0x45, RTW_CHPLAN_WORLD_ETSI5 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC8,		TXPWR_LMT_FCC),		/* 0x46, RTW_CHPLAN_FCC1_FCC8 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI6,	TXPWR_LMT_ETSI),	/* 0x47, RTW_CHPLAN_WORLD_ETSI6 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI7,	TXPWR_LMT_ETSI),	/* 0x48, RTW_CHPLAN_WORLD_ETSI7 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI8,	TXPWR_LMT_ETSI),	/* 0x49, RTW_CHPLAN_WORLD_ETSI8 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4A, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4B, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4C, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4D, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4E, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x4F, */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI9,	TXPWR_LMT_ETSI),	/* 0x50, RTW_CHPLAN_WORLD_ETSI9 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI10,	TXPWR_LMT_ETSI),	/* 0x51, RTW_CHPLAN_WORLD_ETSI10 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI11,	TXPWR_LMT_ETSI),	/* 0x52, RTW_CHPLAN_WORLD_ETSI11 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_NCC4,		TXPWR_LMT_FCC),		/* 0x53, RTW_CHPLAN_FCC1_NCC4 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI12,	TXPWR_LMT_ETSI),	/* 0x54, RTW_CHPLAN_WORLD_ETSI12 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC9,		TXPWR_LMT_FCC),		/* 0x55, RTW_CHPLAN_FCC1_FCC9 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI13,	TXPWR_LMT_ETSI),	/* 0x56, RTW_CHPLAN_WORLD_ETSI13 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC10,	TXPWR_LMT_FCC),		/* 0x57, RTW_CHPLAN_FCC1_FCC10 */
-	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK4,		TXPWR_LMT_MKK),		/* 0x58, RTW_CHPLAN_MKK2_MKK4 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI14,	TXPWR_LMT_ETSI),	/* 0x59, RTW_CHPLAN_WORLD_ETSI14 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5A, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5B, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5C, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5D, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5E, */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_NULL,		TXPWR_LMT_WW),		/* 0x5F, */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC5,		TXPWR_LMT_FCC),		/* 0x60, RTW_CHPLAN_FCC1_FCC5 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x61, RTW_CHPLAN_FCC2_FCC7 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC),		/* 0x62, RTW_CHPLAN_FCC2_FCC1 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI15,	TXPWR_LMT_ETSI),	/* 0x63, RTW_CHPLAN_WORLD_ETSI15 */
-	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK5,		TXPWR_LMT_MKK),		/* 0x64, RTW_CHPLAN_MKK2_MKK5 */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI16,	TXPWR_LMT_ETSI),	/* 0x65, RTW_CHPLAN_ETSI1_ETSI16 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC14,	TXPWR_LMT_FCC),		/* 0x66, RTW_CHPLAN_FCC1_FCC14 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x67, RTW_CHPLAN_FCC1_FCC12 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC14,	TXPWR_LMT_FCC),		/* 0x68, RTW_CHPLAN_FCC2_FCC14 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x69, RTW_CHPLAN_FCC2_FCC12 */
-	CHPLAN_ENT(RTW_RD_2G_ETSI1,		RTW_RD_5G_ETSI17,	TXPWR_LMT_ETSI),	/* 0x6A, RTW_CHPLAN_ETSI1_ETSI17 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC16,	TXPWR_LMT_FCC),		/* 0x6B, RTW_CHPLAN_WORLD_FCC16 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC13,	TXPWR_LMT_FCC),		/* 0x6C, RTW_CHPLAN_WORLD_FCC13 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC15,	TXPWR_LMT_FCC),		/* 0x6D, RTW_CHPLAN_FCC2_FCC15 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC12,	TXPWR_LMT_FCC),		/* 0x6E, RTW_CHPLAN_WORLD_FCC12 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI8,	TXPWR_LMT_ETSI),	/* 0x6F, RTW_CHPLAN_NULL_ETSI8 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI18,	TXPWR_LMT_ETSI),	/* 0x70, RTW_CHPLAN_NULL_ETSI18 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI17,	TXPWR_LMT_ETSI),	/* 0x71, RTW_CHPLAN_NULL_ETSI17 */
-	CHPLAN_ENT(RTW_RD_2G_NULL,		RTW_RD_5G_ETSI19,	TXPWR_LMT_ETSI),	/* 0x72, RTW_CHPLAN_NULL_ETSI19 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC7,		TXPWR_LMT_FCC),		/* 0x73, RTW_CHPLAN_WORLD_FCC7 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC17,	TXPWR_LMT_FCC),		/* 0x74, RTW_CHPLAN_FCC2_FCC17 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI20,	TXPWR_LMT_ETSI),	/* 0x75, RTW_CHPLAN_WORLD_ETSI20 */
-	CHPLAN_ENT(RTW_RD_2G_FCC2,		RTW_RD_5G_FCC11,	TXPWR_LMT_FCC),		/* 0x76, RTW_CHPLAN_FCC2_FCC11 */
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_ETSI21,	TXPWR_LMT_ETSI),	/* 0x77, RTW_CHPLAN_WORLD_ETSI21 */
-	CHPLAN_ENT(RTW_RD_2G_FCC1,		RTW_RD_5G_FCC18,	TXPWR_LMT_FCC),		/* 0x78, RTW_CHPLAN_FCC1_FCC18 */
-	CHPLAN_ENT(RTW_RD_2G_MKK2,		RTW_RD_5G_MKK1,		TXPWR_LMT_MKK),		/* 0x79, RTW_CHPLAN_MKK2_MKK1 */
-};
-
-static RT_CHANNEL_PLAN_MAP RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE =
-	CHPLAN_ENT(RTW_RD_2G_WORLD,		RTW_RD_5G_FCC1,		TXPWR_LMT_FCC);		/* 0x7F, Realtek Define */
-
-bool rtw_chplan_is_empty(u8 id)
-{
-	RT_CHANNEL_PLAN_MAP *chplan_map;
-
-	if (id == RTW_CHPLAN_REALTEK_DEFINE)
-		chplan_map = &RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE;
-	else
-		chplan_map = &RTW_ChannelPlanMap[id];
-
-	if (chplan_map->Index2G == RTW_RD_2G_NULL
-		#ifdef CONFIG_IEEE80211_BAND_5GHZ
-		&& chplan_map->Index5G == RTW_RD_5G_NULL
-		#endif
-	)
-		return _TRUE;
-
-	return _FALSE;
-}
-
-bool rtw_regsty_is_excl_chs(struct registry_priv *regsty, u8 ch)
-{
-	int i;
-
-	for (i = 0; i < MAX_CHANNEL_NUM; i++) {
-		if (regsty->excl_chs[i] == 0)
-			break;
-		if (regsty->excl_chs[i] == ch)
-			return _TRUE;
-	}
-	return _FALSE;
-}
-
-inline u8 rtw_rd_5g_band1_passive(u8 rtw_rd_5g)
-{
-	u8 passive = 0;
-
-	switch (rtw_rd_5g) {
-	case RTW_RD_5G_FCC13:
-	case RTW_RD_5G_FCC16:
-	case RTW_RD_5G_ETSI18:
-	case RTW_RD_5G_ETSI19:
-	case RTW_RD_5G_WORLD:
-		passive = 1;
-	};
-
-	return passive;
-}
-
-inline u8 rtw_rd_5g_band4_passive(u8 rtw_rd_5g)
-{
-	u8 passive = 0;
-
-	switch (rtw_rd_5g) {
-	case RTW_RD_5G_MKK5:
-	case RTW_RD_5G_ETSI16:
-	case RTW_RD_5G_ETSI18:
-	case RTW_RD_5G_ETSI19:
-	case RTW_RD_5G_WORLD:
-		passive = 1;
-	};
-
-	return passive;
-}
-
 static void init_channel_list(_adapter *padapter, RT_CHANNEL_INFO *channel_set
 	, struct p2p_channels *channel_list)
 {
@@ -445,14 +149,14 @@ static void init_channel_list(_adapter *padapter, RT_CHANNEL_INFO *channel_set
 		for (ch = o->min_chan; ch <= o->max_chan; ch += o->inc) {
 			if (rtw_chset_search_ch(channel_set, ch) == -1)
 				continue;
-
+#if defined(CONFIG_80211N_HT) || defined(CONFIG_80211AC_VHT)
 			if ((padapter->registrypriv.ht_enable == 0) && (o->inc == 8))
 				continue;
 
 			if ((REGSTY_IS_BW_5G_SUPPORT(regsty, CHANNEL_WIDTH_40)) &&
 			    ((o->bw == BW40MINUS) || (o->bw == BW40PLUS)))
 				continue;
-
+#endif
 			if (reg == NULL) {
 				reg = &channel_list->reg_class[cla];
 				cla++;
@@ -467,132 +171,10 @@ static void init_channel_list(_adapter *padapter, RT_CHANNEL_INFO *channel_set
 
 }
 
-static u8 init_channel_set(_adapter *padapter, u8 ChannelPlan, RT_CHANNEL_INFO *channel_set)
-{
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	struct registry_priv *regsty = adapter_to_regsty(padapter);
-	u8	index, chanset_size = 0;
-	u8	b5GBand = _FALSE, b2_4GBand = _FALSE;
-	u8	Index2G = 0, Index5G = 0;
-	int i;
-
-	if (!rtw_is_channel_plan_valid(ChannelPlan)) {
-		RTW_ERR("ChannelPlan ID 0x%02X error !!!!!\n", ChannelPlan);
-		return chanset_size;
-	}
-
-	_rtw_memset(channel_set, 0, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
-
-	if (IsSupported24G(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_2G))
-		b2_4GBand = _TRUE;
-
-	if (is_supported_5g(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_5G))
-		b5GBand = _TRUE;
-
-	if (b2_4GBand == _FALSE && b5GBand == _FALSE) {
-		RTW_WARN("HW band_cap has no intersection with SW wireless_mode setting\n");
-		return chanset_size;
-	}
-
-	if (b2_4GBand) {
-		if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
-			Index2G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index2G;
-		else
-			Index2G = RTW_ChannelPlanMap[ChannelPlan].Index2G;
-
-		for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan2G[Index2G]); index++) {
-			if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan2G[Index2G], index)) == _TRUE)
-				continue;
-
-			if (chanset_size >= MAX_CHANNEL_NUM) {
-				RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
-				break;
-			}
-
-			channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan2G[Index2G], index);
-
-			if (ChannelPlan == RTW_CHPLAN_GLOBAL_DOAMIN
-				|| Index2G == RTW_RD_2G_GLOBAL
-			) {
-				/* Channel 1~11 is active, and 12~14 is passive */
-				if (channel_set[chanset_size].ChannelNum >= 1 && channel_set[chanset_size].ChannelNum <= 11)
-					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-				else if ((channel_set[chanset_size].ChannelNum  >= 12 && channel_set[chanset_size].ChannelNum  <= 14))
-					channel_set[chanset_size].ScanType  = SCAN_PASSIVE;
-			} else if (ChannelPlan == RTW_CHPLAN_WORLD_WIDE_13
-				|| ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G
-				|| Index2G == RTW_RD_2G_WORLD
-			) {
-				/* channel 12~13, passive scan */
-				if (channel_set[chanset_size].ChannelNum <= 11)
-					channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-				else
-					channel_set[chanset_size].ScanType = SCAN_PASSIVE;
-			} else
-				channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-
-			chanset_size++;
-		}
-	}
-
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-	if (b5GBand) {
-		if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
-			Index5G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index5G;
-		else
-			Index5G = RTW_ChannelPlanMap[ChannelPlan].Index5G;
-
-		for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan5G[Index5G]); index++) {
-			if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan5G[Index5G], index)) == _TRUE)
-				continue;
-			#ifndef CONFIG_DFS
-			if (rtw_is_dfs_ch(CH_LIST_CH(RTW_ChannelPlan5G[Index5G], index)))
-				continue;
-			#endif
-
-			if (chanset_size >= MAX_CHANNEL_NUM) {
-				RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
-				break;
-			}
-
-			channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan5G[Index5G], index);
-
-			if ((ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G) /* all channels passive */
-				|| (rtw_is_5g_band1(channel_set[chanset_size].ChannelNum)
-					&& rtw_rd_5g_band1_passive(Index5G)) /* band1 passive */
-				|| (rtw_is_5g_band4(channel_set[chanset_size].ChannelNum)
-					&& rtw_rd_5g_band4_passive(Index5G)) /* band4 passive */
-				|| (rtw_is_dfs_ch(channel_set[chanset_size].ChannelNum)) /* DFS channel(band2, 3) passive */
-			)
-				channel_set[chanset_size].ScanType = SCAN_PASSIVE;
-			else
-				channel_set[chanset_size].ScanType = SCAN_ACTIVE;
-
-			chanset_size++;
-		}
-	}
-
-	#ifdef CONFIG_DFS_MASTER
-	for (i = 0; i < chanset_size; i++)
-		channel_set[i].non_ocp_end_time = rtw_get_current_time();
-	#endif
-#endif /* CONFIG_IEEE80211_BAND_5GHZ */
-
-	if (chanset_size)
-		RTW_INFO(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, ch num:%d\n"
-			, FUNC_ADPT_ARG(padapter), ChannelPlan, chanset_size);
-	else
-		RTW_WARN(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, final chset has no channel\n"
-			, FUNC_ADPT_ARG(padapter), ChannelPlan);
-
-	return chanset_size;
-}
-
 #ifdef CONFIG_TXPWR_LIMIT
 void rtw_txpwr_init_regd(struct rf_ctl_t *rfctl)
 {
 	u8 regd;
-	u8 regd_name;
 	struct regd_exc_ent *exc;
 	struct txpwr_lmt_ent *ent;
 	_irqL irqL;
@@ -635,11 +217,7 @@ void rtw_txpwr_init_regd(struct rf_ctl_t *rfctl)
 	}
 
 	/* follow default channel plan mapping */
-	if (rfctl->ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
-		regd = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.regd;
-	else
-		regd = RTW_ChannelPlanMap[rfctl->ChannelPlan].regd;
-
+	regd = rtw_chplan_get_default_regd(rfctl->ChannelPlan);
 	if (regd == TXPWR_LMT_NONE)
 		rfctl->regd_name = regd_str(TXPWR_LMT_NONE);
 	else if (regd == TXPWR_LMT_WW)
@@ -660,15 +238,17 @@ void rtw_txpwr_init_regd(struct rf_ctl_t *rfctl)
 
 	switch (regd) {
 	/*
-	* To support older chips without IC and KCC regd:
-	* IC not found, use FCC instead
-	* KCC not found, use ETSI instead
+	* To support older chips without new predefined regd:
+	* - use FCC if IC or CHILE not found
+	* - use ETSI if KCC or ACMA not found
 	*/
 	case TXPWR_LMT_IC:
 	case TXPWR_LMT_KCC:
-		if (regd == TXPWR_LMT_IC)
+	case TXPWR_LMT_ACMA:
+	case TXPWR_LMT_CHILE:
+		if (regd == TXPWR_LMT_IC || regd == TXPWR_LMT_CHILE)
 			regd = TXPWR_LMT_FCC;
-		else if (regd == TXPWR_LMT_KCC)
+		else if (regd == TXPWR_LMT_KCC || regd == TXPWR_LMT_ACMA)
 			regd = TXPWR_LMT_ETSI;
 		ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_str(regd));
 		if (ent)
@@ -697,16 +277,22 @@ void rtw_rfctl_init(_adapter *adapter)
 	rfctl->max_chan_nums = init_channel_set(adapter, rfctl->ChannelPlan, rfctl->channel_set);
 	init_channel_list(adapter, rfctl->channel_set, &rfctl->channel_list);
 
+	_rtw_mutex_init(&rfctl->offch_mutex);
+
 #ifdef CONFIG_TXPWR_LIMIT
 	_rtw_mutex_init(&rfctl->txpwr_lmt_mutex);
 	_rtw_init_listhead(&rfctl->reg_exc_list);
 	_rtw_init_listhead(&rfctl->txpwr_lmt_list);
 #endif
 
+	rfctl->ch_sel_same_band_prefer = 1;
+
 #ifdef CONFIG_DFS_MASTER
 	rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
-
-	/* TODO: dfs_master_timer */
+	rtw_init_timer(&(rfctl->radar_detect_timer), adapter, rtw_dfs_rd_timer_hdl, rfctl);
+#endif
+#ifdef CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
+	rfctl->dfs_slave_with_rd = 1;
 #endif
 }
 
@@ -714,26 +300,23 @@ void rtw_rfctl_deinit(_adapter *adapter)
 {
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 
+	_rtw_mutex_free(&rfctl->offch_mutex);
+
 #ifdef CONFIG_TXPWR_LIMIT
 	rtw_regd_exc_list_free(rfctl);
 	rtw_txpwr_lmt_list_free(rfctl);
 	_rtw_mutex_free(&rfctl->txpwr_lmt_mutex);
 #endif
-
-#ifdef CONFIG_DFS_MASTER
-	/* TODO: dfs_master_timer */
-#endif
 }
 
 #ifdef CONFIG_DFS_MASTER
 /*
-* called in rtw_dfs_master_enable()
+* called in rtw_dfs_rd_enable()
 * assume the request channel coverage is DFS range
 * base on the current status and the request channel coverage to check if need to reset complete CAC time
 */
-bool rtw_is_cac_reset_needed(_adapter *adapter, u8 ch, u8 bw, u8 offset)
+bool rtw_is_cac_reset_needed(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset)
 {
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	bool needed = _FALSE;
 	u32 cur_hi, cur_lo, hi, lo;
 
@@ -830,7 +413,7 @@ bool rtw_rfctl_is_tx_blocked_by_ch_waiting(struct rf_ctl_t *rfctl)
 	return rtw_rfctl_overlap_radar_detect_ch(rfctl) && IS_CH_WAITING(rfctl);
 }
 
-bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
+bool rtw_chset_is_chbw_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
 {
 	bool ret = _FALSE;
 	u32 hi = 0, lo = 0;
@@ -860,6 +443,11 @@ exit:
 	return ret;
 }
 
+bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch)
+{
+	return rtw_chset_is_chbw_non_ocp(ch_set, ch, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE);
+}
+
 u32 rtw_chset_get_ch_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
 {
 	int ms = 0;
@@ -939,20 +527,19 @@ inline void rtw_chset_update_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u
 	_rtw_chset_update_non_ocp(ch_set, ch, bw, offset, ms);
 }
 
-u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms)
+u32 rtw_get_ch_waiting_ms(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms)
 {
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
 	u32 non_ocp_ms;
 	u32 cac_ms;
 	u8 in_rd_range = 0; /* if in current radar detection range*/
 
-	if (rtw_chset_is_ch_non_ocp(rfctl->channel_set, ch, bw, offset))
+	if (rtw_chset_is_chbw_non_ocp(rfctl->channel_set, ch, bw, offset))
 		non_ocp_ms = rtw_chset_get_ch_non_ocp_ms(rfctl->channel_set, ch, bw, offset);
 	else
 		non_ocp_ms = 0;
 
-	if (rfctl->dfs_master_enabled) {
+	if (rfctl->radar_detect_enabled) {
 		u32 cur_hi, cur_lo, hi, lo;
 
 		if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE) {
@@ -976,7 +563,7 @@ u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non
 			cac_ms = rtw_systime_to_ms(rfctl->cac_end_time - rtw_get_current_time());
 		else
 			cac_ms = 0;
-	} else if (rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(adapter)))
+	} else if (rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(dvobj)))
 		cac_ms = CAC_TIME_CE_MS;
 	else
 		cac_ms = CAC_TIME_MS;
@@ -989,13 +576,12 @@ u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non
 	return non_ocp_ms + cac_ms;
 }
 
-void rtw_reset_cac(_adapter *adapter, u8 ch, u8 bw, u8 offset)
+void rtw_reset_cac(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset)
 {
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	u32 non_ocp_ms;
 	u32 cac_ms;
 
-	rtw_get_ch_waiting_ms(adapter
+	rtw_get_ch_waiting_ms(rfctl
 		, ch
 		, bw
 		, offset
@@ -1014,17 +600,48 @@ void rtw_reset_cac(_adapter *adapter, u8 ch, u8 bw, u8 offset)
 	if (rfctl->cac_end_time == RTW_CAC_STOPPED)
 		rfctl->cac_end_time++;
 }
+
+u32 rtw_force_stop_cac(struct rf_ctl_t *rfctl, u32 timeout_ms)
+{
+	struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
+	systime start;
+	u32 pass_ms;
+
+	start = rtw_get_current_time();
+
+	rfctl->cac_force_stop = 1;
+
+	while (rtw_get_passing_time_ms(start) <= timeout_ms
+		&& IS_UNDER_CAC(rfctl)
+	) {
+		if (dev_is_surprise_removed(dvobj) || dev_is_drv_stopped(dvobj))
+			break;
+		rtw_msleep_os(20);
+	}
+
+	if (IS_UNDER_CAC(rfctl)) {
+		if (!dev_is_surprise_removed(dvobj) && !dev_is_drv_stopped(dvobj))
+			RTW_INFO("%s waiting for cac stop timeout!\n", __func__);
+	}
+
+	rfctl->cac_force_stop = 0;
+
+	pass_ms = rtw_get_passing_time_ms(start);
+
+	return pass_ms;
+}
 #endif /* CONFIG_DFS_MASTER */
 
 /* choose channel with shortest waiting (non ocp + cac) time */
-bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset, u8 d_flags)
+bool rtw_choose_shortest_waiting_ch(struct rf_ctl_t *rfctl, u8 sel_ch, u8 max_bw
+	, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset
+	, u8 d_flags, u8 cur_ch, u8 same_band_prefer, u8 mesh_only)
 {
 #ifndef DBG_CHOOSE_SHORTEST_WAITING_CH
 #define DBG_CHOOSE_SHORTEST_WAITING_CH 0
 #endif
-
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-	struct registry_priv *regsty = adapter_to_regsty(adapter);
+	struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
+	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
 	u8 ch, bw, offset;
 	u8 ch_c = 0, bw_c = 0, offset_c = 0;
 	int i;
@@ -1036,8 +653,8 @@ bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8
 	}
 
 	/* full search and narrow bw judegement first to avoid potetial judegement timing issue */
-	for (bw = CHANNEL_WIDTH_20; bw <= req_bw; bw++) {
-		if (!hal_is_bw_support(adapter, bw))
+	for (bw = CHANNEL_WIDTH_20; bw <= max_bw; bw++) {
+		if (!hal_is_bw_support(dvobj_get_primary_adapter(dvobj), bw))
 			continue;
 
 		for (i = 0; i < rfctl->max_chan_nums; i++) {
@@ -1046,6 +663,8 @@ bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8
 			u32 waiting_ms = 0;
 
 			ch = rfctl->channel_set[i].ChannelNum;
+			if (sel_ch > 0 && ch != sel_ch)
+				continue;
 
 			if ((d_flags & RTW_CHF_2G) && ch <= 14)
 				continue;
@@ -1061,38 +680,46 @@ bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8
 					continue;
 			}
 
+			if (mesh_only && ch >= 5 && ch <= 9 && bw > CHANNEL_WIDTH_20)
+				continue;
+
 			if (!rtw_get_offset_by_chbw(ch, bw, &offset))
 				continue;
 
 			if (!rtw_chset_is_chbw_valid(rfctl->channel_set, ch, bw, offset))
 				continue;
 
-			if ((d_flags & RTW_CHF_NON_OCP) && rtw_chset_is_ch_non_ocp(rfctl->channel_set, ch, bw, offset))
+			if ((d_flags & RTW_CHF_NON_OCP) && rtw_chset_is_chbw_non_ocp(rfctl->channel_set, ch, bw, offset))
 				continue;
 
 			if ((d_flags & RTW_CHF_DFS) && rtw_is_dfs_chbw(ch, bw, offset))
 				continue;
 
-			if ((d_flags & RTW_CHF_LONG_CAC) && rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(adapter)))
+			if ((d_flags & RTW_CHF_LONG_CAC) && rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(dvobj)))
 				continue;
 
 			if ((d_flags & RTW_CHF_NON_DFS) && !rtw_is_dfs_chbw(ch, bw, offset))
 				continue;
 
-			if ((d_flags & RTW_CHF_NON_LONG_CAC) && !rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(adapter)))
+			if ((d_flags & RTW_CHF_NON_LONG_CAC) && !rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(dvobj)))
 				continue;
 
 			#ifdef CONFIG_DFS_MASTER
-			waiting_ms = rtw_get_ch_waiting_ms(adapter, ch, bw, offset, &non_ocp_ms, &cac_ms);
+			waiting_ms = rtw_get_ch_waiting_ms(rfctl, ch, bw, offset, &non_ocp_ms, &cac_ms);
 			#endif
 
 			if (DBG_CHOOSE_SHORTEST_WAITING_CH)
-				RTW_INFO(FUNC_ADPT_FMT":%u,%u,%u %u(non_ocp:%u, cac:%u)\n"
-					, FUNC_ADPT_ARG(adapter), ch, bw, offset, waiting_ms, non_ocp_ms, cac_ms);
+				RTW_INFO("%s:%u,%u,%u %u(non_ocp:%u, cac:%u)\n"
+					, __func__, ch, bw, offset, waiting_ms, non_ocp_ms, cac_ms);
 
 			if (ch_c == 0
+				/* first: smaller wating time */
 				|| min_waiting_ms > waiting_ms
-				|| (min_waiting_ms == waiting_ms && bw > bw_c) /* wider bw first */
+				/* then: wider bw */
+				|| (min_waiting_ms == waiting_ms && bw > bw_c)
+				/* then: same band if requested */
+				|| (same_band_prefer && min_waiting_ms == waiting_ms && bw == bw_c
+					&& !rtw_is_same_band(cur_ch, ch_c) && rtw_is_same_band(cur_ch, ch))
 			) {
 				ch_c = ch;
 				bw_c = bw;
@@ -1103,8 +730,10 @@ bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8
 	}
 
 	if (ch_c != 0) {
-		RTW_INFO(FUNC_ADPT_FMT": d_flags:0x%02x %u,%u,%u waiting_ms:%u\n"
-			, FUNC_ADPT_ARG(adapter), d_flags, ch_c, bw_c, offset_c, min_waiting_ms);
+		RTW_INFO("%s: d_flags:0x%02x cur_ch:%u sb_prefer:%u%s %u,%u,%u waiting_ms:%u\n"
+			, __func__, d_flags, cur_ch, same_band_prefer
+			, mesh_only ? " mesh_only" : ""
+			, ch_c, bw_c, offset_c, min_waiting_ms);
 
 		*dec_ch = ch_c;
 		*dec_bw = bw_c;
@@ -1112,77 +741,14 @@ bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8
 		return _TRUE;
 	}
 
-	if (d_flags == 0)
+	if (d_flags == 0) {
+		RTW_INFO("%s: sel_ch:%u max_bw:%u d_flags:0x%02x cur_ch:%u sb_prefer:%u%s\n"
+			, __func__, sel_ch, max_bw, d_flags, cur_ch, same_band_prefer
+			, mesh_only ? " mesh_only" : "");
 		rtw_warn_on(1);
-
-	return _FALSE;
-}
-
-void dump_country_chplan(void *sel, const struct country_chplan *ent)
-{
-	_RTW_PRINT_SEL(sel, "\"%c%c\", 0x%02X%s\n"
-		, ent->alpha2[0], ent->alpha2[1], ent->chplan
-		, COUNTRY_CHPLAN_EN_11AC(ent) ? " ac" : ""
-	);
-}
-
-void dump_country_chplan_map(void *sel)
-{
-	const struct country_chplan *ent;
-	u8 code[2];
-
-#if RTW_DEF_MODULE_REGULATORY_CERT
-	_RTW_PRINT_SEL(sel, "RTW_DEF_MODULE_REGULATORY_CERT:0x%x\n", RTW_DEF_MODULE_REGULATORY_CERT);
-#endif
-#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
-	_RTW_PRINT_SEL(sel, "CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP\n");
-#endif
-
-	for (code[0] = 'A'; code[0] <= 'Z'; code[0]++) {
-		for (code[1] = 'A'; code[1] <= 'Z'; code[1]++) {
-			ent = rtw_get_chplan_from_country(code);
-			if (!ent)
-				continue;
-
-			dump_country_chplan(sel, ent);
-		}
 	}
-}
-
-void dump_chplan_id_list(void *sel)
-{
-	int i;
-
-	for (i = 0; i < RTW_CHPLAN_MAX; i++) {
-		if (!rtw_is_channel_plan_valid(i))
-			continue;
 
-		_RTW_PRINT_SEL(sel, "0x%02X ", i);
-	}
-
-	RTW_PRINT_SEL(sel, "0x7F\n");
-}
-
-void dump_chplan_test(void *sel)
-{
-	int i, j;
-
-	/* check invalid channel */
-	for (i = 0; i < RTW_RD_2G_MAX; i++) {
-		for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan2G[i]); j++) {
-			if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan2G[i], j)) == 0)
-				RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan2G[i], j), i, j);
-		}
-	}
-
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-	for (i = 0; i < RTW_RD_5G_MAX; i++) {
-		for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan5G[i]); j++) {
-			if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan5G[i], j)) == 0)
-				RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan5G[i], j), i, j);
-		}
-	}
-#endif
+	return _FALSE;
 }
 
 void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set)
@@ -1213,11 +779,10 @@ void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set)
 	RTW_PRINT_SEL(sel, "total ch number:%d\n", i);
 }
 
-void dump_cur_chset(void *sel, _adapter *adapter)
+void dump_cur_chset(void *sel, struct rf_ctl_t *rfctl)
 {
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-	struct registry_priv *regsty = adapter_to_regsty(adapter);
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
+	struct registry_priv *regsty = dvobj_to_regsty(dvobj);
 	int i;
 
 	if (rfctl->country_ent)
@@ -1230,7 +795,7 @@ void dump_cur_chset(void *sel, _adapter *adapter)
 #endif
 
 #ifdef CONFIG_DFS_MASTER
-	RTW_PRINT_SEL(sel, "dfs_domain:%u\n", rtw_odm_get_dfs_domain(adapter));
+	RTW_PRINT_SEL(sel, "dfs_domain:%u\n", rtw_odm_get_dfs_domain(dvobj));
 #endif
 
 	for (i = 0; i < MAX_CHANNEL_NUM; i++)
@@ -1238,13 +803,13 @@ void dump_cur_chset(void *sel, _adapter *adapter)
 			break;
 
 	if (i < MAX_CHANNEL_NUM) {
-		_RTW_PRINT_SEL(sel, "excl_chs:");
+		RTW_PRINT_SEL(sel, "excl_chs:");
 		for (i = 0; i < MAX_CHANNEL_NUM; i++) {
 			if (regsty->excl_chs[i] == 0)
 				break;
 			_RTW_PRINT_SEL(sel, "%u ", regsty->excl_chs[i]);
 		}
-		RTW_PRINT_SEL(sel, "\n");
+		_RTW_PRINT_SEL(sel, "\n");
 	}
 
 	dump_chset(sel, rfctl->channel_set);
@@ -1308,6 +873,50 @@ exit:
 	return valid;
 }
 
+/**
+ * rtw_chset_sync_chbw - obey g_ch, adjust g_bw, g_offset, bw, offset to fit in channel plan
+ * @ch_set: channel plan to check
+ * @req_ch: pointer of the request ch, may be modified further
+ * @req_bw: pointer of the request bw, may be modified further
+ * @req_offset: pointer of the request offset, may be modified further
+ * @g_ch: pointer of the ongoing group ch
+ * @g_bw: pointer of the ongoing group bw, may be modified further
+ * @g_offset: pointer of the ongoing group offset, may be modified further
+ */
+void rtw_chset_sync_chbw(RT_CHANNEL_INFO *ch_set, u8 *req_ch, u8 *req_bw, u8 *req_offset
+	, u8 *g_ch, u8 *g_bw, u8 *g_offset)
+{
+	u8 r_ch, r_bw, r_offset;
+	u8 u_ch, u_bw, u_offset;
+	u8 cur_bw = *req_bw;
+
+	while (1) {
+		r_ch = *req_ch;
+		r_bw = cur_bw;
+		r_offset = *req_offset;
+		u_ch = *g_ch;
+		u_bw = *g_bw;
+		u_offset = *g_offset;
+
+		rtw_sync_chbw(&r_ch, &r_bw, &r_offset, &u_ch, &u_bw, &u_offset);
+
+		if (rtw_chset_is_chbw_valid(ch_set, r_ch, r_bw, r_offset))
+			break;
+		if (cur_bw == CHANNEL_WIDTH_20) {
+			rtw_warn_on(1);
+			break;
+		}
+		cur_bw--;
+	};
+
+	*req_ch = r_ch;
+	*req_bw = r_bw;
+	*req_offset = r_offset;
+	*g_ch = u_ch;
+	*g_bw = u_bw;
+	*g_offset = u_offset;
+}
+
 /*
  * Check the @param ch is fit with setband setting of @param adapter
  * @adapter: the given adapter
@@ -1366,9 +975,20 @@ Following are the initialization functions for WiFi MLME
 int init_hw_mlme_ext(_adapter *padapter)
 {
 	struct	mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	u8 rx_bar_enble = _TRUE;
 
-	/* set_opmode_cmd(padapter, infra_client_with_mlme); */ /* removed */
+	/*
+	 * Sync driver status and hardware setting
+	 */
 
+	/* Modify to make sure first time change channel(band) would be done properly */
+	pHalData->current_channel = 0;
+	pHalData->current_channel_bw = CHANNEL_WIDTH_MAX;
+	pHalData->current_band_type = BAND_ON_2_4G;
+
+	/* set_opmode_cmd(padapter, infra_client_with_mlme); */ /* removed */
+	rtw_hal_set_hwreg(padapter, HW_VAR_ENABLE_RX_BAR, &rx_bar_enble);
 	set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
 
 	return _SUCCESS;
@@ -1376,16 +996,40 @@ int init_hw_mlme_ext(_adapter *padapter)
 
 void init_mlme_default_rate_set(_adapter *padapter)
 {
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-	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,};
+	struct	mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	unsigned	char end_set[1] = {0xff};
+	u8	offset_datarate = 0;
+	u8	offset_basicrate = 0;
+#ifdef CONFIG_80211N_HT
 	unsigned char	supported_mcs_set[16] = {0xff, 0xff, 0xff, 0x00, 0x00, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
+#endif
 
-	_rtw_memcpy(pmlmeext->datarate, mixed_datarate, NumRates);
-	_rtw_memcpy(pmlmeext->basicrate, mixed_basicrate, NumRates);
+	if (IsSupportedTxCCK(padapter->registrypriv.wireless_mode)) {
+
+		unsigned char	datarate_b[B_MODE_RATE_NUM] ={_1M_RATE_, _2M_RATE_, _5M_RATE_, _11M_RATE_};
+		_rtw_memcpy(pmlmeext->datarate, datarate_b, B_MODE_RATE_NUM);
+		_rtw_memcpy(pmlmeext->basicrate, datarate_b, B_MODE_RATE_NUM);
+		offset_datarate += B_MODE_RATE_NUM;
+		offset_basicrate += B_MODE_RATE_NUM;
+		RTW_INFO("%s: support CCK\n", __func__);
+	}
+	if(IsSupportedTxOFDM(padapter->registrypriv.wireless_mode)) {
+		unsigned char	datarate_g[G_MODE_RATE_NUM] ={_6M_RATE_, _9M_RATE_, _12M_RATE_, _18M_RATE_,_24M_RATE_, _36M_RATE_, _48M_RATE_, _54M_RATE_};
+		unsigned char	basicrate_g[G_MODE_BASIC_RATE_NUM] = {_6M_RATE_, _12M_RATE_, _24M_RATE_};
+		_rtw_memcpy(pmlmeext->datarate + offset_datarate, datarate_g, G_MODE_RATE_NUM);
+		_rtw_memcpy(pmlmeext->basicrate + offset_basicrate,basicrate_g, G_MODE_BASIC_RATE_NUM);
+		offset_datarate += G_MODE_RATE_NUM;
+		offset_basicrate += G_MODE_BASIC_RATE_NUM;
+		RTW_INFO("%s: support OFDM\n", __func__);
 
-	_rtw_memcpy(pmlmeext->default_supported_mcs_set, supported_mcs_set, sizeof(pmlmeext->default_supported_mcs_set));
+	}
+	_rtw_memcpy(pmlmeext->datarate + offset_datarate, end_set, 1);
+	_rtw_memcpy(pmlmeext->basicrate + offset_basicrate, end_set, 1);
+
+#ifdef CONFIG_80211N_HT
+	if( padapter->registrypriv.ht_enable && is_supported_ht(padapter->registrypriv.wireless_mode))
+		_rtw_memcpy(pmlmeext->default_supported_mcs_set, supported_mcs_set, sizeof(pmlmeext->default_supported_mcs_set));
+#endif
 }
 
 static void init_mlme_ext_priv_value(_adapter *padapter)
@@ -1397,9 +1041,7 @@ static void init_mlme_ext_priv_value(_adapter *padapter)
 	pmlmeext->mgnt_seq = 0;/* reset to zero when disconnect at client mode */
 #ifdef CONFIG_IEEE80211W
 	pmlmeext->sa_query_seq = 0;
-	pmlmeext->mgnt_80211w_IPN = 0;
-	pmlmeext->mgnt_80211w_IPN_rx = 0;
-#endif /* CONFIG_IEEE80211W */
+#endif
 	pmlmeext->cur_channel = padapter->registrypriv.channel;
 	pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
 	pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
@@ -1407,7 +1049,6 @@ static void init_mlme_ext_priv_value(_adapter *padapter)
 	pmlmeext->retry = 0;
 
 	pmlmeext->cur_wireless_mode = padapter->registrypriv.wireless_mode;
-
 	init_mlme_default_rate_set(padapter);
 
 	if (pmlmeext->cur_channel > 14)
@@ -1423,7 +1064,12 @@ static void init_mlme_ext_priv_value(_adapter *padapter)
 	pmlmeext->sitesurvey_res.rx_ampdu_size = RX_AMPDU_SIZE_INVALID;
 #ifdef CONFIG_SCAN_BACKOP
 	mlmeext_assign_scan_backop_flags_sta(pmlmeext, /*SS_BACKOP_EN|*/SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
+	#ifdef CONFIG_AP_MODE
 	mlmeext_assign_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN | SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
+	#endif
+	#ifdef CONFIG_RTW_MESH
+	mlmeext_assign_scan_backop_flags_mesh(pmlmeext, /*SS_BACKOP_EN | */SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
+	#endif
 	pmlmeext->sitesurvey_res.scan_cnt = 0;
 	pmlmeext->sitesurvey_res.scan_cnt_max = RTW_SCAN_NUM_OF_CH;
 	pmlmeext->sitesurvey_res.backop_ms = RTW_BACK_OP_CH_MS;
@@ -1454,6 +1100,11 @@ static void init_mlme_ext_priv_value(_adapter *padapter)
 
 	pmlmeext->action_public_rxseq = 0xffff;
 	pmlmeext->action_public_dialog_token = 0xff;
+#ifdef ROKU_PRIVATE
+/*infra mode, used to store AP's info*/
+	_rtw_memset(pmlmeinfo->SupportedRates_infra_ap, 0, NDIS_802_11_LENGTH_RATES_EX);
+	pmlmeinfo->ht_vht_received = 0;
+#endif /* ROKU_PRIVATE */
 }
 
 void init_mlme_ext_timer(_adapter *padapter)
@@ -1463,8 +1114,8 @@ void init_mlme_ext_timer(_adapter *padapter)
 	rtw_init_timer(&pmlmeext->survey_timer, padapter, survey_timer_hdl, padapter);
 	rtw_init_timer(&pmlmeext->link_timer, padapter, link_timer_hdl, padapter);
 #ifdef CONFIG_RTW_80211R
-	rtw_init_timer(&pmlmeext->ft_link_timer, padapter, ft_link_timer_hdl, padapter);
-	rtw_init_timer(&pmlmeext->ft_roam_timer, padapter, ft_roam_timer_hdl, padapter);
+	rtw_init_timer(&pmlmeext->ft_link_timer, padapter, rtw_ft_link_timer_hdl, padapter);
+	rtw_init_timer(&pmlmeext->ft_roam_timer, padapter, rtw_ft_roam_timer_hdl, padapter);
 #endif
 
 #ifdef CONFIG_RTW_REPEATER_SON
@@ -1477,7 +1128,6 @@ int	init_mlme_ext_priv(_adapter *padapter)
 	int	res = _SUCCESS;
 	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);
 
 	/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
@@ -1510,6 +1160,24 @@ int	init_mlme_ext_priv(_adapter *padapter)
 	pmlmeext->fixed_chan = 0xFF;
 #endif
 
+	pmlmeext->tsf_update_pause_factor = pregistrypriv->tsf_update_pause_factor;
+	pmlmeext->tsf_update_restore_factor = pregistrypriv->tsf_update_restore_factor;
+
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+	pmlmeext->ssmps_en = _FALSE;
+	pmlmeext->ssmps_tx_tp_th = SSMPS_TX_TP_TH;/*Mbps*/
+	pmlmeext->ssmps_rx_tp_th = SSMPS_RX_TP_TH;/*Mbps*/
+	#ifdef DBG_STATIC_SMPS
+	pmlmeext->ssmps_test = _FALSE;
+	#endif
+#endif
+
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+	pmlmeext->txss_ctrl_en = _TRUE;
+	pmlmeext->txss_tp_th = TXSS_TP_TH;
+	pmlmeext->txss_tp_chk_cnt = TXSS_TP_CHK_CNT;
+#endif
+
 	return res;
 
 }
@@ -1527,12 +1195,14 @@ void free_mlme_ext_priv(struct mlme_ext_priv *pmlmeext)
 	}
 }
 
+#ifdef CONFIG_PATCH_JOIN_WRONG_CHANNEL
 static u8 cmp_pkt_chnl_diff(_adapter *padapter, u8 *pframe, uint packet_len)
 {
 	/* if the channel is same, return 0. else return channel differential	 */
 	uint len;
 	u8 channel;
 	u8 *p;
+
 	p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_, _DSSET_IE_, &len, packet_len - _BEACON_IE_OFFSET_);
 	if (p) {
 		channel = *(p + 2);
@@ -1543,6 +1213,7 @@ static u8 cmp_pkt_chnl_diff(_adapter *padapter, u8 *pframe, uint packet_len)
 	} else
 		return 0;
 }
+#endif /* CONFIG_PATCH_JOIN_WRONG_CHANNEL */
 
 static void _mgt_dispatcher(_adapter *padapter, struct mlme_handler *ptable, union recv_frame *precv_frame)
 {
@@ -1553,7 +1224,25 @@ static void _mgt_dispatcher(_adapter *padapter, struct mlme_handler *ptable, uni
 		/* receive the frames that ra(a1) is my address or ra(a1) is bc address. */
 		if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN) &&
 		    !_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN))
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+		{
+			struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+
+			if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) != _TRUE)
+				return;
+
+		    if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE)
+				return;
+
+		    if ( pwdev_priv->pno_mac_addr[0] == 0xFF)
+				return;
+
+		    if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_pno_mac_addr(padapter), ETH_ALEN))
+				return;
+		}
+#else
 			return;
+#endif
 
 		ptable->func(padapter, precv_frame);
 	}
@@ -1564,9 +1253,6 @@ void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)
 {
 	int index;
 	struct mlme_handler *ptable;
-#ifdef CONFIG_AP_MODE
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-#endif /* CONFIG_AP_MODE */
 	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	struct sta_info *psta = rtw_get_stainfo(&padapter->stapriv, get_addr2_ptr(pframe));
@@ -1592,7 +1278,25 @@ void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)
 	/* receive the frames that ra(a1) is my address or ra(a1) is bc address. */
 	if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN) &&
 	    !_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN))
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+		{
+			struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+
+			if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) != _TRUE)
+				return;
+
+			if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE)
+				return;
+
+			if ( pwdev_priv->pno_mac_addr[0] == 0xFF)
+				return;
+
+			if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_pno_mac_addr(padapter), ETH_ALEN))
+				return;
+		}
+#else
 		return;
+#endif
 
 	ptable = mlme_sta_tbl;
 
@@ -1635,7 +1339,7 @@ void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)
 #ifdef CONFIG_AP_MODE
 	switch (get_frame_sub_type(pframe)) {
 	case WIFI_AUTH:
-		if (MLME_IS_AP(padapter))
+		if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter))
 			ptable->func = &OnAuth;
 		else
 			ptable->func = &OnAuthClient;
@@ -1778,7 +1482,7 @@ unsigned int OnProbeReq(_adapter *padapter, union recv_frame *precv_frame)
 		/*	Commented by Kurt 2012/10/16 */
 		/*	IOT issue: Google Nexus7 use 1M rate to send p2p_probe_req after GO nego completed and Nexus7 is client */
 		if (padapter->registrypriv.wifi_spec == 1) {
-			if (pattrib->data_rate <= 3)
+			if (pattrib->data_rate <= DESC_RATE11M)
 				wifi_test_chk_rate = 0;
 		}
 
@@ -1888,35 +1592,31 @@ _continue:
 			/* update peer stainfo */
 			psta->isrc = _TRUE;
 
-			/* get a unique AID */
+			/* AID assignment */
 			if (psta->cmn.aid > 0)
-				RTW_INFO("old AID %d\n", psta->cmn.aid);
+				RTW_INFO(FUNC_ADPT_FMT" old AID=%d\n", FUNC_ADPT_ARG(padapter), psta->cmn.aid);
 			else {
-				for (psta->cmn.aid = 1; psta->cmn.aid <= NUM_STA; psta->cmn.aid++)
-					if (pstapriv->sta_aid[psta->cmn.aid - 1] == NULL)
-						break;
-
-				if (psta->cmn.aid > pstapriv->max_num_sta) {
-					psta->cmn.aid = 0;
-					RTW_INFO("no room for more AIDs\n");
+				if (!rtw_aid_alloc(padapter, psta)) {
+					RTW_INFO(FUNC_ADPT_FMT" no room for more AIDs\n", FUNC_ADPT_ARG(padapter));
 					return _SUCCESS;
-				} else {
-					pstapriv->sta_aid[psta->cmn.aid - 1] = psta;
-					RTW_INFO("allocate new AID = (%d)\n", psta->cmn.aid);
 				}
+				RTW_INFO(FUNC_ADPT_FMT" allocate new AID=%d\n", FUNC_ADPT_ARG(padapter), psta->cmn.aid);
 			}
 
 			psta->qos_option = 1;
 			psta->cmn.bw_mode = CHANNEL_WIDTH_20;
 			psta->ieee8021x_blocked = _FALSE;
 #ifdef CONFIG_80211N_HT
-			psta->htpriv.ht_option = _TRUE;
-			psta->htpriv.ampdu_enable = _FALSE;
-			psta->htpriv.sgi_20m = _FALSE;
-			psta->htpriv.sgi_40m = _FALSE;
-			psta->htpriv.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-			psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
-			psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
+			if(padapter->registrypriv.ht_enable &&
+				is_supported_ht(padapter->registrypriv.wireless_mode)) {
+				psta->htpriv.ht_option = _TRUE;
+				psta->htpriv.ampdu_enable = _FALSE;
+				psta->htpriv.sgi_20m = _FALSE;
+				psta->htpriv.sgi_40m = _FALSE;
+				psta->htpriv.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+				psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
+				psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
+			}
 #endif
 
 			rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
@@ -1962,9 +1662,20 @@ _non_rc_device:
 			goto _issue_probersp;
 
 		if ((ielen != 0 && _FALSE == _rtw_memcmp((void *)(p + 2), (void *)cur->Ssid.Ssid, cur->Ssid.SsidLength))
-		    || (ielen == 0 && pmlmeinfo->hidden_ssid_mode)
-		   )
-			return _SUCCESS;
+			|| (ielen == 0 && pmlmeinfo->hidden_ssid_mode))
+			goto exit;
+
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter)) {
+			p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, WLAN_EID_MESH_ID, (int *)&ielen,
+					len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
+
+			if (!p)
+				goto exit;
+			if (ielen != 0 && _rtw_memcmp((void *)(p + 2), (void *)cur->mesh_id.Ssid, cur->mesh_id.SsidLength) == _FALSE)
+				goto exit;
+		}
+		#endif
 
 _issue_probersp:
 		if (((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
@@ -1975,16 +1686,14 @@ _issue_probersp:
 
 	}
 
+exit:
 	return _SUCCESS;
 
 }
 
 unsigned int OnProbeRsp(_adapter *padapter, union recv_frame *precv_frame)
 {
-	struct sta_info		*psta;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct sta_priv		*pstapriv = &padapter->stapriv;
 	u8	*pframe = precv_frame->u.hdr.rx_data;
 #ifdef CONFIG_P2P
 	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
@@ -2032,10 +1741,11 @@ unsigned int OnProbeRsp(_adapter *padapter, union recv_frame *precv_frame)
 
 
 	if ((mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS))
-#ifdef CONFIG_RTW_REPEATER_SON
+		|| (MLME_IS_MESH(padapter) && check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE))
+		#ifdef CONFIG_RTW_REPEATER_SON
 		|| (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS)
-#endif
-		) {
+		#endif
+	) {
 		rtw_mi_report_survey_event(padapter, precv_frame);
 		return _SUCCESS;
 	}
@@ -2070,12 +1780,11 @@ static void rtw_check_legacy_ap(_adapter *padapter, u8 *pframe, u32 len)
 
 	if (pmlmeext->bstart_bss == _TRUE) {
 		int left;
-		u16 capability;
 		unsigned char *pos;
 		struct rtw_ieee802_11_elems elems;
-		struct HT_info_element *pht_info = NULL;
+#ifdef CONFIG_80211N_HT
 		u16 cur_op_mode; 
-
+#endif
 		/* checking IEs */
 		left = len - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_;
 		pos = pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_;
@@ -2083,9 +1792,9 @@ static void rtw_check_legacy_ap(_adapter *padapter, u8 *pframe, u32 len)
 			RTW_INFO("%s: parse fail for "MAC_FMT"\n", __func__, MAC_ARG(GetAddr3Ptr(pframe)));
 			return;
 		}
-
+#ifdef CONFIG_80211N_HT
 		cur_op_mode = pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_OP_MODE_MASK;
-
+#endif
 		/* for legacy ap */
 		if (elems.ht_capabilities == NULL && elems.ht_capabilities_len == 0) {
 
@@ -2110,8 +1819,6 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 	uint len = precv_frame->u.hdr.len;
 	WLAN_BSSID_EX *pbss;
 	int ret = _SUCCESS;
-	u8 *p = NULL;
-	u32 ielen = 0;
 #ifdef CONFIG_TDLS
 	struct sta_info *ptdls_sta;
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
@@ -2122,19 +1829,10 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 
 	if (validate_beacon_len(pframe, len) == _FALSE)
 		return _SUCCESS;
-#ifdef CONFIG_ATTEMPT_TO_FIX_AP_BEACON_ERROR
-	p = rtw_get_ie(pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, &ielen,
-		precv_frame->u.hdr.len - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_);
-	if ((p != NULL) && (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. */
-			RTW_INFO("[WIFIDBG] Error in ESR IE is detected in Beacon of BSSID:"MAC_FMT". Fix the length of ESR IE to avoid failed Beacon parsing.\n", MAC_ARG(GetAddr3Ptr(pframe)));
-			*(p + 1) = ielen - 1;
-		}
-	}
-#endif
 
-	if (mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS)) {
+	if (mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS)
+		|| (MLME_IS_MESH(padapter) && check_fwstate(pmlmepriv, WIFI_ASOC_STATE))
+	) {
 		rtw_mi_report_survey_event(padapter, precv_frame);
 		return _SUCCESS;
 	}
@@ -2147,9 +1845,9 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 
 	if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)) {
 		if ((pmlmeinfo->state & WIFI_FW_AUTH_NULL)
-			&& rtw_sta_linking_test_wait_done()
+			&& (rtw_sta_linking_test_wait_done() || pmlmeext->join_abort)
 		) {
-			if (rtw_sta_linking_test_force_fail()) {
+			if (rtw_sta_linking_test_force_fail() || pmlmeext->join_abort) {
 				set_link_timer(pmlmeext, 1);
 				return _SUCCESS;
 			}
@@ -2168,12 +1866,13 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 						RTW_INFO("%s: beacon keys ready\n", __func__);
 						_rtw_memcpy(&pmlmepriv->cur_beacon_keys,
 							&recv_beacon, sizeof(recv_beacon));
-						pmlmepriv->new_beacon_cnts = 0;
 					} else {
 						RTW_ERR("%s: get beacon keys failed\n", __func__);
 						_rtw_memset(&pmlmepriv->cur_beacon_keys, 0, sizeof(recv_beacon));
-						pmlmepriv->new_beacon_cnts = 0;
 					}
+					#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
+					pmlmepriv->new_beacon_cnts = 0;
+					#endif
 				}
 				rtw_mfree((u8 *)pbss, sizeof(WLAN_BSSID_EX));
 			}
@@ -2183,14 +1882,8 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 
 			/* update TSF Value */
 			update_TSF(pmlmeext, pframe, len);
-
-			/* reset for adaptive_early_32k */
-			pmlmeext->adaptive_tsf_done = _FALSE;
-			pmlmeext->DrvBcnEarly = 0xff;
-			pmlmeext->DrvBcnTimeOut = 0xff;
 			pmlmeext->bcn_cnt = 0;
-			_rtw_memset(pmlmeext->bcn_delay_cnt, 0, sizeof(pmlmeext->bcn_delay_cnt));
-			_rtw_memset(pmlmeext->bcn_delay_ratio, 0, sizeof(pmlmeext->bcn_delay_ratio));
+			pmlmeext->last_bcn_cnt = 0;
 
 #ifdef CONFIG_P2P_PS
 			/* Comment by YiWei , in wifi p2p spec the "3.3 P2P Power Management" , "These mechanisms are available in a P2P Group in which only P2P Devices are associated." */
@@ -2228,7 +1921,9 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 					return _SUCCESS;
 				}
 #endif /* CONFIG_PATCH_JOIN_WRONG_CHANNEL */
-
+#ifdef CONFIG_RTW_80211R
+				rtw_ft_update_bcn(padapter, precv_frame);
+#endif
 				ret = rtw_check_bcn_info(padapter, pframe, len);
 				if (!ret) {
 					RTW_PRINT("ap has changed, disconnect now\n ");
@@ -2243,9 +1938,10 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 				}
 
 				pmlmepriv->cur_network_scanned->network.Rssi = precv_frame->u.hdr.attrib.phy_info.recv_signal_power;
-
-				adaptive_early_32k(pmlmeext, pframe, len);
-
+				pmlmeext->bcn_cnt++;
+#ifdef CONFIG_BCN_RECV_TIME
+				rtw_rx_bcn_time_update(padapter, len, precv_frame->u.hdr.attrib.data_rate);
+#endif
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_TDLS_CH_SW
 				if (rtw_tdls_is_chsw_allowed(padapter) == _TRUE) {
@@ -2262,15 +1958,17 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 #endif
 #endif /* CONFIG_TDLS */
 
-#ifdef CONFIG_DFS
-				process_csa_ie(padapter, pframe, len);	/* channel switch announcement */
-#endif /* CONFIG_DFS */
+				#ifdef CONFIG_DFS
+				process_csa_ie(padapter
+					, pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_
+					, len - (WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_));
+				#endif
 
 #ifdef CONFIG_P2P_PS
 				process_p2p_ps_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN));
 #endif /* CONFIG_P2P_PS */
 
-				if (pmlmeext->en_hw_update_tsf)
+				if (pmlmeext->tsf_update_required && pmlmeext->en_hw_update_tsf)
 					rtw_enable_hw_update_tsf_cmd(padapter);
 
 #if 0 /* move to validate_recv_mgnt_frame */
@@ -2279,7 +1977,6 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 			}
 
 		} else if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
-			_irqL irqL;
 			u8 rate_set[16];
 			u8 rate_num = 0;
 
@@ -2292,7 +1989,7 @@ unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
 				if ((sta_rx_pkts(psta) & 0xf) == 0)
 					update_beacon_info(padapter, pframe, len, psta);
 
-				if (pmlmeext->en_hw_update_tsf)
+				if (pmlmeext->tsf_update_required && pmlmeext->en_hw_update_tsf)
 					rtw_enable_hw_update_tsf_cmd(padapter);
 			} else {
 				rtw_ies_get_supported_rate(pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_, len - WLAN_HDR_A3_LEN - _BEACON_IE_OFFSET_, rate_set, &rate_num);
@@ -2357,6 +2054,14 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 	if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
 		return _FAIL;
 
+	if (!MLME_IS_ASOC(padapter))
+		return _SUCCESS;
+
+#if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_RTW_MESH)
+	if (MLME_IS_MESH(padapter))
+		return rtw_mesh_on_auth(padapter, precv_frame);
+#endif
+
 	RTW_INFO("+OnAuth\n");
 
 	sa = get_addr2_ptr(pframe);
@@ -2386,6 +2091,13 @@ unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
 
 	RTW_INFO("auth alg=%x, seq=%X\n", algorithm, seq);
 
+	if (rtw_ap_linking_test_force_auth_fail()) {
+		status = rtw_ap_linking_test_force_auth_fail();
+		RTW_INFO(FUNC_ADPT_FMT" force auth fail with status:%u\n"
+			, FUNC_ADPT_ARG(padapter), status);
+		goto auth_fail;
+	}
+
 	if (auth_mode == 2 &&
 	    psecuritypriv->dot11PrivacyAlgrthm != _WEP40_ &&
 	    psecuritypriv->dot11PrivacyAlgrthm != _WEP104_)
@@ -2560,7 +2272,7 @@ auth_fail:
 	pstat = &stat;
 	_rtw_memset((char *)pstat, '\0', sizeof(stat));
 	pstat->auth_seq = 2;
-	_rtw_memcpy(pstat->cmn.mac_addr, sa, 6);
+	_rtw_memcpy(pstat->cmn.mac_addr, sa, ETH_ALEN);
 
 #ifdef CONFIG_NATIVEAP_MLME
 	issue_auth(padapter, pstat, (unsigned short)status);
@@ -2578,12 +2290,6 @@ unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)
 	unsigned int	go2asoc = 0;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-#ifdef CONFIG_RTW_80211R
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	ft_priv	*pftpriv = &pmlmepriv->ftpriv;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta = NULL;
-#endif
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	uint pkt_len = precv_frame->u.hdr.len;
 
@@ -2593,7 +2299,7 @@ unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)
 	if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
 		return _SUCCESS;
 
-	if (!(pmlmeinfo->state & WIFI_FW_AUTH_STATE))
+	if (!(pmlmeinfo->state & WIFI_FW_AUTH_STATE) || pmlmeext->join_abort)
 		return _SUCCESS;
 
 	offset = (GetPrivacy(pframe)) ? 4 : 0;
@@ -2612,6 +2318,7 @@ unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)
 			/* pmlmeinfo->reauth_count = 0; */
 		}
 
+		pmlmeinfo->auth_status = status;
 		set_link_timer(pmlmeext, 1);
 		goto authclnt_fail;
 	}
@@ -2650,29 +2357,9 @@ unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)
 
 	if (go2asoc) {
 #ifdef CONFIG_RTW_80211R
-		if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
-			u8 target_ap_addr[ETH_ALEN] = {0};
-
-			if ((rtw_chk_ft_status(padapter, RTW_FT_AUTHENTICATED_STA)) ||
-				(rtw_chk_ft_status(padapter, RTW_FT_ASSOCIATING_STA)) ||
-				(rtw_chk_ft_status(padapter, RTW_FT_ASSOCIATED_STA))) {
-				/*report_ft_reassoc_event already, and waiting for cfg80211_rtw_update_ft_ies*/
-				return _SUCCESS;
-			}
-
-			rtw_buf_update(&pmlmepriv->auth_rsp, &pmlmepriv->auth_rsp_len, pframe, pkt_len);
-			pftpriv->ft_event.ies = pmlmepriv->auth_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6;
-			pftpriv->ft_event.ies_len = pmlmepriv->auth_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6;
-
-			/*Not support RIC*/
-			pftpriv->ft_event.ric_ies =  NULL;
-			pftpriv->ft_event.ric_ies_len =  0;
-			_rtw_memcpy(target_ap_addr, pmlmepriv->assoc_bssid, ETH_ALEN);
-			report_ft_reassoc_event(padapter, target_ap_addr);
+		if (rtw_ft_update_auth_rsp_ies(padapter, pframe, pkt_len))
 			return _SUCCESS;
-		}
 #endif
-
 		RTW_PRINT("auth success, start assoc\n");
 		start_clnt_assoc(padapter);
 		return _SUCCESS;
@@ -2690,14 +2377,13 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 {
 #ifdef CONFIG_AP_MODE
 	_irqL irqL;
-	u16 capab_info, listen_interval;
+	u16 listen_interval;
 	struct rtw_ieee802_11_elems elems;
 	struct sta_info	*pstat;
-	unsigned char		reassoc, *p, *pos;
-	int		i, ie_len, left;
+	unsigned char		reassoc, *pos;
+	int		left;
 	unsigned short		status = _STATS_SUCCESSFUL_;
 	unsigned short		frame_type, ie_offset = 0;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX	*cur = &(pmlmeinfo->network);
@@ -2767,6 +2453,13 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 	}
 #endif
 
+	if (rtw_ap_linking_test_force_asoc_fail()) {
+		status = rtw_ap_linking_test_force_asoc_fail();
+		RTW_INFO(FUNC_ADPT_FMT" force asoc fail with status:%u\n"
+			, FUNC_ADPT_ARG(padapter), status);
+		goto OnAssocReqFail;
+	}
+
 	/* now parse all ieee802_11 ie to point to elems */
 	left = pkt_len - (IEEE80211_3ADDR_LEN + ie_offset);
 	pos = pframe + (IEEE80211_3ADDR_LEN + ie_offset);
@@ -2820,6 +2513,12 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 	rtw_ap_parse_sta_wmm_ie(padapter, pstat
 		, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
 
+#ifdef CONFIG_RTS_FULL_BW
+	/*check vendor IE*/
+	rtw_parse_sta_vendor_ie_8812(padapter, pstat
+		, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
+#endif/*CONFIG_RTS_FULL_BW*/
+
 	rtw_ap_parse_sta_ht_ie(padapter, pstat, &elems);
 	rtw_ap_parse_sta_vht_ie(padapter, pstat, &elems);
 
@@ -2873,32 +2572,19 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 #ifdef CONFIG_RTW_80211K
 	rtw_ap_parse_sta_rm_en_cap(padapter, pstat, &elems);
 #endif
-	/* get a unique AID */
+
+	/* AID assignment */
 	if (pstat->cmn.aid > 0)
-		RTW_INFO("  old AID %d\n", pstat->cmn.aid);
+		RTW_INFO(FUNC_ADPT_FMT" old AID=%d\n", FUNC_ADPT_ARG(padapter), pstat->cmn.aid);
 	else {
-		for (pstat->cmn.aid = 1; pstat->cmn.aid <= NUM_STA; pstat->cmn.aid++) {
-			if (pstapriv->sta_aid[pstat->cmn.aid - 1] == NULL) {
-				if (pstat->cmn.aid > pstapriv->max_num_sta) {
-					pstat->cmn.aid = 0;
-
-					RTW_INFO("  no room for more AIDs\n");
-
-					status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
-
-					goto OnAssocReqFail;
-
-
-				} else {
-					pstapriv->sta_aid[pstat->cmn.aid - 1] = pstat;
-					RTW_INFO("allocate new AID = (%d)\n", pstat->cmn.aid);
-					break;
-				}
-			}
+		if (!rtw_aid_alloc(padapter, pstat)) {
+			RTW_INFO(FUNC_ADPT_FMT" no room for more AIDs\n", FUNC_ADPT_ARG(padapter));
+			status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
+			goto OnAssocReqFail;
 		}
+		RTW_INFO(FUNC_ADPT_FMT" allocate new AID=%d\n", FUNC_ADPT_ARG(padapter), pstat->cmn.aid);
 	}
 
-
 	pstat->state &= (~WIFI_FW_ASSOC_STATE);
 	pstat->state |= WIFI_FW_ASSOC_SUCCESS;
 	/* RTW_INFO("==================%s, %d,  (%x), bpairwise_key_installed=%d, MAC:"MAC_FMT"\n"
@@ -2967,7 +2653,7 @@ unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
 			report_add_sta_event(padapter, pstat->cmn.mac_addr);
 		}
 #ifdef CONFIG_IEEE80211W
-		if (pstat->bpairwise_key_installed == _TRUE && padapter->securitypriv.binstallBIPkey == _TRUE) {
+		if (pstat->bpairwise_key_installed == _TRUE && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
 			RTW_INFO(MAC_FMT"\n", MAC_ARG(pstat->cmn.mac_addr));
 			issue_action_SA_Query(padapter, pstat->cmn.mac_addr, 0, 0, IEEE80211W_RIGHT_KEY);
 		}
@@ -3003,6 +2689,34 @@ OnAssocReqFail:
 
 }
 
+#if defined(CONFIG_LAYER2_ROAMING) && defined(CONFIG_RTW_80211K)
+void rtw_roam_nb_discover(_adapter *padapter, u8 bfroce)
+{
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);	
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta;
+	u8 nb_req_issue = _FALSE;
+
+	if (!check_fwstate(pmlmepriv, _FW_LINKED))
+		return;
+
+	if (!rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE))
+		return;
+
+	psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
+	if (!psta)
+		return;
+	
+	if (bfroce || (!pmlmepriv->nb_info.nb_rpt_is_same))
+		nb_req_issue = _TRUE;
+	
+	if (nb_req_issue && (psta->rm_en_cap[0] & RTW_RRM_NB_RPT_EN)) 
+		rm_add_nb_req(padapter, psta);
+}
+#endif
+
 unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 {
 	uint i;
@@ -3015,7 +2729,9 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 	/* WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network); */
 	u8 *pframe = precv_frame->u.hdr.rx_data;
 	uint pkt_len = precv_frame->u.hdr.len;
+#ifdef CONFIG_WAPI_SUPPORT
 	PNDIS_802_11_VARIABLE_IEs	pWapiIE = NULL;
+#endif
 
 	RTW_INFO("%s\n", __FUNCTION__);
 
@@ -3023,7 +2739,7 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 	if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
 		return _SUCCESS;
 
-	if (!(pmlmeinfo->state & (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE)))
+	if (!(pmlmeinfo->state & (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE)) || pmlmeext->join_abort)
 		return _SUCCESS;
 
 	if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
@@ -3048,6 +2764,14 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 
 	/* AID */
 	res = pmlmeinfo->aid = (int)(le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 4)) & 0x3fff);
+	
+	/* check aid value */
+	if (res < 1 || res > 2007) {
+		RTW_INFO("assoc reject, aid: %d\n", res);
+		pmlmeinfo->state = WIFI_FW_NULL_STATE;
+		res = -4;
+		goto report_assoc_result;
+	}
 
 	/* following are moved to join event callback function */
 	/* to handle HT, WMM, rate adaptive, update MAC reg */
@@ -3073,6 +2797,9 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 
 		case _HT_CAPABILITY_IE_:	/* HT caps */
 			HT_caps_handler(padapter, pIE);
+#ifdef ROKU_PRIVATE
+			HT_caps_handler_infra_ap(padapter, pIE);
+#endif /* ROKU_PRIVATE */
 			break;
 
 		case _HT_EXTRA_INFO_IE_:	/* HT info */
@@ -3082,6 +2809,9 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 #ifdef CONFIG_80211AC_VHT
 		case EID_VHTCapability:
 			VHT_caps_handler(padapter, pIE);
+#ifdef ROKU_PRIVATE
+			VHT_caps_handler_infra_ap(padapter, pIE);
+#endif /* ROKU_PRIVATE */
 			break;
 
 		case EID_VHTOperation:
@@ -3106,6 +2836,17 @@ unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
 			RM_IE_handler(padapter, pIE);
 			break;
 #endif
+
+#ifdef ROKU_PRIVATE
+		/* Infra mode, used to store AP's info , Parse the supported rates from AssocRsp */
+		case _SUPPORTEDRATES_IE_:
+			Supported_rate_infra_ap(padapter, pIE);
+			break;
+
+		case _EXT_SUPPORTEDRATES_IE_:
+			Extended_Supported_rate_infra_ap(padapter, pIE);
+			break;
+#endif /* ROKU_PRIVATE */
 		default:
 			break;
 		}
@@ -3129,8 +2870,11 @@ report_assoc_result:
 	else
 		rtw_buf_free(&pmlmepriv->assoc_rsp, &pmlmepriv->assoc_rsp_len);
 
-	report_join_res(padapter, res);
+	report_join_res(padapter, res, status);
 
+#if defined(CONFIG_LAYER2_ROAMING) && defined(CONFIG_RTW_80211K)
+	rtw_roam_nb_discover(padapter, _TRUE);
+#endif
 	return _SUCCESS;
 }
 
@@ -3160,8 +2904,6 @@ unsigned int OnDeAuth(_adapter *padapter, union recv_frame *precv_frame)
 
 	reason = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
 
-	rtw_lock_rx_suspend_timeout(8000);
-
 #ifdef CONFIG_AP_MODE
 	if (MLME_IS_AP(padapter)) {
 		_irqL irqL;
@@ -3195,7 +2937,7 @@ unsigned int OnDeAuth(_adapter *padapter, union recv_frame *precv_frame)
 		return _SUCCESS;
 	} else
 #endif
-	{
+	if (!MLME_IS_MESH(padapter)) {
 		int	ignore_received_deauth = 0;
 
 		/*	Commented by Albert 20130604 */
@@ -3250,8 +2992,6 @@ unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame)
 
 	reason = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
 
-	rtw_lock_rx_suspend_timeout(8000);
-
 #ifdef CONFIG_AP_MODE
 	if (MLME_IS_AP(padapter)) {
 		_irqL irqL;
@@ -3284,7 +3024,7 @@ unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame)
 		return _SUCCESS;
 	} else
 #endif
-	{
+	if (!MLME_IS_MESH(padapter)) {
 		RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
 			, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe));
 
@@ -3369,8 +3109,6 @@ unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame)
 	u8 category;
 	u8 action;
 
-	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(padapter->pnetdev));
-
 	psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
 
 	if (!psta)
@@ -3381,6 +3119,9 @@ unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame)
 		goto exit;
 
 	action = frame_body[1];
+
+	RTW_INFO(FUNC_ADPT_FMT" action:%u\n", FUNC_ADPT_ARG(padapter), action);
+
 	switch (action) {
 	case RTW_WLAN_ACTION_SPCT_MSR_REQ:
 	case RTW_WLAN_ACTION_SPCT_MSR_RPRT:
@@ -3389,8 +3130,13 @@ unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame)
 		break;
 	case RTW_WLAN_ACTION_SPCT_CHL_SWITCH:
 #ifdef CONFIG_SPCT_CH_SWITCH
-		ret = on_action_spct_ch_switch(padapter, psta, &frame_body[2],
-				       frame_len - (frame_body - pframe) - 2);
+		ret = on_action_spct_ch_switch(padapter, psta
+				, frame_body + 2, frame_len - (frame_body - pframe) - 2);
+#elif defined(CONFIG_DFS)
+		if (MLME_IS_STA(padapter) && MLME_IS_ASOC(padapter)) {
+			process_csa_ie(padapter
+				, frame_body + 2, frame_len - (frame_body - pframe) - 2);
+		}
 #endif
 		break;
 	default:
@@ -3416,12 +3162,13 @@ unsigned int on_action_wnm(_adapter *adapter, union recv_frame *rframe)
 {
 	unsigned int ret = _FAIL;
 	struct sta_info *sta = NULL;
-	struct sta_priv *stapriv = &adapter->stapriv;
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	struct sta_priv *stapriv = &(adapter->stapriv);
 	u8 *frame = rframe->u.hdr.rx_data;
-	uint frame_len = rframe->u.hdr.len;
+	u32 frame_len = rframe->u.hdr.len;
 	u8 *frame_body = (u8 *)(frame + sizeof(struct rtw_ieee80211_hdr_3addr));
-	u8 category;
-	u8 action;
+	u32 frame_body_len = frame_len - sizeof(struct rtw_ieee80211_hdr_3addr);	
+	u8 category, action;
 	int cnt = 0;
 	char msg[16];
 
@@ -3436,6 +3183,15 @@ unsigned int on_action_wnm(_adapter *adapter, union recv_frame *rframe)
 	action = frame_body[1];
 
 	switch (action) {
+#ifdef CONFIG_RTW_80211R
+	case RTW_WLAN_ACTION_WNM_BTM_REQ:
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+			RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_REQ recv.\n");
+			rtw_wnm_process_btm_req(adapter, frame_body, frame_body_len);
+		}
+		ret = _SUCCESS;
+		break;
+#endif		
 	default:
 		#ifdef CONFIG_IOCTL_CFG80211
 		cnt += sprintf((msg + cnt), "ACT_WNM %u", action);
@@ -3720,7 +3476,6 @@ u8 rx_ampdu_apply_sta(_adapter *adapter, struct sta_info *sta, u8 accept, u8 siz
 u16 rtw_rx_ampdu_apply(_adapter *adapter)
 {
 	u16 adj_cnt = 0;
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 	struct sta_info *sta;
 	u8 accept = rtw_rx_ampdu_is_accept(adapter);
 	u8 size;
@@ -3906,6 +3661,25 @@ unsigned int OnAction_back(_adapter *padapter, union recv_frame *precv_frame)
 	return _SUCCESS;
 }
 
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+u32 rtw_build_vendor_ie(_adapter *padapter , unsigned char **pframe , u8 mgmt_frame_tyte)
+{
+	int vendor_ie_num = 0;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	u32 len = 0;
+
+	for (vendor_ie_num = 0 ; vendor_ie_num < WLAN_MAX_VENDOR_IE_NUM ; vendor_ie_num++) {
+		if (pmlmepriv->vendor_ielen[vendor_ie_num] > 0 && pmlmepriv->vendor_ie_mask[vendor_ie_num] & mgmt_frame_tyte) {
+			_rtw_memcpy(*pframe , pmlmepriv->vendor_ie[vendor_ie_num] , pmlmepriv->vendor_ielen[vendor_ie_num]);
+			*pframe +=  pmlmepriv->vendor_ielen[vendor_ie_num];
+			len += pmlmepriv->vendor_ielen[vendor_ie_num];
+		}
+	}
+
+	return len;
+}
+#endif
+
 #ifdef CONFIG_P2P
 int get_reg_classes_full_count(struct p2p_channels *channel_list)
 {
@@ -3926,8 +3700,7 @@ void issue_p2p_GO_request(_adapter *padapter, u8 *raddr)
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_GO_NEGO_REQ;
 	u8			wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
-	u8			wpsielen = 0, p2pielen = 0, i;
-	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
+	u8			wpsielen = 0, p2pielen = 0;
 	u16			len_channellist_attr = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
@@ -3940,7 +3713,6 @@ void issue_p2p_GO_request(_adapter *padapter, u8 *raddr)
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
@@ -4324,11 +4096,10 @@ void issue_p2p_GO_response(_adapter *padapter, u8 *raddr, u8 *frame_body, uint l
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_GO_NEGO_RESP;
 	u8			wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
-	u8			p2pielen = 0, i;
+	u8			p2pielen = 0;
 	uint			wpsielen = 0;
 	u16			wps_devicepassword_id = 0x0000;
 	uint			wps_devicepassword_id_len = 0;
-	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh;
 	u16			len_channellist_attr = 0;
 
 	struct xmit_frame			*pmgntframe;
@@ -4338,7 +4109,6 @@ void issue_p2p_GO_response(_adapter *padapter, u8 *raddr, u8 *frame_body, uint l
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 #ifdef CONFIG_WFD
@@ -4742,8 +4512,8 @@ void issue_p2p_GO_confirm(_adapter *padapter, u8 *raddr, u8 result)
 	u8			action = P2P_PUB_ACTION_ACTION;
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_GO_NEGO_CONF;
-	u8			wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
-	u8			wpsielen = 0, p2pielen = 0;
+	u8			p2pie[255] = { 0x00 };
+	u8			p2pielen = 0;
 
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
@@ -4752,7 +4522,6 @@ void issue_p2p_GO_confirm(_adapter *padapter, u8 *raddr, u8 result)
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
@@ -4978,9 +4747,8 @@ void issue_p2p_invitation_request(_adapter *padapter, u8 *raddr)
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_INVIT_REQ;
 	u8			p2pie[255] = { 0x00 };
-	u8			p2pielen = 0, i;
+	u8			p2pielen = 0;
 	u8			dialogToken = 3;
-	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
 	u16			len_channellist_attr = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
@@ -4993,7 +4761,6 @@ void issue_p2p_invitation_request(_adapter *padapter, u8 *raddr)
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
@@ -5278,8 +5045,7 @@ void issue_p2p_invitation_response(_adapter *padapter, u8 *raddr, u8 dialogToken
 	u32			p2poui = cpu_to_be32(P2POUI);
 	u8			oui_subtype = P2P_INVIT_RESP;
 	u8			p2pie[255] = { 0x00 };
-	u8			p2pielen = 0, i;
-	u8			channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
+	u8			p2pielen = 0;
 	u16			len_channellist_attr = 0;
 #ifdef CONFIG_WFD
 	u32					wfdielen = 0;
@@ -5292,7 +5058,6 @@ void issue_p2p_invitation_response(_adapter *padapter, u8 *raddr, u8 dialogToken
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
@@ -5528,7 +5293,6 @@ void issue_p2p_provision_request(_adapter *padapter, u8 *pssid, u8 ussidlen, u8
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
@@ -5649,7 +5413,6 @@ void issue_probersp_p2p(_adapter *padapter, unsigned char *da)
 	unsigned char					*mac;
 	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	/* WLAN_BSSID_EX 		*cur_network = &(pmlmeinfo->network); */
 	u16					beacon_interval = 100;
@@ -5958,6 +5721,11 @@ void issue_probersp_p2p(_adapter *padapter, unsigned char *da)
 	pattrib->pktlen += wfdielen;
 #endif
 
+/* Vendor Specific IE */
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_P2P_PROBERESP_VENDOR_IE_BIT);
+#endif
+
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
 
@@ -5976,11 +5744,8 @@ int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short		*fctrl;
 	unsigned char			*mac;
-	unsigned char			bssrate[NumRates];
 	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	int	bssrate_len = 0;
 	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	u8					wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
@@ -6276,6 +6041,11 @@ int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
 	pattrib->pktlen += wfdielen;
 #endif
 
+/* Vendor Specific IE */
+#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_P2P_PROBEREQ_VENDOR_IE_BIT);
+#endif
+
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
 
@@ -6375,7 +6145,7 @@ unsigned int on_action_public_p2p(union recv_frame *precv_frame)
 	u8 *frame_body;
 #ifdef CONFIG_P2P
 	u8 *p2p_ie;
-	u32	p2p_ielen, wps_ielen;
+	u32	p2p_ielen;
 	struct	wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	u8	result = P2P_STATUS_SUCCESS;
 	u8	empty_addr[ETH_ALEN] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
@@ -6513,7 +6283,6 @@ unsigned int on_action_public_p2p(union recv_frame *precv_frame)
 				u8	status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
 				struct group_id_info group_id;
 				u8	invitation_flag = 0;
-				int j = 0;
 
 				merged_p2p_ielen = rtw_get_p2p_merged_ies_len(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_);
 
@@ -6748,7 +6517,6 @@ unsigned int on_action_public_vendor(union recv_frame *precv_frame)
 {
 	unsigned int ret = _FAIL;
 	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint frame_len = precv_frame->u.hdr.len;
 	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
 
 	if (_rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE) {
@@ -6769,7 +6537,6 @@ unsigned int on_action_public_default(union recv_frame *precv_frame, u8 action)
 {
 	unsigned int ret = _FAIL;
 	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint frame_len = precv_frame->u.hdr.len;
 	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
 	u8 token;
 	_adapter *adapter = precv_frame->u.hdr.adapter;
@@ -6800,36 +6567,279 @@ unsigned int on_action_public(_adapter *padapter, union recv_frame *precv_frame)
 	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
 	u8 category, action;
 
-	/* check RA matches or not */
-	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
-		goto exit;
+	/* check RA matches or not */
+	if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
+		goto exit;
+
+	category = frame_body[0];
+	if (category != RTW_WLAN_CATEGORY_PUBLIC)
+		goto exit;
+
+	action = frame_body[1];
+	switch (action) {
+	case ACT_PUBLIC_BSSCOEXIST:
+#ifdef CONFIG_80211N_HT
+#ifdef CONFIG_AP_MODE
+		/*20/40 BSS Coexistence Management frame is a Public Action frame*/
+		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
+			rtw_process_public_act_bsscoex(padapter, pframe, frame_len);
+#endif /*CONFIG_AP_MODE*/
+#endif /*CONFIG_80211N_HT*/
+		break;
+	case ACT_PUBLIC_VENDOR:
+		ret = on_action_public_vendor(precv_frame);
+		break;
+	default:
+		ret = on_action_public_default(precv_frame, action);
+		break;
+	}
+
+exit:
+	return ret;
+}
+
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+static u8 rtw_wnm_nb_elem_parsing(
+	u8* pdata, u32 data_len, u8 from_btm, 
+	u32 *nb_rpt_num, u8 *nb_rpt_is_same,
+	struct roam_nb_info *pnb, struct wnm_btm_cant *pcandidates)
+{
+	u8 bfound = _FALSE, ret = _SUCCESS;
+	u8 *ptr, *pend, *op;
+	u32 elem_len, subelem_len, op_len;
+	u32 i, nb_rpt_entries = 0;
+	struct nb_rpt_hdr *pie;
+	struct wnm_btm_cant *pcandidate;
+
+	if ((!pdata) || (!pnb))
+		return _FAIL;
+
+	if ((from_btm) && (!pcandidates))
+		return _FAIL;
+
+	ptr = pdata;
+	pend = ptr + data_len;
+	elem_len = data_len;
+	subelem_len = (u32)*(pdata+1);
+
+	for (i=0; i < RTW_MAX_NB_RPT_NUM; i++) {
+		if (((ptr + 7) > pend) || (elem_len < subelem_len)) 
+			break;
+
+		if (*ptr != 0x34) {
+			RTW_ERR("WNM: invalid data(0x%2x)!\n", *ptr);
+			ret = _FAIL;
+			break;
+		}
+
+		pie = (struct nb_rpt_hdr *)ptr;		
+		if (from_btm) {
+			op = rtw_get_ie((u8 *)(ptr+15), 
+				WNM_BTM_CAND_PREF_SUBEID, 
+				&op_len, (subelem_len - 15));
+		}
+
+		ptr = (u8 *)(ptr + subelem_len + 2);
+		elem_len -= (subelem_len +2);
+		subelem_len = *(ptr+1);
+		if (from_btm) {
+			pcandidate = (pcandidates + i);
+			_rtw_memcpy(&pcandidate->nb_rpt, pie, sizeof(struct nb_rpt_hdr));
+			if (op && (op_len !=0)) {
+				pcandidate->preference = *(op + 2);
+				bfound = _TRUE;
+			} else
+				pcandidate->preference = 0;
+
+			RTW_DBG("WNM: preference check bssid("MAC_FMT
+				") ,bss_info(0x%04X), reg_class(0x%02X), ch(%d),"
+				" phy_type(0x%02X), preference(0x%02X)\n",
+				MAC_ARG(pcandidate->nb_rpt.bssid), pcandidate->nb_rpt.bss_info, 
+				pcandidate->nb_rpt.reg_class, pcandidate->nb_rpt.ch_num, 
+				pcandidate->nb_rpt.phy_type, pcandidate->preference);
+		} else {
+			if (_rtw_memcmp(&pnb->nb_rpt[i], pie, sizeof(struct nb_rpt_hdr)) == _FALSE)
+				*nb_rpt_is_same = _FALSE;
+			_rtw_memcpy(&pnb->nb_rpt[i], pie, sizeof(struct nb_rpt_hdr));
+		}
+		nb_rpt_entries++;			
+	} 
+
+	if (from_btm) 
+		pnb->preference_en = (bfound)?_TRUE:_FALSE; 
+
+	*nb_rpt_num = nb_rpt_entries;
+	return ret;
+}	
+
+/* selection sorting based on preference value
+ * IN : 		nb_rpt_entries - candidate num
+ * IN/OUT :	pcandidates	- candidate list
+ * return : TRUE - means pcandidates is updated.  
+ */
+static u8 rtw_wnm_candidates_sorting(
+	u32 nb_rpt_entries, struct wnm_btm_cant *pcandidates)
+{
+	u8 updated = _FALSE;
+	u32 i, j, pos;
+	struct wnm_btm_cant swap;
+	struct wnm_btm_cant *pcant_1, *pcant_2;
+
+	if ((!nb_rpt_entries) || (!pcandidates))
+		return updated;
+
+	for (i=0; i < (nb_rpt_entries - 1); i++) {
+		pos = i;
+		for (j=(i + 1); j < nb_rpt_entries; j++) {
+			pcant_1 = pcandidates+pos;
+			pcant_2 = pcandidates+j;
+			if ((pcant_1->preference) < (pcant_2->preference))
+				pos = j;
+		}
+
+		if (pos != i) {
+			updated = _TRUE;
+			_rtw_memcpy(&swap, (pcandidates+i), sizeof(struct wnm_btm_cant));
+			_rtw_memcpy((pcandidates+i), (pcandidates+pos), sizeof(struct wnm_btm_cant));
+			_rtw_memcpy((pcandidates+pos), &swap, sizeof(struct wnm_btm_cant));
+		}
+	}	
+	return updated;
+}	
+
+static void rtw_wnm_nb_info_update(
+	u32 nb_rpt_entries, u8 from_btm, 
+	struct roam_nb_info *pnb, struct wnm_btm_cant *pcandidates, 
+	u8 *nb_rpt_is_same)
+{
+	u8 is_found;
+	u32 i, j;
+	struct wnm_btm_cant *pcand;
+
+	if (!pnb)
+		return;
+
+	pnb->nb_rpt_ch_list_num = 0;
+	for (i=0; i<nb_rpt_entries; i++) {
+		is_found = _FALSE;
+		if (from_btm) {
+			pcand = (pcandidates+i);
+			if (_rtw_memcmp(&pnb->nb_rpt[i], &pcand->nb_rpt,
+					sizeof(struct nb_rpt_hdr)) == _FALSE)
+				*nb_rpt_is_same = _FALSE;
+			_rtw_memcpy(&pnb->nb_rpt[i], &pcand->nb_rpt, sizeof(struct nb_rpt_hdr));
+		}
+
+		RTW_DBG("WNM: bssid(" MAC_FMT 
+			") , bss_info(0x%04X), reg_class(0x%02X), ch_num(%d), phy_type(0x%02X)\n",
+			MAC_ARG(pnb->nb_rpt[i].bssid), pnb->nb_rpt[i].bss_info, 
+			pnb->nb_rpt[i].reg_class, pnb->nb_rpt[i].ch_num, 
+			pnb->nb_rpt[i].phy_type);
+
+		if (pnb->nb_rpt[i].ch_num == 0)
+			continue;
+
+		for (j=0; j<nb_rpt_entries; j++) {
+			if (pnb->nb_rpt[i].ch_num == pnb->nb_rpt_ch_list[j].hw_value) {
+				is_found = _TRUE;
+				break;
+			}
+		}
+							
+		if (!is_found) {
+			pnb->nb_rpt_ch_list[pnb->nb_rpt_ch_list_num].hw_value = pnb->nb_rpt[i].ch_num;
+				pnb->nb_rpt_ch_list_num++;
+		}
+	}
+}
+
+static void rtw_wnm_btm_candidate_select(_adapter *padapter)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	struct wlan_network *pnetwork;
+	u8 bfound = _FALSE;
+	u32 i;
+
+	for (i = 0; i < pnb->last_nb_rpt_entries; i++) {
+		pnetwork = rtw_find_network(
+				&(pmlmepriv->scanned_queue), 
+				pnb->nb_rpt[i].bssid);
+
+		if (pnetwork) {
+			bfound = _TRUE;
+			break;
+		}
+	}
+
+	if (bfound) {
+		_rtw_memcpy(pnb->roam_target_addr, pnb->nb_rpt[i].bssid, ETH_ALEN);
+		RTW_INFO("WNM : select btm entry(%d) - %s("MAC_FMT", ch%u) rssi:%d\n"
+			, i
+			, pnetwork->network.Ssid.Ssid
+			, MAC_ARG(pnetwork->network.MacAddress)
+			, pnetwork->network.Configuration.DSConfig
+			, (int)pnetwork->network.Rssi);
+	} else 
+		_rtw_memset(pnb->roam_target_addr,0, ETH_ALEN);
+}
 
-	category = frame_body[0];
-	if (category != RTW_WLAN_CATEGORY_PUBLIC)
+u32 rtw_wnm_btm_candidates_survey(
+	_adapter *padapter, u8* pframe, u32 elem_len, u8 from_btm)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	struct wnm_btm_cant *pcandidate_list = NULL;
+	u8 nb_rpt_is_same = _TRUE;
+	u32	ret = _FAIL;
+	u32 nb_rpt_entries = 0;	
+
+	if (from_btm) {
+		u32 mlen = sizeof(struct wnm_btm_cant) * RTW_MAX_NB_RPT_NUM;
+		pcandidate_list = (struct wnm_btm_cant *)rtw_malloc(mlen);
+		if (pcandidate_list == NULL) 
+			goto exit;				
+	}
+
+	/*clean the status set last time*/
+	_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
+	pnb->nb_rpt_valid = _FALSE;
+	if (!rtw_wnm_nb_elem_parsing(
+			pframe, elem_len, from_btm, 
+			&nb_rpt_entries, &nb_rpt_is_same,
+			pnb, pcandidate_list))
 		goto exit;
 
-	action = frame_body[1];
-	switch (action) {
-	case ACT_PUBLIC_BSSCOEXIST:
-#ifdef CONFIG_80211N_HT
-#ifdef CONFIG_AP_MODE
-		/*20/40 BSS Coexistence Management frame is a Public Action frame*/
-		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
-			rtw_process_public_act_bsscoex(padapter, pframe, frame_len);
-#endif /*CONFIG_AP_MODE*/
-#endif /*CONFIG_80211N_HT*/
-		break;
-	case ACT_PUBLIC_VENDOR:
-		ret = on_action_public_vendor(precv_frame);
-		break;
-	default:
-		ret = on_action_public_default(precv_frame, action);
-		break;
+	if (nb_rpt_entries != 0) {
+		if ((from_btm) && (rtw_wnm_btm_preference_cap(padapter)))
+			rtw_wnm_candidates_sorting(nb_rpt_entries, pcandidate_list);
+
+		rtw_wnm_nb_info_update(
+			nb_rpt_entries, from_btm, 
+			pnb, pcandidate_list, &nb_rpt_is_same);
+	}
+
+	RTW_INFO("nb_rpt_is_same = %d, nb_rpt_entries = %d, last_nb_rpt_entries = %d\n", 
+		nb_rpt_is_same, nb_rpt_entries, pnb->last_nb_rpt_entries);
+	if ((nb_rpt_is_same == _TRUE) && (nb_rpt_entries == pnb->last_nb_rpt_entries))
+		pnb->nb_rpt_is_same = _TRUE;
+	else {
+		pnb->nb_rpt_is_same = _FALSE;
+		pnb->last_nb_rpt_entries = nb_rpt_entries;
 	}
 
+	if ((from_btm) && (nb_rpt_entries != 0))
+		rtw_wnm_btm_candidate_select(padapter);
+	
+	pnb->nb_rpt_valid = _TRUE;
+	ret = _SUCCESS;
+
 exit:
+	if (from_btm && pcandidate_list)
+		rtw_mfree((u8 *)pcandidate_list, sizeof(struct wnm_btm_cant) * RTW_MAX_NB_RPT_NUM);
+	
 	return ret;
 }
+#endif
 
 unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame)
 {
@@ -6848,13 +6858,13 @@ unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame)
 	struct mlme_ext_info *pmlmeinfo = NULL;
 	struct mlme_priv *pmlmepriv = NULL;
 	struct wlan_network *proam_target = NULL;
-	ft_priv *pftpriv = NULL;
+	struct ft_roam_info *pft_roam = NULL;
 	_irqL  irqL;
 
-	pmlmeext = &padapter->mlmeextpriv;
+	pmlmeext = &(padapter->mlmeextpriv);
 	pmlmeinfo = &(pmlmeext->mlmext_info);
-	pmlmepriv = &padapter->mlmepriv;
-	pftpriv = &pmlmepriv->ftpriv;
+	pmlmepriv = &(padapter->mlmepriv);
+	pft_roam = &(pmlmepriv->ft_roam);
 	pframe = precv_frame->u.hdr.rx_data;
 	frame_len = precv_frame->u.hdr.len;
 	pframe_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
@@ -6865,8 +6875,8 @@ unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame)
 
 	action_code = pframe_body[1];
 	switch (action_code) {
-	case RTW_WLAN_ACTION_FT_RESPONSE:
-		RTW_INFO("FT: %s RTW_WLAN_ACTION_FT_RESPONSE\n", __func__);
+	case RTW_WLAN_ACTION_FT_RSP:
+		RTW_INFO("FT: RTW_WLAN_ACTION_FT_RSP recv.\n");
 		if (!_rtw_memcmp(adapter_mac_addr(padapter), &pframe_body[2], ETH_ALEN)) {
 			RTW_ERR("FT: Unmatched STA MAC Address "MAC_FMT"\n", MAC_ARG(&pframe_body[2]));
 			goto exit;
@@ -6885,24 +6895,24 @@ unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame)
 
 		pie = rtw_get_ie(pframe_body, _MDIE_, &ft_ie_len, frame_len);
 		if (pie) {
-			if (!_rtw_memcmp(&pftpriv->mdid, pie+2, 2)) {
+			if (!_rtw_memcmp(&pft_roam->mdid, pie+2, 2)) {
 				RTW_ERR("FT: Invalid MDID\n");
 				goto exit;
 			}
 		}
 
-		rtw_set_ft_status(padapter, RTW_FT_REQUESTED_STA);
+		rtw_ft_set_status(padapter, RTW_FT_REQUESTED_STA);
 		_cancel_timer_ex(&pmlmeext->ft_link_timer);
 
 		/*Disconnect current AP*/
 		receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress, WLAN_REASON_ACTIVE_ROAM, _FALSE);
 
-		pftpriv->ft_action_len = frame_len;
-		_rtw_memcpy(pftpriv->ft_action, pframe, rtw_min(frame_len, RTW_MAX_FTIE_SZ));
+		pft_roam->ft_action_len = frame_len;
+		_rtw_memcpy(pft_roam->ft_action, pframe, rtw_min(frame_len, RTW_FT_MAX_IE_SZ));
 		ret = _SUCCESS;
 		break;
-	case RTW_WLAN_ACTION_FT_REQUEST:
-	case RTW_WLAN_ACTION_FT_CONFIRM:
+	case RTW_WLAN_ACTION_FT_REQ:
+	case RTW_WLAN_ACTION_FT_CONF:
 	case RTW_WLAN_ACTION_FT_ACK:
 	default:
 		RTW_ERR("FT: Unsupported FT Action!\n");
@@ -6916,10 +6926,241 @@ exit:
 #endif
 }
 
+#ifdef CONFIG_RTW_WNM
+u8 rtw_wmn_btm_rsp_reason_decision(_adapter *padapter, u8* req_mode)
+{
+	struct recv_priv *precvpriv = &padapter->recvpriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 reason = 0;
+
+	if (!rtw_wnm_btm_diff_bss(padapter)) {
+		/* Reject - No suitable BSS transition candidates */
+		reason = 7;
+		goto candidate_remove;
+	}
+
+#ifdef CONFIG_RTW_80211R
+	if (rtw_ft_chk_flags(padapter, RTW_FT_BTM_ROAM)) {
+		/* Accept */
+		reason = 0;
+		goto under_survey;
+	}	
+#endif
+
+	if (((*req_mode) & DISASSOC_IMMINENT) == 0) {
+		/* Reject - Unspecified reject reason */
+		reason = 1;
+		goto candidate_remove;
+	}	
+
+	if (precvpriv->signal_strength_data.avg_val >= pmlmepriv->roam_rssi_threshold) {
+		reason = 1;
+		goto candidate_remove;
+	}
+
+under_survey:	
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
+		RTW_INFO("%s reject due to _FW_UNDER_SURVEY\n", __func__);
+		reason = 1;
+	}
+
+candidate_remove:
+	if (reason !=0)
+		rtw_wnm_reset_btm_candidate(&padapter->mlmepriv.nb_info);
+
+	return reason;
+}
+
+static u32 rtw_wnm_btm_candidates_offset_get(u8* pframe)
+{
+	u8 *pos = pframe;
+	u32 offset = 0;
+
+	if (!pframe)
+		return 0;
+
+	offset += 7;
+	pos += offset;
+
+	/* BSS Termination Duration check */
+	if (wnm_btm_bss_term_inc(pframe)) {
+		offset += 12;
+		pos += offset;	
+	}	
+
+	/* Session Information URL check*/
+	if (wnm_btm_ess_disassoc_im(pframe)) {
+		/*URL length field + URL variable length*/
+		offset = 1 + *(pframe + offset);
+		pos += offset;	
+	}
+
+	offset = (pos - pframe);
+	return offset;
+}
+
+static void rtw_wnm_btm_req_hdr_parsing(u8* pframe, struct btm_req_hdr *phdr)
+{
+	u8 *pos = pframe;
+	u32 offset = 0;
+
+	if (!pframe || !phdr)
+		return;
+
+	_rtw_memset(phdr, 0, sizeof(struct btm_req_hdr));
+	phdr->req_mode  = wnm_btm_req_mode(pframe);
+	phdr->disassoc_timer = wnm_btm_disassoc_timer(pframe);
+	phdr->validity_interval = wnm_btm_valid_interval(pframe);
+	if (wnm_btm_bss_term_inc(pframe)) {
+		_rtw_memcpy(&phdr->term_duration, 
+			wnm_btm_term_duration_offset(pframe), 
+			sizeof(struct btm_term_duration));
+	}
+
+	RTW_DBG("WNM: req_mode(%1x), disassoc_timer(%02x), interval(%x)\n",
+		phdr->req_mode, phdr->disassoc_timer, phdr->validity_interval);
+	if (wnm_btm_bss_term_inc(pframe))
+		RTW_INFO("WNM: tsf(%llx), duration(%2x)\n",
+			phdr->term_duration.tsf, phdr->term_duration.duration);
+}
+
+void rtw_wnm_roam_scan_hdl(void *ctx)
+{
+	_adapter *padapter = (_adapter *)ctx;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	if (rtw_is_scan_deny(padapter)) 
+		RTW_INFO("WNM: roam scan would abort by scan_deny!\n");
+		
+	pmlmepriv->need_to_roam = _TRUE;
+	rtw_drv_scan_by_self(padapter, RTW_AUTO_SCAN_REASON_ROAM);
+}
+
+static void rtw_wnm_roam_scan(_adapter *padapter)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+
+	if (rtw_is_scan_deny(padapter)) {
+		_cancel_timer_ex(&pnb->roam_scan_timer);
+		_set_timer(&pnb->roam_scan_timer, 1000);
+	} else
+		rtw_wnm_roam_scan_hdl((void *)padapter);
+}
+
+void rtw_wnm_process_btm_req(_adapter *padapter, u8* pframe, u32 frame_len)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+	struct btm_req_hdr req_hdr;
+	u8 *ptr, reason;
+	u32 elem_len, offset;
+
+	rtw_wnm_btm_req_hdr_parsing(pframe, &req_hdr);
+	offset = rtw_wnm_btm_candidates_offset_get(pframe);
+	if ((offset == 0) || ((frame_len - offset) <= 15))
+		return;
+
+	ptr = (pframe + offset);
+	elem_len = (frame_len - offset);
+	rtw_wnm_btm_candidates_survey(padapter, ptr, elem_len, _TRUE);
+	reason = rtw_wmn_btm_rsp_reason_decision(padapter, &pframe[3]);
+	rtw_wnm_issue_action(padapter, 
+		RTW_WLAN_ACTION_WNM_BTM_RSP, reason);
+
+	if (reason == 0) 
+		rtw_wnm_roam_scan(padapter);
+}
+
+void rtw_wnm_reset_btm_candidate(struct roam_nb_info *pnb)
+{
+	pnb->preference_en = _FALSE;
+	_rtw_memset(pnb->roam_target_addr, 0, ETH_ALEN);
+}
+
+void rtw_wnm_reset_btm_state(_adapter *padapter)
+{
+	struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
+
+	pnb->last_nb_rpt_entries = 0;
+	pnb->nb_rpt_is_same = _TRUE;
+	pnb->nb_rpt_valid = _FALSE;
+	pnb->nb_rpt_ch_list_num = 0;
+	rtw_wnm_reset_btm_candidate(pnb);
+	_rtw_memset(&pnb->nb_rpt, 0, sizeof(pnb->nb_rpt));
+	_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
+}
+
+void rtw_wnm_issue_action(_adapter *padapter, u8 action, u8 reason)
+{
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct xmit_frame *pmgntframe;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct pkt_attrib *pattrib;
+	u8 category, dialog_token, termination_delay, *pframe;
+	u16 *fctrl;
+
+	if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
+		return ;
+	
+	pattrib = &(pmgntframe->attrib);
+	update_mgntframe_attrib(padapter, pattrib);
+	_rtw_memset(pmgntframe->buf_addr, 0, (WLANHDR_OFFSET + TXDESC_OFFSET));
+
+	pframe = (u8 *)(pmgntframe->buf_addr + TXDESC_OFFSET);
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &(pwlanhdr->frame_ctl);
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+	pmlmeext->mgnt_seq++;
+	set_frame_sub_type(pframe, WIFI_ACTION);
+
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	category = RTW_WLAN_CATEGORY_WNM;
+	pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
+	pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
+
+	switch (action) {
+		case RTW_WLAN_ACTION_WNM_BTM_QUERY:
+			pframe = rtw_set_fixed_ie(pframe, 1, &(dialog_token), &(pattrib->pktlen));
+			pframe = rtw_set_fixed_ie(pframe, 1, &(reason), &(pattrib->pktlen));
+			RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_QUERY sent.\n");
+			break;
+		case RTW_WLAN_ACTION_WNM_BTM_RSP:
+			termination_delay = 0;
+			pframe = rtw_set_fixed_ie(pframe, 1, &(dialog_token), &(pattrib->pktlen));
+			pframe = rtw_set_fixed_ie(pframe, 1, &(reason), &(pattrib->pktlen));
+			pframe = rtw_set_fixed_ie(pframe, 1, &(termination_delay), &(pattrib->pktlen));
+			if (!is_zero_mac_addr(pmlmepriv->nb_info.roam_target_addr)) {
+				pframe = rtw_set_fixed_ie(pframe, 6, 
+					pmlmepriv->nb_info.roam_target_addr, &(pattrib->pktlen));
+			}
+			RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_RSP sent. reason = %d\n", reason);			
+			break;		
+		default:
+			goto exit;
+	}	
+	
+	pattrib->last_txcmdsz = pattrib->pktlen;
+	dump_mgntframe(padapter, pmgntframe);
+
+exit:	
+	return;
+}
+#endif
+
 unsigned int OnAction_ht(_adapter *padapter, union recv_frame *precv_frame)
 {
 	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint frame_len = precv_frame->u.hdr.len;
 	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
 	u8 category, action;
 
@@ -7018,9 +7259,7 @@ unsigned int OnAction_wmm(_adapter *padapter, union recv_frame *precv_frame)
 unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame)
 {
 #ifdef CONFIG_80211AC_VHT
-	struct rx_pkt_attrib *prxattrib = &precv_frame->u.hdr.attrib;
 	u8 *pframe = precv_frame->u.hdr.rx_data;
-	uint frame_len = precv_frame->u.hdr.len;
 	struct rtw_ieee80211_hdr_3addr *whdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
 	u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
 	u8 category, action;
@@ -7287,6 +7526,11 @@ void update_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
 	u8	wireless_mode;
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct xmit_priv		*pxmitpriv = &padapter->xmitpriv;
+
+#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif /* CONFIG_P2P_PS_NOA_USE_MACID_SLEEP */
+
 	/* _rtw_memset((u8 *)(pattrib), 0, sizeof(struct pkt_attrib)); */
 
 	pattrib->hdrlen = 24;
@@ -7299,6 +7543,33 @@ void update_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
 	update_mcc_mgntframe_attrib(padapter, pattrib);
 #endif
 
+
+#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_buddy_check_fwstate(padapter, WIFI_ASOC_STATE))
+#endif /* CONFIG_CONCURRENT_MODE */
+		if (MLME_IS_GC(padapter)) {
+			if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
+				struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+				struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+				WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
+				struct sta_priv *pstapriv = &padapter->stapriv;
+				struct sta_info *psta;
+
+				psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
+				if (psta) {
+					/* use macid sleep during NoA, mgmt frame use ac queue & ap macid */
+					pattrib->mac_id = psta->cmn.mac_id;
+					pattrib->qsel = QSLT_VO;
+				} else {
+					if (pwdinfo->p2p_ps_state != P2P_PS_DISABLE)
+						RTW_ERR("%s , psta was NULL\n", __func__);
+				}
+			}
+		}
+#endif /* CONFIG_P2P_PS_NOA_USE_MACID_SLEEP */
+
+
 	pattrib->pktlen = 0;
 
 	if (IS_CCK_RATE(pmlmeext->tx_rate))
@@ -7465,25 +7736,6 @@ int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
 	return len_diff;
 }
 
-#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
-u32 rtw_build_vendor_ie(_adapter *padapter , unsigned char *pframe , u8 mgmt_frame_tyte)
-{
-	int vendor_ie_num = 0;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	u32 len = 0;
-
-	for (vendor_ie_num = 0 ; vendor_ie_num < WLAN_MAX_VENDOR_IE_NUM ; vendor_ie_num++) {
-		if (pmlmepriv->vendor_ielen[vendor_ie_num] > 0 && pmlmepriv->vendor_ie_mask[vendor_ie_num] & mgmt_frame_tyte) {
-			_rtw_memcpy(pframe , pmlmepriv->vendor_ie[vendor_ie_num] , pmlmepriv->vendor_ielen[vendor_ie_num]);
-			pframe +=  pmlmepriv->vendor_ielen[vendor_ie_num];
-			len += pmlmepriv->vendor_ielen[vendor_ie_num];
-		}
-	}
-
-	return len;
-}
-#endif
-
 void issue_beacon(_adapter *padapter, int timeout_ms)
 {
 	struct xmit_frame	*pmgntframe;
@@ -7532,6 +7784,10 @@ void issue_beacon(_adapter *padapter, int timeout_ms)
 	if (padapter->hw_port == HW_PORT1)
 		pattrib->mbssid = 1;
 #endif
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	if (padapter->vap_id != CONFIG_LIMITED_AP_NUM)
+		pattrib->mbssid = padapter->vap_id;
+#endif
 
 	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
 
@@ -7677,6 +7933,12 @@ void issue_beacon(_adapter *padapter, int timeout_ms)
 				_clr_fwstate_(pmlmepriv, WIFI_UNDER_WPS);
 		}
 
+#ifdef CONFIG_RTW_80211K
+		pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_,
+			sizeof(padapter->rmpriv.rm_en_cap_def),
+			padapter->rmpriv.rm_en_cap_def, &pattrib->pktlen);
+#endif
+
 #ifdef CONFIG_P2P
 		if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
 			u32 len;
@@ -7709,8 +7971,13 @@ void issue_beacon(_adapter *padapter, int timeout_ms)
 		rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
 #endif
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
-		pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_BEACON_VENDOR_IE_BIT);
+		pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_BEACON_VENDOR_IE_BIT);
 #endif
+
+#ifdef CONFIG_RTL8812A 
+		pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
+#endif/*CONFIG_RTL8812A*/
+
 		goto _issue_bcn;
 
 	}
@@ -7774,8 +8041,10 @@ _issue_bcn:
 	_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
 #endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 
-	if ((pattrib->pktlen + TXDESC_SIZE) > 512) {
-		RTW_INFO("beacon frame too large\n");
+	if ((pattrib->pktlen + TXDESC_SIZE) > MAX_BEACON_LEN) {
+		RTW_ERR("beacon frame too large ,len(%d,%d)\n",
+			(pattrib->pktlen + TXDESC_SIZE), MAX_BEACON_LEN);
+		rtw_warn_on(1);
 		return;
 	}
 
@@ -7809,9 +8078,6 @@ void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probe
 	unsigned int	rate_len;
 #ifdef CONFIG_P2P
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-#ifdef CONFIG_WFD
-	u32					wfdielen = 0;
-#endif
 #endif /* CONFIG_P2P */
 
 	/* RTW_INFO("%s\n", __FUNCTION__); */
@@ -7933,7 +8199,7 @@ void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probe
 		rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
 #endif
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
-		pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_PROBERESP_VENDOR_IE_BIT);
+		pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_PROBERESP_VENDOR_IE_BIT);
 #endif
 	} else
 #endif
@@ -7991,6 +8257,12 @@ void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probe
 
 	}
 
+#ifdef CONFIG_RTW_80211K
+	pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_,
+		sizeof(padapter->rmpriv.rm_en_cap_def),
+		padapter->rmpriv.rm_en_cap_def, &pattrib->pktlen);
+#endif
+
 #ifdef CONFIG_P2P
 	if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)
 	    /* IOT issue, When wifi_spec is not set, send probe_resp with P2P IE even if probe_req has no P2P IE */
@@ -8053,6 +8325,9 @@ void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probe
 	}
 #endif /* CONFIG_AUTO_AP_MODE */
 
+#ifdef CONFIG_RTL8812A 
+	pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen);
+#endif/*CONFIG_RTL8812A*/
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
@@ -8063,7 +8338,7 @@ void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probe
 
 }
 
-int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch, bool append_wps, int wait_ack)
+int _issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps, int wait_ack)
 {
 	int ret = _FAIL;
 	struct xmit_frame		*pmgntframe;
@@ -8076,9 +8351,11 @@ int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch,
 	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;
 	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+#endif
 
 	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
@@ -8097,6 +8374,13 @@ int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch,
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+	if ((pwdev_priv->pno_mac_addr[0] != 0xFF)
+	    && (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == _TRUE)
+	    && (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE))
+		mac = pwdev_priv->pno_mac_addr;
+	else
+#endif
 	mac = adapter_mac_addr(padapter);
 
 	fctrl = &(pwlanhdr->frame_ctl);
@@ -8114,14 +8398,30 @@ int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch,
 
 	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
 
-	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
-	pmlmeext->mgnt_seq++;
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+	if ((pwdev_priv->pno_mac_addr[0] != 0xFF)
+	    && (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == _TRUE)
+	    && (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE)) {
+#ifdef CONFIG_RTW_DEBUG
+		RTW_DBG("%s pno_scan_seq_num: %d\n", __func__,
+			 pwdev_priv->pno_scan_seq_num);
+#endif
+		SetSeqNum(pwlanhdr, pwdev_priv->pno_scan_seq_num);
+		pattrib->seqnum = pwdev_priv->pno_scan_seq_num;
+		pattrib->qos_en = 1;
+		pwdev_priv->pno_scan_seq_num++;
+	} else
+#endif
+	{
+		SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+		pmlmeext->mgnt_seq++;
+	}
 	set_frame_sub_type(pframe, WIFI_PROBEREQ);
 
 	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
 	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
 
-	if (pssid)
+	if (pssid && !MLME_IS_MESH(padapter))
 		pframe = rtw_set_ie(pframe, _SSID_IE_, pssid->SsidLength, pssid->Ssid, &(pattrib->pktlen));
 	else
 		pframe = rtw_set_ie(pframe, _SSID_IE_, 0, NULL, &(pattrib->pktlen));
@@ -8137,6 +8437,15 @@ int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch,
 	if (ch)
 		pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, &ch, &pattrib->pktlen);
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (pssid)
+			pframe = rtw_set_ie_mesh_id(pframe, &pattrib->pktlen, pssid->Ssid, pssid->SsidLength);
+		else
+			pframe = rtw_set_ie_mesh_id(pframe, &pattrib->pktlen, NULL, 0);
+	}
+#endif
+
 	if (append_wps) {
 		/* add wps_ie for wps2.0 */
 		if (pmlmepriv->wps_probe_req_ie_len > 0 && pmlmepriv->wps_probe_req_ie) {
@@ -8147,9 +8456,14 @@ int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch,
 		}
 	}
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
-	pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_PROBEREQ_VENDOR_IE_BIT);
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_PROBEREQ_VENDOR_IE_BIT);
 #endif
 
+#ifdef CONFIG_RTL8812A 
+	pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
+#endif/*CONFIG_RTL8812A*/
+
+
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
 
@@ -8164,7 +8478,7 @@ exit:
 	return ret;
 }
 
-inline void issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da)
+inline void issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da)
 {
 	_issue_probereq(padapter, pssid, da, 0, 1, _FALSE);
 }
@@ -8174,7 +8488,7 @@ inline void issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da)
  * wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
  * try_cnt means the maximal TX count to try
  */
-int issue_probereq_ex(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch, bool append_wps,
+int issue_probereq_ex(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps,
 		      int try_cnt, int wait_ms)
 {
 	int ret = _FAIL;
@@ -8218,6 +8532,118 @@ exit:
 	return ret;
 }
 
+//WIFIDBG
+void issue_auth_for_monitor(_adapter *padapter, u8 *da, unsigned short status)
+{
+  struct xmit_frame 		  *pmgntframe;
+  struct pkt_attrib 		  *pattrib;
+  unsigned char 				  *pframe;
+  struct rtw_ieee80211_hdr	  *pwlanhdr;
+  unsigned short			  *fctrl;
+  unsigned int					  val32;
+  unsigned short			  val16;
+  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);
+
+
+  if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
+	  return;
+
+  pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+  if (pmgntframe == NULL)
+	  return;
+
+  /* update attribute */
+  pattrib = &pmgntframe->attrib;
+  update_mgntframe_attrib(padapter, pattrib);
+
+  _rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+
+  pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+  pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+  fctrl = &(pwlanhdr->frame_ctl);
+  *(fctrl) = 0;
+
+  SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
+  pmlmeext->mgnt_seq++;
+  set_frame_sub_type(pframe, WIFI_AUTH);
+
+  pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
+  pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+
+{
+	  _rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+	  _rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	  _rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
+
+	  pmlmeinfo->auth_seq = 1;
+
+	  {
+		  /* setting auth algo number */
+		  val16 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared) ? 1 : 0;  /* 0:OPEN System, 1:Shared key */
+		  if (val16) {
+			  val16 = cpu_to_le16(val16);
+			  use_shared_key = 1;
+		  }
+	  }
+
+	  /* RTW_INFO("%s auth_algo= %s auth_seq=%d\n",__FUNCTION__,(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)) {
+		  /* RTW_INFO("==> iv(%d),key_index(%d)\n",pmlmeinfo->iv,pmlmeinfo->key_index); */
+		  val32 = ((pmlmeinfo->iv++) | (pmlmeinfo->key_index << 30));
+		  val32 = cpu_to_le32(val32);
+		  pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *)&val32, &(pattrib->pktlen));
+
+		  pattrib->iv_len = 4;
+	  }
+
+	  pframe = rtw_set_fixed_ie(pframe, _AUTH_ALGM_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
+
+	  /* setting auth seq number */
+	  val16 = pmlmeinfo->auth_seq;
+	  val16 = cpu_to_le16(val16);
+	  pframe = rtw_set_fixed_ie(pframe, _AUTH_SEQ_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
+
+
+	  /* setting status code... */
+	  val16 = status;
+	  val16 = cpu_to_le16(val16);
+	  pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
+
+
+	  /* 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_ie(pframe, _CHLGETXT_IE_, 128, pmlmeinfo->chg_txt, &(pattrib->pktlen));
+
+		  SetPrivacy(fctrl);
+
+		  pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+		  pattrib->encrypt = _WEP40_;
+
+		  pattrib->icv_len = 4;
+
+		  pattrib->pktlen += pattrib->icv_len;
+
+	  }
+
+  }
+
+  pattrib->last_txcmdsz = pattrib->pktlen;
+
+  rtw_wep_encrypt(padapter, (u8 *)pmgntframe);
+  RTW_INFO("%s\n", __FUNCTION__);
+  dump_mgntframe(padapter, pmgntframe);
+
+  return;
+}
+
 /* if psta == NULL, indiate we are station(client) now... */
 void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status)
 {
@@ -8232,14 +8658,6 @@ void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-#ifdef CONFIG_RTW_80211R
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	ft_priv			*pftpriv = &pmlmepriv->ftpriv;
-	u8	is_ft_roaming = _FALSE;
-	u8	is_ft_roaming_with_rsn_ie = _TRUE;
-	u8 *pie = NULL;
-	u32 ft_ie_len = 0;
-#endif
 
 	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		return;
@@ -8309,11 +8727,9 @@ void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status
 		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
 
 #ifdef CONFIG_RTW_80211R
-		/*For Fast BSS Transition */
-		if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
-			is_ft_roaming = _TRUE;
-			val16 = 2;	/* 2: 802.11R FTAA */
-			val16 = cpu_to_le16(val16);
+		if (rtw_ft_roam(padapter)) {
+			/* 2: 802.11R FTAA */
+			val16 = cpu_to_le16(2);
 		} else
 #endif
 		{
@@ -8351,21 +8767,7 @@ void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status
 		pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
 
 #ifdef CONFIG_RTW_80211R
-		if (is_ft_roaming == _TRUE) {
-			pie = rtw_get_ie(pftpriv->updated_ft_ies, EID_WPA2, &ft_ie_len, pftpriv->updated_ft_ies_len);
-			if (pie)
-				pframe = rtw_set_ie(pframe, EID_WPA2, ft_ie_len, pie+2, &(pattrib->pktlen));
-			else
-				is_ft_roaming_with_rsn_ie = _FALSE;
-
-			pie = rtw_get_ie(pftpriv->updated_ft_ies, _MDIE_, &ft_ie_len, pftpriv->updated_ft_ies_len);
-			if (pie)
-				pframe = rtw_set_ie(pframe, _MDIE_, ft_ie_len , pie+2, &(pattrib->pktlen));
-
-			pie = rtw_get_ie(pftpriv->updated_ft_ies, _FTIE_, &ft_ie_len, pftpriv->updated_ft_ies_len);
-			if (pie && is_ft_roaming_with_rsn_ie)
-				pframe = rtw_set_ie(pframe, _FTIE_, ft_ie_len , pie+2, &(pattrib->pktlen));
-		}
+		rtw_ft_build_auth_req_ies(padapter, pattrib, &pframe);
 #endif
 
 		/* then checking to see if sending challenging text... */
@@ -8607,8 +9009,14 @@ void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *p
 
 #endif /* CONFIG_P2P */
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
-	pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_ASSOCRESP_VENDOR_IE_BIT);
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_ASSOCRESP_VENDOR_IE_BIT);
 #endif
+
+#ifdef CONFIG_RTL8812A 
+	pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
+#endif/*CONFIG_RTL8812A*/
+
+
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
 	dump_mgntframe(padapter, pmgntframe);
@@ -8621,14 +9029,13 @@ void _issue_assocreq(_adapter *padapter, u8 is_reassoc)
 	int ret = _FAIL;
 	struct xmit_frame				*pmgntframe;
 	struct pkt_attrib				*pattrib;
-	unsigned char					*pframe, *p;
+	unsigned char					*pframe;
 	struct rtw_ieee80211_hdr			*pwlanhdr;
 	unsigned short				*fctrl;
 	unsigned short				val16;
-	unsigned int					i, j, ie_len, index = 0;
-	unsigned char					rf_type, bssrate[NumRates], sta_bssrate[NumRates];
+	unsigned int					i, j, index = 0;
+	unsigned char					bssrate[NumRates], sta_bssrate[NumRates];
 	PNDIS_802_11_VARIABLE_IEs	pIE;
-	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);
@@ -8652,11 +9059,6 @@ void _issue_assocreq(_adapter *padapter, u8 is_reassoc)
 	u8 pow_cap_ele[2] = { 0x00 };
 	u8 sup_ch[30 * 2] = {0x00 }, sup_ch_idx = 0, idx_5g = 2;	/* For supported channel */
 #endif /* CONFIG_DFS */
-#ifdef CONFIG_RTW_80211R
-	u8 *pie = NULL;
-	u32 ft_ie_len = 0;
-	ft_priv *pftpriv = &pmlmepriv->ftpriv;
-#endif
 
 	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
@@ -8859,10 +9261,8 @@ void _issue_assocreq(_adapter *padapter, u8 is_reassoc)
 
 		case EID_WPA2:
 #ifdef CONFIG_RTW_80211R
-			if ((is_reassoc == _TRUE) && (rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
-				pie = rtw_get_ie(pftpriv->updated_ft_ies, EID_WPA2, &ft_ie_len, pftpriv->updated_ft_ies_len);
-				if (pie)
-					pframe = rtw_set_ie(pframe, EID_WPA2, ft_ie_len, pie+2, &(pattrib->pktlen));
+			if ((is_reassoc) && (rtw_ft_roam(padapter))) {
+				rtw_ft_update_rsnie(padapter, _TRUE, pattrib, &pframe);
 			} else
 #endif
 				pframe = rtw_set_ie(pframe, EID_WPA2, pIE->Length, pIE->data, &(pattrib->pktlen));
@@ -9052,41 +9452,26 @@ void _issue_assocreq(_adapter *padapter, u8 is_reassoc)
 		}
 	}
 
-#endif /* CONFIG_P2P */
-
 #ifdef CONFIG_WFD
 	wfdielen = rtw_append_assoc_req_wfd_ie(padapter, pframe);
 	pframe += wfdielen;
 	pattrib->pktlen += wfdielen;
 #endif
+#endif /* CONFIG_P2P */
+
 #ifdef CONFIG_RTW_REPEATER_SON
 	rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
 #endif
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
-	pattrib->pktlen += rtw_build_vendor_ie(padapter , pframe , WIFI_ASSOCREQ_VENDOR_IE_BIT);
+	pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_ASSOCREQ_VENDOR_IE_BIT);
 #endif
-#ifdef CONFIG_RTW_80211R
-	if (rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
-		u8 mdieval[3] = {0};
-
-		_rtw_memcpy(mdieval, &(pftpriv->mdid), 2);
-		mdieval[2] = pftpriv->ft_cap;
-		pframe = rtw_set_ie(pframe, _MDIE_, 3, mdieval, &(pattrib->pktlen));
-	}
-
-	if (is_reassoc == _TRUE) {
-		if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
-			u8 is_ft_roaming_with_rsn_ie = _TRUE;
 
-			pie = rtw_get_ie(pftpriv->updated_ft_ies, EID_WPA2, &ft_ie_len, pftpriv->updated_ft_ies_len);
-			if (!pie)
-				is_ft_roaming_with_rsn_ie = _FALSE;
+#ifdef CONFIG_RTL8812A 
+	pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
+#endif/*CONFIG_RTL8812A*/
 
-			pie = rtw_get_ie(pftpriv->updated_ft_ies, _FTIE_, &ft_ie_len, pftpriv->updated_ft_ies_len);
-			if (pie && is_ft_roaming_with_rsn_ie)
-				pframe = rtw_set_ie(pframe, _FTIE_, ft_ie_len , pie+2, &(pattrib->pktlen));
-		}
-	}
+#ifdef CONFIG_RTW_80211R
+	rtw_ft_build_assoc_req_ies(padapter, is_reassoc, pattrib, &pframe);
 #endif
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
@@ -9125,6 +9510,7 @@ static int _issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int p
 	struct xmit_priv	*pxmitpriv;
 	struct mlme_ext_priv	*pmlmeext;
 	struct mlme_ext_info	*pmlmeinfo;
+	u8 a4_shift;
 
 	/* RTW_INFO("%s:%d\n", __FUNCTION__, power_mode); */
 
@@ -9159,20 +9545,34 @@ static int _issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int p
 		SetFrDs(fctrl);
 	else if (MLME_IS_STA(padapter))
 		SetToDs(fctrl);
+	else if (MLME_IS_MESH(padapter)) {
+		SetToDs(fctrl);
+		SetFrDs(fctrl);
+	}
 
 	if (power_mode)
 		SetPwrMgt(fctrl);
 
-	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+	if (get_tofr_ds(fctrl) == 3) {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr4, adapter_mac_addr(padapter), ETH_ALEN);
+		a4_shift = ETH_ALEN;
+		pattrib->hdrlen += ETH_ALEN;
+	} else {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		a4_shift = 0;
+	}
 
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
 	set_frame_sub_type(pframe, WIFI_DATA_NULL);
 
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr) + a4_shift;
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr) + a4_shift;
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
@@ -9202,17 +9602,6 @@ int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mod
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-#ifdef CONFIG_MCC_MODE
-	if (MCC_EN(padapter)) {
-		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
-			if (da == NULL) {
-				RTW_INFO("Warning: Do not tx null data to AP under MCC mode\n");
-				rtw_warn_on(1);
-			}
-		}
-	}
-#endif
-
 	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
 
@@ -9255,7 +9644,7 @@ exit:
 }
 
 /* when wait_ack is ture, this function shoule be called at process context */
-static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int wait_ack)
+static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int wait_ack)
 {
 	int ret = _FAIL;
 	struct xmit_frame			*pmgntframe;
@@ -9266,11 +9655,12 @@ static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, i
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8 a4_shift;
 
 	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		goto exit;
 
-	RTW_INFO("%s\n", __FUNCTION__);
+	/* RTW_INFO("%s\n", __FUNCTION__); */
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
 	if (pmgntframe == NULL)
@@ -9298,10 +9688,31 @@ static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, i
 		SetFrDs(fctrl);
 	else if (MLME_IS_STA(padapter))
 		SetToDs(fctrl);
+	else if (MLME_IS_MESH(padapter)) {
+		SetToDs(fctrl);
+		SetFrDs(fctrl);
+	}
+
+	if (ps)
+		SetPwrMgt(fctrl);
 
 	if (pattrib->mdata)
 		SetMData(fctrl);
 
+	if (get_tofr_ds(fctrl) == 3) {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr4, adapter_mac_addr(padapter), ETH_ALEN);
+		a4_shift = ETH_ALEN;
+		pattrib->hdrlen += ETH_ALEN;
+	} else {
+		_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+		a4_shift = 0;
+	}
+
 	qc = (unsigned short *)(pframe + pattrib->hdrlen - 2);
 
 	SetPriority(qc, tid);
@@ -9310,16 +9721,12 @@ static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, i
 
 	SetAckpolicy(qc, pattrib->ack_policy);
 
-	_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
 	SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
 	pmlmeext->mgnt_seq++;
 	set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
 
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
+	pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos) + a4_shift;
+	pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos) + a4_shift;
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
@@ -9341,7 +9748,7 @@ exit:
  * try_cnt means the maximal TX count to try
  * da == NULL for station mode
  */
-int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int try_cnt, int wait_ms)
+int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int try_cnt, int wait_ms)
 {
 	int ret = _FAIL;
 	int i = 0;
@@ -9357,7 +9764,7 @@ int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int try_c
 		da = get_my_bssid(&(pmlmeinfo->network));
 
 	do {
-		ret = _issue_qos_nulldata(padapter, da, tid, wait_ms > 0 ? _TRUE : _FALSE);
+		ret = _issue_qos_nulldata(padapter, da, tid, ps, wait_ms > 0 ? _TRUE : _FALSE);
 
 		i++;
 
@@ -9527,17 +9934,13 @@ exit:
 
 void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset)
 {
-	_irqL	irqL;
-	_list		*plist, *phead;
-	struct xmit_frame			*pmgntframe;
-	struct pkt_attrib			*pattrib;
+	struct xmit_frame *pmgntframe;
+	struct pkt_attrib *pattrib;
 	unsigned char				*pframe;
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	unsigned short			*fctrl;
 	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);
 
 	if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
 		return;
@@ -9656,7 +10059,7 @@ void issue_action_SA_Query(_adapter *padapter, unsigned char *raddr, unsigned ch
 		pmlmeext->sa_query_seq++;
 		/* send sa query request to AP, AP should reply sa query response in 1 second */
 		if (pattrib->key_type == IEEE80211W_RIGHT_KEY) {
-			psta = rtw_get_stainfo(pstapriv, raddr);
+			psta = rtw_get_stainfo(pstapriv, pwlanhdr->addr1);
 			if (psta != NULL) {
 				/* RTW_INFO("%s, %d, set dot11w_expire_timer\n", __func__, __LINE__); */
 				_set_timer(&psta->dot11w_expire_timer, 1000);
@@ -10410,19 +10813,18 @@ unsigned int send_delba(_adapter *padapter, u8 initiator, u8 *addr)
 
 unsigned int send_beacon(_adapter *padapter)
 {
-	u8	bxmitok = _FALSE;
-	int	issue = 0;
-	int poll = 0;
-#if defined(CONFIG_PCI_HCI) && defined(RTL8814AE_SW_BCN)
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-#endif
+#if defined(CONFIG_PCI_HCI) && !defined(CONFIG_PCI_BCN_POLLING)
+	#ifdef CONFIG_FW_HANDLE_TXBCN
+	u8 vap_id = padapter->vap_id;
+
+	/* bypass TX BCN because vap_id is invalid*/
+	if (vap_id == CONFIG_LIMITED_AP_NUM)
+		return _SUCCESS;
+	#endif
 
-#ifdef CONFIG_PCI_HCI
 	/* bypass TX BCN queue because op ch is switching/waiting */
 	if (check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
-		#ifdef CONFIG_DFS_MASTER
 		|| IS_CH_WAITING(adapter_to_rfctl(padapter))
-		#endif
 	)
 		return _SUCCESS;
 
@@ -10432,50 +10834,84 @@ unsigned int send_beacon(_adapter *padapter)
 
 	/* 8192EE Port select for Beacon DL */
 	rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
+	#ifdef CONFIG_FW_HANDLE_TXBCN
+	rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
+	#endif
 
 	issue_beacon(padapter, 0);
 
-#ifdef RTL8814AE_SW_BCN
-	if (pHalData->bCorrectBCN != 0)
+	#ifdef CONFIG_FW_HANDLE_TXBCN
+	vap_id = 0xFF;
+	rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
+	#endif
+
+	#ifdef RTL8814AE_SW_BCN
+	if (GET_HAL_DATA(padapter)->bCorrectBCN != 0)
 		RTW_INFO("%s, line%d, Warnning, pHalData->bCorrectBCN != 0\n", __func__, __LINE__);
-	pHalData->bCorrectBCN = 1;
-#endif
+	GET_HAL_DATA(padapter)->bCorrectBCN = 1;
+	#endif
 
 	return _SUCCESS;
 #endif
 
-#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+/* CONFIG_PCI_BCN_POLLING is for pci interface beacon polling mode */
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)|| defined(CONFIG_PCI_BCN_POLLING) 
+	u8 bxmitok = _FALSE;
+	int issue = 0;
+	int poll = 0;
 	systime start = rtw_get_current_time();
+	#ifdef CONFIG_FW_HANDLE_TXBCN
+	u8 vap_id = padapter->vap_id;
+
+	/* bypass TX BCN because vap_id is invalid*/
+	if (vap_id == CONFIG_LIMITED_AP_NUM)
+		return _SUCCESS;
+	#endif
 
 	/* bypass TX BCN queue because op ch is switching/waiting */
 	if (check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
-		#ifdef CONFIG_DFS_MASTER
 		|| IS_CH_WAITING(adapter_to_rfctl(padapter))
-		#endif
 	)
 		return _SUCCESS;
 
-#if defined(CONFIG_USB_HCI)
-#if defined(CONFIG_RTL8812A)
+	#if defined(CONFIG_USB_HCI)
+	#if defined(CONFIG_RTL8812A)
 	if (IS_FULL_SPEED_USB(padapter)) {
 		issue_beacon(padapter, 300);
 		bxmitok = _TRUE;
 	} else
-#endif
-#endif
+	#endif
+	#endif
 	{
 		rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
 		rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
+		#ifdef CONFIG_FW_HANDLE_TXBCN
+		rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
+		#endif
 		do {
+			#if defined(CONFIG_PCI_BCN_POLLING) 
+			issue_beacon(padapter, 0);
+			#else
 			issue_beacon(padapter, 100);
+			#endif
 			issue++;
 			do {
+				#if defined(CONFIG_PCI_BCN_POLLING) 
+				rtw_msleep_os(1);
+				#else
 				rtw_yield_os();
+				#endif
 				rtw_hal_get_hwreg(padapter, HW_VAR_BCN_VALID, (u8 *)(&bxmitok));
 				poll++;
 			} while ((poll % 10) != 0 && _FALSE == bxmitok && !RTW_CANNOT_RUN(padapter));
-
+			#if defined(CONFIG_PCI_BCN_POLLING) 
+			rtw_hal_unmap_beacon_icf(padapter);
+			#endif
 		} while (bxmitok == _FALSE && (issue < 100) && !RTW_CANNOT_RUN(padapter));
+		#ifdef CONFIG_FW_HANDLE_TXBCN
+		vap_id = 0xFF;
+		rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
+		#endif
 	}
 	if (RTW_CANNOT_RUN(padapter))
 		return _FAIL;
@@ -10495,12 +10931,13 @@ unsigned int send_beacon(_adapter *padapter)
 		else if (0)
 			RTW_INFO("%s success, issue:%d, poll:%d, %u ms\n", __FUNCTION__, issue, poll, rtw_get_passing_time_ms(start));
 
+		#ifdef CONFIG_FW_CORRECT_BCN
 		rtw_hal_fw_correct_bcn(padapter);
-
+		#endif
 		return _SUCCESS;
 	}
 
-#endif
+#endif /*defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)*/
 
 }
 
@@ -10531,7 +10968,7 @@ BOOLEAN IsLegal5GChannel(
 u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid)
 {
 	int	i;
-	u32	len;
+	sint len;
 	u8	*p;
 	u8	rf_path;
 	u16	val16, subtype;
@@ -10540,7 +10977,6 @@ u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSI
 	u8 ie_offset;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
-	struct mlme_priv 	*pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
@@ -10625,6 +11061,11 @@ u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSI
 			RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
 			return _FAIL;
 		}
+		if (rtw_validate_value(_SUPPORTEDRATES_IE_, p+2, len) == _FALSE) {
+			rtw_absorb_ssid_ifneed(padapter, bssid, pframe);
+			RTW_DBG_DUMP("Invalidated Support Rate IE --", p, len+2);
+			return _FAIL;
+		}
 		_rtw_memcpy(bssid->SupportedRates, (p + 2), len);
 		i = len;
 	}
@@ -10635,6 +11076,11 @@ u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSI
 			RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
 			return _FAIL;
 		}
+		if (rtw_validate_value(_EXT_SUPPORTEDRATES_IE_, p+2, len) == _FALSE) {
+			rtw_absorb_ssid_ifneed(padapter, bssid, pframe);
+			RTW_DBG_DUMP("Invalidated EXT Support Rate IE --", p, len+2);
+			return _FAIL;
+		}
 		_rtw_memcpy(bssid->SupportedRates + i, (p + 2), len);
 	}
 
@@ -10703,12 +11149,49 @@ u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSI
 
 	val16 = rtw_get_capability((WLAN_BSSID_EX *)bssid);
 
-	if (val16 & BIT(0)) {
+	if ((val16 & 0x03) == cap_ESS) {
 		bssid->InfrastructureMode = Ndis802_11Infrastructure;
 		_rtw_memcpy(bssid->MacAddress, get_addr2_ptr(pframe), ETH_ALEN);
-	} else {
+	} else if ((val16 & 0x03) == cap_IBSS){
 		bssid->InfrastructureMode = Ndis802_11IBSS;
 		_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
+	} else if ((val16 & 0x03) == 0x00){
+		u8 *mesh_id_ie, *mesh_conf_ie;
+		sint mesh_id_ie_len, mesh_conf_ie_len;
+
+		mesh_id_ie = rtw_get_ie(bssid->IEs + ie_offset, WLAN_EID_MESH_ID, &mesh_id_ie_len, bssid->IELength - ie_offset);
+		mesh_conf_ie = rtw_get_ie(bssid->IEs + ie_offset, WLAN_EID_MESH_CONFIG, &mesh_conf_ie_len, bssid->IELength - ie_offset);
+		if (mesh_id_ie || mesh_conf_ie) {
+			if (!mesh_id_ie) {
+				RTW_INFO("cannot find Mesh ID for survey event\n");
+				return _FAIL;
+			}
+			if (mesh_id_ie_len) {
+				if (mesh_id_ie_len > NDIS_802_11_LENGTH_SSID) {
+					RTW_INFO("Mesh ID too long (%d) for survey event\n", mesh_id_ie_len);
+					return _FAIL;
+				}
+				_rtw_memcpy(bssid->mesh_id.Ssid, (mesh_id_ie + 2), mesh_id_ie_len);
+				bssid->mesh_id.SsidLength = mesh_id_ie_len;
+			} else
+				bssid->mesh_id.SsidLength = 0;
+
+			if (!mesh_conf_ie) {
+				RTW_INFO("cannot find Mesh config for survey event\n");
+				return _FAIL;
+			}
+			if (mesh_conf_ie_len != 7) {
+				RTW_INFO("invalid Mesh conf IE len (%d) for survey event\n", mesh_conf_ie_len);
+				return _FAIL;
+			}
+
+			bssid->InfrastructureMode = Ndis802_11_mesh;
+			_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
+		} else {
+			/* default cases */
+			bssid->InfrastructureMode = Ndis802_11IBSS;
+			_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
+		}
 	}
 
 	if (val16 & BIT(4))
@@ -10808,15 +11291,15 @@ void start_create_ibss(_adapter *padapter)
 		/* issue beacon */
 		if (send_beacon(padapter) == _FAIL) {
 
-			report_join_res(padapter, -1);
+			report_join_res(padapter, -1, WLAN_STATUS_UNSPECIFIED_FAILURE);
 			pmlmeinfo->state = WIFI_FW_NULL_STATE;
 		} else {
 			rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, padapter->registrypriv.dev_network.MacAddress);
+			rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
 			join_type = 0;
 			rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
-			rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
 
-			report_join_res(padapter, 1);
+			report_join_res(padapter, 1, WLAN_STATUS_SUCCESS);
 			pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
 			rtw_indicate_connect(padapter);
 		}
@@ -10915,23 +11398,8 @@ void start_clnt_join(_adapter *padapter)
 			(REAUTH_TO * REAUTH_LIMIT) + (REASSOC_TO * REASSOC_LIMIT) + beacon_timeout);
 
 #ifdef CONFIG_RTW_80211R
-		if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
-			if (rtw_chk_ft_flags(padapter, RTW_FT_OVER_DS_SUPPORTED)) {
-				struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-				ft_priv *pftpriv = &pmlmepriv->ftpriv;
-
-				pmlmeinfo->state = WIFI_FW_AUTH_SUCCESS | WIFI_FW_STATION_STATE;
-				pftpriv->ft_event.ies =  pftpriv->ft_action + sizeof(struct rtw_ieee80211_hdr_3addr) + 16;
-				pftpriv->ft_event.ies_len = pftpriv->ft_action_len - sizeof(struct rtw_ieee80211_hdr_3addr);
-
-				/*Not support RIC*/
-				pftpriv->ft_event.ric_ies =  NULL;
-				pftpriv->ft_event.ric_ies_len = 0;
-				report_ft_event(padapter);
-			} else {
-				pmlmeinfo->state = WIFI_FW_AUTH_NULL | WIFI_FW_STATION_STATE;
-				start_clnt_auth(padapter);
-			}
+		if (rtw_ft_roam(padapter)) {
+			rtw_ft_start_clnt_join(padapter);
 		} else
 #endif
 		{
@@ -10940,7 +11408,6 @@ void start_clnt_join(_adapter *padapter)
 		}
 	} else if (caps & cap_IBSS) { /* adhoc client */
 		Set_MSR(padapter, WIFI_FW_ADHOC_STATE);
-		rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
 
 		val8 = 0xcf;
 		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
@@ -10949,7 +11416,7 @@ void start_clnt_join(_adapter *padapter)
 
 		pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
 
-		report_join_res(padapter, 1);
+		report_join_res(padapter, 1, WLAN_STATUS_SUCCESS);
 	} else {
 		/* RTW_INFO("marc: invalid cap:%x\n", caps); */
 		return;
@@ -10974,8 +11441,8 @@ void start_clnt_auth(_adapter *padapter)
 	pmlmeext->retry = 0;
 
 #ifdef CONFIG_RTW_80211R
-	if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
-		rtw_set_ft_status(padapter, RTW_FT_AUTHENTICATING_STA);
+	if (rtw_ft_roam(padapter)) {
+		rtw_ft_set_status(padapter, RTW_FT_AUTHENTICATING_STA);
 		RTW_PRINT("start ft auth\n");
 	} else
 #endif
@@ -10998,7 +11465,7 @@ void start_clnt_assoc(_adapter *padapter)
 	pmlmeinfo->state |= (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE);
 
 #ifdef CONFIG_RTW_80211R
-	if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED))
+	if (rtw_ft_roam(padapter))
 		issue_reassocreq(padapter);
 	else
 #endif
@@ -11025,13 +11492,15 @@ unsigned int receive_disconnect(_adapter *padapter, unsigned char *MacAddr, unsi
 			if (report_del_sta_event(padapter, MacAddr, reason, _TRUE, locally_generated) != _FAIL)
 				pmlmeinfo->state = WIFI_FW_NULL_STATE;
 		} else if (pmlmeinfo->state & WIFI_FW_LINKING_STATE) {
-			if (report_join_res(padapter, -2) != _FAIL)
+			if (report_join_res(padapter, -2, reason) != _FAIL)
 				pmlmeinfo->state = WIFI_FW_NULL_STATE;
 		} else
 			RTW_INFO(FUNC_ADPT_FMT" - End to Disconnect\n", FUNC_ADPT_ARG(padapter));
 #ifdef CONFIG_RTW_80211R
-		if ((rtw_to_roam(padapter) > 0) && !rtw_chk_ft_status(padapter, RTW_FT_REQUESTED_STA))
-			rtw_reset_ft_status(padapter);
+		rtw_ft_roam_status_reset(padapter);
+#endif
+#ifdef CONFIG_RTW_WNM
+		rtw_wnm_reset_btm_state(padapter);
 #endif
 	}
 
@@ -11058,7 +11527,7 @@ static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)
 		u8 *ie, *p;
 		u32 len;
 		RT_CHANNEL_PLAN chplan_ap;
-		RT_CHANNEL_INFO chplan_sta[MAX_CHANNEL_NUM];
+		RT_CHANNEL_INFO *chplan_sta = NULL;
 		u8 country[4];
 		u8 fcn; /* first channel number */
 		u8 noc; /* number of channel */
@@ -11106,7 +11575,11 @@ static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)
 		_RTW_INFO("}\n");
 #endif
 
-		_rtw_memcpy(chplan_sta, rfctl->channel_set, sizeof(chplan_sta));
+		chplan_sta = rtw_malloc(sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
+		if (!chplan_sta)
+			goto done_update_chplan_from_ap;
+
+		_rtw_memcpy(chplan_sta, rfctl->channel_set, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
 #ifdef CONFIG_RTW_DEBUG
 		i = 0;
 		RTW_INFO("%s: STA channel plan {", __FUNCTION__);
@@ -11278,26 +11751,10 @@ static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)
 			k++;
 		}
 #endif
-	}
-
-	/* If channel is used by AP, set channel scan type to active */
-	channel = bssid->Configuration.DSConfig;
-	chplan_new = rfctl->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 (rtw_is_dfs_ch(channel))
-					break;
 
-				chplan_new[i].ScanType = SCAN_ACTIVE;
-				RTW_INFO("%s: change channel %d scan type from passive to active\n",
-					 __FUNCTION__, channel);
-			}
-			break;
-		}
-		i++;
+done_update_chplan_from_ap:
+		if (chplan_sta)
+			rtw_mfree(chplan_sta, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
 	}
 }
 #endif
@@ -11366,15 +11823,21 @@ void report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
 	process_80211d(padapter, &psurvey_evt->bss);
 #endif
 
-#ifdef CONFIG_DFS
 	ch_set_idx = rtw_chset_search_ch(chset, psurvey_evt->bss.Configuration.DSConfig);
 	if (ch_set_idx >= 0) {
-		if (psurvey_evt->bss.InfrastructureMode == Ndis802_11Infrastructure
-			&& (psurvey_evt->bss.Ssid.SsidLength == 0
-				|| is_all_null(psurvey_evt->bss.Ssid.Ssid, psurvey_evt->bss.Ssid.SsidLength) == _TRUE))
-			chset[ch_set_idx].hidden_bss_cnt++;
+		if (psurvey_evt->bss.InfrastructureMode == Ndis802_11Infrastructure) {
+			if (chset[ch_set_idx].ScanType == SCAN_PASSIVE
+				&& !rtw_is_dfs_ch(psurvey_evt->bss.Configuration.DSConfig)
+			) {
+				RTW_INFO("%s: change ch:%d to active\n", __func__, psurvey_evt->bss.Configuration.DSConfig);
+				chset[ch_set_idx].ScanType = SCAN_ACTIVE;
+			}
+			#ifdef CONFIG_DFS
+			if (hidden_ssid_ap(&psurvey_evt->bss))
+				chset[ch_set_idx].hidden_bss_cnt++;
+			#endif
+		}
 	}
-#endif
 
 	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
 
@@ -11430,7 +11893,7 @@ void report_surveydone_event(_adapter *padapter)
 
 }
 
-u32 report_join_res(_adapter *padapter, int res)
+u32 report_join_res(_adapter *padapter, int aid_res, u16 status)
 {
 	struct cmd_obj *pcmd_obj;
 	u8	*pevtcmd;
@@ -11469,12 +11932,12 @@ u32 report_join_res(_adapter *padapter, int res)
 
 	pjoinbss_evt = (struct joinbss_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
 	_rtw_memcpy((unsigned char *)(&(pjoinbss_evt->network.network)), &(pmlmeinfo->network), sizeof(WLAN_BSSID_EX));
-	pjoinbss_evt->network.join_res	= pjoinbss_evt->network.aid = res;
+	pjoinbss_evt->network.join_res	= pjoinbss_evt->network.aid = aid_res;
 
-	RTW_INFO("report_join_res(%d)\n", res);
+	RTW_INFO("report_join_res(%d, %u)\n", aid_res, status);
 
 
-	rtw_joinbss_event_prehandle(padapter, (u8 *)&pjoinbss_evt->network);
+	rtw_joinbss_event_prehandle(padapter, (u8 *)&pjoinbss_evt->network, status);
 
 
 	ret = rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
@@ -11491,7 +11954,6 @@ void report_wmm_edca_update(_adapter *padapter)
 	struct wmm_event		*pwmm_event;
 	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 = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
@@ -11828,7 +12290,6 @@ static void rtw_mlmeext_disconnect(_adapter *padapter)
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 	u8 self_action = MLME_ACTION_UNKNOWN;
 	u8 state_backup = (pmlmeinfo->state & 0x03);
 	u8 ASIX_ID[] = {0x00, 0x0E, 0xC6};
@@ -11841,15 +12302,20 @@ static void rtw_mlmeext_disconnect(_adapter *padapter)
 		self_action = MLME_STA_DISCONNECTED;
 	else if (MLME_IS_ADHOC(padapter) || MLME_IS_ADHOC_MASTER(padapter))
 		self_action = MLME_ADHOC_STOPPED;
-	else if (MLME_IS_NULL(padapter))
-		self_action = MLME_ACTION_NONE;
-	else
+	else {
+		RTW_INFO("state:0x%x\n", MLME_STATE(padapter));
 		rtw_warn_on(1);
+	}
 
 	/* set_opmode_cmd(padapter, infra_client_with_mlme); */
-
+#ifdef CONFIG_HW_P0_TSF_SYNC
+	if (self_action == MLME_STA_DISCONNECTED)
+		correct_TSF(padapter, self_action);
+#endif
 	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_DISCONNECT, 0);
 	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
+	if (self_action == MLME_STA_DISCONNECTED)
+		rtw_hal_rcr_set_chk_bssid(padapter, self_action);
 
 	/* set MSR to no link state->infra. mode */
 	Set_MSR(padapter, _HW_STATE_STATION_);
@@ -11882,19 +12348,23 @@ static void rtw_mlmeext_disconnect(_adapter *padapter)
 	/* switch to the 20M Hz mode after disconnect */
 	pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
 	pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+	pmlmeext->txss_1ss = _FALSE;
+#endif
 
 #ifdef CONFIG_FCS_MODE
 	if (EN_FCS(padapter))
 		rtw_hal_set_hwreg(padapter, HW_VAR_STOP_FCS_MODE, NULL);
 #endif
 
-#ifdef CONFIG_DFS_MASTER
-	rtw_dfs_master_status_apply(padapter, self_action);
-#endif
-
-	{
+	if (!(MLME_IS_STA(padapter) && MLME_IS_OPCH_SW(padapter))) {
+		/* DFS and channel status no need to check here for STA under OPCH_SW */
 		u8 ch, bw, offset;
 
+		#ifdef CONFIG_DFS_MASTER
+		rtw_dfs_rd_en_decision(padapter, self_action, 0);
+		#endif
+
 		if (rtw_mi_get_ch_setting_union_no_self(padapter, &ch, &bw, &offset) != 0) {
 			set_channel_bwmode(padapter, ch, offset, bw);
 			rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
@@ -11927,29 +12397,39 @@ static void rtw_mlmeext_disconnect(_adapter *padapter)
 		pmlmepriv->qospriv.uapsd_ap_supported = 0;
 	}
 #endif /* CONFIG_WMMPS_STA */
+#ifdef CONFIG_RTS_FULL_BW
+	rtw_set_rts_bw(padapter);
+#endif/*CONFIG_RTS_FULL_BW*/
 
 }
 
 void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
 {
-	struct sta_info		*psta, *psta_bmc;
+	struct sta_info		*psta;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
 	struct sta_priv		*pstapriv = &padapter->stapriv;
 	u8	join_type;
-#ifdef CONFIG_ARP_KEEP_ALIVE
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-#endif
+
+#ifndef CONFIG_IOCTL_CFG80211
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#endif
+
+	if (pmlmepriv->wpa_phase == _TRUE)
+		pmlmepriv->wpa_phase = _FALSE;
 
 	if (join_res < 0) {
 		join_type = 1;
 		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 		rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
+		if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE)
+			rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_DISCONNECTED);
 
 		goto exit_mlmeext_joinbss_event_callback;
 	}
+
 #ifdef CONFIG_ARP_KEEP_ALIVE
 	pmlmepriv->bGetGateway = 1;
 	pmlmepriv->GetGatewayTryCnt = 0;
@@ -11967,6 +12447,10 @@ void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
 	/* update IOT-releated issue */
 	update_IOT_info(padapter);
 
+	#ifdef CONFIG_RTS_FULL_BW
+	rtw_set_rts_bw(padapter);
+	#endif/*CONFIG_RTS_FULL_BW*/
+
 	rtw_hal_set_hwreg(padapter, HW_VAR_BASIC_RATE, cur_network->SupportedRates);
 
 	/* BCN interval */
@@ -11977,10 +12461,10 @@ void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
 
 	/* WMM, Update EDCA param */
 	WMMOnAssocRsp(padapter);
-
+#ifdef CONFIG_80211N_HT
 	/* HT */
 	HTOnAssocRsp(padapter);
-
+#endif /* CONFIG_80211N_HT */
 #ifdef CONFIG_80211AC_VHT
 	/* VHT */
 	VHTOnAssocRsp(padapter);
@@ -11990,10 +12474,6 @@ void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
 	if (psta) { /* only for infra. mode */
 		psta->wireless_mode = pmlmeext->cur_wireless_mode;
 
-#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-		rtw_hal_set_default_port_id_cmd(padapter, psta->cmn.mac_id);
-#endif
-
 		/* set per sta rate after updating HT cap. */
 		set_sta_rate(padapter, psta);
 
@@ -12016,8 +12496,10 @@ void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
 	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 
 	if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) {
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTED);
+
 		/* correcting TSF */
-		correct_TSF(padapter, pmlmeext);
+		correct_TSF(padapter, MLME_STA_CONNECTED);
 
 		/* set_link_timer(pmlmeext, DISCONNECT_TO); */
 	}
@@ -12060,7 +12542,7 @@ void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta)
 			/* update_TSF(pmlmeext, pframe, len);			 */
 
 			/* correcting TSF */
-			correct_TSF(padapter, pmlmeext);
+			correct_TSF(padapter, MLME_ADHOC_STARTED);
 
 			/* start beacon */
 			if (send_beacon(padapter) == _FAIL)
@@ -12088,12 +12570,8 @@ void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta)
 
 void mlmeext_sta_del_event_callback(_adapter *padapter)
 {
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
 	if (is_client_associated_to_ap(padapter) || is_IBSS_empty(padapter))
 		rtw_mlmeext_disconnect(padapter);
-
 }
 
 /****************************************************************************
@@ -12155,10 +12633,10 @@ void rtw_delba_check(_adapter *padapter, struct sta_info *psta, u8 from_timer)
 u8 chk_ap_is_alive(_adapter *padapter, struct sta_info *psta)
 {
 	u8 ret = _FALSE;
+#ifdef DBG_EXPIRATION_CHK
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
-#ifdef DBG_EXPIRATION_CHK
 	RTW_INFO(FUNC_ADPT_FMT" rx:"STA_PKTS_FMT", beacon:%llu, probersp_to_self:%llu"
 		/*", probersp_bm:%llu, probersp_uo:%llu, probereq:%llu, BI:%u"*/
 		 ", retry:%u\n"
@@ -12325,7 +12803,6 @@ void linked_status_chk(_adapter *padapter, u8 from_timer)
 {
 	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;
@@ -12351,12 +12828,16 @@ void linked_status_chk(_adapter *padapter, u8 from_timer)
 #elif defined(CONFIG_LAYER2_ROAMING)
 		if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE)) {
 			RTW_INFO("signal_strength_data.avg_val = %d\n", precvpriv->signal_strength_data.avg_val);
-			if (precvpriv->signal_strength_data.avg_val < pmlmepriv->roam_rssi_threshold) {
+			if ((precvpriv->signal_strength_data.avg_val < pmlmepriv->roam_rssi_threshold)
+				&& (rtw_get_passing_time_ms(pmlmepriv->last_roaming) >= pmlmepriv->roam_scan_int*2000)) {
+#ifdef CONFIG_RTW_80211K
+				rtw_roam_nb_discover(padapter, _FALSE);
+#endif
 				pmlmepriv->need_to_roam = _TRUE;
 				rtw_drv_scan_by_self(padapter, RTW_AUTO_SCAN_REASON_ROAM);
-			} else {
+				pmlmepriv->last_roaming = rtw_get_current_time();
+			} else
 				pmlmepriv->need_to_roam = _FALSE;
-			}
 		}
 #endif
 #ifdef CONFIG_MCC_MODE
@@ -12384,7 +12865,7 @@ void linked_status_chk(_adapter *padapter, u8 from_timer)
 				pmlmepriv->bGetGateway = 0;
 			else {
 				_rtw_memset(pmlmepriv->gw_ip, 0, 4);
-				_rtw_memset(pmlmepriv->gw_mac_addr, 0, 6);
+				_rtw_memset(pmlmepriv->gw_mac_addr, 0, ETH_ALEN);
 			}
 		}
 #endif
@@ -12431,41 +12912,50 @@ void linked_status_chk(_adapter *padapter, u8 from_timer)
 			if (sta_last_tx_pkts(psta) == sta_tx_pkts(psta))
 				tx_chk = _FAIL;
 
-#if defined(CONFIG_ACTIVE_KEEP_ALIVE_CHECK) && !defined(CONFIG_LPS_LCLK_WD_TIMER)
-			if (pmlmeext->active_keep_alive_check && (rx_chk == _FAIL || tx_chk == _FAIL)
-				#ifdef CONFIG_MCC_MODE
-				/* Driver don't know operation channel under MCC*/
-				/* So driver don't  do KEEP_ALIVE_CHECK */
-				&& (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC))
-				#endif
+#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
+			if (!from_timer && pmlmeext->active_keep_alive_check && (rx_chk == _FAIL || tx_chk == _FAIL)
 			) {
 				u8 backup_ch = 0, backup_bw = 0, backup_offset = 0;
-				u8 union_ch = 0, union_bw, union_offset;
-
-				if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
-					|| pmlmeext->cur_channel != union_ch)
-						goto bypass_active_keep_alive;
-
-				/* switch to correct channel of current network  before issue keep-alive frames */
-				if (rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
-					backup_ch = rtw_get_oper_ch(padapter);
-					backup_bw = rtw_get_oper_bw(padapter);
-					backup_offset = rtw_get_oper_choffset(padapter);
-					set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+				u8 union_ch = 0, union_bw = 0, union_offset = 0;
+				u8 switch_channel_by_drv = _TRUE;
+
+				
+#ifdef CONFIG_MCC_MODE
+				if (MCC_EN(padapter)) {
+					/* driver doesn't switch channel under MCC */
+					if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+						switch_channel_by_drv = _FALSE;
+				}
+#endif
+				if (switch_channel_by_drv) {
+					if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
+						|| pmlmeext->cur_channel != union_ch)
+							goto bypass_active_keep_alive;
+
+					/* switch to correct channel of current network  before issue keep-alive frames */
+					if (rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
+						backup_ch = rtw_get_oper_ch(padapter);
+						backup_bw = rtw_get_oper_bw(padapter);
+						backup_offset = rtw_get_oper_choffset(padapter);
+						set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
+					}
 				}
 
 				if (rx_chk != _SUCCESS)
 					issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, psta->cmn.mac_addr, 0, 0, 3, 1);
 
 				if ((tx_chk != _SUCCESS && pmlmeinfo->link_count++ == link_count_limit) || rx_chk != _SUCCESS) {
-					tx_chk = issue_nulldata(padapter, psta->cmn.mac_addr, 0, 3, 1);
+					if (rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY))
+						tx_chk = issue_nulldata(padapter, psta->cmn.mac_addr, 1, 3, 1);
+					else
+						tx_chk = issue_nulldata(padapter, psta->cmn.mac_addr, 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_ch > 0)
+				if (backup_ch > 0 && switch_channel_by_drv)
 					set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
 
 bypass_active_keep_alive:
@@ -12493,7 +12983,7 @@ bypass_active_keep_alive:
 					#ifdef DBG_EXPIRATION_CHK
 					RTW_INFO("%s issue_nulldata(%d)\n", __FUNCTION__, from_timer ? 1 : 0);
 					#endif
-					if (from_timer)
+					if (from_timer || rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY))
 						tx_chk = issue_nulldata(padapter, NULL, 1, 0, 0);
 					else
 						tx_chk = issue_nulldata(padapter, NULL, 0, 1, 1);
@@ -12574,9 +13064,6 @@ void survey_timer_hdl(void *ctx)
 	struct sitesurvey_parm *psurveyPara;
 	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
-#endif
 
 	if (mlmeext_scan_state(pmlmeext) > SCAN_DISABLE) {
 		cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
@@ -12629,17 +13116,28 @@ void link_timer_hdl(void *ctx)
 	if (rtw_sta_linking_test_force_fail())
 		RTW_INFO("rtw_sta_linking_test_force_fail\n");
 
+	if (pmlmeext->join_abort && pmlmeinfo->state != WIFI_FW_NULL_STATE) {
+		RTW_INFO(FUNC_ADPT_FMT" join abort\n", FUNC_ADPT_ARG(padapter));
+		pmlmeinfo->state = WIFI_FW_NULL_STATE;
+		report_join_res(padapter, -4, WLAN_STATUS_UNSPECIFIED_FAILURE);
+		goto exit;
+	}
+
 	if (pmlmeinfo->state & WIFI_FW_AUTH_NULL) {
 		RTW_INFO("link_timer_hdl:no beacon while connecting\n");
 		pmlmeinfo->state = WIFI_FW_NULL_STATE;
-		report_join_res(padapter, -3);
+		report_join_res(padapter, -3, WLAN_STATUS_UNSPECIFIED_FAILURE);
 	} 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_res(padapter, -1);
+			if (pmlmeinfo->auth_status) {
+				report_join_res(padapter, -1, pmlmeinfo->auth_status);
+				pmlmeinfo->auth_status = 0; /* reset */
+			} else
+				report_join_res(padapter, -1, WLAN_STATUS_UNSPECIFIED_FAILURE);
 			return;
 			/* } */
 			/* else */
@@ -12658,18 +13156,18 @@ void link_timer_hdl(void *ctx)
 		if (++pmlmeinfo->reassoc_count > REASSOC_LIMIT) {
 			pmlmeinfo->state = WIFI_FW_NULL_STATE;
 #ifdef CONFIG_RTW_80211R
-			if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
+			if (rtw_ft_roam(padapter)) {
 				psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
 				if (psta)
 					rtw_free_stainfo(padapter,  psta);
 			}
 #endif
-			report_join_res(padapter, -2);
+			report_join_res(padapter, -2, WLAN_STATUS_UNSPECIFIED_FAILURE);
 			return;
 		}
 
 #ifdef CONFIG_RTW_80211R
-		if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED)) {
+		if (rtw_ft_roam(padapter)) {
 			RTW_INFO("link_timer_hdl: reassoc timeout and try again\n");
 			issue_reassocreq(padapter);
 		} else
@@ -12682,6 +13180,7 @@ void link_timer_hdl(void *ctx)
 		set_link_timer(pmlmeext, REASSOC_TO);
 	}
 
+exit:
 	return;
 }
 
@@ -12765,12 +13264,11 @@ void report_sta_timeout_event(_adapter *padapter, u8 *MacAddr, unsigned short re
 
 void clnt_sa_query_timeout(_adapter *padapter)
 {
+	struct mlme_ext_priv *mlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
 
-	rtw_disassoc_cmd(padapter, 0, 0);
-	rtw_indicate_disconnect(padapter, 0, _FALSE);
-	rtw_free_assoc_resources(padapter, 1);
-
-	RTW_INFO("SA query timeout client disconnect\n");
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+	receive_disconnect(padapter, get_my_bssid(&(mlmeinfo->network)), WLAN_REASON_SA_QUERY_TIMEOUT, _FALSE);
 }
 
 void sa_query_timer_hdl(void *ctx)
@@ -12791,66 +13289,242 @@ void sa_query_timer_hdl(void *ctx)
 #endif /* CONFIG_IEEE80211W */
 
 #ifdef CONFIG_RTW_80211R
-void start_clnt_ft_action(_adapter *padapter, u8 *pTargetAddr)
+void rtw_ft_update_bcn(_adapter *padapter, union recv_frame *precv_frame)
 {
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	uint len = precv_frame->u.hdr.len;
+	WLAN_BSSID_EX *pbss;
 
-	rtw_set_ft_status(padapter, RTW_FT_REQUESTING_STA);
-	issue_action_ft_request(padapter, pTargetAddr);
-	_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
+	if (rtw_ft_chk_status(padapter,RTW_FT_ASSOCIATED_STA) 
+		&& (pmlmepriv->ft_roam.ft_updated_bcn == _FALSE)) {
+		pbss = (WLAN_BSSID_EX*)rtw_malloc(sizeof(WLAN_BSSID_EX));
+		if (pbss) {
+			if (collect_bss_info(padapter, precv_frame, pbss) == _SUCCESS) {
+				struct beacon_keys recv_beacon;
+
+				update_network(&(pmlmepriv->cur_network.network), pbss, padapter, _TRUE);
+				rtw_get_bcn_info(&(pmlmepriv->cur_network));
+				
+				/* update bcn keys */
+				if (rtw_get_bcn_keys(padapter, pframe, len, &recv_beacon) == _TRUE) {
+					RTW_INFO("%s: beacon keys ready\n", __func__);
+					_rtw_memcpy(&pmlmepriv->cur_beacon_keys,
+						&recv_beacon, sizeof(recv_beacon));
+				} else {
+					RTW_ERR("%s: get beacon keys failed\n", __func__);
+					_rtw_memset(&pmlmepriv->cur_beacon_keys, 0, sizeof(recv_beacon));
+				}
+				#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
+				pmlmepriv->new_beacon_cnts = 0;
+				#endif
+			}
+			rtw_mfree((u8*)pbss, sizeof(WLAN_BSSID_EX));
+		}
+
+		/* check the vendor of the assoc AP */
+		pmlmeinfo->assoc_AP_vendor = 	
+			check_assoc_AP(pframe+sizeof(struct rtw_ieee80211_hdr_3addr),
+				(len - sizeof(struct rtw_ieee80211_hdr_3addr)));
+
+		/* update TSF Value */
+		update_TSF(pmlmeext, pframe, len);
+		pmlmeext->bcn_cnt = 0;
+		pmlmeext->last_bcn_cnt = 0;
+		pmlmepriv->ft_roam.ft_updated_bcn = _TRUE;
+	}
+}
+
+void rtw_ft_start_clnt_join(_adapter *padapter)
+{
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct	mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+
+	if (rtw_ft_otd_roam(padapter)) {
+		pmlmeinfo->state = WIFI_FW_AUTH_SUCCESS | WIFI_FW_STATION_STATE;
+		pft_roam->ft_event.ies =
+			(pft_roam->ft_action + sizeof(struct rtw_ieee80211_hdr_3addr) + 16);
+		pft_roam->ft_event.ies_len =
+			(pft_roam->ft_action_len - sizeof(struct rtw_ieee80211_hdr_3addr));
+
+		/*Not support RIC*/
+		pft_roam->ft_event.ric_ies =  NULL;
+		pft_roam->ft_event.ric_ies_len = 0;
+		rtw_ft_report_evt(padapter);
+		return;
+	}
+
+	pmlmeinfo->state = WIFI_FW_AUTH_NULL | WIFI_FW_STATION_STATE;
+	start_clnt_auth(padapter);
+}
+
+u8 rtw_ft_update_rsnie(
+	_adapter *padapter, u8 bwrite, 
+	struct pkt_attrib *pattrib, u8 **pframe)
+{
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u8 *pie;
+	u32 len;
+
+	pie = rtw_get_ie(pft_roam->updated_ft_ies, EID_WPA2, &len, 
+			pft_roam->updated_ft_ies_len);
+
+	if (!bwrite)
+		return (pie)?_SUCCESS:_FAIL;
+	
+	if (pie) {
+		*pframe = rtw_set_ie(((u8 *)*pframe), EID_WPA2, len, 
+						pie+2, &(pattrib->pktlen));
+	} else
+		return _FAIL;
+
+	return _SUCCESS;	
+}
+
+static u8 rtw_ft_update_mdie(
+	_adapter *padapter, struct pkt_attrib *pattrib, u8 **pframe)
+{
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u8 *pie, mdie[3];
+	u32 len = 3;
+
+	if (rtw_ft_roam(padapter)) {
+		if ((pie = rtw_get_ie(pft_roam->updated_ft_ies, _MDIE_, 
+				&len, pft_roam->updated_ft_ies_len))) {
+			pie = (pie + 2); /* ignore md-id & length */
+		} else 
+			return _FAIL;
+	} else {
+		*((u16 *)&mdie[0]) = pft_roam->mdid;
+		mdie[2] = pft_roam->ft_cap;
+		pie = &mdie[0];
+	}
+
+	*pframe = rtw_set_ie(((u8 *)*pframe), _MDIE_, len , pie, &(pattrib->pktlen));
+	return _SUCCESS;	
+}
+
+static u8 rtw_ft_update_ftie(
+	_adapter *padapter, struct pkt_attrib *pattrib, u8 **pframe)
+{
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+	u8 *pie;
+	u32 len;
+
+	if ((pie = rtw_get_ie(pft_roam->updated_ft_ies, _FTIE_, &len, 
+				pft_roam->updated_ft_ies_len)) != NULL) {
+		*pframe = rtw_set_ie(*pframe, _FTIE_, len , 
+					(pie+2), &(pattrib->pktlen));
+	} else
+		return _FAIL;
+
+	return _SUCCESS;	
+}
+
+void rtw_ft_build_auth_req_ies(_adapter *padapter, 
+	struct pkt_attrib *pattrib, u8 **pframe)
+{
+	u8 ftie_append = _TRUE;
+
+	if (!pattrib || !(*pframe))
+		return;
+
+	if (!rtw_ft_roam(padapter))
+		return;
+
+	ftie_append = rtw_ft_update_rsnie(padapter, _TRUE, pattrib, pframe);
+	rtw_ft_update_mdie(padapter, pattrib, pframe);
+	if (ftie_append)
+		rtw_ft_update_ftie(padapter, pattrib, pframe);
+}
+
+void rtw_ft_build_assoc_req_ies(_adapter *padapter, 
+	u8 is_reassoc, struct pkt_attrib *pattrib, u8 **pframe)
+{
+	if (!pattrib || !(*pframe))
+		return;
+
+	if (rtw_ft_chk_flags(padapter, RTW_FT_PEER_EN))
+		rtw_ft_update_mdie(padapter, pattrib, pframe);
+
+	if ((!is_reassoc) || (!rtw_ft_roam(padapter)))
+		return;
+
+	if (rtw_ft_update_rsnie(padapter, _FALSE, pattrib, pframe))
+		rtw_ft_update_ftie(padapter, pattrib, pframe);	
+}
+
+u8 rtw_ft_update_auth_rsp_ies(_adapter *padapter, u8 *pframe, u32 len)
+{
+	u8 ret = _SUCCESS;
+	u8 target_ap_addr[ETH_ALEN] = {0};
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+
+	if (!rtw_ft_roam(padapter))
+		return _FAIL;
+
+	/*rtw_ft_report_reassoc_evt already,
+	 * and waiting for cfg80211_rtw_update_ft_ies */
+	if (rtw_ft_authed_sta(padapter))
+		return ret;
+
+	if (!pframe || !len)
+		return _FAIL;
+	
+	rtw_buf_update(&pmlmepriv->auth_rsp, 
+		&pmlmepriv->auth_rsp_len, pframe, len);
+	pft_roam->ft_event.ies =
+		(pmlmepriv->auth_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6);
+	pft_roam->ft_event.ies_len =
+		(pmlmepriv->auth_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6);
+
+	/*Not support RIC*/
+	pft_roam->ft_event.ric_ies =  NULL;
+	pft_roam->ft_event.ric_ies_len =  0;
+	_rtw_memcpy(target_ap_addr, pmlmepriv->assoc_bssid, ETH_ALEN);
+	rtw_ft_report_reassoc_evt(padapter, target_ap_addr);
+
+	return ret;	
 }
 
-void ft_link_timer_hdl(void *ctx)
+static void rtw_ft_start_clnt_action(_adapter *padapter, u8 *pTargetAddr)
 {
-	_adapter *padapter = (_adapter *)ctx;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	ft_priv		*pftpriv = &pmlmepriv->ftpriv;
-
-	if (rtw_chk_ft_status(padapter, RTW_FT_REQUESTING_STA)) {
-		if (pftpriv->ft_req_retry_cnt < FT_ACTION_REQ_LIMIT) {
-			pftpriv->ft_req_retry_cnt++;
-			issue_action_ft_request(padapter, (u8 *)pmlmepriv->roam_network->network.MacAddress);
-			_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
-		} else {
-			pftpriv->ft_req_retry_cnt = 0;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-			if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-				rtw_set_ft_status(padapter, RTW_FT_ASSOCIATED_STA);
-			else
-				rtw_reset_ft_status(padapter);
-		}
-	}
+	rtw_ft_set_status(padapter, RTW_FT_REQUESTING_STA);
+	rtw_ft_issue_action_req(padapter, pTargetAddr);
+	_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
 }
 
-void ft_roam_timer_hdl(void *ctx)
+void rtw_ft_start_roam(_adapter *padapter, u8 *pTargetAddr)
 {
-	_adapter *padapter = (_adapter *)ctx;
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-	receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress
-							, WLAN_REASON_ACTIVE_ROAM, _FALSE);
+	if (rtw_ft_otd_roam(padapter)) {
+		rtw_ft_start_clnt_action(padapter, pTargetAddr);
+	} else {
+		/*wait a little time to retrieve packets buffered in the current ap while scan*/
+		_set_timer(&pmlmeext->ft_roam_timer, 30);
+	}
 }
 
-void issue_action_ft_request(_adapter *padapter, u8 *pTargetAddr)
+void rtw_ft_issue_action_req(_adapter *padapter, u8 *pTargetAddr)
 {
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct xmit_frame *pmgntframe = NULL;
-	struct rtw_ieee80211_hdr *pwlanhdr = NULL;
-	struct pkt_attrib *pattrib = NULL;
-	ft_priv *pftpriv = NULL;
-	u8 *pframe = NULL;
+	struct xmit_frame *pmgntframe;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct pkt_attrib *pattrib;
+	u8 *pframe;
 	u8 category = RTW_WLAN_CATEGORY_FT;
-	u8 action = RTW_WLAN_ACTION_FT_REQUEST;
-	u8 is_ft_roaming_with_rsn_ie = _TRUE;
-	u8 *pie = NULL;
-	u16 *fctrl = NULL;
-	u32 ft_ie_len = 0;
+	u8 action = RTW_WLAN_ACTION_FT_REQ;
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
 	if (pmgntframe == NULL)
@@ -12862,9 +13536,7 @@ void issue_action_ft_request(_adapter *padapter, u8 *pTargetAddr)
 
 	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
+	pwlanhdr->frame_ctl = 0;
 
 	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
@@ -12888,45 +13560,34 @@ void issue_action_ft_request(_adapter *padapter, u8 *pTargetAddr)
 	pframe += ETH_ALEN;
 	pattrib->pktlen += ETH_ALEN;
 
-	pftpriv = &pmlmepriv->ftpriv;
-	pie = rtw_get_ie(pftpriv->updated_ft_ies, EID_WPA2, &ft_ie_len, pftpriv->updated_ft_ies_len);
-	if (pie)
-		pframe = rtw_set_ie(pframe, EID_WPA2, ft_ie_len, pie+2, &(pattrib->pktlen));
-	else
-		is_ft_roaming_with_rsn_ie = _FALSE;
-
-	pie = rtw_get_ie(pftpriv->updated_ft_ies, _MDIE_, &ft_ie_len, pftpriv->updated_ft_ies_len);
-	if (pie)
-		pframe = rtw_set_ie(pframe, _MDIE_, ft_ie_len , pie+2, &(pattrib->pktlen));
-
-	pie = rtw_get_ie(pftpriv->updated_ft_ies, _FTIE_, &ft_ie_len, pftpriv->updated_ft_ies_len);
-	if (pie && is_ft_roaming_with_rsn_ie)
-		pframe = rtw_set_ie(pframe, _FTIE_, ft_ie_len , pie+2, &(pattrib->pktlen));
+	rtw_ft_update_mdie(padapter, pattrib, &pframe);
+	if (rtw_ft_update_rsnie(padapter, _TRUE, pattrib, &pframe))
+		rtw_ft_update_ftie(padapter, pattrib, &pframe);
 
 	pattrib->last_txcmdsz = pattrib->pktlen;
 	dump_mgntframe(padapter, pmgntframe);
 }
 
-void report_ft_event(_adapter *padapter)
+void rtw_ft_report_evt(_adapter *padapter)
 {
-	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
-	ft_priv	*pftpriv = &pmlmepriv->ftpriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&(pmlmeinfo->network);
 	struct cfg80211_ft_event_params ft_evt_parms;
 	_irqL irqL;
 
 	_rtw_memset(&ft_evt_parms, 0, sizeof(ft_evt_parms));
-	rtw_update_ft_stainfo(padapter, pnetwork);
+	rtw_ft_update_stainfo(padapter, pnetwork);
 
 	if (!pnetwork)
 		goto err_2;
 
-	ft_evt_parms.ies_len = pftpriv->ft_event.ies_len;
+	ft_evt_parms.ies_len = pft_roam->ft_event.ies_len;
 	ft_evt_parms.ies =  rtw_zmalloc(ft_evt_parms.ies_len);
 	if (ft_evt_parms.ies)
-		_rtw_memcpy((void *)ft_evt_parms.ies, pftpriv->ft_event.ies, ft_evt_parms.ies_len);
+		_rtw_memcpy((void *)ft_evt_parms.ies, pft_roam->ft_event.ies, ft_evt_parms.ies_len);
 	 else
 		goto err_2;
 
@@ -12936,31 +13597,28 @@ void report_ft_event(_adapter *padapter)
 	else
 		goto err_1;
 
-	ft_evt_parms.ric_ies = pftpriv->ft_event.ric_ies;
-	ft_evt_parms.ric_ies_len = pftpriv->ft_event.ric_ies_len;
-
-	_enter_critical_bh(&pmlmepriv->lock, &irqL);
-	rtw_set_ft_status(padapter, RTW_FT_AUTHENTICATED_STA);
-	_exit_critical_bh(&pmlmepriv->lock, &irqL);
+	ft_evt_parms.ric_ies = pft_roam->ft_event.ric_ies;
+	ft_evt_parms.ric_ies_len = pft_roam->ft_event.ric_ies_len;
 
+	rtw_ft_lock_set_status(padapter, RTW_FT_AUTHENTICATED_STA, &irqL);
 	rtw_cfg80211_ft_event(padapter, &ft_evt_parms);
-	RTW_INFO("FT: report_ft_event\n");
-	rtw_mfree((u8 *)pftpriv->ft_event.target_ap, ETH_ALEN);
+	RTW_INFO("FT: rtw_ft_report_evt\n");
+	rtw_mfree((u8 *)pft_roam->ft_event.target_ap, ETH_ALEN);
 err_1:
 	rtw_mfree((u8 *)ft_evt_parms.ies, ft_evt_parms.ies_len);
 err_2:
 	return;
 }
 
-void report_ft_reassoc_event(_adapter *padapter, u8 *pMacAddr)
+void rtw_ft_report_reassoc_evt(_adapter *padapter, u8 *pMacAddr)
 {
-	struct mlme_ext_priv		*pmlmeext = &padapter->mlmeextpriv;
-	struct cmd_priv			*pcmdpriv = &padapter->cmdpriv;
-	struct cmd_obj			*pcmd_obj = NULL;
-	struct stassoc_event		*passoc_sta_evt = NULL;
-	struct C2HEvent_Header	*pc2h_evt_hdr = NULL;
-	u8	*pevtcmd = NULL;
-	u32	cmdsz = 0;
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
+	struct cmd_obj *pcmd_obj = NULL;
+	struct stassoc_event *passoc_sta_evt = NULL;
+	struct C2HEvent_Header *pc2h_evt_hdr = NULL;
+	u8 *pevtcmd = NULL;
+	u32 cmdsz = 0;
 
 	pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
 	if (pcmd_obj == NULL)
@@ -12989,6 +13647,50 @@ void report_ft_reassoc_event(_adapter *padapter, u8 *pMacAddr)
 	_rtw_memcpy((unsigned char *)(&(passoc_sta_evt->macaddr)), pMacAddr, ETH_ALEN);
 	rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
 }
+
+void rtw_ft_link_timer_hdl(void *ctx)
+{
+	_adapter *padapter = (_adapter *)ctx;
+	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
+
+	if (rtw_ft_chk_status(padapter, RTW_FT_REQUESTING_STA)) {
+		if (pft_roam->ft_req_retry_cnt < RTW_FT_ACTION_REQ_LMT) {
+			pft_roam->ft_req_retry_cnt++;
+			rtw_ft_issue_action_req(padapter, (u8 *)pmlmepriv->roam_network->network.MacAddress);
+			_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
+		} else {
+			pft_roam->ft_req_retry_cnt = 0;	
+			if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
+				rtw_ft_set_status(padapter, RTW_FT_ASSOCIATED_STA);
+			else
+				rtw_ft_reset_status(padapter);
+		}
+	}
+}
+
+void rtw_ft_roam_timer_hdl(void *ctx)
+{
+	_adapter *padapter = (_adapter *)ctx;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+
+	receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress
+				, WLAN_REASON_ACTIVE_ROAM, _FALSE);
+}
+
+void rtw_ft_roam_status_reset(_adapter *padapter)
+{
+	struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
+
+	if ((rtw_to_roam(padapter) > 0) && 
+		(!rtw_ft_chk_status(padapter, RTW_FT_REQUESTED_STA))) {
+		rtw_ft_reset_status(padapter);
+	}	
+	
+	padapter->mlmepriv.ft_roam.ft_updated_bcn = _FALSE;
+}
 #endif
 
 u8 NULL_hdl(_adapter *padapter, u8 *pbuf)
@@ -13037,7 +13739,7 @@ void rtw_start_auto_ap(_adapter *adapter)
 
 	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11APMode);
 
-	rtw_setopmode_cmd(adapter, Ndis802_11APMode, _TRUE);
+	rtw_setopmode_cmd(adapter, Ndis802_11APMode, RTW_CMDF_WAIT_ACK);
 }
 
 static int rtw_auto_ap_start_beacon(_adapter *adapter)
@@ -13132,7 +13834,9 @@ u8 setopmode_hdl(_adapter *padapter, u8 *pbuf)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct setopmode_parm *psetop = (struct setopmode_parm *)pbuf;
 
-	if (psetop->mode == Ndis802_11APMode) {
+	if (psetop->mode == Ndis802_11APMode
+		|| psetop->mode == Ndis802_11_mesh
+	) {
 		pmlmeinfo->state = WIFI_FW_AP_STATE;
 		type = _HW_STATE_AP_;
 	} else if (psetop->mode == Ndis802_11Infrastructure) {
@@ -13172,8 +13876,10 @@ u8 setopmode_hdl(_adapter *padapter, u8 *pbuf)
 	}
 
 #ifdef CONFIG_BT_COEXIST
-	if (psetop->mode == Ndis802_11APMode ||
-		psetop->mode == Ndis802_11Monitor) {
+	if (psetop->mode == Ndis802_11APMode
+		|| psetop->mode == Ndis802_11_mesh
+		|| psetop->mode == Ndis802_11Monitor
+	) {
 		/* Do this after port switch to */
 		/* prevent from downloading rsvd page to wrong port */
 		rtw_btcoex_MediaStatusNotify(padapter, 1); /* connect */
@@ -13195,7 +13901,9 @@ u8 createbss_hdl(_adapter *padapter, u8 *pbuf)
 	/* u8	initialgain; */
 
 #ifdef CONFIG_AP_MODE
-	if (pmlmeinfo->state == WIFI_FW_AP_STATE) {
+	if ((parm->req_ch == 0 && pmlmeinfo->state == WIFI_FW_AP_STATE)
+		|| parm->req_ch != 0
+	) {
 		start_bss_network(padapter, parm);
 		goto exit;
 	}
@@ -13249,7 +13957,6 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 {
 	u8	join_type;
 	PNDIS_802_11_VARIABLE_IEs	pIE;
-	struct registry_priv	*pregpriv = &padapter->registrypriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
@@ -13279,6 +13986,8 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 
 
 		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_DISCONNECT, 0);
+		if (pmlmeinfo->state & WIFI_FW_STATION_STATE)
+			rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_DISCONNECTED);
 	}
 
 #ifdef CONFIG_ANTENNA_DIVERSITY
@@ -13301,7 +14010,10 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 	pmlmeinfo->bwmode_updated = _FALSE;
 	/* pmlmeinfo->assoc_AP_vendor = HT_IOT_PEER_MAX; */
 	pmlmeinfo->VHT_enable = 0;
-
+#ifdef ROKU_PRIVATE
+	pmlmeinfo->ht_vht_received = 0;
+	_rtw_memset(pmlmeinfo->SupportedRates_infra_ap, 0, NDIS_802_11_LENGTH_RATES_EX);
+#endif /* ROKU_PRIVATE */
 	_rtw_memcpy(pnetwork, pbuf, FIELD_OFFSET(WLAN_BSSID_EX, IELength));
 	pnetwork->IELength = ((WLAN_BSSID_EX *)pbuf)->IELength;
 
@@ -13309,7 +14021,7 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 		return H2C_PARAMETERS_ERROR;
 
 	if (pnetwork->IELength < 2) {
-		report_join_res(padapter, (-4));
+		report_join_res(padapter, (-4), WLAN_STATUS_UNSPECIFIED_FAILURE);
 		return H2C_SUCCESS;
 	}
 	_rtw_memcpy(pnetwork->IEs, ((WLAN_BSSID_EX *)pbuf)->IEs, pnetwork->IELength);
@@ -13355,7 +14067,7 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 	}
 
 	rtw_bss_get_chbw(pnetwork
-		, &pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset);
+		, &pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset, 1, 1);
 
 	rtw_adjust_chbw(padapter, pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset);
 
@@ -13390,7 +14102,7 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 
 	/* check channel, bandwidth, offset and switch */
 	if (rtw_chk_start_clnt_join(padapter, &u_ch, &u_bw, &u_offset) == _FAIL) {
-		report_join_res(padapter, (-4));
+		report_join_res(padapter, (-4), WLAN_STATUS_UNSPECIFIED_FAILURE);
 		return H2C_SUCCESS;
 	}
 
@@ -13402,10 +14114,14 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 	/*rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);*/
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmlmeinfo->network.MacAddress);
-	join_type = 0;
-	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 	if (MLME_IS_STA(padapter))
 		rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTING);
+	else
+		rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
+
+	join_type = 0;
+	rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+
 	doiqk = _TRUE;
 	rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
 
@@ -13426,34 +14142,35 @@ u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
 
 u8 disconnect_hdl(_adapter *padapter, unsigned char *pbuf)
 {
+#ifdef CONFIG_DFS
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+#endif
 	struct disconnect_parm *param = (struct disconnect_parm *)pbuf;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 	u8 val8;
 
-	if (is_client_associated_to_ap(padapter)) {
-#ifdef CONFIG_DFS
-		if (padapter->mlmepriv.handle_dfs == _FALSE)
-#endif /* CONFIG_DFS */
-#ifdef CONFIG_PLATFORM_ROCKCHIPS
-			/* To avoid connecting to AP fail during resume process, change retry count from 5 to 1 */
-			issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
-#else
-			issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, param->deauth_timeout_ms / 100, 100);
-#endif /* CONFIG_PLATFORM_ROCKCHIPS */
+	if (is_client_associated_to_ap(padapter)
+		#ifdef CONFIG_DFS
+		&& !IS_RADAR_DETECTED(rfctl) && !rfctl->csa_ch
+		#endif
+	) {
+		#ifdef CONFIG_PLATFORM_ROCKCHIPS
+		/* To avoid connecting to AP fail during resume process, change retry count from 5 to 1 */
+		issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
+		#else
+		issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, param->deauth_timeout_ms / 100, 100);
+		#endif /* CONFIG_PLATFORM_ROCKCHIPS */
 	}
 
-#ifdef CONFIG_DFS
-	if (padapter->mlmepriv.handle_dfs == _TRUE)
-		padapter->mlmepriv.handle_dfs = _FALSE;
-#endif /* CONFIG_DFS */
-
+#ifndef CONFIG_SUPPORT_MULTI_BCN
 	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
 		/* Stop BCN */
 		val8 = 0;
 		rtw_hal_set_hwreg(padapter, HW_VAR_BCN_FUNC, (u8 *)(&val8));
 	}
+#endif
 
 	rtw_mlmeext_disconnect(padapter);
 
@@ -13490,7 +14207,6 @@ const char *scan_state_str(u8 state)
 static bool scan_abort_hdl(_adapter *adapter)
 {
 	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct ss_res *ss = &pmlmeext->sitesurvey_res;
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &adapter->wdinfo;
@@ -13624,6 +14340,35 @@ exit:
 	return ret_num;
 }
 
+#ifdef CONFIG_SCAN_BACKOP
+u8 rtw_scan_backop_decision(_adapter *adapter)
+{
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+	struct mi_state mstate;
+	u8 backop_flags = 0;
+
+	rtw_mi_status(adapter, &mstate);
+
+	if ((MSTATE_STA_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(mlmeext, SS_BACKOP_EN))
+		|| (MSTATE_STA_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(mlmeext, SS_BACKOP_EN_NL)))
+		backop_flags |= mlmeext_scan_backop_flags_sta(mlmeext);
+
+#ifdef CONFIG_AP_MODE
+	if ((MSTATE_AP_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(mlmeext, SS_BACKOP_EN))
+		|| (MSTATE_AP_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(mlmeext, SS_BACKOP_EN_NL)))
+		backop_flags |= mlmeext_scan_backop_flags_ap(mlmeext);
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	if ((MSTATE_MESH_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_mesh(mlmeext, SS_BACKOP_EN))
+		|| (MSTATE_MESH_NUM(&mstate) && mlmeext_chk_scan_backop_flags_mesh(mlmeext, SS_BACKOP_EN_NL)))
+		backop_flags |= mlmeext_scan_backop_flags_mesh(mlmeext);
+#endif
+
+	return backop_flags;
+}
+#endif
+
 #define SCANNING_TIMEOUT_EX	2000
 u32 rtw_scan_timeout_decision(_adapter *padapter)
 {
@@ -13631,7 +14376,6 @@ u32 rtw_scan_timeout_decision(_adapter *padapter)
 	u8 max_chan_num;
 	u16 scan_ms;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
 	struct ss_res *ss = &pmlmeext->sitesurvey_res;
 
 	if (is_supported_5g(padapter->registrypriv.wireless_mode)
@@ -13641,7 +14385,7 @@ u32 rtw_scan_timeout_decision(_adapter *padapter)
 		max_chan_num = MAX_CHANNEL_NUM_2G;/*single band*/
 
 	#ifdef CONFIG_SCAN_BACKOP
-	if (rtw_mi_buddy_check_mlmeinfo_state(padapter, WIFI_FW_AP_STATE))
+	if (rtw_scan_backop_decision(padapter))
 		back_op_times = (max_chan_num / ss->scan_cnt_max) * ss->backop_ms;
 	#endif
 
@@ -13666,7 +14410,6 @@ static int rtw_scan_ch_decision(_adapter *padapter, struct rtw_ieee80211_channel
 		u32 out_num, struct rtw_ieee80211_channel *in, u32 in_num)
 {
 	int i, j;
-	int scan_ch_num = 0;
 	int set_idx;
 	u8 chan;
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
@@ -13791,13 +14534,15 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 	u8 scan_ch = 0;
 	RT_SCAN_TYPE scan_type = SCAN_PASSIVE;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
 	struct ss_res *ss = &pmlmeext->sitesurvey_res;
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	int ch_set_idx;
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
 #endif
+#ifdef CONFIG_SCAN_BACKOP
+	u8 backop_flags = 0;
+#endif
 
 	/* handle scan abort request */
 	scan_abort_hdl(padapter);
@@ -13825,18 +14570,37 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 	{
 		struct rtw_ieee80211_channel *ch;
 
+		#ifdef CONFIG_SCAN_BACKOP
+		backop_flags = rtw_scan_backop_decision(padapter);
+		#endif
+
 #ifdef CONFIG_DFS
-		if (ss->channel_idx != 0 && ss->dfs_ch_ssid_scan == 0
-			&& pmlmeext->sitesurvey_res.ssid_num
-			&& rtw_is_dfs_ch(ss->ch[ss->channel_idx - 1].hw_value)
-		) {
-			ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, ss->ch[ss->channel_idx - 1].hw_value);
-			if (ch_set_idx != -1 && rfctl->channel_set[ch_set_idx].hidden_bss_cnt) {
-				ss->channel_idx--;
-				ss->dfs_ch_ssid_scan = 1;
-			}
-		} else
-			ss->dfs_ch_ssid_scan = 0;
+		#ifdef CONFIG_SCAN_BACKOP
+		if (!(backop_flags && ss->scan_cnt >= ss->scan_cnt_max))
+		#endif
+		{
+			#ifdef CONFIG_RTW_WIFI_HAL
+			if (adapter_to_dvobj(padapter)->nodfs) {
+				while ( ss->channel_idx < ss->ch_num && rtw_is_dfs_ch(ss->ch[ss->channel_idx].hw_value))
+					ss->channel_idx++;
+			} else
+			#endif
+			if (ss->channel_idx != 0 && ss->dfs_ch_ssid_scan == 0
+				&& pmlmeext->sitesurvey_res.ssid_num
+				&& rtw_is_dfs_ch(ss->ch[ss->channel_idx - 1].hw_value)
+			) {
+				ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, ss->ch[ss->channel_idx - 1].hw_value);
+				if (ch_set_idx != -1 && rfctl->channel_set[ch_set_idx].hidden_bss_cnt
+					&& (!IS_DFS_SLAVE_WITH_RD(rfctl)
+						|| rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
+						|| !CH_IS_NON_OCP(&rfctl->channel_set[ch_set_idx]))
+				) {
+					ss->channel_idx--;
+					ss->dfs_ch_ssid_scan = 1;
+				}
+			} else
+				ss->dfs_ch_ssid_scan = 0;
+		}
 #endif /* CONFIG_DFS */
 
 		if (ss->channel_idx < ss->ch_num) {
@@ -13854,31 +14618,18 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 
 	if (scan_ch != 0) {
 		next_state = SCAN_PROCESS;
-#ifdef CONFIG_SCAN_BACKOP
-		{
-			struct mi_state mstate;
-			u8 backop_flags = 0;
-
-			rtw_mi_status(padapter, &mstate);
 
-			if ((MSTATE_STA_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN))
-				|| (MSTATE_STA_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN_NL)))
-				backop_flags |= mlmeext_scan_backop_flags_sta(pmlmeext);
-
-			if ((MSTATE_AP_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN))
-				|| (MSTATE_AP_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN_NL)))
-				backop_flags |= mlmeext_scan_backop_flags_ap(pmlmeext);
-
-			if (backop_flags) {
-				if (ss->scan_cnt < ss->scan_cnt_max)
-					ss->scan_cnt++;
-				else {
-					mlmeext_assign_scan_backop_flags(pmlmeext, backop_flags);
-					next_state = SCAN_BACKING_OP;
-				}
+		#ifdef CONFIG_SCAN_BACKOP
+		if (backop_flags) {
+			if (ss->scan_cnt < ss->scan_cnt_max)
+				ss->scan_cnt++;
+			else {
+				mlmeext_assign_scan_backop_flags(pmlmeext, backop_flags);
+				next_state = SCAN_BACKING_OP;
 			}
 		}
-#endif /* CONFIG_SCAN_BACKOP */
+		#endif
+
 	} else if (rtw_p2p_findphase_ex_is_needed(pwdinfo)) {
 		/* go p2p listen */
 		next_state = SCAN_TO_P2P_LISTEN;
@@ -13938,12 +14689,13 @@ static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *
 void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType)
 {
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct ss_res *ss = &pmlmeext->sitesurvey_res;
 	u8 ssid_scan = 0;
 
 #ifdef CONFIG_P2P
+#ifndef CONFIG_IOCTL_CFG80211
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+#endif
 #endif
 
 	if (survey_channel != 0) {
@@ -14061,7 +14813,9 @@ void survey_done_set_ch_bw(_adapter *padapter)
 					FUNC_ADPT_ARG(padapter), cur_channel, cur_bwmode, cur_ch_offset);
 		}
 	}
+#ifdef CONFIG_MCC_MODE
 exit:
+#endif
 	set_channel_bwmode(padapter, cur_channel, cur_ch_offset, cur_bwmode);
 }
 
@@ -14087,9 +14841,24 @@ u8 rtw_ps_annc(_adapter *adapter, bool ps)
 		if (MLME_IS_STA(iface)) {
 			if (is_client_associated_to_ap(iface) == _TRUE) {
 				/* TODO: TDLS peers */
+				#ifdef CONFIG_MCC_MODE
+				/* for two station case */
+				if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_NEED_MCC)) {
+					u8 ch = iface->mlmeextpriv.cur_channel;
+					u8 offset = iface->mlmeextpriv.cur_ch_offset;
+					u8 bw = iface->mlmeextpriv.cur_bwmode;
+
+					set_channel_bwmode(iface, ch, offset, bw);
+				}
+				#endif /* CONFIG_MCC_MODE */
 				issue_nulldata(iface, NULL, ps, 3, 500);
 				ps_anc = 1;
 			}
+		#ifdef CONFIG_RTW_MESH
+		} else if (MLME_IS_MESH(iface)) {
+			if (rtw_mesh_ps_annc(iface, ps))
+				ps_anc = 1;
+		#endif
 		}
 	}
 	return ps_anc;
@@ -14097,44 +14866,53 @@ u8 rtw_ps_annc(_adapter *adapter, bool ps)
 
 void rtw_leave_opch(_adapter *adapter)
 {
-	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 
 #ifdef CONFIG_MCC_MODE
 	if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
 		return;
 #endif
 
-	/* prepare to leave operating channel */
-	mlmeext_set_scan_state(pmlmeext, SCAN_LEAVING_OP);
+	_enter_critical_mutex(&rfctl->offch_mutex, NULL);
 
-	/* clear HW TX queue */
-	rtw_hal_set_hwreg(adapter, HW_VAR_CHECK_TXBUF, 0);
+	if (rfctl->offch_state == OFFCHS_NONE) {
+		/* prepare to leave operating channel */
+		rfctl->offch_state = OFFCHS_LEAVING_OP;
 
-	rtw_hal_macid_sleep_all_used(adapter);
+		/* clear HW TX queue */
+		rtw_hal_set_hwreg(adapter, HW_VAR_CHECK_TXBUF, 0);
 
-	rtw_ps_annc(adapter, 1);
+		rtw_hal_macid_sleep_all_used(adapter);
 
-	mlmeext_set_scan_state(pmlmeext, SCAN_LEAVE_OP);
+		rtw_ps_annc(adapter, 1);
+
+		rfctl->offch_state = OFFCHS_LEAVE_OP;
+	}
+
+	_exit_critical_mutex(&rfctl->offch_mutex, NULL);
 }
 
 void rtw_back_opch(_adapter *adapter)
 {
-	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 
 #ifdef CONFIG_MCC_MODE
 	if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
 		return;
 #endif
 
-	if (mlmeext_scan_state(pmlmeext) == SCAN_DISABLE)
-		return;
+	_enter_critical_mutex(&rfctl->offch_mutex, NULL);
 
-	mlmeext_set_scan_state(pmlmeext, SCAN_BACKING_OP);
-	rtw_hal_macid_wakeup_all_used(adapter);
-	rtw_ps_annc(adapter, 0);
+	if (rfctl->offch_state != OFFCHS_NONE) {
+		rfctl->offch_state = OFFCHS_BACKING_OP;
+		rtw_hal_macid_wakeup_all_used(adapter);
+		rtw_ps_annc(adapter, 0);
 
-	mlmeext_set_scan_state(pmlmeext, SCAN_DISABLE);
-	rtw_mi_os_xmit_schedule(adapter);
+		rfctl->offch_state = OFFCHS_NONE;
+		rtw_mi_os_xmit_schedule(adapter);
+	}
+
+	_exit_critical_mutex(&rfctl->offch_mutex, NULL);
 }
 
 void sitesurvey_set_igi(_adapter *adapter)
@@ -14158,6 +14936,7 @@ void sitesurvey_set_igi(_adapter *adapter)
 			igi = 0x28;
 		else
 		#endif /* CONFIG_P2P */
+
 		if (ss->igi)
 			igi = ss->igi;
 		else
@@ -14217,14 +14996,49 @@ void sitesurvey_set_msr(_adapter *adapter, bool enter)
 	}
 	Set_MSR(adapter, network_type);
 }
+
+void sitesurvey_set_offch_state(_adapter *adapter, u8 scan_state)
+{
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	_enter_critical_mutex(&rfctl->offch_mutex, NULL);
+
+	switch (scan_state) {
+	case SCAN_DISABLE:
+	case SCAN_BACK_OP:
+		rfctl->offch_state = OFFCHS_NONE;
+		break;
+	case SCAN_START:
+	case SCAN_LEAVING_OP:
+		rfctl->offch_state = OFFCHS_LEAVING_OP;
+		break;
+	case SCAN_ENTER:
+	case SCAN_LEAVE_OP:
+		rfctl->offch_state = OFFCHS_LEAVE_OP;
+		break;
+	case SCAN_COMPLETE:
+	case SCAN_BACKING_OP:
+		rfctl->offch_state = OFFCHS_BACKING_OP;
+		break;
+	default:
+		break;
+	}
+
+	_exit_critical_mutex(&rfctl->offch_mutex, NULL);
+}
+
 u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf)
 {
 	struct sitesurvey_parm	*pparm = (struct sitesurvey_parm *)pbuf;
+#ifdef DBG_CHECK_FW_PS_STATE
 	struct dvobj_priv *dvobj = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
+#endif
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct ss_res *ss = &pmlmeext->sitesurvey_res;
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+		struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+#endif
 	u8 val8;
 
 #ifdef CONFIG_P2P
@@ -14259,6 +15073,21 @@ operation_by_state:
 		goto operation_by_state;
 
 	case SCAN_START:
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+		if ((pwdev_priv->pno_mac_addr[0] != 0xFF)
+			    && (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == _TRUE)
+	    	    && (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE)) {
+			u16 seq_num;
+
+			rtw_hal_pno_random_gen_mac_addr(padapter);
+			rtw_hal_set_hw_mac_addr(padapter, pwdev_priv->pno_mac_addr);
+			get_random_bytes(&seq_num, 2);
+			pwdev_priv->pno_scan_seq_num = seq_num & 0xFFF;
+			RTW_INFO("%s pno_scan_seq_num %d\n", __func__,
+				 pwdev_priv->pno_scan_seq_num);
+		}
+#endif
+
 		/*
 		* prepare to leave operating channel
 		*/
@@ -14329,27 +15158,29 @@ operation_by_state:
 
 		/* still SCAN_PROCESS state */
 		#ifdef DBG_SITESURVEY
-#ifdef CONFIG_P2P
-			RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (cnt:%u,idx:%d) at %dms, %c%c%c\n"
-				 , FUNC_ADPT_ARG(padapter)
-				 , mlmeext_scan_state_str(pmlmeext)
-				 , scan_ch
+			#ifdef CONFIG_P2P
+			RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (cnt:%u,idx:%d) at %dms, %c%c%c%c\n"
+				, FUNC_ADPT_ARG(padapter)
+				, mlmeext_scan_state_str(pmlmeext)
+				, scan_ch
 				, pwdinfo->find_phase_state_exchange_cnt, ss->channel_idx
 				, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
 				, scan_type ? 'A' : 'P', ss->scan_mode ? 'A' : 'P'
-				 , ss->ssid[0].SsidLength ? 'S' : ' '
-				);
-#else
-			RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (idx:%d) at %dms, %c%c%c\n"
-				 , FUNC_ADPT_ARG(padapter)
-				 , mlmeext_scan_state_str(pmlmeext)
-				 , scan_ch
-				 , ss->channel_idx
+				, ss->ssid[0].SsidLength ? 'S' : ' '
+				, ss->dfs_ch_ssid_scan ? 'D' : ' '
+			);
+			#else
+			RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (idx:%d) at %dms, %c%c%c%c\n"
+				, FUNC_ADPT_ARG(padapter)
+				, mlmeext_scan_state_str(pmlmeext)
+				, scan_ch
+				, ss->channel_idx
 				, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
 				, scan_type ? 'A' : 'P', ss->scan_mode ? 'A' : 'P'
-				 , ss->ssid[0].SsidLength ? 'S' : ' '
-				);
-#endif /* CONFIG_P2P */
+				, ss->ssid[0].SsidLength ? 'S' : ' '
+				, ss->dfs_ch_ssid_scan ? 'D' : ' '
+			);
+			#endif /* CONFIG_P2P */
 		#endif /*DBG_SITESURVEY*/
 #ifdef DBG_FIXED_CHAN
 		if (pmlmeext->fixed_chan != 0xff)
@@ -14364,7 +15195,12 @@ operation_by_state:
 		else
 			scan_ms = 40;
 #else
-		scan_ms = ss->scan_ch_ms;
+		#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
+		if (IS_ACS_ENABLE(padapter) && rtw_is_acs_st_valid(padapter))
+			scan_ms = rtw_acs_get_adv_st(padapter);
+		else
+		#endif /*CONFIG_RTW_ACS*/
+			scan_ms = ss->scan_ch_ms;
 #endif
 
 #if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
@@ -14373,8 +15209,12 @@ operation_by_state:
 #endif
 
 #ifdef CONFIG_RTW_ACS
-		if (IS_ACS_ENABLE(padapter))
-			rtw_acs_trigger(padapter, scan_ms, scan_ch);
+		if (IS_ACS_ENABLE(padapter)) {
+			if (pparm->token)
+				rtw_acs_trigger(padapter, scan_ms, scan_ch, NHM_PID_IEEE_11K_HIGH);
+			else
+				rtw_acs_trigger(padapter, scan_ms, scan_ch, NHM_PID_ACS);
+		}
 #endif
 
 #ifdef CONFIG_BACKGROUND_NOISE_MONITOR
@@ -14522,6 +15362,9 @@ operation_by_state:
 #endif /* CONFIG_P2P */
 
 	case SCAN_COMPLETE:
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+		rtw_hal_set_hw_mac_addr(padapter, adapter_mac_addr(padapter));
+#endif
 #ifdef CONFIG_P2P
 		if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
 		    || rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH)
@@ -14636,23 +15479,26 @@ u8 setkey_hdl(_adapter *padapter, u8 *pbuf)
 		cam_id = rtw_iface_bcmc_id_get(padapter);
 	else
 #endif
-		cam_id = rtw_camid_alloc(padapter, NULL, pparm->keyid, &used);
+		cam_id = rtw_camid_alloc(padapter, NULL, pparm->keyid, 1, &used);
 
 	if (cam_id < 0)
 		goto enable_mc;
 
 #ifndef CONFIG_CONCURRENT_MODE
-	if (cam_id >= 0 && cam_id <= 3)
+	if (cam_id >= 0 && cam_id <= 3) {
+		/* default key camid */
 		addr = null_addr;
-	else
+	} else
 #endif
 	{
-		if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
-			/* for AP mode ,we will force sec cam entry_id so hw dont search cam when tx*/
+		/* not default key camid */
+		if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)) {
+			/* group TX, force sec cam entry_id */
 			addr = adapter_mac_addr(padapter);
-		else
-			/* not default key, searched by A2 */
+		} else {
+			/* group RX, searched by A2 (TA) */
 			addr = get_bssid(&padapter->mlmepriv);
+		}
 	}
 
 	/* cam entry searched is pairwise key */
@@ -14719,6 +15565,7 @@ u8 setkey_hdl(_adapter *padapter, u8 *pbuf)
 	    _rtw_camctl_chk_cap(padapter, SEC_CAP_CHK_BMC)) {
 		struct set_stakey_parm	sta_pparm;
 
+		_rtw_memset(&sta_pparm, 0, sizeof(struct set_stakey_parm));
 		sta_pparm.algorithm = pparm->algorithm;
 		sta_pparm.keyid = pparm->keyid;
 		_rtw_memcpy(sta_pparm.key, pparm->key, 16);
@@ -14746,6 +15593,7 @@ void rtw_ap_wep_pk_setting(_adapter *adapter, struct sta_info *psta)
 		if ((psecuritypriv->key_mask & BIT(keyid)) && (keyid == psecuritypriv->dot11PrivacyKeyIndex)) {
 			sta_pparm.algorithm = psecuritypriv->dot11PrivacyAlgrthm;
 			sta_pparm.keyid = keyid;
+			sta_pparm.gk = 0;
 			_rtw_memcpy(sta_pparm.key, &(psecuritypriv->dot11DefKey[keyid].skey[0]), 16);
 			_rtw_memcpy(sta_pparm.addr, psta->cmn.mac_addr, ETH_ALEN);
 
@@ -14762,7 +15610,6 @@ u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf)
 	u16 ctrl = 0;
 	s16 cam_id = 0;
 	bool used;
-	u8 kid = 0;
 	u8 ret = H2C_SUCCESS;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
@@ -14781,14 +15628,13 @@ u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf)
 	}
 
 	pmlmeinfo->enc_algo = pparm->algorithm;
-	if (is_wep_enc(pparm->algorithm))
-		kid = pparm->keyid;
-	cam_id = rtw_camid_alloc(padapter, psta, kid, &used);
+
+	cam_id = rtw_camid_alloc(padapter, psta, pparm->keyid, pparm->gk, &used);
 	if (cam_id < 0)
 		goto exit;
 
-	/* cam entry searched is group key */
-	if (used == _TRUE && rtw_camid_is_gk(padapter, cam_id) == _TRUE) {
+	/* cam entry searched is group key when setting pariwise key */
+	if (!pparm->gk && used == _TRUE && rtw_camid_is_gk(padapter, cam_id) == _TRUE) {
 		s16 camid_clr;
 
 		RTW_PRINT(FUNC_ADPT_FMT" pairwise key with "MAC_FMT" id:%u the same key id as group key\n"
@@ -14814,9 +15660,12 @@ write_to_cam:
 			rtw_camid_free(padapter, cam_id);
 		}
 	} else {
-		RTW_PRINT("set pairwise key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n",
-			cam_id, MAC_ARG(pparm->addr), pparm->keyid, security_type_str(pparm->algorithm));
+		RTW_PRINT("set %s key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n"
+			, pparm->gk ? "group" : "pairwise"
+			, cam_id, MAC_ARG(pparm->addr), pparm->keyid, security_type_str(pparm->algorithm));
 		ctrl = BIT(15) | ((pparm->algorithm) << 2) | pparm->keyid;
+		if (pparm->gk)
+			ctrl |= BIT(6);
 		write_cam(padapter, cam_id, ctrl, pparm->addr, pparm->key);
 	}
 	ret = H2C_SUCCESS_RSP;
@@ -14863,10 +15712,10 @@ u8 add_ba_hdl(_adapter *padapter, unsigned char *pbuf)
 u8 add_ba_rsp_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 	struct addBaRsp_parm *pparm = (struct addBaRsp_parm *)pbuf;
-	u8 ret = _TRUE, i = 0, try_cnt = 3, wait_ms = 50;
 	struct recv_reorder_ctrl *preorder_ctrl;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct sta_info *psta;
+	u8 ret = _TRUE;
 
 	psta = rtw_get_stainfo(pstapriv, pparm->addr);
 	if (!psta)
@@ -15056,7 +15905,7 @@ u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf)
 	if (!psta_bmc)
 		return H2C_SUCCESS;
 
-	if ((pstapriv->tim_bitmap & BIT(0)) && (psta_bmc->sleepq_len > 0)) {
+	if ((rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) && (psta_bmc->sleepq_len > 0)) {
 #ifndef CONFIG_PCI_HCI
 		rtw_msleep_os(10);/* 10ms, ATIM(HIQ) Windows */
 #endif
@@ -15108,7 +15957,7 @@ u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf)
 
 u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf)
 {
-
+	/*RTW_INFO(FUNC_ADPT_FMT, FUNC_ADPT_ARG(padapter));*/
 #ifdef CONFIG_SWTIMER_BASED_TXBCN
 
 	tx_beacon_handlder(padapter->dvobj);
@@ -15136,8 +15985,6 @@ u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf)
 void change_band_update_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 ch)
 {
 	u8	network_type, rate_len, total_rate_len, remainder_rate_len;
-	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	u8	erpinfo = 0x4;
@@ -15150,13 +15997,12 @@ void change_band_update_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 ch)
 		/* if channel in 5G band, then add vht ie . */
 		if ((pmlmepriv->htpriv.ht_option == _TRUE)
 			&& REGSTY_IS_11AC_ENABLE(&padapter->registrypriv)
-			&& hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+			&& is_supported_vht(padapter->registrypriv.wireless_mode)
 			&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
 		) {
-			if (REGSTY_IS_11AC_AUTO(&padapter->registrypriv))
+			if (REGSTY_IS_11AC_AUTO(&padapter->registrypriv)
+				|| pmlmepriv->ori_vht_en)
 				rtw_vht_ies_attach(padapter, pnetwork);
-			/*else*/
-				/*TODO vht_enable == 1*/
 		}
 		#endif
 	} else {
@@ -15232,21 +16078,34 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 			if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
 				&& check_fwstate(mlme, WIFI_ASOC_STATE)
 			) {
+				u8 ori_ch, ori_bw, ori_offset;
 				bool is_grouped = rtw_is_chbw_grouped(u_ch, u_bw, u_offset
 					, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
 
 				if (is_grouped == _FALSE) {
 					/* handle AP which need to switch ch setting */
 
+					ori_ch = mlmeext->cur_channel;
+					ori_bw = mlmeext->cur_bwmode;
+					ori_offset = mlmeext->cur_ch_offset;
+
 					/* restore original bw, adjust bw by registry setting on target ch */
 					mlmeext->cur_bwmode = mlme->ori_bw;
 					mlmeext->cur_channel = u_ch;
-					rtw_adjust_chbw(iface
-						, mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset);
+					rtw_adjust_chbw(iface, mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset);
+					#ifdef CONFIG_RTW_MESH
+					if (MLME_IS_MESH(iface))
+						rtw_mesh_adjust_chbw(mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset);
+					#endif
 
-					rtw_sync_chbw(&mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
+					rtw_chset_sync_chbw(adapter_to_chset(adapter)
+						, &mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
 						, &u_ch, &u_bw, &u_offset);
 
+					RTW_INFO(FUNC_ADPT_FMT" %u,%u,%u => %u,%u,%u\n", FUNC_ADPT_ARG(iface)
+						, ori_ch, ori_bw, ori_offset
+						, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+
 					rtw_ap_update_bss_chbw(iface, &(mlmeext->mlmext_info.network)
 						, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
 
@@ -15256,9 +16115,15 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 
 					if (MLME_IS_GO(iface) || MLME_IS_MESH(iface)) { /* pure AP is not needed*/
 						#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+						u8 ht_option = 0;
+
+						#ifdef CONFIG_80211N_HT
+						ht_option = mlme->htpriv.ht_option;
+						#endif
+
 						rtw_cfg80211_ch_switch_notify(iface
 							, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset
-							, mlme->htpriv.ht_option);
+							, ht_option);
 						#endif
 					}
 				}
@@ -15269,7 +16134,7 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 		}
 
 #ifdef CONFIG_DFS_MASTER
-		rtw_dfs_master_status_apply(adapter, MLME_STA_CONNECTED);
+		rtw_dfs_rd_en_decision(adapter, MLME_STA_CONNECTED, 0);
 #endif
 	} else {
 		for (i = 0; i < dvobj->iface_nums; i++) {
@@ -15288,11 +16153,12 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 			}
 		}
 #ifdef CONFIG_DFS_MASTER
-		rtw_dfs_master_status_apply(adapter, MLME_STA_DISCONNECTED);
+		rtw_dfs_rd_en_decision(adapter, MLME_STA_DISCONNECTED, 0);
 #endif
 	}
 
 	if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset)) {
+		RTW_INFO(FUNC_ADPT_FMT" union:%u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
 		set_channel_bwmode(adapter, u_ch, u_offset, u_bw);
 		rtw_mi_update_union_chan_inf(adapter, u_ch, u_offset, u_bw);
 	}
@@ -15305,7 +16171,9 @@ void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
 
 int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 {
+#ifdef CONFIG_CONCURRENT_MODE
 	bool chbw_allow = _TRUE;
+#endif
 	bool connect_allow = _TRUE;
 	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
 	u8 cur_ch, cur_bw, cur_ch_offset;
@@ -15342,7 +16210,7 @@ int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 		dvobj = adapter_to_dvobj(adapter);
 
 		rtw_mi_status_no_self(adapter, &mstate);
-		RTW_INFO(FUNC_ADPT_FMT" ld_sta_num:%u, ap_num:%u, mesh_num:%u\n"
+		RTW_INFO(FUNC_ADPT_FMT" others ld_sta_num:%u, ap_num:%u, mesh_num:%u\n"
 			, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate)
 			, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate));
 
@@ -15355,7 +16223,7 @@ int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 			dump_adapters_status(RTW_DBGDUMP , dvobj);
 			rtw_warn_on(1);
 		}
-		RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n"
+		RTW_INFO(FUNC_ADPT_FMT" others union:%u,%u,%u\n"
 			 , FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
 
 		/* chbw_allow? */
@@ -15398,7 +16266,7 @@ int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 		}
 #endif /* CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT */
 
-		if (MSTATE_STA_LD_NUM(&mstate) + MSTATE_AP_LD_NUM(&mstate) + MSTATE_MESH_LD_NUM(&mstate) >= 2)
+		if (MSTATE_STA_LD_NUM(&mstate) + MSTATE_AP_LD_NUM(&mstate) + MSTATE_MESH_LD_NUM(&mstate) >= 4)
 			connect_allow = _FALSE;
 
 		RTW_INFO(FUNC_ADPT_FMT" connect_allow:%d\n"
@@ -15410,10 +16278,6 @@ int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
 connect_allow_hdl:
 		/* connect_allow == _TRUE */
 
-#ifdef CONFIG_DFS_MASTER
-		rtw_dfs_master_status_apply(adapter, MLME_STA_CONNECTING);
-#endif
-
 		if (chbw_allow == _FALSE) {
 			u_ch = cur_ch;
 			u_bw = cur_bw;
@@ -15445,10 +16309,14 @@ connect_allow_hdl:
 				) {
 					rtw_disassoc_cmd(iface, 500, RTW_CMDF_DIRECTLY);
 					rtw_indicate_disconnect(iface, 0, _FALSE);
-					rtw_free_assoc_resources(iface, 1);
+					rtw_free_assoc_resources(iface, _TRUE);
 				}
 			}
 		}
+
+		#ifdef CONFIG_DFS_MASTER
+		rtw_dfs_rd_en_decision(adapter, MLME_STA_CONNECTING, 0);
+		#endif
 	}
 #endif /* CONFIG_CONCURRENT_MODE */
 
@@ -15468,7 +16336,6 @@ exit:
 u8 rtw_set_chbw_hdl(_adapter *padapter, u8 *pbuf)
 {
 	struct set_ch_parm *set_ch_parm;
-	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 
 	if (!pbuf)
@@ -15493,7 +16360,6 @@ u8 set_chplan_hdl(_adapter *padapter, unsigned char *pbuf)
 {
 	struct SetChannelPlan_param *setChannelPlan_param;
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
 	if (!pbuf)
 		return H2C_PARAMETERS_ERROR;
@@ -15515,8 +16381,8 @@ u8 set_chplan_hdl(_adapter *padapter, unsigned char *pbuf)
 	rtw_hal_set_odm_var(padapter, HAL_ODM_REGULATION, NULL, _TRUE);
 
 #ifdef CONFIG_IOCTL_CFG80211
-	rtw_reg_notify_by_driver(padapter);
-#endif /* CONFIG_IOCTL_CFG80211 */
+	rtw_regd_apply_flags(adapter_to_wiphy(padapter));
+#endif
 
 	return	H2C_SUCCESS;
 }
@@ -15537,41 +16403,15 @@ u8 led_blink_hdl(_adapter *padapter, unsigned char *pbuf)
 	return	H2C_SUCCESS;
 }
 
-u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf)
+u8 set_csa_hdl(_adapter *adapter, unsigned char *pbuf)
 {
 #ifdef CONFIG_DFS
-	struct SetChannelSwitch_param *setChannelSwitch_param;
-	u8 new_ch_no;
-	u8 gval8 = 0x00, sval8 = 0xff;
-
-	if (!pbuf)
-		return H2C_PARAMETERS_ERROR;
-
-	setChannelSwitch_param = (struct SetChannelSwitch_param *)pbuf;
-	new_ch_no = setChannelSwitch_param->new_ch_no;
-
-	rtw_hal_get_hwreg(padapter, HW_VAR_TXPAUSE, &gval8);
-
-	rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &sval8);
-
-	RTW_INFO("DFS detected! Swiching channel to %d!\n", new_ch_no);
-	set_channel_bwmode(padapter, new_ch_no, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-
-	rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &gval8);
-
-	rtw_disassoc_cmd(padapter, 0, RTW_CMDF_DIRECTLY);
-	rtw_indicate_disconnect(padapter, 0, _FALSE);
-	rtw_free_assoc_resources(padapter, 1);
-	rtw_free_network_queue(padapter, _TRUE);
-
-	if (rtw_is_dfs_ch(new_ch_no))
-		RTW_INFO("Switched to DFS band (ch %u) again!!\n", new_ch_no);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 
+	if (rfctl->csa_ch)
+		rtw_dfs_ch_switch_hdl(adapter_to_dvobj(adapter));
+#endif
 	return	H2C_SUCCESS;
-#else
-	return	H2C_REJECTED;
-#endif /* CONFIG_DFS */
-
 }
 
 u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)
@@ -15785,14 +16625,16 @@ u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)
 		rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_NOLINK);
 		break;
 	case TDLS_TEARDOWN_STA:
+	case TDLS_TEARDOWN_STA_NO_WAIT:
 		_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
 		txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
 		_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
 
-		issue_tdls_teardown(padapter, &txmgmt, _TRUE);
+		issue_tdls_teardown(padapter, &txmgmt, (option == TDLS_TEARDOWN_STA) ? _TRUE : _FALSE);
 
 		break;
 	case TDLS_TEARDOWN_STA_LOCALLY:
+	case TDLS_TEARDOWN_STA_LOCALLY_POST:
 #ifdef CONFIG_TDLS_CH_SW
 		if (_rtw_memcmp(TDLSoption->addr, pchsw_info->addr, ETH_ALEN) == _TRUE) {
 			pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE |
@@ -15802,8 +16644,11 @@ u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)
 			_rtw_memset(pchsw_info->addr, 0x00, ETH_ALEN);
 		}
 #endif
-		rtw_sta_media_status_rpt(padapter, ptdls_sta, 0);
-		free_tdls_sta(padapter, ptdls_sta);
+
+		if (option == TDLS_TEARDOWN_STA_LOCALLY)
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+
+		rtw_tdls_teardown_post_hdl(padapter, ptdls_sta, _FALSE);
 
 		if (ptdlsinfo->tdls_sctx != NULL)
 			rtw_sctx_done(&(ptdlsinfo->tdls_sctx));
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp.c
index 564be07bdd26..548a293b73ff 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -147,6 +148,7 @@ static void _init_mp_priv_(struct mp_priv *pmp_priv)
 	pmp_priv->bloopback = _FALSE;
 
 	pmp_priv->bloadefusemap = _FALSE;
+	pmp_priv->brx_filter_beacon = _FALSE;
 
 	pnetwork = &pmp_priv->mp_network.network;
 	_rtw_memcpy(pnetwork->MacAddress, pmp_priv->network_macaddr, ETH_ALEN);
@@ -159,6 +161,8 @@ static void _init_mp_priv_(struct mp_priv *pmp_priv)
 	pmp_priv->tx.attrib.ht_en = 1;
 #endif
 
+	pmp_priv->mpt_ctx.mpt_rate_index = 1;
+
 }
 
 #ifdef PLATFORM_WINDOWS
@@ -220,6 +224,7 @@ static int init_mp_priv_by_os(struct mp_priv *pmp_priv)
 #endif
 
 #ifdef PLATFORM_LINUX
+#if 0
 static int init_mp_priv_by_os(struct mp_priv *pmp_priv)
 {
 	int i, res;
@@ -261,6 +266,7 @@ _exit_init_mp_priv:
 	return res;
 }
 #endif
+#endif
 
 static void mp_init_xmit_attrib(struct mp_tx *pmptx, PADAPTER padapter)
 {
@@ -296,6 +302,11 @@ static void mp_init_xmit_attrib(struct mp_tx *pmptx, PADAPTER padapter)
 
 	pattrib->pktlen = 1500;
 
+	if (pHalData->rf_type == RF_2T2R)
+		pattrib->raid = RATEID_IDX_BGN_40M_2SS;
+	else
+		pattrib->raid = RATEID_IDX_BGN_40M_1SS;
+
 #ifdef CONFIG_80211AC_VHT
 	if (pHalData->rf_type == RF_1T1R)
 		pattrib->raid = RATEID_IDX_VHT_1SS;
@@ -361,7 +372,7 @@ void free_mp_priv(struct mp_priv *pmp_priv)
 	pmp_priv->pmp_xmtframe_buf = NULL;
 }
 
-
+#if 0
 static VOID PHY_IQCalibrate_default(
 	IN	PADAPTER	pAdapter,
 	IN	BOOLEAN	bReCovery
@@ -384,7 +395,7 @@ static VOID PHY_SetRFPathSwitch_default(
 {
 	RTW_INFO("%s\n", __func__);
 }
-
+#endif
 
 void mpt_InitHWConfig(PADAPTER Adapter)
 {
@@ -451,8 +462,8 @@ void mpt_InitHWConfig(PADAPTER Adapter)
 	else if (IS_HARDWARE_TYPE_8821C(Adapter))
 		PlatformEFIOWrite2Byte(Adapter, REG_RXFLTMAP1_8821C, 0x2000);
 #endif /* CONFIG_RTL8821C */
-#ifdef CONFIG_RTL8188F
-	else if (IS_HARDWARE_TYPE_8188F(Adapter)) {
+#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
+	else if (IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8188GTV(Adapter)) {
 		if (IS_A_CUT(hal->version_id) || IS_B_CUT(hal->version_id)) {
 			RTW_INFO("%s() Active large power detection\n", __func__);
 			phy_active_large_power_detection_8188f(&(GET_HAL_DATA(Adapter)->odmpriv));
@@ -502,6 +513,10 @@ static u8 PHY_QueryRFPathSwitch(PADAPTER padapter)
 	} else if (IS_HARDWARE_TYPE_8188F(padapter)) {
 #ifdef CONFIG_RTL8188F
 		bmain = PHY_QueryRFPathSwitch_8188F(padapter);
+#endif
+	} else if (IS_HARDWARE_TYPE_8188GTV(padapter)) {
+#ifdef CONFIG_RTL8188GTV
+		bmain = PHY_QueryRFPathSwitch_8188GTV(padapter);
 #endif
 	} else if (IS_HARDWARE_TYPE_8822B(padapter)) {
 #ifdef CONFIG_RTL8822B
@@ -525,49 +540,73 @@ static u8 PHY_QueryRFPathSwitch(PADAPTER padapter)
 
 static void  PHY_SetRFPathSwitch(PADAPTER padapter , BOOLEAN bMain) {
 
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+	struct dm_struct *phydm = &hal->odmpriv;
+
 	if (IS_HARDWARE_TYPE_8723B(padapter)) {
 #ifdef CONFIG_RTL8723B
-		phy_set_rf_path_switch_8723b(padapter, bMain);
+		phy_set_rf_path_switch_8723b(phydm, bMain);
 #endif
 	} else if (IS_HARDWARE_TYPE_8188E(padapter)) {
 #ifdef CONFIG_RTL8188E
-		phy_set_rf_path_switch_8188e(padapter, bMain);
+		phy_set_rf_path_switch_8188e(phydm, bMain);
 #endif
-	} else if (IS_HARDWARE_TYPE_8814A(padapter)) {	
+	} else if (IS_HARDWARE_TYPE_8814A(padapter)) {
 #ifdef CONFIG_RTL8814A
-		phy_set_rf_path_switch_8814a(padapter, bMain);
+		phy_set_rf_path_switch_8814a(phydm, bMain);
 #endif
 	} else if (IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter)) {
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
-		phy_set_rf_path_switch_8812a(padapter, bMain);
+		phy_set_rf_path_switch_8812a(phydm, bMain);
 #endif
 	} else if (IS_HARDWARE_TYPE_8192E(padapter)) {
 #ifdef CONFIG_RTL8192E
-		phy_set_rf_path_switch_8192e(padapter, bMain);
+		phy_set_rf_path_switch_8192e(phydm, bMain);
 #endif
 	} else if (IS_HARDWARE_TYPE_8703B(padapter)) {
 #ifdef CONFIG_RTL8703B
-		phy_set_rf_path_switch_8703b(padapter, bMain);
+		phy_set_rf_path_switch_8703b(phydm, bMain);
 #endif
-	} else if (IS_HARDWARE_TYPE_8188F(padapter)) {
-#ifdef CONFIG_RTL8188F
-		phy_set_rf_path_switch_8188f(padapter, bMain);
+	} else if (IS_HARDWARE_TYPE_8188F(padapter) || IS_HARDWARE_TYPE_8188GTV(padapter)) {
+#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
+		phy_set_rf_path_switch_8188f(phydm, bMain);
+#endif
+	} else if (IS_HARDWARE_TYPE_8192F(padapter)) {
+#ifdef CONFIG_RTL8192F
+		phy_set_rf_path_switch_8192f(padapter, bMain);
 #endif
 	} else if (IS_HARDWARE_TYPE_8822B(padapter)) {
 #ifdef CONFIG_RTL8822B
-		phy_set_rf_path_switch_8822b(padapter, bMain);
+		phy_set_rf_path_switch_8822b(phydm, bMain);
 #endif
 	} else if (IS_HARDWARE_TYPE_8723D(padapter)) {
 #ifdef CONFIG_RTL8723D
-		phy_set_rf_path_switch_8723d(padapter, bMain);
+		phy_set_rf_path_switch_8723d(phydm, bMain);
 #endif
 	} else if (IS_HARDWARE_TYPE_8821C(padapter)) {
 #ifdef CONFIG_RTL8821C
-		phy_set_rf_path_switch_8821c(padapter, bMain);
+		phy_set_rf_path_switch_8821c(phydm, bMain);
 #endif
 	}
 }
 
+
+static void phy_switch_rf_path_set(PADAPTER padapter , u8 *prf_set_State) {
+#ifdef CONFIG_RTL8821C
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+	struct dm_struct *p_dm = &pHalData->odmpriv;
+
+	if (IS_HARDWARE_TYPE_8821C(padapter)) {
+		config_phydm_set_ant_path(p_dm, *prf_set_State, p_dm->current_ant_num_8821c);
+		/* Do IQK when switching to BTG/WLG, requested by RF Binson */
+		if (*prf_set_State == SWITCH_TO_BTG || *prf_set_State == SWITCH_TO_WLG)
+			PHY_IQCalibrate(padapter, FALSE);
+	}
+#endif
+
+}
+
+
 #ifdef CONFIG_ANTENNA_DIVERSITY
 u8 rtw_mp_set_antdiv(PADAPTER padapter, BOOLEAN bMain)
 {
@@ -596,7 +635,6 @@ MPT_InitializeAdapter(
 	s32		rtStatus = _SUCCESS;
 	PMPT_CONTEXT	pMptCtx = &pAdapter->mppriv.mpt_ctx;
 	u32		ledsetting;
-	struct mlme_priv *pmlmepriv = &pAdapter->mlmepriv;
 
 	pMptCtx->bMptDrvUnload = _FALSE;
 	pMptCtx->bMassProdTest = _FALSE;
@@ -620,11 +658,12 @@ MPT_InitializeAdapter(
 		/* <20130522, Kordan> Turn off equalizer to improve Rx sensitivity. (Asked by EEChou)*/
 		phy_set_bb_reg(pAdapter, 0xA00, BIT8, 0x0);
 		PHY_SetRFPathSwitch(pAdapter, 1/*pHalData->bDefaultAntenna*/); /*default use Main*/
-		/*<20130522, Kordan> 0x51 and 0x71 should be set immediately after path switched, or they might be overwritten. */
-		if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90))
-			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B10E);
-		else
+
+		if (pHalData->PackageType == PACKAGE_DEFAULT)
 			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
+		else
+			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6F10E);
+
 	}
 	/*set ant to wifi side in mp mode*/
 	rtw_write16(pAdapter, 0x870, 0x300);
@@ -759,7 +798,7 @@ static void init_mp_data(PADAPTER padapter)
 {
 	u8 v8;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 
 	/*disable BCN*/
 	v8 = rtw_read8(padapter, REG_BCN_CTRL);
@@ -772,7 +811,7 @@ static void init_mp_data(PADAPTER padapter)
 void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 	u32	rf_ability;
 
 	if (bstart == 1) {
@@ -791,9 +830,9 @@ void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart)
 		pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
 		padapter->mppriv.mp_dm = 0;
 		{
-			struct _TXPWRTRACK_CFG	c;
+			struct txpwrtrack_cfg c;
 			u1Byte	chnl = 0 ;
-			_rtw_memset(&c, 0, sizeof(struct _TXPWRTRACK_CFG));
+			_rtw_memset(&c, 0, sizeof(struct txpwrtrack_cfg));
 			configure_txpower_track(pDM_Odm, &c);
 			odm_clear_txpowertracking_state(pDM_Odm);
 			if (*c.odm_tx_pwr_track_set_pwr) {
@@ -802,6 +841,9 @@ void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart)
 				else if (pDM_Odm->support_ic_type == ODM_RTL8723D) {
 					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_A, chnl);
 					SetTxPower(padapter);
+				} else if (pDM_Odm->support_ic_type == ODM_RTL8192F) {
+					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, MIX_MODE, RF_PATH_A, chnl);
+					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, MIX_MODE, RF_PATH_B, chnl);
 				} else {
 					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_A, chnl);
 					(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_B, chnl);
@@ -818,7 +860,6 @@ u32 mp_join(PADAPTER padapter, u8 mode)
 	WLAN_BSSID_EX bssid;
 	struct sta_info *psta;
 	u32 length;
-	u8 val8, join_type;
 	_irqL irqL;
 	s32 res = _SUCCESS;
 
@@ -829,9 +870,6 @@ u32 mp_join(PADAPTER padapter, u8 mode)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	WLAN_BSSID_EX		*pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 
-#ifdef CONFIG_IOCTL_CFG80211
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
-#endif /* #ifdef CONFIG_IOCTL_CFG80211 */
 	/* 1. initialize a new WLAN_BSSID_EX */
 	_rtw_memset(&bssid, 0, sizeof(WLAN_BSSID_EX));
 	RTW_INFO("%s ,pmppriv->network_macaddr=%x %x %x %x %x %x\n", __func__,
@@ -870,7 +908,7 @@ u32 mp_join(PADAPTER padapter, u8 mode)
 	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
 		rtw_disassoc_cmd(padapter, 500, 0);
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
-		rtw_free_assoc_resources(padapter, 1);
+		rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
 	}
 	pmppriv->prev_fw_state = get_fwstate(pmlmepriv);
 	/*pmlmepriv->fw_state = WIFI_MP_STATE;*/
@@ -918,13 +956,8 @@ end_of_mp_start_test:
 			/* set msr to WIFI_FW_ADHOC_STATE */
 			pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
 			Set_MSR(padapter, (pmlmeinfo->state & 0x3));
-
 			rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, padapter->registrypriv.dev_network.MacAddress);
-			join_type = 0;
-			rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 			rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
-
-			report_join_res(padapter, 1);
 			pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
 		} else {
 			Set_MSR(padapter, WIFI_FW_STATION_STATE);
@@ -943,6 +976,9 @@ end_of_mp_start_test:
 s32 mp_start_test(PADAPTER padapter)
 {
 	struct mp_priv *pmppriv = &padapter->mppriv;
+#ifdef CONFIG_PCI_HCI
+	PHAL_DATA_TYPE hal;
+#endif
 	s32 res = _SUCCESS;
 
 	padapter->registrypriv.mp_mode = 1;
@@ -966,6 +1002,9 @@ s32 mp_start_test(PADAPTER padapter)
 #ifdef CONFIG_RTL8188F
 	rtl8188f_InitHalDm(padapter);
 #endif
+#ifdef CONFIG_RTL8188GTV
+	rtl8188gtv_InitHalDm(padapter);
+#endif
 #ifdef CONFIG_RTL8188E
 	rtl8188e_InitHalDm(padapter);
 #endif
@@ -973,6 +1012,13 @@ s32 mp_start_test(PADAPTER padapter)
 	rtl8723d_InitHalDm(padapter);
 #endif /* CONFIG_RTL8723D */
 
+#ifdef CONFIG_PCI_HCI
+	hal = GET_HAL_DATA(padapter);
+	hal->pci_backdoor_ctrl = 0;
+	rtw_pci_aspm_config(padapter);
+#endif
+
+
 	/* 3 0. update mp_priv */
 
 	if (!RF_TYPE_VALID(padapter->registrypriv.rf_config)) {
@@ -1012,6 +1058,10 @@ void mp_stop_test(PADAPTER padapter)
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct wlan_network *tgt_network = &pmlmepriv->cur_network;
 	struct sta_info *psta;
+#ifdef CONFIG_PCI_HCI
+	struct registry_priv  *registry_par = &padapter->registrypriv;
+	PHAL_DATA_TYPE hal;
+#endif
 
 	_irqL irqL;
 
@@ -1025,7 +1075,7 @@ void mp_stop_test(PADAPTER padapter)
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
 
 		/* 3 2. clear psta used in mp test mode.
-		*	rtw_free_assoc_resources(padapter, 1); */
+		*	rtw_free_assoc_resources(padapter, _TRUE); */
 		psta = rtw_get_stainfo(&padapter->stapriv, tgt_network->network.MacAddress);
 		if (psta)
 			rtw_free_stainfo(padapter, psta);
@@ -1043,6 +1093,12 @@ end_of_mp_stop_test:
 
 		_exit_critical_bh(&pmlmepriv->lock, &irqL);
 
+#ifdef CONFIG_PCI_HCI
+		hal = GET_HAL_DATA(padapter);
+		hal->pci_backdoor_ctrl = registry_par->pci_aspm_config;
+		rtw_pci_aspm_config(padapter);
+#endif
+
 #ifdef CONFIG_RTL8812A
 		rtl8812_InitHalDm(padapter);
 #endif
@@ -1058,6 +1114,9 @@ end_of_mp_stop_test:
 #ifdef CONFIG_RTL8188F
 		rtl8188f_InitHalDm(padapter);
 #endif
+#ifdef CONFIG_RTL8188GTV
+		rtl8188gtv_InitHalDm(padapter);
+#endif
 #ifdef CONFIG_RTL8723D
 		rtl8723d_InitHalDm(padapter);
 #endif
@@ -1123,6 +1182,7 @@ static VOID mpt_AdjustRFRegByRateByChan92CU(PADAPTER pAdapter, u8 RateIdx, u8 Ch
  * 01/09/2009	MHC		Add CCK modification for 40MHZ. Suggestion from SD3.
  *
  *---------------------------------------------------------------------------*/
+#if 0
 static void mpt_SwitchRfSetting(PADAPTER pAdapter)
 {
 	hal_mpt_SwitchRfSetting(pAdapter);
@@ -1134,6 +1194,7 @@ static void MPT_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
 {
 	hal_mpt_CCKTxPowerAdjust(Adapter, bInCH14);
 }
+#endif
 
 /*---------------------------hal\rtl8192c\MPT_HelperFunc.c---------------------------*/
 
@@ -1195,6 +1256,13 @@ void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter , BOOLEAN bMain)
 
 }
 
+void mp_phy_switch_rf_path_set(PADAPTER pAdapter , u8 *pstate)
+{
+
+	phy_switch_rf_path_set(pAdapter, pstate);
+
+}
+
 u8 MP_PHY_QueryRFPathSwitch(PADAPTER pAdapter)
 {
 	return PHY_QueryRFPathSwitch(pAdapter);
@@ -1205,6 +1273,7 @@ s32 SetThermalMeter(PADAPTER pAdapter, u8 target_ther)
 	return hal_mpt_SetThermalMeter(pAdapter, target_ther);
 }
 
+#if 0
 static void TriggerRFThermalMeter(PADAPTER pAdapter)
 {
 	hal_mpt_TriggerRFThermalMeter(pAdapter);
@@ -1214,6 +1283,7 @@ static u8 ReadRFThermalMeter(PADAPTER pAdapter)
 {
 	return hal_mpt_ReadRFThermalMeter(pAdapter);
 }
+#endif
 
 void GetThermalMeter(PADAPTER pAdapter, u8 *value)
 {
@@ -1287,7 +1357,7 @@ static struct xmit_frame *alloc_mp_xmitframe(struct xmit_priv *pxmitpriv)
 
 }
 
-#ifdef CONFIG_PCIE_HCI
+#ifdef CONFIG_PCI_HCI
 static u8 check_nic_enough_desc(_adapter *padapter, struct pkt_attrib *pattrib)
 {
 	u32 prio;
@@ -1347,7 +1417,7 @@ static thread_return mp_xmit_packet_thread(thread_context context)
 	RTW_INFO("%s:pkTx Start\n", __func__);
 	while (1) {
 		pxmitframe = alloc_mp_xmitframe(pxmitpriv);
-#ifdef CONFIG_PCIE_HCI
+#ifdef CONFIG_PCI_HCI
 		if(check_nic_enough_desc(padapter, &pmptx->attrib) == _FALSE) {
 			rtw_usleep_os(1000);
 			continue;
@@ -1461,7 +1531,7 @@ void fill_tx_desc_8814a(PADAPTER padapter)
 
 	u32	pkt_size = pattrib->last_txcmdsz;
 	s32 bmcast = IS_MCAST(pattrib->ra);
-	u8 data_rate, pwr_status, offset;
+	u8 offset;
 
 	/* SET_TX_DESC_FIRST_SEG_8814A(pDesc, 1); */
 	SET_TX_DESC_LAST_SEG_8814A(pDesc, 1);
@@ -1715,6 +1785,37 @@ void fill_tx_desc_8188f(PADAPTER padapter)
 }
 #endif
 
+#if defined(CONFIG_RTL8188GTV)
+void fill_tx_desc_8188gtv(PADAPTER padapter)
+{
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
+	u8 *ptxdesc = pmp_priv->tx.desc;
+
+	SET_TX_DESC_AGG_BREAK_8188GTV(ptxdesc, 1);
+	SET_TX_DESC_MACID_8188GTV(ptxdesc, pattrib->mac_id);
+	SET_TX_DESC_QUEUE_SEL_8188GTV(ptxdesc, pattrib->qsel);
+
+	SET_TX_DESC_RATE_ID_8188GTV(ptxdesc, pattrib->raid);
+	SET_TX_DESC_SEQ_8188GTV(ptxdesc, pattrib->seqnum);
+	SET_TX_DESC_HWSEQ_EN_8188GTV(ptxdesc, 1);
+	SET_TX_DESC_USE_RATE_8188GTV(ptxdesc, 1);
+	SET_TX_DESC_DISABLE_FB_8188GTV(ptxdesc, 1);
+
+	if (pmp_priv->preamble)
+		if (HwRateToMPTRate(pmp_priv->rateidx) <=  MPT_RATE_54M)
+			SET_TX_DESC_DATA_SHORT_8188GTV(ptxdesc, 1);
+
+	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
+		SET_TX_DESC_DATA_BW_8188GTV(ptxdesc, 1);
+
+	SET_TX_DESC_TX_RATE_8188GTV(ptxdesc, pmp_priv->rateidx);
+
+	SET_TX_DESC_DATA_RATE_FB_LIMIT_8188GTV(ptxdesc, 0x1F);
+	SET_TX_DESC_RTS_RATE_FB_LIMIT_8188GTV(ptxdesc, 0xF);
+}
+#endif
+
 #if defined(CONFIG_RTL8723D)
 void fill_tx_desc_8723d(PADAPTER padapter)
 {
@@ -1747,6 +1848,70 @@ void fill_tx_desc_8723d(PADAPTER padapter)
 }
 #endif
 
+#if defined(CONFIG_RTL8710B)
+void fill_tx_desc_8710b(PADAPTER padapter)
+{
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
+	u8 *ptxdesc = pmp_priv->tx.desc;
+
+	SET_TX_DESC_BK_8710B(ptxdesc, 1);
+	SET_TX_DESC_MACID_8710B(ptxdesc, pattrib->mac_id);
+	SET_TX_DESC_QUEUE_SEL_8710B(ptxdesc, pattrib->qsel);
+
+	SET_TX_DESC_RATE_ID_8710B(ptxdesc, pattrib->raid);
+	SET_TX_DESC_SEQ_8710B(ptxdesc, pattrib->seqnum);
+	SET_TX_DESC_HWSEQ_EN_8710B(ptxdesc, 1);
+	SET_TX_DESC_USE_RATE_8710B(ptxdesc, 1);
+	SET_TX_DESC_DISABLE_FB_8710B(ptxdesc, 1);
+
+	if (pmp_priv->preamble) {
+		if (HwRateToMPTRate(pmp_priv->rateidx) <=  MPT_RATE_54M)
+			SET_TX_DESC_DATA_SHORT_8710B(ptxdesc, 1);
+	}
+
+	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
+		SET_TX_DESC_DATA_BW_8710B(ptxdesc, 1);
+
+	SET_TX_DESC_TX_RATE_8710B(ptxdesc, pmp_priv->rateidx);
+
+	SET_TX_DESC_DATA_RATE_FB_LIMIT_8710B(ptxdesc, 0x1F);
+	SET_TX_DESC_RTS_RATE_FB_LIMIT_8710B(ptxdesc, 0xF);
+}
+#endif
+
+#if defined(CONFIG_RTL8192F)
+void fill_tx_desc_8192f(PADAPTER padapter)
+{
+	struct mp_priv *pmp_priv = &padapter->mppriv;
+	struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
+	u8 *ptxdesc = pmp_priv->tx.desc;
+
+	SET_TX_DESC_BK_8192F(ptxdesc, 1);
+	SET_TX_DESC_MACID_8192F(ptxdesc, pattrib->mac_id);
+	SET_TX_DESC_QUEUE_SEL_8192F(ptxdesc, pattrib->qsel);
+
+	SET_TX_DESC_RATE_ID_8192F(ptxdesc, pattrib->raid);
+	SET_TX_DESC_SEQ_8192F(ptxdesc, pattrib->seqnum);
+	SET_TX_DESC_HWSEQ_EN_8192F(ptxdesc, 1);
+	SET_TX_DESC_USE_RATE_8192F(ptxdesc, 1);
+	SET_TX_DESC_DISABLE_FB_8192F(ptxdesc, 1);
+
+	if (pmp_priv->preamble) {
+		if (HwRateToMPTRate(pmp_priv->rateidx) <=  MPT_RATE_54M)
+			SET_TX_DESC_DATA_SHORT_8192F(ptxdesc, 1);
+	}
+
+	if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
+		SET_TX_DESC_DATA_BW_8192F(ptxdesc, 1);
+
+	SET_TX_DESC_TX_RATE_8192F(ptxdesc, pmp_priv->rateidx);
+
+	SET_TX_DESC_DATA_RATE_FB_LIMIT_8192F(ptxdesc, 0x1F);
+	SET_TX_DESC_RTS_RATE_FB_LIMIT_8192F(ptxdesc, 0xF);
+}
+
+#endif
 static void Rtw_MPSetMacTxEDCA(PADAPTER padapter)
 {
 
@@ -1764,8 +1929,8 @@ static void Rtw_MPSetMacTxEDCA(PADAPTER padapter)
 
 void SetPacketTx(PADAPTER padapter)
 {
-	u8 *ptr, *pkt_start, *pkt_end, *fctrl;
-	u32 pkt_size, offset, startPlace, i;
+	u8 *ptr, *pkt_start, *pkt_end;
+	u32 pkt_size, i;
 	struct rtw_ieee80211_hdr *hdr;
 	u8 payload;
 	s32 bmcast;
@@ -1786,7 +1951,7 @@ void SetPacketTx(PADAPTER padapter)
 	_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
 	_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
 	bmcast = IS_MCAST(pattrib->ra);
-	if (bmcast) 
+	if (bmcast)
 		pattrib->psta = rtw_get_bcmc_stainfo(padapter);
 	else
 		pattrib->psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
@@ -1859,10 +2024,24 @@ void SetPacketTx(PADAPTER padapter)
 		fill_tx_desc_8188f(padapter);
 #endif
 
+#if defined(CONFIG_RTL8188GTV)
+	if (IS_HARDWARE_TYPE_8188GTV(padapter))
+		fill_tx_desc_8188gtv(padapter);
+#endif
+
 #if defined(CONFIG_RTL8723D)
 	if (IS_HARDWARE_TYPE_8723D(padapter))
 		fill_tx_desc_8723d(padapter);
 #endif
+#if defined(CONFIG_RTL8192F)
+		if (IS_HARDWARE_TYPE_8192F(padapter))
+			fill_tx_desc_8192f(padapter);
+#endif
+
+#if defined(CONFIG_RTL8710B)
+	if (IS_HARDWARE_TYPE_8710B(padapter))
+		fill_tx_desc_8710b(padapter);
+#endif
 
 	/* 3 4. make wlan header, make_wlanhdr() */
 	hdr = (struct rtw_ieee80211_hdr *)pkt_start;
@@ -1952,11 +2131,13 @@ void SetPacketRx(PADAPTER pAdapter, u8 bStartRx, u8 bAB)
 				 MAC_ARG(pmppriv->network_macaddr));
 			pHalData->ReceiveConfig = 0;
 			pHalData->ReceiveConfig |= RCR_CBSSID_DATA | RCR_CBSSID_BCN |RCR_APM | RCR_AM | RCR_AB |RCR_AMF;
+			pHalData->ReceiveConfig |= RCR_APP_PHYST_RXFF;
 
 #if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
 			write_bbreg(pAdapter, 0x550, BIT3, bEnable);
 #endif
 			rtw_write16(pAdapter, REG_RXFLTMAP0, 0xFFEF); /* REG_RXFLTMAP0 (RX Filter Map Group 0) */
+			pmppriv->brx_filter_beacon = _TRUE;
 
 		} else {
 			pHalData->ReceiveConfig |= RCR_ADF;
@@ -2026,6 +2207,167 @@ u32 GetPhyRxPktCRC32Error(PADAPTER pAdapter)
 	return OFDM_cnt + CCK_cnt + HT_cnt;
 }
 
+struct psd_init_regs {
+	/* 3 wire */
+	int reg_88c;
+	int reg_c00;
+	int reg_e00;
+	int reg_1800;
+	int reg_1a00;
+	/* cck */
+	int reg_800;
+	int reg_808;
+};
+
+static int rtw_mp_psd_init(PADAPTER padapter, struct psd_init_regs *regs)
+{
+	HAL_DATA_TYPE	*phal_data	= GET_HAL_DATA(padapter);
+
+	switch (phal_data->rf_type) {
+	/* 1R */
+	case RF_1T1R:
+		if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
+			/* 11AC 1R PSD Setting 3wire & cck off */
+			regs->reg_c00 = rtw_read32(padapter, 0xC00);
+			phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
+			regs->reg_808 = rtw_read32(padapter, 0x808);
+			phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
+		} else {
+			/* 11N 3-wire off 1 */
+			regs->reg_88c = rtw_read32(padapter, 0x88C);
+			phy_set_bb_reg(padapter, 0x88C, 0x300000, 0x3);
+			/* 11N CCK off */
+			regs->reg_800 = rtw_read32(padapter, 0x800);
+			phy_set_bb_reg(padapter, 0x800, 0x1000000, 0x0);
+		}
+	break;
+
+	/* 2R */
+	case RF_1T2R:
+	case RF_2T2R:
+		if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
+			/* 11AC 2R PSD Setting 3wire & cck off */
+			regs->reg_c00 = rtw_read32(padapter, 0xC00);
+			regs->reg_e00 = rtw_read32(padapter, 0xE00);
+			phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
+			phy_set_bb_reg(padapter, 0xE00, 0x3, 0x00);
+			regs->reg_808 = rtw_read32(padapter, 0x808);
+			phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
+		} else {
+			/* 11N 3-wire off 2 */
+			regs->reg_88c = rtw_read32(padapter, 0x88C);
+			phy_set_bb_reg(padapter, 0x88C, 0xF00000, 0xF);
+			/* 11N CCK off */
+			regs->reg_800 = rtw_read32(padapter, 0x800);
+			phy_set_bb_reg(padapter, 0x800, 0x1000000, 0x0);
+		}
+	break;
+
+	/* 3R */
+	case RF_2T3R:
+	case RF_3T3R:
+		if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
+			/* 11AC 3R PSD Setting 3wire & cck off */
+			regs->reg_c00 = rtw_read32(padapter, 0xC00);
+			regs->reg_e00 = rtw_read32(padapter, 0xE00);
+			regs->reg_1800 = rtw_read32(padapter, 0x1800);
+			phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
+			phy_set_bb_reg(padapter, 0xE00, 0x3, 0x00);
+			phy_set_bb_reg(padapter, 0x1800, 0x3, 0x00);
+			regs->reg_808 = rtw_read32(padapter, 0x808);
+			phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
+		} else {
+			RTW_ERR("%s: 11n don't support 3R\n", __func__);
+			return -1;
+		}
+		break;
+
+	/* 4R */
+	case RF_2T4R:
+	case RF_3T4R:
+	case RF_4T4R:
+		if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
+			/* 11AC 4R PSD Setting 3wire & cck off */
+			regs->reg_c00 = rtw_read32(padapter, 0xC00);
+			regs->reg_e00 = rtw_read32(padapter, 0xE00);
+			regs->reg_1800 = rtw_read32(padapter, 0x1800);
+			regs->reg_1a00 = rtw_read32(padapter, 0x1A00);
+			phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
+			phy_set_bb_reg(padapter, 0xE00, 0x3, 0x00);
+			phy_set_bb_reg(padapter, 0x1800, 0x3, 0x00);
+			phy_set_bb_reg(padapter, 0x1A00, 0x3, 0x00);
+			regs->reg_808 = rtw_read32(padapter, 0x808);
+			phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
+		} else {
+			RTW_ERR("%s: 11n don't support 4R\n", __func__);
+			return -1;
+		}
+		break;
+
+	default:
+		RTW_ERR("%s: unknown %d rf type\n", __func__, phal_data->rf_type);
+		return -1;
+	}
+
+	/* Set PSD points, 0=128, 1=256, 2=512, 3=1024 */
+	if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC))
+		phy_set_bb_reg(padapter, 0x910, 0xC000, 3);
+	else
+		phy_set_bb_reg(padapter, 0x808, 0xC000, 3);
+
+	RTW_INFO("%s: set %d rf type done\n", __func__, phal_data->rf_type);
+	return 0;
+}
+
+static int rtw_mp_psd_close(PADAPTER padapter, struct psd_init_regs *regs)
+{
+	HAL_DATA_TYPE	*phal_data	= GET_HAL_DATA(padapter);
+
+
+	if (!hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
+		/* 11n 3wire restore */
+		rtw_write32(padapter, 0x88C, regs->reg_88c);
+		/* 11n cck restore */
+		rtw_write32(padapter, 0x800, regs->reg_800);
+		RTW_INFO("%s: restore %d rf type\n", __func__, phal_data->rf_type);
+		return 0;
+	}
+
+	/* 11ac 3wire restore */
+	switch (phal_data->rf_type) {
+	case RF_1T1R:
+		rtw_write32(padapter, 0xC00, regs->reg_c00);
+		break;
+	case RF_1T2R:
+	case RF_2T2R:
+		rtw_write32(padapter, 0xC00, regs->reg_c00);
+		rtw_write32(padapter, 0xE00, regs->reg_e00);
+		break;
+	case RF_2T3R:
+	case RF_3T3R:
+		rtw_write32(padapter, 0xC00, regs->reg_c00);
+		rtw_write32(padapter, 0xE00, regs->reg_e00);
+		rtw_write32(padapter, 0x1800, regs->reg_1800);
+		break;
+	case RF_2T4R:
+	case RF_3T4R:
+	case RF_4T4R:
+		rtw_write32(padapter, 0xC00, regs->reg_c00);
+		rtw_write32(padapter, 0xE00, regs->reg_e00);
+		rtw_write32(padapter, 0x1800, regs->reg_1800);
+		rtw_write32(padapter, 0x1A00, regs->reg_1a00);
+		break;
+	default:
+		RTW_WARN("%s: unknown %d rf type\n", __func__, phal_data->rf_type);
+		break;
+	}
+
+	/* 11ac cck restore */
+	rtw_write32(padapter, 0x808, regs->reg_808);
+	RTW_INFO("%s: restore %d rf type done\n", __func__, phal_data->rf_type);
+	return 0;
+}
+
 /* reg 0x808[9:0]: FFT data x
  * reg 0x808[22]:  0  -->  1  to get 1 FFT data y
  * reg 0x8B4[15:0]: FFT data y report */
@@ -2054,7 +2396,11 @@ static u32 rtw_GetPSDData(PADAPTER pAdapter, u32 point)
 	rtw_mdelay_os(1);
 
 	psd_val = rtw_read32(pAdapter, psd_regL);
+#if defined(CONFIG_RTL8821C)
+	psd_val = (psd_val & 0x00FFFFFF) / 32;
+#else
 	psd_val &= 0x0000FFFF;
+#endif
 
 	return psd_val;
 }
@@ -2071,7 +2417,8 @@ u32 mp_query_psd(PADAPTER pAdapter, u8 *data)
 {
 	u32 i, psd_pts = 0, psd_start = 0, psd_stop = 0;
 	u32 psd_data = 0;
-
+	struct psd_init_regs regs = {};
+	int psd_analysis = 0;
 
 #ifdef PLATFORM_LINUX
 	if (!netif_running(pAdapter->pnetdev)) {
@@ -2087,6 +2434,11 @@ u32 mp_query_psd(PADAPTER pAdapter, u8 *data)
 		psd_pts = 128;
 		psd_start = 64;
 		psd_stop = 128;
+	} else if (strncmp(data, "analysis,", 9) == 0) {
+		if (rtw_mp_psd_init(pAdapter, &regs) != 0)
+			return 0;
+		psd_analysis = 1;
+		sscanf(data + 9, "pts=%d,start=%d,stop=%d", &psd_pts, &psd_start, &psd_stop);
 	} else
 		sscanf(data, "pts=%d,start=%d,stop=%d", &psd_pts, &psd_start, &psd_stop);
 
@@ -2108,6 +2460,9 @@ u32 mp_query_psd(PADAPTER pAdapter, u8 *data)
 	rtw_mdelay_os(100);
 #endif
 
+	if (psd_analysis)
+		rtw_mp_psd_close(pAdapter, &regs);
+
 	return strlen(data) + 1;
 }
 
@@ -2704,7 +3059,6 @@ ULONG mpt_ProQueryCalTxPower(
 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
 
 	ULONG			TxPower = 1;
-	u1Byte			rate = 0;
 	struct txpwr_idx_comp tic;
 	u8 mgn_rate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
 
@@ -2715,10 +3069,14 @@ ULONG mpt_ProQueryCalTxPower(
 		, TxPower, tic.base, (tic.by_rate > tic.limit ? tic.limit : tic.by_rate), tic.by_rate, tic.limit, tic.tpt, tic.ebias);
 
 	pAdapter->mppriv.txpoweridx = (u8)TxPower;
-	pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)TxPower;
-	pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)TxPower;
-	pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)TxPower;
-	pMptCtx->TxPwrLevel[RF_PATH_D]  = (u8)TxPower;
+	if (RfPath == RF_PATH_A)
+		pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)TxPower;
+	else if (RfPath == RF_PATH_B)
+		pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)TxPower;
+	else if (RfPath == RF_PATH_C)
+		pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)TxPower;
+	else if (RfPath == RF_PATH_D)
+		pMptCtx->TxPwrLevel[RF_PATH_D]    = (u8)TxPower;
 	hal_mpt_SetTxPower(pAdapter);
 
 	return TxPower;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp_ioctl.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp_ioctl.c
index 035d2815d76a..08d4e980165f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp_ioctl.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_mp_ioctl.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_odm.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_odm.c
index d5833b94fa9a..098c579c8701 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_odm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_odm.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -19,7 +20,7 @@
 u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT *podmpriv = &pHalData->odmpriv;
+	struct dm_struct *podmpriv = &pHalData->odmpriv;
 	u32 result = 0;
 
 	switch (ops) {
@@ -56,7 +57,7 @@ u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability)
 /* set ODM_CMNINFO_IC_TYPE based on chip_type */
 void rtw_odm_init_ic_type(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *odm = adapter_to_phydm(adapter);
+	struct dm_struct *odm = adapter_to_phydm(adapter);
 	u4Byte ic_type = chip_type_to_odm_ic_type(rtw_get_chip_type(adapter));
 
 	rtw_warn_on(!ic_type);
@@ -103,43 +104,16 @@ void rtw_odm_adaptivity_mode_msg(void *sel, _adapter *adapter)
 		_RTW_PRINT_SEL(sel, "INVALID\n");
 }
 
-#define RTW_ADAPTIVITY_DML_DISABLE 0
-#define RTW_ADAPTIVITY_DML_ENABLE 1
-
-void rtw_odm_adaptivity_dml_msg(void *sel, _adapter *adapter)
-{
-	struct registry_priv *regsty = &adapter->registrypriv;
-
-	RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_DML_");
-
-	if (regsty->adaptivity_dml == RTW_ADAPTIVITY_DML_DISABLE)
-		_RTW_PRINT_SEL(sel, "DISABLE\n");
-	else if (regsty->adaptivity_dml == RTW_ADAPTIVITY_DML_ENABLE)
-		_RTW_PRINT_SEL(sel, "ENABLE\n");
-	else
-		_RTW_PRINT_SEL(sel, "INVALID\n");
-}
-
-void rtw_odm_adaptivity_dc_backoff_msg(void *sel, _adapter *adapter)
-{
-	struct registry_priv *regsty = &adapter->registrypriv;
-
-	RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_DC_BACKOFF:%u\n", regsty->adaptivity_dc_backoff);
-}
-
 void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter)
 {
 	rtw_odm_adaptivity_ver_msg(sel, adapter);
 	rtw_odm_adaptivity_en_msg(sel, adapter);
 	rtw_odm_adaptivity_mode_msg(sel, adapter);
-	rtw_odm_adaptivity_dml_msg(sel, adapter);
-	rtw_odm_adaptivity_dc_backoff_msg(sel, adapter);
 }
 
 bool rtw_odm_adaptivity_needed(_adapter *adapter)
 {
 	struct registry_priv *regsty = &adapter->registrypriv;
-	struct mlme_priv *mlme = &adapter->mlmepriv;
 	bool ret = _FALSE;
 
 	if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_ENABLE)
@@ -150,44 +124,32 @@ bool rtw_odm_adaptivity_needed(_adapter *adapter)
 
 void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter)
 {
-	struct PHY_DM_STRUCT *odm = adapter_to_phydm(adapter);
+	struct dm_struct *odm = adapter_to_phydm(adapter);
 
 	rtw_odm_adaptivity_config_msg(sel, adapter);
 
-	RTW_PRINT_SEL(sel, "%10s %16s %16s %22s %12s\n"
-		, "th_l2h_ini", "th_edcca_hl_diff", "th_l2h_ini_mode2", "th_edcca_hl_diff_mode2", "edcca_enable");
-	RTW_PRINT_SEL(sel, "0x%-8x %-16d 0x%-14x %-22d %-12d\n"
+	RTW_PRINT_SEL(sel, "%10s %16s\n"
+		, "th_l2h_ini", "th_edcca_hl_diff");
+	RTW_PRINT_SEL(sel, "0x%-8x %-16d\n"
 		, (u8)odm->th_l2h_ini
 		, odm->th_edcca_hl_diff
-		, (u8)odm->th_l2h_ini_mode2
-		, odm->th_edcca_hl_diff_mode2
-		, odm->edcca_enable
-	);
-
-	RTW_PRINT_SEL(sel, "%15s %9s\n", "AdapEnableState", "Adap_Flag");
-	RTW_PRINT_SEL(sel, "%-15x %-9x\n"
-		, odm->adaptivity_enable
-		, odm->adaptivity_flag
 	);
 }
 
-void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff, s8 th_l2h_ini_mode2, s8 th_edcca_hl_diff_mode2, u8 edcca_enable)
+void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff)
 {
-	struct PHY_DM_STRUCT *odm = adapter_to_phydm(adapter);
+	struct dm_struct *odm = adapter_to_phydm(adapter);
 
 	odm->th_l2h_ini = th_l2h_ini;
 	odm->th_edcca_hl_diff = th_edcca_hl_diff;
-	odm->th_l2h_ini_mode2 = th_l2h_ini_mode2;
-	odm->th_edcca_hl_diff_mode2 = th_edcca_hl_diff_mode2;
-	odm->edcca_enable = edcca_enable;
 }
 
 void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter)
 {
-	struct PHY_DM_STRUCT *odm = adapter_to_phydm(adapter);
+	struct dm_struct *odm = adapter_to_phydm(adapter);
 
-	RTW_PRINT_SEL(sel, "rx_rate = %s, RSSI_A = %d(%%), RSSI_B = %d(%%)\n",
-		      HDATA_RATE(odm->rx_rate), odm->RSSI_A, odm->RSSI_B);
+	RTW_PRINT_SEL(sel, "rx_rate = %s, rssi_a = %d(%%), rssi_b = %d(%%)\n",
+		      HDATA_RATE(odm->rx_rate), odm->rssi_a, odm->rssi_b);
 }
 
 
@@ -217,10 +179,10 @@ void rtw_odm_releasespinlock(_adapter *adapter,	enum rt_spinlock_type type)
 	}
 }
 
-inline u8 rtw_odm_get_dfs_domain(_adapter *adapter)
+inline u8 rtw_odm_get_dfs_domain(struct dvobj_priv *dvobj)
 {
 #ifdef CONFIG_DFS_MASTER
-	struct PHY_DM_STRUCT *pDM_Odm = adapter_to_phydm(adapter);
+	struct dm_struct *pDM_Odm = dvobj_to_phydm(dvobj);
 
 	return pDM_Odm->dfs_region_domain;
 #else
@@ -228,10 +190,10 @@ inline u8 rtw_odm_get_dfs_domain(_adapter *adapter)
 #endif
 }
 
-inline u8 rtw_odm_dfs_domain_unknown(_adapter *adapter)
+inline u8 rtw_odm_dfs_domain_unknown(struct dvobj_priv *dvobj)
 {
 #ifdef CONFIG_DFS_MASTER
-	return rtw_odm_get_dfs_domain(adapter) == PHYDM_DFS_DOMAIN_UNKNOWN;
+	return rtw_odm_get_dfs_domain(dvobj) == PHYDM_DFS_DOMAIN_UNKNOWN;
 #else
 	return 1;
 #endif
@@ -258,6 +220,11 @@ inline BOOLEAN rtw_odm_radar_detect(_adapter *adapter)
 {
 	return phydm_radar_detect(adapter_to_phydm(adapter));
 }
+
+inline u8 rtw_odm_radar_detect_polling_int_ms(struct dvobj_priv *dvobj)
+{
+	return phydm_dfs_polling_time(dvobj_to_phydm(dvobj));
+}
 #endif /* CONFIG_DFS_MASTER */
 
 void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)
@@ -268,11 +235,11 @@ void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)
 
 #if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
 	_adapter *adapter = rframe->u.hdr.adapter;
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
 	struct rx_pkt_attrib *attrib = &rframe->u.hdr.attrib;
 	u8 *wlanhdr = get_recvframe_data(rframe);
 
-	if (phydm->support_ic_type & ODM_IC_PHY_STATUE_NEW_TYPE) {
+	if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
 		/*
 		* 8723D:
 		* type_0(CCK)
@@ -301,7 +268,7 @@ void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)
 		*/
 
 		if ((*phys & 0xf) == 0) {
-			struct _phy_status_rpt_jaguar2_type0 *phys_t0 = (struct _phy_status_rpt_jaguar2_type0 *)phys;
+			struct phy_sts_rpt_jgr2_type0 *phys_t0 = (struct phy_sts_rpt_jgr2_type0 *)phys;
 
 			if (DBG_RX_PHYSTATUS_CHINFO) {
 				RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u)\n"
@@ -314,7 +281,7 @@ void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)
 			}
 
 		} else if ((*phys & 0xf) == 1) {
-			struct _phy_status_rpt_jaguar2_type1 *phys_t1 = (struct _phy_status_rpt_jaguar2_type1 *)phys;
+			struct phy_sts_rpt_jgr2_type1 *phys_t1 = (struct phy_sts_rpt_jgr2_type1 *)phys;
 			u8 rxsc = (attrib->data_rate > DESC_RATE11M && attrib->data_rate < DESC_RATEMCS0) ? phys_t1->l_rxsc : phys_t1->ht_rxsc;
 			u8 pkt_cch = 0;
 			u8 pkt_bw = CHANNEL_WIDTH_20;
@@ -435,7 +402,7 @@ type1_end:
 				attrib->ch = pkt_cch;
 
 		} else {
-			struct _phy_status_rpt_jaguar2_type2 *phys_t2 = (struct _phy_status_rpt_jaguar2_type2 *)phys;
+			struct phy_sts_rpt_jgr2_type2 *phys_t2 = (struct phy_sts_rpt_jgr2_type2 *)phys;
 
 			if (DBG_RX_PHYSTATUS_CHINFO) {
 				RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u, ht_rxsc:%u)\n"
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_p2p.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_p2p.c
index 180bca4a1e5b..83567b54b4bb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_p2p.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_p2p.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -290,7 +291,6 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr,
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
@@ -2807,8 +2807,6 @@ u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe
 		u8	attr_content = 0x00;
 		u32	attr_contentlen = 0;
 		u8	operatingch_info[5] = { 0x00 };
-		uint	ch_cnt = 0;
-		u8	ch_content[100] = { 0x00 };
 		u8	groupid[38];
 		u16	cap_attr;
 		u8	peer_ch_list[100] = { 0x00 };
@@ -2974,7 +2972,9 @@ u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe
 
 u8 process_p2p_group_negotation_confirm(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
 {
+#ifdef CONFIG_CONCURRENT_MODE
 	_adapter *padapter = pwdinfo->padapter;
+#endif
 	u8 *ies;
 	u32 ies_len;
 	u8 *p2p_ie;
@@ -3097,8 +3097,6 @@ void p2p_concurrent_handler(_adapter *padapter);
 void restore_p2p_state_handler(_adapter	*padapter)
 {
 	struct wifidirect_info  *pwdinfo = &padapter->wdinfo;
-	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
-
 
 	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
 		rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
@@ -3175,6 +3173,12 @@ void p2p_concurrent_handler(_adapter	*padapter)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	u8					val8;
 
+#ifdef CONFIG_IOCTL_CFG80211
+	if (pwdinfo->driver_interface == DRIVER_CFG80211
+		&& !rtw_cfg80211_get_is_roch(padapter))
+		return;
+#endif
+
 	if (rtw_mi_check_status(padapter, MI_LINKED)) {
 		u8 union_ch = rtw_mi_get_union_chan(padapter);
 		u8 union_bw = rtw_mi_get_union_bw(padapter);
@@ -3183,7 +3187,8 @@ void p2p_concurrent_handler(_adapter	*padapter)
 		pwdinfo->operating_channel = union_ch;
 
 		if (pwdinfo->driver_interface == DRIVER_CFG80211) {
-			RTW_INFO("%s, switch ch back to union_ch=%d\n", __func__, union_ch);
+			RTW_INFO("%s, switch ch back to union=%u,%u, %u\n"
+				, __func__, union_ch, union_bw, union_offset);
 			set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
 			rtw_back_opch(padapter);
 
@@ -3275,7 +3280,7 @@ void p2p_concurrent_handler(_adapter	*padapter)
 #endif
 
 #ifdef CONFIG_IOCTL_CFG80211
-static u8 _stay_in_cur_chan(_adapter *padapter)
+u8 roch_stay_in_cur_chan(_adapter *padapter)
 {
 	int i;
 	_adapter *iface;
@@ -3288,16 +3293,15 @@ static u8 _stay_in_cur_chan(_adapter *padapter)
 		if (iface) {
 			pmlmepriv = &iface->mlmepriv;
 
-			if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS) == _TRUE) {
-				RTW_ERR(ADPT_FMT"- _FW_UNDER_LINKING |WIFI_UNDER_WPS (mlme state:0x%x)\n",
+			if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS | WIFI_UNDER_KEY_HANDSHAKE) == _TRUE) {
+				RTW_INFO(ADPT_FMT"- _FW_UNDER_LINKING |WIFI_UNDER_WPS | WIFI_UNDER_KEY_HANDSHAKE (mlme state:0x%x)\n",
 						ADPT_ARG(iface), get_fwstate(&iface->mlmepriv));
 				rst = _TRUE;
 				break;
 			}
 			#ifdef CONFIG_AP_MODE
 			if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
-				if (rtw_ap_sta_linking_state_check(iface) == _TRUE) {
-					RTW_ERR(ADPT_FMT"- SoftAP/Mesh -have sta under linking\n", ADPT_ARG(iface));
+				if (rtw_ap_sta_states_check(iface) == _TRUE) {
 					rst = _TRUE;
 					break;
 				}
@@ -3315,8 +3319,12 @@ static int ro_ch_handler(_adapter *adapter, u8 *buf)
 	struct p2p_roch_parm *roch_parm = (struct p2p_roch_parm *)buf;
 	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
 	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &adapter->cfg80211_wdinfo;
-	struct wifidirect_info *pwdinfo = &adapter->wdinfo;
+#ifdef CONFIG_CONCURRENT_MODE
 	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+#ifdef RTW_ROCH_BACK_OP
+	struct wifidirect_info *pwdinfo = &adapter->wdinfo;
+#endif
+#endif
 	u8 ready_on_channel = _FALSE;
 	u8 remain_ch;
 	unsigned int duration;
@@ -3326,7 +3334,7 @@ static int ro_ch_handler(_adapter *adapter, u8 *buf)
 	if (rtw_cfg80211_get_is_roch(adapter) != _TRUE)
 		goto exit;
 
-	remain_ch = (u8) ieee80211_frequency_to_channel(roch_parm->ch.center_freq);
+	remain_ch = (u8)ieee80211_frequency_to_channel(roch_parm->ch.center_freq);
 	duration = roch_parm->duration;
 
 	RTW_INFO(FUNC_ADPT_FMT" ch:%u duration:%d, cookie:0x%llx\n"
@@ -3346,7 +3354,7 @@ static int ro_ch_handler(_adapter *adapter, u8 *buf)
 		}
 	}
 
-	if (_stay_in_cur_chan(adapter) == _TRUE) {
+	if (roch_stay_in_cur_chan(adapter) == _TRUE) {
 		remain_ch = rtw_mi_get_union_chan(adapter);
 		RTW_INFO(FUNC_ADPT_FMT" stay in union ch:%d\n", FUNC_ADPT_ARG(adapter), remain_ch);
 	}
@@ -3354,12 +3362,11 @@ static int ro_ch_handler(_adapter *adapter, u8 *buf)
 	#ifdef CONFIG_CONCURRENT_MODE
 	if (rtw_mi_check_status(adapter, MI_LINKED) && (0 != rtw_mi_get_union_chan(adapter))) {
 		if ((remain_ch != rtw_mi_get_union_chan(adapter)) && !check_fwstate(&adapter->mlmepriv, _FW_LINKED)) {
-			if (
+			if (remain_ch != pmlmeext->cur_channel
 				#ifdef RTW_ROCH_BACK_OP
-				ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1 ||
+				|| ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1
 				#endif
-				(remain_ch != pmlmeext->cur_channel)) {
-
+			) {
 				rtw_leave_opch(adapter);
 
 				#ifdef RTW_ROCH_BACK_OP
@@ -3434,6 +3441,11 @@ static int cancel_ro_ch_handler(_adapter *padapter, u8 *buf)
 		}
 	}
 
+#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_CONCURRENT_MODE)
+	_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
+	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
+#endif
+
 	if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
 		if (0)
 			RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
@@ -3455,8 +3467,7 @@ static int cancel_ro_ch_handler(_adapter *padapter, u8 *buf)
 	}
 
 	set_channel_bwmode(padapter, ch, offset, bw);
-	if (rtw_mi_check_status(padapter, MI_LINKED))
-		rtw_back_opch(padapter);
+	rtw_back_opch(padapter);
 
 	rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
 #ifdef CONFIG_DEBUG_CFG80211
@@ -3467,7 +3478,7 @@ static int cancel_ro_ch_handler(_adapter *padapter, u8 *buf)
 
 	rtw_cfg80211_set_is_roch(padapter, _FALSE);
 	pcfg80211_wdinfo->ro_ch_wdev = NULL;
-	pcfg80211_wdinfo->last_ro_ch_time = rtw_get_current_time();
+	rtw_cfg80211_set_last_ro_ch_time(padapter);
 
 	rtw_cfg80211_remain_on_channel_expired(wdev
 		, pcfg80211_wdinfo->remain_on_ch_cookie
@@ -3494,6 +3505,7 @@ static void ro_ch_timer_process(void *FunctionContext)
 	p2p_cancel_roch_cmd(adapter, 0, NULL, 0);
 }
 
+#if 0
 static void rtw_change_p2pie_op_ch(_adapter *padapter, const u8 *frame_body, u32 len, u8 ch)
 {
 	u8 *ies, *p2p_ie;
@@ -3524,7 +3536,9 @@ static void rtw_change_p2pie_op_ch(_adapter *padapter, const u8 *frame_body, u32
 		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 }
+#endif
 
+#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
 static void rtw_change_p2pie_ch_list(_adapter *padapter, const u8 *frame_body, u32 len, u8 ch)
 {
 	u8 *ies, *p2p_ie;
@@ -3568,11 +3582,12 @@ static void rtw_change_p2pie_ch_list(_adapter *padapter, const u8 *frame_body, u
 		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
 }
+#endif
 
+#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
 static bool rtw_chk_p2pie_ch_list_with_buddy(_adapter *padapter, const u8 *frame_body, u32 len)
 {
 	bool fit = _FALSE;
-#ifdef CONFIG_CONCURRENT_MODE
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
 	u8 union_ch = rtw_mi_get_union_chan(padapter);
@@ -3614,14 +3629,14 @@ static bool rtw_chk_p2pie_ch_list_with_buddy(_adapter *padapter, const u8 *frame
 		/* Get the next P2P IE */
 		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
-#endif
+
 	return fit;
 }
 
+#if defined(CONFIG_P2P_INVITE_IOT)
 static bool rtw_chk_p2pie_op_ch_with_buddy(_adapter *padapter, const u8 *frame_body, u32 len)
 {
 	bool fit = _FALSE;
-#ifdef CONFIG_CONCURRENT_MODE
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
 	u8 union_ch = rtw_mi_get_union_chan(padapter);
@@ -3650,13 +3665,13 @@ static bool rtw_chk_p2pie_op_ch_with_buddy(_adapter *padapter, const u8 *frame_b
 		/* Get the next P2P IE */
 		p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
 	}
-#endif
+
 	return fit;
 }
+#endif
 
 static void rtw_cfg80211_adjust_p2pie_channel(_adapter *padapter, const u8 *frame_body, u32 len)
 {
-#ifdef CONFIG_CONCURRENT_MODE
 	u8 *ies, *p2p_ie;
 	u32 ies_len, p2p_ielen;
 	u8 union_ch = rtw_mi_get_union_chan(padapter);
@@ -3719,8 +3734,8 @@ static void rtw_cfg80211_adjust_p2pie_channel(_adapter *padapter, const u8 *fram
 
 	}
 
-#endif
 }
+#endif
 
 #ifdef CONFIG_WFD
 u32 rtw_xframe_build_wfd_ie(struct xmit_frame *xframe)
@@ -3804,8 +3819,6 @@ u32 rtw_xframe_build_wfd_ie(struct xmit_frame *xframe)
 bool rtw_xframe_del_wfd_ie(struct xmit_frame *xframe)
 {
 #define DBG_XFRAME_DEL_WFD_IE 0
-
-	_adapter *adapter = xframe->padapter;
 	u8 *frame = xframe->buf_addr + TXDESC_OFFSET;
 	u8 *frame_body = frame + sizeof(struct rtw_ieee80211_hdr_3addr);
 	u8 *frame_tail = frame + xframe->attrib.pktlen;
@@ -3852,12 +3865,9 @@ bool rtw_xframe_del_wfd_ie(struct xmit_frame *xframe)
 void rtw_xframe_chk_wfd_ie(struct xmit_frame *xframe)
 {
 	_adapter *adapter = xframe->padapter;
-	u8 *frame = xframe->buf_addr + TXDESC_OFFSET;
-	u8 *frame_body = frame + sizeof(struct rtw_ieee80211_hdr_3addr);
-	u8 *frame_tail = frame + xframe->attrib.pktlen;
-
+#ifdef CONFIG_IOCTL_CFG80211
 	struct wifidirect_info *wdinfo = &adapter->wdinfo;
-	struct mlme_priv *mlme = &adapter->mlmepriv;
+#endif
 	u8 build = 0;
 	u8 del = 0;
 
@@ -3865,7 +3875,7 @@ void rtw_xframe_chk_wfd_ie(struct xmit_frame *xframe)
 		del = 1;
 
 #ifdef CONFIG_IOCTL_CFG80211
-	if (_TRUE == wdinfo->wfd_info->wfd_enable)
+	if (wdinfo->wfd_info->wfd_enable == _TRUE)
 #endif
 		del = build = 1;
 
@@ -3885,7 +3895,6 @@ u8 *dump_p2p_attr_ch_list(u8 *p2p_ie, uint p2p_ielen, u8 *buf, u32 buf_len)
 	int w_sz = 0;
 	u8 ch_cnt = 0;
 	u8 ch_list[40];
-	bool continuous = _FALSE;
 
 	pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, &attr_contentlen);
 	if (pattr != NULL) {
@@ -4188,10 +4197,13 @@ int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx)
 				if (!tx) {
 					#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
 					if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
+						#if defined(CONFIG_P2P_INVITE_IOT)
 						if (op_ch != -1 && rtw_chk_p2pie_op_ch_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
 							RTW_INFO(FUNC_ADPT_FMT" op_ch:%u has no intersect with buddy\n", FUNC_ADPT_ARG(padapter), op_ch);
 							rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
-						} else if (rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
+						} else
+						#endif
+						if (rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
 							RTW_INFO(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
 							rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
 						}
@@ -4341,7 +4353,6 @@ void rtw_init_cfg80211_wifidirect_info(_adapter	*padapter)
 s32 p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType, u8 *buf)
 {
 	int ret = H2C_SUCCESS;
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	switch (intCmdType) {
 	case P2P_FIND_PHASE_WK:
@@ -4418,7 +4429,6 @@ int process_p2p_cross_connect_ie(PADAPTER padapter, u8 *IEs, u32 IELength)
 	u8	p2p_attr[MAX_P2P_IE_LEN] = { 0x00 };/* NoA length should be n*(13) + 2 */
 	u32	attr_contentlen = 0;
 
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
 	if (IELength <= _BEACON_IE_OFFSET_)
@@ -4541,7 +4551,6 @@ void p2p_ps_wk_hdl(_adapter *padapter, u8 p2p_ps_state)
 {
 	struct pwrctrl_priv		*pwrpriv = adapter_to_pwrctl(padapter);
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	u32 ps_deny = 0;
 
 	/* Pre action for p2p state */
@@ -4608,6 +4617,9 @@ void p2p_ps_wk_hdl(_adapter *padapter, u8 p2p_ps_state)
 		break;
 	}
 
+#ifdef CONFIG_MCC_MODE
+	rtw_hal_mcc_process_noa(padapter);
+#endif /* CONFIG_MCC_MODE */
 }
 
 u8 p2p_ps_wk_cmd(_adapter *padapter, u8 p2p_ps_state, u8 enqueue)
@@ -4716,7 +4728,6 @@ static void pre_tx_scan_timer_process(void *FunctionContext)
 	struct	wifidirect_info				*pwdinfo = &adapter->wdinfo;
 	_irqL							irqL;
 	struct mlme_priv					*pmlmepriv = &adapter->mlmepriv;
-	u8								_status = 0;
 
 	if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
 		return;
@@ -5030,7 +5041,6 @@ void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role)
 #ifdef CONFIG_WFD
 	struct wifi_display_info	*pwfd_info = &padapter->wfd_info;
 #endif
-	u8 union_ch = 0;
 	pwdinfo = &padapter->wdinfo;
 
 	pwdinfo->padapter = padapter;
@@ -5045,6 +5055,8 @@ void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role)
 		&& pwdinfo->driver_interface != DRIVER_CFG80211
 	) {
 		#ifdef CONFIG_CONCURRENT_MODE
+		u8 union_ch = 0;
+
 		if (rtw_mi_check_status(padapter, MI_LINKED))
 			union_ch = rtw_mi_get_union_chan(padapter);
 
@@ -5180,6 +5192,14 @@ void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role)
 	pwdinfo->p2p_info.scan_op_ch_only = 0;
 }
 
+void _rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)
+{
+	if (wdinfo->role != role) {
+		wdinfo->role = role;
+		rtw_mi_update_iface_status(&(wdinfo->padapter->mlmepriv), 0);
+	}
+}
+
 #ifdef CONFIG_DBG_P2P
 
 /**
@@ -5328,9 +5348,6 @@ int rtw_p2p_enable(_adapter *padapter, enum P2P_ROLE role)
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 
 	if (role == P2P_ROLE_DEVICE || role == P2P_ROLE_CLIENT || role == P2P_ROLE_GO) {
-		u8 channel, ch_offset;
-		u16 bwmode;
-
 #if defined(CONFIG_CONCURRENT_MODE) && (!defined(RTW_P2P_GROUP_INTERFACE) || !RTW_P2P_GROUP_INTERFACE)
 		/*	Commented by Albert 2011/12/30 */
 		/*	The driver just supports 1 P2P group operation. */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_pwrctrl.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_pwrctrl.c
index c43a954c4167..d761f0379e1e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_pwrctrl.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_pwrctrl.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -18,13 +19,13 @@
 #include <hal_data.h>
 #include <hal_com_h2c.h>
 
+#ifdef DBG_CHECK_FW_PS_STATE
 int rtw_fw_ps_state(PADAPTER padapter)
 {
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	int ret = _FAIL, dont_care = 0;
 	u16 fw_ps_state = 0;
-	u32 start_time;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct registry_priv  *registry_par = &padapter->registrypriv;
 
@@ -40,6 +41,15 @@ int rtw_fw_ps_state(PADAPTER padapter)
 			 , rtw_is_drv_stopped(padapter) ? "True" : "False");
 		goto exit_fw_ps_state;
 	}
+	#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
+	rtw_hal_get_hwreg(padapter, HW_VAR_FW_PS_STATE, (u8 *)&fw_ps_state);
+	if ((fw_ps_state & BIT_LPS_STATUS) == 0)
+		ret = _SUCCESS;
+	else {
+		pdbgpriv->dbg_poll_fail_cnt++;
+		RTW_INFO("%s: fw_ps_state=%04x\n", __FUNCTION__, fw_ps_state);
+	}
+	#else
 	rtw_hal_set_hwreg(padapter, HW_VAR_SET_REQ_FW_PS, (u8 *)&dont_care);
 	{
 		/* 4. if 0x88[7]=1, driver set cmd to leave LPS/IPS. */
@@ -58,13 +68,13 @@ int rtw_fw_ps_state(PADAPTER padapter)
 			RTW_INFO("%s: fw_ps_state=%04x\n", __FUNCTION__, fw_ps_state);
 		}
 	}
-
+	#endif
 
 exit_fw_ps_state:
 	_exit_pwrlock(&pwrpriv->check_32k_lock);
 	return ret;
 }
-
+#endif /*DBG_CHECK_FW_PS_STATE*/
 #ifdef CONFIG_IPS
 void _ips_enter(_adapter *padapter)
 {
@@ -85,6 +95,10 @@ void _ips_enter(_adapter *padapter)
 		if (pwrpriv->ips_mode == IPS_LEVEL_2)
 			pwrpriv->bkeepfwalive = _TRUE;
 
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS		
+		pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 		rtw_ips_pwr_down(padapter);
 		pwrpriv->rf_pwrstate = rf_off;
 	}
@@ -120,6 +134,11 @@ int _ips_leave(_adapter *padapter)
 		result = rtw_ips_pwr_up(padapter);
 		if (result == _SUCCESS)
 			pwrpriv->rf_pwrstate = rf_on;
+		
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS	
+		pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 		RTW_PRINT("nolinked power save leave\n");
 
 		RTW_INFO("==> ips_leave.....LED(0x%08x)...\n", rtw_read32(padapter, 0x4c));
@@ -135,8 +154,10 @@ int _ips_leave(_adapter *padapter)
 int ips_leave(_adapter *padapter)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+#ifdef DBG_CHECK_FW_PS_STATE
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+#endif
 	int ret;
 
 	if (!is_primary_adapter(padapter))
@@ -183,9 +204,6 @@ bool rtw_pwr_unassociated_idle(_adapter *adapter)
 	struct mlme_priv *pmlmepriv;
 #ifdef CONFIG_P2P
 	struct wifidirect_info	*pwdinfo;
-#ifdef CONFIG_IOCTL_CFG80211
-	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
-#endif
 #endif
 
 	bool ret = _FALSE;
@@ -195,7 +213,7 @@ bool rtw_pwr_unassociated_idle(_adapter *adapter)
 		goto exit;
 	}
 
-	if (time_after(adapter_to_pwrctl(adapter)->ips_deny_time, rtw_get_current_time())) {
+	if (rtw_time_after(adapter_to_pwrctl(adapter)->ips_deny_time, rtw_get_current_time())) {
 		/* RTW_INFO("%s ips_deny_time\n", __func__); */
 		goto exit;
 	}
@@ -206,9 +224,6 @@ bool rtw_pwr_unassociated_idle(_adapter *adapter)
 			pmlmepriv = &(iface->mlmepriv);
 #ifdef CONFIG_P2P
 			pwdinfo = &(iface->wdinfo);
-#ifdef CONFIG_IOCTL_CFG80211
-			pcfg80211_wdinfo = &iface->cfg80211_wdinfo;
-#endif
 #endif
 			if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE | WIFI_SITE_MONITOR)
 				|| check_fwstate(pmlmepriv, WIFI_UNDER_LINKING | WIFI_UNDER_WPS)
@@ -217,13 +232,12 @@ bool rtw_pwr_unassociated_idle(_adapter *adapter)
 				|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE)
 				#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
 				|| rtw_cfg80211_get_is_roch(iface) == _TRUE
+				|| (rtw_cfg80211_is_ro_ch_once(adapter)
+					&& rtw_cfg80211_get_last_ro_ch_passing_ms(adapter) < 3000)
 				#elif defined(CONFIG_P2P)
 				|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)
 				|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN)
 				#endif
-				#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
-				|| rtw_get_passing_time_ms(pcfg80211_wdinfo->last_ro_ch_time) < 3000
-				#endif
 			)
 				goto exit;
 
@@ -261,9 +275,6 @@ exit:
  */
 void rtw_ps_processor(_adapter *padapter)
 {
-#ifdef CONFIG_P2P
-	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
-#endif /* CONFIG_P2P */
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct dvobj_priv *psdpriv = padapter->dvobj;
@@ -396,9 +407,69 @@ void pwr_state_check_handler(void *ctx)
 }
 
 #ifdef CONFIG_LPS
+#ifdef CONFIG_CHECK_LEAVE_LPS
+#ifdef CONFIG_LPS_CHK_BY_TP
+void traffic_check_for_leave_lps_by_tp(PADAPTER padapter, u8 tx, struct sta_info *sta)
+{
+	struct stainfo_stats *pstats = &sta->sta_stats;
+	u64 cur_acc_tx_bytes = 0, cur_acc_rx_bytes = 0;
+	u32 tx_tp_kbyte = 0, rx_tp_kbyte = 0;
+	u32 tx_tp_th = 0, rx_tp_th = 0;
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	u8	leave_lps = _FALSE;
+
+	if (tx) { /* from tx */
+		cur_acc_tx_bytes = pstats->tx_bytes - pstats->acc_tx_bytes;
+		tx_tp_kbyte = cur_acc_tx_bytes >> 10;
+		tx_tp_th = pwrpriv->lps_tx_tp_th * 1024 / 8 * 2; /*KBytes @2s*/
+
+		if (tx_tp_kbyte >= tx_tp_th ||
+			padapter->mlmepriv.LinkDetectInfo.NumTxOkInPeriod >= pwrpriv->lps_tx_pkts){
+			if (pwrpriv->bLeisurePs
+				&& (pwrpriv->pwr_mode != PS_MODE_ACTIVE)
+				#ifdef CONFIG_BT_COEXIST
+				&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
+				#endif
+			) {
+				leave_lps = _TRUE;
+			}
+		}
+
+	} else { /* from rx path */
+		cur_acc_rx_bytes = pstats->rx_bytes - pstats->acc_rx_bytes;
+		rx_tp_kbyte = cur_acc_rx_bytes >> 10;
+		rx_tp_th = pwrpriv->lps_rx_tp_th * 1024 / 8 * 2;
+
+		if (rx_tp_kbyte>= rx_tp_th ||
+			padapter->mlmepriv.LinkDetectInfo.NumRxUnicastOkInPeriod >= pwrpriv->lps_rx_pkts) {
+			if (pwrpriv->bLeisurePs
+				&& (pwrpriv->pwr_mode != PS_MODE_ACTIVE)
+				#ifdef CONFIG_BT_COEXIST
+				&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
+				#endif
+			) {
+				leave_lps = _TRUE;
+			}
+		}
+	}
+
+	if (leave_lps) {
+		#ifdef DBG_LPS_CHK_BY_TP
+		RTW_INFO("leave lps via %s, ", tx ? "Tx" : "Rx");
+		if (tx)
+			RTW_INFO("Tx = %d [%d] (KB)\n", tx_tp_kbyte, tx_tp_th);
+		else
+			RTW_INFO("Rx = %d [%d] (KB)\n", rx_tp_kbyte, rx_tp_th);
+		#endif
+		pwrpriv->lps_chk_cnt = pwrpriv->lps_chk_cnt_th;
+		/* rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1); */
+		rtw_lps_ctrl_wk_cmd(padapter, tx ? LPS_CTRL_TX_TRAFFIC_LEAVE : LPS_CTRL_RX_TRAFFIC_LEAVE, 1);
+	}
+}
+#endif /*CONFIG_LPS_CHK_BY_TP*/
+
 void	traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets)
 {
-#ifdef CONFIG_CHECK_LEAVE_LPS
 	static systime start_time = 0;
 	static u32 xmit_cnt = 0;
 	u8	bLeaveLPS = _FALSE;
@@ -448,62 +519,76 @@ void	traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets)
 		/* rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1); */
 		rtw_lps_ctrl_wk_cmd(padapter, tx ? LPS_CTRL_TX_TRAFFIC_LEAVE : LPS_CTRL_RX_TRAFFIC_LEAVE, tx ? 0 : 1);
 	}
-#endif /* CONFIG_CHECK_LEAVE_LPS */
 }
+#endif /* CONFIG_CHECK_LEAVE_LPS */
 
 #ifdef CONFIG_LPS_LCLK
-u8 rtw_cpwm_polling(_adapter *adapter, u8 cpwm_orig)
+#define LPS_CPWM_TIMEOUT_MS	10 /*ms*/
+#define LPS_RPWM_RETRY_CNT		3
+
+u8 rtw_cpwm_polling(_adapter *adapter, u8 rpwm, u8 cpwm_orig)
 {
-	u8 result = _FAIL;
-	u8 cpwm_now;
-	u8 poll_cnt = 0;
+	u8 rst = _FAIL;
+	u8 cpwm_now = 0;
 	systime start_time;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
+	#ifdef DBG_CHECK_FW_PS_STATE
 	struct debug_priv *pdbgpriv = &(adapter_to_dvobj(adapter)->drv_dbg);
+	#endif
 
-	/*RTW_INFO("%s.....\n", __func__);*/
+	pwrpriv->rpwm_retry = 0;
 
-	start_time = rtw_get_current_time();
-
-	/* polling cpwm */
 	do {
-		rtw_msleep_os(1);
-		poll_cnt++;
-		cpwm_now = 0;
-		rtw_hal_get_hwreg(adapter, HW_VAR_CPWM, &cpwm_now);
-
-		if ((cpwm_orig ^ cpwm_now) & 0x80) {
-			pwrpriv->cpwm = PS_STATE_S4;
-			pwrpriv->cpwm_tog = cpwm_now & PS_TOGGLE;
-			#ifdef DBG_CHECK_FW_PS_STATE
-			RTW_INFO("%s: polling cpwm OK! poll_cnt=%d, cpwm_orig=%02x, cpwm_now=%02x , 0x100=0x%x\n"
-				, __func__, poll_cnt, cpwm_orig, cpwm_now, rtw_read8(adapter, REG_CR));
-			if (rtw_fw_ps_state(adapter) == _FAIL) {
-				RTW_INFO("leave 32k but fw state in 32k\n");
-				pdbgpriv->dbg_rpwm_toogle_cnt++;
-			}
-			#endif /* DBG_CHECK_FW_PS_STATE */
-			result = _SUCCESS;
-			break;
-		}
+		start_time = rtw_get_current_time();
+		do {
+			rtw_msleep_os(1);
+			rtw_hal_get_hwreg(adapter, HW_VAR_CPWM, &cpwm_now);
 
-		if (rtw_get_passing_time_ms(start_time) > LPS_RPWM_WAIT_MS) {
-			RTW_ERR("%s: polling cpwm timeout! poll_cnt=%d, cpwm_orig=%02x, cpwm_now=%02x\n"
-				, __func__, poll_cnt, cpwm_orig, cpwm_now);
-			#ifdef DBG_CHECK_FW_PS_STATE
-			if (rtw_fw_ps_state(adapter) == _FAIL) {
-				RTW_INFO("rpwm timeout and fw ps state in 32k\n");
-				pdbgpriv->dbg_rpwm_timeout_fail_cnt++;
+			if ((cpwm_orig ^ cpwm_now) & 0x80) {
+				pwrpriv->cpwm = PS_STATE_S4;
+				pwrpriv->cpwm_tog = cpwm_now & PS_TOGGLE;
+				rst = _SUCCESS;
+				break;
 			}
-			#endif /* DBG_CHECK_FW_PS_STATE */
+		} while (rtw_get_passing_time_ms(start_time) < LPS_CPWM_TIMEOUT_MS && !RTW_CANNOT_RUN(adapter));
 
-			#ifdef CONFIG_LPS_RPWM_TIMER
-			_set_timer(&pwrpriv->pwr_rpwm_timer, 1);
-			#endif /* CONFIG_LPS_RPWM_TIMER */
+		if (rst == _SUCCESS)
 			break;
+		else {
+			/* rpwm retry */
+			cpwm_orig = cpwm_now;
+			rpwm &= ~PS_TOGGLE;
+			rpwm |= pwrpriv->tog;
+			rtw_hal_set_hwreg(adapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
+			pwrpriv->tog += 0x80;
 		}
-	} while (1);
-	return result;
+	} while (pwrpriv->rpwm_retry++ < LPS_RPWM_RETRY_CNT && !RTW_CANNOT_RUN(adapter));
+
+	if (rst == _SUCCESS) {
+		#ifdef DBG_CHECK_FW_PS_STATE
+		RTW_INFO("%s: polling cpwm OK! rpwm_retry=%d, cpwm_orig=%02x, cpwm_now=%02x , 0x100=0x%x\n"
+			, __func__, pwrpriv->rpwm_retry, cpwm_orig, cpwm_now, rtw_read8(adapter, REG_CR));
+		if (rtw_fw_ps_state(adapter) == _FAIL) {
+			RTW_INFO("leave 32k but fw state in 32k\n");
+			pdbgpriv->dbg_rpwm_toogle_cnt++;
+		}
+		#endif /* DBG_CHECK_FW_PS_STATE */
+	} else {
+		RTW_ERR("%s: polling cpwm timeout! rpwm_retry=%d, cpwm_orig=%02x, cpwm_now=%02x\n"
+				, __func__, pwrpriv->rpwm_retry, cpwm_orig, cpwm_now);
+		#ifdef DBG_CHECK_FW_PS_STATE
+		if (rtw_fw_ps_state(adapter) == _FAIL) {
+			RTW_INFO("rpwm timeout and fw ps state in 32k\n");
+			pdbgpriv->dbg_rpwm_timeout_fail_cnt++;
+		}
+		#endif /* DBG_CHECK_FW_PS_STATE */
+
+		#ifdef CONFIG_LPS_RPWM_TIMER
+		_set_timer(&pwrpriv->pwr_rpwm_timer, 1);
+		#endif /* CONFIG_LPS_RPWM_TIMER */
+	}
+
+	return rst;
 }
 #endif
 /*
@@ -515,15 +600,13 @@ u8 rtw_cpwm_polling(_adapter *adapter, u8 cpwm_orig)
  *	pslv			power state level, only could be PS_STATE_S0 ~ PS_STATE_S4
  *
  */
-void rtw_set_rpwm(PADAPTER padapter, u8 pslv)
+u8 rtw_set_rpwm(PADAPTER padapter, u8 pslv)
 {
-	u8	rpwm;
+	u8	rpwm = 0xFF;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 #ifdef CONFIG_LPS_LCLK
 	u8 cpwm_orig;
 #endif
-	struct dvobj_priv *psdpriv = padapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 
 	pslv = PS_STATE(pslv);
 
@@ -539,7 +622,7 @@ void rtw_set_rpwm(PADAPTER padapter, u8 pslv)
 #endif
 			|| (pwrpriv->lps_level == LPS_NORMAL)
 		   ) {
-			return;
+			return rpwm;
 		}
 	}
 
@@ -548,12 +631,12 @@ void rtw_set_rpwm(PADAPTER padapter, u8 pslv)
 
 		pwrpriv->cpwm = PS_STATE_S4;
 
-		return;
+		return rpwm;
 	}
 
 	if (rtw_is_drv_stopped(padapter))
 		if (pslv < PS_STATE_S2)
-			return;
+			return rpwm;
 
 	rpwm = pslv | pwrpriv->tog;
 #ifdef CONFIG_LPS_LCLK
@@ -571,9 +654,16 @@ void rtw_set_rpwm(PADAPTER padapter, u8 pslv)
 #endif
 
 #if defined(CONFIG_LPS_RPWM_TIMER) && !defined(CONFIG_DETECT_CPWM_BY_POLLING)
-	if (rpwm & PS_ACK)
-		_set_timer(&pwrpriv->pwr_rpwm_timer, LPS_RPWM_WAIT_MS);
+	if (rpwm & PS_ACK) {
+		#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
+		if (pwrpriv->wowlan_mode != _TRUE &&
+			pwrpriv->wowlan_ap_mode != _TRUE &&
+			pwrpriv->wowlan_p2p_mode != _TRUE)
+		#endif
+		_set_timer(&pwrpriv->pwr_rpwm_timer, LPS_CPWM_TIMEOUT_MS);
+	}
 #endif /* CONFIG_LPS_RPWM_TIMER & !CONFIG_DETECT_CPWM_BY_POLLING */
+
 	rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
 
 	pwrpriv->tog += 0x80;
@@ -581,14 +671,14 @@ void rtw_set_rpwm(PADAPTER padapter, u8 pslv)
 #ifdef CONFIG_LPS_LCLK
 	/* No LPS 32K, No Ack */
 	if (rpwm & PS_ACK) {
-#ifdef CONFIG_DETECT_CPWM_BY_POLLING
-		rtw_cpwm_polling(padapter, cpwm_orig);
+		#ifdef CONFIG_DETECT_CPWM_BY_POLLING
+		rtw_cpwm_polling(padapter, rpwm, cpwm_orig);
 		#else
 		#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
 		if (pwrpriv->wowlan_mode == _TRUE ||
 			pwrpriv->wowlan_ap_mode == _TRUE ||
 			pwrpriv->wowlan_p2p_mode == _TRUE)
-				rtw_cpwm_polling(padapter, cpwm_orig);
+				rtw_cpwm_polling(padapter, rpwm, cpwm_orig);
 		#endif /*#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)*/
 		#endif /*#ifdef CONFIG_DETECT_CPWM_BY_POLLING*/
 	} else
@@ -597,6 +687,7 @@ void rtw_set_rpwm(PADAPTER padapter, u8 pslv)
 		pwrpriv->cpwm = pslv;
 	}
 
+	return rpwm;
 }
 
 u8 PS_RDY_CHECK(_adapter *padapter)
@@ -604,12 +695,6 @@ u8 PS_RDY_CHECK(_adapter *padapter)
 	u32 delta_ms;
 	struct pwrctrl_priv	*pwrpriv = adapter_to_pwrctl(padapter);
 	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-#ifdef CONFIG_P2P
-	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
-#ifdef CONFIG_IOCTL_CFG80211
-	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
-#endif /* CONFIG_IOCTL_CFG80211 */
-#endif /* CONFIG_P2P */
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
 	if (_TRUE == pwrpriv->bInSuspend && pwrpriv->wowlan_mode)
@@ -640,6 +725,9 @@ u8 PS_RDY_CHECK(_adapter *padapter)
 		/* TDLS link is established. */
 		|| (padapter->tdlsinfo.link_established == _TRUE)
 		#endif /* CONFIG_TDLS		 */
+		#ifdef CONFIG_DFS_MASTER
+		|| adapter_to_rfctl(padapter)->radar_detect_enabled
+		#endif
 	)
 		return _FALSE;
 
@@ -775,9 +863,14 @@ void rtw_set_fw_in_ips_mode(PADAPTER padapter, u8 enable)
 void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode, const char *msg)
 {
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
 	struct dvobj_priv *psdpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+#endif
+#ifdef CONFIG_WMMPS_STA	
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
+#endif
 #ifdef CONFIG_P2P
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 #endif /* CONFIG_P2P */
@@ -905,11 +998,18 @@ void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode
 				rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
 			}
 #endif
+#ifdef CONFIG_WOWLAN
+			if (pwrpriv->wowlan_mode == _TRUE)
+				rtw_hal_set_hwreg(padapter, HW_VAR_H2C_INACTIVE_IPS, (u8 *)(&ps_mode));
+#endif /* CONFIG_WOWLAN */
+
 			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
+			rtw_hal_set_hwreg(padapter, HW_VAR_LPS_STATE_CHK, (u8 *)(&ps_mode));
+
 
 #ifdef CONFIG_LPS_PG
 			if (pwrpriv->lps_level == LPS_PG) {
-				lps_pg_hdl_id = LPS_PG_RESEND_H2C;
+				lps_pg_hdl_id = LPS_PG_PHYDM_EN;
 				rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
 			}
 #endif
@@ -934,6 +1034,9 @@ void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode
 #ifdef CONFIG_P2P_WOWLAN
 		    || (_TRUE == pwrpriv->wowlan_p2p_mode)
 #endif /* CONFIG_P2P_WOWLAN */
+#ifdef CONFIG_WOWLAN
+			|| WOWLAN_IS_STA_MIX_MODE(padapter)
+#endif /* CONFIG_WOWLAN */
 		   ) {
 			u8 pslv;
 
@@ -972,12 +1075,24 @@ void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode
 			pwrpriv->pwr_mode = ps_mode;
 			pwrpriv->smart_ps = smart_ps;
 			pwrpriv->bcn_ant_mode = bcn_ant_mode;
+#ifdef CONFIG_LPS_PG
+			if (pwrpriv->lps_level == LPS_PG) {
+				lps_pg_hdl_id = LPS_PG_PHYDM_DIS;
+				rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
+			}
+#endif
 
 #ifdef CONFIG_WMMPS_STA	
 			pwrpriv->wmm_smart_ps = pregistrypriv->wmm_smart_ps;
 #endif /* CONFIG_WMMPS_STA */
 			
-			rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
+			
+			if (check_fwstate(pmlmepriv, _FW_LINKED))
+				rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
+#ifdef CONFIG_WOWLAN
+			if (pwrpriv->wowlan_mode == _TRUE)
+				rtw_hal_set_hwreg(padapter, HW_VAR_H2C_INACTIVE_IPS, (u8 *)(&ps_mode));
+#endif /* CONFIG_WOWLAN */
 
 #ifdef CONFIG_P2P_PS
 			/* Set CTWindow after LPS */
@@ -1013,42 +1128,6 @@ void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode
 
 }
 
-/*
- * Return:
- *	0:	Leave OK
- *	-1:	Timeout
- *	-2:	Other error
- */
-s32 LPS_RF_ON_check(PADAPTER padapter, u32 delay_ms)
-{
-	systime start_time;
-	u8 bAwake = _FALSE;
-	s32 err = 0;
-
-
-	start_time = rtw_get_current_time();
-	while (1) {
-		rtw_hal_get_hwreg(padapter, HW_VAR_FWLPS_RF_ON, &bAwake);
-		if (_TRUE == bAwake)
-			break;
-
-		if (rtw_is_surprise_removed(padapter)) {
-			err = -2;
-			RTW_INFO("%s: device surprise removed!!\n", __FUNCTION__);
-			break;
-		}
-
-		if (rtw_get_passing_time_ms(start_time) > delay_ms) {
-			err = -1;
-			RTW_INFO("%s: Wait for FW LPS leave more than %u ms!!!\n", __FUNCTION__, delay_ms);
-			break;
-		}
-		rtw_usleep_os(100);
-	}
-
-	return err;
-}
-
 /*
  *	Description:
  *		Enter the leisure power save mode.
@@ -1057,11 +1136,11 @@ void LPS_Enter(PADAPTER padapter, const char *msg)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct pwrctrl_priv	*pwrpriv = dvobj_to_pwrctl(dvobj);
-	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	int n_assoc_iface = 0;
 	int i;
 	char buf[32] = {0};
-
+#ifdef DBG_LA_MODE
+	struct registry_priv *registry_par = &(padapter->registrypriv);
+#endif
 
 	/*	RTW_INFO("+LeisurePSEnter\n"); */
 	if (GET_HAL_DATA(padapter)->bFWReady == _FALSE)
@@ -1072,12 +1151,14 @@ void LPS_Enter(PADAPTER padapter, const char *msg)
 		return;
 #endif
 
-	/* Skip lps enter request if number of assocated adapters is not 1 */
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		if (check_fwstate(&(dvobj->padapters[i]->mlmepriv), WIFI_ASOC_STATE))
-			n_assoc_iface++;
+#ifdef DBG_LA_MODE
+	if(registry_par->la_mode_en == 1) {
+		RTW_INFO("%s LA debug mode lps_leave \n", __func__);
+		return;
 	}
-	if (n_assoc_iface != 1)
+#endif
+	/* Skip lps enter request if number of assocated adapters is not 1 */
+	if (rtw_mi_get_assoc_if_num(padapter) != 1)
 		return;
 
 #ifndef CONFIG_FW_MULTI_PORT_SUPPORT
@@ -1091,6 +1172,14 @@ void LPS_Enter(PADAPTER padapter, const char *msg)
 			return;
 	}
 
+#ifdef CONFIG_CLIENT_PORT_CFG
+	if ((rtw_hal_get_port(padapter) == CLT_PORT_INVALID) ||
+		get_clt_num(padapter) > MAX_CLIENT_PORT_NUM){
+		RTW_ERR(ADPT_FMT" cannot get client port or clt num(%d) over than 4\n", ADPT_ARG(padapter), get_clt_num(padapter));
+		return;
+	}
+#endif
+
 #ifdef CONFIG_P2P_PS
 	if (padapter->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
 		return;/* supporting p2p client ps NOA via H2C_8723B_P2P_PS_OFFLOAD */
@@ -1109,6 +1198,11 @@ void LPS_Enter(PADAPTER padapter, const char *msg)
 				
 				sprintf(buf, "WIFI-%s", msg);
 				pwrpriv->bpower_saving = _TRUE;
+				
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 				rtw_set_ps_mode(padapter, pwrpriv->power_mgnt, padapter->registrypriv.smart_ps, 0, buf);
 			}
 		} else
@@ -1129,10 +1223,10 @@ void LPS_Leave(PADAPTER padapter, const char *msg)
 
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct pwrctrl_priv	*pwrpriv = dvobj_to_pwrctl(dvobj);
-	u32 start_time;
-	u8 bAwake = _FALSE;
 	char buf[32] = {0};
+#ifdef DBG_CHECK_FW_PS_STATE
 	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
+#endif
 
 
 	/*	RTW_INFO("+LeisurePSLeave\n"); */
@@ -1153,8 +1247,9 @@ void LPS_Leave(PADAPTER padapter, const char *msg)
 			sprintf(buf, "WIFI-%s", msg);
 			rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, buf);
 
-			if (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
-				LPS_RF_ON_check(padapter, LPS_LEAVE_TIMEOUT_MS);
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS	
+			pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
 		}
 	}
 
@@ -1187,15 +1282,13 @@ void rtw_wow_lps_level_decide(_adapter *adapter, u8 wow_en)
 void LeaveAllPowerSaveModeDirect(PADAPTER Adapter)
 {
 	PADAPTER pri_padapter = GET_PRIMARY_ADAPTER(Adapter);
-	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(Adapter);
-	struct dvobj_priv *psdpriv = Adapter->dvobj;
-	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
+#ifdef CONFIG_LPS_LCLK
 #ifndef CONFIG_DETECT_CPWM_BY_POLLING
-	u8 cpwm_orig, cpwm_now;
-	systime start_time;
+	u8 cpwm_orig;
 #endif /* CONFIG_DETECT_CPWM_BY_POLLING */
-
+	u8 rpwm;
+#endif
 
 	RTW_INFO("%s.....\n", __FUNCTION__);
 
@@ -1218,46 +1311,15 @@ void LeaveAllPowerSaveModeDirect(PADAPTER Adapter)
 		cpwm_orig = 0;
 		rtw_hal_get_hwreg(Adapter, HW_VAR_CPWM, &cpwm_orig);
 #endif /* CONFIG_DETECT_CPWM_BY_POLLING */
-		rtw_set_rpwm(Adapter, PS_STATE_S4);
+		rpwm = rtw_set_rpwm(Adapter, PS_STATE_S4);
 
 #ifndef CONFIG_DETECT_CPWM_BY_POLLING
-
-		start_time = rtw_get_current_time();
-
-		/* polling cpwm */
-		do {
-			rtw_mdelay_os(1);
-
-			rtw_hal_get_hwreg(Adapter, HW_VAR_CPWM, &cpwm_now);
-			if ((cpwm_orig ^ cpwm_now) & 0x80) {
-				pwrpriv->cpwm = PS_STATE_S4;
-				pwrpriv->cpwm_tog = cpwm_now & PS_TOGGLE;
-#ifdef DBG_CHECK_FW_PS_STATE
-				RTW_INFO("%s: polling cpwm OK! cpwm_orig=%02x, cpwm_now=%02x, 0x100=0x%x\n"
-					, __FUNCTION__, cpwm_orig, cpwm_now, rtw_read8(Adapter, REG_CR));
-				if (rtw_fw_ps_state(Adapter) == _FAIL) {
-					RTW_INFO("%s: leave 32k but fw state in 32k\n", __FUNCTION__);
-					pdbgpriv->dbg_rpwm_toogle_cnt++;
-				}
-#endif /* DBG_CHECK_FW_PS_STATE */
-				break;
-			}
-
-			if (rtw_get_passing_time_ms(start_time) > LPS_RPWM_WAIT_MS) {
-				RTW_INFO("%s: polling cpwm timeout! cpwm_orig=%02x, cpwm_now=%02x\n", __FUNCTION__, cpwm_orig, cpwm_now);
-#ifdef DBG_CHECK_FW_PS_STATE
-				if (rtw_fw_ps_state(Adapter) == _FAIL) {
-					RTW_INFO("rpwm timeout and fw ps state in 32k\n");
-					pdbgpriv->dbg_rpwm_timeout_fail_cnt++;
-				}
-#endif /* DBG_CHECK_FW_PS_STATE */
-				break;
-			}
-		} while (1);
+		if (rpwm != 0xFF && rpwm & PS_ACK)
+			rtw_cpwm_polling(Adapter, rpwm, cpwm_orig);
 #endif /* CONFIG_DETECT_CPWM_BY_POLLING */
 
 		_exit_pwrlock(&pwrpriv->lock);
-#endif
+#endif/*CONFIG_LPS_LCLK*/
 
 #ifdef CONFIG_P2P_PS
 		p2p_ps_wk_cmd(pri_padapter, P2P_PS_DISABLE, 0);
@@ -1297,31 +1359,25 @@ void LeaveAllPowerSaveModeDirect(PADAPTER Adapter)
 void LeaveAllPowerSaveMode(IN PADAPTER Adapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(Adapter);
-	struct mlme_priv	*pmlmepriv = &(Adapter->mlmepriv);
 	u8	enqueue = 0;
-	int n_assoc_iface = 0;
 	int i;
 
-
-	/* RTW_INFO("%s.....\n",__FUNCTION__); */
-
+	#ifndef CONFIG_NEW_NETDEV_HDL
 	if (_FALSE == Adapter->bup) {
 		RTW_INFO(FUNC_ADPT_FMT ": bup=%d Skip!\n",
 			 FUNC_ADPT_ARG(Adapter), Adapter->bup);
 		return;
 	}
+	#endif
+
+/*	RTW_INFO(FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(Adapter));*/
 
 	if (rtw_is_surprise_removed(Adapter)) {
 		RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=_TRUE Skip!\n", FUNC_ADPT_ARG(Adapter));
 		return;
 	}
 
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		if (check_fwstate(&(dvobj->padapters[i]->mlmepriv), WIFI_ASOC_STATE))
-			n_assoc_iface++;
-	}
-
-	if (n_assoc_iface) {
+	if (rtw_mi_get_assoc_if_num(Adapter)) {
 		/* connect */
 #ifdef CONFIG_LPS_LCLK
 		enqueue = 1;
@@ -1402,7 +1458,7 @@ void LPS_Leave_check(
 			break;
 
 		if (rtw_get_passing_time_ms(start_time) > 100) {
-			RTW_INFO("Wait for cpwm event  than 100 ms!!!\n");
+			RTW_ERR("Wait for cpwm event  than 100 ms!!!\n");
 			break;
 		}
 		rtw_msleep_os(1);
@@ -1486,6 +1542,41 @@ static void dma_event_callback(struct work_struct *work)
 }
 
 #ifdef CONFIG_LPS_RPWM_TIMER
+
+#define DBG_CPWM_CHK_FAIL
+#if defined(DBG_CPWM_CHK_FAIL) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+#define CPU_EXCEPTION_CODE 0xFAFAFAFA
+static void rtw_cpwm_chk_fail_debug(_adapter *padapter)
+{
+	u32 cpu_state;
+
+	cpu_state = rtw_read32(padapter, 0x10FC);
+
+	RTW_INFO("[PS-DBG] Reg_10FC =0x%08x\n", cpu_state);
+	RTW_INFO("[PS-DBG] Reg_10F8 =0x%08x\n", rtw_read32(padapter, 0x10F8));
+	RTW_INFO("[PS-DBG] Reg_11F8 =0x%08x\n", rtw_read32(padapter, 0x11F8));
+	RTW_INFO("[PS-DBG] Reg_4A4 =0x%08x\n", rtw_read32(padapter, 0x4A4));
+	RTW_INFO("[PS-DBG] Reg_4A8 =0x%08x\n", rtw_read32(padapter, 0x4A8));
+
+	if (cpu_state == CPU_EXCEPTION_CODE) {
+		RTW_INFO("[PS-DBG] Reg_48C =0x%08x\n", rtw_read32(padapter, 0x48C));
+		RTW_INFO("[PS-DBG] Reg_490 =0x%08x\n", rtw_read32(padapter, 0x490));
+		RTW_INFO("[PS-DBG] Reg_494 =0x%08x\n", rtw_read32(padapter, 0x494));
+		RTW_INFO("[PS-DBG] Reg_498 =0x%08x\n", rtw_read32(padapter, 0x498));
+		RTW_INFO("[PS-DBG] Reg_49C =0x%08x\n", rtw_read32(padapter, 0x49C));
+		RTW_INFO("[PS-DBG] Reg_4A0 =0x%08x\n", rtw_read32(padapter, 0x4A0));
+		RTW_INFO("[PS-DBG] Reg_1BC =0x%08x\n", rtw_read32(padapter, 0x1BC));
+
+		RTW_INFO("[PS-DBG] Reg_008 =0x%08x\n", rtw_read32(padapter, 0x08));
+		RTW_INFO("[PS-DBG] Reg_2F0 =0x%08x\n", rtw_read32(padapter, 0x2F0));
+		RTW_INFO("[PS-DBG] Reg_2F4 =0x%08x\n", rtw_read32(padapter, 0x2F4));
+		RTW_INFO("[PS-DBG] Reg_2F8 =0x%08x\n", rtw_read32(padapter, 0x2F8));
+		RTW_INFO("[PS-DBG] Reg_2FC =0x%08x\n", rtw_read32(padapter, 0x2FC));
+
+		rtw_dump_fifo(RTW_DBGDUMP, padapter, 5, 0, 3072);
+	}
+}
+#endif
 static void rpwmtimeout_workitem_callback(struct work_struct *work)
 {
 	PADAPTER padapter;
@@ -1496,7 +1587,6 @@ static void rpwmtimeout_workitem_callback(struct work_struct *work)
 	pwrpriv = container_of(work, struct pwrctrl_priv, rpwmtimeoutwi);
 	dvobj = pwrctl_to_dvobj(pwrpriv);
 	padapter = dvobj_get_primary_adapter(dvobj);
-	/*	RTW_INFO("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm); */
 
 	if (!padapter)
 		return;
@@ -1509,8 +1599,25 @@ static void rpwmtimeout_workitem_callback(struct work_struct *work)
 		RTW_INFO("%s: rpwm=0x%02X cpwm=0x%02X CPWM done!\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
 		goto exit;
 	}
+
+	if (pwrpriv->rpwm_retry++ < LPS_RPWM_RETRY_CNT) {
+		u8 rpwm = (pwrpriv->rpwm | pwrpriv->tog | PS_ACK);
+
+		rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
+
+		pwrpriv->tog += 0x80;
+		_set_timer(&pwrpriv->pwr_rpwm_timer, LPS_CPWM_TIMEOUT_MS);
+		goto exit;
+	}
+
+	pwrpriv->rpwm_retry = 0;
 	_exit_pwrlock(&pwrpriv->lock);
 
+#if defined(DBG_CPWM_CHK_FAIL) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+	RTW_INFO("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
+	rtw_cpwm_chk_fail_debug(padapter);
+#endif
+
 	if (rtw_read8(padapter, 0x100) != 0xEA) {
 #if 1
 		struct reportpwrstate_parm report;
@@ -1991,12 +2098,15 @@ void rtw_unregister_evt_alive(PADAPTER padapter)
 void rtw_init_pwrctrl_priv(PADAPTER padapter)
 {
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+#ifdef CONFIG_WOWLAN
 	struct registry_priv  *registry_par = &padapter->registrypriv;
-
+#endif
+#ifdef CONFIG_GPIO_WAKEUP
 	u8 val8 = 0;
+#endif
 
 #if defined(CONFIG_CONCURRENT_MODE)
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
+	if (!is_primary_adapter(padapter))
 		return;
 #endif
 
@@ -2013,6 +2123,15 @@ void rtw_init_pwrctrl_priv(PADAPTER padapter)
 	pwrctrlpriv->lps_enter_cnts = 0;
 	pwrctrlpriv->lps_leave_cnts = 0;
 	pwrctrlpriv->bips_processing = _FALSE;
+#ifdef CONFIG_LPS_CHK_BY_TP
+	pwrctrlpriv->lps_chk_by_tp = padapter->registrypriv.lps_chk_by_tp;
+	pwrctrlpriv->lps_tx_tp_th = LPS_TX_TP_TH;
+	pwrctrlpriv->lps_rx_tp_th = LPS_RX_TP_TH;
+	pwrctrlpriv->lps_bi_tp_th = LPS_BI_TP_TH;
+	pwrctrlpriv->lps_chk_cnt = pwrctrlpriv->lps_chk_cnt_th = LPS_TP_CHK_CNT;
+	pwrctrlpriv->lps_tx_pkts = LPS_CHK_PKTS_TX;
+	pwrctrlpriv->lps_rx_pkts = LPS_CHK_PKTS_RX;
+#endif
 
 	pwrctrlpriv->ips_mode = padapter->registrypriv.ips_mode;
 	pwrctrlpriv->ips_mode_req = padapter->registrypriv.ips_mode;
@@ -2057,6 +2176,7 @@ void rtw_init_pwrctrl_priv(PADAPTER padapter)
 	pwrctrlpriv->dtim = 0;
 
 	pwrctrlpriv->tog = 0x80;
+	pwrctrlpriv->rpwm_retry = 0;
 
 #ifdef CONFIG_LPS_LCLK
 	rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&pwrctrlpriv->rpwm));
@@ -2092,8 +2212,12 @@ void rtw_init_pwrctrl_priv(PADAPTER padapter)
 
 #ifdef CONFIG_GPIO_WAKEUP
 	/*default low active*/
-	pwrctrlpriv->is_high_active = HIGH_ACTIVE;
-
+	pwrctrlpriv->is_high_active = HIGH_ACTIVE_DEV2HST;
+	pwrctrlpriv->hst2dev_high_active = HIGH_ACTIVE_HST2DEV;
+#ifdef CONFIG_RTW_ONE_PIN_GPIO
+	rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
+	rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
+#else
 	#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
 	if (pwrctrlpriv->is_high_active == 0)
 		rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
@@ -2101,11 +2225,11 @@ void rtw_init_pwrctrl_priv(PADAPTER padapter)
 		rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
 	#else
 	val8 = (pwrctrlpriv->is_high_active == 0) ? 1 : 0;
-	rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
 	rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
 	RTW_INFO("%s: set GPIO_%d %d as default.\n",
 		 __func__, WAKEUP_GPIO_IDX, val8);
 	#endif /*CONFIG_WAKEUP_GPIO_INPUT_MODE*/
+#endif /* CONFIG_RTW_ONE_PIN_GPIO */
 #endif /* CONFIG_GPIO_WAKEUP */
 
 #ifdef CONFIG_WOWLAN
@@ -2141,7 +2265,7 @@ void rtw_free_pwrctrl_priv(PADAPTER adapter)
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(adapter);
 
 #if defined(CONFIG_CONCURRENT_MODE)
-	if (adapter->adapter_type != PRIMARY_ADAPTER)
+	if (!is_primary_adapter(adapter))
 		return;
 #endif
 
@@ -2160,6 +2284,14 @@ void rtw_free_pwrctrl_priv(PADAPTER adapter)
 	rtw_hal_set_hwreg(adapter, HW_VAR_LPS_POFF_DEINIT, 0);
 #endif
 
+#ifdef CONFIG_LPS_LCLK
+	_cancel_workitem_sync(&pwrctrlpriv->cpwm_event);
+	_cancel_workitem_sync(&pwrctrlpriv->dma_event);
+	#ifdef CONFIG_LPS_RPWM_TIMER
+	_cancel_workitem_sync(&pwrctrlpriv->rpwmtimeoutwi);
+	#endif
+#endif /* CONFIG_LPS_LCLK */
+
 #ifdef CONFIG_WOWLAN
 #ifdef CONFIG_PNO_SUPPORT
 	if (pwrctrlpriv->pnlo_info != NULL)
@@ -2365,9 +2497,9 @@ int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)
 	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
 	struct mlme_priv *pmlmepriv;
 	int ret = _SUCCESS;
-	int i;
 	systime start = rtw_get_current_time();
 
+	/*RTW_INFO(FUNC_ADPT_FMT "===>\n", FUNC_ADPT_ARG(padapter));*/
 	/* for LPS */
 	LeaveAllPowerSaveMode(padapter);
 
@@ -2375,7 +2507,7 @@ int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)
 	padapter = GET_PRIMARY_ADAPTER(padapter);
 	pmlmepriv = &padapter->mlmepriv;
 
-	if (time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
+	if (rtw_time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
 		pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms);
 
 
@@ -2501,8 +2633,9 @@ int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)
 	}
 
 exit:
-	if (time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
+	if (rtw_time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
 		pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms);
+	/*RTW_INFO(FUNC_ADPT_FMT "<===\n", FUNC_ADPT_ARG(padapter));*/
 	return ret;
 
 }
@@ -2565,8 +2698,6 @@ int rtw_pm_set_ips(_adapter *padapter, u8 mode)
 void rtw_ps_deny(PADAPTER padapter, PS_DENY_REASON reason)
 {
 	struct pwrctrl_priv *pwrpriv;
-	s32 ret;
-
 
 	/* 	RTW_INFO("+" FUNC_ADPT_FMT ": Request PS deny for %d (0x%08X)\n",
 	 *		FUNC_ADPT_ARG(padapter), reason, BIT(reason)); */
@@ -2625,3 +2756,38 @@ u32 rtw_ps_deny_get(PADAPTER padapter)
 
 	return deny;
 }
+
+static void _rtw_ssmps(_adapter *adapter, struct sta_info *sta)
+{
+	struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (MLME_IS_STA(adapter)) {
+		issue_action_SM_PS_wait_ack(adapter , get_my_bssid(&(pmlmeinfo->network)),
+			sta->cmn.sm_ps, 3 , 1);
+	}
+	else if (MLME_IS_AP(adapter)) {
+
+	}
+	rtw_phydm_ra_registed(adapter, sta);
+}
+void rtw_ssmps_enter(_adapter *adapter, struct sta_info *sta)
+{
+	if (sta->cmn.sm_ps == SM_PS_STATIC)
+		return;
+
+	RTW_INFO(ADPT_FMT" STA [" MAC_FMT "]\n", ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+
+	sta->cmn.sm_ps = SM_PS_STATIC;
+	_rtw_ssmps(adapter, sta);
+}
+void rtw_ssmps_leave(_adapter *adapter, struct sta_info *sta)
+{
+	if (sta->cmn.sm_ps == SM_PS_DISABLE)
+		return;
+
+	RTW_INFO(ADPT_FMT" STA [" MAC_FMT "] \n", ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
+	sta->cmn.sm_ps = SM_PS_DISABLE;
+	_rtw_ssmps(adapter, sta);
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_recv.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_recv.c
index 9d70cd893273..f0a10326ae3c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_recv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_recv.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -44,6 +45,17 @@ u8 signal_stat_calc_profile[SIGNAL_STAT_CALC_PROFILE_MAX][2] = {
 
 #endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
+u8 rtw_bridge_tunnel_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8 };
+u8 rtw_rfc1042_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };
+static u8 SNAP_ETH_TYPE_IPX[2] = {0x81, 0x37};
+static u8 SNAP_ETH_TYPE_APPLETALK_AARP[2] = {0x80, 0xf3};
+#ifdef CONFIG_TDLS
+static u8 SNAP_ETH_TYPE_TDLS[2] = {0x89, 0x0d};
+#endif
+
+#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
+int recv_frame_monitor(_adapter *padapter, union recv_frame *rframe);
+#endif
 void _rtw_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv)
 {
 
@@ -601,10 +613,11 @@ union recv_frame *decryptor(_adapter *padapter, union recv_frame *precv_frame)
 	}
 
 	if (prxattrib->encrypt && !prxattrib->bdecrypted) {
-
-		#ifdef CONFIG_CONCURRENT_MODE
-		if (!IS_MCAST(prxattrib->ra)) /* bc/mc packets may use sw decryption for concurrent mode */
-		#endif
+		if (GetFrameType(get_recvframe_data(precv_frame)) == WIFI_DATA
+			#ifdef CONFIG_CONCURRENT_MODE
+			&& !IS_MCAST(prxattrib->ra) /* bc/mc packets may use sw decryption for concurrent mode */
+			#endif
+		)
 			psecuritypriv->hw_decrypted = _FALSE;
 
 #ifdef DBG_RX_SW_DECRYPTOR
@@ -685,6 +698,13 @@ union recv_frame *decryptor(_adapter *padapter, union recv_frame *precv_frame)
 #endif
 	}
 
+	#ifdef CONFIG_RTW_MESH
+	if (res != _FAIL
+		&& !prxattrib->amsdu
+		&& prxattrib->mesh_ctrl_present)
+		res = rtw_mesh_rx_validate_mctrl_non_amsdu(padapter, precv_frame);
+	#endif
+
 	if (res == _FAIL) {
 		rtw_free_recvframe(return_packet, &padapter->recvpriv.free_recv_queue);
 		return_packet = NULL;
@@ -766,39 +786,6 @@ union recv_frame *portctrl(_adapter *adapter, union recv_frame *precv_frame)
 
 }
 
-sint recv_decache(union recv_frame *precv_frame, u8 bretry)
-{
-	struct sta_info *sta = precv_frame->u.hdr.psta;
-	struct stainfo_rxcache *prxcache = &sta->sta_recvpriv.rxcache;
-
-	sint tid = precv_frame->u.hdr.attrib.priority;
-	u16 seq_ctrl = ((precv_frame->u.hdr.attrib.seq_num & 0xffff) << 4) |
-		       (precv_frame->u.hdr.attrib.frag_num & 0xf);
-
-	if (tid > 15)
-		return _FAIL;
-
-	if (1) { /* if(bretry) */
-		if (seq_ctrl == prxcache->tid_rxseq[tid]) {
-			/* for non-AMPDU case	*/
-			sta->sta_stats.duplicate_cnt++;
-
-			if (sta->sta_stats.duplicate_cnt % 100 == 0)
-				RTW_INFO("%s: tid=%u seq=%d frag=%d\n", __func__
-					, tid, precv_frame->u.hdr.attrib.seq_num
-					, precv_frame->u.hdr.attrib.frag_num);
-
-			return _FAIL;
-		}
-	}
-
-	prxcache->tid_rxseq[tid] = seq_ctrl;
-
-
-	return _SUCCESS;
-
-}
-
 /* VALID_PN_CHK
  * Return true when PN is legal, otherwise false.
  * Legal PN:
@@ -808,17 +795,13 @@ sint recv_decache(union recv_frame *precv_frame, u8 bretry)
 #define PN_LESS_CHK(a, b)	(((a-b) & 0x800000000000) != 0)
 #define VALID_PN_CHK(new, old)	(((old) == 0) || PN_LESS_CHK(old, new))
 #define CCMPH_2_KEYID(ch)	(((ch) & 0x00000000c0000000) >> 30)
-#define CCMPH_2_PN(ch)	((ch) & 0x000000000000ffff) \
-				| (((ch) & 0xffffffff00000000) >> 16)
 sint recv_ucast_pn_decache(union recv_frame *precv_frame);
 sint recv_ucast_pn_decache(union recv_frame *precv_frame)
 {
-	_adapter *padapter = precv_frame->u.hdr.adapter;
 	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
 	struct sta_info *sta = precv_frame->u.hdr.psta;
 	struct stainfo_rxcache *prxcache = &sta->sta_recvpriv.rxcache;
 	u8 *pdata = precv_frame->u.hdr.rx_data;
-	u32 data_len = precv_frame->u.hdr.len;
 	sint tid = precv_frame->u.hdr.attrib.priority;
 	u64 tmp_iv_hdr = 0;
 	u64 curr_pn = 0, pkt_pn = 0;
@@ -829,14 +812,17 @@ sint recv_ucast_pn_decache(union recv_frame *precv_frame)
 	if (pattrib->encrypt == _AES_) {
 		tmp_iv_hdr = le64_to_cpu(*(u64*)(pdata + pattrib->hdrlen));
 		pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
-	
 		tmp_iv_hdr = le64_to_cpu(*(u64*)prxcache->iv[tid]);
-		curr_pn = CCMPH_2_PN(tmp_iv_hdr);	
+		curr_pn = CCMPH_2_PN(tmp_iv_hdr);
 
 		if (!VALID_PN_CHK(pkt_pn, curr_pn)) {
 			/* return _FAIL; */
-		} else
-			_rtw_memcpy(prxcache->iv[tid], (pdata + pattrib->hdrlen), sizeof(prxcache->iv[tid]));
+		} else {
+			prxcache->last_tid = tid;
+			_rtw_memcpy(prxcache->iv[tid],
+				    (pdata + pattrib->hdrlen),
+				    sizeof(prxcache->iv[tid]));
+		}
 	}
 
 	return _SUCCESS;
@@ -850,18 +836,17 @@ sint recv_bcast_pn_decache(union recv_frame *precv_frame)
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
 	u8 *pdata = precv_frame->u.hdr.rx_data;
-	u32 data_len = precv_frame->u.hdr.len;
 	u64 tmp_iv_hdr = 0;
 	u64 curr_pn = 0, pkt_pn = 0;
 	u8 key_id;
 
 	if ((pattrib->encrypt == _AES_) &&
-		(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)) {		
+		(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)) {
 
 		tmp_iv_hdr = le64_to_cpu(*(u64*)(pdata + pattrib->hdrlen));
 		key_id = CCMPH_2_KEYID(tmp_iv_hdr);
 		pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
-	
+
 		curr_pn = le64_to_cpu(*(u64*)psecuritypriv->iv_seq[key_id]);
 		curr_pn &= 0x0000ffffffffffff;
 
@@ -874,33 +859,84 @@ sint recv_bcast_pn_decache(union recv_frame *precv_frame)
 	return _SUCCESS;
 }
 
+sint recv_decache(union recv_frame *precv_frame)
+{
+	struct sta_info *psta = precv_frame->u.hdr.psta;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	_adapter *adapter = psta->padapter;
+	sint tid = pattrib->priority;
+	u16 seq_ctrl = ((precv_frame->u.hdr.attrib.seq_num & 0xffff) << 4) |
+		       (precv_frame->u.hdr.attrib.frag_num & 0xf);
+	u16 *prxseq;
+
+	if (tid > 15)
+		return _FAIL;
+
+	if (pattrib->qos) {
+		if (IS_MCAST(pattrib->ra))
+			prxseq = &psta->sta_recvpriv.bmc_tid_rxseq[tid];
+		else
+			prxseq = &psta->sta_recvpriv.rxcache.tid_rxseq[tid];
+	} else {
+		if (IS_MCAST(pattrib->ra)) {
+			prxseq = &psta->sta_recvpriv.nonqos_bmc_rxseq;
+			#ifdef DBG_RX_SEQ
+			RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" nonqos bmc seq_num:%d\n"
+				, FUNC_ADPT_ARG(adapter), pattrib->seq_num);
+			#endif
+
+		} else {
+			prxseq = &psta->sta_recvpriv.nonqos_rxseq;
+			#ifdef DBG_RX_SEQ
+			RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" nonqos seq_num:%d\n"
+				, FUNC_ADPT_ARG(adapter), pattrib->seq_num);
+			#endif
+		}
+	}
+
+	if (seq_ctrl == *prxseq) {
+		/* for non-AMPDU case	*/
+		psta->sta_stats.duplicate_cnt++;
+
+		if (psta->sta_stats.duplicate_cnt % 100 == 0)
+			RTW_INFO("%s: tid=%u seq=%d frag=%d\n", __func__
+				, tid, precv_frame->u.hdr.attrib.seq_num
+				, precv_frame->u.hdr.attrib.frag_num);
+
+		#ifdef DBG_RX_DROP_FRAME
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_decache _FAIL for sta="MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
+		#endif
+		return _FAIL;
+	}
+	*prxseq = seq_ctrl;
+
+	return _SUCCESS;
+}
+
 void process_pwrbit_data(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *psta)
 {
 #ifdef CONFIG_AP_MODE
 	unsigned char pwrbit;
 	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
-	struct sta_priv *pstapriv = &padapter->stapriv;
 
 	pwrbit = GetPwrMgt(ptr);
 
 	if (pwrbit) {
 		if (!(psta->state & WIFI_SLEEP_STATE)) {
 			/* psta->state |= WIFI_SLEEP_STATE; */
-			/* pstapriv->sta_dz_bitmap |= BIT(psta->cmn.aid); */
+			/* rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, BIT(psta->cmn.aid)); */
 
 			stop_sta_xmit(padapter, psta);
-
-			/* RTW_INFO("to sleep, sta_dz_bitmap=%x\n", pstapriv->sta_dz_bitmap); */
+			/* RTW_INFO_DUMP("to sleep, sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len); */
 		}
 	} else {
 		if (psta->state & WIFI_SLEEP_STATE) {
 			/* psta->state ^= WIFI_SLEEP_STATE; */
-			/* pstapriv->sta_dz_bitmap &= ~BIT(psta->cmn.aid); */
+			/* rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, BIT(psta->cmn.aid)); */
 
 			wakeup_sta_to_xmit(padapter, psta);
-
-			/* RTW_INFO("to wakeup, sta_dz_bitmap=%x\n", pstapriv->sta_dz_bitmap); */
+			/* RTW_INFO_DUMP("to wakeup, sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len); */
 		}
 	}
 #endif
@@ -910,7 +946,6 @@ void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame, struc
 {
 #ifdef CONFIG_AP_MODE
 	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
-	struct sta_priv *pstapriv = &padapter->stapriv;
 
 #ifdef CONFIG_TDLS
 	if (!(psta->tdls_sta_state & TDLS_LINKED_STATE)) {
@@ -955,7 +990,7 @@ void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame, struc
 				xmit_delivery_enabled_frames(padapter, psta);
 			} else {
 				/* issue one qos null frame with More data bit = 0 and the EOSP bit set (=1) */
-				issue_qos_nulldata(padapter, psta->cmn.mac_addr, (u16)pattrib->priority, 0, 0);
+				issue_qos_nulldata(padapter, psta->cmn.mac_addr, (u16)pattrib->priority, 0, 0, 0);
 			}
 		}
 
@@ -1079,7 +1114,6 @@ exit:
 }
 #endif /* CONFIG_TDLS */
 
-void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info *sta);
 void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info *sta)
 {
 	int	sz;
@@ -1087,8 +1121,6 @@ void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_in
 	struct stainfo_stats	*pstats = NULL;
 	struct rx_pkt_attrib	*pattrib = &prframe->u.hdr.attrib;
 	struct recv_priv		*precvpriv = &padapter->recvpriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 	sz = get_recvframe_len(prframe);
 	precvpriv->rx_bytes += sz;
@@ -1108,6 +1140,7 @@ void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_in
 
 		pstats = &psta->sta_stats;
 
+		pstats->last_rx_time = rtw_get_current_time();
 		pstats->rx_data_pkts++;
 		pstats->rx_bytes += sz;
 		if (is_broadcast_mac_addr(pattrib->ra)) {
@@ -1123,11 +1156,22 @@ void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_in
 			/*record rx packets for every tid*/
 			pstats->rx_data_qos_pkts[pattrib->priority]++;
 		}
+#ifdef CONFIG_DYNAMIC_SOML
+		rtw_dyn_soml_byte_update(padapter, pattrib->data_rate, sz);
+#endif
+#if defined(CONFIG_CHECK_LEAVE_LPS) && defined(CONFIG_LPS_CHK_BY_TP)
+		if (adapter_to_pwrctl(padapter)->lps_chk_by_tp)
+			traffic_check_for_leave_lps_by_tp(padapter, _FALSE, psta);
+#endif /* CONFIG_LPS */
+
 	}
 
 #ifdef CONFIG_CHECK_LEAVE_LPS
-	traffic_check_for_leave_lps(padapter, _FALSE, 0);
-#endif /* CONFIG_LPS */
+#ifdef CONFIG_LPS_CHK_BY_TP
+	if (!adapter_to_pwrctl(padapter)->lps_chk_by_tp)
+#endif
+		traffic_check_for_leave_lps(padapter, _FALSE, 0);
+#endif /* CONFIG_CHECK_LEAVE_LPS */
 
 }
 
@@ -1359,12 +1403,14 @@ sint ap2sta_data_frame(
 			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" BSSID="MAC_FMT", mybssid="MAC_FMT"\n"
 				, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->bssid), MAC_ARG(mybssid));
 			#endif
-
-			if (!bmcast) {
+#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
+			if (!bmcast
+				&& !IS_RADAR_DETECTED(adapter_to_rfctl(adapter))
+			) {
 				RTW_INFO(ADPT_FMT" -issue_deauth to the nonassociated ap=" MAC_FMT " for the reason(7)\n", ADPT_ARG(adapter), MAC_ARG(pattrib->bssid));
 				issue_deauth(adapter, pattrib->bssid, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
 			}
-
+#endif
 			ret = _FAIL;
 			goto exit;
 		}
@@ -1470,21 +1516,13 @@ sint sta2ap_data_frame(
 
 		*psta = rtw_get_stainfo(pstapriv, pattrib->ta);
 		if (*psta == NULL) {
-			#ifdef CONFIG_DFS_MASTER
-			struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-
-			/* prevent RX tasklet blocks cmd_thread */
-			if (rfctl->radar_detected == 1)
-				goto bypass_deauth7;
-			#endif
-
-			RTW_INFO("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
-
-			issue_deauth(adapter, pattrib->src, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
-
-#ifdef CONFIG_DFS_MASTER
-bypass_deauth7:
+			if (!IS_RADAR_DETECTED(adapter_to_rfctl(adapter))) {
+#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
+				RTW_INFO("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
+				issue_deauth(adapter, pattrib->src, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
 #endif
+			}
+
 			ret = RTW_RX_HANDLED;
 			goto exit;
 		}
@@ -1526,8 +1564,10 @@ bypass_deauth7:
 			ret = RTW_RX_HANDLED;
 			goto exit;
 		}
+#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
 		RTW_INFO("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
 		issue_deauth(adapter, pattrib->src, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
+#endif
 		ret = RTW_RX_HANDLED;
 		goto exit;
 	}
@@ -1562,6 +1602,7 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 		return _FAIL;
 
 	/* for rx pkt statistics */
+	psta->sta_stats.last_rx_time = rtw_get_current_time();
 	psta->sta_stats.rx_ctrl_pkts++;
 
 	/* only handle ps-poll */
@@ -1603,7 +1644,7 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 			psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
 		}
 
-		if ((psta->state & WIFI_SLEEP_STATE) && (pstapriv->sta_dz_bitmap & BIT(psta->cmn.aid))) {
+		if ((psta->state & WIFI_SLEEP_STATE) && (rtw_tim_map_is_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid))) {
 			_irqL irqL;
 			_list	*xmitframe_plist, *xmitframe_phead;
 			struct xmit_frame *pxmitframe = NULL;
@@ -1631,7 +1672,8 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 
 				pxmitframe->attrib.triggered = 1;
 
-				/* RTW_INFO("handling ps-poll, q_len=%d, tim=%x\n", psta->sleepq_len, pstapriv->tim_bitmap); */
+				/* RTW_INFO("handling ps-poll, q_len=%d\n", psta->sleepq_len); */
+				/* RTW_INFO_DUMP("handling, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 
 #if 0
 				_exit_critical_bh(&psta->sleep_q.lock, &irqL);
@@ -1642,9 +1684,10 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 				rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
 
 				if (psta->sleepq_len == 0) {
-					pstapriv->tim_bitmap &= ~BIT(psta->cmn.aid);
+					rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-					/* RTW_INFO("after handling ps-poll, tim=%x\n", pstapriv->tim_bitmap); */
+					/* RTW_INFO("after handling ps-poll\n"); */
+					/* RTW_INFO_DUMP("after handling, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 
 					/* upate BCN for TIM IE */
 					/* update_BCNTIM(padapter);		 */
@@ -1659,7 +1702,7 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 				_exit_critical_bh(&pxmitpriv->lock, &irqL);
 
 				/* RTW_INFO("no buffered packets to xmit\n"); */
-				if (pstapriv->tim_bitmap & BIT(psta->cmn.aid)) {
+				if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
 					if (psta->sleepq_len == 0) {
 						RTW_INFO("no buffered packets to xmit\n");
 
@@ -1670,7 +1713,7 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 						psta->sleepq_len = 0;
 					}
 
-					pstapriv->tim_bitmap &= ~BIT(psta->cmn.aid);
+					rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
 					/* upate BCN for TIM IE */
 					/* update_BCNTIM(padapter); */
@@ -1683,41 +1726,280 @@ sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
 #ifdef CONFIG_BEAMFORMING
 		rtw_beamforming_get_ndpa_frame(padapter, precv_frame);
 #endif/*CONFIG_BEAMFORMING*/
+	} else if (get_frame_sub_type(pframe) == WIFI_BAR) {
+		rtw_process_bar_frame(padapter, precv_frame);
 	}
 
 	return _FAIL;
 
 }
 
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+static sint validate_mgmt_protect(_adapter *adapter, union recv_frame *precv_frame)
+{
+#define DBG_VALIDATE_MGMT_PROTECT 0
+#define DBG_VALIDATE_MGMT_DEC 0
+
+	struct security_priv *sec = &adapter->securitypriv;
+	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
+	struct sta_info	*psta = precv_frame->u.hdr.psta;
+	u8 *ptr;
+	u8 type;
+	u8 subtype;
+	u8 is_bmc;
+	u8 category = 0xFF;
+
+#ifdef CONFIG_IEEE80211W
+	const u8 *igtk;
+	u16 igtk_id;
+	u64* ipn;
+#endif
+
+	u8 *mgmt_DATA;
+	u32 data_len = 0;
+
+	sint ret;
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		if (!adapter->mesh_info.mesh_auth_id)
+			return pattrib->privacy ? _FAIL : _SUCCESS;
+	} else
+#endif
+	if (SEC_IS_BIP_KEY_INSTALLED(sec) == _FALSE)
+		return _SUCCESS;
+
+	ptr = precv_frame->u.hdr.rx_data;
+	type = GetFrameType(ptr);
+	subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
+	is_bmc = IS_MCAST(GetAddr1Ptr(ptr));
+
+#if DBG_VALIDATE_MGMT_PROTECT
+	if (subtype == WIFI_DEAUTH) {
+		RTW_INFO(FUNC_ADPT_FMT" bmc:%u, deauth, privacy:%u, encrypt:%u, bdecrypted:%u\n"
+			, FUNC_ADPT_ARG(adapter)
+			, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+	} else if (subtype == WIFI_DISASSOC) {
+		RTW_INFO(FUNC_ADPT_FMT" bmc:%u, disassoc, privacy:%u, encrypt:%u, bdecrypted:%u\n"
+			, FUNC_ADPT_ARG(adapter)
+			, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+	} if (subtype == WIFI_ACTION) {
+		if (pattrib->privacy) {
+			RTW_INFO(FUNC_ADPT_FMT" bmc:%u, action(?), privacy:%u, encrypt:%u, bdecrypted:%u\n"
+				, FUNC_ADPT_ARG(adapter)
+				, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+		} else {
+			RTW_INFO(FUNC_ADPT_FMT" bmc:%u, action(%u), privacy:%u, encrypt:%u, bdecrypted:%u\n"
+				, FUNC_ADPT_ARG(adapter), is_bmc
+				, *(ptr + sizeof(struct rtw_ieee80211_hdr_3addr))
+				, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
+		}
+	}
+#endif
+
+	if (!pattrib->privacy) {
+		if (!psta || !(psta->flags & WLAN_STA_MFP)) {
+			/* peer is not MFP capable, no need to check */
+			goto exit;
+		}
+
+		if (subtype == WIFI_ACTION)
+			category = *(ptr + sizeof(struct rtw_ieee80211_hdr_3addr));
+
+		if (is_bmc) {
+			/* broadcast cases */
+			if (subtype == WIFI_ACTION) {
+				if (CATEGORY_IS_GROUP_PRIVACY(category)) {
+					/* drop broadcast group privacy action frame without encryption */
+					#if DBG_VALIDATE_MGMT_PROTECT
+					RTW_INFO(FUNC_ADPT_FMT" broadcast gp action(%u) w/o encrypt\n"
+						, FUNC_ADPT_ARG(adapter), category);
+					#endif
+					goto fail;
+				}
+				if (CATEGORY_IS_ROBUST(category)) {
+					/* broadcast robust action frame need BIP check */
+					goto bip_verify;
+				}
+			}
+			if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC) {
+				/* broadcast deauth or disassoc frame need BIP check */
+				goto bip_verify;
+			}
+			goto exit;
+
+		} else {
+			/* unicast cases */
+			#ifdef CONFIG_IEEE80211W
+			if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC) {
+				if (!MLME_IS_MESH(adapter)) {
+					unsigned short reason = le16_to_cpu(*(unsigned short *)(ptr + WLAN_HDR_A3_LEN));
+
+					#if DBG_VALIDATE_MGMT_PROTECT
+					RTW_INFO(FUNC_ADPT_FMT" unicast %s, reason=%d w/o encrypt\n"
+						, FUNC_ADPT_ARG(adapter), subtype == WIFI_DEAUTH ? "deauth" : "disassoc", reason);
+					#endif
+					if (reason == 6 || reason == 7) {
+						/* issue sa query request */
+						issue_action_SA_Query(adapter, psta->cmn.mac_addr, 0, 0, IEEE80211W_RIGHT_KEY);
+					}
+				}
+				goto fail;
+			}
+			#endif
+
+			if (subtype == WIFI_ACTION && CATEGORY_IS_ROBUST(category)) {
+				if (psta->bpairwise_key_installed == _TRUE) {
+					#if DBG_VALIDATE_MGMT_PROTECT
+					RTW_INFO(FUNC_ADPT_FMT" unicast robust action(%d) w/o encrypt\n"
+						, FUNC_ADPT_ARG(adapter), category);
+					#endif
+					goto fail;
+				}
+			}
+			goto exit;
+		}
+
+bip_verify:
+#ifdef CONFIG_IEEE80211W
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(adapter)) {
+			if (psta->igtk_bmp) {
+				igtk = psta->igtk.skey;
+				igtk_id = psta->igtk_id;
+				ipn = &psta->igtk_pn.val;
+			} else {
+				/* mesh MFP without IGTK */
+				goto exit;
+			}
+		} else
+		#endif
+		{
+			igtk = sec->dot11wBIPKey[sec->dot11wBIPKeyid].skey;
+			igtk_id = sec->dot11wBIPKeyid;
+			ipn = &sec->dot11wBIPrxpn.val;
+		}
+
+		/* verify BIP MME IE */
+		ret = rtw_BIP_verify(adapter
+			, get_recvframe_data(precv_frame)
+			, get_recvframe_len(precv_frame)
+			, igtk, igtk_id, ipn);
+		if (ret == _FAIL) {
+			/* RTW_INFO("802.11w BIP verify fail\n"); */
+			goto fail;
+
+		} else if (ret == RTW_RX_HANDLED) {
+			#if DBG_VALIDATE_MGMT_PROTECT
+			RTW_INFO(FUNC_ADPT_FMT" none protected packet\n", FUNC_ADPT_ARG(adapter));
+			#endif
+			goto fail;
+		}
+#endif /* CONFIG_IEEE80211W */
+		goto exit;
+	}
+
+	/* cases to decrypt mgmt frame */
+	pattrib->bdecrypted = 0;
+	pattrib->encrypt = _AES_;
+	pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	/* set iv and icv length */
+	SET_ICE_IV_LEN(pattrib->iv_len, pattrib->icv_len, pattrib->encrypt);
+	_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
+	_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
+
+	/* actual management data frame body */
+	data_len = pattrib->pkt_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
+	mgmt_DATA = rtw_zmalloc(data_len);
+	if (mgmt_DATA == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT" mgmt allocate fail  !!!!!!!!!\n", FUNC_ADPT_ARG(adapter));
+		goto fail;
+	}
+
+#if DBG_VALIDATE_MGMT_DEC
+	/* dump the packet content before decrypt */
+	{
+		int pp;
+
+		printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
+		for (pp = 0; pp < pattrib->pkt_len; pp++)
+		printk(" %02x ", ptr[pp]);
+		printk("\n");
+	}
+#endif
+
+	precv_frame = decryptor(adapter, precv_frame);
+	/* save actual management data frame body */
+	_rtw_memcpy(mgmt_DATA, ptr + pattrib->hdrlen + pattrib->iv_len, data_len);
+	/* overwrite the iv field */
+	_rtw_memcpy(ptr + pattrib->hdrlen, mgmt_DATA, data_len);
+	/* remove the iv and icv length */
+	pattrib->pkt_len = pattrib->pkt_len - pattrib->iv_len - pattrib->icv_len;
+	rtw_mfree(mgmt_DATA, data_len);
+
+#if DBG_VALIDATE_MGMT_DEC
+	/* print packet content after decryption */
+	{
+		int pp;
+
+		printk("after decryption pattrib->pktlen = %d @@=>", pattrib->pkt_len);
+		for (pp = 0; pp < pattrib->pkt_len; pp++)
+		printk(" %02x ", ptr[pp]);
+		printk("\n");
+	}
+#endif
+
+	if (!precv_frame) {
+		#if DBG_VALIDATE_MGMT_PROTECT
+		RTW_INFO(FUNC_ADPT_FMT" mgmt descrypt fail  !!!!!!!!!\n", FUNC_ADPT_ARG(adapter));
+		#endif
+		goto fail;
+	}
+
+exit:
+	return _SUCCESS;
+
+fail:
+	return _FAIL;
+
+}
+#endif /* defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH) */
+
 union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame);
-sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame);
+
 sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)
 {
-	/* struct mlme_priv *pmlmepriv = &adapter->mlmepriv; */
+	struct sta_info *psta = precv_frame->u.hdr.psta
+		= rtw_get_stainfo(&padapter->stapriv, get_addr2_ptr(precv_frame->u.hdr.rx_data));
+
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+	if (validate_mgmt_protect(padapter, precv_frame) == _FAIL) {
+		DBG_COUNTER(padapter->rx_logs.core_rx_pre_mgmt_err_80211w);
+		goto exit;
+	}
+#endif
 
 	precv_frame = recvframe_chk_defrag(padapter, precv_frame);
-	if (precv_frame == NULL) {
+	if (precv_frame == NULL)
 		return _SUCCESS;
-	}
 
-	{
-		/* for rx pkt statistics */
-		struct sta_info *psta = rtw_get_stainfo(&padapter->stapriv, get_addr2_ptr(precv_frame->u.hdr.rx_data));
-		if (psta) {
-			psta->sta_stats.rx_mgnt_pkts++;
-			if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_BEACON)
-				psta->sta_stats.rx_beacon_pkts++;
-			else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBEREQ)
-				psta->sta_stats.rx_probereq_pkts++;
-			else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBERSP) {
-				if (_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(precv_frame->u.hdr.rx_data), ETH_ALEN) == _TRUE)
-					psta->sta_stats.rx_probersp_pkts++;
-				else if (is_broadcast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data))
-					|| is_multicast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data)))
-					psta->sta_stats.rx_probersp_bm_pkts++;
-				else
-					psta->sta_stats.rx_probersp_uo_pkts++;
-			}
+	/* for rx pkt statistics */
+	if (psta) {
+		psta->sta_stats.last_rx_time = rtw_get_current_time();
+		psta->sta_stats.rx_mgnt_pkts++;
+		if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_BEACON)
+			psta->sta_stats.rx_beacon_pkts++;
+		else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBEREQ)
+			psta->sta_stats.rx_probereq_pkts++;
+		else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBERSP) {
+			if (_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(precv_frame->u.hdr.rx_data), ETH_ALEN) == _TRUE)
+				psta->sta_stats.rx_probersp_pkts++;
+			else if (is_broadcast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data))
+				|| is_multicast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data)))
+				psta->sta_stats.rx_probersp_bm_pkts++;
+			else
+				psta->sta_stats.rx_probersp_uo_pkts++;
 		}
 	}
 
@@ -1770,21 +2052,37 @@ sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)
 #endif
 	mgt_dispatcher(padapter, precv_frame);
 
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+exit:
+#endif
 	return _SUCCESS;
 
 }
 
 sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)
 {
-	u8 bretry;
+	u8 bretry, a4_shift;
 	struct sta_info *psta = NULL;
 	u8 *ptr = precv_frame->u.hdr.rx_data;
 	struct rx_pkt_attrib	*pattrib = &precv_frame->u.hdr.attrib;
-	struct sta_priv	*pstapriv = &adapter->stapriv;
 	struct security_priv	*psecuritypriv = &adapter->securitypriv;
 	sint ret = _SUCCESS;
 
 	bretry = GetRetry(ptr);
+	a4_shift = (pattrib->to_fr_ds == 3) ? ETH_ALEN : 0;
+
+	/* some address fields are different when using AMSDU */
+	if (pattrib->qos)
+		pattrib->amsdu = GetAMsdu(ptr + WLAN_HDR_A3_LEN + a4_shift);
+	else
+		pattrib->amsdu = 0;
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		ret = rtw_mesh_rx_data_validate_hdr(adapter, precv_frame, &psta);
+		goto pre_validate_status_chk;
+	}
+#endif
 
 	switch (pattrib->to_fr_ds) {
 	case 0:
@@ -1821,10 +2119,13 @@ sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)
 		break;
 	}
 
+#ifdef CONFIG_RTW_MESH
+pre_validate_status_chk:
+#endif
 	if (ret == _FAIL) {
 		#ifdef DBG_RX_DROP_FRAME
-		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" case:%d, res:%d\n"
-			, FUNC_ADPT_ARG(adapter), pattrib->to_fr_ds, ret);
+		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" case:%d, res:%d, ra="MAC_FMT", ta="MAC_FMT"\n"
+			, FUNC_ADPT_ARG(adapter), pattrib->to_fr_ds, ret, MAC_ARG(GetAddr1Ptr(ptr)), MAC_ARG(get_addr2_ptr(ptr)));
 		#endif
 		goto exit;
 	} else if (ret == RTW_RX_HANDLED)
@@ -1834,45 +2135,46 @@ sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)
 	if (psta == NULL) {
 		#ifdef DBG_RX_DROP_FRAME
 		RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" psta == NULL, ra="MAC_FMT", ta="MAC_FMT"\n"
-			, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->ra), MAC_ARG(pattrib->ta));
+			, FUNC_ADPT_ARG(adapter), MAC_ARG(GetAddr1Ptr(ptr)), MAC_ARG(get_addr2_ptr(ptr)));
 		#endif
 		ret = _FAIL;
 		goto exit;
 	}
 
 	precv_frame->u.hdr.psta = psta;
-
-
-	pattrib->amsdu = 0;
+	precv_frame->u.hdr.preorder_ctrl = NULL;
 	pattrib->ack_policy = 0;
+
 	/* parsing QC field */
 	if (pattrib->qos == 1) {
-		pattrib->priority = GetPriority((ptr + 24));
-		pattrib->ack_policy = GetAckpolicy((ptr + 24));
-		pattrib->amsdu = GetAMsdu((ptr + 24));
-		pattrib->hdrlen = pattrib->to_fr_ds == 3 ? 32 : 26;
-
+		pattrib->priority = GetPriority((ptr + WLAN_HDR_A3_LEN + a4_shift)); /* point to Qos field*/
+		pattrib->ack_policy = GetAckpolicy((ptr + WLAN_HDR_A3_LEN + a4_shift));
+		pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN + a4_shift;
 		if (pattrib->priority != 0 && pattrib->priority != 3)
 			adapter->recvpriv.is_any_non_be_pkts = _TRUE;
 		else
 			adapter->recvpriv.is_any_non_be_pkts = _FALSE;
 	} else {
 		pattrib->priority = 0;
-		pattrib->hdrlen = pattrib->to_fr_ds == 3 ? 30 : 24;
+		pattrib->hdrlen = WLAN_HDR_A3_LEN + a4_shift;
 	}
 
-
 	if (pattrib->order) /* HT-CTRL 11n */
 		pattrib->hdrlen += 4;
 
+	/* decache, drop duplicate recv packets */
+	ret = recv_decache(precv_frame);
+	if (ret  == _FAIL)
+		goto exit;
+
 	if (!IS_MCAST(pattrib->ra)) {
-		precv_frame->u.hdr.preorder_ctrl = &psta->recvreorder_ctrl[pattrib->priority];
 
-		/* decache, drop duplicate recv packets */
-		if ((recv_decache(precv_frame, bretry) == _FAIL) ||
-			(recv_ucast_pn_decache(precv_frame) == _FAIL)) {
+		if (pattrib->qos)
+			precv_frame->u.hdr.preorder_ctrl = &psta->recvreorder_ctrl[pattrib->priority];
+
+		if (recv_ucast_pn_decache(precv_frame) == _FAIL) {
 			#ifdef DBG_RX_DROP_FRAME
-			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_decache return _FAIL for sta="MAC_FMT"\n"
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_ucast_pn_decache return _FAIL for sta="MAC_FMT"\n"
 				, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
 			#endif
 			ret = _FAIL;
@@ -1881,14 +2183,12 @@ sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)
 	} else {
 		if (recv_bcast_pn_decache(precv_frame) == _FAIL) {
 			#ifdef DBG_RX_DROP_FRAME
-			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_bcast_pn_decache _FAIL for invalid PN!\n"
-				, FUNC_ADPT_ARG(adapter));
+			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_bcast_pn_decache return _FAIL for sta="MAC_FMT"\n"
+				, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
 			#endif
 			ret = _FAIL;
 			goto exit;
-		}	
-
-		precv_frame->u.hdr.preorder_ctrl = NULL;
+		}
 	}
 
 	if (pattrib->privacy) {
@@ -1906,128 +2206,16 @@ sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)
 		pattrib->iv_len = pattrib->icv_len = 0;
 	}
 
-exit:
-
-
-	return ret;
-}
-
-#ifdef CONFIG_IEEE80211W
-static sint validate_80211w_mgmt(_adapter *adapter, union recv_frame *precv_frame)
-{
-	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
-	u8 *ptr = precv_frame->u.hdr.rx_data;
-	struct sta_info	*psta;
-	struct sta_priv		*pstapriv = &adapter->stapriv;
-	u8 type;
-	u8 subtype;
-
-	type =  GetFrameType(ptr);
-	subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
-
-	if (adapter->securitypriv.binstallBIPkey == _TRUE) {
-		/* unicast management frame decrypt */
-		if (pattrib->privacy && !(IS_MCAST(GetAddr1Ptr(ptr))) &&
-		    (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC || subtype == WIFI_ACTION)) {
-			u8 *ppp, *mgmt_DATA;
-			u32 data_len = 0;
-			ppp = get_addr2_ptr(ptr);
-
-			pattrib->bdecrypted = 0;
-			pattrib->encrypt = _AES_;
-			pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-			/* set iv and icv length */
-			SET_ICE_IV_LEN(pattrib->iv_len, pattrib->icv_len, pattrib->encrypt);
-			_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
-			_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
-			/* actual management data frame body */
-			data_len = pattrib->pkt_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
-			mgmt_DATA = rtw_zmalloc(data_len);
-			if (mgmt_DATA == NULL) {
-				RTW_INFO("%s mgmt allocate fail  !!!!!!!!!\n", __FUNCTION__);
-				goto validate_80211w_fail;
-			}
-#if 0
-			/* dump the packet content before decrypt */
-			{
-				int pp;
-				printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
-				for (pp = 0; pp < pattrib->pkt_len; pp++)
-					printk(" %02x ", ptr[pp]);
-				printk("\n");
-			}
-#endif
-
-			precv_frame = decryptor(adapter, precv_frame);
-			/* save actual management data frame body */
-			_rtw_memcpy(mgmt_DATA, ptr + pattrib->hdrlen + pattrib->iv_len, data_len);
-			/* overwrite the iv field */
-			_rtw_memcpy(ptr + pattrib->hdrlen, mgmt_DATA, data_len);
-			/* remove the iv and icv length */
-			pattrib->pkt_len = pattrib->pkt_len - pattrib->iv_len - pattrib->icv_len;
-			rtw_mfree(mgmt_DATA, data_len);
-#if 0
-			/* print packet content after decryption */
-			{
-				int pp;
-				printk("after decryption pattrib->pktlen = %d @@=>", pattrib->pkt_len);
-				for (pp = 0; pp < pattrib->pkt_len; pp++)
-					printk(" %02x ", ptr[pp]);
-				printk("\n");
-			}
+#ifdef CONFIG_RTW_MESH
+	if (!pattrib->amsdu
+		&& pattrib->mesh_ctrl_present
+		&& (!pattrib->encrypt || pattrib->bdecrypted))
+		ret = rtw_mesh_rx_validate_mctrl_non_amsdu(adapter, precv_frame);
 #endif
-			if (!precv_frame) {
-				RTW_INFO("%s mgmt descrypt fail  !!!!!!!!!\n", __FUNCTION__);
-				goto validate_80211w_fail;
-			}
-		} else if (IS_MCAST(GetAddr1Ptr(ptr)) &&
-			(subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC)) {
-			sint BIP_ret = _SUCCESS;
-			/* verify BIP MME IE of broadcast/multicast de-auth/disassoc packet */
-			BIP_ret = rtw_BIP_verify(adapter, (u8 *)precv_frame);
-			if (BIP_ret == _FAIL) {
-				/* RTW_INFO("802.11w BIP verify fail\n"); */
-				goto validate_80211w_fail;
-			} else if (BIP_ret == RTW_RX_HANDLED) {
-				RTW_INFO("802.11w recv none protected packet\n");
-				/* drop pkt, don't issue sa query request */
-				/* issue_action_SA_Query(adapter, NULL, 0, 0, 0); */
-				goto validate_80211w_fail;
-			}
-		} /* 802.11w protect */
-		else {
-			psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(ptr));
-
-			if (subtype == WIFI_ACTION && psta && psta->bpairwise_key_installed == _TRUE) {
-				/* according 802.11-2012 standard, these five types are not robust types */
-				if (ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_PUBLIC          &&
-				    ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_HT              &&
-				    ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_UNPROTECTED_WNM &&
-				    ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_SELF_PROTECTED  &&
-				    ptr[WLAN_HDR_A3_LEN] != RTW_WLAN_CATEGORY_P2P) {
-					RTW_INFO("action frame category=%d should robust\n", ptr[WLAN_HDR_A3_LEN]);
-					goto validate_80211w_fail;
-				}
-			} else if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC) {
-				unsigned short	reason;
-				reason = le16_to_cpu(*(unsigned short *)(ptr + WLAN_HDR_A3_LEN));
-				RTW_INFO("802.11w recv none protected packet, reason=%d\n", reason);
-				if (reason == 6 || reason == 7) {
-					/* issue sa query request */
-					issue_action_SA_Query(adapter, NULL, 0, 0, IEEE80211W_RIGHT_KEY);
-				}
-				goto validate_80211w_fail;
-			}
-		}
-	}
-	return _SUCCESS;
-
-validate_80211w_fail:
-	return _FAIL;
 
+exit:
+	return ret;
 }
-#endif /* CONFIG_IEEE80211W */
 
 static inline void dump_rx_packet(u8 *ptr)
 {
@@ -2140,14 +2328,6 @@ sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame)
 	switch (type) {
 	case WIFI_MGT_TYPE: /* mgnt */
 		DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt);
-#ifdef CONFIG_IEEE80211W
-		if (validate_80211w_mgmt(adapter, precv_frame) == _FAIL) {
-			retval = _FAIL;
-			DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt_err_80211w);
-			break;
-		}
-#endif /* CONFIG_IEEE80211W */
-
 		retval = validate_recv_mgnt_frame(adapter, precv_frame);
 		if (retval == _FAIL) {
 			DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt_err);
@@ -2208,7 +2388,7 @@ sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame)
 				/* dump eapol */
 				rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_RXPKT, &(bDumpRxPkt));
 				/* get ether_type */
-				_rtw_memcpy(&eth_type, ptr + pattrib->hdrlen + pattrib->iv_len + LLC_HEADER_SIZE, 2);
+				_rtw_memcpy(&eth_type, ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + LLC_HEADER_SIZE, 2);
 				eth_type = ntohs((unsigned short) eth_type);
 				if ((bDumpRxPkt == 4) && (eth_type == 0x888e))
 					dump_rx_packet(ptr);
@@ -2255,8 +2435,8 @@ sint wlanhdr_to_ethhdr(union recv_frame *precvframe)
 	if (pattrib->encrypt)
 		recvframe_pull_tail(precvframe, pattrib->icv_len);
 
-	psnap = (struct ieee80211_snap_hdr *)(ptr + pattrib->hdrlen + pattrib->iv_len);
-	psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
+	psnap = (struct ieee80211_snap_hdr *)(ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib));
+	psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + SNAP_SIZE;
 	/* convert hdr + possible LLC headers into Ethernet header */
 	/* eth_type = (psnap_type[0] << 8) | psnap_type[1]; */
 	if ((_rtw_memcmp(psnap, rtw_rfc1042_header, SNAP_SIZE) &&
@@ -2271,7 +2451,7 @@ sint wlanhdr_to_ethhdr(union recv_frame *precvframe)
 		bsnaphdr = _FALSE;
 	}
 
-	rmv_len = pattrib->hdrlen + pattrib->iv_len + (bsnaphdr ? SNAP_SIZE : 0);
+	rmv_len = pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + (bsnaphdr ? SNAP_SIZE : 0);
 	len = precvframe->u.hdr.len - rmv_len;
 
 
@@ -2310,6 +2490,8 @@ sint wlanhdr_to_ethhdr(union recv_frame *precvframe)
 			len = htons(len);
 			_rtw_memcpy(ptr + 12, &len, 2);
 		}
+
+		rtw_rframe_set_os_pkt(precvframe);
 	}
 
 exiting:
@@ -2318,6 +2500,11 @@ exiting:
 }
 
 #else
+static u8 SNAP_ETH_TYPE_APPLETALK_DDP[2] = {0x80, 0x9b};
+/* Datagram Delivery Protocol */
+static u8 SNAP_HDR_APPLETALK_DDP[3] = {0x08, 0x00, 0x07};
+static u8 oui_8021h[] = {0x00, 0x00, 0xf8};
+static u8 oui_rfc1042[] = {0x00, 0x00, 0x00};
 
 sint wlanhdr_to_ethhdr(union recv_frame *precvframe)
 {
@@ -2590,7 +2777,7 @@ union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *prec
 	struct sta_priv *pstapriv;
 	_list *phead;
 	union recv_frame *prtnframe = NULL;
-	_queue *pfree_recv_queue, *pdefrag_q;
+	_queue *pfree_recv_queue, *pdefrag_q = NULL;
 
 
 	pstapriv = &padapter->stapriv;
@@ -2609,7 +2796,8 @@ union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *prec
 		u8 type = GetFrameType(pfhdr->rx_data);
 		if (type != WIFI_DATA_TYPE) {
 			psta = rtw_get_bcmc_stainfo(padapter);
-			pdefrag_q = &psta->sta_recvpriv.defrag_q;
+			if (psta)
+				pdefrag_q = &psta->sta_recvpriv.defrag_q;
 		} else
 			pdefrag_q = NULL;
 	} else
@@ -2690,6 +2878,13 @@ static int rtw_recv_indicatepkt_check(union recv_frame *rframe, u8 *ehdr_pos, u3
 	_adapter *adapter = rframe->u.hdr.adapter;
 	struct recv_priv *recvpriv = &adapter->recvpriv;
 	struct ethhdr *ehdr = (struct ethhdr *)ehdr_pos;
+#ifdef DBG_IP_R_MONITOR
+	int i;
+	struct rx_pkt_attrib *pattrib = &rframe->u.hdr.attrib;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
+	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+#endif/*DBG_IP_R_MONITOR*/
 	int ret = _FAIL;
 
 #ifdef CONFIG_WAPI_SUPPORT
@@ -2706,7 +2901,11 @@ static int rtw_recv_indicatepkt_check(union recv_frame *rframe, u8 *ehdr_pos, u3
 		rtw_st_ctl_rx(rframe->u.hdr.psta, ehdr_pos);
 
 	if (ntohs(ehdr->h_proto) == 0x888e)
-		RTW_PRINT("recv eapol packet\n");
+		parsing_eapol_packet(adapter, ehdr_pos + ETH_HLEN, rframe->u.hdr.psta, 0);
+#ifdef DBG_ARP_DUMP
+	else if (ntohs(ehdr->h_proto) == ETH_P_ARP)
+		dump_arp_pkt(RTW_DBGDUMP, ehdr->h_dest, ehdr->h_source, ehdr_pos + ETH_HLEN, 0);
+#endif
 
 	if (recvpriv->sink_udpport > 0)
 		rtw_sink_rtp_seq_dbg(adapter, ehdr_pos);
@@ -2727,6 +2926,22 @@ static int rtw_recv_indicatepkt_check(union recv_frame *rframe, u8 *ehdr_pos, u3
 	}
 #endif
 
+#ifdef DBG_IP_R_MONITOR
+	#define LEN_ARP_OP_HDR 7 /*ARP OERATION */
+	if (ntohs(ehdr->h_proto) == ETH_P_ARP) {
+
+		if(check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _TRUE){
+			if(ehdr_pos[ETHERNET_HEADER_SIZE+LEN_ARP_OP_HDR] == 2) {
+				RTW_INFO("%s,[DBG_ARP] Rx ARP RSP Packet with Dst= "MAC_FMT" ;SeqNum = %d !\n",
+					__FUNCTION__, MAC_ARG(pattrib->dst), pattrib->seq_num);
+				for(i=0;i<(pkt_len -ETHERNET_HEADER_SIZE);i++)
+					RTW_INFO("0x%x ",ehdr_pos[i+ETHERNET_HEADER_SIZE]);
+				RTW_INFO("\n");
+			}
+		}
+	}
+#endif/*DBG_IP_R_MONITOR*/
+
 #ifdef CONFIG_AUTO_AP_MODE
 	if (ntohs(ehdr->h_proto) == 0x8899)
 		rtw_auto_ap_rx_msg_dump(adapter, rframe, ehdr_pos);
@@ -2734,10 +2949,94 @@ static int rtw_recv_indicatepkt_check(union recv_frame *rframe, u8 *ehdr_pos, u3
 
 	ret = _SUCCESS;
 
+#ifdef CONFIG_WAPI_SUPPORT
 exit:
+#endif
 	return ret;
 }
 
+static void recv_free_fwd_resource(_adapter *adapter, struct xmit_frame *fwd_frame, _list *b2u_list)
+{
+	struct xmit_priv *xmitpriv = &adapter->xmitpriv;
+
+	if (fwd_frame)
+		rtw_free_xmitframe(xmitpriv, fwd_frame);
+
+#ifdef CONFIG_RTW_MESH
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (!rtw_is_list_empty(b2u_list)) {
+		struct xmit_frame *b2uframe;
+		_list *list;
+
+		list = get_next(b2u_list);
+		while (rtw_end_of_queue_search(b2u_list, list) == _FALSE) {
+			b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+			list = get_next(list);
+			rtw_list_delete(&b2uframe->list);
+			rtw_free_xmitframe(xmitpriv, b2uframe);
+		}
+	}
+#endif
+#endif /* CONFIG_RTW_MESH */
+}
+
+#ifdef CONFIG_RTW_MESH
+static void recv_fwd_pkt_hdl(_adapter *adapter, _pkt *pkt
+	, u8 act, struct xmit_frame *fwd_frame, _list *b2u_list)
+{
+	struct xmit_priv *xmitpriv = &adapter->xmitpriv;
+	_pkt *fwd_pkt = pkt;
+
+	if (act & RTW_RX_MSDU_ACT_INDICATE) {
+		fwd_pkt = rtw_os_pkt_copy(pkt);
+		if (!fwd_pkt) {
+			#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME %s rtw_os_pkt_copy fail\n", __func__);
+			#endif
+			recv_free_fwd_resource(adapter, fwd_frame, b2u_list);
+			goto exit;
+		}
+	}
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	if (!rtw_is_list_empty(b2u_list)) {
+		_list *list = get_next(b2u_list);
+		struct xmit_frame *b2uframe;
+
+		while (rtw_end_of_queue_search(b2u_list, list) == _FALSE) {
+			b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+			list = get_next(list);
+			rtw_list_delete(&b2uframe->list);
+
+			if (!fwd_frame && rtw_is_list_empty(b2u_list)) /* the last fwd_pkt */
+				b2uframe->pkt = fwd_pkt;
+			else
+				b2uframe->pkt = rtw_os_pkt_copy(fwd_pkt);
+			if (!b2uframe->pkt) {
+				rtw_free_xmitframe(xmitpriv, b2uframe);
+				continue;
+			}
+
+			rtw_xmit_posthandle(adapter, b2uframe, b2uframe->pkt);
+		}
+	}
+#endif
+
+	if (fwd_frame) {
+		fwd_frame->pkt = fwd_pkt;
+		if (rtw_xmit_posthandle(adapter, fwd_frame, fwd_pkt) < 0) {
+			#ifdef DBG_TX_DROP_FRAME
+			RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit_posthandle fail\n", __func__);
+			#endif
+			xmitpriv->tx_drop++;
+		}
+	}
+
+exit:
+	return;
+}
+#endif /* CONFIG_RTW_MESH */
+
 int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)
 {
 	struct rx_pkt_attrib *rattrib = &prframe->u.hdr.attrib;
@@ -2748,6 +3047,11 @@ int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)
 	_pkt *sub_pkt, *subframes[MAX_SUBFRAME_COUNT];
 	struct recv_priv *precvpriv = &padapter->recvpriv;
 	_queue *pfree_recv_queue = &(precvpriv->free_recv_queue);
+	const u8 *da, *sa;
+	int act;
+	struct xmit_frame *fwd_frame;
+	_list b2u_list;
+	u8 mctrl_len = 0;
 	int	ret = _SUCCESS;
 
 	nr_subframes = 0;
@@ -2761,26 +3065,72 @@ int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)
 	pdata = prframe->u.hdr.rx_data;
 
 	while (a_len > ETH_HLEN) {
-
 		/* Offset 12 denote 2 mac address */
 		nSubframe_Length = RTW_GET_BE16(pdata + 12);
-
 		if (a_len < (ETHERNET_HEADER_SIZE + nSubframe_Length)) {
 			RTW_INFO("nRemain_Length is %d and nSubframe_Length is : %d\n", a_len, nSubframe_Length);
 			break;
 		}
 
-		sub_pkt = rtw_os_alloc_msdu_pkt(prframe, nSubframe_Length, pdata);
+		act = RTW_RX_MSDU_ACT_INDICATE;
+		fwd_frame = NULL;
+
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter)) {
+			u8 *mda = pdata, *msa = pdata + ETH_ALEN;
+			struct rtw_ieee80211s_hdr *mctrl = (struct rtw_ieee80211s_hdr *)(pdata + ETH_HLEN);
+			int v_ret;
+
+			v_ret = rtw_mesh_rx_data_validate_mctrl(padapter, prframe
+				, mctrl, mda, msa, &mctrl_len, &da, &sa);
+			if (v_ret != _SUCCESS)
+				goto move_to_next;
+
+			act = rtw_mesh_rx_msdu_act_check(prframe
+				, mda, msa, da, sa, mctrl, &fwd_frame, &b2u_list);
+		} else
+		#endif
+		{
+			da = pdata;
+			sa = pdata + ETH_ALEN;
+		}
+
+		if (!act)
+			goto move_to_next;
+
+		rtw_led_rx_control(padapter, da);
+
+		sub_pkt = rtw_os_alloc_msdu_pkt(prframe, da, sa
+			, pdata + ETH_HLEN + mctrl_len, nSubframe_Length - mctrl_len);
 		if (sub_pkt == NULL) {
-			RTW_INFO("%s(): allocate sub packet fail !!!\n", __FUNCTION__);
+			if (act & RTW_RX_MSDU_ACT_INDICATE) {
+				#ifdef DBG_RX_DROP_FRAME
+				RTW_INFO("DBG_RX_DROP_FRAME %s rtw_os_alloc_msdu_pkt fail\n", __func__);
+				#endif
+			}
+			if (act & RTW_RX_MSDU_ACT_FORWARD) {
+				#ifdef DBG_TX_DROP_FRAME
+				RTW_INFO("DBG_TX_DROP_FRAME %s rtw_os_alloc_msdu_pkt fail\n", __func__);
+				#endif
+				recv_free_fwd_resource(padapter, fwd_frame, &b2u_list);
+			}
 			break;
 		}
 
+		#ifdef CONFIG_RTW_MESH
+		if (act & RTW_RX_MSDU_ACT_FORWARD) {
+			recv_fwd_pkt_hdl(padapter, sub_pkt, act, fwd_frame, &b2u_list);
+			if (!(act & RTW_RX_MSDU_ACT_INDICATE))
+				goto move_to_next;
+		}
+		#endif
+
 		if (rtw_recv_indicatepkt_check(prframe, rtw_os_pkt_data(sub_pkt), rtw_os_pkt_len(sub_pkt)) == _SUCCESS)
 			subframes[nr_subframes++] = sub_pkt;
 		else
 			rtw_os_pkt_free(sub_pkt);
 
+move_to_next:
 		/* move the data point to data content */
 		pdata += ETH_HLEN;
 		a_len -= ETH_HLEN;
@@ -2822,7 +3172,6 @@ int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)
 
 static int recv_process_mpdu(_adapter *padapter, union recv_frame *prframe)
 {
-	struct recv_priv *precvpriv = &padapter->recvpriv;
 	_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
 	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
 	int ret;
@@ -2838,16 +3187,57 @@ static int recv_process_mpdu(_adapter *padapter, union recv_frame *prframe)
 			goto exit;
 		}
 	} else {
+		int act = RTW_RX_MSDU_ACT_INDICATE;
+		struct xmit_frame *fwd_frame = NULL;
+		_list b2u_list;
+
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter) && pattrib->mesh_ctrl_present) {
+			act = rtw_mesh_rx_msdu_act_check(prframe
+				, pattrib->mda, pattrib->msa
+				, pattrib->dst, pattrib->src
+				, (struct rtw_ieee80211s_hdr *)(get_recvframe_data(prframe) + pattrib->hdrlen + pattrib->iv_len)
+				, &fwd_frame, &b2u_list);
+		}
+		#endif
+
+		if (!act) {
+			rtw_free_recvframe(prframe, pfree_recv_queue);
+			ret = _FAIL;
+			goto exit;
+		}
+
+		rtw_led_rx_control(padapter, pattrib->dst);
+
 		ret = wlanhdr_to_ethhdr(prframe);
 		if (ret != _SUCCESS) {
-			#ifdef DBG_RX_DROP_FRAME
-			RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" wlanhdr_to_ethhdr: drop pkt\n"
-				, FUNC_ADPT_ARG(padapter));
-			#endif
+			if (act & RTW_RX_MSDU_ACT_INDICATE) {
+				#ifdef DBG_RX_DROP_FRAME
+				RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" wlanhdr_to_ethhdr: drop pkt\n"
+					, FUNC_ADPT_ARG(padapter));
+				#endif
+			}
+			if (act & RTW_RX_MSDU_ACT_FORWARD) {
+				#ifdef DBG_TX_DROP_FRAME
+				RTW_INFO("DBG_TX_DROP_FRAME %s wlanhdr_to_ethhdr fail\n", __func__);
+				#endif
+				recv_free_fwd_resource(padapter, fwd_frame, &b2u_list);
+			}
 			rtw_free_recvframe(prframe, pfree_recv_queue);
 			goto exit;
 		}
 
+		#ifdef CONFIG_RTW_MESH
+		if (act & RTW_RX_MSDU_ACT_FORWARD) {
+			recv_fwd_pkt_hdl(padapter, prframe->u.hdr.pkt, act, fwd_frame, &b2u_list);
+			if (!(act & RTW_RX_MSDU_ACT_INDICATE)) {
+				prframe->u.hdr.pkt = NULL;
+				rtw_free_recvframe(prframe, pfree_recv_queue);
+				goto exit;
+			}
+		}
+		#endif
+
 		if (!RTW_CANNOT_RUN(padapter)) {
 			ret = rtw_recv_indicatepkt_check(prframe
 				, get_recvframe_data(prframe), get_recvframe_len(prframe));
@@ -3138,7 +3528,6 @@ static int recv_indicatepkts_in_order(_adapter *padapter, struct recv_reorder_ct
 static int recv_indicatepkt_reorder(_adapter *padapter, union recv_frame *prframe)
 {
 	_irqL irql;
-	int retval = _SUCCESS;
 	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
 	struct recv_reorder_ctrl *preorder_ctrl = prframe->u.hdr.preorder_ctrl;
 	_queue *ppending_recvframe_queue = preorder_ctrl ? &preorder_ctrl->pending_recvframe_queue : NULL;
@@ -3357,7 +3746,6 @@ static sint MPwlanhdr_to_ethhdr(union recv_frame *precvframe)
 
 	sint ret = _SUCCESS;
 	_adapter			*adapter = precvframe->u.hdr.adapter;
-	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 
 	u8	*ptr = get_recvframe_data(precvframe) ; /* point to frame_ctrl field */
 	struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
@@ -3425,7 +3813,6 @@ int mp_recv_frame(_adapter *padapter, union recv_frame *rframe)
 {
 	int ret = _SUCCESS;
 	struct rx_pkt_attrib *pattrib = &rframe->u.hdr.attrib;
-	struct recv_priv *precvpriv = &padapter->recvpriv;
 	_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
 #ifdef CONFIG_MP_INCLUDED
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
@@ -3603,8 +3990,6 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 #endif
 
 	sint ret = _SUCCESS;
-	_adapter			*adapter = precvframe->u.hdr.adapter;
-	struct mlme_priv	*pmlmepriv = &adapter->mlmepriv;
 	struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
 
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
@@ -3675,9 +4060,9 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	rt_len += 1;
 
 	/* rate */
-	if (pattrib->data_rate < 12) {
+	if (pattrib->data_rate <= DESC_RATE54M) {
 		rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_RATE);
-		if (pattrib->data_rate < 4) {
+		if (pattrib->data_rate <= DESC_RATE11M) {
 			/* CCK */
 			hdr_buf[rt_len] = data_rate[pattrib->data_rate];
 		} else {
@@ -3702,8 +4087,8 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	else
 		tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_5GHZ);
 
-	if (pattrib->data_rate < 12) {
-		if (pattrib->data_rate < 4) {
+	if (pattrib->data_rate <= DESC_RATE54M) {
+		if (pattrib->data_rate <= DESC_RATE11M) {
 			/* CCK */
 			tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_CCK);
 		} else {
@@ -3746,7 +4131,7 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	rt_len += 2;
 
 	/* MCS information */
-	if (pattrib->data_rate >= 12 && pattrib->data_rate < 44) {
+	if (pattrib->data_rate >= DESC_RATEMCS0 && pattrib->data_rate <= DESC_RATEMCS31) {
 		rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_MCS);
 		/* known, flag */
 		hdr_buf[rt_len] |= BIT1; /* MCS index known */
@@ -3771,7 +4156,7 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	}
 
 	/* VHT */
-	if (pattrib->data_rate >= 44 && pattrib->data_rate < 84) {
+	if (pattrib->data_rate >= DESC_RATEVHTSS1MCS0 && pattrib->data_rate <= DESC_RATEVHTSS4MCS9) {
 		rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_VHT);
 
 		/* known 16 bit, flag 8 bit */
@@ -3813,16 +4198,16 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 		rt_len += 1;
 
 		/* mcs_nss */
-		if (pattrib->data_rate >= 44 && pattrib->data_rate < 54) {
+		if (pattrib->data_rate >= DESC_RATEVHTSS1MCS0 && pattrib->data_rate <= DESC_RATEVHTSS1MCS9) {
 			hdr_buf[rt_len] |= 1;
 			hdr_buf[rt_len] |= data_rate[pattrib->data_rate] << 4;
-		} else if (pattrib->data_rate >= 54 && pattrib->data_rate < 64) {
+		} else if (pattrib->data_rate >= DESC_RATEVHTSS2MCS0 && pattrib->data_rate <= DESC_RATEVHTSS2MCS9) {
 			hdr_buf[rt_len + 1] |= 2;
 			hdr_buf[rt_len + 1] |= data_rate[pattrib->data_rate] << 4;
-		} else if (pattrib->data_rate >= 64 && pattrib->data_rate < 74) {
+		} else if (pattrib->data_rate >= DESC_RATEVHTSS3MCS0 && pattrib->data_rate <= DESC_RATEVHTSS3MCS9) {
 			hdr_buf[rt_len + 2] |= 3;
 			hdr_buf[rt_len + 2] |= data_rate[pattrib->data_rate] << 4;
-		} else if (pattrib->data_rate >= 74 && pattrib->data_rate < 84) {
+		} else if (pattrib->data_rate >= DESC_RATEVHTSS4MCS0 && pattrib->data_rate <= DESC_RATEVHTSS4MCS9) {
 			hdr_buf[rt_len + 3] |= 4;
 			hdr_buf[rt_len + 3] |= data_rate[pattrib->data_rate] << 4;
 		}
@@ -3853,6 +4238,7 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 	ptr = skb_push(pskb, rt_len);
 	if (ptr) {
 		rtap_hdr->it_len = cpu_to_le16(rt_len);
+		rtap_hdr->it_present = cpu_to_le32(rtap_hdr->it_present);
 		memcpy(ptr, rtap_hdr, rt_len);
 	} else
 		ret = _FAIL;
@@ -3864,24 +4250,37 @@ static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe,
 int recv_frame_monitor(_adapter *padapter, union recv_frame *rframe)
 {
 	int ret = _SUCCESS;
-	struct rx_pkt_attrib *pattrib = &rframe->u.hdr.attrib;
-	struct recv_priv *precvpriv = &padapter->recvpriv;
 	_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
 	_pkt *pskb = NULL;
 
+#ifdef CONFIG_AIRKISS
+	u8 broadcast_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+#endif
+
 	/* read skb information from recv frame */
 	pskb = rframe->u.hdr.pkt;
 	pskb->len = rframe->u.hdr.len;
 	pskb->data = rframe->u.hdr.rx_data;
 	skb_set_tail_pointer(pskb, rframe->u.hdr.len);
 
+#ifdef CONFIG_AIRKISS
+	/* for simpleconfig, only report broadcast data frame*/
+	if ((_rtw_memcmp(get_da(rframe->u.hdr.rx_data), broadcast_addr, ETH_ALEN) == _FALSE) ||
+		GetFrameType(rframe->u.hdr.rx_data) != WIFI_DATA_TYPE) {
+		ret = _FAIL;
+		rtw_free_recvframe(rframe, pfree_recv_queue); /* free this recv_frame */
+		goto exit;
+	}
+#endif
+
+#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
 	/* fill radiotap header */
 	if (fill_radiotap_hdr(padapter, rframe, (u8 *)pskb) == _FAIL) {
 		ret = _FAIL;
 		rtw_free_recvframe(rframe, pfree_recv_queue); /* free this recv_frame */
 		goto exit;
 	}
-
+#endif
 	/* write skb information to recv frame */
 	skb_reset_mac_header(pskb);
 	rframe->u.hdr.len = pskb->len;
@@ -3911,8 +4310,9 @@ exit:
 int recv_func_prehandle(_adapter *padapter, union recv_frame *rframe)
 {
 	int ret = _SUCCESS;
+#ifdef DBG_RX_COUNTER_DUMP
 	struct rx_pkt_attrib *pattrib = &rframe->u.hdr.attrib;
-	struct recv_priv *precvpriv = &padapter->recvpriv;
+#endif
 	_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
 
 #ifdef DBG_RX_COUNTER_DUMP
@@ -3957,9 +4357,6 @@ int recv_func_posthandle(_adapter *padapter, union recv_frame *prframe)
 
 	DBG_COUNTER(padapter->rx_logs.core_rx_post);
 
-	/* DATA FRAME */
-	rtw_led_control(padapter, LED_CTL_RX);
-
 	prframe = decryptor(padapter, prframe);
 	if (prframe == NULL) {
 		#ifdef DBG_RX_DROP_FRAME
@@ -3977,7 +4374,7 @@ int recv_func_posthandle(_adapter *padapter, union recv_frame *prframe)
 #endif
 
 #if 0
-	if (padapter->adapter_type == PRIMARY_ADAPTER) {
+	if (is_primary_adapter(padapter)) {
 		RTW_INFO("+++\n");
 		{
 			int i;
@@ -4062,7 +4459,10 @@ int recv_func(_adapter *padapter, union recv_frame *rframe)
 	struct recv_priv *recvpriv = &padapter->recvpriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-
+#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
+	u8 type;
+	u8 *ptr = rframe->u.hdr.rx_data;
+#endif
 	if (check_fwstate(mlmepriv, WIFI_MONITOR_STATE)) {
 		/* monitor mode */
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
@@ -4071,7 +4471,18 @@ int recv_func(_adapter *padapter, union recv_frame *rframe)
 		ret = _SUCCESS;
 		goto exit;
 	} else
-
+		{}
+#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
+	type = GetFrameType(ptr);
+	if ((type == WIFI_DATA_TYPE)&& check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
+		struct wlan_network *cur_network = &(mlmepriv->cur_network);
+		if ( _rtw_memcmp(get_addr2_ptr(ptr), cur_network->network.MacAddress, ETH_ALEN)==0) {
+			recv_frame_monitor(padapter, rframe);
+			ret = _SUCCESS;
+			goto exit;
+		}
+	}
+#endif
 		/* check if need to handle uc_swdec_pending_queue*/
 		if (check_fwstate(mlmepriv, WIFI_STATION_STATE) && psecuritypriv->busetkipkey) {
 			union recv_frame *pending_frame;
@@ -4258,10 +4669,11 @@ set_timer:
 
 static void rx_process_rssi(_adapter *padapter, union recv_frame *prframe)
 {
-	u32	last_rssi, tmp_val;
 	struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	struct signal_stat *signal_stat = &padapter->recvpriv.signal_strength_data;
+#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+	u32 last_rssi, tmp_val;
 #endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
 	/* RTW_INFO("process_rssi=> pattrib->rssil(%d) signal_strength(%d)\n ",pattrib->recv_signal_power,pattrib->signal_strength); */
@@ -4308,10 +4720,11 @@ static void rx_process_rssi(_adapter *padapter, union recv_frame *prframe)
 
 static void rx_process_link_qual(_adapter *padapter, union recv_frame *prframe)
 {
-	u32	last_evm = 0, tmpVal;
 	struct rx_pkt_attrib *pattrib;
 #ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
 	struct signal_stat *signal_stat;
+#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
+	u32 last_evm = 0, tmpVal;
 #endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
 
 	if (prframe == NULL || padapter == NULL)
@@ -4437,7 +4850,8 @@ void rx_query_phy_status(
 
 	pkt_info.is_packet_match_bssid = (!IsFrameTypeCtrl(wlanhdr))
 		&& (!pattrib->icv_err) && (!pattrib->crc_err)
-		&& _rtw_memcmp(get_hdr_bssid(wlanhdr), get_bssid(&padapter->mlmepriv), ETH_ALEN);
+		&& ((!MLME_IS_MESH(padapter) && _rtw_memcmp(get_hdr_bssid(wlanhdr), get_bssid(&padapter->mlmepriv), ETH_ALEN))
+			|| (MLME_IS_MESH(padapter) && psta));
 
 	pkt_info.is_to_self = (!pattrib->icv_err) && (!pattrib->crc_err)
 		&& _rtw_memcmp(ra, adapter_mac_addr(padapter), ETH_ALEN);
@@ -4458,20 +4872,40 @@ void rx_query_phy_status(
 
 	odm_phy_status_query(&pHalData->odmpriv, p_phy_info, pphy_status, &pkt_info);
 
+	/* If bw is initial value, get from phy status */
+	if (pattrib->bw == CHANNEL_WIDTH_MAX)
+		pattrib->bw = p_phy_info->band_width;
+
 	{
 		precvframe->u.hdr.psta = NULL;
-		if ((!MLME_IS_MESH(padapter) && pkt_info.is_packet_match_bssid)
-			|| padapter->registrypriv.mp_mode == 1
-		) {
-			if (psta) {
-				precvframe->u.hdr.psta = psta;
+		if (padapter->registrypriv.mp_mode != 1) {
+			if ((!MLME_IS_MESH(padapter) && pkt_info.is_packet_match_bssid)
+				|| (MLME_IS_MESH(padapter) && psta)) {
+				if (psta) {
+					precvframe->u.hdr.psta = psta;
+					rx_process_phy_info(padapter, precvframe);
+				}
+			} else if (pkt_info.is_packet_to_self || pkt_info.is_packet_beacon) {
+				if (psta)
+					precvframe->u.hdr.psta = psta;
 				rx_process_phy_info(padapter, precvframe);
 			}
-		} else if (pkt_info.is_packet_to_self || pkt_info.is_packet_beacon) {
-
-			if (psta)
-				precvframe->u.hdr.psta = psta;
-			rx_process_phy_info(padapter, precvframe);
+		} else {
+#ifdef CONFIG_MP_INCLUDED
+			if (padapter->mppriv.brx_filter_beacon == _TRUE) {
+				if (pkt_info.is_packet_beacon) {
+					RTW_INFO("in MP Rx is_packet_beacon\n");
+					if (psta)
+						precvframe->u.hdr.psta = psta;
+					rx_process_phy_info(padapter, precvframe);
+				}
+			} else 
+#endif
+			{
+					if (psta)
+						precvframe->u.hdr.psta = psta;
+					rx_process_phy_info(padapter, precvframe);
+			}
 		}
 	}
 
@@ -4522,9 +4956,9 @@ s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status)
 	u8 *pbuf = precvframe->u.hdr.rx_data;
 	u8 *pda = get_ra(pbuf);
 	u8 ra_is_bmc = IS_MCAST(pda);
+	_adapter *primary_padapter = precvframe->u.hdr.adapter;
 #ifdef CONFIG_CONCURRENT_MODE
 	_adapter *iface = NULL;
-	_adapter *primary_padapter = precvframe->u.hdr.adapter;
 
 	#ifdef CONFIG_MP_INCLUDED
 	if (rtw_mp_mode_check(primary_padapter))
@@ -4534,6 +4968,10 @@ s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status)
 	if (ra_is_bmc == _FALSE) { /*unicast packets*/
 		iface = rtw_get_iface_by_macddr(primary_padapter , pda);
 		if (NULL == iface) {
+		#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+			if (_rtw_memcmp(pda, adapter_pno_mac_addr(primary_padapter),
+					ETH_ALEN) != _TRUE)
+		#endif
 			RTW_INFO("%s [WARN] Cannot find appropriate adapter - mac_addr : "MAC_FMT"\n", __func__, MAC_ARG(pda));
 			/*rtw_warn_on(1);*/
 		} else
@@ -4542,13 +4980,14 @@ s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status)
 		rtw_mi_buddy_clone_bcmc_packet(primary_padapter, precvframe, pphy_status);
 bypass_concurrent_hdl:
 #endif /* CONFIG_CONCURRENT_MODE */
-
-	/* skip unnecessary bmc data frame for primary adapter */
-	if (ra_is_bmc == _TRUE && GetFrameType(pbuf) == WIFI_DATA_TYPE
-		&& !adapter_allow_bmc_data_rx(precvframe->u.hdr.adapter)
-	) {
-		rtw_free_recvframe(precvframe, &precvframe->u.hdr.adapter->recvpriv.free_recv_queue);
-		goto exit;
+	if (primary_padapter->registrypriv.mp_mode != 1) {
+		/* skip unnecessary bmc data frame for primary adapter */
+		if (ra_is_bmc == _TRUE && GetFrameType(pbuf) == WIFI_DATA_TYPE
+			&& !adapter_allow_bmc_data_rx(precvframe->u.hdr.adapter)
+		) {
+			rtw_free_recvframe(precvframe, &precvframe->u.hdr.adapter->recvpriv.free_recv_queue);
+			goto exit;
+		}
 	}
 
 	if (pphy_status)
@@ -4565,11 +5004,13 @@ thread_return rtw_recv_thread(thread_context context)
 	_adapter *adapter = (_adapter *)context;
 	struct recv_priv *recvpriv = &adapter->recvpriv;
 	s32 err = _SUCCESS;
+#ifdef RTW_RECV_THREAD_HIGH_PRIORITY
 #ifdef PLATFORM_LINUX
 	struct sched_param param = { .sched_priority = 1 };
 
 	sched_setscheduler(current, SCHED_FIFO, &param);
 #endif /* PLATFORM_LINUX */
+#endif /*RTW_RECV_THREAD_HIGH_PRIORITY*/
 	thread_enter("RTW_RECV_THREAD");
 
 	RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(adapter));
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rf.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rf.c
index 982a01ccb38b..b3eeb5870c5a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rf.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -204,7 +205,6 @@ struct center_chs_ent_t center_chs_5g_by_bw[] = {
  */
 u8 rtw_get_scch_by_cch_offset(u8 cch, u8 bw, u8 offset)
 {
-	int i;
 	u8 t_cch = 0;
 
 	if (bw == CHANNEL_WIDTH_20) {
@@ -470,7 +470,6 @@ bool rtw_chbw_to_freq_range(u8 ch, u8 bw, u8 offset, u32 *hi, u32 *lo)
 	u8 c_ch;
 	u32 freq;
 	u32 hi_ret = 0, lo_ret = 0;
-	int i;
 	bool valid = _FALSE;
 
 	if (hi)
@@ -509,22 +508,24 @@ exit:
 	return valid;
 }
 
-const char *const _ch_width_str[] = {
+const char *const _ch_width_str[CHANNEL_WIDTH_MAX] = {
 	"20MHz",
 	"40MHz",
 	"80MHz",
 	"160MHz",
 	"80_80MHz",
-	"CHANNEL_WIDTH_MAX",
+	"5MHz",
+	"10MHz",
 };
 
-const u8 _ch_width_to_bw_cap[] = {
+const u8 _ch_width_to_bw_cap[CHANNEL_WIDTH_MAX] = {
 	BW_CAP_20M,
 	BW_CAP_40M,
 	BW_CAP_80M,
 	BW_CAP_160M,
 	BW_CAP_80_80M,
-	0,
+	BW_CAP_5M,
+	BW_CAP_10M,
 };
 
 const char *const _band_str[] = {
@@ -565,461 +566,6 @@ const u8 _rf_type_to_rf_rx_cnt[] = {
 	1, /*RF_TYPE_MAX*/
 };
 
-#ifdef CONFIG_80211AC_VHT
-#define COUNTRY_CHPLAN_ASSIGN_EN_11AC(_val) , .en_11ac = (_val)
-#else
-#define COUNTRY_CHPLAN_ASSIGN_EN_11AC(_val)
-#endif
-
-#if RTW_DEF_MODULE_REGULATORY_CERT
-#define COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_val) , .def_module_flags = (_val)
-#else
-#define COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_val)
-#endif
-
-/* has def_module_flags specified, used by common map and HAL dfference map */
-#define COUNTRY_CHPLAN_ENT(_alpha2, _chplan, _en_11ac, _def_module_flags) \
-	{.alpha2 = (_alpha2), .chplan = (_chplan) \
-		COUNTRY_CHPLAN_ASSIGN_EN_11AC(_en_11ac) \
-		COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_def_module_flags) \
-	}
-
-#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
-
-#include "../platform/custom_country_chplan.h"
-
-#elif RTW_DEF_MODULE_REGULATORY_CERT
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AE_HMC_M2) /* 2013 certify */
-static const struct country_chplan RTL8821AE_HMC_M2_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("CL", 0x30, 1, 0x3F1), /* Chile */
-	COUNTRY_CHPLAN_ENT("CN", 0x51, 1, 0x3FB), /* China */
-	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0x3F1), /* Mexico */
-	COUNTRY_CHPLAN_ENT("MY", 0x47, 1, 0x3F1), /* Malaysia */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0x3FB), /* Ukraine */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AU) /* 2014 certify */
-static const struct country_chplan RTL8821AU_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0x3FB), /* Russia(fac/gost), Kaliningrad */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0x3FB), /* Ukraine */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AENF_NGFF) /* 2014 certify */
-static const struct country_chplan RTL8812AENF_NGFF_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AEBT_HMC) /* 2013 certify */
-static const struct country_chplan RTL8812AEBT_HMC_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0x3FB), /* Russia(fac/gost), Kaliningrad */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0x3FB), /* Ukraine */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8188EE_HMC_M2) /* 2012 certify */
-static const struct country_chplan RTL8188EE_HMC_M2_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0x3F1), /* Mexico */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BE_HMC_M2) /* 2013 certify */
-static const struct country_chplan RTL8723BE_HMC_M2_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0x3F1), /* Mexico */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BS_NGFF1216) /* 2014 certify */
-static const struct country_chplan RTL8723BS_NGFF1216_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0x3F1), /* Mexico */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8192EEBT_HMC_M2) /* 2013 certify */
-static const struct country_chplan RTL8192EEBT_HMC_M2_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0x3F1), /* Mexico */
-	COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0x3FF), /* United States of America (USA) */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723DE_NGFF1630) /* 2016 certify */
-static const struct country_chplan RTL8723DE_NGFF1630_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CA", 0x2A, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0x3F1), /* Mexico */
-};
-#endif
-
-#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8822BE) /* 2016 certify */
-static const struct country_chplan RTL8822BE_country_chplan_exc_map[] = {
-	COUNTRY_CHPLAN_ENT("CL", 0x30, 1, 0x3F1), /* Chile */
-};
-#endif
-
-/**
- * rtw_def_module_get_chplan_from_country -
- * @country_code: string of country code
- * @return:
- * Return NULL for case referring to common map
- */
-static const struct country_chplan *rtw_def_module_get_chplan_from_country(const char *country_code)
-{
-	const struct country_chplan *ent = NULL;
-	const struct country_chplan *hal_map = NULL;
-	u16 hal_map_sz = 0;
-	int i;
-
-	/* TODO: runtime selection for multi driver */
-#if (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AE_HMC_M2)
-	hal_map = RTL8821AE_HMC_M2_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8821AE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AU)
-	hal_map = RTL8821AU_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8821AU_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AENF_NGFF)
-	hal_map = RTL8812AENF_NGFF_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8812AENF_NGFF_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AEBT_HMC)
-	hal_map = RTL8812AEBT_HMC_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8812AEBT_HMC_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8188EE_HMC_M2)
-	hal_map = RTL8188EE_HMC_M2_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8188EE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BE_HMC_M2)
-	hal_map = RTL8723BE_HMC_M2_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8723BE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BS_NGFF1216)
-	hal_map = RTL8723BS_NGFF1216_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8723BS_NGFF1216_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8192EEBT_HMC_M2)
-	hal_map = RTL8192EEBT_HMC_M2_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8192EEBT_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723DE_NGFF1630)
-	hal_map = RTL8723DE_NGFF1630_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8723DE_NGFF1630_country_chplan_exc_map) / sizeof(struct country_chplan);
-#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8822BE)
-	hal_map = RTL8822BE_country_chplan_exc_map;
-	hal_map_sz = sizeof(RTL8822BE_country_chplan_exc_map) / sizeof(struct country_chplan);
-#endif
-
-	if (hal_map == NULL || hal_map_sz == 0)
-		goto exit;
-
-	for (i = 0; i < hal_map_sz; i++) {
-		if (strncmp(country_code, hal_map[i].alpha2, 2) == 0) {
-			ent = &hal_map[i];
-			break;
-		}
-	}
-
-exit:
-	return ent;
-}
-#endif /* CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP or RTW_DEF_MODULE_REGULATORY_CERT */
-
-static const struct country_chplan country_chplan_map[] = {
-	COUNTRY_CHPLAN_ENT("AD", 0x26, 1, 0x000), /* Andorra */
-	COUNTRY_CHPLAN_ENT("AE", 0x26, 1, 0x3FB), /* United Arab Emirates */
-	COUNTRY_CHPLAN_ENT("AF", 0x42, 1, 0x000), /* Afghanistan */
-	COUNTRY_CHPLAN_ENT("AG", 0x26, 1, 0x000), /* Antigua & Barbuda */
-	COUNTRY_CHPLAN_ENT("AI", 0x26, 1, 0x000), /* Anguilla(UK) */
-	COUNTRY_CHPLAN_ENT("AL", 0x26, 1, 0x3F1), /* Albania */
-	COUNTRY_CHPLAN_ENT("AM", 0x26, 1, 0x2B0), /* Armenia */
-	COUNTRY_CHPLAN_ENT("AN", 0x26, 1, 0x3F1), /* Netherlands Antilles */
-	COUNTRY_CHPLAN_ENT("AO", 0x47, 1, 0x2E0), /* Angola */
-	COUNTRY_CHPLAN_ENT("AQ", 0x26, 1, 0x000), /* Antarctica */
-	COUNTRY_CHPLAN_ENT("AR", 0x57, 1, 0x3F3), /* Argentina */
-	COUNTRY_CHPLAN_ENT("AS", 0x34, 1, 0x000), /* American Samoa */
-	COUNTRY_CHPLAN_ENT("AT", 0x26, 1, 0x3FB), /* Austria */
-	COUNTRY_CHPLAN_ENT("AU", 0x45, 1, 0x3FB), /* Australia */
-	COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0x0B0), /* Aruba */
-	COUNTRY_CHPLAN_ENT("AZ", 0x26, 1, 0x3F1), /* Azerbaijan */
-	COUNTRY_CHPLAN_ENT("BA", 0x26, 1, 0x3F1), /* Bosnia & Herzegovina */
-	COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0x250), /* Barbados */
-	COUNTRY_CHPLAN_ENT("BD", 0x26, 1, 0x3F1), /* Bangladesh */
-	COUNTRY_CHPLAN_ENT("BE", 0x26, 1, 0x3FB), /* Belgium */
-	COUNTRY_CHPLAN_ENT("BF", 0x26, 1, 0x2B0), /* Burkina Faso */
-	COUNTRY_CHPLAN_ENT("BG", 0x26, 1, 0x3F1), /* Bulgaria */
-	COUNTRY_CHPLAN_ENT("BH", 0x47, 1, 0x3F1), /* Bahrain */
-	COUNTRY_CHPLAN_ENT("BI", 0x26, 1, 0x2B0), /* Burundi */
-	COUNTRY_CHPLAN_ENT("BJ", 0x26, 1, 0x2B0), /* Benin */
-	COUNTRY_CHPLAN_ENT("BN", 0x47, 1, 0x210), /* Brunei */
-	COUNTRY_CHPLAN_ENT("BO", 0x73, 1, 0x3F1), /* Bolivia */
-	COUNTRY_CHPLAN_ENT("BR", 0x34, 1, 0x3F1), /* Brazil */
-	COUNTRY_CHPLAN_ENT("BS", 0x34, 1, 0x220), /* Bahamas */
-	COUNTRY_CHPLAN_ENT("BW", 0x26, 1, 0x2F1), /* Botswana */
-	COUNTRY_CHPLAN_ENT("BY", 0x26, 1, 0x3F1), /* Belarus */
-	COUNTRY_CHPLAN_ENT("BZ", 0x34, 1, 0x000), /* Belize */
-	COUNTRY_CHPLAN_ENT("CA", 0x2B, 1, 0x3FB), /* Canada */
-	COUNTRY_CHPLAN_ENT("CC", 0x26, 1, 0x000), /* Cocos (Keeling) Islands (Australia) */
-	COUNTRY_CHPLAN_ENT("CD", 0x26, 1, 0x2B0), /* Congo, Republic of the */
-	COUNTRY_CHPLAN_ENT("CF", 0x26, 1, 0x2B0), /* Central African Republic */
-	COUNTRY_CHPLAN_ENT("CG", 0x26, 1, 0x2B0), /* Congo, Democratic Republic of the. Zaire */
-	COUNTRY_CHPLAN_ENT("CH", 0x26, 1, 0x3FB), /* Switzerland */
-	COUNTRY_CHPLAN_ENT("CI", 0x26, 1, 0x3F1), /* Cote d'Ivoire */
-	COUNTRY_CHPLAN_ENT("CK", 0x26, 1, 0x000), /* Cook Islands */
-	COUNTRY_CHPLAN_ENT("CL", 0x73, 1, 0x3F1), /* Chile */
-	COUNTRY_CHPLAN_ENT("CM", 0x26, 1, 0x2B0), /* Cameroon */
-	COUNTRY_CHPLAN_ENT("CN", 0x48, 1, 0x3FB), /* China */
-	COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0x3F1), /* Colombia */
-	COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0x3F1), /* Costa Rica */
-	COUNTRY_CHPLAN_ENT("CV", 0x26, 1, 0x2B0), /* Cape Verde */
-	COUNTRY_CHPLAN_ENT("CX", 0x45, 1, 0x000), /* Christmas Island (Australia) */
-	COUNTRY_CHPLAN_ENT("CY", 0x26, 1, 0x3FB), /* Cyprus */
-	COUNTRY_CHPLAN_ENT("CZ", 0x26, 1, 0x3FB), /* Czech Republic */
-	COUNTRY_CHPLAN_ENT("DE", 0x26, 1, 0x3FB), /* Germany */
-	COUNTRY_CHPLAN_ENT("DJ", 0x26, 1, 0x280), /* Djibouti */
-	COUNTRY_CHPLAN_ENT("DK", 0x26, 1, 0x3FB), /* Denmark */
-	COUNTRY_CHPLAN_ENT("DM", 0x34, 1, 0x000), /* Dominica */
-	COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0x3F1), /* Dominican Republic */
-	COUNTRY_CHPLAN_ENT("DZ", 0x26, 1, 0x3F1), /* Algeria */
-	COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0x3F1), /* Ecuador */
-	COUNTRY_CHPLAN_ENT("EE", 0x26, 1, 0x3FB), /* Estonia */
-	COUNTRY_CHPLAN_ENT("EG", 0x47, 0, 0x3F1), /* Egypt */
-	COUNTRY_CHPLAN_ENT("EH", 0x47, 1, 0x280), /* Western Sahara */
-	COUNTRY_CHPLAN_ENT("ER", 0x26, 1, 0x000), /* Eritrea */
-	COUNTRY_CHPLAN_ENT("ES", 0x26, 1, 0x3FB), /* Spain, Canary Islands, Ceuta, Melilla */
-	COUNTRY_CHPLAN_ENT("ET", 0x26, 1, 0x0B0), /* Ethiopia */
-	COUNTRY_CHPLAN_ENT("FI", 0x26, 1, 0x3FB), /* Finland */
-	COUNTRY_CHPLAN_ENT("FJ", 0x34, 1, 0x200), /* Fiji */
-	COUNTRY_CHPLAN_ENT("FK", 0x26, 1, 0x000), /* Falkland Islands (Islas Malvinas) (UK) */
-	COUNTRY_CHPLAN_ENT("FM", 0x34, 1, 0x000), /* Micronesia, Federated States of (USA) */
-	COUNTRY_CHPLAN_ENT("FO", 0x26, 1, 0x000), /* Faroe Islands (Denmark) */
-	COUNTRY_CHPLAN_ENT("FR", 0x26, 1, 0x3FB), /* France */
-	COUNTRY_CHPLAN_ENT("GA", 0x26, 1, 0x2B0), /* Gabon */
-	COUNTRY_CHPLAN_ENT("GB", 0x26, 1, 0x3FB), /* Great Britain (United Kingdom; England) */
-	COUNTRY_CHPLAN_ENT("GD", 0x34, 1, 0x0B0), /* Grenada */
-	COUNTRY_CHPLAN_ENT("GE", 0x26, 1, 0x200), /* Georgia */
-	COUNTRY_CHPLAN_ENT("GF", 0x26, 1, 0x080), /* French Guiana */
-	COUNTRY_CHPLAN_ENT("GG", 0x26, 1, 0x000), /* Guernsey (UK) */
-	COUNTRY_CHPLAN_ENT("GH", 0x26, 1, 0x3F1), /* Ghana */
-	COUNTRY_CHPLAN_ENT("GI", 0x26, 1, 0x200), /* Gibraltar (UK) */
-	COUNTRY_CHPLAN_ENT("GL", 0x26, 1, 0x200), /* Greenland (Denmark) */
-	COUNTRY_CHPLAN_ENT("GM", 0x26, 1, 0x2B0), /* Gambia */
-	COUNTRY_CHPLAN_ENT("GN", 0x26, 1, 0x210), /* Guinea */
-	COUNTRY_CHPLAN_ENT("GP", 0x26, 1, 0x200), /* Guadeloupe (France) */
-	COUNTRY_CHPLAN_ENT("GQ", 0x26, 1, 0x2B0), /* Equatorial Guinea */
-	COUNTRY_CHPLAN_ENT("GR", 0x26, 1, 0x3FB), /* Greece */
-	COUNTRY_CHPLAN_ENT("GS", 0x26, 1, 0x000), /* South Georgia and the Sandwich Islands (UK) */
-	COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0x3F1), /* Guatemala */
-	COUNTRY_CHPLAN_ENT("GU", 0x34, 1, 0x200), /* Guam (USA) */
-	COUNTRY_CHPLAN_ENT("GW", 0x26, 1, 0x2B0), /* Guinea-Bissau */
-	COUNTRY_CHPLAN_ENT("GY", 0x44, 1, 0x000), /* Guyana */
-	COUNTRY_CHPLAN_ENT("HK", 0x26, 1, 0x3FB), /* Hong Kong */
-	COUNTRY_CHPLAN_ENT("HM", 0x45, 1, 0x000), /* Heard and McDonald Islands (Australia) */
-	COUNTRY_CHPLAN_ENT("HN", 0x32, 1, 0x3F1), /* Honduras */
-	COUNTRY_CHPLAN_ENT("HR", 0x26, 1, 0x3F9), /* Croatia */
-	COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0x250), /* Haiti */
-	COUNTRY_CHPLAN_ENT("HU", 0x26, 1, 0x3FB), /* Hungary */
-	COUNTRY_CHPLAN_ENT("ID", 0x54, 0, 0x3F3), /* Indonesia */
-	COUNTRY_CHPLAN_ENT("IE", 0x26, 1, 0x3FB), /* Ireland */
-	COUNTRY_CHPLAN_ENT("IL", 0x47, 1, 0x3F1), /* Israel */
-	COUNTRY_CHPLAN_ENT("IM", 0x26, 1, 0x000), /* Isle of Man (UK) */
-	COUNTRY_CHPLAN_ENT("IN", 0x48, 1, 0x3F1), /* India */
-	COUNTRY_CHPLAN_ENT("IQ", 0x26, 1, 0x000), /* Iraq */
-	COUNTRY_CHPLAN_ENT("IR", 0x26, 0, 0x000), /* Iran */
-	COUNTRY_CHPLAN_ENT("IS", 0x26, 1, 0x3FB), /* Iceland */
-	COUNTRY_CHPLAN_ENT("IT", 0x26, 1, 0x3FB), /* Italy */
-	COUNTRY_CHPLAN_ENT("JE", 0x26, 1, 0x000), /* Jersey (UK) */
-	COUNTRY_CHPLAN_ENT("JM", 0x51, 1, 0x3F1), /* Jamaica */
-	COUNTRY_CHPLAN_ENT("JO", 0x49, 1, 0x3FB), /* Jordan */
-	COUNTRY_CHPLAN_ENT("JP", 0x27, 1, 0x3FF), /* Japan- Telec */
-	COUNTRY_CHPLAN_ENT("KE", 0x47, 1, 0x3F9), /* Kenya */
-	COUNTRY_CHPLAN_ENT("KG", 0x26, 1, 0x3F1), /* Kyrgyzstan */
-	COUNTRY_CHPLAN_ENT("KH", 0x26, 1, 0x3F1), /* Cambodia */
-	COUNTRY_CHPLAN_ENT("KI", 0x26, 1, 0x000), /* Kiribati */
-	COUNTRY_CHPLAN_ENT("KN", 0x34, 1, 0x000), /* Saint Kitts and Nevis */
-	COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0x3FB), /* South Korea */
-	COUNTRY_CHPLAN_ENT("KW", 0x47, 1, 0x3FB), /* Kuwait */
-	COUNTRY_CHPLAN_ENT("KY", 0x34, 1, 0x000), /* Cayman Islands (UK) */
-	COUNTRY_CHPLAN_ENT("KZ", 0x26, 1, 0x300), /* Kazakhstan */
-	COUNTRY_CHPLAN_ENT("LA", 0x26, 1, 0x000), /* Laos */
-	COUNTRY_CHPLAN_ENT("LB", 0x26, 1, 0x3F1), /* Lebanon */
-	COUNTRY_CHPLAN_ENT("LC", 0x34, 1, 0x000), /* Saint Lucia */
-	COUNTRY_CHPLAN_ENT("LI", 0x26, 1, 0x3FB), /* Liechtenstein */
-	COUNTRY_CHPLAN_ENT("LK", 0x26, 1, 0x3F1), /* Sri Lanka */
-	COUNTRY_CHPLAN_ENT("LR", 0x26, 1, 0x2B0), /* Liberia */
-	COUNTRY_CHPLAN_ENT("LS", 0x26, 1, 0x3F1), /* Lesotho */
-	COUNTRY_CHPLAN_ENT("LT", 0x26, 1, 0x3FB), /* Lithuania */
-	COUNTRY_CHPLAN_ENT("LU", 0x26, 1, 0x3FB), /* Luxembourg */
-	COUNTRY_CHPLAN_ENT("LV", 0x26, 1, 0x3FB), /* Latvia */
-	COUNTRY_CHPLAN_ENT("LY", 0x26, 1, 0x000), /* Libya */
-	COUNTRY_CHPLAN_ENT("MA", 0x47, 1, 0x3F1), /* Morocco */
-	COUNTRY_CHPLAN_ENT("MC", 0x26, 1, 0x3FB), /* Monaco */
-	COUNTRY_CHPLAN_ENT("MD", 0x26, 1, 0x3F1), /* Moldova */
-	COUNTRY_CHPLAN_ENT("ME", 0x26, 1, 0x3F1), /* Montenegro */
-	COUNTRY_CHPLAN_ENT("MF", 0x34, 1, 0x000), /* Saint Martin */
-	COUNTRY_CHPLAN_ENT("MG", 0x26, 1, 0x220), /* Madagascar */
-	COUNTRY_CHPLAN_ENT("MH", 0x34, 1, 0x000), /* Marshall Islands (USA) */
-	COUNTRY_CHPLAN_ENT("MK", 0x26, 1, 0x3F1), /* Republic of Macedonia (FYROM) */
-	COUNTRY_CHPLAN_ENT("ML", 0x26, 1, 0x2B0), /* Mali */
-	COUNTRY_CHPLAN_ENT("MM", 0x26, 1, 0x000), /* Burma (Myanmar) */
-	COUNTRY_CHPLAN_ENT("MN", 0x26, 1, 0x000), /* Mongolia */
-	COUNTRY_CHPLAN_ENT("MO", 0x26, 1, 0x200), /* Macau */
-	COUNTRY_CHPLAN_ENT("MP", 0x34, 1, 0x000), /* Northern Mariana Islands (USA) */
-	COUNTRY_CHPLAN_ENT("MQ", 0x26, 1, 0x240), /* Martinique (France) */
-	COUNTRY_CHPLAN_ENT("MR", 0x26, 1, 0x2A0), /* Mauritania */
-	COUNTRY_CHPLAN_ENT("MS", 0x26, 1, 0x000), /* Montserrat (UK) */
-	COUNTRY_CHPLAN_ENT("MT", 0x26, 1, 0x3FB), /* Malta */
-	COUNTRY_CHPLAN_ENT("MU", 0x26, 1, 0x2B0), /* Mauritius */
-	COUNTRY_CHPLAN_ENT("MV", 0x47, 1, 0x000), /* Maldives */
-	COUNTRY_CHPLAN_ENT("MW", 0x26, 1, 0x2B0), /* Malawi */
-	COUNTRY_CHPLAN_ENT("MX", 0x61, 1, 0x3F1), /* Mexico */
-	COUNTRY_CHPLAN_ENT("MY", 0x63, 1, 0x3F1), /* Malaysia */
-	COUNTRY_CHPLAN_ENT("MZ", 0x26, 1, 0x3F1), /* Mozambique */
-	COUNTRY_CHPLAN_ENT("NA", 0x26, 1, 0x300), /* Namibia */
-	COUNTRY_CHPLAN_ENT("NC", 0x26, 1, 0x000), /* New Caledonia */
-	COUNTRY_CHPLAN_ENT("NE", 0x26, 1, 0x2B0), /* Niger */
-	COUNTRY_CHPLAN_ENT("NF", 0x45, 1, 0x000), /* Norfolk Island (Australia) */
-	COUNTRY_CHPLAN_ENT("NG", 0x75, 1, 0x3F9), /* Nigeria */
-	COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0x3F1), /* Nicaragua */
-	COUNTRY_CHPLAN_ENT("NL", 0x26, 1, 0x3FB), /* Netherlands */
-	COUNTRY_CHPLAN_ENT("NO", 0x26, 1, 0x3FB), /* Norway */
-	COUNTRY_CHPLAN_ENT("NP", 0x47, 1, 0x2F0), /* Nepal */
-	COUNTRY_CHPLAN_ENT("NR", 0x26, 1, 0x000), /* Nauru */
-	COUNTRY_CHPLAN_ENT("NU", 0x45, 1, 0x000), /* Niue */
-	COUNTRY_CHPLAN_ENT("NZ", 0x45, 1, 0x3FB), /* New Zealand */
-	COUNTRY_CHPLAN_ENT("OM", 0x26, 1, 0x3F9), /* Oman */
-	COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0x3F1), /* Panama */
-	COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0x3F1), /* Peru */
-	COUNTRY_CHPLAN_ENT("PF", 0x26, 1, 0x000), /* French Polynesia (France) */
-	COUNTRY_CHPLAN_ENT("PG", 0x26, 1, 0x3F1), /* Papua New Guinea */
-	COUNTRY_CHPLAN_ENT("PH", 0x26, 1, 0x3F1), /* Philippines */
-	COUNTRY_CHPLAN_ENT("PK", 0x51, 1, 0x3F1), /* Pakistan */
-	COUNTRY_CHPLAN_ENT("PL", 0x26, 1, 0x3FB), /* Poland */
-	COUNTRY_CHPLAN_ENT("PM", 0x26, 1, 0x000), /* Saint Pierre and Miquelon (France) */
-	COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0x3F1), /* Puerto Rico */
-	COUNTRY_CHPLAN_ENT("PT", 0x26, 1, 0x3FB), /* Portugal */
-	COUNTRY_CHPLAN_ENT("PW", 0x34, 1, 0x000), /* Palau */
-	COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0x3F1), /* Paraguay */
-	COUNTRY_CHPLAN_ENT("QA", 0x51, 1, 0x3F9), /* Qatar */
-	COUNTRY_CHPLAN_ENT("RE", 0x26, 1, 0x000), /* Reunion (France) */
-	COUNTRY_CHPLAN_ENT("RO", 0x26, 1, 0x3F1), /* Romania */
-	COUNTRY_CHPLAN_ENT("RS", 0x26, 1, 0x3F1), /* Serbia, Kosovo */
-	COUNTRY_CHPLAN_ENT("RU", 0x59, 1, 0x3FB), /* Russia(fac/gost), Kaliningrad */
-	COUNTRY_CHPLAN_ENT("RW", 0x26, 1, 0x2B0), /* Rwanda */
-	COUNTRY_CHPLAN_ENT("SA", 0x26, 1, 0x3FB), /* Saudi Arabia */
-	COUNTRY_CHPLAN_ENT("SB", 0x26, 1, 0x000), /* Solomon Islands */
-	COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0x290), /* Seychelles */
-	COUNTRY_CHPLAN_ENT("SE", 0x26, 1, 0x3FB), /* Sweden */
-	COUNTRY_CHPLAN_ENT("SG", 0x26, 1, 0x3FB), /* Singapore */
-	COUNTRY_CHPLAN_ENT("SH", 0x26, 1, 0x000), /* Saint Helena (UK) */
-	COUNTRY_CHPLAN_ENT("SI", 0x26, 1, 0x3FB), /* Slovenia */
-	COUNTRY_CHPLAN_ENT("SJ", 0x26, 1, 0x000), /* Svalbard (Norway) */
-	COUNTRY_CHPLAN_ENT("SK", 0x26, 1, 0x3FB), /* Slovakia */
-	COUNTRY_CHPLAN_ENT("SL", 0x26, 1, 0x2B0), /* Sierra Leone */
-	COUNTRY_CHPLAN_ENT("SM", 0x26, 1, 0x000), /* San Marino */
-	COUNTRY_CHPLAN_ENT("SN", 0x26, 1, 0x3F1), /* Senegal */
-	COUNTRY_CHPLAN_ENT("SO", 0x26, 1, 0x000), /* Somalia */
-	COUNTRY_CHPLAN_ENT("SR", 0x74, 1, 0x000), /* Suriname */
-	COUNTRY_CHPLAN_ENT("ST", 0x34, 1, 0x280), /* Sao Tome and Principe */
-	COUNTRY_CHPLAN_ENT("SV", 0x30, 1, 0x3F1), /* El Salvador */
-	COUNTRY_CHPLAN_ENT("SX", 0x34, 1, 0x000), /* Sint Marteen */
-	COUNTRY_CHPLAN_ENT("SZ", 0x26, 1, 0x020), /* Swaziland */
-	COUNTRY_CHPLAN_ENT("TC", 0x26, 1, 0x000), /* Turks and Caicos Islands (UK) */
-	COUNTRY_CHPLAN_ENT("TD", 0x26, 1, 0x2B0), /* Chad */
-	COUNTRY_CHPLAN_ENT("TF", 0x26, 1, 0x280), /* French Southern and Antarctic Lands (FR Southern Territories) */
-	COUNTRY_CHPLAN_ENT("TG", 0x26, 1, 0x2B0), /* Togo */
-	COUNTRY_CHPLAN_ENT("TH", 0x26, 1, 0x3F1), /* Thailand */
-	COUNTRY_CHPLAN_ENT("TJ", 0x26, 1, 0x240), /* Tajikistan */
-	COUNTRY_CHPLAN_ENT("TK", 0x45, 1, 0x000), /* Tokelau */
-	COUNTRY_CHPLAN_ENT("TM", 0x26, 1, 0x000), /* Turkmenistan */
-	COUNTRY_CHPLAN_ENT("TN", 0x47, 1, 0x3F1), /* Tunisia */
-	COUNTRY_CHPLAN_ENT("TO", 0x26, 1, 0x000), /* Tonga */
-	COUNTRY_CHPLAN_ENT("TR", 0x26, 1, 0x3F1), /* Turkey, Northern Cyprus */
-	COUNTRY_CHPLAN_ENT("TT", 0x42, 1, 0x3F1), /* Trinidad & Tobago */
-	COUNTRY_CHPLAN_ENT("TW", 0x76, 1, 0x3FF), /* Taiwan */
-	COUNTRY_CHPLAN_ENT("TZ", 0x26, 1, 0x2F0), /* Tanzania */
-	COUNTRY_CHPLAN_ENT("UA", 0x36, 1, 0x3FB), /* Ukraine */
-	COUNTRY_CHPLAN_ENT("UG", 0x26, 1, 0x2F1), /* Uganda */
-	COUNTRY_CHPLAN_ENT("US", 0x76, 1, 0x3FF), /* United States of America (USA) */
-	COUNTRY_CHPLAN_ENT("UY", 0x30, 1, 0x3F1), /* Uruguay */
-	COUNTRY_CHPLAN_ENT("UZ", 0x47, 1, 0x2F0), /* Uzbekistan */
-	COUNTRY_CHPLAN_ENT("VA", 0x26, 1, 0x000), /* Holy See (Vatican City) */
-	COUNTRY_CHPLAN_ENT("VC", 0x34, 1, 0x010), /* Saint Vincent and the Grenadines */
-	COUNTRY_CHPLAN_ENT("VE", 0x30, 1, 0x3F1), /* Venezuela */
-	COUNTRY_CHPLAN_ENT("VI", 0x34, 1, 0x000), /* United States Virgin Islands (USA) */
-	COUNTRY_CHPLAN_ENT("VN", 0x26, 1, 0x3F1), /* Vietnam */
-	COUNTRY_CHPLAN_ENT("VU", 0x26, 1, 0x000), /* Vanuatu */
-	COUNTRY_CHPLAN_ENT("WF", 0x26, 1, 0x000), /* Wallis and Futuna (France) */
-	COUNTRY_CHPLAN_ENT("WS", 0x34, 1, 0x000), /* Samoa */
-	COUNTRY_CHPLAN_ENT("YE", 0x26, 1, 0x040), /* Yemen */
-	COUNTRY_CHPLAN_ENT("YT", 0x26, 1, 0x280), /* Mayotte (France) */
-	COUNTRY_CHPLAN_ENT("ZA", 0x26, 1, 0x3F1), /* South Africa */
-	COUNTRY_CHPLAN_ENT("ZM", 0x26, 1, 0x2B0), /* Zambia */
-	COUNTRY_CHPLAN_ENT("ZW", 0x26, 1, 0x3F1), /* Zimbabwe */
-};
-
-/*
-* rtw_get_chplan_from_country -
-* @country_code: string of country code
-*
-* Return pointer of struct country_chplan entry or NULL when unsupported country_code is given
-*/
-const struct country_chplan *rtw_get_chplan_from_country(const char *country_code)
-{
-	const struct country_chplan *ent = NULL;
-	const struct country_chplan *map = NULL;
-	u16 map_sz = 0;
-	char code[2];
-	int i;
-
-	code[0] = alpha_to_upper(country_code[0]);
-	code[1] = alpha_to_upper(country_code[1]);
-
-#if !defined(CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP) && RTW_DEF_MODULE_REGULATORY_CERT
-	ent = rtw_def_module_get_chplan_from_country(code);
-	if (ent != NULL)
-		goto exit;
-#endif
-
-#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
-	map = CUSTOMIZED_country_chplan_map;
-	map_sz = sizeof(CUSTOMIZED_country_chplan_map) / sizeof(struct country_chplan);
-#else
-	map = country_chplan_map;
-	map_sz = sizeof(country_chplan_map) / sizeof(struct country_chplan);
-#endif
-
-	for (i = 0; i < map_sz; i++) {
-		if (strncmp(code, map[i].alpha2, 2) == 0) {
-			ent = &map[i];
-			break;
-		}
-	}
-
-exit:
-	#if RTW_DEF_MODULE_REGULATORY_CERT
-	if (ent && !(COUNTRY_CHPLAN_DEF_MODULE_FALGS(ent) & RTW_DEF_MODULE_REGULATORY_CERT))
-		ent = NULL;
-	#endif
-
-	return ent;
-}
-
 const char *const _regd_str[] = {
 	"NONE",
 	"FCC",
@@ -1027,6 +573,8 @@ const char *const _regd_str[] = {
 	"ETSI",
 	"IC",
 	"KCC",
+	"ACMA",
+	"CHILE",
 	"WW",
 };
 
@@ -1147,7 +695,6 @@ struct regd_exc_ent *_rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *co
 		break;
 	}
 
-exit:
 	if (match)
 		return ent;
 	else
@@ -1327,13 +874,13 @@ void dump_txpwr_lmt(void *sel, _adapter *adapter)
 						ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
 						cur = get_next(cur);
 
-						sprintf(fmt, "%%%zus%%s ", strlen(ent->regd_name) < 4 ? 5 - strlen(ent->regd_name) : 1);
+						sprintf(fmt, "%%%zus%%s ", strlen(ent->regd_name) >= 6 ? 1 : 6 - strlen(ent->regd_name));
 						snprintf(tmp_str, TMP_STR_LEN, fmt
 							, strcmp(ent->regd_name, rfctl->regd_name) == 0 ? "*" : ""
 							, ent->regd_name);
 						_RTW_PRINT_SEL(sel, "%s", tmp_str);
 					}
-					sprintf(fmt, "%%%zus%%s ", strlen(regd_str(TXPWR_LMT_WW)) < 4 ? 5 - strlen(regd_str(TXPWR_LMT_WW)) : 1);
+					sprintf(fmt, "%%%zus%%s ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? 1 : 6 - strlen(regd_str(TXPWR_LMT_WW)));
 					snprintf(tmp_str, TMP_STR_LEN, fmt
 						, strcmp(rfctl->regd_name, regd_str(TXPWR_LMT_WW)) == 0 ? "*" : ""
 						, regd_str(TXPWR_LMT_WW));
@@ -1380,45 +927,41 @@ void dump_txpwr_lmt(void *sel, _adapter *adapter)
 							ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
 							cur = get_next(cur);
 							lmt = phy_get_txpwr_lmt_abs(adapter, ent->regd_name, band, bw, tlrs, ntx_idx, ch, 0);
-							if (lmt == MAX_POWER_INDEX) {
-								sprintf(fmt, "%%%zus ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) + 1 : 5);
+							if (lmt == hal_spec->txgi_max) {
+								sprintf(fmt, "%%%zus ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) + 1 : 6);
 								snprintf(tmp_str, TMP_STR_LEN, fmt, "NA");
 								_RTW_PRINT_SEL(sel, "%s", tmp_str);
-							} else {
-								if (lmt == -1) { /* -0.5 */
-									sprintf(fmt, "%%%zus ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) + 1 : 5);
-									snprintf(tmp_str, TMP_STR_LEN, fmt, "-0.5");
-									_RTW_PRINT_SEL(sel, "%s", tmp_str);
-								} else if (lmt % 2) { /* n.5 */
-									sprintf(fmt, "%%%zud.5 ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) - 1 : 3);
-									snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
-									_RTW_PRINT_SEL(sel, "%s", tmp_str);
-								} else { /* n */
-									sprintf(fmt, "%%%zud ", strlen(ent->regd_name) >= 5 ? strlen(ent->regd_name) + 1 : 5);
-									snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
-									_RTW_PRINT_SEL(sel, "%s", tmp_str);
-								}
+							} else if (lmt > -hal_spec->txgi_pdbm && lmt < 0) { /* -0.xx */
+								sprintf(fmt, "%%%zus-0.%%d ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) - 4 : 1);
+								snprintf(tmp_str, TMP_STR_LEN, fmt, "", (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+								_RTW_PRINT_SEL(sel, "%s", tmp_str);
+							} else if (lmt % hal_spec->txgi_pdbm) { /* d.xx */
+								sprintf(fmt, "%%%zud.%%d ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) - 2 : 3);
+								snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm, (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+								_RTW_PRINT_SEL(sel, "%s", tmp_str);
+							} else { /* d */
+								sprintf(fmt, "%%%zud ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) + 1 : 6);
+								snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm);
+								_RTW_PRINT_SEL(sel, "%s", tmp_str);
 							}
 						}
 						lmt = phy_get_txpwr_lmt_abs(adapter, regd_str(TXPWR_LMT_WW), band, bw, tlrs, ntx_idx, ch, 0);
-						if (lmt == MAX_POWER_INDEX) {
-							sprintf(fmt, "%%%zus ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 5);
+						if (lmt == hal_spec->txgi_max) {
+							sprintf(fmt, "%%%zus ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 6);
 							snprintf(tmp_str, TMP_STR_LEN, fmt, "NA");
 							_RTW_PRINT_SEL(sel, "%s", tmp_str);
-						} else {
-							if (lmt == -1) { /* -0.5 */
-								sprintf(fmt, "%%%zus ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 5);
-								snprintf(tmp_str, TMP_STR_LEN, fmt, "-0.5");
-								_RTW_PRINT_SEL(sel, "%s", tmp_str);
-							} else if (lmt % 2) { /* n.5 */
-								sprintf(fmt, "%%%zud.5 ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) - 1 : 3);
-								snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
-								_RTW_PRINT_SEL(sel, "%s", tmp_str);
-							} else { /* n */
-								sprintf(fmt, "%%%zud ", strlen(regd_str(TXPWR_LMT_WW)) >= 5 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 5);
-								snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / 2);
-								_RTW_PRINT_SEL(sel, "%s", tmp_str);
-							}
+						} else if (lmt > -hal_spec->txgi_pdbm && lmt < 0) { /* -0.xx */
+							sprintf(fmt, "%%%zus-0.%%d ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) - 4 : 1);
+							snprintf(tmp_str, TMP_STR_LEN, fmt, "", (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+							_RTW_PRINT_SEL(sel, "%s", tmp_str);
+						} else if (lmt % hal_spec->txgi_pdbm) { /* d.xx */
+							sprintf(fmt, "%%%zud.%%d ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) - 2 : 3);
+							snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm, (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+							_RTW_PRINT_SEL(sel, "%s", tmp_str);
+						} else { /* d */
+							sprintf(fmt, "%%%zud ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 6);
+							snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm);
+							_RTW_PRINT_SEL(sel, "%s", tmp_str);
 						}
 
 						/* dump limit offset of each path */
@@ -1436,8 +979,8 @@ void dump_txpwr_lmt(void *sel, _adapter *adapter)
 								ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
 								cur = get_next(cur);
 								lmt_offset = phy_get_txpwr_lmt(adapter, ent->regd_name, band, bw, path, rs, ntx_idx, ch, 0);
-								if (lmt_offset == MAX_POWER_INDEX) {
-									*(lmt_idx + i * RF_PATH_MAX + path) = MAX_POWER_INDEX;
+								if (lmt_offset == hal_spec->txgi_max) {
+									*(lmt_idx + i * RF_PATH_MAX + path) = hal_spec->txgi_max;
 									_RTW_PRINT_SEL(sel, "%3s ", "NA");
 								} else {
 									*(lmt_idx + i * RF_PATH_MAX + path) = lmt_offset + base;
@@ -1446,7 +989,7 @@ void dump_txpwr_lmt(void *sel, _adapter *adapter)
 								i++;
 							}
 							lmt_offset = phy_get_txpwr_lmt(adapter, regd_str(TXPWR_LMT_WW), band, bw, path, rs, ntx_idx, ch, 0);
-							if (lmt_offset == MAX_POWER_INDEX)
+							if (lmt_offset == hal_spec->txgi_max)
 								_RTW_PRINT_SEL(sel, "%3s ", "NA");
 							else
 								_RTW_PRINT_SEL(sel, "%3d ", lmt_offset);
@@ -1488,6 +1031,7 @@ release_lock:
 void rtw_txpwr_lmt_add_with_nlen(struct rf_ctl_t *rfctl, const char *regd_name, u32 nlen
 	, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt)
 {
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(dvobj_get_primary_adapter(rfctl_to_dvobj(rfctl)));
 	struct txpwr_lmt_ent *ent;
 	_irqL irqL;
 	_list *cur, *head;
@@ -1526,13 +1070,13 @@ void rtw_txpwr_lmt_add_with_nlen(struct rf_ctl_t *rfctl, const char *regd_name,
 			for (k = 0; k < TXPWR_LMT_RS_NUM_2G; ++k)
 				for (m = 0; m < CENTER_CH_2G_NUM; ++m)
 					for (l = 0; l < MAX_TX_COUNT; ++l)
-						ent->lmt_2g[j][k][m][l] = MAX_POWER_INDEX;
+						ent->lmt_2g[j][k][m][l] = hal_spec->txgi_max;
 		#ifdef CONFIG_IEEE80211_BAND_5GHZ
 		for (j = 0; j < MAX_5G_BANDWIDTH_NUM; ++j)
 			for (k = 0; k < TXPWR_LMT_RS_NUM_5G; ++k)
 				for (m = 0; m < CENTER_CH_5G_ALL_NUM; ++m)
 					for (l = 0; l < MAX_TX_COUNT; ++l)
-						ent->lmt_5g[j][k][m][l] = MAX_POWER_INDEX;
+						ent->lmt_5g[j][k][m][l] = hal_spec->txgi_max;
 		#endif
 	}
 
@@ -1549,7 +1093,7 @@ chk_lmt_val:
 	else
 		goto release_lock;
 
-	if (pre_lmt != MAX_POWER_INDEX)
+	if (pre_lmt != hal_spec->txgi_max)
 		RTW_PRINT("duplicate txpwr_lmt for [%s][%s][%s][%s][%uT][%d]\n"
 			, regd_name, band_str(band), ch_width_str(bw), txpwr_lmt_rs_str(tlrs), ntx_idx + 1
 			, band == BAND_ON_2_4G ? ch_idx + 1 : center_ch_5g_all[ch_idx]);
@@ -1670,7 +1214,6 @@ s8 rtw_rf_get_kfree_tx_gain_offset(_adapter *padapter, u8 path, u8 ch)
 	s8 kfree_offset = 0;
 
 #ifdef CONFIG_RF_POWER_TRIM
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 	struct kfree_data_t *kfree_data = GET_KFREE_DATA(padapter);
 	s8 bb_gain_sel = rtw_ch_to_bb_gain_sel(ch);
 
@@ -1696,7 +1239,9 @@ exit:
 
 void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset)
 {
+#if !defined(CONFIG_RTL8814A) && !defined(CONFIG_RTL8822B) && !defined(CONFIG_RTL8821C)
 	u8 write_value;
+#endif
 	u8 target_path = 0;
 	u32 val32 = 0;
 
@@ -1735,6 +1280,12 @@ void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset)
 		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
 		break;
 #endif /* CONFIG_RTL8188F */
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		write_value = RF_TX_GAIN_OFFSET_8188GTV(offset);
+		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
+		break;
+#endif /* CONFIG_RTL8188GTV */
 #ifdef CONFIG_RTL8192E
 	case RTL8192E:
 		write_value = RF_TX_GAIN_OFFSET_8192E(offset);
@@ -1748,10 +1299,11 @@ void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset)
 		rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0f8000, write_value);
 		break;
 #endif /* CONFIG_RTL8821A */
-#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8192F)
 	case RTL8814A:
 	case RTL8822B:
 	case RTL8821C:
+	case RTL8192F:
 		RTW_INFO("\nkfree by PhyDM on the sw CH. path %d\n", path);
 		break;
 #endif /* CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
@@ -1792,34 +1344,6 @@ void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch)
 	}
 }
 
-inline u8 rtw_is_5g_band1(u8 ch)
-{
-	if (ch >= 36 && ch <= 48)
-		return 1;
-	return 0;
-}
-
-inline u8 rtw_is_5g_band2(u8 ch)
-{
-	if (ch >= 52 && ch <= 64)
-		return 1;
-	return 0;
-}
-
-inline u8 rtw_is_5g_band3(u8 ch)
-{
-	if (ch >= 100 && ch <= 144)
-		return 1;
-	return 0;
-}
-
-inline u8 rtw_is_5g_band4(u8 ch)
-{
-	if (ch >= 149 && ch <= 177)
-		return 1;
-	return 0;
-}
-
 inline u8 rtw_is_dfs_range(u32 hi, u32 lo)
 {
 	return rtw_is_range_overlap(hi, lo, 5720 + 10, 5260 - 10);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm.c
index f29f45a295c3..0a8d0b981cae 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -266,6 +267,53 @@ static int is_wildcard_bssid(u8 *bssid)
 	return _FALSE;
 }
 
+/* for caller outside rm */
+u8 rm_add_nb_req(_adapter *padapter, struct sta_info *psta)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct rm_obj *prm;
+
+
+	prm = rm_alloc_rmobj(padapter);
+
+	if (prm == NULL) {
+		RTW_ERR("RM: unable to alloc rm obj for requeset\n");
+		return _FALSE;
+	}
+
+	prm->psta = psta;
+	prm->q.category = RTW_WLAN_CATEGORY_RADIO_MEAS;
+	prm->q.diag_token = pmlmeinfo->dialogToken++;
+	prm->q.m_token = 1;
+
+	prm->rmid = psta->cmn.aid << 16
+		| prm->q.diag_token << 8
+		| RM_MASTER;
+
+	prm->q.action_code = RM_ACT_NB_REP_REQ;
+
+	#if 0
+	if (pmac) { /* find sta_info according to bssid */
+		pmac += 4; /* skip mac= */
+		if (hwaddr_parse(pmac, bssid) == NULL) {
+			sprintf(pstr(s), "Err: \nincorrect mac format\n");
+			return _FAIL;
+		}
+		psta = rm_get_sta(padapter, 0xff, bssid);
+	}
+	#endif
+
+	/* enquee rmobj */
+	rm_enqueue_rmobj(padapter, prm, _FALSE);
+
+	RTW_INFO("RM: rmid=%x add req to " MAC_FMT "\n",
+		prm->rmid, MAC_ARG(psta->cmn.mac_addr));
+
+	return _SUCCESS;
+}
+
+
 static u8 *build_wlan_hdr(_adapter *padapter, struct xmit_frame *pmgntframe,
 	struct sta_info *psta, u16 frame_type)
 {
@@ -383,40 +431,17 @@ int issue_null_reply(struct rm_obj *prm)
 int ready_for_scan(struct rm_obj *prm)
 {
 	_adapter *padapter = prm->psta->padapter;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-
-	if (rtw_is_scan_deny(padapter))
-		return _FALSE;
+	u8 ssc_chk;
 
 	if (!rtw_is_adapter_up(padapter))
 		return _FALSE;
 
-	if (rtw_mi_busy_traffic_check(padapter, _FALSE))
-		return _FALSE;
+	ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
 
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE)
-		&& check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
-		RTW_INFO(FUNC_ADPT_FMT" WIFI_AP_STATE && WIFI_UNDER_WPS\n",
-		FUNC_ADPT_ARG(padapter));
-		return _FALSE;
-	}
-	if (check_fwstate(pmlmepriv,
-		(_FW_UNDER_SURVEY | _FW_UNDER_LINKING)) == _TRUE) {
-		RTW_INFO(FUNC_ADPT_FMT" _FW_UNDER_SURVEY|_FW_UNDER_LINKING\n",
-			FUNC_ADPT_ARG(padapter));
-		return _FALSE;
-	}
+	if (ssc_chk == SS_ALLOW)
+		return _SUCCESS;
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_mi_buddy_check_fwstate(padapter,
-		(_FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS))) {
-		RTW_INFO(FUNC_ADPT_FMT", but buddy_intf is under scanning or linking or wps_phase\n",
-			FUNC_ADPT_ARG(padapter));
-		return _FALSE;
-	}
-#endif
-	return _SUCCESS;
+	return _FALSE;
 }
 
 int rm_sitesurvey(struct rm_obj *prm)
@@ -911,10 +936,11 @@ int rm_radio_mens_nb_rep(_adapter *padapter,
 #endif
 	rm_post_event(padapter, prm->rmid, RM_EV_recv_rep);
 
-#ifdef CONFIG_RTW_BSS_TRANS
-	ret = bss_transition_candidates_list_survey(padapter,
-		pframe_body+3, len, _FALSE);
-	if (ret == _FAIL)
+#ifdef CONFIG_LAYER2_ROAMING
+	if (rtw_wnm_btm_candidates_survey(padapter
+			,(pdiag_body + 3)
+			,(len - sizeof(struct rtw_ieee80211_hdr_3addr))
+			,_FALSE) == _FAIL)
 		return _FALSE;
 #endif
 	rtw_cfg80211_rx_rrm_action(padapter, precv_frame);
@@ -1824,32 +1850,43 @@ int rm_radio_meas_report_cond(struct rm_obj *prm)
 
 int retrieve_radio_meas_result(struct rm_obj *prm)
 {
-	int i;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(prm->psta->padapter);
+	int i, ch = -1;
 	u8 val8;
 
 
+	ch = rtw_chset_search_ch(adapter_to_chset(prm->psta->padapter),
+		prm->q.ch_num);
+
+	if ((ch == -1) || (ch >= MAX_CHANNEL_NUM)) {
+		RTW_ERR("RM: get ch(CH:%d) fail\n", prm->q.ch_num);
+		ch = 0;
+	}
+
 	switch (prm->q.m_type) {
 	case ch_load_req:
-#ifdef CONFOG_RTK_ACS
-		val8 = rtw_acs_get_clm_ratio_by_ch_num(
-			prm->psta->padapter,prm->q.ch_num);
-		val8 = 255 * (val8/100);
+#ifdef CONFIG_RTW_ACS
+		val8 = hal_data->acs.clm_ratio[ch];
 #else
 		val8 = 0;
 #endif
 		prm->p.ch_load = val8;
 		break;
 	case noise_histo_req:
+#ifdef CONFIG_RTW_ACS
 		/* ANPI */
-#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
-		//val8 = rtw_noise_query_by_chan_num(padapter, cur_chan);
-		prm->p.anpi = 0; /* TODO */
+		prm->p.anpi = hal_data->acs.nhm_ratio[ch];
+
+		/* IPI 0~10 */
+		for (i=0;i<11;i++)
+			prm->p.ipi[i] = hal_data->acs.nhm[ch][i];
+		
 #else
 		val8 = 0;
-#endif
-		/* IPI 0~10 TODO */
+		prm->p.anpi = val8;
 		for (i=0;i<11;i++)
-			prm->p.ipi[i] = i;
+			prm->p.ipi[i] = val8;
+#endif
 		break;
 	default:
 		break;
@@ -1939,9 +1976,12 @@ done:
 void rtw_ap_parse_sta_rm_en_cap(_adapter *padapter,
 	struct sta_info *psta, struct rtw_ieee802_11_elems *elem)
 {
-	RTW_INFO("assoc.rm_en_cap="RM_CAP_FMT"\n", RM_CAP_ARG(elem->rm_en_cap));
-	_rtw_memcpy(psta->rm_en_cap,
-		(elem->rm_en_cap), elem->rm_en_cap_len);
+	if (elem->rm_en_cap) {
+		RTW_INFO("assoc.rm_en_cap="RM_CAP_FMT"\n",
+			RM_CAP_ARG(elem->rm_en_cap));
+		_rtw_memcpy(psta->rm_en_cap,
+			(elem->rm_en_cap), elem->rm_en_cap_len);
+	}
 }
 
 void RM_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
@@ -2385,6 +2425,10 @@ static void rm_dbg_list_meas(_adapter *padapter, char *s)
 
 void rm_dbg_cmd(_adapter *padapter, char *s)
 {
+	unsigned val;
+	char *paid;
+	struct sta_info *psta=NULL;
+
 #if (RM_SUPPORT_IWPRIV_DBG)
 	if (_rtw_memcmp(s, "help", 4)) {
 		rm_dbg_help(padapter, s);
@@ -2406,6 +2450,18 @@ void rm_dbg_cmd(_adapter *padapter, char *s)
 
 	} else if (_rtw_memcmp(s, "run_meas", 8)) {
 		rm_dbg_run_meas(padapter, s);
+	} else if (_rtw_memcmp(s, "nb", 2)) {
+
+		paid = strstr(s, "aid=");
+
+		if (paid) { /* find sta_info according to aid */
+			paid += 4; /* skip aid= */
+			sscanf(paid, "%u", &val); /* aid=x */
+			psta = rm_get_sta(padapter, val, NULL);
+
+			if (psta)
+				rm_add_nb_req(padapter, psta);
+		}
 	}
 #else
 	sprintf(pstr(s), "\n");
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm_fsm.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm_fsm.c
index 1ed3c9d7d3ce..d24173a5bf9a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm_fsm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rm_fsm.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -656,8 +657,8 @@ static int rm_state_do_meas(struct rm_obj *prm, enum RM_EV_ID evid)
 	case RM_EV_start_meas:
 		if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
 			/* resotre measurement start time */
-			rtw_hal_get_hwreg(padapter, HW_VAR_TSF, (u8 *)&val64);
-			prm->meas_start_time = val64;
+			prm->meas_start_time = rtw_hal_get_tsftr_by_port(padapter
+									, rtw_hal_get_port(padapter));
 
 			switch (prm->q.m_type) {
 			case bcn_req:
@@ -741,8 +742,8 @@ static int rm_state_do_meas(struct rm_obj *prm, enum RM_EV_ID evid)
 	case RM_EV_state_out:
 		rm_cancel_clock(prm);
 		/* resotre measurement end time */
-		rtw_hal_get_hwreg(padapter, HW_VAR_TSF, (u8 *)&val64);
-		_rtw_memcpy(&prm->meas_end_time, (char *)&val64, sizeof(u64));
+		prm->meas_end_time = rtw_hal_get_tsftr_by_port(padapter
+								, rtw_hal_get_port(padapter));
 
 		val8 = 0; /* Disable free run counter */
 		rtw_hal_set_hwreg(padapter, HW_VAR_FREECNT, &val8);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rson.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rson.c
index 9d3cd537304b..3100ac714bc7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rson.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_rson.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
@@ -326,6 +327,9 @@ int rtw_rson_isupdate_roamcan(struct mlme_priv *mlme
 		|| (rson_comp.id != CONFIG_RTW_REPEATER_SON_ID))
 		return _FALSE;
 
+	if (is_match_bssid(competitor->network.MacAddress, rtw_rson_block_bssid, rtw_rson_block_bssid_idx) == _TRUE)
+		return _FALSE;
+
 	if ((!mlme->cur_network_scanned)
 		|| (mlme->cur_network_scanned == competitor)
 		|| (rtw_get_rson_struct(&(mlme->cur_network_scanned->network), &rson_curr)) != _TRUE)
@@ -510,7 +514,7 @@ void rtw_rson_scan_cmd_hdl(_adapter *padapter, int op)
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	u8 val8;
 
-	if (mlmeext_chk_scan_state(pmlmeext, SCAN_DISABLE) != _FALSE)
+	if (mlmeext_chk_scan_state(pmlmeext, SCAN_DISABLE) != _TRUE)
 		return;
 	if (op == RSON_SCAN_PROCESS) {
 		padapter->rtw_rson_scanstage = RSON_SCAN_PROCESS;
@@ -552,7 +556,7 @@ void rtw_rson_scan_cmd_hdl(_adapter *padapter, int op)
 								RTW_INFO("change to widi listen\n");
 							}
 #endif /* CONFIG_INTEL_WIDI */
-							rtw_free_assoc_resources(padapter, 1);
+							rtw_free_assoc_resources(padapter, _TRUE);
 							rtw_indicate_disconnect(padapter, 0, _FALSE);
 						} else
 							pmlmepriv->to_join = _TRUE;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sdio.c
index e8f49bfc30d1..328a2284c6aa 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_security.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_security.c
index dd5b1b2bea60..a925a8899a29 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_security.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_security.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -982,13 +983,6 @@ static void next_key(u8 *key, sint round);
 static void byte_sub(u8 *in, u8 *out);
 static void shift_row(u8 *in, u8 *out);
 static void mix_column(u8 *in, u8 *out);
-#ifndef PLATFORM_FREEBSD
-static void add_round_key(u8 *shiftrow_in,
-			  u8 *mcol_in,
-			  u8 *block_in,
-			  sint round,
-			  u8 *out);
-#endif /* PLATFORM_FREEBSD */
 static void aes128k128d(u8 *key, u8 *data, u8 *ciphertext);
 
 
@@ -1185,11 +1179,11 @@ static void construct_mic_iv(
 		mic_iv[1] = mpdu[24] & 0x0f;   /* mute bits 7-4   */
 	if (!qc_exists)
 		mic_iv[1] = 0x00;
-#ifdef CONFIG_IEEE80211W
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
 	/* 802.11w management frame should set management bit(4) */
 	if (frtype == WIFI_MGT_TYPE)
 		mic_iv[1] |= BIT(4);
-#endif /* CONFIG_IEEE80211W */
+#endif
 	for (i = 2; i < 8; i++)
 		mic_iv[i] = mpdu[i + 8];                    /* mic_iv[2:7] = A2[0:5] = mpdu[10:15] */
 #ifdef CONSISTENT_PN_ORDER
@@ -1219,12 +1213,12 @@ static void construct_mic_header1(
 {
 	mic_header1[0] = (u8)((header_length - 2) / 256);
 	mic_header1[1] = (u8)((header_length - 2) % 256);
-#ifdef CONFIG_IEEE80211W
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
 	/* 802.11w management frame don't AND subtype bits 4,5,6 of frame control field */
 	if (frtype == WIFI_MGT_TYPE)
 		mic_header1[2] = mpdu[0];
 	else
-#endif /* CONFIG_IEEE80211W */
+#endif
 		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 */
@@ -1320,11 +1314,11 @@ static void construct_ctr_preload(
 		ctr_preload[1] = mpdu[30] & 0x0f;   /* QoC_Control */
 	if (qc_exists && !a4_exists)
 		ctr_preload[1] = mpdu[24] & 0x0f;
-#ifdef CONFIG_IEEE80211W
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
 	/* 802.11w management frame should set management bit(4) */
 	if (frtype == WIFI_MGT_TYPE)
 		ctr_preload[1] |= BIT(4);
-#endif /* CONFIG_IEEE80211W */
+#endif
 	for (i = 2; i < 8; i++)
 		ctr_preload[i] = mpdu[i + 8];                       /* ctr_preload[2:7] = A2[0:5] = mpdu[10:15] */
 #ifdef CONSISTENT_PN_ORDER
@@ -1394,8 +1388,7 @@ static sint aes_cipher(u8 *key, uint	hdrlen,
 		((frtype | frsubtype) == WIFI_DATA_CFPOLL) ||
 		((frtype | frsubtype) == WIFI_DATA_CFACKPOLL)) {
 		qc_exists = 1;
-		if (hdrlen !=  WLAN_HDR_A3_QOS_LEN)
-
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
 			hdrlen += 2;
 	}
 	/* add for CONFIG_IEEE80211W, none 11w also can use */
@@ -1404,8 +1397,7 @@ static sint aes_cipher(u8 *key, uint	hdrlen,
 		  (frsubtype == 0x09) ||
 		  (frsubtype == 0x0a) ||
 		  (frsubtype == 0x0b))) {
-		if (hdrlen !=  WLAN_HDR_A3_QOS_LEN)
-
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
 			hdrlen += 2;
 		qc_exists = 1;
 	} else
@@ -1715,8 +1707,7 @@ static sint aes_decipher(u8 *key, uint	hdrlen,
 		((frtype | frsubtype) == WIFI_DATA_CFPOLL) ||
 		((frtype | frsubtype) == WIFI_DATA_CFACKPOLL)) {
 		qc_exists = 1;
-		if (hdrlen !=  WLAN_HDR_A3_QOS_LEN)
-
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
 			hdrlen += 2;
 	} /* only for data packet . add for CONFIG_IEEE80211W, none 11w also can use */
 	else if ((frtype == WIFI_DATA) &&
@@ -1724,8 +1715,7 @@ static sint aes_decipher(u8 *key, uint	hdrlen,
 		  (frsubtype == 0x09) ||
 		  (frsubtype == 0x0a) ||
 		  (frsubtype == 0x0b))) {
-		if (hdrlen !=  WLAN_HDR_A3_QOS_LEN)
-
+		if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
 			hdrlen += 2;
 		qc_exists = 1;
 	} else
@@ -1933,7 +1923,6 @@ u32	rtw_aes_decrypt(_adapter *padapter, u8 *precvframe)
 
 
 	sint		length;
-	u32	prwskeylen;
 	u8	*pframe, *prwskey;	/* , *payload,*iv */
 	struct	sta_info		*stainfo;
 	struct	rx_pkt_attrib	*prxattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
@@ -1954,7 +1943,11 @@ u32	rtw_aes_decrypt(_adapter *padapter, u8 *precvframe)
 
 				/* RTW_INFO("rx bc/mc packets, to perform sw rtw_aes_decrypt\n"); */
 				/* prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey; */
-				if (psecuritypriv->binstallGrpkey == _FALSE) {
+				if ((!MLME_IS_MESH(padapter) && psecuritypriv->binstallGrpkey == _FALSE)
+					#ifdef CONFIG_RTW_MESH
+					|| !(stainfo->gtk_bmp | BIT(prxattrib->key_index))
+					#endif
+				) {
 					res = _FAIL;
 
 					if (start == 0)
@@ -1986,12 +1979,20 @@ u32	rtw_aes_decrypt(_adapter *padapter, u8 *precvframe)
 				no_gkey_bc_cnt = 0;
 				no_gkey_mc_cnt = 0;
 
-				prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
-				if (psecuritypriv->dot118021XGrpKeyid != prxattrib->key_index) {
-					RTW_DBG("not match packet_index=%d, install_index=%d\n"
-						, prxattrib->key_index, psecuritypriv->dot118021XGrpKeyid);
-					res = _FAIL;
-					goto exit;
+				#ifdef CONFIG_RTW_MESH
+				if (MLME_IS_MESH(padapter)) {
+					/* TODO: multiple GK? */
+					prwskey = &stainfo->gtk.skey[0];
+				} else
+				#endif
+				{
+					prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
+					if (psecuritypriv->dot118021XGrpKeyid != prxattrib->key_index) {
+						RTW_DBG("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];
@@ -2033,94 +2034,96 @@ exit:
 }
 
 #ifdef CONFIG_IEEE80211W
-u32	rtw_BIP_verify(_adapter *padapter, u8 *precvframe)
+u32	rtw_BIP_verify(_adapter *padapter, u8 *whdr_pos, sint flen
+	, const u8 *key, u16 keyid, u64* ipn)
 {
-	struct rx_pkt_attrib *pattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
-	u8 *pframe;
-	u8 *BIP_AAD, *p;
+	u8 *BIP_AAD, *mme;
 	u32	res = _FAIL;
 	uint len, ori_len;
+	u16 pkt_keyid = 0;
+	u64 pkt_ipn = 0;
 	struct rtw_ieee80211_hdr *pwlanhdr;
 	u8 mic[16];
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	ori_len = pattrib->pkt_len - WLAN_HDR_A3_LEN + BIP_AAD_SIZE;
-	BIP_AAD = rtw_zmalloc(ori_len);
 
+	mme = whdr_pos + flen - 18;
+	if (*mme != _MME_IE_)
+		return RTW_RX_HANDLED;
+
+	/* copy key index */
+	_rtw_memcpy(&pkt_keyid, mme + 2, 2);
+	pkt_keyid = le16_to_cpu(pkt_keyid);
+	if (pkt_keyid != keyid) {
+		RTW_INFO("BIP key index error!\n");
+		return _FAIL;
+	}
+
+	/* save packet number */
+	_rtw_memcpy(&pkt_ipn, mme + 4, 6);
+	pkt_ipn = le64_to_cpu(pkt_ipn);
+	/* BIP packet number should bigger than previous BIP packet */
+	if (pkt_ipn <= *ipn) { /* wrap around? */
+		RTW_INFO("replay BIP packet\n");
+		return _FAIL;
+	}
+
+	ori_len = flen - WLAN_HDR_A3_LEN + BIP_AAD_SIZE;
+	BIP_AAD = rtw_zmalloc(ori_len);
 	if (BIP_AAD == NULL) {
 		RTW_INFO("BIP AAD allocate fail\n");
 		return _FAIL;
 	}
-	/* PKT start */
-	pframe = (unsigned char *)((union recv_frame *)precvframe)->u.hdr.rx_data;
+
 	/* mapping to wlan header */
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	pwlanhdr = (struct rtw_ieee80211_hdr *)whdr_pos;
+
 	/* save the frame body + MME */
-	_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, pframe + WLAN_HDR_A3_LEN, pattrib->pkt_len - WLAN_HDR_A3_LEN);
-	/* find MME IE pointer */
-	p = rtw_get_ie(BIP_AAD + BIP_AAD_SIZE, _MME_IE_, &len, pattrib->pkt_len - WLAN_HDR_A3_LEN);
-	/* Baron */
-	if (p) {
-		u16 keyid = 0;
-		u64 temp_ipn = 0;
-		/* save packet number */
-		_rtw_memcpy(&temp_ipn, p + 4, 6);
-		temp_ipn = le64_to_cpu(temp_ipn);
-		/* BIP packet number should bigger than previous BIP packet */
-		if (temp_ipn < pmlmeext->mgnt_80211w_IPN_rx) {
-			RTW_INFO("replay BIP packet\n");
-			goto BIP_exit;
-		}
-		/* copy key index */
-		_rtw_memcpy(&keyid, p + 2, 2);
-		keyid = le16_to_cpu(keyid);
-		if (keyid != padapter->securitypriv.dot11wBIPKeyid) {
-			RTW_INFO("BIP key index error!\n");
-			goto BIP_exit;
-		}
-		/* clear the MIC field of MME to zero */
-		_rtw_memset(p + 2 + len - 8, 0, 8);
+	_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, whdr_pos + WLAN_HDR_A3_LEN, flen - WLAN_HDR_A3_LEN);
+
+	/* point mme to the copy */
+	mme = BIP_AAD + ori_len - 18;
+
+	/* clear the MIC field of MME to zero */
+	_rtw_memset(mme + 10, 0, 8);
 
-		/* conscruct AAD, copy frame control field */
-		_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
-		ClearRetry(BIP_AAD);
-		ClearPwrMgt(BIP_AAD);
-		ClearMData(BIP_AAD);
-		/* conscruct AAD, copy address 1 to address 3 */
-		_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
+	/* conscruct AAD, copy frame control field */
+	_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
+	ClearRetry(BIP_AAD);
+	ClearPwrMgt(BIP_AAD);
+	ClearMData(BIP_AAD);
+	/* conscruct AAD, copy address 1 to address 3 */
+	_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
 
-		if (omac1_aes_128(padapter->securitypriv.dot11wBIPKey[padapter->securitypriv.dot11wBIPKeyid].skey
-				  , BIP_AAD, ori_len, mic))
-			goto BIP_exit;
+	if (omac1_aes_128(key, BIP_AAD, ori_len, mic))
+		goto BIP_exit;
 
 #if 0
-		/* management packet content */
-		{
-			int pp;
-			RTW_INFO("pkt: ");
-			for (pp = 0; pp < pattrib->pkt_len; pp++)
-				printk(" %02x ", pframe[pp]);
-			RTW_INFO("\n");
-			/* BIP AAD + management frame body + MME(MIC is zero) */
-			RTW_INFO("AAD+PKT: ");
-			for (pp = 0; pp < ori_len; pp++)
-				RTW_INFO(" %02x ", BIP_AAD[pp]);
-			RTW_INFO("\n");
-			/* show the MIC result */
-			RTW_INFO("mic: ");
-			for (pp = 0; pp < 16; pp++)
-				RTW_INFO(" %02x ", mic[pp]);
-			RTW_INFO("\n");
-		}
+	/* management packet content */
+	{
+		int pp;
+		RTW_INFO("pkt: ");
+		for (pp = 0; pp < flen; pp++)
+			printk(" %02x ", whdr_pos[pp]);
+		RTW_INFO("\n");
+		/* BIP AAD + management frame body + MME(MIC is zero) */
+		RTW_INFO("AAD+PKT: ");
+		for (pp = 0; pp < ori_len; pp++)
+			RTW_INFO(" %02x ", BIP_AAD[pp]);
+		RTW_INFO("\n");
+		/* show the MIC result */
+		RTW_INFO("mic: ");
+		for (pp = 0; pp < 16; pp++)
+			RTW_INFO(" %02x ", mic[pp]);
+		RTW_INFO("\n");
+	}
 #endif
-		/* MIC field should be last 8 bytes of packet (packet without FCS) */
-		if (_rtw_memcmp(mic, pframe + pattrib->pkt_len - 8, 8)) {
-			pmlmeext->mgnt_80211w_IPN_rx = temp_ipn;
-			res = _SUCCESS;
-		} else
-			RTW_INFO("BIP MIC error!\n");
 
+	/* MIC field should be last 8 bytes of packet (packet without FCS) */
+	if (_rtw_memcmp(mic, whdr_pos + flen - 8, 8)) {
+		*ipn = pkt_ipn;
+		res = _SUCCESS;
 	} else
-		res = RTW_RX_HANDLED;
+		RTW_INFO("BIP MIC error!\n");
+
 BIP_exit:
 
 	rtw_mfree(BIP_AAD, ori_len);
@@ -2129,6 +2132,7 @@ BIP_exit:
 #endif /* CONFIG_IEEE80211W */
 
 #ifndef PLATFORM_FREEBSD
+#if defined(CONFIG_TDLS)
 /* compress 512-bits */
 static int sha256_compress(struct sha256_state *md, unsigned char *buf)
 {
@@ -2309,10 +2313,12 @@ static u8 os_strlen(const char *s)
 		p++;
 	return p - s;
 }
+#endif
 
-static int os_memcmp(void *s1, void *s2, u8 n)
+#if defined(CONFIG_TDLS) || defined(CONFIG_RTW_MESH_AEK)
+static int os_memcmp(const void *s1, const void *s2, u8 n)
 {
-	unsigned char *p1 = s1, *p2 = s2;
+	const unsigned char *p1 = s1, *p2 = s2;
 
 	if (n == 0)
 		return 0;
@@ -2327,6 +2333,7 @@ static int os_memcmp(void *s1, void *s2, u8 n)
 
 	return *p1 - *p2;
 }
+#endif
 
 /**
  * hmac_sha256_vector - HMAC-SHA256 over data vector (RFC 2104)
@@ -2337,6 +2344,7 @@ static int os_memcmp(void *s1, void *s2, u8 n)
  * @len: Lengths of the data blocks
  * @mac: Buffer for the hash (32 bytes)
  */
+#if defined(CONFIG_TDLS)
 static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
 			       u8 *addr[], size_t *len, u8 *mac)
 {
@@ -2398,6 +2406,7 @@ static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
 	_len[1] = 32;
 	sha256_vector(2, _addr, _len, mac);
 }
+#endif /* CONFIG_TDLS */
 #endif /* PLATFORM_FREEBSD */
 /**
  * sha256_prf - SHA256-based Pseudo-Random Function (IEEE 802.11r, 8.5.1.5.2)
@@ -2413,6 +2422,7 @@ static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
  * given key.
  */
 #ifndef PLATFORM_FREEBSD /* Baron */
+#if defined(CONFIG_TDLS)
 static void sha256_prf(u8 *key, size_t key_len, char *label,
 		       u8 *data, size_t data_len, u8 *buf, size_t buf_len)
 {
@@ -2449,6 +2459,7 @@ static void sha256_prf(u8 *key, size_t key_len, char *label,
 		counter++;
 	}
 }
+#endif
 #endif /* PLATFORM_FREEBSD Baron */
 
 /* AES tables*/
@@ -2718,7 +2729,7 @@ static void rijndaelEncrypt(u32 rk[/*44*/], u8 pt[16], u8 ct[16])
 	PUTU32(ct + 12, s3);
 }
 
-static void *aes_encrypt_init(u8 *key, size_t len)
+static void *aes_encrypt_init(const u8 *key, size_t len)
 {
 	u32 *rk;
 	if (len != 16)
@@ -2768,12 +2779,12 @@ static void aes_encrypt_deinit(void *ctx)
  * OMAC1 was standardized with the name CMAC by NIST in a Special Publication
  * (SP) 800-38B.
  */
-static int omac1_aes_128_vector(u8 *key, size_t num_elem,
-				u8 *addr[], size_t *len, u8 *mac)
+static int omac1_aes_128_vector(const u8 *key, size_t num_elem,
+			 const u8 *addr[], const size_t *len, u8 *mac)
 {
 	void *ctx;
 	u8 cbc[AES_BLOCK_SIZE], pad[AES_BLOCK_SIZE];
-	u8 *pos, *end;
+	const u8 *pos, *end;
 	size_t i, e, left, total_len;
 
 	ctx = aes_encrypt_init(key, 16);
@@ -2841,12 +2852,237 @@ static int omac1_aes_128_vector(u8 *key, size_t num_elem,
  * OMAC1 was standardized with the name CMAC by NIST in a Special Publication
  * (SP) 800-38B.
  */ /* modify for CONFIG_IEEE80211W */
-int omac1_aes_128(u8 *key, u8 *data, size_t data_len, u8 *mac)
+int omac1_aes_128(const u8 *key, const u8 *data, size_t data_len, u8 *mac)
 {
 	return omac1_aes_128_vector(key, 1, &data, &data_len, mac);
 }
 #endif /* PLATFORM_FREEBSD Baron */
 
+#ifdef CONFIG_RTW_MESH_AEK
+/* for AES-SIV */
+#define os_memset _rtw_memset
+#define os_memcpy _rtw_memcpy
+#define os_malloc rtw_malloc
+#define bin_clear_free(bin, len) \
+	do { \
+		if (bin) { \
+			os_memset(bin, 0, len); \
+			rtw_mfree(bin, len); \
+		} \
+	} while (0)
+
+static const u8 zero[AES_BLOCK_SIZE];
+
+static void dbl(u8 *pad)
+{
+	int i, carry;
+
+	carry = pad[0] & 0x80;
+	for (i = 0; i < AES_BLOCK_SIZE - 1; i++)
+		pad[i] = (pad[i] << 1) | (pad[i + 1] >> 7);
+	pad[AES_BLOCK_SIZE - 1] <<= 1;
+	if (carry)
+		pad[AES_BLOCK_SIZE - 1] ^= 0x87;
+}
+
+static void xor(u8 *a, const u8 *b)
+{
+	int i;
+
+	for (i = 0; i < AES_BLOCK_SIZE; i++)
+		*a++ ^= *b++;
+}
+
+static void xorend(u8 *a, int alen, const u8 *b, int blen)
+{
+	int i;
+
+	if (alen < blen)
+		return;
+
+	for (i = 0; i < blen; i++)
+		a[alen - blen + i] ^= b[i];
+}
+
+static void pad_block(u8 *pad, const u8 *addr, size_t len)
+{
+	os_memset(pad, 0, AES_BLOCK_SIZE);
+	os_memcpy(pad, addr, len);
+
+	if (len < AES_BLOCK_SIZE)
+		pad[len] = 0x80;
+}
+
+static int aes_s2v(const u8 *key, size_t num_elem, const u8 *addr[],
+		   size_t *len, u8 *mac)
+{
+	u8 tmp[AES_BLOCK_SIZE], tmp2[AES_BLOCK_SIZE];
+	u8 *buf = NULL;
+	int ret;
+	size_t i;
+
+	if (!num_elem) {
+		os_memcpy(tmp, zero, sizeof(zero));
+		tmp[AES_BLOCK_SIZE - 1] = 1;
+		return omac1_aes_128(key, tmp, sizeof(tmp), mac);
+	}
+
+	ret = omac1_aes_128(key, zero, sizeof(zero), tmp);
+	if (ret)
+		return ret;
+
+	for (i = 0; i < num_elem - 1; i++) {
+		ret = omac1_aes_128(key, addr[i], len[i], tmp2);
+		if (ret)
+			return ret;
+
+		dbl(tmp);
+		xor(tmp, tmp2);
+	}
+	if (len[i] >= AES_BLOCK_SIZE) {
+		buf = os_malloc(len[i]);
+		if (!buf)
+			return -ENOMEM;
+
+		os_memcpy(buf, addr[i], len[i]);
+		xorend(buf, len[i], tmp, AES_BLOCK_SIZE);
+		ret = omac1_aes_128(key, buf, len[i], mac);
+		bin_clear_free(buf, len[i]);
+		return ret;
+	}
+
+	dbl(tmp);
+	pad_block(tmp2, addr[i], len[i]);
+	xor(tmp, tmp2);
+
+	return omac1_aes_128(key, tmp, sizeof(tmp), mac);
+}
+
+/**
+ * aes_128_ctr_encrypt - AES-128 CTR mode encryption
+ * @key: Key for encryption (16 bytes)
+ * @nonce: Nonce for counter mode (16 bytes)
+ * @data: Data to encrypt in-place
+ * @data_len: Length of data in bytes
+ * Returns: 0 on success, -1 on failure
+ */
+int aes_128_ctr_encrypt(const u8 *key, const u8 *nonce,
+			u8 *data, size_t data_len)
+{
+	void *ctx;
+	size_t j, len, left = data_len;
+	int i;
+	u8 *pos = data;
+	u8 counter[AES_BLOCK_SIZE], buf[AES_BLOCK_SIZE];
+
+	ctx = aes_encrypt_init(key, 16);
+	if (ctx == NULL)
+		return -1;
+	os_memcpy(counter, nonce, AES_BLOCK_SIZE);
+
+	while (left > 0) {
+		#if 0
+		aes_encrypt(ctx, counter, buf);
+		#else
+		aes_128_encrypt(ctx, counter, buf);
+		#endif
+
+		len = (left < AES_BLOCK_SIZE) ? left : AES_BLOCK_SIZE;
+		for (j = 0; j < len; j++)
+			pos[j] ^= buf[j];
+		pos += len;
+		left -= len;
+
+		for (i = AES_BLOCK_SIZE - 1; i >= 0; i--) {
+			counter[i]++;
+			if (counter[i])
+				break;
+		}
+	}
+	aes_encrypt_deinit(ctx);
+	return 0;
+}
+
+int aes_siv_encrypt(const u8 *key, const u8 *pw,
+		    size_t pwlen, size_t num_elem,
+		    const u8 *addr[], const size_t *len, u8 *out)
+{
+	const u8 *_addr[6];
+	size_t _len[6];
+	const u8 *k1 = key, *k2 = key + 16;
+	u8 v[AES_BLOCK_SIZE];
+	size_t i;
+	u8 *iv, *crypt_pw;
+
+	if (num_elem > ARRAY_SIZE(_addr) - 1)
+		return -1;
+
+	for (i = 0; i < num_elem; i++) {
+		_addr[i] = addr[i];
+		_len[i] = len[i];
+	}
+	_addr[num_elem] = pw;
+	_len[num_elem] = pwlen;
+
+	if (aes_s2v(k1, num_elem + 1, _addr, _len, v))
+		return -1;
+
+	iv = out;
+	crypt_pw = out + AES_BLOCK_SIZE;
+
+	os_memcpy(iv, v, AES_BLOCK_SIZE);
+	os_memcpy(crypt_pw, pw, pwlen);
+
+	/* zero out 63rd and 31st bits of ctr (from right) */
+	v[8] &= 0x7f;
+	v[12] &= 0x7f;
+	return aes_128_ctr_encrypt(k2, v, crypt_pw, pwlen);
+}
+
+int aes_siv_decrypt(const u8 *key, const u8 *iv_crypt, size_t iv_c_len,
+		    size_t num_elem, const u8 *addr[], const size_t *len,
+		    u8 *out)
+{
+	const u8 *_addr[6];
+	size_t _len[6];
+	const u8 *k1 = key, *k2 = key + 16;
+	size_t crypt_len;
+	size_t i;
+	int ret;
+	u8 iv[AES_BLOCK_SIZE];
+	u8 check[AES_BLOCK_SIZE];
+
+	if (iv_c_len < AES_BLOCK_SIZE || num_elem > ARRAY_SIZE(_addr) - 1)
+		return -1;
+	crypt_len = iv_c_len - AES_BLOCK_SIZE;
+
+	for (i = 0; i < num_elem; i++) {
+		_addr[i] = addr[i];
+		_len[i] = len[i];
+	}
+	_addr[num_elem] = out;
+	_len[num_elem] = crypt_len;
+
+	os_memcpy(iv, iv_crypt, AES_BLOCK_SIZE);
+	os_memcpy(out, iv_crypt + AES_BLOCK_SIZE, crypt_len);
+
+	iv[8] &= 0x7f;
+	iv[12] &= 0x7f;
+
+	ret = aes_128_ctr_encrypt(k2, iv, out, crypt_len);
+	if (ret)
+		return ret;
+
+	ret = aes_s2v(k1, num_elem + 1, _addr, _len, check);
+	if (ret)
+		return ret;
+	if (os_memcmp(check, iv_crypt, AES_BLOCK_SIZE) == 0)
+		return 0;
+
+	return -1;
+}
+#endif /* CONFIG_RTW_MESH_AEK */
+
 #ifdef CONFIG_TDLS
 void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta)
 {
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sreset.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sreset.c
index db954e2b54ce..27b1ed8b8558 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sreset.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sreset.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -47,10 +48,9 @@ u8 sreset_get_wifi_status(_adapter *padapter)
 #if defined(DBG_CONFIG_ERROR_DETECT)
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-
 	u8 status = WIFI_STATUS_SUCCESS;
 	u32 val32 = 0;
-	_irqL irqL;
+
 	if (psrtpriv->silent_reset_inprogress == _TRUE)
 		return status;
 	val32 = rtw_read32(padapter, REG_TXDMA_STATUS);
@@ -104,11 +104,9 @@ bool sreset_inprogress(_adapter *padapter)
 
 void sreset_restore_security_station(_adapter *padapter)
 {
-	u8 EntryId = 0;
 	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct sta_info *psta;
-	struct security_priv *psecuritypriv = &(padapter->securitypriv);
 	struct mlme_ext_info	*pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
 
 	{
@@ -126,31 +124,18 @@ void sreset_restore_security_station(_adapter *padapter)
 		rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
 	}
 
-#if 0
-	if ((padapter->securitypriv.dot11PrivacyAlgrthm == _WEP40_) ||
-	    (padapter->securitypriv.dot11PrivacyAlgrthm == _WEP104_)) {
-
-		for (EntryId = 0; EntryId < 4; EntryId++) {
-			if (EntryId == psecuritypriv->dot11PrivacyKeyIndex)
-				rtw_set_key(padapter, &padapter->securitypriv, EntryId, 1, _FALSE);
-			else
-				rtw_set_key(padapter, &padapter->securitypriv, EntryId, 0, _FALSE);
-		}
-
-	} else
-#endif
-		if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
-		    (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
-			psta = rtw_get_stainfo(pstapriv, get_bssid(mlmepriv));
-			if (psta == NULL) {
-				/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
-			} else {
-				/* pairwise key */
-				rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _FALSE);
-				/* group key */
-				rtw_set_key(padapter, &padapter->securitypriv, padapter->securitypriv.dot118021XGrpKeyid, 0, _FALSE);
-			}
+	if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
+	    (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
+		psta = rtw_get_stainfo(pstapriv, get_bssid(mlmepriv));
+		if (psta == NULL) {
+			/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
+		} else {
+			/* pairwise key */
+			rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _FALSE);
+			/* group key */
+			rtw_set_key(padapter, &padapter->securitypriv, padapter->securitypriv.dot118021XGrpKeyid, 0, _FALSE);
 		}
+	}
 }
 
 void sreset_restore_network_station(_adapter *padapter)
@@ -160,32 +145,14 @@ void sreset_restore_network_station(_adapter *padapter)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	u8 doiqk = _FALSE;
 
-#if 0
-	{
-		/* ======================================================= */
-		/* reset related register of Beacon control */
-
-		/* set MSR to nolink */
-		Set_MSR(padapter, _HW_STATE_NOLINK_);
-		/* reject all data frame */
-		rtw_write16(padapter, REG_RXFLTMAP2, 0x00);
-		/* reset TSF */
-		rtw_write8(padapter, REG_DUAL_TSF_RST, (BIT(0) | BIT(1)));
-
-		/* disable update TSF */
-		SetBcnCtrlReg(padapter, BIT(4), 0);
-
-		/* ======================================================= */
-	}
-#endif
-
-	rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, _FALSE);
+	rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, RTW_CMDF_DIRECTLY);
 
 	{
 		u8 threshold;
 #ifdef CONFIG_USB_HCI
 		/* TH=1 => means that invalidate usb rx aggregation */
 		/* TH=0 => means that validate usb rx aggregation, use init value. */
+#ifdef CONFIG_80211N_HT
 		if (mlmepriv->htpriv.ht_option) {
 			if (padapter->registrypriv.wifi_spec == 1)
 				threshold = 1;
@@ -196,6 +163,7 @@ void sreset_restore_network_station(_adapter *padapter)
 			threshold = 1;
 			rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
 		}
+#endif /* CONFIG_80211N_HT */
 #endif
 	}
 
@@ -213,8 +181,9 @@ void sreset_restore_network_station(_adapter *padapter)
 
 	{
 		u8	join_type = 0;
-		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
+
 		rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTING);
+		rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
 	}
 
 	Set_MSR(padapter, (pmlmeinfo->state & 0x3));
@@ -230,8 +199,6 @@ void sreset_restore_network_station(_adapter *padapter)
 void sreset_restore_network_status(_adapter *padapter)
 {
 	struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 	if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
 		RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
@@ -329,6 +296,9 @@ void sreset_reset(_adapter *padapter)
 #ifdef CONFIG_IPS
 	_ips_enter(padapter);
 	_ips_leave(padapter);
+#endif
+#ifdef CONFIG_CONCURRENT_MODE
+	rtw_mi_ap_info_restore(padapter);
 #endif
 	rtw_mi_sreset_adapter_hdl(padapter, _TRUE);/*sreset_start_adapter*/
 
@@ -338,5 +308,8 @@ void sreset_reset(_adapter *padapter)
 
 	RTW_INFO("%s done in %d ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
 	pdbgpriv->dbg_sreset_cnt++;
+
+	psrtpriv->self_dect_fw = _FALSE;
+	psrtpriv->rx_cnt = 0;
 #endif
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sta_mgt.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sta_mgt.c
index 232a240db38b..959132e5a00d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sta_mgt.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_sta_mgt.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -229,14 +230,17 @@ void _rtw_init_stainfo(struct sta_info *psta)
 
 u32	_rtw_init_sta_priv(struct	sta_priv *pstapriv)
 {
+	_adapter *adapter = container_of(pstapriv, _adapter, stapriv);
+	struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
 	struct sta_info *psta;
 	s32 i;
+	u32 ret = _FAIL;
 
+	pstapriv->padapter = adapter;
 
 	pstapriv->pallocated_stainfo_buf = rtw_zvmalloc(sizeof(struct sta_info) * NUM_STA + 4);
-
 	if (!pstapriv->pallocated_stainfo_buf)
-		return _FAIL;
+		goto exit;
 
 	pstapriv->pstainfo_buf = pstapriv->pallocated_stainfo_buf + 4 -
 			 ((SIZE_PTR)(pstapriv->pallocated_stainfo_buf) & 3);
@@ -266,9 +270,19 @@ u32	_rtw_init_sta_priv(struct	sta_priv *pstapriv)
 	pstapriv->adhoc_expire_to = 4; /* 4 * 2 = 8 sec */
 
 #ifdef CONFIG_AP_MODE
-
-	pstapriv->sta_dz_bitmap = 0;
-	pstapriv->tim_bitmap = 0;
+	pstapriv->max_aid = macid_ctl->num;
+	pstapriv->rr_aid = 0;
+	pstapriv->started_aid = 1;
+	pstapriv->sta_aid = rtw_zmalloc(pstapriv->max_aid * sizeof(struct sta_info *));
+	if (!pstapriv->sta_aid)
+		goto exit;
+	pstapriv->aid_bmp_len = AID_BMP_LEN(pstapriv->max_aid);
+	pstapriv->sta_dz_bitmap = rtw_zmalloc(pstapriv->aid_bmp_len);
+	if (!pstapriv->sta_dz_bitmap)
+		goto exit;
+	pstapriv->tim_bitmap = rtw_zmalloc(pstapriv->aid_bmp_len);
+	if (!pstapriv->tim_bitmap)
+		goto exit;
 
 	_rtw_init_listhead(&pstapriv->asoc_list);
 	_rtw_init_listhead(&pstapriv->auth_list);
@@ -294,15 +308,29 @@ u32	_rtw_init_sta_priv(struct	sta_priv *pstapriv)
 #endif
 
 #if CONFIG_RTW_MACADDR_ACL
-	_rtw_init_queue(&(pstapriv->acl_list.acl_node_q));
+	for (i = 0; i < RTW_ACL_PERIOD_NUM; i++)
+		rtw_macaddr_acl_init(adapter, i);
 #endif
 
 #if CONFIG_RTW_PRE_LINK_STA
 	rtw_pre_link_sta_ctl_init(pstapriv);
 #endif
 
-	return _SUCCESS;
+	ret = _SUCCESS;
 
+exit:
+	if (ret != _SUCCESS) {
+		if (pstapriv->pallocated_stainfo_buf)
+			rtw_vmfree(pstapriv->pallocated_stainfo_buf, sizeof(struct sta_info) * NUM_STA + 4);
+		#ifdef CONFIG_AP_MODE
+		if (pstapriv->sta_aid)
+			rtw_mfree(pstapriv->sta_aid, pstapriv->max_aid * sizeof(struct sta_info *));
+		if (pstapriv->sta_dz_bitmap)
+			rtw_mfree(pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+		#endif
+	}
+
+	return ret;
 }
 
 inline int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta)
@@ -435,7 +463,8 @@ u32	_rtw_free_sta_priv(struct	sta_priv *pstapriv)
 		rtw_mfree_sta_priv_lock(pstapriv);
 
 #if CONFIG_RTW_MACADDR_ACL
-		_rtw_deinit_queue(&(pstapriv->acl_list.acl_node_q));
+		for (index = 0; index < RTW_ACL_PERIOD_NUM; index++)
+			rtw_macaddr_acl_deinit(pstapriv->padapter, index);
 #endif
 
 #if CONFIG_RTW_PRE_LINK_STA
@@ -444,6 +473,14 @@ u32	_rtw_free_sta_priv(struct	sta_priv *pstapriv)
 
 		if (pstapriv->pallocated_stainfo_buf)
 			rtw_vmfree(pstapriv->pallocated_stainfo_buf, sizeof(struct sta_info) * NUM_STA + 4);
+		#ifdef CONFIG_AP_MODE
+		if (pstapriv->sta_aid)
+			rtw_mfree(pstapriv->sta_aid, pstapriv->max_aid * sizeof(struct sta_info *));
+		if (pstapriv->sta_dz_bitmap)
+			rtw_mfree(pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+		if (pstapriv->tim_bitmap)
+			rtw_mfree(pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
+		#endif
 	}
 
 	return _SUCCESS;
@@ -460,9 +497,9 @@ static void rtw_init_recv_timer(struct recv_reorder_ctrl *preorder_ctrl)
 }
 
 /* struct	sta_info *rtw_alloc_stainfo(_queue *pfree_sta_queue, unsigned char *hwaddr) */
-struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr)
+struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, const u8 *hwaddr)
 {
-	_irqL irqL, irqL2;
+	_irqL irqL2;
 	s32	index;
 	_list	*phash_list;
 	struct sta_info	*psta;
@@ -516,6 +553,7 @@ struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr)
 
 		for (i = 0; i < 16; i++) {
 			_rtw_memcpy(&psta->sta_recvpriv.rxcache.tid_rxseq[i], &wRxSeqInitialValue, 2);
+			_rtw_memcpy(&psta->sta_recvpriv.bmc_tid_rxseq[i], &wRxSeqInitialValue, 2);
 			_rtw_memset(&psta->sta_recvpriv.rxcache.iv[i], 0, sizeof(psta->sta_recvpriv.rxcache.iv[i]));
 		}
 
@@ -558,6 +596,7 @@ struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr)
 #endif
 		/* init for the sequence number of received management frame */
 		psta->RxMgmtFrameSeqNum = 0xffff;
+		_rtw_memset(&psta->sta_stats, 0, sizeof(struct stainfo_stats));
 
 		rtw_alloc_macid(pstapriv->padapter, psta);
 
@@ -686,7 +725,6 @@ u32	rtw_free_stainfo(_adapter *padapter , struct sta_info *psta)
 
 #ifdef CONFIG_TDLS
 	psta->tdls_sta_state = TDLS_STATE_NONE;
-	rtw_free_tdls_timer(psta);
 #endif /* CONFIG_TDLS */
 
 	/* for A-MPDU Rx reordering buffer control, cancel reordering_ctrl_timer */
@@ -763,8 +801,8 @@ u32	rtw_free_stainfo(_adapter *padapter , struct sta_info *psta)
 #ifdef CONFIG_NATIVEAP_MLME
 
 	if (pmlmeinfo->state == _HW_STATE_AP_) {
-		pstapriv->sta_dz_bitmap &= ~BIT(psta->cmn.aid);
-		pstapriv->tim_bitmap &= ~BIT(psta->cmn.aid);
+		rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
+		rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
 		/* rtw_indicate_sta_disassoc_event(padapter, psta); */
 
@@ -851,7 +889,7 @@ exit:
 }
 
 /* any station allocated can be searched by hash list */
-struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, u8 *hwaddr)
+struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, const u8 *hwaddr)
 {
 
 	_irqL	 irqL;
@@ -862,7 +900,7 @@ struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, u8 *hwaddr)
 
 	u32	index;
 
-	u8 *addr;
+	const u8 *addr;
 
 	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
 
@@ -950,14 +988,75 @@ struct sta_info *rtw_get_bcmc_stainfo(_adapter *padapter)
 
 }
 
+#ifdef CONFIG_AP_MODE
+u16 rtw_aid_alloc(_adapter *adapter, struct sta_info *sta)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u16 aid, i, used_cnt = 0;
+
+	for (i = 0; i < stapriv->max_aid; i++) {
+		aid = ((i + stapriv->started_aid - 1) % stapriv->max_aid) + 1;
+		if (stapriv->sta_aid[aid - 1] == NULL)
+			break;
+		if (++used_cnt >= stapriv->max_num_sta)
+			break;
+	}
+
+	/* check for aid limit and assoc limit  */
+	if (i >= stapriv->max_aid || used_cnt >= stapriv->max_num_sta)
+		aid = 0;
+
+	sta->cmn.aid = aid;
+	if (aid) {
+		stapriv->sta_aid[aid - 1] = sta;
+		if (stapriv->rr_aid)
+			stapriv->started_aid = (aid % stapriv->max_aid) + 1;
+	}
+
+	return aid;
+}
+
+void dump_aid_status(void *sel, _adapter *adapter)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	u8 *aid_bmp;
+	u16 i, used_cnt = 0;
+
+	aid_bmp = rtw_zmalloc(stapriv->aid_bmp_len);
+	if (!aid_bmp)
+		return;
+
+	for (i = 1; i <= stapriv->max_aid; i++) {
+		if (stapriv->sta_aid[i - 1]) {
+			aid_bmp[i / 8] |= BIT(i % 8);
+			++used_cnt;
+		}
+	}
+
+	RTW_PRINT_SEL(sel, "used_cnt:%u/%u\n", used_cnt, stapriv->max_aid);
+	RTW_MAP_DUMP_SEL(sel, "aid_map:", aid_bmp, stapriv->aid_bmp_len);
+	RTW_PRINT_SEL(sel, "\n");
+
+	RTW_PRINT_SEL(sel, "%-2s %-11s\n", "rr", "started_aid");
+	RTW_PRINT_SEL(sel, "%2d %11d\n", stapriv->rr_aid, stapriv->started_aid);
+
+	rtw_mfree(aid_bmp, stapriv->aid_bmp_len);
+}
+#endif /* CONFIG_AP_MODE */
+
 #if CONFIG_RTW_MACADDR_ACL
-const char *const _acl_mode_str[] = {
+const char *const _acl_period_str[RTW_ACL_PERIOD_NUM] = {
+	"DEV",
+	"BSS",
+};
+
+const char *const _acl_mode_str[RTW_ACL_MODE_MAX] = {
 	"DISABLED",
 	"ACCEPT_UNLESS_LISTED",
 	"DENY_UNLESS_LISTED",
 };
 
-u8 rtw_access_ctrl(_adapter *adapter, u8 *mac_addr)
+u8 _rtw_access_ctrl(_adapter *adapter, u8 period, const u8 *mac_addr)
 {
 	u8 res = _TRUE;
 	_irqL irqL;
@@ -965,8 +1064,20 @@ u8 rtw_access_ctrl(_adapter *adapter, u8 *mac_addr)
 	struct rtw_wlan_acl_node *acl_node;
 	u8 match = _FALSE;
 	struct sta_priv *stapriv = &adapter->stapriv;
-	struct wlan_acl_pool *acl = &stapriv->acl_list;
-	_queue	*acl_node_q = &acl->acl_node_q;
+	struct wlan_acl_pool *acl;
+	_queue	*acl_node_q;
+
+	if (period >= RTW_ACL_PERIOD_NUM) {
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	acl = &stapriv->acl_list[period];
+	acl_node_q = &acl->acl_node_q;
+
+	if (acl->mode != RTW_ACL_MODE_ACCEPT_UNLESS_LISTED
+		&& acl->mode != RTW_ACL_MODE_DENY_UNLESS_LISTED)
+		goto exit;
 
 	_enter_critical_bh(&(acl_node_q->lock), &irqL);
 	head = get_list_head(acl_node_q);
@@ -986,26 +1097,42 @@ u8 rtw_access_ctrl(_adapter *adapter, u8 *mac_addr)
 
 	if (acl->mode == RTW_ACL_MODE_ACCEPT_UNLESS_LISTED)
 		res = (match == _TRUE) ?  _FALSE : _TRUE;
-	else if (acl->mode == RTW_ACL_MODE_DENY_UNLESS_LISTED)
+	else /* RTW_ACL_MODE_DENY_UNLESS_LISTED */
 		res = (match == _TRUE) ?  _TRUE : _FALSE;
-	else
-		res = _TRUE;
 
+exit:
 	return res;
 }
 
-void dump_macaddr_acl(void *sel, _adapter *adapter)
+u8 rtw_access_ctrl(_adapter *adapter, const u8 *mac_addr)
 {
-	struct sta_priv *stapriv = &adapter->stapriv;
-	struct wlan_acl_pool *acl = &stapriv->acl_list;
 	int i;
 
-	RTW_PRINT_SEL(sel, "mode:%s(%d)\n", acl_mode_str(acl->mode), acl->mode);
-	RTW_PRINT_SEL(sel, "num:%d/%d\n", acl->num, NUM_ACL);
-	for (i = 0; i < NUM_ACL; i++) {
-		if (acl->aclnode[i].valid == _FALSE)
-			continue;
-		RTW_PRINT_SEL(sel, MAC_FMT"\n", MAC_ARG(acl->aclnode[i].addr));
+	for (i = 0; i < RTW_ACL_PERIOD_NUM; i++)
+		if (_rtw_access_ctrl(adapter, i, mac_addr) == _FALSE)
+			return _FALSE;
+
+	return _TRUE;
+}
+
+void dump_macaddr_acl(void *sel, _adapter *adapter)
+{
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct wlan_acl_pool *acl;
+	int i, j;
+
+	for (j = 0; j < RTW_ACL_PERIOD_NUM; j++) {
+		RTW_PRINT_SEL(sel, "period:%s(%d)\n", acl_period_str(j), j);
+
+		acl = &stapriv->acl_list[j];
+		RTW_PRINT_SEL(sel, "mode:%s(%d)\n", acl_mode_str(acl->mode), acl->mode);
+		RTW_PRINT_SEL(sel, "num:%d/%d\n", acl->num, NUM_ACL);
+		for (i = 0; i < NUM_ACL; i++) {
+			if (acl->aclnode[i].valid == _FALSE)
+				continue;
+			RTW_PRINT_SEL(sel, MAC_FMT"\n", MAC_ARG(acl->aclnode[i].addr));
+		}
+		RTW_PRINT_SEL(sel, "\n");
 	}
 }
 #endif /* CONFIG_RTW_MACADDR_ACL */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_tdls.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_tdls.c
index 8a5e0d34c7e1..009ffbd6e52e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_tdls.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_tdls.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -95,7 +96,7 @@ void rtw_free_tdls_info(struct tdls_info *ptdlsinfo)
 
 }
 
-void rtw_free_all_tdls_sta(_adapter *padapter, u8 from_cmd_thread)
+void rtw_free_all_tdls_sta(_adapter *padapter, u8 enqueue_cmd)
 {
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
@@ -103,11 +104,10 @@ void rtw_free_all_tdls_sta(_adapter *padapter, u8 from_cmd_thread)
 	_list	*plist, *phead;
 	s32	index;
 	struct sta_info *psta = NULL;
-	u8 tdls_sta[NUM_STA][ETH_ALEN];
+	struct sta_info *ptdls_sta[NUM_STA];
 	u8 empty_hwaddr[ETH_ALEN] = { 0x00 };
-	struct submit_ctx sctx;
 
-	_rtw_memset(tdls_sta, 0x00, sizeof(tdls_sta));
+	_rtw_memset(ptdls_sta, 0x00, sizeof(ptdls_sta));
 
 	_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 	for (index = 0; index < NUM_STA; index++) {
@@ -120,32 +120,31 @@ void rtw_free_all_tdls_sta(_adapter *padapter, u8 from_cmd_thread)
 			plist = get_next(plist);
 
 			if (psta->tdls_sta_state != TDLS_STATE_NONE)
-				_rtw_memcpy(tdls_sta[index], psta->cmn.mac_addr, ETH_ALEN);
+				ptdls_sta[index] = psta;
 		}
 	}
 	_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
 	for (index = 0; index < NUM_STA; index++) {
-		if (!_rtw_memcmp(tdls_sta[index], empty_hwaddr, ETH_ALEN)) {
-			RTW_INFO("issue tear down to "MAC_FMT" by from_cmd_thread = %d\n", MAC_ARG(tdls_sta[index]), from_cmd_thread);
+		if (ptdls_sta[index]) {
+			struct TDLSoption_param tdls_param;
 
-			if (from_cmd_thread == _TRUE) {
-				struct TDLSoption_param tdls_param;
+			psta = ptdls_sta[index];
 
-				_rtw_memcpy(&(tdls_param.addr), tdls_sta[index], ETH_ALEN);
+			RTW_INFO("Do tear down to "MAC_FMT" by enqueue_cmd = %d\n", MAC_ARG(psta->cmn.mac_addr), enqueue_cmd);
 
-				tdls_param.option = TDLS_TEARDOWN_STA;
-				tdls_hdl(padapter, (unsigned char *)&(tdls_param));
+			_rtw_memcpy(&(tdls_param.addr), psta->cmn.mac_addr, ETH_ALEN);
+			tdls_param.option = TDLS_TEARDOWN_STA_NO_WAIT;
+			tdls_hdl(padapter, (unsigned char *)&(tdls_param));
+
+			rtw_tdls_teardown_pre_hdl(padapter, psta);
 
-				tdls_param.option = TDLS_TEARDOWN_STA_LOCALLY;
+			if (enqueue_cmd == _TRUE)
+				rtw_tdls_cmd(padapter, psta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+			else
+			 {
+				tdls_param.option = TDLS_TEARDOWN_STA_LOCALLY_POST;
 				tdls_hdl(padapter, (unsigned char *)&(tdls_param));
-			} else {
-				if (rtw_tdls_cmd(padapter, tdls_sta[index], TDLS_TEARDOWN_STA) == _SUCCESS) {
-					ptdlsinfo->tdls_sctx = &sctx;
-					rtw_sctx_init(ptdlsinfo->tdls_sctx, 1000);
-					rtw_sctx_wait(ptdlsinfo->tdls_sctx, __func__);
-					ptdlsinfo->tdls_sctx = NULL;
-				}
 			}
 		}
 	}
@@ -206,12 +205,12 @@ void rtw_enable_tdls_func(_adapter *padapter)
 	rtw_set_tdls_enable(padapter, _TRUE);
 }
 
-void rtw_disable_tdls_func(_adapter *padapter, u8 from_cmd_thread)
+void rtw_disable_tdls_func(_adapter *padapter, u8 enqueue_cmd)
 {
 	if (rtw_is_tdls_enabled(padapter) == _FALSE)
 		return;
 
-	rtw_free_all_tdls_sta(padapter, from_cmd_thread);
+	rtw_free_all_tdls_sta(padapter, enqueue_cmd);
 	rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
 	rtw_reset_tdls_info(padapter);
 
@@ -256,6 +255,9 @@ u8 rtw_tdls_is_setup_allowed(_adapter *padapter)
 {
 	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
 
+	if (is_client_associated_to_ap(padapter) == _FALSE)
+		return _FALSE;
+
 	if (ptdlsinfo->ap_prohibited == _TRUE)
 		return _FALSE;
 
@@ -408,37 +410,6 @@ exit:
 	return ret;
 }
 
-void free_tdls_sta(_adapter *padapter, struct sta_info *ptdls_sta)
-{
-	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	_irqL irqL;
-
-	/* free peer sta_info */
-	_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-	if (ptdlsinfo->sta_cnt != 0)
-		ptdlsinfo->sta_cnt--;
-	_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
-	/* -2: AP + BC/MC sta, -4: default key */
-	if (ptdlsinfo->sta_cnt < MAX_ALLOWED_TDLS_STA_NUM) {
-		ptdlsinfo->sta_maximum = _FALSE;
-		_rtw_memset(&ptdlsinfo->ss_record, 0x00, sizeof(struct tdls_ss_record));
-	}
-
-	/* clear cam */
-	rtw_clearstakey_cmd(padapter, ptdls_sta, _TRUE);
-
-	if (ptdlsinfo->sta_cnt == 0) {
-		rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
-		rtw_tdls_set_link_established(padapter, _FALSE);
-	} else
-		RTW_INFO("Remain tdls sta:%02x\n", ptdlsinfo->sta_cnt);
-
-	rtw_free_stainfo(padapter,  ptdls_sta);
-
-}
-
-
 /* TDLS encryption(if needed) will always be CCMP */
 void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta)
 {
@@ -469,7 +440,7 @@ void rtw_tdls_process_ht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8
 	}
 
 	if (ptdls_sta->flags & WLAN_STA_HT) {
-		if (padapter->registrypriv.ht_enable == _TRUE) {
+		if (padapter->registrypriv.ht_enable == _TRUE && is_supported_ht(padapter->registrypriv.wireless_mode) ) {
 			ptdls_sta->htpriv.ht_option = _TRUE;
 			ptdls_sta->qos_option = _TRUE;
 		} else {
@@ -589,7 +560,7 @@ void rtw_tdls_process_vht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8
 
 	if (ptdls_sta->flags & WLAN_STA_VHT) {
 		if (REGSTY_IS_11AC_ENABLE(&padapter->registrypriv)
-		    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+		    && is_supported_vht(padapter->registrypriv.wireless_mode)
 		    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent)))
 			ptdls_sta->vhtpriv.vht_option = _TRUE;
 		else
@@ -912,15 +883,19 @@ u8 *rtw_tdls_set_sup_reg_class(u8 *pframe, struct pkt_attrib *pattrib)
 	return rtw_set_ie(pframe, _SRC_IE_ , sizeof(TDLS_SRC), TDLS_SRC, &(pattrib->pktlen));
 }
 
-u8 *rtw_tdls_set_linkid(u8 *pframe, struct pkt_attrib *pattrib, u8 init)
+u8 *rtw_tdls_set_linkid(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 init)
 {
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
 	u8 link_id_addr[18] = {0};
+
+	_rtw_memcpy(link_id_addr, get_my_bssid(&(pmlmeinfo->network)), 6);
+
 	if (init == _TRUE) {
-		_rtw_memcpy(link_id_addr, pattrib->ra, 6);
 		_rtw_memcpy((link_id_addr + 6), pattrib->src, 6);
 		_rtw_memcpy((link_id_addr + 12), pattrib->dst, 6);
 	} else {
-		_rtw_memcpy(link_id_addr, pattrib->ra, 6);
 		_rtw_memcpy((link_id_addr + 6), pattrib->dst, 6);
 		_rtw_memcpy((link_id_addr + 12), pattrib->src, 6);
 	}
@@ -953,6 +928,20 @@ u8 *rtw_tdls_set_ch_sw(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *
 
 void rtw_tdls_set_ch_sw_oper_control(_adapter *padapter, u8 enable)
 {
+	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
+
+	if (enable == _TRUE) {
+#ifdef CONFIG_TDLS_CH_SW_V2
+		pHalData->ch_switch_offload = _TRUE;
+#endif
+
+#ifdef CONFIG_TDLS_CH_SW_BY_DRV
+		pHalData->ch_switch_offload = _FALSE;
+#endif
+	}
+	else
+		pHalData->ch_switch_offload = _FALSE;
+	
 	if (ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on) != enable)
 		ATOMIC_SET(&padapter->tdlsinfo.chsw_info.chsw_on, enable);
 
@@ -1005,8 +994,8 @@ s32 rtw_tdls_do_ch_sw(_adapter *padapter, struct sta_info *ptdls_sta, u8 chnl_ty
 
 	/* set mac_id sleep before channel switch */
 	rtw_hal_macid_sleep(padapter, ptdls_sta->cmn.mac_id);
-	
-#ifdef CONFIG_TDLS_CH_SW_BY_DRV
+
+#if defined(CONFIG_TDLS_CH_SW_BY_DRV) || defined(CONFIG_TDLS_CH_SW_V2)
 	set_channel_bwmode(padapter, channel, channel_offset, bwmode);
 	ret = _SUCCESS;
 #else
@@ -1254,6 +1243,7 @@ int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wa
 			rtw_free_xmitframe(pxmitpriv, pmgntframe);
 			goto exit;
 		}
+		ptdlsinfo->sta_cnt++;
 	}
 
 	ptxmgmt->action_code = TDLS_SETUP_REQUEST;
@@ -1269,9 +1259,6 @@ int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wa
 
 	update_tdls_attrib(padapter, pattrib);
 
-	if (!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
-		ptdlsinfo->sta_cnt++;
-
 	if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
 		ptdlsinfo->sta_maximum  = _TRUE;
 
@@ -1302,25 +1289,19 @@ exit:
 	return ret;
 }
 
-int _issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)
+int _issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta, u8 wait_ack)
 {
 	struct xmit_frame			*pmgntframe;
 	struct pkt_attrib			*pattrib;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info	*ptdls_sta = NULL;
 	_irqL irqL;
 	int ret = _FAIL;
 
 	RTW_INFO("[TDLS] %s\n", __FUNCTION__);
 
 	ptxmgmt->action_code = TDLS_TEARDOWN;
-	ptdls_sta = rtw_get_stainfo(pstapriv, ptxmgmt->peer);
-	if (ptdls_sta == NULL) {
-		RTW_INFO("Np tdls_sta for tearing down\n");
-		goto exit;
-	}
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
 	if (pmgntframe == NULL)
@@ -1371,18 +1352,28 @@ exit:
 
 int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)
 {
+	struct sta_info *ptdls_sta = NULL;
 	int ret = _FAIL;
 
-	ret = _issue_tdls_teardown(padapter, ptxmgmt, wait_ack);
+	ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), ptxmgmt->peer);
+	if (ptdls_sta == NULL) {
+		RTW_INFO("No tdls_sta for tearing down\n");
+		goto exit;
+	}
+
+	ret = _issue_tdls_teardown(padapter, ptxmgmt, ptdls_sta, wait_ack);
 	if ((ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_) && (ret == _FAIL)) {
 		/* Change status code and send teardown again via AP */
 		ptxmgmt->status_code = _RSON_TDLS_TEAR_TOOFAR_;
-		ret = _issue_tdls_teardown(padapter, ptxmgmt, wait_ack);
+		ret = _issue_tdls_teardown(padapter, ptxmgmt, ptdls_sta, wait_ack);
 	}
 
-	if (rtw_tdls_is_driver_setup(padapter))
-		rtw_tdls_cmd(padapter, ptxmgmt->peer, TDLS_TEARDOWN_STA_LOCALLY);
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptxmgmt->peer, TDLS_TEARDOWN_STA_LOCALLY_POST);
+	}
 
+exit:
 	return ret;
 }
 
@@ -1875,8 +1866,13 @@ sint On_TDLS_Setup_Req(_adapter *padapter, union recv_frame *precv_frame, struct
 			 - ETH_TYPE_LEN
 			 - PAYLOAD_TYPE_LEN;
 
-	if (ptdls_sta == NULL)
+	if (ptdls_sta == NULL) {
 		ptdls_sta = rtw_alloc_stainfo(pstapriv, psa);
+		if (ptdls_sta == NULL)
+			goto exit;
+		
+		ptdlsinfo->sta_cnt++;
+	}
 	else {
 		if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
 			/* If the direct link is already set up */
@@ -2014,8 +2010,6 @@ sint On_TDLS_Setup_Req(_adapter *padapter, union recv_frame *precv_frame, struct
 		ptdls_sta->bssratelen = supportRateNum;
 		_rtw_memcpy(ptdls_sta->bssrateset, supportRate, supportRateNum);
 
-		if (!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
-			ptdlsinfo->sta_cnt++;
 		/* -2: AP + BC/MC sta, -4: default key */
 		if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
 			ptdlsinfo->sta_maximum = _TRUE;
@@ -2034,8 +2028,10 @@ sint On_TDLS_Setup_Req(_adapter *padapter, union recv_frame *precv_frame, struct
 
 		if (txmgmt.status_code == _STATS_SUCCESSFUL_)
 			_set_timer(&ptdls_sta->handshake_timer, TDLS_HANDSHAKE_TIME);
-		else
-			free_tdls_sta(padapter, ptdls_sta);
+		else {
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+		}
 	}
 
 exit:
@@ -2082,7 +2078,8 @@ int On_TDLS_Setup_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct
 
 	if (status_code != 0) {
 		RTW_INFO("[TDLS] %s status_code = %d, free_tdls_sta\n", __FUNCTION__, status_code);
-		free_tdls_sta(padapter, ptdls_sta);
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
 		ret = _FAIL;
 		goto exit;
 	}
@@ -2180,7 +2177,8 @@ int On_TDLS_Setup_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct
 				wpa_tdls_generate_tpk(padapter, ptdls_sta);
 				if (tdls_verify_mic(ptdls_sta->tpk.kck, 2, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL) {
 					RTW_INFO("[TDLS] %s tdls_verify_mic fail, free_tdls_sta\n", __FUNCTION__);
-					free_tdls_sta(padapter, ptdls_sta);
+					rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+					rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
 					ret = _FAIL;
 					goto exit;
 				}
@@ -2251,7 +2249,8 @@ int On_TDLS_Setup_Cfm(_adapter *padapter, union recv_frame *precv_frame, struct
 
 	if (status_code != 0) {
 		RTW_INFO("[%s] status_code = %d\n, free_tdls_sta", __FUNCTION__, status_code);
-		free_tdls_sta(padapter, ptdls_sta);
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
 		ret = _FAIL;
 		goto exit;
 	}
@@ -2304,7 +2303,8 @@ int On_TDLS_Setup_Cfm(_adapter *padapter, union recv_frame *precv_frame, struct
 		/* Verify mic in FTIE MIC field */
 		if (rtw_tdls_is_driver_setup(padapter) &&
 		    (tdls_verify_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL)) {
-			free_tdls_sta(padapter, ptdls_sta);
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
 			ret = _FAIL;
 			goto exit;
 		}
@@ -2375,7 +2375,7 @@ int On_TDLS_Dis_Req(_adapter *padapter, union recv_frame *precv_frame)
 			if (psta_ap == NULL)
 				goto exit;
 			dst = pIE->data + 12;
-			if (MacAddr_isBcst(dst) == _FALSE && (_rtw_memcmp(adapter_mac_addr(padapter), dst, 6) == _FALSE))
+			if (MacAddr_isBcst(dst) == _FALSE && (_rtw_memcmp(adapter_mac_addr(padapter), dst, ETH_ALEN) == _FALSE))
 				goto exit;
 			break;
 		default:
@@ -2406,8 +2406,10 @@ int On_TDLS_Teardown(_adapter *padapter, union recv_frame *precv_frame, struct s
 	reason = *(ptr + prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN + 2);
 	RTW_INFO("[TDLS] %s Reason code(%d)\n", __FUNCTION__, reason);
 
-	if (rtw_tdls_is_driver_setup(padapter))
-		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY);
+	if (rtw_tdls_is_driver_setup(padapter)) {
+		rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+		rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
+	}
 
 	return _SUCCESS;
 
@@ -2844,7 +2846,7 @@ void rtw_build_tdls_setup_req_ies(_adapter *padapter, struct xmit_frame *pxmitfr
 
 	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
 
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 
 	if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
 		pframe = rtw_tdls_set_qos_cap(pframe, pattrib);
@@ -2852,7 +2854,7 @@ void rtw_build_tdls_setup_req_ies(_adapter *padapter, struct xmit_frame *pxmitfr
 #ifdef CONFIG_80211AC_VHT
 	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
 	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
-	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	    && is_supported_vht(pregistrypriv->wireless_mode)
 	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
 	   ) {
 		pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
@@ -2935,7 +2937,7 @@ void rtw_build_tdls_setup_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitfr
 	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
 
 	plinkid_ie = pframe;
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
 
 	/* Fill FTIE mic */
 	if (pattrib->encrypt && rtw_tdls_is_driver_setup(padapter) == _TRUE)
@@ -2947,7 +2949,7 @@ void rtw_build_tdls_setup_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitfr
 #ifdef CONFIG_80211AC_VHT
 	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
 	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
-	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	    && is_supported_vht(pregistrypriv->wireless_mode)
 	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
 	   ) {
 		pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
@@ -3012,7 +3014,7 @@ void rtw_build_tdls_setup_cfm_ies(_adapter *padapter, struct xmit_frame *pxmitfr
 	/* HT operation; todo */
 
 	plinkid_ie = pframe;
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 
 	if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
 		wpa_tdls_ftie_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie, pftie_mic);
@@ -3024,7 +3026,7 @@ void rtw_build_tdls_setup_cfm_ies(_adapter *padapter, struct xmit_frame *pxmitfr
 	if ((padapter->mlmepriv.htpriv.ht_option == _TRUE)
 	    && (ptdls_sta->vhtpriv.vht_option == _TRUE) && (pmlmeext->cur_channel > 14)
 	    && REGSTY_IS_11AC_ENABLE(pregistrypriv)
-	    && hal_chk_proto_cap(padapter, PROTO_CAP_11AC)
+	    && is_supported_vht(pregistrypriv->wireless_mode)
 	    && (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
 	   ) {
 		pframe = rtw_tdls_set_vht_operation(padapter, pframe, pattrib, pmlmeext->cur_channel);
@@ -3055,9 +3057,9 @@ void rtw_build_tdls_teardown_ies(_adapter *padapter, struct xmit_frame *pxmitfra
 
 	plinkid_ie = pframe;
 	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
 	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 
 	if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
 		wpa_tdls_teardown_ftie_mic(ptdls_sta->tpk.kck, plinkid_ie, ptxmgmt->status_code, 1, 4, pftie, pftie_mic);
@@ -3071,7 +3073,7 @@ void rtw_build_tdls_dis_req_ies(_adapter *padapter, struct xmit_frame *pxmitfram
 	pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
 	pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
 	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 
 }
 
@@ -3110,7 +3112,7 @@ void rtw_build_tdls_dis_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitfram
 #endif
 
 	pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
-	pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
+	pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
 
 }
 
@@ -3127,9 +3129,9 @@ void rtw_build_tdls_peer_traffic_indication_ies(_adapter *padapter, struct xmit_
 	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
 
 	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
 	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 
 	/* PTI control */
 	/* PU buffer status */
@@ -3156,9 +3158,9 @@ void rtw_build_tdls_peer_traffic_rsp_ies(_adapter *padapter, struct xmit_frame *
 	pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
 
 	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
 	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 }
 
 #ifdef CONFIG_TDLS_CH_SW
@@ -3190,9 +3192,9 @@ void rtw_build_tdls_ch_switch_req_ies(_adapter *padapter, struct xmit_frame *pxm
 	}
 
 	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
 	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 
 	pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
 
@@ -3210,9 +3212,9 @@ void rtw_build_tdls_ch_switch_rsp_ies(_adapter *padapter, struct xmit_frame *pxm
 	pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
 
 	if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _FALSE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
 	else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
-		pframe = rtw_tdls_set_linkid(pframe, pattrib, _TRUE);
+		pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
 
 	pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
 }
@@ -3383,7 +3385,7 @@ void _tdls_pti_timer_hdl(void *FunctionContext)
 		if (ptdls_sta->tdls_sta_state & TDLS_WAIT_PTR_STATE) {
 			RTW_INFO("[TDLS] Doesn't receive PTR from peer dev:"MAC_FMT"; "
 				"Send TDLS Tear Down\n", MAC_ARG(ptdls_sta->cmn.mac_addr));
-			issue_tdls_teardown(padapter, &txmgmt, _FALSE);
+			rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA);
 		}
 	}
 }
@@ -3402,7 +3404,7 @@ void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta)
 	rtw_init_timer(&psta->pti_timer, padapter, _tdls_pti_timer_hdl, psta);
 }
 
-void rtw_free_tdls_timer(struct sta_info *psta)
+void rtw_cancel_tdls_timer(struct sta_info *psta)
 {
 	_cancel_timer_ex(&psta->TPK_timer);
 #ifdef CONFIG_TDLS_CH_SW
@@ -3415,6 +3417,54 @@ void rtw_free_tdls_timer(struct sta_info *psta)
 	_cancel_timer_ex(&psta->pti_timer);
 }
 
+void rtw_tdls_teardown_pre_hdl(_adapter *padapter, struct sta_info *psta)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	_irqL irqL;
+
+	rtw_cancel_tdls_timer(psta);
+
+	_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
+	if (ptdlsinfo->sta_cnt != 0)
+		ptdlsinfo->sta_cnt--;
+	_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
+
+	if (ptdlsinfo->sta_cnt < MAX_ALLOWED_TDLS_STA_NUM) {
+		ptdlsinfo->sta_maximum = _FALSE;
+		_rtw_memset(&ptdlsinfo->ss_record, 0x00, sizeof(struct tdls_ss_record));
+	}
+
+	if (ptdlsinfo->sta_cnt == 0)
+		rtw_tdls_set_link_established(padapter, _FALSE);
+	else
+		RTW_INFO("Remain tdls sta:%02x\n", ptdlsinfo->sta_cnt);
+}
+
+void rtw_tdls_teardown_post_hdl(_adapter *padapter, struct sta_info *psta, u8 enqueue_cmd)
+{
+	struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
+
+	/* Clear cam */
+	rtw_clearstakey_cmd(padapter, psta, enqueue_cmd);
+
+	/* Update sta media status */
+	if (enqueue_cmd)
+		rtw_sta_media_status_rpt_cmd(padapter, psta, 0);
+	else
+		rtw_sta_media_status_rpt(padapter, psta, 0);
+
+	/* Set RCR if necessary */
+	if (ptdlsinfo->sta_cnt == 0) {
+		if (enqueue_cmd)
+			rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
+		else
+			rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_NOLINK);
+	}
+
+	/* Free tdls sta info */
+	rtw_free_stainfo(padapter,  psta);
+}
 
 int rtw_tdls_is_driver_setup(_adapter *padapter)
 {
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_vht.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_vht.c
index 372042e005c9..2896cdd89315 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_vht.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_vht.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -18,6 +19,93 @@
 #include <hal_data.h>
 
 #ifdef CONFIG_80211AC_VHT
+const u16 _vht_max_mpdu_len[] = {
+	3895,
+	7991,
+	11454,
+	0,
+};
+
+const u8 _vht_sup_ch_width_set_to_bw_cap[] = {
+	BW_CAP_80M,
+	BW_CAP_80M | BW_CAP_160M,
+	BW_CAP_80M | BW_CAP_160M | BW_CAP_80_80M,
+	0,
+};
+
+const char *const _vht_sup_ch_width_set_str[] = {
+	"80MHz",
+	"160MHz",
+	"160MHz & 80+80MHz",
+	"BW-RSVD",
+};
+
+void dump_vht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len)
+{
+	if (buf_len != VHT_CAP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid VHT capability IE len:%d != %d\n", buf_len, VHT_CAP_IE_LEN);
+		return;
+	}
+
+	RTW_PRINT_SEL(sel, "cap_info:%02x %02x %02x %02x: MAX_MPDU_LEN:%u %s%s%s%s%s RX-STBC:%u MAX_AMPDU_LEN:%u\n"
+		, *(buf), *(buf + 1), *(buf + 2), *(buf + 3)
+		, vht_max_mpdu_len(GET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(buf))
+		, vht_sup_ch_width_set_str(GET_VHT_CAPABILITY_ELE_CHL_WIDTH(buf))
+		, GET_VHT_CAPABILITY_ELE_RX_LDPC(buf) ? " RX-LDPC" : ""
+		, GET_VHT_CAPABILITY_ELE_SHORT_GI80M(buf) ? " SGI-80" : ""
+		, GET_VHT_CAPABILITY_ELE_SHORT_GI160M(buf) ? " SGI-160" : ""
+		, GET_VHT_CAPABILITY_ELE_TX_STBC(buf) ? " TX-STBC" : ""
+		, GET_VHT_CAPABILITY_ELE_RX_STBC(buf)
+		, VHT_MAX_AMPDU_LEN(GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(buf))
+	);
+}
+
+void dump_vht_cap_ie(void *sel, const u8 *ie, u32 ie_len)
+{
+	const u8 *vht_cap_ie;
+	sint vht_cap_ielen;
+
+	vht_cap_ie = rtw_get_ie(ie, WLAN_EID_VHT_CAPABILITY, &vht_cap_ielen, ie_len);
+	if (!ie || vht_cap_ie != ie)
+		return;
+
+	dump_vht_cap_ie_content(sel, vht_cap_ie + 2, vht_cap_ielen);
+}
+
+const char *const _vht_op_ch_width_str[] = {
+	"20 or 40MHz",
+	"80MHz",
+	"160MHz",
+	"80+80MHz",
+	"BW-RSVD",
+};
+
+void dump_vht_op_ie_content(void *sel, const u8 *buf, u32 buf_len)
+{
+	if (buf_len != VHT_OP_IE_LEN) {
+		RTW_PRINT_SEL(sel, "Invalid VHT operation IE len:%d != %d\n", buf_len, VHT_OP_IE_LEN);
+		return;
+	}
+
+	RTW_PRINT_SEL(sel, "%s, ch0:%u, ch1:%u\n"
+		, vht_op_ch_width_str(GET_VHT_OPERATION_ELE_CHL_WIDTH(buf))
+		, GET_VHT_OPERATION_ELE_CENTER_FREQ1(buf)
+		, GET_VHT_OPERATION_ELE_CENTER_FREQ2(buf)
+	);
+}
+
+void dump_vht_op_ie(void *sel, const u8 *ie, u32 ie_len)
+{
+	const u8 *vht_op_ie;
+	sint vht_op_ielen;
+
+	vht_op_ie = rtw_get_ie(ie, WLAN_EID_VHT_OPERATION, &vht_op_ielen, ie_len);
+	if (!ie || vht_op_ie != ie)
+		return;
+
+	dump_vht_op_ie_content(sel, vht_op_ie + 2, vht_op_ielen);
+}
+
 /*				20/40/80,	ShortGI,	MCS Rate  */
 const u16 VHT_MCS_DATA_RATE[3][2][30] = {
 	{	{
@@ -178,43 +266,53 @@ void	rtw_vht_use_default_setting(_adapter *padapter)
 	/* Beamforming setting */
 	CLEAR_FLAGS(pvhtpriv->beamform_cap);
 #ifdef CONFIG_BEAMFORMING
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&bHwSupportBeamformer);
-	rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&bHwSupportBeamformee);
-	mu_bfer = _FALSE;
-	mu_bfee = _FALSE;
-	rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMER, &mu_bfer);
-	rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMEE, &mu_bfee);
-	if (TEST_FLAG(pregistrypriv->beamform_cap, BIT0) && bHwSupportBeamformer) {
+#ifdef RTW_BEAMFORMING_VERSION_2
+	/* only enable beamforming in STA client mode */
+	if (MLME_IS_STA(padapter) && !MLME_IS_GC(padapter)
+				  && !MLME_IS_ADHOC(padapter)
+				  && !MLME_IS_MESH(padapter))
+#endif
+	{
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER,
+			(u8 *)&bHwSupportBeamformer);
+		rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE,
+			(u8 *)&bHwSupportBeamformee);
+		mu_bfer = _FALSE;
+		mu_bfee = _FALSE;
+		rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMER, &mu_bfer);
+		rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMEE, &mu_bfee);
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT0) && bHwSupportBeamformer) {
 #ifdef CONFIG_CONCURRENT_MODE
-		if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+			if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+				SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
+				RTW_INFO("[VHT] CONCURRENT AP Support Beamformer\n");
+				if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(2))
+				    && (_TRUE == mu_bfer)) {
+					SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
+					RTW_INFO("[VHT] Support MU-MIMO AP\n");
+				}
+			} else
+				RTW_INFO("[VHT] CONCURRENT not AP ;not allow  Support Beamformer\n");
+#else
 			SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
-			RTW_INFO("[VHT] CONCURRENT AP Support Beamformer\n");
+			RTW_INFO("[VHT] Support Beamformer\n");
 			if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(2))
-			    && (_TRUE == mu_bfer)) {
+			    && (_TRUE == mu_bfer)
+			    && ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
 				SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
 				RTW_INFO("[VHT] Support MU-MIMO AP\n");
 			}
-		} else
-			RTW_INFO("[VHT] CONCURRENT not AP ;not allow  Support Beamformer\n");
-#else
-		SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
-		RTW_INFO("[VHT] Support Beamformer\n");
-		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(2))
-		    && (_TRUE == mu_bfer)
-		    && ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
-			SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
-			RTW_INFO("[VHT] Support MU-MIMO AP\n");
-		}
 #endif
-	}
-	if (TEST_FLAG(pregistrypriv->beamform_cap, BIT1) && bHwSupportBeamformee) {
-		SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
-		RTW_INFO("[VHT] Support Beamformee\n");
-		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(3))
-		    && (_TRUE == mu_bfee)
-		    && ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)) {
-			SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
-			RTW_INFO("[VHT] Support MU-MIMO STA\n");
+		}
+		if (TEST_FLAG(pregistrypriv->beamform_cap, BIT1) && bHwSupportBeamformee) {
+			SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
+			RTW_INFO("[VHT] Support Beamformee\n");
+			if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(3))
+			    && (_TRUE == mu_bfee)
+			    && ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)) {
+				SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
+				RTW_INFO("[VHT] Support MU-MIMO STA\n");
+			}
 		}
 	}
 #endif /* CONFIG_BEAMFORMING */
@@ -300,16 +398,34 @@ void	update_sta_vht_info_apmode(_adapter *padapter, PVOID sta)
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct vht_priv	*pvhtpriv_ap = &pmlmepriv->vhtpriv;
 	struct vht_priv	*pvhtpriv_sta = &psta->vhtpriv;
-	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0, bw_mode = 0;
+	u8	cur_ldpc_cap = 0, cur_stbc_cap = 0;
+	s8 bw_mode = -1;
 	u8	*pcap_mcs;
 
 	if (pvhtpriv_sta->vht_option == _FALSE)
 		return;
 
-	bw_mode = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(&pvhtpriv_sta->vht_op_mode_notify);
+	if (pvhtpriv_sta->op_present) {
+		switch (GET_VHT_OPERATION_ELE_CHL_WIDTH(pvhtpriv_sta->vht_op)) {
+		case 1: /* 80MHz */
+		case 2: /* 160MHz */
+		case 3: /* 80+80 */
+			bw_mode = CHANNEL_WIDTH_80; /* only support up to 80MHz for now */
+			break;
+		}
+	}
+
+	if (pvhtpriv_sta->notify_present)
+		bw_mode = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(&pvhtpriv_sta->vht_op_mode_notify);
+	else if (MLME_IS_AP(padapter)) {
+		/* for VHT client without Operating Mode Notify IE; minimal 80MHz */
+		if (bw_mode < CHANNEL_WIDTH_80)
+			bw_mode = CHANNEL_WIDTH_80;
+	}
+
+	if (bw_mode != -1)
+		psta->cmn.bw_mode = bw_mode; /* update bw_mode only if get value from VHT IEs */
 
-	/* if (bw_mode > psta->cmn.bw_mode) */
-	psta->cmn.bw_mode = bw_mode;
 	psta->cmn.ra_info.is_vht_enable = _TRUE;
 
 	/* B4 Rx LDPC */
@@ -367,6 +483,83 @@ void	update_hw_vht_param(_adapter *padapter)
 		rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&pvhtpriv->ampdu_len));
 }
 
+#ifdef ROKU_PRIVATE
+u8 VHT_get_ss_from_map(u8 *vht_mcs_map)
+{
+	u8 i, j;
+	u8 ss = 0;
+
+	for (i = 0; i < 2; i++) {
+		if (vht_mcs_map[i] != 0xff) {
+			for (j = 0; j < 8; j += 2) {
+				if (((vht_mcs_map[i] >> j) & 0x03) == 0x03)
+					break;
+				ss++;
+			}
+		}
+
+	}
+
+return ss;
+}
+
+void VHT_caps_handler_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
+{
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct vht_priv_infra_ap	*pvhtpriv = &pmlmepriv->vhtpriv_infra_ap;
+	u8      cur_stbc_cap_infra_ap = 0;
+	u16	cur_beamform_cap_infra_ap = 0;
+	u8	*pcap_mcs;
+	u8	*pcap_mcs_tx;
+	u8	Rx_ss = 0, Tx_ss = 0;
+
+	struct mlme_ext_priv		*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info		*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (pIE == NULL)
+		return;
+
+	pmlmeinfo->ht_vht_received |= BIT(1);
+
+	pvhtpriv->ldpc_cap_infra_ap = GET_VHT_CAPABILITY_ELE_RX_LDPC(pIE->data);
+
+	if (GET_VHT_CAPABILITY_ELE_RX_STBC(pIE->data))
+		SET_FLAG(cur_stbc_cap_infra_ap, STBC_VHT_ENABLE_RX);
+	if (GET_VHT_CAPABILITY_ELE_TX_STBC(pIE->data))
+		SET_FLAG(cur_stbc_cap_infra_ap, STBC_VHT_ENABLE_TX);
+	pvhtpriv->stbc_cap_infra_ap = cur_stbc_cap_infra_ap;
+
+	/*store ap info for channel bandwidth*/
+	pvhtpriv->channel_width_infra_ap = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(pIE->data);
+
+	/*check B11: SU Beamformer Capable and B12: SU Beamformee B19: MU Beamformer B20:MU Beamformee*/
+	if (GET_VHT_CAPABILITY_ELE_SU_BFER(pIE->data))
+		SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
+	if (GET_VHT_CAPABILITY_ELE_SU_BFEE(pIE->data))
+		SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
+	if (GET_VHT_CAPABILITY_ELE_MU_BFER(pIE->data))
+		SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
+	if (GET_VHT_CAPABILITY_ELE_MU_BFEE(pIE->data))
+		SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
+	pvhtpriv->beamform_cap_infra_ap = cur_beamform_cap_infra_ap;
+
+	/*store information about vht_mcs_set*/
+	pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pIE->data);
+	pcap_mcs_tx = GET_VHT_CAPABILITY_ELE_TX_MCS(pIE->data);
+	_rtw_memcpy(pvhtpriv->vht_mcs_map_infra_ap, pcap_mcs, 2);
+	_rtw_memcpy(pvhtpriv->vht_mcs_map_tx_infra_ap, pcap_mcs_tx, 2);
+
+	Rx_ss = VHT_get_ss_from_map(pvhtpriv->vht_mcs_map_infra_ap);
+	Tx_ss = VHT_get_ss_from_map(pvhtpriv->vht_mcs_map_tx_infra_ap);
+	if (Rx_ss >= Tx_ss) {
+		pvhtpriv->number_of_streams_infra_ap = Rx_ss;
+	} else{
+		pvhtpriv->number_of_streams_infra_ap = Tx_ss;
+	}
+
+}
+#endif /* ROKU_PRIVATE */
+
 void VHT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 {
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
@@ -498,17 +691,21 @@ void rtw_process_vht_op_mode_notify(_adapter *padapter, u8 *pframe, PVOID sta)
 	struct sta_info		*psta = (struct sta_info *)sta;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv		*pvhtpriv = &pmlmepriv->vhtpriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct registry_priv *regsty = adapter_to_regsty(padapter);
 	u8	target_bw;
 	u8	target_rxss, current_rxss;
 	u8	update_ra = _FALSE;
+	u8 tx_nss = 0, rf_type = RF_1T1R;
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
 
 	if (pvhtpriv->vht_option == _FALSE)
 		return;
 
 	target_bw = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(pframe);
-	target_rxss = (GET_VHT_OPERATING_MODE_FIELD_RX_NSS(pframe) + 1);
+
+	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
+	tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
+	target_rxss = rtw_min(tx_nss, (GET_VHT_OPERATING_MODE_FIELD_RX_NSS(pframe) + 1));
 
 	if (target_bw != psta->cmn.bw_mode) {
 		if (hal_is_bw_support(padapter, target_bw)
@@ -597,7 +794,7 @@ u32	rtw_build_vht_op_mode_notify_ie(_adapter *padapter, u8 *pbuf, u8 bw)
 
 u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
 {
-	u8	bw, rf_type, rf_num, rx_stbc_nss = 0;
+	u8	bw, rf_num, rx_stbc_nss = 0;
 	u16	HighestRate;
 	u8	*pcap, *pcap_mcs;
 	u32	len = 0;
@@ -615,19 +812,19 @@ u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
 	rtw_hal_get_def_var(padapter, HAL_DEF_RX_PACKET_OFFSET, &rx_packet_offset);
 	rtw_hal_get_def_var(padapter, HAL_DEF_MAX_RECVBUF_SZ, &max_recvbuf_sz);
 
-	RTW_DBG("%s, line%d, Available RX buf size = %d bytes\n.", __FUNCTION__, __LINE__, max_recvbuf_sz - rx_packet_offset);
+	RTW_DBG("%s, line%d, Available RX buf size = %d bytes\n", __FUNCTION__, __LINE__, max_recvbuf_sz - rx_packet_offset);
 
 	if ((max_recvbuf_sz - rx_packet_offset) >= 11454) {
 		SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 2);
-		RTW_INFO("%s, line%d, Set MAX MPDU len = 11454 bytes\n.", __FUNCTION__, __LINE__);
+		RTW_INFO("%s, line%d, Set MAX MPDU len = 11454 bytes\n", __FUNCTION__, __LINE__);
 	} else if ((max_recvbuf_sz - rx_packet_offset) >= 7991) {
 		SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 1);
-		RTW_INFO("%s, line%d, Set MAX MPDU len = 7991 bytes\n.", __FUNCTION__, __LINE__);
+		RTW_INFO("%s, line%d, Set MAX MPDU len = 7991 bytes\n", __FUNCTION__, __LINE__);
 	} else if ((max_recvbuf_sz - rx_packet_offset) >= 3895) {
 		SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 0);
-		RTW_INFO("%s, line%d, Set MAX MPDU len = 3895 bytes\n.", __FUNCTION__, __LINE__);
+		RTW_INFO("%s, line%d, Set MAX MPDU len = 3895 bytes\n", __FUNCTION__, __LINE__);
 	} else
-		RTW_ERR("%s, line%d, Error!! Available RX buf size < 3895 bytes\n.", __FUNCTION__, __LINE__);
+		RTW_ERR("%s, line%d, Error!! Available RX buf size < 3895 bytes\n", __FUNCTION__, __LINE__);
 
 	/* B2 B3 Supported Channel Width Set */
 	if (hal_chk_bw_cap(padapter, BW_CAP_160M) && REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_160)) {
@@ -688,10 +885,11 @@ u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
 		rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
 
 		/* IOT action suggested by Yu Chen 2017/3/3 */
+#ifdef CONFIG_80211AC_VHT
 		if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) &&
-			!GET_VHT_CAPABILITY_ELE_MU_BFER(&pvhtpriv->beamform_cap))
+			!pvhtpriv->ap_is_mu_bfer)
 			rf_num = (rf_num >= 2 ? 2 : rf_num);
-
+#endif
 		/* B13 14 15 Compressed Steering Number of Beamformer Antennas Supported */
 		SET_VHT_CAPABILITY_ELE_BFER_ANT_SUPP(pcap, rf_num);
 		/* B20 SU Beamformee Capable */
@@ -736,61 +934,109 @@ u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
 
 u32 rtw_restructure_vht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len)
 {
-	u32	ielen = 0, out_len = 0;
-	u8	cap_len = 0, notify_len = 0, notify_bw = 0, operation_bw = 0, supported_chnl_width = 0;
-	u8	*p, *pframe;
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	RT_CHANNEL_INFO *chset = rfctl->channel_set;
+	u32	ielen;
+	u8 max_bw;
+	u8 oper_ch, oper_bw = CHANNEL_WIDTH_20, oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	u8 *out_vht_op_ie, *ht_op_ie, *vht_cap_ie, *vht_op_ie;
 	struct registry_priv *pregistrypriv = &padapter->registrypriv;
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct vht_priv	*pvhtpriv = &pmlmepriv->vhtpriv;
 
 	rtw_vht_use_default_setting(padapter);
 
-	p = rtw_get_ie(in_ie + 12, EID_VHTCapability, &ielen, in_len - 12);
-	if (p && ielen > 0) {
-		supported_chnl_width = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p + 2);
+	ht_op_ie = rtw_get_ie(in_ie + 12, WLAN_EID_HT_OPERATION, &ielen, in_len - 12);
+	if (!ht_op_ie || ielen != HT_OP_IE_LEN)
+		goto exit;
+	vht_cap_ie = rtw_get_ie(in_ie + 12, EID_VHTCapability, &ielen, in_len - 12);
+	if (!vht_cap_ie || ielen != VHT_CAP_IE_LEN)
+		goto exit;
+	vht_op_ie = rtw_get_ie(in_ie + 12, EID_VHTOperation, &ielen, in_len - 12);
+	if (!vht_op_ie || ielen != VHT_OP_IE_LEN)
+		goto exit;
 
-		/* VHT Capabilities element */
-		cap_len = rtw_build_vht_cap_ie(padapter, out_ie + *pout_len);
-		*pout_len += cap_len;
+	/* VHT Capabilities element */
+	*pout_len += rtw_build_vht_cap_ie(padapter, out_ie + *pout_len);
 
-		/* Get HT BW */
-		p = rtw_get_ie(in_ie + 12, _HT_EXTRA_INFO_IE_, &ielen, in_len - 12);
-		if (p && ielen > 0) {
-			struct HT_info_element *pht_info = (struct HT_info_element *)(p + 2);
-			if (pht_info->infos[0] & BIT(2))
-				operation_bw = CHANNEL_WIDTH_40;
-			else
-				operation_bw = CHANNEL_WIDTH_20;
-		}
 
-		/* VHT Operation element */
-		p = rtw_get_ie(in_ie + 12, EID_VHTOperation, &ielen, in_len - 12);
-		if (p && ielen > 0) {
-			out_len = *pout_len;
-			if (GET_VHT_OPERATION_ELE_CHL_WIDTH(p + 2) >= 1) {
-				if (supported_chnl_width == 2)
-					operation_bw = CHANNEL_WIDTH_80_80;
-				else if (supported_chnl_width == 1)
-					operation_bw = CHANNEL_WIDTH_160;
-				else
-					operation_bw = CHANNEL_WIDTH_80;
+	/* VHT Operation element */
+	out_vht_op_ie = out_ie + *pout_len;
+	rtw_set_ie(out_vht_op_ie, EID_VHTOperation, VHT_OP_IE_LEN, vht_op_ie + 2 , pout_len);
+
+	/* get primary channel from HT_OP_IE */
+	oper_ch = GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2);
+
+	/* find the largest bw supported by both registry and hal */
+	max_bw = hal_largest_bw(padapter, REGSTY_BW_5G(pregistrypriv));
+
+	if (max_bw >= CHANNEL_WIDTH_40) {
+		/* get bw offset form HT_OP_IE */
+		if (GET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2)) {
+			switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2)) {
+			case SCA:
+				oper_bw = CHANNEL_WIDTH_40;
+				oper_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
+				break;
+			case SCB:
+				oper_bw = CHANNEL_WIDTH_40;
+				oper_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
+				break;
 			}
-			pframe = rtw_set_ie(out_ie + out_len, EID_VHTOperation, ielen, p + 2 , pout_len);
 		}
 
-		/* find the largest bw supported by both registry and hal */
-		notify_bw = hal_largest_bw(padapter, REGSTY_BW_5G(pregistrypriv));
-
-		if (notify_bw > operation_bw)
-			notify_bw = operation_bw;
+		if (oper_bw == CHANNEL_WIDTH_40) {
+			switch (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2)) {
+			case 1: /* 80MHz */
+			case 2: /* 160MHz */
+			case 3: /* 80+80 */
+				oper_bw = CHANNEL_WIDTH_80; /* only support up to 80MHz for now */
+				break;
+			}
 
-		/* Operating Mode Notification element */
-		notify_len = rtw_build_vht_op_mode_notify_ie(padapter, out_ie + *pout_len, notify_bw);
-		*pout_len += notify_len;
+			oper_bw = rtw_min(oper_bw, max_bw);
+
+			/* try downgrage bw to fit in channel plan setting */
+			while (!rtw_chset_is_chbw_valid(chset, oper_ch, oper_bw, oper_offset)
+				|| (IS_DFS_SLAVE_WITH_RD(rfctl)
+					&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
+					&& rtw_chset_is_chbw_non_ocp(chset, oper_ch, oper_bw, oper_offset))
+			) {
+				oper_bw--;
+				if (oper_bw == CHANNEL_WIDTH_20) {
+					oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+					break;
+				}
+			}
+		}
+	}
 
-		pvhtpriv->vht_option = _TRUE;
+	rtw_warn_on(!rtw_chset_is_chbw_valid(chset, oper_ch, oper_bw, oper_offset));
+	if (IS_DFS_SLAVE_WITH_RD(rfctl) && !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl)))
+		rtw_warn_on(rtw_chset_is_chbw_non_ocp(chset, oper_ch, oper_bw, oper_offset));
+
+	/* update VHT_OP_IE */
+	if (oper_bw < CHANNEL_WIDTH_80) {
+		SET_VHT_OPERATION_ELE_CHL_WIDTH(out_vht_op_ie + 2, 0);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(out_vht_op_ie + 2, 0);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(out_vht_op_ie + 2, 0);
+	} else if (oper_bw == CHANNEL_WIDTH_80) {
+		u8 cch = rtw_get_center_ch(oper_ch, oper_bw, oper_offset);
+
+		SET_VHT_OPERATION_ELE_CHL_WIDTH(out_vht_op_ie + 2, 1);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(out_vht_op_ie + 2, cch);
+		SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(out_vht_op_ie + 2, 0);
+	} else {
+		RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(padapter), oper_bw);
+		rtw_warn_on(1);
 	}
 
+	/* Operating Mode Notification element */
+	*pout_len += rtw_build_vht_op_mode_notify_ie(padapter, out_ie + *pout_len, oper_bw);
+
+	pvhtpriv->vht_option = _TRUE;
+
+exit:
 	return pvhtpriv->vht_option;
 
 }
@@ -849,6 +1095,8 @@ void rtw_vht_ies_attach(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
 										pnetwork->Configuration.DSConfig);
 	pnetwork->IELength += operation_len;
 
+	rtw_check_for_vht20(padapter, pnetwork->IEs + _BEACON_IE_OFFSET_, pnetwork->IELength - _BEACON_IE_OFFSET_);
+
 	pmlmepriv->vhtpriv.vht_option = _TRUE;
 }
 
@@ -863,4 +1111,26 @@ void rtw_vht_ies_detach(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
 	pmlmepriv->vhtpriv.vht_option = _FALSE;
 }
 
+void rtw_check_for_vht20(_adapter *adapter, u8 *ies, int ies_len)
+{
+	u8 ht_ch, ht_bw, ht_offset;
+	u8 vht_ch, vht_bw, vht_offset;
+
+	rtw_ies_get_chbw(ies, ies_len, &ht_ch, &ht_bw, &ht_offset, 1, 0);
+	rtw_ies_get_chbw(ies, ies_len, &vht_ch, &vht_bw, &vht_offset, 1, 1);
+
+	if (ht_bw == CHANNEL_WIDTH_20 && vht_bw >= CHANNEL_WIDTH_80) {
+		u8 *vht_op_ie;
+		int vht_op_ielen;
+
+		RTW_INFO(FUNC_ADPT_FMT" vht80 is not allowed without ht40\n", FUNC_ADPT_ARG(adapter));
+		vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
+		if (vht_op_ie && vht_op_ielen) {
+			RTW_INFO(FUNC_ADPT_FMT" switch to vht20\n", FUNC_ADPT_ARG(adapter));
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
+		}
+	}
+}
 #endif /* CONFIG_80211AC_VHT */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi.c
index d8dcefcb20ab..5380e09cfc0f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -1065,7 +1066,7 @@ void wapi_test_set_key(struct _adapter *padapter, u8 *buf)
 void wapi_test_init(struct _adapter *padapter)
 {
 	u8 keybuf[100];
-	u8 mac_addr[6] = {0x00, 0xe0, 0x4c, 0x72, 0x04, 0x70};
+	u8 mac_addr[ETH_ALEN] = {0x00, 0xe0, 0x4c, 0x72, 0x04, 0x70};
 	u8 UskDataKey[16] = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f};
 	u8 UskMicKey[16] = {0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f};
 	u8 UskId = 0;
@@ -1091,7 +1092,7 @@ void wapi_test_init(struct _adapter *padapter)
 	keybuf[2] = 1; 				/* AE */
 	keybuf[3] = 0; 				/* not update */
 
-	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 4, mac_addr, ETH_ALEN);
 	memcpy(keybuf + 10, UskDataKey, 16);
 	memcpy(keybuf + 26, UskMicKey, 16);
 	keybuf[42] = UskId;
@@ -1103,7 +1104,7 @@ void wapi_test_init(struct _adapter *padapter)
 	keybuf[2] = 0; 				/* AE */
 	keybuf[3] = 0; 				/* not update */
 
-	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 4, mac_addr, ETH_ALEN);
 	memcpy(keybuf + 10, UskDataKey, 16);
 	memcpy(keybuf + 26, UskMicKey, 16);
 	keybuf[42] = UskId;
@@ -1116,7 +1117,7 @@ void wapi_test_init(struct _adapter *padapter)
 	keybuf[1] = 1;                               /* Enable TX */
 	keybuf[2] = 1; 				/* AE */
 	keybuf[3] = 0;                              /* not update */
-	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 4, mac_addr, ETH_ALEN);
 	memcpy(keybuf + 10, MskDataKey, 16);
 	memcpy(keybuf + 26, MskMicKey, 16);
 	keybuf[42] = MskId;
@@ -1127,7 +1128,7 @@ void wapi_test_init(struct _adapter *padapter)
 	keybuf[1] = 1;                               /* Enable TX */
 	keybuf[2] = 0; 				/* AE */
 	keybuf[3] = 0;                              /* not update */
-	memcpy(keybuf + 4, mac_addr, 6);
+	memcpy(keybuf + 4, mac_addr, ETH_ALEN);
 	memcpy(keybuf + 10, MskDataKey, 16);
 	memcpy(keybuf + 26, MskMicKey, 16);
 	keybuf[42] = MskId;
@@ -1252,4 +1253,61 @@ bool rtw_wapi_drop_for_key_absent(_adapter *padapter, u8 *pRA)
 	return bDrop;
 }
 
+void rtw_wapi_set_set_encryption(_adapter *padapter, struct ieee_param *param)
+{
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
+	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
+	PRT_WAPI_STA_INFO	pWapiSta;
+	u8					WapiASUEPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+	u8					WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
+
+	if (param->u.crypt.set_tx == 1) {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (_rtw_memcmp(pWapiSta->PeerMacAddr, param->sta_addr, 6)) {
+				_rtw_memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
+
+				pWapiSta->wapiUsk.bSet = true;
+				_rtw_memcpy(pWapiSta->wapiUsk.dataKey, param->u.crypt.key, 16);
+				_rtw_memcpy(pWapiSta->wapiUsk.micKey, param->u.crypt.key + 16, 16);
+				pWapiSta->wapiUsk.keyId = param->u.crypt.idx ;
+				pWapiSta->wapiUsk.bTxEnable = true;
+
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiAEPNInitialValueSrc, 16);
+				_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
+				pWapiSta->wapiUskUpdate.bTxEnable = false;
+				pWapiSta->wapiUskUpdate.bSet = false;
+
+				if (psecuritypriv->sw_encrypt == false || psecuritypriv->sw_decrypt == false) {
+					/* set unicast key for ASUE */
+					rtw_wapi_set_key(padapter, &pWapiSta->wapiUsk, pWapiSta, false, false);
+				}
+			}
+		}
+	} else {
+		list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
+			if (_rtw_memcmp(pWapiSta->PeerMacAddr, get_bssid(pmlmepriv), 6)) {
+				pWapiSta->wapiMsk.bSet = true;
+				_rtw_memcpy(pWapiSta->wapiMsk.dataKey, param->u.crypt.key, 16);
+				_rtw_memcpy(pWapiSta->wapiMsk.micKey, param->u.crypt.key + 16, 16);
+				pWapiSta->wapiMsk.keyId = param->u.crypt.idx ;
+				pWapiSta->wapiMsk.bTxEnable = false;
+				if (!pWapiSta->bSetkeyOk)
+					pWapiSta->bSetkeyOk = true;
+				pWapiSta->bAuthenticateInProgress = false;
+
+				_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
+
+				if (psecuritypriv->sw_decrypt == false) {
+					/* set rx broadcast key for ASUE */
+					rtw_wapi_set_key(padapter, &pWapiSta->wapiMsk, pWapiSta, true, false);
+				}
+			}
+		}
+	}
+}
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi_sms4.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi_sms4.c
index 4b7cf957c8f2..5eaa5be44c91 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi_sms4.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wapi_sms4.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wlan_util.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wlan_util.c
index be223fd99927..dd23b8999b0c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wlan_util.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_wlan_util.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -52,9 +53,6 @@ extern unsigned char RSN_TKIP_CIPHER[4];
 #define WAIT_FOR_BCN_TO_MIN	(6000)
 #define WAIT_FOR_BCN_TO_MAX	(20000)
 
-#define DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS 1000
-#define DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD 3
-
 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
@@ -72,8 +70,41 @@ static u8 rtw_basic_rate_mix[7] = {
 	IEEE80211_OFDM_RATE_24MB | IEEE80211_BASIC_RATE_MASK
 };
 
-int new_bcn_max = 3;
+/* test if rate is defined in rtw_basic_rate_cck */
+bool rtw_is_basic_rate_cck(u8 rate)
+{
+	int i;
+
+	for (i = 0; i < 4; i++)
+		if ((rtw_basic_rate_cck[i] & 0x7F) == (rate & 0x7F))
+			return 1;
+	return 0;
+}
+
+/* test if rate is defined in rtw_basic_rate_ofdm */
+bool rtw_is_basic_rate_ofdm(u8 rate)
+{
+	int i;
+
+	for (i = 0; i < 3; i++)
+		if ((rtw_basic_rate_ofdm[i] & 0x7F) == (rate & 0x7F))
+			return 1;
+	return 0;
+}
+
+/* test if rate is defined in rtw_basic_rate_mix */
+bool rtw_is_basic_rate_mix(u8 rate)
+{
+	int i;
 
+	for (i = 0; i < 7; i++)
+		if ((rtw_basic_rate_mix[i] & 0x7F) == (rate & 0x7F))
+			return 1;
+	return 0;
+}
+#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
+int new_bcn_max = 3;
+#endif
 int cckrates_included(unsigned char *rate, int ratelen)
 {
 	int	i;
@@ -507,53 +538,6 @@ exit:
 	return valid;
 }
 
-u8 rtw_get_offset_by_ch(u8 channel)
-{
-	u8 offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-
-	if (channel >= 1 && channel <= 4)
-		offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-	else if (channel >= 5 && channel <= 14)
-		offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-	else {
-		switch (channel) {
-		case 36:
-		case 44:
-		case 52:
-		case 60:
-		case 100:
-		case 108:
-		case 116:
-		case 124:
-		case 132:
-		case 149:
-		case 157:
-			offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-			break;
-		case 40:
-		case 48:
-		case 56:
-		case 64:
-		case 104:
-		case 112:
-		case 120:
-		case 128:
-		case 136:
-		case 153:
-		case 161:
-			offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-			break;
-		default:
-			offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-			break;
-		}
-
-	}
-
-	return offset;
-
-}
-
 u8 rtw_get_center_ch(u8 channel, u8 chnl_bw, u8 chnl_offset)
 {
 	u8 center_ch = channel;
@@ -604,7 +588,6 @@ inline systime rtw_get_on_cur_ch_time(_adapter *adapter)
 void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char channel_offset, unsigned short bwmode)
 {
 	u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 #if (defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)) || defined(CONFIG_MCC_MODE)
 	u8 iqk_info_backup = _FALSE;
 #endif
@@ -627,10 +610,8 @@ void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char
 #ifdef CONFIG_MCC_MODE
 	if (MCC_EN(padapter)) {
 		/* driver doesn't set channel setting reg under MCC */
-		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
 			RTW_INFO("Warning: Do not set channel setting reg MCC mode\n");
-			rtw_warn_on(1);
-		}
 	}
 #endif
 
@@ -687,16 +668,6 @@ void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char
 	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
 }
 
-int get_bsstype(unsigned short capability)
-{
-	if (capability & BIT(0))
-		return WIFI_FW_AP_STATE;
-	else if (capability & BIT(1))
-		return WIFI_FW_ADHOC_STATE;
-	else
-		return 0;
-}
-
 __inline u8 *get_my_bssid(WLAN_BSSID_EX *pnetwork)
 {
 	return pnetwork->MacAddress;
@@ -1188,7 +1159,7 @@ s16 rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk)
 	return cam_id;
 }
 
-s16 rtw_get_camid(_adapter *adapter, struct sta_info *sta, u8 *addr, s16 kid)
+s16 rtw_get_camid(_adapter *adapter, u8 *addr, s16 kid, u8 gk)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
@@ -1209,7 +1180,7 @@ s16 rtw_get_camid(_adapter *adapter, struct sta_info *sta, u8 *addr, s16 kid)
 
 	/* find cam entry which has the same addr, kid (, gk bit) */
 	if (_rtw_camctl_chk_cap(adapter, SEC_CAP_CHK_BMC) == _TRUE)
-		i = _rtw_camid_search(adapter, addr, kid, sta ? _FALSE : _TRUE);
+		i = _rtw_camid_search(adapter, addr, kid, gk);
 	else
 		i = _rtw_camid_search(adapter, addr, kid, -1);
 
@@ -1229,12 +1200,8 @@ s16 rtw_get_camid(_adapter *adapter, struct sta_info *sta, u8 *addr, s16 kid)
 	}
 
 	if (i == cam_ctl->num) {
-		if (sta)
-			RTW_PRINT(FUNC_ADPT_FMT" pairwise key with "MAC_FMT" id:%u no room\n"
-				  , FUNC_ADPT_ARG(adapter), MAC_ARG(addr), kid);
-		else
-			RTW_PRINT(FUNC_ADPT_FMT" group key with "MAC_FMT" id:%u no room\n"
-				  , FUNC_ADPT_ARG(adapter), MAC_ARG(addr), kid);
+		RTW_PRINT(FUNC_ADPT_FMT" %s key with "MAC_FMT" id:%u no room\n"
+			, FUNC_ADPT_ARG(adapter), gk ? "group" : "pairwise", MAC_ARG(addr), kid);
 		rtw_warn_on(1);
 		goto _exit;
 	}
@@ -1246,7 +1213,7 @@ _exit:
 	return cam_id;
 }
 
-s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used)
+s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, u8 gk, bool *used)
 {
 	struct mlme_ext_info *mlmeinfo = &adapter->mlmeextpriv.mlmext_info;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
@@ -1260,8 +1227,12 @@ s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used)
 
 	if ((((mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((mlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
 	    && !sta) {
+		/*
+		* 1. non-STA mode WEP key
+		* 2. group TX key
+		*/
 #ifndef CONFIG_CONCURRENT_MODE
-		/* AP/Ad-hoc mode group key static alloction to default key by key ID on Non-concurrent*/
+		/* static alloction to default key by key ID when concurrent is not defined */
 		if (kid > 3) {
 			RTW_PRINT(FUNC_ADPT_FMT" group key with invalid key id:%u\n"
 				  , FUNC_ADPT_ARG(adapter), kid);
@@ -1272,12 +1243,17 @@ s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used)
 #else
 		u8 *addr = adapter_mac_addr(adapter);
 
-		cam_id = rtw_get_camid(adapter, sta, addr, kid);
+		cam_id = rtw_get_camid(adapter, addr, kid, gk);
 		if (1)
 			RTW_PRINT(FUNC_ADPT_FMT" group key with "MAC_FMT" assigned cam_id:%u\n"
 				, FUNC_ADPT_ARG(adapter), MAC_ARG(addr), cam_id);
 #endif
 	} else {
+		/*
+		* 1. STA mode WEP key
+		* 2. STA mode group RX key
+		* 3. sta key (pairwise, group RX)
+		*/
 		u8 *addr = sta ? sta->cmn.mac_addr : NULL;
 
 		if (!sta) {
@@ -1287,7 +1263,7 @@ s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used)
 			}
 			addr = get_bssid(&adapter->mlmepriv);/*A2*/
 		}
-		cam_id = rtw_get_camid(adapter, sta, addr, kid);
+		cam_id = rtw_get_camid(adapter, addr, kid, gk);
 	}
 
 
@@ -1430,12 +1406,12 @@ void rtw_clean_hw_dk_cam(_adapter *adapter)
 
 void flush_all_cam_entry(_adapter *padapter)
 {
+#ifdef CONFIG_CONCURRENT_MODE
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct security_priv *psecpriv = &padapter->securitypriv;
 
-#ifdef CONFIG_CONCURRENT_MODE
 	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
 		struct sta_priv	*pstapriv = &padapter->stapriv;
 		struct sta_info		*psta;
@@ -1809,6 +1785,97 @@ static void bwmode_update_check(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pI
 #endif /* CONFIG_80211N_HT */
 }
 
+#ifdef ROKU_PRIVATE
+void Supported_rate_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
+{
+	unsigned int	i;
+	struct mlme_ext_priv		*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info		*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (pIE == NULL)
+		return;
+
+	for (i = 0 ; i < pIE->Length; i++)
+		pmlmeinfo->SupportedRates_infra_ap[i] = (pIE->data[i]);
+
+}
+
+void Extended_Supported_rate_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
+{
+	unsigned int i, j;
+	struct mlme_ext_priv		*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info		*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (pIE == NULL)
+		return;
+
+	if (pIE->Length > 0) {
+		for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
+			if (pmlmeinfo->SupportedRates_infra_ap[i] == 0)
+				break;
+		}
+		for (j = 0; j < pIE->Length; j++)
+			pmlmeinfo->SupportedRates_infra_ap[i+j] = (pIE->data[j]);
+	}
+
+}
+
+void HT_get_ss_from_mcs_set(u8 *mcs_set, u8 *Rx_ss)
+{
+	u8 i, j;
+	u8 r_ss = 0, t_ss = 0;
+
+	for (i = 0; i < 4; i++) {
+		if ((mcs_set[3-i] & 0xff) != 0x00) {
+			r_ss = 4-i;
+			break;
+		}
+	}
+
+	*Rx_ss = r_ss;
+}
+
+void HT_caps_handler_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
+{
+	unsigned int	i;
+	u8	cur_stbc_cap_infra_ap = 0;
+	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
+	struct ht_priv_infra_ap		*phtpriv = &pmlmepriv->htpriv_infra_ap;
+
+	struct mlme_ext_priv		*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info		*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+	if (pIE == NULL)
+		return;
+
+	pmlmeinfo->ht_vht_received |= BIT(0);
+
+	/*copy MCS_SET*/
+	for (i = 3; i < 19; i++)
+		phtpriv->MCS_set_infra_ap[i-3] = (pIE->data[i]);
+
+	/*get number of stream from mcs set*/
+	HT_get_ss_from_mcs_set(phtpriv->MCS_set_infra_ap, &phtpriv->Rx_ss_infra_ap);
+
+	phtpriv->rx_highest_data_rate_infra_ap = le16_to_cpu(GET_HT_CAP_ELE_RX_HIGHEST_DATA_RATE(pIE->data));
+
+	phtpriv->ldpc_cap_infra_ap = GET_HT_CAP_ELE_LDPC_CAP(pIE->data);
+
+	if (GET_HT_CAP_ELE_RX_STBC(pIE->data))
+		SET_FLAG(cur_stbc_cap_infra_ap, STBC_HT_ENABLE_RX);
+	if (GET_HT_CAP_ELE_TX_STBC(pIE->data))
+		SET_FLAG(cur_stbc_cap_infra_ap, STBC_HT_ENABLE_TX);
+	phtpriv->stbc_cap_infra_ap = cur_stbc_cap_infra_ap;
+
+	/*store ap info SGI 20m 40m*/
+	phtpriv->sgi_20m_infra_ap = GET_HT_CAP_ELE_SHORT_GI20M(pIE->data);
+	phtpriv->sgi_40m_infra_ap = GET_HT_CAP_ELE_SHORT_GI40M(pIE->data);
+
+	/*store ap info for supported channel bandwidth*/
+	phtpriv->channel_width_infra_ap = GET_HT_CAP_ELE_CHL_WIDTH(pIE->data);
+}
+#endif /* ROKU_PRIVATE */
+
 void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 {
 #ifdef CONFIG_80211N_HT
@@ -1820,7 +1887,9 @@ void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct ht_priv			*phtpriv = &pmlmepriv->htpriv;
+#ifdef CONFIG_DISABLE_MCS13TO15
 	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
+#endif
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
 
 	if (pIE == NULL)
@@ -2026,9 +2095,9 @@ void HTOnAssocRsp(_adapter *padapter)
 	min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MIN_SPACE, (u8 *)(&min_MPDU_spacing));
-
+#ifdef CONFIG_80211N_HT
 	rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&max_AMPDU_len));
-
+#endif /* CONFIG_80211N_HT */
 #if 0 /* move to rtw_update_ht_cap() */
 	if ((pregpriv->bw_mode > 0) &&
 	    (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & BIT(1)) &&
@@ -2091,7 +2160,6 @@ void ERP_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
 void VCS_update(_adapter *padapter, struct sta_info *psta)
 {
 	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);
 
@@ -2170,7 +2238,6 @@ int check_ielen(u8 *start, uint len)
 {
 	int left = len;
 	u8 *pos = start;
-	int unknown = 0;
 	u8 id, elen;
 
 	while (left >= 2) {
@@ -2183,7 +2250,7 @@ int check_ielen(u8 *start, uint len)
 					id, elen, (unsigned long) left);
 			return _FALSE;
 		}
-		if ((id == WLAN_EID_VENDOR_SPECIFIC) && (elen < 4))
+		if ((id == WLAN_EID_VENDOR_SPECIFIC) && (elen < 3))
 				return _FALSE;
 
 		left -= elen;
@@ -2210,6 +2277,175 @@ int validate_beacon_len(u8 *pframe, u32 len)
 	return _TRUE;
 }
 
+
+u8 support_rate_ranges[] = {
+	IEEE80211_CCK_RATE_1MB,
+	IEEE80211_CCK_RATE_2MB,
+	IEEE80211_CCK_RATE_5MB,
+	IEEE80211_CCK_RATE_11MB,
+	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,
+};
+
+inline bool match_ranges(u16 EID, u32 value)
+{
+	int i;
+	int nr_range;
+
+	switch (EID) {
+	case _EXT_SUPPORTEDRATES_IE_:
+	case _SUPPORTEDRATES_IE_:
+		nr_range = sizeof(support_rate_ranges)/sizeof(u8);
+		for (i = 0; i < nr_range; i++) {
+			/*	clear bit7 before searching.	*/
+			value &= ~BIT(7);
+			if (value == support_rate_ranges[i])
+				return _TRUE;
+		}
+		break;
+	default:
+		break;
+	};
+	return _FALSE;
+}
+
+/*
+ * rtw_validate_value: validate the IE contain.
+ *
+ *	Input : 
+ *		EID : Element ID
+ *		p	: IE buffer (without EID & length)
+ *		len	: IE length
+ *	return: 
+ * 		_TRUE	: All Values are validated.
+ *		_FALSE	: At least one value is NOT validated.
+ */
+bool rtw_validate_value(u16 EID, u8 *p, u16 len)
+{
+	u8 rate;
+	u32 i, nr_val;
+
+	switch (EID) {
+	case _EXT_SUPPORTEDRATES_IE_:
+	case _SUPPORTEDRATES_IE_:
+		nr_val = len;
+		for (i=0; i<nr_val; i++) {
+			rate = *(p+i);
+			if (match_ranges(EID, rate) == _FALSE)
+				return _FALSE;
+		}
+		break;
+	default:
+		break;
+	};
+	return _TRUE;
+}
+
+inline bool hidden_ssid_ap(WLAN_BSSID_EX *snetwork)
+{
+	return ((snetwork->Ssid.SsidLength == 0) ||  
+		is_all_null(snetwork->Ssid.Ssid, snetwork->Ssid.SsidLength) == _TRUE);
+}
+
+/*
+	Get SSID if this ilegal frame(probe resp) comes from a hidden SSID AP.
+	Update the SSID to the corresponding pnetwork in scan queue.
+*/
+void rtw_absorb_ssid_ifneed(_adapter *padapter, WLAN_BSSID_EX *bssid, u8 *pframe)
+{
+	struct wlan_network *scanned = NULL;
+	WLAN_BSSID_EX	*snetwork;
+	u8 ie_offset, *p=NULL, *next_ie=NULL, *mac = get_addr2_ptr(pframe);
+	sint len, ssid_len_ori;
+	u32 remain_len = 0;
+	u8 backupIE[MAX_IE_SZ];
+	u16 subtype = get_frame_sub_type(pframe);
+	_irqL irqL;
+
+	if ((!bssid) || (!pframe))
+		return;
+
+	if (subtype == WIFI_BEACON) {
+		bssid->Reserved[0] = BSS_TYPE_BCN;
+		ie_offset = _BEACON_IE_OFFSET_;
+	} else {
+		/* FIXME : more type */
+		if (subtype == WIFI_PROBERSP) {
+			ie_offset = _PROBERSP_IE_OFFSET_;
+			bssid->Reserved[0] = BSS_TYPE_PROB_RSP;
+		} else if (subtype == WIFI_PROBEREQ) {
+			ie_offset = _PROBEREQ_IE_OFFSET_;
+			bssid->Reserved[0] = BSS_TYPE_PROB_REQ;
+		} else {
+			bssid->Reserved[0] = BSS_TYPE_UNDEF;
+			ie_offset = _FIXED_IE_LENGTH_;
+		}
+	}
+	
+	_enter_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
+	scanned = _rtw_find_network(&padapter->mlmepriv.scanned_queue, mac);
+	if (!scanned) {
+		_exit_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
+		return;
+	}
+
+	snetwork = &(scanned->network);
+	/* scan queue records as Hidden SSID && Input frame is NOT Hidden SSID	*/
+	if (hidden_ssid_ap(snetwork) && !hidden_ssid_ap(bssid)) {
+		p = rtw_get_ie(snetwork->IEs+ie_offset, _SSID_IE_, &ssid_len_ori, snetwork->IELength-ie_offset);
+		if (!p) {
+			_exit_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
+			return;
+		}
+		next_ie = p + 2 + ssid_len_ori;
+		remain_len = snetwork->IELength - (next_ie - snetwork->IEs);
+		scanned->network.Ssid.SsidLength = bssid->Ssid.SsidLength;
+		_rtw_memcpy(scanned->network.Ssid.Ssid, bssid->Ssid.Ssid, bssid->Ssid.SsidLength);
+
+		//update pnetwork->ssid, pnetwork->ssidlen
+		_rtw_memcpy(backupIE, next_ie, remain_len);
+		*(p+1) = bssid->Ssid.SsidLength;
+		_rtw_memcpy(p+2, bssid->Ssid.Ssid, bssid->Ssid.SsidLength);
+		_rtw_memcpy(p+2+bssid->Ssid.SsidLength, backupIE, remain_len);
+		snetwork->IELength += bssid->Ssid.SsidLength;
+	}
+	_exit_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
+}
+
+#ifdef DBG_RX_BCN
+void rtw_debug_rx_bcn(_adapter *adapter, u8 *pframe, u32 packet_len)
+{
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *mlmeinfo = &(pmlmeext->mlmext_info);
+	u16 sn = ((struct rtw_ieee80211_hdr_3addr *)pframe)->seq_ctl >> 4;
+	u64 tsf, tsf_offset;
+	u8 dtim_cnt, dtim_period, tim_bmap, tim_pvbit;
+
+	update_TSF(pmlmeext, pframe, packet_len);
+	tsf = pmlmeext->TSFValue;
+	tsf_offset = rtw_modular64(pmlmeext->TSFValue, (mlmeinfo->bcn_interval * 1024));
+
+	/*get TIM IE*/
+	/*DTIM Count*/
+	dtim_cnt = pmlmeext->tim[0];
+	/*DTIM Period*/
+	dtim_period = pmlmeext->tim[1];
+	/*Bitmap*/
+	tim_bmap = pmlmeext->tim[2];
+	/*Partial VBitmap AID 0 ~ 7*/
+	tim_pvbit = pmlmeext->tim[3];
+
+	RTW_INFO("[BCN] SN-%d, TSF-%lld(us), offset-%lld, bcn_interval-%d DTIM-%d[%d] bitmap-0x%02x-0x%02x\n",
+		sn, tsf, tsf_offset, mlmeinfo->bcn_interval, dtim_period, dtim_cnt, tim_bmap, tim_pvbit);
+}
+#endif
+
 /*
  * rtw_get_bcn_keys: get beacon keys from recv frame
  *
@@ -2285,7 +2521,7 @@ int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
 		recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WPA2;
 		rtw_parse_wpa2_ie(elems.rsn_ie - 2, elems.rsn_ie_len + 2,
 			&recv_beacon->group_cipher, &recv_beacon->pairwise_cipher,
-				  &recv_beacon->is_8021x);
+				  &recv_beacon->is_8021x, NULL);
 	}
 	/* checking WPA secon */
 	else if (elems.wpa_ie && elems.wpa_ie_len) {
@@ -2296,50 +2532,36 @@ int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
 	} else if (capability & BIT(4))
 		recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WEP;
 
+	if (elems.tim && elems.tim_len) {
+		struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
+
+		#ifdef DBG_RX_BCN
+		_rtw_memcpy(pmlmeext->tim, elems.tim, 4);
+		#endif
+		pmlmeext->dtim = elems.tim[1];
+	}
+
 	return _TRUE;
 }
 
 void rtw_dump_bcn_keys(struct beacon_keys *recv_beacon)
 {
-	int i;
-	char *p;
 	u8 ssid[IW_ESSID_MAX_SIZE + 1];
 
 	_rtw_memcpy(ssid, recv_beacon->ssid, recv_beacon->ssid_len);
 	ssid[recv_beacon->ssid_len] = '\0';
 
 	RTW_INFO("%s: ssid = %s\n", __func__, ssid);
-	RTW_INFO("%s: channel = %x\n", __func__, recv_beacon->bcn_channel);
-	RTW_INFO("%s: ht_cap = %x\n", __func__,	recv_beacon->ht_cap_info);
-	RTW_INFO("%s: ht_info_infos_0_sco = %x\n", __func__, recv_beacon->ht_info_infos_0_sco);
+	RTW_INFO("%s: channel = %d\n", __func__, recv_beacon->bcn_channel);
+	RTW_INFO("%s: ht_cap = 0x%04x\n", __func__,	recv_beacon->ht_cap_info);
+	RTW_INFO("%s: ht_info_infos_0_sco = 0x%02x\n", __func__, recv_beacon->ht_info_infos_0_sco);
 	RTW_INFO("%s: sec=%d, group = %x, pair = %x, 8021X = %x\n", __func__,
 		 recv_beacon->encryp_protocol, recv_beacon->group_cipher,
 		 recv_beacon->pairwise_cipher, recv_beacon->is_8021x);
 }
-
+#define DBG_BCN_CNT
 int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 {
-#if 0
-	unsigned int		len;
-	unsigned char		*p;
-	unsigned short	val16, subtype;
-	struct wlan_network *cur_network = &(Adapter->mlmepriv.cur_network);
-	/* u8 wpa_ie[255],rsn_ie[255]; */
-	u16 wpa_len = 0, rsn_len = 0;
-	u8 encryp_protocol = 0;
-	WLAN_BSSID_EX *bssid;
-	int group_cipher = 0, pairwise_cipher = 0, is_8021x = 0;
-	unsigned char *pbuf;
-	u32 wpa_ielen = 0;
-	u8 *pbssid = GetAddr3Ptr(pframe);
-	u32 hidden_ssid = 0;
-	u8 cur_network_type, network_type = 0;
-	struct HT_info_element *pht_info = NULL;
-	struct rtw_ieee80211_ht_cap *pht_cap = NULL;
-	u32 bcn_channel;
-	unsigned short	ht_cap_info;
-	unsigned char	ht_info_infos_0;
-#endif
 	unsigned int len;
 	u8 *pbssid = GetAddr3Ptr(pframe);
 	struct mlme_priv *pmlmepriv = &Adapter->mlmepriv;
@@ -2365,13 +2587,17 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 	if (rtw_get_bcn_keys(Adapter, pframe, packet_len, &recv_beacon) == _FALSE)
 		return _TRUE; /* parsing failed => broken IE */
 
+#ifdef DBG_RX_BCN
+	rtw_debug_bcn(Adapter, pframe, packet_len);
+#endif
+
 	/* don't care hidden ssid, use current beacon ssid directly */
 	if (recv_beacon.ssid_len == 0) {
 		_rtw_memcpy(recv_beacon.ssid, pmlmepriv->cur_beacon_keys.ssid,
 			    pmlmepriv->cur_beacon_keys.ssid_len);
 		recv_beacon.ssid_len = pmlmepriv->cur_beacon_keys.ssid_len;
 	}
-
+#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
 	if (_rtw_memcmp(&recv_beacon, &pmlmepriv->cur_beacon_keys, sizeof(recv_beacon)) == _TRUE)
 		pmlmepriv->new_beacon_cnts = 0;
 	else if ((pmlmepriv->new_beacon_cnts == 0) ||
@@ -2386,7 +2612,7 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 		RTW_DBG("%s: new beacon key\n", __func__);
 		RTW_DBG_EXPR(rtw_dump_bcn_keys(&recv_beacon));
 
-		memcpy(&pmlmepriv->new_beacon_keys, &recv_beacon, sizeof(recv_beacon));
+		_rtw_memcpy(&pmlmepriv->new_beacon_keys, &recv_beacon, sizeof(recv_beacon));
 		pmlmepriv->new_beacon_cnts = 1;
 	} else {
 		RTW_DBG("%s: new beacon again (seq=%d)\n", __func__, GetSequence(pframe));
@@ -2394,7 +2620,11 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 	}
 
 	/* if counter >= max, it means beacon is changed really */
-	if (pmlmepriv->new_beacon_cnts >= new_bcn_max) {
+	if (pmlmepriv->new_beacon_cnts >= new_bcn_max)
+#else
+	if (_rtw_memcmp(&recv_beacon, &pmlmepriv->cur_beacon_keys, sizeof(recv_beacon)) == _FALSE)
+#endif
+	{
 		/* check bw mode change only? */
 		pmlmepriv->cur_beacon_keys.ht_cap_info = recv_beacon.ht_cap_info;
 		pmlmepriv->cur_beacon_keys.ht_info_infos_0_sco = recv_beacon.ht_info_infos_0_sco;
@@ -2402,204 +2632,35 @@ int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
 				sizeof(recv_beacon)) == _FALSE) {
 			/* beacon is changed, have to do disconnect/connect */
 			RTW_WARN("%s: new beacon occur!!\n", __func__);
+			#ifdef DBG_BCN_CNT
+			rtw_dump_bcn_keys(&recv_beacon);
+			#endif
 			return _FAIL;
 		}
-
+		#ifdef DBG_BCN_CNT
 		RTW_INFO("%s bw mode change\n", __func__);
 		RTW_INFO("%s bcn now: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
 			 cur_network->BcnInfo.ht_cap_info,
 			 cur_network->BcnInfo.ht_info_infos_0);
+		#endif
 
 		cur_network->BcnInfo.ht_cap_info = recv_beacon.ht_cap_info;
 		cur_network->BcnInfo.ht_info_infos_0 =
 			(cur_network->BcnInfo.ht_info_infos_0 & (~0x03)) |
 			recv_beacon.ht_info_infos_0_sco;
 
+		#ifdef DBG_BCN_CNT
 		RTW_INFO("%s bcn link: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
 			 cur_network->BcnInfo.ht_cap_info,
 			 cur_network->BcnInfo.ht_info_infos_0);
-
-		memcpy(&pmlmepriv->cur_beacon_keys, &recv_beacon, sizeof(recv_beacon));
+		#endif
+		_rtw_memcpy(&pmlmepriv->cur_beacon_keys, &recv_beacon, sizeof(recv_beacon));
+		#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
 		pmlmepriv->new_beacon_cnts = 0;
+		#endif
 	}
 
 	return _SUCCESS;
-
-#if 0
-	bssid = (WLAN_BSSID_EX *)rtw_zmalloc(sizeof(WLAN_BSSID_EX));
-	if (bssid == NULL) {
-		RTW_INFO("%s rtw_zmalloc fail !!!\n", __func__);
-		return _TRUE;
-	}
-
-	if ((pmlmepriv->timeBcnInfoChkStart != 0) && (rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart) > DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS)) {
-		pmlmepriv->timeBcnInfoChkStart = 0;
-		pmlmepriv->NumOfBcnInfoChkFail = 0;
-	}
-
-	subtype = get_frame_sub_type(pframe) >> 4;
-
-	if (subtype == WIFI_BEACON)
-		bssid->Reserved[0] = 1;
-
-	bssid->Length = sizeof(WLAN_BSSID_EX) - MAX_IE_SZ + len;
-
-	/* below is to copy the information element */
-	bssid->IELength = len;
-	_rtw_memcpy(bssid->IEs, (pframe + sizeof(struct rtw_ieee80211_hdr_3addr)), bssid->IELength);
-
-	/* check bw and channel offset */
-	/* parsing HT_CAP_IE */
-	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _HT_CAPABILITY_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-	if (p && len > 0) {
-		pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
-		ht_cap_info = pht_cap->cap_info;
-	} else
-		ht_cap_info = 0;
-	/* parsing HT_INFO_IE */
-	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _HT_ADD_INFO_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-	if (p && len > 0) {
-		pht_info = (struct HT_info_element *)(p + 2);
-		ht_info_infos_0 = pht_info->infos[0];
-	} else
-		ht_info_infos_0 = 0;
-	if (ht_cap_info != cur_network->BcnInfo.ht_cap_info ||
-	    ((ht_info_infos_0 & 0x03) != (cur_network->BcnInfo.ht_info_infos_0 & 0x03))) {
-		RTW_INFO("%s bcn now: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
-			 ht_cap_info, ht_info_infos_0);
-		RTW_INFO("%s bcn link: ht_cap_info:%x ht_info_infos_0:%x\n", __func__,
-			cur_network->BcnInfo.ht_cap_info, cur_network->BcnInfo.ht_info_infos_0);
-		RTW_INFO("%s bw mode change\n", __func__);
-		{
-			/* bcn_info_update */
-			cur_network->BcnInfo.ht_cap_info = ht_cap_info;
-			cur_network->BcnInfo.ht_info_infos_0 = ht_info_infos_0;
-			/* to do : need to check that whether modify related register of BB or not */
-		}
-		/* goto _mismatch; */
-	}
-
-	/* Checking for channel */
-	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _DSSET_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-	if (p)
-		bcn_channel = *(p + 2);
-	else {/* In 5G, some ap do not have DSSET IE checking HT info for channel */
-		rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _HT_ADD_INFO_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-		if (pht_info)
-			bcn_channel = pht_info->primary_channel;
-		else { /* we don't find channel IE, so don't check it */
-			/* RTW_INFO("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) {
-		RTW_INFO("%s beacon channel:%d cur channel:%d disconnect\n", __func__,
-			 bcn_channel, Adapter->mlmeextpriv.cur_channel);
-		goto _mismatch;
-	}
-
-	/* checking SSID */
-	p = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _SSID_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
-	if (p == NULL) {
-		RTW_INFO("%s marc: cannot find SSID for survey event\n", __func__);
-		hidden_ssid = _TRUE;
-	} else
-		hidden_ssid = _FALSE;
-
-	if ((NULL != p) && (_FALSE == hidden_ssid && (*(p + 1)))) {
-		_rtw_memcpy(bssid->Ssid.Ssid, (p + 2), *(p + 1));
-		bssid->Ssid.SsidLength = *(p + 1);
-	} else {
-		bssid->Ssid.SsidLength = 0;
-		bssid->Ssid.Ssid[0] = '\0';
-	}
-
-
-	if (_rtw_memcmp(bssid->Ssid.Ssid, cur_network->network.Ssid.Ssid, 32) == _FALSE ||
-	    bssid->Ssid.SsidLength != cur_network->network.Ssid.SsidLength) {
-		if (bssid->Ssid.Ssid[0] != '\0' && bssid->Ssid.SsidLength != 0) { /* not hidden ssid */
-			RTW_INFO("%s(), SSID is not match\n", __func__);
-			goto _mismatch;
-		}
-	}
-
-	/* check encryption info */
-	val16 = rtw_get_capability((WLAN_BSSID_EX *)bssid);
-
-	if (val16 & BIT(4))
-		bssid->Privacy = 1;
-	else
-		bssid->Privacy = 0;
-
-	if (cur_network->network.Privacy != bssid->Privacy) {
-		RTW_INFO("%s(), privacy is not match\n", __func__);
-		goto _mismatch;
-	}
-
-	rtw_get_sec_ie(bssid->IEs, bssid->IELength, NULL, &rsn_len, NULL, &wpa_len);
-
-	if (rsn_len > 0)
-		encryp_protocol = ENCRYP_PROTOCOL_WPA2;
-	else if (wpa_len > 0)
-		encryp_protocol = ENCRYP_PROTOCOL_WPA;
-	else {
-		if (bssid->Privacy)
-			encryp_protocol = ENCRYP_PROTOCOL_WEP;
-	}
-
-	if (cur_network->BcnInfo.encryp_protocol != encryp_protocol) {
-		RTW_INFO("%s(): enctyp is not match\n", __func__);
-		goto _mismatch;
-	}
-
-	if (encryp_protocol == ENCRYP_PROTOCOL_WPA || encryp_protocol == ENCRYP_PROTOCOL_WPA2) {
-		pbuf = rtw_get_wpa_ie(&bssid->IEs[12], &wpa_ielen, bssid->IELength - 12);
-		if (pbuf && (wpa_ielen > 0)) {
-			rtw_parse_wpa_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is_8021x);
-		} else {
-			pbuf = rtw_get_wpa2_ie(&bssid->IEs[12], &wpa_ielen, bssid->IELength - 12);
-
-			if (pbuf && (wpa_ielen > 0)) {
-				rtw_parse_wpa2_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is_8021x);
-			}
-		}
-
-		if (pairwise_cipher != cur_network->BcnInfo.pairwise_cipher || group_cipher != cur_network->BcnInfo.group_cipher) {
-			RTW_INFO("%s pairwise_cipher(%x:%x) or group_cipher(%x:%x) is not match\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) {
-			RTW_INFO("%s authentication is not match\n", __func__);
-			goto _mismatch;
-		}
-	}
-
-	rtw_mfree((u8 *)bssid, sizeof(WLAN_BSSID_EX));
-	return _SUCCESS;
-
-_mismatch:
-	rtw_mfree((u8 *)bssid, sizeof(WLAN_BSSID_EX));
-
-	if (pmlmepriv->NumOfBcnInfoChkFail == 0)
-		pmlmepriv->timeBcnInfoChkStart = rtw_get_current_time();
-
-	pmlmepriv->NumOfBcnInfoChkFail++;
-	RTW_INFO("%s by "ADPT_FMT" - NumOfChkFail = %d (SeqNum of this Beacon frame = %d).\n", __func__, ADPT_ARG(Adapter), pmlmepriv->NumOfBcnInfoChkFail, GetSequence(pframe));
-
-	if ((pmlmepriv->timeBcnInfoChkStart != 0) && (rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart) <= DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS)
-	    && (pmlmepriv->NumOfBcnInfoChkFail >= DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD)) {
-		RTW_INFO("%s by "ADPT_FMT" - NumOfChkFail = %d >= threshold : %d (in %d ms), return FAIL.\n", __func__, ADPT_ARG(Adapter), pmlmepriv->NumOfBcnInfoChkFail,
-			DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD, rtw_get_passing_time_ms(pmlmepriv->timeBcnInfoChkStart));
-		pmlmepriv->timeBcnInfoChkStart = 0;
-		pmlmepriv->NumOfBcnInfoChkFail = 0;
-		return _FAIL;
-	}
-
-	return _SUCCESS;
-#endif
 }
 
 void update_beacon_info(_adapter *padapter, u8 *pframe, uint pkt_len, struct sta_info *psta)
@@ -2657,26 +2718,23 @@ void update_beacon_info(_adapter *padapter, u8 *pframe, uint pkt_len, struct sta
 }
 
 #ifdef CONFIG_DFS
-void process_csa_ie(_adapter *padapter, u8 *pframe, uint pkt_len)
+void process_csa_ie(_adapter *padapter, u8 *ies, uint ies_len)
 {
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
 	unsigned int i;
-	unsigned int len;
 	PNDIS_802_11_VARIABLE_IEs	pIE;
-	u8 new_ch_no = 0;
+	u8 ch = 0;
 
-	if (padapter->mlmepriv.handle_dfs == _TRUE)
+	/* TODO: compare with scheduling CSA */
+	if (rfctl->csa_ch)
 		return;
 
-	len = pkt_len - (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN);
-
-	for (i = 0; i < len;) {
-		pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN) + i);
+	for (i = 0; i + 1 < ies_len;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(ies + i);
 
 		switch (pIE->ElementID) {
 		case _CH_SWTICH_ANNOUNCE_:
-			padapter->mlmepriv.handle_dfs = _TRUE;
-			_rtw_memcpy(&new_ch_no, pIE->data + 1, 1);
-			rtw_set_csa_cmd(padapter, new_ch_no);
+			ch = *(pIE->data + 1);
 			break;
 		default:
 			break;
@@ -2684,9 +2742,65 @@ void process_csa_ie(_adapter *padapter, u8 *pframe, uint pkt_len)
 
 		i += (pIE->Length + 2);
 	}
+
+	if (ch != 0) {
+		rfctl->csa_ch = ch;
+		if (rtw_set_csa_cmd(padapter) != _SUCCESS)
+			rfctl->csa_ch = 0;
+	}
 }
 #endif /* CONFIG_DFS */
 
+void parsing_eapol_packet(_adapter *padapter, u8 *key_payload, struct sta_info *psta, u8 trx_type)
+{
+	struct security_priv *psecuritypriv = &(padapter->securitypriv);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct sta_priv *pstapriv = &(padapter->stapriv);
+	struct ieee802_1x_hdr *hdr;
+	struct wpa_eapol_key *key;
+	u16 key_info, key_data_length;
+	char *trx_msg = trx_type ? "send" : "recv";
+
+	hdr = (struct ieee802_1x_hdr *) key_payload;
+
+	 /* WPS - eapol start packet */
+	if (hdr->type == 1 && hdr->length == 0) {
+		RTW_INFO("%s eapol start packet\n", trx_msg);
+		return;
+	}
+
+	if (hdr->type == 0) { /* WPS - eapol packet */
+		RTW_INFO("%s eapol packet\n", trx_msg);
+		return;
+	}
+
+	key = (struct wpa_eapol_key *) (hdr + 1);
+	key_info = be16_to_cpu(*((u16 *)(key->key_info)));
+	key_data_length = be16_to_cpu(*((u16 *)(key->key_data_length)));
+
+	if (!(key_info & WPA_KEY_INFO_KEY_TYPE)) { /* WPA group key handshake */
+		if (key_info & WPA_KEY_INFO_ACK) {
+			RTW_PRINT("%s eapol packet - WPA Group Key 1/2\n", trx_msg);
+		} else {
+			RTW_PRINT("%s eapol packet - WPA Group Key 2/2\n", trx_msg);
+
+			/* WPA key-handshake has completed */
+			if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPAPSK)
+				psta->state &= (~WIFI_UNDER_KEY_HANDSHAKE);
+		}
+	} else if (key_info & WPA_KEY_INFO_MIC) {
+		if (key_data_length == 0)
+			RTW_PRINT("%s eapol packet 4/4\n", trx_msg);
+		else if (key_info & WPA_KEY_INFO_ACK)
+			RTW_PRINT("%s eapol packet 3/4\n", trx_msg);
+		else
+			RTW_PRINT("%s eapol packet 2/4\n", trx_msg);
+	} else {
+		RTW_PRINT("%s eapol packet 1/4\n", trx_msg);
+	}
+
+}
+
 unsigned int is_ap_in_tkip(_adapter *padapter)
 {
 	u32 i;
@@ -3051,6 +3165,107 @@ unsigned char check_assoc_AP(u8 *pframe, uint len)
 	return HT_IOT_PEER_UNKNOWN;
 }
 
+void get_assoc_AP_Vendor(char *vendor, u8 assoc_AP_vendor)
+{
+	switch (assoc_AP_vendor) {
+	
+	case HT_IOT_PEER_UNKNOWN:
+	sprintf(vendor, "%s", "unknown");
+	break;
+
+	case HT_IOT_PEER_REALTEK:
+	case HT_IOT_PEER_REALTEK_92SE:
+	case HT_IOT_PEER_REALTEK_SOFTAP:
+	case HT_IOT_PEER_REALTEK_JAGUAR_BCUTAP:
+	case HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP:
+
+	sprintf(vendor, "%s", "Realtek");
+	break;
+
+	case HT_IOT_PEER_BROADCOM:
+	sprintf(vendor, "%s", "Broadcom");
+	break;
+
+	case HT_IOT_PEER_MARVELL:
+	sprintf(vendor, "%s", "Marvell");
+	break;
+
+	case HT_IOT_PEER_RALINK:
+	sprintf(vendor, "%s", "Ralink");
+	break;
+
+	case HT_IOT_PEER_CISCO:
+	sprintf(vendor, "%s", "Cisco");
+	break;
+
+	case HT_IOT_PEER_AIRGO:
+	sprintf(vendor, "%s", "Airgo");
+	break;
+
+	case HT_IOT_PEER_ATHEROS:
+	sprintf(vendor, "%s", "Atheros");
+	break;
+
+	default:
+	sprintf(vendor, "%s", "unkown");
+	break;
+	}
+
+}
+#ifdef CONFIG_RTS_FULL_BW
+void rtw_parse_sta_vendor_ie_8812(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len)
+{
+	struct mlme_priv *mlme = &adapter->mlmepriv;
+	unsigned char REALTEK_OUI[] = {0x00,0xe0, 0x4c};
+	u8 *p;
+	int i;
+
+	p = rtw_get_ie_ex(tlv_ies, tlv_ies_len, WLAN_EID_VENDOR_SPECIFIC, REALTEK_OUI, 3, NULL, NULL);
+	if (!p)
+		goto exit;
+	else {
+		if(*(p+1) > 6 ) {
+			for(i=0; i<9;i++)
+				RTW_INFO("p[%d]=0x%x",i,*(p+i) );
+				RTW_INFO("\n");
+			if(*(p+6) != 2)
+				goto exit;
+			
+			if(*(p+8) == RT_HT_CAP_USE_JAGUAR_BCUT)
+				sta->vendor_8812 = TRUE;
+			else if (*(p+8) == RT_HT_CAP_USE_JAGUAR_CCUT)
+				sta->vendor_8812 = TRUE;
+		}
+	}
+exit:
+	return;
+}
+#endif/*CONFIG_RTS_FULL_BW*/
+
+#ifdef CONFIG_80211AC_VHT
+unsigned char get_vht_mu_bfer_cap(u8 *pframe, uint len)
+{
+	unsigned int i;
+	unsigned int mu_bfer=0;
+	PNDIS_802_11_VARIABLE_IEs pIE;
+
+	for (i = sizeof(NDIS_802_11_FIXED_IEs); i < len;) {
+		pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + i);
+
+		switch (pIE->ElementID) {
+
+		case EID_VHTCapability:
+			mu_bfer = GET_VHT_CAPABILITY_ELE_MU_BFER(pIE->data);
+			break;
+		default:
+			break;
+		}
+		i += (pIE->Length + 2);
+	}
+	return mu_bfer;
+}
+#endif
+
 void update_capinfo(PADAPTER Adapter, u16 updateCap)
 {
 	struct mlme_ext_priv	*pmlmeext = &Adapter->mlmeextpriv;
@@ -3150,6 +3365,9 @@ void update_wireless_mode(_adapter *padapter)
 
 	pmlmeext->cur_wireless_mode = network_type & padapter->registrypriv.wireless_mode;
 	/* RTW_INFO("network_type=%02x, padapter->registrypriv.wireless_mode=%02x\n", network_type, padapter->registrypriv.wireless_mode); */
+
+#ifndef RTW_HALMAC
+	/* HALMAC IC do not set HW_VAR_RESP_SIFS here */
 #if 0
 	if ((pmlmeext->cur_wireless_mode == WIRELESS_11G) ||
 	    (pmlmeext->cur_wireless_mode == WIRELESS_11BG)) /* WIRELESS_MODE_G) */
@@ -3162,6 +3380,7 @@ void update_wireless_mode(_adapter *padapter)
                               * change this value if having IOT issues. */
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_RESP_SIFS, (u8 *)&SIFS_Timer);
+#endif
 
 	rtw_hal_set_hwreg(padapter, HW_VAR_WIRELESS_MODE, (u8 *)&(pmlmeext->cur_wireless_mode));
 
@@ -3220,26 +3439,71 @@ void update_sta_basic_rate(struct sta_info *psta, u8 wireless_mode)
 
 int rtw_ies_get_supported_rate(u8 *ies, uint ies_len, u8 *rate_set, u8 *rate_num)
 {
-	u8 *ie;
+	u8 *ie, *p;
 	unsigned int ie_len;
-
+	int i, j;
+
+	struct support_rate_handler support_rate_tbl[] = {
+		{IEEE80211_CCK_RATE_1MB, 		_FALSE,		_FALSE},
+		{IEEE80211_CCK_RATE_2MB, 		_FALSE,		_FALSE},
+		{IEEE80211_CCK_RATE_5MB, 		_FALSE,		_FALSE},
+		{IEEE80211_CCK_RATE_11MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_6MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_9MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_12MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_18MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_24MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_36MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_48MB,		_FALSE,		_FALSE},
+		{IEEE80211_OFDM_RATE_54MB,		_FALSE,		_FALSE},
+	};
+		
 	if (!rate_set || !rate_num)
 		return _FALSE;
 
 	*rate_num = 0;
-
 	ie = rtw_get_ie(ies, _SUPPORTEDRATES_IE_, &ie_len, ies_len);
 	if (ie == NULL)
 		goto ext_rate;
 
-	_rtw_memcpy(rate_set, ie + 2, ie_len);
-	*rate_num = ie_len;
+	/* get valid supported rates */
+	for (i = 0; i < 12; i++) {
+		p = ie + 2;
+		for (j = 0; j < ie_len; j++) {
+			if ((*p & ~BIT(7)) == support_rate_tbl[i].rate){
+				support_rate_tbl[i].existence = _TRUE;
+				if ((*p) & BIT(7))
+					support_rate_tbl[i].basic = _TRUE;
+			}
+			p++;
+		}
+	}
 
 ext_rate:
 	ie = rtw_get_ie(ies, _EXT_SUPPORTEDRATES_IE_, &ie_len, ies_len);
 	if (ie) {
-		_rtw_memcpy(rate_set + *rate_num, ie + 2, ie_len);
-		*rate_num += ie_len;
+		/* get valid extended supported rates */
+		for (i = 0; i < 12; i++) {
+			p = ie + 2;
+			for (j = 0; j < ie_len; j++) {
+				if ((*p & ~BIT(7)) == support_rate_tbl[i].rate){
+					support_rate_tbl[i].existence = _TRUE;
+					if ((*p) & BIT(7))
+						support_rate_tbl[i].basic = _TRUE;
+				}
+				p++;
+			}
+		}
+	}
+
+	for (i = 0; i < 12; i++){
+		if (support_rate_tbl[i].existence){
+			if (support_rate_tbl[i].basic)
+				rate_set[*rate_num] = support_rate_tbl[i].rate | IEEE80211_BASIC_RATE_MASK;
+			else
+				rate_set[*rate_num] = support_rate_tbl[i].rate;
+			*rate_num += 1;
+		}
 	}
 
 	if (*rate_num == 0)
@@ -3261,8 +3525,6 @@ void process_addba_req(_adapter *padapter, u8 *paddba_req, u8 *addr)
 	u16 tid, start_seq, param;
 	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);
 	u8 size, accept = _FALSE;
 
 	psta = rtw_get_stainfo(pstapriv, addr);
@@ -3292,6 +3554,32 @@ exit:
 	return;
 }
 
+void rtw_process_bar_frame(_adapter *padapter, union recv_frame *precv_frame)
+{
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	struct sta_info *psta = NULL;
+	struct recv_reorder_ctrl *preorder_ctrl = NULL;
+	u8 tid = 0;
+	u16 start_seq=0;
+
+	psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
+	if (psta == NULL)
+		goto exit;
+
+	tid = ((cpu_to_le16((*(u16 *)(pframe + 16))) & 0xf000) >> 12);
+	preorder_ctrl = &psta->recvreorder_ctrl[tid];
+	start_seq = ((cpu_to_le16(*(u16 *)(pframe + 18))) >> 4);
+	preorder_ctrl->indicate_seq = start_seq;
+
+	/* for Debug use */
+	if (0)
+		RTW_INFO(FUNC_ADPT_FMT" tid=%d, start_seq=%d\n", FUNC_ADPT_ARG(padapter),  tid, start_seq);
+
+exit:
+	return;
+}
+
 void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
 {
 	u8 *pIE;
@@ -3307,101 +3595,39 @@ void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
 	pmlmeext->TSFValue |= le32_to_cpu(*pbuf);
 }
 
-void correct_TSF(_adapter *padapter, struct mlme_ext_priv *pmlmeext)
+void correct_TSF(_adapter *padapter, u8 mlme_state)
 {
-	rtw_hal_set_hwreg(padapter, HW_VAR_CORRECT_TSF, 0);
+	u8 m_state = mlme_state;
+
+	rtw_hal_set_hwreg(padapter, HW_VAR_CORRECT_TSF, (u8 *)&m_state);
 }
 
-void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
+#ifdef CONFIG_BCN_RECV_TIME
+/*	calculate beacon receiving time
+	1.RxBCNTime(CCK_1M) = [192us(preamble)] + [length of beacon(byte)*8us] + [10us]
+	2.RxBCNTime(OFDM_6M) = [8us(S) + 8us(L) + 4us(L-SIG)] + [(length of beacon(byte)/3 + 1] *4us] + [10us]
+*/
+inline u16 _rx_bcn_time_calculate(uint bcn_len, u8 data_rate)
 {
-	int i;
-	u8 *pIE;
-	u32 *pbuf;
-	u64 tsf = 0;
-	u32 delay_ms;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-
-	pmlmeext->bcn_cnt++;
-
-	pIE = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
-	pbuf = (u32 *)pIE;
-
-	tsf = le32_to_cpu(*(pbuf + 1));
-	tsf = tsf << 32;
-	tsf |= le32_to_cpu(*pbuf);
-
-	/* RTW_INFO("%s(): tsf_upper= 0x%08x, tsf_lower=0x%08x\n", __func__, (u32)(tsf>>32), (u32)tsf); */
-
-	/* delay = (timestamp mod 1024*100)/1000 (unit: ms) */
-	/* delay_ms = do_div(tsf, (pmlmeinfo->bcn_interval*1024))/1000; */
-	delay_ms = rtw_modular64(tsf, (pmlmeinfo->bcn_interval * 1024));
-	delay_ms = delay_ms / 1000;
-
-	if (delay_ms >= 8) {
-		pmlmeext->bcn_delay_cnt[8]++;
-		/* pmlmeext->bcn_delay_ratio[8] = (pmlmeext->bcn_delay_cnt[8] * 100) /pmlmeext->bcn_cnt; */
-	} else {
-		pmlmeext->bcn_delay_cnt[delay_ms]++;
-		/* pmlmeext->bcn_delay_ratio[delay_ms] = (pmlmeext->bcn_delay_cnt[delay_ms] * 100) /pmlmeext->bcn_cnt; */
-	}
-
-	/*
-		RTW_INFO("%s(): (a)bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt);
-
-
-		for(i=0; i<9; i++)
-		{
-			RTW_INFO("%s():bcn_delay_cnt[%d]=%d,  bcn_delay_ratio[%d]=%d\n", __func__, i,
-				pmlmeext->bcn_delay_cnt[i] , i, pmlmeext->bcn_delay_ratio[i]);
-		}
-	*/
-
-	/* dump for  adaptive_early_32k */
-	if (pmlmeext->bcn_cnt > 100 && (pmlmeext->adaptive_tsf_done == _TRUE)) {
-		u8 ratio_20_delay, ratio_80_delay;
-		u8 DrvBcnEarly, DrvBcnTimeOut;
-
-		ratio_20_delay = 0;
-		ratio_80_delay = 0;
-		DrvBcnEarly = 0xff;
-		DrvBcnTimeOut = 0xff;
-
-		RTW_INFO("%s(): bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt);
-
-		for (i = 0; i < 9; i++) {
-			pmlmeext->bcn_delay_ratio[i] = (pmlmeext->bcn_delay_cnt[i] * 100) / pmlmeext->bcn_cnt;
-
-
-			/* RTW_INFO("%s():bcn_delay_cnt[%d]=%d,  bcn_delay_ratio[%d]=%d\n", __func__, i,  */
-			/*	pmlmeext->bcn_delay_cnt[i] , i, pmlmeext->bcn_delay_ratio[i]); */
-
-			ratio_20_delay += pmlmeext->bcn_delay_ratio[i];
-			ratio_80_delay += pmlmeext->bcn_delay_ratio[i];
-
-			if (ratio_20_delay > 20 && DrvBcnEarly == 0xff) {
-				DrvBcnEarly = i;
-				/* RTW_INFO("%s(): DrvBcnEarly = %d\n", __func__, DrvBcnEarly); */
-			}
-
-			if (ratio_80_delay > 80 && DrvBcnTimeOut == 0xff) {
-				DrvBcnTimeOut = i;
-				/* RTW_INFO("%s(): DrvBcnTimeOut = %d\n", __func__, DrvBcnTimeOut); */
-			}
-
-			/* reset adaptive_early_32k cnt */
-			pmlmeext->bcn_delay_cnt[i] = 0;
-			pmlmeext->bcn_delay_ratio[i] = 0;
-		}
-
-		pmlmeext->DrvBcnEarly = DrvBcnEarly;
-		pmlmeext->DrvBcnTimeOut = DrvBcnTimeOut;
-
-		pmlmeext->bcn_cnt = 0;
-	}
+	u16 rx_bcn_time = 0;/*us*/
 
+	if (data_rate == DESC_RATE1M)
+		rx_bcn_time = 192 + bcn_len * 8 + 10;
+	else if(data_rate == DESC_RATE6M)
+		rx_bcn_time = 8 + 8 + 4 + (bcn_len /3 + 1) * 4 + 10;
+/*
+	else
+		RTW_ERR("%s invalid data rate(0x%02x)\n", __func__, data_rate);
+*/
+	return rx_bcn_time;
 }
+void rtw_rx_bcn_time_update(_adapter *adapter, uint bcn_len, u8 data_rate)
+{
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
 
+	pmlmeext->bcn_rx_time = _rx_bcn_time_calculate(bcn_len, data_rate);
+}
+#endif
 
 void beacon_timing_control(_adapter *padapter)
 {
@@ -3467,22 +3693,6 @@ inline void rtw_macid_map_set(struct macid_bmp *map, u8 id)
 		rtw_warn_on(1);
 }
 
-/*Record bc's mac-id and sec-cam-id*/
-inline void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-
-	macid_ctl->iface_bmc[padapter->iface_id] = mac_id;
-}
-inline u8 rtw_iface_bcmc_id_get(_adapter *padapter)
-{
-	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-
-	return macid_ctl->iface_bmc[padapter->iface_id];
-}
-
 inline void rtw_macid_map_clr(struct macid_bmp *map, u8 id)
 {
 	if (id < 32)
@@ -3568,6 +3778,33 @@ inline s8 rtw_macid_get_ch_g(struct macid_ctl_t *macid_ctl, u8 id)
 	return -1;
 }
 
+/*Record bc's mac-id and sec-cam-id*/
+inline void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+
+	macid_ctl->iface_bmc[padapter->iface_id] = mac_id;
+}
+inline u8 rtw_iface_bcmc_id_get(_adapter *padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+
+	return macid_ctl->iface_bmc[padapter->iface_id];
+}
+#if defined(DBG_CONFIG_ERROR_RESET) && defined(CONFIG_CONCURRENT_MODE)
+void rtw_iface_bcmc_sec_cam_map_restore(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
+	int cam_id = -1;
+
+	cam_id = rtw_iface_bcmc_id_get(adapter);
+	if (cam_id != INVALID_SEC_MAC_CAM_ID)
+		rtw_sec_cam_map_set(&cam_ctl->used, cam_id);
+}
+#endif
 void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta)
 {
 	int i;
@@ -3602,14 +3839,6 @@ void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta)
 		goto assigned;
 	}
 
-#ifdef CONFIG_MCC_MODE
-	if (MCC_EN(padapter)) {
-		if (MLME_IS_AP(padapter))
-			/* GO/AP assign client macid from 8 */
-			last_id = 8;
-	}
-#endif /* CONFIG_MCC_MODE */
-
 	_enter_critical_bh(&macid_ctl->lock, &irqL);
 
 	for (i = last_id; i < macid_ctl->num; i++) {
@@ -3867,6 +4096,87 @@ inline void rtw_macid_ctl_deinit(struct macid_ctl_t *macid_ctl)
 	_rtw_spinlock_free(&macid_ctl->lock);
 }
 
+inline bool rtw_bmp_is_set(const u8 *bmp, u8 bmp_len, u8 id)
+{
+	if (id / 8 >= bmp_len)
+		return 0;
+
+	return bmp[id / 8] & BIT(id % 8);
+}
+
+inline void rtw_bmp_set(u8 *bmp, u8 bmp_len, u8 id)
+{
+	if (id / 8 < bmp_len)
+		bmp[id / 8] |= BIT(id % 8);
+}
+
+inline void rtw_bmp_clear(u8 *bmp, u8 bmp_len, u8 id)
+{
+	if (id / 8 < bmp_len)
+		bmp[id / 8] &= ~BIT(id % 8);
+}
+
+inline bool rtw_bmp_not_empty(const u8 *bmp, u8 bmp_len)
+{
+	int i;
+
+	for (i = 0; i < bmp_len; i++) {
+		if (bmp[i])
+			return 1;
+	}
+
+	return 0;
+}
+
+inline bool rtw_bmp_not_empty_exclude_bit0(const u8 *bmp, u8 bmp_len)
+{
+	int i;
+
+	for (i = 0; i < bmp_len; i++) {
+		if (i == 0) {
+			if (bmp[i] & 0xFE)
+				return 1;
+		} else {
+			if (bmp[i])
+				return 1;
+		}
+	}
+
+	return 0;
+}
+
+#ifdef CONFIG_AP_MODE
+/* Check the id be set or not in map , if yes , return a none zero value*/
+bool rtw_tim_map_is_set(_adapter *padapter, const u8 *map, u8 id)
+{
+	return rtw_bmp_is_set(map, padapter->stapriv.aid_bmp_len, id);
+}
+
+/* Set the id into map array*/
+void rtw_tim_map_set(_adapter *padapter, u8 *map, u8 id)
+{
+	rtw_bmp_set(map, padapter->stapriv.aid_bmp_len, id);
+}
+
+/* Clear the id from map array*/
+void rtw_tim_map_clear(_adapter *padapter, u8 *map, u8 id)
+{
+	rtw_bmp_clear(map, padapter->stapriv.aid_bmp_len, id);
+}
+
+/* Check have anyone bit be set , if yes return true*/
+bool rtw_tim_map_anyone_be_set(_adapter *padapter, const u8 *map)
+{
+	return rtw_bmp_not_empty(map, padapter->stapriv.aid_bmp_len);
+}
+
+/* Check have anyone bit be set exclude bit0 , if yes return true*/
+bool rtw_tim_map_anyone_be_set_exclude_aid0(_adapter *padapter, const u8 *map)
+{
+	return rtw_bmp_not_empty_exclude_bit0(map, padapter->stapriv.aid_bmp_len);
+}
+#endif /* CONFIG_AP_MODE */
+
 #if 0
 unsigned int setup_beacon_frame(_adapter *padapter, unsigned char *beacon_frame)
 {
@@ -4647,3 +4957,16 @@ void rtw_dev_pno_debug(struct net_device *net)
 }
 #endif /* CONFIG_PNO_SET_DEBUG */
 #endif /* CONFIG_PNO_SUPPORT */
+
+inline void rtw_collect_bcn_info(_adapter *adapter)
+{
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+
+	if (!is_client_associated_to_ap(adapter))
+		return;
+
+	pmlmeext->cur_bcn_cnt = pmlmeext->bcn_cnt - pmlmeext->last_bcn_cnt;
+	pmlmeext->last_bcn_cnt = pmlmeext->bcn_cnt;
+	/*TODO get offset of bcn's timestamp*/
+	/*pmlmeext->bcn_timestamp;*/
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_xmit.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_xmit.c
index e7902ca013e9..f4685924e309 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_xmit.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/core/rtw_xmit.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -471,7 +472,6 @@ void rtw_get_adapter_tx_rate_bmp_by_bw(_adapter *adapter, u8 bw, u16 *r_bmp_cck_
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 	u8 fix_bw = 0xFF;
 	u16 bmp_cck_ofdm = 0;
 	u32 bmp_ht = 0;
@@ -504,7 +504,6 @@ void rtw_get_adapter_tx_rate_bmp_by_bw(_adapter *adapter, u8 bw, u16 *r_bmp_cck_
 
 	/* TODO: mlmeext->tx_rate*/
 
-exit:
 	if (r_bmp_cck_ofdm)
 		*r_bmp_cck_ofdm = bmp_cck_ofdm;
 	if (r_bmp_ht)
@@ -925,8 +924,7 @@ static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattri
 	pattrib->triggered = 0;
 	pattrib->ampdu_spacing = 0;
 
-	/* qos_en, ht_en, init rate, ,bw, ch_offset, sgi */
-	pattrib->qos_en = psta->qos_option;
+	/* ht_en, init rate, ,bw, ch_offset, sgi */
 
 	pattrib->raid = psta->cmn.ra_info.rate_id;
 
@@ -938,23 +936,26 @@ static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattri
 	pattrib->stbc = psta->cmn.stbc_en;
 
 #ifdef CONFIG_80211N_HT
-	pattrib->ht_en = psta->htpriv.ht_option;
-	pattrib->ch_offset = psta->htpriv.ch_offset;
-	pattrib->ampdu_en = _FALSE;
+	if(padapter->registrypriv.ht_enable &&
+		is_supported_ht(padapter->registrypriv.wireless_mode)) {
+		pattrib->ht_en = psta->htpriv.ht_option;
+		pattrib->ch_offset = psta->htpriv.ch_offset;
+		pattrib->ampdu_en = _FALSE;
 
-	if (padapter->driver_ampdu_spacing != 0xFF) /* driver control AMPDU Density for peer sta's rx */
-		pattrib->ampdu_spacing = padapter->driver_ampdu_spacing;
-	else
-		pattrib->ampdu_spacing = psta->htpriv.rx_ampdu_min_spacing;
-
-	/* check if enable ampdu */
-	if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
-		if (psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority)) {
-			pattrib->ampdu_en = _TRUE;
-			if (psta->htpriv.tx_amsdu_enable == _TRUE)
-				pattrib->amsdu_ampdu_en = _TRUE;
-			else
-				pattrib->amsdu_ampdu_en = _FALSE;
+		if (padapter->driver_ampdu_spacing != 0xFF) /* driver control AMPDU Density for peer sta's rx */
+			pattrib->ampdu_spacing = padapter->driver_ampdu_spacing;
+		else
+			pattrib->ampdu_spacing = psta->htpriv.rx_ampdu_min_spacing;
+
+		/* check if enable ampdu */
+		if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
+			if (psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority)) {
+				pattrib->ampdu_en = _TRUE;
+				if (psta->htpriv.tx_amsdu_enable == _TRUE)
+					pattrib->amsdu_ampdu_en = _TRUE;
+				else
+					pattrib->amsdu_ampdu_en = _FALSE;
+			}
 		}
 	}
 #endif /* CONFIG_80211N_HT */
@@ -970,10 +971,13 @@ static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattri
 
 		pattrib->raid = psta->cmn.ra_info.rate_id;
 #ifdef CONFIG_80211N_HT
-		pattrib->bwmode = rtw_get_tx_bw_mode(padapter, psta);
-		pattrib->ht_en = psta->htpriv.ht_option;
-		pattrib->ch_offset = psta->htpriv.ch_offset;
-		pattrib->sgi = query_ra_short_GI(psta, pattrib->bwmode);
+	if(padapter->registrypriv.ht_enable &&
+		is_supported_ht(padapter->registrypriv.wireless_mode)) {
+			pattrib->bwmode = rtw_get_tx_bw_mode(padapter, psta);
+			pattrib->ht_en = psta->htpriv.ht_option;
+			pattrib->ch_offset = psta->htpriv.ch_offset;
+			pattrib->sgi = query_ra_short_GI(psta, pattrib->bwmode);
+	}
 #endif /* CONFIG_80211N_HT */
 	}
 #endif /* CONFIG_TDLS */
@@ -1185,6 +1189,15 @@ static void set_qos(struct pkt_file *ppktfile, struct pkt_attrib *pattrib)
 			UserPriority = 7;
 		}
 	*/
+
+	#ifdef CONFIG_ICMP_VOQ
+	if(pattrib->icmp_pkt==1)/*use VO queue to send icmp packet*/
+		UserPriority = 7;
+	#endif
+	#ifdef CONFIG_IP_R_MONITOR
+	if (pattrib->ether_type == ETH_P_ARP)
+		UserPriority = 7;
+	#endif/*CONFIG_IP_R_MONITOR*/
 	pattrib->priority = UserPriority;
 	pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
 	pattrib->subtype = WIFI_QOS_DATA_TYPE;
@@ -1273,18 +1286,49 @@ exit:
 
 #endif /* CONFIG_TDLS */
 
-/*get non-qos hw_ssn control register,mapping to REG_HW_SEQ0,1,2,3*/
+/*get non-qos hw_ssn control register,mapping to REG_HW_SEQ 0,1,2,3*/
 inline u8 rtw_get_hwseq_no(_adapter *padapter)
 {
 	u8 hwseq_num = 0;
+
 #ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
+	#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
+	hwseq_num = padapter->iface_id;
+	if (hwseq_num > 3)
+		hwseq_num = 3;
+	#else
+	if (!is_primary_adapter(padapter))
 		hwseq_num = 1;
-	/* else */
-	/*	hwseq_num = 2; */
+	#endif
 #endif /* CONFIG_CONCURRENT_MODE */
 	return hwseq_num;
 }
+#ifdef CONFIG_LPS
+#define LPS_PT_NORMAL	0
+#define LPS_PT_SP		1/* only DHCP packets is as SPECIAL_PACKET*/
+#define LPS_PT_ICMP		2
+
+/*If EAPOL , ARP , OR DHCP packet, driver must be in active mode.*/
+static u8 _rtw_lps_chk_packet_type(struct pkt_attrib *pattrib)
+{
+	u8 pkt_type = LPS_PT_NORMAL; /*normal data frame*/
+
+	#ifdef CONFIG_WAPI_SUPPORT
+	if ((pattrib->ether_type == 0x88B4) || (pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
+		pkt_type = LPS_PT_SP;
+	#else /* !CONFIG_WAPI_SUPPORT */
+
+	#ifndef CONFIG_LPS_NOT_LEAVE_FOR_ICMP
+	if (pattrib->icmp_pkt == 1)
+		pkt_type = LPS_PT_ICMP;
+	else
+	#endif
+		if (pattrib->dhcp_pkt == 1)
+			pkt_type = LPS_PT_SP;
+	#endif
+	return pkt_type;
+}
+#endif
 static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattrib)
 {
 	uint i;
@@ -1294,12 +1338,13 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 
 	sint bmcast;
 	struct sta_priv		*pstapriv = &padapter->stapriv;
-	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	struct qos_priv		*pqospriv = &pmlmepriv->qospriv;
 	struct xmit_priv		*pxmitpriv = &padapter->xmitpriv;
 	sint res = _SUCCESS;
-
+#ifdef CONFIG_LPS
+	u8 pkt_type = 0;
+#endif
 
 	DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib);
 
@@ -1308,11 +1353,12 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 
 	pattrib->ether_type = ntohs(etherhdr.h_proto);
 
+	if (MLME_IS_MESH(padapter)) /* address resolve is done for mesh */
+		goto get_sta_info;
 
 	_rtw_memcpy(pattrib->dst, &etherhdr.h_dest, ETH_ALEN);
 	_rtw_memcpy(pattrib->src, &etherhdr.h_source, ETH_ALEN);
 
-
 	if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
 	    (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
 		_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
@@ -1334,14 +1380,15 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 	} else
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_unknown);
 
+get_sta_info:
 	bmcast = IS_MCAST(pattrib->ra);
 	if (bmcast) {
 		psta = rtw_get_bcmc_stainfo(padapter);
 		if (psta == NULL) { /* if we cannot get psta => drop the pkt */
 			DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_sta);
-#ifdef DBG_TX_DROP_FRAME
+			#ifdef DBG_TX_DROP_FRAME
 			RTW_INFO("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
-#endif
+			#endif
 			res = _FAIL;
 			goto exit;
 		}
@@ -1349,9 +1396,9 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 		psta = rtw_get_stainfo(pstapriv, pattrib->ra);
 		if (psta == NULL) { /* if we cannot get psta => drop the pkt */
 			DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_ucast_sta);
-#ifdef DBG_TX_DROP_FRAME
+			#ifdef DBG_TX_DROP_FRAME
 			RTW_INFO("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
-#endif
+			#endif
 			res = _FAIL;
 			goto exit;
 		} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE && !(psta->state & _FW_LINKED)) {
@@ -1438,29 +1485,34 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 		}
 
 	} else if (0x888e == pattrib->ether_type)
-		RTW_PRINT("send eapol packet\n");
+		parsing_eapol_packet(padapter, pktfile.cur_addr, psta, 1);
+#ifdef DBG_ARP_DUMP
+	else if (pattrib->ether_type == ETH_P_ARP) {
+		u8 arp[28] = {0};
+
+		_rtw_pktfile_read(&pktfile, arp, 28);
+		dump_arp_pkt(RTW_DBGDUMP, etherhdr.h_dest, etherhdr.h_source, arp, 1);
+	}
+#endif
 
 	if ((pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
 		rtw_mi_set_scan_deny(padapter, 3000);
 
+	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) &&
+		pattrib->ether_type == ETH_P_ARP &&
+		!IS_MCAST(pattrib->dst)) {
+		rtw_mi_set_scan_deny(padapter, 1000);
+		rtw_mi_scan_abort(padapter, _FALSE); /*rtw_scan_abort_no_wait*/
+	}
+
 #ifdef CONFIG_LPS
-	/* If EAPOL , ARP , OR DHCP packet, driver must be in active mode. */
-#ifdef CONFIG_WAPI_SUPPORT
-	if ((pattrib->ether_type == 0x88B4) || (pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
-#else /* !CONFIG_WAPI_SUPPORT */
-#if 0
-	if ((pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
-#else /* only ICMP/DHCP packets is as SPECIAL_PACKET, and leave LPS when tx IMCP/DHCP packets. */
-	/* if ((pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1) ) */
-	if (pattrib->icmp_pkt == 1)
-		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1);
-	else if (pattrib->dhcp_pkt == 1)
-#endif
-#endif
-	{
+	pkt_type = _rtw_lps_chk_packet_type(pattrib);
+
+	if (pkt_type == LPS_PT_SP) {/*packet is as SPECIAL_PACKET*/
 		DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_active);
 		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_SPECIAL_PACKET, 1);
-	}
+	} else if (pkt_type == LPS_PT_ICMP)
+		rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 1);
 #endif /* CONFIG_LPS */
 
 #ifdef CONFIG_BEAMFORMING
@@ -1474,29 +1526,24 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 		goto exit;
 	}
 
-	update_attrib_phy_info(padapter, pattrib, psta);
-
-	/* RTW_INFO("%s ==> mac_id(%d)\n",__FUNCTION__,pattrib->mac_id ); */
-
-	pattrib->psta = psta;
-	/* TODO:_unlock */
-
-	pattrib->pctrl = 0;
-
-	pattrib->ack_policy = 0;
 	/* get ether_hdr_len */
 	pattrib->pkt_hdrlen = ETH_HLEN;/* (pattrib->ether_type == 0x8100) ? (14 + 4 ): 14; */ /* vlan tag */
 
 	pattrib->hdrlen = WLAN_HDR_A3_LEN;
 	pattrib->subtype = WIFI_DATA_TYPE;
+	pattrib->qos_en = psta->qos_option;
 	pattrib->priority = 0;
 
-	if (bmcast)
-		pattrib->rate = psta->init_rate;
-
-	if (check_fwstate(pmlmepriv, WIFI_AP_STATE | WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
-		if (pattrib->qos_en)
+	if (check_fwstate(pmlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE
+		| WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)
+	) {
+		if (pattrib->qos_en) {
 			set_qos(&pktfile, pattrib);
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter))
+				rtw_mesh_tx_set_whdr_mctrl_len(pattrib->mesh_frame_mode, pattrib);
+			#endif
+		}
 	} else {
 #ifdef CONFIG_TDLS
 		if (pattrib->direct_link == _TRUE) {
@@ -1513,6 +1560,21 @@ static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattr
 			}
 		}
 	}
+	
+	update_attrib_phy_info(padapter, pattrib, psta);
+
+	/* RTW_INFO("%s ==> mac_id(%d)\n",__FUNCTION__,pattrib->mac_id ); */
+
+	pattrib->psta = psta;
+	/* TODO:_unlock */
+
+	pattrib->pctrl = 0;
+
+	pattrib->ack_policy = 0;
+
+	if (bmcast)
+		pattrib->rate = psta->init_rate;
+
 
 #ifdef CONFIG_WMMPS_STA
 	update_attrib_trigger_frame_info(padapter, pattrib);
@@ -1534,7 +1596,6 @@ static s32 xmitframe_addmic(_adapter *padapter, struct xmit_frame *pxmitframe)
 	u8	*pframe, *payload, mic[8];
 	struct	mic_data		micdata;
 	/* struct	sta_info		*stainfo; */
-	struct	qos_priv   *pqospriv = &(padapter->mlmepriv.qospriv);
 	struct	pkt_attrib	*pattrib = &pxmitframe->attrib;
 	struct	security_priv	*psecuritypriv = &padapter->securitypriv;
 	struct	xmit_priv		*pxmitpriv = &padapter->xmitpriv;
@@ -1618,7 +1679,6 @@ static s32 xmitframe_addmic(_adapter *padapter, struct xmit_frame *pxmitframe)
 
 			}
 
-			/* if(pqospriv->qos_option==1) */
 			if (pattrib->qos_en)
 				priority[0] = (u8)pxmitframe->attrib.priority;
 
@@ -1779,6 +1839,17 @@ s32 rtw_make_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib)
 
 			if (pattrib->qos_en)
 				qos_option = _TRUE;
+#ifdef CONFIG_RTW_MESH
+		} else if (check_fwstate(pmlmepriv, WIFI_MESH_STATE) == _TRUE) {
+			rtw_mesh_tx_build_whdr(padapter, pattrib, fctrl, pwlanhdr);
+			if (pattrib->qos_en)
+				qos_option = _TRUE;
+			else {
+				RTW_WARN("[%s] !qos_en in Mesh\n", __FUNCTION__);
+				res = _FAIL;
+				goto exit;
+			}
+#endif
 		} else {
 			res = _FAIL;
 			goto exit;
@@ -1802,6 +1873,18 @@ s32 rtw_make_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib)
 
 			if(pattrib->amsdu)
 				SetAMsdu(qc, pattrib->amsdu);
+#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter)) {
+				/* active: don't care, light sleep: 0, deep sleep: 1*/
+				set_mps_lv(qc, 0); //TBD
+
+				/* TBD: temporary set (rspi, eosp) = (0, 1) which means End MPSP */
+				set_rspi(qc, 0);
+				SetEOSP(qc, 1);
+				
+				set_mctrl_present(qc, 1);
+			}
+#endif
 		}
 
 		/* TODO: fill HT Control Field */
@@ -2234,6 +2317,7 @@ u32 rtw_calculate_wlan_pkt_size_by_attribue(struct pkt_attrib *pattrib)
 
 	len = pattrib->hdrlen /* WLAN Header */
 		+ pattrib->iv_len /* IV */
+		+ XATTRIB_GET_MCTRL_LEN(pattrib)
 		+ SNAP_SIZE + sizeof(u16) /* LLC */
 		+ pattrib->pktlen
 		+ (pattrib->encrypt == _TKIP_ ? 8 : 0) /* MIC */
@@ -2347,7 +2431,6 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 	pattrib->amsdu = 1;
 
 	if (rtw_make_wlanhdr(padapter, mem_start, pattrib) == _FAIL) {
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n"));
 		RTW_INFO("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n");
 		res = _FAIL;
 		goto exit;
@@ -2366,9 +2449,8 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 	if (pattrib->iv_len) {
 		_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len); // queue or new?
 
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_notice_,
-			("rtw_xmitframe_coalesce: 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)));
+		RTW_DBG("rtw_xmitframe_coalesce: 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;
 	}
@@ -2383,16 +2465,28 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 		_rtw_open_pktfile(pkt_queue, &pktfile_queue);
 		_rtw_pktfile_read(&pktfile_queue, NULL, pattrib_queue->pkt_hdrlen);
 
-		/* 802.3 MAC Header DA(6)  SA(6)  Len(2)*/
-
-		_rtw_memcpy(pframe, pattrib_queue->dst, ETH_ALEN);
-		pframe += ETH_ALEN;
-
-		_rtw_memcpy(pframe, pattrib_queue->src, ETH_ALEN);
-		pframe += ETH_ALEN;
-
-		len = (u16*) pframe;
-		pframe += 2;
+		#ifdef CONFIG_RTW_MESH
+		if (MLME_IS_MESH(padapter)) {
+			/* mDA(6), mSA(6), len(2), mctrl */
+			_rtw_memcpy(pframe, pattrib_queue->mda, ETH_ALEN);
+			pframe += ETH_ALEN;
+			_rtw_memcpy(pframe, pattrib_queue->msa, ETH_ALEN);
+			pframe += ETH_ALEN;
+			len = (u16*)pframe;
+			pframe += 2;
+			rtw_mesh_tx_build_mctrl(padapter, pattrib_queue, pframe);
+			pframe += XATTRIB_GET_MCTRL_LEN(pattrib_queue);
+		} else
+		#endif
+		{
+			/* 802.3 MAC Header DA(6)  SA(6)  Len(2)*/
+			_rtw_memcpy(pframe, pattrib_queue->dst, ETH_ALEN);
+			pframe += ETH_ALEN;
+			_rtw_memcpy(pframe, pattrib_queue->src, ETH_ALEN);
+			pframe += ETH_ALEN;
+			len = (u16*)pframe;
+			pframe += 2;
+		}
 
 		llc_sz = rtw_put_snap(pframe, pattrib_queue->ether_type);
 		pframe += llc_sz;
@@ -2400,17 +2494,17 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 		mem_sz = _rtw_pktfile_read(&pktfile_queue, pframe, pattrib_queue->pktlen);
 		pframe += mem_sz;
 
-		*len = htons(llc_sz + mem_sz);
+		*len = htons(XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz);
 
 		//calc padding
-		padding = 4 - ((ETH_HLEN + llc_sz + mem_sz) & (4-1));
+		padding = 4 - ((ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz) & (4-1));
 		if(padding == 4)
 			padding = 0;
 
 		//_rtw_memset(pframe,0xaa, padding);
 		pframe += padding;
 
-		pattrib->last_txcmdsz += ETH_HLEN + llc_sz + mem_sz + padding ;
+		pattrib->last_txcmdsz += ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz + padding ;
 	}
 
 	//2nd mpdu
@@ -2419,16 +2513,28 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 	_rtw_open_pktfile(pkt, &pktfile);
 	_rtw_pktfile_read(&pktfile, NULL, pattrib->pkt_hdrlen);
 
-	/* 802.3 MAC Header  DA(6)  SA(6)  Len(2) */
-
-	_rtw_memcpy(pframe, pattrib->dst, ETH_ALEN);
-	pframe += ETH_ALEN;
-
-	_rtw_memcpy(pframe, pattrib->src, ETH_ALEN);
-	pframe += ETH_ALEN;
-
-	len = (u16*) pframe;
-	pframe += 2;
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		/* mDA(6), mSA(6), len(2), mctrl */
+		_rtw_memcpy(pframe, pattrib->mda, ETH_ALEN);
+		pframe += ETH_ALEN;
+		_rtw_memcpy(pframe, pattrib->msa, ETH_ALEN);
+		pframe += ETH_ALEN;
+		len = (u16*)pframe;
+		pframe += 2;
+		rtw_mesh_tx_build_mctrl(padapter, pattrib, pframe);
+		pframe += XATTRIB_GET_MCTRL_LEN(pattrib);
+	} else
+#endif
+	{
+		/* 802.3 MAC Header  DA(6)  SA(6)  Len(2) */
+		_rtw_memcpy(pframe, pattrib->dst, ETH_ALEN);
+		pframe += ETH_ALEN;
+		_rtw_memcpy(pframe, pattrib->src, ETH_ALEN);
+		pframe += ETH_ALEN;
+		len = (u16*)pframe;
+		pframe += 2;
+	}
 
 	llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
 	pframe += llc_sz;
@@ -2437,14 +2543,14 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 
 	pframe += mem_sz;
 
-	*len = htons(llc_sz + mem_sz);
+	*len = htons(XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz + mem_sz);
 
 	//the last ampdu has no padding
 	padding = 0;
 
 	pattrib->nr_frags = 1;
 
-	pattrib->last_txcmdsz += ETH_HLEN + llc_sz + mem_sz + padding +
+	pattrib->last_txcmdsz += ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz + mem_sz + padding +
 		((pattrib->bswenc) ? pattrib->icv_len : 0) ;
 
 	if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
@@ -2453,7 +2559,6 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 	}
 
 	if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
-		RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("xmitframe_addmic(padapter, pxmitframe)==_FAIL\n"));
 		RTW_INFO("xmitframe_addmic(padapter, pxmitframe)==_FAIL\n");
 		res = _FAIL;
 		goto exit;
@@ -2461,7 +2566,7 @@ s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitfra
 
 	xmitframe_swencrypt(padapter, pxmitframe);
 
-	pattrib->vcs_mode = NONE_VCS;
+	update_attrib_vcs_info(padapter, pxmitframe);
 
 exit:
 	return res;
@@ -2614,6 +2719,14 @@ s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxm
 		}
 
 		if (frg_inx == 0) {
+			#ifdef CONFIG_RTW_MESH
+			if (MLME_IS_MESH(padapter)) {
+				rtw_mesh_tx_build_mctrl(padapter, pattrib, pframe);
+				pframe += XATTRIB_GET_MCTRL_LEN(pattrib);
+				mpdu_len -= XATTRIB_GET_MCTRL_LEN(pattrib);
+			}
+			#endif
+
 			llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
 			pframe += llc_sz;
 			mpdu_len -= llc_sz;
@@ -2641,7 +2754,8 @@ s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxm
 		if (bmcst || (rtw_endofpktfile(&pktfile) == _TRUE)) {
 			pattrib->nr_frags = frg_inx;
 
-			pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len + ((pattrib->nr_frags == 1) ? llc_sz : 0) +
+			pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len +
+				((pattrib->nr_frags == 1) ? (XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz) : 0) +
 				((pattrib->bswenc) ? pattrib->icv_len : 0) + mem_sz;
 
 			ClearMFrag(mem_start);
@@ -2675,15 +2789,23 @@ exit:
 	return res;
 }
 
-#ifdef CONFIG_IEEE80211W
-/* broadcast or multicast management pkt use BIP, unicast management pkt use CCMP encryption */
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+/*
+ * CCMP encryption for unicast robust mgmt frame and broadcast group privicy action
+ * BIP for broadcast robust mgmt frame
+ */
 s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe)
 {
+#define DBG_MGMT_XMIT_COALESEC_DUMP 0
+#define DBG_MGMT_XMIT_BIP_DUMP 0
+#define DBG_MGMT_XMIT_ENC_DUMP 0
+
 	struct pkt_file pktfile;
 	s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
 	SIZE_PTR addr;
 	u8 *pframe, *mem_start = NULL, *tmp_buf = NULL;
 	u8 hw_hdr_offset, subtype ;
+	u8 category = 0xFF;
 	struct sta_info		*psta = NULL;
 	struct xmit_priv	*pxmitpriv = &padapter->xmitpriv;
 	struct pkt_attrib	*pattrib = &pxmitframe->attrib;
@@ -2700,205 +2822,282 @@ s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame
 
 	_irqL irqL;
 	u32	ori_len;
+	union pn48 *pn = NULL;
+	u8 kid;
+
+	if (pxmitframe->buf_addr == NULL) {
+		RTW_WARN(FUNC_ADPT_FMT" pxmitframe->buf_addr\n"
+			, FUNC_ADPT_ARG(padapter));
+		return _FAIL;
+	}
+
 	mem_start = pframe = (u8 *)(pxmitframe->buf_addr) + TXDESC_OFFSET;
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	subtype = get_frame_sub_type(pframe); /* bit(7)~bit(2) */
+
+	/* check if robust mgmt frame */
+	if (subtype != WIFI_DEAUTH && subtype != WIFI_DISASSOC && subtype != WIFI_ACTION)
+		return _SUCCESS;
+	if (subtype == WIFI_ACTION) {
+		category = *(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
+		if (CATEGORY_IS_NON_ROBUST(category))
+			return _SUCCESS;
+	}
+	if (!bmcst) {
+		if (pattrib->psta)
+			psta = pattrib->psta;
+		else
+			pattrib->psta = psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
+		if (psta == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast sta == NULL\n", FUNC_ADPT_ARG(padapter));
+			return _FAIL;
+		}
+		if (!(psta->flags & WLAN_STA_MFP)) {
+			/* peer is not MFP capable, no need to encrypt */
+			return _SUCCESS;
+		}
+		if (psta->bpairwise_key_installed != _TRUE) {
+			RTW_INFO(FUNC_ADPT_FMT" PTK is not installed\n"
+				, FUNC_ADPT_ARG(padapter));
+			return _FAIL;
+		}
+	}
 
 	ori_len = BIP_AAD_SIZE + pattrib->pktlen;
 	tmp_buf = BIP_AAD = rtw_zmalloc(ori_len);
-	subtype = get_frame_sub_type(pframe); /* bit(7)~bit(2) */
-
 	if (BIP_AAD == NULL)
 		return _FAIL;
 
 	_enter_critical_bh(&padapter->security_key_mutex, &irqL);
 
-
-	/* IGTK key is not install, it may not support 802.11w */
-	if (padapter->securitypriv.binstallBIPkey != _TRUE) {
-		RTW_INFO("no instll BIP key\n");
-		goto xmitframe_coalesce_success;
-	}
-	/* station mode doesn't need TX BIP, just ready the code */
 	if (bmcst) {
-		int frame_body_len;
-		u8 mic[16];
+		if (subtype == WIFI_ACTION && CATEGORY_IS_GROUP_PRIVACY(category)) {
+			/* broadcast group privacy action frame */
+			#if DBG_MGMT_XMIT_COALESEC_DUMP
+			RTW_INFO(FUNC_ADPT_FMT" broadcast gp action(%u)\n"
+				, FUNC_ADPT_ARG(padapter), category);
+			#endif
 
-		_rtw_memset(MME, 0, _MME_IE_LENGTH_);
-
-		/* other types doesn't need the BIP */
-		if (get_frame_sub_type(pframe) != WIFI_DEAUTH && get_frame_sub_type(pframe) != WIFI_DISASSOC)
-			goto xmitframe_coalesce_fail;
-
-		MGMT_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
-		pframe += pattrib->pktlen;
-
-		/* octent 0 and 1 is key index ,BIP keyid is 4 or 5, LSB only need octent 0 */
-		MME[0] = padapter->securitypriv.dot11wBIPKeyid;
-		/* copy packet number */
-		_rtw_memcpy(&MME[2], &pmlmeext->mgnt_80211w_IPN, 6);
-		/* increase the packet number */
-		pmlmeext->mgnt_80211w_IPN++;
-
-		/* add MME IE with MIC all zero, MME string doesn't include element id and length */
-		pframe = rtw_set_ie(pframe, _MME_IE_ , 16 , MME, &(pattrib->pktlen));
-		pattrib->last_txcmdsz = pattrib->pktlen;
-		/* total frame length - header length */
-		frame_body_len = pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr);
-
-		/* conscruct AAD, copy frame control field */
-		_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
-		ClearRetry(BIP_AAD);
-		ClearPwrMgt(BIP_AAD);
-		ClearMData(BIP_AAD);
-		/* conscruct AAD, copy address 1 to address 3 */
-		_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
-		/* copy management fram body */
-		_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, MGMT_body, frame_body_len);
-#if 0
-		/* dump total packet include MME with zero MIC */
-		{
-			int i;
-			printk("Total packet: ");
-			for (i = 0; i < BIP_AAD_SIZE + frame_body_len; i++)
-				printk(" %02x ", BIP_AAD[i]);
-			printk("\n");
-		}
-#endif
-		/* calculate mic */
-		if (omac1_aes_128(padapter->securitypriv.dot11wBIPKey[padapter->securitypriv.dot11wBIPKeyid].skey
-			  , BIP_AAD, BIP_AAD_SIZE + frame_body_len, mic))
-			goto xmitframe_coalesce_fail;
-
-#if 0
-		/* dump calculated mic result */
-		{
-			int i;
-			printk("Calculated mic result: ");
-			for (i = 0; i < 16; i++)
-				printk(" %02x ", mic[i]);
-			printk("\n");
-		}
-#endif
-		/* copy right BIP mic value, total is 128bits, we use the 0~63 bits */
-		_rtw_memcpy(pframe - 8, mic, 8);
-		/*/dump all packet after mic ok
-		{
-			int pp;
-			printk("pattrib->pktlen = %d\n", pattrib->pktlen);
-			for(pp=0;pp< pattrib->pktlen; pp++)
-				printk(" %02x ", mem_start[pp]);
-			printk("\n");
-		}*/
-	} else { /* unicast mgmt frame TX */
-		/* start to encrypt mgmt frame */
-		if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC ||
-		    subtype == WIFI_REASSOCREQ || subtype == WIFI_ACTION) {
 			if (pattrib->psta)
 				psta = pattrib->psta;
 			else
-				psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
-
+				pattrib->psta = psta = rtw_get_bcmc_stainfo(padapter);
 			if (psta == NULL) {
-
-				RTW_INFO("%s, psta==NUL\n", __func__);
+				RTW_INFO(FUNC_ADPT_FMT" broadcast sta == NULL\n"
+					, FUNC_ADPT_ARG(padapter));
 				goto xmitframe_coalesce_fail;
 			}
-
-			if (pxmitframe->buf_addr == NULL) {
-				RTW_INFO("%s, pxmitframe->buf_addr\n", __func__);
+			if (padapter->securitypriv.binstallGrpkey != _TRUE) {
+				RTW_INFO(FUNC_ADPT_FMT" GTK is not installed\n"
+					, FUNC_ADPT_ARG(padapter));
 				goto xmitframe_coalesce_fail;
 			}
 
-			/* RTW_INFO("%s, action frame category=%d\n", __func__, pframe[WLAN_HDR_A3_LEN]); */
-			/* according 802.11-2012 standard, these five types are not robust types */
-			if (subtype == WIFI_ACTION &&
-			    (pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_PUBLIC ||
-			     pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_HT ||
-			     pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_UNPROTECTED_WNM ||
-			     pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_SELF_PROTECTED  ||
-			     pframe[WLAN_HDR_A3_LEN] == RTW_WLAN_CATEGORY_P2P))
-				goto xmitframe_coalesce_fail;
-			/* before encrypt dump the management packet content */
-			/*{
-				int i;
-				printk("Management pkt: ");
-				for(i=0; i<pattrib->pktlen; i++)
-				printk(" %02x ", pframe[i]);
-				printk("=======\n");
-			}*/
-			if (pattrib->encrypt > 0)
-				_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);
-
-			/* To use wrong key */
-			if (pattrib->key_type == IEEE80211W_WRONG_KEY) {
-				RTW_INFO("use wrong key\n");
-				pattrib->dot118021x_UncstKey.skey[0] = 0xff;
+			pn = &psta->dot11txpn;
+			kid = padapter->securitypriv.dot118021XGrpKeyid;
+		} else {
+			#ifdef CONFIG_IEEE80211W
+			/* broadcast robust mgmt frame, using BIP */
+			int frame_body_len;
+			u8 mic[16];
+
+			/* IGTK key is not install ex: mesh MFP without IGTK */
+			if (SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) != _TRUE)
+				goto xmitframe_coalesce_success;
+
+			#if DBG_MGMT_XMIT_COALESEC_DUMP
+			if (subtype == WIFI_DEAUTH)
+				RTW_INFO(FUNC_ADPT_FMT" braodcast deauth\n", FUNC_ADPT_ARG(padapter));
+			else if (subtype == WIFI_DISASSOC)
+				RTW_INFO(FUNC_ADPT_FMT" braodcast disassoc\n", FUNC_ADPT_ARG(padapter));
+			else if (subtype == WIFI_ACTION) {
+				RTW_INFO(FUNC_ADPT_FMT" braodcast action(%u)\n"
+					, FUNC_ADPT_ARG(padapter), category);
 			}
+			#endif
 
-			/* bakeup original management packet */
-			_rtw_memcpy(tmp_buf, pframe, pattrib->pktlen);
-			/* move to data portion */
-			pframe += pattrib->hdrlen;
+			_rtw_memset(MME, 0, _MME_IE_LENGTH_);
 
-			/* 802.11w unicast management packet must be _AES_ */
-			pattrib->iv_len = 8;
-			/* it's MIC of AES */
-			pattrib->icv_len = 8;
+			MGMT_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
+			pframe += pattrib->pktlen;
 
-			switch (pattrib->encrypt) {
-			case _AES_:
-				/* set AES IV header */
-				AES_IV(pattrib->iv, psta->dot11wtxpn, 0);
-				break;
-			default:
-				goto xmitframe_coalesce_fail;
-			}
-			/* insert iv header into management frame */
-			_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
-			pframe += pattrib->iv_len;
-			/* copy mgmt data portion after CCMP header */
-			_rtw_memcpy(pframe, tmp_buf + pattrib->hdrlen, pattrib->pktlen - pattrib->hdrlen);
-			/* move pframe to end of mgmt pkt */
-			pframe += pattrib->pktlen - pattrib->hdrlen;
-			/* add 8 bytes CCMP IV header to length */
-			pattrib->pktlen += pattrib->iv_len;
-#if 0
-			/* dump management packet include AES IV header */
+			/* octent 0 and 1 is key index ,BIP keyid is 4 or 5, LSB only need octent 0 */
+			MME[0] = padapter->securitypriv.dot11wBIPKeyid;
+			/* increase PN and apply to packet */
+			padapter->securitypriv.dot11wBIPtxpn.val++;
+			RTW_PUT_LE64(&MME[2], padapter->securitypriv.dot11wBIPtxpn.val);
+
+			/* add MME IE with MIC all zero, MME string doesn't include element id and length */
+			pframe = rtw_set_ie(pframe, _MME_IE_ , 16 , MME, &(pattrib->pktlen));
+			pattrib->last_txcmdsz = pattrib->pktlen;
+			/* total frame length - header length */
+			frame_body_len = pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr);
+
+			/* conscruct AAD, copy frame control field */
+			_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
+			ClearRetry(BIP_AAD);
+			ClearPwrMgt(BIP_AAD);
+			ClearMData(BIP_AAD);
+			/* conscruct AAD, copy address 1 to address 3 */
+			_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
+			/* copy management fram body */
+			_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, MGMT_body, frame_body_len);
+
+			#if DBG_MGMT_XMIT_BIP_DUMP
+			/* dump total packet include MME with zero MIC */
 			{
 				int i;
-				printk("Management pkt + IV: ");
-				/* for(i=0; i<pattrib->pktlen; i++) */
-
-				printk("@@@@@@@@@@@@@\n");
+				printk("Total packet: ");
+				for (i = 0; i < BIP_AAD_SIZE + frame_body_len; i++)
+					printk(" %02x ", BIP_AAD[i]);
+				printk("\n");
 			}
-#endif
+			#endif
 
-			if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
-				_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
-				pframe += pattrib->icv_len;
-			}
-			/* add 8 bytes MIC */
-			pattrib->pktlen += pattrib->icv_len;
-			/* set final tx command size */
-			pattrib->last_txcmdsz = pattrib->pktlen;
+			/* calculate mic */
+			if (omac1_aes_128(padapter->securitypriv.dot11wBIPKey[padapter->securitypriv.dot11wBIPKeyid].skey
+				  , BIP_AAD, BIP_AAD_SIZE + frame_body_len, mic))
+				goto xmitframe_coalesce_fail;
 
-			/* set protected bit must be beofre SW encrypt */
-			SetPrivacy(mem_start);
-#if 0
-			/* dump management packet include AES header */
+			#if DBG_MGMT_XMIT_BIP_DUMP
+			/* dump calculated mic result */
 			{
 				int i;
-				printk("prepare to enc Management pkt + IV: ");
-				for (i = 0; i < pattrib->pktlen; i++)
-					printk(" %02x ", mem_start[i]);
-				printk("@@@@@@@@@@@@@\n");
+				printk("Calculated mic result: ");
+				for (i = 0; i < 16; i++)
+					printk(" %02x ", mic[i]);
+				printk("\n");
 			}
-#endif
-			/* software encrypt */
-			xmitframe_swencrypt(padapter, pxmitframe);
+			#endif
+
+			/* copy right BIP mic value, total is 128bits, we use the 0~63 bits */
+			_rtw_memcpy(pframe - 8, mic, 8);
+
+			#if DBG_MGMT_XMIT_BIP_DUMP
+			/*dump all packet after mic ok */
+			{
+				int pp;
+				printk("pattrib->pktlen = %d\n", pattrib->pktlen);
+				for(pp=0;pp< pattrib->pktlen; pp++)
+					printk(" %02x ", mem_start[pp]);
+				printk("\n");
+			}
+			#endif
+
+			#endif /* CONFIG_IEEE80211W */
+
+			goto xmitframe_coalesce_success;
+		}
+	}
+	else {
+		/* unicast robust mgmt frame */
+		#if DBG_MGMT_XMIT_COALESEC_DUMP
+		if (subtype == WIFI_DEAUTH) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast deauth to "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(pattrib->ra));
+		} else if (subtype == WIFI_DISASSOC) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast disassoc to "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(pattrib->ra));
+		} else if (subtype == WIFI_ACTION) {
+			RTW_INFO(FUNC_ADPT_FMT" unicast action(%u) to "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), category, MAC_ARG(pattrib->ra));
+		}
+		#endif
+
+		_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);
+
+		/* To use wrong key */
+		if (pattrib->key_type == IEEE80211W_WRONG_KEY) {
+			RTW_INFO("use wrong key\n");
+			pattrib->dot118021x_UncstKey.skey[0] = 0xff;
 		}
+
+		pn = &psta->dot11txpn;
+		kid = 0;
 	}
 
+	#if DBG_MGMT_XMIT_ENC_DUMP
+	/* before encrypt dump the management packet content */
+	{
+		int i;
+		printk("Management pkt: ");
+		for(i=0; i<pattrib->pktlen; i++)
+		printk(" %02x ", pframe[i]);
+		printk("=======\n");
+	}
+	#endif
+
+	/* bakeup original management packet */
+	_rtw_memcpy(tmp_buf, pframe, pattrib->pktlen);
+	/* move to data portion */
+	pframe += pattrib->hdrlen;
+
+	/* 802.11w encrypted management packet must be _AES_ */
+	if (pattrib->key_type != IEEE80211W_NO_KEY) {
+		pattrib->encrypt = _AES_;
+		pattrib->bswenc = _TRUE;
+	}
+
+	pattrib->iv_len = 8;
+	/* it's MIC of AES */
+	pattrib->icv_len = 8;
+
+	switch (pattrib->encrypt) {
+	case _AES_:
+		/* set AES IV header */
+		AES_IV(pattrib->iv, (*pn), kid);
+		break;
+	default:
+		goto xmitframe_coalesce_fail;
+	}
+
+	/* insert iv header into management frame */
+	_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
+	pframe += pattrib->iv_len;
+	/* copy mgmt data portion after CCMP header */
+	_rtw_memcpy(pframe, tmp_buf + pattrib->hdrlen, pattrib->pktlen - pattrib->hdrlen);
+	/* move pframe to end of mgmt pkt */
+	pframe += pattrib->pktlen - pattrib->hdrlen;
+	/* add 8 bytes CCMP IV header to length */
+	pattrib->pktlen += pattrib->iv_len;
+
+	#if DBG_MGMT_XMIT_ENC_DUMP
+	/* dump management packet include AES IV header */
+	{
+		int i;
+		printk("Management pkt + IV: ");
+		/* for(i=0; i<pattrib->pktlen; i++) */
+
+		printk("@@@@@@@@@@@@@\n");
+	}
+	#endif
+
+	if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
+		_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
+		pframe += pattrib->icv_len;
+	}
+	/* add 8 bytes MIC */
+	pattrib->pktlen += pattrib->icv_len;
+	/* set final tx command size */
+	pattrib->last_txcmdsz = pattrib->pktlen;
+
+	/* set protected bit must be beofre SW encrypt */
+	SetPrivacy(mem_start);
+
+	#if DBG_MGMT_XMIT_ENC_DUMP
+	/* dump management packet include AES header */
+	{
+		int i;
+		printk("prepare to enc Management pkt + IV: ");
+		for (i = 0; i < pattrib->pktlen; i++)
+			printk(" %02x ", mem_start[i]);
+		printk("@@@@@@@@@@@@@\n");
+	}
+	#endif
+
+	/* software encrypt */
+	xmitframe_swencrypt(padapter, pxmitframe);
+
 xmitframe_coalesce_success:
 	_exit_critical_bh(&padapter->security_key_mutex, &irqL);
 	rtw_mfree(BIP_AAD, ori_len);
@@ -2910,7 +3109,7 @@ xmitframe_coalesce_fail:
 
 	return _FAIL;
 }
-#endif /* CONFIG_IEEE80211W */
+#endif /* defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH) */
 
 /* Logical Link Control(LLC) SubNetwork Attachment Point(SNAP) header
  * IEEE LLC/SNAP header contains 8 octets
@@ -3011,11 +3210,15 @@ void rtw_count_tx_stats(PADAPTER padapter, struct xmit_frame *pxmitframe, int sz
 			pstats->tx_pkts += pkt_num;
 
 			pstats->tx_bytes += sz;
+			#if defined(CONFIG_CHECK_LEAVE_LPS) && defined(CONFIG_LPS_CHK_BY_TP)
+			if (adapter_to_pwrctl(padapter)->lps_chk_by_tp)
+				traffic_check_for_leave_lps_by_tp(padapter, _TRUE, psta);
+			#endif /* CONFIG_LPS */
 		}
 
 #ifdef CONFIG_CHECK_LEAVE_LPS
 		/* traffic_check_for_leave_lps(padapter, _TRUE); */
-#endif /* CONFIG_LPS */
+#endif /* CONFIG_CHECK_LEAVE_LPS */
 
 	}
 }
@@ -3052,9 +3255,6 @@ static struct xmit_buf *__rtw_alloc_cmd_xmitbuf(struct xmit_priv *pxmitpriv,
 	} else
 		RTW_INFO("%s fail, no xmitbuf available !!!\n", __func__);
 
-exit:
-
-
 	return pxmitbuf;
 }
 
@@ -3585,10 +3785,6 @@ struct xmit_frame *rtw_get_xframe(struct xmit_priv *pxmitpriv, int *num_frame)
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 	int i, inx[4];
 
-#ifdef CONFIG_USB_HCI
-	/*	int j, tmp, acirp_cnt[4]; */
-#endif
-
 	inx[0] = 0;
 	inx[1] = 1;
 	inx[2] = 2;
@@ -3643,10 +3839,6 @@ struct xmit_frame *rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmi
 	_adapter *padapter = pxmitpriv->adapter;
 	struct registry_priv	*pregpriv = &padapter->registrypriv;
 	int i, inx[4];
-#ifdef CONFIG_USB_HCI
-	/*	int j, tmp, acirp_cnt[4]; */
-#endif
-
 
 	inx[0] = 0;
 	inx[1] = 1;
@@ -3654,7 +3846,7 @@ struct xmit_frame *rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmi
 	inx[3] = 3;
 
 	if (pregpriv->wifi_spec == 1) {
-		int j, tmp, acirp_cnt[4];
+		int j;
 #if 0
 		if (flags < XMIT_QUEUE_ENTRY) {
 			/* priority exchange according to the completed xmitbuf flags. */
@@ -3817,7 +4009,6 @@ s32 rtw_xmit_classifier(_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;
 	sint res = _SUCCESS;
 
@@ -3965,7 +4156,6 @@ void rtw_init_hwxmits(struct hw_xmit *phwxmit, sint entry)
 int rtw_br_client_tx(_adapter *padapter, struct sk_buff **pskb)
 {
 	struct sk_buff *skb = *pskb;
-	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	_irqL irqL;
 	/* if(check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE) */
 	{
@@ -4217,30 +4407,32 @@ static void do_queue_select(_adapter	*padapter, struct pkt_attrib *pattrib)
  #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
 s32 rtw_monitor_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;
 	u16 frame_ctl;
-	unsigned char src_mac_addr[6];
-	unsigned char dst_mac_addr[6];
-	struct rtw_ieee80211_hdr *dot11_hdr;
-	struct ieee80211_radiotap_header *rtap_hdr;
+	struct ieee80211_radiotap_header rtap_hdr;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct pkt_file pktfile;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct pkt_attrib	*pattrib;
+	struct xmit_frame		*pmgntframe;
+	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
+	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
+	unsigned char	*pframe;
+	u8 dummybuf[32];
+	int len = skb->len, rtap_len;
+
 
-	if (skb)
-		rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
+	rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
 
+#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
 	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))
+	_rtw_open_pktfile((_pkt *)skb, &pktfile);
+	_rtw_pktfile_read(&pktfile, (u8 *)(&rtap_hdr), sizeof(struct ieee80211_radiotap_header));
+	rtap_len = ieee80211_get_radiotap_len((u8 *)(&rtap_hdr));
+	if (unlikely(rtap_hdr.it_version))
 		goto fail;
 
-	rtap_len = ieee80211_get_radiotap_len(skb->data);
 	if (unlikely(skb->len < rtap_len))
 		goto fail;
 
@@ -4248,106 +4440,115 @@ s32 rtw_monitor_xmit_entry(struct sk_buff *skb, struct net_device *ndev)
 		RTW_INFO("radiotap len (should be 14): %d\n", rtap_len);
 		goto fail;
 	}
+	_rtw_pktfile_read(&pktfile, dummybuf, rtap_len-sizeof(struct ieee80211_radiotap_header));
+	len = len - rtap_len;
+#endif
+	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
+	if (pmgntframe == NULL) {
+		rtw_udelay_os(500);
+		goto fail;
+	}
 
-	/* Skip the ratio tap header */
-	skb_pull(skb, rtap_len);
+	_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+//	_rtw_memcpy(pframe, (void *)checking, len);
+	_rtw_pktfile_read(&pktfile, pframe, len);
 
-	dot11_hdr = (struct rtw_ieee80211_hdr *)skb->data;
-	frame_ctl = le16_to_cpu(dot11_hdr->frame_ctl);
-	/* Check if the QoS bit is set */
 
+	/* Check DATA/MGNT frames */
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	frame_ctl = le16_to_cpu(pwlanhdr->frame_ctl);
 	if ((frame_ctl & RTW_IEEE80211_FCTL_FTYPE) == RTW_IEEE80211_FTYPE_DATA) {
 
-		struct xmit_frame		*pmgntframe;
-		struct pkt_attrib	*pattrib;
-		unsigned char	*pframe;
-		struct rtw_ieee80211_hdr *pwlanhdr;
-		struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-		struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-		u8 *buf = skb->data;
-		u32 len = skb->len;
-		u8 category, action;
-		int type = -1;
-
-		pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-		if (pmgntframe == NULL) {
-			rtw_udelay_os(500);
-			goto fail;
-		}
 		pattrib = &pmgntframe->attrib;
-
 		update_monitor_frame_attrib(padapter, pattrib);
 
-		pattrib->retry_ctrl = _FALSE;
-
-		_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-		pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-		_rtw_memcpy(pframe, (void *)buf, len);
-
-		pattrib->pktlen = len;
-
-		pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
 		if (is_broadcast_mac_addr(pwlanhdr->addr3) || is_broadcast_mac_addr(pwlanhdr->addr1))
 			pattrib->rate = MGN_24M;
 
-		pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
-		pattrib->seqnum = pmlmeext->mgnt_seq;
-		pmlmeext->mgnt_seq++;
-
-		pattrib->last_txcmdsz = pattrib->pktlen;
-
-		dump_mgntframe(padapter, pmgntframe);
-
 	} else {
-		struct xmit_frame		*pmgntframe;
-		struct pkt_attrib	*pattrib;
-		unsigned char	*pframe;
-		struct rtw_ieee80211_hdr *pwlanhdr;
-		struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-		struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-		u8 *buf = skb->data;
-		u32 len = skb->len;
-		u8 category, action;
-		int type = -1;
-
-		pmgntframe = alloc_mgtxmitframe(pxmitpriv);
-		if (pmgntframe == NULL)
-			goto fail;
 
 		pattrib = &pmgntframe->attrib;
 		update_mgntframe_attrib(padapter, pattrib);
-		pattrib->retry_ctrl = _FALSE;
 
-		_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
+	}
+	pattrib->retry_ctrl = _FALSE;
+	pattrib->pktlen = len;
+	pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
+	pattrib->seqnum = pmlmeext->mgnt_seq;
+	pmlmeext->mgnt_seq++;
+	pattrib->last_txcmdsz = pattrib->pktlen;
 
-		pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
+	dump_mgntframe(padapter, pmgntframe);
 
-		_rtw_memcpy(pframe, (void *)buf, len);
+fail:
+	rtw_skb_free(skb);
+	return 0;
+}
+#endif
 
-		pattrib->pktlen = len;
+/*
+ * The main transmit(tx) entry post handle
+ *
+ * Return
+ *	1	enqueue
+ *	0	success, hardware will handle this xmit frame(packet)
+ *	<0	fail
+ */
+s32 rtw_xmit_posthandle(_adapter *padapter, struct xmit_frame *pxmitframe, _pkt *pkt)
+{
+#ifdef CONFIG_AP_MODE
+	_irqL irqL0;
+#endif
+	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
+	s32 res;
 
-		pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+	res = update_attrib(padapter, pkt, &pxmitframe->attrib);
 
-		pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
-		pattrib->seqnum = pmlmeext->mgnt_seq;
-		pmlmeext->mgnt_seq++;
+#ifdef CONFIG_MCC_MODE
+	/* record data kernel TX to driver to check MCC concurrent TX */
+	rtw_hal_mcc_calc_tx_bytes_from_kernel(padapter, pxmitframe->attrib.pktlen);
+#endif /* CONFIG_MCC_MODE */
 
-		pattrib->last_txcmdsz = pattrib->pktlen;
+#ifdef CONFIG_WAPI_SUPPORT
+	if (pxmitframe->attrib.ether_type != 0x88B4) {
+		if (rtw_wapi_drop_for_key_absent(padapter, pxmitframe->attrib.ra)) {
+			WAPI_TRACE(WAPI_RX, "drop for key absend when tx\n");
+			res = _FAIL;
+		}
+	}
+#endif
+	if (res == _FAIL) {
+		/*RTW_INFO("%s-"ADPT_FMT" update attrib fail\n", __func__, ADPT_ARG(padapter));*/
+#ifdef DBG_TX_DROP_FRAME
+		RTW_INFO("DBG_TX_DROP_FRAME %s update attrib fail\n", __FUNCTION__);
+#endif
+		rtw_free_xmitframe(pxmitpriv, pxmitframe);
+		return -1;
+	}
+	pxmitframe->pkt = pkt;
 
-		dump_mgntframe(padapter, pmgntframe);
+	rtw_led_tx_control(padapter, pxmitframe->attrib.dst);
 
-	}
+	do_queue_select(padapter, &pxmitframe->attrib);
 
-fail:
+#ifdef CONFIG_AP_MODE
+	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
+	if (xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe) == _TRUE) {
+		_exit_critical_bh(&pxmitpriv->lock, &irqL0);
+		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue);
+		return 1;
+	}
+	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
+#endif
 
-	rtw_skb_free(skb);
+	/* pre_xmitframe */
+	if (rtw_hal_xmit(padapter, pxmitframe) == _FALSE)
+		return 1;
 
 	return 0;
 }
-#endif
+
 /*
  * The main transmit(tx) entry
  *
@@ -4360,20 +4561,18 @@ s32 rtw_xmit(_adapter *padapter, _pkt **ppkt)
 {
 	static systime start = 0;
 	static u32 drop_cnt = 0;
-#ifdef CONFIG_AP_MODE
-	_irqL irqL0;
-#endif
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 	struct xmit_frame *pxmitframe = NULL;
-#ifdef CONFIG_BR_EXT
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	void *br_port = NULL;
-#endif /* CONFIG_BR_EXT */
-
 	s32 res;
 
 	DBG_COUNTER(padapter->tx_logs.core_tx);
 
+	if (IS_CH_WAITING(adapter_to_rfctl(padapter)))
+		return -1;
+
+	if (rtw_linked_check(padapter) == _FALSE)
+		return -1;
+
 	if (start == 0)
 		start = rtw_get_current_time();
 
@@ -4394,70 +4593,72 @@ s32 rtw_xmit(_adapter *padapter, _pkt **ppkt)
 	}
 
 #ifdef CONFIG_BR_EXT
+	if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE) {
+		void *br_port = NULL;
 
-#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
-	br_port = padapter->pnetdev->br_port;
-#else   /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
-	rcu_read_lock();
-	br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
-	rcu_read_unlock();
-#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
+		#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
+		br_port = padapter->pnetdev->br_port;
+		#else
+		rcu_read_lock();
+		br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
+		rcu_read_unlock();
+		#endif
 
-	if (br_port && check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE) {
-		res = rtw_br_client_tx(padapter, ppkt);
-		if (res == -1) {
-			rtw_free_xmitframe(pxmitpriv, pxmitframe);
-			DBG_COUNTER(padapter->tx_logs.core_tx_err_brtx);
-			return -1;
+		if (br_port) {
+			res = rtw_br_client_tx(padapter, ppkt);
+			if (res == -1) {
+				rtw_free_xmitframe(pxmitpriv, pxmitframe);
+				DBG_COUNTER(padapter->tx_logs.core_tx_err_brtx);
+				return -1;
+			}
 		}
 	}
-
 #endif /* CONFIG_BR_EXT */
 
-	res = update_attrib(padapter, *ppkt, &pxmitframe->attrib);
-
-#ifdef CONFIG_MCC_MODE
-	/* record data kernel TX to driver to check MCC concurrent TX */
-	rtw_hal_mcc_calc_tx_bytes_from_kernel(padapter, pxmitframe->attrib.pktlen);
-#endif /* CONFIG_MCC_MODE */
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		_list b2u_list;
 
-#ifdef CONFIG_WAPI_SUPPORT
-	if (pxmitframe->attrib.ether_type != 0x88B4) {
-		if (rtw_wapi_drop_for_key_absent(padapter, pxmitframe->attrib.ra)) {
-			WAPI_TRACE(WAPI_RX, "drop for key absend when tx\n");
-			res = _FAIL;
-		}
-	}
-#endif
-	if (res == _FAIL) {
-		/*RTW_INFO("%s-"ADPT_FMT" update attrib fail\n", __func__, ADPT_ARG(padapter));*/
-#ifdef DBG_TX_DROP_FRAME
-		RTW_INFO("DBG_TX_DROP_FRAME %s update attrib fail\n", __FUNCTION__);
-#endif
-		rtw_free_xmitframe(pxmitpriv, pxmitframe);
-		return -1;
-	}
-	pxmitframe->pkt = *ppkt;
+		res = rtw_mesh_addr_resolve(padapter, pxmitframe, *ppkt, &b2u_list);
+		if (res == RTW_RA_RESOLVING)
+			return 1;
+		if (res == _FAIL)
+			return -1;
 
-	rtw_led_control(padapter, LED_CTL_TX);
+		#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+		if (!rtw_is_list_empty(&b2u_list)) {
+			_list *list = get_next(&b2u_list);
+			struct xmit_frame *b2uframe;
+
+			while ((rtw_end_of_queue_search(&b2u_list, list)) == _FALSE) {
+				b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
+				list = get_next(list);
+				rtw_list_delete(&b2uframe->list);
+
+				b2uframe->pkt = rtw_os_pkt_copy(*ppkt);
+				if (!b2uframe->pkt) {
+					if (res == RTW_BMC_NO_NEED)
+						res = _SUCCESS;
+					rtw_free_xmitframe(pxmitpriv, b2uframe);
+					continue;
+				}
 
-	do_queue_select(padapter, &pxmitframe->attrib);
+				rtw_xmit_posthandle(padapter, b2uframe, b2uframe->pkt);
+			}
+		}
+		#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
 
-#ifdef CONFIG_AP_MODE
-	_enter_critical_bh(&pxmitpriv->lock, &irqL0);
-	if (xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe) == _TRUE) {
-		_exit_critical_bh(&pxmitpriv->lock, &irqL0);
-		DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue);
-		return 1;
+		if (res == RTW_BMC_NO_NEED) {
+			rtw_free_xmitframe(&padapter->xmitpriv, pxmitframe);
+			return 0;
+		}
 	}
-	_exit_critical_bh(&pxmitpriv->lock, &irqL0);
-#endif
+#endif /* CONFIG_RTW_MESH */
 
-	/* pre_xmitframe */
-	if (rtw_hal_xmit(padapter, pxmitframe) == _FALSE)
-		return 1;
+	pxmitframe->pkt = NULL; /* let rtw_xmit_posthandle not to free pkt inside */
+	res = rtw_xmit_posthandle(padapter, pxmitframe, *ppkt);
 
-	return 0;
+	return res;
 }
 
 #ifdef CONFIG_TDLS
@@ -4577,7 +4778,6 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 	struct sta_info *psta = NULL;
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	struct pkt_attrib *pattrib = &pxmitframe->attrib;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	sint bmcst = IS_MCAST(pattrib->ra);
 	bool update_tim = _FALSE;
 #ifdef CONFIG_TDLS
@@ -4635,7 +4835,7 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 	if (bmcst) {
 		_enter_critical_bh(&psta->sleep_q.lock, &irqL);
 
-		if (pstapriv->sta_dz_bitmap) { /* if anyone sta is in ps mode */
+		if (rtw_tim_map_anyone_be_set(padapter, pstapriv->sta_dz_bitmap)) { /* if anyone sta is in ps mode */
 			/* pattrib->qsel = QSLT_HIGH; */ /* HIQ */
 
 			rtw_list_delete(&pxmitframe->list);
@@ -4646,13 +4846,14 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 
 			psta->sleepq_len++;
 
-			if (!(pstapriv->tim_bitmap & BIT(0)))
+			if (!(rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)))
 				update_tim = _TRUE;
 
-			pstapriv->tim_bitmap |= BIT(0);
-			pstapriv->sta_dz_bitmap |= BIT(0);
+			rtw_tim_map_set(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, 0);
 
-			/* RTW_INFO("enqueue, sq_len=%d, tim=%x\n", psta->sleepq_len, pstapriv->tim_bitmap); */
+			/* RTW_INFO("enqueue, sq_len=%d\n", psta->sleepq_len); */
+			/* RTW_INFO_DUMP("enqueue, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 			if (update_tim == _TRUE) {
 				if (is_broadcast_mac_addr(pattrib->ra))
 					_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, "buffer BC");
@@ -4666,7 +4867,6 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 			ret = _TRUE;
 
 			DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_mcast);
-
 		}
 
 		_exit_critical_bh(&psta->sleep_q.lock, &irqL);
@@ -4681,7 +4881,7 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 	if (psta->state & WIFI_SLEEP_STATE) {
 		u8 wmmps_ac = 0;
 
-		if (pstapriv->sta_dz_bitmap & BIT(psta->cmn.aid)) {
+		if (rtw_tim_map_is_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid)) {
 			rtw_list_delete(&pxmitframe->list);
 
 			/* _enter_critical_bh(&psta->sleep_q.lock, &irqL);	 */
@@ -4714,12 +4914,13 @@ sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *p
 				psta->sleepq_ac_len++;
 
 			if (((psta->has_legacy_ac) && (!wmmps_ac)) || ((!psta->has_legacy_ac) && (wmmps_ac))) {
-				if (!(pstapriv->tim_bitmap & BIT(psta->cmn.aid)))
+				if (!(rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)))
 					update_tim = _TRUE;
 
-				pstapriv->tim_bitmap |= BIT(psta->cmn.aid);
+				rtw_tim_map_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-				/* RTW_INFO("enqueue, sq_len=%d, tim=%x\n", psta->sleepq_len, pstapriv->tim_bitmap); */
+				/* RTW_INFO("enqueue, sq_len=%d\n", psta->sleepq_len); */
+				/* RTW_INFO_DUMP("enqueue, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 
 				if (update_tim == _TRUE) {
 					/* RTW_INFO("sleepq_len==1, update BCNTIM\n"); */
@@ -4806,22 +5007,14 @@ void stop_sta_xmit(_adapter *padapter, struct sta_info *psta)
 #ifdef CONFIG_TDLS
 	if (!(psta->tdls_sta_state & TDLS_LINKED_STATE))
 #endif /* CONFIG_TDLS */
-		pstapriv->sta_dz_bitmap |= BIT(psta->cmn.aid);
-
-
+		rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
 
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vo_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
-
-
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vi_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
-
-
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->be_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
-
-
 	dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->bk_q.sta_pending);
 	rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
 
@@ -4829,12 +5022,16 @@ void stop_sta_xmit(_adapter *padapter, struct sta_info *psta)
 	if (!(psta->tdls_sta_state & TDLS_LINKED_STATE) && (psta_bmc != NULL)) {
 #endif /* CONFIG_TDLS */
 
-
 		/* for BC/MC Frames */
 		pstaxmitpriv = &psta_bmc->sta_xmitpriv;
+		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->vo_q.sta_pending);
+		rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
+		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->vi_q.sta_pending);
+		rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
 		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->be_q.sta_pending);
 		rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
-
+		dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->bk_q.sta_pending);
+		rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
 
 #ifdef CONFIG_TDLS
 	}
@@ -4933,14 +5130,15 @@ void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)
 		}
 #endif /* CONFIG_TDLS */
 
-		if (pstapriv->tim_bitmap & BIT(psta->cmn.aid)) {
-			/* RTW_INFO("wakeup to xmit, qlen==0, update_BCNTIM, tim=%x\n", pstapriv->tim_bitmap); */
+		if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
+			/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
+			/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 			/* upate BCN for TIM IE */
 			/* update_BCNTIM(padapter); */
 			update_mask = BIT(0);
 		}
 
-		pstapriv->tim_bitmap &= ~BIT(psta->cmn.aid);
+		rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
 		if (psta->state & WIFI_SLEEP_STATE)
 			psta->state ^= WIFI_SLEEP_STATE;
@@ -4951,14 +5149,14 @@ void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)
 			psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
 		}
 
-		pstapriv->sta_dz_bitmap &= ~BIT(psta->cmn.aid);
+		rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
 	}
 
 	/* for BC/MC Frames */
 	if (!psta_bmc)
 		goto _exit;
 
-	if ((pstapriv->sta_dz_bitmap & 0xfffe) == 0x0) { /* no any sta in ps mode */
+	if (!(rtw_tim_map_anyone_be_set_exclude_aid0(padapter, pstapriv->sta_dz_bitmap))) { /* no any sta in ps mode */
 		xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
 		xmitframe_plist = get_next(xmitframe_phead);
 
@@ -4991,14 +5189,15 @@ void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)
 		}
 
 		if (psta_bmc->sleepq_len == 0) {
-			if (pstapriv->tim_bitmap & BIT(0)) {
-				/* RTW_INFO("wakeup to xmit, qlen==0, update_BCNTIM, tim=%x\n", pstapriv->tim_bitmap); */
+			if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) {
+				/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
+				/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 				/* upate BCN for TIM IE */
 				/* update_BCNTIM(padapter); */
 				update_mask |= BIT(1);
 			}
-			pstapriv->tim_bitmap &= ~BIT(0);
-			pstapriv->sta_dz_bitmap &= ~BIT(0);
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
+			rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
 		}
 
 	}
@@ -5087,9 +5286,10 @@ void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta)
 				goto exit;
 			}
 #endif /* CONFIG_TDLS */
-			pstapriv->tim_bitmap &= ~BIT(psta->cmn.aid);
+			rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
 
-			/* RTW_INFO("wakeup to xmit, qlen==0, update_BCNTIM, tim=%x\n", pstapriv->tim_bitmap); */
+			/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
+			/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
 			/* upate BCN for TIM IE */
 			/* update_BCNTIM(padapter); */
 			update_beacon(padapter, _TIM_IE_, NULL, _TRUE);
@@ -5098,7 +5298,9 @@ void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta)
 
 	}
 
+#ifdef CONFIG_TDLS
 exit:
+#endif
 	/* _exit_critical_bh(&psta->sleep_q.lock, &irqL);	 */
 	_exit_critical_bh(&pxmitpriv->lock, &irqL);
 
@@ -5169,60 +5371,6 @@ struct xmit_buf *dequeue_pending_xmitbuf(
 	return pxmitbuf;
 }
 
-static struct xmit_buf *dequeue_pending_xmitbuf_under_survey(
-	struct xmit_priv *pxmitpriv)
-{
-	_irqL irql;
-	struct xmit_buf *pxmitbuf;
-#ifdef CONFIG_USB_HCI
-	struct xmit_frame *pxmitframe;
-#endif
-	_queue *pqueue;
-
-
-	pxmitbuf = NULL;
-	pqueue = &pxmitpriv->pending_xmitbuf_queue;
-
-	_enter_critical_bh(&pqueue->lock, &irql);
-
-	if (_rtw_queue_empty(pqueue) == _FALSE) {
-		_list *plist, *phead;
-		u8 type = 0;
-
-		phead = get_list_head(pqueue);
-		plist = phead;
-		do {
-			plist = get_next(plist);
-			if (plist == phead)
-				break;
-
-			pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
-
-#ifdef CONFIG_USB_HCI
-			pxmitframe = (struct xmit_frame *)pxmitbuf->priv_data;
-			if (pxmitframe)
-				type = get_frame_sub_type(pxmitbuf->pbuf + TXDESC_SIZE + pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
-			else
-				RTW_INFO("%s, !!!ERROR!!! For USB, TODO ITEM\n", __FUNCTION__);
-#else
-			type = get_frame_sub_type(pxmitbuf->pbuf + TXDESC_OFFSET);
-#endif
-
-			if ((type == WIFI_PROBEREQ) ||
-			    (type == WIFI_DATA_NULL) ||
-			    (type == WIFI_QOS_DATA_NULL)) {
-				rtw_list_delete(&pxmitbuf->list);
-				break;
-			}
-			pxmitbuf = NULL;
-		} while (1);
-	}
-
-	_exit_critical_bh(&pqueue->lock, &irql);
-
-	return pxmitbuf;
-}
-
 static struct xmit_buf *dequeue_pending_xmitbuf_ext(
 	struct xmit_priv *pxmitpriv)
 {
@@ -5269,13 +5417,9 @@ struct xmit_buf *select_and_dequeue_pending_xmitbuf(_adapter *padapter)
 	if (_TRUE == rtw_is_xmit_blocked(padapter))
 		return pxmitbuf;
 
-	if (rtw_xmit_ac_blocked(padapter) == _TRUE)
-		pxmitbuf = dequeue_pending_xmitbuf_under_survey(pxmitpriv);
-	else {
-		pxmitbuf = dequeue_pending_xmitbuf_ext(pxmitpriv);
-		if (pxmitbuf == NULL)
-			pxmitbuf = dequeue_pending_xmitbuf(pxmitpriv);
-	}
+	pxmitbuf = dequeue_pending_xmitbuf_ext(pxmitpriv);
+	if (pxmitbuf == NULL && rtw_xmit_ac_blocked(padapter) != _TRUE)
+		pxmitbuf = dequeue_pending_xmitbuf(pxmitpriv);
 
 	return pxmitbuf;
 }
@@ -5386,9 +5530,9 @@ bool rtw_is_xmit_blocked(_adapter *padapter)
 bool rtw_xmit_ac_blocked(_adapter *adapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	_adapter *iface;
 	struct mlme_ext_priv *mlmeext;
-	struct mlme_ext_info *mlmeextinfo;
 	bool blocked = _FALSE;
 	int i;
 #ifdef DBG_CONFIG_ERROR_DETECT
@@ -5402,6 +5546,14 @@ bool rtw_xmit_ac_blocked(_adapter *adapter)
 #endif/* #ifdef DBG_CONFIG_ERROR_RESET */
 #endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
 
+	if (rfctl->offch_state != OFFCHS_NONE
+		#ifdef CONFIG_DFS
+		|| IS_RADAR_DETECTED(rfctl) || rfctl->csa_ch
+		#endif
+	) {
+		blocked = _TRUE;
+		goto exit;
+	}
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
@@ -5597,8 +5749,6 @@ static u8 backup_idx[HW_QUEUE_ENTRY];
 
 void rtw_tx_desc_backup(_adapter *padapter, struct xmit_frame *pxmitframe, u8 desc_size, u8 hwq)
 {
-	u16 reg_rp;
-	u16 reg_wp;
 	u32 tmp32;
 	u8 *pxmit_buf;
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/HalPwrSeqCmd.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/HalPwrSeqCmd.c
index 389785c2bfe4..ae95ca814807 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/HalPwrSeqCmd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/HalPwrSeqCmd.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e1ant.c
deleted file mode 100644
index 1c60239fc38d..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e1ant.c
+++ /dev/null
@@ -1,3431 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8192E Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8192E_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8192e_1ant		glcoex_dm_8192e_1ant;
-static struct  coex_dm_8192e_1ant	*coex_dm = &glcoex_dm_8192e_1ant;
-static struct  coex_sta_8192e_1ant		glcoex_sta_8192e_1ant;
-static struct  coex_sta_8192e_1ant	*coex_sta = &glcoex_sta_8192e_1ant;
-
-const char *const glbt_info_src_8192e_1ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8192e_1ant = 20140527;
-u32	glcoex_ver_8192e_1ant = 0x4f;
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8192e1ant_
- * ************************************************************ */
-u8 halbtc8192e1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8192e1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-void halbtc8192e1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-void halbtc8192e1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = false;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-void halbtc8192e1ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-void halbtc8192e1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8192e1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8192e1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8192e1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8192e1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
-	}
-
-	halbtc8192e1ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8192e1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8192e1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-void halbtc8192e1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8192e1ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	coex_sta->c2h_bt_info_req_sent = true;
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-void halbtc8192e1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0;
-
-	/* to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS */
-	/* if (! (btcoexist->btc_read_1byte(btcoexist, 0x76e) & 0x8) ) */
-
-	if (coex_sta->under_ips) {
-		coex_sta->high_priority_tx = 65535;
-		coex_sta->high_priority_rx = 65535;
-		coex_sta->low_priority_tx = 65535;
-		coex_sta->low_priority_rx = 65535;
-		return;
-	}
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	if ((coex_sta->low_priority_tx >= 1050)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	if ((reg_hp_tx == 0) && (reg_hp_rx == 0) && (reg_lp_tx == 0) &&
-	    (reg_lp_rx == 0)) {
-		num_of_bt_counter_chk++;
-		if (num_of_bt_counter_chk >= 3) {
-			halbtc8192e1ant_query_bt_info(btcoexist);
-			num_of_bt_counter_chk = 0;
-		}
-	}
-}
-
-
-void halbtc8192e1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-	s32	wifi_rssi = 0;
-	boolean wifi_busy = false, wifi_under_b_mode = false;
-	static u8 cck_lock_counter = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-			   &wifi_under_b_mode);
-
-	if (coex_sta->under_ips) {
-		coex_sta->crc_ok_cck = 0;
-		coex_sta->crc_ok_11g = 0;
-		coex_sta->crc_ok_11n = 0;
-		coex_sta->crc_ok_11n_agg = 0;
-
-		coex_sta->crc_err_cck = 0;
-		coex_sta->crc_err_11g = 0;
-		coex_sta->crc_err_11n = 0;
-		coex_sta->crc_err_11n_agg = 0;
-	} else {
-		coex_sta->crc_ok_cck	= btcoexist->btc_read_4byte(btcoexist,
-					  0xf88);
-		coex_sta->crc_ok_11g	= btcoexist->btc_read_2byte(btcoexist,
-					  0xf94);
-		coex_sta->crc_ok_11n	= btcoexist->btc_read_2byte(btcoexist,
-					  0xf90);
-		coex_sta->crc_ok_11n_agg = btcoexist->btc_read_2byte(btcoexist,
-					   0xfb8);
-
-		coex_sta->crc_err_cck	 = btcoexist->btc_read_4byte(btcoexist,
-					   0xf84);
-		coex_sta->crc_err_11g	 = btcoexist->btc_read_2byte(btcoexist,
-					   0xf96);
-		coex_sta->crc_err_11n	 = btcoexist->btc_read_2byte(btcoexist,
-					   0xf92);
-		coex_sta->crc_err_11n_agg = btcoexist->btc_read_2byte(btcoexist,
-					    0xfba);
-	}
-
-
-	/* reset counter */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xf16, 0x1, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xf16, 0x1, 0x0);
-
-	if ((wifi_busy) && (wifi_rssi >= 30) && (!wifi_under_b_mode)) {
-		if ((coex_dm->bt_status == BT_8192E_1ANT_BT_STATUS_ACL_BUSY) ||
-		    (coex_dm->bt_status ==
-		     BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		    (coex_dm->bt_status ==
-		     BT_8192E_1ANT_BT_STATUS_SCO_BUSY)) {
-			if (coex_sta->crc_ok_cck > (coex_sta->crc_ok_11g +
-						    coex_sta->crc_ok_11n +
-						    coex_sta->crc_ok_11n_agg)) {
-				if (cck_lock_counter < 5)
-					cck_lock_counter++;
-			} else {
-				if (cck_lock_counter > 0)
-					cck_lock_counter--;
-			}
-
-		} else {
-			if (cck_lock_counter > 0)
-				cck_lock_counter--;
-		}
-	} else {
-		if (cck_lock_counter > 0)
-			cck_lock_counter--;
-	}
-
-	if (!coex_sta->pre_ccklock) {
-
-		if (cck_lock_counter >= 5)
-			coex_sta->cck_lock = true;
-		else
-			coex_sta->cck_lock = false;
-	} else {
-		if (cck_lock_counter == 0)
-			coex_sta->cck_lock = false;
-		else
-			coex_sta->cck_lock = true;
-	}
-
-	coex_sta->pre_ccklock =  coex_sta->cck_lock;
-
-
-}
-
-boolean halbtc8192e1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	boolean wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-	}
-
-	return false;
-}
-
-void halbtc8192e1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-u8 halbtc8192e1ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-	u8				algorithm = BT_8192E_1ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Profile = SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_1ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8192E_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8192e1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8192e1ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8192e1ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8192e1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xf9;	/* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-}
-
-void halbtc8192e1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8192e1ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8192e1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8192e1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8192e1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8192e1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** CoexTable(%d) **********\n", type);
-	BTC_TRACE(trace_buf);
-
-	coex_sta->coex_table_type = type;
-
-	switch (type) {
-	case 0:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x55555555, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 4:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0xaaaa5a5a, 0xffffff, 0x3);
-		break;
-	case 5:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0xaa5a5a5a, 0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 7:
-		halbtc8192e1ant_coex_table(btcoexist, force_exec,
-				   0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8192e1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8192e1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8192e1ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8192e1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8192e1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8192e1ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8192e1ant_sw_mechanism(IN struct btc_coexist *btcoexist,
-				  IN boolean low_penalty_ra)
-{
-	halbtc8192e1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra);
-}
-
-void halbtc8192e1ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean init_hwcfg, IN boolean wifi_off)
-{
-	u32			u32tmp = 0;
-
-	if (init_hwcfg) {
-		btcoexist->btc_write_1byte(btcoexist, 0x944, 0x24);
-		btcoexist->btc_write_4byte(btcoexist, 0x930, 0x700700);
-		if (btcoexist->chip_interface == BTC_INTF_USB)
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30430004);
-		else
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30030004);
-
-		/* 0x4c[27][24]='00', Set Antenna to BB */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp &= ~BIT(24);
-		u32tmp &= ~BIT(27);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-	} else if (wifi_off) {
-		if (btcoexist->chip_interface == BTC_INTF_USB)
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30430004);
-		else
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30030004);
-
-		/* 0x4c[27][24]='11', Set Antenna to BT, 0x64[8:7]=0, 0x64[2]=1 */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp |= BIT(24);
-		u32tmp |= BIT(27);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-	}
-
-	/* ext switch setting */
-	switch (ant_pos_type) {
-	case BTC_ANT_PATH_WIFI:
-		btcoexist->btc_write_1byte(btcoexist, 0x92c, 0x4);
-		break;
-	case BTC_ANT_PATH_BT:
-		btcoexist->btc_write_1byte(btcoexist, 0x92c, 0x20);
-		break;
-	default:
-	case BTC_ANT_PATH_PTA:
-		btcoexist->btc_write_1byte(btcoexist, 0x92c, 0x4);
-		break;
-	}
-}
-
-void halbtc8192e1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], FW for 1Ant AP mode\n");
-			BTC_TRACE(trace_buf);
-			real_byte1 &= ~BIT(4);
-			real_byte1 |= BIT(5);
-
-			real_byte5 |= BIT(5);
-			real_byte5 &= ~BIT(6);
-		}
-	}
-
-	h2c_parameter[0] = real_byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = real_byte5;
-
-	coex_dm->ps_tdma_para[0] = real_byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = real_byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-
-void halbtc8192e1ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_busy = false;
-	u8			rssi_adjust_val = 0;
-	u8			ps_tdma_byte4_val = 0x50, ps_tdma_byte0_val = 0x51,
-				ps_tdma_byte3_val =  0x10;
-	s8			wifi_duration_adjust = 0x0;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-
-	if (coex_sta->scan_ap_num <= 5)
-		wifi_duration_adjust = 5;
-	else if (coex_sta->scan_ap_num >= 40)
-		wifi_duration_adjust = -15;
-	else if (coex_sta->scan_ap_num >= 20)
-		wifi_duration_adjust = -10;
-
-	if (!coex_sta->force_lps_on) { /* only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30 */
-		ps_tdma_byte0_val = 0x61;  /* no null-pkt */
-		ps_tdma_byte3_val = 0x11; /* no tx-pause at BT-slot */
-		ps_tdma_byte4_val = 0x10; /* 0x778 = d/1 toggle */
-	}
-
-	if ((type == 3) || (type == 13) || (type == 14))
-		ps_tdma_byte4_val = ps_tdma_byte4_val &
-			    0xbf;  /* no dynamic slot for multi-profile */
-
-	if (bt_link_info->slave_role == true)
-		ps_tdma_byte4_val = ps_tdma_byte4_val |
-			0x1;  /* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-
-	if (turn_on) {
-		switch (type) {
-		default:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x1a, 0x1a, 0x0, ps_tdma_byte4_val);
-			break;
-		case 1:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x3a +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 2:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x2d +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 3:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x1d, 0x1d, 0x0, ps_tdma_byte4_val);
-			break;
-		case 4:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x14, 0x0);
-			break;
-		case 5:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x15, 0x3, 0x11, 0x11);
-			break;
-		case 6:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x20, 0x3, 0x11, 0x11);
-			break;
-		case 7:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xc, 0x5, 0x0, 0x0);
-			break;
-		case 8:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			break;
-		case 9:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 10:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0xa, 0x0, 0x40);
-			break;
-		case 11:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 12:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x0a, 0x0a, 0x0, 0x50);
-			break;
-		case 13:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x12, 0x12, 0x0, ps_tdma_byte4_val);
-			break;
-		case 14:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x21, 0x3, 0x10, ps_tdma_byte4_val);
-			break;
-		case 15:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0x3, 0x8, 0x0);
-			break;
-		case 16:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x10, 0x0);
-			break;
-		case 18:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			break;
-		case 20:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x3f, 0x03, 0x11, 0x10);
-			break;
-		case 21:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11, 0x11);
-			break;
-		case 22:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11, 0x10);
-			break;
-		case 23:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x18);
-			break;
-		case 24:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x3, 0x31, 0x18);
-			break;
-		case 25:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			break;
-		case 26:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			break;
-		case 27:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x98);
-			break;
-		case 28:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x69,
-						      0x25, 0x3, 0x31, 0x0);
-			break;
-		case 29:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xab,
-						      0x1a, 0x1a, 0x1, 0x10);
-			break;
-		case 30:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10, 0x10);
-			break;
-		case 31:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1a, 0x1a, 0, 0x58);
-			break;
-		case 32:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x3, 0x11, 0x11);
-			break;
-		case 33:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xa3,
-						      0x25, 0x3, 0x30, 0x90);
-			break;
-		case 34:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 35:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 36:
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x12, 0x3, 0x14, 0x50);
-			break;
-		case 40: /* SoftAP only with no sta associated,BT disable ,TDMA mode for power saving */
-			/* here softap mode screen off will cost 70-80mA for phone */
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x23,
-						      0x18, 0x00, 0x10, 0x24);
-			break;
-		}
-	} else {
-
-		/* disable PS tdma */
-		switch (type) {
-		case 8: /* PTA Control */
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x8,
-						      0x0, 0x0, 0x0, 0x0);
-			halbtc8192e1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_PTA, false, false);
-			break;
-		case 0:
-		default:  /* Software control, Antenna at BT side */
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			halbtc8192e1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_BT, false, false);
-			break;
-		case 9:   /* Software control, Antenna at WiFi side */
-			halbtc8192e1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			halbtc8192e1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_WIFI, false, false);
-			break;
-		}
-	}
-	rssi_adjust_val = 0;
-	btcoexist->btc_set(btcoexist,
-		BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssi_adjust_val);
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-		    btcoexist->btc_read_4byte(btcoexist, 0x948),
-		    btcoexist->btc_read_1byte(btcoexist, 0x765),
-		    btcoexist->btc_read_1byte(btcoexist, 0x67));
-	BTC_TRACE(trace_buf);
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-void halbtc8192e1ant_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-	/* sw all off */
-	halbtc8192e1ant_sw_mechanism(btcoexist, false);
-
-	/* hw all off */
-	halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-boolean halbtc8192e1ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = false, wifi_connected = false, wifi_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected &&
-	    BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	    coex_dm->bt_status) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		/* halbtc8192e1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (wifi_connected &&
-		   (BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		/* halbtc8192e1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (!wifi_connected &&
-		(BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		/* halbtc8192e1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (wifi_connected &&
-		(BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		/* halbtc8192e1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (!wifi_connected &&
-		(BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE != coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non connected-idle + BT Busy!!\n");
-		BTC_TRACE(trace_buf);
-		/* halbtc8192e1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else {
-		if (wifi_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		common = false;
-	}
-
-	return common;
-}
-
-
-void halbtc8192e1ant_tdma_duration_adjust_for_acl(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0, bt_info_ext;
-	boolean			wifi_busy = false;
-	/*static boolean	pre_wifi_busy = false;*/
-
-	if (BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY == wifi_status)
-		wifi_busy = true;
-	else
-		wifi_busy = false;
-
-	if ((BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN ==
-	     wifi_status) ||
-	    (BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifi_status) ||
-	    (BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT ==
-	     wifi_status)) {
-		if (coex_dm->cur_ps_tdma != 1 &&
-		    coex_dm->cur_ps_tdma != 2 &&
-		    coex_dm->cur_ps_tdma != 3 &&
-		    coex_dm->cur_ps_tdma != 9) {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						9);
-			coex_dm->ps_tdma_du_adj_type = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n = 3;
-			result = 0;
-			wait_count = 0;
-		}
-		return;
-	}
-
-	if (!coex_dm->auto_tdma_adjust) {
-		coex_dm->auto_tdma_adjust = true;
-
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 2);
-		coex_dm->ps_tdma_du_adj_type = 2;
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2 */
-		retry_count = coex_sta->bt_retry_cnt;
-		bt_info_ext = coex_sta->bt_info_ext;
-
-		if ((coex_sta->low_priority_tx) > 1050 ||
-		    (coex_sta->low_priority_rx) > 1250)
-			retry_count++;
-
-		result = 0;
-		wait_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if retry count during continuous n*2 seconds is 0, enlarge WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if continuous 2 retry count(every 2 seconds) >0 and < 3, reduce WiFi duration */
-				if (wait_count <= 2)
-					m++; /* to avoid loop between the two levels */
-				else
-					m = 1;
-
-				if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-			}
-		} else { /* retry count > 3, once retry count > 3, to reduce WiFi duration */
-			if (wait_count == 1)
-				m++; /* to avoid loop between the two levels */
-			else
-				m = 1;
-
-			if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-		}
-
-		if (result == -1) {
-			if ((BT_INFO_8192E_1ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-			    ((coex_dm->cur_ps_tdma == 1) ||
-			     (coex_dm->cur_ps_tdma == 2))) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 1) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 2);
-				coex_dm->ps_tdma_du_adj_type = 2;
-			} else if (coex_dm->cur_ps_tdma == 2) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 9) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 11);
-				coex_dm->ps_tdma_du_adj_type = 11;
-			}
-		} else if (result == 1) {
-			if ((BT_INFO_8192E_1ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-			    ((coex_dm->cur_ps_tdma == 1) ||
-			     (coex_dm->cur_ps_tdma == 2))) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 11) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 9) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 2);
-				coex_dm->ps_tdma_du_adj_type = 2;
-			} else if (coex_dm->cur_ps_tdma == 2) {
-				halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 1);
-				coex_dm->ps_tdma_du_adj_type = 1;
-			}
-		} else { /* no change */
-			/* Bryant Modify
-			if(wifi_busy != pre_wifi_busy)
-			{
-				pre_wifi_busy = wifi_busy;
-				halbtc8192e1ant_ps_tdma(btcoexist, FORCE_EXEC, true, coex_dm->cur_ps_tdma);
-			}
-			*/
-		}
-
-		if (coex_dm->cur_ps_tdma != 1 &&
-		    coex_dm->cur_ps_tdma != 2 &&
-		    coex_dm->cur_ps_tdma != 9 &&
-		    coex_dm->cur_ps_tdma != 11) {
-			/* recover to previous adjust type */
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		}
-	}
-}
-
-void halbtc8192e1ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						0);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						0);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-void halbtc8192e1ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	case BTC_PS_LPS_ON:
-		halbtc8192e1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, true);
-		halbtc8192e1ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		coex_sta->force_lps_on = true;
-		break;
-	case BTC_PS_LPS_OFF:
-		halbtc8192e1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8192e1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
-{
-	halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 9);
-}
-
-void halbtc8192e1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = true, bt_disabled = false;
-
-	/* This function check if bt is disabled */
-
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = false;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = false;
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is enabled !!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		bt_disable_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], bt all counters=0, %d times!!\n",
-			    bt_disable_cnt);
-		BTC_TRACE(trace_buf);
-		if (bt_disable_cnt >= 2) {
-			bt_disabled = true;
-			btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-					   &bt_disabled);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e1ant_action_wifi_only(btcoexist);
-		}
-	}
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-		if (!bt_disabled) {
-		} else {
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-					   NULL);
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-					   NULL);
-		}
-	}
-}
-
-/* *********************************************
- *
- *	Software Coex Mechanism start
- *
- * ********************************************* */
-
-/* SCO only or SCO+PAN(HS) */
-
-/*
-void halbtc8192e1ant_action_sco(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, true);
-}
-
-
-void halbtc8192e1ant_action_hid(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, true);
-}
-
-
-void halbtc8192e1ant_action_a2dp(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8192e1ant_action_a2dp_pan_hs(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8192e1ant_action_pan_edr(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, false);
-}
-
-
-void halbtc8192e1ant_action_pan_hs(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, false);
-}
-
-
-void halbtc8192e1ant_action_pan_edr_a2dp(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8192e1ant_action_pan_edr_hid(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, true);
-}
-
-
-void halbtc8192e1ant_action_hid_a2dp_pan_edr(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, true);
-}
-
-void halbtc8192e1ant_action_hid_a2dp(IN struct btc_coexist* btcoexist)
-{
-	halbtc8192e1ant_sw_mechanism(btcoexist, true);
-}
-
-*/
-
-/* *********************************************
- *
- *	Non-Software Coex Mechanism start
- *
- * ********************************************* */
-void halbtc8192e1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-	halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-}
-
-void halbtc8192e1ant_action_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5);
-	halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-}
-
-void halbtc8192e1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_connected = false, ap_enable = false, wifi_busy = false,
-				bt_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	if ((!wifi_connected) && (!coex_sta->wifi_is_high_pri_task)) {
-		halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist) ||
-		   (bt_link_info->a2dp_exist)) {
-		/* SCO/HID/A2DP  busy */
-		halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if ((bt_link_info->pan_exist) || (wifi_busy)) {
-		halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	}
-}
-
-void halbtc8192e1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	/* tdma and coex table */
-
-	if (bt_link_info->sco_exist) {
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	} else { /* HID */
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 6);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	}
-}
-
-void halbtc8192e1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	u8		bt_rssi_state;
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	bt_rssi_state = halbtc8192e1ant_bt_rssi_state(2, 28, 0);
-
-	if ((coex_sta->low_priority_rx >= 1000)  &&
-	    (coex_sta->low_priority_rx != 65535))
-		bt_link_info->slave_role = true;
-	else
-		bt_link_info->slave_role = false;
-
-	if (bt_link_info->hid_only) { /* HID */
-		halbtc8192e1ant_action_bt_sco_hid_only_busy(btcoexist,
-				wifi_status);
-		coex_dm->auto_tdma_adjust = false;
-		return;
-	} else if (bt_link_info->a2dp_only) { /* A2DP		 */
-		if (BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifi_status) {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-			coex_dm->auto_tdma_adjust = false;
-		} else {
-			halbtc8192e1ant_tdma_duration_adjust_for_acl(btcoexist,
-					wifi_status);
-#if 0
-			if (coex_sta->cck_lock)
-				halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 3);
-			else
-#endif
-				halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-			coex_dm->auto_tdma_adjust = true;
-		}
-	} else if (((bt_link_info->a2dp_exist) && (bt_link_info->pan_exist)) ||
-		   (bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) { /* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 13);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	} else if (bt_link_info->hid_exist &&
-		   bt_link_info->a2dp_exist) { /* HID+A2DP */
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 14);
-		coex_dm->auto_tdma_adjust = false;
-
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	} else if ((bt_link_info->pan_only) || (bt_link_info->hid_exist &&
-		bt_link_info->pan_exist)) { /* PAN(OPP,FTP), HID+PAN(OPP,FTP)			 */
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 3);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	} else {
-		/* BT no-profile busy (0x9) */
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	}
-}
-
-void halbtc8192e1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-	/* power save state */
-	halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	halbtc8192e1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8);
-	halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8192e1ant_action_wifi_not_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if (BT_8192E_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8192E_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8192e1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* Bryant Add */
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8192e1ant_action_wifi_not_connected_asso_auth(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist)  || (bt_link_info->hid_exist) ||
-	    (bt_link_info->a2dp_exist)) {
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if (bt_link_info->pan_exist) {
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8192e1ant_action_wifi_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if (BT_8192E_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8192E_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8192e1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* Bryant Add */
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8192e1ant_action_wifi_connected_specific_packet(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist) ||
-	    (bt_link_info->a2dp_exist)) {
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if (bt_link_info->pan_exist) {
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8192e1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-	boolean	wifi_busy = false;
-	boolean		scan = false, link = false, roam = false;
-	boolean		under_4way = false, ap_enable = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], CoexForWifiConnect()===>\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-	if (under_4way) {
-		halbtc8192e1ant_action_wifi_connected_specific_packet(btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	if (scan || link || roam) {
-		if (scan)
-			halbtc8192e1ant_action_wifi_connected_scan(btcoexist);
-		else
-			halbtc8192e1ant_action_wifi_connected_specific_packet(
-				btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* power save state */
-	if (!ap_enable &&
-	    BT_8192E_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status &&
-	    !btcoexist->bt_link_info.hid_only) {
-		if (btcoexist->bt_link_info.a2dp_only) {	/* A2DP */
-			if (!wifi_busy)
-				halbtc8192e1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			else { /* busy */
-				if (coex_sta->scan_ap_num >=
-				    BT_8192E_1ANT_WIFI_NOISY_THRESH)  /* no force LPS, no PS-TDMA, use pure TDMA */
-					halbtc8192e1ant_power_save_state(
-						btcoexist, BTC_PS_WIFI_NATIVE,
-						0x0, 0x0);
-				else
-					halbtc8192e1ant_power_save_state(
-						btcoexist, BTC_PS_LPS_ON, 0x50,
-						0x4);
-			}
-		} else if ((coex_sta->pan_exist == false) &&
-			   (coex_sta->a2dp_exist == false) &&
-			   (coex_sta->hid_exist == false))
-			halbtc8192e1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8192e1ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-	} else
-		halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-
-	/* tdma and coex table */
-	if (!wifi_busy) {
-		if (BT_8192E_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8192e1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else if ((BT_8192E_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8192e1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-
-			if ((coex_sta->high_priority_tx) +
-			    (coex_sta->high_priority_rx) <= 60)
-				halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-			else
-				halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	} else {
-		if (BT_8192E_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8192e1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else if ((BT_8192E_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8192e1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else {
-			halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-
-			if ((coex_sta->high_priority_tx) +
-			    (coex_sta->high_priority_rx) <= 60)
-				halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-			else
-				halbtc8192e1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	}
-}
-
-void halbtc8192e1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8				algorithm = 0;
-
-	algorithm = halbtc8192e1ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-
-	if (halbtc8192e1ant_is_common_action(btcoexist)) {
-
-	} else {
-		switch (coex_dm->cur_algorithm) {
-		case BT_8192E_1ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_sco(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_hid(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_a2dp(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_a2dp_pan_hs(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_pan_edr(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_pan_hs(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_pan_edr_a2dp(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_pan_edr_hid(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_hid_a2dp_pan_edr(btcoexist); */
-			break;
-		case BT_8192E_1ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_action_hid_a2dp(btcoexist); */
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8192e1ant_coex_all_off(btcoexist); */
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-void halbtc8192e1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false, bt_hs_on = false;
-	boolean	increase_scan_dev_num = false;
-	boolean	bt_ctrl_agg_buf_size = false;
-	boolean	miracast_plus_bt = false;
-	u8	agg_buf_size = 5;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if ((BT_8192E_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8192E_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		increase_scan_dev_num = true;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_INC_SCAN_DEV_NUM,
-			   &increase_scan_dev_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist) {
-			halbtc8192e1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1,
-						   0, 1);
-			miracast_plus_bt = true;
-		} else {
-			halbtc8192e1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0,
-						   0, 0);
-			miracast_plus_bt = false;
-		}
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-		halbtc8192e1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-
-		if ((bt_link_info->a2dp_exist) &&
-		    (coex_sta->c2h_bt_inquiry_page)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is Inquirying\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e1ant_action_bt_inquiry(btcoexist);
-		} else
-			halbtc8192e1ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	}
-
-	miracast_plus_bt = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-			   &miracast_plus_bt);
-
-	if ((bt_link_info->bt_link_exist) && (wifi_connected)) {
-		halbtc8192e1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1, 0, 1);
-
-		if (bt_link_info->sco_exist)
-			halbtc8192e1ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, true, 0x5);
-		else
-			halbtc8192e1ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, true, 0x8);
-
-		halbtc8192e1ant_sw_mechanism(btcoexist, true);
-		halbtc8192e1ant_run_sw_coexist_mechanism(
-			btcoexist);  /* just print debug message */
-	} else {
-		halbtc8192e1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-		halbtc8192e1ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x5);
-
-		halbtc8192e1ant_sw_mechanism(btcoexist, false);
-		halbtc8192e1ant_run_sw_coexist_mechanism(
-			btcoexist); /* just print debug message */
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "############# [BTCoex],  BT Is Inquirying\n");
-		BTC_TRACE(trace_buf);
-		halbtc8192e1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8192e1ant_action_hs(btcoexist);
-		return;
-	}
-
-
-	if (!wifi_connected) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is non connected-idle !!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (scan || link || roam) {
-			if (scan)
-				halbtc8192e1ant_action_wifi_not_connected_scan(
-					btcoexist);
-			else
-				halbtc8192e1ant_action_wifi_not_connected_asso_auth(
-					btcoexist);
-		} else
-			halbtc8192e1ant_action_wifi_not_connected(btcoexist);
-	} else	/* wifi LPS/Busy */
-		halbtc8192e1ant_action_wifi_connected(btcoexist);
-}
-
-void halbtc8192e1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-
-	/* sw all off */
-	halbtc8192e1ant_sw_mechanism(btcoexist, false);
-
-	/* halbtc8192e1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8); */
-	halbtc8192e1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	coex_sta->pop_event_cnt = 0;
-}
-
-void halbtc8192e1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean wifi_only)
-{
-	u16	u16tmp = 0;
-	u8	u8tmp = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	/* antenna sw ctrl to bt */
-	halbtc8192e1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, true, false);
-
-	halbtc8192e1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	/* antenna switch control parameter */
-	btcoexist->btc_write_4byte(btcoexist, 0x858, 0x55555555);
-
-	/* coex parameters */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	/* enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	/* enable PTA */
-	btcoexist->btc_write_1byte(btcoexist, 0x40, 0x20);
-	/* enable mailbox interface */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x40);
-	u16tmp |= BIT(9);
-	btcoexist->btc_write_2byte(btcoexist, 0x40, u16tmp);
-
-	/* enable PTA I2C mailbox */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x101);
-	u8tmp |= BIT(4);
-	btcoexist->btc_write_1byte(btcoexist, 0x101, u8tmp);
-
-	/* enable bt clock when wifi is disabled. */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x93);
-	u8tmp |= BIT(0);
-	btcoexist->btc_write_1byte(btcoexist, 0x93, u8tmp);
-	/* enable bt clock when suspend. */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x7);
-	u8tmp |= BIT(0);
-	btcoexist->btc_write_1byte(btcoexist, 0x7, u8tmp);
-}
-
-
-/*
-void halbtc8192e1ant_wifi_off_hw_cfg(IN struct btc_coexist* btcoexist)
-{
-
-
-}
-*/
-
-/* ************************************************************
- * work around function start with wa_halbtc8192e1ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8192e1ant_
- * ************************************************************ */
-void ex_halbtc8192e1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-#if 0
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x0;
-	u16 u16tmp = 0x0;
-
-	btcoexist->stop_coex_dm = true;
-
-	btcoexist->btc_write_1byte(btcoexist, 0x67, 0x20);
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly. */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-	/* set GRAN_BT = 1 */
-	btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18);
-	/* set WLAN_ACT = 0 */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	/*  */
-	/* S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info) */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-	if (btcoexist->chip_interface == BTC_INTF_USB) {
-		/* fixed at S0 for USB interface */
-		btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0);
-
-		u8tmp |= 0x1;	/* antenna inverse */
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-	} else {
-		/* for PCIE and SDIO interface, we check efuse 0xc3[6] */
-		if (board_info->single_ant_path == 0) {
-			/* set to S1 */
-			btcoexist->btc_write_4byte(btcoexist, 0x948, 0x280);
-			board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-		} else if (board_info->single_ant_path == 1) {
-			/* set to S0 */
-			btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0);
-			u8tmp |= 0x1;	/* antenna inverse */
-			board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-		}
-
-		if (btcoexist->chip_interface == BTC_INTF_PCI)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x384,
-							     u8tmp);
-		else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60,
-							     u8tmp);
-	}
-#endif
-}
-
-void ex_halbtc8192e1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8192e1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8192e1ant_init_hw_config(btcoexist, wifi_only);
-	btcoexist->stop_coex_dm = false;
-}
-
-void ex_halbtc8192e1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->stop_coex_dm = false;
-
-	halbtc8192e1ant_init_coex_dm(btcoexist);
-
-	halbtc8192e1ant_query_bt_info(btcoexist);
-}
-
-void ex_halbtc8192e1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u32				u32tmp[4];
-	u32				fw_ver = 0, bt_patch_ver = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "Ant PG number/ Ant mechanism:",
-		   board_info->pg_ant_num, board_info->btdm_ant_num);
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%d/ 0x%x/ 0x%x(%d)",
-		   "CoexVer/ FwVer/ PatchVer",
-		   glcoex_ver_date_8192e_1ant, glcoex_ver_8192e_1ant, fw_ver,
-		   bt_patch_ver, bt_patch_ver);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi, coex_sta->bt_retry_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP",
-		   bt_link_info->sco_exist, bt_link_info->hid_exist,
-		   bt_link_info->pan_exist, bt_link_info->a2dp_exist);
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Info A2DP rate",
-		   (bt_info_ext & BIT(0)) ? "Basic rate" : "EDR rate");
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8192E_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8192e_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	if (!btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[mechanisms]============");
-		CL_PRINTF(cli_buf);
-
-		ps_tdma_case = coex_dm->cur_ps_tdma;
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)",
-			   "PS TDMA",
-			   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-			   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-			   coex_dm->ps_tdma_para[4], ps_tdma_case,
-			   coex_dm->auto_tdma_adjust);
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ",
-			   "Latest error condition(should be 0)",
-			   coex_dm->error_condition);
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ",
-			   "IgnWlanAct",
-			   coex_dm->cur_ignore_wlan_act);
-		CL_PRINTF(cli_buf);
-	}
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc04);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xd04);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x90c);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0xc04/ 0xd04/ 0x90c",
-		   u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x778",
-		   u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x92c);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x930);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x92c/ 0x930",
-		   (u8tmp[0]), u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x4f);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x40/ 0x4f",
-		   u8tmp[0], u8tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)",
-		   u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(hp rx[31:16]/tx[15:0])",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(lp rx[31:16]/tx[15:0])",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8192E_1ANT == 1)
-	halbtc8192e1ant_monitor_bt_ctr(btcoexist);
-#endif
-
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-void ex_halbtc8192e1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = true;
-
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8192e1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false,
-					     true);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = false;
-
-		halbtc8192e1ant_init_hw_config(btcoexist, false);
-		halbtc8192e1ant_init_coex_dm(btcoexist);
-		halbtc8192e1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8192e1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = true;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8192e1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	u8 u8tmpa, u8tmpb;
-	u32 u32tmp;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_SCAN_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8192e1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948);
-		u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-		u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x67);
-
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-			    u32tmp,  u8tmpa, u8tmpb);
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-	}
-
-	if (coex_sta->bt_disabled)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	halbtc8192e1ant_query_bt_info(btcoexist);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8192e1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8192e1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8192e1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8192e1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8192e1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_SCAN_START == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8192e1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		else	/* wifi is connected */
-			halbtc8192e1ant_action_wifi_connected_scan(btcoexist);
-	} else if (BTC_SCAN_FINISH == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8192e1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8192e1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-void ex_halbtc8192e1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	boolean	wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-
-	if (BTC_ASSOCIATE_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-		/* coex_dm->arp_cnt = 0; */
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8192e1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8192e1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8192e1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8192e1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8192e1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_ASSOCIATE_START == type)
-		halbtc8192e1ant_action_wifi_not_connected_asso_auth(btcoexist);
-	else if (BTC_ASSOCIATE_FINISH == type) {
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-				   &wifi_connected);
-		if (!wifi_connected) /* non-connected scan */
-			halbtc8192e1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8192e1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-void ex_halbtc8192e1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	boolean			wifi_under_b_mode = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-				   &wifi_under_b_mode);
-
-		/* Set CCK Tx/Rx high Pri except 11b mode */
-		if (wifi_under_b_mode) {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x00); /* CCK Rx */
-		} else {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x10); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x10); /* CCK Rx */
-		}
-
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		/* h2c_parameter[0] = 0x1; */
-		h2c_parameter[0] = 0x0;
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-}
-
-void ex_halbtc8192e1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean	bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    BTC_PACKET_ARP == type) {
-		if (BTC_PACKET_ARP == type) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], specific Packet ARP notify\n");
-			BTC_TRACE(trace_buf);
-
-			coex_dm->arp_cnt++;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], ARP Packet Count = %d\n",
-				    coex_dm->arp_cnt);
-			BTC_TRACE(trace_buf);
-
-			if (coex_dm->arp_cnt >=
-			    10) /* if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecificPacket(btcoexist) */
-				coex_sta->wifi_is_high_pri_task = false;
-			else
-				coex_sta->wifi_is_high_pri_task = true;
-		} else {
-			coex_sta->wifi_is_high_pri_task = true;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], specific Packet DHCP or EAPOL notify\n");
-			BTC_TRACE(trace_buf);
-		}
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet [Type = %d] notify\n", type);
-		BTC_TRACE(trace_buf);
-	}
-
-	coex_sta->specific_pkt_period_cnt = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8192e1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8192e1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8192e1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8192e1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8192e1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    ((BTC_PACKET_ARP == type) && (coex_sta->wifi_is_high_pri_task)))
-		halbtc8192e1ant_action_wifi_connected_specific_packet(btcoexist);
-}
-
-void ex_halbtc8192e1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8				bt_info = 0;
-	u8				i, rsp_source = 0;
-	boolean				wifi_connected = false;
-	boolean				bt_busy = false;
-
-	coex_sta->c2h_bt_info_req_sent = false;
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8192E_1ANT_MAX)
-		rsp_source = BT_INFO_SRC_8192E_1ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	if (BT_INFO_SRC_8192E_1ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->bt_info_c2h[rsp_source][2] & 0x20)
-			coex_sta->c2h_bt_page = true;
-		else
-			coex_sta->c2h_bt_page = false;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 - 90;
-		/* coex_sta->bt_info_c2h[rsp_source][3]*2+10; */
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		coex_sta->bt_tx_rx_mask = (coex_sta->bt_info_c2h[rsp_source][2]
-					   & 0x40);
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TX_RX_MASK,
-				   &coex_sta->bt_tx_rx_mask);
-		if (!coex_sta->bt_tx_rx_mask) {
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF,
-						  0x3c, 0x15);
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if (coex_sta->bt_info_ext & BIT(1)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-			if (wifi_connected)
-				ex_halbtc8192e1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8192e1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(3)) {
-			if (!btcoexist->manual_control &&
-			    !btcoexist->stop_coex_dm) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8192e1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, false);
-			}
-		} else {
-			/* BT already NOT ignore Wlan active, do nothing here. */
-		}
-#if (BT_AUTO_REPORT_ONLY_8192E_1ANT == 0)
-		if ((coex_sta->bt_info_ext & BIT(4))) {
-			/* BT auto report already enabled, do nothing */
-		} else
-			halbtc8192e1ant_bt_auto_report(btcoexist, FORCE_EXEC,
-						       true);
-#endif
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8192E_1ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8192E_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8192E_1ANT_B_FTP)
-			coex_sta->pan_exist = true;
-		else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8192E_1ANT_B_A2DP)
-			coex_sta->a2dp_exist = true;
-		else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8192E_1ANT_B_HID)
-			coex_sta->hid_exist = true;
-		else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8192E_1ANT_B_SCO_ESCO)
-			coex_sta->sco_exist = true;
-		else
-			coex_sta->sco_exist = false;
-	}
-
-	halbtc8192e1ant_update_bt_link_info(btcoexist);
-
-	bt_info = bt_info &
-		0x1f;  /* mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41) */
-
-	if (!(bt_info & BT_INFO_8192E_1ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info ==
-		BT_INFO_8192E_1ANT_B_CONNECTION) {	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if ((bt_info & BT_INFO_8192E_1ANT_B_SCO_ESCO) ||
-		   (bt_info & BT_INFO_8192E_1ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8192E_1ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info & BT_INFO_8192E_1ANT_B_ACL_BUSY) {
-		if (BT_8192E_1ANT_BT_STATUS_ACL_BUSY != coex_dm->bt_status)
-			coex_dm->auto_tdma_adjust = false;
-		coex_dm->bt_status = BT_8192E_1ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_dm->bt_status = BT_8192E_1ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((BT_8192E_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8192E_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = true;
-	else
-		bt_busy = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	halbtc8192e1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8192e1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u32	u32tmp;
-	u8	u8tmpa, u8tmpb, u8tmpc;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = false;
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8192e1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-		halbtc8192e1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false,
-					     true);
-
-		halbtc8192e1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-		btcoexist->stop_coex_dm = true;
-
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948);
-		u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-		u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x67);
-		u8tmpc = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x, 0x76e=0x%x\n",
-			    u32tmp,  u8tmpa, u8tmpb, u8tmpc);
-		BTC_TRACE(trace_buf);
-
-	}
-}
-
-void ex_halbtc8192e1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-	halbtc8192e1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-	halbtc8192e1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false, true);
-
-	halbtc8192e1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-
-	ex_halbtc8192e1ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	btcoexist->stop_coex_dm = true;
-}
-
-void ex_halbtc8192e1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_WIFI_PNP_SLEEP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8192e1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8192e1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-		halbtc8192e1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false,
-					     true);
-
-		/* Sinda 20150819, workaround for driver skip leave IPS/LPS to speed up sleep time. */
-		/* Driver do not leave IPS/LPS when driver is going to sleep, so BTCoexistence think wifi is still under IPS/LPS */
-		/* BT should clear UnderIPS/UnderLPS state to avoid mismatch state after wakeup. */
-		coex_sta->under_ips = false;
-		coex_sta->under_lps = false;
-		btcoexist->stop_coex_dm = true;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = false;
-		halbtc8192e1ant_init_hw_config(btcoexist, false);
-		halbtc8192e1ant_init_coex_dm(btcoexist);
-		halbtc8192e1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8192e1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], *****************Coex DM Reset*****************\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8192e1ant_init_hw_config(btcoexist, false);
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); */
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x2, 0xfffff, 0x0); */
-	halbtc8192e1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8192e1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-#if (BT_AUTO_REPORT_ONLY_8192E_1ANT == 0)
-	halbtc8192e1ant_query_bt_info(btcoexist);
-	halbtc8192e1ant_monitor_bt_enable_disable(btcoexist);
-#else
-	halbtc8192e1ant_monitor_bt_ctr(btcoexist);
-	halbtc8192e1ant_monitor_wifi_ctr(btcoexist);
-
-	if (halbtc8192e1ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust)
-
-		halbtc8192e1ant_run_coexist_mechanism(btcoexist);
-
-	coex_sta->specific_pkt_period_cnt++;
-#endif
-}
-
-
-void ex_halbtc8192e1ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata)
-{
-	switch (op_code) {
-	case BTC_DBG_SET_COEX_NORMAL:
-		btcoexist->manual_control = false;
-		halbtc8192e1ant_init_coex_dm(btcoexist);
-		break;
-	case BTC_DBG_SET_COEX_WIFI_ONLY:
-		btcoexist->manual_control = true;
-		halbtc8192e1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8192e1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-					9);
-		break;
-	case BTC_DBG_SET_COEX_BT_ONLY:
-		/* todo */
-		break;
-	default:
-		break;
-	}
-}
-
-#endif	/*  #if (RTL8192E_SUPPORT == 1) */
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e1ant.h
deleted file mode 100644
index 10c34c1dbe0e..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e1ant.h
+++ /dev/null
@@ -1,240 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8192E_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8192E 1ANT BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8192E_1ANT				1
-
-#define	BT_INFO_8192E_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8192E_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8192E_1ANT_B_HID						BIT(5)
-#define	BT_INFO_8192E_1ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8192E_1ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8192E_1ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8192E_1ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8192E_1ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8192E_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT(0))) ? true : false)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT		2
-
-#define  BT_8192E_1ANT_WIFI_NOISY_THRESH								30   /* max: 255 */
-
-enum bt_info_src_8192e_1ant {
-	BT_INFO_SRC_8192E_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8192E_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8192E_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8192E_1ANT_MAX
-};
-
-enum bt_8192e_1ant_bt_status {
-	BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8192E_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8192E_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8192E_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8192E_1ANT_BT_STATUS_MAX
-};
-
-enum bt_8192e_1ant_wifi_status {
-	BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8192E_1ANT_WIFI_STATUS_MAX
-};
-
-enum bt_8192e_1ant_coex_algo {
-	BT_8192E_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8192E_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8192E_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8192E_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8192E_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8192E_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8192E_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8192E_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8192E_1ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-struct coex_dm_8192e_1ant {
-	/* fw mechanism */
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	/* sw mechanism */
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-	u32		arp_cnt;
-
-	u8		error_condition;
-};
-
-struct coex_sta_8192e_1ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	s8					bt_rssi;
-	boolean					bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8192E_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8192E_1ANT_MAX];
-	boolean					c2h_bt_inquiry_page;
-	boolean					c2h_bt_page;				/* Add for win8.1 page out issue */
-	boolean					wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_agg;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_agg;
-
-	boolean					cck_lock;
-	boolean					pre_ccklock;
-	u8					coex_table_type;
-
-	boolean					force_lps_on;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8192e1ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e1ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8192e1ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e1ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8192e1ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8192e1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8192e1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8192e1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8192e1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8192e1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8192e1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8192e1ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8192e1ant_coex_dm_reset(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e1ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e1ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e1ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata);
-
-#else	/*  #if (RTL8192E_SUPPORT == 1) */
-#define	ex_halbtc8192e1ant_power_on_setting(btcoexist)
-#define	ex_halbtc8192e1ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8192e1ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8192e1ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8192e1ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8192e1ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8192e1ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8192e1ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8192e1ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8192e1ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8192e1ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8192e1ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8192e1ant_halt_notify(btcoexist)
-#define	ex_halbtc8192e1ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8192e1ant_coex_dm_reset(btcoexist)
-#define	ex_halbtc8192e1ant_periodical(btcoexist)
-#define	ex_halbtc8192e1ant_display_coex_info(btcoexist)
-#define	ex_halbtc8192e1ant_dbg_control(btcoexist, op_code, op_len, pdata)
-
-#endif
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e2ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e2ant.c
deleted file mode 100644
index fe578a196888..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e2ant.c
+++ /dev/null
@@ -1,4273 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8192E Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8192E_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8192e_2ant		glcoex_dm_8192e_2ant;
-static struct  coex_dm_8192e_2ant	*coex_dm = &glcoex_dm_8192e_2ant;
-static struct  coex_sta_8192e_2ant		glcoex_sta_8192e_2ant;
-static struct  coex_sta_8192e_2ant	*coex_sta = &glcoex_sta_8192e_2ant;
-
-const char *const glbt_info_src_8192e_2ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-/* ************************************************************
- * BtCoex Version Format:
- * 1. date :			glcoex_ver_date_XXXXX_1ant
- * 2. WifiCoexVersion : glcoex_ver_XXXX_1ant
- * 3. BtCoexVersion :	glcoex_ver_btdesired_XXXXX_1ant
- * 4. others :			glcoex_ver_XXXXXX_XXXXX_1ant
- *
- * Variable should be indicated IC and Antenna numbers !!!
- * Please strictly follow this order and naming style !!!
- *
- * ************************************************************ */
-u32	glcoex_ver_date_8192e_2ant = 20170113;
-u32	glcoex_ver_8192e_2ant = 0x46;
-u32	glcoex_ver_btdesired_8192e_2ant = 0x04;
-/*1.fix miracast issue*/
-/*2.update BT FW for power on latch issue*/
-/*3. move the function of polling BT version to ex_halbtc8192e2ant_display_coex_info*/
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8192e2ant_
- * ************************************************************ */
-u8 halbtc8192e2ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8192e2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-u32 halbtc8192e2ant_decide_ra_mask(IN struct btc_coexist *btcoexist,
-				   IN u8 ss_type, IN u32 ra_mask_type)
-{
-	u32	dis_ra_mask = 0x0;
-
-	switch (ra_mask_type) {
-	case 0: /* normal mode */
-		if (ss_type == 2)
-			dis_ra_mask = 0x0;			/* enable 2ss */
-		else
-			dis_ra_mask = 0xfff00000;		/* disable 2ss */
-		break;
-	case 1: /* disable cck 1/2 */
-		if (ss_type == 2)
-			dis_ra_mask = 0x00000003;		/* enable 2ss */
-		else
-			dis_ra_mask = 0xfff00003;		/* disable 2ss */
-		break;
-	case 2: /* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		if (ss_type == 2)
-			dis_ra_mask = 0x0001f1f7;		/* enable 2ss */
-		else
-			dis_ra_mask = 0xfff1f1f7;		/* disable 2ss */
-		break;
-	default:
-		break;
-	}
-
-	return dis_ra_mask;
-}
-
-void halbtc8192e2ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-void halbtc8192e2ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = false;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-void halbtc8192e2ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-void halbtc8192e2ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8192e2ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	u32	dis_ra_mask = 0x0;
-
-	coex_dm->cur_ra_mask_type = ra_mask_type;
-	dis_ra_mask = halbtc8192e2ant_decide_ra_mask(btcoexist,
-			coex_dm->cur_ss_type, ra_mask_type);
-	halbtc8192e2ant_update_ra_mask(btcoexist, force_exec, dis_ra_mask);
-
-	halbtc8192e2ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8192e2ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8192e2ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-void halbtc8192e2ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8192e2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_hp_txrx, reg_hp_tx, reg_hp_tx, reg_hp_rx, reg_hp_rx);
-	BTC_TRACE(trace_buf);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_lp_txrx, reg_lp_tx, reg_lp_tx, reg_lp_rx, reg_lp_rx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-}
-
-
-void halbtc8192e2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-#if 1
-
-	coex_sta->crc_ok_cck =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_VHT);
-#endif
-}
-
-
-
-void halbtc8192e2ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	coex_sta->c2h_bt_info_req_sent = true;
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex],Query BT info!!!! H2C 0x61 = 0x1\n");
-	BTC_TRACE(trace_buf);
-}
-
-boolean halbtc8192e2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	boolean	wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean	wifi_connected = false;
-	u8	wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-
-		wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0,
-				  2, 34, 0);
-
-		if ((BTC_RSSI_STATE_HIGH == wifi_rssi_state) ||
-		    (BTC_RSSI_STATE_LOW == wifi_rssi_state))
-			return true;
-	}
-
-	return false;
-}
-
-void halbtc8192e2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-u8 halbtc8192e2ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	struct  btc_stack_info	*stack_info = &btcoexist->stack_info;
-	boolean				bt_hs_on = false;
-	u8				algorithm = BT_8192E_2ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_2ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_SCO_PAN;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (stack_info->num_of_hid >= 2) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID*2 + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8192E_2ANT_COEX_ALGO_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_SCO_PAN;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8192E_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8192E_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8192e2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,
-		IN u8 dac_swing_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	/* There are several type of dacswing */
-	/* 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 */
-	h2c_parameter[0] = dac_swing_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter);
-}
-
-void halbtc8192e2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				       IN u8 dec_bt_pwr_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = dec_bt_pwr_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x62, 1, h2c_parameter);
-}
-
-void halbtc8192e2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				IN boolean force_exec, IN u8 dec_bt_pwr_lvl)
-{
-	coex_dm->cur_bt_dec_pwr_lvl = dec_bt_pwr_lvl;
-
-	if (!force_exec) {
-#if 0	/* work around, avoid h2c command fail. */
-		if (coex_dm->pre_bt_dec_pwr_lvl == coex_dm->cur_bt_dec_pwr_lvl)
-			return;
-#endif
-	}
-	halbtc8192e2ant_set_fw_dec_bt_pwr(btcoexist,
-					  coex_dm->cur_bt_dec_pwr_lvl);
-
-	coex_dm->pre_bt_dec_pwr_lvl = coex_dm->cur_bt_dec_pwr_lvl;
-}
-
-void halbtc8192e2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8192e2ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8192e2ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8192e2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,
-			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
-{
-	coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_fw_dac_swing_lvl ==
-		    coex_dm->cur_fw_dac_swing_lvl)
-			return;
-	}
-
-	halbtc8192e2ant_set_fw_dac_swing_level(btcoexist,
-					       coex_dm->cur_fw_dac_swing_lvl);
-
-	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
-}
-
-void halbtc8192e2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,
-		IN boolean rx_rf_shrink_on)
-{
-	if (rx_rf_shrink_on) {
-		/* Shrink RF Rx LPF corner */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Shrink RF Rx LPF corner!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e, 0xfffff,
-					  0xffffc);
-	} else {
-		/* Resume RF Rx LPF corner */
-		/* After initialized, we can use coex_dm->bt_rf_0x1e_backup */
-		if (btcoexist->initilized) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Resume RF Rx LPF corner!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-					  0xfffff, coex_dm->bt_rf_0x1e_backup);
-		}
-	}
-}
-
-void halbtc8192e2ant_rf_shrink(IN struct btc_coexist *btcoexist,
-		       IN boolean force_exec, IN boolean rx_rf_shrink_on)
-{
-	coex_dm->cur_rf_rx_lpf_shrink = rx_rf_shrink_on;
-
-	if (!force_exec) {
-		if (coex_dm->pre_rf_rx_lpf_shrink ==
-		    coex_dm->cur_rf_rx_lpf_shrink)
-			return;
-	}
-	halbtc8192e2ant_set_sw_rf_rx_lpf_corner(btcoexist,
-						coex_dm->cur_rf_rx_lpf_shrink);
-
-	coex_dm->pre_rf_rx_lpf_shrink = coex_dm->cur_rf_rx_lpf_shrink;
-}
-
-void halbtc8192e2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xf9;	/* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-}
-
-void halbtc8192e2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8192e2ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8192e2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,
-				       IN u32 level)
-{
-	u8	val = (u8)level;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Write SwDacSwing = 0x%x\n", level);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x883, 0x3e, val);
-}
-
-void halbtc8192e2ant_set_sw_full_time_dac_swing(IN struct btc_coexist
-		*btcoexist, IN boolean sw_dac_swing_on, IN u32 sw_dac_swing_lvl)
-{
-	if (sw_dac_swing_on)
-		halbtc8192e2ant_set_dac_swing_reg(btcoexist, sw_dac_swing_lvl);
-	else
-		halbtc8192e2ant_set_dac_swing_reg(btcoexist, 0x18);
-}
-
-
-void halbtc8192e2ant_dac_swing(IN struct btc_coexist *btcoexist,
-	IN boolean force_exec, IN boolean dac_swing_on, IN u32 dac_swing_lvl)
-{
-	coex_dm->cur_dac_swing_on = dac_swing_on;
-	coex_dm->cur_dac_swing_lvl = dac_swing_lvl;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_dac_swing_on == coex_dm->cur_dac_swing_on) &&
-		    (coex_dm->pre_dac_swing_lvl ==
-		     coex_dm->cur_dac_swing_lvl))
-			return;
-	}
-	delay_ms(30);
-	halbtc8192e2ant_set_sw_full_time_dac_swing(btcoexist, dac_swing_on,
-			dac_swing_lvl);
-
-	coex_dm->pre_dac_swing_on = coex_dm->cur_dac_swing_on;
-	coex_dm->pre_dac_swing_lvl = coex_dm->cur_dac_swing_lvl;
-}
-
-void halbtc8192e2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,
-				      IN boolean adc_back_off)
-{
-	if (adc_back_off) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc05, 0x30, 0x3);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc05, 0x30, 0x1);
-	}
-}
-
-void halbtc8192e2ant_adc_back_off(IN struct btc_coexist *btcoexist,
-			  IN boolean force_exec, IN boolean adc_back_off)
-{
-	coex_dm->cur_adc_back_off = adc_back_off;
-
-	if (!force_exec) {
-		if (coex_dm->pre_adc_back_off == coex_dm->cur_adc_back_off)
-			return;
-	}
-	halbtc8192e2ant_set_adc_back_off(btcoexist, coex_dm->cur_adc_back_off);
-
-	coex_dm->pre_adc_back_off = coex_dm->cur_adc_back_off;
-}
-
-void halbtc8192e2ant_set_agc_table(IN struct btc_coexist *btcoexist,
-				   IN boolean agc_table_en)
-{
-	/* =================BB AGC Gain Table */
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x0a1A0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x091B0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x081C0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x071D0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x061E0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x051F0001);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xaa1A0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa91B0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa81C0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa71D0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa61E0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa51F0001);
-	}
-}
-
-void halbtc8192e2ant_agc_table(IN struct btc_coexist *btcoexist,
-			       IN boolean force_exec, IN boolean agc_table_en)
-{
-	coex_dm->cur_agc_table_en = agc_table_en;
-
-	if (!force_exec) {
-		if (coex_dm->pre_agc_table_en == coex_dm->cur_agc_table_en)
-			return;
-	}
-	halbtc8192e2ant_set_agc_table(btcoexist, agc_table_en);
-
-	coex_dm->pre_agc_table_en = coex_dm->cur_agc_table_en;
-}
-
-void halbtc8192e2ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8192e2ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8192e2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8192e2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	switch (type) {
-	case 0:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x55555555,
-					   0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x5a5a5a5a,
-					   0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x55dd55dd,
-					   0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x5fdf5fdf,
-					   0x5fdb5fdb, 0xffffff, 0x3);
-		break;
-	case 4:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0xdfffdfff,
-					   0x5ffb5ffb, 0xffffff, 0x3);
-		break;
-	case 5:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x5ddd5ddd,
-					   0x5fdb5fdb, 0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x5fff5fff,
-					   0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 7:
-		if (coex_sta->scan_ap_num <= NOISY_AP_NUM_THRESH_8192E)
-			halbtc8192e2ant_coex_table(btcoexist, force_exec,  0xffffffff, 0xfafafafa, 0xffffff, 0x3);
-		else
-			halbtc8192e2ant_coex_table(btcoexist, force_exec, 0xffffffff, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 8:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x5f5f5f5f, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 9:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x55555555, 0xfafafafa, 0xffffff, 0x3);
-		break;
-	case 10:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 11:
-		halbtc8192e2ant_coex_table(btcoexist, force_exec, 0x55555555, 0xfafafafa, 0xffffff, 0x3);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8192e2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8192e2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8192e2ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8192e2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8192e2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8192e2ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8192e2ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x8, 0, 0, 0, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			/*halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);*/
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			/*halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);*/
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-
-void halbtc8192e2ant_power_save_state(IN struct btc_coexist *btcoexist,
-		      IN u8 ps_type,  IN u8 lps_val,  IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-	boolean		bApEnable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE, &bApEnable);
-	if (bApEnable) {
-		ps_type = BTC_PS_WIFI_NATIVE;
-		lps_val = 0x0;
-		rpwm_val = 0x0;
-	}
-	/*for 8192e, NO 32k*/
-	low_pwr_disable = true;
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		coex_sta->force_lps_on = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS, NULL);
-		break;
-	case BTC_PS_LPS_ON:
-		coex_sta->force_lps_on = true;
-		halbtc8192e2ant_ps_tdma_check_for_power_save_state(btcoexist, true);
-		halbtc8192e2ant_lps_rpwm(btcoexist, NORMAL_EXEC, lps_val, rpwm_val);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER, &low_pwr_disable);
-		/* power save must executed before psTdma. */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS, NULL);
-		break;
-	case BTC_PS_LPS_OFF:
-		coex_sta->force_lps_on = false;
-		halbtc8192e2ant_ps_tdma_check_for_power_save_state(btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS, NULL);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8192e2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean		ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if ((ap_enable) && (byte1 & BIT(4) && !(byte1 & BIT(5)))) {
-		real_byte1 &= ~BIT(4);
-		real_byte1 |= BIT(5);
-
-		real_byte5 |= BIT(5);
-		real_byte5 &= ~BIT(6);
-	} else if ((byte1 & BIT(4)) && (!(byte1 & BIT(5))))
-		halbtc8192e2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-	else
-		halbtc8192e2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-
-	h2c_parameter[0] = byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = byte5;
-
-	coex_dm->ps_tdma_para[0] = byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-void halbtc8192e2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,
-			   IN boolean shrink_rx_lpf, IN boolean low_penalty_ra,
-			   IN boolean limited_dig, IN boolean bt_lna_constrain)
-{
-	/*
-	u32	wifi_bw;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if(BTC_WIFI_BW_HT40 != wifi_bw)
-	{
-		if (shrink_rx_lpf)
-			shrink_rx_lpf = false;
-	}
-	*/
-
-	halbtc8192e2ant_rf_shrink(btcoexist, NORMAL_EXEC, shrink_rx_lpf);
-	/* halbtc8192e2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra); */
-}
-
-void halbtc8192e2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,
-			   IN boolean agc_table_shift, IN boolean adc_back_off,
-			   IN boolean sw_dac_swing, IN u32 dac_swing_lvl)
-{
-	halbtc8192e2ant_agc_table(btcoexist, NORMAL_EXEC, agc_table_shift);
-	/* halbtc8192e2ant_adc_back_off(btcoexist, NORMAL_EXEC, adc_back_off); */
-	halbtc8192e2ant_dac_swing(btcoexist, NORMAL_EXEC, sw_dac_swing,
-				  dac_swing_lvl);
-}
-
-void halbtc8192e2ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean init_hwcfg, IN boolean wifi_off)
-{
-	u32			u32tmp = 0;
-
-	if (init_hwcfg) {
-		btcoexist->btc_write_1byte(btcoexist, 0x944, 0x24);
-		btcoexist->btc_write_4byte(btcoexist, 0x930, 0x700700);
-		if (btcoexist->chip_interface == BTC_INTF_USB)
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30430004);
-		else
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30030004);
-
-		/* 0x4c[27][24]='00', Set Antenna to BB */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp &= ~BIT(24);
-		u32tmp &= ~BIT(27);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-	} else if (wifi_off) {
-		if (btcoexist->chip_interface == BTC_INTF_USB)
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30430004);
-		else
-			btcoexist->btc_write_4byte(btcoexist, 0x64, 0x30030004);
-
-		/* 0x4c[27][24]='11', Set Antenna to BT, 0x64[8:7]=0, 0x64[2]=1 */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp |= BIT(24);
-		u32tmp |= BIT(27);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-	}
-
-	/* ext switch setting */
-	switch (ant_pos_type) {
-	case BTC_ANT_PATH_WIFI:
-		btcoexist->btc_write_1byte(btcoexist, 0x92c, 0x4);
-		break;
-	case BTC_ANT_PATH_BT:
-		btcoexist->btc_write_1byte(btcoexist, 0x92c, 0x20);
-		break;
-	default:
-	case BTC_ANT_PATH_PTA:
-		btcoexist->btc_write_1byte(btcoexist, 0x92c, 0x4);
-		break;
-	}
-}
-
-void halbtc8192e2ant_set_switch_ss_type(IN struct btc_coexist *btcoexist,
-					IN u8 ss_type)
-{
-	u8	mimo_ps = BTC_MIMO_PS_DYNAMIC;
-	u32	dis_ra_mask = 0x0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], REAL set SS Type = %d\n", ss_type);
-	BTC_TRACE(trace_buf);
-
-	dis_ra_mask = halbtc8192e2ant_decide_ra_mask(btcoexist, ss_type,
-			coex_dm->cur_ra_mask_type);
-	halbtc8192e2ant_update_ra_mask(btcoexist, FORCE_EXEC, dis_ra_mask);
-
-	if (ss_type == 1) {
-		/*halbtc8192e2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 1);*/
-		/* switch ofdm path */
-		btcoexist->btc_write_1byte(btcoexist, 0xc04, 0x11);
-		btcoexist->btc_write_1byte(btcoexist, 0xd04, 0x1);
-		btcoexist->btc_write_4byte(btcoexist, 0x90c, 0x81111111);
-		/* switch cck patch */
-		/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0xe77, 0x4, 0x1); */
-		/* btcoexist->btc_write_1byte(btcoexist, 0xa07, 0x81); */
-		mimo_ps = BTC_MIMO_PS_STATIC;
-	} else if (ss_type == 2) {
-		/*halbtc8192e2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);*/
-		btcoexist->btc_write_1byte(btcoexist, 0xc04, 0x33);
-		btcoexist->btc_write_1byte(btcoexist, 0xd04, 0x3);
-		btcoexist->btc_write_4byte(btcoexist, 0x90c, 0x81121313);
-		/* remove, if 0xe77[2]=0x0 then CCK will fail, advised by Jenyu */
-		/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0xe77, 0x4, 0x0); */
-		/* btcoexist->btc_write_1byte(btcoexist, 0xa07, 0x41); */
-		mimo_ps = BTC_MIMO_PS_DYNAMIC;
-	}
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_SEND_MIMO_PS,
-			   &mimo_ps);	/* set rx 1ss or 2ss */
-}
-
-void halbtc8192e2ant_switch_ss_type(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 new_ss_type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s Switch SS Type = %d\n",
-		    (force_exec ? "force to" : ""), new_ss_type);
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_ss_type = new_ss_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ss_type == coex_dm->cur_ss_type)
-			return;
-	}
-	halbtc8192e2ant_set_switch_ss_type(btcoexist, coex_dm->cur_ss_type);
-
-	coex_dm->pre_ss_type = coex_dm->cur_ss_type;
-}
-
-void halbtc8192e2ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	s8		wifi_duration_adjust = 0x0;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-
-	if (coex_sta->scan_ap_num  >= 40)
-		wifi_duration_adjust = -15;
-	else if (coex_sta->scan_ap_num  >= 20)
-		wifi_duration_adjust = -10;
-
-
-	if (turn_on) {
-		switch (type) {
-		case 1:
-		default:	/*d1,wb*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x3c, 0x03, 0x11, 0x10);
-			break;
-		case 2:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x32, 0x03, 0x11, 0x10);
-			break;
-		case 3:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x28, 0x03, 0x11, 0x10);
-			break;
-		case 4:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1e, 0x03, 0x11, 0x10);
-			break;
-		case 5:		/*d1,pb,TXpause*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x63, 0x3c, 0x03, 0x90, 0x10);
-			break;
-		case 6:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x63, 0x32, 0x03, 0x90, 0x10);
-			break;
-		case 7:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x63, 0x28, 0x03, 0x90, 0x10);
-			break;
-		case 8:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x63, 0x1e, 0x03, 0x90, 0x10);
-			break;
-		case 9:		/*d1,bb*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x3c, 0x03, 0x31, 0x10);
-			break;
-		case 10:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x32, 0x03, 0x31, 0x10);
-			break;
-		case 11:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x28, 0x03, 0x31, 0x10);
-			break;
-		case 12:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1e, 0x03, 0x31, 0x10);
-			break;
-		case 13:		/*d1,bb,TXpause*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x3c, 0x03, 0x30, 0x10);
-			break;
-		case 14:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x32, 0x03, 0x30, 0x10);
-			break;
-		case 15:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x28, 0x03, 0x30, 0x10);
-			break;
-		case 16:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1e, 0x03, 0x30, 0x10);
-			break;
-		case 17:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x61, 0x20, 0x03, 0x10, 0x10);
-			break;
-		case 18:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90);
-			break;
-		case 19:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x25, 0x25, 0xe1, 0x90);
-			break;
-		case 20:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x25, 0x25, 0x60, 0x90);
-			break;
-		case 21:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x61, 0x15, 0x03, 0x11, 0x11);
-			break;
-		case 22:	/* d1,wb */
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x14, 0x03, 0x11, 0x14);
-			break;
-		case 23:	/* d1,pb,TXpause */
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x63, 0x14, 0x03, 0x90, 0x14);
-			break;
-		case 24:	/* d1,bb */
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x14, 0x03, 0x31, 0x14);
-			break;
-		case 25:	/* d1,bb,TXpause */
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x14, 0x03, 0x30, 0x14);
-			break;
-		case 26:	/*d1,wp,noTXpause*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe1, 0x3c, 0x03, 0x11, 0x10);
-			break;
-		case 27:	/*11,pp,noTXpause*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x61, 0x3c, 0x03, 0x11, 0x11);
-			break;
-		case 28:	/*11,pp,noTXpause*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x61, 0x50, 0x03, 0x11, 0x11);
-			break;
-		case 29:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x61, 0x15, 0x03, 0x11, 0x11);
-			break;
-		case 30:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x14, 0x03, 0x10, 0x14);
-			break;
-		case 31: /*d3,bb,TXpause*/
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x14, 0x03, 0x30, 0x94);
-			break;
-		case 32:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x61, 0x35, 0x03, 0x11, 0x11);
-			break;
-		case 71:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90);
-			break;
-		/* following cases is for wifi rssi low // bad antenna isolation, started from 81 */
-		case 80:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x3c, 0x3, 0x10, 0x50);
-			break;
-		case 81:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x3a + wifi_duration_adjust, 0x3, 0x10, 0x50);
-			break;
-		case 82:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x30 + wifi_duration_adjust, 0x03, 0x10, 0x50);
-			break;
-		case 83:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x21, 0x03, 0x10, 0x50);
-			break;
-		case 84:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x15, 0x3, 0x10, 0x50);
-			break;
-		case 85:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x3a, 0x03, 0x10, 0x50);
-			break;
-		case 86:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x21, 0x03, 0x10, 0x50);
-			break;
-		case 87:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x51, 0x14, 0x03, 0x10, 0x54);
-			break;
-		case 88:
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x53, 0x14, 0x03, 0x10, 0x54);
-			break;
-		}
-	} else {
-		/* disable PS tdma */
-		switch (type) {
-		default:
-		case 0:  /* ANT2PTA, 0x778=1 */
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x8, 0x0, 0x0, 0x0, 0x0);
-			halbtc8192e2ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, false, false);
-			break;
-		case 1:  /* ANT2BT, 0x778=3 */
-			halbtc8192e2ant_set_fw_pstdma(btcoexist, 0x0, 0x0, 0x0, 0x8, 0x0);
-			delay_ms(5);
-			halbtc8192e2ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false, false);
-			break;
-		}
-	}
-
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-
-void halbtc8192e2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32	bt_disable_cnt = 0;
-	boolean			bt_active = true, bt_disabled = false;
-
-	/* This function check if bt is disabled */
-
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = false;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = false;
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is enabled !!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		bt_disable_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], bt all counters=0, %d times!!\n",
-			    bt_disable_cnt);
-		BTC_TRACE(trace_buf);
-		if (bt_disable_cnt >= 2) {
-			bt_disabled = true;
-			btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-					   &bt_disabled);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-		if (bt_disabled) {
-			halbtc8192e2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		}
-	}
-}
-
-
-void halbtc8192e2ant_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-	/* fw all off */
-	halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	/* hw all off */
-	halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8192e2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	coex_sta->cnt_setup_link = 0;
-
-	/* force to reset coex mechanism */
-	halbtc8192e2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6);
-	halbtc8192e2ant_dec_bt_pwr(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8192e2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-	halbtc8192e2ant_switch_ss_type(btcoexist, FORCE_EXEC, 2);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-void halbtc8192e2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	struct	btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	if (coex_sta->wifi_is_high_pri_task && (!bt_link_info->a2dp_exist)) {
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11);
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-	} else {
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 29);
-	}
-
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-boolean halbtc8192e2ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean			common = false, wifi_connected = false, wifi_busy = false;
-	boolean			bt_hs_on = false, low_pwr_disable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (bt_link_info->sco_exist || bt_link_info->hid_exist)
-		halbtc8192e2ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 0, 0, 0);
-	else
-		halbtc8192e2ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-	if (!wifi_connected) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non-connected idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		if ((coex_dm->bt_status == BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE) ||
-		    (coex_dm->bt_status == BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE)) {
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		} else {
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-		}
-		halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-		halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-		common = true;
-	} else {
-		if (coex_dm->bt_status == BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE) {
-			if (wifi_busy && (coex_sta->high_priority_rx > 10))  {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Wifi busy + BT non connected-idle!!\n");
-				BTC_TRACE(trace_buf);
-
-				halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 9);
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 26);
-				halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-				halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-				halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-				common = true;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Wifi connected-idle + BT non connected-idle!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-				halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-				halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-				halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-				common = true;
-			}
-		} else if (coex_dm->bt_status == BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE) {
-
-			if (bt_hs_on)
-				return false;
-
-			if (wifi_busy) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Wifi busy + BT connected-idle!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 10);
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 27);
-				halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-				halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-				halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-				common = true;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Wifi connected-idle + BT connected-idle!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-				halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-				halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_sw_mechanism1(btcoexist, true, false, false, false);
-				halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-				common = true;
-			}
-		} else {
-
-			if (wifi_busy) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-				common = false;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 21);
-				halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-				halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-				halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-				halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-				common = true;
-			}
-		}
-	}
-	return common;
-}
-
-
-void halbtc8192e2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,
-		IN boolean sco_hid, IN boolean tx_pause, IN u8 max_interval)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0;
-
-
-	if (!coex_dm->auto_tdma_adjust) {
-		coex_dm->auto_tdma_adjust = true;
-		{
-			if (sco_hid) {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					} else if (max_interval == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (max_interval == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					} else if (max_interval == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (max_interval == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			} else {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (max_interval == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (max_interval == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (max_interval == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (max_interval == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					}
-				}
-			}
-		}
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2 */
-		retry_count = coex_sta->bt_retry_cnt;
-		result = 0;
-		wait_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if retry count during continuous n*2 seconds is 0, enlarge WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if continuous 2 retry count(every 2 seconds) >0 and < 3, reduce WiFi duration */
-				if (wait_count <= 2)
-					m++; /* to avoid loop between the two levels */
-				else
-					m = 1;
-
-				if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-			}
-		} else { /* retry count > 3, once retry count > 3, to reduce WiFi duration */
-			if (wait_count == 1)
-				m++; /* to avoid loop between the two levels */
-			else
-				m = 1;
-
-			if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-		}
-
-		if (max_interval == 1) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 5);
-					coex_dm->ps_tdma_du_adj_type = 5;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 13);
-					coex_dm->ps_tdma_du_adj_type = 13;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 1);
-					coex_dm->ps_tdma_du_adj_type = 1;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 9);
-					coex_dm->ps_tdma_du_adj_type = 9;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 71);
-						coex_dm->ps_tdma_du_adj_type =
-							71;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					}
-				}
-			}
-		} else if (max_interval == 2) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					}
-				}
-			}
-		} else if (max_interval == 3) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8192e2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8192e2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			}
-		}
-	}
-
-	/* 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 (coex_dm->cur_ps_tdma != coex_dm->ps_tdma_du_adj_type) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], PsTdma type dismatch!!!, cur_ps_tdma=%d, recordPsTdma=%d\n",
-			    coex_dm->cur_ps_tdma, coex_dm->ps_tdma_du_adj_type);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (!scan && !link && !roam)
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-}
-
-/* ******************
- * pstdma for wifi rssi low
- * ****************** */
-void halbtc8192e2ant_tdma_duration_adjust_for_wifi_rssi_low(
-	IN struct btc_coexist *btcoexist/* , */ /* IN u8 wifi_status */)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0, bt_info_ext;
-
-	coex_dm->auto_tdma_adjust = false;
-
-	retry_count = coex_sta->bt_retry_cnt;
-	bt_info_ext = coex_sta->bt_info_ext;
-
-	if (!coex_dm->auto_tdma_adjust_low_rssi) {
-		coex_dm->auto_tdma_adjust_low_rssi = true;
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 81);
-		coex_dm->ps_tdma_du_adj_type = 81;
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2
-		*		retry_count = coex_sta->bt_retry_cnt;
-		*		bt_info_ext = coex_sta->bt_info_ext; */
-		result = 0;
-		wait_count++;
-
-		if ((coex_sta->low_priority_tx) > 1050 ||
-		    (coex_sta->low_priority_rx) > 1250)
-			retry_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if retry count during continuous n*2 seconds is 0, enlarge WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if continuous 2 retry count(every 2 seconds) >0 and < 3, reduce WiFi duration */
-				if (wait_count <= 2)
-					m++; /* to avoid loop between the two levels */
-				else
-					m = 1;
-
-				if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-			}
-		} else { /* retry count > 3, once retry count > 3, to reduce WiFi duration */
-			if (wait_count == 1)
-				m++; /* to avoid loop between the two levels */
-			else
-				m = 1;
-
-			if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-		}
-
-		if (result == -1) {
-			if (coex_dm->cur_ps_tdma == 80) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 81);
-				coex_dm->ps_tdma_du_adj_type = 81;
-			} else if (coex_dm->cur_ps_tdma == 81) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 82);
-				coex_dm->ps_tdma_du_adj_type = 82;
-			} else if (coex_dm->cur_ps_tdma == 82) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 83);
-				coex_dm->ps_tdma_du_adj_type = 83;
-			} else if (coex_dm->cur_ps_tdma == 83) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 84);
-				coex_dm->ps_tdma_du_adj_type = 84;
-			}
-		} else if (result == 1) {
-			if (coex_dm->cur_ps_tdma == 84) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 83);
-				coex_dm->ps_tdma_du_adj_type = 83;
-			} else if (coex_dm->cur_ps_tdma == 83) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 82);
-				coex_dm->ps_tdma_du_adj_type = 82;
-			} else if (coex_dm->cur_ps_tdma == 82) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 81);
-				coex_dm->ps_tdma_du_adj_type = 81;
-			} else if ((coex_dm->cur_ps_tdma == 81) &&
-				   (coex_sta->scan_ap_num <= 5)) {
-				halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 81);
-				coex_dm->ps_tdma_du_adj_type = 81;
-			}
-		}
-
-		if (coex_dm->cur_ps_tdma != 80 &&
-		    coex_dm->cur_ps_tdma != 81 &&
-		    coex_dm->cur_ps_tdma != 82 &&
-		    coex_dm->cur_ps_tdma != 83 &&
-		    coex_dm->cur_ps_tdma != 84) {
-			/* recover to previous adjust type */
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		}
-	}
-}
-
-
-void halbtc8192e2ant_get_bt_rssi_threshold(IN struct btc_coexist *btcoexist,
-		IN u8 *pThres0, IN u8 *pThres1)
-{
-	u8 ant_type;
-
-	struct  btc_board_info  *board_info = &btcoexist->board_info;
-
-	ant_type = board_info->ant_type;
-
-	switch (ant_type) {
-	case BTC_ANT_TYPE_0:
-		*pThres0 = 100;
-		*pThres1 = 100;
-		break;
-	case BTC_ANT_TYPE_1:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	case BTC_ANT_TYPE_2:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	case BTC_ANT_TYPE_3:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	case BTC_ANT_TYPE_4:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8192e2ant_action_bt_relink(IN struct btc_coexist *btcoexist)
-{
-	if (coex_sta->wifi_is_high_pri_task) {
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	} else {
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-	}
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-
-/* SCO only or SCO+PAN(HS) */
-void halbtc8192e2ant_action_sco(IN struct btc_coexist *btcoexist)
-{
-	u8	wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-	u32	wifi_bw;
-	u8	bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8192e2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	else
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&	(!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-	else
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-
-
-	halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-void halbtc8192e2ant_action_sco_pan(IN struct btc_coexist *btcoexist)
-{
-	u8	wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-	u32	wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-
-	halbtc8192e2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	else
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 10);
-	else
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 86);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)) &&
-	    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8192E))
-		halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-	else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		 (coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8192E))
-		halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-	else
-		halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-}
-
-
-void halbtc8192e2ant_action_hid(IN struct btc_coexist *btcoexist)
-{
-	u8	wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32	wifi_bw;
-	u8	anttype = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34, 0);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, 34, 42);
-
-	if (anttype == 0) {
-		/*ANTTYPE = 0   2ant with SPDT*/
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 28);
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if (anttype == 1) {
-		/*2ant with coupler and bad ant. isolation, 3ant with bad ant. isolation*/
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 28);
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if (anttype == 2) {
-		/*ANTTYPE = 2, 2ant with coupler and normal/good ant. isolation, 3ant with normal ant. isolation*/
-		if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-		}
-	} else if (anttype == 3) {
-		/*ANTTYPE = 3,  3ant with good ant. isolation*/
-		if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		}
-	}
-
-	halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-void halbtc8192e2ant_action_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	boolean		long_dist = false;
-	u8	anttype = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34, 0);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, 34, 42);
-
-	if (anttype == 0) {
-		/*ANTTYPE = 0   2ant with SPDT*/
-		if ((coex_sta->scan_ap_num > 40) && (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 30);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 88);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		}
-	} else if (anttype == 1) {
-		/*2ant with coupler and bad ant. isolation, 3ant with bad ant. isolation*/
-		if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 25);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 88);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		}
-	} else if (anttype == 2) {
-		/*ANTTYPE = 2, 2ant with coupler and normal/good ant. isolation, 3ant with normal ant. isolation*/
-		if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 88);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		}
-	} else if (anttype == 3) {
-		/*ANTTYPE = 3,  3ant with good ant. isolation*/
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	}
-	halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-void halbtc8192e2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, 34, 42);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-		halbtc8192e2ant_tdma_duration_adjust(btcoexist, false, true, 2);
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	} else if ((bt_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-		   (bt_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM)) {
-		halbtc8192e2ant_tdma_duration_adjust(btcoexist, false, false,
-						     2);
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	} else if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		   (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		halbtc8192e2ant_tdma_duration_adjust(btcoexist, false, false,
-						     2);
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	}
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		} else {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x6);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		} else {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x6);
-		}
-	}
-}
-
-void halbtc8192e2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8192e2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-	/*	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34, 0); */
-	wifi_rssi_state = BTC_RSSI_STATE_LOW;
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&	(!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 1);
-	else
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 85);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-/* PAN(HS) only */
-void halbtc8192e2ant_action_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, 34, 42);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_LOW))
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	else if ((bt_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-		 (bt_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM))
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		 (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH))
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8192e2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8192e2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* PAN(EDR)+A2DP */
-void halbtc8192e2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8192e2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-	/*	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34, 0); */
-	wifi_rssi_state = BTC_RSSI_STATE_LOW;
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 4);
-	else
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 86);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-}
-
-void halbtc8192e2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8192e2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	else
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&	(!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 10);
-	else
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 86);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-/* HID+A2DP+PAN(EDR) */
-void halbtc8192e2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8192e2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	else
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 4);
-	else
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 86);
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-void halbtc8192e2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0, anttype = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-	wifi_rssi_state = halbtc8192e2ant_wifi_rssi_state(btcoexist, 0, 2, 34, 0);
-	bt_rssi_state = halbtc8192e2ant_bt_rssi_state(3, 34, 42);
-
-	if (anttype == 0) {
-		/*2ant with SPDT*/
-		if ((coex_sta->scan_ap_num > 40) && (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 31);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 88);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		}
-	} else if (anttype == 1) {
-		/*2ant with coupler and bad ant. isolation, 3ant with bad ant. isolation*/
-		if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 25);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 87);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		}
-	} else if (anttype == 2) {
-		/*ANTTYPE = 2, 2ant with coupler and normal/good ant. isolation, 3ant with normal ant. isolation*/
-		if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state))) {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 25);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		} else {
-			halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 87);
-			halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		}
-	} else if (anttype == 3) {
-		/*ANTTYPE = 3,  3ant with good ant. isolation*/
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	}
-
-	halbtc8192e2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-	halbtc8192e2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	halbtc8192e2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8192e2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-void halbtc8192e2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8				algorithm = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	algorithm = halbtc8192e2ant_action_algorithm(btcoexist);
-	if (coex_sta->c2h_bt_inquiry_page &&
-	    (BT_8192E_2ANT_COEX_ALGO_PANHS != algorithm)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8192e2ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	if (coex_sta->is_setup_link) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is re-link !!!\n");
-		halbtc8192e2ant_action_bt_relink(btcoexist);
-		return;
-	}
-
-
-	coex_dm->cur_algorithm = algorithm;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Algorithm = %d\n",
-		    coex_dm->cur_algorithm);
-	BTC_TRACE(trace_buf);
-
-	if (halbtc8192e2ant_is_common_action(btcoexist)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant common.\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->auto_tdma_adjust = false;
-		coex_dm->auto_tdma_adjust_low_rssi = false;
-
-	} else {
-		if (coex_dm->cur_algorithm != coex_dm->pre_algorithm) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], pre_algorithm=%d, cur_algorithm=%d\n",
-				coex_dm->pre_algorithm, coex_dm->cur_algorithm);
-			BTC_TRACE(trace_buf);
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-
-		}
-		switch (coex_dm->cur_algorithm) {
-		case BT_8192E_2ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_sco(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_SCO_PAN:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = SCO+PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_sco_pan(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_hid(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_a2dp(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_a2dp_pan_hs(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_pan_edr(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_pan_hs(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_pan_edr_a2dp(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_pan_edr_hid(btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_hid_a2dp_pan_edr(
-				btcoexist);
-			break;
-		case BT_8192E_2ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_action_hid_a2dp(btcoexist);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = unknown!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8192e2ant_coex_all_off(btcoexist);
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-void halbtc8192e2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up)
-{
-	u16	u16tmp = 0;
-	u8	u8tmp = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 2Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	if (back_up) {
-		/* backup rf 0x1e value */
-		coex_dm->bt_rf_0x1e_backup =
-			btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-						  0xfffff);
-
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	}
-
-	/* antenna sw ctrl to bt */
-	halbtc8192e2ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, true, false);
-
-	halbtc8192e2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	/* antenna switch control parameter */
-	/*	btcoexist->btc_write_4byte(btcoexist, 0x858, 0x55555555); */
-
-	/* coex parameters */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x3);
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	/* enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	/* enable PTA */
-	btcoexist->btc_write_1byte(btcoexist, 0x40, 0x20);
-	/* enable mailbox interface */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x40);
-	u16tmp |= BIT(9);
-	btcoexist->btc_write_2byte(btcoexist, 0x40, u16tmp);
-
-	/* enable PTA I2C mailbox */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x101);
-	u8tmp |= BIT(4);
-	btcoexist->btc_write_1byte(btcoexist, 0x101, u8tmp);
-
-	/* enable bt clock when wifi is disabled. */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x93);
-	u8tmp |= BIT(0);
-	btcoexist->btc_write_1byte(btcoexist, 0x93, u8tmp);
-	/* enable bt clock when suspend. */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x7);
-	u8tmp |= BIT(0);
-	btcoexist->btc_write_1byte(btcoexist, 0x7, u8tmp);
-
-	/* Give bt_coex_supported_version the default value */
-	coex_sta->bt_coex_supported_version = 0;
-}
-
-/* ************************************************************
- * work around function start with wa_halbtc8192e2ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8192e2ant_
- * ************************************************************ */
-void ex_halbtc8192e2ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8192e2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8192e2ant_init_hw_config(btcoexist, true);
-}
-
-void ex_halbtc8192e2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8192e2ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8192e2ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_stack_info		*stack_info = &btcoexist->stack_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	u32				phyver = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "Ant PG number/ Ant mechanism:",
-		   board_info->pg_ant_num, board_info->btdm_ant_num);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Antenna type:",
-		   board_info->ant_type);
-	CL_PRINTF(cli_buf);
-
-	if (!coex_sta->bt_disabled) {
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			(coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-						&bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-	bt_coex_ver = coex_sta->bt_coex_supported_version & 0xff;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8192e_2ant, glcoex_ver_8192e_2ant,
-		   glcoex_ver_btdesired_8192e_2ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (coex_sta->bt_disabled ? "BT-disable" :
-		     (bt_coex_ver >= glcoex_ver_btdesired_8192e_2ant ?
-		      "Match" : "Mis-Match"))));
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d",
-		   "W_FW/ B_FW/ Phy", fw_ver, bt_patch_ver, phyver);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/", "WifibHiPri",
-		(coex_sta->wifi_is_high_pri_task ? "Yes" : "No"));
-	CL_PRINTF(cli_buf);
-
-#if 0
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/", "test patch version",
-			"20161003_v3");
-		CL_PRINTF(cli_buf);
-#endif
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi, coex_sta->bt_retry_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP",
-		   stack_info->sco_exist, stack_info->hid_exist,
-		   stack_info->pan_exist, stack_info->a2dp_exist);
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Info A2DP rate",
-		   (bt_info_ext & BIT(0)) ? "Basic rate" : "EDR rate");
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8192E_2ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8192e_2ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "SS Type",
-		   coex_dm->cur_ss_type);
-	CL_PRINTF(cli_buf);
-
-	/* Sw mechanism	 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Sw mechanism]============");
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ",
-		   "SM1[ShRf/ LpRA/ LimDig]",
-		   coex_dm->cur_rf_rx_lpf_shrink, coex_dm->cur_low_penalty_ra,
-		   coex_dm->limited_dig);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ",
-		   "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]",
-		   coex_dm->cur_agc_table_en, coex_dm->cur_adc_back_off,
-		   coex_dm->cur_dac_swing_on, coex_dm->cur_dac_swing_lvl);
-	CL_PRINTF(cli_buf);
-
-	/* Fw mechanism		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Fw mechanism]============");
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)",
-		   "PS TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   coex_dm->auto_tdma_adjust);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "DecBtPwr/ IgnWlanAct",
-		   coex_dm->cur_bt_dec_pwr_lvl, coex_dm->cur_ignore_wlan_act);
-	CL_PRINTF(cli_buf);
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x",
-		   "RF-A, 0x1e initVal",
-		   coex_dm->bt_rf_0x1e_backup);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "backup ARFR1/ARFR2/RL/AMaxTime",
-		   coex_dm->backup_arfr_cnt1, coex_dm->backup_arfr_cnt2,
-		   coex_dm->backup_retry_limit,
-		   coex_dm->backup_ampdu_max_time);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
-	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x456);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "0x430/0x434/0x42a/0x456",
-		   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc04);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xd04);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x90c);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0xc04/ 0xd04/ 0x90c",
-		   u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x880);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "0x778/0x880[29:25]",
-		u8tmp[0], (u32tmp[0] & 0x3e000000) >> 25);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x92c);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x930);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x92c/ 0x930",
-		   (u8tmp[0]), u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x4f);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x40/ 0x4f",
-		   u8tmp[0], u8tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)",
-		   u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11n-agg",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(hp rx[31:16]/tx[15:0])",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(lp rx[31:16]/tx[15:0])",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8192E_2ANT == 1)
-	halbtc8192e2ant_monitor_bt_ctr(btcoexist);
-#endif
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8192e2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = true;
-		halbtc8192e2ant_coex_all_off(btcoexist);
-		halbtc8192e2ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false, true);
-		halbtc8192e2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-		ex_halbtc8192e2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = false;
-		halbtc8192e2ant_init_hw_config(btcoexist, false);
-		halbtc8192e2ant_init_coex_dm(btcoexist);
-	}
-}
-
-void ex_halbtc8192e2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = true;
-
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8192e2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	if (BTC_SCAN_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-	} else if (BTC_SCAN_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-
-	}
-}
-
-void ex_halbtc8192e2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	if (BTC_ASSOCIATE_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->wifi_is_high_pri_task = true;
-		coex_sta->cnt_wifi_high_pri = 2;
-		halbtc8192e2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, false);
-		halbtc8192e2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8192e2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11);
-		halbtc8192e2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	} else if (BTC_ASSOCIATE_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->wifi_is_high_pri_task = false;
-		halbtc8192e2ant_run_coexist_mechanism(btcoexist);
-	}
-}
-
-void ex_halbtc8192e2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		h2c_parameter[0] = 0x1;
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-}
-
-void ex_halbtc8192e2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	if (type == BTC_PACKET_DHCP) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], DHCP Packet notify\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void ex_halbtc8192e2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8			bt_info = 0;
-	u8			i, rsp_source = 0;
-	boolean			bt_busy = false, limited_dig = false;
-	boolean			wifi_connected = false;
-	static u8		bt_info_for_wifi_fw_count = 0;
-
-	coex_sta->c2h_bt_info_req_sent = false;
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8192E_2ANT_MAX)
-		rsp_source = BT_INFO_SRC_8192E_2ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-
-	/*avoid mailbox issue*/
-	if (rsp_source == BT_INFO_SRC_8192E_2ANT_WIFI_FW) {
-		bt_info_for_wifi_fw_count++;
-		if (bt_info_for_wifi_fw_count < 5)
-			return;
-	} else
-		bt_info_for_wifi_fw_count = 0;
-
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	if (BT_INFO_SRC_8192E_2ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 + 10;
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if ((coex_sta->bt_info_ext & BIT(1))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-			if (wifi_connected)
-				ex_halbtc8192e2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8192e2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setup_link++;
-			coex_sta->is_setup_link = true;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link start in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		} else
-			coex_sta->is_setup_link = false;
-
-		if ((coex_sta->bt_info_ext & BIT(3))) {
-			if (!btcoexist->manual_control &&
-			    !btcoexist->stop_coex_dm) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8192e2ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, false);
-			}
-		} else {
-			/* BT already NOT ignore Wlan active, do nothing here. */
-		}
-
-#if (BT_AUTO_REPORT_ONLY_8192E_2ANT == 0)
-		if ((coex_sta->bt_info_ext & BIT(4))) {
-			/* BT auto report already enabled, do nothing */
-		} else
-			halbtc8192e2ant_bt_auto_report(btcoexist, FORCE_EXEC,
-						       true);
-#endif
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8192E_2ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8192E_2ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8192E_2ANT_B_FTP)
-			coex_sta->pan_exist = true;
-		else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8192E_2ANT_B_A2DP)
-			coex_sta->a2dp_exist = true;
-		else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8192E_2ANT_B_HID)
-			coex_sta->hid_exist = true;
-		else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8192E_2ANT_B_SCO_ESCO)
-			coex_sta->sco_exist = true;
-		else
-			coex_sta->sco_exist = false;
-	}
-
-	halbtc8192e2ant_update_bt_link_info(btcoexist);
-
-	if (!(bt_info & BT_INFO_8192E_2ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info ==
-		BT_INFO_8192E_2ANT_B_CONNECTION) {	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if ((bt_info & BT_INFO_8192E_2ANT_B_SCO_ESCO) ||
-		   (bt_info & BT_INFO_8192E_2ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8192E_2ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info & BT_INFO_8192E_2ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8192E_2ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_dm->bt_status = BT_8192E_2ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((BT_8192E_2ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8192E_2ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8192E_2ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status)) {
-		bt_busy = true;
-		limited_dig = true;
-	} else {
-		bt_busy = false;
-		limited_dig = false;
-	}
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	coex_dm->limited_dig = limited_dig;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_LIMITED_DIG, &limited_dig);
-
-	halbtc8192e2ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8192e2ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8192e2ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false, true);
-	halbtc8192e2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-	ex_halbtc8192e2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-}
-
-void ex_halbtc8192e2ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	boolean			wifi_connected = false;
-	static u8			count = 0;
-	static boolean		pre_wifi_connected = false;
-
-/*If wifi is connecting, the update of wifi channel mask may fail caused by wifi FW*/
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-
-	if (pre_wifi_connected != wifi_connected)
-		count = 0;
-
-	if  (count < 10)
-		count++;
-
-	if (count == 2) {
-		if (wifi_connected)
-			ex_halbtc8192e2ant_media_status_notify(btcoexist, BTC_MEDIA_CONNECT);
-		else
-			ex_halbtc8192e2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-	}
-
-	pre_wifi_connected = wifi_connected;
-/*If wifi is connecting, the update of wifi channel mask may fail caused by wifi FW*/
-
-#if (BT_AUTO_REPORT_ONLY_8192E_2ANT == 0)
-	halbtc8192e2ant_query_bt_info(btcoexist);
-	halbtc8192e2ant_monitor_bt_ctr(btcoexist);
-	halbtc8192e2ant_monitor_wifi_ctr(btcoexist);
-	halbtc8192e2ant_monitor_bt_enable_disable(btcoexist);
-#else
-	halbtc8192e2ant_monitor_wifi_ctr(btcoexist);
-
-	if (halbtc8192e2ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust)
-		halbtc8192e2ant_run_coexist_mechanism(btcoexist);
-#endif
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e2ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e2ant.h
deleted file mode 100644
index 3b5a8acdf74f..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8192e2ant.h
+++ /dev/null
@@ -1,230 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8192E_SUPPORT == 1)
-/* *******************************************
- * The following is for 8192E 2Ant BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8192E_2ANT				0
-
-#define	BT_INFO_8192E_2ANT_B_FTP						BIT(7)
-#define	BT_INFO_8192E_2ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8192E_2ANT_B_HID						BIT(5)
-#define	BT_INFO_8192E_2ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8192E_2ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8192E_2ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8192E_2ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8192E_2ANT_B_CONNECTION				BIT(0)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT		2
-#define	NOISY_AP_NUM_THRESH_8192E				10
-
-enum bt_info_src_8192e_2ant {
-	BT_INFO_SRC_8192E_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8192E_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8192E_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8192E_2ANT_MAX
-};
-
-enum bt_8192e_2ant_bt_status {
-	BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8192E_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8192E_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8192E_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8192E_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8192E_2ANT_BT_STATUS_MAX
-};
-
-enum bt_8192e_2ant_coex_algo {
-	BT_8192E_2ANT_COEX_ALGO_UNDEFINED		= 0x0,
-	BT_8192E_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8192E_2ANT_COEX_ALGO_SCO_PAN			= 0x2,
-	BT_8192E_2ANT_COEX_ALGO_HID				= 0x3,
-	BT_8192E_2ANT_COEX_ALGO_A2DP			= 0x4,
-	BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS		= 0x5,
-	BT_8192E_2ANT_COEX_ALGO_PANEDR			= 0x6,
-	BT_8192E_2ANT_COEX_ALGO_PANHS			= 0x7,
-	BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x8,
-	BT_8192E_2ANT_COEX_ALGO_PANEDR_HID		= 0x9,
-	BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0xa,
-	BT_8192E_2ANT_COEX_ALGO_HID_A2DP		= 0xb,
-	BT_8192E_2ANT_COEX_ALGO_MAX				= 0xc
-};
-
-struct coex_dm_8192e_2ant {
-	/* fw mechanism */
-	u8		pre_bt_dec_pwr_lvl;
-	u8		cur_bt_dec_pwr_lvl;
-	u8		pre_fw_dac_swing_lvl;
-	u8		cur_fw_dac_swing_lvl;
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		reset_tdma_adjust;
-	boolean		auto_tdma_adjust;
-	boolean		auto_tdma_adjust_low_rssi;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-
-	/* sw mechanism */
-	boolean		pre_rf_rx_lpf_shrink;
-	boolean		cur_rf_rx_lpf_shrink;
-	u32		bt_rf_0x1e_backup;
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	boolean		pre_dac_swing_on;
-	u32		pre_dac_swing_lvl;
-	boolean		cur_dac_swing_on;
-	u32		cur_dac_swing_lvl;
-	boolean		pre_adc_back_off;
-	boolean		cur_adc_back_off;
-	boolean	pre_agc_table_en;
-	boolean		cur_agc_table_en;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u8		pre_ss_type;
-	u8		cur_ss_type;
-
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		cur_ra_mask_type;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-};
-
-struct coex_sta_8192e_2ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-	boolean					force_lps_on;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	u8					bt_rssi;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8192E_2ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8192E_2ANT_MAX];
-	boolean					c2h_bt_inquiry_page;
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u8					scan_ap_num;
-	u32				bt_coex_supported_version;
-	u32					cnt_setup_link;
-	u32					cnt_wifi_high_pri;
-	boolean				is_setup_link;
-	boolean				wifi_is_high_pri_task;
-
-	u32				crc_ok_cck;
-	u32				crc_ok_11g;
-	u32				crc_ok_11n;
-	u32				crc_ok_11n_vht;
-
-	u32				crc_err_cck;
-	u32				crc_err_11g;
-	u32				crc_err_11n;
-	u32				crc_err_11n_vht;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8192e2ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8192e2ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e2ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8192e2ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8192e2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8192e2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8192e2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8192e2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8192e2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8192e2ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e2ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8192e2ant_display_coex_info(IN struct btc_coexist *btcoexist);
-
-#else	/*  #if (RTL8192E_SUPPORT == 1) */
-#define	ex_halbtc8192e2ant_power_on_setting(btcoexist)
-#define	ex_halbtc8192e2ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8192e2ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8192e2ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8192e2ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8192e2ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8192e2ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8192e2ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8192e2ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8192e2ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8192e2ant_halt_notify(btcoexist)
-#define	ex_halbtc8192e2ant_periodical(btcoexist)
-#define	ex_halbtc8192e2ant_display_coex_info(btcoexist)
-
-#endif
-
-#endif
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8703b1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8703b1ant.c
deleted file mode 100644
index 86621f8f7035..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8703b1ant.c
+++ /dev/null
@@ -1,4501 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8703B Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8703B_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	*trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8703b_1ant		glcoex_dm_8703b_1ant;
-static struct  coex_dm_8703b_1ant	*coex_dm = &glcoex_dm_8703b_1ant;
-static struct  coex_sta_8703b_1ant		glcoex_sta_8703b_1ant;
-static struct  coex_sta_8703b_1ant	*coex_sta = &glcoex_sta_8703b_1ant;
-static struct  psdscan_sta_8703b_1ant	gl_psd_scan_8703b_1ant;
-static struct  psdscan_sta_8703b_1ant *psd_scan = &gl_psd_scan_8703b_1ant;
-
-
-const char *const glbt_info_src_8703b_1ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-/* ************************************************************
- * BtCoex Version Format:
- * 1. date :			glcoex_ver_date_XXXXX_1ant
- * 2. WifiCoexVersion : glcoex_ver_XXXX_1ant
- * 3. BtCoexVersion :	glcoex_ver_btdesired_XXXXX_1ant
- * 4. others :			glcoex_ver_XXXXXX_XXXXX_1ant
- *
- * Variable should be indicated IC and Antenna numbers !!!
- * Please strictly follow this order and naming style !!!
- *
- * ************************************************************ */
-u32	glcoex_ver_date_8703b_1ant = 20170626;
-u32	glcoex_ver_8703b_1ant = 0x1a;
-u32	glcoex_ver_btdesired_8703b_1ant = 0x16;
-
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8703b1ant_
- * ************************************************************ */
-u8 halbtc8703b1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8703b1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-void halbtc8703b1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-void halbtc8703b1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = FALSE;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-void halbtc8703b1ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-void halbtc8703b1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8703b1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8703b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8703b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8703b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
-	}
-
-	halbtc8703b1ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8703b1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8703b1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-void halbtc8703b1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8703b1ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-void halbtc8703b1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0, cnt_slave = 0, cnt_overhead = 0,
-				cnt_autoslot_hang = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS */
-	/* if (! (btcoexist->btc_read_1byte(btcoexist, 0x76e) & 0x8) ) */
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-				reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-
-	BTC_TRACE(trace_buf);
-
-	if (BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			coex_dm->bt_status) {
-
-			if (coex_sta->high_priority_rx >= 15) {
-					if (cnt_overhead < 3)
-						cnt_overhead++;
-
-					if (cnt_overhead == 3)
-						coex_sta->is_hiPri_rx_overhead = TRUE;
-			} else {
-					if (cnt_overhead > 0)
-						cnt_overhead--;
-
-					if (cnt_overhead == 0)
-						coex_sta->is_hiPri_rx_overhead = FALSE;
-			}
-	} else
-		coex_sta->is_hiPri_rx_overhead = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	if ((coex_sta->low_priority_tx > 1150)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	if ((coex_sta->low_priority_rx >= 1150) &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx)
-	    && (!coex_sta->under_ips)  && (!coex_sta->c2h_bt_inquiry_page) &&
-	    (coex_sta->bt_link_exist))	{
-		if (cnt_slave >= 3) {
-			bt_link_info->slave_role = TRUE;
-			cnt_slave = 3;
-		} else
-			cnt_slave++;
-	} else {
-		if (cnt_slave == 0)	{
-			bt_link_info->slave_role = FALSE;
-			cnt_slave = 0;
-		} else
-			cnt_slave--;
-
-	}
-
-	if (coex_sta->is_tdma_btautoslot) {
-		if ((coex_sta->low_priority_tx >= 1300) &&
-			(coex_sta->low_priority_rx <= 150)) {
-			if (cnt_autoslot_hang >= 2) {
-				coex_sta->is_tdma_btautoslot_hang = TRUE;
-				cnt_autoslot_hang = 2;
-			} else
-				cnt_autoslot_hang++;
-		} else {
-			if (cnt_autoslot_hang == 0) {
-				coex_sta->is_tdma_btautoslot_hang = FALSE;
-				cnt_autoslot_hang = 0;
-			} else
-				cnt_autoslot_hang--;
-		}
-	}
-
-	if (bt_link_info->hid_only) {
-		if (coex_sta->low_priority_rx > 50)
-			coex_sta->is_hid_low_pri_tx_overhead = true;
-		else
-			coex_sta->is_hid_low_pri_tx_overhead = false;
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if ((coex_sta->high_priority_tx == 0) &&
-		    (coex_sta->high_priority_rx == 0) &&
-		    (coex_sta->low_priority_tx == 0) &&
-		    (coex_sta->low_priority_rx == 0)) {
-			num_of_bt_counter_chk++;
-			if (num_of_bt_counter_chk >= 3) {
-				halbtc8703b1ant_query_bt_info(btcoexist);
-				num_of_bt_counter_chk = 0;
-			}
-		}
-	}
-
-}
-
-
-void halbtc8703b1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-	s32 wifi_rssi = 0;
-	boolean wifi_busy = FALSE, wifi_under_b_mode = FALSE,
-			wifi_scan = FALSE, wifi_connected = FALSE;
-	boolean bt_idle = FALSE, wl_idle = FALSE, is_cck_deadlock = FALSE;
-	static u8 cck_lock_counter = 0, wl_noisy_count0 = 0,
-		  wl_noisy_count1 = 3, wl_noisy_count2 = 0;
-	u32 total_cnt, reg_val1, reg_val2, cnt_cck;
-	u32 cnt_crcok = 0, cnt_crcerr = 0;
-	static u8 cnt = 0, cnt_ccklocking = 0;
-	u8	h2c_parameter[1] = {0};
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/*send h2c to query WL FW dbg info	*/
-	if (((coex_dm->cur_ps_tdma_on) && (coex_sta->force_lps_ctrl)) ||
-		 ((coex_sta->acl_busy) && (bt_link_info->a2dp_exist))) {
-		h2c_parameter[0] = 0x8;
-		btcoexist->btc_fill_h2c(btcoexist, 0x69, 1, h2c_parameter);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-			   &wifi_under_b_mode);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_ERROR_VHT);
-
-	cnt_crcok =  coex_sta->crc_ok_cck + coex_sta->crc_ok_11g
-				+ coex_sta->crc_ok_11n
-				+ coex_sta->crc_ok_11n_vht;
-
-	cnt_crcerr =  coex_sta->crc_err_cck + coex_sta->crc_err_11g
-				+ coex_sta->crc_err_11n
-				+ coex_sta->crc_err_11n_vht;
-
-	/*	CCK lock identification	*/
-	if (coex_sta->cck_lock)
-		cnt_ccklocking++;
-	else if (cnt_ccklocking != 0)
-		cnt_ccklocking--;
-
-	if (cnt_ccklocking >= 3) {
-		cnt_ccklocking = 3;
-		coex_sta->cck_lock_ever = TRUE;
-	}
-
-	/* WiFi environment noisy identification */
-	cnt_cck = coex_sta->crc_ok_cck + coex_sta->crc_err_cck;
-
-	if ((!wifi_busy) && (!coex_sta->cck_lock)) {
-		if (cnt_cck > 250) {
-			if (wl_noisy_count2 < 3)
-				wl_noisy_count2++;
-
-			if (wl_noisy_count2 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count1 = 0;
-			}
-
-		} else if (cnt_cck < 50) {
-			if (wl_noisy_count0 < 3)
-				wl_noisy_count0++;
-
-			if (wl_noisy_count0 == 3) {
-				wl_noisy_count1 = 0;
-				wl_noisy_count2 = 0;
-			}
-
-		} else {
-			if (wl_noisy_count1 < 3)
-				wl_noisy_count1++;
-
-			if (wl_noisy_count1 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count2 = 0;
-			}
-	}
-
-		if (wl_noisy_count2 == 3)
-			coex_sta->wl_noisy_level = 2;
-		else if (wl_noisy_count1 == 3)
-			coex_sta->wl_noisy_level = 1;
-		else
-			coex_sta->wl_noisy_level = 0;
-	}
-
-}
-
-
-
-
-void halbtc8703b1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = FALSE;
-	boolean		bt_busy = FALSE;
-
-
-	coex_sta->num_of_profile = 0;
-
-	/* set link exist status */
-	if (!(coex_sta->bt_info & BT_INFO_8703B_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = FALSE;
-		coex_sta->pan_exist = FALSE;
-		coex_sta->a2dp_exist = FALSE;
-		coex_sta->hid_exist = FALSE;
-		coex_sta->sco_exist = FALSE;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = TRUE;
-		if (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_FTP) {
-			coex_sta->pan_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->pan_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_A2DP) {
-			coex_sta->a2dp_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->a2dp_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_HID) {
-			coex_sta->hid_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->hid_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_SCO_ESCO) {
-			coex_sta->sco_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->sco_exist = FALSE;
-
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-	bt_link_info->acl_busy = coex_sta->acl_busy;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = TRUE;
-		bt_link_info->bt_link_exist = TRUE;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = TRUE;
-	else
-		bt_link_info->sco_only = FALSE;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = TRUE;
-	else
-		bt_link_info->a2dp_only = FALSE;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = TRUE;
-	else
-		bt_link_info->pan_only = FALSE;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = TRUE;
-	else
-		bt_link_info->hid_only = FALSE;
-
-	if (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_INQ_PAGE) {
-		coex_dm->bt_status = BT_8703B_1ANT_BT_STATUS_INQ_PAGE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Inq/page!!!\n");
-	} else if (!(coex_sta->bt_info & BT_INFO_8703B_1ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-	} else if (coex_sta->bt_info == BT_INFO_8703B_1ANT_B_CONNECTION) {
-		/* connection exists but no busy */
-		coex_dm->bt_status = BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-	} else if (((coex_sta->bt_info & BT_INFO_8703B_1ANT_B_SCO_ESCO) ||
-		    (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_SCO_BUSY)) &&
-		   (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_ACL_BUSY)) {
-		coex_dm->bt_status = BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL SCO busy!!!\n");
-	} else if ((coex_sta->bt_info & BT_INFO_8703B_1ANT_B_SCO_ESCO) ||
-		   (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8703B_1ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-	} else if (coex_sta->bt_info & BT_INFO_8703B_1ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8703B_1ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-	} else {
-		coex_dm->bt_status = BT_8703B_1ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-	}
-
-	BTC_TRACE(trace_buf);
-
-	if ((BT_8703B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8703B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = TRUE;
-	else
-		bt_busy = FALSE;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-}
-
-
-void halbtc8703b1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		h2c_parameter[0] =
-			0x1;  /* enable BT AFH skip WL channel for 8703b because BT Rx LO interference */
-		/* h2c_parameter[0] = 0x0; */
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-
-}
-
-void halbtc8703b1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8703b1ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8703b1ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8703b1ant_set_fw_low_penalty_ra(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xf9;	/* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-}
-
-void halbtc8703b1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-
-	halbtc8703b1ant_set_fw_low_penalty_ra(btcoexist,
-					      coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8703b1ant_write_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16				bitpos,
-	IN	boolean		state
-)
-{
-
-	static u16 originalval = 0x8002;
-
-	if (state)
-		originalval = originalval | bitpos;
-	else
-		originalval = originalval & (~bitpos);
-
-
-	btcoexist->btc_write_2byte(btcoexist, 0xaa, originalval);
-#if 0
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "\n [BTCoex], ********** Write Scoreboard = %x**********\n",
-		    originalval);
-	BTC_TRACE(trace_buf);
-#endif
-
-}
-
-void halbtc8703b1ant_read_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN   u16				*score_board_val
-)
-{
-
-	*score_board_val = (btcoexist->btc_read_2byte(btcoexist,
-			    0xaa)) & 0x7fff;
-}
-
-void halbtc8703b1ant_post_state_to_bt(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16						type,
-	IN  boolean                 state
-)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8703b1ant_post_state_to_bt: type = %d, state =%d\n",
-		type, state);
-	BTC_TRACE(trace_buf);
-
-	halbtc8703b1ant_write_score_board(btcoexist, (u16) type, state);
-}
-
-boolean halbtc8703b1ant_is_wifibt_status_changed(IN struct btc_coexist
-		*btcoexist)
-{
-	static boolean	pre_wifi_busy = FALSE, pre_under_4way = FALSE,
-			pre_bt_hs_on = FALSE, pre_bt_off = FALSE,
-			pre_bt_slave = FALSE, pre_hid_low_pri_tx_overhead = FALSE,
-			pre_wifi_under_lps = FALSE, pre_bt_setup_link = FALSE,
-			pre_cck_lock = FALSE, pre_cck_lock_warn = FALSE;
-	static u8 pre_hid_busy_num = 0, pre_wl_noisy_level = 0;
-	boolean wifi_busy = FALSE, under_4way = FALSE, bt_hs_on = FALSE;
-	boolean wifi_connected = FALSE;
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (coex_sta->bt_disabled != pre_bt_off) {
-		pre_bt_off = coex_sta->bt_disabled;
-
-		if (coex_sta->bt_disabled)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT is disabled !!\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT is enabled !!\n");
-
-		BTC_TRACE(trace_buf);
-
-		coex_sta->bt_coex_supported_feature = 0;
-		coex_sta->bt_coex_supported_version = 0;
-		coex_sta->bt_ble_scan_type = 0;
-		coex_sta->bt_ble_scan_para[0] = 0;
-		coex_sta->bt_ble_scan_para[1] = 0;
-		coex_sta->bt_ble_scan_para[2] = 0;
-
-		return TRUE;
-	}
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-
-			if (wifi_busy)
-				halbtc8703b1ant_post_state_to_bt(btcoexist,
-						BT_8703B_1ANT_SCOREBOARD_UNDERTEST, TRUE);
-			else
-				halbtc8703b1ant_post_state_to_bt(btcoexist,
-						BT_8703B_1ANT_SCOREBOARD_UNDERTEST, FALSE);
-			return TRUE;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return TRUE;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return TRUE;
-		}
-		if (coex_sta->wl_noisy_level != pre_wl_noisy_level) {
-			pre_wl_noisy_level = coex_sta->wl_noisy_level;
-			return TRUE;
-		}
-		if (coex_sta->under_lps != pre_wifi_under_lps) {
-			pre_wifi_under_lps = coex_sta->under_lps;
-			if (coex_sta->under_lps == TRUE)
-				return TRUE;
-		}
-		if (coex_sta->cck_lock != pre_cck_lock) {
-			pre_cck_lock = coex_sta->cck_lock;
-			return TRUE;
-		}
-		if (coex_sta->cck_lock_warn != pre_cck_lock_warn) {
-			pre_cck_lock_warn = coex_sta->cck_lock_warn;
-			return TRUE;
-		}
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->hid_busy_num != pre_hid_busy_num) {
-			pre_hid_busy_num = coex_sta->hid_busy_num;
-			return TRUE;
-		}
-
-		if (bt_link_info->slave_role != pre_bt_slave) {
-			pre_bt_slave = bt_link_info->slave_role;
-			return TRUE;
-		}
-
-		if (pre_hid_low_pri_tx_overhead != coex_sta->is_hid_low_pri_tx_overhead) {
-			pre_hid_low_pri_tx_overhead = coex_sta->is_hid_low_pri_tx_overhead;
-			return TRUE;
-		}
-
-		if (pre_bt_setup_link != coex_sta->is_setupLink) {
-			pre_bt_setup_link = coex_sta->is_setupLink;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-
-void halbtc8703b1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = TRUE, bt_disabled = FALSE;
-	u16			u16tmp;
-
-	/* This function check if bt is disabled */
-#if 1
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = FALSE;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = FALSE;
-
-
-#else   /*  8703b BT can't show correct on/off status in scoreboard[1] 2015/11/26 */
-
-	halbtc8703b1ant_read_score_board(btcoexist,	&u16tmp);
-
-	bt_active = u16tmp & BIT(1);
-
-
-#endif
-
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = FALSE;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	} else {
-
-		bt_disable_cnt++;
-		if (bt_disable_cnt >= 10) {
-			bt_disabled = TRUE;
-			bt_disable_cnt = 10;
-		}
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	}
-
-	if (bt_disabled)
-		halbtc8703b1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-	else
-		halbtc8703b1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
-
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-
-	}
-}
-
-
-
-void halbtc8703b1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
-					IN boolean isenable)
-{
-
-#if (BT_8703B_1ANT_ENABLE_GNTBT_TO_GPIO14 == 1)
-	if (isenable) {
-		/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x1);
-
-		/* enable GNT_BT debug to GPIO */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e, 0x40, 0x0);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x1, 0x0);
-	} else {
-		/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x0);
-
-		/* Disable GNT_BT debug to GPIO, and enable chip_wakeup_host */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e, 0x40, 0x1);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x1, 0x1);
-	}
-#endif
-}
-
-u32 halbtc8703b1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
-		IN u16 reg_addr)
-{
-	u32 j = 0, delay_count = 0;
-
-	/* wait for ready bit before access 0x7c0/0x7c4	*/
-	while (1) {
-		if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-			delay_ms(50);
-			delay_count++;
-			if (delay_count >= 10) {
-				delay_count = 0;
-				break;
-			}
-		} else
-			break;
-	}
-
-	btcoexist->btc_write_4byte(btcoexist, 0x7c0, 0x800F0000 | reg_addr);
-
-	return btcoexist->btc_read_4byte(btcoexist,
-					 0x7c8);  /* get read data */
-
-}
-
-void halbtc8703b1ant_ltecoex_indirect_write_reg(IN struct btc_coexist
-		*btcoexist,
-		IN u16 reg_addr, IN u32 bit_mask, IN u32 reg_value)
-{
-	u32 val, i = 0, j = 0, bitpos = 0, delay_count = 0;
-
-	if (bit_mask == 0x0)
-		return;
-	if (bit_mask == 0xffffffff) {
-		/* wait for ready bit before access 0x7c0/0x7c4 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else
-				break;
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x7c4,
-					   reg_value); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x7c0,
-					   0xc00F0000 | reg_addr);
-	} else {
-		for (i = 0; i <= 31; i++) {
-			if (((bit_mask >> i) & 0x1) == 0x1) {
-				bitpos = i;
-				break;
-			}
-		}
-
-		/* read back register value before write */
-		val = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				reg_addr);
-		val = (val & (~bit_mask)) | (reg_value << bitpos);
-
-		/* wait for ready bit before access 0x7c0/0x7c4	*/
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else
-				break;
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x7c4,
-					   val); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x7c0,
-					   0xc00F0000 | reg_addr);
-
-	}
-
-}
-
-void halbtc8703b1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
-				    IN boolean enable)
-{
-	u8 val;
-
-	val = (enable) ? 1 : 0;
-	halbtc8703b1ant_ltecoex_indirect_write_reg(btcoexist, 0x38, 0x80,
-			val);  /* 0x38[7] */
-
-}
-
-void halbtc8703b1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_control)
-{
-	u8 val;
-
-	val = (wifi_control) ? 1 : 0;
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x4,
-					   val); /* 0x70[26] */
-
-}
-
-void halbtc8703b1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, val_orig = 0;
-
-	if (!sw_control)
-		val = 0x0;
-	else if (state & 0x1)
-		val = 0x3;
-	else
-		val = 0x1;
-
-	val_orig = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0x38);
-
-	switch (control_block) {
-	case BT_8703B_1ANT_GNT_BLOCK_RFC_BB:
-	default:
-		val = ((val << 14) | (val << 10)) | (val_orig & 0xffff33ff);
-		break;
-	case BT_8703B_1ANT_GNT_BLOCK_RFC:
-		val = (val << 14) | (val_orig & 0xffff3fff);
-		break;
-	case BT_8703B_1ANT_GNT_BLOCK_BB:
-		val = (val << 10) | (val_orig & 0xfffff3ff);
-		break;
-	}
-
-	halbtc8703b1ant_ltecoex_indirect_write_reg(btcoexist,
-			0x38, 0xffffffff, val);
-}
-
-
-void halbtc8703b1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, val_orig = 0;
-
-	if (!sw_control)
-		val = 0x0;
-	else if (state & 0x1)
-		val = 0x3;
-	else
-		val = 0x1;
-
-	val_orig = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0x38);
-
-	switch (control_block) {
-	case BT_8703B_1ANT_GNT_BLOCK_RFC_BB:
-	default:
-		val = ((val << 12) | (val << 8)) | (val_orig & 0xffffccff);
-		break;
-	case BT_8703B_1ANT_GNT_BLOCK_RFC:
-		val = (val << 12) | (val_orig & 0xffffcfff);
-		break;
-	case BT_8703B_1ANT_GNT_BLOCK_BB:
-		val = (val << 8) | (val_orig & 0xfffffcff);
-		break;
-	}
-
-	halbtc8703b1ant_ltecoex_indirect_write_reg(btcoexist,
-			0x38, 0xffffffff, val);
-}
-
-
-void halbtc8703b1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u16 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8703B_1ANT_CTT_WL_VS_LTE:
-		reg_addr = 0xa0;
-		break;
-	case BT_8703B_1ANT_CTT_BT_VS_LTE:
-		reg_addr = 0xa4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8703b1ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xffff, table_content); /* 0xa0[15:0] or 0xa4[15:0] */
-
-
-}
-
-
-void halbtc8703b1ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u8 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8703B_1ANT_LBTT_WL_BREAK_LTE:
-		reg_addr = 0xa8;
-		break;
-	case BT_8703B_1ANT_LBTT_BT_BREAK_LTE:
-		reg_addr = 0xac;
-		break;
-	case BT_8703B_1ANT_LBTT_LTE_BREAK_WL:
-		reg_addr = 0xb0;
-		break;
-	case BT_8703B_1ANT_LBTT_LTE_BREAK_BT:
-		reg_addr = 0xb4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8703b1ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xff, table_content); /* 0xa8[15:0] or 0xb4[15:0] */
-
-
-}
-
-void halbtc8703b1ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
-{
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
-
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
-	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
-			return;
-	}
-
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-
-void halbtc8703b1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8703b1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8703b1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8703b1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	u32	break_table;
-	u8	select_table;
-
-	coex_sta->coex_table_type = type;
-
-	if (coex_sta->concurrent_rx_mode_on == TRUE) {
-		break_table = 0xf0ffffff;  /* set WL hi-pri can break BT */
-		select_table =
-			0xb;		/* set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS) */
-	} else {
-		break_table = 0xffffff;
-		select_table = 0x3;
-	}
-
-	switch (type) {
-	case 0:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x55555555, break_table,
-					   select_table);
-		break;
-	case 1:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 2:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xaa5a5a5a, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 3:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x5a5a5a5a, break_table,
-					   select_table);
-		break;
-	case 4:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 5:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0x5a5a5a5a, 0x5a5a5a5a, break_table,
-					   select_table);
-		break;
-	case 6:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 7:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xaa555555, 0xaa555555, break_table,
-					   select_table);
-		break;
-	case 8:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaaaa5aaa, break_table,
-					   select_table);
-		break;
-	case 9:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0x5a5a5a5a, 0xaaaa5aaa, break_table,
-					   select_table);
-		break;
-	case 10:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xaaaaaaaa, 0xaaaaaaaa, break_table,
-					   select_table);
-		break;
-	case 11:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xa5a55555, 0xaaaa5a5a, break_table,
-					   select_table);
-		break;
-	case 12:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaaaa5a5a, break_table,
-					   select_table);
-		break;
-	case 13:
-		halbtc8703b1ant_coex_table(btcoexist, force_exec,
-					   0xaa5555aa, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8703b1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8703b1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8703b1ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8703b1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8703b1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8703b1ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8703b1ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x8, 0, 0, 0, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-void halbtc8703b1ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = FALSE;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		coex_sta->force_lps_ctrl = FALSE;
-		low_pwr_disable = FALSE;
-		/* btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable); */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_PRE_NORMAL_LPS,
-				   NULL);
-
-		break;
-	case BTC_PS_LPS_ON:
-		coex_sta->force_lps_ctrl = TRUE;
-		halbtc8703b1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, TRUE);
-		halbtc8703b1ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = TRUE;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-
-		break;
-	case BTC_PS_LPS_OFF:
-		coex_sta->force_lps_ctrl = TRUE;
-		halbtc8703b1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, FALSE);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-
-		break;
-	default:
-		break;
-	}
-}
-
-
-
-void halbtc8703b1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = FALSE;
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	u8		ps_type = BTC_PS_WIFI_NATIVE;
-
-	if (byte5 & BIT(2))
-		coex_sta->is_tdma_btautoslot = TRUE;
-	else
-		coex_sta->is_tdma_btautoslot = FALSE;
-
-	/* release bt-auto slot for auto-slot hang is detected!! */
-	if (coex_sta->is_tdma_btautoslot)
-		if ((coex_sta->is_tdma_btautoslot_hang) ||
-			(bt_link_info->slave_role))
-			byte5 = byte5 & 0xfb;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if ((ap_enable) && (byte1 & BIT(4) && !(byte1 & BIT(5)))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], FW for AP mode\n");
-		BTC_TRACE(trace_buf);
-		real_byte1 &= ~BIT(4);
-		real_byte1 |= BIT(5);
-
-		real_byte5 |= BIT(5);
-		real_byte5 &= ~BIT(6);
-
-		ps_type = BTC_PS_WIFI_NATIVE;
-		halbtc8703b1ant_power_save_state(btcoexist,
-					ps_type, 0x0,
-					0x0);
-	} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-
-		ps_type = BTC_PS_LPS_ON;
-		halbtc8703b1ant_power_save_state(
-			btcoexist, ps_type, 0x50,
-			0x4);
-	} else {
-		ps_type = BTC_PS_WIFI_NATIVE;
-		halbtc8703b1ant_power_save_state(btcoexist, ps_type,
-						 0x0,
-						 0x0);
-	}
-
-	h2c_parameter[0] = real_byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = real_byte5;
-
-	coex_dm->ps_tdma_para[0] = real_byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = real_byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-
-	if (ps_type == BTC_PS_WIFI_NATIVE)
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_POST_NORMAL_LPS, NULL);
-}
-
-
-void halbtc8703b1ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_busy = FALSE;
-	u8			rssi_adjust_val = 0;
-	static u8			psTdmaByte4Modify = 0x0, pre_psTdmaByte4Modify = 0x0;
-	static boolean	 pre_wifi_busy = FALSE;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (wifi_busy != pre_wifi_busy) {
-		force_exec = TRUE;
-		pre_wifi_busy = wifi_busy;
-	}
-
-	/* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-	if ((bt_link_info->slave_role) && (bt_link_info->a2dp_exist))
-		psTdmaByte4Modify = 0x1;
-	else
-		psTdmaByte4Modify = 0x0;
-
-	if (pre_psTdmaByte4Modify != psTdmaByte4Modify) {
-
-		force_exec = TRUE;
-		pre_psTdmaByte4Modify = psTdmaByte4Modify;
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-	if (turn_on)	{
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-	}
-
-
-	if (turn_on) {
-		switch (type) {
-		default:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x35, 0x03, 0x11, 0x11);
-			break;
-		case 3:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x30, 0x03, 0x10, 0x50);
-			break;
-		case 4:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x21, 0x03, 0x10, 0x50);
-			break;
-		case 5:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x3a, 0x03, 0x11, 0x11);
-			break;
-		case 6:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x20, 0x03, 0x11, 0x11);
-			break;
-		case 7:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x54 |
-							psTdmaByte4Modify);
-			break;
-		case 8:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x54 |
-							psTdmaByte4Modify);
-			break;
-		case 9:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x54 |
-							psTdmaByte4Modify);
-			break;
-		case 10:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x30, 0x03, 0x11, 0x10);
-			break;
-		case 11:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x25, 0x03, 0x11,  0x11 |
-							psTdmaByte4Modify);
-			break;
-		case 12:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x35, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
-			break;
-		case 13:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x25, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
-			break;
-		case 14:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x15, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
-			break;
-		case 15:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x20, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
-			break;
-		case 16:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11,  0x15 |
-							psTdmaByte4Modify);
-			break;
-		case 17:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11, 0x14);
-			break;
-		case 18:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x30, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
-			break;
-		case 19:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x15, 0x03, 0x11, 0x10);
-			break;
-		case 20:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x30, 0x03, 0x11, 0x10);
-			break;
-		case 21:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x30, 0x03, 0x11, 0x10);
-			break;
-		case 22:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x25, 0x03, 0x11, 0x10);
-			break;
-		case 27:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11, 0x15);
-			break;
-		case 28:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x0b, 0x10,  0x54);
-			break;
-		case 32:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x35, 0x03, 0x11, 0x11);
-			break;
-		case 33:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x35, 0x03, 0x11, 0x10);
-			break;
-		case 57:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
-			break;
-		case 58:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
-			break;
-		case 67:
-			halbtc8703b1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11,  0x10 |
-							psTdmaByte4Modify);
-			break;
-		}
-	} else {
-
-		/* disable PS tdma */
-		switch (type) {
-		case 8: /* PTA Control */
-			halbtc8703b1ant_set_fw_pstdma(btcoexist, 0x8,
-							0x0, 0x0, 0x0, 0x0);
-			break;
-		case 0:
-		default:  /* Software control, Antenna at BT side */
-			halbtc8703b1ant_set_fw_pstdma(btcoexist, 0x0,
-							0x0, 0x0, 0x0, 0x0);
-			break;
-		case 1: /* 2-Ant, 0x778=3, antenna control by antenna diversity */
-			halbtc8703b1ant_set_fw_pstdma(btcoexist, 0x0,
-							0x0, 0x0, 0x48, 0x0);
-			break;
-		}
-	}
-
-}
-
-void halbtc8703b1ant_set_ant_path(IN struct btc_coexist *btcoexist,
-				  IN u8 ant_pos_type, IN boolean force_exec,
-				  IN u8 phase)
-{
-	u32	cnt_bt_cal_chk = 0;
-	boolean	is_in_mp_mode = FALSE;
-	u8	u8tmp = 0;
-	u32	u32tmp1 = 0, u32tmp2 = 0;
-
-
-	u32tmp1 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0x38);
-
-	/* To avoid indirect access fail	*/
-	if (((u32tmp1 & 0xf000) >> 12) != ((u32tmp1 & 0x0f00) >> 8)) {
-		force_exec = TRUE;
-		coex_sta->gnt_error_cnt++;
-	}
-
-#if 1
-	u32tmp2 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x54);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (Before Ant Setup) 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n",
-		    u8tmp, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-	coex_dm->cur_ant_pos_type = ant_pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->cur_ant_pos_type == coex_dm->pre_ant_pos_type) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** Skip Antenna Path Setup because no change!!**********\n");
-			BTC_TRACE(trace_buf);
-			return;
-		}
-	}
-
-	coex_dm->pre_ant_pos_type = coex_dm->cur_ant_pos_type;
-
-	switch (phase) {
-	case BT_8703B_1ANT_PHASE_COEX_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
-		halbtc8703b1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8703b1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8703B_1ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8703b1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8703B_1ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-		/* Wait If BT IQK running, because Path control owner is at BT during BT IQK (setup by WiFi firmware) */
-		while (cnt_bt_cal_chk <= 20) {
-			u8tmp = btcoexist->btc_read_1byte(
-					btcoexist,
-					0x49d);
-			cnt_bt_cal_chk++;
-			if (u8tmp & BIT(0)) {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				delay_ms(50);
-			} else {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** BT is NOT calibrating (wait cnt=%d)**********\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				break;
-			}
-		}
-
-
-		/* set Path control owner to WL at initial step */
-		halbtc8703b1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8703B_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8703b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW low */
-		halbtc8703b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_LOW);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		coex_sta->run_time_state = FALSE;
-		break;
-	case BT_8703B_1ANT_PHASE_WLANONLY_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
-		halbtc8703b1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8703b1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8703B_1ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8703b1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8703B_1ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-		/* set Path control owner to WL at initial step */
-		halbtc8703b1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8703B_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW low */
-		halbtc8703b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_LOW);
-		/* Set GNT_WL to SW high */
-		halbtc8703b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_HIGH);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type =
-				BTC_ANT_PATH_WIFI;
-
-		coex_sta->run_time_state = FALSE;
-		break;
-	case BT_8703B_1ANT_PHASE_WLAN_OFF:
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8703b1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to BT */
-		halbtc8703b1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8703B_1ANT_PCO_BTSIDE);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		coex_sta->run_time_state = FALSE;
-		break;
-	case BT_8703B_1ANT_PHASE_2G_RUNTIME:
-		halbtc8703b1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8703B_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to PTA */
-		halbtc8703b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA,
-					   BT_8703B_1ANT_SIG_STA_SET_BY_HW);
-		/* Set GNT_WL to PTA */
-		halbtc8703b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA,
-					   BT_8703B_1ANT_SIG_STA_SET_BY_HW);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_PTA;
-
-		coex_sta->run_time_state = TRUE;
-		break;
-	case BT_8703B_1ANT_PHASE_BTMPMODE:
-		halbtc8703b1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8703B_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to high */
-		halbtc8703b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to low */
-		halbtc8703b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_LOW);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		coex_sta->run_time_state = FALSE;
-		break;
-	}
-
-
-#if 1
-	u32tmp1 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (After Ant-Setup) 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n",
-		    u8tmp, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-#endif
-}
-
-
-boolean halbtc8703b1ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = FALSE, wifi_connected = FALSE, wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected &&
-	    BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	    coex_dm->bt_status) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		common = TRUE;
-	} else if (wifi_connected &&
-		   (BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		common = TRUE;
-	} else if (!wifi_connected &&
-		   (BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		common = TRUE;
-	} else if (wifi_connected &&
-		   (BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		common = TRUE;
-	} else if (!wifi_connected &&
-		   (BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE !=
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non connected-idle + BT Busy!!\n");
-		BTC_TRACE(trace_buf);
-		common = TRUE;
-	} else {
-		if (wifi_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		common = FALSE;
-	}
-
-	return common;
-}
-
-
-/* *********************************************
- *
- *	Non-Software Coex Mechanism start
- *
- * ********************************************* */
-u8 halbtc8703b1ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean	bt_hs_on = FALSE;
-	u8	algorithm = BT_8703B_1ANT_COEX_ALGO_UNDEFINED;
-	u8	num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Profile = SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8703B_1ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8703B_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8703B_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8703B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8703b1ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)
-{
-	halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8703B_1ANT_PHASE_2G_RUNTIME);
-	halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-void halbtc8703b1ant_action_bt_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-}
-
-void halbtc8703b1ant_action_bt_relink(IN struct btc_coexist *btcoexist)
-{
-	if (coex_sta->is_bt_multi_link == TRUE)
-		return;
-
-	halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-	halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-}
-
-void halbtc8703b1ant_action_bt_idle(IN struct btc_coexist *btcoexist)
-{
-	boolean wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_busy) {
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
-	} else {/* if wl busy */
-
-	if (BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			coex_dm->bt_status) {
-
-		if (coex_sta->is_hiPri_rx_overhead)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		else
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-	} else {
-
-	   halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-	   halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-	  }
-	}
-}
-
-void halbtc8703b1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_connected = FALSE, ap_enable = FALSE, wifi_busy = FALSE,
-				bt_busy = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-	if ((wifi_link) || (wifi_roam)  || (coex_sta->wifi_is_high_pri_task)) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-	} else if (((wifi_scan) || (wifi_busy)) &&
-		   (coex_sta->bt_create_connection)) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-	} else if ((!wifi_connected) && (!wifi_scan)) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-	}  else if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist)) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
-	} else if ((bt_link_info->a2dp_exist) && (bt_link_info->pan_exist)) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-	} else if (bt_link_info->a2dp_exist) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-	} else if (wifi_scan) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 20);
-	} else if (wifi_busy) {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-	} else {
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-	}
-}
-
-void halbtc8703b1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = FALSE, wifi_busy = FALSE, wifi_cckdeadlock_ap = FALSE;
-	u32  wifi_bw = 1;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	if ((iot_peer == BTC_IOT_PEER_ATHEROS) && (coex_sta->cck_lock_ever))
-		wifi_cckdeadlock_ap = TRUE;
-
-	if (bt_link_info->sco_exist) {
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC,	TRUE, 5);
-	} else {
-		if ((wifi_cckdeadlock_ap) && (coex_sta->is_bt_multi_link)) {
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 18);
-		} else if (coex_sta->is_hid_low_pri_tx_overhead) {
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 18);
-		} else if (wifi_bw == 0) { /* if 11bg mode */
-
-			if (coex_sta->is_bt_multi_link) {
-				halbtc8703b1ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC, 11);
-				halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
-			} else {
-				halbtc8703b1ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC, 11);
-				halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
-			}
-		} else {
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
-		}
-	}
-}
-
-
-void halbtc8703b1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
-{
-	halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8703B_1ANT_PHASE_2G_RUNTIME);
-	halbtc8703b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 10);
-	halbtc8703b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-}
-
-void halbtc8703b1ant_action_wifi_native_lps(IN struct btc_coexist *btcoexist)
-{
-	halbtc8703b1ant_coex_table_with_type(btcoexist,
-					     NORMAL_EXEC, 5);
-	halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-void halbtc8703b1ant_action_wifi_cck_dead_lock(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	if ((bt_link_info->hid_exist) && (bt_link_info->a2dp_exist) &&
-		(!bt_link_info->pan_exist)) {
-
-		if ((coex_sta->cck_lock) || (coex_sta->cck_lock_warn)) {
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 28);
-		} else {
-
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-		}
-	}
-}
-
-void halbtc8703b1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8703B_1ANT_PHASE_2G_RUNTIME);
-
-	if ((BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		coex_dm->bt_status) ||
-		(BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		coex_dm->bt_status))
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	else if (!bt_link_info->pan_exist)
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	else
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-	halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-void halbtc8703b1ant_action_wifi_linkscan_process(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	if (bt_link_info->pan_exist)
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-	else if (bt_link_info->a2dp_exist)
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 27);
-	else
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-}
-
-void halbtc8703b1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
-		*btcoexist)
-{
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean wifi_busy = FALSE, wifi_turbo = FALSE, wifi_cckdeadlock_ap = FALSE;
-	u32  wifi_bw = 1;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &coex_sta->scan_ap_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy_level = %d\n",
-			coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-
-	if ((iot_peer == BTC_IOT_PEER_ATHEROS) && (coex_sta->cck_lock_ever))
-		wifi_cckdeadlock_ap = TRUE;
-
-	if ((bt_link_info->a2dp_exist) && (coex_sta->is_bt_a2dp_sink)) {
-
-		if (wifi_cckdeadlock_ap)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		else
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 12);
-	} else if (bt_link_info->a2dp_only) { /* A2DP		 */
-
-		if (wifi_cckdeadlock_ap)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		else if (wifi_turbo)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 7);
-	} else if (((bt_link_info->a2dp_exist) &&
-			(bt_link_info->pan_exist)) ||
-			(bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) { /* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
-
-		if (wifi_cckdeadlock_ap)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		else if (bt_link_info->hid_exist)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		else if (wifi_turbo)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 13);
-		else
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 14);
-	} else if (bt_link_info->hid_exist &&
-		   bt_link_info->a2dp_exist) { /* HID+A2DP */
-
-		if (wifi_cckdeadlock_ap) {
-#if 1
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-#endif
-
-#if 0
-			halbtc8703b1ant_action_wifi_cck_dead_lock(btcoexist);
-#endif
-		} else if (wifi_bw == 0) {/* if 11bg mode */
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 12);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-		} else {
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-		}
-
-	} else if ((bt_link_info->pan_only)
-		   || (bt_link_info->hid_exist && bt_link_info->pan_exist)) {
-			/* PAN(OPP,FTP), HID+PAN(OPP,FTP) */
-
-		if (wifi_cckdeadlock_ap)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		else if (bt_link_info->hid_exist)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		else if (wifi_turbo)
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (!wifi_busy)
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 4);
-		else
-			halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 3);
-	} else {
-		/* BT no-profile busy (0x9) */
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-	}
-
-}
-
-
-void halbtc8703b1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-	/* tdma and coex table */
-	halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8703b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-}
-
-void halbtc8703b1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean wifi_busy = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect()===>\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					NORMAL_EXEC,
-					BT_8703B_1ANT_PHASE_2G_RUNTIME);
-
-	if (BT_8703B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-
-		if (bt_link_info->hid_only)/* HID only */
-			halbtc8703b1ant_action_bt_sco_hid_only_busy(btcoexist);
-		else
-			halbtc8703b1ant_action_wifi_connected_bt_acl_busy(btcoexist);
-
-	} else if ((BT_8703B_1ANT_BT_STATUS_SCO_BUSY ==
-				coex_dm->bt_status) ||
-			   (BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-				coex_dm->bt_status)) {
-			halbtc8703b1ant_action_bt_sco_hid_only_busy(btcoexist);
-	} else
-		halbtc8703b1ant_action_bt_idle(btcoexist);
-}
-
-
-void halbtc8703b1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8	algorithm = 0;
-
-	algorithm = halbtc8703b1ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-
-	if (halbtc8703b1ant_is_common_action(btcoexist)) {
-
-	} else {
-		switch (coex_dm->cur_algorithm) {
-		case BT_8703B_1ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8703B_1ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-void halbtc8703b1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean wifi_connected = FALSE, bt_hs_on = FALSE;
-	boolean increase_scan_dev_num = FALSE;
-	boolean bt_ctrl_agg_buf_size = FALSE;
-	boolean miracast_plus_bt = FALSE, wifi_under_5g = FALSE;
-	u8	agg_buf_size = 5;
-	u32 wifi_link_status = 0;
-	u32 num_of_wifi_link = 0, wifi_bw;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-	boolean scan = FALSE, link = FALSE, roam = FALSE, under_4way = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], under_lps = %d, force_lps_ctrl = %d, acl_busy = %d!!!\n",
-			coex_sta->under_lps, coex_sta->force_lps_ctrl, coex_sta->acl_busy);
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-#if 1
-	if ((coex_sta->under_lps) && (!coex_sta->force_lps_ctrl) &&
-		(!coex_sta->acl_busy)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], RunCoexistMechanism(), wifi is under LPS !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8703b1ant_action_wifi_native_lps(btcoexist);
-		return;
-	}
-#endif
-
-	if (!coex_sta->run_time_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], return for run_time_state = FALSE !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->freeze_coexrun_by_btinfo) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), return for freeze_coexrun_by_btinfo\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8703b1ant_action_bt_whql_test(btcoexist);
-		return;
-	}
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT is disabled !!!\n");
-		halbtc8703b1ant_action_wifi_only(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8703b1ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	if ((coex_sta->is_setupLink) &&
-			(coex_sta->bt_relink_downcount != 0)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], BT is re-link !!!\n");
-		halbtc8703b1ant_action_bt_relink(btcoexist);
-		return;
-	}
-
-	if ((BT_8703B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-		(BT_8703B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		(BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		increase_scan_dev_num = TRUE;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_INC_SCAN_DEV_NUM,
-				&increase_scan_dev_num);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-				&wifi_link_status);
-
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-		(wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-				num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist)
-			miracast_plus_bt = TRUE;
-		else
-			miracast_plus_bt = FALSE;
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-#if 0
-		halbtc8703b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					FALSE, 0x5);
-#endif
-		halbtc8703b1ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	} else {
-
-	miracast_plus_bt = FALSE;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				&miracast_plus_bt);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-
-	if ((bt_link_info->bt_link_exist) && (wifi_connected)) {
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-		if (BTC_IOT_PEER_CISCO == iot_peer) {
-
-			if (BTC_WIFI_BW_HT40 == wifi_bw)
-					halbtc8703b1ant_limited_rx(btcoexist,
-						NORMAL_EXEC, FALSE, TRUE, 0x10);
-			else
-					halbtc8703b1ant_limited_rx(btcoexist,
-						NORMAL_EXEC, FALSE, TRUE, 0x8);
-		}
-	}
-
-	halbtc8703b1ant_run_sw_coexist_mechanism(
-			btcoexist);  /* just print debug message */
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (bt_hs_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is hs\n");
-		BTC_TRACE(trace_buf);
-		halbtc8703b1ant_action_bt_hs(btcoexist);
-		return;
-	}
-
-	if ((BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			coex_dm->bt_status) ||
-		(BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE ==
-			coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is idle\n");
-		BTC_TRACE(trace_buf);
-		halbtc8703b1ant_action_bt_idle(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			&under_4way);
-
-	if (scan || link || roam || under_4way) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], scan = %d, link = %d, roam = %d 4way = %d!!!\n",
-					scan, link, roam, under_4way);
-		BTC_TRACE(trace_buf);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], wifi is under linkscan process!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_action_wifi_linkscan_process(btcoexist);
-	} else if (wifi_connected) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], wifi is under connected!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_action_wifi_connected(btcoexist);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], wifi is under not-connected!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_action_wifi_not_connected(btcoexist);
-	 }
-}
-
-
-void halbtc8703b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-
-	halbtc8703b1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	coex_sta->pop_event_cnt = 0;
-	coex_sta->cnt_RemoteNameReq = 0;
-	coex_sta->cnt_ReInit = 0;
-	coex_sta->cnt_setupLink = 0;
-	coex_sta->cnt_IgnWlanAct = 0;
-	coex_sta->cnt_Page = 0;
-	coex_sta->cnt_RoleSwitch = 0;
-}
-
-void halbtc8703b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up, IN boolean wifi_only)
-{
-	u32				u32tmp0 = 0, u32tmp1 = 0, u32tmp2 = 0;
-	u8 i = 0;
-
-	u32tmp0 = btcoexist->btc_read_4byte(btcoexist, 0x70),
-	u32tmp1 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"\n [BTCoex], ********** 0x70/ 0x38/ 0x54 (Before Init HW config) = 0x%x/ 0x%x/ 0x%x**********\n",
-		    u32tmp0,
-		    u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	coex_sta->bt_coex_supported_feature = 0;
-	coex_sta->bt_coex_supported_version = 0;
-	coex_sta->bt_ble_scan_type = 0;
-	coex_sta->bt_ble_scan_para[0] = 0;
-	coex_sta->bt_ble_scan_para[1] = 0;
-	coex_sta->bt_ble_scan_para[2] = 0;
-	coex_sta->gnt_error_cnt = 0;
-	coex_sta->bt_relink_downcount = 0;
-	coex_sta->wl_rx_rate = BTC_UNKNOWN;
-
-	for (i = 0; i <= 9; i++)
-		coex_sta->bt_afh_map[i] = 0;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* BT report packet sample rate	 */
-	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
-
-	/* Enable BT counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* Enable PTA (3-wire function form BT side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
-
-	/* Enable PTA (tx/rx signal form WiFi side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
-
-	halbtc8703b1ant_enable_gnt_to_gpio(btcoexist, FALSE);
-
-#if 0
-	if (btcoexist->btc_read_1byte(btcoexist, 0x80) == 0xc6)
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-					 BT_8703B_1ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-
-	/* Antenna config */
-	if (coex_sta->is_rf_state_off) {
-
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_WLAN_OFF);
-
-		btcoexist->stop_coex_dm = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  halbtc8703b1ant_init_hw_config (RF Off)**********\n");
-		BTC_TRACE(trace_buf);
-	} else if (wifi_only) {
-		coex_sta->concurrent_rx_mode_on = FALSE;
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_WIFI,
-					     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_WLANONLY_INIT);
-	} else {
-		coex_sta->concurrent_rx_mode_on = TRUE;
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x2, 0x1);
-		/* RF 0x1[0] = 0->Set GNT_WL_RF_Rx always = 1 for con-current Rx */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x1, 0x0);
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_COEX_INIT);
-	}
-
-	/* PTA parameter */
-	halbtc8703b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-	halbtc8703b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-
-	u32tmp0 = btcoexist->btc_read_4byte(btcoexist, 0x70),
-	u32tmp1 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** 0x70/ 0x38/ 0x54 (After Init HW config) = 0x%x/ 0x%x/ 0x%x**********\n",
-		    u32tmp0,
-		    u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-}
-
-
-
-/* ************************************************************
- * work around function start with wa_halbtc8703b1ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8703b1ant_
- * ************************************************************ */
-void ex_halbtc8703b1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x0;
-	u16 u16tmp = 0x0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx Execute 8703b 1-Ant PowerOn Setting xxxxxxxxxxxxxxxx!!\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "Ant Det Finish = %s, Ant Det Number  = %d\n",
-		    (board_info->btdm_ant_det_finish ? "Yes" : "No"),
-		    board_info->btdm_ant_num_by_ant_det);
-	BTC_TRACE(trace_buf);
-
-	btcoexist->stop_coex_dm = TRUE;
-	coex_sta->is_rf_state_off = FALSE;
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write BB/MAC reg correctly. */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-	/* set Path control owner to WiFi */
-	halbtc8703b1ant_ltecoex_pathcontrol_owner(btcoexist,
-			BT_8703B_1ANT_PCO_WLSIDE);
-
-	/* set GNT_BT to high */
-	halbtc8703b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_HIGH);
-	/* Set GNT_WL to low */
-	halbtc8703b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8703B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8703B_1ANT_SIG_STA_SET_TO_LOW);
-
-	/* set WLAN_ACT = 0 */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	halbtc8703b1ant_enable_gnt_to_gpio(btcoexist, FALSE);
-
-	/* */
-	/* S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info) */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-
-	u8tmp = 0;
-	board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-
-	if (btcoexist->chip_interface == BTC_INTF_USB)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60, u8tmp);
-
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********  0x70(MAC)/0x38/0x54 (Power-On) =0x%x/  0x%x/ 0x%x**********\n",
-		    btcoexist->btc_read_4byte(btcoexist, 0x70),
-		    halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38),
-		    halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54));
-	BTC_TRACE(trace_buf);
-
-
-}
-
-void ex_halbtc8703b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8703b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8703b1ant_init_hw_config(btcoexist, TRUE, wifi_only);
-	btcoexist->stop_coex_dm = FALSE;
-}
-
-void ex_halbtc8703b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8703b1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8703b1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_stack_info		*stack_info = &btcoexist->stack_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0, cnt = 0;
-	u32				phyver = 0;
-	boolean			lte_coex_on = FALSE;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->bt_coex_supported_feature == 0)
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_FEATURE,
-						&coex_sta->bt_coex_supported_feature);
-
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			 (coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-		if (coex_sta->num_of_profile > 0) {
-			cnt++;
-
-			if (cnt >= 3) {
-				btcoexist->btc_get_bt_afh_map_from_bt(btcoexist, 0,
-					&coex_sta->bt_afh_map[0]);
-				cnt = 0;
-			}
-		}
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d",
-			   "Ant PG Num/ Mech/ Pos",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   board_info->btdm_ant_pos);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %d  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   board_info->btdm_ant_pos,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-		if (board_info->btdm_ant_det_finish) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-				   "Ant Det PSD Value",
-				   psd_scan->ant_det_peak_val);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-
-	/*bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;*/
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-
-	bt_coex_ver = ((coex_sta->bt_coex_supported_version & 0xff00) >> 8);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8703b_1ant, glcoex_ver_8703b_1ant,
-		   glcoex_ver_btdesired_8703b_1ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		   (bt_coex_ver >= glcoex_ver_btdesired_8703b_1ant ?
-		      "Match":"Mis-Match")));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s",
-		   "WifibHiPri/ Ccklock/ CckEverLock",
-		   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-		   (coex_sta->cck_lock ? "Yes" : "No"),
-		   (coex_sta->cck_lock_ever ? "Yes" : "No"));
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-			   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page")
-			   : ((BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-	if (coex_sta->num_of_profile != 0)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %s%s%s%s%s",
-			   "Profiles",
-			   ((bt_link_info->a2dp_exist) ?
-			   ((coex_sta->is_bt_a2dp_sink) ? "A2DP sink," :
-			    "A2DP,") : ""),
-			   ((bt_link_info->sco_exist) ?  "HFP," : ""),
-			   ((bt_link_info->hid_exist) ?
-			    ((coex_sta->hid_busy_num >= 2) ? "HID(4/18)," :
-			     "HID(2/18),") : ""),
-			   ((bt_link_info->pan_exist) ?  "PAN," : ""),
-			   ((coex_sta->voice_over_HOGP) ? "Voice" : ""));
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = None",
-			   "Profiles");
-
-	CL_PRINTF(cli_buf);
-
-	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			   "A2DP Rate/Bitpool/Auto_Slot",
-			   ((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
-			   coex_sta->a2dp_bit_pool,
-			   ((coex_sta->is_autoslot) ? "On" : "Off")
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	if (bt_link_info->hid_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "HID PairNum/Forbid_Slot",
-			   coex_sta->hid_pair_cnt,
-			   coex_sta->forbidden_slot
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
-				"Role/RoleSwCnt/IgnWlact/Feature",
-				((bt_link_info->slave_role) ? "Slave" : "Master"),
-				coex_sta->cnt_RoleSwitch,
-				((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
-				coex_sta->bt_coex_supported_feature);
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-		   "ReInit/ReLink/IgnWlact/Page/NameReq",
-		   coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-		   coex_sta->cnt_IgnWlanAct,
-		   coex_sta->cnt_Page,
-		   coex_sta->cnt_RemoteNameReq
-		  );
-	CL_PRINTF(cli_buf);
-
-	halbtc8703b1ant_read_score_board(btcoexist, &u16tmp[0]);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %04x",
-		   "ScoreBoard[14:0] (from BT)", u16tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	if (coex_sta->num_of_profile > 0) {
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %02x%02x%02x%02x %02x%02x%02x%02x %02x%02x",
-			"AFH MAP",
-			coex_sta->bt_afh_map[0],
-			coex_sta->bt_afh_map[1],
-			coex_sta->bt_afh_map[2],
-			coex_sta->bt_afh_map[3],
-			coex_sta->bt_afh_map[4],
-			coex_sta->bt_afh_map[5],
-			coex_sta->bt_afh_map[6],
-			coex_sta->bt_afh_map[7],
-			coex_sta->bt_afh_map[8],
-			coex_sta->bt_afh_map[9]
-			   );
-		CL_PRINTF(cli_buf);
-	}
-
-	for (i = 0; i < BT_INFO_SRC_8703B_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8703b_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[mechanisms] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[mechanisms]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "SM[LowPenaltyRA]",
-		   coex_dm->cur_low_penalty_ra);
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)",
-		   "PS TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "On" : "Off"),
-		   (coex_dm->auto_tdma_adjust ? "Adj" : "Fix"));
-
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "WL/BT Coex Table Type",
-		   coex_sta->coex_table_type);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x778/0x6cc/IgnWlanAct",
-		   u8tmp[0], u32tmp[0],  coex_dm->cur_ignore_wlan_act);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "BT_Empty/BT_Late",
-		   coex_sta->wl_fw_dbg_info[4],
-		   coex_sta->wl_fw_dbg_info[5]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ?  TRUE : FALSE;
-
-	if (lte_coex_on) {
-		u32tmp[0] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa0);
-		u32tmp[1] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa4);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-			   "LTE Coex Table W_L/B_L",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff);
-		CL_PRINTF(cli_buf);
-
-		u32tmp[0] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa8);
-		u32tmp[1] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xac);
-		u32tmp[2] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb0);
-		u32tmp[3] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb4);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			   "LTE Break Table W_L/B_L/L_W/L_B",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff,
-			   u32tmp[2] & 0xffff, u32tmp[3] & 0xffff);
-		CL_PRINTF(cli_buf);
-	}
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %s",
-		   "LTE CoexOn/Path Ctrl Owner",
-		   (int)((u32tmp[0] & BIT(7)) >> 7),
-		   ((u8tmp[0] & BIT(2)) ? "WL" : "BT"));
-	CL_PRINTF(cli_buf);
-
-	if (lte_coex_on) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-			   "LTE 3Wire/OPMode/UART/UARTMode",
-			   (int)((u32tmp[0] & BIT(6)) >> 6),
-			   (int)((u32tmp[0] & (BIT(5) | BIT(4))) >> 4),
-			   (int)((u32tmp[0] & BIT(3)) >> 3),
-			   (int)(u32tmp[0] & (BIT(2) | BIT(1) | BIT(0))));
-		CL_PRINTF(cli_buf);
-	}
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %s (BB:%s)/ %s (BB:%s)/ %s %d",
-			   "GNT_WL_Ctrl/GNT_BT_Ctrl/Dbg",
-			   ((u32tmp[0] & BIT(12)) ? "SW" : "HW"),
-			   ((u32tmp[0] & BIT(8)) ?	"SW" : "HW"),
-			   ((u32tmp[0] & BIT(14)) ? "SW" : "HW"),
-			   ((u32tmp[0] & BIT(10)) ?  "SW" : "HW"),
-			   ((u8tmp[0] & BIT(3)) ? "On" : "Off"),
-			   coex_sta->gnt_error_cnt);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8703b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "GNT_WL/GNT_BT/LTE_Busy/UART_Busy",
-		   (int)((u32tmp[0] & BIT(2)) >> 2),
-		   (int)((u32tmp[0] & BIT(3)) >> 3),
-		   (int)((u32tmp[0] & BIT(1)) >> 1), (int)(u32tmp[0] & BIT(0)));
-	CL_PRINTF(cli_buf);
-
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x4c6[4]/0x40[5] (WL/BT PTA)",
-		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x953);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ %s",
-		   "0x550(bcn ctrl)/0x522/4-RxAGC",
-		   u32tmp[0], u8tmp[0], (u8tmp[1] & 0x2) ? "On" : "Off");
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist, PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist, PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist, PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist, PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d (Rx_rate Data/RTS= %d/%d)",
-		   "CRC_OK CCK/11g/11n/11ac",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht,
-		   coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
-			   "WlHiPri/ Locking/ Locked/ Noisy",
-			   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-			   (coex_sta->cck_lock ? "Yes" : "No"),
-			   (coex_sta->cck_lock_ever ? "Yes" : "No"),
-			   coex_sta->wl_noisy_level);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-		   "0x770(Hi-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx,
-		   (coex_sta->is_hiPri_rx_overhead ? "(scan overhead!!)" : ""));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-		   "0x774(Lo-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx,
-		   (bt_link_info->slave_role ? "(Slave!!)" : (
-		   coex_sta->is_tdma_btautoslot_hang ? "(auto-slot hang!!)" : "")));
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8703b1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = TRUE;
-		coex_sta->under_lps = FALSE;
-
-		/* Write WL "Active" in Score-board for LPS off */
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				BT_8703B_1ANT_SCOREBOARD_ACTIVE |
-				BT_8703B_1ANT_SCOREBOARD_ONOFF |
-				BT_8703B_1ANT_SCOREBOARD_SCAN |
-				BT_8703B_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_WLAN_OFF);
-
-		halbtc8703b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8703b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-#if 0
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				 BT_8703B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-#endif
-		halbtc8703b1ant_init_hw_config(btcoexist, FALSE, FALSE);
-		halbtc8703b1ant_init_coex_dm(btcoexist);
-		halbtc8703b1ant_query_bt_info(btcoexist);
-
-		coex_sta->under_ips = FALSE;
-	}
-}
-
-void ex_halbtc8703b1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	static boolean  pre_force_lps_on = FALSE;
-
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = TRUE;
-		coex_sta->under_ips = FALSE;
-
-		if (coex_sta->force_lps_ctrl == TRUE) { /* LPS No-32K */
-			/* Write WL "Active" in Score-board for PS-TDMA */
-			pre_force_lps_on = TRUE;
-			halbtc8703b1ant_post_state_to_bt(btcoexist,
-				 BT_8703B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		} else { /* LPS-32K, need check if this h2c 0x71 can work?? (2015/08/28) */
-			/* Write WL "Non-Active" in Score-board for Native-PS */
-			pre_force_lps_on = FALSE;
-			halbtc8703b1ant_post_state_to_bt(btcoexist,
-				 BT_8703B_1ANT_SCOREBOARD_ACTIVE, FALSE);
-
-			halbtc8703b1ant_action_wifi_native_lps(btcoexist);
-		}
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = FALSE;
-
-		/* Write WL "Active" in Score-board for LPS off */
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				 BT_8703B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		if ((pre_force_lps_on == FALSE) && (!coex_sta->force_lps_ctrl))
-			halbtc8703b1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8703b1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean wifi_connected = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	halbtc8703b1ant_query_bt_info(btcoexist);
-
-	if (BTC_SCAN_START == type) {
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-					BT_8703B_1ANT_SCOREBOARD_ACTIVE |
-					BT_8703B_1ANT_SCOREBOARD_SCAN |
-					BT_8703B_1ANT_SCOREBOARD_ONOFF,
-					TRUE);
-
-		/* Force antenna setup for no scan result issue */
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_2G_RUNTIME);
-
-		halbtc8703b1ant_run_coexist_mechanism(btcoexist);
-
-	} else {
-
-		coex_sta->wifi_is_high_pri_task = FALSE;
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify  (Scan-AP = %d)\n",
-			    coex_sta->scan_ap_num);
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_run_coexist_mechanism(btcoexist);
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], SCAN START Notify() end\n");
-	BTC_TRACE(trace_buf);
-
-}
-
-void ex_halbtc8703b1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	boolean	wifi_connected = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	if (BTC_ASSOCIATE_START == type) {
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-					 BT_8703B_1ANT_SCOREBOARD_ACTIVE |
-					 BT_8703B_1ANT_SCOREBOARD_SCAN |
-					 BT_8703B_1ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-
-		/* Force antenna setup for no scan result issue */
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-						 FORCE_EXEC,
-						 BT_8703B_1ANT_PHASE_2G_RUNTIME);
-
-		/* psd_scan->ant_det_is_ant_det_available = TRUE; */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-
-		halbtc8703b1ant_run_coexist_mechanism(btcoexist);
-	} else {
-		coex_sta->wifi_is_high_pri_task = FALSE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_run_coexist_mechanism(btcoexist);
-	}
-
-}
-
-void ex_halbtc8703b1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean			wifi_under_b_mode = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_MEDIA_CONNECT == type) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-					 BT_8703B_1ANT_SCOREBOARD_ACTIVE |
-					 BT_8703B_1ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-
-		/* Force antenna setup for no scan result issue */
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_2G_RUNTIME);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-				   &wifi_under_b_mode);
-
-		/* Set CCK Tx/Rx high Pri except 11b mode */
-		if (wifi_under_b_mode) {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x00); /* CCK Rx */
-		} else {
-			/* btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x10); */ /*CCK Tx */
-			/* btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x10); */ /*CCK Rx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x10); /* CCK Rx */
-		}
-
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				 BT_8703B_1ANT_SCOREBOARD_ACTIVE, FALSE);
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-
-		coex_sta->cck_lock_ever = FALSE;
-	}
-
-	halbtc8703b1ant_update_wifi_channel_info(btcoexist, type);
-
-}
-
-void ex_halbtc8703b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean	under_4way = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (under_4way) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ---- under_4way!!\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	} else if (BTC_PACKET_ARP == type) {
-
-		coex_dm->arp_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ARP notify -cnt = %d\n",
-			    coex_dm->arp_cnt);
-		BTC_TRACE(trace_buf);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet DHCP or EAPOL notify [Type = %d]\n",
-			    type);
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	}
-
-	if (coex_sta->wifi_is_high_pri_task) {
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-					 BT_8703B_1ANT_SCOREBOARD_SCAN, TRUE);
-		halbtc8703b1ant_run_coexist_mechanism(btcoexist);
-	}
-}
-
-void ex_halbtc8703b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8				i, rsp_source = 0;
-	boolean				wifi_connected = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE,
-		    wifi_busy = FALSE;
-	static boolean is_scoreboard_scan = FALSE;
-
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8703B_1ANT_MAX)
-		rsp_source = BT_INFO_SRC_8703B_1ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt_info[%d], len=%d, data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	coex_sta->bt_info = coex_sta->bt_info_c2h[rsp_source][1];
-	coex_sta->bt_info_ext = coex_sta->bt_info_c2h[rsp_source][4];
-	coex_sta->bt_info_ext2 = coex_sta->bt_info_c2h[rsp_source][5];
-
-	if (BT_INFO_SRC_8703B_1ANT_WIFI_FW != rsp_source) {
-
-		/* if 0xff, it means BT is under WHCK test */
-		coex_sta->bt_whck_test = ((coex_sta->bt_info == 0xff) ? TRUE :
-					  FALSE);
-
-		coex_sta->bt_create_connection = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x80) ? TRUE :
-						  FALSE);
-
-		/* unit: %, value-100 to translate to unit: dBm */
-		coex_sta->bt_rssi = coex_sta->bt_info_c2h[rsp_source][3] * 2 +
-				    10;
-
-		coex_sta->c2h_bt_remote_name_req = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x20) ? TRUE :
-						    FALSE);
-
-		coex_sta->is_A2DP_3M = ((coex_sta->bt_info_c2h[rsp_source][2] &
-					 0x10) ? TRUE : FALSE);
-
-		coex_sta->acl_busy = ((coex_sta->bt_info_c2h[rsp_source][1] &
-				       0x8) ? TRUE : FALSE);
-
-		coex_sta->voice_over_HOGP = ((coex_sta->bt_info_ext & 0x10) ?
-					     TRUE : FALSE);
-
-		coex_sta->c2h_bt_inquiry_page = ((coex_sta->bt_info &
-			  BT_INFO_8703B_1ANT_B_INQ_PAGE) ? TRUE : FALSE);
-
-		coex_sta->a2dp_bit_pool = (((
-			coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) ?
-				   coex_sta->bt_info_c2h[rsp_source][6] : 0);
-
-		coex_sta->is_bt_a2dp_sink = (coex_sta->bt_info_c2h[rsp_source][6] & 0x80) ?
-									TRUE : FALSE;
-
-		coex_sta->bt_retry_cnt = coex_sta->bt_info_c2h[rsp_source][2] &
-					 0xf;
-
-		coex_sta->is_autoslot = coex_sta->bt_info_ext2 & 0x8;
-
-		coex_sta->forbidden_slot = coex_sta->bt_info_ext2 & 0x7;
-
-		coex_sta->hid_busy_num = (coex_sta->bt_info_ext2 & 0x30) >> 4;
-
-		coex_sta->hid_pair_cnt = (coex_sta->bt_info_ext2 & 0xc0) >> 6;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->c2h_bt_remote_name_req)
-			coex_sta->cnt_RemoteNameReq++;
-
-		if (coex_sta->bt_info_ext & BIT(1))
-			coex_sta->cnt_ReInit++;
-
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setupLink++;
-			coex_sta->is_setupLink = TRUE;
-			coex_sta->bt_relink_downcount = 2;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link start in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->is_setupLink = FALSE;
-			coex_sta->bt_relink_downcount = 0;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link stop in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(3))
-			coex_sta->cnt_IgnWlanAct++;
-
-		if (coex_sta->bt_info_ext & BIT(6))
-			coex_sta->cnt_RoleSwitch++;
-
-		if (coex_sta->bt_info_ext & BIT(7))
-			coex_sta->is_bt_multi_link = TRUE;
-		else
-			coex_sta->is_bt_multi_link = FALSE;
-
-		if (coex_sta->bt_create_connection) {
-			coex_sta->cnt_Page++;
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY,
-					   &wifi_busy);
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-			if ((wifi_link) || (wifi_roam) || (wifi_scan) ||
-			    (coex_sta->wifi_is_high_pri_task) || (wifi_busy)) {
-
-				is_scoreboard_scan = TRUE;
-				halbtc8703b1ant_post_state_to_bt(btcoexist,
-					 BT_8703B_1ANT_SCOREBOARD_SCAN, TRUE);
-
-			} else
-				halbtc8703b1ant_post_state_to_bt(btcoexist,
-					 BT_8703B_1ANT_SCOREBOARD_SCAN, FALSE);
-
-		} else {
-				if (is_scoreboard_scan) {
-					halbtc8703b1ant_post_state_to_bt(btcoexist,
-						 BT_8703B_1ANT_SCOREBOARD_SCAN, FALSE);
-					is_scoreboard_scan = FALSE;
-				}
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-
-		if ((!btcoexist->manual_control) &&
-		    (!btcoexist->stop_coex_dm)) {
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-
-			/*  Re-Init */
-			if ((coex_sta->bt_info_ext & BIT(1))) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-				BTC_TRACE(trace_buf);
-				if (wifi_connected)
-					halbtc8703b1ant_update_wifi_channel_info(
-						btcoexist, BTC_MEDIA_CONNECT);
-				else
-					halbtc8703b1ant_update_wifi_channel_info(
-						btcoexist,
-						BTC_MEDIA_DISCONNECT);
-			}
-
-
-			/*  If Ignore_WLanAct && not SetUp_Link */
-			if ((coex_sta->bt_info_ext & BIT(3)) &&
-			    (!(coex_sta->bt_info_ext & BIT(2)))) {
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8703b1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, FALSE);
-			}
-		}
-
-	}
-	if ((coex_sta->bt_info_ext & BIT(5))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit4 check, query BLE Scan type!!\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_ble_scan_type = btcoexist->btc_get_ble_scan_type_from_bt(btcoexist);
-
-		if ((coex_sta->bt_ble_scan_type & 0x1) == 0x1)
-			coex_sta->bt_ble_scan_para[0]  = btcoexist->btc_get_ble_scan_para_from_bt(btcoexist, 0x1);
-		if ((coex_sta->bt_ble_scan_type & 0x2) == 0x2)
-			coex_sta->bt_ble_scan_para[1]  = btcoexist->btc_get_ble_scan_para_from_bt(btcoexist, 0x2);
-		if ((coex_sta->bt_ble_scan_type & 0x4) == 0x4)
-			coex_sta->bt_ble_scan_para[2]  = btcoexist->btc_get_ble_scan_para_from_bt(btcoexist, 0x4);
-	}
-
-	halbtc8703b1ant_update_bt_link_info(btcoexist);
-
-	halbtc8703b1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8703b1ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8 i = 0;
-	static u8 tmp_buf_pre[10] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d (len = %d)\n",
-				tmp_buf[0], tmp_buf[1],
-				tmp_buf[2], tmp_buf[3],
-				tmp_buf[4], tmp_buf[5], length);
-	BTC_TRACE(trace_buf);
-
-	if (tmp_buf[0] == 0x8) {
-		for (i = 1; i <= 5; i++) {
-			coex_sta->wl_fw_dbg_info[i] =
-				(tmp_buf[i] >= tmp_buf_pre[i]) ?
-				(tmp_buf[i] - tmp_buf_pre[i]) :
-				(255 - tmp_buf_pre[i] + tmp_buf[i]);
-
-			tmp_buf_pre[i] = tmp_buf[i];
-		}
-	}
-}
-
-
-void ex_halbtc8703b1ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
-		IN BOOLEAN is_data_frame, IN u8 btc_rate_id)
-{
-	BOOLEAN wifi_connected = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	if (is_data_frame) {
-		coex_sta->wl_rx_rate = btc_rate_id;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], rx_rate_change_notify data rate id = %d, RTS_Rate = %d\n",
-			coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate);
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_sta->wl_rts_rx_rate = btc_rate_id;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], rts_rate_change_notify RTS rate id = %d, RTS_Rate = %d\n",
-			coex_sta->wl_rts_rx_rate, coex_sta->wl_rts_rx_rate);
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((wifi_connected) &&
-		((coex_dm->bt_status ==  BT_8703B_1ANT_BT_STATUS_ACL_BUSY) ||
-		(coex_dm->bt_status ==  BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		(coex_dm->bt_status == BT_8703B_1ANT_BT_STATUS_SCO_BUSY))) {
-
-		if ((coex_sta->wl_rx_rate == BTC_CCK_5_5) ||
-			(coex_sta->wl_rx_rate == BTC_OFDM_6) ||
-			(coex_sta->wl_rx_rate == BTC_MCS_0)) {
-
-			coex_sta->cck_lock_warn = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck lock warning...\n");
-			BTC_TRACE(trace_buf);
-		} else if ((coex_sta->wl_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rx_rate == BTC_CCK_2) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_2)) {
-
-			coex_sta->cck_lock = TRUE;
-			coex_sta->cck_lock_ever = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck locking...\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->cck_lock_warn = FALSE;
-			coex_sta->cck_lock = FALSE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck unlock...\n");
-			BTC_TRACE(trace_buf);
-		}
-	} else {
-		if ((coex_dm->bt_status ==
-			BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE) ||
-			(coex_dm->bt_status ==
-			BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE)) {
-			coex_sta->cck_lock_warn = FALSE;
-			coex_sta->cck_lock = FALSE;
-		}
-	}
-
-}
-
-
-
-void ex_halbtc8703b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->stop_coex_dm = FALSE;
-		coex_sta->is_rf_state_off = FALSE;
-#if 0
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				 BT_8703B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-					 BT_8703B_1ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-		/*	halbtc8703b1ant_init_hw_config(btcoexist, FALSE, FALSE); */
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				BT_8703B_1ANT_SCOREBOARD_ACTIVE |
-				BT_8703B_1ANT_SCOREBOARD_ONOFF |
-				BT_8703B_1ANT_SCOREBOARD_SCAN |
-				BT_8703B_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_WLAN_OFF);
-
-		halbtc8703b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-		btcoexist->stop_coex_dm = TRUE;
-		coex_sta->is_rf_state_off = TRUE;
-	}
-}
-
-void ex_halbtc8703b1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8703b1ant_post_state_to_bt(btcoexist,
-				BT_8703B_1ANT_SCOREBOARD_ACTIVE |
-				BT_8703B_1ANT_SCOREBOARD_ONOFF |
-				BT_8703B_1ANT_SCOREBOARD_SCAN |
-				BT_8703B_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-	halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8703B_1ANT_PHASE_WLAN_OFF);
-
-	ex_halbtc8703b1ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	halbtc8703b1ant_enable_gnt_to_gpio(btcoexist, FALSE);
-
-	halbtc8703b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-	btcoexist->stop_coex_dm = TRUE;
-}
-
-void ex_halbtc8703b1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	if ((BTC_WIFI_PNP_SLEEP == pnp_state) ||
-	    (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				BT_8703B_1ANT_SCOREBOARD_ACTIVE |
-				BT_8703B_1ANT_SCOREBOARD_ONOFF |
-				BT_8703B_1ANT_SCOREBOARD_SCAN |
-				BT_8703B_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		if (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state) {
-
-			halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-						     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_2G_RUNTIME);
-		} else {
-
-			halbtc8703b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-						     FORCE_EXEC,
-					     BT_8703B_1ANT_PHASE_WLAN_OFF);
-		}
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-#if 0
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-				 BT_8703B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8703b1ant_post_state_to_bt(btcoexist,
-							 BT_8703B_1ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-		btcoexist->stop_coex_dm = FALSE;
-	}
-}
-
-void ex_halbtc8703b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], *****************Coex DM Reset*****************\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8703b1ant_init_hw_config(btcoexist, FALSE, FALSE);
-	halbtc8703b1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8703b1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	u32	bt_patch_ver;
-	boolean wifi_busy = FALSE;
-	boolean bt_relink_finish = FALSE;
-
-#if (BT_AUTO_REPORT_ONLY_8703B_1ANT == 0)
-	halbtc8703b1ant_query_bt_info(btcoexist);
-#endif
-
-	halbtc8703b1ant_monitor_bt_ctr(btcoexist);
-	halbtc8703b1ant_monitor_wifi_ctr(btcoexist);
-
-	halbtc8703b1ant_monitor_bt_enable_disable(btcoexist);
-
-#if 0
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-		/* halbtc8703b1ant_read_score_board(btcoexist, &bt_scoreboard_val); */
-
-		if (wifi_busy) {
-			halbtc8703b1ant_post_state_to_bt(btcoexist,
-					BT_8703B_1ANT_SCOREBOARD_UNDERTEST, TRUE);
-			/*
-			halbtc8703b1ant_post_state_to_bt(btcoexist,
-						 BT_8703B_1ANT_SCOREBOARD_WLBUSY, TRUE);
-
-			if (bt_scoreboard_val & BIT(6))
-				halbtc8703b1ant_query_bt_info(btcoexist); */
-		} else {
-			halbtc8703b1ant_post_state_to_bt(btcoexist,
-						BT_8703B_1ANT_SCOREBOARD_UNDERTEST, FALSE);
-			/*
-			halbtc8703b1ant_post_state_to_bt(btcoexist,
-						BT_8703B_1ANT_SCOREBOARD_WLBUSY,
-						FALSE);  */
-		}
-#endif
-
-	if (coex_sta->bt_relink_downcount != 0) {
-		coex_sta->bt_relink_downcount--;
-
-		if (coex_sta->bt_relink_downcount == 0) {
-			coex_sta->is_setupLink = FALSE;
-			bt_relink_finish = TRUE;
-		}
-	}
-
-	/* for 4-way, DHCP, EAPOL packet */
-	if (coex_sta->specific_pkt_period_cnt > 0) {
-
-		coex_sta->specific_pkt_period_cnt--;
-
-		if ((coex_sta->specific_pkt_period_cnt == 0) &&
-		    (coex_sta->wifi_is_high_pri_task))
-			coex_sta->wifi_is_high_pri_task = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ***************** Hi-Pri Task = %s*****************\n",
-			    (coex_sta->wifi_is_high_pri_task ? "Yes" :
-			     "No"));
-		BTC_TRACE(trace_buf);
-
-	}
-
-	if (halbtc8703b1ant_is_wifibt_status_changed(btcoexist) || (bt_relink_finish))
-		halbtc8703b1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8703b1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-	/* No Antenna Detection required because 8730b is only 1-Ant */
-}
-
-void ex_halbtc8703b1ant_antenna_isolation(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-
-}
-
-void ex_halbtc8703b1ant_psd_scan(IN struct btc_coexist *btcoexist,
-		 IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-
-}
-
-void ex_halbtc8703b1ant_display_ant_detection(IN struct btc_coexist *btcoexist)
-{
-
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8703b1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8703b1ant.h
deleted file mode 100644
index 073e036212df..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8703b1ant.h
+++ /dev/null
@@ -1,435 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8703B_SUPPORT == 1)
-/* *******************************************
- * The following is for 8703B 1ANT BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8703B_1ANT				1
-#define BT_8703B_1ANT_ENABLE_GNTBT_TO_GPIO14		0
-
-#define	BT_INFO_8703B_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8703B_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8703B_1ANT_B_HID						BIT(5)
-#define	BT_INFO_8703B_1ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8703B_1ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8703B_1ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8703B_1ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8703B_1ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8703B_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-	(((_BT_INFO_EXT_&BIT(0))) ? TRUE : FALSE)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT		2
-
-#define  BT_8703B_1ANT_WIFI_NOISY_THRESH							50   /* max: 255 */
-
-/* for Antenna detection */
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_BACKGROUND					50
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			55
-#define	BT_8703B_1ANT_ANTDET_PSDTHRES_1ANT							35
-#define	BT_8703B_1ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8703B_1ANT_ANTDET_SWEEPPOINT_DELAY							40000
-#define	BT_8703B_1ANT_ANTDET_ENABLE									0
-#define	BT_8703B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE				0
-
-#define	BT_8703B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
-
-enum bt_8703b_1ant_signal_state {
-	BT_8703B_1ANT_SIG_STA_SET_TO_LOW		= 0x0,
-	BT_8703B_1ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8703B_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,
-	BT_8703B_1ANT_SIG_STA_MAX
-};
-
-enum bt_8703b_1ant_path_ctrl_owner {
-	BT_8703B_1ANT_PCO_BTSIDE		= 0x0,
-	BT_8703B_1ANT_PCO_WLSIDE	= 0x1,
-	BT_8703B_1ANT_PCO_MAX
-};
-
-enum bt_8703b_1ant_gnt_ctrl_type {
-	BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,
-	BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,
-	BT_8703B_1ANT_GNT_TYPE_MAX
-};
-
-enum bt_8703b_1ant_gnt_ctrl_block {
-	BT_8703B_1ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8703B_1ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8703B_1ANT_GNT_BLOCK_BB			= 0x2,
-	BT_8703B_1ANT_GNT_BLOCK_MAX
-};
-
-enum bt_8703b_1ant_lte_coex_table_type {
-	BT_8703B_1ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8703B_1ANT_CTT_BT_VS_LTE			= 0x1,
-	BT_8703B_1ANT_CTT_MAX
-};
-
-enum bt_8703b_1ant_lte_break_table_type {
-	BT_8703B_1ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8703B_1ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8703B_1ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8703B_1ANT_LBTT_LTE_BREAK_BT				= 0x3,
-	BT_8703B_1ANT_LBTT_MAX
-};
-
-enum bt_info_src_8703b_1ant {
-	BT_INFO_SRC_8703B_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8703B_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8703B_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8703B_1ANT_MAX
-};
-
-enum bt_8703b_1ant_bt_status {
-	BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8703B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8703B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8703B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8703B_1ANT_BT_STATUS_MAX
-};
-
-enum bt_8703b_1ant_wifi_status {
-	BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8703B_1ANT_WIFI_STATUS_MAX
-};
-
-enum bt_8703b_1ant_coex_algo {
-	BT_8703B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8703B_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8703B_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8703B_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8703B_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8703B_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8703B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8703B_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8703B_1ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-enum bt_8703b_1ant_phase {
-	BT_8703B_1ANT_PHASE_COEX_INIT								= 0x0,
-	BT_8703B_1ANT_PHASE_WLANONLY_INIT							= 0x1,
-	BT_8703B_1ANT_PHASE_WLAN_OFF								= 0x2,
-	BT_8703B_1ANT_PHASE_2G_RUNTIME								= 0x3,
-	BT_8703B_1ANT_PHASE_5G_RUNTIME								= 0x4,
-	BT_8703B_1ANT_PHASE_BTMPMODE								= 0x5,
-	BT_8703B_1ANT_PHASE_ANTENNA_DET								= 0x6,
-	BT_8703B_1ANT_PHASE_MAX
-};
-
-enum bt_8703b_1ant_Scoreboard {
-	BT_8703B_1ANT_SCOREBOARD_ACTIVE								= BIT(0),
-	BT_8703B_1ANT_SCOREBOARD_ONOFF								= BIT(1),
-	BT_8703B_1ANT_SCOREBOARD_SCAN								= BIT(2),
-	BT_8703B_1ANT_SCOREBOARD_UNDERTEST							= BIT(3),
-	BT_8703B_1ANT_SCOREBOARD_WLBUSY								= BIT(6)
-};
-
-
-struct coex_dm_8703b_1ant {
-	/* hw setting */
-	u8		pre_ant_pos_type;
-	u8		cur_ant_pos_type;
-	/* fw mechanism */
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	/* sw mechanism */
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-	u32		arp_cnt;
-
-	u8		error_condition;
-};
-
-struct coex_sta_8703b_1ant {
-	boolean				bt_disabled;
-	boolean				bt_link_exist;
-	boolean				sco_exist;
-	boolean				a2dp_exist;
-	boolean				hid_exist;
-	boolean				pan_exist;
-	boolean				bt_hi_pri_link_exist;
-	u8					num_of_profile;
-
-	boolean				under_lps;
-	boolean				under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	boolean             is_hiPri_rx_overhead;
-	s8					bt_rssi;
-	boolean				bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	u8					bt_info_c2h[BT_INFO_SRC_8703B_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8703B_1ANT_MAX];
-	boolean			    bt_whck_test;
-	boolean				c2h_bt_inquiry_page;
-	boolean				c2h_bt_remote_name_req;
-	boolean				c2h_bt_page;				/* Add for win8.1 page out issue */
-	boolean				wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u8					bt_info_ext2;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	boolean				cck_lock;
-	boolean				cck_lock_ever;
-	boolean				cck_lock_warn;
-
-	u8					coex_table_type;
-	boolean				force_lps_ctrl;
-
-	boolean				concurrent_rx_mode_on;
-
-	u16					score_board;
-	u8					isolation_btween_wb;   /* 0~ 50 */
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-	boolean				acl_busy;
-	boolean				bt_create_connection;
-
-	u32					bt_coex_supported_feature;
-	u32					bt_coex_supported_version;
-
-	u8					bt_ble_scan_type;
-	u32					bt_ble_scan_para[3];
-
-	boolean				run_time_state;
-	boolean				freeze_coexrun_by_btinfo;
-
-	boolean				is_A2DP_3M;
-	boolean				voice_over_HOGP;
-	u8                  bt_info;
-	boolean				is_autoslot;
-	u8					forbidden_slot;
-	u8					hid_busy_num;
-	u8					hid_pair_cnt;
-
-	u32					cnt_RemoteNameReq;
-	u32					cnt_setupLink;
-	u32					cnt_ReInit;
-	u32					cnt_IgnWlanAct;
-	u32					cnt_Page;
-	u32					cnt_RoleSwitch;
-
-	u16					bt_reg_vendor_ac;
-	u16					bt_reg_vendor_ae;
-
-	boolean				is_setupLink;
-	u8					wl_noisy_level;
-	u32                 gnt_error_cnt;
-
-	u8					bt_afh_map[10];
-	u8					bt_relink_downcount;
-	boolean				is_tdma_btautoslot;
-	boolean				is_tdma_btautoslot_hang;
-
-	boolean				is_rf_state_off;
-
-	boolean				is_hid_low_pri_tx_overhead;
-	boolean				is_bt_multi_link;
-	boolean				is_bt_a2dp_sink;
-
-	u8					wl_fw_dbg_info[10];
-	u8					wl_rx_rate;
-	u8					wl_rts_rx_rate;
-};
-
-#define  BT_8703B_1ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
-#define  BT_8703B_1ANT_ANTDET_PSD_AVGNUM			1	/* MAX:3 */
-#define	BT_8703B_1ANT_ANTDET_BUF_LEN				16
-
-struct psdscan_sta_8703b_1ant {
-
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8703B_1ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8703B_1ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_psd_running;
-	boolean			is_psd_show_max_only;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8703b1ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8703b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8703b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8703b1ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8703b1ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8703b1ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8703b1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8703b1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8703b1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8703b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8703b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8703b1ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8703b1ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
-		IN BOOLEAN is_data_frame, IN u8 btc_rate_id);
-void ex_halbtc8703b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8703b1ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8703b1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8703b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist);
-void ex_halbtc8703b1ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8703b1ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8703b1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8703b1ant_antenna_isolation(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-
-void ex_halbtc8703b1ant_psd_scan(IN struct btc_coexist *btcoexist,
-		 IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8703b1ant_display_ant_detection(IN struct btc_coexist *btcoexist);
-
-#else
-#define	ex_halbtc8703b1ant_power_on_setting(btcoexist)
-#define	ex_halbtc8703b1ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8703b1ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8703b1ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8703b1ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8703b1ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8703b1ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8703b1ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8703b1ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8703b1ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8703b1ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define ex_halbtc8703b1ant_wl_fwdbginfo_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8703b1ant_rx_rate_change_notify(btcoexist, is_data_frame, btc_rate_id)
-#define	ex_halbtc8703b1ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8703b1ant_halt_notify(btcoexist)
-#define	ex_halbtc8703b1ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8703b1ant_coex_dm_reset(btcoexist)
-#define	ex_halbtc8703b1ant_periodical(btcoexist)
-#define	ex_halbtc8703b1ant_display_coex_info(btcoexist)
-#define	ex_halbtc8703b1ant_antenna_detection(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8703b1ant_antenna_isolation(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8703b1ant_psd_scan(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8703b1ant_display_ant_detection(btcoexist)
-
-#endif
-
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b1ant.c
deleted file mode 100644
index 9c20add58366..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b1ant.c
+++ /dev/null
@@ -1,5238 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8723B Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8723B_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8723b_1ant		glcoex_dm_8723b_1ant;
-static struct  coex_dm_8723b_1ant	*coex_dm = &glcoex_dm_8723b_1ant;
-static struct  coex_sta_8723b_1ant		glcoex_sta_8723b_1ant;
-static struct  coex_sta_8723b_1ant	*coex_sta = &glcoex_sta_8723b_1ant;
-static struct  psdscan_sta_8723b_1ant	gl_psd_scan_8723b_1ant;
-static struct  psdscan_sta_8723b_1ant *psd_scan = &gl_psd_scan_8723b_1ant;
-
-
-const char *const glbt_info_src_8723b_1ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8723b_1ant = 20170517;
-u32	glcoex_ver_8723b_1ant = 0x6a;
-u32	glcoex_ver_btdesired_8723b_1ant = 0x6a;
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8723b1ant_
- * ************************************************************ */
-
-void halbtc8723b1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-void halbtc8723b1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = false;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-void halbtc8723b1ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-void halbtc8723b1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8723b1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8723b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8723b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8723b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
-	}
-
-	halbtc8723b1ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8723b1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8723b1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-void halbtc8723b1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8723b1ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	coex_sta->c2h_bt_info_req_sent = true;
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-void halbtc8723b1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u32		num_of_bt_counter_chk = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS */
-	/* if (! (btcoexist->btc_read_1byte(btcoexist, 0x76e) & 0x8) ) */
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	if ((coex_sta->high_priority_tx  + coex_sta->high_priority_rx < 50) &&
-	    (bt_link_info->hid_exist == true))
-		bt_link_info->hid_exist  = false;
-
-	if ((coex_sta->low_priority_tx > 1050)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	if ((coex_sta->low_priority_rx >= 950)  && (!coex_sta->under_ips)
-	    && (coex_sta->low_priority_rx >=
-		coex_sta->low_priority_tx)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		bt_link_info->slave_role = true;
-	else
-		bt_link_info->slave_role = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	/* This part is for wifi FW and driver to update BT's status as disabled. */
-	/* The flow is as the following */
-	/* 1. disable BT */
-	/* 2. if all BT Tx/Rx counter=0, after 6 sec we query bt info */
-	/* 3. Because BT will not rsp from mailbox, so wifi fw will know BT is disabled */
-	/* 4. FW will rsp c2h for BT that driver will know BT is disabled. */
-	if ((reg_hp_tx == 0) && (reg_hp_rx == 0) && (reg_lp_tx == 0) &&
-	    (reg_lp_rx == 0)) {
-		num_of_bt_counter_chk++;
-		if (num_of_bt_counter_chk >= 3) {
-			halbtc8723b1ant_query_bt_info(btcoexist);
-			num_of_bt_counter_chk = 0;
-		}
-	}
-
-}
-
-
-void halbtc8723b1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-	s32	wifi_rssi = 0;
-	boolean wifi_busy = false, wifi_under_b_mode = false;
-	static u8 cck_lock_counter = 0;
-	u32	total_cnt;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-			   &wifi_under_b_mode);
-
-#if 1
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-					 btcoexist,
-					 PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_VHT);
-
-#endif
-
-	if ((wifi_busy) && (wifi_rssi >= 30) && (!wifi_under_b_mode)) {
-		total_cnt = coex_sta->crc_ok_cck + coex_sta->crc_ok_11g +
-			    coex_sta->crc_ok_11n +
-			    coex_sta->crc_ok_11n_vht;
-
-		if ((coex_dm->bt_status == BT_8723B_1ANT_BT_STATUS_ACL_BUSY) ||
-		    (coex_dm->bt_status ==
-		     BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		    (coex_dm->bt_status ==
-		     BT_8723B_1ANT_BT_STATUS_SCO_BUSY)) {
-			if (coex_sta->crc_ok_cck > (total_cnt -
-						    coex_sta->crc_ok_cck))			{
-				if (cck_lock_counter < 3)
-					cck_lock_counter++;
-			} else {
-				if (cck_lock_counter > 0)
-					cck_lock_counter--;
-			}
-
-		} else {
-			if (cck_lock_counter > 0)
-				cck_lock_counter--;
-		}
-	} else {
-		if (cck_lock_counter > 0)
-			cck_lock_counter--;
-	}
-
-	if (!coex_sta->pre_ccklock) {
-
-		if (cck_lock_counter >= 3)
-			coex_sta->cck_lock = true;
-		else
-			coex_sta->cck_lock = false;
-	} else {
-		if (cck_lock_counter == 0)
-			coex_sta->cck_lock = false;
-		else
-			coex_sta->cck_lock = true;
-	}
-
-	if (coex_sta->cck_lock)
-		coex_sta->cck_ever_lock = true;
-
-	coex_sta->pre_ccklock =  coex_sta->cck_lock;
-
-
-}
-
-boolean halbtc8723b1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	boolean wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-
-
-	}
-
-	return false;
-}
-
-void halbtc8723b1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = true, bt_disabled = false, bt_change = false;
-
-	/* This function check if bt is disabled */
-
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = false;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = false;
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = false;
-	} else {
-		bt_disable_cnt++;
-		if (bt_disable_cnt >= 10)
-			bt_disabled = true;
-	}
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		bt_change = true;
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_BL_BT_ENABLE_DISABLE_CHANGE,
-				   &bt_change);
-
-		coex_sta->bt_disabled = bt_disabled;
-	} else {
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_BL_BT_ENABLE_DISABLE_CHANGE,
-				   &bt_change);
-	}
-}
-
-void halbtc8723b1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-	bt_link_info->bt_hi_pri_link_exist = coex_sta->bt_hi_pri_link_exist;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-void halbtc8723b1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8723b1ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8723b1ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8723b1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xf9;	/* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-}
-
-void halbtc8723b1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8723b1ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8723b1ant_sw_mechanism(IN struct btc_coexist *btcoexist,
-				  IN boolean low_penalty_ra)
-{
-	halbtc8723b1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra);
-}
-
-void halbtc8723b1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-
-
-void halbtc8723b1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8723b1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8723b1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE
-	if (board_info->btdm_ant_num_by_ant_det == 2) {
-		if (type == 3)
-			type = 14;
-		else if (type == 4)
-			type  = 13;
-		else if (type == 5)
-			type = 8;
-	}
-#endif
-#endif
-
-	coex_sta->coex_table_type = type;
-
-	switch (type) {
-	case 0:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x55555555, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 4:
-		if ((coex_sta->cck_ever_lock)  &&
-		    (coex_sta->scan_ap_num <= 5))
-			halbtc8723b1ant_coex_table(btcoexist,
-					   force_exec, 0x55555555, 0xaaaa5a5a,
-						   0xffffff, 0x3);
-		else
-			halbtc8723b1ant_coex_table(btcoexist,
-					   force_exec, 0x55555555, 0x5a5a5a5a,
-						   0xffffff, 0x3);
-		break;
-	case 5:
-		if ((coex_sta->cck_ever_lock)  &&
-		    (coex_sta->scan_ap_num <= 5))
-			halbtc8723b1ant_coex_table(btcoexist,
-					   force_exec, 0x5a5a5a5a, 0x5aaa5a5a,
-						   0xffffff, 0x3);
-		else
-			halbtc8723b1ant_coex_table(btcoexist,
-					   force_exec, 0x5a5a5a5a, 0x5aaa5a5a,
-						   0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 7:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 8:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 9:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 10:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 11:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 12:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 13:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 14:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 15:
-		halbtc8723b1ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 16:
-		halbtc8723b1ant_coex_table(btcoexist,
-					   force_exec, 0x55555555, 0x5a5a5aaa,
-						   0xffffff, 0x3);
-		break;
-	case 17:
-		halbtc8723b1ant_coex_table(btcoexist,
-					   force_exec, 0x55555555, 0xaaaa5aaa,
-						   0xffffff, 0x3);
-		break;
-	case 18:
-		halbtc8723b1ant_coex_table(btcoexist,
-					   force_exec, 0x55555555, 0x5a5a5a6a,
-						   0xffffff, 0x3);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8723b1ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
-{
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
-
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
-	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
-			return;
-	}
-
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-
-void halbtc8723b1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8723b1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8723b1ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8723b1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8723b1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8723b1ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8723b1ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean force_exec, IN boolean init_hwcfg,
-				  IN boolean wifi_off)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-	u32			fw_ver = 0, u32tmp = 0, cnt_bt_cal_chk = 0;
-	boolean			pg_ext_switch = false;
-	boolean			use_ext_switch = false;
-	boolean			is_in_mp_mode = false;
-	u8			h2c_parameter[2] = {0}, u8tmp = 0;
-	u32         u32tmp_1[4];
-	boolean		is_fw_ready;
-
-	coex_dm->cur_ant_pos_type = ant_pos_type;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_EXT_SWITCH, &pg_ext_switch);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER,
-			   &fw_ver);	/* [31:16]=fw ver, [15:0]=fw sub ver */
-
-	if ((fw_ver > 0 && fw_ver < 0xc0000) || pg_ext_switch)
-		use_ext_switch = true;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE
-	if (ant_pos_type == BTC_ANT_PATH_PTA) {
-		if ((board_info->btdm_ant_det_finish) &&
-		    (board_info->btdm_ant_num_by_ant_det == 2)) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type = BTC_ANT_PATH_WIFI;
-			else
-				ant_pos_type = BTC_ANT_PATH_BT;
-		}
-	}
-#endif
-#endif
-
-	if (init_hwcfg) {
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x780); /* WiFi TRx Mask on */
-		/* remove due to interrupt is disabled that polling c2h will fail and delay 100ms. */
-		/* btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x3c, 0x15); */ /*BT TRx Mask on */
-
-		if (fw_ver >= 0x180000) {
-			/* Use H2C to set GNT_BT to HIGH */
-			h2c_parameter[0] = 1;
-			btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1,
-						h2c_parameter);
-
-			cnt_bt_cal_chk = 0;
-			while (1) {
-				btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_FW_READY, &is_fw_ready);
-				if (is_fw_ready == false) {
-					BTC_SPRINTF(trace_buf , BT_TMP_BUF_SIZE,
-						("halbtc8723b1ant_set_ant_path(): we don't need to wait for H2C command completion because of Fw download fail!!!\n"));
-					BTC_TRACE(trace_buf);
-					break;
-				}
-
-				if (btcoexist->btc_read_1byte(btcoexist,
-							      0x765) == 0x18)
-					break;
-
-				cnt_bt_cal_chk++;
-				if (cnt_bt_cal_chk > 20)
-					break;
-			}
-		} else {
-			/* set grant_bt to high */
-			btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18);
-		}
-		/* set wlan_act control by PTA */
-		btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-			   0x0); /* BT select s0/s1 is controlled by BT */
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x39, 0x8, 0x1);
-		btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x944, 0x3, 0x3);
-		btcoexist->btc_write_1byte(btcoexist, 0x930, 0x77);
-	} else if (wifi_off) {
-		if (fw_ver >= 0x180000) {
-			/* Use H2C to set GNT_BT to HIGH */
-			h2c_parameter[0] = 1;
-			btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1,
-						h2c_parameter);
-
-			cnt_bt_cal_chk = 0;
-			while (1) {
-				btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_FW_READY, &is_fw_ready);
-				if (is_fw_ready == false) {
-					BTC_SPRINTF(trace_buf , BT_TMP_BUF_SIZE,
-						("halbtc8723b1ant_set_ant_path(): we don't need to wait for H2C command completion because of Fw download fail!!!\n"));
-					BTC_TRACE(trace_buf);
-					break;
-				}
-
-				if (btcoexist->btc_read_1byte(btcoexist,
-							      0x765) == 0x18)
-					break;
-
-				cnt_bt_cal_chk++;
-				if (cnt_bt_cal_chk > 20)
-					break;
-			}
-		} else {
-			/* set grant_bt to high */
-			btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18);
-		}
-		/* set wlan_act to always low */
-		btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_IS_IN_MP_MODE,
-				   &is_in_mp_mode);
-		if (!is_in_mp_mode)
-			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-				0x20, 0x0); /* BT select s0/s1 is controlled by BT */
-		else
-			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-				0x20, 0x1); /* BT select s0/s1 is controlled by WiFi */
-
-		/* 0x4c[24:23]=00, Set Antenna control by BT_RFE_CTRL	BT Vendor 0xac=0xf002 */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp &= ~BIT(23);
-		u32tmp &= ~BIT(24);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-	} else {
-		/* Use H2C to set GNT_BT to LOW */
-		if (fw_ver >= 0x180000) {
-			if (btcoexist->btc_read_1byte(btcoexist, 0x765) != 0) {
-				h2c_parameter[0] = 0;
-				btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1,
-							h2c_parameter);
-
-				cnt_bt_cal_chk = 0;
-				while (1) {
-					btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_FW_READY, &is_fw_ready);
-					if (is_fw_ready == false) {
-						BTC_SPRINTF(trace_buf ,
-							    BT_TMP_BUF_SIZE,
-							("halbtc8723b1ant_set_ant_path(): we don't need to wait for H2C command completion because of Fw download fail!!!\n"));
-						BTC_TRACE(trace_buf);
-						break;
-					}
-
-					if (btcoexist->btc_read_1byte(btcoexist,
-							      0x765) == 0x0)
-						break;
-
-					cnt_bt_cal_chk++;
-					if (cnt_bt_cal_chk > 20)
-						break;
-				}
-			}
-		} else {
-			/* BT calibration check */
-			while (cnt_bt_cal_chk <= 20) {
-				u8tmp = btcoexist->btc_read_1byte(btcoexist,
-								  0x49d);
-				cnt_bt_cal_chk++;
-				if (u8tmp & BIT(0)) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n",
-						    cnt_bt_cal_chk);
-					BTC_TRACE(trace_buf);
-					delay_ms(50);
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], ********** BT is NOT calibrating (wait cnt=%d)**********\n",
-						    cnt_bt_cal_chk);
-					BTC_TRACE(trace_buf);
-					break;
-				}
-			}
-
-			/* set grant_bt to PTA */
-			btcoexist->btc_write_1byte(btcoexist, 0x765, 0x0);
-		}
-
-		if (btcoexist->btc_read_1byte(btcoexist, 0x76e) != 0xc) {
-			/* set wlan_act control by PTA */
-			btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-		}
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-			   0x1); /* BT select s0/s1 is controlled by WiFi */
-	}
-
-	if (use_ext_switch) {
-		if (init_hwcfg) {
-			/* 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT */
-			u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-			u32tmp &= ~BIT(23);
-			u32tmp |= BIT(24);
-			btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-
-
-			u32tmp_1[0] = btcoexist->btc_read_4byte(btcoexist,
-								0x948);
-			if ((u32tmp_1[0] == 0x40) || (u32tmp_1[0] == 0x240))
-				btcoexist->btc_write_4byte(btcoexist, 0x948,
-							   u32tmp_1[0]);
-			else
-				btcoexist->btc_write_4byte(btcoexist, 0x948,
-							   0x0);
-
-
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT) {
-				/* tell firmware "no antenna inverse" */
-				h2c_parameter[0] = 0;
-				h2c_parameter[1] = 1;  /* ext switch type */
-				btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-							h2c_parameter);
-			} else {
-				/* tell firmware "antenna inverse" */
-				h2c_parameter[0] = 1;
-				h2c_parameter[1] = 1;  /* ext switch type */
-				btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-							h2c_parameter);
-			}
-		}
-
-		if (force_exec ||
-		    (coex_dm->cur_ant_pos_type !=
-		     coex_dm->pre_ant_pos_type)) {
-			/* ext switch setting */
-			switch (ant_pos_type) {
-			case BTC_ANT_PATH_WIFI:
-				if (board_info->btdm_ant_pos ==
-				    BTC_ANTENNA_AT_MAIN_PORT)
-					btcoexist->btc_write_1byte_bitmask(
-						btcoexist, 0x92c, 0x3,
-						0x1);
-				else
-					btcoexist->btc_write_1byte_bitmask(
-						btcoexist, 0x92c, 0x3,
-						0x2);
-				break;
-			case BTC_ANT_PATH_BT:
-				if (board_info->btdm_ant_pos ==
-				    BTC_ANTENNA_AT_MAIN_PORT)
-					btcoexist->btc_write_1byte_bitmask(
-						btcoexist, 0x92c, 0x3,
-						0x2);
-				else
-					btcoexist->btc_write_1byte_bitmask(
-						btcoexist, 0x92c, 0x3,
-						0x1);
-				break;
-			default:
-			case BTC_ANT_PATH_PTA:
-				if (board_info->btdm_ant_pos ==
-				    BTC_ANTENNA_AT_MAIN_PORT)
-					btcoexist->btc_write_1byte_bitmask(
-						btcoexist, 0x92c, 0x3,
-						0x1);
-				else
-					btcoexist->btc_write_1byte_bitmask(
-						btcoexist, 0x92c, 0x3,
-						0x2);
-				break;
-			}
-		}
-	} else {
-		if (init_hwcfg) {
-			/* 0x4c[23]=1, 0x4c[24]=0  Antenna control by 0x64 */
-			u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-			u32tmp |= BIT(23);
-			u32tmp &= ~BIT(24);
-			btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-
-			/* Fix Ext switch Main->S1, Aux->S0 */
-			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1,
-							   0x0);
-
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT) {
-
-				/* tell firmware "no antenna inverse" */
-				h2c_parameter[0] = 0;
-				h2c_parameter[1] =
-					0;  /* internal switch type */
-				btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-							h2c_parameter);
-			} else {
-
-				/* tell firmware "antenna inverse" */
-				h2c_parameter[0] = 1;
-				h2c_parameter[1] =
-					0;  /* internal switch type */
-				btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-							h2c_parameter);
-			}
-		}
-
-		if (force_exec ||
-		    (coex_dm->cur_ant_pos_type !=
-		     coex_dm->pre_ant_pos_type)) {
-			/* internal switch setting */
-			switch (ant_pos_type) {
-			case BTC_ANT_PATH_WIFI:
-				if (board_info->btdm_ant_pos ==
-				    BTC_ANTENNA_AT_MAIN_PORT) {
-					u32tmp_1[0] = btcoexist->btc_read_4byte(
-							      btcoexist, 0x948);
-					if ((u32tmp_1[0] == 0x40) ||
-					    (u32tmp_1[0] == 0x240))
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948,
-							u32tmp_1[0]);
-					else
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948, 0x0);
-				} else {
-					u32tmp_1[0] = btcoexist->btc_read_4byte(
-							      btcoexist, 0x948);
-					if ((u32tmp_1[0] == 0x40) ||
-					    (u32tmp_1[0] == 0x240))
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948,
-							u32tmp_1[0]);
-					else
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948,
-							0x280);
-				}
-				break;
-			case BTC_ANT_PATH_BT:
-				if (board_info->btdm_ant_pos ==
-				    BTC_ANTENNA_AT_MAIN_PORT) {
-					u32tmp_1[0] = btcoexist->btc_read_4byte(
-							      btcoexist, 0x948);
-					if ((u32tmp_1[0] == 0x40) ||
-					    (u32tmp_1[0] == 0x240))
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948,
-							u32tmp_1[0]);
-					else
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948,
-							0x280);
-				} else {
-					u32tmp_1[0] = btcoexist->btc_read_4byte(
-							      btcoexist, 0x948);
-					if ((u32tmp_1[0] == 0x40) ||
-					    (u32tmp_1[0] == 0x240))
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948,
-							u32tmp_1[0]);
-					else
-						btcoexist->btc_write_4byte(
-							btcoexist, 0x948, 0x0);
-				}
-				break;
-			default:
-			case BTC_ANT_PATH_PTA:
-				if (board_info->btdm_ant_pos ==
-				    BTC_ANTENNA_AT_MAIN_PORT)
-					btcoexist->btc_write_4byte(
-						btcoexist, 0x948,
-						0x200);
-				else
-					btcoexist->btc_write_4byte(
-						btcoexist, 0x948, 0x80);
-				break;
-			}
-		}
-	}
-
-	coex_dm->pre_ant_pos_type = coex_dm->cur_ant_pos_type;
-}
-
-void halbtc8723b1ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x8, 0, 0, 0, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			/* halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8); */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			/* halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8); */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-
-void halbtc8723b1ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	case BTC_PS_LPS_ON:
-		halbtc8723b1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, true);
-		halbtc8723b1ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		coex_sta->force_lps_on = true;
-		break;
-	case BTC_PS_LPS_OFF:
-		halbtc8723b1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	default:
-		break;
-	}
-}
-
-
-void halbtc8723b1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean		ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			real_byte1 &= ~BIT(4);
-			real_byte1 |= BIT(5);
-
-			real_byte5 |= BIT(5);
-			real_byte5 &= ~BIT(6);
-
-			halbtc8723b1ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		}
-	} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			halbtc8723b1ant_power_save_state(btcoexist,
-				BTC_PS_LPS_ON, 0x50, 0x4);
-
-	} else {
-			halbtc8723b1ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	}
-
-	h2c_parameter[0] = real_byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = real_byte5;
-
-	coex_dm->ps_tdma_para[0] = real_byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = real_byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-
-void halbtc8723b1ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_busy = false;
-	u8			rssi_adjust_val = 0;
-	u8			ps_tdma_byte4_val = 0x50, ps_tdma_byte0_val = 0x51,
-				ps_tdma_byte3_val =  0x10;
-	s8			wifi_duration_adjust = 0x0;
-	static boolean	 pre_wifi_busy = false;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE
-	if (board_info->btdm_ant_num_by_ant_det == 2) {
-		if (turn_on)
-			type = type +
-			       100; /* for WiFi RSSI low or BT RSSI low */
-		else
-			type = 1; /* always translate to TDMA(off,1) for TDMA-off case */
-	}
-
-#endif
-#endif
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (wifi_busy != pre_wifi_busy) {
-		force_exec = true;
-		pre_wifi_busy = wifi_busy;
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-
-	if (coex_sta->scan_ap_num <= 5) {
-		wifi_duration_adjust = 5;
-
-		if (coex_sta->a2dp_bit_pool >= 35)
-			wifi_duration_adjust = -10;
-		else if (coex_sta->a2dp_bit_pool >= 45)
-			wifi_duration_adjust = -15;
-	} else if (coex_sta->scan_ap_num >= 40) {
-		wifi_duration_adjust = -15;
-
-		if (coex_sta->a2dp_bit_pool < 35)
-			wifi_duration_adjust = -5;
-		else if (coex_sta->a2dp_bit_pool < 45)
-			wifi_duration_adjust = -10;
-	} else if (coex_sta->scan_ap_num >= 20) {
-		wifi_duration_adjust = -10;
-
-		if (coex_sta->a2dp_bit_pool >= 45)
-			wifi_duration_adjust = -15;
-	} else {
-		wifi_duration_adjust = 0;
-
-		if (coex_sta->a2dp_bit_pool >= 35)
-			wifi_duration_adjust = -10;
-		else if (coex_sta->a2dp_bit_pool >= 45)
-			wifi_duration_adjust = -15;
-	}
-
-	if ((type == 1) || (type == 2) || (type == 9) || (type == 11) ||
-	    (type == 101)
-	    || (type == 102) || (type == 109) || (type == 101)) {
-#if 0
-		if (!coex_sta->force_lps_on) { /* Native power save TDMA, only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30 */
-			ps_tdma_byte0_val = 0x61;  /* no null-pkt */
-			ps_tdma_byte3_val = 0x11; /* no tx-pause at BT-slot */
-			ps_tdma_byte4_val =
-				0x10; /* 0x778 = d/1 toggle, no dynamic slot */
-		} else {
-#endif
-			ps_tdma_byte0_val = 0x51;  /* null-pkt */
-			ps_tdma_byte3_val = 0x10; /* tx-pause at BT-slot */
-			ps_tdma_byte4_val =
-				0x50; /* 0x778 = d/1 toggle, dynamic slot */
-#if 0
-		}
-#endif
-	} else if ((type == 3) || (type == 13) || (type == 14) ||
-		   (type == 103) || (type == 113) || (type == 114)) {
-		ps_tdma_byte0_val = 0x51;  /* null-pkt */
-		ps_tdma_byte3_val = 0x10; /* tx-pause at BT-slot */
-		ps_tdma_byte4_val =
-			0x10; /* 0x778 = d/1 toggle, no dynamic slot */
-#if 0
-		if (!wifi_busy)
-			ps_tdma_byte4_val = ps_tdma_byte4_val |
-				0x1;  /* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-#endif
-	} else { /* native power save case */
-		ps_tdma_byte0_val = 0x61;  /* no null-pkt */
-		ps_tdma_byte3_val = 0x11; /* no tx-pause at BT-slot */
-		ps_tdma_byte4_val =
-			0x11; /* 0x778 = d/1 toggle, no dynamic slot */
-		/* psTdmaByte4Va is not defne for 0x778 = d/1, 1/1 case */
-	}
-
-	/* if (bt_link_info->slave_role == true) */
-	if ((bt_link_info->slave_role == true)	&& (bt_link_info->a2dp_exist))
-		ps_tdma_byte4_val = ps_tdma_byte4_val |
-			0x1;  /* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-
-	if (type > 100) {
-		ps_tdma_byte0_val = ps_tdma_byte0_val |
-				    0x82; /* set antenna control by SW	 */
-		ps_tdma_byte3_val = ps_tdma_byte3_val |
-			0x60;  /* set antenna no toggle, control by antenna diversity */
-	}
-
-
-	if (turn_on) {
-		switch (type) {
-		default:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x1a, 0x1a, 0x0, ps_tdma_byte4_val);
-			break;
-		case 1:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x3a +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 2:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x2d +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 3:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x30, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 4:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x14, 0x0);
-			break;
-		case 5:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x1f, 0x3,
-						      ps_tdma_byte3_val, 0x11);
-			break;
-		case 6:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x20, 0x3,
-						      ps_tdma_byte3_val, 0x11);
-			break;
-		case 7:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xc, 0x5, 0x0, 0x0);
-			break;
-		case 8:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			break;
-		case 9:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 10:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0xa, 0x0, 0x40);
-			break;
-		case 11:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 12:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x0a, 0x0a, 0x0, 0x50);
-			break;
-		case 13:
-			if (coex_sta->scan_ap_num <= 3)
-				halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x40, 0x3,
-							      ps_tdma_byte3_val,
-						      ps_tdma_byte4_val);
-			else
-				halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-							      ps_tdma_byte3_val,
-						      ps_tdma_byte4_val);
-			break;
-		case 14:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x3, 0x10, 0x54);
-#if 0
-			if (coex_sta->scan_ap_num <= 3)
-				halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x30, 0x3, 0x10, 0x50);
-			else
-				halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-							      ps_tdma_byte3_val,
-						      ps_tdma_byte4_val);
-#endif
-			break;
-		case 15:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0x3, 0x8, 0x0);
-			break;
-		case 16:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x10, 0x0);
-			break;
-		case 17:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      0x55, 0x10, 0x3, 0x10, 0x54);
-			break;
-		case 18:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			break;
-		case 20:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x3f, 0x03,
-						      ps_tdma_byte3_val, 0x10);
-			break;
-		case 21:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11, 0x11);
-			break;
-		case 22:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x25, 0x03,
-						      ps_tdma_byte3_val, 0x10);
-			break;
-		case 23:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x18);
-			break;
-		case 24:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x3, 0x31, 0x18);
-			break;
-		case 25:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			break;
-		case 26:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			break;
-		case 27:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x98);
-			break;
-		case 28:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x69,
-						      0x25, 0x3, 0x31, 0x0);
-			break;
-		case 29:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xab,
-						      0x1a, 0x1a, 0x1, 0x10);
-			break;
-		case 30:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10, 0x10);
-			break;
-		case 31:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1a, 0x1a, 0, 0x58);
-			break;
-		case 32:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x35, 0x3,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 33:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x35, 0x3,
-						      ps_tdma_byte3_val, 0x10);
-			break;
-		case 34:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 35:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 36:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x12, 0x3, 0x14, 0x50);
-			break;
-		case 37:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x3, 0x10, 0x54);
-			break;
-		case 40: /* SoftAP only with no sta associated,BT disable ,TDMA mode for power saving */
-			/* here softap mode screen off will cost 70-80mA for phone */
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x23,
-						      0x18, 0x00, 0x10, 0x24);
-			break;
-		case 41:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x7, 0x10, 0x54);
-			break;
-		case 42:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      0x55, 0x10, 0x7, 0x10, 0x54);
-			break;
-		/* for 1-Ant translate to 2-Ant	 */
-		case 101:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x3a +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 102:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x2d +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 103:
-			/* halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x51, 0x1d, 0x1d, 0x0, ps_tdma_byte4_val); */
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x3a, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 105:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x15, 0x3,
-						      ps_tdma_byte3_val, 0x11);
-			break;
-		case 106:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x20, 0x3,
-						      ps_tdma_byte3_val, 0x11);
-			break;
-		case 109:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 111:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 113:
-			/* halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x51, 0x12, 0x12, 0x0, ps_tdma_byte4_val); */
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 114:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 120:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x3f, 0x03,
-						      ps_tdma_byte3_val, 0x10);
-			break;
-		case 122:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x25, 0x03,
-						      ps_tdma_byte3_val, 0x10);
-			break;
-		case 132:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x25, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 133:
-			halbtc8723b1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x25, 0x03,
-						      ps_tdma_byte3_val, 0x11);
-			break;
-
-		}
-	} else {
-
-		/* disable PS tdma */
-		switch (type) {
-		case 8: /* PTA Control */
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x8,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		case 0:
-		default:  /* Software control, Antenna at BT side */
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		case 1: /* 2-Ant, 0x778=3, antenna control by antenna diversity */
-			halbtc8723b1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x48, 0x0);
-			break;
-		}
-	}
-	rssi_adjust_val = 0;
-	btcoexist->btc_set(btcoexist,
-		BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssi_adjust_val);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-		    btcoexist->btc_read_4byte(btcoexist, 0x948),
-		    btcoexist->btc_read_1byte(btcoexist, 0x765),
-		    btcoexist->btc_read_1byte(btcoexist, 0x67));
-	BTC_TRACE(trace_buf);
-
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-void halbtc8723b1ant_tdma_duration_adjust_for_acl(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0, bt_info_ext;
-	boolean			wifi_busy = false;
-
-	if (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY == wifi_status)
-		wifi_busy = true;
-	else
-		wifi_busy = false;
-
-	if ((BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN ==
-	     wifi_status) ||
-	    (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifi_status) ||
-	    (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT ==
-	     wifi_status)) {
-		if (coex_dm->cur_ps_tdma != 1 &&
-		    coex_dm->cur_ps_tdma != 2 &&
-		    coex_dm->cur_ps_tdma != 3 &&
-		    coex_dm->cur_ps_tdma != 9) {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						9);
-			coex_dm->ps_tdma_du_adj_type = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n = 3;
-			result = 0;
-			wait_count = 0;
-		}
-		return;
-	}
-
-	if (!coex_dm->auto_tdma_adjust) {
-		coex_dm->auto_tdma_adjust = true;
-
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 2);
-		coex_dm->ps_tdma_du_adj_type = 2;
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2 */
-		retry_count = coex_sta->bt_retry_cnt;
-		bt_info_ext = coex_sta->bt_info_ext;
-
-		if ((coex_sta->low_priority_tx) > 1050 ||
-		    (coex_sta->low_priority_rx) > 1250)
-			retry_count++;
-
-		result = 0;
-		wait_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if retry count during continuous n*2 seconds is 0, enlarge WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if continuous 2 retry count(every 2 seconds) >0 and < 3, reduce WiFi duration */
-				if (wait_count <= 2)
-					m++; /* to avoid loop between the two levels */
-				else
-					m = 1;
-
-				if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-			}
-		} else { /* retry count > 3, once retry count > 3, to reduce WiFi duration */
-			if (wait_count == 1)
-				m++; /* to avoid loop between the two levels */
-			else
-				m = 1;
-
-			if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-		}
-
-		if (result == -1) {
-			/*		if( (BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-						((coex_dm->cur_ps_tdma == 1) ||(coex_dm->cur_ps_tdma == 2)) )
-					{
-						halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9);
-						coex_dm->ps_tdma_du_adj_type = 9;
-					}
-					else */ if (coex_dm->cur_ps_tdma == 1) {
-							halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 2);
-				coex_dm->ps_tdma_du_adj_type = 2;
-			} else if (coex_dm->cur_ps_tdma == 2) {
-				halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 9) {
-				halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 11);
-				coex_dm->ps_tdma_du_adj_type = 11;
-			}
-		} else if (result == 1) {
-			/*			if( (BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-							((coex_dm->cur_ps_tdma == 1) ||(coex_dm->cur_ps_tdma == 2)) )
-						{
-							halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9);
-							coex_dm->ps_tdma_du_adj_type = 9;
-						}
-						else */ if (coex_dm->cur_ps_tdma == 11) {
-								halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-								true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 9) {
-				halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 2);
-				coex_dm->ps_tdma_du_adj_type = 2;
-			} else if (coex_dm->cur_ps_tdma == 2) {
-				halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 1);
-				coex_dm->ps_tdma_du_adj_type = 1;
-			}
-		} else { /* no change */
-			/* Bryant Modify
-			if(wifi_busy != pre_wifi_busy)
-			{
-				pre_wifi_busy = wifi_busy;
-				halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, true, coex_dm->cur_ps_tdma);
-			}
-			*/
-
-		}
-
-		if (coex_dm->cur_ps_tdma != 1 &&
-		    coex_dm->cur_ps_tdma != 2 &&
-		    coex_dm->cur_ps_tdma != 9 &&
-		    coex_dm->cur_ps_tdma != 11) {
-			/* recover to previous adjust type */
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		}
-	}
-}
-
-
-/* *********************************************
- *
- *	Non-Software Coex Mechanism start
- *
- * ********************************************* */
-void halbtc8723b1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)
-{
-	halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-	halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC,
-				     false, false);
-	halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-
-void halbtc8723b1ant_action_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5);
-	halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-}
-
-void halbtc8723b1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_connected = false, ap_enable = false, wifi_busy = false,
-				bt_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	if (coex_sta->bt_abnormal_scan) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-					33);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else if ((!wifi_connected) && (!coex_sta->wifi_is_high_pri_task)) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist) ||
-		   (bt_link_info->a2dp_exist)) {
-		/* SCO/HID/A2DP  busy */
-
-		if (coex_sta->c2h_bt_remote_name_req)
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						33);
-		else
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if ((bt_link_info->pan_exist) || (wifi_busy)) {
-
-		if (coex_sta->c2h_bt_remote_name_req)
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						33);
-		else
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-	}
-}
-
-void halbtc8723b1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	/* tdma and coex table */
-
-	if (bt_link_info->sco_exist) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	} else { /* HID */
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 6);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	}
-}
-
-void halbtc8723b1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
-{
-	halbtc8723b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-	halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8);
-	halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, FORCE_EXEC,
-				     false, false);
-}
-
-void halbtc8723b1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-	halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC,
-				     false, false);
-	halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-}
-
-void halbtc8723b1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-	u32  wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	if ((coex_sta->low_priority_rx >= 950)  && (!coex_sta->under_ips))
-		bt_link_info->slave_role = true;
-	else
-		bt_link_info->slave_role = false;
-
-	if (bt_link_info->hid_only) { /* HID */
-		halbtc8723b1ant_action_bt_sco_hid_only_busy(btcoexist,
-				wifi_status);
-		coex_dm->auto_tdma_adjust = false;
-		return;
-	} else if (bt_link_info->a2dp_only) { /* A2DP		 */
-		if (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifi_status) {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-			coex_dm->auto_tdma_adjust = false;
-		} else {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						37);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 16);
-			coex_dm->auto_tdma_adjust = false;
-		}
-	} else if (((bt_link_info->a2dp_exist) && (bt_link_info->pan_exist)) ||
-		   (bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) { /* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 13);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	} else if (bt_link_info->hid_exist &&
-		   bt_link_info->a2dp_exist) { /* HID+A2DP */
-
-#if 1
-
-		coex_dm->auto_tdma_adjust = false;
-
-		if (iot_peer == BTC_IOT_PEER_ATHEROS) {
-			halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 17);
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 14);
-		} else {
-			if (coex_sta->a2dp_bit_pool < 40) { /*for longer wifi slot RS1 */
-				if (wifi_bw == 0) { /*11bg mode*/
-#if 1
-					halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-					halbtc8723b1ant_set_wltoggle_coex_table(btcoexist, NORMAL_EXEC,
-						0x1, 0xaa, 0x5a, 0x5a, 0x5a);
-					halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 42);
-#endif
-#if 0
-					halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 18);
-					halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 41);
-#endif
-
-				} else {  /*11n mode*/
-					halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-					halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 14);
-				}
-			} else {   /*for shorter wifi slot RS2 */
-				halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 14);
-				if (wifi_bw == 0) /* 11bg mode */
-					halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 16);
-				else  /*11n mode*/
-					halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			}
-		}
-#endif
-	} else if ((bt_link_info->pan_only) || (bt_link_info->hid_exist &&
-		bt_link_info->pan_exist)) { /* PAN(OPP,FTP), HID+PAN(OPP,FTP)			 */
-
-		if (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifi_status)
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						9);
-		else
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						3);
-
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	} else {
-		/* BT no-profile busy (0x9) */
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 33);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	}
-}
-
-void halbtc8723b1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-
-	/* tdma and coex table */
-	halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8);
-	halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC,
-				     false, false);
-	halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8723b1ant_action_wifi_not_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* tdma and coex table */
-	if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8723b1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* Bryant Add */
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8723b1ant_action_wifi_not_connected_asso_auth(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist)  || (bt_link_info->hid_exist) ||
-	    (bt_link_info->a2dp_exist)) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 4);
-	} else if (bt_link_info->pan_exist) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 4);
-	} else {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 2);
-	}
-}
-
-void halbtc8723b1ant_action_wifi_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* tdma and coex table */
-	if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8723b1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* Bryant Add */
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8723b1ant_action_wifi_connected_specific_packet(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean wifi_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* no specific packet process for both WiFi and BT very busy */
-	if ((wifi_busy) && ((bt_link_info->pan_exist) ||
-			    (coex_sta->num_of_profile >= 2)))
-		return;
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist)) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	} else if (bt_link_info->a2dp_exist) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if (bt_link_info->pan_exist) {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8723b1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-	boolean	wifi_busy = false;
-	boolean		scan = false, link = false, roam = false;
-	boolean		under_4way = false, ap_enable = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], CoexForWifiConnect()===>\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-	if (under_4way) {
-		halbtc8723b1ant_action_wifi_connected_specific_packet(
-			btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	if (scan || link || roam) {
-		if (scan)
-			halbtc8723b1ant_action_wifi_connected_scan(btcoexist);
-		else
-			halbtc8723b1ant_action_wifi_connected_specific_packet(
-				btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-
-	/* tdma and coex table */
-	if (!wifi_busy) {
-		if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8723b1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8723b1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else {
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-			halbtc8723b1ant_set_ant_path(btcoexist,
-				BTC_ANT_PATH_PTA, NORMAL_EXEC, false, false);
-			/* if ((coex_sta->high_priority_tx) +
-			    (coex_sta->high_priority_rx) <= 60) */
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-			/* else
-				halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7); */
-		}
-	} else {
-		if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8723b1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8723b1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else {
-			/* halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-			halbtc8723b1ant_set_ant_path(btcoexist,
-				BTC_ANT_PATH_PTA, NORMAL_EXEC, false, false);
-			if ((coex_sta->high_priority_tx) +
-			    (coex_sta->high_priority_rx) <= 60)
-				halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-			else
-				halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7); */
-			halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8723b1ant_set_ant_path(btcoexist,
-				BTC_ANT_PATH_PTA, NORMAL_EXEC, false, false);
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-
-		}
-	}
-}
-
-void halbtc8723b1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false, bt_hs_on = false, wifi_busy = false;
-	boolean	increase_scan_dev_num = false;
-	boolean	bt_ctrl_agg_buf_size = false;
-	boolean	miracast_plus_bt = false;
-	u8	agg_buf_size = 5;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0, wifi_bw;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b1ant_action_bt_whck_test(btcoexist);
-		return;
-	}
-
-	if ((BT_8723B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8723B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		increase_scan_dev_num = true;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_INC_SCAN_DEV_NUM,
-			   &increase_scan_dev_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		if (bt_link_info->bt_link_exist) {
-			halbtc8723b1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1,
-						   0, 1);
-			miracast_plus_bt = true;
-		} else {
-			halbtc8723b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0,
-						   0, 0);
-			miracast_plus_bt = false;
-		}
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-		halbtc8723b1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-
-		if (((bt_link_info->a2dp_exist) || (wifi_busy)) &&
-		    (coex_sta->c2h_bt_inquiry_page))
-			halbtc8723b1ant_action_bt_inquiry(btcoexist);
-		else
-			halbtc8723b1ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	}
-
-	miracast_plus_bt = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-			   &miracast_plus_bt);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if ((bt_link_info->bt_link_exist) && (wifi_connected)) {
-		halbtc8723b1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1, 0, 1);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-		/* if(BTC_IOT_PEER_CISCO != iot_peer)		 */
-		if ((BTC_IOT_PEER_CISCO != iot_peer) &&
-		    (BTC_IOT_PEER_BROADCOM != iot_peer)) {
-			if (bt_link_info->sco_exist) /* if (bt_link_info->bt_hi_pri_link_exist) */
-				/* halbtc8723b1ant_limited_rx(btcoexist, NORMAL_EXEC, true, false, 0x5);				 */
-				halbtc8723b1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, true, false, 0x5);
-			else
-				halbtc8723b1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, false, false, 0x5);
-			/* halbtc8723b1ant_limited_rx(btcoexist, NORMAL_EXEC, false, true, 0x8);		 */
-		} else {
-			if (bt_link_info->sco_exist)
-				halbtc8723b1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, true, false, 0x5);
-			else if (bt_link_info->hid_exist)
-				halbtc8723b1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, false, true, 0x8);
-			else {
-				if (BTC_WIFI_BW_HT40 == wifi_bw)
-					halbtc8723b1ant_limited_rx(btcoexist,
-						NORMAL_EXEC, false, true, 0x10);
-				else
-					halbtc8723b1ant_limited_rx(btcoexist,
-						NORMAL_EXEC, false, true, 0x8);
-			}
-		}
-
-		halbtc8723b1ant_sw_mechanism(btcoexist, true);
-
-		/* low pelnaty ra in pcr ra */
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 35);
-
-	} else {
-		halbtc8723b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-		halbtc8723b1ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x5);
-
-		halbtc8723b1ant_sw_mechanism(btcoexist, false);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8723b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8723b1ant_action_hs(btcoexist);
-		return;
-	}
-
-
-	if (!wifi_connected) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is non connected-idle !!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (scan || link || roam) {
-			if (scan)
-				halbtc8723b1ant_action_wifi_not_connected_scan(
-					btcoexist);
-			else
-				halbtc8723b1ant_action_wifi_not_connected_asso_auth(
-					btcoexist);
-		} else
-			halbtc8723b1ant_action_wifi_not_connected(btcoexist);
-	} else	/* wifi LPS/Busy */
-		halbtc8723b1ant_action_wifi_connected(btcoexist);
-}
-
-void halbtc8723b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-
-	/* sw all off */
-	halbtc8723b1ant_sw_mechanism(btcoexist, false);
-
-	/* halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8); */
-	/* halbtc8723b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0); */
-
-	coex_sta->pop_event_cnt = 0;
-}
-
-void halbtc8723b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up, IN boolean wifi_only)
-{
-	u32				u32tmp = 0; /* , fw_ver; */
-	u8				u8tmpa = 0, u8tmpb = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	psd_scan->ant_det_is_ant_det_available = false;
-
-
-	/* Give bt_coex_supported_version the default value */
-	coex_sta->bt_coex_supported_version = 0;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* 0x790[5:0]=0x5	 */
-	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
-
-	/* Enable counter statistics */
-	/* btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc); */ /*0x76e[3] =1, WLAN_Act control by PTA */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-
-
-	/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20, 0x1); */ /*BT select s0/s1 is controlled by WiFi */
-
-	halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8);
-
-	/* Antenna config */
-	if (wifi_only)
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_WIFI,
-					     FORCE_EXEC, true, false);
-	else
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, true, false);
-
-	/* PTA parameter */
-	halbtc8723b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948);
-	u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-	u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x67);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-		    u32tmp,  u8tmpa, u8tmpb);
-	BTC_TRACE(trace_buf);
-
-}
-
-/* Donot remove optimize off flag, otherwise antenna detection would trigger BT collapsed */
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-void halbtc8723b1ant_mechanism_switch(IN struct btc_coexist *btcoexist,
-				      IN boolean bSwitchTo2Antenna)
-{
-
-	if (bSwitchTo2Antenna) {
-
-		/* BT TRx mask off */
-		btcoexist->btc_set_bt_trx_mask(btcoexist, 0);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex], BT TRx Mask off for mechanism_switch\n");
-
-		BTC_TRACE(trace_buf);
-
-	} else {
-
-		/* BT TRx mask on */
-		btcoexist->btc_set_bt_trx_mask(btcoexist, 1);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex], BT TRx Mask on for mechanism_switch\n");
-
-		BTC_TRACE(trace_buf);
-	}
-
-
-#if 0
-	if (bSwitchTo2Antenna) { /* 1-Ant -> 2-Ant */
-		/* un-lock TRx Mask setup for 8723b f-cut */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdd, 0x80, 0x1);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdf, 0x1, 0x1);
-		/* WiFi TRx Mask on				 */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0);
-
-		/* BT TRx Mask un-lock 0x2c[0], 0x30[0] = 1 */
-		btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x2c,
-					  0x7c45);
-		btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x30,
-					  0x7c45);
-
-		/* BT TRx Mask on */
-		btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x3c, 0x1);
-
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, false, false);
-	} else {
-		/* WiFi TRx Mask on				 */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x780);
-
-		/* lock TRx Mask setup for 8723b f-cut */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdd, 0x80, 0x0);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdf, 0x1, 0x0);
-
-		/* BT TRx Mask on */
-		btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x3c, 0x15);
-
-		/* BT TRx Mask ock 0x2c[0], 0x30[0]  = 0 */
-		btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x2c,
-					  0x7c44);
-		btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x30,
-					  0x7c44);
-
-
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     FORCE_EXEC, false, false);
-	}
-
-#endif
-}
-
-u32 halbtc8723b1ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)
-{
-	u8	j;
-	u32	tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
-	u32	result, val_fractiond_b = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
-				   174, 151, 132, 115, 100, 86, 74, 62, 51, 42,
-							   32, 23, 15, 7, 0
-							      };
-
-	if (val == 0)
-		return 0;
-
-	tmp = val;
-
-	while (1) {
-		if (tmp == 1)
-			break;
-
-		tmp = (tmp >> 1);
-		shiftcount++;
-	}
-
-
-	val_integerd_b = shiftcount + 1;
-
-	tmp2 = 1;
-	for (j = 1; j <= val_integerd_b; j++)
-		tmp2 = tmp2 * 2;
-
-	tmp = (val * 100) / tmp2;
-	tindex = tmp / 5;
-
-	if (tindex > 20)
-		tindex = 20;
-
-	val_fractiond_b = table_fraction[tindex];
-
-	result = val_integerd_b * 100 - val_fractiond_b;
-
-	return result;
-
-
-}
-
-void halbtc8723b1ant_psd_show_antenna_detect_result(IN struct btc_coexist
-		*btcoexist)
-{
-	u8		*cli_buf = btcoexist->cli_buf;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n============[Antenna Detection info]  ============\n");
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 1)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (>%d)",
-			   "Ant Det Result", "2-Antenna (Bad-Isolation)",
-			   BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else if (psd_scan->ant_det_result == 2)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)",
-			   "Ant Det Result", "2-Antenna (Good-Isolation)",
-			   BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-			   + psd_scan->ant_det_thres_offset,
-			   BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)",
-			   "Ant Det Result", "1-Antenna",
-			   BT_8723B_1ANT_ANTDET_PSDTHRES_1ANT,
-			   BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-			   + psd_scan->ant_det_thres_offset);
-
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s ",
-		   "Antenna Detection Finish",
-		   (board_info->btdm_ant_det_finish
-		    ? "Yes" : "No"));
-	CL_PRINTF(cli_buf);
-
-	switch (psd_scan->ant_det_result) {
-	case 0:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is not available)");
-		break;
-	case 1:  /* 2-Ant bad-isolation */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 2:  /* 2-Ant good-isolation */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 3:  /* 1-Ant */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 4:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Uncertainty result)");
-		break;
-	case 5:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "(Pre-Scan fai)");
-		break;
-	case 6:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(WiFi is Scanning)");
-		break;
-	case 7:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is not idle)");
-		break;
-	case 8:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Abort by WiFi Scanning)");
-		break;
-	case 9:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Antenna Init is not ready)");
-		break;
-	case 10:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is Inquiry or page)");
-		break;
-	case 11:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is Disabled)");
-		break;
-	}
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Ant Detect Total Count", psd_scan->ant_det_try_count);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Ant Detect Fail Count", psd_scan->ant_det_fail_count);
-	CL_PRINTF(cli_buf);
-
-	if ((!board_info->btdm_ant_det_finish) &&
-	    (psd_scan->ant_det_result != 5))
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Response",
-		   (psd_scan->ant_det_result ? "ok" : "fail"));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ms", "BT Tx Time",
-		   psd_scan->ant_det_bt_tx_time);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "BT Tx Ch",
-		   psd_scan->ant_det_bt_le_channel);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d",
-		   "WiFi PSD Cent-Ch/Offset/Span",
-		   psd_scan->real_cent_freq, psd_scan->real_offset,
-		   psd_scan->real_span);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dB",
-		   "PSD Pre-Scan Peak Value",
-		   psd_scan->ant_det_pre_psdscan_peak_val / 100);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (<= %d)",
-		   "PSD Pre-Scan result",
-		   (psd_scan->ant_det_result != 5 ? "ok" : "fail"),
-		   BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND
-		   + psd_scan->ant_det_thres_offset);
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 5)
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s dB",
-		   "PSD Scan Peak Value", psd_scan->ant_det_peak_val);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s MHz",
-		   "PSD Scan Peak Freq", psd_scan->ant_det_peak_freq);
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "TFBGA Package",
-		   (board_info->tfbga_package) ?  "Yes" : "No");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "PSD Threshold Offset", psd_scan->ant_det_thres_offset);
-	CL_PRINTF(cli_buf);
-
-}
-
-void halbtc8723b1ant_psd_showdata(IN struct btc_coexist *btcoexist)
-{
-	u8		*cli_buf = btcoexist->cli_buf;
-	u32		delta_freq_per_point;
-	u32		freq, freq1, freq2, n = 0, i = 0, j = 0, m = 0, psd_rep1, psd_rep2;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n\n============[PSD info]  (%d)============\n",
-		   psd_scan->psd_gen_count);
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->psd_gen_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n No data !!\n");
-		CL_PRINTF(cli_buf);
-		return;
-	}
-
-	if (psd_scan->psd_point == 0)
-		delta_freq_per_point = 0;
-	else
-		delta_freq_per_point = psd_scan->psd_band_width /
-				       psd_scan->psd_point;
-
-	/* if (psd_scan->is_psd_show_max_only) */
-	if (0) {
-		psd_rep1 = psd_scan->psd_max_value / 100;
-		psd_rep2 = psd_scan->psd_max_value - psd_rep1 * 100;
-
-		freq = ((psd_scan->real_cent_freq - 20) * 1000000 +
-			psd_scan->psd_max_value_point * delta_freq_per_point);
-		freq1 = freq / 1000000;
-		freq2 = freq / 1000 - freq1 * 1000;
-
-		if (freq2 < 100)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n Freq = %d.0%d MHz",
-				   freq1, freq2);
-		else
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n Freq = %d.%d MHz",
-				   freq1, freq2);
-
-		if (psd_rep2 < 10)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   ", Value = %d.0%d dB, (%d)\n",
-				   psd_rep1, psd_rep2, psd_scan->psd_max_value);
-		else
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   ", Value = %d.%d dB, (%d)\n",
-				   psd_rep1, psd_rep2, psd_scan->psd_max_value);
-
-		CL_PRINTF(cli_buf);
-	} else {
-		m = psd_scan->psd_start_point;
-		n = psd_scan->psd_start_point;
-		i = 1;
-		j = 1;
-
-		while (1) {
-			do {
-				freq = ((psd_scan->real_cent_freq - 20) *
-					1000000 + m *
-					delta_freq_per_point);
-				freq1 = freq / 1000000;
-				freq2 = freq / 1000 - freq1 * 1000;
-
-				if (i == 1) {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.000",
-							   freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.0%2d",
-							   freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.%3d",
-							   freq1,
-							   freq2);
-				} else if ((i % 8 == 0) ||
-					   (m == psd_scan->psd_stop_point)) {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.000\n", freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.0%2d\n", freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.%3d\n", freq1,
-							   freq2);
-				} else {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.000", freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.0%2d", freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.%3d", freq1,
-							   freq2);
-				}
-
-				i++;
-				m++;
-				CL_PRINTF(cli_buf);
-
-			} while ((i <= 8) && (m <= psd_scan->psd_stop_point));
-
-
-			do {
-				psd_rep1 = psd_scan->psd_report_max_hold[n] /
-					   100;
-				psd_rep2 = psd_scan->psd_report_max_hold[n] -
-					   psd_rep1 *
-					   100;
-
-				if (j == 1) {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Val %7d.0%d",
-							   psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Val %7d.%d",
-							   psd_rep1,
-							   psd_rep2);
-				} else if ((j % 8 == 0)  ||
-					   (n == psd_scan->psd_stop_point)) {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							"%7d.0%d\n", psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.%d\n", psd_rep1,
-							   psd_rep2);
-				} else {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.0%d", psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.%d", psd_rep1,
-							   psd_rep2);
-				}
-
-				j++;
-				n++;
-				CL_PRINTF(cli_buf);
-
-			} while ((j <= 8) && (n <= psd_scan->psd_stop_point));
-
-			if ((m > psd_scan->psd_stop_point) ||
-			    (n > psd_scan->psd_stop_point))
-				break;
-
-			i = 1;
-			j = 1;
-		}
-	}
-
-
-}
-
-void halbtc8723b1ant_psd_max_holddata(IN struct btc_coexist *btcoexist,
-				      IN u32 gen_count)
-{
-	u32	i = 0, i_max = 0, val_max = 0;
-
-	if (gen_count == 1) {
-		memcpy(psd_scan->psd_report_max_hold,
-		       psd_scan->psd_report,
-		       BT_8723B_1ANT_ANTDET_PSD_POINTS * sizeof(u32));
-
-		psd_scan->psd_max_value_point = 0;
-		psd_scan->psd_max_value = 0;
-
-	} else {
-		for (i = psd_scan->psd_start_point;
-		     i <= psd_scan->psd_stop_point; i++) {
-			if (psd_scan->psd_report[i] >
-			    psd_scan->psd_report_max_hold[i])
-				psd_scan->psd_report_max_hold[i] =
-					psd_scan->psd_report[i];
-
-			/* search Max Value */
-			if (i == psd_scan->psd_start_point) {
-				i_max = i;
-				val_max = psd_scan->psd_report_max_hold[i];
-			} else {
-				if (psd_scan->psd_report_max_hold[i] >
-				    val_max) {
-					i_max = i;
-					val_max = psd_scan->psd_report_max_hold[i];
-				}
-			}
-
-		}
-
-		psd_scan->psd_max_value_point = i_max;
-		psd_scan->psd_max_value = val_max;
-
-	}
-
-
-}
-
-u32 halbtc8723b1ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)
-{
-	/* reg 0x808[9:0]: FFT data x */
-	/* reg 0x808[22]: 0-->1 to get 1 FFT data y */
-	/* reg 0x8b4[15:0]: FFT data y report */
-
-	u32 val = 0, psd_report = 0;
-	int k = 0;
-
-	val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-
-	val &= 0xffbffc00;
-	val |= point;
-
-	btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-	val |= 0x00400000;
-	btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-	while (1) {
-		if (k++ > BT_8723B_1ANT_ANTDET_SWEEPPOINT_DELAY)
-			break;
-	}
-
-	val = btcoexist->btc_read_4byte(btcoexist, 0x8b4);
-
-	psd_report = val & 0x0000ffff;
-
-	return psd_report;
-}
-
-
-boolean halbtc8723b1ant_psd_sweep_point(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN s32 offset, IN u32 span, IN u32 points,
-					IN u32 avgnum, IN u32 loopcnt)
-{
-	u32	 i, val, n, k = 0, j, point_index = 0;
-	u32	points1 = 0, psd_report = 0;
-	u32	start_p = 0, stop_p = 0, delta_freq_per_point = 156250;
-	u32    psd_center_freq = 20 * 10 ^ 6;
-	boolean outloop = false, scan , roam, is_sweep_ok = true;
-	u8	 flag = 0;
-	u32	tmp;
-	u32	wifi_original_channel = 1;
-
-	psd_scan->is_psd_running = true;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx PSD Sweep Start!!\n");
-	BTC_TRACE(trace_buf);
-
-	do {
-		switch (flag) {
-		case 0:  /* Get PSD parameters */
-		default:
-
-			psd_scan->psd_band_width = 40 * 1000000;
-			psd_scan->psd_point = points;
-			psd_scan->psd_start_base = points / 2;
-			psd_scan->psd_avg_num = avgnum;
-			psd_scan->real_cent_freq = cent_freq;
-			psd_scan->real_offset = offset;
-			psd_scan->real_span = span;
-
-
-			points1 = psd_scan->psd_point;
-			delta_freq_per_point = psd_scan->psd_band_width /
-					       psd_scan->psd_point;
-
-			/* PSD point setup */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-			val &= 0xffff0fff;
-
-			switch (psd_scan->psd_point) {
-			case 128:
-				val |= 0x0;
-				break;
-			case 256:
-			default:
-				val |= 0x00004000;
-				break;
-			case 512:
-				val |= 0x00008000;
-				break;
-			case 1024:
-				val |= 0x0000c000;
-				break;
-			}
-
-			switch (psd_scan->psd_avg_num) {
-			case 1:
-				val |= 0x0;
-				break;
-			case 8:
-				val |= 0x00001000;
-				break;
-			case 16:
-				val |= 0x00002000;
-				break;
-			case 32:
-			default:
-				val |= 0x00003000;
-				break;
-			}
-			btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-			flag = 1;
-			break;
-		case 1:	  /* calculate the PSD point index from freq/offset/span */
-			psd_center_freq = psd_scan->psd_band_width / 2 +
-					  offset * (1000000);
-
-			start_p = psd_scan->psd_start_base + (psd_center_freq -
-				span * (1000000) / 2) / delta_freq_per_point;
-			psd_scan->psd_start_point = start_p -
-						    psd_scan->psd_start_base;
-
-			stop_p = psd_scan->psd_start_base + (psd_center_freq +
-				span * (1000000) / 2) / delta_freq_per_point;
-			psd_scan->psd_stop_point = stop_p -
-						   psd_scan->psd_start_base - 1;
-
-			flag = 2;
-			break;
-		case 2:  /* set RF channel/BW/Mode */
-
-			/* set 3-wire off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x88c);
-			val |= 0x00300000;
-			btcoexist->btc_write_4byte(btcoexist, 0x88c, val);
-
-			/* CCK off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x800);
-			val &= 0xfeffffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x800, val);
-
-			/* store WiFi original channel */
-			wifi_original_channel = btcoexist->btc_get_rf_reg(
-					btcoexist, BTC_RF_A, 0x18, 0x3ff);
-
-			/* Set RF channel */
-			if (cent_freq == 2484)
-				btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A,
-							  0x18, 0x3ff, 0xe);
-			else
-				btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A,
-					  0x18, 0x3ff, (cent_freq - 2412) / 5 +
-						  1); /* WiFi TRx Mask on */
-
-
-			/* Set RF Rx filter corner */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-						  0xfffff, 0x3e4);
-
-			/* Set TRx mask off */
-			/* un-lock TRx Mask setup */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdd,
-						  0x80, 0x1);
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdf,
-						  0x1, 0x1);
-
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x0);
-
-			/* Set  RF mode = Rx, RF Gain = 0x8a0 */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x0,
-						  0xfffff, 0x308a0);
-
-			while (1) {
-				if (k++ > BT_8723B_1ANT_ANTDET_SWEEPPOINT_DELAY)
-					break;
-			}
-			flag = 3;
-			break;
-		case 3:
-			psd_scan->psd_gen_count = 0;
-			for (j = 1; j <= loopcnt; j++) {
-
-				btcoexist->btc_get(btcoexist,
-						   BTC_GET_BL_WIFI_SCAN, &scan);
-				btcoexist->btc_get(btcoexist,
-						   BTC_GET_BL_WIFI_ROAM, &roam);
-
-				if (scan || roam) {
-					is_sweep_ok = false;
-					break;
-				}
-				memset(psd_scan->psd_report, 0,
-				       psd_scan->psd_point * sizeof(u32));
-				start_p = psd_scan->psd_start_point +
-					  psd_scan->psd_start_base;
-				stop_p = psd_scan->psd_stop_point +
-					 psd_scan->psd_start_base + 1;
-
-				i = start_p;
-				point_index = 0;
-
-				while (i < stop_p) {
-					if (i >= points1)
-						psd_report =
-							halbtc8723b1ant_psd_getdata(
-							btcoexist, i - points1);
-					else
-						psd_report =
-							halbtc8723b1ant_psd_getdata(
-								btcoexist, i);
-
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"Point=%d, psd_raw_data = 0x%08x\n",
-						    i, psd_report);
-					BTC_TRACE(trace_buf);
-					if (psd_report == 0)
-						tmp = 0;
-					else
-						/* tmp =  20*log10((double)psd_report); */
-						/* 20*log2(x)/log2(10), log2Base return theresult of the psd_report*100 */
-						tmp = 6 * halbtc8723b1ant_psd_log2base(
-							btcoexist, psd_report);
-
-					n = i - psd_scan->psd_start_base;
-					psd_scan->psd_report[n] =  tmp;
-
-
-					halbtc8723b1ant_psd_max_holddata(
-						btcoexist, j);
-
-					i++;
-
-				}
-
-				psd_scan->psd_gen_count = j;
-			}
-
-			flag = 100;
-			break;
-		case 99:	/* error */
-
-			outloop = true;
-			break;
-		case 100: /* recovery */
-
-			/* set 3-wire on */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x88c);
-			val &= 0xffcfffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x88c, val);
-
-			/* CCK on */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x800);
-			val |= 0x01000000;
-			btcoexist->btc_write_4byte(btcoexist, 0x800, val);
-
-			/* PSD off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-			val &= 0xffbfffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-			/* TRx Mask on */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x780);
-
-			/* lock TRx Mask setup */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdd,
-						  0x80, 0x0);
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xdf,
-						  0x1, 0x0);
-
-			/* Set RF Rx filter corner */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-						  0xfffff, 0x0);
-
-			/* restore WiFi original channel */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x18,
-						  0x3ff, wifi_original_channel);
-
-			outloop = true;
-			break;
-
-		}
-
-	} while (!outloop);
-
-
-
-	psd_scan->is_psd_running = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx PSD Sweep Stop!!\n");
-	BTC_TRACE(trace_buf);
-	return is_sweep_ok;
-
-}
-
-void halbtc8723b1ant_psd_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 bt_tx_time, IN u32 bt_le_channel)
-{
-	u32	i = 0;
-	u32	wlpsd_cent_freq = 2484, wlpsd_span = 2, wlpsd_sweep_count = 50;
-	s32	wlpsd_offset = -4;
-	u8	bt_le_ch[13] = {3, 6, 8, 11, 13, 16, 18, 21, 23, 26, 28, 31, 33};
-
-	u8	h2c_parameter[3] = {0}, u8tmpa, u8tmpb;
-
-	u8	state = 0;
-	boolean		outloop = false, bt_resp = false;
-	u32		freq, freq1, freq2, psd_rep1, psd_rep2, delta_freq_per_point,
-			u32tmp;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	board_info->btdm_ant_det_finish = false;
-	memset(psd_scan->ant_det_peak_val, 0, 16 * sizeof(u8));
-	memset(psd_scan->ant_det_peak_freq, 0, 16 * sizeof(u8));
-
-	if (board_info->tfbga_package) /* for TFBGA */
-		psd_scan->ant_det_thres_offset = 5;
-	else
-		psd_scan->ant_det_thres_offset = 0;
-
-	do {
-		switch (state) {
-		case 0:
-			if (bt_le_channel == 39)
-				wlpsd_cent_freq = 2484;
-			else {
-				for (i = 1; i <= 13; i++) {
-					if (bt_le_ch[i - 1] ==
-					    bt_le_channel) {
-						wlpsd_cent_freq = 2412
-								  + (i - 1) * 5;
-						break;
-					}
-				}
-
-				if (i == 14) {
-
-					BTC_SPRINTF(trace_buf,
-						    BT_TMP_BUF_SIZE,
-						"xxxxxxxxxxxxxxxx AntennaDetect(), Abort!!, Invalid LE channel = %d\n ",
-						    bt_le_channel);
-					BTC_TRACE(trace_buf);
-					outloop = true;
-					break;
-				}
-			}
-
-			wlpsd_sweep_count = bt_tx_time * 238 /
-					    100; /* bt_tx_time/0.42								 */
-			wlpsd_sweep_count = wlpsd_sweep_count / 5;
-
-			if (wlpsd_sweep_count % 5 != 0)
-				wlpsd_sweep_count = (wlpsd_sweep_count /
-						     5 + 1) * 5;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), BT_LETxTime=%d,  BT_LECh = %d\n",
-				    bt_tx_time, bt_le_channel);
-			BTC_TRACE(trace_buf);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), wlpsd_cent_freq=%d,  wlpsd_offset = %d, wlpsd_span = %d, wlpsd_sweep_count = %d\n",
-				    wlpsd_cent_freq,
-				    wlpsd_offset,
-				    wlpsd_span,
-				    wlpsd_sweep_count);
-			BTC_TRACE(trace_buf);
-
-			state = 1;
-			break;
-		case 1: /* stop coex DM & set antenna path */
-			/* Stop Coex DM */
-
-			/*
-			btcoexist->stop_coex_dm = true;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Stop Coex DM!!\n");
-			BTC_TRACE(trace_buf);  */
-
-			/* Set TDMA off,				 */
-			halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC,
-						false, 0);
-
-			/* Set coex table */
-			halbtc8723b1ant_coex_table_with_type(btcoexist,
-							     FORCE_EXEC, 0);
-
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Main Port\n");
-				BTC_TRACE(trace_buf);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Aux Port\n");
-				BTC_TRACE(trace_buf);
-			}
-
-			/* Set Antenna path, switch WiFi to un-certain antenna port */
-			halbtc8723b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_BT, FORCE_EXEC, false,
-						     false);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to BT!!\n");
-			BTC_TRACE(trace_buf);
-
-			/* Set AFH mask on at WiFi channel 2472MHz +/- 10MHz */
-			h2c_parameter[0] = 0x1;
-			h2c_parameter[1] = 0xd;
-			h2c_parameter[2] = 0x14;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-				    h2c_parameter[1],
-				    h2c_parameter[2]);
-			BTC_TRACE(trace_buf);
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x66, 3,
-						h2c_parameter);
-
-			u32tmp = btcoexist->btc_read_4byte(btcoexist,
-							   0x948);
-			u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-			u8tmpb = btcoexist->btc_read_1byte(btcoexist,
-							   0x778);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x778=0x%x\n",
-				    u32tmp,  u8tmpa, u8tmpb);
-			BTC_TRACE(trace_buf);
-
-			state = 2;
-			break;
-		case 2:	/* Pre-sweep background psd */
-			if (!halbtc8723b1ant_psd_sweep_point(btcoexist,
-				     wlpsd_cent_freq, wlpsd_offset, wlpsd_span,
-					     BT_8723B_1ANT_ANTDET_PSD_POINTS,
-				     BT_8723B_1ANT_ANTDET_PSD_AVGNUM, 3)) {
-				board_info->btdm_ant_det_finish = false;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 8;
-				state = 99;
-				break;
-			}
-
-			psd_scan->ant_det_pre_psdscan_peak_val =
-				psd_scan->psd_max_value;
-
-			if (psd_scan->psd_max_value >
-			    (BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND
-			     + psd_scan->ant_det_thres_offset) * 100) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Abort Antenna Detection!! becaus background = %d > thres (%d)\n",
-					    psd_scan->psd_max_value / 100,
-					BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND
-					    + psd_scan->ant_det_thres_offset);
-				BTC_TRACE(trace_buf);
-				board_info->btdm_ant_det_finish = false;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 5;
-				state = 99;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Start Antenna Detection!! becaus background = %d <= thres (%d)\n",
-					    psd_scan->psd_max_value / 100,
-					BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND
-					    + psd_scan->ant_det_thres_offset);
-				BTC_TRACE(trace_buf);
-				state = 3;
-			}
-			break;
-		case 3:
-			bt_resp = btcoexist->btc_set_bt_ant_detection(
-					  btcoexist, (u8)(bt_tx_time & 0xff),
-					  (u8)(bt_le_channel & 0xff));
-
-			if (!halbtc8723b1ant_psd_sweep_point(btcoexist,
-					     wlpsd_cent_freq, wlpsd_offset,
-							     wlpsd_span,
-					     BT_8723B_1ANT_ANTDET_PSD_POINTS,
-					     BT_8723B_1ANT_ANTDET_PSD_AVGNUM,
-						     wlpsd_sweep_count)) {
-				board_info->btdm_ant_det_finish = false;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 8;
-				state = 99;
-				break;
-			}
-
-			psd_scan->ant_det_psd_scan_peak_val =
-				psd_scan->psd_max_value;
-			psd_scan->ant_det_psd_scan_peak_freq =
-				psd_scan->psd_max_value_point;
-			state = 4;
-			break;
-		case 4:
-
-			if (psd_scan->psd_point == 0)
-				delta_freq_per_point = 0;
-			else
-				delta_freq_per_point =
-					psd_scan->psd_band_width /
-					psd_scan->psd_point;
-
-			psd_rep1 = psd_scan->psd_max_value / 100;
-			psd_rep2 = psd_scan->psd_max_value - psd_rep1 *
-				   100;
-
-			freq = ((psd_scan->real_cent_freq - 20) *
-				1000000 + psd_scan->psd_max_value_point
-				* delta_freq_per_point);
-			freq1 = freq / 1000000;
-			freq2 = freq / 1000 - freq1 * 1000;
-
-			if (freq2 < 100) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.0%d MHz",
-					    freq1, freq2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_freq,
-					   BT_8723B_1ANT_ANTDET_BUF_LEN,
-					   "%d.0%d", freq1, freq2);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.%d MHz",
-					    freq1, freq2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_freq,
-					   BT_8723B_1ANT_ANTDET_BUF_LEN,
-					   "%d.%d", freq1, freq2);
-			}
-
-			if (psd_rep2 < 10) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    ", Value = %d.0%d dB\n",
-					    psd_rep1, psd_rep2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_val,
-					   BT_8723B_1ANT_ANTDET_BUF_LEN,
-					   "%d.0%d", psd_rep1, psd_rep2);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    ", Value = %d.%d dB\n",
-					    psd_rep1, psd_rep2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_val,
-					   BT_8723B_1ANT_ANTDET_BUF_LEN,
-					   "%d.%d", psd_rep1, psd_rep2);
-			}
-
-			psd_scan->ant_det_is_btreply_available = true;
-
-			if (bt_resp == false) {
-				psd_scan->ant_det_is_btreply_available =
-					false;
-				psd_scan->ant_det_result = 0;
-				board_info->btdm_ant_det_finish = false;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), BT Response = Fail\n ");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->psd_max_value >
-				(BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION)
-				   * 100) {
-				psd_scan->ant_det_result = 1;
-				board_info->btdm_ant_det_finish = true;
-				board_info->btdm_ant_det_already_init_phydm =
-					true;
-				board_info->btdm_ant_num_by_ant_det = 2;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Bad-Isolation!!\n");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->psd_max_value >
-				(BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-				    + psd_scan->ant_det_thres_offset) * 100) {
-				psd_scan->ant_det_result = 2;
-				board_info->btdm_ant_det_finish = true;
-				board_info->btdm_ant_det_already_init_phydm =
-					true;
-				board_info->btdm_ant_num_by_ant_det = 2;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Good-Isolation!!\n");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->psd_max_value >
-				   (BT_8723B_1ANT_ANTDET_PSDTHRES_1ANT) *
-				   100) {
-				psd_scan->ant_det_result = 3;
-				board_info->btdm_ant_det_finish = true;
-				board_info->btdm_ant_det_already_init_phydm =
-					true;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant!!\n");
-				BTC_TRACE(trace_buf);
-			} else {
-				psd_scan->ant_det_result = 4;
-				board_info->btdm_ant_det_finish = false;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant, un-certainity!!\n");
-				BTC_TRACE(trace_buf);
-			}
-
-			state = 99;
-			break;
-		case 99:  /* restore setup */
-
-			/* Set AFH mask off at WiFi channel 2472MHz +/- 10MHz */
-			h2c_parameter[0] = 0x0;
-			h2c_parameter[1] = 0x0;
-			h2c_parameter[2] = 0x0;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-				    h2c_parameter[1], h2c_parameter[2]);
-			BTC_TRACE(trace_buf);
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x66, 3,
-						h2c_parameter);
-
-			/* Set Antenna Path					 */
-			halbtc8723b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_PTA, FORCE_EXEC, false,
-						     false);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to PTA\n!!");
-			BTC_TRACE(trace_buf);
-
-			/* Resume Coex DM */
-			/*
-			btcoexist->stop_coex_dm = false;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Resume Coex DM\n!!");
-			BTC_TRACE(trace_buf); */
-
-			/* stimulate coex running */
-			/*
-			halbtc8723b1ant_run_coexist_mechanism(
-				btcoexist);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Stimulate Coex running\n!!");
-			BTC_TRACE(trace_buf);
-			*/
-
-			outloop = true;
-			break;
-		}
-
-	} while (!outloop);
-
-
-
-}
-
-void halbtc8723b1ant_psd_antenna_detection_check(IN struct btc_coexist
-		*btcoexist)
-{
-	static u32 ant_det_count = 0, ant_det_fail_count = 0;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	boolean scan, roam;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-
-	/* psd_scan->ant_det_bt_tx_time = 20; */
-	psd_scan->ant_det_bt_tx_time =
-		BT_8723B_1ANT_ANTDET_BTTXTIME;	   /* 0.42ms*50 = 20ms (0.42ms = 1 PSD sweep) */
-	psd_scan->ant_det_bt_le_channel = BT_8723B_1ANT_ANTDET_BTTXCHANNEL;
-
-	ant_det_count++;
-
-	psd_scan->ant_det_try_count = ant_det_count;
-
-	if (scan || roam) {
-		board_info->btdm_ant_det_finish = false;
-		psd_scan->ant_det_result = 6;
-	} else if (coex_sta->bt_disabled) {
-		board_info->btdm_ant_det_finish = false;
-		psd_scan->ant_det_result = 11;
-	} else if (coex_sta->num_of_profile >= 1) {
-		board_info->btdm_ant_det_finish = false;
-		psd_scan->ant_det_result = 7;
-	} else if (
-		!psd_scan->ant_det_is_ant_det_available) { /* Antenna initial setup is not ready */
-		board_info->btdm_ant_det_finish = false;
-		psd_scan->ant_det_result = 9;
-	} else if (coex_sta->c2h_bt_inquiry_page) {
-		board_info->btdm_ant_det_finish = false;
-		psd_scan->ant_det_result = 10;
-	} else {
-		btcoexist->stop_coex_dm = true;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"xxxxxxxxxxxxxxxx AntennaDetect(), Stop Coex DM!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8723b1ant_psd_antenna_detection(btcoexist,
-					      psd_scan->ant_det_bt_tx_time,
-					      psd_scan->ant_det_bt_le_channel);
-
-		delay_ms(psd_scan->ant_det_bt_tx_time);
-
-		btcoexist->stop_coex_dm = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"xxxxxxxxxxxxxxxx AntennaDetect(), Resume Coex DM\n!!");
-		BTC_TRACE(trace_buf);
-
-		/* stimulate coex running */
-
-		halbtc8723b1ant_run_coexist_mechanism(
-			btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"xxxxxxxxxxxxxxxx AntennaDetect(), Stimulate Coex running\n!!");
-		BTC_TRACE(trace_buf);
-	}
-
-	board_info->ant_det_result = psd_scan->ant_det_result;
-	if (!board_info->btdm_ant_det_finish)
-		ant_det_fail_count++;
-
-	psd_scan->ant_det_fail_count = ant_det_fail_count;
-
-}
-
-
-/* ************************************************************
- * work around function start with wa_halbtc8723b1ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8723b1ant_
- * ************************************************************ */
-void ex_halbtc8723b1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8				u8tmp = 0x0;
-	u16				u16tmp = 0x0;
-	u32				value;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx Execute 8723b 1-Ant PowerOn Setting xxxxxxxxxxxxxxxx!!\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "Ant Det Finish = %s, Ant Det Number  = %d\n",
-		    (board_info->btdm_ant_det_finish ? "Yes" : "No"),
-		    board_info->btdm_ant_num_by_ant_det);
-	BTC_TRACE(trace_buf);
-
-
-	btcoexist->stop_coex_dm = true;
-
-	btcoexist->btc_write_1byte(btcoexist, 0x67, 0x20);
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly. */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-	/* set GRAN_BT = 1 */
-	btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18);
-	/* set WLAN_ACT = 0 */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	/* */
-	/* S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info) */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-	if (btcoexist->chip_interface == BTC_INTF_USB) {
-		/* fixed at S0 for USB interface */
-		btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0);
-
-		u8tmp |= 0x1;	/* antenna inverse */
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-	} else {
-		/* for PCIE and SDIO interface, we check efuse 0xc3[6] */
-		if (board_info->single_ant_path == 0) {
-			/* set to S1 */
-			btcoexist->btc_write_4byte(btcoexist, 0x948, 0x280);
-			board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-			value = 1;
-		} else if (board_info->single_ant_path == 1) {
-			/* set to S0 */
-			btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0);
-			u8tmp |= 0x1;	/* antenna inverse */
-			board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-			value = 0;
-		}
-
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
-				   &value);
-
-		if (btcoexist->chip_interface == BTC_INTF_PCI)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x384,
-							     u8tmp);
-		else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60,
-							     u8tmp);
-	}
-}
-
-void ex_halbtc8723b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8723b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8723b1ant_init_hw_config(btcoexist, true, wifi_only);
-	btcoexist->stop_coex_dm = false;
-}
-
-void ex_halbtc8723b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->stop_coex_dm = false;
-
-	halbtc8723b1ant_init_coex_dm(btcoexist);
-
-	halbtc8723b1ant_query_bt_info(btcoexist);
-}
-
-void ex_halbtc8723b1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0;
-	u32				bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0;
-	u32				phyver = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d",
-			   "Ant PG Num/ Mech/ Pos",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   board_info->btdm_ant_pos);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %d  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   board_info->btdm_ant_pos,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-		if (board_info->btdm_ant_det_finish) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-				   "Ant Det PSD Value",
-				   psd_scan->ant_det_peak_val);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	if (board_info->ant_det_result_five_complete) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d",
-			   "Ant number by AntDet",
-			   board_info->btdm_ant_num_by_ant_det);
-		CL_PRINTF(cli_buf);
-	}
-
-	/* btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver); */
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-	bt_coex_ver = ((coex_sta->bt_coex_supported_version & 0xff00) >> 8);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8723b_1ant, glcoex_ver_8723b_1ant,
-		   glcoex_ver_btdesired_8723b_1ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (bt_coex_ver >= glcoex_ver_btdesired_8723b_1ant ?
-		     "Match" : "Mis-Match")));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s",
-		   "WifibHiPri/ Ccklock/ CckEverLock",
-		   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-		   (coex_sta->cck_lock ? "Yes" : "No"),
-		   (coex_sta->cck_ever_lock ? "Yes" : "No"));
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Abnormal scan",
-		   (coex_sta->bt_abnormal_scan) ? "Yes" : "No");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d / %d / %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP/NameReq/WHQL",
-		   bt_link_info->sco_exist, bt_link_info->hid_exist,
-		   bt_link_info->pan_exist, bt_link_info->a2dp_exist,
-		   coex_sta->c2h_bt_remote_name_req,
-		   coex_sta->bt_whck_test);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Role",
-		   (bt_link_info->slave_role) ? "Slave" : "Master");
-	CL_PRINTF(cli_buf);
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d",
-		   "A2DP Rate/Bitpool",
-		(bt_info_ext & BIT(0)) ? "BR" : "EDR", coex_sta->a2dp_bit_pool);
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8723B_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8723b_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[mechanisms] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[mechanisms]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "SM[LowPenaltyRA]",
-		   coex_dm->cur_low_penalty_ra);
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	if (board_info->btdm_ant_num_by_ant_det == 2) {
-		if (coex_dm->cur_ps_tdma_on)
-			ps_tdma_case = ps_tdma_case +
-				100; /* for WiFi RSSI low or BT RSSI low */
-		else
-			ps_tdma_case =
-				1; /* always translate to TDMA(off,1) for TDMA-off case */
-	}
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)",
-		   "PS TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "On" : "Off"),
-		   (coex_dm->auto_tdma_adjust ? "Adj" : "Fix"));
-
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Coex Table Type",
-		   coex_sta->coex_table_type);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "IgnWlanAct",
-		   coex_dm->cur_ignore_wlan_act);
-	CL_PRINTF(cli_buf);
-
-	/*
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Latest error condition(should be 0)",
-		coex_dm->error_condition);
-	CL_PRINTF(cli_buf);
-	*/
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "backup ARFR1/ARFR2/RL/AMaxTime",
-		   coex_dm->backup_arfr_cnt1, coex_dm->backup_arfr_cnt2,
-		   coex_dm->backup_retry_limit,
-		   coex_dm->backup_ampdu_max_time);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
-	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x456);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "0x430/0x434/0x42a/0x456",
-		   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6cc);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x880);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x778/0x6cc/0x880[29:25]",
-		   u8tmp[0], u32tmp[0], (u32tmp[1] & 0x3e000000) >> 25);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x948);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x67);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x764);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x948/ 0x67[5] / 0x764 / 0x76e",
-		   u32tmp[0], ((u8tmp[0] & 0x20) >> 5), (u32tmp[1] & 0xffff),
-		   u8tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x92c);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x930);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x944);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x92c[1:0]/ 0x930[7:0]/0x944[1:0]",
-		   u32tmp[0] & 0x3, u32tmp[1] & 0xff, u32tmp[2] & 0x3);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x39);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x64);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x38[11]/0x40/0x4c[24:23]/0x64[0]",
-		   ((u8tmp[0] & 0x8) >> 3), u8tmp[1],
-		   ((u32tmp[0] & 0x01800000) >> 23), u8tmp[2] & 0x1);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x49c);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0xc50(dig)/0x49c(null-drop)",
-		   u32tmp[0] & 0xff, u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11n-agg",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(high-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(low-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8723B_1ANT == 1)
-	/* halbtc8723b1ant_monitor_bt_ctr(btcoexist); */
-#endif
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8723b1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = true;
-
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, false, true);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8723b1ant_init_hw_config(btcoexist, false, false);
-		halbtc8723b1ant_init_coex_dm(btcoexist);
-		halbtc8723b1ant_query_bt_info(btcoexist);
-
-		coex_sta->under_ips = false;
-	}
-}
-
-void ex_halbtc8723b1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = true;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8723b1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	u8 u8tmpa, u8tmpb;
-	u32 u32tmp;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_SCAN_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-		psd_scan->ant_det_is_ant_det_available = true;
-		halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     FORCE_EXEC, false, false);
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948);
-		u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-		u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x67);
-
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x\n",
-			    u32tmp,  u8tmpa, u8tmpb);
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-	}
-
-	if (coex_sta->bt_disabled)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	halbtc8723b1ant_query_bt_info(btcoexist);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8723b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8723b1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8723b1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8723b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8723b1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_SCAN_START == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8723b1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		else	/* wifi is connected */
-			halbtc8723b1ant_action_wifi_connected_scan(btcoexist);
-	} else if (BTC_SCAN_FINISH == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8723b1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8723b1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-void ex_halbtc8723b1ant_set_antenna_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (type == 2) /* two antenna */
-		halbtc8723b1ant_mechanism_switch(btcoexist, true);
-	else /* one antenna */
-		halbtc8723b1ant_mechanism_switch(btcoexist, false);
-}
-
-void ex_halbtc8723b1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	boolean	wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_ASSOCIATE_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		psd_scan->ant_det_is_ant_det_available = true;
-		halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     FORCE_EXEC, false, false);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-		/* coex_dm->arp_cnt = 0; */
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8723b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8723b1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8723b1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8723b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8723b1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_ASSOCIATE_START == type)
-		halbtc8723b1ant_action_wifi_not_connected_asso_auth(btcoexist);
-	else if (BTC_ASSOCIATE_FINISH == type) {
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-				   &wifi_connected);
-		if (!wifi_connected) /* non-connected scan */
-			halbtc8723b1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8723b1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-void ex_halbtc8723b1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	boolean			wifi_under_b_mode = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     FORCE_EXEC, false, false);
-		psd_scan->ant_det_is_ant_det_available = true;
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-				   &wifi_under_b_mode);
-
-		/* Set CCK Tx/Rx high Pri except 11b mode */
-		if (wifi_under_b_mode) {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x00); /* CCK Rx */
-		} else {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x10); /* CCK Rx */
-		}
-
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-
-		coex_sta->cck_ever_lock = false;
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		/* h2c_parameter[0] = 0x1; */
-		h2c_parameter[0] = 0x0;
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-}
-
-void ex_halbtc8723b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean	bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false, under_4way = false;
-	u8	agg_buf_size = 5;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    BTC_PACKET_ARP == type) {
-		if (BTC_PACKET_ARP == type) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], specific Packet ARP notify\n");
-			BTC_TRACE(trace_buf);
-
-			coex_dm->arp_cnt++;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], ARP Packet Count = %d\n",
-				    coex_dm->arp_cnt);
-			BTC_TRACE(trace_buf);
-
-			if ((coex_dm->arp_cnt >= 10) &&
-			    (!under_4way))  /* if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecificPacket(btcoexist) */
-				coex_sta->wifi_is_high_pri_task = false;
-			else
-				coex_sta->wifi_is_high_pri_task = true;
-		} else {
-			coex_sta->wifi_is_high_pri_task = true;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], specific Packet DHCP or EAPOL notify\n");
-			BTC_TRACE(trace_buf);
-		}
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet [Type = %d] notify\n", type);
-		BTC_TRACE(trace_buf);
-	}
-
-	coex_sta->specific_pkt_period_cnt = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8723b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8723b1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8723b1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8723b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8723b1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    ((BTC_PACKET_ARP == type) && (coex_sta->wifi_is_high_pri_task)))
-		halbtc8723b1ant_action_wifi_connected_specific_packet(
-			btcoexist);
-}
-
-/* Donot remove optimize off flag, otherwise antenna detection would trigger BT collapsed */
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-void ex_halbtc8723b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8				bt_info = 0;
-	u8				i, rsp_source = 0;
-	boolean				wifi_connected = false;
-	boolean				bt_busy = false;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	coex_sta->c2h_bt_info_req_sent = false;
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8723B_1ANT_MAX)
-		rsp_source = BT_INFO_SRC_8723B_1ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	/* if 0xff, it means BT is under WHCK test */
-	if (bt_info == 0xff)
-		coex_sta->bt_whck_test = true;
-	else
-		coex_sta->bt_whck_test = false;
-
-	if (BT_INFO_SRC_8723B_1ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->bt_info_c2h[rsp_source][2] & 0x20)
-			coex_sta->c2h_bt_remote_name_req = true;
-		else
-			coex_sta->c2h_bt_remote_name_req = false;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 - 90;
-		/* coex_sta->bt_info_c2h[rsp_source][3]*2+10; */
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		if ((coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) {
-			coex_sta->a2dp_bit_pool =
-				coex_sta->bt_info_c2h[rsp_source][6] & 0x7f;
-		} else
-			coex_sta->a2dp_bit_pool = 0;
-
-		coex_sta->bt_tx_rx_mask = (coex_sta->bt_info_c2h[rsp_source][2]
-					   & 0x40);
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TX_RX_MASK,
-				   &coex_sta->bt_tx_rx_mask);
-
-		if (btcoexist->stop_coex_dm) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex], BT info Notify() return because stop_coex_dm\n");
-			BTC_TRACE(trace_buf);
-
-			return;
-		}
-
-
-#if BT_8723B_1ANT_ANTDET_ENABLE
-#if BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE
-		if ((board_info->btdm_ant_det_finish) &&
-		    (board_info->btdm_ant_num_by_ant_det == 2)) {
-			if (coex_sta->bt_tx_rx_mask) {
-
-				/* BT TRx mask off */
-				btcoexist->btc_set_bt_trx_mask(btcoexist, 0);
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"############# [BTCoex], BT TRx Mask off for BT Info Notify\n");
-				BTC_TRACE(trace_buf);
-#if 0
-				/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x1\n");
-				BTC_TRACE(trace_buf);
-
-				/* BT TRx Mask un-lock 0x2c[0], 0x30[0] = 1 */
-				btcoexist->btc_set_bt_reg(btcoexist,
-						  BTC_BT_REG_RF, 0x2c, 0x7c45);
-				btcoexist->btc_set_bt_reg(btcoexist,
-						  BTC_BT_REG_RF, 0x30, 0x7c45);
-
-				btcoexist->btc_set_bt_reg(btcoexist,
-						  BTC_BT_REG_RF, 0x3c, 0x1);
-#endif
-			}
-		} else
-#endif
-#endif
-
-		{
-			if (!coex_sta->bt_tx_rx_mask) {
-
-				/* BT TRx mask on */
-				btcoexist->btc_set_bt_trx_mask(btcoexist, 1);
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"############# [BTCoex], BT TRx Mask on for  BT Info Notify\n");
-				BTC_TRACE(trace_buf);
-#if 0
-				/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n");
-				BTC_TRACE(trace_buf);
-				btcoexist->btc_set_bt_reg(btcoexist,
-							  BTC_BT_REG_RF,
-							  0x3c, 0x15);
-
-				/* BT TRx Mask lock 0x2c[0], 0x30[0] = 0 */
-				btcoexist->btc_set_bt_reg(btcoexist,
-							  BTC_BT_REG_RF,
-							  0x2c, 0x7c44);
-				btcoexist->btc_set_bt_reg(btcoexist,
-							  BTC_BT_REG_RF,
-							  0x30, 0x7c44);
-#endif
-			}
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if (coex_sta->bt_info_ext & BIT(1)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-			if (wifi_connected)
-				ex_halbtc8723b1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8723b1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(3)) {
-			if (!btcoexist->manual_control &&
-			    !btcoexist->stop_coex_dm) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8723b1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, false);
-			}
-		} else {
-			/* BT already NOT ignore Wlan active, do nothing here. */
-		}
-#if (BT_AUTO_REPORT_ONLY_8723B_1ANT == 0)
-		if ((coex_sta->bt_info_ext & BIT(4))) {
-			/* BT auto report already enabled, do nothing */
-		} else
-			halbtc8723b1ant_bt_auto_report(btcoexist, FORCE_EXEC,
-						       true);
-#endif
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8723B_1ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	coex_sta->num_of_profile = 0;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8723B_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-
-		coex_sta->bt_hi_pri_link_exist = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8723B_1ANT_B_FTP) {
-			coex_sta->pan_exist = true;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8723B_1ANT_B_A2DP) {
-			coex_sta->a2dp_exist = true;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8723B_1ANT_B_HID) {
-			coex_sta->hid_exist = true;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8723B_1ANT_B_SCO_ESCO) {
-			coex_sta->sco_exist = true;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->sco_exist = false;
-
-		if ((coex_sta->hid_exist == false) &&
-		    (coex_sta->c2h_bt_inquiry_page == false) &&
-		    (coex_sta->sco_exist == false)) {
-			if (coex_sta->high_priority_tx  +
-			    coex_sta->high_priority_rx >= 160) {
-				coex_sta->hid_exist = true;
-				coex_sta->wrong_profile_notification++;
-				coex_sta->num_of_profile++;
-				bt_info = bt_info | 0x28;
-			}
-		}
-
-		/* Add Hi-Pri Tx/Rx counter to avoid false detection */
-		if (((coex_sta->hid_exist) || (coex_sta->sco_exist)) &&
-		    (coex_sta->high_priority_tx  +
-		     coex_sta->high_priority_rx >= 160)
-		    && (!coex_sta->c2h_bt_inquiry_page))
-			coex_sta->bt_hi_pri_link_exist = true;
-
-		if ((bt_info & BT_INFO_8723B_1ANT_B_ACL_BUSY) &&
-		    (coex_sta->num_of_profile == 0)) {
-			if (coex_sta->low_priority_tx  +
-			    coex_sta->low_priority_rx >= 160) {
-				coex_sta->pan_exist = true;
-				coex_sta->num_of_profile++;
-				coex_sta->wrong_profile_notification++;
-				bt_info = bt_info | 0x88;
-			}
-		}
-	}
-
-	halbtc8723b1ant_update_bt_link_info(btcoexist);
-
-	bt_info = bt_info &
-		0x1f;  /* mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41) */
-
-	if (!(bt_info & BT_INFO_8723B_1ANT_B_CONNECTION))
-		coex_dm->bt_status = BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-	else if (bt_info ==
-		BT_INFO_8723B_1ANT_B_CONNECTION)	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE;
-	else if ((bt_info & BT_INFO_8723B_1ANT_B_SCO_ESCO) ||
-		 (bt_info & BT_INFO_8723B_1ANT_B_SCO_BUSY))
-		coex_dm->bt_status = BT_8723B_1ANT_BT_STATUS_SCO_BUSY;
-	else if (bt_info & BT_INFO_8723B_1ANT_B_ACL_BUSY) {
-		if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY != coex_dm->bt_status)
-			coex_dm->auto_tdma_adjust = false;
-		coex_dm->bt_status = BT_8723B_1ANT_BT_STATUS_ACL_BUSY;
-	} else
-		coex_dm->bt_status = BT_8723B_1ANT_BT_STATUS_MAX;
-
-	if ((BT_8723B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8723B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = true;
-	else
-		bt_busy = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	halbtc8723b1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8723b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u32	u32tmp;
-	u8	u8tmpa, u8tmpb, u8tmpc;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = false;
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, false, true);
-
-		halbtc8723b1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-		btcoexist->stop_coex_dm = true;
-
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948);
-		u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-		u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x67);
-		u8tmpc = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x67=0x%x, 0x76e=0x%x\n",
-			    u32tmp,  u8tmpa, u8tmpb, u8tmpc);
-		BTC_TRACE(trace_buf);
-
-	}
-}
-
-void ex_halbtc8723b1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8723b1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-	halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, FORCE_EXEC,
-				     false, true);
-
-	halbtc8723b1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-
-	ex_halbtc8723b1ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	btcoexist->stop_coex_dm = true;
-}
-
-void ex_halbtc8723b1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	if (BTC_WIFI_PNP_SLEEP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8723b1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8723b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, false, true);
-		halbtc8723b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-		/* Sinda 20150819, workaround for driver skip leave IPS/LPS to speed up sleep time. */
-		/* Driver do not leave IPS/LPS when driver is going to sleep, so BTCoexistence think wifi is still under IPS/LPS */
-		/* BT should clear UnderIPS/UnderLPS state to avoid mismatch state after wakeup. */
-		coex_sta->under_ips = false;
-		coex_sta->under_lps = false;
-		btcoexist->stop_coex_dm = true;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = false;
-		halbtc8723b1ant_init_hw_config(btcoexist, false, false);
-		halbtc8723b1ant_init_coex_dm(btcoexist);
-		halbtc8723b1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8723b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8723b1ant_init_hw_config(btcoexist, false, false);
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); */
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x2, 0xfffff, 0x0); */
-	halbtc8723b1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8723b1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	u32 bt_patch_ver;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ==========================Periodical===========================\n");
-	BTC_TRACE(trace_buf);
-
-#if (BT_AUTO_REPORT_ONLY_8723B_1ANT == 0)
-	halbtc8723b1ant_query_bt_info(btcoexist);
-#endif
-	halbtc8723b1ant_monitor_bt_ctr(btcoexist);
-	halbtc8723b1ant_monitor_wifi_ctr(btcoexist);
-
-	halbtc8723b1ant_monitor_bt_enable_disable(btcoexist);
-
-
-	if (halbtc8723b1ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust ||
-	    btcoexist->bt_info.bt_enable_disable_change)
-		halbtc8723b1ant_run_coexist_mechanism(btcoexist);
-
-	if (((coex_sta->bt_coex_supported_version == 0) ||
-	     (coex_sta->bt_coex_supported_version == 0xffff)) && (!coex_sta->bt_disabled))
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION, &coex_sta->bt_coex_supported_version);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-	coex_sta->specific_pkt_period_cnt++;
-
-	/* sample to set bt to execute Ant detection */
-	/* btcoexist->btc_set_bt_ant_detection(btcoexist, 20, 14);
-	*
-	if (psd_scan->is_ant_det_enable)
-	{
-		 if (psd_scan->psd_gen_count > psd_scan->realseconds)
-			psd_scan->psd_gen_count = 0;
-
-		halbtc8723b1ant_antenna_detection(btcoexist, psd_scan->realcent_freq,  psd_scan->realoffset, psd_scan->realspan,  psd_scan->realseconds);
-		psd_scan->psd_gen_total_count +=2;
-		psd_scan->psd_gen_count += 2;
-	}
-	*/
-}
-
-/* Donot remove optimize off flag, otherwise antenna detection would trigger BT collapsed */
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-void ex_halbtc8723b1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-#if BT_8723B_1ANT_ANTDET_ENABLE
-	static u32 ant_det_count = 0, ant_det_fail_count = 0;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	/*boolean scan, roam;*/
-
-	if (seconds == 0) {
-		psd_scan->ant_det_try_count	= 0;
-		psd_scan->ant_det_fail_count	= 0;
-		ant_det_count = 0;
-		ant_det_fail_count = 0;
-		board_info->btdm_ant_det_finish = false;
-		board_info->btdm_ant_num_by_ant_det = 1;
-		return;
-	}
-
-	if (!board_info->btdm_ant_det_finish) {
-		psd_scan->ant_det_inteval_count =
-			psd_scan->ant_det_inteval_count + 2;
-
-		if (psd_scan->ant_det_inteval_count >=
-		    BT_8723B_1ANT_ANTDET_RETRY_INTERVAL) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is up, Try Detect!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b1ant_psd_antenna_detection_check(btcoexist);
-
-			if (board_info->btdm_ant_det_finish) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Success!!\n");
-				BTC_TRACE(trace_buf);
-
-
-#if 1
-				if (board_info->btdm_ant_num_by_ant_det == 2)
-					halbtc8723b1ant_mechanism_switch(
-						btcoexist, true);
-				else
-					halbtc8723b1ant_mechanism_switch(
-						btcoexist, false);
-#endif
-
-				board_info->btdm_ant_det_complete_fail = false;
-
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Fail!!\n");
-				BTC_TRACE(trace_buf);
-
-				board_info->btdm_ant_det_complete_fail = true;
-			}
-			psd_scan->ant_det_inteval_count = 0;
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is not up! (%d)\n",
-				    psd_scan->ant_det_inteval_count);
-			BTC_TRACE(trace_buf);
-		}
-
-	}
-#endif
-
-
-	/*
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-
-			psd_scan->ant_det_bt_tx_time = seconds;
-		psd_scan->ant_det_bt_le_channel = cent_freq;
-
-		if (seconds == 0)
-			{
-			psd_scan->ant_det_try_count	= 0;
-			psd_scan->ant_det_fail_count	= 0;
-			ant_det_count = 0;
-			ant_det_fail_count = 0;
-			board_info->btdm_ant_det_finish = false;
-			board_info->btdm_ant_num_by_ant_det = 1;
-				 return;
-		}
-		else
-		{
-			ant_det_count++;
-
-			psd_scan->ant_det_try_count = ant_det_count;
-
-				if (scan ||roam)
-			{
-				board_info->btdm_ant_det_finish = false;
-				psd_scan->ant_det_result = 6;
-			}
-			else if (coex_sta->num_of_profile >= 1)
-			{
-				board_info->btdm_ant_det_finish = false;
-				psd_scan->ant_det_result = 7;
-			}
-				else if (!psd_scan->ant_det_is_ant_det_available)
-			{
-				board_info->btdm_ant_det_finish = false;
-				psd_scan->ant_det_result = 9;
-			}
-			else if (coex_sta->c2h_bt_inquiry_page)
-			{
-				board_info->btdm_ant_det_finish = false;
-				psd_scan->ant_det_result = 10;
-			}
-			else
-			{
-
-		}
-
-			if (!board_info->btdm_ant_det_finish)
-				ant_det_fail_count++;
-
-			psd_scan->ant_det_fail_count = ant_det_fail_count;
-		}
-	*/
-}
-
-
-void ex_halbtc8723b1ant_display_ant_detection(IN struct btc_coexist *btcoexist)
-{
-#if BT_8723B_1ANT_ANTDET_ENABLE
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	if (psd_scan->ant_det_try_count != 0) {
-		halbtc8723b1ant_psd_show_antenna_detect_result(btcoexist);
-
-		if (board_info->btdm_ant_det_finish)
-			halbtc8723b1ant_psd_showdata(btcoexist);
-		return;
-	}
-#endif
-
-	/* halbtc8723b1ant_show_psd_data(btcoexist); */
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
-
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b1ant.h
deleted file mode 100644
index adb29d492bd7..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b1ant.h
+++ /dev/null
@@ -1,307 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8723B_SUPPORT == 1)
-/* *******************************************
- * The following is for 8723B 1ANT BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8723B_1ANT				1
-
-#define	BT_INFO_8723B_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8723B_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8723B_1ANT_B_HID						BIT(5)
-#define	BT_INFO_8723B_1ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8723B_1ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8723B_1ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8723B_1ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8723B_1ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT(0))) ? true : false)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT		2
-
-#define  BT_8723B_1ANT_WIFI_NOISY_THRESH								50 /* 30   /max: 255								 */
-
-/* for Antenna detection */
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND						50
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			48
-#define	BT_8723B_1ANT_ANTDET_PSDTHRES_1ANT							32
-#define	BT_8723B_1ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8723B_1ANT_ANTDET_SWEEPPOINT_DELAY							40000
-#define	BT_8723B_1ANT_ANTDET_ENABLE										1
-#define	BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE				1
-#define	BT_8723B_1ANT_ANTDET_BTTXTIME									100
-#define	BT_8723B_1ANT_ANTDET_BTTXCHANNEL								39
-
-enum bt_info_src_8723b_1ant {
-	BT_INFO_SRC_8723B_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723B_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8723B_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8723B_1ANT_MAX
-};
-
-enum bt_8723b_1ant_bt_status {
-	BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8723B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8723B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8723B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8723B_1ANT_BT_STATUS_MAX
-};
-
-enum bt_8723b_1ant_wifi_status {
-	BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8723B_1ANT_WIFI_STATUS_MAX
-};
-
-enum bt_8723b_1ant_coex_algo {
-	BT_8723B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8723B_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8723B_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8723B_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8723B_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8723B_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8723B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8723B_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8723B_1ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-struct coex_dm_8723b_1ant {
-	/* hw setting */
-	u8		pre_ant_pos_type;
-	u8		cur_ant_pos_type;
-	/* fw mechanism */
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	/* sw mechanism */
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-	u32		arp_cnt;
-
-	u8		error_condition;
-};
-
-struct coex_sta_8723b_1ant {
-	boolean					bt_disabled;
-	boolean					bt_enable_disable_change;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-	boolean					bt_hi_pri_link_exist;
-	u8					num_of_profile;
-	boolean					bt_abnormal_scan;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	s8					bt_rssi;
-	boolean					bt_tx_rx_mask;
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8723B_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723B_1ANT_MAX];
-	boolean					bt_whck_test;
-	boolean					c2h_bt_inquiry_page;
-	boolean					c2h_bt_remote_name_req;
-	boolean					wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	boolean					cck_lock;
-	boolean					pre_ccklock;
-	boolean					cck_ever_lock;
-	u8					coex_table_type;
-
-	boolean					force_lps_on;
-	u32					wrong_profile_notification;
-	u32					bt_coex_supported_version;
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-};
-
-#define BT_8723B_1ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
-#define BT_8723B_1ANT_ANTDET_PSD_AVGNUM		1	/* MAX:3 */
-#define	BT_8723B_1ANT_ANTDET_BUF_LEN			16
-
-struct psdscan_sta_8723b_1ant {
-
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8723B_1ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8723B_1ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_psd_running;
-	boolean			is_psd_show_max_only;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8723b1ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8723b1ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b1ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8723b1ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8723b1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8723b1ant_set_antenna_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8723b1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8723b1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8723b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8723b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8723b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8723b1ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8723b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b1ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b1ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-
-void ex_halbtc8723b1ant_display_ant_detection(IN struct btc_coexist *btcoexist);
-
-#else
-#define	ex_halbtc8723b1ant_power_on_setting(btcoexist)
-#define	ex_halbtc8723b1ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8723b1ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8723b1ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8723b1ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_set_antenna_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8723b1ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8723b1ant_halt_notify(btcoexist)
-#define	ex_halbtc8723b1ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8723b1ant_coex_dm_reset(btcoexist)
-#define	ex_halbtc8723b1ant_periodical(btcoexist)
-#define	ex_halbtc8723b1ant_display_coex_info(btcoexist)
-#define	ex_halbtc8723b1ant_antenna_detection(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8723b1ant_display_ant_detection(btcoexist)
-
-#endif
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b2ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b2ant.c
deleted file mode 100644
index 066dafb5ac0f..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b2ant.c
+++ /dev/null
@@ -1,4989 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8723B Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8723B_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8723b_2ant		glcoex_dm_8723b_2ant;
-static struct  coex_dm_8723b_2ant	*coex_dm = &glcoex_dm_8723b_2ant;
-static struct  coex_sta_8723b_2ant		glcoex_sta_8723b_2ant;
-static struct  coex_sta_8723b_2ant	*coex_sta = &glcoex_sta_8723b_2ant;
-
-const char *const glbt_info_src_8723b_2ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8723b_2ant = 20170517;
-u32	glcoex_ver_8723b_2ant = 0x4d;
-u32	glcoex_ver_btdesired_8723b_2ant = 0x4d;
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8723b2ant_
- * ************************************************************ */
-u8 halbtc8723b2ant_bt_rssi_state(u8 *ppre_bt_rssi_state, u8 level_num,
-				 u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = *ppre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return *ppre_bt_rssi_state;
-		}
-
-		if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-			(*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	*ppre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8723b2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 *pprewifi_rssi_state, IN u8 level_num, IN u8 rssi_thresh,
-				   IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = *pprewifi_rssi_state;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((*pprewifi_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return *pprewifi_rssi_state;
-		}
-
-		if ((*pprewifi_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((*pprewifi_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-			(*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	*pprewifi_rssi_state = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-void halbtc8723b2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean		bt_active = true, bt_disabled = false;
-
-	/* This function check if bt is disabled */
-
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = false;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = false;
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = false;
-	} else {
-		bt_disable_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], bt all counters=0, %d times!!\n",
-			    bt_disable_cnt);
-		BTC_TRACE(trace_buf);
-		if (bt_disable_cnt >= 10)
-			bt_disabled = true;
-	}
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-
-		coex_sta->bt_disabled = bt_disabled;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-		if (bt_disabled) {
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-					   NULL);
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-					   NULL);
-		}
-	}
-}
-
-
-void halbtc8723b2ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-}
-
-void halbtc8723b2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	if ((coex_sta->low_priority_tx > 1050)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	if ((coex_sta->low_priority_rx >= 950)  &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx) &&
-	    (!coex_sta->under_ips))
-		bt_link_info->slave_role = true;
-	else
-		bt_link_info->slave_role = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_hp_txrx, reg_hp_tx, reg_hp_tx, reg_hp_rx, reg_hp_rx);
-	BTC_TRACE(trace_buf);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_lp_txrx, reg_lp_tx, reg_lp_tx, reg_lp_rx, reg_lp_rx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-}
-
-void halbtc8723b2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-#if 1
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-					 btcoexist,
-					 PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_VHT);
-
-#endif
-}
-
-void halbtc8723b2ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	coex_sta->c2h_bt_info_req_sent = true;
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-boolean halbtc8723b2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	boolean			wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean			wifi_connected = false;
-	u8			wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-
-
-		wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-				  &prewifi_rssi_state, 2,
-				  BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-				  coex_dm->switch_thres_offset, 0);
-
-		if ((BTC_RSSI_STATE_HIGH == wifi_rssi_state) ||
-		    (BTC_RSSI_STATE_LOW == wifi_rssi_state))
-			return true;
-
-	}
-
-	return false;
-}
-
-void halbtc8723b2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-u8 halbtc8723b2ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-	u8				algorithm = BT_8723B_2ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8723B_2ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8723B_2ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8723B_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8723B_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				{
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8723B_2ANT_COEX_ALGO_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8723B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8723b2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,
-		IN u8 dac_swing_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	/* There are several type of dacswing */
-	/* 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 */
-	h2c_parameter[0] = dac_swing_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter);
-}
-
-void halbtc8723b2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				       IN u8 dec_bt_pwr_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = dec_bt_pwr_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x62, 1, h2c_parameter);
-}
-
-void halbtc8723b2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				IN boolean force_exec, IN u8 dec_bt_pwr_lvl)
-{
-	coex_dm->cur_bt_dec_pwr_lvl = dec_bt_pwr_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_dec_pwr_lvl == coex_dm->cur_bt_dec_pwr_lvl)
-			return;
-	}
-	halbtc8723b2ant_set_fw_dec_bt_pwr(btcoexist,
-					  coex_dm->cur_bt_dec_pwr_lvl);
-
-	coex_dm->pre_bt_dec_pwr_lvl = coex_dm->cur_bt_dec_pwr_lvl;
-}
-
-void halbtc8723b2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8723b2ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8723b2ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8723b2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,
-			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
-{
-	coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_fw_dac_swing_lvl ==
-		    coex_dm->cur_fw_dac_swing_lvl)
-			return;
-	}
-
-	halbtc8723b2ant_set_fw_dac_swing_level(btcoexist,
-					       coex_dm->cur_fw_dac_swing_lvl);
-
-	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
-}
-
-void halbtc8723b2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,
-		IN boolean rx_rf_shrink_on)
-{
-	if (rx_rf_shrink_on) {
-		/* Shrink RF Rx LPF corner */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Shrink RF Rx LPF corner!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e, 0xfffff,
-					  0xffffc);
-	} else {
-		/* Resume RF Rx LPF corner */
-		/* After initialized, we can use coex_dm->bt_rf_0x1e_backup */
-		if (btcoexist->initilized) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Resume RF Rx LPF corner!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-					  0xfffff, coex_dm->bt_rf_0x1e_backup);
-		}
-	}
-}
-
-void halbtc8723b2ant_rf_shrink(IN struct btc_coexist *btcoexist,
-		       IN boolean force_exec, IN boolean rx_rf_shrink_on)
-{
-	coex_dm->cur_rf_rx_lpf_shrink = rx_rf_shrink_on;
-
-	if (!force_exec) {
-		if (coex_dm->pre_rf_rx_lpf_shrink ==
-		    coex_dm->cur_rf_rx_lpf_shrink)
-			return;
-	}
-	halbtc8723b2ant_set_sw_rf_rx_lpf_corner(btcoexist,
-						coex_dm->cur_rf_rx_lpf_shrink);
-
-	coex_dm->pre_rf_rx_lpf_shrink = coex_dm->cur_rf_rx_lpf_shrink;
-}
-
-void halbtc8723b2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf4;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xf5;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xf6;	/* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-}
-
-void halbtc8723b2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8723b2ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8723b2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,
-				       IN u32 level)
-{
-	u8	val = (u8)level;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Write SwDacSwing = 0x%x\n", level);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x883, 0x3e, val);
-}
-
-void halbtc8723b2ant_set_sw_full_time_dac_swing(IN struct btc_coexist
-		*btcoexist, IN boolean sw_dac_swing_on, IN u32 sw_dac_swing_lvl)
-{
-	if (sw_dac_swing_on)
-		halbtc8723b2ant_set_dac_swing_reg(btcoexist, sw_dac_swing_lvl);
-	else
-		halbtc8723b2ant_set_dac_swing_reg(btcoexist, 0x18);
-}
-
-
-void halbtc8723b2ant_dac_swing(IN struct btc_coexist *btcoexist,
-	IN boolean force_exec, IN boolean dac_swing_on, IN u32 dac_swing_lvl)
-{
-	coex_dm->cur_dac_swing_on = dac_swing_on;
-	coex_dm->cur_dac_swing_lvl = dac_swing_lvl;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_dac_swing_on == coex_dm->cur_dac_swing_on) &&
-		    (coex_dm->pre_dac_swing_lvl ==
-		     coex_dm->cur_dac_swing_lvl))
-			return;
-	}
-	delay_ms(30);
-	halbtc8723b2ant_set_sw_full_time_dac_swing(btcoexist, dac_swing_on,
-			dac_swing_lvl);
-
-	coex_dm->pre_dac_swing_on = coex_dm->cur_dac_swing_on;
-	coex_dm->pre_dac_swing_lvl = coex_dm->cur_dac_swing_lvl;
-}
-
-void halbtc8723b2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,
-				      IN boolean adc_back_off)
-{
-	if (adc_back_off) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc05, 0x30, 0x3);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc05, 0x30, 0x1);
-	}
-}
-
-void halbtc8723b2ant_adc_back_off(IN struct btc_coexist *btcoexist,
-			  IN boolean force_exec, IN boolean adc_back_off)
-{
-	coex_dm->cur_adc_back_off = adc_back_off;
-
-	if (!force_exec) {
-		if (coex_dm->pre_adc_back_off == coex_dm->cur_adc_back_off)
-			return;
-	}
-	halbtc8723b2ant_set_adc_back_off(btcoexist, coex_dm->cur_adc_back_off);
-
-	coex_dm->pre_adc_back_off = coex_dm->cur_adc_back_off;
-}
-
-void halbtc8723b2ant_set_agc_table(IN struct btc_coexist *btcoexist,
-				   IN boolean agc_table_en)
-{
-	u8		rssi_adjust_val = 0;
-
-	/* =================BB AGC Gain Table */
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6e1A0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6d1B0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6c1C0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6b1D0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6a1E0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x691F0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x68200001);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xaa1A0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa91B0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa81C0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa71D0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa61E0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa51F0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa4200001);
-	}
-
-
-	/* =================RF Gain */
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x38fff);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x38ffe);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x380c3);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x28ce6);
-	}
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xed, 0xfffff, 0x1);
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x38fff);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x38ffe);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x380c3);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x28ce6);
-	}
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xed, 0xfffff, 0x0);
-
-	/* set rssi_adjust_val for wifi module. */
-	if (agc_table_en)
-		rssi_adjust_val = 8;
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
-			   &rssi_adjust_val);
-}
-
-void halbtc8723b2ant_agc_table(IN struct btc_coexist *btcoexist,
-			       IN boolean force_exec, IN boolean agc_table_en)
-{
-	coex_dm->cur_agc_table_en = agc_table_en;
-
-	if (!force_exec) {
-		if (coex_dm->pre_agc_table_en == coex_dm->cur_agc_table_en)
-			return;
-	}
-	halbtc8723b2ant_set_agc_table(btcoexist, agc_table_en);
-
-	coex_dm->pre_agc_table_en = coex_dm->cur_agc_table_en;
-}
-
-void halbtc8723b2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,
-			   IN boolean shrink_rx_lpf, IN boolean low_penalty_ra,
-			   IN boolean limited_dig, IN boolean bt_lna_constrain)
-{
-	/*
-	u32	wifi_bw;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if(BTC_WIFI_BW_HT40 != wifi_bw)
-	{
-		if (shrink_rx_lpf)
-			shrink_rx_lpf = false;
-	}
-	*/
-
-	/* halbtc8723b2ant_rf_shrink(btcoexist, NORMAL_EXEC, shrink_rx_lpf); */
-	halbtc8723b2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra);
-}
-
-void halbtc8723b2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,
-			   IN boolean agc_table_shift, IN boolean adc_back_off,
-			   IN boolean sw_dac_swing, IN u32 dac_swing_lvl)
-{
-	/* halbtc8723b2ant_agc_table(btcoexist, NORMAL_EXEC, agc_table_shift); */
-	/* halbtc8723b2ant_adc_back_off(btcoexist, NORMAL_EXEC, adc_back_off); */
-	/* halbtc8723b2ant_dac_swing(btcoexist, NORMAL_EXEC, sw_dac_swing, dac_swing_lvl); */
-}
-
-void halbtc8723b2ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8723b2ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8723b2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8723b2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	coex_sta->coex_table_type = type;
-
-	switch (type) {
-	case 0:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x55555555, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5afa5afa, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x5ada5ada, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 4:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0xffffffff, 0xffffffff, 0xffffff, 0x3);
-		break;
-	case 5:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0x5fff5fff, 0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55ff55ff, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 7:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 8:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 9:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 10:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 11:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 12:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 13:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 14:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 15:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 16:
-		halbtc8723b2ant_coex_table(btcoexist, force_exec,
-				   0xffff55ff, 0xfafafafa, 0xffffff, 0x3);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8723b2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8723b2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8723b2ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8723b2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8723b2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8723b2ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8723b2ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x0, 0, 0, 48, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			/* halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						1); */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			/* halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						1); */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-void halbtc8723b2ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	case BTC_PS_LPS_ON:
-		halbtc8723b2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, true);
-		halbtc8723b2ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		coex_sta->force_lps_on = true;
-		break;
-	case BTC_PS_LPS_OFF:
-		halbtc8723b2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	default:
-		break;
-	}
-}
-
-
-void halbtc8723b2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean		ap_enable = false;
-
-#if 0
-	if ((coex_sta->a2dp_exist) && (coex_sta->hid_exist))
-		byte5 = byte5 | 0x1;
-#endif
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			real_byte1 &= ~BIT(4);
-			real_byte1 |= BIT(5);
-
-			real_byte5 |= BIT(5);
-			real_byte5 &= ~BIT(6);
-
-			halbtc8723b2ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		}
-	} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			halbtc8723b2ant_power_save_state(btcoexist,
-				BTC_PS_LPS_ON, 0x50, 0x4);
-
-	} else {
-			halbtc8723b2ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	}
-
-	h2c_parameter[0] = byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = byte5;
-
-	coex_dm->ps_tdma_para[0] = byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-void halbtc8723b2ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8			wifi_rssi_state1,  bt_rssi_state;
-	s8			wifi_duration_adjust = 0x0;
-	u8			psTdmaByte4Modify = 0x0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-		&prewifi_rssi_state, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES
-			   - coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s turn %s PS TDMA, type=%d\n",
-		(force_exec ? "force to" : ""), (turn_on ? "ON" : "OFF"), type);
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	if (!(BTC_RSSI_HIGH(wifi_rssi_state1) &&
-	      BTC_RSSI_HIGH(bt_rssi_state)) && turn_on)
-		/* if (halbtc8723b2ant_CoexSwitchThresCheck(btcoexist) &&  turn_on) */
-	{
-		type = type + 100; /* for WiFi RSSI low or BT RSSI low */
-		coex_dm->is_switch_to_1dot5_ant = true;
-	} else
-		coex_dm->is_switch_to_1dot5_ant = false;
-
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-
-	if (coex_sta->scan_ap_num <= 5) {
-		if (coex_sta->a2dp_bit_pool >= 45)
-			wifi_duration_adjust = -15;
-		else if (coex_sta->a2dp_bit_pool >= 35)
-			wifi_duration_adjust = -10;
-		else
-			wifi_duration_adjust = 5;
-	} else  if (coex_sta->scan_ap_num <= 20) {
-		if (coex_sta->a2dp_bit_pool >= 45)
-			wifi_duration_adjust = -15;
-		else if (coex_sta->a2dp_bit_pool >= 35)
-			wifi_duration_adjust = -10;
-		else
-			wifi_duration_adjust = 0;
-	} else if (coex_sta->scan_ap_num <= 40) {
-		if (coex_sta->a2dp_bit_pool >= 45)
-			wifi_duration_adjust = -15;
-		else if (coex_sta->a2dp_bit_pool >= 35)
-			wifi_duration_adjust = -10;
-		else
-			wifi_duration_adjust = -5;
-	} else {
-		if (coex_sta->a2dp_bit_pool >= 45)
-			wifi_duration_adjust = -15;
-		else if (coex_sta->a2dp_bit_pool >= 35)
-			wifi_duration_adjust = -10;
-		else
-			wifi_duration_adjust = -10;
-	}
-
-	if ((bt_link_info->slave_role == true)	&& (bt_link_info->a2dp_exist))
-		psTdmaByte4Modify =
-			0x1;  /* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-
-
-	if (turn_on) {
-		switch (type) {
-		case 1:
-		default:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x3c + wifi_duration_adjust, 0x03, 0xf1,
-						      0x90 | psTdmaByte4Modify);
-			break;
-		case 2:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x2d + wifi_duration_adjust, 0x03, 0xf1,
-						      0x90 | psTdmaByte4Modify);
-			break;
-		case 3:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0xf1,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 4:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x10, 0x03, 0xf1,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 5:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x3c + wifi_duration_adjust, 0x3, 0x70,
-						      0x90 | psTdmaByte4Modify);
-			break;
-		case 6:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x2d + wifi_duration_adjust, 0x3, 0x70,
-						      0x90 | psTdmaByte4Modify);
-			break;
-		case 7:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0x70,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 8:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xa3,
-						      0x10, 0x3, 0x70,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 9:
-			/*
-				halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-					      0x3c + wifi_duration_adjust, 0x03, 0xf1,
-							      0x90 | psTdmaByte4Modify);
-			*/
-			/* Bryant Modify for BT no-profile busy case */
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x3c + wifi_duration_adjust, 0x03, 0xf1,
-						      0x91);
-
-			break;
-		case 10:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x2d + wifi_duration_adjust, 0x03, 0xf1,
-						      0x90 | psTdmaByte4Modify);
-			break;
-		case 11:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0xf1,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 12:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x10, 0x3, 0xf1,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 13:
-			/*
-				halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-					      0x3c + wifi_duration_adjust, 0x3, 0x70,
-							      0x90 | psTdmaByte4Modify);
-			*/
-			/* Bryant Modify for BT no-profile busy case */
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x3c + wifi_duration_adjust, 0x3, 0x70,
-						      0x91);
-			break;
-		case 14:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x2d + wifi_duration_adjust, 0x3, 0x70,
-						      0x90 | psTdmaByte4Modify);
-			break;
-		case 15:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0x70,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 16:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x10, 0x3, 0x70,  0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 17:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xa3,
-						      0x2f, 0x2f, 0x60, 0x90);
-			break;
-		case 18:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x5, 0x5, 0xe1, 0x90);
-			break;
-		case 19:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x25, 0xe1, 0x90);
-			break;
-		case 20:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x25, 0x60, 0x90);
-			break;
-		case 21:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x03, 0x70, 0x90);
-			break;
-		case 22:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x35, 0x03, 0xf1, 0x90);
-			break;
-		case 23:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x35, 0x03, 0x71, 0x10);
-			break;
-
-		case 25:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x30, 0x03, 0x71, 0x10);
-			break;
-		case 30:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x10, 0x3, 0x70, 0x54);
-			break;
-		case 33:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0xf1,  0x91);
-
-			break;
-		case 71:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-				      0x3c + wifi_duration_adjust, 0x03, 0xf1,
-						      0x90);
-			break;
-		case 101:
-		case 105:
-		case 113:
-		case 171:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-				      0x3a + wifi_duration_adjust, 0x03, 0x70,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 102:
-		case 106:
-		case 110:
-		case 114:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-				      0x2d + wifi_duration_adjust, 0x03, 0x70,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 103:
-		case 107:
-		case 111:
-		case 115:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1c, 0x03, 0x70, 0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 104:
-		case 108:
-		case 112:
-		case 116:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x10, 0x03, 0x70, 0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 109:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0xf1, 0x90 |
-						      psTdmaByte4Modify);
-			break;
-		/* case 113:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0x70, 0x90 |
-						      psTdmaByte4Modify);
-			break; */
-		case 121:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x03, 0x70, 0x90 |
-						      psTdmaByte4Modify);
-			break;
-		case 122:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x35, 0x03, 0x71, 0x11);
-			break;
-		case 123:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x35, 0x03, 0x71, 0x10);
-			break;
-		case 125:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x30, 0x03, 0x70, 0x51);
-			break;
-		case 130:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x10, 0x3, 0x70, 0x54);
-			break;
-		case 133:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1c, 0x3, 0x70,  0x51);
-
-			break;
-		}
-	} else {
-		/* disable PS tdma */
-		switch (type) {
-		case 0:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		case 1:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x48, 0x0);
-			break;
-		default:
-			halbtc8723b2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		}
-	}
-
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-
-void halbtc8723b2ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean init_hwcfg, IN boolean wifi_off)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-	u32			fw_ver = 0, u32tmp = 0, cnt_bt_cal_chk = 0;
-	boolean			pg_ext_switch = false;
-	boolean			use_ext_switch = false;
-	u8			h2c_parameter[2] = {0};
-	u32				u32tmp_1[4];
-	boolean		is_fw_ready;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_EXT_SWITCH, &pg_ext_switch);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER,
-			   &fw_ver);	/* [31:16]=fw ver, [15:0]=fw sub ver */
-
-	if ((fw_ver > 0 && fw_ver < 0xc0000) || pg_ext_switch)
-		use_ext_switch = true;
-
-	if (init_hwcfg) {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x39, 0x8, 0x1);
-		btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x944, 0x3, 0x3);
-		btcoexist->btc_write_1byte(btcoexist, 0x930, 0x77);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20, 0x1);
-
-		if (fw_ver >= 0x180000) {
-			/* Use H2C to set GNT_BT to High to avoid A2DP click */
-			h2c_parameter[0] = 1;
-			btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1,
-						h2c_parameter);
-
-			cnt_bt_cal_chk = 0;
-			while (1) {
-				btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_FW_READY, &is_fw_ready);
-				if (is_fw_ready == false)
-					break;
-
-				if (btcoexist->btc_read_1byte(btcoexist,
-							      0x765) == 0x18)
-					break;
-
-				cnt_bt_cal_chk++;
-				if (cnt_bt_cal_chk > 20)
-					break;
-			}
-		} else
-			btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18);
-		u32tmp_1[0] = btcoexist->btc_read_4byte(btcoexist, 0x948);
-		if ((u32tmp_1[0] == 0x40) || (u32tmp_1[0] == 0x240))
-			btcoexist->btc_write_4byte(btcoexist, 0x948,
-						   u32tmp_1[0]);
-		else
-			btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0);
-
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0); /* WiFi TRx Mask off */
-		/* remove due to interrupt is disabled that polling c2h will fail and delay 100ms. */
-		/* btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x3c, 0x01); */ /*BT TRx Mask off */
-
-		if (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT) {
-			/* tell firmware "no antenna inverse" */
-			h2c_parameter[0] = 0;
-		} else {
-			/* tell firmware "antenna inverse" */
-			h2c_parameter[0] = 1;
-		}
-
-		if (use_ext_switch) {
-			/* ext switch type */
-			h2c_parameter[1] = 1;
-		} else {
-			/* int switch type */
-			h2c_parameter[1] = 0;
-		}
-		btcoexist->btc_fill_h2c(btcoexist, 0x65, 2, h2c_parameter);
-	} else {
-		if (fw_ver >= 0x180000) {
-			/* Use H2C to set GNT_BT to "Control by PTA"*/
-			h2c_parameter[0] = 0;
-			btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1,
-						h2c_parameter);
-
-			cnt_bt_cal_chk = 0;
-			while (1) {
-				btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_FW_READY, &is_fw_ready);
-				if (is_fw_ready == false)
-					break;
-
-				if (btcoexist->btc_read_1byte(btcoexist,
-							      0x765) == 0x0)
-					break;
-
-				cnt_bt_cal_chk++;
-				if (cnt_bt_cal_chk > 20)
-					break;
-			}
-		} else
-			btcoexist->btc_write_1byte(btcoexist, 0x765, 0x0);
-	}
-
-	/* ext switch setting */
-	if (use_ext_switch) {
-		if (init_hwcfg) {
-			/* 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT */
-			u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-			u32tmp &= ~BIT(23);
-			u32tmp |= BIT(24);
-			btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-		}
-		u32tmp_1[0] = btcoexist->btc_read_4byte(btcoexist, 0x948);
-		if ((u32tmp_1[0] == 0x40) || (u32tmp_1[0] == 0x240))
-			btcoexist->btc_write_4byte(btcoexist, 0x948,
-						   u32tmp_1[0]);
-		else
-			btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0);
-
-		switch (ant_pos_type) {
-		case BTC_ANT_WIFI_AT_MAIN:
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0x92c, 0x3,
-					   0x1);	/* ext switch main at wifi */
-			break;
-		case BTC_ANT_WIFI_AT_AUX:
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0x92c, 0x3,
-					   0x2);	/* ext switch aux at wifi */
-			break;
-		}
-	} else {	/* internal switch */
-		if (init_hwcfg) {
-			/* 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT */
-			u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-			u32tmp |= BIT(23);
-			u32tmp &= ~BIT(24);
-			btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-		}
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1,
-			   0x0); /* fixed external switch S1->Main, S0->Aux */
-		switch (ant_pos_type) {
-		case BTC_ANT_WIFI_AT_MAIN:
-			u32tmp_1[0] = btcoexist->btc_read_4byte(btcoexist,
-								0x948);
-			if ((u32tmp_1[0] == 0x40) || (u32tmp_1[0] == 0x240))
-				btcoexist->btc_write_4byte(btcoexist, 0x948,
-							   u32tmp_1[0]);
-			else
-				btcoexist->btc_write_4byte(btcoexist, 0x948,
-							   0x0);
-			break;
-		case BTC_ANT_WIFI_AT_AUX:
-			u32tmp_1[0] = btcoexist->btc_read_4byte(btcoexist,
-								0x948);
-			if ((u32tmp_1[0] == 0x40) || (u32tmp_1[0] == 0x240))
-				btcoexist->btc_write_4byte(btcoexist, 0x948,
-							   u32tmp_1[0]);
-			else
-				btcoexist->btc_write_4byte(btcoexist, 0x948,
-							   0x280);
-			break;
-		}
-	}
-}
-#if 0
-boolean halbtc8723b2ant_CoexSwitchThresCheck(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8 wifi_rssi_state1, bt_rssi_state;
-	u32 vendor;
-	u8 offset = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_VENDOR, &vendor);
-
-	/* if (vendor == BTC_VENDOR_LENOVO) */
-	/*	offset = 20; */
-
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-		&prewifi_rssi_state, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES
-			   - coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	if (BTC_RSSI_LOW(wifi_rssi_state1) || BTC_RSSI_LOW(bt_rssi_state))
-		return true;
-
-	return false;
-}
-#endif
-
-
-void halbtc8723b2ant_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-	/* fw all off */
-	halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	/* hw all off */
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); */
-	halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8723b2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-	halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8723b2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 1);
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6);
-	halbtc8723b2ant_dec_bt_pwr(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	coex_sta->pop_event_cnt = 0;
-
-}
-
-void halbtc8723b2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	boolean	wifi_connected = false;
-	boolean	low_pwr_disable = true;
-	boolean		scan = false, link = false, roam = false;
-	boolean wifi_busy = false;
-
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER,
-			   &low_pwr_disable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-
-	if (coex_sta->bt_abnormal_scan) {
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-					23);
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	} else if (scan || link || roam) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi link process + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     7);
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 3);
-	} else if (wifi_connected) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     7);
-
-		if (wifi_busy)
-			halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						3);
-		else
-			halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 33);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi no-link + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	}
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6);
-	halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-	/*
-		coex_dm->need_recover0x948 = true;
-		coex_dm->backup0x948 = btcoexist->btc_read_4byte(btcoexist, 0x948);
-
-		halbtc8723b2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_AUX, false, false);
-	*/
-}
-
-
-void halbtc8723b2ant_action_wifi_link_process(IN struct btc_coexist *btcoexist)
-{
-	u32	u32tmp;
-	u8	u8tmpa, u8tmpb;
-
-	halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 15);
-	halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22);
-
-	halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948);
-	u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-	u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x76e=0x%x\n",
-		    u32tmp,  u8tmpa, u8tmpb);
-	BTC_TRACE(trace_buf);
-}
-
-boolean halbtc8723b2ant_action_wifi_idle_process(IN struct btc_coexist
-		*btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u8		ap_num = 0;
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	/* wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES-coex_dm->switch_thres_offset-coex_dm->switch_thres_offset, 0); */
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-		coex_dm->switch_thres_offset - coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-		coex_dm->switch_thres_offset - coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num);
-
-	/* define the office environment */
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) &&
-	    (coex_sta->hid_exist == true) &&
-	    (coex_sta->a2dp_exist == true)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi  idle process for BT HID+A2DP exist!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8723b2ant_dac_swing(btcoexist, NORMAL_EXEC, true, 0x6);
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		/* sw all off */
-		halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false,
-					      false);
-		halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-		return true;
-	}
-
-	halbtc8723b2ant_dac_swing(btcoexist, NORMAL_EXEC, true, 0x18);
-	return false;
-}
-
-
-
-boolean halbtc8723b2ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = false, wifi_connected = false, wifi_busy = false;
-	boolean			bt_hs_on = false, low_pwr_disable = false;
-	boolean			asus_8723b = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected) {
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non-connected idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0);
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-		halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false,
-					      false);
-		halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-
-		common = true;
-	} else {
-		if (BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-			low_pwr_disable = false;
-			btcoexist->btc_set(btcoexist,
-					   BTC_SET_ACT_DISABLE_LOW_POWER,
-					   &low_pwr_disable);
-			halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, false, 0x8);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-			BTC_TRACE(trace_buf);
-
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x0);
-			halbtc8723b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-			halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						1);
-			halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 0xb);
-			halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false,
-						      false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-
-			common = true;
-		} else if (BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE ==
-			   coex_dm->bt_status) {
-			low_pwr_disable = true;
-			btcoexist->btc_set(btcoexist,
-					   BTC_SET_ACT_DISABLE_LOW_POWER,
-					   &low_pwr_disable);
-
-			if (bt_hs_on)
-				return false;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi connected + BT connected-idle!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, false, 0x8);
-
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x0);
-			halbtc8723b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-			halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						1);
-			halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 0xb);
-			halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-
-			common = true;
-		} else {
-			low_pwr_disable = true;
-			btcoexist->btc_set(btcoexist,
-					   BTC_SET_ACT_DISABLE_LOW_POWER,
-					   &low_pwr_disable);
-
-			if (wifi_busy) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-				/* btcoexist->btc_get(btcoexist,
-					BTC_GET_BL_IS_ASUS_8723B, &asus_8723b);
-				if (!asus_8723b)
-					common = false;
-				else
-					common = halbtc8723b2ant_action_wifi_idle_process(
-							 btcoexist); */
-				common = false;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-				/* common = false;	 */
-				common = halbtc8723b2ant_action_wifi_idle_process(
-						 btcoexist);
-			}
-		}
-	}
-
-	return common;
-}
-void halbtc8723b2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,
-		IN boolean sco_hid, IN boolean tx_pause, IN u8 max_interval)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0;
-
-	if (!coex_dm->auto_tdma_adjust) {
-		coex_dm->auto_tdma_adjust = true;
-		{
-			if (sco_hid) {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					} else if (max_interval == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (max_interval == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					} else if (max_interval == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (max_interval == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			} else {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (max_interval == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (max_interval == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (max_interval == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (max_interval == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					}
-				}
-			}
-		}
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2 */
-		retry_count = coex_sta->bt_retry_cnt;
-
-		if ((coex_sta->low_priority_tx) > 1050 ||
-		    (coex_sta->low_priority_rx) > 1250)
-			retry_count++;
-
-		result = 0;
-		wait_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if retry count during continuous n*2 seconds is 0, enlarge WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {/* if continuous 2 retry count(every 2 seconds) >0 and < 3, reduce WiFi duration */
-				if (wait_count <= 2)
-					m++; /* to avoid loop between the two levels */
-				else
-					m = 1;
-
-				if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-			}
-		} else { /* retry count > 3, once retry count > 3, to reduce WiFi duration */
-			if (wait_count == 1)
-				m++; /* to avoid loop between the two levels */
-			else
-				m = 1;
-
-			if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-		}
-
-		if (max_interval == 1) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 71) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 5);
-					coex_dm->ps_tdma_du_adj_type = 5;
-				} else if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 5);
-					coex_dm->ps_tdma_du_adj_type = 5;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 13);
-					coex_dm->ps_tdma_du_adj_type = 13;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 71);
-					coex_dm->ps_tdma_du_adj_type = 71;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 9);
-					coex_dm->ps_tdma_du_adj_type = 9;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 71) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 71);
-						coex_dm->ps_tdma_du_adj_type =
-							71;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					}
-				}
-			}
-		} else if (max_interval == 2) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					}
-				}
-			}
-		} else if (max_interval == 3) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8723b2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8723b2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			}
-		}
-	}
-
-	/* 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 (coex_dm->cur_ps_tdma != coex_dm->ps_tdma_du_adj_type) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], PsTdma type dismatch!!!, cur_ps_tdma=%d, recordPsTdma=%d\n",
-			    coex_dm->cur_ps_tdma, coex_dm->ps_tdma_du_adj_type);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (!scan && !link && !roam)
-			halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-}
-
-/* SCO only or SCO+PAN(HS) */
-void halbtc8723b2ant_action_sco(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8	wifi_rssi_state, bt_rssi_state;
-	u32	wifi_bw;
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 4);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if (BTC_WIFI_BW_LEGACY == wifi_bw) /* for SCO quality at 11b/g mode */
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	else  /* for SCO quality & wifi performance balance at 11n mode */
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-	halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-				0); /* for voice quality */
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x4);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x4);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x4);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x4);
-		}
-	}
-}
-
-
-void halbtc8723b2ant_action_hid(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8	wifi_rssi_state, bt_rssi_state;
-	u32	wifi_bw;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if (BTC_WIFI_BW_LEGACY == wifi_bw) /* for HID at 11b/g mode */
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	else  /* for HID quality & wifi performance balance at 11n mode */
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 9);
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH))
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9);
-	else
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 13);
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-void halbtc8723b2ant_action_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-	u8		ap_num = 0;
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num);
-
-	/* define the office environment */
-	if ((ap_num >= 10) && BTC_RSSI_HIGH(wifi_rssi_state1) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-		/* dbg_print(" AP#>10(%d)\n", ap_num); */
-
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0);
-		halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-		halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-		/* sw mechanism */
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x18);
-		}
-		return;
-
-	}
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-	} else {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-	}
-
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH))
-		halbtc8723b2ant_tdma_duration_adjust(btcoexist, false, false,
-						     1);
-	else
-		halbtc8723b2ant_tdma_duration_adjust(btcoexist, false, true, 1);
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8723b2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-	} else {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-	}
-
-	halbtc8723b2ant_tdma_duration_adjust(btcoexist, false, true, 2);
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8723b2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     10);
-	} else {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-	}
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH))
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 1);
-	else
-		halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5);
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-
-/* PAN(HS) only */
-void halbtc8723b2ant_action_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-	halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* PAN(EDR)+A2DP */
-void halbtc8723b2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u8		ap_num = 0;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &ap_num);
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     12);
-
-		if (ap_num < 10)
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     false, 1);
-		else
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     false, 3);
-
-	} else {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-		if (ap_num < 10)
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 1);
-		else
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 3);
-	}
-
-	/* sw mechanism	 */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8723b2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     14);
-	}
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		if (BTC_WIFI_BW_HT40 == wifi_bw) {
-			halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 3);
-			/* halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11); */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x780);
-		} else {
-			halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 6);
-			/* halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x0);
-		}
-		halbtc8723b2ant_tdma_duration_adjust(btcoexist, true, false, 2);
-	} else {
-		halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		/* halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14); */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0);
-		halbtc8723b2ant_tdma_duration_adjust(btcoexist, true, true, 2);
-	}
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* HID+A2DP+PAN(EDR) */
-void halbtc8723b2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1,  bt_rssi_state;
-	u32		wifi_bw;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 2,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     14);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 3);
-		else
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     false, 3);
-	} else
-		halbtc8723b2ant_tdma_duration_adjust(btcoexist, true, true, 3);
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8723b2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW,
-			prewifi_rssi_state1 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-	u8		ap_num = 0;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 35);
-
-
-	wifi_rssi_state = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2, 15, 0);
-	/* bt_rssi_state = halbtc8723b2ant_bt_rssi_state(2, 29, 0); */
-	wifi_rssi_state1 = halbtc8723b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state1, 2,
-			   BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES -
-			   coex_dm->switch_thres_offset, 0);
-	bt_rssi_state = halbtc8723b2ant_bt_rssi_state(&pre_bt_rssi_state, 3,
-			BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES -
-			coex_dm->switch_thres_offset, 37);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &ap_num);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, true, 0x5);
-
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_LEGACY == wifi_bw) {
-		if (BTC_RSSI_HIGH(bt_rssi_state))
-			halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else if (BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	} else {
-		/* only 802.11N mode we have to dec bt power to 4 degree */
-		if (BTC_RSSI_HIGH(bt_rssi_state)) {
-			/* need to check ap Number of Not */
-			if (ap_num < 10)
-				halbtc8723b2ant_dec_bt_pwr(btcoexist,
-							   NORMAL_EXEC, 4);
-			else
-				halbtc8723b2ant_dec_bt_pwr(btcoexist,
-							   NORMAL_EXEC, 2);
-		} else if (BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	}
-
-#if 1
-	halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     16);
-	halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 30);
-#endif
-#if 0
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else {
-		halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     14);
-	}
-
-	if (BTC_RSSI_HIGH(bt_rssi_state)) {
-		if (ap_num < 10)
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     false, 2);
-
-		else
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     false, 3);
-	} else {
-		halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 18);
-		btcoexist->btc_write_1byte(btcoexist, 0x456, 0x38);
-		btcoexist->btc_write_2byte(btcoexist, 0x42a, 0x0808);
-		btcoexist->btc_write_4byte(btcoexist, 0x430, 0x0);
-		btcoexist->btc_write_4byte(btcoexist, 0x434, 0x01010000);
-
-		if (ap_num < 10)
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 2);
-
-		else
-			halbtc8723b2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 3);
-	}
-#endif
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8723b2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8723b2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8723b2ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)
-{
-	halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8723b2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	halbtc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8723b2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8723b2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	/* hw all off */
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); */
-	halbtc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-}
-
-void halbtc8723b2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8				algorithm = 0;
-	u32				num_of_wifi_link = 0;
-	u32				wifi_link_status = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean				miracast_plus_bt = false;
-	boolean				scan = false, link = false, roam = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_action_bt_whck_test(btcoexist);
-		return;
-	}
-
-	algorithm = halbtc8723b2ant_action_algorithm(btcoexist);
-	if (coex_sta->c2h_bt_inquiry_page &&
-	    (BT_8723B_2ANT_COEX_ALGO_PANHS != algorithm)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	/*
-		if(coex_dm->need_recover0x948)
-		{
-			coex_dm->need_recover0x948 = false;
-			btcoexist->btc_write_4byte(btcoexist, 0x948, coex_dm->backup0x948);
-		}
-	*/
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-	if (scan || link || roam) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under Link Process !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_action_wifi_link_process(btcoexist);
-		return;
-	}
-
-	/* for P2P */
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist)
-			miracast_plus_bt = true;
-		else
-			miracast_plus_bt = false;
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-		halbtc8723b2ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	}
-
-	miracast_plus_bt = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-			   &miracast_plus_bt);
-
-	coex_dm->cur_algorithm = algorithm;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Algorithm = %d\n",
-		    coex_dm->cur_algorithm);
-	BTC_TRACE(trace_buf);
-
-	if (halbtc8723b2ant_is_common_action(btcoexist)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant common.\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->auto_tdma_adjust = false;
-	} else {
-		if (coex_dm->cur_algorithm != coex_dm->pre_algorithm) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], pre_algorithm=%d, cur_algorithm=%d\n",
-				coex_dm->pre_algorithm, coex_dm->cur_algorithm);
-			BTC_TRACE(trace_buf);
-			coex_dm->auto_tdma_adjust = false;
-		}
-		switch (coex_dm->cur_algorithm) {
-		case BT_8723B_2ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_sco(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_hid(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_a2dp(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_a2dp_pan_hs(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_pan_edr(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_pan_hs(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_pan_edr_a2dp(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_pan_edr_hid(btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_hid_a2dp_pan_edr(
-				btcoexist);
-			break;
-		case BT_8723B_2ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_action_hid_a2dp(btcoexist);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_coex_all_off(btcoexist);
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-void halbtc8723b2ant_wifi_off_hw_cfg(IN struct btc_coexist *btcoexist)
-{
-	boolean	is_in_mp_mode = false;
-	u8 h2c_parameter[2] = {0};
-	u32 fw_ver = 0;
-
-	/* set wlan_act to low */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-			  0x780); /* WiFi goto standby while GNT_BT 0-->1 */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	if (fw_ver >= 0x180000) {
-		/* Use H2C to set GNT_BT to HIGH */
-		h2c_parameter[0] = 1;
-		btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1, h2c_parameter);
-	} else
-		btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_IS_IN_MP_MODE,
-			   &is_in_mp_mode);
-	if (!is_in_mp_mode)
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-			   0x0); /* BT select s0/s1 is controlled by BT */
-	else
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-			   0x1); /* BT select s0/s1 is controlled by WiFi */
-}
-
-void halbtc8723b2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up)
-{
-	u8	u8tmp = 0;
-	u32	 vendor;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 2Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_VENDOR, &vendor);
-	if (vendor == BTC_VENDOR_LENOVO)
-		coex_dm->switch_thres_offset = 0;
-	else if (vendor == BTC_VENDOR_ASUS)
-		coex_dm->switch_thres_offset = 0;
-	else
-		coex_dm->switch_thres_offset = 20;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	/* backup rf 0x1e value */
-	coex_dm->bt_rf_0x1e_backup =
-		btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x1e, 0xfffff);
-
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	/* Antenna config	 */
-	halbtc8723b2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_MAIN, true,
-				     false);
-	coex_sta->dis_ver_info_cnt = 0;
-
-	/* PTA parameter */
-	halbtc8723b2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	/* Enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e,
-			   0x4); /* 0x76e[3] =1, WLAN_Act control by PTA */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x3);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-
-	/* Give bt_coex_supported_version the default value */
-	coex_sta->bt_coex_supported_version = 0;
-
-}
-
-/* ************************************************************
- * work around function start with wa_halbtc8723b2ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8723b2ant_
- * ************************************************************ */
-void ex_halbtc8723b2ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u16 u16tmp = 0x0;
-	u32				value = 0;
-	u32    u32tmp_1[4];
-
-	btcoexist->btc_write_1byte(btcoexist, 0x67, 0x20);
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly. */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-	btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0);
-
-	if (btcoexist->chip_interface == BTC_INTF_USB) {
-		/* fixed at S0 for USB interface */
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-	} else {
-		/* for PCIE and SDIO interface, we check efuse 0xc3[6] */
-		if (board_info->single_ant_path == 0) {
-			/* set to S1 */
-			board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-		} else if (board_info->single_ant_path == 1) {
-			/* set to S0 */
-			board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-		}
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
-				   &value);
-	}
-}
-
-void ex_halbtc8723b2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x4; /* Set BIT2 by default since it's 2ant case */
-
-	/* */
-	/* S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info) */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-	if (btcoexist->chip_interface == BTC_INTF_USB) {
-		/* fixed at S0 for USB interface */
-		u8tmp |= 0x1;	/* antenna inverse */
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	} else {
-		if (board_info->single_ant_path == 1) {
-			/* set to S0 */
-			u8tmp |= 0x1;	/* antenna inverse */
-		}
-
-		if (btcoexist->chip_interface == BTC_INTF_PCI)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x384,
-							     u8tmp);
-		else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60,
-							     u8tmp);
-	}
-}
-
-void ex_halbtc8723b2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8723b2ant_init_hw_config(btcoexist, true);
-}
-
-void ex_halbtc8723b2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8723b2ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8723b2ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0;
-	u32				bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0;
-	u32				phyver = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "Ant PG number/ Ant mechanism:",
-		   board_info->pg_ant_num, board_info->btdm_ant_num);
-	CL_PRINTF(cli_buf);
-
-	/* btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver); */
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-	bt_coex_ver = coex_sta->bt_coex_supported_version & 0xff;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8723b_2ant, glcoex_ver_8723b_2ant,
-		   glcoex_ver_btdesired_8723b_2ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (bt_coex_ver >= glcoex_ver_btdesired_8723b_2ant ?
-		     "Match" : "Mis-Match")));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Abnormal scan",
-		   (coex_sta->bt_abnormal_scan) ? "Yes" : "No");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d / %d / %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP/NameReq/WHQL",
-		   bt_link_info->sco_exist, bt_link_info->hid_exist,
-		   bt_link_info->pan_exist, bt_link_info->a2dp_exist,
-		   coex_sta->c2h_bt_remote_name_req,
-		   coex_sta->bt_whck_test);
-	CL_PRINTF(cli_buf);
-
-	{
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-			   "BT Role",
-			   (bt_link_info->slave_role) ? "Slave" : "Master");
-		CL_PRINTF(cli_buf);
-	}
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d",
-		   "A2DP Rate/Bitpool",
-		(bt_info_ext & BIT(0)) ? "BR" : "EDR", coex_sta->a2dp_bit_pool);
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8723B_2ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8723b_2ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	/* Sw mechanism	 */
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[Sw mechanism] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[Sw mechanism]============");
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ",
-		   "SM1[ShRf/ LpRA/ LimDig]",
-		   coex_dm->cur_rf_rx_lpf_shrink, coex_dm->cur_low_penalty_ra,
-		   coex_dm->limited_dig);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ",
-		   "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]",
-		   coex_dm->cur_agc_table_en, coex_dm->cur_adc_back_off,
-		   coex_dm->cur_dac_swing_on, coex_dm->cur_dac_swing_lvl);
-	CL_PRINTF(cli_buf);
-
-	/* Fw mechanism		 */
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[Fw mechanism] (before Manual) ============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[Fw mechanism]============");
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-
-	if (coex_dm->is_switch_to_1dot5_ant)
-		ps_tdma_case = ps_tdma_case + 100;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)",
-		   "PS TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "On" : "Off"),
-		   (coex_dm->auto_tdma_adjust ? "Adj" : "Fix"));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Coex Table Type",
-		   coex_sta->coex_table_type);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "DecBtPwr/ IgnWlanAct",
-		   coex_dm->cur_bt_dec_pwr_lvl, coex_dm->cur_ignore_wlan_act);
-	CL_PRINTF(cli_buf);
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x",
-		   "RF-A, 0x1e initVal",
-		   coex_dm->bt_rf_0x1e_backup);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x880);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x778/0x880[29:25]",
-		   u8tmp[0], (u32tmp[0] & 0x3e000000) >> 25);
-	CL_PRINTF(cli_buf);
-
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x948);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x67);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x765);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x948/ 0x67[5] / 0x765",
-		   u32tmp[0], ((u8tmp[0] & 0x20) >> 5), u8tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x92c);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x930);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x944);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x92c[1:0]/ 0x930[7:0]/0x944[1:0]",
-		   u32tmp[0] & 0x3, u32tmp[1] & 0xff, u32tmp[2] & 0x3);
-	CL_PRINTF(cli_buf);
-
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x39);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x64);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x38[11]/0x40/0x4c[24:23]/0x64[0]",
-		   ((u8tmp[0] & 0x8) >> 3), u8tmp[1],
-		   ((u32tmp[0] & 0x01800000) >> 23), u8tmp[2] & 0x1);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x49c);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0xc50(dig)/0x49c(null-drop)",
-		   u32tmp[0] & 0xff, u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11n-agg",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(high-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(low-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8723B_2ANT == 1)
-	/* halbtc8723b2ant_monitor_bt_ctr(btcoexist); */
-#endif
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8723b2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = true;
-		halbtc8723b2ant_wifi_off_hw_cfg(btcoexist);
-		halbtc8723b2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-		halbtc8723b2ant_coex_all_off(btcoexist);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = false;
-		halbtc8723b2ant_init_hw_config(btcoexist, false);
-		halbtc8723b2ant_init_coex_dm(btcoexist);
-		halbtc8723b2ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8723b2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = true;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8723b2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	u32	u32tmp;
-	u8	u8tmpa, u8tmpb;
-
-
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948);
-	u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-	u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-
-	if (BTC_SCAN_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_MAIN,
-					     false, false);
-	} else if (BTC_SCAN_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x76e=0x%x\n",
-		    u32tmp,  u8tmpa, u8tmpb);
-	BTC_TRACE(trace_buf);
-}
-
-void ex_halbtc8723b2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	if (BTC_ASSOCIATE_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_MAIN,
-					     false, false);
-	} else if (BTC_ASSOCIATE_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void ex_halbtc8723b2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	u8			ap_num = 0;
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_MAIN,
-					     false, false);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		h2c_parameter[0] = 0x1;
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else {
-			btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-					   &ap_num);
-			if (ap_num < 10)
-				h2c_parameter[2] = 0x30;
-			else
-				h2c_parameter[2] = 0x20;
-		}
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-}
-
-void ex_halbtc8723b2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	if (type == BTC_PACKET_DHCP) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], DHCP Packet notify\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void ex_halbtc8723b2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8			bt_info = 0;
-	u8			i, rsp_source = 0;
-	boolean			bt_busy = false, limited_dig = false;
-	boolean			wifi_connected = false;
-
-	coex_sta->c2h_bt_info_req_sent = false;
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8723B_2ANT_MAX)
-		rsp_source = BT_INFO_SRC_8723B_2ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), return for Manual CTRL<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	/* if 0xff, it means BT is under WHCK test */
-	if (bt_info == 0xff)
-		coex_sta->bt_whck_test = true;
-	else
-		coex_sta->bt_whck_test = false;
-
-	if (BT_INFO_SRC_8723B_2ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 + 10;
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		if (coex_sta->bt_info_c2h[rsp_source][2] & 0x20)
-			coex_sta->c2h_bt_remote_name_req = true;
-		else
-			coex_sta->c2h_bt_remote_name_req = false;
-
-		if (coex_sta->bt_info_c2h[rsp_source][1] == 0x49) {
-			coex_sta->a2dp_bit_pool =
-				coex_sta->bt_info_c2h[rsp_source][6];
-		} else
-			coex_sta->a2dp_bit_pool = 0;
-
-		coex_sta->bt_tx_rx_mask = (coex_sta->bt_info_c2h[rsp_source][2]
-					   & 0x40);
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TX_RX_MASK,
-				   &coex_sta->bt_tx_rx_mask);
-		if (coex_sta->bt_tx_rx_mask) {
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x01 => Need to switch BT TRx Mask */
-			/* BT TRx mask off */
-			btcoexist->btc_set_bt_trx_mask(btcoexist, 0);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex], BT TRx Mask off for BT Info Notify\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x01\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF,
-						  0x3c, 0x01);
-#endif
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if ((coex_sta->bt_info_ext & BIT(1))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-			if (wifi_connected)
-				ex_halbtc8723b2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8723b2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-		if ((coex_sta->bt_info_ext & BIT(3))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_ignore_wlan_act(btcoexist, FORCE_EXEC,
-							false);
-		} else {
-			/* BT already NOT ignore Wlan active, do nothing here. */
-		}
-#if (BT_AUTO_REPORT_ONLY_8723B_2ANT == 0)
-		if ((coex_sta->bt_info_ext & BIT(4))) {
-			/* BT auto report already enabled, do nothing */
-		} else
-			halbtc8723b2ant_bt_auto_report(btcoexist, FORCE_EXEC,
-						       true);
-#endif
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8723B_2ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8723B_2ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8723B_2ANT_B_FTP)
-			coex_sta->pan_exist = true;
-		else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8723B_2ANT_B_A2DP)
-			coex_sta->a2dp_exist = true;
-		else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8723B_2ANT_B_HID)
-			coex_sta->hid_exist = true;
-		else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8723B_2ANT_B_SCO_ESCO)
-			coex_sta->sco_exist = true;
-		else
-			coex_sta->sco_exist = false;
-
-		if ((coex_sta->hid_exist == false) &&
-		    (coex_sta->c2h_bt_inquiry_page == false) &&
-		    (coex_sta->sco_exist == false)) {
-			if (coex_sta->high_priority_tx  +
-			    coex_sta->high_priority_rx >= 160) {
-				coex_sta->hid_exist = true;
-				bt_info = bt_info | 0x28;
-			}
-		}
-	}
-
-	halbtc8723b2ant_update_bt_link_info(btcoexist);
-
-	if (!(bt_info & BT_INFO_8723B_2ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info ==
-		BT_INFO_8723B_2ANT_B_CONNECTION) {	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if ((bt_info & BT_INFO_8723B_2ANT_B_SCO_ESCO) ||
-		   (bt_info & BT_INFO_8723B_2ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info & BT_INFO_8723B_2ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((BT_8723B_2ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8723B_2ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status)) {
-		bt_busy = true;
-		limited_dig = true;
-	} else {
-		bt_busy = false;
-		limited_dig = false;
-	}
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	coex_dm->limited_dig = limited_dig;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_LIMITED_DIG, &limited_dig);
-
-	halbtc8723b2ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8723b2ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8723b2ant_wifi_off_hw_cfg(btcoexist);
-	/* remove due to interrupt is disabled that polling c2h will fail and delay 100ms. */
-	/* btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x3c, 0x15); */ /*BT goto standby while GNT_BT 1-->0 */
-	halbtc8723b2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-
-	ex_halbtc8723b2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-}
-
-void ex_halbtc8723b2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_WIFI_PNP_SLEEP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		/* Sinda 20150819, workaround for driver skip leave IPS/LPS to speed up sleep time. */
-		/* Driver do not leave IPS/LPS when driver is going to sleep, so BTCoexistence think wifi is still under IPS/LPS */
-		/* BT should clear UnderIPS/UnderLPS state to avoid mismatch state after wakeup. */
-		coex_sta->under_ips = false;
-		coex_sta->under_lps = false;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-		halbtc8723b2ant_init_hw_config(btcoexist, false);
-		halbtc8723b2ant_init_coex_dm(btcoexist);
-		halbtc8723b2ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8723b2ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	u32 bt_patch_ver;
-
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ==========================Periodical===========================\n");
-	BTC_TRACE(trace_buf);
-	if (coex_sta->dis_ver_info_cnt <= 5) {
-		coex_sta->dis_ver_info_cnt += 1;
-		if (coex_sta->dis_ver_info_cnt == 3) {
-			/* Antenna config to set 0x765 = 0x0 (GNT_BT control by PTA) after initial */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Set GNT_BT control by PTA\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723b2ant_set_ant_path(btcoexist,
-				     BTC_ANT_WIFI_AT_MAIN, false, false);
-		}
-	}
-
-	if (((coex_sta->bt_coex_supported_version == 0) ||
-	     (coex_sta->bt_coex_supported_version == 0xffff)) && (!coex_sta->bt_disabled))
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION, &coex_sta->bt_coex_supported_version);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-#if (BT_AUTO_REPORT_ONLY_8723B_2ANT == 0)
-	halbtc8723b2ant_query_bt_info(btcoexist);
-	halbtc8723b2ant_monitor_bt_enable_disable(btcoexist);
-#else
-	halbtc8723b2ant_monitor_bt_ctr(btcoexist);
-	halbtc8723b2ant_monitor_wifi_ctr(btcoexist);
-
-	/* for some BT speaker that Hi-Pri pkt appear begore start play, this will cause HID exist */
-	if ((coex_sta->high_priority_tx  + coex_sta->high_priority_rx < 50) &&
-	    (bt_link_info->hid_exist == true))
-		bt_link_info->hid_exist  = false;
-
-	if (halbtc8723b2ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust)
-		halbtc8723b2ant_run_coexist_mechanism(btcoexist);
-#endif
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b2ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b2ant.h
deleted file mode 100644
index fb6149a68d92..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723b2ant.h
+++ /dev/null
@@ -1,231 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8723B_SUPPORT == 1)
-/* *******************************************
- * The following is for 8723B 2Ant BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8723B_2ANT				1
-
-
-#define	BT_INFO_8723B_2ANT_B_FTP						BIT(7)
-#define	BT_INFO_8723B_2ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8723B_2ANT_B_HID						BIT(5)
-#define	BT_INFO_8723B_2ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8723B_2ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8723B_2ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8723B_2ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8723B_2ANT_B_CONNECTION				BIT(0)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT		2
-
-
-#define	BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES				42  /* WiFi RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation */
-#define	BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES				46 /* BT RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation */
-
-enum bt_info_src_8723b_2ant {
-	BT_INFO_SRC_8723B_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723B_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8723B_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8723B_2ANT_MAX
-};
-
-enum bt_8723b_2ant_bt_status {
-	BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8723B_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8723B_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8723B_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8723B_2ANT_BT_STATUS_MAX
-};
-
-enum bt_8723b_2ant_coex_algo {
-	BT_8723B_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8723B_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8723B_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8723B_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8723B_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8723B_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8723B_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8723B_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8723B_2ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-struct coex_dm_8723b_2ant {
-	/* fw mechanism */
-	u8		pre_bt_dec_pwr_lvl;
-	u8		cur_bt_dec_pwr_lvl;
-	u8		pre_fw_dac_swing_lvl;
-	u8		cur_fw_dac_swing_lvl;
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		reset_tdma_adjust;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-
-	/* sw mechanism */
-	boolean		pre_rf_rx_lpf_shrink;
-	boolean		cur_rf_rx_lpf_shrink;
-	u32		bt_rf_0x1e_backup;
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	boolean		pre_dac_swing_on;
-	u32		pre_dac_swing_lvl;
-	boolean		cur_dac_swing_on;
-	u32		cur_dac_swing_lvl;
-	boolean		pre_adc_back_off;
-	boolean		cur_adc_back_off;
-	boolean	pre_agc_table_en;
-	boolean		cur_agc_table_en;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	boolean		need_recover0x948;
-	u32		backup0x948;
-
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	boolean		is_switch_to_1dot5_ant;
-	u8		switch_thres_offset;
-};
-
-struct coex_sta_8723b_2ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-	boolean					bt_abnormal_scan;
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	u8					bt_rssi;
-	boolean					bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8723B_2ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723B_2ANT_MAX];
-	boolean				bt_whck_test;
-	boolean					c2h_bt_inquiry_page;
-	boolean					c2h_bt_remote_name_req;
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	u32					bt_coex_supported_version;
-
-	u8					coex_table_type;
-	boolean					force_lps_on;
-
-	u8					dis_ver_info_cnt;
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8723b2ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b2ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8723b2ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b2ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8723b2ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8723b2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8723b2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8723b2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8723b2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8723b2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8723b2ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8723b2ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8723b2ant_display_coex_info(IN struct btc_coexist *btcoexist);
-
-#else
-#define	ex_halbtc8723b2ant_power_on_setting(btcoexist)
-#define	ex_halbtc8723b2ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8723b2ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8723b2ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8723b2ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8723b2ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8723b2ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8723b2ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8723b2ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8723b2ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8723b2ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8723b2ant_halt_notify(btcoexist)
-#define	ex_halbtc8723b2ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8723b2ant_periodical(btcoexist)
-#define	ex_halbtc8723b2ant_display_coex_info(btcoexist)
-
-#endif
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723bwifionly.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723bwifionly.c
deleted file mode 100644
index d1a8361c4d41..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723bwifionly.c
+++ /dev/null
@@ -1,82 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 "mp_precomp.h"
-
-
-VOID
-ex_hal8723b_wifi_only_hw_config(
-	IN struct wifi_only_cfg *pwifionlycfg
-	)
-{
-	struct wifi_only_haldata *pwifionly_haldata = &pwifionlycfg->haldata_info;
-
-
-	halwifionly_write1byte(pwifionlycfg, 0x778, 0x3); /* Set pta for wifi first priority, 0x1 need to reference pta table to determine wifi and bt priority */
-	halwifionly_bitmaskwrite1byte(pwifionlycfg, 0x40, 0x20, 0x1);
-
-	/* Set Antenna path to Wifi */
-	halwifionly_write2byte(pwifionlycfg, 0x0765, 0x8); /* Set pta for wifi first priority, 0x0 need to reference pta table to determine wifi and bt priority */
-	halwifionly_write2byte(pwifionlycfg, 0x076e, 0xc);
-
-	halwifionly_write4byte(pwifionlycfg, 0x000006c0, 0xaaaaaaaa); /* pta table, 0xaaaaaaaa means wifi is higher priority than bt */
-	halwifionly_write4byte(pwifionlycfg, 0x000006c4, 0xaaaaaaaa);
-
-	halwifionly_bitmaskwrite1byte(pwifionlycfg, 0x67, 0x20, 0x1); /* BT select s0/s1 is controlled by WiFi */
-
-	/* 0x948 setting */
-	if (pwifionlycfg->chip_interface == WIFIONLY_INTF_PCI) {
-		/* HP Foxconn NGFF at S0
-		 not sure HP pg correct or not(EEPROMBluetoothSingleAntPath), so here we just write
-		 0x948=0x280 for HP HW id NIC. */
-		if (pwifionly_haldata->customer_id == CUSTOMER_HP_1) {
-			halwifionly_write4byte(pwifionlycfg, 0x948, 0x280);
-			halwifionly_phy_set_rf_reg(pwifionlycfg, 0, 0x1, 0xfffff, 0x0); /* WiFi TRx Mask off */
-			return;
-		}
-	}
-
-	if (pwifionly_haldata->efuse_pg_antnum == 2) {
-		halwifionly_write4byte(pwifionlycfg, 0x948, 0x0);
-	} else {
-	/* 3Attention !!! For 8723BU  !!!!
-	 For 8723BU single ant case: jira [USB-1237]
-		   Because of 8723BU S1 has HW problem, we only can use S0 instead.
-		   Whether Efuse 0xc3 [6] is 0 or 1, we should always use S0 and write 0x948 to 80/280
-
-	 --------------------------------------------------
-	 BT Team :
-		  When in Single Ant case, Reg[0x948] has two case : 0x80 or 0x200
-		 When in Two Ant case, Reg[0x948] has two case : 0x280 or 0x0
-		  Efuse 0xc3 [6] Antenna Path
-		  0xc3 [6] = 0	 ==>  S1	 ==>   0x948 = 0/40/200
-		  0xc3 [6] = 1	 ==>  S0	 ==>   0x948 = 80/240/280 */
-
-		if (pwifionlycfg->chip_interface == WIFIONLY_INTF_USB)
-			halwifionly_write4byte(pwifionlycfg, 0x948, 0x80);
-		else {
-			if (pwifionly_haldata->efuse_pg_antpath == 0)
-				halwifionly_write4byte(pwifionlycfg, 0x948, 0x0);
-			else
-				halwifionly_write4byte(pwifionlycfg, 0x948, 0x280);
-		}
-
-	}
-
-
-	/* after 8723B F-cut, TRx Mask should be set when 0x948=0x0 or 0x280
-	PHY_SetRFReg(Adapter, 0, 0x1, 0xfffff, 0x780); WiFi TRx Mask on */
-	halwifionly_phy_set_rf_reg(pwifionlycfg, 0, 0x1, 0xfffff, 0x0); /*WiFi TRx Mask off */
-
-}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.c
index 1fae248f02c4..527b87fa2dcc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -48,155 +49,13 @@ const char *const glbt_info_src_8723d_1ant[] = {
 	"BT Info[bt rsp]",
 	"BT Info[bt auto report]",
 };
-/* ************************************************************
- * BtCoex Version Format:
- * 1. date :			glcoex_ver_date_XXXXX_1ant
- * 2. WifiCoexVersion : glcoex_ver_XXXX_1ant
- * 3. BtCoexVersion :	glcoex_ver_btdesired_XXXXX_1ant
- * 4. others :			glcoex_ver_XXXXXX_XXXXX_1ant
- *
- * Variable should be indicated IC and Antenna numbers !!!
- * Please strictly follow this order and naming style !!!
- *
- * ************************************************************ */
-u32	glcoex_ver_date_8723d_1ant = 20171025;
-u32	glcoex_ver_8723d_1ant = 0x20;
-u32 glcoex_ver_btdesired_8723d_1ant = 0x20;
-
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8723d1ant_
- * ************************************************************ */
-u8 halbtc8723d1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8723d1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
 
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
+u32	glcoex_ver_date_8723d_1ant = 20181130;
+u32	glcoex_ver_8723d_1ant = 0x2e;
+u32	glcoex_ver_btdesired_8723d_1ant = 0x2d;
 
+#if 0
+static
 void halbtc8723d1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
 				    IN boolean force_exec, IN u32 dis_rate_mask)
 {
@@ -208,6 +67,7 @@ void halbtc8723d1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
 }
 
+static
 void halbtc8723d1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
 		IN boolean force_exec, IN u8 type)
 {
@@ -247,6 +107,7 @@ void halbtc8723d1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
 }
 
+static
 void halbtc8723d1ant_retry_limit(IN struct btc_coexist *btcoexist,
 				 IN boolean force_exec, IN u8 type)
 {
@@ -272,6 +133,7 @@ void halbtc8723d1ant_retry_limit(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
 }
 
+static
 void halbtc8723d1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
 				    IN boolean force_exec, IN u8 type)
 {
@@ -281,11 +143,11 @@ void halbtc8723d1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
 	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
 		switch (coex_dm->cur_ampdu_time_type) {
 		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
+			btcoexist->btc_write_1byte(btcoexist, 0x455,
 					   coex_dm->backup_ampdu_max_time);
 			break;
 		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
+			btcoexist->btc_write_1byte(btcoexist, 0x455,
 						   0x38);
 			break;
 		default:
@@ -295,58 +157,177 @@ void halbtc8723d1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
 
 	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
 }
+#endif
 
-void halbtc8723d1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
+static void
+halbtc8723d1ant_limited_tx(struct btc_coexist *btcoexist, boolean force_exec,
+			   boolean tx_limit_en,  boolean ampdu_limit_en)
 {
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8723d1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8723d1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8723d1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
+	boolean wifi_under_b_mode = FALSE;
+	u32	wifi_link_status = 0, num_of_wifi_link = 0;
+
+	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
+			   &wifi_link_status);
+
+	num_of_wifi_link = wifi_link_status >> 16;
+
+	/* Force Max Tx retry limit = 8*/
+	if (!coex_sta->wl_tx_limit_en) {
+		coex_sta->wl_0x430_backup =
+			btcoexist->btc_read_4byte(btcoexist, 0x430);
+		coex_sta->wl_0x434_backup =
+			btcoexist->btc_read_4byte(btcoexist, 0x434);
+		coex_sta->wl_0x42a_backup =
+			btcoexist->btc_read_2byte(btcoexist, 0x42a);
 	}
 
-	halbtc8723d1ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8723d1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8723d1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
+	if (!coex_sta->wl_ampdu_limit_en)
+		coex_sta->wl_0x456_backup = btcoexist->btc_read_1byte(btcoexist,
+								      0x456);
+
+	if (!force_exec && tx_limit_en == coex_sta->wl_tx_limit_en &&
+	    ampdu_limit_en == coex_sta->wl_ampdu_limit_en)
+		return;
+
+	coex_sta->wl_tx_limit_en = tx_limit_en;
+	coex_sta->wl_ampdu_limit_en = ampdu_limit_en;
+
+	if (tx_limit_en) {
+		/* Set BT polluted packet on for Tx rate adaptive not
+		 *including Tx retry break by PTA, 0x45c[19] =1
+		 *
+		 * Set queue life time to avoid can't reach tx retry limit
+		 * if tx is always break by GNT_BT.
+		 */
+		if ((wifi_link_status & WIFI_STA_CONNECTED) &&
+		     num_of_wifi_link == 1) {
+			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x1);
+			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x426, 0xf, 0xf);
+		}
+
+		/* Max Tx retry limit = 8*/
+		btcoexist->btc_write_2byte(btcoexist, 0x42a, 0x0808);
+
+		/* AMPDU duration limit*/
+		btcoexist->btc_write_1byte(btcoexist, 0x456, 0x20);
+
+		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
+				   &wifi_under_b_mode);
+
+		/* Auto rate fallback step within 8 retry*/
+		if (wifi_under_b_mode) {
+			btcoexist->btc_write_4byte(btcoexist, 0x430, 0x1000000);
+			btcoexist->btc_write_4byte(btcoexist, 0x434, 0x1010101);
+		} else {
+			btcoexist->btc_write_4byte(btcoexist, 0x430, 0x1000000);
+			btcoexist->btc_write_4byte(btcoexist, 0x434, 0x4030201);
+		}
+	} else {
+		/* Set BT polluted packet on for Tx rate adaptive not
+		 *including Tx retry break by PTA, 0x45c[19] =1
+		 */
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x0);
+
+		/* Set queue life time to avoid can't reach tx retry limit
+		 * if tx is always break by GNT_BT.
+		 */
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x426, 0xf, 0x0);
+
+		/* Recovery Max Tx retry limit*/
+		btcoexist->btc_write_2byte(btcoexist, 0x42a,
+					   coex_sta->wl_0x42a_backup);
+		btcoexist->btc_write_4byte(btcoexist, 0x430,
+					   coex_sta->wl_0x430_backup);
+		btcoexist->btc_write_4byte(btcoexist, 0x434,
+					   coex_sta->wl_0x434_backup);
+	}
+
+	if (ampdu_limit_en)
+		btcoexist->btc_write_1byte(btcoexist, 0x456, 0x20);
+	else
+		btcoexist->btc_write_1byte(btcoexist, 0x456,
+					   coex_sta->wl_0x456_backup);
 }
 
-void halbtc8723d1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
+static void
+halbtc8723d1ant_limited_rx(struct btc_coexist *btcoexist, boolean force_exec,
+			   boolean rej_ap_agg_pkt, boolean bt_ctrl_agg_buf_size,
+			   u8 agg_buf_size)
 {
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
+#if 0
+	boolean reject_rx_agg = rej_ap_agg_pkt;
+	boolean bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
+	u8 rx_agg_size = agg_buf_size;
+
+	if (!force_exec &&
+	    bt_ctrl_agg_buf_size == coex_sta->wl_rxagg_limit_en &&
+	    agg_buf_size == coex_sta->wl_rxagg_size)
+		return;
+
+	coex_sta->wl_rxagg_limit_en = bt_ctrl_agg_buf_size;
+	coex_sta->wl_rxagg_size = agg_buf_size;
+
+	/*btc->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
+	 *&reject_rx_agg);
+	 */
 	/* decide BT control aggregation buf size or not */
 	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
 			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
+	/* aggregation buf size, only work
+	 * when BT control Rx aggregation size
+	 */
 	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
 	/* real update aggregation setting */
 	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
+#endif
+}
+
+static
+void halbtc8723d1ant_set_fw_low_penalty_ra(IN struct btc_coexist *btcoexist,
+					   IN boolean low_penalty_ra)
+{
+	u8  h2c_parameter[6] = {0};
+
+	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
+
+	if (low_penalty_ra) {
+		h2c_parameter[1] |= BIT(0);
+
+		/* normal rate except MCS7/6/5, OFDM54/48/36 */
+		h2c_parameter[2] = 0x00;
+		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
+		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
+		h2c_parameter[5] = 0xf9;  /* MCS5 or OFDM36 */
+	}
+
+	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
+}
+
+static
+void halbtc8723d1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
+				    IN boolean force_exec,
+				    IN boolean low_penalty_ra)
+{
+	coex_dm->cur_low_penalty_ra = low_penalty_ra;
+
+	if (!force_exec) {
+		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
+			return;
+	}
 
+	halbtc8723d1ant_set_fw_low_penalty_ra(btcoexist,
+					      coex_dm->cur_low_penalty_ra);
 
+#if 0
+	if (low_penalty_ra)
+		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 15);
+	else
+		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
+#endif
+	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
 }
 
+static
 void halbtc8723d1ant_query_bt_info(IN struct btc_coexist *btcoexist)
 {
 	u8			h2c_parameter[1] = {0};
@@ -360,12 +341,13 @@ void halbtc8723d1ant_query_bt_info(IN struct btc_coexist *btcoexist)
 	BTC_TRACE(trace_buf);
 }
 
+static
 void halbtc8723d1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 {
 	u32 reg_hp_txrx, reg_lp_txrx, u32tmp;
 	u32 reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0, cnt_slave = 0, cnt_overhead = 0,
-				cnt_autoslot_hang = 0;
+	static u8	num_of_bt_counter_chk = 0, cnt_overhead = 0,
+		cnt_autoslot_hang = 0;
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
 	/* to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS */
@@ -393,59 +375,40 @@ void halbtc8723d1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 
 	BTC_TRACE(trace_buf);
 
-	if (BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		coex_dm->bt_status) {
-
-			if (coex_sta->high_priority_rx >= 15) {
-					if (cnt_overhead < 3)
-						cnt_overhead++;
+	if (coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE) {
+		if (coex_sta->high_priority_rx >= 15) {
+			if (cnt_overhead < 3)
+				cnt_overhead++;
 
-					if (cnt_overhead == 3)
-						coex_sta->is_hiPri_rx_overhead = TRUE;
-			} else {
-					if (cnt_overhead > 0)
-						cnt_overhead--;
+			if (cnt_overhead == 3)
+				coex_sta->is_hipri_rx_overhead = TRUE;
+		} else {
+			if (cnt_overhead > 0)
+				cnt_overhead--;
 
-					if (cnt_overhead == 0)
-						coex_sta->is_hiPri_rx_overhead = FALSE;
-			}
-	} else
-		coex_sta->is_hiPri_rx_overhead = FALSE;
+			if (cnt_overhead == 0)
+				coex_sta->is_hipri_rx_overhead = FALSE;
+		}
+	} else {
+		coex_sta->is_hipri_rx_overhead = FALSE;
+	}
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-			reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
+		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
+		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
 
 	BTC_TRACE(trace_buf);
 
 	/* reset counter */
 	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
 
-	if ((coex_sta->low_priority_tx > 1150)	&&
-		(!coex_sta->c2h_bt_inquiry_page))
+	if (coex_sta->low_priority_tx > 1150 &&
+	    !coex_sta->c2h_bt_inquiry_page)
 		coex_sta->pop_event_cnt++;
 
-	if ((coex_sta->low_priority_rx >= 1150) &&
-		(coex_sta->low_priority_rx >= coex_sta->low_priority_tx)
-		&& (!coex_sta->under_ips)  && (!coex_sta->c2h_bt_inquiry_page) &&
-		(coex_sta->bt_link_exist))	{
-		if (cnt_slave >= 2) {
-			bt_link_info->slave_role = TRUE;
-			cnt_slave = 2;
-		} else
-			cnt_slave++;
-	} else {
-		if (cnt_slave == 0) {
-			bt_link_info->slave_role = FALSE;
-			cnt_slave = 0;
-		} else
-			cnt_slave--;
-
-	}
-
 	if (coex_sta->is_tdma_btautoslot) {
-		if ((coex_sta->low_priority_tx >= 1300) &&
-			(coex_sta->low_priority_rx <= 150)) {
+		if (coex_sta->low_priority_tx >= 1300 &&
+		    coex_sta->low_priority_rx <= 150) {
 			if (cnt_autoslot_hang >= 2) {
 				coex_sta->is_tdma_btautoslot_hang = TRUE;
 				cnt_autoslot_hang = 2;
@@ -468,11 +431,10 @@ void halbtc8723d1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 	}
 
 	if (!coex_sta->bt_disabled) {
-
-		if ((coex_sta->high_priority_tx == 0) &&
-			(coex_sta->high_priority_rx == 0) &&
-			(coex_sta->low_priority_tx == 0) &&
-			(coex_sta->low_priority_rx == 0)) {
+		if (coex_sta->high_priority_tx == 0 &&
+		    coex_sta->high_priority_rx == 0 &&
+		    coex_sta->low_priority_tx == 0 &&
+		    coex_sta->low_priority_rx == 0) {
 			num_of_bt_counter_chk++;
 			if (num_of_bt_counter_chk >= 3) {
 				halbtc8723d1ant_query_bt_info(btcoexist);
@@ -483,6 +445,7 @@ void halbtc8723d1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 
 }
 
+static
 void halbtc8723d1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
 {
 	s32 wifi_rssi = 0;
@@ -493,13 +456,12 @@ void halbtc8723d1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
 		  wl_noisy_count1 = 3, wl_noisy_count2 = 0;
 	u32 total_cnt, reg_val1, reg_val2, cnt_cck;
 	u32 cnt_crcok = 0, cnt_crcerr = 0;
-	static u8 cnt = 0, cnt_ccklocking = 0;
+	static u8 cnt = 0, cnt_ccklocking;
 	u8	h2c_parameter[1] = {0};
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
 	/*send h2c to query WL FW dbg info	*/
-	if (((coex_dm->cur_ps_tdma_on) && (coex_sta->force_lps_ctrl)) ||
-		 ((coex_sta->acl_busy) && (bt_link_info->a2dp_exist))) {
+	if (coex_dm->cur_ps_tdma_on) {
 		h2c_parameter[0] = 0x8;
 		btcoexist->btc_fill_h2c(btcoexist, 0x69, 1, h2c_parameter);
 	}
@@ -595,18 +557,21 @@ void halbtc8723d1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
 
 }
 
-
-
-
+static
 void halbtc8723d1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 {
-	struct	btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean		bt_hs_on = FALSE;
-	boolean		bt_busy = FALSE;
-	u32			val = 0;
-	static	u8		pre_num_of_profile = 0, cur_num_of_profile = 0, cnt = 0;
+	struct btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
+	boolean		bt_hs_on = FALSE, bt_busy = FALSE;
+	u32		val = 0, wifi_link_status = 0, num_of_wifi_link = 0;
+	static u8		pre_num_of_profile, cur_num_of_profile, cnt;
+	static boolean	pre_ble_scan_en;
+
+	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
+			   &wifi_link_status);
+
+	num_of_wifi_link = wifi_link_status >> 16;
 
-	if (coex_sta->is_ble_scan_toggle) {
+	if (coex_sta->is_ble_scan_en && !pre_ble_scan_en) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 					"[BTCoex], BT ext info bit4 check, query BLE Scan type!!\n");
 				BTC_TRACE(trace_buf);
@@ -623,6 +588,7 @@ void halbtc8723d1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist, 0x4);
 	}
 
+	pre_ble_scan_en = coex_sta->is_ble_scan_en;
 	coex_sta->num_of_profile = 0;
 
 	/* set link exist status */
@@ -770,7 +736,8 @@ void halbtc8723d1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 			btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_DEVICE_INFO, &val);
 
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BtInfoNotify(), get BT DEVICE_INFO = %x\n", val);
+				    "[BTCoex], BtInfoNotify(), get BT DEVICE_INFO = %x\n",
+				    val);
 			BTC_TRACE(trace_buf);
 
 			coex_sta->bt_a2dp_vendor_id = (u8)(val & 0xff);
@@ -785,10 +752,13 @@ void halbtc8723d1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 			if (cnt > 0)
 				cnt--;
 
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL, &val);
+			btcoexist->btc_get(btcoexist,
+					   BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL,
+					   &val);
 
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BtInfoNotify(), get BT FORBIDDEN_SLOT_VAL = %x, cnt = %d\n", val, cnt);
+				    "[BTCoex], BtInfoNotify(), get BT FORBIDDEN_SLOT_VAL = %x, cnt = %d\n",
+				    val, cnt);
 			BTC_TRACE(trace_buf);
 
 			coex_sta->legacy_forbidden_slot = (u16)(val & 0xffff);
@@ -797,9 +767,40 @@ void halbtc8723d1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 	}
 
 	pre_num_of_profile = coex_sta->num_of_profile;
-}
 
+	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
+		return;
+
+	if (num_of_wifi_link == 0 ||
+	    coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE) {
+		halbtc8723d1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
+		halbtc8723d1ant_limited_tx(btcoexist, NORMAL_EXEC, FALSE,
+					   FALSE);
+		halbtc8723d1ant_limited_rx(btcoexist, NM_EXCU, FALSE, TRUE, 64);
+	} else if (wifi_link_status & WIFI_P2P_GO_CONNECTED ||
+		   wifi_link_status & WIFI_P2P_GC_CONNECTED) {
+		halbtc8723d1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
+		halbtc8723d1ant_limited_tx(btcoexist, NM_EXCU, TRUE, TRUE);
+		halbtc8723d1ant_limited_rx(btcoexist, NM_EXCU, FALSE, TRUE, 16);
+	} else {
+		halbtc8723d1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
+
+		if (bt_link_info->hid_exist || coex_sta->hid_pair_cnt > 0 ||
+		    bt_link_info->sco_exist) {
+			halbtc8723d1ant_limited_tx(btcoexist, NM_EXCU, TRUE,
+						   TRUE);
+			halbtc8723d1ant_limited_rx(btcoexist, NM_EXCU, FALSE,
+						   TRUE, 16);
+		} else {
+			halbtc8723d1ant_limited_tx(btcoexist, NM_EXCU, TRUE,
+						   FALSE);
+			halbtc8723d1ant_limited_rx(btcoexist, NM_EXCU, FALSE,
+						   TRUE, 64);
+		}
+	}
+}
 
+static
 void halbtc8723d1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
 		IN u8 type)
 {
@@ -831,6 +832,7 @@ void halbtc8723d1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
 
 }
 
+static
 u8 halbtc8723d1ant_action_algorithm(IN struct btc_coexist *btcoexist)
 {
 	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
@@ -1035,81 +1037,7 @@ u8 halbtc8723d1ant_action_algorithm(IN struct btc_coexist *btcoexist)
 	return algorithm;
 }
 
-void halbtc8723d1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8723d1ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8723d1ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8723d1ant_set_fw_low_penalty_ra(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-#if 1
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xf9;	/* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-#endif
-}
-
-void halbtc8723d1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-#if 1
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-
-	halbtc8723d1ant_set_fw_low_penalty_ra(btcoexist,
-					      coex_dm->cur_low_penalty_ra);
-
-#if 0
-	if (low_penalty_ra)
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 15);
-	else
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
-#endif
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-
-#endif
-
-}
-
+static
 void halbtc8723d1ant_write_score_board(
 	IN	struct  btc_coexist		*btcoexist,
 	IN	u16				bitpos,
@@ -1137,7 +1065,7 @@ void halbtc8723d1ant_write_score_board(
 	}
 }
 
-
+static
 void halbtc8723d1ant_read_score_board(
 	IN	struct  btc_coexist		*btcoexist,
 	IN   u16				*score_board_val
@@ -1148,6 +1076,7 @@ void halbtc8723d1ant_read_score_board(
 			    0xaa)) & 0x7fff;
 }
 
+static
 void halbtc8723d1ant_post_state_to_bt(
 	IN	struct  btc_coexist		*btcoexist,
 	IN	u16						type,
@@ -1162,6 +1091,7 @@ void halbtc8723d1ant_post_state_to_bt(
 	halbtc8723d1ant_write_score_board(btcoexist, (u16) type, state);
 }
 
+static
 boolean halbtc8723d1ant_is_wifibt_status_changed(IN struct btc_coexist
 		*btcoexist)
 {
@@ -1264,8 +1194,8 @@ boolean halbtc8723d1ant_is_wifibt_status_changed(IN struct btc_coexist
 			return TRUE;
 		}
 
-		if (pre_bt_setup_link != coex_sta->is_setupLink) {
-			pre_bt_setup_link = coex_sta->is_setupLink;
+		if (pre_bt_setup_link != coex_sta->is_setup_link) {
+			pre_bt_setup_link = coex_sta->is_setup_link;
 			return TRUE;
 		}
 	}
@@ -1273,36 +1203,20 @@ boolean halbtc8723d1ant_is_wifibt_status_changed(IN struct btc_coexist
 	return FALSE;
 }
 
+static
 void halbtc8723d1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
 {
 	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = TRUE, bt_disabled = FALSE;
-	u16			u16tmp;
-
-	/* This function check if bt is disabled */
-#if 0
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = FALSE;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = FALSE;
-
-
-#else
-
-	/* Read BT on/off status from scoreboard[1], enable this only if BT patch support this feature */
-	halbtc8723d1ant_read_score_board(btcoexist,	&u16tmp);
+	boolean		bt_active = TRUE, bt_disabled = FALSE;
+	u16		u16tmp;
 
+	/* This function check if bt is disabled
+	 * Read BT on/off status from scoreboard[1],
+	 *enable this only if BT patch support this feature
+	 */
+	halbtc8723d1ant_read_score_board(btcoexist, &u16tmp);
 	bt_active = u16tmp & BIT(1);
 
-
-#endif
-
 	if (bt_active) {
 		bt_disable_cnt = 0;
 		bt_disabled = FALSE;
@@ -1320,11 +1234,6 @@ void halbtc8723d1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
 				   &bt_disabled);
 	}
 
-	if (bt_disabled)
-		halbtc8723d1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-	else
-		halbtc8723d1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
-
 	if (coex_sta->bt_disabled != bt_disabled) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			    "[BTCoex], BT is from %s to %s!!\n",
@@ -1336,8 +1245,7 @@ void halbtc8723d1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
 
 }
 
-
-
+static
 void halbtc8723d1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
 					boolean isenable)
 {
@@ -1377,6 +1285,7 @@ void halbtc8723d1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
 #endif
 }
 
+static
 u32 halbtc8723d1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
 		IN u16 reg_addr)
 {
@@ -1384,7 +1293,7 @@ u32 halbtc8723d1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
 
 	while (1) {
 		if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-			delay_ms(50);
+			delay_ms(10);
 			delay_count++;
 			if (delay_count >= 10) {
 				delay_count = 0;
@@ -1402,6 +1311,7 @@ u32 halbtc8723d1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
 
 }
 
+static
 void halbtc8723d1ant_ltecoex_indirect_write_reg(IN struct btc_coexist
 		*btcoexist,
 		IN u16 reg_addr, IN u32 bit_mask, IN u32 reg_value)
@@ -1415,7 +1325,7 @@ void halbtc8723d1ant_ltecoex_indirect_write_reg(IN struct btc_coexist
 		/* wait for ready bit before access 0x7c0/0x7c4 */
 		while (1) {
 			if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-				delay_ms(50);
+				delay_ms(10);
 				delay_count++;
 				if (delay_count >= 10) {
 					delay_count = 0;
@@ -1466,6 +1376,7 @@ void halbtc8723d1ant_ltecoex_indirect_write_reg(IN struct btc_coexist
 
 }
 
+static
 void halbtc8723d1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
 				    IN boolean enable)
 {
@@ -1477,8 +1388,9 @@ void halbtc8723d1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
 
 }
 
-void halbtc8723d1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_control)
+static
+void halbtc8723d1ant_coex_ctrl_owner(IN struct btc_coexist *btcoexist,
+				     IN boolean wifi_control)
 {
 	u8 val;
 
@@ -1488,6 +1400,7 @@ void halbtc8723d1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
 
 }
 
+static
 void halbtc8723d1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
 			IN u8 control_block, IN boolean sw_control, IN u8 state)
 {
@@ -1520,7 +1433,7 @@ void halbtc8723d1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
 				0x38, 0xffffffff, val);
 }
 
-
+static
 void halbtc8723d1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
 			IN u8 control_block, IN boolean sw_control, IN u8 state)
 {
@@ -1553,7 +1466,7 @@ void halbtc8723d1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
 		0xffffffff, val);
 }
 
-
+static
 void halbtc8723d1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
 		IN u8 table_type, IN u16 table_content)
 {
@@ -1575,119 +1488,51 @@ void halbtc8723d1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
 
 }
 
-
-void halbtc8723d1ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u8 table_content)
+static
+void halbtc8723d1ant_coex_table(IN struct btc_coexist *btcoexist,
+				IN boolean force_exec, IN u32 val0x6c0,
+				IN u32 val0x6c4, IN u32 val0x6c8,
+				IN u8 val0x6cc)
 {
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8723D_1ANT_LBTT_WL_BREAK_LTE:
-		reg_addr = 0xa8;
-		break;
-	case BT_8723D_1ANT_LBTT_BT_BREAK_LTE:
-		reg_addr = 0xac;
-		break;
-	case BT_8723D_1ANT_LBTT_LTE_BREAK_WL:
-		reg_addr = 0xb0;
-		break;
-	case BT_8723D_1ANT_LBTT_LTE_BREAK_BT:
-		reg_addr = 0xb4;
-		break;
+	if (!force_exec) {
+		if (val0x6c0 == coex_dm->cur_val0x6c0 &&
+		    val0x6c4 == coex_dm->cur_val0x6c4 &&
+		    val0x6c8 == coex_dm->cur_val0x6c8 &&
+		    val0x6cc == coex_dm->cur_val0x6cc)
+			return;
 	}
 
-	if (reg_addr != 0x0000)
-		halbtc8723d1ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xff, table_content); /* 0xa8[15:0] or 0xb4[15:0] */
+	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
+	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
+	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
+	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
+
+	coex_dm->cur_val0x6c0 = val0x6c0;
+	coex_dm->cur_val0x6c4 = val0x6c4;
+	coex_dm->cur_val0x6c8 = val0x6c8;
+	coex_dm->cur_val0x6cc = val0x6cc;
+
+	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+		    "[BTCoex], 0x6c0 = 0x%x, 0x6c4 = 0x%x, 0x6c8 = 0x%x, 0x6cc = 0x%x,\n",
+		    coex_dm->cur_val0x6c0, coex_dm->cur_val0x6c4,
+		    coex_dm->cur_val0x6c8, coex_dm->cur_val0x6cc);
+	BTC_TRACE(trace_buf);
 
 }
 
-void halbtc8723d1ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
+static
+void halbtc8723d1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
+		IN boolean force_exec, IN u8 type)
 {
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
+	u32	break_table;
+	u8	select_table;
 
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
-	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
-			return;
-	}
-
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-
-void halbtc8723d1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8723d1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-
-	halbtc8723d1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8723d1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	u32	break_table;
-	u8	select_table;
-
-	coex_sta->coex_table_type = type;
+	coex_sta->coex_table_type = type;
 
 	if (coex_sta->concurrent_rx_mode_on == TRUE) {
 		break_table = 0xf0ffffff;  /* set WL hi-pri can break BT */
-		select_table =
-			0xb;		/* set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS) */
+		/* set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS) */
+		select_table = 0xb;
 	} else {
 		break_table = 0xffffff;
 		select_table = 0x3;
@@ -1761,28 +1606,40 @@ void halbtc8723d1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
 		break;
 	case 13:
 		halbtc8723d1ant_coex_table(btcoexist, force_exec,
-					   0xaa5555aa, 0xaa5a5a5a, break_table,
+					   0x65555555, 0xaa5a5a5a, break_table,
 					   select_table);
 		break;
 	case 14:
 		halbtc8723d1ant_coex_table(btcoexist, force_exec,
-					   0xaa5555aa, 0x5a5a5a5a, break_table,
+					   0x65555555, 0x5a5a5a5a, break_table,
 					   select_table);
 		break;
 	case 15:
 		halbtc8723d1ant_coex_table(btcoexist, force_exec,
 					   0xaaaaaaaa, 0x5a5a5a5a, break_table,
 					   select_table);
-		/* halbtc8723d1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x5a5a5a5a, break_table,
+		break;
+	case 16:
+		halbtc8723d1ant_coex_table(btcoexist, force_exec,
+					   0x55555555, 0xaaaaaaaa, break_table,
+					   select_table);
+		break;
+	case 17:
+		halbtc8723d1ant_coex_table(btcoexist, force_exec,
+					   0x65555555, 0x65555555, break_table,
+					   select_table);
+		break;
+	case 18:
+		halbtc8723d1ant_coex_table(btcoexist, force_exec,
+					   0x65555555, 0xaaaaaaaa, break_table,
 					   select_table);
-		*/
 		break;
 	default:
 		break;
 	}
 }
 
+static
 void halbtc8723d1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 		IN boolean enable)
 {
@@ -1795,6 +1652,7 @@ void halbtc8723d1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
 }
 
+static
 void halbtc8723d1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 				     IN boolean force_exec, IN boolean enable)
 {
@@ -1810,6 +1668,7 @@ void halbtc8723d1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
 }
 
+static
 void halbtc8723d1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
 				  IN u8 lps_val, IN u8 rpwm_val)
 {
@@ -1820,6 +1679,7 @@ void halbtc8723d1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
 	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
 }
 
+static
 void halbtc8723d1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
 		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
 {
@@ -1837,6 +1697,7 @@ void halbtc8723d1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
 }
 
+static
 void halbtc8723d1ant_ps_tdma_check_for_power_save_state(
 	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
 {
@@ -1864,6 +1725,7 @@ void halbtc8723d1ant_ps_tdma_check_for_power_save_state(
 	}
 }
 
+static
 void halbtc8723d1ant_power_save_state(IN struct btc_coexist *btcoexist,
 			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
 {
@@ -1892,7 +1754,7 @@ void halbtc8723d1ant_power_save_state(IN struct btc_coexist *btcoexist,
 		btcoexist->btc_set(btcoexist,
 				   BTC_SET_ACT_DISABLE_LOW_POWER,
 				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
+		/* power save must executed before psTdma.*/
 		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
 				   NULL);
 
@@ -1910,7 +1772,7 @@ void halbtc8723d1ant_power_save_state(IN struct btc_coexist *btcoexist,
 	}
 }
 
-
+static
 void halbtc8723d1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
 	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
 {
@@ -1979,31 +1841,17 @@ void halbtc8723d1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
 		btcoexist->btc_set(btcoexist, BTC_SET_ACT_POST_NORMAL_LPS, NULL);
 }
 
-
+static
 void halbtc8723d1ant_ps_tdma(IN struct btc_coexist *btcoexist,
 		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
 {
 	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 	struct  btc_board_info	*board_info = &btcoexist->board_info;
 	boolean	wifi_busy = FALSE;
-	static u8	psTdmaByte4Modify = 0x0, pre_psTdmaByte4Modify = 0x0;
+	static u8 tdma_byte4_modify, pre_tdma_byte4_modify;
 	static boolean	 pre_wifi_busy = FALSE;
 
-
-#if BT_8723D_1ANT_ANTDET_ENABLE
-
-	if (board_info->btdm_ant_num_by_ant_det == 2) {
-#if 0
-		if (turn_on)
-			type = type +
-			       100;
-#endif
-	}
-
-#endif
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
+	btcoexist->btc_set_atomic(btcoexist, &coex_dm->setting_tdma, TRUE);
 
 	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
 
@@ -2013,253 +1861,276 @@ void halbtc8723d1ant_ps_tdma(IN struct btc_coexist *btcoexist,
 	}
 
 	/* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-	if ((bt_link_info->slave_role) && (bt_link_info->a2dp_exist))
-		psTdmaByte4Modify = 0x1;
+	if (bt_link_info->slave_role && bt_link_info->a2dp_exist)
+		tdma_byte4_modify = 0x1;
 	else
-		psTdmaByte4Modify = 0x0;
-
-	if (pre_psTdmaByte4Modify != psTdmaByte4Modify) {
+		tdma_byte4_modify = 0x0;
 
+	if (pre_tdma_byte4_modify != tdma_byte4_modify) {
 		force_exec = TRUE;
-		pre_psTdmaByte4Modify = psTdmaByte4Modify;
+		pre_tdma_byte4_modify = tdma_byte4_modify;
 	}
 
 	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
+		if (turn_on == coex_dm->cur_ps_tdma_on &&
+		    type == coex_dm->cur_ps_tdma) {
+			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+				    "[BTCoex], Skip TDMA because no change TDMA(%s, %d)\n",
+				    (coex_dm->cur_ps_tdma_on ? "on" : "off"),
+				    coex_dm->cur_ps_tdma);
+			BTC_TRACE(trace_buf);
+
+			btcoexist->btc_set_atomic(btcoexist,
+						  &coex_dm->setting_tdma,
+						  FALSE);
 			return;
+		}
 	}
 
-	if (coex_dm->cur_ps_tdma_on) {
+	if (turn_on) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
+			    "[BTCoex], ********** TDMA(on, %d)\n", type);
 		BTC_TRACE(trace_buf);
 
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
+		halbtc8723d1ant_post_state_to_bt(btcoexist,
+						 BT_8723D_1ANT_SCOREBOARD_TDMA,
+						 TRUE);
+
+		/* enable TBTT interrupt */
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8, 0x1);
 	} else {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
+			    "[BTCoex], ********** TDMA(off, %d)\n", type);
 		BTC_TRACE(trace_buf);
+
+		halbtc8723d1ant_post_state_to_bt(btcoexist,
+						 BT_8723D_1ANT_SCOREBOARD_TDMA,
+						 FALSE);
 	}
 
 
 	if (turn_on) {
 		switch (type) {
 		default:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x35, 0x03, 0x11, 0x11);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x35, 0x03, 0x11, 0x11);
 			break;
 		case 3:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x30, 0x03, 0x10, 0x50);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x30, 0x03, 0x10, 0x50);
 			break;
 		case 4:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x21, 0x03, 0x10, 0x50);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x21, 0x03, 0x10, 0x50);
 			break;
 		case 5:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x3a, 0x03, 0x11, 0x11);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x3a, 0x03, 0x11, 0x11);
 			break;
 		case 6:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x20, 0x03, 0x11, 0x11);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x20, 0x03, 0x11, 0x11);
 			break;
 		case 7:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x54 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x03, 0x10,  0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 8:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x54 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x03, 0x10,  0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 9:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x54 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x03, 0x10,  0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 10:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x30, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x30, 0x03, 0x11, 0x10);
 			break;
 		case 11:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x25, 0x03, 0x11,  0x11 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x25, 0x03, 0x11,  0x11 |
+						      tdma_byte4_modify);
 			break;
 		case 12:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x35, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x35, 0x03, 0x10,  0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 13:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x07, 0x10,  0x54 |
-						      psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x07, 0x10,  0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 14:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x15, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x15, 0x03, 0x10,  0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 15:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x20, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x20, 0x03, 0x10,  0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 16:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11,  0x15 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x10, 0x03, 0x11,  0x15 |
+						      tdma_byte4_modify);
 			break;
 		case 17:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11, 0x14);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x10, 0x03, 0x11, 0x14);
 			break;
 		case 18:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x30, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x30, 0x03, 0x10,  0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 19:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x15, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x15, 0x03, 0x11, 0x10);
 			break;
 		case 20:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x30, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x30, 0x03, 0x11, 0x10);
 			break;
 		case 21:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x30, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x30, 0x03, 0x11, 0x10);
 			break;
 		case 22:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x25, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x25, 0x03, 0x11, 0x10);
 			break;
 		case 23:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x10, 0x03, 0x11, 0x10);
 			break;
 		case 24:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x08, 0x03, 0x10,  0x54 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x08, 0x03, 0x10,  0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 25:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x3a, 0x03, 0x11, 0x50);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x3a, 0x03, 0x11, 0x50);
+			break;
+		case 26:
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x03, 0x10,  0x55);
 			break;
 		case 27:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11, 0x15);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x10, 0x03, 0x11, 0x15);
 			break;
 		case 28:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x0b, 0x10,  0x54);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x0b, 0x10,  0x54);
 			break;
 		case 32:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x35, 0x03, 0x11, 0x11);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x35, 0x03, 0x11, 0x11);
 			break;
 		case 33:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x35, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x35, 0x03, 0x11, 0x10);
 			break;
+		case 34:
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x3f, 0x03, 0x11, 0x10);
+			break;	
 		case 36:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x48, 0x03, 0x11, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x48, 0x03, 0x11, 0x10);
 			break;
 		case 57:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x03, 0x10,  0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 58:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x51, 0x10, 0x03, 0x10,  0x50 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x03, 0x10,  0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 67:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0x61, 0x10, 0x03, 0x11,  0x10 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x10, 0x03, 0x11,  0x10 |
+						      tdma_byte4_modify);
 			break;
 		/*     1-Ant to 2-Ant      TDMA case */
 		case 103:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xd3, 0x3a, 0x03, 0x70, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xd3,
+						      0x3a, 0x03, 0x70, 0x10);
 			break;
 		case 104:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xd3, 0x21, 0x03, 0x70, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xd3,
+						      0x21, 0x03, 0x70, 0x10);
 			break;
 		case 105:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x15, 0x03, 0x71, 0x11);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x15, 0x03, 0x71, 0x11);
 			break;
 		case 106:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x20, 0x03, 0x71, 0x11);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x20, 0x03, 0x71, 0x11);
 			break;
 		case 107:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xd3, 0x10, 0x03, 0x70,  0x14 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xd3,
+						      0x10, 0x03, 0x70,  0x14 |
+						      tdma_byte4_modify);
 			break;
 		case 108:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xd3, 0x10, 0x03, 0x70,  0x14 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xd3,
+						      0x10, 0x03, 0x70,  0x14 |
+						      tdma_byte4_modify);
 			break;
 		case 113:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xd3, 0x25, 0x03, 0x70,  0x10 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xd3,
+						      0x25, 0x03, 0x70,  0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 114:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xd3, 0x15, 0x03, 0x70,  0x10 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xd3,
+						      0x15, 0x03, 0x70,  0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 115:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xd3, 0x20, 0x03, 0x70,  0x10 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xd3,
+						      0x20, 0x03, 0x70,  0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 117:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x10, 0x03, 0x71,  0x14 |
-							psTdmaByte4Modify);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x10, 0x03, 0x71,  0x14 |
+						      tdma_byte4_modify);
 			break;
 		case 119:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x15, 0x03, 0x71, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x15, 0x03, 0x71, 0x10);
 			break;
 		case 120:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x30, 0x03, 0x71, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x30, 0x03, 0x71, 0x10);
 			break;
 		case 121:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x30, 0x03, 0x71, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x30, 0x03, 0x71, 0x10);
 			break;
 		case 122:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x25, 0x03, 0x71, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x25, 0x03, 0x71, 0x10);
 			break;
 		case 132:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x35, 0x03, 0x71, 0x11);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x35, 0x03, 0x71, 0x11);
 			break;
 		case 133:
-			halbtc8723d1ant_set_fw_pstdma(btcoexist,
-							0xe3, 0x35, 0x03, 0x71, 0x10);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0xe3,
+						      0x35, 0x03, 0x71, 0x10);
 			break;
 		}
 	} else {
@@ -2267,26 +2138,29 @@ void halbtc8723d1ant_ps_tdma(IN struct btc_coexist *btcoexist,
 		/* disable PS tdma */
 		switch (type) {
 		case 8: /* PTA Control */
-			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x8,
-						      0x0, 0x0, 0x0, 0x0);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist,
+						      0x8, 0x0, 0x0, 0x0, 0x0);
 			break;
 		case 0:
 		default:  /* Software control, Antenna at BT side */
-			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist,
+						      0x0, 0x0, 0x0, 0x0, 0x0);
 			break;
 		case 1: /* 2-Ant, 0x778=3, antenna control by antenna diversity */
-			halbtc8723d1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x48, 0x0);
+			halbtc8723d1ant_set_fw_pstdma(btcoexist,
+						      0x0, 0x0, 0x0, 0x48, 0x0);
 			break;
 		}
 	}
 
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
+	/* update pre state */
+	coex_dm->cur_ps_tdma_on = turn_on;
+	coex_dm->cur_ps_tdma = type;
 
+	btcoexist->btc_set_atomic(btcoexist, &coex_dm->setting_tdma, FALSE);
+}
 
+static
 void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 				  IN u8 ant_pos_type, IN boolean force_exec,
 				  IN u8 phase)
@@ -2298,7 +2172,7 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 	u32			u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
 	u16			u16tmp0, u16tmp1 = 0;
 
-#if BT_8723D_1ANT_ANTDET_ENABLE
+#if 0
 
 	if (ant_pos_type == BTC_ANT_PATH_PTA) {
 		if ((board_info->btdm_ant_det_finish) &&
@@ -2313,8 +2187,9 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 
 #endif
 
-	u32tmp1 = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist,
-				0x38);
+#if BT_8723D_1ANT_COEX_DBG
+
+	u32tmp1 = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
 
 	/* To avoid indirect access fail	*/
 	if (((u32tmp1 & 0xf000) >> 12) != ((u32tmp1 & 0x0f00) >> 8)) {
@@ -2322,7 +2197,6 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		coex_sta->gnt_error_cnt++;
 	}
 
-#if BT_8723D_1ANT_COEX_DBG
 	u32tmp2 = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
 	u16tmp0 = btcoexist->btc_read_2byte(btcoexist, 0xaa);
 	u16tmp1 = btcoexist->btc_read_2byte(btcoexist, 0x948);
@@ -2345,7 +2219,7 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 	if (!force_exec) {
 		if (coex_dm->cur_ant_pos_type == coex_dm->pre_ant_pos_type) {
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** Skip Antenna Path Setup because no change!!**********\n");
+				"[BTCoex], Skip Antenna Path Setup because no change!!\n");
 			BTC_TRACE(trace_buf);
 			return;
 		}
@@ -2361,19 +2235,8 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 						   0x80, 0x0);
 
 		/* set Path control owner to WL at initial step */
-		halbtc8723d1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_1ANT_PCO_BTSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8723d1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8723D_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8723D_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8723D_1ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW low */
-		halbtc8723d1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8723D_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8723D_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8723D_1ANT_SIG_STA_SET_TO_HIGH);
+		halbtc8723d1ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_1ANT_PCO_BTSIDE);
 
 		if (BTC_ANT_PATH_AUTO == ant_pos_type)
 			ant_pos_type = BTC_ANT_PATH_BT;
@@ -2382,18 +2245,26 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 
 		break;
 	case BT_8723D_1ANT_PHASE_COEX_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
+		/* Disable LTE Coex Function in WiFi side
+		 *(this should be on if LTE coex is required)
+		 */
 		halbtc8723d1ant_ltecoex_enable(btcoexist, 0x0);
 
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_WL_LTE always = 1
+		 *(this should be config if LTE coex is required)
+		 */
 		halbtc8723d1ant_ltecoex_set_coex_table(btcoexist,
 				       BT_8723D_1ANT_CTT_WL_VS_LTE, 0xffff);
 
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_BT_LTE always = 1
+		 *(this should be config if LTE coex is required)
+		 */
 		halbtc8723d1ant_ltecoex_set_coex_table(btcoexist,
 				       BT_8723D_1ANT_CTT_BT_VS_LTE, 0xffff);
 
-		/* Wait If BT IQK running, because Path control owner is at BT during BT IQK (setup by WiFi firmware) */
+		/* Wait If BT IQK running, because Path control owner is
+		 *at BT during BT IQK (setup by WiFi firmware)
+		 */
 		while (cnt_bt_cal_chk <= 20) {
 			u8tmp0 = btcoexist->btc_read_1byte(btcoexist,
 							   0x49d);
@@ -2401,14 +2272,14 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 			if (u8tmp0 & BIT(0)) {
 				BTC_SPRINTF(trace_buf,
 					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n",
+					    "[BTCoex],  BT is calibrating (wait cnt=%d)\n",
 					    cnt_bt_cal_chk);
 				BTC_TRACE(trace_buf);
 				delay_ms(50);
 			} else {
 				BTC_SPRINTF(trace_buf,
 					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** WL is NOT calibrating (wait cnt=%d)**********\n",
+					    "[BTCoex], WL is NOT calibrating (wait cnt=%d)\n",
 					    cnt_bt_cal_chk);
 				BTC_TRACE(trace_buf);
 				break;
@@ -2416,12 +2287,11 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		}
 
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-						   0x80, 0x1);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);
 
 		/* set Path control owner to WL at initial step */
-		halbtc8723d1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_1ANT_PCO_WLSIDE);
+		halbtc8723d1ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_1ANT_PCO_WLSIDE);
 
 		/* set GNT_BT to SW high */
 		halbtc8723d1ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2440,24 +2310,29 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		coex_sta->run_time_state = FALSE;
 		break;
 	case BT_8723D_1ANT_PHASE_WLANONLY_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
+		/* Disable LTE Coex Function in WiFi side
+		 *(this should be on if LTE coex is required)
+		 */
 		halbtc8723d1ant_ltecoex_enable(btcoexist, 0x0);
 
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_WL_LTE always = 1
+		 *(this should be config if LTE coex is required)
+		 */
 		halbtc8723d1ant_ltecoex_set_coex_table(btcoexist,
 				       BT_8723D_1ANT_CTT_WL_VS_LTE, 0xffff);
 
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_BT_LTE always = 1
+		 *(this should be config if LTE coex is required)
+		 */
 		halbtc8723d1ant_ltecoex_set_coex_table(btcoexist,
 				       BT_8723D_1ANT_CTT_BT_VS_LTE, 0xffff);
 
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-						   0x80, 0x1);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);
 
 		/* set Path control owner to WL at initial step */
-		halbtc8723d1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_1ANT_PCO_WLSIDE);
+		halbtc8723d1ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_1ANT_PCO_WLSIDE);
 
 		/* set GNT_BT to SW low */
 		halbtc8723d1ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2484,10 +2359,12 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 						   0x80, 0x0);
 
 		/* set Path control owner to BT */
-		halbtc8723d1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_1ANT_PCO_BTSIDE);
+		halbtc8723d1ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_1ANT_PCO_BTSIDE);
 
-		/*halbtc8723d1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, TRUE);*/
+		/* halbtc8723d1ant_ignore_wlan_act
+		 * (btcoexist, FORCE_EXEC, TRUE);
+		 */
 
 		if (BTC_ANT_PATH_AUTO == ant_pos_type)
 			ant_pos_type = BTC_ANT_PATH_BT;
@@ -2498,24 +2375,22 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 
 		/* wait for WL/BT IQK finish, keep 0x38 = 0xff00 for WL IQK */
 		while (cnt_bt_cal_chk <= 20) {
-			u8tmp0 = btcoexist->btc_read_1byte(btcoexist,
-							   0x1e6);
+			u8tmp0 = btcoexist->btc_read_1byte(btcoexist, 0x1e6);
 
-			u8tmp1 = btcoexist->btc_read_1byte(btcoexist,
-							   0x49d);
+			u8tmp1 = btcoexist->btc_read_1byte(btcoexist, 0x49d);
 
 			cnt_bt_cal_chk++;
 			if ((u8tmp0 & BIT(0)) || (u8tmp1 & BIT(0))) {
 				BTC_SPRINTF(trace_buf,
 					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### WL or BT is IQK (wait cnt=%d)\n",
+					    "[BTCoex], ########### WL or BT is IQK (wait cnt=%d)\n",
 					    cnt_bt_cal_chk);
 				BTC_TRACE(trace_buf);
 				delay_ms(50);
 			} else {
 				BTC_SPRINTF(trace_buf,
 					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** WL and BT is NOT IQK (wait cnt=%d)\n",
+					    "[BTCoex], ********** WL and BT is NOT IQK (wait cnt=%d)\n",
 					    cnt_bt_cal_chk);
 				BTC_TRACE(trace_buf);
 				break;
@@ -2526,8 +2401,8 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		/* Set Path control to WL */
 		/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1); */
 
-		halbtc8723d1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_1ANT_PCO_WLSIDE);
+		halbtc8723d1ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_1ANT_PCO_WLSIDE);
 
 		/* set GNT_BT to PTA */
 		halbtc8723d1ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2546,12 +2421,11 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		coex_sta->run_time_state = TRUE;
 		break;
 	case BT_8723D_1ANT_PHASE_BTMPMODE:
-		halbtc8723d1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_1ANT_PCO_WLSIDE);
+		halbtc8723d1ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_1ANT_PCO_WLSIDE);
 
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-						   0x80, 0x1);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);
 
 		/* set GNT_BT to high */
 		halbtc8723d1ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2570,12 +2444,11 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		coex_sta->run_time_state = FALSE;
 		break;
 	case BT_8723D_1ANT_PHASE_ANTENNA_DET:
-		halbtc8723d1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_1ANT_PCO_WLSIDE);
+		halbtc8723d1ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_1ANT_PCO_WLSIDE);
 
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-						   0x80, 0x1);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);
 
 		/* set GNT_BT to high */
 		halbtc8723d1ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2608,7 +2481,8 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 			btcoexist->btc_write_2byte(btcoexist, 0x948, 0x40);
 
 	else if ((is_hw_ant_div_on == FALSE) &&
-		(phase != BT_8723D_1ANT_PHASE_WLAN_OFF)) {  /* internal switch setting */
+		(phase != BT_8723D_1ANT_PHASE_WLAN_OFF)) {
+		/* internal switch setting */
 
 		switch (ant_pos_type) {
 
@@ -2616,34 +2490,32 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 			if (board_info->btdm_ant_pos ==
 			    BTC_ANTENNA_AT_MAIN_PORT)
 
-				btcoexist->btc_write_2byte(
-					btcoexist, 0x948, 0x0);
+				btcoexist->btc_write_2byte(btcoexist,
+							   0x948, 0x0);
 			else
-				btcoexist->btc_write_2byte(
-					btcoexist, 0x948, 0x280);
+				btcoexist->btc_write_2byte(btcoexist,
+							   0x948, 0x280);
 
 			break;
 		case BTC_ANT_PATH_BT:
 			if (board_info->btdm_ant_pos ==
 			    BTC_ANTENNA_AT_MAIN_PORT)
-
-				btcoexist->btc_write_2byte(
-					btcoexist, 0x948, 0x280);
+				btcoexist->btc_write_2byte(btcoexist,
+							   0x948, 0x280);
 			else
-				btcoexist->btc_write_2byte(
-					btcoexist, 0x948, 0x0);
+				btcoexist->btc_write_2byte(btcoexist,
+							   0x948, 0x0);
 
 			break;
 		default:
 		case BTC_ANT_PATH_PTA:
 			if (board_info->btdm_ant_pos ==
 			    BTC_ANTENNA_AT_MAIN_PORT)
-				btcoexist->btc_write_2byte(
-					btcoexist, 0x948,
-					0x200);
+				btcoexist->btc_write_2byte(btcoexist,
+							   0x948, 0x200);
 			else
-				btcoexist->btc_write_2byte(
-					btcoexist, 0x948, 0x80);
+				btcoexist->btc_write_2byte(btcoexist,
+							   0x948, 0x80);
 			break;
 		}
 	}
@@ -2658,19 +2530,19 @@ void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,
 	u8tmp0 =  btcoexist->btc_read_1byte(btcoexist, 0x67);
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(After Set Ant Pat)\n",
+		    "[BTCoex], 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(After Set Ant Pat)\n",
 		    u8tmp0, u16tmp1, u8tmp1);
 	BTC_TRACE(trace_buf);
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********0x38= 0x%x, 0x54= 0x%x, 0xaa = 0x%x(After Set Ant Path)\n",
+		    "[BTCoex], 0x38= 0x%x, 0x54= 0x%x, 0xaa = 0x%x(After Set Ant Path)\n",
 		    u32tmp1, u32tmp2, u16tmp0);
 	BTC_TRACE(trace_buf);
 #endif
 
 }
 
-
+static
 boolean halbtc8723d1ant_is_common_action(IN struct btc_coexist *btcoexist)
 {
 	boolean			common = FALSE, wifi_connected = FALSE, wifi_busy = FALSE;
@@ -2737,6 +2609,7 @@ boolean halbtc8723d1ant_is_common_action(IN struct btc_coexist *btcoexist)
  *	Non-Software Coex Mechanism start
  *
  * ********************************************* */
+static
 void halbtc8723d1ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)
 {
 	halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
@@ -2745,24 +2618,26 @@ void halbtc8723d1ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)
 	halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
 }
 
+static
 void halbtc8723d1ant_action_bt_hs(IN struct btc_coexist *btcoexist)
 {
 	halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
 	halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
 }
 
+static
 void halbtc8723d1ant_action_bt_relink(IN struct btc_coexist *btcoexist)
 {
 	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
-	if (((!coex_sta->is_bt_multi_link) && (!bt_link_info->pan_exist)) ||
-		((bt_link_info->a2dp_exist) && (bt_link_info->hid_exist))) {
-
-		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
+	if ((!coex_sta->is_bt_multi_link && !bt_link_info->pan_exist) ||
+	    (bt_link_info->a2dp_exist && bt_link_info->hid_exist)) {
+		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
+		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
 	}
 }
 
+static
 void halbtc8723d1ant_action_bt_idle(IN struct btc_coexist *btcoexist)
 {
 	boolean wifi_busy = FALSE;
@@ -2774,12 +2649,9 @@ void halbtc8723d1ant_action_bt_idle(IN struct btc_coexist *btcoexist)
 		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
 	} else {
 	/* if wl busy */
-	if (BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		coex_dm->bt_status) {
-		halbtc8723d1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-
-		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
+	if (BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE == coex_dm->bt_status) {
+		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
+		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 34);
 	} else {
 		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
 		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
@@ -2788,6 +2660,7 @@ void halbtc8723d1ant_action_bt_idle(IN struct btc_coexist *btcoexist)
 
 }
 
+static
 void halbtc8723d1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
 {
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
@@ -2803,48 +2676,53 @@ void halbtc8723d1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
 	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
 	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
 
-
-	if ((coex_sta->bt_create_connection) && ((wifi_link) || (wifi_roam)
-		|| (wifi_scan) || (coex_sta->wifi_is_high_pri_task))) {
-
+	if (coex_sta->bt_create_connection &&
+	    (coex_sta->wifi_is_high_pri_task || coex_sta->wifi_in_scan_task)) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi link/roam/Scan/busy/hi-pri-task + BT Inq/Page!!\n");
+			"[BTCoex], Wifi Scan/hi-pri-task + BT Inq/Page!!\n");
 		BTC_TRACE(trace_buf);
 
-		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-
-		if ((bt_link_info->a2dp_exist) && (!bt_link_info->pan_exist))
+		if (bt_link_info->a2dp_exist && !bt_link_info->pan_exist) {
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC, 1);
 			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 17);
-		else
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-		} else if ((!wifi_connected) && (!wifi_scan)) {
-
+		} else if (coex_sta->wifi_is_high_pri_task) {
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC, 16);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 36);
+		} else if (coex_sta->wifi_in_scan_task) {
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC, 1);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 33);
+		}
+	} else if (!wifi_connected && !wifi_scan) {
 		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
 
 		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
 	} else if (bt_link_info->pan_exist) {
-
 		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
 
 		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
 	} else if (bt_link_info->a2dp_exist) {
-
 		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
 
 		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
 	} else {
-
 		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
 
-		if ((wifi_link) || (wifi_roam) || (wifi_scan) ||
-			(coex_sta->wifi_is_high_pri_task))
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
+		if (coex_sta->wifi_in_scan_task ||
+		    coex_sta->wifi_is_high_pri_task)
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 21);
 		else
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 23);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 23);
 	}
 }
 
-
+static
 void halbtc8723d1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
 		*btcoexist)
 {
@@ -2864,50 +2742,75 @@ void halbtc8723d1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
 	if (bt_link_info->sco_exist) {
 		if (coex_sta->is_bt_multi_link) {
 			if (coex_sta->specific_pkt_period_cnt > 0)
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 15);
+				halbtc8723d1ant_coex_table_with_type(btcoexist,
+								     FALSE,
+								     15);
 			else
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 25);
+				halbtc8723d1ant_coex_table_with_type(btcoexist,
+								     FALSE,
+								     3);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 25);
 		} else {
-		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC, 1);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 5);
 		}
 	} else if (coex_sta->is_hid_rcu) {
 		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
 
 		if (wifi_busy)
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 36);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 36);
 		else
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 6);
 	} else {
 
-		if ((wifi_cckdeadlock_ap) && (coex_sta->is_hid_low_pri_tx_overhead)) {
-
+		if (wifi_cckdeadlock_ap &&
+		    coex_sta->is_hid_low_pri_tx_overhead) {
 			if (coex_sta->hid_busy_num < 2)
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
+				halbtc8723d1ant_coex_table_with_type(btcoexist,
+								     FALSE,
+								     14);
 			else
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 18);
+				halbtc8723d1ant_coex_table_with_type(btcoexist,
+								     FALSE,
+								     13);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 18);
 		} else if (coex_sta->is_hid_low_pri_tx_overhead) {
 			if (coex_sta->hid_busy_num < 2)
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
+				halbtc8723d1ant_coex_table_with_type(btcoexist,
+								     FALSE,
+								     3);
 			else
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 18);
+				halbtc8723d1ant_coex_table_with_type(btcoexist,
+								     FALSE,
+								     6);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 18);
 		} else if (coex_sta->hid_busy_num < 2) {
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC, 3);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 11);
 		} else if (wifi_bw == 0) { /* if 11bg mode */
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC, 11);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 11);
 		} else {
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC, 6);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 11);
 		}
 	}
 }
 
-
+static
 void halbtc8723d1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
 {
 	halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
@@ -2916,67 +2819,54 @@ void halbtc8723d1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
 	halbtc8723d1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
 }
 
+static
 void halbtc8723d1ant_action_wifi_native_lps(IN struct btc_coexist *btcoexist)
-{
-	halbtc8723d1ant_coex_table_with_type(btcoexist,
-					     NORMAL_EXEC, 5);
-	halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-void halbtc8723d1ant_action_wifi_cck_dead_lock(IN struct btc_coexist *btcoexist)
 {
 	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
-	if ((bt_link_info->hid_exist) && (bt_link_info->a2dp_exist) &&
-		(!bt_link_info->pan_exist)) {
-
-		if ((coex_sta->cck_lock) || (coex_sta->cck_lock_warn)) {
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 28);
-		} else {
-
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-		}
-	}
+	if (bt_link_info->pan_exist)
+		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
+	else
+		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
+	halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
 }
 
+static
 void halbtc8723d1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
 {
 	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 	u8 multi_port_type;
+	u32 traffic_dir;
+	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
 
 	halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
 				     BT_8723D_1ANT_PHASE_2G_RUNTIME);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED, &multi_port_type);
-
-	if (multi_port_type == BTC_MULTIPORT_SCC) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 17);
-		} else if (bt_link_info->pan_exist) {
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
+	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
+			   &traffic_dir);
+
+	if (coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE ||
+	    coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE) {
+		if (traffic_dir == BTC_WIFI_TRAFFIC_RX) {
+			halbtc8723d1ant_coex_table_with_type(btcoexist, FALSE,
+							     18);
+			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
+						33);
 		} else {
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
+			halbtc8723d1ant_coex_table_with_type(btcoexist, FALSE,
+							     17);
+			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE,
+						8);
 		}
-	} else  {
-		if ((BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			coex_dm->bt_status) ||
-			(BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE ==
-			coex_dm->bt_status))
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		else if (!bt_link_info->pan_exist)
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
+	} else if (!bt_link_info->pan_exist) {
+		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
+		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
+	} else {
+		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
 		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
 	}
 }
 
+static
 void halbtc8723d1ant_action_wifi_linkscan_process(IN struct btc_coexist
 		*btcoexist)
 {
@@ -2992,128 +2882,156 @@ void halbtc8723d1ant_action_wifi_linkscan_process(IN struct btc_coexist
 		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
 }
 
+static
 void halbtc8723d1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
 		*btcoexist)
 {
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 	boolean wifi_busy = FALSE, wifi_turbo = FALSE, wifi_cckdeadlock_ap = FALSE;
-	u32  wifi_bw = 1;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
+	u32	wifi_bw = 1;
+	u8	iot_peer = BTC_IOT_PEER_UNKNOWN, table_case;
 
 	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
 	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &coex_sta->scan_ap_num);
+	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
+			   &coex_sta->scan_ap_num);
 	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy_level = %d\n",
-			coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
+		    "############# [BTCoex],  scan_ap_num = %d, wl_noisy_level = %d\n",
+		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
 	BTC_TRACE(trace_buf);
 
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
+	if (wifi_busy && coex_sta->wl_noisy_level == 0)
 		wifi_turbo = TRUE;
 
-	if ((iot_peer == BTC_IOT_PEER_ATHEROS) && (coex_sta->cck_lock_ever))
+	if (coex_sta->cck_lock_ever)
 		wifi_cckdeadlock_ap = TRUE;
 
-	if ((bt_link_info->a2dp_exist) && (coex_sta->is_bt_a2dp_sink)) {
-
+	if (bt_link_info->a2dp_exist && coex_sta->is_bt_a2dp_sink) {
 		if (wifi_cckdeadlock_ap)
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
+			table_case = 13;
 		else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-
-		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 12);
+			table_case = 6;
+		halbtc8723d1ant_coex_table_with_type(btcoexist,
+						     NORMAL_EXEC, table_case);
+		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 15);
 	} else if (bt_link_info->a2dp_only) { /* A2DP		 */
 
 		if (wifi_cckdeadlock_ap)
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
+			table_case = 13;
 		else if (wifi_turbo)
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
+			table_case = 8;
 		else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
+			table_case = 4;
 
-		halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 7);
-	} else if (((bt_link_info->a2dp_exist) &&
-			(bt_link_info->pan_exist)) ||
-			(bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) { /* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
+		halbtc8723d1ant_coex_table_with_type(btcoexist,
+						     NORMAL_EXEC, table_case);
+
+		if (coex_sta->connect_ap_period_cnt > 0)
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 26);
+		else
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 7);
 
+	} else if ((bt_link_info->a2dp_exist &&
+			bt_link_info->pan_exist) ||
+			(bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
+			bt_link_info->pan_exist)) {
+		/* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
 		if (wifi_cckdeadlock_ap) {
-			if ((bt_link_info->hid_exist) && (coex_sta->hid_busy_num < 2))
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
+			if (bt_link_info->hid_exist &&
+			    coex_sta->hid_busy_num < 2)
+				table_case = 14;
 			else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
+				table_case = 13;
 		} else if (bt_link_info->hid_exist) {
 			if (coex_sta->hid_busy_num < 2)
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
+				table_case = 3;
 			else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		} else if (wifi_turbo)
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
+				table_case = 1;
+		} else if (wifi_turbo) {
+			table_case = 8;
+		} else {
+			table_case = 4;
+		}
 
+		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
+						     table_case);
 		if (wifi_busy)
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 13);
+			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
+						13);
 		else
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 14);
+			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
+						14);
 	} else if (bt_link_info->hid_exist &&
 		   bt_link_info->a2dp_exist) { /* HID+A2DP */
 
 		if (wifi_cckdeadlock_ap) {
-#if 1
 			if (coex_sta->hid_busy_num < 2)
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
+				table_case = 14;
 			else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
+				table_case = 13;
+
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC,
+							     table_case);
 
 			if (coex_sta->hid_pair_cnt > 1)
-				halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 24);
+				halbtc8723d1ant_ps_tdma(btcoexist,
+							NORMAL_EXEC, TRUE, 24);
 			else
-				halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-#endif
-
-#if 0
-			halbtc8723d1ant_action_wifi_cck_dead_lock(btcoexist);
-#endif
+				halbtc8723d1ant_ps_tdma(btcoexist,
+							NORMAL_EXEC, TRUE, 8);
 		} else {
 			if (coex_sta->hid_busy_num < 2) /* 2/18 HID */
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
+				table_case = 3;
 			else if (wifi_bw == 0)/* if 11bg mode */
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 12);
+				table_case = 12;
 			else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
+				table_case = 1;
+
+			halbtc8723d1ant_coex_table_with_type(btcoexist,
+							     NORMAL_EXEC,
+							     table_case);
 
 			if (coex_sta->hid_pair_cnt > 1)
-				halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 24);
+				halbtc8723d1ant_ps_tdma(btcoexist,
+							NORMAL_EXEC, TRUE, 24);
 			else
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
+				halbtc8723d1ant_ps_tdma(btcoexist,
+							NORMAL_EXEC, TRUE, 8);
 		}
-
-	} else if ((bt_link_info->pan_only)
+	} else if (bt_link_info->pan_only
 		   || (bt_link_info->hid_exist && bt_link_info->pan_exist)) {
 			/* PAN(OPP,FTP), HID+PAN(OPP,FTP) */
 
 		if (coex_sta->cck_lock_ever) {
-			if ((bt_link_info->hid_exist) && (coex_sta->hid_busy_num < 2))
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
+			if (bt_link_info->hid_exist &&
+			    coex_sta->hid_busy_num < 2)
+				table_case = 14;
 			else
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
+				table_case = 13;
 		} else if (bt_link_info->hid_exist) {
 			if (coex_sta->hid_busy_num < 2)
-				halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
+				table_case = 3;
 			else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		} else if (wifi_turbo)
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
+				table_case = 1;
+		} else if (wifi_turbo) {
+			table_case = 8;
+		} else {
+			table_case = 4;
+		}
 
+		halbtc8723d1ant_coex_table_with_type(btcoexist,
+						     NORMAL_EXEC, table_case);
 		if (!wifi_busy)
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 4);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 4);
 		else
-			halbtc8723d1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 3);
+			halbtc8723d1ant_ps_tdma(btcoexist,
+						NORMAL_EXEC, TRUE, 3);
 	} else {
 		/* BT no-profile busy (0x9) */
 		halbtc8723d1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
@@ -3122,7 +3040,7 @@ void halbtc8723d1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
 
 }
 
-
+static
 void halbtc8723d1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
 {
 	halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
@@ -3132,7 +3050,7 @@ void halbtc8723d1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
 	halbtc8723d1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
 }
 
-
+static
 void halbtc8723d1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
 {
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
@@ -3160,7 +3078,7 @@ void halbtc8723d1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
 		halbtc8723d1ant_action_bt_idle(btcoexist);
 }
 
-
+static
 void halbtc8723d1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
 {
 	u8				algorithm = 0;
@@ -3189,7 +3107,7 @@ void halbtc8723d1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
 			break;
 		case BT_8723D_1ANT_COEX_ALGO_A2DP_PANHS:
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
+				    "[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
 			BTC_TRACE(trace_buf);
 			break;
 		case BT_8723D_1ANT_COEX_ALGO_PANEDR:
@@ -3209,12 +3127,12 @@ void halbtc8723d1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
 			break;
 		case BT_8723D_1ANT_COEX_ALGO_PANEDR_HID:
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
+				    "[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
 			BTC_TRACE(trace_buf);
 			break;
 		case BT_8723D_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
+				    "[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
 			BTC_TRACE(trace_buf);
 			break;
 		case BT_8723D_1ANT_COEX_ALGO_HID_A2DP:
@@ -3224,7 +3142,7 @@ void halbtc8723d1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
 			break;
 		default:
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = coexist All Off!!\n");
+				    "[BTCoex], Action algorithm = coexist All Off!!\n");
 			BTC_TRACE(trace_buf);
 			break;
 		}
@@ -3232,7 +3150,7 @@ void halbtc8723d1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
 	}
 }
 
-
+static
 void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 {
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
@@ -3289,15 +3207,14 @@ void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 		return;
 	}
 
-	if (coex_sta->freeze_coexrun_by_btinfo) {
+	if (coex_sta->freeze_coexrun_by_btinfo && !coex_sta->is_setup_link) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			"[BTCoex], return for freeze_coexrun_by_btinfo\n");
 		BTC_TRACE(trace_buf);
 		return;
 	}
 
-	if ((coex_sta->under_lps) && (!coex_sta->force_lps_ctrl) &&
-		(!coex_sta->acl_busy)) {
+	if (coex_sta->under_lps && !coex_sta->force_lps_ctrl) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				"[BTCoex], RunCoexistMechanism(), wifi is under LPS !!!\n");
 		BTC_TRACE(trace_buf);
@@ -3320,22 +3237,21 @@ void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 		return;
 	}
 
-	if (coex_sta->c2h_bt_inquiry_page) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT is under inquiry/page scan !!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8723d1ant_action_bt_inquiry(btcoexist);
-			return;
-	}
-
-	if ((coex_sta->is_setupLink) &&
-		(coex_sta->bt_relink_downcount != 0)) {
+	if (coex_sta->is_setup_link || coex_sta->bt_relink_downcount != 0) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			"[BTCoex], BT is re-link !!!\n");
 		halbtc8723d1ant_action_bt_relink(btcoexist);
 		return;
 	}
 
+	if (coex_sta->c2h_bt_inquiry_page) {
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			    "[BTCoex], BT is under inquiry/page scan !!\n");
+		BTC_TRACE(trace_buf);
+		halbtc8723d1ant_action_bt_inquiry(btcoexist);
+		return;
+	}
+
 	if ((BT_8723D_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
 		(BT_8723D_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
 		(BT_8723D_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
@@ -3356,10 +3272,6 @@ void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 				num_of_wifi_link, wifi_link_status);
 		BTC_TRACE(trace_buf);
 
-#if 0
-		halbtc8723d1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					FALSE, 0x5);
-#endif
 		if (scan || link || roam || under_4way) {
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				"[BTCoex], scan = %d, link = %d, roam = %d 4way = %d!!!\n",
@@ -3388,8 +3300,8 @@ void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 
 	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
 	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-				&wifi_connected);
-
+			   &wifi_connected);
+#if 0
 	if ((bt_link_info->bt_link_exist) && (wifi_connected)) {
 
 		btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
@@ -3404,7 +3316,7 @@ void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 						NORMAL_EXEC, FALSE, TRUE, 0x8);
 			}
 	}
-
+#endif
 	halbtc8723d1ant_run_sw_coexist_mechanism(
 			btcoexist);  /* just print debug message */
 
@@ -3418,10 +3330,9 @@ void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 		return;
 	}
 
-	if ((BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		coex_dm->bt_status) ||
-		(BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		coex_dm->bt_status)) {
+	if ((coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE ||
+	     coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE)
+	     && wifi_connected) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				"############# [BTCoex],  BT Is idle\n");
 		BTC_TRACE(trace_buf);
@@ -3455,7 +3366,7 @@ void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 	 }
 }
 
-
+static
 void halbtc8723d1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
 {
 	/* force to reset coex mechanism */
@@ -3466,1428 +3377,150 @@ void halbtc8723d1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
 	BTC_TRACE(trace_buf);
 
 	coex_sta->pop_event_cnt = 0;
-	coex_sta->cnt_RemoteNameReq = 0;
-	coex_sta->cnt_ReInit = 0;
-	coex_sta->cnt_setupLink = 0;
-	coex_sta->cnt_IgnWlanAct = 0;
-	coex_sta->cnt_Page = 0;
-	coex_sta->cnt_RoleSwitch = 0;
+	coex_sta->cnt_remotenamereq = 0;
+	coex_sta->cnt_reinit = 0;
+	coex_sta->cnt_setuplink = 0;
+	coex_sta->cnt_ignwlanact = 0;
+	coex_sta->cnt_page = 0;
+	coex_sta->cnt_roleswitch = 0;
 
 	halbtc8723d1ant_query_bt_info(btcoexist);
 }
 
+static
 void halbtc8723d1ant_init_hw_config(IN struct btc_coexist *btcoexist,
 				    IN boolean back_up, IN boolean wifi_only)
 {
 	u32			u32tmp1 = 0, u32tmp2 = 0;
-	u16			u16tmp1 = 0;
-	u8	u8tmp0 = 0, u8tmp1 = 0;
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-	u8 i = 0;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-#if BT_8723D_1ANT_COEX_DBG
-	u32tmp1 = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-	u32tmp2 = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x54);
-	u16tmp1 = btcoexist->btc_read_2byte(btcoexist, 0x948);
-	u8tmp1	= btcoexist->btc_read_1byte(btcoexist, 0x73);
-	u8tmp0 =  btcoexist->btc_read_1byte(btcoexist, 0x67);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(Before init_hw_config)\n",
-		    u8tmp0, u16tmp1, u8tmp1);
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********0x38= 0x%x, 0x54= 0x%x (Before init_hw_config)\n",
-		    u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-
-	coex_sta->bt_coex_supported_feature = 0;
-	coex_sta->bt_coex_supported_version = 0;
-	coex_sta->bt_ble_scan_type = 0;
-	coex_sta->bt_ble_scan_para[0] = 0;
-	coex_sta->bt_ble_scan_para[1] = 0;
-	coex_sta->bt_ble_scan_para[2] = 0;
-	coex_sta->bt_reg_vendor_ac = 0xffff;
-	coex_sta->bt_reg_vendor_ae = 0xffff;
-	coex_sta->isolation_btween_wb = BT_8723D_1ANT_DEFAULT_ISOLATION;
-	coex_sta->gnt_error_cnt = 0;
-	coex_sta->bt_relink_downcount = 0;
-	coex_sta->wl_rx_rate = BTC_UNKNOWN;
-
-	for (i = 0; i <= 9; i++)
-		coex_sta->bt_afh_map[i] = 0;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	if (coex_sta->cut_version >= 0x3)
-		halbtc8723d1ant_post_state_to_bt(btcoexist,
-					 BT_8723D_1ANT_SCOREBOARD_DKTOPP2M,
-					 TRUE);
-	else
-		halbtc8723d1ant_post_state_to_bt(btcoexist,
-					 BT_8723D_1ANT_SCOREBOARD_DKTOPP2M,
-					 FALSE);
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* BT report packet sample rate	 */
-	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
-
-	/* Init 0x778 = 0x1 for 1-Ant */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* Enable PTA (3-wire function form BT side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
-
-	/* Enable PTA (tx/rx signal form WiFi side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
-
-	halbtc8723d1ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-#if 0
-	/* check if WL firmware download ok */
-	if (btcoexist->btc_read_1byte(btcoexist, 0x80) == 0xc6)
-		halbtc8723d1ant_post_state_to_bt(btcoexist,
-					 BT_8723D_1ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-
-	/* PTA parameter */
-	halbtc8723d1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8723d1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-
-	psd_scan->ant_det_is_ant_det_available = TRUE;
-
-	/* Antenna config */
-	if (coex_sta->is_rf_state_off) {
-
-		halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8723D_1ANT_PHASE_WLAN_OFF);
-
-		btcoexist->stop_coex_dm = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  halbtc8723d1ant_init_hw_config (RF Off)**********\n");
-		BTC_TRACE(trace_buf);
-	} else if (wifi_only) {
-		coex_sta->concurrent_rx_mode_on = FALSE;
-		halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_WIFI,
-					     FORCE_EXEC,
-					     BT_8723D_1ANT_PHASE_WLANONLY_INIT);
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else {
-		/*Set BT polluted packet on for Tx rate adaptive not including Tx retry break by PTA, 0x45c[19] =1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x1);
-
-		coex_sta->concurrent_rx_mode_on = TRUE;
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x2, 0x1);
-		/* RF 0x1[0] = 0->Set GNT_WL_RF_Rx always = 1 for con-current Rx */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x1, 0x0);
-		halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8723D_1ANT_PHASE_COEX_INIT);
-
-		btcoexist->stop_coex_dm = FALSE;
-	}
-
-	if (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  Single Antenna, Antenna at Main Port: S1**********\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  Single Antenna, Antenna at Aux Port: S0**********\n");
-		BTC_TRACE(trace_buf);
-	}
-
-}
-
-u32 halbtc8723d1ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)
-{
-	u8	j;
-	u32	tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
-	u32	result, val_fractiond_b = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
-				   174, 151, 132, 115, 100, 86, 74, 62, 51, 42,
-							   32, 23, 15, 7, 0
-							      };
-
-	if (val == 0)
-		return 0;
-
-	tmp = val;
-
-	while (1) {
-		if (tmp == 1)
-			break;
-		else {
-			tmp = (tmp >> 1);
-			shiftcount++;
-		}
-	}
-
-
-	val_integerd_b = shiftcount + 1;
-
-	tmp2 = 1;
-	for (j = 1; j <= val_integerd_b; j++)
-		tmp2 = tmp2 * 2;
-
-	tmp = (val * 100) / tmp2;
-	tindex = tmp / 5;
-
-	if (tindex > 20)
-		tindex = 20;
-
-	val_fractiond_b = table_fraction[tindex];
-
-	result = val_integerd_b * 100 - val_fractiond_b;
-
-	return result;
-
-
-}
-
-void halbtc8723d1ant_psd_show_antenna_detect_result(IN struct btc_coexist
-		*btcoexist)
-{
-	u8		*cli_buf = btcoexist->cli_buf;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n============[Antenna Detection info]  ============\n");
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 12) { /* Get Ant Det from BT  */
-
-		if (board_info->btdm_ant_num_by_ant_det == 1)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n %-35s = %s (%d~%d)",
-				   "Ant Det Result", "1-Antenna",
-				   BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT,
-				BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION);
-		else {
-
-			if (psd_scan->ant_det_psd_scan_peak_val >
-			    (BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION)
-			    * 100)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s (>%d)",
-					"Ant Det Result", "2-Antenna (Bad-Isolation)",
-					BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s (%d~%d)",
-					"Ant Det Result", "2-Antenna (Good-Isolation)",
-					BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION,
-					BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-		}
-	} else if (psd_scan->ant_det_result == 1)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (>%d)",
-			   "Ant Det Result", "2-Antenna (Bad-Isolation)",
-			   BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else if (psd_scan->ant_det_result == 2)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)",
-			   "Ant Det Result", "2-Antenna (Good-Isolation)",
-			   BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-			   + psd_scan->ant_det_thres_offset,
-			   BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)",
-			   "Ant Det Result", "1-Antenna",
-			   BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT,
-			   BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-			   + psd_scan->ant_det_thres_offset);
-
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s ",
-		   "Antenna Detection Finish",
-		   (board_info->btdm_ant_det_finish
-		    ? "Yes" : "No"));
-	CL_PRINTF(cli_buf);
-
-	switch (psd_scan->ant_det_result) {
-	case 0:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is not available)");
-		break;
-	case 1:  /* 2-Ant bad-isolation */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 2:  /* 2-Ant good-isolation */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 3:  /* 1-Ant */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 4:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Uncertainty result)");
-		break;
-	case 5:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "(Pre-Scan fai)");
-		break;
-	case 6:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(WiFi is Scanning)");
-		break;
-	case 7:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is not idle)");
-		break;
-	case 8:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Abort by WiFi Scanning)");
-		break;
-	case 9:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Antenna Init is not ready)");
-		break;
-	case 10:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is Inquiry or page)");
-		break;
-	case 11:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is Disabled)");
-	case 12:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available, result from BT");
-		break;
-	}
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 12) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dB",
-			   "PSD Scan Peak Value",
-			   psd_scan->ant_det_psd_scan_peak_val / 100);
-		CL_PRINTF(cli_buf);
-		return;
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Ant Detect Total Count", psd_scan->ant_det_try_count);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Ant Detect Fail Count", psd_scan->ant_det_fail_count);
-	CL_PRINTF(cli_buf);
-
-	if ((!board_info->btdm_ant_det_finish) &&
-	    (psd_scan->ant_det_result != 5))
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Response",
-		   (psd_scan->ant_det_result ? "ok" : "fail"));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ms", "BT Tx Time",
-		   psd_scan->ant_det_bt_tx_time);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "BT Tx Ch",
-		   psd_scan->ant_det_bt_le_channel);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d",
-		   "WiFi PSD Cent-Ch/Offset/Span",
-		   psd_scan->real_cent_freq, psd_scan->real_offset,
-		   psd_scan->real_span);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dB",
-		   "PSD Pre-Scan Peak Value",
-		   psd_scan->ant_det_pre_psdscan_peak_val / 100);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (<= %d)",
-		   "PSD Pre-Scan result",
-		   (psd_scan->ant_det_result != 5 ? "ok" : "fail"),
-		   BT_8723D_1ANT_ANTDET_PSDTHRES_BACKGROUND
-		   + psd_scan->ant_det_thres_offset);
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 5)
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s dB",
-		   "PSD Scan Peak Value", psd_scan->ant_det_peak_val);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s MHz",
-		   "PSD Scan Peak Freq", psd_scan->ant_det_peak_freq);
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "TFBGA Package",
-		   (board_info->tfbga_package) ?  "Yes" : "No");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "PSD Threshold Offset", psd_scan->ant_det_thres_offset);
-	CL_PRINTF(cli_buf);
-
-}
-
-
-
-void halbtc8723d1ant_psd_showdata(IN struct btc_coexist *btcoexist)
-{
-	u8		*cli_buf = btcoexist->cli_buf;
-	u32		delta_freq_per_point;
-	u32		freq, freq1, freq2, n = 0, i = 0, j = 0, m = 0, psd_rep1, psd_rep2;
-
-	if (psd_scan->ant_det_result == 12)
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n\n============[PSD info]  (%d)============\n",
-		   psd_scan->psd_gen_count);
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->psd_gen_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n No data !!\n");
-		CL_PRINTF(cli_buf);
-		return;
-	}
-
-	if (psd_scan->psd_point == 0)
-		delta_freq_per_point = 0;
-	else
-		delta_freq_per_point = psd_scan->psd_band_width /
-				       psd_scan->psd_point;
-
-	/* if (psd_scan->is_psd_show_max_only) */
-	if (0) {
-		psd_rep1 = psd_scan->psd_max_value / 100;
-		psd_rep2 = psd_scan->psd_max_value - psd_rep1 * 100;
-
-		freq = ((psd_scan->real_cent_freq - 20) * 1000000 +
-			psd_scan->psd_max_value_point * delta_freq_per_point);
-		freq1 = freq / 1000000;
-		freq2 = freq / 1000 - freq1 * 1000;
-
-		if (freq2 < 100)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n Freq = %d.0%d MHz",
-				   freq1, freq2);
-		else
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n Freq = %d.%d MHz",
-				   freq1, freq2);
-
-		if (psd_rep2 < 10)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   ", Value = %d.0%d dB, (%d)\n",
-				   psd_rep1, psd_rep2, psd_scan->psd_max_value);
-		else
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   ", Value = %d.%d dB, (%d)\n",
-				   psd_rep1, psd_rep2, psd_scan->psd_max_value);
-
-		CL_PRINTF(cli_buf);
-	} else {
-		m = psd_scan->psd_start_point;
-		n = psd_scan->psd_start_point;
-		i = 1;
-		j = 1;
-
-		while (1) {
-			do {
-				freq = ((psd_scan->real_cent_freq - 20) *
-					1000000 + m *
-					delta_freq_per_point);
-				freq1 = freq / 1000000;
-				freq2 = freq / 1000 - freq1 * 1000;
-
-				if (i == 1) {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.000",
-							   freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.0%2d",
-							   freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.%3d",
-							   freq1,
-							   freq2);
-				} else if ((i % 8 == 0) ||
-					   (m == psd_scan->psd_stop_point)) {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.000\n", freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.0%2d\n", freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.%3d\n", freq1,
-							   freq2);
-				} else {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.000", freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.0%2d", freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.%3d", freq1,
-							   freq2);
-				}
-
-				i++;
-				m++;
-				CL_PRINTF(cli_buf);
-
-			} while ((i <= 8) && (m <= psd_scan->psd_stop_point));
-
-
-			do {
-				psd_rep1 = psd_scan->psd_report_max_hold[n] /
-					   100;
-				psd_rep2 = psd_scan->psd_report_max_hold[n] -
-					   psd_rep1 *
-					   100;
-
-				if (j == 1) {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Val %7d.0%d",
-							   psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Val %7d.%d",
-							   psd_rep1,
-							   psd_rep2);
-				} else if ((j % 8 == 0)  ||
-					   (n == psd_scan->psd_stop_point)) {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							"%7d.0%d\n", psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.%d\n", psd_rep1,
-							   psd_rep2);
-				} else {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.0%d", psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.%d", psd_rep1,
-							   psd_rep2);
-				}
-
-				j++;
-				n++;
-				CL_PRINTF(cli_buf);
-
-			} while ((j <= 8) && (n <= psd_scan->psd_stop_point));
-
-			if ((m > psd_scan->psd_stop_point) ||
-			    (n > psd_scan->psd_stop_point))
-				break;
-			else {
-				i = 1;
-				j = 1;
-			}
-
-		}
-	}
-
-
-}
-
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-void halbtc8723d1ant_psd_maxholddata(IN struct btc_coexist *btcoexist,
-				     IN u32 gen_count)
-{
-	u32	i = 0;
-	u32 loop_i_max = 0, loop_val_max = 0;
-
-	if (gen_count == 1) {
-		memcpy(psd_scan->psd_report_max_hold,
-		       psd_scan->psd_report,
-		       BT_8723D_1ANT_ANTDET_PSD_POINTS * sizeof(u32));
-	}
-
-	for (i = psd_scan->psd_start_point;
-	     i <= psd_scan->psd_stop_point; i++) {
-
-		/* update max-hold value at each freq point */
-		if (psd_scan->psd_report[i] > psd_scan->psd_report_max_hold[i])
-			psd_scan->psd_report_max_hold[i] =
-				psd_scan->psd_report[i];
-
-		/*  search the max value in this seep */
-		if (psd_scan->psd_report[i] > loop_val_max) {
-			loop_val_max = psd_scan->psd_report[i];
-			loop_i_max = i;
-		}
-	}
-
-	if (gen_count <= BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT)
-		psd_scan->psd_loop_max_value[gen_count - 1] = loop_val_max;
-}
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-u32 halbtc8723d1ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)
-{
-	/* reg 0x808[9:0]: FFT data x */
-	/* reg 0x808[22]: 0-->1 to get 1 FFT data y */
-	/* reg 0x8b4[15:0]: FFT data y report */
-
-	u32 val = 0, psd_report = 0;
-	int k = 0;
-
-	val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-
-	val &= 0xffbffc00;
-	val |= point;
-
-	btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-	val |= 0x00400000;
-	btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-	while (1) {
-		if (k++ > BT_8723D_1ANT_ANTDET_SWEEPPOINT_DELAY)
-			break;
-	}
-
-	val = btcoexist->btc_read_4byte(btcoexist, 0x8b4);
-
-	psd_report = val & 0x0000ffff;
-
-	return psd_report;
-}
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-boolean halbtc8723d1ant_psd_sweep_point(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN s32 offset, IN u32 span, IN u32 points,
-					IN u32 avgnum, IN u32 loopcnt)
-{
-	u32	 i = 0, val = 0, n = 0, k = 0, j, point_index = 0;
-	u32	points1 = 0, psd_report = 0;
-	u32	start_p = 0, stop_p = 0, delta_freq_per_point = 156250;
-	u32    psd_center_freq = 20 * 10 ^ 6;
-	boolean outloop = FALSE, scan, roam, is_sweep_ok = TRUE;
-	u8	 flag = 0;
-	u32	tmp = 0, u32tmp1 = 0;
-	u32	wifi_original_channel = 1;
-	u32 psd_sum = 0, avg_cnt = 0;
-	u32	i_max = 0, val_max = 0, val_max2 = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx PSD Sweep Start!!\n");
-	BTC_TRACE(trace_buf);
-
-	do {
-		switch (flag) {
-		case 0:  /* Get PSD parameters */
-		default:
-
-			psd_scan->psd_band_width = 40 * 1000000;
-			psd_scan->psd_point = points;
-			psd_scan->psd_start_base = points / 2;
-			psd_scan->psd_avg_num = avgnum;
-			psd_scan->real_cent_freq = cent_freq;
-			psd_scan->real_offset = offset;
-			psd_scan->real_span = span;
-
-
-			points1 = psd_scan->psd_point;
-			delta_freq_per_point = psd_scan->psd_band_width /
-					       psd_scan->psd_point;
-
-			/* PSD point setup */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-			val &= 0xffff0fff;
-
-			switch (psd_scan->psd_point) {
-			case 128:
-				val |= 0x0;
-				break;
-			case 256:
-			default:
-				val |= 0x00004000;
-				break;
-			case 512:
-				val |= 0x00008000;
-				break;
-			case 1024:
-				val |= 0x0000c000;
-				break;
-			}
-
-			switch (psd_scan->psd_avg_num) {
-			case 1:
-				val |= 0x0;
-				break;
-			case 8:
-				val |= 0x00001000;
-				break;
-			case 16:
-				val |= 0x00002000;
-				break;
-			case 32:
-			default:
-				val |= 0x00003000;
-				break;
-			}
-			btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-			flag = 1;
-			break;
-		case 1:	  /* calculate the PSD point index from freq/offset/span */
-			psd_center_freq = psd_scan->psd_band_width / 2 +
-					  offset * (1000000);
-
-			start_p = psd_scan->psd_start_base + (psd_center_freq -
-				span * (1000000) / 2) / delta_freq_per_point;
-			psd_scan->psd_start_point = start_p -
-						    psd_scan->psd_start_base;
-
-			stop_p = psd_scan->psd_start_base + (psd_center_freq +
-				span * (1000000) / 2) / delta_freq_per_point;
-			psd_scan->psd_stop_point = stop_p -
-						   psd_scan->psd_start_base - 1;
-
-			flag = 2;
-			break;
-		case 2:  /* set RF channel/BW/Mode */
-
-			/* set 3-wire off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x88c);
-			val |= 0x00300000;
-			btcoexist->btc_write_4byte(btcoexist, 0x88c, val);
-
-			/* CCK off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x800);
-			val &= 0xfeffffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x800, val);
-
-			/* Tx-pause on */
-			btcoexist->btc_write_1byte(btcoexist, 0x522, 0x6f);
-
-			/* store WiFi original channel */
-			wifi_original_channel = btcoexist->btc_get_rf_reg(
-					btcoexist, BTC_RF_A, 0x18, 0x3ff);
-
-			/* Set RF channel */
-			if (cent_freq == 2484)
-				btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A,
-							  0x18, 0x3ff, 0xe);
-			else
-				btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A,
-					  0x18, 0x3ff, (cent_freq - 2412) / 5 +
-						  1); /* WiFi TRx Mask on */
-
-			/* save original RCK value */
-			u32tmp1 =  btcoexist->btc_get_rf_reg(
-					   btcoexist, BTC_RF_A, 0x1d, 0xfffff);
-
-			/* Enter debug mode */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xde,
-						  0x2, 0x1);
-
-			/* Set RF Rx filter corner */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1d,
-						  0xfffff, 0x2e);
-
-
-			/* Set  RF mode = Rx, RF Gain = 0x320a0 */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x0,
-						  0xfffff, 0x320a0);
-
-			while (1) {
-				if (k++ > BT_8723D_1ANT_ANTDET_SWEEPPOINT_DELAY)
-					break;
-			}
-			flag = 3;
-			break;
-		case 3:
-			psd_scan->psd_gen_count = 0;
-			for (j = 1; j <= loopcnt; j++) {
-
-				btcoexist->btc_get(btcoexist,
-						   BTC_GET_BL_WIFI_SCAN, &scan);
-				btcoexist->btc_get(btcoexist,
-						   BTC_GET_BL_WIFI_ROAM, &roam);
-
-				if (scan || roam) {
-					is_sweep_ok = FALSE;
-					break;
-				}
-				memset(psd_scan->psd_report, 0,
-				       psd_scan->psd_point * sizeof(u32));
-				start_p = psd_scan->psd_start_point +
-					  psd_scan->psd_start_base;
-				stop_p = psd_scan->psd_stop_point +
-					 psd_scan->psd_start_base + 1;
-
-				i = start_p;
-				point_index = 0;
-
-				while (i < stop_p) {
-					if (i >= points1)
-						psd_report =
-							halbtc8723d1ant_psd_getdata(
-							btcoexist, i - points1);
-					else
-						psd_report =
-							halbtc8723d1ant_psd_getdata(
-								btcoexist, i);
-
-					if (psd_report == 0)
-						tmp = 0;
-					else
-						/* tmp =  20*log10((double)psd_report); */
-						/* 20*log2(x)/log2(10), log2Base return theresult of the psd_report*100 */
-						tmp = 6 * halbtc8723d1ant_psd_log2base(
-							btcoexist, psd_report);
-
-					n = i - psd_scan->psd_start_base;
-					psd_scan->psd_report[n] =  tmp;
-
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"Point=%d, psd_dB_data = %d\n",
-						    i, psd_scan->psd_report[n]);
-					BTC_TRACE(trace_buf);
-
-					i++;
-
-				}
-
-				halbtc8723d1ant_psd_maxholddata(btcoexist, j);
-
-				psd_scan->psd_gen_count = j;
-
-				/*Accumulate Max PSD value in this loop if the value > threshold */
-				if (psd_scan->psd_loop_max_value[j - 1] >=
-				    4000) {
-					psd_sum = psd_sum +
-						psd_scan->psd_loop_max_value[j -
-								       1];
-					avg_cnt++;
-				}
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "Loop=%d, Max_dB_data = %d\n",
-					    j, psd_scan->psd_loop_max_value[j
-							    - 1]);
-				BTC_TRACE(trace_buf);
-
-			}
-
-			if (loopcnt == BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT) {
-
-				/* search the Max Value between each-freq-point-max-hold value of all sweep*/
-				for (i = 1;
-				     i <= BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT;
-				     i++) {
-
-					if (i == 1) {
-						i_max = i;
-						val_max = psd_scan->psd_loop_max_value[i
-								       - 1];
-						val_max2 =
-							psd_scan->psd_loop_max_value[i
-								     - 1];
-					} else if (
-						psd_scan->psd_loop_max_value[i -
-							     1] > val_max) {
-						val_max2 = val_max;
-						i_max = i;
-						val_max = psd_scan->psd_loop_max_value[i
-								       - 1];
-					} else if (
-						psd_scan->psd_loop_max_value[i -
-							     1] > val_max2)
-						val_max2 =
-							psd_scan->psd_loop_max_value[i
-								     - 1];
-
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"i = %d, val_hold= %d, val_max = %d, val_max2 = %d\n",
-						i, psd_scan->psd_loop_max_value[i
-								    - 1],
-						    val_max, val_max2);
-
-					BTC_TRACE(trace_buf);
-				}
-
-				psd_scan->psd_max_value_point = i_max;
-				psd_scan->psd_max_value = val_max;
-				psd_scan->psd_max_value2 = val_max2;
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "val_max = %d, val_max2 = %d\n",
-					    psd_scan->psd_max_value,
-					    psd_scan->psd_max_value2);
-				BTC_TRACE(trace_buf);
-			}
-
-			if (avg_cnt != 0) {
-				psd_scan->psd_avg_value = (psd_sum / avg_cnt);
-				if ((psd_sum % avg_cnt) >= (avg_cnt / 2))
-					psd_scan->psd_avg_value++;
-			} else
-				psd_scan->psd_avg_value = 0;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "AvgLoop=%d, Avg_dB_data = %d\n",
-				    avg_cnt, psd_scan->psd_avg_value);
-			BTC_TRACE(trace_buf);
-
-			flag = 100;
-			break;
-		case 99:	/* error */
-
-			outloop = TRUE;
-			break;
-		case 100: /* recovery */
-
-			/* set 3-wire on */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x88c);
-			val &= 0xffcfffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x88c, val);
-
-			/* CCK on */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x800);
-			val |= 0x01000000;
-			btcoexist->btc_write_4byte(btcoexist, 0x800, val);
-
-			/* Tx-pause off */
-			btcoexist->btc_write_1byte(btcoexist, 0x522, 0x0);
-
-			/* PSD off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-			val &= 0xffbfffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-			/* restore RF Rx filter corner */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1d,
-						  0xfffff, u32tmp1);
-
-			/* Exit debug mode */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xde,
-						  0x2, 0x0);
-
-			/* restore WiFi original channel */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x18,
-						  0x3ff, wifi_original_channel);
-
-			outloop = TRUE;
-			break;
-
-		}
-
-	} while (!outloop);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx PSD Sweep Stop!!\n");
-	BTC_TRACE(trace_buf);
-	return is_sweep_ok;
-
-}
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-boolean halbtc8723d1ant_psd_antenna_detection(IN struct btc_coexist
-		*btcoexist)
-{
-	u32	i = 0;
-	u32	wlpsd_cent_freq = 2484, wlpsd_span = 2;
-	s32	wlpsd_offset = -4;
-	u32 bt_tx_time, bt_le_channel;
-	u8	bt_le_ch[13] = {3, 6, 8, 11, 13, 16, 18, 21, 23, 26, 28, 31, 33};
-
-	u8	h2c_parameter[3] = {0}, u8tmpa, u8tmpb;
-
-	u8	state = 0;
-	boolean		outloop = FALSE, bt_resp = FALSE, ant_det_finish = FALSE;
-	u32		freq, freq1, freq2, psd_rep1, psd_rep2, delta_freq_per_point,
-			u32tmp, u32tmp0, u32tmp1, u32tmp2 ;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	memset(psd_scan->ant_det_peak_val, 0, 16 * sizeof(u8));
-	memset(psd_scan->ant_det_peak_freq, 0, 16 * sizeof(u8));
-
-	psd_scan->ant_det_bt_tx_time =
-		BT_8723D_1ANT_ANTDET_BTTXTIME;	   /* 0.42ms*50 = 20ms (0.42ms = 1 PSD sweep) */
-	psd_scan->ant_det_bt_le_channel = BT_8723D_1ANT_ANTDET_BTTXCHANNEL;
-
-	bt_tx_time = psd_scan->ant_det_bt_tx_time;
-	bt_le_channel = psd_scan->ant_det_bt_le_channel;
-
-	if (board_info->tfbga_package) /* for TFBGA */
-		psd_scan->ant_det_thres_offset = 5;
-	else
-		psd_scan->ant_det_thres_offset = 0;
-
-	do {
-		switch (state) {
-		case 0:
-			if (bt_le_channel == 39)
-				wlpsd_cent_freq = 2484;
-			else {
-				for (i = 1; i <= 13; i++) {
-					if (bt_le_ch[i - 1] ==
-					    bt_le_channel) {
-						wlpsd_cent_freq = 2412
-								  + (i - 1) * 5;
-						break;
-					}
-				}
-
-				if (i == 14) {
-
-					BTC_SPRINTF(trace_buf,
-						    BT_TMP_BUF_SIZE,
-						"xxxxxxxxxxxxxxxx AntennaDetect(), Abort!!, Invalid LE channel = %d\n ",
-						    bt_le_channel);
-					BTC_TRACE(trace_buf);
-					outloop = TRUE;
-					break;
-				}
-			}
-#if 0
-			wlpsd_sweep_count = bt_tx_time * 238 /
-					    100; /* bt_tx_time/0.42								 */
-			wlpsd_sweep_count = wlpsd_sweep_count / 5;
-
-			if (wlpsd_sweep_count % 5 != 0)
-				wlpsd_sweep_count = (wlpsd_sweep_count /
-						     5 + 1) * 5;
-#endif
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), BT_LETxTime=%d,  BT_LECh = %d\n",
-				    bt_tx_time, bt_le_channel);
-			BTC_TRACE(trace_buf);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), wlpsd_cent_freq=%d,  wlpsd_offset = %d, wlpsd_span = %d, wlpsd_sweep_count = %d\n",
-				    wlpsd_cent_freq,
-				    wlpsd_offset,
-				    wlpsd_span,
-				    BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT);
-			BTC_TRACE(trace_buf);
-
-			state = 1;
-			break;
-		case 1: /* stop coex DM & set antenna path */
-			/* Stop Coex DM */
-			btcoexist->stop_coex_dm = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Stop Coex DM!!\n");
-			BTC_TRACE(trace_buf);
-
-			/* Set coex table */
-			halbtc8723d1ant_coex_table_with_type(btcoexist,
-							     FORCE_EXEC, 0);
-
-			/* Set TDMA off,				 */
-			halbtc8723d1ant_ps_tdma(btcoexist, FORCE_EXEC,
-						FALSE, 0);
-
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Main Port\n");
-				BTC_TRACE(trace_buf);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Aux Port\n");
-				BTC_TRACE(trace_buf);
-			}
-
-			/* Set Antenna path, switch WiFi to un-certain antenna port */
-			/* Set Antenna Path,  both GNT_WL/GNT_BT = 1, and control by SW */
-			halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-						     FORCE_EXEC,
-					     BT_8723D_1ANT_PHASE_ANTENNA_DET);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to BT!!\n");
-			BTC_TRACE(trace_buf);
-
-			/* Set AFH mask on at WiFi channel 2472MHz +/- 10MHz */
-			h2c_parameter[0] = 0x1;
-			h2c_parameter[1] = 0xd;
-			h2c_parameter[2] = 0x14;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-				    h2c_parameter[1],
-				    h2c_parameter[2]);
-			BTC_TRACE(trace_buf);
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x66, 3,
-						h2c_parameter);
-
-			u32tmp = btcoexist->btc_read_2byte(btcoexist, 0x948);
-			u32tmp0 = btcoexist->btc_read_4byte(btcoexist, 0x70);
-			u32tmp1 = halbtc8723d1ant_ltecoex_indirect_read_reg(
-					  btcoexist, 0x38);
-			u32tmp2 = halbtc8723d1ant_ltecoex_indirect_read_reg(
-					  btcoexist, 0x54);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** 0x948 = 0x%x, 0x70 = 0x%x, 0x38= 0x%x, 0x54= 0x%x (Before Ant Det)\n",
-				    u32tmp, u32tmp0, u32tmp1, u32tmp2);
-			BTC_TRACE(trace_buf);
-
-			state = 2;
-			break;
-		case 2:	/* Pre-sweep background psd */
-			if (!halbtc8723d1ant_psd_sweep_point(btcoexist,
-				     wlpsd_cent_freq, wlpsd_offset, wlpsd_span,
-					     BT_8723D_1ANT_ANTDET_PSD_POINTS,
-				     BT_8723D_1ANT_ANTDET_PSD_AVGNUM, 3)) {
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 8;
-				state = 99;
-				break;
-			}
-
-			psd_scan->ant_det_pre_psdscan_peak_val =
-				psd_scan->psd_max_value;
-
-			if (psd_scan->ant_det_pre_psdscan_peak_val >
-			    (BT_8723D_1ANT_ANTDET_PSDTHRES_BACKGROUND
-			     + psd_scan->ant_det_thres_offset) * 100) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Abort Antenna Detection!! becaus background = %d > thres (%d)\n",
-					psd_scan->ant_det_pre_psdscan_peak_val /
-					    100,
-					BT_8723D_1ANT_ANTDET_PSDTHRES_BACKGROUND
-					    + psd_scan->ant_det_thres_offset);
-				BTC_TRACE(trace_buf);
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 5;
-				state = 99;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Start Antenna Detection!! becaus background = %d <= thres (%d)\n",
-					psd_scan->ant_det_pre_psdscan_peak_val /
-					    100,
-					BT_8723D_1ANT_ANTDET_PSDTHRES_BACKGROUND
-					    + psd_scan->ant_det_thres_offset);
-				BTC_TRACE(trace_buf);
-				state = 3;
-			}
-			break;
-		case 3:
-
-			bt_resp = btcoexist->btc_set_bt_ant_detection(
-					  btcoexist, (u8)(bt_tx_time & 0xff),
-					  (u8)(bt_le_channel & 0xff));
-
-			/* Sync WL Rx PSD with BT Tx time because H2C->Mailbox delay */
-			delay_ms(20);
-
-			if (!halbtc8723d1ant_psd_sweep_point(btcoexist,
-					     wlpsd_cent_freq, wlpsd_offset,
-							     wlpsd_span,
-					     BT_8723D_1ANT_ANTDET_PSD_POINTS,
-					     BT_8723D_1ANT_ANTDET_PSD_AVGNUM,
-				     BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT)) {
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 8;
-				state = 99;
-				break;
-			}
-
-#if 1
-			psd_scan->ant_det_psd_scan_peak_val =
-				psd_scan->psd_max_value;
-#endif
-#if 0
-			psd_scan->ant_det_psd_scan_peak_val =
-				((psd_scan->psd_max_value - psd_scan->psd_avg_value) <
-				 800) ?
-				psd_scan->psd_max_value : ((
-						psd_scan->psd_max_value -
-					psd_scan->psd_max_value2 <= 300) ?
-						   psd_scan->psd_avg_value :
-						   psd_scan->psd_max_value2);
-#endif
-			psd_scan->ant_det_psd_scan_peak_freq =
-				psd_scan->psd_max_value_point;
-			state = 4;
-			break;
-		case 4:
-
-			if (psd_scan->psd_point == 0)
-				delta_freq_per_point = 0;
-			else
-				delta_freq_per_point =
-					psd_scan->psd_band_width /
-					psd_scan->psd_point;
-
-			psd_rep1 = psd_scan->ant_det_psd_scan_peak_val / 100;
-			psd_rep2 = psd_scan->ant_det_psd_scan_peak_val -
-				   psd_rep1 *
-				   100;
-
-			freq = ((psd_scan->real_cent_freq - 20) *
-				1000000 + psd_scan->psd_max_value_point
-				* delta_freq_per_point);
-			freq1 = freq / 1000000;
-			freq2 = freq / 1000 - freq1 * 1000;
-
-			if (freq2 < 100) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.0%d MHz",
-					    freq1, freq2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_freq,
-					   BT_8723D_1ANT_ANTDET_BUF_LEN,
-					   "%d.0%d", freq1, freq2);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.%d MHz",
-					    freq1, freq2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_freq,
-					   BT_8723D_1ANT_ANTDET_BUF_LEN,
-					   "%d.%d", freq1, freq2);
-			}
-
-			if (psd_rep2 < 10) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    ", Value = %d.0%d dB\n",
-					    psd_rep1, psd_rep2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_val,
-					   BT_8723D_1ANT_ANTDET_BUF_LEN,
-					   "%d.0%d", psd_rep1, psd_rep2);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    ", Value = %d.%d dB\n",
-					    psd_rep1, psd_rep2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_val,
-					   BT_8723D_1ANT_ANTDET_BUF_LEN,
-					   "%d.%d", psd_rep1, psd_rep2);
-			}
-
-			psd_scan->ant_det_is_btreply_available = TRUE;
+	u16			u16tmp1 = 0;
+	u8	u8tmp0 = 0, u8tmp1 = 0;
+	struct  btc_board_info *board_info = &btcoexist->board_info;
+	u8 i = 0;
+	boolean tmp;
 
-			if (bt_resp == FALSE) {
-				psd_scan->ant_det_is_btreply_available =
-					FALSE;
-				psd_scan->ant_det_result = 0;
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), BT Response = Fail\n ");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->ant_det_psd_scan_peak_val >
-				(BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION)
-				   * 100) {
-				psd_scan->ant_det_result = 1;
-				ant_det_finish = TRUE;
-				board_info->btdm_ant_num_by_ant_det = 2;
-				coex_sta->isolation_btween_wb = (u8)(85 -
-					psd_scan->ant_det_psd_scan_peak_val /
-							     100) & 0xff;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Bad-Isolation!!\n");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->ant_det_psd_scan_peak_val >
-				(BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-				    + psd_scan->ant_det_thres_offset) * 100) {
-				psd_scan->ant_det_result = 2;
-				ant_det_finish = TRUE;
-				board_info->btdm_ant_num_by_ant_det = 2;
-				coex_sta->isolation_btween_wb = (u8)(85 -
-					psd_scan->ant_det_psd_scan_peak_val /
-							     100) & 0xff;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Good-Isolation!!\n");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->ant_det_psd_scan_peak_val >
-				   (BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT) *
-				   100) {
-				psd_scan->ant_det_result = 3;
-				ant_det_finish = TRUE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				coex_sta->isolation_btween_wb = (u8)(85 -
-					psd_scan->ant_det_psd_scan_peak_val /
-							     100) & 0xff;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant!!\n");
-				BTC_TRACE(trace_buf);
-			} else {
-				psd_scan->ant_det_result = 4;
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant, un-certainity!!\n");
-				BTC_TRACE(trace_buf);
-			}
+	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+		    "[BTCoex], 1Ant Init HW Config!!\n");
+	BTC_TRACE(trace_buf);
 
-			state = 99;
-			break;
-		case 99:  /* restore setup */
+#if BT_8723D_1ANT_COEX_DBG
+	u32tmp1 = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist,
+			0x38);
+	u32tmp2 = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist,
+			0x54);
+	u16tmp1 = btcoexist->btc_read_2byte(btcoexist, 0x948);
+	u8tmp1	= btcoexist->btc_read_1byte(btcoexist, 0x73);
+	u8tmp0 =  btcoexist->btc_read_1byte(btcoexist, 0x67);
 
-			/* Set AFH mask off at WiFi channel 2472MHz +/- 10MHz */
-			h2c_parameter[0] = 0x0;
-			h2c_parameter[1] = 0x0;
-			h2c_parameter[2] = 0x0;
+	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+		"[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(Before init_hw_config)\n",
+		    u8tmp0, u16tmp1, u8tmp1);
+	BTC_TRACE(trace_buf);
 
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-				    h2c_parameter[1], h2c_parameter[2]);
-			BTC_TRACE(trace_buf);
+	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+		"[BTCoex], **********0x38= 0x%x, 0x54= 0x%x (Before init_hw_config)\n",
+		    u32tmp1, u32tmp2);
+	BTC_TRACE(trace_buf);
+#endif
 
-			btcoexist->btc_fill_h2c(btcoexist, 0x66, 3,
-						h2c_parameter);
+	coex_sta->bt_coex_supported_feature = 0;
+	coex_sta->bt_coex_supported_version = 0;
+	coex_sta->bt_ble_scan_type = 0;
+	coex_sta->bt_ble_scan_para[0] = 0;
+	coex_sta->bt_ble_scan_para[1] = 0;
+	coex_sta->bt_ble_scan_para[2] = 0;
+	coex_sta->bt_reg_vendor_ac = 0xffff;
+	coex_sta->bt_reg_vendor_ae = 0xffff;
+	coex_sta->isolation_btween_wb = BT_8723D_1ANT_DEFAULT_ISOLATION;
+	coex_sta->gnt_error_cnt = 0;
+	coex_sta->bt_relink_downcount = 0;
+	coex_sta->wl_rx_rate = BTC_UNKNOWN;
 
-			/* Set Antenna Path, GNT_WL/GNT_BT control by PTA */
-			/* Set Antenna path, switch WiFi to certain antenna port */
-			halbtc8723d1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8723D_1ANT_PHASE_2G_RUNTIME);
+	for (i = 0; i <= 9; i++)
+		coex_sta->bt_afh_map[i] = 0;
 
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to PTA\n!!");
-			BTC_TRACE(trace_buf);
+	/* 0xf0[15:12] --> kt_ver */
+	coex_sta->kt_ver = (btcoexist->btc_read_1byte(btcoexist,
+						      0xf1) & 0xf0) >> 4;
 
-			btcoexist->stop_coex_dm = FALSE;
+	if (coex_sta->kt_ver >= 0x3)
+		tmp =  TRUE;
+	else
+		tmp =  FALSE;
 
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Resume Coex DM\n!!");
-			BTC_TRACE(trace_buf);
+	halbtc8723d1ant_post_state_to_bt(btcoexist,
+					 BT_8723D_1ANT_SCOREBOARD_DKTOPP2M,
+					 tmp);
+	/* enable TBTT nterrupt */
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8, 0x1);
 
-			outloop = TRUE;
-			break;
-		}
+	/* BT report packet sample rate	 */
+	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
 
-	} while (!outloop);
+	/* Init 0x778 = 0x1 for 1-Ant */
+	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
 
-	return ant_det_finish;
+	/* Enable PTA (3-wire function form BT side) */
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
 
-}
+	/* Enable PTA (tx/rx signal form WiFi side) */
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
 
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-boolean halbtc8723d1ant_psd_antenna_detection_check(IN struct btc_coexist
-		*btcoexist)
-{
-	static u32 ant_det_count = 0, ant_det_fail_count = 0;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
+	halbtc8723d1ant_enable_gnt_to_gpio(btcoexist, TRUE);
 
-	boolean scan, roam, ant_det_finish = FALSE;
+	/* PTA parameter */
+	halbtc8723d1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
 
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
+	halbtc8723d1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
 
-	ant_det_count++;
-
-	psd_scan->ant_det_try_count = ant_det_count;
-
-	if (scan || roam) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 6;
-	} else if (coex_sta->bt_disabled) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 11;
-	} else if (coex_sta->num_of_profile >= 1) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 7;
-	} else if (
-		!psd_scan->ant_det_is_ant_det_available) { /* Antenna initial setup is not ready */
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 9;
-	} else if (coex_sta->c2h_bt_inquiry_page) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 10;
-	} else {
+	psd_scan->ant_det_is_ant_det_available = TRUE;
 
-		ant_det_finish = halbtc8723d1ant_psd_antenna_detection(
-					 btcoexist);
+	/* Antenna config */
+	if (coex_sta->is_rf_state_off) {
 
-		delay_ms(psd_scan->ant_det_bt_tx_time);
-	}
+		halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
+					     FORCE_EXEC,
+					     BT_8723D_1ANT_PHASE_WLAN_OFF);
 
-	/* board_info->ant_det_result = psd_scan->ant_det_result; */
+		btcoexist->stop_coex_dm = TRUE;
 
-	if (!ant_det_finish)
-		ant_det_fail_count++;
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			"[BTCoex], **********  halbtc8723d1ant_init_hw_config (RF Off)**********\n");
+		BTC_TRACE(trace_buf);
+	} else if (wifi_only) {
+		coex_sta->concurrent_rx_mode_on = FALSE;
+		halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_WIFI,
+					     FORCE_EXEC,
+					     BT_8723D_1ANT_PHASE_WLANONLY_INIT);
 
-	psd_scan->ant_det_fail_count = ant_det_fail_count;
+		btcoexist->stop_coex_dm = TRUE;
+	} else {
+		coex_sta->concurrent_rx_mode_on = TRUE;
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x2, 0x1);
+		/* RF 0x1[0] = 0->Set GNT_WL_RF_Rx always = 1 for con-current Rx */
+		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x1, 0x0);
+		halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
+					     FORCE_EXEC,
+					     BT_8723D_1ANT_PHASE_COEX_INIT);
 
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx AntennaDetect(), result = %d, fail_count = %d, finish = %s\n",
-		    psd_scan->ant_det_result,
-		    psd_scan->ant_det_fail_count,
-		    ant_det_finish == TRUE ? "Yes" : "No");
-	BTC_TRACE(trace_buf);
+		btcoexist->stop_coex_dm = FALSE;
+	}
 
-	return ant_det_finish;
+	if (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT) {
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			"[BTCoex], **********  Single Antenna, Antenna at Main Port: S1**********\n");
+		BTC_TRACE(trace_buf);
+	} else {
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			"[BTCoex], **********  Single Antenna, Antenna at Aux Port: S0**********\n");
+		BTC_TRACE(trace_buf);
+	}
 
 }
 
-
+#ifdef PLATFORM_WINDOWS
+#pragma optimize("", off)
+#endif
 
 /* ************************************************************
  * work around function start with wa_halbtc8723d1ant_
@@ -4967,6 +3600,8 @@ void ex_halbtc8723d1ant_power_on_setting(IN struct btc_coexist *btcoexist)
 	/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
 	halbtc8723d1ant_enable_gnt_to_gpio(btcoexist, TRUE);
 
+#if BT_8723D_1ANT_COEX_DBG
+
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 		"[BTCoex], **********  LTE coex Reg 0x38 (Power-On) = 0x%x**********\n",
 		    halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist, 0x38));
@@ -4978,6 +3613,8 @@ void ex_halbtc8723d1ant_power_on_setting(IN struct btc_coexist *btcoexist)
 		    btcoexist->btc_read_2byte(btcoexist, 0x948));
 	BTC_TRACE(trace_buf);
 
+#endif
+
 }
 
 void ex_halbtc8723d1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
@@ -5011,7 +3648,7 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	boolean			lte_coex_on = FALSE;
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
+		   "\r\n ============[BT Coexist info 8723D]============");
 	CL_PRINTF(cli_buf);
 
 	if (btcoexist->manual_control) {
@@ -5067,10 +3704,13 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	}
 
 	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s",
+		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %s/ %s",
 			   "Ant PG Num/ Mech/ Pos",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == 1 ? "S1" : "S0"));
+			   board_info->pg_ant_num,
+			   (board_info->btdm_ant_num == 1 ?
+			   "Shared" : "Non-Shared"),
+			   (board_info->btdm_ant_pos == 1 ?
+			   "S1" : "S0"));
 		CL_PRINTF(cli_buf);
 	} else {
 		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
@@ -5132,7 +3772,7 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
 		   "W_FW/ B_FW/ Phy/ Kt",
 		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
+		   coex_sta->kt_ver + 65);
 	CL_PRINTF(cli_buf);
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
@@ -5193,21 +3833,13 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	CL_PRINTF(cli_buf);
 
 	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			   "A2DP Rate/Bitpool/Auto_Slot",
-			   ((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
+		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
+			   "\r\n %-35s = %s/ %d/ 0x%x/ 0x%x",
+			   "CQDDR/Bitpool/V_ID/D_name",
+			   ((coex_sta->is_A2DP_3M) ? "On" : "Off"),
 			   coex_sta->a2dp_bit_pool,
-			   ((coex_sta->is_autoslot) ? "On" : "Off")
-			  );
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ %d/ %d",
-			   "V_ID/D_name/FBSlot_Legacy/FBSlot_Le",
 			   coex_sta->bt_a2dp_vendor_id,
-			   coex_sta->bt_a2dp_device_name,
-			   coex_sta->legacy_forbidden_slot,
-			   coex_sta->le_forbidden_slot
-			  );
+			   coex_sta->bt_a2dp_device_name);
 		CL_PRINTF(cli_buf);
 	}
 
@@ -5222,7 +3854,7 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
 				"Role/RoleSwCnt/IgnWlact/Feature",
 				((bt_link_info->slave_role) ? "Slave" : "Master"),
-				coex_sta->cnt_RoleSwitch,
+				coex_sta->cnt_roleswitch,
 				((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
 				coex_sta->bt_coex_supported_feature);
 	CL_PRINTF(cli_buf);
@@ -5243,11 +3875,11 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
 		   "ReInit/ReLink/IgnWlact/Page/NameReq",
-		   coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-		   coex_sta->cnt_IgnWlanAct,
-		   coex_sta->cnt_Page,
-		   coex_sta->cnt_RemoteNameReq
+		   coex_sta->cnt_reinit,
+		   coex_sta->cnt_setuplink,
+		   coex_sta->cnt_ignwlanact,
+		   coex_sta->cnt_page,
+		   coex_sta->cnt_remotenamereq
 		  );
 	CL_PRINTF(cli_buf);
 
@@ -5261,7 +3893,7 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
 			   "\r\n %-35s = 0x%x/ 0x%x/ 0x%04x",
 			   "0xae[4]/0xac[1:0]/Scoreboard(B->W)",
-			   ((unsigned int)(coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
+			   (int)((coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
 			   coex_sta->bt_reg_vendor_ac & 0x3, u16tmp[0]);
 	CL_PRINTF(cli_buf);
 
@@ -5351,6 +3983,12 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		   coex_sta->wl_fw_dbg_info[5]);
 	CL_PRINTF(cli_buf);
 
+	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s",
+		   "TDMA_Togg_cnt/WL5ms_cnt/WL5ms_off",
+		   coex_sta->wl_fw_dbg_info[6], coex_sta->wl_fw_dbg_info[7],
+		   ((coex_sta->is_no_wl_5ms_extend) ? "Yes" : "No"));
+	CL_PRINTF(cli_buf);
+
 	u32tmp[0] = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
 	lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ?  TRUE : FALSE;
 
@@ -5388,16 +4026,6 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
 		   "============[Hw setting]============");
 	CL_PRINTF(cli_buf);
-	/*
-		u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
-		u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
-		u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
-		u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x456);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-			   "0x430/0x434/0x42a/0x456",
-			   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0]);
-		CL_PRINTF(cli_buf);
-	*/
 
 	u32tmp[0] = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
 	u32tmp[1] = halbtc8723d1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
@@ -5463,15 +4091,25 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		   (int)((u8tmp[3] & BIT(7)) >> 7));
 	CL_PRINTF(cli_buf);
 
+	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
+	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
+	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
+	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x426);
+	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x45e);
+	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
+		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x/ 0x%x",
+		   "0x430/0x434/0x42a/0x426/0x45e[3]",
+		   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0],
+		   (int)((u8tmp[1] & BIT(3)) >> 3));
+	CL_PRINTF(cli_buf);
+
 	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x45e);
+	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x40);
 
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x4c6[4]/0x40[5]/0x45e[3](TxRetry)",
+	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
+		   "\r\n %-35s = 0x%x/ 0x%x", "0x4c6[4]/0x40[5]",
 		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5),
-		   (int)((u8tmp[2] & BIT(3)) >> 3));
+		   (int)((u16tmp[0] & BIT(5)) >> 5));
 	CL_PRINTF(cli_buf);
 
 	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
@@ -5517,7 +4155,7 @@ void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
 		   "0x770(Hi-pri rx/tx)",
 		   coex_sta->high_priority_rx, coex_sta->high_priority_tx,
-		   (coex_sta->is_hiPri_rx_overhead ? "(scan overhead!!)" : ""));
+		   (coex_sta->is_hipri_rx_overhead ? "(scan overhead!!)" : ""));
 	CL_PRINTF(cli_buf);
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
@@ -5571,7 +4209,7 @@ void ex_halbtc8723d1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
 #endif
 
 		halbtc8723d1ant_init_hw_config(btcoexist, FALSE, FALSE);
-		halbtc8723d1ant_init_coex_dm(btcoexist);;
+		halbtc8723d1ant_init_coex_dm(btcoexist);
 
 		coex_sta->under_ips = FALSE;
 	}
@@ -5636,7 +4274,7 @@ void ex_halbtc8723d1ant_scan_notify(IN struct btc_coexist *btcoexist,
 	if (BTC_SCAN_START == type) {
 
 		if (!wifi_connected)
-			coex_sta->wifi_is_high_pri_task = TRUE;
+			coex_sta->wifi_in_scan_task = TRUE;
 
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			    "[BTCoex], SCAN START notify\n");
@@ -5648,7 +4286,7 @@ void ex_halbtc8723d1ant_scan_notify(IN struct btc_coexist *btcoexist,
 					BT_8723D_1ANT_SCOREBOARD_ONOFF,
 					TRUE);
 
-		halbtc8723d1ant_query_bt_info(btcoexist);
+		/*halbtc8723d1ant_query_bt_info(btcoexist);*/
 
 		/* Force antenna setup for no scan result issue */
 		halbtc8723d1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
@@ -5659,7 +4297,7 @@ void ex_halbtc8723d1ant_scan_notify(IN struct btc_coexist *btcoexist,
 
 	} else {
 
-		coex_sta->wifi_is_high_pri_task = FALSE;
+		coex_sta->wifi_in_scan_task = FALSE;
 
 		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
 				   &coex_sta->scan_ap_num);
@@ -5710,6 +4348,7 @@ void ex_halbtc8723d1ant_connect_notify(IN struct btc_coexist *btcoexist,
 		BTC_TRACE(trace_buf);
 
 		coex_dm->arp_cnt = 0;
+		coex_sta->connect_ap_period_cnt = 2;
 
 		halbtc8723d1ant_run_coexist_mechanism(btcoexist);
 
@@ -5772,15 +4411,6 @@ void ex_halbtc8723d1ant_media_status_notify(IN struct btc_coexist *btcoexist,
 			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
 						   0x10); /* CCK Rx */
 		}
-
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
 	} else {
 
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
@@ -5845,9 +4475,10 @@ void ex_halbtc8723d1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
 		coex_sta->specific_pkt_period_cnt = 2;
 	}
 
-	if (coex_sta->wifi_is_high_pri_task) {
+	if (coex_sta->wifi_is_high_pri_task || coex_sta->wifi_in_scan_task) {
 		halbtc8723d1ant_post_state_to_bt(btcoexist,
-					 BT_8723D_1ANT_SCOREBOARD_SCAN, TRUE);
+						 BT_8723D_1ANT_SCOREBOARD_SCAN,
+						 TRUE);
 		halbtc8723d1ant_run_coexist_mechanism(btcoexist);
 	}
 }
@@ -5855,13 +4486,14 @@ void ex_halbtc8723d1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
 void ex_halbtc8723d1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 				       IN u8 *tmp_buf, IN u8 length)
 {
-	u8			i, rsp_source = 0;
+	struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
+	u8 i, rsp_source = 0;
 	boolean	wifi_connected = FALSE;
 	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE,
-		    wifi_busy = FALSE;
+		wifi_busy = FALSE;
 	static boolean is_scoreboard_scan = FALSE;
 
-	if (psd_scan->is_AntDet_running == TRUE) {
+	if (psd_scan->is_antdet_running) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			"[BTCoex], bt_info_notify return for AntDet is running\n");
 		BTC_TRACE(trace_buf);
@@ -5928,7 +4560,7 @@ void ex_halbtc8723d1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 
 		coex_sta->a2dp_bit_pool = (((
 			coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) ?
-				   (coex_sta->bt_info_c2h[rsp_source][6]  & 0x7f) : 0);
+			(coex_sta->bt_info_c2h[rsp_source][6]  & 0x7f) : 0);
 
 		coex_sta->is_bt_a2dp_sink = (coex_sta->bt_info_c2h[rsp_source][6] & 0x80) ?
 									TRUE : FALSE;
@@ -5936,7 +4568,7 @@ void ex_halbtc8723d1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 		coex_sta->bt_retry_cnt = coex_sta->bt_info_c2h[rsp_source][2] &
 					 0xf;
 
-		coex_sta->is_autoslot = coex_sta->bt_info_ext2 & 0x8;
+		bt_link_info->slave_role  = coex_sta->bt_info_ext2 & 0x8;
 
 		coex_sta->forbidden_slot = coex_sta->bt_info_ext2 & 0x7;
 
@@ -5950,31 +4582,27 @@ void ex_halbtc8723d1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 			coex_sta->pop_event_cnt++;
 
 		if (coex_sta->c2h_bt_remote_name_req)
-			coex_sta->cnt_RemoteNameReq++;
+			coex_sta->cnt_remotenamereq++;
 
 		if (coex_sta->bt_info_ext & BIT(1))
-			coex_sta->cnt_ReInit++;
+			coex_sta->cnt_reinit++;
 
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setupLink++;
-			coex_sta->is_setupLink = TRUE;
+		if (coex_sta->bt_info_ext & BIT(2) ||
+		    (coex_sta->bt_create_connection &&
+		    coex_sta->pnp_awake_period_cnt > 0)) {
+			coex_sta->cnt_setuplink++;
+			coex_sta->is_setup_link = TRUE;
 			coex_sta->bt_relink_downcount = 2;
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				    "[BTCoex], Re-Link start in BT info!!\n");
 			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->is_setupLink = FALSE;
-			coex_sta->bt_relink_downcount = 0;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link stop in BT info!!\n");
-			BTC_TRACE(trace_buf);
 		}
 
 		if (coex_sta->bt_info_ext & BIT(3))
-			coex_sta->cnt_IgnWlanAct++;
+			coex_sta->cnt_ignwlanact++;
 
 		if (coex_sta->bt_info_ext & BIT(6))
-			coex_sta->cnt_RoleSwitch++;
+			coex_sta->cnt_roleswitch++;
 
 		if (coex_sta->bt_info_ext & BIT(7))
 			coex_sta->is_bt_multi_link = TRUE;
@@ -5987,12 +4615,12 @@ void ex_halbtc8723d1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 			coex_sta->is_hid_rcu = FALSE;
 
 		if (coex_sta->bt_info_ext & BIT(5))
-			coex_sta->is_ble_scan_toggle = TRUE;
+			coex_sta->is_ble_scan_en = TRUE;
 		else
-			coex_sta->is_ble_scan_toggle = FALSE;
+			coex_sta->is_ble_scan_en = FALSE;
 
 		if (coex_sta->bt_create_connection) {
-			coex_sta->cnt_Page++;
+			coex_sta->cnt_page++;
 
 			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY,
 					   &wifi_busy);
@@ -6001,8 +4629,9 @@ void ex_halbtc8723d1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
 			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
 
-			if ((wifi_link) || (wifi_roam) || (wifi_scan) ||
-			    (coex_sta->wifi_is_high_pri_task) || (wifi_busy)) {
+			if (wifi_link || wifi_roam ||
+			    coex_sta->wifi_in_scan_task ||
+			    coex_sta->wifi_is_high_pri_task || wifi_busy) {
 
 				is_scoreboard_scan = TRUE;
 				halbtc8723d1ant_post_state_to_bt(btcoexist,
@@ -6078,25 +4707,61 @@ void ex_halbtc8723d1ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
 				       IN u8 *tmp_buf, IN u8 length)
 {
 	u8 i = 0;
-	static u8 tmp_buf_pre[10] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
+	static u8 tmp_buf_pre[10], cnt;
+	u8 h2c_parameter[2] = {0};
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d (len = %d)\n",
-			    tmp_buf[0], tmp_buf[1],
-			    tmp_buf[2], tmp_buf[3],
-			    tmp_buf[4], tmp_buf[5], length);
+		    "[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d %d %d (len = %d)\n",
+		    tmp_buf[0], tmp_buf[1], tmp_buf[2], tmp_buf[3], tmp_buf[4],
+		    tmp_buf[5], tmp_buf[6], tmp_buf[7], length);
 	BTC_TRACE(trace_buf);
 
 	if (tmp_buf[0] == 0x8) {
-		for (i = 1; i <= 5; i++) {
+		for (i = 1; i <= 7; i++) {
 			coex_sta->wl_fw_dbg_info[i] =
 				(tmp_buf[i] >= tmp_buf_pre[i]) ?
-				(tmp_buf[i] - tmp_buf_pre[i]) :
-				(255 - tmp_buf_pre[i] + tmp_buf[i]);
+					(tmp_buf[i] - tmp_buf_pre[i]) :
+					(255 - tmp_buf_pre[i] + tmp_buf[i]);
 
 			tmp_buf_pre[i] = tmp_buf[i];
 		}
 	}
+
+	if (!coex_sta->is_no_wl_5ms_extend && coex_sta->force_lps_ctrl &&
+	    !coex_sta->cck_lock_ever) {
+		if (coex_sta->wl_fw_dbg_info[7] <= 5)
+			cnt++;
+		else
+			cnt = 0;
+
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			    "[BTCoex], 5ms WL slot extend cnt = %d!!\n", cnt);
+		BTC_TRACE(trace_buf);
+
+		if (cnt == 7) {
+			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+				    "[BTCoex], set h2c 0x69 opcode 12 to turn off 5ms WL slot extend!!\n");
+			BTC_TRACE(trace_buf);
+
+			h2c_parameter[0] = 0xc;
+			h2c_parameter[1] = 0x1;
+			btcoexist->btc_fill_h2c(btcoexist, 0x69, 2,
+						h2c_parameter);
+			coex_sta->is_no_wl_5ms_extend = TRUE;
+			cnt = 0;
+		}
+	}
+
+	if (coex_sta->is_no_wl_5ms_extend && coex_sta->cck_lock) {
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			    "[BTCoex], set h2c 0x69 opcode 12 to turn on 5ms WL slot extend!!\n");
+		BTC_TRACE(trace_buf);
+
+		h2c_parameter[0] = 0xc;
+		h2c_parameter[1] = 0x0;
+		btcoexist->btc_fill_h2c(btcoexist, 0x69, 2, h2c_parameter);
+		coex_sta->is_no_wl_5ms_extend = FALSE;
+	}
 }
 
 void ex_halbtc8723d1ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
@@ -6123,24 +4788,24 @@ void ex_halbtc8723d1ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
 		BTC_TRACE(trace_buf);
 	}
 
-	if ((wifi_connected) &&
-		((coex_dm->bt_status ==  BT_8723D_1ANT_BT_STATUS_ACL_BUSY) ||
-		(coex_dm->bt_status ==  BT_8723D_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		(coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_SCO_BUSY))) {
+	if (wifi_connected &&
+	    (coex_dm->bt_status ==  BT_8723D_1ANT_BT_STATUS_ACL_BUSY ||
+	     coex_dm->bt_status ==  BT_8723D_1ANT_BT_STATUS_ACL_SCO_BUSY ||
+	     coex_dm->bt_status == BT_8723D_1ANT_BT_STATUS_SCO_BUSY)) {
 
-		if ((coex_sta->wl_rx_rate == BTC_CCK_5_5) ||
-			(coex_sta->wl_rx_rate == BTC_OFDM_6) ||
-			(coex_sta->wl_rx_rate == BTC_MCS_0)) {
+		if (coex_sta->wl_rx_rate == BTC_CCK_5_5 ||
+		    coex_sta->wl_rx_rate == BTC_OFDM_6 ||
+		    coex_sta->wl_rx_rate == BTC_MCS_0) {
 
 			coex_sta->cck_lock_warn = TRUE;
 
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				"[BTCoex], cck lock warning...\n");
 			BTC_TRACE(trace_buf);
-		} else if ((coex_sta->wl_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rx_rate == BTC_CCK_2) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_2)) {
+		} else if (coex_sta->wl_rx_rate == BTC_CCK_1 ||
+			   coex_sta->wl_rx_rate == BTC_CCK_2 ||
+			   coex_sta->wl_rts_rx_rate == BTC_CCK_1 ||
+			   coex_sta->wl_rts_rx_rate == BTC_CCK_2) {
 
 			coex_sta->cck_lock = TRUE;
 			coex_sta->cck_lock_ever = TRUE;
@@ -6157,10 +4822,10 @@ void ex_halbtc8723d1ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
 			BTC_TRACE(trace_buf);
 		}
 	} else {
-		if ((coex_dm->bt_status ==
-			BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE) ||
-			(coex_dm->bt_status ==
-			BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE)) {
+		if (coex_dm->bt_status ==
+		    BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE ||
+		    coex_dm->bt_status ==
+		    BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE) {
 			coex_sta->cck_lock_warn = FALSE;
 			coex_sta->cck_lock = FALSE;
 		}
@@ -6242,6 +4907,8 @@ void ex_halbtc8723d1ant_halt_notify(IN struct btc_coexist *btcoexist)
 void ex_halbtc8723d1ant_pnp_notify(IN struct btc_coexist *btcoexist,
 				   IN u8 pnp_state)
 {
+	static u8 pre_pnp_state;
+
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
 	BTC_TRACE(trace_buf);
 
@@ -6251,6 +4918,9 @@ void ex_halbtc8723d1ant_pnp_notify(IN struct btc_coexist *btcoexist,
 			    "[BTCoex], Pnp notify to SLEEP\n");
 		BTC_TRACE(trace_buf);
 
+		coex_sta->under_ips = FALSE;
+		coex_sta->under_lps = FALSE;
+
 		halbtc8723d1ant_post_state_to_bt(btcoexist,
 				BT_8723D_1ANT_SCOREBOARD_ACTIVE |
 				BT_8723D_1ANT_SCOREBOARD_ONOFF |
@@ -6271,19 +4941,31 @@ void ex_halbtc8723d1ant_pnp_notify(IN struct btc_coexist *btcoexist,
 		}
 
 		btcoexist->stop_coex_dm = TRUE;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
+	} else {
 
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			    "[BTCoex], Pnp notify to WAKE UP\n");
 		BTC_TRACE(trace_buf);
+
+		coex_sta->pnp_awake_period_cnt = 3;
+
+		/*WoWLAN*/
+		if (pre_pnp_state == BTC_WIFI_PNP_SLEEP_KEEP_ANT ||
+		    pnp_state == BTC_WIFI_PNP_WOWLAN) {
+			coex_sta->run_time_state = TRUE;
+			btcoexist->stop_coex_dm = FALSE;
+			halbtc8723d1ant_run_coexist_mechanism(btcoexist);
+		}
 #if 0
 		halbtc8723d1ant_post_state_to_bt(btcoexist,
 					 BT_8723D_1ANT_SCOREBOARD_ACTIVE, TRUE);
 		halbtc8723d1ant_post_state_to_bt(btcoexist,
 					 BT_8723D_1ANT_SCOREBOARD_ONOFF, TRUE);
 #endif
-		btcoexist->stop_coex_dm = FALSE;
+		/*btcoexist->stop_coex_dm = FALSE;*/
 	}
+
+	pre_pnp_state = pnp_state;
 }
 
 
@@ -6325,7 +5007,7 @@ void ex_halbtc8723d1ant_periodical(IN struct btc_coexist *btcoexist)
 		coex_sta->bt_relink_downcount--;
 
 		if (coex_sta->bt_relink_downcount == 0) {
-			coex_sta->is_setupLink = FALSE;
+			coex_sta->is_setup_link = FALSE;
 			bt_relink_finish = TRUE;
 		}
 	}
@@ -6336,45 +5018,27 @@ void ex_halbtc8723d1ant_periodical(IN struct btc_coexist *btcoexist)
 		coex_sta->specific_pkt_period_cnt--;
 
 		if ((coex_sta->specific_pkt_period_cnt == 0) &&
-		    (coex_sta->wifi_is_high_pri_task))
+		    (coex_sta->wifi_is_high_pri_task)) {
 			coex_sta->wifi_is_high_pri_task = FALSE;
-		special_pkt_finish = TRUE;
+		}
+			special_pkt_finish = TRUE;
 	}
 
-	if (!coex_sta->bt_disabled) {
-
-#if BT_8723D_1ANT_ANTDET_ENABLE
-
-		if (board_info->btdm_ant_det_finish) {
-			if ((psd_scan->ant_det_result == 12) &&
-			    (psd_scan->ant_det_psd_scan_peak_val == 0)
-			    && (!psd_scan->is_AntDet_running)) {
-				psd_scan->ant_det_psd_scan_peak_val =
-					btcoexist->btc_get_ant_det_val_from_bt(
-					btcoexist) * 100;
-
-				board_info->antdetval = psd_scan->ant_det_psd_scan_peak_val/100;
-				value = board_info->antdetval;
-
-#ifdef PLATFORM_WINDOWS
-				{
-					PWCHAR	registryName;
+	if (coex_sta->pnp_awake_period_cnt > 0)
+		coex_sta->pnp_awake_period_cnt--;
 
-					registryName = L"antdetval";
-					PlatformWriteCommonDwordRegistry(registryName, &value);
-				}
-#endif
-			}
-		}
+	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+		    "[BTCoex], pnp_awake_period_cnt = %d\n",
+				coex_sta->pnp_awake_period_cnt);
+	BTC_TRACE(trace_buf);
 
-#endif
-	}
+	/*for A2DP glitch during connecting AP*/
+	if (coex_sta->connect_ap_period_cnt > 0)
+		coex_sta->connect_ap_period_cnt--;
 
-	if (halbtc8723d1ant_is_wifibt_status_changed(btcoexist) || (bt_relink_finish)
-		|| (special_pkt_finish))
+	if (halbtc8723d1ant_is_wifibt_status_changed(btcoexist) ||
+	    bt_relink_finish || special_pkt_finish)
 		halbtc8723d1ant_run_coexist_mechanism(btcoexist);
-
-
 }
 
 void ex_halbtc8723d1ant_set_antenna_notify(IN struct btc_coexist *btcoexist,
@@ -6412,156 +5076,12 @@ void ex_halbtc8723d1ant_antenna_detection(IN struct btc_coexist *btcoexist,
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 		    "xxxxxxxxxxxxxxxx Ext Call AntennaDetect()!!\n");
 	BTC_TRACE(trace_buf);
-
-#if BT_8723D_1ANT_ANTDET_ENABLE
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx Call AntennaDetect()!!\n");
-	BTC_TRACE(trace_buf);
-
-	if (seconds == 0) {
-		psd_scan->ant_det_try_count	= 0;
-		psd_scan->ant_det_fail_count	= 0;
-		ant_det_count = 0;
-		ant_det_fail_count = 0;
-		board_info->btdm_ant_det_finish = FALSE;
-		board_info->btdm_ant_num_by_ant_det = 1;
-		return;
-	}
-
-	if (!board_info->btdm_ant_det_finish) {
-		psd_scan->ant_det_inteval_count =
-			psd_scan->ant_det_inteval_count + 2;
-
-		if (psd_scan->ant_det_inteval_count >=
-		    BT_8723D_2ANT_ANTDET_RETRY_INTERVAL) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is up, Try Detect!!\n");
-			BTC_TRACE(trace_buf);
-
-			psd_scan->is_AntDet_running = TRUE;
-
-			halbtc8723d1ant_read_score_board(btcoexist,	&u16tmp);
-
-			if (u16tmp & BIT(
-				2)) { /* Antenna detection is already done before last WL power on   */
-				board_info->btdm_ant_det_finish = TRUE;
-				psd_scan->ant_det_try_count = 1;
-				psd_scan->ant_det_fail_count = 0;
-				board_info->btdm_ant_num_by_ant_det = (u16tmp &
-							       BIT(3)) ? 1 : 2;
-				psd_scan->ant_det_result = 12;
-
-				psd_scan->ant_det_psd_scan_peak_val =
-					btcoexist->btc_get_ant_det_val_from_bt(
-						btcoexist) * 100;
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Result from BT (%d-Ant)\n",
-					board_info->btdm_ant_num_by_ant_det);
-				BTC_TRACE(trace_buf);
-			} else
-				board_info->btdm_ant_det_finish =
-					halbtc8723d1ant_psd_antenna_detection_check(
-						btcoexist);
-
-			board_info->ant_det_result = psd_scan->ant_det_result;
-			btcoexist->bdontenterLPS = FALSE;
-
-			if (board_info->btdm_ant_det_finish) {
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Success!!\n");
-				BTC_TRACE(trace_buf);
-
-				if (board_info->btdm_ant_num_by_ant_det == 2) {
-					board_info->ant_div_cfg = TRUE;
-					halbtc8723d1ant_set_ant_path(btcoexist,
-						BTC_ANT_PATH_WIFI, FORCE_EXEC,
-						BT_8723D_1ANT_PHASE_2G_RUNTIME);
-				} else
-					halbtc8723d1ant_set_ant_path(btcoexist,
-						BTC_ANT_PATH_AUTO, FORCE_EXEC,
-						BT_8723D_1ANT_PHASE_2G_RUNTIME);
-
-				/*for 8723d, btc_set_bt_trx_mask is just used to
-					notify BT stop le tx and Ant Det Result , not set BT RF TRx Mask  */
-				if (psd_scan->ant_det_result != 12) {
-
-					AntDetval = (u8)(
-						psd_scan->ant_det_psd_scan_peak_val
-							    / 100) & 0x7f;
-
-					AntDetval =
-						(board_info->btdm_ant_num_by_ant_det
-						 == 1) ? (AntDetval | 0x80) :
-						AntDetval;
-					board_info->antdetval = AntDetval;
-
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"xxxxxx AntennaDetect(), Ant Count = %d, PSD Val = %d\n",
-						    ((AntDetval &
-						      0x80) ? 1
-						     : 2), AntDetval
-						    & 0x7f);
-					BTC_TRACE(trace_buf);
-
-					if (btcoexist->btc_set_bt_trx_mask(
-						    btcoexist, AntDetval))
-						BTC_SPRINTF(trace_buf,
-							    BT_TMP_BUF_SIZE,
-							"xxxxxx AntennaDetect(), Notify BT stop le tx by set_bt_trx_mask ok!\n");
-					else
-						BTC_SPRINTF(trace_buf,
-							    BT_TMP_BUF_SIZE,
-							"xxxxxx AntennaDetect(), Notify BT stop le tx by set_bt_trx_mask fail!\n");
-
-					BTC_TRACE(trace_buf);
-				} else
-					board_info->antdetval =
-						psd_scan->ant_det_psd_scan_peak_val/100;
-
-				board_info->btdm_ant_det_complete_fail = FALSE;
-
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Fail!!\n");
-				BTC_TRACE(trace_buf);
-
-				board_info->btdm_ant_det_complete_fail = TRUE;
-			}
-
-			psd_scan->ant_det_inteval_count = 0;
-			psd_scan->is_AntDet_running = FALSE;
-			/* stimulate coex running */
-			halbtc8723d1ant_run_coexist_mechanism(
-				btcoexist);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Stimulate Coex running\n!!");
-			BTC_TRACE(trace_buf);
-
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is not up! (%d)\n",
-				    psd_scan->ant_det_inteval_count);
-			BTC_TRACE(trace_buf);
-
-			if (psd_scan->ant_det_inteval_count == 8)
-				btcoexist->bdontenterLPS = TRUE;
-			else
-				btcoexist->bdontenterLPS = FALSE;
-		}
-
-	}
-#endif
-
-
 }
 
 
 void ex_halbtc8723d1ant_display_ant_detection(IN struct btc_coexist *btcoexist)
 {
-#if BT_8723D_1ANT_ANTDET_ENABLE
+#if 0
 	struct  btc_board_info	*board_info = &btcoexist->board_info;
 
 	if (psd_scan->ant_det_try_count != 0)	{
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.h
index f34224f24fa7..bf5d5193cf21 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d1ant.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -24,9 +25,9 @@
 #define	BT_8723D_1ANT_COEX_DBG					0
 #define	BT_AUTO_REPORT_ONLY_8723D_1ANT				1
 
-#define	BT_INFO_8723D_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8723D_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8723D_1ANT_B_HID						BIT(5)
+#define	BT_INFO_8723D_1ANT_B_FTP				BIT(7)
+#define	BT_INFO_8723D_1ANT_B_A2DP				BIT(6)
+#define	BT_INFO_8723D_1ANT_B_HID				BIT(5)
 #define	BT_INFO_8723D_1ANT_B_SCO_BUSY				BIT(4)
 #define	BT_INFO_8723D_1ANT_B_ACL_BUSY				BIT(3)
 #define	BT_INFO_8723D_1ANT_B_INQ_PAGE				BIT(2)
@@ -38,67 +39,67 @@
 
 #define	BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT		2
 
-#define  BT_8723D_1ANT_WIFI_NOISY_THRESH							30   /* max: 255 */
-#define  BT_8723D_1ANT_DEFAULT_ISOLATION						15	 /*  unit: dB */
+#define  BT_8723D_1ANT_WIFI_NOISY_THRESH			30 /*max: 255*/
+#define  BT_8723D_1ANT_DEFAULT_ISOLATION			15 /*unit: dB*/
 
 
 /* for Antenna detection */
-#define	BT_8723D_1ANT_ANTDET_PSDTHRES_BACKGROUND					50
-#define	BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			55
-#define	BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT							35
-#define	BT_8723D_1ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8723D_1ANT_ANTDET_SWEEPPOINT_DELAY							60000
-#define	BT_8723D_1ANT_ANTDET_ENABLE									1
-#define	BT_8723D_1ANT_ANTDET_BTTXTIME									100
-#define	BT_8723D_1ANT_ANTDET_BTTXCHANNEL								39
-#define	BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT						50
+#define	BT_8723D_1ANT_ANTDET_PSDTHRES_BACKGROUND			50
+#define	BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION			70
+#define	BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION		55
+#define	BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT				35
+#define	BT_8723D_1ANT_ANTDET_RETRY_INTERVAL				10
+#define	BT_8723D_1ANT_ANTDET_SWEEPPOINT_DELAY				60000
+#define	BT_8723D_1ANT_ANTDET_ENABLE					0
+#define	BT_8723D_1ANT_ANTDET_BTTXTIME					100
+#define	BT_8723D_1ANT_ANTDET_BTTXCHANNEL				39
+#define	BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT				50
 
 #define	BT_8723D_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
 
 enum bt_8723d_1ant_signal_state {
-	BT_8723D_1ANT_SIG_STA_SET_TO_LOW		= 0x0,
+	BT_8723D_1ANT_SIG_STA_SET_TO_LOW	= 0x0,
 	BT_8723D_1ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8723D_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,
+	BT_8723D_1ANT_SIG_STA_SET_TO_HIGH	= 0x1,
 	BT_8723D_1ANT_SIG_STA_MAX
 };
 
 enum bt_8723d_1ant_path_ctrl_owner {
 	BT_8723D_1ANT_PCO_BTSIDE		= 0x0,
-	BT_8723D_1ANT_PCO_WLSIDE	= 0x1,
+	BT_8723D_1ANT_PCO_WLSIDE		= 0x1,
 	BT_8723D_1ANT_PCO_MAX
 };
 
 enum bt_8723d_1ant_gnt_ctrl_type {
-	BT_8723D_1ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,
-	BT_8723D_1ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,
+	BT_8723D_1ANT_GNT_TYPE_CTRL_BY_PTA	= 0x0,
+	BT_8723D_1ANT_GNT_TYPE_CTRL_BY_SW	= 0x1,
 	BT_8723D_1ANT_GNT_TYPE_MAX
 };
 
 enum bt_8723d_1ant_gnt_ctrl_block {
 	BT_8723D_1ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8723D_1ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8723D_1ANT_GNT_BLOCK_BB			= 0x2,
+	BT_8723D_1ANT_GNT_BLOCK_RFC		= 0x1,
+	BT_8723D_1ANT_GNT_BLOCK_BB		= 0x2,
 	BT_8723D_1ANT_GNT_BLOCK_MAX
 };
 
 enum bt_8723d_1ant_lte_coex_table_type {
-	BT_8723D_1ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8723D_1ANT_CTT_BT_VS_LTE			= 0x1,
+	BT_8723D_1ANT_CTT_WL_VS_LTE		= 0x0,
+	BT_8723D_1ANT_CTT_BT_VS_LTE		= 0x1,
 	BT_8723D_1ANT_CTT_MAX
 };
 
 enum bt_8723d_1ant_lte_break_table_type {
-	BT_8723D_1ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8723D_1ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8723D_1ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8723D_1ANT_LBTT_LTE_BREAK_BT				= 0x3,
+	BT_8723D_1ANT_LBTT_WL_BREAK_LTE		= 0x0,
+	BT_8723D_1ANT_LBTT_BT_BREAK_LTE		= 0x1,
+	BT_8723D_1ANT_LBTT_LTE_BREAK_WL		= 0x2,
+	BT_8723D_1ANT_LBTT_LTE_BREAK_BT		= 0x3,
 	BT_8723D_1ANT_LBTT_MAX
 };
 
 enum bt_info_src_8723d_1ant {
 	BT_INFO_SRC_8723D_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723D_1ANT_BT_RSP				= 0x1,
+	BT_INFO_SRC_8723D_1ANT_BT_RSP			= 0x1,
 	BT_INFO_SRC_8723D_1ANT_BT_ACTIVE_SEND		= 0x2,
 	BT_INFO_SRC_8723D_1ANT_MAX
 };
@@ -106,20 +107,20 @@ enum bt_info_src_8723d_1ant {
 enum bt_8723d_1ant_bt_status {
 	BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
 	BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8723D_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8723D_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8723D_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8723D_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
+	BT_8723D_1ANT_BT_STATUS_INQ_PAGE		= 0x2,
+	BT_8723D_1ANT_BT_STATUS_ACL_BUSY		= 0x3,
+	BT_8723D_1ANT_BT_STATUS_SCO_BUSY		= 0x4,
+	BT_8723D_1ANT_BT_STATUS_ACL_SCO_BUSY		= 0x5,
 	BT_8723D_1ANT_BT_STATUS_MAX
 };
 
 enum bt_8723d_1ant_wifi_status {
-	BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
+	BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE		= 0x0,
+	BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	= 0x1,
+	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SCAN		= 0x2,
+	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	= 0x3,
+	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_IDLE		= 0x4,
+	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_BUSY		= 0x5,
 	BT_8723D_1ANT_WIFI_STATUS_MAX
 };
 
@@ -128,36 +129,37 @@ enum bt_8723d_1ant_coex_algo {
 	BT_8723D_1ANT_COEX_ALGO_SCO				= 0x1,
 	BT_8723D_1ANT_COEX_ALGO_HID				= 0x2,
 	BT_8723D_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8723D_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8723D_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8723D_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8723D_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8723D_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8723D_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
+	BT_8723D_1ANT_COEX_ALGO_A2DP_PANHS			= 0x4,
+	BT_8723D_1ANT_COEX_ALGO_PANEDR				= 0x5,
+	BT_8723D_1ANT_COEX_ALGO_PANHS				= 0x6,
+	BT_8723D_1ANT_COEX_ALGO_PANEDR_A2DP			= 0x7,
+	BT_8723D_1ANT_COEX_ALGO_PANEDR_HID			= 0x8,
+	BT_8723D_1ANT_COEX_ALGO_HID_A2DP_PANEDR			= 0x9,
 	BT_8723D_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
 	BT_8723D_1ANT_COEX_ALGO_MAX				= 0xb,
 };
 
 enum bt_8723d_1ant_phase {
-	BT_8723D_1ANT_PHASE_COEX_INIT								= 0x0,
-	BT_8723D_1ANT_PHASE_WLANONLY_INIT							= 0x1,
-	BT_8723D_1ANT_PHASE_WLAN_OFF								= 0x2,
-	BT_8723D_1ANT_PHASE_2G_RUNTIME								= 0x3,
-	BT_8723D_1ANT_PHASE_5G_RUNTIME								= 0x4,
-	BT_8723D_1ANT_PHASE_BTMPMODE								= 0x5,
-	BT_8723D_1ANT_PHASE_ANTENNA_DET								= 0x6,
-	BT_8723D_1ANT_PHASE_COEX_POWERON							= 0x7,
+	BT_8723D_1ANT_PHASE_COEX_INIT				= 0x0,
+	BT_8723D_1ANT_PHASE_WLANONLY_INIT			= 0x1,
+	BT_8723D_1ANT_PHASE_WLAN_OFF				= 0x2,
+	BT_8723D_1ANT_PHASE_2G_RUNTIME				= 0x3,
+	BT_8723D_1ANT_PHASE_5G_RUNTIME				= 0x4,
+	BT_8723D_1ANT_PHASE_BTMPMODE				= 0x5,
+	BT_8723D_1ANT_PHASE_ANTENNA_DET				= 0x6,
+	BT_8723D_1ANT_PHASE_COEX_POWERON			= 0x7,
 	BT_8723D_1ANT_PHASE_MAX
 };
 
 enum bt_8723d_1ant_Scoreboard {
-	BT_8723D_1ANT_SCOREBOARD_ACTIVE								= BIT(0),
-	BT_8723D_1ANT_SCOREBOARD_ONOFF								= BIT(1),
-	BT_8723D_1ANT_SCOREBOARD_SCAN								= BIT(2),
-	BT_8723D_1ANT_SCOREBOARD_UNDERTEST							= BIT(3),
-	BT_8723D_1ANT_SCOREBOARD_RXGAIN								= BIT(4),
-	BT_8723D_1ANT_SCOREBOARD_DKTOPP2M							= BIT(5),
-	BT_8723D_1ANT_SCOREBOARD_WLBUSY								= BIT(6)
+	BT_8723D_1ANT_SCOREBOARD_ACTIVE				= BIT(0),
+	BT_8723D_1ANT_SCOREBOARD_ONOFF				= BIT(1),
+	BT_8723D_1ANT_SCOREBOARD_SCAN				= BIT(2),
+	BT_8723D_1ANT_SCOREBOARD_UNDERTEST			= BIT(3),
+	BT_8723D_1ANT_SCOREBOARD_RXGAIN				= BIT(4),
+	BT_8723D_1ANT_SCOREBOARD_DKTOPP2M			= BIT(5),
+	BT_8723D_1ANT_SCOREBOARD_WLBUSY				= BIT(6),
+	BT_8723D_1ANT_SCOREBOARD_TDMA				= BIT(9),
 };
 
 struct coex_dm_8723d_1ant {
@@ -167,11 +169,9 @@ struct coex_dm_8723d_1ant {
 	/* fw mechanism */
 	boolean		cur_ignore_wlan_act;
 	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
 	u8		cur_ps_tdma;
 	u8		ps_tdma_para[5];
 	u8		ps_tdma_du_adj_type;
-	boolean		pre_ps_tdma_on;
 	boolean		cur_ps_tdma_on;
 	boolean		pre_bt_auto_report;
 	boolean		cur_bt_auto_report;
@@ -183,18 +183,14 @@ struct coex_dm_8723d_1ant {
 	/* sw mechanism */
 	boolean	pre_low_penalty_ra;
 	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
 	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
 	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
 	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
 	u8		cur_val0x6cc;
 	boolean		limited_dig;
 
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
+	u32		backup_arfr_cnt1;
+	u32		backup_arfr_cnt2;
 	u16		backup_retry_limit;
 	u8		backup_ampdu_max_time;
 
@@ -215,169 +211,183 @@ struct coex_dm_8723d_1ant {
 	u32		arp_cnt;
 
 	u8		error_condition;
+	u32		setting_tdma;
 };
 
 struct coex_sta_8723d_1ant {
-	boolean				bt_disabled;
-	boolean				bt_link_exist;
-	boolean				sco_exist;
-	boolean				a2dp_exist;
-	boolean				hid_exist;
-	boolean				pan_exist;
-	boolean				bt_hi_pri_link_exist;
-	u8					num_of_profile;
-
-	boolean				under_lps;
-	boolean				under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	boolean             is_hiPri_rx_overhead;
-	s8					bt_rssi;
-	boolean				bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	u8					bt_info_c2h[BT_INFO_SRC_8723D_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723D_1ANT_MAX];
-	boolean				bt_whck_test;
-	boolean				c2h_bt_inquiry_page;
-	boolean				c2h_bt_remote_name_req;
-	boolean				c2h_bt_page;				/* Add for win8.1 page out issue */
-	boolean				wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u8					bt_info_ext2;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	boolean				cck_lock;
-	boolean				cck_lock_ever;
-	boolean				cck_lock_warn;
-
-	u8					coex_table_type;
-	boolean				force_lps_ctrl;
-	boolean				concurrent_rx_mode_on;
-
-	u16					score_board;
-	u8					isolation_btween_wb;   /* 0~ 50 */
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-	boolean				acl_busy;
-	boolean				bt_create_connection;
-
-	u32					bt_coex_supported_feature;
-	u32					bt_coex_supported_version;
-
-	u8					bt_ble_scan_type;
-	u32					bt_ble_scan_para[3];
-
-	boolean				run_time_state;
-	boolean				freeze_coexrun_by_btinfo;
-
-	boolean				is_A2DP_3M;
-	boolean				voice_over_HOGP;
-	u8                  bt_info;
-	boolean				is_autoslot;
-	u8					forbidden_slot;
-	u8					hid_busy_num;
-	u8					hid_pair_cnt;
-
-	u32					cnt_RemoteNameReq;
-	u32					cnt_setupLink;
-	u32					cnt_ReInit;
-	u32					cnt_IgnWlanAct;
-	u32					cnt_Page;
-	u32					cnt_RoleSwitch;
-
-	u16					bt_reg_vendor_ac;
-	u16					bt_reg_vendor_ae;
-
-	boolean				is_setupLink;
-	u8					wl_noisy_level;
-	u32                 gnt_error_cnt;
-
-	u8					bt_afh_map[10];
-	u8					bt_relink_downcount;
-	boolean				is_tdma_btautoslot;
-	boolean				is_tdma_btautoslot_hang;
-
-	boolean				is_rf_state_off;
-
-	boolean				is_hid_low_pri_tx_overhead;
-	boolean				is_bt_multi_link;
-	boolean				is_bt_a2dp_sink;
-
-	u8					wl_fw_dbg_info[10];
-	u8					wl_rx_rate;
-	u8					wl_rts_rx_rate;
-
-	u16					score_board_WB;
-
-	boolean				is_hid_rcu;
-	boolean				is_ble_scan_toggle;
-
-	u16					legacy_forbidden_slot;
-	u16					le_forbidden_slot;
-	u8					bt_a2dp_vendor_id;
-	u32					bt_a2dp_device_name;
-	boolean				is_bt_opp_exist;
+	boolean		bt_disabled;
+	boolean		bt_link_exist;
+	boolean		sco_exist;
+	boolean		a2dp_exist;
+	boolean		hid_exist;
+	boolean		pan_exist;
+	boolean		bt_hi_pri_link_exist;
+	u8		num_of_profile;
+
+	boolean		under_lps;
+	boolean		under_ips;
+	u32		specific_pkt_period_cnt;
+	u8		connect_ap_period_cnt;
+	u8		pnp_awake_period_cnt;
+	u32		high_priority_tx;
+	u32		high_priority_rx;
+	u32		low_priority_tx;
+	u32		low_priority_rx;
+	boolean		is_hipri_rx_overhead;
+	s8		bt_rssi;
+	boolean		bt_tx_rx_mask;
+	u8		pre_bt_rssi_state;
+	u8		pre_wifi_rssi_state[4];
+	u8		bt_info_c2h[BT_INFO_SRC_8723D_1ANT_MAX][10];
+	u32		bt_info_c2h_cnt[BT_INFO_SRC_8723D_1ANT_MAX];
+	boolean		bt_whck_test;
+	boolean		c2h_bt_inquiry_page;
+	boolean		c2h_bt_remote_name_req;
+	boolean		c2h_bt_page;
+	boolean		wifi_is_high_pri_task;
+	boolean		wifi_in_scan_task;
+	u8		bt_retry_cnt;
+	u8		bt_info_ext;
+	u8		bt_info_ext2;
+	u32		pop_event_cnt;
+	u8		scan_ap_num;
+
+	u32		crc_ok_cck;
+	u32		crc_ok_11g;
+	u32		crc_ok_11n;
+	u32		crc_ok_11n_vht;
+
+	u32		crc_err_cck;
+	u32		crc_err_11g;
+	u32		crc_err_11n;
+	u32		crc_err_11n_vht;
+
+	boolean		cck_lock;
+	boolean		cck_lock_ever;
+	boolean		cck_lock_warn;
+
+	u8		coex_table_type;
+	boolean		force_lps_ctrl;
+	boolean		concurrent_rx_mode_on;
+
+	u16		score_board;
+	u8		isolation_btween_wb;   /* 0~ 50 */
+
+	u8		a2dp_bit_pool;
+	u8		kt_ver;
+	boolean		acl_busy;
+	boolean		bt_create_connection;
+
+	u32		bt_coex_supported_feature;
+	u32		bt_coex_supported_version;
+
+	u8		bt_ble_scan_type;
+	u32		bt_ble_scan_para[3];
+
+	boolean		run_time_state;
+	boolean		freeze_coexrun_by_btinfo;
+
+	boolean		is_A2DP_3M;
+	boolean		voice_over_HOGP;
+	u8		bt_info;
+	u8		forbidden_slot;
+	u8		hid_busy_num;
+	u8		hid_pair_cnt;
+
+	u32		cnt_remotenamereq;
+	u32		cnt_setuplink;
+	u32		cnt_reinit;
+	u32		cnt_ignwlanact;
+	u32		cnt_page;
+	u32		cnt_roleswitch;
+
+	u16		bt_reg_vendor_ac;
+	u16		bt_reg_vendor_ae;
+
+	boolean		is_setup_link;
+	u8		wl_noisy_level;
+	u32		gnt_error_cnt;
+
+	u8		bt_afh_map[10];
+	u8		bt_relink_downcount;
+	boolean		is_tdma_btautoslot;
+	boolean		is_tdma_btautoslot_hang;
+
+	boolean		is_rf_state_off;
+
+	boolean		is_hid_low_pri_tx_overhead;
+	boolean		is_bt_multi_link;
+	boolean		is_bt_a2dp_sink;
+
+	u8		wl_fw_dbg_info[10];
+	u8		wl_rx_rate;
+	u8		wl_rts_rx_rate;
+
+	u16		score_board_WB;
+
+	boolean		is_hid_rcu;
+	boolean		is_ble_scan_en;
+
+	u16		legacy_forbidden_slot;
+	u16		le_forbidden_slot;
+	u8		bt_a2dp_vendor_id;
+	u32		bt_a2dp_device_name;
+	boolean		is_bt_opp_exist;
+	boolean		is_no_wl_5ms_extend;
+
+	u16		wl_0x42a_backup;
+	u32		wl_0x430_backup;
+	u32		wl_0x434_backup;
+	u8		wl_0x456_backup;
+
+	boolean		wl_tx_limit_en;
+	boolean		wl_ampdu_limit_en;
+	boolean		wl_rxagg_limit_en;
+	u8		wl_rxagg_size;
 };
 
-#define  BT_8723D_1ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
-#define  BT_8723D_1ANT_ANTDET_PSD_AVGNUM			1	/* MAX:3 */
-#define	BT_8723D_1ANT_ANTDET_BUF_LEN				16
+#define  BT_8723D_1ANT_ANTDET_PSD_POINTS			256
+#define  BT_8723D_1ANT_ANTDET_PSD_AVGNUM			1
+#define	BT_8723D_1ANT_ANTDET_BUF_LEN			16
 
 struct psdscan_sta_8723d_1ant {
 
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8723D_1ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8723D_1ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_max_value2;
-	u32			psd_avg_value;   /* filter loop_max_value that below BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT, and average the rest*/
-	u32			psd_loop_max_value[BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT];  /*max value in each loop */
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_AntDet_running;
-	boolean			is_psd_show_max_only;
+	u32	ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
+	u32	ant_det_bt_tx_time;
+	u32	ant_det_pre_psdscan_peak_val;
+	boolean	ant_det_is_ant_det_available;
+	u32	ant_det_psd_scan_peak_val;
+	boolean	ant_det_is_btreply_available;
+	u32	ant_det_psd_scan_peak_freq;
+
+	u8	ant_det_result;
+	u8	ant_det_peak_val[BT_8723D_1ANT_ANTDET_BUF_LEN];
+	u8	ant_det_peak_freq[BT_8723D_1ANT_ANTDET_BUF_LEN];
+	u32	ant_det_try_count;
+	u32	ant_det_fail_count;
+	u32	ant_det_inteval_count;
+	u32	ant_det_thres_offset;
+
+	u32	real_cent_freq;
+	s32	real_offset;
+	u32	real_span;
+
+	u32	psd_band_width;
+	u32	psd_point;
+	u32	psd_report[1024];
+	u32	psd_report_max_hold[1024];
+	u32	psd_start_point;
+	u32	psd_stop_point;
+	u32	psd_max_value_point;
+	u32	psd_max_value;
+	u32	psd_max_value2;
+	u32	psd_avg_value;
+	u32	psd_loop_max_value[BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT];
+	u32	psd_start_base;
+	u32	psd_avg_num;	/* 1/8/16/32 */
+	u32	psd_gen_count;
+	boolean	is_antdet_running;
+	boolean	is_psd_show_max_only;
 };
 
 /* *******************************************
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.c
index fe8bec2c5924..36b4519fb496 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -47,28 +48,12 @@ const char *const glbt_info_src_8723d_2ant[] = {
 	"BT Info[bt rsp]",
 	"BT Info[bt auto report]",
 };
-/* ************************************************************
- * BtCoex Version Format:
- * 1. date :			glcoex_ver_date_XXXXX_1ant
- * 2. WifiCoexVersion : glcoex_ver_XXXX_1ant
- * 3. BtCoexVersion :	glcoex_ver_btdesired_XXXXX_1ant
- * 4. others :			glcoex_ver_XXXXXX_XXXXX_1ant
- *
- * Variable should be indicated IC and Antenna numbers !!!
- * Please strictly follow this order and naming style !!!
- *
- * ************************************************************ */
-u32	glcoex_ver_date_8723d_2ant = 20171025;
-u32	glcoex_ver_8723d_2ant = 0x20;
-u32 glcoex_ver_btdesired_8723d_2ant = 0x20;
 
+u32	glcoex_ver_date_8723d_2ant = 20181130;
+u32	glcoex_ver_8723d_2ant = 0x2e;
+u32	glcoex_ver_btdesired_8723d_2ant = 0x2d;
 
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8723d2ant_
- * ************************************************************ */
+static
 u8 halbtc8723d2ant_bt_rssi_state(IN struct btc_coexist *btcoexist,
 	u8 *ppre_bt_rssi_state, u8 level_num,
 	u8 rssi_thresh, u8 rssi_thresh1)
@@ -129,6 +114,7 @@ u8 halbtc8723d2ant_bt_rssi_state(IN struct btc_coexist *btcoexist,
 	return bt_rssi_state;
 }
 
+static
 u8 halbtc8723d2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
 	   IN u8 *pprewifi_rssi_state, IN u8 level_num, IN u8 rssi_thresh,
 				   IN u8 rssi_thresh1)
@@ -189,6 +175,7 @@ u8 halbtc8723d2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
 	return wifi_rssi_state;
 }
 
+static
 void halbtc8723d2ant_coex_switch_threshold(IN struct btc_coexist *btcoexist,
 		IN u8 isolation_measuared)
 {
@@ -207,61 +194,177 @@ void halbtc8723d2ant_coex_switch_threshold(IN struct btc_coexist *btcoexist,
 
 	coex_sta->bt_coex_thres		 = BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES1;
 	coex_sta->bt_coex_thres2		 = BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES2;
+}
+
+static void
+halbtc8723d2ant_limited_tx(struct btc_coexist *btcoexist, boolean force_exec,
+			   boolean tx_limit_en,  boolean ampdu_limit_en)
+{
+	boolean wifi_under_b_mode = FALSE;
+	u32	wifi_link_status = 0, num_of_wifi_link = 0;
 
+	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
+			   &wifi_link_status);
 
-	/*
-		coex_sta->wifi_coex_thres		= interference_wl_tx + BT_8723D_2ANT_WIFI_SIR_THRES1;
-		coex_sta->wifi_coex_thres2		= interference_wl_tx + BT_8723D_2ANT_WIFI_SIR_THRES2;
+	num_of_wifi_link = wifi_link_status >> 16;
 
-		coex_sta->bt_coex_thres		= interference_bt_tx + BT_8723D_2ANT_BT_SIR_THRES1;
-		coex_sta->bt_coex_thres2		= interference_bt_tx + BT_8723D_2ANT_BT_SIR_THRES2;
-	*/
+	/* Force Max Tx retry limit = 8*/
+	if (!coex_sta->wl_tx_limit_en) {
+		coex_sta->wl_0x430_backup =
+			btcoexist->btc_read_4byte(btcoexist, 0x430);
+		coex_sta->wl_0x434_backup =
+			btcoexist->btc_read_4byte(btcoexist, 0x434);
+		coex_sta->wl_0x42a_backup =
+			btcoexist->btc_read_2byte(btcoexist, 0x42a);
+	}
 
+	if (!coex_sta->wl_ampdu_limit_en)
+		coex_sta->wl_0x456_backup = btcoexist->btc_read_1byte(btcoexist,
+								      0x456);
 
+	if (!force_exec && tx_limit_en == coex_sta->wl_tx_limit_en &&
+	    ampdu_limit_en == coex_sta->wl_ampdu_limit_en)
+		return;
 
+	coex_sta->wl_tx_limit_en = tx_limit_en;
+	coex_sta->wl_ampdu_limit_en = ampdu_limit_en;
+
+	if (tx_limit_en) {
+		/* Set BT polluted packet on for Tx rate adaptive not
+		 * including Tx retry break by PTA, 0x45c[19] =1
+		 *
+		 * Set queue life time to avoid can't reach tx retry limit
+		 * if tx is always break by GNT_BT.
+		 */
+		if ((wifi_link_status & WIFI_STA_CONNECTED) &&
+		     num_of_wifi_link == 1) {
+			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x1);
+			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x426, 0xf, 0xf);
+		}
 
+		/* Max Tx retry limit = 8*/
+		btcoexist->btc_write_2byte(btcoexist, 0x42a, 0x0808);
 
-	/*
-		if  ( BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES1 < (isolation_measuared -
-					BT_8723D_2ANT_DEFAULT_ISOLATION) )
-			coex_sta->wifi_coex_thres	 = BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES1;
-		else
-			coex_sta->wifi_coex_thres =  BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES1 -  (isolation_measuared -
-					BT_8723D_2ANT_DEFAULT_ISOLATION);
+		/* AMPDU duration limit*/
+		btcoexist->btc_write_1byte(btcoexist, 0x456, 0x20);
 
-		if  ( BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES1 < (isolation_measuared -
-					BT_8723D_2ANT_DEFAULT_ISOLATION) )
-			coex_sta->bt_coex_thres	 = BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES1;
-		else
-			coex_sta->bt_coex_thres =  BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES1 -  (isolation_measuared -
-					BT_8723D_2ANT_DEFAULT_ISOLATION);
+		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
+				   &wifi_under_b_mode);
 
-	*/
+		/* Auto rate fallback step within 8 retry*/
+		if (wifi_under_b_mode) {
+			btcoexist->btc_write_4byte(btcoexist, 0x430, 0x1000000);
+			btcoexist->btc_write_4byte(btcoexist, 0x434, 0x1010101);
+		} else {
+			btcoexist->btc_write_4byte(btcoexist, 0x430, 0x1000000);
+			btcoexist->btc_write_4byte(btcoexist, 0x434, 0x4030201);
+		}
+	} else {
+		/* Set BT polluted packet on for Tx rate adaptive not
+		 *including Tx retry break by PTA, 0x45c[19] =1
+		 */
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x0);
+
+		/* Set queue life time to avoid can't reach tx retry limit
+		 * if tx is always break by GNT_BT.
+		 */
+		if (num_of_wifi_link  == 1)
+			btcoexist->btc_write_1byte_bitmask(btcoexist, 0x426, 0xf, 0x0);
+
+		/* Recovery Max Tx retry limit*/
+		btcoexist->btc_write_2byte(btcoexist, 0x42a,
+					   coex_sta->wl_0x42a_backup);
+		btcoexist->btc_write_4byte(btcoexist, 0x430,
+					   coex_sta->wl_0x430_backup);
+		btcoexist->btc_write_4byte(btcoexist, 0x434,
+					   coex_sta->wl_0x434_backup);
+	}
+
+	if (ampdu_limit_en)
+		btcoexist->btc_write_1byte(btcoexist, 0x456, 0x20);
+	else
+		btcoexist->btc_write_1byte(btcoexist, 0x456,
+					   coex_sta->wl_0x456_backup);
 }
 
-
-void halbtc8723d2ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
+static void
+halbtc8723d2ant_limited_rx(struct btc_coexist *btcoexist, boolean force_exec,
+			   boolean rej_ap_agg_pkt, boolean bt_ctrl_agg_buf_size,
+			   u8 agg_buf_size)
 {
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
+#if 0
+	boolean reject_rx_agg = rej_ap_agg_pkt;
+	boolean bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
+	u8 rx_agg_size = agg_buf_size;
+
+	if (!force_exec &&
+	    bt_ctrl_agg_buf_size == coex_sta->wl_rxagg_limit_en &&
+	    agg_buf_size == coex_sta->wl_rxagg_size)
+		return;
+
+	coex_sta->wl_rxagg_limit_en = bt_ctrl_agg_buf_size;
+	coex_sta->wl_rxagg_size = agg_buf_size;
+
+	/*btc->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
+	 *&reject_rx_agg);
+	 */
 	/* decide BT control aggregation buf size or not */
 	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
 			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
+	/* aggregation buf size, only work
+	 * when BT control Rx aggregation size
+	 */
 	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
 	/* real update aggregation setting */
 	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
+#endif
+}
+
+static
+void halbtc8723d2ant_set_fw_low_penalty_ra(IN struct btc_coexist
+		*btcoexist, IN boolean low_penalty_ra)
+{
+	u8 h2c_parameter[6] = {0};
+
+	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
+
+	if (low_penalty_ra) {
+		h2c_parameter[1] |= BIT(0);
+		h2c_parameter[2] =
+			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
+		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
+		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
+		h2c_parameter[5] = 0xf9;	/* MCS5 or OFDM36	 */
+	}
+
+	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
+}
+
+static
+void halbtc8723d2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
+				    IN boolean force_exec,
+				    IN boolean low_penalty_ra)
+{
+	coex_dm->cur_low_penalty_ra = low_penalty_ra;
+
+	if (!force_exec) {
+		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
+			return;
+	}
+
+	halbtc8723d2ant_set_fw_low_penalty_ra(btcoexist,
+					      coex_dm->cur_low_penalty_ra);
+
+#if 0
+	if (low_penalty_ra)
+		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 15);
+	else
+		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
+#endif
+	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
 }
 
+static
 void halbtc8723d2ant_query_bt_info(IN struct btc_coexist *btcoexist)
 {
 	u8			h2c_parameter[1] = {0};
@@ -272,12 +375,13 @@ void halbtc8723d2ant_query_bt_info(IN struct btc_coexist *btcoexist)
 	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
 }
 
+static
 void halbtc8723d2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 {
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0, cnt_slave = 0, cnt_overhead = 0,
-				cnt_autoslot_hang = 0;
+	u32 reg_hp_txrx, reg_lp_txrx, u32tmp;
+	u32 reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
+	static u8	num_of_bt_counter_chk = 0, cnt_overhead = 0,
+		cnt_autoslot_hang = 0;
 
 	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
@@ -298,58 +402,39 @@ void halbtc8723d2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 	coex_sta->low_priority_rx = reg_lp_rx;
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-				reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
+		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
+		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
 
 	BTC_TRACE(trace_buf);
 
-	if (BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		coex_dm->bt_status) {
+	if (coex_dm->bt_status == BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE) {
+		if (coex_sta->high_priority_rx >= 15) {
+			if (cnt_overhead < 3)
+				cnt_overhead++;
 
-			if (coex_sta->high_priority_rx >= 15) {
-					if (cnt_overhead < 3)
-						cnt_overhead++;
-
-					if (cnt_overhead == 3)
-						coex_sta->is_hiPri_rx_overhead = TRUE;
-			 } else {
-					if (cnt_overhead > 0)
-						cnt_overhead--;
+			if (cnt_overhead == 3)
+				coex_sta->is_hipri_rx_overhead = TRUE;
+		} else {
+			if (cnt_overhead > 0)
+				cnt_overhead--;
 
-					if (cnt_overhead == 0)
-						coex_sta->is_hiPri_rx_overhead = FALSE;
-			}
-	} else
-		coex_sta->is_hiPri_rx_overhead = FALSE;
+			if (cnt_overhead == 0)
+				coex_sta->is_hipri_rx_overhead = FALSE;
+		}
+	} else {
+		coex_sta->is_hipri_rx_overhead = FALSE;
+	}
 
 	/* reset counter */
 	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
 
-	if ((coex_sta->low_priority_tx > 1050)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
+	if (coex_sta->low_priority_tx > 1050  &&
+	    !coex_sta->c2h_bt_inquiry_page)
 		coex_sta->pop_event_cnt++;
 
-	if ((coex_sta->low_priority_rx >= 950) &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx)
-	    && (!coex_sta->under_ips)  && (!coex_sta->c2h_bt_inquiry_page) &&
-	    (coex_sta->bt_link_exist))	{
-		if (cnt_slave >= 2) {
-			bt_link_info->slave_role = TRUE;
-			cnt_slave = 2;
-		} else
-			cnt_slave++;
-	} else {
-		if (cnt_slave == 0)	{
-			bt_link_info->slave_role = FALSE;
-			cnt_slave = 0;
-		} else
-			cnt_slave--;
-
-	}
-
 	if (coex_sta->is_tdma_btautoslot) {
-		if ((coex_sta->low_priority_tx >= 1300) &&
-			(coex_sta->low_priority_rx <= 150)) {
+		if (coex_sta->low_priority_tx >= 1300 &&
+		    coex_sta->low_priority_rx <= 150) {
 			if (cnt_autoslot_hang >= 2) {
 				coex_sta->is_tdma_btautoslot_hang = TRUE;
 				cnt_autoslot_hang = 2;
@@ -365,11 +450,11 @@ void halbtc8723d2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 	}
 
 	if (coex_sta->sco_exist) {
-		if ((coex_sta->high_priority_tx >= 400) &&
-		(coex_sta->high_priority_rx >= 400))
-			coex_sta->is_eSCO_mode = FALSE;
+		if (coex_sta->high_priority_tx >= 400 &&
+		    coex_sta->high_priority_rx >= 400)
+			coex_sta->is_esco_mode = FALSE;
 		else
-			coex_sta->is_eSCO_mode = TRUE;
+			coex_sta->is_esco_mode = TRUE;
 	}
 
 	if (bt_link_info->hid_only) {
@@ -380,11 +465,10 @@ void halbtc8723d2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 	}
 
 	if (!coex_sta->bt_disabled) {
-
-		if ((coex_sta->high_priority_tx == 0) &&
-		    (coex_sta->high_priority_rx == 0) &&
-		    (coex_sta->low_priority_tx == 0) &&
-		    (coex_sta->low_priority_rx == 0)) {
+		if (coex_sta->high_priority_tx == 0 &&
+		    coex_sta->high_priority_rx == 0 &&
+		    coex_sta->low_priority_tx == 0 &&
+		    coex_sta->low_priority_rx == 0) {
 			num_of_bt_counter_chk++;
 			if (num_of_bt_counter_chk >= 3) {
 				halbtc8723d2ant_query_bt_info(btcoexist);
@@ -392,9 +476,9 @@ void halbtc8723d2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
 			}
 		}
 	}
-
 }
 
+static
 void halbtc8723d2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
 {
 	s32 wifi_rssi = 0;
@@ -404,15 +488,14 @@ void halbtc8723d2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
 	static u8 cck_lock_counter = 0, wl_noisy_count0 = 0,
 		  wl_noisy_count1 = 3, wl_noisy_count2 = 0;
 	u32 total_cnt, reg_val1, reg_val2, cnt_cck;
-	u32 cnt_crcok = 0, cnt_crcerr = 0, cnt_ccklocking = 0;
-	static u8 cnt = 0, cnt_cal = 0;
+	u32 cnt_crcok = 0, cnt_crcerr = 0;
+	static u8 cnt = 0, cnt_cal = 0, cnt_ccklocking = 0;
 	u8	h2c_parameter[1] = {0};
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
 
 	/*send h2c to query WL FW dbg info	*/
-	if (((coex_dm->cur_ps_tdma_on) && (coex_sta->force_lps_ctrl)) ||
-		 ((coex_sta->acl_busy) && (bt_link_info->a2dp_exist))) {
+	if (coex_dm->cur_ps_tdma_on) {
 		h2c_parameter[0] = 0x8;
 		btcoexist->btc_fill_h2c(btcoexist, 0x69, 1, h2c_parameter);
 	}
@@ -534,17 +617,21 @@ void halbtc8723d2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
 	}
 }
 
-
-
+static
 void halbtc8723d2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 {
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean			bt_hs_on = FALSE;
-	boolean			bt_busy = FALSE;
-	u32			val = 0;
-	static	u8		pre_num_of_profile = 0, cur_num_of_profile = 0, cnt = 0;
+	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
+	boolean		bt_hs_on = FALSE, bt_busy = FALSE;
+	u32		val = 0, wifi_link_status = 0, num_of_wifi_link = 0;
+	static u8		pre_num_of_profile, cur_num_of_profile, cnt;
+	static boolean	pre_ble_scan_en;
+
+	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
+			   &wifi_link_status);
+
+	num_of_wifi_link = wifi_link_status >> 16;
 
-	if (coex_sta->is_ble_scan_toggle) {
+	if (coex_sta->is_ble_scan_en && !pre_ble_scan_en) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 					"[BTCoex], BT ext info bit4 check, query BLE Scan type!!\n");
 				BTC_TRACE(trace_buf);
@@ -561,6 +648,7 @@ void halbtc8723d2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist, 0x4);
 	}
 
+	pre_ble_scan_en = coex_sta->is_ble_scan_en;
 	coex_sta->num_of_profile = 0;
 
 	/* set link exist status */
@@ -708,7 +796,8 @@ void halbtc8723d2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 			btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_DEVICE_INFO, &val);
 
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BtInfoNotify(), get BT DEVICE_INFO = %x\n", val);
+				    "[BTCoex], BtInfoNotify(), get BT DEVICE_INFO = %x\n",
+				    val);
 			BTC_TRACE(trace_buf);
 
 			coex_sta->bt_a2dp_vendor_id = (u8)(val & 0xff);
@@ -723,10 +812,13 @@ void halbtc8723d2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 			if (cnt > 0)
 				cnt--;
 
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL, &val);
+			btcoexist->btc_get(btcoexist,
+					   BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL,
+					   &val);
 
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BtInfoNotify(), get BT FORBIDDEN_SLOT_VAL = %x, cnt = %d\n", val, cnt);
+				    "[BTCoex], BtInfoNotify(), get BT FORBIDDEN_SLOT_VAL = %x, cnt = %d\n",
+				    val, cnt);
 			BTC_TRACE(trace_buf);
 
 			coex_sta->legacy_forbidden_slot = (u16)(val & 0xffff);
@@ -735,8 +827,40 @@ void halbtc8723d2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
 	}
 
 	pre_num_of_profile = coex_sta->num_of_profile;
+
+	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
+		return;
+
+	if (num_of_wifi_link == 0 ||
+	    coex_dm->bt_status == BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE) {
+		halbtc8723d2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
+		halbtc8723d2ant_limited_tx(btcoexist, NORMAL_EXEC, FALSE,
+					   FALSE);
+		halbtc8723d2ant_limited_rx(btcoexist, NM_EXCU, FALSE, TRUE, 64);
+	} else if (wifi_link_status & WIFI_P2P_GO_CONNECTED ||
+		    wifi_link_status & WIFI_P2P_GC_CONNECTED) {
+		halbtc8723d2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
+		halbtc8723d2ant_limited_tx(btcoexist, NM_EXCU, TRUE, TRUE);
+		halbtc8723d2ant_limited_rx(btcoexist, NM_EXCU, FALSE, TRUE, 16);
+	} else {
+		halbtc8723d2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
+
+		if (bt_link_info->hid_exist || coex_sta->hid_pair_cnt > 0 ||
+		    bt_link_info->sco_exist) {
+			halbtc8723d2ant_limited_tx(btcoexist, NM_EXCU, TRUE,
+						   TRUE);
+			halbtc8723d2ant_limited_rx(btcoexist, NM_EXCU, FALSE,
+						   TRUE, 16);
+		} else {
+			halbtc8723d2ant_limited_tx(btcoexist, NM_EXCU, TRUE,
+						   FALSE);
+			halbtc8723d2ant_limited_rx(btcoexist, NM_EXCU, FALSE,
+						   TRUE, 64);
+		}
+	}
 }
 
+static
 void halbtc8723d2ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
 		IN u8 type)
 {
@@ -747,14 +871,15 @@ void halbtc8723d2ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
 	/* only 2.4G we need to inform bt the chnl mask */
 	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
 			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		h2c_parameter[0] =
-			0x1;  /* enable BT AFH skip WL channel for 8723d because BT Rx LO interference */
-		/* h2c_parameter[0] = 0x0; */
+	if (type == BTC_MEDIA_CONNECT && wifi_central_chnl <= 14) {
+		/* enable BT AFH skip WL channel for 8723d
+		 * because BT Rx LO interference
+		 * h2c_parameter[0] = 0x1;
+		 * h2c_parameter[0] = 0x0;
+		 */
 		h2c_parameter[1] = wifi_central_chnl;
 		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
+		if (wifi_bw == BTC_WIFI_BW_HT40)
 			h2c_parameter[2] = 0x30;
 		else
 			h2c_parameter[2] = 0x20;
@@ -768,6 +893,7 @@ void halbtc8723d2ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
 
 }
 
+static
 void halbtc8723d2ant_write_score_board(
 	IN	struct  btc_coexist		*btcoexist,
 	IN	u16				bitpos,
@@ -785,45 +911,41 @@ void halbtc8723d2ant_write_score_board(
 	coex_sta->score_board_WB = originalval;
 
 	if (originalval != preval) {
-
 		preval = originalval;
-	btcoexist->btc_write_2byte(btcoexist, 0xaa, originalval);
+		btcoexist->btc_write_2byte(btcoexist, 0xaa, originalval);
 	} else {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8723d2ant_write_score_board: return for nochange\n");
+			    "[BTCoex], halbtc8723d2ant_write_score_board: return for nochange\n");
 		BTC_TRACE(trace_buf);
 	}
 }
 
-
-
+static
 void halbtc8723d2ant_read_score_board(
 	IN	struct  btc_coexist		*btcoexist,
 	IN   u16				*score_board_val
 )
 {
-
-	*score_board_val = (btcoexist->btc_read_2byte(btcoexist,
-			    0xaa)) & 0x7fff;
+	*score_board_val = (btcoexist->btc_read_2byte(btcoexist, 0xaa)) &
+				0x7fff;
 }
 
-
+static
 void halbtc8723d2ant_post_state_to_bt(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16						type,
-	IN  boolean                 state
+	IN struct  btc_coexist	*btcoexist,
+	IN u16		type,
+	IN boolean	state
 )
 {
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8723d2ant_post_state_to_bt: type = %d, state =%d\n",
-		type, state);
+		    "[BTCoex], %s: type = %d, state =%d\n",
+		    __func__, type, state);
 	BTC_TRACE(trace_buf);
 
 	halbtc8723d2ant_write_score_board(btcoexist, (u16) type, state);
-
 }
 
-
+static
 void halbtc8723d2ant_adjust_wl_tx_power(IN struct btc_coexist *btcoexist,
 			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
 {
@@ -841,11 +963,11 @@ void halbtc8723d2ant_adjust_wl_tx_power(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
 }
 
-
+static
 void halbtc8723d2ant_adjust_bt_tx_power(IN struct btc_coexist *btcoexist,
 				IN boolean force_exec, IN u8 dec_bt_pwr_lvl)
 {
-	u8			h2c_parameter[1] = {0};
+	u8	h2c_parameter[1] = {0};
 
 	coex_dm->cur_bt_dec_pwr_lvl = dec_bt_pwr_lvl;
 
@@ -861,19 +983,26 @@ void halbtc8723d2ant_adjust_bt_tx_power(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_bt_dec_pwr_lvl = coex_dm->cur_bt_dec_pwr_lvl;
 }
 
+static
 void halbtc8723d2ant_adjust_wl_rx_gain(IN struct btc_coexist *btcoexist,
 			       IN boolean force_exec, IN boolean agc_table_en)
 {
-	u32 rx_gain_value_enable[] = {0xec120101, 0xeb130101, 0xce140101, 0xcd150101, 0xcc160101,
-		0xcb170101, 0xca180101, 0x8d190101, 0x8c1a0101, 0x8b1b0101,
-		0x4f1c0101, 0x4e1d0101, 0x4d1e0101, 0x4c1f0101, 0x0e200101,
-		0x0d210101, 0x0c220101, 0x0b230101, 0xcf240001, 0xce250001,
-		0xcd260001, 0xcc270001, 0x8f280001, 0xffffffff};
-	u32 rx_gain_value_disable[] = {0xec120101, 0xeb130101, 0xea140101, 0xe9150101, 0xe8160101,
-		0xe7170101, 0xe6180101, 0xe5190101, 0xe41a0101, 0xe31b0101,
-		0xe21c0101, 0xe11d0101, 0xe01e0101, 0x861f0101, 0x85200101,
-		0x84210101, 0x83220101, 0x82230101, 0x81240101, 0x80250101,
-		0x44260101, 0x43270101, 0x42280101, 0xffffffff};
+	u32 rx_gain_value_enable[] = {0xec120101, 0xeb130101, 0xce140101,
+				      0xcd150101, 0xcc160101, 0xcb170101,
+				      0xca180101, 0x8d190101, 0x8c1a0101,
+				      0x8b1b0101, 0x4f1c0101, 0x4e1d0101,
+				      0x4d1e0101, 0x4c1f0101, 0x0e200101,
+				      0x0d210101, 0x0c220101, 0x0b230101,
+				      0xcf240001, 0xce250001, 0xcd260001,
+				      0xcc270001, 0x8f280001, 0xffffffff};
+	u32 rx_gain_value_disable[] = {0xec120101, 0xeb130101, 0xea140101,
+				       0xe9150101, 0xe8160101, 0xe7170101,
+				       0xe6180101, 0xe5190101, 0xe41a0101,
+				       0xe31b0101, 0xe21c0101, 0xe11d0101,
+				       0xe01e0101, 0x861f0101, 0x85200101,
+				       0x84210101, 0x83220101, 0x82230101,
+				       0x81240101, 0x80250101, 0x44260101,
+				       0x43270101, 0x42280101, 0xffffffff};
 
 	u8 i;
 
@@ -884,122 +1013,51 @@ void halbtc8723d2ant_adjust_wl_rx_gain(IN struct btc_coexist *btcoexist,
 			return;
 	}
 
-		if (agc_table_en) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BB Agc Table On!\n");
-			BTC_TRACE(trace_buf);
+	if (agc_table_en) {
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			    "[BTCoex], BB Agc Table On!\n");
+		BTC_TRACE(trace_buf);
 
-			for (i = 0; i <= 100; i++) {
-				if (rx_gain_value_enable[i] == 0xffffffff)
-					break;
+		for (i = 0; i < ARRAY_SIZE(rx_gain_value_enable); i++) {
+			if (rx_gain_value_enable[i] == 0xffffffff)
+				break;
 
-				btcoexist->btc_write_4byte(btcoexist,
-					0xc78, rx_gain_value_enable[i]);
-			}
+			btcoexist->btc_write_4byte(btcoexist,
+				0xc78, rx_gain_value_enable[i]);
+		}
 
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BB Agc Table Off!\n");
-			BTC_TRACE(trace_buf);
+	} else {
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			    "[BTCoex], BB Agc Table Off!\n");
+		BTC_TRACE(trace_buf);
 
-			for (i = 0; i <= 100; i++) {
-				if (rx_gain_value_disable[i] == 0xffffffff)
-					break;
+		for (i = 0; i < ARRAY_SIZE(rx_gain_value_disable); i++) {
+			if (rx_gain_value_disable[i] == 0xffffffff)
+				break;
 
-				btcoexist->btc_write_4byte(btcoexist,
-					0xc78, rx_gain_value_disable[i]);
-			}
+			btcoexist->btc_write_4byte(btcoexist,
+				0xc78, rx_gain_value_disable[i]);
 		}
-
+	}
 
 	coex_dm->pre_agc_table_en = coex_dm->cur_agc_table_en;
 }
 
-
+static
 void halbtc8723d2ant_adjust_bt_rx_gain(IN struct btc_coexist *btcoexist,
 			       IN boolean force_exec, IN boolean rx_gain_en)
 {
+	u8 lna_lvl = 1;
+
+	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL,
+			   &lna_lvl);
 
 	/* use scoreboard[4] to notify BT Rx gain table change   */
 	halbtc8723d2ant_post_state_to_bt(btcoexist,
 		BT_8723D_2ANT_SCOREBOARD_RXGAIN, rx_gain_en);
 }
 
-
-void halbtc8723d2ant_set_fw_low_penalty_ra(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-#if 1
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf7;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xf8;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xf9;	/* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-#endif
-}
-
-void halbtc8723d2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-#if 1
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-
-	halbtc8723d2ant_set_fw_low_penalty_ra(btcoexist,
-							  coex_dm->cur_low_penalty_ra);
-
-#if 0
-	if (low_penalty_ra)
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 15);
-	else
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
-#endif
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-
-#endif
-}
-
-void halbtc8723d2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8723d2ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8723d2ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
+static
 boolean halbtc8723d2ant_is_wifibt_status_changed(IN struct btc_coexist
 		*btcoexist)
 {
@@ -1102,8 +1160,8 @@ boolean halbtc8723d2ant_is_wifibt_status_changed(IN struct btc_coexist
 			return TRUE;
 		}
 
-		if (pre_bt_setup_link != coex_sta->is_setupLink) {
-			pre_bt_setup_link = coex_sta->is_setupLink;
+		if (pre_bt_setup_link != coex_sta->is_setup_link) {
+			pre_bt_setup_link = coex_sta->is_setup_link;
 			return TRUE;
 		}
 	}
@@ -1111,36 +1169,20 @@ boolean halbtc8723d2ant_is_wifibt_status_changed(IN struct btc_coexist
 	return FALSE;
 }
 
+static
 void halbtc8723d2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
 {
 	static u32		bt_disable_cnt = 0;
 	boolean			bt_active = TRUE, bt_disabled = FALSE;
 	u16			u16tmp;
 
-	/* This function check if bt is disabled */
-#if 0
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = FALSE;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = FALSE;
-
-
-#else
-
-	/* Read BT on/off status from scoreboard[1], enable this only if BT patch support this feature */
-	halbtc8723d2ant_read_score_board(btcoexist,	&u16tmp);
-
+	/* This function check if bt is disabled
+	 * Read BT on/off status from scoreboard[1],
+	 * enable this only if BT patch support this feature
+	 */
+	halbtc8723d2ant_read_score_board(btcoexist, &u16tmp);
 	bt_active = u16tmp & BIT(1);
 
-
-#endif
-
 	if (bt_active) {
 		bt_disable_cnt = 0;
 		bt_disabled = FALSE;
@@ -1158,11 +1200,6 @@ void halbtc8723d2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
 				   &bt_disabled);
 	}
 
-	if (bt_disabled)
-		halbtc8723d2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-	else
-		halbtc8723d2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
-
 	if (coex_sta->bt_disabled != bt_disabled) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			    "[BTCoex], BT is from %s to %s!!\n",
@@ -1174,8 +1211,7 @@ void halbtc8723d2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
 
 }
 
-
-
+static
 void halbtc8723d2ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
 					boolean isenable)
 {
@@ -1215,6 +1251,7 @@ void halbtc8723d2ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
 #endif
 }
 
+static
 u32 halbtc8723d2ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
 		IN u16 reg_addr)
 {
@@ -1223,7 +1260,7 @@ u32 halbtc8723d2ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
 	/* wait for ready bit before access 0x7c0/0x7c4 */
 	while (1) {
 		if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-			delay_ms(50);
+			delay_ms(10);
 			delay_count++;
 			if (delay_count >= 10) {
 				delay_count = 0;
@@ -1240,6 +1277,7 @@ u32 halbtc8723d2ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
 
 }
 
+static
 void halbtc8723d2ant_ltecoex_indirect_write_reg(IN struct btc_coexist
 		*btcoexist,
 		IN u16 reg_addr, IN u32 bit_mask, IN u32 reg_value)
@@ -1253,7 +1291,7 @@ void halbtc8723d2ant_ltecoex_indirect_write_reg(IN struct btc_coexist
 		/* wait for ready bit before access 0x7c0/0x7c4 */
 		while (1) {
 			if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-				delay_ms(50);
+				delay_ms(10);
 				delay_count++;
 				if (delay_count >= 10) {
 					delay_count = 0;
@@ -1284,7 +1322,7 @@ void halbtc8723d2ant_ltecoex_indirect_write_reg(IN struct btc_coexist
 		/* wait for ready bit before access 0x7c0/0x7c4	*/
 		while (1) {
 			if ((btcoexist->btc_read_1byte(btcoexist, 0x7c3)&BIT(5)) == 0) {
-				delay_ms(50);
+				delay_ms(10);
 				delay_count++;
 				if (delay_count >= 10) {
 					delay_count = 0;
@@ -1304,6 +1342,7 @@ void halbtc8723d2ant_ltecoex_indirect_write_reg(IN struct btc_coexist
 
 }
 
+static
 void halbtc8723d2ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
 				    IN boolean enable)
 {
@@ -1315,8 +1354,9 @@ void halbtc8723d2ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
 
 }
 
-void halbtc8723d2ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_control)
+static
+void halbtc8723d2ant_coex_ctrl_owner(IN struct btc_coexist *btcoexist,
+				     IN boolean wifi_control)
 {
 	u8 val;
 
@@ -1326,6 +1366,7 @@ void halbtc8723d2ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
 
 }
 
+static
 void halbtc8723d2ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
 			IN u8 control_block, IN boolean sw_control, IN u8 state)
 {
@@ -1358,7 +1399,7 @@ void halbtc8723d2ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
 				0x38, 0xffffffff, val);
 }
 
-
+static
 void halbtc8723d2ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
 			IN u8 control_block, IN boolean sw_control, IN u8 state)
 {
@@ -1391,6 +1432,7 @@ void halbtc8723d2ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
 				0x38, 0xffffffff, val);
 }
 
+static
 void halbtc8723d2ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
 		IN u8 table_type, IN u16 table_content)
 {
@@ -1412,106 +1454,33 @@ void halbtc8723d2ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
 
 }
 
-
-void halbtc8723d2ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u8 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8723D_2ANT_LBTT_WL_BREAK_LTE:
-		reg_addr = 0xa8;
-		break;
-	case BT_8723D_2ANT_LBTT_BT_BREAK_LTE:
-		reg_addr = 0xac;
-		break;
-	case BT_8723D_2ANT_LBTT_LTE_BREAK_WL:
-		reg_addr = 0xb0;
-		break;
-	case BT_8723D_2ANT_LBTT_LTE_BREAK_BT:
-		reg_addr = 0xb4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8723d2ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xff, table_content); /* 0xa8[15:0] or 0xb4[15:0] */
-
-
-}
-
-void halbtc8723d2ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
+static
+void halbtc8723d2ant_coex_table(IN struct btc_coexist *btcoexist,
+				IN boolean force_exec, IN u32 val0x6c0,
+				IN u32 val0x6c4, IN u32 val0x6c8,
+				IN u8 val0x6cc)
 {
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
-
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
 	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
+		if (val0x6c0 == coex_dm->cur_val0x6c0 &&
+		    val0x6c4 == coex_dm->cur_val0x6c4 &&
+		    val0x6c8 == coex_dm->cur_val0x6c8 &&
+		    val0x6cc == coex_dm->cur_val0x6cc)
 			return;
 	}
 
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-void halbtc8723d2ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
 	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
 	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
 	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
 	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
 
-void halbtc8723d2ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
 	coex_dm->cur_val0x6c0 = val0x6c0;
 	coex_dm->cur_val0x6c4 = val0x6c4;
 	coex_dm->cur_val0x6c8 = val0x6c8;
 	coex_dm->cur_val0x6cc = val0x6cc;
 
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8723d2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
 }
 
+static
 void halbtc8723d2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
 		IN boolean force_exec, IN u8 type)
 {
@@ -1575,6 +1544,7 @@ void halbtc8723d2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
 	}
 }
 
+static
 void halbtc8723d2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 		IN boolean enable)
 {
@@ -1587,6 +1557,7 @@ void halbtc8723d2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
 }
 
+static
 void halbtc8723d2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 				     IN boolean force_exec, IN boolean enable)
 {
@@ -1602,6 +1573,7 @@ void halbtc8723d2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
 }
 
+static
 void halbtc8723d2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
 				  IN u8 lps_val, IN u8 rpwm_val)
 {
@@ -1612,6 +1584,7 @@ void halbtc8723d2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
 	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
 }
 
+static
 void halbtc8723d2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
 		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
 {
@@ -1629,6 +1602,7 @@ void halbtc8723d2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
 	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
 }
 
+static
 void halbtc8723d2ant_ps_tdma_check_for_power_save_state(
 	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
 {
@@ -1656,6 +1630,7 @@ void halbtc8723d2ant_ps_tdma_check_for_power_save_state(
 	}
 }
 
+static
 void halbtc8723d2ant_power_save_state(IN struct btc_coexist *btcoexist,
 			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
 {
@@ -1699,8 +1674,7 @@ void halbtc8723d2ant_power_save_state(IN struct btc_coexist *btcoexist,
 	}
 }
 
-
-
+static
 void halbtc8723d2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
 	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
 {
@@ -1770,48 +1744,62 @@ void halbtc8723d2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
 		btcoexist->btc_set(btcoexist, BTC_SET_ACT_POST_NORMAL_LPS, NULL);
 }
 
+static
 void halbtc8723d2ant_ps_tdma(IN struct btc_coexist *btcoexist,
 		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
 {
 
-	static u8			psTdmaByte4Modify = 0x0, pre_psTdmaByte4Modify = 0x0;
+	static u8 tdma_byte4_modify, pre_tdma_byte4_modify;
 	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
+	btcoexist->btc_set_atomic(btcoexist, &coex_dm->setting_tdma, TRUE);
 
 	/* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
 	if ((bt_link_info->slave_role) && (bt_link_info->a2dp_exist))
-		psTdmaByte4Modify = 0x1;
+		tdma_byte4_modify = 0x1;
 	else
-		psTdmaByte4Modify = 0x0;
-
-	if (pre_psTdmaByte4Modify != psTdmaByte4Modify) {
+		tdma_byte4_modify = 0x0;
 
+	if (pre_tdma_byte4_modify != tdma_byte4_modify) {
 		force_exec = TRUE;
-		pre_psTdmaByte4Modify = psTdmaByte4Modify;
+		pre_tdma_byte4_modify = tdma_byte4_modify;
 	}
 
 	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
+		if (turn_on == coex_dm->cur_ps_tdma_on &&
+		    type == coex_dm->cur_ps_tdma) {
+			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+				    "[BTCoex], Skip TDMA because no change TDMA(%s, %d)\n",
+				    (coex_dm->cur_ps_tdma_on ? "on" : "off"),
+				    coex_dm->cur_ps_tdma);
+			BTC_TRACE(trace_buf);
+
+			btcoexist->btc_set_atomic(btcoexist,
+						  &coex_dm->setting_tdma,
+						  FALSE);
 			return;
+		}
 	}
 
-	if (coex_dm->cur_ps_tdma_on) {
+	if (turn_on) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
+			    "[BTCoex], ********** TDMA(on, %d)\n", type);
 		BTC_TRACE(trace_buf);
 
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
+		halbtc8723d2ant_post_state_to_bt(btcoexist,
+						 BT_8723D_2ANT_SCOREBOARD_TDMA,
+						 TRUE);
+
+		/* enable TBTT interrupt */
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8, 0x1);
 	} else {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
+			    "[BTCoex], ********** TDMA(off, %d)\n", type);
 		BTC_TRACE(trace_buf);
+
+		halbtc8723d2ant_post_state_to_bt(btcoexist,
+						 BT_8723D_2ANT_SCOREBOARD_TDMA,
+						 FALSE);
 	}
 
 
@@ -1819,183 +1807,179 @@ void halbtc8723d2ant_ps_tdma(IN struct btc_coexist *btcoexist,
 		switch (type) {
 		case 1:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x10, 0x03, 0x91,
-								0x54 | psTdmaByte4Modify);
+						      0x10, 0x03, 0x91, 0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 2:
 		default:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x35, 0x03, 0x11,
-								0x11 | psTdmaByte4Modify);
+						      0x35, 0x03, 0x11, 0x11 |
+						      tdma_byte4_modify);
 			break;
 		case 3:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x3a, 0x3, 0x91,
-								0x10 | psTdmaByte4Modify);
+						      0x3a, 0x3, 0x91, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 4:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x21, 0x3, 0x91,
-								0x10 | psTdmaByte4Modify);
+						      0x21, 0x3, 0x91, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 5:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x25, 0x3, 0x91,
-								0x10 | psTdmaByte4Modify);
+						      0x25, 0x3, 0x91, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 6:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x10, 0x3, 0x91,
-								0x10 | psTdmaByte4Modify);
+						      0x10, 0x3, 0x91, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 7:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x20, 0x3, 0x91,
-								0x10 | psTdmaByte4Modify);
+						      0x20, 0x3, 0x91, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 8:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x15, 0x03, 0x11,
-								0x11);
+						      0x15, 0x03, 0x11, 0x11);
 			break;
 		case 10:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x30, 0x03, 0x11,
-								0x10);
+						      0x30, 0x03, 0x11, 0x10);
 			break;
 		case 11:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x35, 0x03, 0x11,
-								0x10 | psTdmaByte4Modify);
+						      0x35, 0x03, 0x11, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 12:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x35, 0x03, 0x11, 0x11);
+						      0x35, 0x03, 0x11, 0x11);
 			break;
 		case 13:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x1c, 0x03, 0x11,
-								0x10 | psTdmaByte4Modify);
+						      0x1c, 0x03, 0x11, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 14:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x20, 0x03, 0x11,
-								0x11);
+						      0x20, 0x03, 0x11, 0x11);
 			break;
 		case 15:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x10, 0x03, 0x11,
-								0x14);
+						      0x10, 0x03, 0x11, 0x14);
 			break;
 		case 16:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x10, 0x03, 0x11,
-								0x15);
+						      0x10, 0x03, 0x11, 0x15);
 			break;
 		case 21:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x30, 0x03, 0x11,
-								0x10);
+						      0x30, 0x03, 0x11, 0x10);
 			break;
 		case 22:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x25, 0x03, 0x11,
-								0x10);
+						      0x25, 0x03, 0x11, 0x10);
 			break;
 		case 23:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x10, 0x03, 0x11,
-								0x10);
+						      0x10, 0x03, 0x11, 0x10);
 			break;
 		case 51:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x10, 0x03, 0x91,
-								0x10 | psTdmaByte4Modify);
+						      0x10, 0x03, 0x91, 0x10 |
+						      tdma_byte4_modify);
 			break;
 		case 101:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x10, 0x03, 0x10,
-								0x54 | psTdmaByte4Modify);
+						      0x10, 0x03, 0x10, 0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 102:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x35, 0x03, 0x11,
-								0x11 | psTdmaByte4Modify);
+						      0x35, 0x03, 0x11, 0x11 |
+						      tdma_byte4_modify);
 			break;
 		case 103:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x30, 0x3, 0x10,
-								0x50 | psTdmaByte4Modify);
+						      0x30, 0x3, 0x10, 0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 104:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x21, 0x3, 0x10,
-								0x50 | psTdmaByte4Modify);
+						      0x21, 0x3, 0x10, 0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 105:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x35, 0x3, 0x10,
-								0x50 | psTdmaByte4Modify);
+						      0x35, 0x3, 0x10, 0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 106:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x10, 0x3, 0x10,
-								0x50 | psTdmaByte4Modify);
+						      0x10, 0x3, 0x10, 0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 107:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x10, 0x7, 0x10,
-								0x54);
+						      0x10, 0x7, 0x10, 0x54);
 			break;
 		case 108:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x30, 0x3, 0x10,
-								0x50 | psTdmaByte4Modify);
+						      0x30, 0x3, 0x10, 0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 109:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x10, 0x03, 0x10,
-								0x54 | psTdmaByte4Modify);
+						      0x10, 0x03, 0x10, 0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 110:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-								0x30, 0x03, 0x10,
-								0x50 | psTdmaByte4Modify);
+						      0x30, 0x03, 0x10, 0x50 |
+						      tdma_byte4_modify);
 			break;
 		case 111:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x25, 0x03, 0x11,
-								0x11);
+						      0x25, 0x03, 0x11, 0x11);
 			break;
 		case 112:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x4a, 0x3, 0x10,
-						      0x50);
+						      0x4a, 0x3, 0x10, 0x50);
 			break;
 		case 113:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-								0x48, 0x03, 0x11,
-								0x10);
+						      0x48, 0x03, 0x11, 0x10);
 			break;
 		case 116:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x08, 0x03, 0x10,
-						      0x54 | psTdmaByte4Modify);
+						      0x08, 0x03, 0x10, 0x54 |
+						      tdma_byte4_modify);
 			break;
 		case 117:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x08, 0x03, 0x10,
-						      0x14 | psTdmaByte4Modify);
+						      0x08, 0x03, 0x10, 0x14 |
+						      tdma_byte4_modify);
 			break;
 		case 119:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x11,
-						      0x14 | psTdmaByte4Modify);
+						      0x10, 0x03, 0x11, 0x14 |
+						      tdma_byte4_modify);
+			break;
+		case 120:
+			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
+						      0x10, 0x03, 0x10, 0x55);
+			break;
+		case 121:
+			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x61,
+						      0x10, 0x03, 0x11, 0x15);
 			break;
 		case 151:
 			halbtc8723d2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x03, 0x10,
-						      0x50 | psTdmaByte4Modify);
+						      0x10, 0x03, 0x10, 0x50 |
+						      tdma_byte4_modify);
 			break;
 		}
 	} else {
@@ -2016,11 +2000,13 @@ void halbtc8723d2ant_ps_tdma(IN struct btc_coexist *btcoexist,
 		}
 	}
 
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
+	coex_dm->cur_ps_tdma_on = turn_on;
+	coex_dm->cur_ps_tdma = type;
 
+	btcoexist->btc_set_atomic(btcoexist, &coex_dm->setting_tdma, FALSE);
 }
 
+static
 void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 				  IN u8 ant_pos_type, IN boolean force_exec,
 				  IN u8 phase)
@@ -2036,8 +2022,9 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 	u16				u16tmp0 = 0,  u16tmp1 = 0;
 
 
-	u32tmp1 = halbtc8723d2ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
+#if BT_8723D_2ANT_COEX_DBG
+
+	u32tmp1 = halbtc8723d2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
 
      /* To avoid indirect access fail   */
 	if (((u32tmp1 & 0xf000) >> 12) != ((u32tmp1 & 0x0f00) >> 8)) {
@@ -2045,8 +2032,6 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		coex_sta->gnt_error_cnt++;
 	}
 
-
-#if BT_8723D_2ANT_COEX_DBG
 	u32tmp2 = halbtc8723d2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
 	u16tmp0 = btcoexist->btc_read_2byte(btcoexist, 0xaa);
 	u16tmp1 = btcoexist->btc_read_2byte(btcoexist, 0x948);
@@ -2054,12 +2039,12 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 	u8tmp0 =  btcoexist->btc_read_1byte(btcoexist, 0x67);
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(Before Set Ant Pat)\n",
+		    "[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(Before Set Ant Pat)\n",
 		    u8tmp0, u16tmp1, u8tmp1);
 	BTC_TRACE(trace_buf);
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********0x38= 0x%x, 0x54= 0x%x, 0xaa = 0x%x (Before Set Ant Path)\n",
+		    "[BTCoex], **********0x38= 0x%x, 0x54= 0x%x, 0xaa = 0x%x (Before Set Ant Path)\n",
 		    u32tmp1, u32tmp2, u16tmp0);
 	BTC_TRACE(trace_buf);
 #endif
@@ -2072,7 +2057,7 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		if (coex_dm->cur_ant_pos_type == coex_dm->pre_ant_pos_type) {
 
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** Skip Antenna Path Setup because no change!!**********\n");
+				    "[BTCoex], Skip Antenna Path Setup because no change!!\n");
 			BTC_TRACE(trace_buf);
 			return;
 		}
@@ -2083,23 +2068,11 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 	switch (phase) {
 	case BT_8723D_2ANT_PHASE_COEX_POWERON:
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-						   0x80, 0x0);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x0);
 
 		/* set Path control owner to WL at initial step */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_2ANT_PCO_BTSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8723d2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8723D_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8723D_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8723D_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW low */
-		halbtc8723d2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8723D_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8723D_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8723D_2ANT_SIG_STA_SET_TO_HIGH);
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_BTSIDE);
 
 		if (BTC_ANT_PATH_AUTO == ant_pos_type)
 			ant_pos_type = BTC_ANT_PATH_WIFI;
@@ -2108,57 +2081,56 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 
 		break;
 	case BT_8723D_2ANT_PHASE_COEX_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
+		/* Disable LTE Coex Function in WiFi side
+		 * (this should be on if LTE coex is required)
+		 */
 		halbtc8723d2ant_ltecoex_enable(btcoexist, 0x0);
 
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_WL_LTE always = 1
+		 * (this should be config if LTE coex is required)
+		 */
 		halbtc8723d2ant_ltecoex_set_coex_table(
 			btcoexist,
 			BT_8723D_2ANT_CTT_WL_VS_LTE,
 			0xffff);
 
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_BT_LTE always = 1
+		 * (this should be config if LTE coex is required)
+		 */
 		halbtc8723d2ant_ltecoex_set_coex_table(
 			btcoexist,
 			BT_8723D_2ANT_CTT_BT_VS_LTE,
 			0xffff);
 
-		/* Wait If BT IQK running, because Path control owner is at BT during BT IQK (setup by WiFi firmware) */
+		/* Wait If BT IQK running, because Path control owner is
+		 * at BT during BT IQK (setup by WiFi firmware)
+		 */
 		while (cnt_bt_cal_chk <= 20) {
-			u8tmp0 = btcoexist->btc_read_1byte(
-					 btcoexist,
-					 0x49d);
+			u8tmp0 = btcoexist->btc_read_1byte(btcoexist, 0x49d);
 			cnt_bt_cal_chk++;
 			if (u8tmp0 & BIT(0)) {
-				BTC_SPRINTF(
-					trace_buf,
-					BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n",
-					cnt_bt_cal_chk);
-				BTC_TRACE(
-					trace_buf);
+				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+					    "[BTCoex],  BT is calibrating (wait cnt=%d)\n",
+					    cnt_bt_cal_chk);
+				BTC_TRACE(trace_buf);
 				delay_ms(50);
 			} else {
-				BTC_SPRINTF(
-					trace_buf,
-					BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** BT is NOT calibrating (wait cnt=%d)**********\n",
-					cnt_bt_cal_chk);
-				BTC_TRACE(
-					trace_buf);
+				BTC_SPRINTF(trace_buf,
+					    BT_TMP_BUF_SIZE,
+					    "[BTCoex], BT is NOT calibrating (wait cnt=%d)\n",
+					    cnt_bt_cal_chk);
+				BTC_TRACE(trace_buf);
 				break;
 			}
 		}
 
 
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist,
-						   0x67, 0x80, 0x1);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);
 
 		/* set Path control owner to WL at initial step */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8723D_2ANT_PCO_WLSIDE);
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_WLSIDE);
 
 		/* set GNT_BT to SW high */
 		halbtc8723d2ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2176,25 +2148,29 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
 			if (board_info->btdm_ant_pos ==
 			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
+				ant_pos_type = BTC_ANT_WIFI_AT_MAIN;
 			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
+				ant_pos_type = BTC_ANT_WIFI_AT_AUX;
 		}
 
 		break;
 	case BT_8723D_2ANT_PHASE_WLANONLY_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
+		/* Disable LTE Coex Function in WiFi side
+		 * (this should be on if LTE coex is required)
+		 */
 		halbtc8723d2ant_ltecoex_enable(btcoexist, 0x0);
 
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_WL_LTE always = 1
+		 * (this should be config if LTE coex is required)
+		 */
 		halbtc8723d2ant_ltecoex_set_coex_table(
 			btcoexist,
 			BT_8723D_2ANT_CTT_WL_VS_LTE,
 			0xffff);
 
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
+		/* GNT_BT_LTE always = 1
+		 *(this should be config if LTE coex is required)
+		 */
 		halbtc8723d2ant_ltecoex_set_coex_table(
 			btcoexist,
 			BT_8723D_2ANT_CTT_BT_VS_LTE,
@@ -2205,9 +2181,8 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 						   0x67, 0x80, 0x1);
 
 		/* set Path control owner to WL at initial step */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8723D_2ANT_PCO_WLSIDE);
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_WLSIDE);
 
 		/* set GNT_BT to SW Low */
 		halbtc8723d2ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2225,11 +2200,9 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
 			if (board_info->btdm_ant_pos ==
 			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
+				ant_pos_type = BTC_ANT_WIFI_AT_MAIN;
 			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
+				ant_pos_type = BTC_ANT_WIFI_AT_AUX;
 		}
 
 		break;
@@ -2238,15 +2211,11 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		halbtc8723d2ant_ltecoex_enable(btcoexist, 0x0);
 
 		/* Set Path control to BT */
-		btcoexist->btc_write_1byte_bitmask(btcoexist,
-						   0x67, 0x80, 0x0);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x0);
 
 		/* set Path control owner to BT */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8723D_2ANT_PCO_BTSIDE);
-
-		/*halbtc8723d2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, TRUE);*/
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_BTSIDE);
 
 		coex_sta->run_time_state = FALSE;
 		break;
@@ -2263,32 +2232,30 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 					 0x49d);
 
 			cnt_bt_cal_chk++;
-			if ((u8tmp0 & BIT(0)) ||
-			    (u8tmp1 & BIT(0))) {
+			if ((u8tmp0 & BIT(0)) || (u8tmp1 & BIT(0))) {
 				BTC_SPRINTF(trace_buf,
 					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### WL or BT is IQK (wait cnt=%d)\n",
+					    "[BTCoex], ########### WL or BT is IQK (wait cnt=%d)\n",
 					    cnt_bt_cal_chk);
 				BTC_TRACE(trace_buf);
 				delay_ms(50);
 			} else {
 				BTC_SPRINTF(trace_buf,
 					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** WL and BT is NOT IQK (wait cnt=%d)\n",
+					    "[BTCoex], ********** WL and BT is NOT IQK (wait cnt=%d)\n",
 					    cnt_bt_cal_chk);
 				BTC_TRACE(trace_buf);
 				break;
 			}
 		}
 
-		/* Set Path control to WL */
-		/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);*/
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8723D_2ANT_PCO_WLSIDE);
-
+		/* Set Path control to WL
+		 * btcoexist->btc_write_1byte_bitmask(
+		 * btcoexist, 0x67, 0x80, 0x1);
+		 * set Path control owner to WL at runtime step
+		 */
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_WLSIDE);
 
 		halbtc8723d2ant_ltecoex_set_gnt_bt(btcoexist,
 					   BT_8723D_2ANT_GNT_BLOCK_RFC_BB,
@@ -2306,20 +2273,17 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
 			if (board_info->btdm_ant_pos ==
 			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
+				ant_pos_type = BTC_ANT_WIFI_AT_MAIN;
 			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
+				ant_pos_type = BTC_ANT_WIFI_AT_AUX;
 		}
 
 		break;
 	case BT_8723D_2ANT_PHASE_2G_FREERUN:
 
 		/* set Path control owner to WL at runtime step */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8723D_2ANT_PCO_WLSIDE);
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_WLSIDE);
 
 		/* set GNT_BT to SW Hi */
 		halbtc8723d2ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2340,13 +2304,11 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		halbtc8723d2ant_ltecoex_enable(btcoexist, 0x0);
 
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist,
-						   0x67, 0x80, 0x1);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);
 
 		/* set Path control owner to WL */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8723D_2ANT_PCO_WLSIDE);
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_WLSIDE);
 
 		/* set GNT_BT to SW Hi */
 		halbtc8723d2ant_ltecoex_set_gnt_bt(btcoexist,
@@ -2365,26 +2327,25 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
 			if (board_info->btdm_ant_pos ==
 			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
+				ant_pos_type = BTC_ANT_WIFI_AT_MAIN;
 			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
+				ant_pos_type = BTC_ANT_WIFI_AT_AUX;
 		}
 
 		break;
 	case BT_8723D_2ANT_PHASE_ANTENNA_DET:
 
 		/* Set Path control to WL */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67,
-						   0x80, 0x1);
+		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x80, 0x1);
 
 		/* set Path control owner to WL */
-		halbtc8723d2ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8723D_2ANT_PCO_WLSIDE);
+		halbtc8723d2ant_coex_ctrl_owner(btcoexist,
+						BT_8723D_2ANT_PCO_WLSIDE);
 
-		/* Set Antenna Path,  both GNT_WL/GNT_BT = 1, and control by SW */
-		/* set GNT_BT to SW high */
+		/* Set Antenna Path,  both GNT_WL/GNT_BT = 1,
+		 *and control by SW
+		 * set GNT_BT to SW high
+		 */
 		halbtc8723d2ant_ltecoex_set_gnt_bt(btcoexist,
 					   BT_8723D_2ANT_GNT_BLOCK_RFC_BB,
 					   BT_8723D_2ANT_GNT_TYPE_CTRL_BY_SW,
@@ -2406,21 +2367,17 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 
 	is_hw_ant_div_on = board_info->ant_div_cfg;
 
-	if ((is_hw_ant_div_on) && (phase != BT_8723D_2ANT_PHASE_ANTENNA_DET))
+	if (is_hw_ant_div_on && phase != BT_8723D_2ANT_PHASE_ANTENNA_DET)
 		btcoexist->btc_write_2byte(btcoexist, 0x948, 0x140);
 	else if ((is_hw_ant_div_on == FALSE) &&
 		 (phase != BT_8723D_2ANT_PHASE_WLAN_OFF)) {
 
 		switch (ant_pos_type) {
 		case BTC_ANT_WIFI_AT_MAIN:
-
-			btcoexist->btc_write_2byte(btcoexist,
-						   0x948, 0x0);
+			btcoexist->btc_write_2byte(btcoexist, 0x948, 0x0);
 			break;
 		case BTC_ANT_WIFI_AT_AUX:
-
-			btcoexist->btc_write_2byte(btcoexist,
-						   0x948, 0x280);
+			btcoexist->btc_write_2byte(btcoexist, 0x948, 0x280);
 			break;
 		}
 	}
@@ -2435,18 +2392,19 @@ void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,
 	u8tmp0 =  btcoexist->btc_read_1byte(btcoexist, 0x67);
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(After Set Ant Pat)\n",
+		    "[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(After Set Ant Pat)\n",
 		    u8tmp0, u16tmp1, u8tmp1);
 	BTC_TRACE(trace_buf);
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********0x38= 0x%x, 0x54= 0x%x, 0xaa= 0x%x (After Set Ant Path)\n",
+		    "[BTCoex], **********0x38= 0x%x, 0x54= 0x%x, 0xaa= 0x%x (After Set Ant Path)\n",
 		    u32tmp1, u32tmp2, u16tmp0);
 	BTC_TRACE(trace_buf);
 #endif
 
 }
 
+static
 u8 halbtc8723d2ant_action_algorithm(IN struct btc_coexist *btcoexist)
 {
 	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
@@ -2482,7 +2440,7 @@ u8 halbtc8723d2ant_action_algorithm(IN struct btc_coexist *btcoexist)
 		}
 	} else if ((bt_link_info->a2dp_exist) && (coex_sta->is_bt_a2dp_sink)) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], A2DP Sink\n");
+			    "[BTCoex], A2DP Sink\n");
 		BTC_TRACE(trace_buf);
 		algorithm = BT_8723D_2ANT_COEX_ALGO_A2DPSINK;
 	} else if (num_of_diff_profile == 1) {
@@ -2597,13 +2555,13 @@ u8 halbtc8723d2ant_action_algorithm(IN struct btc_coexist *btcoexist)
 				   bt_link_info->pan_exist) {
 				if (bt_hs_on) {
 					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(HS)\n");
+						    "[BTCoex], SCO + HID + PAN(HS)\n");
 					BTC_TRACE(trace_buf);
 					algorithm =
 						BT_8723D_2ANT_COEX_ALGO_PANEDR_HID;
 				} else {
 					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(EDR)\n");
+						    "[BTCoex], SCO + HID + PAN(EDR)\n");
 					BTC_TRACE(trace_buf);
 					algorithm =
 						BT_8723D_2ANT_COEX_ALGO_PANEDR_HID;
@@ -2668,8 +2626,7 @@ u8 halbtc8723d2ant_action_algorithm(IN struct btc_coexist *btcoexist)
 	return algorithm;
 }
 
-
-
+static
 void halbtc8723d2ant_action_coex_all_off(IN struct btc_coexist *btcoexist)
 {
 
@@ -2684,6 +2641,7 @@ void halbtc8723d2ant_action_coex_all_off(IN struct btc_coexist *btcoexist)
 	halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
 }
 
+static
 void halbtc8723d2ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)
 {
 	halbtc8723d2ant_adjust_wl_tx_power(btcoexist, NORMAL_EXEC, 0xb2);
@@ -2696,6 +2654,7 @@ void halbtc8723d2ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)
 	halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
 }
 
+static
 void halbtc8723d2ant_action_freerun(IN struct btc_coexist *btcoexist)
 {
 	boolean wifi_busy = FALSE;
@@ -2722,8 +2681,7 @@ void halbtc8723d2ant_action_freerun(IN struct btc_coexist *btcoexist)
 	halbtc8723d2ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
 }
 
-
-
+static
 void halbtc8723d2ant_action_bt_hs(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -2809,7 +2767,7 @@ void halbtc8723d2ant_action_bt_hs(IN struct btc_coexist *btcoexist)
 
 }
 
-
+static
 void halbtc8723d2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
 {
 
@@ -2881,24 +2839,27 @@ void halbtc8723d2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
 
 }
 
-
+static
 void halbtc8723d2ant_action_bt_relink(IN struct btc_coexist *btcoexist)
 {
 	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
 
-	if (((!coex_sta->is_bt_multi_link) && (!bt_link_info->pan_exist)) ||
-		((bt_link_info->a2dp_exist) && (bt_link_info->hid_exist))) {
+	if ((!coex_sta->is_bt_multi_link && !bt_link_info->pan_exist) ||
+	    (bt_link_info->a2dp_exist && bt_link_info->hid_exist)) {
 
 		halbtc8723d2ant_adjust_wl_tx_power(btcoexist, FORCE_EXEC, 0xb2);
 		halbtc8723d2ant_adjust_bt_tx_power(btcoexist, NORMAL_EXEC, 0);
-		halbtc8723d2ant_adjust_wl_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-		halbtc8723d2ant_adjust_bt_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
+		halbtc8723d2ant_adjust_wl_rx_gain(btcoexist,
+						  NORMAL_EXEC, FALSE);
+		halbtc8723d2ant_adjust_bt_rx_gain(btcoexist,
+						  NORMAL_EXEC, FALSE);
 
 		halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
 		halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
 	}
 }
 
+static
 void halbtc8723d2ant_action_bt_idle(IN struct btc_coexist *btcoexist)
 {
 	boolean wifi_busy = FALSE;
@@ -2939,6 +2900,7 @@ void halbtc8723d2ant_action_bt_idle(IN struct btc_coexist *btcoexist)
 
 
 /* SCO only or SCO+PAN(HS) */
+static
 void halbtc8723d2ant_action_sco(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -2995,7 +2957,7 @@ void halbtc8723d2ant_action_sco(IN struct btc_coexist *btcoexist)
 
 		coex_dm->is_switch_to_1dot5_ant = FALSE;
 
-		if (coex_sta->is_eSCO_mode)
+		if (coex_sta->is_esco_mode)
 			halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
 		else  /* 2-Ant free run if eSCO mode */
 			halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
@@ -3005,7 +2967,7 @@ void halbtc8723d2ant_action_sco(IN struct btc_coexist *btcoexist)
 
 }
 
-
+static
 void halbtc8723d2ant_action_hid(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3082,6 +3044,7 @@ void halbtc8723d2ant_action_hid(IN struct btc_coexist *btcoexist)
 
 }
 
+static
 void halbtc8723d2ant_action_a2dpsink(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3164,12 +3127,13 @@ void halbtc8723d2ant_action_a2dpsink(IN struct btc_coexist *btcoexist)
 		coex_dm->is_switch_to_1dot5_ant = TRUE;
 
 		halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 105);
+		halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 104);
 	}
 
 }
 
 /* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
+static
 void halbtc8723d2ant_action_a2dp(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3231,32 +3195,48 @@ void halbtc8723d2ant_action_a2dp(IN struct btc_coexist *btcoexist)
 			80, 0);
 
 #if 1
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		BTC_RSSI_HIGH(bt_rssi_state)) {
-
+	if (BTC_RSSI_HIGH(wifi_rssi_state) && BTC_RSSI_HIGH(bt_rssi_state)) {
 		halbtc8723d2ant_action_freerun(btcoexist);
 	} else {
 
 		if (wifi_link_status & WIFI_P2P_GC_CONNECTED) {
-			halbtc8723d2ant_adjust_wl_tx_power(btcoexist, NORMAL_EXEC, 0xb2);
-			halbtc8723d2ant_adjust_bt_tx_power(btcoexist, NORMAL_EXEC, 15);
+			halbtc8723d2ant_adjust_wl_tx_power(btcoexist,
+							   NORMAL_EXEC, 0xb2);
+			halbtc8723d2ant_adjust_bt_tx_power(btcoexist,
+							   NORMAL_EXEC, 15);
 
 		} else {
-			halbtc8723d2ant_adjust_wl_tx_power(btcoexist, NORMAL_EXEC, 0x90);
-			halbtc8723d2ant_adjust_bt_tx_power(btcoexist, NORMAL_EXEC, 0x0);
+			halbtc8723d2ant_adjust_wl_tx_power(btcoexist,
+							   NORMAL_EXEC, 0x90);
+			halbtc8723d2ant_adjust_bt_tx_power(btcoexist,
+							   NORMAL_EXEC, 0x0);
 		}
 
-		halbtc8723d2ant_adjust_wl_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-		halbtc8723d2ant_adjust_bt_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
+		halbtc8723d2ant_adjust_wl_rx_gain(btcoexist,
+						  NORMAL_EXEC, FALSE);
+		halbtc8723d2ant_adjust_bt_rx_gain(btcoexist,
+						  NORMAL_EXEC, FALSE);
 
 		coex_dm->is_switch_to_1dot5_ant = TRUE;
 
 		halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
 
-		if (BTC_RSSI_HIGH(wifi_rssi_state3))
-			halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 119);
-		else
-			halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 101);
+		if (BTC_RSSI_HIGH(wifi_rssi_state3)) {
+			if (coex_sta->connect_ap_period_cnt > 0)
+				halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC,
+							TRUE, 121);
+			else
+				halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC,
+							TRUE, 119);
+		} else {
+			if (coex_sta->connect_ap_period_cnt > 0)
+				halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC,
+							TRUE, 120);
+			else
+				halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC,
+							TRUE, 101);
+		}
+
 	}
 
 #else
@@ -3306,7 +3286,7 @@ void halbtc8723d2ant_action_a2dp(IN struct btc_coexist *btcoexist)
 
 }
 
-
+static
 void halbtc8723d2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3414,8 +3394,8 @@ void halbtc8723d2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
 		coex_dm->is_switch_to_1dot5_ant = TRUE;
 
 		/* for Lenovo CPT_For_WiFi OPP test  */
-		if ((btcoexist->board_info.customerID == RT_CID_LENOVO_CHINA) &&
-			BTC_RSSI_HIGH(wifi_rssi_state3) && (wifi_busy)) {
+		if (btcoexist->board_info.customer_id == RT_CID_LENOVO_CHINA &&
+		    BTC_RSSI_HIGH(wifi_rssi_state3) && wifi_busy) {
 			halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
 
 			halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 112);
@@ -3434,6 +3414,7 @@ void halbtc8723d2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
 
 }
 
+static
 void halbtc8723d2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3566,7 +3547,7 @@ void halbtc8723d2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
 #endif
 }
 
-
+static
 void halbtc8723d2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3678,6 +3659,7 @@ void halbtc8723d2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
 
 
 /* PAN(EDR)+A2DP */
+static
 void halbtc8723d2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3779,8 +3761,8 @@ void halbtc8723d2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
 		coex_dm->is_switch_to_1dot5_ant = TRUE;
 
 		/* for Lenovo coex test case    */
-		if ((btcoexist->board_info.customerID == RT_CID_LENOVO_CHINA) &&
-			(coex_sta->scan_ap_num <= 10)) {
+		if (btcoexist->board_info.customer_id == RT_CID_LENOVO_CHINA &&
+		    coex_sta->scan_ap_num <= 10) {
 
 			halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
 
@@ -3806,7 +3788,7 @@ void halbtc8723d2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
 
 }
 
-
+static
 void halbtc8723d2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3890,6 +3872,7 @@ void halbtc8723d2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
 
 
 /* HID+A2DP+PAN(EDR) */
+static
 void halbtc8723d2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
 {
 	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
@@ -3977,12 +3960,19 @@ void halbtc8723d2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
 
 }
 
+static
 void halbtc8723d2ant_action_wifi_native_lps(IN struct btc_coexist *btcoexist)
 {
-	halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
+	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
+
+	if (bt_link_info->pan_exist)
+		halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
+	else
+		halbtc8723d2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
 	halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
 }
 
+static
 void halbtc8723d2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
 {
 	halbtc8723d2ant_adjust_wl_tx_power(btcoexist, NORMAL_EXEC, 0xb2);
@@ -3996,6 +3986,7 @@ void halbtc8723d2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
 	halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
 }
 
+static
 void halbtc8723d2ant_action_wifi_linkscan_process(IN struct btc_coexist *btcoexist)
 {
 	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
@@ -4015,6 +4006,7 @@ void halbtc8723d2ant_action_wifi_linkscan_process(IN struct btc_coexist *btcoexi
 		halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
 }
 
+static
 void halbtc8723d2ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
 {
 	halbtc8723d2ant_adjust_wl_tx_power(btcoexist, NORMAL_EXEC, 0xb2);
@@ -4028,6 +4020,7 @@ void halbtc8723d2ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
 	halbtc8723d2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
 }
 
+static
 void halbtc8723d2ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
 {
 	switch (coex_dm->cur_algorithm) {
@@ -4111,7 +4104,7 @@ void halbtc8723d2ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
 
 }
 
-
+static
 void halbtc8723d2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 {
 	u8	algorithm = 0;
@@ -4174,8 +4167,7 @@ void halbtc8723d2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 		return;
 	}
 
-	if ((coex_sta->under_lps) && (!coex_sta->force_lps_ctrl) &&
-		(!coex_sta->acl_busy)) {
+	if (coex_sta->under_lps && !coex_sta->force_lps_ctrl) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				"[BTCoex], RunCoexistMechanism(), wifi is under LPS !!!\n");
 		BTC_TRACE(trace_buf);
@@ -4207,9 +4199,7 @@ void halbtc8723d2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 		return;
 	}
 
-	if ((coex_sta->is_setupLink) &&
-		(coex_sta->bt_relink_downcount != 0) &&
-		(!coex_sta->is_2g_freerun)) {
+	if (coex_sta->is_setup_link || coex_sta->bt_relink_downcount != 0) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			"[BTCoex], BT is re-link !!!\n");
 		BTC_TRACE(trace_buf);
@@ -4265,10 +4255,9 @@ void halbtc8723d2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 			return;
 	}
 
-	if ((BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			coex_dm->bt_status) ||
-		   (BT_8723D_2ANT_BT_STATUS_CONNECTED_IDLE ==
-			coex_dm->bt_status)) {
+	if ((coex_dm->bt_status == BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE ||
+	     coex_dm->bt_status == BT_8723D_2ANT_BT_STATUS_CONNECTED_IDLE)
+	     && wifi_connected) {
 
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				"[BTCoex], Action 2-Ant, bt idle!!.\n");
@@ -4308,7 +4297,7 @@ void halbtc8723d2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
 	}
 }
 
-
+static
 void halbtc8723d2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
 {
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
@@ -4324,17 +4313,17 @@ void halbtc8723d2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
 	halbtc8723d2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
 
 	coex_sta->pop_event_cnt = 0;
-	coex_sta->cnt_RemoteNameReq = 0;
-	coex_sta->cnt_ReInit = 0;
-	coex_sta->cnt_setupLink = 0;
-	coex_sta->cnt_IgnWlanAct = 0;
-	coex_sta->cnt_Page = 0;
-	coex_sta->cnt_RoleSwitch = 0;
+	coex_sta->cnt_remotenamereq = 0;
+	coex_sta->cnt_reinit = 0;
+	coex_sta->cnt_setuplink = 0;
+	coex_sta->cnt_ignwlanact = 0;
+	coex_sta->cnt_page = 0;
+	coex_sta->cnt_roleswitch = 0;
 
 	halbtc8723d2ant_query_bt_info(btcoexist);
 }
 
-
+static
 void halbtc8723d2ant_init_hw_config(IN struct btc_coexist *btcoexist,
 				    IN boolean wifi_only)
 {
@@ -4360,1396 +4349,114 @@ void halbtc8723d2ant_init_hw_config(IN struct btc_coexist *btcoexist,
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 		"[BTCoex], ********** 0x67 = 0x%x, 0x948 = 0x%x, 0x73 = 0x%x(Before init_hw_config)\n",
-		    u8tmp0, u16tmp1, u8tmp1);
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********0x38= 0x%x, 0x54= 0x%x (Before init_hw_config)\n",
-		    u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-
-	coex_sta->bt_coex_supported_feature = 0;
-	coex_sta->bt_coex_supported_version = 0;
-	coex_sta->bt_ble_scan_type = 0;
-	coex_sta->bt_ble_scan_para[0] = 0;
-	coex_sta->bt_ble_scan_para[1] = 0;
-	coex_sta->bt_ble_scan_para[2] = 0;
-	coex_sta->bt_reg_vendor_ac = 0xffff;
-	coex_sta->bt_reg_vendor_ae = 0xffff;
-	coex_sta->gnt_error_cnt = 0;
-	coex_sta->bt_relink_downcount = 0;
-	coex_sta->wl_rx_rate = BTC_UNKNOWN;
-
-	for (i = 0; i <= 9; i++)
-		coex_sta->bt_afh_map[i] = 0;
-
-#if 0
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_VENDOR, &vendor);
-	if (vendor == BTC_VENDOR_LENOVO)
-		coex_dm->switch_thres_offset = 0;
-	else
-		coex_dm->switch_thres_offset = 20;
-#endif
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	coex_sta->dis_ver_info_cnt = 0;
-
-	/* default isolation = 15dB */
-	coex_sta->isolation_btween_wb = BT_8723D_2ANT_DEFAULT_ISOLATION;
-	halbtc8723d2ant_coex_switch_threshold(btcoexist,
-					      coex_sta->isolation_btween_wb);
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* BT report packet sample rate	 */
-	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
-
-	/* Init 0x778 = 0x1 for 2-Ant */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* Enable PTA (3-wire function form BT side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
-
-	/* Enable PTA (tx/rx signal form WiFi side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
-
-	halbtc8723d2ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-#if 0
-	/* check if WL firmware download ok */
-	if (btcoexist->btc_read_1byte(btcoexist, 0x80) == 0xc6)
-		halbtc8723d2ant_post_state_to_bt(btcoexist,
-					 BT_8723D_2ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-
-	/* Enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e,
-			   0x4); /* 0x76e[3] =1, WLAN_Act control by PTA */
-
-	/* WLAN_Tx by GNT_WL  0x950[29] = 0 */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x20, 0x0);
-
-	psd_scan->ant_det_is_ant_det_available = TRUE;
-
-	if (coex_sta->is_rf_state_off) {
-
-		halbtc8723d2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8723D_2ANT_PHASE_WLAN_OFF);
-
-		btcoexist->stop_coex_dm = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  halbtc8723d2ant_init_hw_config (RF Off)**********\n");
-		BTC_TRACE(trace_buf);
-	} else if (wifi_only) {
-		coex_sta->concurrent_rx_mode_on = FALSE;
-		/* Path config	 */
-		/* Set Antenna Path */
-		halbtc8723d2ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8723D_2ANT_PHASE_WLANONLY_INIT);
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else {
-		/*Set BT polluted packet on for Tx rate adaptive not including Tx retry break by PTA, 0x45c[19] =1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x1);
-
-		coex_sta->concurrent_rx_mode_on = TRUE;
-		/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x2, 0x1); */
-
-		/* RF 0x1[0] = 0->Set GNT_WL_RF_Rx always = 1 for con-current Rx */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x1, 0x0);
-
-		/* Path config	 */
-		halbtc8723d2ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8723D_2ANT_PHASE_COEX_INIT);
-
-		btcoexist->stop_coex_dm = FALSE;
-	}
-
-	halbtc8723d2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8723d2ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-}
-
-u32 halbtc8723d2ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)
-{
-	u8	j;
-	u32	tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
-	u32	result, val_fractiond_b = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
-				   174, 151, 132, 115, 100, 86, 74, 62, 51, 42,
-							   32, 23, 15, 7, 0
-							      };
-
-	if (val == 0)
-		return 0;
-
-	tmp = val;
-
-	while (1) {
-		if (tmp == 1)
-			break;
-		else {
-			tmp = (tmp >> 1);
-			shiftcount++;
-		}
-	}
-
-
-	val_integerd_b = shiftcount + 1;
-
-	tmp2 = 1;
-	for (j = 1; j <= val_integerd_b; j++)
-		tmp2 = tmp2 * 2;
-
-	tmp = (val * 100) / tmp2;
-	tindex = tmp / 5;
-
-	if (tindex > 20)
-		tindex = 20;
-
-	val_fractiond_b = table_fraction[tindex];
-
-	result = val_integerd_b * 100 - val_fractiond_b;
-
-	return result;
-
-
-}
-
-void halbtc8723d2ant_psd_show_antenna_detect_result(IN struct btc_coexist
-		*btcoexist)
-{
-	u8		*cli_buf = btcoexist->cli_buf;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n============[Antenna Detection info]  ============\n");
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 12) { /* Get Ant Det from BT  */
-
-		if (board_info->btdm_ant_num_by_ant_det == 1)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n %-35s = %s (%d~%d)",
-				   "Ant Det Result", "1-Antenna",
-				   BT_8723D_2ANT_ANTDET_PSDTHRES_1ANT,
-				BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION);
-		else {
-
-			if (psd_scan->ant_det_psd_scan_peak_val >
-			    (BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION)
-			    * 100)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s (>%d)",
-					"Ant Det Result", "2-Antenna (Bad-Isolation)",
-					BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s (%d~%d)",
-					"Ant Det Result", "2-Antenna (Good-Isolation)",
-					BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-					   + psd_scan->ant_det_thres_offset,
-					BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-		}
-
-	} else if (psd_scan->ant_det_result == 1)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (>%d)",
-			   "Ant Det Result", "2-Antenna (Bad-Isolation)",
-			   BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else if (psd_scan->ant_det_result == 2)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)",
-			   "Ant Det Result", "2-Antenna (Good-Isolation)",
-			   BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-			   + psd_scan->ant_det_thres_offset,
-			   BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (%d~%d)",
-			   "Ant Det Result", "1-Antenna",
-			   BT_8723D_2ANT_ANTDET_PSDTHRES_1ANT,
-			   BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-			   + psd_scan->ant_det_thres_offset);
-
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s ",
-		   "Antenna Detection Finish",
-		   (board_info->btdm_ant_det_finish
-		    ? "Yes" : "No"));
-	CL_PRINTF(cli_buf);
-
-	switch (psd_scan->ant_det_result) {
-	case 0:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is not available)");
-		break;
-	case 1:  /* 2-Ant bad-isolation */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 2:  /* 2-Ant good-isolation */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 3:  /* 1-Ant */
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available)");
-		break;
-	case 4:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Uncertainty result)");
-		break;
-	case 5:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "(Pre-Scan fai)");
-		break;
-	case 6:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(WiFi is Scanning)");
-		break;
-	case 7:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is not idle)");
-		break;
-	case 8:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Abort by WiFi Scanning)");
-		break;
-	case 9:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(Antenna Init is not ready)");
-		break;
-	case 10:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is Inquiry or page)");
-		break;
-	case 11:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is Disabled)");
-	case 12:
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "(BT is available, result from BT");
-		break;
-	}
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 12) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dB",
-			   "PSD Scan Peak Value",
-			   psd_scan->ant_det_psd_scan_peak_val / 100);
-		CL_PRINTF(cli_buf);
-		return;
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Ant Detect Total Count", psd_scan->ant_det_try_count);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Ant Detect Fail Count", psd_scan->ant_det_fail_count);
-	CL_PRINTF(cli_buf);
-
-	if ((!board_info->btdm_ant_det_finish) &&
-	    (psd_scan->ant_det_result != 5))
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT Response",
-		   (psd_scan->ant_det_result ? "ok" : "fail"));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ms", "BT Tx Time",
-		   psd_scan->ant_det_bt_tx_time);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "BT Tx Ch",
-		   psd_scan->ant_det_bt_le_channel);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d",
-		   "WiFi PSD Cent-Ch/Offset/Span",
-		   psd_scan->real_cent_freq, psd_scan->real_offset,
-		   psd_scan->real_span);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dB",
-		   "PSD Pre-Scan Peak Value",
-		   psd_scan->ant_det_pre_psdscan_peak_val / 100);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s (<= %d)",
-		   "PSD Pre-Scan result",
-		   (psd_scan->ant_det_result != 5 ? "ok" : "fail"),
-		   BT_8723D_2ANT_ANTDET_PSDTHRES_BACKGROUND
-		   + psd_scan->ant_det_thres_offset);
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->ant_det_result == 5)
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s dB",
-		   "PSD Scan Peak Value", psd_scan->ant_det_peak_val);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s MHz",
-		   "PSD Scan Peak Freq", psd_scan->ant_det_peak_freq);
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "TFBGA Package",
-		   (board_info->tfbga_package) ?  "Yes" : "No");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "PSD Threshold Offset", psd_scan->ant_det_thres_offset);
-	CL_PRINTF(cli_buf);
-
-}
-
-void halbtc8723d2ant_psd_showdata(IN struct btc_coexist *btcoexist)
-{
-	u8		*cli_buf = btcoexist->cli_buf;
-	u32		delta_freq_per_point;
-	u32		freq, freq1, freq2, n = 0, i = 0, j = 0, m = 0, psd_rep1, psd_rep2;
-
-	if (psd_scan->ant_det_result == 12)
-		return;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n\n============[PSD info]  (%d)============\n",
-		   psd_scan->psd_gen_count);
-	CL_PRINTF(cli_buf);
-
-	if (psd_scan->psd_gen_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n No data !!\n");
-		CL_PRINTF(cli_buf);
-		return;
-	}
-
-	if (psd_scan->psd_point == 0)
-		delta_freq_per_point = 0;
-	else
-		delta_freq_per_point = psd_scan->psd_band_width /
-				       psd_scan->psd_point;
-
-	/* if (psd_scan->is_psd_show_max_only) */
-	if (0) {
-		psd_rep1 = psd_scan->psd_max_value / 100;
-		psd_rep2 = psd_scan->psd_max_value - psd_rep1 * 100;
-
-		freq = ((psd_scan->real_cent_freq - 20) * 1000000 +
-			psd_scan->psd_max_value_point * delta_freq_per_point);
-		freq1 = freq / 1000000;
-		freq2 = freq / 1000 - freq1 * 1000;
-
-		if (freq2 < 100)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n Freq = %d.0%d MHz",
-				   freq1, freq2);
-		else
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   "\r\n Freq = %d.%d MHz",
-				   freq1, freq2);
-
-		if (psd_rep2 < 10)
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   ", Value = %d.0%d dB, (%d)\n",
-				   psd_rep1, psd_rep2, psd_scan->psd_max_value);
-		else
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				   ", Value = %d.%d dB, (%d)\n",
-				   psd_rep1, psd_rep2, psd_scan->psd_max_value);
-
-		CL_PRINTF(cli_buf);
-	} else {
-		m = psd_scan->psd_start_point;
-		n = psd_scan->psd_start_point;
-		i = 1;
-		j = 1;
-
-		while (1) {
-			do {
-				freq = ((psd_scan->real_cent_freq - 20) *
-					1000000 + m *
-					delta_freq_per_point);
-				freq1 = freq / 1000000;
-				freq2 = freq / 1000 - freq1 * 1000;
-
-				if (i == 1) {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.000",
-							   freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.0%2d",
-							   freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Freq%6d.%3d",
-							   freq1,
-							   freq2);
-				} else if ((i % 8 == 0) ||
-					   (m == psd_scan->psd_stop_point)) {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.000\n", freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.0%2d\n", freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.%3d\n", freq1,
-							   freq2);
-				} else {
-					if (freq2 == 0)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.000", freq1);
-					else if (freq2 < 100)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.0%2d", freq1,
-							   freq2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%6d.%3d", freq1,
-							   freq2);
-				}
-
-				i++;
-				m++;
-				CL_PRINTF(cli_buf);
-
-			} while ((i <= 8) && (m <= psd_scan->psd_stop_point));
-
-
-			do {
-				psd_rep1 = psd_scan->psd_report_max_hold[n] /
-					   100;
-				psd_rep2 = psd_scan->psd_report_max_hold[n] -
-					   psd_rep1 *
-					   100;
-
-				if (j == 1) {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Val %7d.0%d",
-							   psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "\r\n Val %7d.%d",
-							   psd_rep1,
-							   psd_rep2);
-				} else if ((j % 8 == 0)  ||
-					   (n == psd_scan->psd_stop_point)) {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							"%7d.0%d\n", psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.%d\n", psd_rep1,
-							   psd_rep2);
-				} else {
-					if (psd_rep2 < 10)
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.0%d", psd_rep1,
-							   psd_rep2);
-					else
-						CL_SPRINTF(cli_buf,
-							   BT_TMP_BUF_SIZE,
-							   "%7d.%d", psd_rep1,
-							   psd_rep2);
-				}
-
-				j++;
-				n++;
-				CL_PRINTF(cli_buf);
-
-			} while ((j <= 8) && (n <= psd_scan->psd_stop_point));
-
-			if ((m > psd_scan->psd_stop_point) ||
-			    (n > psd_scan->psd_stop_point))
-				break;
-			else {
-				i = 1;
-				j = 1;
-			}
-
-		}
-	}
-
-
-}
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-void halbtc8723d2ant_psd_maxholddata(IN struct btc_coexist *btcoexist,
-				     IN u32 gen_count)
-{
-	u32 i = 0;
-	u32 loop_i_max = 0, loop_val_max = 0;
-
-	if (gen_count == 1) {
-		memcpy(psd_scan->psd_report_max_hold,
-		       psd_scan->psd_report,
-		       BT_8723D_2ANT_ANTDET_PSD_POINTS * sizeof(u32));
-	}
-
-	for (i = psd_scan->psd_start_point;
-	     i <= psd_scan->psd_stop_point; i++) {
-
-		/* update max-hold value at each freq point */
-		if (psd_scan->psd_report[i] > psd_scan->psd_report_max_hold[i])
-			psd_scan->psd_report_max_hold[i] =
-				psd_scan->psd_report[i];
-
-		/*	search the max value in this seep */
-		if (psd_scan->psd_report[i] > loop_val_max) {
-			loop_val_max = psd_scan->psd_report[i];
-			loop_i_max = i;
-		}
-	}
-
-	if (gen_count <= BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT)
-		psd_scan->psd_loop_max_value[gen_count - 1] = loop_val_max;
-
-}
-
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-u32 halbtc8723d2ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)
-{
-	/* reg 0x808[9:0]: FFT data x */
-	/* reg 0x808[22]: 0-->1 to get 1 FFT data y */
-	/* reg 0x8b4[15:0]: FFT data y report */
-
-	u32 val = 0, psd_report = 0;
-	int k = 0;
-
-	val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-
-	val &= 0xffbffc00;
-	val |= point;
-
-	btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-	val |= 0x00400000;
-	btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-	while (1) {
-		if (k++ > BT_8723D_2ANT_ANTDET_SWEEPPOINT_DELAY)
-			break;
-	}
-
-	val = btcoexist->btc_read_4byte(btcoexist, 0x8b4);
-
-	psd_report = val & 0x0000ffff;
-
-	return psd_report;
-}
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-boolean halbtc8723d2ant_psd_sweep_point(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN s32 offset, IN u32 span, IN u32 points,
-					IN u32 avgnum, IN u32 loopcnt)
-{
-	u32	 i = 0, val = 0, n = 0, k = 0, j, point_index = 0;
-	u32	points1 = 0, psd_report = 0;
-	u32	start_p = 0, stop_p = 0, delta_freq_per_point = 156250;
-	u32    psd_center_freq = 20 * 10 ^ 6;
-	boolean outloop = FALSE, scan, roam, is_sweep_ok = TRUE;
-	u8	 flag = 0;
-	u32	tmp = 0, u32tmp1 = 0;
-	u32	wifi_original_channel = 1;
-	u32 psd_sum = 0, avg_cnt = 0;
-	u32	i_max = 0, val_max = 0, val_max2 = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx PSD Sweep Start!!\n");
-	BTC_TRACE(trace_buf);
-
-	do {
-		switch (flag) {
-		case 0:  /* Get PSD parameters */
-		default:
-
-			psd_scan->psd_band_width = 40 * 1000000;
-			psd_scan->psd_point = points;
-			psd_scan->psd_start_base = points / 2;
-			psd_scan->psd_avg_num = avgnum;
-			psd_scan->real_cent_freq = cent_freq;
-			psd_scan->real_offset = offset;
-			psd_scan->real_span = span;
-
-
-			points1 = psd_scan->psd_point;
-			delta_freq_per_point = psd_scan->psd_band_width /
-					       psd_scan->psd_point;
-
-			/* PSD point setup */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-			val &= 0xffff0fff;
-
-			switch (psd_scan->psd_point) {
-			case 128:
-				val |= 0x0;
-				break;
-			case 256:
-			default:
-				val |= 0x00004000;
-				break;
-			case 512:
-				val |= 0x00008000;
-				break;
-			case 1024:
-				val |= 0x0000c000;
-				break;
-			}
-
-			switch (psd_scan->psd_avg_num) {
-			case 1:
-				val |= 0x0;
-				break;
-			case 8:
-				val |= 0x00001000;
-				break;
-			case 16:
-				val |= 0x00002000;
-				break;
-			case 32:
-			default:
-				val |= 0x00003000;
-				break;
-			}
-			btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-			flag = 1;
-			break;
-		case 1:	  /* calculate the PSD point index from freq/offset/span */
-			psd_center_freq = psd_scan->psd_band_width / 2 +
-					  offset * (1000000);
-
-			start_p = psd_scan->psd_start_base + (psd_center_freq -
-				span * (1000000) / 2) / delta_freq_per_point;
-			psd_scan->psd_start_point = start_p -
-						    psd_scan->psd_start_base;
-
-			stop_p = psd_scan->psd_start_base + (psd_center_freq +
-				span * (1000000) / 2) / delta_freq_per_point;
-			psd_scan->psd_stop_point = stop_p -
-						   psd_scan->psd_start_base - 1;
-
-			flag = 2;
-			break;
-		case 2:  /* set RF channel/BW/Mode */
-
-			/* set 3-wire off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x88c);
-			val |= 0x00300000;
-			btcoexist->btc_write_4byte(btcoexist, 0x88c, val);
-
-			/* CCK off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x800);
-			val &= 0xfeffffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x800, val);
-
-			/* Tx-pause on */
-			btcoexist->btc_write_1byte(btcoexist, 0x522, 0x6f);
-
-			/* store WiFi original channel */
-			wifi_original_channel = btcoexist->btc_get_rf_reg(
-					btcoexist, BTC_RF_A, 0x18, 0x3ff);
-
-			/* Set RF channel */
-			if (cent_freq == 2484)
-				btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A,
-							  0x18, 0x3ff, 0xe);
-			else
-				btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A,
-					  0x18, 0x3ff, (cent_freq - 2412) / 5 +
-						  1); /* WiFi TRx Mask on */
-
-			/* save original RCK value */
-			u32tmp1 =  btcoexist->btc_get_rf_reg(
-					   btcoexist, BTC_RF_A, 0x1d, 0xfffff);
-
-			/* Enter debug mode */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xde,
-						  0x2, 0x1);
-
-			/* Set RF Rx filter corner */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1d,
-						  0xfffff, 0x2e);
-
-
-			/* Set  RF mode = Rx, RF Gain = 0x320a0 */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x0,
-						  0xfffff, 0x320a0);
-
-			while (1) {
-				if (k++ > BT_8723D_2ANT_ANTDET_SWEEPPOINT_DELAY)
-					break;
-			}
-			flag = 3;
-			break;
-		case 3:
-			psd_scan->psd_gen_count = 0;
-			for (j = 1; j <= loopcnt; j++) {
-
-				btcoexist->btc_get(btcoexist,
-						   BTC_GET_BL_WIFI_SCAN, &scan);
-				btcoexist->btc_get(btcoexist,
-						   BTC_GET_BL_WIFI_ROAM, &roam);
-
-				if (scan || roam) {
-					is_sweep_ok = FALSE;
-					break;
-				}
-				memset(psd_scan->psd_report, 0,
-				       psd_scan->psd_point * sizeof(u32));
-				start_p = psd_scan->psd_start_point +
-					  psd_scan->psd_start_base;
-				stop_p = psd_scan->psd_stop_point +
-					 psd_scan->psd_start_base + 1;
-
-				i = start_p;
-				point_index = 0;
-
-				while (i < stop_p) {
-					if (i >= points1)
-						psd_report =
-							halbtc8723d2ant_psd_getdata(
-							btcoexist, i - points1);
-					else
-						psd_report =
-							halbtc8723d2ant_psd_getdata(
-								btcoexist, i);
-
-					if (psd_report == 0)
-						tmp = 0;
-					else
-						/* tmp =  20*log10((double)psd_report); */
-						/* 20*log2(x)/log2(10), log2Base return theresult of the psd_report*100 */
-						tmp = 6 * halbtc8723d2ant_psd_log2base(
-							btcoexist, psd_report);
-
-					n = i - psd_scan->psd_start_base;
-					psd_scan->psd_report[n] =  tmp;
-
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"Point=%d, psd_dB_data = %d\n",
-						    i, psd_scan->psd_report[n]);
-					BTC_TRACE(trace_buf);
-
-					i++;
-
-				}
-
-				halbtc8723d2ant_psd_maxholddata(btcoexist, j);
-
-				psd_scan->psd_gen_count = j;
-
-				/*Accumulate Max PSD value in this loop if the value > threshold */
-				if (psd_scan->psd_loop_max_value[j - 1] >=
-				    4000) {
-					psd_sum = psd_sum +
-						psd_scan->psd_loop_max_value[j -
-								       1];
-					avg_cnt++;
-				}
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "Loop=%d, Max_dB_data = %d\n",
-					    j, psd_scan->psd_loop_max_value[j
-							    - 1]);
-				BTC_TRACE(trace_buf);
-
-			}
-
-			if (loopcnt == BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT) {
-
-				/* search the Max Value between each-freq-point-max-hold value of all sweep*/
-				for (i = 1;
-				     i <= BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT;
-				     i++) {
-
-					if (i == 1) {
-						i_max = i;
-						val_max = psd_scan->psd_loop_max_value[i
-								       - 1];
-						val_max2 =
-							psd_scan->psd_loop_max_value[i
-								     - 1];
-					} else if (
-						psd_scan->psd_loop_max_value[i -
-							     1] > val_max) {
-						val_max2 = val_max;
-						i_max = i;
-						val_max = psd_scan->psd_loop_max_value[i
-								       - 1];
-					} else if (
-						psd_scan->psd_loop_max_value[i -
-							     1] > val_max2)
-						val_max2 =
-							psd_scan->psd_loop_max_value[i
-								     - 1];
-
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"i = %d, val_hold= %d, val_max = %d, val_max2 = %d\n",
-						i, psd_scan->psd_loop_max_value[i
-								    - 1],
-						    val_max, val_max2);
-
-					BTC_TRACE(trace_buf);
-				}
-
-				psd_scan->psd_max_value_point = i_max;
-				psd_scan->psd_max_value = val_max;
-				psd_scan->psd_max_value2 = val_max2;
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "val_max = %d, val_max2 = %d\n",
-					    psd_scan->psd_max_value,
-					    psd_scan->psd_max_value2);
-				BTC_TRACE(trace_buf);
-			}
-
-			if (avg_cnt != 0) {
-				psd_scan->psd_avg_value = (psd_sum / avg_cnt);
-				if ((psd_sum % avg_cnt) >= (avg_cnt / 2))
-					psd_scan->psd_avg_value++;
-			} else
-				psd_scan->psd_avg_value = 0;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "AvgLoop=%d, Avg_dB_data = %d\n",
-				    avg_cnt, psd_scan->psd_avg_value);
-			BTC_TRACE(trace_buf);
-
-			flag = 100;
-			break;
-		case 99:	/* error */
-
-			outloop = TRUE;
-			break;
-		case 100: /* recovery */
-
-			/* set 3-wire on */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x88c);
-			val &= 0xffcfffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x88c, val);
-
-			/* CCK on */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x800);
-			val |= 0x01000000;
-			btcoexist->btc_write_4byte(btcoexist, 0x800, val);
-
-			/* Tx-pause off */
-			btcoexist->btc_write_1byte(btcoexist, 0x522, 0x0);
-
-			/* PSD off */
-			val = btcoexist->btc_read_4byte(btcoexist, 0x808);
-			val &= 0xffbfffff;
-			btcoexist->btc_write_4byte(btcoexist, 0x808, val);
-
-			/* restore RF Rx filter corner */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1d,
-						  0xfffff, u32tmp1);
-
-			/* Exit debug mode */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xde,
-						  0x2, 0x0);
-
-			/* restore WiFi original channel */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x18,
-						  0x3ff, wifi_original_channel);
-
-			outloop = TRUE;
-			break;
-
-		}
-
-	} while (!outloop);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx PSD Sweep Stop!!\n");
-	BTC_TRACE(trace_buf);
-	return is_sweep_ok;
-
-}
-
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-boolean halbtc8723d2ant_psd_antenna_detection(IN struct btc_coexist
-		*btcoexist)
-{
-	u32	i = 0;
-	u32	wlpsd_cent_freq = 2484, wlpsd_span = 2;
-	s32	wlpsd_offset = -4;
-	u32 bt_tx_time, bt_le_channel;
-	u8	bt_le_ch[13] = {3, 6, 8, 11, 13, 16, 18, 21, 23, 26, 28, 31, 33};
-
-	u8	h2c_parameter[3] = {0}, u8tmpa, u8tmpb;
-
-	u8	state = 0;
-	boolean		outloop = FALSE, bt_resp = FALSE, ant_det_finish = FALSE;
-	u32		freq, freq1, freq2, psd_rep1, psd_rep2, delta_freq_per_point,
-			u32tmp, u32tmp0, u32tmp1, u32tmp2 ;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-
-	memset(psd_scan->ant_det_peak_val, 0, 16 * sizeof(u8));
-	memset(psd_scan->ant_det_peak_freq, 0, 16 * sizeof(u8));
-
-	psd_scan->ant_det_bt_tx_time =
-		BT_8723D_2ANT_ANTDET_BTTXTIME;	   /* 0.42ms*50 = 20ms (0.42ms = 1 PSD sweep) */
-	psd_scan->ant_det_bt_le_channel = BT_8723D_2ANT_ANTDET_BTTXCHANNEL;
-
-	bt_tx_time = psd_scan->ant_det_bt_tx_time;
-	bt_le_channel = psd_scan->ant_det_bt_le_channel;
-
-	if (board_info->tfbga_package) /* for TFBGA */
-		psd_scan->ant_det_thres_offset = 5;
-	else
-		psd_scan->ant_det_thres_offset = 0;
-
-	do {
-		switch (state) {
-		case 0:
-			if (bt_le_channel == 39)
-				wlpsd_cent_freq = 2484;
-			else {
-				for (i = 1; i <= 13; i++) {
-					if (bt_le_ch[i - 1] ==
-					    bt_le_channel) {
-						wlpsd_cent_freq = 2412
-								  + (i - 1) * 5;
-						break;
-					}
-				}
-
-				if (i == 14) {
-
-					BTC_SPRINTF(trace_buf,
-						    BT_TMP_BUF_SIZE,
-						"xxxxxxxxxxxxxxxx AntennaDetect(), Abort!!, Invalid LE channel = %d\n ",
-						    bt_le_channel);
-					BTC_TRACE(trace_buf);
-					outloop = TRUE;
-					break;
-				}
-			}
-#if 0
-			wlpsd_sweep_count = bt_tx_time * 238 /
-					    100; /* bt_tx_time/0.42								 */
-			wlpsd_sweep_count = wlpsd_sweep_count / 5;
-
-			if (wlpsd_sweep_count % 5 != 0)
-				wlpsd_sweep_count = (wlpsd_sweep_count /
-						     5 + 1) * 5;
-#endif
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), BT_LETxTime=%d,  BT_LECh = %d\n",
-				    bt_tx_time, bt_le_channel);
-			BTC_TRACE(trace_buf);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), wlpsd_cent_freq=%d,  wlpsd_offset = %d, wlpsd_span = %d, wlpsd_sweep_count = %d\n",
-				    wlpsd_cent_freq,
-				    wlpsd_offset,
-				    wlpsd_span,
-				    BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT);
-			BTC_TRACE(trace_buf);
-
-			state = 1;
-			break;
-		case 1: /* stop coex DM & set antenna path */
-			/* Stop Coex DM */
-			btcoexist->stop_coex_dm = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Stop Coex DM!!\n");
-			BTC_TRACE(trace_buf);
-
-			/* Set TDMA off,				 */
-			/* Set coex table */
-			halbtc8723d2ant_coex_table_with_type(btcoexist,
-							     FORCE_EXEC, 0);
-
-			halbtc8723d2ant_ps_tdma(btcoexist, FORCE_EXEC,
-						FALSE, 0);
-
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Main Port\n");
-				BTC_TRACE(trace_buf);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna at Aux Port\n");
-				BTC_TRACE(trace_buf);
-			}
-
-			/* Set Antenna path, switch WiFi to un-certain antenna port */
-			/* Set Antenna Path,  both GNT_WL/GNT_BT = 1, and control by SW */
-			halbtc8723d2ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-						     FORCE_EXEC,
-					     BT_8723D_2ANT_PHASE_ANTENNA_DET);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to BT!!\n");
-			BTC_TRACE(trace_buf);
-
-			/* Set AFH mask on at WiFi channel 2472MHz +/- 10MHz */
-			h2c_parameter[0] = 0x1;
-			h2c_parameter[1] = 0xd;
-			h2c_parameter[2] = 0x14;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-				    h2c_parameter[1],
-				    h2c_parameter[2]);
-			BTC_TRACE(trace_buf);
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x66, 3,
-						h2c_parameter);
-
-			u32tmp = btcoexist->btc_read_2byte(btcoexist, 0x948);
-			u32tmp0 = btcoexist->btc_read_4byte(btcoexist, 0x70);
-			u32tmp1 = halbtc8723d2ant_ltecoex_indirect_read_reg(
-					  btcoexist, 0x38);
-			u32tmp2 = halbtc8723d2ant_ltecoex_indirect_read_reg(
-					  btcoexist, 0x54);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** 0x948 = 0x%x, 0x70 = 0x%x, 0x38= 0x%x, 0x54= 0x%x (Before Ant Det)\n",
-				    u32tmp, u32tmp0, u32tmp1, u32tmp2);
-			BTC_TRACE(trace_buf);
-
-			state = 2;
-			break;
-		case 2:	/* Pre-sweep background psd */
-			if (!halbtc8723d2ant_psd_sweep_point(btcoexist,
-				     wlpsd_cent_freq, wlpsd_offset, wlpsd_span,
-					     BT_8723D_2ANT_ANTDET_PSD_POINTS,
-				     BT_8723D_2ANT_ANTDET_PSD_AVGNUM, 3)) {
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 8;
-				state = 99;
-				break;
-			}
-
-			psd_scan->ant_det_pre_psdscan_peak_val =
-				psd_scan->psd_max_value;
-
-			if (psd_scan->ant_det_pre_psdscan_peak_val >
-			    (BT_8723D_2ANT_ANTDET_PSDTHRES_BACKGROUND
-			     + psd_scan->ant_det_thres_offset) * 100) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Abort Antenna Detection!! becaus background = %d > thres (%d)\n",
-					psd_scan->ant_det_pre_psdscan_peak_val /
-					    100,
-					BT_8723D_2ANT_ANTDET_PSDTHRES_BACKGROUND
-					    + psd_scan->ant_det_thres_offset);
-				BTC_TRACE(trace_buf);
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 5;
-				state = 99;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Start Antenna Detection!! becaus background = %d <= thres (%d)\n",
-					psd_scan->ant_det_pre_psdscan_peak_val /
-					    100,
-					BT_8723D_2ANT_ANTDET_PSDTHRES_BACKGROUND
-					    + psd_scan->ant_det_thres_offset);
-				BTC_TRACE(trace_buf);
-				state = 3;
-			}
-			break;
-		case 3:
-			bt_resp = btcoexist->btc_set_bt_ant_detection(
-					  btcoexist, (u8)(bt_tx_time & 0xff),
-					  (u8)(bt_le_channel & 0xff));
-
-			/* Sync WL Rx PSD with BT Tx time because H2C->Mailbox delay */
-			delay_ms(20);
-
-			if (!halbtc8723d2ant_psd_sweep_point(btcoexist,
-					     wlpsd_cent_freq, wlpsd_offset,
-							     wlpsd_span,
-					     BT_8723D_2ANT_ANTDET_PSD_POINTS,
-					     BT_8723D_2ANT_ANTDET_PSD_AVGNUM,
-				     BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT)) {
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				psd_scan->ant_det_result = 8;
-				state = 99;
-				break;
-			}
+		    u8tmp0, u16tmp1, u8tmp1);
+	BTC_TRACE(trace_buf);
 
-#if 1
-			psd_scan->ant_det_psd_scan_peak_val =
-				psd_scan->psd_max_value;
-#endif
-#if 0
-			psd_scan->ant_det_psd_scan_peak_val =
-				((psd_scan->psd_max_value - psd_scan->psd_avg_value) <
-				 800) ?
-				psd_scan->psd_max_value : ((
-						psd_scan->psd_max_value -
-					psd_scan->psd_max_value2 <= 300) ?
-						   psd_scan->psd_avg_value :
-						   psd_scan->psd_max_value2);
+	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+		"[BTCoex], **********0x38= 0x%x, 0x54= 0x%x (Before init_hw_config)\n",
+		    u32tmp1, u32tmp2);
+	BTC_TRACE(trace_buf);
 #endif
-			psd_scan->ant_det_psd_scan_peak_freq =
-				psd_scan->psd_max_value_point;
-			state = 4;
-			break;
-		case 4:
 
-			if (psd_scan->psd_point == 0)
-				delta_freq_per_point = 0;
-			else
-				delta_freq_per_point =
-					psd_scan->psd_band_width /
-					psd_scan->psd_point;
-
-			psd_rep1 = psd_scan->ant_det_psd_scan_peak_val / 100;
-			psd_rep2 = psd_scan->ant_det_psd_scan_peak_val -
-				   psd_rep1 *
-				   100;
-
-			freq = ((psd_scan->real_cent_freq - 20) *
-				1000000 + psd_scan->psd_max_value_point
-				* delta_freq_per_point);
-			freq1 = freq / 1000000;
-			freq2 = freq / 1000 - freq1 * 1000;
-
-			if (freq2 < 100) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.0%d MHz",
-					    freq1, freq2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_freq,
-					   BT_8723D_2ANT_ANTDET_BUF_LEN,
-					   "%d.0%d", freq1, freq2);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Max Value: Freq = %d.%d MHz",
-					    freq1, freq2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_freq,
-					   BT_8723D_2ANT_ANTDET_BUF_LEN,
-					   "%d.%d", freq1, freq2);
-			}
 
-			if (psd_rep2 < 10) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    ", Value = %d.0%d dB\n",
-					    psd_rep1, psd_rep2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_val,
-					   BT_8723D_2ANT_ANTDET_BUF_LEN,
-					   "%d.0%d", psd_rep1, psd_rep2);
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    ", Value = %d.%d dB\n",
-					    psd_rep1, psd_rep2);
-				BTC_TRACE(trace_buf);
-				CL_SPRINTF(psd_scan->ant_det_peak_val,
-					   BT_8723D_2ANT_ANTDET_BUF_LEN,
-					   "%d.%d", psd_rep1, psd_rep2);
-			}
+	coex_sta->bt_coex_supported_feature = 0;
+	coex_sta->bt_coex_supported_version = 0;
+	coex_sta->bt_ble_scan_type = 0;
+	coex_sta->bt_ble_scan_para[0] = 0;
+	coex_sta->bt_ble_scan_para[1] = 0;
+	coex_sta->bt_ble_scan_para[2] = 0;
+	coex_sta->bt_reg_vendor_ac = 0xffff;
+	coex_sta->bt_reg_vendor_ae = 0xffff;
+	coex_sta->gnt_error_cnt = 0;
+	coex_sta->bt_relink_downcount = 0;
+	coex_sta->wl_rx_rate = BTC_UNKNOWN;
 
-			psd_scan->ant_det_is_btreply_available = TRUE;
+	for (i = 0; i <= 9; i++)
+		coex_sta->bt_afh_map[i] = 0;
 
-			if (bt_resp == FALSE) {
-				psd_scan->ant_det_is_btreply_available =
-					FALSE;
-				psd_scan->ant_det_result = 0;
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), BT Response = Fail\n ");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->ant_det_psd_scan_peak_val >
-				(BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION)
-				   * 100) {
-				psd_scan->ant_det_result = 1;
-				ant_det_finish = TRUE;
-				board_info->btdm_ant_num_by_ant_det = 2;
-				coex_sta->isolation_btween_wb = (u8)(85 -
-					psd_scan->ant_det_psd_scan_peak_val /
-							     100) & 0xff;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Bad-Isolation!!\n");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->ant_det_psd_scan_peak_val >
-				(BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION
-				    + psd_scan->ant_det_thres_offset) * 100) {
-				psd_scan->ant_det_result = 2;
-				ant_det_finish = TRUE;
-				board_info->btdm_ant_num_by_ant_det = 2;
-				coex_sta->isolation_btween_wb = (u8)(85 -
-					psd_scan->ant_det_psd_scan_peak_val /
-							     100) & 0xff;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 2-Ant, Good-Isolation!!\n");
-				BTC_TRACE(trace_buf);
-			} else if (psd_scan->ant_det_psd_scan_peak_val >
-				   (BT_8723D_2ANT_ANTDET_PSDTHRES_1ANT) *
-				   100) {
-				psd_scan->ant_det_result = 3;
-				ant_det_finish = TRUE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				coex_sta->isolation_btween_wb = (u8)(85 -
-					psd_scan->ant_det_psd_scan_peak_val /
-							     100) & 0xff;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant!!\n");
-				BTC_TRACE(trace_buf);
-			} else {
-				psd_scan->ant_det_result = 4;
-				ant_det_finish = FALSE;
-				board_info->btdm_ant_num_by_ant_det = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Detect Result = 1-Ant, un-certainity!!\n");
-				BTC_TRACE(trace_buf);
-			}
+	/* 0xf0[15:12] --> kt_ver */
+	coex_sta->kt_ver = (btcoexist->btc_read_1byte(btcoexist,
+				 0xf1) & 0xf0) >> 4;
 
-			state = 99;
-			break;
-		case 99:  /* restore setup */
+	coex_sta->dis_ver_info_cnt = 0;
 
-			/* Set AFH mask off at WiFi channel 2472MHz +/- 10MHz */
-			h2c_parameter[0] = 0x0;
-			h2c_parameter[1] = 0x0;
-			h2c_parameter[2] = 0x0;
+	/* default isolation = 15dB */
+	coex_sta->isolation_btween_wb = BT_8723D_2ANT_DEFAULT_ISOLATION;
+	halbtc8723d2ant_coex_switch_threshold(btcoexist,
+					      coex_sta->isolation_btween_wb);
 
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set AFH on, Cent-Ch= %d,  Mask=%d\n",
-				    h2c_parameter[1], h2c_parameter[2]);
-			BTC_TRACE(trace_buf);
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
+					   0x1);  /* enable TBTT nterrupt */
 
-			btcoexist->btc_fill_h2c(btcoexist, 0x66, 3,
-						h2c_parameter);
+	/* BT report packet sample rate	 */
+	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
 
-			/* Set Antenna Path, GNT_WL/GNT_BT control by PTA */
-			/* Set Antenna path, switch WiFi to certain antenna port */
-			halbtc8723d2ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8723D_2ANT_PHASE_2G_RUNTIME);
+	/* Init 0x778 = 0x1 for 2-Ant */
+	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
 
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Set Antenna to PTA\n!!");
-			BTC_TRACE(trace_buf);
+	/* Enable PTA (3-wire function form BT side) */
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
 
-			btcoexist->stop_coex_dm = FALSE;
+	/* Enable PTA (tx/rx signal form WiFi side) */
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
 
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Resume Coex DM\n!!");
-			BTC_TRACE(trace_buf);
+	halbtc8723d2ant_enable_gnt_to_gpio(btcoexist, TRUE);
 
-			outloop = TRUE;
-			break;
-		}
+	/* Enable counter statistics */
+	btcoexist->btc_write_1byte(btcoexist, 0x76e,
+			   0x4); /* 0x76e[3] =1, WLAN_Act control by PTA */
 
-	} while (!outloop);
+	/* WLAN_Tx by GNT_WL  0x950[29] = 0 */
+	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x20, 0x0);
 
-	return ant_det_finish;
+	psd_scan->ant_det_is_ant_det_available = TRUE;
 
-}
+	if (coex_sta->is_rf_state_off) {
 
-#ifdef PLATFORM_WINDOWS
-#pragma optimize("", off)
-#endif
-boolean halbtc8723d2ant_psd_antenna_detection_check(IN struct btc_coexist
-		*btcoexist)
-{
-	static u32 ant_det_count = 0, ant_det_fail_count = 0;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
+		halbtc8723d2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
+					     FORCE_EXEC,
+					     BT_8723D_2ANT_PHASE_WLAN_OFF);
 
-	boolean scan, roam, ant_det_finish = FALSE;
+		btcoexist->stop_coex_dm = TRUE;
 
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			"[BTCoex], **********  halbtc8723d2ant_init_hw_config (RF Off)**********\n");
+		BTC_TRACE(trace_buf);
+	} else if (wifi_only) {
+		coex_sta->concurrent_rx_mode_on = FALSE;
+		/* Path config	 */
+		/* Set Antenna Path */
+		halbtc8723d2ant_set_ant_path(btcoexist,
+					     BTC_ANT_PATH_AUTO,
+					     FORCE_EXEC,
+					     BT_8723D_2ANT_PHASE_WLANONLY_INIT);
 
-	ant_det_count++;
-
-	psd_scan->ant_det_try_count = ant_det_count;
-
-	if (scan || roam) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 6;
-	} else if (coex_sta->bt_disabled) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 11;
-	} else if (coex_sta->num_of_profile >= 1) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 7;
-	} else if (
-		!psd_scan->ant_det_is_ant_det_available) { /* Antenna initial setup is not ready */
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 9;
-	} else if (coex_sta->c2h_bt_inquiry_page) {
-		ant_det_finish = FALSE;
-		psd_scan->ant_det_result = 10;
+		btcoexist->stop_coex_dm = TRUE;
 	} else {
+		coex_sta->concurrent_rx_mode_on = TRUE;
+		/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x2, 0x1); */
 
-		ant_det_finish = halbtc8723d2ant_psd_antenna_detection(
-					 btcoexist);
-
-		delay_ms(psd_scan->ant_det_bt_tx_time);
-	}
-
-
-	if (!ant_det_finish)
-		ant_det_fail_count++;
+		/* RF 0x1[0] = 0->Set GNT_WL_RF_Rx always = 1 for con-current Rx */
+		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x1, 0x0);
 
-	psd_scan->ant_det_fail_count = ant_det_fail_count;
+		/* Path config	 */
+		halbtc8723d2ant_set_ant_path(btcoexist,
+					     BTC_ANT_PATH_AUTO,
+					     FORCE_EXEC,
+					     BT_8723D_2ANT_PHASE_COEX_INIT);
 
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx AntennaDetect(), result = %d, fail_count = %d, finish = %s\n",
-		    psd_scan->ant_det_result,
-		    psd_scan->ant_det_fail_count,
-		    ant_det_finish == TRUE ? "Yes" : "No");
-	BTC_TRACE(trace_buf);
+		btcoexist->stop_coex_dm = FALSE;
+	}
 
-	return ant_det_finish;
+	halbtc8723d2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
 
+	halbtc8723d2ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
 }
 
+#ifdef PLATFORM_WINDOWS
+#pragma optimize("", off)
+#endif
 
 /* ************************************************************
  * work around function start with wa_halbtc8723d2ant_
@@ -5834,6 +4541,8 @@ void ex_halbtc8723d2ant_power_on_setting(IN struct btc_coexist *btcoexist)
 	/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
 	halbtc8723d2ant_enable_gnt_to_gpio(btcoexist, TRUE);
 
+#if BT_8723D_2ANT_COEX_DBG
+
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 		"[BTCoex], **********  LTE coex Reg 0x38 (Power-On) = 0x%x**********\n",
 		    halbtc8723d2ant_ltecoex_indirect_read_reg(btcoexist, 0x38));
@@ -5844,6 +4553,8 @@ void ex_halbtc8723d2ant_power_on_setting(IN struct btc_coexist *btcoexist)
 		    btcoexist->btc_read_4byte(btcoexist, 0x70),
 		    btcoexist->btc_read_2byte(btcoexist, 0x948));
 	BTC_TRACE(trace_buf);
+
+#endif
 }
 
 void ex_halbtc8723d2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
@@ -5907,7 +4618,7 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	boolean			lte_coex_on = FALSE;
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
+		   "\r\n ============[BT Coexist info 8723D]============");
 	CL_PRINTF(cli_buf);
 
 	if (btcoexist->manual_control) {
@@ -5956,10 +4667,13 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	}
 
 	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s",
+		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %s/ %s",
 			   "Ant PG Num/ Mech/ Pos",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == 1 ? "S1" : "S0"));
+			   board_info->pg_ant_num,
+			   (board_info->btdm_ant_num == 1 ?
+			   "Shared" : "Non-Shared"),
+			   (board_info->btdm_ant_pos == 1 ?
+			   "S1" : "S0"));
 		CL_PRINTF(cli_buf);
 	} else {
 		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
@@ -6022,7 +4736,7 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
 		   "W_FW/ B_FW/ Phy/ Kt",
 		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
+		   coex_sta->kt_ver + 65);
 	CL_PRINTF(cli_buf);
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
@@ -6091,21 +4805,13 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 
 
 	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			   "A2DP Rate/Bitpool/Auto_Slot",
-			   ((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
+		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
+			   "\r\n %-35s = %s/ %d/ 0x%x/ 0x%x",
+			   "CQDDR/Bitpool/V_ID/D_name",
+			   ((coex_sta->is_A2DP_3M) ? "On" : "Off"),
 			   coex_sta->a2dp_bit_pool,
-			   ((coex_sta->is_autoslot) ? "On" : "Off")
-			  );
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ %d/ %d",
-			   "V_ID/D_name/FBSlot_Legacy/FBSlot_Le",
 			   coex_sta->bt_a2dp_vendor_id,
-			   coex_sta->bt_a2dp_device_name,
-			   coex_sta->legacy_forbidden_slot,
-			   coex_sta->le_forbidden_slot
-			  );
+			   coex_sta->bt_a2dp_device_name);
 		CL_PRINTF(cli_buf);
 	}
 
@@ -6120,7 +4826,7 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
 				"Role/RoleSwCnt/IgnWlact/Feature",
 				((bt_link_info->slave_role) ? "Slave" : "Master"),
-				coex_sta->cnt_RoleSwitch,
+				coex_sta->cnt_roleswitch,
 				((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
 				coex_sta->bt_coex_supported_feature);
 	CL_PRINTF(cli_buf);
@@ -6141,12 +4847,11 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
 		   "ReInit/ReLink/IgnWlact/Page/NameReq",
-		   coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-		   coex_sta->cnt_IgnWlanAct,
-		   coex_sta->cnt_Page,
-		   coex_sta->cnt_RemoteNameReq
-		  );
+		   coex_sta->cnt_reinit,
+		   coex_sta->cnt_setuplink,
+		   coex_sta->cnt_ignwlanact,
+		   coex_sta->cnt_page,
+		   coex_sta->cnt_remotenamereq);
 	CL_PRINTF(cli_buf);
 
 	halbtc8723d2ant_read_score_board(btcoexist,	&u16tmp[0]);
@@ -6159,7 +4864,7 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
 			   "\r\n %-35s = 0x%x/ 0x%x/ 0x%04x",
 			   "0xae[4]/0xac[1:0]/Scoreboard(B->W)",
-			   ((unsigned int)(coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
+			   (int)((coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
 			   coex_sta->bt_reg_vendor_ac & 0x3, u16tmp[0]);
 	CL_PRINTF(cli_buf);
 
@@ -6256,6 +4961,12 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		   coex_sta->wl_fw_dbg_info[5]);
 	CL_PRINTF(cli_buf);
 
+	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s",
+		   "TDMA_Togg_cnt/WL5ms_cnt/WL5ms_off",
+		   coex_sta->wl_fw_dbg_info[6], coex_sta->wl_fw_dbg_info[7],
+		   ((coex_sta->is_no_wl_5ms_extend) ? "Yes" : "No"));
+	CL_PRINTF(cli_buf);
+
 	u32tmp[0] = halbtc8723d2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
 	lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ?  TRUE : FALSE;
 
@@ -6293,16 +5004,7 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
 		   "============[Hw setting]============");
 	CL_PRINTF(cli_buf);
-	/*
-		u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
-		u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
-		u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
-		u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x456);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-			   "0x430/0x434/0x42a/0x456",
-			   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0]);
-		CL_PRINTF(cli_buf);
-	*/
+
 	u32tmp[0] = halbtc8723d2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
 	u32tmp[1] = halbtc8723d2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
 	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x73);
@@ -6333,7 +5035,7 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 			   "\r\n %-35s = %s (BB:%s)/ %s (BB:%s)/ %s (gnt_err = %d)",
 			   "GNT_WL_Ctrl/GNT_BT_Ctrl/Dbg",
 			   ((u32tmp[0] & BIT(12)) ? "SW" : "HW"),
-			   ((u32tmp[0] & BIT(8)) ?	"SW" : "HW"),
+			   ((u32tmp[0] & BIT(8)) ? "SW" : "HW"),
 			   ((u32tmp[0] & BIT(14)) ? "SW" : "HW"),
 			   ((u32tmp[0] & BIT(10)) ?  "SW" : "HW"),
 			   ((u8tmp[0] & BIT(3)) ? "On" : "Off"),
@@ -6369,16 +5071,25 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 		   (int)((u8tmp[3] & BIT(7)) >> 7));
 	CL_PRINTF(cli_buf);
 
+	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
+	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
+	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
+	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x426);
+	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x45e);
+	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
+		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x/ 0x%x",
+		   "0x430/0x434/0x42a/0x426/0x45e[3]",
+		   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0],
+		   (int)((u8tmp[1] & BIT(3)) >> 3));
+	CL_PRINTF(cli_buf);
 
 	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x45e);
+	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x40);
 
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x4c6[4]/0x40[5]/0x45e[3](TxRetry)",
+	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
+		   "\r\n %-35s = 0x%x/ 0x%x", "0x4c6[4]/0x40[5]",
 		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5),
-		   (int)((u8tmp[2] & BIT(3)) >> 3));
+		   (int)((u16tmp[0] & BIT(5)) >> 5));
 	CL_PRINTF(cli_buf);
 
 	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
@@ -6424,7 +5135,7 @@ void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
 		   "0x770(Hi-pri rx/tx)",
 		   coex_sta->high_priority_rx, coex_sta->high_priority_tx,
-		   (coex_sta->is_hiPri_rx_overhead ? "(scan overhead!!)" : ""));
+		   (coex_sta->is_hipri_rx_overhead ? "(scan overhead!!)" : ""));
 	CL_PRINTF(cli_buf);
 
 	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
@@ -6617,6 +5328,7 @@ void ex_halbtc8723d2ant_connect_notify(IN struct btc_coexist *btcoexist,
 		coex_sta->freeze_coexrun_by_btinfo = TRUE;
 
 		coex_dm->arp_cnt = 0;
+		coex_sta->connect_ap_period_cnt = 2;
 
 	} else if (BTC_ASSOCIATE_FINISH == type) {
 
@@ -6744,13 +5456,14 @@ void ex_halbtc8723d2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
 void ex_halbtc8723d2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 				       IN u8 *tmp_buf, IN u8 length)
 {
-	u8			i, rsp_source = 0;
-	boolean		wifi_connected = FALSE;
+	struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
+	u8 i, rsp_source = 0;
+	boolean	wifi_connected = FALSE;
 	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE,
-		    wifi_busy = FALSE;
+		wifi_busy = FALSE;
 	static boolean is_scoreboard_scan = FALSE;
 
-	if (psd_scan->is_AntDet_running == TRUE) {
+	if (psd_scan->is_antdet_running) {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			"[BTCoex], bt_info_notify return for AntDet is running\n");
 		BTC_TRACE(trace_buf);
@@ -6817,7 +5530,7 @@ void ex_halbtc8723d2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 
 		coex_sta->a2dp_bit_pool = (((
 			coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) ?
-				   (coex_sta->bt_info_c2h[rsp_source][6] & 0x7f) : 0);
+			(coex_sta->bt_info_c2h[rsp_source][6] & 0x7f) : 0);
 
 		coex_sta->is_bt_a2dp_sink = (coex_sta->bt_info_c2h[rsp_source][6] & 0x80) ?
 									TRUE : FALSE;
@@ -6825,7 +5538,7 @@ void ex_halbtc8723d2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 		coex_sta->bt_retry_cnt = coex_sta->bt_info_c2h[rsp_source][2] &
 					 0xf;
 
-		coex_sta->is_autoslot = coex_sta->bt_info_ext2 & 0x8;
+		bt_link_info->slave_role  = coex_sta->bt_info_ext2 & 0x8;
 
 		coex_sta->forbidden_slot = coex_sta->bt_info_ext2 & 0x7;
 
@@ -6839,31 +5552,27 @@ void ex_halbtc8723d2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 			coex_sta->pop_event_cnt++;
 
 		if (coex_sta->c2h_bt_remote_name_req)
-			coex_sta->cnt_RemoteNameReq++;
+			coex_sta->cnt_remotenamereq++;
 
 		if (coex_sta->bt_info_ext & BIT(1))
-			coex_sta->cnt_ReInit++;
+			coex_sta->cnt_reinit++;
 
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setupLink++;
-			coex_sta->is_setupLink = TRUE;
+		if (coex_sta->bt_info_ext & BIT(2) ||
+		    (coex_sta->bt_create_connection &&
+		    coex_sta->pnp_awake_period_cnt > 0)) {
+			coex_sta->cnt_setuplink++;
+			coex_sta->is_setup_link = TRUE;
 			coex_sta->bt_relink_downcount = 2;
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				    "[BTCoex], Re-Link start in BT info!!\n");
 			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->is_setupLink = FALSE;
-			coex_sta->bt_relink_downcount = 0;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link stop in BT info!!\n");
-			BTC_TRACE(trace_buf);
 		}
 
 		if (coex_sta->bt_info_ext & BIT(3))
-			coex_sta->cnt_IgnWlanAct++;
+			coex_sta->cnt_ignwlanact++;
 
 		if (coex_sta->bt_info_ext & BIT(6))
-			coex_sta->cnt_RoleSwitch++;
+			coex_sta->cnt_roleswitch++;
 
 		if (coex_sta->bt_info_ext & BIT(7))
 			coex_sta->is_bt_multi_link = TRUE;
@@ -6876,12 +5585,12 @@ void ex_halbtc8723d2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
 			coex_sta->is_hid_rcu = FALSE;
 
 		if (coex_sta->bt_info_ext & BIT(5))
-			coex_sta->is_ble_scan_toggle = TRUE;
+			coex_sta->is_ble_scan_en = TRUE;
 		else
-			coex_sta->is_ble_scan_toggle = FALSE;
+			coex_sta->is_ble_scan_en = FALSE;
 
 		if (coex_sta->bt_create_connection) {
-			coex_sta->cnt_Page++;
+			coex_sta->cnt_page++;
 
 			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY,
 					   &wifi_busy);
@@ -6967,27 +5676,62 @@ void ex_halbtc8723d2ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
 				       IN u8 *tmp_buf, IN u8 length)
 {
 	u8 i = 0;
-	static u8 tmp_buf_pre[10] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
+	static u8 tmp_buf_pre[10], cnt;
+	u8 h2c_parameter[2] = {0};
 
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d (len = %d)\n",
-				tmp_buf[0], tmp_buf[1],
-				tmp_buf[2], tmp_buf[3],
-				tmp_buf[4], tmp_buf[5], length);
+		    "[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d %d %d (len = %d)\n",
+		    tmp_buf[0], tmp_buf[1], tmp_buf[2], tmp_buf[3], tmp_buf[4],
+		    tmp_buf[5], tmp_buf[6], tmp_buf[7], length);
 	BTC_TRACE(trace_buf);
 
 	if (tmp_buf[0] == 0x8) {
-		for (i = 1; i <= 5; i++) {
+		for (i = 1; i <= 7; i++) {
 			coex_sta->wl_fw_dbg_info[i] =
 				(tmp_buf[i] >= tmp_buf_pre[i]) ?
-				(tmp_buf[i] - tmp_buf_pre[i]) :
-				(255 - tmp_buf_pre[i] + tmp_buf[i]);
+					(tmp_buf[i] - tmp_buf_pre[i]) :
+					(255 - tmp_buf_pre[i] + tmp_buf[i]);
 
 			tmp_buf_pre[i] = tmp_buf[i];
 		}
 	}
-}
 
+	if (!coex_sta->is_no_wl_5ms_extend && coex_sta->force_lps_ctrl &&
+	    !coex_sta->cck_lock_ever) {
+		if (coex_sta->wl_fw_dbg_info[7] <= 5)
+			cnt++;
+		else
+			cnt = 0;
+
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			    "[BTCoex], 5ms WL slot extend cnt = %d!!\n", cnt);
+		BTC_TRACE(trace_buf);
+
+		if (cnt == 7) {
+			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+				    "[BTCoex], set h2c 0x69 opcode 12 to turn off 5ms WL slot extend!!\n");
+			BTC_TRACE(trace_buf);
+
+			h2c_parameter[0] = 0xc;
+			h2c_parameter[1] = 0x1;
+			btcoexist->btc_fill_h2c(btcoexist, 0x69, 2,
+						h2c_parameter);
+			coex_sta->is_no_wl_5ms_extend = TRUE;
+			cnt = 0;
+		}
+	}
+
+	if (coex_sta->is_no_wl_5ms_extend && coex_sta->cck_lock) {
+		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+			    "[BTCoex], set h2c 0x69 opcode 12 to turn on 5ms WL slot extend!!\n");
+		BTC_TRACE(trace_buf);
+
+		h2c_parameter[0] = 0xc;
+		h2c_parameter[1] = 0x0;
+		btcoexist->btc_fill_h2c(btcoexist, 0x69, 2, h2c_parameter);
+		coex_sta->is_no_wl_5ms_extend = FALSE;
+	}
+}
 
 void ex_halbtc8723d2ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
 		IN BOOLEAN is_data_frame, IN u8 btc_rate_id)
@@ -7013,24 +5757,24 @@ void ex_halbtc8723d2ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
 		BTC_TRACE(trace_buf);
 	}
 
-	if ((wifi_connected) &&
-		((coex_dm->bt_status ==  BT_8723D_2ANT_BT_STATUS_ACL_BUSY) ||
-		(coex_dm->bt_status ==  BT_8723D_2ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		(coex_dm->bt_status == BT_8723D_2ANT_BT_STATUS_SCO_BUSY))) {
+	if (wifi_connected &&
+	    (coex_dm->bt_status ==  BT_8723D_2ANT_BT_STATUS_ACL_BUSY ||
+	     coex_dm->bt_status ==  BT_8723D_2ANT_BT_STATUS_ACL_SCO_BUSY ||
+	     coex_dm->bt_status == BT_8723D_2ANT_BT_STATUS_SCO_BUSY)) {
 
-		if ((coex_sta->wl_rx_rate == BTC_CCK_5_5) ||
-			(coex_sta->wl_rx_rate == BTC_OFDM_6) ||
-			(coex_sta->wl_rx_rate == BTC_MCS_0)) {
+		if (coex_sta->wl_rx_rate == BTC_CCK_5_5 ||
+		    coex_sta->wl_rx_rate == BTC_OFDM_6 ||
+		    coex_sta->wl_rx_rate == BTC_MCS_0) {
 
 			coex_sta->cck_lock_warn = TRUE;
 
 			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 				"[BTCoex], cck lock warning...\n");
 			BTC_TRACE(trace_buf);
-		} else if ((coex_sta->wl_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rx_rate == BTC_CCK_2) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_2)) {
+		} else if (coex_sta->wl_rx_rate == BTC_CCK_1 ||
+			   coex_sta->wl_rx_rate == BTC_CCK_2 ||
+			   coex_sta->wl_rts_rx_rate == BTC_CCK_1 ||
+			   coex_sta->wl_rts_rx_rate == BTC_CCK_2) {
 
 			coex_sta->cck_lock = TRUE;
 			coex_sta->cck_lock_ever = TRUE;
@@ -7047,10 +5791,10 @@ void ex_halbtc8723d2ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
 			BTC_TRACE(trace_buf);
 		}
 	} else {
-		if ((coex_dm->bt_status ==
-			BT_8723D_2ANT_BT_STATUS_CONNECTED_IDLE) ||
-			(coex_dm->bt_status ==
-			BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE)) {
+		if (coex_dm->bt_status ==
+		    BT_8723D_2ANT_BT_STATUS_CONNECTED_IDLE ||
+		    coex_dm->bt_status ==
+		    BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE) {
 			coex_sta->cck_lock_warn = FALSE;
 			coex_sta->cck_lock = FALSE;
 		}
@@ -7128,6 +5872,8 @@ void ex_halbtc8723d2ant_halt_notify(IN struct btc_coexist *btcoexist)
 void ex_halbtc8723d2ant_pnp_notify(IN struct btc_coexist *btcoexist,
 				   IN u8 pnp_state)
 {
+	static u8 pre_pnp_state;
+
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
 	BTC_TRACE(trace_buf);
 
@@ -7162,11 +5908,23 @@ void ex_halbtc8723d2ant_pnp_notify(IN struct btc_coexist *btcoexist,
 					     BT_8723D_2ANT_PHASE_WLAN_OFF);
 		}
 
+		btcoexist->stop_coex_dm = TRUE;
 
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
+	} else {
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 			    "[BTCoex], Pnp notify to WAKE UP\n");
 		BTC_TRACE(trace_buf);
+
+		coex_sta->pnp_awake_period_cnt = 3;
+
+		/*WoWLAN*/
+		if (pre_pnp_state == BTC_WIFI_PNP_SLEEP_KEEP_ANT ||
+		    pnp_state == BTC_WIFI_PNP_WOWLAN) {
+			coex_sta->run_time_state = TRUE;
+			btcoexist->stop_coex_dm = FALSE;
+			halbtc8723d2ant_run_coexist_mechanism(btcoexist);
+		}
+
 #if 0
 		halbtc8723d2ant_post_state_to_bt(btcoexist,
 					BT_8723D_2ANT_SCOREBOARD_ACTIVE, TRUE);
@@ -7174,6 +5932,8 @@ void ex_halbtc8723d2ant_pnp_notify(IN struct btc_coexist *btcoexist,
 					BT_8723D_2ANT_SCOREBOARD_ONOFF, TRUE);
 #endif
 	}
+
+	pre_pnp_state = pnp_state;
 }
 
 void ex_halbtc8723d2ant_periodical(IN struct btc_coexist *btcoexist)
@@ -7224,11 +5984,23 @@ void ex_halbtc8723d2ant_periodical(IN struct btc_coexist *btcoexist)
 		coex_sta->bt_relink_downcount--;
 
 		if (coex_sta->bt_relink_downcount == 0) {
-			coex_sta->is_setupLink = FALSE;
+			coex_sta->is_setup_link = FALSE;
 			bt_relink_finish = TRUE;
 		}
 	}
 
+	if (coex_sta->pnp_awake_period_cnt > 0)
+		coex_sta->pnp_awake_period_cnt--;
+
+	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
+		    "[BTCoex], pnp_awake_period_cnt = %d\n",
+				coex_sta->pnp_awake_period_cnt);
+	BTC_TRACE(trace_buf);
+
+	/*for A2DP glitch during connecting AP*/
+	if (coex_sta->connect_ap_period_cnt > 0)
+		coex_sta->connect_ap_period_cnt--;
+
 	/* for 4-way, DHCP, EAPOL packet */
 	if (coex_sta->specific_pkt_period_cnt > 0) {
 
@@ -7239,31 +6011,27 @@ void ex_halbtc8723d2ant_periodical(IN struct btc_coexist *btcoexist)
 			coex_sta->wifi_is_high_pri_task = FALSE;
 
 		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ***************** Hi-Pri Task = %s*****************\n",
-			    (coex_sta->wifi_is_high_pri_task ? "Yes" :
-			     "No"));
+			   "[BTCoex], ***************** Hi-Pri Task = %s\n",
+			    (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"));
 		BTC_TRACE(trace_buf);
 
 	}
 
 	if (!coex_sta->bt_disabled) {
-
-#if BT_8723D_2ANT_ANTDET_ENABLE
-
+#if 0
 		if (board_info->btdm_ant_det_finish) {
-			if ((psd_scan->ant_det_result == 12) &&
-			    (psd_scan->ant_det_psd_scan_peak_val == 0)
-			    && (!psd_scan->is_AntDet_running))
+			if (psd_scan->ant_det_result == 12 &&
+			    psd_scan->ant_det_psd_scan_peak_val == 0 &&
+			    !psd_scan->is_antdet_running)
 				psd_scan->ant_det_psd_scan_peak_val =
 					btcoexist->btc_get_ant_det_val_from_bt(
 						btcoexist) * 100;
 		}
-
 #endif
 	}
 
-
-	if (halbtc8723d2ant_is_wifibt_status_changed(btcoexist) || (bt_relink_finish))
+	if (halbtc8723d2ant_is_wifibt_status_changed(btcoexist) ||
+	    bt_relink_finish)
 		halbtc8723d2ant_run_coexist_mechanism(btcoexist);
 }
 
@@ -7283,11 +6051,9 @@ void ex_halbtc8723d2ant_set_antenna_notify(IN struct btc_coexist *btcoexist,
 					     BT_8723D_2ANT_PHASE_2G_RUNTIME);
 
 	} else { /* one antenna */
-
 		halbtc8723d2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
 					     FORCE_EXEC,
 					     BT_8723D_2ANT_PHASE_2G_RUNTIME);
-
 	}
 }
 
@@ -7306,142 +6072,12 @@ void ex_halbtc8723d2ant_antenna_detection(IN struct btc_coexist *btcoexist,
 	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
 		    "xxxxxxxxxxxxxxxx Ext Call AntennaDetect()!!\n");
 	BTC_TRACE(trace_buf);
-
-#if BT_8723D_2ANT_ANTDET_ENABLE
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "xxxxxxxxxxxxxxxx Call AntennaDetect()!!\n");
-	BTC_TRACE(trace_buf);
-
-	if (seconds == 0) {
-		psd_scan->ant_det_try_count	= 0;
-		psd_scan->ant_det_fail_count	= 0;
-		ant_det_count = 0;
-		ant_det_fail_count = 0;
-		board_info->btdm_ant_det_finish = FALSE;
-		board_info->btdm_ant_num_by_ant_det = 1;
-		return;
-	}
-
-	if (!board_info->btdm_ant_det_finish) {
-		psd_scan->ant_det_inteval_count =
-			psd_scan->ant_det_inteval_count + 2;
-
-		if (psd_scan->ant_det_inteval_count >=
-		    BT_8723D_2ANT_ANTDET_RETRY_INTERVAL) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is up, Try Detect!!\n");
-			BTC_TRACE(trace_buf);
-
-			psd_scan->is_AntDet_running = TRUE;
-
-			halbtc8723d2ant_read_score_board(btcoexist,	&u16tmp);
-
-			if (u16tmp & BIT(
-				2)) { /* Antenna detection is already done before last WL power on   */
-				board_info->btdm_ant_det_finish = TRUE;
-				psd_scan->ant_det_try_count = 1;
-				psd_scan->ant_det_fail_count = 0;
-				board_info->btdm_ant_num_by_ant_det = (u16tmp &
-							       BIT(3)) ? 1 : 2;
-				psd_scan->ant_det_result = 12;
-
-				psd_scan->ant_det_psd_scan_peak_val =
-					btcoexist->btc_get_ant_det_val_from_bt(
-						btcoexist) * 100;
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Result from BT (%d-Ant)\n",
-					board_info->btdm_ant_num_by_ant_det);
-				BTC_TRACE(trace_buf);
-			} else
-				board_info->btdm_ant_det_finish =
-					halbtc8723d2ant_psd_antenna_detection_check(
-						btcoexist);
-
-			btcoexist->bdontenterLPS = FALSE;
-
-			if (board_info->btdm_ant_det_finish) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Success!!\n");
-				BTC_TRACE(trace_buf);
-
-				/*for 8723d, btc_set_bt_trx_mask is just used to
-					notify BT stop le tx and Ant Det Result , not set BT RF TRx Mask  */
-				if (psd_scan->ant_det_result != 12) {
-
-					AntDetval = (u8)(
-						psd_scan->ant_det_psd_scan_peak_val
-							    / 100) & 0x7f;
-
-					AntDetval =
-						(board_info->btdm_ant_num_by_ant_det
-						 == 1) ? (AntDetval | 0x80) :
-						AntDetval;
-
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"xxxxxx AntennaDetect(), Ant Count = %d, PSD Val = %d\n",
-						    ((AntDetval &
-						      0x80) ? 1
-						     : 2), AntDetval
-						    & 0x7f);
-					BTC_TRACE(trace_buf);
-
-					if (btcoexist->btc_set_bt_trx_mask(
-						    btcoexist, AntDetval))
-						BTC_SPRINTF(trace_buf,
-							    BT_TMP_BUF_SIZE,
-							"xxxxxx AntennaDetect(), Notify BT stop le tx by set_bt_trx_mask ok!\n");
-					else
-						BTC_SPRINTF(trace_buf,
-							    BT_TMP_BUF_SIZE,
-							"xxxxxx AntennaDetect(), Notify BT stop le tx by set_bt_trx_mask fail!\n");
-
-					BTC_TRACE(trace_buf);
-				} else
-					board_info->antdetval =
-						psd_scan->ant_det_psd_scan_peak_val/100;
-				
-				board_info->btdm_ant_det_complete_fail = FALSE;
-
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Fail!!\n");
-				BTC_TRACE(trace_buf);
-			}
-
-			psd_scan->ant_det_inteval_count = 0;
-			psd_scan->is_AntDet_running = FALSE;
-
-			/* stimulate coex running */
-			halbtc8723d2ant_run_coexist_mechanism(
-				btcoexist);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Stimulate Coex running\n!!");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"xxxxxxxxxxxxxxxx AntennaDetect(), Antenna Det Timer is not up! (%d)\n",
-				    psd_scan->ant_det_inteval_count);
-			BTC_TRACE(trace_buf);
-
-			if (psd_scan->ant_det_inteval_count == 8)
-				btcoexist->bdontenterLPS = TRUE;
-			else
-				btcoexist->bdontenterLPS = FALSE;
-		}
-
-	}
-#endif
-
-
 }
 
 
 void ex_halbtc8723d2ant_display_ant_detection(IN struct btc_coexist *btcoexist)
 {
-
-#if BT_8723D_2ANT_ANTDET_ENABLE
+#if 0
 	struct  btc_board_info	*board_info = &btcoexist->board_info;
 
 	if (psd_scan->ant_det_try_count != 0)	{
@@ -7451,7 +6087,6 @@ void ex_halbtc8723d2ant_display_ant_detection(IN struct btc_coexist *btcoexist)
 			halbtc8723d2ant_psd_showdata(btcoexist);
 	}
 #endif
-
 }
 
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.h
index 9075bb83a6c0..1bf37d123547 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723d2ant.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -25,9 +26,9 @@
 #define	BT_AUTO_REPORT_ONLY_8723D_2ANT				1
 
 
-#define	BT_INFO_8723D_2ANT_B_FTP						BIT(7)
-#define	BT_INFO_8723D_2ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8723D_2ANT_B_HID						BIT(5)
+#define	BT_INFO_8723D_2ANT_B_FTP				BIT(7)
+#define	BT_INFO_8723D_2ANT_B_A2DP				BIT(6)
+#define	BT_INFO_8723D_2ANT_B_HID				BIT(5)
 #define	BT_INFO_8723D_2ANT_B_SCO_BUSY				BIT(4)
 #define	BT_INFO_8723D_2ANT_B_ACL_BUSY				BIT(3)
 #define	BT_INFO_8723D_2ANT_B_INQ_PAGE				BIT(2)
@@ -37,128 +38,129 @@
 #define		BTC_RSSI_COEX_THRESH_TOL_8723D_2ANT		2
 
 
-#define	BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES1				80  /* unit: % WiFi RSSI Threshold for   2-Ant free-run/2-Ant TDMA translation, default = 42 */
-#define	BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES1				80 /*  unit: % BT RSSI Threshold for      2-Ant free-run/2-Ant TDMA translation, default = 46 */
-#define	BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES2				80  /* unit: % WiFi RSSI Threshold for   1-Ant TDMA/1-Ant PS-TDMA translation, default = 42 */
-#define	BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES2				80 /*  unit: % BT RSSI Threshold for      1-Ant TDMA/1-Ant PS-TDMA translation, default = 46 */
-#define	BT_8723D_2ANT_DEFAULT_ISOLATION						15	 /*  unit: dB */
-#define   BT_8723D_2ANT_WIFI_MAX_TX_POWER						15	 /*  unit: dBm */
-#define   BT_8723D_2ANT_BT_MAX_TX_POWER							3	 /*  unit: dBm */
-#define   BT_8723D_2ANT_WIFI_SIR_THRES1							-15  /*  unit: dB */
-#define   BT_8723D_2ANT_WIFI_SIR_THRES2							-30  /*  unit: dB */
-#define   BT_8723D_2ANT_BT_SIR_THRES1							-15		 /*  unit: dB */
-#define   BT_8723D_2ANT_BT_SIR_THRES2							-30		 /*  unit: dB */
+#define	BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES1		80
+#define	BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES1			80
+#define	BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES2		80
+#define	BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES2			80
+#define	BT_8723D_2ANT_DEFAULT_ISOLATION				15
+#define   BT_8723D_2ANT_WIFI_MAX_TX_POWER				15
+#define   BT_8723D_2ANT_BT_MAX_TX_POWER				3
+#define   BT_8723D_2ANT_WIFI_SIR_THRES1				-15
+#define   BT_8723D_2ANT_WIFI_SIR_THRES2				-30
+#define   BT_8723D_2ANT_BT_SIR_THRES1				-15
+#define   BT_8723D_2ANT_BT_SIR_THRES2				-30
 
 
 /* for Antenna detection */
-#define	BT_8723D_2ANT_ANTDET_PSDTHRES_BACKGROUND						50
-#define	BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			52
-#define	BT_8723D_2ANT_ANTDET_PSDTHRES_1ANT							40
-#define	BT_8723D_2ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8723D_2ANT_ANTDET_SWEEPPOINT_DELAY							60000
-#define	BT_8723D_2ANT_ANTDET_ENABLE										1
-#define	BT_8723D_2ANT_ANTDET_BTTXTIME									100
-#define	BT_8723D_2ANT_ANTDET_BTTXCHANNEL								39
-#define	BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT						50
+#define	BT_8723D_2ANT_ANTDET_PSDTHRES_BACKGROUND		50
+#define	BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION		70
+#define	BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	52
+#define	BT_8723D_2ANT_ANTDET_PSDTHRES_1ANT			40
+#define	BT_8723D_2ANT_ANTDET_RETRY_INTERVAL			10
+#define	BT_8723D_2ANT_ANTDET_SWEEPPOINT_DELAY			60000
+#define	BT_8723D_2ANT_ANTDET_ENABLE				0
+#define	BT_8723D_2ANT_ANTDET_BTTXTIME				100
+#define	BT_8723D_2ANT_ANTDET_BTTXCHANNEL			39
+#define	BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT			50
 
 
-#define	BT_8723D_2ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
+#define	BT_8723D_2ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT	30000
 
 enum bt_8723d_2ant_signal_state {
-	BT_8723D_2ANT_SIG_STA_SET_TO_LOW		= 0x0,
+	BT_8723D_2ANT_SIG_STA_SET_TO_LOW	= 0x0,
 	BT_8723D_2ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8723D_2ANT_SIG_STA_SET_TO_HIGH		= 0x1,
+	BT_8723D_2ANT_SIG_STA_SET_TO_HIGH	= 0x1,
 	BT_8723D_2ANT_SIG_STA_MAX
 };
 
 enum bt_8723d_2ant_path_ctrl_owner {
 	BT_8723D_2ANT_PCO_BTSIDE		= 0x0,
-	BT_8723D_2ANT_PCO_WLSIDE	= 0x1,
+	BT_8723D_2ANT_PCO_WLSIDE		= 0x1,
 	BT_8723D_2ANT_PCO_MAX
 };
 
 enum bt_8723d_2ant_gnt_ctrl_type {
-	BT_8723D_2ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,
-	BT_8723D_2ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,
+	BT_8723D_2ANT_GNT_TYPE_CTRL_BY_PTA	= 0x0,
+	BT_8723D_2ANT_GNT_TYPE_CTRL_BY_SW	= 0x1,
 	BT_8723D_2ANT_GNT_TYPE_MAX
 };
 
 enum bt_8723d_2ant_gnt_ctrl_block {
 	BT_8723D_2ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8723D_2ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8723D_2ANT_GNT_BLOCK_BB			= 0x2,
+	BT_8723D_2ANT_GNT_BLOCK_RFC		= 0x1,
+	BT_8723D_2ANT_GNT_BLOCK_BB		= 0x2,
 	BT_8723D_2ANT_GNT_BLOCK_MAX
 };
 
 enum bt_8723d_2ant_lte_coex_table_type {
-	BT_8723D_2ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8723D_2ANT_CTT_BT_VS_LTE			= 0x1,
+	BT_8723D_2ANT_CTT_WL_VS_LTE		= 0x0,
+	BT_8723D_2ANT_CTT_BT_VS_LTE		= 0x1,
 	BT_8723D_2ANT_CTT_MAX
 };
 
 enum bt_8723d_2ant_lte_break_table_type {
-	BT_8723D_2ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8723D_2ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8723D_2ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8723D_2ANT_LBTT_LTE_BREAK_BT				= 0x3,
+	BT_8723D_2ANT_LBTT_WL_BREAK_LTE		= 0x0,
+	BT_8723D_2ANT_LBTT_BT_BREAK_LTE		= 0x1,
+	BT_8723D_2ANT_LBTT_LTE_BREAK_WL		= 0x2,
+	BT_8723D_2ANT_LBTT_LTE_BREAK_BT		= 0x3,
 	BT_8723D_2ANT_LBTT_MAX
 };
 
 enum bt_info_src_8723d_2ant {
-	BT_INFO_SRC_8723D_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8723D_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8723D_2ANT_BT_ACTIVE_SEND		= 0x2,
+	BT_INFO_SRC_8723D_2ANT_WIFI_FW		= 0x0,
+	BT_INFO_SRC_8723D_2ANT_BT_RSP		= 0x1,
+	BT_INFO_SRC_8723D_2ANT_BT_ACTIVE_SEND	= 0x2,
 	BT_INFO_SRC_8723D_2ANT_MAX
 };
 
 enum bt_8723d_2ant_bt_status {
 	BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
 	BT_8723D_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8723D_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8723D_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8723D_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8723D_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
+	BT_8723D_2ANT_BT_STATUS_INQ_PAGE		= 0x2,
+	BT_8723D_2ANT_BT_STATUS_ACL_BUSY		= 0x3,
+	BT_8723D_2ANT_BT_STATUS_SCO_BUSY		= 0x4,
+	BT_8723D_2ANT_BT_STATUS_ACL_SCO_BUSY		= 0x5,
 	BT_8723D_2ANT_BT_STATUS_MAX
 };
 
 enum bt_8723d_2ant_coex_algo {
-	BT_8723D_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8723D_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8723D_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8723D_2ANT_COEX_ALGO_A2DP				= 0x3,
+	BT_8723D_2ANT_COEX_ALGO_UNDEFINED		= 0x0,
+	BT_8723D_2ANT_COEX_ALGO_SCO			= 0x1,
+	BT_8723D_2ANT_COEX_ALGO_HID			= 0x2,
+	BT_8723D_2ANT_COEX_ALGO_A2DP			= 0x3,
 	BT_8723D_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
 	BT_8723D_2ANT_COEX_ALGO_PANEDR			= 0x5,
 	BT_8723D_2ANT_COEX_ALGO_PANHS			= 0x6,
 	BT_8723D_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
 	BT_8723D_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8723D_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8723D_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
+	BT_8723D_2ANT_COEX_ALGO_HID_A2DP_PANEDR		= 0x9,
+	BT_8723D_2ANT_COEX_ALGO_HID_A2DP		= 0xa,
 	BT_8723D_2ANT_COEX_ALGO_NOPROFILEBUSY		= 0xb,
 	BT_8723D_2ANT_COEX_ALGO_A2DPSINK		= 0xc,
 	BT_8723D_2ANT_COEX_ALGO_MAX
 };
 
 enum bt_8723d_2ant_phase {
-	BT_8723D_2ANT_PHASE_COEX_INIT								= 0x0,
-	BT_8723D_2ANT_PHASE_WLANONLY_INIT							= 0x1,
-	BT_8723D_2ANT_PHASE_WLAN_OFF								= 0x2,
-	BT_8723D_2ANT_PHASE_2G_RUNTIME								= 0x3,
-	BT_8723D_2ANT_PHASE_5G_RUNTIME								= 0x4,
-	BT_8723D_2ANT_PHASE_BTMPMODE								= 0x5,
-	BT_8723D_2ANT_PHASE_ANTENNA_DET								= 0x6,
-	BT_8723D_2ANT_PHASE_COEX_POWERON							= 0x7,
-	BT_8723D_2ANT_PHASE_2G_FREERUN								= 0x8,
+	BT_8723D_2ANT_PHASE_COEX_INIT			= 0x0,
+	BT_8723D_2ANT_PHASE_WLANONLY_INIT		= 0x1,
+	BT_8723D_2ANT_PHASE_WLAN_OFF			= 0x2,
+	BT_8723D_2ANT_PHASE_2G_RUNTIME			= 0x3,
+	BT_8723D_2ANT_PHASE_5G_RUNTIME			= 0x4,
+	BT_8723D_2ANT_PHASE_BTMPMODE			= 0x5,
+	BT_8723D_2ANT_PHASE_ANTENNA_DET			= 0x6,
+	BT_8723D_2ANT_PHASE_COEX_POWERON		= 0x7,
+	BT_8723D_2ANT_PHASE_2G_FREERUN			= 0x8,
 	BT_8723D_2ANT_PHASE_MAX
 };
 
 enum bt_8723d_2ant_Scoreboard {
-	BT_8723D_2ANT_SCOREBOARD_ACTIVE								= BIT(0),
-	BT_8723D_2ANT_SCOREBOARD_ONOFF								= BIT(1),
-	BT_8723D_2ANT_SCOREBOARD_SCAN								= BIT(2),
-	BT_8723D_2ANT_SCOREBOARD_UNDERTEST							= BIT(3),
-	BT_8723D_2ANT_SCOREBOARD_RXGAIN								= BIT(4),
-	BT_8723D_2ANT_SCOREBOARD_WLBUSY								= BIT(6)
+	BT_8723D_2ANT_SCOREBOARD_ACTIVE			= BIT(0),
+	BT_8723D_2ANT_SCOREBOARD_ONOFF			= BIT(1),
+	BT_8723D_2ANT_SCOREBOARD_SCAN			= BIT(2),
+	BT_8723D_2ANT_SCOREBOARD_UNDERTEST		= BIT(3),
+	BT_8723D_2ANT_SCOREBOARD_RXGAIN			= BIT(4),
+	BT_8723D_2ANT_SCOREBOARD_WLBUSY			= BIT(6),
+	BT_8723D_2ANT_SCOREBOARD_TDMA			= BIT(9),
 };
 
 
@@ -171,12 +173,10 @@ struct coex_dm_8723d_2ant {
 	u8		cur_fw_dac_swing_lvl;
 	boolean		cur_ignore_wlan_act;
 	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
 	u8		cur_ps_tdma;
 	u8		ps_tdma_para[5];
 	u8		ps_tdma_du_adj_type;
 	boolean		reset_tdma_adjust;
-	boolean		pre_ps_tdma_on;
 	boolean		cur_ps_tdma_on;
 	boolean		pre_bt_auto_report;
 	boolean		cur_bt_auto_report;
@@ -185,7 +185,7 @@ struct coex_dm_8723d_2ant {
 	boolean		pre_rf_rx_lpf_shrink;
 	boolean		cur_rf_rx_lpf_shrink;
 	u32		bt_rf_0x1e_backup;
-	boolean	pre_low_penalty_ra;
+	boolean		pre_low_penalty_ra;
 	boolean		cur_low_penalty_ra;
 	boolean		pre_dac_swing_on;
 	u32		pre_dac_swing_lvl;
@@ -193,15 +193,11 @@ struct coex_dm_8723d_2ant {
 	u32		cur_dac_swing_lvl;
 	boolean		pre_adc_back_off;
 	boolean		cur_adc_back_off;
-	boolean	pre_agc_table_en;
+	boolean		pre_agc_table_en;
 	boolean		cur_agc_table_en;
-	u32		pre_val0x6c0;
 	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
 	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
 	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
 	u8		cur_val0x6cc;
 	boolean		limited_dig;
 
@@ -221,185 +217,198 @@ struct coex_dm_8723d_2ant {
 
 	boolean		is_switch_to_1dot5_ant;
 	u8		switch_thres_offset;
-	u32					arp_cnt;
+	u32		arp_cnt;
 
 	u8		pre_ant_pos_type;
 	u8		cur_ant_pos_type;
+	u32		setting_tdma;
 };
 
 struct coex_sta_8723d_2ant {
-	boolean				bt_disabled;
-	boolean				bt_link_exist;
-	boolean				sco_exist;
-	boolean				a2dp_exist;
-	boolean				hid_exist;
-	boolean				pan_exist;
-
-	boolean				under_lps;
-	boolean				under_ips;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	boolean             is_hiPri_rx_overhead;
-	u8					bt_rssi;
-	boolean				bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	u8					bt_info_c2h[BT_INFO_SRC_8723D_2ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723D_2ANT_MAX];
-	boolean				bt_whck_test;
-	boolean				c2h_bt_inquiry_page;
-	boolean				c2h_bt_remote_name_req;
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u8					bt_info_ext2;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	u32					acc_crc_ratio;
-	u32					now_crc_ratio;
-	u32					cnt_crcok_max_in_10s;
-
-	boolean				cck_lock;
-	boolean				cck_lock_ever;
-	boolean				cck_lock_warn;
-
-	u8					coex_table_type;
-	boolean				force_lps_ctrl;
-
-	u8					dis_ver_info_cnt;
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-
-	boolean				concurrent_rx_mode_on;
-
-	u16					score_board;
-	u8					isolation_btween_wb;   /* 0~ 50 */
-	u8					wifi_coex_thres;
-	u8					bt_coex_thres;
-	u8					wifi_coex_thres2;
-	u8					bt_coex_thres2;
-
-	u8					num_of_profile;
-	boolean				acl_busy;
-	boolean				bt_create_connection;
-	boolean				wifi_is_high_pri_task;
-	u32					specific_pkt_period_cnt;
-	u32					bt_coex_supported_feature;
-	u32					bt_coex_supported_version;
-
-	u8					bt_ble_scan_type;
-	u32					bt_ble_scan_para[3];
-
-	boolean				run_time_state;
-	boolean				freeze_coexrun_by_btinfo;
-
-	boolean				is_A2DP_3M;
-	boolean				voice_over_HOGP;
-	u8                  bt_info;
-	boolean				is_autoslot;
-	u8					forbidden_slot;
-	u8					hid_busy_num;
-	u8					hid_pair_cnt;
-
-	u32					cnt_RemoteNameReq;
-	u32					cnt_setupLink;
-	u32					cnt_ReInit;
-	u32					cnt_IgnWlanAct;
-	u32					cnt_Page;
-	u32					cnt_RoleSwitch;
-
-	u16					bt_reg_vendor_ac;
-	u16					bt_reg_vendor_ae;
-
-	boolean				is_setupLink;
-	boolean				wl_noisy_level;
-	u32                 gnt_error_cnt;
-
-	u8					bt_afh_map[10];
-	u8					bt_relink_downcount;
-	boolean				is_tdma_btautoslot;
-	boolean				is_tdma_btautoslot_hang;
-
-	boolean             is_eSCO_mode;
-
-	boolean				is_rf_state_off;
-
-	boolean				is_hid_low_pri_tx_overhead;
-	boolean				is_bt_multi_link;
-	boolean				is_bt_a2dp_sink;
-
-	u8					wl_fw_dbg_info[10];
-	u8					wl_rx_rate;
-	u8					wl_rts_rx_rate;
-
-	u16					score_board_WB;
-	boolean				is_2g_freerun;
-
-	boolean				is_hid_rcu;
-	boolean				is_ble_scan_toggle;
-
-	u16					legacy_forbidden_slot;
-	u16					le_forbidden_slot;
-	u8					bt_a2dp_vendor_id;
-	u32					bt_a2dp_device_name;
-	boolean				is_bt_opp_exist;
+	boolean		bt_disabled;
+	boolean		bt_link_exist;
+	boolean		sco_exist;
+	boolean		a2dp_exist;
+	boolean		hid_exist;
+	boolean		pan_exist;
+
+	boolean		under_lps;
+	boolean		under_ips;
+	u8		connect_ap_period_cnt;
+	u8		pnp_awake_period_cnt;
+	u32		high_priority_tx;
+	u32		high_priority_rx;
+	u32		low_priority_tx;
+	u32		low_priority_rx;
+	boolean         is_hipri_rx_overhead;
+	u8		bt_rssi;
+	boolean		bt_tx_rx_mask;
+	u8		pre_bt_rssi_state;
+	u8		pre_wifi_rssi_state[4];
+	u8		bt_info_c2h[BT_INFO_SRC_8723D_2ANT_MAX][10];
+	u32		bt_info_c2h_cnt[BT_INFO_SRC_8723D_2ANT_MAX];
+	boolean		bt_whck_test;
+	boolean		c2h_bt_inquiry_page;
+	boolean		c2h_bt_remote_name_req;
+	u8		bt_retry_cnt;
+	u8		bt_info_ext;
+	u8		bt_info_ext2;
+	u32		pop_event_cnt;
+	u8		scan_ap_num;
+
+	u32		crc_ok_cck;
+	u32		crc_ok_11g;
+	u32		crc_ok_11n;
+	u32		crc_ok_11n_vht;
+
+	u32		crc_err_cck;
+	u32		crc_err_11g;
+	u32		crc_err_11n;
+	u32		crc_err_11n_vht;
+
+	u32		acc_crc_ratio;
+	u32		now_crc_ratio;
+	u32		cnt_crcok_max_in_10s;
+
+	boolean		cck_lock;
+	boolean		cck_lock_ever;
+	boolean		cck_lock_warn;
+
+	u8		coex_table_type;
+	boolean		force_lps_ctrl;
+
+	u8		dis_ver_info_cnt;
+
+	u8		a2dp_bit_pool;
+	u8		kt_ver;
+
+	boolean		concurrent_rx_mode_on;
+
+	u16		score_board;
+	u8		isolation_btween_wb;   /* 0~ 50 */
+	u8		wifi_coex_thres;
+	u8		bt_coex_thres;
+	u8		wifi_coex_thres2;
+	u8		bt_coex_thres2;
+
+	u8		num_of_profile;
+	boolean		acl_busy;
+	boolean		bt_create_connection;
+	boolean		wifi_is_high_pri_task;
+	u32		specific_pkt_period_cnt;
+	u32		bt_coex_supported_feature;
+	u32		bt_coex_supported_version;
+
+	u8		bt_ble_scan_type;
+	u32		bt_ble_scan_para[3];
+
+	boolean		run_time_state;
+	boolean		freeze_coexrun_by_btinfo;
+
+	boolean		is_A2DP_3M;
+	boolean		voice_over_HOGP;
+	u8		bt_info;
+	u8		forbidden_slot;
+	u8		hid_busy_num;
+	u8		hid_pair_cnt;
+
+	u32		cnt_remotenamereq;
+	u32		cnt_setuplink;
+	u32		cnt_reinit;
+	u32		cnt_ignwlanact;
+	u32		cnt_page;
+	u32		cnt_roleswitch;
+
+	u16		bt_reg_vendor_ac;
+	u16		bt_reg_vendor_ae;
+
+	boolean		is_setup_link;
+	boolean		wl_noisy_level;
+	u32		gnt_error_cnt;
+
+	u8		bt_afh_map[10];
+	u8		bt_relink_downcount;
+	boolean		is_tdma_btautoslot;
+	boolean		is_tdma_btautoslot_hang;
+
+	boolean		is_esco_mode;
+
+	boolean		is_rf_state_off;
+
+	boolean		is_hid_low_pri_tx_overhead;
+	boolean		is_bt_multi_link;
+	boolean		is_bt_a2dp_sink;
+
+	u8		wl_fw_dbg_info[10];
+	u8		wl_rx_rate;
+	u8		wl_rts_rx_rate;
+
+	u16		score_board_WB;
+	boolean		is_2g_freerun;
+
+	boolean		is_hid_rcu;
+	boolean		is_ble_scan_en;
+
+	u16		legacy_forbidden_slot;
+	u16		le_forbidden_slot;
+	u8		bt_a2dp_vendor_id;
+	u32		bt_a2dp_device_name;
+	boolean		is_bt_opp_exist;
+	boolean		is_no_wl_5ms_extend;
+
+	u16		wl_0x42a_backup;
+	u32		wl_0x430_backup;
+	u32		wl_0x434_backup;
+	u8		wl_0x456_backup;
+
+	boolean		wl_tx_limit_en;
+	boolean		wl_ampdu_limit_en;
+	boolean		wl_rxagg_limit_en;
+	u8		wl_rxagg_size;
 };
 
-#define BT_8723D_2ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
+#define BT_8723D_2ANT_ANTDET_PSD_POINTS		256	/* MAX:1024 */
 #define BT_8723D_2ANT_ANTDET_PSD_AVGNUM		1	/* MAX:3 */
-#define BT_8723D_2ANT_ANTDET_BUF_LEN			16
+#define BT_8723D_2ANT_ANTDET_BUF_LEN		16
 
 struct psdscan_sta_8723d_2ant {
 
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8723D_2ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8723D_2ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_max_value2;
-	u32			psd_avg_value;   /* filter loop_max_value that below BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT, and average the rest*/
-	u32			psd_loop_max_value[BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT];  /*max value in each loop */
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_AntDet_running;
-	boolean			is_psd_show_max_only;
+	u32	ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
+	u32	ant_det_bt_tx_time;
+	u32	ant_det_pre_psdscan_peak_val;
+	boolean	ant_det_is_ant_det_available;
+	u32	ant_det_psd_scan_peak_val;
+	boolean	ant_det_is_btreply_available;
+	u32	ant_det_psd_scan_peak_freq;
+
+	u8	ant_det_result;
+	u8	ant_det_peak_val[BT_8723D_2ANT_ANTDET_BUF_LEN];
+	u8	ant_det_peak_freq[BT_8723D_2ANT_ANTDET_BUF_LEN];
+	u32	ant_det_try_count;
+	u32	ant_det_fail_count;
+	u32	ant_det_inteval_count;
+	u32	ant_det_thres_offset;
+
+	u32	real_cent_freq;
+	s32	real_offset;
+	u32	real_span;
+
+	u32	psd_band_width;
+	u32	psd_point;
+	u32	psd_report[1024];
+	u32	psd_report_max_hold[1024];
+	u32	psd_start_point;
+	u32	psd_stop_point;
+	u32	psd_max_value_point;
+	u32	psd_max_value;
+	u32	psd_max_value2;
+	u32	psd_avg_value;
+	u32	psd_loop_max_value[BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT];
+	u32	psd_start_base;
+	u32	psd_avg_num;	/* 1/8/16/32 */
+	u32	psd_gen_count;
+	boolean	is_antdet_running;
+	boolean	is_psd_show_max_only;
 };
 
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a1ant.c
deleted file mode 100644
index 0ac288ea8076..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a1ant.c
+++ /dev/null
@@ -1,3475 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8812A Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8812A_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8812a_1ant		glcoex_dm_8812a_1ant;
-static struct  coex_dm_8812a_1ant	*coex_dm = &glcoex_dm_8812a_1ant;
-static struct  coex_sta_8812a_1ant		glcoex_sta_8812a_1ant;
-static struct  coex_sta_8812a_1ant	*coex_sta = &glcoex_sta_8812a_1ant;
-
-const char *const glbt_info_src_8812a_1ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8812a_1ant = 20140708;
-u32	glcoex_ver_8812a_1ant = 0x52;
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8812a1ant_
- * ************************************************************ */
-u8 halbtc8812a1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8812a1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-void halbtc8812a1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-/* to check 0x430/0x434 is correct?? */
-void halbtc8812a1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = false;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-/* to check 0x42a ?? */
-void halbtc8812a1ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-/* to check 0x456?? */
-void halbtc8812a1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8812a1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8812a1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8812a1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8812a1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
-	}
-
-	halbtc8812a1ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8812a1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8812a1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-void halbtc8812a1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8812a1ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8	data_len = 3;
-	u8	buf[5] = {0};
-
-	if (!coex_sta->bt_disabled) {
-		if (!coex_sta->bt_info_query_cnt ||
-		    (coex_sta->bt_info_c2h_cnt[BT_INFO_SRC_8812A_1ANT_BT_RSP]
-		     - coex_sta->bt_info_query_cnt) > 2) {
-			buf[0] = data_len;
-			buf[1] = 0x1;	/* polling enable, 1=enable, 0=disable */
-			buf[2] = 0x2;	/* polling time in seconds */
-			buf[3] = 0x1;	/* auto report enable, 1=enable, 0=disable */
-
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_CTRL_BT_INFO,
-					   (void *)&buf[0]);
-		}
-	}
-	coex_sta->bt_info_query_cnt++;
-}
-
-void halbtc8812a1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0;
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	if ((coex_sta->low_priority_tx > 1150)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	if ((reg_hp_tx == 0) && (reg_hp_rx == 0) && (reg_lp_tx == 0) &&
-	    (reg_lp_rx == 0)) {
-		num_of_bt_counter_chk++;
-		if (num_of_bt_counter_chk >= 3) {
-			halbtc8812a1ant_query_bt_info(btcoexist);
-			num_of_bt_counter_chk = 0;
-		}
-	}
-}
-
-/* to check registers */
-void halbtc8812a1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-	s32	wifi_rssi = 0;
-	boolean wifi_busy = false, wifi_under_b_mode = false;
-	static u8 cck_lock_counter = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-			   &wifi_under_b_mode);
-
-	if (coex_sta->under_ips) {
-		coex_sta->crc_ok_cck = 0;
-		coex_sta->crc_ok_11g = 0;
-		coex_sta->crc_ok_11n = 0;
-		coex_sta->crc_ok_11n_agg = 0;
-
-		coex_sta->crc_err_cck = 0;
-		coex_sta->crc_err_11g = 0;
-		coex_sta->crc_err_11n = 0;
-		coex_sta->crc_err_11n_agg = 0;
-	} else {
-		coex_sta->crc_ok_cck	= btcoexist->btc_read_2byte(btcoexist,
-					  0xf04);
-		coex_sta->crc_ok_11g	= btcoexist->btc_read_2byte(btcoexist,
-					  0xf14);
-		coex_sta->crc_ok_11n	= btcoexist->btc_read_2byte(btcoexist,
-					  0xf10);
-		coex_sta->crc_ok_11n_agg = btcoexist->btc_read_2byte(btcoexist,
-					   0xf40);
-
-		coex_sta->crc_err_cck	 = btcoexist->btc_read_2byte(btcoexist,
-					   0xf06);
-		coex_sta->crc_err_11g	 = btcoexist->btc_read_2byte(btcoexist,
-					   0xf16);
-		coex_sta->crc_err_11n	 = btcoexist->btc_read_2byte(btcoexist,
-					   0xf12);
-		coex_sta->crc_err_11n_agg = btcoexist->btc_read_2byte(btcoexist,
-					    0xf42);
-	}
-
-
-	/* reset counter */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xb58, 0x1, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xb58, 0x1, 0x0);
-
-	if ((wifi_busy) && (wifi_rssi >= 30) && (!wifi_under_b_mode)) {
-		if ((coex_dm->bt_status == BT_8812A_1ANT_BT_STATUS_ACL_BUSY) ||
-		    (coex_dm->bt_status ==
-		     BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		    (coex_dm->bt_status ==
-		     BT_8812A_1ANT_BT_STATUS_SCO_BUSY)) {
-			if (coex_sta->crc_ok_cck > (coex_sta->crc_ok_11g +
-						    coex_sta->crc_ok_11n +
-						    coex_sta->crc_ok_11n_agg)) {
-				if (cck_lock_counter < 5)
-					cck_lock_counter++;
-			} else {
-				if (cck_lock_counter > 0)
-					cck_lock_counter--;
-			}
-
-		} else {
-			if (cck_lock_counter > 0)
-				cck_lock_counter--;
-		}
-	} else {
-		if (cck_lock_counter > 0)
-			cck_lock_counter--;
-	}
-
-	if (!coex_sta->pre_ccklock) {
-
-		if (cck_lock_counter >= 5)
-			coex_sta->cck_lock = true;
-		else
-			coex_sta->cck_lock = false;
-	} else {
-		if (cck_lock_counter == 0)
-			coex_sta->cck_lock = false;
-		else
-			coex_sta->cck_lock = true;
-	}
-
-	coex_sta->pre_ccklock =  coex_sta->cck_lock;
-
-
-}
-
-boolean halbtc8812a1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	boolean wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-	}
-
-	return false;
-}
-
-void halbtc8812a1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-u8 halbtc8812a1ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-	u8				algorithm = BT_8812A_1ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Profile = SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_1ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8812A_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8812a1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8812a1ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8812a1ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-/* to check */
-void halbtc8812a1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8	tmp_u1;
-
-	tmp_u1 = btcoexist->btc_read_1byte(btcoexist, 0x4fd);
-	tmp_u1 |= BIT(0);
-	if (low_penalty_ra) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Tx rate adaptive, set low penalty!!\n");
-		BTC_TRACE(trace_buf);
-		tmp_u1 &= ~BIT(2);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Tx rate adaptive, set normal!!\n");
-		BTC_TRACE(trace_buf);
-		tmp_u1 |= BIT(2);
-	}
-
-	btcoexist->btc_write_1byte(btcoexist, 0x4fd, tmp_u1);
-}
-
-void halbtc8812a1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8812a1ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8812a1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8812a1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8812a1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8812a1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** CoexTable(%d) **********\n", type);
-	BTC_TRACE(trace_buf);
-
-	coex_sta->coex_table_type = type;
-
-	switch (type) {
-	case 0:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x55555555, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 4:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0xaaaa5a5a, 0xffffff, 0x3);
-		break;
-	case 5:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0xaa5a5a5a, 0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 7:
-		halbtc8812a1ant_coex_table(btcoexist, force_exec,
-				   0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8812a1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8	data_len = 3;
-	u8	buf[5] = {0};
-
-	buf[0] = data_len;
-	buf[1] = 0x1;			/* OP_Code */
-	buf[2] = 0x1;			/* OP_Code_Length */
-	if (enable)
-		buf[3] = 0x1;		/* OP_Code_Content */
-	else
-		buf[3] = 0x0;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_CTRL_BT_COEX,
-			   (void *)&buf[0]);
-}
-
-void halbtc8812a1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8812a1ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8812a1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8812a1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8812a1ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8812a1ant_sw_mechanism(IN struct btc_coexist *btcoexist,
-				  IN boolean low_penalty_ra)
-{
-	halbtc8812a1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra);
-}
-
-/* to check force_exec */
-void halbtc8812a1ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean force_exec, IN boolean init_hwcfg,
-				  IN boolean wifi_off)
-{
-	u8			u8tmp = 0;
-
-	coex_dm->cur_ant_pos_type = ant_pos_type;
-
-	if (init_hwcfg) {
-		btcoexist->btc_write_1byte(btcoexist, 0xcb3, 0x77);
-		btcoexist->btc_write_4byte(btcoexist, 0x900, 0x00000400);
-		btcoexist->btc_write_1byte(btcoexist, 0x76d, 0x1);
-	} else if (wifi_off) {
-		btcoexist->btc_write_1byte(btcoexist, 0xcb3, 0x77);
-		u8tmp = btcoexist->btc_read_1byte(btcoexist, 0xcb7);
-		u8tmp &= ~BIT(3);
-		u8tmp |= BIT(2);
-		btcoexist->btc_write_1byte(btcoexist, 0xcb7, u8tmp);
-	}
-
-	if (force_exec ||
-	    (coex_dm->cur_ant_pos_type != coex_dm->pre_ant_pos_type)) {
-		/* ext switch setting */
-		switch (ant_pos_type) {
-		case BTC_ANT_PATH_WIFI:
-			u8tmp = btcoexist->btc_read_1byte(btcoexist,
-							  0xcb7);
-			u8tmp |= BIT(3);
-			u8tmp &= ~BIT(2);
-			btcoexist->btc_write_1byte(btcoexist, 0xcb7,
-						   u8tmp);
-			break;
-		case BTC_ANT_PATH_BT:
-			u8tmp = btcoexist->btc_read_1byte(btcoexist,
-							  0xcb7);
-			u8tmp &= ~BIT(3);
-			u8tmp |= BIT(2);
-			btcoexist->btc_write_1byte(btcoexist, 0xcb7,
-						   u8tmp);
-			break;
-		default:
-		case BTC_ANT_PATH_PTA:
-			u8tmp = btcoexist->btc_read_1byte(btcoexist,
-							  0xcb7);
-			u8tmp |= BIT(3);
-			u8tmp &= ~BIT(2);
-			btcoexist->btc_write_1byte(btcoexist, 0xcb7,
-						   u8tmp);
-			break;
-		}
-	}
-
-	coex_dm->pre_ant_pos_type = coex_dm->cur_ant_pos_type;
-}
-
-void halbtc8812a1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], FW for 1Ant AP mode\n");
-			BTC_TRACE(trace_buf);
-			real_byte1 &= ~BIT(4);
-			real_byte1 |= BIT(5);
-
-			real_byte5 |= BIT(5);
-			real_byte5 &= ~BIT(6);
-		}
-	}
-
-	h2c_parameter[0] = real_byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = real_byte5;
-
-	coex_dm->ps_tdma_para[0] = real_byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = real_byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-
-void halbtc8812a1ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_busy = false;
-	u8			rssi_adjust_val = 0;
-	u8			ps_tdma_byte4_val = 0x50, ps_tdma_byte0_val = 0x51,
-				ps_tdma_byte3_val =  0x10;
-	s8			wifi_duration_adjust = 0x0;
-	static boolean	 pre_wifi_busy = false;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (wifi_busy != pre_wifi_busy) {
-		force_exec = true;
-		pre_wifi_busy = wifi_busy;
-	}
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-
-	if (coex_sta->scan_ap_num <= 5)
-		wifi_duration_adjust = 2;
-	else if (coex_sta->scan_ap_num >= 40)
-		wifi_duration_adjust = -15;
-	else if (coex_sta->scan_ap_num >= 20)
-		wifi_duration_adjust = -10;
-
-	if (!coex_sta->force_lps_on) { /* only for A2DP-only case 1/2/9/11 while wifi noisy threshold > 30 */
-		ps_tdma_byte0_val = 0x61;  /* no null-pkt */
-		ps_tdma_byte3_val = 0x11; /* no tx-pause at BT-slot */
-		ps_tdma_byte4_val = 0x10; /* 0x778 = d/1 toggle */
-	}
-
-	if ((type == 3) || (type == 13) || (type == 14)) {
-		ps_tdma_byte4_val = ps_tdma_byte4_val &
-			    0xbf;  /* no dynamic slot for multi-profile */
-
-		if (!wifi_busy)
-			ps_tdma_byte4_val = ps_tdma_byte4_val |
-				0x1;  /* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-	}
-
-	if (bt_link_info->slave_role == true)
-		ps_tdma_byte4_val = ps_tdma_byte4_val |
-			0x1;  /* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-
-	if (turn_on) {
-		switch (type) {
-		default:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x1a, 0x1a, 0x0, ps_tdma_byte4_val);
-			break;
-		case 1:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x3a +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 2:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist,
-						      ps_tdma_byte0_val, 0x2d +
-					      wifi_duration_adjust, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 3:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x1d, 0x1d, 0x0, ps_tdma_byte4_val);
-			break;
-		case 4:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x14, 0x0);
-			break;
-		case 5:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x15, 0x3, 0x11, 0x11);
-			break;
-		case 6:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x20, 0x3, 0x11, 0x11);
-			break;
-		case 7:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xc, 0x5, 0x0, 0x0);
-			break;
-		case 8:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			break;
-		case 9:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x3,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 10:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0xa, 0x0, 0x40);
-			break;
-		case 11:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist,
-					      ps_tdma_byte0_val, 0x21, 0x03,
-				      ps_tdma_byte3_val, ps_tdma_byte4_val);
-			break;
-		case 12:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x0a, 0x0a, 0x0, 0x50);
-			break;
-		case 13:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x12, 0x12, 0x0, ps_tdma_byte4_val);
-			break;
-		case 14:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x51,
-				      0x21, 0x3, 0x10, ps_tdma_byte4_val);
-			break;
-		case 15:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0x3, 0x8, 0x0);
-			break;
-		case 16:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x10, 0x0);
-			break;
-		case 18:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			break;
-		case 20:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x3f, 0x03, 0x11, 0x10);
-			break;
-		case 21:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11, 0x11);
-			break;
-		case 22:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11, 0x10);
-			break;
-		case 23:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x18);
-			break;
-		case 24:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x3, 0x31, 0x18);
-			break;
-		case 25:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			break;
-		case 26:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			break;
-		case 27:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x98);
-			break;
-		case 28:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x69,
-						      0x25, 0x3, 0x31, 0x0);
-			break;
-		case 29:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xab,
-						      0x1a, 0x1a, 0x1, 0x10);
-			break;
-		case 30:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10, 0x10);
-			break;
-		case 31:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1a, 0x1a, 0, 0x58);
-			break;
-		case 32:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x3, 0x11, 0x11);
-			break;
-		case 33:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xa3,
-						      0x25, 0x3, 0x30, 0x90);
-			break;
-		case 34:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 35:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 36:
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x12, 0x3, 0x14, 0x50);
-			break;
-		case 40: /* SoftAP only with no sta associated,BT disable ,TDMA mode for power saving */
-			/* here softap mode screen off will cost 70-80mA for phone */
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x23,
-						      0x18, 0x00, 0x10, 0x24);
-			break;
-		}
-	} else {
-
-		/* disable PS tdma */
-		switch (type) {
-		case 8: /* PTA Control */
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x8,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		case 0:
-		default:  /* Software control, Antenna at BT side */
-			halbtc8812a1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		}
-	}
-	rssi_adjust_val = 0;
-	btcoexist->btc_set(btcoexist,
-		BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssi_adjust_val);
-
-
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-boolean halbtc8812a1ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = false, wifi_connected = false, wifi_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected &&
-	    BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	    coex_dm->bt_status) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8812a1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (wifi_connected &&
-		   (BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8812a1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (!wifi_connected &&
-		(BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8812a1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (wifi_connected &&
-		(BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8812a1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else if (!wifi_connected &&
-		(BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE != coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non connected-idle + BT Busy!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8812a1ant_sw_mechanism(btcoexist, false); */
-
-		common = true;
-	} else {
-		if (wifi_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		common = false;
-	}
-
-	return common;
-}
-
-
-void halbtc8812a1ant_tdma_duration_adjust_for_acl(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0, bt_info_ext;
-	boolean			wifi_busy = false;
-
-	if (BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY == wifi_status)
-		wifi_busy = true;
-	else
-		wifi_busy = false;
-
-	if ((BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN ==
-	     wifi_status) ||
-	    (BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN == wifi_status) ||
-	    (BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT ==
-	     wifi_status)) {
-		if (coex_dm->cur_ps_tdma != 1 &&
-		    coex_dm->cur_ps_tdma != 2 &&
-		    coex_dm->cur_ps_tdma != 3 &&
-		    coex_dm->cur_ps_tdma != 9) {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						9);
-			coex_dm->ps_tdma_du_adj_type = 9;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n = 3;
-			result = 0;
-			wait_count = 0;
-		}
-		return;
-	}
-
-	if (!coex_dm->auto_tdma_adjust) {
-		coex_dm->auto_tdma_adjust = true;
-
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 2);
-		coex_dm->ps_tdma_du_adj_type = 2;
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2 */
-		retry_count = coex_sta->bt_retry_cnt;
-		bt_info_ext = coex_sta->bt_info_ext;
-
-		if ((coex_sta->low_priority_tx) > 1150 ||
-		    (coex_sta->low_priority_rx) > 1250)
-			retry_count++;
-
-		result = 0;
-		wait_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if retry count during continuous n*2 seconds is 0, enlarge WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if continuous 2 retry count(every 2 seconds) >0 and < 3, reduce WiFi duration */
-				if (wait_count <= 2)
-					m++; /* to avoid loop between the two levels */
-				else
-					m = 1;
-
-				if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-			}
-		} else { /* retry count > 3, once retry count > 3, to reduce WiFi duration */
-			if (wait_count == 1)
-				m++; /* to avoid loop between the two levels */
-			else
-				m = 1;
-
-			if (m >= 20)  /* maximum of m = 20 ' will recheck if need to adjust wifi duration in maximum time interval 120 seconds */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-		}
-
-		if (result == -1) {
-			if ((BT_INFO_8812A_1ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-			    ((coex_dm->cur_ps_tdma == 1) ||
-			     (coex_dm->cur_ps_tdma == 2))) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 1) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 2);
-				coex_dm->ps_tdma_du_adj_type = 2;
-			} else if (coex_dm->cur_ps_tdma == 2) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 9) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 11);
-				coex_dm->ps_tdma_du_adj_type = 11;
-			}
-		} else if (result == 1) {
-			if ((BT_INFO_8812A_1ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-			    ((coex_dm->cur_ps_tdma == 1) ||
-			     (coex_dm->cur_ps_tdma == 2))) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 11) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 9);
-				coex_dm->ps_tdma_du_adj_type = 9;
-			} else if (coex_dm->cur_ps_tdma == 9) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 2);
-				coex_dm->ps_tdma_du_adj_type = 2;
-			} else if (coex_dm->cur_ps_tdma == 2) {
-				halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 1);
-				coex_dm->ps_tdma_du_adj_type = 1;
-			}
-		} else { /* no change */
-			/* Bryant Modify
-			if(wifi_busy != pre_wifi_busy)
-			{
-				pre_wifi_busy = wifi_busy;
-				halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, true, coex_dm->cur_ps_tdma);
-			}
-			*/
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** TDMA(on, %d) **********\n",
-				    coex_dm->cur_ps_tdma);
-			BTC_TRACE(trace_buf);
-		}
-
-		if (coex_dm->cur_ps_tdma != 1 &&
-		    coex_dm->cur_ps_tdma != 2 &&
-		    coex_dm->cur_ps_tdma != 9 &&
-		    coex_dm->cur_ps_tdma != 11) {
-			/* recover to previous adjust type */
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		}
-	}
-}
-
-void halbtc8812a1ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-void halbtc8812a1ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	case BTC_PS_LPS_ON:
-		halbtc8812a1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, true);
-		halbtc8812a1ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		coex_sta->force_lps_on = true;
-		break;
-	case BTC_PS_LPS_OFF:
-		halbtc8812a1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8812a1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
-{
-	halbtc8812a1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-	halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8);
-	halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, FORCE_EXEC,
-				     false, false);
-}
-
-void halbtc8812a1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = true, bt_disabled = false;
-
-	/* This function check if bt is disabled */
-
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = false;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = false;
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is enabled !!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		bt_disable_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], bt all counters=0, %d times!!\n",
-			    bt_disable_cnt);
-		BTC_TRACE(trace_buf);
-		if (bt_disable_cnt >= 2) {
-			bt_disabled = true;
-			btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-					   &bt_disabled);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a1ant_action_wifi_only(btcoexist);
-		}
-	}
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-		if (!bt_disabled) {
-		} else {
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-					   NULL);
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-					   NULL);
-		}
-	}
-}
-
-/* *********************************************
- *
- *	Software Coex Mechanism start
- *
- * ********************************************* */
-
-/* SCO only or SCO+PAN(HS) */
-
-/*
-void halbtc8812a1ant_action_sco(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, true);
-}
-
-
-void halbtc8812a1ant_action_hid(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, true);
-}
-
-
-void halbtc8812a1ant_action_a2dp(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8812a1ant_action_a2dp_pan_hs(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8812a1ant_action_pan_edr(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, false);
-}
-
-
-void halbtc8812a1ant_action_pan_hs(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, false);
-}
-
-
-void halbtc8812a1ant_action_pan_edr_a2dp(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8812a1ant_action_pan_edr_hid(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, true);
-}
-
-
-void halbtc8812a1ant_action_hid_a2dp_pan_edr(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, true);
-}
-
-void halbtc8812a1ant_action_hid_a2dp(IN struct btc_coexist* btcoexist)
-{
-	halbtc8812a1ant_sw_mechanism(btcoexist, true);
-}
-
-*/
-
-/* *********************************************
- *
- *	Non-Software Coex Mechanism start
- *
- * ********************************************* */
-void halbtc8812a1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-	halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC,
-				     false, false);
-	halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-}
-
-void halbtc8812a1ant_action_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5);
-	halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-}
-
-void halbtc8812a1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_connected = false, ap_enable = false, wifi_busy = false,
-				bt_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	if ((!wifi_connected) && (!coex_sta->wifi_is_high_pri_task)) {
-		halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist) ||
-		   (bt_link_info->a2dp_exist)) {
-		/* SCO/HID/A2DP  busy */
-		halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if ((bt_link_info->pan_exist) || (wifi_busy)) {
-		halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	}
-}
-
-void halbtc8812a1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	/* tdma and coex table */
-
-	if (bt_link_info->sco_exist) {
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	} else { /* HID */
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 6);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	}
-}
-
-void halbtc8812a1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	u8		bt_rssi_state;
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	bt_rssi_state = halbtc8812a1ant_bt_rssi_state(2, 28, 0);
-
-	if ((coex_sta->low_priority_rx >= 950)  && (!coex_sta->under_ips))
-		bt_link_info->slave_role = true;
-	else
-		bt_link_info->slave_role = false;
-
-	if (bt_link_info->hid_only) { /* HID */
-		halbtc8812a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				wifi_status);
-		coex_dm->auto_tdma_adjust = false;
-		return;
-	} else if (bt_link_info->a2dp_only) { /* A2DP		 */
-		if (BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifi_status) {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-			coex_dm->auto_tdma_adjust = false;
-		} else {
-			halbtc8812a1ant_tdma_duration_adjust_for_acl(btcoexist,
-					wifi_status);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-			coex_dm->auto_tdma_adjust = true;
-		}
-	} else if (((bt_link_info->a2dp_exist) && (bt_link_info->pan_exist)) ||
-		   (bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) { /* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 13);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	} else if (bt_link_info->hid_exist &&
-		   bt_link_info->a2dp_exist) { /* HID+A2DP */
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 14);
-		coex_dm->auto_tdma_adjust = false;
-
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	} else if ((bt_link_info->pan_only) || (bt_link_info->hid_exist &&
-		bt_link_info->pan_exist)) { /* PAN(OPP,FTP), HID+PAN(OPP,FTP)			 */
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 3);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	} else {
-		/* BT no-profile busy (0x9) */
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		coex_dm->auto_tdma_adjust = false;
-	}
-}
-
-void halbtc8812a1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-	/* power save state */
-	halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8);
-	halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC,
-				     false, false);
-	halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8812a1ant_action_wifi_not_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if (BT_8812A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8812A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8812a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* Bryant Add */
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8812a1ant_action_wifi_not_connected_asso_auth(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist)  || (bt_link_info->hid_exist) ||
-	    (bt_link_info->a2dp_exist)) {
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 4);
-	} else if (bt_link_info->pan_exist) {
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 4);
-	} else {
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 2);
-	}
-}
-
-void halbtc8812a1ant_action_wifi_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if (BT_8812A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8812A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8812a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* Bryant Add */
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8812a1ant_action_wifi_connected_specific_packet(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist) ||
-	    (bt_link_info->a2dp_exist)) {
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if (bt_link_info->pan_exist) {
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     NORMAL_EXEC, false, false);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8812a1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-	boolean	wifi_busy = false;
-	boolean		scan = false, link = false, roam = false;
-	boolean		under_4way = false, ap_enable = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], CoexForWifiConnect()===>\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-	if (under_4way) {
-		halbtc8812a1ant_action_wifi_connected_specific_packet(btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	if (scan || link || roam) {
-		if (scan)
-			halbtc8812a1ant_action_wifi_connected_scan(btcoexist);
-		else
-			halbtc8812a1ant_action_wifi_connected_specific_packet(
-				btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* power save state */
-	if (!ap_enable &&
-	    BT_8812A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status &&
-	    !btcoexist->bt_link_info.hid_only) {
-		if (btcoexist->bt_link_info.a2dp_only) {	/* A2DP */
-			if (!wifi_busy)
-				halbtc8812a1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			else { /* busy */
-				if (coex_sta->scan_ap_num >=
-				    BT_8812A_1ANT_WIFI_NOISY_THRESH)  /* no force LPS, no PS-TDMA, use pure TDMA */
-					halbtc8812a1ant_power_save_state(
-						btcoexist, BTC_PS_WIFI_NATIVE,
-						0x0, 0x0);
-				else
-					halbtc8812a1ant_power_save_state(
-						btcoexist, BTC_PS_LPS_ON, 0x50,
-						0x4);
-			}
-		} else if ((coex_sta->pan_exist == false) &&
-			   (coex_sta->a2dp_exist == false) &&
-			   (coex_sta->hid_exist == false))
-			halbtc8812a1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		else
-			halbtc8812a1ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-	} else
-		halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-
-	/* tdma and coex table */
-	if (!wifi_busy) {
-		if (BT_8812A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8812a1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else if ((BT_8812A_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8812a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-			halbtc8812a1ant_set_ant_path(btcoexist,
-				BTC_ANT_PATH_PTA, NORMAL_EXEC, false, false);
-			if ((coex_sta->high_priority_tx) +
-			    (coex_sta->high_priority_rx) <= 60)
-				halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-			else
-				halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	} else {
-		if (BT_8812A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8812a1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else if ((BT_8812A_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8812a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else {
-			halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-			halbtc8812a1ant_set_ant_path(btcoexist,
-				BTC_ANT_PATH_PTA, NORMAL_EXEC, false, false);
-			if ((coex_sta->high_priority_tx) +
-			    (coex_sta->high_priority_rx) <= 60)
-				halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-			else
-				halbtc8812a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	}
-}
-
-void halbtc8812a1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8				algorithm = 0;
-
-	algorithm = halbtc8812a1ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-
-	if (halbtc8812a1ant_is_common_action(btcoexist)) {
-
-	} else {
-		switch (coex_dm->cur_algorithm) {
-		case BT_8812A_1ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_sco(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_hid(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_a2dp(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_a2dp_pan_hs(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_pan_edr(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_pan_hs(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_pan_edr_a2dp(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_pan_edr_hid(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_hid_a2dp_pan_edr(btcoexist); */
-			break;
-		case BT_8812A_1ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_action_hid_a2dp(btcoexist); */
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8812a1ant_coex_all_off(btcoexist); */
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-void halbtc8812a1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false, bt_hs_on = false;
-	boolean	increase_scan_dev_num = false;
-	boolean	bt_ctrl_agg_buf_size = false;
-	boolean	miracast_plus_bt = false;
-	u8	agg_buf_size = 5;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0, wifi_bw;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if ((BT_8812A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8812A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		increase_scan_dev_num = true;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_INC_SCAN_DEV_NUM,
-			   &increase_scan_dev_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist) {
-			halbtc8812a1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1,
-						   0, 1);
-			miracast_plus_bt = true;
-		} else {
-			halbtc8812a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0,
-						   0, 0);
-			miracast_plus_bt = false;
-		}
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-		halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-
-		if ((bt_link_info->a2dp_exist) &&
-		    (coex_sta->c2h_bt_inquiry_page)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is Inquirying\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a1ant_action_bt_inquiry(btcoexist);
-		} else
-			halbtc8812a1ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	}
-
-	miracast_plus_bt = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-			   &miracast_plus_bt);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if ((bt_link_info->bt_link_exist) && (wifi_connected)) {
-		halbtc8812a1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1, 0, 1);
-
-		if (bt_link_info->sco_exist)
-			halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC, true,
-						   false, 0x5);
-		else {
-			if (BTC_WIFI_BW_HT40 == wifi_bw)
-				halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC,
-							   false, true, 0x10);
-			else
-				halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC,
-							   false, true, 0x8);
-		}
-
-		halbtc8812a1ant_sw_mechanism(btcoexist, true);
-		halbtc8812a1ant_run_sw_coexist_mechanism(
-			btcoexist);  /* just print debug message */
-	} else {
-		halbtc8812a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-		halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x5);
-
-		halbtc8812a1ant_sw_mechanism(btcoexist, false);
-		halbtc8812a1ant_run_sw_coexist_mechanism(
-			btcoexist); /* //just print debug message */
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "############# [BTCoex],  BT Is Inquirying\n");
-		BTC_TRACE(trace_buf);
-		halbtc8812a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8812a1ant_action_hs(btcoexist);
-		return;
-	}
-
-
-	if (!wifi_connected) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is non connected-idle !!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (scan || link || roam) {
-			if (scan)
-				halbtc8812a1ant_action_wifi_not_connected_scan(
-					btcoexist);
-			else
-				halbtc8812a1ant_action_wifi_not_connected_asso_auth(
-					btcoexist);
-		} else
-			halbtc8812a1ant_action_wifi_not_connected(btcoexist);
-	} else	/* wifi LPS/Busy */
-		halbtc8812a1ant_action_wifi_connected(btcoexist);
-}
-
-void halbtc8812a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-
-	/* sw all off */
-	halbtc8812a1ant_sw_mechanism(btcoexist, false);
-
-	/* halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8); */
-	/* halbtc8812a1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0); */
-
-	coex_sta->pop_event_cnt = 0;
-}
-
-void halbtc8812a1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up, IN boolean wifi_only)
-{
-	u8	u8tmp = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	/* ant sw control to BT */
-	halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, FORCE_EXEC,
-				     true, false);
-
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	/* PTA parameter */
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, 0x0);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, 0xffff);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, 0x55555555);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, 0x55555555);
-
-	/* coex parameters */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	/* enable PTA */
-	btcoexist->btc_write_1byte(btcoexist, 0x40, 0x20);
-
-	/* bt clock related */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x4);
-	u8tmp |= BIT(7);
-	btcoexist->btc_write_1byte(btcoexist, 0x4, u8tmp);
-
-	/* bt clock related */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x7);
-	u8tmp |= BIT(1);
-	btcoexist->btc_write_1byte(btcoexist, 0x7, u8tmp);
-}
-
-/* ************************************************************
- * work around function start with wa_halbtc8812a1ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8812a1ant_
- * ************************************************************ */
-void ex_halbtc8812a1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8812a1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8812a1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8812a1ant_init_hw_config(btcoexist, true, wifi_only);
-	btcoexist->stop_coex_dm = false;
-}
-
-void ex_halbtc8812a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->stop_coex_dm = false;
-
-	halbtc8812a1ant_init_coex_dm(btcoexist);
-
-	halbtc8812a1ant_query_bt_info(btcoexist);
-}
-
-void ex_halbtc8812a1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8			*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u32				u32tmp[4];
-	u32				fw_ver = 0, bt_patch_ver = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "Ant PG number/ Ant mechanism:",
-		   board_info->pg_ant_num, board_info->btdm_ant_num);
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%d/ 0x%x/ 0x%x(%d)",
-		   "CoexVer/ FwVer/ PatchVer",
-		   glcoex_ver_date_8812a_1ant, glcoex_ver_8812a_1ant, fw_ver,
-		   bt_patch_ver, bt_patch_ver);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi, coex_sta->bt_retry_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP",
-		   bt_link_info->sco_exist, bt_link_info->hid_exist,
-		   bt_link_info->pan_exist, bt_link_info->a2dp_exist);
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Info A2DP rate",
-		   (bt_info_ext & BIT(0)) ? "Basic rate" : "EDR rate");
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8812A_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8812a_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	if (!btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[mechanisms]============");
-		CL_PRINTF(cli_buf);
-
-		ps_tdma_case = coex_dm->cur_ps_tdma;
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d",
-			   "PS TDMA",
-			   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-			   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-			   coex_dm->ps_tdma_para[4], ps_tdma_case);
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ",
-			   "Latest error condition(should be 0)",
-			   coex_dm->error_condition);
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ",
-			   "IgnWlanAct",
-			   coex_dm->cur_ignore_wlan_act);
-		CL_PRINTF(cli_buf);
-	}
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x778",
-		   u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xcb3);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0xcb7);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x900);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0xcb3/0xcb7/0x900",
-		   u8tmp[0], u8tmp[1], u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x40",
-		   u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)",
-		   u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(hp rx[31:16]/tx[15:0])",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(lp rx[31:16]/tx[15:0])",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-
-void ex_halbtc8812a1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = true;
-
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, false, true);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8812a1ant_init_hw_config(btcoexist, false, false);
-		halbtc8812a1ant_init_coex_dm(btcoexist);
-		halbtc8812a1ant_query_bt_info(btcoexist);
-
-		coex_sta->under_ips = false;
-	}
-}
-
-void ex_halbtc8812a1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = true;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8812a1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_SCAN_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     FORCE_EXEC, false, false);
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-	}
-
-	if (coex_sta->bt_disabled)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	halbtc8812a1ant_query_bt_info(btcoexist);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8812a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8812a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8812a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8812a1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_SCAN_START == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8812a1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		else	/* wifi is connected */
-			halbtc8812a1ant_action_wifi_connected_scan(btcoexist);
-	} else if (BTC_SCAN_FINISH == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8812a1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8812a1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-void ex_halbtc8812a1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	boolean	wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-
-	if (BTC_ASSOCIATE_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     FORCE_EXEC, false, false);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-		/* coex_dm->arp_cnt = 0; */
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8812a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8812a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8812a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8812a1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_ASSOCIATE_START == type)
-		halbtc8812a1ant_action_wifi_not_connected_asso_auth(btcoexist);
-	else if (BTC_ASSOCIATE_FINISH == type) {
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-				   &wifi_connected);
-		if (!wifi_connected) /* non-connected scan */
-			halbtc8812a1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8812a1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-/* to check registers... */
-void ex_halbtc8812a1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			data_len = 5;
-	u8			buf[6] = {0};
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	boolean			wifi_under_b_mode = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-		halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA,
-					     FORCE_EXEC, false, false);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-				   &wifi_under_b_mode);
-#if 0
-		/* Set CCK Tx/Rx high Pri except 11b mode */
-		if (wifi_under_b_mode) {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x00); /* CCK Rx */
-		} else {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x10); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x10); /* CCK Rx */
-		}
-#endif
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		/* h2c_parameter[0] = 0x1; */
-		h2c_parameter[0] = 0x0;
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	buf[0] = data_len;
-	buf[1] = 0x5;				/* OP_Code */
-	buf[2] = 0x3;				/* OP_Code_Length */
-	buf[3] = h2c_parameter[0];	/* OP_Code_Content */
-	buf[4] = h2c_parameter[1];
-	buf[5] = h2c_parameter[2];
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_CTRL_BT_COEX,
-			   (void *)&buf[0]);
-}
-
-void ex_halbtc8812a1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean	bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    BTC_PACKET_ARP == type) {
-		if (BTC_PACKET_ARP == type) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], specific Packet ARP notify\n");
-			BTC_TRACE(trace_buf);
-
-			coex_dm->arp_cnt++;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], ARP Packet Count = %d\n",
-				    coex_dm->arp_cnt);
-			BTC_TRACE(trace_buf);
-
-			if (coex_dm->arp_cnt >=
-			    10) /* if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecificPacket(btcoexist) */
-				coex_sta->wifi_is_high_pri_task = false;
-			else
-				coex_sta->wifi_is_high_pri_task = true;
-		} else {
-			coex_sta->wifi_is_high_pri_task = true;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], specific Packet DHCP or EAPOL notify\n");
-			BTC_TRACE(trace_buf);
-		}
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet [Type = %d] notify\n", type);
-		BTC_TRACE(trace_buf);
-	}
-
-	coex_sta->specific_pkt_period_cnt = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8812a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8812a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8812a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8812a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8812a1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    ((BTC_PACKET_ARP == type) && (coex_sta->wifi_is_high_pri_task)))
-		halbtc8812a1ant_action_wifi_connected_specific_packet(btcoexist);
-}
-
-void ex_halbtc8812a1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8				bt_info = 0;
-	u8				i, rsp_source = 0;
-	boolean				wifi_connected = false;
-	boolean				bt_busy = false;
-
-	coex_sta->c2h_bt_info_req_sent = false;
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8812A_1ANT_MAX)
-		rsp_source = BT_INFO_SRC_8812A_1ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	if (BT_INFO_SRC_8812A_1ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->bt_info_c2h[rsp_source][2] & 0x20)
-			coex_sta->c2h_bt_page = true;
-		else
-			coex_sta->c2h_bt_page = false;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 - 90;
-		/* coex_sta->bt_info_c2h[rsp_source][3]*2+10; */
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		coex_sta->bt_tx_rx_mask = (coex_sta->bt_info_c2h[rsp_source][2]
-					   & 0x40);
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TX_RX_MASK,
-				   &coex_sta->bt_tx_rx_mask);
-		if (!coex_sta->bt_tx_rx_mask) {
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF,
-						  0x3c, 0x15);
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if (coex_sta->bt_info_ext & BIT(1)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-			if (wifi_connected)
-				ex_halbtc8812a1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8812a1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(3)) {
-			if (!btcoexist->manual_control &&
-			    !btcoexist->stop_coex_dm) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8812a1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, false);
-			}
-		} else {
-			/* BT already NOT ignore Wlan active, do nothing here. */
-		}
-#if (BT_AUTO_REPORT_ONLY_8812A_1ANT == 0)
-		if ((coex_sta->bt_info_ext & BIT(4))) {
-			/* BT auto report already enabled, do nothing */
-		} else
-			halbtc8812a1ant_bt_auto_report(btcoexist, FORCE_EXEC,
-						       true);
-#endif
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8812A_1ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8812A_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8812A_1ANT_B_FTP)
-			coex_sta->pan_exist = true;
-		else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8812A_1ANT_B_A2DP)
-			coex_sta->a2dp_exist = true;
-		else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8812A_1ANT_B_HID)
-			coex_sta->hid_exist = true;
-		else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8812A_1ANT_B_SCO_ESCO)
-			coex_sta->sco_exist = true;
-		else
-			coex_sta->sco_exist = false;
-	}
-
-	halbtc8812a1ant_update_bt_link_info(btcoexist);
-
-	bt_info = bt_info &
-		0x1f;  /* mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41) */
-
-	if (!(bt_info & BT_INFO_8812A_1ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info ==
-		BT_INFO_8812A_1ANT_B_CONNECTION) {	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if ((bt_info & BT_INFO_8812A_1ANT_B_SCO_ESCO) ||
-		   (bt_info & BT_INFO_8812A_1ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8812A_1ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info & BT_INFO_8812A_1ANT_B_ACL_BUSY) {
-		if (BT_8812A_1ANT_BT_STATUS_ACL_BUSY != coex_dm->bt_status)
-			coex_dm->auto_tdma_adjust = false;
-		coex_dm->bt_status = BT_8812A_1ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_dm->bt_status = BT_8812A_1ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((BT_8812A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8812A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = true;
-	else
-		bt_busy = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	halbtc8812a1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8812a1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = false;
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, false, true);
-
-		halbtc8812a1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-		btcoexist->stop_coex_dm = true;
-	}
-}
-
-void ex_halbtc8812a1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-	halbtc8812a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-	halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, FORCE_EXEC,
-				     false, true);
-
-	halbtc8812a1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-
-	ex_halbtc8812a1ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	btcoexist->stop_coex_dm = true;
-}
-
-void ex_halbtc8812a1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_WIFI_PNP_SLEEP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8812a1ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8812a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT,
-					     FORCE_EXEC, false, true);
-		halbtc8812a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-		/* Sinda 20150819, workaround for driver skip leave IPS/LPS to speed up sleep time. */
-		/* Driver do not leave IPS/LPS when driver is going to sleep, so BTCoexistence think wifi is still under IPS/LPS */
-		/* BT should clear UnderIPS/UnderLPS state to avoid mismatch state after wakeup. */
-		coex_sta->under_ips = false;
-		coex_sta->under_lps = false;
-		btcoexist->stop_coex_dm = true;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = false;
-		halbtc8812a1ant_init_hw_config(btcoexist, false, false);
-		halbtc8812a1ant_init_coex_dm(btcoexist);
-		halbtc8812a1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8812a1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], *****************Coex DM Reset*****************\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8812a1ant_init_hw_config(btcoexist, false, false);
-	halbtc8812a1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8812a1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-#if (BT_AUTO_REPORT_ONLY_8812A_1ANT == 0)
-	halbtc8812a1ant_query_bt_info(btcoexist);
-	halbtc8812a1ant_monitor_bt_enable_disable(btcoexist);
-#else
-	halbtc8812a1ant_monitor_bt_ctr(btcoexist);
-	halbtc8812a1ant_monitor_wifi_ctr(btcoexist);
-
-	if (halbtc8812a1ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust)
-		halbtc8812a1ant_run_coexist_mechanism(btcoexist);
-
-	coex_sta->specific_pkt_period_cnt++;
-#endif
-}
-
-void ex_halbtc8812a1ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata)
-{
-	switch (op_code) {
-	case BTC_DBG_SET_COEX_NORMAL:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set CoexMode to Normal\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->manual_control = false;
-		halbtc8812a1ant_init_coex_dm(btcoexist);
-		break;
-	case BTC_DBG_SET_COEX_WIFI_ONLY:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set CoexMode to Wifi Only\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->manual_control = true;
-		halbtc8812a1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-					9);
-		break;
-	case BTC_DBG_SET_COEX_BT_ONLY:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set CoexMode to BT only\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->manual_control = true;
-		halbtc8812a1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		halbtc8812a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-					0);
-		break;
-	case BTC_DBG_SET_COEX_DEC_BT_PWR:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set Dec BT power\n");
-		BTC_TRACE(trace_buf);
-		{
-			u8	data_len = 4;
-			u8	buf[6] = {0};
-			u8	dec_bt_pwr = 0, pwr_level = 0;
-
-			if (op_len == 2) {
-				dec_bt_pwr = pdata[0];
-				pwr_level = pdata[1];
-
-				buf[0] = data_len;
-				buf[1] = 0x3;		/* OP_Code */
-				buf[2] = 0x2;		/* OP_Code_Length */
-
-				buf[3] = dec_bt_pwr;	/* OP_Code_Content */
-				buf[4] = pwr_level;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Set Dec BT power=%d, pwr_level=%d\n",
-					    dec_bt_pwr, pwr_level);
-				BTC_TRACE(trace_buf);
-				btcoexist->btc_set(btcoexist,
-						   BTC_SET_ACT_CTRL_BT_COEX,
-						   (void *)&buf[0]);
-			}
-		}
-		break;
-
-	case BTC_DBG_SET_COEX_BT_AFH_MAP:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set BT AFH Map\n");
-		BTC_TRACE(trace_buf);
-		{
-			u8	data_len = 5;
-			u8	buf[6] = {0};
-
-			if (op_len == 3) {
-				buf[0] = data_len;
-				buf[1] = 0x5;				/* OP_Code */
-				buf[2] = 0x3;				/* OP_Code_Length */
-
-				buf[3] = pdata[0];			/* OP_Code_Content */
-				buf[4] = pdata[1];
-				buf[5] = pdata[2];
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Set BT AFH Map = %02x %02x %02x\n",
-					    pdata[0], pdata[1], pdata[2]);
-				BTC_TRACE(trace_buf);
-				btcoexist->btc_set(btcoexist,
-						   BTC_SET_ACT_CTRL_BT_COEX,
-						   (void *)&buf[0]);
-			}
-		}
-		break;
-
-	case BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set BT Ignore Wlan Active\n");
-		BTC_TRACE(trace_buf);
-		{
-			u8	data_len = 3;
-			u8	buf[6] = {0};
-
-			if (op_len == 1) {
-				buf[0] = data_len;
-				buf[1] = 0x1;			/* OP_Code */
-				buf[2] = 0x1;			/* OP_Code_Length */
-
-				buf[3] = pdata[0];		/* OP_Code_Content */
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Set BT Ignore Wlan Active = 0x%x\n",
-					    pdata[0]);
-				BTC_TRACE(trace_buf);
-
-				btcoexist->btc_set(btcoexist,
-						   BTC_SET_ACT_CTRL_BT_COEX,
-						   (void *)&buf[0]);
-			}
-		}
-		break;
-	default:
-		break;
-	}
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a1ant.h
deleted file mode 100644
index 08fbad259551..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a1ant.h
+++ /dev/null
@@ -1,244 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8812A_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8812A 1ANT BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8812A_1ANT				1
-
-#define	BT_INFO_8812A_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8812A_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8812A_1ANT_B_HID						BIT(5)
-#define	BT_INFO_8812A_1ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8812A_1ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8812A_1ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8812A_1ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8812A_1ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8812A_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT(0))) ? true : false)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT		2
-
-#define  BT_8812A_1ANT_WIFI_NOISY_THRESH								30   /* max: 255 */
-
-enum bt_info_src_8812a_1ant {
-	BT_INFO_SRC_8812A_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8812A_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8812A_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8812A_1ANT_MAX
-};
-
-enum bt_8812a_1ant_bt_status {
-	BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8812A_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8812A_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8812A_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8812A_1ANT_BT_STATUS_MAX
-};
-
-enum bt_8812a_1ant_wifi_status {
-	BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8812A_1ANT_WIFI_STATUS_MAX
-};
-
-enum bt_8812a_1ant_coex_algo {
-	BT_8812A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8812A_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8812A_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8812A_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8812A_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8812A_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8812A_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8812A_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8812A_1ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-struct coex_dm_8812a_1ant {
-	/* hw setting */
-	u8		pre_ant_pos_type;
-	u8		cur_ant_pos_type;
-	/* fw mechanism */
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	/* sw mechanism */
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-	u32		arp_cnt;
-
-	u8		error_condition;
-};
-
-struct coex_sta_8812a_1ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	s8					bt_rssi;
-	boolean					bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8812A_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8812A_1ANT_MAX];
-	u32					bt_info_query_cnt;
-	boolean					c2h_bt_inquiry_page;
-	boolean					c2h_bt_page;				/* Add for win8.1 page out issue */
-	boolean					wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_agg;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_agg;
-
-	boolean					cck_lock;
-	boolean					pre_ccklock;
-	u8					coex_table_type;
-
-	boolean					force_lps_on;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8812a1ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a1ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8812a1ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a1ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8812a1ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8812a1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8812a1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8812a1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8812a1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8812a1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8812a1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8812a1ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8812a1ant_coex_dm_reset(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a1ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a1ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata);
-void ex_halbtc8812a1ant_display_coex_info(IN struct btc_coexist *btcoexist);
-
-#else
-#define	ex_halbtc8812a1ant_power_on_setting(btcoexist)
-#define	ex_halbtc8812a1ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8812a1ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8812a1ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8812a1ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8812a1ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8812a1ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8812a1ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8812a1ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8812a1ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8812a1ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8812a1ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8812a1ant_halt_notify(btcoexist)
-#define	ex_halbtc8812a1ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8812a1ant_coex_dm_reset(btcoexist)
-#define	ex_halbtc8812a1ant_periodical(btcoexist)
-#define	ex_halbtc8812a1ant_dbg_control(btcoexist, op_code, op_len, pdata)
-#define	ex_halbtc8812a1ant_display_coex_info(btcoexist)
-
-#endif
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a2ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a2ant.c
deleted file mode 100644
index e1e6572ed0f9..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a2ant.c
+++ /dev/null
@@ -1,5638 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8812A Co-exist mechanism
- *
- * History
- * 2012/08/22 Cosa first check in.
- * 2012/11/14 Cosa Revise for 8812A 2Ant out sourcing.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-
-#if (RTL8812A_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8812a_2ant	glcoex_dm_8812a_2ant;
-static struct  coex_dm_8812a_2ant	*coex_dm = &glcoex_dm_8812a_2ant;
-static struct  coex_sta_8812a_2ant	glcoex_sta_8812a_2ant;
-static struct  coex_sta_8812a_2ant	*coex_sta = &glcoex_sta_8812a_2ant;
-
-const char *const glbt_info_src_8812a_2ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-/* ************************************************************
- * BtCoex Version Format:
- * 1. date :			glcoex_ver_date_XXXXX_1ant
- * 2. WifiCoexVersion : glcoex_ver_XXXX_1ant
- * 3. BtCoexVersion :	glcoex_ver_btdesired_XXXXX_1ant
- * 4. others :			glcoex_ver_XXXXXX_XXXXX_1ant
- *
- * Variable should be indicated IC and Antenna numbers !!!
- * Please strictly follow this order and naming style !!!
- *
- * ************************************************************ */
-u32	glcoex_ver_date_8812a_2ant = 20160818;
-u32	glcoex_ver_8812a_2ant = 0x3c;
-u32	glcoex_ver_btdesired_8812a_2ant = 0x3c;
-/*1. add coex. log for wifi/BT coex. version*/
-
-/* ************************************************************
-* local function proto type if needed
-* ************************************************************
-* ************************************************************
-* local function start with halbtc8812a2ant_
-* ************************************************************ */
-u8 halbtc8812a2ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-
-u8 halbtc8812a2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-
-void halbtc8812a2ant_set_enable_pta(IN struct btc_coexist *btcoexist,
-				    IN boolean enablePTA)
-{
-	if (enablePTA) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], PTA is enable!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte(btcoexist, 0x40, 0x20);
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], PTA is disable!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte(btcoexist, 0x40, 0x00);
-
-	}
-}
-
-void halbtc8812a2ant_enable_pta(IN struct btc_coexist *btcoexist,
-				IN boolean force_exec, IN boolean enable)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s turn Enable PTA %s\n",
-		    (force_exec ? "force to" : ""), (enable ? "ON" : "OFF"));
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_enable_pta = enable;
-
-	if (!force_exec) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], pre_enable_pta = %d, cur_enable_pta = %d!!\n",
-			    coex_dm->pre_enable_pta, coex_dm->cur_enable_pta);
-		BTC_TRACE(trace_buf);
-
-		if (coex_dm->pre_enable_pta == coex_dm->cur_enable_pta)
-			return;
-	}
-	halbtc8812a2ant_set_enable_pta(btcoexist, enable);
-
-
-	coex_dm->pre_enable_pta = coex_dm->cur_enable_pta;
-}
-
-u32 halbtc8812a2ant_decide_ra_mask(IN struct btc_coexist *btcoexist,
-				   IN u32 ra_mask_type)
-{
-	u32	dis_ra_mask = 0x0;
-
-	switch (ra_mask_type) {
-	case 0: /* normal mode */
-		dis_ra_mask = 0x0;
-		break;
-	case 1: /* disable cck 1/2 */
-		dis_ra_mask = 0x00000003;
-		break;
-	case 2: /* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4			 */
-		dis_ra_mask = 0x0001f1f7;
-		break;
-	default:
-		break;
-	}
-
-	return dis_ra_mask;
-}
-
-void halbtc8812a2ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-void halbtc8812a2ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = false;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-void halbtc8812a2ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-void halbtc8812a2ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8812a2ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	u32	dis_ra_mask = 0x0;
-
-	coex_dm->cur_ra_mask_type = ra_mask_type;
-	dis_ra_mask = halbtc8812a2ant_decide_ra_mask(btcoexist, ra_mask_type);
-	halbtc8812a2ant_update_ra_mask(btcoexist, force_exec, dis_ra_mask);
-
-	halbtc8812a2ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8812a2ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8812a2ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-void halbtc8812a2ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8812a2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_hp_txrx, reg_hp_tx, reg_hp_tx, reg_hp_rx, reg_hp_rx);
-	BTC_TRACE(trace_buf);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_lp_txrx, reg_lp_tx, reg_lp_tx, reg_lp_rx, reg_lp_rx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-}
-
-
-void halbtc8812a2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-#if 1
-
-	coex_sta->crc_ok_cck =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_VHT);
-#endif
-}
-
-
-void halbtc8812a2ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8	data_len = 3;
-	u8	buf[5] = {0};
-	/* 8812a watch btifo to check BT enable/disable
-	 *	if(!btcoexist->bt_info.bt_disabled) */
-	{
-		if (!coex_sta->bt_info_query_cnt ||
-		    (coex_sta->bt_info_c2h_cnt[BT_INFO_SRC_8812A_2ANT_BT_RSP]
-		     - coex_sta->bt_info_query_cnt) > 2) {
-			buf[0] = data_len;
-			buf[1] = 0x1;	/* polling enable, 1=enable, 0=disable */
-			buf[2] = 0x2;	/* polling time in seconds */
-			buf[3] = 0x1;	/* auto report enable, 1=enable, 0=disable */
-
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_CTRL_BT_INFO,
-					   (void *)&buf[0]);
-		}
-	}
-	coex_sta->bt_info_query_cnt++;
-}
-
-boolean halbtc8812a2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	boolean	wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean	wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-	}
-
-	return false;
-}
-
-void halbtc8812a2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-#if 1/* (BT_AUTO_REPORT_ONLY_8812A_2ANT == 1)	/ profile from bt patch */
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-	bt_link_info->acl_busy = coex_sta->acl_busy;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-#else	/* profile from bt stack */
-	bt_link_info->bt_link_exist = stack_info->bt_link_exist;
-	bt_link_info->sco_exist = stack_info->sco_exist;
-	bt_link_info->a2dp_exist = stack_info->a2dp_exist;
-	bt_link_info->pan_exist = stack_info->pan_exist;
-	bt_link_info->hid_exist = stack_info->hid_exist;
-
-	/* for win-8 stack HID report error */
-	if (!stack_info->hid_exist)
-		stack_info->hid_exist =
-			coex_sta->hid_exist;  /* sync  BTInfo with BT firmware and stack */
-	/* when stack HID report error, here we use the info from bt fw. */
-	if (!stack_info->bt_link_exist)
-		stack_info->bt_link_exist = coex_sta->bt_link_exist;
-#endif
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-u8 halbtc8812a2ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	struct  btc_stack_info	*stack_info = &btcoexist->stack_info;
-	boolean				bt_hs_on = false;
-	u8				algorithm = BT_8812A_2ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 0) {
-		if (bt_link_info->acl_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], ACL Busy only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR;
-		}
-	} else if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_2ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_2ANT_COEX_ALGO_SCO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (stack_info->num_of_hid >= 2) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID*2 + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_SCO_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_SCO_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8812A_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8812A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8812a2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,
-		IN u8 dac_swing_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	/* There are several type of dacswing */
-	/* 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 */
-	h2c_parameter[0] = dac_swing_lvl;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Set Dac Swing Level=0x%x\n",
-		    dac_swing_lvl);
-	BTC_TRACE(trace_buf);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], FW write 0x64=0x%x\n",
-		    h2c_parameter[0]);
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter);
-}
-
-void halbtc8812a2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				       IN u8 dec_bt_pwr_lvl)
-{
-	u8	data_len = 4;
-	u8	buf[6] = {0};
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], decrease Bt Power level = %d\n",
-		    dec_bt_pwr_lvl);
-	BTC_TRACE(trace_buf);
-
-	buf[0] = data_len;
-	buf[1] = 0x3;		/* OP_Code */
-	buf[2] = 0x2;		/* OP_Code_Length */
-	if (dec_bt_pwr_lvl)
-		buf[3] = 0x1;	/* OP_Code_Content */
-	else
-		buf[3] = 0x0;
-	buf[4] = dec_bt_pwr_lvl;/* pwr_level */
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_CTRL_BT_COEX,
-			   (void *)&buf[0]);
-}
-
-void halbtc8812a2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				IN boolean force_exec, IN u8 dec_bt_pwr_lvl)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s Dec BT power level = %d\n",
-		    (force_exec ? "force to" : ""), dec_bt_pwr_lvl);
-	BTC_TRACE(trace_buf);
-
-	coex_dm->cur_bt_dec_pwr_lvl = dec_bt_pwr_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_dec_pwr_lvl == coex_dm->cur_bt_dec_pwr_lvl)
-			return;
-	}
-	halbtc8812a2ant_set_fw_dec_bt_pwr(btcoexist,
-					  coex_dm->cur_bt_dec_pwr_lvl);
-
-	coex_dm->pre_bt_dec_pwr_lvl = coex_dm->cur_bt_dec_pwr_lvl;
-}
-
-void halbtc8812a2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,
-			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s set FW Dac Swing level = %d\n",
-		    (force_exec ? "force to" : ""), fw_dac_swing_lvl);
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_fw_dac_swing_lvl ==
-		    coex_dm->cur_fw_dac_swing_lvl)
-			return;
-	}
-
-	halbtc8812a2ant_set_fw_dac_swing_level(btcoexist,
-					       coex_dm->cur_fw_dac_swing_lvl);
-
-	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
-}
-
-void halbtc8812a2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,
-		IN boolean rx_rf_shrink_on)
-{
-	if (rx_rf_shrink_on) {
-		/* Shrink RF Rx LPF corner */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Shrink RF Rx LPF corner!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e, 0xfffff,
-					  0xffffc);
-	} else {
-		/* Resume RF Rx LPF corner */
-		/* After initialized, we can use coex_dm->bt_rf_0x1e_backup */
-		if (btcoexist->initilized) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Resume RF Rx LPF corner!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-					  0xfffff, coex_dm->bt_rf_0x1e_backup);
-		}
-	}
-}
-
-void halbtc8812a2ant_rf_shrink(IN struct btc_coexist *btcoexist,
-		       IN boolean force_exec, IN boolean rx_rf_shrink_on)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s turn Rx RF Shrink = %s\n",
-		    (force_exec ? "force to" : ""),
-		    ((rx_rf_shrink_on) ? "ON" : "OFF"));
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_rf_rx_lpf_shrink = rx_rf_shrink_on;
-
-	if (!force_exec) {
-		if (coex_dm->pre_rf_rx_lpf_shrink ==
-		    coex_dm->cur_rf_rx_lpf_shrink)
-			return;
-	}
-	halbtc8812a2ant_set_sw_rf_rx_lpf_corner(btcoexist,
-						coex_dm->cur_rf_rx_lpf_shrink);
-
-	coex_dm->pre_rf_rx_lpf_shrink = coex_dm->cur_rf_rx_lpf_shrink;
-}
-
-void halbtc8812a2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8	tmp_u1;
-
-	tmp_u1 = btcoexist->btc_read_1byte(btcoexist, 0x4fd);
-	tmp_u1 |= BIT(0);
-	if (low_penalty_ra) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Tx rate adaptive, set low penalty!!\n");
-		BTC_TRACE(trace_buf);
-		tmp_u1 &= ~BIT(2);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Tx rate adaptive, set normal!!\n");
-		BTC_TRACE(trace_buf);
-		tmp_u1 |= BIT(2);
-	}
-
-	btcoexist->btc_write_1byte(btcoexist, 0x4fd, tmp_u1);
-}
-
-void halbtc8812a2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	return;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s turn LowPenaltyRA = %s\n",
-		    (force_exec ? "force to" : ""),
-		    ((low_penalty_ra) ? "ON" : "OFF"));
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8812a2ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8812a2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,
-				       IN u32 level)
-{
-	u8	val = (u8)level;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Write SwDacSwing = 0x%x\n",
-		    level);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc5b, 0x3e, val);
-}
-
-void halbtc8812a2ant_set_sw_full_time_dac_swing(IN struct btc_coexist
-		*btcoexist, IN boolean sw_dac_swing_on, IN u32 sw_dac_swing_lvl)
-{
-	if (sw_dac_swing_on)
-		halbtc8812a2ant_set_dac_swing_reg(btcoexist, sw_dac_swing_lvl);
-	else
-		halbtc8812a2ant_set_dac_swing_reg(btcoexist, 0x18);
-}
-
-
-void halbtc8812a2ant_dac_swing(IN struct btc_coexist *btcoexist,
-	IN boolean force_exec, IN boolean dac_swing_on, IN u32 dac_swing_lvl)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s turn DacSwing=%s, dac_swing_lvl=0x%x\n",
-		(force_exec ? "force to" : ""), ((dac_swing_on) ? "ON" : "OFF"),
-		    dac_swing_lvl);
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_dac_swing_on = dac_swing_on;
-	coex_dm->cur_dac_swing_lvl = dac_swing_lvl;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_dac_swing_on == coex_dm->cur_dac_swing_on) &&
-		    (coex_dm->pre_dac_swing_lvl ==
-		     coex_dm->cur_dac_swing_lvl))
-			return;
-	}
-	delay_ms(30);
-	halbtc8812a2ant_set_sw_full_time_dac_swing(btcoexist, dac_swing_on,
-			dac_swing_lvl);
-
-	coex_dm->pre_dac_swing_on = coex_dm->cur_dac_swing_on;
-	coex_dm->pre_dac_swing_lvl = coex_dm->cur_dac_swing_lvl;
-}
-
-void halbtc8812a2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,
-				      IN boolean adc_back_off)
-{
-	if (adc_back_off) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x8db, 0x60, 0x3);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x8db, 0x60, 0x1);
-	}
-}
-
-void halbtc8812a2ant_adc_back_off(IN struct btc_coexist *btcoexist,
-			  IN boolean force_exec, IN boolean adc_back_off)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s turn AdcBackOff = %s\n",
-		    (force_exec ? "force to" : ""),
-		    ((adc_back_off) ? "ON" : "OFF"));
-	BTC_TRACE(trace_buf);
-
-	coex_dm->cur_adc_back_off = adc_back_off;
-
-	if (!force_exec) {
-		if (coex_dm->pre_adc_back_off == coex_dm->cur_adc_back_off)
-			return;
-	}
-	halbtc8812a2ant_set_adc_back_off(btcoexist, coex_dm->cur_adc_back_off);
-
-	coex_dm->pre_adc_back_off = coex_dm->cur_adc_back_off;
-}
-
-void halbtc8812a2ant_set_agc_table(IN struct btc_coexist *btcoexist,
-				   IN boolean agc_table_en)
-{
-	u8		rssi_adjust_val = 0;
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x28F4B);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x10AB2);
-		rssi_adjust_val = 8;
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x2884B);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x104B2);
-	}
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	/* set rssi_adjust_val for wifi module. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
-			   &rssi_adjust_val);
-}
-
-void halbtc8812a2ant_agc_table(IN struct btc_coexist *btcoexist,
-			       IN boolean force_exec, IN boolean agc_table_en)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s %s Agc Table\n",
-		    (force_exec ? "force to" : ""),
-		    ((agc_table_en) ? "Enable" : "Disable"));
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_agc_table_en = agc_table_en;
-
-	if (!force_exec) {
-		if (coex_dm->pre_agc_table_en == coex_dm->cur_agc_table_en)
-			return;
-	}
-	halbtc8812a2ant_set_agc_table(btcoexist, agc_table_en);
-
-	coex_dm->pre_agc_table_en = coex_dm->cur_agc_table_en;
-}
-
-void halbtc8812a2ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8812a2ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n",
-		(force_exec ? "force to" : ""), val0x6c0, val0x6c4, val0x6c8,
-		    val0x6cc);
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8812a2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8812a2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	switch (type) {
-	case 0:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5ffb5ffb, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0x5fdf5fdf, 0x5fdb5fdb, 0xffffff, 0x3);
-		break;
-	case 4:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0xdfffdfff, 0x5fdb5fdb, 0xffffff, 0x3);
-		break;
-	case 5:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0x5ddd5ddd, 0x5fdb5fdb, 0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 7:
-		if (coex_sta->scan_ap_num <= 5)
-			halbtc8812a2ant_coex_table(btcoexist,
-					   force_exec, 0xffffffff, 0xfafafafa,
-						   0xffffff, 0x3);
-		else
-			halbtc8812a2ant_coex_table(btcoexist,
-					   force_exec, 0xffffffff, 0x5a5a5a5a,
-						   0xffffff, 0x3);
-		break;
-	case 8:
-		halbtc8812a2ant_coex_table(btcoexist, force_exec,
-				   0x5f5f5f5f, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-
-	default:
-		break;
-	}
-}
-
-void halbtc8812a2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8	data_len = 3;
-	u8	buf[5] = {0};
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s BT Ignore Wlan_Act\n",
-		    (enable ? "Enable" : "Disable"));
-	BTC_TRACE(trace_buf);
-
-	buf[0] = data_len;
-	buf[1] = 0x1;			/* OP_Code */
-	buf[2] = 0x1;			/* OP_Code_Length */
-	if (enable)
-		buf[3] = 0x1;		/* OP_Code_Content */
-	else
-		buf[3] = 0x0;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_CTRL_BT_COEX,
-			   (void *)&buf[0]);
-}
-
-void halbtc8812a2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], %s turn Ignore WlanAct %s\n",
-		    (force_exec ? "force to" : ""), (enable ? "ON" : "OFF"));
-	BTC_TRACE(trace_buf);
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8812a2ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8812a2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], FW for 1Ant AP mode\n");
-			BTC_TRACE(trace_buf);
-			real_byte1 &= ~BIT(4);
-			real_byte1 |= BIT(5);
-
-			real_byte5 |= BIT(5);
-			real_byte5 &= ~BIT(6);
-		}
-	}
-
-	h2c_parameter[0] = real_byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = real_byte5;
-
-
-	coex_dm->ps_tdma_para[0] = real_byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = real_byte5;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n",
-		    h2c_parameter[0],
-		    h2c_parameter[1] << 24 | h2c_parameter[2] << 16 |
-		    h2c_parameter[3] << 8 | h2c_parameter[4]);
-
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-void halbtc8812a2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8812a2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8812a2ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8812a2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,
-			   IN boolean shrink_rx_lpf, IN boolean low_penalty_ra,
-			   IN boolean limited_dig, IN boolean bt_lna_constrain)
-{
-	/*
-	u32	wifi_bw;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if(BTC_WIFI_BW_HT40 != wifi_bw)
-	{
-		if (shrink_rx_lpf)
-			shrink_rx_lpf = false;
-	}
-	*/
-
-	halbtc8812a2ant_rf_shrink(btcoexist, NORMAL_EXEC, shrink_rx_lpf);
-	/* halbtc8812a2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra); */
-}
-
-void halbtc8812a2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,
-			   IN boolean agc_table_shift, IN boolean adc_back_off,
-			   IN boolean sw_dac_swing, IN u32 dac_swing_lvl)
-{
-	/* halbtc8812a2ant_agc_table(btcoexist, NORMAL_EXEC, agc_table_shift); */
-	halbtc8812a2ant_adc_back_off(btcoexist, NORMAL_EXEC, adc_back_off);
-	halbtc8812a2ant_dac_swing(btcoexist, NORMAL_EXEC, sw_dac_swing,
-				  dac_swing_lvl);
-}
-
-void halbtc8812a2ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean init_hwcfg, IN boolean wifi_off)
-{
-	u8			u8tmp = 0;
-
-	if (init_hwcfg) {
-		btcoexist->btc_write_4byte(btcoexist, 0x900, 0x00000400);
-		btcoexist->btc_write_1byte(btcoexist, 0x76d, 0x1);
-	} else if (wifi_off) {
-
-		}
-
-	/* ext switch setting */
-	switch (ant_pos_type) {
-	case BTC_ANT_WIFI_AT_CPL_MAIN:
-		u8tmp = btcoexist->btc_read_1byte(btcoexist, 0xcb7);
-		u8tmp &= ~BIT(2);
-		u8tmp |= BIT(3);
-		btcoexist->btc_write_1byte(btcoexist, 0xcb7, u8tmp);
-		break;
-	case BTC_ANT_WIFI_AT_CPL_AUX:
-		u8tmp = btcoexist->btc_read_1byte(btcoexist, 0xcb7);
-		u8tmp &= ~BIT(3);
-		u8tmp |= BIT(2);
-		btcoexist->btc_write_1byte(btcoexist, 0xcb7, u8tmp);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8812a2ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	s8			wifi_duration_adjust = 0x0;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	if (!force_exec) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], pre_ps_tdma_on = %d, cur_ps_tdma_on = %d!!\n",
-			    coex_dm->pre_ps_tdma_on, coex_dm->cur_ps_tdma_on);
-		BTC_TRACE(trace_buf);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], pre_ps_tdma = %d, cur_ps_tdma = %d!!\n",
-			    coex_dm->pre_ps_tdma, coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-
-	if (coex_sta->scan_ap_num >= 40)
-		wifi_duration_adjust = -15;
-	else if (coex_sta->scan_ap_num >= 20)
-		wifi_duration_adjust = -10;
-
-	/*
-		if (!coex_sta->force_lps_on)
-		{
-			ps_tdma_byte0_val = 0x61;
-			ps_tdma_byte3_val = 0x11;
-			ps_tdma_byte4_val = 0x10;
-		}
-
-
-		if (  (type == 3) || (type == 13) || (type == 14) )
-		{
-			ps_tdma_byte4_val = ps_tdma_byte4_val & 0xbf;
-
-			if (!wifi_busy)
-			 ps_tdma_byte4_val = ps_tdma_byte4_val | 0x1;
-		}
-
-		if (bt_link_info->slave_role == true)
-			ps_tdma_byte4_val = ps_tdma_byte4_val | 0x1;
-
-	*/
-	if (turn_on) {
-		switch (type) {
-		case 1:
-		default:	/* d1,wb */
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0x11, 0x10);
-			break;
-		case 2:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x32, 0x03, 0x11, 0x10);
-			break;
-		case 3:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x28, 0x03, 0x11, 0x10);
-			break;
-		case 4:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1e, 0x03, 0x11, 0x10);
-			break;
-		case 5:		/* d1,pb,TXpause */
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x3c, 0x03, 0x90, 0x10);
-			break;
-		case 6:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x32, 0x03, 0x90, 0x10);
-			break;
-		case 7:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x28, 0x03, 0x90, 0x10);
-			break;
-		case 8:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x1e, 0x03, 0x90, 0x10);
-			break;
-		case 9:		/* d1,bb */
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0x31, 0x10);
-			break;
-		case 10:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x32, 0x03, 0x31, 0x10);
-			break;
-		case 11:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x28, 0x03, 0x31, 0x10);
-			break;
-		case 12:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1e, 0x03, 0x31, 0x10);
-			break;
-		case 13:	/* d1,bb,TXpause */
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0x30, 0x10);
-			break;
-		case 14:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x32, 0x03, 0x30, 0x10);
-			break;
-		case 15:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x28, 0x03, 0x30, 0x10);
-			break;
-		case 16:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1e, 0x03, 0x30, 0x10);
-			break;
-		case 17:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x3, 0x11, 0x11);
-			break;
-		case 18:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x5, 0x5, 0xe1, 0x90);
-			break;
-		case 19:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x25, 0xe1, 0x90);
-			break;
-		case 20:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x25, 0x60, 0x90);
-			break;
-		case 21:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x3, 0x70, 0x90);
-			break;
-		case 22:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x1a, 0x1a, 0x21, 0x10);
-			break;
-		case 23:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x03, 0x31, 0x10);
-			break;
-
-		case 71:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1a, 0x1a, 0xe1, 0x90);
-			break;
-
-		/* following cases is for wifi rssi low, started from 81 */
-		case 80:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x3c, 0x3, 0x90, 0x50);
-			break;
-		case 81:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x53,
-				      0x3a + wifi_duration_adjust, 0x3, 0x90,
-						      0x50);
-			break;
-		case 82:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x53,
-				      0x30 + wifi_duration_adjust, 0x03, 0x90,
-						      0x50);
-			break;
-		case 83:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x21, 0x03, 0x90, 0x50);
-			break;
-		case 84:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x15, 0x3, 0x90, 0x50);
-			break;
-		case 85:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x1d, 0x1d, 0x80, 0x50);
-			break;
-		case 86:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x15, 0x15, 0x80, 0x50);
-			break;
-		}
-	} else {
-		/* disable PS tdma */
-		switch (type) {
-		case 0: /* ANT2PTA, 0x778=0x1 */
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x8,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		case 1: /* ANT2BT, 0x778=3 */
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x8, 0x0);
-			delay_ms(5);
-			halbtc8812a2ant_set_ant_path(btcoexist,
-				     BTC_ANT_WIFI_AT_CPL_AUX, false, false);
-			break;
-		case 2: /* ANT2BT, 0x778=3 */
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x8, 0x0);
-			delay_ms(5);
-			halbtc8812a2ant_set_ant_path(btcoexist,
-				     BTC_ANT_WIFI_AT_CPL_MAIN, false, false);
-			break;
-		default:
-			halbtc8812a2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		}
-	}
-
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-
-void halbtc8812a2ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						0);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						0);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-
-void halbtc8812a2ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-	boolean	ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		ps_type = BTC_PS_WIFI_NATIVE;
-		lps_val = 0x0;
-		rpwm_val = 0x0;
-	}
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	case BTC_PS_LPS_ON:
-		halbtc8812a2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, true);
-		halbtc8812a2ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma. */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		coex_sta->force_lps_on = true;
-		break;
-	case BTC_PS_LPS_OFF:
-		halbtc8812a2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8812a2ant_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-	/* fw all off */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-	halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8812a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8812a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	/* hw all off */
-	halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8812a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-	halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 1);
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6);
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8812a2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8812a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8812a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-void halbtc8812a2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_stack_info	*stack_info = &btcoexist->stack_info;
-	static u32	bt_disable_cnt = 0;
-	boolean			bt_active = true, bt_disabled = false;
-
-	/* This function check if bt is disabled */
-
-	/* only 8812a need to consider if core stack is installed. */
-	/*if (!stack_info->hci_version)*/
-	/*bt_active = false;*/
-
-	bt_disabled = btcoexist->bt_info.bt_disabled;
-
-	if (coex_sta->pre_bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			(coex_sta->pre_bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->pre_bt_disabled = bt_disabled;
-
-		if (bt_disabled) {
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						2);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		}
-	}
-}
-
-
-void halbtc8812a2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 3);
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8812a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8812a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-
-boolean halbtc8812a2ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				common = false, wifi_connected = false, wifi_busy = false;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8812a2ant_action_bt_inquiry(btcoexist);
-		return true;
-	}
-
-	if (bt_link_info->sco_exist || bt_link_info->hid_exist)
-		halbtc8812a2ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 0, 0, 0);
-	else
-		halbtc8812a2ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-	if (!wifi_connected) {
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non-connected idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		if ((BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		     coex_dm->bt_status) ||
-		    (BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE ==
-		     coex_dm->bt_status)) {
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						0);
-		} else {
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						1);
-		}
-
-		halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8812a2ant_sw_mechanism1(btcoexist, false, false, false,
-					      false);
-		halbtc8812a2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-
-		common = true;
-	} else {
-		if (BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, false, 0x8);
-
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						0);
-			halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 6);
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-
-			common = true;
-		} else if (BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE ==
-			   coex_dm->bt_status) {
-			if (bt_hs_on)
-				return false;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi connected + BT connected-idle!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, false, 0x8);
-
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						0);
-			halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 6);
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-
-			common = true;
-		} else {
-			if (wifi_busy) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-				common = false;
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-
-				halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-
-				halbtc8812a2ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, false, false, 0x8);
-
-				halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 17);
-
-				halbtc8812a2ant_fw_dac_swing_lvl(btcoexist,
-							 NORMAL_EXEC, 6);
-				halbtc8812a2ant_dec_bt_pwr(btcoexist,
-							   NORMAL_EXEC, 0);
-				halbtc8812a2ant_sw_mechanism1(btcoexist, false,
-						      false, false, false);
-				halbtc8812a2ant_sw_mechanism2(btcoexist, false,
-						      false, false, 0x18);
-				common = true;
-			}
-		}
-	}
-
-	return common;
-}
-
-void halbtc8812a2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,
-		IN boolean sco_hid, IN boolean tx_pause, IN u8 max_interval)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], TdmaDurationAdjust()\n");
-	BTC_TRACE(trace_buf);
-
-	coex_dm->auto_tdma_adjust_low_rssi = false;
-
-	if (!coex_dm->auto_tdma_adjust) {
-		coex_dm->auto_tdma_adjust = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], first run TdmaDurationAdjust()!!\n");
-		BTC_TRACE(trace_buf);
-		{
-			if (sco_hid) {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					} else if (max_interval == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (max_interval == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					} else if (max_interval == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (max_interval == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			} else {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (max_interval == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (max_interval == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (max_interval == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (max_interval == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					}
-				}
-			}
-		}
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2 */
-		retry_count = coex_sta->bt_retry_cnt;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], retry_count = %d\n",
-			    retry_count);
-		BTC_TRACE(trace_buf);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], up=%d, dn=%d, m=%d, n=%d, wait_count=%d\n",
-			    up, dn, m, n, wait_count);
-		BTC_TRACE(trace_buf);
-
-		result = 0;
-		wait_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if 連續 n 個2秒 retry count為0, 則調寬WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Increase wifi duration!!\n");
-				BTC_TRACE(trace_buf);
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if 連續 2 個2秒 retry count< 3, 則調窄WiFi duration */
-				if (wait_count <= 2)
-					m++; /* 避免一直在兩個level中來回 */
-				else
-					m = 1;
-
-				if (m >= 20)  /* m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration. */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Decrease wifi duration for retry_counter<3!!\n");
-				BTC_TRACE(trace_buf);
-			}
-		} else { /* retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration */
-			if (wait_count == 1)
-				m++; /* 避免一直在兩個level中來回 */
-			else
-				m = 1;
-
-			if (m >= 20)  /* m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration. */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Decrease wifi duration for retry_counter>3!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], max Interval = %d\n",
-			    max_interval);
-		BTC_TRACE(trace_buf);
-
-		if (max_interval == 1) {
-			if (tx_pause) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], TxPause = 1\n");
-				BTC_TRACE(trace_buf);
-
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 5);
-					coex_dm->ps_tdma_du_adj_type = 5;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 13);
-					coex_dm->ps_tdma_du_adj_type = 13;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					}
-				}
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], TxPause = 0\n");
-				BTC_TRACE(trace_buf);
-
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 1);
-					coex_dm->ps_tdma_du_adj_type = 1;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 9);
-					coex_dm->ps_tdma_du_adj_type = 9;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					}
-				}
-			}
-		} else if (max_interval == 2) {
-			if (tx_pause) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], TxPause = 1\n");
-				BTC_TRACE(trace_buf);
-
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					}
-				}
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], TxPause = 0\n");
-				BTC_TRACE(trace_buf);
-
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					}
-				}
-			}
-		} else if (max_interval == 3) {
-			if (tx_pause) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], TxPause = 1\n");
-				BTC_TRACE(trace_buf);
-
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				}
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], TxPause = 0\n");
-				BTC_TRACE(trace_buf);
-
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8812a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8812a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			}
-		}
-	}
-
-	/* 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 (coex_dm->cur_ps_tdma != coex_dm->ps_tdma_du_adj_type) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], PsTdma type dismatch!!!, cur_ps_tdma=%d, recordPsTdma=%d\n",
-			    coex_dm->cur_ps_tdma, coex_dm->ps_tdma_du_adj_type);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (!scan && !link && !roam)
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-}
-
-/* ******************
- * pstdma for wifi rssi low
- * ****************** */
-void halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-	IN struct btc_coexist *btcoexist/* , */ /* IN u8 wifi_status */)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0, bt_info_ext;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low()\n");
-	BTC_TRACE(trace_buf);
-#if 0
-	if ((BT_8812A_2ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN ==
-	     wifi_status) ||
-	    (BT_8812A_2ANT_WIFI_STATUS_CONNECTED_SCAN == wifi_status) ||
-	    (BT_8812A_2ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT ==
-	     wifi_status)) {
-		if (coex_dm->cur_ps_tdma != 81 &&
-		    coex_dm->cur_ps_tdma != 82 &&
-		    coex_dm->cur_ps_tdma != 83 &&
-		    coex_dm->cur_ps_tdma != 84) {
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						82);
-			coex_dm->ps_tdma_du_adj_type = 82;
-
-			up = 0;
-			dn = 0;
-			m = 1;
-			n = 3;
-			result = 0;
-			wait_count = 0;
-		}
-		return;
-	}
-#endif
-	coex_dm->auto_tdma_adjust = false;
-
-	retry_count = coex_sta->bt_retry_cnt;
-	bt_info_ext = coex_sta->bt_info_ext;
-
-	if (!coex_dm->auto_tdma_adjust_low_rssi) {
-		coex_dm->auto_tdma_adjust_low_rssi = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], first run TdmaDurationAdjustForWifiRssiLow()!!\n");
-		BTC_TRACE(trace_buf);
-
-		if (BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(bt_info_ext)) {
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						83);
-			coex_dm->ps_tdma_du_adj_type = 83;
-		} else {
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						82);
-			coex_dm->ps_tdma_du_adj_type = 82;
-		}
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2
-		*		retry_count = coex_sta->bt_retry_cnt;
-		*		bt_info_ext = coex_sta->bt_info_ext; */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], retry_count = %d\n",
-			    retry_count);
-		BTC_TRACE(trace_buf);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], up=%d, dn=%d, m=%d, n=%d, wait_count=%d\n",
-			    up, dn, m, n, wait_count);
-		BTC_TRACE(trace_buf);
-		result = 0;
-		wait_count++;
-
-		if ((coex_sta->low_priority_tx) > 1050 ||
-		    (coex_sta->low_priority_rx) > 1250)
-			retry_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if 連續 n 個2秒 retry count為0, 則調寬WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Increase wifi duration!!\n");
-				BTC_TRACE(trace_buf);
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if 連續 2 個2秒 retry count< 3, 則調窄WiFi duration */
-				if (wait_count <= 2)
-					m++; /* 避免一直在兩個level中來回 */
-				else
-					m = 1;
-
-				if (m >= 20)  /* m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration. */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Decrease wifi duration for retry_counter<3!!\n");
-				BTC_TRACE(trace_buf);
-			}
-		} else { /* retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration */
-			if (wait_count == 1)
-				m++; /* 避免一直在兩個level中來回 */
-			else
-				m = 1;
-
-			if (m >= 20)  /* m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration. */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Decrease wifi duration for retry_counter>3!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		if (result == -1) {
-			/*
-						if( (BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-							((coex_dm->cur_ps_tdma == 81) ||(coex_dm->cur_ps_tdma == 82)) )
-						{
-							halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 84);
-							coex_dm->ps_tdma_du_adj_type = 84;
-						}
-			*/
-			if (coex_dm->cur_ps_tdma == 80) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 82);
-				coex_dm->ps_tdma_du_adj_type = 82;
-			} else if (coex_dm->cur_ps_tdma == 81) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 82);
-				coex_dm->ps_tdma_du_adj_type = 82;
-			} else if (coex_dm->cur_ps_tdma == 82) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 83);
-				coex_dm->ps_tdma_du_adj_type = 83;
-			} else if (coex_dm->cur_ps_tdma == 83) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 84);
-				coex_dm->ps_tdma_du_adj_type = 84;
-			}
-		} else if (result == 1) {
-			/*
-						if( (BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(bt_info_ext)) &&
-							((coex_dm->cur_ps_tdma == 81) ||(coex_dm->cur_ps_tdma == 82)) )
-						{
-							halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 83);
-							coex_dm->ps_tdma_du_adj_type = 83;
-						}
-			*/
-			if (coex_dm->cur_ps_tdma == 84) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 83);
-				coex_dm->ps_tdma_du_adj_type = 83;
-			} else if (coex_dm->cur_ps_tdma == 83) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 82);
-				coex_dm->ps_tdma_du_adj_type = 82;
-			} else if (coex_dm->cur_ps_tdma == 82) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 81);
-				coex_dm->ps_tdma_du_adj_type = 81;
-			} else if ((coex_dm->cur_ps_tdma == 81) &&
-				   ((coex_sta->scan_ap_num <= 5))) {
-				halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							true, 81);
-				coex_dm->ps_tdma_du_adj_type = 81;
-			}
-		}
-
-		if (coex_dm->cur_ps_tdma != 80 &&
-		    coex_dm->cur_ps_tdma != 81 &&
-		    coex_dm->cur_ps_tdma != 82 &&
-		    coex_dm->cur_ps_tdma != 83 &&
-		    coex_dm->cur_ps_tdma != 84) {
-			/* recover to previous adjust type */
-			halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		}
-	}
-}
-
-void halbtc8812a2ant_get_bt_rssi_threshold(IN struct btc_coexist *btcoexist,
-		IN u8 *pThres0, IN u8 *pThres1)
-{
-	u8 ant_type;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_ANT_TYPE, &ant_type);
-
-
-	switch (ant_type) {
-	case BTC_ANT_TYPE_0:
-		*pThres0 = 100;
-		*pThres1 = 100;
-		break;
-	case BTC_ANT_TYPE_1:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	case BTC_ANT_TYPE_2:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	case BTC_ANT_TYPE_3:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	case BTC_ANT_TYPE_4:
-		*pThres0 = 34;
-		*pThres1 = 42;
-		break;
-	default:
-		break;
-	}
-}
-
-
-
-void halbtc8812a2ant_action_sco(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-
-	/*	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0, &bt_thresh1); */
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42);
-
-	/* power save state */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* coex table */
-	if (BTC_RSSI_LOW(bt_rssi_state))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	/* pstdma */
-	if (BTC_RSSI_LOW(bt_rssi_state))
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 13);
-	else
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9);
-
-	/* decrease BT power */
-	if (BTC_RSSI_LOW(bt_rssi_state))
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	else if (BTC_RSSI_MEDIUM(bt_rssi_state))
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x6);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x6);
-		}
-	}
-}
-
-void halbtc8812a2ant_action_sco_hid(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	/*	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0, &bt_thresh1); */
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42);
-
-	/* power save state */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* coex table */
-	halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	/* pstdma */
-	if (BTC_RSSI_LOW(bt_rssi_state))
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 13);
-	else
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9);
-
-	/* decrease BT power	 */
-	if (BTC_RSSI_LOW(bt_rssi_state))
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	else if (BTC_RSSI_MEDIUM(bt_rssi_state))
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, true, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x6);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x6);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x6);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x6);
-		}
-	}
-}
-
-void halbtc8812a2ant_action_hid(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		anttype = 0;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-
-	/*	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0, &bt_thresh1);
-	 *	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0, bt_thresh1); */
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42);
-
-
-	if (anttype == 0) { /* ANTTYPE = 0   92E 2ant with SPDT */
-		/* power save state & pstdma & coex table */
-		coex_dm->auto_tdma_adjust = false;
-		coex_dm->auto_tdma_adjust_low_rssi = false;
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if (anttype ==
-		1) { /* 92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation */
-		/* power save state & pstdma & coex table */
-		coex_dm->auto_tdma_adjust = false;
-		coex_dm->auto_tdma_adjust_low_rssi = false;
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-		halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if (anttype ==
-		2) { /* ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, true, 9);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 3);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, true, 9);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 3);
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, true, 9);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 3);
-		}
-	} else if (anttype ==
-		   3) {	/* ANTTYPE = 3,  92E 3ant with good ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		}
-	} else {	/* ANTTYPE = 4 for test */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	}
-
-
-	/* power save state */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* coex table */
-	halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* pstdma */
-	halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-void halbtc8812a2ant_action_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		anttype = 0;
-	boolean			ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-	/*	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0, &bt_thresh1);
-	 *	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0, bt_thresh1); */
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42);
-
-	/*	anttype = 4; */
-
-	if (anttype == 0) { /* ANTTYPE = 0   92E 2ant with SPDT */
-
-		if (coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A) {
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						0);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		} else {
-			if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			    (!BTC_RSSI_LOW(bt_rssi_state))) {
-				/* WIFI RSSI = high & BT RSSI = high & shielding room */
-				halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-				halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-					btcoexist);
-				halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-			} else {	/* WIFI RSSI || BT RSSI == low */
-				halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-				halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-					btcoexist);
-				halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-			}
-		}
-
-		/* power save state & pstdma & coex table
-		*
-		if(BTC_RSSI_HIGH(wifi_rssi_state) &&	(!BTC_RSSI_LOW(bt_rssi_state)) && (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A))
-		{
-			halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		}
-		else if (BTC_RSSI_HIGH(wifi_rssi_state)&&(!BTC_RSSI_LOW(bt_rssi_state)) && (coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A))
-		{
-		coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-			halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		}
-		else
-		{
-			halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-		}
-		*/
-	} else if (anttype ==
-		1) { /* 92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_tdma_duration_adjust(btcoexist, false,
-					     false, 1);	/* shielding room */
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-
-	} else if (anttype ==
-		2) { /* ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_tdma_duration_adjust(btcoexist, false,
-							     false, 1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 5);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	} else if (anttype ==
-		   3) {	/* ANTTYPE = 3,  92E 3ant with good ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		}
-	} else {	/* ANTTYPE = 4 for test */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	}
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* decrease BT power
-	*
-	if(BTC_RSSI_LOW(bt_rssi_state))
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	else if(BTC_RSSI_MEDIUM(bt_rssi_state))
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else if (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)
-		halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	*/
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8812a2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	/*	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0, &bt_thresh1); */
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42);
-
-	/* power save state */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* coex table	 */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-	/* pstdma	 */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, false, false,
-						     2);
-	else
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, false, true, 2);
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	/*
-
-		if(BTC_RSSI_LOW(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-		else if(BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	*/
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x6);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x6);
-		}
-	}
-}
-
-void halbtc8812a2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-
-
-	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	/*	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42); */
-
-	/* power save state */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-	else
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50,
-						 0x4);
-
-	/* coex table */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* pstdma */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 1);
-	else
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 85);
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* PAN(HS) only */
-void halbtc8812a2ant_action_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42);
-
-	/* power save state */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* coex table */
-	halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-	/* pstdma */
-	halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/*
-
-		if(BTC_RSSI_LOW(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-		else if(BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	*/
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* PAN(EDR)+A2DP */
-void halbtc8812a2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	/*	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42); */
-
-	/* power save state */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&	(!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-	else
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50,
-						 0x4);
-
-	/* coex table */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&	(!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* pstdma */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&	(!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, false, false,
-						     3);
-	else {
-		coex_dm->auto_tdma_adjust = false;
-		coex_dm->auto_tdma_adjust_low_rssi = false;
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 86);
-	}
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-
-void halbtc8812a2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-
-	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	/*	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42); */
-
-	/* power save state */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-	else
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50,
-						 0x4);
-
-	/* coex table */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* pstdma */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 10);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 14);
-	else
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 85);
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/*
-
-		if(BTC_RSSI_LOW(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-		else if(BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	*/
-	/* limited Rx */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-	else
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, true,
-					   0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* HID+A2DP+PAN(EDR) */
-void halbtc8812a2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	/*	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42); */
-
-	/* power save state */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0, 0x0);
-	else
-		halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50,
-						 0x4);
-
-	/* coex table */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* pstdma */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, true, false, 3);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, true, true, 3);
-	else {
-		coex_dm->auto_tdma_adjust = false;
-		halbtc8812a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 86);
-	}
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	/*
-
-		if(BTC_RSSI_LOW(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-		else if(BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	*/
-	/* limited Rx */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-	else
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, true,
-					   0x8);
-
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8812a2ant_action_hid_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		bt_thresh0 = 0, bt_thresh1 = 0;
-
-	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0,
-					      &bt_thresh1);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0,
-			bt_thresh1);
-
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	/*	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42); */
-
-	/* power save state */
-	halbtc8812a2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0,
-					 0x0);
-
-	/* coex table */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	else
-		halbtc8812a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* pstdma */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, true, false, 2);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, true, true, 2);
-	else
-		halbtc8812a2ant_tdma_duration_adjust(btcoexist, true, true, 2);
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/*
-
-		if(BTC_RSSI_LOW(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-		else if(BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	*/
-	/* limited Rx */
-	if (BTC_RSSI_HIGH(wifi_rssi_state) && (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-	else if (BTC_RSSI_LOW(wifi_rssi_state) &&
-		 (!BTC_RSSI_LOW(bt_rssi_state)))
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-	else
-		halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, true,
-					   0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8812a2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state = BTC_RSSI_STATE_HIGH,
-			bt_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32		wifi_bw;
-	u8		anttype = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_ANT_TYPE, &anttype);
-
-
-	/*	halbtc8812a2ant_get_bt_rssi_threshold(btcoexist, &bt_thresh0, &bt_thresh1);
-	 *	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, bt_thresh0, bt_thresh1); */
-
-	wifi_rssi_state = halbtc8812a2ant_wifi_rssi_state(btcoexist, 0, 2, 34,
-			  0);
-	bt_rssi_state = halbtc8812a2ant_bt_rssi_state(3, 34, 42);
-
-	if (anttype == 0) { /* ANTTYPE = 0	92E 2ant with SPDT */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, true,
-						83);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						0);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		} else {
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, true,
-						83);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-		}
-	} else if (anttype ==
-		1) { /* 92E 2ant with coupler and bad ant. isolation, 92E 3ant with bad ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 2);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						0);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		} else {
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, true,
-						83);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-		}
-	} else if (anttype ==
-		2) { /* ANTTYPE = 2, 92E 2ant with coupler and normal/good ant. isolation, 92E 3ant with normal ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 2);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						0);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, true,
-						83);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-		}
-	} else if (anttype ==
-		   3) {	/* ANTTYPE = 3,  92E 3ant with good ant. isolation */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-			halbtc8812a2ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-						1);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-		}
-	} else {	/* ANTTYPE = 4 for test */
-		/* power save state & pstdma & coex table */
-		if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		    (!BTC_RSSI_LOW(bt_rssi_state)) &&
-		    (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & shielding room */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		} else if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-			   (!BTC_RSSI_LOW(bt_rssi_state)) &&
-			(coex_sta->scan_ap_num > NOISY_AP_NUM_THRESH_8812A)) {
-			/* WIFI RSSI = high & BT RSSI = high & noisy environment */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		} else {	/* WIFI RSSI || BT RSSI == low */
-			halbtc8812a2ant_power_save_state(btcoexist,
-						 BTC_PS_LPS_ON, 0x50, 0x4);
-			halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low(
-				btcoexist);
-			halbtc8812a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 7);
-		}
-	}
-
-	/* decrease BT power */
-	halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/*
-
-		if(BTC_RSSI_LOW(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-		else if(BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else if (coex_sta->scan_ap_num < NOISY_AP_NUM_THRESH_8812A)
-			halbtc8812a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 4);
-	*/
-	/* limited Rx */
-	halbtc8812a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	/* fw dac swing level */
-	halbtc8812a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if (BTC_RSSI_HIGH(wifi_rssi_state)) {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8812a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8812a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8812a2ant_coex_under_5g(IN struct btc_coexist *btcoexist)
-{
-	halbtc8812a2ant_coex_all_off(btcoexist);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], Under 5G, force set BT to ignore Wlan active!!\n");
-	BTC_TRACE(trace_buf);
-	halbtc8812a2ant_ignore_wlan_act(btcoexist, NORMAL_EXEC, true);
-}
-/* **************************************************** */
-void halbtc8812a2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	boolean				wifi_under_5g = false;
-	u8				algorithm = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), run 5G coex setting!!<===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8812a2ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-
-	algorithm = halbtc8812a2ant_action_algorithm(btcoexist);
-	if (coex_sta->c2h_bt_inquiry_page &&
-	    (BT_8812A_2ANT_COEX_ALGO_PANHS != algorithm)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8812a2ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	coex_dm->cur_algorithm = algorithm;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Algorithm = %d\n",
-		    coex_dm->cur_algorithm);
-	BTC_TRACE(trace_buf);
-
-	if (halbtc8812a2ant_is_common_action(btcoexist)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant common.\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->auto_tdma_adjust = false;
-		coex_dm->auto_tdma_adjust_low_rssi = false;
-	} else {
-		if (coex_dm->cur_algorithm != coex_dm->pre_algorithm) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], pre_algorithm=%d, cur_algorithm=%d\n",
-				coex_dm->pre_algorithm, coex_dm->cur_algorithm);
-			BTC_TRACE(trace_buf);
-			coex_dm->auto_tdma_adjust = false;
-			coex_dm->auto_tdma_adjust_low_rssi = false;
-		}
-		switch (coex_dm->cur_algorithm) {
-		case BT_8812A_2ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_sco(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_SCO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = SCO+HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_sco_hid(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_hid(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_a2dp(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_a2dp_pan_hs(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_pan_edr(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_pan_hs(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_pan_edr_a2dp(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_pan_edr_hid(btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_hid_a2dp_pan_edr(
-				btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_hid_a2dp_pan_hs(
-				btcoexist);
-			break;
-		case BT_8812A_2ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_action_hid_a2dp(btcoexist);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8812a2ant_coex_all_off(btcoexist);
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-
-}
-
-void halbtc8812a2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up)
-{
-	u8	u8tmp = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 2Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	if (back_up) {
-		/* backup rf 0x1e value */
-		coex_dm->bt_rf_0x1e_backup =
-			btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-						  0xfffff);
-
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	}
-
-	/* ant sw control to BT */
-	halbtc8812a2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_CPL_AUX, true,
-				     false);
-
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	/* PTA parameter */
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, 0x0);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, 0xffff);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, 0x55555555);
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, 0x55555555);
-
-	/* coex parameters */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	/* disable PTA to avoid BT insn't on */
-	btcoexist->btc_write_1byte(btcoexist, 0x40, 0x00);
-
-	/* bt clock related */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x4);
-	u8tmp |= BIT(7);
-	btcoexist->btc_write_1byte(btcoexist, 0x4, u8tmp);
-
-	/* bt clock related */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x7);
-	u8tmp |= BIT(1);
-	btcoexist->btc_write_1byte(btcoexist, 0x7, u8tmp);
-
-	/* Give bt_coex_supported_version the default value */
-	coex_sta->bt_coex_supported_version = 0;
-
-}
-
-/* ************************************************************
- * work around function start with wa_halbtc8812a2ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8812a2ant_
- * ************************************************************ */
-void ex_halbtc8812a2ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8812a2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8812a2ant_init_hw_config(btcoexist, true);
-}
-
-void ex_halbtc8812a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8812a2ant_init_coex_dm(btcoexist);
-}
-
-
-void ex_halbtc8812a2ant_pta_off_on_notify(IN struct btc_coexist *btcoexist,
-		IN u8 bt_status)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], BToff/on notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_BT_OFF == bt_status) {
-		/* PTA off */
-		btcoexist->bt_info.bt_disabled = true;
-		halbtc8812a2ant_enable_pta(btcoexist, FORCE_EXEC, false);
-
-	} else {
-		/* PTA on */
-		btcoexist->bt_info.bt_disabled = false;
-		halbtc8812a2ant_enable_pta(btcoexist, FORCE_EXEC, true);
-	}
-
-}
-
-
-void ex_halbtc8812a2ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_stack_info		*stack_info = &btcoexist->stack_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	u32				phyver = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "Ant PG number/ Ant mechanism:",
-		   board_info->pg_ant_num, board_info->btdm_ant_num);
-	CL_PRINTF(cli_buf);
-
-#if 0
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "Antenna type:",
-		   board_info->ant_type);
-	CL_PRINTF(cli_buf);
-#endif
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d",
-		   "BT stack/ hci ext ver",
-		   ((stack_info->profile_notified) ? "Yes" : "No"),
-		   stack_info->hci_version);
-	CL_PRINTF(cli_buf);
-
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-	bt_coex_ver = coex_sta->bt_coex_supported_version & 0xff;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8812a_2ant, glcoex_ver_8812a_2ant,
-		   glcoex_ver_btdesired_8812a_2ant, bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" : (bt_coex_ver >=
-				   glcoex_ver_btdesired_8812a_2ant ? "Match" :
-				   "Mis-Match")));
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d",
-		   "W_FW/ B_FW/ Phy",
-		   fw_ver, bt_patch_ver, phyver);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt]",
-		   ((btcoexist->bt_info.bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi, coex_sta->bt_retry_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP",
-		   bt_link_info->sco_exist, bt_link_info->hid_exist,
-		   bt_link_info->pan_exist, bt_link_info->a2dp_exist);
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Info A2DP rate",
-		   (bt_info_ext & BIT(0)) ? "Basic rate" : "EDR rate");
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8812A_2ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8812a_2ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	/* Sw mechanism	 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Sw mechanism]============");
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ",
-		   "SM1[ShRf/ LpRA/ LimDig]",
-		   coex_dm->cur_rf_rx_lpf_shrink, coex_dm->cur_low_penalty_ra,
-		   coex_dm->limited_dig);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ",
-		   "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]",
-		   coex_dm->cur_agc_table_en, coex_dm->cur_adc_back_off,
-		   coex_dm->cur_dac_swing_on, coex_dm->cur_dac_swing_lvl);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ", "Rate Mask",
-		   btcoexist->bt_info.ra_mask);
-	CL_PRINTF(cli_buf);
-
-	/* Fw mechanism		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Fw mechanism]============");
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d/%d)",
-		   "PS TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   coex_dm->auto_tdma_adjust,
-		   coex_dm->auto_tdma_adjust_low_rssi);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "DecBtPwr/ IgnWlanAct",
-		   coex_dm->cur_bt_dec_pwr_lvl, coex_dm->cur_ignore_wlan_act);
-	CL_PRINTF(cli_buf);
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x",
-		   "RF-A, 0x1e initVal",
-		   coex_dm->bt_rf_0x1e_backup);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "backup ARFR1/ARFR2/RL/AMaxTime",
-		   coex_dm->backup_arfr_cnt1, coex_dm->backup_arfr_cnt2,
-		   coex_dm->backup_retry_limit,
-		   coex_dm->backup_ampdu_max_time);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
-	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x456);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "0x430/0x434/0x42a/0x456",
-		   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x ",
-		   "0x778 (W_Act)/ 0x6cc (CoTab Sel)",
-		   u8tmp[0], u8tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x8db);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0xc5b);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x8db(ADC)/0xc5b[29:25](DAC)",
-		   ((u8tmp[0] & 0x60) >> 5), ((u8tmp[1] & 0x3e) >> 1));
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xcb3);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0xcb7);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0xcb3/ 0xcb7",
-		   u8tmp[0], u8tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x974);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x40/ 0x4c[24:23]/ 0x974",
-		   u8tmp[0], ((u32tmp[0] & 0x01800000) >> 23), u32tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xa0a);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0xc50(DIG)/0xa0a(CCK-TH)",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11n-agg",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(high-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(low-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8812A_2ANT == 1)
-	halbtc8812a2ant_monitor_bt_ctr(btcoexist);
-#endif
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8812a2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	boolean	wifi_under_5g = false;
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->under_ips = true;
-		halbtc8812a2ant_coex_all_off(btcoexist);
-		halbtc8812a2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_CPL_AUX,
-					     false, true);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], IPS notify, force set BT to ignore Wlan active!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8812a2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-		ex_halbtc8812a2ant_media_status_notify(btcoexist,
-						       BTC_MEDIA_DISCONNECT);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->under_ips = false;
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G,
-				   &wifi_under_5g);
-		if (!wifi_under_5g) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], IPS notify, force set BT NOT to ignore Wlan active!!\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8812a2ant_ignore_wlan_act(btcoexist, FORCE_EXEC,
-							false);
-		}
-	}
-}
-
-void ex_halbtc8812a2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->under_lps = true;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8812a2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	if (BTC_SCAN_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-	} else if (BTC_SCAN_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-	}
-}
-
-void ex_halbtc8812a2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	if (BTC_ASSOCIATE_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-	} else if (BTC_ASSOCIATE_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void ex_halbtc8812a2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			data_len = 5;
-	u8			buf[6] = {0};
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    btcoexist->bt_info.bt_disabled)
-		return;
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		h2c_parameter[0] = 0x1;
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	buf[0] = data_len;
-	buf[1] = 0x5;				/* OP_Code */
-	buf[2] = 0x3;				/* OP_Code_Length */
-	buf[3] = h2c_parameter[0];	/* OP_Code_Content */
-	buf[4] = h2c_parameter[1];
-	buf[5] = h2c_parameter[2];
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_CTRL_BT_COEX,
-			   (void *)&buf[0]);
-}
-
-void ex_halbtc8812a2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	if (type == BTC_PACKET_DHCP) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], DHCP Packet notify\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void ex_halbtc8812a2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8			bt_info = 0;
-	u8			i, rsp_source = 0;
-	boolean			bt_busy = false, limited_dig = false;
-	boolean			wifi_connected = false, wifi_under_5g = false;
-
-	coex_sta->c2h_bt_info_req_sent = false;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8812A_2ANT_MAX)
-		rsp_source = BT_INFO_SRC_8812A_2ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	if (BT_INFO_SRC_8812A_2ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 + 10;
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if ((coex_sta->bt_info_ext & BIT(1))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-			if (wifi_connected)
-				ex_halbtc8812a2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8812a2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-		if ((coex_sta->bt_info_ext & BIT(3)) && !wifi_under_5g) {
-			/* BT already ignored WlanAct */
-			if (!btcoexist->manual_control &&
-			    !btcoexist->stop_coex_dm) {
-				if (!coex_sta->under_ips) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-					BTC_TRACE(trace_buf);
-					halbtc8812a2ant_ignore_wlan_act(
-						btcoexist, FORCE_EXEC, false);
-				}
-			}
-		} else {
-			/* BT already NOT ignore Wlan active, do nothing here. */
-
-			if (coex_sta->under_ips) {
-				/* work around for 8812a combo hw bug => when IPS, wlanAct is always high. */
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], wifi is under IPS, set BT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8812a2ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, true);
-			}
-		}
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8812A_2ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8812A_2ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-		coex_sta->acl_busy = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8812A_2ANT_B_FTP)
-			coex_sta->pan_exist = true;
-		else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8812A_2ANT_B_A2DP)
-			coex_sta->a2dp_exist = true;
-		else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8812A_2ANT_B_HID)
-			coex_sta->hid_exist = true;
-		else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8812A_2ANT_B_SCO_ESCO)
-			coex_sta->sco_exist = true;
-		else
-			coex_sta->sco_exist = false;
-		if (bt_info & BT_INFO_8812A_2ANT_B_ACL_BUSY)
-			coex_sta->acl_busy = true;
-		else
-			coex_sta->acl_busy = false;
-
-	}
-
-	halbtc8812a2ant_update_bt_link_info(btcoexist);
-
-	if (!(bt_info & BT_INFO_8812A_2ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info ==
-		BT_INFO_8812A_2ANT_B_CONNECTION) {	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if ((bt_info & BT_INFO_8812A_2ANT_B_SCO_ESCO) ||
-		   (bt_info & BT_INFO_8812A_2ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8812A_2ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info & BT_INFO_8812A_2ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8812A_2ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_dm->bt_status = BT_8812A_2ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((BT_8812A_2ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8812A_2ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8812A_2ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status)) {
-		bt_busy = true;
-		if (!wifi_under_5g)
-			limited_dig = true;
-	} else {
-		bt_busy = false;
-		limited_dig = false;
-	}
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	coex_dm->limited_dig = limited_dig;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_LIMITED_DIG, &limited_dig);
-
-	halbtc8812a2ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8812a2ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8812a2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_CPL_AUX, false,
-				     true);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], Halt notify, force set BT to ignore Wlan active!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8812a2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-	ex_halbtc8812a2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	/* 0x522=0xff, pause tx */
-	btcoexist->btc_write_1byte(btcoexist, 0x522, 0xff);
-	/* 0x40[7:6]=2'b01, modify BT mode. */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0xc0, 0x2);
-	/* PTA off. */
-#ifndef CONFIG_PCI_HCI
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x0);
-#endif
-}
-
-void ex_halbtc8812a2ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	static u8		dis_ver_info_cnt = 0;
-	u32				fw_ver = 0, bt_patch_ver = 0;
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_stack_info		*stack_info = &btcoexist->stack_info;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ==========================Periodical===========================\n");
-	BTC_TRACE(trace_buf);
-
-	if (dis_ver_info_cnt <= 5) {
-		dis_ver_info_cnt += 1;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ****************************************************************\n");
-		BTC_TRACE(trace_buf);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
-			    board_info->pg_ant_num, board_info->btdm_ant_num,
-			    board_info->btdm_ant_pos);
-		BTC_TRACE(trace_buf);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT stack/ hci ext ver = %s / %d\n",
-			    ((stack_info->profile_notified) ? "Yes" : "No"),
-			    stack_info->hci_version);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-				   &bt_patch_ver);
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
-			    glcoex_ver_date_8812a_2ant, glcoex_ver_8812a_2ant,
-			    fw_ver, bt_patch_ver, bt_patch_ver);
-		BTC_TRACE(trace_buf);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ****************************************************************\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((coex_sta->bt_coex_supported_version == 0) ||
-	    (coex_sta->bt_coex_supported_version == 0xffff))
-		coex_sta->bt_coex_supported_version =
-			btcoexist->btc_get_bt_coex_supported_version(btcoexist);
-
-#if (BT_AUTO_REPORT_ONLY_8812A_2ANT == 0)
-	halbtc8812a2ant_query_bt_info(btcoexist);
-	halbtc8812a2ant_monitor_bt_ctr(btcoexist);
-	halbtc8812a2ant_monitor_wifi_ctr(btcoexist);
-	halbtc8812a2ant_monitor_bt_enable_disable(btcoexist);
-#else
-	halbtc8812a2ant_monitor_wifi_ctr(btcoexist);
-
-	if (halbtc8812a2ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust ||
-	    coex_dm->auto_tdma_adjust_low_rssi)
-		halbtc8812a2ant_run_coexist_mechanism(btcoexist);
-#endif
-}
-
-void ex_halbtc8812a2ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata)
-{
-	switch (op_code) {
-	case BTC_DBG_SET_COEX_DEC_BT_PWR:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set Dec BT power\n");
-		BTC_TRACE(trace_buf);
-
-		{
-			u8	data_len = 4;
-			u8	buf[6] = {0};
-			u8	dec_bt_pwr = 0, pwr_level = 0;
-
-			if (op_len == 2) {
-				dec_bt_pwr = pdata[0];
-				pwr_level = pdata[1];
-
-				buf[0] = data_len;
-				buf[1] = 0x3;		/* OP_Code */
-				buf[2] = 0x2;		/* OP_Code_Length */
-
-				buf[3] = dec_bt_pwr;	/* OP_Code_Content */
-				buf[4] = pwr_level;
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Set Dec BT power=%d, pwr_level=%d\n",
-					    dec_bt_pwr, pwr_level);
-				BTC_TRACE(trace_buf);
-
-				btcoexist->btc_set(btcoexist,
-						   BTC_SET_ACT_CTRL_BT_COEX,
-						   (void *)&buf[0]);
-			}
-		}
-		break;
-
-	case BTC_DBG_SET_COEX_BT_AFH_MAP:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set BT AFH Map\n");
-		BTC_TRACE(trace_buf);
-		{
-			u8	data_len = 5;
-			u8	buf[6] = {0};
-
-			if (op_len == 3) {
-				buf[0] = data_len;
-				buf[1] = 0x5;				/* OP_Code */
-				buf[2] = 0x3;				/* OP_Code_Length */
-
-				buf[3] = pdata[0];			/* OP_Code_Content */
-				buf[4] = pdata[1];
-				buf[5] = pdata[2];
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Set BT AFH Map = %02x %02x %02x\n",
-					    pdata[0], pdata[1], pdata[2]);
-				BTC_TRACE(trace_buf);
-				btcoexist->btc_set(btcoexist,
-						   BTC_SET_ACT_CTRL_BT_COEX,
-						   (void *)&buf[0]);
-			}
-		}
-		break;
-
-	case BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Set BT Ignore Wlan Active\n");
-		BTC_TRACE(trace_buf);
-		{
-			u8	data_len = 3;
-			u8	buf[6] = {0};
-
-			if (op_len == 1) {
-				buf[0] = data_len;
-				buf[1] = 0x1;			/* OP_Code */
-				buf[2] = 0x1;			/* OP_Code_Length */
-
-				buf[3] = pdata[0];		/* OP_Code_Content */
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Set BT Ignore Wlan Active = 0x%x\n",
-					    pdata[0]);
-				BTC_TRACE(trace_buf);
-
-				btcoexist->btc_set(btcoexist,
-						   BTC_SET_ACT_CTRL_BT_COEX,
-						   (void *)&buf[0]);
-			}
-		}
-		break;
-
-	default:
-		break;
-	}
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a2ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a2ant.h
deleted file mode 100644
index 2b7f4aabe45b..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8812a2ant.h
+++ /dev/null
@@ -1,241 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8812A_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8812A 2Ant BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8812A_2ANT				0
-
-#define	BT_INFO_8812A_2ANT_B_FTP						BIT(7)
-#define	BT_INFO_8812A_2ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8812A_2ANT_B_HID						BIT(5)
-#define	BT_INFO_8812A_2ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8812A_2ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8812A_2ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8812A_2ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8812A_2ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8812A_2ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT(0))) ? true : false)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT		2
-#define	NOISY_AP_NUM_THRESH_8812A						50
-
-enum bt_info_src_8812a_2ant {
-	BT_INFO_SRC_8812A_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8812A_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8812A_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8812A_2ANT_MAX
-};
-
-enum bt_8812a_2ant_bt_status {
-	BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8812A_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8812A_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8812A_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8812A_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8812A_2ANT_BT_STATUS_MAX
-};
-
-enum bt_8812a_2ant_coex_algo {
-	BT_8812A_2ANT_COEX_ALGO_UNDEFINED		= 0x0,
-	BT_8812A_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8812A_2ANT_COEX_ALGO_SCO_HID		= 0x2,
-	BT_8812A_2ANT_COEX_ALGO_HID				= 0x3,
-	BT_8812A_2ANT_COEX_ALGO_A2DP			= 0x4,
-	BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS		= 0x5,
-	BT_8812A_2ANT_COEX_ALGO_PANEDR			= 0x6,
-	BT_8812A_2ANT_COEX_ALGO_PANHS			= 0x7,
-	BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x8,
-	BT_8812A_2ANT_COEX_ALGO_PANEDR_HID		= 0x9,
-	BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0xa,
-	BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS	= 0xb,
-	BT_8812A_2ANT_COEX_ALGO_HID_A2DP		= 0xc,
-	BT_8812A_2ANT_COEX_ALGO_MAX				= 0xd
-};
-
-struct coex_dm_8812a_2ant {
-	/* fw mechanism */
-	u8		pre_bt_dec_pwr_lvl;
-	u8		cur_bt_dec_pwr_lvl;
-	u8		pre_fw_dac_swing_lvl;
-	u8		cur_fw_dac_swing_lvl;
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		auto_tdma_adjust;
-	boolean		auto_tdma_adjust_low_rssi;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	/* sw mechanism */
-	boolean		pre_rf_rx_lpf_shrink;
-	boolean		cur_rf_rx_lpf_shrink;
-	u32		bt_rf_0x1e_backup;
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	boolean		pre_dac_swing_on;
-	u32		pre_dac_swing_lvl;
-	boolean		cur_dac_swing_on;
-	u32		cur_dac_swing_lvl;
-	boolean		pre_adc_back_off;
-	boolean		cur_adc_back_off;
-	boolean	pre_agc_table_en;
-	boolean		cur_agc_table_en;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		cur_ra_mask_type;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-
-	boolean	cur_enable_pta;
-	boolean	pre_enable_pta;
-};
-
-struct coex_sta_8812a_2ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-	boolean					acl_busy;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	u8					bt_rssi;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8812A_2ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8812A_2ANT_MAX];
-	u32					bt_info_query_cnt;
-	boolean					c2h_bt_inquiry_page;
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u8					scan_ap_num;
-	boolean				pre_bt_disabled;
-	u32					pre_bt_info_c2h_cnt_bt_rsp;
-	u32					pre_bt_info_c2h_cnt_bt_send;
-	boolean				force_lps_on;
-	u32				bt_coex_supported_version;
-
-	u32				crc_ok_cck;
-	u32				crc_ok_11g;
-	u32				crc_ok_11n;
-	u32				crc_ok_11n_vht;
-
-	u32				crc_err_cck;
-	u32				crc_err_11g;
-	u32				crc_err_11n;
-	u32				crc_err_11n_vht;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8812a2ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8812a2ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a2ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8812a2ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8812a2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8812a2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8812a2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8812a2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8812a2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8812a2ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-
-void ex_halbtc8812a2ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a2ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a2ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8812a2ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata);
-void ex_halbtc8812a2ant_pta_off_on_notify(IN struct btc_coexist *btcoexist,
-		IN u8 bt_status);
-
-#else
-#define	ex_halbtc8812a2ant_power_on_setting(btcoexist)
-#define	ex_halbtc8812a2ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8812a2ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8812a2ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8812a2ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8812a2ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8812a2ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8812a2ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8812a2ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8812a2ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8812a2ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8812a2ant_halt_notify(btcoexist)
-#define	ex_halbtc8812a2ant_periodical(btcoexist)
-#define	ex_halbtc8812a2ant_display_coex_info(btcoexist)
-#define	ex_halbtc8812a2ant_dbg_control(btcoexist, op_code, op_len, pdata)
-#define ex_halbtc8812a2ant_pta_off_on_notify(btcoexist, bt_status)
-
-#endif
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a1ant.c
deleted file mode 100644
index 694ab82a0dba..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a1ant.c
+++ /dev/null
@@ -1,3337 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 8821A_1ANT Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************
- * SY modify 2015/04/27
- * ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821A_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8821a_1ant		glcoex_dm_8821a_1ant;
-static struct  coex_dm_8821a_1ant	*coex_dm = &glcoex_dm_8821a_1ant;
-static struct  coex_sta_8821a_1ant		glcoex_sta_8821a_1ant;
-static struct  coex_sta_8821a_1ant	*coex_sta = &glcoex_sta_8821a_1ant;
-
-const char *const glbt_info_src_8821a_1ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8821a_1ant = 20170206;
-u32	glcoex_ver_8821a_1ant = 0x67;
-u32	glcoex_ver_btdesired_8821a_1ant = 0x62;
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8821a1ant_
- * ************************************************************ */
-u8 halbtc8821a1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8821a1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-void halbtc8821a1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-void halbtc8821a1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = false;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-void halbtc8821a1ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-void halbtc8821a1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8821a1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8821a1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8821a1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8821a1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
-	}
-
-	halbtc8821a1ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8821a1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8821a1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-
-/* true/xxxx/x:1
- * false/false/x: 64
- * false/true/x:x */
-void halbtc8821a1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8821a1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-#if 0
-	/* to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS */
-	if (!(btcoexist->btc_read_1byte(btcoexist, 0x76e) & 0x8)) {
-		coex_sta->high_priority_tx = 65535;
-		coex_sta->high_priority_rx = 65535;
-		coex_sta->low_priority_tx = 65535;
-		coex_sta->low_priority_rx = 65535;
-		return;
-	}
-#endif
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-}
-
-void halbtc8821a1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-#if 1
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-					 btcoexist,
-					 PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_VHT);
-
-#endif
-}
-
-
-void halbtc8821a1ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	coex_sta->c2h_bt_info_req_sent = true;
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-boolean halbtc8821a1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	boolean wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-	}
-
-	return false;
-}
-
-void halbtc8821a1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-u8 halbtc8821a1ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-	u8				algorithm = BT_8821A_1ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Profile = SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_1ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8821a1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8821a1ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8821a1ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8821a1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf5;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xa0;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xa0; /* MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-}
-
-void halbtc8821a1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8821a1ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8821a1ant_sw_mechanism(IN struct btc_coexist *btcoexist,
-				  IN boolean low_penalty_ra)
-{
-	halbtc8821a1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra);
-}
-
-void halbtc8821a1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8821a1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8821a1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8821a1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** CoexTable(%d) **********\n", type);
-	BTC_TRACE(trace_buf);
-
-	switch (type) {
-	case 0:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x55555555, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 4:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 5:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0x5a5a5a5a, 0xaaaa5a5a, 0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0xaaaa5a5a, 0xffffff, 0x3);
-		break;
-	case 7:
-		halbtc8821a1ant_coex_table(btcoexist, force_exec,
-				   0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8821a1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8821a1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8821a1ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8821a1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8821a1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8821a1ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8821a1ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean init_hwcfg, IN boolean wifi_off)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-	u32			u32tmp = 0;
-	u8			h2c_parameter[2] = {0};
-
-	if (init_hwcfg) {
-
-		/* 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp &= ~BIT(23);
-		u32tmp |= BIT(24);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-
-		/* 0x765 = 0x18 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x765, 0x18, 0x3);
-
-if (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT) {
-BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-"[BTCoex], 1\n");
-BTC_TRACE(trace_buf);
-			/* tell firmware "antenna inverse"  ==> WRONG firmware antenna control code.==>need fw to fix */
-			h2c_parameter[0] = 1;
-			h2c_parameter[1] = 1;
-			btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-						h2c_parameter);
-
-			/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1, 0x1); */ /*Main Ant to  BT for IPS case 0x4c[23]=1 */
-		} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 2\n");
-	BTC_TRACE(trace_buf);
-			/* tell firmware "no antenna inverse" ==> WRONG firmware antenna control code.==>need fw to fix */
-			h2c_parameter[0] = 0;
-			h2c_parameter[1] = 1;
-			btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-						h2c_parameter);
-
-			/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1, 0x0); */ /*Aux Ant to  BT for IPS case 0x4c[23]=1 */
-		}
-	} else if (wifi_off) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 3\n");
-	BTC_TRACE(trace_buf);
-		/* 0x4c[24:23]=00, Set Antenna control by BT_RFE_CTRL	BT Vendor 0xac=0xf002 */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp &= ~BIT(23);
-		u32tmp &= ~BIT(24);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-
-		/* 0x765 = 0x18 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x765, 0x18, 0x3);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 4\n");
-	BTC_TRACE(trace_buf);
-		/* 0x765 = 0x0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x765, 0x18, 0x0);
-	}
-
-	/* ext switch setting */
-	switch (ant_pos_type) {
-	case BTC_ANT_PATH_WIFI:
-		btcoexist->btc_write_1byte(btcoexist, 0xcb4, 0x77);
-		if (board_info->btdm_ant_pos ==
-		    BTC_ANTENNA_AT_MAIN_PORT)
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0xcb7, 0x30, 0x1);
-		else
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0xcb7, 0x30, 0x2);
-		break;
-	case BTC_ANT_PATH_BT:
-		btcoexist->btc_write_1byte(btcoexist, 0xcb4, 0x77);
-		if (board_info->btdm_ant_pos ==
-		    BTC_ANTENNA_AT_MAIN_PORT)
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0xcb7, 0x30, 0x2);
-		else
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0xcb7, 0x30, 0x1);
-		break;
-	default:
-	case BTC_ANT_PATH_PTA:
-		btcoexist->btc_write_1byte(btcoexist, 0xcb4, 0x66);
-		if (board_info->btdm_ant_pos ==
-		    BTC_ANTENNA_AT_MAIN_PORT)
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0xcb7, 0x30, 0x1);
-		else
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0xcb7, 0x30, 0x2);
-		break;
-	}
-}
-
-
-void halbtc8821a1ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x8, 0, 0, 0, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-/* halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,8); */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-/* halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,8); */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-void halbtc8821a1ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		break;
-	case BTC_PS_LPS_ON:
-		halbtc8821a1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, true);
-		halbtc8821a1ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma. */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		break;
-	case BTC_PS_LPS_OFF:
-		halbtc8821a1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8821a1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			real_byte1 &= ~BIT(4);
-			real_byte1 |= BIT(5);
-
-			real_byte5 |= BIT(5);
-			real_byte5 &= ~BIT(6);
-
-			halbtc8821a1ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		}
-} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-halbtc8821a1ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	} else  {
-			halbtc8821a1ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	}
-
-	h2c_parameter[0] = real_byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = real_byte5;
-
-	coex_dm->ps_tdma_para[0] = real_byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = real_byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-void halbtc8821a1ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	u8			rssi_adjust_val = 0;
-	/* u32			fw_ver=0; */
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-	if (turn_on) {
-		switch (type) {
-		default:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x1a, 0x1a, 0x0, 0x50);
-			break;
-		case 1:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x3a, 0x03, 0x10, 0x50);
-			rssi_adjust_val = 11;
-			break;
-		case 2:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x2b, 0x03, 0x10, 0x50);
-			rssi_adjust_val = 14;
-			break;
-		case 3:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x1d, 0x1d, 0x0, 0x52);
-			break;
-		case 4:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x14, 0x0);
-			rssi_adjust_val = 17;
-			break;
-		case 5:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x15, 0x3, 0x11, 0x10);
-			break;
-		case 6:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x20, 0x3, 0x11, 0x13);
-			break;
-		case 7:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xc, 0x5, 0x0, 0x0);
-			break;
-		case 8:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			break;
-		case 9:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x21, 0x3, 0x10, 0x50);
-			rssi_adjust_val = 18;
-			break;
-		case 10:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0xa, 0x0, 0x40);
-			break;
-		case 11:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x15, 0x03, 0x10, 0x50);
-			rssi_adjust_val = 20;
-			break;
-		case 12:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x0a, 0x0a, 0x0, 0x50);
-			break;
-		case 13:
-
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x40, 0x3, 0x10, 0x50);
-
-			break;
-		case 14:
-
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x1e, 0x3, 0x10, 0x14);
-			break;
-		case 15:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x13,
-						      0xa, 0x3, 0x8, 0x0);
-			break;
-		case 16:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x15, 0x3, 0x10, 0x0);
-			rssi_adjust_val = 18;
-			break;
-		case 18:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x93,
-						      0x25, 0x3, 0x10, 0x0);
-			rssi_adjust_val = 14;
-			break;
-		case 20:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11, 0x10);
-			break;
-		case 21:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11, 0x11);
-			break;
-		case 22:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11, 0x10);
-			break;
-		case 23:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x18);
-			rssi_adjust_val = 22;
-			break;
-		case 24:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x3, 0x31, 0x18);
-			rssi_adjust_val = 22;
-			break;
-		case 25:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			rssi_adjust_val = 22;
-			break;
-		case 26:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0xa, 0x3, 0x31, 0x18);
-			rssi_adjust_val = 22;
-			break;
-		case 27:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x3, 0x31, 0x98);
-			rssi_adjust_val = 22;
-			break;
-		case 28:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x69,
-						      0x25, 0x3, 0x31, 0x0);
-			break;
-		case 29:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xab,
-						      0x1a, 0x1a, 0x1, 0x10);
-			break;
-		case 30:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10, 0x10);
-			break;
-		case 31:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1a, 0x1a, 0, 0x58);
-			break;
-		case 32:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x3, 0x11, 0x11);
-			break;
-		case 33:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xa3,
-						      0x25, 0x3, 0x30, 0x90);
-			break;
-		case 34:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x53,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 35:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x63,
-						      0x1a, 0x1a, 0x0, 0x10);
-			break;
-		case 36:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x12, 0x3, 0x14, 0x50);
-			break;
-		case 40: /* SoftAP only with no sta associated,BT disable ,TDMA mode for power saving */
-			/* here softap mode screen off will cost 70-80mA for phone */
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x23,
-						      0x18, 0x00, 0x10, 0x24);
-			break;
-		case 41:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x15, 0x3, 0x11, 0x11);
-			break;
-		case 42:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x20, 0x3, 0x11, 0x11);
-			break;
-		case 43:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10, 0x11);
-			break;
-		case 44:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x20, 0x3, 0x10, 0x14);
-		case 45:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x25, 0x3, 0x10, 0x10);
-			break;
-		case 46:
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x35, 0x3, 0x10, 0x10);
-			break;
-		}
-	} else {
-		/* disable PS tdma */
-		switch (type) {
-		case 8: /* PTA Control */
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x8,
-						      0x0, 0x0, 0x0, 0x0);
-			halbtc8821a1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_PTA, false, false);
-			break;
-		case 0:
-		default:  /* Software control, Antenna at BT side */
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			halbtc8821a1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_BT, false, false);
-			break;
-		case 9:   /* Software control, Antenna at WiFi side */
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			halbtc8821a1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_WIFI, false, false);
-			break;
-		case 10:	/* under 5G */
-			halbtc8821a1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x8, 0x0);
-			halbtc8821a1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_BT, false, false);
-			break;
-		}
-	}
-	rssi_adjust_val = 0;
-	btcoexist->btc_set(btcoexist,
-		BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE, &rssi_adjust_val);
-
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-void halbtc8821a1ant_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-	/* sw all off */
-	halbtc8821a1ant_sw_mechanism(btcoexist, false);
-
-	/* hw all off */
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-boolean halbtc8821a1ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = false, wifi_connected = false, wifi_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected &&
-	    BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	    coex_dm->bt_status) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_sw_mechanism(btcoexist, false);
-
-		common = true;
-	} else if (wifi_connected &&
-		   (BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_sw_mechanism(btcoexist, false);
-
-		common = true;
-	} else if (!wifi_connected &&
-		   (BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_sw_mechanism(btcoexist, false);
-
-		common = true;
-	} else if (wifi_connected &&
-		   (BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_sw_mechanism(btcoexist, false);
-
-		common = true;
-	} else if (!wifi_connected &&
-		   (BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE !=
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non connected-idle + BT Busy!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_sw_mechanism(btcoexist, false);
-
-		common = true;
-	} else {
-		if (wifi_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		common = false;
-	}
-
-	return common;
-}
-
-/* *********************************************
- *
- *	Software Coex Mechanism start
- *
- * ********************************************* */
-
-void halbtc8821a1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-	/* halbtc8821a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, NORMAL_EXEC, false, false); */
-	halbtc8821a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, false, false);
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-/* SCO only or SCO+PAN(HS) */
-void halbtc8821a1ant_action_sco(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 42);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, true);
-}
-
-void halbtc8821a1ant_action_hid(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 42);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, true);
-}
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-void halbtc8821a1ant_action_a2dp(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 44);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8821a1ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 45);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8821a1ant_action_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 45);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, false);
-}
-
-/* PAN(HS) only */
-void halbtc8821a1ant_action_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 45);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, false);
-}
-
-/* PAN(EDR)+A2DP */
-void halbtc8821a1ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 45);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, false);
-}
-
-void halbtc8821a1ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 45);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, true);
-}
-
-/* HID+A2DP+PAN(EDR) */
-void halbtc8821a1ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 45);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, true);
-}
-
-void halbtc8821a1ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 44);
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-
-	halbtc8821a1ant_sw_mechanism(btcoexist, true);
-}
-
-/* *********************************************
- *
- *	Non-Software Coex Mechanism start
- *
- * ********************************************* */
-void halbtc8821a1ant_action_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 45);
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-}
-
-void halbtc8821a1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_connected = false, ap_enable = false, wifi_busy = false,
-				bt_busy = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	if ((!wifi_connected) && (!coex_sta->wifi_is_high_pri_task)) {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	}
-
-
-	else if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist) ||
-		 (bt_link_info->a2dp_exist)) {
-		/* SCO/HID/A2DP  busy */
-
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	}
-
-
-
-	else if ((bt_link_info->a2dp_exist) &&
-		 (bt_link_info->hid_exist)) {
-		/* A2DP+HID	busy */
-
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-					14);
-
-		halbtc8821a1ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 1);
-	}
-
-
-	else if ((bt_link_info->pan_exist) || (wifi_busy)) {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	}
-}
-
-void halbtc8821a1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	/* tdma and coex table */
-
-	if (bt_link_info->sco_exist) {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	} else { /* HID */
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8821a1ant_coex_under_5g(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8821a1ant_ignore_wlan_act(btcoexist, NORMAL_EXEC, true);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 10);
-
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-	halbtc8821a1ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 5);
-}
-
-void halbtc8821a1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 9);
-}
-
-void halbtc8821a1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = true, bt_disabled = false;
-
-	/* This function check if bt is disabled */
-
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = false;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = false;
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is enabled !!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		bt_disable_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], bt all counters=0, %d times!!\n",
-			    bt_disable_cnt);
-		BTC_TRACE(trace_buf);
-		if (bt_disable_cnt >= 10) {
-			bt_disabled = true;
-			btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-					   &bt_disabled);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_wifi_only(btcoexist);
-		}
-	}
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-		if (!bt_disabled) {
-		} else {
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-					   NULL);
-			btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-					   NULL);
-		}
-	}
-}
-
-void halbtc8821a1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-}
-
-
-void halbtc8821a1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
-		*btcoexist, IN u8 wifi_status)
-{
-	u8		bt_rssi_state;
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	bt_rssi_state = halbtc8821a1ant_bt_rssi_state(2, 28, 0);
-
-	if (bt_link_info->hid_only) { /* HID */
-		halbtc8821a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				wifi_status);
-		coex_dm->auto_tdma_adjust = false;
-		return;
-	} else if (bt_link_info->a2dp_only) { /* A2DP		 */
-		if (BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE == wifi_status) {
-			/* halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8); */
-			/* halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2); */
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						32);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			coex_dm->auto_tdma_adjust = false;
-		} else if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-			   (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			/* halbtc8821a1ant_tdma_duration_adjust_for_acl(btcoexist, wifi_status); */
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						14);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-		} else { /* for low BT RSSI */
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						14);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			coex_dm->auto_tdma_adjust = false;
-		}
-	} else if (bt_link_info->hid_exist &&
-		   bt_link_info->a2dp_exist) { /* HID+A2DP */
-		if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						14);
-			coex_dm->auto_tdma_adjust = false;
-		} else { /* for low BT RSSI */
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						14);
-			coex_dm->auto_tdma_adjust = false;
-		}
-
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-	} else if ((bt_link_info->pan_only) || (bt_link_info->hid_exist &&
-		bt_link_info->pan_exist)) { /* PAN(OPP,FTP), HID+PAN(OPP,FTP)			 */
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 3);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-		coex_dm->auto_tdma_adjust = false;
-	} else if (((bt_link_info->a2dp_exist) && (bt_link_info->pan_exist)) ||
-		   (bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) { /* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 46);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		coex_dm->auto_tdma_adjust = false;
-	} else {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 11);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		coex_dm->auto_tdma_adjust = false;
-	}
-}
-
-void halbtc8821a1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-
-	/* tdma and coex table	 */
-	halbtc8821a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8);
-	halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8821a1ant_action_wifi_not_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-
-	/* tdma and coex table */
-	if (BT_8821A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						14);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8821A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8821a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20); */
-		/* halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1); */
-
-		/* Bryant Add */
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8821a1ant_action_wifi_not_connected_asso_auth(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist)  || (bt_link_info->hid_exist)) {
-		/* sy modify */
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 14);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-	} else if ((bt_link_info->a2dp_exist)  || (bt_link_info->pan_exist)) {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8821a1ant_action_wifi_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* tdma and coex table */
-	if (BT_8821A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			/* sy modify */
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						14);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						22);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		} else {
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						20);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-		}
-	} else if ((BT_8821A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8821a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN);
-	} else {
-		/* halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20); */
-		/* halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1); */
-
-		/* Bryant Add */
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8821a1ant_action_wifi_connected_specific_packet(
-	IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* tdma and coex table */
-	/* sy modify */
-	if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist) ||
-	    (bt_link_info->a2dp_exist)) {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 32);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	}
-
-	if ((bt_link_info->hid_exist) && (bt_link_info->a2dp_exist)) {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-					14);
-		halbtc8821a1ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 1);
-	}
-
-
-	else if (bt_link_info->pan_exist) {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 20);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 8);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	}
-}
-
-void halbtc8821a1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-	boolean	wifi_busy = false;
-	boolean	scan = false, link = false, roam = false;
-	boolean		under_4way = false, ap_enable = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], CoexForWifiConnect()===>\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-	if (under_4way) {
-		halbtc8821a1ant_action_wifi_connected_specific_packet(
-			btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	if (scan || link || roam) {
-		if (scan)
-			halbtc8821a1ant_action_wifi_connected_scan(btcoexist);
-		else
-			halbtc8821a1ant_action_wifi_connected_specific_packet(
-				btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* tdma and coex table */
-	if (!wifi_busy) {
-		if (BT_8821A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8821a1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else if ((BT_8821A_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8821a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE);
-		} else {
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-		}
-	} else {
-		if (BT_8821A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8821a1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else if ((BT_8821A_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8821a1ant_action_bt_sco_hid_only_busy(btcoexist,
-				BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY);
-		} else {
-			halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						8);
-			halbtc8821a1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-		}
-	}
-}
-
-void halbtc8821a1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8	algorithm = 0;
-
-	algorithm = halbtc8821a1ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-
-	if (halbtc8821a1ant_is_common_action(btcoexist)) {
-
-	} else {
-		switch (coex_dm->cur_algorithm) {
-		case BT_8821A_1ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_sco(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_hid(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_a2dp(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_a2dp_pan_hs(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_pan_edr(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_pan_hs(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_pan_edr_a2dp(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_pan_edr_hid(btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_hid_a2dp_pan_edr(
-				btcoexist);
-			break;
-		case BT_8821A_1ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a1ant_action_hid_a2dp(btcoexist);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			/* halbtc8821a1ant_coex_all_off(btcoexist); */
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-void halbtc8821a1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = false, bt_hs_on = false;
-	boolean	increase_scan_dev_num = false;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-	u8	wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	wifi_under_5g = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_action_bt_whck_test(btcoexist);
-		return;
-	}
-
-	if ((BT_8821A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8821A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		increase_scan_dev_num = true;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_INC_SCAN_DEV_NUM,
-			   &increase_scan_dev_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8821a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	if (!bt_link_info->sco_exist && !bt_link_info->hid_exist)
-		halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-	else {
-		if (wifi_connected) {
-			wifi_rssi_state = halbtc8821a1ant_wifi_rssi_state(
-						  btcoexist, 1, 2, 30, 0);
-			if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-			    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-				/* halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1, 1, 1); */
-				halbtc8821a1ant_limited_tx(btcoexist,
-						   NORMAL_EXEC, 1, 1, 0, 1);
-			} else {
-				/* halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1, 1, 1); */
-				halbtc8821a1ant_limited_tx(btcoexist,
-						   NORMAL_EXEC, 1, 1, 0, 1);
-			}
-		} else
-			halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0,
-						   0, 0);
-
-	}
-
-	if (bt_link_info->sco_exist) {
-		bt_ctrl_agg_buf_size = true;
-		agg_buf_size = 0x3;
-	} else if (bt_link_info->hid_exist) {
-		bt_ctrl_agg_buf_size = true;
-		agg_buf_size = 0x5;
-	} else if (bt_link_info->a2dp_exist || bt_link_info->pan_exist) {
-		bt_ctrl_agg_buf_size = true;
-		agg_buf_size = 0x8;
-	}
-	halbtc8821a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-				   bt_ctrl_agg_buf_size, agg_buf_size);
-
-	halbtc8821a1ant_run_sw_coexist_mechanism(btcoexist);
-
-	/* low pelnaty ra in pcr ra */
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8821a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8821a1ant_action_hs(btcoexist);
-		return;
-	}
-
-
-	if (!wifi_connected) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is non connected-idle !!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (scan || link || roam) {
-			if (scan)
-				halbtc8821a1ant_action_wifi_not_connected_scan(
-					btcoexist);
-			else
-				halbtc8821a1ant_action_wifi_not_connected_asso_auth(
-					btcoexist);
-		} else
-			halbtc8821a1ant_action_wifi_not_connected(btcoexist);
-	} else	/* wifi LPS/Busy */
-		halbtc8821a1ant_action_wifi_connected(btcoexist);
-}
-
-void halbtc8821a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-	/* sw all off */
-	halbtc8821a1ant_sw_mechanism(btcoexist, false);
-
-	/* halbtc8821a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 8); */
-	halbtc8821a1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-}
-
-void halbtc8821a1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up, IN boolean wifi_only)
-{
-	u8	u8tmp = 0;
-	boolean			wifi_under_5g = false;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	if (wifi_only)
-		return;
-
-	if (back_up) {
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	}
-
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	/* Give bt_coex_supported_version the default value */
-	coex_sta->bt_coex_supported_version = 0;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	/* Antenna config */
-	if (wifi_under_5g)
-		halbtc8821a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, true,
-					     false);
-	else
-		halbtc8821a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_PTA, true,
-					     false);
-
-	/* PTA parameter */
-	halbtc8821a1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	/* Enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e,
-			   0xc); /* 0x76e[3] =1, WLAN_Act control by PTA */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x3);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-}
-
-/* ************************************************************
- * work around function start with wa_halbtc8821a1ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8821a1ant_
- * ************************************************************ */
-void ex_halbtc8821a1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct	btc_board_info	*board_info = &btcoexist->board_info;
-
-if (board_info->single_ant_path == 0) {
-board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-			} else if (board_info->single_ant_path == 1) {
-				board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-			}
-
-}
-
-void ex_halbtc8821a1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8821a1ant_init_hw_config(btcoexist, true, wifi_only);
-}
-
-void ex_halbtc8821a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->stop_coex_dm = false;
-
-	halbtc8821a1ant_init_coex_dm(btcoexist);
-
-	halbtc8821a1ant_query_bt_info(btcoexist);
-}
-
-void ex_halbtc8821a1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fw_ver = 0, bt_patch_ver = 0;
-	u32				bt_coex_ver = 0;
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				phyver = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d",
-		   "Ant PG Num/ Ant Mech/ Ant Pos:",
-		   board_info->pg_ant_num, board_info->btdm_ant_num,
-		   board_info->btdm_ant_pos);
-	CL_PRINTF(cli_buf);
-
-	/* btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver); */
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-	bt_coex_ver = ((coex_sta->bt_coex_supported_version & 0xff00) >> 8);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8821a_1ant, glcoex_ver_8821a_1ant,
-		   glcoex_ver_btdesired_8821a_1ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (bt_coex_ver >= glcoex_ver_btdesired_8821a_1ant ?
-		     "Match" : "Mis-Match")));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi, coex_sta->bt_retry_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP",
-		   bt_link_info->sco_exist, bt_link_info->hid_exist,
-		   bt_link_info->pan_exist, bt_link_info->a2dp_exist);
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_BT_LINK_INFO);
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Info A2DP rate",
-		   (bt_info_ext & BIT(0)) ? "Basic rate" : "EDR rate");
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8821A_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8821a_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	if (!btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-			   "SM[LowPenaltyRA]",
-			   coex_dm->cur_low_penalty_ra);
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[mechanisms]============");
-		CL_PRINTF(cli_buf);
-
-		ps_tdma_case = coex_dm->cur_ps_tdma;
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)",
-			   "PS TDMA",
-			   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-			   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-			   coex_dm->ps_tdma_para[4], ps_tdma_case,
-			   coex_dm->auto_tdma_adjust);
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ",
-			   "IgnWlanAct",
-			   coex_dm->cur_ignore_wlan_act);
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x ",
-			   "Latest error condition(should be 0)",
-			   coex_dm->error_condition);
-		CL_PRINTF(cli_buf);
-	}
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "backup ARFR1/ARFR2/RL/AMaxTime",
-		   coex_dm->backup_arfr_cnt1, coex_dm->backup_arfr_cnt2,
-		   coex_dm->backup_retry_limit,
-		   coex_dm->backup_ampdu_max_time);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
-	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x456);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "0x430/0x434/0x42a/0x456",
-		   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc58);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x778/ 0xc58[29:25]",
-		   u8tmp[0], (u32tmp[0] & 0x3e000000) >> 25);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x8db);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x8db[6:5]",
-		   ((u8tmp[0] & 0x60) >> 5));
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x975);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0xcb4[29:28]/0xcb4[7:0]/0x974[9:8]",
-		   (u32tmp[0] & 0x30000000) >> 28, u32tmp[0] & 0xff,
-		   u8tmp[0] & 0x3);
-	CL_PRINTF(cli_buf);
-
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x64);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x40/0x4c[24:23]/0x64[0]",
-		   u8tmp[0], ((u32tmp[0] & 0x01800000) >> 23), u8tmp[1] & 0x1);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)",
-		   u32tmp[0] & 0xff);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11n-agg",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(high-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(low-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8821A_1ANT == 1)
-	halbtc8821a1ant_monitor_bt_ctr(btcoexist);
-#endif
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8821a1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	boolean	wifi_under_5g = false;
-
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G,
-			   &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = true;
-
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false,
-					     true);
-		/* halbtc8821a1ant_set_ant_path_d_cut(btcoexist, false, false, false, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF); */
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = false;
-
-		halbtc8821a1ant_init_hw_config(btcoexist, false, false);
-		halbtc8821a1ant_init_coex_dm(btcoexist);
-		halbtc8821a1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8821a1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-
-
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = true;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8821a1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-	boolean	wifi_under_5g = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	if (BTC_SCAN_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821a1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if (coex_sta->bt_disabled)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	halbtc8821a1ant_query_bt_info(btcoexist);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8821a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8821a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8821a1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_SCAN_START == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8821a1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		else	/* wifi is connected */
-			halbtc8821a1ant_action_wifi_connected_scan(btcoexist);
-	} else if (BTC_SCAN_FINISH == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8821a1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8821a1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-/* copy scan notify content to switch band notify */
-void ex_halbtc8821a1ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-	boolean	wifi_under_5g = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	if (BTC_SCAN_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821a1ant_ps_tdma(btcoexist, FORCE_EXEC, false,
-			8);  /* Force antenna setup for no scan result issue */
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if (coex_sta->bt_disabled)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	halbtc8821a1ant_query_bt_info(btcoexist);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8821a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8821a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8821a1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_SCAN_START == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8821a1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		else	/* wifi is connected */
-			halbtc8821a1ant_action_wifi_connected_scan(btcoexist);
-	} else if (BTC_SCAN_FINISH == type) {
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8821a1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8821a1ant_action_wifi_connected(btcoexist);
-	}
-}
-void ex_halbtc8821a1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	boolean	wifi_connected = false, bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-	boolean	wifi_under_5g = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	if (BTC_ASSOCIATE_START == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8821a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8821a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8821a1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_ASSOCIATE_START == type)
-		halbtc8821a1ant_action_wifi_not_connected_asso_auth(btcoexist);
-	else if (BTC_ASSOCIATE_FINISH == type) {
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-				   &wifi_connected);
-		if (!wifi_connected) /* non-connected scan */
-			halbtc8821a1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8821a1ant_action_wifi_connected(btcoexist);
-	}
-}
-
-void ex_halbtc8821a1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	boolean	wifi_under_5g = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-
-if ((wifi_central_chnl <= 14) && (type == BTC_MEDIA_CONNECT)) {
-
-h2c_parameter[0] = 0x1;
-		/*h2c_parameter[0] = 0x0;*/
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-}
-
-void ex_halbtc8821a1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean	bt_hs_on = false;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = false;
-	u8	agg_buf_size = 5;
-	boolean	wifi_under_5g = false;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm ||
-	    coex_sta->bt_disabled)
-		return;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    BTC_PACKET_ARP == type) {
-		coex_sta->wifi_is_high_pri_task = true;
-
-		if (BTC_PACKET_ARP == type) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], specific Packet ARP notify\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], specific Packet DHCP or EAPOL notify\n");
-			BTC_TRACE(trace_buf);
-		}
-	} else {
-		coex_sta->wifi_is_high_pri_task = false;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet [Type = %d] notify\n", type);
-		BTC_TRACE(trace_buf);
-	}
-
-	coex_sta->specific_pkt_period_cnt = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-	if (num_of_wifi_link >= 2) {
-		halbtc8821a1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8821a1ant_limited_rx(btcoexist, NORMAL_EXEC, false,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-		halbtc8821a1ant_action_wifi_multi_port(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8821a1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8821a1ant_action_hs(btcoexist);
-		return;
-	}
-
-	if (BTC_PACKET_DHCP == type ||
-	    BTC_PACKET_EAPOL == type ||
-	    BTC_PACKET_ARP == type) {
-		if (BTC_PACKET_ARP == type) {
-			coex_dm->arp_cnt++;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], ARP Packet Count = %d\n",
-				    coex_dm->arp_cnt);
-			BTC_TRACE(trace_buf);
-			if (coex_dm->arp_cnt >=
-			    10) /* if APR PKT > 10 after connect, do not go to ActionWifiConnectedSpecificPacket(btcoexist) */
-				return;
-		}
-
-		halbtc8821a1ant_action_wifi_connected_specific_packet(
-			btcoexist);
-	}
-}
-
-void ex_halbtc8821a1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8				bt_info = 0;
-	u8				i, rsp_source = 0;
-	boolean				wifi_connected = false;
-	boolean				bt_busy = false;
-	boolean				wifi_under_5g = false;
-
-
-	coex_sta->c2h_bt_info_req_sent = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8821A_1ANT_MAX)
-		rsp_source = BT_INFO_SRC_8821A_1ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-	/* if 0xff, it means BT is under WHCK test */
-	if (bt_info == 0xff)
-		coex_sta->bt_whck_test = true;
-	else
-		coex_sta->bt_whck_test = false;
-
-	if (BT_INFO_SRC_8821A_1ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		if (coex_sta->bt_info_c2h[rsp_source][2] & 0x20)
-			coex_sta->c2h_bt_page = true;
-		else
-			coex_sta->c2h_bt_page = false;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 + 10;
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		coex_sta->bt_tx_rx_mask = (coex_sta->bt_info_c2h[rsp_source][2]
-					   & 0x40);
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TX_RX_MASK,
-				   &coex_sta->bt_tx_rx_mask);
-		if (!coex_sta->bt_tx_rx_mask) {
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x15 => Need to switch BT TRx Mask */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x15\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF,
-						  0x3c, 0x15);
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if (coex_sta->bt_info_ext & BIT(1)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-			if (wifi_connected)
-				ex_halbtc8821a1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8821a1ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-		if ((coex_sta->bt_info_ext & BIT(3)) && !wifi_under_5g) {
-			if (!btcoexist->manual_control &&
-			    !btcoexist->stop_coex_dm) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8821a1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, false);
-			}
-		} else {
-			/* BT already NOT ignore Wlan active, do nothing here. */
-		}
-#if (BT_AUTO_REPORT_ONLY_8821A_1ANT == 0)
-		if ((coex_sta->bt_info_ext & BIT(4))) {
-			/* BT auto report already enabled, do nothing */
-		} else
-			halbtc8821a1ant_bt_auto_report(btcoexist, FORCE_EXEC,
-						       true);
-#endif
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8821A_1ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8821A_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8821A_1ANT_B_FTP)
-			coex_sta->pan_exist = true;
-		else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8821A_1ANT_B_A2DP)
-			coex_sta->a2dp_exist = true;
-		else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8821A_1ANT_B_HID)
-			coex_sta->hid_exist = true;
-		else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8821A_1ANT_B_SCO_ESCO)
-			coex_sta->sco_exist = true;
-		else
-			coex_sta->sco_exist = false;
-	}
-
-	halbtc8821a1ant_update_bt_link_info(btcoexist);
-
-	bt_info = bt_info &
-		0x1f;  /* mask profile bit for connect-ilde identification ( for CSR case: A2DP idle --> 0x41) */
-
-	if (!(bt_info & BT_INFO_8821A_1ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info ==
-		BT_INFO_8821A_1ANT_B_CONNECTION) {	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if ((bt_info & BT_INFO_8821A_1ANT_B_SCO_ESCO) ||
-		   (bt_info & BT_INFO_8821A_1ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8821A_1ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info & BT_INFO_8821A_1ANT_B_ACL_BUSY) {
-		if (BT_8821A_1ANT_BT_STATUS_ACL_BUSY != coex_dm->bt_status)
-			coex_dm->auto_tdma_adjust = false;
-		coex_dm->bt_status = BT_8821A_1ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_dm->bt_status = BT_8821A_1ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((BT_8821A_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8821A_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = true;
-	else
-		bt_busy = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	halbtc8821a1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8821a1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	boolean	wifi_under_5g = false;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8821a1ant_ps_tdma(btcoexist, FORCE_EXEC, false, 0);
-	halbtc8821a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false, true);
-	/* halbtc8821a1ant_set_ant_path_d_cut(btcoexist, false, false, false, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF); */
-
-	halbtc8821a1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-
-	ex_halbtc8821a1ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	btcoexist->stop_coex_dm = true;
-}
-
-void ex_halbtc8821a1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	boolean wifi_under_5g = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for 5G <===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a1ant_coex_under_5g(btcoexist);
-		return;
-	}
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_WIFI_PNP_SLEEP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821a1ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0);
-		halbtc8821a1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-		halbtc8821a1ant_set_ant_path(btcoexist, BTC_ANT_PATH_BT, false,
-					     true);
-		/* halbtc8821a1ant_set_ant_path_d_cut(btcoexist, false, false, false, BTC_ANT_PATH_BT, BTC_WIFI_STAT_NORMAL_OFF); */
-
-		/* Sinda 20150819, workaround for driver skip leave IPS/LPS to speed up sleep time. */
-		/* Driver do not leave IPS/LPS when driver is going to sleep, so BTCoexistence think wifi is still under IPS/LPS */
-		/* BT should clear UnderIPS/UnderLPS state to avoid mismatch state after wakeup. */
-		coex_sta->under_ips = false;
-		coex_sta->under_lps = false;
-		btcoexist->stop_coex_dm = true;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = false;
-		halbtc8821a1ant_init_hw_config(btcoexist, false, false);
-		halbtc8821a1ant_init_coex_dm(btcoexist);
-		halbtc8821a1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8821a1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	u32 bt_patch_ver;
-
-	if (((coex_sta->bt_coex_supported_version == 0) ||
-	     (coex_sta->bt_coex_supported_version == 0xffff)) && (!coex_sta->bt_disabled))
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION, &coex_sta->bt_coex_supported_version);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-#if (BT_AUTO_REPORT_ONLY_8821A_1ANT == 0)
-	halbtc8821a1ant_query_bt_info(btcoexist);
-	halbtc8821a1ant_monitor_bt_enable_disable(btcoexist);
-#else
-	halbtc8821a1ant_monitor_bt_ctr(btcoexist);
-	halbtc8821a1ant_monitor_wifi_ctr(btcoexist);
-	halbtc8821a1ant_monitor_bt_enable_disable(btcoexist);
-	if (halbtc8821a1ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust) {
-		/* if(coex_sta->specific_pkt_period_cnt > 2) */
-		/* { */
-		halbtc8821a1ant_run_coexist_mechanism(btcoexist);
-		/* } */
-	}
-
-	coex_sta->specific_pkt_period_cnt++;
-#endif
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a1ant.h
deleted file mode 100644
index c9c141c0a095..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a1ant.h
+++ /dev/null
@@ -1,228 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821A_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8821A 1ANT BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8821A_1ANT				1
-
-#define	BT_INFO_8821A_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8821A_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8821A_1ANT_B_HID						BIT(5)
-#define	BT_INFO_8821A_1ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8821A_1ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8821A_1ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8821A_1ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8821A_1ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8821A_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT(0))) ? true : false)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT		2
-
-enum bt_info_src_8821a_1ant {
-	BT_INFO_SRC_8821A_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8821A_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8821A_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8821A_1ANT_MAX
-};
-
-enum bt_8821a_1ant_bt_status {
-	BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8821A_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8821A_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8821A_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8821A_1ANT_BT_STATUS_MAX
-};
-
-enum bt_8821a_1ant_wifi_status {
-	BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8821A_1ANT_WIFI_STATUS_MAX
-};
-
-enum bt_8821a_1ant_coex_algo {
-	BT_8821A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8821A_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8821A_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8821A_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8821A_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8821A_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8821A_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8821A_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8821A_1ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-struct coex_dm_8821a_1ant {
-	/* fw mechanism */
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	/* sw mechanism */
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-	u32		arp_cnt;
-
-	u8		error_condition;
-};
-
-struct coex_sta_8821a_1ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	u32					bt_coex_supported_version;
-	u8					cut_version;
-	u8					bt_rssi;
-	u8					scan_ap_num;
-	boolean					bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8821A_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821A_1ANT_MAX];
-	boolean					c2h_bt_inquiry_page;
-	boolean					c2h_bt_page;				/* Add for win8.1 page out issue */
-	boolean					wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	boolean				bt_whck_test;	/* Add for ASUS WHQL TEST that enable wifi test bt */
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8821a1ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8821a1ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a1ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821a1ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821a1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8821a1ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821a1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8821a1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821a1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821a1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8821a1ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8821a1ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a1ant_display_coex_info(IN struct btc_coexist *btcoexist);
-
-#else
-#define	ex_halbtc8821a1ant_power_on_setting(btcoexist)
-#define	ex_halbtc8821a1ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8821a1ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8821a1ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8821a1ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8821a1ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8821a1ant_switchband_notify(btcoexist, type)
-#define	ex_halbtc8821a1ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8821a1ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8821a1ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8821a1ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8821a1ant_halt_notify(btcoexist)
-#define	ex_halbtc8821a1ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8821a1ant_periodical(btcoexist)
-#define	ex_halbtc8821a1ant_display_coex_info(btcoexist)
-
-#endif
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a2ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a2ant.c
deleted file mode 100644
index 802f298a4c74..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a2ant.c
+++ /dev/null
@@ -1,4604 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8821A Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821A_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8821a_2ant		glcoex_dm_8821a_2ant;
-static struct  coex_dm_8821a_2ant	*coex_dm = &glcoex_dm_8821a_2ant;
-static struct  coex_sta_8821a_2ant		glcoex_sta_8821a_2ant;
-static struct  coex_sta_8821a_2ant	*coex_sta = &glcoex_sta_8821a_2ant;
-
-const char *const glbt_info_src_8821a_2ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8821a_2ant = 20161130;
-u32	glcoex_ver_8821a_2ant = 0x61;
-u32	glcoex_ver_btdesired_8821a_2ant = 0x5c;
-
-/* modify 20140903v43 a2dpandhid tdmaonoff a2dp glitch _ tdma off 778=3(case1)->778=1(case0)
- * and to improve tp while a2dphid case23->case25 , case123->case125 for asus spec
- * and modify for asus bt WHQL test _ tdma off_ 778=3->1_
- * ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8821a2ant_
- * ************************************************************ */
-u8 halbtc8821a2ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8821a2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-
-void halbtc8821a2ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-}
-
-void halbtc8821a2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	if ((coex_sta->low_priority_rx >= 950)  &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx) &&
-	    (!coex_sta->under_ips))
-		bt_link_info->slave_role = true;
-	else
-		bt_link_info->slave_role = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], High Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_hp_txrx, reg_hp_tx, reg_hp_tx, reg_hp_rx, reg_hp_rx);
-	BTC_TRACE(trace_buf);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], Low Priority Tx/Rx (reg 0x%x)=0x%x(%d)/0x%x(%d)\n",
-		    reg_lp_txrx, reg_lp_tx, reg_lp_tx, reg_lp_rx, reg_lp_rx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-}
-
-void halbtc8821a2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-#if 1
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-				       btcoexist,
-				       PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-					 btcoexist,
-					 PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist,
-					PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht =
-		btcoexist->btc_phydm_query_PHY_counter(
-			btcoexist,
-			PHYDM_INFO_CRC32_ERROR_VHT);
-
-#endif
-}
-
-void halbtc8821a2ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	coex_sta->c2h_bt_info_req_sent = true;
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-boolean halbtc8821a2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = false, pre_under_4way = false,
-			pre_bt_hs_on = false;
-	boolean			wifi_busy = false, under_4way = false, bt_hs_on = false;
-	boolean			wifi_connected = false;
-	u8			wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return true;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return true;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return true;
-		}
-
-
-		wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 3,
-			  2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-
-		if ((BTC_RSSI_STATE_HIGH == wifi_rssi_state) ||
-		    (BTC_RSSI_STATE_LOW == wifi_rssi_state))
-			return true;
-
-	}
-
-	return false;
-}
-
-void halbtc8821a2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32	bt_disable_cnt = 0;
-	boolean			bt_active = true, bt_disabled = false;
-
-	/* This function check if bt is disabled */
-
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = false;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = false;
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is enabled !!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		bt_disable_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], bt all counters=0, %d times!!\n",
-			    bt_disable_cnt);
-		BTC_TRACE(trace_buf);
-		if (bt_disable_cnt >= 10) {
-			bt_disabled = true;
-			btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-					   &bt_disabled);
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-		/* if (!bt_disabled) {} else {} */
-	}
-}
-
-void halbtc8821a2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = true;
-		bt_link_info->bt_link_exist = true;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = true;
-	else
-		bt_link_info->sco_only = false;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = true;
-	else
-		bt_link_info->a2dp_only = false;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = true;
-	else
-		bt_link_info->pan_only = false;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = true;
-	else
-		bt_link_info->hid_only = false;
-}
-
-u8 halbtc8821a2ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = false;
-	u8				algorithm = BT_8821A_2ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_2ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				{
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], SCO + HID + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(HS) ==> SCO\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(EDR) ==> SCO\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821A_2ANT_COEX_ALGO_SCO;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8821a2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,
-		IN u8 dac_swing_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	/* There are several type of dacswing */
-	/* 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 */
-	h2c_parameter[0] = dac_swing_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter);
-}
-
-void halbtc8821a2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				       IN u8 dec_bt_pwr_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = dec_bt_pwr_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x62, 1, h2c_parameter);
-}
-
-void halbtc8821a2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				IN boolean force_exec, IN u8 dec_bt_pwr_lvl)
-{
-	coex_dm->cur_bt_dec_pwr_lvl = dec_bt_pwr_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_dec_pwr_lvl == coex_dm->cur_bt_dec_pwr_lvl)
-			return;
-	}
-	halbtc8821a2ant_set_fw_dec_bt_pwr(btcoexist,
-					  coex_dm->cur_bt_dec_pwr_lvl);
-
-	coex_dm->pre_bt_dec_pwr_lvl = coex_dm->cur_bt_dec_pwr_lvl;
-}
-
-void halbtc8821a2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8821a2ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8821a2ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8821a2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,
-			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
-{
-	coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_fw_dac_swing_lvl ==
-		    coex_dm->cur_fw_dac_swing_lvl)
-			return;
-	}
-
-	halbtc8821a2ant_set_fw_dac_swing_level(btcoexist,
-					       coex_dm->cur_fw_dac_swing_lvl);
-
-	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
-}
-
-void halbtc8821a2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,
-		IN boolean rx_rf_shrink_on)
-{
-	if (rx_rf_shrink_on) {
-		/* Shrink RF Rx LPF corner */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Shrink RF Rx LPF corner!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e, 0xfffff,
-					  0xffffc);
-	} else {
-		/* Resume RF Rx LPF corner */
-		/* After initialized, we can use coex_dm->bt_rf_0x1e_backup */
-		if (btcoexist->initilized) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Resume RF Rx LPF corner!!\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1e,
-					  0xfffff, coex_dm->bt_rf_0x1e_backup);
-		}
-	}
-}
-
-void halbtc8821a2ant_rf_shrink(IN struct btc_coexist *btcoexist,
-		       IN boolean force_exec, IN boolean rx_rf_shrink_on)
-{
-	coex_dm->cur_rf_rx_lpf_shrink = rx_rf_shrink_on;
-
-	if (!force_exec) {
-		if (coex_dm->pre_rf_rx_lpf_shrink ==
-		    coex_dm->cur_rf_rx_lpf_shrink)
-			return;
-	}
-	halbtc8821a2ant_set_sw_rf_rx_lpf_corner(btcoexist,
-						coex_dm->cur_rf_rx_lpf_shrink);
-
-	coex_dm->pre_rf_rx_lpf_shrink = coex_dm->cur_rf_rx_lpf_shrink;
-}
-
-void halbtc8821a2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist
-		*btcoexist, IN boolean low_penalty_ra)
-{
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = 0x6;	/* op_code, 0x6= Retry_Penalty */
-
-	if (low_penalty_ra) {
-		h2c_parameter[1] |= BIT(0);
-		h2c_parameter[2] =
-			0x00;  /* normal rate except MCS7/6/5, OFDM54/48/36 */
-		h2c_parameter[3] = 0xf3;  /* MCS7 or OFDM54 */
-		h2c_parameter[4] = 0xa0;  /* MCS6 or OFDM48 */
-		h2c_parameter[5] = 0xa0;	/* MCS5 or OFDM36 */
-		/* h2c_parameter[3] = 0xf7; */ /*MCS7 or OFDM54 */
-		/* h2c_parameter[4] = 0xf8; */ /*MCS6 or OFDM48 */
-		/* h2c_parameter[5] = 0xf9;	/MCS5 or OFDM36	 */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter);
-}
-
-void halbtc8821a2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra)
-			return;
-	}
-	halbtc8821a2ant_set_sw_penalty_tx_rate_adaptive(btcoexist,
-			coex_dm->cur_low_penalty_ra);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-}
-
-void halbtc8821a2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,
-				       IN u32 level)
-{
-	u8	val = (u8)level;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Write SwDacSwing = 0x%x\n", level);
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc5b, 0x3e, val);
-}
-
-void halbtc8821a2ant_set_sw_full_time_dac_swing(IN struct btc_coexist
-		*btcoexist, IN boolean sw_dac_swing_on, IN u32 sw_dac_swing_lvl)
-{
-	if (sw_dac_swing_on)
-		halbtc8821a2ant_set_dac_swing_reg(btcoexist, sw_dac_swing_lvl);
-	else
-		halbtc8821a2ant_set_dac_swing_reg(btcoexist, 0x18);
-}
-
-
-void halbtc8821a2ant_dac_swing(IN struct btc_coexist *btcoexist,
-	IN boolean force_exec, IN boolean dac_swing_on, IN u32 dac_swing_lvl)
-{
-	coex_dm->cur_dac_swing_on = dac_swing_on;
-	coex_dm->cur_dac_swing_lvl = dac_swing_lvl;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_dac_swing_on == coex_dm->cur_dac_swing_on) &&
-		    (coex_dm->pre_dac_swing_lvl ==
-		     coex_dm->cur_dac_swing_lvl))
-			return;
-	}
-	delay_ms(30);
-	halbtc8821a2ant_set_sw_full_time_dac_swing(btcoexist, dac_swing_on,
-			dac_swing_lvl);
-
-	coex_dm->pre_dac_swing_on = coex_dm->cur_dac_swing_on;
-	coex_dm->pre_dac_swing_lvl = coex_dm->cur_dac_swing_lvl;
-}
-
-void halbtc8821a2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,
-				      IN boolean adc_back_off)
-{
-	if (adc_back_off) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x8db, 0x60, 0x3);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB BackOff Level Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x8db, 0x60, 0x1);
-	}
-}
-
-void halbtc8821a2ant_adc_back_off(IN struct btc_coexist *btcoexist,
-			  IN boolean force_exec, IN boolean adc_back_off)
-{
-	coex_dm->cur_adc_back_off = adc_back_off;
-
-	if (!force_exec) {
-		if (coex_dm->pre_adc_back_off == coex_dm->cur_adc_back_off)
-			return;
-	}
-	halbtc8821a2ant_set_adc_back_off(btcoexist, coex_dm->cur_adc_back_off);
-
-	coex_dm->pre_adc_back_off = coex_dm->cur_adc_back_off;
-}
-
-void halbtc8821a2ant_set_agc_table(IN struct btc_coexist *btcoexist,
-				   IN boolean agc_table_en)
-{
-	u8		rssi_adjust_val = 0;
-
-	/* =================BB AGC Gain Table */
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6e1A0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6d1B0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6c1C0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6b1D0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x6a1E0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x691F0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0x68200001);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xaa1A0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa91B0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa81C0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa71D0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa61E0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa51F0001);
-		btcoexist->btc_write_4byte(btcoexist, 0xc78, 0xa4200001);
-	}
-
-
-	/* =================RF Gain */
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xef, 0xfffff, 0x02000);
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x38fff);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x38ffe);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x380c3);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x3b, 0xfffff,
-					  0x28ce6);
-	}
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xef, 0xfffff, 0x0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xed, 0xfffff, 0x1);
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x38fff);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x38ffe);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x380c3);
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x40, 0xfffff,
-					  0x28ce6);
-	}
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0xed, 0xfffff, 0x0);
-
-	/* set rssi_adjust_val for wifi module. */
-	if (agc_table_en)
-		rssi_adjust_val = 8;
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
-			   &rssi_adjust_val);
-}
-
-void halbtc8821a2ant_agc_table(IN struct btc_coexist *btcoexist,
-			       IN boolean force_exec, IN boolean agc_table_en)
-{
-	coex_dm->cur_agc_table_en = agc_table_en;
-
-	if (!force_exec) {
-		if (coex_dm->pre_agc_table_en == coex_dm->cur_agc_table_en)
-			return;
-	}
-	halbtc8821a2ant_set_agc_table(btcoexist, agc_table_en);
-
-	coex_dm->pre_agc_table_en = coex_dm->cur_agc_table_en;
-}
-
-void halbtc8821a2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,
-			   IN boolean shrink_rx_lpf, IN boolean low_penalty_ra,
-			   IN boolean limited_dig, IN boolean bt_lna_constrain)
-{
-
-
-	/* halbtc8821a2ant_rf_shrink(btcoexist, NORMAL_EXEC, shrink_rx_lpf); */
-	halbtc8821a2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra);
-}
-
-void halbtc8821a2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,
-			   IN boolean agc_table_shift, IN boolean adc_back_off,
-			   IN boolean sw_dac_swing, IN u32 dac_swing_lvl)
-{
-
-	halbtc8821a2ant_dac_swing(btcoexist, NORMAL_EXEC, sw_dac_swing,
-				  dac_swing_lvl);
-}
-
-void halbtc8821a2ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8821a2ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8821a2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8821a2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	coex_sta->coex_table_type = type;
-
-	switch (type) {
-	case 0:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x55555555, 0xffffff, 0x3);
-		break;
-	case 1:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55555555, 0x5afa5afa, 0xffffff, 0x3);
-		break;
-	case 2:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x5ada5ada, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 3:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0xaaaaaaaa, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 4:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0xffffffff, 0xffffffff, 0xffffff, 0x3);
-		break;
-	case 5:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0x5fff5fff, 0xffffff, 0x3);
-		break;
-	case 6:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55ff55ff, 0x5a5a5a5a, 0xffffff, 0x3);
-		break;
-	case 7:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 8:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 9:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 10:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 11:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 12:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 13:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 14:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x5fff5fff, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	case 15:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x55dd55dd, 0xaaaaaaaa, 0xffffff, 0x3);
-		break;
-	case 16:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x5fdf5fdf, 0x5fdb5fdb, 0xffffff, 0x3);
-		break;
-	case 17:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0xfafafafa, 0xfafafafa, 0xffffff, 0x3);
-		break;
-	case 18:
-		halbtc8821a2ant_coex_table(btcoexist, force_exec,
-				   0x5555555f, 0x5ada5ada, 0xffffff, 0x3);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8821a2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8821a2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8821a2ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-
-void halbtc8821a2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8821a2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8821a2ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8821a2ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x0, 0, 0, 48, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-				h2c_parameter);
-		} else {
-		}
-	}
-}
-
-void halbtc8821a2ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = false;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	case BTC_PS_LPS_ON:
-		halbtc8821a2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, true);
-		halbtc8821a2ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = true;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/*power save must executed before psTdma*/
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		coex_sta->force_lps_on = true;
-		break;
-	case BTC_PS_LPS_OFF:
-		halbtc8821a2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, false);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		coex_sta->force_lps_on = false;
-		break;
-	default:
-		break;
-	}
-}
-
-
-void halbtc8821a2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean		ap_enable = false;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if (ap_enable) {
-		if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-			real_byte1 &= ~BIT(4);
-			real_byte1 |= BIT(5);
-
-			real_byte5 |= BIT(5);
-			real_byte5 &= ~BIT(6);
-
-			halbtc8821a2ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-		}
-} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-halbtc8821a2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 0x4);
-
-	} else {
-			halbtc8821a2ant_power_save_state(btcoexist,
-				BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	}
-
-	h2c_parameter[0] = byte1;
-	h2c_parameter[1] = byte2;
-	h2c_parameter[2] = byte3;
-	h2c_parameter[3] = byte4;
-	h2c_parameter[4] = byte5;
-
-	coex_dm->ps_tdma_para[0] = byte1;
-	coex_dm->ps_tdma_para[1] = byte2;
-	coex_dm->ps_tdma_para[2] = byte3;
-	coex_dm->ps_tdma_para[3] = byte4;
-	coex_dm->ps_tdma_para[4] = byte5;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-}
-
-void halbtc8821a2ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	u8			wifi_rssi_state1, bt_rssi_state;
-
-
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	if (!(BTC_RSSI_HIGH(wifi_rssi_state1) &&
-	      BTC_RSSI_HIGH(bt_rssi_state)) && turn_on) {
-		type = type + 100; /* for WiFi RSSI low or BT RSSI low */
-	}
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma))
-			return;
-	}
-	if (turn_on) {
-		switch (type) {
-		case 1:
-		default:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0xf1, 0x90);
-			break;
-		case 2:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x2d, 0x03, 0xf1, 0x90);
-			break;
-		case 3:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0xf1, 0x90);
-			break;
-		case 4:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x10, 0x03, 0xf1, 0x90);
-			break;
-		case 5:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x3, 0x70, 0x90);
-			break;
-		case 6:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x12, 0x12, 0x60, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x2d, 0x3, 0x70, 0x90);
-			break;
-		case 7:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0x70, 0x90);
-			break;
-		case 8:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xa3,
-						      0x10, 0x3, 0x70, 0x90);
-			break;
-		case 9:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0xf1, 0x90);
-			break;
-		case 10:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x12, 0x12, 0xe1, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x2d, 0x03, 0xf1, 0x90);
-			break;
-		case 11:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0xa, 0xa, 0xe1, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0xf1, 0x90);
-			break;
-		case 12:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x5, 0x5, 0xe1, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x10, 0x3, 0xf1, 0x90);
-			break;
-		case 13:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1a, 0x1a, 0x60, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x3, 0x70, 0x90);
-			break;
-		case 14:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x12, 0x12, 0x60, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x2d, 0x3, 0x70, 0x90);
-			break;
-		case 15:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0xa, 0xa, 0x60, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1c, 0x3, 0x70, 0x90);
-			break;
-		case 16:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x5, 0x5, 0x60, 0x90); */
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x10, 0x3, 0x70, 0x90);
-			break;
-		case 17:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xa3,
-						      0x2f, 0x2f, 0x60, 0x90);
-			break;
-		case 18:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x5, 0x5, 0xe1, 0x90);
-			break;
-		case 19:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x25, 0xe1, 0x90);
-			break;
-		case 20:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x25, 0x25, 0x60, 0x90);
-			break;
-		case 21:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x03, 0x70, 0x90);
-			break;
-		case 23:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1e, 0x03, 0xf1, 0x94);
-			break;
-		case 24:
-		case 124:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x3c, 0x03, 0x70, 0x50);
-			break;
-		/* case25/case125 : for lenovo bt pan tp degrade<30% while wifi downlink */
-		case 25:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x14, 0x03, 0xf1, 0x90);
-			break;
-		case 26:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x30, 0x03, 0xf1, 0x90);
-			break;
-		case 27:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x23, 0x03, 0x70, 0x50);
-			break;
-		case 28:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x1e, 0x03, 0xf1, 0x94);
-			break;
-		case 71:
-			/* halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3, 0x1a, 0x1a, 0xe1, 0x90); */
-
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0xf1, 0x90);
-			break;
-		case 101:
-		case 105:
-		case 171:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x3a, 0x03, 0x70, 0x50);
-			break;
-		case 102:
-		case 106:
-		case 110:
-		case 114:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x2d, 0x03, 0x70, 0x50);
-			break;
-		case 103:
-		case 107:
-		case 111:
-		case 115:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1c, 0x03, 0x70, 0x50);
-			break;
-		case 104:
-		case 108:
-		case 112:
-		case 116:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x10, 0x03, 0x70, 0x50);
-			break;
-		case 109:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0xf1, 0x90);
-			break;
-		case 113:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x3c, 0x03, 0x70, 0x90);
-			break;
-		case 121:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x15, 0x03, 0x70, 0x90);
-			break;
-		case 22:
-		case 122:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xe3,
-						      0x35, 0x03, 0x71, 0x11);
-			break;
-		case 123:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1e, 0x03, 0x70, 0x54);
-			break;
-		/* case25/case125 : for lenovo bt pan tp degrade<30% while wifi downlink */
-		case 125:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x14, 0x03, 0x70, 0x50);
-			break;
-		case 126:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x30, 0x03, 0x70, 0x50);
-			break;
-		case 127:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x28, 0x03, 0x70, 0x50);
-			break;
-		case 128:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0xd3,
-						      0x1e, 0x03, 0x70, 0x54);
-			break;
-		}
-	} else {
-		/* disable PS tdma */
-		switch (type) {
-		case 0:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		case 1:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x48, 0x0);
-			break;
-		default:
-			halbtc8821a2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		}
-	}
-
-	/* update pre state */
-	coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-	coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-}
-
-
-void halbtc8821a2ant_set_ant_path(IN struct btc_coexist *btcoexist,
-	  IN u8 ant_pos_type, IN boolean init_hwcfg, IN boolean wifi_off)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u32				u32tmp = 0;
-	u8				h2c_parameter[2] = {0};
-
-	if (init_hwcfg) {
-		/* 0x4c[23]=0, 0x4c[24]=1  Antenna control by WL/BT */
-		u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-		u32tmp &= ~BIT(23);
-		u32tmp |= BIT(24);
-		btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp);
-
-		btcoexist->btc_write_4byte(btcoexist, 0x974, 0x3ff);
-		/* btcoexist->btc_write_1byte(btcoexist, 0xcb4, 0x77); */
-
-		if (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT) {
-
-			h2c_parameter[0] = 1;
-			h2c_parameter[1] = 1;
-			btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-						h2c_parameter);
-		} else {
-
-			h2c_parameter[0] = 0;
-			h2c_parameter[1] = 1;
-			btcoexist->btc_fill_h2c(btcoexist, 0x65, 2,
-						h2c_parameter);
-		}
-	}
-
-	/* ext switch setting */
-	switch (ant_pos_type) {
-	case BTC_ANT_WIFI_AT_MAIN:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb7,
-						   0x30, 0x1);
-		break;
-	case BTC_ANT_WIFI_AT_AUX:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb7,
-						   0x30, 0x2);
-		break;
-	}
-}
-
-void halbtc8821a2ant_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-	/* fw all off */
-	halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	/* hw all off */
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); */
-	halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8821a2ant_coex_under_5g(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a2ant_coex_all_off(btcoexist);
-
-	halbtc8821a2ant_ignore_wlan_act(btcoexist, NORMAL_EXEC, true);
-}
-
-void halbtc8821a2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	boolean	wifi_connected = false;
-	boolean	low_pwr_disable = true;
-	boolean		scan = false, link = false, roam = false;
-
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER,
-			   &low_pwr_disable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-	if (scan || link || roam) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi link process + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     7);
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22);
-	} else if (wifi_connected) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     7);
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi no-link + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	}
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6);
-	halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-}
-
-
-void halbtc8821a2ant_action_wifi_link_process(IN struct btc_coexist *btcoexist)
-{
-	u8	u8tmpa, u8tmpb;
-
-	halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22);
-
-	halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-
-
-	u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-	u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "############# [BTCoex], 0x765=0x%x, 0x76e=0x%x\n", u8tmpa,
-		    u8tmpb);
-	BTC_TRACE(trace_buf);
-}
-
-boolean halbtc8821a2ant_action_wifi_idle_process(IN struct btc_coexist
-		*btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u8		ap_num = 0;
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	/* wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2, BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0); */
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 20, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num);
-
-	/* define the office environment */
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) &&
-	    (coex_sta->hid_exist == true) &&
-	    (coex_sta->a2dp_exist == true)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi  idle process for BT HID+A2DP exist!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821a2ant_dac_swing(btcoexist, NORMAL_EXEC, true, 0x6);
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		/* sw all off */
-		halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false,
-					      false);
-		halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-		return true;
-	}
-
-	/* */
-	else if (coex_sta->pan_exist == true) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi  idle process for BT PAN exist!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821a2ant_dac_swing(btcoexist, NORMAL_EXEC, true, 0x6);
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		/* sw all off */
-		halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false,
-					      false);
-		halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-		return true;
-	}
-
-	else {
-		halbtc8821a2ant_dac_swing(btcoexist, NORMAL_EXEC, true, 0x18);
-		return false;
-	}
-
-
-}
-
-
-
-boolean halbtc8821a2ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = false, wifi_connected = false, wifi_busy = false;
-	boolean			bt_hs_on = false, low_pwr_disable = false;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected) {
-		low_pwr_disable = false;
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non-connected idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0);
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-		halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false,
-					      false);
-		halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false,
-					      0x18);
-
-		common = true;
-	} else {
-		if (BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-			low_pwr_disable = false;
-			btcoexist->btc_set(btcoexist,
-					   BTC_SET_ACT_DISABLE_LOW_POWER,
-					   &low_pwr_disable);
-			halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, false, 0x8);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-			BTC_TRACE(trace_buf);
-
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x0);
-			halbtc8821a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-			halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						1);
-			halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 0xb);
-			halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false,
-						      false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-
-			common = true;
-		} else if (BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE ==
-			   coex_dm->bt_status) {
-			low_pwr_disable = true;
-			btcoexist->btc_set(btcoexist,
-					   BTC_SET_ACT_DISABLE_LOW_POWER,
-					   &low_pwr_disable);
-
-			if (bt_hs_on)
-				return false;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi connected + BT connected-idle!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC,
-						   false, false, 0x8);
-
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x0);
-			halbtc8821a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 0);
-
-			halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-						1);
-			halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 0xb);
-			halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-
-			common = true;
-		} else {
-			low_pwr_disable = true;
-			btcoexist->btc_set(btcoexist,
-					   BTC_SET_ACT_DISABLE_LOW_POWER,
-					   &low_pwr_disable);
-
-			if (wifi_busy) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-				common = false;
-				/* common = halbtc8821a2ant_action_wifi_idle_process(btcoexist);	 */
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-				BTC_TRACE(trace_buf);
-				/* common = false;	 */
-				common = halbtc8821a2ant_action_wifi_idle_process(
-						 btcoexist);
-			}
-		}
-	}
-
-	return common;
-}
-void halbtc8821a2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,
-		IN boolean sco_hid, IN boolean tx_pause, IN u8 max_interval)
-{
-	static s32		up, dn, m, n, wait_count;
-	s32			result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-	u8			retry_count = 0;
-
-	if (!coex_dm->auto_tdma_adjust) {
-		coex_dm->auto_tdma_adjust = true;
-		{
-			if (sco_hid) {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					} else if (max_interval == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (max_interval == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					} else if (max_interval == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (max_interval == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			} else {
-				if (tx_pause) {
-					if (max_interval == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (max_interval == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (max_interval == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					}
-				} else {
-					if (max_interval == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (max_interval == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (max_interval == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					}
-				}
-			}
-		}
-		/* ============ */
-		up = 0;
-		dn = 0;
-		m = 1;
-		n = 3;
-		result = 0;
-		wait_count = 0;
-	} else {
-		/* acquire the BT TRx retry count from BT_Info byte2 */
-		retry_count = coex_sta->bt_retry_cnt;
-		result = 0;
-		wait_count++;
-
-		if (retry_count ==
-		    0) { /* no retry in the last 2-second duration */
-			up++;
-			dn--;
-
-			if (dn <= 0)
-				dn = 0;
-
-			if (up >= n) {	/* if 連續 n 個2秒 retry count為0, 則調寬WiFi duration */
-				wait_count = 0;
-				n = 3;
-				up = 0;
-				dn = 0;
-				result = 1;
-			}
-		} else if (retry_count <=
-			   3) {	/* <=3 retry in the last 2-second duration */
-			up--;
-			dn++;
-
-			if (up <= 0)
-				up = 0;
-
-			if (dn == 2) {	/* if 連續 2 個2秒 retry count< 3, 則調窄WiFi duration */
-				if (wait_count <= 2)
-					m++; /* 避免一直在兩個level中來回 */
-				else
-					m = 1;
-
-				if (m >= 20)  /* m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration. */
-					m = 20;
-
-				n = 3 * m;
-				up = 0;
-				dn = 0;
-				wait_count = 0;
-				result = -1;
-			}
-		} else { /* retry count > 3, 只要1次 retry count > 3, 則調窄WiFi duration */
-			if (wait_count == 1)
-				m++; /* 避免一直在兩個level中來回 */
-			else
-				m = 1;
-
-			if (m >= 20)  /* m 最大值 = 20 ' 最大120秒 recheck是否調整 WiFi duration. */
-				m = 20;
-
-			n = 3 * m;
-			up = 0;
-			dn = 0;
-			wait_count = 0;
-			result = -1;
-		}
-
-		if (max_interval == 1) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 71) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 5);
-					coex_dm->ps_tdma_du_adj_type = 5;
-				} else if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 5);
-					coex_dm->ps_tdma_du_adj_type = 5;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 13);
-					coex_dm->ps_tdma_du_adj_type = 13;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 5);
-						coex_dm->ps_tdma_du_adj_type =
-							5;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 13);
-						coex_dm->ps_tdma_du_adj_type =
-							13;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 71);
-					coex_dm->ps_tdma_du_adj_type = 71;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 9);
-					coex_dm->ps_tdma_du_adj_type = 9;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 71) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 1);
-						coex_dm->ps_tdma_du_adj_type =
-							1;
-					} else if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 71);
-						coex_dm->ps_tdma_du_adj_type =
-							71;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 9);
-						coex_dm->ps_tdma_du_adj_type =
-							9;
-					}
-				}
-			}
-		} else if (max_interval == 2) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 6);
-					coex_dm->ps_tdma_du_adj_type = 6;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 14);
-					coex_dm->ps_tdma_du_adj_type = 14;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 6);
-						coex_dm->ps_tdma_du_adj_type =
-							6;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 14);
-						coex_dm->ps_tdma_du_adj_type =
-							14;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 2);
-					coex_dm->ps_tdma_du_adj_type = 2;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 10);
-					coex_dm->ps_tdma_du_adj_type = 10;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 2);
-						coex_dm->ps_tdma_du_adj_type =
-							2;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 10);
-						coex_dm->ps_tdma_du_adj_type =
-							10;
-					}
-				}
-			}
-		} else if (max_interval == 3) {
-			if (tx_pause) {
-				if (coex_dm->cur_ps_tdma == 1) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 2) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 3) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 7);
-					coex_dm->ps_tdma_du_adj_type = 7;
-				} else if (coex_dm->cur_ps_tdma == 4) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 8);
-					coex_dm->ps_tdma_du_adj_type = 8;
-				}
-				if (coex_dm->cur_ps_tdma == 9) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 10) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 11) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 15);
-					coex_dm->ps_tdma_du_adj_type = 15;
-				} else if (coex_dm->cur_ps_tdma == 12) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 16);
-					coex_dm->ps_tdma_du_adj_type = 16;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 5) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 8);
-						coex_dm->ps_tdma_du_adj_type =
-							8;
-					} else if (coex_dm->cur_ps_tdma == 13) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 16);
-						coex_dm->ps_tdma_du_adj_type =
-							16;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 8) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 7) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 6) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 7);
-						coex_dm->ps_tdma_du_adj_type =
-							7;
-					} else if (coex_dm->cur_ps_tdma == 16) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 15) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					} else if (coex_dm->cur_ps_tdma == 14) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 15);
-						coex_dm->ps_tdma_du_adj_type =
-							15;
-					}
-				}
-			} else {
-				if (coex_dm->cur_ps_tdma == 5) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 6) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 7) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 3);
-					coex_dm->ps_tdma_du_adj_type = 3;
-				} else if (coex_dm->cur_ps_tdma == 8) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 4);
-					coex_dm->ps_tdma_du_adj_type = 4;
-				}
-				if (coex_dm->cur_ps_tdma == 13) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 14) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 15) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 11);
-					coex_dm->ps_tdma_du_adj_type = 11;
-				} else if (coex_dm->cur_ps_tdma == 16) {
-					halbtc8821a2ant_ps_tdma(btcoexist,
-							NORMAL_EXEC, true, 12);
-					coex_dm->ps_tdma_du_adj_type = 12;
-				}
-				if (result == -1) {
-					if (coex_dm->cur_ps_tdma == 1) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 4);
-						coex_dm->ps_tdma_du_adj_type =
-							4;
-					} else if (coex_dm->cur_ps_tdma == 9) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 12);
-						coex_dm->ps_tdma_du_adj_type =
-							12;
-					}
-				} else if (result == 1) {
-					if (coex_dm->cur_ps_tdma == 4) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 3) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 2) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 3);
-						coex_dm->ps_tdma_du_adj_type =
-							3;
-					} else if (coex_dm->cur_ps_tdma == 12) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 11) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					} else if (coex_dm->cur_ps_tdma == 10) {
-						halbtc8821a2ant_ps_tdma(
-							btcoexist, NORMAL_EXEC,
-							true, 11);
-						coex_dm->ps_tdma_du_adj_type =
-							11;
-					}
-				}
-			}
-		}
-	}
-
-	/* 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 (coex_dm->cur_ps_tdma != coex_dm->ps_tdma_du_adj_type) {
-		boolean	scan = false, link = false, roam = false;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], PsTdma type dismatch!!!, cur_ps_tdma=%d, recordPsTdma=%d\n",
-			    coex_dm->cur_ps_tdma, coex_dm->ps_tdma_du_adj_type);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (!scan && !link && !roam)
-			halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true,
-						coex_dm->ps_tdma_du_adj_type);
-		else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-}
-
-/* SCO only or SCO+PAN(HS) */
-void halbtc8821a2ant_action_sco(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8	wifi_rssi_state, bt_rssi_state;
-	u32	wifi_bw;
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 4);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if (BTC_WIFI_BW_LEGACY == wifi_bw) /* for SCO quality at 11b/g mode */
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	else { /* for SCO quality & wifi performance balance at 11n mode */
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			halbtc8821a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-		else {
-			if (bt_link_info->sco_only)
-				halbtc8821a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 17);
-			else
-				halbtc8821a2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 12);
-		}
-	}
-
-	halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false,
-				0); /* for voice quality */
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      true, 0x18);
-		}
-	}
-}
-
-
-void halbtc8821a2ant_action_hid(IN struct btc_coexist *btcoexist)
-{
-	u8	wifi_rssi_state, bt_rssi_state;
-	u32	wifi_bw;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if (BTC_WIFI_BW_LEGACY == wifi_bw) /* for HID at 11b/g mode */
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	else  /* for HID quality & wifi performance balance at 11n mode */
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-	halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 24);
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-void halbtc8821a2ant_action_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-	u8		ap_num = 0;
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num);
-
-	/* define the office environment */
-	if ((ap_num >= 10) && BTC_RSSI_HIGH(wifi_rssi_state1) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-		/* dbg_print(" AP#>10(%d)\n", ap_num); */
-
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0);
-		halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false,
-					   0x8);
-		halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-		/* halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 23); */
-
-		/* sw mechanism */
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      true, 0x6);
-		}
-		return;
-
-	}
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-	}
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		/* halbtc8821a2ant_tdma_duration_adjust(btcoexist, false, false, 1); */
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 23);
-	} else {
-		/* halbtc8821a2ant_tdma_duration_adjust(btcoexist, false, true, 1); */
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 23);
-	}
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8821a2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-	}
-
-	halbtc8821a2ant_tdma_duration_adjust(btcoexist, false, true, 2);
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8821a2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     10);
-	} else {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-	}
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH))
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 26);
-	else
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 26);
-
-	/* sw mechanism */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-
-/* PAN(HS) only */
-void halbtc8821a2ant_action_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-	halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* PAN(EDR)+A2DP */
-void halbtc8821a2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     12);
-
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			halbtc8821a2ant_tdma_duration_adjust(btcoexist, false,
-							     true, 3);
-		else
-			halbtc8821a2ant_tdma_duration_adjust(btcoexist, false,
-							     false, 3);
-	} else {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     13);
-		halbtc8821a2ant_tdma_duration_adjust(btcoexist, false, true, 3);
-	}
-
-	/* sw mechanism	 */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, false,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8821a2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     14);
-	}
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		if (BTC_WIFI_BW_HT40 == wifi_bw) {
-			halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 3);
-			/* halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11); */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x780);
-		} else {
-			halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC,
-							 6);
-			/* halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); */
-			btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1,
-						  0xfffff, 0x0);
-		}
-		halbtc8821a2ant_tdma_duration_adjust(btcoexist, true, false, 2);
-	} else {
-		halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-		/* halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14); */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-					  0x0);
-		halbtc8821a2ant_tdma_duration_adjust(btcoexist, true, true, 2);
-	}
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-/* HID+A2DP+PAN(EDR) */
-void halbtc8821a2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1,  bt_rssi_state;
-	u32		wifi_bw;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 0);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	if (BTC_RSSI_HIGH(bt_rssi_state))
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-	else
-		halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	} else {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     14);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			halbtc8821a2ant_tdma_duration_adjust(btcoexist, true,
-							     true, 3);
-		else
-			halbtc8821a2ant_tdma_duration_adjust(btcoexist, true,
-							     false, 3);
-	} else
-		halbtc8821a2ant_tdma_duration_adjust(btcoexist, true, true, 3);
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8821a2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
-{
-	u8		wifi_rssi_state, wifi_rssi_state1, bt_rssi_state;
-	u32		wifi_bw;
-	u8		ap_num = 0;
-
-	btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-
-	wifi_rssi_state = halbtc8821a2ant_wifi_rssi_state(btcoexist, 0, 2, 15,
-			  0);
-	/* bt_rssi_state = halbtc8821a2ant_bt_rssi_state(2, 29, 0); */
-	wifi_rssi_state1 = halbtc8821a2ant_wifi_rssi_state(btcoexist, 1, 2,
-			   BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES, 0);
-	bt_rssi_state = halbtc8821a2ant_bt_rssi_state(3,
-			BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES, 37);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0);
-
-	halbtc8821a2ant_limited_rx(btcoexist, NORMAL_EXEC, false, true, 0x6);
-
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	if (BTC_WIFI_BW_LEGACY == wifi_bw) {
-		if (BTC_RSSI_HIGH(bt_rssi_state))
-			halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else if (BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	} else {
-		/* only 802.11N mode we have to dec bt power to 4 degree */
-		if (BTC_RSSI_HIGH(bt_rssi_state)) {
-			btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-					   &ap_num);
-			/* need to check ap Number of Not */
-			if (ap_num < 10)
-				halbtc8821a2ant_dec_bt_pwr(btcoexist,
-							   NORMAL_EXEC, 4);
-			else
-				halbtc8821a2ant_dec_bt_pwr(btcoexist,
-							   NORMAL_EXEC, 2);
-		} else if (BTC_RSSI_MEDIUM(bt_rssi_state))
-			halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-		else
-			halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	}
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     18);
-	} else {
-		halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     18);
-	}
-
-	if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) ||
-	    (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-		/* halbtc8821a2ant_tdma_duration_adjust(btcoexist, true, false, 3); */
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 28);
-	} else {
-		/* halbtc8821a2ant_tdma_duration_adjust(btcoexist, true, true, 3); */
-		halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 28);
-	}
-
-	/* sw mechanism */
-	if (BTC_WIFI_BW_HT40 == wifi_bw) {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, true, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	} else {
-		if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) ||
-		    (wifi_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, true, false,
-						      false, 0x18);
-		} else {
-			halbtc8821a2ant_sw_mechanism1(btcoexist, false, true,
-						      false, false);
-			halbtc8821a2ant_sw_mechanism2(btcoexist, false, false,
-						      false, 0x18);
-		}
-	}
-}
-
-void halbtc8821a2ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-	halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8821a2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6);
-	halbtc8821a2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* sw all off */
-	halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-
-	/* hw all off */
-	/* btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); */
-	halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1);
-}
-
-void halbtc8821a2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	boolean				wifi_under_5g = false;
-	u8				algorithm = 0;
-	u32				num_of_wifi_link = 0;
-	u32				wifi_link_status = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean				miracast_plus_bt = false;
-	boolean				scan = false, link = false, roam = false;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), run 5G coex setting!!<===\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_coex_under_5g(btcoexist);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_action_bt_whck_test(btcoexist);
-		return;
-	}
-
-	algorithm = halbtc8821a2ant_action_algorithm(btcoexist);
-	if (coex_sta->c2h_bt_inquiry_page &&
-	    (BT_8821A_2ANT_COEX_ALGO_PANHS != algorithm)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-	if (scan || link || roam) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under Link Process !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_action_wifi_link_process(btcoexist);
-		return;
-	}
-
-	/* for P2P */
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist)
-			miracast_plus_bt = true;
-		else
-			miracast_plus_bt = false;
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-		halbtc8821a2ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	}
-	miracast_plus_bt = false;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-			   &miracast_plus_bt);
-
-	coex_dm->cur_algorithm = algorithm;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Algorithm = %d\n",
-		    coex_dm->cur_algorithm);
-	BTC_TRACE(trace_buf);
-
-	if (halbtc8821a2ant_is_common_action(btcoexist)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant common.\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->auto_tdma_adjust = false;
-	} else {
-		if (coex_dm->cur_algorithm != coex_dm->pre_algorithm) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], pre_algorithm=%d, cur_algorithm=%d\n",
-				coex_dm->pre_algorithm, coex_dm->cur_algorithm);
-			BTC_TRACE(trace_buf);
-			coex_dm->auto_tdma_adjust = false;
-		}
-		switch (coex_dm->cur_algorithm) {
-		case BT_8821A_2ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_sco(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_hid(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_a2dp(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_a2dp_pan_hs(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_pan_edr(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_pan_hs(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_pan_edr_a2dp(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_pan_edr_hid(btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_hid_a2dp_pan_edr(
-				btcoexist);
-			break;
-		case BT_8821A_2ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_action_hid_a2dp(btcoexist);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_coex_all_off(btcoexist);
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-void halbtc8821a2ant_wifi_off_hw_cfg(IN struct btc_coexist *btcoexist)
-{
-	u8 h2c_parameter[2] = {0};
-	u32 fw_ver = 0;
-
-	/* set wlan_act to low */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4);
-
-	btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff,
-			  0x780); /* WiFi goto standby while GNT_BT 0-->1 */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	if (fw_ver >= 0x180000) {
-		/* Use H2C to set GNT_BT to HIGH */
-		h2c_parameter[0] = 1;
-		btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1, h2c_parameter);
-	} else
-		btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18);
-}
-
-void halbtc8821a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-	halbtc8821a2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821a2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 1);
-	halbtc8821a2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6);
-	halbtc8821a2ant_dec_bt_pwr(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8821a2ant_sw_mechanism1(btcoexist, false, false, false, false);
-	halbtc8821a2ant_sw_mechanism2(btcoexist, false, false, false, 0x18);
-}
-
-void halbtc8821a2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up)
-{
-	u8	u8tmp = 0;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 2Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	/* Give bt_coex_supported_version the default value */
-	coex_sta->bt_coex_supported_version = 0;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	/* backup rf 0x1e value */
-	coex_dm->bt_rf_0x1e_backup =
-		btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x1e, 0xfffff);
-
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	/* Antenna config	 */
-	halbtc8821a2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_MAIN, true,
-				     false);
-	coex_sta->dis_ver_info_cnt = 0;
-
-	/* PTA parameter */
-	halbtc8821a2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	/* Enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e,
-			   0x4); /* 0x76e[3] =1, WLAN_Act control by PTA */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x3);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-}
-
-/* ************************************************************
- * work around function start with wa_halbtc8821a2ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8821a2ant_
- * ************************************************************ */
-void ex_halbtc8821a2ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-
-}
-
-void ex_halbtc8821a2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x4; /* Set BIT2 by default since it's 2ant case */
-
-	/* */
-	/* S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info) */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-	if (btcoexist->chip_interface == BTC_INTF_USB) {
-		/* fixed at S0 for USB interface */
-		u8tmp |= 0x1;	/* antenna inverse */
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	} else {
-		/* for PCIE and SDIO interface, we check efuse 0xc3[6] */
-		if (board_info->single_ant_path == 0) {
-		} else if (board_info->single_ant_path == 1) {
-			/* set to S0 */
-			u8tmp |= 0x1;	/* antenna inverse */
-		}
-
-		if (btcoexist->chip_interface == BTC_INTF_PCI)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x384,
-							     u8tmp);
-		else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60,
-							     u8tmp);
-	}
-}
-
-void ex_halbtc8821a2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8821a2ant_init_hw_config(btcoexist, true);
-}
-
-void ex_halbtc8821a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8821a2ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8821a2ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u32				u32tmp[4];
-	u32				fw_ver = 0, bt_patch_ver = 0;
-	u32				bt_coex_ver = 0;
-	u32				phyver = 0;
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "Ant PG number/ Ant mechanism:",
-		   board_info->pg_ant_num, board_info->btdm_ant_num);
-	CL_PRINTF(cli_buf);
-
-	/* btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver); */
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-	bt_coex_ver = coex_sta->bt_coex_supported_version & 0xff;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8821a_2ant, glcoex_ver_8821a_2ant,
-		   glcoex_ver_btdesired_8821a_2ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (bt_coex_ver >= glcoex_ver_btdesired_8821a_2ant ?
-		     "Match" : "Mis-Match")));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %ddBm/ %d] ",
-		   "BT [status/ rssi/ retryCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d",
-		   "SCO/HID/PAN/A2DP",
-		   bt_link_info->sco_exist, bt_link_info->hid_exist,
-		   bt_link_info->pan_exist, bt_link_info->a2dp_exist);
-	CL_PRINTF(cli_buf);
-
-	{
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-			   "BT Role",
-			   (bt_link_info->slave_role) ? "Slave" : "Master");
-		CL_PRINTF(cli_buf);
-	}
-
-	bt_info_ext = coex_sta->bt_info_ext;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-		   "BT Info A2DP rate",
-		   (bt_info_ext & BIT(0)) ? "Basic rate" : "EDR rate");
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8821A_2ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8821a_2ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	/* Sw mechanism	 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Sw mechanism]============");
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ",
-		   "SM1[ShRf/ LpRA/ LimDig]",
-		   coex_dm->cur_rf_rx_lpf_shrink, coex_dm->cur_low_penalty_ra,
-		   coex_dm->limited_dig);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d(0x%x) ",
-		   "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]",
-		   coex_dm->cur_agc_table_en, coex_dm->cur_adc_back_off,
-		   coex_dm->cur_dac_swing_on, coex_dm->cur_dac_swing_lvl);
-	CL_PRINTF(cli_buf);
-
-	/* Fw mechanism		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Fw mechanism]============");
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (auto:%d)",
-		   "PS TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   coex_dm->auto_tdma_adjust);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "Coex Table Type",
-		   coex_sta->coex_table_type);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d ",
-		   "DecBtPwr/ IgnWlanAct",
-		   coex_dm->cur_bt_dec_pwr_lvl, coex_dm->cur_ignore_wlan_act);
-	CL_PRINTF(cli_buf);
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x",
-		   "RF-A, 0x1e initVal",
-		   coex_dm->bt_rf_0x1e_backup);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0xc5b);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x880);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x778/0x880[29:25]/0xc58[29:25]",
-		   u8tmp[0], (u32tmp[0] & 0x3e000000) >> 25,
-		   ((u8tmp[1] & 0x3e) >> 1));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x764);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x764/ 0x765/ 0x76e",
-		   (u32tmp[0] & 0xff), (u32tmp[0] & 0xff00) >> 8, u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0xcb4[7:0](ctrl)/ 0xcb4[29:28](val)",
-		   u32tmp[0] & 0xff, ((u32tmp[0] & 0x30000000) >> 28));
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x974);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x40/ 0x4c[24:23]/ 0x974",
-		   u8tmp[0], ((u32tmp[0] & 0x01800000) >> 23), u32tmp[1]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x550(bcn ctrl)/0x522",
-		   u32tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x49c);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0xc50(dig)/0x49c(null-drop)",
-		   u32tmp[0] & 0xff, u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11n-agg",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(high-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(low-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8821A_2ANT == 1)
-	/* halbtc8821a2ant_monitor_bt_ctr(btcoexist); */
-#endif
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8821a2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = true;
-		halbtc8821a2ant_wifi_off_hw_cfg(btcoexist);
-		halbtc8821a2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-		halbtc8821a2ant_coex_all_off(btcoexist);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = false;
-		halbtc8821a2ant_init_hw_config(btcoexist, false);
-		halbtc8821a2ant_init_coex_dm(btcoexist);
-		halbtc8821a2ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8821a2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = true;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = false;
-	}
-}
-
-void ex_halbtc8821a2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	u8	u8tmpa, u8tmpb;
-
-	u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-	u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-
-	if (BTC_SCAN_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-	} else if (BTC_SCAN_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "############# [BTCoex], 0x765=0x%x, 0x76e=0x%x\n", u8tmpa,
-		    u8tmpb);
-	BTC_TRACE(trace_buf);
-}
-
-/* copy scan notify content to switch band notify */
-void ex_halbtc8821a2ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8	u8tmpa, u8tmpb;
-
-	u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765);
-	u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x76e);
-
-	if (BTC_SCAN_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-	} else if (BTC_SCAN_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "############# [BTCoex], 0x765=0x%x, 0x76e=0x%x\n", u8tmpa,
-		    u8tmpb);
-	BTC_TRACE(trace_buf);
-}
-
-void ex_halbtc8821a2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	if (BTC_ASSOCIATE_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-	} else if (BTC_ASSOCIATE_FINISH == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void ex_halbtc8821a2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	u8			ap_num = 0;
-
-	if (BTC_MEDIA_CONNECT == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		h2c_parameter[0] = 0x1;
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else {
-			btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-					   &ap_num);
-			if (ap_num < 10)
-				h2c_parameter[2] = 0x30;
-			else
-				h2c_parameter[2] = 0x20;
-		}
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-}
-
-void ex_halbtc8821a2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	if (type == BTC_PACKET_DHCP) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], DHCP Packet notify\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void ex_halbtc8821a2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8			bt_info = 0;
-	u8			i, rsp_source = 0;
-	boolean			bt_busy = false, limited_dig = false;
-	boolean			wifi_connected = false, wifi_under_5g = false;
-
-	coex_sta->c2h_bt_info_req_sent = false;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8821A_2ANT_MAX)
-		rsp_source = BT_INFO_SRC_8821A_2ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt info[%d], length=%d, hex data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-		if (i == 1)
-			bt_info = tmp_buf[i];
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), return for Manual CTRL<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	/* if 0xff, it means BT is under WHCK test */
-	if (bt_info == 0xff)
-		coex_sta->bt_whck_test = true;
-	else
-		coex_sta->bt_whck_test = false;
-
-	if (BT_INFO_SRC_8821A_2ANT_WIFI_FW != rsp_source) {
-		coex_sta->bt_retry_cnt =	/* [3:0] */
-			coex_sta->bt_info_c2h[rsp_source][2] & 0xf;
-
-		coex_sta->bt_rssi =
-			coex_sta->bt_info_c2h[rsp_source][3] * 2 + 10;
-
-		coex_sta->bt_info_ext =
-			coex_sta->bt_info_c2h[rsp_source][4];
-
-		coex_sta->bt_tx_rx_mask = (coex_sta->bt_info_c2h[rsp_source][2]
-					   & 0x40);
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TX_RX_MASK,
-				   &coex_sta->bt_tx_rx_mask);
-		if (coex_sta->bt_tx_rx_mask) {
-			/* BT into is responded by BT FW and BT RF REG 0x3C != 0x01 => Need to switch BT TRx Mask */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Switch BT TRx Mask since BT RF REG 0x3C != 0x01\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF,
-						  0x3c, 0x01);
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-		if ((coex_sta->bt_info_ext & BIT(1))) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-			BTC_TRACE(trace_buf);
-			if (wifi_connected)
-				ex_halbtc8821a2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_CONNECT);
-			else
-				ex_halbtc8821a2ant_media_status_notify(
-					btcoexist, BTC_MEDIA_DISCONNECT);
-		}
-
-
-		if (!btcoexist->manual_control && !wifi_under_5g) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT ext info = 0x%x!!\n",
-				    coex_sta->bt_info_ext);
-			BTC_TRACE(trace_buf);
-			if ((coex_sta->bt_info_ext & BIT(3))) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3=1, wifi_connected=%d\n",
-					    wifi_connected);
-				BTC_TRACE(trace_buf);
-				if (wifi_connected) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-					BTC_TRACE(trace_buf);
-					halbtc8821a2ant_ignore_wlan_act(
-						btcoexist, FORCE_EXEC, false);
-				}
-			} else {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3=0, wifi_connected=%d\n",
-					    wifi_connected);
-				BTC_TRACE(trace_buf);
-				/* BT already NOT ignore Wlan active, do nothing here. */
-				if (!wifi_connected) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT ext info bit3 check, set BT to ignore Wlan active!!\n");
-					BTC_TRACE(trace_buf);
-					halbtc8821a2ant_ignore_wlan_act(
-						btcoexist, FORCE_EXEC, true);
-				}
-			}
-		}
-
-#if (BT_AUTO_REPORT_ONLY_8821A_2ANT == 0)
-		if ((coex_sta->bt_info_ext & BIT(4))) {
-			/* BT auto report already enabled, do nothing */
-		} else
-			halbtc8821a2ant_bt_auto_report(btcoexist, FORCE_EXEC,
-						       true);
-#endif
-	}
-
-	/* check BIT2 first ==> check if bt is under inquiry or page scan */
-	if (bt_info & BT_INFO_8821A_2ANT_B_INQ_PAGE)
-		coex_sta->c2h_bt_inquiry_page = true;
-	else
-		coex_sta->c2h_bt_inquiry_page = false;
-
-	/* set link exist status */
-	if (!(bt_info & BT_INFO_8821A_2ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = false;
-		coex_sta->pan_exist = false;
-		coex_sta->a2dp_exist = false;
-		coex_sta->hid_exist = false;
-		coex_sta->sco_exist = false;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = true;
-		if (bt_info & BT_INFO_8821A_2ANT_B_FTP)
-			coex_sta->pan_exist = true;
-		else
-			coex_sta->pan_exist = false;
-		if (bt_info & BT_INFO_8821A_2ANT_B_A2DP)
-			coex_sta->a2dp_exist = true;
-		else
-			coex_sta->a2dp_exist = false;
-		if (bt_info & BT_INFO_8821A_2ANT_B_HID)
-			coex_sta->hid_exist = true;
-		else
-			coex_sta->hid_exist = false;
-		if (bt_info & BT_INFO_8821A_2ANT_B_SCO_ESCO)
-			coex_sta->sco_exist = true;
-		else
-			coex_sta->sco_exist = false;
-
-		if ((coex_sta->hid_exist == false) &&
-		    (coex_sta->c2h_bt_inquiry_page == false) &&
-		    (coex_sta->sco_exist == false)) {
-			if (coex_sta->high_priority_tx  +
-			    coex_sta->high_priority_rx >= 160)
-				coex_sta->hid_exist = true;
-		}
-	}
-
-	halbtc8821a2ant_update_bt_link_info(btcoexist);
-
-	if (!(bt_info & BT_INFO_8821A_2ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info ==
-		BT_INFO_8821A_2ANT_B_CONNECTION) {	/* connection exists but no busy */
-		coex_dm->bt_status = BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if ((bt_info & BT_INFO_8821A_2ANT_B_SCO_ESCO) ||
-		   (bt_info & BT_INFO_8821A_2ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8821A_2ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else if (bt_info & BT_INFO_8821A_2ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8821A_2ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_dm->bt_status = BT_8821A_2ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((BT_8821A_2ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8821A_2ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8821A_2ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status)) {
-		bt_busy = true;
-		limited_dig = true;
-	} else {
-		bt_busy = false;
-		limited_dig = false;
-	}
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	coex_dm->limited_dig = limited_dig;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_LIMITED_DIG, &limited_dig);
-
-	halbtc8821a2ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8821a2ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8821a2ant_wifi_off_hw_cfg(btcoexist);
-	/* remove due to interrupt is disabled that polling c2h will fail and delay 100ms. */
-	/* btcoexist->btc_set_bt_reg(btcoexist, BTC_BT_REG_RF, 0x3c, 0x15); */ /*BT goto standby while GNT_BT 1-->0 */
-	halbtc8821a2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true);
-
-	ex_halbtc8821a2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-}
-
-void ex_halbtc8821a2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_WIFI_PNP_SLEEP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821a2ant_init_hw_config(btcoexist, false);
-		halbtc8821a2ant_init_coex_dm(btcoexist);
-		halbtc8821a2ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8821a2ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	u32 bt_patch_ver;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ==========================Periodical===========================\n");
-	BTC_TRACE(trace_buf);
-
-	if (coex_sta->dis_ver_info_cnt <= 5) {
-		coex_sta->dis_ver_info_cnt += 1;
-		if (coex_sta->dis_ver_info_cnt == 3) {
-			/* Antenna config to set 0x765 = 0x0 (GNT_BT control by PTA) after initial */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Set GNT_BT control by PTA\n");
-			BTC_TRACE(trace_buf);
-			halbtc8821a2ant_set_ant_path(btcoexist,
-				     BTC_ANT_WIFI_AT_MAIN, false, false);
-		}
-	}
-
-	if (((coex_sta->bt_coex_supported_version == 0) ||
-	     (coex_sta->bt_coex_supported_version == 0xffff)) && (!coex_sta->bt_disabled))
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION, &coex_sta->bt_coex_supported_version);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-#if (BT_AUTO_REPORT_ONLY_8821A_2ANT == 0)
-	halbtc8821a2ant_query_bt_info(btcoexist);
-	halbtc8821a2ant_monitor_bt_enable_disable(btcoexist);
-#else
-	halbtc8821a2ant_monitor_bt_ctr(btcoexist);
-	halbtc8821a2ant_monitor_wifi_ctr(btcoexist);
-	halbtc8821a2ant_monitor_bt_enable_disable(btcoexist);
-
-	if (halbtc8821a2ant_is_wifi_status_changed(btcoexist) ||
-	    coex_dm->auto_tdma_adjust)
-		halbtc8821a2ant_run_coexist_mechanism(btcoexist);
-#endif
-}
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a2ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a2ant.h
deleted file mode 100644
index d76f566f966b..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821a2ant.h
+++ /dev/null
@@ -1,225 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821A_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8821A 2Ant BT Co-exist definition
- * ******************************************* */
-#define	BT_AUTO_REPORT_ONLY_8821A_2ANT				1
-
-
-#define	BT_INFO_8821A_2ANT_B_FTP						BIT(7)
-#define	BT_INFO_8821A_2ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8821A_2ANT_B_HID						BIT(5)
-#define	BT_INFO_8821A_2ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8821A_2ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8821A_2ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8821A_2ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8821A_2ANT_B_CONNECTION				BIT(0)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT		2
-
-
-#define	BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES				42  /* WiFi RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation */
-#define	BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES				46 /* BT RSSI Threshold for 2-Ant TDMA/1-Ant PS-TDMA translation */
-
-enum bt_info_src_8821a_2ant {
-	BT_INFO_SRC_8821A_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8821A_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8821A_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8821A_2ANT_MAX
-};
-
-enum bt_8821a_2ant_bt_status {
-	BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8821A_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8821A_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8821A_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8821A_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8821A_2ANT_BT_STATUS_MAX
-};
-
-enum bt_8821a_2ant_coex_algo {
-	BT_8821A_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8821A_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8821A_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8821A_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8821A_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8821A_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8821A_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8821A_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8821A_2ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-struct coex_dm_8821a_2ant {
-	/* fw mechanism */
-	u8		pre_bt_dec_pwr_lvl;
-	u8		cur_bt_dec_pwr_lvl;
-	u8		pre_fw_dac_swing_lvl;
-	u8		cur_fw_dac_swing_lvl;
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		reset_tdma_adjust;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-
-	/* sw mechanism */
-	boolean		pre_rf_rx_lpf_shrink;
-	boolean		cur_rf_rx_lpf_shrink;
-	u32		bt_rf_0x1e_backup;
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	boolean		pre_dac_swing_on;
-	u32		pre_dac_swing_lvl;
-	boolean		cur_dac_swing_on;
-	u32		cur_dac_swing_lvl;
-	boolean		pre_adc_back_off;
-	boolean		cur_adc_back_off;
-	boolean	pre_agc_table_en;
-	boolean		cur_agc_table_en;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	boolean		need_recover0x948;
-	u32		backup0x948;
-
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-};
-
-struct coex_sta_8821a_2ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	u8					bt_rssi;
-	boolean					bt_tx_rx_mask;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	boolean					c2h_bt_info_req_sent;
-	u8					bt_info_c2h[BT_INFO_SRC_8821A_2ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821A_2ANT_MAX];
-	boolean				bt_whck_test;
-	boolean					c2h_bt_inquiry_page;
-	u8					bt_retry_cnt;
-	u8					bt_info_ext;
-	u8					scan_ap_num;
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	u32					bt_coex_supported_version;
-	u8					cut_version;
-	u8					coex_table_type;
-	boolean					force_lps_on;
-
-	u8					dis_ver_info_cnt;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8821a2ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a2ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8821a2ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a2ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821a2ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821a2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8821a2ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821a2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8821a2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821a2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821a2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8821a2ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8821a2ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821a2ant_display_coex_info(IN struct btc_coexist *btcoexist);
-
-#else
-#define	ex_halbtc8821a2ant_power_on_setting(btcoexist)
-#define	ex_halbtc8821a2ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8821a2ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8821a2ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8821a2ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8821a2ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8821a2ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8821a2ant_switchband_notify(btcoexist, type)
-#define	ex_halbtc8821a2ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8821a2ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8821a2ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8821a2ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8821a2ant_halt_notify(btcoexist)
-#define	ex_halbtc8821a2ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8821a2ant_periodical(btcoexist)
-#define	ex_halbtc8821a2ant_display_coex_info(btcoexist)
-#endif
-
-#endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c1ant.c
deleted file mode 100644
index 0abc5a1c77e0..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c1ant.c
+++ /dev/null
@@ -1,5613 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8821C Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821C_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	*trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8821c_1ant		glcoex_dm_8821c_1ant;
-static struct  coex_dm_8821c_1ant	*coex_dm = &glcoex_dm_8821c_1ant;
-static struct  coex_sta_8821c_1ant		glcoex_sta_8821c_1ant;
-static struct  coex_sta_8821c_1ant	*coex_sta = &glcoex_sta_8821c_1ant;
-static struct  psdscan_sta_8821c_1ant		gl_psd_scan_8821c_1ant;
-static struct  psdscan_sta_8821c_1ant	*psd_scan = &gl_psd_scan_8821c_1ant;
-static struct	rfe_type_8821c_1ant		gl_rfe_type_8821c_1ant;
-static struct	rfe_type_8821c_1ant		*rfe_type = &gl_rfe_type_8821c_1ant;
-
-
-const char *const glbt_info_src_8821c_1ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8821c_1ant = 20170727;
-u32	glcoex_ver_8821c_1ant = 0x1b;
-u32	glcoex_ver_btdesired_8821c_1ant = 0x1b;
-
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8821c1ant_
- * ************************************************************ */
-u8 halbtc8821c1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8821c1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-void halbtc8821c1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-void halbtc8821c1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = FALSE;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-void halbtc8821c1ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-void halbtc8821c1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-void halbtc8821c1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8821c1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8821c1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8821c1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
-	}
-
-	halbtc8821c1ant_auto_rate_fallback_retry(btcoexist, force_exec, arfr_type);
-	halbtc8821c1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8821c1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-void halbtc8821c1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-void halbtc8821c1ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], No query BT info because BT is disabled!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], WL query BT info!!\n");
-	BTC_TRACE(trace_buf);
-}
-
-void halbtc8821c1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0, cnt_slave = 0, cnt_overhead = 0,
-				cnt_autoslot_hang = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS */
-	/* if (! (btcoexist->btc_read_1byte(btcoexist, 0x76e) & 0x8) ) */
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-
-	BTC_TRACE(trace_buf);
-
-	if (BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	    coex_dm->bt_status) {
-
-		if (coex_sta->high_priority_rx >= 15) {
-			if (cnt_overhead < 3)
-				cnt_overhead++;
-
-			if (cnt_overhead == 3)
-				coex_sta->is_hiPri_rx_overhead = TRUE;
-
-		} else {
-			if (cnt_overhead > 0)
-				cnt_overhead--;
-
-			if (cnt_overhead == 0)
-				coex_sta->is_hiPri_rx_overhead = FALSE;
-		}
-	} else
-		coex_sta->is_hiPri_rx_overhead = FALSE;
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	if ((coex_sta->low_priority_tx > 1150)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	if ((coex_sta->low_priority_rx >= 1150) &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx)
-	    && (!coex_sta->under_ips)
-	    && (!coex_sta->c2h_bt_inquiry_page)
-	    && ((bt_link_info->a2dp_exist) || (bt_link_info->pan_exist))) {
-		if (cnt_slave >= 2) {
-			bt_link_info->slave_role = TRUE;
-			cnt_slave = 2;
-		} else
-			cnt_slave++;
-	} else {
-		if (cnt_slave == 0)	{
-			bt_link_info->slave_role = FALSE;
-			cnt_slave = 0;
-		} else
-			cnt_slave--;
-	}
-
-	if (coex_sta->is_tdma_btautoslot) {
-		if ((coex_sta->low_priority_tx >= 1300) &&
-		(coex_sta->low_priority_rx <= 150)) {
-			if (cnt_autoslot_hang >= 2) {
-				coex_sta->is_tdma_btautoslot_hang = TRUE;
-				cnt_autoslot_hang = 2;
-			} else
-				cnt_autoslot_hang++;
-		} else {
-			if (cnt_autoslot_hang == 0)	{
-				coex_sta->is_tdma_btautoslot_hang = FALSE;
-				cnt_autoslot_hang = 0;
-			} else
-				cnt_autoslot_hang--;
-		}
-	}
-
-	if (bt_link_info->hid_only) {
-		if (coex_sta->low_priority_rx > 50)
-			coex_sta->is_hid_low_pri_tx_overhead = true;
-		else
-			coex_sta->is_hid_low_pri_tx_overhead = false;
-	}
-
-	if (!coex_sta->bt_disabled) {
-
-		if ((coex_sta->high_priority_tx == 0) &&
-		    (coex_sta->high_priority_rx == 0) &&
-		    (coex_sta->low_priority_tx == 0) &&
-		    (coex_sta->low_priority_rx == 0)) {
-			num_of_bt_counter_chk++;
-			if (num_of_bt_counter_chk >= 3) {
-				halbtc8821c1ant_query_bt_info(btcoexist);
-				num_of_bt_counter_chk = 0;
-			}
-		}
-	}
-
-}
-
-
-
-void halbtc8821c1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-	s32	wifi_rssi = 0;
-	boolean wifi_busy = FALSE, wifi_under_b_mode = FALSE,
-			wifi_scan = FALSE, wifi_connected = FALSE;
-	boolean bt_idle = FALSE, wl_idle = FALSE, is_cck_deadlock = FALSE;
-	static u8 cck_lock_counter = 0, wl_noisy_count0 = 0,
-		  wl_noisy_count1 = 3, wl_noisy_count2 = 0;
-	u32	total_cnt, reg_val1, reg_val2, cnt_cck;
-	u32 cnt_crcok = 0, cnt_crcerr = 0;
-	static u8 cnt = 0, cnt_ccklocking = 0;
-	u8	h2c_parameter[1] = {0};
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* Only enable for windows becaus 8821cu H2C 0x69 unknown fail @ linux */
-	if (btcoexist->chip_interface != BTC_INTF_USB) {
-		/*send h2c to query WL FW dbg info  */
-		if (((coex_dm->cur_ps_tdma_on) && (coex_sta->force_lps_ctrl)) ||
-			 ((coex_sta->acl_busy) && (bt_link_info->a2dp_exist))) {
-			h2c_parameter[0] = 0x8;
-			btcoexist->btc_fill_h2c(btcoexist, 0x69, 1, h2c_parameter);
-		}
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-			   &wifi_under_b_mode);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_ERROR_VHT);
-
-	cnt_crcok =  coex_sta->crc_ok_cck + coex_sta->crc_ok_11g
-				+ coex_sta->crc_ok_11n
-				+ coex_sta->crc_ok_11n_vht;
-
-	cnt_crcerr =  coex_sta->crc_err_cck + coex_sta->crc_err_11g
-				+ coex_sta->crc_err_11n
-				+ coex_sta->crc_err_11n_vht;
-
-	/* CCK lock identification */
-	if (coex_sta->cck_lock)
-		cnt_ccklocking++;
-	else if	(cnt_ccklocking != 0)
-		cnt_ccklocking--;
-
-	if (cnt_ccklocking >= 3) {
-		cnt_ccklocking = 3;
-		coex_sta->cck_lock_ever = TRUE;
-	}
-
-	/* WiFi environment noisy identification */
-	cnt_cck = coex_sta->crc_ok_cck + coex_sta->crc_err_cck;
-
-	if ((!wifi_busy) && (!coex_sta->cck_lock)) {
-		if (cnt_cck > 250) {
-			if (wl_noisy_count2 < 3)
-				wl_noisy_count2++;
-
-			if (wl_noisy_count2 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count1 = 0;
-			}
-
-		} else if (cnt_cck < 50) {
-			if (wl_noisy_count0 < 3)
-				wl_noisy_count0++;
-
-			if (wl_noisy_count0 == 3) {
-				wl_noisy_count1 = 0;
-				wl_noisy_count2 = 0;
-			}
-
-		} else {
-			if (wl_noisy_count1 < 3)
-				wl_noisy_count1++;
-
-			if (wl_noisy_count1 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count2 = 0;
-			}
-	}
-
-		if (wl_noisy_count2 == 3)
-			coex_sta->wl_noisy_level = 2;
-		else if (wl_noisy_count1 == 3)
-			coex_sta->wl_noisy_level = 1;
-		else
-			coex_sta->wl_noisy_level = 0;
-	}
-
-}
-
-
-void halbtc8821c1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = FALSE;
-	boolean		bt_busy = FALSE;
-
-
-	coex_sta->num_of_profile = 0;
-
-	/* set link exist status */
-	if (!(coex_sta->bt_info & BT_INFO_8821C_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = FALSE;
-		coex_sta->pan_exist = FALSE;
-		coex_sta->a2dp_exist = FALSE;
-		coex_sta->hid_exist = FALSE;
-		coex_sta->sco_exist = FALSE;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = TRUE;
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_FTP) {
-			coex_sta->pan_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->pan_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_A2DP) {
-			coex_sta->a2dp_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->a2dp_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_HID) {
-			coex_sta->hid_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->hid_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_SCO_ESCO) {
-			coex_sta->sco_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->sco_exist = FALSE;
-
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-	bt_link_info->acl_busy = coex_sta->acl_busy;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = TRUE;
-		bt_link_info->bt_link_exist = TRUE;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = TRUE;
-	else
-		bt_link_info->sco_only = FALSE;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = TRUE;
-	else
-		bt_link_info->a2dp_only = FALSE;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = TRUE;
-	else
-		bt_link_info->pan_only = FALSE;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = TRUE;
-	else
-		bt_link_info->hid_only = FALSE;
-
-	if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_INQ_PAGE) {
-		coex_dm->bt_status = BT_8821C_1ANT_BT_STATUS_INQ_PAGE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Inq/page!!!\n");
-	} else if (!(coex_sta->bt_info & BT_INFO_8821C_1ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-	} else if (coex_sta->bt_info == BT_INFO_8821C_1ANT_B_CONNECTION) {
-		/* connection exists but no busy */
-		coex_dm->bt_status = BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-	} else if (((coex_sta->bt_info & BT_INFO_8821C_1ANT_B_SCO_ESCO) ||
-		    (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_SCO_BUSY)) &&
-		   (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_ACL_BUSY)) {
-		coex_dm->bt_status = BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL SCO busy!!!\n");
-	} else if ((coex_sta->bt_info & BT_INFO_8821C_1ANT_B_SCO_ESCO) ||
-		   (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8821C_1ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-	} else if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8821C_1ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-	} else {
-		coex_dm->bt_status = BT_8821C_1ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-	}
-
-	BTC_TRACE(trace_buf);
-
-	if ((BT_8821C_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8821C_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = TRUE;
-	else
-		bt_busy = FALSE;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-}
-
-void halbtc8821c1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0}, i;
-	u32			wifi_bw;
-	u8			wifi_central_chnl = 0;
-	u8			wifi_5g_chnl[19] = {120, 124, 128, 132, 136, 140, 144, 149,
-									153, 157, 118, 126, 134, 142, 151, 159,
-									122, 138, 155};
-	u8			bt_skip_cneter_chanl[19] = {2, 8, 17, 26, 34, 42, 51, 62,
-											71, 77, 2, 12, 29, 46, 66, 76,
-											10, 37, 68};
-	u8			bt_skip_span[19] = {4, 8, 8, 10, 8, 10, 8, 8, 10, 4, 4, 16,
-									16, 16, 16, 4, 20, 34, 20};
-	boolean		wifi_under_5g = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (type == BTC_MEDIA_CONNECT) {
-
-		if (!wifi_under_5g) {
-
-			btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-				&wifi_central_chnl);
-
-			h2c_parameter[0] = 0x1;
-			h2c_parameter[1] = wifi_central_chnl;
-
-			if (wifi_bw == BTC_WIFI_BW_HT40)
-				h2c_parameter[2] = 0x30;
-			else
-				h2c_parameter[2] = 0x20;
-		} else {  /* for 5G  */
-
-			wifi_central_chnl =
-				btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x18, 0xfffff) & 0xff;
-
-			for (i = 0; i <= 18; i++) {
-				if (wifi_central_chnl == wifi_5g_chnl[i])
-					break;
-			}
-
-			if (i <= 18) {
-				h2c_parameter[0] = 0x3;
-				h2c_parameter[1] = bt_skip_cneter_chanl[i];
-				h2c_parameter[2] = bt_skip_span[i];
-			}
-
-		}
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-	coex_sta->wl_center_channel = wifi_central_chnl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], para[0:2] = 0x%x 0x%x 0x%x\n",
-				h2c_parameter[0], h2c_parameter[1], h2c_parameter[2]);
-	BTC_TRACE(trace_buf);
-
-}
-
-u8 halbtc8821c1ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = FALSE;
-	u8				algorithm = BT_8821C_1ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Profile = SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8821C_1ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_1ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_1ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821C_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_1ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821C_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-void halbtc8821c1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8821c1ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8821c1ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-
-void halbtc8821c1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-
-#if 1
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra ==
-		    coex_dm->cur_low_penalty_ra)
-			return;
-	}
-
-	if (low_penalty_ra)
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 15);
-	else
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-
-#endif
-
-}
-
-void halbtc8821c1ant_write_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16				bitpos,
-	IN	boolean		state
-)
-{
-
-	static u16 originalval = 0x8002, preval = 0x0;
-
-	if (state)
-		originalval = originalval | bitpos;
-	else
-		originalval = originalval & (~bitpos);
-
-	coex_sta->score_board_WB = originalval;
-
-	if (originalval != preval) {
-
-		preval = originalval;
-		btcoexist->btc_write_2byte(btcoexist, 0xaa, originalval);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8821c1ant_write_score_board: return for nochange\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-void halbtc8821c1ant_read_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN   u16				*score_board_val
-)
-{
-
-	*score_board_val = (btcoexist->btc_read_2byte(btcoexist,
-			    0xaa)) & 0x7fff;
-}
-
-void halbtc8821c1ant_post_state_to_bt(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16						type,
-	IN  boolean                 state
-)
-{
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8821c1ant_post_state_to_bt: type = %d, state =%d\n",
-		type, state);
-	BTC_TRACE(trace_buf);
-
-	halbtc8821c1ant_write_score_board(btcoexist, (u16) type, state);
-}
-
-boolean halbtc8821c1ant_is_wifibt_status_changed(IN struct btc_coexist
-		*btcoexist)
-{
-	static boolean	pre_wifi_busy = FALSE, pre_under_4way = FALSE,
-			pre_bt_hs_on = FALSE, pre_bt_off = FALSE,
-			pre_bt_slave = FALSE, pre_hid_low_pri_tx_overhead = FALSE,
-			pre_wifi_under_lps = FALSE, pre_bt_setup_link = FALSE,
-			pre_cck_lock = FALSE, pre_cck_lock_warn = FALSE;
-	static u8 pre_hid_busy_num = 0, pre_wl_noisy_level = 0;
-	boolean wifi_busy = FALSE, under_4way = FALSE, bt_hs_on = FALSE;
-	boolean wifi_connected = FALSE;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (coex_sta->bt_disabled != pre_bt_off) {
-		pre_bt_off = coex_sta->bt_disabled;
-
-		if (coex_sta->bt_disabled)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is enabled !!\n");
-
-		BTC_TRACE(trace_buf);
-
-		coex_sta->bt_coex_supported_feature = 0;
-		coex_sta->bt_coex_supported_version = 0;
-		coex_sta->bt_ble_scan_type = 0;
-		coex_sta->bt_ble_scan_para[0] = 0;
-		coex_sta->bt_ble_scan_para[1] = 0;
-		coex_sta->bt_ble_scan_para[2] = 0;
-		coex_sta->bt_reg_vendor_ac = 0xffff;
-		coex_sta->bt_reg_vendor_ae = 0xffff;
-		return TRUE;
-	}
-
-
-	if (wifi_connected) {
-#if 0
-		if ((wifi_busy) &&
-			(coex_dm->bt_status ==  BT_8821C_1ANT_BT_STATUS_ACL_BUSY))
-			halbtc8821c1ant_post_state_to_bt(btcoexist,
-						BT_8821C_1ANT_SCOREBOARD_UNDERTEST, TRUE);
-		else
-			halbtc8821c1ant_post_state_to_bt(btcoexist,
-						BT_8821C_1ANT_SCOREBOARD_UNDERTEST, FALSE);
-#endif
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return TRUE;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return TRUE;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return TRUE;
-		}
-		if (coex_sta->wl_noisy_level != pre_wl_noisy_level) {
-			pre_wl_noisy_level = coex_sta->wl_noisy_level;
-			return TRUE;
-		}
-		if (coex_sta->under_lps != pre_wifi_under_lps) {
-			pre_wifi_under_lps = coex_sta->under_lps;
-			if (coex_sta->under_lps == TRUE)
-				return TRUE;
-		}
-		if (coex_sta->cck_lock != pre_cck_lock) {
-			pre_cck_lock = coex_sta->cck_lock;
-			return TRUE;
-		}
-		if (coex_sta->cck_lock_warn != pre_cck_lock_warn) {
-			pre_cck_lock_warn = coex_sta->cck_lock_warn;
-			return TRUE;
-		}
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->hid_busy_num != pre_hid_busy_num) {
-			pre_hid_busy_num = coex_sta->hid_busy_num;
-			return TRUE;
-		}
-
-		if (bt_link_info->slave_role != pre_bt_slave) {
-			pre_bt_slave = bt_link_info->slave_role;
-			return TRUE;
-		}
-
-		if (pre_hid_low_pri_tx_overhead != coex_sta->is_hid_low_pri_tx_overhead) {
-			pre_hid_low_pri_tx_overhead = coex_sta->is_hid_low_pri_tx_overhead;
-			return TRUE;
-		}
-
-		if (pre_bt_setup_link != coex_sta->is_setupLink) {
-			pre_bt_setup_link = coex_sta->is_setupLink;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-
-void halbtc8821c1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean		bt_active = TRUE, bt_disabled = FALSE, wifi_under_5g = FALSE;
-	u16			u16tmp;
-
-	/* This function check if bt is disabled */
-#if 0
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = FALSE;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = FALSE;
-
-
-#else
-
-	/* Read BT on/off status from scoreboard[1], enable this only if BT patch support this feature */
-	halbtc8821c1ant_read_score_board(btcoexist,	&u16tmp);
-
-	bt_active = u16tmp & BIT(1);
-
-
-#endif
-
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = FALSE;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	} else {
-
-		bt_disable_cnt++;
-		if (bt_disable_cnt >= 2) {
-			bt_disabled = TRUE;
-			bt_disable_cnt = 2;
-		}
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((wifi_under_5g) || (bt_disabled))
-		halbtc8821c1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-	else
-		halbtc8821c1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
-
-
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-	}
-
-}
-
-void halbtc8821c1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
-					boolean isenable)
-{
-#if BT_8821C_1ANT_COEX_DBG
-	static u8			bitVal[5] = {0, 0, 0, 0, 0};
-	static boolean		state = FALSE;
-	/*
-		if (state ==isenable)
-			return;
-		else
-			state = isenable;
-	*/
-	if (isenable) {
-
-		/* enable GNT_WL, GNT_BT to GPIO for debug */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x1);
-
-		/* store original value */
-		bitVal[0] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x66) & BIT(4)) >> 4;	/*0x66[4] */
-		bitVal[1] = (btcoexist->btc_read_1byte(btcoexist,
-					       0x67) & BIT(0));		/*0x66[8] */
-		bitVal[2] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x42) & BIT(3)) >> 3;  /*0x40[19] */
-		bitVal[3] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x65) & BIT(7)) >> 7;  /*0x64[15] */
-		bitVal[4] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x72) & BIT(2)) >> 2;  /*0x70[18] */
-
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   0x0);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   0x0);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-						   0x0);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-						   0x0);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-						   0x0);  /*0x70[18] = 0 */
-
-
-	} else {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x0);
-
-		/*  Restore original value */
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   bitVal[0]);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   bitVal[1]);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-					   bitVal[2]);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-					   bitVal[3]);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-					   bitVal[4]);  /*0x70[18] = 0 */
-	}
-
-#endif
-}
-
-u32 halbtc8821c1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
-		IN u16 reg_addr)
-{
-	u32 j = 0, delay_count = 0;
-
-	/* wait for ready bit before access 0x1700 */
-	while (1) {
-		if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-			delay_ms(50);
-			delay_count++;
-			if (delay_count >= 10) {
-				delay_count = 0;
-				break;
-			}
-		} else
-			break;
-	}
-
-	btcoexist->btc_write_4byte(btcoexist, 0x1700, 0x800F0000 | reg_addr);
-
-	return btcoexist->btc_read_4byte(btcoexist,
-					 0x1708);  /* get read data */
-}
-
-void halbtc8821c1ant_ltecoex_indirect_write_reg(IN struct btc_coexist
-		*btcoexist,
-		IN u16 reg_addr, IN u32 bit_mask, IN u32 reg_value)
-{
-	u32 val, i = 0, j = 0, bitpos = 0, delay_count = 0;
-
-	if (bit_mask == 0x0)
-		return;
-
-	if (bit_mask == 0xffffffff) {
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else
-				break;
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   reg_value); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-	} else {
-		for (i = 0; i <= 31; i++) {
-			if (((bit_mask >> i) & 0x1) == 0x1) {
-				bitpos = i;
-				break;
-			}
-		}
-
-		/* read back register value before write */
-		val = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-				reg_addr);
-		val = (val & (~bit_mask)) | (reg_value << bitpos);
-
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else
-				break;
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   val); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-
-	}
-
-}
-
-void halbtc8821c1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
-				    IN boolean enable)
-{
-	u8 val;
-
-	val = (enable) ? 1 : 0;
-	halbtc8821c1ant_ltecoex_indirect_write_reg(btcoexist, 0x38, 0x80,
-			val);  /* 0x38[7] */
-
-}
-
-void halbtc8821c1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_control)
-{
-	u8 val;
-
-	val = (wifi_control) ? 1 : 0;
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x4,
-					   val); /* 0x70[26] */
-
-}
-
-void halbtc8821c1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, val_orig = 0;
-
-	if (!sw_control)
-		val = 0x0;
-	else if (state & 0x1)
-		val = 0x3;
-	else
-		val = 0x1;
-
-	val_orig = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-
-	switch (control_block) {
-	case BT_8821C_1ANT_GNT_BLOCK_RFC_BB:
-	default:
-		val = ((val << 14) | (val << 10)) | (val_orig & 0xffff33ff);
-		break;
-	case BT_8821C_1ANT_GNT_BLOCK_RFC:
-		val = (val << 14) | (val_orig & 0xffff3fff);
-		break;
-	case BT_8821C_1ANT_GNT_BLOCK_BB:
-		val = (val << 10) | (val_orig & 0xfffff3ff);
-		break;
-	}
-
-	halbtc8821c1ant_ltecoex_indirect_write_reg(btcoexist,
-			0x38, 0xffffffff, val);
-}
-
-void halbtc8821c1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, val_orig = 0;
-
-	if (!sw_control)
-		val = 0x0;
-	else if (state & 0x1)
-		val = 0x3;
-	else
-		val = 0x1;
-
-	val_orig = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-
-	switch (control_block) {
-	case BT_8821C_1ANT_GNT_BLOCK_RFC_BB:
-	default:
-		val = ((val << 12) | (val << 8)) | (val_orig & 0xffffccff);
-		break;
-	case BT_8821C_1ANT_GNT_BLOCK_RFC:
-		val = (val << 12) | (val_orig & 0xffffcfff);
-		break;
-	case BT_8821C_1ANT_GNT_BLOCK_BB:
-		val = (val << 8) | (val_orig & 0xfffffcff);
-		break;
-	}
-
-	halbtc8821c1ant_ltecoex_indirect_write_reg(btcoexist,
-			0x38, 0xffffffff, val);
-}
-
-void halbtc8821c1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u16 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8821C_1ANT_CTT_WL_VS_LTE:
-		reg_addr = 0xa0;
-		break;
-	case BT_8821C_1ANT_CTT_BT_VS_LTE:
-		reg_addr = 0xa4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8821c1ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xffff, table_content); /* 0xa0[15:0] or 0xa4[15:0] */
-
-
-}
-
-
-void halbtc8821c1ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u8 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8821C_1ANT_LBTT_WL_BREAK_LTE:
-		reg_addr = 0xa8;
-		break;
-	case BT_8821C_1ANT_LBTT_BT_BREAK_LTE:
-		reg_addr = 0xac;
-		break;
-	case BT_8821C_1ANT_LBTT_LTE_BREAK_WL:
-		reg_addr = 0xb0;
-		break;
-	case BT_8821C_1ANT_LBTT_LTE_BREAK_BT:
-		reg_addr = 0xb4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8821c1ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xff, table_content); /* 0xa8[15:0] or 0xb4[15:0] */
-
-
-}
-
-void halbtc8821c1ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
-{
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
-
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
-	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
-			return;
-	}
-
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-
-void halbtc8821c1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8821c1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-
-	halbtc8821c1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8821c1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	u32	break_table;
-	u8	select_table;
-
-	coex_sta->coex_table_type = type;
-
-	if (coex_sta->concurrent_rx_mode_on == TRUE) {
-		 /* set WL hi-pri can break BT */
-		break_table = 0xf0ffffff;
-		 /* set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS) */
-		select_table = 0xb;
-	} else {
-		break_table = 0xffffff;
-		select_table = 0x3;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** Table-%d **********\n",
-		    coex_sta->coex_table_type);
-	BTC_TRACE(trace_buf);
-
-	switch (type) {
-	case 0:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x55555555, break_table,
-					   select_table);
-		break;
-	case 1:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 2:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xaa5a5a5a, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 3:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0x5a5a5a5a, break_table,
-					   select_table);
-		break;
-	case 4:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 5:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0x5a5a5a5a, 0x5a5a5a5a, break_table,
-					   select_table);
-		break;
-	case 6:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 7:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xaa555555, 0xaa555555, break_table,
-					   select_table);
-		break;
-	case 8:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaaaa5aaa, break_table,
-					   select_table);
-		break;
-	case 9:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0x5a5a5a5a, 0xaaaa5aaa, break_table,
-					   select_table);
-		break;
-	case 10:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xaaaaaaaa, 0xaaaaaaaa, break_table,
-					   select_table);
-		break;
-	case 11:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xa5a55555, 0xaaaa5a5a, break_table,
-					   select_table);
-		break;
-	case 12:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaaaa5a5a, break_table,
-					   select_table);
-		break;
-	case 13:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xaa5555aa, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 14:
-		halbtc8821c1ant_coex_table(btcoexist, force_exec,
-					   0xaa5555aa, 0x5a5a5a5a, break_table,
-					   select_table);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8821c1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8821c1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8821c1ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8821c1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8821c1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8821c1ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8821c1ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x8, 0, 0, 0, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-boolean halbtc8821c1ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = FALSE, result = TRUE;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		coex_sta->force_lps_ctrl = FALSE;
-		low_pwr_disable = FALSE;
-		/* btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable); */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_PRE_NORMAL_LPS,
-				   NULL);
-
-		break;
-	case BTC_PS_LPS_ON:
-		coex_sta->force_lps_ctrl = TRUE;
-		halbtc8821c1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, TRUE);
-		halbtc8821c1ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = TRUE;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-
-		break;
-	case BTC_PS_LPS_OFF:
-		coex_sta->force_lps_ctrl = TRUE;
-		halbtc8821c1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, FALSE);
-		result = btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-
-		break;
-	default:
-		break;
-	}
-
-	return result;
-}
-
-
-void halbtc8821c1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = FALSE, result = FALSE;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	u8		ps_type = BTC_PS_WIFI_NATIVE;
-
-	if (byte5 & BIT(2))
-		coex_sta->is_tdma_btautoslot = TRUE;
-	else
-		coex_sta->is_tdma_btautoslot = FALSE;
-
-	/* release bt-auto slot for auto-slot hang is detected!! */
-	if (coex_sta->is_tdma_btautoslot)
-		if ((coex_sta->is_tdma_btautoslot_hang) ||
-			(bt_link_info->slave_role))
-			byte5 = byte5 & 0xfb;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if ((ap_enable) && (byte1 & BIT(4) && !(byte1 & BIT(5)))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c1ant_set_fw_pstdma == FW for 1Ant AP mode\n");
-		BTC_TRACE(trace_buf);
-		real_byte1 &= ~BIT(4);
-		real_byte1 |= BIT(5);
-
-		real_byte5 |= BIT(5);
-		real_byte5 &= ~BIT(6);
-
-		ps_type = BTC_PS_WIFI_NATIVE;
-		halbtc8821c1ant_power_save_state(btcoexist,
-					 ps_type, 0x0,
-						 0x0);
-	} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c1ant_set_fw_pstdma == Force LPS Leave (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-
-		ps_type = BTC_PS_LPS_OFF;
-		if (!halbtc8821c1ant_power_save_state(btcoexist, ps_type, 0x50, 0x4))
-			result = TRUE;
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c1ant_set_fw_pstdma == native power save (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-
-		ps_type = BTC_PS_WIFI_NATIVE;
-		halbtc8821c1ant_power_save_state(btcoexist, ps_type,
-						 0x0,
-						 0x0);
-	}
-
-	coex_sta->is_set_ps_state_fail = result;
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		h2c_parameter[0] = real_byte1;
-		h2c_parameter[1] = byte2;
-		h2c_parameter[2] = byte3;
-		h2c_parameter[3] = byte4;
-		h2c_parameter[4] = real_byte5;
-
-		coex_dm->ps_tdma_para[0] = real_byte1;
-		coex_dm->ps_tdma_para[1] = byte2;
-		coex_dm->ps_tdma_para[2] = byte3;
-		coex_dm->ps_tdma_para[3] = byte4;
-		coex_dm->ps_tdma_para[4] = real_byte5;
-
-		btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-
-	} else {
-		coex_sta->cnt_set_ps_state_fail++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c1ant_set_fw_pstdma == Force Leave LPS Fail (cnt = %d)\n",
-			    coex_sta->cnt_set_ps_state_fail);
-		BTC_TRACE(trace_buf);
-	}
-
-	if (ps_type == BTC_PS_WIFI_NATIVE)
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_POST_NORMAL_LPS, NULL);
-}
-
-
-void halbtc8821c1ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	boolean			wifi_busy = FALSE;
-	static u8			psTdmaByte4Modify = 0x0, pre_psTdmaByte4Modify = 0x0;
-	static boolean	 pre_wifi_busy = FALSE;
-
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (wifi_busy != pre_wifi_busy) {
-		force_exec = TRUE;
-		pre_wifi_busy = wifi_busy;
-	}
-
-	/* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-	if ((bt_link_info->slave_role) && (bt_link_info->a2dp_exist))
-		psTdmaByte4Modify = 0x1;
-	else
-		psTdmaByte4Modify = 0x0;
-
-	if (pre_psTdmaByte4Modify != psTdmaByte4Modify) {
-		force_exec = TRUE;
-		pre_psTdmaByte4Modify = psTdmaByte4Modify;
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Skip TDMA because no change TDMA(%s, %d)\n",
-				    (coex_dm->cur_ps_tdma_on ? "on" : "off"),
-				    coex_dm->cur_ps_tdma);
-			BTC_TRACE(trace_buf);
-			return;
-		}
-	}
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-
-	if (turn_on) {
-		switch (type) {
-		default:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x35, 0x03, 0x11, 0x11);
-			break;
-		case 3:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x30, 0x03, 0x10, 0x50);
-			break;
-		case 4:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x21, 0x03, 0x10, 0x50);
-			break;
-		case 5:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x3a, 0x03, 0x11, 0x11);
-			break;
-		case 6:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x20, 0x03, 0x11, 0x10);
-			break;
-		case 7:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x54 |
-						      psTdmaByte4Modify);
-			break;
-		case 8:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x54 |
-						      psTdmaByte4Modify);
-			break;
-		case 9:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x54 |
-						      psTdmaByte4Modify);
-			break;
-		case 10:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x30, 0x03, 0x11, 0x10);
-			break;
-		case 11:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x25, 0x03, 0x11, 0x11);
-			break;
-		case 12:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x35, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 13:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x07, 0x10,  0x54 |
-						      psTdmaByte4Modify);
-			break;
-		case 14:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x15, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 15:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x20, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 16:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x10, 0x03, 0x11,  0x15 |
-						      psTdmaByte4Modify);
-			break;
-		case 17:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x10, 0x03, 0x11, 0x14 |
-							psTdmaByte4Modify);
-			break;
-		case 18:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x30, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 19:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x15, 0x03, 0x11, 0x10);
-			break;
-		case 20:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x30, 0x03, 0x11, 0x10);
-			break;
-		case 21:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x30, 0x03, 0x11, 0x10);
-			break;
-		case 22:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x25, 0x03, 0x11, 0x10);
-			break;
-		case 23:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x10, 0x03, 0x11, 0x10);
-			break;
-		case 24:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x08, 0x03, 0x10,  0x54 |
-						      psTdmaByte4Modify);
-			break;
-		case 27:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x10, 0x03, 0x11, 0x15);
-			break;
-		case 28:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x0b, 0x10,  0x54);
-			break;
-		case 32:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x35, 0x03, 0x11, 0x11);
-			break;
-		case 33:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x35, 0x03, 0x11, 0x10);
-			break;
-		case 57:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 58:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 67:
-			halbtc8821c1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x10, 0x03, 0x11,  0x10 |
-						      psTdmaByte4Modify);
-			break;
-		}
-	} else {
-
-		/* disable PS tdma */
-		switch (type) {
-		case 8: /* PTA Control */
-			halbtc8821c1ant_set_fw_pstdma(btcoexist, 0x8,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		case 0:
-		default:  /* Software control, Antenna at BT side */
-			halbtc8821c1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x0, 0x0);
-			break;
-		case 1: /* 2-Ant, 0x778=3, antenna control by antenna diversity */
-			halbtc8821c1ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x48, 0x0);
-			break;
-		}
-	}
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		/* update pre state */
-		coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-		coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-	}
-}
-
-void halbtc8821c1ant_set_int_block(IN struct btc_coexist *btcoexist,
-				   IN boolean force_exec,  IN u8 pos_type)
-{
-#if 0
-	u8		regval_0xcba;
-	u32		u32tmp1 = 0;
-
-	coex_dm->cur_int_block_status = pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_int_block_status ==
-		    coex_dm->cur_int_block_status)
-			return;
-	}
-
-	coex_dm->pre_int_block_status = coex_dm->cur_int_block_status;
-
-	regval_0xcba =  btcoexist->btc_read_1byte(btcoexist, 0xcba);
-
-	switch (pos_type) {
-
-	case BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG:
-		regval_0xcba = (regval_0xcba | BIT(0)) & (~(BIT(
-			2)));				/* 0xcb8[16] = 1, 0xcb8[18] = 0, WL_G select BTG */
-		regval_0xcba =   regval_0xcba & 0x0f;
-
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc1d, 0x0f, 0x5); */ /* Gain Table */
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xa9e, 0x0f, 0x2); */ /* CCK Gain Table */
-
-		break;
-	case BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG:
-		regval_0xcba =   regval_0xcba & (~(BIT(2) | BIT(
-			0)));			/* 0xcb8[16] = 0, 0xcb8[18] = 0, WL_G select WLAG */
-
-		/* regval_0xcba =   regval_0xcba | BIT(4) | BIT(5) ; */			/* 0xcb8[21:20] = 2b'11, WL_G @ WLAG on */
-		/* regval_0xcba =    (regval_0xcba | BIT(6)) & (~(BIT(7)) ) ; */		/* 0xcb8[23:22] = 2b'01, WL_A @ WLAG off */
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc1d, 0x0f, 0x0); */ /* Gain Table */
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xa9e, 0x0f, 0x6); */ /* CCK Gain Table */
-
-		break;
-	case BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG:
-		regval_0xcba =   regval_0xcba & (~(BIT(2) | BIT(
-			0)));			/* 0xcb8[16] = 0, 0xcb8[18] = 0, WL_G select WLAG */
-		/*regval_0xcba = (regval_0xcba | BIT(4)) & (~(BIT(5))); */			/* 0xcb8[21:20] = 2b'01, WL_G @ WLAG off */
-		/*regval_0xcba = regval_0xcba | BIT(6) | BIT(7); */				/* 0xcb8[23:22] = 2b'11, WL_A @ WLAG on */
-
-		break;
-	}
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcba, 0xff,
-					   regval_0xcba);
-
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcb8);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (After Int Block setup) 0xcb8 = 0x%08x **********\n",
-		    u32tmp1);
-	BTC_TRACE(trace_buf);
-
-#endif
-}
-
-void halbtc8821c1ant_set_ext_band_switch(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 pos_type)
-{
-
-#if 0
-	boolean	switch_polatiry_inverse = FALSE;
-	u8		regval_0xcb6;
-	u32		u32tmp1 = 0, u32tmp2 = 0;
-
-	if (!rfe_type->ext_band_switch_exist)
-		return;
-
-	coex_dm->cur_ext_band_switch_status = pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ext_band_switch_status ==
-		    coex_dm->cur_ext_band_switch_status)
-			return;
-	}
-
-	coex_dm->pre_ext_band_switch_status =
-		coex_dm->cur_ext_band_switch_status;
-
-	/* swap control polarity if use different switch control polarity*/
-	switch_polatiry_inverse = (rfe_type->ext_band_switch_ctrl_polarity == 1
-		   ? ~switch_polatiry_inverse : switch_polatiry_inverse);
-
-	/*swap control polarity for WL_A, default polarity 0xcb4[21] = 0 && 0xcb4[23] = 1 is for WL_G */
-	switch_polatiry_inverse = (pos_type ==
-		BT_8821C_1ANT_EXT_BAND_SWITCH_TO_WLA ? ~switch_polatiry_inverse
-				   : switch_polatiry_inverse);
-
-	regval_0xcb6 =  btcoexist->btc_read_1byte(btcoexist, 0xcb6);
-
-	/* for normal switch polrity, 0xcb4[21] =1 && 0xcb4[23] = 0 for WL_A, vice versa */
-	regval_0xcb6 = (switch_polatiry_inverse == 1 ? ((regval_0xcb6 & (~(BIT(
-		7)))) | BIT(5)) : ((regval_0xcb6 & (~(BIT(5)))) | BIT(7)));
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb6, 0xff,
-					   regval_0xcb6);
-
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcb0);
-	u32tmp2 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (After Ext Band switch setup) 0xcb0 = 0x%08x, 0xcb4 = 0x%08x**********\n",
-		    u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-}
-
-void halbtc8821c1ant_set_ext_ant_switch(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u8 ctrl_type, IN u8 pos_type)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	boolean	switch_polatiry_inverse = FALSE;
-	u8		regval_0xcb7 = 0, regval_0x64;
-	u32		u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-
-	if (!rfe_type->ext_ant_switch_exist)
-		return;
-
-	coex_dm->cur_ext_ant_switch_status = (ctrl_type << 8)  + pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ext_ant_switch_status ==
-		    coex_dm->cur_ext_ant_switch_status)
-			return;
-	}
-
-	coex_dm->pre_ext_ant_switch_status = coex_dm->cur_ext_ant_switch_status;
-
-	/* swap control polarity if use different switch control polarity*/
-	/*  Normal switch polarity for DPDT, 0xcb4[29:28] = 2b'01 => BTG to Main, WLG to Aux,  0xcb4[29:28] = 2b'10 => BTG to Aux, WLG to Main */
-	/*  Normal switch polarity for SPDT, 0xcb4[29:28] = 2b'01 => Ant to BTG,  0xcb4[29:28] = 2b'10 => Ant to WLG */
-	if (rfe_type->ext_ant_switch_ctrl_polarity)
-		switch_polatiry_inverse =  ~switch_polatiry_inverse;
-
-	/* swap control polarity if 1-Ant at Aux */
-	if (rfe_type->ant_at_main_port == FALSE)
-		switch_polatiry_inverse =  ~switch_polatiry_inverse;
-
-	switch (pos_type) {
-	default:
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_TO_BT:
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_TO_NOCARE:
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLA:
-
-		break;
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLG:
-		if (!rfe_type->wlg_Locate_at_btg)
-			switch_polatiry_inverse =  ~switch_polatiry_inverse;
-		break;
-	}
-
-	if (board_info->ant_div_cfg)
-		ctrl_type = BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV;
-
-
-	switch (ctrl_type) {
-	default:
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /*  0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-			0xff, 0x77);	/* BB SW, DPDT use RFE_ctrl8 and RFE_ctrl9 as control pin */
-
-		regval_0xcb7 = (switch_polatiry_inverse == FALSE ?
-			0x1 : 0x2);     /* 0xcb4[29:28] = 2b'01 for no switch_polatiry_inverse, DPDT_SEL_N =1, DPDT_SEL_P =0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb7,
-						   0x30, regval_0xcb7);
-
-		break;
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-			0xff, 0x66);	/* PTA,  DPDT use RFE_ctrl8 and RFE_ctrl9 as control pin */
-
-		regval_0xcb7 = (switch_polatiry_inverse == FALSE ?
-			0x2 : 0x1);     /* 0xcb4[29:28] = 2b'10 for no switch_polatiry_inverse, DPDT_SEL_N =1, DPDT_SEL_P =0  @ GNT_BT=1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb7,
-						   0x30, regval_0xcb7);
-
-		break;
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-						   0xff, 0x88);  /* */
-
-		/* no regval_0xcb7 setup required, because  antenna switch control value by antenna diversity */
-
-		break;
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x1);  /*  0x4c[23] = 1 */
-
-		regval_0x64 = (switch_polatiry_inverse == FALSE ?  0x0 :
-			0x1);     /* 0x64[0] = 1b'0 for no switch_polatiry_inverse, DPDT_SEL_N =1, DPDT_SEL_P =0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1,
-						   regval_0x64);
-		break;
-	case BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x0);  /* 0x4c[24] = 0 */
-
-		/* no  setup required, because  antenna switch control value by BT vendor 0xac[1:0] */
-		break;
-	}
-
-	/* PAPE, LNA_ON control by BT  while WLAN off for current leakage issue */
-	if (ctrl_type == BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT) {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-					   0x0);  /* PAPE   0x64[29] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x10,
-					   0x0);  /* LNA_ON 0x64[28] = 0 */
-	} else {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-					   0x1);  /* PAPE   0x64[29] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x10,
-					   0x1);  /* LNA_ON 0x64[28] = 1 */
-	}
-
-#if BT_8821C_1ANT_COEX_DBG
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp2 = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0x64) & 0xff;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (After Ext Ant switch setup) 0xcb4 = 0x%08x, 0x4c = 0x%08x, 0x64= 0x%02x\n",
-		    u32tmp1, u32tmp2, u32tmp3);
-	BTC_TRACE(trace_buf);
-#endif
-
-}
-
-void halbtc8821c1ant_set_rfe_type(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-
-
-	/* the following setup should be got from Efuse in the future */
-	rfe_type->rfe_module_type = board_info->rfe_type & 0x1f;
-
-	rfe_type->ext_ant_switch_ctrl_polarity = 0;
-
-	switch (rfe_type->rfe_module_type) {
-	case 0:
-	case 8:
-	default:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_USE_DPDT;    /*2-Ant, DPDT, WLG*/
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 1:
-	case 9:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_USE_SPDT;     /*1-Ant, Main, WLG */
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 2:
-	case 10:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_USE_SPDT;     /*1-Ant, Main, BTG */
-		rfe_type->wlg_Locate_at_btg = TRUE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 3:
-	case 11:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_USE_DPDT;    /*1-Ant, Aux, WLG */
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = FALSE;
-		break;
-	case 4:
-	case 12:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_USE_DPDT;    /*1-Ant, Aux, BTG */
-		rfe_type->wlg_Locate_at_btg = TRUE;
-		rfe_type->ant_at_main_port = FALSE;
-		break;
-	case 5:
-	case 13:
-		rfe_type->ext_ant_switch_exist = FALSE;		/*2-Ant, no switch, WLG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_NONE;
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 6:
-	case 14:
-		rfe_type->ext_ant_switch_exist = FALSE;		/*2-Ant, no antenna switch, WLG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_NONE;
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 7:
-	case 15:
-		rfe_type->ext_ant_switch_exist = TRUE;	/*2-Ant, DPDT, BTG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_1ANT_EXT_ANT_SWITCH_USE_DPDT;
-		rfe_type->wlg_Locate_at_btg = TRUE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	}
-
-#if 0
-	if (rfe_type->wlg_Locate_at_btg)
-		halbtc8821c1ant_set_int_block(btcoexist, FORCE_EXEC,
-			      BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG);
-	else
-		halbtc8821c1ant_set_int_block(btcoexist, FORCE_EXEC,
-			      BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG);
-#endif
-
-}
-
-
-void halbtc8821c1ant_set_ant_path(IN struct btc_coexist *btcoexist,
-				  IN u8 ant_pos_type, IN boolean force_exec,
-				  IN u8 phase)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-	u32			cnt_bt_cal_chk = 0;
-	boolean			is_in_mp_mode = FALSE;
-	u8			u8tmp = 0;
-	u32			u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-	u16			u16tmp1 = 0;
-
-
-	u32tmp1 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-
-	/* To avoid indirect access fail  */
-	if (((u32tmp1 & 0xf000) >> 12) != ((u32tmp1 & 0x0f00) >> 8)) {
-		force_exec = TRUE;
-		coex_sta->gnt_error_cnt++;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex],(Before Ant Setup) 0x38= 0x%x\n",
-		    u32tmp1);
-		BTC_TRACE(trace_buf);
-	}
-
-
-#if BT_8821C_1ANT_COEX_DBG
-
-	u32tmp2 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x54);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex],(Before Ant Setup) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    u32tmp3, u8tmp, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-	coex_dm->cur_ant_pos_type = (ant_pos_type << 8)  + phase;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex],(Before Ant Setup) pre_ant_pos_type = 0x%x, cur_ant_pos_type = 0x%x\n",
-		    coex_dm->pre_ant_pos_type,
-		    coex_dm->cur_ant_pos_type);
-	BTC_TRACE(trace_buf);
-
-
-	if (!force_exec) {
-		if (coex_dm->cur_ant_pos_type == coex_dm->pre_ant_pos_type)
-			return;
-	}
-
-	coex_dm->pre_ant_pos_type = coex_dm->cur_ant_pos_type;
-
-
-	switch (phase) {
-	case BT_8821C_1ANT_PHASE_COEX_POWERON:
-
-		/* set Path control owner to BT at power-on step */
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8821C_1ANT_PCO_BTSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8821c1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW high */
-		halbtc8821c1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		coex_sta->run_time_state = FALSE;
-
-		break;
-	case BT_8821C_1ANT_PHASE_COEX_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
-		halbtc8821c1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_1ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_1ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-		/* Wait If BT IQK running, because Path control owner is at BT during BT IQK (setup by WiFi firmware) */
-		while (cnt_bt_cal_chk <= 20) {
-			u8tmp = btcoexist->btc_read_1byte(
-					btcoexist,
-					0x49c);
-			cnt_bt_cal_chk++;
-			if (u8tmp & BIT(1)) {
-				BTC_SPRINTF(
-					trace_buf,
-					BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n",
-					cnt_bt_cal_chk);
-				BTC_TRACE(
-					trace_buf);
-				delay_ms(50);
-			} else {
-				BTC_SPRINTF(
-					trace_buf,
-					BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** BT is NOT calibrating (wait cnt=%d)**********\n",
-					cnt_bt_cal_chk);
-				BTC_TRACE(
-					trace_buf);
-				break;
-			}
-		}
-
-		/* set Path control owner to WL at initial step */
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8821c1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW low */
-		halbtc8821c1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_LOW);
-
-		coex_sta->run_time_state = FALSE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		break;
-	case BT_8821C_1ANT_PHASE_WLANONLY_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
-		halbtc8821c1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_1ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c1ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_1ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-		/* set Path control owner to WL at initial step */
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Low */
-		halbtc8821c1ant_ltecoex_set_gnt_bt(btcoexist,
-						BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-						BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-						BT_8821C_1ANT_SIG_STA_SET_TO_LOW);
-		/* Set GNT_WL to SW high */
-		halbtc8821c1ant_ltecoex_set_gnt_wl(btcoexist,
-						BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-						BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-						BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = FALSE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_WIFI;
-
-		break;
-	case BT_8821C_1ANT_PHASE_WLAN_OFF:
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8821c1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to BT */
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_1ANT_PCO_BTSIDE);
-
-		/* Set Ext Ant Switch to BT control at wifi off step */
-		halbtc8821c1ant_set_ext_ant_switch(btcoexist,
-						FORCE_EXEC,
-						BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT,
-						BT_8821C_1ANT_EXT_ANT_SWITCH_TO_NOCARE);
-
-		halbtc8821c1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, TRUE);
-
-		coex_sta->run_time_state = FALSE;
-		break;
-	case BT_8821C_1ANT_PHASE_2G_RUNTIME:
-
-		while (cnt_bt_cal_chk <= 20) {
-			/* 0x49c[0]=1 WL IQK, 0x49c[1]=1 BT IQK*/
-			u8tmp = btcoexist->btc_read_1byte(
-					btcoexist,
-					0x49c);
-
-			cnt_bt_cal_chk++;
-			if (u8tmp & BIT(0)) {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### WL is IQK (wait cnt=%d)\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				delay_ms(50);
-			} else if (u8tmp & BIT(1)) {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### BT is IQK (wait cnt=%d)\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				delay_ms(50);
-			} else {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** WL and BT is NOT IQK (wait cnt=%d)\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				break;
-			}
-		}
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to PTA */
-		halbtc8821c1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_PTA,
-					   BT_8821C_1ANT_SIG_STA_SET_BY_HW);
-
-		halbtc8821c1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_PTA,
-					   BT_8821C_1ANT_SIG_STA_SET_BY_HW);
-
-		coex_sta->run_time_state = TRUE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (rfe_type->wlg_Locate_at_btg)
-				ant_pos_type =
-					BTC_ANT_PATH_WIFI;
-			else
-				ant_pos_type = BTC_ANT_PATH_PTA;
-		}
-
-		if (rfe_type->wlg_Locate_at_btg)
-			halbtc8821c1ant_set_int_block(btcoexist,
-						      NORMAL_EXEC,
-				BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG);
-		else
-			halbtc8821c1ant_set_int_block(btcoexist,
-						      NORMAL_EXEC,
-				BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG);
-
-		break;
-	case BT_8821C_1ANT_PHASE_5G_RUNTIME:
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8821c1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_PTA,
-					   BT_8821C_1ANT_SIG_STA_SET_BY_HW);
-
-		/* Set GNT_WL to SW Hi */
-		halbtc8821c1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = TRUE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			/*	if (rfe_type->ext_band_switch_exist)
-					ant_pos_type =   BTC_ANT_PATH_PTA;
-				else */
-			ant_pos_type =
-				BTC_ANT_PATH_WIFI5G;
-		}
-
-		halbtc8821c1ant_set_int_block(btcoexist,
-					      NORMAL_EXEC,
-			      BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG);
-
-		break;
-	case BT_8821C_1ANT_PHASE_BTMPMODE:
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8821c1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to WL */
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8821c1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-
-		/* Set GNT_WL to SW Lo */
-		halbtc8821c1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_LOW);
-
-		coex_sta->run_time_state = FALSE;
-
-		/* Set Ext Ant Switch to BT side at BT MP mode */
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		break;
-	case BT_8821C_1ANT_PHASE_ANTENNA_DET:
-		halbtc8821c1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8821C_1ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to high */
-		halbtc8821c1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to high */
-		halbtc8821c1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_1ANT_SIG_STA_SET_TO_HIGH);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		coex_sta->run_time_state = FALSE;
-
-		break;
-	}
-
-	if (phase != BT_8821C_1ANT_PHASE_WLAN_OFF) {
-		switch (ant_pos_type) {
-		case BTC_ANT_PATH_WIFI:
-			halbtc8821c1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLG);
-			break;
-		case BTC_ANT_PATH_WIFI5G
-				:
-			halbtc8821c1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLA);
-			break;
-		case BTC_ANT_PATH_BT:
-			halbtc8821c1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_TO_BT);
-			break;
-		default:
-		case BTC_ANT_PATH_PTA:
-			halbtc8821c1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA,
-				BT_8821C_1ANT_EXT_ANT_SWITCH_TO_NOCARE);
-			break;
-		}
-
-	}
-
-#if BT_8821C_1ANT_COEX_DBG
-	u32tmp1 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex],(After Ant-Setup phase---%d) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    phase, u32tmp3, u8tmp, u32tmp1, u32tmp2);
-
-	BTC_TRACE(trace_buf);
-#endif
-}
-
-
-boolean halbtc8821c1ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = FALSE, wifi_connected = FALSE, wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected &&
-	    BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	    coex_dm->bt_status) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		common = TRUE;
-	} else if (wifi_connected &&
-		   (BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		common = TRUE;
-	} else if (!wifi_connected &&
-		   (BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		common = TRUE;
-	} else if (wifi_connected &&
-		   (BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		common = TRUE;
-	} else if (!wifi_connected &&
-		   (BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE !=
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non connected-idle + BT Busy!!\n");
-		BTC_TRACE(trace_buf);
-
-		common = TRUE;
-	} else {
-		if (wifi_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		common = FALSE;
-	}
-
-	return common;
-}
-
-
-/* *********************************************
- *
- *	Software Coex Mechanism start
- *
- * ********************************************* */
-
-
-
-/* *********************************************
- *
- *	Non-Software Coex Mechanism start
- *
- * ********************************************* */
-void halbtc8821c1ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-	halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-void halbtc8821c1ant_action_bt_hs(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-	halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-}
-
-void halbtc8821c1ant_action_bt_relink(IN struct btc_coexist *btcoexist)
-{
-	if (coex_sta->is_bt_multi_link == TRUE)
-		return;
-
-	halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-void halbtc8821c1ant_action_bt_idle(IN struct btc_coexist *btcoexist)
-{
-	boolean wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_busy) {
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
-	} else {  /* if wl busy */
-
-		if (BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-		} else {
-
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-		}
-	}
-
-}
-
-void halbtc8821c1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_connected = FALSE, wifi_busy = FALSE,
-				bt_busy = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-
-	if ((coex_sta->bt_create_connection) && ((wifi_link) || (wifi_roam)
-		|| (wifi_scan) || (wifi_busy) || (coex_sta->wifi_is_high_pri_task))) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi link/roam/Scan/busy/hi-pri-task + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-
-		if ((bt_link_info->a2dp_exist) && (!bt_link_info->pan_exist))
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 17);
-		else
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-	} else if ((!wifi_connected) && (!wifi_scan)) {
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-	} else if (bt_link_info->pan_exist) {
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-	} else if (bt_link_info->a2dp_exist) {
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-	} else {
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if ((wifi_link) || (wifi_roam) || (wifi_scan) || (wifi_busy)
-			|| (coex_sta->wifi_is_high_pri_task))
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-		else
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 23);
-	}
-}
-
-void halbtc8821c1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = FALSE, wifi_busy = FALSE, wifi_cckdeadlock_ap = FALSE;
-	u32  wifi_bw = 1;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	if ((iot_peer == BTC_IOT_PEER_ATHEROS) && (coex_sta->cck_lock_ever))
-		wifi_cckdeadlock_ap = TRUE;
-
-	if (bt_link_info->sco_exist) {
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-	} else {
-		/* for HID exist */
-		if ((wifi_cckdeadlock_ap) && (coex_sta->is_bt_multi_link)) {
-
-			if (coex_sta->hid_busy_num < 2)
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 18);
-		} else if (coex_sta->is_hid_low_pri_tx_overhead) {
-			if (coex_sta->hid_busy_num < 2)
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 18);
-		} else if (coex_sta->hid_busy_num < 2) {
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
-		} else if (wifi_bw == 0) { /* if 11bg mode */
-
-			if (coex_sta->is_bt_multi_link) {
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11);
-				halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
-			} else {
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 11);
-				halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
-			}
-		} else {
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 11);
-		}
-	}
-}
-
-void halbtc8821c1ant_action_wifi_under5g(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8821C_1ANT_PHASE_5G_RUNTIME);
-	halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-
-void halbtc8821c1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-	halbtc8821c1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 10);
-	halbtc8821c1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-}
-
-void halbtc8821c1ant_action_wifi_native_lps(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-void halbtc8821c1ant_action_wifi_cck_dead_lock(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	if ((bt_link_info->hid_exist) && (bt_link_info->a2dp_exist) &&
-		(!bt_link_info->pan_exist)) {
-
-		if ((coex_sta->cck_lock) || (coex_sta->cck_lock_warn)) {
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 28);
-		} else {
-
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-		}
-	}
-}
-
-void halbtc8821c1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	if ((BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		coex_dm->bt_status) ||
-		(BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		coex_dm->bt_status))
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-	else if (!bt_link_info->pan_exist)
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	else
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2);
-
-	halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-	halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-
-void halbtc8821c1ant_action_wifi_linkscan_process(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	if (bt_link_info->pan_exist) {
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-	} else if (bt_link_info->a2dp_exist) {
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 27);
-	} else {
-
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-	}
-
-}
-
-void halbtc8821c1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE, wifi_cckdeadlock_ap = FALSE;
-	u32  wifi_bw = 1;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &coex_sta->scan_ap_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy_level = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-
-	if ((iot_peer == BTC_IOT_PEER_ATHEROS) && (coex_sta->cck_lock_ever))
-		wifi_cckdeadlock_ap = TRUE;
-
-	if ((bt_link_info->a2dp_exist) && (coex_sta->is_bt_a2dp_sink)) {
-
-		if (wifi_cckdeadlock_ap)
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		else
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 12);
-	} else if (bt_link_info->a2dp_only) { /* A2DP		 */
-
-		if (wifi_cckdeadlock_ap)
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		else if (wifi_turbo)
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 7);
-	} else if (((bt_link_info->a2dp_exist) &&
-		    (bt_link_info->pan_exist)) ||
-			(bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) { /* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
-
-		if (wifi_cckdeadlock_ap) {
-			if ((bt_link_info->hid_exist) && (coex_sta->hid_busy_num < 2))
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		} else if (bt_link_info->hid_exist) {
-			if (coex_sta->hid_busy_num < 2)
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		} else if (wifi_turbo)
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 13);
-		else
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 14);
-	} else if (bt_link_info->hid_exist &&
-		   bt_link_info->a2dp_exist) { /* HID+A2DP */
-
-		if (wifi_cckdeadlock_ap) {
-#if 1
-			if (coex_sta->hid_busy_num < 2)
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-
-			if (coex_sta->hid_pair_cnt > 1)
-				halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 24);
-			else
-				halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-#endif
-
-#if 0
-			halbtc8821c1ant_action_wifi_cck_dead_lock(btcoexist);
-#endif
-		} else {
-			if (coex_sta->hid_busy_num < 2) /* 2/18 HID */
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			else if (wifi_bw == 0)/* if 11bg mode */
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 12);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-
-			if (coex_sta->hid_pair_cnt > 1)
-				halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 24);
-			else
-				halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-		}
-	} else if ((bt_link_info->pan_only)
-		   || (bt_link_info->hid_exist && bt_link_info->pan_exist)) {
-			/* PAN(OPP,FTP), HID+PAN(OPP,FTP) */
-
-		if (wifi_cckdeadlock_ap) {
-			if ((bt_link_info->hid_exist) && (coex_sta->hid_busy_num < 2))
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13);
-		} else if (bt_link_info->hid_exist) {
-			if (coex_sta->hid_busy_num < 2)
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-			else
-				halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		} else if (wifi_turbo)
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		else
-			halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (!wifi_busy)
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 4);
-		else
-			halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 3);
-	} else {
-		/* BT no-profile busy (0x9) */
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-	}
-
-}
-
-void halbtc8821c1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-	/* tdma and coex table */
-	halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-}
-
-void halbtc8821c1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_busy = FALSE;
-	boolean	wifi_under_5g = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], CoexForWifiConnect()===>\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (wifi_under_5g) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_under5g(btcoexist);
-		return;
-	}
-
-	halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-
-	if ((coex_dm->bt_status == BT_8821C_1ANT_BT_STATUS_ACL_BUSY) ||
-		(coex_dm->bt_status == BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY)) {
-
-		if (bt_link_info->hid_only)  /* HID only */
-			halbtc8821c1ant_action_bt_sco_hid_only_busy(btcoexist);
-		else
-			halbtc8821c1ant_action_wifi_connected_bt_acl_busy(btcoexist);
-
-	} else if (coex_dm->bt_status == BT_8821C_1ANT_BT_STATUS_SCO_BUSY)
-		halbtc8821c1ant_action_bt_sco_hid_only_busy(btcoexist);
-	else
-		halbtc8821c1ant_action_bt_idle(btcoexist);
-
-}
-
-void halbtc8821c1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8				algorithm = 0;
-
-	algorithm = halbtc8821c1ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-
-	if (!halbtc8821c1ant_is_common_action(btcoexist)) {
-		switch (coex_dm->cur_algorithm) {
-		case BT_8821C_1ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		case BT_8821C_1ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-
-void halbtc8821c1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = FALSE, bt_hs_on = FALSE;
-	boolean	increase_scan_dev_num = FALSE;
-	boolean	bt_ctrl_agg_buf_size = FALSE;
-	boolean	miracast_plus_bt = FALSE, wifi_under_5g = FALSE;
-	u8	agg_buf_size = 5;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0, wifi_bw;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-	boolean	scan = FALSE, link = FALSE, roam = FALSE, under_4way = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &under_4way);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], under_lps = %d, force_lps_ctrl = %d, acl_busy = %d!!!\n",
-			coex_sta->under_lps, coex_sta->force_lps_ctrl, coex_sta->acl_busy);
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RunCoexistMechanism(), wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (!coex_sta->run_time_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], return for run_time_state = FALSE !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->freeze_coexrun_by_btinfo) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), return for freeze_coexrun_by_btinfo\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((wifi_under_5g) &&
-		(coex_sta->switch_band_notify_to != BTC_SWITCH_TO_24G) &&
-		(coex_sta->switch_band_notify_to != BTC_SWITCH_TO_24G_NOFORSCAN)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_under5g(btcoexist);
-		return;
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 2G!!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     NORMAL_EXEC,
-					     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-	}
-
-	if ((coex_sta->under_lps) && (!coex_sta->force_lps_ctrl) &&
-		(!coex_sta->acl_busy)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RunCoexistMechanism(), wifi is under LPS !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c1ant_action_wifi_native_lps(btcoexist);
-		return;
-	}
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c1ant_action_bt_whql_test(btcoexist);
-		return;
-	}
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is disabled !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c1ant_action_wifi_only(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c1ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	if ((coex_sta->is_setupLink) &&
-			(coex_sta->bt_relink_downcount != 0)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is re-link !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c1ant_action_bt_relink(btcoexist);
-		return;
-	}
-
-	if ((BT_8821C_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8821C_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		increase_scan_dev_num = TRUE;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_INC_SCAN_DEV_NUM,
-			   &increase_scan_dev_num);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist)
-			miracast_plus_bt = TRUE;
-		else
-			miracast_plus_bt = FALSE;
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-
-		if (scan || link || roam || under_4way) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], scan = %d, link = %d, roam = %d 4way = %d!!!\n",
-				    scan, link, roam, under_4way);
-			BTC_TRACE(trace_buf);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], wifi is under linkscan process + Multi-Port !!\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8821c1ant_action_wifi_linkscan_process(btcoexist);
-		} else
-			halbtc8821c1ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	} else {
-
-		miracast_plus_bt = FALSE;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-
-	if ((bt_link_info->bt_link_exist) && (wifi_connected)) {
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-		if (BTC_IOT_PEER_CISCO == iot_peer) {
-
-			if (BTC_WIFI_BW_HT40 == wifi_bw)
-				halbtc8821c1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, FALSE, TRUE, 0x10);
-			else
-				halbtc8821c1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, FALSE, TRUE, 0x8);
-		}
-	}
-
-	/* just print debug message */
-	halbtc8821c1ant_run_sw_coexist_mechanism(btcoexist);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (bt_hs_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "############# [BTCoex],  BT Is hs\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c1ant_action_bt_hs(btcoexist);
-		return;
-	}
-
-	if ((BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	     coex_dm->bt_status) ||
-	    (BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE ==
-	     coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "############# [BTCoex],  BT Is idle\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c1ant_action_bt_idle(btcoexist);
-		return;
-	}
-
-	if (scan || link || roam || under_4way) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], scan = %d, link = %d, roam = %d 4way = %d!!!\n",
-			    scan, link, roam, under_4way);
-		BTC_TRACE(trace_buf);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under linkscan process!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_linkscan_process(btcoexist);
-	} else if (wifi_connected) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under connected!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_connected(btcoexist);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under not-connected!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_not_connected(btcoexist);
-	}
-}
-
-void halbtc8821c1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-	halbtc8821c1ant_low_penalty_ra(btcoexist, FORCE_EXEC, FALSE);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	coex_sta->pop_event_cnt = 0;
-	coex_sta->cnt_RemoteNameReq = 0;
-	coex_sta->cnt_ReInit = 0;
-	coex_sta->cnt_setupLink = 0;
-	coex_sta->cnt_IgnWlanAct = 0;
-	coex_sta->cnt_Page = 0;
-	coex_sta->cnt_RoleSwitch = 0;
-	coex_sta->switch_band_notify_to = BTC_NOT_SWITCH;
-
-	halbtc8821c1ant_query_bt_info(btcoexist);
-}
-
-void halbtc8821c1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up, IN boolean wifi_only)
-{
-	u32			u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-	u16			u16tmp1 = 0;
-	u8			i;
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp1 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex],(Before Init HW config) 0xcb4 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    u32tmp3, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-
-	coex_sta->bt_coex_supported_feature = 0;
-	coex_sta->bt_coex_supported_version = 0;
-	coex_sta->bt_ble_scan_type = 0;
-	coex_sta->bt_ble_scan_para[0] = 0;
-	coex_sta->bt_ble_scan_para[1] = 0;
-	coex_sta->bt_ble_scan_para[2] = 0;
-	coex_sta->bt_reg_vendor_ac = 0xffff;
-	coex_sta->bt_reg_vendor_ae = 0xffff;
-	coex_sta->isolation_btween_wb = BT_8821C_1ANT_DEFAULT_ISOLATION;
-	coex_sta->gnt_error_cnt = 0;
-	coex_sta->bt_relink_downcount = 0;
-	coex_sta->is_set_ps_state_fail = FALSE;
-	coex_sta->cnt_set_ps_state_fail = 0;
-	coex_sta->wl_rx_rate = BTC_UNKNOWN;
-	coex_sta->wl_rts_rx_rate = BTC_UNKNOWN;
-	coex_sta->wl_center_channel = 0;
-
-	for (i = 0; i <= 9; i++)
-		coex_sta->bt_afh_map[i] = 0;
-
-	/* Setup RF front end type */
-	halbtc8821c1ant_set_rfe_type(btcoexist);
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* BT report packet sample rate	 */
-	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
-
-	/* Init 0x778 = 0x1 for 1-Ant */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* Enable PTA (3-wire function form BT side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
-
-	/* Enable PTA (tx/rx signal form WiFi side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
-
-	/* set GNT_BT=1 for coex table select both */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x763, 0x10, 0x1);
-
-	halbtc8821c1ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-#if 0
-	/* check if WL firmware download ok */
-	/*if (btcoexist->btc_read_1byte(btcoexist, 0x80) == 0xc6)*/
-	 halbtc8821c1ant_post_state_to_bt(btcoexist,
-					BT_8821C_1ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-
-	/* PTA parameter */
-	halbtc8821c1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-	halbtc8821c1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-
-	psd_scan->ant_det_is_ant_det_available = TRUE;
-
-	/* Antenna config */
-	if (coex_sta->is_rf_state_off) {
-
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_1ANT_PHASE_WLAN_OFF);
-
-		btcoexist->stop_coex_dm = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  halbtc8821c1ant_init_hw_config (RF Off)**********\n");
-		BTC_TRACE(trace_buf);
-	} else if (wifi_only) {
-		coex_sta->concurrent_rx_mode_on = FALSE;
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_WIFI,
-					     FORCE_EXEC,
-					     BT_8821C_1ANT_PHASE_WLANONLY_INIT);
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else {
-		/*Set BT polluted packet on for Tx rate adaptive not including Tx retry break by PTA, 0x45c[19] =1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x1);
-
-		coex_sta->concurrent_rx_mode_on = TRUE;
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x2, 0x0);
-
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_1ANT_PHASE_COEX_INIT);
-
-		btcoexist->stop_coex_dm = FALSE;
-	}
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp1 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (After Init HW config) 0xcb4 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    u32tmp3, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-}
-
-
-/* ************************************************************
- * work around function start with wa_halbtc8821c1ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8821c1ant_
- * ************************************************************ */
-void ex_halbtc8821c1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x0;
-	u16 u16tmp = 0x0;
-	u32	value = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx Execute 8821c 1-Ant PowerOn Setting xxxxxxxxxxxxxxxx!!\n");
-	BTC_TRACE(trace_buf);
-
-
-	btcoexist->stop_coex_dm = TRUE;
-	coex_sta->is_rf_state_off = FALSE;
-	psd_scan->ant_det_is_ant_det_available = FALSE;
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write BB Register correctly. */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-
-	/* Set Antenna Path to BT side */
-	/* Check efuse 0xc3[6] for Single Antenna Path */
-	if (board_info->single_ant_path == 0) {
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-		u8tmp = 1;
-	} else if (board_info->single_ant_path == 1) {
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-		u8tmp = 0;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (Power On) single_ant_path  = %d, btdm_ant_pos = %d\n",
-		    board_info->single_ant_path , board_info->btdm_ant_pos);
-	BTC_TRACE(trace_buf);
-
-	/* Setup RF front end type */
-	halbtc8821c1ant_set_rfe_type(btcoexist);
-
-	/* Set Antenna Path to BT side */
-	halbtc8821c1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_AUTO,
-				     FORCE_EXEC,
-				     BT_8821C_1ANT_PHASE_COEX_POWERON);
-
-	/* Save"single antenna position" info in Local register setting for FW reading, because FW may not ready at  power on */
-	if (btcoexist->chip_interface == BTC_INTF_PCI)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x3e0, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_USB)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60, u8tmp);
-
-	/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
-	halbtc8821c1ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********  LTE coex Reg 0x38 (Power-On) = 0x%x\n",
-		    halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x38));
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********  MAC Reg 0x70/ BB Reg 0xcb4 (Power-On) = 0x%x / 0x%x\n",
-		    btcoexist->btc_read_4byte(btcoexist, 0x70),
-		    btcoexist->btc_read_4byte(btcoexist, 0xcb4));
-	BTC_TRACE(trace_buf);
-
-}
-
-void ex_halbtc8821c1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8821c1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8821c1ant_init_hw_config(btcoexist, TRUE, wifi_only);
-}
-
-void ex_halbtc8821c1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8821c1ant_display_simple_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	u8		*cli_buf = btcoexist->cli_buf;
-	u32		bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8	cnt = 0;
-
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->bt_coex_supported_feature == 0)
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_FEATURE,
-						&coex_sta->bt_coex_supported_feature);
-
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			(coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		if (coex_sta->bt_reg_vendor_ac == 0xffff)
-			coex_sta->bt_reg_vendor_ac = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xac) & 0xffff);
-
-		if (coex_sta->bt_reg_vendor_ae == 0xffff)
-			coex_sta->bt_reg_vendor_ae = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xae) & 0xffff);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-						&bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-		if (coex_sta->num_of_profile > 0) {
-			cnt++;
-
-			if (cnt >= 3) {
-				btcoexist->btc_get_bt_afh_map_from_bt(btcoexist, 0,
-					&coex_sta->bt_afh_map[0]);
-				cnt = 0;
-			}
-		}
-	}
-
-	// BT coex. info.
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n _____[BT Coexist info]____");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n __[Under Manual Control]_");
-	CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n _________________________");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ____[Coex is STOPPED]____");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n _________________________");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s / 0x%x",
-			   "Ant PG Num/ Mech/ Pos/ RFE",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s/ 0x%x  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos/ RFE",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-		if (board_info->btdm_ant_det_finish) {
-
-			if (psd_scan->ant_det_result != 12)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_peak_val);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %d",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_psd_scan_peak_val
-					   / 100);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	bt_coex_ver = ((coex_sta->bt_coex_supported_version & 0xff00) >> 8);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-			"CoexVer WL/  BT_Desired/ BT_Report",
-			glcoex_ver_date_8821c_1ant, glcoex_ver_8821c_1ant,
-			glcoex_ver_btdesired_8821c_1ant,
-			bt_coex_ver,
-			(bt_coex_ver == 0xff ? "Unknown" :
-			(coex_sta->bt_disabled ? "BT-disable" :
-			(bt_coex_ver >= glcoex_ver_btdesired_8821c_1ant ?
-			"Match" : "Mis-Match"))));
-	CL_PRINTF(cli_buf);
-
-	// BT Status
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s ", "BT status",
-			((coex_sta->bt_disabled) ? ("disabled") :	((
-			coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page")
-			: ((BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			coex_dm->bt_status) ? "non-connected idle" :
-			((BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE ==
-			coex_dm->bt_status) ? "connected-idle" : "busy")))));
-	CL_PRINTF(cli_buf);
-
-	// HW settings
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "0x770(Hi-pri rx/tx)",
-			   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-			   "0x774(Lo-pri rx/tx)",
-			   coex_sta->low_priority_rx, coex_sta->low_priority_tx,
-			   (bt_link_info->slave_role ? "(Slave!!)" : (
-			   coex_sta->is_tdma_btautoslot_hang ? "(auto-slot hang!!)" : "")));
-	CL_PRINTF(cli_buf);
-
-}
-
-void ex_halbtc8821c1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_stack_info		*stack_info = &btcoexist->stack_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0;
-	u32			phyver = 0;
-	boolean			lte_coex_on = FALSE;
-	static u8 cnt = 0;
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->bt_coex_supported_feature == 0)
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_FEATURE,
-						&coex_sta->bt_coex_supported_feature);
-
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			(coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		if (coex_sta->bt_reg_vendor_ac == 0xffff)
-			coex_sta->bt_reg_vendor_ac = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xac) & 0xffff);
-
-		if (coex_sta->bt_reg_vendor_ae == 0xffff)
-			coex_sta->bt_reg_vendor_ae = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xae) & 0xffff);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-						&bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-		if (coex_sta->num_of_profile > 0) {
-			cnt++;
-
-			if (cnt >= 3) {
-				btcoexist->btc_get_bt_afh_map_from_bt(btcoexist, 0,
-					&coex_sta->bt_afh_map[0]);
-				cnt = 0;
-			}
-		}
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s / 0x%x",
-			   "Ant PG Num/ Mech/ Pos/ RFE",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s/ 0x%x  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos/ RFE",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-		if (board_info->btdm_ant_det_finish) {
-
-			if (psd_scan->ant_det_result != 12)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_peak_val);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %d",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_psd_scan_peak_val
-					   / 100);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-
-	bt_coex_ver = ((coex_sta->bt_coex_supported_version & 0xff00) >> 8);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8821c_1ant, glcoex_ver_8821c_1ant,
-		   glcoex_ver_btdesired_8821c_1ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (coex_sta->bt_disabled ? "BT-disable" :
-		     (bt_coex_ver >= glcoex_ver_btdesired_8821c_1ant ?
-		      "Match" : "Mis-Match"))));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x (RF-Ch = %d)",
-		   "AFH Map to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2], coex_sta->wl_center_channel);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = [%s/ %d dBm/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-			   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page")
-			   : ((BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-	if (coex_sta->num_of_profile != 0)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %s%s%s%s%s",
-			   "Profiles",
-			   ((bt_link_info->a2dp_exist) ?
-			   ((coex_sta->is_bt_a2dp_sink) ? "A2DP sink," :
-			    "A2DP,") : ""),
-			   ((bt_link_info->sco_exist) ?  "HFP," : ""),
-			   ((bt_link_info->hid_exist) ?
-			    ((coex_sta->hid_busy_num >= 2) ? "HID(4/18)," :
-			     "HID(2/18),") : ""),
-			   ((bt_link_info->pan_exist) ?  "PAN," : ""),
-			   ((coex_sta->voice_over_HOGP) ? "Voice" : ""));
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = None", "Profiles");
-
-	CL_PRINTF(cli_buf);
-
-	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			   "A2DP Rate/Bitpool/Auto_Slot",
-			   ((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
-			   coex_sta->a2dp_bit_pool,
-			   ((coex_sta->is_autoslot) ? "On" : "Off")
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	if (bt_link_info->hid_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "HID PairNum/Forbid_Slot",
-			   coex_sta->hid_pair_cnt,
-			   coex_sta->forbidden_slot
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
-				"Role/RoleSwCnt/IgnWlact/Feature",
-				((bt_link_info->slave_role) ? "Slave" : "Master"),
-				coex_sta->cnt_RoleSwitch,
-				((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
-				coex_sta->bt_coex_supported_feature);
-	CL_PRINTF(cli_buf);
-
-	if ((coex_sta->bt_ble_scan_type & 0x7) != 0x0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			"BLEScan Type/TV/Init/Ble",
-			coex_sta->bt_ble_scan_type,
-			(coex_sta->bt_ble_scan_type & 0x1 ?
-			coex_sta->bt_ble_scan_para[0] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x2 ?
-			coex_sta->bt_ble_scan_para[1] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x4 ?
-			coex_sta->bt_ble_scan_para[2] : 0x0));
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-		   "ReInit/ReLink/IgnWlact/Page/NameReq",
-		   coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-		   coex_sta->cnt_IgnWlanAct,
-		   coex_sta->cnt_Page,
-		   coex_sta->cnt_RemoteNameReq
-		  );
-	CL_PRINTF(cli_buf);
-
-	halbtc8821c1ant_read_score_board(btcoexist,	&u16tmp[0]);
-
-	if ((coex_sta->bt_reg_vendor_ae == 0xffff) ||
-	    (coex_sta->bt_reg_vendor_ac == 0xffff))
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = x/ x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard(B->W)", u16tmp[0]);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard",
-			   ((coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
-			   coex_sta->bt_reg_vendor_ac & 0x3, u16tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	if (coex_sta->num_of_profile > 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %02x%02x%02x%02x %02x%02x%02x%02x %02x%02x",
-			"AFH MAP",
-			coex_sta->bt_afh_map[0],
-			coex_sta->bt_afh_map[1],
-			coex_sta->bt_afh_map[2],
-			coex_sta->bt_afh_map[3],
-			coex_sta->bt_afh_map[4],
-			coex_sta->bt_afh_map[5],
-			coex_sta->bt_afh_map[6],
-			coex_sta->bt_afh_map[7],
-			coex_sta->bt_afh_map[8],
-			coex_sta->bt_afh_map[9]
-			   );
-		CL_PRINTF(cli_buf);
-	}
-
-	for (i = 0; i < BT_INFO_SRC_8821C_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8821c_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[mechanisms] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[Mechanisms]============");
-
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x (case-%d, %s)",
-		   "TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "TDMA On" : "TDMA Off"));
-
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d/ 0x%x/ 0x%x/ 0x%x",
-		   "Table/0x6c0/0x6c4/0x6c8",
-		   coex_sta->coex_table_type, u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ %04x",
-		   "0x778/0x6cc/Scoreboard(W->B)",
-		   u8tmp[0], u32tmp[0], coex_sta->score_board_WB);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
-		   "AntDiv/BtCtrlLPS/LPRA/PsFail",
-		   ((board_info->ant_div_cfg) ? "On" : "Off"),
-		   ((coex_sta->force_lps_ctrl) ? "On" : "Off"),
-		   ((coex_dm->cur_low_penalty_ra) ? "On" : "Off"),
-		   coex_sta->cnt_set_ps_state_fail);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-		   "Null All/Retry/Ack/BT_Empty/BT_Late",
-		   coex_sta->wl_fw_dbg_info[1],
-		   coex_sta->wl_fw_dbg_info[2],
-		   coex_sta->wl_fw_dbg_info[3],
-		   coex_sta->wl_fw_dbg_info[4],
-		   coex_sta->wl_fw_dbg_info[5]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ?  TRUE : FALSE;
-
-	if (lte_coex_on) {
-
-		u32tmp[0] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa0);
-		u32tmp[1] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa4);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-			   "LTE Coex Table W_L/B_L",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff);
-		CL_PRINTF(cli_buf);
-
-		u32tmp[0] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa8);
-		u32tmp[1] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xac);
-		u32tmp[2] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb0);
-		u32tmp[3] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb4);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			   "LTE Break Table W_L/B_L/L_W/L_B",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff,
-			   u32tmp[2] & 0xffff, u32tmp[3] & 0xffff);
-		CL_PRINTF(cli_buf);
-	}
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp[1] = halbtc8821c1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s",
-		   "LTE Coex/Path Owner",
-		   ((lte_coex_on) ? "On" : "Off") ,
-		   ((u8tmp[0] & BIT(2)) ? "WL" : "BT"));
-	CL_PRINTF(cli_buf);
-
-	if (lte_coex_on) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %d/ %d",
-			   "LTE 3Wire/OPMode/UART/UARTMode",
-			   (int)((u32tmp[0] & BIT(6)) >> 6),
-			   (int)((u32tmp[0] & (BIT(5) | BIT(4))) >> 4),
-			   (int)((u32tmp[0] & BIT(3)) >> 3),
-			   (int)(u32tmp[0] & (BIT(2) | BIT(1) | BIT(0))));
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "LTE_Busy/UART_Busy",
-			   (int)((u32tmp[1] & BIT(1)) >> 1),
-			   (int)(u32tmp[1] & BIT(0)));
-		CL_PRINTF(cli_buf);
-	}
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %s (BB:%s)/ %s (BB:%s)/ %s %d",
-		   "GNT_WL_Ctrl/GNT_BT_Ctrl/Dbg",
-		   ((u32tmp[0] & BIT(12)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(8)) ?  "SW" : "HW"),
-		   ((u32tmp[0] & BIT(14)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(10)) ?  "SW" : "HW"),
-		   ((u8tmp[0] & BIT(3)) ? "On" : "Off"),
-		   coex_sta->gnt_error_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ 0x%x",
-		   "GNT_WL/GNT_BT/ RF_0x1",
-		   (int)((u32tmp[1] & BIT(2)) >> 2),
-		   (int)((u32tmp[1] & BIT(3)) >> 3),
-		   btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff));
-	CL_PRINTF(cli_buf);
-
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xcb0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xcba);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%04x/ 0x%04x/ 0x%02x %s",
-		   "0xcb0/0xcb4/0xcb8[23:16]",
-		   u32tmp[0], u32tmp[1], u8tmp[0],
-		   ((u8tmp[0] & 0x1) == 0x1 ?  "(BTG)" :   "(WL_A+G)"));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x64);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "4c[24:23]/64[0]/4c6[4]/40[5]",
-		   (u32tmp[0] & (BIT(24) | BIT(23))) >> 23 , u8tmp[2] & 0x1 ,
-		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x953);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0xc50);
-	u8tmp[3] = btcoexist->btc_read_1byte(btcoexist, 0x60a);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ %s/ 0x%x/ 0x%x",
-		   "0x550/0x522/4-RxAGC/0xc50/0x60a",
-		u32tmp[0], u8tmp[0], (u8tmp[1] & 0x2) ? "On" : "Off",
-		u8tmp[2], u8tmp[3]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d (Rx_rate Data/RTS= %d/%d)",
-		   "CRC_OK CCK/11g/11n/11ac",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht,
-		   coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11ac",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %s/ %d",
-		   "HiPr/ Locking/ warn/ Locked/ Noisy",
-		   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-		   (coex_sta->cck_lock ? "Yes" : "No"),
-		   (coex_sta->cck_lock_warn ? "Yes" : "No"),
-		   (coex_sta->cck_lock_ever ? "Yes" : "No"),
-		   coex_sta->wl_noisy_level);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(Hi-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-		   "0x774(Lo-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx,
-		   (bt_link_info->slave_role ? "(Slave!!)" : (
-		   coex_sta->is_tdma_btautoslot_hang ? "(auto-slot hang!!)" : "")));
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8821c1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-	if (type == BTC_IPS_ENTER) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = TRUE;
-
-		/* Write WL "Active" in Score-board for LPS off */
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_1ANT_SCOREBOARD_ONOFF |
-				BT_8821C_1ANT_SCOREBOARD_SCAN |
-				BT_8821C_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_1ANT_PHASE_WLAN_OFF);
-		halbtc8821c1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821c1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (type == BTC_IPS_LEAVE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-#if 0
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-		halbtc8821c1ant_init_hw_config(btcoexist, FALSE, FALSE);
-		halbtc8821c1ant_init_coex_dm(btcoexist);
-
-		coex_sta->under_ips = FALSE;
-	}
-}
-
-void ex_halbtc8821c1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	static boolean  pre_force_lps_on = FALSE;
-
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (type == BTC_LPS_ENABLE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = TRUE;
-
-		if (coex_sta->force_lps_ctrl == TRUE) { /* LPS No-32K */
-			/* Write WL "Active" in Score-board for PS-TDMA */
-			pre_force_lps_on = TRUE;
-			halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_ACTIVE, TRUE);
-		} else { /* LPS-32K, need check if this h2c 0x71 can work?? (2015/08/28) */
-			/* Write WL "Non-Active" in Score-board for Native-PS */
-			pre_force_lps_on = FALSE;
-			halbtc8821c1ant_post_state_to_bt(btcoexist,
-				 BT_8821C_1ANT_SCOREBOARD_ACTIVE, FALSE);
-
-			halbtc8821c1ant_action_wifi_native_lps(btcoexist);
-		}
-	} else if (type == BTC_LPS_DISABLE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = FALSE;
-
-		/* Write WL "Active" in Score-board for LPS off */
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		if ((!pre_force_lps_on) && (!coex_sta->force_lps_ctrl))
-			halbtc8821c1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8821c1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean wifi_connected = FALSE;
-	boolean wifi_under_5g = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	coex_sta->freeze_coexrun_by_btinfo = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-
-	if (wifi_connected)
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** WL connected before SCAN\n");
-	else
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  WL is not connected before SCAN\n");
-
-	BTC_TRACE(trace_buf);
-
-	if ((type == BTC_SCAN_START) || (type == BTC_SCAN_START_2G)) {
-
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-					BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-					BT_8821C_1ANT_SCOREBOARD_SCAN |
-					BT_8821C_1ANT_SCOREBOARD_ONOFF,
-					TRUE);
-
-		halbtc8821c1ant_query_bt_info(btcoexist);
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((type == BTC_SCAN_START) && (wifi_under_5g)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], SCAN START notify (5G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_under5g(btcoexist);
-	} else if ((type == BTC_SCAN_START_2G) || (type == BTC_SCAN_START)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		if (!wifi_connected)
-			coex_sta->wifi_is_high_pri_task = TRUE;
-
-		/* Force antenna setup for no scan result issue */
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-
-		halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-	} else {
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify  (Scan-AP = %d)\n",
-			    coex_sta->scan_ap_num);
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = FALSE;
-
-		halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-	}
-
-}
-
-void ex_halbtc8821c1ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-
-	boolean wifi_connected = FALSE, bt_hs_on = FALSE;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = FALSE;
-	u8	agg_buf_size = 5;
-
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	coex_sta->switch_band_notify_to = type;
-
-	if (type == BTC_SWITCH_TO_5G) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], switchband_notify ---  switch to 5G\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_under5g(btcoexist);
-
-	} else if (type == BTC_SWITCH_TO_24G_NOFORSCAN) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], switchband_notify --- BTC_SWITCH_TO_2G (no for scan)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], switchband_notify ---  switch to 2G\n");
-		BTC_TRACE(trace_buf);
-
-		ex_halbtc8821c1ant_scan_notify(btcoexist,
-					       BTC_SCAN_START_2G);
-	}
-
-	coex_sta->switch_band_notify_to = BTC_NOT_SWITCH;
-}
-
-
-void ex_halbtc8821c1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-					 BT_8821C_1ANT_SCOREBOARD_SCAN |
-					 BT_8821C_1ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-
-	if ((type == BTC_ASSOCIATE_5G_START) ||
-	    (type == BTC_ASSOCIATE_5G_FINISH)) {
-
-		if (type == BTC_ASSOCIATE_5G_START)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], connect_notify ---  5G start\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], connect_notify ---  5G finish\n");
-
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_under5g(btcoexist);
-	} else if (type == BTC_ASSOCIATE_START) {
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_dm->arp_cnt = 0;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		/* Force antenna setup for no scan result issue */
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-
-		halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-
-		/* To keep TDMA case during connect process,
-		to avoid changed by Btinfo and runcoexmechanism */
-		coex_sta->freeze_coexrun_by_btinfo = TRUE;
-	} else {
-
-		coex_sta->wifi_is_high_pri_task = FALSE;
-		coex_sta->freeze_coexrun_by_btinfo = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-	}
-
-}
-
-void ex_halbtc8821c1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean			wifi_under_b_mode = FALSE, wifi_under_5g = FALSE;
-
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (type == BTC_MEDIA_CONNECT) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-					 BT_8821C_1ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-
-		if (wifi_under_5g) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], WiFi is under 5G!!!\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8821c1ant_action_wifi_under5g(btcoexist);
-		} else {
-
-			/* Force antenna setup for no scan result issue */
-			halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-						     FORCE_EXEC,
-						     BT_8821C_1ANT_PHASE_2G_RUNTIME);
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-
-			/* Set CCK Tx/Rx high Pri except 11b mode */
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x00); /* CCK Tx */
-				btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x00); /* CCK Rx */
-			} else {
-				btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x00); /* CCK Tx */
-				btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x10); /* CCK Rx */
-			}
-		}
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				 BT_8821C_1ANT_SCOREBOARD_ACTIVE, FALSE);
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-
-		coex_sta->cck_lock_ever = FALSE;
-		coex_sta->cck_lock_warn = FALSE;
-		coex_sta->cck_lock = FALSE;
-	}
-
-	halbtc8821c1ant_update_wifi_channel_info(btcoexist, type);
-
-}
-
-void ex_halbtc8821c1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean	under_4way = FALSE, wifi_under_5g = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (wifi_under_5g) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_action_wifi_under5g(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &under_4way);
-
-	if (under_4way) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ---- under_4way!!\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	} else if (type == BTC_PACKET_ARP) {
-
-		coex_dm->arp_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ARP notify -cnt = %d\n",
-			    coex_dm->arp_cnt);
-		BTC_TRACE(trace_buf);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet DHCP or EAPOL notify [Type = %d]\n",
-			    type);
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	}
-
-	if (coex_sta->wifi_is_high_pri_task) {
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_SCAN, TRUE);
-		halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-	}
-
-}
-
-void ex_halbtc8821c1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8				i, rsp_source = 0;
-	boolean				wifi_connected = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE,
-			wifi_busy = FALSE;
-	static boolean is_scoreboard_scan = FALSE;
-
-	if (psd_scan->is_AntDet_running == TRUE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], bt_info_notify return for AntDet is running\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8821C_1ANT_MAX)
-		rsp_source = BT_INFO_SRC_8821C_1ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt_info[%d], len=%d, data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	coex_sta->bt_info = coex_sta->bt_info_c2h[rsp_source][1];
-	coex_sta->bt_info_ext = coex_sta->bt_info_c2h[rsp_source][4];
-	coex_sta->bt_info_ext2 = coex_sta->bt_info_c2h[rsp_source][5];
-
-	if (BT_INFO_SRC_8821C_1ANT_WIFI_FW != rsp_source) {
-
-		/* if 0xff, it means BT is under WHCK test */
-		coex_sta->bt_whck_test = ((coex_sta->bt_info == 0xff) ? TRUE :
-					  FALSE);
-
-		coex_sta->bt_create_connection = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x80) ? TRUE :
-						  FALSE);
-
-		/* unit: %, value-100 to translate to unit: dBm */
-		coex_sta->bt_rssi = coex_sta->bt_info_c2h[rsp_source][3] * 2 +
-				    10;
-
-		coex_sta->c2h_bt_remote_name_req = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x20) ? TRUE :
-						    FALSE);
-
-		coex_sta->is_A2DP_3M = ((coex_sta->bt_info_c2h[rsp_source][2] &
-					 0x10) ? TRUE : FALSE);
-
-		coex_sta->acl_busy = ((coex_sta->bt_info_c2h[rsp_source][1] &
-				       0x8) ? TRUE : FALSE);
-
-		coex_sta->voice_over_HOGP = ((coex_sta->bt_info_ext & 0x10) ?
-					     TRUE : FALSE);
-
-		coex_sta->c2h_bt_inquiry_page = ((coex_sta->bt_info &
-			  BT_INFO_8821C_1ANT_B_INQ_PAGE) ? TRUE : FALSE);
-
-		coex_sta->a2dp_bit_pool = (((
-			coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) ?
-				   (coex_sta->bt_info_c2h[rsp_source][6] & 0x7f) : 0);
-
-		coex_sta->is_bt_a2dp_sink = (coex_sta->bt_info_c2h[rsp_source][6] & 0x80) ?
-									TRUE : FALSE;
-
-		coex_sta->bt_retry_cnt = coex_sta->bt_info_c2h[rsp_source][2] &
-					 0xf;
-
-		coex_sta->is_autoslot = coex_sta->bt_info_ext2 & 0x8;
-
-		coex_sta->forbidden_slot = coex_sta->bt_info_ext2 & 0x7;
-
-		coex_sta->hid_busy_num = (coex_sta->bt_info_ext2 & 0x30) >> 4;
-
-		coex_sta->hid_pair_cnt = (coex_sta->bt_info_ext2 & 0xc0) >> 6;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->c2h_bt_remote_name_req)
-			coex_sta->cnt_RemoteNameReq++;
-
-		if (coex_sta->bt_info_ext & BIT(1))
-			coex_sta->cnt_ReInit++;
-
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setupLink++;
-			coex_sta->is_setupLink = TRUE;
-			coex_sta->bt_relink_downcount = 2;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link start in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->is_setupLink = FALSE;
-			coex_sta->bt_relink_downcount = 0;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link stop in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(3))
-			coex_sta->cnt_IgnWlanAct++;
-
-		if (coex_sta->bt_info_ext & BIT(6))
-			coex_sta->cnt_RoleSwitch++;
-
-		if (coex_sta->bt_info_ext & BIT(7))
-			coex_sta->is_bt_multi_link = TRUE;
-		else
-			coex_sta->is_bt_multi_link = FALSE;
-
-		if (coex_sta->bt_create_connection) {
-			coex_sta->cnt_Page++;
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-			if ((wifi_link) || (wifi_roam) || (wifi_scan) ||
-			    (coex_sta->wifi_is_high_pri_task) || (wifi_busy)) {
-
-				is_scoreboard_scan = TRUE;
-				halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_SCAN, TRUE);
-
-			} else
-				halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_SCAN, FALSE);
-
-		} else {
-				if (is_scoreboard_scan) {
-					halbtc8821c1ant_post_state_to_bt(btcoexist,
-						 BT_8821C_1ANT_SCOREBOARD_SCAN, FALSE);
-					is_scoreboard_scan = FALSE;
-				}
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-
-		if ((!btcoexist->manual_control) &&
-		    (!btcoexist->stop_coex_dm)) {
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-
-			/*  Re-Init */
-			if ((coex_sta->bt_info_ext & BIT(1))) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-				BTC_TRACE(trace_buf);
-				if (wifi_connected)
-					halbtc8821c1ant_update_wifi_channel_info(
-						btcoexist, BTC_MEDIA_CONNECT);
-				else
-					halbtc8821c1ant_update_wifi_channel_info(
-						btcoexist,
-						BTC_MEDIA_DISCONNECT);
-			}
-
-			/*  If Ignore_WLanAct && not SetUp_Link */
-			if ((coex_sta->bt_info_ext & BIT(3)) &&
-			    (!(coex_sta->bt_info_ext & BIT(2)))) {
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8821c1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, FALSE);
-			}
-		}
-
-	}
-
-	if ((coex_sta->bt_info_ext & BIT(5))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BT ext info bit4 check, query BLE Scan type!!\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_ble_scan_type = btcoexist->btc_get_ble_scan_type_from_bt(
-						     btcoexist);
-
-		if ((coex_sta->bt_ble_scan_type & 0x1) == 0x1)
-			coex_sta->bt_ble_scan_para[0]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x1);
-		if ((coex_sta->bt_ble_scan_type & 0x2) == 0x2)
-			coex_sta->bt_ble_scan_para[1]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x2);
-		if ((coex_sta->bt_ble_scan_type & 0x4) == 0x4)
-			coex_sta->bt_ble_scan_para[2]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x4);
-
-	}
-
-	halbtc8821c1ant_update_bt_link_info(btcoexist);
-
-	halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8821c1ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8 i = 0;
-	static u8 tmp_buf_pre[10] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d (len = %d)\n",
-			    tmp_buf[0], tmp_buf[1],
-				tmp_buf[2], tmp_buf[3],
-				tmp_buf[4], tmp_buf[5], length);
-	BTC_TRACE(trace_buf);
-
-	if (tmp_buf[0] == 0x8) {
-		for (i = 1; i <= 5; i++) {
-			coex_sta->wl_fw_dbg_info[i] =
-				(tmp_buf[i] >= tmp_buf_pre[i]) ?
-				(tmp_buf[i] - tmp_buf_pre[i]) :
-				(255 - tmp_buf_pre[i] + tmp_buf[i]);
-
-			tmp_buf_pre[i] = tmp_buf[i];
-		}
-	}
-}
-
-
-void ex_halbtc8821c1ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
-		IN BOOLEAN is_data_frame, IN u8 btc_rate_id)
-{
-	BOOLEAN wifi_connected = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	if (is_data_frame) {
-		coex_sta->wl_rx_rate = btc_rate_id;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], rx_rate_change_notify data rate id = %d, RTS_Rate = %d\n",
-			coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate);
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_sta->wl_rts_rx_rate = btc_rate_id;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], rts_rate_change_notify RTS rate id = %d, RTS_Rate = %d\n",
-			coex_sta->wl_rts_rx_rate, coex_sta->wl_rts_rx_rate);
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((wifi_connected) &&
-		((coex_dm->bt_status ==  BT_8821C_1ANT_BT_STATUS_ACL_BUSY) ||
-		(coex_dm->bt_status ==  BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		(coex_dm->bt_status == BT_8821C_1ANT_BT_STATUS_SCO_BUSY))) {
-
-		if ((coex_sta->wl_rx_rate == BTC_CCK_5_5) ||
-			(coex_sta->wl_rx_rate == BTC_OFDM_6) ||
-			(coex_sta->wl_rx_rate == BTC_MCS_0)) {
-
-			coex_sta->cck_lock_warn = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck lock warning...\n");
-			BTC_TRACE(trace_buf);
-		} else if ((coex_sta->wl_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rx_rate == BTC_CCK_2) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_2)) {
-
-			coex_sta->cck_lock = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck locking...\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->cck_lock_warn = FALSE;
-			coex_sta->cck_lock = FALSE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck unlock...\n");
-			BTC_TRACE(trace_buf);
-		}
-	} else {
-		if ((coex_dm->bt_status ==
-			BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE) ||
-			(coex_dm->bt_status ==
-			BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE)) {
-			coex_sta->cck_lock_warn = FALSE;
-			coex_sta->cck_lock = FALSE;
-		}
-	}
-
-}
-
-void ex_halbtc8821c1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (type == BTC_RF_ON) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->stop_coex_dm = FALSE;
-		coex_sta->is_rf_state_off = FALSE;
-#if 0
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-					 BT_8821C_1ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-#endif
-	} else if (type == BTC_RF_OFF) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_1ANT_SCOREBOARD_ONOFF |
-				BT_8821C_1ANT_SCOREBOARD_SCAN |
-				BT_8821C_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_1ANT_PHASE_WLAN_OFF);
-		halbtc8821c1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-		btcoexist->stop_coex_dm = TRUE;
-		coex_sta->is_rf_state_off = TRUE;
-	}
-}
-
-void ex_halbtc8821c1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_1ANT_SCOREBOARD_ONOFF |
-				BT_8821C_1ANT_SCOREBOARD_SCAN |
-				BT_8821C_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-	halbtc8821c1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8821C_1ANT_PHASE_WLAN_OFF);
-
-	ex_halbtc8821c1ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	halbtc8821c1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-	btcoexist->stop_coex_dm = TRUE;
-}
-
-void ex_halbtc8821c1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	boolean wifi_under_5g = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((BTC_WIFI_PNP_SLEEP == pnp_state) ||
-	    (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_1ANT_SCOREBOARD_ONOFF |
-				BT_8821C_1ANT_SCOREBOARD_SCAN |
-				BT_8821C_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		if (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state) {
-
-			if (wifi_under_5g)
-				halbtc8821c1ant_set_ant_path(btcoexist,
-						BTC_ANT_PATH_AUTO, FORCE_EXEC,
-						BT_8821C_1ANT_PHASE_5G_RUNTIME);
-			else
-				halbtc8821c1ant_set_ant_path(btcoexist,
-						BTC_ANT_PATH_AUTO, FORCE_EXEC,
-						BT_8821C_1ANT_PHASE_2G_RUNTIME);
-		} else {
-
-			halbtc8821c1ant_set_ant_path(btcoexist,
-						BTC_ANT_PATH_AUTO,
-						FORCE_EXEC,
-						BT_8821C_1ANT_PHASE_WLAN_OFF);
-		}
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-#if 0
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_ACTIVE |
-					 BT_8821C_1ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-#endif
-		btcoexist->stop_coex_dm = FALSE;
-	}
-}
-
-
-void ex_halbtc8821c1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], *****************Coex DM Reset*****************\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8821c1ant_init_hw_config(btcoexist, FALSE, FALSE);
-	halbtc8821c1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8821c1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	boolean wifi_busy = FALSE;
-	u16 bt_scoreboard_val = 0;
-	boolean bt_relink_finish = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ************* Periodical *************\n");
-	BTC_TRACE(trace_buf);
-
-#if (BT_AUTO_REPORT_ONLY_8821C_1ANT == 0)
-	halbtc8821c1ant_query_bt_info(btcoexist);
-
-#endif
-
-	halbtc8821c1ant_monitor_bt_ctr(btcoexist);
-	halbtc8821c1ant_monitor_wifi_ctr(btcoexist);
-
-	halbtc8821c1ant_monitor_bt_enable_disable(btcoexist);
-
-#if 0
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* halbtc8821c1ant_read_score_board(btcoexist, &bt_scoreboard_val); */
-
-	if (wifi_busy) {
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-				BT_8821C_1ANT_SCOREBOARD_UNDERTEST, TRUE);
-		/*
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-					 BT_8821C_1ANT_SCOREBOARD_WLBUSY, TRUE);
-
-		if (bt_scoreboard_val & BIT(6))
-			halbtc8821c1ant_query_bt_info(btcoexist); */
-	} else {
-		halbtc8821c1ant_post_state_to_bt(btcoexist,
-					BT_8821C_1ANT_SCOREBOARD_UNDERTEST, FALSE);
-	}
-#endif
-
-	if (coex_sta->bt_relink_downcount != 0) {
-		coex_sta->bt_relink_downcount--;
-
-		if (coex_sta->bt_relink_downcount == 0) {
-			coex_sta->is_setupLink = FALSE;
-			bt_relink_finish = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Re-Link stop by periodical count-down!!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	/* for 4-way, DHCP, EAPOL packet */
-	if (coex_sta->specific_pkt_period_cnt > 0) {
-
-		coex_sta->specific_pkt_period_cnt--;
-
-		if ((coex_sta->specific_pkt_period_cnt == 0) &&
-		    (coex_sta->wifi_is_high_pri_task))
-			coex_sta->wifi_is_high_pri_task = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ***************** Hi-Pri Task = %s\n",
-			    (coex_sta->wifi_is_high_pri_task ? "Yes" :
-			     "No"));
-		BTC_TRACE(trace_buf);
-
-	}
-
-	if (halbtc8821c1ant_is_wifibt_status_changed(btcoexist) || (bt_relink_finish)
-		|| (coex_sta->is_set_ps_state_fail))
-		halbtc8821c1ant_run_coexist_mechanism(btcoexist);
-
-}
-
-/*#pragma optimize( "", off )*/
-void ex_halbtc8821c1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-}
-
-
-void ex_halbtc8821c1ant_display_ant_detection(IN struct btc_coexist *btcoexist)
-{
-
-}
-
-void ex_halbtc8821c1ant_antenna_isolation(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-
-}
-
-void ex_halbtc8821c1ant_psd_scan(IN struct btc_coexist *btcoexist,
-		 IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-
-}
-
-
-#endif
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c1ant.h
deleted file mode 100644
index bb34171f444e..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c1ant.h
+++ /dev/null
@@ -1,520 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821C_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8821C 1ANT BT Co-exist definition
- * ******************************************* */
-#define	BT_8821C_1ANT_COEX_DBG					0
-#define	BT_AUTO_REPORT_ONLY_8821C_1ANT				1
-
-#define	BT_INFO_8821C_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8821C_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8821C_1ANT_B_HID						BIT(5)
-#define	BT_INFO_8821C_1ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8821C_1ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8821C_1ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8821C_1ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8821C_1ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8821C_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-	(((_BT_INFO_EXT_&BIT(0))) ? TRUE : FALSE)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT		2
-
-#define  BT_8821C_1ANT_WIFI_NOISY_THRESH							30   /* max: 255 */
-#define  BT_8821C_1ANT_DEFAULT_ISOLATION						15	 /*  unit: dB */
-
-
-/* for Antenna detection */
-#define	BT_8821C_1ANT_ANTDET_PSDTHRES_BACKGROUND					50
-#define	BT_8821C_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8821C_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			55
-#define	BT_8821C_1ANT_ANTDET_PSDTHRES_1ANT							35
-#define	BT_8821C_1ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8821C_1ANT_ANTDET_SWEEPPOINT_DELAY							60000
-#define	BT_8821C_1ANT_ANTDET_ENABLE									0
-#define	BT_8821C_1ANT_ANTDET_BTTXTIME									100
-#define	BT_8821C_1ANT_ANTDET_BTTXCHANNEL								39
-#define	BT_8821C_1ANT_ANTDET_PSD_SWWEEPCOUNT						50
-
-#define	BT_8821C_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
-
-enum bt_8821c_1ant_signal_state {
-	BT_8821C_1ANT_SIG_STA_SET_TO_LOW		= 0x0,
-	BT_8821C_1ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8821C_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,
-	BT_8821C_1ANT_SIG_STA_MAX
-};
-
-enum bt_8821c_1ant_path_ctrl_owner {
-	BT_8821C_1ANT_PCO_BTSIDE		= 0x0,
-	BT_8821C_1ANT_PCO_WLSIDE	= 0x1,
-	BT_8821C_1ANT_PCO_MAX
-};
-
-enum bt_8821c_1ant_gnt_ctrl_type {
-	BT_8821C_1ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,
-	BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,
-	BT_8821C_1ANT_GNT_TYPE_MAX
-};
-
-enum bt_8821c_1ant_gnt_ctrl_block {
-	BT_8821C_1ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8821C_1ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8821C_1ANT_GNT_BLOCK_BB			= 0x2,
-	BT_8821C_1ANT_GNT_BLOCK_MAX
-};
-
-enum bt_8821c_1ant_lte_coex_table_type {
-	BT_8821C_1ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8821C_1ANT_CTT_BT_VS_LTE			= 0x1,
-	BT_8821C_1ANT_CTT_MAX
-};
-
-enum bt_8821c_1ant_lte_break_table_type {
-	BT_8821C_1ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8821C_1ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8821C_1ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8821C_1ANT_LBTT_LTE_BREAK_BT				= 0x3,
-	BT_8821C_1ANT_LBTT_MAX
-};
-
-enum bt_info_src_8821c_1ant {
-	BT_INFO_SRC_8821C_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8821C_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8821C_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8821C_1ANT_MAX
-};
-
-enum bt_8821c_1ant_bt_status {
-	BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8821C_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8821C_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8821C_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8821C_1ANT_BT_STATUS_MAX
-};
-
-enum bt_8821c_1ant_wifi_status {
-	BT_8821C_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8821C_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8821C_1ANT_WIFI_STATUS_MAX
-};
-
-enum bt_8821c_1ant_coex_algo {
-	BT_8821C_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8821C_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8821C_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8821C_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8821C_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8821C_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8821C_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8821C_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8821C_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8821C_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8821C_1ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8821C_1ANT_COEX_ALGO_MAX				= 0xb,
-};
-
-enum bt_8821c_1ant_ext_ant_switch_type {
-	BT_8821C_1ANT_EXT_ANT_SWITCH_USE_DPDT		= 0x0,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_USE_SPDT		= 0x1,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_NONE			= 0x2,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_MAX
-};
-
-
-enum bt_8821c_1ant_ext_ant_switch_ctrl_type {
-	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	= 0x0,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA		= 0x1,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC		= 0x3,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_MAX
-};
-
-enum bt_8821c_1ant_ext_ant_switch_pos_type {
-	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_BT			= 0x0,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLG			= 0x1,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLA			= 0x2,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_NOCARE		= 0x3,
-	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_MAX
-};
-
-enum bt_8821c_1ant_ext_band_switch_pos_type {
-	BT_8821C_1ANT_EXT_BAND_SWITCH_TO_WLG			= 0x0,
-	BT_8821C_1ANT_EXT_BAND_SWITCH_TO_WLA			= 0x1,
-	BT_8821C_1ANT_EXT_BAND_SWITCH_TO_MAX
-};
-
-enum bt_8821c_1ant_int_block {
-	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG			= 0x0,
-	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG		= 0x1,
-	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG		= 0x2,
-	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_MAX
-};
-
-enum bt_8821c_1ant_phase {
-	BT_8821C_1ANT_PHASE_COEX_INIT								= 0x0,
-	BT_8821C_1ANT_PHASE_WLANONLY_INIT							= 0x1,
-	BT_8821C_1ANT_PHASE_WLAN_OFF								= 0x2,
-	BT_8821C_1ANT_PHASE_2G_RUNTIME								= 0x3,
-	BT_8821C_1ANT_PHASE_5G_RUNTIME								= 0x4,
-	BT_8821C_1ANT_PHASE_BTMPMODE									= 0x5,
-	BT_8821C_1ANT_PHASE_ANTENNA_DET								= 0x6,
-	BT_8821C_1ANT_PHASE_COEX_POWERON							= 0x7,
-	BT_8821C_1ANT_PHASE_MAX
-};
-
-enum bt_8821c_1ant_Scoreboard {
-	BT_8821C_1ANT_SCOREBOARD_ACTIVE								= BIT(0),
-	BT_8821C_1ANT_SCOREBOARD_ONOFF								= BIT(1),
-	BT_8821C_1ANT_SCOREBOARD_SCAN								= BIT(2),
-	BT_8821C_1ANT_SCOREBOARD_UNDERTEST							= BIT(3),
-	BT_8821C_1ANT_SCOREBOARD_WLBUSY								= BIT(6)
-};
-
-struct coex_dm_8821c_1ant {
-	/* hw setting */
-	u32		pre_ant_pos_type;
-	u32		cur_ant_pos_type;
-	/* fw mechanism */
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	/* sw mechanism */
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-	u32		arp_cnt;
-
-	u32		pre_ext_ant_switch_status;
-	u32		cur_ext_ant_switch_status;
-
-	u8		pre_ext_band_switch_status;
-	u8		cur_ext_band_switch_status;
-
-	u8		pre_int_block_status;
-	u8		cur_int_block_status;
-
-	u8		error_condition;
-};
-
-struct coex_sta_8821c_1ant {
-	boolean				bt_disabled;
-	boolean				bt_link_exist;
-	boolean				sco_exist;
-	boolean				a2dp_exist;
-	boolean				hid_exist;
-	boolean				pan_exist;
-	u8					num_of_profile;
-
-	boolean				under_lps;
-	boolean				under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	boolean             is_hiPri_rx_overhead;
-	s8					bt_rssi;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	u8					bt_info_c2h[BT_INFO_SRC_8821C_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821C_1ANT_MAX];
-	boolean				bt_whck_test;
-	boolean				c2h_bt_inquiry_page;
-	boolean				c2h_bt_remote_name_req;
-	boolean				c2h_bt_page;				/* Add for win8.1 page out issue */
-	boolean				wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-
-	u8					bt_info_ext;
-	u8					bt_info_ext2;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-	u8					bt_retry_cnt;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	boolean				cck_lock;
-	boolean				cck_lock_ever;
-	boolean				cck_lock_warn;
-
-	u8					coex_table_type;
-	boolean				force_lps_ctrl;
-	boolean				concurrent_rx_mode_on;
-	u16					score_board;
-	u8					isolation_btween_wb;   /* 0~ 50 */
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-	boolean				acl_busy;
-	boolean				bt_create_connection;
-
-	u32					bt_coex_supported_feature;
-	u32					bt_coex_supported_version;
-
-	u8					bt_ble_scan_type;
-	u32					bt_ble_scan_para[3];
-
-	boolean				run_time_state;
-	boolean				freeze_coexrun_by_btinfo;
-
-	boolean				is_A2DP_3M;
-	boolean				voice_over_HOGP;
-	u8                  bt_info;
-	boolean				is_autoslot;
-	u8					forbidden_slot;
-	u8					hid_busy_num;
-	u8					hid_pair_cnt;
-
-	u32					cnt_RemoteNameReq;
-	u32					cnt_setupLink;
-	u32					cnt_ReInit;
-	u32					cnt_IgnWlanAct;
-	u32					cnt_Page;
-	u32					cnt_RoleSwitch;
-
-	u16					bt_reg_vendor_ac;
-	u16					bt_reg_vendor_ae;
-
-	boolean				is_setupLink;
-	u8					wl_noisy_level;
-	u32                 gnt_error_cnt;
-
-	u8					bt_afh_map[10];
-	u8					bt_relink_downcount;
-	boolean				is_tdma_btautoslot;
-	boolean				is_tdma_btautoslot_hang;
-
-	u8					switch_band_notify_to;
-	boolean				is_rf_state_off;
-
-	boolean				is_hid_low_pri_tx_overhead;
-	boolean				is_bt_multi_link;
-	boolean				is_bt_a2dp_sink;
-	boolean				is_set_ps_state_fail;
-	u8					cnt_set_ps_state_fail;
-
-	u8					wl_fw_dbg_info[10];
-	u8					wl_rx_rate;
-	u8					wl_rts_rx_rate;
-	u8					wl_center_channel;
-
-	u16					score_board_WB;
-};
-
-
-#define  BT_8821C_1ANT_EXT_BAND_SWITCH_USE_DPDT	0
-#define  BT_8821C_1ANT_EXT_BAND_SWITCH_USE_SPDT	1
-
-
-struct rfe_type_8821c_1ant {
-
-	u8			rfe_module_type;
-	boolean		ext_ant_switch_exist;
-	u8			ext_ant_switch_type;			/* 0:DPDT, 1:SPDT */
-	u8			ext_ant_switch_ctrl_polarity;		/*  iF 0: DPDT_P=0, DPDT_N=1 => BTG to Main, WL_A+G to Aux */
-
-	boolean		ext_band_switch_exist;
-	u8			ext_band_switch_type;			/* 0:DPDT, 1:SPDT */
-	u8			ext_band_switch_ctrl_polarity;
-
-	boolean		ant_at_main_port;
-
-	boolean		wlg_Locate_at_btg;				/*  If TRUE:  WLG at BTG, If FALSE: WLG at WLAG */
-
-	boolean		ext_ant_switch_diversity;		/* If diversity on */
-};
-
-#define  BT_8821C_1ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
-#define  BT_8821C_1ANT_ANTDET_PSD_AVGNUM			1	/* MAX:3 */
-#define	BT_8821C_1ANT_ANTDET_BUF_LEN				16
-
-struct psdscan_sta_8821c_1ant {
-
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8821C_1ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8821C_1ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_max_value2;
-	u32			psd_avg_value;   /* filter loop_max_value that below BT_8821C_1ANT_ANTDET_PSDTHRES_1ANT, and average the rest*/
-	u32			psd_loop_max_value[BT_8821C_1ANT_ANTDET_PSD_SWWEEPCOUNT];  /*max value in each loop */
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_AntDet_running;
-	boolean			is_psd_show_max_only;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8821c1ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8821c1ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821c1ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821c1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8821c1ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8821c1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8821c1ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8821c1ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
-		IN BOOLEAN is_data_frame, IN u8 btc_rate_id);
-void ex_halbtc8821c1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c1ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8821c1ant_coex_dm_reset(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_display_simple_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8821c1ant_antenna_isolation(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-
-void ex_halbtc8821c1ant_psd_scan(IN struct btc_coexist *btcoexist,
-		 IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8821c1ant_display_ant_detection(IN struct btc_coexist *btcoexist);
-
-#else
-#define	ex_halbtc8821c1ant_power_on_setting(btcoexist)
-#define	ex_halbtc8821c1ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8821c1ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8821c1ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8821c1ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_switchband_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8821c1ant_wl_fwdbginfo_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8821c1ant_rx_rate_change_notify(btcoexist, is_data_frame, btc_rate_id)
-#define	ex_halbtc8821c1ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8821c1ant_halt_notify(btcoexist)
-#define	ex_halbtc8821c1ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8821c1ant_coex_dm_reset(btcoexist)
-#define	ex_halbtc8821c1ant_periodical(btcoexist)
-#define	ex_halbtc8821c1ant_display_simple_coex_info(btcoexist)
-#define	ex_halbtc8821c1ant_display_coex_info(btcoexist)
-#define	ex_halbtc8821c1ant_antenna_detection(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8821c1ant_antenna_isolation(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8821c1ant_psd_scan(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8821c1ant_display_ant_detection(btcoexist)
-#endif
-
-#endif
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c2ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c2ant.c
deleted file mode 100644
index 039386aba2e7..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c2ant.c
+++ /dev/null
@@ -1,6389 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 RTL8821C Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821C_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	*trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8821c_2ant		glcoex_dm_8821c_2ant;
-static struct  coex_dm_8821c_2ant	*coex_dm = &glcoex_dm_8821c_2ant;
-static struct  coex_sta_8821c_2ant		glcoex_sta_8821c_2ant;
-static struct  coex_sta_8821c_2ant	*coex_sta = &glcoex_sta_8821c_2ant;
-static struct  psdscan_sta_8821c_2ant	gl_psd_scan_8821c_2ant;
-static struct  psdscan_sta_8821c_2ant *psd_scan = &gl_psd_scan_8821c_2ant;
-static struct	rfe_type_8821c_2ant		gl_rfe_type_8821c_2ant;
-static struct	rfe_type_8821c_2ant		*rfe_type = &gl_rfe_type_8821c_2ant;
-
-const char *const glbt_info_src_8821c_2ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-u32	glcoex_ver_date_8821c_2ant = 20170727;
-u32	glcoex_ver_8821c_2ant = 0x1b;
-u32 glcoex_ver_btdesired_8821c_2ant = 0x1b;
-
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8821c2ant_
- * ************************************************************ */
-u8 halbtc8821c2ant_bt_rssi_state(IN struct btc_coexist *btcoexist,
-				u8 *ppre_bt_rssi_state, u8 level_num,
-				 u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = *ppre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return *ppre_bt_rssi_state;
-		}
-
-		if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-			(*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	*ppre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-u8 halbtc8821c2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 *pprewifi_rssi_state, IN u8 level_num, IN u8 rssi_thresh,
-				   IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = *pprewifi_rssi_state;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((*pprewifi_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return *pprewifi_rssi_state;
-		}
-
-		if ((*pprewifi_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((*pprewifi_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-			(*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	*pprewifi_rssi_state = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-void halbtc8821c2ant_coex_switch_threshold(IN struct btc_coexist *btcoexist,
-		IN u8 isolation_measuared)
-{
-	s8	interference_wl_tx = 0, interference_bt_tx = 0;
-
-
-	interference_wl_tx = BT_8821C_2ANT_WIFI_MAX_TX_POWER -
-			     isolation_measuared;
-	interference_bt_tx = BT_8821C_2ANT_BT_MAX_TX_POWER -
-			     isolation_measuared;
-
-
-
-	coex_sta->wifi_coex_thres		 = BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES1;
-	coex_sta->wifi_coex_thres2	 = BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES2;
-
-	coex_sta->bt_coex_thres		 = BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES1;
-	coex_sta->bt_coex_thres2		 = BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES2;
-
-
-	/*
-		coex_sta->wifi_coex_thres		= interference_wl_tx + BT_8821C_2ANT_WIFI_SIR_THRES1;
-		coex_sta->wifi_coex_thres2		= interference_wl_tx + BT_8821C_2ANT_WIFI_SIR_THRES2;
-
-		coex_sta->bt_coex_thres		= interference_bt_tx + BT_8821C_2ANT_BT_SIR_THRES1;
-		coex_sta->bt_coex_thres2		= interference_bt_tx + BT_8821C_2ANT_BT_SIR_THRES2;
-	*/
-
-
-
-
-
-	/*
-		if  ( BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES1 < (isolation_measuared -
-					BT_8821C_2ANT_DEFAULT_ISOLATION) )
-			coex_sta->wifi_coex_thres	 = BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES1;
-		else
-			coex_sta->wifi_coex_thres =  BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES1 -  (isolation_measuared -
-					BT_8821C_2ANT_DEFAULT_ISOLATION);
-
-		if  ( BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES1 < (isolation_measuared -
-					BT_8821C_2ANT_DEFAULT_ISOLATION) )
-			coex_sta->bt_coex_thres	 = BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES1;
-		else
-			coex_sta->bt_coex_thres =  BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES1 -  (isolation_measuared -
-					BT_8821C_2ANT_DEFAULT_ISOLATION);
-
-	*/
-}
-
-
-void halbtc8821c2ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size. */
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-}
-
-void halbtc8821c2ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], No query BT info because BT is disabled!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-void halbtc8821c2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0, cnt_slave = 0, cnt_overhead = 0,
-				cnt_autoslot_hang = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-
-	BTC_TRACE(trace_buf);
-
-	if (BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	    coex_dm->bt_status) {
-
-		if (coex_sta->high_priority_rx >= 15) {
-			if (cnt_overhead < 3)
-				cnt_overhead++;
-
-			if (cnt_overhead == 3)
-				coex_sta->is_hiPri_rx_overhead = TRUE;
-
-		} else {
-			if (cnt_overhead > 0)
-				cnt_overhead--;
-
-			if (cnt_overhead == 0)
-				coex_sta->is_hiPri_rx_overhead = FALSE;
-		}
-	} else
-		coex_sta->is_hiPri_rx_overhead = FALSE;
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	if ((coex_sta->low_priority_tx > 1150)	&&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	if ((coex_sta->low_priority_rx >= 1150) &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx)
-	    && (!coex_sta->under_ips)
-	    && (!coex_sta->c2h_bt_inquiry_page)
-	    && ((bt_link_info->a2dp_exist) || (bt_link_info->pan_exist))) {
-		if (cnt_slave >= 2) {
-			bt_link_info->slave_role = TRUE;
-			cnt_slave = 2;
-		} else
-			cnt_slave++;
-	} else {
-		if (cnt_slave == 0)	{
-			bt_link_info->slave_role = FALSE;
-			cnt_slave = 0;
-		} else
-			cnt_slave--;
-	}
-
-	if (coex_sta->is_tdma_btautoslot) {
-		if ((coex_sta->low_priority_tx >= 1300) &&
-		(coex_sta->low_priority_rx <= 150)) {
-			if (cnt_autoslot_hang >= 2) {
-				coex_sta->is_tdma_btautoslot_hang = TRUE;
-				cnt_autoslot_hang = 2;
-			} else
-				cnt_autoslot_hang++;
-		} else {
-			if (cnt_autoslot_hang == 0)	{
-				coex_sta->is_tdma_btautoslot_hang = FALSE;
-				cnt_autoslot_hang = 0;
-			} else
-				cnt_autoslot_hang--;
-		}
-	}
-
-	if (coex_sta->sco_exist) {
-		if ((coex_sta->high_priority_tx >= 400) &&
-		(coex_sta->high_priority_rx >= 400))
-			coex_sta->is_eSCO_mode = FALSE;
-		else
-			coex_sta->is_eSCO_mode = TRUE;
-	}
-
-	if (bt_link_info->hid_only) {
-		if (coex_sta->low_priority_rx > 50)
-			coex_sta->is_hid_low_pri_tx_overhead = true;
-		else
-			coex_sta->is_hid_low_pri_tx_overhead = false;
-	}
-
-	if (!coex_sta->bt_disabled) {
-
-		if ((coex_sta->high_priority_tx == 0) &&
-		    (coex_sta->high_priority_rx == 0) &&
-		    (coex_sta->low_priority_tx == 0) &&
-		    (coex_sta->low_priority_rx == 0)) {
-			num_of_bt_counter_chk++;
-			if (num_of_bt_counter_chk >= 3) {
-				halbtc8821c2ant_query_bt_info(btcoexist);
-				num_of_bt_counter_chk = 0;
-			}
-		}
-	}
-
-}
-
-
-void halbtc8821c2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-	s32 wifi_rssi = 0;
-	boolean wifi_busy = FALSE, wifi_under_b_mode = FALSE,
-			wifi_scan = FALSE, wifi_connected = FALSE;
-	boolean bt_idle = FALSE, wl_idle = FALSE, is_cck_deadlock = FALSE;
-	static u8 cck_lock_counter = 0, wl_noisy_count0 = 0,
-		  wl_noisy_count1 = 3, wl_noisy_count2 = 0;
-	u32 total_cnt, reg_val1, reg_val2, cnt_cck;
-	u32 cnt_crcok = 0, cnt_crcerr = 0;
-	static u8 cnt = 0, cnt_cal = 0, cnt_ccklocking = 0;
-	u8	h2c_parameter[1] = {0};
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	/* Only enable for windows becaus 8821cu H2C 0x69 unknown fail @ linux */
-	if (btcoexist->chip_interface != BTC_INTF_USB) {
-		/*send h2c to query WL FW dbg info  */
-		if (((coex_dm->cur_ps_tdma_on) && (coex_sta->force_lps_ctrl)) ||
-			 ((coex_sta->acl_busy) && (bt_link_info->a2dp_exist))) {
-			h2c_parameter[0] = 0x8;
-			btcoexist->btc_fill_h2c(btcoexist, 0x69, 1, h2c_parameter);
-		}
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-			   &wifi_under_b_mode);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist,
-						PHYDM_INFO_CRC32_ERROR_VHT);
-
-	cnt_crcok =  coex_sta->crc_ok_cck + coex_sta->crc_ok_11g
-				+ coex_sta->crc_ok_11n
-				+ coex_sta->crc_ok_11n_vht;
-
-	cnt_crcerr =  coex_sta->crc_err_cck + coex_sta->crc_err_11g
-				+ coex_sta->crc_err_11n
-				+ coex_sta->crc_err_11n_vht;
-
-
-	if ((wifi_busy) && (cnt_crcerr != 0)) {
-		if (cnt_cal == 0)
-			coex_sta->cnt_crcok_max_in_10s = 0;
-
-		cnt_cal++;
-
-		if (cnt_crcok > coex_sta->cnt_crcok_max_in_10s)
-			coex_sta->cnt_crcok_max_in_10s = cnt_crcok;
-
-		if (cnt_cal == 5)
-			cnt_cal = 0;
-
-		coex_sta->now_crc_ratio = cnt_crcok/cnt_crcerr;
-
-		if (cnt == 0)
-			coex_sta->acc_crc_ratio = coex_sta->now_crc_ratio;
-		else
-			coex_sta->acc_crc_ratio = (coex_sta->acc_crc_ratio * 7 +
-				coex_sta->now_crc_ratio * 3)/10;
-
-		if (cnt >= 10)
-			cnt = 0;
-		else
-			cnt++;
-	}
-
-	/* CCK lock identification */
-	if (coex_sta->cck_lock)
-		cnt_ccklocking++;
-	else if	(cnt_ccklocking != 0)
-		cnt_ccklocking--;
-
-	if (cnt_ccklocking >= 3) {
-		cnt_ccklocking = 3;
-		coex_sta->cck_lock_ever = TRUE;
-	}
-
-	/* WiFi environment noisy identification */
-	cnt_cck = coex_sta->crc_ok_cck + coex_sta->crc_err_cck;
-
-	if ((!wifi_busy) && (!coex_sta->cck_lock)) {
-		if (cnt_cck > 250) {
-			if (wl_noisy_count2 < 3)
-				wl_noisy_count2++;
-
-			if (wl_noisy_count2 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count1 = 0;
-			}
-
-		} else if (cnt_cck < 50) {
-			if (wl_noisy_count0 < 3)
-				wl_noisy_count0++;
-
-			if (wl_noisy_count0 == 3) {
-				wl_noisy_count1 = 0;
-				wl_noisy_count2 = 0;
-			}
-
-		} else {
-			if (wl_noisy_count1 < 3)
-				wl_noisy_count1++;
-
-			if (wl_noisy_count1 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count2 = 0;
-			}
-		}
-
-		if (wl_noisy_count2 == 3)
-			coex_sta->wl_noisy_level = 2;
-		else if (wl_noisy_count1 == 3)
-			coex_sta->wl_noisy_level = 1;
-		else
-			coex_sta->wl_noisy_level = 0;
-	}
-}
-
-void halbtc8821c2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-
-	struct	btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean			bt_hs_on = FALSE;
-	boolean		bt_busy = FALSE;
-
-	coex_sta->num_of_profile = 0;
-
-	/* set link exist status */
-	if (!(coex_sta->bt_info & BT_INFO_8821C_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = FALSE;
-		coex_sta->pan_exist = FALSE;
-		coex_sta->a2dp_exist = FALSE;
-		coex_sta->hid_exist = FALSE;
-		coex_sta->sco_exist = FALSE;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = TRUE;
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_FTP) {
-			coex_sta->pan_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->pan_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_A2DP) {
-			coex_sta->a2dp_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->a2dp_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_HID) {
-			coex_sta->hid_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->hid_exist = FALSE;
-
-		if (coex_sta->bt_info & BT_INFO_8821C_1ANT_B_SCO_ESCO) {
-			coex_sta->sco_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else
-			coex_sta->sco_exist = FALSE;
-
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-	bt_link_info->acl_busy = coex_sta->acl_busy;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = TRUE;
-		bt_link_info->bt_link_exist = TRUE;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = TRUE;
-	else
-		bt_link_info->sco_only = FALSE;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = TRUE;
-	else
-		bt_link_info->a2dp_only = FALSE;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = TRUE;
-	else
-		bt_link_info->pan_only = FALSE;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = TRUE;
-	else
-		bt_link_info->hid_only = FALSE;
-
-	if (coex_sta->bt_info & BT_INFO_8821C_2ANT_B_INQ_PAGE) {
-		coex_dm->bt_status = BT_8821C_2ANT_BT_STATUS_INQ_PAGE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Inq/page!!!\n");
-	} else if (!(coex_sta->bt_info & BT_INFO_8821C_2ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-	} else if (coex_sta->bt_info == BT_INFO_8821C_2ANT_B_CONNECTION) {
-		/* connection exists but no busy */
-		coex_dm->bt_status = BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-	} else if (((coex_sta->bt_info & BT_INFO_8821C_2ANT_B_SCO_ESCO) ||
-		    (coex_sta->bt_info & BT_INFO_8821C_2ANT_B_SCO_BUSY)) &&
-		   (coex_sta->bt_info & BT_INFO_8821C_2ANT_B_ACL_BUSY)) {
-		coex_dm->bt_status = BT_8821C_2ANT_BT_STATUS_ACL_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL SCO busy!!!\n");
-	} else if ((coex_sta->bt_info & BT_INFO_8821C_2ANT_B_SCO_ESCO) ||
-		   (coex_sta->bt_info & BT_INFO_8821C_2ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8821C_2ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-	} else if (coex_sta->bt_info & BT_INFO_8821C_2ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8821C_2ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-	} else {
-		coex_dm->bt_status = BT_8821C_2ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-	}
-
-	BTC_TRACE(trace_buf);
-
-	if ((BT_8821C_2ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8821C_2ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8821C_2ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = TRUE;
-	else
-		bt_busy = FALSE;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-}
-
-void halbtc8821c2ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0}, i;
-	u32			wifi_bw;
-	u8			wifi_central_chnl = 0;
-	u8			wifi_5g_chnl[19] = {120, 124, 128, 132, 136, 140, 144, 149,
-									153, 157, 118, 126, 134, 142, 151, 159,
-									122, 138, 155};
-	u8			bt_skip_cneter_chanl[19] = {2, 8, 17, 26, 34, 42, 51, 62,
-											71, 77, 2, 12, 29, 46, 66, 76,
-											10, 37, 68};
-	u8			bt_skip_span[19] = {4, 8, 8, 10, 8, 10, 8, 8, 10, 4, 4, 16,
-									16, 16, 16, 4, 20, 34, 20};
-	boolean		wifi_under_5g = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (type == BTC_MEDIA_CONNECT) {
-
-		if (!wifi_under_5g) {
-
-			btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-				&wifi_central_chnl);
-
-			h2c_parameter[0] = 0x1;
-			h2c_parameter[1] = wifi_central_chnl;
-
-			if (wifi_bw == BTC_WIFI_BW_HT40)
-				h2c_parameter[2] = 0x30;
-			else
-				h2c_parameter[2] = 0x20;
-		} else {  /* for 5G  */
-
-			wifi_central_chnl =
-				btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x18, 0xfffff) & 0xff;
-
-			for (i = 0; i <= 18; i++) {
-				if (wifi_central_chnl == wifi_5g_chnl[i])
-					break;
-			}
-
-			if (i <= 18) {
-				h2c_parameter[0] = 0x3;
-				h2c_parameter[1] = bt_skip_cneter_chanl[i];
-				h2c_parameter[2] = bt_skip_span[i];
-			}
-
-		}
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-	coex_sta->wl_center_channel = wifi_central_chnl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], para[0:2] = 0x%x 0x%x 0x%x\n",
-				h2c_parameter[0], h2c_parameter[1], h2c_parameter[2]);
-	BTC_TRACE(trace_buf);
-
-}
-
-
-
-
-void halbtc8821c2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,
-		IN u8 dac_swing_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	/* There are several type of dacswing */
-	/* 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 */
-	h2c_parameter[0] = dac_swing_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter);
-}
-
-void halbtc8821c2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,
-			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
-{
-	coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_fw_dac_swing_lvl ==
-		    coex_dm->cur_fw_dac_swing_lvl)
-			return;
-	}
-
-	halbtc8821c2ant_set_fw_dac_swing_level(btcoexist,
-					       coex_dm->cur_fw_dac_swing_lvl);
-
-	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
-}
-
-void halbtc8821c2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				       IN u8 dec_bt_pwr_lvl)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0 - dec_bt_pwr_lvl;
-
-#if 1
-	btcoexist->btc_fill_h2c(btcoexist, 0x62, 1, h2c_parameter);
-#endif
-}
-
-void halbtc8821c2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				IN boolean force_exec, IN u8 dec_bt_pwr_lvl)
-{
-	coex_dm->cur_bt_dec_pwr_lvl = dec_bt_pwr_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_dec_pwr_lvl == coex_dm->cur_bt_dec_pwr_lvl)
-			return;
-	}
-	halbtc8821c2ant_set_fw_dec_bt_pwr(btcoexist,
-					  coex_dm->cur_bt_dec_pwr_lvl);
-
-	coex_dm->pre_bt_dec_pwr_lvl = coex_dm->cur_bt_dec_pwr_lvl;
-}
-
-
-void halbtc8821c2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-
-#if 1
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra ==
-		    coex_dm->cur_low_penalty_ra)
-			return;
-	}
-
-	if (low_penalty_ra)
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 15);
-	else
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-
-#endif
-
-}
-
-
-void halbtc8821c2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,
-					IN boolean enable_auto_report)
-{
-	u8			h2c_parameter[1] = {0};
-
-	h2c_parameter[0] = 0;
-
-	if (enable_auto_report)
-		h2c_parameter[0] |= BIT(0);
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter);
-}
-
-void halbtc8821c2ant_bt_auto_report(IN struct btc_coexist *btcoexist,
-		    IN boolean force_exec, IN boolean enable_auto_report)
-{
-	coex_dm->cur_bt_auto_report = enable_auto_report;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report)
-			return;
-	}
-	halbtc8821c2ant_set_bt_auto_report(btcoexist,
-					   coex_dm->cur_bt_auto_report);
-
-	coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report;
-}
-
-void halbtc8821c2ant_write_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16				bitpos,
-	IN	boolean		state
-)
-{
-
-	static u16 originalval = 0x8002, preval = 0x0;
-
-	if (state)
-		originalval = originalval | bitpos;
-	else
-		originalval = originalval & (~bitpos);
-
-	coex_sta->score_board_WB = originalval;
-
-	if (originalval != preval) {
-
-		preval = originalval;
-		btcoexist->btc_write_2byte(btcoexist, 0xaa, originalval);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8821c2ant_write_score_board: return for nochange\n");
-		BTC_TRACE(trace_buf);
-	}
-}
-
-
-void halbtc8821c2ant_read_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN   u16				*score_board_val
-)
-{
-
-	*score_board_val = (btcoexist->btc_read_2byte(btcoexist,
-			    0xaa)) & 0x7fff;
-}
-
-
-void halbtc8821c2ant_post_state_to_bt(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16						type,
-	IN  boolean                 state
-)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], halbtc8821c2ant_post_state_to_bt: type = %d, state =%d\n",
-		type, state);
-	BTC_TRACE(trace_buf);
-
-	halbtc8821c2ant_write_score_board(btcoexist, (u16) type, state);
-}
-
-
-boolean halbtc8821c2ant_is_wifibt_status_changed(IN struct btc_coexist
-		*btcoexist)
-{
-	static boolean	pre_wifi_busy = FALSE, pre_under_4way = FALSE,
-			pre_bt_hs_on = FALSE, pre_bt_off = FALSE,
-			pre_bt_slave = FALSE, pre_hid_low_pri_tx_overhead = FALSE,
-			pre_wifi_under_lps = FALSE, pre_bt_setup_link = FALSE,
-			pre_cck_lock = FALSE, pre_cck_lock_warn = FALSE;
-	static u8 pre_hid_busy_num = 0, pre_wl_noisy_level = 0;
-	boolean wifi_busy = FALSE, under_4way = FALSE, bt_hs_on = FALSE;
-	boolean wifi_connected = FALSE;
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (coex_sta->bt_disabled != pre_bt_off) {
-		pre_bt_off = coex_sta->bt_disabled;
-
-		if (coex_sta->bt_disabled)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is enabled !!\n");
-
-		BTC_TRACE(trace_buf);
-
-		coex_sta->bt_coex_supported_feature = 0;
-		coex_sta->bt_coex_supported_version = 0;
-		coex_sta->bt_ble_scan_type = 0;
-		coex_sta->bt_ble_scan_para[0] = 0;
-		coex_sta->bt_ble_scan_para[1] = 0;
-		coex_sta->bt_ble_scan_para[2] = 0;
-		coex_sta->bt_reg_vendor_ac = 0xffff;
-		coex_sta->bt_reg_vendor_ae = 0xffff;
-		return TRUE;
-	}
-
-
-	if (wifi_connected) {
-#if 0
-		if ((wifi_busy) &&
-			(coex_dm->bt_status ==  BT_8821C_2ANT_BT_STATUS_ACL_BUSY))
-			halbtc8821c2ant_post_state_to_bt(btcoexist,
-						BT_8821C_2ANT_SCOREBOARD_UNDERTEST, TRUE);
-		else
-			halbtc8821c2ant_post_state_to_bt(btcoexist,
-						BT_8821C_2ANT_SCOREBOARD_UNDERTEST, FALSE);
-#endif
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return TRUE;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return TRUE;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return TRUE;
-		}
-		if (coex_sta->wl_noisy_level != pre_wl_noisy_level) {
-			pre_wl_noisy_level = coex_sta->wl_noisy_level;
-			return TRUE;
-		}
-		if (coex_sta->under_lps != pre_wifi_under_lps) {
-			pre_wifi_under_lps = coex_sta->under_lps;
-			if (coex_sta->under_lps == TRUE)
-				return TRUE;
-		}
-		if (coex_sta->cck_lock != pre_cck_lock) {
-			pre_cck_lock = coex_sta->cck_lock;
-			return TRUE;
-		}
-		if (coex_sta->cck_lock_warn != pre_cck_lock_warn) {
-			pre_cck_lock_warn = coex_sta->cck_lock_warn;
-			return TRUE;
-		}
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->hid_busy_num != pre_hid_busy_num) {
-			pre_hid_busy_num = coex_sta->hid_busy_num;
-			return TRUE;
-		}
-
-		if (bt_link_info->slave_role != pre_bt_slave) {
-			pre_bt_slave = bt_link_info->slave_role;
-			return TRUE;
-		}
-
-		if (pre_hid_low_pri_tx_overhead != coex_sta->is_hid_low_pri_tx_overhead) {
-			pre_hid_low_pri_tx_overhead = coex_sta->is_hid_low_pri_tx_overhead;
-			return TRUE;
-		}
-
-		if (pre_bt_setup_link != coex_sta->is_setupLink) {
-			pre_bt_setup_link = coex_sta->is_setupLink;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-void halbtc8821c2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = TRUE, bt_disabled = FALSE, wifi_under_5g = FALSE;
-	u16			u16tmp;
-
-	/* This function check if bt is disabled */
-#if 0
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = FALSE;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = FALSE;
-
-
-#else
-
-	/* Read BT on/off status from scoreboard[1], enable this only if BT patch support this feature */
-	halbtc8821c2ant_read_score_board(btcoexist,	&u16tmp);
-
-	bt_active = u16tmp & BIT(1);
-
-
-#endif
-
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = FALSE;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	} else {
-
-		bt_disable_cnt++;
-		if (bt_disable_cnt >= 2) {
-			bt_disabled = TRUE;
-			bt_disable_cnt = 2;
-		}
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((wifi_under_5g) || (bt_disabled))
-		halbtc8821c2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-	else
-		halbtc8821c2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
-
-
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-	}
-
-}
-
-void halbtc8821c2ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
-					boolean isenable)
-{
-#if BT_8821C_2ANT_COEX_DBG
-	static u8			bitVal[5] = {0, 0, 0, 0, 0};
-	static boolean		state = FALSE;
-	/*
-		if (state ==isenable)
-			return;
-		else
-			state = isenable;
-	*/
-	if (isenable) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], enable_gnt_to_gpio!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* enable GNT_WL, GNT_BT to GPIO for debug */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x1);
-
-		/* store original value */
-		bitVal[0] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x66) & BIT(4)) >> 4;	/*0x66[4] */
-		bitVal[1] = (btcoexist->btc_read_1byte(btcoexist,
-					       0x67) & BIT(0));		/*0x66[8] */
-		bitVal[2] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x42) & BIT(3)) >> 3;  /*0x40[19] */
-		bitVal[3] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x65) & BIT(7)) >> 7;  /*0x64[15] */
-		bitVal[4] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x72) & BIT(2)) >> 2;  /*0x70[18] */
-
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   0x0);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   0x0);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-						   0x0);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-						   0x0);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-						   0x0);  /*0x70[18] = 0 */
-
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], disable_gnt_to_gpio!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x0);
-
-		/*  Restore original value */
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   bitVal[0]);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   bitVal[1]);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-					   bitVal[2]);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-					   bitVal[3]);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-					   bitVal[4]);  /*0x70[18] = 0 */
-	}
-
-#endif
-}
-
-u32 halbtc8821c2ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
-		IN u16 reg_addr)
-{
-	u32 j = 0, delay_count = 0;
-
-	while (1) {
-		if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-			delay_ms(50);
-			delay_count++;
-			if (delay_count >= 10) {
-				delay_count = 0;
-				break;
-			}
-		} else
-			break;
-	}
-
-	/* wait for ready bit before access 0x1700		 */
-	btcoexist->btc_write_4byte(btcoexist, 0x1700, 0x800F0000 | reg_addr);
-
-	return btcoexist->btc_read_4byte(btcoexist,
-					 0x1708);  /* get read data */
-
-}
-
-void halbtc8821c2ant_ltecoex_indirect_write_reg(IN struct btc_coexist
-		*btcoexist,
-		IN u16 reg_addr, IN u32 bit_mask, IN u32 reg_value)
-{
-	u32 val, i = 0, j = 0, bitpos = 0, delay_count = 0;
-
-
-	if (bit_mask == 0x0)
-		return;
-	if (bit_mask == 0xffffffff) {
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else
-				break;
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   reg_value); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-	} else {
-		for (i = 0; i <= 31; i++) {
-			if (((bit_mask >> i) & 0x1) == 0x1) {
-				bitpos = i;
-				break;
-			}
-		}
-
-		/* read back register value before write */
-		val = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-				reg_addr);
-		val = (val & (~bit_mask)) | (reg_value << bitpos);
-
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else
-				break;
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   val); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-	}
-
-}
-
-void halbtc8821c2ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
-				    IN boolean enable)
-{
-	u8 val;
-
-	val = (enable) ? 1 : 0;
-	halbtc8821c2ant_ltecoex_indirect_write_reg(btcoexist, 0x38, 0x80,
-			val);  /* 0x38[7] */
-
-}
-
-void halbtc8821c2ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_control)
-{
-	u8 val;
-
-	val = (wifi_control) ? 1 : 0;
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x4,
-					   val); /* 0x70[26] */
-
-}
-
-void halbtc8821c2ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, val_orig = 0;
-
-	if (!sw_control)
-		val = 0x0;
-	else if (state & 0x1)
-		val = 0x3;
-	else
-		val = 0x1;
-
-	val_orig = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-
-	switch (control_block) {
-	case BT_8821C_2ANT_GNT_BLOCK_RFC_BB:
-	default:
-		val = ((val << 14) | (val << 10)) | (val_orig & 0xffff33ff);
-		break;
-	case BT_8821C_2ANT_GNT_BLOCK_RFC:
-		val = (val << 14) | (val_orig & 0xffff3fff);
-		break;
-	case BT_8821C_2ANT_GNT_BLOCK_BB:
-		val = (val << 10) | (val_orig & 0xfffff3ff);
-		break;
-	}
-
-	halbtc8821c2ant_ltecoex_indirect_write_reg(btcoexist,
-			0x38, 0xffffffff, val);
-}
-
-void halbtc8821c2ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, val_orig = 0;
-
-	if (!sw_control)
-		val = 0x0;
-	else if (state & 0x1)
-		val = 0x3;
-	else
-		val = 0x1;
-
-	val_orig = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-
-	switch (control_block) {
-	case BT_8821C_2ANT_GNT_BLOCK_RFC_BB:
-	default:
-		val = ((val << 12) | (val << 8)) | (val_orig & 0xffffccff);
-		break;
-	case BT_8821C_2ANT_GNT_BLOCK_RFC:
-		val = (val << 12) | (val_orig & 0xffffcfff);
-		break;
-	case BT_8821C_2ANT_GNT_BLOCK_BB:
-		val = (val << 8) | (val_orig & 0xfffffcff);
-		break;
-	}
-
-	halbtc8821c2ant_ltecoex_indirect_write_reg(btcoexist,
-			0x38, 0xffffffff, val);
-}
-
-void halbtc8821c2ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u16 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8821C_2ANT_CTT_WL_VS_LTE:
-		reg_addr = 0xa0;
-		break;
-	case BT_8821C_2ANT_CTT_BT_VS_LTE:
-		reg_addr = 0xa4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8821c2ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xffff, table_content); /* 0xa0[15:0] or 0xa4[15:0] */
-
-
-}
-
-
-void halbtc8821c2ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u8 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8821C_2ANT_LBTT_WL_BREAK_LTE:
-		reg_addr = 0xa8;
-		break;
-	case BT_8821C_2ANT_LBTT_BT_BREAK_LTE:
-		reg_addr = 0xac;
-		break;
-	case BT_8821C_2ANT_LBTT_LTE_BREAK_WL:
-		reg_addr = 0xb0;
-		break;
-	case BT_8821C_2ANT_LBTT_LTE_BREAK_BT:
-		reg_addr = 0xb4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8821c2ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xff, table_content); /* 0xa8[15:0] or 0xb4[15:0] */
-
-
-}
-
-void halbtc8821c2ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
-{
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
-
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
-	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
-			return;
-	}
-
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-
-
-void halbtc8821c2ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-void halbtc8821c2ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8821c2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-void halbtc8821c2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	u32	break_table;
-	u8	select_table;
-
-	coex_sta->coex_table_type = type;
-
-	if (coex_sta->concurrent_rx_mode_on == TRUE) {
-		break_table = 0xf0ffffff;  /* set WL hi-pri can break BT */
-		select_table =
-			0xb;		/* set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS) */
-	} else {
-		break_table = 0xffffff;
-		select_table = 0x3;
-	}
-
-	switch (type) {
-	case 0:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0xffffffff, 0xffffffff, break_table, select_table);
-		break;
-	case 1:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0xfafafafa, break_table, select_table);
-		break;
-	case 2:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0x5a5a5a5a, 0x5a5a5a5a, break_table, select_table);
-		break;
-	case 3:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0x5a5a5a5a, break_table, select_table);
-		break;
-	case 4:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0xffff55ff, 0xfafafafa, break_table, select_table);
-		break;
-	case 5:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0x55555555, break_table, select_table);
-		break;
-	case 6:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0xaaffffaa, 0xfafafafa, break_table, select_table);
-		break;
-	case 7:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0xaaffffaa, 0xfafafafa, break_table, select_table);
-		break;
-	case 8:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0xffff55ff, 0xfafafafa, break_table, select_table);
-		break;
-	case 9:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0x5a5a5a5a, 0xaaaa5aaa, break_table, select_table);
-		break;
-	case 10:
-		halbtc8821c2ant_coex_table(btcoexist, force_exec,
-			   0xaaaaaaaa, 0xaaaaaaaa, break_table, select_table);
-		break;
-	default:
-		break;
-	}
-}
-
-void halbtc8821c2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (enable) {
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-	}
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-void halbtc8821c2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8821c2ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-void halbtc8821c2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-void halbtc8821c2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8821c2ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-void halbtc8821c2ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0, 0, 0, 0x40, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-boolean halbtc8821c2ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = FALSE, result = TRUE;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		coex_sta->force_lps_ctrl = FALSE;
-		/* recover to original 32k low power setting */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c2ant_power_save_state == BTC_PS_WIFI_NATIVE\n");
-		BTC_TRACE(trace_buf);
-
-		low_pwr_disable = FALSE;
-		/* btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable); */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_PRE_NORMAL_LPS,
-				   NULL);
-		break;
-	case BTC_PS_LPS_ON:
-		coex_sta->force_lps_ctrl = TRUE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c2ant_power_save_state == BTC_PS_LPS_ON\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, TRUE);
-		halbtc8821c2ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = TRUE;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma.			 */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		break;
-	case BTC_PS_LPS_OFF:
-		coex_sta->force_lps_ctrl = TRUE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c2ant_power_save_state == BTC_PS_LPS_OFF\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, FALSE);
-		result = btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		break;
-	default:
-		break;
-	}
-
-	return result;
-}
-
-
-
-void halbtc8821c2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean		ap_enable = FALSE, result = FALSE;
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	u8		ps_type = BTC_PS_WIFI_NATIVE;
-
-	if (byte5 & BIT(2))
-		coex_sta->is_tdma_btautoslot = TRUE;
-	else
-		coex_sta->is_tdma_btautoslot = FALSE;
-
-	/* release bt-auto slot for auto-slot hang is detected!! */
-	if (coex_sta->is_tdma_btautoslot)
-		if ((coex_sta->is_tdma_btautoslot_hang) ||
-			(bt_link_info->slave_role))
-			byte5 = byte5 & 0xfb;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if ((ap_enable) && (byte1 & BIT(4) && !(byte1 & BIT(5)))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c2ant_set_fw_pstdma == FW for AP mode\n");
-		BTC_TRACE(trace_buf);
-
-		real_byte1 &= ~BIT(4);
-		real_byte1 |= BIT(5);
-
-		real_byte5 |= BIT(5);
-		real_byte5 &= ~BIT(6);
-
-		ps_type = BTC_PS_WIFI_NATIVE;
-		halbtc8821c2ant_power_save_state(btcoexist,
-					 ps_type, 0x0, 0x0);
-	} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c2ant_set_fw_pstdma == Force LPS Leave (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-
-		ps_type = BTC_PS_LPS_OFF;
-		if (!halbtc8821c2ant_power_save_state(btcoexist, ps_type, 0x50, 0x4))
-			result = TRUE;
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c2ant_set_fw_pstdma == Native LPS (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-
-		ps_type = BTC_PS_WIFI_NATIVE;
-		halbtc8821c2ant_power_save_state(btcoexist, ps_type, 0x0, 0x0);
-	}
-
-	coex_sta->is_set_ps_state_fail = result;
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		h2c_parameter[0] = real_byte1;
-		h2c_parameter[1] = byte2;
-		h2c_parameter[2] = byte3;
-		h2c_parameter[3] = byte4;
-		h2c_parameter[4] = real_byte5;
-
-		coex_dm->ps_tdma_para[0] = real_byte1;
-		coex_dm->ps_tdma_para[1] = byte2;
-		coex_dm->ps_tdma_para[2] = byte3;
-		coex_dm->ps_tdma_para[3] = byte4;
-		coex_dm->ps_tdma_para[4] = real_byte5;
-
-		btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-	} else {
-		coex_sta->cnt_set_ps_state_fail++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8821c2ant_set_fw_pstdma == Force Leave LPS Fail (cnt = %d)\n",
-			    coex_sta->cnt_set_ps_state_fail);
-		BTC_TRACE(trace_buf);
-	}
-
-	if (ps_type == BTC_PS_WIFI_NATIVE)
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_POST_NORMAL_LPS, NULL);
-}
-
-void halbtc8821c2ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	static u8			psTdmaByte4Modify = 0x0, pre_psTdmaByte4Modify = 0x0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	/* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-	if ((bt_link_info->slave_role) && (bt_link_info->a2dp_exist))
-		psTdmaByte4Modify = 0x1;
-	else
-		psTdmaByte4Modify = 0x0;
-
-	if (pre_psTdmaByte4Modify != psTdmaByte4Modify) {
-		force_exec = TRUE;
-		pre_psTdmaByte4Modify = psTdmaByte4Modify;
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Skip TDMA because no change TDMA(%s, %d)\n",
-				    (coex_dm->cur_ps_tdma_on ? "on" : "off"),
-				    coex_dm->cur_ps_tdma);
-			BTC_TRACE(trace_buf);
-			return;
-		}
-	}
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-
-	if (turn_on) {
-		switch (type) {
-		case 1:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x91,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 2:
-		default:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11,
-						      0x11 | psTdmaByte4Modify);
-			break;
-		case 3:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x30, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 4:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x21, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 5:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 6:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 7:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x20, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 8:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x15, 0x03, 0x11,
-						      0x11);
-			break;
-		case 10:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x30, 0x03, 0x11,
-						      0x10);
-			break;
-		case 11:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 12:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11, 0x11);
-			break;
-		case 13:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x1c, 0x03, 0x11,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 14:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x20, 0x03, 0x11,
-						      0x11);
-			break;
-		case 15:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x11,
-						      0x14);
-			break;
-		case 16:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x11,
-						      0x15);
-			break;
-		case 21:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x30, 0x03, 0x11,
-						      0x10);
-			break;
-		case 22:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11,
-						      0x10);
-			break;
-		case 23:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-							0x10, 0x03, 0x11,
-							0x10);
-			break;
-		case 51:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 101:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x03, 0x10,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 102:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11,
-						      0x11 | psTdmaByte4Modify);
-			break;
-		case 103:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 104:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x21, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 105:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x45, 0x3, 0x10,
-						      0x50);
-			break;
-		case 106:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x1a, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 107:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x7, 0x10,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 108:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 109:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x03, 0x10,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 110:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x03, 0x10,
-						      0x50);
-			break;
-		case 111:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11,
-						      0x11);
-			break;
-		case 112:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x4a, 0x3, 0x10,
-						      0x50);
-			break;
-		case 115:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x35, 0x3, 0x10,
-						      0x50);
-			break;
-		case 116:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x08, 0x03, 0x10,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 117:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x08, 0x03, 0x10,
-						      0x14 | psTdmaByte4Modify);
-			break;
-		case 119:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x11,
-						      0x14 | psTdmaByte4Modify);
-			break;
-		case 151:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x03, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		}
-	} else {
-		/* disable PS tdma */
-		switch (type) {
-		case 0:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		case 1:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x48, 0x0);
-			break;
-		default:
-			halbtc8821c2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		}
-	}
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		/* update pre state */
-		coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-		coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-	}
-}
-
-void halbtc8821c2ant_set_int_block(IN struct btc_coexist *btcoexist,
-				   IN boolean force_exec,  IN u8 pos_type)
-{
-#if 0
-	u8		regval_0xcba;
-	u32		u32tmp1 = 0;
-
-	coex_dm->cur_int_block_status = pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_int_block_status ==
-		    coex_dm->cur_int_block_status)
-			return;
-	}
-
-	coex_dm->pre_int_block_status = coex_dm->cur_int_block_status;
-
-	regval_0xcba =  btcoexist->btc_read_1byte(btcoexist, 0xcba);
-
-	switch (pos_type) {
-
-	case BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG:
-		regval_0xcba = (regval_0xcba | BIT(0)) & (~(BIT(
-			2)));			/* 0xcb8[16] = 1, 0xcb8[18] = 0, WL_G select BTG */
-		regval_0xcba =   regval_0xcba & 0x0f;
-
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc1d, 0x0f, 0x5); */ /* Gain Table */
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xa9e, 0x0f, 0x2); */ /* CCK Gain Table */
-
-		break;
-	case BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG:
-		regval_0xcba =   regval_0xcba & (~(BIT(2) | BIT(
-			0)));			/* 0xcb8[16] = 0, 0xcb8[18] = 0, WL_G select WLAG */
-
-		/* regval_0xcba = regval_0xcba | BIT(4) | BIT(5) ; */				/* 0xcb8[21:20] = 2b'11, WL_G @ WLAG on */
-		/* regval_0xcba =    (regval_0xcba | BIT(6)) & (~(BIT(7)) ) ; */		/* 0xcb8[23:22] = 2b'01, WL_A @ WLAG off */
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xc1d, 0x0f, 0x0); */ /* Gain Table */
-		/*btcoexist->btc_write_1byte_bitmask(btcoexist, 0xa9e, 0x0f, 0x6); */ /* CCK Gain Table */
-
-		break;
-	case BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG:
-		regval_0xcba =   regval_0xcba & (~(BIT(2) | BIT(
-			0)));			/* 0xcb8[16] = 0, 0xcb8[18] = 0, WL_G select WLAG */
-		/*regval_0xcba =   (regval_0xcba | BIT(4)) & (~(BIT(5))); */			/* 0xcb8[21:20] = 2b'01, WL_G @ WLAG off */
-		/*regval_0xcba = regval_0xcba | BIT(6) | BIT(7); */					/* 0xcb8[23:22] = 2b'11, WL_A @ WLAG on */
-
-		break;
-	}
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcba, 0xff,
-					   regval_0xcba);
-
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcb8);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (After Int Block setup) 0xcb8 = 0x%08x **********\n",
-		    u32tmp1);
-	BTC_TRACE(trace_buf);
-
-#endif
-}
-
-void halbtc8821c2ant_set_ext_band_switch(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 pos_type)
-{
-
-#if 0
-	boolean	switch_polatiry_inverse = FALSE;
-	u8		regval_0xcb6;
-	u32		u32tmp1 = 0, u32tmp2 = 0;
-
-	if (!rfe_type->ext_band_switch_exist)
-		return;
-
-	coex_dm->cur_ext_band_switch_status = pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ext_band_switch_status ==
-		    coex_dm->cur_ext_band_switch_status)
-			return;
-	}
-
-	coex_dm->pre_ext_band_switch_status =
-		coex_dm->cur_ext_band_switch_status;
-
-	/* swap control polarity if use different switch control polarity*/
-	switch_polatiry_inverse = (rfe_type->ext_band_switch_ctrl_polarity == 1
-		   ? ~switch_polatiry_inverse : switch_polatiry_inverse);
-
-	/*swap control polarity for WL_A, default polarity 0xcb4[21] = 0 && 0xcb4[23] = 1 is for WL_G */
-	switch_polatiry_inverse = (pos_type ==
-		BT_8821C_2ANT_EXT_BAND_SWITCH_TO_WLA ? ~switch_polatiry_inverse
-				   : switch_polatiry_inverse);
-
-	regval_0xcb6 =  btcoexist->btc_read_1byte(btcoexist, 0xcb6);
-
-	/* for normal switch polrity, 0xcb4[21] =1 && 0xcb4[23] = 0 for WL_A, vice versa */
-	regval_0xcb6 = (switch_polatiry_inverse == 1 ? ((regval_0xcb6 & (~(BIT(
-		7)))) | BIT(5)) : ((regval_0xcb6 & (~(BIT(5)))) | BIT(7)));
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb6, 0xff,
-					   regval_0xcb6);
-
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcb0);
-	u32tmp2 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (After Ext Band switch setup) 0xcb0 = 0x%08x, 0xcb4 = 0x%08x**********\n",
-		    u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-}
-
-void halbtc8821c2ant_set_ext_ant_switch(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u8 ctrl_type, IN u8 pos_type)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	boolean	switch_polatiry_inverse = FALSE;
-	u8		regval_0xcb7 = 0, regval_0x64;
-	u32		u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-
-	if (!rfe_type->ext_ant_switch_exist)
-		return;
-
-	coex_dm->cur_ext_ant_switch_status = (ctrl_type << 8)  + pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ext_ant_switch_status ==
-		    coex_dm->cur_ext_ant_switch_status)
-			return;
-	}
-
-	coex_dm->pre_ext_ant_switch_status = coex_dm->cur_ext_ant_switch_status;
-
-	/* swap control polarity if use different switch control polarity*/
-	/*  Normal switch polarity for DPDT, 0xcb4[29:28] = 2b'01 => BTG to Main, WLG to Aux,  0xcb4[29:28] = 2b'10 => BTG to Aux, WLG to Main */
-	/*  Normal switch polarity for SPDT, 0xcb4[29:28] = 2b'01 => Ant to BTG,  0xcb4[29:28] = 2b'10 => Ant to WLG */
-	if (rfe_type->ext_ant_switch_ctrl_polarity)
-		switch_polatiry_inverse =  ~switch_polatiry_inverse;
-
-	/* swap control polarity if 1-Ant at Aux */
-	if (rfe_type->ant_at_main_port == FALSE)
-		switch_polatiry_inverse =  ~switch_polatiry_inverse;
-
-	switch (pos_type) {
-	default:
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_BT:
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE:
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLA:
-
-		break;
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLG:
-		if (!rfe_type->wlg_Locate_at_btg)
-			switch_polatiry_inverse =  ~switch_polatiry_inverse;
-
-		break;
-	}
-
-	if (board_info->ant_div_cfg)
-		ctrl_type = BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV;
-
-
-	switch (ctrl_type) {
-	default:
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /*  0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-			0xff, 0x77);	/* BB SW, DPDT use RFE_ctrl8 and RFE_ctrl9 as control pin */
-
-		regval_0xcb7 = (switch_polatiry_inverse == FALSE ?
-			0x1 : 0x2);     /* 0xcb4[29:28] = 2b'01 for no switch_polatiry_inverse, DPDT_SEL_N =1, DPDT_SEL_P =0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb7,
-						   0x30, regval_0xcb7);
-
-		break;
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_PTA:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-			0xff, 0x66);	/* PTA,  DPDT use RFE_ctrl8 and RFE_ctrl9 as control pin */
-
-		regval_0xcb7 = (switch_polatiry_inverse == FALSE ?
-			0x2 : 0x1);     /* 0xcb4[29:28] = 2b'10 for no switch_polatiry_inverse, DPDT_SEL_N =1, DPDT_SEL_P =0  @ GNT_BT=1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb7,
-						   0x30, regval_0xcb7);
-
-		break;
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-						   0xff, 0x88);  /* */
-
-		/* no regval_0xcb7 setup required, because  antenna switch control value by antenna diversity */
-
-		break;
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_MAC:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x1);  /*  0x4c[23] = 1 */
-
-		regval_0x64 = (switch_polatiry_inverse == FALSE ?  0x0 :
-			0x1);     /* 0x64[0] = 1b'0 for no switch_polatiry_inverse, DPDT_SEL_N =1, DPDT_SEL_P =0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1,
-						   regval_0x64);
-		break;
-	case BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x0);  /* 0x4c[24] = 0 */
-
-		/* no  setup required, because  antenna switch control value by BT vendor 0x1c[1:0] */
-		break;
-	}
-
-	/* PAPE, LNA_ON control by BT  while WLAN off for current leakage issue */
-	if (ctrl_type == BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT) {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-					   0x0);  /* PAPE   0x64[29] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x10,
-					   0x0);  /* LNA_ON 0x64[28] = 0 */
-	} else {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-					   0x1);  /* PAPE   0x64[29] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x10,
-					   0x1);  /* LNA_ON 0x64[28] = 1 */
-	}
-
-#if BT_8821C_2ANT_COEX_DBG
-
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp2 = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0x64) & 0xff;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (After Ext Ant switch setup) 0xcb4 = 0x%08x, 0x4c = 0x%08x, 0x64= 0x%02x\n",
-		    u32tmp1, u32tmp2, u32tmp3);
-	BTC_TRACE(trace_buf);
-#endif
-
-}
-
-void halbtc8821c2ant_set_rfe_type(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-
-
-	/* the following setup should be got from Efuse in the future */
-	rfe_type->rfe_module_type = board_info->rfe_type & 0x1f;
-
-	rfe_type->ext_ant_switch_ctrl_polarity = 0;
-
-	switch (rfe_type->rfe_module_type) {
-	case 0:
-	case 8:
-	default:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_USE_DPDT;  /*2-Ant, DPDT, WLG*/
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 1:
-	case 9:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_USE_SPDT;  /*1-Ant, Main, WLG */
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 2:
-	case 10:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_USE_SPDT;  /*1-Ant, Main, BTG */
-		rfe_type->wlg_Locate_at_btg = TRUE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 3:
-	case 11:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_USE_DPDT;  /*1-Ant, Aux, DPDT, WLG */
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = FALSE;
-		break;
-	case 4:
-	case 12:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_USE_DPDT; /*1-Ant, Aux, DPDT, BTG */
-		rfe_type->wlg_Locate_at_btg = TRUE;
-		rfe_type->ant_at_main_port = FALSE;
-		break;
-	case 5:
-	case 13:
-		rfe_type->ext_ant_switch_exist = FALSE; /*2-Ant, no switch, WLG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_NONE;
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 6:
-	case 14:
-		rfe_type->ext_ant_switch_exist = FALSE;   /*2-Ant, no switch, WLG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_NONE;
-		rfe_type->wlg_Locate_at_btg = FALSE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	case 7:
-	case 15:
-		rfe_type->ext_ant_switch_exist = TRUE;	 /*2-Ant, DPDT, BTG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_2ANT_EXT_ANT_SWITCH_USE_DPDT;
-		rfe_type->wlg_Locate_at_btg = TRUE;
-		rfe_type->ant_at_main_port = TRUE;
-		break;
-	}
-
-#if 0
-	if (rfe_type->wlg_Locate_at_btg)
-		halbtc8821c2ant_set_int_block(btcoexist, FORCE_EXEC,
-			      BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG);
-	else
-		halbtc8821c2ant_set_int_block(btcoexist, FORCE_EXEC,
-			      BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG);
-#endif
-
-}
-
-
-void halbtc8821c2ant_set_ant_path(IN struct btc_coexist *btcoexist,
-				  IN u8 ant_pos_type, IN boolean force_exec,
-				  IN u8 phase)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-	u32			cnt_bt_cal_chk = 0;
-	boolean			is_in_mp_mode = FALSE;
-	u8			u8tmp = 0;
-	u32			u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-	u16			u16tmp1 = 0;
-
-	u32tmp1 = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-
-	/* To avoid indirect access fail  */
-	if (((u32tmp1 & 0xf000) >> 12) != ((u32tmp1 & 0x0f00) >> 8)) {
-		force_exec = TRUE;
-		coex_sta->gnt_error_cnt++;
-	}
-
-
-#if BT_8821C_2ANT_COEX_DBG
-
-	u32tmp2 = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-			0x54);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (Before Ant Setup) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    u32tmp3, u8tmp, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-	coex_dm->cur_ant_pos_type = (ant_pos_type << 8)  + phase;
-
-	if (!force_exec) {
-		if (coex_dm->cur_ant_pos_type == coex_dm->pre_ant_pos_type)
-			return;
-	}
-
-	coex_dm->pre_ant_pos_type = coex_dm->cur_ant_pos_type;
-
-
-	switch (phase) {
-	case BT_8821C_2ANT_PHASE_COEX_POWERON:
-
-		/* set Path control owner to WL at initial step */
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8821C_2ANT_PCO_BTSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8821c2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW high */
-		halbtc8821c2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
-			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
-		}
-
-		coex_sta->run_time_state = FALSE;
-
-		break;
-	case BT_8821C_2ANT_PHASE_COEX_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
-		halbtc8821c2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_2ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_2ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-
-		/* Wait If BT IQK running, because Path control owner is at BT during BT IQK (setup by WiFi firmware) */
-		while (cnt_bt_cal_chk <= 20) {
-			u8tmp = btcoexist->btc_read_1byte(
-					btcoexist, 0x49c);
-			cnt_bt_cal_chk++;
-
-			if (u8tmp & BIT(1)) {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### BT is calibrating (wait cnt=%d) ###########\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				delay_ms(50);
-			} else {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** BT is NOT calibrating (wait cnt=%d)**********\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				break;
-			}
-		}
-
-		/* set Path control owner to WL at initial step */
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8821c2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW high */
-		halbtc8821c2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = FALSE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
-			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
-		}
-
-		break;
-	case BT_8821C_2ANT_PHASE_WLANONLY_INIT:
-		/* Disable LTE Coex Function in WiFi side (this should be on if LTE coex is required) */
-		halbtc8821c2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_2ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1 (this should be config if LTE coex is required) */
-		halbtc8821c2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8821C_2ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-		/* set Path control owner to WL at initial step */
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Low */
-		halbtc8821c2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_LOW);
-		/* Set GNT_WL to SW high */
-		halbtc8821c2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = FALSE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
-			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
-		}
-
-		break;
-	case BT_8821C_2ANT_PHASE_WLAN_OFF:
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8821c2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to BT */
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_2ANT_PCO_BTSIDE);
-
-		/* Set Ext Ant Switch to BT control at wifi off step */
-		halbtc8821c2ant_set_ext_ant_switch(btcoexist,
-					FORCE_EXEC,
-					BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT,
-					BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE);
-
-		halbtc8821c2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, TRUE);
-
-		coex_sta->run_time_state = FALSE;
-		break;
-	case BT_8821C_2ANT_PHASE_2G_RUNTIME:
-	case BT_8821C_2ANT_PHASE_2G_RUNTIME_CONCURRENT:
-
-		while (cnt_bt_cal_chk <= 20) {
-			/* 0x49c[0]=1 WL IQK, 0x49c[1]=1 BT IQK*/
-			u8tmp = btcoexist->btc_read_1byte(btcoexist,
-							  0x49c);
-
-			cnt_bt_cal_chk++;
-			if (u8tmp & BIT(0)) {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### WL is IQK (wait cnt=%d)\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				delay_ms(50);
-			} else if (u8tmp & BIT(1)) {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ########### BT is IQK (wait cnt=%d)\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				delay_ms(50);
-			} else {
-				BTC_SPRINTF(trace_buf,
-					    BT_TMP_BUF_SIZE,
-					"[BTCoex], ********** WL and BT is NOT IQK (wait cnt=%d)\n",
-					    cnt_bt_cal_chk);
-				BTC_TRACE(trace_buf);
-				break;
-			}
-		}
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_2ANT_PCO_WLSIDE);
-
-		if (phase ==
-		    BT_8821C_2ANT_PHASE_2G_RUNTIME_CONCURRENT) {
-			/* set GNT_BT to PTA */
-			halbtc8821c2ant_ltecoex_set_gnt_bt(
-				btcoexist,
-				BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8821C_2ANT_GNT_TYPE_CTRL_BY_PTA,
-				BT_8821C_2ANT_SIG_STA_SET_BY_HW);
-
-			/* Set GNT_WL to SW High */
-			halbtc8821c2ant_ltecoex_set_gnt_wl(
-				btcoexist,
-				BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-				BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-		} else {
-			/* set GNT_BT to PTA */
-			halbtc8821c2ant_ltecoex_set_gnt_bt(
-				btcoexist,
-				BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8821C_2ANT_GNT_TYPE_CTRL_BY_PTA,
-				BT_8821C_2ANT_SIG_STA_SET_BY_HW);
-
-			/* Set GNT_WL to PTA */
-			halbtc8821c2ant_ltecoex_set_gnt_wl(
-				btcoexist,
-				BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8821C_2ANT_GNT_TYPE_CTRL_BY_PTA,
-				BT_8821C_2ANT_SIG_STA_SET_BY_HW);
-		}
-		coex_sta->run_time_state = TRUE;
-
-		if (rfe_type->wlg_Locate_at_btg)
-			halbtc8821c2ant_set_int_block(btcoexist,
-						      NORMAL_EXEC,
-				BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG);
-		else
-			halbtc8821c2ant_set_int_block(btcoexist,
-						      NORMAL_EXEC,
-				BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
-			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
-		}
-
-		break;
-	case BT_8821C_2ANT_PHASE_5G_RUNTIME:
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8821c2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_PTA,
-					   BT_8821C_2ANT_SIG_STA_SET_BY_HW);
-
-		/* Set GNT_WL to SW Hi */
-		halbtc8821c2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = TRUE;
-
-		halbtc8821c2ant_set_int_block(btcoexist,
-					      NORMAL_EXEC,
-			      BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG);
-
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
-			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
-		}
-
-
-		break;
-	case BT_8821C_2ANT_PHASE_BTMPMODE:
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8821c2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to WL */
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8821C_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8821c2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-
-		/* Set GNT_WL to SW Lo */
-		halbtc8821c2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_LOW);
-
-		coex_sta->run_time_state = FALSE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
-			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
-		}
-
-		break;
-	case BT_8821C_2ANT_PHASE_ANTENNA_DET:
-		halbtc8821c2ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8821C_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to high */
-		halbtc8821c2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to high */
-		halbtc8821c2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8821C_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8821C_2ANT_SIG_STA_SET_TO_HIGH);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type) {
-			if (board_info->btdm_ant_pos ==
-			    BTC_ANTENNA_AT_MAIN_PORT)
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_MAIN;
-			else
-				ant_pos_type =
-					BTC_ANT_WIFI_AT_AUX;
-		}
-
-		coex_sta->run_time_state = FALSE;
-
-		break;
-	}
-
-	if (phase != BT_8821C_2ANT_PHASE_WLAN_OFF) {
-		switch (ant_pos_type) {
-		default:
-		case BTC_ANT_WIFI_AT_MAIN
-				:
-			halbtc8821c2ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLG);
-			break;
-		case BTC_ANT_WIFI_AT_AUX
-				:
-			halbtc8821c2ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_BT);
-			break;
-		case BTC_ANT_WIFI_AT_DIVERSITY
-				:
-			halbtc8821c2ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV,
-				BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE);
-			break;
-		}
-
-	}
-
-
-
-#if BT_8821C_2ANT_COEX_DBG
-	u32tmp1 = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (After Ant-Setup phase---%d) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    phase, u32tmp3, u8tmp, u32tmp1, u32tmp2);
-
-	BTC_TRACE(trace_buf);
-#endif
-
-}
-
-
-u8 halbtc8821c2ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = FALSE;
-	u8				algorithm = BT_8821C_2ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 0) {
-
-		if (bt_link_info->acl_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], No-Profile busy\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8821C_2ANT_COEX_ALGO_NOPROFILEBUSY;
-		}
-	} else if ((bt_link_info->a2dp_exist) && (coex_sta->is_bt_a2dp_sink)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], A2DP Sink\n");
-		BTC_TRACE(trace_buf);
-		algorithm = BT_8821C_2ANT_COEX_ALGO_A2DPSINK;
-	} else if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8821C_2ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_2ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_2ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + A2DP ==> A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821C_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				{
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8821C_2ANT_COEX_ALGO_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], SCO + HID + A2DP ==> HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8821C_2ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-
-
-void halbtc8821c2ant_action_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* fw all off */
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-}
-
-void halbtc8821c2ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-}
-
-void halbtc8821c2ant_action_bt_hs(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	}
-
-}
-
-
-void halbtc8821c2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-
-	boolean	wifi_connected = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE;
-	boolean			wifi_busy = FALSE;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-	if ((coex_sta->bt_create_connection) && ((wifi_link) || (wifi_roam)
-		|| (wifi_scan) || (wifi_busy) || (coex_sta->wifi_is_high_pri_task))) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi link/roam/Scan/busy/hi-pri-task + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     8);
-
-		if ((bt_link_info->a2dp_exist) && (!bt_link_info->pan_exist))
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						15);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						11);
-	}  else if ((!wifi_connected) && (!wifi_scan)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi no-link + no-scan + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (bt_link_info->pan_exist) {
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-	} else if (bt_link_info->a2dp_exist) {
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-	} else {
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		if ((wifi_link) || (wifi_roam) || (wifi_scan) || (wifi_busy)
-			|| (coex_sta->wifi_is_high_pri_task))
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 23);
-	}
-
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-}
-
-
-void halbtc8821c2ant_action_bt_relink(IN struct btc_coexist *btcoexist)
-{
-	if (coex_sta->is_bt_multi_link == TRUE)
-		return;
-
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-}
-
-
-void halbtc8821c2ant_action_bt_idle(IN struct btc_coexist *btcoexist)
-{
-
-	boolean			wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_busy) {
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 8);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 14);
-	} else {  /* if wl busy */
-
-		if (BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-#if 0
-			/* for Lenovo WL throughput rainning issue while BT non-connect-idle */
-			if ((btcoexist->board_info.customerID == RT_CID_LENOVO_CHINA) &&
-				(coex_sta->scan_ap_num <= 5))
-				halbtc8821c2ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC, 10);
-			else
-#endif
-			halbtc8821c2ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC, 0);
-
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		} else {
-
-			halbtc8821c2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC,
-							     8);
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						12);
-		}
-	}
-
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-}
-
-
-/* SCO only or SCO+PAN(HS) */
-void halbtc8821c2ant_action_sco(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean			wifi_busy = FALSE;
-	u32  wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-		&pre_bt_rssi_state, 2,
-		coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-		&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	}  else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		if (coex_sta->is_eSCO_mode)
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		else  /* 2-Ant free run if SCO mode */
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-	}
-
-}
-
-
-void halbtc8821c2ant_action_hid(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE;
-	u32  wifi_bw = 1;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,  &wifi_bw);
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			 coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	}  else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		if (coex_sta->is_hid_low_pri_tx_overhead) {
-
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 108);
-		} else if (wifi_bw == 0) {   /* if 11bg mode */
-
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 111);
-		} else {
-
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 111);
-		}
-	}
-
-}
-
-void halbtc8821c2ant_action_a2dpsink(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean wifi_busy = FALSE, wifi_turbo = FALSE;
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-			coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 1);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 115);
-	}
-
-}
-
-
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-void halbtc8821c2ant_action_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-
-	static u8	prewifi_rssi_state3 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state3 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state3, bt_rssi_state3;
-
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	wifi_rssi_state3 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state3, 2,
-			   40, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-	bt_rssi_state3 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state3, 2,
-			50, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 1);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-	} else {
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 101);
-	}
-
-}
-
-void halbtc8821c2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-	static u8	prewifi_rssi_state3 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state3 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state3, bt_rssi_state3;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &coex_sta->scan_ap_num);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	wifi_rssi_state3 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state3, 2,
-			   58, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-	bt_rssi_state3 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state3, 2,
-			47, 0);
-
-#if 0
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-#endif
-
-
-#if 1
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 3);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 4);
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		/* for Lenovo CPT_For_WiFi OPP test  */
-		if ((btcoexist->board_info.customerID == RT_CID_LENOVO_CHINA) &&
-			BTC_RSSI_HIGH(wifi_rssi_state3) && (wifi_busy)) {
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 112);
-		} else {
-
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-			if (wifi_busy)
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 103);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 104);
-		}
-	}
-
-#endif
-
-}
-
-void halbtc8821c2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-
-	static u8	prewifi_rssi_state3 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state3;
-
-	boolean	wifi_busy = FALSE;
-	u32  wifi_bw = 1;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	wifi_rssi_state3 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state3, 2,
-			   45, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 1);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		if (coex_sta->hid_pair_cnt > 1) {
-			if (BTC_RSSI_HIGH(wifi_rssi_state3))
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 117);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 116);
-		} else {
-			if (BTC_RSSI_HIGH(wifi_rssi_state3))
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 119);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 109);
-		}
-	}
-
-}
-
-
-void halbtc8821c2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy) {
-
-			if ((coex_sta->a2dp_bit_pool > 40) &&
-			    (coex_sta->a2dp_bit_pool < 255))
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 7);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-		} else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
-
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-		if (wifi_busy) {
-
-			if ((coex_sta->a2dp_bit_pool > 40) &&
-			    (coex_sta->a2dp_bit_pool < 255))
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 107);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 105);
-		} else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 106);
-
-	}
-
-}
-
-
-
-/* PAN(EDR)+A2DP */
-void halbtc8821c2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-
-	static u8	prewifi_rssi_state3 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state3 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state3, bt_rssi_state3;
-
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	wifi_rssi_state3 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state3, 2,
-			   40, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-	bt_rssi_state3 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state3, 2,
-			45, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy) {
-
-			if (((coex_sta->a2dp_bit_pool > 40) &&
-			     (coex_sta->a2dp_bit_pool < 255)) ||
-			    (!coex_sta->is_A2DP_3M))
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 7);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-		} else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		/* for Lenovo coex test case    */
-		if ((btcoexist->board_info.customerID == RT_CID_LENOVO_CHINA) &&
-			(coex_sta->scan_ap_num <= 10)) {
-
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-			/* for CPT_for_WiFi   */
-			if (BTC_RSSI_HIGH(bt_rssi_state3) && BTC_RSSI_LOW(wifi_rssi_state3)) {
-				halbtc8821c2ant_dec_bt_pwr(btcoexist, FORCE_EXEC, 10);
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 105);
-			} else {  /* for CPT_for_BT   */
-				halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 107);
-			}
-		} else {
-
-			halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-			halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-			if (wifi_busy)
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 107);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 106);
-		}
-	}
-}
-
-void halbtc8821c2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8	wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE;
-	u32	wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 3);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 4);
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7);
-
-		if (wifi_busy)
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 103);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 104);
-	}
-
-}
-
-/* HID+A2DP+PAN(EDR) */
-void halbtc8821c2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8	wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE;
-	u32	wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8821c2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8821c2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy) {
-
-			if (((coex_sta->a2dp_bit_pool > 40) &&
-			     (coex_sta->a2dp_bit_pool < 255)) ||
-			    (!coex_sta->is_A2DP_3M))
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 7);
-			else
-				halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-		} else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 6);
-	} else {
-
-		halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		if (wifi_busy)
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 107);
-		else
-			halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 106);
-		}
-	}
-
-
-void halbtc8821c2ant_action_wifi_under5g(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8821C_2ANT_PHASE_5G_RUNTIME);
-	/* fw all off */
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-}
-
-void halbtc8821c2ant_action_wifi_native_lps(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-}
-
-void halbtc8821c2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	/* hw all off */
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-}
-void halbtc8821c2ant_action_wifi_linkscan_process(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-	if (bt_link_info->pan_exist)
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-	else if (bt_link_info->a2dp_exist)
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-	else
-		halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-}
-
-void halbtc8821c2ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* fw all off */
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-}
-
-void halbtc8821c2ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-	switch (coex_dm->cur_algorithm) {
-
-	case BT_8821C_2ANT_COEX_ALGO_SCO:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, algorithm = SCO.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_sco(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_HID:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, algorithm = HID.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_hid(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_A2DP:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, algorithm = A2DP.\n");
-		BTC_TRACE(trace_buf);
-
-		/* for A2DP + OPP test but BTinfo is A2DP only in Lenovo test case */
-		if (coex_sta->is_bt_multi_link)
-			halbtc8821c2ant_action_pan_edr_a2dp(btcoexist);
-		else
-			halbtc8821c2ant_action_a2dp(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_A2DPSINK:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, algorithm = A2DP Sink.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_a2dpsink(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_A2DP_PANHS:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_a2dp_pan_hs(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_PANEDR:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_pan_edr(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_PANEDR_A2DP:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_pan_edr_a2dp(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_PANEDR_HID:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_pan_edr_hid(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_hid_a2dp_pan_edr(
-			btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_HID_A2DP:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_hid_a2dp(btcoexist);
-		break;
-	case BT_8821C_2ANT_COEX_ALGO_NOPROFILEBUSY:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Action 2-Ant, algorithm = No-Profile busy.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_bt_idle(btcoexist);
-		break;
-	default:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_coex_all_off(btcoexist);
-		break;
-	}
-
-	coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-
-}
-
-
-void halbtc8821c2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8			algorithm = 0;
-	u32			num_of_wifi_link = 0;
-	u32			wifi_link_status = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean		miracast_plus_bt = FALSE;
-	boolean		scan = FALSE, link = FALSE, roam = FALSE,
-				under_4way = FALSE,
-				wifi_connected = FALSE, wifi_under_5g = FALSE,
-				bt_hs_on = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], under_lps = %d, force_lps_ctrl = %d, acl_busy = %d!!!\n",
-			coex_sta->under_lps, coex_sta->force_lps_ctrl, coex_sta->acl_busy);
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (!coex_sta->run_time_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], return for run_time_state = FALSE !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->freeze_coexrun_by_btinfo) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), return for freeze_coexrun_by_btinfo\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((wifi_under_5g) &&
-		(coex_sta->switch_band_notify_to != BTC_SWITCH_TO_24G) &&
-		(coex_sta->switch_band_notify_to != BTC_SWITCH_TO_24G_NOFORSCAN)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_wifi_under5g(btcoexist);
-		return;
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 2G!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     NORMAL_EXEC,
-					     BT_8821C_2ANT_PHASE_2G_RUNTIME);
-	}
-
-	if ((coex_sta->under_lps) && (!coex_sta->force_lps_ctrl) &&
-		(!coex_sta->acl_busy)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RunCoexistMechanism(), wifi is under LPS !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_wifi_native_lps(btcoexist);
-		return;
-	}
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_bt_whql_test(btcoexist);
-		return;
-	}
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is disabled!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_coex_all_off(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	if ((coex_sta->is_setupLink) &&
-		(coex_sta->bt_relink_downcount != 0)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is re-link !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_bt_relink(btcoexist);
-		return;
-	}
-
-	/* for P2P */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist)
-			miracast_plus_bt = TRUE;
-		else
-			miracast_plus_bt = FALSE;
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-
-		if (scan || link || roam || under_4way) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], scan = %d, link = %d, roam = %d 4way = %d!!!\n",
-				    scan, link, roam, under_4way);
-			BTC_TRACE(trace_buf);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], wifi is under linkscan process + Multi-Port !!\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8821c2ant_action_wifi_linkscan_process(btcoexist);
-		} else
-			halbtc8821c2ant_action_wifi_multi_port(btcoexist);
-
-		return;
-	} else {
-		miracast_plus_bt = FALSE;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (bt_hs_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "############# [BTCoex],  BT Is hs\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_bt_hs(btcoexist);
-		return;
-	}
-
-	if ((BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	     coex_dm->bt_status) ||
-	    (BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE ==
-	     coex_dm->bt_status)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, bt idle!!.\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_action_bt_idle(btcoexist);
-		return;
-	}
-
-	algorithm = halbtc8821c2ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Algorithm = %d\n",
-		    coex_dm->cur_algorithm);
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	if (scan || link || roam || under_4way) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under Link Process !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_wifi_linkscan_process(btcoexist);
-	} else if (wifi_connected) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, wifi connected!!.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_wifi_connected(btcoexist);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, wifi not-connected!!.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8821c2ant_action_wifi_not_connected(btcoexist);
-	}
-}
-
-void halbtc8821c2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8821c2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-
-	halbtc8821c2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8821c2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	coex_sta->pop_event_cnt = 0;
-	coex_sta->cnt_RemoteNameReq = 0;
-	coex_sta->cnt_ReInit = 0;
-	coex_sta->cnt_setupLink = 0;
-	coex_sta->cnt_IgnWlanAct = 0;
-	coex_sta->cnt_Page = 0;
-	coex_sta->cnt_RoleSwitch = 0;
-	coex_sta->switch_band_notify_to = BTC_NOT_SWITCH;
-
-	halbtc8821c2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	/* fw all off */
-	halbtc8821c2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-	halbtc8821c2ant_query_bt_info(btcoexist);
-}
-
-
-void halbtc8821c2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean wifi_only)
-{
-	u8	u8tmp = 0;
-	u32	 vendor;
-	u32				u32tmp0 = 0, u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-	u8 i;
-
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp1 = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (Before Init HW config) 0xcb4 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    u32tmp3, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 2Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	coex_sta->bt_coex_supported_feature = 0;
-	coex_sta->bt_coex_supported_version = 0;
-	coex_sta->bt_ble_scan_type = 0;
-	coex_sta->bt_ble_scan_para[0] = 0;
-	coex_sta->bt_ble_scan_para[1] = 0;
-	coex_sta->bt_ble_scan_para[2] = 0;
-	coex_sta->bt_reg_vendor_ac = 0xffff;
-	coex_sta->bt_reg_vendor_ae = 0xffff;
-	coex_sta->isolation_btween_wb = BT_8821C_2ANT_DEFAULT_ISOLATION;
-	coex_sta->gnt_error_cnt = 0;
-	coex_sta->bt_relink_downcount = 0;
-	coex_sta->is_set_ps_state_fail = FALSE;
-	coex_sta->cnt_set_ps_state_fail = 0;
-	coex_sta->wl_rx_rate = BTC_UNKNOWN;
-
-	for (i = 0; i <= 9; i++)
-		coex_sta->bt_afh_map[i] = 0;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	coex_sta->dis_ver_info_cnt = 0;
-
-	halbtc8821c2ant_coex_switch_threshold(btcoexist,
-					      coex_sta->isolation_btween_wb);
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* BT report packet sample rate	 */
-	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
-
-	/* Init 0x778 = 0x1 for 2-Ant */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* Enable PTA (3-wire function form BT side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
-
-	/* Enable PTA (tx/rx signal form WiFi side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
-
-	/* set GNT_BT=1 for coex table select both */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x763, 0x10, 0x1);
-
-	halbtc8821c2ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-#if 0
-	/* check if WL firmware download ok */
-	/*if (btcoexist->btc_read_1byte(btcoexist, 0x80) == 0xc6)*/
-	halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-
-	/* Enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e,
-			   0x4); /* 0x76e[3] =1, WLAN_Act control by PTA */
-
-	/* WLAN_Tx by GNT_WL  0x950[29] = 0 */
-	/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x20, 0x0); */
-
-	psd_scan->ant_det_is_ant_det_available = TRUE;
-
-	if (coex_sta->is_rf_state_off) {
-
-		halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_WLAN_OFF);
-
-		btcoexist->stop_coex_dm = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  halbtc8821c2ant_init_hw_config (RF Off)**********\n");
-		BTC_TRACE(trace_buf);
-	} else if (wifi_only) {
-		coex_sta->concurrent_rx_mode_on = FALSE;
-		/* Path config	 */
-		/* Set Antenna Path */
-		halbtc8821c2ant_set_ant_path(btcoexist,	BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_WLANONLY_INIT);
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else {
-		/*Set BT polluted packet on for Tx rate adaptive not including Tx retry break by PTA, 0x45c[19] =1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x1);
-
-		coex_sta->concurrent_rx_mode_on = TRUE;
-		/* btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x2, 0x1); */
-
-		/* RF 0x1[1] = 0->Set GNT_WL_RF_Rx always = 1 for con-current Rx, mask Tx only */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x2, 0x0);
-
-		/* Set Antenna Path */
-		halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_COEX_INIT);
-
-		btcoexist->stop_coex_dm = FALSE;
-	}
-
-	halbtc8821c2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-
-	halbtc8821c2ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-}
-
-
-
-/* ************************************************************
- * work around function start with wa_halbtc8821c2ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8821c2ant_
- * ************************************************************ */
-void ex_halbtc8821c2ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x0;
-	u16 u16tmp = 0x0;
-	u32	value = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx Execute 8821c 2-Ant PowerOn Setting xxxxxxxxxxxxxxxx!!\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "Ant Det Finish = %s, Ant Det Number  = %d\n",
-		    (board_info->btdm_ant_det_finish ? "Yes" : "No"),
-		    board_info->btdm_ant_num_by_ant_det);
-	BTC_TRACE(trace_buf);
-
-
-	btcoexist->stop_coex_dm = TRUE;
-	coex_sta->is_rf_state_off = FALSE;
-	psd_scan->ant_det_is_ant_det_available = FALSE;
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write BB Register correctly. */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-
-	/* Check efuse 0xc3[6] for Single Antenna Path */
-	if (board_info->single_ant_path == 0) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  Single Antenna, Antenna at Aux Port\n");
-		BTC_TRACE(trace_buf);
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-
-		u8tmp = 7;
-	} else if (board_info->single_ant_path == 1) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  Single Antenna, Antenna at Main Port\n");
-		BTC_TRACE(trace_buf);
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-
-		u8tmp = 6;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (Power On) single_ant_path  = %d, btdm_ant_pos = %d\n",
-		    board_info->single_ant_path , board_info->btdm_ant_pos);
-	BTC_TRACE(trace_buf);
-
-	/* Setup RF front end type */
-	halbtc8821c2ant_set_rfe_type(btcoexist);
-
-	/* Set Antenna Path to BT side */
-	halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8821C_2ANT_PHASE_COEX_POWERON);
-
-	/* Save"single antenna position" info in Local register setting for FW reading, because FW may not ready at  power on */
-	if (btcoexist->chip_interface == BTC_INTF_PCI)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x3e0, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_USB)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60, u8tmp);
-
-	/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
-	halbtc8821c2ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********  LTE coex Reg 0x38 (Power-On) = 0x%x**********\n",
-		    halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x38));
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********  MAC Reg 0x70/ BB Reg 0xcb4 (Power-On) = 0x%x / 0x%x\n",
-		    btcoexist->btc_read_4byte(btcoexist, 0x70),
-		    btcoexist->btc_read_4byte(btcoexist, 0xcb4));
-	BTC_TRACE(trace_buf);
-
-}
-
-void ex_halbtc8821c2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x4; /* Set BIT2 by default since it's 2ant case */
-
-	/* */
-	/* S0 or S1 setting and Local register setting(By the setting fw can get ant number, S0/S1, ... info) */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and BIT2=0 */
-	if (btcoexist->chip_interface == BTC_INTF_USB) {
-		/* fixed at S0 for USB interface */
-		u8tmp |= 0x1;	/* antenna inverse */
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	} else {
-		/* for PCIE and SDIO interface, we check efuse 0xc3[6] */
-		if (board_info->single_ant_path == 0) {
-		} else if (board_info->single_ant_path == 1) {
-			/* set to S0 */
-			u8tmp |= 0x1;	/* antenna inverse */
-		}
-
-		if (btcoexist->chip_interface == BTC_INTF_PCI)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x3e0,
-							     u8tmp);
-		else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60,
-							     u8tmp);
-	}
-}
-
-
-void ex_halbtc8821c2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8821c2ant_init_hw_config(btcoexist, wifi_only);
-}
-
-void ex_halbtc8821c2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8821c2ant_init_coex_dm(btcoexist);
-}
-void ex_halbtc8821c2ant_display_simple_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info   = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	u8		*cli_buf = btcoexist->cli_buf;
-	u32		bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8	cnt = 0;
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->bt_coex_supported_feature == 0)
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_FEATURE,
-						&coex_sta->bt_coex_supported_feature);
-
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			(coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		if (coex_sta->bt_reg_vendor_ac == 0xffff)
-			coex_sta->bt_reg_vendor_ac = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xac) & 0xffff);
-
-		if (coex_sta->bt_reg_vendor_ae == 0xffff)
-			coex_sta->bt_reg_vendor_ae = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xae) & 0xffff);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-						&bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-		if (coex_sta->num_of_profile > 0) {
-			cnt++;
-
-			if (cnt >= 3) {
-				btcoexist->btc_get_bt_afh_map_from_bt(btcoexist, 0,
-					&coex_sta->bt_afh_map[0]);
-				cnt = 0;
-			}
-		}
-	}
-
-	// BT coex. info.
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n _____[BT Coexist info]____");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n __[Under Manual Control]_");
-	CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n _________________________");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s / 0x%x",
-			   "Ant PG Num/ Mech/ Pos/ RFE",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s/ 0x%x  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos/ RFE",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-
-		if (board_info->btdm_ant_det_finish) {
-
-			if (psd_scan->ant_det_result != 12)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_peak_val);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %d",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_psd_scan_peak_val
-					   / 100);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	bt_coex_ver = (coex_sta->bt_coex_supported_version & 0xff);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-			"CoexVer WL/  BT_Desired/ BT_Report",
-			glcoex_ver_date_8821c_2ant, glcoex_ver_8821c_2ant,
-			glcoex_ver_btdesired_8821c_2ant,
-			bt_coex_ver,
-			(bt_coex_ver == 0xff ? "Unknown" :
-			(coex_sta->bt_disabled ? "BT-disable" :
-			(bt_coex_ver >= glcoex_ver_btdesired_8821c_2ant ?
-			"Match" : "Mis-Match"))));
-	CL_PRINTF(cli_buf);
-
-	// BT status
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s ", "BT status",
-			((coex_sta->bt_disabled) ? ("disabled") :	((
-			coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page")
-			: ((BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			coex_dm->bt_status) ? "non-connected idle" :
-			((BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE ==
-			coex_dm->bt_status) ? "connected-idle" : "busy")))));
-	CL_PRINTF(cli_buf);
-
-	// HW settings
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(Hi-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-		   "0x774(Lo-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx,
-		   (bt_link_info->slave_role ? "(Slave!!)" : (
-		   coex_sta->is_tdma_btautoslot_hang ? "(auto-slot hang!!)" : "")));
-	CL_PRINTF(cli_buf);
-
-}
-
-void ex_halbtc8821c2ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, ps_tdma_case = 0;
-	u32				u32tmp[4];
-	u16				u16tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0;
-	u32			phyver = 0;
-	boolean			lte_coex_on = FALSE;
-	static u8 cnt = 0;
-	u32				ratio_crc, cnt_ok, cnt_err;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->bt_coex_supported_feature == 0)
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_FEATURE,
-						&coex_sta->bt_coex_supported_feature);
-
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			(coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		if (coex_sta->bt_reg_vendor_ac == 0xffff)
-			coex_sta->bt_reg_vendor_ac = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xac) & 0xffff);
-
-		if (coex_sta->bt_reg_vendor_ae == 0xffff)
-			coex_sta->bt_reg_vendor_ae = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xae) & 0xffff);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-						&bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-		if (coex_sta->num_of_profile > 0) {
-			cnt++;
-
-			if (cnt >= 3) {
-				btcoexist->btc_get_bt_afh_map_from_bt(btcoexist, 0,
-					&coex_sta->bt_afh_map[0]);
-				cnt = 0;
-			}
-		}
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s / 0x%x",
-			   "Ant PG Num/ Mech/ Pos/ RFE",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s/ 0x%x  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos/ RFE",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   board_info->rfe_type,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-
-		if (board_info->btdm_ant_det_finish) {
-
-			if (psd_scan->ant_det_result != 12)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_peak_val);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %d",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_psd_scan_peak_val
-					   / 100);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-
-	bt_coex_ver = (coex_sta->bt_coex_supported_version & 0xff);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8821c_2ant, glcoex_ver_8821c_2ant,
-		   glcoex_ver_btdesired_8821c_2ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (coex_sta->bt_disabled ? "BT-disable" :
-		     (bt_coex_ver >= glcoex_ver_btdesired_8821c_2ant ?
-		      "Match" : "Mis-Match"))));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x (RF-Ch = %d)",
-		   "AFH Map to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2], coex_sta->wl_center_channel);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d ",
-		   "Isolation/WL_Thres/BT_Thres",
-		   coex_sta->isolation_btween_wb,
-		   coex_sta->wifi_coex_thres,
-		   coex_sta->bt_coex_thres);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = [%s/ %d dBm/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-			   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page")
-			   : ((BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-
-	if (coex_sta->num_of_profile != 0)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %s%s%s%s%s",
-			   "Profiles",
-			   ((bt_link_info->a2dp_exist) ?
-			   ((coex_sta->is_bt_a2dp_sink) ? "A2DP sink," :
-			    "A2DP,") : ""),
-			   ((bt_link_info->sco_exist) ?  "HFP," : ""),
-			   ((bt_link_info->hid_exist) ?
-			    ((coex_sta->hid_busy_num >= 2) ? "HID(4/18)," :
-			     "HID(2/18),") : ""),
-			   ((bt_link_info->pan_exist) ?  "PAN," : ""),
-			   ((coex_sta->voice_over_HOGP) ? "Voice" : ""));
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = None", "Profiles");
-
-	CL_PRINTF(cli_buf);
-
-
-	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			   "A2DP Rate/Bitpool/Auto_Slot",
-			   ((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
-			   coex_sta->a2dp_bit_pool,
-			   ((coex_sta->is_autoslot) ? "On" : "Off")
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	if (bt_link_info->hid_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "HID PairNum/Forbid_Slot",
-			   coex_sta->hid_pair_cnt,
-			   coex_sta->forbidden_slot
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
-				"Role/RoleSwCnt/IgnWlact/Feature",
-				((bt_link_info->slave_role) ? "Slave" : "Master"),
-				coex_sta->cnt_RoleSwitch,
-				((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
-				coex_sta->bt_coex_supported_feature);
-	CL_PRINTF(cli_buf);
-
-	if ((coex_sta->bt_ble_scan_type & 0x7) != 0x0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			"BLEScan Type/TV/Init/Ble",
-			coex_sta->bt_ble_scan_type,
-			(coex_sta->bt_ble_scan_type & 0x1 ?
-			coex_sta->bt_ble_scan_para[0] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x2 ?
-			coex_sta->bt_ble_scan_para[1] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x4 ?
-			coex_sta->bt_ble_scan_para[2] : 0x0));
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-		   "ReInit/ReLink/IgnWlact/Page/NameReq",
-		   coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-		   coex_sta->cnt_IgnWlanAct,
-		   coex_sta->cnt_Page,
-		   coex_sta->cnt_RemoteNameReq
-		  );
-	CL_PRINTF(cli_buf);
-
-	halbtc8821c2ant_read_score_board(btcoexist,	&u16tmp[0]);
-
-	if ((coex_sta->bt_reg_vendor_ae == 0xffff) ||
-	    (coex_sta->bt_reg_vendor_ac == 0xffff))
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = x/ x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard", u16tmp[0]);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard(B->W)",
-			   ((coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
-			   coex_sta->bt_reg_vendor_ac & 0x3, u16tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	if (coex_sta->num_of_profile > 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %02x%02x%02x%02x %02x%02x%02x%02x %02x%02x",
-			"AFH MAP",
-			coex_sta->bt_afh_map[0],
-			coex_sta->bt_afh_map[1],
-			coex_sta->bt_afh_map[2],
-			coex_sta->bt_afh_map[3],
-			coex_sta->bt_afh_map[4],
-			coex_sta->bt_afh_map[5],
-			coex_sta->bt_afh_map[6],
-			coex_sta->bt_afh_map[7],
-			coex_sta->bt_afh_map[8],
-			coex_sta->bt_afh_map[9]
-			   );
-		CL_PRINTF(cli_buf);
-	}
-
-	for (i = 0; i < BT_INFO_SRC_8821C_2ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8821c_2ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	/* Sw mechanism	 */
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[mechanism] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[Mechanism]============");
-
-	CL_PRINTF(cli_buf);
-
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x (case-%d, %s, %s)",
-		   "TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "TDMA On" : "TDMA Off"),
-		   (coex_dm->is_switch_to_1dot5_ant ? "1.5Ant" : "2Ant"));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d/ 0x%x/ 0x%x/ 0x%x",
-		   "Table/0x6c0/0x6c4/0x6c8",
-		   coex_sta->coex_table_type, u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ %04x",
-		   "0x778/0x6cc/Scoreboard(W->B)",
-		   u8tmp[0], u32tmp[0], coex_sta->score_board_WB);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
-		   "AntDiv/BtCtrlLPS/LPRA/PsFail",
-		   ((board_info->ant_div_cfg) ? "On" : "Off"),
-		   ((coex_sta->force_lps_ctrl) ? "On" : "Off"),
-		   ((coex_dm->cur_low_penalty_ra) ? "On" : "Off"),
-		   coex_sta->cnt_set_ps_state_fail);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "WL_DACSwing/ BT_Dec_Pwr", coex_dm->cur_fw_dac_swing_lvl,
-		   coex_dm->cur_bt_dec_pwr_lvl);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-		   "Null All/Retry/Ack/BT_Empty/BT_Late",
-		   coex_sta->wl_fw_dbg_info[1],
-		   coex_sta->wl_fw_dbg_info[2],
-		   coex_sta->wl_fw_dbg_info[3],
-		   coex_sta->wl_fw_dbg_info[4],
-		   coex_sta->wl_fw_dbg_info[5]);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ?  TRUE : FALSE;
-
-	if (lte_coex_on) {
-
-		u32tmp[0] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa0);
-		u32tmp[1] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa4);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-			   "LTE Coex Table W_L/B_L",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff);
-		CL_PRINTF(cli_buf);
-
-
-		u32tmp[0] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa8);
-		u32tmp[1] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xac);
-		u32tmp[2] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb0);
-		u32tmp[3] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb4);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			   "LTE Break Table W_L/B_L/L_W/L_B",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff,
-			   u32tmp[2] & 0xffff, u32tmp[3] & 0xffff);
-		CL_PRINTF(cli_buf);
-
-	}
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp[1] = halbtc8821c2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s",
-		   "LTE Coex/Path Owner",
-		   ((lte_coex_on) ? "On" : "Off") ,
-		   ((u8tmp[0] & BIT(2)) ? "WL" : "BT"));
-	CL_PRINTF(cli_buf);
-
-	if (lte_coex_on) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %d/ %d",
-			   "LTE 3Wire/OPMode/UART/UARTMode",
-			   (int)((u32tmp[0] & BIT(6)) >> 6),
-			   (int)((u32tmp[0] & (BIT(5) | BIT(4))) >> 4),
-			   (int)((u32tmp[0] & BIT(3)) >> 3),
-			   (int)(u32tmp[0] & (BIT(2) | BIT(1) | BIT(0))));
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "LTE_Busy/UART_Busy",
-			   (int)((u32tmp[1] & BIT(1)) >> 1),
-			   (int)(u32tmp[1] & BIT(0)));
-		CL_PRINTF(cli_buf);
-	}
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %s (BB:%s)/ %s (BB:%s)/ %s %d",
-		   "GNT_WL_Ctrl/GNT_BT_Ctrl/Dbg",
-		   ((u32tmp[0] & BIT(12)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(8)) ?  "SW" : "HW"),
-		   ((u32tmp[0] & BIT(14)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(10)) ?  "SW" : "HW"),
-		   ((u8tmp[0] & BIT(3)) ? "On" : "Off"),
-		   coex_sta->gnt_error_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ 0x%x",
-		   "GNT_WL/GNT_BT/ RF_0x1",
-		   (int)((u32tmp[1] & BIT(2)) >> 2),
-		   (int)((u32tmp[1] & BIT(3)) >> 3),
-		   btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xcb0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xcba);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%04x/ 0x%04x/ 0x%02x %s",
-		   "0xcb0/0xcb4/0xcb8[23:16]",
-		   u32tmp[0], u32tmp[1], u8tmp[0],
-		   ((u8tmp[0] & 0x1) == 0x1 ?  "(BTG)" :   "(WL_A+G)"));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x64);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "4c[24:23]/64[0]/4c6[4]/40[5]",
-		   (u32tmp[0] & (BIT(24) | BIT(23))) >> 23 , u8tmp[2] & 0x1 ,
-		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x953);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0xc50);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ %s/ 0x%x",
-		   "0x550/0x522/4-RxAGC/0xc50",
-		u32tmp[0], u8tmp[0], (u8tmp[1] & 0x2) ? "On" : "Off", u8tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d (Rx_rate Data/RTS= %d/%d)",
-		   "CRC_OK CCK/11g/11n/11ac",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht,
-		   coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d  (Max ok = %d)",
-		   "CRC_Err CCK/11g/11n/11ac",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht,
-		   coex_sta->cnt_crcok_max_in_10s);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %s/ %d",
-		   "HiPr/ Locking/ warn/ Locked/ Noisy",
-		   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-		   (coex_sta->cck_lock ? "Yes" : "No"),
-		   (coex_sta->cck_lock_warn ? "Yes" : "No"),
-		   (coex_sta->cck_lock_ever ? "Yes" : "No"),
-		   coex_sta->wl_noisy_level);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(Hi-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-		   "0x774(Lo-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx,
-		   (bt_link_info->slave_role ? "(Slave!!)" : (
-		   coex_sta->is_tdma_btautoslot_hang ? "(auto-slot hang!!)" : "")));
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8821c2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-	if (type == BTC_IPS_ENTER) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = TRUE;
-		coex_sta->under_lps = FALSE;
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-				BT_8821C_2ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_2ANT_SCOREBOARD_ONOFF |
-				BT_8821C_2ANT_SCOREBOARD_SCAN |
-				BT_8821C_2ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_WLAN_OFF);
-
-		halbtc8821c2ant_action_coex_all_off(btcoexist);
-	} else if (type == BTC_IPS_LEAVE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = FALSE;
-#if 0
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-				 BT_8821C_2ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-
-		halbtc8821c2ant_init_hw_config(btcoexist, FALSE);
-		halbtc8821c2ant_init_coex_dm(btcoexist);
-		halbtc8821c2ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8821c2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	static boolean  pre_force_lps_on = FALSE;
-
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (type == BTC_LPS_ENABLE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = TRUE;
-		coex_sta->under_ips = FALSE;
-
-		if (coex_sta->force_lps_ctrl == TRUE) { /* LPS No-32K */
-			/* Write WL "Active" in Score-board for PS-TDMA */
-			pre_force_lps_on = TRUE;
-			halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		} else { /* LPS-32K, need check if this h2c 0x71 can work?? (2015/08/28) */
-			/* Write WL "Non-Active" in Score-board for Native-PS */
-			pre_force_lps_on = FALSE;
-			halbtc8821c2ant_post_state_to_bt(btcoexist,
-				 BT_8821C_2ANT_SCOREBOARD_ACTIVE, FALSE);
-
-			halbtc8821c2ant_action_wifi_native_lps(btcoexist);
-		}
-
-	} else if (type == BTC_LPS_DISABLE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = FALSE;
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		if ((!pre_force_lps_on) && (!coex_sta->force_lps_ctrl))
-			halbtc8821c2ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8821c2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean	wifi_connected = FALSE;
-	boolean wifi_under_5g = FALSE;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], SCAN notify()\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, &wifi_connected);
-
-	/*  this can't be removed for RF off_on event, or BT would dis-connect */
-	if ((type == BTC_SCAN_START) || (type == BTC_SCAN_START_2G)) {
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					BT_8821C_2ANT_SCOREBOARD_ACTIVE |
-					BT_8821C_2ANT_SCOREBOARD_SCAN |
-					BT_8821C_2ANT_SCOREBOARD_ONOFF,
-					TRUE);
-
-		halbtc8821c2ant_query_bt_info(btcoexist);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((type == BTC_SCAN_START) && (wifi_under_5g)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], SCAN START notify (5G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_action_wifi_under5g(btcoexist);
-	} else if ((type == BTC_SCAN_START_2G) || (type == BTC_SCAN_START)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		if (!wifi_connected)
-			coex_sta->wifi_is_high_pri_task = TRUE;
-
-		halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_2G_RUNTIME);
-
-		halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-
-	} else if (type == BTC_SCAN_FINISH) {
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify  (Scan-AP = %d)\n",
-			    coex_sta->scan_ap_num);
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = FALSE;
-
-		halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-	}
-
-}
-
-void ex_halbtc8821c2ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-
-	boolean wifi_connected = FALSE, bt_hs_on = FALSE;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = FALSE;
-	u8	agg_buf_size = 5;
-
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	coex_sta->switch_band_notify_to = type;
-
-	if (type == BTC_SWITCH_TO_5G) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], switchband_notify ---  switch to 5G\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_action_wifi_under5g(btcoexist);
-
-	} else if (type == BTC_SWITCH_TO_24G_NOFORSCAN) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], switchband_notify --- BTC_SWITCH_TO_2G (no for scan)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], switchband_notify ---  switch to 2G\n");
-		BTC_TRACE(trace_buf);
-
-		ex_halbtc8821c2ant_scan_notify(btcoexist, BTC_SCAN_START_2G);
-	}
-
-	coex_sta->switch_band_notify_to = BTC_NOT_SWITCH;
-}
-
-
-void ex_halbtc8821c2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ACTIVE |
-					 BT_8821C_2ANT_SCOREBOARD_SCAN |
-					 BT_8821C_2ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-
-	if ((type == BTC_ASSOCIATE_5G_START) ||
-	    (type == BTC_ASSOCIATE_5G_FINISH)) {
-
-		if (type == BTC_ASSOCIATE_5G_START)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], connect_notify ---  5G start\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], connect_notify ---  5G finish\n");
-
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_action_wifi_under5g(btcoexist);
-	} else if (type == BTC_ASSOCIATE_START) {
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_2G_RUNTIME);
-
-		halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-
-		/* To keep TDMA case during connect process,
-		to avoid changed by Btinfo and runcoexmechanism */
-		coex_sta->freeze_coexrun_by_btinfo = TRUE;
-
-		coex_dm->arp_cnt = 0;
-
-	} else if (type == BTC_ASSOCIATE_FINISH) {
-
-		coex_sta->wifi_is_high_pri_task = FALSE;
-		coex_sta->freeze_coexrun_by_btinfo = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-	}
-}
-
-void ex_halbtc8821c2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	u8			ap_num = 0;
-	boolean		wifi_under_b_mode = FALSE, wifi_under_5g = FALSE;
-
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (type == BTC_MEDIA_CONNECT) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ACTIVE |
-					 BT_8821C_2ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-
-		if (wifi_under_5g) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], WiFi is under 5G!!!\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8821c2ant_action_wifi_under5g(btcoexist);
-		} else {
-
-			halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-						     FORCE_EXEC,
-						     BT_8821C_2ANT_PHASE_2G_RUNTIME);
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-
-			/* Set CCK Tx/Rx high Pri except 11b mode */
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x00); /* CCK Tx */
-				btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x00); /* CCK Rx */
-			} else {
-
-				btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x00); /* CCK Tx */
-				btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x10); /* CCK Rx */
-			}
-		}
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-				 BT_8821C_2ANT_SCOREBOARD_ACTIVE, FALSE);
-
-		coex_sta->cck_lock_ever = FALSE;
-		coex_sta->cck_lock_warn = FALSE;
-		coex_sta->cck_lock = FALSE;
-	}
-
-
-	halbtc8821c2ant_update_wifi_channel_info(btcoexist, type);
-}
-
-void ex_halbtc8821c2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean under_4way = FALSE, wifi_under_5g = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (wifi_under_5g) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_action_wifi_under5g(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (under_4way) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ---- under_4way!!\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-
-	} else if (type == BTC_PACKET_ARP) {
-
-		coex_dm->arp_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ARP notify -cnt = %d\n",
-			    coex_dm->arp_cnt);
-		BTC_TRACE(trace_buf);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet DHCP or EAPOL notify [Type = %d]\n",
-			    type);
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	}
-
-	if (coex_sta->wifi_is_high_pri_task) {
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_SCAN, TRUE);
-		halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-	}
-
-}
-
-void ex_halbtc8821c2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8			i, rsp_source = 0;
-	boolean			wifi_connected = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE,
-			wifi_busy = FALSE;
-	static boolean is_scoreboard_scan = FALSE;
-
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8821C_2ANT_MAX)
-		rsp_source = BT_INFO_SRC_8821C_2ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt_info[%d], len=%d, data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	coex_sta->bt_info = coex_sta->bt_info_c2h[rsp_source][1];
-	coex_sta->bt_info_ext = coex_sta->bt_info_c2h[rsp_source][4];
-	coex_sta->bt_info_ext2 = coex_sta->bt_info_c2h[rsp_source][5];
-
-	if (BT_INFO_SRC_8821C_2ANT_WIFI_FW != rsp_source) {
-
-		/* if 0xff, it means BT is under WHCK test */
-		coex_sta->bt_whck_test = ((coex_sta->bt_info == 0xff) ? TRUE :
-					  FALSE);
-
-		coex_sta->bt_create_connection = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x80) ? TRUE :
-						  FALSE);
-
-		/* unit: %, value-100 to translate to unit: dBm */
-		coex_sta->bt_rssi = coex_sta->bt_info_c2h[rsp_source][3] * 2 +
-				    10;
-
-		coex_sta->c2h_bt_remote_name_req = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x20) ? TRUE :
-						    FALSE);
-
-		coex_sta->is_A2DP_3M = ((coex_sta->bt_info_c2h[rsp_source][2] &
-					 0x10) ? TRUE : FALSE);
-
-		coex_sta->acl_busy = ((coex_sta->bt_info_c2h[rsp_source][1] &
-				       0x8) ? TRUE : FALSE);
-
-		coex_sta->voice_over_HOGP = ((coex_sta->bt_info_ext & 0x10) ?
-					     TRUE : FALSE);
-
-		coex_sta->c2h_bt_inquiry_page = ((coex_sta->bt_info &
-			  BT_INFO_8821C_2ANT_B_INQ_PAGE) ? TRUE : FALSE);
-
-		coex_sta->a2dp_bit_pool = (((
-			coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) ?
-				   (coex_sta->bt_info_c2h[rsp_source][6] & 0x7f) : 0);
-
-		coex_sta->is_bt_a2dp_sink = (coex_sta->bt_info_c2h[rsp_source][6] & 0x80) ?
-									TRUE : FALSE;
-
-		coex_sta->bt_retry_cnt = coex_sta->bt_info_c2h[rsp_source][2] &
-					 0xf;
-
-		coex_sta->is_autoslot = coex_sta->bt_info_ext2 & 0x8;
-
-		coex_sta->forbidden_slot = coex_sta->bt_info_ext2 & 0x7;
-
-		coex_sta->hid_busy_num = (coex_sta->bt_info_ext2 & 0x30) >> 4;
-
-		coex_sta->hid_pair_cnt = (coex_sta->bt_info_ext2 & 0xc0) >> 6;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->c2h_bt_remote_name_req)
-			coex_sta->cnt_RemoteNameReq++;
-
-		if (coex_sta->bt_info_ext & BIT(1))
-			coex_sta->cnt_ReInit++;
-
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setupLink++;
-			coex_sta->is_setupLink = TRUE;
-			coex_sta->bt_relink_downcount = 2;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link start in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->is_setupLink = FALSE;
-			coex_sta->bt_relink_downcount = 0;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link stop in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(3))
-			coex_sta->cnt_IgnWlanAct++;
-
-		if (coex_sta->bt_info_ext & BIT(6))
-			coex_sta->cnt_RoleSwitch++;
-
-		if (coex_sta->bt_info_ext & BIT(7))
-			coex_sta->is_bt_multi_link = TRUE;
-		else
-			coex_sta->is_bt_multi_link = FALSE;
-
-		if (coex_sta->bt_create_connection) {
-			coex_sta->cnt_Page++;
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY,
-					   &wifi_busy);
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-			if ((wifi_link) || (wifi_roam) || (wifi_scan) ||
-			    (coex_sta->wifi_is_high_pri_task) || (wifi_busy)) {
-
-				is_scoreboard_scan = TRUE;
-				halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_SCAN, TRUE);
-
-			} else
-				halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_SCAN, FALSE);
-
-		} else {
-				if (is_scoreboard_scan) {
-					halbtc8821c2ant_post_state_to_bt(btcoexist,
-						 BT_8821C_2ANT_SCOREBOARD_SCAN, FALSE);
-					is_scoreboard_scan = FALSE;
-				}
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-
-		if ((!btcoexist->manual_control) &&
-		    (!btcoexist->stop_coex_dm)) {
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-
-			/*  Re-Init */
-			if ((coex_sta->bt_info_ext & BIT(1))) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-				BTC_TRACE(trace_buf);
-				if (wifi_connected)
-					halbtc8821c2ant_update_wifi_channel_info(
-						btcoexist, BTC_MEDIA_CONNECT);
-				else
-					halbtc8821c2ant_update_wifi_channel_info(
-						btcoexist,
-						BTC_MEDIA_DISCONNECT);
-			}
-
-
-			/*  If Ignore_WLanAct && not SetUp_Link */
-			if ((coex_sta->bt_info_ext & BIT(3)) &&
-				(!(coex_sta->bt_info_ext & BIT(2))) &&
-				(!(coex_sta->bt_info_ext & BIT(6)))) {
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8821c2ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, FALSE);
-			} else {
-				if (coex_sta->bt_info_ext & BIT(2)) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ignore Wlan active because Re-link!!\n");
-					BTC_TRACE(trace_buf);
-				} else if (coex_sta->bt_info_ext & BIT(6)) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ignore Wlan active because Role-Switch!!\n");
-					BTC_TRACE(trace_buf);
-				}
-			}
-		}
-
-	}
-
-	if ((coex_sta->bt_info_ext & BIT(5))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BT ext info bit4 check, query BLE Scan type!!\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_ble_scan_type = btcoexist->btc_get_ble_scan_type_from_bt(
-						     btcoexist);
-
-		if ((coex_sta->bt_ble_scan_type & 0x1) == 0x1)
-			coex_sta->bt_ble_scan_para[0]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x1);
-		if ((coex_sta->bt_ble_scan_type & 0x2) == 0x2)
-			coex_sta->bt_ble_scan_para[1]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x2);
-		if ((coex_sta->bt_ble_scan_type & 0x4) == 0x4)
-			coex_sta->bt_ble_scan_para[2]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x4);
-	}
-
-	halbtc8821c2ant_update_bt_link_info(btcoexist);
-
-	halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8821c2ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8 i = 0;
-	static u8 tmp_buf_pre[10] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d (len = %d)\n",
-				tmp_buf[0], tmp_buf[1],
-				tmp_buf[2], tmp_buf[3],
-				tmp_buf[4], tmp_buf[5], length);
-	BTC_TRACE(trace_buf);
-
-	if (tmp_buf[0] == 0x8) {
-		for (i = 1; i <= 5; i++) {
-			coex_sta->wl_fw_dbg_info[i] =
-				(tmp_buf[i] >= tmp_buf_pre[i]) ?
-				(tmp_buf[i] - tmp_buf_pre[i]) :
-				(255 - tmp_buf_pre[i] + tmp_buf[i]);
-
-			tmp_buf_pre[i] = tmp_buf[i];
-		}
-	}
-}
-
-
-void ex_halbtc8821c2ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
-		IN BOOLEAN is_data_frame, IN u8 btc_rate_id)
-{
-	BOOLEAN wifi_connected = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	if (is_data_frame) {
-		coex_sta->wl_rx_rate = btc_rate_id;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], rx_rate_change_notify data rate id = %d, RTS_Rate = %d\n",
-			coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate);
-		BTC_TRACE(trace_buf);
-	} else {
-		coex_sta->wl_rts_rx_rate = btc_rate_id;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], rts_rate_change_notify RTS rate id = %d, RTS_Rate = %d\n",
-			coex_sta->wl_rts_rx_rate, coex_sta->wl_rts_rx_rate);
-		BTC_TRACE(trace_buf);
-	}
-
-	if ((wifi_connected) &&
-		((coex_dm->bt_status ==  BT_8821C_2ANT_BT_STATUS_ACL_BUSY) ||
-		(coex_dm->bt_status ==  BT_8821C_2ANT_BT_STATUS_ACL_SCO_BUSY) ||
-		(coex_dm->bt_status == BT_8821C_2ANT_BT_STATUS_SCO_BUSY))) {
-
-		if ((coex_sta->wl_rx_rate == BTC_CCK_5_5) ||
-			(coex_sta->wl_rx_rate == BTC_OFDM_6) ||
-			(coex_sta->wl_rx_rate == BTC_MCS_0)) {
-
-			coex_sta->cck_lock_warn = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck lock warning...\n");
-			BTC_TRACE(trace_buf);
-		} else if ((coex_sta->wl_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rx_rate == BTC_CCK_2) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_1) ||
-			(coex_sta->wl_rts_rx_rate == BTC_CCK_2)) {
-
-			coex_sta->cck_lock = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck locking...\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->cck_lock_warn = FALSE;
-			coex_sta->cck_lock = FALSE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], cck unlock...\n");
-			BTC_TRACE(trace_buf);
-		}
-	} else {
-		if ((coex_dm->bt_status ==
-			BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE) ||
-			(coex_dm->bt_status ==
-			BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE)) {
-			coex_sta->cck_lock_warn = FALSE;
-			coex_sta->cck_lock = FALSE;
-		}
-	}
-
-}
-
-
-
-void ex_halbtc8821c2ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->stop_coex_dm = FALSE;
-		coex_sta->is_rf_state_off = FALSE;
-#if 0
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_WLAN_OFF);
-
-		halbtc8821c2ant_action_coex_all_off(btcoexist);
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-				BT_8821C_2ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_2ANT_SCOREBOARD_ONOFF |
-				BT_8821C_2ANT_SCOREBOARD_SCAN |
-				BT_8821C_2ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		btcoexist->stop_coex_dm = TRUE;
-		coex_sta->is_rf_state_off = TRUE;
-	}
-}
-
-void ex_halbtc8821c2ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8821c2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8821C_2ANT_PHASE_WLAN_OFF);
-
-	ex_halbtc8821c2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	halbtc8821c2ant_post_state_to_bt(btcoexist,
-				BT_8821C_2ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_2ANT_SCOREBOARD_ONOFF |
-				BT_8821C_2ANT_SCOREBOARD_SCAN |
-				BT_8821C_2ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-}
-
-void ex_halbtc8821c2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	boolean wifi_under_5g = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((BTC_WIFI_PNP_SLEEP == pnp_state) ||
-	    (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		/* Sinda 20150819, workaround for driver skip leave IPS/LPS to speed up sleep time. */
-		/* Driver do not leave IPS/LPS when driver is going to sleep, so BTCoexistence think wifi is still under IPS/LPS */
-		/* BT should clear UnderIPS/UnderLPS state to avoid mismatch state after wakeup. */
-		coex_sta->under_ips = FALSE;
-		coex_sta->under_lps = FALSE;
-
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-				BT_8821C_2ANT_SCOREBOARD_ACTIVE |
-				BT_8821C_2ANT_SCOREBOARD_ONOFF |
-				BT_8821C_2ANT_SCOREBOARD_SCAN |
-				BT_8821C_2ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		if (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state) {
-
-			if (wifi_under_5g)
-				halbtc8821c2ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_5G_RUNTIME);
-			else
-				halbtc8821c2ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_2G_RUNTIME);
-		} else {
-
-			halbtc8821c2ant_set_ant_path(btcoexist,
-						     BTC_ANT_PATH_AUTO,
-						     FORCE_EXEC,
-					     BT_8821C_2ANT_PHASE_WLAN_OFF);
-		}
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-#if 0
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-					 BT_8821C_2ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-	}
-}
-
-void ex_halbtc8821c2ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	boolean wifi_busy = FALSE;
-	boolean bt_relink_finish = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ************* Periodical *************\n");
-	BTC_TRACE(trace_buf);
-
-#if (BT_AUTO_REPORT_ONLY_8821C_2ANT == 0)
-	halbtc8821c2ant_query_bt_info(btcoexist);
-#endif
-
-	halbtc8821c2ant_monitor_bt_ctr(btcoexist);
-	halbtc8821c2ant_monitor_wifi_ctr(btcoexist);
-	halbtc8821c2ant_monitor_bt_enable_disable(btcoexist);
-
-#if 0
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* halbtc8821c2ant_read_score_board(btcoexist, &bt_scoreboard_val); */
-
-	if (wifi_busy) {
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-				BT_8821C_2ANT_SCOREBOARD_UNDERTEST, TRUE);
-		/*
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-				BT_8821C_2ANT_SCOREBOARD_WLBUSY, TRUE);
-
-		if (bt_scoreboard_val & BIT(6))
-			halbtc8821c2ant_query_bt_info(btcoexist); */
-	} else {
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-			BT_8821C_2ANT_SCOREBOARD_UNDERTEST, FALSE);
-		/*
-		halbtc8821c2ant_post_state_to_bt(btcoexist,
-			BT_8821C_2ANT_SCOREBOARD_WLBUSY,
-				FALSE);  */
-	}
-#endif
-
-	if (coex_sta->bt_relink_downcount != 0) {
-		coex_sta->bt_relink_downcount--;
-
-		if (coex_sta->bt_relink_downcount == 0) {
-			coex_sta->is_setupLink = FALSE;
-			bt_relink_finish = TRUE;
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Re-Link stop by periodical count-down!!\n");
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	/* for 4-way, DHCP, EAPOL packet */
-	if (coex_sta->specific_pkt_period_cnt > 0) {
-
-		coex_sta->specific_pkt_period_cnt--;
-
-		if ((coex_sta->specific_pkt_period_cnt == 0) &&
-		    (coex_sta->wifi_is_high_pri_task))
-			coex_sta->wifi_is_high_pri_task = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ***************** Hi-Pri Task = %s\n",
-			    (coex_sta->wifi_is_high_pri_task ? "Yes" :
-			     "No"));
-		BTC_TRACE(trace_buf);
-
-	}
-
-	if (halbtc8821c2ant_is_wifibt_status_changed(btcoexist) || (bt_relink_finish)
-		|| (coex_sta->is_set_ps_state_fail))
-		halbtc8821c2ant_run_coexist_mechanism(btcoexist);
-}
-
-
-/*#pragma optimize( "", off )*/
-void ex_halbtc8821c2ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-}
-
-
-void ex_halbtc8821c2ant_display_ant_detection(IN struct btc_coexist *btcoexist)
-{
-
-}
-
-
-#endif
-
-#endif	/*  #if (RTL8821C_SUPPORT == 1) */
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c2ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c2ant.h
deleted file mode 100644
index a690aea337fb..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821c2ant.h
+++ /dev/null
@@ -1,534 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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.
- *
- *****************************************************************************/
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8821C_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8821C 2Ant BT Co-exist definition
- * ******************************************* */
-#define	BT_8821C_2ANT_COEX_DBG					0
-#define	BT_AUTO_REPORT_ONLY_8821C_2ANT				1
-
-
-#define	BT_INFO_8821C_2ANT_B_FTP						BIT(7)
-#define	BT_INFO_8821C_2ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8821C_2ANT_B_HID						BIT(5)
-#define	BT_INFO_8821C_2ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8821C_2ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8821C_2ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8821C_2ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8821C_2ANT_B_CONNECTION				BIT(0)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT		2
-
-
-#define	BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES1				80  /* unit: % WiFi RSSI Threshold for   2-Ant free-run/2-Ant TDMA translation, default = 42 */
-#define	BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES1				80 /*  unit: % BT RSSI Threshold for      2-Ant free-run/2-Ant TDMA translation, default = 46 */
-#define	BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES2				80  /* unit: % WiFi RSSI Threshold for   1-Ant TDMA/1-Ant PS-TDMA translation, default = 42 */
-#define	BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES2				80 /*  unit: % BT RSSI Threshold for      1-Ant TDMA/1-Ant PS-TDMA translation, default = 46 */
-#define	BT_8821C_2ANT_DEFAULT_ISOLATION						15	 /*  unit: dB */
-#define   BT_8821C_2ANT_WIFI_MAX_TX_POWER						15	 /*  unit: dBm */
-#define   BT_8821C_2ANT_BT_MAX_TX_POWER							3	 /*  unit: dBm */
-#define   BT_8821C_2ANT_WIFI_SIR_THRES1							-15  /*  unit: dB */
-#define   BT_8821C_2ANT_WIFI_SIR_THRES2							-30  /*  unit: dB */
-#define   BT_8821C_2ANT_BT_SIR_THRES1							-15		 /*  unit: dB */
-#define   BT_8821C_2ANT_BT_SIR_THRES2							-30		 /*  unit: dB */
-
-
-/* for Antenna detection */
-#define	BT_8821C_2ANT_ANTDET_PSDTHRES_BACKGROUND						50
-#define	BT_8821C_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8821C_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			52
-#define	BT_8821C_2ANT_ANTDET_PSDTHRES_1ANT							40
-#define	BT_8821C_2ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8821C_2ANT_ANTDET_SWEEPPOINT_DELAY							60000
-#define	BT_8821C_2ANT_ANTDET_ENABLE										0
-#define	BT_8821C_2ANT_ANTDET_BTTXTIME									100
-#define	BT_8821C_2ANT_ANTDET_BTTXCHANNEL								39
-#define	BT_8821C_2ANT_ANTDET_PSD_SWWEEPCOUNT						50
-
-
-#define	BT_8821C_2ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
-
-enum bt_8821c_2ant_signal_state {
-	BT_8821C_2ANT_SIG_STA_SET_TO_LOW		= 0x0,
-	BT_8821C_2ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8821C_2ANT_SIG_STA_SET_TO_HIGH		= 0x1,
-	BT_8821C_2ANT_SIG_STA_MAX
-};
-
-enum bt_8821c_2ant_path_ctrl_owner {
-	BT_8821C_2ANT_PCO_BTSIDE		= 0x0,
-	BT_8821C_2ANT_PCO_WLSIDE	= 0x1,
-	BT_8821C_2ANT_PCO_MAX
-};
-
-enum bt_8821c_2ant_gnt_ctrl_type {
-	BT_8821C_2ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,
-	BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,
-	BT_8821C_2ANT_GNT_TYPE_MAX
-};
-
-enum bt_8821c_2ant_gnt_ctrl_block {
-	BT_8821C_2ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8821C_2ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8821C_2ANT_GNT_BLOCK_BB			= 0x2,
-	BT_8821C_2ANT_GNT_BLOCK_MAX
-};
-
-enum bt_8821c_2ant_lte_coex_table_type {
-	BT_8821C_2ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8821C_2ANT_CTT_BT_VS_LTE			= 0x1,
-	BT_8821C_2ANT_CTT_MAX
-};
-
-enum bt_8821c_2ant_lte_break_table_type {
-	BT_8821C_2ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8821C_2ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8821C_2ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8821C_2ANT_LBTT_LTE_BREAK_BT				= 0x3,
-	BT_8821C_2ANT_LBTT_MAX
-};
-
-enum bt_info_src_8821c_2ant {
-	BT_INFO_SRC_8821C_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8821C_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8821C_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8821C_2ANT_MAX
-};
-
-enum bt_8821c_2ant_bt_status {
-	BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8821C_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8821C_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8821C_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8821C_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8821C_2ANT_BT_STATUS_MAX
-};
-
-enum bt_8821c_2ant_coex_algo {
-	BT_8821C_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8821C_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8821C_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8821C_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8821C_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8821C_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8821C_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8821C_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8821C_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8821C_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8821C_2ANT_COEX_ALGO_NOPROFILEBUSY		= 0xb,
-	BT_8821C_2ANT_COEX_ALGO_A2DPSINK		= 0xc,
-	BT_8821C_2ANT_COEX_ALGO_MAX
-};
-
-enum bt_8821c_2ant_ext_ant_switch_type {
-	BT_8821C_2ANT_EXT_ANT_SWITCH_USE_DPDT		= 0x0,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_USE_SPDT		= 0x1,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_NONE			= 0x2,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_MAX
-};
-
-enum bt_8821c_2ant_ext_ant_switch_ctrl_type {
-	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	= 0x0,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_PTA		= 0x1,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_MAC		= 0x3,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_MAX
-};
-
-enum bt_8821c_2ant_ext_ant_switch_pos_type {
-	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_BT			= 0x0,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLG			= 0x1,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLA			= 0x2,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE		= 0x3,
-	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_MAX
-};
-
-enum bt_8821c_2ant_ext_band_switch_pos_type {
-	BT_8821C_2ANT_EXT_BAND_SWITCH_TO_WLG			= 0x0,
-	BT_8821C_2ANT_EXT_BAND_SWITCH_TO_WLA			= 0x1,
-	BT_8821C_2ANT_EXT_BAND_SWITCH_TO_MAX
-};
-
-enum bt_8821c_2ant_int_block {
-	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG			= 0x0,
-	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG		= 0x1,
-	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG		= 0x2,
-	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_MAX
-};
-
-enum bt_8821c_2ant_phase {
-	BT_8821C_2ANT_PHASE_COEX_INIT								= 0x0,
-	BT_8821C_2ANT_PHASE_WLANONLY_INIT							= 0x1,
-	BT_8821C_2ANT_PHASE_WLAN_OFF								= 0x2,
-	BT_8821C_2ANT_PHASE_2G_RUNTIME								= 0x3,
-	BT_8821C_2ANT_PHASE_5G_RUNTIME								= 0x4,
-	BT_8821C_2ANT_PHASE_BTMPMODE								= 0x5,
-	BT_8821C_2ANT_PHASE_ANTENNA_DET								= 0x6,
-	BT_8821C_2ANT_PHASE_COEX_POWERON							= 0x7,
-	BT_8821C_2ANT_PHASE_2G_RUNTIME_CONCURRENT					= 0x8,
-	BT_8821C_2ANT_PHASE_MAX
-};
-
-enum bt_8821c_2ant_Scoreboard {
-	BT_8821C_2ANT_SCOREBOARD_ACTIVE								= BIT(0),
-	BT_8821C_2ANT_SCOREBOARD_ONOFF								= BIT(1),
-	BT_8821C_2ANT_SCOREBOARD_SCAN								= BIT(2),
-	BT_8821C_2ANT_SCOREBOARD_UNDERTEST							= BIT(3),
-	BT_8821C_2ANT_SCOREBOARD_WLBUSY								= BIT(6)
-};
-
-
-
-struct coex_dm_8821c_2ant {
-	/* hw setting */
-	u32		pre_ant_pos_type;
-	u32		cur_ant_pos_type;
-	/* fw mechanism */
-	u8		pre_bt_dec_pwr_lvl;
-	u8		cur_bt_dec_pwr_lvl;
-	u8		pre_fw_dac_swing_lvl;
-	u8		cur_fw_dac_swing_lvl;
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		reset_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-
-	/* sw mechanism */
-	boolean		pre_rf_rx_lpf_shrink;
-	boolean		cur_rf_rx_lpf_shrink;
-	u32		bt_rf_0x1e_backup;
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	boolean		pre_dac_swing_on;
-	u32		pre_dac_swing_lvl;
-	boolean		cur_dac_swing_on;
-	u32		cur_dac_swing_lvl;
-	boolean		pre_adc_back_off;
-	boolean		cur_adc_back_off;
-	boolean	pre_agc_table_en;
-	boolean		cur_agc_table_en;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	boolean		need_recover0x948;
-	u32		backup0x948;
-
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	boolean		is_switch_to_1dot5_ant;
-	u8		switch_thres_offset;
-	u32					arp_cnt;
-
-	u32		pre_ext_ant_switch_status;
-	u32		cur_ext_ant_switch_status;
-
-	u8		pre_ext_band_switch_status;
-	u8		cur_ext_band_switch_status;
-
-	u8		pre_int_block_status;
-	u8		cur_int_block_status;
-};
-
-struct coex_sta_8821c_2ant {
-	boolean				bt_disabled;
-	boolean				bt_link_exist;
-	boolean				sco_exist;
-	boolean				a2dp_exist;
-	boolean				hid_exist;
-	boolean				pan_exist;
-
-	boolean				under_lps;
-	boolean				under_ips;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	boolean             is_hiPri_rx_overhead;
-	u8					bt_rssi;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	u8					bt_info_c2h[BT_INFO_SRC_8821C_2ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821C_2ANT_MAX];
-	boolean				bt_whck_test;
-	boolean				c2h_bt_inquiry_page;
-	boolean				c2h_bt_remote_name_req;
-
-	u8					bt_info_ext;
-	u8					bt_info_ext2;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-	u8					bt_retry_cnt;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	u32					acc_crc_ratio;
-	u32					now_crc_ratio;
-	u32					cnt_crcok_max_in_10s;
-
-	boolean				cck_lock;
-	boolean				cck_lock_ever;
-	boolean				cck_lock_warn;
-
-	u8					coex_table_type;
-	boolean				force_lps_ctrl;
-
-	u8					dis_ver_info_cnt;
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-
-	boolean				concurrent_rx_mode_on;
-
-	u16					score_board;
-	u8					isolation_btween_wb;   /* 0~ 50 */
-	u8					wifi_coex_thres;
-	u8					bt_coex_thres;
-	u8					wifi_coex_thres2;
-	u8					bt_coex_thres2;
-
-	u8					num_of_profile;
-	boolean				acl_busy;
-	boolean				bt_create_connection;
-	boolean				wifi_is_high_pri_task;
-	u32					specific_pkt_period_cnt;
-	u32					bt_coex_supported_feature;
-	u32					bt_coex_supported_version;
-
-	u8					bt_ble_scan_type;
-	u32					bt_ble_scan_para[3];
-
-	boolean				run_time_state;
-	boolean				freeze_coexrun_by_btinfo;
-
-	boolean				is_A2DP_3M;
-	boolean				voice_over_HOGP;
-	u8                  bt_info;
-	boolean				is_autoslot;
-	u8					forbidden_slot;
-	u8					hid_busy_num;
-	u8					hid_pair_cnt;
-
-	u32					cnt_RemoteNameReq;
-	u32					cnt_setupLink;
-	u32					cnt_ReInit;
-	u32					cnt_IgnWlanAct;
-	u32					cnt_Page;
-	u32					cnt_RoleSwitch;
-
-	u16					bt_reg_vendor_ac;
-	u16					bt_reg_vendor_ae;
-
-	boolean				is_setupLink;
-	u8				    wl_noisy_level;
-	u32                 gnt_error_cnt;
-
-	u8					bt_afh_map[10];
-	u8					bt_relink_downcount;
-	boolean				is_tdma_btautoslot;
-	boolean				is_tdma_btautoslot_hang;
-
-	boolean             is_eSCO_mode;
-	u8                  switch_band_notify_to;
-	boolean				is_rf_state_off;
-
-	boolean				is_hid_low_pri_tx_overhead;
-	boolean				is_bt_multi_link;
-	boolean				is_bt_a2dp_sink;
-	boolean				is_set_ps_state_fail;
-	u8					cnt_set_ps_state_fail;
-
-	u8					wl_fw_dbg_info[10];
-	u8					wl_rx_rate;
-	u8					wl_rts_rx_rate;
-	u8					wl_center_channel;
-
-	u16					score_board_WB;
-};
-
-
-#define  BT_8821C_2ANT_EXT_BAND_SWITCH_USE_DPDT	0
-#define  BT_8821C_2ANT_EXT_BAND_SWITCH_USE_SPDT	1
-
-
-struct rfe_type_8821c_2ant {
-
-	u8			rfe_module_type;
-	boolean		ext_ant_switch_exist;
-	u8			ext_ant_switch_type;			/* 0:DPDT, 1:SPDT */
-	u8			ext_ant_switch_ctrl_polarity;		/*  iF 0: DPDT_P=0, DPDT_N=1 => BTG to Main, WL_A+G to Aux */
-
-	boolean		ext_band_switch_exist;
-	u8			ext_band_switch_type;			/* 0:DPDT, 1:SPDT */
-	u8			ext_band_switch_ctrl_polarity;
-
-	boolean		ant_at_main_port;
-
-	boolean		wlg_Locate_at_btg;				/*  If TRUE:  WLG at BTG, If FALSE: WLG at WLAG */
-
-	boolean		ext_ant_switch_diversity;		/* If diversity on */
-};
-
-#define BT_8821C_2ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
-#define BT_8821C_2ANT_ANTDET_PSD_AVGNUM		1	/* MAX:3 */
-#define BT_8821C_2ANT_ANTDET_BUF_LEN			16
-
-struct psdscan_sta_8821c_2ant {
-
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8821C_2ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8821C_2ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_max_value2;
-	u32			psd_avg_value;   /* filter loop_max_value that below BT_8821C_1ANT_ANTDET_PSDTHRES_1ANT, and average the rest*/
-	u32			psd_loop_max_value[BT_8821C_2ANT_ANTDET_PSD_SWWEEPCOUNT];  /*max value in each loop */
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_AntDet_running;
-	boolean			is_psd_show_max_only;
-};
-
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8821c2ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c2ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8821c2ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c2ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821c2ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8821c2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8821c2ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8821c2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8821c2ant_wl_fwdbginfo_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8821c2ant_rx_rate_change_notify(IN struct btc_coexist *btcoexist,
-		IN BOOLEAN is_data_frame, IN u8 btc_rate_id);
-void ex_halbtc8821c2ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8821c2ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8821c2ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c2ant_display_simple_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c2ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8821c2ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8821c2ant_display_ant_detection(IN struct btc_coexist *btcoexist);
-
-
-#else
-#define	ex_halbtc8821c2ant_power_on_setting(btcoexist)
-#define	ex_halbtc8821c2ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8821c2ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8821c2ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8821c2ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_switchband_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8821c2ant_wl_fwdbginfo_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8821c2ant_rx_rate_change_notify(btcoexist, is_data_frame, btc_rate_id)
-#define	ex_halbtc8821c2ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8821c2ant_halt_notify(btcoexist)
-#define	ex_halbtc8821c2ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8821c2ant_periodical(btcoexist)
-#define	ex_halbtc8821c2ant_display_simple_coex_info(btcoexist)
-#define	ex_halbtc8821c2ant_display_coex_info(btcoexist)
-#define	ex_halbtc8821c2ant_display_ant_detection(btcoexist)
-#define	ex_halbtc8821c2ant_antenna_detection(btcoexist, cent_freq, offset, span, seconds)
-#endif
-
-#endif
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821cwifionly.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821cwifionly.c
deleted file mode 100644
index ffa32ed3f789..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821cwifionly.c
+++ /dev/null
@@ -1,200 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 "mp_precomp.h"
-
-static struct	rfe_type_8821c_wifi_only	gl_rfe_type_8821c_1ant;
-static struct	rfe_type_8821c_wifi_only	*rfe_type = &gl_rfe_type_8821c_1ant;
-
-
-
-VOID hal8821c_wifi_only_switch_antenna(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte is_5g
-	)
-{
-	boolean switch_polatiry_inverse = false;
-	u8	regval_0xcb7 = 0;
-	u8	pos_type, ctrl_type;
-
-	if (!rfe_type->ext_ant_switch_exist)
-		return;
-
-	/* swap control polarity if use different switch control polarity*/
-	/*	Normal switch polarity for DPDT, 0xcb4[29:28] = 2b'01 => BTG to Main, WLG to Aux,  0xcb4[29:28] = 2b'10 => BTG to Aux, WLG to Main */
-	/*	Normal switch polarity for SPDT, 0xcb4[29:28] = 2b'01 => Ant to BTG,  0xcb4[29:28] = 2b'10 => Ant to WLG */
-	if (rfe_type->ext_ant_switch_ctrl_polarity)
-		switch_polatiry_inverse =  !switch_polatiry_inverse;
-
-	/* swap control polarity if 1-Ant at Aux */
-	if (rfe_type->ant_at_main_port == false)
-		switch_polatiry_inverse =  !switch_polatiry_inverse;
-
-	if (is_5g)
-		pos_type = BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_WLA;
-	else
-		pos_type = BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_WLG;
-
-	switch (pos_type) {
-	default:
-	case BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_WLA:
-
-		break;
-	case BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_WLG:
-		if (!rfe_type->wlg_Locate_at_btg)
-			switch_polatiry_inverse =  !switch_polatiry_inverse;
-		break;
-	}
-
-	if (pwifionlycfg->haldata_info.ant_div_cfg)
-		ctrl_type = BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_ANTDIV;
-	else
-		ctrl_type = BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_BBSW;
-
-
-	switch (ctrl_type) {
-	default:
-	case BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_BBSW:
-		halwifionly_phy_set_bb_reg(pwifionlycfg, 0x4c,  0x01800000, 0x2);
-
-		/* BB SW, DPDT use RFE_ctrl8 and RFE_ctrl9 as control pin */
-		halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcb4, 0x000000ff,	0x77);
-
-		regval_0xcb7 = (switch_polatiry_inverse == false ? 0x1 : 0x2);
-
-		/* 0xcb4[29:28] = 2b'01 for no switch_polatiry_inverse, DPDT_SEL_N =1, DPDT_SEL_P =0 */
-		halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcb4, 0x30000000,	regval_0xcb7);
-		break;
-
-	case BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_ANTDIV:
-		halwifionly_phy_set_bb_reg(pwifionlycfg, 0x4c,  0x01800000, 0x2);
-
-		/* BB SW, DPDT use RFE_ctrl8 and RFE_ctrl9 as control pin */
-		halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcb4, 0x000000ff,	0x88);
-
-		/* no regval_0xcb7 setup required, because	antenna switch control value by antenna diversity */
-
-		break;
-
-	}
-
-}
-
-
-VOID halbtc8821c_wifi_only_set_rfe_type(
-	IN struct wifi_only_cfg *pwifionlycfg
-	)
-{
-
-	/* the following setup should be got from Efuse in the future */
-	rfe_type->rfe_module_type = (pwifionlycfg->haldata_info.rfe_type) & 0x1f;
-
-	rfe_type->ext_ant_switch_ctrl_polarity = 0;
-
-	switch (rfe_type->rfe_module_type) {
-	case 0:
-	default:
-		rfe_type->ext_ant_switch_exist = true;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_DPDT;          /*2-Ant, DPDT, WLG*/
-		rfe_type->wlg_Locate_at_btg = false;
-		rfe_type->ant_at_main_port = true;
-		break;
-	case 1:
-		rfe_type->ext_ant_switch_exist = true;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_SPDT;          /*1-Ant, Main, DPDT or SPDT, WLG */
-		rfe_type->wlg_Locate_at_btg = false;
-		rfe_type->ant_at_main_port = true;
-		break;
-	case 2:
-		rfe_type->ext_ant_switch_exist = true;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_SPDT;            /*1-Ant, Main, DPDT or SPDT, BTG */
-		rfe_type->wlg_Locate_at_btg = true;
-		rfe_type->ant_at_main_port = true;
-		break;
-	case 3:
-		rfe_type->ext_ant_switch_exist = true;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_DPDT;          /*1-Ant, Aux, DPDT, WLG */
-		rfe_type->wlg_Locate_at_btg = false;
-		rfe_type->ant_at_main_port = false;
-		break;
-	case 4:
-		rfe_type->ext_ant_switch_exist = true;
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_DPDT;          /*1-Ant, Aux, DPDT, BTG */
-		rfe_type->wlg_Locate_at_btg = true;
-		rfe_type->ant_at_main_port = false;
-		break;
-	case 5:
-		rfe_type->ext_ant_switch_exist = false;					 /*2-Ant, no antenna switch, WLG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_NONE;
-		rfe_type->wlg_Locate_at_btg = false;
-		rfe_type->ant_at_main_port = true;
-		break;
-	case 6:
-		rfe_type->ext_ant_switch_exist = false;				 /*2-Ant, no antenna switch, WLG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_NONE;
-		rfe_type->wlg_Locate_at_btg = false;
-		rfe_type->ant_at_main_port = true;
-		break;
-	case 7:
-		rfe_type->ext_ant_switch_exist = true;				/*2-Ant, DPDT, BTG*/
-		rfe_type->ext_ant_switch_type =
-			BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_DPDT;
-		rfe_type->wlg_Locate_at_btg = true;
-		rfe_type->ant_at_main_port = true;
-		break;
-	}
-
-}
-
-
-VOID
-ex_hal8821c_wifi_only_hw_config(
-	IN struct wifi_only_cfg *pwifionlycfg
-	)
-{
-	halbtc8821c_wifi_only_set_rfe_type(pwifionlycfg);
-
-	/* set gnt_wl, gnt_bt control owner to WL*/
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x70, 0x400000, 0x1);
-
-	/*gnt_wl=1 , gnt_bt=0*/
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1704, 0xffffffff, 0x7700);
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1700, 0xffffffff, 0xc00f0038);
-}
-
-VOID
-ex_hal8821c_wifi_only_scannotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	)
-{
-	hal8821c_wifi_only_switch_antenna(pwifionlycfg, is_5g);
-}
-
-VOID
-ex_hal8821c_wifi_only_switchbandnotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	)
-{
-	hal8821c_wifi_only_switch_antenna(pwifionlycfg, is_5g);
-}
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821cwifionly.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821cwifionly.h
deleted file mode 100644
index 1949b59c0747..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8821cwifionly.h
+++ /dev/null
@@ -1,84 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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_HAL8821CWIFIONLYHWCFG_H
-#define __INC_HAL8821CWIFIONLYHWCFG_H
-
-
-struct rfe_type_8821c_wifi_only {
-
-	u8			rfe_module_type;
-	boolean		ext_ant_switch_exist;
-	u8			ext_ant_switch_type;			/* 0:DPDT, 1:SPDT */
-	u8			ext_ant_switch_ctrl_polarity;		/*  iF 0: DPDT_P=0, DPDT_N=1 => BTG to Main, WL_A+G to Aux */
-
-	boolean		ant_at_main_port;
-
-	boolean		wlg_Locate_at_btg;				/*  If true:  WLG at BTG, If false: WLG at WLAG */
-
-	boolean		ext_ant_switch_diversity;		/* If diversity on */
-};
-
-enum bt_8821c_wifi_only_ext_ant_switch_type {
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_DPDT		= 0x0,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_USE_SPDT		= 0x1,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_NONE			= 0x2,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_MAX
-};
-
-enum bt_8821c_wifi_only_ext_ant_switch_ctrl_type {
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_BBSW		= 0x0,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_PTA		= 0x1,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_MAC		= 0x3,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_CTRL_MAX
-};
-
-enum bt_8821c_wifi_only_ext_ant_switch_pos_type {
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_BT				= 0x0,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_WLG			= 0x1,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_WLA			= 0x2,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_NOCARE			= 0x3,
-	BT_8821C_WIFI_ONLY_EXT_ANT_SWITCH_TO_MAX
-};
-
-
-VOID
-hal8821c_wifi_only_switch_antenna(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	);
-
-VOID
-halbtc8821c_wifi_only_set_rfe_type(
-	IN struct wifi_only_cfg *pwifionlycfg
-	);
-
-
-VOID
-ex_hal8821c_wifi_only_hw_config(
-	IN struct wifi_only_cfg *pwifionlycfg
-	);
-VOID
-ex_hal8821c_wifi_only_scannotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	);
-VOID
-ex_hal8821c_wifi_only_switchbandnotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	);
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b1ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b1ant.c
deleted file mode 100644
index 272efc97c0c9..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b1ant.c
+++ /dev/null
@@ -1,7131 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-/* ************************************************************
- * Description:
- *
- * This file is for RTL8822B Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-/*only for rf4ce*/
-#include "mp_precomp.h"
-
-
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8822B_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	 *trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8822b_1ant		glcoex_dm_8822b_1ant;
-static struct  coex_dm_8822b_1ant	*coex_dm = &glcoex_dm_8822b_1ant;
-static struct  coex_sta_8822b_1ant		glcoex_sta_8822b_1ant;
-static struct  coex_sta_8822b_1ant	*coex_sta = &glcoex_sta_8822b_1ant;
-static struct  psdscan_sta_8822b_1ant	gl_psd_scan_8822b_1ant;
-static struct  psdscan_sta_8822b_1ant *psd_scan = &gl_psd_scan_8822b_1ant;
-static struct	rfe_type_8822b_1ant		gl_rfe_type_8822b_1ant;
-static struct	rfe_type_8822b_1ant		*rfe_type = &gl_rfe_type_8822b_1ant;
-
-
-
-static const char *const glbt_info_src_8822b_1ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-static u32	glcoex_ver_date_8822b_1ant = 20170707;
-static u32	glcoex_ver_8822b_1ant = 0x46;
-static u32	glcoex_ver_btdesired_8822b_1ant = 0x42;
-
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8822b1ant_
- * ************************************************************ */
-#if 0
-static
-u8 halbtc8822b1ant_bt_rssi_state(IN struct btc_coexist *btcoexist,
-				 u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = coex_sta->pre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_bt_rssi_state;
-		}
-
-		if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (coex_sta->pre_bt_rssi_state ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_bt_rssi_state ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-#endif
-
-static
-u8 halbtc8822b1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 index, IN u8 level_num, IN u8 rssi_thresh, IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index];
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return coex_sta->pre_wifi_rssi_state[index];
-		}
-
-		if ((coex_sta->pre_wifi_rssi_state[index] == BTC_RSSI_STATE_LOW)
-		    ||
-		    (coex_sta->pre_wifi_rssi_state[index] ==
-		     BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_MEDIUM) ||
-			   (coex_sta->pre_wifi_rssi_state[index] ==
-			    BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-static
-void halbtc8822b1ant_update_ra_mask(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u32 dis_rate_mask)
-{
-	coex_dm->cur_ra_mask = dis_rate_mask;
-
-	if (force_exec || (coex_dm->pre_ra_mask != coex_dm->cur_ra_mask))
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_UPDATE_RAMASK,
-				   &coex_dm->cur_ra_mask);
-	coex_dm->pre_ra_mask = coex_dm->cur_ra_mask;
-}
-
-static
-void halbtc8822b1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	boolean	wifi_under_b_mode = FALSE;
-
-	coex_dm->cur_arfr_type = type;
-
-	if (force_exec || (coex_dm->pre_arfr_type != coex_dm->cur_arfr_type)) {
-		switch (coex_dm->cur_arfr_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_4byte(btcoexist, 0x430,
-						   coex_dm->backup_arfr_cnt1);
-			btcoexist->btc_write_4byte(btcoexist, 0x434,
-						   coex_dm->backup_arfr_cnt2);
-			break;
-		case 1:
-			btcoexist->btc_get(btcoexist,
-					   BTC_GET_BL_WIFI_UNDER_B_MODE,
-					   &wifi_under_b_mode);
-			if (wifi_under_b_mode) {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x01010101);
-			} else {
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x430, 0x0);
-				btcoexist->btc_write_4byte(btcoexist,
-							   0x434, 0x04030201);
-			}
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_arfr_type = coex_dm->cur_arfr_type;
-}
-
-static
-void halbtc8822b1ant_retry_limit(IN struct btc_coexist *btcoexist,
-				 IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_retry_limit_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_retry_limit_type !=
-	     coex_dm->cur_retry_limit_type)) {
-		switch (coex_dm->cur_retry_limit_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   coex_dm->backup_retry_limit);
-			break;
-		case 1:	/* retry limit=8 */
-			btcoexist->btc_write_2byte(btcoexist, 0x42a,
-						   0x0808);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_retry_limit_type = coex_dm->cur_retry_limit_type;
-}
-
-static
-void halbtc8822b1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,
-				    IN boolean force_exec, IN u8 type)
-{
-	coex_dm->cur_ampdu_time_type = type;
-
-	if (force_exec ||
-	    (coex_dm->pre_ampdu_time_type != coex_dm->cur_ampdu_time_type)) {
-		switch (coex_dm->cur_ampdu_time_type) {
-		case 0:	/* normal mode */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-					   coex_dm->backup_ampdu_max_time);
-			break;
-		case 1:	/* AMPDU timw = 0x38 * 32us */
-			btcoexist->btc_write_1byte(btcoexist, 0x456,
-						   0x38);
-			break;
-		default:
-			break;
-		}
-	}
-
-	coex_dm->pre_ampdu_time_type = coex_dm->cur_ampdu_time_type;
-}
-
-static
-void halbtc8822b1ant_limited_tx(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 ra_mask_type, IN u8 arfr_type,
-				IN u8 retry_limit_type, IN u8 ampdu_time_type)
-{
-	switch (ra_mask_type) {
-	case 0:	/* normal mode */
-		halbtc8822b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0);
-		break;
-	case 1:	/* disable cck 1/2 */
-		halbtc8822b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x00000003);
-		break;
-	case 2:	/* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4 */
-		halbtc8822b1ant_update_ra_mask(btcoexist, force_exec,
-					       0x0001f1f7);
-		break;
-	default:
-		break;
-	}
-
-	halbtc8822b1ant_auto_rate_fallback_retry(btcoexist, force_exec,
-			arfr_type);
-	halbtc8822b1ant_retry_limit(btcoexist, force_exec, retry_limit_type);
-	halbtc8822b1ant_ampdu_max_time(btcoexist, force_exec, ampdu_time_type);
-}
-
-/*
- * rx agg size setting :
- * 1:      TRUE / don't care / don't care
- * max: FALSE / FALSE / don't care
- * 7:     FALSE / TRUE / 7
- */
-
-static
-void halbtc8822b1ant_limited_rx(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN boolean rej_ap_agg_pkt,
-			IN boolean bt_ctrl_agg_buf_size, IN u8 agg_buf_size)
-{
-	boolean	reject_rx_agg = rej_ap_agg_pkt;
-	boolean	bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
-	u8	rx_agg_size = agg_buf_size;
-
-	/* ============================================ */
-	/*	Rx Aggregation related setting */
-	/* ============================================ */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT,
-			   &reject_rx_agg);
-	/* decide BT control aggregation buf size or not */
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE,
-			   &bt_ctrl_rx_agg_size);
-	/* aggregation buf size, only work when BT control Rx aggregation size*/
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
-	/* real update aggregation setting */
-	btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
-
-
-}
-
-static
-void halbtc8822b1ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], No query BT info because BT is disabled!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], WL query BT info!!\n");
-	BTC_TRACE(trace_buf);
-}
-
-
-
-static
-void halbtc8822b1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0, cnt_slave = 0, cnt_autoslot_hang = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-#if 0
-	/* to avoid 0x76e[3] = 1 (WLAN_Act control by PTA) during IPS */
-	if (!(btcoexist->btc_read_1byte(btcoexist, 0x76e) & 0x8))
-#endif
-
-#if 0
-	if (coex_sta->under_ips) {
-		/* coex_sta->high_priority_tx = 65535; */
-		/* coex_sta->high_priority_rx = 65535; */
-		/* coex_sta->low_priority_tx = 65535; */
-		/* coex_sta->low_priority_rx = 65535; */
-		/* return; */
-	}
-#endif
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
-		    reg_hp_rx, reg_hp_tx, reg_lp_rx, reg_lp_tx);
-	BTC_TRACE(trace_buf);
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	if ((coex_sta->low_priority_tx > 1150)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	if ((coex_sta->low_priority_rx >= 1150) &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx)
-	    && (!coex_sta->under_ips)  &&
-	    (!coex_sta->c2h_bt_inquiry_page) &&
-	    (coex_sta->bt_link_exist))	{
-		if (cnt_slave >= 3) {
-			bt_link_info->slave_role = TRUE;
-			cnt_slave = 3;
-		} else {
-			cnt_slave++;
-		}
-	} else {
-		if (cnt_slave == 0)	{
-			bt_link_info->slave_role = FALSE;
-			cnt_slave = 0;
-		} else {
-			cnt_slave--;
-		}
-
-	}
-
-	if (coex_sta->is_tdma_btautoslot) {
-		if ((coex_sta->low_priority_tx >= 1300) &&
-		(coex_sta->low_priority_rx <= 150)) {
-			if (cnt_autoslot_hang >= 2) {
-				coex_sta->is_tdma_btautoslot_hang = TRUE;
-				cnt_autoslot_hang = 2;
-			} else {
-				cnt_autoslot_hang++;
-			}
-		} else {
-			if (cnt_autoslot_hang == 0)	{
-				coex_sta->is_tdma_btautoslot_hang = FALSE;
-				cnt_autoslot_hang = 0;
-			} else {
-				cnt_autoslot_hang--;
-			}
-		}
-	}
-
-	if (bt_link_info->hid_only) {
-		if (coex_sta->low_priority_rx > 50)
-			coex_sta->is_hid_low_pri_tx_overhead = true;
-		else
-			coex_sta->is_hid_low_pri_tx_overhead = false;
-	}
-
-	if ((coex_sta->high_priority_tx == 0) &&
-	    (coex_sta->high_priority_rx == 0) &&
-	    (coex_sta->low_priority_tx == 0) &&
-	    (coex_sta->low_priority_rx == 0)) {
-		num_of_bt_counter_chk++;
-
-		if (num_of_bt_counter_chk >= 3) {
-			halbtc8822b1ant_query_bt_info(
-				btcoexist);
-			num_of_bt_counter_chk = 0;
-		}
-	}
-
-}
-
-
-static
-void halbtc8822b1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-#if 1
-	s32	wifi_rssi = 0;
-	boolean wifi_busy = FALSE, wifi_under_b_mode = FALSE,
-		wifi_scan = FALSE;
-	static u8 cck_lock_counter = 0, wl_noisy_count0 = 0,
-		  wl_noisy_count1 = 3, wl_noisy_count2 = 0;
-	u32	total_cnt, cck_cnt;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-			   &wifi_under_b_mode);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-
-	coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			       PHYDM_INFO_CRC32_OK_CCK);
-	coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			       PHYDM_INFO_CRC32_OK_LEGACY);
-	coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			       PHYDM_INFO_CRC32_OK_HT);
-	coex_sta->crc_ok_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-					   btcoexist, PHYDM_INFO_CRC32_OK_VHT);
-
-	coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist, PHYDM_INFO_CRC32_ERROR_CCK);
-	coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-				 btcoexist, PHYDM_INFO_CRC32_ERROR_LEGACY);
-	coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-					btcoexist, PHYDM_INFO_CRC32_ERROR_HT);
-	coex_sta->crc_err_11n_vht = btcoexist->btc_phydm_query_PHY_counter(
-				    btcoexist, PHYDM_INFO_CRC32_ERROR_VHT);
-
-	cck_cnt = coex_sta->crc_ok_cck + coex_sta->crc_err_cck;
-
-	if (cck_cnt > 250) {
-		if (wl_noisy_count2 < 3)
-			wl_noisy_count2++;
-
-		if (wl_noisy_count2 == 3) {
-			wl_noisy_count0 = 0;
-			wl_noisy_count1 = 0;
-		}
-
-	} else if (cck_cnt < 50) {
-		if (wl_noisy_count0 < 3)
-			wl_noisy_count0++;
-
-		if (wl_noisy_count0 == 3) {
-			wl_noisy_count1 = 0;
-			wl_noisy_count2 = 0;
-		}
-
-	} else {
-		if (wl_noisy_count1 < 3)
-			wl_noisy_count1++;
-
-		if (wl_noisy_count1 == 3) {
-			wl_noisy_count0 = 0;
-			wl_noisy_count2 = 0;
-		}
-	}
-
-	if (wl_noisy_count2 == 3)
-		coex_sta->wl_noisy_level = 2;
-	else if (wl_noisy_count1 == 3)
-		coex_sta->wl_noisy_level = 1;
-	else
-		coex_sta->wl_noisy_level = 0;
-
-	if ((wifi_busy) && (wifi_rssi >= 30) && (!wifi_under_b_mode)) {
-		total_cnt = coex_sta->crc_ok_cck + coex_sta->crc_ok_11g +
-			    coex_sta->crc_ok_11n + coex_sta->crc_ok_11n_vht;
-
-		if ((coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_ACL_BUSY) ||
-		    (coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY)
-		    ||
-		    (coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_SCO_BUSY)) {
-			if (coex_sta->crc_ok_cck > (total_cnt -
-						    coex_sta->crc_ok_cck)) {
-				if (cck_lock_counter < 3)
-					cck_lock_counter++;
-			} else {
-				if (cck_lock_counter > 0)
-					cck_lock_counter--;
-			}
-
-		} else {
-			if (cck_lock_counter > 0)
-				cck_lock_counter--;
-		}
-	} else {
-		if (cck_lock_counter > 0)
-			cck_lock_counter--;
-	}
-
-	if (!coex_sta->pre_ccklock) {
-
-		if (cck_lock_counter >= 3)
-			coex_sta->cck_lock = TRUE;
-		else
-			coex_sta->cck_lock = FALSE;
-	} else {
-		if (cck_lock_counter == 0)
-			coex_sta->cck_lock = FALSE;
-		else
-			coex_sta->cck_lock = TRUE;
-	}
-
-	if (coex_sta->cck_lock)
-		coex_sta->cck_ever_lock = TRUE;
-
-	coex_sta->pre_ccklock =  coex_sta->cck_lock;
-
-#endif
-}
-
-
-static
-boolean halbtc8822b1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)
-{
-	static boolean	pre_wifi_busy = FALSE, pre_under_4way = FALSE,
-			pre_bt_hs_on = FALSE, pre_rf4ce_enabled = FALSE, pre_bt_off = FALSE,
-			pre_bt_slave = FALSE, pre_hid_low_pri_tx_overhead = FALSE,
-			pre_wifi_under_lps = FALSE, pre_bt_setup_link = FALSE;
-	static u8 pre_hid_busy_num = 0, pre_wl_noisy_level = 0;
-	boolean wifi_busy = FALSE, under_4way = FALSE, bt_hs_on = FALSE, rf4ce_enabled = FALSE;
-	boolean wifi_connected = FALSE;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (coex_sta->bt_disabled != pre_bt_off) {
-		pre_bt_off = coex_sta->bt_disabled;
-
-		if (coex_sta->bt_disabled)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is enabled !!\n");
-
-		BTC_TRACE(trace_buf);
-
-		coex_sta->bt_coex_supported_feature = 0;
-		coex_sta->bt_coex_supported_version = 0;
-		return TRUE;
-	}
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_RF4CE_CONNECTED, &rf4ce_enabled);
-
-	if (rf4ce_enabled != pre_rf4ce_enabled) {
-		pre_rf4ce_enabled = rf4ce_enabled;
-
-		if (rf4ce_enabled)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], rf4ce is enabled !!\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], rf4ce is disabled !!\n");
-
-		BTC_TRACE(trace_buf);
-
-
-		return TRUE;
-	}
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return TRUE;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return TRUE;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return TRUE;
-		}
-		if (coex_sta->wl_noisy_level != pre_wl_noisy_level) {
-			pre_wl_noisy_level = coex_sta->wl_noisy_level;
-			return TRUE;
-		}
-		if (coex_sta->under_lps != pre_wifi_under_lps) {
-			pre_wifi_under_lps = coex_sta->under_lps;
-			if (coex_sta->under_lps)
-				return TRUE;
-		}
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->hid_busy_num != pre_hid_busy_num) {
-			pre_hid_busy_num = coex_sta->hid_busy_num;
-			return TRUE;
-		}
-
-		if (bt_link_info->slave_role != pre_bt_slave) {
-			pre_bt_slave = bt_link_info->slave_role;
-			return TRUE;
-		}
-
-		if (pre_hid_low_pri_tx_overhead != coex_sta->is_hid_low_pri_tx_overhead) {
-			pre_hid_low_pri_tx_overhead = coex_sta->is_hid_low_pri_tx_overhead;
-			return TRUE;
-		}
-
-		if (pre_bt_setup_link != coex_sta->is_setupLink) {
-			pre_bt_setup_link = coex_sta->is_setupLink;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-
-
-static
-void halbtc8822b1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = FALSE;
-	boolean		bt_busy = FALSE;
-
-
-	coex_sta->num_of_profile = 0;
-
-	/* set link exist status */
-	if (!(coex_sta->bt_info & BT_INFO_8822B_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = FALSE;
-		coex_sta->pan_exist = FALSE;
-		coex_sta->a2dp_exist = FALSE;
-		coex_sta->hid_exist = FALSE;
-		coex_sta->sco_exist = FALSE;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = TRUE;
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_FTP) {
-			coex_sta->pan_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->pan_exist = FALSE;
-		}
-
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_A2DP) {
-			coex_sta->a2dp_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->a2dp_exist = FALSE;
-		}
-
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_HID) {
-			coex_sta->hid_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->hid_exist = FALSE;
-		}
-
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_SCO_ESCO) {
-			coex_sta->sco_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->sco_exist = FALSE;
-		}
-
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-	bt_link_info->acl_busy = coex_sta->acl_busy;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = TRUE;
-		bt_link_info->bt_link_exist = TRUE;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = TRUE;
-	else
-		bt_link_info->sco_only = FALSE;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = TRUE;
-	else
-		bt_link_info->a2dp_only = FALSE;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = TRUE;
-	else
-		bt_link_info->pan_only = FALSE;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = TRUE;
-	else
-		bt_link_info->hid_only = FALSE;
-
-	if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_INQ_PAGE) {
-		coex_dm->bt_status = BT_8822B_1ANT_BT_STATUS_INQ_PAGE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Inq/page!!!\n");
-	} else if (!(coex_sta->bt_info & BT_INFO_8822B_1ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-	} else if (coex_sta->bt_info == BT_INFO_8822B_1ANT_B_CONNECTION) {
-		/* connection exists but no busy */
-		coex_dm->bt_status = BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-	} else if (((coex_sta->bt_info & BT_INFO_8822B_1ANT_B_SCO_ESCO) ||
-		    (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_SCO_BUSY)) &&
-		   (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_ACL_BUSY)) {
-		coex_dm->bt_status = BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL SCO busy!!!\n");
-	} else if ((coex_sta->bt_info & BT_INFO_8822B_1ANT_B_SCO_ESCO) ||
-		   (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8822B_1ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-	} else if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8822B_1ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-	} else {
-		coex_dm->bt_status = BT_8822B_1ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-	}
-
-	BTC_TRACE(trace_buf);
-
-	if ((coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_ACL_BUSY) ||
-	    (coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_SCO_BUSY) ||
-	    (coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY))
-		bt_busy = TRUE;
-	else
-		bt_busy = FALSE;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-}
-
-
-static
-void halbtc8822b1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_parameter[3] = {0};
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-
-		/* enable BT AFH skip WL channel for 8822b
-		 * because BT Rx LO interference
-		 */
-		h2c_parameter[0] = 0x1;
-		h2c_parameter[1] = wifi_central_chnl;
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-
-}
-
-static
-u8 halbtc8822b1ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = FALSE;
-	u8				algorithm = BT_8822B_1ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Profile = SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8822B_1ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_1ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + A2DP ==> SCO\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_1ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8822B_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_1ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_1ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8822B_1ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_HID_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_1ANT_COEX_ALGO_PANEDR_HID;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-
-
-
-
-
-
-static
-void halbtc8822b1ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,
-		IN u8 dac_swing_lvl)
-{
-	u8	h2c_parameter[1] = {0};
-	u32	RTL97F_8822B = 0;
-
-	if (RTL97F_8822B)
-		return;
-
-	/* There are several type of dacswing */
-	/* 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 */
-	h2c_parameter[0] = dac_swing_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter);
-}
-
-
-static
-void halbtc8822b1ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,
-			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
-{
-	u32	RTL97F_8822B = 0;
-
-	if (RTL97F_8822B)
-		return;
-
-	coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_fw_dac_swing_lvl ==
-		    coex_dm->cur_fw_dac_swing_lvl)
-			return;
-	}
-
-	halbtc8822b1ant_set_fw_dac_swing_level(btcoexist,
-					       coex_dm->cur_fw_dac_swing_lvl);
-
-	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
-}
-
-static
-void halbtc8822b1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-#if 1
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra ==
-		    coex_dm->cur_low_penalty_ra)
-			return;
-	}
-
-	if (low_penalty_ra)
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 25);
-	else
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-
-#endif
-}
-
-static
-void halbtc8822b1ant_write_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16				bitpos,
-	IN	boolean		state
-)
-{
-
-	static u16 originalval = 0x8002;
-
-	if (state)
-		originalval = originalval | bitpos;
-	else
-		originalval = originalval & (~bitpos);
-
-	btcoexist->btc_write_2byte(btcoexist, 0xaa, originalval);
-}
-
-static
-void halbtc8822b1ant_read_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN   u16				*score_board_val
-)
-{
-
-	*score_board_val = (btcoexist->btc_read_2byte(btcoexist,
-			    0xaa)) & 0x7fff;
-}
-
-static
-void halbtc8822b1ant_post_state_to_bt(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16						type,
-	IN  boolean                 state
-)
-{
-
-	halbtc8822b1ant_write_score_board(btcoexist, (u16) type, state);
-
-}
-
-
-static
-void halbtc8822b1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = TRUE, bt_disabled = FALSE,
-				wifi_under_5g = FALSE;
-	u16		u16tmp;
-
-	/* This function check if bt is disabled */
-#if 0
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = FALSE;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = FALSE;
-
-
-#else
-
-	/* Read BT on/off status from scoreboard[1],
-	 * enable this only if BT patch support this feature
-	 */
-	halbtc8822b1ant_read_score_board(btcoexist, &u16tmp);
-
-	bt_active = u16tmp & BIT(1);
-
-
-#endif
-
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = FALSE;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	} else {
-
-		bt_disable_cnt++;
-		if (bt_disable_cnt >= 2) {
-			bt_disabled = TRUE;
-			bt_disable_cnt = 2;
-		}
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G,
-			   &wifi_under_5g);
-
-	if ((wifi_under_5g) || (bt_disabled))
-		halbtc8822b1ant_low_penalty_ra(btcoexist,
-					       NORMAL_EXEC, FALSE);
-	else
-		halbtc8822b1ant_low_penalty_ra(btcoexist,
-					       NORMAL_EXEC, TRUE);
-
-
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" :
-			     "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-	}
-
-}
-
-
-
-static
-void halbtc8822b1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
-					boolean isenable)
-{
-#if	BT_8822B_1ANT_COEX_DBG
-	static u8			bitVal[5] = {0, 0, 0, 0, 0};
-	static boolean		state = FALSE;
-
-	if (state == isenable)
-		return;
-
-	state = isenable;
-
-	if (isenable) {
-
-		/* enable GNT_WL, GNT_BT to GPIO for debug */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x1);
-
-		/* store original value */
-		bitVal[0] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x66) & BIT(4)) >> 4;	/*0x66[4] */
-		bitVal[1] = (btcoexist->btc_read_1byte(btcoexist,
-					       0x67) & BIT(0));	/*0x66[8] */
-		bitVal[2] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x42) & BIT(3)) >> 3;  /*0x40[19] */
-		bitVal[3] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x65) & BIT(7)) >> 7;  /*0x64[15] */
-		bitVal[4] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x72) & BIT(2)) >> 2;  /*0x70[18] */
-
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   0x0);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   0x0);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-						   0x0);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-						   0x0);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-						   0x0);  /*0x70[18] = 0 */
-
-
-	} else {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x0);
-
-		/*  Restore original value  */
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   bitVal[0]);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   bitVal[1]);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-					   bitVal[2]);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-					   bitVal[3]);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-					   bitVal[4]);  /*0x70[18] = 0 */
-	}
-#endif
-}
-
-
-
-static
-u32 halbtc8822b1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
-		IN u16 reg_addr)
-{
-	u32 delay_count = 0;
-
-	/* wait for ready bit before access 0x1700 */
-	while (1) {
-		if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-			delay_ms(50);
-			delay_count++;
-			if (delay_count >= 10) {
-				delay_count = 0;
-				break;
-			}
-		} else {
-			break;
-		}
-	}
-
-	btcoexist->btc_write_4byte(btcoexist, 0x1700, 0x800F0000 | reg_addr);
-
-	return btcoexist->btc_read_4byte(btcoexist,
-					 0x1708);  /* get read data */
-}
-
-
-static
-void halbtc8822b1ant_ltecoex_indirect_write_reg(IN struct btc_coexist
-		*btcoexist,
-		IN u16 reg_addr, IN u32 bit_mask, IN u32 reg_value)
-{
-	u32 val, i = 0, bitpos = 0, delay_count = 0;
-
-
-	if (bit_mask == 0x0)
-		return;
-
-	if (bit_mask == 0xffffffff) {
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10)	{
-					delay_count = 0;
-					break;
-				}
-			} else {
-				break;
-			}
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   reg_value); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-	} else {
-		for (i = 0; i <= 31; i++) {
-			if (((bit_mask >> i) & 0x1) == 0x1) {
-				bitpos = i;
-				break;
-			}
-		}
-
-		/* read back register value before write */
-		val = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-				reg_addr);
-		val = (val & (~bit_mask)) | (reg_value << bitpos);
-
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10)	{
-					delay_count = 0;
-					break;
-				}
-			} else {
-				break;
-			}
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   val); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-
-	}
-
-}
-
-
-static
-void halbtc8822b1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
-				    IN boolean enable)
-{
-	u8 val;
-
-	val = (enable) ? 1 : 0;
-	/* 0x38[7] */
-	halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist, 0x38, 0x80, val);
-
-}
-
-
-
-static
-void halbtc8822b1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_control)
-{
-	u8 val;
-
-	val = (wifi_control) ? 1 : 0;
-	/* 0x70[26] */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x4, val);
-
-}
-
-
-static
-void halbtc8822b1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, bit_mask;
-
-	state = state & 0x1;
-	/*LTE indirect 0x38=0xccxx (sw : gnt_wl=1,sw gnt_bt=1)
-	 *0x38=0xddxx (sw : gnt_bt=1 , sw gnt_wl=0)
-	 *0x38=0x55xx(hw pta :gnt_wl /gnt_bt )
-	 */
-	val = (sw_control) ? ((state << 1) | 0x1) : 0;
-
-	switch (control_block) {
-	case BT_8822B_1ANT_GNT_BLOCK_RFC_BB:
-	default:
-		bit_mask = 0xc000;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[15:14] */
-		bit_mask = 0x0c00;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[11:10] */
-		break;
-	case BT_8822B_1ANT_GNT_BLOCK_RFC:
-		bit_mask = 0xc000;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[15:14] */
-		break;
-	case BT_8822B_1ANT_GNT_BLOCK_BB:
-		bit_mask = 0x0c00;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[11:10] */
-		break;
-
-	}
-
-}
-
-
-static
-void halbtc8822b1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, bit_mask;
-	/*LTE indirect 0x38=0xccxx (sw : gnt_wl=1,sw gnt_bt=1)
-	 *0x38=0xddxx (sw : gnt_bt=1 , sw gnt_wl=0)
-	 *0x38=0x55xx(hw pta :gnt_wl /gnt_bt )
-	 */
-
-	state = state & 0x1;
-	val = (sw_control) ? ((state << 1) | 0x1) : 0;
-
-	switch (control_block) {
-	case BT_8822B_1ANT_GNT_BLOCK_RFC_BB:
-	default:
-		bit_mask = 0x3000;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[13:12] */
-		bit_mask = 0x0300;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[9:8] */
-		break;
-	case BT_8822B_1ANT_GNT_BLOCK_RFC:
-		bit_mask = 0x3000;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[13:12] */
-		break;
-	case BT_8822B_1ANT_GNT_BLOCK_BB:
-		bit_mask = 0x0300;
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[9:8] */
-		break;
-
-	}
-
-}
-
-
-static
-void halbtc8822b1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u16 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8822B_1ANT_CTT_WL_VS_LTE:
-		reg_addr = 0xa0;
-		break;
-	case BT_8822B_1ANT_CTT_BT_VS_LTE:
-		reg_addr = 0xa4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xffff, table_content); /* 0xa0[15:0] or 0xa4[15:0] */
-
-
-}
-
-
-
-#if 0
-static
-void halbtc8822b1ant_ltcoex_set_break_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u8 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8822B_1ANT_LBTT_WL_BREAK_LTE:
-		reg_addr = 0xa8;
-		break;
-	case BT_8822B_1ANT_LBTT_BT_BREAK_LTE:
-		reg_addr = 0xac;
-		break;
-	case BT_8822B_1ANT_LBTT_LTE_BREAK_WL:
-		reg_addr = 0xb0;
-		break;
-	case BT_8822B_1ANT_LBTT_LTE_BREAK_BT:
-		reg_addr = 0xb4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8822b1ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xff, table_content); /* 0xa8[15:0] or 0xb4[15:0] */
-
-
-}
-#endif
-
-
-
-
-static
-void halbtc8822b1ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
-{
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
-
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
-	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
-			return;
-	}
-
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-
-
-static
-void halbtc8822b1ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-
-static
-void halbtc8822b1ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8822b1ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-
-static
-void halbtc8822b1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	u32	break_table;
-	u8	select_table;
-
-
-
-	coex_sta->coex_table_type = type;
-
-	if (coex_sta->concurrent_rx_mode_on) {
-		break_table = 0xf0ffffff;	/* set WL hi-pri can break BT */
-		select_table = 0x3; /* set Tx response = Hi-Pri
-				     * (ex: Transmitting ACK,BA,CTS)
-				     */
-	} else {
-		break_table = 0xffffff;
-		select_table = 0x3;
-	}
-
-	switch (type) {
-	case 0:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x55555555, break_table,
-					   select_table);
-		break;
-	case 1:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x5a5a5a5a, break_table,
-					   select_table);
-		break;
-	case 2:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xaa5a5a5a, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 3:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0xaa5a5a5a, break_table,
-					   select_table);
-		break;
-	case 4:
-		halbtc8822b1ant_coex_table(btcoexist,
-					   force_exec, 0xaa555555, 0xaa5a5a5a,
-					   break_table, select_table);
-		break;
-	case 5:
-		halbtc8822b1ant_coex_table(btcoexist,
-					   force_exec, 0x5a5a5a5a, 0x5a5a5a5a,
-					   break_table, select_table);
-		break;
-	case 6:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0xaaaaaaaa, break_table,
-					   select_table);
-		break;
-	case 7:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xaaaaaaaa, 0xaaaaaaaa, break_table,
-					   select_table);
-		break;
-	case 8:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xffffffff, 0xffffffff, break_table,
-					   select_table);
-		break;
-	case 9:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x5a5a5555, 0xaaaa5a5a, break_table,
-					   select_table);
-		break;
-	case 10:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xaaaa5aaa, 0xaaaa5aaa, break_table,
-					   select_table);
-		break;
-	case 11:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xaaaaa5aa, 0xaaaaaaaa, break_table,
-					   select_table);
-		break;
-	case 12:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xaaaaa5aa, 0xaaaaa5aa, break_table,
-					   select_table);
-		break;
-	case 13:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0xaaaa5a5a, break_table,
-					   select_table);
-		break;
-	case 14:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x5a5a555a, 0xaaaa5a5a, break_table,
-					   select_table);
-		break;
-	case 15:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0xaaaa55aa, break_table,
-					   select_table);
-		break;
-	case 16:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x5a5a555a, 0x5a5a555a, break_table,
-					   select_table);
-		break;
-	case 17:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xaaaa55aa, 0xaaaa55aa, break_table,
-					   select_table);
-		break;
-	case 18:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x5aaa5a5a, break_table,
-					   select_table);
-		break;
-	case 19:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0xa5555555, 0xaaaa5aaa, break_table,
-					   select_table);
-		break;
-	case 20:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0xaaaa5aaa, break_table,
-					   select_table);
-		break;
-	case 21:
-		halbtc8822b1ant_coex_table(btcoexist, force_exec,
-					   0x55555555, 0x55555a5a, break_table,
-					   select_table);
-		break;
-	default:
-		break;
-	}
-}
-
-
-static
-void halbtc8822b1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-
-
-	u8			h2c_parameter[1] = {0};
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-
-static
-void halbtc8822b1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act) {
-
-			coex_dm->pre_ignore_wlan_act =
-				coex_dm->cur_ignore_wlan_act;
-			return;
-		}
-	}
-
-	halbtc8822b1ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-
-static
-void halbtc8822b1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-
-static
-void halbtc8822b1ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-		return;
-	}
-	halbtc8822b1ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-
-
-static
-void halbtc8822b1ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0x8, 0, 0, 0, 0};
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) { /* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-
-
-
-static
-boolean halbtc8822b1ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = FALSE, result = TRUE;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		/* recover to original 32k low power setting */
-		coex_sta->force_lps_ctrl = FALSE;
-		low_pwr_disable = FALSE;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		break;
-	case BTC_PS_LPS_ON:
-
-		coex_sta->force_lps_ctrl = TRUE;
-		halbtc8822b1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, TRUE);
-		halbtc8822b1ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = TRUE;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma. */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-
-		break;
-	case BTC_PS_LPS_OFF:
-
-		coex_sta->force_lps_ctrl = TRUE;
-		halbtc8822b1ant_ps_tdma_check_for_power_save_state(
-			btcoexist, FALSE);
-		result = btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-
-		break;
-	default:
-		break;
-	}
-
-	return result;
-}
-
-
-
-
-static
-void halbtc8822b1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = FALSE, result = FALSE;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	if (byte5 & BIT(2))
-		coex_sta->is_tdma_btautoslot = TRUE;
-	else
-		coex_sta->is_tdma_btautoslot = FALSE;
-
-	/* release bt-auto slot for auto-slot hang is detected!! */
-	if (coex_sta->is_tdma_btautoslot)
-		if ((coex_sta->is_tdma_btautoslot_hang) ||
-			(bt_link_info->slave_role))
-			byte5 = byte5 & 0xfb;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if ((ap_enable) && (byte1 & BIT(4) && !(byte1 & BIT(5)))) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b1ant_set_fw_pstdma == FW for 1Ant AP mode\n");
-		BTC_TRACE(trace_buf);
-
-		real_byte1 &= ~BIT(4);
-		real_byte1 |= BIT(5);
-
-		real_byte5 |= BIT(5);
-		real_byte5 &= ~BIT(6);
-
-		halbtc8822b1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0,
-							 0x0);
-
-	} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b1ant_set_fw_pstdma == Force LPS (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-		if (!halbtc8822b1ant_power_save_state(btcoexist, BTC_PS_LPS_OFF, 0x50, 0x4))
-			result = TRUE;
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b1ant_set_fw_pstdma == native power save (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_power_save_state(btcoexist,
-						 BTC_PS_WIFI_NATIVE, 0x0,
-						 0x0);
-	}
-
-
-	coex_sta->is_set_ps_state_fail = result;
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		h2c_parameter[0] = real_byte1;
-		h2c_parameter[1] = byte2;
-		h2c_parameter[2] = byte3;
-		h2c_parameter[3] = byte4;
-		h2c_parameter[4] = real_byte5;
-
-		coex_dm->ps_tdma_para[0] = real_byte1;
-		coex_dm->ps_tdma_para[1] = byte2;
-		coex_dm->ps_tdma_para[2] = byte3;
-		coex_dm->ps_tdma_para[3] = byte4;
-		coex_dm->ps_tdma_para[4] = real_byte5;
-
-		btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-
-	} else {
-		coex_sta->cnt_set_ps_state_fail++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b1ant_set_fw_pstdma == Force Leave LPS Fail (cnt = %d)\n",
-			    coex_sta->cnt_set_ps_state_fail);
-		BTC_TRACE(trace_buf);
-	}
-}
-
-
-
-static
-void halbtc8822b1ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_busy = FALSE;
-	static u8			psTdmaByte4Modify = 0x0, pre_psTdmaByte4Modify = 0x0;
-	static boolean	 pre_wifi_busy = FALSE;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (wifi_busy != pre_wifi_busy) {
-		force_exec = TRUE;
-		pre_wifi_busy = wifi_busy;
-	}
-
-	/* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-	if (bt_link_info->slave_role)
-		psTdmaByte4Modify = 0x1;
-	else
-		psTdmaByte4Modify = 0x0;
-
-	if (pre_psTdmaByte4Modify != psTdmaByte4Modify) {
-
-		force_exec = TRUE;
-		pre_psTdmaByte4Modify = psTdmaByte4Modify;
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Skip TDMA because no change TDMA(%s, %d)\n",
-				    (coex_dm->cur_ps_tdma_on ? "on" : "off"),
-				    coex_dm->cur_ps_tdma);
-			BTC_TRACE(trace_buf);
-			return;
-		}
-	}
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-
-
-	if (turn_on) {
-
-		/* enable TBTT nterrupt */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8, 0x1);
-
-		switch (type) {
-		default:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x35, 0x03, 0x11, 0x11);
-			break;
-		case 1:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x3a, 0x03, 0x11, 0x10);
-			break;
-		case 3:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x30, 0x03, 0x10, 0x50);
-			break;
-		case 4:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x21, 0x03, 0x10, 0x50);
-			break;
-		case 5:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x15, 0x3, 0x11, 0x11);
-			break;
-		case 6:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x20, 0x3, 0x11, 0x10);
-			break;
-		case 7:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x54 |
-						      psTdmaByte4Modify);
-			break;
-		case 8:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x14 |
-						      psTdmaByte4Modify);
-			break;
-		case 11:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x25, 0x03, 0x11,  0x10 |
-						      psTdmaByte4Modify);
-			break;
-		case 12:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x30, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 13:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x07, 0x10,  0x54 |
-						      psTdmaByte4Modify);
-			break;
-		case 14:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x15, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-		case 15:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x20, 0x03, 0x10,  0x10 |
-						      psTdmaByte4Modify);
-			break;
-		case 17:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x10, 0x03, 0x11,  0x14 |
-						      psTdmaByte4Modify);
-			break;
-		case 18:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x10, 0x03, 0x10,  0x50 |
-						      psTdmaByte4Modify);
-			break;
-
-		case 20:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x30, 0x03, 0x11, 0x10);
-			break;
-		case 22:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x25, 0x03, 0x11, 0x10);
-			break;
-		case 27:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x10, 0x03, 0x11, 0x15);
-			break;
-		case 32:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x35, 0x3, 0x11, 0x11);
-			break;
-		case 33:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x35, 0x03, 0x11, 0x10);
-			break;
-		case 41:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x45, 0x3, 0x11, 0x11);
-			break;
-		case 42:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x1e, 0x3, 0x10, 0x14 |
-						      psTdmaByte4Modify);
-			break;
-		case 43:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x45, 0x3, 0x10, 0x14);
-			break;
-		case 44:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x25, 0x3, 0x10, 0x10);
-			break;
-		case 45:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x29, 0x3, 0x10, 0x10);
-			break;
-		case 46:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x1a, 0x3, 0x10, 0x10);
-			break;
-		case 47:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x32, 0x3, 0x10, 0x10);
-			break;
-		case 48:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x29, 0x3, 0x10, 0x10);
-			break;
-		case 49:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x55, 0x10, 0x3, 0x10, 0x54);
-			break;
-		case 50:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x51, 0x4a, 0x3, 0x10, 0x10);
-			break;
-		case 51:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-					      0x61, 0x35, 0x3, 0x10, 0x11);
-			break;
-
-		}
-	} else {
-
-		switch (type) {
-		case 0:
-		default:  /* Software control, Antenna at BT side */
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-						      0x0, 0x0, 0x0, 0x0, 0x0);
-#if 0
-			halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_BT, FORCE_EXEC, FALSE,
-						     FALSE);
-#endif
-			break;
-#if 0
-/* 08:1ant:PTA Control -0x778=1-ant hw control,40:2ant:sw control-diversity */
-#endif
-		case 8:
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-						      0x8, 0x0, 0x0, 0x0, 0x0);
-#if 0
-			halbtc8822b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_PTA, FORCE_EXEC,  FALSE,
-				     FALSE);
-#endif
-			break;
-		case 9:   /* Software control, Antenna at WiFi side */
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-						      0x0, 0x0, 0x0, 0x0, 0x0);
-#if 0
-			halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_WIFI, FORCE_EXEC, FALSE, FALSE);
-#endif
-			break;
-		case 10:	/* under 5G , 0x778=1*/
-			halbtc8822b1ant_set_fw_pstdma(btcoexist,
-						      0x0, 0x0, 0x0, 0x0, 0x0);
-
-#if 0
-			halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_WIFI5G, FORCE_EXEC, FALSE,
-						     FALSE);
-#endif
-			break;
-		}
-	}
-
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		/* update pre state */
-		coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-		coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-	}
-}
-
-
-
-static
-void halbtc8822b1ant_sw_mechanism(IN struct btc_coexist *btcoexist,
-				  IN boolean low_penalty_ra)
-{
-	halbtc8822b1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra);
-}
-
-/* rf4 type by efuse, and for ant at main aux inverse use,
- * because is 2x2, and control types are the same, does not need
- */
-
-static
-void halbtc8822b1ant_set_rfe_type(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-
-	/* Ext switch buffer mux */
-	btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991, 0x3, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe, 0x8, 0x0);
-
-	/* the following setup should be got from Efuse in the future */
-	rfe_type->rfe_module_type = board_info->rfe_type;
-
-	rfe_type->ext_ant_switch_ctrl_polarity = 0;
-
-	switch (rfe_type->rfe_module_type) {
-	case 0:
-	default:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 1:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 2:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 3:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 4:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 5:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 6:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 7:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-			BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	}
-
-
-}
-
-/*anttenna control by bb mac bt antdiv pta to write 0x4c 0xcb4,0xcbd*/
-
-
-static
-void halbtc8822b1ant_set_ext_ant_switch(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u8 ctrl_type, IN u8 pos_type)
-{
-	boolean	switch_polatiry_inverse = FALSE;
-	u8		regval_0xcbd = 0, regval_0x64;
-	u32		u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-
-	/* Ext switch buffer mux */
-	btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991, 0x3, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe, 0x8, 0x0);
-
-	if (!rfe_type->ext_ant_switch_exist)
-		return;
-
-	coex_dm->cur_ext_ant_switch_status = (ctrl_type << 8)  + pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ext_ant_switch_status ==
-		    coex_dm->cur_ext_ant_switch_status)
-			return;
-	}
-
-	coex_dm->pre_ext_ant_switch_status = coex_dm->cur_ext_ant_switch_status;
-
-	/* swap control polarity if use different switch control polarity*/
-	/* Normal switch polarity for SPDT,
-	 * 0xcbd[1:0] = 2b'01 => Ant to BTG,
-	 * 0xcbd[1:0] = 2b'10 => Ant to WLG
-	 */
-	switch_polatiry_inverse = (rfe_type->ext_ant_switch_ctrl_polarity == 1 ?
-			   ~switch_polatiry_inverse : switch_polatiry_inverse);
-
-
-	switch (pos_type) {
-	default:
-	case BT_8822B_1ANT_EXT_ANT_SWITCH_TO_BT:
-	case BT_8822B_1ANT_EXT_ANT_SWITCH_TO_NOCARE:
-
-		break;
-	case BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLG:
-		break;
-	case BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLA:
-		break;
-	}
-
-
-	if (rfe_type->ext_ant_switch_type ==
-	    BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT) {
-		switch (ctrl_type) {
-		default:
-		case BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW:
-			/*  0x4c[23] = 0 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4e, 0x80,
-				0x0);
-			/* 0x4c[24] = 1 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4f, 0x01,
-				0x1);
-			/* BB SW, DPDT use RFE_ctrl8 and RFE_ctrl9 as ctrl pin*/
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcb4, 0xff,
-				0x77);
-
-			/* 0xcbd[1:0] = 2b'01 for no switch_polatiry_inverse,
-			 * ANTSWB =1, ANTSW =0
-			 */
-			regval_0xcbd = (!switch_polatiry_inverse ?  0x1 : 0x2);
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3,
-				regval_0xcbd);
-
-			break;
-		case BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA:
-			/* 0x4c[23] = 0 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4e, 0x80,
-				0x0);
-			/* 0x4c[24] = 1 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4f, 0x01,
-				0x1);
-			/* PTA,  DPDT use RFE_ctrl8 and RFE_ctrl9 as ctrl pin */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcb4, 0xff,
-				0x66);
-
-			/* 0xcbd[1:0] = 2b'10 for no switch_polatiry_inverse,
-			 * ANTSWB =1, ANTSW =0  @ GNT_BT=1
-			 */
-			regval_0xcbd = (!switch_polatiry_inverse ?  0x2 : 0x1);
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3,
-				regval_0xcbd);
-
-			break;
-		case BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV:
-			/* 0x4c[23] = 0 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4e, 0x80,
-				0x0);
-			/* 0x4c[24] = 1 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4f, 0x01,
-				0x1);
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcb4, 0xff,
-				0x88);
-
-			/* no regval_0xcbd setup required, because
-			 * antenna switch control value by antenna diversity
-			 */
-
-			break;
-		case BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC:
-			/*  0x4c[23] = 1 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4e, 0x80,
-				0x1);
-
-			/* 0x64[0] = 1b'0 for no switch_polatiry_inverse,
-			 * DPDT_SEL_N =1, DPDT_SEL_P =0
-			 */
-			regval_0x64 = (!switch_polatiry_inverse ?  0x0 : 0x1);
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x64, 0x1,
-				regval_0x64);
-			break;
-		case BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT:
-			/* 0x4c[23] = 0 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4e, 0x80,
-				0x0);
-			/* 0x4c[24] = 0 */
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x4f, 0x01,
-				0x0);
-
-			/* no setup required, because antenna switch control
-			 * value by BT vendor 0xac[1:0]
-			 */
-			break;
-		}
-	}
-
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcbc);
-	u32tmp2 = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0x64) & 0xff;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (After Ext Ant switch setup) 0xcbc = 0x%08x, 0x4c = 0x%08x, 0x64= 0x%02x**********\n",
-		    u32tmp1, u32tmp2, u32tmp3);
-	BTC_TRACE(trace_buf);
-
-
-}
-
-/* set gnt_wl gnt_bt control by sw high low, or
- * hwpta while in power on, ini, wlan off, wlan only, wl2g non-currrent,
- * wl2g current, wl5g
- */
-
-
-static
-void halbtc8822b1ant_set_ant_path(IN struct btc_coexist *btcoexist,
-				  IN u8 ant_pos_type, IN boolean force_exec,
-				  IN u8 phase)
-
-{
-#if BT_8822B_1ANT_COEX_DBG
-	u8			u8tmp = 0;
-#endif
-	u32			u32tmp1 = 0;
-#if BT_8822B_1ANT_COEX_DBG
-	u32			u32tmp2 = 0, u32tmp3 = 0;
-#endif
-
-	u32tmp1 = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-
-	/* To avoid indirect access fail  */
-	if (((u32tmp1 & 0xf000) >> 12) != ((u32tmp1 & 0x0f00) >> 8)) {
-		force_exec = TRUE;
-		coex_sta->gnt_error_cnt++;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex],(Before Ant Setup) 0x38= 0x%x\n",
-		    u32tmp1);
-		BTC_TRACE(trace_buf);
-	}
-
-	/* Ext switch buffer mux */
-	btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991, 0x3, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe, 0x8, 0x0);
-
-	coex_dm->cur_ant_pos_type = (ant_pos_type << 8)  + phase;
-
-	if (!force_exec) {
-		if (coex_dm->cur_ant_pos_type ==
-		    coex_dm->pre_ant_pos_type)
-			return;
-	}
-
-	coex_dm->pre_ant_pos_type = coex_dm->cur_ant_pos_type;
-
-#if BT_8822B_1ANT_COEX_DBG
-	u32tmp1 = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-	u32tmp2 = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0x54);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (Before Ant Setup) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n",
-		    u32tmp3, u8tmp, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-	switch (phase) {
-	case BT_8822B_1ANT_PHASE_COEX_INIT:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (set_ant_path - 1ANT_PHASE_COEX_INIT) **********\n");
-		BTC_TRACE(trace_buf);
-
-		/* Disable LTE Coex Function in WiFi side
-		 * (this should be on if LTE coex is required)
-		 */
-		halbtc8822b1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b1ant_ltecoex_set_coex_table(btcoexist,
-					       BT_8822B_1ANT_CTT_WL_VS_LTE,
-						       0xffff);
-
-		/* GNT_BT_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b1ant_ltecoex_set_coex_table(btcoexist,
-					       BT_8822B_1ANT_CTT_BT_VS_LTE,
-						       0xffff);
-
-		/* set GNT_BT to SW high */
-		halbtc8822b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_HIGH);
-
-		/* set GNT_WL to SW low */
-		halbtc8822b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_LOW);
-
-		/* set Path control owner to WL at initial step */
-		halbtc8822b1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8822B_1ANT_PCO_WLSIDE);
-
-		coex_sta->run_time_state = FALSE;
-
-		/* Ext switch buffer mux */
-		btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991,
-						   0x3, 0x0);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe,
-						   0x8, 0x0);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		break;
-	case BT_8822B_1ANT_PHASE_WLANONLY_INIT:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (set_ant_path - 1ANT_PHASE_WLANONLY_INIT) **********\n");
-		BTC_TRACE(trace_buf);
-
-		/* Disable LTE Coex Function in WiFi side
-		 * (this should be on if LTE coex is required)
-		 */
-		halbtc8822b1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b1ant_ltecoex_set_coex_table(btcoexist,
-					       BT_8822B_1ANT_CTT_WL_VS_LTE,
-						       0xffff);
-
-		/* GNT_BT_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b1ant_ltecoex_set_coex_table(btcoexist,
-					       BT_8822B_1ANT_CTT_BT_VS_LTE,
-						       0xffff);
-
-		/* set GNT_BT to SW Low */
-		halbtc8822b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_LOW);
-
-		/* Set GNT_WL to SW high */
-		halbtc8822b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_HIGH);
-
-		/* set Path control owner to WL at initial step */
-		halbtc8822b1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8822B_1ANT_PCO_WLSIDE);
-
-		coex_sta->run_time_state = FALSE;
-
-		/* Ext switch buffer mux */
-		btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991,
-						   0x3, 0x0);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe,
-						   0x8, 0x0);
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_WIFI;
-
-		break;
-	case BT_8822B_1ANT_PHASE_WLAN_OFF:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (set_ant_path - 1ANT_PHASE_WLAN_OFF) **********\n");
-		BTC_TRACE(trace_buf);
-
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8822b1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to BT */
-		halbtc8822b1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8822B_1ANT_PCO_BTSIDE);
-
-		/* Set Ext Ant Switch to BT control at wifi off step */
-		halbtc8822b1ant_set_ext_ant_switch(btcoexist,
-						   FORCE_EXEC,
-				   BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT,
-				   BT_8822B_1ANT_EXT_ANT_SWITCH_TO_NOCARE);
-
-		coex_sta->run_time_state = FALSE;
-
-		break;
-	case BT_8822B_1ANT_PHASE_2G_RUNTIME:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (set_ant_path - 1ANT_PHASE_2G_RUNTIME) **********\n");
-		BTC_TRACE(trace_buf);
-
-		/* set GNT_BT to PTA */
-		halbtc8822b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_1ANT_GNT_CTRL_BY_PTA,
-					   BT_8822B_1ANT_SIG_STA_SET_BY_HW);
-
-		/* Set GNT_WL to PTA */
-		halbtc8822b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_1ANT_GNT_CTRL_BY_PTA,
-					   BT_8822B_1ANT_SIG_STA_SET_BY_HW);
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8822b1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8822B_1ANT_PCO_WLSIDE);
-
-		coex_sta->run_time_state = TRUE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_PTA;
-
-		break;
-	case BT_8822B_1ANT_PHASE_5G_RUNTIME:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (set_ant_path - 1ANT_PHASE_5G_RUNTIME) **********\n");
-		BTC_TRACE(trace_buf);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8822b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_HIGH);
-
-		/* Set GNT_WL to SW Hi */
-		halbtc8822b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_HIGH);
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8822b1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8822B_1ANT_PCO_WLSIDE);
-
-		coex_sta->run_time_state = TRUE;
-
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type =
-				BTC_ANT_PATH_WIFI5G;
-
-		break;
-	case BT_8822B_1ANT_PHASE_BTMPMODE:
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (set_ant_path - 1ANT_PHASE_BTMPMODE) **********\n");
-		BTC_TRACE(trace_buf);
-
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8822b1ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8822b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_HIGH);
-
-		/* Set GNT_WL to SW Lo */
-		halbtc8822b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-						   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_LOW);
-
-		/* set Path control owner to WL */
-		halbtc8822b1ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8822B_1ANT_PCO_WLSIDE);
-
-		coex_sta->run_time_state = FALSE;
-
-		/* Set Ext Ant Switch to BT side at BT MP mode */
-		if (BTC_ANT_PATH_AUTO == ant_pos_type)
-			ant_pos_type = BTC_ANT_PATH_BT;
-
-		break;
-	}
-
-
-	if (phase != BT_8822B_1ANT_PHASE_WLAN_OFF) {
-		switch (ant_pos_type) {
-		case BTC_ANT_PATH_WIFI:
-			halbtc8822b1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLG);
-			break;
-		case BTC_ANT_PATH_WIFI5G
-				:
-			halbtc8822b1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLA);
-			break;
-		case BTC_ANT_PATH_BT:
-			halbtc8822b1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_TO_BT);
-			break;
-		default:
-		case BTC_ANT_PATH_PTA:
-			halbtc8822b1ant_set_ext_ant_switch(
-				btcoexist,
-				force_exec,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA,
-				BT_8822B_1ANT_EXT_ANT_SWITCH_TO_NOCARE);
-			break;
-		}
-
-	}
-#if BT_8822B_1ANT_COEX_DBG
-	u32tmp1 = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (After Ant Setup) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n",
-		    u32tmp3, u8tmp, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-#endif
-
-}
-
-
-
-static
-void halbtc8822b1ant_set_rx_gain(IN struct btc_coexist *btcoexist,
-				   IN boolean agc_table_en)
-{
-	u8		rssi_adjust_val = 0;
-
-	/* =================BB AGC Gain Table */
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-
-
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		btcoexist->btc_write_1byte(btcoexist, 0xc5b, 0xc8);
-		btcoexist->btc_write_1byte(btcoexist, 0xe5b, 0xc8);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xff000003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xae2e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xad300003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xac320003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xab360003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8d380003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8c3a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8b3c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8a3e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6e400003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6d420003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6c440003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6b460003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6a480003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x694a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x684c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x674e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x66500003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x65520003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x64540003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x64560003);
-
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x007e0403);
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BB Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		btcoexist->btc_write_1byte(btcoexist, 0xc5b, 0xd8);
-		btcoexist->btc_write_1byte(btcoexist, 0xe5b, 0xd8);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xff000003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xe62e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xe5300003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc8320003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc6360003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc5380003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc43a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc33c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc23e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc1400003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc0420003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa5440003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa4460003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa3480003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa24a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa14c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x834e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x82500003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x81520003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x80540003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x65560003);
-
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x007e0403);
-	}
-
-
-}
-
-
-static
-void halbtc8822b1ant_rx_gain(IN struct btc_coexist *btcoexist,
-			       IN boolean force_exec, IN boolean agc_table_en)
-{
-	coex_dm->cur_agc_table_en = agc_table_en;
-
-	if (!force_exec) {
-		if (coex_dm->pre_agc_table_en == coex_dm->cur_agc_table_en)
-			return;
-	}
-	halbtc8822b1ant_set_rx_gain(btcoexist, agc_table_en);
-
-	coex_dm->pre_agc_table_en = coex_dm->cur_agc_table_en;
-}
-
-
-static
-void halbtc8822b1ant_action_bt_idle(IN struct btc_coexist *btcoexist)
-{
-
-	boolean			wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (bt idle) **********\n");
-		BTC_TRACE(trace_buf);
-
-	if (!wifi_busy) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (bt idle wl not busy) **********\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-	} else {  /* if wl busy */
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-
-		if (BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-				     NORMAL_EXEC, 0);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE,
-				8);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** else(bt non connect idle wl not busy) **********\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-			     NORMAL_EXEC, 1);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 12);
-		}
-	}
-
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-}
-
-
-static
-boolean halbtc8822b1ant_is_common_action(IN struct btc_coexist *btcoexist)
-{
-	boolean			common = FALSE, wifi_connected = FALSE, wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_connected &&
-	    coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8822b1ant_sw_mechanism(btcoexist, FALSE); */
-
-		common = TRUE;
-	} else if (wifi_connected &&
-		   (coex_dm->bt_status ==
-		    BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi connected + BT non connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8822b1ant_sw_mechanism(btcoexist, FALSE); */
-
-		common = TRUE;
-	} else if (!wifi_connected &&
-		   (BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi non connected-idle + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8822b1ant_sw_mechanism(btcoexist, FALSE); */
-
-		common = TRUE;
-	} else if (wifi_connected &&
-		   (BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE ==
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi connected + BT connected-idle!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8822b1ant_sw_mechanism(btcoexist, FALSE); */
-
-		common = TRUE;
-	} else if (!wifi_connected &&
-		   (BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE !=
-		    coex_dm->bt_status)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Wifi non connected-idle + BT Busy!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* halbtc8822b1ant_sw_mechanism(btcoexist, FALSE); */
-
-		common = TRUE;
-	} else {
-		if (wifi_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		common = FALSE;
-	}
-
-	return common;
-}
-
-
-static
-void halbtc8822b1ant_action_wifi_under5g(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], under 5g start\n");
-	BTC_TRACE(trace_buf);
-	/* for test : s3 bt disappear , fail rate 1/600*/
-#if 0
-	halbtc8822b1ant_ignore_wlan_act(btcoexist, NORMAL_EXEC, TRUE);
-#endif
-	/*set sw gnt wl bt  high*/
-	btcoexist->btc_write_1byte_bitmask(
-			btcoexist, 0xcbd, 0x3, 1);
-	halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-	halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-	halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-#if 0
-	halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-	halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE, FALSE, 5);
-#endif
-}
-
-
-
-
-static
-void halbtc8822b1ant_action_wifi_only(IN struct btc_coexist *btcoexist)
-{
-	boolean wifi_under_5g = FALSE, rf4ce_enabled = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		halbtc8822b1ant_action_wifi_under5g(btcoexist);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (wlan only -- under 5g ) **********\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (rf4ce_enabled) {
-		btcoexist->btc_write_1byte_bitmask(
-			btcoexist, 0x45e, 0x8, 0x1);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-					TRUE,
-					50);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-		NORMAL_EXEC, 1);
-		return;
-	}
-	halbtc8822b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-	halbtc8822b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-
-	halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (wlan only -- under 2g ) **********\n");
-	BTC_TRACE(trace_buf);
-
-}
-
-static
-void halbtc8822b1ant_action_wifi_native_lps(IN struct btc_coexist *btcoexist)
-{
-	halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 5);
-
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-}
-
-
-/* *********************************************
- *
- *	Non-Software Coex Mechanism start
- *
- * ********************************************* */
-
-static
-void halbtc8822b1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex],action_bt_whck_test\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-	halbtc8822b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-	halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-}
-
-static
-void halbtc8822b1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex],action_wifi_multi_port\n");
-	BTC_TRACE(trace_buf);
-
-	/*halbtc8822b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-	halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);*/
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd, 0x3, 1);
-	halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-	halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-			BT_8822B_1ANT_PHASE_5G_RUNTIME);
-	halbtc8822b1ant_coex_table_with_type(btcoexist,
-			NORMAL_EXEC, 8);
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-
-
-}
-
-
-static
-void halbtc8822b1ant_action_hs(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], action_hs\n");
-	BTC_TRACE(trace_buf);
-	halbtc8822b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-	halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 5);
-
-
-}
-
-static
-void halbtc8822b1ant_action_bt_relink(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-	"[BTCoex], run bt multi link function\n");
-	BTC_TRACE(trace_buf);
-
-	if (coex_sta->is_bt_multi_link)
-		return;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-	"[BTCoex], run bt_re-link function\n");
-	BTC_TRACE(trace_buf);
-	halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-}
-
-#if 0
-static
-void halbtc8822b1ant_action_bt_idle(IN struct btc_coexist *btcoexist)
-{
-	boolean wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_busy) {
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-					6);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 3);
-
-	} else {  /* if wl busy */
-
-		if (BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						33);
-		} else {
-
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						32);
-
-		}
-
-	}
-
-}
-#endif
-
-/*"""bt inquiry"""" + wifi any + bt any*/
-
-static
-void halbtc8822b1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_connected = FALSE, ap_enable = FALSE, wifi_busy = FALSE,
-				bt_busy = FALSE, rf4ce_enabled = FALSE;
-
-
-	boolean		wifi_scan = FALSE, link = FALSE, roam = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** (bt inquiry) **********\n");
-	BTC_TRACE(trace_buf);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** scan = %d,  link =%d, roam = %d**********\n",
-		    wifi_scan, link, roam);
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-
-	if ((link) || (roam) || (coex_sta->wifi_is_high_pri_task)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (bt inquiry wifi  connect or scan ) **********\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 1);
-
-	} else if ((wifi_scan) && (coex_sta->bt_create_connection)) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-
-	} else if ((!wifi_connected) && (!wifi_scan)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (bt inquiry wifi non connect) **********\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-	} else if ((bt_link_info->a2dp_exist) && (bt_link_info->pan_exist)) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-
-	} else if (bt_link_info->a2dp_exist) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-
-	} else if (wifi_scan) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 20);
-
-
-	} else if (wifi_busy) {
-
-		/* for BT inquiry/page fail after S4 resume */
-#if 0
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 20);
-#endif
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-		     15);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-		/*aaaa->55aa for bt connect while wl busy*/
-
-		if (rf4ce_enabled) {
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0x45e, 0x8, 0x1);
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-						NORMAL_EXEC, 0);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-						TRUE,
-				50);
-		}
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (bt inquiry wifi connect) **********\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_set_ant_path(btcoexist,
-						     BTC_ANT_PATH_AUTO,
-						     NORMAL_EXEC,
-						     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-							 4);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-
-	}
-
-#if 0
-	if ((wifi_link) || (wifi_roam) || (coex_sta->wifi_is_high_pri_task)) {
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-
-	} else if ((wifi_scan) && (coex_sta->bt_create_connection)) {
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 6);
-
-	} else if ((!wifi_connected) && (!wifi_scan)) {
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	} else if ((bt_link_info->a2dp_exist) && (bt_link_info->pan_exist)) {
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	} else if (bt_link_info->a2dp_exist) {
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else if (wifi_scan) {
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 20);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-	} else if (wifi_busy) {
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	} else {
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 19);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-	}
-#endif
-}
-
-static
-void halbtc8822b1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = FALSE, wifi_busy = FALSE;
-	u32  wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-
-
-	if (bt_link_info->sco_exist) {
-		/*halbtc8822b1ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 5);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-					TRUE, 5);*/
-		btcoexist->btc_write_1byte_bitmask(
-			btcoexist, 0xcbd, 0x3, 1);
-		halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-	} else {
-
-		if (coex_sta->is_hid_low_pri_tx_overhead) {
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 6);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						18);
-		} else if (wifi_bw == 0) { /* if 11bg mode */
-
-			if (coex_sta->is_bt_multi_link) {
-				btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3, 1);
-			halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-			halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-			halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-				/*halbtc8822b1ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC, 11);
-				halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-							11);*/
-			} else {
-				btcoexist->btc_write_1byte_bitmask(
-			btcoexist, 0xcbd, 0x3, 1);
-			halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-			halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-			halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-				/*halbtc8822b1ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC, 6);
-				halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-				11);*/
-			}
-		} else {
-			btcoexist->btc_write_1byte_bitmask(
-			btcoexist, 0xcbd, 0x3, 1);
-			halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-			halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-			halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-			/*halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 6);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-				11);*/
-		}
-	}
-}
-
-static
-void halbtc8822b1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist
-		*btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean			wifi_busy = FALSE, wifi_turbo = FALSE;
-	u32  wifi_bw = 1;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy_level = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-
-	if ((coex_sta->bt_relink_downcount != 0)
-			&& (!bt_link_info->pan_exist) && (wifi_busy)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  BT Re-Link + A2DP + WL busy\n");
-		BTC_TRACE(trace_buf);
-
-		/*halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);*/
-		btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3, 1);
-		halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-	} else if ((bt_link_info->a2dp_exist) && (coex_sta->is_bt_a2dp_sink)) {
-		/*halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						12);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-		     NORMAL_EXEC, 6);*/
-		btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3, 1);
-		halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-	} else if (bt_link_info->a2dp_only) { /* A2DP */
-
-		/*halbtc8822b1ant_ps_tdma(btcoexist,
-				NORMAL_EXEC, TRUE, 7);
-
-		if (wifi_turbo)
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-			NORMAL_EXEC, 19);
-		else
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-			 NORMAL_EXEC, 4);*/
-		btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3, 1);
-		halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-	} else if (((bt_link_info->a2dp_exist) &&
-		    (bt_link_info->pan_exist)) ||
-		   (bt_link_info->hid_exist && bt_link_info->a2dp_exist &&
-		bt_link_info->pan_exist)) {
-		/* A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP) */
-
-		if (wifi_busy)
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-					TRUE, 13);
-		else
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-					14);
-
-		if (bt_link_info->hid_exist)
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-		else if (wifi_turbo)
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 19);
-		else
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-	} else if (bt_link_info->hid_exist &&
-		   bt_link_info->a2dp_exist) { /* HID+A2DP */
-
-		if (wifi_bw == 0) {/* if 11bg mode */
-			/*halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 21);*/
-			/*halbtc8822b1ant_set_wltoggle_coex_table(btcoexist,
-				NORMAL_EXEC, 1, 0x55, 0x55, 0x5a, 0x5a);*/
-			/*halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-						TRUE,
-						49);*/
-			btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3, 1);
-		halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-		} else {
-			/*halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 21);*/
-			/*halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					   TRUE, 8);*/
-			/*halbtc8822b1ant_set_wltoggle_coex_table(btcoexist,
-				NORMAL_EXEC, 1, 0x55, 0x55, 0x5a, 0x5a);*/
-			/*halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-						TRUE,
-						49);*/
-		btcoexist->btc_write_1byte_bitmask(
-				btcoexist, 0xcbd, 0x3, 1);
-		halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					BT_8822B_1ANT_PHASE_5G_RUNTIME);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-		}
-		/* PAN(OPP,FTP), HID+PAN(OPP,FTP) */
-
-	} else if ((bt_link_info->pan_only) || (bt_link_info->hid_exist && bt_link_info->pan_exist)) {
-
-		if (!wifi_busy)
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						4);
-		else
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						3);
-
-		if (bt_link_info->hid_exist)
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 1);
-		else if (wifi_turbo)
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 19);
-		else
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-						     NORMAL_EXEC, 4);
-	} else {
-		/* BT no-profile busy (0x9) */
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 33);
-	}
-
-}
-
-
-/*wifi not connected + bt action*/
-
-static
-void halbtc8822b1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)
-{
-	boolean rf4ce_enabled = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** (wifi not connect) **********\n");
-	BTC_TRACE(trace_buf);
-
-	/* tdma and coex table */
-	if (rf4ce_enabled) {
-		btcoexist->btc_write_1byte_bitmask(
-			btcoexist, 0x45e, 0x8, 0x1);
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-				NORMAL_EXEC, 1);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-					TRUE,
-					50);
-		return;
-	}
-	halbtc8822b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-	halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8822b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-}
-
-/*""""wl not connected scan"""" + bt action*/
-static
-void halbtc8822b1ant_action_wifi_not_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean bt_hs_on = FALSE;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = FALSE;
-	u8	agg_buf_size = 5;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (wifi non connect scan) **********\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if (num_of_wifi_link >= 2) {
-		halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-
-		if (coex_sta->c2h_bt_inquiry_page) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is Inquirying\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		} else {
-			halbtc8822b1ant_action_wifi_multi_port(btcoexist);
-		}
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8822b1ant_action_hs(btcoexist);
-		return;
-	}
-	/* tdma and coex table */
-	if (BT_8822B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						32);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						22);
-		} else {
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						20);
-		}
-	} else if ((BT_8822B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8822b1ant_action_bt_sco_hid_only_busy(btcoexist);
-	} else {
-		halbtc8822b1ant_set_ant_path(btcoexist,
-					BTC_ANT_PATH_AUTO,
-					NORMAL_EXEC,
-					BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-								     5);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-	}
-}
-
-/*""""wl not connected asso"""" + bt action*/
-
-static
-void halbtc8822b1ant_action_wifi_not_connected_asso_auth(
-	IN struct btc_coexist *btcoexist)
-{
-
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean bt_hs_on = FALSE;
-	u32 wifi_link_status = 0;
-	u32 num_of_wifi_link = 0;
-	boolean bt_ctrl_agg_buf_size = FALSE;
-	u8	agg_buf_size = 5;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (wifi non connect asso_auth) **********\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if (num_of_wifi_link >= 2) {
-
-		halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					   bt_ctrl_agg_buf_size,
-					   agg_buf_size);
-
-		if (coex_sta->c2h_bt_inquiry_page) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is Inquirying\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		} else {
-			halbtc8822b1ant_action_wifi_multi_port(
-				btcoexist);
-		}
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8822b1ant_action_hs(btcoexist);
-		return;
-	}
-
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist)  || (bt_link_info->hid_exist) ||
-	    (bt_link_info->a2dp_exist)) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 4);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-
-	} else if (bt_link_info->pan_exist) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 4);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 20);
-
-	} else {
-		halbtc8822b1ant_set_ant_path(btcoexist,
-				BTC_ANT_PATH_AUTO,
-				NORMAL_EXEC,
-				BT_8822B_1ANT_PHASE_2G_RUNTIME);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 2);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-
-	}
-}
-
-/*""""wl  connected scan"""" + bt action*/
-
-static
-void halbtc8822b1ant_action_wifi_connected_scan(IN struct btc_coexist
-		*btcoexist)
-{
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean bt_hs_on = FALSE;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = FALSE;
-	u8	agg_buf_size = 5;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** (wifi connect scan) **********\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if (num_of_wifi_link >= 2) {
-		halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-
-		if (coex_sta->c2h_bt_inquiry_page) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is Inquirying\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		} else {
-			halbtc8822b1ant_action_wifi_multi_port(btcoexist);
-		}
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8822b1ant_action_hs(btcoexist);
-		return;
-	}
-
-	/* tdma and coex table */
-	if (BT_8822B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-		if (bt_link_info->a2dp_exist) {
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						32);
-		} else if (bt_link_info->a2dp_exist &&
-			   bt_link_info->pan_exist) {
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						22);
-
-		} else {
-			halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						20);
-		}
-	} else if ((BT_8822B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-		   (BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-		    coex_dm->bt_status)) {
-		halbtc8822b1ant_action_bt_sco_hid_only_busy(btcoexist);
-	} else {
-#if 0
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-#endif
-		halbtc8822b1ant_set_ant_path(btcoexist,
-						BTC_ANT_PATH_AUTO,
-						NORMAL_EXEC,
-						BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-					1);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 20);
-#if 0
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-			     6);
-#endif
-
-	}
-}
-
-/*""""wl  connected specific packet"""" + bt action*/
-
-static
-void halbtc8822b1ant_action_wifi_connected_specific_packet(
-	IN struct btc_coexist *btcoexist)
-{
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean bt_hs_on = FALSE;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0;
-	boolean	bt_ctrl_agg_buf_size = FALSE;
-	u8	agg_buf_size = 5;
-	boolean wifi_busy = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (wifi connect specific packet) **********\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if (num_of_wifi_link >= 2) {
-		halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-		halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-
-		if (coex_sta->c2h_bt_inquiry_page) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is Inquirying\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		} else {
-			halbtc8822b1ant_action_wifi_multi_port(btcoexist);
-		}
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8822b1ant_action_hs(btcoexist);
-		return;
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* no specific packet process for both WiFi and BT very busy */
-	if ((wifi_busy) && ((bt_link_info->pan_exist) ||
-			    (coex_sta->num_of_profile >= 2)))
-		return;
-
-	/* tdma and coex table */
-	if ((bt_link_info->sco_exist) || (bt_link_info->hid_exist)) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-
-	} else if (bt_link_info->a2dp_exist) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     15);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 32);
-		/*for a2dp glitch,change from 1 to 15*/
-
-	} else if (bt_link_info->pan_exist) {
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     1);
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 20);
-
-	} else {
-
-		halbtc8822b1ant_set_ant_path(btcoexist,
-					BTC_ANT_PATH_AUTO,
-					NORMAL_EXEC,
-					BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-							     5);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-	}
-}
-
-static
-void halbtc8822b1ant_action_a2dpsink(IN struct btc_coexist *btcoexist)
-{
-
-	boolean wifi_busy = FALSE, wifi_turbo = FALSE;
-
-	btcoexist->btc_write_1byte_bitmask(
-			btcoexist, 0xcbd, 0x3, 1);
-	halbtc8822b1ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-	halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				BT_8822B_1ANT_PHASE_5G_RUNTIME);
-	halbtc8822b1ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-	halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 8);
-
-}
-
-/* wifi connected input point:
- * to set different ps and tdma case (+bt different case)
- */
-
-static
-void halbtc8822b1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-{
-
-	boolean	wifi_busy = FALSE, rf4ce_enabled = FALSE;
-	boolean		scan = FALSE, link = FALSE, roam = FALSE;
-	boolean		under_4way = FALSE, ap_enable = FALSE, wifi_under_5g = FALSE;
-	u8 wifi_rssi_state;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], CoexForWifiConnect()===>\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (wifi_under_5g) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under 5g<===\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b1ant_action_wifi_under5g(btcoexist);
-
-		return;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], CoexForWifiConnect(), return for wifi is under 2g<===\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (under_4way) {
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_action_wifi_connected_specific_packet(
-			btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	if (scan || link || roam) {
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		if (scan)
-			halbtc8822b1ant_action_wifi_connected_scan(btcoexist);
-		else
-			halbtc8822b1ant_action_wifi_connected_specific_packet(
-				btcoexist);
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	/* tdma and coex table */
-	if (!wifi_busy) {
-		if (BT_8822B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8822b1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist);
-		} else if ((BT_8822B_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8822b1ant_action_bt_sco_hid_only_busy(btcoexist);
-		} else {
-
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE,
-						8);
-
-			halbtc8822b1ant_set_ant_path(btcoexist,
-						     BTC_ANT_PATH_AUTO,
-						     NORMAL_EXEC,
-					     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-			if ((coex_sta->high_priority_tx) +
-			    (coex_sta->high_priority_rx) <= 60)
-				/*sy modify case16 -> case17*/
-				halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			else
-				halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-		}
-	} else {
-			halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		if (BT_8822B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) {
-			halbtc8822b1ant_action_wifi_connected_bt_acl_busy(
-				btcoexist);
-		} else if ((BT_8822B_1ANT_BT_STATUS_SCO_BUSY ==
-			    coex_dm->bt_status) ||
-			   (BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY ==
-			    coex_dm->bt_status)) {
-			halbtc8822b1ant_action_bt_sco_hid_only_busy(btcoexist);
-		} else {
-			if (rf4ce_enabled) {
-				btcoexist->btc_write_1byte_bitmask(
-					btcoexist, 0x45e, 0x8, 0x1);
-				halbtc8822b1ant_coex_table_with_type(btcoexist,
-				NORMAL_EXEC, 1);
-
-				halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE,
-							50);
-				return;
-			}
-
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE,
-						8);
-			halbtc8822b1ant_set_ant_path(btcoexist,
-						     BTC_ANT_PATH_AUTO,
-						     NORMAL_EXEC,
-					     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-#if 0
-			halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-								32);
-
-			halbtc8822b1ant_set_ant_path(btcoexist,
-			BTC_ANT_PATH_AUTO, NORMAL_EXEC, BT_8822B_1ANT_PHASE_2G_RUNTIME);
-#endif
-
-
-
-			wifi_rssi_state = halbtc8822b1ant_wifi_rssi_state(
-						  btcoexist, 1, 2, 25, 0);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** before  **********\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			if ((BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			     coex_dm->bt_status)  &&
-			    (coex_sta->scan_ap_num <= 3) &&
-			    (wifi_rssi_state == BTC_RSSI_STATE_LOW ||
-			     wifi_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-#endif
-			if (BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			    coex_dm->bt_status) {
-				if (rf4ce_enabled) {
-					btcoexist->btc_write_1byte_bitmask(
-						btcoexist, 0x45e, 0x8, 0x1);
-					halbtc8822b1ant_coex_table_with_type(btcoexist,
-								NORMAL_EXEC, 1);
-
-					halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-								TRUE,
-								50);
-					return;
-				}
-
-				halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			} else
-
-				halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-#if 0
-			else if ((coex_sta->high_priority_tx +
-							 coex_sta->high_priority_rx) <= 60)
-				halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 1);
-			else
-				halbtc8822b1ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-#endif
-		}
-	}
-}
-
-static
-void halbtc8822b1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-
-	u8				algorithm = 0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** (run sw coexmech) **********\n");
-	BTC_TRACE(trace_buf);
-	algorithm = halbtc8822b1ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-
-	if (halbtc8822b1ant_is_common_action(btcoexist)) {
-
-	} else {
-		switch (coex_dm->cur_algorithm) {
-		case BT_8822B_1ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_sco(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_hid(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_a2dp(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_a2dp_pan_hs(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_pan_edr(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HS mode.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_pan_hs(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_pan_edr_a2dp(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_A2DPSINK:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Action 2-Ant, algorithm = A2DP Sink.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_a2dpsink(btcoexist);
-			break;
-
-		case BT_8822B_1ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_pan_edr_hid(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_hid_a2dp_pan_edr(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_action_hid_a2dp(btcoexist);
-#endif
-			break;
-		case BT_8822B_1ANT_COEX_ALGO_NOPROFILEBUSY:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = No-Profile busy.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_bt_idle(btcoexist);
-			break;
-
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-#if 0
-			halbtc8822b1ant_coex_all_off(btcoexist);
-#endif
-			break;
-		}
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-	}
-}
-
-static
-void halbtc8822b1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean	wifi_connected = FALSE, bt_hs_on = FALSE;
-	boolean	increase_scan_dev_num = FALSE;
-	boolean	bt_ctrl_agg_buf_size = FALSE;
-	boolean	miracast_plus_bt = FALSE;
-	u8	agg_buf_size = 5;
-	u32	wifi_link_status = 0;
-	u32	num_of_wifi_link = 0, wifi_bw;
-	u8	iot_peer = BTC_IOT_PEER_UNKNOWN;
-	boolean wifi_under_5g = FALSE;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if ((coex_sta->under_lps) &&
-		(coex_dm->bt_status != BT_8822B_1ANT_BT_STATUS_ACL_BUSY)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RunCoexistMechanism(), wifi is under LPS !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_action_wifi_native_lps(btcoexist);
-		return;
-	}
-
-	if (!coex_sta->run_time_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], return for run_time_state = FALSE !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->freeze_coexrun_by_btinfo) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), return for freeze_coexrun_by_btinfo\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		halbtc8822b1ant_action_wifi_under5g(btcoexist);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], WiFi is under 2G!!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_action_bt_whck_test(btcoexist);
-		return;
-	}
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is disabled !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-		halbtc8822b1ant_action_wifi_only(btcoexist);
-		return;
-	}
-
-	if (coex_sta->is_setupLink) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is re-link !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_action_bt_relink(btcoexist);
-		return;
-	}
-
-	if ((BT_8822B_1ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8822B_1ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		increase_scan_dev_num = TRUE;
-	halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_INC_SCAN_DEV_NUM,
-			   &increase_scan_dev_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-
-		if (bt_link_info->bt_link_exist) {
-			halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1,
-						   0, 1);
-			miracast_plus_bt = TRUE;
-		} else {
-			halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0,
-						   0, 0);
-			miracast_plus_bt = FALSE;
-		}
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-		halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE,
-					   bt_ctrl_agg_buf_size, agg_buf_size);
-
-		if ((bt_link_info->a2dp_exist) &&
-		    (coex_sta->c2h_bt_inquiry_page)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Is Inquirying\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		} else {
-			halbtc8822b1ant_action_wifi_multi_port(btcoexist);
-		}
-
-		return;
-	}
-
-	miracast_plus_bt = FALSE;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-			   &miracast_plus_bt);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-
-	if ((bt_link_info->bt_link_exist) && (wifi_connected)) {
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 1, 1, 0, 1);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-		if (BTC_IOT_PEER_CISCO != iot_peer) {
-#if 0
-			if (bt_link_info->bt_hi_pri_link_exist)
-#endif
-			if (bt_link_info->sco_exist)
-				halbtc8822b1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, TRUE, FALSE, 0x5);
-			else
-				halbtc8822b1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, FALSE, FALSE, 0x5);
-		} else {
-		halbtc8822b1ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-			if (bt_link_info->sco_exist)
-				halbtc8822b1ant_limited_rx(btcoexist,
-					   NORMAL_EXEC, TRUE, FALSE, 0x5);
-			else {
-				if (BTC_WIFI_BW_HT40 == wifi_bw)
-					halbtc8822b1ant_limited_rx(btcoexist,
-						NORMAL_EXEC, FALSE, TRUE, 0x10);
-				else
-					halbtc8822b1ant_limited_rx(btcoexist,
-						NORMAL_EXEC, FALSE, TRUE, 0x8);
-			}
-		}
-
-		halbtc8822b1ant_sw_mechanism(btcoexist, TRUE);
-		halbtc8822b1ant_run_sw_coexist_mechanism(
-			btcoexist);  /* just print debug message */
-	} else {
-		halbtc8822b1ant_limited_tx(btcoexist, NORMAL_EXEC, 0, 0, 0, 0);
-
-		halbtc8822b1ant_limited_rx(btcoexist, NORMAL_EXEC, FALSE, FALSE,
-					   0x5);
-
-		halbtc8822b1ant_sw_mechanism(btcoexist, FALSE);
-		halbtc8822b1ant_run_sw_coexist_mechanism(
-			btcoexist); /* just print debug message */
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "############# [BTCoex],  BT Is Inquirying\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_action_bt_inquiry(btcoexist);
-		return;
-	} else if (bt_hs_on) {
-		halbtc8822b1ant_action_hs(btcoexist);
-		return;
-	}
-
-
-	if (!wifi_connected) {
-		boolean	scan = FALSE, link = FALSE, roam = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is non connected-idle !!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-
-		if (scan)
-			halbtc8822b1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		else if (link || roam)
-			halbtc8822b1ant_action_wifi_not_connected_asso_auth(
-				btcoexist);
-		else
-			halbtc8822b1ant_action_wifi_not_connected(btcoexist);
-	} else	/* wifi LPS/Busy */
-		halbtc8822b1ant_action_wifi_connected(btcoexist);
-}
-
-static
-void halbtc8822b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	/* force to reset coex mechanism */
-
-	halbtc8822b1ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-
-	/* sw all off */
-	halbtc8822b1ant_sw_mechanism(btcoexist, FALSE);
-
-#if 0
-	halbtc8822b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 8);
-	halbtc8822b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-#endif
-
-	coex_sta->pop_event_cnt = 0;
-}
-
-static
-void halbtc8822b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean back_up, IN boolean wifi_only)
-{
-
-	u8	u8tmp = 0, i = 0;
-	u32				u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp1 = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (Before Init HW config) 0xcb4 = 0x%x, 0x38= 0x%x, 0x54= 0x%x**********\n",
-		    u32tmp3, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 1Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	coex_sta->bt_coex_supported_feature = 0;
-	coex_sta->bt_coex_supported_version = 0;
-	coex_sta->bt_ble_scan_type = 0;
-	coex_sta->bt_ble_scan_para[0] = 0;
-	coex_sta->bt_ble_scan_para[1] = 0;
-	coex_sta->bt_ble_scan_para[2] = 0;
-	coex_sta->bt_reg_vendor_ac = 0xffff;
-	coex_sta->bt_reg_vendor_ae = 0xffff;
-	coex_sta->isolation_btween_wb = BT_8822B_1ANT_DEFAULT_ISOLATION;
-	coex_sta->gnt_error_cnt = 0;
-	coex_sta->bt_relink_downcount = 0;
-	coex_sta->is_set_ps_state_fail = FALSE;
-	coex_sta->cnt_set_ps_state_fail = 0;
-
-	for (i = 0; i <= 9; i++)
-		coex_sta->bt_afh_map[i] = 0;
-
-	/* Setup RF front end type */
-	halbtc8822b1ant_set_rfe_type(btcoexist);
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* BT report packet sample rate	 */
-	/* 0x790[5:0]=0x5 */
-	u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790);
-	u8tmp &= 0xc0;
-	u8tmp |= 0x5;
-	btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp);
-
-	/* Enable BT counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* Enable PTA (3-wire function form BT side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
-
-	/* Enable PTA (tx/rx signal form WiFi side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
-	/*GNT_BT=1 while select both */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x763, 0x10, 0x1);
-
-#if 0
-	/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x1);
-#endif
-
-	/* enable GNT_WL */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e, 0x40, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x1, 0x0);
-
-	if (btcoexist->btc_read_1byte(btcoexist, 0x80) == 0xc6)
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ONOFF, TRUE);
-
-	/* Antenna config */
-	if (coex_sta->is_rf_state_off) {
-
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_WLAN_OFF);
-
-		btcoexist->stop_coex_dm = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  halbtc8822b1ant_init_hw_config (RF Off)**********\n");
-		BTC_TRACE(trace_buf);
-	} else if (wifi_only) {
-
-		coex_sta->concurrent_rx_mode_on = FALSE;
-		halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_WIFI,
-					     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_WLANONLY_INIT);
-	} else {
-
-		coex_sta->concurrent_rx_mode_on = TRUE;
-
-		halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_COEX_INIT);
-	}
-
-	/* PTA parameter */
-	halbtc8822b1ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0);
-	halbtc8822b1ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-}
-
-#if (BTC_COEX_OFFLOAD == 1)
-void halbtc8822b1ant_wifi_info_notify(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			ap_num = 0;
-	s32			wifi_rssi = 0;
-	boolean			wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	h2c_para[0] = ap_num;					/* AP number */
-	h2c_para[1] = (u8)wifi_busy;		/* Busy */
-	h2c_para[2] = (u8)wifi_rssi;			/* RSSI */
-
-	btcoexist->btc_coex_h2c_process(btcoexist, COL_OP_WIFI_INFO_NOTIFY,
-					opcode_ver, &h2c_para[0], 3);
-}
-
-void halbtc8822b1ant_setManual(IN struct btc_coexist *btcoexist,
-			       IN boolean manual)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			set_type = 0;
-
-	if (manual)
-		set_type = 1;
-	else
-		set_type = 0;
-
-	h2c_para[0] = set_type;				/* set_type */
-
-	btcoexist->btc_coex_h2c_process(btcoexist, COL_OP_SET_CONTROL,
-					opcode_ver,
-					&h2c_para[0], 1);
-}
-
-/* ************************************************************
- * work around function start with wa_halbtc8822b1ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8822b1ant_
- * ************************************************************ */
-
-void ex_halbtc8822b1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	coex_sta->is_rf_state_off = FALSE;
-
-}
-void ex_halbtc8822b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{}
-void ex_halbtc8822b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{}
-static
-void ex_halbtc8822b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{}
-void ex_halbtc8822b1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			ips_notify = 0;
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		ips_notify = 1;
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	h2c_para[0] = ips_notify;		/* IPS notify */
-	h2c_para[1] = 0xff;			/* LPS notify */
-	h2c_para[2] = 0xff;			/* RF state notify */
-	h2c_para[3] = 0xff;			/* pnp notify */
-
-	btcoexist->btc_coex_h2c_process(btcoexist,
-					COL_OP_WIFI_POWER_STATE_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-void ex_halbtc8822b1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			lps_notify = 0;
-
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		lps_notify = 1;
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	h2c_para[0] = 0xff;			/* IPS notify */
-	h2c_para[1] = lps_notify;		/* LPS notify */
-	h2c_para[2] = 0xff;			/* RF state notify */
-	h2c_para[3] = 0xff;			/* pnp notify */
-
-	btcoexist->btc_coex_h2c_process(btcoexist,
-					COL_OP_WIFI_POWER_STATE_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-
-void ex_halbtc8822b1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			scan_start = 0;
-	boolean			under_4way = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-	if (BTC_SCAN_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify\n");
-		BTC_TRACE(trace_buf);
-		scan_start = 1;
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	h2c_para[0] = scan_start;		/* scan notify */
-	h2c_para[1] = 0xff;			/* connect notify */
-	h2c_para[2] = 0xff;			/* specific packet notify */
-	if (under_4way)
-		h2c_para[3] = 1;			/* under 4way progress */
-	else
-		h2c_para[3] = 0;
-
-	btcoexist->btc_coex_h2c_process(btcoexist, COL_OP_WIFI_PROGRESS_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-
-void ex_halbtc8822b1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			connect_start = 0;
-	boolean			under_4way = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-	if (BTC_ASSOCIATE_START == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-		connect_start = 1;
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	h2c_para[0] = 0xff;			/* scan notify */
-	h2c_para[1] = connect_start;	/* connect notify */
-	h2c_para[2] = 0xff;			/* specific packet notify */
-	if (under_4way)
-		h2c_para[3] = 1;			/* under 4way progress */
-	else
-		h2c_para[3] = 0;
-
-	btcoexist->btc_coex_h2c_process(btcoexist, COL_OP_WIFI_PROGRESS_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-
-void ex_halbtc8822b1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u32			wifi_bw;
-	u8			wifi_central_chnl;
-	u8			h2c_para[5] = {0};
-	u8			opcode_ver = 0;
-	u8			port = 0, connected = 0, freq = 0, bandwidth = 0, iot_peer = 0;
-	boolean			wifi_under_5g = FALSE;
-
-	if (BTC_MEDIA_CONNECT == type)
-		connected = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-	bandwidth = (u8)wifi_bw;
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g)
-		freq = 1;
-	else
-		freq = 0;
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_IOT_PEER, &iot_peer);
-
-	/* port need to be implemented in the future (p2p port, ...) */
-	h2c_para[0] = (connected << 4) | port;
-	h2c_para[1] = (freq << 4) | bandwidth;
-	h2c_para[2] = wifi_central_chnl;
-	h2c_para[3] = iot_peer;
-	btcoexist->btc_coex_h2c_process(btcoexist, COL_OP_WIFI_STATUS_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-
-void ex_halbtc8822b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			connect_start = 0;
-	boolean			under_4way = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	h2c_para[0] = 0xff;			/* scan notify */
-	h2c_para[1] = 0xff;			/* connect notify */
-	h2c_para[2] = type;			/* specific packet notify */
-	if (under_4way)
-		h2c_para[3] = 1;			/* under 4way progress */
-	else
-		h2c_para[3] = 0;
-
-	btcoexist->btc_coex_h2c_process(btcoexist, COL_OP_WIFI_PROGRESS_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-
-void ex_halbtc8822b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{}
-void ex_halbtc8822b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			rfstate_notify = 0;
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-		rfstate_notify = 1;
-		coex_sta->is_rf_state_off = FALSE;
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->is_rf_state_off = TRUE;
-	}
-
-	h2c_para[0] = 0xff;			/* IPS notify */
-	h2c_para[1] = 0xff;			/* LPS notify */
-	h2c_para[2] = rfstate_notify;	/* RF state notify */
-	h2c_para[3] = 0xff;			/* pnp notify */
-
-	btcoexist->btc_coex_h2c_process(btcoexist,
-					COL_OP_WIFI_POWER_STATE_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-
-void ex_halbtc8822b1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{}
-void ex_halbtc8822b1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	u8			h2c_para[4] = {0};
-	u8			opcode_ver = 0;
-	u8			pnp_notify = 0;
-
-	if (BTC_WIFI_PNP_SLEEP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-		pnp_notify = 1;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-	}
-
-	h2c_para[0] = 0xff;			/* IPS notify */
-	h2c_para[1] = 0xff;			/* LPS notify */
-	h2c_para[2] = 0xff;			/* RF state notify */
-	h2c_para[3] = pnp_notify;		/* pnp notify */
-
-	btcoexist->btc_coex_h2c_process(btcoexist,
-					COL_OP_WIFI_POWER_STATE_NOTIFY,
-					opcode_ver, &h2c_para[0], 4);
-}
-
-void ex_halbtc8822b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)
-{}
-void ex_halbtc8822b1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8822b1ant_wifi_info_notify(btcoexist);
-}
-
-void ex_halbtc8822b1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_stack_info		*stack_info = &btcoexist->stack_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, bt_info_ext, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0;
-	u32			phyver = 0;
-	boolean			lte_coex_on = FALSE;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s / %d",
-			   "Ant PG Num/ Mech/ Pos/ RFE",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   rfe_type->rfe_module_type);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s/ %d  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos/ RFE",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   rfe_type->rfe_module_type,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-		if (board_info->btdm_ant_det_finish) {
-			if (psd_scan->ant_det_result != 12)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
-					"Ant Det PSD Value",
-					psd_scan->ant_det_peak_val);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					"\r\n %-35s = %d",
-					"Ant Det PSD Value",
-				psd_scan->ant_det_psd_scan_peak_val / 100);
-
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)",
-		   "CoexVer/ FwVer/ PatchVer",
-		   glcoex_ver_date_8822b_1ant, glcoex_ver_8822b_1ant, fw_ver,
-		   bt_patch_ver, bt_patch_ver);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "Wifi channel informed to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s",
-		   "WifibHiPri/ Ccklock/ CckEverLock",
-		   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-		   (coex_sta->cck_lock ? "Yes" : "No"),
-		   (coex_sta->cck_ever_lock ? "Yes" : "No"));
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s/ %d/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-		   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page scan")
-			   : ((BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE == coex_dm->bt_status)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-	if (coex_sta->num_of_profile != 0)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %s%s%s%s%s",
-			"Profiles",
-			((bt_link_info->a2dp_exist) ? "A2DP," : ""),
-			((bt_link_info->sco_exist) ?  "SCO," : ""),
-			((bt_link_info->hid_exist) ?
-			((coex_sta->hid_busy_num >= 2) ? "HID(4/18)," : "HID(2/18),") : ""),
-			((bt_link_info->pan_exist) ?  "PAN," : ""),
-			((coex_sta->voice_over_HOGP) ? "Voice" : ""));
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = None", "Profiles");
-
-	CL_PRINTF(cli_buf);
-
-	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			"A2DP Rate/Bitpool/Auto_Slot",
-			((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
-			coex_sta->a2dp_bit_pool,
-			((coex_sta->is_autoslot) ? "On" : "Off"));
-		CL_PRINTF(cli_buf);
-	}
-
-	if (bt_link_info->hid_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "HID PairNum/Forbid_Slot",
-			 coex_sta->hid_pair_cnt,
-			 coex_sta->forbidden_slot
-			 );
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %s/ 0x%x/ 0x%x",
-		"Role/IgnWlanAct/Feature/BLEScan",
-		((bt_link_info->slave_role) ? "Slave" : "Master"),
-		((coex_dm->cur_ignore_wlan_act) ? "Yes":"No"),
-		coex_sta->bt_coex_supported_feature,
-		coex_sta->bt_ble_scan_type);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-				   "ReInit/ReLink/IgnWlact/Page/NameReq",
-			 coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-			 coex_sta->cnt_IgnWlanAct,
-				 coex_sta->cnt_Page,
-			 coex_sta->cnt_RemoteNameReq
-			 );
-		CL_PRINTF(cli_buf);
-
-	halbtc8822b1ant_read_score_board(btcoexist,	&u16tmp[0]);
-
-	if ((coex_sta->bt_reg_vendor_ae == 0xffff) ||
-	    (coex_sta->bt_reg_vendor_ac == 0xffff))
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = x/ x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard", u16tmp[0]);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard",
-			 ((coex_sta->bt_reg_vendor_ae & BIT(4))>>4),
-			   coex_sta->bt_reg_vendor_ac & 0x3, u16tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	for (i = 0; i < BT_INFO_SRC_8822B_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8822b_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[mechanisms] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[mechanisms]============");
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "SM[LowPenaltyRA]",
-		   coex_dm->cur_low_penalty_ra);
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x case-%d (%s,%s)",
-		   "PS TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "On" : "Off"),
-		   (coex_dm->auto_tdma_adjust ? "Adj" : "Fix"));
-
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
-		   "WL/BT Coex Table Type",
-		   coex_sta->coex_table_type);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x6c0/0x6c4/0x6c8(coexTable)",
-		   u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
-		   "0x778/0x6cc/IgnWlanAct",
-		   u8tmp[0], u32tmp[0],  coex_dm->cur_ignore_wlan_act);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0xa0);
-	u32tmp[1] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0xa4);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "LTE Coex Table W_L/B_L",
-		   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0xa8);
-	u32tmp[1] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0xac);
-	u32tmp[2] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0xb0);
-	u32tmp[3] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-			0xb4);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "LTE Break Table W_L/B_L/L_W/L_B",
-		   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff,
-		   u32tmp[2] & 0xffff, u32tmp[3] & 0xffff);
-	CL_PRINTF(cli_buf);
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-#if 0
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x430);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x434);
-	u16tmp[0] = btcoexist->btc_read_2byte(btcoexist, 0x42a);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x456);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
-		   "0x430/0x434/0x42a/0x456",
-		   u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0]);
-	CL_PRINTF(cli_buf);
-#endif
-
-	u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp[1] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %s",
-		   "LTE CoexOn/Path Ctrl Owner",
-		   (int)((u32tmp[0]&BIT(7)) >> 7),
-		   ((u8tmp[0]&BIT(2)) ? "WL" : "BT"));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "LTE 3Wire/OPMode/UART/UARTMode",
-		   (int)((u32tmp[0]&BIT(6)) >> 6),
-		   (int)((u32tmp[0] & (BIT(5) | BIT(4))) >> 4),
-		   (int)((u32tmp[0]&BIT(3)) >> 3),
-		   (int)(u32tmp[0] & (BIT(2) | BIT(1) | BIT(0))));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s",
-		   "GNT_WL_SWCtrl/GNT_BT_SWCtrl/Dbg",
-		   (int)((u32tmp[0]&BIT(12)) >> 12),
-		   (int)((u32tmp[0]&BIT(14)) >> 14),
-		   ((u8tmp[0]&BIT(3)) ? "On" : "Off"));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "GNT_WL/GNT_BT/LTE_Busy/UART_Busy",
-		   (int)((u32tmp[0]&BIT(2)) >> 2),
-		   (int)((u32tmp[0]&BIT(3)) >> 3),
-		   (int)((u32tmp[0]&BIT(1)) >> 1), (int)(u32tmp[0]&BIT(0)));
-	CL_PRINTF(cli_buf);
-
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x4c6[4]/0x40[5] (WL/BT PTA)",
-		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x953);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ %s",
-		   "0x550(bcn ctrl)/0x522/4-RxAGC",
-		   u32tmp[0], u8tmp[0], (u8tmp[1] & 0x2) ? "On" : "Off");
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xda0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xda4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0xda8);
-	u32tmp[3] = btcoexist->btc_read_4byte(btcoexist, 0xcf0);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xa5b);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0xa5c);
-
-	fa_ofdm = ((u32tmp[0] & 0xffff0000) >> 16) + ((u32tmp[1] & 0xffff0000)
-			>> 16) + (u32tmp[1] & 0xffff) + (u32tmp[2] & 0xffff) +
-		   ((u32tmp[3] & 0xffff0000) >> 16) + (u32tmp[3] &
-				   0xffff);
-	fa_cck = (u8tmp[0] << 8) + u8tmp[1];
-
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xc50);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "0xc50/OFDM-CCA/OFDM-FA/CCK-FA",
-		   u32tmp[1] & 0xff, u32tmp[0] & 0xffff, fa_ofdm, fa_cck);
-	CL_PRINTF(cli_buf);
-
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11n-Agg",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_agg);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11n-Agg",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_agg);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(high-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x774(low-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx);
-	CL_PRINTF(cli_buf);
-#if (BT_AUTO_REPORT_ONLY_8822B_1ANT == 1)
-	/* halbtc8822b1ant_monitor_bt_ctr(btcoexist); */
-#endif
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-void ex_halbtc8822b1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{}
-void ex_halbtc8822b1ant_display_ant_detection(IN struct btc_coexist *btcoexist)
-{}
-void ex_halbtc8822b1ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata)
-{
-	switch (op_code) {
-	case BTC_DBG_SET_COEX_MANUAL_CTRL: {
-		boolean		manual = (boolean) *pdata;
-
-		halbtc8822b1ant_setManual(btcoexist, manual);
-	}
-	break;
-	default:
-		break;
-	}
-}
-
-#else
-void ex_halbtc8822b1ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x0;
-	u16 u16tmp = 0x0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx Execute 8822b 1-Ant PowerOn Setting!! xxxxxxxxxxxxxxxx\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "Ant Det Finish = %s, Ant Det Number  = %d\n",
-		    board_info->btdm_ant_det_finish ? "Yes" : "No",
-		    board_info->btdm_ant_num_by_ant_det);
-	BTC_TRACE(trace_buf);
-
-	btcoexist->stop_coex_dm = TRUE;
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly. */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-	/* set Path control owner to WiFi */
-	halbtc8822b1ant_ltecoex_pathcontrol_owner(btcoexist,
-			BT_8822B_1ANT_PCO_WLSIDE);
-
-	/* set GNT_BT to high */
-	halbtc8822b1ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_HIGH);
-	/* Set GNT_WL to low */
-	halbtc8822b1ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_1ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_1ANT_GNT_CTRL_BY_SW,
-					   BT_8822B_1ANT_SIG_STA_SET_TO_LOW);
-
-	/* set WLAN_ACT = 0 */
-	/* btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4); */
-
-	/* SD1 Chunchu red x issue */
-	btcoexist->btc_write_1byte(btcoexist, 0xff1a, 0x0);
-
-	halbtc8822b1ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-	/* */
-	/* S0 or S1 setting and Local register setting
-	 * (By the setting fw can get ant number, S0/S1, ... info)
-	 */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==>
-	 *       BIT1=0 and BIT2=0
-	 */
-
-	u8tmp = 0;
-	board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-
-	if (btcoexist->chip_interface == BTC_INTF_USB)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60, u8tmp);
-
-	BTC_TRACE(trace_buf);
-
-
-}
-
-void ex_halbtc8822b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-}
-
-void ex_halbtc8822b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** (ini hw config) **********\n");
-
-	halbtc8822b1ant_init_hw_config(btcoexist, TRUE, wifi_only);
-	btcoexist->stop_coex_dm = FALSE;
-}
-
-void ex_halbtc8822b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->stop_coex_dm = FALSE;
-
-	halbtc8822b1ant_init_coex_dm(btcoexist);
-
-	halbtc8822b1ant_query_bt_info(btcoexist);
-}
-
-
-void ex_halbtc8822b1ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, ps_tdma_case = 0;
-	u16				u16tmp[4];
-	u32				u32tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0;
-	u32			phyver = 0;
-	boolean			lte_coex_on = FALSE;
-	static u8 cnt = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-	if (btcoexist->stop_coex_dm) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ============[Coex is STOPPED]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->bt_coex_supported_feature == 0)
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_FEATURE,
-						&coex_sta->bt_coex_supported_feature);
-
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			(coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		if (coex_sta->bt_reg_vendor_ac == 0xffff)
-			coex_sta->bt_reg_vendor_ac = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xac) & 0xffff);
-
-		if (coex_sta->bt_reg_vendor_ae == 0xffff)
-			coex_sta->bt_reg_vendor_ae = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xae) & 0xffff);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-						&bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-		if (coex_sta->num_of_profile > 0) {
-			cnt++;
-
-			if (cnt >= 3) {
-				btcoexist->btc_get_bt_afh_map_from_bt(btcoexist, 0,
-					&coex_sta->bt_afh_map[0]);
-				cnt = 0;
-			}
-		}
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s / %d",
-			   "Ant PG Num/ Mech/ Pos/ RFE",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   rfe_type->rfe_module_type);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s/ %d  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos/ RFE",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   rfe_type->rfe_module_type,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-		if (board_info->btdm_ant_det_finish) {
-
-			if (psd_scan->ant_det_result != 12)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_peak_val);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %d",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_psd_scan_peak_val
-					   / 100);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-
-	bt_coex_ver = ((coex_sta->bt_coex_supported_version & 0xff00) >> 8);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8822b_1ant, glcoex_ver_8822b_1ant,
-		   glcoex_ver_btdesired_8822b_1ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (coex_sta->bt_disabled ? "BT-disable" :
-		     (bt_coex_ver >= glcoex_ver_btdesired_8822b_1ant ?
-		      "Match" : "Mis-Match"))));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "AFH Map to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = [%s/ %d dBm/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-			   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page")
-			   : ((BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((coex_dm->bt_status == BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-	if (coex_sta->num_of_profile != 0)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %s%s%s%s%s",
-			   "Profiles",
-			   ((bt_link_info->a2dp_exist) ?
-			   ((coex_sta->is_bt_a2dp_sink) ? "A2DP sink," :
-			    "A2DP,") : ""),
-			   ((bt_link_info->sco_exist) ?  "HFP," : ""),
-			   ((bt_link_info->hid_exist) ?
-			    ((coex_sta->hid_busy_num >= 2) ? "HID(4/18)," :
-			     "HID(2/18),") : ""),
-			   ((bt_link_info->pan_exist) ?  "PAN," : ""),
-			   ((coex_sta->voice_over_HOGP) ? "Voice" : ""));
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = None", "Profiles");
-
-	CL_PRINTF(cli_buf);
-
-	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			   "A2DP Rate/Bitpool/Auto_Slot",
-			   ((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
-			   coex_sta->a2dp_bit_pool,
-			   ((coex_sta->is_autoslot) ? "On" : "Off")
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	if (bt_link_info->hid_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "HID PairNum/Forbid_Slot",
-			   coex_sta->hid_pair_cnt,
-			   coex_sta->forbidden_slot
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
-				"Role/RoleSwCnt/IgnWlact/Feature",
-				((bt_link_info->slave_role) ? "Slave" : "Master"),
-				coex_sta->cnt_RoleSwitch,
-				((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
-				coex_sta->bt_coex_supported_feature);
-	CL_PRINTF(cli_buf);
-
-	if ((coex_sta->bt_ble_scan_type & 0x7) != 0x0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			"BLEScan Type/TV/Init/Ble",
-			coex_sta->bt_ble_scan_type,
-			(coex_sta->bt_ble_scan_type & 0x1 ?
-			coex_sta->bt_ble_scan_para[0] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x2 ?
-			coex_sta->bt_ble_scan_para[1] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x4 ?
-			coex_sta->bt_ble_scan_para[2] : 0x0));
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-		   "ReInit/ReLink/IgnWlact/Page/NameReq",
-		   coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-		   coex_sta->cnt_IgnWlanAct,
-		   coex_sta->cnt_Page,
-		   coex_sta->cnt_RemoteNameReq
-		  );
-	CL_PRINTF(cli_buf);
-
-	halbtc8822b1ant_read_score_board(btcoexist,	&u16tmp[0]);
-
-	if ((coex_sta->bt_reg_vendor_ae == 0xffff) ||
-	    (coex_sta->bt_reg_vendor_ac == 0xffff))
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = x/ x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard", u16tmp[0]);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard",
-			   (int)((coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
-			   coex_sta->bt_reg_vendor_ac & 0x3, u16tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	if (coex_sta->num_of_profile > 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x",
-			"AFH MAP",
-			coex_sta->bt_afh_map[0],
-			coex_sta->bt_afh_map[1],
-			coex_sta->bt_afh_map[2],
-			coex_sta->bt_afh_map[3],
-			coex_sta->bt_afh_map[4],
-			coex_sta->bt_afh_map[5],
-			coex_sta->bt_afh_map[6],
-			coex_sta->bt_afh_map[7],
-			coex_sta->bt_afh_map[8],
-			coex_sta->bt_afh_map[9]
-			   );
-		CL_PRINTF(cli_buf);
-	}
-
-	for (i = 0; i < BT_INFO_SRC_8822B_1ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8822b_1ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[mechanisms] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[Mechanisms]============");
-
-	CL_PRINTF(cli_buf);
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x (case-%d, %s)",
-		   "TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "TDMA On" : "TDMA Off"));
-
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d/ 0x%x/ 0x%x/ 0x%x",
-		   "Table/0x6c0/0x6c4/0x6c8",
-		   coex_sta->coex_table_type, u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x778/0x6cc",
-		   u8tmp[0], u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
-		   "AntDiv/BtCtrlLPS/LPRA/PsFail",
-		   ((board_info->ant_div_cfg) ? "On" : "Off"),
-		   ((coex_sta->force_lps_ctrl) ? "On" : "Off"),
-		   ((coex_dm->cur_low_penalty_ra) ? "On" : "Off"),
-		   coex_sta->cnt_set_ps_state_fail);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ?  TRUE : FALSE;
-
-	if (lte_coex_on) {
-
-		u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa0);
-		u32tmp[1] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa4);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-			   "LTE Coex Table W_L/B_L",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff);
-		CL_PRINTF(cli_buf);
-
-		u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa8);
-		u32tmp[1] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xac);
-		u32tmp[2] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb0);
-		u32tmp[3] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb4);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			   "LTE Break Table W_L/B_L/L_W/L_B",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff,
-			   u32tmp[2] & 0xffff, u32tmp[3] & 0xffff);
-		CL_PRINTF(cli_buf);
-	}
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp[1] = halbtc8822b1ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s",
-		   "LTE Coex/Path Owner",
-		   ((lte_coex_on) ? "On" : "Off"),
-		   ((u8tmp[0] & BIT(2)) ? "WL" : "BT"));
-	CL_PRINTF(cli_buf);
-
-	if (lte_coex_on) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %d/ %d",
-			   "LTE 3Wire/OPMode/UART/UARTMode",
-			   (int)((u32tmp[0] & BIT(6)) >> 6),
-			   (int)((u32tmp[0] & (BIT(5) | BIT(4))) >> 4),
-			   (int)((u32tmp[0] & BIT(3)) >> 3),
-			   (int)(u32tmp[0] & (BIT(2) | BIT(1) | BIT(0))));
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "LTE_Busy/UART_Busy",
-			   (int)((u32tmp[1] & BIT(1)) >> 1),
-			   (int)(u32tmp[1] & BIT(0)));
-		CL_PRINTF(cli_buf);
-	}
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %s (BB:%s)/ %s (BB:%s)/ %s %d",
-		   "GNT_WL_Ctrl/GNT_BT_Ctrl/Dbg",
-		   ((u32tmp[0] & BIT(12)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(8)) ?  "SW" : "HW"),
-		   ((u32tmp[0] & BIT(14)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(10)) ?  "SW" : "HW"),
-		   ((u8tmp[0] & BIT(3)) ? "On" : "Off"),
-		   coex_sta->gnt_error_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "GNT_WL/GNT_BT",
-		   (int)((u32tmp[1] & BIT(2)) >> 2),
-		   (int)((u32tmp[1] & BIT(3)) >> 3));
-	CL_PRINTF(cli_buf);
-
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xcb0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xcba);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%04x/ 0x%04x/ 0x%02x %s",
-		   "0xcb0/0xcb4/0xcb8[23:16]",
-		   u32tmp[0], u32tmp[1], u8tmp[0],
-		   ((u8tmp[0] & 0x1) == 0x1 ?  "(BTG)" :   "(WL_A+G)"));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x64);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "4c[24:23]/64[0]/4c6[4]/40[5]",
-		   (int)((u32tmp[0] & (BIT(24) | BIT(23))) >> 23),
-		   u8tmp[2] & 0x1,
-		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x953);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0xc50);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ %s/ 0x%x",
-		   "0x550/0x522/4-RxAGC/0xc50",
-		u32tmp[0], u8tmp[0], (u8tmp[1] & 0x2) ? "On" : "Off", u8tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm);
-	CL_PRINTF(cli_buf);
-
-
-#if 1
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11ac",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_Err CCK/11g/11n/11ac",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht);
-	CL_PRINTF(cli_buf);
-#endif
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
-		   "WlHiPri/ Locking/ Locked/ Noisy",
-		   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-		   (coex_sta->cck_lock ? "Yes" : "No"),
-		   (coex_sta->cck_ever_lock ? "Yes" : "No"),
-		   coex_sta->wl_noisy_level);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(Hi-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-		   "0x774(Lo-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx,
-		   (bt_link_info->slave_role ? "(Slave!!)" : (
-		   coex_sta->is_tdma_btautoslot_hang ? "(auto-slot hang!!)" : "")));
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-void ex_halbtc8822b1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-
-	if (BTC_IPS_ENTER == type) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = TRUE;
-
-		/* Write WL "Active" in Score-board for LPS off */
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-				BT_8822B_1ANT_SCOREBOARD_ACTIVE, FALSE);
-
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-				BT_8822B_1ANT_SCOREBOARD_ONOFF, FALSE);
-		halbtc8822b1ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-		halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_WLAN_OFF);
-
-
-	} else if (BTC_IPS_LEAVE == type) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-				BT_8822B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-				BT_8822B_1ANT_SCOREBOARD_ONOFF, TRUE);
-
-		/*leave IPS : run ini hw config (exclude wifi only)*/
-		halbtc8822b1ant_init_hw_config(btcoexist, FALSE, FALSE);
-		/*sw all off*/
-		halbtc8822b1ant_init_coex_dm(btcoexist);
-		/*leave IPS : Query bt info*/
-		halbtc8822b1ant_query_bt_info(btcoexist);
-
-		coex_sta->under_ips = FALSE;
-	}
-}
-
-void ex_halbtc8822b1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	static boolean  pre_force_lps_on = FALSE;
-
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (type == BTC_LPS_ENABLE) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = TRUE;
-
-		if (coex_sta->force_lps_ctrl) { /* LPS No-32K */
-			/* Write WL "Active" in Score-board for PS-TDMA */
-			pre_force_lps_on = TRUE;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify-force LPS control\n");
-		BTC_TRACE(trace_buf);
-			halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-		} else {
-			/* LPS-32K, need check if this h2c 0x71 can work??
-			 * (2015/08/28)
-			 */
-			/* Write WL "Non-Active" in Score-board for Native-PS */
-			pre_force_lps_on = FALSE;
-			halbtc8822b1ant_post_state_to_bt(btcoexist,
-				 BT_8822B_1ANT_SCOREBOARD_ACTIVE, FALSE);
-		}
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = FALSE;
-
-		/* Write WL "Active" in Score-board for LPS off */
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		if ((!pre_force_lps_on) && (!coex_sta->force_lps_ctrl))
-			halbtc8822b1ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8822b1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean	wifi_connected = FALSE;
-	boolean wifi_under_5g = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	coex_sta->freeze_coexrun_by_btinfo = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	if (wifi_connected)
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** WL connected before SCAN\n");
-	else
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  WL is not connected before SCAN\n");
-
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_query_bt_info(btcoexist);
-
-		/*2.4 g 1*/
-	if (BTC_SCAN_START == type) {
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-		/*5 g 1*/
-
-		if (wifi_under_5g) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** (scan_notify_5g_scan_action 1) **********\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_wifi_under5g(btcoexist);
-			return;
-		}
-
-		/* 2.4G.2.3*/
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (scan_notify_start action) **********\n");
-		BTC_TRACE(trace_buf);
-
-		if (!wifi_connected) {	/* non-connected scan */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** wifi not connected 2g scan action 1 **********\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		} else {	/* wifi is connected */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** wifi connected 2g scan action 2 **********\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_wifi_connected_scan(
-				btcoexist);
-		}
-
-		return;
-	}
-
-	if (BTC_SCAN_START_2G == type) {
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (scan_notify_2g_sacn_start_for_switch_band_used) **********\n");
-		BTC_TRACE(trace_buf);
-
-		if (!wifi_connected) {	/* non-connected scan */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** wifi not connected 2g scan action 3 **********\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b1ant_action_wifi_not_connected_scan(
-				btcoexist);
-		} else	{ /* wifi is connected */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** wifi connected 2g sacn action 4**********\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_wifi_connected_scan(btcoexist);
-		}
-	} else {
-		coex_sta->wifi_is_high_pri_task = FALSE;
-
-		/* 2.4G 5 WL scan finish, then get and update sacn ap numbers */
-		/*5 g 4*/
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (scan_finish_notify) **********\n");
-		BTC_TRACE(trace_buf);
-
-		if (!wifi_connected)	/* non-connected scan */
-			halbtc8822b1ant_action_wifi_not_connected(btcoexist);
-		else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** scan_finish_notify action wifi connected **********\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b1ant_action_wifi_connected(btcoexist);
-		}
-	}
-}
-
-
-
-void ex_halbtc8822b1ant_scan_notify_without_bt(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-
-	boolean wifi_under_5g = FALSE;
-
-	if (BTC_SCAN_START == type) {
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-		if (wifi_under_5g) {
-			btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd,
-							   0x3, 1);
-			return;
-		}
-
-		/* under 2.4G */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd,
-						   0x3, 2);
-		return;
-	}
-	if (BTC_SCAN_START_2G == type)
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd, 0x3, 2);
-}
-
-void ex_halbtc8822b1ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** (switchband_notify) **********\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	coex_sta->switch_band_notify_to = type;
-		/*2.4g 4.*//*5 g 2*/
-	if (type == BTC_SWITCH_TO_5G) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (switchband_notify 5g action 2) **********\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b1ant_action_wifi_under5g(btcoexist);
-		return;
-	} else if (type == BTC_SWITCH_TO_24G_NOFORSCAN) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (switchband_notify BTC_SWITCH_TO_2G (no for scan)) **********\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b1ant_run_coexist_mechanism(btcoexist);
-		/*5 g 3*/
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** (switchband_notify 2g action 5) **********\n");
-		BTC_TRACE(trace_buf);
-
-		ex_halbtc8822b1ant_scan_notify(btcoexist,
-					       BTC_SCAN_START_2G);
-	}
-	coex_sta->switch_band_notify_to = BTC_NOT_SWITCH;
-
-}
-
-
-void ex_halbtc8822b1ant_switchband_notify_without_bt(IN struct btc_coexist
-		*btcoexist,
-		IN u8 type)
-{
-	boolean wifi_under_5g = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (type == BTC_SWITCH_TO_5G) {
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd,
-						   0x3, 1);
-		return;
-	} else if (type == BTC_SWITCH_TO_24G_NOFORSCAN) {
-
-		if (wifi_under_5g)
-
-			btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd,
-							   0x3, 1);
-
-		else
-			btcoexist->btc_write_1byte_bitmask(btcoexist,
-							   0xcbd, 0x3, 2);
-	} else {
-
-		ex_halbtc8822b1ant_scan_notify_without_bt(btcoexist,
-				BTC_SCAN_START_2G);
-	}
-
-}
-
-void ex_halbtc8822b1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-	boolean	wifi_connected = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ********** (connect notify) **********\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_SCAN, TRUE);
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-
-	if ((BTC_ASSOCIATE_5G_START == type) ||
-	    (BTC_ASSOCIATE_5G_FINISH == type)) {
-
-		if (BTC_ASSOCIATE_5G_START == type) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** (5G associate start notify) **********\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b1ant_action_wifi_under5g(btcoexist);
-
-		} else if (BTC_ASSOCIATE_5G_FINISH == type) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** (5G associate finish notify) **********\n");
-			BTC_TRACE(trace_buf);
-
-		}
-
-		return;
-
-	}
-
-
-	if (BTC_ASSOCIATE_START == type) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], 2G CONNECT START notify\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-		coex_dm->arp_cnt = 0;
-
-		halbtc8822b1ant_action_wifi_not_connected_asso_auth(btcoexist);
-
-		coex_sta->freeze_coexrun_by_btinfo = TRUE;
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], 2G CONNECT Finish notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->wifi_is_high_pri_task = FALSE;
-		coex_sta->freeze_coexrun_by_btinfo = FALSE;
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-				   &wifi_connected);
-
-		if (!wifi_connected) /* non-connected scan */
-			halbtc8822b1ant_action_wifi_not_connected(btcoexist);
-		else
-			halbtc8822b1ant_action_wifi_connected(btcoexist);
-	}
-
-}
-
-void ex_halbtc8822b1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean			wifi_under_b_mode = FALSE;
-	boolean wifi_under_5g = FALSE;
-
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-
-
-
-	if (BTC_MEDIA_CONNECT == type) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], 2g media connect notify");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		if (wifi_under_5g) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], 5g media notify\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b1ant_action_wifi_under5g(btcoexist);
-			return;
-		}
-		/* Force antenna setup for no scan result issue */
-		halbtc8822b1ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-				   &wifi_under_b_mode);
-
-		/* Set CCK Tx/Rx high Pri except 11b mode */
-		if (wifi_under_b_mode) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** (media status notity under b mode) **********\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x00); /* CCK Rx */
-		} else {
-#if 0
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x10); /*CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x10); /*CCK Rx */
-#endif
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** (media status notity not under b mode) **********\n");
-			BTC_TRACE(trace_buf);
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x10); /* CCK Rx */
-		}
-
-		coex_dm->backup_arfr_cnt1 = btcoexist->btc_read_4byte(btcoexist,
-					    0x430);
-		coex_dm->backup_arfr_cnt2 = btcoexist->btc_read_4byte(btcoexist,
-					    0x434);
-		coex_dm->backup_retry_limit = btcoexist->btc_read_2byte(
-						      btcoexist, 0x42a);
-		coex_dm->backup_ampdu_max_time = btcoexist->btc_read_1byte(
-				btcoexist, 0x456);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], 2g media disconnect notify\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->arp_cnt = 0;
-
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-				 BT_8822B_1ANT_SCOREBOARD_ACTIVE, FALSE);
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-
-		coex_sta->cck_ever_lock = FALSE;
-	}
-
-	halbtc8822b1ant_update_wifi_channel_info(btcoexist, type);
-
-}
-
-void ex_halbtc8822b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean	under_4way = FALSE, wifi_under_5g = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-	if (wifi_under_5g) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], 5g special packet notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b1ant_action_wifi_under5g(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (under_4way) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ---- under_4way!!\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	} else if (BTC_PACKET_ARP == type) {
-
-		coex_dm->arp_cnt++;
-
-		if (coex_sta->wifi_is_high_pri_task) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], specific Packet ARP notify -cnt = %d\n",
-				    coex_dm->arp_cnt);
-			BTC_TRACE(trace_buf);
-		}
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet DHCP or EAPOL notify [Type = %d]\n",
-			    type);
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	}
-
-	if (coex_sta->wifi_is_high_pri_task)
-		halbtc8822b1ant_action_wifi_connected_specific_packet(
-			btcoexist);
-
-}
-
-
-void ex_halbtc8822b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8				i, rsp_source = 0;
-	boolean				wifi_connected = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE,
-			wifi_busy = FALSE;
-	static boolean is_scoreboard_scan = FALSE;
-
-	if (psd_scan->is_AntDet_running) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], bt_info_notify return for AntDet is running\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8822B_1ANT_MAX)
-		rsp_source = BT_INFO_SRC_8822B_1ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt_info[%d], len=%d, data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-
-		if (i == length - 1) {
-			/* last one */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			/* normal */
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	coex_sta->bt_info = coex_sta->bt_info_c2h[rsp_source][1];
-	coex_sta->bt_info_ext = coex_sta->bt_info_c2h[rsp_source][4];
-	coex_sta->bt_info_ext2 = coex_sta->bt_info_c2h[rsp_source][5];
-
-	if (BT_INFO_SRC_8822B_1ANT_WIFI_FW != rsp_source) {
-
-		/* if 0xff, it means BT is under WHCK test */
-		coex_sta->bt_whck_test = ((coex_sta->bt_info == 0xff) ? TRUE :
-					  FALSE);
-
-		coex_sta->bt_create_connection = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x80) ? TRUE :
-						  FALSE);
-
-		/* unit: %, value-100 to translate to unit: dBm */
-		coex_sta->bt_rssi = coex_sta->bt_info_c2h[rsp_source][3] * 2 +
-				    10;
-
-		coex_sta->c2h_bt_remote_name_req = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x20) ? TRUE :
-						    FALSE);
-
-		coex_sta->is_A2DP_3M = ((coex_sta->bt_info_c2h[rsp_source][2] &
-					 0x10) ? TRUE : FALSE);
-
-		coex_sta->acl_busy = ((coex_sta->bt_info_c2h[rsp_source][1] &
-				       0x9) ? TRUE : FALSE);
-
-		coex_sta->voice_over_HOGP = ((coex_sta->bt_info_ext & 0x10) ?
-					     TRUE : FALSE);
-
-		coex_sta->c2h_bt_inquiry_page = ((coex_sta->bt_info &
-			  BT_INFO_8822B_1ANT_B_INQ_PAGE) ? TRUE : FALSE);
-
-		coex_sta->a2dp_bit_pool = (((
-			coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) ?
-				   (coex_sta->bt_info_c2h[rsp_source][6] & 0x7f) : 0);
-
-		coex_sta->is_bt_a2dp_sink = (coex_sta->bt_info_c2h[rsp_source][6] & 0x80) ?
-									TRUE : FALSE;
-
-		coex_sta->bt_retry_cnt = coex_sta->bt_info_c2h[rsp_source][2] &
-					 0xf;
-
-		coex_sta->is_autoslot = coex_sta->bt_info_ext2 & 0x8;
-
-		coex_sta->forbidden_slot = coex_sta->bt_info_ext2 & 0x7;
-
-		coex_sta->hid_busy_num = (coex_sta->bt_info_ext2 & 0x30) >> 4;
-
-		coex_sta->hid_pair_cnt = (coex_sta->bt_info_ext2 & 0xc0) >> 6;
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->c2h_bt_remote_name_req)
-			coex_sta->cnt_RemoteNameReq++;
-
-		if (coex_sta->bt_info_ext & BIT(1))
-			coex_sta->cnt_ReInit++;
-
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setupLink++;
-			coex_sta->is_setupLink = TRUE;
-			coex_sta->bt_relink_downcount = 2;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link start in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->is_setupLink = FALSE;
-			coex_sta->bt_relink_downcount = 0;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link stop in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-		if (coex_sta->bt_info_ext & BIT(3))
-			coex_sta->cnt_IgnWlanAct++;
-
-		if (coex_sta->bt_info_ext & BIT(6))
-			coex_sta->cnt_RoleSwitch++;
-
-		if (coex_sta->bt_info_ext & BIT(7))
-			coex_sta->is_bt_multi_link = TRUE;
-		else
-			coex_sta->is_bt_multi_link = FALSE;
-
-		if (coex_sta->bt_create_connection) {
-			coex_sta->cnt_Page++;
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY,
-					   &wifi_busy);
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-			if ((wifi_link) || (wifi_roam) || (wifi_scan) ||
-			    (coex_sta->wifi_is_high_pri_task) || (wifi_busy)) {
-
-				is_scoreboard_scan = TRUE;
-				halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_SCAN, TRUE);
-
-			} else
-				halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_SCAN, FALSE);
-
-		} else {
-				if (is_scoreboard_scan) {
-					halbtc8822b1ant_post_state_to_bt(btcoexist,
-						 BT_8822B_1ANT_SCOREBOARD_SCAN, FALSE);
-					is_scoreboard_scan = FALSE;
-				}
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-
-		if ((!btcoexist->manual_control) &&
-		    (!btcoexist->stop_coex_dm)) {
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-
-			/*  Re-Init */
-			if ((coex_sta->bt_info_ext & BIT(1))) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-				BTC_TRACE(trace_buf);
-				if (wifi_connected)
-					halbtc8822b1ant_update_wifi_channel_info(
-						btcoexist, BTC_MEDIA_CONNECT);
-				else
-					halbtc8822b1ant_update_wifi_channel_info(
-						btcoexist,
-						BTC_MEDIA_DISCONNECT);
-			}
-
-			/*	If Ignore_WLanAct && not SetUp_Link */
-			if ((coex_sta->bt_info_ext & BIT(3)) &&
-			    (!(coex_sta->bt_info_ext & BIT(2)))) {
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8822b1ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, FALSE);
-			}
-		}
-
-	}
-
-	if ((coex_sta->bt_info_ext & BIT(5))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BT ext info bit4 check, query BLE Scan type!!\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_ble_scan_type = btcoexist->btc_get_ble_scan_type_from_bt(
-						     btcoexist);
-
-		if ((coex_sta->bt_ble_scan_type & 0x1) == 0x1)
-			coex_sta->bt_ble_scan_para[0]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x1);
-		if ((coex_sta->bt_ble_scan_type & 0x2) == 0x2)
-			coex_sta->bt_ble_scan_para[1]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x2);
-		if ((coex_sta->bt_ble_scan_type & 0x4) == 0x4)
-			coex_sta->bt_ble_scan_para[2]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x4);
-
-	}
-
-
-	halbtc8822b1ant_update_bt_link_info(btcoexist);
-
-	halbtc8822b1ant_run_coexist_mechanism(btcoexist);
-}
-
-
-void ex_halbtc8822b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-		btcoexist->stop_coex_dm = FALSE;
-
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ONOFF, TRUE);
-
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-				 BT_8822B_1ANT_SCOREBOARD_ACTIVE, FALSE);
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ONOFF, FALSE);
-		halbtc8822b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-		halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_WLAN_OFF);
-		/* for test : s3 bt disppear , fail rate 1/600*/
-
-		halbtc8822b1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, TRUE);
-
-		btcoexist->stop_coex_dm = TRUE;
-	}
-}
-
-void ex_halbtc8822b1ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_post_state_to_bt(btcoexist,
-				 BT_8822B_1ANT_SCOREBOARD_ACTIVE, FALSE);
-	halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ONOFF, FALSE);
-
-	halbtc8822b1ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-	halbtc8822b1ant_set_ant_path(btcoexist,
-				     BTC_ANT_PATH_AUTO,
-				     FORCE_EXEC,
-				     BT_8822B_1ANT_PHASE_WLAN_OFF);
-	/* for test : s3 bt disppear , fail rate 1/600*/
-
-	halbtc8822b1ant_ignore_wlan_act(btcoexist, FORCE_EXEC, TRUE);
-
-	ex_halbtc8822b1ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-	btcoexist->stop_coex_dm = TRUE;
-}
-
-
-void ex_halbtc8822b1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	boolean wifi_under_5g = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((pnp_state == BTC_WIFI_PNP_SLEEP) ||
-	    (pnp_state == BTC_WIFI_PNP_SLEEP_KEEP_ANT)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-				BT_8822B_1ANT_SCOREBOARD_ACTIVE |
-				BT_8822B_1ANT_SCOREBOARD_ONOFF |
-				BT_8822B_1ANT_SCOREBOARD_SCAN |
-				BT_8822B_1ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		if (pnp_state == BTC_WIFI_PNP_SLEEP_KEEP_ANT) {
-
-			if (wifi_under_5g)
-				halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_5G_RUNTIME);
-			else
-				halbtc8822b1ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_2G_RUNTIME);
-		} else {
-
-			halbtc8822b1ant_set_ant_path(btcoexist,
-						     BTC_ANT_PATH_AUTO,
-						     FORCE_EXEC,
-					     BT_8822B_1ANT_PHASE_WLAN_OFF);
-		}
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-#if 0
-		halbtc8822b1ant_post_state_to_bt(btcoexist,
-					 BT_8822B_1ANT_SCOREBOARD_ACTIVE |
-					 BT_8822B_1ANT_SCOREBOARD_ONOFF,
-					 TRUE);
-#endif
-		btcoexist->stop_coex_dm = FALSE;
-	}
-}
-
-void ex_halbtc8822b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], *****************Coex DM Reset*****************\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b1ant_init_hw_config(btcoexist, FALSE, FALSE);
-	halbtc8822b1ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8822b1ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	boolean bt_relink_finish = FALSE;
-
-#if 0
-	boolean rf4ce_connected = FALSE;
-#endif
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ==========================Periodical===========================\n");
-	BTC_TRACE(trace_buf);
-
-#if (BT_AUTO_REPORT_ONLY_8822B_1ANT == 0)
-	halbtc8822b1ant_query_bt_info(btcoexist);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ==========================Periodical-auto report only===========================\n");
-	BTC_TRACE(trace_buf);
-
-#endif
-
-	halbtc8822b1ant_monitor_bt_ctr(btcoexist);
-	halbtc8822b1ant_monitor_wifi_ctr(btcoexist);
-
-	halbtc8822b1ant_monitor_bt_enable_disable(btcoexist);
-
-#if 0
-	/*RF4CE for arris , rf4ce always on*/
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_RF4CE_CONNECTED, &rf4ce_connected);
-	if (rf4ce_connected){
-		btcoexist->btc_write_1byte_bitmask(
-					btcoexist, 0x45e, 0x8, 0x1);
-
-		halbtc8822b1ant_ps_tdma(btcoexist, NORMAL_EXEC,
-					TRUE,
-					50);
-
-		halbtc8822b1ant_coex_table_with_type(btcoexist,
-		NORMAL_EXEC, 1);
-		return;
-	}
-#endif
-
-	if (coex_sta->bt_relink_downcount != 0) {
-		coex_sta->bt_relink_downcount--;
-
-		if (coex_sta->bt_relink_downcount == 0) {
-			coex_sta->is_setupLink = FALSE;
-			bt_relink_finish = TRUE;
-		}
-	}
-
-	/* for 4-way, DHCP, EAPOL packet */
-	if (coex_sta->specific_pkt_period_cnt > 0) {
-
-		coex_sta->specific_pkt_period_cnt--;
-
-		if ((coex_sta->specific_pkt_period_cnt == 0) &&
-		    (coex_sta->wifi_is_high_pri_task))
-			coex_sta->wifi_is_high_pri_task = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ***************** Hi-Pri Task = %s*****************\n",
-			    (coex_sta->wifi_is_high_pri_task ? "Yes" :
-			     "No"));
-		BTC_TRACE(trace_buf);
-	}
-
-	if (halbtc8822b1ant_is_wifi_status_changed(btcoexist) || (bt_relink_finish)
-		|| (coex_sta->is_set_ps_state_fail))
-		halbtc8822b1ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8822b1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-}
-
-void ex_halbtc8822b1ant_antenna_isolation(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-
-}
-
-void ex_halbtc8822b1ant_psd_scan(IN struct btc_coexist *btcoexist,
-		 IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-
-}
-
-void ex_halbtc8822b1ant_display_ant_detection(IN struct btc_coexist *btcoexist)
-{
-
-}
-
-void ex_halbtc8822b1ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata)
-{}
-#endif	/*  #if(BTC_COEX_OFFLOAD == 1) */
-
-#endif
-
-#else
-
-void ex_halbtc8822b1ant_switch_band_without_bt(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_only_5g)
-{
-	/* ant switch WL2G or WL5G*/
-	if (wifi_only_5g)
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd, 0x3, 1);
-
-	else
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd, 0x3, 2);
-
-}
-
-#endif	/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b1ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b1ant.h
deleted file mode 100644
index 0136de48dc6d..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b1ant.h
+++ /dev/null
@@ -1,481 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8822B_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8822B 1ANT BT Co-exist definition
- * ******************************************* */
-#define BT_8822B_1ANT_COEX_DBG						0
-#define	BT_AUTO_REPORT_ONLY_8822B_1ANT				1
-
-#define	BT_INFO_8822B_1ANT_B_FTP						BIT(7)
-#define	BT_INFO_8822B_1ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8822B_1ANT_B_HID						BIT(5)
-#define	BT_INFO_8822B_1ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8822B_1ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8822B_1ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8822B_1ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8822B_1ANT_B_CONNECTION				BIT(0)
-
-#define	BT_INFO_8822B_1ANT_A2DP_BASIC_RATE(_BT_INFO_EXT_)	\
-		(((_BT_INFO_EXT_&BIT(0))) ? true : false)
-
-#define	BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT		2
-
-#define  BT_8822B_1ANT_WIFI_NOISY_THRESH							150  /* max: 255 */
-#define  BT_8822B_1ANT_DEFAULT_ISOLATION						15	 /*  unit: dB */
-
-/* for Antenna detection */
-#define	BT_8822B_1ANT_ANTDET_PSDTHRES_BACKGROUND					50
-#define	BT_8822B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8822B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			55
-#define	BT_8822B_1ANT_ANTDET_PSDTHRES_1ANT							35
-#define	BT_8822B_1ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8822B_1ANT_ANTDET_ENABLE									0
-#define	BT_8822B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE				0
-
-#define	BT_8822B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
-
-
-
-enum bt_8822b_1ant_signal_state {
-	BT_8822B_1ANT_SIG_STA_SET_TO_LOW		= 0x0,
-	BT_8822B_1ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8822B_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,
-	BT_8822B_1ANT_SIG_STA_MAX
-};
-
-enum bt_8822b_1ant_path_ctrl_owner {
-	BT_8822B_1ANT_PCO_BTSIDE		= 0x0,
-	BT_8822B_1ANT_PCO_WLSIDE	= 0x1,
-	BT_8822B_1ANT_PCO_MAX
-};
-
-enum bt_8822b_1ant_gnt_ctrl_type {
-	BT_8822B_1ANT_GNT_CTRL_BY_PTA		= 0x0,
-	BT_8822B_1ANT_GNT_CTRL_BY_SW		= 0x1,
-	BT_8822B_1ANT_GNT_CTRL_MAX
-};
-
-enum bt_8822b_1ant_gnt_ctrl_block {
-	BT_8822B_1ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8822B_1ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8822B_1ANT_GNT_BLOCK_BB			= 0x2,
-	BT_8822B_1ANT_GNT_BLOCK_MAX
-};
-
-enum bt_8822b_1ant_lte_coex_table_type {
-	BT_8822B_1ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8822B_1ANT_CTT_BT_VS_LTE			= 0x1,
-	BT_8822B_1ANT_CTT_MAX
-};
-
-enum bt_8822b_1ant_lte_break_table_type {
-	BT_8822B_1ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8822B_1ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8822B_1ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8822B_1ANT_LBTT_LTE_BREAK_BT				= 0x3,
-	BT_8822B_1ANT_LBTT_MAX
-};
-
-enum bt_info_src_8822b_1ant {
-	BT_INFO_SRC_8822B_1ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8822B_1ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8822B_1ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8822B_1ANT_MAX
-};
-
-enum bt_8822b_1ant_bt_status {
-	BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8822B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8822B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8822B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8822B_1ANT_BT_STATUS_MAX
-};
-
-enum bt_8822b_1ant_wifi_status {
-	BT_8822B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,
-	BT_8822B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,
-	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,
-	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,
-	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,
-	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,
-	BT_8822B_1ANT_WIFI_STATUS_MAX
-};
-
-enum bt_8822b_1ant_coex_algo {
-	BT_8822B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8822B_1ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8822B_1ANT_COEX_ALGO_HID				= 0x2,
-	BT_8822B_1ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8822B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8822B_1ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8822B_1ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8822B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8822B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8822B_1ANT_COEX_ALGO_HID_A2DP_PANEDR		= 0x9,
-	BT_8822B_1ANT_COEX_ALGO_HID_A2DP		= 0xa,
-	BT_8822B_1ANT_COEX_ALGO_NOPROFILEBUSY		= 0xb,
-	BT_8822B_1ANT_COEX_ALGO_A2DPSINK		= 0xc,
-	BT_8822B_1ANT_COEX_ALGO_MAX
-};
-
-enum bt_8822b_1ant_ext_ant_switch_type {
-	BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT		= 0x0,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SP3T		= 0x1,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_MAX
-};
-
-enum bt_8822b_1ant_ext_ant_switch_ctrl_type {
-	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	= 0x0,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA	= 0x1,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC	= 0x3,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_MAX
-};
-
-enum bt_8822b_1ant_ext_ant_switch_pos_type {
-	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_BT			= 0x0,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLG			= 0x1,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLA			= 0x2,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_NOCARE		= 0x3,
-	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_MAX
-};
-
-enum bt_8822b_1ant_phase {
-	BT_8822B_1ANT_PHASE_COEX_INIT				= 0x0,
-	BT_8822B_1ANT_PHASE_WLANONLY_INIT			= 0x1,
-	BT_8822B_1ANT_PHASE_WLAN_OFF				= 0x2,
-	BT_8822B_1ANT_PHASE_2G_RUNTIME				= 0x3,
-	BT_8822B_1ANT_PHASE_5G_RUNTIME				= 0x4,
-	BT_8822B_1ANT_PHASE_BTMPMODE				= 0x5,
-	BT_8822B_1ANT_PHASE_MAX
-};
-
-/*ADD SCOREBOARD TO FIX BT LPS 32K ISSUE WHILE WL BUSY*/
-enum bt_8822b_1ant_Scoreboard {
-	BT_8822B_1ANT_SCOREBOARD_ACTIVE                            = BIT(0),
-	BT_8822B_1ANT_SCOREBOARD_ONOFF                             = BIT(1),
-	BT_8822B_1ANT_SCOREBOARD_SCAN                               = BIT(2),
-	BT_8822B_1ANT_SCOREBOARD_UNDERTEST							= BIT(3),
-	BT_8822B_1ANT_SCOREBOARD_WLBUSY                          = BIT(6)
-};
-
-struct coex_dm_8822b_1ant {
-	/* hw setting */
-	u32		pre_ant_pos_type;
-	u32		cur_ant_pos_type;
-	/* fw mechanism */
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		auto_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-	u8		pre_fw_dac_swing_lvl;
-	u8		cur_fw_dac_swing_lvl;
-
-	/* sw mechanism */
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	u32		backup_arfr_cnt1;	/* Auto Rate Fallback Retry cnt */
-	u32		backup_arfr_cnt2;	/* Auto Rate Fallback Retry cnt */
-	u16		backup_retry_limit;
-	u8		backup_ampdu_max_time;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	u32		pre_ra_mask;
-	u32		cur_ra_mask;
-	u8		pre_arfr_type;
-	u8		cur_arfr_type;
-	u8		pre_retry_limit_type;
-	u8		cur_retry_limit_type;
-	u8		pre_ampdu_time_type;
-	u8		cur_ampdu_time_type;
-	u32		arp_cnt;
-
-	u32		pre_ext_ant_switch_status;
-	u32		cur_ext_ant_switch_status;
-
-	u8		error_condition;
-	boolean		pre_agc_table_en;
-	boolean		cur_agc_table_en;
-};
-
-struct coex_sta_8822b_1ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-	u8					num_of_profile;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					specific_pkt_period_cnt;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	boolean             is_hiPri_rx_overhead;
-	s8					bt_rssi;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	u8					bt_info_c2h[BT_INFO_SRC_8822B_1ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8822B_1ANT_MAX];
-	boolean					bt_whck_test;
-	boolean					c2h_bt_inquiry_page;
-	boolean					c2h_bt_remote_name_req;
-	boolean					c2h_bt_page;			/* Add for win8.1 page out issue */
-	boolean					wifi_is_high_pri_task;		/* Add for win8.1 page out issue */
-
-	u8					bt_info_ext;
-	u8					bt_info_ext2;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-	u8					bt_retry_cnt;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	boolean					cck_lock;
-	boolean					pre_ccklock;
-	boolean					cck_ever_lock;
-	u8					coex_table_type;
-
-	boolean					force_lps_ctrl;
-
-	boolean					concurrent_rx_mode_on;
-
-	u16					score_board;
-	u8					isolation_btween_wb;   /* 0~ 50 */
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-	boolean					acl_busy;
-	boolean					bt_create_connection;
-
-	u32					bt_coex_supported_feature;
-	u32					bt_coex_supported_version;
-
-	u8					bt_ble_scan_type;
-	u32					bt_ble_scan_para[3];
-
-	boolean					run_time_state;
-	boolean					freeze_coexrun_by_btinfo;
-
-	boolean					is_A2DP_3M;
-	boolean					voice_over_HOGP;
-	u8					bt_info;
-	boolean					is_autoslot;
-	u8					forbidden_slot;
-	u8					hid_busy_num;
-	u8					hid_pair_cnt;
-
-	u32					cnt_RemoteNameReq;
-	u32					cnt_setupLink;
-	u32					cnt_ReInit;
-	u32					cnt_IgnWlanAct;
-	u32					cnt_Page;
-	u32					cnt_RoleSwitch;
-
-	u16					bt_reg_vendor_ac;
-	u16					bt_reg_vendor_ae;
-
-	boolean					is_setupLink;
-	u8					wl_noisy_level;
-	u32					gnt_error_cnt;
-	u8					bt_afh_map[10];
-	u8					bt_relink_downcount;
-	boolean					is_tdma_btautoslot;
-	boolean					is_tdma_btautoslot_hang;
-
-	u8					switch_band_notify_to;
-	boolean					is_rf_state_off;
-
-	boolean					is_hid_low_pri_tx_overhead;
-	boolean					is_bt_multi_link;
-	boolean					is_bt_a2dp_sink;
-	boolean					rf4ce_enabled;
-
-	boolean					is_set_ps_state_fail;
-	u8					cnt_set_ps_state_fail;
-};
-
-struct rfe_type_8822b_1ant {
-
-	u8			rfe_module_type;
-	boolean		ext_ant_switch_exist;
-	u8			ext_ant_switch_type;
-	/*  iF 0: ANTSW(rfe_sel9)=0, ANTSWB(rfe_sel8)=1 =>  Ant to BT/5G */
-	u8			ext_ant_switch_ctrl_polarity;
-};
-
-
-#define  BT_8822B_1ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
-#define  BT_8822B_1ANT_ANTDET_PSD_AVGNUM			1	/* MAX:3 */
-#define	BT_8822B_1ANT_ANTDET_BUF_LEN				16
-
-struct psdscan_sta_8822b_1ant {
-
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8822B_1ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8822B_1ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_psd_running;
-	boolean			is_psd_show_max_only;
-	boolean         is_AntDet_running;
-};
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8822b1ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b1ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8822b1ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b1ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8822b1ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8822b1ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8822b1ant_scan_notify_without_bt(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b1ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b1ant_switchband_notify_without_bt(IN struct btc_coexist
-		*btcoexist,
-		IN u8 type);
-void ex_halbtc8822b1ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8822b1ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8822b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b1ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b1ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8822b1ant_ScoreBoardStatusNotify(IN struct btc_coexist *btcoexist,
-		IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8822b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b1ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b1ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b1ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8822b1ant_antenna_isolation(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-
-void ex_halbtc8822b1ant_psd_scan(IN struct btc_coexist *btcoexist,
-		 IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8822b1ant_display_ant_detection(IN struct btc_coexist *btcoexist);
-
-void ex_halbtc8822b1ant_dbg_control(IN struct btc_coexist *btcoexist,
-				    IN u8 op_code, IN u8 op_len, IN u8 *pdata);
-
-#else
-#define	ex_halbtc8822b1ant_power_on_setting(btcoexist)
-#define	ex_halbtc8822b1ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8822b1ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8822b1ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8822b1ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_scan_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_scan_notify_without_bt(btcoexist, type)
-#define	ex_halbtc8822b1ant_switchband_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_switchband_notify_without_bt(btcoexist, type)
-#define	ex_halbtc8822b1ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8822b1ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8822b1ant_halt_notify(btcoexist)
-#define	ex_halbtc8822b1ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8822b1ant_ScoreBoardStatusNotify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8822b1ant_coex_dm_reset(btcoexist)
-#define	ex_halbtc8822b1ant_periodical(btcoexist)
-#define	ex_halbtc8822b1ant_display_coex_info(btcoexist)
-#define	ex_halbtc8822b1ant_antenna_detection(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8822b1ant_antenna_isolation(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8822b1ant_psd_scan(btcoexist, cent_freq, offset, span, seconds)
-#define	ex_halbtc8822b1ant_display_ant_detection(btcoexist)
-#define	ex_halbtc8822b1ant_dbg_control(btcoexist, op_code, op_len, pdata)
-#endif
-#else
-
-void ex_halbtc8822b1ant_init_hw_config_without_bt(IN struct btc_coexist
-		*btcoexist);
-void ex_halbtc8822b1ant_switch_band_without_bt(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_only_5g);
-
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b2ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b2ant.c
deleted file mode 100644
index d20631876bda..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b2ant.c
+++ /dev/null
@@ -1,6113 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-/* ************************************************************
- * Description:
- *
- * This file is for RTL8822B Co-exist mechanism
- *
- * History
- * 2012/11/15 Cosa first check in.
- *
- * ************************************************************ */
-
-/* ************************************************************
- * include files
- * ************************************************************ */
-#include "mp_precomp.h"
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8822B_SUPPORT == 1)
-/* ************************************************************
- * Global variables, these are static variables
- * ************************************************************ */
-static u8	*trace_buf = &gl_btc_trace_buf[0];
-static struct  coex_dm_8822b_2ant		glcoex_dm_8822b_2ant;
-static struct  coex_dm_8822b_2ant	*coex_dm = &glcoex_dm_8822b_2ant;
-static struct  coex_sta_8822b_2ant		glcoex_sta_8822b_2ant;
-static struct  coex_sta_8822b_2ant	*coex_sta = &glcoex_sta_8822b_2ant;
-static struct  psdscan_sta_8822b_2ant	gl_psd_scan_8822b_2ant;
-static struct  psdscan_sta_8822b_2ant *psd_scan = &gl_psd_scan_8822b_2ant;
-static struct	rfe_type_8822b_2ant		gl_rfe_type_8822b_2ant;
-static struct	rfe_type_8822b_2ant		*rfe_type = &gl_rfe_type_8822b_2ant;
-
-static const char *const glbt_info_src_8822b_2ant[] = {
-	"BT Info[wifi fw]",
-	"BT Info[bt rsp]",
-	"BT Info[bt auto report]",
-};
-
-static u32	glcoex_ver_date_8822b_2ant = 20170707;
-static u32	glcoex_ver_8822b_2ant = 0x46;
-static u32	glcoex_ver_btdesired_8822b_2ant = 0x42;
-
-
-/* ************************************************************
- * local function proto type if needed
- * ************************************************************
- * ************************************************************
- * local function start with halbtc8822b2ant_
- * ************************************************************ */
-static
-u8 halbtc8822b2ant_bt_rssi_state(IN struct btc_coexist *btcoexist,
-		u8 *ppre_bt_rssi_state, u8 level_num,
-		u8 rssi_thresh, u8 rssi_thresh1)
-{
-	s32			bt_rssi = 0;
-	u8			bt_rssi_state = *ppre_bt_rssi_state;
-
-	bt_rssi = coex_sta->bt_rssi;
-
-	if (level_num == 2) {
-		if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8822B_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT Rssi thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return *ppre_bt_rssi_state;
-		}
-
-		if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (bt_rssi >= (rssi_thresh +
-					BTC_RSSI_COEX_THRESH_TOL_8822B_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((*ppre_bt_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-			(*ppre_bt_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (bt_rssi >= (rssi_thresh1 +
-					BTC_RSSI_COEX_THRESH_TOL_8822B_2ANT))
-				bt_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (bt_rssi < rssi_thresh)
-				bt_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (bt_rssi < rssi_thresh1)
-				bt_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	*ppre_bt_rssi_state = bt_rssi_state;
-
-	return bt_rssi_state;
-}
-
-
-static
-u8 halbtc8822b2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,
-	   IN u8 *pprewifi_rssi_state, IN u8 level_num, IN u8 rssi_thresh,
-				   IN u8 rssi_thresh1)
-{
-	s32			wifi_rssi = 0;
-	u8			wifi_rssi_state = *pprewifi_rssi_state;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-
-	if (level_num == 2) {
-		if ((*pprewifi_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8822B_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else {
-			if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	} else if (level_num == 3) {
-		if (rssi_thresh > rssi_thresh1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], wifi RSSI thresh error!!\n");
-			BTC_TRACE(trace_buf);
-			return *pprewifi_rssi_state;
-		}
-
-		if ((*pprewifi_rssi_state == BTC_RSSI_STATE_LOW) ||
-		    (*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_LOW)) {
-			if (wifi_rssi >= (rssi_thresh +
-					  BTC_RSSI_COEX_THRESH_TOL_8822B_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW;
-		} else if ((*pprewifi_rssi_state == BTC_RSSI_STATE_MEDIUM) ||
-			(*pprewifi_rssi_state == BTC_RSSI_STATE_STAY_MEDIUM)) {
-			if (wifi_rssi >= (rssi_thresh1 +
-					  BTC_RSSI_COEX_THRESH_TOL_8822B_2ANT))
-				wifi_rssi_state = BTC_RSSI_STATE_HIGH;
-			else if (wifi_rssi < rssi_thresh)
-				wifi_rssi_state = BTC_RSSI_STATE_LOW;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM;
-		} else {
-			if (wifi_rssi < rssi_thresh1)
-				wifi_rssi_state = BTC_RSSI_STATE_MEDIUM;
-			else
-				wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH;
-		}
-	}
-
-	*pprewifi_rssi_state = wifi_rssi_state;
-
-	return wifi_rssi_state;
-}
-
-
-static
-void halbtc8822b2ant_coex_switch_threshold(IN struct btc_coexist *btcoexist,
-		IN u8 isolation_measuared)
-{
-	s8	interference_wl_tx = 0, interference_bt_tx = 0;
-
-
-	interference_wl_tx = BT_8822B_2ANT_WIFI_MAX_TX_POWER -
-			     isolation_measuared;
-	interference_bt_tx = BT_8822B_2ANT_BT_MAX_TX_POWER -
-			     isolation_measuared;
-
-
-
-	coex_sta->wifi_coex_thres		 = BT_8822B_2ANT_WIFI_RSSI_COEXSWITCH_THRES1;
-	coex_sta->wifi_coex_thres2	 = BT_8822B_2ANT_WIFI_RSSI_COEXSWITCH_THRES2;
-
-	coex_sta->bt_coex_thres		 = BT_8822B_2ANT_BT_RSSI_COEXSWITCH_THRES1;
-	coex_sta->bt_coex_thres2		 = BT_8822B_2ANT_BT_RSSI_COEXSWITCH_THRES2;
-
-
-#if 0
-	coex_sta->wifi_coex_thres		= interference_wl_tx + BT_8822B_2ANT_WIFI_SIR_THRES1;
-	coex_sta->wifi_coex_thres2		= interference_wl_tx + BT_8822B_2ANT_WIFI_SIR_THRES2;
-
-	coex_sta->bt_coex_thres		= interference_bt_tx + BT_8822B_2ANT_BT_SIR_THRES1;
-	coex_sta->bt_coex_thres2		= interference_bt_tx + BT_8822B_2ANT_BT_SIR_THRES2;
-#endif
-
-
-
-
-
-#if 0
-	if  (BT_8822B_2ANT_WIFI_RSSI_COEXSWITCH_THRES1 < (isolation_measuared -
-				BT_8822B_2ANT_DEFAULT_ISOLATION))
-		coex_sta->wifi_coex_thres	 = BT_8822B_2ANT_WIFI_RSSI_COEXSWITCH_THRES1;
-	else
-		coex_sta->wifi_coex_thres =  BT_8822B_2ANT_WIFI_RSSI_COEXSWITCH_THRES1 -  (isolation_measuared -
-				BT_8822B_2ANT_DEFAULT_ISOLATION);
-
-	if  (BT_8822B_2ANT_BT_RSSI_COEXSWITCH_THRES1 < (isolation_measuared -
-				BT_8822B_2ANT_DEFAULT_ISOLATION))
-		coex_sta->bt_coex_thres	 = BT_8822B_2ANT_BT_RSSI_COEXSWITCH_THRES1;
-	else
-		coex_sta->bt_coex_thres =  BT_8822B_2ANT_BT_RSSI_COEXSWITCH_THRES1 -  (isolation_measuared -
-				BT_8822B_2ANT_DEFAULT_ISOLATION);
-
-#endif
-}
-
-static
-void halbtc8822b2ant_query_bt_info(IN struct btc_coexist *btcoexist)
-{
-	u8			h2c_parameter[1] = {0};
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], No query BT info because BT is disabled!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-
-	h2c_parameter[0] |= BIT(0);	/* trigger */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter);
-}
-
-
-static
-void halbtc8822b2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)
-{
-	u32			reg_hp_txrx, reg_lp_txrx, u32tmp;
-	u32			reg_hp_tx = 0, reg_hp_rx = 0, reg_lp_tx = 0, reg_lp_rx = 0;
-	static u8		num_of_bt_counter_chk = 0, cnt_slave = 0, cnt_autoslot_hang = 0;
-
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	reg_hp_txrx = 0x770;
-	reg_lp_txrx = 0x774;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx);
-	reg_hp_tx = u32tmp & MASKLWORD;
-	reg_hp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx);
-	reg_lp_tx = u32tmp & MASKLWORD;
-	reg_lp_rx = (u32tmp & MASKHWORD) >> 16;
-
-	coex_sta->high_priority_tx = reg_hp_tx;
-	coex_sta->high_priority_rx = reg_hp_rx;
-	coex_sta->low_priority_tx = reg_lp_tx;
-	coex_sta->low_priority_rx = reg_lp_rx;
-
-
-	/* reset counter */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc);
-
-	if ((coex_sta->low_priority_tx > 1050)  &&
-	    (!coex_sta->c2h_bt_inquiry_page))
-		coex_sta->pop_event_cnt++;
-
-	if ((coex_sta->low_priority_rx >= 950) &&
-	    (coex_sta->low_priority_rx >= coex_sta->low_priority_tx)
-	    && (!coex_sta->under_ips)  && (!coex_sta->c2h_bt_inquiry_page) &&
-	    (coex_sta->bt_link_exist))	{
-		if (cnt_slave >= 2) {
-			bt_link_info->slave_role = TRUE;
-			cnt_slave = 2;
-		} else {
-			cnt_slave++;
-		}
-	} else {
-		if (cnt_slave == 0)	{
-			bt_link_info->slave_role = FALSE;
-			cnt_slave = 0;
-		} else {
-			cnt_slave--;
-		}
-
-	}
-
-	if (coex_sta->is_tdma_btautoslot) {
-		if ((coex_sta->low_priority_tx >= 1300) &&
-		(coex_sta->low_priority_rx <= 150)) {
-			if (cnt_autoslot_hang >= 2) {
-				coex_sta->is_tdma_btautoslot_hang = TRUE;
-				cnt_autoslot_hang = 2;
-			} else {
-				cnt_autoslot_hang++;
-			}
-		} else {
-			if (cnt_autoslot_hang == 0)	{
-				coex_sta->is_tdma_btautoslot_hang = FALSE;
-				cnt_autoslot_hang = 0;
-			} else {
-				cnt_autoslot_hang--;
-			}
-		}
-	}
-
-	if (coex_sta->sco_exist) {
-		if ((coex_sta->high_priority_tx >= 400) &&
-		(coex_sta->high_priority_rx >= 400))
-			coex_sta->is_eSCO_mode = FALSE;
-		else
-			coex_sta->is_eSCO_mode = TRUE;
-	}
-
-	if (bt_link_info->hid_only) {
-		if (coex_sta->low_priority_rx > 50)
-			coex_sta->is_hid_low_pri_tx_overhead = true;
-		else
-			coex_sta->is_hid_low_pri_tx_overhead = false;
-	}
-
-	if ((coex_sta->high_priority_tx == 0) &&
-	    (coex_sta->high_priority_rx == 0) &&
-	    (coex_sta->low_priority_tx == 0) &&
-	    (coex_sta->low_priority_rx == 0)) {
-		num_of_bt_counter_chk++;
-		if (num_of_bt_counter_chk >= 3) {
-			halbtc8822b2ant_query_bt_info(btcoexist);
-			num_of_bt_counter_chk = 0;
-		}
-	}
-
-}
-
-static
-void halbtc8822b2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)
-{
-#if 1
-		s32 wifi_rssi = 0;
-		boolean wifi_busy = FALSE, wifi_under_b_mode = FALSE,
-			wifi_scan = FALSE;
-		boolean bt_idle = FALSE;
-		static u8 cck_lock_counter = 0, wl_noisy_count0 = 0,
-			  wl_noisy_count1 = 3, wl_noisy_count2 = 0;
-		u32 total_cnt, cck_cnt;
-		u32 cnt_crcok = 0, cnt_crcerr = 0;
-		static u8 cnt = 0;
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-		btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi);
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-				   &wifi_under_b_mode);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-
-		coex_sta->crc_ok_cck = btcoexist->btc_phydm_query_PHY_counter(
-						   btcoexist,
-						   PHYDM_INFO_CRC32_OK_CCK);
-		coex_sta->crc_ok_11g = btcoexist->btc_phydm_query_PHY_counter(
-						   btcoexist,
-						   PHYDM_INFO_CRC32_OK_LEGACY);
-		coex_sta->crc_ok_11n = btcoexist->btc_phydm_query_PHY_counter(
-						   btcoexist,
-						   PHYDM_INFO_CRC32_OK_HT);
-		coex_sta->crc_ok_11n_vht =
-			btcoexist->btc_phydm_query_PHY_counter(
-				btcoexist,
-				PHYDM_INFO_CRC32_OK_VHT);
-
-		coex_sta->crc_err_cck = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_CCK);
-		coex_sta->crc_err_11g =  btcoexist->btc_phydm_query_PHY_counter(
-					 btcoexist, PHYDM_INFO_CRC32_ERROR_LEGACY);
-		coex_sta->crc_err_11n = btcoexist->btc_phydm_query_PHY_counter(
-						btcoexist, PHYDM_INFO_CRC32_ERROR_HT);
-		coex_sta->crc_err_11n_vht =
-			btcoexist->btc_phydm_query_PHY_counter(
-				btcoexist,
-				PHYDM_INFO_CRC32_ERROR_VHT);
-
-		cnt_crcok =  coex_sta->crc_ok_cck + coex_sta->crc_ok_11g
-					+ coex_sta->crc_ok_11n
-					+ coex_sta->crc_ok_11n_vht;
-
-		cnt_crcerr =  coex_sta->crc_err_cck + coex_sta->crc_err_11g
-					+ coex_sta->crc_err_11n
-					+ coex_sta->crc_err_11n_vht;
-
-		if ((wifi_busy) && (cnt_crcerr != 0)) {
-
-			coex_sta->now_crc_ratio = cnt_crcok/cnt_crcerr;
-
-			if (cnt == 0)
-				coex_sta->acc_crc_ratio = coex_sta->now_crc_ratio;
-			else
-				coex_sta->acc_crc_ratio = (coex_sta->acc_crc_ratio * 7 +
-					coex_sta->now_crc_ratio * 3)/10;
-
-			if (cnt >= 10)
-				cnt = 0;
-			else
-				cnt++;
-		}
-
-		cck_cnt = coex_sta->crc_ok_cck + coex_sta->crc_err_cck;
-
-		if ((coex_dm->bt_status ==
-			 BT_8822B_2ANT_BT_STATUS_NON_CONNECTED_IDLE) ||
-			(coex_dm->bt_status ==
-			 BT_8822B_2ANT_BT_STATUS_CONNECTED_IDLE) ||
-			(coex_sta->bt_disabled))
-			bt_idle = TRUE;
-
-		if (cck_cnt > 250) {
-			if (wl_noisy_count2 < 3)
-				wl_noisy_count2++;
-
-			if (wl_noisy_count2 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count1 = 0;
-			}
-
-		} else if (cck_cnt < 50) {
-			if (wl_noisy_count0 < 3)
-				wl_noisy_count0++;
-
-			if (wl_noisy_count0 == 3) {
-				wl_noisy_count1 = 0;
-				wl_noisy_count2 = 0;
-			}
-
-		} else {
-			if (wl_noisy_count1 < 3)
-				wl_noisy_count1++;
-
-			if (wl_noisy_count1 == 3) {
-				wl_noisy_count0 = 0;
-				wl_noisy_count2 = 0;
-			}
-		}
-
-		if (wl_noisy_count2 == 3)
-			coex_sta->wl_noisy_level = 2;
-		else if (wl_noisy_count1 == 3)
-			coex_sta->wl_noisy_level = 1;
-		else
-			coex_sta->wl_noisy_level = 0;
-
-		if ((wifi_busy) && (wifi_rssi >= 30) && (!wifi_under_b_mode)) {
-			total_cnt = cnt_crcok;
-
-			if ((coex_dm->bt_status ==
-				 BT_8822B_1ANT_BT_STATUS_ACL_BUSY) ||
-				(coex_dm->bt_status ==
-				 BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY) ||
-				(coex_dm->bt_status ==
-				 BT_8822B_1ANT_BT_STATUS_SCO_BUSY)) {
-				if (coex_sta->crc_ok_cck > (total_cnt -
-								coex_sta->crc_ok_cck)) {
-					if (cck_lock_counter < 3)
-						cck_lock_counter++;
-				} else {
-					if (cck_lock_counter > 0)
-						cck_lock_counter--;
-				}
-
-			} else {
-				if (cck_lock_counter > 0)
-					cck_lock_counter--;
-			}
-		} else {
-			if (cck_lock_counter > 0)
-				cck_lock_counter--;
-		}
-
-		if (!coex_sta->pre_ccklock) {
-
-			if (cck_lock_counter >= 3)
-				coex_sta->cck_lock = TRUE;
-			else
-				coex_sta->cck_lock = FALSE;
-		} else {
-			if (cck_lock_counter == 0)
-				coex_sta->cck_lock = FALSE;
-			else
-				coex_sta->cck_lock = TRUE;
-		}
-
-		if (coex_sta->cck_lock)
-			coex_sta->cck_ever_lock = TRUE;
-
-		coex_sta->pre_ccklock =  coex_sta->cck_lock;
-
-#endif
-}
-
-
-static
-boolean halbtc8822b2ant_is_wifibt_status_changed(IN struct btc_coexist
-		*btcoexist)
-{
-	static boolean	pre_wifi_busy = FALSE, pre_under_4way = FALSE,
-			pre_bt_hs_on = FALSE, pre_bt_off = FALSE,
-			pre_bt_slave = FALSE, pre_hid_low_pri_tx_overhead = FALSE,
-			pre_wifi_under_lps = FALSE, pre_bt_setup_link = FALSE;
-	static u8 pre_hid_busy_num = 0, pre_wl_noisy_level = 0;
-	boolean wifi_busy = FALSE, under_4way = FALSE, bt_hs_on = FALSE;
-	boolean wifi_connected = FALSE;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (coex_sta->bt_disabled != pre_bt_off) {
-		pre_bt_off = coex_sta->bt_disabled;
-
-		if (coex_sta->bt_disabled)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is disabled !!\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], BT is enabled !!\n");
-
-		BTC_TRACE(trace_buf);
-
-		coex_sta->bt_coex_supported_feature = 0;
-		coex_sta->bt_coex_supported_version = 0;
-		coex_sta->bt_ble_scan_type = 0;
-		coex_sta->bt_ble_scan_para[0] = 0;
-		coex_sta->bt_ble_scan_para[1] = 0;
-		coex_sta->bt_ble_scan_para[2] = 0;
-		coex_sta->bt_reg_vendor_ac = 0xffff;
-		coex_sta->bt_reg_vendor_ae = 0xffff;
-		return TRUE;
-	}
-
-
-	if (wifi_connected) {
-		if (wifi_busy != pre_wifi_busy) {
-			pre_wifi_busy = wifi_busy;
-			return TRUE;
-		}
-		if (under_4way != pre_under_4way) {
-			pre_under_4way = under_4way;
-			return TRUE;
-		}
-		if (bt_hs_on != pre_bt_hs_on) {
-			pre_bt_hs_on = bt_hs_on;
-			return TRUE;
-		}
-		if (coex_sta->wl_noisy_level != pre_wl_noisy_level) {
-			pre_wl_noisy_level = coex_sta->wl_noisy_level;
-			return TRUE;
-		}
-		if (coex_sta->under_lps != pre_wifi_under_lps) {
-			pre_wifi_under_lps = coex_sta->under_lps;
-			if (coex_sta->under_lps)
-				return TRUE;
-		}
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->hid_busy_num != pre_hid_busy_num) {
-			pre_hid_busy_num = coex_sta->hid_busy_num;
-			return TRUE;
-		}
-
-		if (bt_link_info->slave_role != pre_bt_slave) {
-			pre_bt_slave = bt_link_info->slave_role;
-			return TRUE;
-		}
-
-		if (pre_hid_low_pri_tx_overhead != coex_sta->is_hid_low_pri_tx_overhead) {
-			pre_hid_low_pri_tx_overhead = coex_sta->is_hid_low_pri_tx_overhead;
-			return TRUE;
-		}
-
-		if (pre_bt_setup_link != coex_sta->is_setupLink) {
-			pre_bt_setup_link = coex_sta->is_setupLink;
-			return TRUE;
-		}
-	}
-
-	return FALSE;
-}
-
-
-static
-void halbtc8822b2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)
-{
-
-	struct	btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean			bt_hs_on = FALSE;
-	boolean		bt_busy = FALSE;
-
-	coex_sta->num_of_profile = 0;
-
-	/* set link exist status */
-	if (!(coex_sta->bt_info & BT_INFO_8822B_1ANT_B_CONNECTION)) {
-		coex_sta->bt_link_exist = FALSE;
-		coex_sta->pan_exist = FALSE;
-		coex_sta->a2dp_exist = FALSE;
-		coex_sta->hid_exist = FALSE;
-		coex_sta->sco_exist = FALSE;
-	} else {	/* connection exists */
-		coex_sta->bt_link_exist = TRUE;
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_FTP) {
-			coex_sta->pan_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->pan_exist = FALSE;
-		}
-
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_A2DP) {
-			coex_sta->a2dp_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->a2dp_exist = FALSE;
-		}
-
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_HID) {
-			coex_sta->hid_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->hid_exist = FALSE;
-		}
-
-		if (coex_sta->bt_info & BT_INFO_8822B_1ANT_B_SCO_ESCO) {
-			coex_sta->sco_exist = TRUE;
-			coex_sta->num_of_profile++;
-		} else {
-			coex_sta->sco_exist = FALSE;
-		}
-
-	}
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	bt_link_info->bt_link_exist = coex_sta->bt_link_exist;
-	bt_link_info->sco_exist = coex_sta->sco_exist;
-	bt_link_info->a2dp_exist = coex_sta->a2dp_exist;
-	bt_link_info->pan_exist = coex_sta->pan_exist;
-	bt_link_info->hid_exist = coex_sta->hid_exist;
-	bt_link_info->acl_busy = coex_sta->acl_busy;
-
-	/* work around for HS mode. */
-	if (bt_hs_on) {
-		bt_link_info->pan_exist = TRUE;
-		bt_link_info->bt_link_exist = TRUE;
-	}
-
-	/* check if Sco only */
-	if (bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->sco_only = TRUE;
-	else
-		bt_link_info->sco_only = FALSE;
-
-	/* check if A2dp only */
-	if (!bt_link_info->sco_exist &&
-	    bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->a2dp_only = TRUE;
-	else
-		bt_link_info->a2dp_only = FALSE;
-
-	/* check if Pan only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    bt_link_info->pan_exist &&
-	    !bt_link_info->hid_exist)
-		bt_link_info->pan_only = TRUE;
-	else
-		bt_link_info->pan_only = FALSE;
-
-	/* check if Hid only */
-	if (!bt_link_info->sco_exist &&
-	    !bt_link_info->a2dp_exist &&
-	    !bt_link_info->pan_exist &&
-	    bt_link_info->hid_exist)
-		bt_link_info->hid_only = TRUE;
-	else
-		bt_link_info->hid_only = FALSE;
-
-	if (coex_sta->bt_info & BT_INFO_8822B_2ANT_B_INQ_PAGE) {
-		coex_dm->bt_status = BT_8822B_2ANT_BT_STATUS_INQ_PAGE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Inq/page!!!\n");
-	} else if (!(coex_sta->bt_info & BT_INFO_8822B_2ANT_B_CONNECTION)) {
-		coex_dm->bt_status = BT_8822B_2ANT_BT_STATUS_NON_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n");
-	} else if (coex_sta->bt_info == BT_INFO_8822B_2ANT_B_CONNECTION) {
-		/* connection exists but no busy */
-		coex_dm->bt_status = BT_8822B_2ANT_BT_STATUS_CONNECTED_IDLE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
-	} else if (((coex_sta->bt_info & BT_INFO_8822B_2ANT_B_SCO_ESCO) ||
-		    (coex_sta->bt_info & BT_INFO_8822B_2ANT_B_SCO_BUSY)) &&
-		   (coex_sta->bt_info & BT_INFO_8822B_2ANT_B_ACL_BUSY)) {
-		coex_dm->bt_status = BT_8822B_2ANT_BT_STATUS_ACL_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL SCO busy!!!\n");
-	} else if ((coex_sta->bt_info & BT_INFO_8822B_2ANT_B_SCO_ESCO) ||
-		   (coex_sta->bt_info & BT_INFO_8822B_2ANT_B_SCO_BUSY)) {
-		coex_dm->bt_status = BT_8822B_2ANT_BT_STATUS_SCO_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
-	} else if (coex_sta->bt_info & BT_INFO_8822B_2ANT_B_ACL_BUSY) {
-		coex_dm->bt_status = BT_8822B_2ANT_BT_STATUS_ACL_BUSY;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
-	} else {
-		coex_dm->bt_status = BT_8822B_2ANT_BT_STATUS_MAX;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n");
-	}
-
-	BTC_TRACE(trace_buf);
-
-	if ((BT_8822B_2ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) ||
-	    (BT_8822B_2ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) ||
-	    (BT_8822B_2ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status))
-		bt_busy = TRUE;
-	else
-		bt_busy = FALSE;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
-}
-
-
-static
-void halbtc8822b2ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	u8	h2c_parameter[3] = {0};
-	u32	wifi_bw;
-	u8	wifi_central_chnl;
-	u32	RTL97F_8822B = 0;
-
-	if (RTL97F_8822B)
-		return;
-
-	/* only 2.4G we need to inform bt the chnl mask */
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_CENTRAL_CHNL,
-			   &wifi_central_chnl);
-	if ((BTC_MEDIA_CONNECT == type) &&
-	    (wifi_central_chnl <= 14)) {
-		/* enable BT AFH skip WL channel for 8822b
-		 * because BT Rx LO interference
-		 */
-		h2c_parameter[0] = 0x1;
-#if 0
-		h2c_parameter[0] = 0x0;
-#endif
-		h2c_parameter[1] = wifi_central_chnl;
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw);
-		if (BTC_WIFI_BW_HT40 == wifi_bw)
-			h2c_parameter[2] = 0x30;
-		else
-			h2c_parameter[2] = 0x20;
-	}
-
-	coex_dm->wifi_chnl_info[0] = h2c_parameter[0];
-	coex_dm->wifi_chnl_info[1] = h2c_parameter[1];
-	coex_dm->wifi_chnl_info[2] = h2c_parameter[2];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter);
-
-}
-
-
-static
-void halbtc8822b2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,
-		IN u8 dac_swing_lvl)
-{
-	u8	h2c_parameter[1] = {0};
-	u32	RTL97F_8822B = 0;
-
-	if (RTL97F_8822B)
-		return;
-
-	/* There are several type of dacswing */
-	/* 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 */
-	h2c_parameter[0] = dac_swing_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter);
-}
-
-
-static
-void halbtc8822b2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,
-			      IN boolean force_exec, IN u8 fw_dac_swing_lvl)
-{
-	u32	RTL97F_8822B = 0;
-
-	if (RTL97F_8822B)
-		return;
-
-	coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_fw_dac_swing_lvl ==
-		    coex_dm->cur_fw_dac_swing_lvl)
-			return;
-	}
-
-	halbtc8822b2ant_set_fw_dac_swing_level(btcoexist,
-					       coex_dm->cur_fw_dac_swing_lvl);
-
-	coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl;
-}
-
-static
-void halbtc8822b2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				       IN u8 dec_bt_pwr_lvl)
-{
-	u32	RTL97F_8822B = 0;
-	u8	h2c_parameter[1] = {0};
-
-	if (RTL97F_8822B)
-		return;
-
-	h2c_parameter[0] = dec_bt_pwr_lvl;
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x62, 1, h2c_parameter);
-}
-
-static
-void halbtc8822b2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,
-				IN boolean force_exec, IN u8 dec_bt_pwr_lvl)
-{
-	coex_dm->cur_bt_dec_pwr_lvl = dec_bt_pwr_lvl;
-
-	if (!force_exec) {
-		if (coex_dm->pre_bt_dec_pwr_lvl == coex_dm->cur_bt_dec_pwr_lvl)
-			return;
-	}
-	halbtc8822b2ant_set_fw_dec_bt_pwr(btcoexist,
-					  coex_dm->cur_bt_dec_pwr_lvl);
-
-	coex_dm->pre_bt_dec_pwr_lvl = coex_dm->cur_bt_dec_pwr_lvl;
-}
-
-static
-void halbtc8822b2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,
-			    IN boolean force_exec, IN boolean low_penalty_ra)
-{
-
-#if 1
-	coex_dm->cur_low_penalty_ra = low_penalty_ra;
-
-	if (!force_exec) {
-		if (coex_dm->pre_low_penalty_ra ==
-		    coex_dm->cur_low_penalty_ra)
-			return;
-	}
-
-	if (low_penalty_ra)
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 50);
-	else
-		btcoexist->btc_phydm_modify_RA_PCR_threshold(btcoexist, 0, 0);
-
-	coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra;
-
-#endif
-
-}
-
-static
-void halbtc8822b2ant_write_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16				bitpos,
-	IN	boolean		state
-)
-{
-
-	static u16 originalval = 0x8002;
-
-	if (state)
-		originalval = originalval | bitpos;
-	else
-		originalval = originalval & (~bitpos);
-
-
-	btcoexist->btc_write_2byte(btcoexist, 0xaa, originalval);
-
-}
-
-static
-void halbtc8822b2ant_read_score_board(
-	IN	struct  btc_coexist		*btcoexist,
-	IN   u16				*score_board_val
-)
-{
-
-	*score_board_val = (btcoexist->btc_read_2byte(btcoexist,
-			    0xaa)) & 0x7fff;
-}
-
-static
-void halbtc8822b2ant_post_state_to_bt(
-	IN	struct  btc_coexist		*btcoexist,
-	IN	u16						type,
-	IN  BOOLEAN                 state
-)
-{
-
-	halbtc8822b2ant_write_score_board(btcoexist, (u16) type, state);
-
-}
-
-
-
-static
-void halbtc8822b2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)
-{
-	static u32		bt_disable_cnt = 0;
-	boolean			bt_active = TRUE, bt_disabled = FALSE, wifi_under_5g = FALSE;
-	u16			u16tmp;
-
-	/* This function check if bt is disabled */
-#if 0
-	if (coex_sta->high_priority_tx == 0 &&
-	    coex_sta->high_priority_rx == 0 &&
-	    coex_sta->low_priority_tx == 0 &&
-	    coex_sta->low_priority_rx == 0)
-		bt_active = FALSE;
-	if (coex_sta->high_priority_tx == 0xffff &&
-	    coex_sta->high_priority_rx == 0xffff &&
-	    coex_sta->low_priority_tx == 0xffff &&
-	    coex_sta->low_priority_rx == 0xffff)
-		bt_active = FALSE;
-
-
-#else
-
-	/* Read BT on/off status from scoreboard[1],
-	 * enable this only if BT patch support this feature
-	 */
-	halbtc8822b2ant_read_score_board(btcoexist,	&u16tmp);
-
-	bt_active = u16tmp & BIT(1);
-
-
-#endif
-
-	if (bt_active) {
-		bt_disable_cnt = 0;
-		bt_disabled = FALSE;
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	} else {
-
-		bt_disable_cnt++;
-		if (bt_disable_cnt >= 10) {
-			bt_disabled = TRUE;
-			bt_disable_cnt = 10;
-		}
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_DISABLE,
-				   &bt_disabled);
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((wifi_under_5g) || (bt_disabled))
-		halbtc8822b2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-	else
-		halbtc8822b2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, TRUE);
-
-
-	if (coex_sta->bt_disabled != bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is from %s to %s!!\n",
-			    (coex_sta->bt_disabled ? "disabled" : "enabled"),
-			    (bt_disabled ? "disabled" : "enabled"));
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_disabled = bt_disabled;
-	}
-
-}
-
-static
-void halbtc8822b2ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,
-					boolean isenable)
-{
-#if BT_8822B_2ANT_COEX_DBG
-	static u8			bitVal[5] = {0, 0, 0, 0, 0};
-#if 0
-	static boolean		state = FALSE;
-
-	if (state == isenable)
-		return;
-
-	state = isenable;
-#endif
-
-	if (isenable) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], enable_gnt_to_gpio!!\n");
-		BTC_TRACE(trace_buf);
-
-		/* enable GNT_WL, GNT_BT to GPIO for debug */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x1);
-
-		/* store original value */
-		bitVal[0] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x66) & BIT(4)) >> 4;	/*0x66[4] */
-		bitVal[1] = (btcoexist->btc_read_1byte(btcoexist,
-					       0x67) & BIT(0));	/*0x66[8] */
-		bitVal[2] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x42) & BIT(3)) >> 3;  /*0x40[19] */
-		bitVal[3] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x65) & BIT(7)) >> 7;  /*0x64[15] */
-		bitVal[4] = (btcoexist->btc_read_1byte(btcoexist,
-				       0x72) & BIT(2)) >> 2;  /*0x70[18] */
-
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   0x0);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   0x0);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-						   0x0);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-						   0x0);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-						   0x0);  /*0x70[18] = 0 */
-
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], disable_gnt_to_gpio!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x8, 0x0);
-
-		/*  Restore original value  */
-		/*  switch GPIO Mux */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, BIT(4),
-						   bitVal[0]);  /*0x66[4] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, BIT(0),
-						   bitVal[1]);  /*0x66[8] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x42, BIT(3),
-					   bitVal[2]);  /*0x40[19] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x65, BIT(7),
-					   bitVal[3]);  /*0x64[15] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x72, BIT(2),
-					   bitVal[4]);  /*0x70[18] = 0 */
-	}
-
-#endif
-}
-
-
-static
-u32 halbtc8822b2ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,
-		IN u16 reg_addr)
-{
-	u32 delay_count = 0;
-
-	while (1) {
-		if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-			delay_ms(50);
-			delay_count++;
-			if (delay_count >= 10) {
-				delay_count = 0;
-				break;
-			}
-		} else {
-			break;
-		}
-	}
-
-	/* wait for ready bit before access 0x1700		 */
-	btcoexist->btc_write_4byte(btcoexist, 0x1700, 0x800F0000 | reg_addr);
-
-	return btcoexist->btc_read_4byte(btcoexist,
-					 0x1708);  /* get read data */
-
-}
-
-
-static
-void halbtc8822b2ant_ltecoex_indirect_write_reg(IN struct btc_coexist
-		*btcoexist,
-		IN u16 reg_addr, IN u32 bit_mask, IN u32 reg_value)
-{
-	u32 val, i = 0, bitpos = 0, delay_count = 0;
-
-
-	if (bit_mask == 0x0)
-		return;
-	if (bit_mask == 0xffffffff) {
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else {
-				break;
-			}
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   reg_value); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-	} else {
-		for (i = 0; i <= 31; i++) {
-			if (((bit_mask >> i) & 0x1) == 0x1) {
-				bitpos = i;
-				break;
-			}
-		}
-
-		/* read back register value before write */
-		val = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				reg_addr);
-		val = (val & (~bit_mask)) | (reg_value << bitpos);
-
-		/* wait for ready bit before access 0x1700/0x1704 */
-		while (1) {
-			if ((btcoexist->btc_read_1byte(btcoexist, 0x1703)&BIT(5)) == 0) {
-				delay_ms(50);
-				delay_count++;
-				if (delay_count >= 10) {
-					delay_count = 0;
-					break;
-				}
-			} else {
-				break;
-			}
-		}
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1704,
-					   val); /* put write data */
-
-		btcoexist->btc_write_4byte(btcoexist, 0x1700,
-					   0xc00F0000 | reg_addr);
-	}
-
-}
-
-
-static
-void halbtc8822b2ant_ltecoex_enable(IN struct btc_coexist *btcoexist,
-				    IN boolean enable)
-{
-	u8 val;
-
-	val = (enable) ? 1 : 0;
-	halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist, 0x38, 0x80,
-			val);  /* 0x38[7] */
-
-}
-
-static
-void halbtc8822b2ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,
-		IN boolean wifi_control)
-{
-	u8 val;
-
-	val = (wifi_control) ? 1 : 0;
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x73, 0x4,
-					   val); /* 0x70[26] */
-
-}
-
-static
-void halbtc8822b2ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, bit_mask;
-
-	state = state & 0x1;
-	val = (sw_control) ? ((state << 1) | 0x1) : 0;
-
-	switch (control_block) {
-	case BT_8822B_2ANT_GNT_BLOCK_RFC_BB:
-	default:
-		bit_mask = 0xc000;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[15:14] */
-		bit_mask = 0x0c00;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[11:10] */
-		break;
-	case BT_8822B_2ANT_GNT_BLOCK_RFC:
-		bit_mask = 0xc000;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[15:14] */
-		break;
-	case BT_8822B_2ANT_GNT_BLOCK_BB:
-		bit_mask = 0x0c00;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[11:10] */
-		break;
-
-	}
-
-}
-
-static
-void halbtc8822b2ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,
-			IN u8 control_block, IN boolean sw_control, IN u8 state)
-{
-	u32 val = 0, bit_mask;
-
-	state = state & 0x1;
-	val = (sw_control) ? ((state << 1) | 0x1) : 0;
-
-	switch (control_block) {
-	case BT_8822B_2ANT_GNT_BLOCK_RFC_BB:
-	default:
-		bit_mask = 0x3000;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[13:12] */
-		bit_mask = 0x0300;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[9:8] */
-		break;
-	case BT_8822B_2ANT_GNT_BLOCK_RFC:
-		bit_mask = 0x3000;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[13:12] */
-		break;
-	case BT_8822B_2ANT_GNT_BLOCK_BB:
-		bit_mask = 0x0300;
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist,
-				0x38, bit_mask, val); /* 0x38[9:8] */
-		break;
-
-	}
-
-}
-
-static
-void halbtc8822b2ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,
-		IN u8 table_type, IN u16 table_content)
-{
-	u16 reg_addr = 0x0000;
-
-	switch (table_type) {
-	case BT_8822B_2ANT_CTT_WL_VS_LTE:
-		reg_addr = 0xa0;
-		break;
-	case BT_8822B_2ANT_CTT_BT_VS_LTE:
-		reg_addr = 0xa4;
-		break;
-	}
-
-	if (reg_addr != 0x0000)
-		halbtc8822b2ant_ltecoex_indirect_write_reg(btcoexist, reg_addr,
-			0xffff, table_content); /* 0xa0[15:0] or 0xa4[15:0] */
-
-
-}
-
-
-static
-void halbtc8822b2ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec,  IN u8 interval,
-		IN u8 val0x6c4_b0, IN u8 val0x6c4_b1, IN u8 val0x6c4_b2,
-		IN u8 val0x6c4_b3)
-{
-	static u8 pre_h2c_parameter[6] = {0};
-	u8	cur_h2c_parameter[6] = {0};
-	u8 i, match_cnt = 0;
-
-	cur_h2c_parameter[0] = 0x7;	/* op_code, 0x7= wlan toggle slot*/
-
-	cur_h2c_parameter[1] = interval;
-	cur_h2c_parameter[2] = val0x6c4_b0;
-	cur_h2c_parameter[3] = val0x6c4_b1;
-	cur_h2c_parameter[4] = val0x6c4_b2;
-	cur_h2c_parameter[5] = val0x6c4_b3;
-
-	if (!force_exec) {
-		for (i = 1; i <= 5; i++) {
-			if (cur_h2c_parameter[i] != pre_h2c_parameter[i])
-				break;
-
-			match_cnt++;
-		}
-
-		if (match_cnt == 5)
-			return;
-	}
-
-	for (i = 1; i <= 5; i++)
-		pre_h2c_parameter[i] = cur_h2c_parameter[i];
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, cur_h2c_parameter);
-}
-
-static
-void halbtc8822b2ant_set_coex_table(IN struct btc_coexist *btcoexist,
-	    IN u32 val0x6c0, IN u32 val0x6c4, IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4);
-
-	btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8);
-
-	btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc);
-}
-
-static
-void halbtc8822b2ant_coex_table(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u32 val0x6c0, IN u32 val0x6c4,
-				IN u32 val0x6c8, IN u8 val0x6cc)
-{
-	coex_dm->cur_val0x6c0 = val0x6c0;
-	coex_dm->cur_val0x6c4 = val0x6c4;
-	coex_dm->cur_val0x6c8 = val0x6c8;
-	coex_dm->cur_val0x6cc = val0x6cc;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) &&
-		    (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) &&
-		    (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) &&
-		    (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc))
-			return;
-	}
-	halbtc8822b2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, val0x6c8,
-				       val0x6cc);
-
-	coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0;
-	coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4;
-	coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8;
-	coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc;
-}
-
-static
-void halbtc8822b2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,
-		IN boolean force_exec, IN u8 type)
-{
-	u32	break_table;
-	u8	select_table;
-
-	coex_sta->coex_table_type = type;
-
-	if (coex_sta->concurrent_rx_mode_on) {
-		break_table = 0xf0ffffff;  /* set WL hi-pri can break BT */
-		/* set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS) */
-		select_table = 0xb;
-	} else {
-		break_table = 0xffffff;
-		select_table = 0x3;
-	}
-
-	switch (type) {
-	case 0:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0xffffffff, 0xffffffff, break_table, select_table);
-		break;
-	case 1:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0x5a5a5a5a, break_table, select_table);
-		break;
-	case 2:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0x5a5a5a5a, 0x5a5a5a5a, break_table, select_table);
-		break;
-	case 3:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0x5a5a5a5a, break_table, select_table);
-		break;
-	case 4:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0x5a5a5a5a, break_table, select_table);
-		break;
-	case 5:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0x55555555, break_table, select_table);
-		break;
-	case 6:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0xa5555555, 0xfafafafa, break_table, select_table);
-		break;
-	case 7:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0xa5555555, 0xaa5a5a5a, break_table, select_table);
-		break;
-	case 8:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0xa5555555, 0xfafafafa, break_table, select_table);
-		break;
-	case 9:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0x5a5a5a5a, 0xaaaa5aaa, break_table, select_table);
-		break;
-	case 10:
-		halbtc8822b2ant_coex_table(btcoexist, force_exec,
-			   0x55555555, 0x5a5a555a, break_table, select_table);
-		break;
-	default:
-		break;
-	}
-}
-
-static
-void halbtc8822b2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-		IN boolean enable)
-{
-	u8			h2c_parameter[1] = {0};
-	u32	RTL97F_8822B = 0;
-
-	if (RTL97F_8822B)
-		return;
-
-	if (enable)
-		h2c_parameter[0] |= BIT(0);		/* function enable */
-
-	btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter);
-}
-
-static
-void halbtc8822b2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,
-				     IN boolean force_exec, IN boolean enable)
-{
-	coex_dm->cur_ignore_wlan_act = enable;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ignore_wlan_act ==
-		    coex_dm->cur_ignore_wlan_act)
-			return;
-	}
-	halbtc8822b2ant_set_fw_ignore_wlan_act(btcoexist, enable);
-
-	coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act;
-}
-
-static
-void halbtc8822b2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,
-				  IN u8 lps_val, IN u8 rpwm_val)
-{
-	u8	lps = lps_val;
-	u8	rpwm = rpwm_val;
-
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps);
-	btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm);
-}
-
-static
-void halbtc8822b2ant_lps_rpwm(IN struct btc_coexist *btcoexist,
-		      IN boolean force_exec, IN u8 lps_val, IN u8 rpwm_val)
-{
-	coex_dm->cur_lps = lps_val;
-	coex_dm->cur_rpwm = rpwm_val;
-
-	if (!force_exec) {
-		if ((coex_dm->pre_lps == coex_dm->cur_lps) &&
-		    (coex_dm->pre_rpwm == coex_dm->cur_rpwm))
-			return;
-	}
-	halbtc8822b2ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val);
-
-	coex_dm->pre_lps = coex_dm->cur_lps;
-	coex_dm->pre_rpwm = coex_dm->cur_rpwm;
-}
-
-
-static
-void halbtc8822b2ant_ps_tdma_check_for_power_save_state(
-	IN struct btc_coexist *btcoexist, IN boolean new_ps_state)
-{
-	u8	lps_mode = 0x0;
-	u8	h2c_parameter[5] = {0, 0, 0, 0x40, 0};
-	u32	RTL97F_8822B = 0;
-
-	if (RTL97F_8822B)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode);
-
-	if (lps_mode) {	/* already under LPS state */
-		if (new_ps_state) {
-			/* keep state under LPS, do nothing. */
-		} else {
-			/* will leave LPS state, turn off psTdma first */
-#if 0
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE,
-						8);
-#endif
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		}
-	} else {					/* NO PS state */
-		if (new_ps_state) {
-			/* will enter LPS state, turn off psTdma first */
-#if 0
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE,
-						8);
-#endif
-			btcoexist->btc_fill_h2c(btcoexist, 0x60, 5,
-						h2c_parameter);
-		} else {
-			/* keep state under NO PS state, do nothing. */
-		}
-	}
-}
-
-
-static
-boolean halbtc8822b2ant_power_save_state(IN struct btc_coexist *btcoexist,
-			      IN u8 ps_type, IN u8 lps_val, IN u8 rpwm_val)
-{
-	boolean		low_pwr_disable = FALSE, result = TRUE;
-
-	switch (ps_type) {
-	case BTC_PS_WIFI_NATIVE:
-		coex_sta->force_lps_ctrl = FALSE;
-		/* recover to original 32k low power setting */
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b2ant_power_save_state == BTC_PS_WIFI_NATIVE\n");
-		BTC_TRACE(trace_buf);
-
-		low_pwr_disable = FALSE;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS,
-				   NULL);
-		break;
-	case BTC_PS_LPS_ON:
-		coex_sta->force_lps_ctrl = TRUE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b2ant_power_save_state == BTC_PS_LPS_ON\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, TRUE);
-		halbtc8822b2ant_lps_rpwm(btcoexist, NORMAL_EXEC,
-					 lps_val, rpwm_val);
-		/* when coex force to enter LPS, do not enter 32k low power. */
-		low_pwr_disable = TRUE;
-		btcoexist->btc_set(btcoexist,
-				   BTC_SET_ACT_DISABLE_LOW_POWER,
-				   &low_pwr_disable);
-		/* power save must executed before psTdma. */
-		btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS,
-				   NULL);
-		break;
-	case BTC_PS_LPS_OFF:
-		coex_sta->force_lps_ctrl = TRUE;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b2ant_power_save_state == BTC_PS_LPS_OFF\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_ps_tdma_check_for_power_save_state(
-			btcoexist, FALSE);
-		result = btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS,
-				   NULL);
-		break;
-	default:
-		break;
-	}
-
-	return result;
-}
-
-
-
-
-static
-void halbtc8822b2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,
-	   IN u8 byte1, IN u8 byte2, IN u8 byte3, IN u8 byte4, IN u8 byte5)
-{
-	u8			h2c_parameter[5] = {0};
-	u8			real_byte1 = byte1, real_byte5 = byte5;
-	boolean			ap_enable = FALSE, result = FALSE;
-	struct	btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	if (byte5 & BIT(2))
-		coex_sta->is_tdma_btautoslot = TRUE;
-	else
-		coex_sta->is_tdma_btautoslot = FALSE;
-
-	/* release bt-auto slot for auto-slot hang is detected!! */
-	if (coex_sta->is_tdma_btautoslot)
-		if ((coex_sta->is_tdma_btautoslot_hang) ||
-			(bt_link_info->slave_role))
-			byte5 = byte5 & 0xfb;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_AP_MODE_ENABLE,
-			   &ap_enable);
-
-	if ((ap_enable) && (byte1 & BIT(4) && !(byte1 & BIT(5)))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b2ant_set_fw_pstdma == FW for AP mode\n");
-		BTC_TRACE(trace_buf);
-
-		real_byte1 &= ~BIT(4);
-		real_byte1 |= BIT(5);
-
-		real_byte5 |= BIT(5);
-		real_byte5 &= ~BIT(6);
-
-		halbtc8822b2ant_power_save_state(btcoexist,
-					 BTC_PS_WIFI_NATIVE, 0x0, 0x0);
-	} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b2ant_set_fw_pstdma == Force LPS (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-
-#if 0
-		halbtc8822b2ant_power_save_state(
-			btcoexist, BTC_PS_LPS_ON, 0x50,
-			0x4);
-#endif
-		if (!halbtc8822b2ant_power_save_state(btcoexist, BTC_PS_LPS_OFF, 0x50, 0x4))
-			result = TRUE;
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], halbtc8822b2ant_set_fw_pstdma == Native LPS (byte1 = 0x%x)\n", byte1);
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE,
-						 0x0,
-						 0x0);
-	}
-
-
-	coex_sta->is_set_ps_state_fail = result;
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		h2c_parameter[0] = real_byte1;
-		h2c_parameter[1] = byte2;
-		h2c_parameter[2] = byte3;
-		h2c_parameter[3] = byte4;
-		h2c_parameter[4] = real_byte5;
-
-		coex_dm->ps_tdma_para[0] = real_byte1;
-		coex_dm->ps_tdma_para[1] = byte2;
-		coex_dm->ps_tdma_para[2] = byte3;
-		coex_dm->ps_tdma_para[3] = byte4;
-		coex_dm->ps_tdma_para[4] = real_byte5;
-
-		btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter);
-
-	} else {
-		coex_sta->cnt_set_ps_state_fail++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], halbtc8822b2ant_set_fw_pstdma == Force Leave LPS Fail (cnt = %d)\n",
-				coex_sta->cnt_set_ps_state_fail);
-		BTC_TRACE(trace_buf);
-	}
-}
-
-
-static
-void halbtc8822b2ant_ps_tdma(IN struct btc_coexist *btcoexist,
-		     IN boolean force_exec, IN boolean turn_on, IN u8 type)
-{
-	static u8			psTdmaByte4Modify = 0x0, pre_psTdmaByte4Modify = 0x0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	coex_dm->cur_ps_tdma_on = turn_on;
-	coex_dm->cur_ps_tdma = type;
-
-	/* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */
-	if (bt_link_info->slave_role)
-		psTdmaByte4Modify = 0x1;
-	else
-		psTdmaByte4Modify = 0x0;
-
-	if (pre_psTdmaByte4Modify != psTdmaByte4Modify) {
-		force_exec = TRUE;
-		pre_psTdmaByte4Modify = psTdmaByte4Modify;
-	}
-
-	if (!force_exec) {
-		if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) &&
-		    (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma)) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Skip TDMA because no change TDMA(%s, %d)\n",
-				    (coex_dm->cur_ps_tdma_on ? "on" : "off"),
-				    coex_dm->cur_ps_tdma);
-			BTC_TRACE(trace_buf);
-			return;
-		}
-	}
-
-	if (coex_dm->cur_ps_tdma_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(on, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], ********** TDMA(off, %d) **********\n",
-			    coex_dm->cur_ps_tdma);
-		BTC_TRACE(trace_buf);
-	}
-
-
-	if (turn_on) {
-		switch (type) {
-		case 1:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x91,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 2:
-		default:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11,
-						      0x11 | psTdmaByte4Modify);
-			break;
-		case 3:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x3a, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 4:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x21, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 5:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 6:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 7:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x20, 0x3, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 8:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x15, 0x03, 0x11,
-						      0x11);
-			break;
-		case 10:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x30, 0x03, 0x11,
-						      0x10);
-			break;
-		case 11:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 12:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11, 0x11);
-			break;
-		case 13:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x1c, 0x03, 0x11,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 14:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x20, 0x03, 0x11,
-						      0x11);
-			break;
-		case 15:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x11,
-						      0x14);
-			break;
-		case 16:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x11,
-						      0x15);
-			break;
-		case 21:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x30, 0x03, 0x11,
-						      0x10);
-			break;
-		case 22:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11,
-						      0x10);
-			break;
-		case 23:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-							0x10, 0x03, 0x11,
-							0x10);
-			break;
-		case 51:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x10, 0x03, 0x91,
-						      0x10 | psTdmaByte4Modify);
-			break;
-		case 101:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11,
-						      0x11 | psTdmaByte4Modify);
-			break;
-		case 102:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x35, 0x03, 0x11,
-						      0x11 | psTdmaByte4Modify);
-			break;
-		case 103:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x3a, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 104:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x21, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 105:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 106:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 107:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x7, 0x10,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 108:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x30, 0x3, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 109:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x03, 0x10,
-						      0x54 | psTdmaByte4Modify);
-			break;
-		case 110:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x55,
-						      0x30, 0x03, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		case 111:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x61,
-						      0x25, 0x03, 0x11,
-						      0x11 | psTdmaByte4Modify);
-			break;
-		case 151:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x51,
-						      0x10, 0x03, 0x10,
-						      0x50 | psTdmaByte4Modify);
-			break;
-		}
-	} else {
-		/* disable PS tdma */
-		switch (type) {
-#if 0
-/* 08:1ant:PTA Control -0x778=1-ant hw control,40:2ant:sw control-diversity */
-#endif
-
-		case 0:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		default:
-			halbtc8822b2ant_set_fw_pstdma(btcoexist, 0x0,
-						      0x0, 0x0, 0x40, 0x0);
-			break;
-		}
-	}
-
-	if (!coex_sta->is_set_ps_state_fail) {
-		/* update pre state */
-		coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on;
-		coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma;
-	}
-}
-
-/*anttenna control by bb mac bt antdiv pta to write 0x4c 0xcb4,0xcbd*/
-static
-void halbtc8822b2ant_set_ext_ant_switch(IN struct btc_coexist *btcoexist,
-			IN boolean force_exec, IN u8 ctrl_type, IN u8 pos_type)
-{
-#if 0
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-#endif
-	boolean	switch_polatiry_inverse = FALSE;
-	u8		regval_0xcbc = 0, regval_0x64;
-#if BT_8822B_2ANT_COEX_DBG
-	u32		u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-#endif
-
-	if (!rfe_type->ext_ant_switch_exist)
-		return;
-
-	coex_dm->cur_ext_ant_switch_status = (ctrl_type << 8)  + pos_type;
-
-	if (!force_exec) {
-		if (coex_dm->pre_ext_ant_switch_status ==
-		    coex_dm->cur_ext_ant_switch_status)
-			return;
-	}
-	coex_dm->pre_ext_ant_switch_status = coex_dm->cur_ext_ant_switch_status;
-
-#if 0
-	switch (pos_type) {
-	default:
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_BT:
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE:
-		break;
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLG:
-		break;
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLA:
-		break;
-	}
-#endif
-
-#if 0
-	if (board_info->ant_div_cfg)
-		ctrl_type = BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV;
-#endif
-
-	/* Ext switch buffer mux */
-	btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991, 0x3, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe, 0x8, 0x0);
-
-
-	switch (ctrl_type) {
-	default:
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /*  0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		/* BB SW, DPDT use RFE_ctrl8 and RFE_ctrl9 as conctrol pin */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-			0xff, 0x77);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd,
-						   0x03, 01);
-
-		break;
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_PTA:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		/* PTA,  DPDT use RFE_ctrl8 and RFE_ctrl9 as conctrol pin */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-			0xff, 0x66);
-
-		/* 0xcb4[29:28] = 2b'10 for no switch_polatiry_inverse,
-		 * DPDT_SEL_N =1, DPDT_SEL_P =0  @ GNT_BT=1
-		 */
-		regval_0xcbc = (!switch_polatiry_inverse ? 0x2 : 0x1);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbc,
-						   0x03, regval_0xcbc);
-
-		break;
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);/* 0x4c[24] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4, 0xff, 0x88);
-		break;
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_MAC:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x1);  /*  0x4c[23] = 1 */
-
-		/* 0x64[0] = 1b'0 for no switch_polatiry_inverse,
-		 * DPDT_SEL_N =1, DPDT_SEL_P =0
-		 */
-		regval_0x64 = (!switch_polatiry_inverse ? 0x0 : 0x1);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1,
-						   regval_0x64);
-		break;
-	case BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x0);  /* 0x4c[24] = 0 */
-
-		/* no setup required, because  antenna switch control value by
-		 * BT vendor 0x1c[1:0]
-		 */
-		break;
-	}
-
-	/* PAPE, LNA_ON control by BT while WLAN off for current leakage issue*/
-	if (ctrl_type == BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT) {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-					   0x0);  /* PAPE   0x64[29] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x10,
-					   0x0);  /* LNA_ON 0x64[28] = 0 */
-	} else {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20,
-					   0x1);  /* PAPE   0x64[29] = 1 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x10,
-					   0x1);  /* LNA_ON 0x64[28] = 1 */
-	}
-
-#if BT_8822B_2ANT_COEX_DBG
-
-	u32tmp1 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp2 = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0x64) & 0xff;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (After Ext Ant switch setup) 0xcb4 = 0x%08x, 0x4c = 0x%08x, 0x64= 0x%02x\n",
-		    u32tmp1, u32tmp2, u32tmp3);
-	BTC_TRACE(trace_buf);
-#endif
-
-
-
-}
-
-/* rf4 type by efuse, and for ant at main aux inverse use,
- * because is 2x2, and control types are the same, does not need
- */
-static
-void halbtc8822b2ant_set_rfe_type(IN struct btc_coexist *btcoexist)
-{
-
-	struct  btc_board_info *board_info = &btcoexist->board_info;
-
-
-	rfe_type->ext_band_switch_exist = FALSE;
-	rfe_type->ext_band_switch_type =
-		BT_8822B_2ANT_EXT_BAND_SWITCH_USE_SPDT;     /* SPDT; */
-	rfe_type->ext_band_switch_ctrl_polarity = 0;
-	/* Ext switch buffer mux */
-	btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991, 0x3, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe, 0x8, 0x0);
-
-	if (rfe_type->ext_band_switch_exist) {
-
-		/* band switch use RFE_ctrl1 (pin name: PAPE_A) and
-		 * RFE_ctrl3 (pin name: LNAON_A)
-		 */
-
-		/* set RFE_ctrl1 as software control */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb0, 0xf0, 0x7);
-
-		/* set RFE_ctrl3 as software control */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb1, 0xf0, 0x7);
-
-	}
-
-
-	/* the following setup should be got from Efuse in the future */
-	rfe_type->rfe_module_type = board_info->rfe_type;
-
-	rfe_type->ext_ant_switch_ctrl_polarity = 0;
-
-	switch (rfe_type->rfe_module_type) {
-	case 0:
-	default:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type = BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 1:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type = BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 2:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type = BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 3:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type = BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 4:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type =
-	BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 5:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type = BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 6:
-		rfe_type->ext_ant_switch_exist = TRUE;
-		rfe_type->ext_ant_switch_type = BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	case 7:
-		rfe_type->ext_ant_switch_exist = TRUE;
-rfe_type->ext_ant_switch_type = BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT;
-		break;
-	}
-
-#if 0
-
-	if (rfe_type->wlg_Locate_at_btg)
-		halbtc8822b2ant_set_int_block(btcoexist, FORCE_EXEC,
-			      BT_8822B_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG);
-	else
-		halbtc8822b2ant_set_int_block(btcoexist, FORCE_EXEC,
-			      BT_8822B_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG);
-#endif
-
-}
-
-/* set gnt_wl gnt_bt control by sw high low, or hwpta while in
- * power on, ini, wlan off, wlan only, wl2g non-currrent, wl2g current, wl5g
- */
-static
-void halbtc8822b2ant_set_ant_path(IN struct btc_coexist *btcoexist,
-				  IN u8 ant_pos_type, IN boolean force_exec,
-				  IN u8 phase)
-{
-#if BT_8822B_2ANT_COEX_DBG
-	u8			u8tmp = 0;
-#endif
-	u32			u32tmp1 = 0;
-#if BT_8822B_2ANT_COEX_DBG
-	u32			u32tmp2 = 0, u32tmp3 = 0;
-#endif
-
-	u32tmp1 = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				0x38);
-
-	/* To avoid indirect access fail  */
-	if (((u32tmp1 & 0xf000) >> 12) != ((u32tmp1 & 0x0f00) >> 8)) {
-		force_exec = TRUE;
-		coex_sta->gnt_error_cnt++;
-	}
-
-	/* Ext switch buffer mux */
-	btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x1991, 0x3, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbe, 0x8, 0x0);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-				   0x80, 0x0);  /*  0x4c[23] = 0 */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-				   0x01, 0x1);  /* 0x4c[24] = 1 */
-
-	coex_dm->cur_ant_pos_type = (ant_pos_type << 8)  + phase;
-
-	if (!force_exec) {
-		if (coex_dm->cur_ant_pos_type == coex_dm->pre_ant_pos_type)
-			return;
-	}
-
-	coex_dm->pre_ant_pos_type = coex_dm->cur_ant_pos_type;
-
-#if BT_8822B_2ANT_COEX_DBG
-	u32tmp1 = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-			0x38);
-	u32tmp2 = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-			0x54);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (Before Ant Setup) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    u32tmp3, u8tmp, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-#endif
-
-	switch (phase) {
-	case BT_8822B_2ANT_PHASE_COEX_POWERON:
-
-		/* set Path control owner to WL at initial step */
-		halbtc8822b2ant_ltecoex_pathcontrol_owner(btcoexist,
-				BT_8822B_2ANT_PCO_BTSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8822b2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW high */
-		halbtc8822b2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = FALSE;
-
-		break;
-	case BT_8822B_2ANT_PHASE_COEX_INIT:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /*  0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x1);  /* 0x4c[24] = 1 */
-		/* Disable LTE Coex Function in WiFi side
-		 * (this should be on if LTE coex is required)
-		 */
-		halbtc8822b2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8822B_2ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8822B_2ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-		/* set Path control owner to WL at initial step */
-		halbtc8822b2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8822B_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW high */
-		halbtc8822b2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW high */
-		halbtc8822b2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = FALSE;
-
-		break;
-	case BT_8822B_2ANT_PHASE_WLANONLY_INIT:
-		/* Disable LTE Coex Function in WiFi side
-		 * (this should be on if LTE coex is required)
-		 */
-		halbtc8822b2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* GNT_WL_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8822B_2ANT_CTT_WL_VS_LTE,
-			0xffff);
-
-		/* GNT_BT_LTE always = 1
-		 * (this should be config if LTE coex is required)
-		 */
-		halbtc8822b2ant_ltecoex_set_coex_table(
-			btcoexist,
-			BT_8822B_2ANT_CTT_BT_VS_LTE,
-			0xffff);
-
-		/* set Path control owner to WL at initial step */
-		halbtc8822b2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8822B_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Low */
-		halbtc8822b2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_LOW);
-		/* Set GNT_WL to SW high */
-		halbtc8822b2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-
-		coex_sta->run_time_state = FALSE;
-
-
-		break;
-	case BT_8822B_2ANT_PHASE_WLAN_OFF:
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4e,
-					   0x80, 0x0);  /* 0x4c[23] = 0 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4f,
-					   0x01, 0x0);  /* 0x4c[24] = 0 */
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8822b2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to BT */
-		halbtc8822b2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8822B_2ANT_PCO_BTSIDE);
-
-		/* Set Ext Ant Switch to BT control at wifi off step */
-		halbtc8822b2ant_set_ext_ant_switch(btcoexist,
-						   FORCE_EXEC,
-				   BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT,
-				   BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE);
-		coex_sta->run_time_state = FALSE;
-		break;
-	case BT_8822B_2ANT_PHASE_2G_RUNTIME:
-	case BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT:
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8822b2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8822B_2ANT_PCO_WLSIDE);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcb4,
-			0xff, 0x66);
-		if (phase ==
-		    BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT) {
-			/* set GNT_BT to PTA */
-			halbtc8822b2ant_ltecoex_set_gnt_bt(
-				btcoexist,
-				BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8822B_2ANT_GNT_TYPE_CTRL_BY_PTA,
-				BT_8822B_2ANT_SIG_STA_SET_BY_HW);
-
-			/* Set GNT_WL to SW High */
-			halbtc8822b2ant_ltecoex_set_gnt_wl(
-				btcoexist,
-				BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-				BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-		} else {
-			/* set GNT_BT to PTA */
-			halbtc8822b2ant_ltecoex_set_gnt_bt(
-				btcoexist,
-				BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8822B_2ANT_GNT_TYPE_CTRL_BY_PTA,
-				BT_8822B_2ANT_SIG_STA_SET_BY_HW);
-
-			/* Set GNT_WL to PTA */
-			halbtc8822b2ant_ltecoex_set_gnt_wl(
-				btcoexist,
-				BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-				BT_8822B_2ANT_GNT_TYPE_CTRL_BY_PTA,
-				BT_8822B_2ANT_SIG_STA_SET_BY_HW);
-		}
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ************* under2g 0xcbd setting =2 *************\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd, 0x03, 02);
-		break;
-
-	case BT_8822B_2ANT_PHASE_5G_RUNTIME:
-
-		/* set Path control owner to WL at runtime step */
-		halbtc8822b2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8822B_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8822b2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW Hi */
-		halbtc8822b2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-		coex_sta->run_time_state = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ************* under5g 0xcbd setting =1 *************\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0xcbd,
-							   0x03, 01);
-
-		break;
-	case BT_8822B_2ANT_PHASE_BTMPMODE:
-		/* Disable LTE Coex Function in WiFi side */
-		halbtc8822b2ant_ltecoex_enable(btcoexist, 0x0);
-
-		/* set Path control owner to WL */
-		halbtc8822b2ant_ltecoex_pathcontrol_owner(
-			btcoexist,
-			BT_8822B_2ANT_PCO_WLSIDE);
-
-		/* set GNT_BT to SW Hi */
-		halbtc8822b2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-
-		/* Set GNT_WL to SW Lo */
-		halbtc8822b2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_LOW);
-
-		coex_sta->run_time_state = FALSE;
-		break;
-	}
-#if BT_8822B_2ANT_COEX_DBG
-	u32tmp1 = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u8tmp  = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (After Ant-Setup phase---%d) 0xcb4 = 0x%x, 0x73 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    phase, u32tmp3, u8tmp, u32tmp1, u32tmp2);
-
-	BTC_TRACE(trace_buf);
-#endif
-
-}
-
-
-static
-void halbtc8822b2ant_set_rx_gain(IN struct btc_coexist *btcoexist,
-				   IN boolean agc_table_en)
-{
-	u8		rssi_adjust_val = 0;
-
-	/* =================BB AGC Gain Table */
-	if (agc_table_en) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table On!\n");
-		BTC_TRACE(trace_buf);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		btcoexist->btc_write_1byte(btcoexist, 0xc5b, 0xc8);
-		btcoexist->btc_write_1byte(btcoexist, 0xe5b, 0xc8);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xff000003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xae2e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xad300003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xac320003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xab360003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8d380003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8c3a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8b3c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x8a3e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6e400003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6d420003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6c440003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6b460003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x6a480003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x694a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x684c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x674e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x66500003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x65520003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x64540003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x64560003);
-
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x007e0403);
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BB Agc Table Off!\n");
-		BTC_TRACE(trace_buf);
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		btcoexist->btc_write_1byte(btcoexist, 0xc5b, 0xd8);
-		btcoexist->btc_write_1byte(btcoexist, 0xe5b, 0xd8);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xff000003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xe62e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xe5300003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc8320003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc6360003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc5380003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc43a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc33c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc23e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc1400003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xc0420003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa5440003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa4460003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa3480003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa24a0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0xa14c0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x834e0003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x82500003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x81520003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x80540003);
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x65560003);
-
-		btcoexist->btc_write_4byte(btcoexist, 0x81c, 0x007e0403);
-	}
-
-}
-
-
-static
-void halbtc8822b2ant_rx_gain(IN struct btc_coexist *btcoexist,
-			       IN boolean force_exec, IN boolean agc_table_en)
-{
-	coex_dm->cur_agc_table_en = agc_table_en;
-
-	if (!force_exec) {
-		if (coex_dm->pre_agc_table_en == coex_dm->cur_agc_table_en)
-			return;
-	}
-	halbtc8822b2ant_set_rx_gain(btcoexist, agc_table_en);
-
-	coex_dm->pre_agc_table_en = coex_dm->cur_agc_table_en;
-}
-
-
-static
-u8 halbtc8822b2ant_action_algorithm(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-	boolean				bt_hs_on = FALSE;
-	u8				algorithm = BT_8822B_2ANT_COEX_ALGO_UNDEFINED;
-	u8				num_of_diff_profile = 0;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (!bt_link_info->bt_link_exist) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], No BT link exists!!!\n");
-		BTC_TRACE(trace_buf);
-		return algorithm;
-	}
-
-	if (bt_link_info->sco_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->hid_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->pan_exist)
-		num_of_diff_profile++;
-	if (bt_link_info->a2dp_exist)
-		num_of_diff_profile++;
-
-	if (num_of_diff_profile == 0) {
-
-		if (bt_link_info->acl_busy) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], No-Profile busy\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8822B_2ANT_COEX_ALGO_NOPROFILEBUSY;
-		}
-	} else if ((bt_link_info->a2dp_exist) && (coex_sta->is_bt_a2dp_sink)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], A2DP Sink\n");
-		BTC_TRACE(trace_buf);
-		algorithm = BT_8822B_2ANT_COEX_ALGO_A2DPSINK;
-	} else if (num_of_diff_profile == 1) {
-		if (bt_link_info->sco_exist) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], SCO only\n");
-			BTC_TRACE(trace_buf);
-			algorithm = BT_8822B_2ANT_COEX_ALGO_SCO;
-		} else {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], HID only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_2ANT_COEX_ALGO_HID;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], A2DP only\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], PAN(HS) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], PAN(EDR) only\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 2) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + HID\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_2ANT_COEX_ALGO_SCO;
-			} else if (bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					    "[BTCoex], SCO + A2DP ==> A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_2ANT_COEX_ALGO_A2DP;
-			} else if (bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8822B_2ANT_COEX_ALGO_SCO;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				{
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						    "[BTCoex], HID + A2DP\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_HID_A2DP;
-				}
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm = BT_8822B_2ANT_COEX_ALGO_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_A2DP_PANHS;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		}
-	} else if (num_of_diff_profile == 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->a2dp_exist) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], SCO + HID + A2DP ==> HID + A2DP\n");
-				BTC_TRACE(trace_buf);
-				algorithm = BT_8822B_2ANT_COEX_ALGO_HID_A2DP;
-			} else if (bt_link_info->hid_exist &&
-				   bt_link_info->pan_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR_HID;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR_HID;
-				}
-			} else if (bt_link_info->pan_exist &&
-				   bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR_A2DP;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_PANEDR_A2DP;
-				}
-			}
-		} else {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], HID + A2DP + PAN(EDR)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	} else if (num_of_diff_profile >= 3) {
-		if (bt_link_info->sco_exist) {
-			if (bt_link_info->hid_exist &&
-			    bt_link_info->pan_exist &&
-			    bt_link_info->a2dp_exist) {
-				if (bt_hs_on) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				} else {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-						"[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
-					BTC_TRACE(trace_buf);
-					algorithm =
-						BT_8822B_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-				}
-			}
-		}
-	}
-
-	return algorithm;
-}
-
-
-static
-void halbtc8822b2ant_action_coex_all_off(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-#if 0
-	/*halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT);*/
-#endif
-
-	/* fw all off */
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-}
-
-static
-void halbtc8822b2ant_action_wifi_under5g(IN struct btc_coexist *btcoexist)
-{
-
-	/* fw all off */
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ************* under5g *************\n");
-	BTC_TRACE(trace_buf);
-	halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-	halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-}
-
-static
-void halbtc8822b2ant_action_wifi_native_lps(IN struct btc_coexist *btcoexist)
-{
-#if 0
-	halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 2);
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-#endif
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-}
-
-
-static
-void halbtc8822b2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)
-{
-
-	boolean	wifi_connected = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE;
-	boolean			wifi_busy = FALSE;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-	if ((coex_sta->bt_create_connection) && ((wifi_link) || (wifi_roam)
-		|| (wifi_scan) || (wifi_busy) || (coex_sta->wifi_is_high_pri_task))) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi link/roam/Scan/busy/hi-pri-task + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC,
-						     8);
-
-		if ((bt_link_info->a2dp_exist) && (!bt_link_info->pan_exist))
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						15);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						11);
-	}  else if ((!wifi_connected) && (!wifi_scan)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], Wifi no-link + no-scan + BT Inq/Page!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (bt_link_info->pan_exist) {
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-
-
-	} else if (bt_link_info->a2dp_exist) {
-#if 0
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-#endif
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 10);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-
-	} else {
-
-		if ((wifi_link) || (wifi_roam) || (wifi_scan) || (wifi_busy)
-			|| (coex_sta->wifi_is_high_pri_task))
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 23);
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-	}
-
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-}
-
-static
-void halbtc8822b2ant_action_wifi_link_process(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 0xd4);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-	if (bt_link_info->pan_exist) {
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 22);
-
-	} else if (bt_link_info->a2dp_exist) {
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 16);
-
-	} else {
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 21);
-
-	}
-
-}
-
-static
-void halbtc8822b2ant_action_wifi_nonconnected(IN struct btc_coexist *btcoexist)
-{
-	halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-#if 0
-	/*halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT);*/
-#endif
-
-	/* fw all off */
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-}
-
-static
-void halbtc8822b2ant_action_bt_relink(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], run bt multi link function\n");
-		BTC_TRACE(trace_buf);
-
-	if (coex_sta->is_bt_multi_link)
-		return;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], run bt re-link function\n");
-	BTC_TRACE(trace_buf);
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-}
-
-static
-void halbtc8822b2ant_action_bt_idle(IN struct btc_coexist *btcoexist)
-{
-
-	boolean			wifi_busy = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	if (!wifi_busy) {
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 14);
-	} else {  /* if wl busy */
-
-		if (BT_8822B_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-		    coex_dm->bt_status) {
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-					     NORMAL_EXEC, 0);
-
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE,
-						0);
-		} else {
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-					     NORMAL_EXEC,
-							  8);
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						12);
-		}
-	}
-
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-}
-
-/* SCO only or SCO+PAN(HS) */
-static
-void halbtc8822b2ant_action_sco(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean			wifi_busy = FALSE;
-	u32  wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres , 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		/*halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);*/
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		if (coex_sta->is_eSCO_mode)
-			halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-		else  /* 2-Ant free run if SCO mode */
-			halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE, 8);
-	}
-
-}
-
-
-static
-void halbtc8822b2ant_action_hid(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE;
-	u32  wifi_bw = 1;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,  &wifi_bw);
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		/*halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);*/
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-	}  else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		if (coex_sta->is_hid_low_pri_tx_overhead) {
-
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 4);
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						108);
-		} else if (wifi_bw == 0) {   /* if 11bg mode */
-
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-					NORMAL_EXEC, 8);
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						111);
-		} else {
-
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-				NORMAL_EXEC, 8);
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						111);
-		}
-	}
-
-}
-
-
-static
-void halbtc8822b2ant_action_a2dpsink(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean wifi_busy = FALSE, wifi_turbo = FALSE;
-#if 0
-	halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-#endif
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-			coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-		BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		/*halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);*/
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-						TRUE, 1);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						16);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		if ((coex_sta->bt_relink_downcount != 0)
-			&& (wifi_busy)) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Re-Link + A2DP + WL busy\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-			halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-		} else {
-			halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-						TRUE, 105);
-		}
-
-	}
-
-}
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-static
-void halbtc8822b2ant_action_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		/*halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);*/
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-						TRUE, 1);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						16);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		if ((coex_sta->bt_relink_downcount != 0)
-			&& (wifi_busy)) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Re-Link + A2DP + WL busy\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-			halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-
-		} else {
-
-			if (wifi_turbo)
-				halbtc8822b2ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC, 10);
-			else
-				halbtc8822b2ant_coex_table_with_type(btcoexist,
-								     NORMAL_EXEC,
-								     10);
-#if 0
-halbtc8822b2ant_coex_table_with_type(btcoexist,
-NORMAL_EXEC,
-7);
-#endif
-
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 109);
-		}
-
-	}
-
-}
-
-
-static
-void halbtc8822b2ant_action_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-#if 0
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-	halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-	coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-#endif
-
-
-#if 1
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						3);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						4);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						103);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						104);
-	}
-
-#endif
-
-}
-
-static
-void halbtc8822b2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean			wifi_busy = FALSE;
-	u32  wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		/*halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);*/
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-						TRUE, 1);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						16);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		if ((coex_sta->bt_relink_downcount != 0)
-			&& (wifi_busy)) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"############# [BTCoex],  BT Re-Link + A2DP + WL busy\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-			halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-		} else {
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 109);
-		}
-	}
-
-}
-
-static
-void halbtc8822b2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);*/
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy) {
-
-			if ((coex_sta->a2dp_bit_pool > 40) &&
-			    (coex_sta->a2dp_bit_pool < 255))
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 7);
-			else
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 5);
-		} else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						6);
-
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		if (wifi_turbo)
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 6);
-		else
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC,
-							     7);
-
-		if (wifi_busy) {
-
-			if ((coex_sta->a2dp_bit_pool > 40) &&
-			    (coex_sta->a2dp_bit_pool < 255))
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 107);
-			else
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 105);
-		} else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						106);
-
-	}
-
-}
-
-
-
-
-/* PAN(EDR)+A2DP */
-static
-void halbtc8822b2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy) {
-
-			if (((coex_sta->a2dp_bit_pool > 40) &&
-			     (coex_sta->a2dp_bit_pool < 255)) ||
-			    (!coex_sta->is_A2DP_3M))
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 7);
-			else
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 5);
-		} else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						6);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC,
-							     8);
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						107);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						106);
-	}
-
-}
-
-
-static
-void halbtc8822b2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8	wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE;
-	u32	wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2);
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						3);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						4);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-		halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8);
-
-		if (wifi_busy)
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						103);
-		else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						104);
-	}
-
-}
-
-
-/* HID+A2DP+PAN(EDR) */
-static
-void halbtc8822b2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8	wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE;
-	u32	wifi_bw = 1;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW,
-			   &wifi_bw);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-#if 0
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 4);
-
-		if (wifi_busy) {
-
-			if (((coex_sta->a2dp_bit_pool > 40) &&
-			     (coex_sta->a2dp_bit_pool < 255)) ||
-			    (!coex_sta->is_A2DP_3M))
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 7);
-			else
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-							TRUE, 5);
-		} else
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						6);
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		if (coex_sta->hid_busy_num >= 2) {
-			halbtc8822b2ant_coex_table_with_type(btcoexist,
-							     NORMAL_EXEC, 8);
-
-			if (wifi_bw == 0) {
-				halbtc8822b2ant_set_wltoggle_coex_table(
-					btcoexist,
-					NORMAL_EXEC,
-					0x1, 0xaa,
-					0x5a, 0xaa,
-					0xaa);
-				}
-			else
-				halbtc8822b2ant_set_wltoggle_coex_table(
-					btcoexist,
-					NORMAL_EXEC,
-					0x2, 0xaa,
-					0x5a, 0xaa,
-					0xaa);
-
-			halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-						110);
-		} else {
-			halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 1);
-
-			if (wifi_busy) {
-
-				if ((coex_sta->a2dp_bit_pool > 40) &&
-				    (coex_sta->a2dp_bit_pool < 255))
-					halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-								TRUE, 107);
-				else
-					halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC,
-								TRUE, 105);
-			} else
-				halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, TRUE,
-							106);
-		}
-	}
-
-}
-
-static
-void halbtc8822b2ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)
-{
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-#if 0
-	/*halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT);*/
-#endif
-
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-}
-
-static
-void halbtc8822b2ant_action_bt_hs(IN struct btc_coexist *btcoexist)
-{
-	static u8	prewifi_rssi_state = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state, bt_rssi_state;
-
-	static u8	prewifi_rssi_state2 = BTC_RSSI_STATE_LOW;
-	static u8	pre_bt_rssi_state2 = BTC_RSSI_STATE_LOW;
-	u8		wifi_rssi_state2, bt_rssi_state2;
-	boolean	wifi_busy = FALSE, wifi_turbo = FALSE;
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-			   &coex_sta->scan_ap_num);
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"############# [BTCoex],  scan_ap_num = %d, wl_noisy = %d\n",
-		    coex_sta->scan_ap_num, coex_sta->wl_noisy_level);
-	BTC_TRACE(trace_buf);
-
-#if 1
-	if ((wifi_busy) && (coex_sta->wl_noisy_level == 0))
-		wifi_turbo = TRUE;
-#endif
-
-
-	wifi_rssi_state = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			  &prewifi_rssi_state, 2,
-			  coex_sta->wifi_coex_thres, 0);
-
-	wifi_rssi_state2 = halbtc8822b2ant_wifi_rssi_state(btcoexist,
-			   &prewifi_rssi_state2, 2,
-			   coex_sta->wifi_coex_thres2, 0);
-
-	bt_rssi_state = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state, 2,
-			coex_sta->bt_coex_thres, 0);
-
-	bt_rssi_state2 = halbtc8822b2ant_bt_rssi_state(btcoexist,
-			&pre_bt_rssi_state2, 2,
-			coex_sta->bt_coex_thres2, 0);
-
-	if (BTC_RSSI_HIGH(wifi_rssi_state) &&
-	    BTC_RSSI_HIGH(bt_rssi_state)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	} else if (BTC_RSSI_HIGH(wifi_rssi_state2) &&
-		   BTC_RSSI_HIGH(bt_rssi_state2)) {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-#if 0
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-		coex_dm->is_switch_to_1dot5_ant = FALSE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-
-	} else {
-
-		halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-		/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-		coex_dm->is_switch_to_1dot5_ant = TRUE;
-
-		halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-
-		halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	}
-
-}
-
-static
-void halbtc8822b2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)
-{
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-	/* hw all off */
-	/*halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);*/
-	halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-		     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-	halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, TRUE);
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0);
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xc8);
-
-#if 0
-	/*halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT);*/
-#endif
-
-	/*halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);*/
-}
-
-static
-void halbtc8822b2ant_action_wifi_connected(IN struct btc_coexist *btcoexist)
-	{
-		switch (coex_dm->cur_algorithm) {
-
-		case BT_8822B_2ANT_COEX_ALGO_SCO:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Action 2-Ant, algorithm = SCO.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_sco(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Action 2-Ant, algorithm = HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_hid(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Action 2-Ant, algorithm = A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_a2dp(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_A2DPSINK:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Action 2-Ant, algorithm = A2DP Sink.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_a2dpsink(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_A2DP_PANHS:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_a2dp_pan_hs(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Action 2-Ant, algorithm = PAN(EDR).\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_pan_edr(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_PANEDR_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Action 2-Ant, algorithm = PAN+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_pan_edr_a2dp(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_PANEDR_HID:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_pan_edr_hid(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_hid_a2dp_pan_edr(
-				btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_HID_A2DP:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], Action 2-Ant, algorithm = HID+A2DP.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_hid_a2dp(btcoexist);
-			break;
-		case BT_8822B_2ANT_COEX_ALGO_NOPROFILEBUSY:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = No-Profile busy.\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_action_bt_idle(btcoexist);
-			break;
-		default:
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n");
-			BTC_TRACE(trace_buf);
-			halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-			halbtc8822b2ant_action_coex_all_off(btcoexist);
-			break;
-		}
-
-		coex_dm->pre_algorithm = coex_dm->cur_algorithm;
-
-	}
-
-static
-void halbtc8822b2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)
-{
-	u8				algorithm = 0;
-	u32				num_of_wifi_link = 0;
-	u32				wifi_link_status = 0;
-	struct  btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info;
-	boolean				miracast_plus_bt = FALSE;
-	boolean				scan = FALSE, link = FALSE, roam = FALSE,
-					under_4way = FALSE,
-					wifi_connected = FALSE, wifi_under_5g =
-							FALSE,
-							bt_hs_on = FALSE;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam);
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], RunCoexistMechanism()===>\n");
-	BTC_TRACE(trace_buf);
-
-	if (btcoexist->manual_control) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (btcoexist->stop_coex_dm) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->under_ips) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], wifi is under IPS !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if ((coex_sta->under_lps) &&
-		(coex_dm->bt_status != BT_8822B_2ANT_BT_STATUS_ACL_BUSY)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RunCoexistMechanism(), wifi is under LPS !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_action_wifi_native_lps(btcoexist);
-		return;
-	}
-
-	if (!coex_sta->run_time_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], return for run_time_state = FALSE !!!\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	if (coex_sta->freeze_coexrun_by_btinfo) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BtInfoNotify(), return for freeze_coexrun_by_btinfo\n");
-		BTC_TRACE(trace_buf);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((wifi_under_5g) &&
-		(coex_sta->switch_band_notify_to != BTC_SWITCH_TO_24G) &&
-		(coex_sta->switch_band_notify_to != BTC_SWITCH_TO_24G_NOFORSCAN)) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-		halbtc8822b2ant_action_wifi_under5g(btcoexist);
-		return;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], WiFi is under 2G!!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-				     NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME);
-
-
-	if (coex_sta->bt_whck_test) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under WHCK TEST!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_action_bt_whck_test(btcoexist);
-		return;
-	}
-
-	if (coex_sta->bt_disabled) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is disabled!!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-		halbtc8822b2ant_action_coex_all_off(btcoexist);
-		return;
-	}
-
-	if (coex_sta->c2h_bt_inquiry_page) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is under inquiry/page scan !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-		halbtc8822b2ant_action_bt_inquiry(btcoexist);
-		return;
-	}
-
-	if (coex_sta->is_setupLink) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], BT is re-link !!!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-		halbtc8822b2ant_action_bt_relink(btcoexist);
-		return;
-	}
-
-	/* for P2P */
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS,
-			   &wifi_link_status);
-	num_of_wifi_link = wifi_link_status >> 16;
-
-	if ((num_of_wifi_link >= 2) ||
-	    (wifi_link_status & WIFI_P2P_GO_CONNECTED)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"############# [BTCoex],  Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n",
-			    num_of_wifi_link, wifi_link_status);
-		BTC_TRACE(trace_buf);
-
-		if (bt_link_info->bt_link_exist)
-			miracast_plus_bt = TRUE;
-		else
-			miracast_plus_bt = FALSE;
-
-		btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-				   &miracast_plus_bt);
-
-		if (scan || link || roam || under_4way) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], scan = %d, link = %d, roam = %d 4way = %d!!!\n",
-				    scan, link, roam, under_4way);
-			BTC_TRACE(trace_buf);
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], wifi is under linkscan process + Multi-Port !!\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b2ant_action_wifi_link_process(btcoexist);
-		} else {
-			halbtc8822b2ant_action_wifi_multi_port(btcoexist);
-		}
-
-		return;
-	}
-
-	miracast_plus_bt = FALSE;
-	btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT,
-			   &miracast_plus_bt);
-
-
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on);
-
-	if (bt_hs_on) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "############# [BTCoex],  BT Is hs\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_action_bt_hs(btcoexist);
-		return;
-	}
-
-	if ((BT_8822B_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-	     coex_dm->bt_status) ||
-	    (BT_8822B_2ANT_BT_STATUS_CONNECTED_IDLE ==
-	     coex_dm->bt_status)) {
-		halbtc8822b2ant_rx_gain(btcoexist, NORMAL_EXEC, FALSE);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, bt idle!!.\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_action_bt_idle(btcoexist);
-		return;
-	}
-
-	algorithm = halbtc8822b2ant_action_algorithm(btcoexist);
-	coex_dm->cur_algorithm = algorithm;
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Algorithm = %d\n",
-		    coex_dm->cur_algorithm);
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	if (scan || link || roam || under_4way) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under Link Process !!\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_action_wifi_link_process(btcoexist);
-	} else if (wifi_connected) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, wifi connected!!.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_action_wifi_connected(btcoexist);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Action 2-Ant, wifi not-connected!!.\n");
-		BTC_TRACE(trace_buf);
-		halbtc8822b2ant_action_wifi_nonconnected(btcoexist);
-	}
-}
-
-static
-void halbtc8822b2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Coex Mechanism Init!!\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, FALSE);
-
-	halbtc8822b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 5);
-#if 0
-	/*halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, NORMAL_EXEC,
-				     BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT);*/
-#endif
-
-	/* fw all off */
-	halbtc8822b2ant_ps_tdma(btcoexist, NORMAL_EXEC, FALSE, 0);
-
-	halbtc8822b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 0xd8);
-#if 0
-	/*halbtc8822b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0);*/
-#endif
-
-	coex_sta->pop_event_cnt = 0;
-	coex_sta->cnt_RemoteNameReq = 0;
-	coex_sta->cnt_ReInit = 0;
-	coex_sta->cnt_setupLink = 0;
-	coex_sta->cnt_IgnWlanAct = 0;
-	coex_sta->cnt_Page = 0;
-	coex_sta->cnt_RoleSwitch = 0;
-	coex_sta->switch_band_notify_to = BTC_NOT_SWITCH;
-
-	halbtc8822b2ant_query_bt_info(btcoexist);
-}
-
-
-static
-void halbtc8822b2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				    IN boolean wifi_only)
-{
-	u32	u32tmp1 = 0, u32tmp2 = 0, u32tmp3 = 0;
-	u32	RTL97F_8822B = 0;
-	u8 i = 0;
-
-
-	u32tmp3 = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u32tmp1 = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp2 = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-
-	if (RTL97F_8822B) {
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x66, 0x04, 0x0);
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x0);
-
-		/* set GNT_BT to SW high */
-		halbtc8822b2ant_ltecoex_set_gnt_bt(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-		/* Set GNT_WL to SW high */
-		halbtc8822b2ant_ltecoex_set_gnt_wl(btcoexist,
-					   BT_8822B_2ANT_GNT_BLOCK_RFC_BB,
-					   BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW,
-					   BT_8822B_2ANT_SIG_STA_SET_TO_HIGH);
-		return;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], (Before Init HW config) 0xcb4 = 0x%x, 0x38= 0x%x, 0x54= 0x%x\n",
-		    u32tmp3, u32tmp1, u32tmp2);
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], 2Ant Init HW Config!!\n");
-	BTC_TRACE(trace_buf);
-
-	coex_sta->bt_coex_supported_feature = 0;
-	coex_sta->bt_coex_supported_version = 0;
-	coex_sta->bt_ble_scan_type = 0;
-	coex_sta->bt_ble_scan_para[0] = 0;
-	coex_sta->bt_ble_scan_para[1] = 0;
-	coex_sta->bt_ble_scan_para[2] = 0;
-	coex_sta->bt_reg_vendor_ac = 0xffff;
-	coex_sta->bt_reg_vendor_ae = 0xffff;
-	coex_sta->isolation_btween_wb = BT_8822B_2ANT_DEFAULT_ISOLATION;
-	coex_sta->gnt_error_cnt = 0;
-	coex_sta->bt_relink_downcount = 0;
-	coex_sta->is_set_ps_state_fail = FALSE;
-	coex_sta->cnt_set_ps_state_fail = 0;
-
-	for (i = 0; i <= 9; i++)
-		coex_sta->bt_afh_map[i] = 0;
-
-	/* 0xf0[15:12] --> Chip Cut information */
-	coex_sta->cut_version = (btcoexist->btc_read_1byte(btcoexist,
-				 0xf1) & 0xf0) >> 4;
-
-	coex_sta->dis_ver_info_cnt = 0;
-
-	halbtc8822b2ant_coex_switch_threshold(btcoexist,
-					      coex_sta->isolation_btween_wb);
-
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x550, 0x8,
-					   0x1);  /* enable TBTT nterrupt */
-
-	/* BT report packet sample rate	 */
-	btcoexist->btc_write_1byte(btcoexist, 0x790, 0x5);
-
-	/* Init 0x778 = 0x1 for 2-Ant */
-	btcoexist->btc_write_1byte(btcoexist, 0x778, 0x1);
-
-	/* Enable PTA (3-wire function form BT side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1);
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x41, 0x02, 0x1);
-
-	/* Enable PTA (tx/rx signal form WiFi side) */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x4c6, 0x10, 0x1);
-
-	halbtc8822b2ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-	/*GNT_BT=1 while select both */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x763, 0x10, 0x1);
-
-
-	/* check if WL firmware download ok */
-#if 0
-	if (btcoexist->btc_read_1byte(btcoexist, 0x80) == 0xc6)
-#endif
-	halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ONOFF, TRUE);
-
-	/* Enable counter statistics */
-	btcoexist->btc_write_1byte(btcoexist, 0x76e,
-			   0x4); /* 0x76e[3] =1, WLAN_Act control by PTA */
-
-#if 0
-	/* WLAN_Tx by GNT_WL  0x950[29] = 0 */
-	btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x20, 0x0);
-#endif
-
-	halbtc8822b2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 5);
-
-	halbtc8822b2ant_ps_tdma(btcoexist, FORCE_EXEC, FALSE, 0);
-
-	psd_scan->ant_det_is_ant_det_available = TRUE;
-
-	if (coex_sta->is_rf_state_off) {
-
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_WLAN_OFF);
-
-		btcoexist->stop_coex_dm = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  halbtc8822b2ant_init_hw_config (RF Off)**********\n");
-		BTC_TRACE(trace_buf);
-	} else if (wifi_only) {
-		coex_sta->concurrent_rx_mode_on = FALSE;
-		/* Path config	 */
-		/* Set Antenna Path */
-		halbtc8822b2ant_set_ant_path(btcoexist,	BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_WLANONLY_INIT);
-
-		btcoexist->stop_coex_dm = TRUE;
-	} else {
-		/* Set BT polluted packet on for Tx rate adaptive not including
-		 * Tx retry break by PTA, 0x45c[19] =1
-		 */
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x45e, 0x8, 0x1);
-
-		coex_sta->concurrent_rx_mode_on = TRUE;
-#if 0
-		btcoexist->btc_write_1byte_bitmask(btcoexist, 0x953, 0x2, 0x1);
-#endif
-
-		/* RF 0x1[1] = 0->Set GNT_WL_RF_Rx always = 1 for
-		 * con-current Rx, mask Tx only
-		 */
-		btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0x2, 0x0);
-
-		/* Set Antenna Path */
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_COEX_INIT);
-
-		btcoexist->stop_coex_dm = FALSE;
-	}
-}
-
-
-
-/* ************************************************************
- * work around function start with wa_halbtc8822b2ant_
- * ************************************************************
- * ************************************************************
- * extern function start with ex_halbtc8822b2ant_
- * ************************************************************ */
-void ex_halbtc8822b2ant_power_on_setting(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x0;
-	u16 u16tmp = 0x0;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"xxxxxxxxxxxxxxxx Execute 8822b 2-Ant PowerOn Setting xxxxxxxxxxxxxxxx!!\n");
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "Ant Det Finish = %s, Ant Det Number  = %d\n",
-		    (board_info->btdm_ant_det_finish ? "Yes" : "No"),
-		    board_info->btdm_ant_num_by_ant_det);
-	BTC_TRACE(trace_buf);
-
-
-	btcoexist->stop_coex_dm = TRUE;
-	psd_scan->ant_det_is_ant_det_available = FALSE;
-
-	/* enable BB, REG_SYS_FUNC_EN such that we can write BB Reg correctly */
-	u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2);
-	btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT(0) | BIT(1));
-
-
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==>
-	 * BIT1=0 and BIT2=0
-	 */
-
-	/* Check efuse 0xc3[6] for Single Antenna Path */
-#if 0
-	if (board_info->single_ant_path == 0) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  Single Antenna, Antenna at Aux Port\n");
-		BTC_TRACE(trace_buf);
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT;
-
-		u8tmp = 7;
-	} else if (board_info->single_ant_path == 1) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], **********  Single Antenna, Antenna at Main Port\n");
-		BTC_TRACE(trace_buf);
-
-		board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
-
-		u8tmp = 6;
-	}
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], ********** (Power On) single_ant_path  = %d, btdm_ant_pos = %d\n",
-		    board_info->single_ant_path , board_info->btdm_ant_pos);
-	BTC_TRACE(trace_buf);
-#endif
-
-	/* Setup RF front end type */
-	halbtc8822b2ant_set_rfe_type(btcoexist);
-
-	/* Set Antenna Path to BT side */
-	halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_COEX_POWERON);
-
-	/* Save"single antenna position" info in Local register setting for
-	 * FW reading, because FW may not ready at power on
-	 */
-	if (btcoexist->chip_interface == BTC_INTF_PCI)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x3e0, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_USB)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60, u8tmp);
-
-	/* enable GNT_WL/GNT_BT debug signal to GPIO14/15 */
-	halbtc8822b2ant_enable_gnt_to_gpio(btcoexist, TRUE);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********  LTE coex Reg 0x38 (Power-On) = 0x%x**********\n",
-		    halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x38));
-	BTC_TRACE(trace_buf);
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		"[BTCoex], **********  MAC Reg 0x70/ BB Reg 0xcb4 (Power-On) = 0x%x / 0x%x\n",
-		    btcoexist->btc_read_4byte(btcoexist, 0x70),
-		    btcoexist->btc_read_4byte(btcoexist, 0xcb4));
-	BTC_TRACE(trace_buf);
-
-}
-
-void ex_halbtc8822b2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info	*board_info = &btcoexist->board_info;
-	u8 u8tmp = 0x4; /* Set BIT2 by default since it's 2ant case */
-
-	/* */
-	/* S0 or S1 setting and Local register setting
-	 * (By the setting fw can get ant number, S0/S1, ... info)
-	 */
-	/* Local setting bit define */
-	/*	BIT0: "0" for no antenna inverse; "1" for antenna inverse  */
-	/*	BIT1: "0" for internal switch; "1" for external switch */
-	/*	BIT2: "0" for one antenna; "1" for two antenna */
-	/* NOTE: here default all internal switch and 1-antenna ==>
-	 *       BIT1=0 and BIT2=0
-	 */
-	if (btcoexist->chip_interface == BTC_INTF_USB) {
-		/* fixed at S0 for USB interface */
-		u8tmp |= 0x1;	/* antenna inverse */
-		btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp);
-	} else {
-		/* for PCIE and SDIO interface, we check efuse 0xc3[6] */
-		if (board_info->single_ant_path == 0) {
-		} else if (board_info->single_ant_path == 1) {
-			/* set to S0 */
-			u8tmp |= 0x1;	/* antenna inverse */
-		}
-
-		if (btcoexist->chip_interface == BTC_INTF_PCI)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x3e0,
-							     u8tmp);
-		else if (btcoexist->chip_interface == BTC_INTF_SDIO)
-			btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60,
-							     u8tmp);
-	}
-}
-
-void ex_halbtc8822b2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only)
-{
-	halbtc8822b2ant_init_hw_config(btcoexist, wifi_only);
-}
-
-void ex_halbtc8822b2ant_init_coex_dm(IN struct btc_coexist *btcoexist)
-{
-
-	halbtc8822b2ant_init_coex_dm(btcoexist);
-}
-
-void ex_halbtc8822b2ant_display_coex_info(IN struct btc_coexist *btcoexist)
-{
-	struct  btc_board_info		*board_info = &btcoexist->board_info;
-	struct  btc_bt_link_info	*bt_link_info = &btcoexist->bt_link_info;
-
-	u8				*cli_buf = btcoexist->cli_buf;
-	u8				u8tmp[4], i, ps_tdma_case = 0;
-	u32				u32tmp[4];
-	u16				u16tmp[4];
-	u32				fa_ofdm, fa_cck, cca_ofdm, cca_cck, ratio_ofdm;
-	u32				fw_ver = 0, bt_patch_ver = 0, bt_coex_ver = 0;
-	static u8			pop_report_in_10s = 0;
-	u32			phyver = 0;
-	boolean			lte_coex_on = FALSE;
-	static u8 cnt = 0;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n ============[BT Coexist info]============");
-	CL_PRINTF(cli_buf);
-
-	if (btcoexist->manual_control) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n ============[Under Manual Control]============");
-		CL_PRINTF(cli_buf);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n ==========================================");
-		CL_PRINTF(cli_buf);
-	}
-
-	if (!coex_sta->bt_disabled) {
-		if (coex_sta->bt_coex_supported_feature == 0)
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_FEATURE,
-						&coex_sta->bt_coex_supported_feature);
-
-		if ((coex_sta->bt_coex_supported_version == 0) ||
-			(coex_sta->bt_coex_supported_version == 0xffff))
-			btcoexist->btc_get(btcoexist, BTC_GET_U4_SUPPORTED_VERSION,
-						&coex_sta->bt_coex_supported_version);
-
-		if (coex_sta->bt_reg_vendor_ac == 0xffff)
-			coex_sta->bt_reg_vendor_ac = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xac) & 0xffff);
-
-		if (coex_sta->bt_reg_vendor_ae == 0xffff)
-			coex_sta->bt_reg_vendor_ae = (u16)(
-					btcoexist->btc_get_bt_reg(btcoexist, 3,
-					0xae) & 0xffff);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER,
-						&bt_patch_ver);
-		btcoexist->bt_info.bt_get_fw_ver = bt_patch_ver;
-
-		if (coex_sta->num_of_profile > 0) {
-			cnt++;
-
-			if (cnt >= 3) {
-				btcoexist->btc_get_bt_afh_map_from_bt(btcoexist, 0,
-					&coex_sta->bt_afh_map[0]);
-				cnt = 0;
-			}
-		}
-	}
-
-	if (psd_scan->ant_det_try_count == 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s / %d",
-			   "Ant PG Num/ Mech/ Pos/ RFE",
-			   board_info->pg_ant_num, board_info->btdm_ant_num,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   rfe_type->rfe_module_type);
-		CL_PRINTF(cli_buf);
-	} else {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %s/ %d  (%d/%d/%d)",
-			   "Ant PG Num/ Mech(Ant_Det)/ Pos/ RFE",
-			   board_info->pg_ant_num,
-			   board_info->btdm_ant_num_by_ant_det,
-			   (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT
-			    ? "Main" : "Aux"),
-			   rfe_type->rfe_module_type,
-			   psd_scan->ant_det_try_count,
-			   psd_scan->ant_det_fail_count,
-			   psd_scan->ant_det_result);
-		CL_PRINTF(cli_buf);
-
-
-		if (board_info->btdm_ant_det_finish) {
-
-			if (psd_scan->ant_det_result != 12)
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %s",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_peak_val);
-			else
-				CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-					   "\r\n %-35s = %d",
-					   "Ant Det PSD Value",
-					   psd_scan->ant_det_psd_scan_peak_val
-					   / 100);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-
-	bt_patch_ver = btcoexist->bt_info.bt_get_fw_ver;
-	btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
-	phyver = btcoexist->btc_get_bt_phydm_version(btcoexist);
-
-	bt_coex_ver = (coex_sta->bt_coex_supported_version & 0xff);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d_%02x/ 0x%02x/ 0x%02x (%s)",
-		   "CoexVer WL/  BT_Desired/ BT_Report",
-		   glcoex_ver_date_8822b_2ant, glcoex_ver_8822b_2ant,
-		   glcoex_ver_btdesired_8822b_2ant,
-		   bt_coex_ver,
-		   (bt_coex_ver == 0xff ? "Unknown" :
-		    (coex_sta->bt_disabled ? "BT-disable" :
-		     (bt_coex_ver >= glcoex_ver_btdesired_8822b_2ant ?
-		      "Match" : "Mis-Match"))));
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ v%d/ %c",
-		   "W_FW/ B_FW/ Phy/ Kt",
-		   fw_ver, bt_patch_ver, phyver,
-		   coex_sta->cut_version + 65);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x ",
-		   "AFH Map to BT",
-		   coex_dm->wifi_chnl_info[0], coex_dm->wifi_chnl_info[1],
-		   coex_dm->wifi_chnl_info[2]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d ",
-		   "Isolation/WL_Thres/BT_Thres",
-		   coex_sta->isolation_btween_wb,
-		   coex_sta->wifi_coex_thres,
-		   coex_sta->bt_coex_thres);
-	CL_PRINTF(cli_buf);
-
-	/* wifi status */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Wifi Status]============");
-	CL_PRINTF(cli_buf);
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_WIFI_STATUS);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[BT Status]============");
-	CL_PRINTF(cli_buf);
-
-	pop_report_in_10s++;
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = [%s/ %d dBm/ %d/ %d] ",
-		   "BT [status/ rssi/ retryCnt/ popCnt]",
-		   ((coex_sta->bt_disabled) ? ("disabled") :	((
-			   coex_sta->c2h_bt_inquiry_page) ? ("inquiry/page")
-			   : ((BT_8822B_2ANT_BT_STATUS_NON_CONNECTED_IDLE ==
-			       coex_dm->bt_status) ? "non-connected idle" :
-		((coex_dm->bt_status == BT_8822B_2ANT_BT_STATUS_CONNECTED_IDLE)
-				       ? "connected-idle" : "busy")))),
-		   coex_sta->bt_rssi - 100, coex_sta->bt_retry_cnt,
-		   coex_sta->pop_event_cnt);
-	CL_PRINTF(cli_buf);
-
-	if (pop_report_in_10s >= 5) {
-		coex_sta->pop_event_cnt = 0;
-		pop_report_in_10s = 0;
-	}
-
-
-	if (coex_sta->num_of_profile != 0)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %s%s%s%s%s",
-			   "Profiles",
-			   ((bt_link_info->a2dp_exist) ?
-			   ((coex_sta->is_bt_a2dp_sink) ? "A2DP sink," :
-			    "A2DP,") : ""),
-			   ((bt_link_info->sco_exist) ?  "HFP," : ""),
-			   ((bt_link_info->hid_exist) ?
-			    ((coex_sta->hid_busy_num >= 2) ? "HID(4/18)," :
-			     "HID(2/18),") : ""),
-			   ((bt_link_info->pan_exist) ?  "PAN," : ""),
-			   ((coex_sta->voice_over_HOGP) ? "Voice" : ""));
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = None", "Profiles");
-
-	CL_PRINTF(cli_buf);
-
-
-	if (bt_link_info->a2dp_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s",
-			   "A2DP Rate/Bitpool/Auto_Slot",
-			   ((coex_sta->is_A2DP_3M) ? "3M" : "No_3M"),
-			   coex_sta->a2dp_bit_pool,
-			   ((coex_sta->is_autoslot) ? "On" : "Off")
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	if (bt_link_info->hid_exist) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "HID PairNum/Forbid_Slot",
-			   coex_sta->hid_pair_cnt,
-			   coex_sta->forbidden_slot
-			  );
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
-				"Role/RoleSwCnt/IgnWlact/Feature",
-				((bt_link_info->slave_role) ? "Slave" : "Master"),
-				coex_sta->cnt_RoleSwitch,
-				((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
-				coex_sta->bt_coex_supported_feature);
-	CL_PRINTF(cli_buf);
-
-	if ((coex_sta->bt_ble_scan_type & 0x7) != 0x0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			"BLEScan Type/TV/Init/Ble",
-			coex_sta->bt_ble_scan_type,
-			(coex_sta->bt_ble_scan_type & 0x1 ?
-			coex_sta->bt_ble_scan_para[0] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x2 ?
-			coex_sta->bt_ble_scan_para[1] : 0x0),
-			(coex_sta->bt_ble_scan_type & 0x4 ?
-			coex_sta->bt_ble_scan_para[2] : 0x0));
-		CL_PRINTF(cli_buf);
-	}
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
-		   "ReInit/ReLink/IgnWlact/Page/NameReq",
-		   coex_sta->cnt_ReInit,
-		   coex_sta->cnt_setupLink,
-		   coex_sta->cnt_IgnWlanAct,
-		   coex_sta->cnt_Page,
-		   coex_sta->cnt_RemoteNameReq
-		  );
-	CL_PRINTF(cli_buf);
-
-	halbtc8822b2ant_read_score_board(btcoexist,	&u16tmp[0]);
-
-	if ((coex_sta->bt_reg_vendor_ae == 0xffff) ||
-	    (coex_sta->bt_reg_vendor_ac == 0xffff))
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = x/ x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard", u16tmp[0]);
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ %04x",
-			   "0xae[4]/0xac[1:0]/Scoreboard",
-			   (int)((coex_sta->bt_reg_vendor_ae & BIT(4)) >> 4),
-			   coex_sta->bt_reg_vendor_ac & 0x3, u16tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	if (coex_sta->num_of_profile > 0) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x",
-			"AFH MAP",
-			coex_sta->bt_afh_map[0],
-			coex_sta->bt_afh_map[1],
-			coex_sta->bt_afh_map[2],
-			coex_sta->bt_afh_map[3],
-			coex_sta->bt_afh_map[4],
-			coex_sta->bt_afh_map[5],
-			coex_sta->bt_afh_map[6],
-			coex_sta->bt_afh_map[7],
-			coex_sta->bt_afh_map[8],
-			coex_sta->bt_afh_map[9]
-			   );
-		CL_PRINTF(cli_buf);
-	}
-
-	for (i = 0; i < BT_INFO_SRC_8822B_2ANT_MAX; i++) {
-		if (coex_sta->bt_info_c2h_cnt[i]) {
-			CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-				"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x(%d)",
-				   glbt_info_src_8822b_2ant[i],
-				   coex_sta->bt_info_c2h[i][0],
-				   coex_sta->bt_info_c2h[i][1],
-				   coex_sta->bt_info_c2h[i][2],
-				   coex_sta->bt_info_c2h[i][3],
-				   coex_sta->bt_info_c2h[i][4],
-				   coex_sta->bt_info_c2h[i][5],
-				   coex_sta->bt_info_c2h[i][6],
-				   coex_sta->bt_info_c2h_cnt[i]);
-			CL_PRINTF(cli_buf);
-		}
-	}
-
-	/* Sw mechanism	 */
-	if (btcoexist->manual_control)
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			"============[mechanism] (before Manual)============");
-	else
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-			   "============[Mechanism]============");
-
-	CL_PRINTF(cli_buf);
-
-
-	ps_tdma_case = coex_dm->cur_ps_tdma;
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %02x %02x %02x %02x %02x (case-%d, %s, %s)",
-		   "TDMA",
-		   coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
-		   coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
-		   coex_dm->ps_tdma_para[4], ps_tdma_case,
-		   (coex_dm->cur_ps_tdma_on ? "TDMA On" : "TDMA Off"),
-		   (coex_dm->is_switch_to_1dot5_ant ? "1.5Ant" : "2Ant"));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4);
-	u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %d/ 0x%x/ 0x%x/ 0x%x",
-		   "Table/0x6c0/0x6c4/0x6c8",
-		   coex_sta->coex_table_type, u32tmp[0], u32tmp[1], u32tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778);
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6cc);
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x",
-		   "0x778/0x6cc",
-		   u8tmp[0], u32tmp[0]);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
-		   "AntDiv/BtCtrlLPS/LPRA/PsFail",
-		   ((board_info->ant_div_cfg) ? "On" : "Off"),
-		   ((coex_sta->force_lps_ctrl) ? "On" : "Off"),
-		   ((coex_dm->cur_low_penalty_ra) ? "On" : "Off"),
-		   coex_sta->cnt_set_ps_state_fail);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-		   "WL_DACSwing/ BT_Dec_Pwr", coex_dm->cur_fw_dac_swing_lvl,
-		   coex_dm->cur_bt_dec_pwr_lvl);
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ?  TRUE : FALSE;
-
-	if (lte_coex_on) {
-
-		u32tmp[0] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa0);
-		u32tmp[1] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa4);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x",
-			   "LTE Coex Table W_L/B_L",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff);
-		CL_PRINTF(cli_buf);
-
-
-		u32tmp[0] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xa8);
-		u32tmp[1] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xac);
-		u32tmp[2] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb0);
-		u32tmp[3] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist,
-				0xb4);
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-			   "LTE Break Table W_L/B_L/L_W/L_B",
-			   u32tmp[0] & 0xffff, u32tmp[1] & 0xffff,
-			   u32tmp[2] & 0xffff, u32tmp[3] & 0xffff);
-		CL_PRINTF(cli_buf);
-
-	}
-
-	/* Hw setting		 */
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
-		   "============[Hw setting]============");
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x38);
-	u32tmp[1] = halbtc8822b2ant_ltecoex_indirect_read_reg(btcoexist, 0x54);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x73);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s",
-		   "LTE Coex/Path Owner",
-		   ((lte_coex_on) ? "On" : "Off"),
-		   ((u8tmp[0] & BIT(2)) ? "WL" : "BT"));
-	CL_PRINTF(cli_buf);
-
-	if (lte_coex_on) {
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-			   "\r\n %-35s = %d/ %d/ %d/ %d",
-			   "LTE 3Wire/OPMode/UART/UARTMode",
-			   (int)((u32tmp[0] & BIT(6)) >> 6),
-			   (int)((u32tmp[0] & (BIT(5) | BIT(4))) >> 4),
-			   (int)((u32tmp[0] & BIT(3)) >> 3),
-			   (int)(u32tmp[0] & (BIT(2) | BIT(1) | BIT(0))));
-		CL_PRINTF(cli_buf);
-
-		CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-			   "LTE_Busy/UART_Busy",
-			   (int)((u32tmp[1] & BIT(1)) >> 1),
-			   (int)(u32tmp[1] & BIT(0)));
-		CL_PRINTF(cli_buf);
-	}
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = %s (BB:%s)/ %s (BB:%s)/ %s %d",
-		   "GNT_WL_Ctrl/GNT_BT_Ctrl/Dbg",
-		   ((u32tmp[0] & BIT(12)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(8)) ?  "SW" : "HW"),
-		   ((u32tmp[0] & BIT(14)) ? "SW" : "HW"),
-		   ((u32tmp[0] & BIT(10)) ?  "SW" : "HW"),
-		   ((u8tmp[0] & BIT(3)) ? "On" : "Off"),
-		   coex_sta->gnt_error_cnt);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "GNT_WL/GNT_BT",
-		   (int)((u32tmp[1] & BIT(2)) >> 2),
-		   (int)((u32tmp[1] & BIT(3)) >> 3));
-	CL_PRINTF(cli_buf);
-
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xcbc);
-	u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xcb4);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xcba);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%04x/ 0x%04x/ 0x%02x %s",
-		   "0xcbc/0xcb4/0xcb8[23:16]",
-		   u32tmp[0], u32tmp[1], u8tmp[0],
-		   ((u8tmp[0] & 0x1) == 0x1 ?  "(BTG)" :   "(WL_A+G)"));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x64);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x4c6);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
-		   "4c[24:23]/64[0]/4c6[4]/40[5]",
-		   (int)(u32tmp[0] & (BIT(24) | BIT(23))) >> 23, u8tmp[2] & 0x1,
-		   (int)((u8tmp[0] & BIT(4)) >> 4),
-		   (int)((u8tmp[1] & BIT(5)) >> 5));
-	CL_PRINTF(cli_buf);
-
-	u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550);
-	u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522);
-	u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x953);
-	u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0xc50);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ %s/ 0x%x",
-		   "0x550/0x522/4-RxAGC/0xc50",
-		u32tmp[0], u8tmp[0], (u8tmp[1] & 0x2) ? "On" : "Off", u8tmp[2]);
-	CL_PRINTF(cli_buf);
-
-	fa_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_OFDM);
-	fa_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_FA_CCK);
-	cca_ofdm = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_OFDM);
-	cca_cck = btcoexist->btc_phydm_query_PHY_counter(btcoexist,
-			PHYDM_INFO_CCA_CCK);
-
-	ratio_ofdm = (fa_ofdm == 0) ? 1000 : (cca_ofdm/fa_ofdm);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
-		   "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x  (%d)",
-		   "CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA",
-		   cca_cck, fa_cck, cca_ofdm, fa_ofdm,
-		   ratio_ofdm);
-	CL_PRINTF(cli_buf);
-
-#if 1
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
-		   "CRC_OK CCK/11g/11n/11ac",
-		   coex_sta->crc_ok_cck, coex_sta->crc_ok_11g,
-		   coex_sta->crc_ok_11n, coex_sta->crc_ok_11n_vht);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d  (%d, %d)",
-		   "CRC_Err CCK/11g/11n/11ac",
-		   coex_sta->crc_err_cck, coex_sta->crc_err_11g,
-		   coex_sta->crc_err_11n, coex_sta->crc_err_11n_vht,
-		   coex_sta->now_crc_ratio, coex_sta->acc_crc_ratio);
-	CL_PRINTF(cli_buf);
-#endif
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
-		   "WlHiPri/ Locking/ Locked/ Noisy",
-		   (coex_sta->wifi_is_high_pri_task ? "Yes" : "No"),
-		   (coex_sta->cck_lock ? "Yes" : "No"),
-		   (coex_sta->cck_ever_lock ? "Yes" : "No"),
-		   coex_sta->wl_noisy_level);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
-		   "0x770(Hi-pri rx/tx)",
-		   coex_sta->high_priority_rx, coex_sta->high_priority_tx);
-	CL_PRINTF(cli_buf);
-
-	CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
-		   "0x774(Lo-pri rx/tx)",
-		   coex_sta->low_priority_rx, coex_sta->low_priority_tx,
-		   (bt_link_info->slave_role ? "(Slave!!)" : (
-		   coex_sta->is_tdma_btautoslot_hang ? "(auto-slot hang!!)" : "")));
-	CL_PRINTF(cli_buf);
-
-	btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS);
-}
-
-
-void ex_halbtc8822b2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	if (btcoexist->manual_control ||	btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_IPS_ENTER == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS ENTER notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = TRUE;
-		coex_sta->under_lps = FALSE;
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-				 BT_8822B_2ANT_SCOREBOARD_ACTIVE, FALSE);
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-				 BT_8822B_2ANT_SCOREBOARD_ONOFF, FALSE);
-
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_WLAN_OFF);
-
-		halbtc8822b2ant_action_coex_all_off(btcoexist);
-	} else if (BTC_IPS_LEAVE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], IPS LEAVE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_ips = FALSE;
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-				 BT_8822B_2ANT_SCOREBOARD_ONOFF, TRUE);
-		halbtc8822b2ant_init_hw_config(btcoexist, FALSE);
-		halbtc8822b2ant_init_coex_dm(btcoexist);
-		halbtc8822b2ant_query_bt_info(btcoexist);
-	}
-}
-
-
-
-void ex_halbtc8822b2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)
-{
-	static boolean  pre_force_lps_on = FALSE;
-
-	if (btcoexist->manual_control || btcoexist->stop_coex_dm)
-		return;
-
-	if (BTC_LPS_ENABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS ENABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = TRUE;
-		coex_sta->under_ips = FALSE;
-
-		if (coex_sta->force_lps_ctrl) { /* LPS No-32K */
-			/* Write WL "Active" in Score-board for PS-TDMA */
-			pre_force_lps_on = TRUE;
-			halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		} else {
-			/* LPS-32K, need check if this h2c 0x71 can work??
-			 * (2015/08/28)
-			 */
-			/* Write WL "Non-Active" in Score-board for Native-PS */
-			pre_force_lps_on = FALSE;
-			halbtc8822b2ant_post_state_to_bt(btcoexist,
-				 BT_8822B_2ANT_SCOREBOARD_ACTIVE, FALSE);
-		}
-
-	} else if (BTC_LPS_DISABLE == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], LPS DISABLE notify\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->under_lps = FALSE;
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		if ((!pre_force_lps_on) && (!coex_sta->force_lps_ctrl))
-			halbtc8822b2ant_query_bt_info(btcoexist);
-	}
-}
-
-void ex_halbtc8822b2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type)
-{
-	boolean	wifi_connected = FALSE;
-	boolean wifi_under_5g = FALSE;
-
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], SCAN notify()\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-			   &wifi_connected);
-
-	/* this can't be removed for RF off_on event, or BT would dis-connect */
-	halbtc8822b2ant_query_bt_info(btcoexist);
-
-	if (BTC_SCAN_START == type) {
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G,
-				   &wifi_under_5g);
-
-		if (wifi_under_5g) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], ********** SCAN START notify (5g)\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b2ant_action_wifi_under5g(btcoexist);
-			return;
-		}
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** SCAN START notify (2g)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_run_coexist_mechanism(
-			btcoexist);
-
-		return;
-	}
-
-
-	if (BTC_SCAN_START_2G == type) {
-
-		if (!wifi_connected)
-			coex_sta->wifi_is_high_pri_task = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN START notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_SCAN, TRUE);
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_2G_RUNTIME);
-
-		halbtc8822b2ant_run_coexist_mechanism(btcoexist);
-
-	} else if (BTC_SCAN_FINISH == type) {
-
-		coex_sta->wifi_is_high_pri_task = FALSE;
-
-		btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM,
-				   &coex_sta->scan_ap_num);
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], SCAN FINISH notify  (Scan-AP = %d)\n",
-			    coex_sta->scan_ap_num);
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_SCAN, FALSE);
-
-		halbtc8822b2ant_run_coexist_mechanism(btcoexist);
-	}
-
-}
-
-void ex_halbtc8822b2ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-	coex_sta->switch_band_notify_to = type;
-
-	if (type == BTC_SWITCH_TO_5G) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], switchband_notify ---  switch to 5G\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_action_wifi_under5g(btcoexist);
-
-	} else if (type == BTC_SWITCH_TO_24G_NOFORSCAN) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ********** switchband_notify BTC_SWITCH_TO_2G (no for scan)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_run_coexist_mechanism(btcoexist);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], switchband_notify ---  switch to 2G\n");
-		BTC_TRACE(trace_buf);
-
-		ex_halbtc8822b2ant_scan_notify(btcoexist,
-					       BTC_SCAN_START_2G);
-	}
-	coex_sta->switch_band_notify_to = BTC_NOT_SWITCH;
-}
-
-
-void ex_halbtc8822b2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type)
-{
-
-	halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	if ((BTC_ASSOCIATE_5G_START == type) ||
-	    (BTC_ASSOCIATE_5G_FINISH == type)) {
-
-		if (BTC_ASSOCIATE_5G_START == type)
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], connect_notify ---  5G start\n");
-		else
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				"[BTCoex], connect_notify ---  5G finish\n");
-
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_action_wifi_under5g(btcoexist);
-		return;
-	}
-
-
-	if (BTC_ASSOCIATE_START == type) {
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT START notify (2G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_2G_RUNTIME);
-
-		halbtc8822b2ant_action_wifi_link_process(btcoexist);
-
-		/* To keep TDMA case during connect process,
-		 * to avoid changed by Btinfo and runcoexmechanism
-		 */
-		coex_sta->freeze_coexrun_by_btinfo = TRUE;
-
-		coex_dm->arp_cnt = 0;
-
-	} else if (BTC_ASSOCIATE_FINISH == type) {
-
-		coex_sta->wifi_is_high_pri_task = FALSE;
-		coex_sta->freeze_coexrun_by_btinfo = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], CONNECT FINISH notify	(2G)\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_run_coexist_mechanism(btcoexist);
-	}
-}
-
-void ex_halbtc8822b2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean		wifi_under_b_mode = FALSE, wifi_under_5g = FALSE;
-
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (BTC_MEDIA_CONNECT == type) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA connect notify\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-
-		if (wifi_under_5g) {
-
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], WiFi is under 5G!!!\n");
-			BTC_TRACE(trace_buf);
-
-			halbtc8822b2ant_action_wifi_under5g(btcoexist);
-			return;
-		}
-
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_2G_RUNTIME);
-
-		btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_B_MODE,
-				   &wifi_under_b_mode);
-
-		/* Set CCK Tx/Rx high Pri except 11b mode */
-		if (wifi_under_b_mode) {
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x00); /* CCK Rx */
-		} else {
-
-			btcoexist->btc_write_1byte(btcoexist, 0x6cd,
-						   0x00); /* CCK Tx */
-			btcoexist->btc_write_1byte(btcoexist, 0x6cf,
-						   0x10); /* CCK Rx */
-		}
-
-	} else {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], MEDIA disconnect notify\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->btc_write_1byte(btcoexist, 0x6cd, 0x0); /* CCK Tx */
-		btcoexist->btc_write_1byte(btcoexist, 0x6cf, 0x0); /* CCK Rx */
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-				 BT_8822B_2ANT_SCOREBOARD_ACTIVE, FALSE);
-	}
-
-
-	halbtc8822b2ant_update_wifi_channel_info(btcoexist, type);
-}
-
-void ex_halbtc8822b2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	boolean under_4way = FALSE, wifi_under_5g = FALSE;
-
-	if (btcoexist->manual_control ||
-	    btcoexist->stop_coex_dm)
-		return;
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if (wifi_under_5g) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], WiFi is under 5G!!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_action_wifi_under5g(btcoexist);
-		return;
-	}
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS,
-			   &under_4way);
-
-	if (under_4way) {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ---- under_4way!!\n");
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-
-	} else if (BTC_PACKET_ARP == type) {
-
-		coex_dm->arp_cnt++;
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], specific Packet ARP notify -cnt = %d\n",
-			    coex_dm->arp_cnt);
-		BTC_TRACE(trace_buf);
-
-	} else {
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], specific Packet DHCP or EAPOL notify [Type = %d]\n",
-			    type);
-		BTC_TRACE(trace_buf);
-
-		coex_sta->wifi_is_high_pri_task = TRUE;
-		coex_sta->specific_pkt_period_cnt = 2;
-	}
-
-	if (coex_sta->wifi_is_high_pri_task)
-		halbtc8822b2ant_run_coexist_mechanism(btcoexist);
-
-}
-
-
-void ex_halbtc8822b2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length)
-{
-	u8			i, rsp_source = 0;
-	boolean			wifi_connected = FALSE;
-	boolean	wifi_scan = FALSE, wifi_link = FALSE, wifi_roam = FALSE,
-			wifi_busy = FALSE;
-	static boolean is_scoreboard_scan = FALSE;
-
-
-	rsp_source = tmp_buf[0] & 0xf;
-	if (rsp_source >= BT_INFO_SRC_8822B_2ANT_MAX)
-		rsp_source = BT_INFO_SRC_8822B_2ANT_WIFI_FW;
-	coex_sta->bt_info_c2h_cnt[rsp_source]++;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], Bt_info[%d], len=%d, data=[", rsp_source,
-		    length);
-	BTC_TRACE(trace_buf);
-
-	for (i = 0; i < length; i++) {
-		coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
-
-		if (i == length - 1) {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x]\n",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		} else {
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "0x%02x, ",
-				    tmp_buf[i]);
-			BTC_TRACE(trace_buf);
-		}
-	}
-
-	coex_sta->bt_info = coex_sta->bt_info_c2h[rsp_source][1];
-	coex_sta->bt_info_ext = coex_sta->bt_info_c2h[rsp_source][4];
-	coex_sta->bt_info_ext2 = coex_sta->bt_info_c2h[rsp_source][5];
-
-	if (BT_INFO_SRC_8822B_2ANT_WIFI_FW != rsp_source) {
-
-		/* if 0xff, it means BT is under WHCK test */
-		coex_sta->bt_whck_test = ((coex_sta->bt_info == 0xff) ? TRUE :
-					  FALSE);
-
-		coex_sta->bt_create_connection = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x80) ? TRUE :
-						  FALSE);
-
-		/* unit: %, value-100 to translate to unit: dBm */
-		coex_sta->bt_rssi = coex_sta->bt_info_c2h[rsp_source][3] * 2 +
-				    10;
-
-		coex_sta->c2h_bt_remote_name_req = ((
-			coex_sta->bt_info_c2h[rsp_source][2] & 0x20) ? TRUE :
-						    FALSE);
-
-		coex_sta->is_A2DP_3M = ((coex_sta->bt_info_c2h[rsp_source][2] &
-					 0x10) ? TRUE : FALSE);
-
-		coex_sta->acl_busy = ((coex_sta->bt_info_c2h[rsp_source][1] &
-				       0x9) ? TRUE : FALSE);
-
-		coex_sta->voice_over_HOGP = ((coex_sta->bt_info_ext & 0x10) ?
-					     TRUE : FALSE);
-
-		coex_sta->c2h_bt_inquiry_page = ((coex_sta->bt_info &
-			  BT_INFO_8822B_2ANT_B_INQ_PAGE) ? TRUE : FALSE);
-
-		coex_sta->a2dp_bit_pool = (((
-			coex_sta->bt_info_c2h[rsp_source][1] & 0x49) == 0x49) ?
-				   (coex_sta->bt_info_c2h[rsp_source][6] & 0x7f) : 0);
-
-		coex_sta->is_bt_a2dp_sink = (coex_sta->bt_info_c2h[rsp_source][6] & 0x80) ?
-									TRUE : FALSE;
-
-		coex_sta->bt_retry_cnt = coex_sta->bt_info_c2h[rsp_source][2] &
-					 0xf;
-
-		coex_sta->is_autoslot = coex_sta->bt_info_ext2 & 0x8;
-
-		coex_sta->forbidden_slot = coex_sta->bt_info_ext2 & 0x7;
-
-		coex_sta->hid_busy_num = (coex_sta->bt_info_ext2 & 0x30) >> 4;
-
-		coex_sta->hid_pair_cnt = (coex_sta->bt_info_ext2 & 0xc0) >> 6;
-
-		if (coex_sta->bt_retry_cnt >= 1)
-			coex_sta->pop_event_cnt++;
-
-		if (coex_sta->c2h_bt_remote_name_req)
-			coex_sta->cnt_RemoteNameReq++;
-
-		if (coex_sta->bt_info_ext & BIT(1))
-			coex_sta->cnt_ReInit++;
-
-		if (coex_sta->bt_info_ext & BIT(2)) {
-			coex_sta->cnt_setupLink++;
-			coex_sta->is_setupLink = TRUE;
-			coex_sta->bt_relink_downcount = 2;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link start in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		} else {
-			coex_sta->is_setupLink = FALSE;
-			coex_sta->bt_relink_downcount = 0;
-			BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-				    "[BTCoex], Re-Link stop in BT info!!\n");
-			BTC_TRACE(trace_buf);
-		}
-
-
-		if (coex_sta->bt_info_ext & BIT(3))
-			coex_sta->cnt_IgnWlanAct++;
-
-		if (coex_sta->bt_info_ext & BIT(6))
-			coex_sta->cnt_RoleSwitch++;
-
-		if (coex_sta->bt_info_ext & BIT(7))
-			coex_sta->is_bt_multi_link = TRUE;
-		else
-			coex_sta->is_bt_multi_link = FALSE;
-
-		if (coex_sta->bt_create_connection) {
-			coex_sta->cnt_Page++;
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY,
-					   &wifi_busy);
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &wifi_scan);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &wifi_link);
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &wifi_roam);
-
-			if ((wifi_link) || (wifi_roam) || (wifi_scan) ||
-			    (coex_sta->wifi_is_high_pri_task) || (wifi_busy)) {
-
-				is_scoreboard_scan = TRUE;
-				halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_SCAN, TRUE);
-
-			} else
-				halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_SCAN, FALSE);
-
-		} else {
-				if (is_scoreboard_scan) {
-					halbtc8822b2ant_post_state_to_bt(btcoexist,
-						 BT_8822B_2ANT_SCOREBOARD_SCAN, FALSE);
-					is_scoreboard_scan = FALSE;
-				}
-		}
-
-		/* Here we need to resend some wifi info to BT */
-		/* because bt is reset and loss of the info. */
-
-		if ((!btcoexist->manual_control) &&
-		    (!btcoexist->stop_coex_dm)) {
-
-			btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED,
-					   &wifi_connected);
-
-			/*  Re-Init */
-			if ((coex_sta->bt_info_ext & BIT(1))) {
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
-				BTC_TRACE(trace_buf);
-				if (wifi_connected)
-					halbtc8822b2ant_update_wifi_channel_info(
-						btcoexist, BTC_MEDIA_CONNECT);
-				else
-					halbtc8822b2ant_update_wifi_channel_info(
-						btcoexist,
-						BTC_MEDIA_DISCONNECT);
-			}
-
-
-			/*  If Ignore_WLanAct && not SetUp_Link */
-			if ((coex_sta->bt_info_ext & BIT(3)) &&
-				(!(coex_sta->bt_info_ext & BIT(2))) &&
-				(!(coex_sta->bt_info_ext & BIT(6)))) {
-
-				BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
-				BTC_TRACE(trace_buf);
-				halbtc8822b2ant_ignore_wlan_act(btcoexist,
-							FORCE_EXEC, FALSE);
-			} else {
-				if (coex_sta->bt_info_ext & BIT(2)) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ignore Wlan active because Re-link!!\n");
-					BTC_TRACE(trace_buf);
-				} else if (coex_sta->bt_info_ext & BIT(6)) {
-					BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-					"[BTCoex], BT ignore Wlan active because Role-Switch!!\n");
-					BTC_TRACE(trace_buf);
-				}
-			}
-		}
-
-	}
-
-	if ((coex_sta->bt_info_ext & BIT(5))) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], BT ext info bit4 check, query BLE Scan type!!\n");
-		BTC_TRACE(trace_buf);
-		coex_sta->bt_ble_scan_type = btcoexist->btc_get_ble_scan_type_from_bt(
-						     btcoexist);
-
-		if ((coex_sta->bt_ble_scan_type & 0x1) == 0x1)
-			coex_sta->bt_ble_scan_para[0]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x1);
-		if ((coex_sta->bt_ble_scan_type & 0x2) == 0x2)
-			coex_sta->bt_ble_scan_para[1]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x2);
-		if ((coex_sta->bt_ble_scan_type & 0x4) == 0x4)
-			coex_sta->bt_ble_scan_para[2]  =
-				btcoexist->btc_get_ble_scan_para_from_bt(btcoexist,
-						0x4);
-	}
-
-	halbtc8822b2ant_update_bt_link_info(btcoexist);
-
-	halbtc8822b2ant_run_coexist_mechanism(btcoexist);
-}
-
-
-void ex_halbtc8822b2ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], RF Status notify\n");
-	BTC_TRACE(trace_buf);
-
-	if (BTC_RF_ON == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned ON!!\n");
-		BTC_TRACE(trace_buf);
-
-		btcoexist->stop_coex_dm = FALSE;
-		coex_sta->is_rf_state_off = FALSE;
-#if 0
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ONOFF, TRUE);
-#endif
-	} else if (BTC_RF_OFF == type) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], RF is turned OFF!!\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-					     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_WLAN_OFF);
-
-		halbtc8822b2ant_action_coex_all_off(btcoexist);
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-				BT_8822B_2ANT_SCOREBOARD_ACTIVE |
-				BT_8822B_2ANT_SCOREBOARD_ONOFF |
-				BT_8822B_2ANT_SCOREBOARD_SCAN |
-				BT_8822B_2ANT_SCOREBOARD_UNDERTEST,
-				FALSE);
-
-		btcoexist->stop_coex_dm = TRUE;
-		coex_sta->is_rf_state_off = TRUE;
-	}
-}
-
-void ex_halbtc8822b2ant_halt_notify(IN struct btc_coexist *btcoexist)
-{
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Halt notify\n");
-	BTC_TRACE(trace_buf);
-
-	halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO, FORCE_EXEC,
-				     BT_8822B_2ANT_PHASE_WLAN_OFF);
-
-	ex_halbtc8822b2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT);
-
-	halbtc8822b2ant_post_state_to_bt(btcoexist,
-				 BT_8822B_2ANT_SCOREBOARD_ACTIVE, FALSE);
-	halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ONOFF, FALSE);
-}
-
-void ex_halbtc8822b2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state)
-{
-	boolean wifi_under_5g = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Pnp notify\n");
-	BTC_TRACE(trace_buf);
-
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g);
-
-	if ((BTC_WIFI_PNP_SLEEP == pnp_state) ||
-	    (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state)) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to SLEEP\n");
-		BTC_TRACE(trace_buf);
-
-		/* Sinda 20150819, workaround for driver skip leave IPS/LPS to
-		 * speed up sleep time.
-		 * Driver do not leave IPS/LPS when driver is going to sleep,
-		 * so BTCoexistence think wifi is still under IPS/LPS.
-		 * BT should clear UnderIPS/UnderLPS state to avoid mismatch
-		 * state after wakeup.
-		 */
-		coex_sta->under_ips = FALSE;
-		coex_sta->under_lps = FALSE;
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-				 BT_8822B_2ANT_SCOREBOARD_ACTIVE, FALSE);
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ONOFF, FALSE);
-
-
-		if (BTC_WIFI_PNP_SLEEP_KEEP_ANT == pnp_state) {
-
-			if (wifi_under_5g)
-				halbtc8822b2ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_5G_RUNTIME);
-			else
-				halbtc8822b2ant_set_ant_path(btcoexist,
-					     BTC_ANT_PATH_AUTO, FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_2G_RUNTIME);
-		} else {
-
-			halbtc8822b2ant_set_ant_path(btcoexist, BTC_ANT_PATH_AUTO,
-						     FORCE_EXEC,
-					     BT_8822B_2ANT_PHASE_WLAN_OFF);
-		}
-	} else if (BTC_WIFI_PNP_WAKE_UP == pnp_state) {
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			    "[BTCoex], Pnp notify to WAKE UP\n");
-		BTC_TRACE(trace_buf);
-
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ACTIVE, TRUE);
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-					 BT_8822B_2ANT_SCOREBOARD_ONOFF, TRUE);
-	}
-}
-
-void ex_halbtc8822b2ant_periodical(IN struct btc_coexist *btcoexist)
-{
-	boolean wifi_busy = FALSE;
-	u16 bt_scoreboard_val = 0;
-	boolean bt_relink_finish = FALSE;
-
-	BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-		    "[BTCoex], ************* Periodical *************\n");
-	BTC_TRACE(trace_buf);
-
-#if (BT_AUTO_REPORT_ONLY_8822B_2ANT == 0)
-	halbtc8822b2ant_query_bt_info(btcoexist);
-#endif
-
-	halbtc8822b2ant_monitor_bt_ctr(btcoexist);
-	halbtc8822b2ant_monitor_wifi_ctr(btcoexist);
-	halbtc8822b2ant_monitor_bt_enable_disable(btcoexist);
-
-#if 1
-	btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy);
-	halbtc8822b2ant_read_score_board(btcoexist, &bt_scoreboard_val);
-
-	if (wifi_busy) {
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-				BT_8822B_2ANT_SCOREBOARD_UNDERTEST, TRUE);
-		/*for bt lps32 clock offset*/
-		if (bt_scoreboard_val & BIT(6))
-			halbtc8822b2ant_query_bt_info(btcoexist);
-	} else {
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-			BT_8822B_2ANT_SCOREBOARD_UNDERTEST, FALSE);
-#if 0
-		halbtc8822b2ant_post_state_to_bt(btcoexist,
-			BT_8822B_2ANT_SCOREBOARD_WLBUSY,
-				FALSE);
-#endif
-	}
-#endif
-
-	if (coex_sta->bt_relink_downcount != 0) {
-		coex_sta->bt_relink_downcount--;
-
-		if (coex_sta->bt_relink_downcount == 0) {
-			coex_sta->is_setupLink = FALSE;
-			bt_relink_finish = TRUE;
-		}
-	}
-
-	/* for 4-way, DHCP, EAPOL packet */
-	if (coex_sta->specific_pkt_period_cnt > 0) {
-
-		coex_sta->specific_pkt_period_cnt--;
-
-		if ((coex_sta->specific_pkt_period_cnt == 0) &&
-		    (coex_sta->wifi_is_high_pri_task))
-			coex_sta->wifi_is_high_pri_task = FALSE;
-
-		BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
-			"[BTCoex], ***************** Hi-Pri Task = %s*****************\n",
-			    (coex_sta->wifi_is_high_pri_task ? "Yes" :
-			     "No"));
-		BTC_TRACE(trace_buf);
-
-	}
-
-	if (halbtc8822b2ant_is_wifibt_status_changed(btcoexist) || (bt_relink_finish)
-		|| (coex_sta->is_set_ps_state_fail))
-		halbtc8822b2ant_run_coexist_mechanism(btcoexist);
-}
-
-void ex_halbtc8822b2ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds)
-{
-
-}
-
-
-void ex_halbtc8822b2ant_display_ant_detection(IN struct btc_coexist *btcoexist)
-{
-}
-
-
-#endif
-
-#endif	/*  #if (RTL8822B_SUPPORT == 1) */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b2ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b2ant.h
deleted file mode 100644
index 9fb0a4637bd3..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822b2ant.h
+++ /dev/null
@@ -1,527 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-
-#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
-
-#if (RTL8822B_SUPPORT == 1)
-
-/* *******************************************
- * The following is for 8822B 2Ant BT Co-exist definition
- * ******************************************* */
-#define	BT_8822B_2ANT_COEX_DBG					0
-#define	BT_AUTO_REPORT_ONLY_8822B_2ANT			1
-
-
-
-
-#define	BT_INFO_8822B_2ANT_B_FTP						BIT(7)
-#define	BT_INFO_8822B_2ANT_B_A2DP					BIT(6)
-#define	BT_INFO_8822B_2ANT_B_HID						BIT(5)
-#define	BT_INFO_8822B_2ANT_B_SCO_BUSY				BIT(4)
-#define	BT_INFO_8822B_2ANT_B_ACL_BUSY				BIT(3)
-#define	BT_INFO_8822B_2ANT_B_INQ_PAGE				BIT(2)
-#define	BT_INFO_8822B_2ANT_B_SCO_ESCO				BIT(1)
-#define	BT_INFO_8822B_2ANT_B_CONNECTION				BIT(0)
-
-#define		BTC_RSSI_COEX_THRESH_TOL_8822B_2ANT		2
-
-
-/* unit: % WiFi RSSI Threshold for 2-Ant free-run/2-Ant TDMA translation.
- * (default = 42)
- */
-#define	BT_8822B_2ANT_WIFI_RSSI_COEXSWITCH_THRES1				30
-/* unit: % BT RSSI Threshold for 2-Ant free-run/2-Ant TDMA translation.
- * (default = 46)
- */
-#define	BT_8822B_2ANT_BT_RSSI_COEXSWITCH_THRES1				20
-/* unit: % WiFi RSSI Threshold for 1-Ant TDMA/1-Ant PS-TDMA translation.
- * (default = 42)
- */
-#define	BT_8822B_2ANT_WIFI_RSSI_COEXSWITCH_THRES2				30
-/* unit: % BT RSSI Threshold for 1-Ant TDMA/1-Ant PS-TDMA translation.
- * (default = 46)
- */
-#define	BT_8822B_2ANT_BT_RSSI_COEXSWITCH_THRES2				20
-#define	BT_8822B_2ANT_DEFAULT_ISOLATION						15	 /*  unit: dB */
-#define   BT_8822B_2ANT_WIFI_MAX_TX_POWER						15	 /*  unit: dBm */
-#define   BT_8822B_2ANT_BT_MAX_TX_POWER							3	 /*  unit: dBm */
-#define   BT_8822B_2ANT_WIFI_SIR_THRES1							-15  /*  unit: dB */
-#define   BT_8822B_2ANT_WIFI_SIR_THRES2							-30  /*  unit: dB */
-#define   BT_8822B_2ANT_BT_SIR_THRES1							-15		 /*  unit: dB */
-#define   BT_8822B_2ANT_BT_SIR_THRES2							-30		 /*  unit: dB */
-
-
-/* for Antenna detection */
-#define	BT_8822B_2ANT_ANTDET_PSDTHRES_BACKGROUND						50
-#define	BT_8822B_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION				70
-#define	BT_8822B_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION			52
-#define	BT_8822B_2ANT_ANTDET_PSDTHRES_1ANT							40
-#define	BT_8822B_2ANT_ANTDET_RETRY_INTERVAL							10	/* retry timer if ant det is fail, unit: second */
-#define	BT_8822B_2ANT_ANTDET_SWEEPPOINT_DELAY							60000
-#define	BT_8822B_2ANT_ANTDET_ENABLE										0
-#define	BT_8822B_2ANT_ANTDET_BTTXTIME									100
-#define	BT_8822B_2ANT_ANTDET_BTTXCHANNEL								39
-#define	BT_8822B_2ANT_ANTDET_PSD_SWWEEPCOUNT						50
-
-
-#define	BT_8822B_2ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT		30000
-
-enum bt_8822b_2ant_signal_state {
-	BT_8822B_2ANT_SIG_STA_SET_TO_LOW		= 0x0,
-	BT_8822B_2ANT_SIG_STA_SET_BY_HW		= 0x0,
-	BT_8822B_2ANT_SIG_STA_SET_TO_HIGH		= 0x1,
-	BT_8822B_2ANT_SIG_STA_MAX
-};
-
-enum bt_8822b_2ant_path_ctrl_owner {
-	BT_8822B_2ANT_PCO_BTSIDE		= 0x0,
-	BT_8822B_2ANT_PCO_WLSIDE	= 0x1,
-	BT_8822B_2ANT_PCO_MAX
-};
-
-enum bt_8822b_2ant_gnt_ctrl_type {
-	BT_8822B_2ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,
-	BT_8822B_2ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,
-	BT_8822B_2ANT_GNT_TYPE_MAX
-};
-
-enum bt_8822b_2ant_gnt_ctrl_block {
-	BT_8822B_2ANT_GNT_BLOCK_RFC_BB		= 0x0,
-	BT_8822B_2ANT_GNT_BLOCK_RFC			= 0x1,
-	BT_8822B_2ANT_GNT_BLOCK_BB			= 0x2,
-	BT_8822B_2ANT_GNT_BLOCK_MAX
-};
-
-enum bt_8822b_2ant_lte_coex_table_type {
-	BT_8822B_2ANT_CTT_WL_VS_LTE			= 0x0,
-	BT_8822B_2ANT_CTT_BT_VS_LTE			= 0x1,
-	BT_8822B_2ANT_CTT_MAX
-};
-
-enum bt_8822b_2ant_lte_break_table_type {
-	BT_8822B_2ANT_LBTT_WL_BREAK_LTE			= 0x0,
-	BT_8822B_2ANT_LBTT_BT_BREAK_LTE				= 0x1,
-	BT_8822B_2ANT_LBTT_LTE_BREAK_WL			= 0x2,
-	BT_8822B_2ANT_LBTT_LTE_BREAK_BT				= 0x3,
-	BT_8822B_2ANT_LBTT_MAX
-};
-
-enum bt_info_src_8822b_2ant {
-	BT_INFO_SRC_8822B_2ANT_WIFI_FW			= 0x0,
-	BT_INFO_SRC_8822B_2ANT_BT_RSP				= 0x1,
-	BT_INFO_SRC_8822B_2ANT_BT_ACTIVE_SEND		= 0x2,
-	BT_INFO_SRC_8822B_2ANT_MAX
-};
-
-enum bt_8822b_2ant_bt_status {
-	BT_8822B_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,
-	BT_8822B_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,
-	BT_8822B_2ANT_BT_STATUS_INQ_PAGE				= 0x2,
-	BT_8822B_2ANT_BT_STATUS_ACL_BUSY				= 0x3,
-	BT_8822B_2ANT_BT_STATUS_SCO_BUSY				= 0x4,
-	BT_8822B_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,
-	BT_8822B_2ANT_BT_STATUS_MAX
-};
-
-enum bt_8822b_2ant_coex_algo {
-	BT_8822B_2ANT_COEX_ALGO_UNDEFINED			= 0x0,
-	BT_8822B_2ANT_COEX_ALGO_SCO				= 0x1,
-	BT_8822B_2ANT_COEX_ALGO_HID				= 0x2,
-	BT_8822B_2ANT_COEX_ALGO_A2DP				= 0x3,
-	BT_8822B_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,
-	BT_8822B_2ANT_COEX_ALGO_PANEDR			= 0x5,
-	BT_8822B_2ANT_COEX_ALGO_PANHS			= 0x6,
-	BT_8822B_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,
-	BT_8822B_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,
-	BT_8822B_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,
-	BT_8822B_2ANT_COEX_ALGO_HID_A2DP			= 0xa,
-	BT_8822B_2ANT_COEX_ALGO_NOPROFILEBUSY		= 0xb,
-	BT_8822B_2ANT_COEX_ALGO_A2DPSINK			= 0xc,
-	BT_8822B_2ANT_COEX_ALGO_MAX
-};
-
-enum bt_8822b_2ant_ext_ant_switch_type {
-	BT_8822B_2ANT_EXT_ANT_SWITCH_USE_DPDT		= 0x0,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_USE_SPDT		= 0x1,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_NONE			= 0x2,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_MAX
-};
-
-enum bt_8822b_2ant_ext_ant_switch_ctrl_type {
-	BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	= 0x0,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_PTA		= 0x1,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_MAC		= 0x3,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_CTRL_MAX
-};
-
-enum bt_8822b_2ant_ext_ant_switch_pos_type {
-	BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_BT			= 0x0,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLG			= 0x1,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLA			= 0x2,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE		= 0x3,
-	BT_8822B_2ANT_EXT_ANT_SWITCH_MAIN_TO_MAX
-};
-
-enum bt_8822b_2ant_ext_band_switch_pos_type {
-	BT_8822B_2ANT_EXT_BAND_SWITCH_TO_WLG			= 0x0,
-	BT_8822B_2ANT_EXT_BAND_SWITCH_TO_WLA			= 0x1,
-	BT_8822B_2ANT_EXT_BAND_SWITCH_TO_MAX
-};
-
-enum bt_8822b_2ant_int_block {
-	BT_8822B_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG			= 0x0,
-	BT_8822B_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG		= 0x1,
-	BT_8822B_2ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG		= 0x2,
-	BT_8822B_2ANT_INT_BLOCK_SWITCH_TO_MAX
-};
-
-enum bt_8822b_2ant_phase {
-	BT_8822B_2ANT_PHASE_COEX_INIT								= 0x0,
-	BT_8822B_2ANT_PHASE_WLANONLY_INIT							= 0x1,
-	BT_8822B_2ANT_PHASE_WLAN_OFF								= 0x2,
-	BT_8822B_2ANT_PHASE_2G_RUNTIME								= 0x3,
-	BT_8822B_2ANT_PHASE_5G_RUNTIME								= 0x4,
-	BT_8822B_2ANT_PHASE_BTMPMODE								= 0x5,
-	BT_8822B_2ANT_PHASE_ANTENNA_DET								= 0x6,
-	BT_8822B_2ANT_PHASE_COEX_POWERON							= 0x7,
-	BT_8822B_2ANT_PHASE_2G_RUNTIME_CONCURRENT					= 0x8,
-	BT_8822B_2ANT_PHASE_MAX
-};
-
-/*ADD SCOREBOARD TO FIX BT LPS 32K ISSUE WHILE WL BUSY*/
-
-enum bt_8822b_2ant_Scoreboard {
-	BT_8822B_2ANT_SCOREBOARD_ACTIVE								= BIT(0),
-	BT_8822B_2ANT_SCOREBOARD_ONOFF								= BIT(1),
-	BT_8822B_2ANT_SCOREBOARD_SCAN								= BIT(2),
-	BT_8822B_2ANT_SCOREBOARD_UNDERTEST							= BIT(3),
-	BT_8822B_2ANT_SCOREBOARD_WLBUSY                                                              = BIT(6)
-};
-
-
-
-
-
-struct coex_dm_8822b_2ant {
-	/* hw setting */
-	u32		pre_ant_pos_type;
-	u32		cur_ant_pos_type;
-	/* fw mechanism */
-	u8		pre_bt_dec_pwr_lvl;
-	u8		cur_bt_dec_pwr_lvl;
-	u8		pre_fw_dac_swing_lvl;
-	u8		cur_fw_dac_swing_lvl;
-	boolean		cur_ignore_wlan_act;
-	boolean		pre_ignore_wlan_act;
-	u8		pre_ps_tdma;
-	u8		cur_ps_tdma;
-	u8		ps_tdma_para[5];
-	u8		ps_tdma_du_adj_type;
-	boolean		reset_tdma_adjust;
-	boolean		pre_ps_tdma_on;
-	boolean		cur_ps_tdma_on;
-	boolean		pre_bt_auto_report;
-	boolean		cur_bt_auto_report;
-
-	/* sw mechanism */
-	boolean		pre_rf_rx_lpf_shrink;
-	boolean		cur_rf_rx_lpf_shrink;
-	u32		bt_rf_0x1e_backup;
-	boolean	pre_low_penalty_ra;
-	boolean		cur_low_penalty_ra;
-	boolean		pre_dac_swing_on;
-	u32		pre_dac_swing_lvl;
-	boolean		cur_dac_swing_on;
-	u32		cur_dac_swing_lvl;
-	boolean		pre_adc_back_off;
-	boolean		cur_adc_back_off;
-	boolean		pre_agc_table_en;
-	boolean		cur_agc_table_en;
-	u32		pre_val0x6c0;
-	u32		cur_val0x6c0;
-	u32		pre_val0x6c4;
-	u32		cur_val0x6c4;
-	u32		pre_val0x6c8;
-	u32		cur_val0x6c8;
-	u8		pre_val0x6cc;
-	u8		cur_val0x6cc;
-	boolean		limited_dig;
-
-	/* algorithm related */
-	u8		pre_algorithm;
-	u8		cur_algorithm;
-	u8		bt_status;
-	u8		wifi_chnl_info[3];
-
-	boolean		need_recover0x948;
-	u32		backup0x948;
-
-	u8		pre_lps;
-	u8		cur_lps;
-	u8		pre_rpwm;
-	u8		cur_rpwm;
-
-	boolean		is_switch_to_1dot5_ant;
-	u8		switch_thres_offset;
-	u32					arp_cnt;
-
-	u32		pre_ext_ant_switch_status;
-	u32		cur_ext_ant_switch_status;
-
-	u8		pre_ext_band_switch_status;
-	u8		cur_ext_band_switch_status;
-
-	u8		pre_int_block_status;
-	u8		cur_int_block_status;
-};
-
-
-struct coex_sta_8822b_2ant {
-	boolean					bt_disabled;
-	boolean					bt_link_exist;
-	boolean					sco_exist;
-	boolean					a2dp_exist;
-	boolean					hid_exist;
-	boolean					pan_exist;
-
-	boolean					under_lps;
-	boolean					under_ips;
-	u32					high_priority_tx;
-	u32					high_priority_rx;
-	u32					low_priority_tx;
-	u32					low_priority_rx;
-	boolean             is_hiPri_rx_overhead;
-	u8					bt_rssi;
-	u8					pre_bt_rssi_state;
-	u8					pre_wifi_rssi_state[4];
-	u8					bt_info_c2h[BT_INFO_SRC_8822B_2ANT_MAX][10];
-	u32					bt_info_c2h_cnt[BT_INFO_SRC_8822B_2ANT_MAX];
-	boolean				bt_whck_test;
-	boolean					c2h_bt_inquiry_page;
-	boolean					c2h_bt_remote_name_req;
-
-	u8					bt_info_ext;
-	u8					bt_info_ext2;
-	u32					pop_event_cnt;
-	u8					scan_ap_num;
-	u8					bt_retry_cnt;
-
-	u32					crc_ok_cck;
-	u32					crc_ok_11g;
-	u32					crc_ok_11n;
-	u32					crc_ok_11n_vht;
-
-	u32					crc_err_cck;
-	u32					crc_err_11g;
-	u32					crc_err_11n;
-	u32					crc_err_11n_vht;
-
-	u32					acc_crc_ratio;
-	u32					now_crc_ratio;
-
-	boolean					cck_lock;
-	boolean					pre_ccklock;
-	boolean					cck_ever_lock;
-
-	u8					coex_table_type;
-	boolean					force_lps_ctrl;
-
-	u8					dis_ver_info_cnt;
-
-	u8					a2dp_bit_pool;
-	u8					cut_version;
-
-	boolean					concurrent_rx_mode_on;
-
-	u16					score_board;
-	u8					isolation_btween_wb;   /* 0~ 50 */
-	u8					wifi_coex_thres;
-	u8					bt_coex_thres;
-	u8					wifi_coex_thres2;
-	u8					bt_coex_thres2;
-
-	u8					num_of_profile;
-	boolean				acl_busy;
-	boolean				bt_create_connection;
-	boolean				wifi_is_high_pri_task;
-	u32					specific_pkt_period_cnt;
-	u32					bt_coex_supported_feature;
-	u32					bt_coex_supported_version;
-
-	u8					bt_ble_scan_type;
-	u32					bt_ble_scan_para[3];
-
-	boolean				run_time_state;
-	boolean				freeze_coexrun_by_btinfo;
-
-	boolean				is_A2DP_3M;
-	boolean				voice_over_HOGP;
-	u8                  bt_info;
-	boolean				is_autoslot;
-	u8					forbidden_slot;
-	u8					hid_busy_num;
-	u8					hid_pair_cnt;
-
-	u32					cnt_RemoteNameReq;
-	u32					cnt_setupLink;
-	u32					cnt_ReInit;
-	u32					cnt_IgnWlanAct;
-	u32					cnt_Page;
-	u32					cnt_RoleSwitch;
-
-	u16					bt_reg_vendor_ac;
-	u16					bt_reg_vendor_ae;
-
-	boolean				is_setupLink;
-	u8				    wl_noisy_level;
-	u32                 gnt_error_cnt;
-
-	u8					bt_afh_map[10];
-	u8					bt_relink_downcount;
-	boolean				is_tdma_btautoslot;
-	boolean				is_tdma_btautoslot_hang;
-
-	boolean             is_eSCO_mode;
-	u8                  switch_band_notify_to;
-	boolean				is_rf_state_off;
-
-	boolean				is_hid_low_pri_tx_overhead;
-	boolean				is_bt_multi_link;
-	boolean				is_bt_a2dp_sink;
-
-	boolean				is_set_ps_state_fail;
-	u8					cnt_set_ps_state_fail;
-};
-
-
-#define  BT_8822B_2ANT_EXT_BAND_SWITCH_USE_DPDT	0
-#define  BT_8822B_2ANT_EXT_BAND_SWITCH_USE_SPDT	1
-
-
-struct rfe_type_8822b_2ant {
-
-	u8			rfe_module_type;
-	boolean		ext_ant_switch_exist;
-	u8			ext_ant_switch_type;			/* 0:DPDT, 1:SPDT */
-	/*  iF 0: DPDT_P=0, DPDT_N=1 => BTG to Main, WL_A+G to Aux */
-	u8			ext_ant_switch_ctrl_polarity;
-
-	boolean		ext_band_switch_exist;
-	u8			ext_band_switch_type;			/* 0:DPDT, 1:SPDT */
-	u8			ext_band_switch_ctrl_polarity;
-
-	/*  If true:  WLG at BTG, If false: WLG at WLAG */
-	boolean		wlg_Locate_at_btg;
-
-	boolean		ext_ant_switch_diversity;		/* If diversity on */
-};
-
-#define BT_8822B_2ANT_ANTDET_PSD_POINTS			256	/* MAX:1024 */
-#define BT_8822B_2ANT_ANTDET_PSD_AVGNUM		1	/* MAX:3 */
-#define BT_8822B_2ANT_ANTDET_BUF_LEN			16
-
-struct psdscan_sta_8822b_2ant {
-
-	u32			ant_det_bt_le_channel;  /* BT LE Channel ex:2412 */
-	u32			ant_det_bt_tx_time;
-	u32			ant_det_pre_psdscan_peak_val;
-	boolean			ant_det_is_ant_det_available;
-	u32			ant_det_psd_scan_peak_val;
-	boolean			ant_det_is_btreply_available;
-	u32			ant_det_psd_scan_peak_freq;
-
-	u8			ant_det_result;
-	u8			ant_det_peak_val[BT_8822B_2ANT_ANTDET_BUF_LEN];
-	u8			ant_det_peak_freq[BT_8822B_2ANT_ANTDET_BUF_LEN];
-	u32			ant_det_try_count;
-	u32			ant_det_fail_count;
-	u32			ant_det_inteval_count;
-	u32			ant_det_thres_offset;
-
-	u32			real_cent_freq;
-	s32			real_offset;
-	u32			real_span;
-
-	u32			psd_band_width;  /* unit: Hz */
-	u32			psd_point;		/* 128/256/512/1024 */
-	u32			psd_report[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_report_max_hold[1024];  /* unit:dB (20logx), 0~255 */
-	u32			psd_start_point;
-	u32			psd_stop_point;
-	u32			psd_max_value_point;
-	u32			psd_max_value;
-	u32			psd_max_value2;
-	/* filter loop_max_value that below BT_8822B_1ANT_ANTDET_PSDTHRES_1ANT,
-	 * and average the rest
-	 */
-	u32			psd_avg_value;
-	/*max value in each loop */
-	u32			psd_loop_max_value[BT_8822B_2ANT_ANTDET_PSD_SWWEEPCOUNT];
-	u32			psd_start_base;
-	u32			psd_avg_num;	/* 1/8/16/32 */
-	u32			psd_gen_count;
-	boolean			is_AntDet_running;
-	boolean			is_psd_show_max_only;
-};
-
-
-/* *******************************************
- * The following is interface which will notify coex module.
- * ******************************************* */
-void ex_halbtc8822b2ant_power_on_setting(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b2ant_pre_load_firmware(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b2ant_init_hw_config(IN struct btc_coexist *btcoexist,
-				       IN boolean wifi_only);
-void ex_halbtc8822b2ant_init_coex_dm(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b2ant_ips_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8822b2ant_lps_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 type);
-void ex_halbtc8822b2ant_scan_notify(IN struct btc_coexist *btcoexist,
-				    IN u8 type);
-void ex_halbtc8822b2ant_switchband_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b2ant_connect_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 type);
-void ex_halbtc8822b2ant_media_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b2ant_bt_info_notify(IN struct btc_coexist *btcoexist,
-				       IN u8 *tmp_buf, IN u8 length);
-void ex_halbtc8822b2ant_rf_status_notify(IN struct btc_coexist *btcoexist,
-		IN u8 type);
-void ex_halbtc8822b2ant_halt_notify(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b2ant_pnp_notify(IN struct btc_coexist *btcoexist,
-				   IN u8 pnp_state);
-void ex_halbtc8822b2ant_periodical(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b2ant_display_coex_info(IN struct btc_coexist *btcoexist);
-void ex_halbtc8822b2ant_antenna_detection(IN struct btc_coexist *btcoexist,
-		IN u32 cent_freq, IN u32 offset, IN u32 span, IN u32 seconds);
-void ex_halbtc8822b2ant_display_ant_detection(IN struct btc_coexist *btcoexist);
-
-
-#else
-#define	ex_halbtc8822b2ant_power_on_setting(btcoexist)
-#define	ex_halbtc8822b2ant_pre_load_firmware(btcoexist)
-#define	ex_halbtc8822b2ant_init_hw_config(btcoexist, wifi_only)
-#define	ex_halbtc8822b2ant_init_coex_dm(btcoexist)
-#define	ex_halbtc8822b2ant_ips_notify(btcoexist, type)
-#define	ex_halbtc8822b2ant_lps_notify(btcoexist, type)
-#define	ex_halbtc8822b2ant_scan_notify(btcoexist, type)
-#define   ex_halbtc8822b2ant_switchband_notify(btcoexist, type)
-#define	ex_halbtc8822b2ant_connect_notify(btcoexist, type)
-#define	ex_halbtc8822b2ant_media_status_notify(btcoexist, type)
-#define	ex_halbtc8822b2ant_specific_packet_notify(btcoexist, type)
-#define	ex_halbtc8822b2ant_bt_info_notify(btcoexist, tmp_buf, length)
-#define	ex_halbtc8822b2ant_rf_status_notify(btcoexist, type)
-#define	ex_halbtc8822b2ant_halt_notify(btcoexist)
-#define	ex_halbtc8822b2ant_pnp_notify(btcoexist, pnp_state)
-#define	ex_halbtc8822b2ant_periodical(btcoexist)
-#define	ex_halbtc8822b2ant_display_coex_info(btcoexist)
-#define	ex_halbtc8822b2ant_display_ant_detection(btcoexist)
-#define	ex_halbtc8822b2ant_antenna_detection(btcoexist, cent_freq, offset, span, seconds)
-#endif
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822bwifionly.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822bwifionly.c
deleted file mode 100644
index 8de640966cb4..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822bwifionly.c
+++ /dev/null
@@ -1,68 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
- *
- * 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 "mp_precomp.h"
-
-
-VOID
-ex_hal8822b_wifi_only_hw_config(
-	IN struct wifi_only_cfg *pwifionlycfg
-	)
-{
-	/*BB control*/
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x4c, 0x01800000, 0x2);
-	/*SW control*/
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcb4, 0xff, 0x77);
-	/*antenna mux switch */
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x974, 0x300, 0x3);
-
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1990, 0x300, 0x0);
-
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcbc, 0x80000, 0x0);
-	/*switch to WL side controller and gnt_wl gnt_bt debug signal */
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x70, 0xff000000, 0x0e);
-	/*gnt_wl=1 , gnt_bt=0*/
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1704, 0xffffffff, 0x7700);
-	halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1700, 0xffffffff, 0xc00f0038);
-}
-
-VOID
-ex_hal8822b_wifi_only_scannotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	)
-{
-	hal8822b_wifi_only_switch_antenna(pwifionlycfg, is_5g);
-}
-
-VOID
-ex_hal8822b_wifi_only_switchbandnotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	)
-{
-	hal8822b_wifi_only_switch_antenna(pwifionlycfg, is_5g);
-}
-
-VOID
-hal8822b_wifi_only_switch_antenna(IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	)
-{
-
-	if (is_5g)
-		halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcbc, 0x300, 0x1);
-	else
-		halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcbc, 0x300, 0x2);
-}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtcoutsrc.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtcoutsrc.h
index 0f209671c7e0..77bde2b572fc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtcoutsrc.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtcoutsrc.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -133,6 +134,9 @@ do {\
 #define		NORMAL_EXEC					FALSE
 #define		FORCE_EXEC						TRUE
 
+#define		NM_EXCU						FALSE
+#define		FC_EXCU						TRUE
+
 #define		BTC_RF_OFF					0x0
 #define		BTC_RF_ON					0x1
 
@@ -214,6 +218,7 @@ typedef enum _BTC_CHIP_TYPE {
 /* following is for command line utility */
 #define	CL_SPRINTF	rsprintf
 #define	CL_PRINTF	DCMD_Printf
+#define CL_STRNCAT(dst, dst_size, src, src_size) rstrncat(dst, src, src_size)
 
 struct btc_board_info {
 	/* The following is some board information */
@@ -234,6 +239,7 @@ struct btc_board_info {
 	boolean			ant_det_result_five_complete;
 	u32				antdetval;
 	u8				customerID;
+	u8				customer_id;
 };
 
 typedef enum _BTC_DBG_OPCODE {
@@ -271,6 +277,7 @@ typedef enum _BTC_WIFI_ROLE {
 typedef enum _BTC_WIRELESS_FREQ {
 	BTC_FREQ_2_4G					= 0x0,
 	BTC_FREQ_5G						= 0x1,
+	BTC_FREQ_25G					= 0x2,
 	BTC_FREQ_MAX
 } BTC_WIRELESS_FREQ, *PBTC_WIRELESS_FREQ;
 
@@ -293,6 +300,7 @@ typedef enum _BTC_WIFI_PNP {
 	BTC_WIFI_PNP_WAKE_UP					= 0x0,
 	BTC_WIFI_PNP_SLEEP						= 0x1,
 	BTC_WIFI_PNP_SLEEP_KEEP_ANT				= 0x2,
+	BTC_WIFI_PNP_WOWLAN					= 0x3,
 	BTC_WIFI_PNP_MAX
 } BTC_WIFI_PNP, *PBTC_WIFI_PNP;
 
@@ -353,6 +361,7 @@ typedef enum _BTC_GET_TYPE {
 	BTC_GET_BL_WIFI_FW_READY,
 	BTC_GET_BL_WIFI_CONNECTED,
 	BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED,
+	BTC_GET_BL_WIFI_LINK_INFO,
 	BTC_GET_BL_WIFI_BUSY,
 	BTC_GET_BL_WIFI_SCAN,
 	BTC_GET_BL_WIFI_LINK,
@@ -366,6 +375,7 @@ typedef enum _BTC_GET_TYPE {
 	BTC_GET_BL_WIFI_IS_IN_MP_MODE,
 	BTC_GET_BL_IS_ASUS_8723B,
 	BTC_GET_BL_RF4CE_CONNECTED,
+	BTC_GET_BL_WIFI_LW_PWR_STATE,
 
 	/* type s4Byte */
 	BTC_GET_S4_WIFI_RSSI,
@@ -418,6 +428,7 @@ typedef enum _BTC_SET_TYPE {
 	BTC_SET_BL_INC_SCAN_DEV_NUM,
 	BTC_SET_BL_BT_TX_RX_MASK,
 	BTC_SET_BL_MIRACAST_PLUS_BT,
+	BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL,
 
 	/* type u1Byte */
 	BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
@@ -427,6 +438,9 @@ typedef enum _BTC_SET_TYPE {
 	BTC_SET_ACT_GET_BT_RSSI,
 	BTC_SET_ACT_AGGREGATE_CTRL,
 	BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
+
+	// for mimo ps mode setting
+	BTC_SET_MIMO_PS_MODE,
 	/*===== for 1Ant ======*/
 	/* type BOOLEAN */
 
@@ -472,6 +486,7 @@ typedef enum _BTC_NOTIFY_TYPE_SCAN {
 	BTC_SCAN_FINISH							= 0x0,
 	BTC_SCAN_START							= 0x1,
 	BTC_SCAN_START_2G						= 0x2,
+	BTC_SCAN_START_5G						= 0x3,
 	BTC_SCAN_MAX
 } BTC_NOTIFY_TYPE_SCAN, *PBTC_NOTIFY_TYPE_SCAN;
 typedef enum _BTC_NOTIFY_TYPE_SWITCHBAND {
@@ -491,6 +506,7 @@ typedef enum _BTC_NOTIFY_TYPE_ASSOCIATE {
 typedef enum _BTC_NOTIFY_TYPE_MEDIA_STATUS {
 	BTC_MEDIA_DISCONNECT					= 0x0,
 	BTC_MEDIA_CONNECT						= 0x1,
+	BTC_MEDIA_CONNECT_5G					= 0x02,
 	BTC_MEDIA_MAX
 } BTC_NOTIFY_TYPE_MEDIA_STATUS, *PBTC_NOTIFY_TYPE_MEDIA_STATUS;
 typedef enum _BTC_NOTIFY_TYPE_SPECIFIC_PACKET {
@@ -519,6 +535,8 @@ typedef enum _BTC_BT_OFFON {
 	BTC_BT_ON				= 0x1,
 } BTC_BTOFFON, *PBTC_BT_OFFON;
 
+#define BTC_5G_BAND 0x80
+
 /*==================================================
 For following block is for coex offload
 ==================================================*/
@@ -628,6 +646,49 @@ typedef struct _BTC_OFFLOAD {
 extern BTC_OFFLOAD				gl_coex_offload;
 /*==================================================*/
 
+/* BTC_LINK_MODE same as WIFI_LINK_MODE */
+typedef enum _BTC_LINK_MODE{
+	BTC_LINK_NONE=0,
+	BTC_LINK_ONLY_GO,
+	BTC_LINK_ONLY_GC,
+	BTC_LINK_ONLY_STA,
+	BTC_LINK_ONLY_AP,
+	BTC_LINK_2G_MCC_GO_STA,
+	BTC_LINK_5G_MCC_GO_STA,
+	BTC_LINK_25G_MCC_GO_STA,
+	BTC_LINK_2G_MCC_GC_STA,
+	BTC_LINK_5G_MCC_GC_STA,
+	BTC_LINK_25G_MCC_GC_STA,
+	BTC_LINK_2G_SCC_GO_STA,
+	BTC_LINK_5G_SCC_GO_STA,
+	BTC_LINK_2G_SCC_GC_STA,
+	BTC_LINK_5G_SCC_GC_STA,
+	BTC_LINK_MAX=30
+}BTC_LINK_MODE, *PBTC_LINK_MODE;
+
+
+struct btc_wifi_link_info {
+	BTC_LINK_MODE link_mode; /* LinkMode */
+	u1Byte sta_center_channel; /* StaCenterChannel */
+	u1Byte p2p_center_channel; /* P2PCenterChannel	*/
+	BOOLEAN bany_client_join_go;
+	BOOLEAN benable_noa;
+	BOOLEAN bhotspot;
+};
+
+typedef enum _BTC_MULTI_PORT_TDMA_MODE {
+	BTC_MULTI_PORT_TDMA_MODE_NONE=0,
+	BTC_MULTI_PORT_TDMA_MODE_2G_SCC_GO,
+	BTC_MULTI_PORT_TDMA_MODE_2G_P2P_GO,
+	BTC_MULTI_PORT_TDMA_MODE_2G_HOTSPOT_GO
+} BTC_MULTI_PORT_TDMA_MODE, *PBTC_MULTI_PORT_TDMA_MODE;
+
+typedef struct btc_multi_port_tdma_info {
+	BTC_MULTI_PORT_TDMA_MODE btc_multi_port_tdma_mode;
+	u1Byte start_time_from_bcn;
+	u1Byte bt_time;
+} BTC_MULTI_PORT_TDMA_INFO, *PBTC_MULTI_PORT_TDMA_INFO;
+
 typedef u1Byte
 (*BFP_BTC_R1)(
 	IN	PVOID			pBtcContext,
@@ -779,6 +840,14 @@ typedef u4Byte
 	IN	PVOID			pBtcContext
 	);
 
+typedef u4Byte
+(*BFP_BTC_SET_ATOMIC) 	(
+	IN	PVOID			pBtcContext,
+	IN	pu4Byte 		target,
+	IN	u4Byte			val
+	);
+
+
 typedef VOID
 (*BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD)(
 	IN	PVOID		pDM_Odm,
@@ -909,6 +978,8 @@ struct btc_statistics {
 	u32					cnt_stack_operation_notify;
 	u32					cnt_dbg_ctrl;
 	u32					cnt_rate_id_notify;
+	u32					cnt_halt_notify;
+	u32					cnt_pnp_notify;
 };
 
 struct btc_coexist {
@@ -918,6 +989,7 @@ struct btc_coexist {
 	struct  btc_bt_info			bt_info;		/*some bt info referenced by non-bt module*/
 	struct  btc_stack_info		stack_info;
 	struct  btc_bt_link_info		bt_link_info;
+	struct btc_wifi_link_info	wifi_link_info;
 
 #ifdef CONFIG_RF4CE_COEXIST
 	struct  btc_rf4ce_info		rf4ce_info;
@@ -932,6 +1004,8 @@ struct btc_coexist {
 	pu1Byte					cli_buf;
 	struct btc_statistics		statistics;
 	u1Byte				pwrModeVal[10];
+	BOOLEAN dbg_mode;
+	BOOLEAN auto_report;
 
 	/* function pointers */
 	/* io related */
@@ -969,13 +1043,67 @@ struct btc_coexist {
 	BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE btc_get_bt_coex_supported_feature;
 	BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION btc_get_bt_coex_supported_version;
 	BFP_BTC_GET_PHYDM_VERSION		btc_get_bt_phydm_version;
+	BFP_BTC_SET_ATOMIC			btc_set_atomic;
 	BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD	btc_phydm_modify_RA_PCR_threshold;
 	BTC_PHYDM_CMNINFOQUERY				btc_phydm_query_PHY_counter;
-	BTC_PHYDM_MODIFY_ANTDIV_HWSW		btc_phydm_modify_ANTDIV_HwSw;
+	BTC_PHYDM_MODIFY_ANTDIV_HWSW		btc_phydm_modify_antdiv_hwsw;
 	BFP_BTC_GET_ANT_DET_VAL_FROM_BT		btc_get_ant_det_val_from_bt;
 	BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT	btc_get_ble_scan_type_from_bt;
 	BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT	btc_get_ble_scan_para_from_bt;
 	BFP_BTC_GET_BT_AFH_MAP_FROM_BT		btc_get_bt_afh_map_from_bt;
+
+	union {
+		#ifdef CONFIG_RTL8822B
+		struct coex_dm_8822b_1ant	coex_dm_8822b_1ant;
+		struct coex_dm_8822b_2ant	coex_dm_8822b_2ant;
+		#endif /* 8822B */
+		#ifdef CONFIG_RTL8821C
+		struct coex_dm_8821c_1ant	coex_dm_8821c_1ant;
+		struct coex_dm_8821c_2ant	coex_dm_8821c_2ant;
+		#endif /* 8821C */
+        #ifdef CONFIG_RTL8723D
+        struct coex_dm_8723d_1ant   coex_dm_8723d_1ant;
+        struct coex_dm_8723d_2ant   coex_dm_8723d_2ant;
+        #endif /* 8723D */
+	};
+
+	union {
+		#ifdef CONFIG_RTL8822B
+		struct coex_sta_8822b_1ant	coex_sta_8822b_1ant;
+		struct coex_sta_8822b_2ant	coex_sta_8822b_2ant;
+		#endif /* 8822B */
+		#ifdef CONFIG_RTL8821C
+		struct coex_sta_8821c_1ant	coex_sta_8821c_1ant;
+		struct coex_sta_8821c_2ant	coex_sta_8821c_2ant;
+		#endif /* 8821C */
+        #ifdef CONFIG_RTL8723D
+        struct coex_sta_8723d_1ant  coex_sta_8723d_1ant;
+        struct coex_sta_8723d_2ant  coex_sta_8723d_2ant;
+        #endif /* 8723D */
+	};
+
+	union {
+		#ifdef CONFIG_RTL8822B
+		struct rfe_type_8822b_1ant	rfe_type_8822b_1ant;
+		struct rfe_type_8822b_2ant	rfe_type_8822b_2ant;
+		#endif /* 8822B */
+		#ifdef CONFIG_RTL8821C
+		struct rfe_type_8821c_1ant	rfe_type_8821c_1ant;
+		struct rfe_type_8821c_2ant	rfe_type_8821c_2ant;
+		#endif /* 8821C */
+	};
+
+	union {
+		#ifdef CONFIG_RTL8822B
+		struct wifi_link_info_8822b_1ant	wifi_link_info_8822b_1ant;
+		struct wifi_link_info_8822b_2ant	wifi_link_info_8822b_2ant;
+		#endif /* 8822B */
+		#ifdef CONFIG_RTL8821C
+		struct wifi_link_info_8821c_1ant	wifi_link_info_8821c_1ant;
+		struct wifi_link_info_8821c_2ant	wifi_link_info_8821c_2ant;
+		#endif /* 8821C */
+	};
+
 };
 typedef struct btc_coexist *PBTC_COEXIST;
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/mp_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/mp_precomp.h
index b7402aac5583..c4f599391d2a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/mp_precomp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/mp_precomp.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -22,6 +23,7 @@
 
 #ifdef PLATFORM_LINUX
 #define rsprintf snprintf
+#define rstrncat(dst, src, src_size) strncat(dst, src, src_size)
 #elif defined(PLATFORM_WINDOWS)
 #define rsprintf sprintf_s
 #endif
@@ -59,27 +61,73 @@ extern u4Byte GLBtcDbgType[];
 #define HS_SUPPORT		0
 #endif
 
-#include "halbtcoutsrc.h"
+/* for wifi only mode */
+#include "hal_btcoex_wifionly.h"
+
+#ifdef CONFIG_BT_COEXIST
+#define BTC_BTINFO_LENGTH_MAX 10
+
+struct wifi_only_cfg;
+struct btc_coexist;
+
+#ifdef CONFIG_RTL8192E
 #include "halbtc8192e1ant.h"
 #include "halbtc8192e2ant.h"
+#endif
+
+#ifdef CONFIG_RTL8723B
+#include "halbtc8723bwifionly.h"
 #include "halbtc8723b1ant.h"
 #include "halbtc8723b2ant.h"
+#endif
+
+#ifdef CONFIG_RTL8812A
 #include "halbtc8812a1ant.h"
 #include "halbtc8812a2ant.h"
+#endif
+
+#ifdef CONFIG_RTL8821A
 #include "halbtc8821a1ant.h"
 #include "halbtc8821a2ant.h"
+#endif
+
+#ifdef CONFIG_RTL8703B
 #include "halbtc8703b1ant.h"
+#endif
+
+#ifdef CONFIG_RTL8723D
 #include "halbtc8723d1ant.h"
 #include "halbtc8723d2ant.h"
+#endif
+
+#ifdef CONFIG_RTL8822B
+#include "halbtc8822bwifionly.h"
 #include "halbtc8822b1ant.h"
 #include "halbtc8822b2ant.h"
+#endif
+
+#ifdef CONFIG_RTL8821C
+#include "halbtc8821cwifionly.h"
 #include "halbtc8821c1ant.h"
 #include "halbtc8821c2ant.h"
+#endif
 
-/* for wifi only mode */
-#include "hal_btcoex_wifionly.h"
+#include "halbtcoutsrc.h"
+
+#else /* CONFIG_BT_COEXIST */
+
+#ifdef CONFIG_RTL8723B
 #include "halbtc8723bwifionly.h"
+#endif
+
+#ifdef CONFIG_RTL8822B
 #include "halbtc8822bwifionly.h"
+#endif
+
+#ifdef CONFIG_RTL8821C
 #include "halbtc8821cwifionly.h"
+#endif
+
+#endif /* CONFIG_BT_COEXIST */
 
 #endif /*  __MP_PRECOMP_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/efuse_mask.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/efuse_mask.h
index 82705690d93e..e17bd45b6185 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/efuse_mask.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/efuse_mask.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -13,7 +14,7 @@
  *
  *****************************************************************************/
 
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#ifdef CONFIG_USB_HCI
 
 	#if defined(CONFIG_RTL8188E)
 		#include "rtl8188e/HalEfuseMask8188E_USB.h"
@@ -51,6 +52,10 @@
 		#include "rtl8188f/HalEfuseMask8188F_USB.h"
 	#endif
 
+	#if defined(CONFIG_RTL8188GTV)
+		#include "rtl8188gtv/HalEfuseMask8188GTV_USB.h"
+	#endif
+
 	#if defined(CONFIG_RTL8822B)
 		#include "rtl8822b/HalEfuseMask8822B_USB.h"
 	#endif
@@ -58,8 +63,17 @@
 	#if defined(CONFIG_RTL8821C)
 		#include "rtl8821c/HalEfuseMask8821C_USB.h"
 	#endif
+	
+	#if defined(CONFIG_RTL8710B)
+		#include "rtl8710b/HalEfuseMask8710B_USB.h"
+	#endif
+	
+	#if defined(CONFIG_RTL8192F)
+		#include "rtl8192f/HalEfuseMask8192F_USB.h"
+	#endif
+#endif /*CONFIG_USB_HCI*/
 
-#elif DEV_BUS_TYPE == RT_PCI_INTERFACE
+#ifdef CONFIG_PCI_HCI
 
 	#if defined(CONFIG_RTL8188E)
 		#include "rtl8188e/HalEfuseMask8188E_PCIE.h"
@@ -99,7 +113,11 @@
 		#include "rtl8821c/HalEfuseMask8821C_PCIE.h"
 	#endif
 
-#elif DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	#if defined(CONFIG_RTL8192F)
+		#include "rtl8192f/HalEfuseMask8192F_PCIE.h"
+	#endif
+#endif /*CONFIG_PCI_HCI*/
+#ifdef CONFIG_SDIO_HCI
 	#if defined(CONFIG_RTL8723B)
 		#include "rtl8723b/HalEfuseMask8723B_SDIO.h"
 	#endif
@@ -116,6 +134,10 @@
 		#include "rtl8188f/HalEfuseMask8188F_SDIO.h"
 	#endif
 
+	#if defined(CONFIG_RTL8188GTV)
+		#include "rtl8188gtv/HalEfuseMask8188GTV_SDIO.h"
+	#endif
+
 	#if defined(CONFIG_RTL8723D)
 		#include "rtl8723d/HalEfuseMask8723D_SDIO.h"
 	#endif
@@ -135,4 +157,9 @@
 	#if defined(CONFIG_RTL8822B)
 		#include "rtl8822b/HalEfuseMask8822B_SDIO.h"
 	#endif
-#endif
+
+	#if defined(CONFIG_RTL8192F)
+		#include "rtl8192f/HalEfuseMask8192F_SDIO.h"
+	#endif
+
+#endif /*CONFIG_SDIO_HCI*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c
index 0ad1d6c75852..43e61c274204 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.h
index 8f97872f8e32..6fb951e001a1 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c
index bc40b1c8f5d4..a71b53063244 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.h
index d4b818797a99..349f871485b3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c
index a461d63bc3fb..53eecade5afc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.h
index 61cf1f3d730a..e3631f84ccac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/efuse/rtl8723d/HalEfuseMask8723D_USB.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex.c
index 3717e3d2a2ba..f943290bf914 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -71,13 +72,14 @@ const char *const GLBtcWifiBwString[] = {
 	"11bg",
 	"HT20",
 	"HT40",
-	"HT80",
-	"HT160"
+	"VHT80",
+	"VHT160"
 };
 
 const char *const GLBtcWifiFreqString[] = {
 	"2.4G",
-	"5G"
+	"5G",
+	"2.4G+5G"
 };
 
 const char *const GLBtcIotPeerString[] = {
@@ -174,10 +176,11 @@ typedef enum _bt_op_code {
 	BT_OP_GET_BT_COEX_SUPPORTED_FEATURE		= 0x2a,
 	BT_OP_GET_BT_COEX_SUPPORTED_VERSION		= 0x2b,
 	BT_OP_GET_BT_ANT_DET_VAL				= 0x2c,
-	BT_OP_GET_BT_BLE_SCAN_PARA				= 0x2d,
-	BT_OP_GET_BT_BLE_SCAN_TYPE				= 0x2e,
+	BT_OP_GET_BT_BLE_SCAN_TYPE				= 0x2d,
+	BT_OP_GET_BT_BLE_SCAN_PARA				= 0x2e,
 	BT_OP_GET_BT_DEVICE_INFO				= 0x30,
 	BT_OP_GET_BT_FORBIDDEN_SLOT_VAL			= 0x31,
+	BT_OP_SET_BT_LANCONSTRAIN_LEVEL			= 0x32,
 	BT_OP_MAX
 } BT_OP_CODE;
 
@@ -614,6 +617,112 @@ u32 halbtcoutsrc_GetWifiLinkStatus(PBTC_COEXIST pBtCoexist)
 	return retVal;
 }
 
+struct btc_wifi_link_info halbtcoutsrc_getwifilinkinfo(PBTC_COEXIST pBtCoexist)
+{
+	u8 n_assoc_iface = 0, i =0, mcc_en = _FALSE;
+	PADAPTER adapter = NULL;
+	PADAPTER iface = NULL;
+	PADAPTER sta_iface = NULL, p2p_iface = NULL, ap_iface = NULL;
+	BTC_LINK_MODE btc_link_moe = BTC_LINK_MAX;
+	struct dvobj_priv *dvobj = NULL;
+	struct mlme_ext_priv *mlmeext = NULL;
+	struct btc_wifi_link_info wifi_link_info;
+
+	adapter = (PADAPTER)pBtCoexist->Adapter;
+	dvobj = adapter_to_dvobj(adapter);
+	n_assoc_iface = rtw_mi_get_assoc_if_num(adapter);
+
+	/* init value */
+	wifi_link_info.link_mode = BTC_LINK_NONE;
+	wifi_link_info.sta_center_channel = 0;
+	wifi_link_info.p2p_center_channel = 0;
+	wifi_link_info.bany_client_join_go = _FALSE;
+	wifi_link_info.benable_noa = _FALSE;
+	wifi_link_info.bhotspot = _FALSE;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+		
+		mlmeext = &iface->mlmeextpriv;
+		if (MLME_IS_GO(iface)) {
+			wifi_link_info.link_mode = BTC_LINK_ONLY_GO;
+			wifi_link_info.p2p_center_channel =
+				rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+			p2p_iface	 = iface;
+			if (rtw_linked_check(iface))
+				wifi_link_info.bany_client_join_go = _TRUE;
+		} else if (MLME_IS_GC(iface)) {
+			wifi_link_info.link_mode = BTC_LINK_ONLY_GC;
+			wifi_link_info.p2p_center_channel =
+				rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+			p2p_iface = iface;
+		} else if (MLME_IS_AP(iface)) {
+			wifi_link_info.link_mode = BTC_LINK_ONLY_AP;
+			ap_iface = iface;
+			wifi_link_info.p2p_center_channel =
+				rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+		} else if (MLME_IS_STA(iface) && rtw_linked_check(iface)) {
+			wifi_link_info.link_mode = BTC_LINK_ONLY_STA;
+			wifi_link_info.sta_center_channel =
+				rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
+			sta_iface = iface;
+		}
+	}
+
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(adapter)) {
+		if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
+			mcc_en = _TRUE;
+	}
+#endif/* CONFIG_MCC_MODE */
+
+	if (n_assoc_iface == 0) {
+		wifi_link_info.link_mode = BTC_LINK_NONE;
+	} else if (n_assoc_iface == 1) {
+		/* by pass */
+	} else if (n_assoc_iface == 2) {	
+		if (sta_iface && p2p_iface) {
+			u8 band_sta = sta_iface->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
+			u8 band_p2p = p2p_iface->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
+			if (band_sta == band_p2p) {
+				switch (band_sta) {
+				case BAND_ON_2_4G:
+					if (MLME_IS_GO(p2p_iface))
+						wifi_link_info.link_mode =
+							mcc_en == _TRUE ?  BTC_LINK_2G_MCC_GO_STA : BTC_LINK_2G_SCC_GO_STA;
+					else if (MLME_IS_GC(p2p_iface))
+						wifi_link_info.link_mode =
+							mcc_en == _TRUE ?  BTC_LINK_2G_MCC_GC_STA : BTC_LINK_2G_SCC_GC_STA;
+					break;
+				case BAND_ON_5G:
+					if (MLME_IS_GO(p2p_iface))
+						wifi_link_info.link_mode =
+							mcc_en == _TRUE ?  BTC_LINK_5G_MCC_GO_STA : BTC_LINK_5G_SCC_GO_STA;
+					else if (MLME_IS_GC(p2p_iface))
+						wifi_link_info.link_mode =
+							mcc_en == _TRUE ?  BTC_LINK_5G_MCC_GC_STA : BTC_LINK_5G_SCC_GC_STA;
+					break;
+				default:
+					break;
+				}
+			} else {
+				if (MLME_IS_GO(p2p_iface))
+					wifi_link_info.link_mode = BTC_LINK_25G_MCC_GO_STA;
+				else if (MLME_IS_GC(p2p_iface))
+					wifi_link_info.link_mode = BTC_LINK_25G_MCC_GC_STA;
+			}
+		}
+	} else {
+		if (pBtCoexist->board_info.btdm_ant_num == 1)
+			RTW_ERR("%s do not support n_assoc_iface > 2 (ant_num == 1)", __func__);
+	}
+
+	return wifi_link_info;
+}
+
+
 static void _btmpoper_timer_hdl(void *p)
 {
 	if (GLBtcBtMpRptWait == _TRUE) {
@@ -899,6 +1008,7 @@ u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
 	PADAPTER padapter;
 	PHAL_DATA_TYPE pHalData;
 	struct mlme_ext_priv *mlmeext;
+	struct btc_wifi_link_info *wifi_link_info;
 	u8 bSoftApExist, bVwifiExist;
 	u8 *pu8;
 	s32 *pS4Tmp;
@@ -922,6 +1032,7 @@ u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
 	pU4Tmp = (u32 *)pOutBuf;
 	pU1Tmp = (u8 *)pOutBuf;
 	pU2Tmp = (u16*)pOutBuf;
+	wifi_link_info = (struct btc_wifi_link_info *)pOutBuf;
 	ret = _TRUE;
 
 	switch (getType) {
@@ -1018,6 +1129,11 @@ u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
 #endif
 		break;
 
+	case BTC_GET_BL_WIFI_LW_PWR_STATE:
+		/* return false due to coex do not run during 32K */
+		*pu8 = FALSE;
+		break;
+
 	case BTC_GET_S4_WIFI_RSSI:
 		*pS4Tmp = halbtcoutsrc_GetWifiRssi(padapter);
 		break;
@@ -1072,7 +1188,9 @@ u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
 	case BTC_GET_U4_WIFI_LINK_STATUS:
 		*pU4Tmp = halbtcoutsrc_GetWifiLinkStatus(pBtCoexist);
 		break;
-
+	case BTC_GET_BL_WIFI_LINK_INFO:
+		*wifi_link_info = halbtcoutsrc_getwifilinkinfo(pBtCoexist);
+		break;
 	case BTC_GET_U4_BT_PATCH_VER:
 		*pU4Tmp = halbtcoutsrc_GetBtPatchVer(pBtCoexist);
 		break;
@@ -1188,6 +1306,30 @@ u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
 	return ret;
 }
 
+u16 halbtcoutsrc_LnaConstrainLvl(void *pBtcContext, u8 *lna_constrain_level)
+{
+	PBTC_COEXIST pBtCoexist;
+	u16 ret = BT_STATUS_BT_OP_SUCCESS;
+
+	pBtCoexist = (PBTC_COEXIST)pBtcContext;
+
+	if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
+		_irqL irqL;
+		u8 op_code;
+
+		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+
+		ret = _btmpoper_cmd(pBtCoexist, BT_OP_SET_BT_LANCONSTRAIN_LEVEL, 0, lna_constrain_level, 1);
+
+		_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
+	} else { 
+		ret = BT_STATUS_NOT_IMPLEMENT;
+		RTW_INFO("%s halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == FALSE\n", __func__);
+	}
+
+	return ret;
+}
+
 u8 halbtcoutsrc_Set(void *pBtcContext, u8 setType, void *pInBuf)
 {
 	PBTC_COEXIST pBtCoexist;
@@ -1388,6 +1530,9 @@ u8 halbtcoutsrc_Set(void *pBtcContext, u8 setType, void *pInBuf)
 		ret = _FALSE;
 #endif
 		break;
+	case BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL:
+		halbtcoutsrc_LnaConstrainLvl(pBtCoexist, pu8);
+		break;
 	/* ===================== */
 	default:
 		ret = _FALSE;
@@ -1640,13 +1785,101 @@ void halbtcoutsrc_DisplayWifiStatus(PBTC_COEXIST pBtCoexist)
 	u8			wifiChnl = 0, wifiP2PChnl = 0, nScanAPNum = 0, FwPSState;
 	u32			iqk_cnt_total = 0, iqk_cnt_ok = 0, iqk_cnt_fail = 0;
 	u16			wifiBcnInterval = 0;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
+	struct btc_wifi_link_info wifi_link_info;
+
+	wifi_link_info = halbtcoutsrc_getwifilinkinfo(pBtCoexist);
+
+	switch (wifi_link_info.link_mode) {
+		case BTC_LINK_NONE:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"None", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = hal->current_channel > 14 ?  BTC_FREQ_5G : BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_ONLY_GO:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"ONLY_GO", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = hal->current_channel > 14 ?  BTC_FREQ_5G : BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_ONLY_GC:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"ONLY_GC", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = hal->current_channel > 14 ?  BTC_FREQ_5G : BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_ONLY_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"ONLY_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = hal->current_channel > 14 ?  BTC_FREQ_5G : BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_ONLY_AP:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"ONLY_AP", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = hal->current_channel > 14 ?  BTC_FREQ_5G : BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_2G_MCC_GO_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"24G_MCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_5G_MCC_GO_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"5G_MCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_5G;
+			break;
+		case BTC_LINK_25G_MCC_GO_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"2BANDS_MCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_25G;
+			break;
+		case BTC_LINK_2G_MCC_GC_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"24G_MCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_5G_MCC_GC_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"5G_MCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_5G;
+			break;
+		case BTC_LINK_25G_MCC_GC_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"2BANDS_MCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_25G;
+			break;
+		case BTC_LINK_2G_SCC_GO_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"24G_SCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_5G_SCC_GO_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"5G_SCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_5G;
+			break;
+		case BTC_LINK_2G_SCC_GC_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"24G_SCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_2_4G;
+			break;
+		case BTC_LINK_5G_SCC_GC_STA:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"5G_SCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = BTC_FREQ_5G;
+			break;
+		default:
+			CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
+					"UNKNOWN", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
+			wifiFreq = hal->current_channel > 14 ?  BTC_FREQ_5G : BTC_FREQ_2_4G;
+			break;
+	}
+
+	CL_PRINTF(cliBuf);
 
 	wifiLinkStatus = halbtcoutsrc_GetWifiLinkStatus(pBtCoexist);
-	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d (mcc+2band = %d)", "STA/vWifi/HS/p2pGo/p2pGc",
+	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d", "STA/vWifi/HS/p2pGo/p2pGc",
 		((wifiLinkStatus & WIFI_STA_CONNECTED) ? 1 : 0), ((wifiLinkStatus & WIFI_AP_CONNECTED) ? 1 : 0),
 		((wifiLinkStatus & WIFI_HS_CONNECTED) ? 1 : 0), ((wifiLinkStatus & WIFI_P2P_GO_CONNECTED) ? 1 : 0),
-		((wifiLinkStatus & WIFI_P2P_GC_CONNECTED) ? 1 : 0),
-		halbtcoutsrc_IsDualBandConnected(padapter) ? 1 : 0);
+		((wifiLinkStatus & WIFI_P2P_GC_CONNECTED) ? 1 : 0));
 	CL_PRINTF(cliBuf);
 
 	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
@@ -1670,16 +1903,14 @@ void halbtcoutsrc_DisplayWifiStatus(PBTC_COEXIST pBtCoexist)
 	}
 
 	pBtCoexist->btc_get(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
-	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U1_WIFI_DOT11_CHNL, &wifiChnl);
 	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U2_BEACON_PERIOD, &wifiBcnInterval);
-	if ((wifiLinkStatus & WIFI_P2P_GO_CONNECTED) || (wifiLinkStatus & WIFI_P2P_GC_CONNECTED)) 
-		pBtCoexist->btc_get(pBtCoexist, BTC_GET_U1_WIFI_P2P_CHNL, &wifiP2PChnl);	
+	wifiChnl = wifi_link_info.sta_center_channel;
+	wifiP2PChnl = wifi_link_info.p2p_center_channel;
 
 	CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dBm/ %d/ %d/ %d", "RSSI/ STA_Chnl/ P2P_Chnl/ BI",
 		wifiRssi-100, wifiChnl, wifiP2PChnl, wifiBcnInterval);
 	CL_PRINTF(cliBuf);
 
-	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifiFreq);
 	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
 	pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
 	pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
@@ -2212,11 +2443,12 @@ u32 halbtcoutsrc_GetBleScanParaFromBt(void *pBtcContext, u8 scanType)
 		u8 op_code;
 		u8 status;
 		
+		buf[0] = scanType;
 
 		_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
 
 		op_code = BT_OP_GET_BT_BLE_SCAN_PARA;
-		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
+		status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 1);
 		if (status == BT_STATUS_BT_OP_SUCCESS)
 			data = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
 		else
@@ -2320,6 +2552,16 @@ u32 halbtcoutsrc_GetPhydmVersion(void *pBtcContext)
 #ifdef CONFIG_RTL8821C
 	return RELEASE_VERSION_8821C;
 #endif
+
+#ifdef CONFIG_RTL8192F
+	return RELEASE_VERSION_8192F;
+#endif
+}
+
+u32 halbtcoutsrc_SetAtomic (void *btc_ctx, u32 *target, u32 val)
+{
+	*target = val;
+	return _SUCCESS;
 }
 
 void halbtcoutsrc_phydm_modify_AntDiv_HwSw(void *pBtcContext, u8 is_hw)
@@ -2343,7 +2585,7 @@ u32 halbtcoutsrc_phydm_query_PHY_counter(void *pBtcContext, u8 info_type)
 
 /* switch to #if 0 in case the phydm version does not provide the function */
 #if 1
-	return phydm_cmn_info_query((struct PHY_DM_STRUCT *)pBtCoexist->odm_priv, (enum phydm_info_query_e)info_type);
+	return phydm_cmn_info_query((struct dm_struct *)pBtCoexist->odm_priv, (enum phydm_info_query)info_type);
 #else
 	return 0;
 #endif
@@ -2507,6 +2749,7 @@ void EXhalbtcoutsrc_AntInfoSetting(void *padapter)
 	}
 
 	pBtCoexist->board_info.customerID = RT_CID_DEFAULT;
+	pBtCoexist->board_info.customer_id = RT_CID_DEFAULT;
 
 	/* set default antenna position to main  port */
 	pBtCoexist->board_info.btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
@@ -2576,9 +2819,10 @@ u8 EXhalbtcoutsrc_InitlizeVariables(void *padapter)
 	pBtCoexist->btc_get_ble_scan_para_from_bt = halbtcoutsrc_GetBleScanParaFromBt;
 	pBtCoexist->btc_get_bt_afh_map_from_bt = halbtcoutsrc_GetBtAFHMapFromBt;
 	pBtCoexist->btc_get_bt_phydm_version = halbtcoutsrc_GetPhydmVersion;
+	pBtCoexist->btc_set_atomic= halbtcoutsrc_SetAtomic;
 	pBtCoexist->btc_phydm_modify_RA_PCR_threshold = halbtcoutsrc_phydm_modify_RA_PCR_threshold;
 	pBtCoexist->btc_phydm_query_PHY_counter = halbtcoutsrc_phydm_query_PHY_counter;
-	pBtCoexist->btc_phydm_modify_ANTDIV_HwSw = halbtcoutsrc_phydm_modify_AntDiv_HwSw;
+	pBtCoexist->btc_phydm_modify_antdiv_hwsw = halbtcoutsrc_phydm_modify_AntDiv_HwSw;
 
 	pBtCoexist->cli_buf = &GLBtcDbgBuf[0];
 
@@ -2618,44 +2862,56 @@ void EXhalbtcoutsrc_PowerOnSetting(PBTC_COEXIST pBtCoexist)
 	pHalData = GET_HAL_DATA((PADAPTER)pBtCoexist->Adapter);
 
 	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_power_on_setting(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_power_on_setting(pBtCoexist);
+#endif
 	}
 
-	if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_power_on_setting(pBtCoexist);
 	}
+#endif
 
-	if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_power_on_setting(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_power_on_setting(pBtCoexist);
 	}
+#endif
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821A
+	else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_power_on_setting(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_power_on_setting(pBtCoexist);
 	}
+#endif
 
-	if ((IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
+#ifdef CONFIG_RTL8822B
+	else if ((IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_power_on_setting(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_power_on_setting(pBtCoexist);
 	}
+#endif
 
-	if ((IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
+#ifdef CONFIG_RTL8821C
+	else if ((IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_power_on_setting(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_power_on_setting(pBtCoexist);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_PreLoadFirmware(PBTC_COEXIST pBtCoexist)
@@ -2666,25 +2922,31 @@ void EXhalbtcoutsrc_PreLoadFirmware(PBTC_COEXIST pBtCoexist)
 	pBtCoexist->statistics.cnt_pre_load_firmware++;
 
 	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_pre_load_firmware(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_pre_load_firmware(pBtCoexist);
+#endif
 	}
 
-	if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_pre_load_firmware(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_pre_load_firmware(pBtCoexist);
 	}
+#endif
 
-	if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_pre_load_firmware(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_pre_load_firmware(pBtCoexist);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_init_hw_config(PBTC_COEXIST pBtCoexist, u8 bWifiOnly)
@@ -2695,57 +2957,74 @@ void EXhalbtcoutsrc_init_hw_config(PBTC_COEXIST pBtCoexist, u8 bWifiOnly)
 	pBtCoexist->statistics.cnt_init_hw_config++;
 
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_init_hw_config(pBtCoexist, bWifiOnly);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_init_hw_config(pBtCoexist, bWifiOnly);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_init_hw_config(pBtCoexist, bWifiOnly);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_init_hw_config(pBtCoexist, bWifiOnly);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_init_hw_config(pBtCoexist, bWifiOnly);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_init_hw_config(pBtCoexist, bWifiOnly);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_init_hw_config(pBtCoexist, bWifiOnly);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_init_hw_config(pBtCoexist, bWifiOnly);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_init_hw_config(pBtCoexist, bWifiOnly);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_init_hw_config(pBtCoexist, bWifiOnly);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_init_hw_config(pBtCoexist, bWifiOnly);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_init_hw_config(pBtCoexist, bWifiOnly);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_init_hw_config(pBtCoexist, bWifiOnly);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_init_hw_config(pBtCoexist, bWifiOnly);
-		#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-		rtw_hal_set_default_port_id_cmd(pBtCoexist->Adapter, 0);
-		rtw_hal_set_wifi_port_id_cmd(pBtCoexist->Adapter);
-		#endif
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_init_hw_config(pBtCoexist, bWifiOnly);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_init_hw_config(pBtCoexist, bWifiOnly);
-		#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-		rtw_hal_set_default_port_id_cmd(pBtCoexist->Adapter, 0);
-		rtw_hal_set_wifi_port_id_cmd(pBtCoexist->Adapter);
-		#endif
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_init_coex_dm(PBTC_COEXIST pBtCoexist)
@@ -2756,49 +3035,74 @@ void EXhalbtcoutsrc_init_coex_dm(PBTC_COEXIST pBtCoexist)
 	pBtCoexist->statistics.cnt_init_coex_dm++;
 
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_init_coex_dm(pBtCoexist);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_init_coex_dm(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_init_coex_dm(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_init_coex_dm(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_init_coex_dm(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_init_coex_dm(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_init_coex_dm(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_init_coex_dm(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_init_coex_dm(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_init_coex_dm(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_init_coex_dm(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_init_coex_dm(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_init_coex_dm(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_init_coex_dm(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_init_coex_dm(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_init_coex_dm(pBtCoexist);
 	}
+#endif
 
 	pBtCoexist->initilized = _TRUE;
 }
@@ -2826,50 +3130,74 @@ void EXhalbtcoutsrc_ips_notify(PBTC_COEXIST pBtCoexist, u8 type)
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
 
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_ips_notify(pBtCoexist, ipsType);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_ips_notify(pBtCoexist, ipsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_ips_notify(pBtCoexist, ipsType);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_ips_notify(pBtCoexist, ipsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_ips_notify(pBtCoexist, ipsType);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_ips_notify(pBtCoexist, ipsType);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_ips_notify(pBtCoexist, ipsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_ips_notify(pBtCoexist, ipsType);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_ips_notify(pBtCoexist, ipsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_ips_notify(pBtCoexist, ipsType);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_ips_notify(pBtCoexist, ipsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_ips_notify(pBtCoexist, ipsType);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_ips_notify(pBtCoexist, ipsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_ips_notify(pBtCoexist, ipsType);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_ips_notify(pBtCoexist, ipsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_ips_notify(pBtCoexist, ipsType);
 	}
-
+#endif
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
@@ -2894,49 +3222,74 @@ void EXhalbtcoutsrc_lps_notify(PBTC_COEXIST pBtCoexist, u8 type)
 	}
 
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_lps_notify(pBtCoexist, lpsType);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_lps_notify(pBtCoexist, lpsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_lps_notify(pBtCoexist, lpsType);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_lps_notify(pBtCoexist, lpsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_lps_notify(pBtCoexist, lpsType);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_lps_notify(pBtCoexist, lpsType);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_lps_notify(pBtCoexist, lpsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_lps_notify(pBtCoexist, lpsType);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_lps_notify(pBtCoexist, lpsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_lps_notify(pBtCoexist, lpsType);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_lps_notify(pBtCoexist, lpsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_lps_notify(pBtCoexist, lpsType);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_lps_notify(pBtCoexist, lpsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_lps_notify(pBtCoexist, lpsType);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_lps_notify(pBtCoexist, lpsType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_lps_notify(pBtCoexist, lpsType);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_scan_notify(PBTC_COEXIST pBtCoexist, u8 type)
@@ -2961,49 +3314,74 @@ void EXhalbtcoutsrc_scan_notify(PBTC_COEXIST pBtCoexist, u8 type)
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
 
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_scan_notify(pBtCoexist, scanType);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_scan_notify(pBtCoexist, scanType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_scan_notify(pBtCoexist, scanType);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_scan_notify(pBtCoexist, scanType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_scan_notify(pBtCoexist, scanType);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_scan_notify(pBtCoexist, scanType);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_scan_notify(pBtCoexist, scanType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_scan_notify(pBtCoexist, scanType);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_scan_notify(pBtCoexist, scanType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_scan_notify(pBtCoexist, scanType);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_scan_notify(pBtCoexist, scanType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_scan_notify(pBtCoexist, scanType);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_scan_notify(pBtCoexist, scanType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_scan_notify(pBtCoexist, scanType);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_scan_notify(pBtCoexist, scanType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_scan_notify(pBtCoexist, scanType);
 	}
+#endif
 
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
@@ -3048,58 +3426,84 @@ void EXhalbtcoutsrc_connect_notify(PBTC_COEXIST pBtCoexist, u8 assoType)
 	
 	/* All notify is called in cmd thread, don't need to leave low power again
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
-
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_connect_notify(pBtCoexist, assoType);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_connect_notify(pBtCoexist, assoType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_connect_notify(pBtCoexist, assoType);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_connect_notify(pBtCoexist, assoType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_connect_notify(pBtCoexist, assoType);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_connect_notify(pBtCoexist, assoType);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_connect_notify(pBtCoexist, assoType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_connect_notify(pBtCoexist, assoType);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_connect_notify(pBtCoexist, assoType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_connect_notify(pBtCoexist, assoType);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_connect_notify(pBtCoexist, assoType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_connect_notify(pBtCoexist, assoType);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_connect_notify(pBtCoexist, assoType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_connect_notify(pBtCoexist, assoType);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_connect_notify(pBtCoexist, assoType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_connect_notify(pBtCoexist, assoType);
 	}
+#endif
 
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
 void EXhalbtcoutsrc_media_status_notify(PBTC_COEXIST pBtCoexist, RT_MEDIA_STATUS mediaStatus)
 {
-	u8 mStatus;
+	u8 mStatus = BTC_MEDIA_MAX;
+	PADAPTER adapter = (PADAPTER)pBtCoexist->Adapter;
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
 
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
@@ -3108,65 +3512,104 @@ void EXhalbtcoutsrc_media_status_notify(PBTC_COEXIST pBtCoexist, RT_MEDIA_STATUS
 	if (pBtCoexist->manual_control)
 		return;
 
-	if (RT_MEDIA_CONNECT == mediaStatus)
-		mStatus = BTC_MEDIA_CONNECT;
-	else
+	if (RT_MEDIA_CONNECT == mediaStatus) {
+		if (hal->current_band_type == BAND_ON_2_4G)
+			mStatus = BTC_MEDIA_CONNECT;
+		else if (hal->current_band_type == BAND_ON_5G)
+			mStatus = BTC_MEDIA_CONNECT_5G;
+		else {
+			mStatus = BTC_MEDIA_CONNECT;
+			RTW_ERR("%s unknow band type\n", __func__);
+		}
+	} else
 		mStatus = BTC_MEDIA_DISCONNECT;
 
 	/* All notify is called in cmd thread, don't need to leave low power again
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
-
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_media_status_notify(pBtCoexist, mStatus);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
+		/* compatible for 8821A */
+		if (mStatus == BTC_MEDIA_CONNECT_5G)
+			mStatus = BTC_MEDIA_CONNECT;
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_media_status_notify(pBtCoexist, mStatus);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_media_status_notify(pBtCoexist, mStatus);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_media_status_notify(pBtCoexist, mStatus);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_media_status_notify(pBtCoexist, mStatus);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_media_status_notify(pBtCoexist, mStatus);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_media_status_notify(pBtCoexist, mStatus);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_media_status_notify(pBtCoexist, mStatus);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_media_status_notify(pBtCoexist, mStatus);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_media_status_notify(pBtCoexist, mStatus);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		/* compatible for 8812A */
+		if (mStatus == BTC_MEDIA_CONNECT_5G)
+			mStatus = BTC_MEDIA_CONNECT;
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_media_status_notify(pBtCoexist, mStatus);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_media_status_notify(pBtCoexist, mStatus);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_media_status_notify(pBtCoexist, mStatus);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_media_status_notify(pBtCoexist, mStatus);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_media_status_notify(pBtCoexist, mStatus);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_media_status_notify(pBtCoexist, mStatus);
 	}
+#endif
 
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
 
 void EXhalbtcoutsrc_specific_packet_notify(PBTC_COEXIST pBtCoexist, u8 pktType)
 {
-	u8	packetType;
+	u8 packetType;
+	PADAPTER adapter = (PADAPTER)pBtCoexist->Adapter;
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
 
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
@@ -3185,53 +3628,88 @@ void EXhalbtcoutsrc_specific_packet_notify(PBTC_COEXIST pBtCoexist, u8 pktType)
 		return;
 	}
 
+	if (hal->current_band_type == BAND_ON_5G)
+		packetType |=  BTC_5G_BAND;
+
 	/* All notify is called in cmd thread, don't need to leave low power again
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
-
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_specific_packet_notify(pBtCoexist, packetType);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
+		/* compatible for 8821A */
+		if (hal->current_band_type == BAND_ON_5G)
+			packetType &= ~BTC_5G_BAND;
+
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_specific_packet_notify(pBtCoexist, packetType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_specific_packet_notify(pBtCoexist, packetType);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_specific_packet_notify(pBtCoexist, packetType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_specific_packet_notify(pBtCoexist, packetType);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_specific_packet_notify(pBtCoexist, packetType);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_specific_packet_notify(pBtCoexist, packetType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_specific_packet_notify(pBtCoexist, packetType);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_specific_packet_notify(pBtCoexist, packetType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_specific_packet_notify(pBtCoexist, packetType);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+		/* compatible for 8812A */
+		if (hal->current_band_type == BAND_ON_5G)
+			packetType &= ~BTC_5G_BAND;
+		
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_specific_packet_notify(pBtCoexist, packetType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_specific_packet_notify(pBtCoexist, packetType);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_specific_packet_notify(pBtCoexist, packetType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_specific_packet_notify(pBtCoexist, packetType);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_specific_packet_notify(pBtCoexist, packetType);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_specific_packet_notify(pBtCoexist, packetType);
 	}
+#endif
 
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
@@ -3245,51 +3723,75 @@ void EXhalbtcoutsrc_bt_info_notify(PBTC_COEXIST pBtCoexist, u8 *tmpBuf, u8 lengt
 
 	/* All notify is called in cmd thread, don't need to leave low power again
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
-
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
 	}
+#endif
 
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
@@ -3298,21 +3800,31 @@ void EXhalbtcoutsrc_WlFwDbgInfoNotify(PBTC_COEXIST pBtCoexist, u8* tmpBuf, u8 le
 {
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
-	
+
 	if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8703B
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_rx_rate_change_notify(PBTC_COEXIST pBtCoexist, u8 is_data_frame, u8 btc_rate_id)
@@ -3323,19 +3835,29 @@ void EXhalbtcoutsrc_rx_rate_change_notify(PBTC_COEXIST pBtCoexist, u8 is_data_fr
 	pBtCoexist->statistics.cnt_rate_id_notify++;
 
 	if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8703B
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
 	}
+#endif
 }
 
 VOID
@@ -3348,29 +3870,44 @@ EXhalbtcoutsrc_RfStatusNotify(
 		return;
 	pBtCoexist->statistics.cnt_rf_status_notify++;
 
-	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_rf_status_notify(pBtCoexist, type);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_rf_status_notify(pBtCoexist, type);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_rf_status_notify(pBtCoexist, type);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_rf_status_notify(pBtCoexist, type);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_rf_status_notify(pBtCoexist, type);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_rf_status_notify(pBtCoexist, type);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_rf_status_notify(pBtCoexist, type);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_StackOperationNotify(PBTC_COEXIST pBtCoexist, u8 type)
@@ -3404,50 +3941,77 @@ void EXhalbtcoutsrc_halt_notify(PBTC_COEXIST pBtCoexist)
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
+	pBtCoexist->statistics.cnt_halt_notify++;
+
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_halt_notify(pBtCoexist);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_halt_notify(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_halt_notify(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_halt_notify(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_halt_notify(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_halt_notify(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_halt_notify(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_halt_notify(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_halt_notify(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_halt_notify(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_halt_notify(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_halt_notify(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_halt_notify(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_halt_notify(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_halt_notify(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_halt_notify(pBtCoexist);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_SwitchBtTRxMask(PBTC_COEXIST pBtCoexist)
@@ -3466,51 +4030,77 @@ void EXhalbtcoutsrc_pnp_notify(PBTC_COEXIST pBtCoexist, u8 pnpState)
 	if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
 		return;
 
+	pBtCoexist->statistics.cnt_pnp_notify++;
+
 	/*  */
 	/* currently only 1ant we have to do the notification, */
 	/* once pnp is notified to sleep state, we have to leave LPS that we can sleep normally. */
 	/*  */
-
 	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_pnp_notify(pBtCoexist, pnpState);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_pnp_notify(pBtCoexist, pnpState);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_pnp_notify(pBtCoexist, pnpState);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_pnp_notify(pBtCoexist, pnpState);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_pnp_notify(pBtCoexist, pnpState);
-	} else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_pnp_notify(pBtCoexist, pnpState);
-		else
+	}
 #endif
+
+#ifdef CONFIG_RTL8821A
+	else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_pnp_notify(pBtCoexist, pnpState);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_pnp_notify(pBtCoexist, pnpState);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_pnp_notify(pBtCoexist, pnpState);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_pnp_notify(pBtCoexist, pnpState);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_pnp_notify(pBtCoexist, pnpState);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_pnp_notify(pBtCoexist, pnpState);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_pnp_notify(pBtCoexist, pnpState);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_pnp_notify(pBtCoexist, pnpState);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_CoexDmSwitch(PBTC_COEXIST pBtCoexist)
@@ -3522,6 +4112,7 @@ void EXhalbtcoutsrc_CoexDmSwitch(PBTC_COEXIST pBtCoexist)
 	halbtcoutsrc_LeaveLowPower(pBtCoexist);
 
 	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
 		if (pBtCoexist->board_info.btdm_ant_num == 1) {
 			pBtCoexist->stop_coex_dm = TRUE;
 			ex_halbtc8723b1ant_coex_dm_reset(pBtCoexist);
@@ -3530,7 +4121,11 @@ void EXhalbtcoutsrc_CoexDmSwitch(PBTC_COEXIST pBtCoexist)
 			ex_halbtc8723b2ant_init_coex_dm(pBtCoexist);
 			pBtCoexist->stop_coex_dm = FALSE;
 		}
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1) {
 			pBtCoexist->stop_coex_dm = TRUE;
 			ex_halbtc8723d1ant_coex_dm_reset(pBtCoexist);
@@ -3540,6 +4135,7 @@ void EXhalbtcoutsrc_CoexDmSwitch(PBTC_COEXIST pBtCoexist)
 			pBtCoexist->stop_coex_dm = FALSE;
 		}
 	}
+#endif
 
 	halbtcoutsrc_NormalLowPower(pBtCoexist);
 }
@@ -3553,53 +4149,77 @@ void EXhalbtcoutsrc_periodical(PBTC_COEXIST pBtCoexist)
 	/* Periodical should be called in cmd thread, */
 	/* don't need to leave low power again
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
-
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_periodical(pBtCoexist);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_periodical(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1) {
 			if (!halbtcoutsrc_UnderIps(pBtCoexist))
 				ex_halbtc8821a1ant_periodical(pBtCoexist);
 		}
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_periodical(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_periodical(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_periodical(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_periodical(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_periodical(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_periodical(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_periodical(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_periodical(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_periodical(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_periodical(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_periodical(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_periodical(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_periodical(pBtCoexist);
 	}
+#endif
 
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
@@ -3614,18 +4234,27 @@ void EXhalbtcoutsrc_dbg_control(PBTC_COEXIST pBtCoexist, u8 opCode, u8 opLen, u8
 	/* This function doesn't be called yet, */
 	/* default no need to leave low power to avoid deadlock
 	*	halbtcoutsrc_LeaveLowPower(pBtCoexist); */
-
 	if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8192E
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_dbg_control(pBtCoexist, opCode, opLen, pData);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
-	} else if(IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter))
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter))
 		if(pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
+#endif
 
 	/*	halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
@@ -3815,49 +4444,74 @@ void EXhalbtcoutsrc_DisplayBtCoexInfo(PBTC_COEXIST pBtCoexist)
 	halbtcoutsrc_EnterPwrLock(pBtCoexist);
 
 	if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
-#if 0
-		if (halbtcoutsrc_IsCsrBtCoex(pBtCoexist) == _TRUE)
-			ex_halbtc8821aCsr2ant_display_coex_info(pBtCoexist);
-		else
-#endif
+#ifdef CONFIG_RTL8821A
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821a2ant_display_coex_info(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821a1ant_display_coex_info(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8723B
+	else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723b2ant_display_coex_info(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_display_coex_info(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8703B
+	else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8703b1ant_display_coex_info(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8723D
+	else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8723d2ant_display_coex_info(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723d1ant_display_coex_info(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8192E
+	else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8192e2ant_display_coex_info(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8192e1ant_display_coex_info(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8812A
+	else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_display_coex_info(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8812a1ant_display_coex_info(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8822B
+	else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_display_coex_info(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_display_coex_info(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+	}
+#endif
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_display_coex_info(pBtCoexist);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_display_coex_info(pBtCoexist);
 	}
+#endif
 
 	halbtcoutsrc_ExitPwrLock(pBtCoexist);
 
@@ -3872,13 +4526,10 @@ void EXhalbtcoutsrc_DisplayAntDetection(PBTC_COEXIST pBtCoexist)
 	halbtcoutsrc_LeaveLowPower(pBtCoexist);
 
 	if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8723B
 		if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8723b1ant_display_ant_detection(pBtCoexist);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
-		if (pBtCoexist->board_info.btdm_ant_num == 2)
-			ex_halbtc8821c2ant_display_ant_detection(pBtCoexist);
-		else if (pBtCoexist->board_info.btdm_ant_num == 1)
-			ex_halbtc8821c1ant_display_ant_detection(pBtCoexist);
+#endif
 	}
 
 	halbtcoutsrc_NormalLowPower(pBtCoexist);
@@ -3886,10 +4537,12 @@ void EXhalbtcoutsrc_DisplayAntDetection(PBTC_COEXIST pBtCoexist)
 
 void ex_halbtcoutsrc_pta_off_on_notify(PBTC_COEXIST pBtCoexist, u8 bBTON)
 {
+#ifdef CONFIG_RTL8812A
 	if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8812a2ant_pta_off_on_notify(pBtCoexist, (bBTON == _TRUE) ? BTC_BT_ON : BTC_BT_OFF);
 	}
+#endif
 }
 
 void EXhalbtcoutsrc_set_rfe_type(u8 type)
@@ -3921,16 +4574,22 @@ void EXhalbtcoutsrc_switchband_notify(struct btc_coexist *pBtCoexist, u8 type)
 	/* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
 
 	if(IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
+#ifdef CONFIG_RTL8822B
 		if(pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8822b1ant_switchband_notify(pBtCoexist, type);
 		else if(pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8822b2ant_switchband_notify(pBtCoexist, type);
-	} else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
+#endif
+	}
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
 		if (pBtCoexist->board_info.btdm_ant_num == 2)
 			ex_halbtc8821c2ant_switchband_notify(pBtCoexist, type);
 		else if (pBtCoexist->board_info.btdm_ant_num == 1)
 			ex_halbtc8821c1ant_switchband_notify(pBtCoexist, type);
 	}
+#endif
 
 	/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
 }
@@ -4482,7 +5141,7 @@ void hal_btcoex_SuspendNotify(PADAPTER padapter, u8 state)
 	case BTCOEX_SUSPEND_STATE_RESUME:
 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
 		/* re-download FW after resume, inform WL FW port number */
-		rtw_hal_set_wifi_port_id_cmd(GLBtCoexist.Adapter);
+		rtw_hal_set_wifi_btc_port_id_cmd(GLBtCoexist.Adapter);
 #endif
 		EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_WAKE_UP);
 		break;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex_wifionly.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex_wifionly.c
index 33555656aac5..90affea52b1e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex_wifionly.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_btcoex_wifionly.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -12,9 +13,12 @@
  * more details.
  *
  *****************************************************************************/
-#include "btc/mp_precomp.h"
 #include <hal_btcoex_wifionly.h>
 
+#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
+
+#include "btc/mp_precomp.h"
+
 struct  wifi_only_cfg GLBtCoexistWifiOnly;
 
 void halwifionly_write1byte(PVOID pwifionlyContext, u32 RegAddr, u8 Data)
@@ -109,10 +113,16 @@ void hal_btcoex_wifionly_switchband_notify(PADAPTER padapter)
 	if (pHalData->current_band_type == BAND_ON_5G)
 		is_5g = _TRUE;
 
-	if (IS_HARDWARE_TYPE_8822B(padapter))
+	if (IS_HARDWARE_TYPE_8822B(padapter)) {
+#ifdef CONFIG_RTL8822B
 		ex_hal8822b_wifi_only_switchbandnotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+	}
+
+#ifdef CONFIG_RTL8821C
 	else if (IS_HARDWARE_TYPE_8821C(padapter))
 		ex_hal8821c_wifi_only_switchbandnotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
 }
 
 void hal_btcoex_wifionly_scan_notify(PADAPTER padapter)
@@ -123,22 +133,57 @@ void hal_btcoex_wifionly_scan_notify(PADAPTER padapter)
 	if (pHalData->current_band_type == BAND_ON_5G)
 		is_5g = _TRUE;
 
-	if (IS_HARDWARE_TYPE_8822B(padapter))
+	if (IS_HARDWARE_TYPE_8822B(padapter)) {
+#ifdef CONFIG_RTL8822B
 		ex_hal8822b_wifi_only_scannotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+	}
+
+#ifdef CONFIG_RTL8821C
 	else if (IS_HARDWARE_TYPE_8821C(padapter))
 		ex_hal8821c_wifi_only_scannotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+}
+
+void hal_btcoex_wifionly_connect_notify(PADAPTER padapter)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+	u8 is_5g = _FALSE;
+
+	if (pHalData->current_band_type == BAND_ON_5G)
+		is_5g = _TRUE;
+
+	if (IS_HARDWARE_TYPE_8822B(padapter)) {
+#ifdef CONFIG_RTL8822B
+		ex_hal8822b_wifi_only_connectnotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
+	}
+
+#ifdef CONFIG_RTL8821C
+	else if (IS_HARDWARE_TYPE_8821C(padapter))
+		ex_hal8821c_wifi_only_connectnotify(&GLBtCoexistWifiOnly, is_5g);
+#endif
 }
 
 void hal_btcoex_wifionly_hw_config(PADAPTER padapter)
 {
 	struct wifi_only_cfg *pwifionlycfg = &GLBtCoexistWifiOnly;
 
-	if (IS_HARDWARE_TYPE_8723B(padapter))
+	if (IS_HARDWARE_TYPE_8723B(padapter)) {
+#ifdef CONFIG_RTL8723B
 		ex_hal8723b_wifi_only_hw_config(pwifionlycfg);
+#endif
+	}
+
+#ifdef CONFIG_RTL8822B
 	else if (IS_HARDWARE_TYPE_8822B(padapter))
 		ex_hal8822b_wifi_only_hw_config(pwifionlycfg);
+#endif
+
+#ifdef CONFIG_RTL8821C
 	else if (IS_HARDWARE_TYPE_8821C(padapter))
 		ex_hal8821c_wifi_only_hw_config(pwifionlycfg);
+#endif
 }
 
 void hal_btcoex_wifionly_initlizevariables(PADAPTER padapter)
@@ -176,3 +221,5 @@ void hal_btcoex_wifionly_AntInfoSetting(PADAPTER padapter)
 	pwifionly_haldata->ant_div_cfg = pHalData->AntDivCfg;
 }
 
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com.c
index c8987fa9a18c..3a1490a695ec 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -114,6 +115,8 @@ void dump_chip_info(HAL_VERSION	ChipVersion)
 		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188E_");
 	else if (IS_8188F(ChipVersion))
 		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188F_");
+	else if (IS_8188GTV(ChipVersion))
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188GTV_");
 	else if (IS_8812_SERIES(ChipVersion))
 		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8812_");
 	else if (IS_8192E(ChipVersion))
@@ -132,6 +135,11 @@ void dump_chip_info(HAL_VERSION	ChipVersion)
 		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8822B_");
 	else if (IS_8821C_SERIES(ChipVersion))
 		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8821C_");
+	else if (IS_8710B_SERIES(ChipVersion))
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8710B_");
+	else if (IS_8192F_SERIES(ChipVersion))
+		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8192F_");
+
 	else
 		cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_UNKNOWN_");
 
@@ -183,6 +191,38 @@ void dump_chip_info(HAL_VERSION	ChipVersion)
 
 	RTW_INFO("%s", buf);
 }
+
+u8 rtw_hal_get_port(_adapter *adapter)
+{
+	u8 hw_port = get_hw_port(adapter);
+#ifdef CONFIG_CLIENT_PORT_CFG
+	u8 clt_port = get_clt_port(adapter);
+
+	if (clt_port)
+		hw_port = clt_port;
+
+#ifdef DBG_HW_PORT
+	if (MLME_IS_STA(adapter) && (adapter->client_id != MAX_CLIENT_PORT_NUM)) {
+		if(hw_port == CLT_PORT_INVALID) {
+			RTW_ERR(ADPT_FMT" @@@@@ Client port == 0 @@@@@\n", ADPT_ARG(adapter));
+			rtw_warn_on(1);
+		}
+	}
+	else if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
+		if (hw_port != HW_PORT0) {
+			RTW_ERR(ADPT_FMT" @@@@@ AP / MESH port != 0 @@@@@\n", ADPT_ARG(adapter));
+			rtw_warn_on(1);
+		}
+	}
+	if (0)
+		RTW_INFO(ADPT_FMT" - HP:%d,CP:%d\n", ADPT_ARG(adapter), get_hw_port(adapter), get_clt_port(adapter));
+#endif /*DBG_HW_PORT*/
+
+#endif/*CONFIG_CLIENT_PORT_CFG*/
+
+	return hw_port;
+}
+
 void rtw_hal_config_rftype(PADAPTER  padapter)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
@@ -1096,6 +1136,8 @@ Hal_MappingOutPipe(
 		break;
 	case 3:
 	case 4:
+	case 5:
+	case 6:
 		_ThreeOutPipeMapping(pAdapter, bWIFICfg);
 		break;
 	case 1:
@@ -1150,6 +1192,8 @@ void rtw_hal_hw_port_enable(_adapter *adapter)
 
 	_rtw_memset(&bcn_ctrl, 0, sizeof(struct rtw_halmac_bcn_ctrl));
 	bcn_ctrl.enable_bcn = 1;
+	bcn_ctrl.rx_bssid_fit = 1;
+	bcn_ctrl.rxbcn_rpt = 1;
 
 	/*rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
 				struct rtw_halmac_bcn_ctrl *bcn_ctrl)*/
@@ -1184,10 +1228,10 @@ void rtw_restore_hw_port_cfg(_adapter *adapter)
 }
 #endif
 
-void rtw_restore_mac_addr(_adapter *adapter)
+void rtw_mi_set_mac_addr(_adapter *adapter)
 {
 #ifdef CONFIG_MI_WITH_MBSSID_CAM
-	rtw_mbid_cam_restore(adapter);
+	rtw_mi_set_mbid_cam(adapter);
 #else
 	int i;
 	_adapter *iface;
@@ -1211,6 +1255,11 @@ void rtw_init_hal_com_default_value(PADAPTER Adapter)
 	pHalData->AntDetection = 1;
 	pHalData->antenna_test = _FALSE;
 	pHalData->RegIQKFWOffload = regsty->iqk_fw_offload;
+	pHalData->ch_switch_offload = regsty->ch_switch_offload;
+#ifdef RTW_REDUCE_SCAN_SWITCH_CH_TIME
+	if (pHalData->ch_switch_offload == 0)
+		pHalData->ch_switch_offload = 1;
+#endif
 }
 
 #ifdef CONFIG_FW_C2H_REG
@@ -1252,7 +1301,7 @@ s32 c2h_evt_read_88xx(_adapter *adapter, u8 *buf)
 	for (i = 0; i < C2H_PLEN_88XX(buf); i++)
 		*(C2H_PAYLOAD_88XX(buf) + i) = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL + 2 + i);
 
-	RTW_DBG_DUMP("payload:\n", C2H_PAYLOAD_88XX(buf), C2H_PLEN_88XX(buf));
+	RTW_DBG_DUMP("payload: ", C2H_PAYLOAD_88XX(buf), C2H_PLEN_88XX(buf));
 
 	ret = _SUCCESS;
 
@@ -1459,12 +1508,6 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 		RTW_PRINT("nic:0x%x\n", nic);
 	}
 
-	/*
-	* NOTICE:
-	* for now, the following is common info/format
-	* if there is any hal difference need to export
-	* some IC dependent code will need to be implement
-	*/
 	hal_data->PackageType = package_type;
 	hal_spec->wl_func &= mac_hidden_wl_func_to_hal_wl_func(wl_func);
 	hal_spec->bw_cap &= mac_hidden_max_bw_to_hal_bw_cap(bw);
@@ -1473,7 +1516,18 @@ int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
 	hal_spec->proto_cap &= mac_hidden_proto_to_hal_proto_cap(protocol);
 	hal_spec->hci_type = hci_type;
 
-	/* TODO: tr_switch */
+#if defined(CONFIG_RTL8822C)
+	if (IS_8822C_SERIES(hal_data->version_id)) {
+		#define GET_C2H_MAC_HIDDEN_RPT_SS_NUM(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 3, 2)
+		u8 ss_num = GET_C2H_MAC_HIDDEN_RPT_SS_NUM(data);
+
+		if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE)
+			RTW_PRINT("ss_num:0x%x\n", ss_num);
+
+		hal_spec->tx_nss_num = rtw_min(hal_spec->tx_nss_num, ss_num);
+		hal_spec->rx_nss_num = rtw_min(hal_spec->rx_nss_num, ss_num);
+	}
+#endif
 
 	ret = _SUCCESS;
 
@@ -1499,8 +1553,8 @@ int c2h_mac_hidden_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len)
 			RTW_PRINT("%s: 0x%02X\n", __func__, *(data + i));
 	}
 
-	#ifdef CONFIG_RTL8188F
-	if (IS_8188F(hal_data->version_id)) {
+	#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
+	if (IS_8188F(hal_data->version_id) || IS_8188GTV(hal_data->version_id)) {
 		#define GET_C2H_MAC_HIDDEN_RPT_IRV(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 0, 0, 4)
 		u8 irv = GET_C2H_MAC_HIDDEN_RPT_IRV(data);
 
@@ -1835,6 +1889,120 @@ exit:
 }
 #endif /* CONFIG_RTW_CUSTOMER_STR */
 
+#ifdef RTW_PER_CMD_SUPPORT_FW
+#define H2C_REQ_PER_RPT_LEN 5
+#define SET_H2CCMD_REQ_PER_RPT_GROUP_MACID(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_REQ_PER_RPT_RPT_TYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_H2CCMD_REQ_PER_RPT_MACID_BMAP(__pH2CCmd, __Value)	SET_BITS_TO_LE_4BYTE(__pH2CCmd + 1, 0, 32, __Value)
+
+u8 rtw_hal_set_req_per_rpt_cmd(_adapter *adapter, u8 group_macid,
+				      u8 rpt_type, u32 macid_bitmap)
+{
+	u8 ret = _FAIL;
+	u8 cmd_buf[H2C_REQ_PER_RPT_LEN] = {0};
+
+	SET_H2CCMD_REQ_PER_RPT_GROUP_MACID(cmd_buf, group_macid);
+	SET_H2CCMD_REQ_PER_RPT_RPT_TYPE(cmd_buf, rpt_type);
+	SET_H2CCMD_REQ_PER_RPT_MACID_BMAP(cmd_buf, macid_bitmap);
+
+	ret = rtw_hal_fill_h2c_cmd(adapter, 
+				   H2C_REQ_PER_RPT, 
+				   H2C_REQ_PER_RPT_LEN, 
+				   cmd_buf);
+	return ret;
+}
+
+#define	GET_C2H_PER_RATE_RPT_TYPE0_MACID0(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)), 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_PER0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 1, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_RATE0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 2, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_BW0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 3, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT0(_data)	LE_BITS_TO_2BYTE(((u8 *)(_data)) + 4, 0, 16)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_MACID1(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_PER1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_RATE1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 8, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_BW1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 9, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT1(_data)	LE_BITS_TO_2BYTE(((u8 *)(_data)) + 10, 0, 16)
+
+#define	GET_C2H_PER_RATE_RPT_TYPE1_MACID0(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)), 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_PER0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 1, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_RATE0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 2, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_BW0(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 3, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_MACID1(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 4, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_PER1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 5, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_RATE1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_BW1(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 0, 2)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_MACID2(_data)	LE_BITS_TO_1BYTE(((u8 *)(_data)) + 8, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_PER2(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 9, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_RATE2(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 10, 0, 8)
+#define	GET_C2H_PER_RATE_RPT_TYPE1_BW2(_data)		LE_BITS_TO_1BYTE(((u8 *)(_data)) + 11, 0, 2)
+
+static void per_rate_rpt_update(_adapter *adapter, u8 mac_id,
+				u8 per, u8 rate,
+				u8 bw, u8 total_pkt)
+{
+#ifdef CONFIG_RTW_MESH
+	rtw_ieee80211s_update_metric(adapter, mac_id,
+				     per, rate,
+				     bw, total_pkt);
+#endif
+}
+
+int c2h_per_rate_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
+{
+	/* Now only consider type0, since it covers all params in type1
+	 * type0: mac_id, per, rate, bw, total_pkt
+	 * type1: mac_id, per, rate, bw
+	 */
+	u8 mac_id[2] = {0}, per[2] = {0}, rate[2] = {0}, bw[2] = {0};
+	u16 total_pkt[2] = {0};
+	int ret = _FAIL, i, macid_cnt = 0;
+
+	/* type0:
+	 * 1 macid includes   6 bytes info + 1 byte 0xff
+	 * 2 macid includes 2*6 bytes info
+	 */
+	if (!(len == 7 || len == 12)) {
+		RTW_WARN("%s len(%u) != 7 or 12\n", __FUNCTION__, len);
+		goto exit;
+	}
+
+	macid_cnt++;
+	mac_id[0] = GET_C2H_PER_RATE_RPT_TYPE0_MACID0(data);
+	per[0] = GET_C2H_PER_RATE_RPT_TYPE0_PER0(data);
+	rate[0] = GET_C2H_PER_RATE_RPT_TYPE0_RATE0(data);
+	bw[0] = GET_C2H_PER_RATE_RPT_TYPE0_BW0(data);
+	total_pkt[0] = GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT0(data);
+
+	mac_id[1] = GET_C2H_PER_RATE_RPT_TYPE0_MACID1(data);
+	/* 0xff means no report anymore */
+	if (mac_id[1] == 0xff)
+		goto update_per;
+	if (len != 12) {
+		RTW_WARN("%s incorrect format\n", __FUNCTION__);
+		goto exit;
+	}
+	macid_cnt++;
+	per[1] = GET_C2H_PER_RATE_RPT_TYPE0_PER1(data);
+	rate[1] = GET_C2H_PER_RATE_RPT_TYPE0_RATE1(data);
+	bw[1] = GET_C2H_PER_RATE_RPT_TYPE0_BW1(data);
+	total_pkt[1] = GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT1(data);
+
+update_per:
+	for (i = 0; i < macid_cnt; i++) {
+		RTW_DBG("[%s] type0 rpt[%d]: macid = %u, per = %u, "
+			"rate = %u, bw = %u, total_pkt = %u\n",
+			__FUNCTION__, i, mac_id[i], per[i],
+			rate[i], bw[i], total_pkt[i]);
+		per_rate_rpt_update(adapter, mac_id[i],
+				    per[i], rate[i],
+				    bw[i], total_pkt[i]);
+	}
+	ret = _SUCCESS;
+exit:
+	return ret;
+}
+#endif /* RTW_PER_CMD_SUPPORT_FW */
+
 void rtw_hal_update_sta_wset(_adapter *adapter, struct sta_info *psta)
 {
 	u8 w_set = 0;
@@ -1879,6 +2047,10 @@ void rtw_hal_update_sta_mimo_type(_adapter *adapter, struct sta_info *psta)
 	else
 		rtw_warn_on(1);
 
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+	rtw_ctrl_txss_update_mimo_type(adapter, psta);
+#endif
+
 	RTW_INFO("STA - MAC_ID:%d, Tx - %d SS, Rx - %d SS\n",
 			psta->cmn.mac_id, tx_nss, rx_nss);
 }
@@ -1925,7 +2097,7 @@ void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta)
 {
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
 	u8 i, rf_type, tx_nss;
-	u64 tx_ra_bitmap = 0;
+	u64 tx_ra_bitmap = 0, tmp64=0;
 
 	if (psta == NULL)
 		return;
@@ -1937,6 +2109,7 @@ void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta)
 	}
 
 #ifdef CONFIG_80211N_HT
+if (padapter->registrypriv.ht_enable && is_supported_ht(padapter->registrypriv.wireless_mode)) {
 	rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
 	tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
 #ifdef CONFIG_80211AC_VHT
@@ -1957,8 +2130,10 @@ void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta)
 			}
 		}
 
-		tx_ra_bitmap |= (rtw_ht_mcs_set_to_bitmap(psta->htpriv.ht_cap.supp_mcs_set, tx_nss) << 12);
+		tmp64 = rtw_ht_mcs_set_to_bitmap(psta->htpriv.ht_cap.supp_mcs_set, tx_nss);
+		tx_ra_bitmap |= (tmp64 << 12);
 	}
+}
 #endif /* CONFIG_80211N_HT */
 	psta->cmn.ra_info.ramask = tx_ra_bitmap;
 	psta->init_rate = get_highest_rate_idx(tx_ra_bitmap) & 0x3f;
@@ -1971,6 +2146,130 @@ void rtw_hal_update_sta_ra_info(PADAPTER padapter, struct sta_info *psta)
 	rtw_hal_update_sta_rate_mask(padapter, psta);
 }
 
+static u32 hw_bcn_ctrl_addr(_adapter *adapter, u8 hw_port)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+
+	if (hw_port >= hal_spec->port_num) {
+		RTW_ERR(FUNC_ADPT_FMT" HW Port(%d) invalid\n", FUNC_ADPT_ARG(adapter), hw_port);
+		rtw_warn_on(1);
+		return 0;
+	}
+
+	switch (hw_port) {
+	case HW_PORT0:
+		return REG_BCN_CTRL;
+	case HW_PORT1:
+		return REG_BCN_CTRL_1;
+	}
+
+	return 0;
+}
+
+static void rtw_hal_get_msr(_adapter *adapter, u8 *net_type)
+{
+#ifdef RTW_HALMAC
+	rtw_halmac_get_network_type(adapter_to_dvobj(adapter),
+				adapter->hw_port, net_type);
+#else /* !RTW_HALMAC */
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+		/*REG_CR - BIT[17:16]-Network Type for port 1*/
+		*net_type = rtw_read8(adapter, MSR) & 0x03;
+		break;
+	case HW_PORT1:
+		/*REG_CR - BIT[19:18]-Network Type for port 1*/
+		*net_type = (rtw_read8(adapter, MSR) & 0x0C) >> 2;
+		break;
+#if defined(CONFIG_RTL8814A)
+	case HW_PORT2:
+		/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
+		*net_type = rtw_read8(adapter, MSR1) & 0x03;
+		break;
+	case HW_PORT3:
+		/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
+		*net_type = (rtw_read8(adapter, MSR1) & 0x0C) >> 2;
+		break;
+	case HW_PORT4:
+		/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
+		*net_type = (rtw_read8(adapter, MSR1) & 0x30) >> 4;
+		break;
+#endif /*#if defined(CONFIG_RTL8814A)*/
+	default:
+		RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
+			 ADPT_ARG(adapter), adapter->hw_port);
+		rtw_warn_on(1);
+		break;
+	}
+#endif /* !RTW_HALMAC */
+}
+
+#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM) /*For 2 hw ports - 88E/92E/8812/8821/8723B*/
+static u8 rtw_hal_net_type_decision(_adapter *adapter, u8 net_type)
+{
+	if ((adapter->hw_port == HW_PORT0) && (rtw_get_mbid_cam_entry_num(adapter))) {
+		if (net_type != _HW_STATE_NOLINK_)
+			return _HW_STATE_AP_;
+	}
+	return net_type;
+}
+#endif
+static void rtw_hal_set_msr(_adapter *adapter, u8 net_type)
+{
+#ifdef RTW_HALMAC
+	#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
+	net_type = rtw_hal_net_type_decision(adapter, net_type);
+	#endif
+	rtw_halmac_set_network_type(adapter_to_dvobj(adapter),
+				adapter->hw_port, net_type);
+#else /* !RTW_HALMAC */
+	u8 val8 = 0;
+
+	switch (adapter->hw_port) {
+	case HW_PORT0:
+		#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
+		net_type = rtw_hal_net_type_decision(adapter, net_type);
+		#endif
+		/*REG_CR - BIT[17:16]-Network Type for port 0*/
+		val8 = rtw_read8(adapter, MSR) & 0x0C;
+		val8 |= net_type;
+		rtw_write8(adapter, MSR, val8);
+		break;
+	case HW_PORT1:
+		/*REG_CR - BIT[19:18]-Network Type for port 1*/
+		val8 = rtw_read8(adapter, MSR) & 0x03;
+		val8 |= net_type << 2;
+		rtw_write8(adapter, MSR, val8);
+		break;
+#if defined(CONFIG_RTL8814A)
+	case HW_PORT2:
+		/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
+		val8 = rtw_read8(adapter, MSR1) & 0xFC;
+		val8 |= net_type;
+		rtw_write8(adapter, MSR1, val8);
+		break;
+	case HW_PORT3:
+		/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
+		val8 = rtw_read8(adapter, MSR1) & 0xF3;
+		val8 |= net_type << 2;
+		rtw_write8(adapter, MSR1, val8);
+		break;
+	case HW_PORT4:
+		/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
+		val8 = rtw_read8(adapter, MSR1) & 0xCF;
+		val8 |= net_type << 4;
+		rtw_write8(adapter, MSR1, val8);
+		break;
+#endif /* CONFIG_RTL8814A */
+	default:
+		RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
+			 ADPT_ARG(adapter), adapter->hw_port);
+		rtw_warn_on(1);
+		break;
+	}
+#endif /* !RTW_HALMAC */
+}
+
 #ifndef SEC_CAM_ACCESS_TIMEOUT_MS
 	#define SEC_CAM_ACCESS_TIMEOUT_MS 200
 #endif
@@ -2114,8 +2413,8 @@ void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
 {
 	unsigned int i;
 	int j;
-	u8 addr;
-	u32 wdata;
+	u8 addr, addr1 = 0;
+	u32 wdata, wdata1 = 0;
 
 	/* TODO: consider other key length accordingly */
 #if 0
@@ -2150,8 +2449,20 @@ void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
 
 		addr = (id << 3) + j;
 
+#if defined(CONFIG_RTL8192F)
+		if(j == 1) {
+			wdata1 = wdata;
+			addr1 = addr;
+			continue;
+		}
+#endif
+
 		rtw_sec_write_cam(adapter, addr, wdata);
 	}
+
+#if defined(CONFIG_RTL8192F)
+	rtw_sec_write_cam(adapter, addr1, wdata1);
+#endif
 }
 
 void rtw_sec_clr_cam_ent(_adapter *adapter, u8 id)
@@ -2317,14 +2628,14 @@ u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr)
 	struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
 	u8 entry_num = ATOMIC_READ(&mbid_cam_ctl->mbid_entry_num);
 
+	if (INVALID_CAM_ID != rtw_mbid_cam_search_by_macaddr(adapter, mac_addr))
+		goto exit;
+
 	if (entry_num >= TOTAL_MBID_CAM_NUM) {
 		RTW_INFO(FUNC_ADPT_FMT" failed !! MBSSID number :%d over TOTAL_CAM_ENTRY(8)\n", FUNC_ADPT_ARG(adapter), entry_num);
 		rtw_warn_on(1);
 	}
 
-	if (INVALID_CAM_ID != rtw_mbid_cam_search_by_macaddr(adapter, mac_addr))
-		goto exit;
-
 	_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
 	for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
 		if (!(mbid_cam_ctl->bitmap & BIT(i))) {
@@ -2440,23 +2751,23 @@ int rtw_mbid_cam_cache_dump(void *sel, const char *fun_name, _adapter *adapter)
 
 		if (mbid_cam_ctl->bitmap & BIT(i)) {
 			iface_id = dvobj->mbid_cam_cache[i].iface_id;
-			RTW_PRINT_SEL(sel, "IF_ID:%d\t", iface_id);
-			RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\t", MAC_ARG(dvobj->mbid_cam_cache[i].mac_addr));
+			_RTW_PRINT_SEL(sel, "IF_ID:%d\t", iface_id);
+			_RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\t", MAC_ARG(dvobj->mbid_cam_cache[i].mac_addr));
 
 			iface = dvobj->padapters[iface_id];
 			if (iface) {
 				if (MLME_IS_STA(iface))
-					RTW_PRINT_SEL(sel, "ROLE:%s\n", "STA");
+					_RTW_PRINT_SEL(sel, "ROLE:%s\n", "STA");
 				else if (MLME_IS_AP(iface))
-					RTW_PRINT_SEL(sel, "ROLE:%s\n", "AP");
+					_RTW_PRINT_SEL(sel, "ROLE:%s\n", "AP");
 				else if (MLME_IS_MESH(iface))
-					RTW_PRINT_SEL(sel, "ROLE:%s\n", "MESH");
+					_RTW_PRINT_SEL(sel, "ROLE:%s\n", "MESH");
 				else
-					RTW_PRINT_SEL(sel, "ROLE:%s\n", "NONE");
+					_RTW_PRINT_SEL(sel, "ROLE:%s\n", "NONE");
 			}
 
 		} else
-			RTW_PRINT_SEL(sel, "N/A\n");
+			_RTW_PRINT_SEL(sel, "N/A\n");
 	}
 	_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
 	return 0;
@@ -2511,7 +2822,7 @@ int rtw_mbid_cam_dump(void *sel, const char *fun_name, _adapter *adapter)
 		RTW_PRINT_SEL(sel, "CAM_ID = %d\t", i);
 		_rtw_memset(mac_addr, 0, ETH_ALEN);
 		read_mbssid_cam(adapter, i, mac_addr);
-		RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\n", MAC_ARG(mac_addr));
+		_RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\n", MAC_ARG(mac_addr));
 	}
 	/*_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);*/
 	return 0;
@@ -2531,17 +2842,19 @@ static void clear_mbssid_cam(_adapter *padapter, u8 cam_addr)
 {
 	rtw_hal_set_hwreg(padapter, HW_VAR_MBSSID_CAM_CLEAR, &cam_addr);
 }
-static void enable_mbssid_cam(_adapter *adapter)
+
+void rtw_ap_set_mbid_num(_adapter *adapter, u8 ap_num)
+{
+	rtw_write8(adapter, REG_MBID_NUM,
+		((rtw_read8(adapter, REG_MBID_NUM) & 0xF8) | ((ap_num -1) & 0x07)));
+
+}
+void rtw_mbid_cam_enable(_adapter *adapter)
 {
-	u8 max_cam_id = rtw_get_max_mbid_cam_id(adapter);
 	/*enable MBSSID*/
 	rtw_hal_rcr_add(adapter, RCR_ENMBID);
-	if (max_cam_id != INVALID_CAM_ID) {
-		rtw_write8(adapter, REG_MBID_NUM,
-			((rtw_read8(adapter, REG_MBID_NUM) & 0xF8) | (max_cam_id & 0x07)));
-	}
 }
-void rtw_mbid_cam_restore(_adapter *adapter)
+void rtw_mi_set_mbid_cam(_adapter *adapter)
 {
 	u8 i;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
@@ -2557,99 +2870,347 @@ void rtw_mbid_cam_restore(_adapter *adapter)
 			RTW_INFO("%s - cam_id:%d => mac:"MAC_FMT"\n", __func__, i, MAC_ARG(dvobj->mbid_cam_cache[i].mac_addr));
 		}
 	}
-	enable_mbssid_cam(adapter);
+	rtw_mbid_cam_enable(adapter);
 }
 #endif /*CONFIG_MBSSID_CAM*/
 
-#ifdef CONFIG_MI_WITH_MBSSID_CAM
-void rtw_hal_set_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
-{
+#ifdef CONFIG_FW_HANDLE_TXBCN
+#define H2C_BCN_OFFLOAD_LEN	1
 
-#if 0 /*TODO - modify for more flexible*/
-	u8 idx = 0;
+#define SET_H2CCMD_BCN_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_BCN_ROOT_TBTT_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_BCN_VAP1_TBTT_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_BCN_VAP2_TBTT_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_H2CCMD_BCN_VAP3_TBTT_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
+#define SET_H2CCMD_BCN_VAP4_TBTT_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
 
-	if ((check_fwstate(&adapter->mlmepriv, WIFI_STATION_STATE) == _TRUE) &&
-	    (DEV_STA_NUM(adapter_to_dvobj(adapter)) == 1)) {
-		for (idx = 0; idx < 6; idx++)
-			rtw_write8(GET_PRIMARY_ADAPTER(adapter), (REG_MACID + idx), val[idx]);
-	}  else {
-		/*MBID entry_id = 0~7 ,0 for root AP, 1~7 for VAP*/
-		u8 entry_id;
+void rtw_hal_set_fw_ap_bcn_offload_cmd(_adapter *adapter, bool fw_bcn_en, u8 tbtt_rpt_map)
+{
+	u8 fw_bcn_offload[1] = {0};
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 
-		if ((check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _TRUE) &&
-		    (DEV_AP_NUM(adapter_to_dvobj(adapter)) == 1)) {
-			entry_id = 0;
-			if (rtw_mbid_cam_assign(adapter, val, entry_id)) {
-				RTW_INFO(FUNC_ADPT_FMT" Root AP assigned success\n", FUNC_ADPT_ARG(adapter));
-				write_mbssid_cam(adapter, entry_id, val);
-			}
-		} else {
-			entry_id = rtw_mbid_camid_alloc(adapter, val);
-			if (entry_id != INVALID_CAM_ID)
-				write_mbssid_cam(adapter, entry_id, val);
-		}
-	}
-#else
-	{
-		/*
-			MBID entry_id = 0~7 ,for IFACE_ID0 ~ IFACE_IDx
-		*/
-		u8 entry_id = rtw_mbid_camid_alloc(adapter, mac_addr);
+	if (fw_bcn_en)
+		SET_H2CCMD_BCN_OFFLOAD_EN(fw_bcn_offload, 1);
 
+	if (tbtt_rpt_map & BIT(0))
+		SET_H2CCMD_BCN_ROOT_TBTT_RPT(fw_bcn_offload, 1);
+	if (tbtt_rpt_map & BIT(1))
+		SET_H2CCMD_BCN_VAP1_TBTT_RPT(fw_bcn_offload, 1);
+	if (tbtt_rpt_map & BIT(2))
+		SET_H2CCMD_BCN_VAP2_TBTT_RPT(fw_bcn_offload, 1);
+	if (tbtt_rpt_map & BIT(3))
+			SET_H2CCMD_BCN_VAP3_TBTT_RPT(fw_bcn_offload, 1);
 
-		if (entry_id != INVALID_CAM_ID) {
-			write_mbssid_cam(adapter, entry_id, mac_addr);
-			enable_mbssid_cam(adapter);
-		}
-	}
-#endif
+	dvobj->vap_tbtt_rpt_map = tbtt_rpt_map;
+	dvobj->fw_bcn_offload = fw_bcn_en;
+	RTW_INFO("[FW BCN] Offload : %s\n", (dvobj->fw_bcn_offload) ? "EN" : "DIS");
+	RTW_INFO("[FW BCN] TBTT RPT map : 0x%02x\n", dvobj->vap_tbtt_rpt_map);
+
+	rtw_hal_fill_h2c_cmd(adapter, H2C_FW_BCN_OFFLOAD,
+					H2C_BCN_OFFLOAD_LEN, fw_bcn_offload);
 }
 
-void rtw_hal_change_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
+void rtw_hal_set_bcn_rsvdpage_loc_cmd(_adapter *adapter)
 {
-	u8 idx = 0;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	u8 entry_id;
+	u8 ret, vap_id;
+	u32 page_size = 0;
+	u8 bcn_rsvdpage[H2C_BCN_RSVDPAGE_LEN] = {0};
 
-	if (!mac_addr) {
-		rtw_warn_on(1);
-		return;
+	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&page_size);
+	#if 1
+	for (vap_id = 0; vap_id < CONFIG_LIMITED_AP_NUM; vap_id++) {
+		if (dvobj->vap_map & BIT(vap_id))
+			bcn_rsvdpage[vap_id] = vap_id * (MAX_BEACON_LEN / page_size);
 	}
+	#else
+#define SET_H2CCMD_BCN_RSVDPAGE_LOC_ROOT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP1(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 8, __Value)
+#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP2(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 8, __Value)
+#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP3(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 8, __Value)
+#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP4(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 8, __Value)
+
+	if (dvobj->vap_map & BIT(0))
+ 		SET_H2CCMD_BCN_RSVDPAGE_LOC_ROOT(bcn_rsvdpage, 0);
+	if (dvobj->vap_map & BIT(1))
+		SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP1(bcn_rsvdpage,
+					1 * (MAX_BEACON_LEN / page_size));
+	if (dvobj->vap_map & BIT(2))
+		SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP2(bcn_rsvdpage,
+					2 * (MAX_BEACON_LEN / page_size));
+	if (dvobj->vap_map & BIT(3))
+		SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP3(bcn_rsvdpage,
+					3 * (MAX_BEACON_LEN / page_size));
+	if (dvobj->vap_map & BIT(4))
+		SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP4(bcn_rsvdpage,
+					4 * (MAX_BEACON_LEN / page_size));
+	#endif
+	if (1) {
+		RTW_INFO("[BCN_LOC] vap_map : 0x%02x\n", dvobj->vap_map);
+		RTW_INFO("[BCN_LOC] page_size :%d, @bcn_page_num :%d\n"
+			, page_size, (MAX_BEACON_LEN / page_size));
+		RTW_INFO("[BCN_LOC] root ap : 0x%02x\n", *bcn_rsvdpage);
+		RTW_INFO("[BCN_LOC] vap_1 : 0x%02x\n", *(bcn_rsvdpage + 1));
+		RTW_INFO("[BCN_LOC] vap_2 : 0x%02x\n", *(bcn_rsvdpage + 2));
+		RTW_INFO("[BCN_LOC] vap_3 : 0x%02x\n", *(bcn_rsvdpage + 3));
+		RTW_INFO("[BCN_LOC] vap_4 : 0x%02x\n", *(bcn_rsvdpage + 4));
+	}
+	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_BCN_RSVDPAGE,
+					H2C_BCN_RSVDPAGE_LEN, bcn_rsvdpage);
+}
 
+void rtw_ap_multi_bcn_cfg(_adapter *adapter)
+{
+	u8 dft_bcn_space = DEFAULT_BCN_INTERVAL;
+	u8 sub_bcn_space = (DEFAULT_BCN_INTERVAL / CONFIG_LIMITED_AP_NUM);
 
-	entry_id = rtw_mbid_cam_info_change(adapter, mac_addr);
+	/*enable to rx data frame*/
+	rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
 
-	if (entry_id != INVALID_CAM_ID)
-		write_mbssid_cam(adapter, entry_id, mac_addr);
-}
+	/*Disable Port0's beacon function*/
+	rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL) & ~BIT_EN_BCN_FUNCTION);
+	/*Reset Port0's TSF*/
+	rtw_write8(adapter, REG_DUAL_TSF_RST, BIT_TSFTR_RST);
 
-#ifdef CONFIG_SWTIMER_BASED_TXBCN
-u16 rtw_hal_bcn_interval_adjust(_adapter *adapter, u16 bcn_interval)
-{
-	if (adapter_to_dvobj(adapter)->inter_bcn_space != bcn_interval)
-		return adapter_to_dvobj(adapter)->inter_bcn_space;
-	else
-		return bcn_interval;
-}
-#endif/*CONFIG_SWTIMER_BASED_TXBCN*/
+	rtw_ap_set_mbid_num(adapter, CONFIG_LIMITED_AP_NUM);
 
-#endif/*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
+	/*BCN space & BCN sub-space 0x554[15:0] = 0x64,0x5BC[23:16] = 0x21*/
+	rtw_halmac_set_bcn_interval(adapter_to_dvobj(adapter), HW_PORT0, dft_bcn_space);
+	rtw_write8(adapter, REG_MBSSID_BCN_SPACE3 + 2, sub_bcn_space);
 
-static void rtw_hal_set_macaddr_port(_adapter *adapter, u8 *val)
+	#if 0 /*setting in hw_var_set_opmode_mbid - ResumeTxBeacon*/
+	/*BCN hold time  0x540[19:8] = 0x80*/
+	rtw_write8(adapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME & 0xFF);
+	rtw_write8(adapter, REG_TBTT_PROHIBIT + 2,
+		(rtw_read8(adapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME >> 8));
+	#endif
+
+	/*ATIM window -0x55A = 0x32, reg 0x570 = 0x32, reg 0x5A0 = 0x32 */
+	rtw_write8(adapter, REG_ATIMWND, 0x32);
+	rtw_write8(adapter, REG_ATIMWND1_V1, 0x32);
+	rtw_write8(adapter, REG_ATIMWND2, 0x32);
+	rtw_write8(adapter, REG_ATIMWND3, 0x32);
+	/*
+	rtw_write8(adapter, REG_ATIMWND4, 0x32);
+	rtw_write8(adapter, REG_ATIMWND5, 0x32);
+	rtw_write8(adapter, REG_ATIMWND6, 0x32);
+	rtw_write8(adapter, REG_ATIMWND7, 0x32);*/
+
+	/*no limit setting - 0x5A7 = 0xFF - Packet in Hi Queue Tx immediately*/
+	rtw_write8(adapter, REG_HIQ_NO_LMT_EN, 0xFF);
+
+	/*Mask all beacon*/
+	rtw_write8(adapter, REG_MBSSID_CTRL, 0);
+
+	/*BCN invalid bit setting 0x454[6] = 1*/
+	/*rtw_write8(adapter, REG_CCK_CHECK, rtw_read8(adapter, REG_CCK_CHECK) | BIT_EN_BCN_PKT_REL);*/
+
+	/*Enable Port0's beacon function*/
+	rtw_write8(adapter, REG_BCN_CTRL,
+	rtw_read8(adapter, REG_BCN_CTRL) | BIT_DIS_RX_BSSID_FIT | BIT_P0_EN_TXBCN_RPT | BIT_DIS_TSF_UDT  | BIT_EN_BCN_FUNCTION);
+
+	/* Enable HW seq for BCN
+	* 0x4FC[0]: EN_HWSEQ / 0x4FC[1]: EN_HWSEQEXT  */
+	 #ifdef CONFIG_RTL8822B
+	if (IS_HARDWARE_TYPE_8822B(adapter))
+		rtw_write8(adapter, REG_DUMMY_PAGE4_V1_8822B, 0x01);
+	#endif
+
+}
+static void _rtw_mbid_bcn_cfg(_adapter *adapter, bool mbcnq_en, u8 mbcnq_id)
+{
+	if (mbcnq_id >= CONFIG_LIMITED_AP_NUM) {
+		RTW_ERR(FUNC_ADPT_FMT"- mbid bcnq_id(%d) invalid\n", FUNC_ADPT_ARG(adapter), mbcnq_id);
+		rtw_warn_on(1);
+	}
+
+	if (mbcnq_en) {
+		rtw_write8(adapter, REG_MBSSID_CTRL,
+			rtw_read8(adapter, REG_MBSSID_CTRL) | BIT(mbcnq_id));
+		RTW_INFO(FUNC_ADPT_FMT"- mbid bcnq_id(%d) enabled\n", FUNC_ADPT_ARG(adapter), mbcnq_id);
+	} else {
+		rtw_write8(adapter, REG_MBSSID_CTRL,
+			rtw_read8(adapter, REG_MBSSID_CTRL) & (~BIT(mbcnq_id)));
+		RTW_INFO(FUNC_ADPT_FMT"- mbid bcnq_id(%d) disabled\n", FUNC_ADPT_ARG(adapter), mbcnq_id);
+	}
+}
+/*#define CONFIG_FW_TBTT_RPT*/
+void rtw_ap_mbid_bcn_en(_adapter *adapter, u8 ap_id)
+{
+	RTW_INFO(FUNC_ADPT_FMT"- ap_id(%d)\n", FUNC_ADPT_ARG(adapter), ap_id);
+
+	#ifdef CONFIG_FW_TBTT_RPT
+	if (rtw_ap_get_nums(adapter) >= 1) {
+		u8 tbtt_rpt_map = adapter_to_dvobj(adapter)->vap_tbtt_rpt_map;
+
+		rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _TRUE,
+			tbtt_rpt_map | BIT(ap_id));/*H2C-0xBA*/
+	}
+	#else
+	if (rtw_ap_get_nums(adapter) == 1)
+		rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _TRUE, 0);/*H2C-0xBA*/
+	#endif
+
+	rtw_hal_set_bcn_rsvdpage_loc_cmd(adapter);/*H2C-0x09*/
+
+	_rtw_mbid_bcn_cfg(adapter, _TRUE, ap_id);
+}
+void rtw_ap_mbid_bcn_dis(_adapter *adapter, u8 ap_id)
+{
+	RTW_INFO(FUNC_ADPT_FMT"- ap_id(%d)\n", FUNC_ADPT_ARG(adapter), ap_id);
+	_rtw_mbid_bcn_cfg(adapter, _FALSE, ap_id);
+
+	if (rtw_ap_get_nums(adapter) == 0)
+		rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _FALSE, 0);
+	#ifdef CONFIG_FW_TBTT_RPT
+	else if (rtw_ap_get_nums(adapter) >= 1) {
+		u8 tbtt_rpt_map = adapter_to_dvobj(adapter)->vap_tbtt_rpt_map;
+
+		rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _TRUE,
+			tbtt_rpt_map & ~BIT(ap_id));/*H2C-0xBA*/
+	}
+	#endif
+}
+#endif
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+void rtw_ap_multi_bcn_cfg(_adapter *adapter)
+{
+	#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
+	rtw_write8(adapter, REG_BCN_CTRL, DIS_TSF_UDT);
+	#else
+	rtw_write8(adapter, REG_BCN_CTRL, DIS_TSF_UDT | DIS_BCNQ_SUB);
+	#endif
+	/*enable to rx data frame*/
+	rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
+
+	/*Beacon Control related register for first time*/
+	rtw_write8(adapter, REG_BCNDMATIM, 0x02); /* 2ms */
+
+	/*rtw_write8(Adapter, REG_BCN_MAX_ERR, 0xFF);*/
+	rtw_write8(adapter, REG_ATIMWND, 0x0c); /* 12ms */
+
+	#ifndef CONFIG_HW_P0_TSF_SYNC
+	rtw_write16(adapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
+	#endif
+
+	/*reset TSF*/
+	rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(0));
+
+	/*enable BCN0 Function for if1*/
+	/*don't enable update TSF0 for if1 (due to TSF update when beacon,probe rsp are received)*/
+	#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
+	rtw_write8(adapter, REG_BCN_CTRL, BIT_DIS_RX_BSSID_FIT | BIT_P0_EN_TXBCN_RPT | BIT_DIS_TSF_UDT |BIT_EN_BCN_FUNCTION);
+	#else
+	rtw_write8(adapter, REG_BCN_CTRL, (DIS_TSF_UDT | EN_BCN_FUNCTION | EN_TXBCN_RPT | DIS_BCNQ_SUB));
+	#endif
+	#ifdef CONFIG_BCN_XMIT_PROTECT
+	rtw_write8(adapter, REG_CCK_CHECK, rtw_read8(adapter, REG_CCK_CHECK) | BIT_EN_BCN_PKT_REL);
+	#endif
+
+	if (IS_HARDWARE_TYPE_8821(adapter) || IS_HARDWARE_TYPE_8192E(adapter))/* select BCN on port 0 for DualBeacon*/
+		rtw_write8(adapter, REG_CCK_CHECK, rtw_read8(adapter, REG_CCK_CHECK) & (~BIT_BCN_PORT_SEL));
+
+	/* Enable HW seq for BCN 
+	 * 0x4FC[0]: EN_HWSEQ / 0x4FC[1]: EN_HWSEQEXT  */
+	#ifdef CONFIG_RTL8822B
+	if (IS_HARDWARE_TYPE_8822B(adapter))
+		rtw_write8(adapter, REG_DUMMY_PAGE4_V1_8822B, 0x01);
+	#endif
+}
+#endif
+
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+void rtw_hal_set_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
+{
+
+#if 0 /*TODO - modify for more flexible*/
+	u8 idx = 0;
+
+	if ((check_fwstate(&adapter->mlmepriv, WIFI_STATION_STATE) == _TRUE) &&
+	    (DEV_STA_NUM(adapter_to_dvobj(adapter)) == 1)) {
+		for (idx = 0; idx < 6; idx++)
+			rtw_write8(GET_PRIMARY_ADAPTER(adapter), (REG_MACID + idx), val[idx]);
+	}  else {
+		/*MBID entry_id = 0~7 ,0 for root AP, 1~7 for VAP*/
+		u8 entry_id;
+
+		if ((check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _TRUE) &&
+		    (DEV_AP_NUM(adapter_to_dvobj(adapter)) == 1)) {
+			entry_id = 0;
+			if (rtw_mbid_cam_assign(adapter, val, entry_id)) {
+				RTW_INFO(FUNC_ADPT_FMT" Root AP assigned success\n", FUNC_ADPT_ARG(adapter));
+				write_mbssid_cam(adapter, entry_id, val);
+			}
+		} else {
+			entry_id = rtw_mbid_camid_alloc(adapter, val);
+			if (entry_id != INVALID_CAM_ID)
+				write_mbssid_cam(adapter, entry_id, val);
+		}
+	}
+#else
+	{
+		/*
+			MBID entry_id = 0~7 ,for IFACE_ID0 ~ IFACE_IDx
+		*/
+		u8 entry_id = rtw_mbid_camid_alloc(adapter, mac_addr);
+
+
+		if (entry_id != INVALID_CAM_ID) {
+			write_mbssid_cam(adapter, entry_id, mac_addr);
+			RTW_INFO("%s "ADPT_FMT"- mbid(%d) mac_addr ="MAC_FMT"\n", __func__,
+				ADPT_ARG(adapter), entry_id, MAC_ARG(mac_addr));
+		}
+	}
+#endif
+}
+
+void rtw_hal_change_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
+{
+	u8 idx = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 entry_id;
+
+	if (!mac_addr) {
+		rtw_warn_on(1);
+		return;
+	}
+
+
+	entry_id = rtw_mbid_cam_info_change(adapter, mac_addr);
+
+	if (entry_id != INVALID_CAM_ID)
+		write_mbssid_cam(adapter, entry_id, mac_addr);
+}
+
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+u16 rtw_hal_bcn_interval_adjust(_adapter *adapter, u16 bcn_interval)
+{
+	if (adapter_to_dvobj(adapter)->inter_bcn_space != bcn_interval)
+		return adapter_to_dvobj(adapter)->inter_bcn_space;
+	else
+		return bcn_interval;
+}
+#endif/*CONFIG_SWTIMER_BASED_TXBCN*/
+
+#endif/*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
+
+static void rtw_hal_set_macaddr_port(_adapter *adapter, u8 *val)
 {
 	u8 idx = 0;
 	u32 reg_macid = 0;
+	enum _hw_port hwport;
 
 	if (val == NULL)
 		return;
+	hwport = get_hw_port(adapter);
 
 	RTW_INFO("%s "ADPT_FMT"- hw port(%d) mac_addr ="MAC_FMT"\n",  __func__,
-		 ADPT_ARG(adapter), adapter->hw_port, MAC_ARG(val));
+		 ADPT_ARG(adapter), hwport, MAC_ARG(val));
 
 #ifdef RTW_HALMAC
-	rtw_halmac_set_mac_address(adapter_to_dvobj(adapter), adapter->hw_port, val);
+	rtw_halmac_set_mac_address(adapter_to_dvobj(adapter), hwport, val);
 #else /* !RTW_HALMAC */
-	switch (adapter->hw_port) {
+	switch (hwport) {
 	case HW_PORT0:
 	default:
 		reg_macid = REG_MACID;
@@ -2670,7 +3231,7 @@ static void rtw_hal_set_macaddr_port(_adapter *adapter, u8 *val)
 #endif/*defined(CONFIG_RTL8814A)*/
 	}
 
-	for (idx = 0; idx < 6; idx++)
+	for (idx = 0; idx < ETH_ALEN; idx++)
 		rtw_write8(GET_PRIMARY_ADAPTER(adapter), (reg_macid + idx), val[idx]);
 #endif /* !RTW_HALMAC */
 }
@@ -2708,7 +3269,7 @@ static void rtw_hal_get_macaddr_port(_adapter *adapter, u8 *mac_addr)
 #endif /*defined(CONFIG_RTL8814A)*/
 	}
 
-	for (idx = 0; idx < 6; idx++)
+	for (idx = 0; idx < ETH_ALEN; idx++)
 		mac_addr[idx] = rtw_read8(GET_PRIMARY_ADAPTER(adapter), (reg_macid + idx));
 #endif /* !RTW_HALMAC */
 
@@ -2718,13 +3279,15 @@ static void rtw_hal_get_macaddr_port(_adapter *adapter, u8 *mac_addr)
 
 static void rtw_hal_set_bssid(_adapter *adapter, u8 *val)
 {
+	u8 hw_port = rtw_hal_get_port(adapter);
+
 #ifdef RTW_HALMAC
-	rtw_halmac_set_bssid(adapter_to_dvobj(adapter), adapter->hw_port, val);
+	rtw_halmac_set_bssid(adapter_to_dvobj(adapter), hw_port, val);
 #else /* !RTW_HALMAC */
 	u8	idx = 0;
 	u32 reg_bssid = 0;
 
-	switch (adapter->hw_port) {
+	switch (hw_port) {
 	case HW_PORT0:
 	default:
 		reg_bssid = REG_BSSID;
@@ -2732,7 +3295,7 @@ static void rtw_hal_set_bssid(_adapter *adapter, u8 *val)
 	case HW_PORT1:
 		reg_bssid = REG_BSSID1;
 		break;
-#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)
+#if defined(CONFIG_RTL8814A)
 	case HW_PORT2:
 		reg_bssid = REG_BSSID2;
 		break;
@@ -2742,14 +3305,211 @@ static void rtw_hal_set_bssid(_adapter *adapter, u8 *val)
 	case HW_PORT4:
 		reg_bssid = REG_BSSID4;
 		break;
-#endif/*defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)*/
+#endif/*defined(CONFIG_RTL8814A)*/
 	}
 
-	for (idx = 0 ; idx < 6; idx++)
+	for (idx = 0 ; idx < ETH_ALEN; idx++)
 		rtw_write8(adapter, (reg_bssid + idx), val[idx]);
 #endif /* !RTW_HALMAC */
 
-	RTW_INFO("%s "ADPT_FMT"- hw port -%d BSSID: "MAC_FMT"\n", __func__, ADPT_ARG(adapter), adapter->hw_port, MAC_ARG(val));
+	RTW_INFO("%s "ADPT_FMT"- hw port -%d BSSID: "MAC_FMT"\n",
+		__func__, ADPT_ARG(adapter), hw_port, MAC_ARG(val));
+}
+
+static void rtw_hal_set_tsf_update(_adapter *adapter, u8 en)
+{
+	u32 addr = 0;
+	u8 val8;
+
+	rtw_hal_get_hwreg(adapter, HW_VAR_BCN_CTRL_ADDR, (u8 *)&addr);
+	if (addr) {
+		val8 = rtw_read8(adapter, addr);
+		if (en && (val8 & DIS_TSF_UDT)) {
+			rtw_write8(adapter, addr, val8 & ~DIS_TSF_UDT);
+			#ifdef DBG_TSF_UPDATE
+			RTW_INFO("port%u("ADPT_FMT") enable TSF update\n", adapter->hw_port, ADPT_ARG(adapter));
+			#endif
+		}
+		if (!en && !(val8 & DIS_TSF_UDT)) {
+			rtw_write8(adapter, addr, val8 | DIS_TSF_UDT);
+			#ifdef DBG_TSF_UPDATE
+			RTW_INFO("port%u("ADPT_FMT") disable TSF update\n", adapter->hw_port, ADPT_ARG(adapter));
+			#endif
+		}
+	} else {
+		RTW_WARN("unknown port%d("ADPT_FMT") %s TSF update\n"
+			, adapter->hw_port, ADPT_ARG(adapter), en ? "enable" : "disable");
+		rtw_warn_on(1);
+	}
+}
+
+static void rtw_hal_set_hw_update_tsf(PADAPTER padapter)
+{
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_MI_WITH_MBSSID_CAM)
+	RTW_INFO("[Warn] %s "ADPT_FMT" enter func\n", __func__, ADPT_ARG(padapter));
+	rtw_warn_on(1);
+	return;
+#endif
+
+	if (!pmlmeext->en_hw_update_tsf)
+		return;
+
+	/* check RCR */
+	if (!rtw_hal_rcr_check(padapter, RCR_CBSSID_BCN))
+		return;
+
+	if (pmlmeext->tsf_update_required) {
+		pmlmeext->tsf_update_pause_stime = 0;
+		rtw_hal_set_tsf_update(padapter, 1);
+	}
+
+	pmlmeext->en_hw_update_tsf = 0;
+}
+
+void rtw_iface_enable_tsf_update(_adapter *adapter)
+{
+	adapter->mlmeextpriv.tsf_update_pause_stime = 0;
+	adapter->mlmeextpriv.tsf_update_required = 1;
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+
+#else
+	rtw_hal_set_tsf_update(adapter, 1);
+#endif
+}
+
+void rtw_iface_disable_tsf_update(_adapter *adapter)
+{
+	adapter->mlmeextpriv.tsf_update_required = 0;
+	adapter->mlmeextpriv.tsf_update_pause_stime = 0;
+	adapter->mlmeextpriv.en_hw_update_tsf = 0;
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+
+#else
+	rtw_hal_set_tsf_update(adapter, 0);
+#endif
+}
+
+static void rtw_hal_tsf_update_pause(_adapter *adapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+
+#else
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
+	int i;
+	u8 val8;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		rtw_hal_set_tsf_update(iface, 0);
+		if (iface->mlmeextpriv.tsf_update_required) {
+			iface->mlmeextpriv.tsf_update_pause_stime = rtw_get_current_time();
+			if (!iface->mlmeextpriv.tsf_update_pause_stime)
+				iface->mlmeextpriv.tsf_update_pause_stime++;
+		}
+		iface->mlmeextpriv.en_hw_update_tsf = 0;
+	}
+#endif
+}
+
+static void rtw_hal_tsf_update_restore(_adapter *adapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+
+#else
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
+	int i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		if (iface->mlmeextpriv.tsf_update_required) {
+			/* enable HW TSF update when recive beacon*/
+			iface->mlmeextpriv.en_hw_update_tsf = 1;
+			#ifdef DBG_TSF_UPDATE
+			RTW_INFO("port%d("ADPT_FMT") enabling TSF update...\n"
+				, iface->hw_port, ADPT_ARG(iface));
+			#endif
+		}
+	}
+#endif
+}
+
+void rtw_hal_periodic_tsf_update_chk(_adapter *adapter)
+{
+#ifdef CONFIG_MI_WITH_MBSSID_CAM
+
+#else
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
+	struct mlme_ext_priv *mlmeext;
+	int i;
+	u32 restore_ms = 0;
+
+	if (dvobj->periodic_tsf_update_etime) {
+		if (rtw_time_after(rtw_get_current_time(), dvobj->periodic_tsf_update_etime)) {
+			/* end for restore status */
+			dvobj->periodic_tsf_update_etime = 0;
+			rtw_hal_rcr_set_chk_bssid(adapter, MLME_ACTION_NONE);
+		}
+		return;
+	}
+
+	if (dvobj->rf_ctl.offch_state != OFFCHS_NONE)
+		return;
+
+	/*
+	* all required ifaces can switch to restore status together
+	* loop all pause iface to get largest restore time required
+	*/
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+
+		mlmeext = &iface->mlmeextpriv;
+
+		if (mlmeext->tsf_update_required
+			&& mlmeext->tsf_update_pause_stime
+			&& rtw_get_passing_time_ms(mlmeext->tsf_update_pause_stime)
+				> mlmeext->mlmext_info.bcn_interval * mlmeext->tsf_update_pause_factor
+		) {
+			if (restore_ms < mlmeext->mlmext_info.bcn_interval * mlmeext->tsf_update_restore_factor)
+				restore_ms = mlmeext->mlmext_info.bcn_interval * mlmeext->tsf_update_restore_factor;
+		}
+	}
+
+	if (!restore_ms)
+		return;
+
+	dvobj->periodic_tsf_update_etime = rtw_get_current_time() + rtw_ms_to_systime(restore_ms);
+	if (!dvobj->periodic_tsf_update_etime)
+		dvobj->periodic_tsf_update_etime++;
+
+	rtw_hal_rcr_set_chk_bssid(adapter, MLME_ACTION_NONE);
+
+	/* set timer to end restore status */
+	_set_timer(&dvobj->periodic_tsf_update_end_timer, restore_ms);
+#endif
+}
+
+void rtw_hal_periodic_tsf_update_end_timer_hdl(void *ctx)
+{
+	struct dvobj_priv *dvobj = (struct dvobj_priv *)ctx;
+
+	if (dev_is_surprise_removed(dvobj) || dev_is_drv_stopped(dvobj))
+		return;
+
+	rtw_periodic_tsf_update_end_cmd(dvobj_get_primary_adapter(dvobj));
 }
 
 static inline u8 hw_var_rcr_config(_adapter *adapter, u32 rcr)
@@ -2823,13 +3583,14 @@ inline u8 rtw_hal_rcr_clear(_adapter *adapter, u32 clear)
 void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	u32 rcr, rcr_new;
 	struct mi_state mstate, mstate_s;
 
 	rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
 	rcr_new = rcr;
 
-#ifdef CONFIG_MI_WITH_MBSSID_CAM
+#if defined(CONFIG_MI_WITH_MBSSID_CAM) && !defined(CONFIG_CLIENT_PORT_CFG)
 	rcr_new &= ~(RCR_CBSSID_BCN | RCR_CBSSID_DATA);
 #else
 	rtw_mi_status_no_self(adapter, &mstate);
@@ -2844,6 +3605,18 @@ void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action)
 	case MLME_SCAN_DONE:
 		mstate_s.scan_enter_num = 0;
 		break;
+	case MLME_STA_CONNECTING:
+		mstate_s.lg_sta_num = 1;
+		mstate_s.ld_sta_num = 0;
+		break;
+	case MLME_STA_CONNECTED:
+		mstate_s.lg_sta_num = 0;
+		mstate_s.ld_sta_num = 1;
+		break;
+	case MLME_STA_DISCONNECTED:
+		mstate_s.lg_sta_num = 0;
+		mstate_s.ld_sta_num = 0;
+		break;
 #ifdef CONFIG_TDLS
 	case MLME_TDLS_LINKED:
 		mstate_s.ld_tdls_num = 1;
@@ -2871,7 +3644,6 @@ void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action)
 		break;
 #endif
 	case MLME_ACTION_NONE:
-	case MLME_STA_CONNECTING:
 	case MLME_ADHOC_STARTED:
 		/* caller without effect of decision */
 		break;
@@ -2891,142 +3663,73 @@ void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action)
 	else
 		rcr_new |= RCR_CBSSID_DATA;
 
-	if ((MSTATE_AP_NUM(&mstate) && adapter->registrypriv.wifi_spec) /* for 11n Logo 4.2.31/4.2.32 */
+	if (MSTATE_SCAN_ENTER_NUM(&mstate) || hal_data->in_cta_test)
+		rcr_new &= ~RCR_CBSSID_BCN;
+	else if (MSTATE_STA_LG_NUM(&mstate)
+		|| adapter_to_dvobj(adapter)->periodic_tsf_update_etime
+	)
+		rcr_new |= RCR_CBSSID_BCN;
+	else if ((MSTATE_AP_NUM(&mstate) && adapter->registrypriv.wifi_spec) /* for 11n Logo 4.2.31/4.2.32 */
 		|| MSTATE_MESH_NUM(&mstate)
-		|| MSTATE_SCAN_ENTER_NUM(&mstate)
-		|| hal_data->in_cta_test
 	)
 		rcr_new &= ~RCR_CBSSID_BCN;	
 	else
 		rcr_new |= RCR_CBSSID_BCN;
-#endif /* CONFIG_MI_WITH_MBSSID_CAM */
-
-	if (rcr != rcr_new)
-		rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr_new);
-}
-
-static void hw_var_set_rcr_am(_adapter *adapter, u8 enable)
-{
-	u32 rcr = RCR_AM;
-
-	if (enable)
-		rtw_hal_rcr_add(adapter, rcr);
-	else
-		rtw_hal_rcr_clear(adapter, rcr);
-}
-
-static void rtw_hal_get_msr(_adapter *adapter, u8 *net_type)
-{
-#ifdef RTW_HALMAC
-	rtw_halmac_get_network_type(adapter_to_dvobj(adapter),
-				adapter->hw_port, net_type);
-#else /* !RTW_HALMAC */
-	switch (adapter->hw_port) {
-	case HW_PORT0:
-		/*REG_CR - BIT[17:16]-Network Type for port 1*/
-		*net_type = rtw_read8(adapter, MSR) & 0x03;
-		break;
-	case HW_PORT1:
-		/*REG_CR - BIT[19:18]-Network Type for port 1*/
-		*net_type = (rtw_read8(adapter, MSR) & 0x0C) >> 2;
-		break;
-#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)
-	case HW_PORT2:
-		/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
-		*net_type = rtw_read8(adapter, MSR1) & 0x03;
-		break;
-	case HW_PORT3:
-		/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
-		*net_type = (rtw_read8(adapter, MSR1) & 0x0C) >> 2;
-		break;
-	case HW_PORT4:
-		/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
-		*net_type = (rtw_read8(adapter, MSR1) & 0x30) >> 4;
-		break;
-#endif /*#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)*/
-	default:
-		RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
-			 ADPT_ARG(adapter), adapter->hw_port);
-		rtw_warn_on(1);
-		break;
-	}
-#endif /* !RTW_HALMAC */
-}
 
-#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM) /*For 2 hw ports - 88E/92E/8812/8821/8723B*/
-static u8 rtw_hal_net_type_decision(_adapter *adapter, u8 net_type)
-{
-	if ((adapter->hw_port == HW_PORT0) && (rtw_get_mbid_cam_entry_num(adapter))) {
-		if (net_type != _HW_STATE_NOLINK_)
-			return _HW_STATE_AP_;
-	}
-	return net_type;
-}
-#endif
-static void rtw_hal_set_msr(_adapter *adapter, u8 net_type)
-{
-#ifdef RTW_HALMAC
-	#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
-	net_type = rtw_hal_net_type_decision(adapter, net_type);
-	#endif
-	rtw_halmac_set_network_type(adapter_to_dvobj(adapter),
-				adapter->hw_port, net_type);
-#else /* !RTW_HALMAC */
-	u8 val8 = 0;
-
-	switch (adapter->hw_port) {
-	case HW_PORT0:
-		#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
-		net_type = rtw_hal_net_type_decision(adapter, net_type);
-		#endif
-		/*REG_CR - BIT[17:16]-Network Type for port 0*/
-		val8 = rtw_read8(adapter, MSR) & 0x0C;
-		val8 |= net_type;
-		rtw_write8(adapter, MSR, val8);
-		break;
-	case HW_PORT1:
-		/*REG_CR - BIT[19:18]-Network Type for port 1*/
-		val8 = rtw_read8(adapter, MSR) & 0x03;
-		val8 |= net_type << 2;
-		rtw_write8(adapter, MSR, val8);
-		break;
-#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
-	case HW_PORT2:
-		/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
-		val8 = rtw_read8(adapter, MSR1) & 0xFC;
-		val8 |= net_type;
-		rtw_write8(adapter, MSR1, val8);
-		break;
-	case HW_PORT3:
-		/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
-		val8 = rtw_read8(adapter, MSR1) & 0xF3;
-		val8 |= net_type << 2;
-		rtw_write8(adapter, MSR1, val8);
-		break;
-	case HW_PORT4:
-		/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
-		val8 = rtw_read8(adapter, MSR1) & 0xCF;
-		val8 |= net_type << 4;
-		rtw_write8(adapter, MSR1, val8);
-		break;
-#endif /* CONFIG_RTL8814A | CONFIG_RTL8822B */
-	default:
-		RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
-			 ADPT_ARG(adapter), adapter->hw_port);
-		rtw_warn_on(1);
-		break;
-	}
-#endif /* !RTW_HALMAC */
+	#ifdef CONFIG_CLIENT_PORT_CFG
+	if (get_clt_num(adapter) > MAX_CLIENT_PORT_NUM)
+		rcr_new &= ~RCR_CBSSID_BCN;
+	#endif
+#endif /* CONFIG_MI_WITH_MBSSID_CAM */
+
+	if (rcr == rcr_new)
+		return;
+
+	if (!hal_spec->rx_tsf_filter
+		&& (rcr & RCR_CBSSID_BCN) && !(rcr_new & RCR_CBSSID_BCN))
+		rtw_hal_tsf_update_pause(adapter);
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr_new);
+
+	if (!hal_spec->rx_tsf_filter
+		&& !(rcr & RCR_CBSSID_BCN) && (rcr_new & RCR_CBSSID_BCN)
+		&& self_action != MLME_STA_CONNECTING)
+		rtw_hal_tsf_update_restore(adapter);
+}
+
+static void hw_var_set_rcr_am(_adapter *adapter, u8 enable)
+{
+	u32 rcr = RCR_AM;
+
+	if (enable)
+		rtw_hal_rcr_add(adapter, rcr);
+	else
+		rtw_hal_rcr_clear(adapter, rcr);
 }
 
-static void hw_var_set_bcn_interval(struct _ADAPTER *a, u16 interval)
+static void hw_var_set_bcn_interval(_adapter *adapter, u16 interval)
 {
+#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	interval = rtw_hal_bcn_interval_adjust(adapter, interval);
+#endif
+
 #ifdef RTW_HALMAC
-	rtw_halmac_set_bcn_interval(adapter_to_dvobj(a), a->hw_port, interval);
-#else /* !RTW_HALMAC */
-	RTW_ERR(FUNC_ADPT_FMT ": Not implemented yet!!\n", FUNC_ADPT_ARG(a));
-	rtw_warn_on(1);
-#endif /* !RTW_HALMAC */
+	rtw_halmac_set_bcn_interval(adapter_to_dvobj(adapter), adapter->hw_port, interval);
+#else
+	rtw_write16(adapter, REG_MBSSID_BCN_SPACE, interval);
+#endif
+
+#ifdef CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
+	{
+		struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
+		struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+
+		if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
+			RTW_INFO("%s==> bcn_interval:%d, eraly_int:%d\n", __func__, interval, interval >> 1);
+			rtw_write8(adapter, REG_DRVERLYINT, interval >> 1);
+		}
+	}
+#endif
 }
 
 void hw_var_port_switch(_adapter *adapter)
@@ -3059,6 +3762,10 @@ void hw_var_port_switch(_adapter *adapter)
 	u8 bssid[6];
 	u8 macid_1[6];
 	u8 bssid_1[6];
+#if defined(CONFIG_RTL8192F)
+	u16 wlan_act_mask_ctrl = 0;
+	u16 en_port_mask = EN_PORT_0_FUNCTION | EN_PORT_1_FUNCTION;
+#endif
 
 	u8 hw_port;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
@@ -3067,6 +3774,9 @@ void hw_var_port_switch(_adapter *adapter)
 	msr = rtw_read8(adapter, MSR);
 	bcn_ctrl = rtw_read8(adapter, REG_BCN_CTRL);
 	bcn_ctrl_1 = rtw_read8(adapter, REG_BCN_CTRL_1);
+#if defined(CONFIG_RTL8192F)
+	wlan_act_mask_ctrl = rtw_read16(adapter, REG_WLAN_ACT_MASK_CTRL_1);
+#endif
 
 	for (i = 0; i < 2; i++)
 		atimwnd[i] = rtw_read8(adapter, REG_ATIMWND + i);
@@ -3095,6 +3805,9 @@ void hw_var_port_switch(_adapter *adapter)
 		 "msr:0x%02x\n"
 		 "bcn_ctrl:0x%02x\n"
 		 "bcn_ctrl_1:0x%02x\n"
+#if defined(CONFIG_RTL8192F)
+		 "wlan_act_mask_ctrl:0x%02x\n"
+#endif
 		 "atimwnd:0x%04x\n"
 		 "atimwnd_1:0x%04x\n"
 		 "tsftr:%llu\n"
@@ -3107,6 +3820,9 @@ void hw_var_port_switch(_adapter *adapter)
 		 , msr
 		 , bcn_ctrl
 		 , bcn_ctrl_1
+#if defined(CONFIG_RTL8192F)
+		 , wlan_act_mask_ctrl
+#endif
 		 , *((u16 *)atimwnd)
 		 , *((u16 *)atimwnd_1)
 		 , *((u64 *)tsftr)
@@ -3122,6 +3838,10 @@ void hw_var_port_switch(_adapter *adapter)
 	rtw_write8(adapter, REG_BCN_CTRL, (bcn_ctrl & (~EN_BCN_FUNCTION)) | DIS_TSF_UDT);
 	rtw_write8(adapter, REG_BCN_CTRL_1, (bcn_ctrl_1 & (~EN_BCN_FUNCTION)) | DIS_TSF_UDT);
 
+#if defined(CONFIG_RTL8192F)
+	rtw_write16(adapter, REG_WLAN_ACT_MASK_CTRL_1, wlan_act_mask_ctrl & ~en_port_mask);
+#endif
+
 	/* switch msr */
 	msr = (msr & 0xf0) | ((msr & 0x03) << 2) | ((msr & 0x0c) >> 2);
 	rtw_write8(adapter, MSR, msr);
@@ -3161,6 +3881,14 @@ void hw_var_port_switch(_adapter *adapter)
 	rtw_write8(adapter, REG_BCN_CTRL, bcn_ctrl_1);
 	rtw_write8(adapter, REG_BCN_CTRL_1, bcn_ctrl);
 
+#if defined(CONFIG_RTL8192F)
+	/* if the setting of port0 and port1 are the same, it does not need to switch port setting*/
+	if(((wlan_act_mask_ctrl & en_port_mask) != 0) && ((wlan_act_mask_ctrl & en_port_mask)
+		!= (EN_PORT_0_FUNCTION | EN_PORT_1_FUNCTION)))
+		wlan_act_mask_ctrl ^= en_port_mask;
+	rtw_write16(adapter, REG_WLAN_ACT_MASK_CTRL_1, wlan_act_mask_ctrl);
+#endif
+
 	if (adapter->iface_id == IFACE_ID0)
 		iface = dvobj->padapters[IFACE_ID1];
 	else if (adapter->iface_id == IFACE_ID1)
@@ -3183,6 +3911,9 @@ void hw_var_port_switch(_adapter *adapter)
 	msr = rtw_read8(adapter, MSR);
 	bcn_ctrl = rtw_read8(adapter, REG_BCN_CTRL);
 	bcn_ctrl_1 = rtw_read8(adapter, REG_BCN_CTRL_1);
+#if defined(CONFIG_RTL8192F)
+	wlan_act_mask_ctrl = rtw_read16(adapter, REG_WLAN_ACT_MASK_CTRL_1);
+#endif
 
 	for (i = 0; i < 2; i++)
 		atimwnd[i] = rtw_read8(adapter, REG_ATIMWND + i);
@@ -3210,6 +3941,9 @@ void hw_var_port_switch(_adapter *adapter)
 		 "msr:0x%02x\n"
 		 "bcn_ctrl:0x%02x\n"
 		 "bcn_ctrl_1:0x%02x\n"
+#if defined(CONFIG_RTL8192F)
+		 "wlan_act_mask_ctrl:0x%02x\n"
+#endif
 		 "atimwnd:%u\n"
 		 "atimwnd_1:%u\n"
 		 "tsftr:%llu\n"
@@ -3222,6 +3956,9 @@ void hw_var_port_switch(_adapter *adapter)
 		 , msr
 		 , bcn_ctrl
 		 , bcn_ctrl_1
+#if defined(CONFIG_RTL8192F)
+		 , wlan_act_mask_ctrl
+#endif
 		 , *((u16 *)atimwnd)
 		 , *((u16 *)atimwnd_1)
 		 , *((u64 *)tsftr)
@@ -3255,15 +3992,21 @@ s32 rtw_hal_set_default_port_id_cmd(_adapter *adapter, u8 mac_id)
 	s32 ret = _SUCCESS;
 	u8 parm[H2C_DEFAULT_PORT_ID_LEN] = {0};
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 port_id = rtw_hal_get_port(adapter);
+
+	if ((dvobj->dft.port_id == port_id) && (dvobj->dft.mac_id == mac_id))
+		return ret;
 
-	SET_H2CCMD_DFTPID_PORT_ID(parm, adapter->hw_port);
+	SET_H2CCMD_DFTPID_PORT_ID(parm, port_id);
 	SET_H2CCMD_DFTPID_MAC_ID(parm, mac_id);
 
 	RTW_DBG_DUMP("DFT port id parm:", parm, H2C_DEFAULT_PORT_ID_LEN);
-	RTW_INFO("%s port_id :%d, mad_id:%d\n", __func__, adapter->hw_port, mac_id);
+	RTW_INFO("%s ("ADPT_FMT") port_id :%d, mad_id:%d\n",
+		__func__, ADPT_ARG(adapter), port_id, mac_id);
 
 	ret = rtw_hal_fill_h2c_cmd(adapter, H2C_DEFAULT_PORT_ID, H2C_DEFAULT_PORT_ID_LEN, parm);
-	dvobj->default_port_id = adapter->hw_port;
+	dvobj->dft.port_id = port_id;
+	dvobj->dft.mac_id = mac_id;
 
 	return ret;
 }
@@ -3272,12 +4015,8 @@ s32 rtw_set_default_port_id(_adapter *adapter)
 	s32 ret = _SUCCESS;
 	struct sta_info		*psta;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-
-	if (adapter->hw_port == dvobj->default_port_id)
-		return ret;
 
-	if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
+	if (is_client_associated_to_ap(adapter)) {
 		psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
 		if (psta)
 			ret = rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
@@ -3292,9 +4031,9 @@ s32 rtw_set_ps_rsvd_page(_adapter *adapter)
 {
 	s32 ret = _SUCCESS;
 	u16 media_status_rpt = RT_MEDIA_CONNECT;
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 
-	if (adapter->hw_port == dvobj->default_port_id)
+	if (adapter->iface_id == pwrctl->fw_psmode_iface_id)
 		return ret;
 
 	rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
@@ -3303,7 +4042,123 @@ s32 rtw_set_ps_rsvd_page(_adapter *adapter)
 	return ret;
 }
 
+#if 0
+_adapter * _rtw_search_dp_iface(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
+	_adapter *target_iface = NULL;
+	int i;
+	u8 sta_num = 0, tdls_num = 0, ap_num = 0, mesh_num = 0, adhoc_num = 0;
+	u8 p2p_go_num = 0, p2p_gc_num = 0;
+	_adapter *sta_ifs[8];
+	_adapter *ap_ifs[8];
+	_adapter *mesh_ifs[8];
+	_adapter *gc_ifs[8];
+	_adapter *go_ifs[8];
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+
+		if (check_fwstate(&iface->mlmepriv, WIFI_STATION_STATE) == _TRUE) {
+			if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
+				sta_ifs[sta_num++] = iface;
+
+				#ifdef CONFIG_TDLS
+				if (iface->tdlsinfo.link_established == _TRUE)
+					tdls_num++;
+				#endif
+				#ifdef CONFIG_P2P
+				if (MLME_IS_GC(iface))
+					gc_ifs[p2p_gc_num++] = iface;
+				#endif
+			}
+#ifdef CONFIG_AP_MODE
+		} else if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE ) {
+			if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
+				ap_ifs[ap_num++] = iface;
+				#ifdef CONFIG_P2P
+				if (MLME_IS_GO(iface))
+					go_ifs[p2p_go_num++] = iface;
+				#endif
+			}
+#endif
+		} else if (check_fwstate(&iface->mlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) == _TRUE
+			&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
+		) {
+			adhoc_num++;
+
+#ifdef CONFIG_RTW_MESH
+		} else if (check_fwstate(&iface->mlmepriv, WIFI_MESH_STATE) == _TRUE
+			&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
+		) {
+			mesh_ifs[mesh_num++] = iface;
+#endif
+		}
+	}
+
+	if (p2p_gc_num) {
+		target_iface = gc_ifs[0];
+	}
+	else if (sta_num) {
+		if(sta_num == 1) {
+			target_iface = sta_ifs[0];
+		} else if (sta_num >= 2) {
+			/*TODO get target_iface by timestamp*/
+			target_iface = sta_ifs[0];
+		}
+	} else if (ap_num) {
+		target_iface = ap_ifs[0];
+	}
+
+	RTW_INFO("[IFS_ASSOC_STATUS] - STA :%d", sta_num);
+	RTW_INFO("[IFS_ASSOC_STATUS] - TDLS :%d", tdls_num);
+	RTW_INFO("[IFS_ASSOC_STATUS] - AP:%d", ap_num);
+	RTW_INFO("[IFS_ASSOC_STATUS] - MESH :%d", mesh_num);
+	RTW_INFO("[IFS_ASSOC_STATUS] - ADHOC :%d", adhoc_num);
+	RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GC :%d", p2p_gc_num);
+	RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GO :%d", p2p_go_num);
+
+	if (target_iface)
+		RTW_INFO("%s => target_iface ("ADPT_FMT")\n",
+			__func__, ADPT_ARG(target_iface));
+	else
+		RTW_INFO("%s => target_iface NULL\n", __func__);
+
+	return target_iface;
+}
+
+void rtw_search_default_port(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *adp_iface = NULL;
+#ifdef CONFIG_WOWLAN
+	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+
+	if (pwrpriv->wowlan_mode == _TRUE) {
+		adp_iface = adapter;
+		goto exit;
+	}
+#endif
+	adp_iface = _rtw_search_dp_iface(adapter);
+
+exit :
+	if ((adp_iface != NULL) && (MLME_IS_STA(adp_iface)))
+		rtw_set_default_port_id(adp_iface);
+	else
+		rtw_hal_set_default_port_id_cmd(adapter, 0);
+
+	if (1) {
+		_adapter *tmp_adp;
+
+		tmp_adp = (adp_iface) ? adp_iface : adapter;
+
+		RTW_INFO("%s ("ADPT_FMT")=> hw_port :%d, default_port(%d)\n",
+			__func__, ADPT_ARG(adapter), get_hw_port(tmp_adp), get_dft_portid(tmp_adp));
+	}
+}
 #endif
+#endif /*CONFIG_FW_MULTI_PORT_SUPPORT*/
 
 #ifdef CONFIG_P2P_PS
 #ifdef RTW_HALMAC
@@ -3319,11 +4174,12 @@ void rtw_set_p2p_ps_offload_cmd(_adapter *adapter, u8 p2p_ps_state)
 	HAL_P2P_PS_PARA p2p_ps_para;
 	int status = -1;
 	u8 i;
+	u8 hw_port = rtw_hal_get_port(adapter);
 
 	_rtw_memset(&p2p_ps_para, 0, sizeof(HAL_P2P_PS_PARA));
 	_rtw_memcpy((&p2p_ps_para) , &hal->p2p_ps_offload , sizeof(hal->p2p_ps_offload));
 
-	(&p2p_ps_para)->p2p_port_id = adapter->hw_port;
+	(&p2p_ps_para)->p2p_port_id = hw_port;
 	(&p2p_ps_para)->p2p_group = 0;
 	psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
 	if (psta) {
@@ -3367,6 +4223,13 @@ void rtw_set_p2p_ps_offload_cmd(_adapter *adapter, u8 p2p_ps_state)
 			/* To control the register setting for which NOA */
 			(&p2p_ps_para)->noa_sel = i;
 			(&p2p_ps_para)->noa_en = 1;
+			(&p2p_ps_para)->disable_close_rf = 0;
+#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+#ifdef CONFIG_CONCURRENT_MODE
+			if (rtw_mi_buddy_check_fwstate(adapter, WIFI_ASOC_STATE))
+#endif /* CONFIG_CONCURRENT_MODE */
+				(&p2p_ps_para)->disable_close_rf = 1;
+#endif /* CONFIG_P2P_PS_NOA_USE_MACID_SLEEP */
 			/* config P2P NoA Descriptor Register */
 			/* config NOA duration */
 			(&p2p_ps_para)->noa_duration_para = pwdinfo->noa_duration[i];
@@ -3448,6 +4311,9 @@ s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miraca
 	u8 parm[H2C_MEDIA_STATUS_RPT_LEN] = {0};
 	int i;
 	s32 ret;
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+	u8 hw_port = rtw_hal_get_port(adapter);
+#endif
 
 	SET_H2CCMD_MSRRPT_PARM_OPMODE(parm, opmode);
 	SET_H2CCMD_MSRRPT_PARM_MACID_IND(parm, macid_ind);
@@ -3457,7 +4323,7 @@ s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miraca
 	SET_H2CCMD_MSRRPT_PARM_MACID(parm, macid);
 	SET_H2CCMD_MSRRPT_PARM_MACID_END(parm, macid_end);
 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-	SET_H2CCMD_MSRRPT_PARM_PORT_NUM(parm, adapter->hw_port);
+	SET_H2CCMD_MSRRPT_PARM_PORT_NUM(parm, hw_port);
 #endif
 	RTW_DBG_DUMP("MediaStatusRpt parm:", parm, H2C_MEDIA_STATUS_RPT_LEN);
 
@@ -3556,8 +4422,10 @@ void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 
-	if (IS_8723D_SERIES(pHalData->version_id) || IS_8822B_SERIES(pHalData->version_id))
-		rtw_hal_set_hwreg(padapter, HW_SET_GPIO_WL_CTRL, (u8 *)(&enable));
+	if (IS_8723D_SERIES(pHalData->version_id) || IS_8192F_SERIES(pHalData->version_id)
+		|| IS_8822B_SERIES(pHalData->version_id) || IS_8821C_SERIES(pHalData->version_id)
+		/*|| IS_8822C_SERIES(pHalData->version_id)*/)
+			rtw_hal_set_hwreg(padapter, HW_SET_GPIO_WL_CTRL, (u8 *)(&enable));
 	/*
 	* Switch GPIO_13, GPIO_14 to wlan control, or pull GPIO_13,14 MUST fail.
 	* It happended at 8723B/8192E/8821A. New IC will check multi function GPIO,
@@ -3576,6 +4444,9 @@ void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable)
 
 void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval)
 {
+#if defined(CONFIG_RTL8192F)
+	rtw_hal_set_hwreg(padapter, HW_VAR_WOW_OUTPUT_GPIO, (u8 *)(&index));
+#else
 	if (index <= 7) {
 		/* config GPIO mode */
 		rtw_write8(padapter, REG_GPIO_PIN_CTRL + 3,
@@ -3625,9 +4496,13 @@ void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval)
 		RTW_INFO("%s: invalid GPIO%d=%d\n",
 			 __FUNCTION__, index, outputval);
 	}
+#endif
 }
 void rtw_hal_set_input_gpio(_adapter *padapter, u8 index)
 {
+#if defined(CONFIG_RTL8192F)
+	rtw_hal_set_hwreg(padapter, HW_VAR_WOW_INPUT_GPIO, (u8 *)(&index));
+#else
 	if (index <= 7) {
 		/* config GPIO mode */
 		rtw_write8(padapter, REG_GPIO_PIN_CTRL + 3,
@@ -3658,7 +4533,7 @@ void rtw_hal_set_input_gpio(_adapter *padapter, u8 index)
 			rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 2) & ~BIT(index));
 	} else
 		RTW_INFO("%s: invalid GPIO%d\n", __func__, index);
-
+#endif
 }
 
 #endif
@@ -3726,6 +4601,26 @@ void rtw_hal_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc
 #endif /* CONFIG_WOWLAN */
 }
 
+#ifdef DBG_FW_DEBUG_MSG_PKT
+void rtw_hal_set_fw_dbg_msg_pkt_rsvd_page_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
+{
+	struct	hal_ops *pHalFunc = &padapter->hal_func;
+	u8	u1H2C_fw_dbg_msg_pkt_parm[H2C_FW_DBG_MSG_PKT_LEN] = {0};
+	u8	ret = 0;
+
+
+	RTW_INFO("RsvdPageLoc: loc_fw_dbg_msg_pkt =%d\n", rsvdpageloc->loc_fw_dbg_msg_pkt);
+
+	SET_H2CCMD_FW_DBG_MSG_PKT_EN(u1H2C_fw_dbg_msg_pkt_parm, 1);
+	SET_H2CCMD_RSVDPAGE_LOC_FW_DBG_MSG_PKT(u1H2C_fw_dbg_msg_pkt_parm, rsvdpageloc->loc_fw_dbg_msg_pkt);
+	ret = rtw_hal_fill_h2c_cmd(padapter,
+				   H2C_FW_DBG_MSG_PKT,
+				   H2C_FW_DBG_MSG_PKT_LEN,
+				   u1H2C_fw_dbg_msg_pkt_parm);
+
+}
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
 /*#define DBG_GET_RSVD_PAGE*/
 int rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset,
 	u32 page_num, u8 *buffer, u32 buffer_size)
@@ -3736,6 +4631,14 @@ int rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset,
 	u8 i = 0;
 	bool rst = _FALSE;
 
+#ifdef DBG_LA_MODE
+	struct registry_priv *registry_par = &adapter->registrypriv;
+
+	if(registry_par->la_mode_en == 1) {
+		RTW_INFO("%s LA debug mode can't dump rsvd pg \n", __func__);
+		return rst;
+	}
+#endif
 	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
 
 	addr = page_offset * page_size;
@@ -3814,7 +4717,7 @@ void rtw_dump_rsvd_page(void *sel, _adapter *adapter, u8 page_offset, u8 page_nu
 void rtw_dump_fifo(void *sel, _adapter *adapter, u8 fifo_sel, u32 fifo_addr, u32 fifo_size)
 {
 	u8 *buffer = NULL;
-	u8 buff_size = 0;
+	u32 buff_size = 0;
 	static const char * const fifo_sel_str[] = {
 		"TX", "RX", "RSVD_PAGE", "REPORT", "LLT", "RXBUF_FW"
 	};
@@ -3879,7 +4782,7 @@ static void rtw_hal_release_rx_dma(_adapter *adapter)
 	rtw_write32(adapter, REG_RXPKT_NUM, (val32 & (~RW_RELEASE_EN)));
 
 	RTW_INFO("%s, [0x%04x]: 0x%08x\n",
-		 __func__, REG_RXPKT_NUM, (unsigned int)(val32 & (~RW_RELEASE_EN)));
+		 __func__, REG_RXPKT_NUM, (u32)(val32 & (~RW_RELEASE_EN)));
 }
 
 static u8 rtw_hal_pause_rx_dma(_adapter *adapter)
@@ -3999,11 +4902,11 @@ static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)
 	if (IS_HARDWARE_TYPE_JAGUAR2(adapter)) {
 		if (chk_type) {
 			reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
-			RTW_DBG("%s reason:0x%02x\n", __func__, reason);
+			RTW_INFO("%s reason:0x%02x\n", __func__, reason);
 
 			while (reason && trycnt > 1) {
 				reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
-				RTW_DBG("Loop index: %d :0x%02x\n",
+				RTW_PRINT("Loop index: %d :0x%02x\n",
 					  trycnt, reason);
 				trycnt--;
 				rtw_msleep_os(20);
@@ -4016,7 +4919,7 @@ static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)
 			/* Wait FW to cleare 0x120 bit16, 0x284 bit18 to 0 */
 			fe1_imr = rtw_read32(adapter, REG_FE1IMR); /* RxDone IMR for 3081 */
 			rxpkt_num = rtw_read32(adapter, REG_RXPKT_NUM); /* Release RXDMA */
-			RTW_DBG("%s REG_FE1IMR (reg120): 0x%x, REG_RXPKT_NUM(reg284): 0x%x\n", __func__, fe1_imr, rxpkt_num);
+			RTW_PRINT("%s REG_FE1IMR (reg120): 0x%x, REG_RXPKT_NUM(reg284): 0x%x\n", __func__, fe1_imr, rxpkt_num);
 
 			while (((fe1_imr & BIT_FS_RXDONE_INT_EN) || (rxpkt_num & BIT_RW_RELEASE_EN)) && trycnt > 1) {
 				rtw_msleep_os(20);
@@ -4034,13 +4937,13 @@ static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)
 		}
 	} else {
 		mstatus = rtw_read8(adapter, REG_WOW_CTRL);
-		RTW_DBG("%s mstatus:0x%02x\n", __func__, mstatus);
+		RTW_INFO("%s mstatus:0x%02x\n", __func__, mstatus);
 
 
 		if (chk_type) {
 			while (!(mstatus & BIT1) && trycnt > 1) {
 				mstatus = rtw_read8(adapter, REG_WOW_CTRL);
-				RTW_DBG("Loop index: %d :0x%02x\n",
+				RTW_PRINT("Loop index: %d :0x%02x\n",
 					  trycnt, mstatus);
 				trycnt--;
 				rtw_msleep_os(20);
@@ -4052,7 +4955,7 @@ static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)
 		} else {
 			while (mstatus & BIT1 && trycnt > 1) {
 				mstatus = rtw_read8(adapter, REG_WOW_CTRL);
-				RTW_DBG("Loop index: %d :0x%02x\n",
+				RTW_PRINT("Loop index: %d :0x%02x\n",
 					  trycnt, mstatus);
 				trycnt--;
 				rtw_msleep_os(20);
@@ -4065,7 +4968,7 @@ static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)
 		}
 	}
 
-	RTW_INFO("%s check_type: %d res: %d trycnt: %d\n",
+	RTW_PRINT("%s check_type: %d res: %d trycnt: %d\n",
 		  __func__, chk_type, res, (25 - trycnt));
 	return res;
 }
@@ -4080,7 +4983,7 @@ static u8 rtw_hal_check_pno_enabled(_adapter *adapter)
 	if (ppwrpriv->wowlan_pno_enable && ppwrpriv->wowlan_in_resume == _FALSE) {
 		res = rtw_read8(adapter, REG_PNO_STATUS);
 		while (!(res & BIT(7)) && count < 25) {
-			RTW_DBG("[%d] cmd: 0x81 REG_PNO_STATUS: 0x%02x\n",
+			RTW_INFO("[%d] cmd: 0x81 REG_PNO_STATUS: 0x%02x\n",
 				 count, res);
 			res = rtw_read8(adapter, REG_PNO_STATUS);
 			count++;
@@ -4119,7 +5022,7 @@ static void rtw_hal_fw_sync_cam_id(_adapter *adapter)
 	addr = get_bssid(pmlmepriv);
 
 	if (addr == NULL) {
-		RTW_ERR("%s: get bssid MAC addr fail!!\n", __func__);
+		RTW_INFO("%s: get bssid MAC addr fail!!\n", __func__);
 		return;
 	}
 
@@ -4149,8 +5052,8 @@ static void rtw_hal_update_gtk_offload_info(_adapter *adapter)
 	struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
 	_irqL irqL;
 	u8 get_key[16];
-	u8 gtk_id = 0, offset = 0, i = 0, sz = 0;
-	u64 replay_count = 0;
+	u8 gtk_id = 0, offset = 0, i = 0, sz = 0, aoac_rpt_ver = 0, has_rekey = _FALSE;
+	u64 replay_count = 0, tmp_iv_hdr = 0, pkt_pn = 0;
 
 	if (!MLME_IS_STA(adapter))
 		return;
@@ -4161,10 +5064,30 @@ static void rtw_hal_update_gtk_offload_info(_adapter *adapter)
 
 	/*read gtk key index*/
 	gtk_id = paoac_rpt->key_index;
+	aoac_rpt_ver = paoac_rpt->version_info;
+
+	if (aoac_rpt_ver == 0) {
+		/* initial verison */
+		if (gtk_id == 5)
+			has_rekey = _FALSE;
+		else
+			has_rekey = _TRUE;
+	} else if (aoac_rpt_ver >= 1) {
+		/* Add krack patch */
+		if (gtk_id == 5)
+			RTW_WARN("%s FW check iv fail\n", __func__);
 
-	if (gtk_id == 5 || gtk_id == 0) {
+		if (aoac_rpt_ver == 1)
+			RTW_WARN("%s aoac report version should be update to v2\n", __func__);
+
+		/* Fix key id mismatch */
+		if (aoac_rpt_ver == 2)
+			has_rekey = paoac_rpt->rekey_ok == 1 ? _TRUE : _FALSE;
+	}
+
+	if (has_rekey == _FALSE) {
 		RTW_INFO("%s no rekey event happened.\n", __func__);
-	} else if (gtk_id > 0 && gtk_id < 4) {
+	} else if (has_rekey == _TRUE) {
 		RTW_INFO("%s update security key.\n", __func__);
 		/*read key from sec-cam,for DK ,keyindex is equal to cam-id*/
 		rtw_sec_read_cam_ent(adapter, gtk_id,
@@ -4203,17 +5126,21 @@ static void rtw_hal_update_gtk_offload_info(_adapter *adapter)
 				&(paoac_rpt->group_key[offset]),
 				RTW_TKIP_MIC_LEN);
 		}
-		/* Update broadcast RX IV */
-		if (psecuritypriv->dot118021XGrpPrivacy == _AES_) {
-			sz = sizeof(psecuritypriv->iv_seq[0]);
-			for (i = 0 ; i < 4 ; i++)
-				_rtw_memset(psecuritypriv->iv_seq[i], 0, sz);
-		}
-
-		RTW_INFO("GTK (%d) "KEY_FMT"\n", gtk_id,
+		RTW_PRINT("GTK (%d) "KEY_FMT"\n", gtk_id,
 			KEY_ARG(psecuritypriv->dot118021XGrpKey[gtk_id].skey));
 	}
 
+	/* Update broadcast RX IV */
+	if (psecuritypriv->dot118021XGrpPrivacy == _AES_) {
+		sz = sizeof(psecuritypriv->iv_seq[0]);
+		for (i = 0 ; i < 4 ; i++) {
+			_rtw_memcpy(&tmp_iv_hdr, paoac_rpt->rxgtk_iv[i], sz);
+			tmp_iv_hdr = le64_to_cpu(tmp_iv_hdr);
+			pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
+			_rtw_memcpy(psecuritypriv->iv_seq[i], &pkt_pn, sz);
+		}
+	}
+
 	rtw_clean_dk_section(adapter);
 
 	rtw_write8(adapter, REG_SECCFG, 0x0c);
@@ -4230,6 +5157,7 @@ static void rtw_dump_aoac_rpt(_adapter *adapter)
 {
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 	struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
+	int i = 0;
 
 	RTW_INFO_DUMP("[AOAC-RPT] IV -", paoac_rpt->iv, 8);
 	RTW_INFO_DUMP("[AOAC-RPT] Replay counter of EAPOL key - ",
@@ -4237,6 +5165,15 @@ static void rtw_dump_aoac_rpt(_adapter *adapter)
 	RTW_INFO_DUMP("[AOAC-RPT] Group key - ", paoac_rpt->group_key, 32);
 	RTW_INFO("[AOAC-RPT] Key Index - %d\n", paoac_rpt->key_index);
 	RTW_INFO("[AOAC-RPT] Security Type - %d\n", paoac_rpt->security_type);
+	RTW_INFO("[AOAC-RPT] wow_pattern_idx - %d\n",
+		 paoac_rpt->wow_pattern_idx);
+	RTW_INFO("[AOAC-RPT] version_info - %d\n", paoac_rpt->version_info);
+	RTW_INFO("[AOAC-RPT] rekey_ok - %d\n", paoac_rpt->rekey_ok);
+	RTW_INFO_DUMP("[AOAC-RPT] RX PTK IV-", paoac_rpt->rxptk_iv, 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[0] IV-", paoac_rpt->rxgtk_iv[0], 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[1] IV-", paoac_rpt->rxgtk_iv[1], 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[2] IV-", paoac_rpt->rxgtk_iv[2], 8);
+	RTW_INFO_DUMP("[AOAC-RPT] RX GTK[3] IV-", paoac_rpt->rxgtk_iv[3], 8);
 }
 
 static void rtw_hal_get_aoac_rpt(_adapter *adapter)
@@ -4338,12 +5275,15 @@ static void rtw_hal_update_tx_iv(_adapter *adapter)
 static void rtw_hal_update_sw_security_info(_adapter *adapter)
 {
 	struct security_priv *psecpriv = &adapter->securitypriv;
+	u8 sz = sizeof (psecpriv->iv_seq);
 
 	rtw_hal_update_tx_iv(adapter);
 #ifdef CONFIG_GTK_OL
 	if (psecpriv->binstallKCK_KEK == _TRUE &&
 	    psecpriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK)
 		rtw_hal_update_gtk_offload_info(adapter);
+#else
+	_rtw_memset(psecpriv->iv_seq, 0, sz);
 #endif
 }
 
@@ -4354,14 +5294,15 @@ static u8 rtw_hal_set_keep_alive_cmd(_adapter *adapter, u8 enable, u8 pkt_type)
 	u8 u1H2CKeepAliveParm[H2C_KEEP_ALIVE_CTRL_LEN] = {0};
 	u8 adopt = 1, check_period = 5;
 	u8 ret = _FAIL;
+	u8 hw_port = rtw_hal_get_port(adapter);
 
 	SET_H2CCMD_KEEPALIVE_PARM_ENABLE(u1H2CKeepAliveParm, enable);
 	SET_H2CCMD_KEEPALIVE_PARM_ADOPT(u1H2CKeepAliveParm, adopt);
 	SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(u1H2CKeepAliveParm, pkt_type);
 	SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(u1H2CKeepAliveParm, check_period);
 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-	SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(u1H2CKeepAliveParm, adapter->hw_port);
-	RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, adapter->hw_port);
+	SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(u1H2CKeepAliveParm, hw_port);
+	RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, hw_port);
 #else
 	RTW_INFO("%s(): enable = %d\n", __func__, enable);
 #endif
@@ -4379,14 +5320,16 @@ static u8 rtw_hal_set_disconnect_decision_cmd(_adapter *adapter, u8 enable)
 	u8 u1H2CDisconDecisionParm[H2C_DISCON_DECISION_LEN] = {0};
 	u8 adopt = 1, check_period = 30, trypkt_num = 5;
 	u8 ret = _FAIL;
+	u8 hw_port = rtw_hal_get_port(adapter);
 
 	SET_H2CCMD_DISCONDECISION_PARM_ENABLE(u1H2CDisconDecisionParm, enable);
 	SET_H2CCMD_DISCONDECISION_PARM_ADOPT(u1H2CDisconDecisionParm, adopt);
+	/* SET_H2CCMD_DISCONDECISION_PARM_DISCONNECT_EN(u1H2CDisconDecisionParm, adopt); */
 	SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(u1H2CDisconDecisionParm, check_period);
 	SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(u1H2CDisconDecisionParm, trypkt_num);
 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-	SET_H2CCMD_DISCONDECISION_PORT_NUM(u1H2CDisconDecisionParm, adapter->hw_port);
-	RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, adapter->hw_port);
+	SET_H2CCMD_DISCONDECISION_PORT_NUM(u1H2CDisconDecisionParm, hw_port);
+	RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, hw_port);
 #else
 	RTW_INFO("%s(): enable = %d\n", __func__, enable);
 #endif
@@ -4404,9 +5347,10 @@ static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_un
 	struct security_priv *psecpriv = &adapter->securitypriv;
 	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
 	struct hal_ops *pHalFunc = &adapter->hal_func;
+	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
 
 	u8 u1H2CWoWlanCtrlParm[H2C_WOWLAN_LEN] = {0};
-	u8 discont_wake = 0, gpionum = 0, gpio_dur = 0;
+	u8 discont_wake = 0, gpionum = 0, gpio_dur = 0, no_wake = 0;
 	u8 hw_unicast = 0, gpio_pulse_cnt = 0, gpio_pulse_en = 0;
 	u8 sdio_wakeup_enable = 1;
 	u8 gpio_high_active = 0;
@@ -4422,17 +5366,21 @@ static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_un
 	gpionum = WAKEUP_GPIO_IDX;
 	sdio_wakeup_enable = 0;
 #endif /* CONFIG_GPIO_WAKEUP */
-
+	
+	if(registry_par->suspend_type == FW_IPS_DISABLE_BBRF &&
+	!check_fwstate(pmlmepriv, _FW_LINKED))
+		no_wake = 1;
+		
 	if (!ppwrpriv->wowlan_pno_enable &&
-	    registry_par->wakeup_event & BIT(0))
+		registry_par->wakeup_event & BIT(0) && !no_wake)
 		magic_pkt = enable;
 
 	if ((registry_par->wakeup_event & BIT(1)) &&
-	    (psecpriv->dot11PrivacyAlgrthm == _WEP40_ ||
-	     psecpriv->dot11PrivacyAlgrthm == _WEP104_))
+		(psecpriv->dot11PrivacyAlgrthm == _WEP40_ ||
+		psecpriv->dot11PrivacyAlgrthm == _WEP104_) && !no_wake)
 			hw_unicast = 1;
 
-	if (registry_par->wakeup_event & BIT(2))
+	if (registry_par->wakeup_event & BIT(2) && !no_wake)
 		discont_wake = enable;
 
 	RTW_INFO("%s(): enable=%d change_unit=%d\n", __func__,
@@ -4451,6 +5399,7 @@ static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_un
 		gpio_pulse_cnt = 0x04;
 	}
 #endif
+
 	if (enable) {
 		RTW_INFO("gpio_pulse_en\n");
 		gpio_pulse_en = 1;
@@ -4458,7 +5407,8 @@ static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_un
 	}
 
 	SET_H2CCMD_WOWLAN_FUNC_ENABLE(u1H2CWoWlanCtrlParm, enable);
-	SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(u1H2CWoWlanCtrlParm, enable);
+	if(!no_wake)
+		SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(u1H2CWoWlanCtrlParm, enable);
 	SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(u1H2CWoWlanCtrlParm, magic_pkt);
 	SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(u1H2CWoWlanCtrlParm, hw_unicast);
 	SET_H2CCMD_WOWLAN_ALL_PKT_DROP(u1H2CWoWlanCtrlParm, 0);
@@ -4496,10 +5446,18 @@ static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_un
 		dis_uphy_time = 0x4;
 	}
 
-	SET_H2CCMD_WOWLAN_DIS_UPHY(u1H2CWoWlanCtrlParm, dis_uphy);
-	SET_H2CCMD_WOWLAN_HOST_2_DEV(u1H2CWoWlanCtrlParm, 1);
-	SET_H2CCMD_WOWLAN_DIS_UPHY_UNIT(u1H2CWoWlanCtrlParm, dis_uphy_unit);
-	SET_H2CCMD_WOWLAN_DIS_UPHY_TIME(u1H2CWoWlanCtrlParm, dis_uphy_time);
+	SET_H2CCMD_WOWLAN_DISABLE_UPHY(u1H2CWoWlanCtrlParm, dis_uphy);
+	SET_H2CCMD_WOWLAN_UNIT_FOR_UPHY_DISABLE(u1H2CWoWlanCtrlParm, dis_uphy_unit);
+	SET_H2CCMD_WOWLAN_TIME_FOR_UPHY_DISABLE(u1H2CWoWlanCtrlParm, dis_uphy_time);
+	if (ppwrpriv->hst2dev_high_active == 1)
+		SET_H2CCMD_WOWLAN_RISE_HST2DEV(u1H2CWoWlanCtrlParm, 1);
+#ifdef CONFIG_RTW_ONE_PIN_GPIO
+	SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(u1H2CWoWlanCtrlParm, 1);
+	SET_H2CCMD_WOWLAN_DEV2HST_EN(u1H2CWoWlanCtrlParm, 1);
+	SET_H2CCMD_WOWLAN_HST2DEV_EN(u1H2CWoWlanCtrlParm, 0);
+#else
+	SET_H2CCMD_WOWLAN_HST2DEV_EN(u1H2CWoWlanCtrlParm, 1);
+#endif /* CONFIG_RTW_ONE_PIN_GPIO */
 #endif /* CONFIG_DIS_UPHY */
 
 
@@ -4517,89 +5475,105 @@ static u8 rtw_hal_set_remote_wake_ctrl_cmd(_adapter *adapter, u8 enable)
 	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
 	struct registry_priv *pregistrypriv = &adapter->registrypriv;
 	u8 u1H2CRemoteWakeCtrlParm[H2C_REMOTE_WAKE_CTRL_LEN] = {0};
-	u8 ret = _FAIL, count = 0;
+	u8 ret = _FAIL, count = 0, no_wake = 0;
+	struct mlme_priv	*pmlmepriv = &(adapter->mlmepriv);
 
 	RTW_INFO("%s(): enable=%d\n", __func__, enable);
 
-	if (!ppwrpriv->wowlan_pno_enable) {
+	if(pregistrypriv->suspend_type == FW_IPS_DISABLE_BBRF &&
+	!check_fwstate(pmlmepriv, _FW_LINKED))
+		no_wake = 1;
+	if(no_wake) {
 		SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
 			u1H2CRemoteWakeCtrlParm, enable);
-		SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(
-			u1H2CRemoteWakeCtrlParm, 1);
-#ifdef CONFIG_GTK_OL
-		if (psecuritypriv->binstallKCK_KEK == _TRUE &&
-		    psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
-			SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
-				u1H2CRemoteWakeCtrlParm, 1);
-		} else {
-			RTW_INFO("no kck kek\n");
-			SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
-				u1H2CRemoteWakeCtrlParm, 0);
-		}
-#endif /* CONFIG_GTK_OL */
-
-#ifdef CONFIG_IPV6
-		if (ppwrpriv->wowlan_ns_offload_en == _TRUE) {
-			RTW_INFO("enable NS offload\n");
-			SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(
+	} else {
+		if (!ppwrpriv->wowlan_pno_enable) {
+			SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
 				u1H2CRemoteWakeCtrlParm, enable);
-		}
-
-		/*
-		 * filter NetBios name service pkt to avoid being waked-up
-		 * by this kind of unicast pkt this exceptional modification
-		 * is used for match competitor's behavior
-		 */
-
-		SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(
-			u1H2CRemoteWakeCtrlParm, enable);
-#endif /*CONFIG_IPV6*/
-
-		if ((psecuritypriv->dot11PrivacyAlgrthm == _AES_) ||
-			(psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) ||
-			(psecuritypriv->dot11PrivacyAlgrthm == _NO_PRIVACY_)) {
-			SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
-				u1H2CRemoteWakeCtrlParm, 0);
-		} else {
-			SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
+			SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(
 				u1H2CRemoteWakeCtrlParm, 1);
-		}
-
-		if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_ &&
-		    psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
-			SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
+	#ifdef CONFIG_GTK_OL
+			if (psecuritypriv->binstallKCK_KEK == _TRUE &&
+			    psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
+				SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
+					u1H2CRemoteWakeCtrlParm, 1);
+			} else {
+				RTW_INFO("no kck kek\n");
+				SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
+					u1H2CRemoteWakeCtrlParm, 0);
+			}
+	#endif /* CONFIG_GTK_OL */
+	
+	#ifdef CONFIG_IPV6
+			if (ppwrpriv->wowlan_ns_offload_en == _TRUE) {
+				RTW_INFO("enable NS offload\n");
+				SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(
 					u1H2CRemoteWakeCtrlParm, enable);
-
-			if (IS_HARDWARE_TYPE_8188E(adapter) ||
-			    IS_HARDWARE_TYPE_8812(adapter)) {
-				SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
+			}
+	
+			/*
+			 * filter NetBios name service pkt to avoid being waked-up
+			 * by this kind of unicast pkt this exceptional modification
+			 * is used for match competitor's behavior
+			 */
+	
+			SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(
+				u1H2CRemoteWakeCtrlParm, enable);
+	#endif /*CONFIG_IPV6*/
+	
+	#ifdef CONFIG_RTL8192F
+			if (IS_HARDWARE_TYPE_8192F(adapter)){
+				SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(
+					u1H2CRemoteWakeCtrlParm, enable);
+			}
+	#endif /* CONFIG_RTL8192F */
+	
+			if ((psecuritypriv->dot11PrivacyAlgrthm == _AES_) ||
+				(psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) ||
+				(psecuritypriv->dot11PrivacyAlgrthm == _NO_PRIVACY_)) {
+				SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
 					u1H2CRemoteWakeCtrlParm, 0);
+			} else {
 				SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
 					u1H2CRemoteWakeCtrlParm, 1);
 			}
+	
+			if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_ &&
+			    psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
+				SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
+						u1H2CRemoteWakeCtrlParm, enable);
+	
+				if (IS_HARDWARE_TYPE_8188E(adapter) ||
+				    IS_HARDWARE_TYPE_8812(adapter)) {
+					SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
+						u1H2CRemoteWakeCtrlParm, 0);
+					SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
+						u1H2CRemoteWakeCtrlParm, 1);
+				}
+			}
+	
+			SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(
+				u1H2CRemoteWakeCtrlParm, 1);
 		}
-
-		SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(
-			u1H2CRemoteWakeCtrlParm, 1);
-	}
-#ifdef CONFIG_PNO_SUPPORT
-	else {
-		SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
-			u1H2CRemoteWakeCtrlParm, enable);
-		SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(
-			u1H2CRemoteWakeCtrlParm, enable);
-	}
-#endif
-
-#ifdef CONFIG_P2P_WOWLAN
-	if (_TRUE == ppwrpriv->wowlan_p2p_mode) {
-		RTW_INFO("P2P OFFLOAD ENABLE\n");
-		SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 1);
-	} else {
-		RTW_INFO("P2P OFFLOAD DISABLE\n");
-		SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 0);
+	#ifdef CONFIG_PNO_SUPPORT
+		else {
+			SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
+				u1H2CRemoteWakeCtrlParm, enable);
+			SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(
+				u1H2CRemoteWakeCtrlParm, enable);
+		}
+	#endif
+	
+	#ifdef CONFIG_P2P_WOWLAN
+		if (_TRUE == ppwrpriv->wowlan_p2p_mode) {
+			RTW_INFO("P2P OFFLOAD ENABLE\n");
+			SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 1);
+		} else {
+			RTW_INFO("P2P OFFLOAD DISABLE\n");
+			SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 0);
+		}
+	#endif /* CONFIG_P2P_WOWLAN */
 	}
-#endif /* CONFIG_P2P_WOWLAN */
 
 
 	ret = rtw_hal_fill_h2c_cmd(adapter,
@@ -4615,7 +5589,7 @@ static u8 rtw_hal_set_global_info_cmd(_adapter *adapter, u8 group_alg, u8 pairwi
 	u8 ret = _FAIL;
 	u8 u1H2CAOACGlobalInfoParm[H2C_AOAC_GLOBAL_INFO_LEN] = {0};
 
-	RTW_DBG("%s(): group_alg=%d pairwise_alg=%d\n",
+	RTW_INFO("%s(): group_alg=%d pairwise_alg=%d\n",
 		 __func__, group_alg, pairwise_alg);
 	SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(u1H2CAOACGlobalInfoParm,
 			pairwise_alg);
@@ -4640,7 +5614,7 @@ static u8 rtw_hal_set_scan_offload_info_cmd(_adapter *adapter,
 	u8 u1H2CScanOffloadInfoParm[H2C_SCAN_OFFLOAD_CTRL_LEN] = {0};
 	u8 res = 0, count = 0, ret = _FAIL;
 
-	RTW_DBG("%s: loc_probe_packet:%d, loc_scan_info: %d loc_ssid_info:%d\n",
+	RTW_INFO("%s: loc_probe_packet:%d, loc_scan_info: %d loc_ssid_info:%d\n",
 		 __func__, rsvdpageloc->LocProbePacket,
 		 rsvdpageloc->LocScanInfo, rsvdpageloc->LocSSIDInfo);
 
@@ -4670,18 +5644,25 @@ void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable)
 	struct registry_priv *pregistry = &padapter->registrypriv;
 	struct sta_info *psta = NULL;
 	u16 media_status_rpt;
-	u8	pkt_type = 0;
+	u8	pkt_type = 0, no_wake = 0;
 	u8 ret = _SUCCESS;
+	
+	if(pregistry->suspend_type == FW_IPS_DISABLE_BBRF &&
+	!check_fwstate(pmlmepriv, _FW_LINKED))
+		no_wake = 1;
+
+	RTW_PRINT("+%s()+: enable=%d\n", __func__, enable);
 
 	rtw_hal_set_wowlan_ctrl_cmd(padapter, enable, _FALSE);
 
 	if (enable) {
-		rtw_hal_set_global_info_cmd(padapter,
+		if(!no_wake)
+			rtw_hal_set_global_info_cmd(padapter,
 					    psecpriv->dot118021XGrpPrivacy,
 					    psecpriv->dot11PrivacyAlgrthm);
 
 		if (!(ppwrpriv->wowlan_pno_enable)) {
-			if (pregistry->wakeup_event & BIT(2))
+			if (pregistry->wakeup_event & BIT(2) && !no_wake)
 				rtw_hal_set_disconnect_decision_cmd(padapter,
 								    enable);
 #ifdef CONFIG_ARP_KEEP_ALIVE
@@ -4693,7 +5674,8 @@ void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable)
 #else
 			pkt_type = 0;
 #endif /* CONFIG_ARP_KEEP_ALIVE */
-			rtw_hal_set_keep_alive_cmd(padapter, enable, pkt_type);
+			if(!no_wake)
+				rtw_hal_set_keep_alive_cmd(padapter, enable, pkt_type);
 		}
 		rtw_hal_set_remote_wake_ctrl_cmd(padapter, enable);
 #ifdef CONFIG_PNO_SUPPORT
@@ -4710,6 +5692,7 @@ void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable)
 
 		rtw_hal_set_remote_wake_ctrl_cmd(padapter, enable);
 	}
+	RTW_PRINT("-%s()-\n", __func__);
 }
 #endif /* CONFIG_WOWLAN */
 
@@ -4733,7 +5716,7 @@ static u8 rtw_hal_set_ap_wowlan_ctrl_cmd(_adapter *adapter, u8 enable)
 	sdio_wakeup_enable = 0;
 #endif /*CONFIG_GPIO_WAKEUP*/
 
-	RTW_DBG("%s(): enable=%d\n", __func__, enable);
+	RTW_INFO("%s(): enable=%d\n", __func__, enable);
 
 	SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(u1H2CAPWoWlanCtrlParm,
 					  gpionum);
@@ -4760,7 +5743,7 @@ static u8 rtw_hal_set_ap_offload_ctrl_cmd(_adapter *adapter, u8 enable)
 	u8 u1H2CAPOffloadCtrlParm[H2C_WOWLAN_LEN] = {0};
 	u8 ret = _FAIL;
 
-	RTW_DBG("%s(): bFuncEn=%d\n", __func__, enable);
+	RTW_INFO("%s(): bFuncEn=%d\n", __func__, enable);
 
 	SET_H2CCMD_AP_WOWLAN_EN(u1H2CAPOffloadCtrlParm, enable);
 
@@ -4778,7 +5761,7 @@ static u8 rtw_hal_set_ap_ps_cmd(_adapter *adapter, u8 enable)
 	u8 ap_ps_parm[H2C_AP_PS_LEN] = {0};
 	u8 ret = _FAIL;
 
-	RTW_DBG("%s(): enable=%d\n" , __func__ , enable);
+	RTW_INFO("%s(): enable=%d\n" , __func__ , enable);
 
 	SET_H2CCMD_AP_WOW_PS_EN(ap_ps_parm, enable);
 #ifndef CONFIG_USB_HCI
@@ -4805,7 +5788,7 @@ static void rtw_hal_set_ap_rsvdpage_loc_cmd(PADAPTER padapter,
 	u8 ret = _FAIL, header = 0;
 
 	if (pHalFunc->fill_h2c_cmd == NULL) {
-		RTW_ERR("%s: Please hook fill_h2c_cmd first!\n", __func__);
+		RTW_INFO("%s: Please hook fill_h2c_cmd first!\n", __func__);
 		return;
 	}
 
@@ -4823,7 +5806,7 @@ static void rtw_hal_set_ap_rsvdpage_loc_cmd(PADAPTER padapter,
 				   H2C_BCN_RSVDPAGE_LEN, rsvdparm);
 
 	if (ret == _FAIL)
-		RTW_WARN("%s: H2C_BCN_RSVDPAGE cmd fail\n", __func__);
+		RTW_INFO("%s: H2C_BCN_RSVDPAGE cmd fail\n", __func__);
 
 	rtw_msleep_os(10);
 
@@ -4836,7 +5819,7 @@ static void rtw_hal_set_ap_rsvdpage_loc_cmd(PADAPTER padapter,
 				   H2C_PROBERSP_RSVDPAGE_LEN, rsvdparm);
 
 	if (ret == _FAIL)
-		RTW_WARN("%s: H2C_PROBERSP_RSVDPAGE cmd fail\n", __func__);
+		RTW_INFO("%s: H2C_PROBERSP_RSVDPAGE cmd fail\n", __func__);
 
 	rtw_msleep_os(10);
 }
@@ -4867,7 +5850,7 @@ static void rtw_hal_ap_wow_enable(_adapter *padapter)
 #ifdef DBG_CHECK_FW_PS_STATE
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
 		pdbgpriv->dbg_enwow_dload_fw_fail_cnt++;
-		RTW_WARN("wowlan enable no leave 32k\n");
+		RTW_PRINT("wowlan enable no leave 32k\n");
 	}
 #endif /*DBG_CHECK_FW_PS_STATE*/
 
@@ -4888,20 +5871,20 @@ static void rtw_hal_ap_wow_enable(_adapter *padapter)
 	/* RX DMA stop */
 	res = rtw_hal_pause_rx_dma(padapter);
 	if (res == _FAIL)
-		RTW_WARN("[WARNING] pause RX DMA fail\n");
+		RTW_PRINT("[WARNING] pause RX DMA fail\n");
 
 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
 	/* Enable CPWM2 only. */
 	res = rtw_hal_enable_cpwm2(padapter);
 	if (res == _FAIL)
-		RTW_WARN("[WARNING] enable cpwm2 fail\n");
+		RTW_PRINT("[WARNING] enable cpwm2 fail\n");
 #endif
 
 #ifdef CONFIG_GPIO_WAKEUP
 	rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
 #endif
 	/* 5. Set Enable WOWLAN H2C command. */
-	RTW_DBG("Set Enable AP WOWLan cmd\n");
+	RTW_PRINT("Set Enable AP WOWLan cmd\n");
 	rtw_hal_set_fw_ap_wow_related_cmd(padapter, 1);
 
 	rtw_write8(padapter, REG_MCUTST_WOWLAN, 0);
@@ -4911,7 +5894,8 @@ static void rtw_hal_ap_wow_enable(_adapter *padapter)
 #if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
 	/* Invoid SE0 reset signal during suspending*/
 	rtw_write8(padapter, REG_RSV_CTRL, 0x20);
-	if (IS_8188F(pHalData->version_id) == FALSE)
+	if (IS_8188F(pHalData->version_id) == FALSE
+		&& IS_8188GTV(pHalData->version_id) == FALSE)
 		rtw_write8(padapter, REG_RSV_CTRL, 0x60);
 #endif
 }
@@ -4931,7 +5915,7 @@ static void rtw_hal_ap_wow_disable(_adapter *padapter)
 	/* 1. Read wakeup reason*/
 	pwrctl->wowlan_wake_reason = rtw_read8(padapter, REG_MCUTST_WOWLAN);
 
-	RTW_INFO("%s: wakeup_reason: 0x%02x\n", __func__,
+	RTW_PRINT("wakeup_reason: 0x%02x\n",
 		  pwrctl->wowlan_wake_reason);
 
 	rtw_hal_set_fw_ap_wow_related_cmd(padapter, 0);
@@ -4940,7 +5924,7 @@ static void rtw_hal_ap_wow_disable(_adapter *padapter)
 #ifdef DBG_CHECK_FW_PS_STATE
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
 		pdbgpriv->dbg_diswow_dload_fw_fail_cnt++;
-		RTW_WARN("wowlan enable no leave 32k\n");
+		RTW_PRINT("wowlan enable no leave 32k\n");
 	}
 #endif /*DBG_CHECK_FW_PS_STATE*/
 
@@ -4954,6 +5938,9 @@ static void rtw_hal_ap_wow_disable(_adapter *padapter)
 	rtw_hal_fw_dl(padapter, _FALSE);
 
 #ifdef CONFIG_GPIO_WAKEUP
+#ifdef CONFIG_RTW_ONE_PIN_GPIO
+	rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
+#else
 	#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
 	if (pwrctl->is_high_active == 0)
 		rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
@@ -4961,11 +5948,12 @@ static void rtw_hal_ap_wow_disable(_adapter *padapter)
 		rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
 	#else
 	val8 = (pwrctl->is_high_active == 0) ? 1 : 0;
-	RTW_INFO("%s: Set Wake GPIO to default(%d).\n", __func__, val8);
+	RTW_PRINT("Set Wake GPIO to default(%d).\n", val8);
 	rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
 
 	rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _FALSE);
 	#endif/*CONFIG_WAKEUP_GPIO_INPUT_MODE*/
+#endif /* CONFIG_RTW_ONE_PIN_GPIO */
 #endif
 	media_status_rpt = RT_MEDIA_CONNECT;
 
@@ -6442,7 +7430,7 @@ u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter)
 }
 #endif /* CONFIG_P2P_WOWLAN */
 
-static void rtw_hal_construct_beacon(_adapter *padapter,
+void rtw_hal_construct_beacon(_adapter *padapter,
 				     u8 *pframe, u32 *pLength)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
@@ -6482,6 +7470,7 @@ static void rtw_hal_construct_beacon(_adapter *padapter,
 	pframe += 2;
 	pktlen += 2;
 
+#if 0
 	/* capability info: 2 bytes */
 	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
 
@@ -6524,13 +7513,15 @@ static void rtw_hal_construct_beacon(_adapter *padapter,
 	if (rate_len > 8)
 		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pktlen);
 
-
 	/* todo:HT for adhoc */
+#endif
 
 _ConstructBeacon:
 
-	if ((pktlen + TXDESC_SIZE) > 512) {
-		RTW_INFO("beacon frame too large\n");
+	if ((pktlen + TXDESC_SIZE) > MAX_BEACON_LEN) {
+		RTW_ERR("beacon frame too large ,len(%d,%d)\n",
+			(pktlen + TXDESC_SIZE), MAX_BEACON_LEN);
+		rtw_warn_on(1);
 		return;
 	}
 
@@ -6571,11 +7562,48 @@ static void rtw_hal_construct_PSPoll(_adapter *padapter,
 	*pLength = 16;
 }
 
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+void rtw_hal_construct_fw_dbg_msg_pkt(
+	PADAPTER padapter,
+	u8		*pframe,
+	u32		*plength)
+{
+	struct rtw_ieee80211_hdr	*pwlanhdr;
+	u16						*fctrl;
+	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);
+	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+
+	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
+
+	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
+
+	fctrl = &pwlanhdr->frame_ctl;
+	*(fctrl) = 0;
+
+	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
+
+	SetSeqNum(pwlanhdr, 0);
+
+	set_frame_sub_type(pframe, WIFI_DATA);
+
+	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
+
+	*plength = pktlen;
+}
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
 void rtw_hal_construct_NullFunctionData(
 	PADAPTER padapter,
 	u8		*pframe,
 	u32		*pLength,
-	u8		*StaAddr,
 	u8		bQoS,
 	u8		AC,
 	u8		bEosp,
@@ -6588,7 +7616,8 @@ void rtw_hal_construct_NullFunctionData(
 	struct wlan_network		*cur_network = &pmlmepriv->cur_network;
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
+	u8 *sta_addr = NULL;
+	u8 bssid[ETH_ALEN] = {0};
 
 	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
 
@@ -6599,28 +7628,35 @@ void rtw_hal_construct_NullFunctionData(
 	if (bForcePowerSave)
 		SetPwrMgt(fctrl);
 
+	sta_addr = get_my_bssid(&pmlmeinfo->network);
+	if (NULL == sta_addr) {
+		_rtw_memcpy(bssid, adapter_mac_addr(padapter), ETH_ALEN);
+		sta_addr = bssid;
+	}
+
 	switch (cur_network->network.InfrastructureMode) {
 	case Ndis802_11Infrastructure:
 		SetToDs(fctrl);
 		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, StaAddr, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr3, sta_addr, ETH_ALEN);
 		break;
 	case Ndis802_11APMode:
 		SetFrDs(fctrl);
-		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr1, sta_addr, ETH_ALEN);
 		_rtw_memcpy(pwlanhdr->addr2, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 		_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
 		break;
 	case Ndis802_11IBSS:
 	default:
-		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
+		_rtw_memcpy(pwlanhdr->addr1, sta_addr, ETH_ALEN);
 		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
 		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 		break;
 	}
 
 	SetSeqNum(pwlanhdr, 0);
+	set_duration(pwlanhdr, 0);
 
 	if (bQoS == _TRUE) {
 		struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
@@ -6642,11 +7678,11 @@ void rtw_hal_construct_NullFunctionData(
 }
 
 void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,
-				u8 *StaAddr, BOOLEAN bHideSSID)
+				BOOLEAN bHideSSID)
 {
 	struct rtw_ieee80211_hdr	*pwlanhdr;
 	u16					*fctrl;
-	u8					*mac, *bssid;
+	u8					*mac, *bssid, *sta_addr;
 	u32					pktlen;
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
@@ -6658,10 +7694,11 @@ void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,
 
 	mac = adapter_mac_addr(padapter);
 	bssid = cur_network->MacAddress;
+	sta_addr = get_my_bssid(&pmlmeinfo->network);
 
 	fctrl = &(pwlanhdr->frame_ctl);
 	*(fctrl) = 0;
-	_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr1, sta_addr, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, bssid, ETH_ALEN);
 
@@ -6698,7 +7735,7 @@ static void rtw_hal_append_tkip_mic(PADAPTER padapter,
 	u8	priority[4] = {0x0};
 	u8	null_key[16] = {0x0};
 
-	RTW_DBG("%s(): Add MIC, offset: %d\n", __func__, offset);
+	RTW_INFO("%s(): Add MIC, offset: %d\n", __func__, offset);
 
 	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
 
@@ -6824,27 +7861,27 @@ static void rtw_hal_construct_ARPRsp(
 
 	/* ARP element */
 	pARPRspPkt += 8;
-	SET_ARP_PKT_HW(pARPRspPkt, 0x0100);
-	SET_ARP_PKT_PROTOCOL(pARPRspPkt, 0x0008);	/* IP protocol */
-	SET_ARP_PKT_HW_ADDR_LEN(pARPRspPkt, 6);
-	SET_ARP_PKT_PROTOCOL_ADDR_LEN(pARPRspPkt, 4);
-	SET_ARP_PKT_OPERATION(pARPRspPkt, 0x0200);	/* ARP response */
-	SET_ARP_PKT_SENDER_MAC_ADDR(pARPRspPkt, adapter_mac_addr(padapter));
-	SET_ARP_PKT_SENDER_IP_ADDR(pARPRspPkt, pIPAddress);
+	SET_ARP_HTYPE(pARPRspPkt, 1);
+	SET_ARP_PTYPE(pARPRspPkt, ETH_P_IP);	/* IP protocol */
+	SET_ARP_HLEN(pARPRspPkt, ETH_ALEN);
+	SET_ARP_PLEN(pARPRspPkt, RTW_IP_ADDR_LEN);
+	SET_ARP_OPER(pARPRspPkt, 2);	/* ARP response */
+	SET_ARP_SENDER_MAC_ADDR(pARPRspPkt, adapter_mac_addr(padapter));
+	SET_ARP_SENDER_IP_ADDR(pARPRspPkt, pIPAddress);
 #ifdef CONFIG_ARP_KEEP_ALIVE
 	if (!is_zero_mac_addr(pmlmepriv->gw_mac_addr)) {
-		SET_ARP_PKT_TARGET_MAC_ADDR(pARPRspPkt, pmlmepriv->gw_mac_addr);
-		SET_ARP_PKT_TARGET_IP_ADDR(pARPRspPkt, pmlmepriv->gw_ip);
+		SET_ARP_TARGET_MAC_ADDR(pARPRspPkt, pmlmepriv->gw_mac_addr);
+		SET_ARP_TARGET_IP_ADDR(pARPRspPkt, pmlmepriv->gw_ip);
 	} else
 #endif
 	{
-		SET_ARP_PKT_TARGET_MAC_ADDR(pARPRspPkt,
+		SET_ARP_TARGET_MAC_ADDR(pARPRspPkt,
 				    get_my_bssid(&(pmlmeinfo->network)));
-		SET_ARP_PKT_TARGET_IP_ADDR(pARPRspPkt,
+		SET_ARP_TARGET_IP_ADDR(pARPRspPkt,
 					   pIPAddress);
-		RTW_DBG("%s Target Mac Addr:" MAC_FMT "\n", __FUNCTION__,
+		RTW_INFO("%s Target Mac Addr:" MAC_FMT "\n", __FUNCTION__,
 			 MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
-		RTW_DBG("%s Target IP Addr" IP_FMT "\n", __FUNCTION__,
+		RTW_INFO("%s Target IP Addr" IP_FMT "\n", __FUNCTION__,
 			 IP_ARG(pIPAddress));
 	}
 
@@ -7018,7 +8055,7 @@ static void rtw_hal_construct_ndp_info(_adapter *padapter,
 	u8	*pndp_info = pframe;
 	u8	len = sizeof(struct rtw_ndp_info);
 
-	/*RTW_INFO("%s: len: %d\n", __func__, len);*/
+	RTW_INFO("%s: len: %d\n", __func__, len);
 
 	pmlmeext =  &padapter->mlmeextpriv;
 	pmlmeinfo = &pmlmeext->mlmext_info;
@@ -7325,8 +8362,86 @@ static void rtw_hal_construct_GTKRsp(
 	if (psecuritypriv->dot118021XGrpPrivacy == _TKIP_)
 		*pLength += 8;
 }
-#endif /* CONFIG_GTK_OL */
+#endif /* CONFIG_GTK_OL */
+
+#define PN_2_CCMPH(ch,key_id)	((ch) & 0x000000000000ffff) \
+				| (((ch) & 0x0000ffffffff0000) << 16) \
+				| (((key_id) << 30)) \
+				| BIT(29)
+static void rtw_hal_construct_remote_control_info(_adapter *adapter,
+						  u8 *pframe, u32 *pLength)
+{
+	struct mlme_priv   *pmlmepriv = &adapter->mlmepriv;
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct security_priv *psecuritypriv = &adapter->securitypriv;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	struct sta_info *psta;
+	struct stainfo_rxcache *prxcache;
+	u8 cur_dot11rxiv[8], id = 0, tid_id = 0, i = 0;
+	size_t sz = 0, total = 0;
+	u64 ccmp_hdr = 0, tmp_key = 0;
+
+	psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
+
+	if (psta == NULL) {
+		rtw_warn_on(1);
+		return;
+	}
+
+	prxcache = &psta->sta_recvpriv.rxcache;
+	sz = sizeof(cur_dot11rxiv);
+
+	/* 3 SEC IV * 1 page */
+	rtw_get_sec_iv(adapter, cur_dot11rxiv,
+		       get_my_bssid(&pmlmeinfo->network));
+
+	_rtw_memcpy(pframe, cur_dot11rxiv, sz);
+	*pLength += sz;
+	pframe += sz;
+
+	_rtw_memset(&cur_dot11rxiv, 0, sz);
+
+	if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
+		id = psecuritypriv->dot118021XGrpKeyid;
+		tid_id = prxcache->last_tid;
+		REMOTE_INFO_CTRL_SET_VALD_EN(cur_dot11rxiv, 0xdd);
+		REMOTE_INFO_CTRL_SET_PTK_EN(cur_dot11rxiv, 1);
+		REMOTE_INFO_CTRL_SET_GTK_EN(cur_dot11rxiv, 1);
+		REMOTE_INFO_CTRL_SET_GTK_IDX(cur_dot11rxiv, id);
+		_rtw_memcpy(pframe, cur_dot11rxiv, sz);
+		*pLength += sz;
+		pframe += sz;
+
+		_rtw_memcpy(pframe, prxcache->iv[tid_id], sz);
+		*pLength += sz;
+		pframe += sz;
+
+		total = sizeof(psecuritypriv->iv_seq);
+		total /= sizeof(psecuritypriv->iv_seq[0]);
+
+		for (i = 0 ; i < total ; i ++) {
+			ccmp_hdr =
+				le64_to_cpu(*(u64*)psecuritypriv->iv_seq[i]);
+			_rtw_memset(&cur_dot11rxiv, 0, sz);
+			if (ccmp_hdr != 0) {
+				tmp_key = i;
+				ccmp_hdr = PN_2_CCMPH(ccmp_hdr, tmp_key);
+				*(u64*)cur_dot11rxiv = cpu_to_le64(ccmp_hdr);
+				_rtw_memcpy(pframe, cur_dot11rxiv, sz);
+			}
+			*pLength += sz;
+			pframe += sz;
+		}
+	}
+}
 
+/*#define DBG_RSVD_PAGE_CFG*/
+#ifdef DBG_RSVD_PAGE_CFG
+#define RSVD_PAGE_CFG(ops, v1, v2, v3)	\
+	RTW_INFO("=== [RSVD][%s]-NeedPage:%d, TotalPageNum:%d TotalPacketLen:%d ===\n",	\
+		ops, v1, v2, v3)
+#endif
 void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 		  u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
 				  RSVDPAGE_LOC *rsvd_page_loc)
@@ -7337,9 +8452,8 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 	struct mlme_ext_priv	*pmlmeext;
 	struct mlme_ext_info	*pmlmeinfo;
 	u32	ARPLength = 0, GTKLength = 0, PNOLength = 0, ScanInfoLength = 0;
-	u32	SSIDLegnth = 0, ProbeReqLength = 0, ns_len = 0;
+	u32     SSIDLegnth = 0, ProbeReqLength = 0, ns_len = 0, rc_len = 0;
 	u8 CurtPktPageNum = 0;
-	u8 cur_dot11txpn[8];
 
 #ifdef CONFIG_GTK_OL
 	struct sta_priv *pstapriv = &adapter->stapriv;
@@ -7361,7 +8475,7 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 
 		rsvd_page_loc->LocArpRsp = *page_num;
 
-		RTW_DBG("LocArpRsp: %d\n", rsvd_page_loc->LocArpRsp);
+		RTW_INFO("LocArpRsp: %d\n", rsvd_page_loc->LocArpRsp);
 
 		rtw_hal_construct_ARPRsp(adapter, &pframe[index],
 					 &ARPLength, pmlmeinfo->ip_addr);
@@ -7375,11 +8489,15 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 		*page_num += CurtPktPageNum;
 
 		index += (CurtPktPageNum * page_size);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-ARPRsp", CurtPktPageNum, *page_num, 0);
+		#endif
+
 #ifdef CONFIG_IPV6
 		/* 2 NS offload and NDP Info*/
 		if (pwrctl->wowlan_ns_offload_en == _TRUE) {
 			rsvd_page_loc->LocNbrAdv = *page_num;
-			RTW_DBG("LocNbrAdv: %d\n", rsvd_page_loc->LocNbrAdv);
+			RTW_INFO("LocNbrAdv: %d\n", rsvd_page_loc->LocNbrAdv);
 			rtw_hal_construct_na_message(adapter,
 						     &pframe[index], &ns_len);
 			rtw_hal_fill_fake_txdesc(adapter,
@@ -7390,9 +8508,12 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 						      page_size);
 			*page_num += CurtPktPageNum;
 			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-NbrAdv", CurtPktPageNum, *page_num, 0);
+			#endif
 
 			rsvd_page_loc->LocNDPInfo = *page_num;
-			RTW_DBG("LocNDPInfo: %d\n",
+			RTW_INFO("LocNDPInfo: %d\n",
 				 rsvd_page_loc->LocNDPInfo);
 
 			rtw_hal_construct_ndp_info(adapter,
@@ -7402,24 +8523,24 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 				(u8)PageNum(tx_desc + ns_len, page_size);
 			*page_num += CurtPktPageNum;
 			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-NDPInfo", CurtPktPageNum, *page_num, 0);
+			#endif
+
 		}
 #endif /*CONFIG_IPV6*/
-
-		/* 3 SEC IV * 1 page */
-		rtw_get_sec_iv(adapter, cur_dot11txpn,
-			       get_my_bssid(&pmlmeinfo->network));
-
+		/* 3 Remote Control Info. * 1 page */
 		rsvd_page_loc->LocRemoteCtrlInfo = *page_num;
-
-		RTW_DBG("LocRemoteCtrlInfo: %d\n", rsvd_page_loc->LocRemoteCtrlInfo);
-
-		_rtw_memcpy(pframe + index - tx_desc, cur_dot11txpn, _AES_IV_LEN_);
-
-		CurtPktPageNum = (u8)PageNum(_AES_IV_LEN_, page_size);
-
+		RTW_INFO("LocRemoteCtrlInfo: %d\n", rsvd_page_loc->LocRemoteCtrlInfo);
+		rtw_hal_construct_remote_control_info(adapter,
+						      &pframe[index - tx_desc],
+						      &rc_len);
+		CurtPktPageNum = (u8)PageNum(rc_len, page_size);
 		*page_num += CurtPktPageNum;
-
-		*total_pkt_len = index + _AES_IV_LEN_;
+		*total_pkt_len = index + rc_len;
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-RCI", CurtPktPageNum, *page_num, *total_pkt_len);
+		#endif
 #ifdef CONFIG_GTK_OL
 		index += (CurtPktPageNum * page_size);
 
@@ -7437,7 +8558,7 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 
 		/* 3 KEK, KCK */
 		rsvd_page_loc->LocGTKInfo = *page_num;
-		RTW_DBG("LocGTKInfo: %d\n", rsvd_page_loc->LocGTKInfo);
+		RTW_INFO("LocGTKInfo: %d\n", rsvd_page_loc->LocGTKInfo);
 
 		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_8812(adapter)) {
 			struct security_priv *psecpriv = NULL;
@@ -7479,7 +8600,7 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 			printk("\n");
 		}
 
-		RTW_DBG("%s(): HW_VAR_SET_TX_CMD: KEK KCK %p %d\n",
+		RTW_INFO("%s(): HW_VAR_SET_TX_CMD: KEK KCK %p %d\n",
 			 __FUNCTION__, &pframe[index - tx_desc],
 			 (tx_desc + RTW_KCK_LEN + RTW_KEK_LEN));
 #endif
@@ -7487,10 +8608,13 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 		*page_num += CurtPktPageNum;
 
 		index += (CurtPktPageNum * page_size);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-GTKInfo", CurtPktPageNum, *page_num, 0);
+		#endif
 
 		/* 3 GTK Response */
 		rsvd_page_loc->LocGTKRsp = *page_num;
-		RTW_DBG("LocGTKRsp: %d\n", rsvd_page_loc->LocGTKRsp);
+		RTW_INFO("LocGTKRsp: %d\n", rsvd_page_loc->LocGTKRsp);
 		rtw_hal_construct_GTKRsp(adapter, &pframe[index], &GTKLength);
 
 		rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
@@ -7507,7 +8631,7 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 			printk(" <=end\n");
 		}
 
-		RTW_DBG("%s(): HW_VAR_SET_TX_CMD: GTK RSP %p %d\n",
+		RTW_INFO("%s(): HW_VAR_SET_TX_CMD: GTK RSP %p %d\n",
 			 __FUNCTION__, &pframe[index - tx_desc],
 			 (tx_desc + GTKLength));
 #endif
@@ -7517,11 +8641,14 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 		*page_num += CurtPktPageNum;
 
 		index += (CurtPktPageNum * page_size);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-GTKRsp", CurtPktPageNum, *page_num, 0);
+		#endif
 
 		/* below page is empty for GTK extension memory */
 		/* 3(11) GTK EXT MEM */
 		rsvd_page_loc->LocGTKEXTMEM = *page_num;
-		RTW_DBG("LocGTKEXTMEM: %d\n", rsvd_page_loc->LocGTKEXTMEM);
+		RTW_INFO("LocGTKEXTMEM: %d\n", rsvd_page_loc->LocGTKEXTMEM);
 		CurtPktPageNum = 2;
 
 		if (page_size >= 256)
@@ -7530,15 +8657,21 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 		*page_num += CurtPktPageNum;
 		/* extension memory for FW */
 		*total_pkt_len = index + (page_size * CurtPktPageNum);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-GTKEXTMEM", CurtPktPageNum, *page_num, *total_pkt_len);
+		#endif
 #endif /* CONFIG_GTK_OL */
 
 		index += (CurtPktPageNum * page_size);
 
 		/*Reserve 1 page for AOAC report*/
 		rsvd_page_loc->LocAOACReport = *page_num;
-		RTW_DBG("LocAOACReport: %d\n", rsvd_page_loc->LocAOACReport);
+		RTW_INFO("LocAOACReport: %d\n", rsvd_page_loc->LocAOACReport);
 		*page_num += 1;
 		*total_pkt_len = index + (page_size * 1);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("WOW-AOAC", 1, *page_num, *total_pkt_len);
+		#endif
 	} else {
 #ifdef CONFIG_PNO_SUPPORT
 		if (pwrctl->wowlan_in_resume == _FALSE &&
@@ -7547,7 +8680,7 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 			/* Broadcast Probe Request */
 			rsvd_page_loc->LocProbePacket = *page_num;
 
-			RTW_DBG("loc_probe_req: %d\n",
+			RTW_INFO("loc_probe_req: %d\n",
 				 rsvd_page_loc->LocProbePacket);
 
 			rtw_hal_construct_ProbeReq(
@@ -7566,6 +8699,9 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 			*page_num += CurtPktPageNum;
 
 			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-ProbeReq", CurtPktPageNum, *page_num, 0);
+			#endif
 
 			/* Hidden SSID Probe Request */
 			ssid_num = pwrctl->pnlo_info->hidden_ssid_num;
@@ -7590,11 +8726,14 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 				*page_num += CurtPktPageNum;
 
 				index += (CurtPktPageNum * page_size);
+				#ifdef DBG_RSVD_PAGE_CFG
+				RSVD_PAGE_CFG("WOW-ProbeReq", CurtPktPageNum, *page_num, 0);
+				#endif
 			}
 
 			/* PNO INFO Page */
 			rsvd_page_loc->LocPNOInfo = *page_num;
-			RTW_DBG("LocPNOInfo: %d\n", rsvd_page_loc->LocPNOInfo);
+			RTW_INFO("LocPNOInfo: %d\n", rsvd_page_loc->LocPNOInfo);
 			rtw_hal_construct_PNO_info(adapter,
 						   &pframe[index - tx_desc],
 						   &PNOLength);
@@ -7602,10 +8741,13 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 			CurtPktPageNum = (u8)PageNum(PNOLength, page_size);
 			*page_num += CurtPktPageNum;
 			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-PNOInfo", CurtPktPageNum, *page_num, 0);
+			#endif
 
 			/* Scan Info Page */
 			rsvd_page_loc->LocScanInfo = *page_num;
-			RTW_DBG("LocScanInfo: %d\n", rsvd_page_loc->LocScanInfo);
+			RTW_INFO("LocScanInfo: %d\n", rsvd_page_loc->LocScanInfo);
 			rtw_hal_construct_scan_info(adapter,
 						    &pframe[index - tx_desc],
 						    &ScanInfoLength);
@@ -7614,6 +8756,9 @@ void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 			*page_num += CurtPktPageNum;
 			*total_pkt_len = index + ScanInfoLength;
 			index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("WOW-ScanInfo", CurtPktPageNum, *page_num, *total_pkt_len);
+			#endif
 		}
 #endif /* CONFIG_PNO_SUPPORT */
 	}
@@ -7647,7 +8792,7 @@ static void rtw_hal_gate_bb(_adapter *adapter, bool stop)
 		val8 = rtw_read8(adapter, REG_SYS_FUNC_EN);
 		val8 &= ~BIT(0);
 		rtw_write8(adapter, REG_SYS_FUNC_EN, val8);
-		RTW_DBG("%s: BB gated: 0x%02x, store TXPAUSE: %02x\n",
+		RTW_INFO("%s: BB gated: 0x%02x, store TXPAUSE: %02x\n",
 			 __func__,
 			 rtw_read8(adapter, REG_SYS_FUNC_EN),
 			 pwrpriv->wowlan_txpause_status);
@@ -7655,7 +8800,7 @@ static void rtw_hal_gate_bb(_adapter *adapter, bool stop)
 		val8 = rtw_read8(adapter, REG_SYS_FUNC_EN);
 		val8 |= BIT(0);
 		rtw_write8(adapter, REG_SYS_FUNC_EN, val8);
-		RTW_DBG("%s: BB release: 0x%02x, recover TXPAUSE:%02x\n",
+		RTW_INFO("%s: BB release: 0x%02x, recover TXPAUSE:%02x\n",
 			 __func__, rtw_read8(adapter, REG_SYS_FUNC_EN),
 			 pwrpriv->wowlan_txpause_status);
 		/* release TX*/
@@ -7695,7 +8840,7 @@ static u8 rtw_hal_wow_pattern_generate(_adapter *adapter, u8 idx, struct rtl_wow
 	int i, j;
 
 	if (pwrctl->wowlan_pattern_idx > MAX_WKFM_CAM_NUM) {
-		RTW_ERR("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
+		RTW_INFO("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
 			 __func__, MAX_WKFM_CAM_NUM);
 		return _FAIL;
 	}
@@ -7790,7 +8935,7 @@ static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)
 
 	val8 = rtw_read8(adapter, REG_FIFOPAGE + 3);
 	if (val8 != 0)
-		RTW_WARN("%s:[%04x]some PKTs in TXPKTBUF\n",
+		RTW_INFO("%s:[%04x]some PKTs in TXPKTBUF\n",
 			 __func__, (REG_FIFOPAGE + 3));
 
 	rtw_hal_reset_mac_rx(adapter);
@@ -7801,7 +8946,7 @@ static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)
 		rxff_bndy = rx_dma_buff_sz - 1;
 
 		rtw_write16(adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
-		RTW_DBG("%s: wow mode, 0x%04x: 0x%04x\n", __func__,
+		RTW_INFO("%s: wow mode, 0x%04x: 0x%04x\n", __func__,
 			 REG_TRXFF_BNDY + 2,
 			 rtw_read16(adapter, (REG_TRXFF_BNDY + 2)));
 	} else {
@@ -7809,7 +8954,7 @@ static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)
 				    (u8 *)&rx_dma_buff_sz);
 		rxff_bndy = rx_dma_buff_sz - 1;
 		rtw_write16(adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
-		RTW_DBG("%s: normal mode, 0x%04x: 0x%04x\n", __func__,
+		RTW_INFO("%s: normal mode, 0x%04x: 0x%04x\n", __func__,
 			 REG_TRXFF_BNDY + 2,
 			 rtw_read16(adapter, (REG_TRXFF_BNDY + 2)));
 	}
@@ -7826,7 +8971,7 @@ bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)
 	bool res = _TRUE;
 
 	if (idx > MAX_WKFM_CAM_NUM) {
-		RTW_ERR("[Error]: %s, pattern index is out of range\n",
+		RTW_INFO("[Error]: %s, pattern index is out of range\n",
 			 __func__);
 		return _FALSE;
 	}
@@ -7835,14 +8980,14 @@ bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)
 			    (u8 *)&rx_dma_buff_sz);
 
 	if (rx_dma_buff_sz == 0) {
-		RTW_ERR("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
+		RTW_INFO("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
 		return _FALSE;
 	}
 
 	rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
 
 	if (page_sz == 0) {
-		RTW_ERR("[Error]: %s, page_sz is 0!!\n", __func__);
+		RTW_INFO("[Error]: %s, page_sz is 0!!\n", __func__);
 		return _FALSE;
 	}
 
@@ -7874,7 +9019,7 @@ bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)
 		data_l = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_L);
 		data_h = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_H);
 
-		RTW_DBG("[%d]: %08x %08x\n", i, data_h, data_l);
+		RTW_INFO("[%d]: %08x %08x\n", i, data_h, data_l);
 
 		count = 0;
 
@@ -7885,7 +9030,7 @@ bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)
 		} while (!tmp && count < 100);
 
 		if (count >= 100) {
-			RTW_ERR("%s count:%d\n", __func__, count);
+			RTW_INFO("%s count:%d\n", __func__, count);
 			res = _FALSE;
 		}
 	}
@@ -7907,7 +9052,7 @@ bool rtw_write_to_frame_mask(_adapter *adapter, u8 idx,
 	int res = 0, i = 0;
 
 	if (idx > MAX_WKFM_CAM_NUM) {
-		RTW_ERR("[Error]: %s, pattern index is out of range\n",
+		RTW_INFO("[Error]: %s, pattern index is out of range\n",
 			 __func__);
 		return _FALSE;
 	}
@@ -7916,14 +9061,14 @@ bool rtw_write_to_frame_mask(_adapter *adapter, u8 idx,
 			    (u8 *)&rx_dma_buff_sz);
 
 	if (rx_dma_buff_sz == 0) {
-		RTW_ERR("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
+		RTW_INFO("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
 		return _FALSE;
 	}
 
 	rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
 
 	if (page_sz == 0) {
-		RTW_ERR("[Error]: %s, page_sz is 0!!\n", __func__);
+		RTW_INFO("[Error]: %s, page_sz is 0!!\n", __func__);
 		return _FALSE;
 	}
 
@@ -8040,7 +9185,7 @@ static int rtw_hal_set_pattern(_adapter *adapter, u8 *pattern,
 	int i, j;
 
 	if (pwrctl->wowlan_pattern_idx > MAX_WKFM_CAM_NUM) {
-		RTW_ERR("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
+		RTW_INFO("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
 			 __func__, MAX_WKFM_CAM_NUM);
 		return _FALSE;
 	}
@@ -8154,7 +9299,7 @@ void rtw_fill_pattern(_adapter *adapter)
 				index += 2;
 
 			if (rtw_write_to_frame_mask(adapter, index, &wow_pattern) == _FALSE)
-				RTW_ERR("%s: ERROR!! idx: %d write_to_frame_mask_cam fail\n", __func__, i);
+				RTW_INFO("%s: ERROR!! idx: %d write_to_frame_mask_cam fail\n", __func__, i);
 		}
 
 	}
@@ -8433,6 +9578,7 @@ static void rtw_hal_dl_pattern(_adapter *adapter, u8 mode)
 
 static void rtw_hal_wow_enable(_adapter *adapter)
 {
+	struct registry_priv  *registry_par = &adapter->registrypriv;
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 	struct security_priv *psecuritypriv = &adapter->securitypriv;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
@@ -8441,9 +9587,14 @@ static void rtw_hal_wow_enable(_adapter *adapter)
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
 	int res;
 	u16 media_status_rpt;
+	u8 no_wake = 0;
 
 
-	RTW_INFO("%s, WOWLAN_ENABLE\n", __func__);
+	if(registry_par->suspend_type == FW_IPS_DISABLE_BBRF &&
+	!check_fwstate(pmlmepriv, _FW_LINKED))
+		no_wake = 1;
+
+	RTW_PRINT(FUNC_ADPT_FMT " WOWLAN_ENABLE\n", FUNC_ADPT_ARG(adapter));
 	rtw_hal_gate_bb(adapter, _TRUE);
 #ifdef CONFIG_GTK_OL
 	if (psecuritypriv->binstallKCK_KEK == _TRUE)
@@ -8453,7 +9604,10 @@ static void rtw_hal_wow_enable(_adapter *adapter)
 		rtw_hal_backup_rate(adapter);
 
 	rtw_hal_fw_dl(adapter, _TRUE);
-	media_status_rpt = RT_MEDIA_CONNECT;
+	if(no_wake)
+		media_status_rpt = RT_MEDIA_DISCONNECT;
+	else
+		media_status_rpt = RT_MEDIA_CONNECT;
 	rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
 			  (u8 *)&media_status_rpt);
 
@@ -8465,7 +9619,7 @@ static void rtw_hal_wow_enable(_adapter *adapter)
 
 	res = rtw_hal_pause_rx_dma(adapter);
 	if (res == _FAIL)
-		RTW_WARN("[WARNING] pause RX DMA fail\n");
+		RTW_PRINT("[WARNING] pause RX DMA fail\n");
 
 	#ifndef CONFIG_WOW_PATTERN_HW_CAM
 	/* Reconfig RX_FF Boundary */
@@ -8473,17 +9627,20 @@ static void rtw_hal_wow_enable(_adapter *adapter)
 	#endif
 
 	/* redownload wow pattern */
-	rtw_hal_dl_pattern(adapter, 1);
+	if(!no_wake)
+		rtw_hal_dl_pattern(adapter, 1);
 
 	if (!pwrctl->wowlan_pno_enable) {
 		psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
 
 		if (psta != NULL) {
 			#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+			adapter_to_dvobj(adapter)->dft.port_id = 0xFF;
+			adapter_to_dvobj(adapter)->dft.mac_id = 0xFF;
 			rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
 			#endif
-
-			rtw_sta_media_status_rpt(adapter, psta, 1);
+			if(!no_wake)
+				rtw_sta_media_status_rpt(adapter, psta, 1);
 		}
 	}
 
@@ -8491,23 +9648,24 @@ static void rtw_hal_wow_enable(_adapter *adapter)
 	/* Enable CPWM2 only. */
 	res = rtw_hal_enable_cpwm2(adapter);
 	if (res == _FAIL)
-		RTW_WARN("[WARNING] enable cpwm2 fail\n");
+		RTW_PRINT("[WARNING] enable cpwm2 fail\n");
 #endif
 #ifdef CONFIG_GPIO_WAKEUP
 	rtw_hal_switch_gpio_wl_ctrl(adapter, WAKEUP_GPIO_IDX, _TRUE);
 #endif
 	/* Set WOWLAN H2C command. */
+	RTW_PRINT("Set WOWLan cmd\n");
 	rtw_hal_set_fw_wow_related_cmd(adapter, 1);
 
 	res = rtw_hal_check_wow_ctrl(adapter, _TRUE);
 
 	if (res == _FALSE)
-		RTW_ERR("[Error]%s: set wowlan CMD fail!!\n", __func__);
+		RTW_INFO("[Error]%s: set wowlan CMD fail!!\n", __func__);
 
 	pwrctl->wowlan_wake_reason =
 		rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
 
-	RTW_INFO("%s: wowlan_wake_reason: 0x%02x\n", __func__,
+	RTW_PRINT("wowlan_wake_reason: 0x%02x\n",
 		  pwrctl->wowlan_wake_reason);
 #ifdef CONFIG_GTK_OL_DBG
 	dump_sec_cam(RTW_DBGDUMP, adapter);
@@ -8521,7 +9679,8 @@ static void rtw_hal_wow_enable(_adapter *adapter)
 #if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
 	/* Invoid SE0 reset signal during suspending*/
 	rtw_write8(adapter, REG_RSV_CTRL, 0x20);
-	if (IS_8188F(pHalData->version_id) == FALSE)
+	if (IS_8188F(pHalData->version_id) == FALSE
+		&& IS_8188GTV(pHalData->version_id) == FALSE)
 		rtw_write8(adapter, REG_RSV_CTRL, 0x60);
 #endif
 
@@ -8586,30 +9745,36 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct hal_ops *pHalFunc = &adapter->hal_func;
 	struct sta_info *psta = NULL;
+	struct registry_priv  *registry_par = &adapter->registrypriv;
 	int res;
 	u16 media_status_rpt;
 	u8 val8;
 
-	RTW_INFO("%s, WOWLAN_DISABLE\n", __func__);
-
+	RTW_PRINT("%s, WOWLAN_DISABLE\n", __func__);
+	
+	if(registry_par->suspend_type == FW_IPS_DISABLE_BBRF && !check_fwstate(pmlmepriv, _FW_LINKED)) {
+		RTW_INFO("FW_IPS_DISABLE_BBRF resume\n");
+		return;
+	}
+	
 	if (!pwrctl->wowlan_pno_enable) {
 		psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
 		if (psta != NULL)
 			rtw_sta_media_status_rpt(adapter, psta, 0);
 		else
-			RTW_WARN("%s: psta is null\n", __func__);
+			RTW_INFO("%s: psta is null\n", __func__);
 	}
 
 	if (0) {
-		RTW_DBG("0x630:0x%02x\n", rtw_read8(adapter, 0x630));
-		RTW_DBG("0x631:0x%02x\n", rtw_read8(adapter, 0x631));
-		RTW_DBG("0x634:0x%02x\n", rtw_read8(adapter, 0x634));
-		RTW_DBG("0x1c7:0x%02x\n", rtw_read8(adapter, 0x1c7));
+		RTW_INFO("0x630:0x%02x\n", rtw_read8(adapter, 0x630));
+		RTW_INFO("0x631:0x%02x\n", rtw_read8(adapter, 0x631));
+		RTW_INFO("0x634:0x%02x\n", rtw_read8(adapter, 0x634));
+		RTW_INFO("0x1c7:0x%02x\n", rtw_read8(adapter, 0x1c7));
 	}
 
 	pwrctl->wowlan_wake_reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
 
-	RTW_INFO("%s: wakeup_reason: 0x%02x\n", __func__,
+	RTW_PRINT("wakeup_reason: 0x%02x\n",
 		  pwrctl->wowlan_wake_reason);
 	#ifdef DBG_WAKEUP_REASON
 	_dbg_rtw_wake_up_reason(adapter, pwrctl->wowlan_wake_reason);
@@ -8620,7 +9785,7 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 	res = rtw_hal_check_wow_ctrl(adapter, _FALSE);
 
 	if (res == _FALSE) {
-		RTW_ERR("[Error]%s: disable WOW cmd fail\n!!", __func__);
+		RTW_INFO("[Error]%s: disable WOW cmd fail\n!!", __func__);
 		rtw_hal_force_enable_rxdma(adapter);
 	}
 
@@ -8628,7 +9793,7 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 
 	res = rtw_hal_pause_rx_dma(adapter);
 	if (res == _FAIL)
-		RTW_WARN("[WARNING] pause RX DMA fail\n");
+		RTW_PRINT("[WARNING] pause RX DMA fail\n");
 
 	/* clean HW pattern match */
 	rtw_hal_dl_pattern(adapter, 0);
@@ -8644,8 +9809,8 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 		rtw_hal_enable_tx_report(adapter);
 	#endif
 
-	if ((pwrctl->wowlan_wake_reason != RX_DISASSOC) ||
-		(pwrctl->wowlan_wake_reason != RX_DEAUTH) ||
+	if ((pwrctl->wowlan_wake_reason != RX_DISASSOC) &&
+		(pwrctl->wowlan_wake_reason != RX_DEAUTH) &&
 		(pwrctl->wowlan_wake_reason != FW_DECISION_DISCONNECT)) {
 		rtw_hal_get_aoac_rpt(adapter);
 		rtw_hal_update_sw_security_info(adapter);
@@ -8655,6 +9820,9 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 
 #ifdef CONFIG_GPIO_WAKEUP
 
+#ifdef CONFIG_RTW_ONE_PIN_GPIO
+	rtw_hal_set_input_gpio(adapter, WAKEUP_GPIO_IDX);
+#else
 #ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
 	if (pwrctl->is_high_active == 0)
 		rtw_hal_set_input_gpio(adapter, WAKEUP_GPIO_IDX);
@@ -8662,12 +9830,12 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 		rtw_hal_set_output_gpio(adapter, WAKEUP_GPIO_IDX, 0);
 #else
 	val8 = (pwrctl->is_high_active == 0) ? 1 : 0;
-	RTW_INFO("%s: Set Wake GPIO to default(%d).\n", __func__, val8);
+	RTW_PRINT("Set Wake GPIO to default(%d).\n", val8);
 
 	rtw_hal_set_output_gpio(adapter, WAKEUP_GPIO_IDX, val8);
 	rtw_hal_switch_gpio_wl_ctrl(adapter, WAKEUP_GPIO_IDX, _FALSE);
 #endif
-
+#endif /* CONFIG_RTW_ONE_PIN_GPIO */
 #endif
 	if ((pwrctl->wowlan_wake_reason != FW_DECISION_DISCONNECT) &&
 	    (pwrctl->wowlan_wake_reason != RX_PAIRWISEKEY) &&
@@ -8680,6 +9848,8 @@ static void rtw_hal_wow_disable(_adapter *adapter)
 
 		if (psta != NULL) {
 			#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+			adapter_to_dvobj(adapter)->dft.port_id = 0xFF;
+			adapter_to_dvobj(adapter)->dft.mac_id = 0xFF;
 			rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
 			#endif
 			rtw_sta_media_status_rpt(adapter, psta, 1);
@@ -8714,6 +9884,9 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-Beacon", CurtPktPageNum, *page_num, 0);
+	#endif
 
 	/* P2P Probe rsp */
 	rsvd_page_loc->LocP2PProbeRsp = *page_num;
@@ -8730,6 +9903,9 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-ProbeRsp", CurtPktPageNum, *page_num, 0);
+	#endif
 
 	/* P2P nego rsp */
 	rsvd_page_loc->LocNegoRsp = *page_num;
@@ -8746,6 +9922,9 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-NegoRsp", CurtPktPageNum, *page_num, 0);
+	#endif
 
 	/* P2P invite rsp */
 	rsvd_page_loc->LocInviteRsp = *page_num;
@@ -8762,6 +9941,9 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 	*page_num += CurtPktPageNum;
 
 	index += (CurtPktPageNum * page_size);
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-InviteRsp", CurtPktPageNum, *page_num, 0);
+	#endif
 
 	/* P2P provision discovery rsp */
 	rsvd_page_loc->LocPDRsp = *page_num;
@@ -8779,6 +9961,9 @@ void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
 	*page_num += CurtPktPageNum;
 
 	*total_pkt_len = index + P2PPDRspLength;
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("WOW-P2P-PDR", CurtPktPageNum, *page_num, *total_pkt_len);
+	#endif
 
 	index += (CurtPktPageNum * page_size);
 
@@ -8836,8 +10021,8 @@ static void rtw_hal_set_lps_pg_info_rsvd_page(_adapter *adapter)
 #endif
 #ifdef CONFIG_BEAMFORMING  /*&& MU BF*/
 	/*Btye 3 - Max MU rate table Group ID*/
-	LPSPG_RSVD_PAGE_SET_MU_RAID_GID(lps_pg_info, _value);
-	RTW_INFO("[LPSPG-INFO] Max MU rate table Group ID :%d\n", _value);
+	LPSPG_RSVD_PAGE_SET_MU_RAID_GID(lps_pg_info, 0);
+	RTW_INFO("[LPSPG-INFO] Max MU rate table Group ID :%d\n", 0);
 #endif
 
 	/*Btye 8 ~15 - used Security CAM entry */
@@ -8973,6 +10158,13 @@ void rtw_hal_lps_pg_rssi_lv_decide(_adapter *adapter, struct sta_info *sta)
 
 void rtw_hal_lps_pg_handler(_adapter *adapter, enum lps_pg_hdl_id hdl_id)
 {
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct sta_priv *pstapriv = &adapter->stapriv;
+	struct sta_info *sta;
+
+	sta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
+
 	switch (hdl_id) {
 	case LPS_PG_INFO_CFG:
 		rtw_hal_set_lps_pg_info(adapter);
@@ -8987,20 +10179,16 @@ void rtw_hal_lps_pg_handler(_adapter *adapter, enum lps_pg_hdl_id hdl_id)
 			rtw_clr_xmit_block(adapter, XMIT_BLOCK_REDLMEM);
 		}
 		break;
-
-	case LPS_PG_RESEND_H2C:
+	case LPS_PG_PHYDM_DIS:/*Disable RA and PT by H2C*/
+		if (sta)
+			rtw_phydm_lps_pg_hdl(adapter, sta, _TRUE);
+		break;
+	case LPS_PG_PHYDM_EN:/*Enable RA and PT by H2C*/
 		{
-			struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
-			struct sta_info *sta;
-			int i;
-
-			for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
-				sta = macid_ctl->sta[i];
-				if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr)) {
-					rtw_hal_lps_pg_rssi_lv_decide(adapter, sta);
-					set_sta_rate(adapter, sta);
-					sta->lps_pg_rssi_lv = 0;
-				}
+			if (sta) {
+				rtw_hal_lps_pg_rssi_lv_decide(adapter, sta);
+				rtw_phydm_lps_pg_hdl(adapter, sta, _FALSE);
+				sta->lps_pg_rssi_lv = 0;
 			}
 		}
 		break;
@@ -9012,6 +10200,73 @@ void rtw_hal_lps_pg_handler(_adapter *adapter, enum lps_pg_hdl_id hdl_id)
 
 #endif /*CONFIG_LPS_PG*/
 
+static u8 _rtw_mi_assoc_if_num(_adapter *adapter)
+{
+	u8 mi_iface_num = 0;
+
+	if (0) {
+		RTW_INFO("[IFS_ASSOC_STATUS] - STA :%d", DEV_STA_LD_NUM(adapter_to_dvobj(adapter)));
+		RTW_INFO("[IFS_ASSOC_STATUS] - AP:%d", DEV_AP_NUM(adapter_to_dvobj(adapter)));
+		RTW_INFO("[IFS_ASSOC_STATUS] - AP starting :%d", DEV_AP_STARTING_NUM(adapter_to_dvobj(adapter)));
+		RTW_INFO("[IFS_ASSOC_STATUS] - MESH :%d", DEV_MESH_NUM(adapter_to_dvobj(adapter)));
+		RTW_INFO("[IFS_ASSOC_STATUS] - ADHOC :%d", DEV_ADHOC_NUM(adapter_to_dvobj(adapter)));
+		/*RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GC :%d", DEV_P2P_GC_NUM(adapter_to_dvobj(adapter)));*/
+		/*RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GO :%d", DEV_P2P_GO_NUM(adapter_to_dvobj(adapter)));*/
+	}
+
+	mi_iface_num = (DEV_STA_LD_NUM(adapter_to_dvobj(adapter)) +
+		DEV_AP_NUM(adapter_to_dvobj(adapter)) +
+		DEV_AP_STARTING_NUM(adapter_to_dvobj(adapter)));
+	return mi_iface_num;
+}
+
+static _adapter *_rtw_search_sta_iface(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface = NULL;
+	_adapter *sta_iface = NULL;
+	int i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (check_fwstate(&iface->mlmepriv, WIFI_STATION_STATE) == _TRUE) {
+			if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
+				sta_iface = iface;
+				break;
+			}
+		}
+	}
+	return sta_iface;
+}
+#ifdef CONFIG_AP_MODE
+static _adapter *_rtw_search_ap_iface(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface = NULL;
+	_adapter *ap_iface = NULL;
+	int i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE ) {
+			ap_iface = iface;
+			break;
+		}
+	}
+	return ap_iface;
+}
+#endif
+
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
+void rtw_hal_set_pathb_phase(_adapter *adapter, u8 phase_idx)
+{
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(adapter);
+	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
+
+	return phydm_pathb_q_matrix_rotate(pDM_Odm, phase_idx);
+}
+#endif
+
 /*
  * Description: Fill the reserved packets that FW will use to RSVD page.
  *			Now we just send 4 types packet to rsvd page.
@@ -9040,8 +10295,6 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 	struct xmit_frame	*pcmdframe = NULL;
 	struct pkt_attrib	*pattrib;
 	struct xmit_priv	*pxmitpriv;
-	struct mlme_ext_priv	*pmlmeext;
-	struct mlme_ext_info	*pmlmeinfo;
 	struct pwrctrl_priv *pwrctl;
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	struct hal_ops *pHalFunc = &adapter->hal_func;
@@ -9054,6 +10307,11 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 	u16	BufIndex = 0;
 	u32	TotalPacketLen = 0, MaxRsvdPageBufSize = 0, PageSize = 0;
 	RSVDPAGE_LOC	RsvdPageLoc;
+	struct registry_priv  *registry_par = &adapter->registrypriv;
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	u32	fw_dbg_msg_pkt_len = 0;
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 
 #ifdef DBG_CONFIG_ERROR_DETECT
 	struct sreset_priv *psrtpriv;
@@ -9062,23 +10320,34 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 #ifdef CONFIG_MCC_MODE
 	u8 dl_mcc_page = _FAIL;
 #endif /* CONFIG_MCC_MODE */
+	u8 nr_assoc_if;
+
+	_adapter *sta_iface = NULL;
+	_adapter *ap_iface = NULL;
+
+	bool is_wow_mode = _FALSE;
 
 	pHalData = GET_HAL_DATA(adapter);
 #ifdef DBG_CONFIG_ERROR_DETECT
 	psrtpriv = &pHalData->srestpriv;
 #endif
 	pxmitpriv = &adapter->xmitpriv;
-	pmlmeext = &adapter->mlmeextpriv;
-	pmlmeinfo = &pmlmeext->mlmext_info;
 	pwrctl = adapter_to_pwrctl(adapter);
 
 	rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&PageSize);
 
 	if (PageSize == 0) {
-		RTW_INFO("[Error]: %s, PageSize is zero!!\n", __func__);
+		RTW_ERR("[Error]: %s, PageSize is zero!!\n", __func__);
 		return;
 	}
+	nr_assoc_if = _rtw_mi_assoc_if_num(adapter);
 
+	if ((pwrctl->wowlan_mode == _TRUE && pwrctl->wowlan_in_resume == _FALSE) ||
+		pwrctl->wowlan_ap_mode == _TRUE ||
+		pwrctl->wowlan_p2p_mode == _TRUE)
+		is_wow_mode = _TRUE;
+
+	/*page_num for init time to get rsvd page number*/
 	/* Prepare ReservedPagePacket */
 	if (page_num) {
 		ReservedPagePacket = rtw_zmalloc(MAX_CMDBUF_SZ);
@@ -9087,13 +10356,17 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 			*page_num = 0xFF;
 			return;
 		}
+		RTW_INFO(FUNC_ADPT_FMT" Get [ %s ] RsvdPageNUm  ==>\n",
+			FUNC_ADPT_ARG(adapter), (is_wow_mode) ? "WOW" : "NOR");
+
 	} else {
-		if (pwrctl->wowlan_mode == _TRUE || pwrctl->wowlan_ap_mode == _TRUE)
+		if (is_wow_mode)
 			RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _TRUE);
 		else
 			RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _FALSE);
 
-		RTW_INFO("%s PageSize: %d, RsvdPageNUm: %d\n", __func__, PageSize, RsvdPageNum);
+		RTW_INFO(FUNC_ADPT_FMT" PageSize: %d, [ %s ]-RsvdPageNUm: %d\n",
+			FUNC_ADPT_ARG(adapter), PageSize, (is_wow_mode) ? "WOW" : "NOR", RsvdPageNum);
 
 		MaxRsvdPageBufSize = RsvdPageNum * PageSize;
 		if (MaxRsvdPageBufSize > MAX_CMDBUF_SZ) {
@@ -9114,8 +10387,9 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 
 	_rtw_memset(&RsvdPageLoc, 0, sizeof(RSVDPAGE_LOC));
 
-	/* beacon * 1 pages */
 	BufIndex = TxDescOffset;
+
+	/*======== beacon content =======*/
 	rtw_hal_construct_beacon(adapter,
 				 &ReservedPagePacket[BufIndex], &BeaconLength);
 
@@ -9123,19 +10397,32 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 	* 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.
 	*/
+	BeaconLength = MAX_BEACON_LEN - TxDescLen;
 	CurtPktPageNum = (u8)PageNum((TxDescLen + BeaconLength), PageSize);
 
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	CurtPktPageNum = CurtPktPageNum * CONFIG_LIMITED_AP_NUM;
+#endif
 	TotalPageNum += CurtPktPageNum;
 
 	BufIndex += (CurtPktPageNum * PageSize);
 
-	if (pwrctl->wowlan_ap_mode == _TRUE) {
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("Beacon", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+	#endif
+
+	/*======== probe response content ========*/
+	if (pwrctl->wowlan_ap_mode == _TRUE) {/*WOW mode*/
+		#ifdef CONFIG_CONCURRENT_MODE
+		if (nr_assoc_if >= 2)
+			RTW_ERR("Not support > 2 net-interface in WOW\n");
+		#endif
 		/* (4) probe response*/
 		RsvdPageLoc.LocProbeRsp = TotalPageNum;
 		rtw_hal_construct_ProbeRsp(
 			adapter, &ReservedPagePacket[BufIndex],
 			&ProbeRspLength,
-			get_my_bssid(&pmlmeinfo->network), _FALSE);
+			_FALSE);
 		rtw_hal_fill_fake_txdesc(adapter,
 				 &ReservedPagePacket[BufIndex - TxDescLen],
 				 ProbeRspLength, _FALSE, _FALSE, _FALSE);
@@ -9144,109 +10431,169 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 		TotalPageNum += CurtPktPageNum;
 		TotalPacketLen = BufIndex + ProbeRspLength;
 		BufIndex += (CurtPktPageNum * PageSize);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("ProbeRsp", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+		#endif
 		goto download_page;
 	}
 
-	/* ps-poll * 1 page */
-	RsvdPageLoc.LocPsPoll = TotalPageNum;
-	RTW_INFO("LocPsPoll: %d\n", RsvdPageLoc.LocPsPoll);
-	rtw_hal_construct_PSPoll(adapter,
-				 &ReservedPagePacket[BufIndex], &PSPollLength);
-	rtw_hal_fill_fake_txdesc(adapter,
-				 &ReservedPagePacket[BufIndex - TxDescLen],
-				 PSPollLength, _TRUE, _FALSE, _FALSE);
-
-	CurtPktPageNum = (u8)PageNum((TxDescLen + PSPollLength), PageSize);
-
-	TotalPageNum += CurtPktPageNum;
-
-	BufIndex += (CurtPktPageNum * PageSize);
-
-#ifdef CONFIG_BT_COEXIST
-	if (pwrctl->wowlan_mode == _FALSE ||
-		pwrctl->wowlan_in_resume == _TRUE) {
-		/* BT Qos null data * 1 page */
-		RsvdPageLoc.LocBTQosNull = TotalPageNum;
-
-		RTW_INFO("LocBTQosNull: %d\n", RsvdPageLoc.LocBTQosNull);
-
-		rtw_hal_construct_NullFunctionData(adapter,
-					&ReservedPagePacket[BufIndex],
-					&BTQosNullLength,
-					get_my_bssid(&pmlmeinfo->network),
-					_TRUE, 0, 0, _FALSE);
+	/*======== ps-poll content * 1 page ========*/
+	sta_iface = adapter;
+	#ifdef CONFIG_CONCURRENT_MODE
+	if (!MLME_IS_STA(sta_iface) && DEV_STA_LD_NUM(adapter_to_dvobj(sta_iface))) {
+		sta_iface = _rtw_search_sta_iface(adapter);
+		RTW_INFO("get ("ADPT_FMT") to create PS-Poll/Null/QosNull\n", ADPT_ARG(sta_iface));
+	}
+	#endif
 
-		rtw_hal_fill_fake_txdesc(adapter,
-				&ReservedPagePacket[BufIndex - TxDescLen],
-				BTQosNullLength, _FALSE, _TRUE, _FALSE);
+	if (MLME_IS_STA(sta_iface) || (nr_assoc_if == 0)) {
+		RsvdPageLoc.LocPsPoll = TotalPageNum;
+		RTW_INFO("LocPsPoll: %d\n", RsvdPageLoc.LocPsPoll);
+		rtw_hal_construct_PSPoll(sta_iface,
+					 &ReservedPagePacket[BufIndex], &PSPollLength);
+		rtw_hal_fill_fake_txdesc(sta_iface,
+					 &ReservedPagePacket[BufIndex - TxDescLen],
+					 PSPollLength, _TRUE, _FALSE, _FALSE);
 
-		CurtPktPageNum = (u8)PageNum(TxDescLen + BTQosNullLength,
-					     PageSize);
+		CurtPktPageNum = (u8)PageNum((TxDescLen + PSPollLength), PageSize);
 
 		TotalPageNum += CurtPktPageNum;
+
 		BufIndex += (CurtPktPageNum * PageSize);
+		#ifdef DBG_RSVD_PAGE_CFG
+		RSVD_PAGE_CFG("PSPoll", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+		#endif
 	}
-#endif /* CONFIG_BT_COEXIT */
 
 #ifdef CONFIG_MCC_MODE
-	if (MCC_EN(adapter)) {
+	/*======== MCC * n page ======== */
+	if (MCC_EN(adapter)) {/*Normal mode*/
 		dl_mcc_page = rtw_hal_dl_mcc_fw_rsvd_page(adapter, ReservedPagePacket,
-				&BufIndex, TxDescLen, PageSize,
-				&TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
+				&BufIndex, TxDescLen, PageSize, &TotalPageNum, &RsvdPageLoc, page_num);
 	} else {
 		dl_mcc_page = _FAIL;
 	}
 
 	if (dl_mcc_page == _FAIL)
 #endif /* CONFIG_MCC_MODE */
-	{
-		/* null data * 1 page */
-		RsvdPageLoc.LocNullData = TotalPageNum;
-		RTW_INFO("LocNullData: %d\n", RsvdPageLoc.LocNullData);
-		rtw_hal_construct_NullFunctionData(
-			adapter,
-			&ReservedPagePacket[BufIndex],
-			&NullDataLength,
-			get_my_bssid(&pmlmeinfo->network),
-			_FALSE, 0, 0, _FALSE);
-		rtw_hal_fill_fake_txdesc(adapter,
+	{	/*======== null data * 1 page ======== */
+		if (MLME_IS_STA(sta_iface) || (nr_assoc_if == 0)) {
+			RsvdPageLoc.LocNullData = TotalPageNum;
+			RTW_INFO("LocNullData: %d\n", RsvdPageLoc.LocNullData);
+			rtw_hal_construct_NullFunctionData(
+				sta_iface,
+				&ReservedPagePacket[BufIndex],
+				&NullDataLength,
+				_FALSE, 0, 0, _FALSE);
+			rtw_hal_fill_fake_txdesc(sta_iface,
 				 &ReservedPagePacket[BufIndex - TxDescLen],
 				 NullDataLength, _FALSE, _FALSE, _FALSE);
 
-		CurtPktPageNum = (u8)PageNum(TxDescLen + NullDataLength, PageSize);
+			CurtPktPageNum = (u8)PageNum(TxDescLen + NullDataLength, PageSize);
 
-		TotalPageNum += CurtPktPageNum;
+			TotalPageNum += CurtPktPageNum;
 
-		BufIndex += (CurtPktPageNum * PageSize);
+			BufIndex += (CurtPktPageNum * PageSize);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("NullData", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+			#endif
+		}
+	}
+
+	/*======== Qos null data * 1 page ======== */
+	if (pwrctl->wowlan_mode == _FALSE ||
+		pwrctl->wowlan_in_resume == _TRUE) {/*Normal mode*/	
+		if (MLME_IS_STA(sta_iface) || (nr_assoc_if == 0)) {
+			RsvdPageLoc.LocQosNull = TotalPageNum;
+			RTW_INFO("LocQosNull: %d\n", RsvdPageLoc.LocQosNull);
+			rtw_hal_construct_NullFunctionData(sta_iface,
+						&ReservedPagePacket[BufIndex],
+						&QosNullLength,
+						_TRUE, 0, 0, _FALSE);
+			rtw_hal_fill_fake_txdesc(sta_iface,
+					 &ReservedPagePacket[BufIndex - TxDescLen],
+					 QosNullLength, _FALSE, _FALSE, _FALSE);
+
+			CurtPktPageNum = (u8)PageNum(TxDescLen + QosNullLength,
+						     PageSize);
+
+			TotalPageNum += CurtPktPageNum;
+
+			BufIndex += (CurtPktPageNum * PageSize);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("QosNull", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+			#endif
+		}
 	}
 
+#ifdef CONFIG_BT_COEXIST
+	/*======== BT Qos null data * 1 page ======== */
 	if (pwrctl->wowlan_mode == _FALSE ||
-		pwrctl->wowlan_in_resume == _TRUE) {
-		/* Qos null data * 1 page */
-		RsvdPageLoc.LocQosNull = TotalPageNum;
-		RTW_INFO("LocQosNull: %d\n", RsvdPageLoc.LocQosNull);
-		rtw_hal_construct_NullFunctionData(adapter,
-					&ReservedPagePacket[BufIndex],
-					&QosNullLength,
-					get_my_bssid(&pmlmeinfo->network),
-					_TRUE, 0, 0, _FALSE);
+		pwrctl->wowlan_in_resume == _TRUE) {/*Normal mode*/
+
+		ap_iface = adapter;
+		#ifdef CONFIG_CONCURRENT_MODE
+		if (!MLME_IS_AP(ap_iface) && DEV_AP_NUM(adapter_to_dvobj(ap_iface))) {	/*DEV_AP_STARTING_NUM*/
+			ap_iface = _rtw_search_ap_iface(adapter);
+			RTW_INFO("get ("ADPT_FMT") to create BTQoSNull\n", ADPT_ARG(ap_iface));
+		}
+		#endif
+
+		if (MLME_IS_AP(ap_iface) || (nr_assoc_if == 0)) {
+			RsvdPageLoc.LocBTQosNull = TotalPageNum;
+
+			RTW_INFO("LocBTQosNull: %d\n", RsvdPageLoc.LocBTQosNull);
+
+			rtw_hal_construct_NullFunctionData(ap_iface,
+						&ReservedPagePacket[BufIndex],
+						&BTQosNullLength,
+						_TRUE, 0, 0, _FALSE);
+
+			rtw_hal_fill_fake_txdesc(ap_iface,
+					&ReservedPagePacket[BufIndex - TxDescLen],
+					BTQosNullLength, _FALSE, _TRUE, _FALSE);
+
+			CurtPktPageNum = (u8)PageNum(TxDescLen + BTQosNullLength,
+							 PageSize);
+
+			TotalPageNum += CurtPktPageNum;
+			BufIndex += (CurtPktPageNum * PageSize);
+
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("BTQosNull", CurtPktPageNum, TotalPageNum, TotalPacketLen);
+			#endif
+		}
+	}
+#endif /* CONFIG_BT_COEXIT */
+
+	TotalPacketLen = BufIndex;
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+		/*======== FW DEBUG MSG * n page ======== */
+		RsvdPageLoc.loc_fw_dbg_msg_pkt = TotalPageNum;
+		RTW_INFO("loc_fw_dbg_msg_pkt: %d\n", RsvdPageLoc.loc_fw_dbg_msg_pkt);
+		rtw_hal_construct_fw_dbg_msg_pkt(
+			adapter,
+			&ReservedPagePacket[BufIndex],
+			&fw_dbg_msg_pkt_len);
+
 		rtw_hal_fill_fake_txdesc(adapter,
 				 &ReservedPagePacket[BufIndex - TxDescLen],
-				 QosNullLength, _FALSE, _FALSE, _FALSE);
+				 fw_dbg_msg_pkt_len, _FALSE, _FALSE, _FALSE);
 
-		CurtPktPageNum = (u8)PageNum(TxDescLen + QosNullLength,
-					     PageSize);
+		CurtPktPageNum = (u8)PageNum(TxDescLen + fw_dbg_msg_pkt_len, PageSize);
 
 		TotalPageNum += CurtPktPageNum;
 
+		TotalPacketLen = BufIndex + fw_dbg_msg_pkt_len;
 		BufIndex += (CurtPktPageNum * PageSize);
-	}
-
-	TotalPacketLen = BufIndex + QosNullLength;
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 
 #ifdef CONFIG_WOWLAN
+	/*======== WOW * n page ======== */
 	if (pwrctl->wowlan_mode == _TRUE &&
-		pwrctl->wowlan_in_resume == _FALSE) {
+		pwrctl->wowlan_in_resume == _FALSE &&
+		!(registry_par->suspend_type == FW_IPS_DISABLE_BBRF && !check_fwstate(pmlmepriv, _FW_LINKED))) {/*WOW mode*/
 		rtw_hal_set_wow_fw_rsvd_page(adapter, ReservedPagePacket,
 					     BufIndex, TxDescLen, PageSize,
 			     &TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
@@ -9254,7 +10601,8 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 #endif /* CONFIG_WOWLAN */
 
 #ifdef CONFIG_P2P_WOWLAN
-	if (_TRUE == pwrctl->wowlan_p2p_mode) {
+	/*======== P2P WOW * n page ======== */
+	if (_TRUE == pwrctl->wowlan_p2p_mode) {/*WOW mode*/
 		rtw_hal_set_p2p_wow_fw_rsvd_page(adapter, ReservedPagePacket,
 						 BufIndex, TxDescLen, PageSize,
 				 &TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
@@ -9262,18 +10610,34 @@ static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page
 #endif /* CONFIG_P2P_WOWLAN */
 
 #ifdef CONFIG_LPS_PG
+	/*======== LPS PG * 1 page ======== */
 	/* must reserved last 1 x page for LPS PG Info*/
 	pwrctl->lpspg_rsvd_page_locate = TotalPageNum;
 	pwrctl->blpspg_info_up = _TRUE;
 	if (page_num)
 		TotalPageNum += LPS_PG_INFO_RSVD_PAGE_NUM;
+
+	#ifdef DBG_RSVD_PAGE_CFG
+	RSVD_PAGE_CFG("LPS_PG", LPS_PG_INFO_RSVD_PAGE_NUM,
+		(page_num) ? TotalPageNum : (TotalPageNum + LPS_PG_INFO_RSVD_PAGE_NUM),
+		TotalPacketLen);
+	#endif
+
 #endif
 
+	/*Note:  BufIndex already add a TxDescOffset offset in first Beacon page
+	* The "TotalPacketLen" is calculate by BufIndex.
+	* We need to decrease TxDescOffset before doing length check. by yiwei
+	*/
+	TotalPacketLen = TotalPacketLen - TxDescOffset;
+
 download_page:
 	if (page_num) {
 		*page_num = TotalPageNum;
 		rtw_mfree(ReservedPagePacket, MAX_CMDBUF_SZ);
 		ReservedPagePacket = NULL;
+		RTW_INFO(FUNC_ADPT_FMT" Get [ %s ] RsvdPageNUm <==\n",
+			FUNC_ADPT_ARG(adapter), (is_wow_mode) ? "WOW" : "NOR");
 		return;
 	}
 
@@ -9282,18 +10646,18 @@ download_page:
 		 __func__, TotalPageNum, TotalPacketLen);
 
 #ifdef CONFIG_LPS_PG
-	if ((TotalPacketLen + (LPS_PG_INFO_RSVD_PAGE_NUM * PageSize)) > MaxRsvdPageBufSize) {
+	if ((TotalPageNum + LPS_PG_INFO_RSVD_PAGE_NUM) > RsvdPageNum) {
 		pwrctl->lpspg_rsvd_page_locate = 0;
 		pwrctl->blpspg_info_up = _FALSE;
 
-		RTW_ERR("%s rsvd page size is not enough!!TotalPacketLen+LPS_PG_INFO_LEN %d, MaxRsvdPageBufSize %d\n",
-			 __func__, (TotalPacketLen + (LPS_PG_INFO_RSVD_PAGE_NUM * PageSize)), MaxRsvdPageBufSize);
+		RTW_ERR("%s [LPS_PG] rsvd page %d  is not enough! need %d pages\n",
+			__func__, RsvdPageNum, (TotalPageNum + LPS_PG_INFO_RSVD_PAGE_NUM));
 		rtw_warn_on(1);
 	}
 #endif
 
 	if (TotalPacketLen > MaxRsvdPageBufSize) {
-		RTW_ERR("%s(ERROR): rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
+		RTW_ERR("%s : rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
 			 __FUNCTION__, TotalPacketLen, MaxRsvdPageBufSize);
 		rtw_warn_on(1);
 		goto error;
@@ -9302,8 +10666,8 @@ download_page:
 		pattrib = &pcmdframe->attrib;
 		update_mgntframe_attrib(adapter, pattrib);
 		pattrib->qsel = QSLT_BEACON;
-		pattrib->pktlen = TotalPacketLen - TxDescOffset;
-		pattrib->last_txcmdsz = TotalPacketLen - TxDescOffset;
+		pattrib->pktlen = TotalPacketLen;
+		pattrib->last_txcmdsz = TotalPacketLen;
 #ifdef CONFIG_PCI_HCI
 		dump_mgntframe(adapter, pcmdframe);
 #else
@@ -9318,8 +10682,14 @@ download_page:
 	RTW_INFO_DUMP("\n", ReservedPagePacket, TotalPacketLen);
 	RTW_INFO(" ==================================================\n");
 #endif
-	if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
+
+
+	if (check_fwstate(pmlmepriv, _FW_LINKED)
+		|| MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)){
 		rtw_hal_set_FwRsvdPage_cmd(adapter, &RsvdPageLoc);
+#ifdef DBG_FW_DEBUG_MSG_PKT
+		rtw_hal_set_fw_dbg_msg_pkt_rsvd_page_cmd(adapter, &RsvdPageLoc);
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 #ifdef CONFIG_WOWLAN
 		if (pwrctl->wowlan_mode == _TRUE &&
 			pwrctl->wowlan_in_resume == _FALSE)
@@ -9353,7 +10723,10 @@ error:
 
 void rtw_hal_set_fw_rsvd_page(struct _ADAPTER *adapter, bool finished)
 {
-	_rtw_hal_set_fw_rsvd_page(adapter, finished, NULL);
+	if (finished)
+		rtw_mi_tx_beacon_hdl(adapter);
+	else
+		_rtw_hal_set_fw_rsvd_page(adapter, finished, NULL);
 }
 
 /**
@@ -9376,7 +10749,107 @@ u8 rtw_hal_get_rsvd_page_num(struct _ADAPTER *adapter)
 	return num;
 }
 
-static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 variable, u8 *val)
+static void hw_var_set_bcn_func(_adapter *adapter, u8 enable)
+{
+	u32 bcn_ctrl_reg;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (adapter->hw_port == HW_PORT1)
+		bcn_ctrl_reg = REG_BCN_CTRL_1;
+	else
+#endif
+		bcn_ctrl_reg = REG_BCN_CTRL;
+
+	if (enable)
+		rtw_write8(adapter, bcn_ctrl_reg, (EN_BCN_FUNCTION | EN_TXBCN_RPT));
+	else {
+		u8 val8;
+
+		val8 = rtw_read8(adapter, bcn_ctrl_reg);
+		val8 &= ~(EN_BCN_FUNCTION | EN_TXBCN_RPT);
+
+#ifdef CONFIG_BT_COEXIST
+		if (GET_HAL_DATA(adapter)->EEPROMBluetoothCoexist == 1) {
+			/* Always enable port0 beacon function for PSTDMA */
+			if (REG_BCN_CTRL == bcn_ctrl_reg)
+				val8 |= EN_BCN_FUNCTION;
+		}
+#endif
+
+		rtw_write8(adapter, bcn_ctrl_reg, val8);
+	}
+
+#ifdef CONFIG_RTL8192F
+	if (IS_HARDWARE_TYPE_8192F(adapter)) {
+		u16 val16, val16_ori;
+
+		val16_ori = val16 = rtw_read16(adapter, REG_WLAN_ACT_MASK_CTRL_1);
+
+		#ifdef CONFIG_CONCURRENT_MODE
+		if (adapter->hw_port == HW_PORT1) {
+			if (enable)
+				val16 |= EN_PORT_1_FUNCTION;
+			else
+				val16 &= ~EN_PORT_1_FUNCTION;
+		} else
+		#endif
+		{
+			if (enable)
+				val16 |= EN_PORT_0_FUNCTION;
+			else
+				val16 &= ~EN_PORT_0_FUNCTION;
+
+			#ifdef CONFIG_BT_COEXIST
+			if (GET_HAL_DATA(adapter)->EEPROMBluetoothCoexist == 1)
+				val16 |= EN_PORT_0_FUNCTION;
+			#endif
+		}
+
+		if (val16 != val16_ori)
+			rtw_write16(adapter, REG_WLAN_ACT_MASK_CTRL_1,  val16);
+	}
+#endif
+}
+
+static void hw_var_set_mlme_disconnect(_adapter *adapter)
+{
+	u8 val8;
+
+	/* reject all data frames */
+#ifdef CONFIG_CONCURRENT_MODE
+	if (rtw_mi_check_status(adapter, MI_LINKED) == _FALSE)
+#endif
+		rtw_write16(adapter, REG_RXFLTMAP2, 0x0000);
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (adapter->hw_port == HW_PORT1) {
+		/* reset TSF1 */
+		rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(1));
+
+		/* disable update TSF1 */
+		rtw_iface_disable_tsf_update(adapter);
+
+		if (!IS_HARDWARE_TYPE_8723D(adapter)
+			&& !IS_HARDWARE_TYPE_8192F(adapter)
+			&& !IS_HARDWARE_TYPE_8710B(adapter)
+		) {
+			/* disable Port1's beacon function */
+			val8 = rtw_read8(adapter, REG_BCN_CTRL_1);
+			val8 &= ~EN_BCN_FUNCTION;
+			rtw_write8(adapter, REG_BCN_CTRL_1, val8);
+		}
+	} else
+#endif
+	{
+		/* reset TSF */
+		rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(0));
+
+		/* disable update TSF */
+		rtw_iface_disable_tsf_update(adapter);
+	}
+}
+
+static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 enable)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
@@ -9396,7 +10869,7 @@ static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 variable, u8 *val)
 	value_rxfltmap2 = 0;
 #endif
 
-	if (*((u8 *)val)) { /* under sitesurvey */
+	if (enable) { /* under sitesurvey */
 		/*
 		* 1. configure REG_RXFLTMAP2
 		* 2. disable TSF update &  buddy TSF update to avoid updating wrong TSF due to clear RCR_CBSSID_BCN
@@ -9404,29 +10877,6 @@ static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 variable, u8 *val)
 		*/
 		rtw_write16(adapter, REG_RXFLTMAP2, value_rxfltmap2);
 
-#ifdef CONFIG_MI_WITH_MBSSID_CAM
-		/*do nothing~~*/
-#else
-
-		/* disable update TSF */
-		for (i = 0; i < dvobj->iface_nums; i++) {
-			iface = dvobj->padapters[i];
-			if (!iface)
-				continue;
-
-			if (rtw_linked_check(iface)
-				&& !MLME_IS_AP(iface) && !MLME_IS_MESH(iface)
-			) {
-				if (iface->hw_port == HW_PORT1)
-					rtw_write8(iface, REG_BCN_CTRL_1, rtw_read8(iface, REG_BCN_CTRL_1) | DIS_TSF_UDT);
-				else
-					rtw_write8(iface, REG_BCN_CTRL, rtw_read8(iface, REG_BCN_CTRL) | DIS_TSF_UDT);
-
-				iface->mlmeextpriv.en_hw_update_tsf = _FALSE;
-			}
-		}
-#endif /* CONFIG_MI_WITH_MBSSID_CAM */
-
 		rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_ENTER);
 
 		/* Save orignal RRSR setting. needed? */
@@ -9446,38 +10896,15 @@ static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 variable, u8 *val)
 		/*
 		* 1. enable rx data frame
 		* 2. config RCR not to receive different BSSID BCN or probe rsp
-		* 3. doesn't enable TSF update &  buddy TSF right now to avoid HW conflict
-		*	 so, we enable TSF update when rx first BCN after sitesurvey done
-		*/
-		if (rtw_mi_check_fwstate(adapter, _FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE)) {
-			/* enable to rx data frame */
-			rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
-		}
-
-		rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_DONE);
-
-#ifdef CONFIG_MI_WITH_MBSSID_CAM
-		/*if ((rtw_mi_get_assoced_sta_num(adapter) == 1) && (!rtw_mi_check_status(adapter, MI_AP_MODE)))
-			rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL)&(~DIS_TSF_UDT));*/
-#else
-
-		for (i = 0; i < dvobj->iface_nums; i++) {
-			iface = dvobj->padapters[i];
-			if (!iface)
-				continue;
-			if (rtw_linked_check(iface)
-				&& !MLME_IS_AP(iface) && !MLME_IS_MESH(iface)
-			) {
-				/* enable HW TSF update when recive beacon*/
-				/*if (iface->hw_port == HW_PORT1)
-					rtw_write8(iface, REG_BCN_CTRL_1, rtw_read8(iface, REG_BCN_CTRL_1)&(~(DIS_TSF_UDT)));
-				else
-					rtw_write8(iface, REG_BCN_CTRL, rtw_read8(iface, REG_BCN_CTRL)&(~(DIS_TSF_UDT)));
-				*/
-				iface->mlmeextpriv.en_hw_update_tsf = _TRUE;
-			}
+		* 3. doesn't enable TSF update &  buddy TSF right now to avoid HW conflict
+		*	 so, we enable TSF update when rx first BCN after sitesurvey done
+		*/
+		if (rtw_mi_check_fwstate(adapter, _FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE)) {
+			/* enable to rx data frame */
+			rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
 		}
-#endif /* CONFIG_MI_WITH_MBSSID_CAM */
+
+		rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_DONE);
 
 		/* Restore orignal RRSR setting. needed? */
 		rtw_write16(adapter, REG_RRSR, hal_data->RegRRSR);
@@ -9496,6 +10923,90 @@ static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 variable, u8 *val)
 	}
 }
 
+static void hw_var_set_mlme_join(_adapter *adapter, u8 type)
+{
+	u8 val8;
+	u16 val16;
+	u32 val32;
+	u8 RetryLimit = RL_VAL_STA;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
+
+#ifdef CONFIG_CONCURRENT_MODE
+	if (type == 0) {
+		/* prepare to join */
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
+			StopTxBeacon(adapter);
+
+		/* enable to rx data frame.Accept all data frame */
+		rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
+
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+			RetryLimit = (hal_data->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
+		else /* Ad-hoc Mode */
+			RetryLimit = RL_VAL_AP;
+
+		rtw_iface_enable_tsf_update(adapter);
+
+	} else if (type == 1) {
+		/* joinbss_event call back when join res < 0 */
+		if (rtw_mi_check_status(adapter, MI_LINKED) == _FALSE)
+			rtw_write16(adapter, REG_RXFLTMAP2, 0x00);
+
+		rtw_iface_disable_tsf_update(adapter);
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
+			ResumeTxBeacon(adapter);
+
+			/* reset TSF 1/2 after ResumeTxBeacon */
+			rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(1) | BIT(0));
+		}
+
+	} else if (type == 2) {
+		/* sta add event call back */
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
+			/* fixed beacon issue for 8191su........... */
+			rtw_write8(adapter, 0x542 , 0x02);
+			RetryLimit = RL_VAL_AP;
+		}
+
+		if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
+			ResumeTxBeacon(adapter);
+
+			/* reset TSF 1/2 after ResumeTxBeacon */
+			rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(1) | BIT(0));
+		}
+	}
+
+	val16 = BIT_SRL(RetryLimit) | BIT_LRL(RetryLimit);
+	rtw_write16(adapter, REG_RETRY_LIMIT, val16);
+#else /* !CONFIG_CONCURRENT_MODE */
+	if (type == 0) { /* prepare to join */
+		/* enable to rx data frame.Accept all data frame */
+		rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
+
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
+			RetryLimit = (hal_data->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
+		else /* Ad-hoc Mode */
+			RetryLimit = RL_VAL_AP;
+
+		rtw_iface_enable_tsf_update(adapter);
+
+	} else if (type == 1) { /* joinbss_event call back when join res < 0 */
+		rtw_write16(adapter, REG_RXFLTMAP2, 0x00);
+
+		rtw_iface_disable_tsf_update(adapter);
+
+	} else if (type == 2) { /* sta add event call back */
+		if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE))
+			RetryLimit = RL_VAL_AP;
+	}
+
+	val16 = BIT_SRL(RetryLimit) | BIT_LRL(RetryLimit);
+	rtw_write16(adapter, REG_RETRY_LIMIT, val16);
+#endif /* !CONFIG_CONCURRENT_MODE */
+}
+
 #ifdef CONFIG_TSF_RESET_OFFLOAD
 static int rtw_hal_h2c_reset_tsf(_adapter *adapter, u8 reset_port)
 {
@@ -9539,39 +11050,284 @@ int rtw_hal_reset_tsf(_adapter *adapter, u8 reset_port)
 }
 #endif /* CONFIG_TSF_RESET_OFFLOAD */
 
-static void rtw_hal_set_hw_update_tsf(PADAPTER padapter)
+#ifdef CONFIG_HW_P0_TSF_SYNC
+#ifdef CONFIG_CONCURRENT_MODE
+static void hw_port0_tsf_sync_sel(_adapter *adapter, u8 benable, u8 hw_port, u16 tr_offset)
 {
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	u8 val8;
+	u8 client_id = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 
-#if defined(CONFIG_RTL8822B) || defined(CONFIG_MI_WITH_MBSSID_CAM)
-	RTW_INFO("[Warn] %s "ADPT_FMT" enter func\n", __func__, ADPT_ARG(padapter));
-	rtw_warn_on(1);
-	return;
+#ifdef CONFIG_MCC_MODE
+	if (MCC_EN(adapter) && (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))) {
+		RTW_INFO("[MCC] do not set HW TSF sync\n");
+		return;
+	}
 #endif
+	/* check if port0 is already synced */
+	if (benable && dvobj->p0_tsf.sync_port != MAX_HW_PORT && dvobj->p0_tsf.sync_port == hw_port) {
+		RTW_WARN(FUNC_ADPT_FMT ": port0 already enable TSF sync(%d)\n",
+			FUNC_ADPT_ARG(adapter), dvobj->p0_tsf.sync_port);
+		return;
+	}
 
-	if (!pmlmeext->en_hw_update_tsf)
+	/* check if port0 already disable sync */
+	if (!benable && dvobj->p0_tsf.sync_port == MAX_HW_PORT) {
+		RTW_WARN(FUNC_ADPT_FMT ": port0 already disable TSF sync\n", FUNC_ADPT_ARG(adapter));
 		return;
+	}
 
-	/* check RCR */
-	if (!rtw_hal_rcr_check(padapter, RCR_CBSSID_BCN))
+	/* check if port0 sync to port0 */
+	if (benable && hw_port == HW_PORT0) {
+		RTW_ERR(FUNC_ADPT_FMT ": hw_port is port0 under enable\n", FUNC_ADPT_ARG(adapter));
+		rtw_warn_on(1);
 		return;
+	}
 
-	/* enable hw update tsf function for non-AP and non-Mesh */
-	if (rtw_linked_check(padapter)
-		&& !MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter)
-	) {
+	/*0x5B4 [6:4] :SYNC_CLI_SEL - The selector for the CLINT port of sync tsft source for port 0*/
+	/*	Bit[5:4] : 0 for clint0, 1 for clint1, 2 for clint2, 3 for clint3.
+		Bit6 : 1= enable sync to port 0. 0=disable sync to port 0.*/
+
+	val8 = rtw_read8(adapter, REG_TIMER0_SRC_SEL);
+
+	if (benable) {
+		/*Disable Port0's beacon function*/
+		rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL) & ~BIT_EN_BCN_FUNCTION);
+
+		/*Reg 0x518[15:0]: TSFTR_SYN_OFFSET*/
+		if (tr_offset)
+			rtw_write16(adapter, REG_TSFTR_SYN_OFFSET, tr_offset);
+
+		/*reg 0x577[6]=1*/	/*auto sync by tbtt*/
+		rtw_write8(adapter, REG_MISC_CTRL, rtw_read8(adapter, REG_MISC_CTRL) | BIT_AUTO_SYNC_BY_TBTT);
+
+		if (HW_PORT1 == hw_port)
+			client_id = 0;
+		else if (HW_PORT2 == hw_port)
+			client_id = 1;
+		else if (HW_PORT3 == hw_port)
+			client_id = 2;
+		else if (HW_PORT4 == hw_port)
+			client_id = 3;
+
+		val8 &= 0x8F;
+		val8 |= (BIT(6) | (client_id << 4));
+
+		dvobj->p0_tsf.sync_port = hw_port;
+		dvobj->p0_tsf.offset = tr_offset;
+		rtw_write8(adapter, REG_TIMER0_SRC_SEL, val8);
+
+		/*Enable Port0's beacon function*/
+		rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL)  | BIT_EN_BCN_FUNCTION);
+		RTW_INFO("%s Port_%d TSF sync to P0, timer offset :%d\n", __func__, hw_port, tr_offset);
+	} else {
+		val8 &= ~BIT(6);
+
+		dvobj->p0_tsf.sync_port = MAX_HW_PORT;
+		dvobj->p0_tsf.offset = 0;
+		rtw_write8(adapter, REG_TIMER0_SRC_SEL, val8);
+		RTW_INFO("%s P0 TSF sync disable\n", __func__);
+	}
+}
+static _adapter * _search_ld_sta(_adapter *adapter, u8 include_self)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 i;
+	_adapter *iface = NULL;
+
+	if (rtw_mi_get_assoced_sta_num(adapter) == 0) {
+		RTW_ERR("STA_LD_NUM == 0\n");
+		rtw_warn_on(1);
+	}
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+		if (include_self == _FALSE && adapter == iface)
+			continue;
+		if (is_client_associated_to_ap(iface))
+			break;
+	}
+	if (iface)
+		RTW_INFO("search STA iface -"ADPT_FMT"\n", ADPT_ARG(iface));
+	return iface;
+}
+#endif /*CONFIG_CONCURRENT_MODE*/
+/*Correct port0's TSF*/
+/*#define DBG_P0_TSF_SYNC*/
+void hw_var_set_correct_tsf(PADAPTER adapter, u8 mlme_state)
+{
 #ifdef CONFIG_CONCURRENT_MODE
-		if (padapter->hw_port == HW_PORT1)
-			rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) & (~DIS_TSF_UDT));
-		else
-#endif
-			rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) & (~DIS_TSF_UDT));
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 p0_tsfsync = _FALSE;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+	_adapter *sta_if = NULL;
+	u8 hw_port;
+
+	RTW_INFO(FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(adapter));
+	#ifdef DBG_P0_TSF_SYNC
+	RTW_INFO("[TSF_SYNC] AP_NUM = %d\n", rtw_mi_get_ap_num(adapter));
+	RTW_INFO("[TSF_SYNC] MESH_NUM = %d\n", rtw_mi_get_mesh_num(adapter));
+	RTW_INFO("[TSF_SYNC] LD_STA_NUM = %d\n", rtw_mi_get_assoced_sta_num(adapter));
+	if (dvobj->p0_tsf.sync_port == MAX_HW_PORT)
+		RTW_INFO("[TSF_SYNC] org p0 sync port = N/A\n");
+	else
+		RTW_INFO("[TSF_SYNC] org p0 sync port = %d\n", dvobj->p0_tsf.sync_port);
+	RTW_INFO("[TSF_SYNC] timer offset = %d\n", dvobj->p0_tsf.offset);
+	#endif
+	switch (mlme_state) {
+		case MLME_STA_CONNECTED :
+			{
+				hw_port = rtw_hal_get_port(adapter);
+
+				if (!MLME_IS_STA(adapter)) {
+					RTW_ERR("STA CON state,but iface("ADPT_FMT") is not STA\n", ADPT_ARG(adapter));
+					rtw_warn_on(1);
+				}
+
+				if ((dvobj->p0_tsf.sync_port != MAX_HW_PORT) && (hw_port == HW_PORT0)) {
+					RTW_ERR(ADPT_FMT" is STA with P0 connected => DIS P0_TSF_SYNC\n", ADPT_ARG(adapter));
+					rtw_warn_on(1);
+					hw_port0_tsf_sync_sel(adapter, _FALSE, 0, 0);
+				}
+
+				if ((dvobj->p0_tsf.sync_port == MAX_HW_PORT) &&
+					(rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))) {
+					hw_port0_tsf_sync_sel(adapter, _TRUE, hw_port, 50);/*timer offset 50ms*/
+					#ifdef DBG_P0_TSF_SYNC
+					RTW_INFO("[TSF_SYNC] STA_LINKED => EN P0_TSF_SYNC\n");
+					#endif
+				}
+			}
+			break;
+		case MLME_STA_DISCONNECTED :
+			{
+				hw_port = rtw_hal_get_port(adapter);
+
+				if (!MLME_IS_STA(adapter)) {
+					RTW_ERR("STA DIS_CON state,but iface("ADPT_FMT") is not STA\n", ADPT_ARG(adapter));
+					rtw_warn_on(1);
+				}
+
+				if (dvobj->p0_tsf.sync_port == hw_port) {
+					if (rtw_mi_get_assoced_sta_num(adapter) >= 2) {
+						/* search next appropriate sta*/
+						sta_if = _search_ld_sta(adapter, _FALSE);
+						if (sta_if) {
+							hw_port = rtw_hal_get_port(sta_if);
+							hw_port0_tsf_sync_sel(adapter, _TRUE, hw_port, 50);/*timer offset 50ms*/
+							#ifdef DBG_P0_TSF_SYNC
+							RTW_INFO("[TSF_SYNC] STA_DIS_CON => CHANGE P0_TSF_SYNC\n");
+							#endif
+						}
+					} else if (rtw_mi_get_assoced_sta_num(adapter) == 1) {
+						hw_port0_tsf_sync_sel(adapter, _FALSE, 0, 0);
+						#ifdef DBG_P0_TSF_SYNC
+						RTW_INFO("[TSF_SYNC] STA_DIS_CON => DIS P0_TSF_SYNC\n");
+						#endif
+					}
+				}
+			}
+			break;
+		case MLME_AP_STARTED :
+		case MLME_MESH_STARTED :
+			{
+				if (!(MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))) {
+					RTW_ERR("AP START state,but iface("ADPT_FMT") is not AP\n", ADPT_ARG(adapter));
+					rtw_warn_on(1);
+				}
+
+				if ((dvobj->p0_tsf.sync_port == MAX_HW_PORT) &&
+					rtw_mi_get_assoced_sta_num(adapter)) {
+					/* get port of sta */
+					sta_if = _search_ld_sta(adapter, _FALSE);
+					if (sta_if) {
+						hw_port = rtw_hal_get_port(sta_if);
+						hw_port0_tsf_sync_sel(adapter, _TRUE, hw_port, 50);/*timer offset 50ms*/
+						#ifdef DBG_P0_TSF_SYNC
+						RTW_INFO("[TSF_SYNC] AP_START => EN P0_TSF_SYNC\n");
+						#endif
+					}
+				}
+			}
+			break;
+		case MLME_AP_STOPPED :
+		case MLME_MESH_STOPPED :
+			{
+				if (!(MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))) {
+					RTW_ERR("AP START state,but iface("ADPT_FMT") is not AP\n", ADPT_ARG(adapter));
+					rtw_warn_on(1);
+				}
+				/*stop ap mode*/
+				if ((rtw_mi_get_ap_num(adapter) + rtw_mi_get_mesh_num(adapter) == 1) &&
+					(dvobj->p0_tsf.sync_port != MAX_HW_PORT)) {
+					hw_port0_tsf_sync_sel(adapter, _FALSE, 0, 0);
+					#ifdef DBG_P0_TSF_SYNC
+					RTW_INFO("[TSF_SYNC] AP_STOP => DIS P0_TSF_SYNC\n");
+					#endif
+				}
+			}
+			break;
+		default :
+			RTW_ERR(FUNC_ADPT_FMT" unknow state(0x%02x)\n", FUNC_ADPT_ARG(adapter), mlme_state);
+			break;
 	}
-	pmlmeext->en_hw_update_tsf = _FALSE;
+
+	/*#ifdef DBG_P0_TSF_SYNC*/
+	#if 1
+	if (dvobj->p0_tsf.sync_port == MAX_HW_PORT)
+		RTW_INFO("[TSF_SYNC] p0 sync port = N/A\n");
+	else
+		RTW_INFO("[TSF_SYNC] p0 sync port = %d\n", dvobj->p0_tsf.sync_port);
+	RTW_INFO("[TSF_SYNC] timer offset = %d\n", dvobj->p0_tsf.offset);
+	#endif
+#endif /*CONFIG_CONCURRENT_MODE*/
+}
+
+#else
+static void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf)
+{
+	if (hw_port == HW_PORT0) {
+		/*disable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) & (~EN_BCN_FUNCTION));
+#if defined(CONFIG_RTL8192F)
+		rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
+					REG_WLAN_ACT_MASK_CTRL_1) & ~EN_PORT_0_FUNCTION);
+#endif
+
+		rtw_write32(padapter, REG_TSFTR, tsf);
+		rtw_write32(padapter, REG_TSFTR + 4, tsf >> 32);
+
+		/*enable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) | EN_BCN_FUNCTION);
+#if defined(CONFIG_RTL8192F)
+		rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
+					REG_WLAN_ACT_MASK_CTRL_1) | EN_PORT_0_FUNCTION);
+#endif
+	} else if (hw_port == HW_PORT1) {
+		/*disable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) & (~EN_BCN_FUNCTION));
+#if defined(CONFIG_RTL8192F)
+		rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
+					REG_WLAN_ACT_MASK_CTRL_1) & ~EN_PORT_1_FUNCTION);
+#endif
+
+		rtw_write32(padapter, REG_TSFTR1, tsf);
+		rtw_write32(padapter, REG_TSFTR1 + 4, tsf >> 32);
+
+		/*enable related TSF function*/
+		rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) | EN_BCN_FUNCTION);
+#if defined(CONFIG_RTL8192F)
+		rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
+					REG_WLAN_ACT_MASK_CTRL_1) | EN_PORT_1_FUNCTION);
+#endif
+	} else
+		RTW_INFO("%s-[WARN] "ADPT_FMT" invalid hw_port:%d\n", __func__, ADPT_ARG(padapter), hw_port);
 }
 
-static void hw_var_set_correct_tsf(_adapter *adapter)
+static void hw_var_set_correct_tsf(_adapter *adapter, u8 mlme_state)
 {
 #ifdef CONFIG_MI_WITH_MBSSID_CAM
 	/*do nothing*/
@@ -9624,6 +11380,81 @@ static void hw_var_set_correct_tsf(_adapter *adapter)
 
 #endif /*CONFIG_MI_WITH_MBSSID_CAM*/
 }
+#endif
+
+u64 rtw_hal_get_tsftr_by_port(_adapter *adapter, u8 port)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	u64 tsftr = 0;
+
+	if (port >= hal_spec->port_num) {
+		RTW_ERR("%s invalid port(%d) \n", __func__, port);
+		goto exit;
+	}
+
+	switch (rtw_get_chip_type(adapter)) {
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+	case RTL8814A:
+	case RTL8822B:
+	case RTL8821C:
+	{
+		u8 val8;
+
+		/* 0x554[30:28] - BIT_BCN_TIMER_SEL_FWRD */
+		val8 = rtw_read8(adapter, REG_MBSSID_BCN_SPACE + 3);
+		val8 &= 0x8F;
+		val8 |= port << 4;
+		rtw_write8(adapter, REG_MBSSID_BCN_SPACE + 3, val8);
+
+		tsftr = rtw_read32(adapter, REG_TSFTR + 4);
+		tsftr = tsftr << 32;
+		tsftr |= rtw_read32(adapter, REG_TSFTR);
+
+		break;
+	}
+#endif
+#if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) \
+		|| defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8192F) \
+		|| defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || defined(CONFIG_RTL8723D) \
+		|| defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) \
+		|| defined(CONFIG_RTL8710B)
+	case RTL8188E:
+	case RTL8188F:
+	case RTL8188GTV:
+	case RTL8192E:
+	case RTL8192F:
+	case RTL8723B:
+	case RTL8703B:
+	case RTL8723D:
+	case RTL8812:
+	case RTL8821:
+	case RTL8710B:
+	{
+		u32 addr;
+
+		if (port == HW_PORT0)
+			addr = REG_TSFTR;
+		else if (port == HW_PORT1)
+			addr = REG_TSFTR1;
+		else {
+			RTW_ERR("%s unknown port(%d) \n", __func__, port);
+			goto exit;
+		}
+
+		tsftr = rtw_read32(adapter, addr + 4);
+		tsftr = tsftr << 32;
+		tsftr |= rtw_read32(adapter, addr);
+
+		break;
+	}
+#endif
+	default:
+		RTW_ERR("%s unknow chip type\n", __func__);
+	}
+
+exit:
+	return tsftr;
+}
 
 #ifdef CONFIG_TDLS
 #ifdef CONFIG_TDLS_CH_SW
@@ -9667,16 +11498,39 @@ void rtw_hal_update_uapsd_tid(_adapter *adapter)
 
 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
 /* For multi-port support, driver needs to inform the port ID to FW for btc operations */
-s32 rtw_hal_set_wifi_port_id_cmd(_adapter *adapter)
+s32 rtw_hal_set_wifi_btc_port_id_cmd(_adapter *adapter)
 {
-	u8 port_id = 0;
 	u8 h2c_buf[H2C_BTC_WL_PORT_ID_LEN] = {0};
+	u8 hw_port = rtw_hal_get_port(adapter);
 
-	SET_H2CCMD_BTC_WL_PORT_ID(h2c_buf, adapter->hw_port);
+	SET_H2CCMD_BTC_WL_PORT_ID(h2c_buf, hw_port);
+	RTW_INFO("%s ("ADPT_FMT") - hw_port :%d\n", __func__, ADPT_ARG(adapter), hw_port);
 	return rtw_hal_fill_h2c_cmd(adapter, H2C_BTC_WL_PORT_ID, H2C_BTC_WL_PORT_ID_LEN, h2c_buf);
 }
 #endif
 
+#define LPS_ACTIVE_TIMEOUT	10 /*number of times*/
+void rtw_lps_state_chk(_adapter *adapter, u8 ps_mode)
+{
+	if (ps_mode == PS_MODE_ACTIVE) {
+		u8 ps_ready = _FALSE;
+		s8 leave_wait_count = LPS_ACTIVE_TIMEOUT;
+
+		do {
+			if ((rtw_read8(adapter, REG_TCR) & BIT_PWRBIT_OW_EN) == 0) {
+				ps_ready = _TRUE;
+				break;
+			}
+			rtw_msleep_os(1);
+		} while (leave_wait_count--);
+
+		if (ps_ready == _FALSE) {
+			RTW_ERR(FUNC_ADPT_FMT" PS_MODE_ACTIVE check failed\n", FUNC_ADPT_ARG(adapter));
+			rtw_warn_on(1);
+		}
+	}
+}
+
 u8 SetHwReg(_adapter *adapter, u8 variable, u8 *val)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
@@ -9689,6 +11543,12 @@ u8 SetHwReg(_adapter *adapter, u8 variable, u8 *val)
 		rtw_hal_set_msr(adapter, net_type);
 	}
 	break;
+	case HW_VAR_DO_IQK:
+		if (*val)
+			hal_data->bNeedIQK = _TRUE;
+		else
+			hal_data->bNeedIQK = _FALSE;
+		break;
 	case HW_VAR_MAC_ADDR:
 #ifdef CONFIG_MI_WITH_MBSSID_CAM
 		rtw_hal_set_macaddr_mbid(adapter, val);
@@ -9836,22 +11696,56 @@ u8 SetHwReg(_adapter *adapter, u8 variable, u8 *val)
 		break;
 #endif /*defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)*/
 
+	case HW_VAR_BCN_FUNC:
+		hw_var_set_bcn_func(adapter, *val);
+		break;
+
+	case HW_VAR_MLME_DISCONNECT:
+		hw_var_set_mlme_disconnect(adapter);
+		break;
+
 	case HW_VAR_MLME_SITESURVEY:
-		hw_var_set_mlme_sitesurvey(adapter, variable, val);
+		hw_var_set_mlme_sitesurvey(adapter, *val);
 		#ifdef CONFIG_BT_COEXIST
 		if (hal_data->EEPROMBluetoothCoexist == 1)
 			rtw_btcoex_ScanNotify(adapter, *val ? _TRUE : _FALSE);
 		#endif
 		break;
 
+	case HW_VAR_MLME_JOIN:
+		hw_var_set_mlme_join(adapter, *val);
+		#ifdef CONFIG_BT_COEXIST
+		if (hal_data->EEPROMBluetoothCoexist == 1) {
+			switch (*val) {
+			case 0:
+				/* Notify coex. mechanism before join */
+				rtw_btcoex_ConnectNotify(adapter, _TRUE);
+				break;
+			case 1:
+			case 2:
+				/* Notify coex. mechanism after join, whether successful or failed */
+				rtw_btcoex_ConnectNotify(adapter, _FALSE);
+				break;
+			}
+		}
+		#endif /* CONFIG_BT_COEXIST */
+		break;
+
 	case HW_VAR_EN_HW_UPDATE_TSF:
 		rtw_hal_set_hw_update_tsf(adapter);
 		break;
-
 	case HW_VAR_CORRECT_TSF:
-		hw_var_set_correct_tsf(adapter);
+		hw_var_set_correct_tsf(adapter, *val);
 		break;
 
+#if defined(CONFIG_HW_P0_TSF_SYNC) && defined(CONFIG_CONCURRENT_MODE)
+	case HW_VAR_TSF_AUTO_SYNC:
+		if (*val == _TRUE)
+			hw_port0_tsf_sync_sel(adapter, _TRUE, adapter->hw_port, 50);
+		else
+			hw_port0_tsf_sync_sel(adapter, _FALSE, adapter->hw_port, 50);
+		break;
+#endif
 	case HW_VAR_APFM_ON_MAC:
 		hal_data->bMacPwrCtrlOn = *val;
 		RTW_INFO("%s: bMacPwrCtrlOn=%d\n", __func__, hal_data->bMacPwrCtrlOn);
@@ -9870,6 +11764,87 @@ u8 SetHwReg(_adapter *adapter, u8 variable, u8 *val)
 	case HW_VAR_DM_IN_LPS_LCLK:
 		rtw_phydm_wd_lps_lclk_hdl(adapter);
 		break;
+#endif
+	case HW_VAR_ENABLE_RX_BAR:
+		if (*val == _TRUE) {
+			/* enable RX BAR */
+			u16 val16 = rtw_read16(adapter, REG_RXFLTMAP1);
+
+			val16 |= BIT(8);
+			rtw_write16(adapter, REG_RXFLTMAP1, val16);
+		} else {
+			/* disable RX BAR */
+			u16 val16 = rtw_read16(adapter, REG_RXFLTMAP1);
+
+			val16 &= (~BIT(8));
+			rtw_write16(adapter, REG_RXFLTMAP1, val16);
+		}
+		RTW_INFO("[HW_VAR_ENABLE_RX_BAR] 0x%02X=0x%02X\n",
+			REG_RXFLTMAP1, rtw_read16(adapter, REG_RXFLTMAP1));
+		break;
+	case HW_VAR_HCI_SUS_STATE:
+		hal_data->hci_sus_state = *(u8 *)val;
+		RTW_INFO("%s: hci_sus_state=%u\n", __func__, hal_data->hci_sus_state);
+		break;
+#if defined(CONFIG_AP_MODE) && defined(CONFIG_FW_HANDLE_TXBCN) && defined(CONFIG_SUPPORT_MULTI_BCN)
+		case HW_VAR_BCN_HEAD_SEL:
+		{
+			u8 vap_id = *(u8 *)val;
+
+			if ((vap_id >= CONFIG_LIMITED_AP_NUM) && (vap_id != 0xFF)) {
+				RTW_ERR(ADPT_FMT " vap_id(%d:%d) is invalid\n", ADPT_ARG(adapter),vap_id, adapter->vap_id);
+				rtw_warn_on(1);
+			}
+			if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
+				u16 drv_pg_bndy = 0, bcn_addr = 0;
+				u32 page_size = 0;
+
+				/*rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_BOUNDARY, &drv_pg_bndy);*/
+				rtw_halmac_get_rsvd_drv_pg_bndy(adapter_to_dvobj(adapter), &drv_pg_bndy);
+				rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&page_size);
+
+				if (vap_id != 0xFF)
+					bcn_addr = drv_pg_bndy + (vap_id * (MAX_BEACON_LEN / page_size));
+				else
+					bcn_addr = drv_pg_bndy;
+				RTW_INFO(ADPT_FMT" vap_id(%d) change BCN HEAD to 0x%04x\n",
+					ADPT_ARG(adapter), vap_id, bcn_addr);
+				rtw_write16(adapter, REG_FIFOPAGE_CTRL_2,
+					(bcn_addr & BIT_MASK_BCN_HEAD_1_V1) | BIT_BCN_VALID_V1);
+			}
+		}
+		break;
+#endif
+	case HW_VAR_LPS_STATE_CHK :
+		rtw_lps_state_chk(adapter, *(u8 *)val);
+		break;
+
+#ifdef CONFIG_RTS_FULL_BW
+	case HW_VAR_SET_RTS_BW:
+	{
+		#ifdef RTW_HALMAC
+			rtw_halmac_set_rts_full_bw(adapter_to_dvobj(adapter), (*val));
+		#else
+			u8 temp;
+			if(*val)
+				temp = (( rtw_read8(adapter, REG_INIRTS_RATE_SEL)) | BIT5 );
+			else
+				temp = (( rtw_read8(adapter, REG_INIRTS_RATE_SEL)) & (~BIT5));
+			rtw_write8(adapter, REG_INIRTS_RATE_SEL, temp);
+			/*RTW_INFO("HW_VAR_SET_RTS_BW	val=%u REG480=0x%x\n", *val, rtw_read8(adapter, REG_INIRTS_RATE_SEL));*/
+		#endif
+	}
+	break;
+#endif/*CONFIG_RTS_FULL_BW*/
+#if defined(CONFIG_PCI_HCI)
+	case HW_VAR_ENSWBCN: 
+	if (*val == _TRUE) {
+		rtw_write8(adapter, REG_CR + 1,
+			   rtw_read8(adapter, REG_CR + 1) | BIT(0));
+	} else
+		rtw_write8(adapter, REG_CR + 1,
+			   rtw_read8(adapter, REG_CR + 1) & ~BIT(0));
+	break;
 #endif
 	default:
 		if (0)
@@ -9897,6 +11872,9 @@ void GetHwReg(_adapter *adapter, u8 variable, u8 *val)
 		break;
 	case HW_VAR_RF_TYPE:
 		*((u8 *)val) = hal_data->rf_type;
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA		
+		*((u8 *)val) = RF_1T1R;
+#endif
 		break;
 	case HW_VAR_MEDIA_STATUS:
 		rtw_hal_get_msr(adapter, val);
@@ -9938,14 +11916,12 @@ void GetHwReg(_adapter *adapter, u8 variable, u8 *val)
 		}
 		break;
 
-	case HW_VAR_TSF:
-		/* read and save HIGH 32bits TSF value */
-		val64 = rtw_read32(adapter, REG_TSFTR+4);
-		val64 = val64 << 32;
+	case HW_VAR_HCI_SUS_STATE:
+		*((u8 *)val) = hal_data->hci_sus_state;
+		break;
 
-		/* read and save LOW 32bits TSF value */
-		val64 |= rtw_read32(adapter, REG_TSFTR);
-		*((u64*)val) = val64;
+	case HW_VAR_BCN_CTRL_ADDR:
+		*((u32 *)val) = hw_bcn_ctrl_addr(adapter, adapter->hw_port);
 		break;
 
 	default:
@@ -9995,9 +11971,6 @@ SetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)
 	case HAL_DEF_ANT_DETECT:
 		hal_data->AntDetection = *((u8 *)value);
 		break;
-	case HAL_DEF_DBG_DIS_PWT:
-		hal_data->bDisableTXPowerTraining = *((u8 *)value);
-		break;
 	default:
 		RTW_PRINT("%s: [WARNING] HAL_DEF_VARIABLE(%d) not defined!\n", __FUNCTION__, variable);
 		bResult = _FAIL;
@@ -10052,6 +12025,35 @@ u8 rtw_hal_query_txbfee_rf_num(_adapter *adapter)
 		return 1;
 
 }
+#ifdef RTW_BEAMFORMING_VERSION_2
+void rtw_hal_beamforming_config_csirate(PADAPTER adapter)
+{
+	struct dm_struct *p_dm_odm;
+	struct beamforming_info *bf_info;
+	u8 fix_rate_enable = 0;
+	u8 new_csi_rate_idx;
+
+	/* Acting as BFee */
+	if (IS_BEAMFORMEE(adapter)) {
+	#if 0
+		/* Do not enable now because it will affect MU performance and CTS/BA rate. 2016.07.19. by tynli. [PCIE-1660] */
+		if (IS_HARDWARE_TYPE_8821C(Adapter))
+			FixRateEnable = 1;	/* Support after 8821C */
+	#endif
+
+		p_dm_odm = adapter_to_phydm(adapter);
+		bf_info = GET_BEAMFORM_INFO(adapter);
+
+		rtw_halmac_bf_cfg_csi_rate(adapter_to_dvobj(adapter),
+				p_dm_odm->rssi_min,
+				bf_info->cur_csi_rpt_rate,
+				fix_rate_enable, &new_csi_rate_idx);
+
+		if (new_csi_rate_idx != bf_info->cur_csi_rpt_rate)
+			bf_info->cur_csi_rpt_rate = new_csi_rate_idx;
+	}
+}
+#endif
 #endif
 
 u8
@@ -10085,9 +12087,6 @@ GetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)
 	case HAL_DEF_TX_PAGE_SIZE:
 		*((u32 *)value) = _get_page_size(adapter);
 		break;
-	case HAL_DEF_DBG_DIS_PWT:
-		*(u8 *)value = hal_data->bDisableTXPowerTraining;
-		break;
 	case HAL_DEF_EXPLICIT_BEAMFORMER:
 	case HAL_DEF_EXPLICIT_BEAMFORMEE:
 	case HAL_DEF_VHT_MU_BEAMFORMER:
@@ -10224,6 +12223,9 @@ GetFractionValueFromString(
 		++(*pu4bMove);
 	}
 
+	if (*szScan < '0' || *szScan > '9')
+		return _FALSE;
+
 	/* Parse each digit. */
 	do {
 		(*pInteger) *= 10;
@@ -10238,12 +12240,17 @@ GetFractionValueFromString(
 
 			if (*szScan < '0' || *szScan > '9')
 				return _FALSE;
-			else {
-				*pFraction = *szScan - '0';
+
+			*pFraction += (*szScan - '0') * 10;
+			++szScan;
+			++(*pu4bMove);
+
+			if (*szScan >= '0' && *szScan <= '9') {
+				*pFraction += *szScan - '0';
 				++szScan;
 				++(*pu4bMove);
-				return _TRUE;
 			}
+			return _TRUE;
 		}
 	} while (*szScan >= '0' && *szScan <= '9');
 
@@ -10349,12 +12356,14 @@ void rtw_hal_check_rxfifo_full(_adapter *adapter)
 		/* switch counter to RX fifo */
 		if (IS_8188E(pHalData->version_id) ||
 		    IS_8188F(pHalData->version_id) ||
+		    IS_8188GTV(pHalData->version_id) ||
 		    IS_8812_SERIES(pHalData->version_id) ||
 		    IS_8821_SERIES(pHalData->version_id) ||
 		    IS_8723B_SERIES(pHalData->version_id) ||
 		    IS_8192E(pHalData->version_id) ||
 		    IS_8703B_SERIES(pHalData->version_id) ||
-		    IS_8723D_SERIES(pHalData->version_id)) {
+		    IS_8723D_SERIES(pHalData->version_id) ||
+		    IS_8192F_SERIES(pHalData->version_id)) {
 			rtw_write8(adapter, REG_RXERR_RPT + 3, rtw_read8(adapter, REG_RXERR_RPT + 3) | 0xa0);
 			save_cnt = _TRUE;
 		} else {
@@ -10472,8 +12481,8 @@ void rtw_dump_rx_dframe_info(_adapter *padapter, void *sel)
 	struct sta_recv_dframe_info *psta_dframe_info;
 	int i, j;
 	_list	*plist, *phead;
-	u8 bc_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-	u8 null_addr[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
 
 	if (precvpriv->store_law_data_flag) {
 
@@ -10489,9 +12498,9 @@ void rtw_dump_rx_dframe_info(_adapter *padapter, void *sel)
 				plist = get_next(plist);
 
 				if (psta) {
-					if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6)  !=   _TRUE)
-					    && (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6)  !=  _TRUE)
-					    && (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), 6)  !=  _TRUE)) {
+					if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN)  !=   _TRUE)
+					    && (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN)  !=  _TRUE)
+					    && (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), ETH_ALEN)  !=  _TRUE)) {
 
 						RTW_PRINT_SEL(sel, "==============================\n");
 						RTW_PRINT_SEL(sel, "macaddr =" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
@@ -10595,61 +12604,6 @@ void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe)
 
 }
 
-
-int check_phy_efuse_tx_power_info_valid(PADAPTER padapter)
-{
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
-	u8 *pContent = pHalData->efuse_eeprom_data;
-	int index = 0;
-	u16 tx_index_offset = 0x0000;
-
-	switch (rtw_get_chip_type(padapter)) {
-	case RTL8723B:
-		tx_index_offset = EEPROM_TX_PWR_INX_8723B;
-		break;
-	case RTL8703B:
-		tx_index_offset = EEPROM_TX_PWR_INX_8703B;
-		break;
-	case RTL8723D:
-		tx_index_offset = EEPROM_TX_PWR_INX_8723D;
-		break;
-	case RTL8188E:
-		tx_index_offset = EEPROM_TX_PWR_INX_88E;
-		break;
-	case RTL8188F:
-		tx_index_offset = EEPROM_TX_PWR_INX_8188F;
-		break;
-	case RTL8192E:
-		tx_index_offset = EEPROM_TX_PWR_INX_8192E;
-		break;
-	case RTL8821:
-		tx_index_offset = EEPROM_TX_PWR_INX_8821;
-		break;
-	case RTL8812:
-		tx_index_offset = EEPROM_TX_PWR_INX_8812;
-		break;
-	case RTL8814A:
-		tx_index_offset = EEPROM_TX_PWR_INX_8814;
-		break;
-	case RTL8822B:
-		tx_index_offset = EEPROM_TX_PWR_INX_8822B;
-		break;
-	case RTL8821C:
-		tx_index_offset = EEPROM_TX_PWR_INX_8821C;
-		break;
-	default:
-		tx_index_offset = 0x0010;
-		break;
-	}
-
-	/* TODO: chacking length by ICs */
-	for (index = 0 ; index < 11 ; index++) {
-		if (pContent[tx_index_offset + index] == 0xFF)
-			return _FALSE;
-	}
-	return _TRUE;
-}
-
 int hal_efuse_macaddr_offset(_adapter *adapter)
 {
 	u8 interface_type = 0;
@@ -10705,6 +12659,14 @@ int hal_efuse_macaddr_offset(_adapter *adapter)
 			addr_offset = EEPROM_MAC_ADDR_8188FS;
 		break;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		if (interface_type == RTW_USB)
+			addr_offset = EEPROM_MAC_ADDR_8188GTVU;
+		else if (interface_type == RTW_SDIO)
+			addr_offset = EEPROM_MAC_ADDR_8188GTVS;
+		break;
+#endif
 #ifdef CONFIG_RTL8812A
 	case RTL8812:
 		if (interface_type == RTW_USB)
@@ -10763,6 +12725,25 @@ int hal_efuse_macaddr_offset(_adapter *adapter)
 			addr_offset = EEPROM_MAC_ADDR_8821CE;
 		break;
 #endif /* CONFIG_RTL8821C */
+
+#ifdef CONFIG_RTL8710B
+	case RTL8710B:
+		if (interface_type == RTW_USB)
+			addr_offset = EEPROM_MAC_ADDR_8710B;
+		break;
+#endif
+
+#ifdef CONFIG_RTL8192F
+	case RTL8192F:
+		if (interface_type == RTW_USB)
+			addr_offset = EEPROM_MAC_ADDR_8192FU;
+		else if (interface_type == RTW_SDIO)
+			addr_offset = EEPROM_MAC_ADDR_8192FS;
+		else if (interface_type == RTW_PCIE)
+			addr_offset = EEPROM_MAC_ADDR_8192FE;
+		break;
+#endif /* CONFIG_RTL8192F */
+
 	}
 
 	if (addr_offset == -1) {
@@ -10858,6 +12839,9 @@ int hal_config_macaddr(_adapter *adapter, bool autoload_fail)
 	int addr_offset = hal_efuse_macaddr_offset(adapter);
 	u8 *hw_addr = NULL;
 	int ret = _SUCCESS;
+#if defined(CONFIG_RTL8822B) && defined(CONFIG_USB_HCI)
+	u8 ft_mac_addr[ETH_ALEN] = {0x00, 0xff, 0xff, 0xff, 0xff, 0xff}; /* FT USB2 for 8822B */
+#endif
 
 	if (autoload_fail)
 		goto bypass_hw_pg;
@@ -10877,6 +12861,11 @@ int hal_config_macaddr(_adapter *adapter, bool autoload_fail)
 			hw_addr = addr;
 	}
 
+#if defined(CONFIG_RTL8822B) && defined(CONFIG_USB_HCI)
+	if (_rtw_memcmp(hw_addr, ft_mac_addr, ETH_ALEN))
+		hw_addr[0] = 0xff;
+#endif
+
 	/* check hw pg data */
 	if (hw_addr && rtw_check_invalid_mac_address(hw_addr, _TRUE) == _FALSE) {
 		_rtw_memcpy(hal_data->EEPROMMACAddr, hw_addr, ETH_ALEN);
@@ -10932,7 +12921,7 @@ void rtw_bb_rf_gain_offset(_adapter *padapter)
 	}
 
 #if defined(CONFIG_RTL8723B)
-	if (value & BIT4 || (registry_par->RegPwrTrimEnable == 1)) {
+	if (value & BIT4 && (registry_par->RegPwrTrimEnable == 1)) {
 		RTW_INFO("Offset RF Gain.\n");
 		RTW_INFO("Offset RF Gain.  pHalData->EEPROMRFGainVal=0x%x\n", pHalData->EEPROMRFGainVal);
 
@@ -10971,7 +12960,7 @@ void rtw_bb_rf_gain_offset(_adapter *padapter)
 		RTW_INFO("Using the default RF gain.\n");
 
 #elif defined(CONFIG_RTL8188E)
-	if (value & BIT4 || (registry_par->RegPwrTrimEnable == 1)) {
+	if (value & BIT4 && (registry_par->RegPwrTrimEnable == 1)) {
 		RTW_INFO("8188ES Offset RF Gain.\n");
 		RTW_INFO("8188ES Offset RF Gain. EEPROMRFGainVal=0x%x\n",
 			 pHalData->EEPROMRFGainVal);
@@ -11560,8 +13549,10 @@ void rtw_reset_mac_rx_counters(_adapter *padapter)
 
 	/* If no packet rx, MaxRx clock be gating ,BIT_DISGCLK bit19 set 1 for fix*/
 	if (IS_HARDWARE_TYPE_8703B(padapter) ||
-	    IS_HARDWARE_TYPE_8723D(padapter) ||
-	    IS_HARDWARE_TYPE_8188F(padapter))
+		IS_HARDWARE_TYPE_8723D(padapter) ||
+		IS_HARDWARE_TYPE_8188F(padapter) ||
+		IS_HARDWARE_TYPE_8188GTV(padapter) ||
+		IS_HARDWARE_TYPE_8192F(padapter))
 		phy_set_mac_reg(padapter, REG_RCR, BIT19, 0x1);
 
 	/* reset mac counter */
@@ -11717,27 +13708,50 @@ void rtw_dump_rx_counters(_adapter *padapter)
 #endif
 u8 rtw_get_current_tx_sgi(_adapter *padapter, struct sta_info *psta)
 {
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 	u8 curr_tx_sgi = 0;
 	struct ra_sta_info *ra_info;
 
 	if (!psta)
 		return curr_tx_sgi;
 
-	ra_info = &psta->cmn.ra_info;
-	curr_tx_sgi = ((ra_info->curr_tx_rate) & 0x80) >> 7;
+	if (padapter->fix_rate == 0xff) {
+#if defined(CONFIG_RTL8188E)
+#if (RATE_ADAPTIVE_SUPPORT == 1)
+		curr_tx_sgi = hal_data->odmpriv.ra_info[psta->cmn.mac_id].rate_sgi;
+#endif /* (RATE_ADAPTIVE_SUPPORT == 1)*/
+#else
+		ra_info = &psta->cmn.ra_info;
+		curr_tx_sgi = ((ra_info->curr_tx_rate) & 0x80) >> 7;
+#endif
+	} else {
+		curr_tx_sgi = ((padapter->fix_rate) & 0x80) >> 7;
+	}
 
 	return curr_tx_sgi;
 }
+
 u8 rtw_get_current_tx_rate(_adapter *padapter, struct sta_info *psta)
 {
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 	u8 rate_id = 0;
 	struct ra_sta_info *ra_info;
 
 	if (!psta)
 		return rate_id;
 
-	ra_info = &psta->cmn.ra_info;
-	rate_id = ra_info->curr_tx_rate & 0x7f;
+	if (padapter->fix_rate == 0xff) {
+#if defined(CONFIG_RTL8188E)
+#if (RATE_ADAPTIVE_SUPPORT == 1)
+		rate_id = hal_data->odmpriv.ra_info[psta->cmn.mac_id].decision_rate;
+#endif /* (RATE_ADAPTIVE_SUPPORT == 1)*/
+#else
+		ra_info = &psta->cmn.ra_info;
+		rate_id = ra_info->curr_tx_rate & 0x7f;
+#endif
+	} else {
+		rate_id = padapter->fix_rate & 0x7f;
+	}
 
 	return rate_id;
 }
@@ -11768,6 +13782,49 @@ void update_IOT_info(_adapter *padapter)
 	}
 
 }
+#ifdef CONFIG_RTS_FULL_BW 
+/*
+8188E: not support full RTS BW feature(mac REG no define 480[5])
+*/
+void rtw_set_rts_bw(_adapter *padapter) {
+	int i;
+	u8 enable = 1;
+	bool connect_to_8812 = _FALSE;
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+	struct sta_info *station = NULL;
+
+	for (i = 0; i < macid_ctl->num; i++) {
+		if (rtw_macid_is_used(macid_ctl, i)) {
+
+			station = NULL;
+			station = macid_ctl->sta[i];
+			if(station) {
+				
+				 _adapter *sta_adapter =station->padapter;
+				struct mlme_ext_priv	*pmlmeext = &(sta_adapter->mlmeextpriv);
+				struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+				
+				if ( pmlmeinfo->state != WIFI_FW_NULL_STATE) {
+					if(_rtw_memcmp(macid_ctl->sta[i]->cmn.mac_addr, bc_addr, ETH_ALEN) !=  _TRUE) {
+						if (  macid_ctl->sta[i]->vendor_8812) {
+							connect_to_8812 = _TRUE;
+							enable = 0;
+						}	
+					}	
+				}
+			}
+		}
+
+		if(connect_to_8812)
+			break;
+	}
+	
+		RTW_INFO("%s connect_to_8812=%d,enable=%u\n", __FUNCTION__,connect_to_8812,enable);
+		rtw_hal_set_hwreg(padapter, HW_VAR_SET_RTS_BW, &enable);
+}
+#endif/*CONFIG_RTS_FULL_BW*/
 
 /* TODO: merge with phydm, see odm_SetCrystalCap() */
 void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap)
@@ -11775,9 +13832,10 @@ void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap)
 	crystal_cap = crystal_cap & 0x3F;
 
 	switch (rtw_get_chip_type(adapter)) {
-#if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F)
+#if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
 	case RTL8188E:
 	case RTL8188F:
+	case RTL8188GTV:
 		/* write 0x24[16:11] = 0x24[22:17] = CrystalCap */
 		phy_set_bb_reg(adapter, REG_AFE_XTAL_CTRL, 0x007FF800, (crystal_cap | (crystal_cap << 6)));
 		break;
@@ -11790,7 +13848,7 @@ void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap)
 #endif
 #if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || \
 		defined(CONFIG_RTL8723D) || defined(CONFIG_RTL8821A) || \
-		defined(CONFIG_RTL8192E)
+		defined(CONFIG_RTL8192E) 
 	case RTL8723B:
 	case RTL8703B:
 	case RTL8723D:
@@ -11806,15 +13864,24 @@ void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap)
 		phy_set_bb_reg(adapter, REG_MAC_PHY_CTRL, 0x07FF8000, (crystal_cap | (crystal_cap << 6)));
 		break;
 #endif
-#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8192F)
 
 	case RTL8822B:
 	case RTL8821C:
+	case RTL8192F:	
 		/* write 0x28[6:1] = 0x24[30:25] = CrystalCap */
 		crystal_cap = crystal_cap & 0x3F;
 		phy_set_bb_reg(adapter, REG_AFE_XTAL_CTRL, 0x7E000000, crystal_cap);
 		phy_set_bb_reg(adapter, REG_AFE_PLL_CTRL, 0x7E, crystal_cap);
 		break;
+#endif
+#if defined(CONFIG_RTL8710B)
+	case RTL8710B:
+		/*Change by ylb 20160728, Becase 0x2C[23:12] is removed to syson 0x60[29:18] */
+		/* 0x2C[23:18] = 0x2C[29:24] = CrystalCap //Xo:[29:24], Xi:[23:18]*/
+		crystal_cap = crystal_cap & 0x3F;
+		hal_set_syson_reg(adapter, REG_SYS_XTAL_CTRL0, 0x3FFC0000, (crystal_cap | (crystal_cap << 6)));
+		break;
 #endif
 	default:
 		rtw_warn_on(1);
@@ -11854,6 +13921,11 @@ int hal_spec_init(_adapter *adapter)
 		init_hal_spec_8188f(adapter);
 		break;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		init_hal_spec_8188gtv(adapter);
+		break;
+#endif
 #ifdef CONFIG_RTL8812A
 	case RTL8812:
 		init_hal_spec_8812a(adapter);
@@ -11884,6 +13956,17 @@ int hal_spec_init(_adapter *adapter)
 		init_hal_spec_rtl8821c(adapter);
 		break;
 #endif
+#ifdef CONFIG_RTL8710B
+	case RTL8710B:
+		init_hal_spec_8710b(adapter);
+		break;
+#endif
+#ifdef CONFIG_RTL8192F
+	case RTL8192F:
+		init_hal_spec_8192f(adapter);
+		break;
+#endif
+
 	default:
 		RTW_ERR("%s: unknown chip_type:%u\n"
 			, __func__, rtw_get_chip_type(adapter));
@@ -11933,6 +14016,8 @@ void dump_hal_spec(void *sel, _adapter *adapter)
 	RTW_PRINT_SEL(sel, "sec_cam_ent_num:%u\n", hal_spec->sec_cam_ent_num);
 	RTW_PRINT_SEL(sel, "rfpath_num_2g:%u\n", hal_spec->rfpath_num_2g);
 	RTW_PRINT_SEL(sel, "rfpath_num_5g:%u\n", hal_spec->rfpath_num_5g);
+	RTW_PRINT_SEL(sel, "txgi_max:%u\n", hal_spec->txgi_max);
+	RTW_PRINT_SEL(sel, "txgi_pdbm:%u\n", hal_spec->txgi_pdbm);
 	RTW_PRINT_SEL(sel, "max_tx_cnt:%u\n", hal_spec->max_tx_cnt);
 	RTW_PRINT_SEL(sel, "tx_nss_num:%u\n", hal_spec->tx_nss_num);
 	RTW_PRINT_SEL(sel, "rx_nss_num:%u\n", hal_spec->rx_nss_num);
@@ -11964,6 +14049,11 @@ void dump_hal_spec(void *sel, _adapter *adapter)
 			_RTW_PRINT_SEL(sel, "%s ", _wl_func_str[i]);
 	}
 	_RTW_PRINT_SEL(sel, "\n");
+
+	RTW_PRINT_SEL(sel, "rx_tsf_filter:%u\n", hal_spec->rx_tsf_filter);
+
+	RTW_PRINT_SEL(sel, "pg_txpwr_saddr:0x%X\n", hal_spec->pg_txpwr_saddr);
+	RTW_PRINT_SEL(sel, "pg_txgi_diff_factor:%u\n", hal_spec->pg_txgi_diff_factor);
 }
 
 inline bool hal_chk_band_cap(_adapter *adapter, u8 cap)
@@ -12026,6 +14116,13 @@ inline bool hal_is_wireless_mode_support(_adapter *adapter, u8 mode)
 
 	return 0;
 }
+inline bool hal_is_mimo_support(_adapter *adapter)
+{
+	if ((GET_HAL_SPEC(adapter)->tx_nss_num == 1) &&
+		(GET_HAL_SPEC(adapter)->rx_nss_num == 1))
+		return 0;
+	return 1;
+}
 
 /*
 * hal_largest_bw - starting from in_bw, get largest bw supported by HAL
@@ -12047,34 +14144,8 @@ u8 hal_largest_bw(_adapter *adapter, u8 in_bw)
 	return in_bw;
 }
 
-void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf)
-{
-	if (hw_port == HW_PORT0) {
-		/*disable related TSF function*/
-		rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) & (~EN_BCN_FUNCTION));
-
-		rtw_write32(padapter, REG_TSFTR, tsf);
-		rtw_write32(padapter, REG_TSFTR + 4, tsf >> 32);
-
-		/*enable related TSF function*/
-		rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) | EN_BCN_FUNCTION);
-	} else if (hw_port == HW_PORT1) {
-		/*disable related TSF function*/
-		rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) & (~EN_BCN_FUNCTION));
-
-		rtw_write32(padapter, REG_TSFTR1, tsf);
-		rtw_write32(padapter, REG_TSFTR1 + 4, tsf >> 32);
-
-		/*enable related TSF function*/
-		rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) | EN_BCN_FUNCTION);
-	} else
-		RTW_INFO("%s-[WARN] "ADPT_FMT" invalid hw_port:%d\n", __func__, ADPT_ARG(padapter), hw_port);
-}
-
 void ResumeTxBeacon(_adapter *padapter)
 {
-#ifdef CONFIG_MI_WITH_MBSSID_CAM
-#else
 	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
 		rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2) | BIT(6));
 
@@ -12088,13 +14159,10 @@ void ResumeTxBeacon(_adapter *padapter)
 	rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME & 0xFF);
 	rtw_write8(padapter, REG_TBTT_PROHIBIT + 2,
 		(rtw_read8(padapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME >> 8));
-#endif
 }
 
 void StopTxBeacon(_adapter *padapter)
 {
-#ifdef CONFIG_MI_WITH_MBSSID_CAM
-#else
 	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
 		rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2) & (~BIT6));
 
@@ -12102,63 +14170,142 @@ void StopTxBeacon(_adapter *padapter)
 	rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME_STOP_BCN & 0xFF);
 	rtw_write8(padapter, REG_TBTT_PROHIBIT + 2,
 		(rtw_read8(padapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME_STOP_BCN >> 8));
-#endif
 }
 
 #ifdef CONFIG_MI_WITH_MBSSID_CAM /*HW port0 - MBSS*/
-void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode)
+
+#ifdef CONFIG_CLIENT_PORT_CFG
+const u8 _clt_port_id[MAX_CLIENT_PORT_NUM] = {
+	CLT_PORT0,
+	CLT_PORT1,
+	CLT_PORT2,
+	CLT_PORT3
+};
+
+void rtw_clt_port_init(struct clt_port_t  *cltp)
 {
-	RTW_INFO("%s()-"ADPT_FMT" mode = %d\n", __func__, ADPT_ARG(Adapter), mode);
+	cltp->bmp = 0;
+	cltp->num = 0;
+	_rtw_spinlock_init(&cltp->lock);
+}
+void rtw_clt_port_deinit(struct clt_port_t *cltp)
+{
+	_rtw_spinlock_free(&cltp->lock);
+}
+static void _hw_client_port_alloc(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct clt_port_t  *cltp = &dvobj->clt_port;
+	_irqL irql;
+	int i;
 
-	rtw_hal_rcr_set_chk_bssid(Adapter, MLME_ACTION_NONE);
+	#if 0
+	if (cltp->num > MAX_CLIENT_PORT_NUM) {
+		RTW_ERR(ADPT_FMT" cann't  alloc client (%d)\n", ADPT_ARG(adapter), cltp->num);
+		rtw_warn_on(1);
+		return;
+	}
+	#endif
 
-	/* disable Port0 TSF update*/
-	rtw_write8(Adapter, REG_BCN_CTRL, rtw_read8(Adapter, REG_BCN_CTRL) | DIS_TSF_UDT);
+	if (adapter->client_id !=  MAX_CLIENT_PORT_NUM) {
+		RTW_INFO(ADPT_FMT" client_id %d has allocated port:%d\n",
+			ADPT_ARG(adapter), adapter->client_id, adapter->client_port);
+		return;
+	}
+	_enter_critical_bh(&cltp->lock, &irql);
+	for (i = 0; i < MAX_CLIENT_PORT_NUM; i++) {
+		if (!(cltp->bmp & BIT(i)))
+			break;
+	}
 
-	/* set net_type */
-	Set_MSR(Adapter, mode);
+	if (i < MAX_CLIENT_PORT_NUM) {
+		adapter->client_id = i;
+		cltp->bmp |= BIT(i);
+		adapter->client_port = _clt_port_id[i];
+	}
+	cltp->num++;
+	_exit_critical_bh(&cltp->lock, &irql);
+	RTW_INFO("%s("ADPT_FMT")id:%d, port:%d clt_num:%d\n",
+		__func__, ADPT_ARG(adapter), adapter->client_id, adapter->client_port, cltp->num);
+}
+static void _hw_client_port_free(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct clt_port_t  *cltp = &dvobj->clt_port;
+	_irqL irql;
 
-	if ((mode == _HW_STATE_STATION_) || (mode == _HW_STATE_NOLINK_)) {
-		if (!rtw_mi_get_ap_num(Adapter) && !rtw_mi_get_mesh_num(Adapter))
-			StopTxBeacon(Adapter);
+	#if 0
+	if (adapter->client_id >=  MAX_CLIENT_PORT_NUM) {
+		RTW_ERR(ADPT_FMT" client_id %d is invalid\n", ADPT_ARG(adapter), adapter->client_id);
+		/*rtw_warn_on(1);*/
+	}
+	#endif
 
-		rtw_write8(Adapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_ATIM);/*disable atim wnd*/
-	} else if (mode == _HW_STATE_ADHOC_) {
-		ResumeTxBeacon(Adapter);
-		rtw_write8(Adapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_BCNQ_SUB);
+	RTW_INFO("%s ("ADPT_FMT") id:%d, port:%d clt_num:%d\n",
+		__func__, ADPT_ARG(adapter), adapter->client_id, adapter->client_port, cltp->num);
 
-	} else if (mode == _HW_STATE_AP_) {
-		ResumeTxBeacon(Adapter);
+	_enter_critical_bh(&cltp->lock, &irql);
+	if (adapter->client_id !=  MAX_CLIENT_PORT_NUM) {
+		cltp->bmp &= ~ BIT(adapter->client_id);
+		adapter->client_id = MAX_CLIENT_PORT_NUM;
+		adapter->client_port = CLT_PORT_INVALID;
+	}
+	cltp->num--;
+	if (cltp->num < 0)
+		cltp->num = 0;
+	_exit_critical_bh(&cltp->lock, &irql);
+}
+void rtw_hw_client_port_allocate(_adapter *adapter)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 
-		rtw_write8(Adapter, REG_BCN_CTRL, DIS_TSF_UDT | DIS_BCNQ_SUB);
+	if (hal_spec->port_num != 5)
+		return;
 
-		/*enable to rx data frame*/
-		rtw_write16(Adapter, REG_RXFLTMAP2, 0xFFFF);
+	_hw_client_port_alloc(adapter);
+}
+void rtw_hw_client_port_release(_adapter *adapter)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 
-		/*Beacon Control related register for first time*/
-		rtw_write8(Adapter, REG_BCNDMATIM, 0x02); /* 2ms */
+	if (hal_spec->port_num != 5)
+		return;
 
-		/*rtw_write8(Adapter, REG_BCN_MAX_ERR, 0xFF);*/
-		rtw_write8(Adapter, REG_ATIMWND, 0x0c); /* 12ms */
-		rtw_write16(Adapter, REG_BCNTCFG, 0x00);
+	_hw_client_port_free(adapter);
+}
+#endif /*CONFIG_CLIENT_PORT_CFG*/
 
-		rtw_write16(Adapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
+void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode)
+{
+	RTW_INFO("%s()-"ADPT_FMT" mode = %d\n", __func__, ADPT_ARG(Adapter), mode);
 
-		/*reset TSF*/
-		rtw_write8(Adapter, REG_DUAL_TSF_RST, BIT(0));
+	rtw_hal_rcr_set_chk_bssid(Adapter, MLME_ACTION_NONE);
 
-		/*enable BCN0 Function for if1*/
-		/*don't enable update TSF0 for if1 (due to TSF update when beacon,probe rsp are received)*/
-		rtw_write8(Adapter, REG_BCN_CTRL, (DIS_TSF_UDT | EN_BCN_FUNCTION | EN_TXBCN_RPT | DIS_BCNQ_SUB));
-		#ifdef CONFIG_BCN_XMIT_PROTECT
-		rtw_write8(Adapter, REG_CCK_CHECK, rtw_read8(Adapter, REG_CCK_CHECK) | BIT_EN_BCN_PKT_REL);
-		#endif
+	/* set net_type */
+	Set_MSR(Adapter, mode);
 
-		if (IS_HARDWARE_TYPE_8821(Adapter) || IS_HARDWARE_TYPE_8192E(Adapter))/* select BCN on port 0 for DualBeacon*/
-			rtw_write8(Adapter, REG_CCK_CHECK, rtw_read8(Adapter, REG_CCK_CHECK) & (~BIT_BCN_PORT_SEL));
+	if ((mode == _HW_STATE_STATION_) || (mode == _HW_STATE_NOLINK_)) {
+		if (!rtw_mi_get_ap_num(Adapter) && !rtw_mi_get_mesh_num(Adapter))
+			StopTxBeacon(Adapter);
+	} else if (mode == _HW_STATE_ADHOC_)
+		ResumeTxBeacon(Adapter);
+	else if (mode == _HW_STATE_AP_)
+		/* enable rx ps-poll */
+		rtw_write16(Adapter, REG_RXFLTMAP1, rtw_read16(Adapter, REG_RXFLTMAP1) | BIT_CTRLFLT10EN);
 
-	}
+	/* enable rx data frame */
+	rtw_write16(Adapter, REG_RXFLTMAP2, 0xFFFF);
 
+#ifdef CONFIG_CLIENT_PORT_CFG
+	if (mode == _HW_STATE_STATION_)
+		rtw_hw_client_port_allocate(Adapter);
+	else
+		rtw_hw_client_port_release(Adapter);
+#endif
+#if defined(CONFIG_RTL8192F)
+		rtw_write16(Adapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(Adapter, 
+					REG_WLAN_ACT_MASK_CTRL_1) | EN_PORT_0_FUNCTION);	
+#endif
 }
 #endif
 
@@ -12347,3 +14494,153 @@ u8 rtw_ap_bcn_queue_empty_check(_adapter *padapter, u32 txbcn_timer_ms)
 }
 #endif /*CONFIG_BCN_XMIT_PROTECT*/
 #endif /*CONFIG_SWTIMER_BASED_TXBCN*/
+
+static void _rf_type_to_ant_path(enum rf_type rf, enum bb_path *tx,
+				 enum bb_path *rx)
+{
+	if (tx) {
+		switch (rf) {
+		case RF_1T1R:
+		case RF_1T2R:
+			*tx = BB_PATH_A;
+			break;
+		case RF_2T2R:
+		case RF_2T3R:
+		case RF_2T4R:
+			*tx = BB_PATH_AB;
+			break;
+		case RF_3T3R:
+		case RF_3T4R:
+			*tx = BB_PATH_ABC;
+			break;
+		case RF_4T4R:
+		default:
+			*tx = BB_PATH_ABCD;
+			break;
+		}
+	}
+
+	if (rx) {
+		switch (rf) {
+		case RF_1T1R:
+			*rx = BB_PATH_A;
+			break;
+		case RF_1T2R:
+		case RF_2T2R:
+			*rx = BB_PATH_AB;
+			break;
+		case RF_2T3R:
+		case RF_3T3R:
+			*rx = BB_PATH_ABC;
+			break;
+		case RF_2T4R:
+		case RF_3T4R:
+		case RF_4T4R:
+		default:
+			*rx = BB_PATH_ABCD;
+			break;
+		}
+	}
+}
+
+/**
+ * rtw_hal_get_rf_path() - Get RF path related information
+ * @d:		struct dvobj_priv*
+ * @type:	RF type, nTnR
+ * @tx:		Tx path
+ * @rx:		Rx path
+ *
+ * Get RF type, TX path and RX path information.
+ */
+void rtw_hal_get_rf_path(struct dvobj_priv *d, enum rf_type *type,
+			 enum bb_path *tx, enum bb_path *rx)
+{
+	struct _ADAPTER *a;
+	u8 val8 = RF_1T1R;
+	enum rf_type rf;
+
+
+	a = dvobj_get_primary_adapter(d);
+#ifndef CONFIG_CUSTOMER01_SMART_ANTENNA
+	rtw_hal_get_hwreg(a, HW_VAR_RF_TYPE, &val8);
+#else
+	val8 = RF_2T2R;
+#endif
+	rf = (enum rf_type)val8;
+	if (type)
+		*type = rf;
+
+	if (tx || rx)
+		_rf_type_to_ant_path(rf, tx, rx);
+}
+
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+void rtw_hal_switch_chnl_and_set_bw_offload(_adapter *adapter, u8 central_ch, u8 pri_ch_idx, u8 bw)
+{
+	u8 h2c[H2C_SINGLE_CHANNELSWITCH_V2_LEN] = {0};
+	PHAL_DATA_TYPE hal;
+	struct submit_ctx *chsw_sctx;
+
+	hal = GET_HAL_DATA(adapter);
+	chsw_sctx = &hal->chsw_sctx;
+
+	SET_H2CCMD_SINGLE_CH_SWITCH_V2_CENTRAL_CH_NUM(h2c, central_ch);
+	SET_H2CCMD_SINGLE_CH_SWITCH_V2_PRIMARY_CH_IDX(h2c, pri_ch_idx);
+	SET_H2CCMD_SINGLE_CH_SWITCH_V2_BW(h2c, bw);
+
+	rtw_sctx_init(chsw_sctx, 10);
+	rtw_hal_fill_h2c_cmd(adapter, H2C_SINGLE_CHANNELSWITCH_V2, H2C_SINGLE_CHANNELSWITCH_V2_LEN, h2c);
+	rtw_sctx_wait(chsw_sctx, __func__);
+}
+#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8812A) ||\
+	defined(CONFIG_RTL8192F) || defined(CONFIG_RTL8192E) ||\
+	defined(CONFIG_RTL8822B) ||defined(CONFIG_RTL8821A)
+u8 phy_get_current_tx_num(
+	IN	PADAPTER		pAdapter,
+	IN	u8				Rate
+)
+{
+	u8	tx_num = RF_1TX;
+
+	if (IS_1T_RATE(Rate)) {
+	#if defined(CONFIG_RTW_TX_2PATH_EN)
+		tx_num = RF_2TX;
+	else
+		tx_num = RF_1TX;
+	#endif
+	}
+	else if (IS_2T_RATE(Rate))
+		tx_num = RF_2TX;
+	else if (IS_3T_RATE(Rate))
+		tx_num = RF_3TX;
+	else
+		rtw_warn_on(1);
+
+	return tx_num;
+}
+#endif
+#ifdef CONFIG_RTL8812A
+u8 * rtw_hal_set_8812a_vendor_ie(_adapter *padapter , u8 *pframe ,uint *frlen ) {
+	int vender_len = 7;
+	unsigned char	vendor_info[vender_len];
+	unsigned char REALTEK_OUI[] = {0x00, 0xe0, 0x4c};
+	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
+
+	if( !IS_HARDWARE_TYPE_8812(padapter) )
+		return pframe;
+
+	_rtw_memset(vendor_info,0,vender_len);
+	_rtw_memcpy(vendor_info, REALTEK_OUI, 3);
+	vendor_info[4] =2;
+	if(pHalData->version_id.CUTVersion > B_CUT_VERSION )
+		vendor_info[6] = RT_HT_CAP_USE_JAGUAR_CCUT;
+	else
+		vendor_info[6] = RT_HT_CAP_USE_JAGUAR_BCUT;
+	pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_,vender_len,vendor_info , frlen);
+	
+	return pframe;
+}
+#endif /*CONFIG_RTL8812A*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_c2h.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_c2h.h
index 4991fcced7ae..a12317778da2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_c2h.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_c2h.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -71,6 +72,9 @@ typedef enum _C2H_EVT {
 	C2H_CUSTOMER_STR_RPT = 0x24,
 	C2H_CUSTOMER_STR_RPT_2 = 0x25,
 	C2H_WLAN_INFO = 0x27,
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	C2H_PER_RATE_RPT = 0x2c,
+#endif
 	C2H_DEFEATURE_RSVD = 0xFD,
 	C2H_EXTEND = 0xff,
 } C2H_EVT;
@@ -112,4 +116,9 @@ int c2h_customer_str_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
 int c2h_customer_str_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len);
 #endif /* CONFIG_RTW_CUSTOMER_STR */
 
+#ifdef RTW_PER_CMD_SUPPORT_FW
+/* C2H_PER_RATE_RPT, 0x2c */
+int c2h_per_rate_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
+#endif
+
 #endif /* __COMMON_C2H_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_phycfg.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_phycfg.c
index dafac278539c..bef9184c42fe 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_phycfg.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_com_phycfg.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -17,19 +18,21 @@
 #include <drv_types.h>
 #include <hal_data.h>
 
+#define PG_TXPWR_1PATH_BYTE_NUM_2G 18
+#define PG_TXPWR_BASE_BYTE_NUM_2G 11
+
+#define PG_TXPWR_1PATH_BYTE_NUM_5G 24
+#define PG_TXPWR_BASE_BYTE_NUM_5G 14
+
 #define PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) (((_pg_v) & 0xf0) >> 4)
 #define PG_TXPWR_LSB_DIFF_S4BIT(_pg_v) ((_pg_v) & 0x0f)
 #define PG_TXPWR_MSB_DIFF_TO_S8BIT(_pg_v) ((PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) & BIT3) ? (PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) | 0xF0) : PG_TXPWR_MSB_DIFF_S4BIT(_pg_v))
 #define PG_TXPWR_LSB_DIFF_TO_S8BIT(_pg_v) ((PG_TXPWR_LSB_DIFF_S4BIT(_pg_v) & BIT3) ? (PG_TXPWR_LSB_DIFF_S4BIT(_pg_v) | 0xF0) : PG_TXPWR_LSB_DIFF_S4BIT(_pg_v))
-#define IS_PG_TXPWR_BASE_INVALID(_base) ((_base) > 63)
+#define IS_PG_TXPWR_BASE_INVALID(hal_spec, _base) ((_base) > hal_spec->txgi_max)
 #define IS_PG_TXPWR_DIFF_INVALID(_diff) ((_diff) > 7 || (_diff) < -8)
 #define PG_TXPWR_INVALID_BASE 255
 #define PG_TXPWR_INVALID_DIFF 8
 
-#if !IS_PG_TXPWR_BASE_INVALID(PG_TXPWR_INVALID_BASE)
-#error "PG_TXPWR_BASE definition has problem"
-#endif
-
 #if !IS_PG_TXPWR_DIFF_INVALID(PG_TXPWR_INVALID_DIFF)
 #error "PG_TXPWR_DIFF definition has problem"
 #endif
@@ -254,6 +257,14 @@ static const struct map_t rtl8188f_pg_txpwr_def_info =
 	);
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+static const struct map_t rtl8188gtv_pg_txpwr_def_info =
+	MAP_ENT(0xB8, 1, 0xFF
+		, MAPSEG_ARRAY_ENT(0x10, 12,
+			0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x27, 0x27, 0x27, 0x27, 0x27, 0x24)
+	);
+#endif
+
 #ifdef CONFIG_RTL8723B
 static const struct map_t rtl8723b_pg_txpwr_def_info =
 	MAP_ENT(0xB8, 2, 0xFF
@@ -306,13 +317,21 @@ static const struct map_t rtl8821a_pg_txpwr_def_info =
 static const struct map_t rtl8821c_pg_txpwr_def_info =
 	MAP_ENT(0xB8, 1, 0xFF
 		, MAPSEG_ARRAY_ENT(0x10, 54,
-			0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xFF, 0xFF, 0xFF, 0xFF, 
-			0xFF, 0xFF, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 
+			0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xFF, 0xFF, 0xFF, 0xFF,
+			0xFF, 0xFF, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28,
 			0x02, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xEC, 0xFF, 0xFF, 0xFF, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D,
 			0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02)
 	);
 #endif
 
+#ifdef CONFIG_RTL8710B
+static const struct map_t rtl8710b_pg_txpwr_def_info =
+	MAP_ENT(0xC8, 1, 0xFF
+		, MAPSEG_ARRAY_ENT(0x20, 12,
+			0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x20)
+	);
+#endif
+
 #ifdef CONFIG_RTL8812A
 static const struct map_t rtl8812a_pg_txpwr_def_info =
 	MAP_ENT(0xB8, 1, 0xFF
@@ -357,6 +376,16 @@ static const struct map_t rtl8814a_pg_txpwr_def_info =
 	);
 #endif
 
+#ifdef CONFIG_RTL8192F/*use 8192F default,no document*/
+static const struct map_t rtl8192f_pg_txpwr_def_info =
+	MAP_ENT(0xB8, 2, 0xFF
+		, MAPSEG_ARRAY_ENT(0x10, 14,
+			0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE)
+		, MAPSEG_ARRAY_ENT(0x3A, 14,
+			0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE)
+	);
+#endif
+
 const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter)
 {
 	u8 interface_type = 0;
@@ -390,6 +419,11 @@ const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter)
 		map = &rtl8188f_pg_txpwr_def_info;
 		break;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	case RTL8188GTV:
+		map = &rtl8188gtv_pg_txpwr_def_info;
+		break;
+#endif
 #ifdef CONFIG_RTL8812A
 	case RTL8812:
 		map = &rtl8812a_pg_txpwr_def_info;
@@ -419,6 +453,16 @@ const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter)
 	case RTL8821C:
 		map = &rtl8821c_pg_txpwr_def_info;
 		break;
+#endif
+#ifdef CONFIG_RTL8710B
+	case RTL8710B:
+		map = &rtl8710b_pg_txpwr_def_info;
+		break;
+#endif
+#ifdef CONFIG_RTL8192F
+	case RTL8192F:
+		map = &rtl8192f_pg_txpwr_def_info;
+		break;
 #endif
 	}
 
@@ -443,8 +487,8 @@ static u8 hal_chk_pg_txpwr_info_2g(_adapter *adapter, TxPowerInfo24G *pwr_info)
 		if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path))
 			continue;
 		for (group = 0; group < MAX_CHNL_GROUP_24G; group++) {
-			if (IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexCCK_Base[path][group])
-				|| IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexBW40_Base[path][group]))
+			if (IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexCCK_Base[path][group])
+				|| IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group]))
 				return _FAIL;
 		}
 		for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
@@ -474,7 +518,7 @@ static u8 hal_chk_pg_txpwr_info_5g(_adapter *adapter, TxPowerInfo5G *pwr_info)
 		if (!HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
 			continue;
 		for (group = 0; group < MAX_CHNL_GROUP_5G; group++)
-			if (IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexBW40_Base[path][group]))
+			if (IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group]))
 				return _FAIL;
 		for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
 			if (!HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx))
@@ -575,8 +619,6 @@ u16 hal_load_pg_txpwr_info_path_2g(
 	const struct map_t *txpwr_map,
 	u16 pg_offset)
 {
-#define PG_TXPWR_1PATH_BYTE_NUM_2G 18
-
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	u16 offset = pg_offset;
 	u8 group, tx_idx;
@@ -595,8 +637,8 @@ u16 hal_load_pg_txpwr_info_path_2g(
 	for (group = 0; group < MAX_CHNL_GROUP_24G; group++) {
 		if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
 			tmp_base = map_read8(txpwr_map, offset);
-			if (!IS_PG_TXPWR_BASE_INVALID(tmp_base)
-				&& IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexCCK_Base[path][group])
+			if (!IS_PG_TXPWR_BASE_INVALID(hal_spec, tmp_base)
+				&& IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexCCK_Base[path][group])
 			) {
 				pwr_info->IndexCCK_Base[path][group] = tmp_base;
 				if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
@@ -609,8 +651,8 @@ u16 hal_load_pg_txpwr_info_path_2g(
 	for (group = 0; group < MAX_CHNL_GROUP_24G - 1; group++) {
 		if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
 			tmp_base = map_read8(txpwr_map, offset);
-			if (!IS_PG_TXPWR_BASE_INVALID(tmp_base)
-				&& IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexBW40_Base[path][group])
+			if (!IS_PG_TXPWR_BASE_INVALID(hal_spec, tmp_base)
+				&& IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group])
 			) {
 				pwr_info->IndexBW40_Base[path][group] =	tmp_base;
 				if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
@@ -693,7 +735,7 @@ u16 hal_load_pg_txpwr_info_path_2g(
 		rtw_warn_on(1);
 	}
 
-exit:	
+exit:
 	return offset;
 }
 
@@ -705,8 +747,6 @@ u16 hal_load_pg_txpwr_info_path_5g(
 	const struct map_t *txpwr_map,
 	u16 pg_offset)
 {
-#define PG_TXPWR_1PATH_BYTE_NUM_5G 24
-
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	u16 offset = pg_offset;
 	u8 group, tx_idx;
@@ -721,7 +761,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 		offset += PG_TXPWR_1PATH_BYTE_NUM_5G;
 		goto exit;
 	}
-	
+
 #ifdef CONFIG_IEEE80211_BAND_5GHZ
 	if (DBG_PG_TXPWR_READ)
 		RTW_INFO("%s[%c] eaddr:0x%03x\n", __func__, rf_path_char(path), offset);
@@ -729,8 +769,8 @@ u16 hal_load_pg_txpwr_info_path_5g(
 	for (group = 0; group < MAX_CHNL_GROUP_5G; group++) {
 		if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path)) {
 			tmp_base = map_read8(txpwr_map, offset);
-			if (!IS_PG_TXPWR_BASE_INVALID(tmp_base)
-				&& IS_PG_TXPWR_BASE_INVALID(pwr_info->IndexBW40_Base[path][group])
+			if (!IS_PG_TXPWR_BASE_INVALID(hal_spec, tmp_base)
+				&& IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group])
 			) {
 				pwr_info->IndexBW40_Base[path][group] = tmp_base;
 				if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
@@ -784,7 +824,7 @@ u16 hal_load_pg_txpwr_info_path_5g(
 			}
 			offset++;
 		}
-	}	
+	}
 
 	/* OFDM diff 2T ~ 3T */
 	if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, 1)) {
@@ -878,7 +918,7 @@ void hal_load_pg_txpwr_info(
 	hal_init_pg_txpwr_info_5g(adapter, pwr_info_5g);
 
 select_src:
-	pg_offset = 0x10;
+	pg_offset = hal_spec->pg_txpwr_saddr;
 
 	switch (txpwr_src) {
 	case PG_TXPWR_SRC_PG_DATA:
@@ -927,6 +967,79 @@ exit:
 	return;
 }
 
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+
+#define EFUSE_POWER_INDEX_INVALID 0xFF
+
+static u8 _check_phy_efuse_tx_power_info_valid(u8 *pg_data, int base_len, u16 pg_offset)
+{
+	int ff_cnt = 0;
+	int i;
+
+	for (i = 0; i < base_len; i++) {
+		if (*(pg_data + pg_offset + i) == 0xFF)
+			ff_cnt++;
+	}
+
+	if (ff_cnt == 0)
+		return _TRUE;
+	else if (ff_cnt == base_len)
+		return _FALSE;
+	else
+		return EFUSE_POWER_INDEX_INVALID;
+}
+
+int check_phy_efuse_tx_power_info_valid(_adapter *adapter)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	u8 *pg_data = hal_data->efuse_eeprom_data;
+	u16 pg_offset = hal_spec->pg_txpwr_saddr;
+	u8 path;
+	u8 valid_2g_path_bmp = 0;
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	u8 valid_5g_path_bmp = 0;
+#endif
+	int result = _FALSE;
+
+	for (path = 0; path < MAX_RF_PATH; path++) {
+		u8 ret = _FALSE;
+
+		if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && !HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
+			break;
+
+		if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
+			ret = _check_phy_efuse_tx_power_info_valid(pg_data, PG_TXPWR_BASE_BYTE_NUM_2G, pg_offset);
+			if (ret == _TRUE)
+				valid_2g_path_bmp |= BIT(path);
+			else if (ret == EFUSE_POWER_INDEX_INVALID)
+				return _FALSE;
+		}
+		pg_offset += PG_TXPWR_1PATH_BYTE_NUM_2G;
+
+		#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path)) {
+			ret = _check_phy_efuse_tx_power_info_valid(pg_data, PG_TXPWR_BASE_BYTE_NUM_5G, pg_offset);
+			if (ret == _TRUE)
+				valid_5g_path_bmp |= BIT(path);
+			else if (ret == EFUSE_POWER_INDEX_INVALID)
+				return _FALSE;
+		}
+		#endif
+		pg_offset += PG_TXPWR_1PATH_BYTE_NUM_5G;
+	}
+
+	if ((hal_chk_band_cap(adapter, BAND_CAP_2G) && valid_2g_path_bmp)
+		#ifdef CONFIG_IEEE80211_BAND_5GHZ
+		|| (hal_chk_band_cap(adapter, BAND_CAP_5G) && valid_5g_path_bmp)
+		#endif
+	)
+		return _TRUE;
+
+	return _FALSE;
+}
+#endif /* CONFIG_EFUSE_CONFIG_FILE */
+
 void hal_load_txpwr_info(
 	_adapter *adapter,
 	TxPowerInfo24G *pwr_info_2g,
@@ -964,10 +1077,10 @@ void hal_load_txpwr_info(
 			if (tx_idx >= max_tx_cnt)
 				break;
 
-			hal_data->CCK_24G_Diff[rfpath][tx_idx] = pwr_info_2g->CCK_Diff[rfpath][tx_idx];
-			hal_data->OFDM_24G_Diff[rfpath][tx_idx] = pwr_info_2g->OFDM_Diff[rfpath][tx_idx];
-			hal_data->BW20_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW20_Diff[rfpath][tx_idx];
-			hal_data->BW40_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW40_Diff[rfpath][tx_idx];
+			hal_data->CCK_24G_Diff[rfpath][tx_idx] = pwr_info_2g->CCK_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
+			hal_data->OFDM_24G_Diff[rfpath][tx_idx] = pwr_info_2g->OFDM_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
+			hal_data->BW20_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW20_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
+			hal_data->BW40_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW40_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
 		}
 bypass_2g:
 		;
@@ -999,10 +1112,10 @@ bypass_2g:
 			if (tx_idx >= max_tx_cnt)
 				break;
 
-			hal_data->OFDM_5G_Diff[rfpath][tx_idx] = pwr_info_5g->OFDM_Diff[rfpath][tx_idx];
-			hal_data->BW20_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW20_Diff[rfpath][tx_idx];
-			hal_data->BW40_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW40_Diff[rfpath][tx_idx];
-			hal_data->BW80_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW80_Diff[rfpath][tx_idx];
+			hal_data->OFDM_5G_Diff[rfpath][tx_idx] = pwr_info_5g->OFDM_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
+			hal_data->BW20_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW20_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
+			hal_data->BW40_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW40_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
+			hal_data->BW80_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW80_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
 		}
 bypass_5g:
 		;
@@ -1290,7 +1403,7 @@ bool rtw_regsty_chk_target_tx_power_valid(_adapter *adapter)
 /*
 * PHY_GetTxPowerByRateBase -
 *
-* Return 2 times of dBm
+* Return value in unit of TX Gain Index
 */
 u8
 PHY_GetTxPowerByRateBase(
@@ -1489,7 +1602,7 @@ phy_StoreTxPowerByRateBase(
 					continue;
 
 				if (regsty->target_tx_pwr_valid == _TRUE)
-					base = 2 * rtw_regsty_get_target_tx_power(pAdapter, band, path, rs);
+					base = hal_spec->txgi_pdbm * rtw_regsty_get_target_tx_power(pAdapter, band, path, rs);
 				else
 					base = _PHY_GetTxPowerByRate(pAdapter, band, path, rate_sec_base[rs]);
 				phy_SetTxPowerByRateBase(pAdapter, band, path, rs, base);
@@ -1498,6 +1611,16 @@ phy_StoreTxPowerByRateBase(
 	}
 }
 
+static u8 get_val_from_dhex(u32 dhex, u8 i)
+{
+	return (((dhex >> (i * 8 + 4)) & 0xF)) * 10 + ((dhex >> (i * 8)) & 0xF);
+}
+
+static u8 get_val_from_hex(u32 hex, u8 i)
+{
+	return (hex >> (i * 8)) & 0xFF;
+}
+
 VOID
 PHY_GetRateValuesOfTxPowerByRate(
 	IN	PADAPTER pAdapter,
@@ -1510,8 +1633,15 @@ PHY_GetRateValuesOfTxPowerByRate(
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(pAdapter);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 	u8				index = 0, i = 0;
+	u8 (*get_val)(u32, u8);
+
+	if (pDM_Odm->phy_reg_pg_version == 1)
+		get_val = get_val_from_dhex;
+	else
+		get_val = get_val_from_hex;
 
 	switch (RegAddr) {
 	case rTxAGC_A_Rate18_06:
@@ -1520,10 +1650,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_9M;
 		Rate[2] = MGN_12M;
 		Rate[3] = MGN_18M;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1533,17 +1661,14 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_36M;
 		Rate[2] = MGN_48M;
 		Rate[3] = MGN_54M;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
 	case rTxAGC_A_CCK1_Mcs32:
 		Rate[0] = MGN_1M;
-		PwrByRateVal[0] = (s8)((((Value >> (8 + 4)) & 0xF)) * 10 +
-				       ((Value >> 8) & 0xF));
+		PwrByRateVal[0] = (s8)get_val(Value, 1);
 		*RateNum = 1;
 		break;
 
@@ -1552,15 +1677,12 @@ PHY_GetRateValuesOfTxPowerByRate(
 			Rate[0] = MGN_2M;
 			Rate[1] = MGN_5_5M;
 			Rate[2] = MGN_11M;
-			for (i = 1; i < 4; ++i) {
-				PwrByRateVal[i - 1] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-						   ((Value >> (i * 8)) & 0xF));
-			}
+			for (i = 1; i < 4; ++i)
+				PwrByRateVal[i - 1] = (s8)get_val(Value, i);
 			*RateNum = 3;
 		} else if (BitMask == 0x000000ff) {
 			Rate[0] = MGN_11M;
-			PwrByRateVal[0] = (s8)((((Value >> 4) & 0xF)) * 10 +
-					       (Value & 0xF));
+			PwrByRateVal[0] = (s8)get_val(Value, 0);
 			*RateNum = 1;
 		}
 		break;
@@ -1571,10 +1693,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS1;
 		Rate[2] = MGN_MCS2;
 		Rate[3] = MGN_MCS3;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1584,10 +1704,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS5;
 		Rate[2] = MGN_MCS6;
 		Rate[3] = MGN_MCS7;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1597,10 +1715,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS9;
 		Rate[2] = MGN_MCS10;
 		Rate[3] = MGN_MCS11;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1610,22 +1726,17 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS13;
 		Rate[2] = MGN_MCS14;
 		Rate[3] = MGN_MCS15;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
-
 		break;
 
 	case rTxAGC_B_CCK1_55_Mcs32:
 		Rate[0] = MGN_1M;
 		Rate[1] = MGN_2M;
 		Rate[2] = MGN_5_5M;
-		for (i = 1; i < 4; ++i) {
-			PwrByRateVal[i - 1] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-						   ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 1; i < 4; ++i)
+			PwrByRateVal[i - 1] = (s8)get_val(Value, i);
 		*RateNum = 3;
 		break;
 
@@ -1637,10 +1748,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_2M;
 		Rate[2] = MGN_5_5M;
 		Rate[3] = MGN_11M;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1652,10 +1761,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_9M;
 		Rate[2] = MGN_12M;
 		Rate[3] = MGN_18M;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1667,10 +1774,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_36M;
 		Rate[2] = MGN_48M;
 		Rate[3] = MGN_54M;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1682,10 +1787,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS1;
 		Rate[2] = MGN_MCS2;
 		Rate[3] = MGN_MCS3;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1697,10 +1800,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS5;
 		Rate[2] = MGN_MCS6;
 		Rate[3] = MGN_MCS7;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1712,10 +1813,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS9;
 		Rate[2] = MGN_MCS10;
 		Rate[3] = MGN_MCS11;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1727,10 +1826,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS13;
 		Rate[2] = MGN_MCS14;
 		Rate[3] = MGN_MCS15;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1742,10 +1839,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_VHT1SS_MCS1;
 		Rate[2] = MGN_VHT1SS_MCS2;
 		Rate[3] = MGN_VHT1SS_MCS3;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1757,10 +1852,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_VHT1SS_MCS5;
 		Rate[2] = MGN_VHT1SS_MCS6;
 		Rate[3] = MGN_VHT1SS_MCS7;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1772,10 +1865,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_VHT1SS_MCS9;
 		Rate[2] = MGN_VHT2SS_MCS0;
 		Rate[3] = MGN_VHT2SS_MCS1;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1787,10 +1878,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_VHT2SS_MCS3;
 		Rate[2] = MGN_VHT2SS_MCS4;
 		Rate[3] = MGN_VHT2SS_MCS5;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1802,10 +1891,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_VHT2SS_MCS7;
 		Rate[2] = MGN_VHT2SS_MCS8;
 		Rate[3] = MGN_VHT2SS_MCS9;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1817,10 +1904,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS17;
 		Rate[2] = MGN_MCS18;
 		Rate[3] = MGN_MCS19;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1832,10 +1917,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_MCS21;
 		Rate[2] = MGN_MCS22;
 		Rate[3] = MGN_MCS23;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1847,10 +1930,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_VHT3SS_MCS1;
 		Rate[2] = MGN_VHT3SS_MCS2;
 		Rate[3] = MGN_VHT3SS_MCS3;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1862,10 +1943,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 		Rate[1] = MGN_VHT3SS_MCS5;
 		Rate[2] = MGN_VHT3SS_MCS6;
 		Rate[3] = MGN_VHT3SS_MCS7;
-		for (i = 0; i < 4; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 4; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 4;
 		break;
 
@@ -1875,10 +1954,8 @@ PHY_GetRateValuesOfTxPowerByRate(
 	case 0x1aE8:
 		Rate[0] = MGN_VHT3SS_MCS8;
 		Rate[1] = MGN_VHT3SS_MCS9;
-		for (i = 0; i < 2; ++i) {
-			PwrByRateVal[i] = (s8)((((Value >> (i * 8 + 4)) & 0xF)) * 10 +
-					       ((Value >> (i * 8)) & 0xF));
-		}
+		for (i = 0; i < 2; ++i)
+			PwrByRateVal[i] = (s8)get_val(Value, i);
 		*RateNum = 2;
 		break;
 
@@ -1947,7 +2024,7 @@ phy_store_tx_power_by_rate(
 )
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 
 	if (pDM_Odm->phy_reg_pg_version > 0)
 		PHY_StoreTxPowerByRateNew(pAdapter, Band, RfPath, RegAddr, BitMask, Data);
@@ -2124,7 +2201,7 @@ PHY_GetTxPowerIndexBase(
 )
 {
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(pAdapter);
-	struct PHY_DM_STRUCT			*pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct			*pDM_Odm = &pHalData->odmpriv;
 	u8					i = 0;	/* default set to 1S */
 	u8					txPower = 0;
 	u8					chnlIdx = (Channel - 1);
@@ -2263,7 +2340,10 @@ PHY_GetTxPowerIndexBase(
 				}
 			}
 			if (i >= CENTER_CH_5G_80M_NUM) {
-				rtw_warn_on(1);
+			#ifdef CONFIG_MP_INCLUDED
+				if (rtw_mp_mode_check(pAdapter) == _FALSE)
+			#endif
+					rtw_warn_on(1);
 				txPower = 0;
 				goto exit;
 			}
@@ -2298,7 +2378,7 @@ PHY_GetTxPowerTrackingOffset(
 )
 {
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(pAdapter);
-	struct PHY_DM_STRUCT			*pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct			*pDM_Odm = &pHalData->odmpriv;
 	s8	offset = 0;
 
 	if (pDM_Odm->rf_calibrate_info.txpowertrack_control  == _FALSE)
@@ -2658,6 +2738,34 @@ PHY_SetTxPowerByRate(
 	pHalData->TxPwrByRateOffset[Band][RFPath][rateIndex] = Value;
 }
 
+u8 phy_check_under_survey_ch(_adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	_adapter *iface;
+	struct mlme_ext_priv *mlmeext;
+	u8 ret = _FALSE;
+	int i;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
+		mlmeext = &iface->mlmeextpriv;
+
+		/* check scan state */
+		if (mlmeext_scan_state(mlmeext) != SCAN_DISABLE
+			&& mlmeext_scan_state(mlmeext) != SCAN_COMPLETE
+				&& mlmeext_scan_state(mlmeext) != SCAN_BACKING_OP) {
+			ret = _TRUE;
+		} else if (mlmeext_scan_state(mlmeext) == SCAN_BACKING_OP
+			&& !mlmeext_chk_scan_backop_flags(mlmeext, SS_BACKOP_TX_RESUME)) {
+			ret = _TRUE;
+		}
+	}
+
+	return ret;
+}
+
 VOID
 phy_set_tx_power_level_by_path(
 	IN	PADAPTER	Adapter,
@@ -2667,6 +2775,8 @@ phy_set_tx_power_level_by_path(
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
 	BOOLEAN bIsIn24G = (pHalData->current_band_type == BAND_ON_2_4G);
+	u8 under_survey_ch = phy_check_under_survey_ch(Adapter);
+
 
 	/* if ( pMgntInfo->RegNByteAccess == 0 ) */
 	{
@@ -2674,20 +2784,23 @@ phy_set_tx_power_level_by_path(
 			phy_set_tx_power_index_by_rate_section(Adapter, path, channel, CCK);
 
 		phy_set_tx_power_index_by_rate_section(Adapter, path, channel, OFDM);
-		phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS0_MCS7);
-
-		if (IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter))
-			phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_1SSMCS0_1SSMCS9);
 
-		if (pHalData->NumTotalRFPath >= 2) {
-			phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS8_MCS15);
+		if (!under_survey_ch) {
+			phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS0_MCS7);
 
 			if (IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter))
-				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_2SSMCS0_2SSMCS9);
+				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_1SSMCS0_1SSMCS9);
+
+			if (pHalData->NumTotalRFPath >= 2) {
+				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS8_MCS15);
+
+				if (IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter))
+					phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_2SSMCS0_2SSMCS9);
 
-			if (IS_HARDWARE_TYPE_8814A(Adapter)) {
-				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS16_MCS23);
-				phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_3SSMCS0_3SSMCS9);
+				if (IS_HARDWARE_TYPE_8814A(Adapter)) {
+					phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS16_MCS23);
+					phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_3SSMCS0_3SSMCS9);
+				}
 			}
 		}
 	}
@@ -2759,7 +2872,23 @@ phy_GetChannelIndexOfTxPowerLimit(
 	return channelIndex;
 }
 
-/* return txpwr limit absolute value */
+static s8 phy_txpwr_ww_lmt_value(_adapter *adapter)
+{
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
+
+	if (hal_spec->txgi_max == 63)
+		return -63;
+	else if (hal_spec->txgi_max == 127)
+		return -128;
+
+	rtw_warn_on(1);
+	return -128;
+}
+
+/*
+* return txpwr limit absolute value
+* hsl_spec->txgi_max is returned when NO limit
+*/
 s8 phy_get_txpwr_lmt_abs(
 	IN	PADAPTER			Adapter,
 	IN	const char			*regd_name,
@@ -2774,12 +2903,14 @@ s8 phy_get_txpwr_lmt_abs(
 	struct dvobj_priv *dvobj = adapter_to_dvobj(Adapter);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(Adapter);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(Adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
 	struct txpwr_lmt_ent *ent = NULL;
 	_irqL irqL;
 	_list *cur, *head;
 	s8 ch_idx;
 	u8 is_ww_regd = 0;
-	s8 lmt = MAX_POWER_INDEX;
+	s8 ww_lmt_val = phy_txpwr_ww_lmt_value(Adapter);
+	s8 lmt = hal_spec->txgi_max;
 
 	if ((Adapter->registrypriv.RegEnableTxPowerLimit == 2 && hal_data->EEPROMRegulatory != 1) ||
 		Adapter->registrypriv.RegEnableTxPowerLimit == 0)
@@ -2820,31 +2951,41 @@ s8 phy_get_txpwr_lmt_abs(
 		goto release_lock;
 
 	if (Band == BAND_ON_2_4G) {
-		if (is_ww_regd) {
-			lmt = MAX_POWER_INDEX;
-			head = &rfctl->txpwr_lmt_list;
-			cur = get_next(head);
-			while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
-				ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
-				cur = get_next(cur);
-				lmt = rtw_min(lmt, ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx]);
-			}
-		} else
+		if (!is_ww_regd) {
 			lmt = ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx];
+			if (lmt != ww_lmt_val)
+				goto release_lock;
+		}
+
+		/* search for min value for WW regd or WW limit */
+		lmt = hal_spec->txgi_max;
+		head = &rfctl->txpwr_lmt_list;
+		cur = get_next(head);
+		while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+			ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+			cur = get_next(cur);
+			if (ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx] != ww_lmt_val)
+				lmt = rtw_min(lmt, ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx]);
+		}
 	}
 	#ifdef CONFIG_IEEE80211_BAND_5GHZ
 	else if (Band == BAND_ON_5G) {
-		if (is_ww_regd) {
-			lmt = MAX_POWER_INDEX;
-			head = &rfctl->txpwr_lmt_list;
-			cur = get_next(head);
-			while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
-				ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
-				cur = get_next(cur);
-				lmt = rtw_min(lmt, ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx]);
-			}
-		} else
+		if (!is_ww_regd) {
 			lmt = ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx];
+			if (lmt != ww_lmt_val)
+				goto release_lock;
+		}
+
+		/* search for min value for WW regd or WW limit */
+		lmt = hal_spec->txgi_max;
+		head = &rfctl->txpwr_lmt_list;
+		cur = get_next(head);
+		while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
+			ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
+			cur = get_next(cur);
+			if (ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx] != ww_lmt_val)
+				lmt = rtw_min(lmt, ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx]);
+		}
 	}
 	#endif
 
@@ -2856,15 +2997,19 @@ exit:
 	return lmt;
 }
 
-/* return txpwr limit diff value */
+/*
+* return txpwr limit diff value
+* hal_spec->txgi_max is returned when NO limit
+*/
 inline s8 phy_get_txpwr_lmt(_adapter *adapter
 	, const char *regd_name
 	, BAND_TYPE band, enum channel_width bw
 	, u8 rfpath, u8 rs, u8 ntx_idx, u8 cch, u8 lock
 )
 {
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	u8 tlrs;
-	s8 lmt = MAX_POWER_INDEX;
+	s8 lmt = hal_spec->txgi_max;
 
 	if (IS_CCK_RATE_SECTION(rs))
 		tlrs = TXPWR_LMT_RS_CCK;
@@ -2882,7 +3027,7 @@ inline s8 phy_get_txpwr_lmt(_adapter *adapter
 
 	lmt = phy_get_txpwr_lmt_abs(adapter, regd_name, band, bw, tlrs, ntx_idx, cch, lock);
 
-	if (lmt != MAX_POWER_INDEX) {
+	if (lmt != hal_spec->txgi_max) {
 		/* return diff value */
 		lmt = lmt - PHY_GetTxPowerByRateBase(adapter, band, rfpath, rs);
 	}
@@ -2904,13 +3049,14 @@ PHY_GetTxPowerLimit(_adapter *adapter
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	BOOLEAN no_sc = _FALSE;
 	s8 tlrs = -1, rs = -1;
-	s8 lmt = MAX_POWER_INDEX;
+	s8 lmt = hal_spec->txgi_max;
 	u8 tmp_cch = 0;
 	u8 tmp_bw;
 	u8 bw_bmp = 0;
-	s8 min_lmt = MAX_POWER_INDEX;
+	s8 min_lmt = hal_spec->txgi_max;
 	u8 final_bw = bw, final_cch = cch;
 	_irqL irqL;
 
@@ -2995,7 +3141,7 @@ PHY_GetTxPowerLimit(_adapter *adapter
 
 	_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
 
-	if (min_lmt != MAX_POWER_INDEX) {
+	if (min_lmt != hal_spec->txgi_max) {
 		/* return diff value */
 		min_lmt = min_lmt - PHY_GetTxPowerByRateBase(adapter, band, rfpath, rs);
 	}
@@ -3016,6 +3162,7 @@ exit:
 static void phy_txpwr_lmt_cck_ofdm_mt_chk(_adapter *adapter)
 {
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	struct txpwr_lmt_ent *ent;
 	_list *cur, *head;
 	u8 channel, tlrs, ntx_idx;
@@ -3036,7 +3183,7 @@ static void phy_txpwr_lmt_cck_ofdm_mt_chk(_adapter *adapter)
 		for (tlrs = TXPWR_LMT_RS_CCK; tlrs <= TXPWR_LMT_RS_OFDM; tlrs++) {
 			for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
 				for (channel = 0; channel < CENTER_CH_2G_NUM; ++channel) {
-					if (ent->lmt_2g[CHANNEL_WIDTH_20][tlrs][channel][ntx_idx] != MAX_POWER_INDEX) {
+					if (ent->lmt_2g[CHANNEL_WIDTH_20][tlrs][channel][ntx_idx] != hal_spec->txgi_max) {
 						if (tlrs == TXPWR_LMT_RS_CCK)
 							rfctl->txpwr_lmt_2g_cck_ofdm_state |= TXPWR_LMT_HAS_CCK_1T << ntx_idx;
 						else
@@ -3061,7 +3208,7 @@ static void phy_txpwr_lmt_cck_ofdm_mt_chk(_adapter *adapter)
 		/* check 5G OFDM state*/
 		for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
 			for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
-				if (ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM - 1][channel][ntx_idx] != MAX_POWER_INDEX) {
+				if (ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM - 1][channel][ntx_idx] != hal_spec->txgi_max) {
 					rfctl->txpwr_lmt_5g_cck_ofdm_state |= TXPWR_LMT_HAS_OFDM_1T << ntx_idx;
 					break;
 				}
@@ -3085,6 +3232,7 @@ static void phy_txpwr_lmt_cck_ofdm_mt_chk(_adapter *adapter)
 static void phy_txpwr_lmt_cross_ref_ht_vht(_adapter *adapter)
 {
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
 	struct txpwr_lmt_ent *ent;
 	_list *cur, *head;
 	u8 bw, channel, tlrs, ref_tlrs, ntx_idx;
@@ -3119,7 +3267,7 @@ static void phy_txpwr_lmt_cross_ref_ht_vht(_adapter *adapter)
 
 						for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
 
-							if (ent->lmt_5g[bw][ref_tlrs - 1][channel][ntx_idx] == MAX_POWER_INDEX)
+							if (ent->lmt_5g[bw][ref_tlrs - 1][channel][ntx_idx] == hal_spec->txgi_max)
 								continue;
 
 							if (tlrs == TXPWR_LMT_RS_HT)
@@ -3129,7 +3277,7 @@ static void phy_txpwr_lmt_cross_ref_ht_vht(_adapter *adapter)
 							else
 								continue;
 
-							if (ent->lmt_5g[bw][tlrs - 1][channel][ntx_idx] != MAX_POWER_INDEX)
+							if (ent->lmt_5g[bw][tlrs - 1][channel][ntx_idx] != hal_spec->txgi_max)
 								continue;
 
 							if (tlrs == TXPWR_LMT_RS_HT && ref_tlrs == TXPWR_LMT_RS_VHT)
@@ -3155,7 +3303,7 @@ static void phy_txpwr_lmt_cross_ref_ht_vht(_adapter *adapter)
 
 	if (0) {
 		RTW_INFO("ht_ref_vht_5g_20_40:%d, ht_has_ref_5g_20_40:%d\n", ht_ref_vht_5g_20_40, ht_has_ref_5g_20_40);
-		RTW_INFO("vht_ref_hht_5g_20_40:%d, vht_has_ref_5g_20_40:%d\n", vht_ref_ht_5g_20_40, vht_has_ref_5g_20_40);
+		RTW_INFO("vht_ref_ht_5g_20_40:%d, vht_has_ref_5g_20_40:%d\n", vht_ref_ht_5g_20_40, vht_has_ref_5g_20_40);
 	}
 
 	/* 5G 20M&40M HT all come from VHT*/
@@ -3304,10 +3452,14 @@ void phy_txpwr_limit_bandwidth_chk(_adapter *adapter)
 									_RTW_PRINT_SEL(RTW_DBGDUMP, "%03u ", cch_by_bw[bw_pos]);
 								_RTW_PRINT_SEL(RTW_DBGDUMP, "limit:");
 								for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--) {
-									if (lmt[bw_pos] == MAX_POWER_INDEX)
+									if (lmt[bw_pos] == hal_spec->txgi_max)
 										_RTW_PRINT_SEL(RTW_DBGDUMP, "N/A ");
+									else if (lmt[bw_pos] > -hal_spec->txgi_pdbm && lmt[bw_pos] < 0) /* -1 < value < 0 */
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "-0.%d", (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+									else if (lmt[bw_pos] % hal_spec->txgi_pdbm)
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d.%d ", lmt[bw_pos] / hal_spec->txgi_pdbm, (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
 									else
-										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2u%s ", lmt[bw_pos] / 2, lmt[bw_pos] % 2 ? ".5" : "");
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d ", lmt[bw_pos] / hal_spec->txgi_pdbm);
 								}
 								_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
 							}
@@ -3329,10 +3481,14 @@ void phy_txpwr_limit_bandwidth_chk(_adapter *adapter)
 									_RTW_PRINT_SEL(RTW_DBGDUMP, "%03u ", cch_by_bw[bw_pos]);
 								_RTW_PRINT_SEL(RTW_DBGDUMP, "limit:");
 								for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--) {
-									if (lmt[bw_pos] == MAX_POWER_INDEX)
+									if (lmt[bw_pos] == hal_spec->txgi_max)
 										_RTW_PRINT_SEL(RTW_DBGDUMP, "N/A ");
+									else if (lmt[bw_pos] > -hal_spec->txgi_pdbm && lmt[bw_pos] < 0) /* -1 < value < 0 */
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "-0.%d", (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+									else if (lmt[bw_pos] % hal_spec->txgi_pdbm)
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d.%d ", lmt[bw_pos] / hal_spec->txgi_pdbm, (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
 									else
-										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2u%s ", lmt[bw_pos] / 2, lmt[bw_pos] % 2 ? ".5" : "");
+										_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d ", lmt[bw_pos] / hal_spec->txgi_pdbm);
 								}
 								_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
 							}
@@ -3404,7 +3560,7 @@ GetS1ByteIntegerFromStringInDecimal(
 */
 VOID
 phy_set_tx_power_limit(
-	IN	struct PHY_DM_STRUCT		*pDM_Odm,
+	IN	struct dm_struct		*pDM_Odm,
 	IN	u8				*Regulation,
 	IN	u8				*Band,
 	IN	u8				*Bandwidth,
@@ -3417,9 +3573,11 @@ phy_set_tx_power_limit(
 #ifdef CONFIG_TXPWR_LIMIT
 	PADAPTER Adapter = pDM_Odm->adapter;
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
 	u8 band = 0, bandwidth = 0, tlrs = 0, channel;
 	u8 ntx_idx;
 	s8 powerLimit = 0, prevPowerLimit, channelIndex;
+	s8 ww_lmt_val = phy_txpwr_ww_lmt_value(Adapter);
 
 	if (0)
 		RTW_INFO("Index of power limit table [regulation %s][band %s][bw %s][rate section %s][ntx %s][chnl %s][val %s]\n"
@@ -3432,7 +3590,15 @@ phy_set_tx_power_limit(
 		return;
 	}
 
-	powerLimit = powerLimit > MAX_POWER_INDEX ? MAX_POWER_INDEX : powerLimit;
+	if (powerLimit != ww_lmt_val) {
+		if (powerLimit < -hal_spec->txgi_max || powerLimit > hal_spec->txgi_max)
+			RTW_PRINT("Illegal power limit value [ch %s][val %s]\n", Channel, PowerLimit);
+
+		if (powerLimit > hal_spec->txgi_max)
+			powerLimit = hal_spec->txgi_max;
+		else if (powerLimit < -hal_spec->txgi_max)
+			powerLimit =  ww_lmt_val + 1;
+	}
 
 	if (eqNByte(RateSection, (u8 *)("CCK"), 3))
 		tlrs = TXPWR_LMT_RS_CCK;
@@ -3529,42 +3695,7 @@ PHY_SetTxPowerIndex(
 	IN	u8				Rate
 )
 {
-	if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
-#if (RTL8814A_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8814A(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
-#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-		PHY_SetTxPowerIndex_8812A(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
-#if (RTL8723B_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8723B(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
-#if (RTL8703B_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8703B(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
-#if (RTL8723D_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8723D(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
-#if (RTL8192E_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8192E(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
-#if (RTL8188E_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8188E(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_8188F(pAdapter)) {
-#if (RTL8188F_SUPPORT == 1)
-		PHY_SetTxPowerIndex_8188F(pAdapter, PowerIndex, RFPath, Rate);
-#endif
-	} else if (IS_HARDWARE_TYPE_8822B(pAdapter))
-		rtw_hal_set_tx_power_index(pAdapter, PowerIndex, RFPath, Rate);
-	else if (IS_HARDWARE_TYPE_8821C(pAdapter))
-		rtw_hal_set_tx_power_index(pAdapter, PowerIndex, RFPath, Rate);
+	rtw_hal_set_tx_power_index(pAdapter, PowerIndex, RFPath, Rate);
 }
 
 void dump_tx_power_idx_title(void *sel, _adapter *adapter)
@@ -3786,7 +3917,7 @@ void dump_tx_power_ext_info(void *sel, _adapter *adapter)
 	if (regsty->target_tx_pwr_valid == _TRUE)
 		RTW_PRINT_SEL(sel, "target_tx_power: from registry\n");
 	else if (phy_is_tx_power_by_rate_needed(adapter))
-		RTW_PRINT_SEL(sel, "target_tx_power: from power by rate\n"); 
+		RTW_PRINT_SEL(sel, "target_tx_power: from power by rate\n");
 	else
 		RTW_PRINT_SEL(sel, "target_tx_power: unavailable\n");
 
@@ -3835,10 +3966,13 @@ void dump_target_tx_power(void *sel, _adapter *adapter)
 
 				target = PHY_GetTxPowerByRateBase(adapter, band, path, rs);
 
-				if (target % 2)
-					_RTW_PRINT_SEL(sel, "%7s: %2d.5\n", rate_section_str(rs), target / 2);
-				else
-					_RTW_PRINT_SEL(sel, "%7s: %4d\n", rate_section_str(rs), target / 2);
+				if (target % hal_spec->txgi_pdbm) {
+					_RTW_PRINT_SEL(sel, "%7s: %2d.%d\n", rate_section_str(rs)
+						, target / hal_spec->txgi_pdbm, (target % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+				} else {
+					_RTW_PRINT_SEL(sel, "%7s: %5d\n", rate_section_str(rs)
+						, target / hal_spec->txgi_pdbm);
+				}
 			}
 		}
 	}
@@ -3890,13 +4024,14 @@ void dump_tx_power_by_rate(void *sel, _adapter *adapter)
 				for (n = rate_num - 1; n >= 0; n--) {
 					by_rate_offset = PHY_GetTxPowerByRate(adapter, band, path, rates_by_sections[rs].rates[n]);
 
-					if ((base + by_rate_offset) % 2)
-						_RTW_PRINT_SEL(sel, "%2d.5 ", (base + by_rate_offset) / 2);
-					else
-						_RTW_PRINT_SEL(sel, "%4d ", (base + by_rate_offset) / 2);
+					if ((base + by_rate_offset) % hal_spec->txgi_pdbm) {
+						_RTW_PRINT_SEL(sel, "%2d.%d ", (base + by_rate_offset) / hal_spec->txgi_pdbm
+							, ((base + by_rate_offset) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
+					} else
+						_RTW_PRINT_SEL(sel, "%5d ", (base + by_rate_offset) / hal_spec->txgi_pdbm);
 				}
 				for (n = 0; n < max_rate_num - rate_num; n++)
-					_RTW_PRINT_SEL(sel, "%4s ", "");
+					_RTW_PRINT_SEL(sel, "%5s ", "");
 
 				_RTW_PRINT_SEL(sel, "|");
 
@@ -4147,14 +4282,19 @@ phy_DecryptBBPgParaFile(
 	}
 }
 
+#ifndef DBG_TXPWR_BY_RATE_FILE_PARSE
+#define DBG_TXPWR_BY_RATE_FILE_PARSE 0
+#endif
+
 int
 phy_ParseBBPgParaFile(
 	PADAPTER		Adapter,
 	char			*buffer
 )
 {
-	int	rtStatus = _SUCCESS;
+	int	rtStatus = _FAIL;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
 	char	*szLine, *ptmp;
 	u32	u4bRegOffset, u4bRegMask, u4bRegValue;
 	u32	u4bMove;
@@ -4162,8 +4302,6 @@ phy_ParseBBPgParaFile(
 	u8	tx_num = 0;
 	u8	band = 0, rf_path = 0;
 
-	/* RTW_INFO("=====>phy_ParseBBPgParaFile()\n"); */
-
 	if (Adapter->registrypriv.RegDecryptCustomFile == 1)
 		phy_DecryptBBPgParaFile(Adapter, buffer);
 
@@ -4175,112 +4313,25 @@ phy_ParseBBPgParaFile(
 		if (!IsCommentString(szLine)) {
 			/* Get header info (relative value or exact value) */
 			if (firstLine) {
-				if (eqNByte(szLine, (u8 *)("#[v1]"), 5)) {
-
-					pHalData->odmpriv.phy_reg_pg_version = szLine[3] - '0';
-					/* RTW_INFO("This is a new format PHY_REG_PG.txt\n"); */
-				} else if (eqNByte(szLine, (u8 *)("#[v0]"), 5)) {
+				if (eqNByte(szLine, (u8 *)("#[v1]"), 5)
+					|| eqNByte(szLine, (u8 *)("#[v2]"), 5))
 					pHalData->odmpriv.phy_reg_pg_version = szLine[3] - '0';
-					/* RTW_INFO("This is a old format PHY_REG_PG.txt ok\n"); */
-				} else {
-					RTW_INFO("The format in PHY_REG_PG are invalid %s\n", szLine);
-					return _FAIL;
+				else {
+					RTW_ERR("The format in PHY_REG_PG are invalid %s\n", szLine);
+					goto exit;
 				}
 
 				if (eqNByte(szLine + 5, (u8 *)("[Exact]#"), 8)) {
 					pHalData->odmpriv.phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
-					/* RTW_INFO("The values in PHY_REG_PG are exact values ok\n"); */
-					firstLine = _FALSE;
-					continue;
-				} else if (eqNByte(szLine + 5, (pu1Byte)("[Relative]#"), 11)) {
-					pHalData->odmpriv.phy_reg_pg_value_type = PHY_REG_PG_RELATIVE_VALUE;
-					/* RTW_INFO("The values in PHY_REG_PG are relative values ok\n"); */
 					firstLine = _FALSE;
 					continue;
 				} else {
-					RTW_INFO("The values in PHY_REG_PG are invalid %s\n", szLine);
-					return _FAIL;
+					RTW_ERR("The values in PHY_REG_PG are invalid %s\n", szLine);
+					goto exit;
 				}
 			}
 
-			if (pHalData->odmpriv.phy_reg_pg_version == 0) {
-				/* Get 1st hex value as register offset. */
-				if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
-					szLine += u4bMove;
-					if (u4bRegOffset == 0xffff) {
-						/* Ending. */
-						break;
-					}
-
-					/* Get 2nd hex value as register mask. */
-					if (GetHexValueFromString(szLine, &u4bRegMask, &u4bMove))
-						szLine += u4bMove;
-					else
-						return _FAIL;
-
-					if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_RELATIVE_VALUE) {
-						/* Get 3rd hex value as register value. */
-						if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
-							phy_store_tx_power_by_rate(Adapter, 0, 0, 1, u4bRegOffset, u4bRegMask, u4bRegValue);
-							/* RTW_INFO("[ADDR] %03X=%08X Mask=%08x\n", u4bRegOffset, u4bRegValue, u4bRegMask); */
-						} else
-							return _FAIL;
-					} else if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_EXACT_VALUE) {
-						u32	combineValue = 0;
-						u8	integer = 0, fraction = 0;
-
-						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
-							szLine += u4bMove;
-						else
-							return _FAIL;
-
-						integer *= 2;
-						if (fraction == 5)
-							integer += 1;
-						combineValue |= (((integer / 10) << 4) + (integer % 10));
-						/* RTW_INFO(" %d", integer ); */
-
-						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
-							szLine += u4bMove;
-						else
-							return _FAIL;
-
-						integer *= 2;
-						if (fraction == 5)
-							integer += 1;
-						combineValue <<= 8;
-						combineValue |= (((integer / 10) << 4) + (integer % 10));
-						/* RTW_INFO(" %d", integer ); */
-
-						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
-							szLine += u4bMove;
-						else
-							return _FAIL;
-
-						integer *= 2;
-						if (fraction == 5)
-							integer += 1;
-						combineValue <<= 8;
-						combineValue |= (((integer / 10) << 4) + (integer % 10));
-						/* RTW_INFO(" %d", integer ); */
-
-						if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
-							szLine += u4bMove;
-						else
-							return _FAIL;
-
-						integer *= 2;
-						if (fraction == 5)
-							integer += 1;
-						combineValue <<= 8;
-						combineValue |= (((integer / 10) << 4) + (integer % 10));
-						/* RTW_INFO(" %d", integer ); */
-						phy_store_tx_power_by_rate(Adapter, 0, 0, 1, u4bRegOffset, u4bRegMask, combineValue);
-
-						/* RTW_INFO("[ADDR] 0x%3x = 0x%4x\n", u4bRegOffset, combineValue ); */
-					}
-				}
-			} else if (pHalData->odmpriv.phy_reg_pg_version > 0) {
+			if (pHalData->odmpriv.phy_reg_pg_version > 0) {
 				u32	index = 0, cnt = 0;
 
 				if (eqNByte(szLine, "0xffff", 6))
@@ -4297,12 +4348,13 @@ phy_ParseBBPgParaFile(
 							band = BAND_ON_5G;
 							index += 6;
 						} else {
-							RTW_INFO("Invalid band %s in PHY_REG_PG.txt\n", szLine);
-							return _FAIL;
+							RTW_ERR("Invalid band %s in PHY_REG_PG.txt\n", szLine);
+							goto exit;
 						}
 
 						rf_path = szLine[index] - 'A';
-						/* RTW_INFO(" Table label Band %d, RfPath %d\n", band, rf_path ); */
+						if (DBG_TXPWR_BY_RATE_FILE_PARSE)
+							RTW_INFO(" Table label Band %d, RfPath %d\n", band, rf_path );
 					} else { /* load rows of tables */
 						if (szLine[1] == '1')
 							tx_num = RF_1TX;
@@ -4313,8 +4365,8 @@ phy_ParseBBPgParaFile(
 						else if (szLine[1] == '4')
 							tx_num = RF_4TX;
 						else {
-							RTW_INFO("Invalid row in PHY_REG_PG.txt '%c'(%d)\n", szLine[1], szLine[1]);
-							return _FAIL;
+							RTW_ERR("Invalid row in PHY_REG_PG.txt '%c'(%d)\n", szLine[1], szLine[1]);
+							goto exit;
 						}
 
 						while (szLine[index] != ']')
@@ -4326,81 +4378,84 @@ phy_ParseBBPgParaFile(
 						if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
 							szLine += u4bMove;
 						else
-							return _FAIL;
+							goto exit;
 
 						/* Get 2nd hex value as register mask. */
 						if (GetHexValueFromString(szLine, &u4bRegMask, &u4bMove))
 							szLine += u4bMove;
 						else
-							return _FAIL;
-
-						if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_RELATIVE_VALUE) {
-							/* Get 3rd hex value as register value. */
-							if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
-								phy_store_tx_power_by_rate(Adapter, band, rf_path, tx_num, u4bRegOffset, u4bRegMask, u4bRegValue);
-								/* RTW_INFO("[ADDR] %03X (tx_num %d) =%08X Mask=%08x\n", u4bRegOffset, tx_num, u4bRegValue, u4bRegMask); */
-							} else
-								return _FAIL;
-						} else if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_EXACT_VALUE) {
+							goto exit;
+
+						if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_EXACT_VALUE) {
 							u32	combineValue = 0;
 							u8	integer = 0, fraction = 0;
 
 							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
-								return _FAIL;
+								goto exit;
 
-							integer *= 2;
-							if (fraction == 5)
-								integer += 1;
-							combineValue |= (((integer / 10) << 4) + (integer % 10));
-							/* RTW_INFO(" %d", integer ); */
+							integer *= hal_spec->txgi_pdbm;
+							integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
+							if (pHalData->odmpriv.phy_reg_pg_version == 1)
+								combineValue |= (((integer / 10) << 4) + (integer % 10));
+							else
+								combineValue |= integer;
 
 							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
-								return _FAIL;
+								goto exit;
 
-							integer *= 2;
-							if (fraction == 5)
-								integer += 1;
+							integer *= hal_spec->txgi_pdbm;
+							integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
 							combineValue <<= 8;
-							combineValue |= (((integer / 10) << 4) + (integer % 10));
-							/* RTW_INFO(" %d", integer ); */
+							if (pHalData->odmpriv.phy_reg_pg_version == 1)
+								combineValue |= (((integer / 10) << 4) + (integer % 10));
+							else
+								combineValue |= integer;
 
 							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
-								return _FAIL;
+								goto exit;
 
-							integer *= 2;
-							if (fraction == 5)
-								integer += 1;
+							integer *= hal_spec->txgi_pdbm;
+							integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
 							combineValue <<= 8;
-							combineValue |= (((integer / 10) << 4) + (integer % 10));
-							/* RTW_INFO(" %d", integer ); */
+							if (pHalData->odmpriv.phy_reg_pg_version == 1)
+								combineValue |= (((integer / 10) << 4) + (integer % 10));
+							else
+								combineValue |= integer;
 
 							if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
 								szLine += u4bMove;
 							else
-								return _FAIL;
+								goto exit;
 
-							integer *= 2;
-							if (fraction == 5)
-								integer += 1;
+							integer *= hal_spec->txgi_pdbm;
+							integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
 							combineValue <<= 8;
-							combineValue |= (((integer / 10) << 4) + (integer % 10));
-							/* RTW_INFO(" %d", integer ); */
+							if (pHalData->odmpriv.phy_reg_pg_version == 1)
+								combineValue |= (((integer / 10) << 4) + (integer % 10));
+							else
+								combineValue |= integer;
+
 							phy_store_tx_power_by_rate(Adapter, band, rf_path, tx_num, u4bRegOffset, u4bRegMask, combineValue);
 
-							/* RTW_INFO("[ADDR] 0x%3x (tx_num %d) = 0x%4x\n", u4bRegOffset, tx_num, combineValue ); */
+							if (DBG_TXPWR_BY_RATE_FILE_PARSE)
+								RTW_INFO("addr:0x%3x mask:0x%08x %dTx = 0x%08x\n", u4bRegOffset, u4bRegMask, tx_num + 1, combineValue);
 						}
 					}
 				}
 			}
 		}
 	}
-	/* RTW_INFO("<=====phy_ParseBBPgParaFile()\n"); */
+
+	rtStatus = _SUCCESS;
+
+exit:
+	RTW_INFO("%s return %d\n", __func__, rtStatus);
 	return rtStatus;
 }
 
@@ -4441,7 +4496,7 @@ phy_ConfigBBWithPgParaFile(
 
 	if (rtStatus == _SUCCESS) {
 		/* RTW_INFO("phy_ConfigBBWithPgParaFile(): read %s ok\n", pFileName); */
-		phy_ParseBBPgParaFile(Adapter, pHalData->para_file_buf);
+		rtStatus = phy_ParseBBPgParaFile(Adapter, pHalData->para_file_buf);
 	} else
 		RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
 
@@ -4688,8 +4743,8 @@ initDeltaSwingIndexTables(
 	} } while (0)\
 
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
-	struct odm_rf_calibration_structure	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
 	u32	j = 0;
 	char	*token;
 	char	delim[] = ",";
@@ -4757,8 +4812,8 @@ PHY_ConfigRFWithTxPwrTrackParaFile(
 )
 {
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT			*pDM_Odm = &pHalData->odmpriv;
-	struct odm_rf_calibration_structure		*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+	struct dm_struct			*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct		*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
 	int	rlen = 0, rtStatus = _FAIL;
 	char	*szLine, *ptmp;
 	u32	i = 0, j = 0;
@@ -4976,17 +5031,15 @@ phy_ParsePowerLimitTableFile(
 
 	int	rtStatus = _FAIL;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT	*pDM_Odm = &(pHalData->odmpriv);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
+	struct dm_struct	*pDM_Odm = &(pHalData->odmpriv);
 	u8	loadingStage = LD_STAGE_EXC_MAPPING;
 	u32	i = 0, forCnt = 0;
-	u8 limitValue = 0, fraction = 0, negative = 0;
 	char	*szLine, *ptmp;
 	char band[10], bandwidth[10], rateSection[10], ntx[10], colNumBuf[10];
 	char **regulation = NULL;
 	u8	colNum = 0;
 
-	RTW_INFO("%s enter\n", __func__);
-
 	if (Adapter->registrypriv.RegDecryptCustomFile == 1)
 		phy_DecryptBBPgParaFile(Adapter, buffer);
 
@@ -5177,88 +5230,59 @@ phy_ParsePowerLimitTableFile(
 					++i;
 
 				/* load the power limit value */
-				cnt = 0;
-				fraction = 0;
-				negative = 0;
 				_rtw_memset((PVOID) powerLimit, 0, 10);
-				while ((szLine[i] >= '0' && szLine[i] <= '9') || szLine[i] == '.'
+
+				if (szLine[i] == 'W' && szLine[i + 1] == 'W') {
+					/*
+					* case "WW" assign special ww value
+					* means to get minimal limit in other regulations at same channel
+					*/
+					s8 ww_value = phy_txpwr_ww_lmt_value(Adapter);
+
+					sprintf(powerLimit, "%d", ww_value);
+					i += 2;
+
+				} else if (szLine[i] == 'N' && szLine[i + 1] == 'A') {
+					/*
+					* case "NA" assign max txgi value
+					* means no limitation
+					*/
+					sprintf(powerLimit, "%d", hal_spec->txgi_max);
+					i += 2;
+
+				} else if ((szLine[i] >= '0' && szLine[i] <= '9') || szLine[i] == '.'
 					|| szLine[i] == '+' || szLine[i] == '-'
-				) {
+				){
+					/* case of dBm value */
+					u8 integer = 0, fraction = 0, negative = 0;
+					u32 u4bMove;
+					s8 lmt = 0;
+
 					if (szLine[i] == '+' || szLine[i] == '-') {
-						if (cnt != 0) {
-							RTW_ERR("Wrong position for sign '%c'\n", szLine[i]);
-							goto exit;
-						}
-						if (szLine[i] == '-') {
+						if (szLine[i] == '-')
 							negative = 1;
-							++i;
-							continue;
-						}
-
-					} else if (szLine[i] == '.') {
-						if ((szLine[i + 1] >= '0' && szLine[i + 1] <= '9')) {
-							fraction = szLine[i + 1];
-							i += 2;
-						} else {
-							RTW_ERR("Wrong fraction '%c'(%d)\n", szLine[i + 1], szLine[i + 1]);
-							goto exit;
-						}
-
-						break;
+						i++;
 					}
 
-					powerLimit[cnt] = szLine[i];
-					++cnt;
-					++i;
-				}
-
-				if (powerLimit[0] == '\0') {
-					powerLimit[0] = '6';
-					powerLimit[1] = '3';
-					i += 2;
-				} else {
-					if (!GetU1ByteIntegerFromStringInDecimal(powerLimit, &limitValue)) {
-						RTW_ERR("Limit \"%s\" is not valid decimal\n", powerLimit);
+					if (GetFractionValueFromString(&szLine[i], &integer, &fraction, &u4bMove))
+						i += u4bMove;
+					else {
+						RTW_ERR("Limit \"%s\" is not valid decimal\n", &szLine[i]);
 						goto exit;
 					}
 
-					limitValue *= 2;
-					cnt = 0;
-
+					/* transform to string of value in unit of txgi */
+					lmt = integer * hal_spec->txgi_pdbm + ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
 					if (negative)
-						powerLimit[cnt++] = '-';
-
-					if (fraction == '5')
-						++limitValue;
-
-					/* the value is greater or equal to 100 */
-					if (limitValue >= 100) {
-						powerLimit[cnt++] = limitValue / 100 + '0';
-						limitValue %= 100;
+						lmt = -lmt;
+					sprintf(powerLimit, "%d", lmt);
 
-						if (limitValue >= 10) {
-							powerLimit[cnt++] = limitValue / 10 + '0';
-							limitValue %= 10;
-						} else
-							powerLimit[cnt++] = '0';
-
-						powerLimit[cnt++] = limitValue + '0';
-					}
-					/* the value is greater or equal to 10 */
-					else if (limitValue >= 10) {
-						powerLimit[cnt++] = limitValue / 10 + '0';
-						limitValue %= 10;
-						powerLimit[cnt++] = limitValue + '0';
-					}
-					/* the value is less than 10 */
-					else
-						powerLimit[cnt++] = limitValue + '0';
-
-					powerLimit[cnt] = '\0';
+				} else {
+					RTW_ERR("Wrong limit expression \"%c%c\"(%d, %d)\n"
+						, szLine[i], szLine[i + 1], szLine[i], szLine[i + 1]);
+					goto exit;
 				}
 
-				/* RTW_INFO("ch%s => %s\n", channel, powerLimit); */
-
 				/* store the power limit value */
 				phy_set_tx_power_limit(pDM_Odm, (u8 *)regulation[forCnt], (u8 *)band,
 					(u8 *)bandwidth, (u8 *)rateSection, (u8 *)ntx, (u8 *)channel, (u8 *)powerLimit);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.c
index aa7aa4805a66..73357941a783 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2014 - 2017 Realtek Corporation.
@@ -17,9 +18,9 @@
 #include <hal_data.h>
 
 /* A mapping from HalData to ODM. */
-enum odm_board_type_e boardType(u8 InterfaceSel)
+enum odm_board_type boardType(u8 InterfaceSel)
 {
-	enum odm_board_type_e        board	= ODM_BOARD_DEFAULT;
+	enum odm_board_type        board	= ODM_BOARD_DEFAULT;
 
 #ifdef CONFIG_PCI_HCI
 	INTERFACE_SELECT_PCIE   pcie	= (INTERFACE_SELECT_PCIE)InterfaceSel;
@@ -68,7 +69,7 @@ enum odm_board_type_e boardType(u8 InterfaceSel)
 void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter)
 {
 	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(adapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
 
 	if (hal->RegIQKFWOffload) {
 		rtw_sctx_init(&hal->iqk_sctx, 0);
@@ -82,8 +83,8 @@ void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter)
 #if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
 void rtw_phydm_iqk_trigger(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(adapter);
-	u8 clear = _FALSE;
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
+	u8 clear = _TRUE;
 	u8 segment = _FALSE;
 	u8 rfk_forbidden = _FALSE;
 
@@ -96,7 +97,7 @@ void rtw_phydm_iqk_trigger(_adapter *adapter)
 
 void rtw_phydm_iqk_trigger_dbg(_adapter *adapter, bool recovery, bool clear, bool segment)
 {
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(adapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
 
 #if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
 		halrf_segment_iqk_trigger(p_dm_odm, clear, segment);
@@ -106,14 +107,14 @@ void rtw_phydm_iqk_trigger_dbg(_adapter *adapter, bool recovery, bool clear, boo
 }
 void rtw_phydm_lck_trigger(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(adapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
 
 	halrf_lck_trigger(p_dm_odm);
 }
 #ifdef CONFIG_DBG_RF_CAL
 void rtw_hal_iqk_test(_adapter *adapter, bool recovery, bool clear, bool segment)
 {
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(adapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
 
 	rtw_ps_deny(adapter, PS_DENY_IOCTL);
 	LeaveAllPowerSaveModeDirect(adapter);
@@ -131,7 +132,7 @@ void rtw_hal_iqk_test(_adapter *adapter, bool recovery, bool clear, bool segment
 
 void rtw_hal_lck_test(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(adapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
 
 	rtw_ps_deny(adapter, PS_DENY_IOCTL);
 	LeaveAllPowerSaveModeDirect(adapter);
@@ -151,7 +152,7 @@ void rtw_hal_lck_test(_adapter *adapter)
 #ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
 void rtw_hal_update_param_init_fw_offload_cap(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(adapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
 
 	if (adapter->registrypriv.fw_param_init)
 		phydm_fwoffload_ability_init(p_dm_odm, PHYDM_PHY_PARAM_OFFLOAD);
@@ -164,43 +165,155 @@ void rtw_hal_update_param_init_fw_offload_cap(_adapter *adapter)
 
 void record_ra_info(void *p_dm_void, u8 macid, struct cmn_sta_info *p_sta, u64 ra_mask)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *p_dm = (struct dm_struct *)p_dm_void;
 	_adapter *adapter = p_dm->adapter;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
 
-	rtw_macid_ctl_set_bw(macid_ctl, macid, p_sta->ra_info.ra_bw_mode);
-	rtw_macid_ctl_set_vht_en(macid_ctl, macid, p_sta->ra_info.is_vht_enable);
-	rtw_macid_ctl_set_rate_bmp0(macid_ctl, macid, ra_mask);
-	rtw_macid_ctl_set_rate_bmp1(macid_ctl, macid, ra_mask >> 32);
+	if (p_sta) {
+		rtw_macid_ctl_set_bw(macid_ctl, macid, p_sta->ra_info.ra_bw_mode);
+		rtw_macid_ctl_set_vht_en(macid_ctl, macid, p_sta->ra_info.is_vht_enable);
+		rtw_macid_ctl_set_rate_bmp0(macid_ctl, macid, ra_mask);
+		rtw_macid_ctl_set_rate_bmp1(macid_ctl, macid, ra_mask >> 32);
 
-	rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
+		rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
+	}
+}
+
+#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
+void rtw_phydm_fill_desc_dpt(void *dm, u8 *desc, u8 dpt_lv)
+{
+	struct dm_struct *p_dm = (struct dm_struct *)dm;
+	_adapter *adapter = p_dm->adapter;
+
+	switch (rtw_get_chip_type(adapter)) {
+/*
+	#ifdef CONFIG_RTL8188F
+	case RTL8188F:
+		break;
+	#endif
+
+	#ifdef CONFIG_RTL8723B
+	case RTL8723B :
+		break;
+	#endif
+
+	#ifdef CONFIG_RTL8703B
+	case RTL8703B :
+		break;
+	#endif
+
+	#ifdef CONFIG_RTL8812A
+	case RTL8812 :
+		break;
+	#endif
+
+	#ifdef CONFIG_RTL8821A
+	case RTL8821:
+		break;
+	#endif
+
+	#ifdef CONFIG_RTL8814A
+	case RTL8814A :
+		break;
+	#endif
+
+	#ifdef CONFIG_RTL8192F
+	case RTL8192F :
+		break;
+	#endif
+*/
+/*
+	#ifdef CONFIG_RTL8192E
+	case RTL8192E :
+		SET_TX_DESC_TX_POWER_0_PSET_92E(desc, dpt_lv);
+		break;
+	#endif
+*/
+
+	#ifdef CONFIG_RTL8821C
+	case RTL8821C :
+		SET_TX_DESC_TXPWR_OFSET_8821C(desc, dpt_lv);
+	break;
+	#endif
+
+	default :
+		RTW_ERR("%s IC not support dynamic tx power\n", __func__);
+		break;
+	}
+}
+void rtw_phydm_set_dyntxpwr(_adapter *adapter, u8 *desc, u8 mac_id)
+{
+	struct dm_struct *dm = adapter_to_phydm(adapter);
+
+	odm_set_dyntxpwr(dm, desc, mac_id);
 }
+#endif
 
-void rtw_phydm_ops_func_init(struct PHY_DM_STRUCT *p_phydm)
+#ifdef CONFIG_RTW_TX_2PATH_EN
+void rtw_phydm_tx_2path_en(_adapter *adapter)
 {
-	struct _rate_adaptive_table_ *p_ra_t = &p_phydm->dm_ra_table;
+	struct dm_struct *dm = adapter_to_phydm(adapter);
+
+	phydm_tx_2path(dm);
+}
+#endif
+#ifdef CONFIG_TDMADIG
+void rtw_phydm_tdmadig(_adapter *adapter, u8 state)
+{
+	struct registry_priv	*pregistrypriv = &adapter->registrypriv;
+	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
+	struct dm_struct *dm = adapter_to_phydm(adapter);
+	u8 tdma_dig_en;
+
+	switch (state) {
+	case TDMADIG_INIT:
+		phydm_tdma_dig_para_upd(dm, ENABLE_TDMA, pregistrypriv->tdmadig_en);
+		phydm_tdma_dig_para_upd(dm, MODE_DECISION, pregistrypriv->tdmadig_mode);
+		break;
+	case TDMADIG_NON_INIT:
+		if(pregistrypriv->tdmadig_dynamic) {
+			if(pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE)
+				tdma_dig_en = 0;
+			else
+				tdma_dig_en = pregistrypriv->tdmadig_en;
+			phydm_tdma_dig_para_upd(dm, ENABLE_TDMA, tdma_dig_en);
+		}
+		break;
+	default:
+		break;
+
+	}
+}
+#endif/*CONFIG_TDMADIG*/
+void rtw_phydm_ops_func_init(struct dm_struct *p_phydm)
+{
+	struct ra_table *p_ra_t = &p_phydm->dm_ra_table;
 
 	p_ra_t->record_ra_info = record_ra_info;
+	#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
+	p_phydm->fill_desc_dyntxpwr = rtw_phydm_fill_desc_dpt;
+	#endif
+}
+void rtw_phydm_priv_init(_adapter *adapter)
+{
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm = &(hal->odmpriv);
+
+	phydm->adapter = adapter;
+	odm_cmn_info_init(phydm, ODM_CMNINFO_PLATFORM, ODM_CE);
 }
 
 void Init_ODM_ComInfo(_adapter *adapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct	*pDM_Odm = &(pHalData->odmpriv);
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 	int i;
 
-	_rtw_memset(pDM_Odm, 0, sizeof(*pDM_Odm));
-
-	pDM_Odm->adapter = adapter;
-
 	/*phydm_op_mode could be change for different scenarios: ex: SoftAP - PHYDM_BALANCE_MODE*/
 	pHalData->phydm_op_mode = PHYDM_PERFORMANCE_MODE;/*Service one device*/
-
-	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_PLATFORM, ODM_CE);
-
 	rtw_odm_init_ic_type(adapter);
 
 	if (rtw_get_intf_type(adapter) == RTW_GSPI)
@@ -250,7 +363,7 @@ void Init_ODM_ComInfo(_adapter *adapter)
 
 #ifdef CONFIG_DFS_MASTER
 	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_DFS_REGION_DOMAIN, adapter->registrypriv.dfs_region_domain);
-	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_DFS_MASTER_ENABLE, &(adapter_to_rfctl(adapter)->dfs_master_enabled));
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_DFS_MASTER_ENABLE, &(adapter_to_rfctl(adapter)->radar_detect_enabled));
 #endif
 
 	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_GPA, pHalData->TypeGPA);
@@ -259,6 +372,7 @@ void Init_ODM_ComInfo(_adapter *adapter)
 	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_ALNA, pHalData->TypeALNA);
 
 	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RFE_TYPE, pHalData->rfe_type);
+	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_X_CAP_SETTING, pHalData->crystal_cap);
 
 	odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_TRSW, 0);
 
@@ -277,15 +391,12 @@ void Init_ODM_ComInfo(_adapter *adapter)
 	/*Add by YuChen for adaptivity init*/
 	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ADAPTIVITY, &(adapter->registrypriv.adaptivity_en));
 	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE, (adapter->registrypriv.adaptivity_mode != 0) ? TRUE : FALSE);
-	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_DCBACKOFF, adapter->registrypriv.adaptivity_dc_backoff);
-	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY, (adapter->registrypriv.adaptivity_dml != 0) ? TRUE : FALSE);
 	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_L2H_INI, adapter->registrypriv.adaptivity_th_l2h_ini);
 	phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF, adapter->registrypriv.adaptivity_th_edcca_hl_diff);
 
 	/*halrf info init*/
 	halrf_cmn_info_init(pDM_Odm, HALRF_CMNINFO_EEPROM_THERMAL_VALUE, pHalData->eeprom_thermal_meter);
-	halrf_cmn_info_init(pDM_Odm, HALRF_CMNINFO_FW_VER,
-		((pHalData->firmware_version << 16) | pHalData->firmware_sub_version));
+	halrf_cmn_info_init(pDM_Odm, HALRF_CMNINFO_PWT_TYPE, 0);
 
 	if (rtw_odm_adaptivity_needed(adapter) == _TRUE)
 		rtw_odm_adaptivity_config_msg(RTW_DBGDUMP, adapter);
@@ -330,6 +441,10 @@ void Init_ODM_ComInfo(_adapter *adapter)
 	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_HUBUSBMODE, &(dvobj->usb_speed));
 #endif
 
+#ifdef CONFIG_DYNAMIC_SOML
+	odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ADAPTIVE_SOML, &(adapter->registrypriv.dyn_soml_en));
+#endif
+
 	/*halrf info hook*/
 #ifdef CONFIG_MP_INCLUDED
 	halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_CON_TX, &(adapter->mppriv.mpt_ctx.is_start_cont_tx));
@@ -363,6 +478,65 @@ static u32 edca_setting_dl_g_mode[HT_IOT_PEER_MAX] =
 /*RALINK, ATHEROS, CISCO, MERU, MARVELL, 92U_AP, SELF_AP */
 { 0x4322, 0xa44f, 0x5e4322, 0xa42b, 0x5e4322, 0x4322,	 0xa42b, 0x5ea42b, 0xa44f, 0x5e4322, 0x5ea42b};
 
+
+struct turbo_edca_setting{
+	u32 edca_ul; /* uplink, tx */
+	u32 edca_dl; /* downlink, rx */
+};
+
+#define TURBO_EDCA_ENT(UL, DL) {UL, DL}
+
+#if 0
+#define TURBO_EDCA_MODE_NUM 18
+static struct turbo_edca_setting rtw_turbo_edca[TURBO_EDCA_MODE_NUM] = {
+	TURBO_EDCA_ENT(0xa42b, 0xa42b), /* mode 0 */
+	TURBO_EDCA_ENT(0x431c, 0x431c), /* mode 1 */
+	TURBO_EDCA_ENT(0x4319, 0x4319), /* mode 2 */	
+	
+	TURBO_EDCA_ENT(0x5ea42b, 0x5ea42b), /* mode 3 */
+	TURBO_EDCA_ENT(0x5e431c, 0x5e431c), /* mode 4 */
+	TURBO_EDCA_ENT(0x5e4319, 0x5e4319), /* mode 5 */	
+	
+	TURBO_EDCA_ENT(0x6ea42b, 0x6ea42b), /* mode 6 */
+	TURBO_EDCA_ENT(0x6e431c, 0x6e431c), /* mode 7 */
+	TURBO_EDCA_ENT(0x6e4319, 0x6e4319), /* mode 8 */
+	
+	TURBO_EDCA_ENT(0x5ea42b, 0xa42b), /* mode 9 */
+	TURBO_EDCA_ENT(0x5e431c, 0x431c), /* mode 10 */
+	TURBO_EDCA_ENT(0x5e4319, 0x4319), /* mode 11 */
+	
+	TURBO_EDCA_ENT(0x6ea42b, 0xa42b), /* mode 12 */
+	TURBO_EDCA_ENT(0x6e431c, 0x431c), /* mode 13 */
+	TURBO_EDCA_ENT(0x6e4319, 0x4319), /* mode 14 */
+
+	TURBO_EDCA_ENT(0x431c, 0x5e431c), /* mode 15 */
+
+	TURBO_EDCA_ENT(0xa42b, 0x5ea42b), /* mode 16 */
+
+	TURBO_EDCA_ENT(0x138642b, 0x431c), /* mode 17 */
+};
+#else
+#define TURBO_EDCA_MODE_NUM 8
+static struct turbo_edca_setting rtw_turbo_edca[TURBO_EDCA_MODE_NUM] = {
+	/* { UL, DL } */
+	TURBO_EDCA_ENT(0x5e431c, 0x431c), /* mode 0 */
+
+	TURBO_EDCA_ENT(0x431c, 0x431c), /* mode 1 */	
+	
+	TURBO_EDCA_ENT(0x5e431c, 0x5e431c), /* mode 2 */
+
+	TURBO_EDCA_ENT(0x5ea42b, 0x5ea42b), /* mode 3 */
+	
+	TURBO_EDCA_ENT(0x5ea42b, 0x431c), /* mode 4 */
+	
+	TURBO_EDCA_ENT(0x6ea42b, 0x6ea42b), /* mode 5 */
+
+	TURBO_EDCA_ENT(0xa42b, 0xa42b), /* mode 6 */
+	
+	TURBO_EDCA_ENT(0x5e431c, 0xa42b), /* mode 7 */
+};
+#endif
+
 void rtw_hal_turbo_edca(_adapter *adapter)
 {
 	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA(adapter);
@@ -392,7 +566,7 @@ void rtw_hal_turbo_edca(_adapter *adapter)
 	u8	is_linked = _FALSE;
 	u8	interface_type;
 
-	if (hal_data->dis_turboedca)
+	if (hal_data->dis_turboedca == 1)
 		return;
 
 	if (rtw_mi_check_status(adapter, MI_ASSOC))
@@ -475,7 +649,7 @@ void rtw_hal_turbo_edca(_adapter *adapter)
 				EDCA_BE_DL = edca_setting_DL[iot_peer];
 			}
 
-			if ((ic_type == RTL8812) || (ic_type == RTL8821) || (ic_type == RTL8192E)) { /* add 8812AU/8812AE */
+			if ((ic_type == RTL8812) || (ic_type == RTL8821) || (ic_type == RTL8192E) || (ic_type == RTL8192F)) { /* add 8812AU/8812AE */
 				EDCA_BE_UL = 0x5ea42b;
 				EDCA_BE_DL = 0x5ea42b;
 
@@ -489,16 +663,101 @@ void rtw_hal_turbo_edca(_adapter *adapter)
 				EDCA_BE_DL = 0x6ea42b;
 			}
 
+			if ((ic_type == RTL8822B)
+			    && (interface_type == RTW_SDIO))
+				EDCA_BE_DL = 0x00431c;
+
+#ifdef CONFIG_RTW_TPT_MODE
+			if ( dvobj->tpt_mode > 0 ) {				
+				EDCA_BE_UL = dvobj->edca_be_ul;
+				EDCA_BE_DL = dvobj->edca_be_dl;
+			}
+#endif /* CONFIG_RTW_TPT_MODE */
+
+			/* keep this condition at last check */
+			if (hal_data->dis_turboedca == 2) {					
+				
+					if (hal_data->edca_param_mode < TURBO_EDCA_MODE_NUM) {
+
+						struct turbo_edca_setting param;
+
+						param = rtw_turbo_edca[hal_data->edca_param_mode];
+
+						EDCA_BE_UL = param.edca_ul;
+						EDCA_BE_DL = param.edca_dl;
+						
+					} else {
+					
+						EDCA_BE_UL = hal_data->edca_param_mode;
+						EDCA_BE_DL = hal_data->edca_param_mode;
+					}				
+			}
+
 			if (traffic_index == DOWN_LINK)
 				edca_param = EDCA_BE_DL;
 			else
 				edca_param = EDCA_BE_UL;
+
+#ifdef CONFIG_EXTEND_LOWRATE_TXOP
+#define TXOP_CCK1M			0x01A6
+#define TXOP_CCK2M			0x00E6
+#define TXOP_CCK5M			0x006B
+#define TXOP_OFD6M			0x0066
+#define TXOP_MCS6M			0x0061
+{
+			struct sta_info *psta;
+			struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
+			u8 mac_id, role, current_rate_id;
+			
+			/*	search all used & connect2AP macid	*/
+			for (mac_id = 0; mac_id < macid_ctl->num; mac_id++) {
+				if (rtw_macid_is_used(macid_ctl, mac_id))  {
+					role = GET_H2CCMD_MSRRPT_PARM_ROLE(&(macid_ctl->h2c_msr[mac_id]));
+					if (role != H2C_MSR_ROLE_AP)
+						continue;
+
+					psta = macid_ctl->sta[mac_id];
+					current_rate_id = rtw_get_current_tx_rate(adapter, psta);
+					/*  Check init tx_rate==1M and set 0x508[31:16]==0x019B(unit 32us) if it is 	*/
+					switch (current_rate_id) {
+						case DESC_RATE1M:
+							edca_param &= 0x0000FFFF;
+							edca_param |= (TXOP_CCK1M<<16);
+							break;
+						case DESC_RATE2M:
+							edca_param &= 0x0000FFFF;
+							edca_param |= (TXOP_CCK2M<<16);
+							break;
+						case DESC_RATE5_5M:
+							edca_param &= 0x0000FFFF;
+							edca_param |= (TXOP_CCK5M<<16);
+							break;
+						case DESC_RATE6M:
+							edca_param &= 0x0000FFFF;
+							edca_param |= (TXOP_OFD6M<<16);
+							break;
+						case DESC_RATEMCS0:
+							edca_param &= 0x0000FFFF;
+							edca_param |= (TXOP_MCS6M<<16);
+							break;
+						default:
+							break;
+					}
+				}
+			}
+}
+#endif /* CONFIG_EXTEND_LOWRATE_TXOP */
+
 #ifdef 	CONFIG_RTW_CUSTOMIZE_BEEDCA
 			edca_param = CONFIG_RTW_CUSTOMIZE_BEEDCA;
 #endif
-			rtw_hal_set_hwreg(adapter, HW_VAR_AC_PARAM_BE, (u8 *)(&edca_param));
 
-			RTW_DBG("Turbo EDCA =0x%x\n", edca_param);
+			if ( edca_param != hal_data->ac_param_be) {
+				
+				rtw_hal_set_hwreg(adapter, HW_VAR_AC_PARAM_BE, (u8 *)(&edca_param));
+
+				RTW_INFO("Turbo EDCA =0x%x\n", edca_param);
+			}
 
 			hal_data->prv_traffic_idx = traffic_index;
 		}
@@ -520,54 +779,54 @@ void rtw_hal_turbo_edca(_adapter *adapter)
 
 s8 rtw_phydm_get_min_rssi(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
 	s8 rssi_min = 0;
 
-	rssi_min = phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_RSSI_MIN);
+	rssi_min = phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_RSSI_MIN);
 	return rssi_min;
 }
 
 u8 rtw_phydm_get_cur_igi(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
 	u8 cur_igi = 0;
 
-	cur_igi = phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CURR_IGI);
+	cur_igi = phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CURR_IGI);
 	return cur_igi;
 }
 
 u32 rtw_phydm_get_phy_cnt(_adapter *adapter, enum phy_cnt cnt)
 {
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
 
 	if (cnt == FA_OFDM)
-		return  phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_FA_OFDM);
+		return  phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_OFDM);
 	else if (cnt == FA_CCK)
-		return  phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_FA_CCK);
+		return  phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_CCK);
 	else if (cnt == FA_TOTAL)
-		return  phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_FA_TOTAL);
+		return  phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_TOTAL);
 	else if (cnt == CCA_OFDM)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CCA_OFDM);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_OFDM);
 	else if (cnt == CCA_CCK)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CCA_CCK);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_CCK);
 	else if (cnt == CCA_ALL)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CCA_ALL);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_ALL);
 	else if (cnt == CRC32_OK_VHT)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_OK_VHT);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_VHT);
 	else if (cnt == CRC32_OK_HT)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_OK_HT);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_HT);
 	else if (cnt == CRC32_OK_LEGACY)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_OK_LEGACY);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_LEGACY);
 	else if (cnt == CRC32_OK_CCK)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_OK_CCK);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_CCK);
 	else if (cnt == CRC32_ERROR_VHT)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_ERROR_VHT);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_VHT);
 	else if (cnt == CRC32_ERROR_HT)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_ERROR_HT);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_HT);
 	else if (cnt == CRC32_ERROR_LEGACY)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_ERROR_LEGACY);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_LEGACY);
 	else if (cnt == CRC32_ERROR_CCK)
-		return	phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CRC32_ERROR_CCK);
+		return	phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_CCK);
 	else
 		return 0;
 }
@@ -575,7 +834,7 @@ u32 rtw_phydm_get_phy_cnt(_adapter *adapter, enum phy_cnt cnt)
 u8 rtw_phydm_is_iqk_in_progress(_adapter *adapter)
 {
 	u8 rts = _FALSE;
-	struct PHY_DM_STRUCT *podmpriv = adapter_to_phydm(adapter);
+	struct dm_struct *podmpriv = adapter_to_phydm(adapter);
 
 	odm_acquire_spin_lock(podmpriv, RT_IQK_SPINLOCK);
 	if (podmpriv->rf_calibrate_info.is_iqk_in_progress == _TRUE) {
@@ -593,7 +852,7 @@ void SetHalODMVar(
 	PVOID					pValue1,
 	BOOLEAN					bSet)
 {
-	struct PHY_DM_STRUCT *podmpriv = adapter_to_phydm(Adapter);
+	struct dm_struct *podmpriv = adapter_to_phydm(Adapter);
 	/* _irqL irqL; */
 	switch (eVariable) {
 	case HAL_ODM_STA_INFO: {
@@ -623,8 +882,8 @@ void SetHalODMVar(
 		break;
 	case HAL_ODM_REGULATION:
 		/* used to auto enable/disable adaptivity by SD7 */
-		odm_cmn_info_init(podmpriv, ODM_CMNINFO_DOMAIN_CODE_2G, 0);
-		odm_cmn_info_init(podmpriv, ODM_CMNINFO_DOMAIN_CODE_5G, 0);
+		phydm_adaptivity_info_update(podmpriv, PHYDM_ADAPINFO_DOMAIN_CODE_2G, 0);
+		phydm_adaptivity_info_update(podmpriv, PHYDM_ADAPINFO_DOMAIN_CODE_5G, 0);
 		break;
 	case HAL_ODM_INITIAL_GAIN: {
 		u8 rx_gain = *((u8 *)(pValue1));
@@ -658,10 +917,10 @@ void SetHalODMVar(
 		if (podmpriv->is_linked) {
 			_RTW_PRINT_SEL(sel, "rx_rate = %s", HDATA_RATE(podmpriv->rx_rate));
 			if (IS_HARDWARE_TYPE_8814A(Adapter))
-				_RTW_PRINT_SEL(sel, " RSSI_A = %d(%%), RSSI_B = %d(%%), RSSI_C = %d(%%), RSSI_D = %d(%%)\n",
-					podmpriv->RSSI_A, podmpriv->RSSI_B, podmpriv->RSSI_C, podmpriv->RSSI_D);
+				_RTW_PRINT_SEL(sel, " rssi_a = %d(%%), rssi_b = %d(%%), rssi_c = %d(%%), rssi_d = %d(%%)\n",
+					podmpriv->rssi_a, podmpriv->rssi_b, podmpriv->rssi_c, podmpriv->rssi_d);
 			else
-				_RTW_PRINT_SEL(sel, " RSSI_A = %d(%%), RSSI_B = %d(%%)\n", podmpriv->RSSI_A, podmpriv->RSSI_B);
+				_RTW_PRINT_SEL(sel, " rssi_a = %d(%%), rssi_b = %d(%%)\n", podmpriv->rssi_a, podmpriv->rssi_b);
 #ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
 			rtw_dump_raw_rssi_info(Adapter, sel);
 #endif
@@ -703,7 +962,7 @@ void GetHalODMVar(
 	PVOID					pValue1,
 	PVOID					pValue2)
 {
-	struct PHY_DM_STRUCT *podmpriv = adapter_to_phydm(Adapter);
+	struct dm_struct *podmpriv = adapter_to_phydm(Adapter);
 
 	switch (eVariable) {
 #ifdef CONFIG_ANTENNA_DIVERSITY
@@ -727,7 +986,7 @@ void GetHalODMVar(
 
 enum hal_status
 rtw_phydm_fw_iqk(
-	struct PHY_DM_STRUCT	*p_dm_odm,
+	struct dm_struct	*p_dm_odm,
 	u8 clear,
 	u8 segment
 )
@@ -743,7 +1002,7 @@ rtw_phydm_fw_iqk(
 
 enum hal_status
 rtw_phydm_cfg_phy_para(
-	struct PHY_DM_STRUCT	*p_dm_odm,
+	struct dm_struct	*p_dm_odm,
 	enum phydm_halmac_param config_type,
 	u32 offset,
 	u32 data,
@@ -761,7 +1020,7 @@ rtw_phydm_cfg_phy_para(
 		para.data.mac.offset = offset;
 		para.data.mac.value = data;
 		para.data.mac.msk = mask;
-		para.data.mac.msk_en = 1;
+		para.data.mac.msk_en = (mask) ? 1 : 0;
 		para.data.mac.size = 1;
 	break;
 	case PHYDM_HALMAC_CMD_MAC_W16:
@@ -769,7 +1028,7 @@ rtw_phydm_cfg_phy_para(
 		para.data.mac.offset = offset;
 		para.data.mac.value = data;
 		para.data.mac.msk = mask;
-		para.data.mac.msk_en = 1;
+		para.data.mac.msk_en = (mask) ? 1 : 0;
 		para.data.mac.size = 2;
 	break;
 	case PHYDM_HALMAC_CMD_MAC_W32:
@@ -777,7 +1036,7 @@ rtw_phydm_cfg_phy_para(
 		para.data.mac.offset = offset;
 		para.data.mac.value = data;
 		para.data.mac.msk = mask;
-		para.data.mac.msk_en = 1;
+		para.data.mac.msk_en = (mask) ? 1 : 0;
 		para.data.mac.size = 4;
 	break;
 	case PHYDM_HALMAC_CMD_BB_W8:
@@ -785,7 +1044,7 @@ rtw_phydm_cfg_phy_para(
 		para.data.bb.offset = offset;
 		para.data.bb.value = data;
 		para.data.bb.msk = mask;
-		para.data.bb.msk_en = 1;
+		para.data.bb.msk_en = (mask) ? 1 : 0;
 		para.data.bb.size = 1;
 	break;
 	case PHYDM_HALMAC_CMD_BB_W16:
@@ -793,7 +1052,7 @@ rtw_phydm_cfg_phy_para(
 		para.data.bb.offset = offset;
 		para.data.bb.value = data;
 		para.data.bb.msk = mask;
-		para.data.bb.msk_en = 1;
+		para.data.bb.msk_en = (mask) ? 1 : 0;
 		para.data.bb.size = 2;
 	break;
 	case PHYDM_HALMAC_CMD_BB_W32:
@@ -801,7 +1060,7 @@ rtw_phydm_cfg_phy_para(
 		para.data.bb.offset = offset;
 		para.data.bb.value = data;
 		para.data.bb.msk = mask;
-		para.data.bb.msk_en = 1;
+		para.data.bb.msk_en = (mask) ? 1 : 0;
 		para.data.bb.size = 4;
 	break;
 	case PHYDM_HALMAC_CMD_RF_W:
@@ -809,7 +1068,7 @@ rtw_phydm_cfg_phy_para(
 		para.data.rf.offset = offset;
 		para.data.rf.value = data;
 		para.data.rf.msk = mask;
-		para.data.rf.msk_en = 1;
+		para.data.rf.msk_en = (mask) ? 1 : 0;
 		if (e_rf_path == RF_PATH_A)
 			para.data.rf.path = 0;
 		else if (e_rf_path == RF_PATH_B)
@@ -850,7 +1109,7 @@ void rtw_phydm_wd_lps_lclk_hdl(_adapter *adapter)
 {
 	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT	*podmpriv = &(pHalData->odmpriv);
+	struct dm_struct	*podmpriv = &(pHalData->odmpriv);
 	struct sta_priv *pstapriv = &adapter->stapriv;
 	struct sta_info *psta = NULL;
 	u8 rssi_min = 0;
@@ -912,15 +1171,22 @@ void dump_sta_traffic(void *sel, _adapter *adapter, struct sta_info *psta)
 {
 	struct ra_sta_info *ra_info;
 	u8 curr_sgi = _FALSE;
+	u32 tx_tp_mbips, rx_tp_mbips, bi_tp_mbips;
 
 	if (!psta)
 		return;
-	RTW_PRINT_SEL(sel, "====== mac_id : %d ======\n", psta->cmn.mac_id);
+	RTW_PRINT_SEL(sel, "\n");
+	RTW_PRINT_SEL(sel, "====== mac_id : %d [" MAC_FMT "] ======\n",
+		psta->cmn.mac_id, MAC_ARG(psta->cmn.mac_addr));
+
+	if (is_client_associated_to_ap(psta->padapter))
+		RTW_PRINT_SEL(sel, "BCN counts : %d (per-%d second), DTIM Period:%d\n",
+		rtw_get_bcn_cnt(psta->padapter) / 2, 1, rtw_get_bcn_dtim_period(psta->padapter));
 
 	ra_info = &psta->cmn.ra_info;
-	curr_sgi = (ra_info->curr_tx_rate & 0x80) ? _TRUE : _FALSE;
+	curr_sgi = rtw_get_current_tx_sgi(adapter, psta);
 	RTW_PRINT_SEL(sel, "tx_rate : %s(%s)  rx_rate : %s, rx_rate_bmc : %s, rssi : %d %%\n"
-		, HDATA_RATE((ra_info->curr_tx_rate & 0x7F)), (curr_sgi) ? "S" : "L"
+		, HDATA_RATE(rtw_get_current_tx_rate(adapter, psta)), (curr_sgi) ? "S" : "L"
 		, HDATA_RATE((psta->curr_rx_rate & 0x7F)), HDATA_RATE((psta->curr_rx_rate_bmc & 0x7F)), psta->cmn.rssi_stat.rssi
 	);
 
@@ -943,14 +1209,51 @@ void dump_sta_traffic(void *sel, _adapter *adapter, struct sta_info *psta)
 		);
 	}
 
-	RTW_PRINT_SEL(sel, "TP {Tx,Rx,Total} = { %d , %d , %d } Mbps\n",
-		(psta->sta_stats.tx_tp_mbytes << 3), (psta->sta_stats.rx_tp_mbytes << 3),
-		(psta->sta_stats.tx_tp_mbytes + psta->sta_stats.rx_tp_mbytes) << 3);
+	_RTW_PRINT_SEL(sel, "RTW: [TP] ");
+	tx_tp_mbips = psta->sta_stats.tx_tp_kbits >> 10;
+	rx_tp_mbips = psta->sta_stats.rx_tp_kbits >> 10;
+	bi_tp_mbips = tx_tp_mbips + rx_tp_mbips;
 
+	if (tx_tp_mbips)
+		_RTW_PRINT_SEL(sel, "Tx : %d(Mbps) ", tx_tp_mbips);
+	else
+		_RTW_PRINT_SEL(sel, "Tx : %d(Kbps) ", psta->sta_stats.tx_tp_kbits);
+
+	if (rx_tp_mbips) 
+		_RTW_PRINT_SEL(sel, "Rx : %d(Mbps) ", rx_tp_mbips);
+	else
+		_RTW_PRINT_SEL(sel, "Rx : %d(Kbps) ", psta->sta_stats.rx_tp_kbits);
+
+	if (bi_tp_mbips)
+		_RTW_PRINT_SEL(sel, "Total : %d(Mbps)\n", bi_tp_mbips);
+	else
+		_RTW_PRINT_SEL(sel, "Total : %d(Kbps)\n", psta->sta_stats.tx_tp_kbits + psta->sta_stats.rx_tp_kbits);
+
+
+	_RTW_PRINT_SEL(sel, "RTW: [Smooth TP] ");
+	tx_tp_mbips = psta->sta_stats.smooth_tx_tp_kbits >> 10;
+	rx_tp_mbips = psta->sta_stats.smooth_rx_tp_kbits >> 10;
+	bi_tp_mbips = tx_tp_mbips + rx_tp_mbips;
+	if (tx_tp_mbips)
+		_RTW_PRINT_SEL(sel, "Tx : %d(Mbps) ", tx_tp_mbips);
+	else
+		_RTW_PRINT_SEL(sel, "Tx : %d(Kbps) ", psta->sta_stats.smooth_tx_tp_kbits);
+
+	if (rx_tp_mbips) 
+		_RTW_PRINT_SEL(sel, "Rx : %d(Mbps) ", rx_tp_mbips);
+	else
+		_RTW_PRINT_SEL(sel, "Rx : %d(Kbps) ", psta->sta_stats.smooth_rx_tp_kbits);
+
+	if (bi_tp_mbips)
+		_RTW_PRINT_SEL(sel, "Total : %d(Mbps)\n", bi_tp_mbips);
+	else
+		_RTW_PRINT_SEL(sel, "Total : %d(Kbps)\n", psta->sta_stats.smooth_tx_tp_kbits + psta->sta_stats.rx_tp_kbits);
+
+	#if 0
 	RTW_PRINT_SEL(sel, "Moving-AVG TP {Tx,Rx,Total} = { %d , %d , %d } Mbps\n\n",
 		(psta->cmn.tx_moving_average_tp << 3), (psta->cmn.rx_moving_average_tp << 3),
 		(psta->cmn.tx_moving_average_tp + psta->cmn.rx_moving_average_tp) << 3);
-
+	#endif
 }
 
 void dump_sta_info(void *sel, struct sta_info *psta)
@@ -969,6 +1272,7 @@ void dump_sta_info(void *sel, struct sta_info *psta)
 	RTW_PRINT_SEL(sel, "mac_id : %d\n", psta->cmn.mac_id);
 	RTW_PRINT_SEL(sel, "wireless_mode : 0x%02x\n", psta->wireless_mode);
 	RTW_PRINT_SEL(sel, "mimo_type : %d\n", psta->cmn.mimo_type);
+	RTW_PRINT_SEL(sel, "static smps : %s\n", (psta->cmn.sm_ps == SM_PS_STATIC) ? "Y" : "N");
 	RTW_PRINT_SEL(sel, "bw_mode : %s, ra_bw_mode : %s\n",
 			ch_width_str(psta->cmn.bw_mode), ch_width_str(ra_info->ra_bw_mode));
 	RTW_PRINT_SEL(sel, "rate_id : %d\n", ra_info->rate_id);
@@ -980,8 +1284,8 @@ void dump_sta_info(void *sel, struct sta_info *psta)
 	RTW_PRINT_SEL(sel, "is_noisy : %s\n", (ra_info->is_noisy) ? "Y" : "N");
 	RTW_PRINT_SEL(sel, "txrx_state : %d\n", ra_info->txrx_state);/*0: uplink, 1:downlink, 2:bi-direction*/
 
-	curr_tx_sgi = (ra_info->curr_tx_rate & 0x80) ? _TRUE : _FALSE;
-	curr_tx_rate = ra_info->curr_tx_rate & 0x7F;
+	curr_tx_sgi = rtw_get_current_tx_sgi(psta->padapter, psta);
+	curr_tx_rate = rtw_get_current_tx_rate(psta->padapter, psta);
 	RTW_PRINT_SEL(sel, "curr_tx_rate : %s (%s)\n",
 			HDATA_RATE(curr_tx_rate), (curr_tx_sgi) ? "S" : "L");
 	RTW_PRINT_SEL(sel, "curr_tx_bw : %s\n", ch_width_str(ra_info->curr_tx_bw));
@@ -1000,11 +1304,31 @@ void rtw_phydm_ra_registed(_adapter *adapter, struct sta_info *psta)
 	}
 
 	phydm_ra_registed(&hal_data->odmpriv, psta->cmn.mac_id, psta->cmn.rssi_stat.rssi);
-	if (_DRV_DEBUG_ <= rtw_drv_log_level)
-		dump_sta_info(RTW_DBGDUMP, psta);
+	dump_sta_info(RTW_DBGDUMP, psta);
+}
+
+static void init_phydm_info(_adapter *adapter)
+{
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm = &(hal_data->odmpriv);
+
+	odm_cmn_info_init(phydm, ODM_CMNINFO_FW_VER, hal_data->firmware_version);
+	odm_cmn_info_init(phydm, ODM_CMNINFO_FW_SUB_VER, hal_data->firmware_sub_version);
+}
+void rtw_phydm_init(_adapter *adapter)
+{
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct	*phydm = &(hal_data->odmpriv);
+
+	init_phydm_info(adapter);
+	odm_dm_init(phydm);
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
+	phydm_pathb_q_matrix_rotate_en(phydm);
+#endif
 }
 
 #ifdef CONFIG_LPS_PG
+/*
 static void _lps_pg_state_update(_adapter *adapter)
 {
 	u8	is_in_lpspg = _FALSE;
@@ -1021,44 +1345,90 @@ static void _lps_pg_state_update(_adapter *adapter)
 	if (psta)
 		psta->cmn.ra_info.disable_ra = (is_in_lpspg) ? _TRUE : _FALSE;
 }
+*/
+void rtw_phydm_lps_pg_hdl(_adapter *adapter, struct sta_info *sta, bool in_lpspg)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+	/*u8 rate_id;*/
+
+	if(sta == NULL) {
+		RTW_ERR("%s sta is null\n", __func__);
+		rtw_warn_on(1);
+		return;
+	}
+
+	if (in_lpspg) {
+		sta->cmn.ra_info.disable_ra = _TRUE;
+		sta->cmn.ra_info.disable_pt = _TRUE;
+		/*TODO : DRV fix tx rate*/
+		/*rate_id = phydm_get_rate_from_rssi_lv(phydm, sta->cmn.mac_id);*/
+	} else {
+		sta->cmn.ra_info.disable_ra = _FALSE;
+		sta->cmn.ra_info.disable_pt = _FALSE;
+	}
+
+	rtw_phydm_ra_registed(adapter, sta);
+}
 #endif
 
 /*#define DBG_PHYDM_STATE_CHK*/
 
 
-static u8 _rtw_phydm_rfk_condition_check(_adapter *adapter)
+static u8 _rtw_phydm_rfk_condition_check(_adapter *adapter, u8 is_scaning, u8 ifs_linked)
 {
-	u8 rst = _FALSE;
+	u8 rfk_allowed = _TRUE;
 
-	if (rtw_mi_stayin_union_ch_chk(adapter))
-		rst = _TRUE;
+	#ifdef CONFIG_SKIP_RFK_IN_DM
+	rfk_allowed = _FALSE;
+	if (0)
+		RTW_ERR("[RFK-CHK] RF-K not allowed due to CONFIG_SKIP_RFK_IN_DM\n");
+	return rfk_allowed;
+	#endif
 
 	#ifdef CONFIG_MCC_MODE
 	/*not in MCC State*/
-	if (MCC_EN(adapter))
-		if (!rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
-			rst = _TRUE;
+	if (MCC_EN(adapter) && 
+		rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
+		rfk_allowed = _FALSE;
+		if (0)
+			RTW_INFO("[RFK-CHK] RF-K not allowed due to doing MCC\n");
+		return rfk_allowed;
+	}
 	#endif
 
 	#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
 
 	#endif
 
-	return rst;
+	if (ifs_linked) {
+		if (is_scaning) {
+			rfk_allowed = _FALSE;
+			RTW_DBG("[RFK-CHK] RF-K not allowed due to ifaces under site-survey\n");
+		}
+		else {
+			rfk_allowed = rtw_mi_stayin_union_ch_chk(adapter) ? _TRUE : _FALSE;
+			if (rfk_allowed == _FALSE)
+				RTW_ERR("[RFK-CHK] RF-K not allowed due to ld_iface not stayin union ch\n");
+		}
+	}
+
+	return rfk_allowed;
 }
+
 #if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
-static u8 _rtw_phydm_iqk_segment_chk(_adapter *adapter)
+static u8 _rtw_phydm_iqk_segment_chk(_adapter *adapter, u8 ifs_linked)
 {
-	u8 rst = _FALSE;
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 iqk_sgt = _FALSE;
 
 #if 0
-	if (dvobj->traffic_stat.cur_tx_tp > 2 || dvobj->traffic_stat.cur_rx_tp > 2)
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	if (ifs_linked && (dvobj->traffic_stat.cur_tx_tp > 2 || dvobj->traffic_stat.cur_rx_tp > 2))
 		rst = _TRUE;
 #else
-	rst = _TRUE;
+	if (ifs_linked)
+		iqk_sgt = _TRUE;
 #endif
-	return rst;
+	return iqk_sgt;
 }
 #endif
 
@@ -1092,16 +1462,93 @@ static u8 _rtw_phydm_pwr_tracking_rate_check(_adapter *adapter)
 	return tx_rate;
 }
 
-void rtw_phydm_watchdog(_adapter *adapter)
+#ifdef CONFIG_DYNAMIC_SOML
+void rtw_dyn_soml_byte_update(_adapter *adapter, u8 data_rate, u32 size)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+
+	phydm_soml_bytes_acq(phydm, data_rate, size);
+}
+
+void rtw_dyn_soml_para_set(_adapter *adapter, u8 train_num, u8 intvl,
+			u8 period, u8 delay)
+{
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+
+	phydm_adaptive_soml_para_set(phydm, train_num, intvl, period, delay);
+	RTW_INFO("%s.\n", __func__);
+}
+
+void rtw_dyn_soml_config(_adapter *adapter)
+{
+	RTW_INFO("%s.\n", __func__);
+
+	if (adapter->registrypriv.dyn_soml_en == 1) {
+		/* Must after phydm_adaptive_soml_init() */
+		rtw_hal_set_hwreg(adapter , HW_VAR_SET_SOML_PARAM , NULL);
+		RTW_INFO("dyn_soml_en = 1\n");
+	} else {
+		if (adapter->registrypriv.dyn_soml_en == 2) {
+			rtw_dyn_soml_para_set(adapter, 
+				adapter->registrypriv.dyn_soml_train_num, 
+				adapter->registrypriv.dyn_soml_interval, 
+				adapter->registrypriv.dyn_soml_period,
+				adapter->registrypriv.dyn_soml_delay);
+			RTW_INFO("dyn_soml_en = 2\n");
+			RTW_INFO("dyn_soml_en, param = %d, %d, %d, %d\n",
+				adapter->registrypriv.dyn_soml_train_num,
+				adapter->registrypriv.dyn_soml_interval, 
+				adapter->registrypriv.dyn_soml_period,
+				adapter->registrypriv.dyn_soml_delay);
+		} else if (adapter->registrypriv.dyn_soml_en == 0) {
+			RTW_INFO("dyn_soml_en = 0\n");
+		} else
+			RTW_ERR("%s, wrong setting: dyn_soml_en = %d\n", __func__,
+				adapter->registrypriv.dyn_soml_en);
+	}
+}
+#endif
+
+
+void rtw_phydm_read_efuse(_adapter *adapter)
+{
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct *phydm = &(hal_data->odmpriv);
+
+	/*PHYDM API - thermal trim*/
+	phydm_get_thermal_trim_offset(phydm);
+	/*PHYDM API - power trim*/
+	phydm_get_power_trim_offset(phydm);
+}
+
+#ifdef CONFIG_LPS_PWR_TRACKING
+void rtw_phydm_pwr_tracking_directly(_adapter *adapter)
+{
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
+	u8 rfk_forbidden = _TRUE;
+	u8 is_linked = _FALSE;
+
+	if (rtw_mi_check_status(adapter, MI_ASSOC))
+		is_linked = _TRUE;
+
+	rfk_forbidden = (_rtw_phydm_rfk_condition_check(adapter, hal_data->bScanInProcess, is_linked) == _TRUE) ? _FALSE : _TRUE;
+	halrf_cmn_info_set(&hal_data->odmpriv, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
+
+	odm_txpowertracking_direct_ce(&hal_data->odmpriv);
+}
+#endif
+
+void rtw_phydm_watchdog(_adapter *adapter, bool in_lps)
 {
 	u8	bLinked = _FALSE;
 	u8	bsta_state = _FALSE;
 	u8	bBtDisabled = _TRUE;
-	u8	rfk_forbidden = _TRUE;
-	u8	segment_iqk = _TRUE;
+	u8	rfk_forbidden = _FALSE;
+	#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+	u8	segment_iqk = _FALSE;
+	#endif
 	u8	tx_unlinked_low_rate = 0xFF;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(adapter);
-	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
 
 	if (!rtw_is_hw_init_completed(adapter)) {
 		RTW_DBG("%s skip due to hw_init_completed == FALSE\n", __func__);
@@ -1121,33 +1568,28 @@ void rtw_phydm_watchdog(_adapter *adapter)
 	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_LINK, bLinked);
 	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_STATION_STATE, bsta_state);
 
-#ifdef CONFIG_BT_COEXIST
+	#ifdef CONFIG_BT_COEXIST
 	bBtDisabled = rtw_btcoex_IsBtDisabled(adapter);
-#endif /* CONFIG_BT_COEXIST */
+	#endif /* CONFIG_BT_COEXIST */
 	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_BT_ENABLED,
 							(bBtDisabled == _TRUE) ? _FALSE : _TRUE);
-	odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_POWER_TRAINING,
-							(pHalData->bDisableTXPowerTraining) ? _TRUE : _FALSE);
-#ifdef CONFIG_LPS_PG
-	_lps_pg_state_update(adapter);
-#endif
 
-	if (bLinked == _TRUE) {
-		rfk_forbidden = (_rtw_phydm_rfk_condition_check(adapter) == _TRUE) ? _FALSE : _TRUE;
-		halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
+	rfk_forbidden = (_rtw_phydm_rfk_condition_check(adapter, pHalData->bScanInProcess, bLinked) == _TRUE) ? _FALSE : _TRUE;
+	halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
 
-		#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
-		segment_iqk = _rtw_phydm_iqk_segment_chk(adapter);
-		halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_IQK_SEGMENT, segment_iqk);
-		#endif
-	} else {
+	#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
+	segment_iqk = _rtw_phydm_iqk_segment_chk(adapter, bLinked);
+	halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_IQK_SEGMENT, segment_iqk);
+	#endif
+	#ifdef DBG_PHYDM_STATE_CHK
+	RTW_INFO("%s rfk_forbidden = %s, segment_iqk = %s\n",
+			__func__, (rfk_forbidden) ? "Y" : "N", (segment_iqk) ? "Y" : "N");
+	#endif
+
+	if (bLinked == _FALSE) {
 		tx_unlinked_low_rate = _rtw_phydm_pwr_tracking_rate_check(adapter);
 		halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_RATE_INDEX, tx_unlinked_low_rate);
 	}
-#ifdef DBG_PHYDM_STATE_CHK
-	RTW_INFO("%s rfk_forbidden = %s, segment_iqk = %s\n",
-		__func__, (rfk_forbidden) ? "Y" : "N", (segment_iqk) ? "Y" : "N");
-#endif
 
 	/*if (!rtw_mi_stayin_union_band_chk(adapter)) {
 		#ifdef DBG_PHYDM_STATE_CHK
@@ -1155,7 +1597,12 @@ void rtw_phydm_watchdog(_adapter *adapter)
 		#endif
 		goto _exit;
 	}*/
-	if (pwrctl->bpower_saving)
+
+	#ifdef CONFIG_TDMADIG
+	rtw_phydm_tdmadig(adapter, TDMADIG_NON_INIT);
+	#endif/*CONFIG_TDMADIG*/
+
+	if (in_lps)
 		phydm_watchdog_lps(&pHalData->odmpriv);
 	else
 		phydm_watchdog(&pHalData->odmpriv);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.h
index 93ed020a136c..ca300179f3f5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -16,8 +17,14 @@
 #define __HAL_DM_H__
 
 #define adapter_to_phydm(adapter) (&(GET_HAL_DATA(adapter)->odmpriv))
-
+#define dvobj_to_phydm(dvobj) adapter_to_phydm(dvobj_get_primary_adapter(dvobj))
+#ifdef CONFIG_TDMADIG
+void rtw_phydm_tdmadig(_adapter *adapter, u8 state);
+#endif
+void rtw_phydm_priv_init(_adapter *adapter);
 void Init_ODM_ComInfo(_adapter *adapter);
+void rtw_phydm_init(_adapter *adapter);
+
 void rtw_hal_turbo_edca(_adapter *adapter);
 u8 rtw_phydm_is_iqk_in_progress(_adapter *adapter);
 
@@ -34,7 +41,13 @@ void SetHalODMVar(
 
 void rtw_phydm_ra_registed(_adapter *adapter, struct sta_info *psta);
 
-void rtw_phydm_watchdog(_adapter *adapter);
+#ifdef CONFIG_DYNAMIC_SOML
+void rtw_dyn_soml_byte_update(_adapter *adapter, u8 data_rate, u32 size);
+void rtw_dyn_soml_para_set(_adapter *adapter, u8 train_num, u8 intvl,
+			u8 period, u8 delay);
+void rtw_dyn_soml_config(_adapter *adapter);
+#endif
+void rtw_phydm_watchdog(_adapter *adapter, bool in_lps);
 
 void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter);
 void dump_sta_info(void *sel, struct sta_info *psta);
@@ -55,7 +68,12 @@ extern void phydm_rssi_monitor_check(void *p_dm_void);
 void rtw_phydm_wd_lps_lclk_hdl(_adapter *adapter);
 void rtw_phydm_watchdog_in_lps_lclk(_adapter *adapter);
 #endif
-
+#ifdef CONFIG_TDMADIG
+enum rtw_tdmadig_state{
+	TDMADIG_INIT,
+	TDMADIG_NON_INIT,
+};
+#endif
 enum phy_cnt {
 	FA_OFDM,
 	FA_CCK,
@@ -76,5 +94,19 @@ u32 rtw_phydm_get_phy_cnt(_adapter *adapter, enum phy_cnt cnt);
 #if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1))
 void rtw_phydm_iqk_trigger(_adapter *adapter);
 #endif
+void rtw_phydm_read_efuse(_adapter *adapter);
+
+#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
+void rtw_phydm_set_dyntxpwr(_adapter *adapter, u8 *desc, u8 mac_id);
+#endif
+#ifdef CONFIG_RTW_TX_2PATH_EN
+void rtw_phydm_tx_2path_en(_adapter *adapter);
+#endif
+#ifdef CONFIG_LPS_PG
+void rtw_phydm_lps_pg_hdl(_adapter *adapter, struct sta_info *sta, bool in_lpspg);
+#endif
+#ifdef CONFIG_LPS_PWR_TRACKING
+void rtw_phydm_pwr_tracking_directly(_adapter *adapter);
+#endif
 
 #endif /* __HAL_DM_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.c
index 465bd1a769cf..9b581a6059c6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2014 - 2017 Realtek Corporation.
@@ -79,15 +80,15 @@ void rtw_acs_version_dump(void *sel, _adapter *adapter)
 }
 u8 rtw_phydm_clm_ratio(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
 
-	return phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_CLM_RATIO);
+	return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CLM_RATIO);
 }
 u8 rtw_phydm_nhm_ratio(_adapter *adapter)
 {
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
 
-	return phydm_cmn_info_query(phydm, (enum phydm_info_query_e) PHYDM_INFO_NHM_RATIO);
+	return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_NHM_RATIO);
 }
 void rtw_acs_reset(_adapter *adapter)
 {
@@ -95,44 +96,136 @@ void rtw_acs_reset(_adapter *adapter)
 	struct auto_chan_sel *pacs = &hal_data->acs;
 
 	_rtw_memset(pacs, 0, sizeof(struct auto_chan_sel));
+	#ifdef CONFIG_RTW_ACS_DBG
+	rtw_acs_adv_reset(adapter);
+	#endif /*CONFIG_RTW_ACS_DBG*/
+}
+
+#ifdef CONFIG_RTW_ACS_DBG
+u8 rtw_is_acs_igi_valid(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct auto_chan_sel *pacs = &hal_data->acs;
+
+	if ((pacs->igi) && ((pacs->igi >= 0x1E) || (pacs->igi < 0x60)))
+		return _TRUE;
+
+	return _FALSE;
+}
+void rtw_acs_adv_setting(_adapter *adapter, RT_SCAN_TYPE scan_type, u16 scan_time, u8 igi, u8 bw)
+{
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
+	struct auto_chan_sel *pacs = &hal_data->acs;
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
+
+	pacs->scan_type = scan_type;
+	pacs->scan_time = scan_time;
+	pacs->igi = igi;
+	pacs->bw = bw;
+	RTW_INFO("[ACS] ADV setting - scan_type:%c, ch_ms:%d(ms), igi:0x%02x, bw:%d\n",
+		pacs->scan_type ? 'A' : 'P', pacs->scan_time, pacs->igi, pacs->bw);
 }
+void rtw_acs_adv_reset(_adapter *adapter)
+{
+	rtw_acs_adv_setting(adapter, SCAN_ACTIVE, 0, 0, 0);
+}
+#endif /*CONFIG_RTW_ACS_DBG*/
 
-void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan)
+void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan, enum NHM_PID pid)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
-	u16 sample_times = 0;
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
+#if (RTK_ACS_VERSION == 3)
+	struct clm_para_info clm_para;
+	struct nhm_para_info nhm_para;
+	struct env_trig_rpt trig_rpt;
+
+	scan_time_ms -= 10;
+
+	init_acs_clm(clm_para, scan_time_ms);
+
+	if (pid == NHM_PID_IEEE_11K_HIGH)
+		init_11K_high_nhm(nhm_para, scan_time_ms);
+	else if (pid == NHM_PID_IEEE_11K_LOW)
+		init_11K_low_nhm(nhm_para, scan_time_ms);
+	else
+		init_acs_nhm(nhm_para, scan_time_ms);
+
+	hal_data->acs.trig_rst = phydm_env_mntr_trigger(phydm, &nhm_para, &clm_para, &trig_rpt);
+	if (hal_data->acs.trig_rst == (NHM_SUCCESS | CLM_SUCCESS)) {
+		hal_data->acs.trig_rpt.clm_rpt_stamp = trig_rpt.clm_rpt_stamp;
+		hal_data->acs.trig_rpt.nhm_rpt_stamp = trig_rpt.nhm_rpt_stamp;
+		/*RTW_INFO("[ACS] trigger success (rst = 0x%02x, clm_stamp:%d, nhm_stamp:%d)\n",
+			hal_data->acs.trig_rst, hal_data->acs.trig_rpt.clm_rpt_stamp, hal_data->acs.trig_rpt.nhm_rpt_stamp);*/
+	} else
+		RTW_ERR("[ACS] trigger failed (rst = 0x%02x)\n", hal_data->acs.trig_rst);
+#else
+	phydm_ccx_monitor_trigger(phydm, scan_time_ms);
+#endif
 
 	hal_data->acs.trigger_ch = scan_chan;
-	/*scan_time - ms ,1ms can sample 250 times*/
-	sample_times = scan_time_ms * 250;
-	phydm_ccx_monitor_trigger(phydm, sample_times);
+	hal_data->acs.triggered = _TRUE;
 
 	#ifdef CONFIG_RTW_ACS_DBG
-	RTW_INFO("[ACS] Trigger CH:%d, Times:%d\n", hal_data->acs.trigger_ch, sample_times);
+	RTW_INFO("[ACS] Trigger CH:%d, Times:%d\n", hal_data->acs.trigger_ch, scan_time_ms);
 	#endif
 }
 void rtw_acs_get_rst(_adapter *adapter)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT *phydm = adapter_to_phydm(adapter);
+	struct dm_struct *phydm = adapter_to_phydm(adapter);
 	int chan_idx = -1;
 	u8 cur_chan = hal_data->acs.trigger_ch;
 
 	if (cur_chan == 0)
 		return;
 
+	if (!hal_data->acs.triggered)
+		return;
+
 	chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), cur_chan);
 	if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
 		RTW_ERR("[ACS] %s can't get chan_idx(CH:%d)\n", __func__, cur_chan);
 		return;
 	}
+#if (RTK_ACS_VERSION == 3)
+	if (!(hal_data->acs.trig_rst == (NHM_SUCCESS | CLM_SUCCESS))) {
+		RTW_ERR("[ACS] get_rst return, due to acs trigger failed\n");
+		return;
+	}
 
+	{
+		struct env_mntr_rpt rpt = {0};
+		u8 rst;
+
+		rst = phydm_env_mntr_result(phydm, &rpt);
+		if ((rst == (NHM_SUCCESS | CLM_SUCCESS)) &&
+			(rpt.clm_rpt_stamp == hal_data->acs.trig_rpt.clm_rpt_stamp) &&
+			(rpt.nhm_rpt_stamp == hal_data->acs.trig_rpt.nhm_rpt_stamp)){
+			hal_data->acs.clm_ratio[chan_idx] = rpt.clm_ratio;
+			hal_data->acs.nhm_ratio[chan_idx] = rpt.nhm_ratio;
+			_rtw_memcpy(&hal_data->acs.nhm[chan_idx][0], rpt.nhm_result, NHM_RPT_NUM);
+
+			/*RTW_INFO("[ACS] get_rst success (rst = 0x%02x, clm_stamp:%d:%d, nhm_stamp:%d:%d)\n",
+			rst,
+			hal_data->acs.trig_rpt.clm_rpt_stamp, rpt.clm_rpt_stamp,
+			hal_data->acs.trig_rpt.nhm_rpt_stamp, rpt.nhm_rpt_stamp);*/
+		} else {
+			RTW_ERR("[ACS] get_rst failed (rst = 0x%02x, clm_stamp:%d:%d, nhm_stamp:%d:%d)\n",
+			rst,
+			hal_data->acs.trig_rpt.clm_rpt_stamp, rpt.clm_rpt_stamp,
+			hal_data->acs.trig_rpt.nhm_rpt_stamp, rpt.nhm_rpt_stamp);
+		}
+	}
+
+#else
 	phydm_ccx_monitor_result(phydm);
 
 	hal_data->acs.clm_ratio[chan_idx] = rtw_phydm_clm_ratio(adapter);
 	hal_data->acs.nhm_ratio[chan_idx] = rtw_phydm_nhm_ratio(adapter);
-
+#endif
+	hal_data->acs.triggered = _FALSE;
 	#ifdef CONFIG_RTW_ACS_DBG
 	RTW_INFO("[ACS] Result CH:%d, CLM:%d NHM:%d\n",
 		cur_chan, hal_data->acs.clm_ratio[chan_idx], hal_data->acs.nhm_ratio[chan_idx]);
@@ -191,6 +284,9 @@ void rtw_acs_info_dump(void *sel, _adapter *adapter)
 	_RTW_PRINT_SEL(sel, "Best 5G Channel:%d\n\n", hal_data->acs.best_chan_5g);
 
 	#ifdef CONFIG_RTW_ACS_DBG
+	_RTW_PRINT_SEL(sel, "Advanced setting - scan_type:%c, ch_ms:%d(ms), igi:0x%02x, bw:%d\n",
+		hal_data->acs.scan_type ? 'A' : 'P', hal_data->acs.scan_time, hal_data->acs.igi, hal_data->acs.bw);
+
 	_RTW_PRINT_SEL(sel, "BW  20MHz\n");
 	_RTW_PRINT_SEL(sel, "%5s  %3s  %3s  %3s(%%)  %3s(%%)  %3s\n",
 						"Index", "CH", "BSS", "CLM", "NHM", "ITF");
@@ -373,7 +469,7 @@ void rtw_noise_info_dump(void *sel, _adapter *adapter)
 void rtw_noise_measure(_adapter *adapter, u8 chan, u8 is_pause_dig, u8 igi_value, u32 max_time)
 {
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT *phydm = &hal_data->odmpriv;
+	struct dm_struct *phydm = &hal_data->odmpriv;
 	int chan_idx = -1;
 	s16 noise = 0;
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.h
index 63370a80b53e..c515deed624e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_dm_acs.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -15,7 +16,47 @@
 #ifndef __HAL_DM_ACS_H__
 #define __HAL_DM_ACS_H__
 #ifdef CONFIG_RTW_ACS
-#define RTK_ACS_VERSION	1
+#define RTK_ACS_VERSION	3
+
+#if (RTK_ACS_VERSION == 3)
+enum NHM_PID {
+	NHM_PID_ACS,
+	NHM_PID_IEEE_11K_HIGH,
+	NHM_PID_IEEE_11K_LOW,
+};
+
+#define init_clm_param(clm, app, lv, time) \
+	do {\
+		clm.clm_app = app;\
+		clm.clm_lv = lv;\
+		clm.mntr_time = time;\
+	} while (0)
+
+#define init_nhm_param(nhm, txon, cca, cnt_opt, app, lv, time) \
+	do {\
+		nhm.incld_txon = txon;\
+		nhm.incld_cca = cca;\
+		nhm.div_opt = cnt_opt;\
+		nhm.nhm_app = app;\
+		nhm.nhm_lv = lv;\
+		nhm.mntr_time = time;\
+	} while (0)
+
+	
+#define init_acs_clm(clm, time) \
+	init_clm_param(clm, CLM_ACS, CLM_LV_2, time)
+
+#define init_acs_nhm(nhm, time) \
+	init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, NHM_ACS, NHM_LV_2, time)
+
+#define init_11K_high_nhm(nhm, time) \
+	init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, IEEE_11K_HIGH, NHM_LV_2, time)
+	
+#define init_11K_low_nhm(nhm, time) \
+		init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, IEEE_11K_LOW, NHM_LV_2, time)
+
+
+#endif /*(RTK_ACS_VERSION == 3)*/
 void rtw_acs_version_dump(void *sel, _adapter *adapter);
 extern void phydm_ccx_monitor_trigger(void *p_dm_void, u16 monitor_time);
 extern void phydm_ccx_monitor_result(void *p_dm_void);
@@ -29,29 +70,65 @@ enum ACS_STATE {
 	ACS_ENABLE,
 };
 
+#define ACS_BW_20M	BIT(0)
+#define ACS_BW_40M	BIT(1)
+#define ACS_BW_80M	BIT(2)
+#define ACS_BW_160M	BIT(3)
+
 struct auto_chan_sel {
 	ATOMIC_T state;
 	u8 trigger_ch;
+	bool triggered;
 	u8 clm_ratio[MAX_CHANNEL_NUM];
 	u8 nhm_ratio[MAX_CHANNEL_NUM];
+	#if (RTK_ACS_VERSION == 3)
+	u8 nhm[MAX_CHANNEL_NUM][NHM_RPT_NUM];
+	#endif
 	u8 bss_nums[MAX_CHANNEL_NUM];
 	u8 interference_time[MAX_CHANNEL_NUM];
 	u8 cur_ch_clm_ratio;
 	u8 cur_ch_nhm_ratio;
 	u8 best_chan_5g;
 	u8 best_chan_24g;
+
+	#if (RTK_ACS_VERSION == 3)
+	u8 trig_rst;
+	struct env_trig_rpt	trig_rpt;
+	#endif
+
+	#ifdef CONFIG_RTW_ACS_DBG
+	RT_SCAN_TYPE scan_type;
+	u16 scan_time;
+	u8 igi;
+	u8 bw;
+	#endif
 };
 
 #define rtw_acs_get_best_chan_24g(adapter)		(GET_HAL_DATA(adapter)->acs.best_chan_24g)
 #define rtw_acs_get_best_chan_5g(adapter)		(GET_HAL_DATA(adapter)->acs.best_chan_5g)
 
+#ifdef CONFIG_RTW_ACS_DBG
+#define rtw_is_acs_passiv_scan(adapter)	(((GET_HAL_DATA(adapter)->acs.scan_type) == SCAN_PASSIVE) ? _TRUE : _FALSE)
+
+#define rtw_acs_get_adv_st(adapter)	(GET_HAL_DATA(adapter)->acs.scan_time)
+#define rtw_is_acs_st_valid(adapter)	((GET_HAL_DATA(adapter)->acs.scan_time) ? _TRUE : _FALSE)
+
+#define rtw_acs_get_adv_igi(adapter)	(GET_HAL_DATA(adapter)->acs.igi)
+u8 rtw_is_acs_igi_valid(_adapter *adapter);
+
+#define rtw_acs_get_adv_bw(adapter)	(GET_HAL_DATA(adapter)->acs.bw)
+
+void rtw_acs_adv_setting(_adapter *adapter, RT_SCAN_TYPE scan_type, u16 scan_time, u8 igi, u8 bw);
+void rtw_acs_adv_reset(_adapter *adapter);
+#endif
+
 u8 rtw_acs_get_clm_ratio_by_ch_num(_adapter *adapter, u8 chan);
 u8 rtw_acs_get_clm_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx);
 u8 rtw_acs_get_nhm_ratio_by_ch_num(_adapter *adapter, u8 chan);
 u8 rtw_acs_get_num_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx);
 
 void rtw_acs_reset(_adapter *adapter);
-void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan);
+void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan, enum NHM_PID pid);
 void rtw_acs_get_rst(_adapter *adapter);
 void rtw_acs_select_best_chan(_adapter *adapter);
 void rtw_acs_info_dump(void *sel, _adapter *adapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.c
index 21e2c863ceb6..e20887fee1fc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2015 - 2017 Realtek Corporation.
+ * Copyright(c) 2015 - 2018 Realtek Corporation.
  *
  * 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
@@ -18,10 +19,17 @@
 #include <hal_data.h>		/* efuse, PHAL_DATA_TYPE and etc. */
 #include "hal_halmac.h"		/* dvobj_to_halmac() and ect. */
 
+/*
+ * HALMAC take return value 0 for fail and 1 for success to replace
+ * _FALSE/_TRUE after V1_04_09
+ */
+#define RTW_HALMAC_FAIL			0
+#define RTW_HALMAC_SUCCESS		1
+
 #define DEFAULT_INDICATOR_TIMELMT	1000	/* ms */
 #define MSG_PREFIX			"[HALMAC]"
 
-/*#define RTW_HALMAC_DLFW_MEM_NO_STOP_TX*/
+#define RTW_HALMAC_DLFW_MEM_NO_STOP_TX
 
 /*
  * Driver API for HALMAC operations
@@ -181,19 +189,20 @@ exit:
 static u8 _halmac_sdio_reg_read_n(void *p, u32 offset, u32 size, u8 *data)
 {
 	struct dvobj_priv *d = (struct dvobj_priv *)p;
-	PSDIO_DATA psdio = &d->intf_data;
 	u8 *pbuf;
 	u8 ret;
-	u8 rst = _FALSE;
+	u8 rst = RTW_HALMAC_FAIL;
 	u32 sdio_read_size;
 
 
+	if (!data)
+		return rst;
+
 	sdio_read_size = RND4(size);
-	if (sdio_read_size > psdio->block_transfer_len)
-		sdio_read_size = _RND(sdio_read_size, psdio->block_transfer_len);
+	sdio_read_size = rtw_sdio_cmd53_align_size(d, sdio_read_size);
 
 	pbuf = rtw_zmalloc(sdio_read_size);
-	if ((!pbuf) || (!data))
+	if (!pbuf)
 		return rst;
 
 	ret = rtw_sdio_read_cmd53(d, offset, pbuf, sdio_read_size);
@@ -203,7 +212,7 @@ static u8 _halmac_sdio_reg_read_n(void *p, u32 offset, u32 size, u8 *data)
 	}
 
 	_rtw_memcpy(data, pbuf, size);
-	rst = _TRUE;
+	rst = RTW_HALMAC_SUCCESS;
 exit:
 	rtw_mfree(pbuf, sdio_read_size);
 
@@ -275,6 +284,22 @@ static void _halmac_sdio_reg_write_32(void *p, u32 offset, u32 val)
 	rtw_mfree(pbuf, 4);
 }
 
+static u8 _halmac_sdio_read_cia(void *p, u32 offset)
+{
+	struct dvobj_priv *d;
+	u8 data = 0;
+	u8 ret;
+
+
+	d = (struct dvobj_priv *)p;
+
+	ret = rtw_sdio_f0_read(d, offset, &data, 1);
+	if (ret == _FAIL)
+		RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
+
+	return data;
+}
+
 #else /* !CONFIG_SDIO_HCI */
 
 static u8 _halmac_reg_read_8(void *p, u32 offset)
@@ -362,7 +387,7 @@ static void _halmac_reg_write_32(void *p, u32 offset, u32 val)
 static u8 _halmac_mfree(void *p, void *buffer, u32 size)
 {
 	rtw_mfree(buffer, size);
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
 static void *_halmac_malloc(void *p, u32 size)
@@ -373,30 +398,36 @@ static void *_halmac_malloc(void *p, u32 size)
 static u8 _halmac_memcpy(void *p, void *dest, void *src, u32 size)
 {
 	_rtw_memcpy(dest, src, size);
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
 static u8 _halmac_memset(void *p, void *addr, u8 value, u32 size)
 {
 	_rtw_memset(addr, value, size);
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
 static void _halmac_udelay(void *p, u32 us)
 {
-	rtw_udelay_os(us);
+	/* Most hardware polling wait time < 50us) */
+	if (us <= 50)
+		rtw_udelay_os(us);
+	else if (us <= 1000)
+		rtw_usleep_os(us);
+	else
+		rtw_msleep_os(RTW_DIV_ROUND_UP(us, 1000));
 }
 
 static u8 _halmac_mutex_init(void *p, HALMAC_MUTEX *pMutex)
 {
 	_rtw_mutex_init(pMutex);
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
 static u8 _halmac_mutex_deinit(void *p, HALMAC_MUTEX *pMutex)
 {
 	_rtw_mutex_free(pMutex);
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
 static u8 _halmac_mutex_lock(void *p, HALMAC_MUTEX *pMutex)
@@ -405,25 +436,69 @@ static u8 _halmac_mutex_lock(void *p, HALMAC_MUTEX *pMutex)
 
 	err = _enter_critical_mutex(pMutex, NULL);
 	if (err)
-		return _FALSE;
+		return RTW_HALMAC_FAIL;
 
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
 static u8 _halmac_mutex_unlock(void *p, HALMAC_MUTEX *pMutex)
 {
 	_exit_critical_mutex(pMutex, NULL);
+	return RTW_HALMAC_SUCCESS;
+}
+
+#ifndef CONFIG_SDIO_HCI
+#define DBG_MSG_FILTER
+#endif
+
+#ifdef DBG_MSG_FILTER
+static u8 is_msg_allowed(uint drv_lv, u8 msg_lv)
+{
+	switch (drv_lv) {
+	case _DRV_NONE_:
+		return _FALSE;
+
+	case _DRV_ALWAYS_:
+		if (msg_lv > HALMAC_DBG_ALWAYS)
+			return _FALSE;
+		break;
+	case _DRV_ERR_:
+		if (msg_lv > HALMAC_DBG_ERR)
+			return _FALSE;
+		break;
+	case _DRV_WARNING_:
+		if (msg_lv > HALMAC_DBG_WARN)
+			return _FALSE;
+		break;
+	case _DRV_INFO_:
+		if (msg_lv >= HALMAC_DBG_TRACE)
+			return _FALSE;
+		break;
+	}
+
 	return _TRUE;
 }
+#endif /* DBG_MSG_FILTER */
 
 static u8 _halmac_msg_print(void *p, u32 msg_type, u8 msg_level, s8 *fmt, ...)
 {
 #define MSG_LEN		100
 	va_list args;
 	u8 str[MSG_LEN] = {0};
+#ifdef DBG_MSG_FILTER
+	uint drv_level = _DRV_NONE_;
+#endif
 	int err;
-	u8 ret = _TRUE;
+	u8 ret = RTW_HALMAC_SUCCESS;
+
 
+#ifdef DBG_MSG_FILTER
+#ifdef CONFIG_RTW_DEBUG
+	drv_level = rtw_drv_log_level;
+#endif
+	if (is_msg_allowed(drv_level, msg_level) == _FALSE)
+		return ret;
+#endif
 
 	str[0] = '\n';
 	va_start(args, fmt);
@@ -432,10 +507,10 @@ static u8 _halmac_msg_print(void *p, u32 msg_type, u8 msg_level, s8 *fmt, ...)
 
 	/* An output error is encountered */
 	if (err < 0)
-		return _FALSE;
+		return RTW_HALMAC_FAIL;
 	/* Output may be truncated due to size limit */
 	if ((err == (MSG_LEN - 1)) && (str[MSG_LEN - 2] != '\n'))
-		ret = _FALSE;
+		ret = RTW_HALMAC_FAIL;
 
 	if (msg_level == HALMAC_DBG_ALWAYS)
 		RTW_PRINT(MSG_PREFIX "%s", str);
@@ -456,7 +531,7 @@ static u8 _halmac_buff_print(void *p, u32 msg_type, u8 msg_level, s8 *buf, u32 s
 	else
 		RTW_DBG_DUMP(MSG_PREFIX, buf, size);
 
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
 
@@ -471,10 +546,11 @@ const char *const RTW_HALMAC_FEATURE_NAME[] = {
 	"HALMAC_FEATURE_IQK",
 	"HALMAC_FEATURE_POWER_TRACKING",
 	"HALMAC_FEATURE_PSD",
+	"HALMAC_FEATURE_FW_SNDING",
 	"HALMAC_FEATURE_ALL"
 };
 
-static inline u8 is_valid_id_status(HALMAC_FEATURE_ID id, HALMAC_CMD_PROCESS_STATUS status)
+static inline u8 is_valid_id_status(enum halmac_feature_id id, enum halmac_cmd_process_status status)
 {
 	switch (id) {
 	case HALMAC_FEATURE_CFG_PARA:
@@ -494,6 +570,9 @@ static inline u8 is_valid_id_status(HALMAC_FEATURE_ID id, HALMAC_CMD_PROCESS_STA
 		break;
 	case HALMAC_FEATURE_UPDATE_PACKET:
 		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		if (status != HALMAC_CMD_PROCESS_DONE)
+			RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
+				 __FUNCTION__, id, status);
 		break;
 	case HALMAC_FEATURE_UPDATE_DATAPACK:
 		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
@@ -503,6 +582,11 @@ static inline u8 is_valid_id_status(HALMAC_FEATURE_ID id, HALMAC_CMD_PROCESS_STA
 		break;
 	case HALMAC_FEATURE_CHANNEL_SWITCH:
 		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		if ((status != HALMAC_CMD_PROCESS_DONE) && (status != HALMAC_CMD_PROCESS_RCVD))
+			RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
+				 __FUNCTION__, id, status);
+		if (status == HALMAC_CMD_PROCESS_DONE)
+			return _FALSE;
 		break;
 	case HALMAC_FEATURE_IQK:
 		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
@@ -513,6 +597,9 @@ static inline u8 is_valid_id_status(HALMAC_FEATURE_ID id, HALMAC_CMD_PROCESS_STA
 	case HALMAC_FEATURE_PSD:
 		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
 		break;
+	case HALMAC_FEATURE_FW_SNDING:
+		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
+		break;
 	case HALMAC_FEATURE_ALL:
 		RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
 		break;
@@ -524,7 +611,7 @@ static inline u8 is_valid_id_status(HALMAC_FEATURE_ID id, HALMAC_CMD_PROCESS_STA
 	return _TRUE;
 }
 
-static int init_halmac_event_with_waittime(struct dvobj_priv *d, HALMAC_FEATURE_ID id, u8 *buf, u32 size, u32 time)
+static int init_halmac_event_with_waittime(struct dvobj_priv *d, enum halmac_feature_id id, u8 *buf, u32 size, u32 time)
 {
 	struct submit_ctx *sctx;
 
@@ -550,12 +637,12 @@ static int init_halmac_event_with_waittime(struct dvobj_priv *d, HALMAC_FEATURE_
 	return 0;
 }
 
-static inline int init_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id, u8 *buf, u32 size)
+static inline int init_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id, u8 *buf, u32 size)
 {
 	return init_halmac_event_with_waittime(d, id, buf, size, DEFAULT_INDICATOR_TIMELMT);
 }
 
-static void free_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id)
+static void free_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id)
 {
 	struct submit_ctx *sctx;
 
@@ -568,10 +655,10 @@ static void free_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id)
 	rtw_mfree((u8 *)sctx, sizeof(*sctx));
 }
 
-static int wait_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id)
+static int wait_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 	struct submit_ctx *sctx;
 	int ret;
 
@@ -597,9 +684,9 @@ static int wait_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id)
 
 /*
  * Return:
- *	Always return _TRUE, HALMAC don't care the return value.
+ *	Always return RTW_HALMAC_SUCCESS, HALMAC don't care the return value.
  */
-static u8 _halmac_event_indication(void *p, HALMAC_FEATURE_ID feature_id, HALMAC_CMD_PROCESS_STATUS process_status, u8 *buf, u32 size)
+static u8 _halmac_event_indication(void *p, enum halmac_feature_id feature_id, enum halmac_cmd_process_status process_status, u8 *buf, u32 size)
 {
 	struct dvobj_priv *d;
 	PADAPTER adapter;
@@ -648,10 +735,10 @@ static u8 _halmac_event_indication(void *p, HALMAC_FEATURE_ID feature_id, HALMAC
 	rtw_sctx_done(&sctx);
 
 exit:
-	return _TRUE;
+	return RTW_HALMAC_SUCCESS;
 }
 
-HALMAC_PLATFORM_API rtw_halmac_platform_api = {
+struct halmac_platform_api rtw_halmac_platform_api = {
 	/* R/W register */
 #ifdef CONFIG_SDIO_HCI
 	.SDIO_CMD52_READ = _halmac_sdio_cmd52_read,
@@ -663,16 +750,16 @@ HALMAC_PLATFORM_API rtw_halmac_platform_api = {
 	.SDIO_CMD53_WRITE_8 = _halmac_sdio_reg_write_8,
 	.SDIO_CMD53_WRITE_16 = _halmac_sdio_reg_write_16,
 	.SDIO_CMD53_WRITE_32 = _halmac_sdio_reg_write_32,
-
+	.SDIO_CMD52_CIA_READ = _halmac_sdio_read_cia,
 #endif /* CONFIG_SDIO_HCI */
-#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCIE_HCI)
+#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
 	.REG_READ_8 = _halmac_reg_read_8,
 	.REG_READ_16 = _halmac_reg_read_16,
 	.REG_READ_32 = _halmac_reg_read_32,
 	.REG_WRITE_8 = _halmac_reg_write_8,
 	.REG_WRITE_16 = _halmac_reg_write_16,
 	.REG_WRITE_32 = _halmac_reg_write_32,
-#endif /* CONFIG_USB_HCI || CONFIG_PCIE_HCI */
+#endif /* CONFIG_USB_HCI || CONFIG_PCI_HCI */
 
 	/* Write data */
 #if 0
@@ -702,8 +789,8 @@ HALMAC_PLATFORM_API rtw_halmac_platform_api = {
 
 u8 rtw_halmac_read8(struct intf_hdl *pintfhdl, u32 addr)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 
 
 	/* WARNING: pintf_dev should not be null! */
@@ -715,8 +802,8 @@ u8 rtw_halmac_read8(struct intf_hdl *pintfhdl, u32 addr)
 
 u16 rtw_halmac_read16(struct intf_hdl *pintfhdl, u32 addr)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 
 
 	/* WARNING: pintf_dev should not be null! */
@@ -728,8 +815,8 @@ u16 rtw_halmac_read16(struct intf_hdl *pintfhdl, u32 addr)
 
 u32 rtw_halmac_read32(struct intf_hdl *pintfhdl, u32 addr)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 
 
 	/* WARNING: pintf_dev should not be null! */
@@ -800,9 +887,9 @@ static void _read_register(struct dvobj_priv *d, u32 addr, u32 cnt, u8 *buf)
 #ifdef CONFIG_SDIO_HCI
 static int _sdio_read_local(struct dvobj_priv *d, u32 addr, u32 cnt, u8 *buf)
 {
-	struct _HALMAC_ADAPTER *mac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	if (buf == NULL)
@@ -850,8 +937,8 @@ void rtw_halmac_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem)
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
 u8 rtw_halmac_iread8(struct intf_hdl *pintfhdl, u32 addr)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 
 	/* WARNING: pintf_dev should not be null! */
 	mac = dvobj_to_halmac(pintfhdl->pintf_dev);
@@ -863,8 +950,8 @@ u8 rtw_halmac_iread8(struct intf_hdl *pintfhdl, u32 addr)
 
 u16 rtw_halmac_iread16(struct intf_hdl *pintfhdl, u32 addr)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 	u16 val16 = 0;
 
 	/* WARNING: pintf_dev should not be null! */
@@ -877,8 +964,8 @@ u16 rtw_halmac_iread16(struct intf_hdl *pintfhdl, u32 addr)
 
 u32 rtw_halmac_iread32(struct intf_hdl *pintfhdl, u32 addr)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 
 
 	/* WARNING: pintf_dev should not be null! */
@@ -891,9 +978,9 @@ u32 rtw_halmac_iread32(struct intf_hdl *pintfhdl, u32 addr)
 
 int rtw_halmac_write8(struct intf_hdl *pintfhdl, u32 addr, u8 value)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	/* WARNING: pintf_dev should not be null! */
@@ -910,9 +997,9 @@ int rtw_halmac_write8(struct intf_hdl *pintfhdl, u32 addr, u8 value)
 
 int rtw_halmac_write16(struct intf_hdl *pintfhdl, u32 addr, u16 value)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	/* WARNING: pintf_dev should not be null! */
@@ -929,9 +1016,9 @@ int rtw_halmac_write16(struct intf_hdl *pintfhdl, u32 addr, u16 value)
 
 int rtw_halmac_write32(struct intf_hdl *pintfhdl, u32 addr, u32 value)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	/* WARNING: pintf_dev should not be null! */
@@ -948,18 +1035,18 @@ int rtw_halmac_write32(struct intf_hdl *pintfhdl, u32 addr, u32 value)
 
 static int init_write_rsvd_page_size(struct dvobj_priv *d)
 {
-	struct _HALMAC_ADAPTER *mac;
-	struct _HALMAC_API *api;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
 	u32 size = 0;
-	struct _HALMAC_OFLD_FUNC_INFO ofld_info;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_ofld_func_info ofld_info;
+	enum halmac_ret_status status;
 	int err = 0;
 
 
 #ifdef CONFIG_USB_HCI
 	/* for USB do not exceed MAX_CMDBUF_SZ */
 	size = 0x1000;
-#elif defined(CONFIG_PCIE_HCI)
+#elif defined(CONFIG_PCI_HCI)
 	size = MAX_CMDBUF_SZ - TXDESC_OFFSET;
 #elif defined(CONFIG_SDIO_HCI)
 	size = 0x7000; /* 28KB */
@@ -1042,10 +1129,10 @@ static void deinit_priv(struct halmacpriv *priv)
 }
 
 #ifdef CONFIG_SDIO_HCI
-static enum _HALMAC_SDIO_SPEC_VER _sdio_ver_drv2halmac(struct dvobj_priv *d)
+static enum halmac_sdio_spec_ver _sdio_ver_drv2halmac(struct dvobj_priv *d)
 {
 	bool v3;
-	enum _HALMAC_SDIO_SPEC_VER ver;
+	enum halmac_sdio_spec_ver ver;
 
 
 	v3 = rtw_is_sdio30(dvobj_get_primary_adapter(d));
@@ -1060,8 +1147,8 @@ static enum _HALMAC_SDIO_SPEC_VER _sdio_ver_drv2halmac(struct dvobj_priv *d)
 
 void rtw_halmac_get_version(char *str, u32 len)
 {
-	HALMAC_RET_STATUS status;
-	HALMAC_VER ver;
+	enum halmac_ret_status status;
+	struct halmac_ver ver;
 
 
 	status = halmac_get_version(&ver);
@@ -1072,33 +1159,33 @@ void rtw_halmac_get_version(char *str, u32 len)
 		    ver.major_ver, ver.prototype_ver, ver.minor_ver);
 }
 
-int rtw_halmac_init_adapter(struct dvobj_priv *d, PHALMAC_PLATFORM_API pf_api)
+int rtw_halmac_init_adapter(struct dvobj_priv *d, struct halmac_platform_api *pf_api)
 {
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_INTERFACE intf;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_interface intf;
+	enum halmac_ret_status status;
 	int err = 0;
 #ifdef CONFIG_SDIO_HCI
-	HALMAC_SDIO_HW_INFO info;
+	struct halmac_sdio_hw_info info;
 #endif /* CONFIG_SDIO_HCI */
 
 
 	halmac = dvobj_to_halmac(d);
 	if (halmac) {
-		err = 0;
-		goto out;
+		RTW_WARN("%s: initialize already completed!\n", __FUNCTION__);
+		goto error;
 	}
 
 	err = init_priv(&d->hmpriv);
 	if (err)
-		goto out;
+		goto error;
 
 #ifdef CONFIG_SDIO_HCI
 	intf = HALMAC_INTERFACE_SDIO;
 #elif defined(CONFIG_USB_HCI)
 	intf = HALMAC_INTERFACE_USB;
-#elif defined(CONFIG_PCIE_HCI)
+#elif defined(CONFIG_PCI_HCI)
 	intf = HALMAC_INTERFACE_PCIE;
 #else
 #warning "INTERFACE(CONFIG_XXX_HCI) not be defined!!"
@@ -1108,7 +1195,9 @@ int rtw_halmac_init_adapter(struct dvobj_priv *d, PHALMAC_PLATFORM_API pf_api)
 	if (HALMAC_RET_SUCCESS != status) {
 		RTW_ERR("%s: halmac_init_adapter fail!(status=%d)\n", __FUNCTION__, status);
 		err = -1;
-		goto out;
+		if (halmac)
+			goto deinit;
+		goto free;
 	}
 
 	dvobj_set_halmac(d, halmac);
@@ -1117,96 +1206,103 @@ int rtw_halmac_init_adapter(struct dvobj_priv *d, PHALMAC_PLATFORM_API pf_api)
 	if (status != HALMAC_RET_SUCCESS) {
 		RTW_ERR("%s: halmac_interface_integration_tuning fail!(status=%d)\n", __FUNCTION__, status);
 		err = -1;
-		goto out;
+		goto deinit;
 	}
 
 	status = api->halmac_phy_cfg(halmac, HALMAC_INTF_PHY_PLATFORM_ALL);
 	if (status != HALMAC_RET_SUCCESS) {
 		RTW_ERR("%s: halmac_phy_cfg fail!(status=%d)\n", __FUNCTION__, status);
 		err = -1;
-		goto out;
+		goto deinit;
 	}
 
 	init_write_rsvd_page_size(d);
 
 #ifdef CONFIG_SDIO_HCI
+	_rtw_memset(&info, 0, sizeof(info));
 	info.spec_ver = _sdio_ver_drv2halmac(d);
-	/* clock unit is MHz */
+	/* Convert clock speed unit to MHz from Hz */
 	info.clock_speed = RTW_DIV_ROUND_UP(rtw_sdio_get_clock(d), 1000000);
-	RTW_DBG("%s: SDIO clock=%uMHz ver=%u\n", __FUNCTION__, info.clock_speed, info.spec_ver+2);
+	info.block_size = rtw_sdio_get_block_size(d);
+	RTW_DBG("%s: SDIO ver=%u clock=%uMHz blk_size=%u bytes\n",
+		__FUNCTION__, info.spec_ver+2, info.clock_speed,
+		info.block_size);
 	status = api->halmac_sdio_hw_info(halmac, &info);
 	if (status != HALMAC_RET_SUCCESS) {
-		RTW_ERR("%s: halmac_sdio_hw_info fail!(status=%d)\n", __FUNCTION__, status);
+		RTW_ERR("%s: halmac_sdio_hw_info fail!(status=%d)\n",
+			__FUNCTION__, status);
 		err = -1;
-		goto out;
+		goto deinit;
 	}
 #endif /* CONFIG_SDIO_HCI */
 
-out:
-	if (err)
-		rtw_halmac_deinit_adapter(d);
+	return 0;
+
+deinit:
+	status = halmac_deinit_adapter(halmac);
+	dvobj_set_halmac(d, NULL);
+	if (status != HALMAC_RET_SUCCESS)
+		RTW_ERR("%s: halmac_deinit_adapter fail!(status=%d)\n",
+			__FUNCTION__, status);
 
+free:
+	deinit_priv(&d->hmpriv);
+
+error:
 	return err;
 }
 
 int rtw_halmac_deinit_adapter(struct dvobj_priv *d)
 {
-	PHALMAC_ADAPTER halmac;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	enum halmac_ret_status status;
 	int err = 0;
 
 
 	halmac = dvobj_to_halmac(d);
-	if (!halmac) {
-		err = 0;
-		goto out;
+	if (halmac) {
+		status = halmac_deinit_adapter(halmac);
+		dvobj_set_halmac(d, NULL);
+		if (status != HALMAC_RET_SUCCESS)
+			err = -1;
 	}
 
 	deinit_priv(&d->hmpriv);
 
-	status = halmac_deinit_adapter(halmac);
-	dvobj_set_halmac(d, NULL);
-	if (status != HALMAC_RET_SUCCESS) {
-		err = -1;
-		goto out;
-	}
-
-out:
 	return err;
 }
 
-static inline u8 _hw_port_drv2halmac(enum _hw_port hwport)
+static inline enum halmac_portid _hw_port_drv2halmac(enum _hw_port hwport)
 {
-	u8 port = 0;
+	enum halmac_portid port = HALMAC_PORTID_NUM;
 
 
 	switch (hwport) {
 	case HW_PORT0:
-		port = 0;
+		port = HALMAC_PORTID0;
 		break;
 	case HW_PORT1:
-		port = 1;
+		port = HALMAC_PORTID1;
 		break;
 	case HW_PORT2:
-		port = 2;
+		port = HALMAC_PORTID2;
 		break;
 	case HW_PORT3:
-		port = 3;
+		port = HALMAC_PORTID3;
 		break;
 	case HW_PORT4:
-		port = 4;
+		port = HALMAC_PORTID4;
 		break;
 	default:
-		port = hwport;
 		break;
 	}
 
 	return port;
 }
 
-static enum _HALMAC_NETWORK_TYPE_SELECT _network_type_drv2halmac(u8 type)
+static enum halmac_network_type_select _network_type_drv2halmac(u8 type)
 {
-	enum _HALMAC_NETWORK_TYPE_SELECT network = HALMAC_NETWORK_UNDEFINE;
+	enum halmac_network_type_select network = HALMAC_NETWORK_UNDEFINE;
 
 
 	switch (type) {
@@ -1231,7 +1327,7 @@ static enum _HALMAC_NETWORK_TYPE_SELECT _network_type_drv2halmac(u8 type)
 	return network;
 }
 
-static u8 _network_type_halmac2drv(enum _HALMAC_NETWORK_TYPE_SELECT network)
+static u8 _network_type_halmac2drv(enum halmac_network_type_select network)
 {
 	u8 type = _HW_STATE_NOLINK_;
 
@@ -1258,35 +1354,35 @@ static u8 _network_type_halmac2drv(enum _HALMAC_NETWORK_TYPE_SELECT network)
 	return type;
 }
 
-static void _beacon_ctrl_halmac2drv(struct HALMAC_BCN_CTRL *ctrl,
+static void _beacon_ctrl_halmac2drv(struct halmac_bcn_ctrl *ctrl,
 				struct rtw_halmac_bcn_ctrl *drv_ctrl)
 {
 	drv_ctrl->rx_bssid_fit = ctrl->dis_rx_bssid_fit ? 0 : 1;
 	drv_ctrl->txbcn_rpt = ctrl->en_txbcn_rpt ? 1 : 0;
 	drv_ctrl->tsf_update = ctrl->dis_tsf_udt ? 0 : 1;
 	drv_ctrl->enable_bcn = ctrl->en_bcn ? 1 : 0;
-	drv_ctrl->rxbcn_rpt = ctrl->ex_rxbcn_rpt ? 1 : 0;
+	drv_ctrl->rxbcn_rpt = ctrl->en_rxbcn_rpt ? 1 : 0;
 	drv_ctrl->p2p_ctwin = ctrl->en_p2p_ctwin ? 1 : 0;
 	drv_ctrl->p2p_bcn_area = ctrl->en_p2p_bcn_area ? 1 : 0;
 }
 
 static void _beacon_ctrl_drv2halmac(struct rtw_halmac_bcn_ctrl *drv_ctrl,
-				struct HALMAC_BCN_CTRL *ctrl)
+				struct halmac_bcn_ctrl *ctrl)
 {
 	ctrl->dis_rx_bssid_fit = drv_ctrl->rx_bssid_fit ? 0 : 1;
 	ctrl->en_txbcn_rpt = drv_ctrl->txbcn_rpt ? 1 : 0;
 	ctrl->dis_tsf_udt = drv_ctrl->tsf_update ? 0 : 1;
 	ctrl->en_bcn = drv_ctrl->enable_bcn ? 1 : 0;
-	ctrl->ex_rxbcn_rpt = drv_ctrl->rxbcn_rpt ? 1 : 0;
+	ctrl->en_rxbcn_rpt = drv_ctrl->rxbcn_rpt ? 1 : 0;
 	ctrl->en_p2p_ctwin = drv_ctrl->p2p_ctwin ? 1 : 0;
 	ctrl->en_p2p_bcn_area = drv_ctrl->p2p_bcn_area ? 1 : 0;
 }
 
-int rtw_halmac_get_hw_value(struct dvobj_priv *d, HALMAC_HW_ID hw_id, VOID *pvalue)
+int rtw_halmac_get_hw_value(struct dvobj_priv *d, enum halmac_hw_id hw_id, void *pvalue)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	mac = dvobj_to_halmac(d);
@@ -1310,9 +1406,9 @@ int rtw_halmac_get_hw_value(struct dvobj_priv *d, HALMAC_HW_ID hw_id, VOID *pval
  */
 int rtw_halmac_get_tx_fifo_size(struct dvobj_priv *d, u32 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val = 0;
 
 
@@ -1339,9 +1435,9 @@ int rtw_halmac_get_tx_fifo_size(struct dvobj_priv *d, u32 *size)
  */
 int rtw_halmac_get_rx_fifo_size(struct dvobj_priv *d, u32 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val = 0;
 
 
@@ -1368,9 +1464,9 @@ int rtw_halmac_get_rx_fifo_size(struct dvobj_priv *d, u32 *size)
  */
 int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *d, u16 *bndy)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u16 val = 0;
 
 
@@ -1397,9 +1493,9 @@ int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *d, u16 *bndy)
  */
 int rtw_halmac_get_page_size(struct dvobj_priv *d, u32 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val = 0;
 
 
@@ -1426,9 +1522,9 @@ int rtw_halmac_get_page_size(struct dvobj_priv *d, u32 *size)
  */
 int rtw_halmac_get_tx_agg_align_size(struct dvobj_priv *d, u16 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u16 val = 0;
 
 
@@ -1455,9 +1551,9 @@ int rtw_halmac_get_tx_agg_align_size(struct dvobj_priv *d, u16 *size)
  */
 int rtw_halmac_get_rx_agg_align_size(struct dvobj_priv *d, u8 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u8 val = 0;
 
 
@@ -1499,9 +1595,9 @@ int rtw_halmac_get_rx_agg_align_size(struct dvobj_priv *d, u8 *size)
  */
 int rtw_halmac_get_rx_drv_info_sz(struct dvobj_priv *d, u8 *sz)
 {
-	HALMAC_RET_STATUS status;
-	PHALMAC_ADAPTER halmac = dvobj_to_halmac(d);
-	PHALMAC_API api = HALMAC_GET_API(halmac);
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac = dvobj_to_halmac(d);
+	struct halmac_api *api = HALMAC_GET_API(halmac);
 	u8 dw = 0;
 
 	status = api->halmac_get_hw_value(halmac, HALMAC_HW_DRV_INFO_SIZE, &dw);
@@ -1523,9 +1619,9 @@ int rtw_halmac_get_rx_drv_info_sz(struct dvobj_priv *d, u8 *sz)
  */
 int rtw_halmac_get_tx_desc_size(struct dvobj_priv *d, u32 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val = 0;
 
 
@@ -1552,9 +1648,9 @@ int rtw_halmac_get_tx_desc_size(struct dvobj_priv *d, u32 *size)
  */
 int rtw_halmac_get_rx_desc_size(struct dvobj_priv *d, u32 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val = 0;
 
 
@@ -1582,9 +1678,9 @@ int rtw_halmac_get_rx_desc_size(struct dvobj_priv *d, u32 *size)
  */
 static int rtw_halmac_get_fw_max_size(struct dvobj_priv *d, u32 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val = 0;
 
 
@@ -1611,9 +1707,9 @@ static int rtw_halmac_get_fw_max_size(struct dvobj_priv *d, u32 *size)
  */
 int rtw_halmac_get_ori_h2c_size(struct dvobj_priv *d, u32 *size)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val = 0;
 
 
@@ -1631,9 +1727,9 @@ int rtw_halmac_get_ori_h2c_size(struct dvobj_priv *d, u32 *size)
 
 int rtw_halmac_get_oqt_size(struct dvobj_priv *d, u8 *size)
 {
-	enum _HALMAC_RET_STATUS status;
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
 	u8 val;
 
 
@@ -1653,9 +1749,9 @@ int rtw_halmac_get_oqt_size(struct dvobj_priv *d, u8 *size)
 
 int rtw_halmac_get_ac_queue_number(struct dvobj_priv *d, u8 *num)
 {
-	enum _HALMAC_RET_STATUS status;
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
 	u8 val;
 
 
@@ -1685,65 +1781,27 @@ int rtw_halmac_get_ac_queue_number(struct dvobj_priv *d, u8 *num)
  */
 int rtw_halmac_get_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
 {
-#if 0
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-#endif
-	u8 port;
-	union _HALMAC_WLAN_ADDR hwa;
-#if 0
-	enum _HALMAC_RET_STATUS status;
-#endif
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
 	if (!addr)
 		goto out;
-#if 0
+
 	halmac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(halmac);
-#endif
 	port = _hw_port_drv2halmac(hwport);
-
 	_rtw_memset(&hwa, 0, sizeof(hwa));
 
-#if 0
 	status = api->halmac_get_mac_addr(halmac, port, &hwa);
 	if (status != HALMAC_RET_SUCCESS)
 		goto out;
-#else
-	{
-	u32 offset;
-
-	switch (port) {
-	case 0:
-		offset = REG_MACID;
-		break;
-
-	case 1:
-		offset = REG_MACID1;
-		break;
-
-	case 2:
-		offset = REG_MACID2;
-		break;
-
-	case 3:
-		offset = REG_MACID3;
-		break;
-
-	case 4:
-		offset = REG_MACID4;
-		break;
-
-	default:
-		goto out;
-	}
 
-	_read_register(d, offset, 6, hwa.Address);
-	}
-#endif
-	_rtw_memcpy(addr, hwa.Address, 6);
+	_rtw_memcpy(addr, hwa.addr, 6);
 
 	err = 0;
 out:
@@ -1763,11 +1821,11 @@ out:
 int rtw_halmac_get_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 *type)
 {
 #if 0
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	enum _HALMAC_NETWORK_TYPE_SELECT network;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_network_type_select network;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -1787,8 +1845,8 @@ out:
 	return err;
 #else
 	struct _ADAPTER *a;
-	u8 port;
-	enum _HALMAC_NETWORK_TYPE_SELECT network;
+	enum halmac_portid port;
+	enum halmac_network_type_select network;
 	u32 val;
 	int err = -1;
 
@@ -1798,27 +1856,27 @@ out:
 	network = HALMAC_NETWORK_UNDEFINE;
 
 	switch (port) {
-	case 0:
+	case HALMAC_PORTID0:
 		val = rtw_read32(a, REG_CR);
 		network = BIT_GET_NETYPE0(val);
 		break;
 
-	case 1:
+	case HALMAC_PORTID1:
 		val = rtw_read32(a, REG_CR);
 		network = BIT_GET_NETYPE1(val);
 		break;
 
-	case 2:
+	case HALMAC_PORTID2:
 		val = rtw_read32(a, REG_CR_EXT);
 		network = BIT_GET_NETYPE2(val);
 		break;
 
-	case 3:
+	case HALMAC_PORTID3:
 		val = rtw_read32(a, REG_CR_EXT);
 		network = BIT_GET_NETYPE3(val);
 		break;
 
-	case 4:
+	case HALMAC_PORTID4:
 		val = rtw_read32(a, REG_CR_EXT);
 		network = BIT_GET_NETYPE4(val);
 		break;
@@ -1848,18 +1906,18 @@ out:
 int rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
 			struct rtw_halmac_bcn_ctrl *bcn_ctrl)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	struct HALMAC_BCN_CTRL ctrl;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	struct halmac_bcn_ctrl ctrl;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
 	halmac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(halmac);
 	port = _hw_port_drv2halmac(hwport);
-	_rtw_memset(&ctrl, 0, sizeof(struct HALMAC_BCN_CTRL));
+	_rtw_memset(&ctrl, 0, sizeof(ctrl));
 
 	status = api->halmac_rw_bcn_ctrl(halmac, port, 0, &ctrl);
 	if (status != HALMAC_RET_SUCCESS)
@@ -1875,11 +1933,11 @@ out:
  * Note:
  *	When this function return, the register REG_RCR may be changed.
  */
-int rtw_halmac_config_rx_info(struct dvobj_priv *d, HALMAC_DRV_INFO info)
+int rtw_halmac_config_rx_info(struct dvobj_priv *d, enum halmac_drv_info info)
 {
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -1912,9 +1970,9 @@ out:
  */
 int rtw_halmac_set_max_dl_fw_size(struct dvobj_priv *d, u32 size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	if (!size || (size == 1))
@@ -1950,11 +2008,11 @@ int rtw_halmac_set_max_dl_fw_size(struct dvobj_priv *d, u32 size)
  */
 int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
 {
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	u8 port;
-	HALMAC_WLAN_ADDR hwa;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -1963,7 +2021,7 @@ int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *a
 
 	port = _hw_port_drv2halmac(hwport);
 	_rtw_memset(&hwa, 0, sizeof(hwa));
-	_rtw_memcpy(hwa.Address, addr, 6);
+	_rtw_memcpy(hwa.addr, addr, 6);
 
 	status = api->halmac_cfg_mac_addr(halmac, port, &hwa);
 	if (status != HALMAC_RET_SUCCESS)
@@ -1986,19 +2044,20 @@ out:
  */
 int rtw_halmac_set_bssid(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
 {
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	u8 port;
-	HALMAC_WLAN_ADDR hwa;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
 	int err = -1;
 
+
 	halmac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(halmac);
 	port = _hw_port_drv2halmac(hwport);
 
-	_rtw_memset(&hwa, 0, sizeof(HALMAC_WLAN_ADDR));
-	_rtw_memcpy(hwa.Address, addr, 6);
+	_rtw_memset(&hwa, 0, sizeof(hwa));
+	_rtw_memcpy(hwa.addr, addr, 6);
 	status = api->halmac_cfg_bssid(halmac, port, &hwa);
 	if (status != HALMAC_RET_SUCCESS)
 		goto out;
@@ -2020,19 +2079,19 @@ out:
  */
 int rtw_halmac_set_tx_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	union _HALMAC_WLAN_ADDR hwa;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	union halmac_wlan_addr hwa;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
 	halmac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(halmac);
 	port = _hw_port_drv2halmac(hwport);
-	_rtw_memset(&hwa, 0, sizeof(union _HALMAC_WLAN_ADDR));
-	_rtw_memcpy(hwa.Address, addr, 6);
+	_rtw_memset(&hwa, 0, sizeof(hwa));
+	_rtw_memcpy(hwa.addr, addr, 6);
 
 	status = api->halmac_cfg_transmitter_addr(halmac, port, &hwa);
 	if (status != HALMAC_RET_SUCCESS)
@@ -2055,12 +2114,11 @@ out:
  */
 int rtw_halmac_set_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 type)
 {
-#if 0 /* Fail to set AP mode for port0 */
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	enum _HALMAC_NETWORK_TYPE_SELECT network;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_network_type_select network;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -2076,61 +2134,6 @@ int rtw_halmac_set_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 t
 	err = 0;
 out:
 	return err;
-#else
-	struct _ADAPTER *a;
-	u8 port;
-	enum _HALMAC_NETWORK_TYPE_SELECT network;
-	u32 val;
-	int err = -1;
-
-
-	a = dvobj_get_primary_adapter(d);
-	port = _hw_port_drv2halmac(hwport);
-	network = _network_type_drv2halmac(type);
-
-	if ((port > 0) && (network == HALMAC_NETWORK_AP))
-		goto out;
-
-	switch (port) {
-	case 0:
-		val = rtw_read32(a, REG_CR);
-		val = BIT_SET_NETYPE0(val, network);
-		rtw_write32(a, REG_CR, val);
-		break;
-
-	case 1:
-		val = rtw_read32(a, REG_CR);
-		val = BIT_SET_NETYPE1(val, network);
-		rtw_write32(a, REG_CR, val);
-		break;
-
-	case 2:
-		val = rtw_read32(a, REG_CR_EXT);
-		val = BIT_SET_NETYPE2(val, network);
-		rtw_write32(a, REG_CR_EXT, val);
-		break;
-
-	case 3:
-		val = rtw_read32(a, REG_CR_EXT);
-		val = BIT_SET_NETYPE3(val, network);
-		rtw_write32(a, REG_CR_EXT, val);
-		break;
-
-	case 4:
-		val = rtw_read32(a, REG_CR_EXT);
-		val = BIT_SET_NETYPE4(val, network);
-		rtw_write32(a, REG_CR_EXT, val);
-		break;
-
-	default:
-		goto out;
-	}
-
-
-	err = 0;
-out:
-	return err;
-#endif
 }
 
 /**
@@ -2145,10 +2148,10 @@ out:
  */
 int rtw_halmac_reset_tsf(struct dvobj_priv *d, enum _hw_port hwport)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -2178,10 +2181,10 @@ out:
 int rtw_halmac_set_bcn_interval(struct dvobj_priv *d, enum _hw_port hwport,
 				u32 interval)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -2211,18 +2214,18 @@ out:
 int rtw_halmac_set_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
 			struct rtw_halmac_bcn_ctrl *bcn_ctrl)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	struct HALMAC_BCN_CTRL ctrl;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	struct halmac_bcn_ctrl ctrl;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
 	halmac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(halmac);
 	port = _hw_port_drv2halmac(hwport);
-	_rtw_memset(&ctrl, 0, sizeof(struct HALMAC_BCN_CTRL));
+	_rtw_memset(&ctrl, 0, sizeof(ctrl));
 	_beacon_ctrl_drv2halmac(bcn_ctrl, &ctrl);
 
 	status = api->halmac_rw_bcn_ctrl(halmac, port, 1, &ctrl);
@@ -2246,10 +2249,10 @@ out:
  */
 int rtw_halmac_set_aid(struct dvobj_priv *d, enum _hw_port hwport, u16 aid)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	u8 port;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_portid port;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -2318,9 +2321,9 @@ out:
 
 int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8 bw)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	mac = dvobj_to_halmac(d);
@@ -2345,11 +2348,11 @@ int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8
  */
 int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_ACQ_ID ac;
-	HALMAC_EDCA_PARA edca;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_acq_id ac;
+	struct halmac_edca_para edca;
+	enum halmac_ret_status status;
 
 
 	mac = dvobj_to_halmac(d);
@@ -2383,6 +2386,164 @@ int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop
 	return 0;
 }
 
+/**
+ * rtw_halmac_set_rts_full_bw() - Send RTS to all covered channels
+ * @d:		struct dvobj_priv*
+ * @enable:	_TRUE(enable), _FALSE(disable)
+ *
+ * Hradware will duplicate RTS packet to all channels which are covered in used
+ * bandwidth.
+ *
+ * Return 0 if process OK, otherwise -1.
+ */
+int rtw_halmac_set_rts_full_bw(struct dvobj_priv *d, u8 enable)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u8 full;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+	full = (enable == _TRUE) ? 1 : 0;
+
+	status = api->halmac_set_hw_value(mac, HALMAC_HW_RTS_FULL_BW, &full);
+	if (HALMAC_RET_SUCCESS != status)
+		return -1;
+
+	return 0;
+}
+
+#ifdef RTW_HALMAC_DBG_POWER_SWITCH
+static void _dump_mac_reg(struct dvobj_priv *d, u32 start, u32 end)
+{
+	struct _ADAPTER *adapter;
+	int i, j = 1;
+
+
+	adapter = dvobj_get_primary_adapter(d);
+	for (i = start; i < end; i += 4) {
+		if (j % 4 == 1)
+			RTW_PRINT("0x%04x", i);
+		_RTW_PRINT(" 0x%08x ", rtw_read32(adapter, i));
+		if ((j++) % 4 == 0)
+			_RTW_PRINT("\n");
+	}
+}
+
+void dump_dbg_val(struct _ADAPTER *a, u32 reg)
+{
+	u32 v32;
+
+
+	rtw_write8(a, 0x3A, reg);
+	v32 = rtw_read32(a, 0xC0);
+	RTW_PRINT("0x3A = %02x, 0xC0 = 0x%08x\n",reg, v32);
+}
+
+#ifdef CONFIG_PCI_HCI
+static void _dump_pcie_cfg_space(struct dvobj_priv *d)
+{
+	struct _ADAPTER *padapter = dvobj_get_primary_adapter(d);
+	struct dvobj_priv       *pdvobjpriv = adapter_to_dvobj(padapter);
+	struct pci_dev  *pdev = pdvobjpriv->ppcidev;
+	struct pci_dev  *bridge_pdev = pdev->bus->self;
+
+        u32 tmp[4] = { 0 };
+        u32 i, j;
+
+	RTW_PRINT("\n*****  PCI Device Configuration Space *****\n\n");
+
+        for(i = 0; i < 0x100; i += 0x10)
+        {
+                for (j = 0 ; j < 4 ; j++)
+                        pci_read_config_dword(pdev, i + j * 4, tmp+j);
+
+        	RTW_PRINT("%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
+                        i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
+                        tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
+                        tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
+                        tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
+        }
+
+	RTW_PRINT("\n*****  PCI Host Device Configuration Space*****\n\n");
+
+        for(i = 0; i < 0x100; i += 0x10)
+        {
+                for (j = 0 ; j < 4 ; j++)
+                        pci_read_config_dword(bridge_pdev, i + j * 4, tmp+j);
+
+        	RTW_PRINT("%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
+                        i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
+                        tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
+                        tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
+                        tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
+        }
+}
+#endif
+
+static void _dump_mac_reg_for_power_switch(struct dvobj_priv *d,
+					   const char* caller, char* desc)
+{
+	struct _ADAPTER *a;
+	u8 v8;
+
+
+	RTW_PRINT("%s: %s\n", caller, desc);
+	RTW_PRINT("======= MAC REG =======\n");
+	/* page 0/1 */
+	_dump_mac_reg(d, 0x0, 0x200);
+	_dump_mac_reg(d, 0x300, 0x400); /* also dump page 3 */
+
+	/* dump debug register */
+	a = dvobj_get_primary_adapter(d);
+
+#ifdef CONFIG_PCI_HCI
+	_dump_pcie_cfg_space(d);
+
+	v8 = rtw_read8(a, 0xF6) | 0x01;
+	rtw_write8(a, 0xF6, v8);
+	RTW_PRINT("0xF6 = %02x\n", v8);
+
+	dump_dbg_val(a, 0x63);
+	dump_dbg_val(a, 0x64);
+	dump_dbg_val(a, 0x68);
+	dump_dbg_val(a, 0x69);
+	dump_dbg_val(a, 0x6a);
+	dump_dbg_val(a, 0x6b);
+	dump_dbg_val(a, 0x71);
+	dump_dbg_val(a, 0x72);
+#endif
+}
+
+static enum halmac_ret_status _power_switch(struct halmac_adapter *halmac,
+					    struct halmac_api *api,
+					    enum halmac_mac_power pwr)
+{
+	enum halmac_ret_status status;
+	char desc[80] = {0};
+
+
+	rtw_sprintf(desc, 80, "before calling power %s",
+				(pwr==HALMAC_MAC_POWER_ON)?"on":"off");
+	_dump_mac_reg_for_power_switch((struct dvobj_priv *)halmac->drv_adapter,
+			__FUNCTION__, desc);
+
+	status = api->halmac_mac_power_switch(halmac, pwr);
+	RTW_PRINT("%s: status=%d\n", __FUNCTION__, status);
+
+	rtw_sprintf(desc, 80, "after calling power %s",
+				(pwr==HALMAC_MAC_POWER_ON)?"on":"off");
+	_dump_mac_reg_for_power_switch((struct dvobj_priv *)halmac->drv_adapter,
+			__FUNCTION__, desc);
+
+	return status;
+}
+#else /* !RTW_HALMAC_DBG_POWER_SWITCH */
+#define _power_switch(mac, api, pwr)	(api)->halmac_mac_power_switch(mac, pwr)
+#endif /* !RTW_HALMAC_DBG_POWER_SWITCH */
+
 /*
  * Description:
  *	Power on device hardware.
@@ -2396,11 +2557,17 @@ int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop
  */
 int rtw_halmac_poweron(struct dvobj_priv *d)
 {
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	int err = -1;
+#if defined(CONFIG_PCI_HCI) && defined(CONFIG_RTL8822B)
+	struct _ADAPTER *a;
+	u8 v8;
+	u32 addr;
 
+	a = dvobj_get_primary_adapter(d);
+#endif
 
 	halmac = dvobj_to_halmac(d);
 	if (!halmac)
@@ -2418,14 +2585,48 @@ int rtw_halmac_poweron(struct dvobj_priv *d)
 		goto out;
 #endif /* CONFIG_SDIO_HCI */
 
-	status = api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_ON);
+#if defined(CONFIG_PCI_HCI) && defined(CONFIG_RTL8822B)
+	addr = 0x3F3;
+	v8 = rtw_read8(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
+	/* are we in pcie debug mode? */
+	if (!(v8 & BIT(2))) {
+		RTW_PRINT("%s: Enable pcie debug mode\n", __FUNCTION__);
+		v8 |= BIT(2);
+		v8 = rtw_write8(a, addr, v8);
+	}
+#endif
+
+	status = _power_switch(halmac, api, HALMAC_MAC_POWER_ON);
 	if (HALMAC_RET_PWR_UNCHANGE == status) {
+
+#if defined(CONFIG_PCI_HCI) && defined(CONFIG_RTL8822B)
+		addr = 0x3F3;
+		v8 = rtw_read8(a, addr);
+		RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
+		
+		/* are we in pcie debug mode? */
+		if (!(v8 & BIT(2))) {
+			RTW_PRINT("%s: Enable pcie debug mode\n", __FUNCTION__);
+			v8 |= BIT(2);
+			v8 = rtw_write8(a, addr, v8);
+		} else if (v8 & BIT(0)) {
+			/* DMA stuck */
+			addr = 0x1350;
+			v8 = rtw_read8(a, addr);
+			RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
+			RTW_PRINT("%s: recover DMA stuck\n", __FUNCTION__);
+			v8 |= BIT(6);
+			v8 = rtw_write8(a, addr, v8);
+			RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
+		}
+#endif
 		/*
 		 * Work around for warm reboot but device not power off,
 		 * but it would also fall into this case when auto power on is enabled.
 		 */
-		api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_OFF);
-		status = api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_ON);
+		_power_switch(halmac, api, HALMAC_MAC_POWER_OFF);
+		status = _power_switch(halmac, api, HALMAC_MAC_POWER_ON);
 		RTW_WARN("%s: Power state abnormal, try to recover...%s\n",
 			 __FUNCTION__, (HALMAC_RET_SUCCESS == status)?"OK":"FAIL!");
 	}
@@ -2454,9 +2655,9 @@ out:
  */
 int rtw_halmac_poweroff(struct dvobj_priv *d)
 {
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -2466,7 +2667,7 @@ int rtw_halmac_poweroff(struct dvobj_priv *d)
 
 	api = HALMAC_GET_API(halmac);
 
-	status = api->halmac_mac_power_switch(halmac, HALMAC_MAC_POWER_OFF);
+	status = _power_switch(halmac, api, HALMAC_MAC_POWER_OFF);
 	if ((HALMAC_RET_SUCCESS != status)
 	    && (HALMAC_RET_PWR_UNCHANGE != status))
 		goto out;
@@ -2477,7 +2678,7 @@ out:
 }
 
 #ifdef CONFIG_SUPPORT_TRX_SHARED
-static inline HALMAC_RX_FIFO_EXPANDING_MODE _trx_share_mode_drv2halmac(u8 trx_share_mode)
+static inline enum halmac_rx_fifo_expanding_mode _trx_share_mode_drv2halmac(u8 trx_share_mode)
 {
 	if (0 == trx_share_mode)
 		return HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE;
@@ -2490,16 +2691,18 @@ static inline HALMAC_RX_FIFO_EXPANDING_MODE _trx_share_mode_drv2halmac(u8 trx_sh
 	else
 		return HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE;
 }
-static HALMAC_RX_FIFO_EXPANDING_MODE _rtw_get_trx_share_mode(_adapter *adapter)
+
+static enum halmac_rx_fifo_expanding_mode _rtw_get_trx_share_mode(struct _ADAPTER *adapter)
 {
-	struct registry_priv  *registry_par = &adapter->registrypriv;
+	struct registry_priv *registry_par = &adapter->registrypriv;
 
 	return _trx_share_mode_drv2halmac(registry_par->trx_share_mode);
 }
-void dump_trx_share_mode(void *sel, _adapter *adapter)
+
+void dump_trx_share_mode(void *sel, struct _ADAPTER *adapter)
 {
 	struct registry_priv  *registry_par = &adapter->registrypriv;
-	u8 mode =  _trx_share_mode_drv2halmac(registry_par->trx_share_mode);
+	u8 mode = _trx_share_mode_drv2halmac(registry_par->trx_share_mode);
 
 	if (HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK == mode)
 		RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "RX_FIFO_EXPANDING_MODE_1");
@@ -2512,7 +2715,7 @@ void dump_trx_share_mode(void *sel, _adapter *adapter)
 }
 #endif
 
-static enum _HALMAC_DRV_RSVD_PG_NUM _rsvd_page_num_drv2halmac(u8 num)
+static enum halmac_drv_rsvd_pg_num _rsvd_page_num_drv2halmac(u16 num)
 {
 	if (num <= 8)
 		return HALMAC_RSVD_PG_NUM8;
@@ -2520,18 +2723,24 @@ static enum _HALMAC_DRV_RSVD_PG_NUM _rsvd_page_num_drv2halmac(u8 num)
 		return HALMAC_RSVD_PG_NUM16;
 	if (num <= 24)
 		return HALMAC_RSVD_PG_NUM24;
-
-	if (num > 32)
+	if (num <= 32)
+		return HALMAC_RSVD_PG_NUM32;
+	if (num <= 64)
+		return HALMAC_RSVD_PG_NUM64;
+	if (num <= 128)
+		return HALMAC_RSVD_PG_NUM128;
+
+	if (num > 256)
 		RTW_WARN("%s: Fail to allocate RSVD page(%d)!!"
-			 " The MAX RSVD page number is 32...\n",
+			 " The MAX RSVD page number is 256...\n",
 			 __FUNCTION__, num);
 
-	return HALMAC_RSVD_PG_NUM32;
+	return HALMAC_RSVD_PG_NUM256;
 }
 
-static u8 _rsvd_page_num_halmac2drv(HALMAC_DRV_RSVD_PG_NUM rsvd_page_number)
+static u16 _rsvd_page_num_halmac2drv(enum halmac_drv_rsvd_pg_num rsvd_page_number)
 {
-	u8 num = 0;
+	u16 num = 0;
 
 
 	switch (rsvd_page_number) {
@@ -2550,12 +2759,24 @@ static u8 _rsvd_page_num_halmac2drv(HALMAC_DRV_RSVD_PG_NUM rsvd_page_number)
 	case HALMAC_RSVD_PG_NUM32:
 		num = 32;
 		break;
+
+	case HALMAC_RSVD_PG_NUM64:
+		num = 64;
+		break;
+
+	case HALMAC_RSVD_PG_NUM128:
+		num = 128;
+		break;
+
+	case HALMAC_RSVD_PG_NUM256:
+		num = 256;
+		break;
 	}
 
 	return num;
 }
 
-static HALMAC_TRX_MODE _choose_trx_mode(struct dvobj_priv *d)
+static enum halmac_trx_mode _choose_trx_mode(struct dvobj_priv *d)
 {
 	PADAPTER p;
 
@@ -2573,9 +2794,9 @@ static HALMAC_TRX_MODE _choose_trx_mode(struct dvobj_priv *d)
 	return HALMAC_TRX_MODE_NORMAL;
 }
 
-static inline enum _HALMAC_RF_TYPE _rf_type_drv2halmac(enum rf_type rf_drv)
+static inline enum halmac_rf_type _rf_type_drv2halmac(enum rf_type rf_drv)
 {
-	enum _HALMAC_RF_TYPE rf_mac;
+	enum halmac_rf_type rf_mac;
 
 
 	switch (rf_drv) {
@@ -2612,59 +2833,112 @@ static inline enum _HALMAC_RF_TYPE _rf_type_drv2halmac(enum rf_type rf_drv)
 	return rf_mac;
 }
 
-static void _ant_status_by_rf_type(enum rf_type rf, u8 *tx, u8 *rx)
+static inline enum rf_type _rf_type_halmac2drv(enum halmac_rf_type rf_mac)
 {
-	switch (rf) {
-	case RF_1T1R:
-	case RF_1T2R:
-		*tx = BB_PATH_A;
+	enum rf_type rf_drv;
+
+
+	switch (rf_mac) {
+	case HALMAC_RF_1T2R:
+		rf_drv = RF_1T2R;
 		break;
-	case RF_2T2R:
-	case RF_2T3R:
-	case RF_2T4R:
-		*tx = BB_PATH_AB;
+	case HALMAC_RF_2T4R:
+		rf_drv = RF_2T4R;
 		break;
-	case RF_3T3R:
-	case RF_3T4R:
-		*tx = BB_PATH_ABC;
+	case HALMAC_RF_2T2R:
+	case HALMAC_RF_2T2R_GREEN:
+		rf_drv = RF_2T2R;
 		break;
-	case RF_4T4R:
-	default:
-		*tx = BB_PATH_ABCD;
+	case HALMAC_RF_2T3R:
+		rf_drv = RF_2T3R;
 		break;
-	}
-
-	switch (rf) {
-	case RF_1T1R:
-		*rx = BB_PATH_A;
+	case HALMAC_RF_1T1R:
+		rf_drv = RF_1T1R;
 		break;
-	case RF_1T2R:
-	case RF_2T2R:
-		*rx = BB_PATH_AB;
+	case HALMAC_RF_3T3R:
+		rf_drv = RF_3T3R;
 		break;
-	case RF_2T3R:
-	case RF_3T3R:
-		*rx = BB_PATH_ABC;
+	case HALMAC_RF_3T4R:
+		rf_drv = RF_3T4R;
+		break;
+	case HALMAC_RF_4T4R:
+		rf_drv = RF_4T4R;
 		break;
-	case RF_2T4R:
-	case RF_3T4R:
-	case RF_4T4R:
 	default:
-		*rx = BB_PATH_ABCD;
+		rf_drv = RF_TYPE_MAX;
+		RTW_ERR("%s: Invalid RF type(0x%x)!\n", __FUNCTION__, rf_mac);
 		break;
 	}
+
+	return rf_drv;
+}
+
+static enum odm_cut_version _cut_version_drv2phydm(
+				enum tag_HAL_Cut_Version_Definition cut_drv)
+{
+	enum odm_cut_version cut_phydm = ODM_CUT_A;
+	u32 diff;
+
+
+	if (cut_drv > K_CUT_VERSION)
+		RTW_WARN("%s: unknown cut_ver=%d !!\n", __FUNCTION__, cut_drv);
+
+	diff = cut_drv - A_CUT_VERSION;
+	cut_phydm += diff;
+
+	return cut_phydm;
+}
+
+static int _send_general_info_by_reg(struct dvobj_priv *d,
+				     struct halmac_general_info *info)
+{
+	struct _ADAPTER *a;
+	struct hal_com_data *hal;
+	enum tag_HAL_Cut_Version_Definition cut_drv;
+	enum rf_type rftype;
+	enum odm_cut_version cut_phydm;
+	u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
+
+
+	a = dvobj_get_primary_adapter(d);
+	hal = GET_HAL_DATA(a);
+	rftype = _rf_type_halmac2drv(info->rf_type);
+	cut_drv = GET_CVID_CUT_VERSION(hal->version_id);
+	cut_phydm = _cut_version_drv2phydm(cut_drv);
+
+#define CLASS_GENERAL_INFO_REG				0x02
+#define CMD_ID_GENERAL_INFO_REG				0x0C
+#define GENERAL_INFO_REG_SET_CMD_ID(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 0, 5, v)
+#define GENERAL_INFO_REG_SET_CLASS(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 5, 3, v)
+#define GENERAL_INFO_REG_SET_RFE_TYPE(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 8, 8, v)
+#define GENERAL_INFO_REG_SET_RF_TYPE(buf, v)		SET_BITS_TO_LE_4BYTE(buf, 16, 8, v)
+#define GENERAL_INFO_REG_SET_CUT_VERSION(buf, v)	SET_BITS_TO_LE_4BYTE(buf, 24, 8, v)
+#define GENERAL_INFO_REG_SET_RX_ANT_STATUS(buf, v)	SET_BITS_TO_LE_1BYTE(buf+4, 0, 4, v)
+#define GENERAL_INFO_REG_SET_TX_ANT_STATUS(buf, v)	SET_BITS_TO_LE_1BYTE(buf+4, 4, 4, v)
+
+	GENERAL_INFO_REG_SET_CMD_ID(h2c, CMD_ID_GENERAL_INFO_REG);
+	GENERAL_INFO_REG_SET_CLASS(h2c, CLASS_GENERAL_INFO_REG);
+	GENERAL_INFO_REG_SET_RFE_TYPE(h2c, info->rfe_type);
+	GENERAL_INFO_REG_SET_RF_TYPE(h2c, rftype);
+	GENERAL_INFO_REG_SET_CUT_VERSION(h2c, cut_phydm);
+	GENERAL_INFO_REG_SET_RX_ANT_STATUS(h2c, info->rx_ant_status);
+	GENERAL_INFO_REG_SET_TX_ANT_STATUS(h2c, info->tx_ant_status);
+
+	return rtw_halmac_send_h2c(d, h2c);
 }
 
 static int _send_general_info(struct dvobj_priv *d)
 {
 	struct _ADAPTER *adapter;
 	struct hal_com_data *hal;
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	struct _HALMAC_GENERAL_INFO info;
-	enum _HALMAC_RET_STATUS status;
-	enum rf_type rf;
-	u8 val8;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	struct halmac_general_info info;
+	enum halmac_ret_status status;
+	enum rf_type rf = RF_1T1R;
+	enum bb_path txpath = BB_PATH_A;
+	enum bb_path rxpath = BB_PATH_A;
+	int err;
 
 
 	adapter = dvobj_get_primary_adapter(d);
@@ -2676,10 +2950,10 @@ static int _send_general_info(struct dvobj_priv *d)
 
 	_rtw_memset(&info, 0, sizeof(info));
 	info.rfe_type = (u8)hal->rfe_type;
-	rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)&val8);
-	rf = (enum rf_type)val8;
+	rtw_hal_get_rf_path(d, &rf, &txpath, &rxpath);
 	info.rf_type = _rf_type_drv2halmac(rf);
-	_ant_status_by_rf_type(rf, &info.tx_ant_status, &info.rx_ant_status);
+	info.tx_ant_status = (u8)txpath;
+	info.rx_ant_status = (u8)rxpath;
 
 	status = api->halmac_send_general_info(halmac, &info);
 	switch (status) {
@@ -2693,6 +2967,13 @@ static int _send_general_info(struct dvobj_priv *d)
 		return -1;
 	}
 
+	err = _send_general_info_by_reg(d, &info);
+	if (err) {
+		RTW_ERR("%s: Fail to send general info by register!\n",
+			 __FUNCTION__);
+		return -1;
+	}
+
 	return 0;
 }
 
@@ -2700,11 +2981,11 @@ static int _cfg_drv_rsvd_pg_num(struct dvobj_priv *d)
 {
 	struct _ADAPTER *a;
 	struct hal_com_data *hal;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	enum _HALMAC_DRV_RSVD_PG_NUM rsvd_page_number;
-	HALMAC_RET_STATUS status;
-	u8 drv_rsvd_num;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_drv_rsvd_pg_num rsvd_page_number;
+	enum halmac_ret_status status;
+	u16 drv_rsvd_num;
 
 
 	a = dvobj_get_primary_adapter(d);
@@ -2726,6 +3007,199 @@ static int _cfg_drv_rsvd_pg_num(struct dvobj_priv *d)
 	return 0;
 }
 
+static void _debug_dlfw_fail(struct dvobj_priv *d)
+{
+	struct _ADAPTER *a;
+	u32 addr;
+	u32 v32, i, n;
+	u8 data[0x100] = {0};
+
+
+	a = dvobj_get_primary_adapter(d);
+
+	/* read 0x80[15:0], 0x10F8[31:0] once */
+	addr = 0x80;
+	v32 = rtw_read16(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%04x\n", __FUNCTION__, addr, v32);
+
+	addr = 0x10F8;
+	v32 = rtw_read32(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%08x\n", __FUNCTION__, addr, v32);
+
+	/* read 0x10FC[31:0], 5 times */
+	addr = 0x10FC;
+	n = 5;
+	for (i = 0; i < n; i++) {
+		v32 = rtw_read32(a, addr);
+		RTW_PRINT("%s: 0x%X = 0x%08x (%u/%u)\n",
+			  __FUNCTION__, addr, v32, i, n);
+	}
+
+	/*
+	 * write 0x3A[7:0]=0x28 and 0xF6[7:0]=0x01
+	 * and then read 0xC0[31:0] 5 times
+	 */
+	addr = 0x3A;
+	v32 = 0x28;
+	rtw_write8(a, addr, (u8)v32);
+	v32 = rtw_read8(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v32);
+
+	addr = 0xF6;
+	v32 = 0x1;
+	rtw_write8(a, addr, (u8)v32);
+	v32 = rtw_read8(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v32);
+
+	addr = 0xC0;
+	n = 5;
+	for (i = 0; i < n; i++) {
+		v32 = rtw_read32(a, addr);
+		RTW_PRINT("%s: 0x%X = 0x%08x (%u/%u)\n",
+			  __FUNCTION__, addr, v32, i, n);
+	}
+
+	/* 0x00~0xFF, 0x1000~0x10FF */
+	addr = 0;
+	n = 0x100;
+	for (i = 0; i < n; i+=4)
+		*(u32*)&data[i] = cpu_to_le32(rtw_read32(a, addr+i));
+	for (i = 0; i < n; i++) {
+		if (i % 16 == 0)
+			RTW_PRINT("0x%04x\t", addr+i);
+		_RTW_PRINT("0x%02x", data[i]);
+		if (i % 16 == 15)
+			_RTW_PRINT("\n");
+		else
+			_RTW_PRINT(" ");
+	}
+
+	addr = 0x1000;
+	n = 0x100;
+	for (i = 0; i < n; i+=4)
+		*(u32*)&data[i] = cpu_to_le32(rtw_read32(a, addr+i));
+	for (i = 0; i < n; i++) {
+		if (i % 16 == 0)
+			RTW_PRINT("0x%04x\t", addr+i);
+		_RTW_PRINT("0x%02x", data[i]);
+		if (i % 16 == 15)
+			_RTW_PRINT("\n");
+		else
+			_RTW_PRINT(" ");
+	}
+
+	/* read 0x80 after 10 secs */
+	rtw_msleep_os(10000);
+	addr = 0x80;
+	v32 = rtw_read16(a, addr);
+	RTW_PRINT("%s: 0x%X = 0x%04x (after 10 secs)\n",
+		  __FUNCTION__, addr, v32);
+}
+
+static enum halmac_ret_status _enter_cpu_sleep_mode(struct dvobj_priv *d)
+{
+	struct hal_com_data *hal;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+
+
+	hal = GET_HAL_DATA(dvobj_get_primary_adapter(d));
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+#ifdef CONFIG_RTL8822B
+	/* Support after firmware version 21 */
+	if (hal->firmware_version < 21)
+		return HALMAC_RET_NOT_SUPPORT;
+#elif defined(CONFIG_RTL8821C)
+	/* Support after firmware version 13.6 or 16 */
+	if (hal->firmware_version == 13) {
+		if (hal->firmware_sub_version < 6)
+			return HALMAC_RET_NOT_SUPPORT;
+	} else if (hal->firmware_version < 16) {
+		return HALMAC_RET_NOT_SUPPORT;
+	}
+#endif
+
+	return api->halmac_enter_cpu_sleep_mode(mac);
+}
+
+/*
+ * _cpu_sleep() - Let IC CPU enter sleep mode
+ * @d:		struct dvobj_priv*
+ * @timeout:	time limit of wait, unit is ms
+ *		0 for no limit
+ *
+ * Rteurn 0 for CPU in sleep mode, otherwise fail to enter sleep mode.
+ * Error codes definition are as follow:
+ * 	-1	HALMAC enter sleep return fail
+ *	-2	HALMAC get CPU mode return fail
+ *	-110	timeout
+ */
+static int _cpu_sleep(struct dvobj_priv *d, u32 timeout)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_wlcpu_mode mode = HALMAC_WLCPU_UNDEFINE;
+	systime start_t;
+	s32 period = 0;
+	u32 cnt = 0;
+	int err = 0;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	start_t = rtw_get_current_time();
+
+	status = _enter_cpu_sleep_mode(d);
+	if (status != HALMAC_RET_SUCCESS) {
+		if (status != HALMAC_RET_NOT_SUPPORT)
+			err = -1;
+		goto exit;
+	}
+
+	do {
+		cnt++;
+
+		mode = HALMAC_WLCPU_UNDEFINE;
+		status = api->halmac_get_cpu_mode(mac, &mode);
+
+		period = rtw_get_passing_time_ms(start_t);
+
+		if (status != HALMAC_RET_SUCCESS) {
+			err = -2;
+			break;
+		}
+		if (mode == HALMAC_WLCPU_SLEEP)
+			break;
+		if (period > timeout) {
+			err = -110;
+			break;
+		}
+
+		rtw_msleep_os(1);
+	} while (1);
+
+exit:
+	if (err)
+		RTW_ERR("%s: Fail to enter sleep mode! (%d, %d)\n",
+			__FUNCTION__, status, mode);
+
+	RTW_INFO("%s: Cost %dms to polling %u times. (err=%d)\n",
+		__FUNCTION__, period, cnt, err);
+
+	return err;
+}
+
+static void _init_trx_cfg_drv(struct dvobj_priv *d)
+{
+#ifdef CONFIG_PCI_HCI
+	rtw_hal_irp_reset(dvobj_get_primary_adapter(d));
+#endif
+}
+
 /*
  * Description:
  *	Downlaod Firmware Flow
@@ -2744,17 +3218,17 @@ static int _cfg_drv_rsvd_pg_num(struct dvobj_priv *d)
  */
 static int download_fw(struct dvobj_priv *d, u8 *fw, u32 fwsize, u8 re_dl)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
-	int err = 0;
 	PHAL_DATA_TYPE hal;
-	HALMAC_FW_VERSION fw_vesion;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	struct halmac_fw_version fw_vesion;
+	enum halmac_ret_status status;
+	int err = 0;
 
 
+	hal = GET_HAL_DATA(dvobj_get_primary_adapter(d));
 	mac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(mac);
-	hal = GET_HAL_DATA(dvobj_get_primary_adapter(d));
 
 	if ((!fw) || (!fwsize))
 		return -1;
@@ -2775,58 +3249,71 @@ static int download_fw(struct dvobj_priv *d, u8 *fw, u32 fwsize, u8 re_dl)
 	 * somewhere calling rtw_halmac_set_max_dl_fw_size().
 	 */
 
-	/* 4. Download Firmware */
+	if (re_dl) {
+		/* 4. Enter IC CPU sleep mode */
+		err = _cpu_sleep(d, 2000);
+		if (err) {
+			RTW_ERR("%s: IC CPU fail to enter sleep mode!(%d)\n",
+				__FUNCTION__, err);
+			/* skip this error */
+			err = 0;
+		}
+	}
+
+	/* 5. Download Firmware */
 	status = api->halmac_download_firmware(mac, fw, fwsize);
 	if (status != HALMAC_RET_SUCCESS) {
 		RTW_ERR("%s: download firmware FAIL! status=0x%02x\n",
 			__FUNCTION__, status);
+		_debug_dlfw_fail(d);
 		err = -1;
 		goto resume_tx;
 	}
 
+	/* 5.1. (Driver) Reset driver variables if needed */
+	hal->LastHMEBoxNum = 0;
+
+	/* 5.2. (Driver) Get FW version */
+	status = api->halmac_get_fw_version(mac, &fw_vesion);
+	if (status == HALMAC_RET_SUCCESS) {
+		hal->firmware_version = fw_vesion.version;
+		hal->firmware_sub_version = fw_vesion.sub_version;
+		hal->firmware_size = fwsize;
+	}
+
 resume_tx:
-	/* 5. Driver resume TX if needed */
+	/* 6. Driver resume TX if needed */
 	/* ToDo */
 
 	if (err)
 		goto exit;
 
 	if (re_dl) {
-		HALMAC_TRX_MODE mode;
+		enum halmac_trx_mode mode;
 
-		/* 6. Change reserved page size */
+		/* 7. Change reserved page size */
 		err = _cfg_drv_rsvd_pg_num(d);
 		if (err)
 			return -1;
 
-		/* 7. Init TRX Configuration */
+		/* 8. Init TRX Configuration */
 		mode = _choose_trx_mode(d);
 		status = api->halmac_init_trx_cfg(mac, mode);
 		if (HALMAC_RET_SUCCESS != status)
 			return -1;
+		_init_trx_cfg_drv(d);
 
-		/* 8. Config RX Aggregation */
+		/* 9. Config RX Aggregation */
 		err = rtw_halmac_rx_agg_switch(d, _TRUE);
 		if (err)
 			return -1;
 
-		/* 9. Send General Info */
+		/* 10. Send General Info */
 		err = _send_general_info(d);
 		if (err)
 			return -1;
 	}
 
-	/* 10. (Driver) Reset driver variables if needed */
-	hal->LastHMEBoxNum = 0;
-
-	/* 11. (Driver) Get FW version */
-	status = api->halmac_get_fw_version(mac, &fw_vesion);
-	if (status == HALMAC_RET_SUCCESS) {
-		hal->firmware_version = fw_vesion.version;
-		hal->firmware_sub_version = fw_vesion.sub_version;
-		hal->firmware_size = fwsize;
-	}
-
 exit:
 	return err;
 }
@@ -2835,12 +3322,12 @@ static int init_mac_flow(struct dvobj_priv *d)
 {
 	PADAPTER p;
 	struct hal_com_data *hal;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	enum _HALMAC_DRV_RSVD_PG_NUM rsvd_page_number;
-	HALMAC_WLAN_ADDR hwa;
-	HALMAC_TRX_MODE trx_mode;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_drv_rsvd_pg_num rsvd_page_number;
+	union halmac_wlan_addr hwa;
+	enum halmac_trx_mode trx_mode;
+	enum halmac_ret_status status;
 	u8 drv_rsvd_num;
 	u8 nettype;
 	int err, err_ret = -1;
@@ -2852,7 +3339,8 @@ static int init_mac_flow(struct dvobj_priv *d)
 	api = HALMAC_GET_API(halmac);
 
 #ifdef CONFIG_SUPPORT_TRX_SHARED
-	status = api->halmac_cfg_rx_fifo_expanding_mode(halmac, _rtw_get_trx_share_mode(p));
+	status = api->halmac_cfg_rxff_expand_mode(halmac,
+						  _rtw_get_trx_share_mode(p));
 	if (status != HALMAC_RET_SUCCESS)
 		goto out;
 #endif
@@ -2877,6 +3365,7 @@ static int init_mac_flow(struct dvobj_priv *d)
 	status = api->halmac_init_mac_cfg(halmac, trx_mode);
 	if (status != HALMAC_RET_SUCCESS)
 		goto out;
+	_init_trx_cfg_drv(d);
 
 	err = rtw_halmac_rx_agg_switch(d, _TRUE);
 	if (err)
@@ -2907,7 +3396,11 @@ static int _drv_enable_trx(struct dvobj_priv *d)
 
 	adapter = dvobj_get_primary_adapter(d);
 	if (adapter->bup == _FALSE) {
+#ifdef CONFIG_NEW_NETDEV_HDL
+		status = rtw_mi_start_drv_threads(adapter);
+#else
 		status = rtw_start_drv_threads(adapter);
+#endif
 		if (status == _FAIL) {
 			RTW_ERR("%s: Start threads Failed!\n", __FUNCTION__);
 			return -1;
@@ -2929,10 +3422,10 @@ static int _drv_enable_trx(struct dvobj_priv *d)
 static int _halmac_init_hal(struct dvobj_priv *d, u8 *fw, u32 fwsize)
 {
 	PADAPTER adapter;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
-	u32 ok = _TRUE;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u32 ok;
 	u8 fw_ok = _FALSE;
 	int err, err_ret = -1;
 
@@ -3064,7 +3557,7 @@ int rtw_halmac_init_hal_fw_file(struct dvobj_priv *d, u8 *fwpath)
 
 exit:
 	rtw_mfree(fw, fwmaxsize);
-	fw = NULL;
+	/*fw = NULL;*/
 
 	return err;
 }
@@ -3072,9 +3565,9 @@ exit:
 int rtw_halmac_deinit_hal(struct dvobj_priv *d)
 {
 	PADAPTER adapter;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -3097,9 +3590,9 @@ out:
 
 int rtw_halmac_self_verify(struct dvobj_priv *d)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	int err = -1;
 
 
@@ -3121,9 +3614,9 @@ out:
 
 static u8 rtw_halmac_txfifo_is_empty(struct dvobj_priv *d)
 {
-	struct _HALMAC_ADAPTER *mac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 chk_num = 10;
 	u8 rst = _FALSE;
 
@@ -3182,7 +3675,7 @@ int rtw_halmac_txfifo_wait_empty(struct dvobj_priv *d, u32 timeout)
 	if (empty == _FALSE) {
 #ifdef CONFIG_RTW_DEBUG
 		u16 dbg_reg[] = {0x210, 0x230, 0x234, 0x238, 0x23C, 0x240,
-				 0x41A, 0x10FC, 0x10F8, 0x11F4, 0x11F8};
+				 0x418, 0x10FC, 0x10F8, 0x11F4, 0x11F8};
 		u8 i;
 		u32 val;
 
@@ -3202,9 +3695,9 @@ int rtw_halmac_txfifo_wait_empty(struct dvobj_priv *d, u32 timeout)
 	return 0;
 }
 
-static enum _HALMAC_DLFW_MEM _fw_mem_drv2halmac(enum fw_mem mem, u8 tx_stop)
+static enum halmac_dlfw_mem _fw_mem_drv2halmac(enum fw_mem mem, u8 tx_stop)
 {
-	enum _HALMAC_DLFW_MEM mem_halmac = HALMAC_DLFW_MEM_UNDEFINE;
+	enum halmac_dlfw_mem mem_halmac = HALMAC_DLFW_MEM_UNDEFINE;
 
 
 	switch (mem) {
@@ -3226,10 +3719,10 @@ static enum _HALMAC_DLFW_MEM _fw_mem_drv2halmac(enum fw_mem mem, u8 tx_stop)
 
 int rtw_halmac_dlfw_mem(struct dvobj_priv *d, u8 *fw, u32 fwsize, enum fw_mem mem)
 {
-	struct _HALMAC_ADAPTER *mac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
-	enum _HALMAC_DLFW_MEM dlfw_mem;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_dlfw_mem dlfw_mem;
 	u8 tx_stop = _FALSE;
 	u32 chk_timeout = 2000; /* unit: ms */
 	int err = 0;
@@ -3300,7 +3793,7 @@ int rtw_halmac_dlfw_mem_from_file(struct dvobj_priv *d, u8 *fwpath, enum fw_mem
 		err = -1;
 
 	rtw_mfree(fw, fwmaxsize);
-	fw = NULL;
+	/*fw = NULL;*/
 
 	return err;
 }
@@ -3313,8 +3806,8 @@ int rtw_halmac_dlfw_mem_from_file(struct dvobj_priv *d, u8 *fwpath, enum fw_mem
 int rtw_halmac_dlfw(struct dvobj_priv *d, u8 *fw, u32 fwsize)
 {
 	PADAPTER adapter;
-	HALMAC_RET_STATUS status;
-	u32 ok = _TRUE;
+	enum halmac_ret_status status;
+	u32 ok;
 	int err, err_ret = -1;
 
 
@@ -3377,7 +3870,7 @@ int rtw_halmac_dlfw_from_file(struct dvobj_priv *d, u8 *fwpath)
 		err = -1;
 
 	rtw_mfree(fw, fwmaxsize);
-	fw = NULL;
+	/*fw = NULL;*/
 
 	return err;
 }
@@ -3396,9 +3889,10 @@ int rtw_halmac_dlfw_from_file(struct dvobj_priv *d, u8 *fwpath)
 int rtw_halmac_phy_power_switch(struct dvobj_priv *d, u8 enable)
 {
 	PADAPTER adapter;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	u8 on;
 
 
 	adapter = dvobj_get_primary_adapter(d);
@@ -3406,8 +3900,9 @@ int rtw_halmac_phy_power_switch(struct dvobj_priv *d, u8 enable)
 	if (!halmac)
 		return -1;
 	api = HALMAC_GET_API(halmac);
+	on = (enable == _TRUE) ? 1 : 0;
 
-	status = api->halmac_set_hw_value(halmac, HALMAC_HW_EN_BB_RF, &enable);
+	status = api->halmac_set_hw_value(halmac, HALMAC_HW_EN_BB_RF, &on);
 	if (status != HALMAC_RET_SUCCESS)
 		return -1;
 
@@ -3441,6 +3936,10 @@ static u8 _is_fw_read_cmd_down(PADAPTER adapter, u8 msgbox_num)
  *
  * Send H2C to firmware by message box register(0x1D0~0x1D3 & 0x1F0~0x1F3).
  *
+ * Assume firmware be ready to accept H2C here, please check
+ * (hal->bFWReady == _TRUE) before call this function or make sure firmware is
+ * ready.
+ *
  * Return: 0 if process OK, otherwise fail to send this H2C.
  */
 int rtw_halmac_send_h2c(struct dvobj_priv *d, u8 *h2c)
@@ -3454,10 +3953,6 @@ int rtw_halmac_send_h2c(struct dvobj_priv *d, u8 *h2c)
 	u32 h2c_cmd_ex = 0;
 	int err = -1;
 
-	if (hal->bFWReady == _FALSE) {
-		RTW_WARN("%s: return H2C cmd because fw is not ready\n", __FUNCTION__);
-		return err;
-	}
 
 	if (!h2c) {
 		RTW_WARN("%s: pbuf is NULL\n", __FUNCTION__);
@@ -3524,9 +4019,9 @@ exit:
  */
 int rtw_halmac_c2h_handle(struct dvobj_priv *d, u8 *c2h, u32 size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	mac = dvobj_to_halmac(d);
@@ -3541,9 +4036,9 @@ int rtw_halmac_c2h_handle(struct dvobj_priv *d, u8 *c2h, u32 size)
 
 int rtw_halmac_get_available_efuse_size(struct dvobj_priv *d, u32 *size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val;
 
 
@@ -3560,9 +4055,9 @@ int rtw_halmac_get_available_efuse_size(struct dvobj_priv *d, u32 *size)
 
 int rtw_halmac_get_physical_efuse_size(struct dvobj_priv *d, u32 *size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val;
 
 
@@ -3579,10 +4074,10 @@ int rtw_halmac_get_physical_efuse_size(struct dvobj_priv *d, u32 *size)
 
 int rtw_halmac_read_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
-	HALMAC_FEATURE_ID id;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
 	int ret;
 
 
@@ -3609,9 +4104,9 @@ int rtw_halmac_read_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)
 
 int rtw_halmac_read_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u8 v;
 	u32 i;
 	u8 *efuse = NULL;
@@ -3652,9 +4147,9 @@ int rtw_halmac_read_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8
 
 int rtw_halmac_write_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 i;
 
 
@@ -3675,9 +4170,9 @@ int rtw_halmac_write_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u
 
 int rtw_halmac_get_logical_efuse_size(struct dvobj_priv *d, u32 *size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 val;
 
 
@@ -3694,10 +4189,10 @@ int rtw_halmac_get_logical_efuse_size(struct dvobj_priv *d, u32 *size)
 
 int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u8 *maskmap, u32 masksize)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
-	HALMAC_FEATURE_ID id;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
 	int ret;
 
 
@@ -3720,11 +4215,11 @@ int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u
 		return -1;
 
 	if (maskmap && masksize) {
-		struct _HALMAC_PG_EFUSE_INFO pginfo;
+		struct halmac_pg_efuse_info pginfo;
 
-		pginfo.pEfuse_map = map;
+		pginfo.efuse_map = map;
 		pginfo.efuse_map_size = size;
-		pginfo.pEfuse_mask = maskmap;
+		pginfo.efuse_mask = maskmap;
 		pginfo.efuse_mask_size = masksize;
 
 		status = api->halmac_mask_logical_efuse(mac, &pginfo);
@@ -3737,18 +4232,18 @@ int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u
 
 int rtw_halmac_write_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u8 *maskmap, u32 masksize)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_PG_EFUSE_INFO pginfo;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	struct halmac_pg_efuse_info pginfo;
+	enum halmac_ret_status status;
 
 
 	mac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(mac);
 
-	pginfo.pEfuse_map = map;
+	pginfo.efuse_map = map;
 	pginfo.efuse_map_size = size;
-	pginfo.pEfuse_mask = maskmap;
+	pginfo.efuse_mask = maskmap;
 	pginfo.efuse_mask_size = masksize;
 
 	status = api->halmac_pg_efuse_by_map(mac, &pginfo, HALMAC_EFUSE_R_AUTO);
@@ -3760,9 +4255,9 @@ int rtw_halmac_write_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size,
 
 int rtw_halmac_read_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u8 v;
 	u32 i;
 
@@ -3782,9 +4277,9 @@ int rtw_halmac_read_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8
 
 int rtw_halmac_write_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 i;
 
 
@@ -3802,12 +4297,13 @@ int rtw_halmac_write_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8
 
 int rtw_halmac_write_bt_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 i;
 	u8 bank = 1;
 
+
 	mac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(mac);
 
@@ -3825,13 +4321,12 @@ int rtw_halmac_write_bt_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt
 
 int rtw_halmac_read_bt_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
-	HALMAC_FEATURE_ID id;
-	int ret;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	int bank = 1;
 
+
 	mac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(mac);
 
@@ -3846,7 +4341,7 @@ int rtw_halmac_read_bt_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 siz
 	return 0;
 }
 
-static enum _HAL_FIFO_SEL _fifo_sel_drv2halmac(u8 fifo_sel)
+static enum hal_fifo_sel _fifo_sel_drv2halmac(u8 fifo_sel)
 {
 	switch (fifo_sel) {
 	case 0:
@@ -3869,15 +4364,15 @@ static enum _HAL_FIFO_SEL _fifo_sel_drv2halmac(u8 fifo_sel)
 /*#define CONFIG_HALMAC_FIFO_DUMP*/
 int rtw_halmac_dump_fifo(struct dvobj_priv *d, u8 fifo_sel, u32 addr, u32 size, u8 *buffer)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum hal_fifo_sel halmac_fifo_sel;
+	enum halmac_ret_status status;
 	u8 *pfifo_map = NULL;
 	u32 fifo_size = 0;
 	s8 ret = 0;/* 0:success, -1:error */
 	u8 mem_created = _FALSE;
 
-	HAL_FIFO_SEL halmac_fifo_sel;
 
 	mac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(mac);
@@ -3925,15 +4420,36 @@ _exit:
 	return ret;
 }
 
+/*
+ * rtw_halmac_rx_agg_switch() - Switch RX aggregation function and setting
+ * @d		struct dvobj_priv *
+ * @enable	_FALSE/_TRUE for disable/enable RX aggregation function
+ *
+ * This function could help to on/off bus RX aggregation function, and is only
+ * useful for SDIO and USB interface. Although only "enable" flag is brough in,
+ * some setting would be taken from other places, and they are from:
+ * [DMA aggregation]
+ *	struct hal_com_data.rxagg_dma_size
+ *	struct hal_com_data.rxagg_dma_timeout
+ * [USB aggregation] (only use for USB interface)
+ *	struct hal_com_data.rxagg_usb_size
+ *	struct hal_com_data.rxagg_usb_timeout
+ * If above values of size and timeout are both 0 means driver would not
+ * control the threshold setting and leave it to HALMAC handle.
+ *
+ * From HALMAC V1_04_04, driver force the size threshold be hard limit, and the
+ * rx size can not exceed the setting.
+ *
+ * Return 0 for success, otherwise fail.
+ */
 int rtw_halmac_rx_agg_switch(struct dvobj_priv *d, u8 enable)
 {
-	PADAPTER adapter;
-	PHAL_DATA_TYPE hal;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RXAGG_CFG rxaggcfg;
-	HALMAC_RET_STATUS status;
-	int err = -1;
+	struct _ADAPTER *adapter;
+	struct hal_com_data *hal;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	struct halmac_rxagg_cfg rxaggcfg;
+	enum halmac_ret_status status;
 
 
 	adapter = dvobj_get_primary_adapter(d);
@@ -3941,12 +4457,29 @@ int rtw_halmac_rx_agg_switch(struct dvobj_priv *d, u8 enable)
 	halmac = dvobj_to_halmac(d);
 	api = HALMAC_GET_API(halmac);
 	_rtw_memset((void *)&rxaggcfg, 0, sizeof(rxaggcfg));
+	rxaggcfg.mode = HALMAC_RX_AGG_MODE_NONE;
+	/*
+	 * Always enable size limit to avoid rx size exceed
+	 * driver defined size.
+	 */
+	rxaggcfg.threshold.size_limit_en = 1;
 
+#ifdef RTW_RX_AGGREGATION
 	if (_TRUE == enable) {
 #ifdef CONFIG_SDIO_HCI
 		rxaggcfg.mode = HALMAC_RX_AGG_MODE_DMA;
 		rxaggcfg.threshold.drv_define = 0;
-#elif defined(CONFIG_USB_HCI) && defined(CONFIG_USB_RX_AGGREGATION)
+		if (hal->rxagg_dma_size || hal->rxagg_dma_timeout) {
+			rxaggcfg.threshold.drv_define = 1;
+			rxaggcfg.threshold.timeout = hal->rxagg_dma_timeout;
+			rxaggcfg.threshold.size = hal->rxagg_dma_size;
+			RTW_INFO("%s: RX aggregation threshold: "
+				 "timeout=%u size=%u\n",
+				 __FUNCTION__,
+				 hal->rxagg_dma_timeout,
+				 hal->rxagg_dma_size);
+		}
+#elif defined(CONFIG_USB_HCI)
 		switch (hal->rxagg_mode) {
 		case RX_AGG_DISABLE:
 			rxaggcfg.mode = HALMAC_RX_AGG_MODE_NONE;
@@ -3972,23 +4505,21 @@ int rtw_halmac_rx_agg_switch(struct dvobj_priv *d, u8 enable)
 			break;
 		}
 #endif /* CONFIG_USB_HCI */
-	} else
-		rxaggcfg.mode = HALMAC_RX_AGG_MODE_NONE;
+	}
+#endif /* RTW_RX_AGGREGATION */
 
 	status = api->halmac_cfg_rx_aggregation(halmac, &rxaggcfg);
 	if (status != HALMAC_RET_SUCCESS)
-		goto out;
+		return -1;
 
-	err = 0;
-out:
-	return err;
+	return 0;
 }
 
 int rtw_halmac_download_rsvd_page(struct dvobj_priv *dvobj, u8 pg_offset, u8 *pbuf, u32 size)
 {
-	HALMAC_RET_STATUS status = HALMAC_RET_SUCCESS;
-	PHALMAC_ADAPTER halmac = dvobj_to_halmac(dvobj);
-	PHALMAC_API api = HALMAC_GET_API(halmac);
+	enum halmac_ret_status status = HALMAC_RET_SUCCESS;
+	struct halmac_adapter *halmac = dvobj_to_halmac(dvobj);
+	struct halmac_api *api = HALMAC_GET_API(halmac);
 
 	status = api->halmac_dl_drv_rsvd_page(halmac, pg_offset, pbuf, size);
 	if (status != HALMAC_RET_SUCCESS)
@@ -4008,9 +4539,9 @@ int rtw_halmac_download_rsvd_page(struct dvobj_priv *dvobj, u8 pg_offset, u8 *pb
  */
 int rtw_halmac_fill_hal_spec(struct dvobj_priv *dvobj, struct hal_spec_t *spec)
 {
-	HALMAC_RET_STATUS status;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
+	enum halmac_ret_status status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
 	u8 cam = 0;	/* Security Cam Entry Number */
 
 
@@ -4028,12 +4559,12 @@ int rtw_halmac_fill_hal_spec(struct dvobj_priv *dvobj, struct hal_spec_t *spec)
 	return 0;
 }
 
-int rtw_halmac_p2pps(struct dvobj_priv *dvobj, PHAL_P2P_PS_PARA pp2p_ps_para)
+int rtw_halmac_p2pps(struct dvobj_priv *dvobj, struct hal_p2p_ps_para *pp2p_ps_para)
 {
-	HALMAC_RET_STATUS status = HALMAC_RET_SUCCESS;
-	PHALMAC_ADAPTER halmac = dvobj_to_halmac(dvobj);
-	PHALMAC_API api = HALMAC_GET_API(halmac);
-	HALMAC_P2PPS halmac_p2p_ps;
+	enum halmac_ret_status status = HALMAC_RET_SUCCESS;
+	struct halmac_adapter *halmac = dvobj_to_halmac(dvobj);
+	struct halmac_api *api = HALMAC_GET_API(halmac);
+	struct halmac_p2pps halmac_p2p_ps;
 
 	(&halmac_p2p_ps)->offload_en = pp2p_ps_para->offload_en;
 	(&halmac_p2p_ps)->role = pp2p_ps_para->role;
@@ -4042,6 +4573,7 @@ int rtw_halmac_p2pps(struct dvobj_priv *dvobj, PHAL_P2P_PS_PARA pp2p_ps_para)
 	(&halmac_p2p_ps)->noa_sel = pp2p_ps_para->noa_sel;
 	(&halmac_p2p_ps)->all_sta_sleep = pp2p_ps_para->all_sta_sleep;
 	(&halmac_p2p_ps)->discovery = pp2p_ps_para->discovery;
+	(&halmac_p2p_ps)->disable_close_rf = pp2p_ps_para->disable_close_rf;
 	(&halmac_p2p_ps)->p2p_port_id = _hw_port_drv2halmac(pp2p_ps_para->p2p_port_id);
 	(&halmac_p2p_ps)->p2p_group = pp2p_ps_para->p2p_group;
 	(&halmac_p2p_ps)->p2p_macid = pp2p_ps_para->p2p_macid;
@@ -4071,11 +4603,11 @@ int rtw_halmac_p2pps(struct dvobj_priv *dvobj, PHAL_P2P_PS_PARA pp2p_ps_para)
  */
 int rtw_halmac_iqk(struct dvobj_priv *d, u8 clear, u8 segment)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
-	HALMAC_FEATURE_ID id;
-	HALMAC_IQK_PARA para;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
+	struct halmac_iqk_para para;
 	int ret;
 	u8 retry = 3;
 	u8 delay = 1; /* ms */
@@ -4114,7 +4646,15 @@ int rtw_halmac_iqk(struct dvobj_priv *d, u8 clear, u8 segment)
 	return 0;
 }
 
-static int _phy_parameter_drv2halmac(struct rtw_phy_parameter *para, struct _HALMAC_PHY_PARAMETER_INFO *info)
+static inline u32 _phy_parameter_val_drv2halmac(u32 val, u8 msk_en, u32 msk)
+{
+	if (!msk_en)
+		return val;
+
+	return (val << bitshift(msk));
+}
+
+static int _phy_parameter_drv2halmac(struct rtw_phy_parameter *para, struct halmac_phy_parameter_info *info)
 {
 	if (!para || !info)
 		return -1;
@@ -4135,7 +4675,10 @@ static int _phy_parameter_drv2halmac(struct rtw_phy_parameter *para, struct _HAL
 			info->cmd_id = HALMAC_PARAMETER_CMD_MAC_W32;
 			break;
 		}
-		info->content.MAC_REG_W.value = para->data.mac.value;
+		info->content.MAC_REG_W.value = _phy_parameter_val_drv2halmac(
+							para->data.mac.value,
+							para->data.mac.msk_en,
+							para->data.mac.msk);
 		info->content.MAC_REG_W.msk = para->data.mac.msk;
 		info->content.MAC_REG_W.offset = para->data.mac.offset;
 		info->content.MAC_REG_W.msk_en = para->data.mac.msk_en;
@@ -4154,16 +4697,22 @@ static int _phy_parameter_drv2halmac(struct rtw_phy_parameter *para, struct _HAL
 			info->cmd_id = HALMAC_PARAMETER_CMD_BB_W32;
 			break;
 		}
-		info->content.BB_REG_W.value = para->data.mac.value;
-		info->content.BB_REG_W.msk = para->data.mac.msk;
-		info->content.BB_REG_W.offset = para->data.mac.offset;
-		info->content.BB_REG_W.msk_en = para->data.mac.msk_en;
+		info->content.BB_REG_W.value = _phy_parameter_val_drv2halmac(
+							para->data.bb.value,
+							para->data.bb.msk_en,
+							para->data.bb.msk);
+		info->content.BB_REG_W.msk = para->data.bb.msk;
+		info->content.BB_REG_W.offset = para->data.bb.offset;
+		info->content.BB_REG_W.msk_en = para->data.bb.msk_en;
 		break;
 
 	case 2:
 		/* RF register */
 		info->cmd_id = HALMAC_PARAMETER_CMD_RF_W;
-		info->content.RF_REG_W.value = para->data.rf.value;
+		info->content.RF_REG_W.value = _phy_parameter_val_drv2halmac(
+							para->data.rf.value,
+							para->data.rf.msk_en,
+							para->data.rf.msk);
 		info->content.RF_REG_W.msk = para->data.rf.msk;
 		info->content.RF_REG_W.offset = para->data.rf.offset;
 		info->content.RF_REG_W.msk_en = para->data.rf.msk_en;
@@ -4204,11 +4753,11 @@ static int _phy_parameter_drv2halmac(struct rtw_phy_parameter *para, struct _HAL
  */
 int rtw_halmac_cfg_phy_para(struct dvobj_priv *d, struct rtw_phy_parameter *para)
 {
-	struct _HALMAC_ADAPTER *mac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
-	enum _HALMAC_FEATURE_ID id;
-	struct _HALMAC_PHY_PARAMETER_INFO info;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_feature_id id;
+	struct halmac_phy_parameter_info info;
 	u8 full_fifo;
 	int err, ret;
 
@@ -4255,6 +4804,362 @@ int rtw_halmac_cfg_phy_para(struct dvobj_priv *d, struct rtw_phy_parameter *para
 	return ret;
 }
 
+static enum halmac_wlled_mode _led_mode_drv2halmac(u8 drv_mode)
+{
+	enum halmac_wlled_mode halmac_mode;
+
+
+	switch (drv_mode) {
+	case 1:
+		halmac_mode = HALMAC_WLLED_MODE_TX;
+		break;
+	case 2:
+		halmac_mode = HALMAC_WLLED_MODE_RX;
+		break;
+	case 3:
+		halmac_mode = HALMAC_WLLED_MODE_SW_CTRL;
+		break;
+	case 0:
+	default:
+		halmac_mode = HALMAC_WLLED_MODE_TRX;
+		break;
+	}
+
+	return halmac_mode;
+}
+
+/**
+ * rtw_halmac_led_cfg() - Configure Hardware LED Mode
+ * @d:		struct dvobj_priv*
+ * @enable:	enable or disable LED function
+ *		0: disable
+ *		1: enable
+ * @mode:	WLan LED mode (valid when enable==1)
+ *		0: Blink when TX(transmit packet) and RX(receive packet)
+ *		1: Blink when TX only
+ *		2: Blink when RX only
+ *		3: Software control
+ *
+ * Configure hardware WLan LED mode.
+ * If want to change LED mode after enabled, need to disable LED first and
+ * enable again to set new mode.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_led_cfg(struct dvobj_priv *d, u8 enable, u8 mode)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_wlled_mode led_mode;
+	enum halmac_ret_status status;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	if (enable) {
+		status = api->halmac_pinmux_set_func(halmac,
+						     HALMAC_GPIO_FUNC_WL_LED);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: pinmux set fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+
+		led_mode = _led_mode_drv2halmac(mode);
+		status = api->halmac_pinmux_wl_led_mode(halmac, led_mode);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: mode set fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+	} else {
+		/* Change LED to software control and turn off */
+		api->halmac_pinmux_wl_led_mode(halmac,
+					       HALMAC_WLLED_MODE_SW_CTRL);
+		api->halmac_pinmux_wl_led_sw_ctrl(halmac, 0);
+
+		status = api->halmac_pinmux_free_func(halmac,
+						      HALMAC_GPIO_FUNC_WL_LED);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: pinmux free fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+	}
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_led_switch() - Turn Hardware LED on/off
+ * @d:		struct dvobj_priv*
+ * @on:		LED light or not
+ *		0: Off
+ *		1: On(Light)
+ *
+ * Turn Hardware WLan LED On/Off.
+ * Before use this function, user should call rtw_halmac_led_ctrl() to switch
+ * mode to "software control(3)" first, otherwise control would fail.
+ * The interval between on and off must be longer than 1 ms, or the LED would
+ * keep light or dark only.
+ * Ex. Turn off LED at first, turn on after 0.5ms and turn off again after
+ * 0.5ms. The LED during this flow will only keep dark, and miss the turn on
+ * operation between two turn off operations.
+ */
+void rtw_halmac_led_switch(struct dvobj_priv *d, u8 on)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	api->halmac_pinmux_wl_led_sw_ctrl(halmac, on);
+}
+
+/**
+ * rtw_halmac_bt_wake_cfg() - Configure BT wake host function
+ * @d:		struct dvobj_priv*
+ * @enable:	enable or disable BT wake host function
+ *		0: disable
+ *		1: enable
+ *
+ * Configure pinmux to allow BT to control BT wake host pin.
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_bt_wake_cfg(struct dvobj_priv *d, u8 enable)
+{
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	halmac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(halmac);
+
+	if (enable) {
+		status = api->halmac_pinmux_set_func(halmac,
+						HALMAC_GPIO_FUNC_BT_HOST_WAKE1);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: pinmux set BT_HOST_WAKE1 fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+	} else {
+		status = api->halmac_pinmux_free_func(halmac,
+						HALMAC_GPIO_FUNC_BT_HOST_WAKE1);
+		if (status != HALMAC_RET_SUCCESS) {
+			RTW_ERR("%s: pinmux free BT_HOST_WAKE1 fail!(0x%x)\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+	}
+
+	return 0;
+}
+
+#ifdef CONFIG_PNO_SUPPORT
+/**
+ * _halmac_scanoffload() - Switch channel by firmware during scanning
+ * @d:		struct dvobj_priv*
+ * @enable:	1: enable, 0: disable
+ * @nlo:	1: nlo mode (no c2h event), 0: normal mode
+ * @ssid:	ssid of probe request
+ * @ssid_len:	ssid length
+ *
+ * Switch Channel and Send Porbe Request Offloaded by FW
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+static int _halmac_scanoffload(struct dvobj_priv *d, u32 enable, u8 nlo,
+			       u8 *ssid, u8 ssid_len)
+{
+	struct _ADAPTER *adapter;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	struct halmac_ch_info ch_info;
+	struct halmac_ch_switch_option cs_option;
+	struct mlme_ext_priv *pmlmeext;
+	enum halmac_feature_id id_update, id_ch_sw;
+	struct halmac_indicator *indicator, *tbl;
+
+	int err = 0;
+	u8 probereq[64];
+	u32 len = 0;
+	int i = 0;
+	struct pno_ssid pnossid;
+	struct rf_ctl_t *rfctl = NULL;
+	struct _RT_CHANNEL_INFO *ch_set;
+
+
+	tbl = d->hmpriv.indicator;
+	adapter = dvobj_get_primary_adapter(d);
+	mac = dvobj_to_halmac(d);
+	if (!mac)
+		return -1;
+	api = HALMAC_GET_API(mac);
+	id_update = HALMAC_FEATURE_UPDATE_PACKET;
+	id_ch_sw = HALMAC_FEATURE_CHANNEL_SWITCH;
+	pmlmeext = &(adapter->mlmeextpriv);
+	rfctl = adapter_to_rfctl(adapter);
+	ch_set = rfctl->channel_set;
+
+	RTW_INFO("%s: %s scanoffload, mode: %s\n",
+		 __FUNCTION__, enable?"Enable":"Disable",
+		 nlo?"PNO/NLO":"Normal");
+
+	if (enable) {
+		_rtw_memset(probereq, 0, sizeof(probereq));
+
+		_rtw_memset(&pnossid, 0, sizeof(pnossid));
+		if (ssid) {
+			if (ssid_len > sizeof(pnossid.SSID)) {
+				RTW_ERR("%s: SSID length(%d) is too long(>%d)!!\n",
+					__FUNCTION__, ssid_len, sizeof(pnossid.SSID));
+				return -1;
+			}
+
+			pnossid.SSID_len = ssid_len;
+			_rtw_memcpy(pnossid.SSID, ssid, ssid_len);
+		}
+
+		rtw_hal_construct_ProbeReq(adapter, probereq, &len, &pnossid);
+
+		if (!nlo) {
+			err = init_halmac_event(d, id_update, NULL, 0);
+			if (err)
+				return -1;
+		}
+
+		status = api->halmac_update_packet(mac, HALMAC_PACKET_PROBE_REQ,
+						   probereq, len);
+		if (status != HALMAC_RET_SUCCESS) {
+			if (!nlo)
+				free_halmac_event(d, id_update);
+			RTW_ERR("%s: halmac_update_packet FAIL(%d)!!\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+
+		if (!nlo) {
+			err = wait_halmac_event(d, id_update);
+			if (err)
+				RTW_ERR("%s: wait update packet FAIL(%d)!!\n",
+					__FUNCTION__, err);
+		}
+
+		api->halmac_clear_ch_info(mac);
+
+		for (i = 0; i < rfctl->max_chan_nums && ch_set[i].ChannelNum != 0; i++) {
+			_rtw_memset(&ch_info, 0, sizeof(ch_info));
+			ch_info.extra_info = 0;
+			ch_info.channel = ch_set[i].ChannelNum;
+			ch_info.bw = HALMAC_BW_20;
+			ch_info.pri_ch_idx = HALMAC_CH_IDX_1;
+			ch_info.action_id = HALMAC_CS_ACTIVE_SCAN;
+			ch_info.timeout = 1;
+			status = api->halmac_add_ch_info(mac, &ch_info);
+			if (status != HALMAC_RET_SUCCESS) {
+				RTW_ERR("%s: add_ch_info FAIL(%d)!!\n",
+					__FUNCTION__, status);
+				return -1;
+			}
+		}
+
+		/* set channel switch option */
+		_rtw_memset(&cs_option, 0, sizeof(cs_option));
+		cs_option.dest_bw = HALMAC_BW_20;
+		cs_option.periodic_option = HALMAC_CS_PERIODIC_2_PHASE;
+		cs_option.dest_pri_ch_idx = HALMAC_CH_IDX_UNDEFINE;
+		cs_option.tsf_low = 0;
+		cs_option.switch_en = 1;
+		cs_option.dest_ch_en = 1;
+		cs_option.absolute_time_en = 0;
+		cs_option.dest_ch = 1;
+
+		cs_option.normal_period = 5;
+		cs_option.normal_period_sel = 0;
+		cs_option.normal_cycle = 10;
+
+		cs_option.phase_2_period = 1;
+		cs_option.phase_2_period_sel = 1;
+
+		/* nlo is for wow fw,  1: no c2h response */
+		cs_option.nlo_en = nlo;
+
+		if (!nlo) {
+			err = init_halmac_event(d, id_ch_sw, NULL, 0);
+			if (err)
+				return -1;
+		}
+
+		status = api->halmac_ctrl_ch_switch(mac, &cs_option);
+		if (status != HALMAC_RET_SUCCESS) {
+			if (!nlo)
+				free_halmac_event(d, id_ch_sw);
+			RTW_ERR("%s: halmac_ctrl_ch_switch FAIL(%d)!!\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+
+		if (!nlo) {
+			err = wait_halmac_event(d, id_ch_sw);
+			if (err)
+				RTW_ERR("%s: wait ctrl_ch_switch FAIL(%d)!!\n",
+					__FUNCTION__, err);
+		}
+	} else {
+		api->halmac_clear_ch_info(mac);
+
+		_rtw_memset(&cs_option, 0, sizeof(cs_option));
+		cs_option.switch_en = 0;
+
+		if (!nlo) {
+			err = init_halmac_event(d, id_ch_sw, NULL, 0);
+			if (err)
+				return -1;
+		}
+
+		status = api->halmac_ctrl_ch_switch(mac, &cs_option);
+		if (status != HALMAC_RET_SUCCESS) {
+			if (!nlo)
+				free_halmac_event(d, id_ch_sw);
+			RTW_ERR("%s: halmac_ctrl_ch_switch FAIL(%d)!!\n",
+				__FUNCTION__, status);
+			return -1;
+		}
+
+		if (!nlo) {
+			err = wait_halmac_event(d, id_ch_sw);
+			if (err)
+				RTW_ERR("%s: wait ctrl_ch_switch FAIL(%d)!!\n",
+					__FUNCTION__, err);
+		}
+	}
+
+	return 0;
+}
+
+/**
+ * rtw_halmac_pno_scanoffload() - Control firmware scan AP function for PNO
+ * @d:		struct dvobj_priv*
+ * @enable:	1: enable, 0: disable
+ *
+ * Switch firmware scan AP function for PNO(prefer network offload) or
+ * NLO(network list offload).
+ *
+ * Rteurn 0 for OK, otherwise fail.
+ */
+int rtw_halmac_pno_scanoffload(struct dvobj_priv *d, u32 enable)
+{
+	return _halmac_scanoffload(d, enable, 1, NULL, 0);
+}
+#endif /* CONFIG_PNO_SUPPORT */
+
 #ifdef CONFIG_SDIO_HCI
 
 /*
@@ -4272,12 +5177,12 @@ int rtw_halmac_query_tx_page_num(struct dvobj_priv *d)
 {
 	PADAPTER adapter;
 	struct halmacpriv *hmpriv;
-	PHALMAC_ADAPTER halmac;
-	PHALMAC_API api;
-	HALMAC_RQPN_MAP rqpn;
-	HALMAC_DMA_MAPPING dmaqueue;
-	HALMAC_TXFF_ALLOCATION fifosize;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	struct halmac_rqpn_map rqpn;
+	enum halmac_dma_mapping dmaqueue;
+	struct halmac_txff_allocation fifosize;
+	enum halmac_ret_status status;
 	u8 i;
 
 
@@ -4376,9 +5281,9 @@ int rtw_halmac_get_tx_queue_page_num(struct dvobj_priv *d, u8 queue, u32 *page)
  */
 u32 rtw_halmac_sdio_get_tx_addr(struct dvobj_priv *d, u8 *desc, u32 size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u32 addr;
 
 
@@ -4394,9 +5299,9 @@ u32 rtw_halmac_sdio_get_tx_addr(struct dvobj_priv *d, u8 *desc, u32 size)
 
 int rtw_halmac_sdio_tx_allowed(struct dvobj_priv *d, u8 *buf, u32 size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 
 
 	mac = dvobj_to_halmac(d);
@@ -4425,9 +5330,9 @@ u32 rtw_halmac_sdio_get_rx_addr(struct dvobj_priv *d, u8 *seq)
 #ifdef CONFIG_USB_HCI
 u8 rtw_halmac_usb_get_bulkout_id(struct dvobj_priv *d, u8 *buf, u32 size)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u8 bulkout_id;
 
 
@@ -4452,9 +5357,9 @@ u8 rtw_halmac_usb_get_bulkout_id(struct dvobj_priv *d, u8 *buf, u32 size)
  */
 int rtw_halmac_usb_get_txagg_desc_num(struct dvobj_priv *d, u8 *num)
 {
-	struct _HALMAC_ADAPTER *halmac;
-	struct _HALMAC_API *api;
-	enum _HALMAC_RET_STATUS status;
+	struct halmac_adapter *halmac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
 	u8 val = 0;
 
 
@@ -4470,9 +5375,9 @@ int rtw_halmac_usb_get_txagg_desc_num(struct dvobj_priv *d, u8 *num)
 	return 0;
 }
 
-static inline HALMAC_USB_MODE _usb_mode_drv2halmac(enum RTW_USB_SPEED usb_mode)
+static inline enum halmac_usb_mode _usb_mode_drv2halmac(enum RTW_USB_SPEED usb_mode)
 {
-	HALMAC_USB_MODE halmac_usb_mode = HALMAC_USB_MODE_U2;
+	enum halmac_usb_mode halmac_usb_mode = HALMAC_USB_MODE_U2;
 
 	switch (usb_mode) {
 	case RTW_USB_SPEED_2:
@@ -4491,11 +5396,11 @@ static inline HALMAC_USB_MODE _usb_mode_drv2halmac(enum RTW_USB_SPEED usb_mode)
 
 u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode)
 {
-	PHALMAC_ADAPTER mac;
-	PHALMAC_API api;
-	HALMAC_RET_STATUS status;
 	PADAPTER adapter;
-	HALMAC_USB_MODE halmac_usb_mode;
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	enum halmac_usb_mode halmac_usb_mode;
 
 	adapter = dvobj_get_primary_adapter(d);
 	mac = dvobj_to_halmac(d);
@@ -4509,3 +5414,143 @@ u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode)
 	return _SUCCESS;
 }
 #endif /* CONFIG_USB_HCI */
+
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+int rtw_halmac_bf_add_mu_bfer(struct dvobj_priv *d, u16 paid, u16 csi_para,
+		u16 my_aid, enum halmac_csi_seg_len sel, u8 *addr)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	struct halmac_mu_bfer_init_para param;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	_rtw_memset(&param, 0, sizeof(param));
+	param.paid = paid;
+	param.csi_para = csi_para;
+	param.my_aid = my_aid;
+	param.csi_length_sel = sel;
+	_rtw_memcpy(param.bfer_address.addr, addr, 6);
+
+	status = api->halmac_mu_bfer_entry_init(mac, &param);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_del_mu_bfer(struct dvobj_priv *d)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_mu_bfer_entry_del(mac);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+
+int rtw_halmac_bf_cfg_sounding(struct dvobj_priv *d,
+		enum halmac_snd_role role, enum halmac_data_rate rate)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_cfg_sounding(mac, role, rate);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_del_sounding(struct dvobj_priv *d,
+		enum halmac_snd_role role)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_del_sounding(mac, role);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_cfg_csi_rate(struct dvobj_priv *d,
+		u8 rssi, u8 current_rate, u8 fixrate_en,
+		u8 *new_rate)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	status = api->halmac_cfg_csi_rate(mac,
+			rssi, current_rate, fixrate_en, new_rate);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+int rtw_halmac_bf_cfg_mu_mimo(struct dvobj_priv *d, enum halmac_snd_role role,
+		u8 *sounding_sts, u16 grouping_bitmap, u8 mu_tx_en,
+		u32 *given_gid_tab, u32 *given_user_pos)
+{
+	struct halmac_adapter *mac;
+	struct halmac_api *api;
+	enum halmac_ret_status status;
+	struct halmac_cfg_mumimo_para param;
+
+
+	mac = dvobj_to_halmac(d);
+	api = HALMAC_GET_API(mac);
+
+	_rtw_memset(&param, 0, sizeof(param));
+
+	param.role = role;
+	param.grouping_bitmap = grouping_bitmap;
+	param.mu_tx_en = mu_tx_en;
+
+	if (sounding_sts)
+		_rtw_memcpy(param.sounding_sts, sounding_sts, 6);
+
+	if (given_gid_tab)
+		_rtw_memcpy(param.given_gid_tab, given_gid_tab, 8);
+
+	if (given_user_pos)
+		_rtw_memcpy(param.given_user_pos, given_user_pos, 16);
+
+	status = api->halmac_cfg_mumimo(mac, &param);
+	if (status != HALMAC_RET_SUCCESS)
+		return -1;
+
+	return 0;
+}
+
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.h
index c08d7b6c0055..24e00785a322 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_halmac.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2015 - 2017 Realtek Corporation.
+ * Copyright(c) 2015 - 2018 Realtek Corporation.
  *
  * 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
@@ -17,14 +18,14 @@
 
 #include <drv_types.h>		/* adapter_to_dvobj(), struct intf_hdl and etc. */
 #include <hal_data.h>		/* struct hal_spec_t */
-#include "halmac/halmac_api.h"	/* PHALMAC_ADAPTER and etc. */
+#include "halmac/halmac_api.h"	/* struct halmac_adapter* and etc. */
 
 /* HALMAC Definition for Driver */
 #define RTW_HALMAC_H2C_MAX_SIZE		8
 #define RTW_HALMAC_BA_SSN_RPT_SIZE	4
 
 #define dvobj_set_halmac(d, mac)	((d)->halmac = (mac))
-#define dvobj_to_halmac(d)		((PHALMAC_ADAPTER)((d)->halmac))
+#define dvobj_to_halmac(d)		((struct halmac_adapter *)((d)->halmac))
 #define adapter_to_halmac(p)		dvobj_to_halmac(adapter_to_dvobj(p))
 
 /* for H2C cmd */
@@ -39,10 +40,10 @@ typedef enum _RTW_HALMAC_MODE {
 
 union rtw_phy_para_data {
 	struct _mac {
-		u32	value;
-		u32	msk;
-		u16	offset;
-		u8	msk_en;	/* Enable bit mask(msk) or not */
+		u32	value;	/* value to be set in bit mask(msk) */
+		u32	msk;	/* bit mask */
+		u16	offset; /* address */
+		u8	msk_en;	/* 0/1 for msk invalid/valid */
 		u8	size;	/* Unit is bytes, and value should be 1/2/4 */
 	} mac;
 	struct _bb {
@@ -97,7 +98,7 @@ struct rtw_halmac_bcn_ctrl {
 	u8 p2p_bcn_area:1;	/* Enable P2P BCN area on function */
 };
 
-extern HALMAC_PLATFORM_API rtw_halmac_platform_api;
+extern struct halmac_platform_api rtw_halmac_platform_api;
 
 /* HALMAC API for Driver(HAL) */
 u8 rtw_halmac_read8(struct intf_hdl *, u32 addr);
@@ -117,11 +118,11 @@ int rtw_halmac_write32(struct intf_hdl *, u32 addr, u32 value);
 void rtw_halmac_get_version(char *str, u32 len);
 
 /* Software Initialization */
-int rtw_halmac_init_adapter(struct dvobj_priv *, PHALMAC_PLATFORM_API);
+int rtw_halmac_init_adapter(struct dvobj_priv *d, struct halmac_platform_api *pf_api);
 int rtw_halmac_deinit_adapter(struct dvobj_priv *);
 
 /* Get operations */
-int rtw_halmac_get_hw_value(struct dvobj_priv *, HALMAC_HW_ID hw_id, VOID *pvalue);
+int rtw_halmac_get_hw_value(struct dvobj_priv *d, enum halmac_hw_id hw_id, void *pvalue);
 int rtw_halmac_get_tx_fifo_size(struct dvobj_priv *d, u32 *size);
 int rtw_halmac_get_rx_fifo_size(struct dvobj_priv *d, u32 *size);
 int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *d, u16 *bndy);
@@ -140,7 +141,7 @@ int rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport, struct r
 /*int rtw_halmac_get_wow_reason(struct dvobj_priv *, u8 *reason);*/
 
 /* Set operations */
-int rtw_halmac_config_rx_info(struct dvobj_priv *, HALMAC_DRV_INFO);
+int rtw_halmac_config_rx_info(struct dvobj_priv *d, enum halmac_drv_info info);
 int rtw_halmac_set_max_dl_fw_size(struct dvobj_priv *d, u32 size);
 int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
 int rtw_halmac_set_bssid(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
@@ -152,6 +153,7 @@ int rtw_halmac_set_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport, struct r
 int rtw_halmac_set_aid(struct dvobj_priv *d, enum _hw_port hwport, u16 aid);
 int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8 bw);
 int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop);
+int rtw_halmac_set_rts_full_bw(struct dvobj_priv *d, u8 enable);
 
 /* Functions */
 int rtw_halmac_poweron(struct dvobj_priv *);
@@ -194,6 +196,12 @@ int rtw_halmac_fill_hal_spec(struct dvobj_priv *, struct hal_spec_t *);
 int rtw_halmac_p2pps(struct dvobj_priv *dvobj, PHAL_P2P_PS_PARA pp2p_ps_para);
 int rtw_halmac_iqk(struct dvobj_priv *d, u8 clear, u8 segment);
 int rtw_halmac_cfg_phy_para(struct dvobj_priv *d, struct rtw_phy_parameter *para);
+int rtw_halmac_led_cfg(struct dvobj_priv *d, u8 enable, u8 mode);
+void rtw_halmac_led_switch(struct dvobj_priv *d, u8 on);
+int rtw_halmac_bt_wake_cfg(struct dvobj_priv *d, u8 enable);
+#ifdef CONFIG_PNO_SUPPORT
+int rtw_halmac_pno_scanoffload(struct dvobj_priv *d, u32 enable);
+#endif
 
 #ifdef CONFIG_SDIO_HCI
 int rtw_halmac_query_tx_page_num(struct dvobj_priv *);
@@ -212,4 +220,27 @@ u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode)
 #ifdef CONFIG_SUPPORT_TRX_SHARED
 void dump_trx_share_mode(void *sel, _adapter *adapter);
 #endif
+
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+int rtw_halmac_bf_add_mu_bfer(struct dvobj_priv *d, u16 paid, u16 csi_para,
+		u16 my_aid, enum halmac_csi_seg_len sel, u8 *addr);
+int rtw_halmac_bf_del_mu_bfer(struct dvobj_priv *d);
+
+int rtw_halmac_bf_cfg_sounding(struct dvobj_priv *d, enum halmac_snd_role role,
+		enum halmac_data_rate rate);
+int rtw_halmac_bf_del_sounding(struct dvobj_priv *d, enum halmac_snd_role role);
+
+int rtw_halmac_bf_cfg_csi_rate(struct dvobj_priv *d, u8 rssi, u8 current_rate,
+		u8 fixrate_en, u8 *new_rate);
+
+int rtw_halmac_bf_cfg_mu_mimo(struct dvobj_priv *d, enum halmac_snd_role role,
+		u8 *sounding_sts, u16 grouping_bitmap, u8 mu_tx_en,
+		u32 *given_gid_tab, u32 *given_user_pos);
+#define rtw_halmac_bf_cfg_mu_bfee(d, gid_tab, user_pos) \
+	rtw_halmac_bf_cfg_mu_mimo(d, HAL_BFEE, NULL, 0, 0, gid_tab, user_pos)
+
+#endif /* RTW_BEAMFORMING_VERSION_2 */
+#endif /* CONFIG_BEAMFORMING */
+
 #endif /* _HAL_HALMAC_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_hci/hal_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_hci/hal_sdio.c
index 9bcd8cee3da9..6a98edc250b3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_hci/hal_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_hci/hal_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -158,7 +159,7 @@ void rtw_hal_sdio_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 Required
 	/* _exit_critical_bh(&pHalData->SdioTxFIFOFreePageLock, &irql); */
 }
 
-void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ)
+void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ, u8 div_num)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
 	u32	page_size;
@@ -166,9 +167,9 @@ void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 nu
 
 	rtw_hal_get_def_var(padapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
 
-	lenHQ = ((numHQ + numPubQ) >> 1) * page_size;
-	lenNQ = ((numNQ + numPubQ) >> 1) * page_size;
-	lenLQ = ((numLQ + numPubQ) >> 1) * page_size;
+	lenHQ = ((numHQ + numPubQ) / div_num) * page_size;
+	lenNQ = ((numNQ + numPubQ) / div_num) * page_size;
+	lenLQ = ((numLQ + numPubQ) / div_num) * page_size;
 
 	pHalData->sdio_tx_max_len[HI_QUEUE_IDX] = (lenHQ > MAX_XMITBUF_SZ) ? MAX_XMITBUF_SZ : lenHQ;
 	pHalData->sdio_tx_max_len[MID_QUEUE_IDX] = (lenNQ > MAX_XMITBUF_SZ) ? MAX_XMITBUF_SZ : lenNQ;
@@ -231,4 +232,473 @@ exit:
 }
 #endif
 
+#ifdef CONFIG_SDIO_CHK_HCI_RESUME
+
+#ifndef SDIO_HCI_RESUME_PWR_RDY_TIMEOUT_MS
+	#define SDIO_HCI_RESUME_PWR_RDY_TIMEOUT_MS 200
+#endif
+#ifndef DBG_SDIO_CHK_HCI_RESUME
+	#define DBG_SDIO_CHK_HCI_RESUME 0
+#endif
+
+bool sdio_chk_hci_resume(struct intf_hdl *pintfhdl)
+{
+	_adapter *adapter = pintfhdl->padapter;
+	u8 hci_sus_state;
+	u8 sus_ctl, sus_ctl_ori = 0xEA;
+	u8 do_leave = 0;
+	systime start = 0, end = 0;
+	u32 poll_cnt = 0;
+	u8 timeout = 0;
+	u8 sr = 0;
+	s32 err = 0;
+
+	rtw_hal_get_hwreg(adapter, HW_VAR_HCI_SUS_STATE, &hci_sus_state);
+	if (hci_sus_state == HCI_SUS_LEAVE || hci_sus_state == HCI_SUS_ERR)
+		goto no_hdl;
+
+	err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_HSUS_CTRL), 1, &sus_ctl);
+	if (err)
+		goto exit;
+	sus_ctl_ori = sus_ctl;
+
+	if ((sus_ctl & HCI_RESUME_PWR_RDY) && !(sus_ctl & HCI_SUS_CTRL))
+		goto exit;
+
+	if (sus_ctl & HCI_SUS_CTRL) {
+		sus_ctl &= ~(HCI_SUS_CTRL);
+		err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_HSUS_CTRL), 1, &sus_ctl);
+		if (err)
+			goto exit;
+	}
+
+	do_leave = 1;
+
+	/* polling for HCI_RESUME_PWR_RDY && !HCI_SUS_CTRL */
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(adapter)) {
+			sr = 1;
+			break;
+		}
+
+		err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_HSUS_CTRL), 1, &sus_ctl);
+		poll_cnt++;
+
+		if (!err && (sus_ctl & HCI_RESUME_PWR_RDY) && !(sus_ctl & HCI_SUS_CTRL))
+			break;
+
+		if (rtw_get_passing_time_ms(start) > SDIO_HCI_RESUME_PWR_RDY_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+	end = rtw_get_current_time();
+
+exit:
+
+	if (DBG_SDIO_CHK_HCI_RESUME) {
+		RTW_INFO(FUNC_ADPT_FMT" hci_sus_state:%u, sus_ctl:0x%02x(0x%02x), do_leave:%u, to:%u, err:%u\n"
+			, FUNC_ADPT_ARG(adapter), hci_sus_state, sus_ctl, sus_ctl_ori, do_leave, timeout, err);
+		if (start != 0 || end != 0) {
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms, cnt:%u\n"
+				, FUNC_ADPT_ARG(adapter), rtw_get_time_interval_ms(start, end), poll_cnt);
+		}
+	}
+
+	if (timeout) {
+		RTW_ERR(FUNC_ADPT_FMT" timeout(err:%d) sus_ctl:0x%02x\n"
+			, FUNC_ADPT_ARG(adapter), err, sus_ctl);
+	} else if (err) {
+		RTW_ERR(FUNC_ADPT_FMT" err:%d\n"
+			, FUNC_ADPT_ARG(adapter), err);
+	}
+
+no_hdl:
+	return do_leave ? _TRUE : _FALSE;
+}
+
+void sdio_chk_hci_suspend(struct intf_hdl *pintfhdl)
+{
+#define SDIO_CHK_HCI_SUSPEND_POLLING 0
+
+	_adapter *adapter = pintfhdl->padapter;
+	u8 hci_sus_state;
+	u8 sus_ctl, sus_ctl_ori = 0xEA;
+	systime start = 0, end = 0;
+	u32 poll_cnt = 0;
+	u8 timeout = 0;
+	u8 sr = 0;
+	s32 err = 0;
+	u8 device_id;
+	u16 offset;
+
+	rtw_hal_get_hwreg(adapter, HW_VAR_HCI_SUS_STATE, &hci_sus_state);
+	if (hci_sus_state == HCI_SUS_LEAVE || hci_sus_state == HCI_SUS_LEAVING || hci_sus_state == HCI_SUS_ERR)
+		goto no_hdl;
+
+	err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_HSUS_CTRL), 1, &sus_ctl);
+	if (err)
+		goto exit;
+	sus_ctl_ori = sus_ctl;
+
+	if (!(sus_ctl & HCI_RESUME_PWR_RDY))
+		goto exit;
+
+	sus_ctl |= HCI_SUS_CTRL;
+	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_HSUS_CTRL), 1, &sus_ctl);
+	if (err)
+		goto exit;
+
+#if SDIO_CHK_HCI_SUSPEND_POLLING
+	/* polling for HCI_RESUME_PWR_RDY cleared */
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(adapter)) {
+			sr = 1;
+			break;
+		}
+
+		err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_HSUS_CTRL), 1, &sus_ctl);
+		poll_cnt++;
+
+		if (!err && !(sus_ctl & HCI_RESUME_PWR_RDY))
+			break;
+
+		if (rtw_get_passing_time_ms(start) > SDIO_HCI_RESUME_PWR_RDY_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+	end = rtw_get_current_time();
+#endif /* SDIO_CHK_HCI_SUSPEND_POLLING */
+
+exit:
+
+	if (DBG_SDIO_CHK_HCI_RESUME) {
+		RTW_INFO(FUNC_ADPT_FMT" hci_sus_state:%u, sus_ctl:0x%02x(0x%02x), to:%u, err:%u\n"
+			, FUNC_ADPT_ARG(adapter), hci_sus_state, sus_ctl, sus_ctl_ori, timeout, err);
+		if (start != 0 || end != 0) {
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms, cnt:%u\n"
+				, FUNC_ADPT_ARG(adapter), rtw_get_time_interval_ms(start, end), poll_cnt);
+		}
+	}
+
+#if SDIO_CHK_HCI_SUSPEND_POLLING
+	if (timeout) {
+		RTW_ERR(FUNC_ADPT_FMT" timeout(err:%d) sus_ctl:0x%02x\n"
+			, FUNC_ADPT_ARG(adapter), err, sus_ctl);
+	} else
+#endif
+		if (err) {
+			RTW_ERR(FUNC_ADPT_FMT" err:%d\n"
+				, FUNC_ADPT_ARG(adapter), err);
+		}
+
+no_hdl:
+	return;
+}
+#endif /* CONFIG_SDIO_CHK_HCI_RESUME */
+
+
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+
+/* program indirect access register in sdio local to read/write page0 registers */
+#ifndef INDIRECT_ACCESS_TIMEOUT_MS
+	#define INDIRECT_ACCESS_TIMEOUT_MS 200
+#endif
+#ifndef DBG_SDIO_INDIRECT_ACCESS
+	#define DBG_SDIO_INDIRECT_ACCESS 0
+#endif
+
+s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v)
+{
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
+	_mutex *mutex = &adapter_to_dvobj(padapter)->sd_indirect_access_mutex;
+
+	u8 val[4] = {0};
+	u8 cmd[4] = {0}; /* mapping to indirect access register, little endien */
+	systime start = 0, end = 0;
+	u8 timeout = 0;
+	u8 sr = 0;
+	s32 err = 0;
+
+	if (size == 1)
+		SET_INDIRECT_REG_SIZE_1BYTE(cmd);
+	else if (size == 2)
+		SET_INDIRECT_REG_SIZE_2BYTE(cmd);
+	else if (size == 4)
+		SET_INDIRECT_REG_SIZE_4BYTE(cmd);
+
+	SET_INDIRECT_REG_ADDR(cmd, addr);
+
+	/* acquire indirect access lock */
+	_enter_critical_mutex(mutex, NULL);
+
+	if (DBG_SDIO_INDIRECT_ACCESS)
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+
+	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG), 3, cmd);
+	if (err)
+		goto exit;
+
+	/* trigger */
+	SET_INDIRECT_REG_READ(cmd);
+
+	if (DBG_SDIO_INDIRECT_ACCESS)
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+
+	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG + 2), 1, cmd + 2);
+	if (err)
+		goto exit;
+
+	/* polling for indirect access done */
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(padapter)) {
+			sr = 1;
+			break;
+		}
+
+		err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG + 2), 1, cmd + 2);
+
+		if (!err && GET_INDIRECT_REG_RDY(cmd))
+			break;
+
+		if (rtw_get_passing_time_ms(start) > INDIRECT_ACCESS_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+	end = rtw_get_current_time();
+
+	if (timeout || sr)
+		goto exit;
+
+	/* read result */
+	err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_DATA), size, val);
+	if (size == 2)
+		*((u16 *)(val)) = le16_to_cpu(*((u16 *)(val)));
+	else if (size == 4)
+		*((u32 *)(val)) = le32_to_cpu(*((u32 *)(val)));
+
+	if (DBG_SDIO_INDIRECT_ACCESS) {
+		if (size == 1)
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%02x\n", FUNC_ADPT_ARG(padapter), *((u8 *)(val)));
+		else if (size == 2)
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%04x\n", FUNC_ADPT_ARG(padapter), *((u16 *)(val)));
+		else if (size == 4)
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%08x\n", FUNC_ADPT_ARG(padapter), *((u32 *)(val)));
+	}
+
+exit:
+	/* release indirect access lock */
+	_exit_critical_mutex(mutex, NULL);
+
+	if (DBG_SDIO_INDIRECT_ACCESS) {
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%0x size:%u, cmd:%02x %02x %02x %02x, to:%u, err:%u\n"
+			, FUNC_ADPT_ARG(padapter), addr, size, cmd[0], cmd[1], cmd[2], cmd[3], timeout, err);
+		if (start != 0 || end != 0) {
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms\n"
+				, FUNC_ADPT_ARG(padapter), rtw_get_time_interval_ms(start, end));
+		}
+	}
+
+	if (timeout) {
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x timeout(err:%d), cmd\n"
+			, FUNC_ADPT_ARG(padapter), addr, err);
+		if (!err)
+			err = -1; /* just for return value */
+	} else if (err) {
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x err:%d\n"
+			, FUNC_ADPT_ARG(padapter), addr, err);
+	} else if (sr) {
+		/* just for return value */
+		err = -1;
+	}
+
+	if (!err && !timeout && !sr)
+		_rtw_memcpy(v, val, size);
+
+	return err;
+}
+
+s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v)
+{
+	struct intf_hdl *pintfhdl = &padapter->iopriv.intf;
+	_mutex *mutex = &adapter_to_dvobj(padapter)->sd_indirect_access_mutex;
+
+	u8 val[4] = {0};
+	u8 cmd[4] = {0}; /* mapping to indirect access register, little endien */
+	systime start = 0, end = 0;
+	u8 timeout = 0;
+	u8 sr = 0;
+	s32 err = 0;
+
+	if (size == 1)
+		SET_INDIRECT_REG_SIZE_1BYTE(cmd);
+	else if (size == 2)
+		SET_INDIRECT_REG_SIZE_2BYTE(cmd);
+	else if (size == 4)
+		SET_INDIRECT_REG_SIZE_4BYTE(cmd);
+
+	SET_INDIRECT_REG_ADDR(cmd, addr);
+
+	/* acquire indirect access lock */
+	_enter_critical_mutex(mutex, NULL);
+
+	if (DBG_SDIO_INDIRECT_ACCESS)
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+
+	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG), 3, cmd);
+	if (err)
+		goto exit;
+
+	/* data to write */
+	_rtw_memcpy(val, v, size);
+
+	if (DBG_SDIO_INDIRECT_ACCESS) {
+		if (size == 1)
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%02x\n", FUNC_ADPT_ARG(padapter), *((u8 *)(val)));
+		else if (size == 2)
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%04x\n", FUNC_ADPT_ARG(padapter), *((u16 *)(val)));
+		else if (size == 4)
+			RTW_INFO(FUNC_ADPT_FMT" val:0x%08x\n", FUNC_ADPT_ARG(padapter), *((u32 *)(val)));
+	}
+
+	if (size == 2)
+		*((u16 *)(val)) = cpu_to_le16(*((u16 *)(val)));
+	else if (size == 4)
+		*((u32 *)(val)) = cpu_to_le32(*((u32 *)(val)));
+
+	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_DATA), size, val);
+	if (err)
+		goto exit;
+
+	/* trigger */
+	SET_INDIRECT_REG_WRITE(cmd);
+
+	if (DBG_SDIO_INDIRECT_ACCESS)
+		RTW_INFO(FUNC_ADPT_FMT" cmd:%02x %02x %02x %02x\n", FUNC_ADPT_ARG(padapter), cmd[0], cmd[1], cmd[2], cmd[3]);
+
+	err = sd_cmd52_write(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG + 2), 1, cmd + 2);
+	if (err)
+		goto exit;
+
+	/* polling for indirect access done */
+	start = rtw_get_current_time();
+	while (1) {
+		if (rtw_is_surprise_removed(padapter)) {
+			sr = 1;
+			break;
+		}
+
+		err = sd_cmd52_read(pintfhdl, SDIO_LOCAL_CMD_ADDR(SDIO_REG_INDIRECT_REG_CFG + 2), 1, cmd + 2);
+
+		if (!err && GET_INDIRECT_REG_RDY(cmd))
+			break;
+
+		if (rtw_get_passing_time_ms(start) > INDIRECT_ACCESS_TIMEOUT_MS) {
+			timeout = 1;
+			break;
+		}
+	}
+	end = rtw_get_current_time();
+
+	if (timeout || sr)
+		goto exit;
+
+exit:
+	/* release indirect access lock */
+	_exit_critical_mutex(mutex, NULL);
+
+	if (DBG_SDIO_INDIRECT_ACCESS) {
+		RTW_INFO(FUNC_ADPT_FMT" addr:0x%0x size:%u, cmd:%02x %02x %02x %02x, to:%u, err:%u\n"
+			, FUNC_ADPT_ARG(padapter), addr, size, cmd[0], cmd[1], cmd[2], cmd[3], timeout, err);
+		if (start != 0 || end != 0) {
+			RTW_INFO(FUNC_ADPT_FMT" polling %d ms\n"
+				, FUNC_ADPT_ARG(padapter), rtw_get_time_interval_ms(start, end));
+		}
+	}
+
+	if (timeout) {
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x timeout(err:%d), cmd\n"
+			, FUNC_ADPT_ARG(padapter), addr, err);
+		if (!err)
+			err = -1; /* just for return value */
+	} else if (err) {
+		RTW_ERR(FUNC_ADPT_FMT" addr:0x%0x err:%d\n"
+			, FUNC_ADPT_ARG(padapter), addr, err);
+	} else if (sr) {
+		/* just for return value */
+		err = -1;
+	}
+
+	return err;
+}
+
+u8 sdio_iread8(struct intf_hdl *pintfhdl, u32 addr)
+{
+	u8 val;
+
+	if (sdio_iread(pintfhdl->padapter, addr, 1, (u8 *)&val) != 0)
+		val = SDIO_ERR_VAL8;
+
+	return val;
+}
+
+u16 sdio_iread16(struct intf_hdl *pintfhdl, u32 addr)
+{
+	u16 val;
+
+	if (sdio_iread(pintfhdl->padapter, addr, 2, (u8 *)&val) != 0)
+		val = SDIO_ERR_VAL16;
+
+	return val;
+}
+
+u32 sdio_iread32(struct intf_hdl *pintfhdl, u32 addr)
+{
+	u32 val;
+
+	if (sdio_iread(pintfhdl->padapter, addr, 4, (u8 *)&val) != 0)
+		val = SDIO_ERR_VAL32;
+
+	return val;
+}
+
+s32 sdio_iwrite8(struct intf_hdl *pintfhdl, u32 addr, u8 val)
+{
+	return sdio_iwrite(pintfhdl->padapter, addr, 1, (u8 *)&val);
+}
+
+s32 sdio_iwrite16(struct intf_hdl *pintfhdl, u32 addr, u16 val)
+{
+	return sdio_iwrite(pintfhdl->padapter, addr, 2, (u8 *)&val);
+}
+
+s32 sdio_iwrite32(struct intf_hdl *pintfhdl, u32 addr, u32 val)
+{
+	return sdio_iwrite(pintfhdl->padapter, addr, 4, (u8 *)&val);
+}
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+u32 cmd53_4byte_alignment(struct intf_hdl *pintfhdl, u32 addr)
+{
+	u32 addr_rdr;
+	u32 value;
+
+	value = 0;
+	addr_rdr = addr % 4;
+
+	if (addr_rdr) {
+		u8 shift_bit;
+
+		shift_bit = addr_rdr * 8;
+		value = (sd_read32(pintfhdl, (addr - addr_rdr), NULL)) >> shift_bit;
+	} else
+		value = sd_read32(pintfhdl, addr, NULL);
+	
+	return value;
+}
+
 #endif /* !RTW_HALMAC */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_intf.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_intf.c
index b460341c0248..3f2bc0ac7ce8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_intf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_intf.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -28,9 +29,12 @@ const u32 _chip_type_to_odm_ic_type[] = {
 	ODM_RTL8814A,
 	ODM_RTL8703B,
 	ODM_RTL8188F,
+	ODM_RTL8188F,
 	ODM_RTL8822B,
 	ODM_RTL8723D,
 	ODM_RTL8821C,
+	ODM_RTL8710B,
+	ODM_RTL8192F,
 	0,
 };
 
@@ -75,12 +79,56 @@ void rtw_hal_read_chip_version(_adapter *padapter)
 	rtw_odm_init_ic_type(padapter);
 }
 
+static void rtw_init_wireless_mode(_adapter *padapter)
+{
+	u8 proto_wireless_mode = 0;
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
+	if(hal_spec->proto_cap & PROTO_CAP_11B)
+		proto_wireless_mode |= WIRELESS_11B;
+	
+	if(hal_spec->proto_cap & PROTO_CAP_11G)
+		proto_wireless_mode |= WIRELESS_11G;
+#ifdef CONFIG_80211AC_VHT
+	if(hal_spec->band_cap & BAND_CAP_5G)
+		proto_wireless_mode |= WIRELESS_11A;
+#endif
+
+#ifdef CONFIG_80211N_HT
+	if(hal_spec->proto_cap & PROTO_CAP_11N) {
+
+		if(hal_spec->band_cap & BAND_CAP_2G)
+			proto_wireless_mode |= WIRELESS_11_24N;
+		if(hal_spec->band_cap & BAND_CAP_5G)
+			proto_wireless_mode |= WIRELESS_11_5N;
+	}
+#endif
+
+#ifdef CONFIG_80211AC_VHT
+	if(hal_spec->proto_cap & PROTO_CAP_11AC) 
+		proto_wireless_mode |= WIRELESS_11AC;
+#endif
+	padapter->registrypriv.wireless_mode &= proto_wireless_mode;
+}
+
 void rtw_hal_def_value_init(_adapter *padapter)
 {
 	if (is_primary_adapter(padapter)) {
+		/*init fw_psmode_iface_id*/
+		adapter_to_pwrctl(padapter)->fw_psmode_iface_id = 0xff;
+		/*wireless_mode*/
+		rtw_init_wireless_mode(padapter);
 		padapter->hal_func.init_default_value(padapter);
 
 		rtw_init_hal_com_default_value(padapter);
+		
+		#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+		adapter_to_dvobj(padapter)->dft.port_id = 0xFF;
+		adapter_to_dvobj(padapter)->dft.mac_id = 0xFF;
+		#endif
+		#ifdef CONFIG_HW_P0_TSF_SYNC
+		adapter_to_dvobj(padapter)->p0_tsf.sync_port = MAX_HW_PORT;
+		adapter_to_dvobj(padapter)->p0_tsf.offset = 0;
+		#endif
 
 		{
 			struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
@@ -92,6 +140,7 @@ void rtw_hal_def_value_init(_adapter *padapter)
 			dvobj->cam_ctl.sec_cap = hal_spec->sec_cap;
 			dvobj->cam_ctl.num = rtw_min(hal_spec->sec_cam_ent_num, SEC_CAM_ENT_NUM_SW_LIMIT);
 		}
+		GET_HAL_DATA(padapter)->rx_tsf_addr_filter_config = 0;
 	}
 }
 
@@ -104,6 +153,7 @@ u8 rtw_hal_data_init(_adapter *padapter)
 			RTW_INFO("cant not alloc memory for HAL DATA\n");
 			return _FAIL;
 		}
+		rtw_phydm_priv_init(padapter);
 	}
 	return _SUCCESS;
 }
@@ -149,15 +199,35 @@ void rtw_hal_dm_deinit(_adapter *padapter)
 		_rtw_spinlock_free(&pHalData->IQKSpinLock);
 	}
 }
+
 #ifdef CONFIG_RTW_SW_LED
-void	rtw_hal_sw_led_init(_adapter *padapter)
+void rtw_hal_sw_led_init(_adapter *padapter)
 {
-	if (padapter->hal_func.InitSwLeds)
+	struct led_priv *ledpriv = adapter_to_led(padapter);
+
+	if (ledpriv->bRegUseLed == _FALSE)
+		return;
+
+	if (!is_primary_adapter(padapter))
+		return;
+
+	if (padapter->hal_func.InitSwLeds) {
 		padapter->hal_func.InitSwLeds(padapter);
+		rtw_led_set_ctl_en_mask_primary(padapter);
+		rtw_led_set_iface_en(padapter, 1);
+	}
 }
 
 void rtw_hal_sw_led_deinit(_adapter *padapter)
 {
+	struct led_priv *ledpriv = adapter_to_led(padapter);
+
+	if (ledpriv->bRegUseLed == _FALSE)
+		return;
+
+	if (!is_primary_adapter(padapter))
+		return;
+
 	if (padapter->hal_func.DeInitSwLeds)
 		padapter->hal_func.DeInitSwLeds(padapter);
 }
@@ -206,25 +276,82 @@ void rtw_hal_init_opmode(_adapter *padapter)
 #ifdef CONFIG_AP_MODE
 	else if (fw_state & WIFI_AP_STATE)
 		networkType = Ndis802_11APMode;
+#endif
+#ifdef CONFIG_RTW_MESH
+	else if (fw_state & WIFI_MESH_STATE)
+		networkType = Ndis802_11_mesh;
 #endif
 	else
 		return;
 
-	rtw_setopmode_cmd(padapter, networkType, _FALSE);
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_DIRECTLY);
+}
+
+#ifdef CONFIG_NEW_NETDEV_HDL
+uint rtw_hal_iface_init(_adapter *adapter)
+{
+	uint status = _SUCCESS;
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_MAC_ADDR, adapter_mac_addr(adapter));
+	#ifdef RTW_HALMAC
+	rtw_hal_hw_port_enable(adapter);
+	#endif
+	rtw_sec_restore_wep_key(adapter);
+	rtw_hal_init_opmode(adapter);
+	rtw_hal_start_thread(adapter);
+	return status;
 }
+uint rtw_hal_init(_adapter *padapter)
+{
+	uint status = _SUCCESS;
+
+	status = padapter->hal_func.hal_init(padapter);
 
+	if (status == _SUCCESS) {
+		rtw_set_hw_init_completed(padapter, _TRUE);
+		if (padapter->registrypriv.notch_filter == 1)
+			rtw_hal_notch_filter(padapter, 1);
+		rtw_led_control(padapter, LED_CTL_POWER_ON);
+		init_hw_mlme_ext(padapter);
+		#ifdef CONFIG_RF_POWER_TRIM
+		rtw_bb_rf_gain_offset(padapter);
+		#endif /*CONFIG_RF_POWER_TRIM*/
+		GET_PRIMARY_ADAPTER(padapter)->bup = _TRUE; /*temporary*/
+		#ifdef CONFIG_MI_WITH_MBSSID_CAM
+		rtw_mi_set_mbid_cam(padapter);
+		#endif
+		#ifdef CONFIG_SUPPORT_MULTI_BCN
+		rtw_ap_multi_bcn_cfg(padapter);
+		#endif
+		#if (RTL8822B_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)
+		#ifdef CONFIG_DYNAMIC_SOML
+		rtw_dyn_soml_config(padapter);
+		#endif
+		#endif
+		#ifdef CONFIG_TDMADIG
+		rtw_phydm_tdmadig(padapter, TDMADIG_INIT);
+		#endif/*CONFIG_TDMADIG*/
+#ifdef CONFIG_RTW_TX_2PATH_EN
+		rtw_phydm_tx_2path_en(padapter);
+#endif
+	} else {
+		rtw_set_hw_init_completed(padapter, _FALSE);
+		RTW_ERR("%s: hal_init fail\n", __func__);
+	}
+	return status;
+}
+#else
 uint	 rtw_hal_init(_adapter *padapter)
 {
 	uint	status = _SUCCESS;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 	int i;
 
 	status = padapter->hal_func.hal_init(padapter);
 
 	if (status == _SUCCESS) {
-		pHalData->hw_init_completed = _TRUE;
-		rtw_restore_mac_addr(padapter);
+		rtw_set_hw_init_completed(padapter, _TRUE);
+		rtw_mi_set_mac_addr(padapter);/*set mac addr of all ifaces*/
 		#ifdef RTW_HALMAC
 		rtw_restore_hw_port_cfg(padapter);
 		#endif
@@ -240,32 +367,48 @@ uint	 rtw_hal_init(_adapter *padapter)
 
 		rtw_hal_init_opmode(padapter);
 
-#ifdef CONFIG_RF_POWER_TRIM
+		#ifdef CONFIG_RF_POWER_TRIM
 		rtw_bb_rf_gain_offset(padapter);
-#endif /*CONFIG_RF_POWER_TRIM*/
+		#endif /*CONFIG_RF_POWER_TRIM*/
+
+		#ifdef CONFIG_SUPPORT_MULTI_BCN
+		rtw_ap_multi_bcn_cfg(padapter);
+		#endif
+
+#if (RTL8822B_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)
+#ifdef CONFIG_DYNAMIC_SOML
+		rtw_dyn_soml_config(padapter);
+#endif
+#endif
+		#ifdef CONFIG_TDMADIG
+		rtw_phydm_tdmadig(padapter, TDMADIG_INIT);
+		#endif/*CONFIG_TDMADIG*/
 
+#ifdef CONFIG_RTW_TX_2PATH_EN
+		rtw_phydm_tx_2path_en(padapter);
+#endif
 	} else {
-		pHalData->hw_init_completed = _FALSE;
-		RTW_INFO("rtw_hal_init: hal_init fail\n");
+		rtw_set_hw_init_completed(padapter, _FALSE);
+		RTW_ERR("%s: fail\n", __func__);
 	}
 
 
 	return status;
 
 }
+#endif
 
 uint rtw_hal_deinit(_adapter *padapter)
 {
 	uint	status = _SUCCESS;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 	int i;
 
 	status = padapter->hal_func.hal_deinit(padapter);
 
 	if (status == _SUCCESS) {
 		rtw_led_control(padapter, LED_CTL_POWER_OFF);
-		pHalData->hw_init_completed = _FALSE;
+		rtw_set_hw_init_completed(padapter, _FALSE);
 	} else
 		RTW_INFO("\n rtw_hal_deinit: hal_init fail\n");
 
@@ -462,38 +605,18 @@ s32	rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe)
 s32	rtw_hal_mgnt_xmit(_adapter *padapter, struct xmit_frame *pmgntframe)
 {
 	s32 ret = _FAIL;
-	u8	*pframe, subtype;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct sta_info	*psta;
-	struct sta_priv		*pstapriv = &padapter->stapriv;
 
 	update_mgntframe_attrib_addr(padapter, pmgntframe);
-	pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-	subtype = get_frame_sub_type(pframe); /* bit(7)~bit(2) */
-
-	/* pwlanhdr = (struct rtw_ieee80211_hdr *)pframe; */
-	/* _rtw_memcpy(pmgntframe->attrib.ra, pwlanhdr->addr1, ETH_ALEN); */
-
-#ifdef CONFIG_IEEE80211W
-	if (padapter->securitypriv.binstallBIPkey == _TRUE && (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC ||
-			subtype == WIFI_ACTION)) {
-		if (IS_MCAST(pmgntframe->attrib.ra) && pmgntframe->attrib.key_type != IEEE80211W_NO_KEY) {
-			pmgntframe->attrib.encrypt = _BIP_;
-			/* pmgntframe->attrib.bswenc = _TRUE; */
-		} else if (pmgntframe->attrib.key_type != IEEE80211W_NO_KEY) {
-			psta = rtw_get_stainfo(pstapriv, pmgntframe->attrib.ra);
-			if (psta && psta->bpairwise_key_installed == _TRUE) {
-				pmgntframe->attrib.encrypt = _AES_;
-				pmgntframe->attrib.bswenc = _TRUE;
-			} else {
-				RTW_INFO("%s, %d, bpairwise_key_installed is FALSE\n", __func__, __LINE__);
-				goto no_mgmt_coalesce;
-			}
-		}
-		RTW_INFO("encrypt=%d, bswenc=%d\n", pmgntframe->attrib.encrypt, pmgntframe->attrib.bswenc);
+
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
+	if ((!MLME_IS_MESH(padapter) && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE)
+		#ifdef CONFIG_RTW_MESH
+		|| (MLME_IS_MESH(padapter) && padapter->mesh_info.mesh_auth_id)
+		#endif
+	)
 		rtw_mgmt_xmitframe_coalesce(padapter, pmgntframe->pkt, pmgntframe);
-	}
-#endif /* CONFIG_IEEE80211W */
+#endif
+
 no_mgmt_coalesce:
 	ret = padapter->hal_func.mgnt_xmit(padapter, pmgntframe);
 	return ret;
@@ -530,7 +653,7 @@ void rtw_sta_ra_registed(_adapter *padapter, struct sta_info *psta)
 
 #ifdef CONFIG_AP_MODE
 	if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
-		if (psta->cmn.aid >= NUM_STA) {
+		if (psta->cmn.aid > padapter->stapriv.max_aid) {
 			RTW_ERR("station aid %d exceed the max number\n", psta->cmn.aid);
 			rtw_warn_on(1);
 			return;
@@ -598,10 +721,12 @@ u32 rtw_hal_read_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u3
 	if (padapter->hal_func.read_rfreg) {
 		data = padapter->hal_func.read_rfreg(padapter, eRFPath, RegAddr, BitMask);
 
-		if (match_rf_read_sniff_ranges(eRFPath, RegAddr, BitMask)) {
+		#ifdef DBG_IO
+		if (match_rf_read_sniff_ranges(padapter, eRFPath, RegAddr, BitMask)) {
 			RTW_INFO("DBG_IO rtw_hal_read_rfreg(%u, 0x%04x, 0x%08x) read:0x%08x(0x%08x)\n"
 				, eRFPath, RegAddr, BitMask, (data << PHY_CalculateBitShift(BitMask)), data);
 		}
+		#endif
 	}
 
 	return data;
@@ -611,10 +736,12 @@ void rtw_hal_write_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr,
 {
 	if (padapter->hal_func.write_rfreg) {
 
-		if (match_rf_write_sniff_ranges(eRFPath, RegAddr, BitMask)) {
+		#ifdef DBG_IO
+		if (match_rf_write_sniff_ranges(padapter, eRFPath, RegAddr, BitMask)) {
 			RTW_INFO("DBG_IO rtw_hal_write_rfreg(%u, 0x%04x, 0x%08x) write:0x%08x(0x%08x)\n"
 				, eRFPath, RegAddr, BitMask, (Data << PHY_CalculateBitShift(BitMask)), Data);
 		}
+		#endif
 
 		padapter->hal_func.write_rfreg(padapter, eRFPath, RegAddr, BitMask, Data);
 
@@ -625,6 +752,23 @@ void rtw_hal_write_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr,
 	}
 }
 
+#ifdef CONFIG_SYSON_INDIRECT_ACCESS
+u32 rtw_hal_read_syson_reg(PADAPTER padapter, u32 RegAddr, u32 BitMask)
+{
+	u32 data = 0;
+	if (padapter->hal_func.read_syson_reg)
+		data = padapter->hal_func.read_syson_reg(padapter, RegAddr, BitMask);
+
+	return data;
+}
+
+void rtw_hal_write_syson_reg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data)
+{
+	if (padapter->hal_func.write_syson_reg)
+		padapter->hal_func.write_syson_reg(padapter, RegAddr, BitMask, Data);
+}
+#endif
+
 #if defined(CONFIG_PCI_HCI)
 s32	rtw_hal_interrupt_handler(_adapter *padapter)
 {
@@ -632,6 +776,11 @@ s32	rtw_hal_interrupt_handler(_adapter *padapter)
 	ret = padapter->hal_func.interrupt_handler(padapter);
 	return ret;
 }
+
+void	rtw_hal_unmap_beacon_icf(_adapter *padapter)
+{
+	padapter->hal_func.unmap_beacon_icf(padapter);
+}
 #endif
 #if defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
 void	rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf)
@@ -692,12 +841,7 @@ void	rtw_hal_get_tx_power_level(_adapter *padapter, s32 *powerlevel)
 
 void	rtw_hal_dm_watchdog(_adapter *padapter)
 {
-#ifdef CONFIG_MCC_MODE
-	if (MCC_EN(padapter)) {
-		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
-			return;
-	}
-#endif /* CONFIG_MCC_MODE */
+
 	rtw_hal_turbo_edca(padapter);
 	padapter->hal_func.hal_dm_watchdog(padapter);
 
@@ -931,7 +1075,11 @@ s32 c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
 		c2h_customer_str_rpt_2_hdl(adapter, payload, plen);
 		break;
 #endif
-
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	case C2H_PER_RATE_RPT:
+		c2h_per_rate_rpt_hdl(adapter, payload, plen);
+		break;
+#endif
 	case C2H_EXTEND:
 		sub_id = payload[0];
 		/* no handle, goto default */
@@ -1067,33 +1215,37 @@ static s32 _rtw_hal_macid_bmp_sleep(_adapter *adapter, struct macid_bmp *bmp, u8
 {
 	struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
 	u16 reg_sleep;
-	u32 *m = &bmp->m0;
+	u32 m;
 	u8 mid = 0;
 	u32 val32;
 
 	do {
-		if (*m == 0)
-			goto move_next;
-
-		if (mid == 0)
+		if (mid == 0) {
+			m = bmp->m0;
 			reg_sleep = macid_ctl->reg_sleep_m0;
 		#if (MACID_NUM_SW_LIMIT > 32)
-		else if (mid == 1)
+		} else if (mid == 1) {
+			m = bmp->m1;
 			reg_sleep = macid_ctl->reg_sleep_m1;
 		#endif
 		#if (MACID_NUM_SW_LIMIT > 64)
-		else if (mid == 2)
+		} else if (mid == 2) {
+			m = bmp->m2;
 			reg_sleep = macid_ctl->reg_sleep_m2;
 		#endif
 		#if (MACID_NUM_SW_LIMIT > 96)
-		else if (mid == 3)
+		} else if (mid == 3) {
+			m = bmp->m3;
 			reg_sleep = macid_ctl->reg_sleep_m3;
 		#endif
-		else {
+		} else {
 			rtw_warn_on(1);
 			break;
 		}
 
+		if (m == 0)
+			goto move_next;
+
 		if (!reg_sleep) {
 			rtw_warn_on(1);
 			break;
@@ -1102,22 +1254,21 @@ static s32 _rtw_hal_macid_bmp_sleep(_adapter *adapter, struct macid_bmp *bmp, u8
 		val32 = rtw_read32(adapter, reg_sleep);
 		RTW_INFO(ADPT_FMT" %s m%u=0x%08x, ori reg_0x%03x=0x%08x\n"
 			, ADPT_ARG(adapter), sleep ? "sleep" : "wakeup"
-			, mid, *m, reg_sleep, val32);
+			, mid, m, reg_sleep, val32);
 
 		if (sleep) {
-			if ((val32 & *m) == *m)
+			if ((val32 & m) == m)
 				goto move_next;
-			val32 |= *m;
+			val32 |= m;
 		} else {
-			if ((val32 & *m) == 0)
+			if ((val32 & m) == 0)
 				goto move_next;
-			val32 &= ~(*m);
+			val32 &= ~m;
 		}
 
 		rtw_write32(adapter, reg_sleep, val32);
 
 move_next:
-		m++;
 		mid++;
 	} while (mid * 32 < MACID_NUM_SW_LIMIT);
 
@@ -1197,11 +1348,13 @@ void rtw_hal_gpio_multi_func_reset(_adapter *padapter, u8 gpio_num)
 }
 #endif
 
+#ifdef CONFIG_FW_CORRECT_BCN
 void rtw_hal_fw_correct_bcn(_adapter *padapter)
 {
 	if (padapter->hal_func.fw_correct_bcn)
 		padapter->hal_func.fw_correct_bcn(padapter);
 }
+#endif
 
 void rtw_hal_set_tx_power_index(PADAPTER padapter, u32 powerindex, enum rf_path rfpath, u8 rate)
 {
@@ -1494,20 +1647,18 @@ u8 rtw_hal_ops_check(_adapter *padapter)
 	}
 #endif
 
-	if ((IS_HARDWARE_TYPE_8814A(padapter)
-	     || IS_HARDWARE_TYPE_8822BU(padapter) || IS_HARDWARE_TYPE_8822BS(padapter))
+	#ifdef CONFIG_FW_CORRECT_BCN
+	if (IS_HARDWARE_TYPE_8814A(padapter)
 	    && NULL == padapter->hal_func.fw_correct_bcn) {
 		rtw_hal_error_msg("fw_correct_bcn");
 		ret = _FAIL;
 	}
+	#endif
 
-	if (IS_HARDWARE_TYPE_8822B(padapter) || IS_HARDWARE_TYPE_8821C(padapter)) {
-		if (!padapter->hal_func.set_tx_power_index_handler) {
-			rtw_hal_error_msg("set_tx_power_index_handler");
-			ret = _FAIL;
-		}
+	if (!padapter->hal_func.set_tx_power_index_handler) {
+		rtw_hal_error_msg("set_tx_power_index_handler");
+		ret = _FAIL;
 	}
-
 	if (!padapter->hal_func.get_tx_power_index_handler) {
 		rtw_hal_error_msg("get_tx_power_index_handler");
 		ret = _FAIL;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mcc.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mcc.c
index 2290cd773779..4f3c4dfb5ffc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mcc.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mcc.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
@@ -20,21 +21,24 @@
 #include <hal_data.h> /* HAL_DATA */
 #include <rtw_pwrctrl.h> /* power control */
 
-#define MCC_DURATION_IDX 0
+/*  use for AP/GO + STA/GC case */
+#define MCC_DURATION_IDX 0 /* druration for station side */
 #define MCC_TSF_SYNC_OFFSET_IDX 1
 #define MCC_START_TIME_OFFSET_IDX 2
 #define MCC_INTERVAL_IDX 3
 #define MCC_GUARD_OFFSET0_IDX 4
 #define MCC_GUARD_OFFSET1_IDX 5
+#define MCC_STOP_THRESHOLD 6
 #define TU 1024 /* 1 TU equals 1024 microseconds */
-/* port 1 druration, TSF sync offset, start time offset, interval (unit:TU (1024 microseconds))*/
-u8 mcc_switch_channel_policy_table[][6]={
-	{35, 50, 30, 100, 0, 0},
-	{19, 50, 40, 100, 2, 2},
-	{25, 50, 30, 100, 5, 5},
+/* druration, TSF sync offset, start time offset, interval (unit:TU (1024 microseconds))*/
+u8 mcc_switch_channel_policy_table[][7]={
+	{20, 50, 40, 100, 0, 0, 30},
+	{80, 50, 10, 100, 0, 0, 30},
+	{36, 50, 32, 100, 0, 0, 30},
+	{30, 50, 35, 100, 0, 0, 30},
 };
 
-const int mcc_max_policy_num = sizeof(mcc_switch_channel_policy_table) /sizeof(u8) /6;
+const int mcc_max_policy_num = sizeof(mcc_switch_channel_policy_table) /sizeof(u8) /7;
 
 static void dump_iqk_val_table(PADAPTER padapter)
 {
@@ -45,6 +49,9 @@ static void dump_iqk_val_table(PADAPTER padapter)
 	u8 backup_chan_idx = 0;
 	u8 backup_reg_idx = 0;
 
+#ifdef CONFIG_MCC_MODE_V2
+#else
+
 	RTW_INFO("=============dump IQK backup table================\n");
 	for (backup_chan_idx = 0; backup_chan_idx < MAX_IQK_INFO_BACKUP_CHNL_NUM; backup_chan_idx++) {
 		for (rf_path_idx = 0; rf_path_idx < total_rf_path; rf_path_idx++) {
@@ -60,6 +67,8 @@ static void dump_iqk_val_table(PADAPTER padapter)
 		}
 	}	
 	RTW_INFO("=============================================\n");
+
+#endif
 }
 
 static void rtw_hal_mcc_build_p2p_noa_attr(PADAPTER padapter, u8 *ie, u32 *ie_len)
@@ -72,14 +81,14 @@ static void rtw_hal_mcc_build_p2p_noa_attr(PADAPTER padapter, u8 *ie, u32 *ie_le
 	u8 noa_desc_num = 1;
 	u8 opp_ps = 0; /* Disable OppPS */
 	u8 noa_count = 255;
-	u32 noa_duration = 0x20;
-	u32 noa_interval = 0x64;
+	u32 noa_duration;
+	u32 noa_interval;
 	u8 noa_index = 0;
 	u8 mcc_policy_idx = 0;
 
 	mcc_policy_idx = pmccobjpriv->policy_index;
-	noa_duration = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_DURATION_IDX];
-	noa_interval = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_INTERVAL_IDX];
+	noa_duration = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_DURATION_IDX] * TU;
+	noa_interval = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_INTERVAL_IDX] * TU;
 
 	/* P2P OUI(4 bytes) */
 	_rtw_memcpy(p2p_noa_attr_ie, P2P_OUI, 4);
@@ -90,7 +99,7 @@ static void rtw_hal_mcc_build_p2p_noa_attr(PADAPTER padapter, u8 *ie, u32 *ie_le
 	p2p_noa_attr_len = p2p_noa_attr_len + 1;
 	
 	/* attrute length(2 bytes) length = noa_desc_num*13 + 2 */
-	RTW_PUT_LE16(p2p_noa_attr_ie + p2p_noa_attr_len, (noa_desc_num*13 + 2));
+	RTW_PUT_LE16(p2p_noa_attr_ie + p2p_noa_attr_len, (noa_desc_num * 13 + 2));
 	p2p_noa_attr_len = p2p_noa_attr_len + 2;
 
 	/* Index (1 byte) */
@@ -106,11 +115,11 @@ static void rtw_hal_mcc_build_p2p_noa_attr(PADAPTER padapter, u8 *ie, u32 *ie_le
 	p2p_noa_attr_len = p2p_noa_attr_len + 1;
 
 	/* NoA Duration (4 bytes) unit: microseconds */
-	RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, (noa_duration * TU));
+	RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, noa_duration);
 	p2p_noa_attr_len = p2p_noa_attr_len + 4;
 
 	/* NoA Interval (4 bytes) unit: microseconds */
-	RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, (noa_interval * TU));
+	RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, noa_interval);
 	p2p_noa_attr_len = p2p_noa_attr_len + 4;
 
 	/* NoA Start Time (4 bytes) unit: microseconds */
@@ -135,6 +144,7 @@ static void rtw_hal_mcc_build_p2p_noa_attr(PADAPTER padapter, u8 *ie, u32 *ie_le
 static void rtw_hal_mcc_update_go_p2p_ie(PADAPTER padapter)
 {
 	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
 	u8 *pos = NULL;
 
 
@@ -142,14 +152,22 @@ static void rtw_hal_mcc_update_go_p2p_ie(PADAPTER padapter)
 	if (pmccadapriv->p2p_go_noa_ie_len == 0)
 		rtw_hal_mcc_build_p2p_noa_attr(padapter, pmccadapriv->p2p_go_noa_ie, &pmccadapriv->p2p_go_noa_ie_len);
 	else {
-	/* has noa attribut, modify it */
+		/* has noa attribut, modify it */
+		u32 noa_duration = 0;
+		
 		/* update index */
 		pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 15;
 		/* 0~255 */
 		(*pos) = ((*pos) + 1) % 256;
-		if (1)
+		if (0)
 			RTW_INFO("indxe:%d\n", (*pos));
 
+
+		/* update duration */
+		noa_duration = mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_DURATION_IDX] * TU;
+		pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 12;
+		RTW_PUT_LE32(pos, noa_duration);
+
 		/* update start time */
 		pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 4;
 		RTW_PUT_LE32(pos, pmccadapriv->noa_start_time);
@@ -163,16 +181,8 @@ static void rtw_hal_mcc_update_go_p2p_ie(PADAPTER padapter)
 	}
 
 	if (0) {
-		u8 i = 0;
 		RTW_INFO("p2p_go_noa_ie_len:%d\n", pmccadapriv->p2p_go_noa_ie_len);
-		
-		for (i = 0;i < pmccadapriv->p2p_go_noa_ie_len; i++) {
-			if ((i+1)%8 != 0)
-				printk("0x%02x ", pmccadapriv->p2p_go_noa_ie[i]);
-			else
-				printk("0x%02x\n", pmccadapriv->p2p_go_noa_ie[i]);
-		}
-		printk("\n");
+		RTW_INFO_DUMP("\n", pmccadapriv->p2p_go_noa_ie, pmccadapriv->p2p_go_noa_ie_len);
 	}
 	update_beacon(padapter, _VENDOR_SPECIFIC_IE_, P2P_OUI, _TRUE);
 }
@@ -200,6 +210,7 @@ void rtw_hal_mcc_restore_iqk_val(PADAPTER padapter)
 	u8 take_care_iqk = _FALSE;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	_adapter *iface = NULL;
+	struct mcc_adapter_priv *mccadapriv = NULL;
 	u8 i = 0;
 
 	rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
@@ -209,6 +220,10 @@ void rtw_hal_mcc_restore_iqk_val(PADAPTER padapter)
 			if (iface == NULL)
 				continue;
 
+			mccadapriv = &iface->mcc_adapterpriv;
+			if (mccadapriv->role == MCC_ROLE_MAX)
+				continue;
+
 			rtw_hal_ch_sw_iqk_info_restore(iface, CH_SW_USE_CASE_MCC);
 		}
 	}
@@ -241,101 +256,74 @@ void rtw_hal_clear_mcc_status(PADAPTER padapter, u8 mcc_status)
 	pmccobjpriv->mcc_status &= (~mcc_status);
 }
 
-void rtw_hal_mcc_update_switch_channel_policy_table(PADAPTER padapter)
+static void rtw_hal_mcc_update_policy_table(PADAPTER adapter)
 {
-	struct registry_priv *registry_par = &padapter->registrypriv;
-	u8 idx = 0;
-
-	if (registry_par->rtw_mcc_policy_table_idx < 0)
-		return;
-
-	if (registry_par->rtw_mcc_policy_table_idx >= mcc_max_policy_num) {
-		RTW_INFO("[MCC] mcc_policy_table_idx error, do not update policy table\n");
-		return;
-	}
-
-	idx = registry_par->rtw_mcc_policy_table_idx;
-	
-	if (registry_par->rtw_mcc_duration > 0)
-		mcc_switch_channel_policy_table[idx][MCC_DURATION_IDX] = registry_par->rtw_mcc_duration;
-
-	if (registry_par->rtw_mcc_tsf_sync_offset > 0)
-		mcc_switch_channel_policy_table[idx][MCC_TSF_SYNC_OFFSET_IDX] = registry_par->rtw_mcc_tsf_sync_offset;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	u8 mcc_duration = mccobjpriv->duration;
+	s8 mcc_policy_idx = mccobjpriv->policy_index;
+	u8 interval = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_INTERVAL_IDX];
+	u8 new_mcc_duration_time = 0;
+	u8 new_starttime_offset = 0;
 
-	if (registry_par->rtw_mcc_start_time_offset > 0)
-		mcc_switch_channel_policy_table[idx][MCC_START_TIME_OFFSET_IDX] = registry_par->rtw_mcc_start_time_offset;
+	/* convert % to ms */
+	new_mcc_duration_time = mcc_duration * interval / 100;
 
-	if (registry_par->rtw_mcc_interval > 0)
-		mcc_switch_channel_policy_table[idx][MCC_INTERVAL_IDX] = registry_par->rtw_mcc_interval;
+	/* start time offset = (interval - duration time)/2 */
+	new_starttime_offset = (interval - new_mcc_duration_time) >> 1;
 
-	if (registry_par->rtw_mcc_guard_offset0 >= 0)
-		mcc_switch_channel_policy_table[idx][MCC_GUARD_OFFSET0_IDX] = registry_par->rtw_mcc_guard_offset0;
+	/* update modified parameters */
+	mcc_switch_channel_policy_table[mcc_policy_idx][MCC_DURATION_IDX]
+		= new_mcc_duration_time;
 
-	if (registry_par->rtw_mcc_guard_offset1 >= 0)
-		mcc_switch_channel_policy_table[idx][MCC_GUARD_OFFSET1_IDX] = registry_par->rtw_mcc_guard_offset1;
+	mcc_switch_channel_policy_table[mcc_policy_idx][MCC_START_TIME_OFFSET_IDX]
+		= new_starttime_offset;
+	
 
 }
 
 static void rtw_hal_config_mcc_switch_channel_setting(PADAPTER padapter)
 {
-	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
 	struct registry_priv *registry_par = &padapter->registrypriv;
-	u8 interval = pmlmepriv->cur_network.network.Configuration.BeaconPeriod;
-	u8 i = 0;
+	u8 mcc_duration = 0;
 	s8 mcc_policy_idx = 0;
 
-	rtw_hal_mcc_update_switch_channel_policy_table(padapter);
 	mcc_policy_idx = registry_par->rtw_mcc_policy_table_idx;
+	mcc_duration = mccobjpriv->duration;
 
 	if (mcc_policy_idx < 0 || mcc_policy_idx >= mcc_max_policy_num) {
-		pmccobjpriv->policy_index = 0;
-		RTW_INFO("[MCC] can't find table(%d,%d,%d), use default policy(%d)\n"
-			, pmccobjpriv->duration, interval, mcc_policy_idx, pmccobjpriv->policy_index);
+		mccobjpriv->policy_index = 0;
+		RTW_INFO("[MCC] can't find table(%d), use default policy(%d)\n",
+			mcc_policy_idx, mccobjpriv->policy_index);
 	} else
-		pmccobjpriv->policy_index = mcc_policy_idx;
+		mccobjpriv->policy_index = mcc_policy_idx;
+
+	/* convert % to time */
+	if (mcc_duration != 0)
+		rtw_hal_mcc_update_policy_table(padapter);
 
 	RTW_INFO("[MCC] policy(%d): %d,%d,%d,%d,%d,%d\n"
-		, pmccobjpriv->policy_index
-		, mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_DURATION_IDX]
-		, mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_TSF_SYNC_OFFSET_IDX]
-		, mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_START_TIME_OFFSET_IDX]
-		, mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_INTERVAL_IDX]
-		, mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
-		, mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX]);
+		, mccobjpriv->policy_index
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_DURATION_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_TSF_SYNC_OFFSET_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_START_TIME_OFFSET_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_INTERVAL_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
+		, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX]);
 
 }
 
-static void rtw_hal_config_mcc_role_setting(PADAPTER padapter)
+static void rtw_hal_mcc_assign_tx_threshold(PADAPTER padapter) 
 {
-	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
-	struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
-	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
-	struct sta_priv *pstapriv = &padapter->stapriv;
-	struct sta_info *psta = NULL;
 	struct registry_priv *preg = &padapter->registrypriv;
-	u8 policy_index = 0;
-	u8 mcc_duration = 0;
-	u8 mcc_interval = 0;
-
-	policy_index = pmccobjpriv->policy_index;
-	mcc_duration = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_DURATION_IDX]
-		- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
-			- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX];
-	mcc_interval = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_INTERVAL_IDX];
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
-	/* GO/AP is 1nd order  GC/STA is 2nd order */
 	switch (pmccadapriv->role) {
 	case MCC_ROLE_STA:
 	case MCC_ROLE_GC:
-		pmccadapriv->order = 1;
-		pmccadapriv->mcc_duration = mcc_duration;
-
 		switch (pmlmeext->cur_bwmode) {
 		case CHANNEL_WIDTH_20:
 			/*
@@ -359,26 +347,9 @@ static void rtw_hal_config_mcc_role_setting(PADAPTER padapter)
 				, FUNC_ADPT_ARG(padapter), pmlmeext->cur_bwmode);
 			break;
 		}
-
-		/* assign used mac to avoid affecting RA */
-		pmccadapriv->mgmt_queue_macid = MCC_ROLE_STA_GC_MGMT_QUEUE_MACID;
-
-		psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
-		if (psta) {
-			/* combine AP/GO macid and mgmt queue macid to bitmap */
-			pmccadapriv->mcc_macid_bitmap = BIT(psta->cmn.mac_id) | BIT(pmccadapriv->mgmt_queue_macid);
-		} else {
-			RTW_INFO(FUNC_ADPT_FMT":AP/GO station info is NULL\n", FUNC_ADPT_ARG(padapter));
-			rtw_warn_on(1);
-		}
 		break;
 	case MCC_ROLE_AP:
 	case MCC_ROLE_GO:
-		pmccadapriv->order = 0;
-		/* total druation value equals interval */
-		pmccadapriv->mcc_duration = mcc_interval - mcc_duration;
-		pmccadapriv->p2p_go_noa_ie_len = 0; /* not NoA attribute at init time */
-
 		switch (pmlmeext->cur_bwmode) {
 		case CHANNEL_WIDTH_20:
 			pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_ap_bw20_target_tx_tp * 128 * pmccadapriv->mcc_duration;
@@ -395,31 +366,154 @@ static void rtw_hal_config_mcc_role_setting(PADAPTER padapter)
 				, FUNC_ADPT_ARG(padapter), pmlmeext->cur_bwmode);
 			break;
 		}
+		break;
+	default:
+		RTW_INFO(FUNC_ADPT_FMT": unknown role = %d\n"
+			, FUNC_ADPT_ARG(padapter), pmccadapriv->role);
+		break;
+	}
+}
+
+static void rtw_hal_config_mcc_role_setting(PADAPTER padapter, u8 order)
+{
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+	struct wlan_network *cur_network = &(pmlmepriv->cur_network);
+	struct sta_priv *pstapriv = &padapter->stapriv;
+	struct sta_info *psta = NULL;
+	struct registry_priv *preg = &padapter->registrypriv;
+	_irqL irqL;
+	_list	*phead =NULL, *plist = NULL;
+	u8 policy_index = 0;
+	u8 mcc_duration = 0;
+	u8 mcc_interval = 0;
+	u8 starting_ap_num = DEV_AP_STARTING_NUM(pdvobjpriv);
+	u8 ap_num = DEV_AP_NUM(pdvobjpriv);
 
+	policy_index = pmccobjpriv->policy_index;
+	mcc_duration = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_DURATION_IDX]
+		- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
+			- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX];
+	mcc_interval = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_INTERVAL_IDX];
 
-		psta = rtw_get_bcmc_stainfo(padapter);
+	if (starting_ap_num == 0 && ap_num == 0) {
+		pmccadapriv->order = order;
 
-		if (psta != NULL)
-			pmccadapriv->mgmt_queue_macid = psta->cmn.mac_id;
-		else {
+		if (pmccadapriv->order == 0) {
+			/* setting is smiliar to GO/AP */
+			/* pmccadapriv->mcc_duration = mcc_interval - mcc_duration;*/
 			pmccadapriv->mgmt_queue_macid = MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID;
-			RTW_INFO(FUNC_ADPT_FMT":bcmc station is NULL, use macid %d\n"
-				, FUNC_ADPT_ARG(padapter), pmccadapriv->mgmt_queue_macid);
+		} else if (pmccadapriv->order == 1) {
+			/* pmccadapriv->mcc_duration = mcc_duration; */
+			pmccadapriv->mgmt_queue_macid = MCC_ROLE_STA_GC_MGMT_QUEUE_MACID;
+		} else {
+			RTW_INFO("[MCC] not support >= 3 interface\n");
+			rtw_warn_on(1);
+		}
+
+		rtw_hal_mcc_assign_tx_threshold(padapter);
+
+		psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
+		if (psta) {
+			/* combine AP/GO macid and mgmt queue macid to bitmap */
+			pmccadapriv->mcc_macid_bitmap = BIT(psta->cmn.mac_id) | BIT(pmccadapriv->mgmt_queue_macid);
+		} else {
+			RTW_INFO(FUNC_ADPT_FMT":AP/GO station info is NULL\n", FUNC_ADPT_ARG(padapter));
+			rtw_warn_on(1);
+		}
+	} else {
+		/* GO/AP is 1nd order  GC/STA is 2nd order */
+		switch (pmccadapriv->role) {
+		case MCC_ROLE_STA:
+		case MCC_ROLE_GC:
+			pmccadapriv->order = 1;
+			pmccadapriv->mcc_duration = mcc_duration;
+
+			rtw_hal_mcc_assign_tx_threshold(padapter);
+			/* assign used mac to avoid affecting RA */
+			pmccadapriv->mgmt_queue_macid = MCC_ROLE_STA_GC_MGMT_QUEUE_MACID;
+
+			psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
+			if (psta) {
+				/* combine AP/GO macid and mgmt queue macid to bitmap */
+				pmccadapriv->mcc_macid_bitmap = BIT(psta->cmn.mac_id) | BIT(pmccadapriv->mgmt_queue_macid);
+			} else {
+				RTW_INFO(FUNC_ADPT_FMT":AP/GO station info is NULL\n", FUNC_ADPT_ARG(padapter));
+				rtw_warn_on(1);
+			}
+			break;
+		case MCC_ROLE_AP:
+		case MCC_ROLE_GO:
+			pmccadapriv->order = 0;
+			/* total druation value equals interval */
+			pmccadapriv->mcc_duration = mcc_interval - mcc_duration;
+			pmccadapriv->p2p_go_noa_ie_len = 0; /* not NoA attribute at init time */
+
+			rtw_hal_mcc_assign_tx_threshold(padapter);
+
+			_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+			phead = &pstapriv->asoc_list;
+			plist = get_next(phead);
+			pmccadapriv->mcc_macid_bitmap = 0;
+	
+			while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
+				psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
+				plist = get_next(plist);
+				pmccadapriv->mcc_macid_bitmap |= BIT(psta->cmn.mac_id);
+			}
+
+			_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
+
+			psta = rtw_get_bcmc_stainfo(padapter);
+
+			if (psta != NULL)
+				pmccadapriv->mgmt_queue_macid = psta->cmn.mac_id;
+			else {
+				pmccadapriv->mgmt_queue_macid = MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID;
+				RTW_INFO(FUNC_ADPT_FMT":bcmc station is NULL, use macid %d\n"
+					, FUNC_ADPT_ARG(padapter), pmccadapriv->mgmt_queue_macid);
+			}
+
+			/* combine client macid and mgmt queue macid to bitmap */
+			pmccadapriv->mcc_macid_bitmap |= BIT(pmccadapriv->mgmt_queue_macid);
+			break;
+		default:
+			RTW_INFO("Unknown role\n");
+			rtw_warn_on(1);
+			break;
 		}
 
-		/* combine client macid and mgmt queue macid to bitmap */
-		pmccadapriv->mcc_macid_bitmap = (0xff << 8) | BIT(pmccadapriv->mgmt_queue_macid);
-		break;
-	default:
-		RTW_INFO("Unknown role\n");
-		rtw_warn_on(1);
-		break;
 	}
 
+	/* setting Null data parameters */
+	if (pmccadapriv->role == MCC_ROLE_STA) {
+			pmccadapriv->null_early = 3;
+			pmccadapriv->null_rty_num= 5;
+	} else if (pmccadapriv->role == MCC_ROLE_GC) {
+			pmccadapriv->null_early = 2;
+			pmccadapriv->null_rty_num= 5;
+	} else {
+			pmccadapriv->null_early = 0;
+			pmccadapriv->null_rty_num= 0;
+	}
+
+	RTW_INFO("********* "FUNC_ADPT_FMT" *********\n", FUNC_ADPT_ARG(padapter));
+	RTW_INFO("order:%d\n", pmccadapriv->order);
+	RTW_INFO("role:%d\n", pmccadapriv->role);
+	RTW_INFO("mcc duration:%d\n", pmccadapriv->mcc_duration);
+	RTW_INFO("null_early:%d\n", pmccadapriv->null_early);
+	RTW_INFO("null_rty_num:%d\n", pmccadapriv->null_rty_num);
+	RTW_INFO("mgmt queue macid:%d\n", pmccadapriv->mgmt_queue_macid);
+	RTW_INFO("bitmap:0x%02x\n", pmccadapriv->mcc_macid_bitmap);
+	RTW_INFO("target tx bytes:%d\n", pmccadapriv->mcc_target_tx_bytes_to_port);
+	RTW_INFO("**********************************\n");
+
 	pmccobjpriv->iface[pmccadapriv->order] = padapter;
-	RTW_INFO(FUNC_ADPT_FMT": order:%d, role:%d, mcc duration:%d, target tx bytes:%d, mgmt queue macid:%d, bitmap:0x%02x\n"
-		, FUNC_ADPT_ARG(padapter), pmccadapriv->order, pmccadapriv->role, pmccadapriv->mcc_duration
-			, pmccadapriv->mcc_target_tx_bytes_to_port, pmccadapriv->mgmt_queue_macid, pmccadapriv->mcc_macid_bitmap);
+
 }
 
 static void rtw_hal_clear_mcc_macid(PADAPTER padapter)
@@ -441,6 +535,400 @@ static void rtw_hal_clear_mcc_macid(PADAPTER padapter)
 		break;
 	}
 }
+
+static void rtw_hal_mcc_rqt_tsf(PADAPTER padapter, u64 *out_tsf)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	PADAPTER order0_iface = NULL;
+	PADAPTER order1_iface = NULL;
+	struct submit_ctx *tsf_req_sctx = NULL;
+	enum _hw_port tsfx = MAX_HW_PORT;
+	enum _hw_port tsfy = MAX_HW_PORT;
+	u8 cmd[H2C_MCC_RQT_TSF_LEN] = {0};
+
+	_enter_critical_mutex(&mccobjpriv->mcc_tsf_req_mutex, NULL);
+
+	order0_iface = mccobjpriv->iface[0];
+	order1_iface = mccobjpriv->iface[1];
+
+	tsf_req_sctx = &mccobjpriv->mcc_tsf_req_sctx;
+	rtw_sctx_init(tsf_req_sctx, MCC_EXPIRE_TIME);
+	mccobjpriv->mcc_tsf_req_sctx_order = 0;
+	tsfx = rtw_hal_get_port(order0_iface);
+	tsfy = rtw_hal_get_port(order1_iface);
+
+	SET_H2CCMD_MCC_RQT_TSFX(cmd, tsfx);
+	SET_H2CCMD_MCC_RQT_TSFY(cmd, tsfy);
+
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_RQT_TSF, H2C_MCC_RQT_TSF_LEN, cmd);
+
+	if (!rtw_sctx_wait(tsf_req_sctx, __func__))
+		RTW_INFO(FUNC_ADPT_FMT": wait for mcc tsf req C2H time out\n", FUNC_ADPT_ARG(padapter));
+
+	if (tsf_req_sctx->status  == RTW_SCTX_DONE_SUCCESS && out_tsf != NULL) {
+		out_tsf[0] = order0_iface->mcc_adapterpriv.tsf;
+		out_tsf[1] = order1_iface->mcc_adapterpriv.tsf;
+	}
+
+
+	_exit_critical_mutex(&mccobjpriv->mcc_tsf_req_mutex, NULL);
+}
+
+static u8 rtw_hal_mcc_check_start_time_is_valid(PADAPTER padapter, u8 case_num,
+	u32 tsfdiff, s8 *upper_bound_0, s8 *lower_bound_0, s8 *upper_bound_1, s8 *lower_bound_1)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	u8 duration_0 = 0, duration_1 = 0;
+	s8 final_upper_bound = 0, final_lower_bound = 0;
+	u8 intersection =  _FALSE;
+	u8 min_start_time = 5;
+	u8 max_start_time = 95;
+	
+	duration_0 = mccobjpriv->iface[0]->mcc_adapterpriv.mcc_duration;
+	duration_1 = mccobjpriv->iface[1]->mcc_adapterpriv.mcc_duration;
+
+	switch(case_num) {
+	case 1:
+		*upper_bound_0 = tsfdiff;
+		*lower_bound_0 = tsfdiff - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 2:
+		*upper_bound_0 = tsfdiff + 100;
+		*lower_bound_0 = tsfdiff + 100 - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 3:
+		*upper_bound_0 = tsfdiff + 50;
+		*lower_bound_0 = tsfdiff + 50 - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 4:
+		*upper_bound_0 = tsfdiff;
+		*lower_bound_0 = tsfdiff - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 5:
+		*upper_bound_0 = 200 - tsfdiff;
+		*lower_bound_0 = 200 - tsfdiff - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	case 6:
+		*upper_bound_0 = tsfdiff - 50;
+		*lower_bound_0 = tsfdiff - 50 - duration_1;
+		*upper_bound_1 = 150 - duration_1;
+		*lower_bound_1= 0;
+		break;
+	default:
+		RTW_ERR("[MCC] %s: error case number(%d\n)", __func__, case_num);
+	}
+
+
+	/* check Intersection or not */
+	if ((*lower_bound_1 >= *upper_bound_0) ||
+		(*lower_bound_0 >= *upper_bound_1))
+		intersection = _FALSE;
+	else
+		intersection = _TRUE;
+
+	if (intersection) {
+		if (*upper_bound_0 > *upper_bound_1)
+			final_upper_bound = *upper_bound_1;
+		else
+			final_upper_bound = *upper_bound_0;
+
+		if (*lower_bound_0 > *lower_bound_1)
+			final_lower_bound = *lower_bound_0;
+		else
+			final_lower_bound = *lower_bound_1;
+
+		mccobjpriv->start_time = (final_lower_bound + final_upper_bound) / 2;
+
+		/* check start time less than 5ms, request by Pablo@SD1 */
+		if (mccobjpriv->start_time <= min_start_time) {
+			mccobjpriv->start_time = 6;
+			if (mccobjpriv->start_time < final_lower_bound && mccobjpriv->start_time > final_upper_bound) {
+				intersection = _FALSE;
+				goto exit;
+			}
+		}
+
+		/* check start time less than 95ms */
+		if (mccobjpriv->start_time >= max_start_time) {
+			mccobjpriv->start_time = 90;
+			if (mccobjpriv->start_time < final_lower_bound && mccobjpriv->start_time > final_upper_bound) {
+				intersection = _FALSE;
+				goto exit;
+			}
+		}
+	}
+
+exit:
+	return intersection;
+}
+
+static void rtw_hal_mcc_decide_duration(PADAPTER padapter)
+{
+	struct registry_priv *registry_par = &padapter->registrypriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_adapter_priv *mccadapriv = NULL, *mccadapriv_order0 = NULL, *mccadapriv_order1 = NULL;
+	_adapter *iface = NULL, *iface_order0 = NULL,  *iface_order1 = NULL;
+	u8 duration = 0, i = 0, duration_time;
+	u8 mcc_interval = 150;
+
+	iface_order0 = mccobjpriv->iface[0];
+	iface_order1 = mccobjpriv->iface[1];
+	mccadapriv_order0 = &iface_order0->mcc_adapterpriv;
+	mccadapriv_order1 = &iface_order1->mcc_adapterpriv;
+	
+	if (mccobjpriv->duration == 0) {
+		/* default */
+		duration = 30;/*(%)*/
+		RTW_INFO("%s: mccobjpriv->duration=0, use default value(%d)\n",
+			__FUNCTION__, duration);
+	} else {
+		duration = mccobjpriv->duration;/*(%)*/
+		RTW_INFO("%s: mccobjpriv->duration=%d\n",
+			__FUNCTION__, duration);
+	}
+
+	mccobjpriv->interval = mcc_interval;
+	mccobjpriv->mcc_stop_threshold = 2000 * 4 / 300 - 6;
+	/* convert % to ms, for primary adapter */
+	duration_time = mccobjpriv->interval * duration / 100;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+
+		if (!iface)
+			continue;
+
+		mccadapriv = &iface->mcc_adapterpriv;
+		if (mccadapriv->role == MCC_ROLE_MAX)
+			continue;
+
+		if (is_primary_adapter(iface))
+			mccadapriv->mcc_duration = duration_time;
+		else
+			mccadapriv->mcc_duration = mccobjpriv->interval - duration_time;
+	}
+
+	RTW_INFO("[MCC]"  FUNC_ADPT_FMT " order 0 duration=%d\n", FUNC_ADPT_ARG(iface_order0), mccadapriv_order0->mcc_duration);
+	RTW_INFO("[MCC]"  FUNC_ADPT_FMT " order 1 duration=%d\n", FUNC_ADPT_ARG(iface_order1), mccadapriv_order1->mcc_duration);
+}
+
+static u8 rtw_hal_mcc_update_timing_parameters(PADAPTER padapter, u8 force_update)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	u8 need_update = _FALSE;
+	u8 starting_ap_num = DEV_AP_STARTING_NUM(dvobj);
+	u8 ap_num = DEV_AP_NUM(dvobj);
+
+
+	/* for STA+STA, modify policy table */
+	if (starting_ap_num == 0 && ap_num == 0) {
+		struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+		struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+		struct mcc_adapter_priv *pmccadapriv = NULL;
+		_adapter *iface = NULL;
+		u64 tsf[MAX_MCC_NUM] = {0};
+		u64 tsf0 = 0, tsf1 = 0;
+		u32 beaconperiod_0 = 0, beaconperiod_1 = 0, tsfdiff = 0;
+		s8 upper_bound_0 = 0, lower_bound_0 = 0;
+		s8 upper_bound_1 = 0, lower_bound_1 = 0;
+		u8 valid = _FALSE;
+		u8 case_num = 1;
+		u8 i = 0;
+		
+		/* query TSF */
+		rtw_hal_mcc_rqt_tsf(padapter, tsf);
+
+		/* selecet policy table according TSF diff */
+		tsf0 = tsf[0];
+		beaconperiod_0 = pmccobjpriv->iface[0]->mlmepriv.cur_network.network.Configuration.BeaconPeriod;
+		tsf0 = rtw_modular64(tsf0, (beaconperiod_0 * TU));
+
+		tsf1 = tsf[1];
+		beaconperiod_1 = pmccobjpriv->iface[1]->mlmepriv.cur_network.network.Configuration.BeaconPeriod;
+		tsf1 = rtw_modular64(tsf1, (beaconperiod_1 * TU));
+
+		if (tsf0 > tsf1)
+			tsfdiff = tsf0- tsf1;
+		else
+			tsfdiff = (tsf0 +  beaconperiod_0 * TU) - tsf1;
+
+		/* convert to ms */
+		tsfdiff = (tsfdiff / TU);
+
+		/* force update*/
+		if (force_update) {
+			RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
+				pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
+			RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
+			RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
+				__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
+			pmccobjpriv->last_tsfdiff = tsfdiff;
+			need_update = _TRUE;
+		} else {
+			if (pmccobjpriv->last_tsfdiff > tsfdiff) {
+				/* last tsfdiff - current tsfdiff > THRESHOLD, update parameters */
+				if (pmccobjpriv->last_tsfdiff > (tsfdiff + MCC_UPDATE_PARAMETER_THRESHOLD)) {
+					RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
+						pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
+					RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
+					RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
+						__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
+
+					pmccobjpriv->last_tsfdiff = tsfdiff;
+					need_update = _TRUE;
+				} else {
+					need_update = _FALSE;
+				}
+			} else if (tsfdiff > pmccobjpriv->last_tsfdiff){
+				/* current tsfdiff - last tsfdiff > THRESHOLD, update parameters */
+				if (tsfdiff > (pmccobjpriv->last_tsfdiff + MCC_UPDATE_PARAMETER_THRESHOLD)) {
+					RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
+						pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
+					RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
+					RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
+						__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
+
+					pmccobjpriv->last_tsfdiff = tsfdiff;
+					need_update = _TRUE;
+				} else {
+					need_update = _FALSE;
+				}
+			} else {
+				need_update = _FALSE;
+			}
+		}
+
+		if (need_update == _FALSE)
+			goto exit;
+
+		rtw_hal_mcc_decide_duration(padapter);
+
+		if (tsfdiff <= 50) {
+	
+			/* RX TBTT 0 */
+			case_num = 1;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+	
+			/* RX TBTT 1 */
+			case_num = 2;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+			
+			/* RX TBTT 2 */
+			case_num = 3;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+
+			if (valid == _FALSE) {
+				RTW_INFO("[MCC] do not find fit start time\n");
+				RTW_INFO("[MCC] tsfdiff:%d, duration:%d(%c), interval:%d\n",
+					tsfdiff, pmccobjpriv->duration, 37, pmccobjpriv->interval);
+
+			}
+
+		} else {
+
+			/* RX TBTT 0 */
+			case_num = 4;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+			
+			
+			/* RX TBTT 1 */
+			case_num = 5;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+
+			
+			/* RX TBTT 2 */
+			case_num = 6;
+			valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
+				&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
+
+			if (valid)
+				goto valid_result;
+
+			if (valid == _FALSE) {
+				RTW_INFO("[MCC] do not find fit start time\n");
+				RTW_INFO("[MCC] tsfdiff:%d, duration:%d(%c), interval:%d\n",
+					tsfdiff, pmccobjpriv->duration, 37, pmccobjpriv->interval);
+			}
+		}
+
+		
+
+	valid_result:
+		RTW_INFO("********************\n");
+		RTW_INFO("%s: case_num:%d, start time:%d\n",
+				__func__, case_num, pmccobjpriv->start_time);
+		RTW_INFO("%s: upper_bound_0:%d, lower_bound_0:%d\n",
+				__func__, upper_bound_0, lower_bound_0);
+		RTW_INFO("%s: upper_bound_1:%d, lower_bound_1:%d\n",
+				__func__, upper_bound_1, lower_bound_1);
+		
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface == NULL)
+				continue;
+
+			pmccadapriv = &iface->mcc_adapterpriv;
+			pmccadapriv = &iface->mcc_adapterpriv;
+			if (pmccadapriv->role == MCC_ROLE_MAX)
+				continue;
+#if 0
+			if (pmccadapriv->order == 0) {
+				pmccadapriv->mcc_duration = mcc_duration;
+			} else if (pmccadapriv->order == 1) {
+				pmccadapriv->mcc_duration = mcc_interval - mcc_duration;
+			} else {
+				RTW_INFO("[MCC] not support >= 3 interface\n");
+				rtw_warn_on(1);
+			}
+#endif
+			RTW_INFO("********************\n");
+			RTW_INFO(FUNC_ADPT_FMT": order:%d, role:%d\n",
+				FUNC_ADPT_ARG(iface), pmccadapriv->order, pmccadapriv->role);
+			RTW_INFO(FUNC_ADPT_FMT": mcc duration:%d, target tx bytes:%d\n",
+				FUNC_ADPT_ARG(iface), pmccadapriv->mcc_duration, pmccadapriv->mcc_target_tx_bytes_to_port);
+			RTW_INFO(FUNC_ADPT_FMT": mgmt queue macid:%d, bitmap:0x%02x\n",
+				FUNC_ADPT_ARG(iface), pmccadapriv->mgmt_queue_macid, pmccadapriv->mcc_macid_bitmap);
+			RTW_INFO("********************\n");
+		}
+		
+	}
+exit:
+	return need_update;
+}
+
 static u8 rtw_hal_decide_mcc_role(PADAPTER padapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
@@ -449,6 +937,7 @@ static u8 rtw_hal_decide_mcc_role(PADAPTER padapter)
 	struct wifidirect_info *pwdinfo = NULL;
 	struct mlme_priv *pmlmepriv = NULL;
 	u8 ret = _SUCCESS, i = 0;
+	u8 order = 1;
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
@@ -456,6 +945,7 @@ static u8 rtw_hal_decide_mcc_role(PADAPTER padapter)
 			continue;
 
 		pmccadapriv = &iface->mcc_adapterpriv;
+		pwdinfo = &iface->wdinfo;
 
 		if (MLME_IS_GO(iface))
 			pmccadapriv->role = MCC_ROLE_GO;
@@ -463,32 +953,36 @@ static u8 rtw_hal_decide_mcc_role(PADAPTER padapter)
 			pmccadapriv->role = MCC_ROLE_AP;
 		else if (MLME_IS_GC(iface))
 			pmccadapriv->role = MCC_ROLE_GC;
-		else if (MLME_IS_STA(iface))
-			pmccadapriv->role = MCC_ROLE_STA;
-		else {
-			pwdinfo = &iface->wdinfo;
-			pmlmepriv = &iface->mlmepriv;
-
-			RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(iface));
-			RTW_INFO("Unknown:P2P state:%d, mlme state:0x%2x, mlmext info state:0x%02x\n",
-				pwdinfo->role, pmlmepriv->fw_state, iface->mlmeextpriv.mlmext_info.state);
-			rtw_warn_on(1);
-			ret =  _FAIL;
-			goto exit;
+		else if (MLME_IS_STA(iface)) {
+			if (MLME_IS_LINKING(iface) || MLME_IS_ASOC(iface))
+				pmccadapriv->role = MCC_ROLE_STA;
+			else {
+				/* bypass non-linked/non-linking interface */
+				RTW_INFO(FUNC_ADPT_FMT" mlme state:0x%2x\n",
+					FUNC_ADPT_ARG(iface), MLME_STATE(iface));
+				continue;
+			}
+		} else {
+			/* bypass non-linked/non-linking interface */
+			RTW_INFO(FUNC_ADPT_FMT" P2P Role:%d, mlme state:0x%2x\n",
+				FUNC_ADPT_ARG(iface), pwdinfo->role, MLME_STATE(iface));
+			continue;
 		}
 
-		if (ret == _SUCCESS)
-			rtw_hal_config_mcc_role_setting(iface);
+		if (padapter == iface) {
+			/* current adapter is order 0 */
+			rtw_hal_config_mcc_role_setting(iface, 0);
+		} else {
+			rtw_hal_config_mcc_role_setting(iface, order);
+			order ++;
+		}
 	}
 
+	rtw_hal_mcc_update_timing_parameters(padapter, _TRUE);
 exit:
 	return ret;
 }
 
-static void rtw_hal_init_mcc_parameter(PADAPTER padapter)
-{
-}
-
 static void rtw_hal_construct_CTS(PADAPTER padapter, u8 *pframe, u32 *pLength)
 {
 	u8 broadcast_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
@@ -510,9 +1004,69 @@ static void rtw_hal_construct_CTS(PADAPTER padapter, u8 *pframe, u32 *pLength)
 	*pLength = 22;
 }
 
+/* avoid wrong information for power limit */
+void rtw_hal_mcc_upadate_chnl_bw(_adapter *padapter, u8 ch, u8 ch_offset, u8 bw, u8 print)
+{
+
+	u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
+	PHAL_DATA_TYPE	hal = GET_HAL_DATA(padapter);
+	u8 cch_160, cch_80, cch_40, cch_20;
+
+	center_ch = rtw_get_center_ch(ch, bw, ch_offset);
+
+	if (bw == CHANNEL_WIDTH_80) {
+		if (center_ch > ch)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
+		else if (center_ch < ch)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
+		else
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	}
+
+	/* set Channel */
+	/* saved channel/bw info */
+	rtw_set_oper_ch(padapter, ch);
+	rtw_set_oper_bw(padapter, bw);
+	rtw_set_oper_choffset(padapter, ch_offset);
+
+	cch_80 = bw == CHANNEL_WIDTH_80 ? center_ch : 0;
+	cch_40 = bw == CHANNEL_WIDTH_40 ? center_ch : 0;
+	cch_20 = bw == CHANNEL_WIDTH_20 ? center_ch : 0;
+
+	if (cch_80 != 0)
+		cch_40 = rtw_get_scch_by_cch_offset(cch_80, CHANNEL_WIDTH_80, chnl_offset80);
+	if (cch_40 != 0)
+		cch_20 = rtw_get_scch_by_cch_offset(cch_40, CHANNEL_WIDTH_40, ch_offset);
+
+
+	hal->cch_80 = cch_80;
+	hal->cch_40 = cch_40;
+	hal->cch_20 = cch_20;
+	hal->current_channel = center_ch;
+	hal->CurrentCenterFrequencyIndex1 = center_ch;
+	hal->current_channel_bw = bw;
+	hal->nCur40MhzPrimeSC = ch_offset;
+	hal->nCur80MhzPrimeSC = chnl_offset80;
+	hal->current_band_type = ch > 14 ? BAND_ON_5G:BAND_ON_2_4G;
+
+	if (print) {
+		RTW_INFO(FUNC_ADPT_FMT" cch:%u, %s, offset40:%u, offset80:%u (%u, %u, %u), band:%s\n"
+			, FUNC_ADPT_ARG(padapter), center_ch, ch_width_str(bw)
+			, ch_offset, chnl_offset80
+			, hal->cch_80, hal->cch_40, hal->cch_20
+			, band_str(hal->current_band_type));
+	}
+}
+
+#ifdef DBG_RSVD_PAGE_CFG
+#define RSVD_PAGE_CFG(ops, v1, v2, v3)	\
+	RTW_INFO("=== [RSVD][%s]-NeedPage:%d, TotalPageNum:%d TotalPacketLen:%d ===\n",	\
+		ops, v1, v2, v3)
+#endif
+
 u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index,
-	u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
-		RSVDPAGE_LOC *rsvd_page_loc)
+	u8 tx_desc, u32 page_size, u8 *total_page_num, RSVDPAGE_LOC *rsvd_page_loc, u8 *page_num)
 {
 	u32 len = 0;
 	_adapter *iface = NULL;
@@ -520,8 +1074,21 @@ u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index,
 	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
 	struct mlme_ext_info *pmlmeinfo = NULL;
 	struct mlme_ext_priv *pmlmeext = NULL;
-	u8 ret = _SUCCESS, i = 0, order = 0, CurtPktPageNum = 0;
-	u8 bssid[ETH_ALEN] = {0};
+	struct hal_com_data *hal = GET_HAL_DATA(adapter);
+	struct mcc_adapter_priv *mccadapriv = NULL;
+	u8 ret = _SUCCESS, i = 0, j  =0, order = 0, CurtPktPageNum = 0;
+	u8 *start = NULL;
+	u8 path = RF_PATH_A;
+
+	if (page_num) {
+#ifdef CONFIG_MCC_MODE_V2
+		if (!hal->RegIQKFWOffload)
+			RTW_WARN("[MCC] must enable FW IQK for New IC\n");
+#endif /* CONFIG_MCC_MODE_V2 */
+		/* Null data(interface number) + power index(interface number) + 1  */
+		*total_page_num += (2 * dvobj->iface_nums + 3);
+		goto exit;
+	}
 
 	/* check proccess mcc start setting */
 	if (!rtw_hal_check_mcc_status(adapter, MCC_STATUS_PROCESS_MCC_START_SETTING)) {
@@ -534,34 +1101,37 @@ u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index,
 		if (iface == NULL)
 			continue;
 
-		order = iface->mcc_adapterpriv.order;
-		dvobj->mcc_objpriv.mcc_loc_rsvd_paga[order] = *page_num;
+		mccadapriv = &iface->mcc_adapterpriv;
+		if (mccadapriv->role == MCC_ROLE_MAX)
+			continue;
+
+		order = mccadapriv->order;
+		pmccobjpriv->mcc_loc_rsvd_paga[order] = *total_page_num;
 
-		switch (iface->mcc_adapterpriv.role) {
+		switch (mccadapriv->role) {
 		case MCC_ROLE_STA:
 		case MCC_ROLE_GC:
 			/* Build NULL DATA */
 			RTW_INFO("LocNull(order:%d): %d\n"
-				, order, dvobj->mcc_objpriv.mcc_loc_rsvd_paga[order]);
+				, order, pmccobjpriv->mcc_loc_rsvd_paga[order]);
 			len = 0;
-			pmlmeext = &iface->mlmeextpriv;
-			pmlmeinfo = &pmlmeext->mlmext_info;
 
-			_rtw_memcpy(bssid, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
 			rtw_hal_construct_NullFunctionData(iface
-				, &pframe[*index], &len, bssid, _FALSE, 0, 0, _FALSE);
+				, &pframe[*index], &len, _FALSE, 0, 0, _FALSE);
 			rtw_hal_fill_fake_txdesc(iface, &pframe[*index-tx_desc],
 				len, _FALSE, _FALSE, _FALSE);
 
 			CurtPktPageNum = (u8)PageNum(tx_desc + len, page_size);
-			*page_num += CurtPktPageNum;
+			*total_page_num += CurtPktPageNum;
 			*index += (CurtPktPageNum * page_size);
-			*total_pkt_len = *index + len;
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("LocNull", CurtPktPageNum, *total_page_num, *index);
+			#endif
 			break;
 		case MCC_ROLE_AP:
 			/* Bulid CTS */
 			RTW_INFO("LocCTS(order:%d): %d\n"
-				, order, dvobj->mcc_objpriv.mcc_loc_rsvd_paga[order]);
+				, order, pmccobjpriv->mcc_loc_rsvd_paga[order]);
 
 			len = 0;
 			rtw_hal_construct_CTS(iface, &pframe[*index], &len);
@@ -569,15 +1139,315 @@ u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index,
 				len, _FALSE, _FALSE, _FALSE);
 
 			CurtPktPageNum = (u8)PageNum(tx_desc + len, page_size);
-			*page_num += CurtPktPageNum;
+			*total_page_num += CurtPktPageNum;
 			*index += (CurtPktPageNum * page_size);
-			*total_pkt_len = *index + len;
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("LocCTS", CurtPktPageNum, *total_page_num, *index);
+			#endif
 			break;
 		case MCC_ROLE_GO:
 		/* To DO */
 			break;
+		default:
+			RTW_INFO(FUNC_ADPT_FMT": unknown role = %d\n"
+				, FUNC_ADPT_ARG(iface), mccadapriv->role);
+			break;
 		}
 	}
+
+	for (i = 0; i < MAX_MCC_NUM; i++) {
+		u8 center_ch = 0, ch = 0, bw = 0, bw_offset = 0;
+		u8 power_index = 0;
+		u8 rate_array_sz = 0;
+		u8 *rates = NULL;
+		u8 rate = 0;
+		u8 shift = 0;
+		u32 power_index_4bytes = 0;
+		u8 total_rate = 0;
+		u8 *total_rate_offset = NULL;
+
+		iface = pmccobjpriv->iface[i];
+		pmlmeext = &iface->mlmeextpriv;
+		ch = pmlmeext->cur_channel;
+		bw = pmlmeext->cur_bwmode;
+		bw_offset = pmlmeext->cur_ch_offset;
+		center_ch = rtw_get_center_ch(ch, bw, bw_offset);
+		rtw_hal_mcc_upadate_chnl_bw(iface, ch, bw_offset, bw, _TRUE);
+
+		start = &pframe[*index - tx_desc];
+		_rtw_memset(start, 0, page_size);
+		pmccobjpriv->mcc_pwr_idx_rsvd_page[i] = *total_page_num;
+		RTW_INFO(ADPT_FMT" order:%d, pwr_idx_rsvd_page location[%d]: %d\n",
+			ADPT_ARG(iface), mccadapriv->order,
+			i, pmccobjpriv->mcc_pwr_idx_rsvd_page[i]);
+
+		total_rate_offset = start;
+			
+		for (path = RF_PATH_A; path < hal->NumTotalRFPath; ++path) {
+			total_rate = 0;
+			/* PATH A for 0~63 byte, PATH B for 64~127 byte*/
+			if (path == RF_PATH_A)
+				start = total_rate_offset + 1;
+			else if (path == RF_PATH_B)
+				start = total_rate_offset + 64;
+			else {
+				RTW_INFO("[MCC] %s: unknow RF PATH(%d)\n", __func__, path);
+				break;
+			}
+
+			/* CCK */
+			if (ch <= 14) {
+				rate_array_sz = rates_by_sections[CCK].rate_num;
+				rates = rates_by_sections[CCK].rates;
+				for (j = 0; j < rate_array_sz; ++j) {
+					power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+					rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+					shift = rate % 4;
+					if (shift == 0) {
+						*start = rate;
+						start++;
+						total_rate++;
+
+						#ifdef DBG_PWR_IDX_RSVD_PAGE
+						RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+							ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+							center_ch, MGN_RATE_STR(rates[j]), power_index);
+						#endif
+					}
+
+					*start = power_index;
+					start++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+					
+					shift = rate % 4;
+					power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+					if (shift == 3) {
+						rate = rate - 3;
+						RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+						power_index_4bytes = 0;
+						total_rate++;
+					}
+					#endif
+						
+				}
+			}
+
+			/* OFDM */
+			rate_array_sz = rates_by_sections[OFDM].rate_num;
+			rates = rates_by_sections[OFDM].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+
+				}
+
+				*start = power_index;
+				start++;
+
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* HT_MCS0_MCS7 */
+			rate_array_sz = rates_by_sections[HT_MCS0_MCS7].rate_num;
+			rates = rates_by_sections[HT_MCS0_MCS7].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+
+				}
+
+				*start = power_index;
+				start++;
+
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* HT_MCS8_MCS15 */
+			rate_array_sz = rates_by_sections[HT_MCS8_MCS15].rate_num;
+			rates = rates_by_sections[HT_MCS8_MCS15].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+				}
+
+				*start = power_index;
+				start++;
+
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+				
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* VHT_1SSMCS0_1SSMCS9 */
+			rate_array_sz = rates_by_sections[VHT_1SSMCS0_1SSMCS9].rate_num;
+			rates = rates_by_sections[VHT_1SSMCS0_1SSMCS9].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:0x%02x\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+				}
+				*start = power_index;
+				start++;
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+					total_rate++;
+				}
+				#endif
+			}
+
+			/* VHT_2SSMCS0_2SSMCS9 */
+			rate_array_sz = rates_by_sections[VHT_2SSMCS0_2SSMCS9].rate_num;
+			rates = rates_by_sections[VHT_2SSMCS0_2SSMCS9].rates;
+			for (j = 0; j < rate_array_sz; ++j) {
+				power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
+				rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
+
+				shift = rate % 4;
+				if (shift == 0) {
+					*start = rate;
+					start++;
+					total_rate++;
+					#ifdef DBG_PWR_IDX_RSVD_PAGE
+					RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+						ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+						center_ch, MGN_RATE_STR(rates[j]), power_index);
+					#endif
+				}
+				*start = power_index;
+				start++;
+				#ifdef DBG_PWR_IDX_RSVD_PAGE
+				RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
+					ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
+					center_ch, MGN_RATE_STR(rates[j]), power_index);
+
+				shift = rate % 4;
+				power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
+				if (shift == 3) {
+					rate = rate - 3;
+					RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
+					power_index_4bytes = 0;
+						total_rate++;
+				}
+				#endif
+			}
+				
+		}
+		/*  total rate store in offset 0 */
+		*total_rate_offset = total_rate;
+
+#ifdef DBG_PWR_IDX_RSVD_PAGE
+			RTW_INFO("total_rate=%d\n", total_rate);
+			RTW_INFO(" ======================="ADPT_FMT"===========================\n", ADPT_ARG(iface));
+			RTW_INFO_DUMP("\n", total_rate_offset, 128);
+			RTW_INFO(" ==================================================\n");
+#endif
+
+			CurtPktPageNum = 1;
+			*total_page_num += CurtPktPageNum;
+			*index += (CurtPktPageNum * page_size);
+			#ifdef DBG_RSVD_PAGE_CFG
+			RSVD_PAGE_CFG("mcc_pwr_idx_rsvd_page", CurtPktPageNum, *total_page_num, *index);
+			#endif
+		}
+
 exit:
 	return ret;
 }
@@ -601,12 +1471,17 @@ static void rtw_hal_set_fw_mcc_rsvd_page(PADAPTER padapter)
 	rtw_hal_set_hwreg(port0_iface, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
 
 	/* Re-Download beacon */
-	for (i = 0; i < dvobj->iface_nums; i++) {
+	for (i = 0; i < MAX_MCC_NUM; i++) {
 		iface = pmccobjpriv->iface[i];
+		if (iface == NULL)
+			continue;
+
 		pmccadapriv = &iface->mcc_adapterpriv;
+
 		if (pmccadapriv->role == MCC_ROLE_AP
-			|| pmccadapriv->role == MCC_ROLE_GO)
+			|| pmccadapriv->role == MCC_ROLE_GO) {
 			tx_beacon_hdl(iface, NULL);
+		}
 	}
 }
 
@@ -614,23 +1489,17 @@ static void rtw_hal_set_mcc_rsvdpage_cmd(_adapter *padapter)
 {
 	u8 cmd[H2C_MCC_LOCATION_LEN] = {0}, i = 0, order = 0;
 	_adapter *iface = NULL;
+	PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
 
+	SET_H2CCMD_MCC_PWRIDX_OFFLOAD_EN(cmd, _TRUE);
+	SET_H2CCMD_MCC_PWRIDX_OFFLOAD_RFNUM(cmd, hal->NumTotalRFPath);
+	for (order = 0; order < MAX_MCC_NUM; order++) {
+		iface = pmccobjpriv->iface[i];
 
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		iface = dvobj->padapters[i];
-		if (iface == NULL)
-			continue;
-
-		order = iface->mcc_adapterpriv.order;
-		if (order >= H2C_MCC_LOCATION_LEN) {
-			RTW_INFO(FUNC_ADPT_FMT" only support 3 interface at most(%d)\n"
-				, FUNC_ADPT_ARG(padapter), order);
-			continue;
-		}
-
-		SET_H2CCMD_MCC_RSVDPAGE_LOC((cmd + order), (pmccobjpriv->mcc_loc_rsvd_paga[order]));
+		SET_H2CCMD_MCC_RSVDPAGE_LOC((cmd + order), pmccobjpriv->mcc_loc_rsvd_paga[order]);
+		SET_H2CCMD_MCC_PWRIDX_RSVDPAGE_LOC ((cmd + order), pmccobjpriv->mcc_pwr_idx_rsvd_page[order]);
 	}
 
 #ifdef CONFIG_MCC_MODE_DEBUG
@@ -645,44 +1514,78 @@ static void rtw_hal_set_mcc_rsvdpage_cmd(_adapter *padapter)
 	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_LOCATION, H2C_MCC_LOCATION_LEN, cmd);
 }
 
-static void rtw_hal_set_mcc_noa_cmd(PADAPTER padapter)
+static void rtw_hal_set_mcc_time_setting_cmd(PADAPTER padapter)
 {
 	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
-	u8 cmd[H2C_MCC_NOA_PARAM_LEN] = {0};
-	u8 policy_idx = pmccobjpriv->policy_index;
-	u8 noa_fw_eable = 1;
-	u8 noa_tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
-	u8 noa_start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
-	u8 noa_interval = mcc_switch_channel_policy_table[policy_idx][MCC_INTERVAL_IDX];
-	u8 guard_offset0 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET0_IDX];
-	u8 guard_offset1 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET1_IDX];
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	u8 cmd[H2C_MCC_TIME_SETTING_LEN] = {0};
+	u8 fw_eable = 1;
 	u8 swchannel_early_time = MCC_SWCH_FW_EARLY_TIME;
-	u8 i = 0;
+	u8 starting_ap_num = DEV_AP_STARTING_NUM(dvobj);
+	u8 ap_num = DEV_AP_NUM(dvobj);	
 
-	/* FW set NOA enable */
-	SET_H2CCMD_MCC_NOA_FW_EN(cmd, noa_fw_eable);
-	/* TSF Sync offset */
-	SET_H2CCMD_MCC_NOA_TSF_SYNC_OFFSET(cmd, noa_tsf_sync_offset);
-	/* NoA start time offset */
-	SET_H2CCMD_MCC_NOA_START_TIME(cmd, (noa_start_time_offset + guard_offset0));
-	/* NoA interval */
-	SET_H2CCMD_MCC_NOA_INTERVAL(cmd, noa_interval);
-	/* Early time to inform driver by C2H before switch channel */
-	SET_H2CCMD_MCC_EARLY_TIME(cmd, swchannel_early_time);
+	if (starting_ap_num == 0 && ap_num == 0)
+		/* For STA+GC/STA+STA, TSF of GC/STA does not need to sync from TSF of other STA/GC */
+		fw_eable = 0;
+	else
+		/* Only for STA+GO/STA+AP, TSF of AP/GO need to sync from TSF of STA */
+		fw_eable = 1;
+
+	if (fw_eable == 1) {
+		PADAPTER order0_iface = NULL;
+		PADAPTER order1_iface = NULL;
+		u8 policy_idx = mccobjpriv->policy_index;
+		u8 tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
+		u8 start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
+		u8 interval = mcc_switch_channel_policy_table[policy_idx][MCC_INTERVAL_IDX];
+		u8 guard_offset0 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET0_IDX];
+		u8 guard_offset1 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET1_IDX];
+		enum _hw_port tsf_bsae_port = MAX_HW_PORT;
+		enum _hw_port tsf_sync_port = MAX_HW_PORT;
+		order0_iface = mccobjpriv->iface[0];
+		order1_iface = mccobjpriv->iface[1];
+
+		tsf_bsae_port = rtw_hal_get_port(order1_iface);
+		tsf_sync_port = rtw_hal_get_port(order0_iface);
+		
+		/* FW set enable */
+		SET_H2CCMD_MCC_TIME_SETTING_FW_EN(cmd, fw_eable);
+		/* TSF Sync offset */
+		SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(cmd, tsf_sync_offset);
+		/* start time offset */
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, (start_time_offset + guard_offset0));
+		/* interval */
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
+		/* Early time to inform driver by C2H before switch channel */
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+		/* Port0 sync from Port1, not support multi-port */
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(cmd, tsf_bsae_port);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(cmd, tsf_sync_port);
+	} else {
+		/* start time offset */
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, mccobjpriv->start_time);
+		/* interval */
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, mccobjpriv->interval);
+		/* Early time to inform driver by C2H before switch channel */
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+	}
 
 #ifdef CONFIG_MCC_MODE_DEBUG
-	RTW_INFO("=========================\n");
-	RTW_INFO("NoA:\n");
-	for (i = 0; i < H2C_MCC_NOA_PARAM_LEN; i++)
-		pr_dbg("0x%x ", cmd[i]);
-	pr_dbg("\n");
-	RTW_INFO("=========================\n");
+	{
+		u8 i = 0;
+
+		RTW_INFO("=========================\n");
+		RTW_INFO("NoA:\n");
+		for (i = 0; i < H2C_MCC_TIME_SETTING_LEN; i++)
+			pr_dbg("0x%x ", cmd[i]);
+		pr_dbg("\n");
+		RTW_INFO("=========================\n");
+	}
 #endif /* CONFIG_MCC_MODE_DEBUG */
 
-	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_NOA_PARAM, H2C_MCC_NOA_PARAM_LEN, cmd);
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_TIME_SETTING, H2C_MCC_TIME_SETTING_LEN, cmd);
 }
 
 static void rtw_hal_set_mcc_IQK_offload_cmd(PADAPTER padapter)
@@ -697,7 +1600,7 @@ static void rtw_hal_set_mcc_IQK_offload_cmd(PADAPTER padapter)
 	u8 rf_path_idx = 0, last_order = MAX_MCC_NUM - 1, last_rf_path_index = total_rf_path - 1;
 
 	/* by order, last order & last_rf_path_index must set ready bit = 1 */
-	for (i = 0; i < dvobj->iface_nums; i++) {
+	for (i = 0; i < MAX_MCC_NUM; i++) {
 		iface = pmccobjpriv->iface[i];
 		if (iface == NULL)
 			continue;
@@ -779,6 +1682,9 @@ static void rtw_hal_set_mcc_macid_cmd(PADAPTER padapter)
 			continue;
 
 		pmccadapriv = &iface->mcc_adapterpriv;
+		if (pmccadapriv->role == MCC_ROLE_MAX)
+			continue;
+		
 		order = pmccadapriv->order;
 		bitmap = pmccadapriv->mcc_macid_bitmap;
 
@@ -795,20 +1701,168 @@ static void rtw_hal_set_mcc_macid_cmd(PADAPTER padapter)
 	RTW_INFO("=========================\n");
 	RTW_INFO("MACID BITMAP: ");
 	for (i = 0; i < H2C_MCC_MACID_BITMAP_LEN; i++)
-		pr_dbg("0x%x ", cmd[i]);
-	pr_dbg("\n");
+		printk("0x%x ", cmd[i]);
+	printk("\n");
 	RTW_INFO("=========================\n");
 #endif /* CONFIG_MCC_MODE_DEBUG */
 	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_MACID_BITMAP, H2C_MCC_MACID_BITMAP_LEN, cmd);
 }
 
-static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
+#ifdef CONFIG_MCC_MODE_V2
+static u8 get_pri_ch_idx_by_adapter(u8 center_ch, u8 channel, u8 bw, u8 ch_offset40)
+{
+	u8 pri_ch_idx = 0, chnl_offset80 = 0;
+
+	if (bw == CHANNEL_WIDTH_80) {
+		if (center_ch > channel)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
+		else if (center_ch < channel)
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
+		else
+			chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	}
+
+	if (bw == CHANNEL_WIDTH_80) {
+		/* primary channel is at lower subband of 80MHz & 40MHz */
+		if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER))
+			pri_ch_idx = VHT_DATA_SC_20_LOWEST_OF_80MHZ;
+		/* primary channel is at lower subband of 80MHz & upper subband of 40MHz */
+		else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_UPPER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER))
+			pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+		/* primary channel is at upper subband of 80MHz & lower subband of 40MHz */
+		else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER))
+			pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+		/* primary channel is at upper subband of 80MHz & upper subband of 40MHz */
+		else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_UPPER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER))
+			pri_ch_idx = VHT_DATA_SC_20_UPPERST_OF_80MHZ;
+		else {
+			if (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER)
+				pri_ch_idx = VHT_DATA_SC_40_LOWER_OF_80MHZ;
+			else if (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER)
+				pri_ch_idx = VHT_DATA_SC_40_UPPER_OF_80MHZ;
+			else
+				RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+		}
+	} else if (bw == CHANNEL_WIDTH_40) {
+		/* primary channel is at upper subband of 40MHz */
+		if (ch_offset40== HAL_PRIME_CHNL_OFFSET_UPPER)
+			pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
+		/* primary channel is at lower subband of 40MHz */
+		else if (ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER)
+			pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
+		else
+			RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
+	}
+
+	return  pri_ch_idx;
+}
+
+static void rtw_hal_set_mcc_ctrl_cmd_v2(PADAPTER padapter, u8 stop)
+{
+	u8 cmd[H2C_MCC_CTRL_LEN] = {0}, i = 0;
+	u8 order = 0, totalnum = 0;
+	u8 center_ch = 0, pri_ch_idx = 0, bw = 0;
+	u8 duration = 0, role = 0, incurch = 0, rfetype = 0, distxnull = 0, c2hrpt = 0;
+	u8 dis_sw_retry = 0, null_early_time=2, tsfx = 0, update_parm = 0;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_adapter_priv *mccadapriv = NULL;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mlme_ext_info *pmlmeinfo = NULL;
+	_adapter *iface = NULL;
+
+	RTW_INFO(FUNC_ADPT_FMT": stop=%d\n", FUNC_ADPT_ARG(padapter), stop);
+
+	for (i = 0; i < MAX_MCC_NUM; i++) {
+		iface = pmccobjpriv->iface[i];
+		if (iface == NULL)
+			continue;
+
+		if (stop) {
+			if (iface != padapter)
+				continue;
+		}
+
+		mccadapriv = &iface->mcc_adapterpriv;
+		order = mccadapriv->order;
+
+		if (!stop)
+			totalnum = MAX_MCC_NUM;
+		else
+			totalnum = 0xff; /* 0xff means stop */
+
+		pmlmeext = &iface->mlmeextpriv;
+		center_ch = rtw_get_center_ch(pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
+		pri_ch_idx = get_pri_ch_idx_by_adapter(center_ch, pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
+		bw = pmlmeext->cur_bwmode;
+		duration = mccadapriv->mcc_duration;
+		role = mccadapriv->role;
+
+		incurch = _FALSE;
+		dis_sw_retry = _TRUE;
+
+		/* STA/GC TX NULL data to inform AP/GC for ps mode */
+		switch (role) {
+		case MCC_ROLE_GO:
+		case MCC_ROLE_AP:
+			distxnull = MCC_DISABLE_TX_NULL;
+			break;
+		case MCC_ROLE_GC:
+			set_channel_bwmode(iface, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
+			distxnull = MCC_ENABLE_TX_NULL;
+			break;
+		case MCC_ROLE_STA:
+			distxnull = MCC_ENABLE_TX_NULL;
+			break;
+		}
+
+		null_early_time = mccadapriv->null_early;
+
+		c2hrpt = MCC_C2H_REPORT_ALL_STATUS;
+		tsfx = rtw_hal_get_port(iface);
+		update_parm = 0;
+
+		SET_H2CCMD_MCC_CTRL_V2_ORDER(cmd, order);
+		SET_H2CCMD_MCC_CTRL_V2_TOTALNUM(cmd, totalnum);
+		SET_H2CCMD_MCC_CTRL_V2_CENTRAL_CH(cmd, center_ch);
+		SET_H2CCMD_MCC_CTRL_V2_PRIMARY_CH(cmd, pri_ch_idx);
+		SET_H2CCMD_MCC_CTRL_V2_BW(cmd, bw);
+		SET_H2CCMD_MCC_CTRL_V2_DURATION(cmd, duration);
+		SET_H2CCMD_MCC_CTRL_V2_ROLE(cmd, role);
+		SET_H2CCMD_MCC_CTRL_V2_INCURCH(cmd, incurch);
+		SET_H2CCMD_MCC_CTRL_V2_DIS_SW_RETRY(cmd, dis_sw_retry);
+		SET_H2CCMD_MCC_CTRL_V2_DISTXNULL(cmd, distxnull);
+		SET_H2CCMD_MCC_CTRL_V2_C2HRPT(cmd, c2hrpt);
+		SET_H2CCMD_MCC_CTRL_V2_TSFX(cmd, tsfx);
+		SET_H2CCMD_MCC_CTRL_V2_NULL_EARLY(cmd, null_early_time);
+		SET_H2CCMD_MCC_CTRL_V2_UPDATE_PARM(cmd, update_parm);
+
+#ifdef CONFIG_MCC_MODE_DEBUG
+		RTW_INFO("=========================\n");
+		RTW_INFO(FUNC_ADPT_FMT" MCC INFO:\n", FUNC_ADPT_ARG(iface));
+		RTW_INFO("cmd[0]:0x%02x\n", cmd[0]);
+		RTW_INFO("cmd[1]:0x%02x\n", cmd[1]);
+		RTW_INFO("cmd[2]:0x%02x\n", cmd[2]);
+		RTW_INFO("cmd[3]:0x%02x\n", cmd[3]);
+		RTW_INFO("cmd[4]:0x%02x\n", cmd[4]);
+		RTW_INFO("cmd[5]:0x%02x\n", cmd[5]);
+		RTW_INFO("cmd[6]:0x%02x\n", cmd[6]);
+		RTW_INFO("=========================\n");
+#endif /* CONFIG_MCC_MODE_DEBUG */
+
+		rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_CTRL_V2, H2C_MCC_CTRL_LEN, cmd);
+	}
+}
+
+#else
+static void rtw_hal_set_mcc_ctrl_cmd_v1(PADAPTER padapter, u8 stop)
 {
 	u8 cmd[H2C_MCC_CTRL_LEN] = {0}, i = 0;
 	u8 order = 0, totalnum = 0, chidx = 0, bw = 0, bw40sc = 0, bw80sc = 0;
 	u8 duration = 0, role = 0, incurch = 0, rfetype = 0, distxnull = 0, c2hrpt = 0, chscan = 0;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_adapter_priv *mccadapriv = NULL;
 	struct mlme_ext_priv *pmlmeext = NULL;
 	struct mlme_ext_info *pmlmeinfo = NULL;
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
@@ -816,7 +1870,7 @@ static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
 
 	RTW_INFO(FUNC_ADPT_FMT": stop=%d\n", FUNC_ADPT_ARG(padapter), stop);
 
-	for (i = 0; i < dvobj->iface_nums; i++) {
+	for (i = 0; i < MAX_MCC_NUM; i++) {
 		iface = pmccobjpriv->iface[i];
 		if (iface == NULL)
 			continue;
@@ -826,10 +1880,11 @@ static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
 				continue;
 		}
 
+		mccadapriv = &iface->mcc_adapterpriv;
+		order = mccadapriv->order;
 
-		order = iface->mcc_adapterpriv.order;
 		if (!stop)
-			totalnum = dvobj->iface_nums;
+			totalnum = MAX_MCC_NUM;
 		else
 			totalnum = 0xff; /* 0xff means stop */
 
@@ -851,8 +1906,8 @@ static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
 		} else
 			bw80sc = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
 
-		duration = iface->mcc_adapterpriv.mcc_duration;
-		role = iface->mcc_adapterpriv.role;
+		duration = mccadapriv->mcc_duration;
+		role = mccadapriv->role;
 
 		incurch = _FALSE;
 
@@ -903,13 +1958,79 @@ static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
 		RTW_INFO("=========================\n");
 #endif /* CONFIG_MCC_MODE_DEBUG */
 
-		rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_CTRL, H2C_MCC_CTRL_LEN, cmd);
+		rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_CTRL, H2C_MCC_CTRL_LEN, cmd);
+	}
+}
+#endif
+
+static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
+{
+	#ifdef CONFIG_MCC_MODE_V2
+		/* new cmd 0x17 */
+		rtw_hal_set_mcc_ctrl_cmd_v2(padapter, stop);
+	#else
+		/* old cmd 0x18 */
+		rtw_hal_set_mcc_ctrl_cmd_v1(padapter, stop);
+	#endif
+}
+
+static u8 check_mcc_support(PADAPTER adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	u8 sta_linking_num = DEV_STA_LG_NUM(dvobj);
+	u8 sta_linked_num = DEV_STA_LD_NUM(dvobj);
+	u8 starting_ap_num = DEV_AP_STARTING_NUM(dvobj);
+	u8 ap_num = DEV_AP_NUM(dvobj);
+	u8 ret = _SUCCESS;
+
+	/* case for linking sta + linked sta  */
+	if ((sta_linking_num + sta_linked_num) != MAX_MCC_NUM) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* case for starting AP + linked sta */
+	if ((starting_ap_num + sta_linked_num) != MAX_MCC_NUM) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* case for linking sta  + started AP */
+	if ((sta_linking_num + ap_num) != MAX_MCC_NUM) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+	/* case for starting AP +  started AP */
+	if ((starting_ap_num + ap_num) != MAX_MCC_NUM) {
+		ret = _FAIL;
+		goto exit;
+	}
+
+exit:
+		return ret;
+}
+
+static void rtw_hal_mcc_start_prehdl(PADAPTER padapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	_adapter *iface = NULL;
+	struct mcc_adapter_priv *mccadapriv = NULL;
+	u8 i = 1;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+
+		mccadapriv = &iface->mcc_adapterpriv;
+		mccadapriv->role = MCC_ROLE_MAX;
 	}
 }
 
 static u8 rtw_hal_set_mcc_start_setting(PADAPTER padapter, u8 status)
 {
-	u8 ret = _SUCCESS;
+	u8 ret = _SUCCESS, enable_tsf_auto_sync = _FALSE;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
 
@@ -919,12 +2040,15 @@ static u8 rtw_hal_set_mcc_start_setting(PADAPTER padapter, u8 status)
 		LeaveAllPowerSaveModeDirect(padapter);
 	}
 
-	if (dvobj->iface_nums > MAX_MCC_NUM) {
-		RTW_INFO("%s: current iface num(%d) > MAX_MCC_NUM(%d)\n", __func__, dvobj->iface_nums, MAX_MCC_NUM);
+	if (check_mcc_support(padapter)) {
+		RTW_INFO("%s: check_mcc_support fail\n", __func__);
+		dump_dvobj_mi_status(RTW_DBGDUMP, __func__, padapter);
 		ret = _FAIL;
 		goto exit;
 	}
 
+	rtw_hal_mcc_start_prehdl(padapter);
+
 	/* configure mcc switch channel setting */
 	rtw_hal_config_mcc_switch_channel_setting(padapter);
 
@@ -943,15 +2067,25 @@ static u8 rtw_hal_set_mcc_start_setting(PADAPTER padapter, u8 status)
 		rtw_hal_set_mcc_rsvdpage_cmd(padapter);
 	}
 
-	/* configure NoA setting */
-	rtw_hal_set_mcc_noa_cmd(padapter);
+	/* configure time setting */
+	rtw_hal_set_mcc_time_setting_cmd(padapter);
 
+#ifndef CONFIG_MCC_MODE_V2
 	/* IQK value offload */
 	rtw_hal_set_mcc_IQK_offload_cmd(padapter);
+#endif
 
 	/* set mac id to fw */
 	rtw_hal_set_mcc_macid_cmd(padapter);
 
+	if (dvobj->p0_tsf.sync_port != MAX_HW_PORT ) {
+		/* disable tsf auto sync */
+		RTW_INFO("[MCC] disable HW TSF sync\n");
+		rtw_hal_set_hwreg(padapter, HW_VAR_TSF_AUTO_SYNC, &enable_tsf_auto_sync);
+	} else {
+		RTW_INFO("[MCC] already disable HW TSF sync\n");
+	}
+
 	/* set mcc parameter  */
 	rtw_hal_set_mcc_ctrl_cmd(padapter, _FALSE);
 
@@ -962,7 +2096,9 @@ exit:
 static void rtw_hal_set_mcc_stop_setting(PADAPTER padapter, u8 status)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &dvobj->mcc_objpriv;
 	_adapter *iface = NULL;
+	struct mcc_adapter_priv *mccadapriv = NULL;
 	u8 i = 0;
 	/*
 	 * when adapter disconnect, stop mcc mod
@@ -972,10 +2108,13 @@ static void rtw_hal_set_mcc_stop_setting(PADAPTER padapter, u8 status)
 	switch (status) {
 	default:
 		/* let fw switch to other interface channel */
-		for (i = 0; i < dvobj->iface_nums; i++) {
-			iface = dvobj->padapters[i];
+		for (i = 0; i < MAX_MCC_NUM; i++) {
+			iface = mccobjpriv->iface[i];
 			if (iface == NULL)
 				continue;
+
+			mccadapriv = &iface->mcc_adapterpriv;
+
 			/* use other interface to set cmd */
 			if (iface != padapter) {
 				rtw_hal_set_mcc_ctrl_cmd(iface, _TRUE);
@@ -1010,38 +2149,94 @@ static void rtw_hal_mcc_status_hdl(PADAPTER padapter, u8 status)
 static void rtw_hal_mcc_stop_posthdl(PADAPTER padapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	struct mcc_adapter_priv *mccadapriv = NULL;
 	_adapter *iface = NULL;
+	PHAL_DATA_TYPE hal;
+	struct dm_struct *p_dm_odm;
 	u8 i = 0;
+	u8 enable_rx_bar = _FALSE;
 
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		iface = dvobj->padapters[i];
+	for (i = 0; i < MAX_MCC_NUM; i++) {
+		iface = mccobjpriv->iface[i];
 		if (iface == NULL)
 			continue;
+
 		/* release network queue */
 		rtw_netif_wake_queue(iface->pnetdev);
-		iface->mcc_adapterpriv.mcc_tx_bytes_from_kernel = 0;
-		iface->mcc_adapterpriv.mcc_last_tx_bytes_from_kernel = 0;
-		iface->mcc_adapterpriv.mcc_tx_bytes_to_port = 0;
+		mccadapriv = &iface->mcc_adapterpriv;
+		mccadapriv->mcc_tx_bytes_from_kernel = 0;
+		mccadapriv->mcc_last_tx_bytes_from_kernel = 0;
+		mccadapriv->mcc_tx_bytes_to_port = 0;
 
-		if (iface->mcc_adapterpriv.role == MCC_ROLE_GO)
+		if (mccadapriv->role == MCC_ROLE_GO)
 			rtw_hal_mcc_remove_go_p2p_ie(iface);
+
+#ifdef CONFIG_TDLS
+		if (MLME_IS_STA(iface)) {
+			if (mccadapriv->backup_tdls_en) {
+				rtw_enable_tdls_func(iface);
+				RTW_INFO("%s: Disable MCC, Enable TDLS\n", __func__);
+				mccadapriv->backup_tdls_en = _FALSE;
+			}
+		}
+#endif /* CONFIG_TDLS */
+
+		mccadapriv->role = MCC_ROLE_MAX;
+		mccobjpriv->iface[i] = NULL;
 	}
+
+	hal = GET_HAL_DATA(padapter);
+	p_dm_odm = &hal->odmpriv;
+	phydm_dm_early_init(p_dm_odm);
+
+	/* force switch channel */
+	hal->current_channel = 0;
+	hal->current_channel_bw = CHANNEL_WIDTH_MAX;
 }
 
 static void rtw_hal_mcc_start_posthdl(PADAPTER padapter)
 {
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	struct mcc_adapter_priv *mccadapriv = NULL;
 	_adapter *iface = NULL;
+	PHAL_DATA_TYPE hal;
+	struct dm_struct *p_dm_odm;
+	struct _hal_rf_ *p_rf;
+	u32 support_ability = 0;
 	u8 i = 0;
+	u8 enable_rx_bar = _TRUE;
 
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
 		if (iface == NULL)
 			continue;
-		iface->mcc_adapterpriv.mcc_tx_bytes_from_kernel = 0;
-		iface->mcc_adapterpriv.mcc_last_tx_bytes_from_kernel = 0;
-		iface->mcc_adapterpriv.mcc_tx_bytes_to_port = 0;
+
+		mccadapriv = &iface->mcc_adapterpriv;
+		if (mccadapriv->role == MCC_ROLE_MAX)
+			continue;
+		
+		mccadapriv->mcc_tx_bytes_from_kernel = 0;
+		mccadapriv->mcc_last_tx_bytes_from_kernel = 0;
+		mccadapriv->mcc_tx_bytes_to_port = 0;
+
+#ifdef CONFIG_TDLS
+		if (MLME_IS_STA(iface)) {
+			if (rtw_is_tdls_enabled(iface)) {
+				mccadapriv->backup_tdls_en = _TRUE;
+				rtw_disable_tdls_func(iface, _TRUE);
+				RTW_INFO("%s: Enable MCC, Disable TDLS\n", __func__);
+			}
+		}
+#endif /* CONFIG_TDLS */
 	}
+
+	hal = GET_HAL_DATA(padapter);
+	p_dm_odm = &hal->odmpriv;
+	p_rf = &(p_dm_odm->rf_table);
+	mccobjpriv->backup_phydm_ability = p_rf->rf_supportability;
+	p_rf->rf_supportability = p_rf->rf_supportability & (~HAL_RF_TX_PWR_TRACK) & (~HAL_RF_IQK);
 }
 
 /*
@@ -1055,7 +2250,7 @@ static u8 rtw_hal_set_mcc_setting(PADAPTER padapter, u8 status)
 	u8 ret = _FAIL;
 	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
 	u8 stop = (status < MCC_SETCMD_STATUS_START_CONNECT) ? _TRUE : _FALSE;
-	systime start_time = rtw_get_current_time();
+	u32 start_time = rtw_get_current_time();
 
 	RTW_INFO("===> "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
 
@@ -1075,6 +2270,7 @@ static u8 rtw_hal_set_mcc_setting(PADAPTER padapter, u8 status)
 
 		if (ret == _SUCCESS) {
 			RTW_INFO(FUNC_ADPT_FMT": mcc start sucecssfully\n", FUNC_ADPT_ARG(padapter));
+			rtw_hal_mcc_status_hdl(padapter, status);
 			rtw_hal_mcc_start_posthdl(padapter);
 		}
 	} else {
@@ -1090,13 +2286,12 @@ static u8 rtw_hal_set_mcc_setting(PADAPTER padapter, u8 status)
 			RTW_INFO(FUNC_ADPT_FMT": wait for mcc stop C2H time out\n", FUNC_ADPT_ARG(padapter));
 		else {
 			ret = _SUCCESS;
+			rtw_hal_mcc_status_hdl(padapter, status);
 			rtw_hal_mcc_stop_posthdl(padapter);
 		}
 	}
 
 exit:
-
-	rtw_hal_mcc_status_hdl(padapter, status);
 	/* clear mcc status */
 	rtw_hal_clear_mcc_status(padapter
 		, MCC_STATUS_PROCESS_MCC_START_SETTING | MCC_STATUS_PROCESS_MCC_STOP_SETTING);
@@ -1141,6 +2336,9 @@ static void rtw_hal_mcc_sw_ch_fw_notify_hdl(PADAPTER padapter)
 
 	for (i = 0; i < iface_num; i++) {
 		iface = pdvobjpriv->padapters[i];
+		if (iface == NULL)
+			continue;
+
 		if (cur_op_ch == iface->mlmeextpriv.cur_channel) {
 			cur_iface = iface;
 			cur_mccadapriv = &cur_iface->mcc_adapterpriv;
@@ -1152,6 +2350,12 @@ static void rtw_hal_mcc_sw_ch_fw_notify_hdl(PADAPTER padapter)
 		}
 	}
 
+	if (cur_iface == NULL || next_iface == NULL) {
+		RTW_ERR("cur_iface=%p,next_iface=%p\n", cur_iface, next_iface);
+		rtw_warn_on(1);
+		return;
+	}
+
 	/* check other interface tx busy traffic or not under every 2 switch channel notify(Mbits/100ms) */
 	if (cnt == 2) {
 		cur_mccadapriv->mcc_tp = (cur_mccadapriv->mcc_tx_bytes_from_kernel
@@ -1230,6 +2434,9 @@ static void rtw_hal_mcc_update_noa_start_time_hdl(PADAPTER padapter, u8 buflen,
 			continue;
 		
 		pmccadapriv = &iface->mcc_adapterpriv;
+		if (pmccadapriv->role == MCC_ROLE_MAX)
+			continue;
+
 		/* GO & channel match */
 		if (pmccadapriv->role == MCC_ROLE_GO) {
 			/* convert GO TBTT from FW to noa_start_time(TU convert to mircosecond) */
@@ -1255,6 +2462,31 @@ static void rtw_hal_mcc_update_noa_start_time_hdl(PADAPTER padapter, u8 buflen,
 
 }
 
+static void rtw_hal_mcc_rpt_tsf_hdl(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
+{
+	struct dvobj_priv *dvobjpriv = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
+	struct submit_ctx *mcc_tsf_req_sctx = &mccobjpriv->mcc_tsf_req_sctx;
+	struct mcc_adapter_priv *mccadapriv = NULL;
+	_adapter *iface = NULL;
+	u8 order = 0;
+
+	order = mccobjpriv->mcc_tsf_req_sctx_order;
+	iface = mccobjpriv->iface[order];
+	mccadapriv = &iface->mcc_adapterpriv;
+	mccadapriv->tsf = RTW_GET_LE64(tmpBuf + 2);
+
+
+	if (0)
+		RTW_INFO(FUNC_ADPT_FMT" TSF(order:%d):0x%02llx\n", FUNC_ADPT_ARG(iface), mccadapriv->order, mccadapriv->tsf);
+
+	if (mccadapriv->order == (MAX_MCC_NUM - 1))
+		rtw_sctx_done(&mcc_tsf_req_sctx);
+	else
+		mccobjpriv->mcc_tsf_req_sctx_order ++;
+
+}
+
 /**
  * rtw_hal_mcc_c2h_handler - mcc c2h handler
  */
@@ -1264,6 +2496,8 @@ void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
 	struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
 	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
 	struct submit_ctx *mcc_sctx = &pmccobjpriv->mcc_sctx;
+	_adapter *cur_adapter = NULL;
+	u8 cur_ch = 0, cur_bw = 0, cur_ch_offset = 0;
 	_irqL irqL;
 
 	/* RTW_INFO("[length]=%d, [C2H data]="MAC_FMT"\n", buflen, MAC_ARG(tmpBuf)); */
@@ -1274,19 +2508,32 @@ void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
 	}
 
 	pmccobjpriv->mcc_c2h_status = tmpBuf[0];
+	pmccobjpriv->current_order = tmpBuf[1];
+	cur_adapter = pmccobjpriv->iface[pmccobjpriv->current_order];
+	cur_ch = cur_adapter->mlmeextpriv.cur_channel;
+	cur_bw = cur_adapter->mlmeextpriv.cur_bwmode;
+	cur_ch_offset = cur_adapter->mlmeextpriv.cur_ch_offset;
+	rtw_set_oper_ch(cur_adapter, cur_ch);
+	rtw_set_oper_bw(cur_adapter, cur_bw);
+	rtw_set_oper_choffset(cur_adapter, cur_ch_offset);
+
+	if (0)
+		RTW_INFO("%d,order:%d,TSF:0x%llx\n", tmpBuf[0], tmpBuf[1], RTW_GET_LE64(tmpBuf + 2));
+	
 	switch (pmccobjpriv->mcc_c2h_status) {
 	case MCC_RPT_SUCCESS:
-		pdvobjpriv->oper_channel = tmpBuf[1];
 		_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
 		pmccobjpriv->cur_mcc_success_cnt++;
+		rtw_hal_mcc_upadate_chnl_bw(cur_adapter, cur_ch, cur_ch_offset, cur_bw, _FALSE);
 		_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
 		break;
 	case MCC_RPT_TXNULL_FAIL:
 		RTW_INFO("[MCC] TXNULL FAIL\n");
 		break;
 	case MCC_RPT_STOPMCC:
-		RTW_INFO("[MCC] MCC stop (time:%d)\n", rtw_get_current_time());
+		RTW_INFO("[MCC] MCC stop\n");
 		pmccobjpriv->mcc_c2h_status = MCC_RPT_STOPMCC;
+		rtw_hal_mcc_upadate_chnl_bw(cur_adapter, cur_ch, cur_ch_offset, cur_bw, _TRUE);
 		rtw_sctx_done(&mcc_sctx);
 		break;
 	case MCC_RPT_READY:
@@ -1299,22 +2546,116 @@ void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
 		pmccobjpriv->mcc_tolerance_time = MCC_TOLERANCE_TIME;
 		_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
 
-		RTW_INFO("[MCC] MCC ready (time:%d)\n", pmccobjpriv->mcc_launch_time);
+		RTW_INFO("[MCC] MCC ready\n");
 		rtw_sctx_done(&mcc_sctx);
 		break;
 	case MCC_RPT_SWICH_CHANNEL_NOTIFY:
-		pdvobjpriv->oper_channel = tmpBuf[1];
 		rtw_hal_mcc_sw_ch_fw_notify_hdl(padapter);
 		break;
 	case MCC_RPT_UPDATE_NOA_START_TIME:
 		rtw_hal_mcc_update_noa_start_time_hdl(padapter, buflen, tmpBuf);
 		break;
+	case MCC_RPT_TSF:
+		_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		rtw_hal_mcc_rpt_tsf_hdl(padapter, buflen, tmpBuf);
+		_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
+		break;
 	default:
 		/* RTW_INFO("[MCC] Other MCC status(%d)\n", pmccobjpriv->mcc_c2h_status); */
 		break;
 	}
 }
 
+void rtw_hal_mcc_update_parameter(PADAPTER padapter, u8 force_update)
+{	
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	u8 cmd[H2C_MCC_TIME_SETTING_LEN] = {0};
+	u8 swchannel_early_time = MCC_SWCH_FW_EARLY_TIME;
+	u8 ap_num = DEV_AP_NUM(dvobj);	
+
+	if (ap_num == 0) {
+		u8 need_update = _FALSE;
+		u8 start_time_offset = 0, interval = 0, duration = 0;
+
+		need_update = rtw_hal_mcc_update_timing_parameters(padapter, force_update);
+
+		if (need_update == _FALSE)
+			return;
+		
+		start_time_offset = mccobjpriv->start_time;
+		interval = mccobjpriv->interval;
+		duration = mccobjpriv->iface[0]->mcc_adapterpriv.mcc_duration;
+
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, start_time_offset);
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+		SET_H2CCMD_MCC_TIME_SETTING_UPDATE(cmd, _TRUE);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(cmd, duration);
+	} else {
+		PADAPTER order0_iface = NULL;
+		PADAPTER order1_iface = NULL;
+		u8 policy_idx = mccobjpriv->policy_index;
+		u8 duration = mcc_switch_channel_policy_table[policy_idx][MCC_DURATION_IDX];
+		u8 tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
+		u8 start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
+		u8 interval = mcc_switch_channel_policy_table[policy_idx][MCC_INTERVAL_IDX];
+		u8 guard_offset0 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET0_IDX];
+		u8 guard_offset1 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET1_IDX];
+		u8 order0_duration = 0;
+		u8 i = 0;
+		enum _hw_port tsf_bsae_port = MAX_HW_PORT;
+		enum _hw_port tsf_sync_port = MAX_HW_PORT;
+
+		RTW_INFO("%s: policy_idx=%d\n", __func__, policy_idx);
+
+		order0_iface = mccobjpriv->iface[0];
+		order1_iface = mccobjpriv->iface[1];
+
+		/* GO/AP is order 0, GC/STA is order 1 */
+		order0_duration = order0_iface->mcc_adapterpriv.mcc_duration = interval - duration;
+		order0_iface->mcc_adapterpriv.mcc_duration = duration;
+
+		tsf_bsae_port = rtw_hal_get_port(order1_iface);
+		tsf_sync_port = rtw_hal_get_port(order0_iface);
+
+		/* update IE */
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			PADAPTER iface = NULL;
+			struct mcc_adapter_priv *mccadapriv = NULL;
+
+			iface = dvobj->padapters[i];
+			if (iface == NULL)
+				continue;
+		
+			mccadapriv = &iface->mcc_adapterpriv;
+			if (mccadapriv->role == MCC_ROLE_MAX)
+				continue;
+			
+			if (mccadapriv->role == MCC_ROLE_GO)
+				rtw_hal_mcc_update_go_p2p_ie(iface);
+		}
+
+		/* update H2C cmd */
+		/* FW set enable */
+		SET_H2CCMD_MCC_TIME_SETTING_FW_EN(cmd, _TRUE);
+		/* TSF Sync offset */
+		SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(cmd, tsf_sync_offset);
+		/* start time offset */
+		SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, (start_time_offset + guard_offset0));
+		/* interval */
+		SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
+		/* Early time to inform driver by C2H before switch channel */
+		SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
+		/* Port0 sync from Port1, not support multi-port */
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(cmd, tsf_bsae_port);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(cmd, tsf_sync_port);
+		SET_H2CCMD_MCC_TIME_SETTING_UPDATE(cmd, _TRUE);
+		SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(cmd, order0_duration);
+	}
+
+	rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_TIME_SETTING, H2C_MCC_TIME_SETTING_LEN, cmd);
+}
 
 /**
  * rtw_hal_mcc_sw_status_check - check mcc swich channel status
@@ -1325,8 +2666,14 @@ void rtw_hal_mcc_sw_status_check(PADAPTER padapter)
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
 	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
 	struct pwrctrl_priv	*pwrpriv = dvobj_to_pwrctl(dvobj);
-	u8 cur_cnt = 0, prev_cnt = 0, diff_cnt = 0, check_ret = _FAIL;
+	struct mcc_adapter_priv *mccadapriv = NULL;
+	_adapter *iface = NULL;
+	u8 cur_cnt = 0, prev_cnt = 0, diff_cnt = 0, check_ret = _FAIL, threshold = 0;
+	u8 policy_idx = pmccobjpriv->policy_index;
+	u8 noa_enable = _FALSE;
+	u8 i = 0;
 	_irqL irqL;
+	u8 ap_num = DEV_AP_NUM(dvobj);	
 
 /* #define MCC_RESTART 1 */
 
@@ -1337,6 +2684,27 @@ void rtw_hal_mcc_sw_status_check(PADAPTER padapter)
 
 	if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
 
+		/* check noa enable or not */
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			iface = dvobj->padapters[i];
+			if (iface == NULL)
+				continue;
+
+			mccadapriv = &iface->mcc_adapterpriv;
+			if (mccadapriv->role == MCC_ROLE_MAX)
+				continue;
+			
+			if (iface->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
+				noa_enable = _TRUE;
+				break;
+			}
+		}		
+
+		if (!noa_enable && ap_num == 0)
+			rtw_hal_mcc_update_parameter(padapter, _FALSE);
+
+		threshold = pmccobjpriv->mcc_stop_threshold;
+
 		if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
 			rtw_warn_on(1);
 			RTW_INFO("PS mode is not active under mcc, force exit ps mode\n");
@@ -1353,7 +2721,7 @@ void rtw_hal_mcc_sw_status_check(PADAPTER padapter)
 			else
 				diff_cnt = cur_cnt - prev_cnt;
 
-			if (diff_cnt < 30) {
+			if (diff_cnt < threshold) {
 				pmccobjpriv->mcc_tolerance_time--;
 				RTW_INFO("%s: diff_cnt:%d, tolerance_time:%d\n",
 					__func__, diff_cnt, pmccobjpriv->mcc_tolerance_time);
@@ -1398,10 +2766,11 @@ void rtw_hal_mcc_sw_status_check(PADAPTER padapter)
  */
 u8 rtw_hal_mcc_change_scan_flag(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset)
 {
-	u8 need_ch_setting_union = _TRUE, i = 0, flags = 0, role = 0;
+	u8 need_ch_setting_union = _TRUE, i = 0, flags = 0, back_op = _FALSE;
 	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-	struct mcc_adapter_priv *pmccadapriv = NULL;
-	struct mlme_ext_priv *pmlmeext = NULL;
+	struct mcc_adapter_priv *mccadapriv = NULL;
+	struct mlme_ext_priv *mlmeext = NULL;
+	_adapter *iface = NULL;
 
 	if (!MCC_EN(padapter))
 		goto exit;
@@ -1409,41 +2778,45 @@ u8 rtw_hal_mcc_change_scan_flag(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset)
 	if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC))
 		goto exit;
 
-	for (i = 0; i < dvobj->iface_nums; i++) {
-		if (!dvobj->padapters[i])
-				continue;
-
-		pmlmeext = &dvobj->padapters[i]->mlmeextpriv;
-		pmccadapriv = &dvobj->padapters[i]->mcc_adapterpriv;
-		role = pmccadapriv->role;
+	/* disable PS_ANNC & TX_RESUME for all interface */
+	/* ToDo: TX_RESUME by interface in SCAN_BACKING_OP */
+	mlmeext = &padapter->mlmeextpriv;
+	
+	flags = mlmeext_scan_backop_flags(mlmeext);
+	if (mlmeext_chk_scan_backop_flags(mlmeext, SS_BACKOP_PS_ANNC))
+		flags &= ~SS_BACKOP_PS_ANNC;
 
-		switch (role) {
-		case MCC_ROLE_AP:
-		case MCC_ROLE_GO:
-			*ch = pmlmeext->cur_channel;
-			*bw = pmlmeext->cur_bwmode;
-			*offset = pmlmeext->cur_ch_offset;
-			need_ch_setting_union = _FALSE;
-			break;
-		case MCC_ROLE_STA:
-		case MCC_ROLE_GC:
-			break;
-		default:
-			RTW_INFO("unknown role\n");
-			rtw_warn_on(1);
-			break;
-		}
+	if (mlmeext_chk_scan_backop_flags(mlmeext, SS_BACKOP_TX_RESUME))
+		flags &= ~SS_BACKOP_TX_RESUME;
 
-		/* check other scan flag */
-		flags = mlmeext_scan_backop_flags(pmlmeext);
-		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC))
-			flags &= ~SS_BACKOP_PS_ANNC;
+	mlmeext_assign_scan_backop_flags(mlmeext, flags);
 
-		if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_TX_RESUME))
-			flags &= ~SS_BACKOP_TX_RESUME;
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (!iface)
+			continue;
 
-		mlmeext_assign_scan_backop_flags(pmlmeext, flags);
+		mlmeext = &iface->mlmeextpriv;
 
+		if (MLME_IS_GO(iface) || MLME_IS_AP(iface))
+			back_op = _TRUE;
+		else if (MLME_IS_GC(iface) && (iface != padapter))
+			/* switch to another linked interface(GO) to receive beacon to avoid no beacon disconnect */
+			back_op = _TRUE;
+		else if (MLME_IS_STA(iface) && MLME_IS_ASOC(iface) && (iface != padapter))
+			/* switch to another linked interface(STA) to receive beacon to avoid no beacon disconnect  */
+			back_op = _TRUE;
+		else {
+			/* bypass non-linked/non-linking interface/scan interface */
+			continue;
+		}
+		
+		if (back_op) {
+			*ch = mlmeext->cur_channel;
+			*bw = mlmeext->cur_bwmode;
+			*offset = mlmeext->cur_ch_offset;
+			need_ch_setting_union = _FALSE;
+		}
 	}
 exit:
 	return need_ch_setting_union;
@@ -1479,13 +2852,14 @@ inline void rtw_hal_mcc_calc_tx_bytes_to_port(PADAPTER padapter, u32 len)
 		struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
 		struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
 
-		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
 			pmccadapriv->mcc_tx_bytes_to_port += len;
 			if (0)
 				RTW_INFO("%s(order:%d): mcc tx bytes to port:%d, mcc target tx bytes to port:%d\n"
 					, __func__, pmccadapriv->order, pmccadapriv->mcc_tx_bytes_to_port
 					, pmccadapriv->mcc_target_tx_bytes_to_port);
 		}
+	}
 }
 
 /**
@@ -1512,6 +2886,45 @@ inline u8 rtw_hal_mcc_stop_tx_bytes_to_port(PADAPTER padapter)
 	return _FALSE;
 }
 
+static void rtw_hal_mcc_assign_scan_flag(PADAPTER padapter, u8 scan_done)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_adapter_priv *mccadapriv = NULL;
+	_adapter *iface = NULL;
+	struct mlme_ext_priv *pmlmeext = NULL;
+	u8 i = 0, flags;
+
+	if (!MCC_EN(padapter))
+		return;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface == NULL)
+			continue;
+
+		mccadapriv = &iface->mcc_adapterpriv;
+		if (mccadapriv->role == MCC_ROLE_MAX)
+			continue;
+
+		pmlmeext = &iface->mlmeextpriv;
+		if (is_client_associated_to_ap(iface)) {
+			flags = mlmeext_scan_backop_flags_sta(pmlmeext);
+			if (scan_done) {
+				if (mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN)) {
+					flags &= ~SS_BACKOP_EN;
+					mlmeext_assign_scan_backop_flags_sta(pmlmeext, flags);
+				}
+			} else {
+				if (!mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN)) {
+					flags |= SS_BACKOP_EN;
+					mlmeext_assign_scan_backop_flags_sta(pmlmeext, flags);
+				}
+			}
+
+		}
+	}
+}
+
 /**
  * rtw_hal_set_mcc_setting_scan_start - setting mcc under scan start
  * @padapter: the adapter to be setted
@@ -1528,8 +2941,7 @@ u8 rtw_hal_set_mcc_setting_scan_start(PADAPTER padapter)
 		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
 			if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
 				ret = rtw_hal_set_mcc_setting(padapter,  MCC_SETCMD_STATUS_STOP_SCAN_START);
-				/* issue null data to all station connected to AP before scan */
-				rtw_hal_mcc_issue_null_data(padapter, 0, 1);
+				rtw_hal_mcc_assign_scan_flag(padapter, 0);
 			}
 		}
 		_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
@@ -1552,9 +2964,10 @@ u8 rtw_hal_set_mcc_setting_scan_complete(PADAPTER padapter)
 
 		_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
 
-		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC))
-				ret = rtw_hal_set_mcc_setting(padapter,  MCC_SETCMD_STATUS_START_SCAN_DONE);
-
+		if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
+				rtw_hal_mcc_assign_scan_flag(padapter, 1);
+				ret = rtw_hal_set_mcc_setting(padapter,  MCC_SETCMD_STATUS_START_SCAN_DONE);	
+		}
 		_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
 	}
 
@@ -1651,9 +3064,9 @@ u8 rtw_hal_set_mcc_setting_join_done_chk_ch(PADAPTER padapter)
 				_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
 				ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_CONNECT);
 				_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
-			}
 		}
 	}
+	}
 
 	return ret;
 }
@@ -1676,12 +3089,15 @@ u8 rtw_hal_set_mcc_setting_chk_start_clnt_join(PADAPTER padapter, u8 *ch, u8 *bw
 		if (chbw_allow == _FALSE) {
 			struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 
+			/* issue null data to other interface connected to AP */
+			rtw_hal_mcc_issue_null_data(padapter, chbw_allow, _TRUE);
+
 			*ch = pmlmeext->cur_channel;
 			*bw = pmlmeext->cur_bwmode;
 			*offset = pmlmeext->cur_ch_offset;
 
 			RTW_INFO(FUNC_ADPT_FMT" en_mcc:%d(%d,%d,%d,)\n"
-				, FUNC_ADPT_ARG(padapter), padapter->registrypriv.en_mcc
+				, FUNC_ADPT_ARG(padapter), MCC_EN(padapter)
 				, *ch, *bw, *offset);
 			ret = _SUCCESS;
 		}
@@ -1709,34 +3125,47 @@ static void rtw_hal_mcc_dump_noa_content(void *sel, PADAPTER padapter)
 
 void rtw_hal_dump_mcc_info(void *sel, struct dvobj_priv *dvobj)
 {
-	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
-	struct mcc_adapter_priv *pmccadapriv = NULL;
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	struct mcc_adapter_priv *mccadapriv = NULL;
 	_adapter *iface = NULL, *adapter = NULL;
 	struct registry_priv *regpriv = NULL;
+	u64 tsf[MAX_MCC_NUM] = {0};
 	u8 i = 0;
 
 	/* regpriv is common for all adapter */
-	adapter = dvobj->padapters[IFACE_ID0];
+	adapter = dvobj_get_primary_adapter(dvobj);
 
 	RTW_PRINT_SEL(sel, "**********************************************\n");
+	RTW_PRINT_SEL(sel, "en_mcc:%d\n", MCC_EN(adapter));
+	RTW_PRINT_SEL(sel, "primary adapter("ADPT_FMT") duration:%d%c\n",
+		ADPT_ARG(dvobj_get_primary_adapter(dvobj)), mccobjpriv->duration, 37);
+	RTW_PRINT_SEL(sel, "runtime duration:%s\n", mccobjpriv->enable_runtime_duration ? "enable":"disable");
+
+	rtw_hal_mcc_rqt_tsf(dvobj_get_primary_adapter(dvobj), tsf);
+
 	for (i = 0; i < dvobj->iface_nums; i++) {
 		iface = dvobj->padapters[i];
 		if (!iface)
 			continue;
 
 		regpriv = &iface->registrypriv;
-		pmccadapriv = &iface->mcc_adapterpriv;
-		if (pmccadapriv) {
+		mccadapriv = &iface->mcc_adapterpriv;
+		if (mccadapriv->role == MCC_ROLE_MAX)
+			continue;
+
+		if (mccadapriv) {
+			u8 p2p_ps_mode = iface->wdinfo.p2p_ps_mode;
+
 			RTW_PRINT_SEL(sel, "adapter mcc info:\n");
 			RTW_PRINT_SEL(sel, "ifname:%s\n", ADPT_ARG(iface));
-			RTW_PRINT_SEL(sel, "order:%d\n", pmccadapriv->order);
-			RTW_PRINT_SEL(sel, "duration:%d\n", pmccadapriv->mcc_duration);
-			RTW_PRINT_SEL(sel, "target tx bytes:%d\n", pmccadapriv->mcc_target_tx_bytes_to_port);
-			RTW_PRINT_SEL(sel, "current TP:%d\n", pmccadapriv->mcc_tp);
-			RTW_PRINT_SEL(sel, "mgmt queue macid:%d\n", pmccadapriv->mgmt_queue_macid);
-			RTW_PRINT_SEL(sel, "macid bitmap:0x%02x\n\n", pmccadapriv->mcc_macid_bitmap);
+			RTW_PRINT_SEL(sel, "order:%d\n", mccadapriv->order);
+			RTW_PRINT_SEL(sel, "duration:%d\n", mccadapriv->mcc_duration);
+			RTW_PRINT_SEL(sel, "target tx bytes:%d\n", mccadapriv->mcc_target_tx_bytes_to_port);
+			RTW_PRINT_SEL(sel, "current TP:%d\n", mccadapriv->mcc_tp);
+			RTW_PRINT_SEL(sel, "mgmt queue macid:%d\n", mccadapriv->mgmt_queue_macid);
+			RTW_PRINT_SEL(sel, "macid bitmap:0x%02x\n", mccadapriv->mcc_macid_bitmap);
+			RTW_PRINT_SEL(sel, "P2P NoA:%s\n\n", p2p_ps_mode == P2P_PS_NOA ? "enable":"disable");
 			RTW_PRINT_SEL(sel, "registry data:\n");
-			RTW_PRINT_SEL(sel, "en_mcc:%d\n", regpriv->en_mcc);
 			RTW_PRINT_SEL(sel, "ap target tx TP(BW:20M):%d Mbps\n", regpriv->rtw_mcc_ap_bw20_target_tx_tp);
 			RTW_PRINT_SEL(sel, "ap target tx TP(BW:40M):%d Mbps\n", regpriv->rtw_mcc_ap_bw40_target_tx_tp);
 			RTW_PRINT_SEL(sel, "ap target tx TP(BW:80M):%d Mbps\n", regpriv->rtw_mcc_ap_bw80_target_tx_tp);
@@ -1744,13 +3173,14 @@ void rtw_hal_dump_mcc_info(void *sel, struct dvobj_priv *dvobj)
 			RTW_PRINT_SEL(sel, "sta target tx TP(BW:40M ):%d Mbps\n", regpriv->rtw_mcc_sta_bw40_target_tx_tp);
 			RTW_PRINT_SEL(sel, "sta target tx TP(BW:80M):%d Mbps\n", regpriv->rtw_mcc_sta_bw80_target_tx_tp);
 			RTW_PRINT_SEL(sel, "single tx criteria:%d Mbps\n", regpriv->rtw_mcc_single_tx_cri);
+			RTW_PRINT_SEL(sel, "HW TSF=0x%llx\n", tsf[mccadapriv->order]);
 			if (MLME_IS_GO(iface))
 				rtw_hal_mcc_dump_noa_content(sel, iface);
 			RTW_PRINT_SEL(sel, "**********************************************\n");
 		}
 	}
 	RTW_PRINT_SEL(sel, "------------------------------------------\n");
-	RTW_PRINT_SEL(sel, "policy index:%d\n", pmccobjpriv->policy_index);
+	RTW_PRINT_SEL(sel, "policy index:%d\n", mccobjpriv->policy_index);	
 	RTW_PRINT_SEL(sel, "------------------------------------------\n");
 	RTW_PRINT_SEL(sel, "define data:\n");
 	RTW_PRINT_SEL(sel, "ap target tx TP(BW:20M):%d Mbps\n", MCC_AP_BW20_TARGET_TX_TP);
@@ -1833,7 +3263,7 @@ void rtw_hal_mcc_issue_null_data(_adapter *padapter, u8 chbw_allow, u8 ps_mode)
 			if (!sta)
 				continue;
 
-			set_channel_bwmode(iface, ch, bw, offset);
+			set_channel_bwmode(iface, ch, offset, bw);
 
 			if (ps_mode)
 				rtw_hal_macid_sleep(iface, sta->cmn.mac_id);
@@ -1881,4 +3311,179 @@ void rtw_hal_dump_mcc_policy_table(void *sel)
 	}
 }
 
+void rtw_hal_mcc_update_macid_bitmap(PADAPTER padapter, int mac_id, u8 add)
+{
+	struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
+
+	if (!MCC_EN(padapter))
+		return;
+
+	if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+		return;
+
+	if (pmccadapriv->role == MCC_ROLE_GC || pmccadapriv->role == MCC_ROLE_STA)
+		return;
+
+	if (mac_id < 0) {
+		RTW_WARN("%s: mac_id < 0(%d)\n", __func__, mac_id);
+		return;
+	}
+
+	RTW_INFO(ADPT_FMT" %s macid=%d, ori mcc_macid_bitmap=0x%08x\n"
+		, ADPT_ARG(padapter), add ? "add" : "clear"
+		, mac_id, pmccadapriv->mcc_macid_bitmap);
+
+	if (add)
+		pmccadapriv->mcc_macid_bitmap |= BIT(mac_id);
+	else
+		pmccadapriv->mcc_macid_bitmap &= ~(BIT(mac_id));
+
+	rtw_hal_set_mcc_macid_cmd(padapter);
+}
+
+void rtw_hal_mcc_process_noa(PADAPTER padapter)
+{
+	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+	struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
+
+	if (!MCC_EN(padapter))
+		return;
+
+	if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
+		return;
+
+	if (!MLME_IS_GC(padapter))
+		return;
+
+	switch(pwdinfo->p2p_ps_mode) {
+	case P2P_PS_NONE:
+		RTW_INFO("[MCC] Disable NoA under MCC\n");
+		rtw_hal_mcc_update_parameter(padapter, _TRUE);
+		break;
+	case P2P_PS_NOA:
+		RTW_INFO("[MCC] Enable NoA under MCC\n");
+		break;
+	default:
+		break;
+
+	}
+}
+
+void rtw_hal_mcc_parameter_init(PADAPTER padapter)
+{
+	if (!padapter->registrypriv.en_mcc)
+		return;
+
+	if (is_primary_adapter(padapter)) {
+		SET_MCC_EN_FLAG(padapter, padapter->registrypriv.en_mcc);
+		SET_MCC_DURATION(padapter, padapter->registrypriv.rtw_mcc_duration);
+		SET_MCC_RUNTIME_DURATION(padapter, padapter->registrypriv.rtw_mcc_enable_runtime_duration);
+	}
+}
+
+
+u8 rtw_set_mcc_duration_hdl(PADAPTER adapter, u8 type, const u8 *val)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
+	_adapter *iface = NULL;
+	u8 duration = 50;
+	u8 ret = _SUCCESS, noa_enable = _FALSE, i = 0;
+
+	if (!mccobjpriv->enable_runtime_duration)
+		goto exit;
+
+#ifdef CONFIG_P2P_PS
+	/* check noa enable or not */
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
+			noa_enable = _TRUE;
+			break;
+		}
+	}
+#endif /* CONFIG_P2P_PS */
+
+
+
+	if (type == MCC_DURATION_MAPPING) {
+		switch (*val) {
+			/* 0 = fair scheduling */
+			case 0:
+				mccobjpriv->duration= 40;
+				mccobjpriv->policy_index = 2;
+				mccobjpriv->mchan_sched_mode = MCC_FAIR_SCHEDULE;
+				break;
+			/* 1 = favor STA */
+			case 1:
+				mccobjpriv->duration= 70;
+				mccobjpriv->policy_index = 1;
+				mccobjpriv->mchan_sched_mode = MCC_FAVOE_STA;
+				break;
+			/* 2 = favor P2P*/
+			case 2:
+			default:
+				mccobjpriv->duration= 30;
+				mccobjpriv->policy_index = 0;
+				mccobjpriv->mchan_sched_mode = MCC_FAVOE_P2P;
+				break;
+		}
+	} else {
+		mccobjpriv->duration = *val;
+		rtw_hal_mcc_update_policy_table(adapter);
+	}
+
+	/* only update sw parameter under MCC 
+	    it will be force update during */
+	if (noa_enable)
+		goto exit;
+
+	if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
+		rtw_hal_mcc_update_parameter(adapter, _TRUE);
+exit:
+	return ret;
+}
+
+u8 rtw_set_mcc_duration_cmd(_adapter *adapter, u8 type, u8 val)
+{
+	struct cmd_obj *cmdobj;
+	struct drvextra_cmd_parm *pdrvextra_cmd_parm;
+	struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
+	u8 *mcc_duration = NULL;
+	u8 res = _FAIL;
+
+	
+	cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
+	if (cmdobj == NULL)
+		goto exit;
+
+	pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
+	if (pdrvextra_cmd_parm == NULL) {
+		rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
+		goto exit;
+	}
+
+	mcc_duration = rtw_zmalloc(sizeof(u8));
+	if (mcc_duration == NULL) {
+		rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
+		rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
+		res = _FAIL;
+		goto exit;
+	}
+
+	pdrvextra_cmd_parm->ec_id = MCC_SET_DURATION_WK_CID;
+	pdrvextra_cmd_parm->type = type;
+	pdrvextra_cmd_parm->size = 1;
+	pdrvextra_cmd_parm->pbuf = mcc_duration;
+
+	_rtw_memcpy(mcc_duration, &val, 1);
+
+	init_h2fwcmd_w_parm_no_rsp(cmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
+	res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
+
+exit:
+	return res;
+}
+
 #endif /* CONFIG_MCC_MODE */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mp.c
index e352b69148fb..e6aa07805e7f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_mp.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -42,9 +43,18 @@
 	#ifdef CONFIG_RTL8723D
 		#include <rtl8723d_hal.h>
 	#endif
+	#ifdef CONFIG_RTL8710B
+		#include <rtl8710b_hal.h>
+	#endif
 	#ifdef CONFIG_RTL8188F
 		#include <rtl8188f_hal.h>
 	#endif
+	#ifdef CONFIG_RTL8188GTV
+		#include <rtl8188gtv_hal.h>
+	#endif
+	#ifdef CONFIG_RTL8192F
+		#include <rtl8192f_hal.h>
+	#endif
 #endif /* !RTW_HALMAC */
 
 
@@ -105,7 +115,7 @@ void hal_mpt_SwitchRfSetting(PADAPTER	pAdapter)
 s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 
 	if (!netif_running(padapter->pnetdev)) {
@@ -126,7 +136,7 @@ s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable)
 void hal_mpt_GetPowerTracking(PADAPTER padapter, u8 *enable)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 
 	*enable = pDM_Odm->rf_calibrate_info.txpowertrack_control;
@@ -145,7 +155,8 @@ void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
 	u1Byte				DataRate = 0xFF;
 
 	/* Do not modify CCK TX filter parameters for 8822B*/
-	if(IS_HARDWARE_TYPE_8822B(Adapter) || IS_HARDWARE_TYPE_8821C(Adapter) || IS_HARDWARE_TYPE_8723D(Adapter))
+	if(IS_HARDWARE_TYPE_8822B(Adapter) || IS_HARDWARE_TYPE_8821C(Adapter) ||
+		IS_HARDWARE_TYPE_8723D(Adapter) || IS_HARDWARE_TYPE_8192F(Adapter))
 		return;
 
 	DataRate = mpt_to_mgnt_rate(ulRateIdx);
@@ -183,7 +194,7 @@ void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
 					     pHalData->RegForRecover[i].value);
 			}
 		}
-	} else if (IS_HARDWARE_TYPE_8188F(Adapter)) {
+	} else if (IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8188GTV(Adapter)) {
 		/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
 		CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
 		CCKSwingIndex = 20; /* default index */
@@ -310,7 +321,7 @@ void hal_mpt_SetChannel(PADAPTER pAdapter)
 {
 	enum rf_path eRFPath;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 	struct mp_priv	*pmp = &pAdapter->mppriv;
 	u8		channel = pmp->channel;
 	u8		bandwidth = pmp->bandwidth;
@@ -319,9 +330,18 @@ void hal_mpt_SetChannel(PADAPTER pAdapter)
 
 	pHalData->bSwChnl = _TRUE;
 	pHalData->bSetChnlBW = _TRUE;
-	rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, 0, 0);
+
+#ifdef CONFIG_RTL8822B
+	if (bandwidth == 2) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
+	} else if (bandwidth == 1) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
+	} else
+#endif
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, pmp->prime_channel_offset, 0);
 
 	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
+	rtw_btcoex_wifionly_scan_notify(pAdapter);
 
 }
 
@@ -339,9 +359,19 @@ void hal_mpt_SetBandwidth(PADAPTER pAdapter)
 
 	pHalData->bSwChnl = _TRUE;
 	pHalData->bSetChnlBW = _TRUE;
-	rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, 0, 0);
+
+#ifdef CONFIG_RTL8822B
+	if (bandwidth == 2) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
+	} else if (bandwidth == 1) {
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
+	} else
+#endif
+		rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, pmp->prime_channel_offset, 0);
 
 	hal_mpt_SwitchRfSetting(pAdapter);
+	rtw_btcoex_wifionly_scan_notify(pAdapter);
+
 }
 
 void mpt_SetTxPower_Old(PADAPTER pAdapter, MPT_TXPWR_DEF Rate, u8 *pTxPower)
@@ -416,7 +446,8 @@ mpt_SetTxPower(
 
 	if (IS_HARDWARE_TYPE_8814A(pAdapter))
 		EndPath = RF_PATH_D;
-	else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter))
+	else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)
+		|| IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter))
 		EndPath = RF_PATH_A;
 
 	switch (Rate) {
@@ -501,14 +532,16 @@ void hal_mpt_SetTxPower(PADAPTER pAdapter)
 {
 	HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
-	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 
 	if (pHalData->rf_chip < RF_CHIP_MAX) {
 		if (IS_HARDWARE_TYPE_8188E(pAdapter) ||
 		    IS_HARDWARE_TYPE_8723B(pAdapter) ||
 		    IS_HARDWARE_TYPE_8192E(pAdapter) ||
 		    IS_HARDWARE_TYPE_8703B(pAdapter) ||
-		    IS_HARDWARE_TYPE_8188F(pAdapter)) {
+		    IS_HARDWARE_TYPE_8188F(pAdapter) ||
+		    IS_HARDWARE_TYPE_8188GTV(pAdapter)
+		) {
 			u8 path = (pHalData->antenna_tx_path == ANTENNA_A) ? (RF_PATH_A) : (RF_PATH_B);
 
 			RTW_INFO("===> MPT_ProSetTxPower: Old\n");
@@ -517,12 +550,14 @@ void hal_mpt_SetTxPower(PADAPTER pAdapter)
 			mpt_SetTxPower_Old(pAdapter, MPT_OFDM_AND_HT, pMptCtx->TxPwrLevel);
 
 		} else {
-			RTW_INFO("===> MPT_ProSetTxPower: Jaguar/Jaguar2\n");
+
 			mpt_SetTxPower(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
 			mpt_SetTxPower(pAdapter, MPT_OFDM, pMptCtx->TxPwrLevel);
 			mpt_SetTxPower(pAdapter, MPT_HT, pMptCtx->TxPwrLevel);
-			mpt_SetTxPower(pAdapter, MPT_VHT, pMptCtx->TxPwrLevel);
-
+			if(IS_HARDWARE_TYPE_JAGUAR(pAdapter)||IS_HARDWARE_TYPE_JAGUAR2(pAdapter)) {
+				RTW_INFO("===> MPT_ProSetTxPower: Jaguar/Jaguar2\n");
+				mpt_SetTxPower(pAdapter, MPT_VHT, pMptCtx->TxPwrLevel);
+			}
 		}
 	} else
 		RTW_INFO("RFChipID < RF_CHIP_MAX, the RF chip is not supported - %d\n", pHalData->rf_chip);
@@ -542,7 +577,7 @@ void hal_mpt_SetDataRate(PADAPTER pAdapter)
 
 	hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
 #ifdef CONFIG_RTL8723B
-	if (IS_HARDWARE_TYPE_8723B(pAdapter) || IS_HARDWARE_TYPE_8188F(pAdapter)) {
+	if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
 		if (IS_CCK_RATE(DataRate)) {
 			if (pMptCtx->mpt_rf_path == RF_PATH_A)
 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0x6);
@@ -604,7 +639,6 @@ VOID mpt_SetRFPath_8814A(PADAPTER	pAdapter)
 	R_ANTENNA_SELECT_OFDM	*p_ofdm_tx;	/* OFDM Tx register */
 	R_ANTENNA_SELECT_CCK	*p_cck_txrx;
 	u8	ForcedDataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
-	u8	HtStbcCap = pAdapter->registrypriv.stbc_cap;
 	/*/PRT_HIGH_THROUGHPUT		pHTInfo = GET_HT_INFO(pMgntInfo);*/
 	/*/PRT_VERY_HIGH_THROUGHPUT	pVHTInfo = GET_VHT_INFO(pMgntInfo);*/
 
@@ -1061,8 +1095,8 @@ void mpt_SetRFPath_8723B(PADAPTER pAdapter)
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 	u32		ulAntennaTx, ulAntennaRx;
 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
-	struct PHY_DM_STRUCT	*pDM_Odm = &pHalData->odmpriv;
-	struct odm_rf_calibration_structure	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+	struct dm_struct	*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
 
 	ulAntennaTx = pHalData->antenna_tx_path;
 	ulAntennaRx = pHalData->AntennaRxPath;
@@ -1079,12 +1113,6 @@ void mpt_SetRFPath_8723B(PADAPTER pAdapter)
 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x0);
 		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
 
-		/*/<20130522, Kordan> 0x51 and 0x71 should be set immediately after path switched, or they might be overwritten.*/
-		if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90))
-			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B10E);
-		else
-			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
-
 		for (i = 0; i < 3; ++i) {
 			u4Byte offset = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][0];
 			u4Byte data = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][1];
@@ -1112,11 +1140,6 @@ void mpt_SetRFPath_8723B(PADAPTER pAdapter)
 		pMptCtx->mpt_rf_path = RF_PATH_B;
 		phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x5);
 		phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x1); /*/ AGC Table Sel.*/
-		/* <20130522, Kordan> 0x51 and 0x71 should be set immediately after path switched, or they might be overwritten.*/
-		if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90))
-			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B10E);
-		else
-			phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
 
 		for (i = 0; i < 3; ++i) {
 			/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC  to S1 instead of S0.*/
@@ -1151,8 +1174,8 @@ void mpt_SetRFPath_8703B(PADAPTER pAdapter)
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 	u4Byte					ulAntennaTx, ulAntennaRx;
 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
-	struct PHY_DM_STRUCT		*pDM_Odm = &pHalData->odmpriv;
-	struct odm_rf_calibration_structure			*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct			*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
 
 	ulAntennaTx = pHalData->antenna_tx_path;
 	ulAntennaRx = pHalData->AntennaRxPath;
@@ -1231,8 +1254,8 @@ void mpt_SetRFPath_8723D(PADAPTER pAdapter)
 	u1Byte	p = 0, i = 0;
 	u4Byte	ulAntennaTx, ulAntennaRx, offset = 0, data = 0, val32 = 0;
 	PMPT_CONTEXT	pMptCtx = &(pAdapter->mppriv.mpt_ctx);
-	struct PHY_DM_STRUCT	*pDM_Odm = &pHalData->odmpriv;
-	struct odm_rf_calibration_structure	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
+	struct dm_struct	*pDM_Odm = &pHalData->odmpriv;
+	struct dm_rf_calibration_struct	*pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
 
 	ulAntennaTx = pHalData->antenna_tx_path;
 	ulAntennaRx = pHalData->AntennaRxPath;
@@ -1422,6 +1445,65 @@ VOID mpt_SetRFPath_819X(PADAPTER	pAdapter)
 	}
 }	/* MPT_ProSetRFPath */
 
+#ifdef CONFIG_RTL8192F
+
+void mpt_set_rfpath_8192f(PADAPTER	pAdapter)
+{
+	HAL_DATA_TYPE			*pHalData	= GET_HAL_DATA(pAdapter);
+	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+
+	u16		ForcedDataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
+	u8				NssforRate, odmNssforRate;
+	u32				ulAntennaTx, ulAntennaRx;
+	u8				RxAntToPhyDm;
+	u8				TxAntToPhyDm;
+
+	ulAntennaTx = pHalData->antenna_tx_path;
+	ulAntennaRx = pHalData->AntennaRxPath;
+	NssforRate = MgntQuery_NssTxRate(ForcedDataRate);
+
+	if (pHalData->rf_chip >= RF_TYPE_MAX)
+		RTW_INFO("This RF chip ID is not supported\n");
+
+	switch (ulAntennaTx) {
+	case ANTENNA_A:
+			pMptCtx->mpt_rf_path = RF_PATH_A;
+			TxAntToPhyDm = BB_PATH_A;
+			break;
+	case ANTENNA_B:
+			pMptCtx->mpt_rf_path = RF_PATH_B;
+			TxAntToPhyDm = BB_PATH_B;
+			break;
+	case ANTENNA_AB:
+			pMptCtx->mpt_rf_path = RF_PATH_AB;
+			TxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
+			break;
+	default:
+			pMptCtx->mpt_rf_path = RF_PATH_AB;
+			TxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
+			break;
+	}
+
+	switch (ulAntennaRx) {
+	case ANTENNA_A:
+			RxAntToPhyDm = BB_PATH_A;
+			break;
+	case ANTENNA_B:
+			RxAntToPhyDm = BB_PATH_B;
+			break;
+	case ANTENNA_AB:
+			RxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
+			break;
+	default:
+			RxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
+			break;
+	}
+
+	config_phydm_trx_mode_8192f(GET_PDM_ODM(pAdapter), TxAntToPhyDm, RxAntToPhyDm, FALSE);
+
+}
+
+#endif
 
 void hal_mpt_SetAntenna(PADAPTER	pAdapter)
 
@@ -1471,6 +1553,14 @@ void hal_mpt_SetAntenna(PADAPTER	pAdapter)
 		return;
 	}
 #endif
+
+#ifdef CONFIG_RTL8192F
+		if (IS_HARDWARE_TYPE_8192F(pAdapter)) {
+			mpt_set_rfpath_8192f(pAdapter);
+			return;
+		}
+#endif
+
 	/*	else if (IS_HARDWARE_TYPE_8821B(pAdapter))
 			mpt_SetRFPath_8821B(pAdapter);
 		Prepare for 8822B
@@ -1517,7 +1607,7 @@ void hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter)
 u8 hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter)
 
 {
-	struct PHY_DM_STRUCT *p_dm_odm = adapter_to_phydm(pAdapter);
+	struct dm_struct *p_dm_odm = adapter_to_phydm(pAdapter);
 	u32 ThermalValue = 0;
 	s32 thermal_value_temp = 0;
 	s8 thermal_offset = 0;
@@ -1603,6 +1693,7 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 {
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
 	PMPT_CONTEXT		pMptCtx = &(pAdapter->mppriv.mpt_ctx);
+	struct dm_struct		*pDM_Odm = &pHalData->odmpriv;
 	u4Byte			ulAntennaTx = pHalData->antenna_tx_path;
 	static u4Byte		regRF = 0, regBB0 = 0, regBB1 = 0, regBB2 = 0, regBB3 = 0;
 	u8 rfPath;
@@ -1637,6 +1728,18 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 			phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0xF);
 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO disabled*/
 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
+		}	else if (IS_HARDWARE_TYPE_8192F(pAdapter)) { /* USB need to do RF LO disable first, PCIE isn't required to follow this order.*/
+ #ifdef CONFIG_RTL8192F
+			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT23, 0x1);
+			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT26, 0x1);
+			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT7, 0x1);
+			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT1, 0x1);
+			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT0, 0x1);
+			phy_set_mac_reg(pAdapter, REG_AFE_CTRL_4_8192F, BIT16, 0x1);
+			phy_set_bb_reg(pAdapter, 0x88C, 0xF00000, 0xF);
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x57, BIT1, 0x1); /* RF LO disabled*/
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2); /* Tx mode*/
+#endif
 		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
@@ -1651,7 +1754,7 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /* Tx mode */
 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x1); /* RF LO enabled */
 			}
-		} else if (IS_HARDWARE_TYPE_8188F(pAdapter)) {
+		} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
 			/*Set BB REG 88C: Prevent SingleTone Fail*/
 			phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xF);
 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1);
@@ -1667,8 +1770,8 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x0);
 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x1);
 			}
-		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter)) {
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B)
+		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
 			u1Byte p = RF_PATH_A;
 
 			regRF = phy_query_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, bRFRegOffsetMask);
@@ -1688,26 +1791,49 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 			} else {
 				phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
 				phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
-				phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
+#ifdef CONFIG_RTL8821C
+				if (IS_HARDWARE_TYPE_8821C(pAdapter) && pDM_Odm->current_rf_set_8821c == SWITCH_TO_BTG)
+					phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x75, BIT16, 0x1); /* RF LO (for BTG) enabled */
+				else
+#endif
+					phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
 			}
-
-			phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
-			phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
-
-			if (pHalData->external_pa_5g) {
-				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xCB4[23:16] = 0x12*/
-				phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xEB4[23:16] = 0x12*/
-			} else if (pHalData->ExternalPA_2G) {
-				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xCB4[23:16] = 0x11*/
-				phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xEB4[23:16] = 0x11*/
+			if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777);  /* 0xCB0=0x77777777*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777);  /* 0xEB0=0x77777777*/
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777);  /* 0xCB4[15:0] = 0x7777*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777);  /* 0xEB4[15:0] = 0x7777*/
+					phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xFFF, 0xb); /* 0xCBC[23:16] = 0x12*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xFFF, 0x830); /* 0xEBC[23:16] = 0x12*/
+			} else if (IS_HARDWARE_TYPE_8821C(pAdapter)) {
+				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xF0F0, 0x707);  /* 0xCB0[[15:12, 7:4] = 0x707*/
+
+				if (pHalData->external_pa_5g)
+				{
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
+				}
+				else if (pHalData->ExternalPA_2G)
+				{
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
+				}
+			} else {
+				phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
+				phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007);  /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
+
+				if (pHalData->external_pa_5g) {
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xCB4[23:16] = 0x12*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xEB4[23:16] = 0x12*/
+				} else if (pHalData->ExternalPA_2G) {
+					phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xCB4[23:16] = 0x11*/
+					phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xEB4[23:16] = 0x11*/
+				}
 			}
 #endif
 		}
-#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8821C)
-				else if (IS_HARDWARE_TYPE_8814A(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter))
+#if defined(CONFIG_RTL8814A)
+				else if (IS_HARDWARE_TYPE_8814A(pAdapter))
 						mpt_SetSingleTone_8814A(pAdapter, TRUE, FALSE);
 #endif
-
 		else	/*/ Turn On SingleTone and turn off the other test modes.*/
 			phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_SingleTone);
 
@@ -1725,6 +1851,18 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0);/*/ RF LO disabled */
 			/*/ RESTORE MAC REG 88C: Enable RF Functions*/
 			phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0x0);
+		} else if (IS_HARDWARE_TYPE_8192F(pAdapter)){
+#ifdef CONFIG_RTL8192F
+			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT23, 0x0);
+			phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT26, 0x0);
+			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT7, 0x0);
+			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT1, 0x0);
+			phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT0, 0x0);
+			phy_set_mac_reg(pAdapter, REG_AFE_CTRL_4_8192F, BIT16, 0x0);
+			phy_set_bb_reg(pAdapter, 0x88C, 0xF00000, 0x0);
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x57, BIT1, 0x0); /* RF LO disabled*/
+			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3); /* Rx mode*/
+#endif
 		} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
 			if (pMptCtx->mpt_rf_path == RF_PATH_A) {
 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
@@ -1739,7 +1877,7 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /* Rx mode */
 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x0); /* RF LO disabled */
 			}
-		} else if (IS_HARDWARE_TYPE_8188F(pAdapter)) {
+		} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3); /*Tx mode*/
 			phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0); /*RF LO disabled*/
 			/*Set BB REG 88C: Prevent SingleTone Fail*/
@@ -1754,8 +1892,8 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 				phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x1);
 				phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x0);
 			}
-		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter)) {
-#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B)
+		} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
+#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
 			u1Byte p = RF_PATH_A;
 
 			phy_set_bb_reg(pAdapter, rOFDMCCKEN_Jaguar, BIT29 | BIT28, 0x3); /*/ Disable CCK and OFDM*/
@@ -1766,7 +1904,12 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 					phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
 				}
 			} else {
+				p = pMptCtx->mpt_rf_path;
 				phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
+
+				if (IS_HARDWARE_TYPE_8821C(pAdapter))
+					phy_set_rf_reg(pAdapter, p, 0x75, BIT16, 0x0); /* RF LO (for BTG) disabled */
+
 				phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
 			}
 
@@ -1774,10 +1917,16 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
 			phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, regBB1);
 			phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB2);
 			phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB3);
+
+			if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
+				RTW_INFO("Restore RFE control Pin cbc\n");
+				phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xfff, 0x0);
+				phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xfff, 0x0);
+			}
 #endif
 		}
-#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
-		else if (IS_HARDWARE_TYPE_8814A(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter))
+#if defined(CONFIG_RTL8814A)
+		else if (IS_HARDWARE_TYPE_8814A(pAdapter))
 			mpt_SetSingleTone_8814A(pAdapter, FALSE, FALSE);
 
 		else/*/ Turn off all test modes.*/
@@ -2006,12 +2155,10 @@ static	VOID mpt_StartOfdmContTx(
 void mpt_ProSetPMacTx(PADAPTER	Adapter)
 {
 	PMPT_CONTEXT	pMptCtx		=	&(Adapter->mppriv.mpt_ctx);
+	struct mp_priv *pmppriv = &Adapter->mppriv;
 	RT_PMAC_TX_INFO	PMacTxInfo	=	pMptCtx->PMacTxInfo;
 	u32			u4bTmp;
 
-	dbg_print("SGI %d bSPreamble %d bSTBC %d bLDPC %d NDP_sound %d\n", PMacTxInfo.bSGI, PMacTxInfo.bSPreamble, PMacTxInfo.bSTBC, PMacTxInfo.bLDPC, PMacTxInfo.NDP_sound);
-	dbg_print("TXSC %d BandWidth %d PacketPeriod %d PacketCount %d PacketLength %d PacketPattern %d\n", PMacTxInfo.TX_SC, PMacTxInfo.BandWidth, PMacTxInfo.PacketPeriod, PMacTxInfo.PacketCount,
-		 PMacTxInfo.PacketLength, PMacTxInfo.PacketPattern);
 #if 0
 	PRINT_DATA("LSIG ", PMacTxInfo.LSIG, 3);
 	PRINT_DATA("HT_SIG", PMacTxInfo.HT_SIG, 6);
@@ -2020,46 +2167,61 @@ void mpt_ProSetPMacTx(PADAPTER	Adapter)
 	dbg_print("VHT_SIG_B_CRC %x\n", PMacTxInfo.VHT_SIG_B_CRC);
 	PRINT_DATA("VHT_Delimiter", PMacTxInfo.VHT_Delimiter, 4);
 
-	PRINT_DATA("Src Address", Adapter->mac_addr, 6);
-	PRINT_DATA("Dest Address", PMacTxInfo.MacAddress, 6);
+	PRINT_DATA("Src Address", Adapter->mac_addr, ETH_ALEN);
+	PRINT_DATA("Dest Address", PMacTxInfo.MacAddress, ETH_ALEN);
 #endif
+	if (pmppriv->pktInterval != 0)
+		PMacTxInfo.PacketPeriod = pmppriv->pktInterval;
+
+    	if (pmppriv->tx.count != 0)
+        	PMacTxInfo.PacketCount = pmppriv->tx.count;
+
+	RTW_INFO("SGI %d bSPreamble %d bSTBC %d bLDPC %d NDP_sound %d\n", PMacTxInfo.bSGI, PMacTxInfo.bSPreamble, PMacTxInfo.bSTBC, PMacTxInfo.bLDPC, PMacTxInfo.NDP_sound);
+	RTW_INFO("TXSC %d BandWidth %d PacketPeriod %d PacketCount %d PacketLength %d PacketPattern %d\n", PMacTxInfo.TX_SC, PMacTxInfo.BandWidth, PMacTxInfo.PacketPeriod, PMacTxInfo.PacketCount,
+		 PMacTxInfo.PacketLength, PMacTxInfo.PacketPattern);
 
 	if (PMacTxInfo.bEnPMacTx == FALSE) {
-		if (PMacTxInfo.Mode == CONTINUOUS_TX) {
+		if (pMptCtx->HWTxmode == CONTINUOUS_TX) {
 			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);			/*	TX Stop*/
-			if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
+			if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index))
 				mpt_StopCckContTx(Adapter);
 			else
 				mpt_StopOfdmContTx(Adapter);
-		} else if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
+		} else if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index)) {
 			u4bTmp = phy_query_bb_reg(Adapter, 0xf50, bMaskLWord);
 			phy_set_bb_reg(Adapter, 0xb1c, bMaskLWord, u4bTmp + 50);
 			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);		/*TX Stop*/
 		} else
 			phy_set_bb_reg(Adapter, 0xb04, 0xf, 2);		/*	TX Stop*/
 
-		if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
+		if (pMptCtx->HWTxmode == OFDM_Single_Tone_TX) {
 			/* Stop HW TX -> Stop Continuous TX -> Stop RF Setting*/
-			if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
+			if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index))
 				mpt_StopCckContTx(Adapter);
 			else
 				mpt_StopOfdmContTx(Adapter);
 
 			mpt_SetSingleTone_8814A(Adapter, FALSE, TRUE);
 		}
-
+		pMptCtx->HWTxmode = TEST_NONE;
 		return;
 	}
 
+    	pMptCtx->mpt_rate_index = PMacTxInfo.TX_RATE;
+
 	if (PMacTxInfo.Mode == CONTINUOUS_TX) {
+		pMptCtx->HWTxmode = CONTINUOUS_TX;
 		PMacTxInfo.PacketCount = 1;
 
+        	hal_mpt_SetTxPower(Adapter);
+
 		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
 			mpt_StartCckContTx(Adapter);
 		else
 			mpt_StartOfdmContTx(Adapter);
 	} else if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
 		/* Continuous TX -> HW TX -> RF Setting */
+		pMptCtx->HWTxmode = OFDM_Single_Tone_TX;
 		PMacTxInfo.PacketCount = 1;
 
 		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
@@ -2067,6 +2229,7 @@ void mpt_ProSetPMacTx(PADAPTER	Adapter)
 		else
 			mpt_StartOfdmContTx(Adapter);
 	} else if (PMacTxInfo.Mode == PACKETS_TX) {
+		pMptCtx->HWTxmode = PACKETS_TX;
 		if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE) && PMacTxInfo.PacketCount == 0)
 			PMacTxInfo.PacketCount = 0xffff;
 	}
@@ -2173,7 +2336,7 @@ void mpt_ProSetPMacTx(PADAPTER	Adapter)
 	u4bTmp = (PMacTxInfo.TX_SC) | ((PMacTxInfo.BandWidth) << 4) | ((PMacTxInfo.m_STBC - 1) << 6) | ((PMacTxInfo.NDP_sound) << 8);
 	phy_set_bb_reg(Adapter, 0xb4c, 0x1ff, u4bTmp);
 
-	if (IS_HARDWARE_TYPE_8814A(Adapter) || IS_HARDWARE_TYPE_8822B(Adapter)) {
+	if (IS_HARDWARE_TYPE_JAGUAR2(Adapter)) {
 		u4Byte offset = 0xb44;
 
 		if (IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
@@ -2182,6 +2345,16 @@ void mpt_ProSetPMacTx(PADAPTER	Adapter)
 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 1);
 		else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
 			phy_set_bb_reg(Adapter, offset, 0xc0000000, 2);
+
+	} else if(IS_HARDWARE_TYPE_JAGUAR(Adapter)) {
+		u4Byte offset = 0xb4c;
+
+		if(IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
+			phy_set_bb_reg(Adapter, offset, 0xc0000000, 0);
+		else if(IS_MPT_HT_RATE(PMacTxInfo.TX_RATE))
+			phy_set_bb_reg(Adapter, offset, 0xc0000000, 1);
+		else if(IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
+			phy_set_bb_reg(Adapter, offset, 0xc0000000, 2);
 	}
 
 	phy_set_bb_reg(Adapter, 0xb00, BIT8, 1);		/*	Turn on PMAC*/
@@ -2203,8 +2376,7 @@ void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart)
 {
 	u8 Rate;
 
-	RT_TRACE(_module_mp_, _drv_info_,
-		 ("SetContinuousTx: rate:%d\n", pAdapter->mppriv.rateidx));
+	RTW_INFO("SetContinuousTx: rate:%d\n", pAdapter->mppriv.rateidx);
 	Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
 	pAdapter->mppriv.mpt_ctx.is_start_cont_tx = bStart;
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_phy.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_phy.c
index 84c571265f74..59b3673f6f26 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_phy.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/hal_phy.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -16,12 +17,6 @@
 
 #include <drv_types.h>
 
-/* ********************************************************************************
- *	Constant.
- * ********************************************************************************
- * 2008/11/20 MH For Debug only, RF */
-static RF_SHADOW_T RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
-
 /**
 * Function:	PHY_CalculateBitShift
 *
@@ -49,6 +44,13 @@ PHY_CalculateBitShift(
 }
 
 
+#ifdef CONFIG_RF_SHADOW_RW
+/* ********************************************************************************
+ *	Constant.
+ * ********************************************************************************
+ * 2008/11/20 MH For Debug only, RF */
+static RF_SHADOW_T RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
+
 /*
  * ==> RF shadow Operation API Code Section!!!
  *
@@ -253,3 +255,4 @@ PHY_RFShadowRefresh(
 	}
 
 }	/* PHY_RFShadowRead */
+#endif /*CONFIG_RF_SHADOW_RW*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/led/hal_led.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/led/hal_led.c
new file mode 100644
index 000000000000..7a68107c67f8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/led/hal_led.c
@@ -0,0 +1,255 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 <hal_data.h>
+
+#ifdef CONFIG_RTW_LED
+void dump_led_config(void *sel, _adapter *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+	int i;
+
+	RTW_PRINT_SEL(sel, "strategy:%u\n", ledpriv->LedStrategy);
+#ifdef CONFIG_RTW_SW_LED
+	RTW_PRINT_SEL(sel, "bRegUseLed:%u\n", ledpriv->bRegUseLed);
+	RTW_PRINT_SEL(sel, "iface_en_mask:0x%02X\n", ledpriv->iface_en_mask);
+	for (i = 0; i < dvobj->iface_nums; i++)
+		RTW_PRINT_SEL(sel, "ctl_en_mask[%d]:0x%08X\n", i, ledpriv->ctl_en_mask[i]);
+#endif
+}
+
+void rtw_led_set_strategy(_adapter *adapter, u8 strategy)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+	_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
+
+#ifndef CONFIG_RTW_SW_LED
+	if (IS_SW_LED_STRATEGY(strategy)) {
+		RTW_WARN("CONFIG_RTW_SW_LED is not defined\n");
+		return;
+	}
+#endif
+
+#ifdef CONFIG_RTW_SW_LED
+	if (!ledpriv->bRegUseLed)
+		return;
+#endif
+
+	if (ledpriv->LedStrategy == strategy)
+		return;
+
+	if (IS_HW_LED_STRATEGY(strategy) || IS_HW_LED_STRATEGY(ledpriv->LedStrategy)) {
+		RTW_WARN("switching on/off HW_LED strategy is not supported\n");
+		return;
+	}
+
+	ledpriv->LedStrategy = strategy;
+
+#ifdef CONFIG_RTW_SW_LED
+	rtw_hal_sw_led_deinit(pri_adapter);
+#endif
+
+	rtw_led_control(pri_adapter, RTW_LED_OFF);
+}
+
+#ifdef CONFIG_RTW_SW_LED
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+void rtw_sw_led_blink_uc_trx_only(LED_DATA *led)
+{
+	_adapter *adapter = led->padapter;
+	BOOLEAN bStopBlinking = _FALSE;
+
+	if (led->BlinkingLedState == RTW_LED_ON)
+		SwLedOn(adapter, led);
+	else
+		SwLedOff(adapter, led);
+
+	switch (led->CurrLedState) {
+	case RTW_LED_ON:
+		SwLedOn(adapter, led);
+		break;
+
+	case RTW_LED_OFF:
+		SwLedOff(adapter, led);
+		break;
+
+	case LED_BLINK_TXRX:
+		led->BlinkTimes--;
+		if (led->BlinkTimes == 0)
+			bStopBlinking = _TRUE;
+
+		if (adapter_to_pwrctl(adapter)->rf_pwrstate != rf_on
+			&& adapter_to_pwrctl(adapter)->rfoff_reason > RF_CHANGE_BY_PS
+		) {
+			SwLedOff(adapter, led);
+			led->bLedBlinkInProgress = _FALSE;
+		} else {
+			if (led->bLedOn)
+				led->BlinkingLedState = RTW_LED_OFF;
+			else
+				led->BlinkingLedState = RTW_LED_ON;
+			
+			if (bStopBlinking) {
+				led->CurrLedState = RTW_LED_OFF;
+				led->bLedBlinkInProgress = _FALSE;
+			}
+			_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	default:
+		break;
+	}
+}
+
+void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl)
+{
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+	LED_DATA *led = &(ledpriv->SwLed0);
+	LED_DATA *led1 = &(ledpriv->SwLed1);
+	LED_DATA *led2 = &(ledpriv->SwLed2);
+
+	switch (ctl) {
+	case LED_CTL_UC_TX:
+	case LED_CTL_UC_RX:
+		if (led->bLedBlinkInProgress == _FALSE) {
+			led->bLedBlinkInProgress = _TRUE;
+			led->CurrLedState = LED_BLINK_TXRX;
+			led->BlinkTimes = 2;
+			if (led->bLedOn)
+				led->BlinkingLedState = RTW_LED_OFF;
+			else
+				led->BlinkingLedState = RTW_LED_ON;
+			_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
+		}
+		break;
+
+	case LED_CTL_POWER_OFF:
+		led->CurrLedState = RTW_LED_OFF;
+		led->BlinkingLedState = RTW_LED_OFF;
+
+		if (led->bLedBlinkInProgress) {
+			_cancel_timer_ex(&(led->BlinkTimer));
+			led->bLedBlinkInProgress = _FALSE;
+		}
+
+		SwLedOff(adapter, led);
+		SwLedOff(adapter, led1);
+		SwLedOff(adapter, led2);
+		break;
+
+	default:
+		break;
+	}
+}
+#endif /* CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY */
+
+void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl)
+{
+	struct led_priv	*ledpriv = adapter_to_led(adapter);
+
+	if (ledpriv->LedControlHandler) {
+		#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+		if (ledpriv->LedStrategy != SW_LED_MODE_UC_TRX_ONLY) {
+			if (ctl == LED_CTL_UC_TX || ctl == LED_CTL_BMC_TX) {
+				if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_TX))
+					ctl = LED_CTL_TX; /* transform specific TX ctl to general TX ctl */
+			} else if (ctl == LED_CTL_UC_RX || ctl == LED_CTL_BMC_RX) {
+				if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_RX))
+					ctl = LED_CTL_RX; /* transform specific RX ctl to general RX ctl */
+			}
+		}
+		#endif
+
+		if ((ledpriv->iface_en_mask & BIT(adapter->iface_id))
+			&& (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(ctl)))
+			ledpriv->LedControlHandler(adapter, ctl);
+	}
+}
+
+void rtw_led_tx_control(_adapter *adapter, const u8 *da)
+{
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (IS_MCAST(da))
+		rtw_led_control(adapter, LED_CTL_BMC_TX);
+	else
+		rtw_led_control(adapter, LED_CTL_UC_TX);
+#else
+	rtw_led_control(adapter, LED_CTL_TX);
+#endif
+}
+
+void rtw_led_rx_control(_adapter *adapter, const u8 *da)
+{
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (IS_MCAST(da))
+		rtw_led_control(adapter, LED_CTL_BMC_RX);
+	else
+		rtw_led_control(adapter, LED_CTL_UC_RX);
+#else
+	rtw_led_control(adapter, LED_CTL_RX);
+#endif
+}
+
+void rtw_led_set_iface_en(_adapter *adapter, u8 en)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+	if (en)
+		ledpriv->iface_en_mask |= BIT(adapter->iface_id);
+	else
+		ledpriv->iface_en_mask &= ~BIT(adapter->iface_id);
+}
+
+void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+
+	ledpriv->iface_en_mask = mask;
+}
+
+void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask)
+{
+	struct led_priv *ledpriv = adapter_to_led(adapter);
+	
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	if (ctl_mask & BIT(LED_CTL_TX))
+		ctl_mask |= BIT(LED_CTL_UC_TX) | BIT(LED_CTL_BMC_TX);
+	if (ctl_mask & BIT(LED_CTL_RX))
+		ctl_mask |= BIT(LED_CTL_UC_RX) | BIT(LED_CTL_BMC_RX);
+#endif
+
+	ledpriv->ctl_en_mask[adapter->iface_id] = ctl_mask;
+}
+
+void rtw_led_set_ctl_en_mask_primary(_adapter *adapter)
+{
+	rtw_led_set_ctl_en_mask(adapter, 0xFFFFFFFF);
+}
+
+void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter)
+{
+	rtw_led_set_ctl_en_mask(adapter
+		, BIT(LED_CTL_POWER_ON) | BIT(LED_CTL_POWER_OFF)
+		| BIT(LED_CTL_TX) | BIT(LED_CTL_RX)
+	);
+}
+#endif /* CONFIG_RTW_SW_LED */
+
+#endif /* CONFIG_RTW_LED */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/led/hal_sdio_led.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/led/hal_sdio_led.c
index ffe004d96761..d60325f5a284 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/led/hal_sdio_led.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/led/hal_sdio_led.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -119,7 +120,7 @@ SwLedBlink1(
 {
 	_adapter				*padapter = pLed->padapter;
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);
-	struct led_priv		*ledpriv = &(padapter->ledpriv);
+	struct led_priv		*ledpriv = adapter_to_led(padapter);
 	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
 	PLED_SDIO			pLed1 = &(ledpriv->SwLed1);
 	u8					bStopBlinking = _FALSE;
@@ -503,7 +504,7 @@ SwLedBlink4(
 )
 {
 	_adapter			*padapter = pLed->padapter;
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	PLED_SDIO		pLed1 = &(ledpriv->SwLed1);
 	u8				bStopBlinking = _FALSE;
@@ -767,7 +768,7 @@ SwLedBlink6(
 void BlinkHandler(PLED_SDIO	pLed)
 {
 	_adapter		*padapter = pLed->padapter;
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 
 	/* RTW_INFO("%s (%s:%d)\n",__FUNCTION__, current->comm, current->pid); */
 	if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
@@ -780,6 +781,12 @@ void BlinkHandler(PLED_SDIO	pLed)
 	}
 
 	switch (ledpriv->LedStrategy) {
+	#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	case SW_LED_MODE_UC_TRX_ONLY:
+		rtw_sw_led_blink_uc_trx_only(pLed);
+		break;
+	#endif
+
 	case SW_LED_MODE0:
 		SwLedBlink(pLed);
 		break;
@@ -858,7 +865,7 @@ SwLedControlMode0(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 	PLED_SDIO	pLed = &(ledpriv->SwLed1);
 
 	/* Decide led state */
@@ -960,7 +967,7 @@ SwLedControlMode1(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv		*ledpriv = &(padapter->ledpriv);
+	struct led_priv		*ledpriv = adapter_to_led(padapter);
 	PLED_SDIO			pLed = &(ledpriv->SwLed0);
 	struct mlme_priv		*pmlmepriv = &(padapter->mlmepriv);
 	PHAL_DATA_TYPE		pHalData = GET_HAL_DATA(padapter);
@@ -1189,7 +1196,7 @@ SwLedControlMode2(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	PLED_SDIO		pLed = &(ledpriv->SwLed0);
 
@@ -1328,7 +1335,7 @@ SwLedControlMode3(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	PLED_SDIO		pLed = &(ledpriv->SwLed0);
 
@@ -1483,7 +1490,7 @@ SwLedControlMode4(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	PLED_SDIO		pLed = &(ledpriv->SwLed0);
 	PLED_SDIO		pLed1 = &(ledpriv->SwLed1);
@@ -1773,7 +1780,7 @@ SwLedControlMode5(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(padapter);
 	PLED_SDIO		pLed = &(ledpriv->SwLed0);
@@ -1852,7 +1859,7 @@ SwLedControlMode6(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	PLED_SDIO pLed0 = &(ledpriv->SwLed0);
 
@@ -1882,7 +1889,7 @@ LedControlSDIO(
 	LED_CTL_MODE		LedAction
 )
 {
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 
 #if (MP_DRIVER == 1)
 	if (padapter->registrypriv.mp_mode == 1)
@@ -1903,12 +1910,6 @@ LedControlSDIO(
 	/* if(priv->bInHctTest) */
 	/*	return; */
 
-#ifdef CONFIG_CONCURRENT_MODE
-	/* Only do led action for PRIMARY_ADAPTER */
-	if (padapter->adapter_type != PRIMARY_ADAPTER)
-		return;
-#endif
-
 	if ((adapter_to_pwrctl(padapter)->rf_pwrstate != rf_on &&
 	     adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) &&
 	    (LedAction == LED_CTL_TX || LedAction == LED_CTL_RX ||
@@ -1919,6 +1920,12 @@ LedControlSDIO(
 		return;
 
 	switch (ledpriv->LedStrategy) {
+	#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+	case SW_LED_MODE_UC_TRX_ONLY:
+		rtw_sw_led_ctl_mode_uc_trx_only(padapter, LedAction);
+		break;
+	#endif
+
 	case SW_LED_MODE0:
 		SwLedControlMode0(padapter, LedAction);
 		break;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/ap_makefile.mk b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/ap_makefile.mk
index 9f8fa2504172..ebad94a978f9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/ap_makefile.mk
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/ap_makefile.mk
@@ -1,120 +1,189 @@
 # SPDX-License-Identifier: GPL-2.0
-
-_PHYDM_FILES :=\
-	phydm/phydm.o \
-	phydm/phydm_dig.o\
-	phydm/phydm_antdiv.o\
-	phydm/phydm_soml.o\
-	phydm/phydm_smt_ant.o\
-	phydm/phydm_pathdiv.o\
-	phydm/phydm_rainfo.o\
-	phydm/phydm_dynamictxpower.o\
-	phydm/phydm_adaptivity.o\
-	phydm/phydm_debug.o\
-	phydm/phydm_interface.o\
-	phydm/phydm_phystatus.o\
-	phydm/phydm_hwconfig.o\
-	phydm/phydm_dfs.o\
-	phydm/phydm_cfotracking.o\
-	phydm/phydm_acs.o\
-	phydm/phydm_adc_sampling.o\
-	phydm/phydm_ccx.o\
-	phydm/phydm_primary_cca.o\
-	phydm/phydm_cck_pd.o\
-	phydm/phydm_rssi_monitor.o\
-	phydm/phydm_auto_dbg.o\
-	phydm/phydm_math_lib.o\
-	phydm/phydm_noisemonitor.o\
-	phydm/phydm_api.o\
-	phydm/phydm_pow_train.o\
-	phydm/txbf/phydm_hal_txbf_api.o\
-	EdcaTurboCheck.o\
-	phydm/halrf/halrf.o\
-	phydm/halrf/halphyrf_ap.o\
-	phydm/halrf/halrf_powertracking_ap.o\
-	phydm/halrf/halrf_powertracking.o\
-	phydm/halrf/halrf_kfree.o
-
-ifeq ($(CONFIG_RTL_88E_SUPPORT),y)
-	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
-		_PHYDM_FILES += \
-		phydm/rtl8188e/halhwimg8188e_bb.o\
-		phydm/rtl8188e/halhwimg8188e_mac.o\
-		phydm/rtl8188e/halhwimg8188e_rf.o\
-		phydm/rtl8188e/phydm_regconfig8188e.o\
-		phydm/rtl8188e/hal8188erateadaptive.o\
-		phydm/rtl8188e/phydm_rtl8188e.o\
-		phydm/halrf/rtl8188e/halrf_8188e_ap.o
-	endif
-endif
-	
-ifeq ($(CONFIG_RTL_8812_SUPPORT),y)
-	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
-		_PHYDM_FILES += ./phydm/halrf/rtl8812a/halrf_8812a_ap.o
-	endif
-endif
-	
-ifeq ($(CONFIG_WLAN_HAL_8881A),y)
-	_PHYDM_FILES += phydm/halrf/rtl8821a/halrf_iqk_8821a_ap.o
-endif
-
-ifeq ($(CONFIG_WLAN_HAL_8192EE),y)
-	_PHYDM_FILES += \
-	phydm/halrf/rtl8192e/halrf_8192e_ap.o\
-	phydm/rtl8192e/phydm_rtl8192e.o
-endif
-
-ifeq ($(CONFIG_WLAN_HAL_8814AE),y)
-	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_8814a_ap.o
-	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_iqk_8814a.o
-	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
-		rtl8192cd-objs += \
-		phydm/rtl8814a/halhwimg8814a_bb.o\
-		phydm/rtl8814a/halhwimg8814a_mac.o\
-		phydm/rtl8814a/halhwimg8814a_rf.o\
-		phydm/rtl8814a/phydm_regconfig8814a.o\
-		phydm/rtl8814a/phydm_rtl8814a.o			
-	endif
-endif
-	
-ifeq ($(CONFIG_WLAN_HAL_8822BE),y)
-	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_8822b.o
-	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_iqk_8822b.o
-	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
-		_PHYDM_FILES += \
-		phydm/rtl8822b/halhwimg8822b_bb.o\
-		phydm/rtl8822b/halhwimg8822b_mac.o\
-		phydm/rtl8822b/halhwimg8822b_rf.o\
-		phydm/rtl8822b/phydm_regconfig8822b.o\
-		phydm/rtl8822b/phydm_hal_api8822b.o\
-		phydm/rtl8822b/phydm_rtl8822b.o
-	endif
-endif
-
-ifeq ($(CONFIG_WLAN_HAL_8821CE),y)
-	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_8821c.o
-	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_iqk_8821c.o
-	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
-		_PHYDM_FILES += \
-		phydm/rtl8821c/halhwimg8821c_bb.o\
-		phydm/rtl8821c/halhwimg8821c_mac.o\
-		phydm/rtl8821c/halhwimg8821c_rf.o\
-		phydm/rtl8821c/phydm_regconfig8821c.o\
-		phydm/rtl8821c/phydm_hal_api8821c.o
-	endif
-endif
-	
-ifeq ($(CONFIG_WLAN_HAL_8197F),y)
-		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_8197f.o
-		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_iqk_8197f.o
-		_PHYDM_FILES += efuse_97f/efuse.o
-	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
-		_PHYDM_FILES += \
-		phydm/rtl8197f/halhwimg8197f_bb.o\
-		phydm/rtl8197f/halhwimg8197f_mac.o\
-		phydm/rtl8197f/halhwimg8197f_rf.o\
-		phydm/rtl8197f/phydm_hal_api8197f.o\
-		phydm/rtl8197f/phydm_regconfig8197f.o\
-		phydm/rtl8197f/phydm_rtl8197f.o
-	endif
-endif
+
+_PHYDM_FILES :=\
+	phydm/phydm.o \
+	phydm/phydm_dig.o\
+	phydm/phydm_antdiv.o\
+	phydm/phydm_soml.o\
+	phydm/phydm_smt_ant.o\
+	phydm/phydm_pathdiv.o\
+	phydm/phydm_rainfo.o\
+	phydm/phydm_dynamictxpower.o\
+	phydm/phydm_adaptivity.o\
+	phydm/phydm_debug.o\
+	phydm/phydm_interface.o\
+	phydm/phydm_phystatus.o\
+	phydm/phydm_hwconfig.o\
+	phydm/phydm_dfs.o\
+	phydm/phydm_cfotracking.o\
+	phydm/phydm_adc_sampling.o\
+	phydm/phydm_ccx.o\
+	phydm/phydm_primary_cca.o\
+	phydm/phydm_cck_pd.o\
+	phydm/phydm_rssi_monitor.o\
+	phydm/phydm_auto_dbg.o\
+	phydm/phydm_math_lib.o\
+	phydm/phydm_noisemonitor.o\
+	phydm/phydm_api.o\
+	phydm/phydm_pow_train.o\
+	phydm/phydm_lna_sat.o\
+	phydm/phydm_pmac_tx_setting.o\
+	phydm/phydm_mp.o\
+	phydm/txbf/phydm_hal_txbf_api.o\
+	EdcaTurboCheck.o\
+	phydm/halrf/halrf.o\
+	phydm/halrf/halrf_debug.o\
+	phydm/halrf/halphyrf_ap.o\
+	phydm/halrf/halrf_powertracking_ap.o\
+	phydm/halrf/halrf_powertracking.o\
+	phydm/halrf/halrf_kfree.o
+
+ifeq ($(CONFIG_RTL_88E_SUPPORT),y)
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8188e/halhwimg8188e_bb.o\
+		phydm/rtl8188e/halhwimg8188e_mac.o\
+		phydm/rtl8188e/halhwimg8188e_rf.o\
+		phydm/rtl8188e/phydm_regconfig8188e.o\
+		phydm/rtl8188e/hal8188erateadaptive.o\
+		phydm/rtl8188e/phydm_rtl8188e.o\
+		phydm/halrf/rtl8188e/halrf_8188e_ap.o
+	endif
+endif
+
+ifeq ($(CONFIG_RTL_8812_SUPPORT),y)
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += ./phydm/halrf/rtl8812a/halrf_8812a_ap.o
+	endif
+	_PHYDM_FILES += phydm/rtl8812a/phydm_rtl8812a.o
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8881A),y)
+	_PHYDM_FILES += phydm/halrf/rtl8821a/halrf_iqk_8821a_ap.o
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8192EE),y)
+	_PHYDM_FILES += \
+	phydm/halrf/rtl8192e/halrf_8192e_ap.o\
+	phydm/rtl8192e/phydm_rtl8192e.o
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8814AE),y)
+	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_8814a_ap.o
+	rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_iqk_8814a.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		rtl8192cd-objs += \
+		phydm/rtl8814a/halhwimg8814a_bb.o\
+		phydm/rtl8814a/halhwimg8814a_mac.o\
+		phydm/rtl8814a/halhwimg8814a_rf.o\
+		phydm/rtl8814a/phydm_regconfig8814a.o\
+		phydm/rtl8814a/phydm_rtl8814a.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8822BE),y)
+	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_8822b.o
+	_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_iqk_8822b.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8822b/halhwimg8822b_bb.o\
+		phydm/rtl8822b/halhwimg8822b_mac.o\
+		phydm/rtl8822b/halhwimg8822b_rf.o\
+		phydm/rtl8822b/phydm_regconfig8822b.o\
+		phydm/rtl8822b/phydm_hal_api8822b.o\
+		phydm/rtl8822b/phydm_rtl8822b.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8822CE),y)
+	_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_8822c.o
+	_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_iqk_8822c.o
+	_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_dpk_8822c.o
+	_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_rfk_init_8822c.o	
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8822c/halhwimg8822c_bb.o\
+		phydm/rtl8822c/halhwimg8822c_mac.o\
+		phydm/rtl8822c/halhwimg8822c_rf.o\
+		phydm/rtl8822c/phydm_regconfig8822c.o\
+		phydm/rtl8822c/phydm_hal_api8822c.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8821CE),y)
+	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_8821c.o
+	_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_iqk_8821c.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8821c/halhwimg8821c_bb.o\
+		phydm/rtl8821c/halhwimg8821c_mac.o\
+		phydm/rtl8821c/halhwimg8821c_rf.o\
+		phydm/rtl8821c/phydm_regconfig8821c.o\
+		phydm/rtl8821c/phydm_hal_api8821c.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8197F),y)
+		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_8197f.o
+		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_iqk_8197f.o
+		_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_dpk_8197f.o
+		_PHYDM_FILES += efuse_97f/efuse.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8197f/halhwimg8197f_bb.o\
+		phydm/rtl8197f/halhwimg8197f_mac.o\
+		phydm/rtl8197f/halhwimg8197f_rf.o\
+		phydm/rtl8197f/phydm_hal_api8197f.o\
+		phydm/rtl8197f/phydm_regconfig8197f.o\
+		phydm/rtl8197f/phydm_rtl8197f.o
+	endif
+endif
+
+
+ifeq ($(CONFIG_WLAN_HAL_8192FE),y)
+		_PHYDM_FILES += phydm/halrf/rtl8192f/halrf_8192f.o
+		_PHYDM_FILES += phydm/halrf/rtl8192f/halrf_dpk_8192f.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8192f/halhwimg8192f_bb.o\
+		phydm/rtl8192f/halhwimg8192f_mac.o\
+		phydm/rtl8192f/halhwimg8192f_rf.o\
+		phydm/rtl8192f/phydm_hal_api8192f.o\
+		phydm/rtl8192f/phydm_regconfig8192f.o\
+		phydm/rtl8192f/phydm_rtl8192f.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8198F),y)
+		_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_8198f.o
+		_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_iqk_8198f.o
+		_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_dpk_8198f.o
+		_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_rfk_init_8198f.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8198f/phydm_hal_api8198f.o\
+		phydm/rtl8198f/halhwimg8198f_bb.o\
+		phydm/rtl8198f/halhwimg8198f_mac.o\
+		phydm/rtl8198f/halhwimg8198f_rf.o\
+		phydm/rtl8198f/phydm_regconfig8198f.o \
+		phydm/halrf/rtl8198f/halrf_8198f.o
+	endif
+endif
+
+ifeq ($(CONFIG_WLAN_HAL_8814BE),y)
+		_PHYDM_FILES += phydm/halrf/rtl8814b/halrf_8814b.o
+		_PHYDM_FILES += phydm/halrf/rtl8814b/halrf_iqk_8814b.o
+		_PHYDM_FILES += phydm/halrf/rtl8814b/halrf_rfk_init_8814b.o
+	ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
+		_PHYDM_FILES += \
+		phydm/rtl8814b/phydm_hal_api8814b.o\
+		phydm/rtl8814b/halhwimg8814b_bb.o\
+		phydm/rtl8814b/halhwimg8814b_mac.o\
+		phydm/rtl8814b/halhwimg8814b_rf.o\
+		phydm/rtl8814b/phydm_regconfig8814b.o \
+		phydm/halrf/rtl8814b/halrf_8814b.o
+	endif
+endif
+
+
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halhwimg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halhwimg.h
index e8f580220543..1c8f0841394a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halhwimg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halhwimg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -16,76 +17,76 @@
 #ifndef __INC_HW_IMG_H
 #define __INC_HW_IMG_H
 
-/*
+/*@
  * 2011/03/15 MH Add for different IC HW image file selection. code size consideration.
  *   */
 #if RT_PLATFORM == PLATFORM_LINUX
 
 	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-		/* For 92C */
+		/* @For 92C */
 		#define		RTL8192CE_HWIMG_SUPPORT					1
 		#define		RTL8192CE_TEST_HWIMG_SUPPORT			0
 		#define		RTL8192CU_HWIMG_SUPPORT					0
 		#define		RTL8192CU_TEST_HWIMG_SUPPORT			0
 
-		/* For 92D */
+		/* @For 92D */
 		#define		RTL8192DE_HWIMG_SUPPORT					1
 		#define		RTL8192DE_TEST_HWIMG_SUPPORT			0
 		#define		RTL8192DU_HWIMG_SUPPORT					0
 		#define		RTL8192DU_TEST_HWIMG_SUPPORT			0
 
-		/* For 8723 */
+		/* @For 8723 */
 		#define		RTL8723E_HWIMG_SUPPORT					1
 		#define		RTL8723U_HWIMG_SUPPORT					0
 		#define		RTL8723S_HWIMG_SUPPORT					0
 
-		/* For 88E */
+		/* @For 88E */
 		#define		RTL8188EE_HWIMG_SUPPORT					0
 		#define		RTL8188EU_HWIMG_SUPPORT					0
 		#define		RTL8188ES_HWIMG_SUPPORT					0
 
 	#elif (DEV_BUS_TYPE == RT_USB_INTERFACE)
-		/* For 92C */
+		/* @For 92C */
 		#define	RTL8192CE_HWIMG_SUPPORT				0
 		#define	RTL8192CE_TEST_HWIMG_SUPPORT			0
 		#define	RTL8192CU_HWIMG_SUPPORT				1
 		#define	RTL8192CU_TEST_HWIMG_SUPPORT			0
 
-		/* For 92D */
+		/* @For 92D */
 		#define	RTL8192DE_HWIMG_SUPPORT				0
 		#define	RTL8192DE_TEST_HWIMG_SUPPORT			0
 		#define	RTL8192DU_HWIMG_SUPPORT				1
 		#define	RTL8192DU_TEST_HWIMG_SUPPORT			0
 
-		/* For 8723 */
+		/* @For 8723 */
 		#define	RTL8723E_HWIMG_SUPPORT					0
 		#define	RTL8723U_HWIMG_SUPPORT					1
 		#define	RTL8723S_HWIMG_SUPPORT					0
 
-		/* For 88E */
+		/* @For 88E */
 		#define		RTL8188EE_HWIMG_SUPPORT					0
 		#define		RTL8188EU_HWIMG_SUPPORT					0
 		#define		RTL8188ES_HWIMG_SUPPORT					0
 
 	#elif (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
-		/* For 92C */
+		/* @For 92C */
 		#define	RTL8192CE_HWIMG_SUPPORT				0
 		#define	RTL8192CE_TEST_HWIMG_SUPPORT			0
 		#define	RTL8192CU_HWIMG_SUPPORT				1
 		#define	RTL8192CU_TEST_HWIMG_SUPPORT			0
 
-		/* For 92D */
+		/* @For 92D */
 		#define	RTL8192DE_HWIMG_SUPPORT				0
 		#define	RTL8192DE_TEST_HWIMG_SUPPORT			0
 		#define	RTL8192DU_HWIMG_SUPPORT				1
 		#define	RTL8192DU_TEST_HWIMG_SUPPORT			0
 
-		/* For 8723 */
+		/* @For 8723 */
 		#define	RTL8723E_HWIMG_SUPPORT					0
 		#define	RTL8723U_HWIMG_SUPPORT					0
 		#define	RTL8723S_HWIMG_SUPPORT					1
 
-		/* For 88E */
+		/* @For 88E */
 		#define		RTL8188EE_HWIMG_SUPPORT					0
 		#define		RTL8188EU_HWIMG_SUPPORT					0
 		#define		RTL8188ES_HWIMG_SUPPORT					0
@@ -93,40 +94,40 @@
 
 #else	/* PLATFORM_WINDOWS & MacOSX */
 
-	/* For 92C */
+	/* @For 92C */
 	#define		RTL8192CE_HWIMG_SUPPORT						1
 	#define		RTL8192CE_TEST_HWIMG_SUPPORT				1
 	#define		RTL8192CU_HWIMG_SUPPORT						1
 	#define		RTL8192CU_TEST_HWIMG_SUPPORT				1
 
-	/* For 92D */
+	/* @For 92D */
 	#define		RTL8192DE_HWIMG_SUPPORT					1
 	#define		RTL8192DE_TEST_HWIMG_SUPPORT				1
 	#define		RTL8192DU_HWIMG_SUPPORT					1
 	#define		RTL8192DU_TEST_HWIMG_SUPPORT				1
 
 	#if defined(UNDER_CE)
-		/* For 8723 */
+		/* @For 8723 */
 		#define		RTL8723E_HWIMG_SUPPORT					0
 		#define		RTL8723U_HWIMG_SUPPORT					0
 		#define		RTL8723S_HWIMG_SUPPORT					1
 
-		/* For 88E */
+		/* @For 88E */
 		#define		RTL8188EE_HWIMG_SUPPORT					0
 		#define		RTL8188EU_HWIMG_SUPPORT					0
 		#define		RTL8188ES_HWIMG_SUPPORT					0
 
 	#else
 
-		/* For 8723 */
+		/* @For 8723 */
 		#define		RTL8723E_HWIMG_SUPPORT					1
-		/* #define		RTL_8723E_TEST_HWIMG_SUPPORT			1 */
+		/* @#define		RTL_8723E_TEST_HWIMG_SUPPORT			1 */
 		#define		RTL8723U_HWIMG_SUPPORT					1
-		/* #define		RTL_8723U_TEST_HWIMG_SUPPORT			1 */
+		/* @#define		RTL_8723U_TEST_HWIMG_SUPPORT			1 */
 		#define		RTL8723S_HWIMG_SUPPORT					1
-		/* #define		RTL_8723S_TEST_HWIMG_SUPPORT			1 */
+		/* @#define		RTL_8723S_TEST_HWIMG_SUPPORT			1 */
 
-		/* For 88E */
+		/* @For 88E */
 		#define		RTL8188EE_HWIMG_SUPPORT					1
 		#define		RTL8188EU_HWIMG_SUPPORT					1
 		#define		RTL8188ES_HWIMG_SUPPORT					1
@@ -134,4 +135,4 @@
 
 #endif
 
-#endif /* __INC_HW_IMG_H */
+#endif /* @__INC_HW_IMG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.c
index 44fc908c858d..ac20b4d082fd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -39,52 +40,61 @@
 
 
 void configure_txpower_track(
-	void		*p_dm_void,
-	struct _TXPWRTRACK_CFG	*p_config
+	void		*dm_void,
+	struct txpwrtrack_cfg	*config
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 #if RTL8812A_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	/* if (IS_HARDWARE_TYPE_8812(p_dm->adapter)) */
-	if (p_dm->support_ic_type == ODM_RTL8812)
-		configure_txpower_track_8812a(p_config);
+	/* if (IS_HARDWARE_TYPE_8812(dm->adapter)) */
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
 	/* else */
 #endif
 #endif
 
 #if RTL8814A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8814A)
-		configure_txpower_track_8814a(p_config);
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
 #endif
 
 
 #if RTL8188E_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8188E)
-		configure_txpower_track_8188e(p_config);
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
 #endif
 
 #if RTL8197F_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8197F)
-		configure_txpower_track_8197f(p_config);
+	if (dm->support_ic_type == ODM_RTL8197F)
+		configure_txpower_track_8197f(config);
 #endif
 
 #if RTL8822B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8822B)
-		configure_txpower_track_8822b(p_config);
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
 #endif
 
+#if RTL8192F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192F)
+		configure_txpower_track_8192f(config);
+#endif
+
+#if RTL8198F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8198F)
+		configure_txpower_track_8198f(config);
+#endif
 
 }
 
 #if (RTL8192E_SUPPORT == 1)
 void
 odm_txpowertracking_callback_thermal_meter_92e(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
 	u8	thermal_value = 0, delta, delta_IQK, delta_LCK, channel, is_decrease, rf_mimo_mode;
 	u8	thermal_value_avg_count = 0;
 	u8     OFDM_min_index = 10; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur */
@@ -92,13 +102,13 @@ odm_txpowertracking_callback_thermal_meter_92e(
 	u32	thermal_value_avg = 0, reg0x18;
 	u32	i = 0, j = 0, rf;
 	s32	value32, CCK_index = 0, ele_A, ele_D, ele_C, X, Y;
-	struct rtl8192cd_priv	*priv = p_dm->priv;
+	struct rtl8192cd_priv	*priv = dm->priv;
 
-	rf_mimo_mode = p_dm->rf_type;
-	/* ODM_RT_TRACE(p_dm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("%s:%d rf_mimo_mode:%d\n", __FUNCTION__, __LINE__, rf_mimo_mode)); */
+	rf_mimo_mode = dm->rf_type;
+	/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK,"%s:%d rf_mimo_mode:%d\n", __FUNCTION__, __LINE__, rf_mimo_mode); */
 
 #ifdef MP_TEST
-	if ((OPMODE & WIFI_MP_STATE) || *(p_dm->p_mp_mode)) {
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
 		channel = priv->pshare->working_channel;
 		if (priv->pshare->mp_txpwr_tracking == false)
 			return;
@@ -108,8 +118,8 @@ odm_txpowertracking_callback_thermal_meter_92e(
 		channel = (priv->pmib->dot11RFEntry.dot11channel);
 	}
 
-	thermal_value = (unsigned char)odm_get_rf_reg(p_dm, RF_PATH_A, ODM_RF_T_METER_92E, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther));
+	thermal_value = (unsigned char)odm_get_rf_reg(dm, RF_PATH_A, ODM_RF_T_METER_92E, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
 
 
 	switch (rf_mimo_mode) {
@@ -129,7 +139,7 @@ odm_txpowertracking_callback_thermal_meter_92e(
 	for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
 		if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
 			OFDM_index[0] = (unsigned char)i;
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("PathA 0xC80[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[0]));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "PathA 0xC80[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[0]);
 			break;
 		}
 	}
@@ -140,7 +150,7 @@ odm_txpowertracking_callback_thermal_meter_92e(
 		for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
 			if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
 				OFDM_index[1] = (unsigned char)i;
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("PathB 0xC88[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[1]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "PathB 0xC88[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[1]);
 				break;
 			}
 		}
@@ -162,7 +172,7 @@ odm_txpowertracking_callback_thermal_meter_92e(
 
 		if (thermal_value_avg_count) {
 			thermal_value = (unsigned char)(thermal_value_avg / thermal_value_avg_count);
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("AVG Thermal Meter = 0x%x\n", thermal_value));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
 		}
 	}
 
@@ -174,8 +184,8 @@ odm_txpowertracking_callback_thermal_meter_92e(
 	}
 
 	if (thermal_value != priv->pshare->thermal_value) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\n******** START POWER TRACKING ********\n"));
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
 
 		delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
 		delta_IQK = RTL_ABS(thermal_value, priv->pshare->thermal_value_iqk);
@@ -184,32 +194,32 @@ odm_txpowertracking_callback_thermal_meter_92e(
 
 #ifdef _TRACKING_TABLE_FILE
 		if (priv->pshare->rf_ft_var.pwr_track_file) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0)));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
 
 			if (is_decrease) {
 				for (i = 0; i < rf; i++) {
 					OFDM_index[i] = priv->pshare->OFDM_index0[i] + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
 					OFDM_index[i] = ((OFDM_index[i] > (OFDM_TABLE_SIZE_92E- 1)) ? (OFDM_TABLE_SIZE_92E - 1) : OFDM_index[i]);
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0)));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
 					CCK_index = priv->pshare->CCK_index0 + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
 					CCK_index = ((CCK_index > (CCK_TABLE_SIZE_92E - 1)) ? (CCK_TABLE_SIZE_92E - 1) : CCK_index);
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> Decrese power ---> new CCK_INDEX:%d (%d + %d)\n",  CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1)));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> Decrese power ---> new CCK_INDEX:%d (%d + %d)\n",  CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
 				}
 			} else {
 				for (i = 0; i < rf; i++) {
 					OFDM_index[i] = priv->pshare->OFDM_index0[i] - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
 					OFDM_index[i] = ((OFDM_index[i] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[i]);
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> Increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0)));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> Increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
 					CCK_index = priv->pshare->CCK_index0 - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
 					CCK_index = ((CCK_index < 0) ? 0 : CCK_index);
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> Increse power ---> new CCK_INDEX:%d (%d - %d)\n", CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1)));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> Increse power ---> new CCK_INDEX:%d (%d - %d)\n", CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
 				}
 			}
 		}
 #endif /* CFG_TRACKING_TABLE_FILE */
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]));
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]);
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]);
 
 		/* Adujst OFDM Ant_A according to IQK result */
 		ele_D = (ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] & 0xFFC00000) >> 22;
@@ -275,18 +285,18 @@ odm_txpowertracking_callback_thermal_meter_92e(
 
 		}
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("0xc80 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD)));
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("0xc88 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD)));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xc80 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xc88 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD));
 
-		if ((delta_IQK > 3) && (!p_iqk_info->rfk_forbidden)) {
+		if ((delta_IQK > 3) && (!iqk_info->rfk_forbidden)) {
 			priv->pshare->thermal_value_iqk = thermal_value;
 #ifdef MP_TEST
-#endif			if (!(*(p_dm->p_mp_mode) && (OPMODE & (WIFI_MP_CTX_BACKGROUND | WIFI_MP_CTX_PACKET))))
+#endif			if (!(*(dm->mp_mode) && (OPMODE & (WIFI_MP_CTX_BACKGROUND | WIFI_MP_CTX_PACKET))))
 
-				halrf_iqk_trigger(p_dm, false);
+				halrf_iqk_trigger(dm, false);
 		}
 
-		if ((delta_LCK > 8)  && (!p_iqk_info->rfk_forbidden)) {
+		if ((delta_LCK > 8)  && (!iqk_info->rfk_forbidden)) {
 			RTL_W8(0x522, 0xff);
 			reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
 			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
@@ -305,40 +315,43 @@ odm_txpowertracking_callback_thermal_meter_92e(
 		priv->pshare->OFDM_index[i] = OFDM_index[i];
 	priv->pshare->CCK_index = CCK_index;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\n******** END:%s() ********\n", __FUNCTION__));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
 }
 #endif
 
 
 
-#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+#if (RTL8197F_SUPPORT == 1 || RTL8192F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 ||\
+	RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1)
 void
 odm_txpowertracking_callback_thermal_meter_jaguar_series3(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
 #if 1
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
-	u8			thermal_value_avg_count = 0, p = 0, i = 0;
-	u32			thermal_value_avg = 0;
-	struct rtl8192cd_priv		*priv = p_dm->priv;
-	struct _TXPWRTRACK_CFG	c;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
-	/*4 1. The following TWO tables decide the final index of OFDM/CCK swing table.*/
-	u8			*delta_swing_table_idx_tup_a = NULL, *delta_swing_table_idx_tdown_a = NULL;
-	u8			*delta_swing_table_idx_tup_b = NULL, *delta_swing_table_idx_tdown_b = NULL;
-	u8			*delta_swing_table_idx_tup_cck_a = NULL, *delta_swing_table_idx_tdown_cck_a = NULL;
-	u8			*delta_swing_table_idx_tup_cck_b = NULL, *delta_swing_table_idx_tdown_cck_b = NULL;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
+	u8 thermal_value_avg_count = 0, p = 0, i = 0;
+	u32 thermal_value_avg = 0;
+	struct rtl8192cd_priv *priv = dm->priv;
+	struct txpwrtrack_cfg c;
+	struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	/*The following tables decide the final index of OFDM/CCK swing table.*/
+	u8 *pwrtrk_tab_up_a = NULL, *pwrtrk_tab_down_a = NULL;
+	u8 *pwrtrk_tab_up_b = NULL, *pwrtrk_tab_down_b = NULL;
+	u8 *pwrtrk_tab_up_cck_a = NULL, *pwrtrk_tab_down_cck_a = NULL;
+	u8 *pwrtrk_tab_up_cck_b = NULL, *pwrtrk_tab_down_cck_b = NULL;
 	/*for 8814 add by Yu Chen*/
-	u8			*delta_swing_table_idx_tup_c = NULL, *delta_swing_table_idx_tdown_c = NULL;
-	u8			*delta_swing_table_idx_tup_d = NULL, *delta_swing_table_idx_tdown_d = NULL;
-	u8			*delta_swing_table_idx_tup_cck_c = NULL, *delta_swing_table_idx_tdown_cck_c = NULL;
-	u8			*delta_swing_table_idx_tup_cck_d = NULL, *delta_swing_table_idx_tdown_cck_d = NULL;
+	u8 *pwrtrk_tab_up_c = NULL, *pwrtrk_tab_down_c = NULL;
+	u8 *pwrtrk_tab_up_d = NULL, *pwrtrk_tab_down_d = NULL;
+	u8 *pwrtrk_tab_up_cck_c = NULL, *pwrtrk_tab_down_cck_c = NULL;
+	u8 *pwrtrk_tab_up_cck_d = NULL, *pwrtrk_tab_down_cck_d = NULL;
+	s8 thermal_value_temp = 0;
 
 #ifdef MP_TEST
-	if ((OPMODE & WIFI_MP_STATE) || *(p_dm->p_mp_mode)) {
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
 		channel = priv->pshare->working_channel;
 		if (priv->pshare->mp_txpwr_tracking == false)
 			return;
@@ -348,221 +361,240 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series3(
 		channel = (priv->pmib->dot11RFEntry.dot11channel);
 	}
 
-	configure_txpower_track(p_dm, &c);
+	configure_txpower_track(dm, &c);
 
-	(*c.get_delta_all_swing_table)(p_dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
-		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b,
-		(u8 **)&delta_swing_table_idx_tup_cck_a, (u8 **)&delta_swing_table_idx_tdown_cck_a,
-		(u8 **)&delta_swing_table_idx_tup_cck_b, (u8 **)&delta_swing_table_idx_tdown_cck_b);
+	(*c.get_delta_all_swing_table)(dm,
+		(u8 **)&pwrtrk_tab_up_a, (u8 **)&pwrtrk_tab_down_a,
+		(u8 **)&pwrtrk_tab_up_b, (u8 **)&pwrtrk_tab_down_b,
+		(u8 **)&pwrtrk_tab_up_cck_a, (u8 **)&pwrtrk_tab_down_cck_a,
+		(u8 **)&pwrtrk_tab_up_cck_b, (u8 **)&pwrtrk_tab_down_cck_b);
 
-	thermal_value = (u8)odm_get_rf_reg(p_dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /*0x42: RF Reg[15:10] 88E*/
+	if (GET_CHIP_VER(priv) == VERSION_8198F) {
+		(*c.get_delta_all_swing_table_ex)(dm,
+			(u8 **)&pwrtrk_tab_up_c, (u8 **)&pwrtrk_tab_down_c,
+			(u8 **)&pwrtrk_tab_up_d, (u8 **)&pwrtrk_tab_down_d,
+			(u8 **)&pwrtrk_tab_up_cck_c, (u8 **)&pwrtrk_tab_down_cck_c,
+			(u8 **)&pwrtrk_tab_up_cck_d, (u8 **)&pwrtrk_tab_down_cck_d);
+	}
+	/*0x42: RF Reg[15:10] 88E*/
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);
 #ifdef THER_TRIM
 	if (GET_CHIP_VER(priv) == VERSION_8197F) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("orig thermal_value=%d, ther_trim_val=%d\n", thermal_value, priv->pshare->rf_ft_var.ther_trim_val));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"orig thermal_value=%d, ther_trim_val=%d\n", thermal_value, priv->pshare->rf_ft_var.ther_trim_val);
 
 		thermal_value += priv->pshare->rf_ft_var.ther_trim_val;
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("after thermal trim, thermal_value=%d\n", thermal_value));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"after thermal trim, thermal_value=%d\n", thermal_value);
+	}
+
+	if (GET_CHIP_VER(priv) == VERSION_8198F) {
+		thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
+
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "thermal_value_temp(%d) = ther_value(%d) + ther_trim_ther(%d)\n",
+		       thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
+
+		if (thermal_value_temp > 63)
+			thermal_value = 63;
+		else if (thermal_value_temp < 0)
+			thermal_value = 0;
+		else
+			thermal_value = thermal_value_temp;
 	}
 #endif
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("Readback Thermal Meter = 0x%x(%d) EEPROMthermalmeter 0x%x(%d)\n"
-		, thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther));
+
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\n\n\nCurrent Thermal = 0x%x(%d) EEPROMthermalmeter 0x%x(%d)\n"
+		, thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
 
 	/* Initialize */
-	if (!p_dm->rf_calibrate_info.thermal_value)
-		p_dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
+	if (!dm->rf_calibrate_info.thermal_value)
+		dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
 
-	if (!p_dm->rf_calibrate_info.thermal_value_lck)
-		p_dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
+	if (!dm->rf_calibrate_info.thermal_value_lck)
+		dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
 
-	if (!p_dm->rf_calibrate_info.thermal_value_iqk)
-		p_dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
+	if (!dm->rf_calibrate_info.thermal_value_iqk)
+		dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
 
 	/* calculate average thermal meter */
-	p_dm->rf_calibrate_info.thermal_value_avg[p_dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
-	p_dm->rf_calibrate_info.thermal_value_avg_index++;
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
 
-	if (p_dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
-		p_dm->rf_calibrate_info.thermal_value_avg_index = 0;
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
 
 	for (i = 0; i < c.average_thermal_num; i++) {
-		if (p_dm->rf_calibrate_info.thermal_value_avg[i]) {
-			thermal_value_avg += p_dm->rf_calibrate_info.thermal_value_avg[i];
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
 			thermal_value_avg_count++;
 		}
 	}
 
 	if (thermal_value_avg_count) {/*Calculate Average thermal_value after average enough times*/
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("thermal_value_avg=0x%x(%d)  thermal_value_avg_count = %d\n"
-			, thermal_value_avg, thermal_value_avg, thermal_value_avg_count));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"thermal_value_avg=0x%x(%d)  thermal_value_avg_count = %d\n"
+			, thermal_value_avg, thermal_value_avg, thermal_value_avg_count);
 
 		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X(%d), EEPROMthermalmeter = 0x%X(%d)\n", thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X(%d), EEPROMthermalmeter = 0x%X(%d)\n", thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
 	}
 
 	/*4 Calculate delta, delta_LCK, delta_IQK.*/
 	delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
-	delta_LCK = RTL_ABS(thermal_value, p_dm->rf_calibrate_info.thermal_value_lck);
-	delta_IQK = RTL_ABS(thermal_value, p_dm->rf_calibrate_info.thermal_value_iqk);
+	delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
+	delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
 	is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
 
 	if (delta > 29) { /* power track table index(thermal diff.) upper bound*/
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta(%d) > 29, set delta to 29\n", delta));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta(%d) > 29, set delta to 29\n", delta);
 		delta = 29;
 	}
 
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
 
 	/*4 if necessary, do LCK.*/
-	if ((delta_LCK > c.threshold_iqk) && (!p_iqk_info->rfk_forbidden)) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk));
-		p_dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+	if ((delta_LCK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_lck = thermal_value;
 #if (RTL8822B_SUPPORT != 1)
-		if (!(p_dm->support_ic_type & ODM_RTL8822B)) {
-		if (c.phy_lc_calibrate)
-			(*c.phy_lc_calibrate)(p_dm);
-	}
+		if (!(dm->support_ic_type & ODM_RTL8822B)) {
+			if (c.phy_lc_calibrate)
+				(*c.phy_lc_calibrate)(dm);
+		}
 #endif
 	}
 
-	if ((delta_IQK > c.threshold_iqk) && (!p_iqk_info->rfk_forbidden)) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk));
-		p_dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
-		if (c.do_iqk)
-			(*c.do_iqk)(p_dm, true, 0, 0);
-	}
-
-	if (!priv->pmib->dot11RFEntry.ther)	/*Don't do power tracking since no calibrated thermal value*/
+	if (!priv->pmib->dot11RFEntry.ther) /*Don't do power tracking since no calibrated thermal value*/
 		return;
 
 	/*4 Do Power Tracking*/
 
-	if (thermal_value != p_dm->rf_calibrate_info.thermal_value) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			     ("\n\n******** START POWER TRACKING ********\n"));
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("Readback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n",
-			thermal_value, p_dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther));
+	if (thermal_value != dm->rf_calibrate_info.thermal_value) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******** START POWER TRACKING ********\n");
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"Readback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n",
+		       thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
 
 #ifdef _TRACKING_TABLE_FILE
 		if (priv->pshare->rf_ft_var.pwr_track_file) {
-			if (is_increase) {			/*thermal is higher than base*/
+			if (is_increase) { /*thermal is higher than base*/
 				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
 					switch (p) {
 					case RF_PATH_B:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_b[%d] = %d delta_swing_table_idx_tup_cck_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta], delta, delta_swing_table_idx_tup_cck_b[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_b[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_b[%d] = %d pwrtrk_tab_up_cck_b[%d] = %d\n", delta, pwrtrk_tab_up_b[delta], delta, pwrtrk_tab_up_cck_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_b[delta];
+						cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_b[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 
 					case RF_PATH_C:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_c[%d] = %d delta_swing_table_idx_tup_cck_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta], delta, delta_swing_table_idx_tup_cck_c[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_c[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_c[%d] = %d pwrtrk_tab_up_cck_c[%d] = %d\n", delta, pwrtrk_tab_up_c[delta], delta, pwrtrk_tab_up_cck_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_c[delta];
+						cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_c[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 
 					case RF_PATH_D:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_d[%d] = %d delta_swing_table_idx_tup_cck_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta], delta, delta_swing_table_idx_tup_cck_d[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_d[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_d[%d] = %d pwrtrk_tab_up_cck_d[%d] = %d\n", delta, pwrtrk_tab_up_d[delta], delta, pwrtrk_tab_up_cck_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_d[delta];
+						cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_d[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 					default:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_a[%d] = %d delta_swing_table_idx_tup_cck_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta], delta, delta_swing_table_idx_tup_cck_a[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_cck_a[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_a[%d] = %d pwrtrk_tab_up_cck_a[%d] = %d\n", delta, pwrtrk_tab_up_a[delta], delta, pwrtrk_tab_up_cck_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_a[delta];
+						cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_a[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 					}
 				}
-			} else {			/* thermal is lower than base*/
+			} else { /* thermal is lower than base*/
 				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
 					switch (p) {
 					case RF_PATH_B:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_b[%d] = %d   delta_swing_table_idx_tdown_cck_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta], delta, delta_swing_table_idx_tdown_cck_b[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_b[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d   pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_b[%d] = %d   pwrtrk_tab_down_cck_b[%d] = %d\n", delta, pwrtrk_tab_down_b[delta], delta, pwrtrk_tab_down_cck_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_b[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_b[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d   pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 
 					case RF_PATH_C:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_c[%d] = %d   delta_swing_table_idx_tdown_cck_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta], delta, delta_swing_table_idx_tdown_cck_c[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_c[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d   pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_c[%d] = %d   pwrtrk_tab_down_cck_c[%d] = %d\n", delta, pwrtrk_tab_down_c[delta], delta, pwrtrk_tab_down_cck_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_c[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_c[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d   pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 
 					case RF_PATH_D:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_d[%d] = %d   delta_swing_table_idx_tdown_cck_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta], delta, delta_swing_table_idx_tdown_cck_d[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_d[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d   pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_d[%d] = %d   pwrtrk_tab_down_cck_d[%d] = %d\n", delta, pwrtrk_tab_down_d[delta], delta, pwrtrk_tab_down_cck_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_d[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_d[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d   pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 
 					default:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_a[%d] = %d   delta_swing_table_idx_tdown_cck_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta], delta, delta_swing_table_idx_tdown_cck_a[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta];
-						p_rf_calibrate_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_cck_a[delta];
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d   pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p], p_rf_calibrate_info->absolute_cck_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_a[%d] = %d   pwrtrk_tab_down_cck_a[%d] = %d\n", delta, pwrtrk_tab_down_a[delta], delta, pwrtrk_tab_down_cck_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_a[delta];
+						cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_a[delta];
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d   pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
 						break;
 					}
 				}
 			}
 
 			if (is_increase) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> increse power --->\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> increse power --->\n");
 				if (GET_CHIP_VER(priv) == VERSION_8197F) {
 					for (p = RF_PATH_A; p < c.rf_path_count; p++)
-						(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, p, 0);
+						(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
+				//}  else if (GET_CHIP_VER(priv) == VERSION_8192F) {
+				//	for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				//		(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 				} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
 					for (p = RF_PATH_A; p < c.rf_path_count; p++)
-						(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 				} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
 					for (p = RF_PATH_A; p < c.rf_path_count; p++)
-						(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				}  else if (GET_CHIP_VER(priv) == VERSION_8198F) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 				}
 			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> decrese power --->\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power --->\n");
 				if (GET_CHIP_VER(priv) == VERSION_8197F) {
 					for (p = RF_PATH_A; p < c.rf_path_count; p++)
-						(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, p, 0);
+						(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
+				//} else if (GET_CHIP_VER(priv) == VERSION_8192F) {
+				//	for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				//		(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 				} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
 					for (p = RF_PATH_A; p < c.rf_path_count; p++)
-						(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 				} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
 					for (p = RF_PATH_A; p < c.rf_path_count; p++)
-						(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+				} else if (GET_CHIP_VER(priv) == VERSION_8198F) {
+					for (p = RF_PATH_A; p < c.rf_path_count; p++)
+						(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 				}
 			}
 		}
 #endif
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\n******** END:%s() ********\n\n", __func__));
+		if (GET_CHIP_VER(priv) != VERSION_8198F) {
+			if ((delta_IQK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+				dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+				if (!(dm->support_ic_type & ODM_RTL8197F)) {
+					if (c.do_iqk)
+						(*c.do_iqk)(dm, false, thermal_value, 0);
+				}
+			}
+		}
+
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n\n", __func__);
 		/*update thermal meter value*/
-		p_dm->rf_calibrate_info.thermal_value =  thermal_value;
+		dm->rf_calibrate_info.thermal_value =  thermal_value;
 
 	}
 
@@ -575,21 +607,21 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series3(
 
 void
 odm_txpowertracking_callback_thermal_meter_jaguar_series2(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
 	u8			thermal_value_avg_count = 0, p = 0, i = 0;
 	u32			thermal_value_avg = 0, reg0x18;
 	u32			bb_swing_reg[4] = {REG_A_TX_SCALE_JAGUAR, REG_B_TX_SCALE_JAGUAR, REG_C_TX_SCALE_JAGUAR2, REG_D_TX_SCALE_JAGUAR2};
 	s32			ele_D;
 	u32			bb_swing_idx;
-	struct rtl8192cd_priv	*priv = p_dm->priv;
-	struct _TXPWRTRACK_CFG	c;
+	struct rtl8192cd_priv	*priv = dm->priv;
+	struct txpwrtrack_cfg	c;
 	boolean			is_tssi_enable = false;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
 
 	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
 	u8			*delta_swing_table_idx_tup_a = NULL, *delta_swing_table_idx_tdown_a = NULL;
@@ -599,7 +631,7 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series2(
 	u8			*delta_swing_table_idx_tup_d = NULL, *delta_swing_table_idx_tdown_d = NULL;
 
 #ifdef MP_TEST
-	if ((OPMODE & WIFI_MP_STATE) || *(p_dm->p_mp_mode)) {
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
 		channel = priv->pshare->working_channel;
 		if (priv->pshare->mp_txpwr_tracking == false)
 			return;
@@ -609,97 +641,93 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series2(
 		channel = (priv->pmib->dot11RFEntry.dot11channel);
 	}
 
-	configure_txpower_track(p_dm, &c);
-	p_rf_calibrate_info->default_ofdm_index = priv->pshare->OFDM_index0[RF_PATH_A];
+	configure_txpower_track(dm, &c);
+	cali_info->default_ofdm_index = priv->pshare->OFDM_index0[RF_PATH_A];
 
-	(*c.get_delta_swing_table)(p_dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
 		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
 
-	if (p_dm->support_ic_type & ODM_RTL8814A)	/* for 8814 path C & D */
-		(*c.get_delta_swing_table8814only)(p_dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+	if (dm->support_ic_type & ODM_RTL8814A)	/* for 8814 path C & D */
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
 			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
 
-	thermal_value = (u8)odm_get_rf_reg(p_dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("\nReadback Thermal Meter = 0x%x, pre thermal meter 0x%x, EEPROMthermalmeter 0x%x\n", thermal_value, p_dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther));
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x, pre thermal meter 0x%x, EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
 
 	/* Initialize */
-	if (!p_dm->rf_calibrate_info.thermal_value)
-		p_dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
+	if (!dm->rf_calibrate_info.thermal_value)
+		dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
 
-	if (!p_dm->rf_calibrate_info.thermal_value_lck)
-		p_dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
+	if (!dm->rf_calibrate_info.thermal_value_lck)
+		dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
 
-	if (!p_dm->rf_calibrate_info.thermal_value_iqk)
-		p_dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
+	if (!dm->rf_calibrate_info.thermal_value_iqk)
+		dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
 
-	is_tssi_enable = (boolean)odm_get_rf_reg(p_dm, RF_PATH_A, REG_RF_TX_GAIN_OFFSET, BIT(7));	/* check TSSI enable */
+	is_tssi_enable = (boolean)odm_get_rf_reg(dm, RF_PATH_A, REG_RF_TX_GAIN_OFFSET, BIT(7));	/* check TSSI enable */
 
 	/* 4 Query OFDM BB swing default setting 	Bit[31:21] */
 	for (p = RF_PATH_A ; p < c.rf_path_count ; p++) {
-		ele_D = odm_get_bb_reg(p_dm, bb_swing_reg[p], 0xffe00000);
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[p], odm_get_bb_reg(p_dm, bb_swing_reg[p], MASKDWORD), ele_D));
+		ele_D = odm_get_bb_reg(dm, bb_swing_reg[p], 0xffe00000);
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[p], odm_get_bb_reg(dm, bb_swing_reg[p], MASKDWORD), ele_D);
 
 		for (bb_swing_idx = 0; bb_swing_idx < TXSCALE_TABLE_SIZE; bb_swing_idx++) {/* 4 */
 			if (ele_D == tx_scaling_table_jaguar[bb_swing_idx]) {
-				p_dm->rf_calibrate_info.OFDM_index[p] = (u8)bb_swing_idx;
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("OFDM_index[%d]=%d\n", p, p_dm->rf_calibrate_info.OFDM_index[p]));
+				dm->rf_calibrate_info.OFDM_index[p] = (u8)bb_swing_idx;
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"OFDM_index[%d]=%d\n", p, dm->rf_calibrate_info.OFDM_index[p]);
 				break;
 			}
 		}
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("kfree_offset[%d]=%d\n", p, p_rf_calibrate_info->kfree_offset[p]));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "kfree_offset[%d]=%d\n", p, cali_info->kfree_offset[p]);
 
 	}
 
 	/* calculate average thermal meter */
-	p_dm->rf_calibrate_info.thermal_value_avg[p_dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
-	p_dm->rf_calibrate_info.thermal_value_avg_index++;
-	if (p_dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)  /* Average times =  c.average_thermal_num */
-		p_dm->rf_calibrate_info.thermal_value_avg_index = 0;
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)  /* Average times =  c.average_thermal_num */
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
 
 	for (i = 0; i < c.average_thermal_num; i++) {
-		if (p_dm->rf_calibrate_info.thermal_value_avg[i]) {
-			thermal_value_avg += p_dm->rf_calibrate_info.thermal_value_avg[i];
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
 			thermal_value_avg_count++;
 		}
 	}
 
 	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
 		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X, EEPROMthermalmeter = 0x%X\n", thermal_value, priv->pmib->dot11RFEntry.ther));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X, EEPROMthermalmeter = 0x%X\n", thermal_value, priv->pmib->dot11RFEntry.ther);
 	}
 
 	/* 4 Calculate delta, delta_LCK, delta_IQK. */
 	delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
-	delta_LCK = RTL_ABS(thermal_value, p_dm->rf_calibrate_info.thermal_value_lck);
-	delta_IQK = RTL_ABS(thermal_value, p_dm->rf_calibrate_info.thermal_value_iqk);
+	delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
+	delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
 	is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
 
 	/* 4 if necessary, do LCK. */
-	if (!(p_dm->support_ic_type & ODM_RTL8821)) {
-		if ((delta_LCK > c.threshold_iqk) && (!p_iqk_info->rfk_forbidden)) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk));
-			p_dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+	if (!(dm->support_ic_type & ODM_RTL8821)) {
+		if ((delta_LCK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+			dm->rf_calibrate_info.thermal_value_lck = thermal_value;
 
 			/*Use RTLCK, so close power tracking driver LCK*/
 #if (RTL8814A_SUPPORT != 1)
-			if (!(p_dm->support_ic_type & ODM_RTL8814A)) {
+			if (!(dm->support_ic_type & ODM_RTL8814A)) {
 				if (c.phy_lc_calibrate)
-					(*c.phy_lc_calibrate)(p_dm);
+					(*c.phy_lc_calibrate)(dm);
 			}
 #endif
 		}
 	}
 
-	if ((delta_IQK > c.threshold_iqk) && (!p_iqk_info->rfk_forbidden)) {
+	if ((delta_IQK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
 		panic_printk("%s(%d)\n", __FUNCTION__, __LINE__);
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk));
-		p_dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
 		if (c.do_iqk)
-			(*c.do_iqk)(p_dm, true, 0, 0);
+			(*c.do_iqk)(dm, true, 0, 0);
 	}
 
 	if (!priv->pmib->dot11RFEntry.ther)	/*Don't do power tracking since no calibrated thermal value*/
@@ -708,14 +736,12 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series2(
 	/* 4 Do Power Tracking */
 
 	if (is_tssi_enable == true) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter PURE TSSI MODE**********\n"));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter PURE TSSI MODE**********\n");
 		for (p = RF_PATH_A; p < c.rf_path_count; p++)
-			(*c.odm_tx_pwr_track_set_pwr)(p_dm, TSSI_MODE, p, 0);
-	} else if (thermal_value != p_dm->rf_calibrate_info.thermal_value) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			     ("\n******** START POWER TRACKING ********\n"));
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, p_dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther));
+			(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
+	} else if (thermal_value != dm->rf_calibrate_info.thermal_value) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\n******** START POWER TRACKING ********\n");
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
 
 #ifdef _TRACKING_TABLE_FILE
 		if (priv->pshare->rf_ft_var.pwr_track_file) {
@@ -723,35 +749,27 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series2(
 				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
 					switch (p) {
 					case RF_PATH_B:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta];       /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and p_dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta];       /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 
 					case RF_PATH_C:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta];       /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and p_dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta];       /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 
 					case RF_PATH_D:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta];       /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and p_dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta];       /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 
 					default:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta];        /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is higher and p_dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta];        /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 					}
 				}
@@ -759,55 +777,47 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series2(
 				for (p = RF_PATH_A; p < c.rf_path_count; p++) {
 					switch (p) {
 					case RF_PATH_B:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta];        /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and p_dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta];        /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 
 					case RF_PATH_C:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta];        /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and p_dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta];        /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 
 					case RF_PATH_D:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta];        /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and p_dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta];        /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 
 					default:
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]));
-						p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta];        /* Record delta swing for mix mode power tracking */
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-							("******Temp is lower and p_dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+						cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta];        /* Record delta swing for mix mode power tracking */
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 						break;
 					}
 				}
 			}
 
 			if (is_increase) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> increse power --->\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> increse power --->\n");
 				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> decrese power --->\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power --->\n");
 				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 			}
 		}
 #endif
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\n******** END:%s() ********\n", __FUNCTION__));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
 		/* update thermal meter value */
-		p_dm->rf_calibrate_info.thermal_value =  thermal_value;
+		dm->rf_calibrate_info.thermal_value =  thermal_value;
 
 	}
 }
@@ -816,10 +826,10 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series2(
 #if (RTL8812A_SUPPORT == 1 || RTL8881A_SUPPORT == 1)
 void
 odm_txpowertracking_callback_thermal_meter_jaguar_series(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 	unsigned char			thermal_value = 0, delta, delta_LCK, channel, is_decrease;
 	unsigned char			thermal_value_avg_count = 0;
 	unsigned int			thermal_value_avg = 0, reg0x18;
@@ -827,13 +837,13 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 	int					ele_D, value32;
 	char					OFDM_index[2], index;
 	unsigned int			i = 0, j = 0, rf_path, max_rf_path = 2, rf;
-	struct rtl8192cd_priv		*priv = p_dm->priv;
+	struct rtl8192cd_priv		*priv = dm->priv;
 	unsigned char			OFDM_min_index = 7; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur and Mimic */
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
 
 
 #ifdef MP_TEST
-	if ((OPMODE & WIFI_MP_STATE) || *(p_dm->p_mp_mode)) {
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
 		channel = priv->pshare->working_channel;
 		if (priv->pshare->mp_txpwr_tracking == false)
 			return;
@@ -844,10 +854,10 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 	}
 
 #if RTL8881A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8881A) {
+	if (dm->support_ic_type == ODM_RTL8881A) {
 		max_rf_path = 1;
 		if ((get_bonding_type_8881A() == BOND_8881AM || get_bonding_type_8881A() == BOND_8881AN)
-		    && priv->pshare->rf_ft_var.use_intpa8881A && (*p_dm->p_band_type == ODM_BAND_2_4G))
+		    && priv->pshare->rf_ft_var.use_intpa8881A && (*dm->band_type == ODM_BAND_2_4G))
 			OFDM_min_index = 6;		/* intPA - upper bond set to +3 dB (base: -2 dB)ot11RFEntry.phy_band_select == PHY_BAND_2G)) */
 		else
 			OFDM_min_index = 10;		/* OFDM BB Swing should be less than +1dB, which is required by Arthur and Mimic */
@@ -856,17 +866,17 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 
 
 	thermal_value = (unsigned char)phy_query_rf_reg(priv, RF_PATH_A, 0x42, 0xfc00, 1); /* 0x42: RF Reg[15:10] 88E */
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
 
 
 	/* 4 Query OFDM BB swing default setting 	Bit[31:21] */
 	for (rf_path = 0 ; rf_path < max_rf_path ; rf_path++) {
 		ele_D = phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000);
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], MASKDWORD), ele_D));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], MASKDWORD), ele_D);
 		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
 			if (ele_D == ofdm_swing_table_8812[i]) {
 				OFDM_index[rf_path] = (unsigned char)i;
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("OFDM_index[%d]=%d\n", rf_path, OFDM_index[rf_path]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "OFDM_index[%d]=%d\n", rf_path, OFDM_index[rf_path]);
 				break;
 			}
 		}
@@ -874,22 +884,22 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 #if 0
 	/* Query OFDM path A default setting 	Bit[31:21] */
 	ele_D = phy_query_bb_reg(priv, 0xc1c, 0xffe00000);
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("0xc1c:0x%x ([31:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xc1c, MASKDWORD), ele_D));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xc1c:0x%x ([31:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xc1c, MASKDWORD), ele_D);
 	for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
 		if (ele_D == ofdm_swing_table_8812[i]) {
 			OFDM_index[0] = (unsigned char)i;
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("OFDM_index[0]=%d\n", OFDM_index[0]));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "OFDM_index[0]=%d\n", OFDM_index[0]);
 			break;
 		}
 	}
 	/* Query OFDM path B default setting */
 	if (rf == 2) {
 		ele_D = phy_query_bb_reg(priv, 0xe1c, 0xffe00000);
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("0xe1c:0x%x ([32:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xe1c, MASKDWORD), ele_D));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xe1c:0x%x ([32:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xe1c, MASKDWORD), ele_D);
 		for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {
 			if (ele_D == ofdm_swing_table_8812[i]) {
 				OFDM_index[1] = (unsigned char)i;
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("OFDM_index[1]=%d\n", OFDM_index[1]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "OFDM_index[1]=%d\n", OFDM_index[1]);
 				break;
 			}
 		}
@@ -928,23 +938,23 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 		return;
 
 	if (thermal_value != priv->pshare->thermal_value) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\n******** START POWER TRACKING ********\n"));
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
 		delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
 		delta_LCK = RTL_ABS(thermal_value, priv->pshare->thermal_value_lck);
 		is_decrease = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
-		/* if (*p_dm->p_band_type == ODM_BAND_5G) */
+		/* if (*dm->band_type == ODM_BAND_5G) */
 		{
 #ifdef _TRACKING_TABLE_FILE
 			if (priv->pshare->rf_ft_var.pwr_track_file) {
 				for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0)));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
 					if (is_decrease) {
 						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] + get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
 						OFDM_index[rf_path] = ((OFDM_index[rf_path] > (OFDM_TABLE_SIZE_8812 - 1)) ? (OFDM_TABLE_SIZE_8812 - 1) : OFDM_index[rf_path]);
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0)));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
 #if 0/* RTL8881A_SUPPORT */
-						if (p_dm->support_ic_type == ODM_RTL8881A) {
+						if (dm->support_ic_type == ODM_RTL8881A) {
 							if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
 								if (priv->pshare->add_tx_agc) { /* tx_agc has been added */
 									add_tx_power88xx_ac(priv, 0);
@@ -958,7 +968,7 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 
 						OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] - get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
 #if 0/* RTL8881A_SUPPORT */
-						if (p_dm->support_ic_type == ODM_RTL8881A) {
+						if (dm->support_ic_type == ODM_RTL8881A) {
 							if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
 								if (OFDM_index[i] < OFDM_min_index) {
 									priv->pshare->add_tx_agc_index = (OFDM_min_index - OFDM_index[i]) / 2; /* Calculate Remnant tx_agc value,  2 index for 1 tx_agc */
@@ -977,7 +987,7 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 #else
 						OFDM_index[rf_path] = ((OFDM_index[rf_path] < OFDM_min_index) ?  OFDM_min_index : OFDM_index[rf_path]);
 #endif
-						ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, (">>> increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0)));
+						RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
 					}
 				}
 			}
@@ -985,11 +995,11 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 			/* 4 Set new BB swing index */
 			for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
 				phy_set_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000, ofdm_swing_table_8812[(unsigned int)OFDM_index[rf_path]]);
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("Readback 0x%x[31:21] = 0x%x, OFDM_index:%d\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000), OFDM_index[rf_path]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Readback 0x%x[31:21] = 0x%x, OFDM_index:%d\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000), OFDM_index[rf_path]);
 			}
 
 		}
-		if ((delta_LCK > 8) && (!p_iqk_info->rfk_forbidden)) {
+		if ((delta_LCK > 8) && (!iqk_info->rfk_forbidden)) {
 			RTL_W8(0x522, 0xff);
 			reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
 			phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
@@ -1004,7 +1014,7 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 			RTL_W8(0x522, 0x0);
 			priv->pshare->thermal_value_lck = thermal_value;
 		}
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("\n******** END:%s() ********\n", __FUNCTION__));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
 
 		/* update thermal meter value */
 		priv->pshare->thermal_value = thermal_value;
@@ -1018,43 +1028,43 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series(
 
 void
 odm_txpowertracking_callback_thermal_meter(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
-
-#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8197F || p_dm->support_ic_type == ODM_RTL8822B
-		|| p_dm->support_ic_type == ODM_RTL8821C) {
-		odm_txpowertracking_callback_thermal_meter_jaguar_series3(p_dm);
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
+
+#if (RTL8197F_SUPPORT == 1 ||RTL8192F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8197F || dm->support_ic_type == ODM_RTL8192F || dm->support_ic_type == ODM_RTL8822B
+		|| dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8198F) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series3(dm);
 		return;
 	}
 #endif
 #if (RTL8814A_SUPPORT == 1)		/*use this function to do power tracking after 8814 by YuChen*/
-	if (p_dm->support_ic_type & ODM_RTL8814A) {
-		odm_txpowertracking_callback_thermal_meter_jaguar_series2(p_dm);
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series2(dm);
 		return;
 	}
 #endif
 #if (RTL8881A_SUPPORT || RTL8812A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8812 || p_dm->support_ic_type & ODM_RTL8881A) {
-		odm_txpowertracking_callback_thermal_meter_jaguar_series(p_dm);
+	if (dm->support_ic_type & ODM_RTL8812 || dm->support_ic_type & ODM_RTL8881A) {
+		odm_txpowertracking_callback_thermal_meter_jaguar_series(dm);
 		return;
 	}
 #endif
 
 #if (RTL8192E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8192E) {
-		odm_txpowertracking_callback_thermal_meter_92e(p_dm);
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_txpowertracking_callback_thermal_meter_92e(dm);
 		return;
 	}
 #endif
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	/* PMGNT_INFO      		p_mgnt_info = &adapter->mgnt_info; */
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	/* PMGNT_INFO      		mgnt_info = &adapter->mgnt_info; */
 #endif
 
 
@@ -1070,10 +1080,10 @@ odm_txpowertracking_callback_thermal_meter(
 	/*	bool 		bInteralPA = false; */
 
 	u8			OFDM_max_index = 34, rf = (is2T) ? 2 : 1; /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
-	u8			indexforchannel = 0;/*get_right_chnl_place_for_iqk(p_hal_data->current_channel)*/
+	u8			indexforchannel = 0;/*get_right_chnl_place_for_iqk(hal_data->current_channel)*/
 	enum            _POWER_DEC_INC { POWER_DEC, POWER_INC };
 
-	struct _TXPWRTRACK_CFG	c;
+	struct txpwrtrack_cfg	c;
 
 
 	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
@@ -1087,64 +1097,64 @@ odm_txpowertracking_callback_thermal_meter(
 	};
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct rtl8192cd_priv	*priv = p_dm->priv;
+	struct rtl8192cd_priv	*priv = dm->priv;
 #endif
 
 	/* 4 2. Initilization ( 7 steps in total ) */
 
-	configure_txpower_track(p_dm, &c);
+	configure_txpower_track(dm, &c);
 
-	p_dm->rf_calibrate_info.txpowertracking_callback_cnt++; /* cosa add for debug */
-	p_dm->rf_calibrate_info.is_txpowertracking_init = true;
+	dm->rf_calibrate_info.txpowertracking_callback_cnt++; /* cosa add for debug */
+	dm->rf_calibrate_info.is_txpowertracking_init = true;
 
 #if (MP_DRIVER == 1)
-	p_dm->rf_calibrate_info.txpowertrack_control = p_hal_data->txpowertrack_control; /* <Kordan> We should keep updating the control variable according to HalData.
+	dm->rf_calibrate_info.txpowertrack_control = hal_data->txpowertrack_control; /* <Kordan> We should keep updating the control variable according to HalData.
      * <Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
-	p_dm->rf_calibrate_info.rega24 = 0x090e1317;
+	dm->rf_calibrate_info.rega24 = 0x090e1317;
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP) && defined(MP_TEST)
-	if ((OPMODE & WIFI_MP_STATE) || *(p_dm->p_mp_mode)) {
-		if (p_dm->priv->pshare->mp_txpwr_tracking == false)
+	if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
+		if (dm->priv->pshare->mp_txpwr_tracking == false)
 			return;
 	}
 #endif
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("===>odm_txpowertracking_callback_thermal_meter_8188e, p_dm->bb_swing_idx_cck_base: %d, p_dm->bb_swing_idx_ofdm_base: %d\n", p_rf_calibrate_info->bb_swing_idx_cck_base, p_rf_calibrate_info->bb_swing_idx_ofdm_base));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "===>odm_txpowertracking_callback_thermal_meter_8188e, dm->bb_swing_idx_cck_base: %d, dm->bb_swing_idx_ofdm_base: %d\n", cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base);
 	/*
-		if (!p_dm->rf_calibrate_info.tm_trigger) {
-			odm_set_rf_reg(p_dm, RF_PATH_A, c.thermal_reg_addr, BIT(17) | BIT(16), 0x3);
-			p_dm->rf_calibrate_info.tm_trigger = 1;
+		if (!dm->rf_calibrate_info.tm_trigger) {
+			odm_set_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, BIT(17) | BIT(16), 0x3);
+			dm->rf_calibrate_info.tm_trigger = 1;
 			return;
 		}
 	*/
-	thermal_value = (u8)odm_get_rf_reg(p_dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	if (!thermal_value || !p_dm->rf_calibrate_info.txpowertrack_control)
+	if (!thermal_value || !dm->rf_calibrate_info.txpowertrack_control)
 #else
-	if (!p_dm->rf_calibrate_info.txpowertrack_control)
+	if (!dm->rf_calibrate_info.txpowertrack_control)
 #endif
 		return;
 
 	/* 4 3. Initialize ThermalValues of rf_calibrate_info */
 
-	if (!p_dm->rf_calibrate_info.thermal_value) {
-		p_dm->rf_calibrate_info.thermal_value_lck = thermal_value;
-		p_dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+	if (!dm->rf_calibrate_info.thermal_value) {
+		dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+		dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
 	}
 
-	if (p_dm->rf_calibrate_info.is_reloadtxpowerindex)
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("reload ofdm index for band switch\n"));
+	if (dm->rf_calibrate_info.is_reloadtxpowerindex)
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "reload ofdm index for band switch\n");
 
 	/* 4 4. Calculate average thermal meter */
 
-	p_dm->rf_calibrate_info.thermal_value_avg[p_dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
-	p_dm->rf_calibrate_info.thermal_value_avg_index++;
-	if (p_dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)
-		p_dm->rf_calibrate_info.thermal_value_avg_index = 0;
+	dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
+	dm->rf_calibrate_info.thermal_value_avg_index++;
+	if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)
+		dm->rf_calibrate_info.thermal_value_avg_index = 0;
 
 	for (i = 0; i < c.average_thermal_num; i++) {
-		if (p_dm->rf_calibrate_info.thermal_value_avg[i]) {
-			thermal_value_avg += p_dm->rf_calibrate_info.thermal_value_avg[i];
+		if (dm->rf_calibrate_info.thermal_value_avg[i]) {
+			thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
 			thermal_value_avg_count++;
 		}
 	}
@@ -1154,124 +1164,121 @@ odm_txpowertracking_callback_thermal_meter(
 		thermal_value_avg += (thermal_value * 4);
 
 		thermal_value = (u8)(thermal_value_avg / (thermal_value_avg_count + 4));
-		p_rf_calibrate_info->thermal_value_delta = thermal_value - priv->pmib->dot11RFEntry.ther;
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("AVG Thermal Meter = 0x%x\n", thermal_value));
+		cali_info->thermal_value_delta = thermal_value - priv->pmib->dot11RFEntry.ther;
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
 	}
 
 	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
 
-	delta	  = (thermal_value > p_dm->rf_calibrate_info.thermal_value) ? (thermal_value - p_dm->rf_calibrate_info.thermal_value) : (p_dm->rf_calibrate_info.thermal_value - thermal_value);
-	delta_LCK = (thermal_value > p_dm->rf_calibrate_info.thermal_value_lck) ? (thermal_value - p_dm->rf_calibrate_info.thermal_value_lck) : (p_dm->rf_calibrate_info.thermal_value_lck - thermal_value);
-	delta_IQK = (thermal_value > p_dm->rf_calibrate_info.thermal_value_iqk) ? (thermal_value - p_dm->rf_calibrate_info.thermal_value_iqk) : (p_dm->rf_calibrate_info.thermal_value_iqk - thermal_value);
+	delta	  = (thermal_value > dm->rf_calibrate_info.thermal_value) ? (thermal_value - dm->rf_calibrate_info.thermal_value) : (dm->rf_calibrate_info.thermal_value - thermal_value);
+	delta_LCK = (thermal_value > dm->rf_calibrate_info.thermal_value_lck) ? (thermal_value - dm->rf_calibrate_info.thermal_value_lck) : (dm->rf_calibrate_info.thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > dm->rf_calibrate_info.thermal_value_iqk) ? (thermal_value - dm->rf_calibrate_info.thermal_value_iqk) : (dm->rf_calibrate_info.thermal_value_iqk - thermal_value);
 
 	/* 4 6. If necessary, do LCK. */
-	if (!(p_dm->support_ic_type & ODM_RTL8821)) {
-		/*if((delta_LCK > p_hal_data->delta_lck) && (p_hal_data->delta_lck != 0))*/
-		if ((delta_LCK >= c.threshold_iqk) && (!p_iqk_info->rfk_forbidden)) {
+	if (!(dm->support_ic_type & ODM_RTL8821)) {
+		/*if((delta_LCK > hal_data->delta_lck) && (hal_data->delta_lck != 0))*/
+		if ((delta_LCK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
 			/*Delta temperature is equal to or larger than 20 centigrade.*/
-			p_dm->rf_calibrate_info.thermal_value_lck = thermal_value;
-			(*c.phy_lc_calibrate)(p_dm);
+			dm->rf_calibrate_info.thermal_value_lck = thermal_value;
+			(*c.phy_lc_calibrate)(dm);
 		}
 	}
 
 	/* 3 7. If necessary, move the index of swing table to adjust Tx power. */
 
-	if (delta > 0 && p_dm->rf_calibrate_info.txpowertrack_control) {
+	if (delta > 0 && dm->rf_calibrate_info.txpowertrack_control) {
 
-		delta = (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - p_dm->priv->pmib->dot11RFEntry.ther) : (p_dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
 
 		/* 4 7.1 The Final Power index = BaseIndex + power_index_offset */
 
-		if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) {
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
 			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_INC, index_mapping_NUM_88E, delta);
-			p_dm->rf_calibrate_info.delta_power_index_last = p_dm->rf_calibrate_info.delta_power_index;
-			p_dm->rf_calibrate_info.delta_power_index =  delta_swing_table_idx[POWER_INC][offset];
+			dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
+			dm->rf_calibrate_info.delta_power_index =  delta_swing_table_idx[POWER_INC][offset];
 
 		} else {
 
 			CALCULATE_SWINGTALBE_OFFSET(offset, POWER_DEC, index_mapping_NUM_88E, delta);
-			p_dm->rf_calibrate_info.delta_power_index_last = p_dm->rf_calibrate_info.delta_power_index;
-			p_dm->rf_calibrate_info.delta_power_index = (-1) * delta_swing_table_idx[POWER_DEC][offset];
+			dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
+			dm->rf_calibrate_info.delta_power_index = (-1) * delta_swing_table_idx[POWER_DEC][offset];
 		}
 
-		if (p_dm->rf_calibrate_info.delta_power_index == p_dm->rf_calibrate_info.delta_power_index_last)
-			p_dm->rf_calibrate_info.power_index_offset = 0;
+		if (dm->rf_calibrate_info.delta_power_index == dm->rf_calibrate_info.delta_power_index_last)
+			dm->rf_calibrate_info.power_index_offset = 0;
 		else
-			p_dm->rf_calibrate_info.power_index_offset = p_dm->rf_calibrate_info.delta_power_index - p_dm->rf_calibrate_info.delta_power_index_last;
+			dm->rf_calibrate_info.power_index_offset = dm->rf_calibrate_info.delta_power_index - dm->rf_calibrate_info.delta_power_index_last;
 
 		for (i = 0; i < rf; i++)
-			p_dm->rf_calibrate_info.OFDM_index[i] = p_rf_calibrate_info->bb_swing_idx_ofdm_base + p_dm->rf_calibrate_info.power_index_offset;
-		p_dm->rf_calibrate_info.CCK_index = p_rf_calibrate_info->bb_swing_idx_cck_base + p_dm->rf_calibrate_info.power_index_offset;
+			dm->rf_calibrate_info.OFDM_index[i] = cali_info->bb_swing_idx_ofdm_base + dm->rf_calibrate_info.power_index_offset;
+		dm->rf_calibrate_info.CCK_index = cali_info->bb_swing_idx_cck_base + dm->rf_calibrate_info.power_index_offset;
 
-		p_rf_calibrate_info->bb_swing_idx_cck = p_dm->rf_calibrate_info.CCK_index;
-		p_rf_calibrate_info->bb_swing_idx_ofdm[RF_PATH_A] = p_dm->rf_calibrate_info.OFDM_index[RF_PATH_A];
+		cali_info->bb_swing_idx_cck = dm->rf_calibrate_info.CCK_index;
+		cali_info->bb_swing_idx_ofdm[RF_PATH_A] = dm->rf_calibrate_info.OFDM_index[RF_PATH_A];
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", p_rf_calibrate_info->bb_swing_idx_cck, p_rf_calibrate_info->bb_swing_idx_cck_base, p_dm->rf_calibrate_info.power_index_offset));
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("The 'OFDM' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", p_rf_calibrate_info->bb_swing_idx_ofdm[RF_PATH_A], p_rf_calibrate_info->bb_swing_idx_ofdm_base, p_dm->rf_calibrate_info.power_index_offset));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, dm->rf_calibrate_info.power_index_offset);
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "The 'OFDM' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base, dm->rf_calibrate_info.power_index_offset);
 
 		/* 4 7.1 Handle boundary conditions of index. */
 
 
 		for (i = 0; i < rf; i++) {
-			if (p_dm->rf_calibrate_info.OFDM_index[i] > OFDM_max_index)
-				p_dm->rf_calibrate_info.OFDM_index[i] = OFDM_max_index;
-			else if (p_dm->rf_calibrate_info.OFDM_index[i] < 0)
-				p_dm->rf_calibrate_info.OFDM_index[i] = 0;
+			if (dm->rf_calibrate_info.OFDM_index[i] > OFDM_max_index)
+				dm->rf_calibrate_info.OFDM_index[i] = OFDM_max_index;
+			else if (dm->rf_calibrate_info.OFDM_index[i] < 0)
+				dm->rf_calibrate_info.OFDM_index[i] = 0;
 		}
 
-		if (p_dm->rf_calibrate_info.CCK_index > c.swing_table_size_cck - 1)
-			p_dm->rf_calibrate_info.CCK_index = c.swing_table_size_cck - 1;
-		else if (p_dm->rf_calibrate_info.CCK_index < 0)
-			p_dm->rf_calibrate_info.CCK_index = 0;
+		if (dm->rf_calibrate_info.CCK_index > c.swing_table_size_cck - 1)
+			dm->rf_calibrate_info.CCK_index = c.swing_table_size_cck - 1;
+		else if (dm->rf_calibrate_info.CCK_index < 0)
+			dm->rf_calibrate_info.CCK_index = 0;
 	} else {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("The thermal meter is unchanged or TxPowerTracking OFF: thermal_value: %d, p_dm->rf_calibrate_info.thermal_value: %d)\n", thermal_value, p_dm->rf_calibrate_info.thermal_value));
-		p_dm->rf_calibrate_info.power_index_offset = 0;
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"The thermal meter is unchanged or TxPowerTracking OFF: thermal_value: %d, dm->rf_calibrate_info.thermal_value: %d)\n", thermal_value, dm->rf_calibrate_info.thermal_value);
+		dm->rf_calibrate_info.power_index_offset = 0;
 	}
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n", p_dm->rf_calibrate_info.CCK_index, p_rf_calibrate_info->bb_swing_idx_cck_base));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.CCK_index, cali_info->bb_swing_idx_cck_base);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index: %d\n", p_dm->rf_calibrate_info.OFDM_index[RF_PATH_A], p_rf_calibrate_info->bb_swing_idx_ofdm_base));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.OFDM_index[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base);
 
-	if (p_dm->rf_calibrate_info.power_index_offset != 0 && p_dm->rf_calibrate_info.txpowertrack_control) {
+	if (dm->rf_calibrate_info.power_index_offset != 0 && dm->rf_calibrate_info.txpowertrack_control) {
 		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
 
-		p_dm->rf_calibrate_info.is_tx_power_changed = true; /* Always true after Tx Power is adjusted by power tracking. */
+		dm->rf_calibrate_info.is_tx_power_changed = true; /* Always true after Tx Power is adjusted by power tracking. */
 		/*  */
 		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
 		/* to increase TX power. Otherwise, EVM will be bad. */
 		/*  */
 		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
-		if (thermal_value > p_dm->rf_calibrate_info.thermal_value) {
-			/* ODM_RT_TRACE(p_dm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, */
-			/*	("Temperature Increasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
-			/*	p_dm->rf_calibrate_info.power_index_offset, delta, thermal_value, p_hal_data->eeprom_thermal_meter, p_dm->rf_calibrate_info.thermal_value)); */
-		} else if (thermal_value < p_dm->rf_calibrate_info.thermal_value) { /* Low temperature */
-			/* ODM_RT_TRACE(p_dm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, */
-			/*	("Temperature Decreasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
-			/*		p_dm->rf_calibrate_info.power_index_offset, delta, thermal_value, p_hal_data->eeprom_thermal_meter, p_dm->rf_calibrate_info.thermal_value)); */
+		if (thermal_value > dm->rf_calibrate_info.thermal_value) {
+			/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK, */
+			/*	"Temperature Increasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
+			/*	dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
+		} else if (thermal_value < dm->rf_calibrate_info.thermal_value) { /* Low temperature */
+			/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK, */
+			/*	"Temperature Decreasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
+			/*		dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
 		}
-		if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther)
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
 		{
-			/*				ODM_RT_TRACE(p_dm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("Temperature(%d) hugher than PG value(%d), increases the power by tx_agc\n", thermal_value, p_hal_data->eeprom_thermal_meter)); */
-			(*c.odm_tx_pwr_track_set_pwr)(p_dm, TXAGC, 0, 0);
+			/*				RF_DBG(dm,DBG_RF_TX_PWR_TRACK,"Temperature(%d) hugher than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
+			(*c.odm_tx_pwr_track_set_pwr)(dm, TXAGC, 0, 0);
 		} else {
-			/*			ODM_RT_TRACE(p_dm,ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,("Temperature(%d) lower than PG value(%d), increases the power by tx_agc\n", thermal_value, p_hal_data->eeprom_thermal_meter)); */
-			(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, RF_PATH_A, indexforchannel);
+			/*			RF_DBG(dm,DBG_RF_TX_PWR_TRACK,"Temperature(%d) lower than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
+			(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_A, indexforchannel);
 			if (is2T)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, RF_PATH_B, indexforchannel);
+				(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_B, indexforchannel);
 		}
 
-		p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->bb_swing_idx_cck;
-		p_rf_calibrate_info->bb_swing_idx_ofdm_base = p_rf_calibrate_info->bb_swing_idx_ofdm[RF_PATH_A];
-		p_dm->rf_calibrate_info.thermal_value = thermal_value;
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;
+		cali_info->bb_swing_idx_ofdm_base = cali_info->bb_swing_idx_ofdm[RF_PATH_A];
+		dm->rf_calibrate_info.thermal_value = thermal_value;
 
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("<===dm_TXPowerTrackingCallback_ThermalMeter_8188E\n"));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===dm_TXPowerTrackingCallback_ThermalMeter_8188E\n");
 
-	p_dm->rf_calibrate_info.tx_powercount = 0;
+	dm->rf_calibrate_info.tx_powercount = 0;
 }
 
 /* 3============================================================
@@ -1280,7 +1287,7 @@ odm_txpowertracking_callback_thermal_meter(
 
 void
 odm_reset_iqk_result(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
 	return;
@@ -1307,47 +1314,47 @@ u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
 
 void
 odm_iq_calibrate(
-	struct PHY_DM_STRUCT	*p_dm
+	struct dm_struct	*dm
 )
 {
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
 
-	if ((p_dm->is_linked) && (!p_iqk_info->rfk_forbidden)) {
-		if ((*p_dm->p_channel != p_dm->pre_channel) && (!*p_dm->p_is_scan_in_process)) {
-			p_dm->pre_channel = *p_dm->p_channel;
-			p_dm->linked_interval = 0;
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		if ((*dm->channel != dm->pre_channel) && (!*dm->is_scan_in_process)) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
 		}
 
-		if (p_dm->linked_interval < 3)
-			p_dm->linked_interval++;
+		if (dm->linked_interval < 3)
+			dm->linked_interval++;
 
-		if (p_dm->linked_interval == 2)
-			halrf_iqk_trigger(p_dm, false);
+		if (dm->linked_interval == 2)
+			halrf_iqk_trigger(dm, false);
 	} else
-		p_dm->linked_interval = 0;
+		dm->linked_interval = 0;
 
 }
 
-void phydm_rf_init(void		*p_dm_void)
+void phydm_rf_init(void		*dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	odm_txpowertracking_init(p_dm);
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	odm_txpowertracking_init(dm);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		phy_iq_calibrate_8814a_init(p_dm);
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
 #endif
 #endif
 
 }
 
-void phydm_rf_watchdog(void		*p_dm_void)
+void phydm_rf_watchdog(void		*dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	odm_txpowertracking_check(p_dm);
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-		odm_iq_calibrate(p_dm);
+	odm_txpowertracking_check(dm);
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_iq_calibrate(dm);
 #endif
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.h
index ee34c2125d40..6309443cffd9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ap.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -13,8 +14,8 @@
  *
  *****************************************************************************/
 
-#ifndef __HAL_PHY_RF_H__
-#define __HAL_PHY_RF_H__
+#ifndef __HALPHYRF_H__
+#define __HALPHYRF_H__
 
 #include "halrf/halrf_powertracking_ap.h"
 #include "halrf/halrf_kfree.h"
@@ -31,6 +32,22 @@
 	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
 #endif
 
+#if (RTL8195B_SUPPORT == 1)
+//	#include "halrf/rtl8195b/halrf.h"
+	#include "halrf/rtl8195b/halrf_iqk_8195b.h"
+	#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
+	#include "halrf/rtl8195b/halrf_dpk_8195b.h"
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	#include "halrf/rtl8198f/halrf_iqk_8198f.h"
+	#include "halrf/rtl8198f/halrf_dpk_8198f.h"
+#endif
+
+#if (RTL8814B_SUPPORT == 1)
+	#include "halrf/rtl8814b/halrf_iqk_8814b.h"
+#endif
+
 enum pwrtrack_method {
 	BBSWING,
 	TXAGC,
@@ -45,9 +62,9 @@ typedef void	(*func_lck)(void *);
 typedef void	(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
 typedef void	(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
 typedef void	(*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_all_swing_ex)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
 
-
-struct _TXPWRTRACK_CFG {
+struct txpwrtrack_cfg {
 	u8		swing_table_size_cck;
 	u8		swing_table_size_ofdm;
 	u8		threshold_iqk;
@@ -60,44 +77,45 @@ struct _TXPWRTRACK_CFG {
 	func_lck		phy_lc_calibrate;
 	func_swing	get_delta_swing_table;
 	func_swing8814only	get_delta_swing_table8814only;
-	func_all_swing	get_delta_all_swing_table;
+	func_all_swing		get_delta_all_swing_table;
+	func_all_swing_ex	get_delta_all_swing_table_ex;
 };
 
 void
 configure_txpower_track(
-	void		*p_dm_void,
-	struct _TXPWRTRACK_CFG	*p_config
+	void		*dm_void,
+	struct txpwrtrack_cfg	*config
 );
 
 
 void
 odm_txpowertracking_callback_thermal_meter(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 #if (RTL8192E_SUPPORT == 1)
 void
 odm_txpowertracking_callback_thermal_meter_92e(
-	void		*p_dm_void
+	void		*dm_void
 );
 #endif
 
 #if (RTL8814A_SUPPORT == 1)
 void
 odm_txpowertracking_callback_thermal_meter_jaguar_series2(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 #elif ODM_IC_11AC_SERIES_SUPPORT
 void
 odm_txpowertracking_callback_thermal_meter_jaguar_series(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 #elif (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
 void
 odm_txpowertracking_callback_thermal_meter_jaguar_series3(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 #endif
@@ -109,14 +127,14 @@ odm_txpowertracking_callback_thermal_meter_jaguar_series3(
 
 void
 odm_reset_iqk_result(
-	void		*p_dm_void
+	void		*dm_void
 );
 u8
 odm_get_right_chnl_place_for_iqk(
 	u8 chnl
 );
 
-void phydm_rf_init(void		*p_dm_void);
-void phydm_rf_watchdog(void		*p_dm_void);
+void phydm_rf_init(void		*dm_void);
+void phydm_rf_watchdog(void		*dm_void);
 
-#endif	/*  #ifndef __HAL_PHY_RF_H__ */
+#endif	/*#ifndef __HALPHYRF_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.c
index f9c031fdc791..8206d5d9fee7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,257 +9,442 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
-	do {\
-		for (_offset = 0; _offset < _size; _offset++) { \
-			\
-			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
-				\
-				if (_offset != 0)\
-					_offset--;\
-				break;\
-			} \
-		}			\
-		if (_offset >= _size)\
-			_offset = _size-1;\
+#define CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal)\
+	do {                                                                   \
+		u32 __offset = (u32)_offset;                                   \
+		u32 __size = (u32)_size;                                       \
+		for (__offset = 0; __offset < __size; __offset++) {            \
+			if (_delta_thermal <                                   \
+				thermal_threshold[_direction][__offset]) {     \
+				if (__offset != 0)                             \
+					__offset--;                            \
+				break;                                         \
+			}                                                      \
+		}                                                              \
+		if (__offset >= __size)                                        \
+			__offset = __size - 1;                                 \
 	} while (0)
 
-void configure_txpower_track(
-	void					*p_dm_void,
-	struct _TXPWRTRACK_CFG	*p_config
-)
+void configure_txpower_track(void *dm_void, struct txpwrtrack_cfg *config)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 #if RTL8192E_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8192E)
-		configure_txpower_track_8192e(p_config);
+	if (dm->support_ic_type == ODM_RTL8192E)
+		configure_txpower_track_8192e(config);
 #endif
 #if RTL8821A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8821)
-		configure_txpower_track_8821a(p_config);
+	if (dm->support_ic_type == ODM_RTL8821)
+		configure_txpower_track_8821a(config);
 #endif
 #if RTL8812A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8812)
-		configure_txpower_track_8812a(p_config);
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
 #endif
 #if RTL8188E_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8188E)
-		configure_txpower_track_8188e(p_config);
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
 #endif
 
 #if RTL8723B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8723B)
-		configure_txpower_track_8723b(p_config);
+	if (dm->support_ic_type == ODM_RTL8723B)
+		configure_txpower_track_8723b(config);
 #endif
 
 #if RTL8814A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8814A)
-		configure_txpower_track_8814a(p_config);
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
 #endif
 
 #if RTL8703B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8703B)
-		configure_txpower_track_8703b(p_config);
+	if (dm->support_ic_type == ODM_RTL8703B)
+		configure_txpower_track_8703b(config);
 #endif
 
 #if RTL8188F_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8188F)
-		configure_txpower_track_8188f(p_config);
+	if (dm->support_ic_type == ODM_RTL8188F)
+		configure_txpower_track_8188f(config);
 #endif
 #if RTL8723D_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8723D)
-		configure_txpower_track_8723d(p_config);
+	if (dm->support_ic_type == ODM_RTL8723D)
+		configure_txpower_track_8723d(config);
 #endif
-/* JJ ADD 20161014 */
+/*@ JJ ADD 20161014 */
 #if RTL8710B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8710B)
-		configure_txpower_track_8710b(p_config);
+	if (dm->support_ic_type == ODM_RTL8710B)
+		configure_txpower_track_8710b(config);
 #endif
-
 #if RTL8822B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8822B)
-		configure_txpower_track_8822b(p_config);
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
 #endif
 #if RTL8821C_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8821C)
-		configure_txpower_track_8821c(p_config);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		configure_txpower_track_8821c(config);
 #endif
 
+#if RTL8192F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192F)
+		configure_txpower_track_8192f(config);
+#endif
 }
 
-/* **********************************************************************
+/*@ **********************************************************************
  * <20121113, Kordan> This function should be called when tx_agc changed.
  * Otherwise the previous compensation is gone, because we record the
  * delta of temperature between two TxPowerTracking watch dogs.
  *
  * NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
  * need to call this function.
- * ********************************************************************** */
-void
-odm_clear_txpowertracking_state(
-	void					*p_dm_void
-)
+ * **********************************************************************
+ */
+void odm_clear_txpowertracking_state(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
-	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
-#else
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(p_dm->adapter);
-#endif
-	u8			p = 0;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	u8 p = 0;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
 
-	p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->default_cck_index;
-	p_rf_calibrate_info->bb_swing_idx_cck = p_rf_calibrate_info->default_cck_index;
-	p_dm->rf_calibrate_info.CCK_index = 0;
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+	dm->rf_calibrate_info.CCK_index = 0;
 
 	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
-		p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->bb_swing_idx_ofdm[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->OFDM_index[p] = p_rf_calibrate_info->default_ofdm_index;
-
-		p_rf_calibrate_info->power_index_offset[p] = 0;
-		p_rf_calibrate_info->delta_power_index[p] = 0;
-		p_rf_calibrate_info->delta_power_index_last[p] = 0;
+		cali_info->bb_swing_idx_ofdm_base[p]
+						= cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+
+		cali_info->power_index_offset[p] = 0;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+
+		/* Initial Mix mode power tracking*/
+		cali_info->absolute_ofdm_swing_idx[p] = 0;
+		cali_info->remnant_ofdm_swing_idx[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+	/* Initial Mix mode power tracking*/
+	cali_info->modify_tx_agc_flag_path_a = false;
+	cali_info->modify_tx_agc_flag_path_b = false;
+	cali_info->modify_tx_agc_flag_path_c = false;
+	cali_info->modify_tx_agc_flag_path_d = false;
+	cali_info->remnant_cck_swing_idx = 0;
+	cali_info->thermal_value = rf->eeprom_thermal;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->modify_tx_agc_value_ofdm = 0;
+}
 
-		p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = 0;    /* Initial Mix mode power tracking*/
-		p_rf_calibrate_info->remnant_ofdm_swing_idx[p] = 0;
-		p_rf_calibrate_info->kfree_offset[p] = 0;
+void odm_get_tracking_table(void *dm_void, u8 thermal_value, u8 delta)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	struct txpwrtrack_cfg c = {0};
+
+	u8 p;
+	/* 4 1. TWO tables decide the final index of OFDM/CCK swing table. */
+	u8 *pwrtrk_tab_up_a = NULL;
+	u8 *pwrtrk_tab_down_a = NULL;
+	u8 *pwrtrk_tab_up_b = NULL;
+	u8 *pwrtrk_tab_down_b = NULL;
+	/*for 8814 add by Yu Chen*/
+	u8 *pwrtrk_tab_up_c = NULL;
+	u8 *pwrtrk_tab_down_c = NULL;
+	u8 *pwrtrk_tab_up_d = NULL;
+	u8 *pwrtrk_tab_down_d = NULL;
+	/*for Xtal Offset by James.Tung*/
+	s8 *xtal_tab_up = NULL;
+	s8 *xtal_tab_down = NULL;
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_swing_table)(dm,
+				   (u8 **)&pwrtrk_tab_up_a,
+				   (u8 **)&pwrtrk_tab_down_a,
+				   (u8 **)&pwrtrk_tab_up_b,
+				   (u8 **)&pwrtrk_tab_down_b);
+
+	if (dm->support_ic_type & ODM_RTL8814A) /*for 8814 path C & D*/
+		(*c.get_delta_swing_table8814only)(dm,
+						   (u8 **)&pwrtrk_tab_up_c,
+						   (u8 **)&pwrtrk_tab_down_c,
+						   (u8 **)&pwrtrk_tab_up_d,
+						   (u8 **)&pwrtrk_tab_down_d);
+	/*for Xtal Offset*/
+	if (dm->support_ic_type &
+	    (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F))
+		(*c.get_delta_swing_xtal_table)(dm,
+						(s8 **)&xtal_tab_up,
+						(s8 **)&xtal_tab_down);
+
+	if (thermal_value > rf->eeprom_thermal) {
+		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+			/*recording power index offset*/
+			cali_info->delta_power_index_last[p] =
+					cali_info->delta_power_index[p];
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "******Temp is higher******\n");
+			switch (p) {
+			case RF_PATH_B:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_up_b[%d] = %d\n", delta,
+				       pwrtrk_tab_up_b[delta]);
+
+				cali_info->delta_power_index[p] =
+							pwrtrk_tab_up_b[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+							pwrtrk_tab_up_b[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_B] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+
+			case RF_PATH_C:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_up_c[%d] = %d\n", delta,
+				       pwrtrk_tab_up_c[delta]);
+
+				cali_info->delta_power_index[p] =
+							pwrtrk_tab_up_c[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+							pwrtrk_tab_up_c[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_C] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+
+			case RF_PATH_D:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_up_d[%d] = %d\n", delta,
+				       pwrtrk_tab_up_d[delta]);
+
+				cali_info->delta_power_index[p] =
+							pwrtrk_tab_up_d[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+							pwrtrk_tab_up_d[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_D] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+
+			default:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_up_a[%d] = %d\n", delta,
+				       pwrtrk_tab_up_a[delta]);
+
+				cali_info->delta_power_index[p] =
+							pwrtrk_tab_up_a[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+							pwrtrk_tab_up_a[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_A] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+			}
+		}
+		/* @JJ ADD 20161014 */
+		/*Save xtal_offset from Xtal table*/
+		if (dm->support_ic_type &
+		    (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B |
+		    ODM_RTL8192F)) {
+			/*recording last Xtal offset*/
+			cali_info->xtal_offset_last = cali_info->xtal_offset;
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "[Xtal] xtal_tab_up[%d] = %d\n",
+			       delta, xtal_tab_up[delta]);
+			cali_info->xtal_offset = xtal_tab_up[delta];
+			if (cali_info->xtal_offset_last != xtal_tab_up[delta])
+				cali_info->xtal_offset_eanble = 1;
+		}
+	} else {
+		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+			/*recording power index offset*/
+			cali_info->delta_power_index_last[p] =
+						cali_info->delta_power_index[p];
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "******Temp is lower******\n");
+			switch (p) {
+			case RF_PATH_B:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_down_b[%d] = %d\n", delta,
+				       pwrtrk_tab_down_b[delta]);
+				cali_info->delta_power_index[p] =
+						-1 * pwrtrk_tab_down_b[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+						-1 * pwrtrk_tab_down_b[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_B] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+
+			case RF_PATH_C:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_down_c[%d] = %d\n", delta,
+				       pwrtrk_tab_down_c[delta]);
+				cali_info->delta_power_index[p] =
+						-1 * pwrtrk_tab_down_c[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+						-1 * pwrtrk_tab_down_c[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_C] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+
+			case RF_PATH_D:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_down_d[%d] = %d\n", delta,
+				       pwrtrk_tab_down_d[delta]);
+				cali_info->delta_power_index[p] =
+						-1 * pwrtrk_tab_down_d[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+						-1 * pwrtrk_tab_down_d[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_D] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+
+			default:
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "pwrtrk_tab_down_a[%d] = %d\n", delta,
+				       pwrtrk_tab_down_a[delta]);
+				cali_info->delta_power_index[p] =
+						-1 * pwrtrk_tab_down_a[delta];
+				cali_info->absolute_ofdm_swing_idx[p] =
+						-1 * pwrtrk_tab_down_a[delta];
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "absolute_ofdm_swing_idx[PATH_A] = %d\n",
+				       cali_info->absolute_ofdm_swing_idx[p]);
+				break;
+			}
+		}
+		/* @JJ ADD 20161014 */
+		if (dm->support_ic_type &
+		    (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B |
+		    ODM_RTL8192F)) {
+			/*recording last Xtal offset*/
+			cali_info->xtal_offset_last = cali_info->xtal_offset;
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "[Xtal] xtal_tab_down[%d] = %d\n", delta,
+			       xtal_tab_down[delta]);
+			/*Save xtal_offset from Xtal table*/
+			cali_info->xtal_offset = xtal_tab_down[delta];
+			if (cali_info->xtal_offset_last != xtal_tab_down[delta])
+				cali_info->xtal_offset_eanble = 1;
+		}
 	}
+}
 
-	p_rf_calibrate_info->modify_tx_agc_flag_path_a = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->modify_tx_agc_flag_path_b = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->modify_tx_agc_flag_path_c = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->modify_tx_agc_flag_path_d = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->remnant_cck_swing_idx = 0;
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	p_rf_calibrate_info->thermal_value = rtlefu->eeprom_thermalmeter;
-#else
-	p_rf_calibrate_info->thermal_value = p_hal_data->eeprom_thermal_meter;
-#endif
+void odm_pwrtrk_method(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 p, idxforchnl = 0;
+
+	struct txpwrtrack_cfg c = {0};
 
-	p_rf_calibrate_info->modify_tx_agc_value_cck = 0;			/* modify by Mingzhi.Guo */
-	p_rf_calibrate_info->modify_tx_agc_value_ofdm = 0;		/* modify by Mingzhi.Guo */
+	configure_txpower_track(dm, &c);
 
+	if (dm->support_ic_type &
+		(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8821 | ODM_RTL8812 |
+		ODM_RTL8723B | ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8188F |
+		ODM_RTL8822B | ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B |
+		ODM_RTL8192F)) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "***Enter PwrTrk MIX_MODE***\n");
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+	} else {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "***Enter PwrTrk BBSWING_MODE***\n");
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			(*c.odm_tx_pwr_track_set_pwr)
+				(dm, BBSWING, p, idxforchnl);
+	}
 }
 
-void
-odm_txpowertracking_callback_thermal_meter(
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	void	*p_dm_void
+void odm_txpowertracking_callback_thermal_meter(struct dm_struct *dm)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void odm_txpowertracking_callback_thermal_meter(void *dm_void)
 #else
-	struct _ADAPTER	*adapter
+void odm_txpowertracking_callback_thermal_meter(void *adapter)
 #endif
-)
 {
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
-	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
-	void *adapter = p_dm->adapter;
-#elif !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->odmpriv;
-#endif
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
 
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	struct	_IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
 
-	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
-	s8			diff_DPK[4] = {0};
-	u8			thermal_value_avg_count = 0;
-	u32			thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
+	u8 thermal_value = 0, delta, delta_lck, delta_iqk, p = 0, i = 0;
+	u8 thermal_value_avg_count = 0;
+	u32 thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
 
-	u8			OFDM_min_index = 0;  /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
-	u8			indexforchannel = 0; /* get_right_chnl_place_for_iqk(p_hal_data->current_channel) */
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	u8			power_tracking_type = 0;	/* no specify type */
-#else
-	u8			power_tracking_type = p_hal_data->rf_power_tracking_type;
+	/* OFDM BB Swing should be less than +3.0dB, required by Arthur */
+#if 0
+	u8 OFDM_min_index = 0;
 #endif
-	u8			xtal_offset_eanble = 0;
-	s8			thermal_value_temp = 0;
-
-	struct _TXPWRTRACK_CFG	c = {0};
+#if 0
+	/* get_right_chnl_place_for_iqk(hal_data->current_channel) */
+#endif
+	u8 power_tracking_type = rf->pwt_type;
+	s8 thermal_value_temp = 0;
 
-	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
-	u8			*delta_swing_table_idx_tup_a = NULL;
-	u8			*delta_swing_table_idx_tdown_a = NULL;
-	u8			*delta_swing_table_idx_tup_b = NULL;
-	u8			*delta_swing_table_idx_tdown_b = NULL;
-	/*for 8814 add by Yu Chen*/
-	u8			*delta_swing_table_idx_tup_c = NULL;
-	u8			*delta_swing_table_idx_tdown_c = NULL;
-	u8			*delta_swing_table_idx_tup_d = NULL;
-	u8			*delta_swing_table_idx_tdown_d = NULL;
-	/*for Xtal Offset by James.Tung*/
-	s8			*delta_swing_table_xtal_up = NULL;
-	s8			*delta_swing_table_xtal_down = NULL;
+	struct txpwrtrack_cfg c = {0};
 
-	/* 4 2. Initilization ( 7 steps in total ) */
+	/* @4 2. Initialization ( 7 steps in total ) */
 
-	configure_txpower_track(p_dm, &c);
+	configure_txpower_track(dm, &c);
 
-	(*c.get_delta_swing_table)(p_dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
-		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+	cali_info->txpowertracking_callback_cnt++;
+	cali_info->is_txpowertracking_init = true;
 
-	if (p_dm->support_ic_type & ODM_RTL8814A)	/*for 8814 path C & D*/
-		(*c.get_delta_swing_table8814only)(p_dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
-			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
-	/* JJ ADD 20161014 */
-	if (p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B))	/*for Xtal Offset*/
-		(*c.get_delta_swing_xtal_table)(p_dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "\n\n\n===>%s bbsw_idx_cck_base=%d\n",
+	       __func__, cali_info->bb_swing_idx_cck_base);
 
-	p_rf_calibrate_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
-	p_rf_calibrate_info->is_txpowertracking_init = true;
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "bbsw_idx_ofdm_base[A]=%d default_ofdm_idx=%d\n",
+	       cali_info->bb_swing_idx_ofdm_base[RF_PATH_A],
+	       cali_info->default_ofdm_index);
 
-	/*p_rf_calibrate_info->txpowertrack_control = p_hal_data->txpowertrack_control;
-	<Kordan> We should keep updating the control variable according to HalData.
-	<Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-#if (MP_DRIVER == 1)
-	p_rf_calibrate_info->rega24 = 0x090e1317;
-#endif
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	if (*(p_dm->p_mp_mode) == true)
-		p_rf_calibrate_info->rega24 = 0x090e1317;
-#endif
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("===>odm_txpowertracking_callback_thermal_meter\n p_rf_calibrate_info->bb_swing_idx_cck_base: %d, p_rf_calibrate_info->bb_swing_idx_ofdm_base[A]: %d, p_rf_calibrate_info->default_ofdm_index: %d\n",
-		p_rf_calibrate_info->bb_swing_idx_cck_base, p_rf_calibrate_info->bb_swing_idx_ofdm_base[RF_PATH_A], p_rf_calibrate_info->default_ofdm_index));
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("p_rf_calibrate_info->txpowertrack_control=%d,  rtlefu->eeprom_thermalmeter %d\n", p_rf_calibrate_info->txpowertrack_control,  rtlefu->eeprom_thermalmeter));
-#else
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("p_rf_calibrate_info->txpowertrack_control=%d,  p_hal_data->eeprom_thermal_meter %d\n", p_rf_calibrate_info->txpowertrack_control,  p_hal_data->eeprom_thermal_meter));
-#endif
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "cali_info->txpowertrack_control=%d, rf->eeprom_thermal %d\n",
+	       cali_info->txpowertrack_control, rf->eeprom_thermal);
 
-	thermal_value = (u8)odm_get_rf_reg(p_dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+	 /* 0x42: RF Reg[15:10] 88E */
+	thermal_value =
+		(u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);
 
-	thermal_value_temp = thermal_value + phydm_get_thermal_offset(p_dm);
+	thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("thermal_value_temp(%d) = thermal_value(%d) + power_trim_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(p_dm)));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "thermal_value_temp(%d) = ther_value(%d) + pwr_trim_ther(%d)\n",
+	       thermal_value_temp, thermal_value,
+	       phydm_get_thermal_offset(dm));
 
 	if (thermal_value_temp > 63)
 		thermal_value = 63;
@@ -267,563 +453,401 @@ odm_txpowertracking_callback_thermal_meter(
 	else
 		thermal_value = thermal_value_temp;
 
-	/*add log by zhao he, check c80/c94/c14/ca0 value*/
-	if (p_dm->support_ic_type == ODM_RTL8723D) {
-		regc80 = odm_get_bb_reg(p_dm, 0xc80, MASKDWORD);
-		regcd0 = odm_get_bb_reg(p_dm, 0xcd0, MASKDWORD);
-		regcd4 = odm_get_bb_reg(p_dm, 0xcd4, MASKDWORD);
-		regab4 = odm_get_bb_reg(p_dm, 0xab4, 0x000007FF);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4));
-	}
-	/* JJ ADD 20161014 */
-	if (p_dm->support_ic_type == ODM_RTL8710B) {
-		regc80 = odm_get_bb_reg(p_dm, 0xc80, MASKDWORD);
-		regcd0 = odm_get_bb_reg(p_dm, 0xcd0, MASKDWORD);
-		regcd4 = odm_get_bb_reg(p_dm, 0xcd4, MASKDWORD);
-		regab4 = odm_get_bb_reg(p_dm, 0xab4, 0x000007FF);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4));
+	/*@add log by zhao he, check c80/c94/c14/ca0 value*/
+	if (dm->support_ic_type &
+	    (ODM_RTL8723D | ODM_RTL8710B)) {
+		regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, R_0xab4, 0x000007FF);
+		RF_DBG(dm, DBG_RF_IQK,
+		       "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n",
+		       regc80, regcd0, regcd4, regab4);
 	}
 
-	if (!p_rf_calibrate_info->txpowertrack_control)
+	if (!cali_info->txpowertrack_control)
 		return;
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	if (rtlefu->eeprom_thermalmeter == 0xff) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no pg, p_hal_data->eeprom_thermal_meter = 0x%x\n", rtlefu->eeprom_thermalmeter));
+	if (rf->eeprom_thermal == 0xff) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "no pg, hal_data->eeprom_thermal_meter = 0x%x\n",
+		       rf->eeprom_thermal);
 		return;
 	}
-#else
-	if (p_hal_data->eeprom_thermal_meter == 0xff) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no pg, p_hal_data->eeprom_thermal_meter = 0x%x\n", p_hal_data->eeprom_thermal_meter));
-		return;
-	}
-#endif
 
-	/*4 3. Initialize ThermalValues of rf_calibrate_info*/
+	/*@4 3. Initialize ThermalValues of rf_calibrate_info*/
 
-	if (p_rf_calibrate_info->is_reloadtxpowerindex)
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("reload ofdm index for band switch\n"));
+	if (cali_info->is_reloadtxpowerindex)
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "reload ofdm index for band switch\n");
 
-	/*4 4. Calculate average thermal meter*/
+	/*@4 4. Calculate average thermal meter*/
 
-	p_rf_calibrate_info->thermal_value_avg[p_rf_calibrate_info->thermal_value_avg_index] = thermal_value;
-	p_rf_calibrate_info->thermal_value_avg_index++;
-	if (p_rf_calibrate_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
-		p_rf_calibrate_info->thermal_value_avg_index = 0;
+	cali_info->thermal_value_avg[cali_info->thermal_value_avg_index]
+		= thermal_value;
+
+	cali_info->thermal_value_avg_index++;
+	/*Average times =  c.average_thermal_num*/
+	if (cali_info->thermal_value_avg_index == c.average_thermal_num)
+		cali_info->thermal_value_avg_index = 0;
 
 	for (i = 0; i < c.average_thermal_num; i++) {
-		if (p_rf_calibrate_info->thermal_value_avg[i]) {
-			thermal_value_avg += p_rf_calibrate_info->thermal_value_avg[i];
+		if (cali_info->thermal_value_avg[i]) {
+			thermal_value_avg += cali_info->thermal_value_avg[i];
 			thermal_value_avg_count++;
 		}
 	}
 
-	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
-		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		p_rf_calibrate_info->thermal_value_delta = thermal_value - rtlefu->eeprom_thermalmeter;
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, rtlefu->eeprom_thermalmeter));
-#else
-		p_rf_calibrate_info->thermal_value_delta = thermal_value - p_hal_data->eeprom_thermal_meter;
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-#endif
-	}
-
-	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
-
-	/* "delta" here is used to determine whether thermal value changes or not. */
-	delta	= (thermal_value > p_rf_calibrate_info->thermal_value) ? (thermal_value - p_rf_calibrate_info->thermal_value) : (p_rf_calibrate_info->thermal_value - thermal_value);
-	delta_LCK = (thermal_value > p_rf_calibrate_info->thermal_value_lck) ? (thermal_value - p_rf_calibrate_info->thermal_value_lck) : (p_rf_calibrate_info->thermal_value_lck - thermal_value);
-	delta_IQK = (thermal_value > p_rf_calibrate_info->thermal_value_iqk) ? (thermal_value - p_rf_calibrate_info->thermal_value_iqk) : (p_rf_calibrate_info->thermal_value_iqk - thermal_value);
-
-	if (p_rf_calibrate_info->thermal_value_iqk == 0xff) {	/*no PG, use thermal value for IQK*/
-		p_rf_calibrate_info->thermal_value_iqk = thermal_value;
-		delta_IQK = (thermal_value > p_rf_calibrate_info->thermal_value_iqk) ? (thermal_value - p_rf_calibrate_info->thermal_value_iqk) : (p_rf_calibrate_info->thermal_value_iqk - thermal_value);
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, use thermal_value for IQK\n"));
+	/* Calculate Average thermal_value after average enough times */
+	if (thermal_value_avg_count) {
+		thermal_value =
+			(u8)(thermal_value_avg / thermal_value_avg_count);
+		cali_info->thermal_value_delta
+			= thermal_value - rf->eeprom_thermal;
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n",
+		       thermal_value, rf->eeprom_thermal);
 	}
 
-	for (p = RF_PATH_A; p < c.rf_path_count; p++)
-		diff_DPK[p] = (s8)thermal_value - (s8)p_rf_calibrate_info->dpk_thermal[p];
-
-	/*4 6. If necessary, do LCK.*/
-
-	if (!(p_dm->support_ic_type & ODM_RTL8821)) {	/*no PG, do LCK at initial status*/
-		if (p_rf_calibrate_info->thermal_value_lck == 0xff) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, do LCK\n"));
-			p_rf_calibrate_info->thermal_value_lck = thermal_value;
-
-			/*Use RTLCK, so close power tracking driver LCK*/
-			if (!(p_dm->support_ic_type & ODM_RTL8814A) && !(p_dm->support_ic_type & ODM_RTL8822B) && c.phy_lc_calibrate)
-				(*c.phy_lc_calibrate)(p_dm);
-
-			delta_LCK = (thermal_value > p_rf_calibrate_info->thermal_value_lck) ? (thermal_value - p_rf_calibrate_info->thermal_value_lck) : (p_rf_calibrate_info->thermal_value_lck - thermal_value);
-		}
-
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK));
+	/* @4 5. Calculate delta, delta_lck, delta_iqk. */
+	/* "delta" here is used to determine thermal value changes or not. */
+	if (thermal_value > cali_info->thermal_value)
+		delta = thermal_value - cali_info->thermal_value;
+	else
+		delta = cali_info->thermal_value - thermal_value;
 
-		/* Wait sacn to do LCK by RF Jenyu*/
-		if ((*p_dm->p_is_scan_in_process == false) && (!p_iqk_info->rfk_forbidden)) {
-			/* Delta temperature is equal to or larger than 20 centigrade.*/
-			if (delta_LCK >= c.threshold_iqk) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk));
-				p_rf_calibrate_info->thermal_value_lck = thermal_value;
+	if (thermal_value > cali_info->thermal_value_lck)
+		delta_lck = thermal_value - cali_info->thermal_value_lck;
+	else
+		delta_lck = cali_info->thermal_value_lck - thermal_value;
 
-				/*Use RTLCK, so close power tracking driver LCK*/
-				if (!(p_dm->support_ic_type & ODM_RTL8814A) && !(p_dm->support_ic_type & ODM_RTL8822B) && c.phy_lc_calibrate)
-					(*c.phy_lc_calibrate)(p_dm);
+	if (thermal_value > cali_info->thermal_value_iqk)
+		delta_iqk = thermal_value - cali_info->thermal_value_iqk;
+	else
+		delta_iqk = cali_info->thermal_value_iqk - thermal_value;
+
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "(delta, delta_lck, delta_iqk) = (%d, %d, %d)\n", delta,
+	       delta_lck, delta_iqk);
+
+	/*@4 6. If necessary, do LCK.*/
+	/* Wait sacn to do LCK by RF Jenyu*/
+	if (!(*dm->is_scan_in_process) && !iqk_info->rfk_forbidden) {
+		/* Delta temperature is equal to or larger than 20 centigrade.*/
+		if (delta_lck >= c.threshold_iqk) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "delta_lck(%d) >= threshold_iqk(%d)\n",
+			       delta_lck, c.threshold_iqk);
+			cali_info->thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, close power tracking driver LCK*/
+			/*8821 don't do LCK*/
+			if (!(dm->support_ic_type &
+				(ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B)) &&
+				c.phy_lc_calibrate) {
+				(*c.phy_lc_calibrate)(dm);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "do pwrtrk lck\n");
 			}
 		}
 	}
 
-	/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
+	/*@3 7. If necessary, move the index of swing table to adjust Tx power.*/
+	/* "delta" here is used to record the absolute value of difference. */
+	if (delta > 0 && cali_info->txpowertrack_control) {
+		if (thermal_value > rf->eeprom_thermal)
+			delta = thermal_value - rf->eeprom_thermal;
+		else
+			delta = rf->eeprom_thermal - thermal_value;
 
-	if (delta > 0 && p_rf_calibrate_info->txpowertrack_control) {
-		/* "delta" here is used to record the absolute value of differrence. */
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		delta = thermal_value > rtlefu->eeprom_thermalmeter ? (thermal_value - rtlefu->eeprom_thermalmeter) : (rtlefu->eeprom_thermalmeter - thermal_value);
-#else
-		delta = thermal_value > p_hal_data->eeprom_thermal_meter ? (thermal_value - p_hal_data->eeprom_thermal_meter) : (p_hal_data->eeprom_thermal_meter - thermal_value);
-#endif
-#else
-		delta = (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - p_dm->priv->pmib->dot11RFEntry.ther) : (p_dm->priv->pmib->dot11RFEntry.ther - thermal_value);
-#endif
 		if (delta >= TXPWR_TRACK_TABLE_SIZE)
 			delta = TXPWR_TRACK_TABLE_SIZE - 1;
 
-		/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		if (thermal_value > rtlefu->eeprom_thermalmeter) {
-#else
-		if (thermal_value > p_hal_data->eeprom_thermal_meter) {
-#endif
-#else
-		if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) {
-#endif
-
-			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-				p_rf_calibrate_info->delta_power_index_last[p] = p_rf_calibrate_info->delta_power_index[p];	/*recording poer index offset*/
-				switch (p) {
-				case RF_PATH_B:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]));
-
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_b[delta];       /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-
-				case RF_PATH_C:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]));
-
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_c[delta];       /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-
-				case RF_PATH_D:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]));
-
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_d[delta];       /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-
-				default:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]));
-
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_a[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-				}
-			}
-			/* JJ ADD 20161014 */
-			if (p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
-				/*Save xtal_offset from Xtal table*/
-				p_rf_calibrate_info->xtal_offset_last = p_rf_calibrate_info->xtal_offset;	/*recording last Xtal offset*/
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]));
-				p_rf_calibrate_info->xtal_offset = delta_swing_table_xtal_up[delta];
-				xtal_offset_eanble = (p_rf_calibrate_info->xtal_offset_last != p_rf_calibrate_info->xtal_offset);
-			}
-
-		} else {
-			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-				p_rf_calibrate_info->delta_power_index_last[p] = p_rf_calibrate_info->delta_power_index[p];	/*recording poer index offset*/
-
-				switch (p) {
-				case RF_PATH_B:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_b[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-
-				case RF_PATH_C:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_c[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-
-				case RF_PATH_D:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_d[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-
-				default:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_a[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
-					break;
-				}
-			}
-			/* JJ ADD 20161014 */
-			if (p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
-				/*Save xtal_offset from Xtal table*/
-				p_rf_calibrate_info->xtal_offset_last = p_rf_calibrate_info->xtal_offset;	/*recording last Xtal offset*/
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]));
-				p_rf_calibrate_info->xtal_offset = delta_swing_table_xtal_down[delta];
-				xtal_offset_eanble = (p_rf_calibrate_info->xtal_offset_last != p_rf_calibrate_info->xtal_offset);
-			}
-
-		}
+		odm_get_tracking_table(dm, thermal_value, delta);
 
 		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "\n[path-%d] Calculate pwr_idx_offset\n", p);
 
-			if (p_rf_calibrate_info->delta_power_index[p] == p_rf_calibrate_info->delta_power_index_last[p])         /*If Thermal value changes but lookup table value still the same*/
-				p_rf_calibrate_info->power_index_offset[p] = 0;
+			/*If Thermal value changes but table value is the same*/
+			if (cali_info->delta_power_index[p] ==
+				cali_info->delta_power_index_last[p])
+				cali_info->power_index_offset[p] = 0;
 			else
-				p_rf_calibrate_info->power_index_offset[p] = p_rf_calibrate_info->delta_power_index[p] - p_rf_calibrate_info->delta_power_index_last[p];      /*Power index diff between 2 times Power Tracking*/
+				cali_info->power_index_offset[p] =
+				cali_info->delta_power_index[p] -
+				cali_info->delta_power_index_last[p];
 
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, p_rf_calibrate_info->power_index_offset[p], p_rf_calibrate_info->delta_power_index[p], p_rf_calibrate_info->delta_power_index_last[p]));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "path-%d pwridx_diff%d=pwr_idx%d - last_idx%d\n",
+			       p, cali_info->power_index_offset[p],
+			       cali_info->delta_power_index[p],
+			       cali_info->delta_power_index_last[p]);
+#if 0
 
-			p_rf_calibrate_info->OFDM_index[p] = p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] + p_rf_calibrate_info->power_index_offset[p];
-			p_rf_calibrate_info->CCK_index = p_rf_calibrate_info->bb_swing_idx_cck_base + p_rf_calibrate_info->power_index_offset[p];
+			cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
+			cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
 
-			p_rf_calibrate_info->bb_swing_idx_cck = p_rf_calibrate_info->CCK_index;
-			p_rf_calibrate_info->bb_swing_idx_ofdm[p] = p_rf_calibrate_info->OFDM_index[p];
+			cali_info->bb_swing_idx_cck = cali_info->CCK_index;
+			cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
 
 			/*************Print BB Swing base and index Offset*************/
 
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", p_rf_calibrate_info->bb_swing_idx_cck, p_rf_calibrate_info->bb_swing_idx_cck_base, p_rf_calibrate_info->power_index_offset[p]));
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", p_rf_calibrate_info->bb_swing_idx_ofdm[p], p, p_rf_calibrate_info->bb_swing_idx_ofdm_base[p], p_rf_calibrate_info->power_index_offset[p]));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n",
+			       cali_info->bb_swing_idx_cck,
+			       cali_info->bb_swing_idx_cck_base,
+			       cali_info->power_index_offset[p]);
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n",
+			       cali_info->bb_swing_idx_ofdm[p], p,
+			       cali_info->bb_swing_idx_ofdm_base[p],
+			       cali_info->power_index_offset[p]);
 
 			/*4 7.1 Handle boundary conditions of index.*/
 
-			if (p_rf_calibrate_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
-				p_rf_calibrate_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
-			else if (p_rf_calibrate_info->OFDM_index[p] <= OFDM_min_index)
-				p_rf_calibrate_info->OFDM_index[p] = OFDM_min_index;
+			if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
+				cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
+			else if (cali_info->OFDM_index[p] <= OFDM_min_index)
+				cali_info->OFDM_index[p] = OFDM_min_index;
+#endif
 		}
+#if 0
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "\n\n========================================================================================================\n");
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("\n\n========================================================================================================\n"));
-
-		if (p_rf_calibrate_info->CCK_index > c.swing_table_size_cck - 1)
-			p_rf_calibrate_info->CCK_index = c.swing_table_size_cck - 1;
-		else if (p_rf_calibrate_info->CCK_index <= 0)
-			p_rf_calibrate_info->CCK_index = 0;
+		if (cali_info->CCK_index > c.swing_table_size_cck - 1)
+			cali_info->CCK_index = c.swing_table_size_cck - 1;
+		else if (cali_info->CCK_index <= 0)
+			cali_info->CCK_index = 0;
+#endif
 	} else {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, p_rf_calibrate_info->thermal_value: %d\n",
-			p_rf_calibrate_info->txpowertrack_control, thermal_value, p_rf_calibrate_info->thermal_value));
-
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "Thermal is unchanged thermal=%d last_thermal=%d\n",
+		       thermal_value,
+		       cali_info->thermal_value);
 		for (p = RF_PATH_A; p < c.rf_path_count; p++)
-			p_rf_calibrate_info->power_index_offset[p] = 0;
+			cali_info->power_index_offset[p] = 0;
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
-		p_rf_calibrate_info->CCK_index, p_rf_calibrate_info->bb_swing_idx_cck_base));       /*Print Swing base & current*/
+#if 0
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
+	       cali_info->CCK_index,
+	       cali_info->bb_swing_idx_cck_base); /*Print Swing base & current*/
 
 	for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
-			p_rf_calibrate_info->OFDM_index[p], p, p_rf_calibrate_info->bb_swing_idx_ofdm_base[p]));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
+		       cali_info->OFDM_index[p], p,
+		       cali_info->bb_swing_idx_ofdm_base[p]);
 	}
+#endif
 
-	if ((p_dm->support_ic_type & ODM_RTL8814A)) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("power_tracking_type=%d\n", power_tracking_type));
+	if ((dm->support_ic_type & ODM_RTL8814A)) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "power_tracking_type=%d\n",
+		       power_tracking_type);
 
 		if (power_tracking_type == 0) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "***Enter PwrTrk MIX_MODE***\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)
+					(dm, MIX_MODE, p, 0);
 		} else if (power_tracking_type == 1) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "***Enter PwrTrk MIX(2G) TSSI(5G) MODE***\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_2G_TSSI_5G_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)
+					(dm, MIX_2G_TSSI_5G_MODE, p, 0);
 		} else if (power_tracking_type == 2) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "***Enter PwrTrk MIX(5G) TSSI(2G)MODE***\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_5G_TSSI_2G_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)
+					(dm, MIX_5G_TSSI_2G_MODE, p, 0);
 		} else if (power_tracking_type == 3) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking TSSI MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "***Enter PwrTrk TSSI MODE***\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, TSSI_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)
+					(dm, TSSI_MODE, p, 0);
 		}
-		p_rf_calibrate_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
-
-	} else if ((p_rf_calibrate_info->power_index_offset[RF_PATH_A] != 0 ||
-		p_rf_calibrate_info->power_index_offset[RF_PATH_B] != 0 ||
-		p_rf_calibrate_info->power_index_offset[RF_PATH_C] != 0 ||
-		p_rf_calibrate_info->power_index_offset[RF_PATH_D] != 0) &&
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		p_rf_calibrate_info->txpowertrack_control && (rtlefu->eeprom_thermalmeter != 0xff)) {
-#else
-		p_rf_calibrate_info->txpowertrack_control && (p_hal_data->eeprom_thermal_meter != 0xff)) {
-#endif
+	} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
+		    cali_info->power_index_offset[RF_PATH_B] != 0 ||
+		    cali_info->power_index_offset[RF_PATH_C] != 0 ||
+		    cali_info->power_index_offset[RF_PATH_D] != 0)) {
+#if 0
 		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
-
-		p_rf_calibrate_info->is_tx_power_changed = true;	/*Always true after Tx Power is adjusted by power tracking.*/
-		/*  */
-		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
-		/* to increase TX power. Otherwise, EVM will be bad. */
-		/*  */
-		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
-		if (thermal_value > p_rf_calibrate_info->thermal_value) {
+		/*Always true after Tx Power is adjusted by power tracking.*/
+
+		cali_info->is_tx_power_changed = true;
+		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital
+		 * to increase TX power. Otherwise, EVM will be bad.
+		 *
+		 * 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E.
+		 */
+		if (thermal_value > cali_info->thermal_value) {
 			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, p_rf_calibrate_info->power_index_offset[p], delta, thermal_value, rtlefu->eeprom_thermalmeter, p_rf_calibrate_info->thermal_value));
-#else
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, p_rf_calibrate_info->power_index_offset[p], delta, thermal_value, p_hal_data->eeprom_thermal_meter, p_rf_calibrate_info->thermal_value));
-#endif
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+				       p, cali_info->power_index_offset[p],
+				       delta, thermal_value, rf->eeprom_thermal,
+				       cali_info->thermal_value);
 			}
-		} else if (thermal_value < p_rf_calibrate_info->thermal_value) {	/*Low temperature*/
+		} else if (thermal_value < cali_info->thermal_value) { /*Low temperature*/
 			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, p_rf_calibrate_info->power_index_offset[p], delta, thermal_value, rtlefu->eeprom_thermalmeter, p_rf_calibrate_info->thermal_value));
-#else
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, p_rf_calibrate_info->power_index_offset[p], delta, thermal_value, p_hal_data->eeprom_thermal_meter, p_rf_calibrate_info->thermal_value));
-#endif
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+				       p, cali_info->power_index_offset[p],
+				       delta, thermal_value, rf->eeprom_thermal,
+				       cali_info->thermal_value);
 			}
 		}
+#endif
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		if (thermal_value > rtlefu->eeprom_thermalmeter)
+		if (thermal_value > rf->eeprom_thermal) {
 #else
-		if (thermal_value > p_hal_data->eeprom_thermal_meter)
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
 #endif
-#else
-		if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther)
-#endif
-		{
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) higher than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter));
-#else
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) higher than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-#endif
-
-			if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8821 ||
-			    p_dm->support_ic_type == ODM_RTL8812 || p_dm->support_ic_type == ODM_RTL8723B || p_dm->support_ic_type == ODM_RTL8814A ||
-			    p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8188F || p_dm->support_ic_type == ODM_RTL8822B ||
-			    p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8821C || p_dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "Temperature(%d) higher than PG value(%d)\n",
+			       thermal_value, rf->eeprom_thermal);
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
-				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
-			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking BBSWING_MODE**********\n"));
-				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, p, indexforchannel);
-			}
+			odm_pwrtrk_method(dm);
 		} else {
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) lower than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter));
-#else
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) lower than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-#endif
-
-			if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8821 ||
-			    p_dm->support_ic_type == ODM_RTL8812 || p_dm->support_ic_type == ODM_RTL8723B || p_dm->support_ic_type == ODM_RTL8814A ||
-			    p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8188F || p_dm->support_ic_type == ODM_RTL8822B ||
-			    p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8821C || p_dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
-
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
-				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, indexforchannel);
-			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking BBSWING_MODE**********\n"));
-				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, p, indexforchannel);
-			}
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "Temperature(%d) lower than PG value(%d)\n",
+			       thermal_value, rf->eeprom_thermal);
 
+			odm_pwrtrk_method(dm);
 		}
 
-		p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
+#if 0
+		/*Record last time Power Tracking result as base.*/
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;
 		for (p = RF_PATH_A; p < c.rf_path_count; p++)
-			p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] = p_rf_calibrate_info->bb_swing_idx_ofdm[p];
-
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("p_rf_calibrate_info->thermal_value = %d thermal_value= %d\n", p_rf_calibrate_info->thermal_value, thermal_value));
-
-		p_rf_calibrate_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
-
-	}
-
-
-	if (p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		if (xtal_offset_eanble != 0 && p_rf_calibrate_info->txpowertrack_control && (rtlefu->eeprom_thermalmeter != 0xff)) {
-#else
-		if (xtal_offset_eanble != 0 && p_rf_calibrate_info->txpowertrack_control && (p_hal_data->eeprom_thermal_meter != 0xff)) {
+			cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
 #endif
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "cali_info->thermal_value = %d thermal_value= %d\n",
+		       cali_info->thermal_value, thermal_value);
+	}
+	/*Record last Power Tracking Thermal value*/
+	cali_info->thermal_value = thermal_value;
 
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter Xtal Tracking**********\n"));
+	if (dm->support_ic_type &
+		(ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8192F | ODM_RTL8710B)) {
+		if (cali_info->xtal_offset_eanble != 0 &&
+		    cali_info->txpowertrack_control &&
+		    rf->eeprom_thermal != 0xff) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "**********Enter Xtal Tracking**********\n");
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-			if (thermal_value > rtlefu->eeprom_thermalmeter) {
-#else
-			if (thermal_value > p_hal_data->eeprom_thermal_meter) {
-#endif
+			if (thermal_value > rf->eeprom_thermal) {
 #else
-			if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) {
+			if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
 #endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature(%d) higher than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter));
-#else
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature(%d) higher than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-#endif
-				(*c.odm_txxtaltrack_set_xtal)(p_dm);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "Temperature(%d) higher than PG (%d)\n",
+				       thermal_value, rf->eeprom_thermal);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
 			} else {
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature(%d) lower than PG value(%d)\n", thermal_value, rtlefu->eeprom_thermalmeter));
-#else
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature(%d) lower than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-#endif
-				(*c.odm_txxtaltrack_set_xtal)(p_dm);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "Temperature(%d) lower than PG (%d)\n",
+				       thermal_value, rf->eeprom_thermal);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
 			}
 		}
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********End Xtal Tracking**********\n"));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "**********End Xtal Tracking**********\n");
 	}
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
 
 	/* Wait sacn to do IQK by RF Jenyu*/
-	if ((*p_dm->p_is_scan_in_process == false)  && (!p_iqk_info->rfk_forbidden)) {
-		if (!IS_HARDWARE_TYPE_8723B(adapter)) {
-			/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
-			if (delta_IQK >= c.threshold_iqk) {
-				p_rf_calibrate_info->thermal_value_iqk = thermal_value;
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk));
-				if (!p_rf_calibrate_info->is_iqk_in_progress)
-					(*c.do_iqk)(p_dm, delta_IQK, thermal_value, 8);
+	if (!(*dm->is_scan_in_process) && !iqk_info->rfk_forbidden &&
+	    !cali_info->is_iqk_in_progress) {
+		if (!(dm->support_ic_type & ODM_RTL8723B)) {
+			/*Delta temperature is equal or larger than 20 Celsius*/
+			/*When threshold is 8*/
+			if (delta_iqk >= c.threshold_iqk) {
+				cali_info->thermal_value_iqk = thermal_value;
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "delta_iqk(%d) >= threshold_iqk(%d)\n",
+				       delta_iqk, c.threshold_iqk);
+				(*c.do_iqk)(dm, delta_iqk, thermal_value, 8);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "do pwrtrk iqk\n");
 			}
 		}
 	}
-	if (p_rf_calibrate_info->dpk_thermal[RF_PATH_A] != 0) {
+
+#if 0
+	if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
 		if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
 			s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
 
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		}
 	}
-	if (p_rf_calibrate_info->dpk_thermal[RF_PATH_B] != 0) {
+	if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
 		if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
 			s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
 
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		}
 	}
+#endif
 
 #endif
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("<===odm_txpowertracking_callback_thermal_meter\n"));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===%s\n", __func__);
 
-	p_rf_calibrate_info->tx_powercount = 0;
+	cali_info->tx_powercount = 0;
 }
 
-
-
-/* 3============================================================
+/*@3============================================================
  * 3 IQ Calibration
- * 3============================================================ */
+ * 3============================================================
+ */
 
-void
-odm_reset_iqk_result(
-	void					*p_dm_void
-)
+void odm_reset_iqk_result(void *dm_void)
 {
-	return;
 }
+
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
 u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
 {
-	u8	channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
-		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 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
-	};
-	u8	place = chnl;
-
+	u8 channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
+		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
+		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};
+	u8 place = chnl;
 
 	if (chnl > 14) {
 		for (place = 14; place < sizeof(channel_all); place++) {
@@ -832,20 +856,16 @@ u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
 		}
 	}
 	return 0;
-
 }
 #endif
 
-void
-odm_iq_calibrate(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void odm_iq_calibrate(struct dm_struct *dm)
 {
-	struct _ADAPTER	*adapter = p_dm->adapter;
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	void *adapter = dm->adapter;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (*p_dm->p_is_fcs_mode_enable)
+	if (*dm->is_fcs_mode_enable)
 		return;
 #endif
 
@@ -854,45 +874,48 @@ odm_iq_calibrate(
 		return;
 #endif
 
-	if ((p_dm->is_linked) && (!p_iqk_info->rfk_forbidden)) {
-		if ((*p_dm->p_channel != p_dm->pre_channel) && (!*p_dm->p_is_scan_in_process)) {
-			p_dm->pre_channel = *p_dm->p_channel;
-			p_dm->linked_interval = 0;
+	if (dm->is_linked && !iqk_info->rfk_forbidden) {
+		if ((*dm->channel != dm->pre_channel) &&
+		    (!*dm->is_scan_in_process)) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
 		}
 
-		if (p_dm->linked_interval < 3)
-			p_dm->linked_interval++;
+		if (dm->linked_interval < 3)
+			dm->linked_interval++;
 
-		if (p_dm->linked_interval == 2)
-			halrf_iqk_trigger(p_dm, false);
-	} else
-		p_dm->linked_interval = 0;
+		if (dm->linked_interval == 2)
+			halrf_iqk_trigger(dm, false);
+	} else {
+		dm->linked_interval = 0;
+	}
 }
 
-void phydm_rf_init(void		*p_dm_void)
+void phydm_rf_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	odm_txpowertracking_init(p_dm);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_txpowertracking_init(dm);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	odm_clear_txpowertracking_state(p_dm);
+	odm_clear_txpowertracking_state(dm);
 #endif
-
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		phy_iq_calibrate_8814a_init(p_dm);
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
 #endif
 #endif
-
 }
 
-void phydm_rf_watchdog(void		*p_dm_void)
+void phydm_rf_watchdog(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	odm_txpowertracking_check(p_dm);
-	/*if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)*/
-		/*odm_iq_calibrate(p_dm);*/
+	odm_txpowertracking_check(dm);
+#if 0
+/*if (dm->support_ic_type & ODM_IC_11AC_SERIES)*/
+/*odm_iq_calibrate(dm);*/
+#endif
 #endif
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.h
index f2afd2804147..4fca20498743 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_ce.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,29 +9,49 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef __HAL_PHY_RF_H__
-#define __HAL_PHY_RF_H__
+#ifndef __HALPHYRF_H__
+#define __HALPHYRF_H__
 
 #include "halrf/halrf_kfree.h"
 #if (RTL8814A_SUPPORT == 1)
-	#include "halrf/rtl8814a/halrf_iqk_8814a.h"
+#include "halrf/rtl8814a/halrf_iqk_8814a.h"
 #endif
 
 #if (RTL8822B_SUPPORT == 1)
-	#include "halrf/rtl8822b/halrf_iqk_8822b.h"
+#include "halrf/rtl8822b/halrf_iqk_8822b.h"
 #endif
 
 #if (RTL8821C_SUPPORT == 1)
-	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
+#include "halrf/rtl8821c/halrf_iqk_8821c.h"
 #endif
 
-#include "halrf/halrf_powertracking_ce.h"
+#if (RTL8195B_SUPPORT == 1)
+/* #include "halrf/rtl8195b/halrf.h" */
+#include "halrf/rtl8195b/halrf_iqk_8195b.h"
+#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
+#include "halrf/rtl8195b/halrf_dpk_8195b.h"
+#endif
+
+#if (RTL8814B_SUPPORT == 1)
+	#include "halrf/rtl8814b/halrf_iqk_8814b.h"
+#endif
 
+#include "halrf/halrf_powertracking_ce.h"
 
 enum spur_cal_method {
 	PLL_RESET,
@@ -46,69 +67,49 @@ enum pwrtrack_method {
 	MIX_5G_TSSI_2G_MODE
 };
 
-typedef void	(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
-typedef void(*func_iqk)(void *, u8, u8, u8);
-typedef void	(*func_lck)(void *);
-typedef void	(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
-typedef void	(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
-typedef void(*func_swing_xtal)(void *, s8 **, s8 **);
-typedef void(*func_set_xtal)(void *);
-
-struct _TXPWRTRACK_CFG {
-	u8		swing_table_size_cck;
-	u8		swing_table_size_ofdm;
-	u8		threshold_iqk;
-	u8		threshold_dpk;
-	u8		average_thermal_num;
-	u8		rf_path_count;
-	u32		thermal_reg_addr;
-	func_set_pwr	odm_tx_pwr_track_set_pwr;
-	func_iqk	do_iqk;
-	func_lck		phy_lc_calibrate;
-	func_swing	get_delta_swing_table;
-	func_swing8814only	get_delta_swing_table8814only;
-	func_swing_xtal			get_delta_swing_xtal_table;
-	func_set_xtal			odm_txxtaltrack_set_xtal;
+typedef void (*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void (*func_iqk)(void *, u8, u8, u8);
+typedef void (*func_lck)(void *);
+typedef void (*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void (*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void (*func_swing_xtal)(void *, s8 **, s8 **);
+typedef void (*func_set_xtal)(void *);
+
+struct txpwrtrack_cfg {
+	u8 swing_table_size_cck;
+	u8 swing_table_size_ofdm;
+	u8 threshold_iqk;
+	u8 threshold_dpk;
+	u8 average_thermal_num;
+	u8 rf_path_count;
+	u32 thermal_reg_addr;
+	func_set_pwr odm_tx_pwr_track_set_pwr;
+	func_iqk do_iqk;
+	func_lck phy_lc_calibrate;
+	func_swing get_delta_swing_table;
+	func_swing8814only get_delta_swing_table8814only;
+	func_swing_xtal get_delta_swing_xtal_table;
+	func_set_xtal odm_txxtaltrack_set_xtal;
 };
 
-void
-configure_txpower_track(
-	void					*p_dm_void,
-	struct _TXPWRTRACK_CFG	*p_config
-);
-
+void configure_txpower_track(void *dm_void, struct txpwrtrack_cfg *config);
 
-void
-odm_clear_txpowertracking_state(
-	void					*p_dm_void
-);
+void odm_clear_txpowertracking_state(void *dm_void);
 
-void
-odm_txpowertracking_callback_thermal_meter(
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	void					*p_dm_void
-#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	void	*p_dm
+void odm_txpowertracking_callback_thermal_meter(void *dm_void);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+void odm_txpowertracking_callback_thermal_meter(void *dm);
 #else
-	struct _ADAPTER	*adapter
+void odm_txpowertracking_callback_thermal_meter(void *adapter);
 #endif
-);
-
-
-
-#define ODM_TARGET_CHNL_NUM_2G_5G	59
 
+#define ODM_TARGET_CHNL_NUM_2G_5G 59
 
-void
-odm_reset_iqk_result(
-	void					*p_dm_void
-);
-u8
-odm_get_right_chnl_place_for_iqk(
-	u8 chnl
-);
+void odm_reset_iqk_result(void *dm_void);
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl);
 
-void phydm_rf_init(void					*p_dm_void);
-void phydm_rf_watchdog(void					*p_dm_void);
+void phydm_rf_init(void *dm_void);
+void phydm_rf_watchdog(void *dm_void);
 
-#endif	/*  #ifndef __HAL_PHY_RF_H__ */
+#endif /*__HALPHYRF_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_iot.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_iot.c
new file mode 100644
index 000000000000..08d5f9b0d304
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_iot.c
@@ -0,0 +1,529 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#define	CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
+	do {\
+		for (_offset = 0; _offset < _size; _offset++) { \
+			if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
+				if (_offset != 0)\
+					_offset--;\
+				break;\
+			} \
+		}			\
+		if (_offset >= _size)\
+			_offset = _size-1;\
+	} while (0)
+
+void configure_txpower_track(
+	void					*dm_void,
+	struct txpwrtrack_cfg	*config
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+#if RTL8195B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8195B)
+		configure_txpower_track_8195b(config);
+#endif
+
+#if RTL8721D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8721D)
+		configure_txpower_track_8721d(config);
+#endif
+
+}
+
+/* **********************************************************************
+ * <20121113, Kordan> This function should be called when tx_agc changed.
+ * Otherwise the previous compensation is gone, because we record the
+ * delta of temperature between two TxPowerTracking watch dogs.
+ *
+ * NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
+ * need to call this function.
+ * ********************************************************************** */
+void
+odm_clear_txpowertracking_state(
+	void					*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	u8			p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+	dm->rf_calibrate_info.CCK_index = 0;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+
+		cali_info->power_index_offset[p] = 0;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+
+		cali_info->absolute_ofdm_swing_idx[p] = 0;
+		cali_info->remnant_ofdm_swing_idx[p] = 0;
+		cali_info->kfree_offset[p] = 0;
+	}
+
+	cali_info->modify_tx_agc_flag_path_a = false;
+	cali_info->modify_tx_agc_flag_path_b = false;
+	cali_info->modify_tx_agc_flag_path_c = false;
+	cali_info->modify_tx_agc_flag_path_d = false;
+	cali_info->remnant_cck_swing_idx = 0;
+	cali_info->thermal_value = rf->eeprom_thermal;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->modify_tx_agc_value_ofdm = 0;
+}
+
+void
+odm_txpowertracking_callback_thermal_meter(
+	void	*dm_void
+)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	struct	dm_iqk_info *iqk_info = &dm->IQK_info;
+
+	u8 thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
+	u8 thermal_value_avg_count = 0;
+	u32 thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
+
+	u8 OFDM_min_index = 0;  /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
+	u8 indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
+	u8 power_tracking_type = rf->pwt_type;
+	u8 xtal_offset_eanble = 0;
+	s8 thermal_value_temp = 0;
+
+	struct txpwrtrack_cfg	c = {0};
+
+	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
+	u8 *delta_swing_table_idx_tup_a = NULL;
+	u8 *delta_swing_table_idx_tdown_a = NULL;
+	u8 *delta_swing_table_idx_tup_b = NULL;
+	u8 *delta_swing_table_idx_tdown_b = NULL;
+	/*for Xtal Offset by James.Tung*/
+	s8 *delta_swing_table_xtal_up = NULL;
+	s8 *delta_swing_table_xtal_down = NULL;
+
+	/* 4 2. Initialization ( 7 steps in total ) */
+
+	configure_txpower_track(dm, &c);
+
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
+
+	/*for Xtal Offset*/
+	if (dm->support_ic_type & (ODM_RTL8195B | ODM_RTL8721D))
+		(*c.get_delta_swing_xtal_table)(dm,
+		 (s8 **)&delta_swing_table_xtal_up,
+		 (s8 **)&delta_swing_table_xtal_down);
+
+	cali_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
+	cali_info->is_txpowertracking_init = true;
+
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
+	       cali_info->bb_swing_idx_cck_base,
+	       cali_info->bb_swing_idx_ofdm_base[RF_PATH_A],
+	       cali_info->default_ofdm_index);
+
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "cali_info->txpowertrack_control = %d, hal_data->eeprom_thermal_meter %d\n",
+	       cali_info->txpowertrack_control, rf->eeprom_thermal);
+
+	if (dm->support_ic_type == ODM_RTL8721D)
+		thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A,
+						   c.thermal_reg_addr, 0x7e0);
+		/* 0x42: RF Reg[10:5] 8721D */
+	else
+		thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A,
+						   c.thermal_reg_addr, 0xfc00);
+		/* 0x42: RF Reg[15:10] 88E */
+
+	thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
+
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "thermal_value_temp(%d) = thermal_value(%d) + power_trim_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
+
+	if (thermal_value_temp > 63)
+		thermal_value = 63;
+	else if (thermal_value_temp < 0)
+		thermal_value = 0;
+	else
+		thermal_value = thermal_value_temp;
+
+	if (!cali_info->txpowertrack_control)
+		return;
+
+	if (rf->eeprom_thermal == 0xff) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", rf->eeprom_thermal);
+		return;
+	}
+#if 0
+	/*4 3. Initialize ThermalValues of rf_calibrate_info*/
+	//if (cali_info->is_reloadtxpowerindex)
+	//	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "reload ofdm index for band switch\n");
+#endif
+	/*4 4. Calculate average thermal meter*/
+
+	cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
+	cali_info->thermal_value_avg_index++;
+	if (cali_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		cali_info->thermal_value_avg_index = 0;
+
+	for (i = 0; i < c.average_thermal_num; i++) {
+		if (cali_info->thermal_value_avg[i]) {
+			thermal_value_avg += cali_info->thermal_value_avg[i];
+			thermal_value_avg_count++;
+		}
+	}
+
+	if (thermal_value_avg_count) {			  /* Calculate Average thermal_value after average enough times */
+		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
+		cali_info->thermal_value_delta = thermal_value - rf->eeprom_thermal;
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, rf->eeprom_thermal);
+	}
+
+	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
+	/* "delta" here is used to determine whether thermal value changes or not. */
+	delta	= (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
+	delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+
+	/*4 6. If necessary, do LCK.*/
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
+
+	/* Wait sacn to do LCK by RF Jenyu*/
+	if ((!*dm->is_scan_in_process) && !iqk_info->rfk_forbidden &&
+	    (!*dm->is_tdma)) {
+		/* Delta temperature is equal to or larger than 20 centigrade.*/
+		if (delta_LCK >= c.threshold_iqk) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+			cali_info->thermal_value_lck = thermal_value;
+
+			/*Use RTLCK, so close power tracking driver LCK*/
+			(*c.phy_lc_calibrate)(dm);
+		}
+	}
+
+	/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
+	if (delta > 0 && cali_info->txpowertrack_control) {
+		/* "delta" here is used to record the absolute value of difference. */
+		delta = thermal_value > rf->eeprom_thermal ? (thermal_value - rf->eeprom_thermal) : (rf->eeprom_thermal - thermal_value);
+
+		if (delta >= TXPWR_TRACK_TABLE_SIZE)
+			delta = TXPWR_TRACK_TABLE_SIZE - 1;
+
+		/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
+		if (thermal_value > rf->eeprom_thermal) {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p]; /*recording poer index offset*/
+				switch (p) {
+				case RF_PATH_B:
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
+
+					cali_info->delta_power_index[p] =
+						delta_swing_table_idx_tup_b
+						[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =
+						delta_swing_table_idx_tup_b
+						[delta];
+					/*Record delta swing for mix mode*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
+
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =
+					delta_swing_table_idx_tup_a[delta];
+					/*Record delta swing*/
+					/*for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+			if (dm->support_ic_type &
+			    (ODM_RTL8195B | ODM_RTL8721D)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
+				xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
+			}
+
+		} else {
+			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p]; /*recording poer index offset*/
+
+				switch (p) {
+				case RF_PATH_B:
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta]; /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+
+				default:
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta]; /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					       "******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
+					break;
+				}
+			}
+			/* JJ ADD 20161014 */
+
+			if (dm->support_ic_type &
+			    (ODM_RTL8195B | ODM_RTL8721D)) {
+				/*Save xtal_offset from Xtal table*/
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
+				xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
+			}
+		}
+#if 0
+		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
+
+			if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p])		 /*If Thermal value changes but lookup table value still the same*/
+				cali_info->power_index_offset[p] = 0;
+			else
+				cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p];		/*Power index diff between 2 times Power Tracking*/
+
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
+
+			cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
+			cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
+
+			cali_info->bb_swing_idx_cck = cali_info->CCK_index;
+			cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
+
+			/*************Print BB Swing base and index Offset*************/
+
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			       "The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
+
+			/*4 7.1 Handle boundary conditions of index.*/
+
+			if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
+				cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
+			else if (cali_info->OFDM_index[p] <= OFDM_min_index)
+				cali_info->OFDM_index[p] = OFDM_min_index;
+		}
+
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "\n\n========================================================================================================\n");
+
+		if (cali_info->CCK_index > c.swing_table_size_cck - 1)
+			cali_info->CCK_index = c.swing_table_size_cck - 1;
+		else if (cali_info->CCK_index <= 0)
+			cali_info->CCK_index = 0;
+#endif
+	} else {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
+		       cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
+
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->power_index_offset[p] = 0;
+	}
+#if 0
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
+	       cali_info->CCK_index, cali_info->bb_swing_idx_cck_base);	   /*Print Swing base & current*/
+
+	for (p = RF_PATH_A; p < c.rf_path_count; p++) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
+		       cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
+	}
+#endif
+	if (thermal_value > rf->eeprom_thermal) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "Temperature(%d) higher than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
+
+		if (dm->support_ic_type == ODM_RTL8188E ||
+		    dm->support_ic_type == ODM_RTL8192E ||
+		    dm->support_ic_type == ODM_RTL8821 ||
+		    dm->support_ic_type == ODM_RTL8812 ||
+		    dm->support_ic_type == ODM_RTL8723B ||
+		    dm->support_ic_type == ODM_RTL8814A ||
+		    dm->support_ic_type == ODM_RTL8703B ||
+		    dm->support_ic_type == ODM_RTL8188F ||
+		    dm->support_ic_type == ODM_RTL8822B ||
+		    dm->support_ic_type == ODM_RTL8723D ||
+		    dm->support_ic_type == ODM_RTL8821C ||
+		    dm->support_ic_type == ODM_RTL8710B ||
+		    dm->support_ic_type == ODM_RTL8192F ||
+		    dm->support_ic_type == ODM_RTL8195B ||
+		    dm->support_ic_type == ODM_RTL8721D){
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
+		} else {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+		}
+	} else {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "Temperature(%d) lower than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
+
+		if (dm->support_ic_type == ODM_RTL8188E ||
+		    dm->support_ic_type == ODM_RTL8192E ||
+		    dm->support_ic_type == ODM_RTL8821 ||
+		    dm->support_ic_type == ODM_RTL8812 ||
+		    dm->support_ic_type == ODM_RTL8723B ||
+		    dm->support_ic_type == ODM_RTL8814A ||
+		    dm->support_ic_type == ODM_RTL8703B ||
+		    dm->support_ic_type == ODM_RTL8188F ||
+		    dm->support_ic_type == ODM_RTL8822B ||
+		    dm->support_ic_type == ODM_RTL8723D ||
+		    dm->support_ic_type == ODM_RTL8821C ||
+		    dm->support_ic_type == ODM_RTL8710B ||
+		    dm->support_ic_type == ODM_RTL8192F ||
+		    dm->support_ic_type == ODM_RTL8195B ||
+		    dm->support_ic_type == ODM_RTL8721D) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
+		} else {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
+			for (p = RF_PATH_A; p < c.rf_path_count; p++)
+				(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
+		}
+
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
+		for (p = RF_PATH_A; p < c.rf_path_count; p++)
+			cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
+
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
+
+		cali_info->thermal_value = thermal_value; /*Record last Power Tracking Thermal value*/
+	}
+
+	/* JJ ADD 20161014 */
+	if (dm->support_ic_type == (ODM_RTL8195B | ODM_RTL8721D)) {
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (rf->eeprom_thermal != 0xff)) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
+
+			if (thermal_value > rf->eeprom_thermal) {
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "Temperature(%d) higher than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			} else {
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "Temperature(%d) lower than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
+			}
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
+		}
+	}
+
+	/* Wait sacn to do IQK by RF Jenyu*/
+	if ((!*dm->is_scan_in_process) && (!iqk_info->rfk_forbidden)) {
+		/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
+		if (delta_IQK >= c.threshold_iqk) {
+			cali_info->thermal_value_iqk = thermal_value;
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+			if (!cali_info->is_iqk_in_progress)
+				(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
+		}
+	}
+
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
+
+	cali_info->tx_powercount = 0;
+}
+
+/* 3============================================================
+ * 3 IQ Calibration
+ * 3============================================================
+ */
+
+void
+odm_reset_iqk_result(
+	void					*dm_void
+)
+{
+	return;
+}
+
+u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
+{
+	
+}
+
+void
+odm_iq_calibrate(
+	struct dm_struct	*dm
+)
+{
+	
+}
+
+void phydm_rf_init(void		*dm_void)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_txpowertracking_init(dm);
+	
+	odm_clear_txpowertracking_state(dm);
+}
+
+void phydm_rf_watchdog(void		*dm_void)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	odm_txpowertracking_check(dm);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_iot.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_iot.h
new file mode 100644
index 000000000000..adf88a47ee76
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_iot.h
@@ -0,0 +1,125 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HALPHYRF_H__
+#define __HALPHYRF_H__
+
+#include "halrf/halrf_kfree.h"
+
+#if (RTL8821C_SUPPORT == 1)
+	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
+#endif
+
+#if (RTL8195B_SUPPORT == 1)
+//	#include "halrf/rtl8195b/halrf.h"
+	#include "halrf/rtl8195b/halrf_iqk_8195b.h"
+	#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
+	#include "halrf/rtl8195b/halrf_dpk_8195b.h"
+#endif
+
+#include "halrf/halrf_powertracking_iot.h"
+
+
+enum spur_cal_method {
+	PLL_RESET,
+	AFE_PHASE_SEL
+};
+
+enum pwrtrack_method {
+	BBSWING,
+	TXAGC,
+	MIX_MODE,
+	TSSI_MODE,
+	MIX_2G_TSSI_5G_MODE,
+	MIX_5G_TSSI_2G_MODE
+};
+
+typedef void	(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
+typedef void(*func_iqk)(void *, u8, u8, u8);
+typedef void	(*func_lck)(void *);
+typedef void	(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void	(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
+typedef void(*func_swing_xtal)(void *, s8 **, s8 **);
+typedef void(*func_set_xtal)(void *);
+
+struct txpwrtrack_cfg {
+	u8		swing_table_size_cck;
+	u8		swing_table_size_ofdm;
+	u8		threshold_iqk;
+	u8		threshold_dpk;
+	u8		average_thermal_num;
+	u8		rf_path_count;
+	u32		thermal_reg_addr;
+	func_set_pwr	odm_tx_pwr_track_set_pwr;
+	func_iqk	do_iqk;
+	func_lck		phy_lc_calibrate;
+	func_swing	get_delta_swing_table;
+	func_swing8814only	get_delta_swing_table8814only;
+	func_swing_xtal			get_delta_swing_xtal_table;
+	func_set_xtal			odm_txxtaltrack_set_xtal;
+};
+
+void
+configure_txpower_track(
+	void					*dm_void,
+	struct txpwrtrack_cfg	*config
+);
+
+
+void
+odm_clear_txpowertracking_state(
+	void					*dm_void
+);
+
+void
+odm_txpowertracking_callback_thermal_meter(
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	void					*dm_void
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void	*dm
+#else
+	void	*adapter
+#endif
+);
+
+
+
+#define ODM_TARGET_CHNL_NUM_2G_5G	59
+
+
+void
+odm_reset_iqk_result(
+	void					*dm_void
+);
+u8
+odm_get_right_chnl_place_for_iqk(
+	u8 chnl
+);
+
+void phydm_rf_init(void					*dm_void);
+void phydm_rf_watchdog(void					*dm_void);
+
+#endif	/*#ifndef __HALPHYRF_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.c
index d5d0b402cdbe..c323d666cf88 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -32,66 +33,76 @@
 	} while (0)
 
 void configure_txpower_track(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct _TXPWRTRACK_CFG	*p_config
+	struct dm_struct		*dm,
+	struct txpwrtrack_cfg	*config
 )
 {
 #if RTL8192E_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8192E)
-		configure_txpower_track_8192e(p_config);
+	if (dm->support_ic_type == ODM_RTL8192E)
+		configure_txpower_track_8192e(config);
 #endif
 #if RTL8821A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8821)
-		configure_txpower_track_8821a(p_config);
+	if (dm->support_ic_type == ODM_RTL8821)
+		configure_txpower_track_8821a(config);
 #endif
 #if RTL8812A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8812)
-		configure_txpower_track_8812a(p_config);
+	if (dm->support_ic_type == ODM_RTL8812)
+		configure_txpower_track_8812a(config);
 #endif
 #if RTL8188E_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8188E)
-		configure_txpower_track_8188e(p_config);
+	if (dm->support_ic_type == ODM_RTL8188E)
+		configure_txpower_track_8188e(config);
 #endif
 
 #if RTL8188F_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8188F)
-		configure_txpower_track_8188f(p_config);
+	if (dm->support_ic_type == ODM_RTL8188F)
+		configure_txpower_track_8188f(config);
 #endif
 
 #if RTL8723B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8723B)
-		configure_txpower_track_8723b(p_config);
+	if (dm->support_ic_type == ODM_RTL8723B)
+		configure_txpower_track_8723b(config);
 #endif
 
 #if RTL8814A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8814A)
-		configure_txpower_track_8814a(p_config);
+	if (dm->support_ic_type == ODM_RTL8814A)
+		configure_txpower_track_8814a(config);
 #endif
 
 #if RTL8703B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8703B)
-		configure_txpower_track_8703b(p_config);
+	if (dm->support_ic_type == ODM_RTL8703B)
+		configure_txpower_track_8703b(config);
 #endif
 
 #if RTL8822B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8822B)
-		configure_txpower_track_8822b(p_config);
+	if (dm->support_ic_type == ODM_RTL8822B)
+		configure_txpower_track_8822b(config);
 #endif
 
 #if RTL8723D_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8723D)
-		configure_txpower_track_8723d(p_config);
+	if (dm->support_ic_type == ODM_RTL8723D)
+		configure_txpower_track_8723d(config);
 #endif
 
 /* JJ ADD 20161014 */
 #if RTL8710B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8710B)
-		configure_txpower_track_8710b(p_config);
+	if (dm->support_ic_type == ODM_RTL8710B)
+		configure_txpower_track_8710b(config);
 #endif
 
 #if RTL8821C_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8821C)
-		configure_txpower_track_8821c(p_config);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		configure_txpower_track_8821c(config);
+#endif
+
+#if RTL8192F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192F)
+		configure_txpower_track_8192f(config);
+#endif
+
+#if RTL8822C_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8822C)
+		configure_txpower_track_8822c(config);
 #endif
 
 }
@@ -106,75 +117,75 @@ void configure_txpower_track(
  * ********************************************************************** */
 void
 odm_clear_txpowertracking_state(
-	struct PHY_DM_STRUCT		*p_dm
+	struct dm_struct		*dm
 )
 {
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(p_dm->adapter);
+	PHAL_DATA_TYPE	hal_data = GET_HAL_DATA((PADAPTER)(dm->adapter));
 	u8			p = 0;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
 
-	p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->default_cck_index;
-	p_rf_calibrate_info->bb_swing_idx_cck = p_rf_calibrate_info->default_cck_index;
-	p_rf_calibrate_info->CCK_index = 0;
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
+	cali_info->CCK_index = 0;
 
 	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
-		p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->bb_swing_idx_ofdm[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->OFDM_index[p] = p_rf_calibrate_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
 
-		p_rf_calibrate_info->power_index_offset[p] = 0;
-		p_rf_calibrate_info->delta_power_index[p] = 0;
-		p_rf_calibrate_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
 
-		p_rf_calibrate_info->absolute_ofdm_swing_idx[p] = 0;    /* Initial Mix mode power tracking*/
-		p_rf_calibrate_info->remnant_ofdm_swing_idx[p] = 0;
-		p_rf_calibrate_info->kfree_offset[p] = 0;
+		cali_info->absolute_ofdm_swing_idx[p] = 0;    /* Initial Mix mode power tracking*/
+		cali_info->remnant_ofdm_swing_idx[p] = 0;
+		cali_info->kfree_offset[p] = 0;
 	}
 
-	p_rf_calibrate_info->modify_tx_agc_flag_path_a = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->modify_tx_agc_flag_path_b = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->modify_tx_agc_flag_path_c = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->modify_tx_agc_flag_path_d = false;       /*Initial at Modify Tx Scaling mode*/
-	p_rf_calibrate_info->remnant_cck_swing_idx = 0;
-	p_rf_calibrate_info->thermal_value = p_hal_data->eeprom_thermal_meter;
+	cali_info->modify_tx_agc_flag_path_a = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_b = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_c = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->modify_tx_agc_flag_path_d = false;       /*Initial at Modify Tx Scaling mode*/
+	cali_info->remnant_cck_swing_idx = 0;
+	cali_info->thermal_value = hal_data->eeprom_thermal_meter;
 
-	p_rf_calibrate_info->modify_tx_agc_value_cck = 0;			/* modify by Mingzhi.Guo */
-	p_rf_calibrate_info->modify_tx_agc_value_ofdm = 0;		/* modify by Mingzhi.Guo */
+	cali_info->modify_tx_agc_value_cck = 0;			/* modify by Mingzhi.Guo */
+	cali_info->modify_tx_agc_value_ofdm = 0;		/* modify by Mingzhi.Guo */
 
 }
 
 void
 odm_txpowertracking_callback_thermal_meter(
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm
+	struct dm_struct		*dm
 #else
-	struct _ADAPTER	*adapter
+	void	*adapter
 #endif
 )
 {
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	struct dm_struct		*dm = &hal_data->DM_OutSrc;
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->odmpriv;
+	struct dm_struct		*dm = &hal_data->odmpriv;
 #endif
 #endif
 
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
- 	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+ 	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
 	u8			thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
 	s8			diff_DPK[4] = {0};
 	u8			thermal_value_avg_count = 0;
-	u32			thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
+	u32			thermal_value_avg = 0, regc80, regcd0, regcd4, regab4, regc88, rege14, reg848,reg838, reg86c;
 
 	u8			OFDM_min_index = 0;  /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
-	u8			indexforchannel = 0; /* get_right_chnl_place_for_iqk(p_hal_data->current_channel) */
-	u8			power_tracking_type = p_hal_data->RfPowerTrackingType;
+	u8			indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
+	u8			power_tracking_type = hal_data->RfPowerTrackingType;
 	u8			xtal_offset_eanble = 0;
 	s8			thermal_value_temp = 0;
 
-	struct _TXPWRTRACK_CFG	c;
+	struct txpwrtrack_cfg	c;
 
 	/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
 	u8			*delta_swing_table_idx_tup_a = NULL;
@@ -192,46 +203,46 @@ odm_txpowertracking_callback_thermal_meter(
 
 	/* 4 2. Initilization ( 7 steps in total ) */
 
-	configure_txpower_track(p_dm, &c);
+	configure_txpower_track(dm, &c);
 
-	(*c.get_delta_swing_table)(p_dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
+	(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
 		(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
 
-	if (p_dm->support_ic_type & ODM_RTL8814A)	/*for 8814 path C & D*/
-		(*c.get_delta_swing_table8814only)(p_dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
+	if (dm->support_ic_type & ODM_RTL8814A)	/*for 8814 path C & D*/
+		(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
 			(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
 	/* JJ ADD 20161014 */
-	if (p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B))	/*for Xtal Offset*/
-		(*c.get_delta_swing_xtal_table)(p_dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
+	if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F))	/*for Xtal Offset*/
+		(*c.get_delta_swing_xtal_table)(dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
 
 
-	p_rf_calibrate_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
-	p_rf_calibrate_info->is_txpowertracking_init = true;
+	cali_info->txpowertracking_callback_cnt++;	/*cosa add for debug*/
+	cali_info->is_txpowertracking_init = true;
 
-	/*p_rf_calibrate_info->txpowertrack_control = p_hal_data->txpowertrack_control;
+	/*cali_info->txpowertrack_control = hal_data->txpowertrack_control;
 	<Kordan> We should keep updating the control variable according to HalData.
 	<Kordan> rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 #if (MP_DRIVER == 1)
-	p_rf_calibrate_info->rega24 = 0x090e1317;
+	cali_info->rega24 = 0x090e1317;
 #endif
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	if (*(p_dm->p_mp_mode) == true)
-		p_rf_calibrate_info->rega24 = 0x090e1317;
+	if (*(dm->mp_mode) == true)
+		cali_info->rega24 = 0x090e1317;
 #endif
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("===>odm_txpowertracking_callback_thermal_meter\n p_rf_calibrate_info->bb_swing_idx_cck_base: %d, p_rf_calibrate_info->bb_swing_idx_ofdm_base[A]: %d, p_rf_calibrate_info->default_ofdm_index: %d\n",
-		p_rf_calibrate_info->bb_swing_idx_cck_base, p_rf_calibrate_info->bb_swing_idx_ofdm_base[RF_PATH_A], p_rf_calibrate_info->default_ofdm_index));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
+		cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("p_rf_calibrate_info->txpowertrack_control=%d,  p_hal_data->eeprom_thermal_meter %d\n", p_rf_calibrate_info->txpowertrack_control,  p_hal_data->eeprom_thermal_meter));
-	thermal_value = (u8)odm_get_rf_reg(p_dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		"cali_info->txpowertrack_control=%d,  hal_data->eeprom_thermal_meter %d\n", cali_info->txpowertrack_control,  hal_data->eeprom_thermal_meter);
+	thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);	/* 0x42: RF Reg[15:10] 88E */
 
-	thermal_value_temp = thermal_value + phydm_get_thermal_offset(p_dm);
+	thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("thermal_value_temp(%d) = thermal_value(%d) + power_time_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(p_dm)));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		"thermal_value_temp(%d) = thermal_value(%d) + power_time_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
 
 	if (thermal_value_temp > 63)
 		thermal_value = 63;
@@ -241,102 +252,114 @@ odm_txpowertracking_callback_thermal_meter(
 		thermal_value = thermal_value_temp;
 
 	/*add log by zhao he, check c80/c94/c14/ca0 value*/
-	if (p_dm->support_ic_type == ODM_RTL8723D) {
-		regc80 = odm_get_bb_reg(p_dm, 0xc80, MASKDWORD);
-		regcd0 = odm_get_bb_reg(p_dm, 0xcd0, MASKDWORD);
-		regcd4 = odm_get_bb_reg(p_dm, 0xcd4, MASKDWORD);
-		regab4 = odm_get_bb_reg(p_dm, 0xab4, 0x000007FF);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4));
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, R_0xab4, 0x000007FF);
+		RF_DBG(dm, DBG_RF_IQK, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
 	}
 
 	/* JJ ADD 20161014 */
-	if (p_dm->support_ic_type == ODM_RTL8710B) {
-		regc80 = odm_get_bb_reg(p_dm, 0xc80, MASKDWORD);
-		regcd0 = odm_get_bb_reg(p_dm, 0xcd0, MASKDWORD);
-		regcd4 = odm_get_bb_reg(p_dm, 0xcd4, MASKDWORD);
-		regab4 = odm_get_bb_reg(p_dm, 0xab4, 0x000007FF);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4));
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
+		regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
+		regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, R_0xab4, 0x000007FF);
+		RF_DBG(dm, DBG_RF_IQK, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
+	}
+	/* Winnita add 20171205 */
+	if (dm->support_ic_type == ODM_RTL8192F) {
+		regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
+		regc88 = odm_get_bb_reg(dm, R_0xc88, MASKDWORD);
+		regab4 = odm_get_bb_reg(dm, R_0xab4, MASKDWORD);
+		rege14 = odm_get_bb_reg(dm, R_0xe14, MASKDWORD);
+		reg848 = odm_get_bb_reg(dm, R_0x848, MASKDWORD);
+		reg838 = odm_get_bb_reg(dm, R_0x838, MASKDWORD);
+		reg86c = odm_get_bb_reg(dm, R_0x86c, MASKDWORD);
+		RF_DBG(dm, DBG_RF_IQK, "0xc80 = 0x%x 0xc88 = 0x%x 0xab4 = 0x%x 0xe14 = 0x%x\n", regc80, regc88, regab4, rege14);
+		RF_DBG(dm, DBG_RF_IQK, "0x848 = 0x%x 0x838 = 0x%x 0x86c = 0x%x\n", reg848, reg838, reg86c);
 	}
 
-	if (!p_rf_calibrate_info->txpowertrack_control)
+	if (!cali_info->txpowertrack_control)
 		return;
 
-	if (p_hal_data->eeprom_thermal_meter == 0xff) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no pg, p_hal_data->eeprom_thermal_meter = 0x%x\n", p_hal_data->eeprom_thermal_meter));
+	if (hal_data->eeprom_thermal_meter == 0xff) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", hal_data->eeprom_thermal_meter);
 		return;
 	}
 
 	/*4 3. Initialize ThermalValues of rf_calibrate_info*/
 
-	if (p_rf_calibrate_info->is_reloadtxpowerindex)
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("reload ofdm index for band switch\n"));
+	if (cali_info->is_reloadtxpowerindex)
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "reload ofdm index for band switch\n");
 
 	/*4 4. Calculate average thermal meter*/
 
-	p_rf_calibrate_info->thermal_value_avg[p_rf_calibrate_info->thermal_value_avg_index] = thermal_value;
-	p_rf_calibrate_info->thermal_value_avg_index++;
-	if (p_rf_calibrate_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
-		p_rf_calibrate_info->thermal_value_avg_index = 0;
+	cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
+	cali_info->thermal_value_avg_index++;
+	if (cali_info->thermal_value_avg_index == c.average_thermal_num)   /*Average times =  c.average_thermal_num*/
+		cali_info->thermal_value_avg_index = 0;
 
 	for (i = 0; i < c.average_thermal_num; i++) {
-		if (p_rf_calibrate_info->thermal_value_avg[i]) {
-			thermal_value_avg += p_rf_calibrate_info->thermal_value_avg[i];
+		if (cali_info->thermal_value_avg[i]) {
+			thermal_value_avg += cali_info->thermal_value_avg[i];
 			thermal_value_avg_count++;
 		}
 	}
 
 	if (thermal_value_avg_count) {            /* Calculate Average thermal_value after average enough times */
 		thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
-		p_rf_calibrate_info->thermal_value_delta = thermal_value - p_hal_data->eeprom_thermal_meter;
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, p_hal_data->eeprom_thermal_meter));
+		cali_info->thermal_value_delta = thermal_value - hal_data->eeprom_thermal_meter;
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, hal_data->eeprom_thermal_meter);
 	}
 
 	/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
 
 	/* "delta" here is used to determine whether thermal value changes or not. */
-	delta	= (thermal_value > p_rf_calibrate_info->thermal_value) ? (thermal_value - p_rf_calibrate_info->thermal_value) : (p_rf_calibrate_info->thermal_value - thermal_value);
-	delta_LCK = (thermal_value > p_rf_calibrate_info->thermal_value_lck) ? (thermal_value - p_rf_calibrate_info->thermal_value_lck) : (p_rf_calibrate_info->thermal_value_lck - thermal_value);
-	delta_IQK = (thermal_value > p_rf_calibrate_info->thermal_value_iqk) ? (thermal_value - p_rf_calibrate_info->thermal_value_iqk) : (p_rf_calibrate_info->thermal_value_iqk - thermal_value);
-
-	if (p_rf_calibrate_info->thermal_value_iqk == 0xff) {	/*no PG, use thermal value for IQK*/
-		p_rf_calibrate_info->thermal_value_iqk = thermal_value;
-		delta_IQK = (thermal_value > p_rf_calibrate_info->thermal_value_iqk) ? (thermal_value - p_rf_calibrate_info->thermal_value_iqk) : (p_rf_calibrate_info->thermal_value_iqk - thermal_value);
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, use thermal_value for IQK\n"));
+	delta	= (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
+	delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
+	delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+
+	if (cali_info->thermal_value_iqk == 0xff) {	/*no PG, use thermal value for IQK*/
+		cali_info->thermal_value_iqk = thermal_value;
+		delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no PG, use thermal_value for IQK\n");
 	}
 
 	for (p = RF_PATH_A; p < c.rf_path_count; p++)
-		diff_DPK[p] = (s8)thermal_value - (s8)p_rf_calibrate_info->dpk_thermal[p];
+		diff_DPK[p] = (s8)thermal_value - (s8)cali_info->dpk_thermal[p];
 
 	/*4 6. If necessary, do LCK.*/
 
-	if (!(p_dm->support_ic_type & ODM_RTL8821)) {	/*no PG, do LCK at initial status*/
-		if (p_rf_calibrate_info->thermal_value_lck == 0xff) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("no PG, do LCK\n"));
-			p_rf_calibrate_info->thermal_value_lck = thermal_value;
+	if (!(dm->support_ic_type & ODM_RTL8821)) {	/*no PG, do LCK at initial status*/
+		if (cali_info->thermal_value_lck == 0xff) {
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no PG, do LCK\n");
+			cali_info->thermal_value_lck = thermal_value;
 
 			/*Use RTLCK, so close power tracking driver LCK*/
-			if ((!(p_dm->support_ic_type & ODM_RTL8814A)) && (!(p_dm->support_ic_type & ODM_RTL8822B))) {
+			if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
 				if (c.phy_lc_calibrate)
-					(*c.phy_lc_calibrate)(p_dm);
+					(*c.phy_lc_calibrate)(dm);
 			}
 
-			delta_LCK = (thermal_value > p_rf_calibrate_info->thermal_value_lck) ? (thermal_value - p_rf_calibrate_info->thermal_value_lck) : (p_rf_calibrate_info->thermal_value_lck - thermal_value);
+			delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
 		}
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
 
 		/* Wait sacn to do LCK by RF Jenyu*/
-		if( (*p_dm->p_is_scan_in_process == false) && (!p_iqk_info->rfk_forbidden)) {
+		if( (*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
 			/* Delta temperature is equal to or larger than 20 centigrade.*/
 			if (delta_LCK >= c.threshold_iqk) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk));
-				p_rf_calibrate_info->thermal_value_lck = thermal_value;
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
+				cali_info->thermal_value_lck = thermal_value;
 
 				/*Use RTLCK, so close power tracking driver LCK*/
-				if ((!(p_dm->support_ic_type & ODM_RTL8814A)) && (!(p_dm->support_ic_type & ODM_RTL8822B))) {
+				if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
 					if (c.phy_lc_calibrate)
-						(*c.phy_lc_calibrate)(p_dm);
+						(*c.phy_lc_calibrate)(dm);
 				}
 			}
 		}
@@ -344,12 +367,12 @@ odm_txpowertracking_callback_thermal_meter(
 
 	/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
 
-	if (delta > 0 && p_rf_calibrate_info->txpowertrack_control) {
+	if (delta > 0 && cali_info->txpowertrack_control) {
 		/* "delta" here is used to record the absolute value of differrence. */
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		delta = thermal_value > p_hal_data->eeprom_thermal_meter ? (thermal_value - p_hal_data->eeprom_thermal_meter) : (p_hal_data->eeprom_thermal_meter - thermal_value);
+		delta = thermal_value > hal_data->eeprom_thermal_meter ? (thermal_value - hal_data->eeprom_thermal_meter) : (hal_data->eeprom_thermal_meter - thermal_value);
 #else
-		delta = (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - p_dm->priv->pmib->dot11RFEntry.ther) : (p_dm->priv->pmib->dot11RFEntry.ther - thermal_value);
+		delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
 #endif
 		if (delta >= TXPWR_TRACK_TABLE_SIZE)
 			delta = TXPWR_TRACK_TABLE_SIZE - 1;
@@ -357,64 +380,64 @@ odm_txpowertracking_callback_thermal_meter(
 		/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		if (thermal_value > p_hal_data->eeprom_thermal_meter) {
+		if (thermal_value > hal_data->eeprom_thermal_meter) {
 #else
-		if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) {
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
 #endif
 
 			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-				p_rf_calibrate_info->delta_power_index_last[p] = p_rf_calibrate_info->delta_power_index[p];	/*recording poer index offset*/
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
 				switch (p) {
 				case RF_PATH_B:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
 
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_b[delta];       /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_b[delta];       /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 
 				case RF_PATH_C:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
 
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_c[delta];       /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_c[delta];       /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 
 				case RF_PATH_D:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
 
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_d[delta];       /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_d[delta];       /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 
 				default:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
 
-					p_rf_calibrate_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_a[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is higher and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  delta_swing_table_idx_tup_a[delta];        /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 				}
 			}
 			/* JJ ADD 20161014 */
-			if (p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F)) {
 				/*Save xtal_offset from Xtal table*/
-				p_rf_calibrate_info->xtal_offset_last = p_rf_calibrate_info->xtal_offset;	/*recording last Xtal offset*/
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]));
-				p_rf_calibrate_info->xtal_offset = delta_swing_table_xtal_up[delta];
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
 
-				if (p_rf_calibrate_info->xtal_offset_last == p_rf_calibrate_info->xtal_offset)
+				if (cali_info->xtal_offset_last == cali_info->xtal_offset)
 					xtal_offset_eanble = 0;
 				else
 					xtal_offset_eanble = 1;
@@ -422,55 +445,55 @@ odm_txpowertracking_callback_thermal_meter(
 
 		} else {
 			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-				p_rf_calibrate_info->delta_power_index_last[p] = p_rf_calibrate_info->delta_power_index[p];	/*recording poer index offset*/
+				cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p];	/*recording poer index offset*/
 
 				switch (p) {
 				case RF_PATH_B:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_b[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_b[delta];        /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 
 				case RF_PATH_C:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_c[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_c[delta];        /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 
 				case RF_PATH_D:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_d[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_d[delta];        /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 
 				default:
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]));
-					p_rf_calibrate_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
-					p_rf_calibrate_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_a[delta];        /*Record delta swing for mix mode power tracking*/
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-						("******Temp is lower and p_rf_calibrate_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", p_rf_calibrate_info->absolute_ofdm_swing_idx[p]));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
+					cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
+					cali_info->absolute_ofdm_swing_idx[p] =  -1 * delta_swing_table_idx_tdown_a[delta];        /*Record delta swing for mix mode power tracking*/
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+						"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
 					break;
 				}
 			}
 			/* JJ ADD 20161014 */
-			if (p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+			if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F)) {
 				/*Save xtal_offset from Xtal table*/
-				p_rf_calibrate_info->xtal_offset_last = p_rf_calibrate_info->xtal_offset;	/*recording last Xtal offset*/
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]));
-				p_rf_calibrate_info->xtal_offset = delta_swing_table_xtal_down[delta];
+				cali_info->xtal_offset_last = cali_info->xtal_offset;	/*recording last Xtal offset*/
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					"[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
+				cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
 
-				if (p_rf_calibrate_info->xtal_offset_last == p_rf_calibrate_info->xtal_offset)
+				if (cali_info->xtal_offset_last == cali_info->xtal_offset)
 					xtal_offset_eanble = 0;
 				else
 					xtal_offset_eanble = 1;
@@ -479,244 +502,246 @@ odm_txpowertracking_callback_thermal_meter(
 		}
 
 		for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				"\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
 
-			if (p_rf_calibrate_info->delta_power_index[p] == p_rf_calibrate_info->delta_power_index_last[p])         /*If Thermal value changes but lookup table value still the same*/
-				p_rf_calibrate_info->power_index_offset[p] = 0;
+			if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p])         /*If Thermal value changes but lookup table value still the same*/
+				cali_info->power_index_offset[p] = 0;
 			else
-				p_rf_calibrate_info->power_index_offset[p] = p_rf_calibrate_info->delta_power_index[p] - p_rf_calibrate_info->delta_power_index_last[p];      /*Power index diff between 2 times Power Tracking*/
+				cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p];      /*Power index diff between 2 times Power Tracking*/
 
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, p_rf_calibrate_info->power_index_offset[p], p_rf_calibrate_info->delta_power_index[p], p_rf_calibrate_info->delta_power_index_last[p]));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				"[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
 
-			p_rf_calibrate_info->OFDM_index[p] = p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] + p_rf_calibrate_info->power_index_offset[p];
-			p_rf_calibrate_info->CCK_index = p_rf_calibrate_info->bb_swing_idx_cck_base + p_rf_calibrate_info->power_index_offset[p];
+			cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
+			cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
 
-			p_rf_calibrate_info->bb_swing_idx_cck = p_rf_calibrate_info->CCK_index;
-			p_rf_calibrate_info->bb_swing_idx_ofdm[p] = p_rf_calibrate_info->OFDM_index[p];
+			cali_info->bb_swing_idx_cck = cali_info->CCK_index;
+			cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
 
 			/*************Print BB Swing base and index Offset*************/
 
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", p_rf_calibrate_info->bb_swing_idx_cck, p_rf_calibrate_info->bb_swing_idx_cck_base, p_rf_calibrate_info->power_index_offset[p]));
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", p_rf_calibrate_info->bb_swing_idx_ofdm[p], p, p_rf_calibrate_info->bb_swing_idx_ofdm_base[p], p_rf_calibrate_info->power_index_offset[p]));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
 
 			/*4 7.1 Handle boundary conditions of index.*/
 
-			if (p_rf_calibrate_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
-				p_rf_calibrate_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
-			else if (p_rf_calibrate_info->OFDM_index[p] <= OFDM_min_index)
-				p_rf_calibrate_info->OFDM_index[p] = OFDM_min_index;
+			if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
+				cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
+			else if (cali_info->OFDM_index[p] <= OFDM_min_index)
+				cali_info->OFDM_index[p] = OFDM_min_index;
 		}
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("\n\n========================================================================================================\n"));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			"\n\n========================================================================================================\n");
 
-		if (p_rf_calibrate_info->CCK_index > c.swing_table_size_cck - 1)
-			p_rf_calibrate_info->CCK_index = c.swing_table_size_cck - 1;
-		else if (p_rf_calibrate_info->CCK_index <= 0)
-			p_rf_calibrate_info->CCK_index = 0;
+		if (cali_info->CCK_index > c.swing_table_size_cck - 1)
+			cali_info->CCK_index = c.swing_table_size_cck - 1;
+		else if (cali_info->CCK_index <= 0)
+			cali_info->CCK_index = 0;
 	} else {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, p_rf_calibrate_info->thermal_value: %d\n",
-			p_rf_calibrate_info->txpowertrack_control, thermal_value, p_rf_calibrate_info->thermal_value));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			"The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
+			cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
 
 		for (p = RF_PATH_A; p < c.rf_path_count; p++)
-			p_rf_calibrate_info->power_index_offset[p] = 0;
+			cali_info->power_index_offset[p] = 0;
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
-		p_rf_calibrate_info->CCK_index, p_rf_calibrate_info->bb_swing_idx_cck_base));       /*Print Swing base & current*/
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
+		cali_info->CCK_index, cali_info->bb_swing_idx_cck_base);       /*Print Swing base & current*/
 
 	for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
-			p_rf_calibrate_info->OFDM_index[p], p, p_rf_calibrate_info->bb_swing_idx_ofdm_base[p]));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
+			cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
 	}
 
-	if ((p_dm->support_ic_type & ODM_RTL8814A)) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("power_tracking_type=%d\n", power_tracking_type));
+	if ((dm->support_ic_type & ODM_RTL8814A)) {
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "power_tracking_type=%d\n", power_tracking_type);
 
 		if (power_tracking_type == 0) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 		} else if (power_tracking_type == 1) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_2G_TSSI_5G_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_2G_TSSI_5G_MODE, p, 0);
 		} else if (power_tracking_type == 2) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_5G_TSSI_2G_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_5G_TSSI_2G_MODE, p, 0);
 		} else if (power_tracking_type == 3) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking TSSI MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI MODE**********\n");
 			for (p = RF_PATH_A; p < c.rf_path_count; p++)
-				(*c.odm_tx_pwr_track_set_pwr)(p_dm, TSSI_MODE, p, 0);
+				(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
 		}
-		p_rf_calibrate_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
 
-	} else if ((p_rf_calibrate_info->power_index_offset[RF_PATH_A] != 0 ||
-		p_rf_calibrate_info->power_index_offset[RF_PATH_B] != 0 ||
-		p_rf_calibrate_info->power_index_offset[RF_PATH_C] != 0 ||
-		p_rf_calibrate_info->power_index_offset[RF_PATH_D] != 0) &&
-		p_rf_calibrate_info->txpowertrack_control && (p_hal_data->eeprom_thermal_meter != 0xff)) {
+	} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
+		cali_info->power_index_offset[RF_PATH_B] != 0 ||
+		cali_info->power_index_offset[RF_PATH_C] != 0 ||
+		cali_info->power_index_offset[RF_PATH_D] != 0) &&
+		cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
 		/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
 
-		p_rf_calibrate_info->is_tx_power_changed = true;	/*Always true after Tx Power is adjusted by power tracking.*/
+		cali_info->is_tx_power_changed = true;	/*Always true after Tx Power is adjusted by power tracking.*/
 		/*  */
 		/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
 		/* to increase TX power. Otherwise, EVM will be bad. */
 		/*  */
 		/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
-		if (thermal_value > p_rf_calibrate_info->thermal_value) {
+		if (thermal_value > cali_info->thermal_value) {
 			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, p_rf_calibrate_info->power_index_offset[p], delta, thermal_value, p_hal_data->eeprom_thermal_meter, p_rf_calibrate_info->thermal_value));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
 			}
-		} else if (thermal_value < p_rf_calibrate_info->thermal_value) {	/*Low temperature*/
+		} else if (thermal_value < cali_info->thermal_value) {	/*Low temperature*/
 			for (p = RF_PATH_A; p < c.rf_path_count; p++) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
-					p, p_rf_calibrate_info->power_index_offset[p], delta, thermal_value, p_hal_data->eeprom_thermal_meter, p_rf_calibrate_info->thermal_value));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
+					p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
 			}
 		}
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		if (thermal_value > p_hal_data->eeprom_thermal_meter)
+		if (thermal_value > hal_data->eeprom_thermal_meter)
 #else
-		if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther)
+		if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
 #endif
 		{
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) higher than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
 
-			if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8821 ||
-			    p_dm->support_ic_type == ODM_RTL8812 || p_dm->support_ic_type == ODM_RTL8723B || p_dm->support_ic_type == ODM_RTL8814A ||
-			    p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8188F || p_dm->support_ic_type == ODM_RTL8822B ||
-			    p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8821C || p_dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B ||
+			    dm->support_ic_type == ODM_RTL8192F) {
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
 				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, 0);
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
 			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking BBSWING_MODE**********\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
 				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, p, indexforchannel);
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
 			}
 		} else {
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-				("Temperature(%d) lower than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-
-			if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8821 ||
-			    p_dm->support_ic_type == ODM_RTL8812 || p_dm->support_ic_type == ODM_RTL8723B || p_dm->support_ic_type == ODM_RTL8814A ||
-			    p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8188F || p_dm->support_ic_type == ODM_RTL8822B ||
-			    p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8821C || p_dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
-
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking MIX_MODE**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+
+			if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
+			    dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
+			    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
+			    dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B ||
+				dm->support_ic_type == ODM_RTL8192F) {
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
 				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, MIX_MODE, p, indexforchannel);
+					(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
 			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter POWER Tracking BBSWING_MODE**********\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
 				for (p = RF_PATH_A; p < c.rf_path_count; p++)
-					(*c.odm_tx_pwr_track_set_pwr)(p_dm, BBSWING, p, indexforchannel);
+					(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
 			}
 
 		}
 
-		p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
+		cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;    /*Record last time Power Tracking result as base.*/
 		for (p = RF_PATH_A; p < c.rf_path_count; p++)
-			p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] = p_rf_calibrate_info->bb_swing_idx_ofdm[p];
+			cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			("p_rf_calibrate_info->thermal_value = %d thermal_value= %d\n", p_rf_calibrate_info->thermal_value, thermal_value));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+			"cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
 
-		p_rf_calibrate_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
+		cali_info->thermal_value = thermal_value;         /*Record last Power Tracking Thermal value*/
 
 	}
 
 
-	if (p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
+	if (dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D ||
+		dm->support_ic_type == ODM_RTL8192F || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
 
-		if (xtal_offset_eanble != 0 && p_rf_calibrate_info->txpowertrack_control && (p_hal_data->eeprom_thermal_meter != 0xff)) {
+		if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
 
-			ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********Enter Xtal Tracking**********\n"));
+			RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-			if (thermal_value > p_hal_data->eeprom_thermal_meter) {
+			if (thermal_value > hal_data->eeprom_thermal_meter) {
 #else
-			if (thermal_value > p_dm->priv->pmib->dot11RFEntry.ther) {
+			if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
 #endif
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature(%d) higher than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-				(*c.odm_txxtaltrack_set_xtal)(p_dm);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
 			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-					("Temperature(%d) lower than PG value(%d)\n", thermal_value, p_hal_data->eeprom_thermal_meter));
-				(*c.odm_txxtaltrack_set_xtal)(p_dm);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+					"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
+				(*c.odm_txxtaltrack_set_xtal)(dm);
 			}
 		}
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("**********End Xtal Tracking**********\n"));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
 	}
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
 
 	/* Wait sacn to do IQK by RF Jenyu*/
-	if ((*p_dm->p_is_scan_in_process == false) && (!p_iqk_info->rfk_forbidden)) {
+	if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
 		if (!IS_HARDWARE_TYPE_8723B(adapter)) {
 			/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
 			if (delta_IQK >= c.threshold_iqk) {
-				p_rf_calibrate_info->thermal_value_iqk = thermal_value;
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk));
-				if (!p_rf_calibrate_info->is_iqk_in_progress)
-					(*c.do_iqk)(p_dm, delta_IQK, thermal_value, 8);
+				cali_info->thermal_value_iqk = thermal_value;
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
+				if (!cali_info->is_iqk_in_progress)
+					(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
 			}
 		}
 	}
-	if (p_rf_calibrate_info->dpk_thermal[RF_PATH_A] != 0) {
+	if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
 		if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
 			s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
 
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		}
 	}
-	if (p_rf_calibrate_info->dpk_thermal[RF_PATH_B] != 0) {
+	if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
 		if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
 			s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
 
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		} else {
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x1);
-			odm_set_bb_reg(p_dm, 0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
-			odm_set_bb_reg(p_dm, 0x82c, BIT(31), 0x0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
+			odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
 		}
 	}
 
 #endif
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("<===odm_txpowertracking_callback_thermal_meter\n"));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
 
-	p_rf_calibrate_info->tx_powercount = 0;
+	cali_info->tx_powercount = 0;
 }
 
 
@@ -727,7 +752,7 @@ odm_txpowertracking_callback_thermal_meter(
 
 void
 odm_reset_iqk_result(
-	struct PHY_DM_STRUCT	*p_dm
+	struct dm_struct	*dm
 )
 {
 	return;
@@ -754,64 +779,64 @@ u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
 
 void
 odm_iq_calibrate(
-	struct PHY_DM_STRUCT	*p_dm
+	struct dm_struct	*dm
 )
 {
-	struct _ADAPTER	*adapter = p_dm->adapter;
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	void	*adapter = dm->adapter;
+	struct dm_iqk_info	*iqk_info = &dm->IQK_info;
 	
-	RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("=>%s\n" , __FUNCTION__));
+	RF_DBG(dm, DBG_RF_IQK, "=>%s\n",__FUNCTION__);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (*p_dm->p_is_fcs_mode_enable)
+	if (*dm->is_fcs_mode_enable)
 		return;
 #endif
 
-	if ((p_dm->is_linked) && (!p_iqk_info->rfk_forbidden)) {
-		RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("interval=%d ch=%d prech=%d scan=%s\n", p_dm->linked_interval,
-			*p_dm->p_channel,  p_dm->pre_channel, *p_dm->p_is_scan_in_process == TRUE ? "TRUE":"FALSE"));
+	if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
+		RF_DBG(dm, DBG_RF_IQK, "interval=%d ch=%d prech=%d scan=%s\n", dm->linked_interval,
+		       *dm->channel,  dm->pre_channel, *dm->is_scan_in_process == TRUE ? "TRUE":"FALSE");
 
-		if (*p_dm->p_channel != p_dm->pre_channel) {
-			p_dm->pre_channel = *p_dm->p_channel;
-			p_dm->linked_interval = 0;
+		if (*dm->channel != dm->pre_channel) {
+			dm->pre_channel = *dm->channel;
+			dm->linked_interval = 0;
 		}
 
-		if ((p_dm->linked_interval < 3) && (!*p_dm->p_is_scan_in_process))
-			p_dm->linked_interval++;
+		if ((dm->linked_interval < 3) && (!*dm->is_scan_in_process))
+			dm->linked_interval++;
 
-		if (p_dm->linked_interval == 2)
+		if (dm->linked_interval == 2)
 			PHY_IQCalibrate(adapter, false);
 	} else
-		p_dm->linked_interval = 0;
+		dm->linked_interval = 0;
 
-		RT_TRACE(COMP_SCAN, ODM_DBG_LOUD, ("<=%s interval=%d ch=%d prech=%d scan=%s\n", __FUNCTION__, p_dm->linked_interval,
-			*p_dm->p_channel,  p_dm->pre_channel, *p_dm->p_is_scan_in_process == TRUE?"TRUE":"FALSE"));
+		RF_DBG(dm, DBG_RF_IQK, "<=%s interval=%d ch=%d prech=%d scan=%s\n", __FUNCTION__, dm->linked_interval,
+			*dm->channel,  dm->pre_channel, *dm->is_scan_in_process == TRUE?"TRUE":"FALSE");
 }
 
-void phydm_rf_init(struct PHY_DM_STRUCT		*p_dm)
+void phydm_rf_init(struct dm_struct		*dm)
 {
 
-	odm_txpowertracking_init(p_dm);
+	odm_txpowertracking_init(dm);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	odm_clear_txpowertracking_state(p_dm);
+	odm_clear_txpowertracking_state(dm);
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		phy_iq_calibrate_8814a_init(p_dm);
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phy_iq_calibrate_8814a_init(dm);
 #endif
 #endif
 
 }
 
-void phydm_rf_watchdog(struct PHY_DM_STRUCT		*p_dm)
+void phydm_rf_watchdog(struct dm_struct		*dm)
 {
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	odm_txpowertracking_check(p_dm);
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-		odm_iq_calibrate(p_dm);
+	odm_txpowertracking_check(dm);
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		odm_iq_calibrate(dm);
 #endif
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.h
index bb6f2555a481..78cc63ddc6ef 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halphyrf_win.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -13,8 +14,8 @@
  *
  *****************************************************************************/
 
-#ifndef __HAL_PHY_RF_H__
-#define __HAL_PHY_RF_H__
+#ifndef __HALPHYRF_H__
+#define __HALPHYRF_H__
 
 #if (RTL8814A_SUPPORT == 1)
 	#include "halrf/rtl8814a/halrf_iqk_8814a.h"
@@ -31,6 +32,17 @@
 	#include "halrf/rtl8821c/halrf_iqk_8821c.h"
 #endif
 
+#if (RTL8195B_SUPPORT == 1)
+//	#include "halrf/rtl8195b/halrf.h"
+	#include "halrf/rtl8195b/halrf_iqk_8195b.h"
+	#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
+	#include "halrf/rtl8195b/halrf_dpk_8195b.h"
+#endif
+
+#if (RTL8814B_SUPPORT == 1)
+	#include "halrf/rtl8814b/halrf_iqk_8814b.h"
+#endif
+
 enum spur_cal_method {
 	PLL_RESET,
 	AFE_PHASE_SEL
@@ -54,7 +66,7 @@ typedef void (*func_swing_xtal)(void *, s8 **, s8 **);
 typedef void (*func_set_xtal)(void *);
 typedef void(*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
 
-struct _TXPWRTRACK_CFG {
+struct txpwrtrack_cfg {
 	u8		swing_table_size_cck;
 	u8		swing_table_size_ofdm;
 	u8		threshold_iqk;
@@ -74,22 +86,22 @@ struct _TXPWRTRACK_CFG {
 
 void
 configure_txpower_track(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct _TXPWRTRACK_CFG	*p_config
+	struct dm_struct		*dm,
+	struct txpwrtrack_cfg	*config
 );
 
 
 void
 odm_clear_txpowertracking_state(
-	struct PHY_DM_STRUCT		*p_dm
+	struct dm_struct		*dm
 );
 
 void
 odm_txpowertracking_callback_thermal_meter(
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm
+	struct dm_struct		*dm
 #else
-	struct _ADAPTER	*adapter
+	void	*adapter
 #endif
 );
 
@@ -100,15 +112,15 @@ odm_txpowertracking_callback_thermal_meter(
 
 void
 odm_reset_iqk_result(
-	struct PHY_DM_STRUCT	*p_dm
+	struct dm_struct	*dm
 );
 u8
 odm_get_right_chnl_place_for_iqk(
 	u8 chnl
 );
 
-void odm_iq_calibrate(struct PHY_DM_STRUCT	*p_dm);
-void phydm_rf_init(struct PHY_DM_STRUCT		*p_dm);
-void phydm_rf_watchdog(struct PHY_DM_STRUCT		*p_dm);
+void odm_iq_calibrate(struct dm_struct	*dm);
+void phydm_rf_init(struct dm_struct		*dm);
+void phydm_rf_watchdog(struct dm_struct		*dm);
 
-#endif	/*  #ifndef __HAL_PHY_RF_H__ */
+#endif	/*#ifndef __HALPHYRF_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.c
index 33cdaf442fbd..987e44b0068e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,62 +9,50 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ * ************************************************************
+ */
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-void halrf_basic_profile(
-	void			*p_dm_void,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
+	RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
+void _iqk_page_switch(void *dm_void)
 {
-#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32 used = *_used;
-	u32 out_len = *_out_len;
-
-	/* HAL RF version List */
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-35s\n", "% HAL RF version %"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Power Tracking", HALRF_POWRTRACKING_VER));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "IQK", HALRF_IQK_VER));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "LCK", HALRF_LCK_VER));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "DPK", HALRF_DPK_VER));
-
-	*_used = used;
-	*_out_len = out_len;
-#endif
-}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-void
-_iqk_page_switch(
-		void			*p_dm_void)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	if (p_dm->support_ic_type == ODM_RTL8821C)	
-		odm_write_4byte(p_dm, 0x1b00, 0xf8000008);
-	else	
-		odm_write_4byte(p_dm, 0x1b00, 0xf800000a);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	else
+		odm_write_4byte(dm, 0x1b00, 0xf800000a);
 }
 
-u32 halrf_psd_log2base(IN u32 val)
+u32 halrf_psd_log2base(u32 val)
 {
-	u8	j;
-	u32	tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
-	u32	result, val_fractiond_b = 0, table_fraction[21] = {0, 432, 332, 274, 232, 200,
-				   174, 151, 132, 115, 100, 86, 74, 62, 51, 42,
-							   32, 23, 15, 7, 0
-							      };
+	u8 j;
+	u32 tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
+	u32 result, val_fractiond_b = 0;
+	u32 table_fraction[21] = {
+		0, 432, 332, 274, 232, 200, 174, 151, 132, 115,
+		100, 86, 74, 62, 51, 42, 32, 23, 15, 7, 0};
 
 	if (val == 0)
 		return 0;
@@ -78,7 +67,6 @@ u32 halrf_psd_log2base(IN u32 val)
 		shiftcount++;
 	}
 
-
 	val_integerd_b = shiftcount + 1;
 
 	tmp2 = 1;
@@ -94,604 +82,603 @@ u32 halrf_psd_log2base(IN u32 val)
 	val_fractiond_b = table_fraction[tindex];
 
 	result = val_integerd_b * 100 - val_fractiond_b;
-	
-	return result;
-
 
+	return result;
 }
 
-void phydm_get_iqk_cfir(
-	void *p_dm_void,
-	u8 idx,
-	u8 path,
-	boolean debug
-)
+void phydm_get_iqk_cfir(void *dm_void, u8 idx, u8 path, boolean debug)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
-	
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+
 	u8 i, ch;
 	u32 tmp;
+	u32 bit_mask_20_16 = BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16);
 
 	if (debug)
 		ch = 2;
 	else
 		ch = 0;
 
-		odm_set_bb_reg(p_dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
-		if (idx == 0)
-			odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
-		else
-			odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
-		odm_set_bb_reg(p_dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
-		for (i = 0; i < 8; i++) {
-			odm_set_bb_reg(p_dm, 0x1bd8, MASKDWORD, 0xe0000001 + (i * 4));
-			tmp = odm_get_bb_reg(p_dm, 0x1bfc, MASKDWORD);
-			p_iqk_info->IQK_CFIR_real[ch][path][idx][i] = (tmp & 0x0fff0000) >> 16;
-			p_iqk_info->IQK_CFIR_imag[ch][path][idx][i] = tmp & 0xfff;
-		}
-	odm_set_bb_reg(p_dm, 0x1bd8, MASKDWORD, 0x0);
-	odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+	odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0xf8000008 | path << 1);
+	if (idx == 0)
+		odm_set_bb_reg(dm, R_0x1b0c, BIT(13) | BIT(12), 0x3);
+	else
+		odm_set_bb_reg(dm, R_0x1b0c, BIT(13) | BIT(12), 0x1);
+	odm_set_bb_reg(dm, R_0x1bd4, bit_mask_20_16, 0x10);
+	for (i = 0; i < 8; i++) {
+		odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0xe0000001 + (i * 4));
+		tmp = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
+		iqk_info->iqk_cfir_real[ch][path][idx][i] =
+						(tmp & 0x0fff0000) >> 16;
+		iqk_info->iqk_cfir_imag[ch][path][idx][i] = tmp & 0xfff;
+	}
+	odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0x0);
+	odm_set_bb_reg(dm, R_0x1b0c, BIT(13) | BIT(12), 0x0);
 }
 
-void
-halrf_iqk_xym_enable(
-	struct PHY_DM_STRUCT *p_dm,
-	u8 xym_enable
-	)
+void halrf_iqk_xym_enable(struct dm_struct *dm, u8 xym_enable)
 {
-	struct _IQK_INFORMATION *p_iqk_info = &p_dm->IQK_info;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
 
 	if (xym_enable == 0)
-		p_iqk_info->xym_read = false;
+		iqk_info->xym_read = false;
 	else
-		p_iqk_info->xym_read = true;
+		iqk_info->xym_read = true;
 
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s %s\n", "xym_read = ", (p_iqk_info->xym_read ? "true": "false")));	
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s %s\n", "xym_read = ",
+	       (iqk_info->xym_read ? "true" : "false"));
 }
 
-void
-halrf_iqk_xym_read(
-	void *p_dm_void,
-	u8 path,
-	u8 xym_type /*0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
- )
+/*xym_type => 0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
+void halrf_iqk_xym_read(void *dm_void, u8 path, u8 xym_type)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION *p_iqk_info = &p_dm->IQK_info;	
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
 	u8 i, start, num;
 	u32 tmp1, tmp2;
 
-	if (!p_iqk_info->xym_read)
+	if (!iqk_info->xym_read)
 		return;
 
-	if (*p_dm->p_band_width == 0) {
+	if (*dm->band_width == 0) {
 		start = 3;
 		num = 4;
-	}else if (*p_dm->p_band_width == 1) { 
+	} else if (*dm->band_width == 1) {
 		start = 2;
 		num = 6;
-	}else {
+	} else {
 		start = 0;
-  		num = 10;
- 	}
-	
-	odm_write_4byte(p_dm, 0x1b00, 0xf8000008);
- 	tmp1 =  odm_read_4byte(p_dm, 0x1b1c);
-	odm_write_4byte(p_dm, 0x1b1c, 0xa2193c32);
-
- 	odm_write_4byte(p_dm, 0x1b00, 0xf800000a);
- 	tmp2 =  odm_read_4byte(p_dm, 0x1b1c);
-	odm_write_4byte(p_dm, 0x1b1c, 0xa2193c32);
-
-	for (path = 0; path < 2; path ++) {
-		odm_write_4byte(p_dm, 0x1b00, 0xf8000008 | path << 1);
-		switch(xym_type){
- 			case 0:
-				for (i = 0; i < num ;i++) {
-	   				odm_write_4byte(p_dm, 0x1b14, 0xe6+start+i);
-	   				odm_write_4byte(p_dm, 0x1b14, 0x0);
-	   				p_iqk_info->rx_xym[path][i] = odm_read_4byte(p_dm, 0x1b38);
-				}
+		num = 10;
+	}
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	tmp1 = odm_read_4byte(dm, 0x1b1c);
+	odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
+
+	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+	tmp2 = odm_read_4byte(dm, 0x1b1c);
+	odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
+
+	for (path = 0; path < 2; path++) {
+		odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
+		switch (xym_type) {
+		case 0:
+			for (i = 0; i < num; i++) {
+				odm_write_4byte(dm, 0x1b14, 0xe6 + start + i);
+				odm_write_4byte(dm, 0x1b14, 0x0);
+				iqk_info->rx_xym[path][i] =
+						odm_read_4byte(dm, 0x1b38);
+			}
 			break;
-			case 1:		
-				for (i = 0; i < num ;i++) {
-	   				odm_write_4byte(p_dm, 0x1b14, 0xe6+start+i);
-	   				odm_write_4byte(p_dm, 0x1b14, 0x0);
-	   				p_iqk_info->tx_xym[path][i] = odm_read_4byte(p_dm, 0x1b38);
-				}
+		case 1:
+			for (i = 0; i < num; i++) {
+				odm_write_4byte(dm, 0x1b14, 0xe6 + start + i);
+				odm_write_4byte(dm, 0x1b14, 0x0);
+				iqk_info->tx_xym[path][i] =
+						odm_read_4byte(dm, 0x1b38);
+			}
+			break;
+		case 2:
+			for (i = 0; i < 6; i++) {
+				odm_write_4byte(dm, 0x1b14, 0xe0 + i);
+				odm_write_4byte(dm, 0x1b14, 0x0);
+				iqk_info->gs1_xym[path][i] =
+						odm_read_4byte(dm, 0x1b38);
+			}
 			break;
-			case 2:		
-				for (i = 0; i < 6 ;i++) {
-	   				odm_write_4byte(p_dm, 0x1b14, 0xe0+i);
-	   				odm_write_4byte(p_dm, 0x1b14, 0x0);
-	   				p_iqk_info->gs1_xym[path][i] = odm_read_4byte(p_dm, 0x1b38);
-				}
+		case 3:
+			for (i = 0; i < 6; i++) {
+				odm_write_4byte(dm, 0x1b14, 0xe0 + i);
+				odm_write_4byte(dm, 0x1b14, 0x0);
+				iqk_info->gs2_xym[path][i] =
+						odm_read_4byte(dm, 0x1b38);
+			}
 			break;
-			case 3:		
-				for (i = 0; i < 6 ;i++) {
-	   				odm_write_4byte(p_dm, 0x1b14, 0xe0+i);
-	   				odm_write_4byte(p_dm, 0x1b14, 0x0);
-	   				p_iqk_info->gs2_xym[path][i] = odm_read_4byte(p_dm, 0x1b38);
-	  		}
-			break;			
-			case 4:		
-				for (i = 0; i < 6 ;i++) {
-	   				odm_write_4byte(p_dm, 0x1b14, 0xe0+i);
-	   				odm_write_4byte(p_dm, 0x1b14, 0x0);
-	   				p_iqk_info->rxk1_xym[path][i] = odm_read_4byte(p_dm, 0x1b38);
-	  		}
+		case 4:
+			for (i = 0; i < 6; i++) {
+				odm_write_4byte(dm, 0x1b14, 0xe0 + i);
+				odm_write_4byte(dm, 0x1b14, 0x0);
+				iqk_info->rxk1_xym[path][i] =
+						odm_read_4byte(dm, 0x1b38);
+			}
 			break;
-
 		}
-		odm_write_4byte(p_dm, 0x1b38, 0x20000000);
-		odm_write_4byte(p_dm, 0x1b00, 0xf8000008);
-		odm_write_4byte(p_dm, 0x1b1c, tmp1);
-		odm_write_4byte(p_dm, 0x1b00, 0xf800000a);
-		odm_write_4byte(p_dm, 0x1b1c, tmp2);
-		_iqk_page_switch(p_dm);
+		odm_write_4byte(dm, 0x1b38, 0x20000000);
+		odm_write_4byte(dm, 0x1b00, 0xf8000008);
+		odm_write_4byte(dm, 0x1b1c, tmp1);
+		odm_write_4byte(dm, 0x1b00, 0xf800000a);
+		odm_write_4byte(dm, 0x1b1c, tmp2);
+		_iqk_page_switch(dm);
 	}
 }
 
-void halrf_iqk_xym_show(
-	struct PHY_DM_STRUCT *p_dm,
-	u8 xym_type /*0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
- )
+/*xym_type => 0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
+void halrf_iqk_xym_show(struct dm_struct *dm, u8 xym_type)
 {
-	u8 num, path, path_num, i;		
-	struct _IQK_INFORMATION *p_iqk_info = &p_dm->IQK_info;	
+	u8 num, path, path_num, i;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
 
-	if (p_dm->rf_type ==RF_1T1R)
+	if (dm->rf_type == RF_1T1R)
 		path_num = 0x1;
-	else if (p_dm->rf_type ==RF_2T2R)
+	else if (dm->rf_type == RF_2T2R)
 		path_num = 0x2;
 	else
 		path_num = 0x4;
 
-	if (*p_dm->p_band_width == CHANNEL_WIDTH_20)
+	if (*dm->band_width == CHANNEL_WIDTH_20)
 		num = 4;
-	else if (*p_dm->p_band_width == CHANNEL_WIDTH_40)
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
 		num = 6;
 	else
 		num = 10;
-		
-	for (path = 0; path < path_num; path ++) {
-		switch (xym_type){
+
+	for (path = 0; path < path_num; path++) {
+		switch (xym_type) {
 		case 0:
-			for (i = 0 ; i < num; i ++)
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s %-2d: 0x%x\n",
-					(path == 0) ? "PATH A RX-XYM ": "PATH B RX-XYM", i, p_iqk_info->rx_xym[path][i]));
+			for (i = 0; i < num; i++)
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-20s %-2d: 0x%x\n",
+				       (path == 0) ? "PATH A RX-XYM " :
+				       "PATH B RX-XYM", i,
+				       iqk_info->rx_xym[path][i]);
 			break;
 		case 1:
-			for (i = 0 ; i < num; i ++)
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s %-2d: 0x%x\n",
-					(path == 0) ? "PATH A TX-XYM ": "PATH B TX-XYM", i, p_iqk_info->tx_xym[path][i]));
+			for (i = 0; i < num; i++)
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-20s %-2d: 0x%x\n",
+				       (path == 0) ? "PATH A TX-XYM " :
+				       "PATH B TX-XYM", i,
+				       iqk_info->tx_xym[path][i]);
 			break;
 		case 2:
-			for (i = 0 ; i < 6; i ++)
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s %-2d: 0x%x\n",
-					(path == 0) ? "PATH A GS1-XYM ": "PATH B GS1-XYM", i, p_iqk_info->gs1_xym[path][i]));
+			for (i = 0; i < 6; i++)
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-20s %-2d: 0x%x\n",
+				       (path == 0) ? "PATH A GS1-XYM " :
+				       "PATH B GS1-XYM", i,
+				       iqk_info->gs1_xym[path][i]);
 			break;
 		case 3:
-			for (i = 0 ; i < 6; i ++)
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s %-2d: 0x%x\n",
-					(path == 0) ? "PATH A GS2-XYM ": "PATH B GS2-XYM", i, p_iqk_info->gs2_xym[path][i]));
-			break;
-		case 4:			
-			for (i = 0 ; i < 6; i ++)
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s %-2d: 0x%x\n",
-					(path == 0) ? "PATH A RXK1-XYM ": "PATH B RXK1-XYM", i, p_iqk_info->rxk1_xym[path][i]));
+			for (i = 0; i < 6; i++)
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-20s %-2d: 0x%x\n",
+				       (path == 0) ? "PATH A GS2-XYM " :
+				       "PATH B GS2-XYM", i,
+				       iqk_info->gs2_xym[path][i]);
+			break;
+		case 4:
+			for (i = 0; i < 6; i++)
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-20s %-2d: 0x%x\n",
+				       (path == 0) ? "PATH A RXK1-XYM " :
+				       "PATH B RXK1-XYM", i,
+				       iqk_info->rxk1_xym[path][i]);
 			break;
 		}
 	}
 }
 
-
-void
-halrf_iqk_xym_dump(
-	void *p_dm_void
- )
+void halrf_iqk_xym_dump(void *dm_void)
 {
 	u32 tmp1, tmp2;
- 	struct PHY_DM_STRUCT	 *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	odm_write_4byte(p_dm, 0x1b00, 0xf8000008);
- 	tmp1 =  odm_read_4byte(p_dm, 0x1b1c);
- 	odm_write_4byte(p_dm, 0x1b00, 0xf800000a);
- 	tmp2 =  odm_read_4byte(p_dm, 0x1b1c);
- 	/*halrf_iqk_xym_read(p_dm, xym_type);*/
- 	odm_write_4byte(p_dm, 0x1b00, 0xf8000008);
- 	odm_write_4byte(p_dm, 0x1b1c, tmp1);
- 	odm_write_4byte(p_dm, 0x1b00, 0xf800000a);
- 	odm_write_4byte(p_dm, 0x1b1c, tmp2);
- 	_iqk_page_switch(p_dm);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	tmp1 = odm_read_4byte(dm, 0x1b1c);
+	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+	tmp2 = odm_read_4byte(dm, 0x1b1c);
+#if 0
+	/*halrf_iqk_xym_read(dm, xym_type);*/
+#endif
+	odm_write_4byte(dm, 0x1b00, 0xf8000008);
+	odm_write_4byte(dm, 0x1b1c, tmp1);
+	odm_write_4byte(dm, 0x1b00, 0xf800000a);
+	odm_write_4byte(dm, 0x1b1c, tmp2);
+	_iqk_page_switch(dm);
 }
 
-void halrf_iqk_info_dump(
-	void *p_dm_void,
-	u32 *_used,
-	char *output,
-	u32 *_out_len)
+void halrf_iqk_info_dump(void *dm_void, u32 *_used, char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u32 used = *_used;
-	u32 out_len = *_out_len;	
-	u8 path, num, i;
-
+	u32 out_len = *_out_len;
 	u8 rf_path, j, reload_iqk = 0;
 	u32 tmp;
-	boolean iqk_result[2][NUM][2];	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
+	boolean iqk_result[2][NUM][2];
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+
+	if (!(dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)))
+		return;
 
 	/* IQK INFO */
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s\n", "% IQK Info %"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s\n",
-		(p_dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" : "Driver-IQK"));	
-
-	reload_iqk = (u8)odm_get_bb_reg(p_dm, 0x1bf0, BIT(16));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-		"reload", (reload_iqk) ? "True" : "False"));
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-			"rfk_forbidden", (p_iqk_info->rfk_forbidden) ? "True" : "False"));
-#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-			"segment_iqk", (p_iqk_info->segment_iqk) ? "True" : "False"));
-#endif
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s:%d %d\n",
-			"iqk count / fail count", p_dm->n_iqk_cnt, p_dm->n_iqk_fail_cnt));
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %d\n",
-			"channel", *p_dm->p_channel));
-
-	if (*p_dm->p_band_width == CHANNEL_WIDTH_20)
-		PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"bandwidth", "BW_20"));
-	else if (*p_dm->p_band_width == CHANNEL_WIDTH_40)
-		PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"bandwidth", "BW_40"));
-	else if (*p_dm->p_band_width == CHANNEL_WIDTH_80)
-		PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"bandwidth", "BW_80"));
-	else if (*p_dm->p_band_width == CHANNEL_WIDTH_160)
-		PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"bandwidth", "BW_160"));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s\n",
+		 "% IQK Info %");
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s\n",
+		 (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" :
+		 "Driver-IQK");
+
+	reload_iqk = (u8)odm_get_bb_reg(dm, R_0x1bf0, BIT(16));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
+		 "reload", (reload_iqk) ? "True" : "False");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
+		 "rfk_forbidden", (iqk_info->rfk_forbidden) ? "True" : "False");
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
+	RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
+		 "segment_iqk", (iqk_info->segment_iqk) ? "True" : "False");
+#endif
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s:%d %d\n",
+		 "iqk count / fail count", dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %d\n",
+		 "channel", *dm->channel);
+
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%-20s: %s\n", "bandwidth", "BW_20");
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%-20s: %s\n", "bandwidth", "BW_40");
+	else if (*dm->band_width == CHANNEL_WIDTH_80)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%-20s: %s\n", "bandwidth", "BW_80");
+	else if (*dm->band_width == CHANNEL_WIDTH_160)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%-20s: %s\n", "bandwidth", "BW_160");
 	else
-		PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"bandwidth", "BW_UNKNOW"));
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %llu %s\n",
-				"progressing_time", p_dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)"));
-		
-	tmp = odm_read_4byte(p_dm, 0x1bf0);
-	for(rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
-		for(j = 0; j < 2; j++)
-			iqk_result[0][rf_path][j] = (boolean)(tmp & BIT(rf_path + (j * 4)) >> (rf_path + (j * 4)));
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: 0x%08x\n","Reg0x1bf0", tmp));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"PATH_A-Tx result", (iqk_result[0][RF_PATH_A][0]) ?  "Fail" : "Pass"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"PATH_A-Rx result", (iqk_result[0][RF_PATH_A][1]) ?  "Fail" : "Pass"));
-#if (RTL8822B_SUPPORT == 1) 
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"PATH_B-Tx result", (iqk_result[0][RF_PATH_B][0]) ?  "Fail" : "Pass"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-20s: %s\n",
-				"PATH_B-Rx result", (iqk_result[0][RF_PATH_B][1]) ?  "Fail" : "Pass"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%-20s: %s\n", "bandwidth", "BW_UNKNOWN");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "%-20s: %llu %s\n", "progressing_time",
+		 dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
+
+	tmp = odm_read_4byte(dm, 0x1bf0);
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
+		for (j = 0; j < 2; j++)
+			iqk_result[0][rf_path][j] = (boolean)
+			(tmp & (BIT(rf_path + (j * 4)) >> (rf_path + (j * 4))));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "%-20s: 0x%08x\n", "Reg0x1bf0", tmp);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
+		 "PATH_A-Tx result",
+		 (iqk_result[0][RF_PATH_A][0]) ? "Fail" : "Pass");
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
+		 "PATH_A-Rx result",
+		 (iqk_result[0][RF_PATH_A][1]) ? "Fail" : "Pass");
+#if (RTL8822B_SUPPORT == 1)
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
+		 "PATH_B-Tx result",
+		 (iqk_result[0][RF_PATH_B][0]) ? "Fail" : "Pass");
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
+		 "PATH_B-Rx result",
+		 (iqk_result[0][RF_PATH_B][1]) ? "Fail" : "Pass");
 #endif
 	*_used = used;
 	*_out_len = out_len;
-
 }
 
-void halrf_get_fw_version(void	*p_dm_void)
+void halrf_get_fw_version(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	{
-		struct _ADAPTER		*adapter = p_dm->adapter;
-
-		p_rf->fw_ver = (adapter->MgntInfo.FirmwareVersion << 16) | adapter->MgntInfo.FirmwareSubVersion;
-	}
-#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	{
-		struct rtl8192cd_priv *priv = p_dm->priv;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
-		p_rf->fw_ver = (priv->pshare->fw_version << 16) | priv->pshare->fw_sub_version;
-	}
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	{
-		struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
-		struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
-
-		p_rf->fw_ver = (rtlhal->fw_version << 16) | rtlhal->fw_subversion;
-	}
-#else
-	{
-		struct _ADAPTER		*adapter = p_dm->adapter;
-		HAL_DATA_TYPE		*p_hal_data = GET_HAL_DATA(adapter);
-
-		p_rf->fw_ver = (p_hal_data->firmware_version << 16) | p_hal_data->firmware_sub_version;
-	}
-#endif
+	rf->fw_ver = (dm->fw_version << 16) | dm->fw_sub_version;
 }
 
-
-void halrf_iqk_dbg(void	*p_dm_void)
+void halrf_iqk_dbg(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8 rf_path, j, reload_iqk = 0;
-	u8 path, num, i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rf_path, j;
 	u32 tmp;
-	boolean iqk_result[2][NUM][2];	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
+	boolean iqk_result[2][NUM][2];
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
 	/* IQK INFO */
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s\n", "====== IQK Info ======"));
-
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s\n",
-		(p_dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" : "Driver-IQK"));
-
-	if (p_dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) {
-		halrf_get_fw_version(p_dm);
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: 0x%x\n",
-			"FW_VER", p_rf->fw_ver));
-	} else
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-			"IQK_VER", HALRF_IQK_VER));
-
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION,( "%-20s: %s\n",
-		"reload", (p_iqk_info->is_reload) ? "True" : "False"));
-
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %d %d\n",
-			"iqk count / fail count", p_dm->n_iqk_cnt, p_dm->n_iqk_fail_cnt));
-
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %d\n",
-			"channel", *p_dm->p_channel));
-
-	if (*p_dm->p_band_width == CHANNEL_WIDTH_20)
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"bandwidth", "BW_20"));
-	else if (*p_dm->p_band_width == CHANNEL_WIDTH_40)
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"bandwidth", "BW_40"));
-	else if (*p_dm->p_band_width == CHANNEL_WIDTH_80)
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"bandwidth", "BW_80"));
-	else if (*p_dm->p_band_width == CHANNEL_WIDTH_160)
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"bandwidth", "BW_160"));
-	else
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"bandwidth", "BW_UNKNOW"));
-/*
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %llu %s\n",
-				"progressing_time", p_dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)"));
-*/
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"rfk_forbidden", (p_iqk_info->rfk_forbidden) ? "True" : "False"));
-#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"segment_iqk", (p_iqk_info->segment_iqk) ? "True" : "False"));
-#endif
+	RF_DBG(dm, DBG_RF_IQK, "%-20s\n", "====== IQK Info ======");
 
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %llu %s\n",
-				"progressing_time", p_dm->rf_calibrate_info.iqk_progressing_time, "(ms)"));
+	RF_DBG(dm, DBG_RF_IQK, "%-20s\n",
+	       (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" :
+	       "Driver-IQK");
 
-	
+	if (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) {
+		halrf_get_fw_version(dm);
+		RF_DBG(dm, DBG_RF_IQK, "%-20s: 0x%x\n", "FW_VER", rf->fw_ver);
+	} else {
+		RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "IQK_VER", HALRF_IQK_VER);
+	}
 
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "reload",
+	       (iqk_info->is_reload) ? "True" : "False");
 
-	tmp = odm_read_4byte(p_dm, 0x1bf0);
-	for(rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
-		for(j = 0; j < 2; j++)
-			iqk_result[0][rf_path][j] = (boolean)(tmp & BIT(rf_path + (j * 4)) >> (rf_path + (j * 4)));
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %d %d\n", "iqk count / fail count",
+	       dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
 
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: 0x%08x\n", "Reg0x1bf0", tmp));
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: 0x%08x\n", "Reg0x1be8", odm_read_4byte(p_dm, 0x1be8)));
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"PATH_A-Tx result", (iqk_result[0][RF_PATH_A][0]) ?  "Fail" : "Pass"));
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"PATH_A-Rx result", (iqk_result[0][RF_PATH_A][1]) ?  "Fail" : "Pass"));
-#if (RTL8822B_SUPPORT == 1) 
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",		
-				"PATH_B-Tx result", (iqk_result[0][RF_PATH_B][0]) ?  "Fail" : "Pass"));
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %s\n",
-				"PATH_B-Rx result", (iqk_result[0][RF_PATH_B][1]) ?  "Fail" : "Pass"));
-#endif
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %d\n", "channel", *dm->channel);
 
+	if (*dm->band_width == CHANNEL_WIDTH_20)
+		RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_20");
+	else if (*dm->band_width == CHANNEL_WIDTH_40)
+		RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_40");
+	else if (*dm->band_width == CHANNEL_WIDTH_80)
+		RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_80");
+	else if (*dm->band_width == CHANNEL_WIDTH_160)
+		RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_160");
+	else
+		RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth",
+		       "BW_UNKNOWN");
+#if 0
+/*
+ *	RF_DBG(dm, DBG_RF_IQK, "%-20s: %llu %s\n",
+ *	       "progressing_time",
+ *	       dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
+ */
+#endif
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "rfk_forbidden",
+	       (iqk_info->rfk_forbidden) ? "True" : "False");
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
+	RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "segment_iqk",
+	       (iqk_info->segment_iqk) ? "True" : "False");
+#endif
 
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %llu %s\n", "progressing_time",
+	       dm->rf_calibrate_info.iqk_progressing_time, "(ms)");
+
+	tmp = odm_read_4byte(dm, 0x1bf0);
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
+		for (j = 0; j < 2; j++)
+			iqk_result[0][rf_path][j] = (boolean)
+			(tmp & (BIT(rf_path + (j * 4)) >> (rf_path + (j * 4))));
+
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: 0x%08x\n", "Reg0x1bf0", tmp);
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: 0x%08x\n", "Reg0x1be8",
+	       odm_read_4byte(dm, 0x1be8));
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_A-Tx result",
+	       (iqk_result[0][RF_PATH_A][0]) ? "Fail" : "Pass");
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_A-Rx result",
+	       (iqk_result[0][RF_PATH_A][1]) ? "Fail" : "Pass");
+#if (RTL8822B_SUPPORT == 1)
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_B-Tx result",
+	       (iqk_result[0][RF_PATH_B][0]) ? "Fail" : "Pass");
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_B-Rx result",
+	       (iqk_result[0][RF_PATH_B][1]) ? "Fail" : "Pass");
+#endif
 }
-void halrf_lck_dbg(struct PHY_DM_STRUCT *p_dm)
+
+void halrf_lck_dbg(struct dm_struct *dm)
 {
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s\n", "====== LCK Info ======"));
-	/*PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, "%-20s\n",
-		(p_dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "LCK" : "RTK"));*/
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("%-20s: %llu %s\n",
-				"progressing_time", p_dm->rf_calibrate_info.lck_progressing_time, "(ms)"));
+	RF_DBG(dm, DBG_RF_IQK, "%-20s\n", "====== LCK Info ======");
+#if 0
+	/*RF_DBG(dm, DBG_RF_IQK, "%-20s\n",
+	 *	 (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "LCK" : "RTK"));
+	 */
+#endif
+	RF_DBG(dm, DBG_RF_IQK, "%-20s: %llu %s\n", "progressing_time",
+	       dm->rf_calibrate_info.lck_progressing_time, "(ms)");
 }
 
-void
-halrf_iqk_dbg_cfir_backup(struct PHY_DM_STRUCT *p_dm)
+void halrf_iqk_dbg_cfir_backup(struct dm_struct *dm)
 {
-	struct _IQK_INFORMATION *p_iqk_info = &p_dm->IQK_info;
-	u8	path, idx, i;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	u8 path, idx, i;
 
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s\n", "backup TX/RX CFIR"));	
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "backup TX/RX CFIR");
 
-	for (path = 0; path < 2; path ++) {
-		for (idx = 0; idx < 2; idx++) {
-			phydm_get_iqk_cfir(p_dm, idx, path, true);
-		}
-	}
+	for (path = 0; path < 2; path++)
+		for (idx = 0; idx < 2; idx++)
+			phydm_get_iqk_cfir(dm, idx, path, true);
 
-	for (path = 0; path < 2; path ++) {
+	for (path = 0; path < 2; path++) {
 		for (idx = 0; idx < 2; idx++) {
-			for(i = 0; i < 8; i++) {
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-7s %-3s CFIR_real: %-2d: 0x%x\n",
-					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, p_iqk_info->IQK_CFIR_real[2][path][idx][i]));
+			for (i = 0; i < 8; i++) {
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-7s %-3s CFIR_real: %-2d: 0x%x\n",
+				       (path == 0) ? "PATH A" : "PATH B",
+				       (idx == 0) ? "TX" : "RX", i,
+				       iqk_info->iqk_cfir_real[2][path][idx][i])
+				       ;
 			}
-			for(i = 0; i < 8; i++) {
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-7s %-3s CFIR_img:%-2d: 0x%x\n",
-					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, p_iqk_info->IQK_CFIR_imag[2][path][idx][i]));
+			for (i = 0; i < 8; i++) {
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-7s %-3s CFIR_img:%-2d: 0x%x\n",
+				       (path == 0) ? "PATH A" : "PATH B",
+				       (idx == 0) ? "TX" : "RX", i,
+				       iqk_info->iqk_cfir_imag[2][path][idx][i])
+				       ;
 			}
 		}
 	}
 }
 
-
-void
-halrf_iqk_dbg_cfir_backup_update(
-	struct PHY_DM_STRUCT			*p_dm
-)
+void halrf_iqk_dbg_cfir_backup_update(struct dm_struct *dm)
 {
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_iqk_info *iqk = &dm->IQK_info;
 	u8 i, path, idx;
+	u32 bmask13_12 = BIT(13) | BIT(12);
+	u32 bmask20_16 = BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16);
+	u32 data;
 
-	if(p_iqk_info->IQK_CFIR_real[2][0][0][0] == 0) {
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s\n", "CFIR is invalid"));
+	if (iqk->iqk_cfir_real[2][0][0][0] == 0) {
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "CFIR is invalid");
 		return;
 	}
 	for (path = 0; path < 2; path++) {
 		for (idx = 0; idx < 2; idx++) {
-			odm_set_bb_reg(p_dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
-			odm_set_bb_reg(p_dm, 0x1b2c, MASKDWORD, 0x7);
-			odm_set_bb_reg(p_dm, 0x1b38, MASKDWORD, 0x20000000);
-			odm_set_bb_reg(p_dm, 0x1b3c, MASKDWORD, 0x20000000);
-			odm_set_bb_reg(p_dm, 0x1bcc, MASKDWORD, 0x00000000);
+			odm_set_bb_reg(dm, R_0x1b00, MASKDWORD,
+				       0xf8000008 | path << 1);
+			odm_set_bb_reg(dm, R_0x1b2c, MASKDWORD, 0x7);
+			odm_set_bb_reg(dm, R_0x1b38, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, R_0x1b3c, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, R_0x1bcc, MASKDWORD, 0x00000000);
 			if (idx == 0)
-				odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+				odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x3);
 			else
-				odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
-			odm_set_bb_reg(p_dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+				odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x1);
+			odm_set_bb_reg(dm, R_0x1bd4, bmask20_16, 0x10);
 			for (i = 0; i < 8; i++) {
-				odm_write_4byte(p_dm, 0x1bd8,	((0xc0000000 >> idx) + 0x3) + (i * 4) + (p_iqk_info->IQK_CFIR_real[2][path][idx][i] << 9));
-				odm_write_4byte(p_dm, 0x1bd8, ((0xc0000000 >> idx) + 0x1) + (i * 4) + (p_iqk_info->IQK_CFIR_imag[2][path][idx][i] << 9));
-				/*odm_write_4byte(p_dm, 0x1bd8, p_iqk_info->IQK_CFIR_real[2][path][idx][i]);*/
-				/*odm_write_4byte(p_dm, 0x1bd8, p_iqk_info->IQK_CFIR_imag[2][path][idx][i]);*/
+				data = ((0xc0000000 >> idx) + 0x3) + (i * 4) +
+					(iqk->iqk_cfir_real[2][path][idx][i]
+					<< 9);
+				odm_write_4byte(dm, 0x1bd8, data);
+				data = ((0xc0000000 >> idx) + 0x1) + (i * 4) +
+					(iqk->iqk_cfir_imag[2][path][idx][i]
+					<< 9);
+				odm_write_4byte(dm, 0x1bd8, data);
+#if 0
+				/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_real[2][path][idx][i]);*/
+				/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_imag[2][path][idx][i]);*/
+#endif
 			}
 		}
-		odm_set_bb_reg(p_dm, 0x1bd8, MASKDWORD, 0x0);
-		odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+		odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0x0);
+		odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x0);
 	}
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s\n", "update new CFIR"));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "update new CFIR");
 }
 
-
-void
-halrf_iqk_dbg_cfir_reload(
-	struct PHY_DM_STRUCT			*p_dm
-)
+void halrf_iqk_dbg_cfir_reload(struct dm_struct *dm)
 {
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_iqk_info *iqk = &dm->IQK_info;
 	u8 i, path, idx;
+	u32 bmask13_12 = BIT(13) | BIT(12);
+	u32 bmask20_16 = BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16);
+	u32 data;
 
-	if(p_iqk_info->IQK_CFIR_real[0][0][0][0] == 0) {
-		PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s\n", "CFIR is invalid"));
+	if (iqk->iqk_cfir_real[0][0][0][0] == 0) {
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "CFIR is invalid");
 		return;
 	}
 	for (path = 0; path < 2; path++) {
 		for (idx = 0; idx < 2; idx++) {
-			odm_set_bb_reg(p_dm, 0x1b00, MASKDWORD, 0xf8000008 | path << 1);
-			odm_set_bb_reg(p_dm, 0x1b2c, MASKDWORD, 0x7);
-			odm_set_bb_reg(p_dm, 0x1b38, MASKDWORD, 0x20000000);
-			odm_set_bb_reg(p_dm, 0x1b3c, MASKDWORD, 0x20000000);
-			odm_set_bb_reg(p_dm, 0x1bcc, MASKDWORD, 0x00000000);
+			odm_set_bb_reg(dm, R_0x1b00, MASKDWORD,
+				       0xf8000008 | path << 1);
+			odm_set_bb_reg(dm, R_0x1b2c, MASKDWORD, 0x7);
+			odm_set_bb_reg(dm, R_0x1b38, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, R_0x1b3c, MASKDWORD, 0x20000000);
+			odm_set_bb_reg(dm, R_0x1bcc, MASKDWORD, 0x00000000);
 			if (idx == 0)
-				odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x3);
+				odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x3);
 			else
-				odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x1);
-			odm_set_bb_reg(p_dm, 0x1bd4, BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16), 0x10);
+				odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x1);
+			odm_set_bb_reg(dm, R_0x1bd4, bmask20_16, 0x10);
 			for (i = 0; i < 8; i++) {
-				/*odm_write_4byte(p_dm, 0x1bd8, p_iqk_info->IQK_CFIR_real[0][path][idx][i]);*/
-				/*odm_write_4byte(p_dm, 0x1bd8, p_iqk_info->IQK_CFIR_imag[0][path][idx][i]);*/
-				odm_write_4byte(p_dm, 0x1bd8,	((0xc0000000 >> idx) + 0x3) + (i * 4) + (p_iqk_info->IQK_CFIR_real[0][path][idx][i] << 9));
-				odm_write_4byte(p_dm, 0x1bd8, ((0xc0000000 >> idx) + 0x1) + (i * 4) + (p_iqk_info->IQK_CFIR_imag[0][path][idx][i] << 9));
+#if 0
+				/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_real[0][path][idx][i]);*/
+				/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_imag[0][path][idx][i]);*/
+#endif
+				data = ((0xc0000000 >> idx) + 0x3) + (i * 4) +
+					(iqk->iqk_cfir_real[0][path][idx][i]
+					<< 9);
+				odm_write_4byte(dm, 0x1bd8, data);
+				data = ((0xc0000000 >> idx) + 0x1) + (i * 4) +
+					(iqk->iqk_cfir_imag[0][path][idx][i]
+					<< 9);
+				odm_write_4byte(dm, 0x1bd8, data);
 			}
 		}
-		odm_set_bb_reg(p_dm, 0x1bd8, MASKDWORD, 0x0);
-		odm_set_bb_reg(p_dm, 0x1b0c, BIT(13) | BIT(12), 0x0);
+		odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0x0);
+		odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x0);
 	}
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s\n", "write CFIR with default value"));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "write CFIR with default value");
 }
 
-void
-halrf_iqk_dbg_cfir_write(
-	struct PHY_DM_STRUCT			*p_dm,
-	u8	type,
-	u32 path,
-	u32 idx,
-	u32 i,
-	u32 data
-)
+void halrf_iqk_dbg_cfir_write(struct dm_struct *dm, u8 type, u32 path, u32 idx,
+			      u32 i, u32 data)
 {
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+
 	if (type == 0)
-		p_iqk_info->IQK_CFIR_real[2][path][idx][i] = data;
+		iqk_info->iqk_cfir_real[2][path][idx][i] = data;
 	else
-		p_iqk_info->IQK_CFIR_imag[2][path][idx][i] = data;
+		iqk_info->iqk_cfir_imag[2][path][idx][i] = data;
 }
 
-void
-halrf_iqk_dbg_cfir_backup_show(struct PHY_DM_STRUCT *p_dm)
+void halrf_iqk_dbg_cfir_backup_show(struct dm_struct *dm)
 {
-	struct _IQK_INFORMATION *p_iqk_info = &p_dm->IQK_info;
-	u8	path, idx, i;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	u8 path, idx, i;
 
-	PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-20s\n", "backup TX/RX CFIR"));	
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "backup TX/RX CFIR");
 
-	for (path = 0; path < 2; path ++) {
+	for (path = 0; path < 2; path++) {
 		for (idx = 0; idx < 2; idx++) {
-			for(i = 0; i < 8; i++) {
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-10s %-3s CFIR_real: %-2d: 0x%x\n",
-					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, p_iqk_info->IQK_CFIR_real[2][path][idx][i]));
+			for (i = 0; i < 8; i++) {
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-10s %-3s CFIR_real:%-2d: 0x%x\n",
+				       (path == 0) ? "PATH A" : "PATH B",
+				       (idx == 0) ? "TX" : "RX", i,
+				       iqk_info->iqk_cfir_real[2][path][idx][i])
+				       ;
 			}
-			for(i = 0; i < 8; i++) {
-				PHYDM_DBG(p_dm, ODM_COMP_CALIBRATION, ("[IQK]%-10s %-3s CFIR_img:%-2d: 0x%x\n",
-					(path == 0) ? "PATH A": "PATH B", (idx == 0) ? "TX": "RX", i, p_iqk_info->IQK_CFIR_imag[2][path][idx][i]));
+			for (i = 0; i < 8; i++) {
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[IQK]%-10s %-3s CFIR_img:%-2d: 0x%x\n",
+				       (path == 0) ? "PATH A" : "PATH B",
+				       (idx == 0) ? "TX" : "RX", i,
+				       iqk_info->iqk_cfir_imag[2][path][idx][i])
+				       ;
 			}
 		}
 	}
 }
 
-void
-halrf_do_imr_test(
-	void	*p_dm_void,
-	u8  flag_imr_test
-)
+void halrf_do_imr_test(void *dm_void, u8 flag_imr_test)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (flag_imr_test != 0x0)
-		switch (p_dm->support_ic_type) {
+		switch (dm->support_ic_type) {
 #if (RTL8822B_SUPPORT == 1)
 		case ODM_RTL8822B:
+			do_imr_test_8822b(dm);
 			break;
 #endif
 #if (RTL8821C_SUPPORT == 1)
 		case ODM_RTL8821C:
-			do_imr_test_8821c(p_dm);
+			do_imr_test_8821c(dm);
 			break;
 #endif
 		default:
-		break;
+			break;
 		}
 }
 
-void halrf_iqk_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void halrf_iqk_debug(void *dm_void, u32 *const dm_value, u32 *_used,
+		     char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
-	
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if 0
 	/*dm_value[0]=0x0: backup from SRAM & show*/
 	/*dm_value[0]=0x1: write backup CFIR to SRAM*/
 	/*dm_value[0]=0x2: reload default CFIR to SRAM*/
@@ -699,273 +686,373 @@ void halrf_iqk_debug(
 	/*dm_value[0]=0x10: write backup CFIR real part*/
 	/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/
 	/*dm_value[0]=0x11: write backup CFIR imag*/
-	/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/	
+	/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/
 	/*dm_value[0]=0x20 :xym_read enable*/
-	/*--> dm_value[1]:0:disable, 1:enable*/ 
+	/*--> dm_value[1]:0:disable, 1:enable*/
 	/*if dm_value[0]=0x20 = enable, */
 	/*0x1:show rx_sym; 0x2: tx_xym; 0x3:gs1_xym; 0x4:gs2_sym; 0x5:rxk1_xym*/
-
+#endif
 	if (dm_value[0] == 0x0)
-		halrf_iqk_dbg_cfir_backup(p_dm);
+		halrf_iqk_dbg_cfir_backup(dm);
 	else if (dm_value[0] == 0x1)
-		halrf_iqk_dbg_cfir_backup_update(p_dm);
+		halrf_iqk_dbg_cfir_backup_update(dm);
 	else if (dm_value[0] == 0x2)
-		halrf_iqk_dbg_cfir_reload(p_dm);
+		halrf_iqk_dbg_cfir_reload(dm);
 	else if (dm_value[0] == 0x3)
-		halrf_iqk_dbg_cfir_backup_show(p_dm);
+		halrf_iqk_dbg_cfir_backup_show(dm);
 	else if (dm_value[0] == 0x10)
-		halrf_iqk_dbg_cfir_write(p_dm, 0, dm_value[1], dm_value[2], dm_value[3], dm_value[4]);
+		halrf_iqk_dbg_cfir_write(dm, 0, dm_value[1], dm_value[2],
+					 dm_value[3], dm_value[4]);
 	else if (dm_value[0] == 0x11)
-		halrf_iqk_dbg_cfir_write(p_dm, 1, dm_value[1], dm_value[2], dm_value[3], dm_value[4]);
+		halrf_iqk_dbg_cfir_write(dm, 1, dm_value[1], dm_value[2],
+					 dm_value[3], dm_value[4]);
 	else if (dm_value[0] == 0x20)
-		halrf_iqk_xym_enable(p_dm, (u8)dm_value[1]);
+		halrf_iqk_xym_enable(dm, (u8)dm_value[1]);
 	else if (dm_value[0] == 0x21)
-		halrf_iqk_xym_show(p_dm,(u8)dm_value[1]);
+		halrf_iqk_xym_show(dm, (u8)dm_value[1]);
 	else if (dm_value[0] == 0x30)
-		halrf_do_imr_test(p_dm, (u8)dm_value[1]);
+		halrf_do_imr_test(dm, (u8)dm_value[1]);
 }
 
-void
-halrf_iqk_hwtx_check(
-	void *p_dm_void,
-	boolean		is_check
-)
+void halrf_iqk_hwtx_check(void *dm_void, boolean is_check)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION	*p_iqk_info = &p_dm->IQK_info;
+#if 0
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
 	u32 tmp_b04;
 
-	if (is_check)
-		p_iqk_info->is_hwtx = (boolean)odm_get_bb_reg(p_dm, 0xb00, BIT(8));
-	else {
-		if (p_iqk_info->is_hwtx) {
-			tmp_b04 = odm_read_4byte(p_dm, 0xb04);
-			odm_set_bb_reg(p_dm, 0xb04, BIT(3) | BIT (2), 0x0);
-			odm_write_4byte(p_dm, 0xb04, tmp_b04);
+	if (is_check) {
+		iqk_info->is_hwtx = (boolean)odm_get_bb_reg(dm, R_0xb00, BIT(8));
+	} else {
+		if (iqk_info->is_hwtx) {
+			tmp_b04 = odm_read_4byte(dm, 0xb04);
+			odm_set_bb_reg(dm, R_0xb04, BIT(3) | BIT(2), 0x0);
+			odm_write_4byte(dm, 0xb04, tmp_b04);
 		}
 	}
+#endif
 }
 
-void
-halrf_segment_iqk_trigger(
-	void			*p_dm_void,
-	boolean		clear,
-	boolean		segment_iqk
-)
+void halrf_segment_iqk_trigger(void *dm_void, boolean clear,
+			       boolean segment_iqk)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION		*p_iqk_info = &p_dm->IQK_info;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
 	u64 start_time;
-	
+
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	if (odm_check_power_status(p_dm) == false)
+	if (odm_check_power_status(dm) == false)
 		return;
 #endif
 
-	if ((p_dm->p_mp_mode != NULL) && (p_rf->p_is_con_tx != NULL) && (p_rf->p_is_single_tone != NULL) && (p_rf->p_is_carrier_suppresion != NULL))
-		if (*(p_dm->p_mp_mode) && ((*(p_rf->p_is_con_tx) || *(p_rf->p_is_single_tone) || *(p_rf->p_is_carrier_suppresion))))
+	if (dm->mp_mode &&
+	    rf->is_con_tx &&
+	    rf->is_single_tone &&
+	    rf->is_carrier_suppresion)
+		if (*dm->mp_mode &&
+		    ((*rf->is_con_tx ||
+		     *rf->is_single_tone ||
+		     *rf->is_carrier_suppresion)))
 			return;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (!(p_rf->rf_supportability & HAL_RF_IQK))
+	if (!(rf->rf_supportability & HAL_RF_IQK))
 		return;
 #endif
 
 #if DISABLE_BB_RF
 	return;
 #endif
-	if (p_iqk_info->rfk_forbidden)
+	if (iqk_info->rfk_forbidden)
 		return;
 
-	if (!p_dm->rf_calibrate_info.is_iqk_in_progress) {
-		odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		p_dm->rf_calibrate_info.is_iqk_in_progress = true;
-		odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		start_time = odm_get_current_time(p_dm);
-		p_dm->IQK_info.segment_iqk = segment_iqk;
+	if (!dm->rf_calibrate_info.is_iqk_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		dm->IQK_info.segment_iqk = segment_iqk;
 
-		switch (p_dm->support_ic_type) {
+		switch (dm->support_ic_type) {
 #if (RTL8822B_SUPPORT == 1)
 		case ODM_RTL8822B:
-			phy_iq_calibrate_8822b(p_dm, clear, segment_iqk);
+			phy_iq_calibrate_8822b(dm, clear, segment_iqk);
+			break;
+#endif
+#if (RTL8822C_SUPPORT == 1)
+		case ODM_RTL8822C:
+			phy_iq_calibrate_8822c(dm, clear, segment_iqk);
 			break;
 #endif
 #if (RTL8821C_SUPPORT == 1)
 		case ODM_RTL8821C:
-			phy_iq_calibrate_8821c(p_dm, clear, segment_iqk);
+			phy_iq_calibrate_8821c(dm, clear, segment_iqk);
 			break;
 #endif
 #if (RTL8814B_SUPPORT == 1)
 		case ODM_RTL8814B:
 			break;
 #endif
+#if (RTL8195B_SUPPORT == 1)
+		case ODM_RTL8195B:
+			phy_iq_calibrate_8195b(dm, clear, segment_iqk);
+			break;
+#endif
+#if (RTL8198F_SUPPORT == 1)
+		case ODM_RTL8198F:
+			phy_iq_calibrate_8198f(dm, clear, segment_iqk);
+			break;
+#endif
+
+
 		default:
 			break;
 		}
-		p_dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(p_dm, start_time);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]IQK progressing_time = %lld ms\n", p_dm->rf_calibrate_info.iqk_progressing_time));
-
-		odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		p_dm->rf_calibrate_info.is_iqk_in_progress = false;
-		odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);
-	} else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("== Return the IQK CMD, because RFKs in Progress ==\n"));
+		dm->rf_calibrate_info.iqk_progressing_time =
+				odm_get_progressing_time(dm, start_time);
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]IQK progressing_time = %lld ms\n",
+		       dm->rf_calibrate_info.iqk_progressing_time);
+
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+	} else {
+		RF_DBG(dm, DBG_RF_IQK,
+		       "== Return the IQK CMD, because RFKs in Progress ==\n");
+	}
 }
 
+#endif
 
+u8 halrf_match_iqk_version(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-#endif
+	u32 iqk_version = 0;
+	char temp[10] = {0};
 
+	odm_move_memory(dm, temp, HALRF_IQK_VER, sizeof(temp));
+	PHYDM_SSCANF(temp + 2, DCMD_HEX, &iqk_version);
 
-void
-halrf_rf_lna_setting(
-	void	*p_dm_void,
-	enum phydm_lna_set type
-)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (iqk_version >= 0x24 && (odm_get_hw_img_version(dm) >= 72))
+			return 1;
+		else if ((iqk_version <= 0x23) &&
+			 (odm_get_hw_img_version(dm) <= 71))
+			return 1;
+		else
+			return 0;
+	}
+
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (iqk_version >= 0x18 && (odm_get_hw_img_version(dm) >= 37))
+			return 1;
+		else
+			return 0;
+	}
+
+	return 1;
+}
+
+void halrf_rf_lna_setting(void *dm_void, enum halrf_lna_set type)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_	 *p_rf = &(p_dm->rf_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-		switch (p_dm->support_ic_type) {
+	switch (dm->support_ic_type) {
 #if (RTL8188E_SUPPORT == 1)
-		case ODM_RTL8188E:
-			halrf_rf_lna_setting_8188e(p_dm, type);
-			break;
+	case ODM_RTL8188E:
+		halrf_rf_lna_setting_8188e(dm, type);
+		break;
 #endif
 #if (RTL8192E_SUPPORT == 1)
-		case ODM_RTL8192E:
-			halrf_rf_lna_setting_8192e(p_dm, type);
-			break;
+	case ODM_RTL8192E:
+		halrf_rf_lna_setting_8192e(dm, type);
+		break;
 #endif
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		halrf_rf_lna_setting_8192f(dm, type);
+		break;
+#endif
+
 #if (RTL8723B_SUPPORT == 1)
-		case ODM_RTL8723B:
-			halrf_rf_lna_setting_8723b(p_dm, type);
-			break;
+	case ODM_RTL8723B:
+		halrf_rf_lna_setting_8723b(dm, type);
+		break;
 #endif
 #if (RTL8812A_SUPPORT == 1)
-		case ODM_RTL8812:
-			halrf_rf_lna_setting_8812a(p_dm, type);
-			break;
+	case ODM_RTL8812:
+		halrf_rf_lna_setting_8812a(dm, type);
+		break;
 #endif
 #if ((RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1))
-		case ODM_RTL8881A:
-		case ODM_RTL8821:
-			halrf_rf_lna_setting_8821a(p_dm, type);
-			break;
+	case ODM_RTL8881A:
+	case ODM_RTL8821:
+		halrf_rf_lna_setting_8821a(dm, type);
+		break;
 #endif
 #if (RTL8822B_SUPPORT == 1)
-		case ODM_RTL8822B:
-			halrf_rf_lna_setting_8822b(p_dm_void, type);
-			break;
+	case ODM_RTL8822B:
+		halrf_rf_lna_setting_8822b(dm_void, type);
+		break;
+#endif
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		halrf_rf_lna_setting_8822c(dm_void, type);
+		break;
 #endif
 #if (RTL8821C_SUPPORT == 1)
-		case ODM_RTL8821C:
-			halrf_rf_lna_setting_8821c(p_dm_void, type);
-			break;
+	case ODM_RTL8821C:
+		halrf_rf_lna_setting_8821c(dm_void, type);
+		break;
 #endif
-		default:
+#if (RTL8814B_SUPPORT == 1)
+		case ODM_RTL8814B:
 			break;
-		}
-
+#endif
+	default:
+		break;
 	}
+}
 
-
-void
-halrf_support_ability_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void halrf_support_ability_debug(void *dm_void, char input[][16], u32 *_used,
+				 char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-	u32	dm_value[10] = {0};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	u32 dm_value[10] = {0};
 	u32 used = *_used;
 	u32 out_len = *_out_len;
-	u8	i;
+	u8 i;
+
+	for (i = 0; i < 5; i++)
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 2], DCMD_DECIMAL, &dm_value[i]);
 
-	for (i = 0; i < 5; i++) {
-		if (input[i + 1]) {
-			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
-		}
-	}
-	
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%s\n", "================================"));
 	if (dm_value[0] == 100) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "[RF Supportability]\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "00. (( %s ))Power Tracking\n", ((p_rf->rf_supportability & HAL_RF_TX_PWR_TRACK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "01. (( %s ))IQK\n", ((p_rf->rf_supportability & HAL_RF_IQK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "02. (( %s ))LCK\n", ((p_rf->rf_supportability & HAL_RF_LCK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "03. (( %s ))DPK\n", ((p_rf->rf_supportability & HAL_RF_DPK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "04. (( %s ))HAL_RF_TXGAPK\n", ((p_rf->rf_supportability & HAL_RF_TXGAPK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));		
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\n[RF Supportability]\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "00. (( %s ))Power Tracking\n",
+			 ((rf->rf_supportability & HAL_RF_TX_PWR_TRACK) ?
+			 ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "01. (( %s ))IQK\n",
+			 ((rf->rf_supportability & HAL_RF_IQK) ? ("V") :
+			 (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "02. (( %s ))LCK\n",
+			 ((rf->rf_supportability & HAL_RF_LCK) ? ("V") :
+			 (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "03. (( %s ))DPK\n",
+			 ((rf->rf_supportability & HAL_RF_DPK) ? ("V") :
+			 (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "04. (( %s ))HAL_RF_TXGAPK\n",
+			 ((rf->rf_supportability & HAL_RF_TXGAPK) ? ("V") :
+			 (".")));
+#if (RTL8192F_SUPPORT == 1)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "07. (( %s ))HAL_2GBAND_SHIFT\n",
+			 ((rf->rf_supportability & HAL_2GBAND_SHIFT) ? ("V") :
+			 (".")));
+#endif
+	} else {
+		if (dm_value[1] == 1) /* enable */
+			rf->rf_supportability |= BIT(dm_value[0]);
+		else if (dm_value[1] == 2) /* disable */
+			rf->rf_supportability &= ~(BIT(dm_value[0]));
+		else
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[Warning!!!]  1:enable,  2:disable\n");
 	}
-	else {
-
-		if (dm_value[1] == 1) { /* enable */
-			p_rf->rf_supportability |= BIT(dm_value[0]) ;
-		} else if (dm_value[1] == 2) /* disable */
-			p_rf->rf_supportability &= ~(BIT(dm_value[0])) ;
-		else {
-			PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[Warning!!!]  1:enable,  2:disable"));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\nCurr-RF_supportability =  0x%x\n\n", rf->rf_supportability);
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void halrf_support_band_shift_debug(void *dm_void, char input[][16], u32 *_used,
+				    char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	//u32 band_value[2] = {00};
+	u32 dm_value[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i;
+
+#if (RTL8192F_SUPPORT == 1)
+	for (i = 0; i < 7; i++)
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 2], DCMD_DECIMAL, &dm_value[i]);
+
+	if (!(rf->rf_supportability & HAL_2GBAND_SHIFT)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\nCurr-RF_supportability[07. (( . ))HAL_2GBAND_SHIFT]\nNo RF Band Shift,default: 2.4G!\n");
+	} else {
+		if (dm_value[0] == 01) {
+			rf->rf_shift_band = HAL_RF_2P3;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n[rf_shift_band] = %d\nRF Band Shift to 2.3G!\n",
+				 rf->rf_shift_band);
+		} else if (dm_value[0] == 02) {
+			rf->rf_shift_band = HAL_RF_2P5;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n[rf_shift_band] = %d\nRF Band Shift to 2.5G!\n",
+				 rf->rf_shift_band);
+		} else {
+			rf->rf_shift_band = HAL_RF_2P4;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n[rf_shift_band] = %d\nNo RF Band Shift,default: 2.4G!\n",
+				 rf->rf_shift_band);
 		}
 	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "Curr-RF_supportability =  0x%x\n", p_rf->rf_supportability));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-
 	*_used = used;
 	*_out_len = out_len;
+#endif
 }
 
-void
-halrf_cmn_info_init(
-	void		*p_dm_void,
-enum halrf_cmninfo_init_e	cmn_info,
-	u32			value
-)
+void halrf_cmn_info_init(void *dm_void, enum halrf_cmninfo_init cmn_info,
+			 u32 value)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
-	switch	(cmn_info) {
-	case	HALRF_CMNINFO_EEPROM_THERMAL_VALUE:
-		p_rf->eeprom_thermal = (u8)value;
+	switch (cmn_info) {
+	case HALRF_CMNINFO_EEPROM_THERMAL_VALUE:
+		rf->eeprom_thermal = (u8)value;
 		break;
-	case	HALRF_CMNINFO_FW_VER:
-		p_rf->fw_ver = (u32)value;
+	case HALRF_CMNINFO_PWT_TYPE:
+		rf->pwt_type = (u8)value;
 		break;
 	default:
 		break;
 	}
 }
 
-
-void
-halrf_cmn_info_hook(
-	void		*p_dm_void,
-enum halrf_cmninfo_hook_e cmn_info,
-	void		*p_value
-)
+void halrf_cmn_info_hook(void *dm_void, enum halrf_cmninfo_hook cmn_info,
+			 void *value)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-	
-	switch	(cmn_info) {
-	case	HALRF_CMNINFO_CON_TX:
-		p_rf->p_is_con_tx = (boolean *)p_value;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+
+	switch (cmn_info) {
+	case HALRF_CMNINFO_CON_TX:
+		rf->is_con_tx = (boolean *)value;
 		break;
-	case	HALRF_CMNINFO_SINGLE_TONE:
-		p_rf->p_is_single_tone = (boolean *)p_value;		
+	case HALRF_CMNINFO_SINGLE_TONE:
+		rf->is_single_tone = (boolean *)value;
 		break;
-	case	HALRF_CMNINFO_CARRIER_SUPPRESSION:
-		p_rf->p_is_carrier_suppresion = (boolean *)p_value;		
+	case HALRF_CMNINFO_CARRIER_SUPPRESSION:
+		rf->is_carrier_suppresion = (boolean *)value;
 		break;
-	case	HALRF_CMNINFO_MP_RATE_INDEX:
-		p_rf->p_mp_rate_index = (u8 *)p_value;
+	case HALRF_CMNINFO_MP_RATE_INDEX:
+		rf->mp_rate_index = (u8 *)value;
 		break;
 	default:
 		/*do nothing*/
@@ -973,226 +1060,293 @@ enum halrf_cmninfo_hook_e cmn_info,
 	}
 }
 
-void
-halrf_cmn_info_set(
-	void		*p_dm_void,
-	u32			cmn_info,
-	u64			value
-)
+void halrf_cmn_info_set(void *dm_void, u32 cmn_info, u64 value)
 {
-	/*  */
 	/* This init variable may be changed in run time. */
-	/*  */
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-	
-	switch	(cmn_info) {
-
-		case	HALRF_CMNINFO_ABILITY:
-			p_rf->rf_supportability = (u32)value;
-			break;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
-		case	HALRF_CMNINFO_DPK_EN:
-			p_rf->dpk_en = (u8)value;
-			break;
-		case HALRF_CMNINFO_RFK_FORBIDDEN :
-			p_dm->IQK_info.rfk_forbidden = (boolean)value;
-			break;
-		#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-		case HALRF_CMNINFO_IQK_SEGMENT:
-			p_dm->IQK_info.segment_iqk = (boolean)value;
-			break;
-		#endif
-		case HALRF_CMNINFO_RATE_INDEX:
-			p_rf->p_rate_index = (u32)value;
-			break;
-		default:
-			/* do nothing */
-			break;
+	switch (cmn_info) {
+	case HALRF_CMNINFO_ABILITY:
+		rf->rf_supportability = (u32)value;
+		break;
+
+	case HALRF_CMNINFO_DPK_EN:
+		rf->dpk_en = (u8)value;
+		break;
+	case HALRF_CMNINFO_RFK_FORBIDDEN:
+		dm->IQK_info.rfk_forbidden = (boolean)value;
+		break;
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
+	RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
+	case HALRF_CMNINFO_IQK_SEGMENT:
+		dm->IQK_info.segment_iqk = (boolean)value;
+		break;
+#endif
+	case HALRF_CMNINFO_RATE_INDEX:
+		rf->p_rate_index = (u32)value;
+		break;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	case HALRF_CMNINFO_MP_PSD_POINT:
+		rf->halrf_psd_data.point = (u32)value;
+		break;
+	case HALRF_CMNINFO_MP_PSD_START_POINT:
+		rf->halrf_psd_data.start_point = (u32)value;
+		break;
+	case HALRF_CMNINFO_MP_PSD_STOP_POINT:
+		rf->halrf_psd_data.stop_point = (u32)value;
+		break;
+	case HALRF_CMNINFO_MP_PSD_AVERAGE:
+		rf->halrf_psd_data.average = (u32)value;
+		break;
+#endif
+	default:
+		/* do nothing */
+		break;
 	}
 }
 
-u64
-halrf_cmn_info_get(
-	void		*p_dm_void,
-	u32			cmn_info
-)
+u64 halrf_cmn_info_get(void *dm_void, u32 cmn_info)
 {
-	/*  */
 	/* This init variable may be changed in run time. */
-	/*  */
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-	u64	return_value = 0;
-	
-	switch	(cmn_info) {
-
-		case	HALRF_CMNINFO_ABILITY:
-			return_value = (u32)p_rf->rf_supportability;
-			break;
-		case HALRF_CMNINFO_RFK_FORBIDDEN :
-			return_value = p_dm->IQK_info.rfk_forbidden;
-			break;
-		#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-		case HALRF_CMNINFO_IQK_SEGMENT:
-			return_value = p_dm->IQK_info.segment_iqk;
-			break;
-		#endif
-		default:
-			/* do nothing */
-			break;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	u64 return_value = 0;
+
+	switch (cmn_info) {
+	case HALRF_CMNINFO_ABILITY:
+		return_value = (u32)rf->rf_supportability;
+		break;
+	case HALRF_CMNINFO_RFK_FORBIDDEN:
+		return_value = dm->IQK_info.rfk_forbidden;
+		break;
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
+	RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1  || RTL8822C_SUPPORT == 1)
+	case HALRF_CMNINFO_IQK_SEGMENT:
+		return_value = dm->IQK_info.segment_iqk;
+		break;
+#endif
+	default:
+		/* do nothing */
+		break;
 	}
 
-	return	return_value;
+	return return_value;
 }
 
-void
-halrf_supportability_init_mp(
-	void		*p_dm_void
-)
+void halrf_supportability_init_mp(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-
-	switch (p_dm->support_ic_type) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
+	switch (dm->support_ic_type) {
 	case ODM_RTL8814B:
-		#if (RTL8814B_SUPPORT == 1) 
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/
+#if (RTL8814B_SUPPORT == 1)
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
 			0;
-		#endif
+#endif
 		break;
-	#if (RTL8822B_SUPPORT == 1) 
+#if (RTL8822B_SUPPORT == 1)
 	case ODM_RTL8822B:
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
 			0;
 		break;
-	#endif
-
-	#if (RTL8821C_SUPPORT == 1) 
-	case ODM_RTL8821C:
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/
-			/*HAL_RF_TXGAPK			|*/
+#endif
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
 			0;
 		break;
-	#endif
+#endif
+#if (RTL8821C_SUPPORT == 1)
+	case ODM_RTL8821C:
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
+			/*@HAL_RF_TXGAPK |*/
+			0;
+		break;
+#endif
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_2GBAND_SHIFT |*/
+			/*@HAL_RF_DPK |*/
+			/*@HAL_RF_TXGAPK |*/
+			0;
+		break;
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			HAL_RF_DPK |
+			HAL_RF_TXGAPK |
+			0;
+		break;
+#endif
 
 	default:
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/
-			/*HAL_RF_TXGAPK			|*/
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
+			/*@HAL_RF_TXGAPK |*/
 			0;
 		break;
-
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IC = ((0x%x)), RF_Supportability Init MP = ((0x%x))\n", p_dm->support_ic_type, p_rf->rf_supportability));
+	RF_DBG(dm, DBG_RF_INIT,
+	       "IC = ((0x%x)), RF_Supportability Init MP = ((0x%x))\n",
+	       dm->support_ic_type, rf->rf_supportability);
 }
 
-void
-halrf_supportability_init(
-	void		*p_dm_void
-)
+void halrf_supportability_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-
-	switch (p_dm->support_ic_type) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
+	switch (dm->support_ic_type) {
 	case ODM_RTL8814B:
-		#if (RTL8814B_SUPPORT == 1) 
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/
+#if (RTL8814B_SUPPORT == 1)
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
 			0;
-		#endif
+#endif
 		break;
-	#if (RTL8822B_SUPPORT == 1) 
+#if (RTL8822B_SUPPORT == 1)
 	case ODM_RTL8822B:
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
 			0;
 		break;
-	#endif
-
-	#if (RTL8821C_SUPPORT == 1) 
+#endif
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			HAL_RF_DPK |
+			0;
+		break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
 	case ODM_RTL8821C:
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/		
-			/*HAL_RF_TXGAPK				|*/
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
+			/*@HAL_RF_TXGAPK |*/
 			0;
 		break;
-	#endif
+#endif
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*HAL_2GBAND_SHIFT |*/
+			/*@HAL_RF_DPK |*/
+			/*@HAL_RF_TXGAPK |*/
+			0;
+		break;
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			HAL_RF_DPK |
+			HAL_RF_TXGAPK |
+			0;
+		break;
+#endif
 
 	default:
-		p_rf->rf_supportability = 
-			HAL_RF_TX_PWR_TRACK	|
-			HAL_RF_IQK				|
-			HAL_RF_LCK				|
-			/*HAL_RF_DPK				|*/
+		rf->rf_supportability =
+			HAL_RF_TX_PWR_TRACK |
+			HAL_RF_IQK |
+			HAL_RF_LCK |
+			/*@HAL_RF_DPK |*/
 			0;
 		break;
-
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_INIT, ODM_DBG_LOUD, ("IC = ((0x%x)), RF_Supportability Init = ((0x%x))\n", p_dm->support_ic_type, p_rf->rf_supportability));
+	RF_DBG(dm, DBG_RF_INIT,
+	       "IC = ((0x%x)), RF_Supportability Init = ((0x%x))\n",
+	       dm->support_ic_type, rf->rf_supportability);
 }
 
-void
-halrf_watchdog(
-	void			*p_dm_void
-)
+void halrf_watchdog(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	phydm_rf_watchdog(p_dm);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+#if 0
+	/*RF_DBG(dm, DBG_RF_TMP, "%s\n", __func__);*/
+#endif
+
+	phydm_rf_watchdog(dm);
 }
+
 #if 0
 void
 halrf_iqk_init(
-	void			*p_dm_void
+	void			*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
-
-	switch (p_dm->support_ic_type) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
-	#if (RTL8814B_SUPPORT == 1) 
+	switch (dm->support_ic_type) {
+#if (RTL8814B_SUPPORT == 1)
 	case ODM_RTL8814B:
 		break;
-	#endif
-	#if (RTL8822B_SUPPORT == 1) 
+#endif
+#if (RTL8822B_SUPPORT == 1)
 	case ODM_RTL8822B:
-		_iq_calibrate_8822b_init(p_dm);
+		_iq_calibrate_8822b_init(dm);
+		break;
+#endif
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		_iq_calibrate_8822c_init(dm);
 		break;
-	#endif
-	#if (RTL8821C_SUPPORT == 1) 
+#endif
+#if (RTL8821C_SUPPORT == 1)
 	case ODM_RTL8821C:
 		break;
-	#endif
+#endif
 
 	default:
 		break;
@@ -1200,272 +1354,1043 @@ halrf_iqk_init(
 }
 #endif
 
+void halrf_dack_trigger(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
 
-void
-halrf_iqk_trigger(
-	void			*p_dm_void,
-	boolean		is_recovery
-)
+	u64 start_time;
+
+	start_time = odm_get_current_time(dm);
+
+	switch (dm->support_ic_type) {
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		halrf_dac_cal_8822c(dm);
+		break;
+#endif
+	default:
+		break;
+	}
+	rf->dpk_progressing_time = odm_get_progressing_time(dm, start_time);
+	RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK progressing_time = %lld ms\n",
+	       rf->dpk_progressing_time);
+}
+
+void halrf_iqk_trigger(void *dm_void, boolean is_recovery)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION		*p_iqk_info = &p_dm->IQK_info;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	struct dm_dpk_info *dpk_info = &dm->dpk_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
 	u64 start_time;
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	if (odm_check_power_status(p_dm) == false)
+	if (odm_check_power_status(dm) == false)
 		return;
 #endif
 
-	if ((p_dm->p_mp_mode != NULL) && (p_rf->p_is_con_tx != NULL) && (p_rf->p_is_single_tone != NULL) && (p_rf->p_is_carrier_suppresion != NULL))
-		if (*(p_dm->p_mp_mode) && ((*(p_rf->p_is_con_tx) || *(p_rf->p_is_single_tone) || *(p_rf->p_is_carrier_suppresion))))
+	if (dm->mp_mode &&
+	    rf->is_con_tx &&
+	    rf->is_single_tone &&
+	    rf->is_carrier_suppresion)
+		if (*dm->mp_mode &&
+		    ((*rf->is_con_tx ||
+		     *rf->is_single_tone ||
+		     *rf->is_carrier_suppresion)))
 			return;
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (!(p_rf->rf_supportability & HAL_RF_IQK))
+	if (!(rf->rf_supportability & HAL_RF_IQK))
 		return;
-#endif
 
 #if DISABLE_BB_RF
 	return;
 #endif
 
-	if (p_iqk_info->rfk_forbidden)
+	if (iqk_info->rfk_forbidden)
 		return;
 
-	if (!p_dm->rf_calibrate_info.is_iqk_in_progress) {
-		odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		p_dm->rf_calibrate_info.is_iqk_in_progress = true;
-		odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		start_time = odm_get_current_time(p_dm);
-		switch (p_dm->support_ic_type) {
-#if (RTL8188E_SUPPORT == 1) 
+	if (!dm->rf_calibrate_info.is_iqk_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		switch (dm->support_ic_type) {
+#if (RTL8188E_SUPPORT == 1)
 		case ODM_RTL8188E:
-			phy_iq_calibrate_8188e(p_dm, is_recovery);
+			phy_iq_calibrate_8188e(dm, is_recovery);
 			break;
 #endif
-#if (RTL8188F_SUPPORT == 1) 
+#if (RTL8188F_SUPPORT == 1)
 		case ODM_RTL8188F:
-			phy_iq_calibrate_8188f(p_dm, is_recovery);
+			phy_iq_calibrate_8188f(dm, is_recovery);
 			break;
 #endif
-#if (RTL8192E_SUPPORT == 1) 
+#if (RTL8192E_SUPPORT == 1)
 		case ODM_RTL8192E:
-			phy_iq_calibrate_8192e(p_dm, is_recovery);
+			phy_iq_calibrate_8192e(dm, is_recovery);
 			break;
 #endif
-#if (RTL8197F_SUPPORT == 1) 
+#if (RTL8197F_SUPPORT == 1)
 		case ODM_RTL8197F:
-			phy_iq_calibrate_8197f(p_dm, is_recovery);
+			phy_iq_calibrate_8197f(dm, is_recovery);
 			break;
 #endif
-#if (RTL8703B_SUPPORT == 1) 
+#if (RTL8192F_SUPPORT == 1)
+		case ODM_RTL8192F:
+			phy_iq_calibrate_8192f(dm, is_recovery);
+			break;
+#endif
+#if (RTL8703B_SUPPORT == 1)
 		case ODM_RTL8703B:
-			phy_iq_calibrate_8703b(p_dm, is_recovery);
+			phy_iq_calibrate_8703b(dm, is_recovery);
 			break;
 #endif
-#if (RTL8710B_SUPPORT == 1) 
+#if (RTL8710B_SUPPORT == 1)
 		case ODM_RTL8710B:
-			phy_iq_calibrate_8710b(p_dm, is_recovery);
+			phy_iq_calibrate_8710b(dm, is_recovery);
 			break;
 #endif
-#if (RTL8723B_SUPPORT == 1) 
+#if (RTL8723B_SUPPORT == 1)
 		case ODM_RTL8723B:
-			phy_iq_calibrate_8723b(p_dm, is_recovery);
+			phy_iq_calibrate_8723b(dm, is_recovery);
 			break;
 #endif
-#if (RTL8723D_SUPPORT == 1) 
+#if (RTL8723D_SUPPORT == 1)
 		case ODM_RTL8723D:
-			phy_iq_calibrate_8723d(p_dm, is_recovery);
+			phy_iq_calibrate_8723d(dm, is_recovery);
+			break;
+#endif
+#if (RTL8721D_SUPPORT == 1)
+		case ODM_RTL8721D:
+			phy_iq_calibrate_8721d(dm, is_recovery);
 			break;
 #endif
-#if (RTL8812A_SUPPORT == 1) 
+#if (RTL8812A_SUPPORT == 1)
 		case ODM_RTL8812:
-			phy_iq_calibrate_8812a(p_dm, is_recovery);
+			phy_iq_calibrate_8812a(dm, is_recovery);
 			break;
 #endif
-#if (RTL8821A_SUPPORT == 1) 
+#if (RTL8821A_SUPPORT == 1)
 		case ODM_RTL8821:
-			phy_iq_calibrate_8821a(p_dm, is_recovery);
+			phy_iq_calibrate_8821a(dm, is_recovery);
 			break;
 #endif
-#if (RTL8814A_SUPPORT == 1) 
+#if (RTL8814A_SUPPORT == 1)
 		case ODM_RTL8814A:
-			phy_iq_calibrate_8814a(p_dm, is_recovery);
+			phy_iq_calibrate_8814a(dm, is_recovery);
 			break;
 #endif
-#if (RTL8822B_SUPPORT == 1) 
+#if (RTL8822B_SUPPORT == 1)
 		case ODM_RTL8822B:
-			phy_iq_calibrate_8822b(p_dm, false, false);
+			phy_iq_calibrate_8822b(dm, false, false);
 			break;
 #endif
-#if (RTL8821C_SUPPORT == 1) 
+#if (RTL8822C_SUPPORT == 1)
+		case ODM_RTL8822C:
+			phy_iq_calibrate_8822c(dm, false, false);
+			/*halrf_do_tssi_8822c(dm);*/
+			do_dpk_8822c(dm);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
 		case ODM_RTL8821C:
-			phy_iq_calibrate_8821c(p_dm, false, false);
+			phy_iq_calibrate_8821c(dm, false, false);
 			break;
 #endif
-#if (RTL8814B_SUPPORT == 1) 
+#if (RTL8814B_SUPPORT == 1)
 		case ODM_RTL8814B:
+			phy_iq_calibrate_8814b(dm, false, false);
 			break;
 #endif
+#if (RTL8195B_SUPPORT == 1)
+		case ODM_RTL8195B:
+			phy_iq_calibrate_8195b(dm, false, false);
+			break;
+#endif
+#if (RTL8198F_SUPPORT == 1)
+		case ODM_RTL8198F:
+			phy_iq_calibrate_8198f(dm, false, false);
+			break;
+#endif
+
 		default:
 			break;
 		}
-		p_dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(p_dm, start_time);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]IQK progressing_time = %lld ms\n", p_dm->rf_calibrate_info.iqk_progressing_time));
-
-		odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		p_dm->rf_calibrate_info.is_iqk_in_progress = false;
-		odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);
-	} else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("== Return the IQK CMD, because RFKs in Progress ==\n"));
+		dm->rf_calibrate_info.iqk_progressing_time =
+				odm_get_progressing_time(dm, start_time);
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]IQK progressing_time = %lld ms\n",
+		       dm->rf_calibrate_info.iqk_progressing_time);
+
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_iqk_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+	} else {
+		RF_DBG(dm, DBG_RF_IQK,
+		       "== Return the IQK CMD, because RFKs in Progress ==\n");
+	}
 }
 
-
-
-void
-halrf_lck_trigger(
-	void			*p_dm_void
-)
+void halrf_lck_trigger(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _IQK_INFORMATION		*p_iqk_info = &p_dm->IQK_info;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_iqk_info *iqk_info = &dm->IQK_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
 	u64 start_time;
-	
+
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	if (odm_check_power_status(p_dm) == false)
+	if (odm_check_power_status(dm) == false)
 		return;
 #endif
 
-	if ((p_dm->p_mp_mode != NULL) && (p_rf->p_is_con_tx != NULL) && (p_rf->p_is_single_tone != NULL) && (p_rf->p_is_carrier_suppresion != NULL))
-		if (*(p_dm->p_mp_mode) && ((*(p_rf->p_is_con_tx) || *(p_rf->p_is_single_tone) || *(p_rf->p_is_carrier_suppresion))))
+	if (dm->mp_mode &&
+	    rf->is_con_tx &&
+	    rf->is_single_tone &&
+	    rf->is_carrier_suppresion)
+		if (*dm->mp_mode &&
+		    ((*rf->is_con_tx ||
+		     *rf->is_single_tone ||
+		     *rf->is_carrier_suppresion)))
 			return;
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	if (!(p_rf->rf_supportability & HAL_RF_LCK))
+	if (!(rf->rf_supportability & HAL_RF_LCK))
 		return;
-#endif
 
 #if DISABLE_BB_RF
-		return;
+	return;
 #endif
-	if (p_iqk_info->rfk_forbidden)
+	if (iqk_info->rfk_forbidden)
 		return;
-	while (*(p_dm->p_is_scan_in_process)) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[LCK]scan is in process, bypass LCK\n"));
+	while (*dm->is_scan_in_process) {
+		RF_DBG(dm, DBG_RF_IQK, "[LCK]scan is in process, bypass LCK\n");
 		return;
 	}
 
-	if (!p_dm->rf_calibrate_info.is_lck_in_progress) {
-		odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		p_dm->rf_calibrate_info.is_lck_in_progress = true;
-		odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		start_time = odm_get_current_time(p_dm);
-		switch (p_dm->support_ic_type) {
+	if (!dm->rf_calibrate_info.is_lck_in_progress) {
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_lck_in_progress = true;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+		start_time = odm_get_current_time(dm);
+		switch (dm->support_ic_type) {
 #if (RTL8188E_SUPPORT == 1)
 		case ODM_RTL8188E:
-			phy_lc_calibrate_8188e(p_dm);
+			phy_lc_calibrate_8188e(dm);
 			break;
 #endif
 #if (RTL8188F_SUPPORT == 1)
 		case ODM_RTL8188F:
-			phy_lc_calibrate_8188f(p_dm);
+			phy_lc_calibrate_8188f(dm);
 			break;
 #endif
 #if (RTL8192E_SUPPORT == 1)
 		case ODM_RTL8192E:
-			phy_lc_calibrate_8192e(p_dm);
+			phy_lc_calibrate_8192e(dm);
 			break;
 #endif
 #if (RTL8197F_SUPPORT == 1)
 		case ODM_RTL8197F:
-			phy_lc_calibrate_8197f(p_dm);
+			phy_lc_calibrate_8197f(dm);
+			break;
+#endif
+#if (RTL8192F_SUPPORT == 1)
+		case ODM_RTL8192F:
+			phy_lc_calibrate_8192f(dm);
 			break;
 #endif
 #if (RTL8703B_SUPPORT == 1)
 		case ODM_RTL8703B:
-			phy_lc_calibrate_8703b(p_dm);
+			phy_lc_calibrate_8703b(dm);
 			break;
 #endif
 #if (RTL8710B_SUPPORT == 1)
 		case ODM_RTL8710B:
-			phy_lc_calibrate_8710b(p_dm);
+			phy_lc_calibrate_8710b(dm);
+			break;
+#endif
+#if (RTL8721D_SUPPORT == 1)
+		case ODM_RTL8721D:
+			phy_lc_calibrate_8721d(dm);
 			break;
 #endif
-#if (RTL8723B_SUPPORT == 1) 
+#if (RTL8723B_SUPPORT == 1)
 		case ODM_RTL8723B:
-			phy_lc_calibrate_8723b(p_dm);
+			phy_lc_calibrate_8723b(dm);
 			break;
 #endif
 #if (RTL8723D_SUPPORT == 1)
 		case ODM_RTL8723D:
-			phy_lc_calibrate_8723d(p_dm);
+			phy_lc_calibrate_8723d(dm);
 			break;
 #endif
 #if (RTL8812A_SUPPORT == 1)
 		case ODM_RTL8812:
-			phy_lc_calibrate_8812a(p_dm);
+			phy_lc_calibrate_8812a(dm);
 			break;
 #endif
-#if (RTL8821A_SUPPORT == 1) 
+#if (RTL8821A_SUPPORT == 1)
 		case ODM_RTL8821:
-			phy_lc_calibrate_8821a(p_dm);
+			phy_lc_calibrate_8821a(dm);
 			break;
 #endif
-#if (RTL8814A_SUPPORT == 1) 
+#if (RTL8814A_SUPPORT == 1)
 		case ODM_RTL8814A:
-			phy_lc_calibrate_8814a(p_dm);
+			phy_lc_calibrate_8814a(dm);
 			break;
 #endif
-#if (RTL8822B_SUPPORT == 1) 
+#if (RTL8822B_SUPPORT == 1)
 		case ODM_RTL8822B:
-			phy_lc_calibrate_8822b(p_dm);
+			phy_lc_calibrate_8822b(dm);
 			break;
 #endif
-#if (RTL8821C_SUPPORT == 1) 
+#if (RTL8822C_SUPPORT == 1)
+		case ODM_RTL8822C:
+			phy_lc_calibrate_8822c(dm);
+			break;
+#endif
+#if (RTL8821C_SUPPORT == 1)
 		case ODM_RTL8821C:
-			phy_lc_calibrate_8821c(p_dm);
+			phy_lc_calibrate_8821c(dm);
 			break;
 #endif
-#if (RTL8814B_SUPPORT == 1) 
+#if (RTL8814B_SUPPORT == 1)
 		case ODM_RTL8814B:
 			break;
 #endif
 		default:
 			break;
 		}
-		p_dm->rf_calibrate_info.lck_progressing_time = odm_get_progressing_time(p_dm, start_time);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]LCK progressing_time = %lld ms\n", p_dm->rf_calibrate_info.lck_progressing_time));
+		dm->rf_calibrate_info.lck_progressing_time =
+				odm_get_progressing_time(dm, start_time);
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]LCK progressing_time = %lld ms\n",
+		       dm->rf_calibrate_info.lck_progressing_time);
 #if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-		halrf_lck_dbg(p_dm);
+		halrf_lck_dbg(dm);
 #endif
-		odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-		p_dm->rf_calibrate_info.is_lck_in_progress = false;
-		odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);		
-	}else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("== Return the LCK CMD, because RFK is in Progress ==\n"));
+		odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+		dm->rf_calibrate_info.is_lck_in_progress = false;
+		odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+	} else {
+		RF_DBG(dm, DBG_RF_IQK,
+		       "= Return the LCK CMD, because RFK is in Progress =\n");
+	}
 }
 
-void
-halrf_init(
-	void			*p_dm_void
-)
+void halrf_aac_check(struct dm_struct *dm)
+{
+	switch (dm->support_ic_type) {
+#if (RTL8821C_SUPPORT == 1)
+	case ODM_RTL8821C:
+#if 0
+		aac_check_8821c(dm);
+#endif
+		break;
+#endif
+#if (RTL8822B_SUPPORT == 1)
+	case ODM_RTL8822B:
+#if 1
+		aac_check_8822b(dm);
+#endif
+		break;
+#endif
+	default:
+		break;
+	}
+}
+
+void halrf_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	
-	ODM_RT_TRACE(p_dm, ODM_COMP_INIT, ODM_DBG_LOUD, ("HALRF_Init\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (*(p_dm->p_mp_mode) == true)
-		halrf_supportability_init_mp(p_dm);
-	else
-		halrf_supportability_init(p_dm);
+	RF_DBG(dm, DBG_RF_INIT, "HALRF_Init\n");
+
+	halrf_init_debug_setting(dm);
 
+	if (*dm->mp_mode)
+		halrf_supportability_init_mp(dm);
+	else
+		halrf_supportability_init(dm);
+#if 1
 	/*Init all RF funciton*/
-	/*iqk_init();*/
-	/*dpk_init();*/
+	halrf_aac_check(dm);
+	halrf_dack_trigger(dm);
+#endif
+	halrf_tssi_init(dm);
+}
+
+void halrf_dpk_trigger(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	struct dm_dpk_info *dpk_info = &dm->dpk_info;
+
+	u64 start_time;
+
+	start_time = odm_get_current_time(dm);
+
+	switch (dm->support_ic_type) {
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		do_dpk_8822c(dm);
+		break;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+#if (RTL8197F_SUPPORT == 1)
+	case ODM_RTL8197F:
+		do_dpk_8197f(dm);
+		break;
+#endif
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		do_dpk_8192f(dm);
+		break;
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	case ODM_RTL8198F:
+		do_dpk_8198f(dm);
+		break;
+#endif
+#if (RTL8814B_SUPPORT == 1)
+	case ODM_RTL8814B:
+		break;
+#endif
+
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		if (!dpk_info->is_dpk_by_channel) {
+			dpk_by_channel(dm); /*do dpk 9 ch*/
+			dpk_result_summary_8195b(dm);
+		} else {
+			/*do dpk 1 ch*/
+			do_dpk_8195b(dm, false);
+		}
+	break;
+#endif
+#endif
+	default:
+		break;
+	}
+	rf->dpk_progressing_time = odm_get_progressing_time(dm, start_time);
+	RF_DBG(dm, DBG_RF_DPK, "[DPK]DPK progressing_time = %lld ms\n",
+	       rf->dpk_progressing_time);
+}
+
+u8 halrf_dpk_result_check(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_dpk_info *dpk_info = &dm->dpk_info;
+
+	u8 result = 0;
+
+	switch (dm->support_ic_type) {
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		if (dpk_info->dpk_path_ok == 0x3)
+			result = 1;
+		else
+			result = 0;
+		break;
+#endif
+
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		if (dpk_info->dpk_path_ok == 0x1)
+			result = 1;
+		else
+			result = 0;
+		break;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#if (RTL8197F_SUPPORT == 1)
+	case ODM_RTL8197F:
+		if (dpk_info->dpk_path_ok == 0x3)
+			result = 1;
+		else
+			result = 0;
+		break;
+#endif
+
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		if (dpk_info->dpk_path_ok == 0x3)
+			result = 1;
+		else
+			result = 0;
+		break;
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	case ODM_RTL8198F:
+		if (dpk_info->dpk_path_ok == 0xf)
+			result = 1;
+		else
+			result = 0;
+		break;
+#endif
+
+#endif
+	default:
+		break;
+	}
+	return result;
+}
+
+void halrf_dpk_sram_read(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	u8 path, group;
+
+	switch (dm->support_ic_type) {
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		dpk_coef_read_8822c(dm);
+		break;
+#endif
+
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		dpk_sram_read_8195b(dm);
+		break;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#if (RTL8197F_SUPPORT == 1)
+	case ODM_RTL8197F:
+		dpk_sram_read_8197f(dm);
+		break;
+#endif
+
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		dpk_sram_read_8192f(dm);
+		break;
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	case ODM_RTL8198F:
+		dpk_sram_read_8198f(dm);
+		break;
+#endif
+
+#endif
+	default:
+		break;
+	}
+}
+
+void halrf_dpk_enable_disable(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	switch (dm->support_ic_type) {
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		dpk_enable_disable_8822c(dm);
+		break;
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		dpk_enable_disable_8195b(dm);
+		break;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#if (RTL8197F_SUPPORT == 1)
+	case ODM_RTL8197F:
+		phy_dpk_enable_disable_8197f(dm);
+		break;
+#endif
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		phy_dpk_enable_disable_8192f(dm);
+		break;
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	case ODM_RTL8198F:
+		dpk_enable_disable_8198f(dm);
+		break;
+#endif
+
+#endif
+	default:
+		break;
+	}
 }
 
+void halrf_dpk_track(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_dpk_info *dpk_info = &dm->dpk_info;
+
+	switch (dm->support_ic_type) {
+#if (RTL8822C_SUPPORT == 1)
+	case ODM_RTL8822C:
+		dpk_track_8822c(dm);
+		break;		
+#endif
+
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		dpk_track_8195b(dm);
+		break;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#if (RTL8197F_SUPPORT == 1)
+	case ODM_RTL8197F:
+		phy_dpk_track_8197f(dm);
+		break;
+#endif
+
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		phy_dpk_track_8192f(dm);
+		break;
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	case ODM_RTL8198F:
+		dpk_track_8198f(dm);
+		break;		
+#endif
+
+#endif
+	default:
+		break;
+	}
+}
+
+void halrf_dpk_reload(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_dpk_info *dpk_info = &dm->dpk_info;
+
+	switch (dm->support_ic_type) {
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		dpk_reload_8195b(dm);
+		break;
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+
+#if (RTL8197F_SUPPORT == 1)
+	case ODM_RTL8197F:
+		if (dpk_info->dpk_path_ok > 0)
+			dpk_reload_8197f(dm);
+		break;
+#endif
+
+#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		if (dpk_info->dpk_path_ok > 0)
+			dpk_reload_8192f(dm);
+
+		break;
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	case ODM_RTL8198F:
+		if (dpk_info->dpk_path_ok > 0)
+			dpk_reload_8198f(dm);
+		break;		
+#endif
+
+#endif
+	default:
+		break;
+	}
+}
+
+enum hal_status
+halrf_config_rfk_with_header_file(void *dm_void, u32 config_type)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	enum hal_status result = HAL_STATUS_SUCCESS;
+#if 0
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (config_type == CONFIG_BB_RF_CAL_INIT)
+			odm_read_and_config_mp_8822b_cal_init(dm);
+	}
+#endif
+#endif
+#if (RTL8198F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8198F) {
+		if (config_type == CONFIG_BB_RF_CAL_INIT)
+			odm_read_and_config_mp_8198f_cal_init(dm);
+	}
+#endif
+#if (RTL8822C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822C) {
+		if (config_type == CONFIG_BB_RF_CAL_INIT)
+			odm_read_and_config_mp_8822c_cal_init(dm);
+	}
+#endif
+#if (RTL8814B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814B) {
+		if (config_type == CONFIG_BB_RF_CAL_INIT)
+			odm_read_and_config_mp_8814b_cal_init(dm);
+	}
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B) {
+		if (config_type == CONFIG_BB_RF_CAL_INIT)
+			odm_read_and_config_mp_8195b_cal_init(dm);
+	}
+#endif
+	return result;
+}
+
+void halrf_txgapk_trigger(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+
+	u64 start_time;
 
+	start_time = odm_get_current_time(dm);
 
+	switch (dm->support_ic_type) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		phy_txgap_calibrate_8195b(dm, false);
+	break;
+#endif
+#endif
+
+	default:
+		break;
+	}
+	rf->dpk_progressing_time =
+		odm_get_progressing_time(dm_void, start_time);
+	RF_DBG(dm, DBG_RF_TXGAPK, "[TGGC]TXGAPK progressing_time = %lld ms\n",
+	       rf->dpk_progressing_time);
+}
+
+void halrf_tssi_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if (RTL8822C_SUPPORT == 1)
+	halrf_tssi_init_8822c(dm);
+#endif
+}
+
+void halrf_do_tssi(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if (RTL8822C_SUPPORT == 1)
+	halrf_do_tssi_8822c(dm);
+#endif
+}
+
+void halrf_set_tssi_value(void *dm_void, u32 tssi_value)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if (RTL8822C_SUPPORT == 1)
+	halrf_set_tssi_value_8822c(dm, tssi_value);
+#endif
+}
+
+u32 halrf_query_tssi_value(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if (RTL8822C_SUPPORT == 1)
+	return halrf_query_tssi_value_8822c(dm);
+#endif
+	return 0;
+}
+
+/*Golbal function*/
+void halrf_reload_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 i;
+
+	for (i = 0; i < num; i++)
+		odm_write_4byte(dm, bp_reg[i], bp[i]);
+}
+
+void halrf_reload_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num,
+		       u8 ss)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 i, path;
+
+	for (i = 0; i < num; i++) {
+		for (path = 0; path < ss; path++)
+			odm_set_rf_reg(dm, (enum rf_path)path, bp_reg[i],
+				       MASK20BITS, bp[i][path]);
+	}
+}
+
+void halrf_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 i;
+
+	for (i = 0; i < num; i++)
+		bp[i] = odm_read_4byte(dm, bp_reg[i]);
+}
+
+void halrf_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num, u8 ss)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 i, path;
+
+	for (i = 0; i < num; i++) {
+		for (path = 0; path < ss; path++) {
+			bp[i][path] =
+				odm_get_rf_reg(dm, (enum rf_path)path,
+					       bp_reg[i], MASK20BITS);
+		}
+	}
+}
+
+void halrf_swap(void *dm_void, u32 *v1, u32 *v2)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 temp;
+
+	temp = *v1;
+	*v1 = *v2;
+	*v2 = temp;
+}
+
+void halrf_bubble(void *dm_void, u32 *v1, u32 *v2)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 temp;
+
+	if (*v1 >= 0x200 && *v2 >= 0x200) {
+		if (*v1 > *v2)
+			halrf_swap(dm, v1, v2);
+	} else if (*v1 < 0x200 && *v2 < 0x200) {
+		if (*v1 > *v2)
+			halrf_swap(dm, v1, v2);
+	} else if (*v1 < 0x200 && *v2 >= 0x200) {
+		halrf_swap(dm, v1, v2);
+	}
+}
+
+void halrf_b_sort(void *dm_void, u32 *iv, u32 *qv)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 temp;
+	u32 i, j;
+
+	RF_DBG(dm, DBG_RF_DACK, "[DACK]bubble!!!!!!!!!!!!");
+	for (i = 0; i < SN - 1; i++) {
+		for (j = 0; j < (SN - 1 - i) ; j++) {
+			halrf_bubble(dm, &iv[j], &iv[j + 1]);
+			halrf_bubble(dm, &qv[j], &qv[j + 1]);
+		}
+	}
+}
+
+void halrf_minmax_compare(void *dm_void, u32 value, u32 *min,
+			  u32 *max)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (value >= 0x200) {
+		if (*min >= 0x200) {
+			if (*min > value)
+				*min = value;
+		} else {
+			*min = value;
+		}
+		if (*max >= 0x200) {
+			if (*max < value)
+				*max = value;
+		}
+	} else {
+		if (*min < 0x200) {
+			if (*min > value)
+				*min = value;
+		}
+
+		if (*max  >= 0x200) {
+			*max = value;
+		} else {
+			if (*max < value)
+				*max = value;
+		}
+	}
+}
+
+u32 halrf_delta(void *dm_void, u32 v1, u32 v2)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (v1 >= 0x200 && v2 >= 0x200) {
+		if (v1 > v2)
+			return v1 - v2;
+		else
+			return v2 - v1;
+	} else if (v1 >= 0x200 && v2 < 0x200) {
+		return v2 + (0x400 - v1);
+	} else if (v1 < 0x200 && v2 >= 0x200) {
+		return v1 + (0x400 - v2);
+	}
+
+	if (v1 > v2)
+		return v1 - v2;
+	else
+		return v2 - v1;
+}
+
+boolean halrf_compare(void *dm_void, u32 value)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	boolean fail = false;
+
+	if (value >= 0x200 && (0x400 - value) > 0x64)
+		fail = true;
+	else if (value < 0x200 && value > 0x64)
+		fail = true;
+
+	if (fail)
+		RF_DBG(dm, DBG_RF_DACK, "[DACK]overflow!!!!!!!!!!!!!!!");
+	return fail;
+}
+
+void halrf_mode(void *dm_void, u32 *i_value, u32 *q_value)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 iv[SN], qv[SN], im[SN], qm[SN], temp, temp1, temp2;
+	u32 p, m, t;
+	u32 i_max = 0, q_max = 0, i_min = 0x0, q_min = 0x0, c = 0x0;
+	u32 i_delta, q_delta;
+	u8 i, j, ii = 0, qi = 0;
+	boolean fail = false;
+
+	ODM_delay_ms(10);
+	for (i = 0; i < SN; i++) {
+		im[i] = 0;
+		qm[i] = 0;
+	}
+	i = 0;
+	c = 0;
+	while (i < SN && c < 1000) {
+		c++;
+		temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
+		iv[i] = (temp & 0x3ff000) >> 12;
+		qv[i] = temp & 0x3ff;
+
+		fail = false;
+		if (halrf_compare(dm, iv[i]))
+			fail = true;
+		if (halrf_compare(dm, qv[i]))
+			fail = true;
+		if (!fail)
+			i++;
+	}
+	c = 0;
+	do {
+		c++;
+		i_min = iv[0];
+		i_max = iv[0];
+		q_min = qv[0];
+		q_max = qv[0];
+		for (i = 0; i < SN; i++) {
+			halrf_minmax_compare(dm, iv[i], &i_min, &i_max);
+			halrf_minmax_compare(dm, qv[i], &q_min, &q_max);
+		}
+		RF_DBG(dm, DBG_RF_DACK, "[DACK]i_min=0x%x, i_max=0x%x",
+		       i_min, i_max);
+		RF_DBG(dm, DBG_RF_DACK, "[DACK]q_min=0x%x, q_max=0x%x",
+		       q_min, q_max);
+		if (i_max < 0x200 && i_min < 0x200)
+			i_delta = i_max - i_min;
+		else if (i_max >= 0x200 && i_min >= 0x200)
+			i_delta = i_max - i_min;
+		else
+			i_delta = i_max + (0x400 - i_min);
+
+		if (q_max < 0x200 && q_min < 0x200)
+			q_delta = q_max - q_min;
+		else if (q_max >= 0x200 && q_min >= 0x200)
+			q_delta = q_max - q_min;
+		else
+			q_delta = q_max + (0x400 - q_min);
+		RF_DBG(dm, DBG_RF_DACK, "[DACK]i_delta=0x%x, q_delta=0x%x",
+		       i_delta, q_delta);
+		halrf_b_sort(dm, iv, qv);
+		if (i_delta > 5 || q_delta > 5) {
+			temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
+			iv[0] = (temp & 0x3ff000) >> 12;
+			qv[0] = temp & 0x3ff;
+			temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
+			iv[SN - 1] = (temp & 0x3ff000) >> 12;
+			qv[SN - 1] = temp & 0x3ff;
+		} else {
+			break;
+		}
+	} while (c < 100);
+#if 1
+#if 0
+	for (i = 0; i < SN; i++)
+		RF_DBG(dm, DBG_RF_DACK, "[DACK]iv[%d] = 0x%x\n", i, iv[i]);
+	for (i = 0; i < SN; i++)
+		RF_DBG(dm, DBG_RF_DACK, "[DACK]qv[%d] = 0x%x\n", i, qv[i]);
+#endif
+	/*i*/
+	m = 0;
+	p = 0;
+	for (i = 10; i < SN - 10; i++) {
+		if (iv[i] > 0x200)
+			m = (0x400 - iv[i]) + m;
+		else
+			p = iv[i] + p;
+	}
+
+	if (p > m) {
+		t = p - m;
+		t = t / (SN - 20);
+	} else {
+		t = m - p;
+		t = t / (SN - 20);
+		if (t != 0x0)
+			t = 0x400 - t;
+	}
+	*i_value = t;
+	/*q*/
+	m = 0;
+	p = 0;
+	for (i = 10; i < SN - 10; i++) {
+		if (qv[i] > 0x200)
+			m = (0x400 - qv[i]) + m;
+		else
+			p = qv[i] + p;
+	}
+	if (p > m) {
+		t = p - m;
+		t = t / (SN - 20);
+	} else {
+		t = m - p;
+		t = t / (SN - 20);
+		if (t != 0x0)
+			t = 0x400 - t;
+	}
+	*q_value = t;
+#endif
+}
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.h
index 8ff339370ea0..59a1261c5f88 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,301 +9,566 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __HALRF_H__
+#define __HALRF_H__
 
-#ifndef	_HALRF_H__
-#define _HALRF_H__
-
-/*============================================================*/
-/*include files*/
-/*============================================================*/
+/*@============================================================*/
+/*@include files*/
+/*@============================================================*/
+#include "halrf/halrf_psd.h"
+#if (RTL8822B_SUPPORT == 1)
+#include "halrf/rtl8822b/halrf_rfk_init_8822b.h"
+#endif
+#if (RTL8822C_SUPPORT == 1)
+#include "halrf/rtl8822c/halrf_rfk_init_8822c.h"
+#include "halrf/rtl8822c/halrf_iqk_8822c.h"
+#include "halrf/rtl8822c/halrf_tssi_8822c.h"
+#include "halrf/rtl8822c/halrf_dpk_8822c.h"
+#endif
 
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#if (RTL8198F_SUPPORT == 1)
+#include "halrf/rtl8198f/halrf_rfk_init_8198f.h"
+#endif
+#endif
 
+#if (RTL8814B_SUPPORT == 1)
+#include "halrf/rtl8814b/halrf_rfk_init_8814b.h"
+#include "halrf/rtl8814b/halrf_iqk_8814b.h"
+#endif
 
-/*============================================================*/
-/*Definition */
-/*============================================================*/
+/*@============================================================*/
+/*@Definition */
+/*@============================================================*/
 /*IQK version*/
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-#define IQK_VERSION_8188E	"0x14"
-#define IQK_VERSION_8192E	"0x01"
-#define IQK_VERSION_8723B	"0x1d"
-#define IQK_VERSION_8812A	"0x01"
-#define IQK_VERSION_8821A	"0x01"
+#define IQK_VER_8188E "0x14"
+#define IQK_VER_8192E "0x01"
+#define IQK_VER_8192F "0x01"
+#define IQK_VER_8723B "0x1e"
+#define IQK_VER_8812A "0x02"
+#define IQK_VER_8821A "0x01"
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-#define IQK_VERSION_8188E	"0x01"
-#define IQK_VERSION_8192E	"0x01"
-#define IQK_VERSION_8723B	"0x19"
-#define IQK_VERSION_8812A	"0x01"
-#define IQK_VERSION_8821A	"0x01"
+#define IQK_VER_8188E "0x01"
+#define IQK_VER_8192E "0x01"
+#define IQK_VER_8192F "0x01"
+#define IQK_VER_8723B "0x1e"
+#define IQK_VER_8812A "0x01"
+#define IQK_VER_8821A "0x01"
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#define IQK_VERSION_8188E	"0x01"
-#define IQK_VERSION_8192E	"0x01"
-#define IQK_VERSION_8723B	"0x01"
-#define IQK_VERSION_8812A	"0x01"
-#define IQK_VERSION_8821A	"0x01"
+#define IQK_VER_8188E "0x01"
+#define IQK_VER_8192E "0x01"
+#define IQK_VER_8192F "0x01"
+#define IQK_VER_8723B "0x1e"
+#define IQK_VER_8812A "0x01"
+#define IQK_VER_8821A "0x01"
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+#define IQK_VER_8188E "0x01"
+#define IQK_VER_8192E "0x01"
+#define IQK_VER_8192F "0x01"
+#define IQK_VER_8723B "0x1e"
+#define IQK_VER_8812A "0x01"
+#define IQK_VER_8821A "0x01"
 #endif
-#define IQK_VERSION_8814A	"0x0f"
-#define IQK_VERSION_8188F	"0x01"
-#define IQK_VERSION_8197F	"0x01"
-#define IQK_VERSION_8703B	"0x04"
-#define IQK_VERSION_8710B	"0x01"
-#define IQK_VERSION_8723D	"0x01"
-#define IQK_VERSION_8822B	"0x2e"
-#define IQK_VERSION_8821C	"0x23"
+#define IQK_VER_8814A "0x0f"
+#define IQK_VER_8188F "0x01"
+#define IQK_VER_8197F "0x1d"
+#define IQK_VER_8703B "0x05"
+#define IQK_VER_8710B "0x01"
+#define IQK_VER_8723D "0x02"
+#define IQK_VER_8822B "0x2f"
+#define IQK_VER_8822C "0x03"
+#define IQK_VER_8821C "0x23"
+#define IQK_VER_8198F "0x09"
+#define IQK_VER_8814B "0x06"
 
 /*LCK version*/
-#define LCK_VERSION_8188E	"0x01"
-#define LCK_VERSION_8192E	"0x01"
-#define LCK_VERSION_8723B	"0x01"
-#define LCK_VERSION_8812A	"0x01"
-#define LCK_VERSION_8821A	"0x01"
-#define LCK_VERSION_8814A	"0x01"
-#define LCK_VERSION_8188F	"0x01"
-#define LCK_VERSION_8197F	"0x01"
-#define LCK_VERSION_8703B	"0x01"
-#define LCK_VERSION_8710B	"0x01"
-#define LCK_VERSION_8723D	"0x01"
-#define LCK_VERSION_8822B	"0x01"
-#define LCK_VERSION_8821C	"0x01"
-
-
-#define HALRF_IQK_VER	(p_dm->support_ic_type == ODM_RTL8188E)? IQK_VERSION_8188E :\
-						(p_dm->support_ic_type == ODM_RTL8192E)? IQK_VERSION_8192E :\
-						(p_dm->support_ic_type == ODM_RTL8723B)? IQK_VERSION_8723B :\
-						(p_dm->support_ic_type == ODM_RTL8812)? IQK_VERSION_8812A :\
-						(p_dm->support_ic_type == ODM_RTL8821)? IQK_VERSION_8821A :\
-						(p_dm->support_ic_type == ODM_RTL8814A)? IQK_VERSION_8814A :\
-						(p_dm->support_ic_type == ODM_RTL8188F)? IQK_VERSION_8188F :\
-						(p_dm->support_ic_type == ODM_RTL8197F)? IQK_VERSION_8197F :\
-						(p_dm->support_ic_type == ODM_RTL8703B)? IQK_VERSION_8703B :\
-						(p_dm->support_ic_type == ODM_RTL8710B)? IQK_VERSION_8710B :\
-						(p_dm->support_ic_type == ODM_RTL8723D)? IQK_VERSION_8723D :\
-						(p_dm->support_ic_type == ODM_RTL8822B)? IQK_VERSION_8822B :\
-						(p_dm->support_ic_type == ODM_RTL8821C)? IQK_VERSION_8821C :"unknown"
-
-
-#define HALRF_LCK_VER	(p_dm->support_ic_type == ODM_RTL8188E)? LCK_VERSION_8188E :\
-						(p_dm->support_ic_type == ODM_RTL8192E)? LCK_VERSION_8192E :\
-						(p_dm->support_ic_type == ODM_RTL8723B)? LCK_VERSION_8723B :\
-						(p_dm->support_ic_type == ODM_RTL8812)? LCK_VERSION_8812A :\
-						(p_dm->support_ic_type == ODM_RTL8821)? LCK_VERSION_8821A :\
-						(p_dm->support_ic_type == ODM_RTL8814A)? LCK_VERSION_8814A :\
-						(p_dm->support_ic_type == ODM_RTL8188F)? LCK_VERSION_8188F :\
-						(p_dm->support_ic_type == ODM_RTL8197F)? LCK_VERSION_8197F :\
-						(p_dm->support_ic_type == ODM_RTL8703B)? LCK_VERSION_8703B :\
-						(p_dm->support_ic_type == ODM_RTL8710B)? LCK_VERSION_8710B :\
-						(p_dm->support_ic_type == ODM_RTL8723D)? LCK_VERSION_8723D :\
-						(p_dm->support_ic_type == ODM_RTL8822B)? LCK_VERSION_8822B :\
-						(p_dm->support_ic_type == ODM_RTL8821C)? LCK_VERSION_8821C :"unknown"
-#define HALRF_DPK_VER	"0x02"
-
-#define IQK_THRESHOLD			8
-#define DPK_THRESHOLD			4
-
-/*============================================================*/
-/* enumeration */
-/*============================================================*/
-enum halrf_ability_e {
-
-	HAL_RF_TX_PWR_TRACK	= BIT(0),
-	HAL_RF_IQK				= BIT(1),
-	HAL_RF_LCK				= BIT(2),
-	HAL_RF_DPK				= BIT(3),
-	HAL_RF_TXGAPK			= BIT(4)
+#define LCK_VER_8188E "0x01"
+#define LCK_VER_8192E "0x01"
+#define LCK_VER_8192F "0x01"
+#define LCK_VER_8723B "0x01"
+#define LCK_VER_8812A "0x01"
+#define LCK_VER_8821A "0x01"
+#define LCK_VER_8814A "0x01"
+#define LCK_VER_8188F "0x01"
+#define LCK_VER_8197F "0x01"
+#define LCK_VER_8703B "0x01"
+#define LCK_VER_8710B "0x01"
+#define LCK_VER_8723D "0x01"
+#define LCK_VER_8822B "0x02"
+#define LCK_VER_8822C "0x00"
+#define LCK_VER_8821C "0x02"
+#define LCK_VER_8814B "0x00"
+#define LCK_VER_8195B "0x02"
+
+/*power tracking version*/
+#define PWRTRK_VER_8188E "0x01"
+#define PWRTRK_VER_8192E "0x01"
+#define PWRTRK_VER_8192F "0x01"
+#define PWRTRK_VER_8723B "0x01"
+#define PWRTRK_VER_8812A "0x01"
+#define PWRTRK_VER_8821A "0x01"
+#define PWRTRK_VER_8814A "0x01"
+#define PWRTRK_VER_8188F "0x01"
+#define PWRTRK_VER_8197F "0x01"
+#define PWRTRK_VER_8703B "0x01"
+#define PWRTRK_VER_8710B "0x01"
+#define PWRTRK_VER_8723D "0x01"
+#define PWRTRK_VER_8822B "0x01"
+#define PWRTRK_VER_8822C "0x00"
+#define PWRTRK_VER_8821C "0x01"
+#define PWRTRK_VER_8814B "0x00"
+
+/*DPK version*/
+#define DPK_VER_8188E "NONE"
+#define DPK_VER_8192E "NONE"
+#define DPK_VER_8723B "NONE"
+#define DPK_VER_8812A "NONE"
+#define DPK_VER_8821A "NONE"
+#define DPK_VER_8814A "NONE"
+#define DPK_VER_8188F "NONE"
+#define DPK_VER_8197F "0x08"
+#define DPK_VER_8703B "NONE"
+#define DPK_VER_8710B "NONE"
+#define DPK_VER_8723D "NONE"
+#define DPK_VER_8822B "NONE"
+#define DPK_VER_8822C "0x04"
+#define DPK_VER_8821C "NONE"
+#define DPK_VER_8192F "0x0c"
+#define DPK_VER_8198F "0x0a"
+#define DPK_VER_8814B "0x00"
+#define DPK_VER_8195B "0x06"
+
+/*RFK_INIT version*/
+#define RFK_INIT_VER_8822B "0x8"
+#define RFK_INIT_VER_8822C "0x3"
+#define RFK_INIT_VER_8195B "0x1"
+#define RFK_INIT_VER_8198F "0x5"
+#define RFK_INIT_VER_8814B "0x5"
+
+/*DACK version*/
+#define DACK_VER_8822C "0x3"
+
+/*Kfree tracking version*/
+#define KFREE_VER_8188E \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8192E \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8192F \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8723B \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8812A \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8821A \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8814A \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8188F \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8197F \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8703B \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8710B \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8723D \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8822B \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8822C \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8821C \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+#define KFREE_VER_8814B \
+		(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
+
+/*PA Bias Calibration version*/
+#define PABIASK_VER_8188E \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8192E \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8192F \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8723B \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8812A \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8821A \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8814A \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8188F \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8197F \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8703B \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8710B \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8723D \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8822B \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8822C \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8821C \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+#define PABIASK_VER_8814B \
+	(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
+
+#define HALRF_IQK_VER \
+	(dm->support_ic_type == ODM_RTL8188E) ? IQK_VER_8188E : \
+	(dm->support_ic_type == ODM_RTL8192E) ? IQK_VER_8192E : \
+	(dm->support_ic_type == ODM_RTL8192F) ? IQK_VER_8192F : \
+	(dm->support_ic_type == ODM_RTL8723B) ? IQK_VER_8723B : \
+	(dm->support_ic_type == ODM_RTL8812) ? IQK_VER_8812A : \
+	(dm->support_ic_type == ODM_RTL8821) ? IQK_VER_8821A : \
+	(dm->support_ic_type == ODM_RTL8814A) ? IQK_VER_8814A : \
+	(dm->support_ic_type == ODM_RTL8188F) ? IQK_VER_8188F : \
+	(dm->support_ic_type == ODM_RTL8197F) ? IQK_VER_8197F : \
+	(dm->support_ic_type == ODM_RTL8703B) ? IQK_VER_8703B : \
+	(dm->support_ic_type == ODM_RTL8710B) ? IQK_VER_8710B : \
+	(dm->support_ic_type == ODM_RTL8723D) ? IQK_VER_8723D : \
+	(dm->support_ic_type == ODM_RTL8822B) ? IQK_VER_8822B : \
+	(dm->support_ic_type == ODM_RTL8822C) ? IQK_VER_8822C : \
+	(dm->support_ic_type == ODM_RTL8821C) ? IQK_VER_8821C : \
+	(dm->support_ic_type == ODM_RTL8814B) ? IQK_VER_8814B : "unknown"
+
+#define HALRF_LCK_VER \
+	(dm->support_ic_type == ODM_RTL8188E) ? LCK_VER_8188E : \
+	(dm->support_ic_type == ODM_RTL8192E) ? LCK_VER_8192E : \
+	(dm->support_ic_type == ODM_RTL8192F) ? LCK_VER_8192F : \
+	(dm->support_ic_type == ODM_RTL8723B) ? LCK_VER_8723B : \
+	(dm->support_ic_type == ODM_RTL8812) ? LCK_VER_8812A : \
+	(dm->support_ic_type == ODM_RTL8821) ? LCK_VER_8821A : \
+	(dm->support_ic_type == ODM_RTL8814A) ? LCK_VER_8814A : \
+	(dm->support_ic_type == ODM_RTL8188F) ? LCK_VER_8188F : \
+	(dm->support_ic_type == ODM_RTL8197F) ? LCK_VER_8197F : \
+	(dm->support_ic_type == ODM_RTL8703B) ? LCK_VER_8703B : \
+	(dm->support_ic_type == ODM_RTL8710B) ? LCK_VER_8710B : \
+	(dm->support_ic_type == ODM_RTL8723D) ? LCK_VER_8723D : \
+	(dm->support_ic_type == ODM_RTL8822B) ? LCK_VER_8822B : \
+	(dm->support_ic_type == ODM_RTL8822C) ? LCK_VER_8822C : \
+	(dm->support_ic_type == ODM_RTL8821C) ? LCK_VER_8821C : \
+	(dm->support_ic_type == ODM_RTL8814B) ? LCK_VER_8814B : "unknown"
+
+#define HALRF_POWRTRACKING_VER \
+	(dm->support_ic_type == ODM_RTL8188E) ? PWRTRK_VER_8188E : \
+	(dm->support_ic_type == ODM_RTL8192E) ? PWRTRK_VER_8192E : \
+	(dm->support_ic_type == ODM_RTL8192F) ? PWRTRK_VER_8192F : \
+	(dm->support_ic_type == ODM_RTL8723B) ? PWRTRK_VER_8723B : \
+	(dm->support_ic_type == ODM_RTL8812) ? PWRTRK_VER_8812A : \
+	(dm->support_ic_type == ODM_RTL8821) ? PWRTRK_VER_8821A : \
+	(dm->support_ic_type == ODM_RTL8814A) ? PWRTRK_VER_8814A : \
+	(dm->support_ic_type == ODM_RTL8188F) ? PWRTRK_VER_8188F : \
+	(dm->support_ic_type == ODM_RTL8197F) ? PWRTRK_VER_8197F : \
+	(dm->support_ic_type == ODM_RTL8703B) ? PWRTRK_VER_8703B : \
+	(dm->support_ic_type == ODM_RTL8710B) ? PWRTRK_VER_8710B : \
+	(dm->support_ic_type == ODM_RTL8723D) ? PWRTRK_VER_8723D : \
+	(dm->support_ic_type == ODM_RTL8822B) ? PWRTRK_VER_8822B : \
+	(dm->support_ic_type == ODM_RTL8822C) ? PWRTRK_VER_8822C : \
+	(dm->support_ic_type == ODM_RTL8821C) ? PWRTRK_VER_8821C : \
+	(dm->support_ic_type == ODM_RTL8814B) ? PWRTRK_VER_8814B : "unknown"
+
+#define HALRF_DPK_VER \
+	(dm->support_ic_type == ODM_RTL8188E) ? DPK_VER_8188E : \
+	(dm->support_ic_type == ODM_RTL8192E) ? DPK_VER_8192E : \
+	(dm->support_ic_type == ODM_RTL8192F) ? DPK_VER_8192F : \
+	(dm->support_ic_type == ODM_RTL8723B) ? DPK_VER_8723B : \
+	(dm->support_ic_type == ODM_RTL8812) ? DPK_VER_8812A : \
+	(dm->support_ic_type == ODM_RTL8821) ? DPK_VER_8821A : \
+	(dm->support_ic_type == ODM_RTL8814A) ? DPK_VER_8814A : \
+	(dm->support_ic_type == ODM_RTL8188F) ? DPK_VER_8188F : \
+	(dm->support_ic_type == ODM_RTL8197F) ? DPK_VER_8197F : \
+	(dm->support_ic_type == ODM_RTL8198F) ? DPK_VER_8198F : \
+	(dm->support_ic_type == ODM_RTL8703B) ? DPK_VER_8703B : \
+	(dm->support_ic_type == ODM_RTL8710B) ? DPK_VER_8710B : \
+	(dm->support_ic_type == ODM_RTL8723D) ? DPK_VER_8723D : \
+	(dm->support_ic_type == ODM_RTL8822B) ? DPK_VER_8822B : \
+	(dm->support_ic_type == ODM_RTL8822C) ? DPK_VER_8822C : \
+	(dm->support_ic_type == ODM_RTL8821C) ? DPK_VER_8821C : \
+	(dm->support_ic_type == ODM_RTL8814B) ? DPK_VER_8814B : "unknown"
+
+#define HALRF_KFREE_VER \
+	(dm->support_ic_type == ODM_RTL8188E) ? KFREE_VER_8188E : \
+	(dm->support_ic_type == ODM_RTL8192E) ? KFREE_VER_8192E : \
+	(dm->support_ic_type == ODM_RTL8192F) ? KFREE_VER_8192F : \
+	(dm->support_ic_type == ODM_RTL8723B) ? KFREE_VER_8723B : \
+	(dm->support_ic_type == ODM_RTL8812) ? KFREE_VER_8812A : \
+	(dm->support_ic_type == ODM_RTL8821) ? KFREE_VER_8821A : \
+	(dm->support_ic_type == ODM_RTL8814A) ? KFREE_VER_8814A : \
+	(dm->support_ic_type == ODM_RTL8188F) ? KFREE_VER_8188F : \
+	(dm->support_ic_type == ODM_RTL8197F) ? KFREE_VER_8197F : \
+	(dm->support_ic_type == ODM_RTL8703B) ? KFREE_VER_8703B : \
+	(dm->support_ic_type == ODM_RTL8710B) ? KFREE_VER_8710B : \
+	(dm->support_ic_type == ODM_RTL8723D) ? KFREE_VER_8723D : \
+	(dm->support_ic_type == ODM_RTL8822B) ? KFREE_VER_8822B : \
+	(dm->support_ic_type == ODM_RTL8822C) ? KFREE_VER_8822C : \
+	(dm->support_ic_type == ODM_RTL8821C) ? KFREE_VER_8821C : \
+	(dm->support_ic_type == ODM_RTL8814B) ? KFREE_VER_8814B : "unknown"
+
+#define HALRF_PABIASK_VER \
+	(dm->support_ic_type == ODM_RTL8188E) ? PABIASK_VER_8188E : \
+	(dm->support_ic_type == ODM_RTL8192E) ? PABIASK_VER_8192E : \
+	(dm->support_ic_type == ODM_RTL8192F) ? PABIASK_VER_8192F : \
+	(dm->support_ic_type == ODM_RTL8723B) ? PABIASK_VER_8723B : \
+	(dm->support_ic_type == ODM_RTL8812) ? PABIASK_VER_8812A : \
+	(dm->support_ic_type == ODM_RTL8821) ? PABIASK_VER_8821A : \
+	(dm->support_ic_type == ODM_RTL8814A) ? PABIASK_VER_8814A : \
+	(dm->support_ic_type == ODM_RTL8188F) ? PABIASK_VER_8188F : \
+	(dm->support_ic_type == ODM_RTL8197F) ? PABIASK_VER_8197F : \
+	(dm->support_ic_type == ODM_RTL8703B) ? PABIASK_VER_8703B : \
+	(dm->support_ic_type == ODM_RTL8710B) ? PABIASK_VER_8710B : \
+	(dm->support_ic_type == ODM_RTL8723D) ? PABIASK_VER_8723D : \
+	(dm->support_ic_type == ODM_RTL8822B) ? PABIASK_VER_8822B : \
+	(dm->support_ic_type == ODM_RTL8822C) ? PABIASK_VER_8822C : \
+	(dm->support_ic_type == ODM_RTL8821C) ? PABIASK_VER_8821C : \
+	(dm->support_ic_type == ODM_RTL8814B) ? PABIASK_VER_8814B : "unknown"
+
+#define HALRF_RFK_INIT_VER \
+	(dm->support_ic_type == ODM_RTL8822B) ? RFK_INIT_VER_8822B : \
+	(dm->support_ic_type == ODM_RTL8822C) ? RFK_INIT_VER_8822C : \
+	(dm->support_ic_type == ODM_RTL8198F) ? RFK_INIT_VER_8198F : \
+	(dm->support_ic_type == ODM_RTL8814B) ? RFK_INIT_VER_8814B : "unknown"
+
+#define HALRF_DACK_VER \
+	(dm->support_ic_type == ODM_RTL8822C) ? DACK_VER_8822C : "unknown"
+
+#define IQK_THRESHOLD 8
+#define DPK_THRESHOLD 4
+#define HALRF_ABS(a,b) ((a>b) ? (a-b) : (b-a))
+#define SN 100
+/*@===========================================================*/
+/*AGC RX High Power mode*/
+/*@===========================================================*/
+#define lna_low_gain_1 0x64
+#define lna_low_gain_2 0x5A
+#define lna_low_gain_3 0x58
+
+/*@============================================================*/
+/*@ enumeration */
+/*@============================================================*/
+
+enum halrf_func_idx { /*F_XXX = PHYDM XXX function*/
+	RF00_PWR_TRK = 0,
+	RF01_IQK = 1,
+	RF02_LCK = 2,
+	RF03_DPK = 3,
+	RF04_TXGAPK = 4,
+	RF05_DACK = 5,
+	RF07_2GBAND_SHIFT = 7
+};
+
+enum halrf_ability {
+	HAL_RF_TX_PWR_TRACK = BIT(RF00_PWR_TRK),
+	HAL_RF_IQK = BIT(RF01_IQK),
+	HAL_RF_LCK = BIT(RF02_LCK),
+	HAL_RF_DPK = BIT(RF03_DPK),
+	HAL_RF_TXGAPK = BIT(RF04_TXGAPK),
+	HAL_RF_DACK = BIT(RF05_DACK),
+	HAL_2GBAND_SHIFT = BIT(RF07_2GBAND_SHIFT)
+};
+
+enum halrf_shift_band {
+	HAL_RF_2P4 = 0,
+	HAL_RF_2P3 = 1,
+	HAL_RF_2P5 = 2
+};
+
+enum halrf_dbg_comp {
+	DBG_RF_TX_PWR_TRACK = BIT(RF00_PWR_TRK),
+	DBG_RF_IQK = BIT(RF01_IQK),
+	DBG_RF_LCK = BIT(RF02_LCK),
+	DBG_RF_DPK = BIT(RF03_DPK),
+	DBG_RF_TXGAPK = BIT(RF04_TXGAPK),
+	DBG_RF_DACK = BIT(RF05_DACK),
+	DBG_RF_MP = BIT(29),
+	DBG_RF_TMP = BIT(30),
+	DBG_RF_INIT = BIT(31)
 };
 
-enum halrf_cmninfo_init_e {
+enum halrf_cmninfo_init {
 	HALRF_CMNINFO_ABILITY = 0,
 	HALRF_CMNINFO_DPK_EN = 1,
 	HALRF_CMNINFO_EEPROM_THERMAL_VALUE,
-	HALRF_CMNINFO_FW_VER,
 	HALRF_CMNINFO_RFK_FORBIDDEN,
 	HALRF_CMNINFO_IQK_SEGMENT,
-	HALRF_CMNINFO_RATE_INDEX
+	HALRF_CMNINFO_RATE_INDEX,
+	HALRF_CMNINFO_PWT_TYPE,
+	HALRF_CMNINFO_MP_PSD_POINT,
+	HALRF_CMNINFO_MP_PSD_START_POINT,
+	HALRF_CMNINFO_MP_PSD_STOP_POINT,
+	HALRF_CMNINFO_MP_PSD_AVERAGE
 };
 
-enum halrf_cmninfo_hook_e {
+enum halrf_cmninfo_hook {
 	HALRF_CMNINFO_CON_TX,
 	HALRF_CMNINFO_SINGLE_TONE,
-	HALRF_CMNINFO_CARRIER_SUPPRESSION,	
+	HALRF_CMNINFO_CARRIER_SUPPRESSION,
 	HALRF_CMNINFO_MP_RATE_INDEX
 };
 
-enum phydm_lna_set {
-	phydm_lna_disable		= 0,
-	phydm_lna_enable		= 1,
+enum halrf_lna_set {
+	HALRF_LNA_DISABLE = 0,
+	HALRF_LNA_ENABLE = 1,
 };
 
-
-/*============================================================*/
-/* structure */
-/*============================================================*/
+/*@============================================================*/
+/*@ structure */
+/*@============================================================*/
 
 struct _hal_rf_ {
 	/*hook*/
-	u8		*test1;
+	u8 *test1;
 
 	/*update*/
-	u32		rf_supportability;
-
-	u8		eeprom_thermal;
-	u8		dpk_en;			/*Enable Function DPK OFF/ON = 0/1*/
-	boolean	dpk_done;
-	u32		fw_ver;
+	u32 rf_supportability;
+	u8 rf_shift_band;
+
+	u8 eeprom_thermal;
+	u8 dpk_en; /*Enable Function DPK OFF/ON = 0/1*/
+	boolean dpk_done;
+	u64 dpk_progressing_time;
+	u32 fw_ver;
+
+	boolean *is_con_tx;
+	boolean *is_single_tone;
+	boolean *is_carrier_suppresion;
+	boolean is_dpk_in_progress;
+
+	u8 *mp_rate_index;
+	u32 p_rate_index;
+	u8 pwt_type;
+	u32 rf_dbg_comp;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct _halrf_psd_data halrf_psd_data;
+#endif
+};
 
-	boolean	*p_is_con_tx;
-	boolean	*p_is_single_tone;
-	boolean	*p_is_carrier_suppresion;
+/*@============================================================*/
+/*@ function prototype */
+/*@============================================================*/
 
-	u8		*p_mp_rate_index;
-	u32		p_rate_index;
-};
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
+	RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
+void halrf_iqk_info_dump(void *dm_void, u32 *_used, char *output,
+			 u32 *_out_len);
 
-/*============================================================*/
-/* function prototype */
-/*============================================================*/
-
-void halrf_basic_profile(
-	void			*p_dm_void,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-);
-#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-void halrf_iqk_info_dump(
-	void *p_dm_void,
-	u32 *_used,
-	char *output,
-	u32 *_out_len
-);
-
-void
-halrf_iqk_hwtx_check(
-	void *p_dm_void,
-	boolean		is_check
-);
+void halrf_iqk_hwtx_check(void *dm_void, boolean is_check);
 #endif
 
-void
-halrf_support_ability_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-void
-halrf_cmn_info_init(
-	void		*p_dm_void,
-	enum halrf_cmninfo_init_e	cmn_info,
-	u32		value
-);
-
-void
-halrf_cmn_info_hook(
-	void		*p_dm_void,
-	u32		cmn_info,
-	void		*p_value
-);
-
-void
-halrf_cmn_info_set(
-	void		*p_dm_void,
-	u32			cmn_info,
-	u64			value
-);
-
-u64
-halrf_cmn_info_get(
-	void		*p_dm_void,
-	u32			cmn_info
-);
-
-void
-halrf_watchdog(
-	void			*p_dm_void
-);
-
-void
-halrf_supportability_init(
-	void		*p_dm_void
-);
-
-void
-halrf_init(
-	void			*p_dm_void
-);
-
-void
-halrf_iqk_trigger(
-	void			*p_dm_void,
-	boolean		is_recovery
-);
-
-void
-halrf_segment_iqk_trigger(
-	void			*p_dm_void,
-	boolean		clear,
-	boolean		segment_iqk
-);
-
-void
-halrf_lck_trigger(
-	void			*p_dm_void
-);
-
-void
-halrf_iqk_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-void
-phydm_get_iqk_cfir(
-	void		*p_dm_void,
-	u8 idx,
-	u8 path,
-	boolean debug
-);
-
-void 
-halrf_iqk_xym_read(
-	void *p_dm_void,
-	u8 path,
-	u8 xym_type
- );
-
-void
-halrf_rf_lna_setting(
-	void	*p_dm_void,
-	enum phydm_lna_set type
-);
-
-
-void
-halrf_do_imr_test(
-	void	*p_dm_void,
-	u8 data
-);
-
-u32
-halrf_psd_log2base(
-	IN u32 val
-);
-
-
-#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-void halrf_iqk_dbg(void	*p_dm_void);
-#endif
+u8 halrf_match_iqk_version(void *dm_void);
+
+void halrf_support_ability_debug(void *dm_void, char input[][16], u32 *_used,
+				 char *output, u32 *_out_len);
+void halrf_support_band_shift_debug(void *dm_void, char input[][16], u32 *_used,
+				    char *output, u32 *_out_len);
+
+void halrf_cmn_info_init(void *dm_void, enum halrf_cmninfo_init cmn_info,
+			 u32 value);
+
+void halrf_cmn_info_hook(void *dm_void, enum halrf_cmninfo_hook cmn_info,
+			 void *value);
+
+void halrf_cmn_info_set(void *dm_void, u32 cmn_info, u64 value);
+
+u64 halrf_cmn_info_get(void *dm_void, u32 cmn_info);
+
+void halrf_watchdog(void *dm_void);
+
+void halrf_supportability_init(void *dm_void);
+
+void halrf_init(void *dm_void);
+
+void halrf_iqk_trigger(void *dm_void, boolean is_recovery);
+
+void halrf_segment_iqk_trigger(void *dm_void, boolean clear,
+			       boolean segment_iqk);
+
+void halrf_lck_trigger(void *dm_void);
+
+void halrf_iqk_debug(void *dm_void, u32 *const dm_value, u32 *_used,
+		     char *output, u32 *_out_len);
+
+void phydm_get_iqk_cfir(void *dm_void, u8 idx, u8 path, boolean debug);
+
+void halrf_iqk_xym_read(void *dm_void, u8 path, u8 xym_type);
+
+void halrf_rf_lna_setting(void *dm_void, enum halrf_lna_set type);
+
+void halrf_do_imr_test(void *dm_void, u8 data);
+
+u32 halrf_psd_log2base(u32 val);
+
+void halrf_dpk_trigger(void *dm_void);
+
+u8 halrf_dpk_result_check(void *dm_void);
+
+void halrf_dpk_sram_read(void *dm_void);
+
+void halrf_dpk_enable_disable(void *dm_void);
+
+void halrf_dpk_track(void *dm_void);
+
+void halrf_dpk_reload(void *dm_void);
+
+/*Global function*/
+
+void halrf_reload_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num);
+
+void halrf_reload_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num,
+		       u8 ss);
+
+void halrf_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num);
+
+void halrf_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num, u8 ss);
+
+void halrf_mode(void *dm_void, u32 *i_value, u32 *q_value);
+
+boolean halrf_compare(void *dm_void, u32 value);
+
+u32 halrf_delta(void *dm_void, u32 v1, u32 v2);
+
+void halrf_minmax_compare(void *dm_void, u32 value, u32 *min, u32 *max);
+
+void halrf_b_sort(void *dm_void, u32 *iv, u32 *qv);
+
+void halrf_bubble(void *dm_void, u32 *v1, u32 *v2);
+
+void halrf_swap(void *dm_void, u32 *v1, u32 *v2);
+
+enum hal_status
+halrf_config_rfk_with_header_file(void *dm_void, u32 config_type);
+
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
+	RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1  || RTL8822C_SUPPORT == 1)
+void halrf_iqk_dbg(void *dm_void);
 #endif
 
+void halrf_tssi_init(void *dm_void);
+
+void halrf_do_tssi(void *dm_void);
+
+void halrf_set_tssi_value(void *dm_void, u32 tssi_value);
+
+u32 halrf_query_tssi_value(void *dm_void);
 
+#endif /*__HALRF_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_debug.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_debug.c
new file mode 100644
index 000000000000..74707193cc49
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_debug.c
@@ -0,0 +1,268 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*@************************************************************
+ * include files
+ * ************************************************************
+ */
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void halrf_basic_profile(void *dm_void, u32 *_used, char *output, u32 *_out_len)
+{
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/* HAL RF version List */
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-35s\n",
+		 "% HAL RF version %");
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Power Tracking", HALRF_POWRTRACKING_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "  %-35s: %s %s\n", "IQK",
+		 (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW" :
+		 HALRF_IQK_VER,
+		 (halrf_match_iqk_version(dm_void)) ? "(match)" : "(mismatch)");
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "LCK", HALRF_LCK_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "DPK", HALRF_DPK_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "KFREE", HALRF_KFREE_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "TX 2G Current Calibration", HALRF_PABIASK_VER);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "RFK Init. Parameter", HALRF_RFK_INIT_VER);
+
+	*_used = used;
+	*_out_len = out_len;
+#endif
+}
+
+void halrf_debug_trace(void *dm_void, char input[][16], u32 *_used,
+		       char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	u32 one = 1;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 rf_var[10] = {0};
+	u8 i;
+
+	for (i = 0; i < 5; i++)
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 2], DCMD_DECIMAL, &rf_var[i]);
+
+	if (rf_var[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\n[DBG MSG] RF Selection\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "00. (( %s ))TX_PWR_TRACK\n",
+			 ((rf->rf_dbg_comp & DBG_RF_TX_PWR_TRACK) ? ("V") :
+			 (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "01. (( %s ))IQK\n",
+			 ((rf->rf_dbg_comp & DBG_RF_IQK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "02. (( %s ))LCK\n",
+			 ((rf->rf_dbg_comp & DBG_RF_LCK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "03. (( %s ))DPK\n",
+			 ((rf->rf_dbg_comp & DBG_RF_DPK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "04. (( %s ))TXGAPK\n",
+			 ((rf->rf_dbg_comp & DBG_RF_TXGAPK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "29. (( %s ))MP\n",
+			 ((rf->rf_dbg_comp & DBG_RF_MP) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "30. (( %s ))TMP\n",
+			 ((rf->rf_dbg_comp & DBG_RF_TMP) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "31. (( %s ))INIT\n",
+			 ((rf->rf_dbg_comp & DBG_RF_INIT) ? ("V") : (".")));
+
+	} else if (rf_var[0] == 101) {
+		rf->rf_dbg_comp = 0;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Disable all DBG COMP\n");
+	} else {
+		if (rf_var[1] == 1) /*enable*/
+			rf->rf_dbg_comp |= (one << rf_var[0]);
+		else if (rf_var[1] == 2) /*disable*/
+			rf->rf_dbg_comp &= ~(one << rf_var[0]);
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\nCurr-RF_Dbg_Comp = 0x%x\n", rf->rf_dbg_comp);
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+struct halrf_command {
+	char name[16];
+	u8 id;
+};
+
+enum halrf_CMD_ID {
+	HALRF_HELP,
+	HALRF_SUPPORTABILITY,
+	HALRF_DBG_COMP,
+	HALRF_PROFILE,
+	HALRF_IQK_INFO,
+	HALRF_IQK,
+	HALRF_IQK_DEBUG,
+	HAL_BAND_SHIFT,
+};
+
+struct halrf_command halrf_cmd_ary[] = {
+	{"-h", HALRF_HELP},
+	{"ability", HALRF_SUPPORTABILITY},
+	{"dbg", HALRF_DBG_COMP},
+	{"profile", HALRF_PROFILE},
+	{"iqk_info", HALRF_IQK_INFO},
+	{"iqk", HALRF_IQK},
+	{"iqk_dbg", HALRF_IQK_DEBUG},
+	{"band_shift", HAL_BAND_SHIFT},
+};
+
+void halrf_cmd_parser(void *dm_void, char input[][16], u32 *_used, char *output,
+		      u32 *_out_len, u32 input_num)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+	u8 id = 0;
+	u32 rf_var[10] = {0};
+	u32 i, input_idx = 0;
+	u32 halrf_ary_size =
+			sizeof(halrf_cmd_ary) / sizeof(struct halrf_command);
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/* Parsing Cmd ID */
+	for (i = 0; i < halrf_ary_size; i++) {
+		if (strcmp(halrf_cmd_ary[i].name, input[1]) == 0) {
+			id = halrf_cmd_ary[i].id;
+			break;
+		}
+	}
+
+	if (i == halrf_ary_size) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "RF Cmd not found\n");
+		return;
+	}
+
+	switch (id) {
+	case HALRF_HELP:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "RF cmd ==>\n");
+
+		for (i = 0; i < halrf_ary_size - 1; i++) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "  %-5d: %s\n", i, halrf_cmd_ary[i + 1].name);
+		}
+		break;
+	case HALRF_SUPPORTABILITY:
+		halrf_support_ability_debug(dm, &input[0], &used, output,
+					    &out_len);
+		break;
+	case HAL_BAND_SHIFT:
+		halrf_support_band_shift_debug(dm, &input[0], &used, output,
+					       &out_len);
+		break;
+	case HALRF_DBG_COMP:
+		halrf_debug_trace(dm, &input[0], &used, output, &out_len);
+		break;
+	case HALRF_PROFILE:
+		halrf_basic_profile(dm, &used, output, &out_len);
+		break;
+	case HALRF_IQK_INFO:
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		halrf_iqk_info_dump(dm, &used, output, &out_len);
+#endif
+		break;
+	case HALRF_IQK:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "TRX IQK Trigger\n");
+		halrf_iqk_trigger(dm, false);
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+		halrf_iqk_info_dump(dm, &used, output, &out_len);
+#endif
+		break;
+	case HALRF_IQK_DEBUG:
+
+		for (i = 0; i < 5; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 2], DCMD_HEX,
+					     &rf_var[i]);
+				input_idx++;
+			}
+		}
+
+		if (input_idx >= 1) {
+#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+			if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+				halrf_iqk_debug(dm, (u32 *)rf_var, &used,
+						output, &out_len);
+#endif
+		}
+		break;
+	default:
+		break;
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+#endif
+}
+
+void halrf_init_debug_setting(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+
+	rf->rf_dbg_comp =
+#if DBG
+#if 0
+	/*DBG_RF_TX_PWR_TRACK	|*/
+	/*DBG_RF_IQK		| */
+	/*DBG_RF_LCK		| */
+	/*DBG_RF_DPK		| */
+	/*DBG_RF_DACK		| */
+	/*DBG_RF_TXGAPK		| */
+	/*DBG_RF_MP			| */
+	/*DBG_RF_TMP		| */
+	/*DBG_RF_INIT		| */
+#endif
+#endif
+	0;
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_debug.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_debug.h
new file mode 100644
index 000000000000..15d4a6268587
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_debug.h
@@ -0,0 +1,124 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HALRF_DEBUG_H__
+#define __HALRF_DEBUG_H__
+
+/*@============================================================*/
+/*@include files*/
+/*@============================================================*/
+
+/*@============================================================*/
+/*@Definition */
+/*@============================================================*/
+
+#if DBG
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+#define RF_DBG(dm, comp, fmt, args...)                     \
+	do {                                               \
+		if ((comp) & dm->rf_table.rf_dbg_comp) { \
+			pr_debug("[RF] ");                 \
+			RT_PRINTK(fmt, ##args);            \
+		}                                          \
+	} while (0)
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+static __inline void RF_DBG(PDM_ODM_T dm, int comp, char *fmt, ...)
+{
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->rf_table.rf_dbg_comp) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		DbgPrint("Failed (%d) to print message to buffer\n", rt_status);
+		return;
+	}
+
+	DbgPrint("[RF] %s", buf);
+}
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+
+#define RF_DBG(dm, comp, fmt, args...)                     \
+	do {                                               \
+		if ((comp) & dm->rf_table.rf_dbg_comp) { \
+			RT_DEBUG(COMP_PHYDM, DBG_DMESG, "[RF] " fmt, ##args);  \
+		}                                          \
+	} while (0)
+
+#else
+#define RF_DBG(dm, comp, fmt, args...)                                         \
+	do {                                                                   \
+		struct dm_struct *__dm = dm;                                   \
+		if ((comp) & __dm->rf_table.rf_dbg_comp) {                     \
+			RT_TRACE(((struct rtl_priv *)__dm->adapter),           \
+				 COMP_PHYDM, DBG_DMESG, "[RF] " fmt, ##args);  \
+		}                                                              \
+	} while (0)
+#endif
+
+#else /*#if DBG*/
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+static __inline void RF_DBG(struct dm_struct *dm, int comp, char *fmt, ...)
+{
+}
+#else
+#define RF_DBG(dm, comp, fmt, args...)
+#endif
+
+#endif /*#if DBG*/
+
+/*@============================================================*/
+/*@ enumeration */
+/*@============================================================*/
+
+/*@============================================================*/
+/*@ structure */
+/*@============================================================*/
+
+/*@============================================================*/
+/*@ function prototype */
+/*@============================================================*/
+
+void halrf_cmd_parser(void *dm_void, char input[][16], u32 *_used, char *output,
+		      u32 *_out_len, u32 input_num);
+
+void halrf_init_debug_setting(void *dm_void);
+
+#endif /*__HALRF_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_dpk.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_dpk.h
new file mode 100644
index 000000000000..025fdfca7adc
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_dpk.h
@@ -0,0 +1,87 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HALRF_DPK_H__
+#define __HALRF_DPK_H__
+
+/*@--------------------------Define Parameters-------------------------------*/
+#define GAIN_LOSS 1
+#define DO_DPK 2
+#define DPK_ON 3
+#define DPK_LOK 4
+#define DPK_TXK 5
+
+#define DAGC 4
+#define LOSS_CHK 0
+#define GAIN_CHK 1
+#define PAS_READ 2
+#define AVG_THERMAL_NUM 8
+#define AVG_THERMAL_NUM_DPK 8
+#define THERMAL_DPK_AVG_NUM 4
+
+/*@---------------------------End Define Parameters---------------------------*/
+
+struct dm_dpk_info {
+
+	boolean	is_dpk_enable;
+	boolean	is_dpk_pwr_on;
+	boolean	is_dpk_by_channel;
+	u16 dpk_path_ok;
+	/*@BIT(15)~BIT(12) : 5G reserved, BIT(11)~BIT(8) 5G_S3~5G_S0*/
+	/*@BIT(7)~BIT(4) : 2G reserved, BIT(3)~BIT(0) 2G_S3~2G_S0*/
+	u8	thermal_dpk;
+	u8	thermal_dpk_avg[AVG_THERMAL_NUM_DPK];
+	u8	thermal_dpk_avg_index;
+
+#if (RTL8822C_SUPPORT == 1)
+	u8 	result[2][1];			/*path/group*/
+	u8 	tx_agc[2][1];			/*path/group*/
+	u32	coef[2][1][20];			/*path/group/MDPD coefficient*/
+#endif
+
+#if (RTL8198F_SUPPORT == 1 || RTL8192F_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
+	/*2G DPK data*/
+	u8 	dpk_result[4][3];		/*path/group*/
+	u8 	pwsf_2g[4][3];			/*path/group*/
+	u32	lut_2g_even[4][3][64];		/*path/group/LUT data*/
+	u32	lut_2g_odd[4][3][64];		/*path/group/LUT data*/
+#endif
+
+#if (RTL8195B_SUPPORT == 1)
+		/*2G DPK data*/
+		u8	dpk_2g_result[1][3];		/*path/group*/
+		u8	pwsf_2g[1][3];			/*path/group*/
+		u32	lut_2g_even[1][3][16];		/*path/group/LUT data*/
+		u32	lut_2g_odd[1][3][16];		/*path/group/LUT data*/
+		/*5G DPK data*/
+		u8	dpk_5g_result[1][6];		/*path/group*/
+		u8	pwsf_5g[1][6];			/*path/group*/
+		u32	lut_5g_even[1][6][16];		/*path/group/LUT data*/
+		u32	lut_5g_odd[1][6][16];		/*path/group/LUT data*/
+#endif
+};
+
+#endif /*__HALRF_DPK_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_features.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_features.h
index e119adcd6acb..a17483b98753 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_features.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_features.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,26 +9,36 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__HALRF_FEATURES_H__
-#define __HALRF_FEATURES
+#ifndef __HALRF_FEATURES_H__
+#define __HALRF_FEATURES_H__
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-	#define	CONFIG_HALRF_POWERTRACKING	1
+#define CONFIG_HALRF_POWERTRACKING 1
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-	#define	CONFIG_HALRF_POWERTRACKING	1
+#define CONFIG_HALRF_POWERTRACKING 1
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 
-	#define	CONFIG_HALRF_POWERTRACKING	1
+#define CONFIG_HALRF_POWERTRACKING 1
 
 #endif
 
-#endif
+#endif /*#ifndef __HALRF_FEATURES_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_iqk.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_iqk.h
index 93ec3c454902..fd8f9e57e7ba 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_iqk.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_iqk.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,68 +9,96 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMIQK_H__
-#define __PHYDMIQK_H__
+#ifndef __HALRF_IQK_H__
+#define __HALRF_IQK_H__
 
-/*--------------------------Define Parameters-------------------------------*/
-#define	LOK_delay 1
-#define	WBIQK_delay 10
-#define	TX_IQK 0
-#define	RX_IQK 1
-#define	TXIQK 0
-#define	RXIQK1 1
-#define	RXIQK2 2
+/*@--------------------------Define Parameters-------------------------------*/
+#define LOK_delay 1
+#define WBIQK_delay 10
+#define TX_IQK 0
+#define RX_IQK 1
+#define TXIQK 0
+#define RXIQK1 1
+#define RXIQK2 2
 #define kcount_limit_80m 2
 #define kcount_limit_others 4
-#define rxiqk_gs_limit 4
+#define rxiqk_gs_limit 10
+#define TXWBIQK_EN 1
+#define RXWBIQK_EN 1
+#define NUM 4
+/*@-----------------------End Define Parameters-----------------------*/
 
-#define	NUM 4
-/*---------------------------End Define Parameters-------------------------------*/
+struct dm_dack_info {
+	u32 ic_a;
+	u32 qc_a;
+	u32 ic_b;
+	u32 qc_b;
+};
 
-struct _IQK_INFORMATION {
-	boolean		LOK_fail[NUM];
-	boolean		IQK_fail[2][NUM];
-	u32		iqc_matrix[2][NUM];
-	u8      iqk_times;
-	u32		rf_reg18;
-	u32		lna_idx;
-	u8		rxiqk_step;
-	u8		tmp1bcc;
-	u8		kcount;
-	u8		rfk_ing; /*bit0:IQKing, bit1:LCKing, bit2:DPKing*/
-	boolean rfk_forbidden;	
-#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-	u32		iqk_channel[2];
-	boolean		IQK_fail_report[2][4][2]; /*channel/path/TRX(TX:0, RX:1) */
-	u32		IQK_CFIR_real[3][4][2][8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_real*/ /*channel index = 2 is just for debug*/
-	u32		IQK_CFIR_imag[3][4][2][8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_imag*/ /*channel index = 2 is just for debug*/
-	u8		retry_count[2][4][3]; /* channel / path / (TXK:0, RXK1:1, RXK2:2) */
-	u8		gs_retry_count[2][4][2]; /* channel / path / (GSRXK1:0, GSRXK2:1) */
-	u8		RXIQK_fail_code[2][4]; /* channel / path 0:SRXK1 fail, 1:RXK1 fail 2:RXK2 fail */
-	u32		LOK_IDAC[2][4];		/*channel / path*/
-	u16		RXIQK_AGC[2][4];	 /*channel / path*/
-	u32		bypass_iqk[2][4];	/*channel / 0xc94/0xe94*/
-	u32		txgap_result[8]; /*txagpK result  */
-	u32		tmp_GNTWL;
-	boolean		is_BTG;
-	boolean		isbnd;
+struct dm_iqk_info {
+	boolean lok_fail[NUM];
+	boolean iqk_fail[2][NUM];
+	u32 iqc_matrix[2][NUM];
+	u8 iqk_times;
+	u32 rf_reg18;
+	u32 rf_reg08;
+	u32 lna_idx;
+	u8 iqk_step;
+	u8 rxiqk_step;
+	u8 tmp1bcc;
+	u8 txgain;
+	u8 kcount;
+	u8 rfk_ing; /*bit0:IQKing, bit1:LCKing, bit2:DPKing*/
+	boolean rfk_forbidden;
+	u8 rxbb;
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
+	RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
+	u32 iqk_channel[2];
+	boolean iqk_fail_report[2][4][2]; /*channel/path/TRX(TX:0, RX:1) */
+	/*channel / path / TRX(TX:0, RX:1) / CFIR_real*/
+	/*channel index = 2 is just for debug*/
+	u32 iqk_cfir_real[3][4][2][8];
+	/*channel / path / TRX(TX:0, RX:1) / CFIR_imag*/
+	/*channel index = 2 is just for debug*/
+	u32 iqk_cfir_imag[3][4][2][8];
+	u8 retry_count[2][4][3]; /* channel / path / (TXK:0, RXK1:1, RXK2:2) */
+	u8 gs_retry_count[2][4][2]; /* channel / path / (GSRXK1:0, GSRXK2:1) */
+	/* channel / path 0:SRXK1 fail, 1:RXK1 fail 2:RXK2 fail */
+	u8 rxiqk_fail_code[2][4];
+	u32 lok_idac[2][4]; /*channel / path*/
+	u16 rxiqk_agc[2][4]; /*channel / path*/
+	u32 bypass_iqk[2][4]; /*channel / 0xc94/0xe94*/
+	u32 txgap_result[8]; /*txagpK result  */
+	u32 tmp_gntwl;
+	boolean is_btg;
+	boolean isbnd;
 	boolean is_reload;
 	boolean segment_iqk;
 	boolean is_hwtx;
-	
-	boolean	xym_read;
+	boolean xym_read;
 	boolean trximr_enable;
-	u32		rx_xym[2][10];
-	u32		tx_xym[2][10];
-	u32		gs1_xym[2][6];
-	u32		gs2_xym[2][6];
-	u32		rxk1_xym[2][6];
+	u32 rx_xym[2][10];
+	u32 tx_xym[2][10];
+	u32 gs1_xym[2][6];
+	u32 gs2_xym[2][6];
+	u32 rxk1_xym[2][6];
 #endif
 };
 
-#endif
+#endif /*__HALRF_IQK_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.c
index 1a127cf8d176..a110d352198f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,427 +9,372 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/*============================================================*/
-/*include files*/
-/*============================================================*/
+/*@============================================================*/
+/*@include files*/
+/*@============================================================*/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
+/*@<YuChen, 150720> Add for KFree Feature Requested by RF David.*/
+/*@This is a phydm API*/
 
-/*<YuChen, 150720> Add for KFree Feature Requested by RF David.*/
-/*This is a phydm API*/
-
-void
-phydm_set_kfree_to_rf_8814a(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	u8		data
-)
+void phydm_set_kfree_to_rf_8814a(void *dm_void, u8 e_rf_path, u8 data)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
 	boolean is_odd;
+	u32 tx_gain_bitmask = (BIT(17) | BIT(16) | BIT(15));
 
-	if ((data % 2) != 0) {	/*odd->positive*/
+	if ((data % 2) != 0) { /*odd->positive*/
 		data = data - 1;
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(19), 1);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), 1);
 		is_odd = true;
-	} else {		/*even->negative*/
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(19), 0);
+	} else { /*even->negative*/
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), 0);
 		is_odd = false;
 	}
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("phy_ConfigKFree8814A(): RF_0x55[19]= %d\n", is_odd));
+	RF_DBG(dm, DBG_RF_MP, "phy_ConfigKFree8814A(): RF_0x55[19]= %d\n",
+	       is_odd);
 	switch (data) {
 	case 0:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 0);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 0;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 0);
+		cali_info->kfree_offset[e_rf_path] = 0;
 		break;
 	case 2:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 0);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 0;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 0);
+		cali_info->kfree_offset[e_rf_path] = 0;
 		break;
 	case 4:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 1);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 1;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 1);
+		cali_info->kfree_offset[e_rf_path] = 1;
 		break;
 	case 6:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 1);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 1;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 1);
+		cali_info->kfree_offset[e_rf_path] = 1;
 		break;
 	case 8:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 2);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 2;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 2);
+		cali_info->kfree_offset[e_rf_path] = 2;
 		break;
 	case 10:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 2);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 2;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 2);
+		cali_info->kfree_offset[e_rf_path] = 2;
 		break;
 	case 12:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 3);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 3;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 3);
+		cali_info->kfree_offset[e_rf_path] = 3;
 		break;
 	case 14:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 3);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 3;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 3);
+		cali_info->kfree_offset[e_rf_path] = 3;
 		break;
 	case 16:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 4);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 4;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 4);
+		cali_info->kfree_offset[e_rf_path] = 4;
 		break;
 	case 18:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 1);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 4);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 4;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 4);
+		cali_info->kfree_offset[e_rf_path] = 4;
 		break;
 	case 20:
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(14), 0);
-		odm_set_rf_reg(p_dm, e_rf_path, REG_RF_TX_GAIN_OFFSET, BIT(17) | BIT(16) | BIT(15), 5);
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = 5;
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 5);
+		cali_info->kfree_offset[e_rf_path] = 5;
 		break;
 
 	default:
 		break;
 	}
 
-	if (is_odd == false) {
+	if (!is_odd) {
 		/*that means Kfree offset is negative, we need to record it.*/
-		p_rf_calibrate_info->kfree_offset[e_rf_path] = (-1) * p_rf_calibrate_info->kfree_offset[e_rf_path];
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("phy_ConfigKFree8814A(): kfree_offset = %d\n", p_rf_calibrate_info->kfree_offset[e_rf_path]));
-	} else
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("phy_ConfigKFree8814A(): kfree_offset = %d\n", p_rf_calibrate_info->kfree_offset[e_rf_path]));
-
+		cali_info->kfree_offset[e_rf_path] =
+				(-1) * cali_info->kfree_offset[e_rf_path];
+		RF_DBG(dm, DBG_RF_MP,
+		       "phy_ConfigKFree8814A(): kfree_offset = %d\n",
+		       cali_info->kfree_offset[e_rf_path]);
+	} else {
+		RF_DBG(dm, DBG_RF_MP,
+		       "phy_ConfigKFree8814A(): kfree_offset = %d\n",
+		       cali_info->kfree_offset[e_rf_path]);
+	}
 }
 
-
-
-//
-//
-//
-void
-phydm_get_thermal_trim_offset_8821c(
-	void	*p_dm_void
-)
+void phydm_get_thermal_trim_offset_8821c(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_power_trim_data	*p_power_trim_info = &(p_dm->power_trim_data);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
 	u8 pg_therm = 0xff;
 
-	odm_efuse_one_byte_read(p_dm, PPG_THERMAL_OFFSET_8821C, &pg_therm, false);
+	odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_21C, &pg_therm, false);
 
 	if (pg_therm != 0xff) {
 		pg_therm = pg_therm & 0x1f;
 		if ((pg_therm & BIT(0)) == 0)
-			p_power_trim_info->thermal = (-1 * (pg_therm >> 1));
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
 		else
-			p_power_trim_info->thermal = (pg_therm >> 1);
+			power_trim_info->thermal = (pg_therm >> 1);
 
-		p_power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8821c thermal trim flag:0x%02x\n", p_power_trim_info->flag));
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8821c thermal trim flag:0x%02x\n",
+	       power_trim_info->flag);
 
-	if (p_power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8821c thermal:%d\n", p_power_trim_info->thermal));
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		RF_DBG(dm, DBG_RF_MP, "[kfree] 8821c thermal:%d\n",
+		       power_trim_info->thermal);
 }
 
-
-
-void
-phydm_get_power_trim_offset_8821c(
-	void	*p_dm_void
-)
+void phydm_get_power_trim_offset_8821c(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_power_trim_data	*p_power_trim_info = &(p_dm->power_trim_data);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
 	u8 pg_power = 0xff, i;
 
-	odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_2G_TXAB_OFFSET_8821C, &pg_power, false);
+	odm_efuse_one_byte_read(dm, PPG_2G_TXAB_21C, &pg_power, false);
 
 	if (pg_power != 0xff) {
-		p_power_trim_info->bb_gain[0][0] = pg_power;
-		odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GL1_TXA_OFFSET_8821C, &pg_power, false);
-		p_power_trim_info->bb_gain[1][0] = pg_power;
-		odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GL2_TXA_OFFSET_8821C, &pg_power, false);
-		p_power_trim_info->bb_gain[2][0] = pg_power;
-		odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GM1_TXA_OFFSET_8821C, &pg_power, false);
-		p_power_trim_info->bb_gain[3][0] = pg_power;
-		odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GM2_TXA_OFFSET_8821C, &pg_power, false);
-		p_power_trim_info->bb_gain[4][0] = pg_power;
-		odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GH1_TXA_OFFSET_8821C, &pg_power, false);
-		p_power_trim_info->bb_gain[5][0] = pg_power;
-		p_power_trim_info->flag = p_power_trim_info->flag | KFREE_FLAG_ON | KFREE_FLAG_ON_2G | KFREE_FLAG_ON_5G;
+		power_trim_info->bb_gain[0][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_21C, &pg_power, false);
+		power_trim_info->bb_gain[1][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GL2_TXA_21C, &pg_power, false);
+		power_trim_info->bb_gain[2][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GM1_TXA_21C, &pg_power, false);
+		power_trim_info->bb_gain[3][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GM2_TXA_21C, &pg_power, false);
+		power_trim_info->bb_gain[4][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GH1_TXA_21C, &pg_power, false);
+		power_trim_info->bb_gain[5][0] = pg_power;
+		power_trim_info->flag =
+			power_trim_info->flag | KFREE_FLAG_ON |
+			KFREE_FLAG_ON_2G | KFREE_FLAG_ON_5G;
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8821c power trim flag:0x%02x\n", p_power_trim_info->flag));
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8821c power trim flag:0x%02x\n",
+	       power_trim_info->flag);
 
-	if (p_power_trim_info->flag & KFREE_FLAG_ON) {
+	if (power_trim_info->flag & KFREE_FLAG_ON) {
 		for (i = 0; i < KFREE_BAND_NUM; i++)
-			ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8821c power_trim_data->bb_gain[%d][0]=0x%X\n", i, p_power_trim_info->bb_gain[i][0]));
+			RF_DBG(dm, DBG_RF_MP,
+			       "[kfree] 8821c pwr_trim->bb_gain[%d][0]=0x%X\n",
+			       i, power_trim_info->bb_gain[i][0]);
 	}
 }
 
-
-
-void
-phydm_set_kfree_to_rf_8821c(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	boolean		wlg_btg,
-	u8		data
-)
+void phydm_set_kfree_to_rf_8821c(void *dm_void, u8 e_rf_path, boolean wlg_btg,
+				 u8 data)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	u8	wlg, btg;
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(0), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(5), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(6), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, BIT(6), 1);
-
-	if (wlg_btg == true) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 wlg, btg;
+	u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
+	u32 s_gain_bmask = (BIT(19) | BIT(18) | BIT(17) |
+			    BIT(16) | BIT(15) | BIT(14));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(5), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(6), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(6), 1);
+
+	if (wlg_btg) {
 		wlg = data & 0xf;
 		btg = (data & 0xf0) >> 4;
 
-		odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(19), (wlg & BIT(0)));
-		odm_set_rf_reg(p_dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (wlg >> 1));
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (wlg & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask, (wlg >> 1));
 
-		odm_set_rf_reg(p_dm, e_rf_path, 0x65, BIT(19), (btg & BIT(0)));
-		odm_set_rf_reg(p_dm, e_rf_path, 0x65, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (btg >> 1));
+		odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(19), (btg & BIT(0)));
+		odm_set_rf_reg(dm, e_rf_path, RF_0x65, gain_bmask, (btg >> 1));
 	} else {
-		odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
-		odm_set_rf_reg(p_dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), data & BIT(0));
+		odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
+			       ((data & 0x1f) >> 1));
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_TRACE,
-		("[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
-		odm_get_rf_reg(p_dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
-		odm_get_rf_reg(p_dm, e_rf_path, 0x65, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)))
-		));
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x55, s_gain_bmask),
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x65, s_gain_bmask));
 }
 
-
-
-void
-phydm_clear_kfree_to_rf_8821c(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	u8		data
-)
+void phydm_clear_kfree_to_rf_8821c(void *dm_void, u8 e_rf_path, u8 data)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(0), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(5), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(6), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, BIT(6), 1);
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (data >> 1));
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, BIT(19), (data & BIT(0)));
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), (data >> 1));
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(0), 0);
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(5), 0);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(6), 0);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, BIT(6), 0);
-
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_TRACE,
-		("[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
-		odm_get_rf_reg(p_dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
-		odm_get_rf_reg(p_dm, e_rf_path, 0x65, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)))
-		));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
+	u32 s_gain_bmask = (BIT(19) | BIT(18) | BIT(17) |
+			    BIT(16) | BIT(15) | BIT(14));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(5), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(6), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(6), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask, (data >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, gain_bmask, (data >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(5), 0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(6), 0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(6), 0);
+
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x55, s_gain_bmask),
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x65, s_gain_bmask));
 }
 
-
-
-void
-phydm_get_thermal_trim_offset_8822b(
-	void	*p_dm_void
-)
+void phydm_get_thermal_trim_offset_8822b(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_power_trim_data	*p_power_trim_info = &(p_dm->power_trim_data);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
 	u8 pg_therm = 0xff;
 
-#if 0
-	u32	thermal_trim_enable = 0xff;
-
-	odm_efuse_logical_map_read(p_dm, 1, 0xc8, &thermal_trim_enable);
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b 0xc8:0x%2x\n", thermal_trim_enable));
-
-	thermal_trim_enable = (thermal_trim_enable & BIT(5)) >> 5;
+	odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_22B, &pg_therm, false);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b thermal trim Enable:%d\n", thermal_trim_enable));
-
-	if ((p_rf_calibrate_info->reg_rf_kfree_enable == 0 && thermal_trim_enable == 1) ||
-		p_rf_calibrate_info->reg_rf_kfree_enable == 1) {
-#endif
-
-		odm_efuse_one_byte_read(p_dm, PPG_THERMAL_OFFSET, &pg_therm, false);
-
-		if (pg_therm != 0xff) {
-			pg_therm = pg_therm & 0x1f;
-			if ((pg_therm & BIT(0)) == 0)
-				p_power_trim_info->thermal = (-1 * (pg_therm >> 1));
-			else
-				p_power_trim_info->thermal = (pg_therm >> 1);
-
-			p_power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
-		}
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b thermal trim flag:0x%02x\n", p_power_trim_info->flag));
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
 
-		if (p_power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
-			ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b thermal:%d\n", p_power_trim_info->thermal));
-#if 0
-	} else
-		return;
-#endif
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b thermal trim flag:0x%02x\n",
+	       power_trim_info->flag);
 
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b thermal:%d\n",
+		       power_trim_info->thermal);
 }
 
-
-
-void
-phydm_get_power_trim_offset_8822b(
-	void	*p_dm_void
-)
+void phydm_get_power_trim_offset_8822b(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_power_trim_data	*p_power_trim_info = &(p_dm->power_trim_data);
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
 	u8 pg_power = 0xff, i, j;
 
-#if 0
-	u32	power_trim_enable = 0xff;
-
-	odm_efuse_logical_map_read(p_dm, 1, 0xc8, &power_trim_enable);
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b 0xc8:0x%2x\n", power_trim_enable));
-
-	power_trim_enable = (power_trim_enable & BIT(4)) >> 4;
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b power trim Enable:%d\n", power_trim_enable));
+	odm_efuse_one_byte_read(dm, PPG_2G_TXAB_22B, &pg_power, false);
 
-	if ((p_rf_calibrate_info->reg_rf_kfree_enable == 0 && power_trim_enable == 1) ||
-		p_rf_calibrate_info->reg_rf_kfree_enable == 1) {
-#endif
+	if (pg_power != 0xff) {
+		/*Path A*/
+		odm_efuse_one_byte_read(dm, PPG_2G_TXAB_22B, &pg_power, false);
+		power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
 
-		odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
+		/*Path B*/
+		odm_efuse_one_byte_read(dm, PPG_2G_TXAB_22B, &pg_power, false);
+		power_trim_info->bb_gain[0][1] = ((pg_power & 0xf0) >> 4);
 
-		if (pg_power != 0xff) {
-			/*Path A*/
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
+		power_trim_info->flag |= KFREE_FLAG_ON_2G;
+		power_trim_info->flag |= KFREE_FLAG_ON;
+	}
 
-			/*Path B*/
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_2G_TXAB_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[0][1] = ((pg_power & 0xf0) >> 4);
+	odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_22B, &pg_power, false);
 
-			p_power_trim_info->flag |= KFREE_FLAG_ON_2G;
-			p_power_trim_info->flag |= KFREE_FLAG_ON;
-		}
-
-		odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GL1_TXA_OFFSET, &pg_power, false);
-		
-		if (pg_power != 0xff) {
-			/*Path A*/
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GL1_TXA_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[1][0] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GL2_TXA_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[2][0] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GM1_TXA_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[3][0] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GM2_TXA_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[4][0] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GH1_TXA_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[5][0] = pg_power;
-
-			/*Path B*/
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GL1_TXB_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[1][1] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GL2_TXB_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[2][1] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GM1_TXB_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[3][1] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GM2_TXB_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[4][1] = pg_power;
-			odm_efuse_one_byte_read(p_dm, PPG_BB_GAIN_5GH1_TXB_OFFSET, &pg_power, false);
-			p_power_trim_info->bb_gain[5][1] = pg_power;
-			
-			p_power_trim_info->flag |= KFREE_FLAG_ON_5G;
-			p_power_trim_info->flag |= KFREE_FLAG_ON;
-		}
+	if (pg_power != 0xff) {
+		/*Path A*/
+		odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_22B, &pg_power, false);
+		power_trim_info->bb_gain[1][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GL2_TXA_22B, &pg_power, false);
+		power_trim_info->bb_gain[2][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GM1_TXA_22B, &pg_power, false);
+		power_trim_info->bb_gain[3][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GM2_TXA_22B, &pg_power, false);
+		power_trim_info->bb_gain[4][0] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GH1_TXA_22B, &pg_power, false);
+		power_trim_info->bb_gain[5][0] = pg_power;
+
+		/*Path B*/
+		odm_efuse_one_byte_read(dm, PPG_5GL1_TXB_22B, &pg_power, false);
+		power_trim_info->bb_gain[1][1] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GL2_TXB_22B, &pg_power, false);
+		power_trim_info->bb_gain[2][1] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GM1_TXB_22B, &pg_power, false);
+		power_trim_info->bb_gain[3][1] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GM2_TXB_22B, &pg_power, false);
+		power_trim_info->bb_gain[4][1] = pg_power;
+		odm_efuse_one_byte_read(dm, PPG_5GH1_TXB_22B, &pg_power, false);
+		power_trim_info->bb_gain[5][1] = pg_power;
+
+		power_trim_info->flag |= KFREE_FLAG_ON_5G;
+		power_trim_info->flag |= KFREE_FLAG_ON;
+	}
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b power trim flag:0x%02x\n", p_power_trim_info->flag));
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b power trim flag:0x%02x\n",
+	       power_trim_info->flag);
 
-		if (p_power_trim_info->flag & KFREE_FLAG_ON) {
-			for (i = 0; i < KFREE_BAND_NUM; i++) {
-				for (j = 0; j < 2; j++)
-					ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b power_trim_data->bb_gain[%d][%d]=0x%X\n", i, j, p_power_trim_info->bb_gain[i][j]));
-			}
-		}
-#if 0
-	} else
+	if (!(power_trim_info->flag & KFREE_FLAG_ON))
 		return;
-#endif
-}
-
 
+	for (i = 0; i < KFREE_BAND_NUM; i++) {
+		for (j = 0; j < 2; j++)
+			RF_DBG(dm, DBG_RF_MP,
+			       "[kfree] 8822b PwrTrim->bb_gain[%d][%d]=0x%X\n",
+			       i, j, power_trim_info->bb_gain[i][j]);
+	}
+}
 
-void
-phydm_set_pa_bias_to_rf_8822b(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	s8		tx_pa_bias
-)
+void phydm_set_pa_bias_to_rf_8822b(void *dm_void, u8 e_rf_path, s8 tx_pa_bias)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	u32	rf_reg_51 = 0, rf_reg_52 = 0, rf_reg_3f = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 rf_reg_51 = 0, rf_reg_52 = 0, rf_reg_3f = 0;
+	u32 tx_pa_bias_bmask = (BIT(12) | BIT(11) | BIT(10) | BIT(9));
 
-	rf_reg_51 = odm_get_rf_reg(p_dm, e_rf_path, 0x51, RFREGOFFSETMASK);
-	rf_reg_52 = odm_get_rf_reg(p_dm, e_rf_path, 0x52, RFREGOFFSETMASK);
+	rf_reg_51 = odm_get_rf_reg(dm, e_rf_path, RF_0x51, RFREGOFFSETMASK);
+	rf_reg_52 = odm_get_rf_reg(dm, e_rf_path, RF_0x52, RFREGOFFSETMASK);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b 2g rf(0x51)=0x%X rf(0x52)=0x%X path=%d\n",
- 		rf_reg_51, rf_reg_52, e_rf_path));
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8822b 2g rf(0x51)=0x%X rf(0x52)=0x%X path=%d\n",
+	       rf_reg_51, rf_reg_52, e_rf_path);
 
+#if 0
 	/*rf3f => rf52[19:17] = rf3f[2:0] rf52[16:15] = rf3f[4:3] rf52[3:0] = rf3f[8:5]*/
 	/*rf3f => rf51[6:3] = rf3f[12:9] rf52[13] = rf3f[13]*/
+#endif
 	rf_reg_3f = ((rf_reg_52 & 0xe0000) >> 17) |
-					(((rf_reg_52 & 0x18000) >> 15) << 3) |
-					((rf_reg_52 & 0xf) << 5) |
-					(((rf_reg_51 & 0x78) >> 3) << 9) |
-					(((rf_reg_52 & 0x2000) >> 13) << 13);
+		    (((rf_reg_52 & 0x18000) >> 15) << 3) |
+		    ((rf_reg_52 & 0xf) << 5) |
+		    (((rf_reg_51 & 0x78) >> 3) << 9) |
+		    (((rf_reg_52 & 0x2000) >> 13) << 13);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD,
-			("[kfree] 8822b 2g original tx_pa_bias=%d rf_reg_3f=0x%X path=%d\n",
-			tx_pa_bias, rf_reg_3f, e_rf_path));
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8822b 2g original pa_bias=%d rf_reg_3f=0x%X path=%d\n",
+	       tx_pa_bias, rf_reg_3f, e_rf_path);
 
-	tx_pa_bias = (s8)((rf_reg_3f & (BIT(12) | BIT(11) | BIT(10) | BIT(9))) >> 9) + tx_pa_bias;
+	tx_pa_bias = (s8)((rf_reg_3f & tx_pa_bias_bmask) >> 9) + tx_pa_bias;
 
 	if (tx_pa_bias < 0)
 		tx_pa_bias = 0;
@@ -437,334 +383,810 @@ phydm_set_pa_bias_to_rf_8822b(
 
 	rf_reg_3f = ((rf_reg_3f & 0xfe1ff) | (tx_pa_bias << 9));
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD,
-			("[kfree] 8822b 2g offset efuse 0x3d5 0x3d6 tx_pa_bias=%d rf_reg_3f=0x%X path=%d\n",
-			tx_pa_bias, rf_reg_3f, e_rf_path));
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0xef, BIT(10), 0x1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x33, RFREGOFFSETMASK, 0x0);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x33, BIT(0), 0x1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x33, BIT(1), 0x1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x33, (BIT(1) | BIT(0)), 0x3);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x3f, RFREGOFFSETMASK, rf_reg_3f);
-	odm_set_rf_reg(p_dm, e_rf_path, 0xef, BIT(10), 0x0);
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD,
-		("[kfree] 8822b 2g tx pa bias rf_0x3f(0x%X) path=%d\n",
-		odm_get_rf_reg(p_dm, e_rf_path, 0x3f, (BIT(12) | BIT(11) | BIT(10) | BIT(9))), e_rf_path));
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8822b 2g 0x%X 0x%X pa_bias=%d rfreg_3f=0x%X path=%d\n",
+	       PPG_PABIAS_2GA_22B, PPG_PABIAS_2GB_22B,
+	       tx_pa_bias, rf_reg_3f, e_rf_path);
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(10), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, BIT(0), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, BIT(1), 0x1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, (BIT(1) | BIT(0)), 0x3);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(10), 0x0);
+
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8822b 2g tx pa bias rf_0x3f(0x%X) path=%d\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x3f,
+			      (BIT(12) | BIT(11) | BIT(10) | BIT(9))),
+			      e_rf_path);
 }
 
-
-
-void
-phydm_get_pa_bias_offset_8822b(
-	void	*p_dm_void
-)
+void phydm_get_pa_bias_offset_8822b(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_power_trim_data	*p_power_trim_info = &(p_dm->power_trim_data);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
 	u8 pg_pa_bias = 0xff, e_rf_path = 0;
 	s8 tx_pa_bias[2] = {0};
 
-	odm_efuse_one_byte_read(p_dm, PPG_PA_BIAS_2G_TXA_OFFSET, &pg_pa_bias, false);
+	odm_efuse_one_byte_read(dm, PPG_PABIAS_2GA_22B, &pg_pa_bias, false);
 
 	if (pg_pa_bias != 0xff) {
 		/*paht a*/
-		odm_efuse_one_byte_read(p_dm, PPG_PA_BIAS_2G_TXA_OFFSET, &pg_pa_bias, false);
+		odm_efuse_one_byte_read(dm, PPG_PABIAS_2GA_22B,
+					&pg_pa_bias, false);
 		pg_pa_bias = pg_pa_bias & 0xf;
-		
+
 		if ((pg_pa_bias & BIT(0)) == 0)
 			tx_pa_bias[0] = (-1 * (pg_pa_bias >> 1));
 		else
 			tx_pa_bias[0] = (pg_pa_bias >> 1);
 
 		/*paht b*/
-		odm_efuse_one_byte_read(p_dm, PPG_PA_BIAS_2G_TXB_OFFSET, &pg_pa_bias, false);
+		odm_efuse_one_byte_read(dm, PPG_PABIAS_2GB_22B,
+					&pg_pa_bias, false);
 		pg_pa_bias = pg_pa_bias & 0xf;
-		
+
 		if ((pg_pa_bias & BIT(0)) == 0)
 			tx_pa_bias[1] = (-1 * (pg_pa_bias >> 1));
 		else
 			tx_pa_bias[1] = (pg_pa_bias >> 1);
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b 2g tx_patha_pa_bias:%d   tx_pathb_pa_bias:%d\n", tx_pa_bias[0], tx_pa_bias[1]));
+		RF_DBG(dm, DBG_RF_MP,
+		       "[kfree] 8822b 2g PathA_pa_bias:%d PathB_pa_bias:%d\n",
+		       tx_pa_bias[0], tx_pa_bias[1]);
 
-		for (e_rf_path = RF_PATH_A;  e_rf_path < 2; e_rf_path++)
-			phydm_set_pa_bias_to_rf_8822b(p_dm, e_rf_path, tx_pa_bias[e_rf_path]);
+		for (e_rf_path = RF_PATH_A; e_rf_path < 2; e_rf_path++)
+			phydm_set_pa_bias_to_rf_8822b(dm, e_rf_path,
+						      tx_pa_bias[e_rf_path]);
+
+		power_trim_info->pa_bias_flag |= PA_BIAS_FLAG_ON;
+	} else {
+		RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b 2g tx pa bias no pg\n");
 	}
-	else
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] 8822b 2g tx pa bias no pg\n"));
 }
 
+void phydm_set_kfree_to_rf_8822b(void *dm_void, u8 e_rf_path, u8 data)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
+		       ((data & 0x1f) >> 1));
+
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b 0x55[19:14]=0x%X path=%d\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x55,
+			      (BIT(19) | BIT(18) | BIT(17) | BIT(16) |
+			      BIT(15) | BIT(14))), e_rf_path);
+}
 
+void phydm_clear_kfree_to_rf_8822b(void *dm_void, u8 e_rf_path, u8 data)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
+		       ((data & 0x1f) >> 1));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(4), 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x65, MASKLWORD, 0x9000);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(7), 0);
+
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8822b clear power trim 0x55[19:14]=0x%X path=%d\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x55,
+			      (BIT(19) | BIT(18) | BIT(17) | BIT(16) |
+			      BIT(15) | BIT(14))), e_rf_path);
+}
 
-void
-phydm_set_kfree_to_rf_8822b(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	u8		data
-)
+void phydm_get_thermal_trim_offset_8710b(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(0), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(4), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(5), 1);
+	u8 pg_therm = 0xff;
 
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
+	odm_efuse_one_byte_read(dm, 0x0EF, &pg_therm, false);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD,
-		("[kfree] 8822b 0x55[19:14]=0x%X path=%d\n",
-		odm_get_rf_reg(p_dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
-		e_rf_path
-		));
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
+
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
+
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b thermal trim flag:0x%02x\n",
+	       power_trim_info->flag);
+
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b thermal:%d\n",
+		       power_trim_info->thermal);
 }
 
+void phydm_get_power_trim_offset_8710b(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
+
+	u8 pg_power = 0xff;
+
+	odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
+
+	if (pg_power != 0xff) {
+		/*Path A*/
+		odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
+		power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
+
+		power_trim_info->flag |= KFREE_FLAG_ON_2G;
+		power_trim_info->flag |= KFREE_FLAG_ON;
+	}
 
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b power trim flag:0x%02x\n",
+	       power_trim_info->flag);
 
-void
-phydm_clear_kfree_to_rf_8822b(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	u8		data
-)
+	if (power_trim_info->flag & KFREE_FLAG_ON)
+		RF_DBG(dm, DBG_RF_MP,
+		       "[kfree] 8710b power_trim_data->bb_gain[0][0]=0x%X\n",
+		       power_trim_info->bb_gain[0][0]);
+}
+
+void phydm_set_kfree_to_rf_8710b(void *dm_void, u8 e_rf_path, u8 data)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(0), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(4), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(5), 1);
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(19), (data & BIT(0)));
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
-
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(0), 0);
-	odm_set_rf_reg(p_dm, e_rf_path, 0xde, BIT(4), 1);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x65, MASKLWORD, 0x9000);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(5), 0);
-	odm_set_rf_reg(p_dm, e_rf_path, 0x55, BIT(7), 0);
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD,
-		("[kfree] 8822b clear power trim 0x55[19:14]=0x%X path=%d\n",
-		odm_get_rf_reg(p_dm, e_rf_path, 0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
-		e_rf_path
-		));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask, ((data & 0xf) >> 1));
+
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b 0x55[19:14]=0x%X path=%d\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x55,
+			      (BIT(19) | BIT(18) | BIT(17) | BIT(16) |
+			      BIT(15) | BIT(14))), e_rf_path);
+}
+
+void phydm_clear_kfree_to_rf_8710b(void *dm_void, u8 e_rf_path, u8 data)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
+		       ((data & 0x1f) >> 1));
+
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8710b clear power trim 0x55[19:14]=0x%X path=%d\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x55,
+			      (BIT(19) | BIT(18) | BIT(17) | BIT(16) |
+			      BIT(15) | BIT(14))), e_rf_path);
 }
 
+void phydm_get_thermal_trim_offset_8192f(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
+
+	u8 pg_therm = 0xff;
+
+	odm_efuse_one_byte_read(dm, 0x1EF, &pg_therm, false);
+
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
+
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
+
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8192f thermal trim flag:0x%02x\n",
+	       power_trim_info->flag);
 
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		RF_DBG(dm, DBG_RF_MP, "[kfree] 8192f thermal:%d\n",
+		       power_trim_info->thermal);
+}
 
-void
-phydm_set_kfree_to_rf(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	u8		data
-)
+void phydm_get_power_trim_offset_8192f(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
+
+	u8 pg_power1 = 0xff, pg_power2 = 0xff, pg_power3 = 0xff, i, j;
+
+	odm_efuse_one_byte_read(dm, 0x1EE, &pg_power1, false); /*CH4-9*/
+
+	if (pg_power1 != 0xff) {
+		/*Path A*/
+		odm_efuse_one_byte_read(dm, 0x1EE, &pg_power1, false);
+		power_trim_info->bb_gain[1][0] = (pg_power1 & 0xf);
+		/*Path B*/
+		odm_efuse_one_byte_read(dm, 0x1EE, &pg_power1, false);
+		power_trim_info->bb_gain[1][1] = ((pg_power1 & 0xf0) >> 4);
+
+		power_trim_info->flag |= KFREE_FLAG_ON_2G;
+		power_trim_info->flag |= KFREE_FLAG_ON;
+	}
 
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		phydm_set_kfree_to_rf_8814a(p_dm, e_rf_path, data);
+	odm_efuse_one_byte_read(dm, 0x1EC, &pg_power2, false); /*CH1-3*/
 
-	if ((p_dm->support_ic_type & ODM_RTL8821C) && (*p_dm->p_band_type == ODM_BAND_2_4G))
-		phydm_set_kfree_to_rf_8821c(p_dm, e_rf_path, true, data);
-	else if (p_dm->support_ic_type & ODM_RTL8821C)
-		phydm_set_kfree_to_rf_8821c(p_dm, e_rf_path, false, data);
+	if (pg_power2 != 0xff) {
+		/*Path A*/
+		odm_efuse_one_byte_read(dm, 0x1EC, &pg_power2, false);
+		power_trim_info->bb_gain[0][0] = (pg_power2 & 0xf);
+		/*Path B*/
+		odm_efuse_one_byte_read(dm, 0x1EC, &pg_power2, false);
+		power_trim_info->bb_gain[0][1] = ((pg_power2 & 0xf0) >> 4);
 
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		phydm_set_kfree_to_rf_8822b(p_dm, e_rf_path, data);
+		power_trim_info->flag |= KFREE_FLAG_ON_2G;
+		power_trim_info->flag |= KFREE_FLAG_ON;
+	} else {
+		power_trim_info->bb_gain[0][0] = (pg_power1 & 0xf);
+		power_trim_info->bb_gain[0][1] = ((pg_power1 & 0xf0) >> 4);
+	}
+
+	odm_efuse_one_byte_read(dm, 0x1EA, &pg_power3, false); /*CH10-14*/
+
+	if (pg_power3 != 0xff) {
+		/*Path A*/
+		odm_efuse_one_byte_read(dm, 0x1EA, &pg_power3, false);
+		power_trim_info->bb_gain[2][0] = (pg_power3 & 0xf);
+		/*Path B*/
+		odm_efuse_one_byte_read(dm, 0x1EA, &pg_power3, false);
+		power_trim_info->bb_gain[2][1] = ((pg_power3 & 0xf0) >> 4);
+
+		power_trim_info->flag |= KFREE_FLAG_ON_2G;
+		power_trim_info->flag |= KFREE_FLAG_ON;
+	} else {
+		power_trim_info->bb_gain[2][0] = (pg_power1 & 0xf);
+		power_trim_info->bb_gain[2][1] = ((pg_power1 & 0xf0) >> 4);
+	}
+
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8192F power trim flag:0x%02x\n",
+	       power_trim_info->flag);
+
+	if (!(power_trim_info->flag & KFREE_FLAG_ON))
+		return;
+
+	for (i = 0; i < KFREE_CH_NUM; i++) {
+		for (j = 0; j < 2; j++)
+			RF_DBG(dm, DBG_RF_MP,
+			       "[kfree] 8192F PwrTrim->bb_gain[%d][%d]=0x%X\n",
+			       i, j, power_trim_info->bb_gain[i][j]);
+	}
 }
 
+void phydm_set_kfree_to_rf_8192f(void *dm_void, u8 e_rf_path, u8 channel_idx,
+				 u8 data)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	/*power_trim based on 55[19:14]*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
+	/*enable 55[14] for 0.5db step*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 1);
+	/*enter power_trim debug mode*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 1);
+	/*write enable*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 1);
+
+	if (e_rf_path == 0) {
+		if (channel_idx == 0) {
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+
+		} else if (channel_idx == 1) {
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+		} else if (channel_idx == 2) {
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+		}
+	} else if (e_rf_path == 1) {
+		if (channel_idx == 0) {
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+		} else if (channel_idx == 1) {
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+		} else if (channel_idx == 2) {
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+
+			odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
+			odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
+		}
+	}
+
+	/*leave power_trim debug mode*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
+	/*write disable*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 0);
 
+	RF_DBG(dm, DBG_RF_MP,
+	       "[kfree] 8192F 0x55[19:14]=0x%X path=%d channel=%d\n",
+	       odm_get_rf_reg(dm, e_rf_path, RF_0x55,
+			      (BIT(19) | BIT(18) | BIT(17) | BIT(16) |
+			      BIT(15) | BIT(14))), e_rf_path, channel_idx);
+}
 
-void
-phydm_clear_kfree_to_rf(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	u8		data
-)
+#if 0
+/*
+void phydm_clear_kfree_to_rf_8192f(void *dm_void, u8 e_rf_path, u8 data)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
 
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		phydm_clear_kfree_to_rf_8822b(p_dm, e_rf_path, 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
 
-	if (p_dm->support_ic_type & ODM_RTL8821C)
-		phydm_clear_kfree_to_rf_8821c(p_dm, e_rf_path, 1);
+	RF_DBG(dm, DBG_RF_MP,
+		"[kfree] 8192F clear power trim 0x55[19:14]=0x%X path=%d\n",
+		odm_get_rf_reg(dm, e_rf_path, RF_0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
+		e_rf_path
+		);
 }
+*/
+#endif
 
+void phydm_get_thermal_trim_offset_8198f(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
+
+	u8 pg_therm = 0xff;
+
+	odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_98F, &pg_therm, false);
+
+	if (pg_therm != 0xff) {
+		pg_therm = pg_therm & 0x1f;
+		if ((pg_therm & BIT(0)) == 0)
+			power_trim_info->thermal = (-1 * (pg_therm >> 1));
+		else
+			power_trim_info->thermal = (pg_therm >> 1);
 
+		power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
+	}
 
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8198f thermal trim flag:0x%02x\n",
+	       power_trim_info->flag);
 
-void
-phydm_get_thermal_trim_offset(
-	void	*p_dm_void
-)
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		RF_DBG(dm, DBG_RF_MP, "[kfree] 8198f thermal:%d\n",
+		       power_trim_info->thermal);
+}
+
+void phydm_get_power_trim_offset_8198f(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	PEFUSE_HAL		pEfuseHal = &(p_hal_data->EfuseHal);
-	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+	u8 pg_power = 0xff, i, j;
 
-	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO(adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] dump efuse fail !!!\n"));
-#endif
+	odm_efuse_one_byte_read(dm, PPG_2GL_TXAB_98F, &pg_power, false);
+
+	if (pg_power != 0xff) {
+		power_trim_info->bb_gain[0][0] = pg_power & 0xf;
+		power_trim_info->bb_gain[0][1] = (pg_power & 0xf0) >> 4;
+
+		odm_efuse_one_byte_read(dm, PPG_2GL_TXCD_98F, &pg_power, false);
+		power_trim_info->bb_gain[0][2] = pg_power & 0xf;
+		power_trim_info->bb_gain[0][3] = (pg_power & 0xf0) >> 4;
+
+		odm_efuse_one_byte_read(dm, PPG_2GM_TXAB_98F, &pg_power, false);
+		power_trim_info->bb_gain[1][0] = pg_power & 0xf;
+		power_trim_info->bb_gain[1][1] = (pg_power & 0xf0) >> 4;
 
-	if (p_dm->support_ic_type & ODM_RTL8821C)
-		phydm_get_thermal_trim_offset_8821c(p_dm_void);
-	else if (p_dm->support_ic_type & ODM_RTL8822B)
-		phydm_get_thermal_trim_offset_8822b(p_dm_void);
+		odm_efuse_one_byte_read(dm, PPG_2GM_TXCD_98F, &pg_power, false);
+		power_trim_info->bb_gain[1][2] = pg_power & 0xf;
+		power_trim_info->bb_gain[1][3] = (pg_power & 0xf0) >> 4;
+
+		odm_efuse_one_byte_read(dm, PPG_5GH_TXAB_98F, &pg_power, false);
+		power_trim_info->bb_gain[2][0] = pg_power & 0xf;
+		power_trim_info->bb_gain[2][1] = (pg_power & 0xf0) >> 4;
+
+		odm_efuse_one_byte_read(dm, PPG_5GH_TXCD_98F, &pg_power, false);
+		power_trim_info->bb_gain[2][2] = pg_power & 0xf;
+		power_trim_info->bb_gain[2][3] = (pg_power & 0xf0) >> 4;
+
+		power_trim_info->flag =
+			power_trim_info->flag | KFREE_FLAG_ON | KFREE_FLAG_ON_2G;
+	}
+
+	RF_DBG(dm, DBG_RF_MP, "[kfree] 8198f power trim flag:0x%02x\n",
+	       power_trim_info->flag);
+
+	if (power_trim_info->flag & KFREE_FLAG_ON) {
+		for (i = 0; i < KFREE_BAND_NUM; i++) {
+			for (j = 0; j < MAX_RF_PATH; j++) {
+				RF_DBG(dm, DBG_RF_MP,
+				       "[kfree] 8198f pwr_trim->bb_gain[%d][%d]=0x%X\n",
+				       i, j, power_trim_info->bb_gain[i][j]);
+			}
+		}
+	}
 }
 
+void phydm_set_kfree_to_rf_8198f(void *dm_void, u8 e_rf_path, u8 data)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
+	u32 band, i;
+	s8 pwr_offset[3];
+
+	RF_DBG(dm, DBG_RF_MP,
+		   "[kfree] %s:Set kfree to rf 0x33\n", __func__);
+
+	/*power_trim based on 55[19:14]*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
+	/*enable 55[14] for 0.5db step*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 1);
+	/*enter power_trim debug mode*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
+	/*write enable*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 1);
+
+	for (i =0; i < 3; i++)
+		pwr_offset[i] = power_trim_info->bb_gain[i][e_rf_path];
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[0]);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[0]);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[1]);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[1]);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[2]);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[2]);
+
+	/*leave power_trim debug mode*/
+	/*odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);*/
+	/*write disable*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 0);
 
+}
 
-void
-phydm_get_power_trim_offset(
-	void	*p_dm_void
-)
+void phydm_clear_kfree_to_rf_8198f(void *dm_void, u8 e_rf_path, u8 data)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	PEFUSE_HAL		pEfuseHal = &(p_hal_data->EfuseHal);
-	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+	RF_DBG(dm, DBG_RF_MP,
+		   "[kfree] %s:Clear kfree to rf 0x55\n", __func__);
+#if 0
+	/*power_trim based on 55[19:14]*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
+	/*enable 55[14] for 0.5db step*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 1);
+	/*enter power_trim debug mode*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
+	/*write enable*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 1);
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
+	odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
+
+	/*leave power_trim debug mode*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
+	/*enable 55[14] for 0.5db step*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 0);
+	/*write disable*/
+	odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 0);
+#else
+
+	odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 1);
+	/*odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 0);*/
 
-	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO(adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] dump efuse fail !!!\n"));
 #endif
 
-	if (p_dm->support_ic_type & ODM_RTL8821C)
-		phydm_get_power_trim_offset_8821c(p_dm_void);
-	else if (p_dm->support_ic_type & ODM_RTL8822B)
-		phydm_get_power_trim_offset_8822b(p_dm_void);
 }
 
 
+void phydm_set_kfree_to_rf(void *dm_void, u8 e_rf_path, u8 data)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phydm_set_kfree_to_rf_8814a(dm, e_rf_path, data);
+
+	if ((dm->support_ic_type & ODM_RTL8821C) &&
+	    (*dm->band_type == ODM_BAND_2_4G))
+		phydm_set_kfree_to_rf_8821c(dm, e_rf_path, true, data);
+	else if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_set_kfree_to_rf_8821c(dm, e_rf_path, false, data);
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_set_kfree_to_rf_8822b(dm, e_rf_path, data);
+
+	if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_set_kfree_to_rf_8710b(dm, e_rf_path, data);
+
+	if (dm->support_ic_type & ODM_RTL8198F)
+		phydm_set_kfree_to_rf_8198f(dm, e_rf_path, data);
+}
 
-void
-phydm_get_pa_bias_offset(
-	void	*p_dm_void
-)
+void phydm_clear_kfree_to_rf(void *dm_void, u8 e_rf_path, u8 data)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_clear_kfree_to_rf_8822b(dm, e_rf_path, 1);
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_clear_kfree_to_rf_8821c(dm, e_rf_path, 1);
+
+	if (dm->support_ic_type & ODM_RTL8198F)
+		phydm_clear_kfree_to_rf_8198f(dm, e_rf_path, 0);
+}
+
+void phydm_get_thermal_trim_offset(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	PEFUSE_HAL		pEfuseHal = &(p_hal_data->EfuseHal);
+	void *adapter = dm->adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL pEfuseHal = &hal_data->EfuseHal;
+	u1Byte eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		RF_DBG(dm, DBG_RF_MP, "[kfree] dump efuse fail !!!\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_get_thermal_trim_offset_8821c(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_thermal_trim_offset_8822b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_get_thermal_trim_offset_8710b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8192F)
+		phydm_get_thermal_trim_offset_8192f(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8198F)
+		phydm_get_thermal_trim_offset_8198f(dm_void);
+}
+
+void phydm_get_power_trim_offset(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+#if 0 //(DM_ODM_SUPPORT_TYPE & ODM_WIN)	// 2017 MH DM Should use the same code.s
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL		pEfuseHal = &hal_data->EfuseHal;
 	u1Byte			eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
 
 	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO(adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] dump efuse fail !!!\n"));
+		RF_DBG(dm, DBG_RF_MP, "[kfree] dump efuse fail !!!\n");
 #endif
 
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		phydm_get_pa_bias_offset_8822b(p_dm_void);
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_get_power_trim_offset_8821c(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_power_trim_offset_8822b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8710B)
+		phydm_get_power_trim_offset_8710b(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8192F)
+		phydm_get_power_trim_offset_8192f(dm_void);
+	else if (dm->support_ic_type & ODM_RTL8198F)
+		phydm_get_power_trim_offset_8198f(dm_void);
 }
 
+void phydm_get_pa_bias_offset(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void *adapter = dm->adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	PEFUSE_HAL pEfuseHal = &hal_data->EfuseHal;
+	u1Byte eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
+
+	if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
+		RF_DBG(dm, DBG_RF_MP, "[kfree] dump efuse fail !!!\n");
+#endif
 
-s8
-phydm_get_thermal_offset(
-	void	*p_dm_void
-)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_get_pa_bias_offset_8822b(dm_void);
+}
+
+s8 phydm_get_thermal_offset(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_power_trim_data	*p_power_trim_info = &(p_dm->power_trim_data);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
 
-	if (p_power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
-		return p_power_trim_info->thermal;
+	if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
+		return power_trim_info->thermal;
 	else
 		return 0;
 }
 
-
-
-void
-phydm_config_kfree(
-	void	*p_dm_void,
-	u8	channel_to_sw
-)
+void phydm_do_kfree(void *dm_void, u8 channel_to_sw)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	struct odm_power_trim_data	*p_power_trim_info = &(p_dm->power_trim_data);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_power_trim_data *pwrtrim = &dm->power_trim_data;
+	u8 channel_idx = 0, rfpath = 0, max_path = 0, kfree_band_num = 0;
+	u8 i, j;
+	s8 bb_gain;
+
+	if (dm->support_ic_type & ODM_RTL8814A)
+		max_path = 4; /*0~3*/
+	else if (dm->support_ic_type &
+		 (ODM_RTL8812 | ODM_RTL8822B | ODM_RTL8192F)) {
+		max_path = 2; /*0~1*/
+		kfree_band_num = KFREE_BAND_NUM;
+	} else if (dm->support_ic_type & ODM_RTL8821C) {
+		max_path = 1;
+		kfree_band_num = KFREE_BAND_NUM;
+	} else if (dm->support_ic_type & ODM_RTL8710B) {
+		max_path = 1;
+		kfree_band_num = 1;
+	} else if (dm->support_ic_type & ODM_RTL8198F) {
+		max_path = 4;
+		kfree_band_num = 3;
+	}
 
-	u8			rfpath = 0, max_rf_path = 0;
-	u8			channel_idx = 0, i, j;
+	if (dm->support_ic_type &
+	    (ODM_RTL8192F | ODM_RTL8822B | ODM_RTL8821C |
+	    ODM_RTL8814A | ODM_RTL8710B)) {
+		for (i = 0; i < kfree_band_num; i++) {
+			for (j = 0; j < max_path; j++)
+				RF_DBG(dm, DBG_RF_MP,
+				       "[kfree] PwrTrim->gain[%d][%d]=0x%X\n",
+				       i, j, pwrtrim->bb_gain[i][j]);
+		}
+	}
+	if (*dm->band_type == ODM_BAND_2_4G &&
+	    pwrtrim->flag & KFREE_FLAG_ON_2G) {
+		if (!(dm->support_ic_type & ODM_RTL8192F)) {
+			if (channel_to_sw >= 1 && channel_to_sw <= 14)
+				channel_idx = PHYDM_2G;
+			for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
+				RF_DBG(dm, DBG_RF_MP,
+				       "[kfree] %s:chnl=%d PATH=%d gain:0x%X\n",
+				       __func__, channel_to_sw, rfpath,
+				       pwrtrim->bb_gain[channel_idx][rfpath]);
+				bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
+				phydm_set_kfree_to_rf(dm, rfpath, bb_gain);
+			}
+		} else if (dm->support_ic_type & ODM_RTL8192F) {
+			if (channel_to_sw >= 1 && channel_to_sw <= 3)
+				channel_idx = 0;
+			if (channel_to_sw >= 4 && channel_to_sw <= 9)
+				channel_idx = 1;
+			if (channel_to_sw >= 10 && channel_to_sw <= 14)
+				channel_idx = 2;
+			for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
+				RF_DBG(dm, DBG_RF_MP,
+				       "[kfree] %s:chnl=%d PATH=%d gain:0x%X\n",
+				       __func__, channel_to_sw, rfpath,
+				       pwrtrim->bb_gain[channel_idx][rfpath]);
+				bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
+				phydm_set_kfree_to_rf_8192f(dm, rfpath,
+							    channel_idx,
+							    bb_gain);
+			}
+		}
+	} else if (*dm->band_type == ODM_BAND_5G &&
+		   pwrtrim->flag & KFREE_FLAG_ON_5G) {
+		if (channel_to_sw >= 36 && channel_to_sw <= 48)
+			channel_idx = PHYDM_5GLB1;
+		if (channel_to_sw >= 52 && channel_to_sw <= 64)
+			channel_idx = PHYDM_5GLB2;
+		if (channel_to_sw >= 100 && channel_to_sw <= 120)
+			channel_idx = PHYDM_5GMB1;
+		if (channel_to_sw >= 122 && channel_to_sw <= 144)
+			channel_idx = PHYDM_5GMB2;
+		if (channel_to_sw >= 149 && channel_to_sw <= 177)
+			channel_idx = PHYDM_5GHB;
+
+		for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
+			RF_DBG(dm, DBG_RF_MP,
+			       "[kfree] %s: channel=%d PATH=%d bb_gain:0x%X\n",
+			       __func__, channel_to_sw, rfpath,
+			       pwrtrim->bb_gain[channel_idx][rfpath]);
+			bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
+			phydm_set_kfree_to_rf(dm, rfpath, bb_gain);
+		}
+	} else {
+		RF_DBG(dm, DBG_RF_MP, "[kfree] Set default Register\n");
+		if (!(dm->support_ic_type & ODM_RTL8192F)) {
+			for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
+				bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
+				phydm_clear_kfree_to_rf(dm, rfpath, bb_gain);
+			}
+		}
+#if 0
+		/*else if(dm->support_ic_type & ODM_RTL8192F){
+			if (channel_to_sw >= 1 && channel_to_sw <= 3)
+				channel_idx = 0;
+			if (channel_to_sw >= 4 && channel_to_sw <= 9)
+				channel_idx = 1;
+			if (channel_to_sw >= 9 && channel_to_sw <= 14)
+				channel_idx = 2;
+			for (rfpath = RF_PATH_A;  rfpath < max_path; rfpath++)
+				phydm_clear_kfree_to_rf_8192f(dm, rfpath, pwrtrim->bb_gain[channel_idx][rfpath]);
+		}*/
+#endif
+	}
+}
 
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		max_rf_path = 4;	/*0~3*/
-	else if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E | ODM_RTL8822B))
-		max_rf_path = 2;	/*0~1*/
-	else if (p_dm->support_ic_type & ODM_RTL8821C)
-		max_rf_path = 1;
+void phydm_config_kfree(void *dm_void, u8 channel_to_sw)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	struct odm_power_trim_data *pwrtrim = &dm->power_trim_data;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("===>[kfree] phy_ConfigKFree()\n"));
+	RF_DBG(dm, DBG_RF_MP, "===>[kfree] phy_ConfigKFree()\n");
 
-	if (p_rf_calibrate_info->reg_rf_kfree_enable == 2) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] phy_ConfigKFree(): reg_rf_kfree_enable == 2, Disable\n"));
+	if (cali_info->reg_rf_kfree_enable == 2) {
+		RF_DBG(dm, DBG_RF_MP,
+		       "[kfree] %s: reg_rf_kfree_enable == 2, Disable\n",
+		       __func__);
 		return;
-	} else if (p_rf_calibrate_info->reg_rf_kfree_enable == 1 || p_rf_calibrate_info->reg_rf_kfree_enable == 0) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] phy_ConfigKFree(): reg_rf_kfree_enable == true\n"));
+	} else if (cali_info->reg_rf_kfree_enable == 1 ||
+			cali_info->reg_rf_kfree_enable == 0) {
+		RF_DBG(dm, DBG_RF_MP,
+		       "[kfree] %s: reg_rf_kfree_enable == true\n", __func__);
 		/*Make sure the targetval is defined*/
-		if (p_power_trim_info->flag & KFREE_FLAG_ON) {
-			/*if kfree_table[0] == 0xff, means no Kfree*/
-
-			for (i = 0; i < KFREE_BAND_NUM; i++) {
-				for (j = 0; j < max_rf_path; j++)
-					ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] power_trim_data->bb_gain[%d][%d]=0x%X\n", i, j, p_power_trim_info->bb_gain[i][j]));
-			}
-
-			if (*p_dm->p_band_type == ODM_BAND_2_4G && p_power_trim_info->flag & KFREE_FLAG_ON_2G) {
-				
-				if (channel_to_sw >= 1 && channel_to_sw <= 14)
-					channel_idx = PHYDM_2G;
-
-				for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++) {
-					ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] phydm_kfree(): channel_to_sw=%d PATH_%d bb_gain:0x%X\n", channel_to_sw, rfpath, p_power_trim_info->bb_gain[channel_idx][rfpath]));
-					phydm_set_kfree_to_rf(p_dm, rfpath, p_power_trim_info->bb_gain[channel_idx][rfpath]);
-				}
-
-			} else if (*p_dm->p_band_type == ODM_BAND_5G && p_power_trim_info->flag & KFREE_FLAG_ON_5G) {
-
-				if (channel_to_sw >= 36 && channel_to_sw <= 48)
-					channel_idx = PHYDM_5GLB1;
-				if (channel_to_sw >= 52 && channel_to_sw <= 64)
-					channel_idx = PHYDM_5GLB2;
-				if (channel_to_sw >= 100 && channel_to_sw <= 120)
-					channel_idx = PHYDM_5GMB1;
-				if (channel_to_sw >= 122 && channel_to_sw <= 144)
-					channel_idx = PHYDM_5GMB2;
-				if (channel_to_sw >= 149 && channel_to_sw <= 177)
-					channel_idx = PHYDM_5GHB;
-
-				for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++) {
-					ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] phydm_kfree(): channel_to_sw=%d PATH_%d bb_gain:0x%X\n", channel_to_sw, rfpath, p_power_trim_info->bb_gain[channel_idx][rfpath]));
-					phydm_set_kfree_to_rf(p_dm, rfpath, p_power_trim_info->bb_gain[channel_idx][rfpath]);
-				}
-			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] Set default Register\n"));
-				for (rfpath = RF_PATH_A;  rfpath < max_rf_path; rfpath++)
-					phydm_clear_kfree_to_rf(p_dm, rfpath, p_power_trim_info->bb_gain[channel_idx][rfpath]);
-			}
-		} else {
-			ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("[kfree] phy_ConfigKFree(): targetval not defined, Don't execute KFree Process.\n"));
+		if (!(pwrtrim->flag & KFREE_FLAG_ON)) {
+			RF_DBG(dm, DBG_RF_MP,
+			       "[kfree] %s: efuse is 0xff, KFree not work\n",
+			       __func__);
 			return;
 		}
+#if 0
+		/*if kfree_table[0] == 0xff, means no Kfree*/
+#endif
+		phydm_do_kfree(dm, channel_to_sw);
 	}
-	ODM_RT_TRACE(p_dm, ODM_COMP_MP, ODM_DBG_LOUD, ("<===[kfree] phy_ConfigKFree()\n"));
+	RF_DBG(dm, DBG_RF_MP, "<===[kfree] phy_ConfigKFree()\n");
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.h
index f6772e0d0e1d..883d78a79489 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_kfree.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,82 +9,93 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __HALRF_KFREE_H__
+#define __HALRF_KFREE_H__
 
-#ifndef	__PHYDMKFREE_H__
-#define    __PHYDKFREE_H__
-
-#define KFREE_VERSION	"1.0"
+#define KFREE_VERSION "1.0"
 
-#define	KFREE_BAND_NUM		6
+#define KFREE_BAND_NUM 6
+#define KFREE_CH_NUM 3
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_AP))
 
-#define	BB_GAIN_NUM		6
-#define KFREE_FLAG_ON				BIT(0)
-#define KFREE_FLAG_THERMAL_K_ON		BIT(1)
+#define BB_GAIN_NUM 6
 
 #endif
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-#define KFREE_FLAG_ON				BIT(0)
-#define KFREE_FLAG_THERMAL_K_ON		BIT(1)
-#endif
-
-#define KFREE_FLAG_ON_2G				BIT(2)
-#define KFREE_FLAG_ON_5G				BIT(3)
-
-#define PPG_THERMAL_OFFSET_8821C				0x1EF
-#define PPG_BB_GAIN_2G_TXAB_OFFSET_8821C		0x1EE
-#define PPG_BB_GAIN_5GL1_TXA_OFFSET_8821C		0x1EC
-#define PPG_BB_GAIN_5GL2_TXA_OFFSET_8821C		0x1E8
-#define PPG_BB_GAIN_5GM1_TXA_OFFSET_8821C		0x1E4
-#define PPG_BB_GAIN_5GM2_TXA_OFFSET_8821C		0x1E0
-#define PPG_BB_GAIN_5GH1_TXA_OFFSET_8821C		0x1DC
-
-
-
-#define PPG_THERMAL_OFFSET				0x3EF
-#define PPG_BB_GAIN_2G_TXAB_OFFSET		0x3EE
-#define PPG_BB_GAIN_2G_TXCD_OFFSET		0x3ED
-#define PPG_BB_GAIN_5GL1_TXA_OFFSET		0x3EC
-#define PPG_BB_GAIN_5GL1_TXB_OFFSET		0x3EB
-#define PPG_BB_GAIN_5GL1_TXC_OFFSET		0x3EA
-#define PPG_BB_GAIN_5GL1_TXD_OFFSET		0x3E9
-#define PPG_BB_GAIN_5GL2_TXA_OFFSET		0x3E8
-#define PPG_BB_GAIN_5GL2_TXB_OFFSET		0x3E7
-#define PPG_BB_GAIN_5GL2_TXC_OFFSET		0x3E6
-#define PPG_BB_GAIN_5GL2_TXD_OFFSET		0x3E5
-#define PPG_BB_GAIN_5GM1_TXA_OFFSET		0x3E4
-#define PPG_BB_GAIN_5GM1_TXB_OFFSET		0x3E3
-#define PPG_BB_GAIN_5GM1_TXC_OFFSET		0x3E2
-#define PPG_BB_GAIN_5GM1_TXD_OFFSET		0x3E1
-#define PPG_BB_GAIN_5GM2_TXA_OFFSET		0x3E0
-#define PPG_BB_GAIN_5GM2_TXB_OFFSET		0x3DF
-#define PPG_BB_GAIN_5GM2_TXC_OFFSET		0x3DE
-#define PPG_BB_GAIN_5GM2_TXD_OFFSET		0x3DD
-#define PPG_BB_GAIN_5GH1_TXA_OFFSET		0x3DC
-#define PPG_BB_GAIN_5GH1_TXB_OFFSET		0x3DB
-#define PPG_BB_GAIN_5GH1_TXC_OFFSET		0x3DA
-#define PPG_BB_GAIN_5GH1_TXD_OFFSET		0x3D9
-
-#define PPG_PA_BIAS_2G_TXA_OFFSET		0x3D5
-#define PPG_PA_BIAS_2G_TXB_OFFSET		0x3D6
-
-
+#define KFREE_FLAG_ON BIT(0)
+#define KFREE_FLAG_THERMAL_K_ON BIT(1)
+
+#define KFREE_FLAG_ON_2G BIT(2)
+#define KFREE_FLAG_ON_5G BIT(3)
+
+#define PA_BIAS_FLAG_ON BIT(4)
+
+#define PPG_THERMAL_OFFSET_98F 0x50
+#define PPG_2GM_TXAB_98F 0x51
+#define PPG_2GM_TXCD_98F 0x52
+#define PPG_2GL_TXAB_98F 0x53
+#define PPG_2GL_TXCD_98F 0x54
+#define PPG_5GH_TXAB_98F 0x55
+#define PPG_5GH_TXCD_98F 0x56
+
+#define PPG_THERMAL_OFFSET_21C 0x1EF
+#define PPG_2G_TXAB_21C 0x1EE
+#define PPG_5GL1_TXA_21C 0x1EC
+#define PPG_5GL2_TXA_21C 0x1E8
+#define PPG_5GM1_TXA_21C 0x1E4
+#define PPG_5GM2_TXA_21C 0x1E0
+#define PPG_5GH1_TXA_21C 0x1DC
+
+#define PPG_THERMAL_OFFSET_22B 0x3EF
+#define PPG_2G_TXAB_22B 0x3EE
+#define PPG_2G_TXCD_22B 0x3ED
+#define PPG_5GL1_TXA_22B 0x3EC
+#define PPG_5GL1_TXB_22B 0x3EB
+#define PPG_5GL1_TXC_22B 0x3EA
+#define PPG_5GL1_TXD_22B 0x3E9
+#define PPG_5GL2_TXA_22B 0x3E8
+#define PPG_5GL2_TXB_22B 0x3E7
+#define PPG_5GL2_TXC_22B 0x3E6
+#define PPG_5GL2_TXD_22B 0x3E5
+#define PPG_5GM1_TXA_22B 0x3E4
+#define PPG_5GM1_TXB_22B 0x3E3
+#define PPG_5GM1_TXC_22B 0x3E2
+#define PPG_5GM1_TXD_22B 0x3E1
+#define PPG_5GM2_TXA_22B 0x3E0
+#define PPG_5GM2_TXB_22B 0x3DF
+#define PPG_5GM2_TXC_22B 0x3DE
+#define PPG_5GM2_TXD_22B 0x3DD
+#define PPG_5GH1_TXA_22B 0x3DC
+#define PPG_5GH1_TXB_22B 0x3DB
+#define PPG_5GH1_TXC_22B 0x3DA
+#define PPG_5GH1_TXD_22B 0x3D9
+
+#define PPG_PABIAS_2GA_22B 0x3D5
+#define PPG_PABIAS_2GB_22B 0x3D6
 
 struct odm_power_trim_data {
 	u8 flag;
+	u8 pa_bias_flag;
 	s8 bb_gain[KFREE_BAND_NUM][MAX_RF_PATH];
 	s8 thermal;
 };
 
-
-
 enum phydm_kfree_channeltosw {
 	PHYDM_2G = 0,
 	PHYDM_5GLB1 = 1,
@@ -93,41 +105,16 @@ enum phydm_kfree_channeltosw {
 	PHYDM_5GHB = 5,
 };
 
+void phydm_get_thermal_trim_offset(void *dm_void);
 
+void phydm_get_power_trim_offset(void *dm_void);
 
-void
-phydm_get_thermal_trim_offset(
-	void	*p_dm_void
-);
-
-void
-phydm_get_power_trim_offset(
-	void	*p_dm_void
-);
-
-void
-phydm_get_pa_bias_offset(
-	void	*p_dm_void
-);
+void phydm_get_pa_bias_offset(void *dm_void);
 
-s8
-phydm_get_thermal_offset(
-	void	*p_dm_void
-);
+s8 phydm_get_thermal_offset(void *dm_void);
 
-void
-phydm_clear_kfree_to_rf(
-	void		*p_dm_void,
-	u8		e_rf_path,
-	u8		data
-);
+void phydm_clear_kfree_to_rf(void *dm_void, u8 e_rf_path, u8 data);
 
+void phydm_config_kfree(void *dm_void, u8 channel_to_sw);
 
-void
-phydm_config_kfree(
-	void	*p_dm_void,
-	u8	channel_to_sw
-);
-
-
-#endif
+#endif /*__HALRF_KFREE_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.c
index dc43998a5f66..e813df6e38ef 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,142 +9,145 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ * ************************************************************
+ */
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-
 boolean
-odm_check_power_status(
-	void		*p_dm_void
-)
+odm_check_power_status(void *dm_void)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER		*p_adapter = p_dm->adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	PADAPTER *adapter = dm->adapter;
 
-	RT_RF_POWER_STATE	rt_state;
-	PMGNT_INFO			p_mgnt_info	= &(p_adapter->MgntInfo);
+	RT_RF_POWER_STATE rt_state;
+	MGNT_INFO *mgnt_info = &((PADAPTER)adapter)->MgntInfo;
 
 	/* 2011/07/27 MH We are not testing ready~~!! We may fail to get correct value when init sequence. */
-	if (p_mgnt_info->init_adpt_in_progress == true) {
-		PHYDM_DBG(p_dm, ODM_COMP_INIT, ("check_pow_status Return true, due to initadapter\n"));
-		return	true;
+	if (mgnt_info->init_adpt_in_progress == true) {
+		RF_DBG(dm, DBG_RF_INIT,
+		       "check_pow_status Return true, due to initadapter\n");
+		return true;
 	}
 
-	/*  */
-	/*	2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK. */
-	/*  */
-	p_adapter->HalFunc.GetHwRegHandler(p_adapter, HW_VAR_RF_STATE, (u8 *)(&rt_state));
-	if (p_adapter->bDriverStopped || p_adapter->bDriverIsGoingToPnpSetPowerSleep || rt_state == eRfOff) {
-		PHYDM_DBG(p_dm, ODM_COMP_INIT, ("check_pow_status Return false, due to %d/%d/%d\n",
-			p_adapter->bDriverStopped, p_adapter->bDriverIsGoingToPnpSetPowerSleep, rt_state));
-		return	false;
+	/*
+	 *	2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK.
+	 */
+	((PADAPTER)adapter)->HalFunc.GetHwRegHandler((PADAPTER)adapter, HW_VAR_RF_STATE, (u8 *)(&rt_state));
+	if (((PADAPTER)adapter)->bDriverStopped || ((PADAPTER)adapter)->bDriverIsGoingToPnpSetPowerSleep || rt_state == eRfOff) {
+		RF_DBG(dm, DBG_RF_INIT,
+		       "check_pow_status Return false, due to %d/%d/%d\n",
+		       ((PADAPTER)adapter)->bDriverStopped,
+		       ((PADAPTER)adapter)->bDriverIsGoingToPnpSetPowerSleep,
+		       rt_state);
+		return false;
 	}
 #endif
-	return	true;
-	
+	return true;
 }
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-void
-halrf_update_pwr_track(
-	void		*p_dm_void,
-	u8		rate
-)
+void halrf_update_pwr_track(void *dm_void, u8 rate)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	u8			path_idx = 0;
+	u8 path_idx = 0;
 #endif
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("Pwr Track Get rate=0x%x\n", rate));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Pwr Track Get rate=0x%x\n", rate);
 
-	p_dm->tx_rate = rate;
+	dm->tx_rate = rate;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
 #if USE_WORKITEM
-	odm_schedule_work_item(&p_dm->ra_rpt_workitem);
+	odm_schedule_work_item(&dm->ra_rpt_workitem);
 #else
-	if (p_dm->support_ic_type == ODM_RTL8821) {
+	if (dm->support_ic_type == ODM_RTL8821) {
 #if (RTL8821A_SUPPORT == 1)
-		odm_tx_pwr_track_set_pwr8821a(p_dm, MIX_MODE, RF_PATH_A, 0);
+		odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
 #endif
-	} else if (p_dm->support_ic_type == ODM_RTL8812) {
+	} else if (dm->support_ic_type == ODM_RTL8812) {
 		for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8812A; path_idx++) {
 #if (RTL8812A_SUPPORT == 1)
-			odm_tx_pwr_track_set_pwr8812a(p_dm, MIX_MODE, path_idx, 0);
+			odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, path_idx, 0);
 #endif
 		}
-	} else if (p_dm->support_ic_type == ODM_RTL8723B) {
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
 #if (RTL8723B_SUPPORT == 1)
-		odm_tx_pwr_track_set_pwr_8723b(p_dm, MIX_MODE, RF_PATH_A, 0);
+		odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
 #endif
-	} else if (p_dm->support_ic_type == ODM_RTL8192E) {
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
 		for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8192E; path_idx++) {
 #if (RTL8192E_SUPPORT == 1)
-			odm_tx_pwr_track_set_pwr92_e(p_dm, MIX_MODE, path_idx, 0);
+			odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, path_idx, 0);
 #endif
 		}
-	} else if (p_dm->support_ic_type == ODM_RTL8188E) {
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
 #if (RTL8188E_SUPPORT == 1)
-		odm_tx_pwr_track_set_pwr88_e(p_dm, MIX_MODE, RF_PATH_A, 0);
+		odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
 #endif
 	}
 #endif
 #else
-	odm_schedule_work_item(&p_dm->ra_rpt_workitem);
+	odm_schedule_work_item(&dm->ra_rpt_workitem);
 #endif
 #endif
-
 }
 
 #endif
 
-
-
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-halrf_update_init_rate_work_item_callback(
-	void	*p_context
-)
+void halrf_update_init_rate_work_item_callback(
+	void *context)
 {
-	struct _ADAPTER	*adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
-	u8		p = 0;
-
-	if (p_dm->support_ic_type == ODM_RTL8821) {
-		odm_tx_pwr_track_set_pwr8821a(p_dm, MIX_MODE, RF_PATH_A, 0);
-		/**/
-	} else if (p_dm->support_ic_type == ODM_RTL8812) {
-		for (p = RF_PATH_A; p < MAX_PATH_NUM_8812A; p++) {    /*DOn't know how to include &c*/
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	u8 p = 0;
 
-			odm_tx_pwr_track_set_pwr8812a(p_dm, MIX_MODE, p, 0);
-			/**/
-		}
-	} else if (p_dm->support_ic_type == ODM_RTL8723B) {
-		odm_tx_pwr_track_set_pwr_8723b(p_dm, MIX_MODE, RF_PATH_A, 0);
-		/**/
-	} else if (p_dm->support_ic_type == ODM_RTL8192E) {
-		for (p = RF_PATH_A; p < MAX_PATH_NUM_8192E; p++) {   /*DOn't know how to include &c*/
-			odm_tx_pwr_track_set_pwr92_e(p_dm, MIX_MODE, p, 0);
-			/**/
-		}
-	} else if (p_dm->support_ic_type == ODM_RTL8188E) {
-		odm_tx_pwr_track_set_pwr88_e(p_dm, MIX_MODE, RF_PATH_A, 0);
-		/**/
+	if (dm->support_ic_type == ODM_RTL8821) {
+#if (RTL8821A_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+#if (RTL8812A_SUPPORT == 1)
+		/*Don't know how to include &c*/
+		for (p = RF_PATH_A; p < MAX_PATH_NUM_8812A; p++)
+			odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, p, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
+#if (RTL8723B_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+#if (RTL8192E_SUPPORT == 1)
+		/*Don't know how to include &c*/
+		for (p = RF_PATH_A; p < MAX_PATH_NUM_8192E; p++)
+			odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, p, 0);
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT == 1)
+		odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
+#endif
 	}
 }
 #endif
-
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.h
index 05abae37c7a4..6b19255e0b1e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,34 +9,34 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__HALRF_POWER_TRACKING_H__
-#define    __HALRF_POWER_TRACKING_H__
-
-#define HALRF_POWRTRACKING_ALL_VER	"1.0"
+#ifndef __HALRF_POWER_TRACKING_H__
+#define __HALRF_POWER_TRACKING_H__
 
 boolean
-odm_check_power_status(
-	void		*p_dm_void
-);
+odm_check_power_status(void *dm_void);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-void
-halrf_update_pwr_track(
-	void		*p_dm_void,
-	u8		rate
-);
+void halrf_update_pwr_track(void *dm_void, u8 rate);
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-halrf_update_init_rate_work_item_callback(
-	void	*p_context
-);
+void halrf_update_init_rate_work_item_callback(
+	void *context);
 #endif
 
-#endif
+#endif /*#ifndef __HALRF_POWERTRACKING_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.c
index 7319c40ab108..426b6a90b952 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -338,6 +339,50 @@ u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
 	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
 };
 
+/* Winnita ADD 20171113 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
+u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
+	0x0CD,			 /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,		/*19*/
+	0x287,		/*20*/
+	0x2AE,		/*21*/
+	0x2D6,		/*22*/
+	0x301,		/*23*/
+	0x32F,		/*24*/
+	0x35F,		/*25*/
+	0x392,		/*26*/
+	0x3C9,		/*27*/
+	0x402,		/*28*/
+	0x43F,		/*29*/
+	0x47F,		/*30*/
+	0x4C3,		/*31*/
+	0x50C,		/*32*/
+	0x558,		/*33*/
+	0x5A9,		/*34*/
+	0x5FF,		/*35*/
+	0x65A,		/*36*/
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
 
 
 #if 0
@@ -692,7 +737,9 @@ u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8] = {
 };
 #endif
 
-#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 ||\
+	RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1)
 u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
 	0x081, /* 0,  -12.0dB */
 	0x088, /* 1,  -11.5dB */
@@ -876,35 +923,44 @@ u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
 
 void
 odm_txpowertracking_init(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	if (!(p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_IC_11N_SERIES)))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_IC_11N_SERIES)))
 		return;
 #endif
 
-	odm_txpowertracking_thermal_meter_init(p_dm);
+	odm_txpowertracking_thermal_meter_init(dm);
 }
 
 
 u8
 get_swing_index(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 	u8			i = 0, bb_swing_mask = 0;
 	u32			bb_swing = 0;
 	u32			swing_table_size = 0;
-	u32			*p_swing_table = 0;
-	struct rtl8192cd_priv	*priv = p_dm->priv;
+	u32			*swing_table = 0;
+	struct rtl8192cd_priv	*priv = dm->priv;
 
 #if (RTL8197F_SUPPORT == 1)
 	if (GET_CHIP_VER(priv) == VERSION_8197F) {
 		bb_swing = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
-		p_swing_table = ofdm_swing_table_new;
+		swing_table = ofdm_swing_table_new;
+		swing_table_size = OFDM_TABLE_SIZE_92D;
+		bb_swing_mask = 22;
+	}
+#endif
+
+#if (RTL8192F_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8192F) {
+		bb_swing = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
+		swing_table = ofdm_swing_table_new;
 		swing_table_size = OFDM_TABLE_SIZE_92D;
 		bb_swing_mask = 22;
 	}
@@ -913,20 +969,20 @@ get_swing_index(
 #if (RTL8822B_SUPPORT == 1)
 	if (GET_CHIP_VER(priv) == VERSION_8822B) {
 		bb_swing = phy_query_bb_reg(priv, REG_A_TX_SCALE_JAGUAR, 0xFFE00000);
-		p_swing_table = tx_scaling_table_jaguar;
+		swing_table = tx_scaling_table_jaguar;
 		swing_table_size = TXSCALE_TABLE_SIZE;
 		bb_swing_mask = 0;
 	}
 #endif
 
 	for (i = 0; i < swing_table_size - 1; i++) {
-		u32 table_value = p_swing_table[i] >> bb_swing_mask;
+		u32 table_value = swing_table[i] >> bb_swing_mask;
 
 		if (bb_swing == table_value)
 			break;
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("bb_swing=0x%x bbswing_index=%d\n", bb_swing, i));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "bb_swing=0x%x bbswing_index=%d\n", bb_swing, i);
 
 
 	return i;
@@ -935,59 +991,56 @@ get_swing_index(
 
 void
 odm_txpowertracking_thermal_meter_init(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	struct rtl8192cd_priv		*priv = p_dm->priv;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
+	struct rtl8192cd_priv		*priv = dm->priv;
 	u8 p;
 	u8 default_swing_index;
-#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
-	if ((GET_CHIP_VER(priv) == VERSION_8197F) || (GET_CHIP_VER(priv) == VERSION_8822B))
-		default_swing_index = get_swing_index(p_dm);
+#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8192F_SUPPORT == 1)
+	if ((GET_CHIP_VER(priv) == VERSION_8197F) || (GET_CHIP_VER(priv) == VERSION_8822B) ||(GET_CHIP_VER(priv) == VERSION_8192F))
+		default_swing_index = get_swing_index(dm);
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	PMGNT_INFO	p_mgnt_info = &adapter->MgntInfo;
-	HAL_DATA_TYPE		*p_hal_data = GET_HAL_DATA(adapter);
+	void		*adapter = dm->adapter;
+	PMGNT_INFO	mgnt_info = &adapter->MgntInfo;
+	HAL_DATA_TYPE		*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 
-	p_mgnt_info->is_txpowertracking = true;
-	p_hal_data->tx_powercount       = 0;
-	p_hal_data->is_txpowertracking_init = false;
+	mgnt_info->is_txpowertracking = true;
+	hal_data->tx_powercount       = 0;
+	hal_data->is_txpowertracking_init = false;
 
-	if (*(p_dm->p_mp_mode) == false)
-		p_hal_data->txpowertrack_control = true;
-	ODM_RT_TRACE(p_dm, COMP_POWER_TRACKING, DBG_LOUD, ("p_mgnt_info->is_txpowertracking = %d\n", p_mgnt_info->is_txpowertracking));
+	if (*(dm->mp_mode) == false)
+		hal_data->txpowertrack_control = true;
+	RF_DBG(dm, COMP_POWER_TRACKING, "mgnt_info->is_txpowertracking = %d\n", mgnt_info->is_txpowertracking);
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 #ifdef CONFIG_RTL8188E
 	{
-		p_dm->rf_calibrate_info.is_txpowertracking = true;
-		p_dm->rf_calibrate_info.tx_powercount = 0;
-		p_dm->rf_calibrate_info.is_txpowertracking_init = false;
+		dm->rf_calibrate_info.is_txpowertracking = true;
+		dm->rf_calibrate_info.tx_powercount = 0;
+		dm->rf_calibrate_info.is_txpowertracking_init = false;
 
-		if (*(p_dm->p_mp_mode) == false)
-			p_dm->rf_calibrate_info.txpowertrack_control = true;
+		if (*(dm->mp_mode) == false)
+			dm->rf_calibrate_info.txpowertrack_control = true;
 
-		MSG_8192C("p_dm txpowertrack_control = %d\n", p_dm->rf_calibrate_info.txpowertrack_control);
+		MSG_8192C("dm txpowertrack_control = %d\n", dm->rf_calibrate_info.txpowertrack_control);
 	}
 #else
 	{
-		struct _ADAPTER		*adapter = p_dm->adapter;
-		HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-		struct dm_priv	*pdmpriv = &p_hal_data->dmpriv;
-
-		/* if(IS_HARDWARE_TYPE_8192C(p_hal_data)) */
-		{
-			pdmpriv->is_txpowertracking = true;
-			pdmpriv->tx_powercount = 0;
-			pdmpriv->is_txpowertracking_init = false;
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+		struct dm_priv	*pdmpriv = &hal_data->dmpriv;
+		
+		pdmpriv->is_txpowertracking = true;
+		pdmpriv->tx_powercount = 0;
+		pdmpriv->is_txpowertracking_init = false;
 
-			if (*(p_dm->p_mp_mode) == false)		/* for mp driver, turn off txpwrtracking as default */
-				pdmpriv->txpowertrack_control = true;
+		if (*(dm->mp_mode) == false)		/* for mp driver, turn off txpwrtracking as default */
+			pdmpriv->txpowertrack_control = true;
 
-		}
 		MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
 
 	}
@@ -996,73 +1049,80 @@ odm_txpowertracking_thermal_meter_init(
 
 #ifdef RTL8188E_SUPPORT
 	{
-		p_dm->rf_calibrate_info.is_txpowertracking = true;
-		p_dm->rf_calibrate_info.tx_powercount = 0;
-		p_dm->rf_calibrate_info.is_txpowertracking_init = false;
-		p_dm->rf_calibrate_info.txpowertrack_control = true;
-		p_dm->rf_calibrate_info.tm_trigger = 0;
+		dm->rf_calibrate_info.is_txpowertracking = true;
+		dm->rf_calibrate_info.tx_powercount = 0;
+		dm->rf_calibrate_info.is_txpowertracking_init = false;
+		dm->rf_calibrate_info.txpowertrack_control = true;
+		dm->rf_calibrate_info.tm_trigger = 0;
 	}
 #endif
 #endif
 
-	p_dm->rf_calibrate_info.txpowertrack_control = true;
-	p_dm->rf_calibrate_info.delta_power_index = 0;
-	p_dm->rf_calibrate_info.delta_power_index_last = 0;
-	p_dm->rf_calibrate_info.power_index_offset = 0;
-	p_dm->rf_calibrate_info.thermal_value = 0;
-	p_rf_calibrate_info->default_ofdm_index = 28;
+	dm->rf_calibrate_info.txpowertrack_control = true;
+	dm->rf_calibrate_info.delta_power_index = 0;
+	dm->rf_calibrate_info.delta_power_index_last = 0;
+	dm->rf_calibrate_info.power_index_offset = 0;
+	dm->rf_calibrate_info.thermal_value = 0;
+	cali_info->default_ofdm_index = 28;
 
 #if (RTL8197F_SUPPORT == 1)
 	if (GET_CHIP_VER(priv) == VERSION_8197F) {
-		p_rf_calibrate_info->default_ofdm_index = (default_swing_index >= (OFDM_TABLE_SIZE_92D - 1)) ? 30 : default_swing_index;
-		p_rf_calibrate_info->default_cck_index = 28;
+		cali_info->default_ofdm_index = (default_swing_index >= (OFDM_TABLE_SIZE_92D - 1)) ? 30 : default_swing_index;
+		cali_info->default_cck_index = 28;
+	}
+#endif
+
+#if (RTL8192F_SUPPORT == 1)
+	if (GET_CHIP_VER(priv) == VERSION_8192F) {
+		cali_info->default_ofdm_index = 30;
+		cali_info->default_cck_index = 28;
 	}
 #endif
 
 #if (RTL8822B_SUPPORT == 1)
 	if (GET_CHIP_VER(priv) == VERSION_8822B) {
-		p_rf_calibrate_info->default_ofdm_index = (default_swing_index >= (TXSCALE_TABLE_SIZE - 1)) ? 24 : default_swing_index;
-		p_rf_calibrate_info->default_cck_index = 20;
+		cali_info->default_ofdm_index = (default_swing_index >= (TXSCALE_TABLE_SIZE - 1)) ? 24 : default_swing_index;
+		cali_info->default_cck_index = 20;
 	}
 #endif
 
 
 #if RTL8188E_SUPPORT
-	p_rf_calibrate_info->default_cck_index = 20;	/* -6 dB */
+	cali_info->default_cck_index = 20;	/* -6 dB */
 #elif RTL8192E_SUPPORT
-	p_rf_calibrate_info->default_cck_index = 8;	/* -12 dB */
+	cali_info->default_cck_index = 8;	/* -12 dB */
 #endif
-	p_rf_calibrate_info->bb_swing_idx_ofdm_base = p_rf_calibrate_info->default_ofdm_index;
-	p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->default_cck_index;
-	p_dm->rf_calibrate_info.CCK_index = p_rf_calibrate_info->default_cck_index;
+	cali_info->bb_swing_idx_ofdm_base = cali_info->default_ofdm_index;
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	dm->rf_calibrate_info.CCK_index = cali_info->default_cck_index;
 
 	for (p = 0; p < MAX_RF_PATH; p++) {
-		p_dm->rf_calibrate_info.OFDM_index[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->bb_swing_idx_ofdm[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->kfree_offset[p] = 0;	/* for 8814 kfree*/
+		dm->rf_calibrate_info.OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
+		cali_info->kfree_offset[p] = 0;	/* for 8814 kfree*/
 	}
-	p_rf_calibrate_info->bb_swing_idx_cck = p_rf_calibrate_info->default_cck_index;
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("p_rf_calibrate_info->default_ofdm_index=%d p_rf_calibrate_info->default_cck_index=%d\n", p_rf_calibrate_info->default_ofdm_index, p_rf_calibrate_info->default_cck_index));
+	cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
 
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "cali_info->default_ofdm_index=%d cali_info->default_cck_index=%d\n", cali_info->default_ofdm_index, cali_info->default_cck_index);
 
+	cali_info->tm_trigger = 0;
 }
 
 
 void
 odm_txpowertracking_check(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
 	/*  */
 	/* For AP/ADSL use struct rtl8192cd_priv* */
-	/* For CE/NIC use struct _ADAPTER* */
+	/* For CE/NIC use struct void* */
 	/*  */
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
 
 
-	if (!(p_rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
 		return;
 
 	/*  */
@@ -1070,17 +1130,17 @@ odm_txpowertracking_check(
 	/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
 	/* HW dynamic mechanism. */
 	/*  */
-	switch	(p_dm->support_platform) {
+	switch	(dm->support_platform) {
 	case	ODM_WIN:
-		odm_txpowertracking_check_mp(p_dm);
+		odm_txpowertracking_check_mp(dm);
 		break;
 
 	case	ODM_CE:
-		odm_txpowertracking_check_ce(p_dm);
+		odm_txpowertracking_check_ce(dm);
 		break;
 
 	case	ODM_AP:
-		odm_txpowertracking_check_ap(p_dm);
+		odm_txpowertracking_check_ap(dm);
 		break;
 	}
 
@@ -1088,33 +1148,33 @@ odm_txpowertracking_check(
 
 void
 odm_txpowertracking_check_ce(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER	*adapter = p_dm->adapter;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+	struct _hal_rf_				*rf = &(dm->rf_table);
 
 #if (RTL8188E_SUPPORT == 1)
 
-	/* if(!p_mgnt_info->is_txpowertracking || (!pdmpriv->txpowertrack_control && pdmpriv->is_ap_kdone)) */
+	/* if(!mgnt_info->is_txpowertracking || (!pdmpriv->txpowertrack_control && pdmpriv->is_ap_kdone)) */
 
-	if (!(p_rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
 		return;
 
-	if (!p_dm->rf_calibrate_info.tm_trigger) {	/* at least delay 1 sec */
-		/* p_hal_data->TxPowerCheckCnt++;	 */ /* cosa add for debug */
-		odm_set_rf_reg(p_dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+	if (!dm->rf_calibrate_info.tm_trigger) {	/* at least delay 1 sec */
+		/* hal_data->TxPowerCheckCnt++;	 */ /* cosa add for debug */
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
 		/* DBG_8192C("Trigger 92C Thermal Meter!!\n"); */
 
-		p_dm->rf_calibrate_info.tm_trigger = 1;
+		dm->rf_calibrate_info.tm_trigger = 1;
 		return;
 
 	} else {
 		/* DBG_8192C("Schedule TxPowerTracking direct call!!\n"); */
 		odm_txpowertracking_callback_thermal_meter_8188e(adapter);
-		p_dm->rf_calibrate_info.tm_trigger = 0;
+		dm->rf_calibrate_info.tm_trigger = 0;
 	}
 #endif
 
@@ -1123,12 +1183,12 @@ odm_txpowertracking_check_ce(
 
 void
 odm_txpowertracking_check_mp(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
 
 	if (odm_check_power_status(adapter) == false)
 		return;
@@ -1142,16 +1202,16 @@ odm_txpowertracking_check_mp(
 
 void
 odm_txpowertracking_check_ap(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	struct rtl8192cd_priv	*priv		= p_dm->priv;
+	struct rtl8192cd_priv	*priv		= dm->priv;
 
-#if ((RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
-	if (p_dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8881A | ODM_RTL8814A | ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8821C))
-		odm_txpowertracking_callback_thermal_meter(p_dm);
+#if ((RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8192F_SUPPORT == 1) || (RTL8198F_SUPPORT == 1))
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8881A | ODM_RTL8814A | ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8192F | ODM_RTL8198F))
+		odm_txpowertracking_callback_thermal_meter(dm);
 	else
 #endif
 	{
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.h
index 20d504b072a4..0b4589741cc8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ap.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -13,10 +14,8 @@
  *
  *****************************************************************************/
 
-#ifndef	__PHYDMPOWERTRACKING_H__
-#define    __PHYDMPOWERTRACKING_H__
-
-#define HALRF_POWRTRACKING_VER	"1.1"
+#ifndef __HALRF_POWERTRACKING_H__
+#define __HALRF_POWERTRACKING_H__
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 	#ifdef RTK_AC_SUPPORT
@@ -45,9 +44,10 @@
 
 #define IQK_BB_REG_NUM		9
 
-#define HP_THERMAL_NUM		8
-
 #define AVG_THERMAL_NUM		8
+#define AVG_THERMAL_NUM_DPK		8
+#define THERMAL_DPK_AVG_NUM		4
+
 #define iqk_matrix_reg_num	8
 /* #define IQK_MATRIX_SETTINGS_NUM	1+24+21 */
 #define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
@@ -57,6 +57,7 @@
 	#define	OFDM_TABLE_SIZE	37
 	#define	CCK_TABLE_SIZE		33
 	#define	CCK_TABLE_SIZE_88F	21
+	#define	CCK_TABLE_SIZE_8192F	41
 
 
 
@@ -73,6 +74,7 @@
 	extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
 	extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
 	extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+	extern	u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
 
 #endif
 
@@ -100,7 +102,9 @@ static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4
 #define	OFDM_TABLE_SIZE_8812	43
 #define	AVG_THERMAL_NUM_8812	4
 
-#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 ||\
+	RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1)
 	extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
 	#elif(ODM_IC_11AC_SERIES_SUPPORT)
 	extern unsigned int ofdm_swing_table_8812[OFDM_TABLE_SIZE_8812];
@@ -112,12 +116,12 @@ extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
 
 #define dm_check_txpowertracking	odm_txpowertracking_check
 
-struct _IQK_MATRIX_REGS_SETTING {
+struct iqk_matrix_regs_setting {
 	boolean	is_iqk_done;
 	s32		value[1][iqk_matrix_reg_num];
 };
 
-struct odm_rf_calibration_structure {
+struct dm_rf_calibration_struct {
 	/* for tx power tracking */
 
 	u32	rega24; /* for TempCCK */
@@ -139,7 +143,7 @@ struct odm_rf_calibration_structure {
 	u8	thermal_value_lck;
 	u8	thermal_value_iqk;
 	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
-	u8	thermal_value_dpk;
+
 	u8	thermal_value_avg[AVG_THERMAL_NUM];
 	u8	thermal_value_avg_index;
 	u8	thermal_value_rx_gain;
@@ -147,7 +151,7 @@ struct odm_rf_calibration_structure {
 	u8	thermal_value_dpk_store;
 	u8	thermal_value_dpk_track;
 	boolean	txpowertracking_in_progress;
-	boolean	is_dpk_enable;
+
 
 	boolean	is_reloadtxpowerindex;
 	u8	is_rf_pi_enable;
@@ -161,9 +165,7 @@ struct odm_rf_calibration_structure {
 	s8	delta_power_index_last;
 	boolean is_tx_power_changed;
 
-	u8	thermal_value_hp[HP_THERMAL_NUM];
-	u8	thermal_value_hp_index;
-	struct _IQK_MATRIX_REGS_SETTING iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
 	u8	delta_lck;
 	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
 	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
@@ -201,6 +203,8 @@ struct odm_rf_calibration_structure {
 	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
 	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
 	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	s8  delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
+	s8  delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
 	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
 	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
 
@@ -229,6 +233,7 @@ struct odm_rf_calibration_structure {
 	boolean			modify_tx_agc_flag_path_c;
 	boolean			modify_tx_agc_flag_path_d;
 	boolean			modify_tx_agc_flag_path_a_cck;
+	boolean			modify_tx_agc_flag_path_b_cck;
 
 	s8			kfree_offset[MAX_RF_PATH];
 
@@ -275,8 +280,51 @@ struct odm_rf_calibration_structure {
 	u8	is_ap_kdone;
 	u8	is_apk_thermal_meter_ignore;
 	u8	is_dp_done;
+#if 0 /*move below members to halrf_dpk.h*/
 	u8	is_dp_path_aok;
 	u8	is_dp_path_bok;
+	u8	is_dp_path_cok;
+	u8	is_dp_path_dok;
+	u8 	dp_path_a_result[3];
+	u8 	dp_path_b_result[3];
+	u8 	dp_path_c_result[3];
+	u8 	dp_path_d_result[3];
+	boolean	is_dpk_enable;
+	u32	txrate[11];
+	u8 	pwsf_2g_a[3];
+	u8 	pwsf_2g_b[3];
+	u8 	pwsf_2g_c[3];
+	u8 	pwsf_2g_d[3];
+	u32	lut_2g_even_a[3][64];
+	u32	lut_2g_odd_a[3][64];
+	u32	lut_2g_even_b[3][64];
+	u32	lut_2g_odd_b[3][64];
+	u32	lut_2g_even_c[3][64];
+	u32	lut_2g_odd_c[3][64];
+	u32	lut_2g_even_d[3][64];
+	u32	lut_2g_odd_d[3][64];
+	u1Byte 	is_5g_pdk_a_ok;
+	u1Byte 	is_5g_pdk_b_ok;
+	u1Byte 	is_5g_pdk_c_ok;
+	u1Byte 	is_5g_pdk_d_ok;
+	u1Byte 	pwsf_5g_a[9];
+	u1Byte 	pwsf_5g_b[9];
+	u1Byte 	pwsf_5g_c[9];
+	u1Byte 	pwsf_5g_d[9];
+	u4Byte	lut_5g_even_a[9][16];
+	u4Byte	lut_5g_odd_a[9][16];
+	u4Byte	lut_5g_even_b[9][16];
+	u4Byte	lut_5g_odd_b[9][16];
+	u4Byte	lut_5g_even_c[9][16];
+	u4Byte	lut_5g_odd_c[9][16];
+	u4Byte	lut_5g_even_d[9][16];
+	u4Byte	lut_5g_odd_d[9][16];
+	u8	thermal_value_dpk;
+	u8	thermal_value_dpk_avg[AVG_THERMAL_NUM_DPK];
+	u8	thermal_value_dpk_avg_index;
+#endif
+	s8  modify_tx_agc_value_ofdm;
+	s8  modify_tx_agc_value_cck;
 
 	/*Add by Yuchen for Kfree Phydm*/
 	u8			reg_rf_kfree_enable;	/*for registry*/
@@ -286,34 +334,34 @@ struct odm_rf_calibration_structure {
 
 void
 odm_txpowertracking_check_ap(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 void
 odm_txpowertracking_check(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 
 void
 odm_txpowertracking_thermal_meter_init(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 void
 odm_txpowertracking_init(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 void
 odm_txpowertracking_check_mp(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 
 void
 odm_txpowertracking_check_ce(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 
@@ -321,31 +369,31 @@ odm_txpowertracking_check_ce(
 
 void
 odm_txpowertracking_callback_thermal_meter92c(
-	struct _ADAPTER	*adapter
+	void	*adapter
 );
 
 void
 odm_txpowertracking_callback_rx_gain_thermal_meter92d(
-	struct _ADAPTER	*adapter
+	void	*adapter
 );
 
 void
 odm_txpowertracking_callback_thermal_meter92d(
-	struct _ADAPTER	*adapter
+	void	*adapter
 );
 
 void
 odm_txpowertracking_direct_call92c(
-	struct _ADAPTER		*adapter
+	void		*adapter
 );
 
 void
 odm_txpowertracking_thermal_meter_check(
-	struct _ADAPTER		*adapter
+	void		*adapter
 );
 
 #endif
 
 
 
-#endif
+#endif	/*#ifndef __HALRF_POWER_TRACKING_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.c
index cb40caf644cc..5cd60dd9adce 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,331 +9,401 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/*============================================================	*/
-/* include files												*/
-/*============================================================	*/
+/*@===========================================================
+ * include files
+ *============================================================
+ */
+
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-/* ************************************************************
+/*@************************************************************
  * Global var
- * ************************************************************ */
-
-u32	ofdm_swing_table[OFDM_TABLE_SIZE] = {
-	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*/
+ * ************************************************************
+ */
+
+u32 ofdm_swing_table[OFDM_TABLE_SIZE] = {
+	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*/
 };
 
-u8	cck_swing_table_ch1_ch13[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 <== default */
-	{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 cck_swing_table_ch1_ch13[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.0 default*/
+	{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	cck_swing_table_ch14[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  <== default*/
-	{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*/
+u8 cck_swing_table_ch14[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.0 default*/
+	{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 */
 };
 
-
 u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
-	0x0b40002d, /* 0,  -15.0dB	*/
-	0x0c000030, /* 1,  -14.5dB*/
-	0x0cc00033, /* 2,  -14.0dB*/
-	0x0d800036, /* 3,  -13.5dB*/
+	0x0b40002d, /* 0,  -15.0dB */
+	0x0c000030, /* 1,  -14.5dB */
+	0x0cc00033, /* 2,  -14.0dB */
+	0x0d800036, /* 3,  -13.5dB */
 	0x0e400039, /* 4,  -13.0dB */
-	0x0f00003c, /* 5,  -12.5dB*/
-	0x10000040, /* 6,  -12.0dB*/
-	0x11000044, /* 7,  -11.5dB*/
-	0x12000048, /* 8,  -11.0dB*/
-	0x1300004c, /* 9,  -10.5dB*/
-	0x14400051, /* 10, -10.0dB*/
-	0x15800056, /* 11, -9.5dB*/
-	0x16c0005b, /* 12, -9.0dB*/
-	0x18000060, /* 13, -8.5dB*/
-	0x19800066, /* 14, -8.0dB*/
-	0x1b00006c, /* 15, -7.5dB*/
-	0x1c800072, /* 16, -7.0dB*/
-	0x1e400079, /* 17, -6.5dB*/
-	0x20000080, /* 18, -6.0dB*/
-	0x22000088, /* 19, -5.5dB*/
-	0x24000090, /* 20, -5.0dB*/
-	0x26000098, /* 21, -4.5dB*/
-	0x288000a2, /* 22, -4.0dB*/
-	0x2ac000ab, /* 23, -3.5dB*/
-	0x2d4000b5, /* 24, -3.0dB*/
-	0x300000c0, /* 25, -2.5dB*/
-	0x32c000cb, /* 26, -2.0dB*/
-	0x35c000d7, /* 27, -1.5dB*/
-	0x390000e4, /* 28, -1.0dB*/
-	0x3c8000f2, /* 29, -0.5dB*/
-	0x40000100, /* 30, +0dB*/
-	0x43c0010f, /* 31, +0.5dB*/
-	0x47c0011f, /* 32, +1.0dB*/
-	0x4c000130, /* 33, +1.5dB*/
-	0x50800142, /* 34, +2.0dB*/
-	0x55400155, /* 35, +2.5dB*/
-	0x5a400169, /* 36, +3.0dB*/
-	0x5fc0017f, /* 37, +3.5dB*/
-	0x65400195, /* 38, +4.0dB*/
-	0x6b8001ae, /* 39, +4.5dB*/
-	0x71c001c7, /* 40, +5.0dB*/
-	0x788001e2, /* 41, +5.5dB*/
-	0x7f8001fe  /* 42, +6.0dB*/
+	0x0f00003c, /* 5,  -12.5dB */
+	0x10000040, /* 6,  -12.0dB */
+	0x11000044, /* 7,  -11.5dB */
+	0x12000048, /* 8,  -11.0dB */
+	0x1300004c, /* 9,  -10.5dB */
+	0x14400051, /* 10, -10.0dB */
+	0x15800056, /* 11, -9.5dB */
+	0x16c0005b, /* 12, -9.0dB */
+	0x18000060, /* 13, -8.5dB */
+	0x19800066, /* 14, -8.0dB */
+	0x1b00006c, /* 15, -7.5dB */
+	0x1c800072, /* 16, -7.0dB */
+	0x1e400079, /* 17, -6.5dB */
+	0x20000080, /* 18, -6.0dB */
+	0x22000088, /* 19, -5.5dB */
+	0x24000090, /* 20, -5.0dB */
+	0x26000098, /* 21, -4.5dB */
+	0x288000a2, /* 22, -4.0dB */
+	0x2ac000ab, /* 23, -3.5dB */
+	0x2d4000b5, /* 24, -3.0dB */
+	0x300000c0, /* 25, -2.5dB */
+	0x32c000cb, /* 26, -2.0dB */
+	0x35c000d7, /* 27, -1.5dB */
+	0x390000e4, /* 28, -1.0dB */
+	0x3c8000f2, /* 29, -0.5dB */
+	0x40000100, /* 30, +0dB */
+	0x43c0010f, /* 31, +0.5dB */
+	0x47c0011f, /* 32, +1.0dB */
+	0x4c000130, /* 33, +1.5dB */
+	0x50800142, /* 34, +2.0dB */
+	0x55400155, /* 35, +2.5dB */
+	0x5a400169, /* 36, +3.0dB */
+	0x5fc0017f, /* 37, +3.5dB */
+	0x65400195, /* 38, +4.0dB */
+	0x6b8001ae, /* 39, +4.5dB */
+	0x71c001c7, /* 40, +5.0dB */
+	0x788001e2, /* 41, +5.5dB */
+	0x7f8001fe /* 42, +6.0dB */
 };
 
-
 u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
-	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
-	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
-	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
-	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
-	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
-	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
-	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
-	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
-	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
-	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
-	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
-	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
-	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
-	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
-	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
-	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
-	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
-	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
-	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
-	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
-	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
 };
 
-
 u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
-	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
-	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
-	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
-	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
-	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
-	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
-	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
-	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
-	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
-	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
-	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
-	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
-	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
-	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
-	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
-	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
-	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
-	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
-	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
-	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
-	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
 };
 
-
 u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
-	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
-	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
-	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
-	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
-	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
-	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
-	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
-	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
-	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
-	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
-	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
-	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
-	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
-	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
-	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
-	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
-	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
-	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
-	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
-	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
-	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+	{0x44, 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+		0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
 };
 
-
 u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
-	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/*  0, -16.0dB*/
-	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/*   1, -15.5dB*/
-	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/*  2, -15.0dB*/
-	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/*   3, -14.5dB*/
-	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   4, -14.0dB*/
-	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   5, -13.5dB*/
-	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/*   6, -13.0dB*/
-	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/*   7, -12.5dB*/
-	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/*  8, -12.0dB*/
-	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/*   9, -11.5dB*/
-	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  10, -11.0dB*/
-	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  11, -10.5dB*/
-	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  12, -10.0dB*/
-	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  13, -9.5dB*/
-	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/*  14, -9.0dB */
-	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/*  15, -8.5dB*/
-	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/*  16, -8.0dB */
-	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/*  17, -7.5dB*/
-	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/*  18, -7.0dB */
-	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/*  19, -6.5dB*/
-	{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	/*20, -6.0dB */
-	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/*  21, -5.5dB*/
-	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
-	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/*  23, -4.5dB*/
-	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/*  24, -4.0dB */
-	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/*  25, -3.5dB*/
-	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/*  26, -3.0dB*/
-	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/*  27, -2.5dB*/
-	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/*  28, -2.0dB */
-	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/*  29, -1.5dB*/
-	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/*  30, -1.0dB*/
-	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/*  31, -0.5dB*/
-	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/*  32, +0dB*/
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}, /*   0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /*   1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /*   2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /*   3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /*   4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /*   5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /*   6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /*   7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /*   8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /*   9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /*  10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /*  11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /*  12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /*  13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /*  14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /*  15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /*  16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /*  17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /*  18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /*  19, -6.5dB*/
+	{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /*  20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /*  21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /*  22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /*  23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /*  24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /*  25, -3.5dB*/
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /*  26, -3.0dB*/
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /*  27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /*  28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /*  29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /*  30, -1.0dB*/
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /*  31, -0.5dB*/
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} /*   32, +0dB*/
 };
 
-
 u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
-	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/*  0, -16.0dB*/
-	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB*/
-	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  2, -15.0dB*/
-	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB*/
-	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  4, -14.0dB*/
-	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/*5, -13.5dB*/
-	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB*/
-	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/*  7, -12.5dB*/
-	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB*/
-	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB*/
-	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB*/
-	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/*11, -10.5dB*/
-	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB*/
-	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB*/
-	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/*14, -9.0dB */
-	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB*/
-	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
-	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB*/
-	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
-	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
-	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
-	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB*/
-	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
-	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/*23, -4.5dB*/
-	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
-	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
-	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
-	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/*27, -2.5dB*/
-	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
-	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/*29, -1.5dB*/
-	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
-	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
-	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB	*/
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00}, /*  0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /*  2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /*  4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /*5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /*  7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /*11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /*14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /*23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /*27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /*29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} /* 32, +0dB	*/
 };
+
 u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
-	0x0CD,          /*0 ,    -20dB*/
+	0x0CD, /*0 ,    -20dB*/
 	0x0D9,
 	0x0E6,
 	0x0F3,
@@ -374,9 +445,10 @@ u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
 	0x78C,
 	0x7FF,
 };
-/* JJ ADD 20161014 */
+
+/*@JJ ADD 20161014 */
 u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
-	0x0CD,          /*0 ,    -20dB*/
+	0x0CD, /*0 ,    -20dB*/
 	0x0D9,
 	0x0E6,
 	0x0F3,
@@ -419,6 +491,50 @@ u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
 	0x7FF,
 };
 
+/*@Winnita ADD 20171116 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
+u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
+	0x0CD, /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263, /*19*/
+	0x287, /*20*/
+	0x2AE, /*21*/
+	0x2D6, /*22*/
+	0x301, /*23*/
+	0x32F, /*24*/
+	0x35F, /*25*/
+	0x392, /*26*/
+	0x3C9, /*27*/
+	0x402, /*28*/
+	0x43F, /*29*/
+	0x47F, /*30*/
+	0x4C3, /*31*/
+	0x50C, /*32*/
+	0x558, /*33*/
+	0x5A9, /*34*/
+	0x5FF, /*35*/
+	0x65A, /*36*/
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
 
 u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
 	0x081, /* 0,  -12.0dB*/
@@ -449,7 +565,7 @@ u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
 	0x21E, /* 25, +0.5dB*/
 	0x23E, /* 26, +1.0dB*/
 	0x261, /* 27, +1.5dB*/
-	0x285,/* 28, +2.0dB*/
+	0x285, /* 28, +2.0dB*/
 	0x2AB, /* 29, +2.5dB*/
 	0x2D3, /*30, +3.0dB*/
 	0x2FE, /* 31, +3.5dB*/
@@ -457,91 +573,93 @@ u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
 	0x35C, /* 33, +4.5dB*/
 	0x38E, /* 34, +5.0dB*/
 	0x3C4, /* 35, +5.5dB*/
-	0x3FE  /* 36, +6.0dB	*/
+	0x3FE /* 36, +6.0dB	*/
 };
 
-void
-odm_txpowertracking_init(
-	void	*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	if (!(p_dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
-		return;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#else
+u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3,
+					  4, 4, 4, 4, 4, 4, 4, 4, 5, 5,
+					  7, 7, 8, 8, 8, 9, 9, 9, 9, 9};
+u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4,
+					  4, 5, 5, 6, 6, 7, 7, 7, 7, 8,
+					  8, 9, 9, 10, 10, 10, 11, 11, 11, 11};
 #endif
 
-	odm_txpowertracking_thermal_meter_init(p_dm);
+void odm_txpowertracking_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	odm_txpowertracking_thermal_meter_init(dm);
 }
 
-u8
-get_swing_index(
-	void	*p_dm_void
-)
+u8 get_swing_index(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+	void *adapter = dm->adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 #endif
-	u8			i = 0;
-	u32			bb_swing;
-	u32			swing_table_size;
-	u32			*p_swing_table;
-
-	if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8723B
-	    || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8188F || p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8710B
-	   ) {
-		bb_swing = odm_get_bb_reg(p_dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
-
-		p_swing_table = ofdm_swing_table_new;
-		swing_table_size = OFDM_TABLE_SIZE;
+	u8 i = 0;
+	u32 bb_swing, table_value;
+
+	if (dm->support_ic_type &
+		(ODM_RTL8188E | ODM_RTL8723B | ODM_RTL8192E |
+		ODM_RTL8188F | ODM_RTL8703B | ODM_RTL8723D |
+		ODM_RTL8710B | ODM_RTL8821)) {
+#if (RTL8821A_SUPPORT == 1)
+		bb_swing =
+		phy_get_tx_bb_swing_8812a(adapter,
+					  hal_data->current_band_type,
+					  RF_PATH_A);
+#else
+		bb_swing = odm_get_bb_reg(dm, R_0xc80, 0xFFC00000);
+#endif
+		for (i = 0; i < OFDM_TABLE_SIZE; i++) {
+			table_value = ofdm_swing_table_new[i];
+
+			if (table_value >= 0x100000)
+				table_value >>= 22;
+			if (bb_swing == table_value)
+				break;
+		}
 	} else {
-#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-		if (p_dm->support_ic_type == ODM_RTL8812 || p_dm->support_ic_type == ODM_RTL8821) {
-			bb_swing = phy_get_tx_bb_swing_8812a(adapter, p_hal_data->current_band_type, RF_PATH_A);
-			p_swing_table = tx_scaling_table_jaguar;
-			swing_table_size = TXSCALE_TABLE_SIZE;
-		} else
+#if (RTL8812A_SUPPORT == 1)
+		bb_swing =
+		phy_get_tx_bb_swing_8812a(adapter,
+					  hal_data->current_band_type,
+					  RF_PATH_A);
+#else
+		bb_swing = odm_get_bb_reg(dm, R_0xc1c, 0xFFE00000);
 #endif
-		{
-			bb_swing = 0;
-			p_swing_table = ofdm_swing_table;
-			swing_table_size = OFDM_TABLE_SIZE;
+		for (i = 0; i < TXSCALE_TABLE_SIZE; i++) {
+			table_value = tx_scaling_table_jaguar[i];
+
+			if (bb_swing == table_value)
+				break;
 		}
 	}
 
-	for (i = 0; i < swing_table_size; ++i) {
-		u32 table_value = p_swing_table[i];
-
-		if (table_value >= 0x100000)
-			table_value >>= 22;
-		if (bb_swing == table_value)
-			break;
-	}
 	return i;
 }
 
-u8
-get_cck_swing_index(
-	void		*p_dm_void
-)
+u8 get_cck_swing_index(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	u8			i = 0;
-	u32			bb_cck_swing;
+	u8 i = 0;
+	u32 bb_cck_swing;
 
-	if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8723B ||
-	    p_dm->support_ic_type == ODM_RTL8192E) {
-		bb_cck_swing = odm_read_1byte(p_dm, 0xa22);
+	if (dm->support_ic_type &
+		(ODM_RTL8188E | ODM_RTL8723B | ODM_RTL8192E)) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
 
 		for (i = 0; i < CCK_TABLE_SIZE; i++) {
 			if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
 				break;
 		}
-	} else if (p_dm->support_ic_type == ODM_RTL8703B) {
-		bb_cck_swing = odm_read_1byte(p_dm, 0xa22);
+	} else if (dm->support_ic_type & ODM_RTL8703B) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
 
 		for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
 			if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
@@ -552,204 +670,199 @@ get_cck_swing_index(
 	return i;
 }
 
-
-void
-odm_txpowertracking_thermal_meter_init(
-	void	*p_dm_void
-)
+void odm_txpowertracking_thermal_meter_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8 default_swing_index = get_swing_index(p_dm);
-	u8 default_cck_swing_index = get_cck_swing_index(p_dm);
-	u8			p = 0;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-
-	if (*(p_dm->p_mp_mode) == false)
-		p_hal_data->txpowertrack_control = true;
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#ifdef DM_ODM_CE_MAC80211
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
-	struct rtl_efuse *rtlefu = rtl_efuse(rtlpriv);
-#else
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-#endif
-
-	p_rf_calibrate_info->is_txpowertracking = true;
-	p_rf_calibrate_info->tx_powercount = 0;
-	p_rf_calibrate_info->is_txpowertracking_init = false;
-
-	if (*(p_dm->p_mp_mode) == false)
-		p_rf_calibrate_info->txpowertrack_control = true;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 swing_idx = get_swing_index(dm);
+	u8 cckswing_idx = get_cck_swing_index(dm);
+	u8 p = 0;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
+
+	cali_info->is_txpowertracking = true;
+	cali_info->tx_powercount = 0;
+	cali_info->is_txpowertracking_init = false;
+
+	if (!(*dm->mp_mode))
+		cali_info->txpowertrack_control = true;
 	else
-		p_rf_calibrate_info->txpowertrack_control = false;
-
-	if (*(p_dm->p_mp_mode) == false)
-		p_rf_calibrate_info->txpowertrack_control = true;
+		cali_info->txpowertrack_control = false;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("p_dm txpowertrack_control = %d\n", p_rf_calibrate_info->txpowertrack_control));
+	if (!(*dm->mp_mode))
+		cali_info->txpowertrack_control = true;
 
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-#ifdef RTL8188E_SUPPORT
-	{
-		p_rf_calibrate_info->is_txpowertracking = true;
-		p_rf_calibrate_info->tx_powercount = 0;
-		p_rf_calibrate_info->is_txpowertracking_init = false;
-		p_rf_calibrate_info->txpowertrack_control = true;
-	}
-#endif
+	RF_DBG(dm, DBG_RF_IQK, "dm txpowertrack_control = %d\n",
+	       cali_info->txpowertrack_control);
+#if 0
+	/* dm->rf_calibrate_info.txpowertrack_control = true; */
 #endif
-
-	/* p_dm->rf_calibrate_info.txpowertrack_control = true; */
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	p_rf_calibrate_info->thermal_value = rtlefu->eeprom_thermalmeter;
-	p_rf_calibrate_info->thermal_value_iqk = rtlefu->eeprom_thermalmeter;
-	p_rf_calibrate_info->thermal_value_lck = rtlefu->eeprom_thermalmeter;
-#else
-	p_rf_calibrate_info->thermal_value = p_hal_data->eeprom_thermal_meter;
-	p_rf_calibrate_info->thermal_value_iqk = p_hal_data->eeprom_thermal_meter;
-	p_rf_calibrate_info->thermal_value_lck = p_hal_data->eeprom_thermal_meter;
-#endif
-
-	if (p_rf_calibrate_info->default_bb_swing_index_flag != true) {
-		/*The index of "0 dB" in SwingTable.*/
-		if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8723B ||
-		    p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8703B) {
-			p_rf_calibrate_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
-			p_rf_calibrate_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
-		} else if (p_dm->support_ic_type == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
-			p_rf_calibrate_info->default_ofdm_index = 28;							/*OFDM: -1dB*/
-			p_rf_calibrate_info->default_cck_index = 20;							/*CCK:-6dB*/
-		} else if (p_dm->support_ic_type == ODM_RTL8723D) {			 /*add by zhaohe  2015-10-27*/
-			p_rf_calibrate_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
-			p_rf_calibrate_info->default_cck_index = 28;							/*CCK:   -6dB*/
-		} else if (p_dm->support_ic_type == ODM_RTL8710B) {		/* JJ ADD 20161014 */
-			p_rf_calibrate_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
-			p_rf_calibrate_info->default_cck_index = 28;							   /*CCK:   -6dB*/
+	cali_info->thermal_value = rf->eeprom_thermal;
+	cali_info->thermal_value_iqk = rf->eeprom_thermal;
+	cali_info->thermal_value_lck = rf->eeprom_thermal;
+
+	if (!cali_info->default_bb_swing_index_flag) {
+		if (dm->support_ic_type &
+			(ODM_RTL8188E | ODM_RTL8723B | ODM_RTL8192E |
+			ODM_RTL8703B | ODM_RTL8821)) {
+			if (swing_idx >= OFDM_TABLE_SIZE)
+				cali_info->default_ofdm_index = 30;
+			else
+				cali_info->default_ofdm_index = swing_idx;
+
+			if (cckswing_idx >= CCK_TABLE_SIZE)
+				cali_info->default_cck_index = 20;
+			else
+				cali_info->default_cck_index = cckswing_idx;
+		/*@add by Mingzhi.Guo  2015-03-23*/
+		} else if (dm->support_ic_type == ODM_RTL8188F) {
+			cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
+			cali_info->default_cck_index = 20; /*CCK:-6dB*/
+		/*@add by zhaohe  2015-10-27*/
+		} else if (dm->support_ic_type == ODM_RTL8723D) {
+			cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28; /*CCK:   -6dB*/
+		/*@JJ ADD 20161014 */
+		} else if (dm->support_ic_type == ODM_RTL8710B) {
+			cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28; /*CCK:   -6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8192F) {
+			cali_info->default_ofdm_index = 30;/*OFDM: 0dB*/
+			cali_info->default_cck_index = 28; /*CCK:   -6dB*/
 		} else {
-			p_rf_calibrate_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
-			p_rf_calibrate_info->default_cck_index = 24;
+			if (swing_idx >= TXSCALE_TABLE_SIZE)
+				cali_info->default_ofdm_index = 24;
+			else
+				cali_info->default_ofdm_index = swing_idx;
+
+			cali_info->default_cck_index = 24;
 		}
-		p_rf_calibrate_info->default_bb_swing_index_flag = true;
+		cali_info->default_bb_swing_index_flag = true;
 	}
 
-	p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->default_cck_index;
-	p_rf_calibrate_info->CCK_index = p_rf_calibrate_info->default_cck_index;
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->CCK_index = cali_info->default_cck_index;
 
 	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
-		p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->OFDM_index[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->delta_power_index[p] = 0;
-		p_rf_calibrate_info->delta_power_index_last[p] = 0;
-		p_rf_calibrate_info->power_index_offset[p] = 0;
+		cali_info->bb_swing_idx_ofdm_base[p] =
+						cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
 	}
-	p_rf_calibrate_info->modify_tx_agc_value_ofdm = 0;
-	p_rf_calibrate_info->modify_tx_agc_value_cck = 0;
-
+	cali_info->modify_tx_agc_value_ofdm = 0;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->tm_trigger = 0;
 }
 
-
-void
-odm_txpowertracking_check(
-	void	*p_dm_void
-)
+void odm_txpowertracking_check(void *dm_void)
 {
-	/* 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. */
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	switch	(p_dm->support_platform) {
-	case	ODM_WIN:
-		odm_txpowertracking_check_mp(p_dm);
+	/*@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.
+	 */
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	switch (dm->support_platform) {
+	case ODM_WIN:
+		odm_txpowertracking_check_mp(dm);
 		break;
 
-	case	ODM_CE:
-		odm_txpowertracking_check_ce(p_dm);
+	case ODM_CE:
+		odm_txpowertracking_check_ce(dm);
 		break;
 
-	case	ODM_AP:
-		odm_txpowertracking_check_ap(p_dm);
+	case ODM_AP:
+		odm_txpowertracking_check_ap(dm);
 		break;
 
 	default:
 		break;
 	}
-
 }
 
-void
-odm_txpowertracking_check_ce(
-	void	*p_dm_void
-)
+void odm_txpowertracking_check_ce(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
 
+	if (!dm->rf_calibrate_info.tm_trigger) {
+		if (dm->support_ic_type &
+			(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8192E |
+			ODM_RTL8723B | ODM_RTL8812 | ODM_RTL8821 |
+			ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8723D |
+			ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8710B |
+			ODM_RTL8192F))
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW,
+				       (BIT(17) | BIT(16)), 0x03);
+		else
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_OLD,
+				       RFREGOFFSETMASK, 0x60);
 
-	if (!(p_rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		dm->rf_calibrate_info.tm_trigger = 1;
+		return;
+	}
+	
+	if (dm->support_ic_type &
+			(ODM_RTL8822C | ODM_RTL8814B))
 		return;
 
-	if (!p_dm->rf_calibrate_info.tm_trigger) {
+	odm_txpowertracking_callback_thermal_meter(dm);
+	dm->rf_calibrate_info.tm_trigger = 0;
+#endif
+}
 
-		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_8188F(adapter) || IS_HARDWARE_TYPE_8192E(adapter)
-		    || IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_8814A(adapter)
-		    || IS_HARDWARE_TYPE_8703B(adapter) || IS_HARDWARE_TYPE_8723D(adapter) || IS_HARDWARE_TYPE_8822B(adapter)
-		    || IS_HARDWARE_TYPE_8821C(adapter)  || (p_dm->support_ic_type == ODM_RTL8710B)
-		   )/* JJ ADD 20161014 */
-			odm_set_rf_reg(p_dm, RF_PATH_A, RF_T_METER_NEW, (BIT(17) | BIT(16)), 0x03);
-		else
-			odm_set_rf_reg(p_dm, RF_PATH_A, RF_T_METER_OLD, RFREGOFFSETMASK, 0x60);
+void odm_txpowertracking_direct_ce(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_ *rf = &dm->rf_table;
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
 
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
 
+	if (dm->support_ic_type &
+		(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8192E |
+		ODM_RTL8723B | ODM_RTL8812 | ODM_RTL8821 |
+		ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8723D |
+		ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8710B |
+		ODM_RTL8192F))
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW, (BIT(17) | BIT(16)), 0x03);
+	else
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_OLD, RFREGOFFSETMASK, 0x60);
 
-		p_dm->rf_calibrate_info.tm_trigger = 1;
-		return;
-	} else {
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		odm_txpowertracking_callback_thermal_meter(p_dm);
-#else
-		odm_txpowertracking_callback_thermal_meter(adapter);
-#endif
-		p_dm->rf_calibrate_info.tm_trigger = 0;
-	}
+	odm_txpowertracking_callback_thermal_meter(dm);
 
 #endif
 }
 
-void
-odm_txpowertracking_check_mp(
-	void	*p_dm_void
-)
+void odm_txpowertracking_check_mp(void *dm_void)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
 
 	if (odm_check_power_status(adapter) == false) {
-		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status, return false\n"));
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
+			 ("check_pow_status, return false\n"));
 		return;
 	}
 
 	odm_txpowertracking_thermal_meter_check(adapter);
 #endif
-
 }
 
-
-void
-odm_txpowertracking_check_ap(
-	void	*p_dm_void
-)
+void odm_txpowertracking_check_ap(void *dm_void)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct rtl8192cd_priv	*priv		= p_dm->priv;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv *priv = dm->priv;
 
 	return;
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.h
index 18e7eb69e838..506783820ed3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_ce.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,336 +9,320 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMPOWERTRACKING_H__
-#define    __PHYDMPOWERTRACKING_H__
-
-#define HALRF_POWRTRACKING_VER	"1.1"
-
-#define		DPK_DELTA_MAPPING_NUM	13
-#define		index_mapping_HP_NUM	15
-#define	OFDM_TABLE_SIZE	43
-#define	CCK_TABLE_SIZE			33
-#define	CCK_TABLE_SIZE_88F	21
-#define TXSCALE_TABLE_SIZE		37
-#define CCK_TABLE_SIZE_8723D	41
-/* JJ ADD 20161014 */
-#define CCK_TABLE_SIZE_8710B	41
-
-#define TXPWR_TRACK_TABLE_SIZE	30
-#define DELTA_SWINGIDX_SIZE     30
-#define DELTA_SWINTSSI_SIZE     61
-#define BAND_NUM				4
-
-#define AVG_THERMAL_NUM		8
-#define HP_THERMAL_NUM		8
-#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 iqk_matrix_reg_num	8
+#ifndef __HALRF_POWERTRACKING_H__
+#define __HALRF_POWERTRACKING_H__
+
+#define DPK_DELTA_MAPPING_NUM 13
+#define index_mapping_HP_NUM 15
+#define OFDM_TABLE_SIZE 43
+#define CCK_TABLE_SIZE 33
+#define CCK_TABLE_SIZE_88F 21
+#define TXSCALE_TABLE_SIZE 37
+#define CCK_TABLE_SIZE_8723D 41
+/*@JJ ADD 20161014 */
+#define CCK_TABLE_SIZE_8710B 41
+#define CCK_TABLE_SIZE_8192F 41
+
+#define TXPWR_TRACK_TABLE_SIZE 30
+#define DELTA_SWINGIDX_SIZE 30
+#define DELTA_SWINTSSI_SIZE 61
+#define BAND_NUM 4
+
+#define AVG_THERMAL_NUM 8
+#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 iqk_matrix_reg_num 8
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
 #else
-#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+/* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+#define IQK_MATRIX_SETTINGS_NUM (14 + 24 + 21)
 #endif
 
-extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE];
-extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
-extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
-
-extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
-extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
-extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
-extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
-extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
-extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
-extern	u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
-/* JJ ADD 20161014 */
-extern	u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
-
-extern  u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
-
-/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+extern u32 ofdm_swing_table[OFDM_TABLE_SIZE];
+extern u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+extern u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+extern u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
+extern u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+extern u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+extern u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+extern u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/*@JJ ADD 20161014 */
+extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+extern u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
+
+extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+
+/*@<20121018, Kordan> In case fail to read TxPowerTrack.txt */
+/* we use the table of 88E as the default table. */
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
 #else
-static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
-static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+extern u8 delta_swing_table_idx_2ga_p_8188e[];
+extern u8 delta_swing_table_idx_2ga_n_8188e[];
 #endif
 
-#define dm_check_txpowertracking	odm_txpowertracking_check
+#define dm_check_txpowertracking odm_txpowertracking_check
 
-struct _IQK_MATRIX_REGS_SETTING {
-	boolean	is_iqk_done;
-	s32		value[3][iqk_matrix_reg_num];
-	boolean	is_bw_iqk_result_saved[3];
+struct iqk_matrix_regs_setting {
+	boolean is_iqk_done;
+	s32 value[3][iqk_matrix_reg_num];
+	boolean is_bw_iqk_result_saved[3];
 };
 
-struct odm_rf_calibration_structure {
+struct dm_rf_calibration_struct {
 	/* for tx power tracking */
 
-	u32	rega24; /* for TempCCK */
-	s32	rege94;
-	s32	rege9c;
-	s32	regeb4;
-	s32	regebc;
+	u32 rega24; /* for TempCCK */
+	s32 rege94;
+	s32 rege9c;
+	s32 regeb4;
+	s32 regebc;
 
-	u8	tx_powercount;
+	u8 tx_powercount;
 	boolean is_txpowertracking_init;
 	boolean is_txpowertracking;
-	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
-	u8	tm_trigger;
-	u8  	internal_pa_5g[2];	/* pathA / pathB */
-
-	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
-	u8	thermal_value;
-	u8	thermal_value_lck;
-	u8	thermal_value_iqk;
-	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
-	u8	thermal_value_dpk;
-	u8	thermal_value_avg[AVG_THERMAL_NUM];
-	u8	thermal_value_avg_index;
-	u8	thermal_value_rx_gain;
-	u8	thermal_value_crystal;
-	u8	thermal_value_dpk_store;
-	u8	thermal_value_dpk_track;
-	boolean	txpowertracking_in_progress;
-
-	boolean	is_reloadtxpowerindex;
-	u8	is_rf_pi_enable;
-	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
-
-
-	/* ------------------------- Tx power Tracking ------------------------- */
-	u8	is_cck_in_ch14;
-	u8	CCK_index;
-	u8	OFDM_index[MAX_RF_PATH];
-	s8	power_index_offset[MAX_RF_PATH];
-	s8	delta_power_index[MAX_RF_PATH];
-	s8	delta_power_index_last[MAX_RF_PATH];
+	/* for mp mode, turn off txpwrtracking as default */
+	u8 txpowertrack_control;
+	u8 tm_trigger;
+	u8 internal_pa_5g[2]; /* pathA / pathB */
+
+	/* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8 thermal_meter[2];
+	u8 thermal_value;
+	u8 thermal_value_lck;
+	u8 thermal_value_iqk;
+	s8 thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8 thermal_value_dpk;
+	u8 thermal_value_avg[AVG_THERMAL_NUM];
+	u8 thermal_value_avg_index;
+	u8 thermal_value_rx_gain;
+	u8 thermal_value_crystal;
+	u8 thermal_value_dpk_store;
+	u8 thermal_value_dpk_track;
+	boolean txpowertracking_in_progress;
+
+	boolean is_reloadtxpowerindex;
+	u8 is_rf_pi_enable;
+	u32 txpowertracking_callback_cnt; /* cosa add for debug */
+
+	/*@---------------------- Tx power Tracking ---------------------- */
+	u8 is_cck_in_ch14;
+	u8 CCK_index;
+	u8 OFDM_index[MAX_RF_PATH];
+	s8 power_index_offset[MAX_RF_PATH];
+	s8 delta_power_index[MAX_RF_PATH];
+	s8 delta_power_index_last[MAX_RF_PATH];
 	boolean is_tx_power_changed;
-	s8	xtal_offset;
-	s8	xtal_offset_last;
-
-	u8	thermal_value_hp[HP_THERMAL_NUM];
-	u8	thermal_value_hp_index;
-	struct _IQK_MATRIX_REGS_SETTING iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
-	u8	delta_lck;
-	s8  bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
-	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
-	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
-	s8  delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
-	s8  delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
-	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
-
-	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
-	u8			bb_swing_idx_ofdm_current;
+	s8 xtal_offset;
+	s8 xtal_offset_last;
+	u8 xtal_offset_eanble;
+
+	struct iqk_matrix_regs_setting
+				iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8 delta_lck;
+	s8 bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
+	u8 delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8 delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	s8 delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
+	s8 delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8 delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8 bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8 bb_swing_idx_ofdm_current;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+	u8 bb_swing_idx_ofdm_base[MAX_RF_PATH];
 #else
-	u8			bb_swing_idx_ofdm_base;
+	u8 bb_swing_idx_ofdm_base;
 #endif
-	boolean		default_bb_swing_index_flag;
-	boolean			bb_swing_flag_ofdm;
-	u8			bb_swing_idx_cck;
-	u8			bb_swing_idx_cck_current;
-	u8			bb_swing_idx_cck_base;
-	u8			default_ofdm_index;
-	u8			default_cck_index;
-	boolean			bb_swing_flag_cck;
-
-	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
-	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
-	s8			absolute_cck_swing_idx[MAX_RF_PATH];
-	s8			remnant_cck_swing_idx;
-	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
-	boolean			modify_tx_agc_flag_path_a;
-	boolean			modify_tx_agc_flag_path_b;
-	boolean			modify_tx_agc_flag_path_c;
-	boolean			modify_tx_agc_flag_path_d;
-	boolean			modify_tx_agc_flag_path_a_cck;
-
-	s8			kfree_offset[MAX_RF_PATH];
-
-	/* -------------------------------------------------------------------- */
+	boolean default_bb_swing_index_flag;
+	boolean bb_swing_flag_ofdm;
+	u8 bb_swing_idx_cck;
+	u8 bb_swing_idx_cck_current;
+	u8 bb_swing_idx_cck_base;
+	u8 default_ofdm_index;
+	u8 default_cck_index;
+	boolean bb_swing_flag_cck;
+
+	s8 absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8 remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8 absolute_cck_swing_idx[MAX_RF_PATH];
+	s8 remnant_cck_swing_idx;
+	s8 modify_tx_agc_value; /*Remnat compensate value at tx_agc */
+	boolean modify_tx_agc_flag_path_a;
+	boolean modify_tx_agc_flag_path_b;
+	boolean modify_tx_agc_flag_path_c;
+	boolean modify_tx_agc_flag_path_d;
+	boolean modify_tx_agc_flag_path_a_cck;
+	boolean modify_tx_agc_flag_path_b_cck;
+
+	s8 kfree_offset[MAX_RF_PATH];
+
+	/*@----------------------------------------------------------------- */
 
 	/* for IQK */
-	u32	regc04;
-	u32	reg874;
-	u32	regc08;
-	u32	regb68;
-	u32	regb6c;
-	u32	reg870;
-	u32	reg860;
-	u32	reg864;
-
-	boolean	is_iqk_initialized;
+	u32 regc04;
+	u32 reg874;
+	u32 regc08;
+	u32 regb68;
+	u32 regb6c;
+	u32 reg870;
+	u32 reg860;
+	u32 reg864;
+
+	boolean is_iqk_initialized;
 	boolean is_lck_in_progress;
-	boolean	is_antenna_detected;
-	boolean	is_need_iqk;
-	boolean	is_iqk_in_progress;
+	boolean is_antenna_detected;
+	boolean is_need_iqk;
+	boolean is_iqk_in_progress;
 	boolean is_iqk_pa_off;
-	u8	delta_iqk;
-	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];
-	u32 	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
-	u32 	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
-	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
-	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
-	u32	tx_iqc_8723d[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
-	u32	rx_iqc_8723d[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	u8 delta_iqk;
+	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];
+	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32 tx_iqc_8723b[2][3][2];
+	/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
+	u32 rx_iqc_8723b[2][2][2];
+	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32 tx_iqc_8703b[3][2];
+	/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
+	u32 rx_iqc_8703b[2][2];
+	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32 tx_iqc_8723d[2][3][2];
+	/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
+	u32 rx_iqc_8723d[2][2][2];
 	/* JJ ADD 20161014 */
-	u32	tx_iqc_8710b[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
-	u32	rx_iqc_8710b[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
-
-	u8	iqk_step;
-	u8	kcount;
-	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
-	boolean	is_mp_mode;
-
-
-
-	/* <James> IQK time measurement */
-	u64	iqk_start_time;
-	u64	iqk_progressing_time;
-	u64	iqk_total_progressing_time;
+	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32 tx_iqc_8710b[2][3][2];
+	/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
+	u32 rx_iqc_8710b[2][2][2];
+
+	u8 iqk_step;
+	u8 kcount;
+	u8 retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean is_mp_mode;
+
+	/*@<James> IQK time measurement */
+	u64 iqk_start_time;
+	u64 iqk_progressing_time;
+	u64 iqk_total_progressing_time;
 	u64 lck_progressing_time;
 
-	u32  lok_result;
+	u32 lok_result;
 
 	/* for APK */
-	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
-	u8	is_ap_kdone;
-	u8	is_apk_thermal_meter_ignore;
+	u32 ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8 is_ap_kdone;
+	u8 is_apk_thermal_meter_ignore;
 
 	/* DPK */
 	boolean is_dpk_fail;
-	u8	is_dp_done;
-	u8	is_dp_path_aok;
-	u8	is_dp_path_bok;
-
-	u32	tx_lok[2];
-	u32  dpk_tx_agc;
-	s32  dpk_gain;
-	u32  dpk_thermal[4];
+	u8 is_dp_done;
+	u8 is_dp_path_aok;
+	u8 is_dp_path_bok;
+
+	u32 tx_lok[2];
+	u32 dpk_tx_agc;
+	s32 dpk_gain;
+	u32 dpk_thermal[4];
 	s8 modify_tx_agc_value_ofdm;
 	s8 modify_tx_agc_value_cck;
 
-	/*Add by Yuchen for Kfree Phydm*/
-	u8			reg_rf_kfree_enable;	/*for registry*/
-	u8			rf_kfree_enable;		/*for efuse enable check*/
-
+	/*@Add by Yuchen for Kfree Phydm*/
+	u8 reg_rf_kfree_enable; /*for registry*/
+	u8 rf_kfree_enable; /*for efuse enable check*/
 };
 
+void odm_txpowertracking_check(void *dm_void);
 
-void
-odm_txpowertracking_check(
-	void		*p_dm_void
-);
-
+void odm_txpowertracking_init(void *dm_void);
 
-void
-odm_txpowertracking_init(
-	void		*p_dm_void
-);
+void odm_txpowertracking_check_ap(void *dm_void);
 
-void
-odm_txpowertracking_check_ap(
-	void		*p_dm_void
-);
+void odm_txpowertracking_thermal_meter_init(void *dm_void);
 
-void
-odm_txpowertracking_thermal_meter_init(
-	void		*p_dm_void
-);
+void odm_txpowertracking_init(void *dm_void);
 
-void
-odm_txpowertracking_init(
-	void		*p_dm_void
-);
+void odm_txpowertracking_check_mp(void *dm_void);
 
-void
-odm_txpowertracking_check_mp(
-	void		*p_dm_void
-);
+void odm_txpowertracking_check_ce(void *dm_void);
 
-
-void
-odm_txpowertracking_check_ce(
-	void		*p_dm_void
-);
+void odm_txpowertracking_direct_ce(void *dm_void);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
 
-void
-odm_txpowertracking_callback_thermal_meter92c(
-	struct _ADAPTER	*adapter
-);
+void odm_txpowertracking_callback_thermal_meter92c(
+	void *adapter);
 
-void
-odm_txpowertracking_callback_rx_gain_thermal_meter92d(
-	struct _ADAPTER	*adapter
-);
+void odm_txpowertracking_callback_rx_gain_thermal_meter92d(
+	void *adapter);
 
-void
-odm_txpowertracking_callback_thermal_meter92d(
-	struct _ADAPTER	*adapter
-);
+void odm_txpowertracking_callback_thermal_meter92d(
+	void *adapter);
 
-void
-odm_txpowertracking_direct_call92c(
-	struct _ADAPTER		*adapter
-);
+void odm_txpowertracking_direct_call92c(
+	void *adapter);
 
-void
-odm_txpowertracking_thermal_meter_check(
-	struct _ADAPTER		*adapter
-);
+void odm_txpowertracking_thermal_meter_check(
+	void *adapter);
 
 #endif
 
-#endif
+#endif /*__HALRF_POWER_TRACKING_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_iot.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_iot.c
new file mode 100644
index 000000000000..efd3fcbcb161
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_iot.c
@@ -0,0 +1,742 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*============================================================	*/
+/* include files												*/
+/*============================================================	*/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+/* ************************************************************
+ * Global var
+ * ************************************************************
+ */
+
+u32	ofdm_swing_table[OFDM_TABLE_SIZE] = {
+	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*/
+};
+
+u8	cck_swing_table_ch1_ch13[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 <== default */
+	{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	cck_swing_table_ch14[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  <== default*/
+	{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*/
+};
+
+u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
+	0x0b40002d, /* 0,  -15.0dB	*/
+	0x0c000030, /* 1,  -14.5dB*/
+	0x0cc00033, /* 2,  -14.0dB*/
+	0x0d800036, /* 3,  -13.5dB*/
+	0x0e400039, /* 4,  -13.0dB */
+	0x0f00003c, /* 5,  -12.5dB*/
+	0x10000040, /* 6,  -12.0dB*/
+	0x11000044, /* 7,  -11.5dB*/
+	0x12000048, /* 8,  -11.0dB*/
+	0x1300004c, /* 9,  -10.5dB*/
+	0x14400051, /* 10, -10.0dB*/
+	0x15800056, /* 11, -9.5dB*/
+	0x16c0005b, /* 12, -9.0dB*/
+	0x18000060, /* 13, -8.5dB*/
+	0x19800066, /* 14, -8.0dB*/
+	0x1b00006c, /* 15, -7.5dB*/
+	0x1c800072, /* 16, -7.0dB*/
+	0x1e400079, /* 17, -6.5dB*/
+	0x20000080, /* 18, -6.0dB*/
+	0x22000088, /* 19, -5.5dB*/
+	0x24000090, /* 20, -5.0dB*/
+	0x26000098, /* 21, -4.5dB*/
+	0x288000a2, /* 22, -4.0dB*/
+	0x2ac000ab, /* 23, -3.5dB*/
+	0x2d4000b5, /* 24, -3.0dB*/
+	0x300000c0, /* 25, -2.5dB*/
+	0x32c000cb, /* 26, -2.0dB*/
+	0x35c000d7, /* 27, -1.5dB*/
+	0x390000e4, /* 28, -1.0dB*/
+	0x3c8000f2, /* 29, -0.5dB*/
+	0x40000100, /* 30, +0dB*/
+	0x43c0010f, /* 31, +0.5dB*/
+	0x47c0011f, /* 32, +1.0dB*/
+	0x4c000130, /* 33, +1.5dB*/
+	0x50800142, /* 34, +2.0dB*/
+	0x55400155, /* 35, +2.5dB*/
+	0x5a400169, /* 36, +3.0dB*/
+	0x5fc0017f, /* 37, +3.5dB*/
+	0x65400195, /* 38, +4.0dB*/
+	0x6b8001ae, /* 39, +4.5dB*/
+	0x71c001c7, /* 40, +5.0dB*/
+	0x788001e2, /* 41, +5.5dB*/
+	0x7f8001fe  /* 42, +6.0dB*/
+};
+
+u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
+	{0x44,	 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-16dB*/
+	{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15.5dB*/
+	{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-15dB*/
+	{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},	    /*-14.5dB*/
+	{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-14dB*/
+	{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13.5dB*/
+	{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-13dB*/
+	{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12.5dB*/
+	{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-12dB*/
+	{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11.5dB*/
+	{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-11dB*/
+	{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10.5dB*/
+	{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-10dB*/
+	{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9.5dB*/
+	{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-9dB*/
+	{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8.5dB*/
+	{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-8dB*/
+	{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7.5dB*/
+	{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-7dB*/
+	{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},    /*-6.5dB*/
+	{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}     /*-6dB*/
+};
+
+u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01},	/*  0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},	/*   1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01},	/*  2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},	/*   3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01},	/*   5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01},	/*   6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01},	/*   7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01},	/*  8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01},	/*   9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01},	/*  11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},	/*  13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},	/*  14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02},	/*  15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},	/*  16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02},	/*  17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},	/*  18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02},	/*  19, -6.5dB*/
+	{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},	/*20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02},	/*  21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02},	/*  23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},	/*  24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03},	/*  25, -3.5dB*/
+	{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},	/*  26, -3.0dB*/
+	{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03},	/*  27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},	/*  28, -2.0dB */
+	{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03},	/*  29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},	/*  30, -1.0dB*/
+	{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04},	/*  31, -0.5dB*/
+	{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}	/*  32, +0dB*/
+};
+
+u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
+	{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00},	/*  0, -16.0dB*/
+	{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 1, -15.5dB*/
+	{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  2, -15.0dB*/
+	{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/* 3, -14.5dB*/
+	{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00},	/*  4, -14.0dB*/
+	{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/*5, -13.5dB*/
+	{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00},	/* 6, -13.0dB*/
+	{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00},	/*  7, -12.5dB*/
+	{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 8, -12.0dB*/
+	{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00},	/* 9, -11.5dB*/
+	{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00},	/* 10, -11.0dB*/
+	{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00},	/*11, -10.5dB*/
+	{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 12, -10.0dB*/
+	{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},	/* 13, -9.5dB*/
+	{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},	/*14, -9.0dB */
+	{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00},	/* 15, -8.5dB*/
+	{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 16, -8.0dB */
+	{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00},	/* 17, -7.5dB*/
+	{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},	/* 18, -7.0dB */
+	{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00},	/* 19, -6.5dB */
+	{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 20, -6.0dB */
+	{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00},	/* 21, -5.5dB*/
+	{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},	/* 22, -5.0dB */
+	{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00},	/*23, -4.5dB*/
+	{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},	/* 24, -4.0dB */
+	{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00},	/* 25, -3.5dB */
+	{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},	/* 26, -3.0dB */
+	{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00},	/*27, -2.5dB*/
+	{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},	/* 28, -2.0dB */
+	{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00},	/*29, -1.5dB*/
+	{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},	/* 30, -1.0dB */
+	{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00},	/* 31, -0.5dB */
+	{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}	/* 32, +0dB	*/
+};
+
+u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
+	0x0CD,          /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+/* JJ ADD 20161014 */
+u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
+	0x0CD,          /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,
+	0x287,
+	0x2AE,
+	0x2D6,
+	0x301,
+	0x32F,
+	0x35F,
+	0x392,
+	0x3C9,
+	0x402,
+	0x43F,
+	0x47F,
+	0x4C3,
+	0x50C,
+	0x558,
+	0x5A9,
+	0x5FF,
+	0x65A,
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+/* Winnita ADD 20171116 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
+u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
+	0x0CD,			 /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,		/*19*/
+	0x287,		/*20*/
+	0x2AE,		/*21*/
+	0x2D6,		/*22*/
+	0x301,		/*23*/
+	0x32F,		/*24*/
+	0x35F,		/*25*/
+	0x392,		/*26*/
+	0x3C9,		/*27*/
+	0x402,		/*28*/
+	0x43F,		/*29*/
+	0x47F,		/*30*/
+	0x4C3,		/*31*/
+	0x50C,		/*32*/
+	0x558,		/*33*/
+	0x5A9,		/*34*/
+	0x5FF,		/*35*/
+	0x65A,		/*36*/
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+/* Winnita ADD 201805 PathA 0xAB4[10:0]*/
+u32 cck_swing_table_ch1_ch14_8721d[CCK_TABLE_SIZE_8721D] = {
+	0x0CD,			 /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,		/*19*/
+	0x287,		/*20*/
+	0x2AE,		/*21*/
+	0x2D6,		/*22*/
+	0x301,		/*23*/
+	0x32F,		/*24*/
+	0x35F,		/*25*/
+	0x392,		/*26*/
+	0x3C9,		/*27*/
+	0x402,		/*28*/
+	0x43F,		/*29*/
+	0x47F,		/*30*/
+	0x4C3,		/*31*/
+	0x50C,		/*32*/
+	0x558,		/*33*/
+	0x5A9,		/*34*/
+	0x5FF,		/*35*/
+	0x65A,		/*36*/
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
+
+u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
+	0x081, /* 0,  -12.0dB*/
+	0x088, /* 1,  -11.5dB*/
+	0x090, /* 2,  -11.0dB*/
+	0x099, /* 3,  -10.5dB*/
+	0x0A2, /* 4,  -10.0dB*/
+	0x0AC, /* 5,  -9.5dB*/
+	0x0B6, /* 6,  -9.0dB*/
+	0x0C0, /*7,  -8.5dB*/
+	0x0CC, /* 8,  -8.0dB*/
+	0x0D8, /* 9,  -7.5dB*/
+	0x0E5, /* 10, -7.0dB*/
+	0x0F2, /* 11, -6.5dB*/
+	0x101, /* 12, -6.0dB*/
+	0x110, /* 13, -5.5dB*/
+	0x120, /* 14, -5.0dB*/
+	0x131, /* 15, -4.5dB*/
+	0x143, /* 16, -4.0dB*/
+	0x156, /* 17, -3.5dB*/
+	0x16A, /* 18, -3.0dB*/
+	0x180, /* 19, -2.5dB*/
+	0x197, /* 20, -2.0dB*/
+	0x1AF, /* 21, -1.5dB*/
+	0x1C8, /* 22, -1.0dB*/
+	0x1E3, /* 23, -0.5dB*/
+	0x200, /* 24, +0  dB*/
+	0x21E, /* 25, +0.5dB*/
+	0x23E, /* 26, +1.0dB*/
+	0x261, /* 27, +1.5dB*/
+	0x285,/* 28, +2.0dB*/
+	0x2AB, /* 29, +2.5dB*/
+	0x2D3, /*30, +3.0dB*/
+	0x2FE, /* 31, +3.5dB*/
+	0x32B, /* 32, +4.0dB*/
+	0x35C, /* 33, +4.5dB*/
+	0x38E, /* 34, +5.0dB*/
+	0x3C4, /* 35, +5.5dB*/
+	0x3FE  /* 36, +6.0dB	*/
+};
+
+void
+odm_txpowertracking_init(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_txpowertracking_thermal_meter_init(dm);
+}
+
+u8
+get_swing_index(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	u8	i = 0;
+	u32	bb_swing;
+	u32	swing_table_size;
+	u32	*swing_table;
+
+	if (dm->support_ic_type == ODM_RTL8195B) {
+		bb_swing = odm_get_bb_reg(dm, R_0xc1c, 0xFFE00000);
+		swing_table = tx_scaling_table_jaguar;
+		swing_table_size = TXSCALE_TABLE_SIZE;
+	}
+
+	for (i = 0; i < swing_table_size; i++) {
+		u32 table_value = swing_table[i];
+
+		table_value = table_value;
+		if (bb_swing == table_value)
+			break;
+	}
+
+	return i;
+}
+
+u8
+get_cck_swing_index(
+	void		*dm_void
+)
+{
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+
+	u8			i = 0;
+	u32			bb_cck_swing;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
+				break;
+		}
+	} else if (dm->support_ic_type == ODM_RTL8703B) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
+
+		for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
+			if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
+				break;
+		}
+	}
+
+	return i;
+}
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	u8 default_swing_index = get_swing_index(dm);
+	u8 p = 0;
+	struct dm_rf_calibration_struct	*cali_info = &dm->rf_calibrate_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
+
+	if (!(*dm->mp_mode))
+		cali_info->txpowertrack_control = true;
+	else
+		cali_info->txpowertrack_control = false;
+
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
+
+	/* dm->rf_calibrate_info.txpowertrack_control = true; */
+	cali_info->thermal_value = rf->eeprom_thermal;
+	cali_info->thermal_value_iqk = rf->eeprom_thermal;
+	cali_info->thermal_value_lck = rf->eeprom_thermal;
+
+	if (!cali_info->default_bb_swing_index_flag) {
+		if (dm->support_ic_type == ODM_RTL8195B) {
+			cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
+			cali_info->default_cck_index = 24;
+		} else if (dm->support_ic_type == ODM_RTL8721D) {
+			cali_info->default_ofdm_index = 30;	/*OFDM: 0dB*/
+			cali_info->default_cck_index = 28;	/*CCK: -6dB*/
+		}
+		cali_info->default_bb_swing_index_flag = true;
+	}
+
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->CCK_index = cali_info->default_cck_index;
+
+	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
+	}
+	cali_info->modify_tx_agc_value_ofdm = 0;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->tm_trigger = 0;
+}
+
+void
+odm_txpowertracking_check(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+
+	odm_txpowertracking_check_iot(dm);
+}
+
+void
+odm_txpowertracking_check_iot(
+	void	*dm_void
+)
+{
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_		*rf = &dm->rf_table;
+
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+		return;
+
+	if (!dm->rf_calibrate_info.tm_trigger) {
+		if (dm->support_ic_type == ODM_RTL8195B)
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW, (BIT(17) | BIT(16)), 0x03);
+		else if (dm->support_ic_type == ODM_RTL8721D)
+			odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW,
+				       (BIT(12) | BIT(11)), 0x03);
+
+		dm->rf_calibrate_info.tm_trigger = 1;
+		return;
+	}
+	odm_txpowertracking_callback_thermal_meter(dm);
+	dm->rf_calibrate_info.tm_trigger = 0;
+}
+
+void
+odm_txpowertracking_check_mp(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void	*adapter = dm->adapter;
+
+	if (odm_check_power_status(adapter) == false) {
+		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status, return false\n"));
+		return;
+	}
+
+	odm_txpowertracking_thermal_meter_check(adapter);
+#endif
+}
+
+void
+odm_txpowertracking_check_ap(
+	void	*dm_void
+)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct rtl8192cd_priv	*priv		= dm->priv;
+
+	return;
+
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_iot.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_iot.h
new file mode 100644
index 000000000000..563f92f6c59f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_iot.h
@@ -0,0 +1,350 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HALRF_POWERTRACKING_H__
+#define __HALRF_POWERTRACKING_H__
+
+#define		DPK_DELTA_MAPPING_NUM	13
+#define		index_mapping_HP_NUM	15
+#define	OFDM_TABLE_SIZE	43
+#define	CCK_TABLE_SIZE			33
+#define	CCK_TABLE_SIZE_88F	21
+#define TXSCALE_TABLE_SIZE		37
+#define CCK_TABLE_SIZE_8723D	41
+/* JJ ADD 20161014 */
+#define CCK_TABLE_SIZE_8710B	41
+#define	CCK_TABLE_SIZE_8192F   41
+#define	CCK_TABLE_SIZE_8721D   41
+
+
+#define TXPWR_TRACK_TABLE_SIZE	30
+#define DELTA_SWINGIDX_SIZE     30
+#define DELTA_SWINTSSI_SIZE     61
+#define BAND_NUM				4
+
+#define AVG_THERMAL_NUM		8
+#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 iqk_matrix_reg_num	8
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#else
+#define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
+#endif
+
+extern	u32 ofdm_swing_table[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
+
+extern	u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
+extern	u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
+extern	u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
+extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
+extern	u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
+/* JJ ADD 20161014 */
+extern	u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+extern	u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
+extern	u32 cck_swing_table_ch1_ch14_8721d[CCK_TABLE_SIZE_8721D];
+
+extern  u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
+
+/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#else
+static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+#endif
+
+void
+odm_txpowertracking_init(
+	void		*dm_void
+);
+
+#define dm_check_txpowertracking	odm_txpowertracking_check
+
+struct iqk_matrix_regs_setting {
+	boolean	is_iqk_done;
+	s32		value[3][iqk_matrix_reg_num];
+	boolean	is_bw_iqk_result_saved[3];
+};
+
+struct dm_rf_calibration_struct {
+	/* for tx power tracking */
+
+	u32	rega24; /* for TempCCK */
+	s32	rege94;
+	s32	rege9c;
+	s32	regeb4;
+	s32	regebc;
+
+	u8	tx_powercount;
+	boolean is_txpowertracking_init;
+	boolean is_txpowertracking;
+	u8  	txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
+	u8	tm_trigger;
+	u8  	internal_pa_5g[2];	/* pathA / pathB */
+
+	u8  	thermal_meter[2];    /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
+	u8	thermal_value;
+	u8	thermal_value_lck;
+	u8	thermal_value_iqk;
+	s8  	thermal_value_delta; /* delta of thermal_value and efuse thermal */
+	u8	thermal_value_dpk;
+	u8	thermal_value_avg[AVG_THERMAL_NUM];
+	u8	thermal_value_avg_index;
+	u8	thermal_value_rx_gain;
+	u8	thermal_value_crystal;
+	u8	thermal_value_dpk_store;
+	u8	thermal_value_dpk_track;
+	boolean	txpowertracking_in_progress;
+
+	boolean	is_reloadtxpowerindex;
+	u8	is_rf_pi_enable;
+	u32 	txpowertracking_callback_cnt; /* cosa add for debug */
+
+
+	/* ------------------------- Tx power Tracking ------------------------- */
+	u8	is_cck_in_ch14;
+	u8	CCK_index;
+	u8	OFDM_index[MAX_RF_PATH];
+	s8	power_index_offset[MAX_RF_PATH];
+	s8	delta_power_index[MAX_RF_PATH];
+	s8	delta_power_index_last[MAX_RF_PATH];
+	boolean is_tx_power_changed;
+	s8	xtal_offset;
+	s8	xtal_offset_last;
+
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	u8	delta_lck;
+	s8  bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
+	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	u8  delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
+	s8  delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
+	s8  delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
+	u8  delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
+
+	u8			bb_swing_idx_ofdm[MAX_RF_PATH];
+	u8			bb_swing_idx_ofdm_current;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_IOT))
+	u8			bb_swing_idx_ofdm_base[MAX_RF_PATH];
+#else
+	u8			bb_swing_idx_ofdm_base;
+#endif
+	boolean		default_bb_swing_index_flag;
+	boolean			bb_swing_flag_ofdm;
+	u8			bb_swing_idx_cck;
+	u8			bb_swing_idx_cck_current;
+	u8			bb_swing_idx_cck_base;
+	u8			default_ofdm_index;
+	u8			default_cck_index;
+	boolean			bb_swing_flag_cck;
+
+	s8			absolute_ofdm_swing_idx[MAX_RF_PATH];
+	s8			remnant_ofdm_swing_idx[MAX_RF_PATH];
+	s8			absolute_cck_swing_idx[MAX_RF_PATH];
+	s8			remnant_cck_swing_idx;
+	s8			modify_tx_agc_value;       /*Remnat compensate value at tx_agc */
+	boolean			modify_tx_agc_flag_path_a;
+	boolean			modify_tx_agc_flag_path_b;
+	boolean			modify_tx_agc_flag_path_c;
+	boolean			modify_tx_agc_flag_path_d;
+	boolean			modify_tx_agc_flag_path_a_cck;
+	boolean			modify_tx_agc_flag_path_b_cck;
+
+	s8			kfree_offset[MAX_RF_PATH];
+
+	/* -------------------------------------------------------------------- */
+
+	/* for IQK */
+	u32	regc04;
+	u32	reg874;
+	u32	regc08;
+	u32	regb68;
+	u32	regb6c;
+	u32	reg870;
+	u32	reg860;
+	u32	reg864;
+
+	boolean	is_iqk_initialized;
+	boolean is_lck_in_progress;
+	boolean	is_antenna_detected;
+	boolean	is_need_iqk;
+	boolean	is_iqk_in_progress;
+	boolean is_iqk_pa_off;
+	u8	delta_iqk;
+	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];
+	u32 	tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
+	u32 	rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} */
+	u32	tx_iqc_8703b[3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8703b[2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	u32	tx_iqc_8723d[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8723d[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+	/* JJ ADD 20161014 */
+	u32	tx_iqc_8710b[2][3][2];	/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
+	u32	rx_iqc_8710b[2][2][2];	/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*/
+
+	u8	iqk_step;
+	u8	kcount;
+	u8	retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
+	boolean	is_mp_mode;
+
+
+
+	/* <James> IQK time measurement */
+	u32	iqk_start_time;
+	u32	iqk_progressing_time;
+	u32	iqk_total_progressing_time;
+	u32	lck_progressing_time;
+
+	u32  lok_result;
+
+	/* for APK */
+	u32 	ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
+	u8	is_ap_kdone;
+	u8	is_apk_thermal_meter_ignore;
+
+	/* DPK */
+	boolean is_dpk_fail;
+	u8	is_dp_done;
+	u8	is_dp_path_aok;
+	u8	is_dp_path_bok;
+
+	u32	tx_lok[2];
+	u32  dpk_tx_agc;
+	s32  dpk_gain;
+	u32  dpk_thermal[4];
+	s8 modify_tx_agc_value_ofdm;
+	s8 modify_tx_agc_value_cck;
+
+	/*Add by Yuchen for Kfree Phydm*/
+	u8			reg_rf_kfree_enable;	/*for registry*/
+	u8			rf_kfree_enable;		/*for efuse enable check*/
+
+};
+
+
+void
+odm_txpowertracking_check(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_check_ap(
+	void		*dm_void
+);
+
+void
+odm_txpowertracking_thermal_meter_init(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_mp(
+	void		*dm_void
+);
+
+
+void
+odm_txpowertracking_check_iot(
+	void		*dm_void
+);
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+
+void
+odm_txpowertracking_callback_thermal_meter92c(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_rx_gain_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_callback_thermal_meter92d(
+	void	*adapter
+);
+
+void
+odm_txpowertracking_direct_call92c(
+	void		*adapter
+);
+
+void
+odm_txpowertracking_thermal_meter_check(
+	void		*adapter
+);
+
+#endif
+
+#endif	/*#ifndef __HALRF_POWER_TRACKING_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.c
index c89d446c790d..3772d37c2fee 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -419,6 +420,50 @@ u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
 	0x7FF,
 };
 
+/* Winnita ADD 20170828 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
+u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
+	0x0CD,			 /*0 ,    -20dB*/
+	0x0D9,
+	0x0E6,
+	0x0F3,
+	0x102,
+	0x111,
+	0x121,
+	0x132,
+	0x144,
+	0x158,
+	0x16C,
+	0x182,
+	0x198,
+	0x1B1,
+	0x1CA,
+	0x1E5,
+	0x202,
+	0x221,
+	0x241,
+	0x263,		/*19*/
+	0x287,		/*20*/
+	0x2AE,		/*21*/
+	0x2D6,		/*22*/
+	0x301,		/*23*/
+	0x32F,		/*24*/
+	0x35F,		/*25*/
+	0x392,		/*26*/
+	0x3C9,		/*27*/
+	0x402,		/*28*/
+	0x43F,		/*29*/
+	0x47F,		/*30*/
+	0x4C3,		/*31*/
+	0x50C,		/*32*/
+	0x558,		/*33*/
+	0x5A9,		/*34*/
+	0x5FF,		/*35*/
+	0x65A,		/*36*/
+	0x6BA,
+	0x720,
+	0x78C,
+	0x7FF,
+};
 
 u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
 	0x081, /* 0,  -12.0dB */
@@ -462,74 +507,78 @@ u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
 
 void
 odm_txpowertracking_init(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	if (!(p_dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
+	if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
 		return;
 #endif
 
-	odm_txpowertracking_thermal_meter_init(p_dm);
+	odm_txpowertracking_thermal_meter_init(dm);
 }
 
 u8
 get_swing_index(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 	u8			i = 0;
-	u32			bb_swing;
-	u32			swing_table_size;
-	u32			*p_swing_table;
+	u32			bb_swing, table_value;
+
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8188F || 
+	    dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D || 
+	    dm->support_ic_type == ODM_RTL8192F || dm->support_ic_type == ODM_RTL8710B ||
+	    dm->support_ic_type == ODM_RTL8821) {
+		bb_swing = odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
 
-	if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8723B ||
-	    p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8188F || p_dm->support_ic_type == ODM_RTL8703B || p_dm->support_ic_type == ODM_RTL8723D || p_dm->support_ic_type == ODM_RTL8710B) {
-		bb_swing = odm_get_bb_reg(p_dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
+		for (i = 0; i < OFDM_TABLE_SIZE; i++) {
+			table_value = ofdm_swing_table_new[i];
 
-		p_swing_table = ofdm_swing_table_new;
-		swing_table_size = OFDM_TABLE_SIZE;
+			if (table_value >= 0x100000)
+				table_value >>= 22;
+			if (bb_swing == table_value)
+				break;
+		}
 	} else {
-		bb_swing = PHY_GetTxBBSwing_8812A(adapter, p_hal_data->CurrentBandType, RF_PATH_A);
-		p_swing_table = tx_scaling_table_jaguar;
-		swing_table_size = TXSCALE_TABLE_SIZE;
-	}
+		bb_swing = PHY_GetTxBBSwing_8812A(adapter, hal_data->CurrentBandType, RF_PATH_A);
 
-	for (i = 0; i < swing_table_size; ++i) {
-		u32 table_value = p_swing_table[i];
+		for (i = 0; i < TXSCALE_TABLE_SIZE; i++) {
+			table_value = tx_scaling_table_jaguar[i];
 
-		if (table_value >= 0x100000)
-			table_value >>= 22;
-		if (bb_swing == table_value)
-			break;
+			if (bb_swing == table_value)
+				break;
+		}
 	}
+
 	return i;
 }
 
 u8
 get_cck_swing_index(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 
 	u8			i = 0;
 	u32			bb_cck_swing;
 
-	if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8723B ||
-	    p_dm->support_ic_type == ODM_RTL8192E) {
-		bb_cck_swing = odm_read_1byte(p_dm, 0xa22);
+	if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+	    dm->support_ic_type == ODM_RTL8192E) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
 
 		for (i = 0; i < CCK_TABLE_SIZE; i++) {
 			if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
 				break;
 		}
-	} else if (p_dm->support_ic_type == ODM_RTL8703B) {
-		bb_cck_swing = odm_read_1byte(p_dm, 0xa22);
+	} else if (dm->support_ic_type == ODM_RTL8703B) {
+		bb_cck_swing = odm_read_1byte(dm, 0xa22);
 
 		for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
 			if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
@@ -543,44 +592,44 @@ get_cck_swing_index(
 
 void
 odm_txpowertracking_thermal_meter_init(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8 default_swing_index = get_swing_index(p_dm);
-	u8 default_cck_swing_index = get_cck_swing_index(p_dm);
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	u8 default_swing_index = get_swing_index(dm);
+	u8 default_cck_swing_index = get_cck_swing_index(dm);
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+	void		*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 	u8			p = 0;
 
-	if (*(p_dm->p_mp_mode) == false)
-		p_rf_calibrate_info->txpowertrack_control = true;
+	if (*(dm->mp_mode) == false)
+		cali_info->txpowertrack_control = true;
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 #ifdef CONFIG_RTL8188E
 	{
-		p_rf_calibrate_info->is_txpowertracking = true;
-		p_rf_calibrate_info->tx_powercount = 0;
-		p_rf_calibrate_info->is_txpowertracking_init = false;
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
 
-		if (*(p_dm->p_mp_mode) == false)
-			p_rf_calibrate_info->txpowertrack_control = true;
+		if (*(dm->mp_mode) == false)
+			cali_info->txpowertrack_control = true;
 
-		MSG_8192C("p_dm txpowertrack_control = %d\n", p_rf_calibrate_info->txpowertrack_control);
+		MSG_8192C("dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
 	}
 #else
 	{
-		struct _ADAPTER		*adapter = p_dm->adapter;
-		HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-		struct dm_priv	*pdmpriv = &p_hal_data->dmpriv;
+		void		*adapter = dm->adapter;
+		HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+		struct dm_priv	*pdmpriv = &hal_data->dmpriv;
 
 		pdmpriv->is_txpowertracking = true;
 		pdmpriv->tx_powercount = 0;
 		pdmpriv->is_txpowertracking_init = false;
 
-		if (*(p_dm->p_mp_mode) == false)
+		if (*(dm->mp_mode) == false)
 			pdmpriv->txpowertrack_control = true;
 
 		MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
@@ -590,71 +639,76 @@ odm_txpowertracking_thermal_meter_init(
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 #ifdef RTL8188E_SUPPORT
 	{
-		p_rf_calibrate_info->is_txpowertracking = true;
-		p_rf_calibrate_info->tx_powercount = 0;
-		p_rf_calibrate_info->is_txpowertracking_init = false;
-		p_rf_calibrate_info->txpowertrack_control = true;
+		cali_info->is_txpowertracking = true;
+		cali_info->tx_powercount = 0;
+		cali_info->is_txpowertracking_init = false;
+		cali_info->txpowertrack_control = true;
 	}
 #endif
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #if (MP_DRIVER == 1)
-	p_rf_calibrate_info->txpowertrack_control = false;
+	cali_info->txpowertrack_control = false;
 #else
-	p_rf_calibrate_info->txpowertrack_control = true;
+	cali_info->txpowertrack_control = true;
 #endif
 #else
-	p_rf_calibrate_info->txpowertrack_control = true;
+	cali_info->txpowertrack_control = true;
 #endif
 
-	p_rf_calibrate_info->thermal_value		= p_hal_data->eeprom_thermal_meter;
-	p_rf_calibrate_info->thermal_value_iqk	= p_hal_data->eeprom_thermal_meter;
-	p_rf_calibrate_info->thermal_value_lck	= p_hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value		= hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_iqk	= hal_data->eeprom_thermal_meter;
+	cali_info->thermal_value_lck	= hal_data->eeprom_thermal_meter;
 
-	if (p_rf_calibrate_info->default_bb_swing_index_flag != true) {
+	if (cali_info->default_bb_swing_index_flag != true) {
 		/*The index of "0 dB" in SwingTable.*/
-		if (p_dm->support_ic_type == ODM_RTL8188E || p_dm->support_ic_type == ODM_RTL8723B ||
-		    p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type == ODM_RTL8703B) {
-			p_rf_calibrate_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
-			p_rf_calibrate_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
-		} else if (p_dm->support_ic_type == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
-			p_rf_calibrate_info->default_ofdm_index = 28;							/*OFDM: -1dB*/
-			p_rf_calibrate_info->default_cck_index = 20;							/*CCK:-6dB*/
-		} else if (p_dm->support_ic_type == ODM_RTL8723D) {			 /*add by zhaohe  2015-10-27*/
-			p_rf_calibrate_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
-			p_rf_calibrate_info->default_cck_index = 28;							/*CCK:   -6dB*/
+		if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
+		    dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8703B ||
+		    dm->support_ic_type == ODM_RTL8821) {
+			cali_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
+			cali_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
+		} else if (dm->support_ic_type == ODM_RTL8188F) {          /*add by Mingzhi.Guo  2015-03-23*/
+			cali_info->default_ofdm_index = 28;							/*OFDM: -1dB*/
+			cali_info->default_cck_index = 20;							/*CCK:-6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8723D) {			 /*add by zhaohe  2015-10-27*/
+			cali_info->default_ofdm_index = 28;						 	   /*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;							/*CCK:   -6dB*/
 			/* JJ ADD 20161014 */
-		} else if (p_dm->support_ic_type == ODM_RTL8710B) {			
-			p_rf_calibrate_info->default_ofdm_index = 28;					/*OFDM: -1dB*/
-			p_rf_calibrate_info->default_cck_index = 28;					/*CCK:   -6dB*/
+		} else if (dm->support_ic_type == ODM_RTL8710B) {			
+			cali_info->default_ofdm_index = 28;					/*OFDM: -1dB*/
+			cali_info->default_cck_index = 28;					/*CCK:   -6dB*/
+		/*Winnita add 20170828*/
+		} else if (dm->support_ic_type == ODM_RTL8192F) {			
+			cali_info->default_ofdm_index = 30;					/*OFDM: 0dB*/
+			cali_info->default_cck_index = 28;					/*CCK:   -6dB*/
 		} else {
-			p_rf_calibrate_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
-			p_rf_calibrate_info->default_cck_index = 24;
+			cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
+			cali_info->default_cck_index = 24;
 		}
-		p_rf_calibrate_info->default_bb_swing_index_flag = true;
+		cali_info->default_bb_swing_index_flag = true;
 	}
 
-	p_rf_calibrate_info->bb_swing_idx_cck_base = p_rf_calibrate_info->default_cck_index;
-	p_rf_calibrate_info->CCK_index = p_rf_calibrate_info->default_cck_index;
+	cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
+	cali_info->CCK_index = cali_info->default_cck_index;
 
 	for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
-		p_rf_calibrate_info->bb_swing_idx_ofdm_base[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->OFDM_index[p] = p_rf_calibrate_info->default_ofdm_index;
-		p_rf_calibrate_info->delta_power_index[p] = 0;
-		p_rf_calibrate_info->delta_power_index_last[p] = 0;
-		p_rf_calibrate_info->power_index_offset[p] = 0;
-		p_rf_calibrate_info->kfree_offset[p] = 0;
+		cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
+		cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
+		cali_info->delta_power_index[p] = 0;
+		cali_info->delta_power_index_last[p] = 0;
+		cali_info->power_index_offset[p] = 0;
+		cali_info->kfree_offset[p] = 0;
 	}
-	p_rf_calibrate_info->modify_tx_agc_value_ofdm = 0;
-	p_rf_calibrate_info->modify_tx_agc_value_cck = 0;
-
+	cali_info->modify_tx_agc_value_ofdm = 0;
+	cali_info->modify_tx_agc_value_cck = 0;
+	cali_info->tm_trigger = 0;
 }
 
 
 void
 odm_txpowertracking_check(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
 
@@ -664,18 +718,18 @@ odm_txpowertracking_check(
 	/* HW dynamic mechanism. */
 #endif
 
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	switch	(p_dm->support_platform) {
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	switch	(dm->support_platform) {
 	case	ODM_WIN:
-		odm_txpowertracking_check_mp(p_dm);
+		odm_txpowertracking_check_mp(dm);
 		break;
 
 	case	ODM_CE:
-		odm_txpowertracking_check_ce(p_dm);
+		odm_txpowertracking_check_ce(dm);
 		break;
 
 	case	ODM_AP:
-		odm_txpowertracking_check_ap(p_dm);
+		odm_txpowertracking_check_ap(dm);
 		break;
 
 	default:
@@ -686,33 +740,33 @@ odm_txpowertracking_check(
 
 void
 odm_txpowertracking_check_ce(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _hal_rf_				*p_rf = &(p_dm->rf_table);
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct _hal_rf_				*rf = &(dm->rf_table);
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	void	*adapter = dm->adapter;
 #if ((RTL8188F_SUPPORT == 1))
 	rtl8192c_odm_check_txpowertracking(adapter);
 #endif
 
 #if (RTL8188E_SUPPORT == 1)
 
-	if (!(p_rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
 		return;
 
-	if (!p_rf_calibrate_info->tm_trigger) {
-		odm_set_rf_reg(p_dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
+	if (!cali_info->tm_trigger) {
+		odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
 		/*DBG_8192C("Trigger 92C Thermal Meter!!\n");*/
 
-		p_rf_calibrate_info->tm_trigger = 1;
+		cali_info->tm_trigger = 1;
 		return;
 
 	} else {
 		/*DBG_8192C("Schedule TxPowerTracking direct call!!\n");*/
 		odm_txpowertracking_callback_thermal_meter_8188e(adapter);
-		p_rf_calibrate_info->tm_trigger = 0;
+		cali_info->tm_trigger = 0;
 	}
 #endif
 #endif
@@ -720,17 +774,17 @@ odm_txpowertracking_check_ce(
 
 void
 odm_txpowertracking_check_mp(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	void	*adapter = dm->adapter;
 
-	if (*p_dm->p_is_fcs_mode_enable)
+	if (*dm->is_fcs_mode_enable)
 		return;
 
-	if (odm_check_power_status(p_dm) == false) {
+	if (odm_check_power_status(dm) == false) {
 		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status return false\n"));
 		return;
 	}
@@ -748,7 +802,7 @@ odm_txpowertracking_check_mp(
 
 void
 odm_txpowertracking_check_ap(
-	void		*p_dm_void
+	void		*dm_void
 )
 {
 	return;
@@ -759,34 +813,34 @@ odm_txpowertracking_check_ap(
 
 void
 odm_txpowertracking_direct_call(
-	struct _ADAPTER		*adapter
+	void		*adapter
 )
 {
-	HAL_DATA_TYPE		*p_hal_data	= GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT			*p_dm = &p_hal_data->DM_OutSrc;
+	HAL_DATA_TYPE		*hal_data	= GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct			*dm = &hal_data->DM_OutSrc;
 
 	odm_txpowertracking_callback_thermal_meter(adapter);
 }
 
 void
 odm_txpowertracking_thermal_meter_check(
-	struct _ADAPTER		*adapter
+	void		*adapter
 )
 {
 	static u8			tm_trigger = 0;
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT	*p_dm = &(pHalData->DM_OutSrc);
-	struct _hal_rf_			*p_rf = &(p_dm->rf_table);
+	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct	*dm = &(pHalData->DM_OutSrc);
+	struct _hal_rf_			*rf = &(dm->rf_table);
 
-	if (!(p_rf->rf_supportability & HAL_RF_TX_PWR_TRACK)) {
+	if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK)) {
 		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
-			("===>odm_txpowertracking_thermal_meter_check(),p_mgnt_info->is_txpowertracking is false, return!!\n"));
+			("===>odm_txpowertracking_thermal_meter_check(),mgnt_info->is_txpowertracking is false, return!!\n"));
 		return;
 	}
 
 	if (!tm_trigger) {
-		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_8192E(adapter) ||
-		    IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8814A(adapter) || IS_HARDWARE_TYPE_8188F(adapter) || IS_HARDWARE_TYPE_8703B(adapter)
+		if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_8192E(adapter) || IS_HARDWARE_TYPE_8192F(adapter)
+		    ||IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8814A(adapter) || IS_HARDWARE_TYPE_8188F(adapter) || IS_HARDWARE_TYPE_8703B(adapter)
 		    || IS_HARDWARE_TYPE_8822B(adapter) || IS_HARDWARE_TYPE_8723D(adapter) || IS_HARDWARE_TYPE_8821C(adapter) || IS_HARDWARE_TYPE_8710B(adapter))/* JJ ADD 20161014 */
 			PHY_SetRFReg(adapter, RF_PATH_A, RF_T_METER_88E, BIT(17) | BIT(16), 0x03);
 		else
@@ -796,7 +850,9 @@ odm_txpowertracking_thermal_meter_check(
 
 		tm_trigger = 1;
 		return;
-	} else {
+	} else if (IS_HARDWARE_TYPE_8822C(adapter) || IS_HARDWARE_TYPE_8814B(adapter))
+		return;
+	else {
 		RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("Schedule TxPowerTracking direct call!!\n"));
 		odm_txpowertracking_direct_call(adapter);
 		tm_trigger = 0;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.h
index 89816b19049a..a059e6dcfe64 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_powertracking_win.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -13,10 +14,8 @@
  *
  *****************************************************************************/
 
-#ifndef	__PHYDMPOWERTRACKING_H__
-#define    __PHYDMPOWERTRACKING_H__
-
-#define HALRF_POWRTRACKING_VER	"1.1"
+#ifndef __HALRF_POWERTRACKING_H__
+#define __HALRF_POWERTRACKING_H__
 
 #define	DPK_DELTA_MAPPING_NUM	13
 #define	index_mapping_HP_NUM	15
@@ -32,13 +31,13 @@
 #define	CCK_TABLE_SIZE_88F	21
 /* JJ ADD 20161014 */
 #define	CCK_TABLE_SIZE_8710B   41
+#define	CCK_TABLE_SIZE_8192F   41
 
 
 #define	dm_check_txpowertracking	odm_txpowertracking_check
 
 #define IQK_MATRIX_SETTINGS_NUM	(14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
 #define	AVG_THERMAL_NUM		8
-#define	HP_THERMAL_NUM		8
 #define	iqk_matrix_reg_num	8
 #define	IQK_MAC_REG_NUM		4
 #define	IQK_ADDA_REG_NUM		16
@@ -59,6 +58,7 @@ extern	u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
 extern	u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
 /* JJ ADD 20161014 */
 extern	u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
+extern	u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
 
 extern  u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
 
@@ -68,33 +68,33 @@ static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4
 
 void
 odm_txpowertracking_check(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 void
 odm_txpowertracking_check_ap(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 void
 odm_txpowertracking_thermal_meter_init(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 void
 odm_txpowertracking_init(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 void
 odm_txpowertracking_check_mp(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 
 void
 odm_txpowertracking_check_ce(
-	void		*p_dm_void
+	void		*dm_void
 );
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
@@ -102,18 +102,18 @@ odm_txpowertracking_check_ce(
 
 void
 odm_txpowertracking_thermal_meter_check(
-	struct _ADAPTER		*adapter
+	void		*adapter
 );
 
 #endif
 
-struct _IQK_MATRIX_REGS_SETTING {
+struct iqk_matrix_regs_setting {
 	boolean	is_iqk_done;
 	s32		value[3][iqk_matrix_reg_num];
 	boolean	is_bw_iqk_result_saved[3];
 };
 
-struct odm_rf_calibration_structure {
+struct dm_rf_calibration_struct {
 	/* for tx power tracking */
 
 	u32	rega24; /* for TempCCK */
@@ -156,9 +156,7 @@ struct odm_rf_calibration_structure {
 	s8	xtal_offset;
 	s8	xtal_offset_last;
 
-	u8	thermal_value_hp[HP_THERMAL_NUM];
-	u8	thermal_value_hp_index;
-	struct _IQK_MATRIX_REGS_SETTING iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
+	struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
 	u8	delta_lck;
 	s8  bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
 	u8  delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
@@ -228,6 +226,7 @@ struct odm_rf_calibration_structure {
 	boolean			modify_tx_agc_flag_path_c;
 	boolean			modify_tx_agc_flag_path_d;
 	boolean			modify_tx_agc_flag_path_a_cck;
+	boolean			modify_tx_agc_flag_path_b_cck;
 
 	s8			kfree_offset[MAX_RF_PATH];
 
@@ -296,11 +295,9 @@ struct odm_rf_calibration_structure {
 	/*Add by Yuchen for Kfree Phydm*/
 	u8			reg_rf_kfree_enable;	/*for registry*/
 	u8			rf_kfree_enable;		/*for efuse enable check*/
-
-	HALMAC_PWR_TRACKING_OPTION	HALMAC_PWR_TRACKING_INFO;
 };
 
 
 
 
-#endif
+#endif	/*#ifndef __HALRF_POWER_TRACKING_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_psd.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_psd.c
new file mode 100644
index 000000000000..c5ed1902e29f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_psd.c
@@ -0,0 +1,429 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+u64 _sqrt(u64 x)
+{
+	u64 i = 0;
+	u64 j = x / 2 + 1;
+
+	while (i <= j) {
+		u64 mid = (i + j) / 2;
+
+		u64 sq = mid * mid;
+
+		if (sq == x)
+			return mid;
+		else if (sq < x)
+			i = mid + 1;
+		else
+			j = mid - 1;
+	}
+
+	return j;
+}
+
+u32 halrf_get_psd_data(
+	struct dm_struct *dm,
+	u32 point)
+{
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
+	u32 psd_val = 0, psd_reg, psd_report, psd_point, psd_start, i, delay_time;
+
+#if (DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+	if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO) {
+		if (psd->average == 0)
+			delay_time = 100;
+		else
+			delay_time = 0;
+	}
+#endif
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	if (dm->support_interface == ODM_ITRF_PCIE) {
+		if (psd->average == 0)
+			delay_time = 1000;
+		else
+			delay_time = 100;
+	}
+#endif
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
+		psd_reg = R_0x910;
+		psd_report = R_0xf44;
+	} else {
+		psd_reg = R_0x808;
+		psd_report = R_0x8b4;
+	}
+
+	if (dm->support_ic_type & ODM_RTL8710B) {
+		psd_point = 0xeffffc00;
+		psd_start = 0x10000000;
+	} else {
+		psd_point = 0xffbffc00;
+		psd_start = 0x00400000;
+	}
+
+	psd_val = odm_get_bb_reg(dm, psd_reg, MASKDWORD);
+
+	psd_val &= psd_point;
+	psd_val |= point;
+
+	odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
+
+	psd_val |= psd_start;
+
+	odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
+
+	for (i = 0; i < delay_time; i++)
+		ODM_delay_us(1);
+
+	psd_val = odm_get_bb_reg(dm, psd_report, MASKDWORD);
+
+	if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8710B)) {
+		psd_val &= MASKL3BYTES;
+		psd_val = psd_val / 32;
+	} else {
+		psd_val &= MASKLWORD;
+	}
+
+	return psd_val;
+}
+
+void halrf_psd(
+	struct dm_struct *dm,
+	u32 point,
+	u32 start_point,
+	u32 stop_point,
+	u32 average)
+{
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
+
+	u32 i = 0, j = 0, k = 0;
+	u32 psd_reg, avg_org, point_temp, average_tmp, mode;
+	u64 data_tatal = 0, data_temp[64] = {0};
+
+	psd->buf_size = 256;
+
+	mode = average >> 16;
+	
+	if (mode == 1)
+		average_tmp = average & 0xffff;
+	else if (mode == 2)
+		average_tmp = 1;
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+		psd_reg = R_0x910;
+	else
+		psd_reg = R_0x808;
+
+#if 0
+	dbg_print("[PSD]point=%d, start_point=%d, stop_point=%d, average=%d, average_tmp=%d, buf_size=%d\n",
+		point, start_point, stop_point, average, average_tmp, psd->buf_size);
+#endif
+
+	for (i = 0; i < psd->buf_size; i++)
+		psd->psd_data[i] = 0;
+
+	if (dm->support_ic_type & ODM_RTL8710B)
+		avg_org = odm_get_bb_reg(dm, psd_reg, 0x30000);
+	else
+		avg_org = odm_get_bb_reg(dm, psd_reg, 0x3000);
+
+	if (mode == 1) {
+		if (dm->support_ic_type & ODM_RTL8710B)
+			odm_set_bb_reg(dm, psd_reg, 0x30000, 0x1);
+		else
+			odm_set_bb_reg(dm, psd_reg, 0x3000, 0x1);
+	}
+
+#if 0
+	if (avg_temp == 0)
+		avg = 1;
+	else if (avg_temp == 1)
+		avg = 8;
+	else if (avg_temp == 2)
+		avg = 16;
+	else if (avg_temp == 3)
+		avg = 32;
+#endif
+
+	i = start_point;
+	while (i < stop_point) {
+		data_tatal = 0;
+
+		if (i >= point)
+			point_temp = i - point;
+		else
+			point_temp = i;
+
+		for (k = 0; k < average_tmp; k++) {
+			data_temp[k] = halrf_get_psd_data(dm, point_temp);
+			data_tatal = data_tatal + (data_temp[k] * data_temp[k]);
+
+#if 0
+			if ((k % 20) == 0)
+				dbg_print("\n ");
+
+			dbg_print("0x%x ", data_temp[k]);
+#endif
+		}
+#if 0
+		/*dbg_print("\n");*/
+#endif
+
+		data_tatal = ((data_tatal * 100) / average_tmp);
+		psd->psd_data[j] = (u32)_sqrt(data_tatal);
+
+		i++;
+		j++;
+	}
+
+#if 0
+	for (i = 0; i < psd->buf_size; i++) {
+		if ((i % 20) == 0)
+			dbg_print("\n ");
+
+		dbg_print("0x%x ", psd->psd_data[i]);
+	}
+	dbg_print("\n\n");
+#endif
+
+	if (dm->support_ic_type & ODM_RTL8710B)
+		odm_set_bb_reg(dm, psd_reg, 0x30000, avg_org);
+	else
+		odm_set_bb_reg(dm, psd_reg, 0x3000, avg_org);
+}
+
+u32 halrf_get_iqk_psd_data(
+	struct dm_struct *dm,
+	u32 point)
+{
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
+	u32 psd_val, psd_val1, psd_val2, psd_point, i, delay_time;
+
+#if (DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+	if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO) {
+		delay_time = 0;
+	}
+#endif
+#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	if (dm->support_interface == ODM_ITRF_PCIE) {
+		delay_time = 150;
+	}
+#endif
+	psd_point = odm_get_bb_reg(dm, R_0x1b2c, MASKDWORD);
+
+	psd_point &= 0xF000FFFF;
+
+	point &= 0xFFF;
+
+	psd_point = psd_point | (point << 16);
+
+	odm_set_bb_reg(dm, R_0x1b2c, MASKDWORD, psd_point);
+
+	odm_set_bb_reg(dm, R_0x1b34, MASKDWORD, 0x1);
+
+	odm_set_bb_reg(dm, R_0x1b34, MASKDWORD, 0x0);
+
+	for (i = 0; i < delay_time; i++)
+		ODM_delay_us(1);
+
+	odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x00250001);
+
+	psd_val1 = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
+
+	psd_val1 = (psd_val1 & 0x07FF0000) >> 16;
+
+	odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x002e0001);
+
+	psd_val2 = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
+
+	psd_val = (psd_val1 << 21) + (psd_val2 >> 11);
+
+	return psd_val;
+}
+
+void halrf_iqk_psd(
+	struct dm_struct *dm,
+	u32 point,
+	u32 start_point,
+	u32 stop_point,
+	u32 average)
+{
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
+
+	u32 i = 0, j = 0, k = 0;
+	u32 psd_reg, avg_org, point_temp, average_tmp, mode;
+	u64 data_tatal = 0, data_temp[64] = {0};
+	s32 point_8814B;
+
+	psd->buf_size = 256;
+
+	mode = average >> 16;
+	
+	if (mode == 1)
+		average_tmp = average & 0xffff;
+	else if (mode == 2) {
+		if (dm->support_ic_type & ODM_RTL8814B)
+			average_tmp = average & 0xffff;
+		else
+			average_tmp = 1;
+	}
+#if 0
+	DbgPrint("[PSD]point=%d, start_point=%d, stop_point=%d, average=0x%x, average_tmp=%d, buf_size=%d, mode=%d\n",
+		point, start_point, stop_point, average, average_tmp, psd->buf_size, mode);
+#endif
+
+	for (i = 0; i < psd->buf_size; i++)
+		psd->psd_data[i] = 0;
+
+	i = start_point;
+	while (i < stop_point) {
+		data_tatal = 0;
+
+		if (i >= point)
+			point_temp = i - point;
+		else
+		{
+			if (dm->support_ic_type & ODM_RTL8814B)
+			{
+				point_8814B = i -point -1;
+				point_temp = point_8814B & 0xfff;
+			}
+			else
+				point_temp = i;
+		}
+
+		for (k = 0; k < average_tmp; k++) {
+			data_temp[k] = halrf_get_iqk_psd_data(dm, point_temp);
+			/*data_tatal = data_tatal + (data_temp[k] * data_temp[k]);*/
+			data_tatal = data_tatal + data_temp[k];
+
+#if 0
+			if ((k % 20) == 0)
+				DbgPrint("\n ");
+
+			DbgPrint("0x%x ", data_temp[k]);
+#endif
+		}
+
+		/*data_tatal = ((data_tatal * 100) / average_tmp);*/
+		/*psd->psd_data[j] = (u32)_sqrt(data_tatal);*/
+
+		psd->psd_data[j] = (u32)((data_tatal * 10) / average_tmp);
+
+		i++;
+		j++;
+	}
+
+#if 0
+	DbgPrint("\n [iqk psd]psd result:\n");
+
+	for (i = 0; i < psd->buf_size; i++) {
+		if ((i % 20) == 0)
+			DbgPrint("\n ");
+
+		DbgPrint("0x%x ", psd->psd_data[i]);
+	}
+	DbgPrint("\n\n");
+#endif
+}
+
+
+enum rt_status
+halrf_psd_init(
+	struct dm_struct *dm)
+{
+	enum rt_status ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
+
+	if (psd->psd_progress) {
+		ret_status = RT_STATUS_PENDING;
+	} else {
+		psd->psd_progress = 1;
+		if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8814B))
+			halrf_iqk_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
+		else
+			halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
+		psd->psd_progress = 0;
+	}
+
+	return ret_status;
+}
+
+enum rt_status
+halrf_psd_query(
+	struct dm_struct *dm,
+	u32 *outbuf,
+	u32 buf_size)
+{
+	enum rt_status ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
+
+	if (psd->psd_progress)
+		ret_status = RT_STATUS_PENDING;
+	else
+		PlatformMoveMemory(outbuf, psd->psd_data, 0x400);
+
+	return ret_status;
+}
+
+enum rt_status
+halrf_psd_init_query(
+	struct dm_struct *dm,
+	u32 *outbuf,
+	u32 point,
+	u32 start_point,
+	u32 stop_point,
+	u32 average,
+	u32 buf_size)
+{
+	enum rt_status ret_status = RT_STATUS_SUCCESS;
+	struct _hal_rf_ *rf = &(dm->rf_table);
+	struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
+
+	psd->point = point;
+	psd->start_point = start_point;
+	psd->stop_point = stop_point;
+	psd->average = average;
+
+	if (psd->psd_progress) {
+		ret_status = RT_STATUS_PENDING;
+	} else {
+		psd->psd_progress = 1;
+		halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
+		PlatformMoveMemory(outbuf, psd->psd_data, 0x400);
+		psd->psd_progress = 0;
+	}
+
+	return ret_status;
+}
+
+#endif /*#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_psd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_psd.h
new file mode 100644
index 000000000000..cf525aec8429
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_psd.h
@@ -0,0 +1,53 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __HALRF_PSD_H__
+#define __HALRF_PSD_H__
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+struct _halrf_psd_data {
+	u32 point;
+	u32 start_point;
+	u32 stop_point;
+	u32 average;
+	u32 buf_size;
+	u32 psd_data[256];
+	u32 psd_progress;
+};
+
+enum rt_status
+halrf_psd_init(
+	struct dm_struct *dm);
+
+enum rt_status
+halrf_psd_query(
+	struct dm_struct *dm,
+	u32 *outbuf,
+	u32 buf_size);
+
+enum rt_status
+halrf_psd_init_query(
+	struct dm_struct *dm,
+	u32 *outbuf,
+	u32 point,
+	u32 start_point,
+	u32 stop_point,
+	u32 average,
+	u32 buf_size);
+
+#endif /*#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)*/
+#endif /*#__HALRF_PSD_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.c
index 9acc8e9e6885..45aec82a4ebe 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.c
@@ -1,292 +1,301 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#include "mp_precomp.h"
-#include "phydm_precomp.h"
-
-
-
-void odm_bub_sort(pu4Byte data, u4Byte n)
-{
-	int i, j, temp, sp;
-	
-	for (i = n - 1;i >= 0;i--) {
-		sp = 1;
-		for (j = 0;j < i;j++) {
-			if (data[j] < data[j + 1]) {
-				temp = data[j];
-				data[j] = data[j + 1];
-				data[j + 1] = temp;
-				sp = 0;
-			}
-		}
-		if (sp == 1)
-			break;          
-	}
-}
-
-
-#if (RTL8197F_SUPPORT == 1)
-
-u4Byte
-odm_tx_gain_gap_psd_8197f(
-	void	*p_dm_void,
-	u1Byte	rf_path,
-	u4Byte	rf56
-)
-{
-	PDM_ODM_T	p_dm_odm = (PDM_ODM_T)p_dm_void;
-	
-	u1Byte i, j;
-	u4Byte psd_vaule[5], psd_avg_time = 5, psd_vaule_temp;
-	
-	u4Byte iqk_ctl_addr[2][6] = {{0xe30, 0xe34, 0xe50, 0xe54, 0xe38, 0xe3c},
-								{0xe50, 0xe54, 0xe30, 0xe34, 0xe58, 0xe5c}};
-	
-	u4Byte psd_finish_bit[2] = {0x04000000, 0x20000000};
-	u4Byte psd_fail_bit[2] = {0x08000000, 0x40000000};
-	
-	u4Byte psd_cntl_value[2][2] = {{0x38008c1c, 0x10008c1c},
-								   {0x38008c2c, 0x10008c2c}};
-	
-	u4Byte psd_report_addr[2] = {0xea0, 0xec0};
-	
-	odm_set_rf_reg(p_dm_odm, rf_path, 0xdf, bRFRegOffsetMask, 0x00e02);
-
-	ODM_delay_us(100);
-
-	odm_set_bb_reg(p_dm_odm, 0xe28, 0xffffffff, 0x0);
-	
-	odm_set_rf_reg(p_dm_odm, rf_path, 0x56, 0xfff, rf56);
-	while(rf56 != (odm_get_rf_reg(p_dm_odm, rf_path, 0x56, 0xfff)))
-		odm_set_rf_reg(p_dm_odm, rf_path, 0x56, 0xfff, rf56);
-
-	odm_set_bb_reg(p_dm_odm, 0xd94, 0xffffffff, 0x44FFBB44);
-	odm_set_bb_reg(p_dm_odm, 0xe70, 0xffffffff, 0x00400040);
-	odm_set_bb_reg(p_dm_odm, 0xc04, 0xffffffff, 0x6f005403);
-	odm_set_bb_reg(p_dm_odm, 0xc08, 0xffffffff, 0x000804e4);
-	odm_set_bb_reg(p_dm_odm, 0x874, 0xffffffff, 0x04203400);
-	odm_set_bb_reg(p_dm_odm, 0xe28, 0xffffffff, 0x80800000);
-
-	odm_set_bb_reg(p_dm_odm, iqk_ctl_addr[rf_path][0], 0xffffffff, psd_cntl_value[rf_path][0]);
-	odm_set_bb_reg(p_dm_odm, iqk_ctl_addr[rf_path][1], 0xffffffff, psd_cntl_value[rf_path][1]);
-	odm_set_bb_reg(p_dm_odm, iqk_ctl_addr[rf_path][2], 0xffffffff, psd_cntl_value[rf_path][0]);
-	odm_set_bb_reg(p_dm_odm, iqk_ctl_addr[rf_path][3], 0xffffffff, psd_cntl_value[rf_path][0]);
-	odm_set_bb_reg(p_dm_odm, iqk_ctl_addr[rf_path][4], 0xffffffff, 0x8215001F);
-	odm_set_bb_reg(p_dm_odm, iqk_ctl_addr[rf_path][5], 0xffffffff, 0x2805001F);
-	
-	odm_set_bb_reg(p_dm_odm, 0xe40, 0xffffffff, 0x81007C00);
-	odm_set_bb_reg(p_dm_odm, 0xe44, 0xffffffff, 0x81004800);
-	odm_set_bb_reg(p_dm_odm, 0xe4c, 0xffffffff, 0x0046a8d0);
-	
-
-	for (i = 0; i < psd_avg_time; i++) {
-			
-		for(j = 0; j < 1000 ; j++) {
-			odm_set_bb_reg(p_dm_odm, 0xe48, 0xffffffff, 0xfa005800);
-			odm_set_bb_reg(p_dm_odm, 0xe48, 0xffffffff, 0xf8005800);
-
-			while(!odm_get_bb_reg(p_dm_odm, 0xeac, psd_finish_bit[rf_path]));	/*wait finish bit*/
-
-			if (!odm_get_bb_reg(p_dm_odm, 0xeac, psd_fail_bit[rf_path])) {	/*check fail bit*/
-				
-				psd_vaule[i] = odm_get_bb_reg(p_dm_odm, psd_report_addr[rf_path], 0xffffffff);
-				
-				if (psd_vaule[i] > 0xffff)
-					break;
-			}
-		}
-			
-		
-
-		ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-			("[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x time=%d psd_vaule=0x%x\n",
-			odm_get_rf_reg(p_dm_odm, rf_path, 0x0, 0xff),
-			rf56, odm_get_rf_reg(p_dm_odm, rf_path, 0x56, 0xfff), j, psd_vaule[i]));
-	}
-
-	odm_bub_sort(psd_vaule, psd_avg_time);
-
-	psd_vaule_temp = psd_vaule[(UINT)(psd_avg_time / 2)];
-
-	odm_set_bb_reg(p_dm_odm, 0xd94, 0xffffffff, 0x44BBBB44);
-	odm_set_bb_reg(p_dm_odm, 0xe70, 0xffffffff, 0x80408040);
-	odm_set_bb_reg(p_dm_odm, 0xc04, 0xffffffff, 0x6f005433);
-	odm_set_bb_reg(p_dm_odm, 0xc08, 0xffffffff, 0x000004e4);
-	odm_set_bb_reg(p_dm_odm, 0x874, 0xffffffff, 0x04003400);
-	odm_set_bb_reg(p_dm_odm, 0xe28, 0xffffffff, 0x00000000);
-
-	ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-		("[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x psd_vaule_temp=0x%x\n",
-		odm_get_rf_reg(p_dm_odm, rf_path, 0x0, 0xff),
-		rf56, odm_get_rf_reg(p_dm_odm, rf_path, 0x56, 0xfff), psd_vaule_temp));
-	
-	odm_set_rf_reg(p_dm_odm, rf_path, 0xdf, bRFRegOffsetMask, 0x00602);
-
-	return psd_vaule_temp;
-
-}
-
-
-
-void
-odm_tx_gain_gap_calibration_8197f(
-	void	*p_dm_void
-)
-{
-	PDM_ODM_T	p_dm_odm = (PDM_ODM_T)p_dm_void;
-
-	u1Byte rf_path, rf0_idx, rf0_idx_current, rf0_idx_next, i, delta_gain_retry = 3;
-	
-	s1Byte delta_gain_gap_pre, delta_gain_gap[2][11];
-	u4Byte rf56_current, rf56_next, psd_value_current, psd_value_next;
-	u4Byte psd_gap, rf56_current_temp[2][11];
-	s4Byte rf33[2][11];
-
-	memset(rf33, 0x0, sizeof(rf33));
-
-	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
-
-		if (rf_path == RF_PATH_A)
-			odm_set_bb_reg(p_dm_odm, 0x88c, (BIT(21) | BIT(20)), 0x3);	/*disable 3-wire*/
-		else if (rf_path == RF_PATH_B)
-			odm_set_bb_reg(p_dm_odm, 0x88c, (BIT(23) | BIT(22)), 0x3);	/*disable 3-wire*/
-		
-		ODM_delay_us(100);
-
-		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
-			
-			rf0_idx_current = 3 * (rf0_idx - 1) + 1;
-			odm_set_rf_reg(p_dm_odm, rf_path, 0x0, 0xff, rf0_idx_current);
-			ODM_delay_us(100);
-			rf56_current_temp[rf_path][rf0_idx] = odm_get_rf_reg(p_dm_odm, rf_path, 0x56, 0xfff);
-			rf56_current = rf56_current_temp[rf_path][rf0_idx];
-			
-			rf0_idx_next = 3 * rf0_idx + 1;
-			odm_set_rf_reg(p_dm_odm, rf_path, 0x0, 0xff, rf0_idx_next);
-			ODM_delay_us(100);
-			rf56_next= odm_get_rf_reg(p_dm_odm, rf_path, 0x56, 0xfff);
-
-			ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-				("[TGGC] rf56_current[%d][%d]=0x%x rf56_next[%d][%d]=0x%x\n",
-				rf_path, rf0_idx, rf56_current,  rf_path, rf0_idx, rf56_next));
-
-			if ((rf56_current >> 5) == (rf56_next >> 5)) {
-				delta_gain_gap[rf_path][rf0_idx] = 0;
-				
-				ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-					("[TGGC] rf56_current[11:5] == rf56_next[%d][%d][11:5]=0x%x delta_gain_gap[%d][%d]=%d\n",
-					rf_path, rf0_idx, (rf56_next >> 5), rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx]));
-			} else {
-				ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-					("[TGGC] rf56_current[%d][%d][11:5]=0x%x != rf56_next[%d][%d][11:5]=0x%x\n",
-					rf_path, rf0_idx, (rf56_current >> 5), rf_path, rf0_idx, (rf56_next >> 5)));
-
-				
-				for (i = 0; i < delta_gain_retry; i++) {
-					psd_value_current = odm_tx_gain_gap_psd_8197f(p_dm_odm, rf_path, rf56_current);
-
-					psd_value_next = odm_tx_gain_gap_psd_8197f(p_dm_odm, rf_path, rf56_next - 2);
-
-					psd_gap = psd_value_next / (psd_value_current / 1000);
-
-#if 0
-					if (psd_gap > 1413)
-						delta_gain_gap[rf_path][rf0_idx] = 1;
-					else if (psd_gap > 1122)
-						delta_gain_gap[rf_path][rf0_idx] = 0;
-					else
-						delta_gain_gap[rf_path][rf0_idx] = -1;
-#endif
-
-					if (psd_gap > 1445)
-						delta_gain_gap[rf_path][rf0_idx] = 1;
-					else if (psd_gap > 1096)
-						delta_gain_gap[rf_path][rf0_idx] = 0;
-					else
-						delta_gain_gap[rf_path][rf0_idx] = -1;
-
-					if (i == 0)
-						delta_gain_gap_pre = delta_gain_gap[rf_path][rf0_idx];
-
-					ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-						("[TGGC] psd_value_current=0x%x psd_value_next=0x%x psd_value_next/psd_value_current=%d delta_gain_gap[%d][%d]=%d\n",
-						psd_value_current, psd_value_next, psd_gap, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx]));
-
-					if ((i == 0) && (delta_gain_gap[rf_path][rf0_idx] == 0)) {
-						break;
-					}
-					else {
-						if (delta_gain_gap_pre != delta_gain_gap[rf_path][rf0_idx]) {
-							delta_gain_gap[rf_path][rf0_idx] = 0;
-
-							ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-								("[TGGC] delta_gain_gap_pre(%d) != delta_gain_gap[%d][%d](%d) time=%d\n",
-								delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i));
-
-							break;
-						} else {
-							ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-								("[TGGC] delta_gain_gap_pre(%d) == delta_gain_gap[%d][%d](%d) time=%d\n",
-								delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i));
-						}
-					}
-				}
-				
-			}
-
-		}
-
-		if (rf_path == RF_PATH_A)
-			odm_set_bb_reg(p_dm_odm, 0x88c, (BIT(21) | BIT(20)), 0x0);	/*enable 3-wire*/
-		else if (rf_path == RF_PATH_B)
-			odm_set_bb_reg(p_dm_odm, 0x88c, (BIT(23) | BIT(22)), 0x0);	/*enable 3-wire*/
-		
-		ODM_delay_us(100);
-
-	}
-	
-	/*odm_set_bb_reg(p_dm_odm, 0x88c, (BIT(23) | BIT(22) | BIT(21) | BIT(20)), 0x0);*/	/*enable 3-wire*/
-
-	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
-
-		odm_set_rf_reg(p_dm_odm, rf_path, 0xef, bRFRegOffsetMask, 0x00100);
-		
-		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
-			
-			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + (rf56_current_temp[rf_path][rf0_idx] & 0x1f); 
-			
-			for (i = rf0_idx; i <= 10; i++)
-				rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + delta_gain_gap[rf_path][i];
-
-			if (rf33[rf_path][rf0_idx] >= 0x1d)
-				rf33[rf_path][rf0_idx] = 0x1d;
-			else if (rf33[rf_path][rf0_idx] <= 0x2)
-				rf33[rf_path][rf0_idx] = 0x2;
-
-			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + ((rf0_idx - 1) * 0x4000) + (rf56_current_temp[rf_path][rf0_idx] & 0xfffe0);
-
-			ODM_RT_TRACE(p_dm_odm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, 
-				("[TGGC] rf56[%d][%d]=0x%05x rf33[%d][%d]=0x%05x\n", rf_path, rf0_idx, rf56_current_temp[rf_path][rf0_idx], rf_path, rf0_idx, rf33[rf_path][rf0_idx]));
-
-			odm_set_rf_reg(p_dm_odm, rf_path, 0x33, bRFRegOffsetMask, rf33[rf_path][rf0_idx]);
-		}
-		
-		odm_set_rf_reg(p_dm_odm, rf_path, 0xef, bRFRegOffsetMask, 0x00000);
-	}
-
-}
-#endif
-
-
-void
-odm_tx_gain_gap_calibration(
-	void	*p_dm_void
-)
-{
-	PDM_ODM_T	p_dm_odm = (PDM_ODM_T)p_dm_void;
-
-	#if (RTL8197F_SUPPORT == 1)
-		if (p_dm_odm->SupportICType & ODM_RTL8197F)
-			odm_tx_gain_gap_calibration_8197f(p_dm_void);
-	#endif
-
-}
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+void odm_bub_sort(u32 *data, u32 n)
+{
+	int i, j, temp, sp;
+
+	for (i = n - 1; i >= 0; i--) {
+		sp = 1;
+		for (j = 0; j < i; j++) {
+			if (data[j] < data[j + 1]) {
+				temp = data[j];
+				data[j] = data[j + 1];
+				data[j + 1] = temp;
+				sp = 0;
+			}
+		}
+		if (sp == 1)
+			break;
+	}
+}
+
+#if (RTL8197F_SUPPORT == 1)
+
+u4Byte
+odm_tx_gain_gap_psd_8197f(
+	void *dm_void,
+	u1Byte rf_path,
+	u4Byte rf56)
+{
+	PDM_ODM_T dm = (PDM_ODM_T)dm_void;
+
+	u1Byte i, j;
+	u4Byte psd_vaule[5], psd_avg_time = 5, psd_vaule_temp;
+
+	u4Byte iqk_ctl_addr[2][6] = {{0xe30, 0xe34, 0xe50, 0xe54, 0xe38, 0xe3c},
+				     {0xe50, 0xe54, 0xe30, 0xe34, 0xe58, 0xe5c}};
+
+	u4Byte psd_finish_bit[2] = {0x04000000, 0x20000000};
+	u4Byte psd_fail_bit[2] = {0x08000000, 0x40000000};
+
+	u4Byte psd_cntl_value[2][2] = {{0x38008c1c, 0x10008c1c},
+				       {0x38008c2c, 0x10008c2c}};
+
+	u4Byte psd_report_addr[2] = {0xea0, 0xec0};
+
+	odm_set_rf_reg(dm, rf_path, RF_0xdf, bRFRegOffsetMask, 0x00e02);
+
+	ODM_delay_us(100);
+
+	odm_set_bb_reg(dm, R_0xe28, 0xffffffff, 0x0);
+
+	odm_set_rf_reg(dm, rf_path, RF_0x56, 0xfff, rf56);
+	while (rf56 != (odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff)))
+		odm_set_rf_reg(dm, rf_path, RF_0x56, 0xfff, rf56);
+
+	odm_set_bb_reg(dm, R_0xd94, 0xffffffff, 0x44FFBB44);
+	odm_set_bb_reg(dm, R_0xe70, 0xffffffff, 0x00400040);
+	odm_set_bb_reg(dm, R_0xc04, 0xffffffff, 0x6f005403);
+	odm_set_bb_reg(dm, R_0xc08, 0xffffffff, 0x000804e4);
+	odm_set_bb_reg(dm, R_0x874, 0xffffffff, 0x04203400);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffffff, 0x80800000);
+
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][0], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][1], 0xffffffff, psd_cntl_value[rf_path][1]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][2], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][3], 0xffffffff, psd_cntl_value[rf_path][0]);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][4], 0xffffffff, 0x8215001F);
+	odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][5], 0xffffffff, 0x2805001F);
+
+	odm_set_bb_reg(dm, R_0xe40, 0xffffffff, 0x81007C00);
+	odm_set_bb_reg(dm, R_0xe44, 0xffffffff, 0x81004800);
+	odm_set_bb_reg(dm, R_0xe4c, 0xffffffff, 0x0046a8d0);
+
+	for (i = 0; i < psd_avg_time; i++) {
+		for (j = 0; j < 1000; j++) {
+			odm_set_bb_reg(dm, R_0xe48, 0xffffffff, 0xfa005800);
+			odm_set_bb_reg(dm, R_0xe48, 0xffffffff, 0xf8005800);
+
+			while (!odm_get_bb_reg(dm, R_0xeac, psd_finish_bit[rf_path]))
+				; /*wait finish bit*/
+
+			if (!odm_get_bb_reg(dm, R_0xeac, psd_fail_bit[rf_path])) { /*check fail bit*/
+
+				psd_vaule[i] = odm_get_bb_reg(dm, psd_report_addr[rf_path], 0xffffffff);
+
+				if (psd_vaule[i] > 0xffff)
+					break;
+			}
+		}
+
+		RF_DBG(dm, DBG_RF_IQK,
+		       "[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x time=%d psd_vaule=0x%x\n",
+		       odm_get_rf_reg(dm, rf_path, RF_0x0, 0xff), rf56,
+		       odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff), j,
+		       psd_vaule[i]);
+	}
+
+	odm_bub_sort(psd_vaule, psd_avg_time);
+
+	psd_vaule_temp = psd_vaule[(UINT)(psd_avg_time / 2)];
+
+	odm_set_bb_reg(dm, R_0xd94, 0xffffffff, 0x44BBBB44);
+	odm_set_bb_reg(dm, R_0xe70, 0xffffffff, 0x80408040);
+	odm_set_bb_reg(dm, R_0xc04, 0xffffffff, 0x6f005433);
+	odm_set_bb_reg(dm, R_0xc08, 0xffffffff, 0x000004e4);
+	odm_set_bb_reg(dm, R_0x874, 0xffffffff, 0x04003400);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffffff, 0x00000000);
+
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x psd_vaule_temp=0x%x\n",
+	       odm_get_rf_reg(dm, rf_path, RF_0x0, 0xff), rf56,
+	       odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff), psd_vaule_temp);
+
+	odm_set_rf_reg(dm, rf_path, RF_0xdf, bRFRegOffsetMask, 0x00602);
+
+	return psd_vaule_temp;
+}
+
+void odm_tx_gain_gap_calibration_8197f(
+	void *dm_void)
+{
+	PDM_ODM_T dm = (PDM_ODM_T)dm_void;
+
+	u1Byte rf_path, rf0_idx, rf0_idx_current, rf0_idx_next, i, delta_gain_retry = 3;
+
+	s1Byte delta_gain_gap_pre, delta_gain_gap[2][11];
+	u4Byte rf56_current, rf56_next, psd_value_current, psd_value_next;
+	u4Byte psd_gap, rf56_current_temp[2][11];
+	s4Byte rf33[2][11];
+
+	memset(rf33, 0x0, sizeof(rf33));
+
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
+		if (rf_path == RF_PATH_A)
+			odm_set_bb_reg(dm, R_0x88c, (BIT(21) | BIT(20)), 0x3); /*disable 3-wire*/
+		else if (rf_path == RF_PATH_B)
+			odm_set_bb_reg(dm, R_0x88c, (BIT(23) | BIT(22)), 0x3); /*disable 3-wire*/
+
+		ODM_delay_us(100);
+
+		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
+			rf0_idx_current = 3 * (rf0_idx - 1) + 1;
+			odm_set_rf_reg(dm, rf_path, RF_0x0, 0xff, rf0_idx_current);
+			ODM_delay_us(100);
+			rf56_current_temp[rf_path][rf0_idx] = odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff);
+			rf56_current = rf56_current_temp[rf_path][rf0_idx];
+
+			rf0_idx_next = 3 * rf0_idx + 1;
+			odm_set_rf_reg(dm, rf_path, RF_0x0, 0xff, rf0_idx_next);
+			ODM_delay_us(100);
+			rf56_next = odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff);
+
+			RF_DBG(dm, DBG_RF_IQK,
+			       "[TGGC] rf56_current[%d][%d]=0x%x rf56_next[%d][%d]=0x%x\n",
+			       rf_path, rf0_idx, rf56_current, rf_path, rf0_idx,
+			       rf56_next);
+
+			if ((rf56_current >> 5) == (rf56_next >> 5)) {
+				delta_gain_gap[rf_path][rf0_idx] = 0;
+
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[TGGC] rf56_current[11:5] == rf56_next[%d][%d][11:5]=0x%x delta_gain_gap[%d][%d]=%d\n",
+				       rf_path, rf0_idx, (rf56_next >> 5),
+				       rf_path, rf0_idx,
+				       delta_gain_gap[rf_path][rf0_idx]);
+
+				continue;
+			}
+
+			RF_DBG(dm, DBG_RF_IQK,
+			       "[TGGC] rf56_current[%d][%d][11:5]=0x%x != rf56_next[%d][%d][11:5]=0x%x\n",
+			       rf_path, rf0_idx, (rf56_current >> 5), rf_path,
+			       rf0_idx, (rf56_next >> 5));
+
+			for (i = 0; i < delta_gain_retry; i++) {
+				psd_value_current = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_current);
+
+				psd_value_next = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_next - 2);
+
+				psd_gap = psd_value_next / (psd_value_current / 1000);
+
+#if 0
+				if (psd_gap > 1413)
+					delta_gain_gap[rf_path][rf0_idx] = 1;
+				else if (psd_gap > 1122)
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+				else
+					delta_gain_gap[rf_path][rf0_idx] = -1;
+#endif
+
+				if (psd_gap > 1445)
+					delta_gain_gap[rf_path][rf0_idx] = 1;
+				else if (psd_gap > 1096)
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+				else
+					delta_gain_gap[rf_path][rf0_idx] = -1;
+
+				if (i == 0)
+					delta_gain_gap_pre = delta_gain_gap[rf_path][rf0_idx];
+
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[TGGC] psd_value_current=0x%x psd_value_next=0x%x psd_value_next/psd_value_current=%d delta_gain_gap[%d][%d]=%d\n",
+				       psd_value_current, psd_value_next,
+				       psd_gap, rf_path, rf0_idx,
+				       delta_gain_gap[rf_path][rf0_idx]);
+
+				if (i == 0 && delta_gain_gap[rf_path][rf0_idx] == 0)
+					break;
+
+				if (delta_gain_gap_pre != delta_gain_gap[rf_path][rf0_idx]) {
+					delta_gain_gap[rf_path][rf0_idx] = 0;
+
+					RF_DBG(dm, DBG_RF_IQK, "[TGGC] delta_gain_gap_pre(%d) != delta_gain_gap[%d][%d](%d) time=%d\n",
+					       delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i);
+
+					break;
+				}
+
+				RF_DBG(dm, DBG_RF_IQK,
+				       "[TGGC] delta_gain_gap_pre(%d) == delta_gain_gap[%d][%d](%d) time=%d\n",
+				       delta_gain_gap_pre, rf_path, rf0_idx,
+				       delta_gain_gap[rf_path][rf0_idx], i);
+			}
+		}
+
+		if (rf_path == RF_PATH_A)
+			odm_set_bb_reg(dm, R_0x88c, (BIT(21) | BIT(20)), 0x0); /*enable 3-wire*/
+		else if (rf_path == RF_PATH_B)
+			odm_set_bb_reg(dm, R_0x88c, (BIT(23) | BIT(22)), 0x0); /*enable 3-wire*/
+
+		ODM_delay_us(100);
+	}
+
+#if 0
+	/*odm_set_bb_reg(dm, R_0x88c, (BIT(23) | BIT(22) | BIT(21) | BIT(20)), 0x0);*/ /*enable 3-wire*/
+#endif
+
+	for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
+		odm_set_rf_reg(dm, rf_path, RF_0xef, bRFRegOffsetMask, 0x00100);
+
+		for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
+			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + (rf56_current_temp[rf_path][rf0_idx] & 0x1f);
+
+			for (i = rf0_idx; i <= 10; i++)
+				rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + delta_gain_gap[rf_path][i];
+
+			if (rf33[rf_path][rf0_idx] >= 0x1d)
+				rf33[rf_path][rf0_idx] = 0x1d;
+			else if (rf33[rf_path][rf0_idx] <= 0x2)
+				rf33[rf_path][rf0_idx] = 0x2;
+
+			rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + ((rf0_idx - 1) * 0x4000) + (rf56_current_temp[rf_path][rf0_idx] & 0xfffe0);
+
+			RF_DBG(dm, DBG_RF_IQK,
+			       "[TGGC] rf56[%d][%d]=0x%05x rf33[%d][%d]=0x%05x\n",
+			       rf_path, rf0_idx,
+			       rf56_current_temp[rf_path][rf0_idx], rf_path,
+			       rf0_idx, rf33[rf_path][rf0_idx]);
+
+			odm_set_rf_reg(dm, rf_path, RF_0x33, bRFRegOffsetMask, rf33[rf_path][rf0_idx]);
+		}
+
+		odm_set_rf_reg(dm, rf_path, RF_0xef, bRFRegOffsetMask, 0x00000);
+	}
+}
+#endif
+
+void odm_tx_gain_gap_calibration(void *dm_void)
+{
+	PDM_ODM_T dm = (PDM_ODM_T)dm_void;
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->SupportICType & ODM_RTL8197F)
+		odm_tx_gain_gap_calibration_8197f(dm_void);
+#endif
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.h
index df5446e43ff3..bafa6d3f813a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/halrf_txgapcal.h
@@ -1,6 +1,32 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-void
-odm_tx_gain_gap_calibration(
-	void	*p_dm_void
-);
-
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __HALRF_TXGAPCAL_H__
+#define __HALRF_TXGAPCAL_H__
+
+void odm_tx_gain_gap_calibration(void *dm_void);
+
+#endif /*__HALRF_TXGAPCAL_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.c
index 8440ade94eb1..2b391b784935 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -15,75 +16,63 @@
 
 #include "mp_precomp.h"
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#if RT_PLATFORM==PLATFORM_MACOSX
-	#include "phydm_precomp.h"
-	#else
-	#include "../phydm_precomp.h"
-	#endif
+#if RT_PLATFORM == PLATFORM_MACOSX
+#include "phydm_precomp.h"
+#else
+#include "../phydm_precomp.h"
+#endif
 #else
 #include "../../phydm_precomp.h"
 #endif
 
-
 #if (RTL8723D_SUPPORT == 1)
 
 /*---------------------------Define Local Constant---------------------------*/
 /*IQK*/
-#define IQK_DELAY_TIME_8723D	10
+#define IQK_DELAY_TIME_8723D 10
 
 /* 2010/04/25 MH Define the max tx power tracking tx agc power.*/
-#define		ODM_TXPWRTRACK_MAX_IDX_8723D		6
-
-#define     PATH_S1                         0
-#define     idx_0xc94                       0
-#define     idx_0xc80                       1
-#define     idx_0xc4c                       2
-
-#define     idx_0xc14                       0
-#define     idx_0xca0                       1
-
+#define ODM_TXPWRTRACK_MAX_IDX_8723D 6
 
-#define     PATH_S0                         1
-#define     idx_0xcd0                       0
-#define     idx_0xcd4                       1
+#define PATH_S1 0
+#define idx_0xc94 0
+#define idx_0xc80 1
+#define idx_0xc4c 2
 
-#define     idx_0xcd8                       0
-#define     idx_0xcdc                       1
+#define idx_0xc14 0
+#define idx_0xca0 1
 
-#define     KEY                             0
-#define     VAL                             1
+#define PATH_S0 1
+#define idx_0xcd0 0
+#define idx_0xcd4 1
 
+#define idx_0xcd8 0
+#define idx_0xcdc 1
 
+#define KEY 0
+#define VAL 1
 
 /*---------------------------Define Local Constant---------------------------*/
 
-
 /* Tx Power Tracking*/
 
-
-void set_iqk_matrix_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		OFDM_index,
-	u8		rf_path,
-	s32		iqk_result_x,
-	s32		iqk_result_y
-)
+void set_iqk_matrix_8723d(struct dm_struct *dm, u8 OFDM_index, u8 rf_path,
+			  s32 iqk_result_x, s32 iqk_result_y)
 {
-	s32			ele_A = 0, ele_D = 0, ele_C = 0, value32;
-	s32			ele_A_ext = 0, ele_C_ext = 0, ele_D_ext = 0;
+	s32 ele_A = 0, ele_D = 0, ele_C = 0, value32;
+	s32 ele_A_ext = 0, ele_C_ext = 0, ele_D_ext = 0;
 
 	if (OFDM_index >= OFDM_TABLE_SIZE)
 		OFDM_index = OFDM_TABLE_SIZE - 1;
 	else if (OFDM_index < 0)
 		OFDM_index = 0;
 
-	if ((iqk_result_x != 0) && (*(p_dm->p_band_type) == ODM_BAND_2_4G)) {
-
+	if (iqk_result_x != 0 && (*dm->band_type == ODM_BAND_2_4G)) {
 		/* new element D */
 		ele_D = (ofdm_swing_table_new[OFDM_index] & 0xFFC00000) >> 22;
 		ele_D_ext = (((iqk_result_x * ele_D) >> 7) & 0x01);
 		/* new element A */
-		if ((iqk_result_x & 0x00000200) != 0)		/* consider minus */
+		if ((iqk_result_x & 0x00000200) != 0) /* consider minus */
 			iqk_result_x = iqk_result_x | 0xFFFFFC00;
 		ele_A = ((iqk_result_x * ele_D) >> 8) & 0x000003FF;
 		ele_A_ext = ((iqk_result_x * ele_D) >> 7) & 0x1;
@@ -98,30 +87,30 @@ void set_iqk_matrix_8723d(
 			/* write new elements A, C, D to regC80, regC94, reg0xc4c, and element B is always 0 */
 			/* write 0xc80 */
 			value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
-			odm_set_bb_reg(p_dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, value32);
+			odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, value32);
 			/* write 0xc94 */
 			value32 = (ele_C & 0x000003C0) >> 6;
-			odm_set_bb_reg(p_dm, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, value32);
+			odm_set_bb_reg(dm, R_0xc94, MASKH4BITS, value32);
 			/* write 0xc4c */
 			value32 = (ele_D_ext << 28) | (ele_A_ext << 31) | (ele_C_ext << 29);
-			value32 = (odm_get_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD) & (~(BIT(31) | BIT(29) | BIT(28)))) | value32;
-			odm_set_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD, value32);
+			value32 = (odm_get_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD) & (~(BIT(31) | BIT(29) | BIT(28)))) | value32;
+			odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD, value32);
 			break;
 
 		case RF_PATH_B:
-			/*wirte new elements A, C, D to regCd0 and regCd4, element B is always 0*/
+			/*write new elements A, C, D to regCd0 and regCd4, element B is always 0*/
 			value32 = ele_D;
-			odm_set_bb_reg(p_dm, 0xCd4, 0x007FE000, value32);
+			odm_set_bb_reg(dm, R_0xcd4, 0x007FE000, value32);
 
 			value32 = ele_C;
-			odm_set_bb_reg(p_dm, 0xCd4, 0x000007FE, value32);
+			odm_set_bb_reg(dm, R_0xcd4, 0x000007FE, value32);
 
 			value32 = ele_A;
-			odm_set_bb_reg(p_dm, 0xCd0, 0x000007FE, value32);
+			odm_set_bb_reg(dm, R_0xcd0, 0x000007FE, value32);
 
-			odm_set_bb_reg(p_dm, 0xCd4, BIT(12), ele_D_ext);
-			odm_set_bb_reg(p_dm, 0xCd0, BIT(0), ele_A_ext);
-			odm_set_bb_reg(p_dm, 0xCd4, BIT(0), ele_C_ext);
+			odm_set_bb_reg(dm, R_0xcd4, BIT(12), ele_D_ext);
+			odm_set_bb_reg(dm, R_0xcd0, BIT(0), ele_A_ext);
+			odm_set_bb_reg(dm, R_0xcd4, BIT(0), ele_C_ext);
 			break;
 		default:
 			break;
@@ -129,73 +118,69 @@ void set_iqk_matrix_8723d(
 	} else {
 		switch (rf_path) {
 		case RF_PATH_A:
-			odm_set_bb_reg(p_dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_new[OFDM_index]);
-			odm_set_bb_reg(p_dm, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, 0x00);
-			value32 = odm_get_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD) & (~(BIT(31) | BIT(29) | BIT(28)));
-			odm_set_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD, value32);
+			odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_new[OFDM_index]);
+			odm_set_bb_reg(dm, R_0xc94, MASKH4BITS, 0x00);
+			value32 = odm_get_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD) & (~(BIT(31) | BIT(29) | BIT(28)));
+			odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, MASKDWORD, value32);
 			break;
 
 		case RF_PATH_B:
 			/*image S1:c80 to S0:Cd0 and Cd4*/
-			odm_set_bb_reg(p_dm, 0xcd0, 0x000007FE, ofdm_swing_table_new[OFDM_index] & 0x000003FF);
-			odm_set_bb_reg(p_dm, 0xcd0, 0x0007E000, (ofdm_swing_table_new[OFDM_index] & 0x0000FC00) >> 10);
-			odm_set_bb_reg(p_dm, 0xcd4, 0x0000007E, (ofdm_swing_table_new[OFDM_index] & 0x003F0000) >> 16);
-			odm_set_bb_reg(p_dm, 0xcd4, 0x007FE000, (ofdm_swing_table_new[OFDM_index] & 0xFFC00000) >> 22);
+			odm_set_bb_reg(dm, R_0xcd0, 0x000007FE, ofdm_swing_table_new[OFDM_index] & 0x000003FF);
+			odm_set_bb_reg(dm, R_0xcd0, 0x0007E000, (ofdm_swing_table_new[OFDM_index] & 0x0000FC00) >> 10);
+			odm_set_bb_reg(dm, R_0xcd4, 0x0000007E, (ofdm_swing_table_new[OFDM_index] & 0x003F0000) >> 16);
+			odm_set_bb_reg(dm, R_0xcd4, 0x007FE000, (ofdm_swing_table_new[OFDM_index] & 0xFFC00000) >> 22);
 
-			odm_set_bb_reg(p_dm, 0xcd4, 0x00000780, 0x00);
+			odm_set_bb_reg(dm, R_0xcd4, 0x00000780, 0x00);
 
-			odm_set_bb_reg(p_dm, 0xcd4, BIT(12), 0x0);
-			odm_set_bb_reg(p_dm, 0xcd4, BIT(0), 0x0);
-			odm_set_bb_reg(p_dm, 0xcd0, BIT(0), 0x0);
+			odm_set_bb_reg(dm, R_0xcd4, BIT(12), 0x0);
+			odm_set_bb_reg(dm, R_0xcd4, BIT(0), 0x0);
+			odm_set_bb_reg(dm, R_0xcd0, BIT(0), 0x0);
 			break;
 		default:
 			break;
 		}
 	}
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("TxPwrTracking path %c: X = 0x%x, Y = 0x%x ele_A = 0x%x ele_C = 0x%x ele_D = 0x%x ele_A_ext = 0x%x ele_C_ext = 0x%x ele_D_ext = 0x%x\n",
-		(rf_path == RF_PATH_A ? 'A' : 'B'), (u32)iqk_result_x, (u32)iqk_result_y, (u32)ele_A, (u32)ele_C, (u32)ele_D, (u32)ele_A_ext, (u32)ele_C_ext, (u32)ele_D_ext));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "TxPwrTracking path %c: X = 0x%x, Y = 0x%x ele_A = 0x%x ele_C = 0x%x ele_D = 0x%x ele_A_ext = 0x%x ele_C_ext = 0x%x ele_D_ext = 0x%x\n",
+	       (rf_path == RF_PATH_A ? 'A' : 'B'), (u32)iqk_result_x,
+	       (u32)iqk_result_y, (u32)ele_A, (u32)ele_C, (u32)ele_D,
+	       (u32)ele_A_ext, (u32)ele_C_ext, (u32)ele_D_ext);
 }
 
-void
-set_cck_filter_coefficient_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		cck_swing_index
-)
+void set_cck_filter_coefficient_8723d(struct dm_struct *dm, u8 cck_swing_index)
 {
-	odm_set_bb_reg(p_dm, 0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[cck_swing_index]);
+	odm_set_bb_reg(dm, R_0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[cck_swing_index]);
 }
 
-void do_iqk_8723d(
-	void		*p_dm_void,
-	u8		delta_thermal_index,
-	u8		thermal_value,
-	u8		threshold
-)
+void do_iqk_8723d(void *dm_void, u8 delta_thermal_index, u8 thermal_value,
+		  u8 threshold)
 {
-	u32  is_bt_enable = 0;
+	u32 is_bt_enable = 0;
 
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (*(p_dm->p_mp_mode) == false)
-		is_bt_enable = odm_get_mac_reg(p_dm, 0xa8, MASKDWORD) & BIT(17);
+	if (!(*dm->mp_mode))
+		is_bt_enable = odm_get_mac_reg(dm, R_0xa8, MASKDWORD) & BIT(17);
 
 	if (is_bt_enable) {
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]Skip IQK because BT is enable\n"));
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]Skip IQK because BT is enable\n");
 		return;
-	} else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]Do IQK because BT is disable\n"));
+	}
+
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]Do IQK because BT is disable\n");
 
-	odm_reset_iqk_result(p_dm);
+	odm_reset_iqk_result(dm);
 
-	p_dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
+	dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
 
-	halrf_iqk_trigger(p_dm, false);
+	halrf_iqk_trigger(dm, false);
 }
 
 /*-----------------------------------------------------------------------------
  * Function:	odm_tx_pwr_track_set_pwr_8723d()
  *
- * Overview:	8723D change all channel tx power accordign to flag.
+ * Overview:	8723D change all channel tx power according to flag.
  *				OFDM & CCK are all different.
  *
  * Input:		NONE
@@ -208,65 +193,66 @@ void do_iqk_8723d(
  *	When		Who		Remark
  *	04/23/2012	MHC		Create version 0.
  *
- *---------------------------------------------------------------------------*/
-void
-odm_tx_pwr_track_set_pwr_8723d(
-	void		*p_dm_void,
-	enum pwrtrack_method	method,
-	u8				rf_path,
-	u8				channel_mapped_index
-)
+ *---------------------------------------------------------------------------
+ */
+void odm_tx_pwr_track_set_pwr_8723d(void *dm_void, enum pwrtrack_method method,
+				    u8 rf_path, u8 channel_mapped_index)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER			*adapter = p_dm->adapter;
-	//PHAL_DATA_TYPE			p_hal_data = GET_HAL_DATA(adapter);
-	struct odm_rf_calibration_structure			*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	struct _hal_rf_ *p_rf = &(p_dm->rf_table);
-	u8					pwr_tracking_limit_ofdm = 30;
-	u8					pwr_tracking_limit_cck = 40;
-	u8					tx_rate = 0xFF;
-	u8					final_ofdm_swing_index = 0;
-	u8					final_cck_swing_index = 0;
-	u8					i = 0;
-
-if (*(p_dm->p_mp_mode) == true) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+#if !((DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211))
+	struct _ADAPTER *adapter = dm->adapter;
+#endif
+#if 0
+	//PHAL_DATA_TYPE			hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+#endif
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	u8 pwr_tracking_limit_ofdm = 30;
+	u8 pwr_tracking_limit_cck = 40;
+	u8 tx_rate = 0xFF;
+	u8 final_ofdm_swing_index = 0;
+	u8 final_cck_swing_index = 0;
+
+	if (*dm->mp_mode) {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 #if (MP_DRIVER == 1)
-		PMPT_CONTEXT p_mpt_ctx = &(adapter->MptCtx);
+		PMPT_CONTEXT p_mpt_ctx = &adapter->MptCtx;
 
 		tx_rate = MptToMgntRate(p_mpt_ctx->MptRateIndex);
 #endif
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 #ifdef CONFIG_MP_INCLUDED
-		PMPT_CONTEXT p_mpt_ctx = &(adapter->mppriv.mpt_ctx);
+		PMPT_CONTEXT p_mpt_ctx = &adapter->mppriv.mpt_ctx;
 
 		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
 #endif
 #endif
 #endif
 	} else {
-		u16	rate	 = *(p_dm->p_forced_data_rate);
+		u16 rate = *dm->forced_data_rate;
 
 		if (!rate) { /*auto rate*/
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-			tx_rate = adapter->HalFunc.GetHwRateFromMRateHandler(p_dm->tx_rate);
+			tx_rate = ((PADAPTER)adapter)->HalFunc.GetHwRateFromMRateHandler(dm->tx_rate);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			tx_rate = dm->tx_rate;
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-			if (p_dm->number_linked_client != 0)
-				tx_rate = hw_rate_to_m_rate(p_dm->tx_rate);
+			if (dm->number_linked_client != 0)
+				tx_rate = hw_rate_to_m_rate(dm->tx_rate);
 			else
-				tx_rate = p_rf->p_rate_index;
+				tx_rate = rf->p_rate_index;
 #endif
-		} else   /*force rate*/
+		} else { /*force rate*/
 			tx_rate = (u8)rate;
+		}
 	}
 
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("===>ODM_TxPwrTrackSetPwr8723DA\n"));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "===>ODM_TxPwrTrackSetPwr8723DA\n");
 
 	if (tx_rate != 0xFF) {
 		/*CCK*/
-		if (((tx_rate >= MGN_1M) && (tx_rate <= MGN_5_5M)) || tx_rate == MGN_11M)
+		if ((tx_rate >= MGN_1M && tx_rate <= MGN_5_5M) || tx_rate == MGN_11M)
 			pwr_tracking_limit_cck = 40;
 		/*OFDM*/
 		else if ((tx_rate >= MGN_6M) && (tx_rate <= MGN_48M))
@@ -290,96 +276,97 @@ if (*(p_dm->p_mp_mode) == true) {
 			pwr_tracking_limit_ofdm = 34;
 
 		else
-			pwr_tracking_limit_ofdm =  p_rf_calibrate_info->default_ofdm_index;   /*Default OFDM index = 30 */
+			pwr_tracking_limit_ofdm = cali_info->default_ofdm_index; /*Default OFDM index = 30 */
 	}
 
 	if (method == TXAGC) {
-		u8	rf = 0;
-		u32	pwr = 0, tx_agc = 0;
-		//struct _ADAPTER *adapter = p_dm->adapter;
+		u32 pwr = 0, tx_agc = 0;
+		/*void *adapter = dm->adapter;*/
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("odm_TxPwrTrackSetPwr_8723D CH=%d\n", *(p_dm->p_channel)));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "odm_TxPwrTrackSetPwr_8723D CH=%d\n", *dm->channel);
 
-		p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path] = p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path];   /* Remnant index equal to aboslute compensate value. */
+		cali_info->remnant_ofdm_swing_idx[rf_path] = cali_info->absolute_ofdm_swing_idx[rf_path]; /* Remnant index equal to aboslute compensate value. */
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
 
 #if (MP_DRIVER != 1)
 #if 0
-		PHY_SetTxPowerLevelByPath8723D(adapter, *p_dm->p_channel, rf_path);   /* Using new set power function */
-		/* PHY_SetTxPowerLevel8723D(p_dm->adapter, *p_dm->p_channel); */
+		PHY_SetTxPowerLevelByPath8723D(adapter, *dm->channel, rf_path);   /* Using new set power function */
+		/* PHY_SetTxPowerLevel8723D(dm->adapter, *dm->channel); */
 #endif
-		p_rf_calibrate_info->modify_tx_agc_flag_path_a = true;
-		p_rf_calibrate_info->modify_tx_agc_flag_path_b = true;
-		p_rf_calibrate_info->modify_tx_agc_flag_path_a_cck = true;
+		cali_info->modify_tx_agc_flag_path_a = true;
+		cali_info->modify_tx_agc_flag_path_b = true;
+		cali_info->modify_tx_agc_flag_path_a_cck = true;
 		if (rf_path == RF_PATH_A) {
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, CCK);
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, OFDM);
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, HT_MCS0_MCS7);
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, HT_MCS8_MCS15);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, CCK);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, OFDM);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, HT_MCS0_MCS7);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, HT_MCS8_MCS15);
 		} else {
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, *p_dm->p_channel, CCK);
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, *p_dm->p_channel, OFDM);
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, *p_dm->p_channel, HT_MCS0_MCS7);
-			odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, *p_dm->p_channel, HT_MCS8_MCS15);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, *dm->channel, CCK);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, *dm->channel, OFDM);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, *dm->channel, HT_MCS0_MCS7);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, *dm->channel, HT_MCS8_MCS15);
 		}
 #else
 
 		if (rf_path == RF_PATH_A) {
 			/*CCK path S1*/
-			pwr = odm_get_bb_reg(p_dm, REG_TX_AGC_A_RATE18_06, 0xFF);
-			pwr += p_rf_calibrate_info->power_index_offset[RF_PATH_A];
-			odm_set_bb_reg(p_dm, REG_TX_AGC_A_CCK_1_MCS32, MASKBYTE1, pwr);
+			pwr = odm_get_bb_reg(dm, REG_TX_AGC_A_RATE18_06, 0xFF);
+			pwr += cali_info->power_index_offset[RF_PATH_A];
+			odm_set_bb_reg(dm, REG_TX_AGC_A_CCK_1_MCS32, MASKBYTE1, pwr);
 			tx_agc = (pwr << 16) | (pwr << 8) | (pwr);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0x00ffffff, tx_agc);
-			RT_DISP(FPHY, PHY_TXPWR, ("odm_tx_pwr_track_set_pwr_8723d: CCK Tx-rf(A) Power = 0x%x\n", tx_agc));
+			odm_set_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0x00ffffff, tx_agc);
+			RT_DISP(FPHY, PHY_TXPWR, ("%s: CCK Tx-rf(A) Power = 0x%x\n", __func__, tx_agc));
 
 			/*OFDM path S1*/
-			pwr = odm_get_bb_reg(p_dm, REG_TX_AGC_A_RATE18_06, 0xFF);
-			pwr += (p_rf_calibrate_info->bb_swing_idx_ofdm[RF_PATH_A] - p_rf_calibrate_info->bb_swing_idx_ofdm_base[RF_PATH_A]);
+			pwr = odm_get_bb_reg(dm, REG_TX_AGC_A_RATE18_06, 0xFF);
+			pwr += (cali_info->bb_swing_idx_ofdm[RF_PATH_A] - cali_info->bb_swing_idx_ofdm_base[RF_PATH_A]);
 			tx_agc = ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS11_MCS08, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS15_MCS12, MASKDWORD, tx_agc);
-			RT_DISP(FPHY, PHY_TXPWR, ("odm_tx_pwr_track_set_pwr_8723d: OFDM Tx-rf(A) Power = 0x%x\n", tx_agc));
+			odm_set_bb_reg(dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_MCS11_MCS08, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_A_MCS15_MCS12, MASKDWORD, tx_agc);
+			RT_DISP(FPHY, PHY_TXPWR, ("%s: OFDM Tx-rf(A) Power = 0x%x\n", __func__, tx_agc));
 		} else if (rf_path == RF_PATH_B) {
-
-			pwr = odm_get_bb_reg(p_dm, REG_TX_AGC_B_RATE18_06, 0xFF);
-			pwr += p_rf_calibrate_info->power_index_offset[RF_PATH_B];
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_CCK_1_55_MCS32, MASKBYTE3, pwr);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0xff000000, pwr);
-			RT_DISP(FPHY, PHY_TXPWR, ("odm_tx_pwr_track_set_pwr_8723d: CCK Tx-rf(B) Power = 0x%x\n", pwr));
-
-
-			pwr = odm_get_bb_reg(p_dm, REG_TX_AGC_B_RATE18_06, 0xFF);
-			pwr += (p_rf_calibrate_info->bb_swing_idx_ofdm[RF_PATH_B] - p_rf_calibrate_info->bb_swing_idx_ofdm_base[RF_PATH_B]);
+			pwr = odm_get_bb_reg(dm, REG_TX_AGC_B_RATE18_06, 0xFF);
+			pwr += cali_info->power_index_offset[RF_PATH_B];
+			odm_set_bb_reg(dm, REG_TX_AGC_B_CCK_1_55_MCS32, MASKBYTE3, pwr);
+			odm_set_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0xff000000, pwr);
+			RT_DISP(FPHY, PHY_TXPWR, ("%s: CCK Tx-rf(B) Power = 0x%x\n", __func__, pwr));
+
+			pwr = odm_get_bb_reg(dm, REG_TX_AGC_B_RATE18_06, 0xFF);
+			pwr += (cali_info->bb_swing_idx_ofdm[RF_PATH_B] - cali_info->bb_swing_idx_ofdm_base[RF_PATH_B]);
 			tx_agc = ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_RATE18_06, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_RATE54_24, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_MCS03_MCS00, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_MCS07_MCS04, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_MCS11_MCS08, MASKDWORD, tx_agc);
-			odm_set_bb_reg(p_dm, REG_TX_AGC_B_MCS15_MCS12, MASKDWORD, tx_agc);
-			RT_DISP(FPHY, PHY_TXPWR, ("odm_tx_pwr_track_set_pwr_8723d: OFDM Tx-rf(B) Power = 0x%x\n", tx_agc));
+			odm_set_bb_reg(dm, REG_TX_AGC_B_RATE18_06, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_B_RATE54_24, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_B_MCS03_MCS00, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_B_MCS07_MCS04, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_B_MCS11_MCS08, MASKDWORD, tx_agc);
+			odm_set_bb_reg(dm, REG_TX_AGC_B_MCS15_MCS12, MASKDWORD, tx_agc);
+			RT_DISP(FPHY, PHY_TXPWR, ("%s: OFDM Tx-rf(B) Power = 0x%x\n", __func__, tx_agc));
 		}
 #endif
 
 #endif
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-		/*phy_rf6052_set_cck_tx_power(p_dm->priv, *(p_dm->p_channel));
-		  phy_rf6052_set_ofdm_tx_power(p_dm->priv, *(p_dm->p_channel));*/
+/*phy_rf6052_set_cck_tx_power(dm->priv, *(dm->channel));
+		  phy_rf6052_set_ofdm_tx_power(dm->priv, *(dm->channel));*/
 #endif
 
 	} else if (method == BBSWING) {
-		final_ofdm_swing_index = p_rf_calibrate_info->default_ofdm_index + p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path];
-		final_cck_swing_index = p_rf_calibrate_info->default_cck_index + p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path];
+		final_ofdm_swing_index = cali_info->default_ofdm_index + cali_info->absolute_ofdm_swing_idx[rf_path];
+		final_cck_swing_index = cali_info->default_cck_index + cali_info->absolute_ofdm_swing_idx[rf_path];
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-			(" p_rf_calibrate_info->default_ofdm_index=%d,  p_rf_calibrate_info->DefaultCCKIndex=%d, p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path]=%d, p_rf_calibrate_info->remnant_cck_swing_idx=%d   rf_path = %d\n",
-			p_rf_calibrate_info->default_ofdm_index, p_rf_calibrate_info->default_cck_index, p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path], p_rf_calibrate_info->remnant_cck_swing_idx, rf_path));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       " cali_info->default_ofdm_index=%d,  cali_info->DefaultCCKIndex=%d, cali_info->absolute_ofdm_swing_idx[rf_path]=%d, cali_info->remnant_cck_swing_idx=%d   rf_path = %d\n",
+		       cali_info->default_ofdm_index,
+		       cali_info->default_cck_index,
+		       cali_info->absolute_ofdm_swing_idx[rf_path],
+		       cali_info->remnant_cck_swing_idx, rf_path);
 
 		/* Adjust BB swing by OFDM IQ matrix */
 		if (final_ofdm_swing_index >= pwr_tracking_limit_ofdm)
@@ -389,101 +376,117 @@ if (*(p_dm->p_mp_mode) == true) {
 
 		if (final_cck_swing_index >= CCK_TABLE_SIZE_8723D)
 			final_cck_swing_index = CCK_TABLE_SIZE_8723D - 1;
-		else if (p_rf_calibrate_info->bb_swing_idx_cck < 0)
+		else if (cali_info->bb_swing_idx_cck < 0)
 			final_cck_swing_index = 0;
 
-		set_iqk_matrix_8723d(p_dm, final_ofdm_swing_index, RF_PATH_A,
-			p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
-			p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+		set_iqk_matrix_8723d(dm, final_ofdm_swing_index, RF_PATH_A,
+				     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+				     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
 
-		set_iqk_matrix_8723d(p_dm, final_ofdm_swing_index, RF_PATH_B,
-			p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
-			p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
+		set_iqk_matrix_8723d(dm, final_ofdm_swing_index, RF_PATH_B,
+				     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
+				     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
 
-		set_cck_filter_coefficient_8723d(p_dm, final_cck_swing_index);
+		set_cck_filter_coefficient_8723d(dm, final_cck_swing_index);
 
-		p_rf_calibrate_info->modify_tx_agc_flag_path_a = true;
+		cali_info->modify_tx_agc_flag_path_a = true;
 
-		odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, CCK);
-		odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, OFDM);
-		odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, HT_MCS0_MCS7);
+		odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, CCK);
+		odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, OFDM);
+		odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, HT_MCS0_MCS7);
 
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("final_cck_swing_index=%d\n", final_cck_swing_index));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "final_cck_swing_index=%d\n",
+		       final_cck_swing_index);
 
 	} else if (method == MIX_MODE) {
-#if (MP_DRIVER == 1)
-		u32	tx_agc = 0;			  /*add by Mingzhi.Guo 2015-04-10*/
-		s32	pwr = 0;
+#if (0)  /*MP_DRIVER == 1*/
+		u32 tx_agc = 0; /*add by Mingzhi.Guo 2015-04-10*/
+		s32 pwr = 0;
 #endif
-		ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("p_dm->default_ofdm_index=%d,  p_dm->DefaultCCKIndex=%d, p_dm->absolute_ofdm_swing_idx[rf_path]=%d, rf_path = %d\n",
-			p_rf_calibrate_info->default_ofdm_index, p_rf_calibrate_info->default_cck_index, p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path], rf_path));
+		RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+		       "dm->default_ofdm_index=%d,  dm->DefaultCCKIndex=%d, dm->absolute_ofdm_swing_idx[rf_path]=%d, rf_path = %d\n",
+		       cali_info->default_ofdm_index,
+		       cali_info->default_cck_index,
+		       cali_info->absolute_ofdm_swing_idx[rf_path], rf_path);
 
-		final_ofdm_swing_index = p_rf_calibrate_info->default_ofdm_index + p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path];
+		final_ofdm_swing_index = cali_info->default_ofdm_index + cali_info->absolute_ofdm_swing_idx[rf_path];
 
 		if (rf_path == RF_PATH_A) {
-			final_cck_swing_index = p_rf_calibrate_info->default_cck_index + p_rf_calibrate_info->absolute_ofdm_swing_idx[rf_path];    /*CCK Follow path-A and lower CCK index means higher power.*/
+			final_cck_swing_index = cali_info->default_cck_index + cali_info->absolute_ofdm_swing_idx[rf_path]; /*CCK Follow path-A and lower CCK index means higher power.*/
 
 			if (final_ofdm_swing_index > pwr_tracking_limit_ofdm) {
-				p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index - pwr_tracking_limit_ofdm;
+				cali_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index - pwr_tracking_limit_ofdm;
 
-				set_iqk_matrix_8723d(p_dm, pwr_tracking_limit_ofdm, RF_PATH_A,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
-				set_iqk_matrix_8723d(p_dm, pwr_tracking_limit_ofdm, RF_PATH_B,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
-
-				p_rf_calibrate_info->modify_tx_agc_flag_path_a = true;
+				set_iqk_matrix_8723d(dm, pwr_tracking_limit_ofdm, RF_PATH_A,
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+				set_iqk_matrix_8723d(dm, pwr_tracking_limit_ofdm, RF_PATH_B,
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
 
+				cali_info->modify_tx_agc_flag_path_a = true;
 				/*Set tx_agc Page C{};*/
-				/*odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, OFDM);*/
-				/*	odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, HT_MCS0_MCS7);*/
+#if 0
+				/*odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, OFDM);*/
+				/*	odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, HT_MCS0_MCS7);*/
+#endif
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A Over BBSwing Limit, pwr_tracking_limit = %d, Remnant tx_agc value = %d\n", pwr_tracking_limit_ofdm, p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_A Over BBSwing Limit, pwr_tracking_limit = %d, Remnant tx_agc value = %d\n",
+				       pwr_tracking_limit_ofdm,
+				       cali_info->remnant_ofdm_swing_idx[rf_path]);
 			} else if (final_ofdm_swing_index < 0) {
-				p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index ;
+				cali_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index;
 
-				set_iqk_matrix_8723d(p_dm, 0, RF_PATH_A,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
-				set_iqk_matrix_8723d(p_dm, 0, RF_PATH_B,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
+				set_iqk_matrix_8723d(dm, 0, RF_PATH_A,
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+				set_iqk_matrix_8723d(dm, 0, RF_PATH_B,
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
 
-				p_rf_calibrate_info->modify_tx_agc_flag_path_a = true;
+				cali_info->modify_tx_agc_flag_path_a = true;
 
 				/*Set tx_agc Page C{};*/
-				/*odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, OFDM);*/
-				/*	odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, HT_MCS0_MCS7);*/
+#if 0
+				/*odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, OFDM);*/
+				/*	odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, HT_MCS0_MCS7);*/
+#endif
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A Lower then BBSwing lower bound  0, Remnant tx_agc value = %d\n", p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_A Lower then BBSwing lower bound  0, Remnant tx_agc value = %d\n",
+				       cali_info->remnant_ofdm_swing_idx[rf_path]);
 			} else {
-				set_iqk_matrix_8723d(p_dm, final_ofdm_swing_index, RF_PATH_A,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
-				set_iqk_matrix_8723d(p_dm, final_ofdm_swing_index, RF_PATH_B,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
+				set_iqk_matrix_8723d(dm, final_ofdm_swing_index, RF_PATH_A,
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][0],
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][1]);
+				set_iqk_matrix_8723d(dm, final_ofdm_swing_index, RF_PATH_B,
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
+						     cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A Compensate with BBSwing, final_ofdm_swing_index = %d\n", final_ofdm_swing_index));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_A Compensate with BBSwing, final_ofdm_swing_index = %d\n",
+				       final_ofdm_swing_index);
 
-				if (p_rf_calibrate_info->modify_tx_agc_flag_path_a) {
-					p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path] = 0;
+				if (cali_info->modify_tx_agc_flag_path_a) {
+					cali_info->remnant_ofdm_swing_idx[rf_path] = 0;
 
 					/*Set tx_agc Page C{};*/
-					/*	odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, OFDM );
-						odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, HT_MCS0_MCS7 );
-						odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, HT_MCS8_MCS15 );*/
+#if 0
+					/*	odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, OFDM );
+						odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, HT_MCS0_MCS7 );
+						odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, HT_MCS8_MCS15 );*/
+#endif
 
-					p_rf_calibrate_info->modify_tx_agc_flag_path_a = false;
+					cali_info->modify_tx_agc_flag_path_a = false;
 
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A p_dm->Modify_TxAGC_Flag = false\n"));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "******Path_A dm->Modify_TxAGC_Flag = false\n");
 				}
 			}
-#if (MP_DRIVER == 1)
-			if ((*(p_dm->p_mp_mode)) == 1) {
-				pwr = odm_get_bb_reg(p_dm, REG_TX_AGC_A_RATE18_06, 0xFF);
-				pwr += (p_rf_calibrate_info->remnant_ofdm_swing_idx[RF_PATH_A] - p_rf_calibrate_info->modify_tx_agc_value_ofdm);
+#if (0) /*MP_DRIVER == 1*/
+			if ((*dm->mp_mode) == 1) {
+				pwr = odm_get_bb_reg(dm, REG_TX_AGC_A_RATE18_06, 0xFF);
+				pwr += (cali_info->remnant_ofdm_swing_idx[RF_PATH_A] - cali_info->modify_tx_agc_value_ofdm);
 
 				if (pwr > 0x3F)
 					pwr = 0x3F;
@@ -491,138 +494,162 @@ if (*(p_dm->p_mp_mode) == true) {
 					pwr = 0;
 
 				tx_agc |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
-
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ODM_TxPwrTrackSetPwr8188F: OFDM Tx-rf(A) Power = 0x%x\n", tx_agc));
-
-			} else
+				odm_set_bb_reg(dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
+
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "ODM_TxPwrTrackSetPwr8188F: OFDM Tx-rf(A) Power = 0x%x\n",
+				       tx_agc);
+			}
 #endif
-			{
 
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, OFDM);
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, HT_MCS0_MCS7);
-			}
-			p_rf_calibrate_info->modify_tx_agc_value_ofdm = p_rf_calibrate_info->remnant_ofdm_swing_idx[RF_PATH_A] ;
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, OFDM);
+			odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, HT_MCS0_MCS7);
+			cali_info->modify_tx_agc_value_ofdm = cali_info->remnant_ofdm_swing_idx[RF_PATH_A];
 
 			if (final_cck_swing_index > pwr_tracking_limit_cck) {
-				p_rf_calibrate_info->remnant_cck_swing_idx = final_cck_swing_index - pwr_tracking_limit_cck;
+				cali_info->remnant_cck_swing_idx = final_cck_swing_index - pwr_tracking_limit_cck;
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A CCK Over Limit, pwr_tracking_limit_cck = %d, p_dm->remnant_cck_swing_idx  = %d\n", pwr_tracking_limit_cck, p_rf_calibrate_info->remnant_cck_swing_idx));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_A CCK Over Limit, pwr_tracking_limit_cck = %d, dm->remnant_cck_swing_idx  = %d\n",
+				       pwr_tracking_limit_cck,
+				       cali_info->remnant_cck_swing_idx);
 
 				/* Adjust BB swing by CCK filter coefficient*/
-				odm_set_bb_reg(p_dm, 0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[pwr_tracking_limit_cck]);
+				odm_set_bb_reg(dm, R_0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[pwr_tracking_limit_cck]);
 
-				p_rf_calibrate_info->modify_tx_agc_flag_path_a_cck = true;
+				cali_info->modify_tx_agc_flag_path_a_cck = true;
 
 				/*Set tx_agc Page C{};*/
-				/*	odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, CCK);
-					odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, CCK);*/
+#if 0
+				/*	odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, CCK);
+					odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, CCK);*/
+#endif
 
 			} else if (final_cck_swing_index < 0) {
-				p_rf_calibrate_info->remnant_cck_swing_idx = final_cck_swing_index;
-
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A CCK Under Limit, pwr_tracking_limit_cck = %d, p_dm->remnant_cck_swing_idx  = %d\n", 0, p_rf_calibrate_info->remnant_cck_swing_idx));
+				cali_info->remnant_cck_swing_idx = final_cck_swing_index;
 
-				odm_set_bb_reg(p_dm, 0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[0]);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_A CCK Under Limit, pwr_tracking_limit_cck = %d, dm->remnant_cck_swing_idx  = %d\n",
+				       0, cali_info->remnant_cck_swing_idx);
 
-				p_rf_calibrate_info->modify_tx_agc_flag_path_a_cck = true;
+				odm_set_bb_reg(dm, R_0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[0]);
 
+				cali_info->modify_tx_agc_flag_path_a_cck = true;
 
-				/*odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, CCK);
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, CCK);*/
+#if 0
+				/*odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, CCK);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, CCK);*/
+#endif
 
 			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A CCK Compensate with BBSwing, final_cck_swing_index = %d\n", final_cck_swing_index));
-
-				odm_set_bb_reg(p_dm, 0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[final_cck_swing_index]);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_A CCK Compensate with BBSwing, final_cck_swing_index = %d\n",
+				       final_cck_swing_index);
 
-				/*	if (p_rf_calibrate_info->modify_tx_agc_flag_path_a_cck) {*/
-				p_rf_calibrate_info->remnant_cck_swing_idx = 0;
+				odm_set_bb_reg(dm, R_0xab4, 0x000007FF, cck_swing_table_ch1_ch14_8723d[final_cck_swing_index]);
 
+#if 0
+				/*	if (cali_info->modify_tx_agc_flag_path_a_cck) {*/
+#endif
+				cali_info->remnant_cck_swing_idx = 0;
 
-				/*odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, p_hal_data->current_channel, CCK );
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, CCK );*/
+#if 0
+				/*odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, hal_data->current_channel, CCK );
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, CCK );*/
+#endif
 
-				p_rf_calibrate_info->modify_tx_agc_flag_path_a_cck = false;
+				cali_info->modify_tx_agc_flag_path_a_cck = false;
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_A p_dm->Modify_TxAGC_Flag_CCK = false\n"));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_A dm->Modify_TxAGC_Flag_CCK = false\n");
 			}
-#if (MP_DRIVER == 1)
-			if ((*(p_dm->p_mp_mode)) == 1) {
-				pwr = odm_get_bb_reg(p_dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, MASKBYTE1);
-				pwr += p_rf_calibrate_info->remnant_cck_swing_idx - p_rf_calibrate_info->modify_tx_agc_value_cck;
+#if (0) /*MP_DRIVER == 1*/
+			if ((*dm->mp_mode)) {
+				pwr = odm_get_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, MASKBYTE1);
+				pwr += cali_info->remnant_cck_swing_idx - cali_info->modify_tx_agc_value_cck;
 
 				if (pwr > 0x3F)
 					pwr = 0x3F;
 				else if (pwr < 0)
 					pwr = 0;
 
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_CCK_1_MCS32, MASKBYTE1, pwr);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_CCK_1_MCS32, MASKBYTE1, pwr);
 				tx_agc = (pwr << 16) | (pwr << 8) | (pwr);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0xffffff00, tx_agc);
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ODM_TxPwrTrackSetPwr8723D: CCK Tx-rf(A) Power = 0x%x\n", tx_agc));
+				odm_set_bb_reg(dm, REG_TX_AGC_B_CCK_11_A_CCK_2_11, 0xffffff00, tx_agc);
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "ODM_TxPwrTrackSetPwr8723D: CCK Tx-rf(A) Power = 0x%x\n",
+				       tx_agc);
 			} else
 #endif
 
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_A, *p_dm->p_channel, CCK);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_A, *dm->channel, CCK);
 
-			p_rf_calibrate_info->modify_tx_agc_value_cck = p_rf_calibrate_info->remnant_cck_swing_idx;
+			cali_info->modify_tx_agc_value_cck = cali_info->remnant_cck_swing_idx;
 		}
 #if 0
 		if (rf_path == RF_PATH_B) {
 			if (final_ofdm_swing_index > pwr_tracking_limit_ofdm) {
-				p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index - pwr_tracking_limit_ofdm;
+				cali_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index - pwr_tracking_limit_ofdm;
 
-				set_iqk_matrix_8723d(p_dm, pwr_tracking_limit_ofdm, RF_PATH_B,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
+				set_iqk_matrix_8723d(dm, pwr_tracking_limit_ofdm, RF_PATH_B,
+					cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
+					cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
 
-				p_rf_calibrate_info->modify_tx_agc_flag_path_a = true;
+				cali_info->modify_tx_agc_flag_path_a = true;
 
 
-				/*odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, OFDM);
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, HT_MCS0_MCS7);*/
+				/*odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, OFDM);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, HT_MCS0_MCS7);*/
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_B Over BBSwing Limit, pwr_tracking_limit = %d, Remnant tx_agc value = %d\n", pwr_tracking_limit_ofdm, p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_B Over BBSwing Limit, pwr_tracking_limit = %d, Remnant tx_agc value = %d\n",
+				       pwr_tracking_limit_ofdm,
+				       cali_info->remnant_ofdm_swing_idx[rf_path
+				       ]);
 			} else if (final_ofdm_swing_index < 0) {
-				p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index ;
+				cali_info->remnant_ofdm_swing_idx[rf_path] = final_ofdm_swing_index ;
 
-				set_iqk_matrix_8723d(p_dm, 0, RF_PATH_B,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
+				set_iqk_matrix_8723d(dm, 0, RF_PATH_B,
+					cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
+					cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
 
-				p_rf_calibrate_info->modify_tx_agc_flag_path_a = true;
+				cali_info->modify_tx_agc_flag_path_a = true;
 
 
-				/*odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, OFDM);
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, HT_MCS0_MCS7);*/
+				/*odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, OFDM);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, HT_MCS0_MCS7);*/
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_B Lower then BBSwing lower bound  0, Remnant tx_agc value = %d\n", p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path]));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_B Lower then BBSwing lower bound  0, Remnant tx_agc value = %d\n",
+				       cali_info->remnant_ofdm_swing_idx[rf_path
+				       ]);
 			} else {
-				set_iqk_matrix_8723d(p_dm, final_ofdm_swing_index, RF_PATH_B,
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
-					p_rf_calibrate_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
+				set_iqk_matrix_8723d(dm, final_ofdm_swing_index, RF_PATH_B,
+					cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][4],
+					cali_info->iqk_matrix_reg_setting[channel_mapped_index].value[0][5]);
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_B Compensate with BBSwing, final_ofdm_swing_index = %d\n", final_ofdm_swing_index));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "******Path_B Compensate with BBSwing, final_ofdm_swing_index = %d\n",
+				       final_ofdm_swing_index);
 
-				if (p_rf_calibrate_info->modify_tx_agc_flag_path_b) {
-					p_rf_calibrate_info->remnant_ofdm_swing_idx[rf_path] = 0;
+				if (cali_info->modify_tx_agc_flag_path_b) {
+					cali_info->remnant_ofdm_swing_idx[rf_path] = 0;
 
-					/*odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, OFDM);
-					odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, p_hal_data->current_channel, HT_MCS0_MCS7);*/
+					/*odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, OFDM);
+					odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, hal_data->current_channel, HT_MCS0_MCS7);*/
 
-					p_rf_calibrate_info->modify_tx_agc_flag_path_a = false;
+					cali_info->modify_tx_agc_flag_path_a = false;
 
-					ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("******Path_B p_dm->Modify_TxAGC_Flag = false\n"));
+					RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "******Path_B dm->Modify_TxAGC_Flag = false\n");
 				}
 			}
 #if (MP_DRIVER == 1)
-			if ((*(p_dm->p_mp_mode)) == 1) {
-				pwr = odm_get_bb_reg(p_dm, REG_TX_AGC_A_RATE18_06, 0xFF);
-				pwr += (p_rf_calibrate_info->remnant_ofdm_swing_idx[RF_PATH_B] - p_rf_calibrate_info->modify_tx_agc_value_ofdm);
+			if ((*dm->mp_mode) == 1) {
+				pwr = odm_get_bb_reg(dm, REG_TX_AGC_A_RATE18_06, 0xFF);
+				pwr += (cali_info->remnant_ofdm_swing_idx[RF_PATH_B] - cali_info->modify_tx_agc_value_ofdm);
 
 				if (pwr > 0x3F)
 					pwr = 0x3F;
@@ -630,285 +657,287 @@ if (*(p_dm->p_mp_mode) == true) {
 					pwr = 0;
 
 				tx_agc |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
-				odm_set_bb_reg(p_dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_RATE18_06, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_RATE54_24, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_MCS03_MCS00, MASKDWORD, tx_agc);
+				odm_set_bb_reg(dm, REG_TX_AGC_A_MCS07_MCS04, MASKDWORD, tx_agc);
 
-				ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("ODM_TxPwrTrackSetPwr8723D: OFDM Tx-rf(A) Power = 0x%x\n", tx_agc));
+				RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+				       "ODM_TxPwrTrackSetPwr8723D: OFDM Tx-rf(A) Power = 0x%x\n",
+				       tx_agc);
 
 			} else
 #endif
 			{
-
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, *p_dm->p_channel, OFDM);
-				odm_set_tx_power_index_by_rate_section(p_dm, RF_PATH_B, *p_dm->p_channel, HT_MCS0_MCS7);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, *dm->channel, OFDM);
+				odm_set_tx_power_index_by_rate_section(dm, RF_PATH_B, *dm->channel, HT_MCS0_MCS7);
 			}
-			p_rf_calibrate_info->modify_tx_agc_value_ofdm = p_rf_calibrate_info->remnant_ofdm_swing_idx[RF_PATH_B] ;
+			cali_info->modify_tx_agc_value_ofdm = cali_info->remnant_ofdm_swing_idx[RF_PATH_B] ;
 		}
 #endif
-	} else
+	} else {
 		return;
+	}
 }
 
-void
-get_delta_swing_table_8723d(
-	void		*p_dm_void,
-	u8 **temperature_up_a,
-	u8 **temperature_down_a,
-	u8 **temperature_up_b,
-	u8 **temperature_down_b
-)
+void get_delta_swing_table_8723d(void *dm_void, u8 **temperature_up_a,
+				 u8 **temperature_down_a, u8 **temperature_up_b,
+				 u8 **temperature_down_b)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER		*adapter		 = p_dm->adapter;
-	struct _hal_rf_ *p_rf = &(p_dm->rf_table);
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
-	u8			tx_rate			= 0xFF;
-	u8			channel		 = *p_dm->p_channel;
-
-	if (*(p_dm->p_mp_mode) == true) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+#if !((DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211))
+	struct _ADAPTER *adapter = dm->adapter;
+#endif
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	struct _hal_rf_ *rf = &dm->rf_table;
+	u8 tx_rate = 0xFF;
+	u8 channel = *dm->channel;
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};
+	static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11};
+#endif
+
+	if (*dm->mp_mode) {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 #if (MP_DRIVER == 1)
-		PMPT_CONTEXT p_mpt_ctx = &(adapter->MptCtx);
+		PMPT_CONTEXT p_mpt_ctx = &adapter->MptCtx;
 
 		tx_rate = MptToMgntRate(p_mpt_ctx->MptRateIndex);
 #endif
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 #ifdef CONFIG_MP_INCLUDED
-		PMPT_CONTEXT p_mpt_ctx = &(adapter->mppriv.mpt_ctx);
+		PMPT_CONTEXT p_mpt_ctx = &adapter->mppriv.mpt_ctx;
 
 		tx_rate = mpt_to_mgnt_rate(p_mpt_ctx->mpt_rate_index);
 #endif
 #endif
 #endif
 	} else {
-		u16	rate	 = *(p_dm->p_forced_data_rate);
+		u16 rate = *dm->forced_data_rate;
 
 		if (!rate) { /*auto rate*/
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-			tx_rate = adapter->HalFunc.GetHwRateFromMRateHandler(p_dm->tx_rate);
+			tx_rate = ((PADAPTER)adapter)->HalFunc.GetHwRateFromMRateHandler(dm->tx_rate);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			tx_rate = dm->tx_rate;
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-			if (p_dm->number_linked_client != 0)
-				tx_rate = hw_rate_to_m_rate(p_dm->tx_rate);
+			if (dm->number_linked_client != 0)
+				tx_rate = hw_rate_to_m_rate(dm->tx_rate);
 			else
-				tx_rate = p_rf->p_rate_index;
+				tx_rate = rf->p_rate_index;
 #endif
-		} else   /*force rate*/
+		} else { /*force rate*/
 			tx_rate = (u8)rate;
+		}
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD, ("Power Tracking tx_rate=0x%X\n", tx_rate));
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Power Tracking tx_rate=0x%X\n",
+	       tx_rate);
 
-	if (1 <= channel && channel <= 14) {
+	if (channel >= 1 && channel <= 14) {
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+		if (RX_HAL_IS_CCK_RATE(tx_rate)) {
+#else
 		if (IS_CCK_RATE(tx_rate)) {
-			*temperature_up_a   = p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_p;
-			*temperature_down_a = p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_n;
-			*temperature_up_b   = p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_p;
-			*temperature_down_b = p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_n;
+#endif
+			*temperature_up_a = cali_info->delta_swing_table_idx_2g_cck_a_p;
+			*temperature_down_a = cali_info->delta_swing_table_idx_2g_cck_a_n;
+			*temperature_up_b = cali_info->delta_swing_table_idx_2g_cck_b_p;
+			*temperature_down_b = cali_info->delta_swing_table_idx_2g_cck_b_n;
 		} else {
-			*temperature_up_a   = p_rf_calibrate_info->delta_swing_table_idx_2ga_p;
-			*temperature_down_a = p_rf_calibrate_info->delta_swing_table_idx_2ga_n;
-			*temperature_up_b   = p_rf_calibrate_info->delta_swing_table_idx_2gb_p;
-			*temperature_down_b = p_rf_calibrate_info->delta_swing_table_idx_2gb_n;
+			*temperature_up_a = cali_info->delta_swing_table_idx_2ga_p;
+			*temperature_down_a = cali_info->delta_swing_table_idx_2ga_n;
+			*temperature_up_b = cali_info->delta_swing_table_idx_2gb_p;
+			*temperature_down_b = cali_info->delta_swing_table_idx_2gb_n;
 		}
 	} else {
-		*temperature_up_a   = (u8 *)delta_swing_table_idx_2ga_p_8188e;
+		*temperature_up_a = (u8 *)delta_swing_table_idx_2ga_p_8188e;
 		*temperature_down_a = (u8 *)delta_swing_table_idx_2ga_n_8188e;
-		*temperature_up_b   = (u8 *)delta_swing_table_idx_2ga_p_8188e;
+		*temperature_up_b = (u8 *)delta_swing_table_idx_2ga_p_8188e;
 		*temperature_down_b = (u8 *)delta_swing_table_idx_2ga_n_8188e;
 	}
-
-	return;
 }
 
-void
-get_delta_swing_xtal_table_8723d(
-	void		*p_dm_void,
-	s8 **temperature_up_xtal,
-	s8 **temperature_down_xtal
-)
+void get_delta_swing_xtal_table_8723d(void *dm_void, s8 **temperature_up_xtal,
+				      s8 **temperature_down_xtal)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
 
-	*temperature_up_xtal   = p_rf_calibrate_info->delta_swing_table_xtal_p;
-	*temperature_down_xtal = p_rf_calibrate_info->delta_swing_table_xtal_n;
+	*temperature_up_xtal = cali_info->delta_swing_table_xtal_p;
+	*temperature_down_xtal = cali_info->delta_swing_table_xtal_n;
 }
 
-
-
-void
-odm_txxtaltrack_set_xtal_8723d(
-	void		*p_dm_void
-)
+void odm_txxtaltrack_set_xtal_8723d(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm		= (struct PHY_DM_STRUCT *)p_dm_void;
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info	= &(p_dm->rf_calibrate_info);
-	struct _ADAPTER		*adapter			= p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data		 = GET_HAL_DATA(adapter);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
+	s8 crystal_cap;
 
-	s8	crystal_cap;
-
-
-	crystal_cap = p_hal_data->crystal_cap & 0x3F;
-	crystal_cap = crystal_cap + p_rf_calibrate_info->xtal_offset;
+	crystal_cap = dm->dm_cfo_track.crystal_cap_default & 0x3F;
+	crystal_cap = crystal_cap + cali_info->xtal_offset;
 
 	if (crystal_cap < 0)
 		crystal_cap = 0;
 	else if (crystal_cap > 63)
 		crystal_cap = 63;
 
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
+	       "crystal_cap(%d)= dm->dm_cfo_track.crystal_cap_default(%d) + cali_info->xtal_offset(%d)\n",
+	       crystal_cap, dm->dm_cfo_track.crystal_cap_default, cali_info->xtal_offset);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("crystal_cap(%d)= p_hal_data->crystal_cap(%d) + p_rf_calibrate_info->xtal_offset(%d)\n", crystal_cap, p_hal_data->crystal_cap, p_rf_calibrate_info->xtal_offset));
-
-	odm_set_bb_reg(p_dm, REG_MAC_PHY_CTRL, 0xFFF000, (crystal_cap | (crystal_cap << 6)));
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_TX_PWR_TRACK, ODM_DBG_LOUD,
-		("crystal_cap(0x2c)  0x%X\n", odm_get_bb_reg(p_dm, REG_MAC_PHY_CTRL, 0xFFF000)));
+	odm_set_bb_reg(dm, REG_MAC_PHY_CTRL, 0xFFF000, (crystal_cap | (crystal_cap << 6)));
 
+	RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "crystal_cap(0x2c)  0x%X\n",
+	       odm_get_bb_reg(dm, REG_MAC_PHY_CTRL, 0xFFF000));
 }
 
-void configure_txpower_track_8723d(
-	struct _TXPWRTRACK_CFG	*p_config
-)
+void configure_txpower_track_8723d(struct txpwrtrack_cfg *config)
 {
-	p_config->swing_table_size_cck = CCK_TABLE_SIZE_8723D;
-	p_config->swing_table_size_ofdm = OFDM_TABLE_SIZE;
-	p_config->threshold_iqk = IQK_THRESHOLD;
-	p_config->average_thermal_num = AVG_THERMAL_NUM_8723D;
-	p_config->rf_path_count = MAX_PATH_NUM_8723D;
-	p_config->thermal_reg_addr = RF_T_METER_88E;
-
-	p_config->odm_tx_pwr_track_set_pwr = odm_tx_pwr_track_set_pwr_8723d;
-	p_config->do_iqk = do_iqk_8723d;
-	p_config->phy_lc_calibrate = halrf_lck_trigger;
-	p_config->get_delta_swing_table = get_delta_swing_table_8723d;
-	p_config->get_delta_swing_xtal_table = get_delta_swing_xtal_table_8723d;
-	p_config->odm_txxtaltrack_set_xtal = odm_txxtaltrack_set_xtal_8723d;
+	config->swing_table_size_cck = CCK_TABLE_SIZE_8723D;
+	config->swing_table_size_ofdm = OFDM_TABLE_SIZE;
+	config->threshold_iqk = IQK_THRESHOLD;
+	config->average_thermal_num = AVG_THERMAL_NUM_8723D;
+	config->rf_path_count = MAX_PATH_NUM_8723D;
+	config->thermal_reg_addr = RF_0x42;
+
+	config->odm_tx_pwr_track_set_pwr = odm_tx_pwr_track_set_pwr_8723d;
+	config->do_iqk = do_iqk_8723d;
+	config->phy_lc_calibrate = halrf_lck_trigger;
+	config->get_delta_swing_table = get_delta_swing_table_8723d;
+	config->get_delta_swing_xtal_table = get_delta_swing_xtal_table_8723d;
+	config->odm_txxtaltrack_set_xtal = odm_txxtaltrack_set_xtal_8723d;
 }
 
+#define MAX_TOLERANCE 5
+#define IQK_DELAY_TIME 1
 
-#define MAX_TOLERANCE		5
-#define IQK_DELAY_TIME		1
-
-u8
-phy_path_s1_iqk_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	config_path_s0
-)
+u8 phy_path_s1_iqk_8723d(struct dm_struct *dm, boolean config_path_s0)
 {
 	u32 reg_eac, reg_e94, reg_e9c, path_sel_bb;
 	u8 result = 0x00, ktime;
 	u32 original_path, original_gnt;
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]path S1 TXIQK!!\n"));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x67 @S1 TXIQK = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]path S1 TXIQK!!\n");
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x67 @S1 TXIQK = 0x%x\n",
+	       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
 	/*save RF path*/
-	path_sel_bb = odm_get_bb_reg(p_dm, 0x948, MASKDWORD);
-	/*ODM_RT_TRACE(p_dm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x1e6@S1 TXIQK = 0x%x\n", platform_efio_read_1byte(p_adapter, 0x1e6)));*/
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, 0x99000000);
+	path_sel_bb = odm_get_bb_reg(dm, R_0x948, MASKDWORD);
+#if 0
+	/*RF_DBG(dm,DBG_RF_IQK, "[IQK]0x1e6@S1 TXIQK = 0x%x\n", platform_efio_read_1byte(adapter, 0x1e6));*/
+#endif
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, 0x99000000);
 
 	/*IQK setting*/
 	/*leave IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
-	/* --- \A7\EF\BCgTXIQK mode table ---//*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x80000);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00004);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x0005d);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0xBFFE0);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
+	/* --- \A7\EF\BCgTXIQK mode table ---*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, RFREGOFFSETMASK, 0x80000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x33, RFREGOFFSETMASK, 0x00004);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3e, RFREGOFFSETMASK, 0x0005d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3f, RFREGOFFSETMASK, 0xBFFE0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, RFREGOFFSETMASK, 0x00000);
 
 	/*path-A IQK setting*/
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x08008c0c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_TX_IQK_PI_A, MASKDWORD, 0x8214019f);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28160200);
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	odm_set_bb_reg(dm, R_0xe30, MASKDWORD, 0x08008c0c);
+	odm_set_bb_reg(dm, R_0xe34, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe38, MASKDWORD, 0x8214019f);
+	odm_set_bb_reg(dm, R_0xe3c, MASKDWORD, 0x28160200);
+	odm_set_bb_reg(dm, R_0xe40, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
 	/*LO calibration setting*/
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_RSP, MASKDWORD, 0x00462911);
+	odm_set_bb_reg(dm, R_0xe4c, MASKDWORD, 0x00462911);
 
 	/*PA, PAD setting*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xdf, 0x800, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x56, 0x600, 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x56, 0x1E0, 0x3);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x8d, 0x1F, 0xf);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xdf, 0x800, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x56, 0x600, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x56, 0x1E0, 0x3);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x8d, 0x1F, 0xf);
 
 	/*LOK setting  added for 8723D*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x10, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x54, 0x1, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, 0x10, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x54, 0x1, 0x1);
 #if 1
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK, 0xe0d);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK, 0x60d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK, 0xe0d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK, 0x60d);
 #endif
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x1 @S1 TXIQK = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x2 @S1 TXIQK = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK)));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x1 @S1 TXIQK = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x2 @S1 TXIQK = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK));
 
 	/*enter IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 
 #if 1
 	/*backup path & GNT value */
-	original_path = odm_get_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD);  /*save 0x70*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
+	original_path = odm_get_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD); /*save 0x70*/
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
 	ODM_delay_ms(1);
-	original_gnt = odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD);  /*save 0x38*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]OriginalGNT = 0x%x\n", original_gnt));
+	original_gnt = odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD); /*save 0x38*/
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]OriginalGNT = 0x%x\n", original_gnt);
 
 	/*set GNT_WL=1/GNT_BT=1  and path owner to WiFi for pause BT traffic*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038);	/*0x38[15:8] = 0x77*/
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038); /*0x38[15:8] = 0x77*/
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
 #endif
 
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
 	ODM_delay_ms(1);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]GNT_BT @S1 TXIQK = 0x%x\n", odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x948 @S1 TXIQK = 0x%x\n", odm_get_bb_reg(p_dm, 0x948, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]GNT_BT @S1 TXIQK = 0x%x\n",
+	       odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x948 @S1 TXIQK = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0x948, MASKDWORD));
 
 	/*One shot, path S1 LOK & IQK*/
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xfa000000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xfa000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf8000000);
 
 	/* delay x ms */
+#if 0
 	/*ODM_delay_ms(IQK_DELAY_TIME_8723D);*/
+#endif
 
 	ktime = 0;
-	while ((!odm_get_bb_reg(p_dm, 0xeac, BIT(26))) && ktime < 10) {
+	while ((!odm_get_bb_reg(dm, R_0xeac, BIT(26))) && ktime < 10) {
 		ODM_delay_ms(1);
 		ktime++;
 	}
 
 #if 1
 	/*Restore GNT_WL/GNT_BT  and path owner*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
 #endif
 
 	/*reload RF path*/
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, path_sel_bb);
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, path_sel_bb);
 
 	/*leave IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 	/*PA/PAD controlled by 0x0*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xdf, 0x800, 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, BIT(0), 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xdf, 0x800, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, BIT(0), 0x0);
 
 	/* Check failed*/
-	reg_eac = odm_get_bb_reg(p_dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
-	reg_e94 = odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD);
-	reg_e9c = odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xeac = 0x%x\n", reg_eac));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe94 = 0x%x, 0xe9c = 0x%x\n", reg_e94, reg_e9c));
+	reg_eac = odm_get_bb_reg(dm, R_0xeac, MASKDWORD);
+	reg_e94 = odm_get_bb_reg(dm, R_0xe94, MASKDWORD);
+	reg_e9c = odm_get_bb_reg(dm, R_0xe9c, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xeac = 0x%x\n", reg_eac);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xe94 = 0x%x, 0xe9c = 0x%x\n", reg_e94,
+	       reg_e9c);
 	/*monitor image power before & after IQK*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
-		odm_get_bb_reg(p_dm, 0xe90, MASKDWORD), odm_get_bb_reg(p_dm, 0xe98, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[IQK]0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xe90, MASKDWORD),
+	       odm_get_bb_reg(dm, R_0xe98, MASKDWORD));
 
 	if (!(reg_eac & BIT(28)) &&
 	    (((reg_e94 & 0x03FF0000) >> 16) != 0x142) &&
@@ -916,433 +945,469 @@ phy_path_s1_iqk_8723d(
 
 		result |= 0x01;
 	else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("S1 TXIQK FAIL\n"));
+		RF_DBG(dm, DBG_RF_IQK, "S1 TXIQK FAIL\n");
 	return result;
 }
 
-u8
-phy_path_s1_rx_iqk_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	config_path_s0
-)
+u8 phy_path_s1_rx_iqk_8723d(struct dm_struct *dm, boolean config_path_s0)
 {
 	u32 reg_eac, reg_e94, reg_e9c, reg_ea4, u4tmp, tmp, path_sel_bb;
 	u8 result = 0x00, ktime;
 	u32 original_path, original_gnt;
 
-	path_sel_bb = odm_get_bb_reg(p_dm, 0x948, MASKDWORD);
+	path_sel_bb = odm_get_bb_reg(dm, R_0x948, MASKDWORD);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]path S1 RXIQK Step1!!\n"));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x67 @S1 RXIQK1 = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, 0x99000000);
-	/*ODM_RT_TRACE(p_dm,ODM_COMP_INIT, ODM_DBG_LOUD, ("[IQK]0x1e6@S1 RXIQK1 = 0x%x\n", platform_efio_read_1byte(p_adapter, 0x1e6)));	*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]path S1 RXIQK Step1!!\n");
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x67 @S1 RXIQK1 = 0x%x\n",
+	       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, 0x99000000);
+#if 0
+	/*RF_DBG(dm,DBG_RF_INIT, "[IQK]0x1e6@S1 RXIQK1 = 0x%x\n", platform_efio_read_1byte(adapter, 0x1e6));	*/
+#endif
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 
 	/*IQK setting*/
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	odm_set_bb_reg(dm, R_0xe40, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
 	/*path-A IQK setting*/
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x18008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe30, MASKDWORD, 0x18008c1c);
+	odm_set_bb_reg(dm, R_0xe34, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe50, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe54, MASKDWORD, 0x38008c1c);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82160000);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28160000);
+	odm_set_bb_reg(dm, R_0xe38, MASKDWORD, 0x82160000);
+	odm_set_bb_reg(dm, R_0xe3c, MASKDWORD, 0x28160000);
 
 	/*LO calibration setting*/
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a911);
+	odm_set_bb_reg(dm, R_0xe4c, MASKDWORD, 0x0046a911);
 
 	/*modify RXIQK mode table*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, RFREGOFFSETMASK, 0x80000);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00006);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x0005f);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0xa7ffb);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, RFREGOFFSETMASK, 0x80000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x33, RFREGOFFSETMASK, 0x00006);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3e, RFREGOFFSETMASK, 0x0005f);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3f, RFREGOFFSETMASK, 0xa7ffb);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, RFREGOFFSETMASK, 0x00000);
 
 	/*---------PA/PAD=0----------*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xdf, 0x800, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x56, 0x600, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xdf, 0x800, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x56, 0x600, 0x0);
 #if 1
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK, 0xe0d);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK, 0x60d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK, 0xe0d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK, 0x60d);
 #endif
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x1@ path S1 RXIQK1 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x2@ path S1 RXIQK1 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK)));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x1@ path S1 RXIQK1 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x2@ path S1 RXIQK1 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK));
 
 	/*enter IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 #if 1
 	/*backup path & GNT value */
-	original_path = odm_get_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD);  /*save 0x70*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
+	original_path = odm_get_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD); /*save 0x70*/
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
 	ODM_delay_ms(1);
-	original_gnt = odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD);  /*save 0x38*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]OriginalGNT = 0x%x\n", original_gnt));
+	original_gnt = odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD); /*save 0x38*/
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]OriginalGNT = 0x%x\n", original_gnt);
 
 	/*set GNT_WL=1/GNT_BT=1  and path owner to WiFi for pause BT traffic*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038);	/*0x38[15:8] = 0x77*/
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038); /*0x38[15:8] = 0x77*/
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
 #endif
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
 	ODM_delay_ms(1);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]GNT_BT @S1 RXIQK1 = 0x%x\n", odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x948 @S1 RXIQK1 = 0x%x\n", odm_get_bb_reg(p_dm, 0x948, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]GNT_BT @S1 RXIQK1 = 0x%x\n",
+	       odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x948 @S1 RXIQK1 = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0x948, MASKDWORD));
 
 	/*One shot, path S1 LOK & IQK*/
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf8000000);
 
 	/*delay x ms*/
+#if 0
 	/*ODM_delay_ms(IQK_DELAY_TIME_8723D);*/
+#endif
 
 	ktime = 0;
-	while ((!odm_get_bb_reg(p_dm, 0xeac, BIT(26))) && ktime < 10) {
+	while ((!odm_get_bb_reg(dm, R_0xeac, BIT(26))) && ktime < 10) {
 		ODM_delay_ms(1);
 		ktime++;
 	}
-	reg_eac = odm_get_bb_reg(p_dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
-	reg_e94 = odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD);
-	reg_e9c = odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xeac = 0x%x\n", reg_eac));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe94 = 0x%x, 0xe9c = 0x%x\n", reg_e94, reg_e9c));
+	reg_eac = odm_get_bb_reg(dm, R_0xeac, MASKDWORD);
+	reg_e94 = odm_get_bb_reg(dm, R_0xe94, MASKDWORD);
+	reg_e9c = odm_get_bb_reg(dm, R_0xe9c, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xeac = 0x%x\n", reg_eac);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xe94 = 0x%x, 0xe9c = 0x%x\n", reg_e94,
+	       reg_e9c);
 	/*monitor image power before & after IQK*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
-		odm_get_bb_reg(p_dm, 0xe90, MASKDWORD), odm_get_bb_reg(p_dm, 0xe98, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[IQK]0xe90(before IQK)= 0x%x, 0xe98(afer IQK) = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xe90, MASKDWORD),
+	       odm_get_bb_reg(dm, R_0xe98, MASKDWORD));
 	tmp = (reg_e9c & 0x03FF0000) >> 16;
 	if ((tmp & 0x200) > 0)
 		tmp = 0x400 - tmp;
 
 	if (!(reg_eac & BIT(28)) &&
 	    (((reg_e94 & 0x03FF0000) >> 16) != 0x142) &&
-	    (((reg_e9c & 0x03FF0000) >> 16) != 0x42))
-
+	    (((reg_e9c & 0x03FF0000) >> 16) != 0x42)) {
 		result |= 0x01;
-	else {
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("S1 RXIQK STEP1 FAIL\n"));
+	} else {
+		RF_DBG(dm, DBG_RF_IQK, "S1 RXIQK STEP1 FAIL\n");
 #if 1
 		/*Restore GNT_WL/GNT_BT  and path owner*/
-		odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
-		odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
-		odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
+		odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
+		odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
+		odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
 #endif
 		/*reload RF path*/
-		odm_set_bb_reg(p_dm, 0x948, MASKDWORD, path_sel_bb);
-		odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0xdf, 0x800, 0x0);
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, BIT(0), 0x0);
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, BIT(0), 0x0);
+		odm_set_bb_reg(dm, R_0x948, MASKDWORD, path_sel_bb);
+		odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0xdf, 0x800, 0x0);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, BIT(0), 0x0);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, BIT(0), 0x0);
 		return result;
 	}
 
-	u4tmp = 0x80007C00 | (reg_e94 & 0x3FF0000)  | ((reg_e9c & 0x3FF0000) >> 16);
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, u4tmp);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe40 = 0x%x u4tmp = 0x%x\n", odm_get_bb_reg(p_dm, REG_TX_IQK, MASKDWORD), u4tmp));
+	u4tmp = 0x80007C00 | (reg_e94 & 0x3FF0000) | ((reg_e9c & 0x3FF0000) >> 16);
+	odm_set_bb_reg(dm, R_0xe40, MASKDWORD, u4tmp);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xe40 = 0x%x u4tmp = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xe40, MASKDWORD), u4tmp);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]path S1 RXIQK STEP2!!\n"));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x67 @S1 RXIQK2 = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
-	/*ODM_RT_TRACE(p_dm,ODM_COMP_INIT, ODM_DBG_LOUD, ("[IQK]0x1e6@S1 RXIQK2 = 0x%x\n", platform_efio_read_1byte(p_adapter, 0x1e6)));	*/
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]path S1 RXIQK STEP2!!\n");
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x67 @S1 RXIQK2 = 0x%x\n",
+	       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
+#if 0
+	/*RF_DBG(dm,DBG_RF_INIT, "[IQK]0x1e6@S1 RXIQK2 = 0x%x\n", platform_efio_read_1byte(adapter, 0x1e6));	*/
+#endif
+	odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x18008c1c);
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe30, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe34, MASKDWORD, 0x18008c1c);
+	odm_set_bb_reg(dm, R_0xe50, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe54, MASKDWORD, 0x38008c1c);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82170000);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28171400);
+	odm_set_bb_reg(dm, R_0xe38, MASKDWORD, 0x82170000);
+	odm_set_bb_reg(dm, R_0xe3c, MASKDWORD, 0x28171400);
 
 	/*LO calibration setting*/
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a8d1);
-
+	odm_set_bb_reg(dm, R_0xe4c, MASKDWORD, 0x0046a8d1);
 
 	/*modify RXIQK mode table*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00007);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x0005f);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0xb3fdb);
-
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x1 @S1 RXIQK2 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x2 @S1 RXIQK2 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK)));
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, 0x80000, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x33, RFREGOFFSETMASK, 0x00007);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3e, RFREGOFFSETMASK, 0x0005f);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3f, RFREGOFFSETMASK, 0xb3fdb);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, RFREGOFFSETMASK, 0x00000);
+
+	RF_DBG(dm, DBG_RF_IQK, "RF0x1 @S1 RXIQK2 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x2 @S1 RXIQK2 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK));
 
 	/*enter IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 
 #if 1
 	/*backup path & GNT value */
-	original_path = odm_get_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD);  /*save 0x70*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
+	original_path = odm_get_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD); /*save 0x70*/
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
 	ODM_delay_ms(1);
-	original_gnt = odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD);  /*save 0x38*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]OriginalGNT = 0x%x\n", original_gnt));
+	original_gnt = odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD); /*save 0x38*/
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]OriginalGNT = 0x%x\n", original_gnt);
 
 	/*set GNT_WL=1/GNT_BT=1  and path owner to WiFi for pause BT traffic*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038);	/*0x38[15:8] = 0x77*/
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038); /*0x38[15:8] = 0x77*/
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
 #endif
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
 	ODM_delay_ms(1);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]GNT_BT @S1 RXIQK2 = 0x%x\n", odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x948 @S1 RXIQK2 = 0x%x\n", odm_get_bb_reg(p_dm, 0x948, MASKDWORD)));
-
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]GNT_BT @S1 RXIQK2 = 0x%x\n",
+	       odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x948 @S1 RXIQK2 = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0x948, MASKDWORD));
 
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf8000000);
 
 	/*ODM_delay_ms(IQK_DELAY_TIME_8723D);*/
 
 	ktime = 0;
-	while ((!odm_get_bb_reg(p_dm, 0xeac, BIT(26))) && ktime < 10) {
+	while ((!odm_get_bb_reg(dm, R_0xeac, BIT(26))) && ktime < 10) {
 		ODM_delay_ms(1);
 		ktime++;
 	}
 
 #if 1
 	/*Restore GNT_WL/GNT_BT  and path owner*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
 #endif
 	/*reload RF path*/
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, path_sel_bb);
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, path_sel_bb);
 
 	/*leave IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 	/*	PA/PAD controlled by 0x0*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xdf, 0x800, 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, BIT(0), 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xdf, 0x800, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, BIT(0), 0x0);
 
-	reg_eac = odm_get_bb_reg(p_dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
-	reg_ea4 = odm_get_bb_reg(p_dm, REG_RX_POWER_BEFORE_IQK_A_2, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xeac = 0x%x\n", reg_eac));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xea4 = 0x%x, 0xeac = 0x%x\n", reg_ea4, reg_eac));
+	reg_eac = odm_get_bb_reg(dm, R_0xeac, MASKDWORD);
+	reg_ea4 = odm_get_bb_reg(dm, R_0xea4, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xeac = 0x%x\n", reg_eac);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xea4 = 0x%x, 0xeac = 0x%x\n", reg_ea4,
+	       reg_eac);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xea0(before IQK)= 0x%x, 0xea8(afer IQK) = 0x%x\n",
-		odm_get_bb_reg(p_dm, 0xea0, MASKDWORD), odm_get_bb_reg(p_dm, 0xea8, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[IQK]0xea0(before IQK)= 0x%x, 0xea8(afer IQK) = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xea0, MASKDWORD),
+	       odm_get_bb_reg(dm, R_0xea8, MASKDWORD));
 
 	tmp = (reg_eac & 0x03FF0000) >> 16;
 	if ((tmp & 0x200) > 0)
 		tmp = 0x400 - tmp;
 
-	if (!(reg_eac & BIT(27)) &&		/*if Tx is OK, check whether Rx is OK*/
+	if (!(reg_eac & BIT(27)) && /*if Tx is OK, check whether Rx is OK*/
 	    (((reg_ea4 & 0x03FF0000) >> 16) != 0x132) &&
 	    (((reg_eac & 0x03FF0000) >> 16) != 0x36) &&
 	    (((reg_ea4 & 0x03FF0000) >> 16) < 0x11a) &&
 	    (((reg_ea4 & 0x03FF0000) >> 16) > 0xe6) &&
-	    (tmp < 0x1a))
+	    tmp < 0x1a)
 		result |= 0x02;
 	else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("S1 RXIQK STEP2 FAIL\n"));
+		RF_DBG(dm, DBG_RF_IQK, "S1 RXIQK STEP2 FAIL\n");
 	return result;
 }
 
-
-u8
-phy_path_s0_iqk_8723d(
-	struct PHY_DM_STRUCT		*p_dm
-)
+u8 phy_path_s0_iqk_8723d(struct dm_struct *dm)
 {
-	u32 reg_eac, reg_e94, reg_e9c, reg_e94_s0, reg_e9c_s0, reg_ea4_s0, reg_eac_s0, tmp, path_sel_bb;
-	u8	result = 0x00, ktime;
+	u32 reg_e94_s0, reg_e9c_s0, reg_eac_s0, path_sel_bb;
+	u8 result = 0x00, ktime;
 	u32 original_path, original_gnt;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 TXIQK!\n"));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x67 @S0 TXIQK = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
-	path_sel_bb = odm_get_bb_reg(p_dm, 0x948, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "path S0 TXIQK!\n");
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x67 @S0 TXIQK = 0x%x\n",
+	       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
+	path_sel_bb = odm_get_bb_reg(dm, R_0x948, MASKDWORD);
 
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, 0x99000280); /*10 od 0x948 0x1 [7] ; WL:S1 to S0;BT:S0 to S1;*/
-	/*ODM_RT_TRACE(p_dm,ODM_COMP_INIT, ODM_DBG_LOUD, ("[IQK]0x1e6@S0 TXIQK = 0x%x\n", platform_efio_read_1byte(p_adapter, 0x1e6)));*/
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, 0x99000280); /*10 od 0x948 0x1 [7] ; WL:S1 to S0;BT:S0 to S1;*/
+#if 0
+	/*RF_DBG(dm,DBG_RF_INIT, "[IQK]0x1e6@S0 TXIQK = 0x%x\n", platform_efio_read_1byte(adapter, 0x1e6));*/
+#endif
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 	/*modify TXIQK mode table*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xee, RFREGOFFSETMASK, 0x80000);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00004);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x0005d);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0xBFFE0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xee, RFREGOFFSETMASK, 0x80000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x33, RFREGOFFSETMASK, 0x00004);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3e, RFREGOFFSETMASK, 0x0005d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3f, RFREGOFFSETMASK, 0xBFFE0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xee, RFREGOFFSETMASK, 0x00000);
 
 	/*path-A IQK setting*/
-	odm_set_bb_reg(p_dm, 0xe30, MASKDWORD, 0x08008c0c);
-	odm_set_bb_reg(p_dm, 0xe34, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, 0xe38, MASKDWORD, 0x8214018a);
-	odm_set_bb_reg(p_dm, 0xe3c, MASKDWORD, 0x28160200);
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	odm_set_bb_reg(dm, R_0xe30, MASKDWORD, 0x08008c0c);
+	odm_set_bb_reg(dm, R_0xe34, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe38, MASKDWORD, 0x8214018a);
+	odm_set_bb_reg(dm, R_0xe3c, MASKDWORD, 0x28160200);
+	odm_set_bb_reg(dm, R_0xe40, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
 	/*LO calibration setting*/
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_RSP, MASKDWORD, 0x00462911);
+	odm_set_bb_reg(dm, R_0xe4c, MASKDWORD, 0x00462911);
 
 	/*PA, PAD setting*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xde, 0x800, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x66, 0x600, 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x66, 0x1E0, 0x3);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x8d, 0x1F, 0xf);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xde, 0x800, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x66, 0x600, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x66, 0x1E0, 0x3);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x8d, 0x1F, 0xf);
 
 	/*LOK setting	added for 8723D*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xee, 0x10, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x64, 0x1, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xee, 0x10, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x64, 0x1, 0x1);
 
 #if 1
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK, 0xe6d);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK, 0x66d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK, 0xe6d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK, 0x66d);
 #endif
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x1 @S0 TXIQK = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x2 @S0 TXIQK = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK)));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x1 @S0 TXIQK = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x2 @S0 TXIQK = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK));
 	/*enter IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 #if 1
 	/*backup path & GNT value */
-	original_path = odm_get_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD);  /*save 0x70*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
+	original_path = odm_get_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD); /*save 0x70*/
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
 	ODM_delay_ms(1);
-	original_gnt = odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD);  /*save 0x38*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]OriginalGNT = 0x%x\n", original_gnt));
+	original_gnt = odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD); /*save 0x38*/
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]OriginalGNT = 0x%x\n", original_gnt);
 
 	/*set GNT_WL=1/GNT_BT=1  and path owner to WiFi for pause BT traffic*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038);	/*0x38[15:8] = 0x77*/
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038); /*0x38[15:8] = 0x77*/
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
 #endif
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
 	ODM_delay_ms(1);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]GNT_BT @S0 TXIQK = 0x%x\n", odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x948 @S0 TXIQK = 0x%x\n", odm_get_bb_reg(p_dm, 0x948, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]GNT_BT @S0 TXIQK = 0x%x\n",
+	       odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x948 @S0 TXIQK = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0x948, MASKDWORD));
 
 	/*One shot, path S1 LOK & IQK*/
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf8000000);
 
 	/*delay x ms*/
+#if 0
 	/*ODM_delay_ms(IQK_DELAY_TIME_8723D);*/
+#endif
 
 	ktime = 0;
-	while ((!odm_get_bb_reg(p_dm, 0xeac, BIT(26))) && ktime < 10) {
+	while ((!odm_get_bb_reg(dm, R_0xeac, BIT(26))) && ktime < 10) {
 		ODM_delay_ms(1);
 		ktime++;
 	}
 #if 1
 	/*Restore GNT_WL/GNT_BT  and path owner*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
 #endif
 	/*reload RF path*/
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, path_sel_bb);
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, path_sel_bb);
 	/*leave IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 	/*PA/PAD controlled by 0x0*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xde, 0x800, 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, BIT(0), 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xde, 0x800, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, BIT(0), 0x0);
 	/* Check failed*/
-	reg_eac_s0 = odm_get_bb_reg(p_dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
-	reg_e94_s0 = odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD);
-	reg_e9c_s0 = odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xeac_s0 = 0x%x\n", reg_eac_s0));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe94_s0 = 0x%x, 0xe9c_s0 = 0x%x\n", reg_e94_s0, reg_e9c_s0));
+	reg_eac_s0 = odm_get_bb_reg(dm, R_0xeac, MASKDWORD);
+	reg_e94_s0 = odm_get_bb_reg(dm, R_0xe94, MASKDWORD);
+	reg_e9c_s0 = odm_get_bb_reg(dm, R_0xe9c, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xeac_s0 = 0x%x\n", reg_eac_s0);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xe94_s0 = 0x%x, 0xe9c_s0 = 0x%x\n",
+	       reg_e94_s0, reg_e9c_s0);
 	/*monitor image power before & after IQK*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe90_s0(before IQK)= 0x%x, 0xe98_s0(afer IQK) = 0x%x\n",
-		odm_get_bb_reg(p_dm, 0xe90, MASKDWORD), odm_get_bb_reg(p_dm, 0xe98, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[IQK]0xe90_s0(before IQK)= 0x%x, 0xe98_s0(afer IQK) = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xe90, MASKDWORD),
+	       odm_get_bb_reg(dm, R_0xe98, MASKDWORD));
 	if (!(reg_eac_s0 & BIT(28)) &&
 	    (((reg_e94_s0 & 0x03FF0000) >> 16) != 0x142) &&
 	    (((reg_e9c_s0 & 0x03FF0000) >> 16) != 0x42))
 
 		result |= 0x01;
 	else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("S0 TXIQK FAIL\n"));
+		RF_DBG(dm, DBG_RF_IQK, "S0 TXIQK FAIL\n");
 
 	return result;
 }
 
-
-u8
-phy_path_s0_rx_iqk_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	config_path_s0
-)
+u8 phy_path_s0_rx_iqk_8723d(struct dm_struct *dm, boolean config_path_s0)
 {
-	u32 reg_e94, reg_e9c, reg_ea4, reg_eac, reg_e94_s0, reg_e9c_s0, reg_ea4_s0, reg_eac_s0, tmp, u4tmp, path_sel_bb;
+	u32 reg_e94_s0, reg_e9c_s0, reg_ea4_s0, reg_eac_s0, tmp, u4tmp;
+	u32 path_sel_bb;
 	u8 result = 0x00, ktime;
 	u32 original_path, original_gnt;
 
-	path_sel_bb = odm_get_bb_reg(p_dm, 0x948, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 RxIQK Step1!!\n"));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x67 @S0 RXIQK1 = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, 0x99000280);
-	/*ODM_RT_TRACE(p_dm,ODM_COMP_INIT, ODM_DBG_LOUD, ("[IQK]0x1e6@S0 RXIQK1 = 0x%x\n", platform_efio_read_1byte(p_adapter, 0x1e6)));*/
+	path_sel_bb = odm_get_bb_reg(dm, R_0x948, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "path S0 RxIQK Step1!!\n");
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x67 @S0 RXIQK1 = 0x%x\n",
+	       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, 0x99000280);
+#if 0
+	/*RF_DBG(dm,DBG_RF_INIT, "[IQK]0x1e6@S0 RXIQK1 = 0x%x\n", platform_efio_read_1byte(adapter, 0x1e6));*/
+#endif
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	odm_set_bb_reg(dm, R_0xe40, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x18008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe30, MASKDWORD, 0x18008c1c);
+	odm_set_bb_reg(dm, R_0xe34, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe50, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe54, MASKDWORD, 0x38008c1c);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82160000);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28160000);
+	odm_set_bb_reg(dm, R_0xe38, MASKDWORD, 0x82160000);
+	odm_set_bb_reg(dm, R_0xe3c, MASKDWORD, 0x28160000);
 
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a911);
+	odm_set_bb_reg(dm, R_0xe4c, MASKDWORD, 0x0046a911);
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xee, RFREGOFFSETMASK, 0x80000);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00006);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x0005f);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0xa7ffb);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xee, RFREGOFFSETMASK, 0x80000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x33, RFREGOFFSETMASK, 0x00006);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3e, RFREGOFFSETMASK, 0x0005f);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3f, RFREGOFFSETMASK, 0xa7ffb);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xee, RFREGOFFSETMASK, 0x00000);
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xde, 0x800, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x66, 0x600, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xde, 0x800, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x66, 0x600, 0x0);
 
 #if 1
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK, 0xe6d);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK, 0x66d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK, 0xe6d);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK, 0x66d);
 #endif
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x1 @S0 RXIQK1 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x2 @S0 RXIQK1 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK)));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x1 @S0 RXIQK1 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x2 @S0 RXIQK1 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK));
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 
 #if 1
 	/*backup path & GNT value */
-	original_path = odm_get_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD);  /*save 0x70*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
+	original_path = odm_get_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD); /*save 0x70*/
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
 	ODM_delay_ms(1);
-	original_gnt = odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD);  /*save 0x38*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]OriginalGNT = 0x%x\n", original_gnt));
+	original_gnt = odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD); /*save 0x38*/
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]OriginalGNT = 0x%x\n", original_gnt);
 
 	/*set GNT_WL=1/GNT_BT=1  and path owner to WiFi for pause BT traffic*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038);	/*0x38[15:8] = 0x77*/
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038); /*0x38[15:8] = 0x77*/
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
 #endif
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
 	ODM_delay_ms(1);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]GNT_BT @S0 RXIQK1 = 0x%x\n", odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x948 @S0 RXIQK1 = 0x%x\n", odm_get_bb_reg(p_dm, 0x948, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]GNT_BT @S0 RXIQK1 = 0x%x\n",
+	       odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x948 @S0 RXIQK1 = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0x948, MASKDWORD));
 
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf8000000);
 
+#if 0
 	/*ODM_delay_ms(IQK_DELAY_TIME_8723D);*/
+#endif
 	ktime = 0;
-	while ((!odm_get_bb_reg(p_dm, 0xeac, BIT(26))) && ktime < 10) {
+	while ((!odm_get_bb_reg(dm, R_0xeac, BIT(26))) && ktime < 10) {
 		ODM_delay_ms(1);
 		ktime++;
 	}
-	reg_eac_s0 = odm_get_bb_reg(p_dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
-	reg_e94_s0 = odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD);
-	reg_e9c_s0 = odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xeac_s0 = 0x%x\n", reg_eac_s0));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe94_s0 = 0x%x, 0xe9c_s0 = 0x%x\n", reg_e94_s0, reg_e9c_s0));
+	reg_eac_s0 = odm_get_bb_reg(dm, R_0xeac, MASKDWORD);
+	reg_e94_s0 = odm_get_bb_reg(dm, R_0xe94, MASKDWORD);
+	reg_e9c_s0 = odm_get_bb_reg(dm, R_0xe9c, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xeac_s0 = 0x%x\n", reg_eac_s0);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xe94_s0 = 0x%x, 0xe9c_s0 = 0x%x\n",
+	       reg_e94_s0, reg_e9c_s0);
 	/*monitor image power before & after IQK*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe90_s0(before IQK)= 0x%x, 0xe98_s0(afer IQK) = 0x%x\n",
-		odm_get_bb_reg(p_dm, 0xe90, MASKDWORD), odm_get_bb_reg(p_dm, 0xe98, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[IQK]0xe90_s0(before IQK)= 0x%x, 0xe98_s0(afer IQK) = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xe90, MASKDWORD),
+	       odm_get_bb_reg(dm, R_0xe98, MASKDWORD));
 
 	tmp = (reg_e9c_s0 & 0x03FF0000) >> 16;
 	if ((tmp & 0x200) > 0)
@@ -1350,165 +1415,175 @@ phy_path_s0_rx_iqk_8723d(
 
 	if (!(reg_eac_s0 & BIT(28)) &&
 	    (((reg_e94_s0 & 0x03FF0000) >> 16) != 0x142) &&
-	    (((reg_e9c_s0 & 0x03FF0000) >> 16) != 0x42))
-
+	    (((reg_e9c_s0 & 0x03FF0000) >> 16) != 0x42)) {
 		result |= 0x01;
-	else {
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("S0 RXIQK STEP1 FAIL\n"));
+	} else {
+		RF_DBG(dm, DBG_RF_IQK, "S0 RXIQK STEP1 FAIL\n");
 #if 1
 		/*Restore GNT_WL/GNT_BT  and path owner*/
-		odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
-		odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
-		odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
+		odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
+		odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
+		odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
 #endif
 		/*reload RF path*/
-		odm_set_bb_reg(p_dm, 0x948, MASKDWORD, path_sel_bb);
-		odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0xde, 0x800, 0x0);
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, BIT(0), 0x0);
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, BIT(0), 0x0);
+		odm_set_bb_reg(dm, R_0x948, MASKDWORD, path_sel_bb);
+		odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0xde, 0x800, 0x0);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, BIT(0), 0x0);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, BIT(0), 0x0);
 		return result;
 	}
 
-	u4tmp = 0x80007C00 | (reg_e94_s0 & 0x3FF0000)  | ((reg_e9c_s0 & 0x3FF0000) >> 16);
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, u4tmp);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xe40_s0 = 0x%x u4tmp = 0x%x\n", odm_get_bb_reg(p_dm, REG_TX_IQK, MASKDWORD), u4tmp));
+	u4tmp = 0x80007C00 | (reg_e94_s0 & 0x3FF0000) | ((reg_e9c_s0 & 0x3FF0000) >> 16);
+	odm_set_bb_reg(dm, R_0xe40, MASKDWORD, u4tmp);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xe40_s0 = 0x%x u4tmp = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xe40, MASKDWORD), u4tmp);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]path S0 RXIQK STEP2!!\n\n"));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x67 @S0 RXIQK2 = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
-	/*ODM_RT_TRACE(p_dm,ODM_COMP_INIT, ODM_DBG_LOUD, ("[IQK]0x1e6@S0 RXIQK2 = 0x%x\n", platform_efio_read_1byte(p_adapter, 0x1e6)));*/
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]path S0 RXIQK STEP2!!\n\n");
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x67 @S0 RXIQK2 = 0x%x\n",
+	       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
+#if 0
+	/*RF_DBG(dm,DBG_RF_INIT, "[IQK]0x1e6@S0 RXIQK2 = 0x%x\n", platform_efio_read_1byte(adapter, 0x1e6));*/
+#endif
+	odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x18008c1c);
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_B, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe30, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe34, MASKDWORD, 0x18008c1c);
+	odm_set_bb_reg(dm, R_0xe50, MASKDWORD, 0x38008c1c);
+	odm_set_bb_reg(dm, R_0xe54, MASKDWORD, 0x38008c1c);
 
-	odm_set_bb_reg(p_dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82170000);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28171400);
+	odm_set_bb_reg(dm, R_0xe38, MASKDWORD, 0x82170000);
+	odm_set_bb_reg(dm, R_0xe3c, MASKDWORD, 0x28171400);
 
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_RSP, MASKDWORD, 0x0046a8d1);
+	odm_set_bb_reg(dm, R_0xe4c, MASKDWORD, 0x0046a8d1);
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xee, 0x80000, 0x1);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x33, RFREGOFFSETMASK, 0x00007);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3e, RFREGOFFSETMASK, 0x0005f);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x3f, RFREGOFFSETMASK, 0xb3fdb);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xee, 0x80000, 0x1);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x33, RFREGOFFSETMASK, 0x00007);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3e, RFREGOFFSETMASK, 0x0005f);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x3f, RFREGOFFSETMASK, 0xb3fdb);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xee, RFREGOFFSETMASK, 0x00000);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x1 @S0 RXIQK2 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x1, RFREGOFFSETMASK)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("RF0x2 @S0 RXIQK2 = 0x%x\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x2, RFREGOFFSETMASK)));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x1 @S0 RXIQK2 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x1, RFREGOFFSETMASK));
+	RF_DBG(dm, DBG_RF_IQK, "RF0x2 @S0 RXIQK2 = 0x%x\n",
+	       odm_get_rf_reg(dm, RF_PATH_A, RF_0x2, RFREGOFFSETMASK));
 	/*enter IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 #if 1
 	/*backup path & GNT value */
-	original_path = odm_get_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD);  /*save 0x70*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
+	original_path = odm_get_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD); /*save 0x70*/
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
 	ODM_delay_ms(1);
-	original_gnt = odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD);  /*save 0x38*/
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]OriginalGNT = 0x%x\n", original_gnt));
+	original_gnt = odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD); /*save 0x38*/
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]OriginalGNT = 0x%x\n", original_gnt);
 
 	/*set GNT_WL=1/GNT_BT=1  and path owner to WiFi for pause BT traffic*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038);	/*0x38[15:8] = 0x77*/
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038); /*0x38[15:8] = 0x77*/
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
 #endif
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0054);
 	ODM_delay_ms(1);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]GNT_BT @S0 RXIQK2 = 0x%x\n", odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD)));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0x948 @S0 RXIQK2 = 0x%x\n", odm_get_bb_reg(p_dm, 0x948, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]GNT_BT @S0 RXIQK2 = 0x%x\n",
+	       odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD));
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0x948 @S0 RXIQK2 = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0x948, MASKDWORD));
 
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, R_0xe48, MASKDWORD, 0xf8000000);
 
+#if 0
 	/*ODM_delay_ms(IQK_DELAY_TIME_8723D);*/
+#endif
 	ktime = 0;
-	while ((!odm_get_bb_reg(p_dm, 0xeac, BIT(26))) && ktime < 10) {
+	while ((!odm_get_bb_reg(dm, R_0xeac, BIT(26))) && ktime < 10) {
 		ODM_delay_ms(1);
 		ktime++;
 	}
 #if 1
 	/*Restore GNT_WL/GNT_BT  and path owner*/
-	odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
-	odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
-	odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
+	odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
+	odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
+	odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
 #endif
 	/*reload RF path*/
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, path_sel_bb);
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, path_sel_bb);
 
 	/*leave IQK mode*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xde, 0x800, 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x2, BIT(0), 0x0);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x1, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xde, 0x800, 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x2, BIT(0), 0x0);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x1, BIT(0), 0x0);
 
-	reg_eac_s0 = odm_get_bb_reg(p_dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD);
-	reg_ea4_s0 = odm_get_bb_reg(p_dm, REG_RX_POWER_BEFORE_IQK_A_2, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xeac_s0 = 0x%x\n", reg_eac_s0));
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xea4_s0 = 0x%x, 0xeac_s0 = 0x%x\n", reg_ea4_s0, reg_eac_s0));
+	reg_eac_s0 = odm_get_bb_reg(dm, R_0xeac, MASKDWORD);
+	reg_ea4_s0 = odm_get_bb_reg(dm, R_0xea4, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xeac_s0 = 0x%x\n", reg_eac_s0);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xea4_s0 = 0x%x, 0xeac_s0 = 0x%x\n",
+	       reg_ea4_s0, reg_eac_s0);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xea0_s0(before IQK)= 0x%x, 0xea8_s0(afer IQK) = 0x%x\n",
-		odm_get_bb_reg(p_dm, 0xea0, MASKDWORD), odm_get_bb_reg(p_dm, 0xea8, MASKDWORD)));
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[IQK]0xea0_s0(before IQK)= 0x%x, 0xea8_s0(afer IQK) = 0x%x\n",
+	       odm_get_bb_reg(dm, R_0xea0, MASKDWORD),
+	       odm_get_bb_reg(dm, R_0xea8, MASKDWORD));
 
 	tmp = (reg_eac_s0 & 0x03FF0000) >> 16;
 	if ((tmp & 0x200) > 0)
 		tmp = 0x400 - tmp;
 
-	if (!(reg_eac_s0 & BIT(27)) &&		/*if Tx is OK, check whether Rx is OK*/
+	if (!(reg_eac_s0 & BIT(27)) && /*if Tx is OK, check whether Rx is OK*/
 	    (((reg_ea4_s0 & 0x03FF0000) >> 16) != 0x132) &&
 	    (((reg_eac_s0 & 0x03FF0000) >> 16) != 0x36) &&
 	    (((reg_ea4_s0 & 0x03FF0000) >> 16) < 0x11a) &&
 	    (((reg_ea4_s0 & 0x03FF0000) >> 16) > 0xe6) &&
-	    (tmp < 0x1a))
+	    tmp < 0x1a)
 		result |= 0x02;
 	else
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("S0 RXIQK STEP2 FAIL\n"));
+		RF_DBG(dm, DBG_RF_IQK, "S0 RXIQK STEP2 FAIL\n");
 	return result;
 }
 
-
-void
-_phy_path_s1_fill_iqk_matrix_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	is_iqk_ok,
-	s32		result[][8],
-	u8		final_candidate,
-	boolean	is_tx_only
-)
+void _phy_path_s1_fill_iqk_matrix_8723d(struct dm_struct *dm, boolean is_iqk_ok,
+					s32 result[][8], u8 final_candidate,
+					boolean is_tx_only)
 {
-	u32	oldval_1, X, TX1_A, reg;
-	s32	Y, TX1_C;
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S1 IQ Calibration %s !\n", (is_iqk_ok) ? "Success" : "Failed"));
+	u32 oldval_1, X, TX1_A, reg;
+	s32 Y, TX1_C;
+	RF_DBG(dm, DBG_RF_IQK, "path S1 IQ Calibration %s !\n",
+	       (is_iqk_ok) ? "Success" : "Failed");
 
 	if (final_candidate == 0xFF)
 		return;
 
-	else if (is_iqk_ok) {
-		oldval_1 = (odm_get_bb_reg(p_dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD) >> 22) & 0x3FF;
+	if (is_iqk_ok) {
+		oldval_1 = (odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD) >> 22) & 0x3FF;
 
 		X = result[final_candidate][0];
 
 		if ((X & 0x00000200) != 0)
 			X = X | 0xFFFFFC00;
 		TX1_A = (X * oldval_1) >> 8;
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("X = 0x%x, TX1_A = 0x%x, oldval_1 0x%x\n", X, TX1_A, oldval_1));
-		odm_set_bb_reg(p_dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0x3FF, TX1_A);
+		RF_DBG(dm, DBG_RF_IQK,
+		       "X = 0x%x, TX1_A = 0x%x, oldval_1 0x%x\n", X, TX1_A,
+		       oldval_1);
+		odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0x3FF, TX1_A);
 
-		odm_set_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(31), ((X * oldval_1 >> 7) & 0x1));
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(31), ((X * oldval_1 >> 7) & 0x1));
 
 		Y = result[final_candidate][1];
 		if ((Y & 0x00000200) != 0)
 			Y = Y | 0xFFFFFC00;
 
 		TX1_C = (Y * oldval_1) >> 8;
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Y = 0x%x, TX1_C = 0x%x\n", Y, TX1_C));
-		odm_set_bb_reg(p_dm, REG_OFDM_0_XC_TX_AFE, 0xF0000000, ((TX1_C & 0x3C0) >> 6));
-		odm_set_bb_reg(p_dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0x003F0000, (TX1_C & 0x3F));
+		RF_DBG(dm, DBG_RF_IQK, "Y = 0x%x, TX1_C = 0x%x\n", Y, TX1_C);
+		odm_set_bb_reg(dm, R_0xc94, 0xF0000000, ((TX1_C & 0x3C0) >> 6));
+		odm_set_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0x003F0000, (TX1_C & 0x3F));
 
-		odm_set_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(29), ((Y * oldval_1 >> 7) & 0x1));
+		odm_set_bb_reg(dm, REG_OFDM_0_ECCA_THRESHOLD, BIT(29), ((Y * oldval_1 >> 7) & 0x1));
 
 		if (is_tx_only) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("_phy_path_s1_fill_iqk_matrix_8723d only Tx OK\n"));
+			RF_DBG(dm, DBG_RF_IQK, "%s only Tx OK\n", __func__);
 			return;
 		}
 		reg = result[final_candidate][2];
@@ -1516,260 +1591,221 @@ _phy_path_s1_fill_iqk_matrix_8723d(
 		if (RTL_ABS(reg, 0x100) >= 16)
 			reg = 0x100;
 #endif
-		odm_set_bb_reg(p_dm, REG_OFDM_0_XA_RX_IQ_IMBALANCE, 0x3FF, reg);
+		odm_set_bb_reg(dm, R_0xc14, 0x3FF, reg);
 
 		reg = result[final_candidate][3] & 0x3F;
-		odm_set_bb_reg(p_dm, REG_OFDM_0_XA_RX_IQ_IMBALANCE, 0xFC00, reg);
+		odm_set_bb_reg(dm, R_0xc14, 0xFC00, reg);
 
 		reg = (result[final_candidate][3] >> 6) & 0xF;
-		odm_set_bb_reg(p_dm, REG_OFDM_0_RX_IQ_EXT_ANTA, 0xF0000000, reg);
-		/*
-		10 os 7201 10
-		10 id ea4 [25:16] p
-		10 os 7202 10
-		10 od c14 VarFromTmp [9:0] p
-
-		10 os 7201 11
-		10 id eac [25:22] p
-		10 os 7202 11
-		10 od ca0 VarFromTmp [31:28] p
-
-		10 os 7201 12
-		10 id eac [21:16] p
-		10 os 7202 12
-		10 od c14 VarFromTmp [15:10] p
-		*/
+		odm_set_bb_reg(dm, R_0xca0, 0xF0000000, reg);
+
+		/* 10 os 7201 10
+		 * 10 id ea4 [25:16] p
+		 * 10 os 7202 10
+		 * 10 od c14 VarFromTmp [9:0] p
+		 *
+		 * 10 os 7201 11
+		 * 10 id eac [25:22] p
+		 * 10 os 7202 11
+		 * 10 od ca0 VarFromTmp [31:28] p
+		 *
+		 * 10 os 7201 12
+		 * 10 id eac [21:16] p
+		 * 10 os 7202 12
+		 * 10 od c14 VarFromTmp [15:10] p
+		 */
 	}
 }
 
-void
-_phy_path_s0_fill_iqk_matrix_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	is_iqk_ok,
-	s32		result[][8],
-	u8		final_candidate,
-	boolean		is_tx_only
-)
+void _phy_path_s0_fill_iqk_matrix_8723d(struct dm_struct *dm, boolean is_iqk_ok,
+					s32 result[][8], u8 final_candidate,
+					boolean is_tx_only)
 {
-	u32	oldval_0, X, TX0_A, reg;
-	s32	Y, TX0_C;
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 IQ Calibration %s !\n", (is_iqk_ok) ? "Success" : "Failed"));
+	u32 oldval_0, X, TX0_A, reg;
+	s32 Y, TX0_C;
+	RF_DBG(dm, DBG_RF_IQK, "path S0 IQ Calibration %s !\n",
+	       (is_iqk_ok) ? "Success" : "Failed");
 
 	if (final_candidate == 0xFF)
 		return;
 
-	else if (is_iqk_ok) {
-		oldval_0 = (odm_get_bb_reg(p_dm, 0xcd4, MASKDWORD) >> 13) & 0x3FF;
+	if (is_iqk_ok) {
+		oldval_0 = (odm_get_bb_reg(dm, R_0xcd4, MASKDWORD) >> 13) & 0x3FF;
 
 		X = result[final_candidate][4];
 		if ((X & 0x00000200) != 0)
 			X = X | 0xFFFFFC00;
 		TX0_A = (X * oldval_0) >> 8;
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("X = 0x%x, TX0_A = 0x%x, oldval_0 0x%x\n", X, TX0_A, oldval_0));
-		odm_set_bb_reg(p_dm, 0xcd0, 0x7FE, TX0_A);
+		RF_DBG(dm, DBG_RF_IQK,
+		       "X = 0x%x, TX0_A = 0x%x, oldval_0 0x%x\n", X, TX0_A,
+		       oldval_0);
+		odm_set_bb_reg(dm, R_0xcd0, 0x7FE, TX0_A);
 
-		odm_set_bb_reg(p_dm, 0xcd0, BIT(0), ((X * oldval_0 >> 7) & 0x1));
+		odm_set_bb_reg(dm, R_0xcd0, BIT(0), ((X * oldval_0 >> 7) & 0x1));
 
 		Y = result[final_candidate][5];
 		if ((Y & 0x00000200) != 0)
 			Y = Y | 0xFFFFFC00;
 
 		TX0_C = (Y * oldval_0) >> 8;
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Y = 0x%x, TX0_C = 0x%x\n", Y, TX0_C));
-		odm_set_bb_reg(p_dm, 0xcd4, 0x7FE, (TX0_C & 0x3FF));
+		RF_DBG(dm, DBG_RF_IQK, "Y = 0x%x, TX0_C = 0x%x\n", Y, TX0_C);
+		odm_set_bb_reg(dm, R_0xcd4, 0x7FE, (TX0_C & 0x3FF));
 
-		odm_set_bb_reg(p_dm, 0xcd4, BIT(0), ((Y * oldval_0 >> 7) & 0x1));
+		odm_set_bb_reg(dm, R_0xcd4, BIT(0), ((Y * oldval_0 >> 7) & 0x1));
 
 		if (is_tx_only)
 			return;
 
 		reg = result[final_candidate][6];
-		odm_set_bb_reg(p_dm, 0xcd8, 0x3FF, reg);
+		odm_set_bb_reg(dm, R_0xcd8, 0x3FF, reg);
 
 		reg = result[final_candidate][7];
-		odm_set_bb_reg(p_dm, 0xcd8, 0x003FF000, reg);
-		/*
-		10 os 7201 10
-		10 id ea4 [25:16] p
-		10 os 7202 10
-		10 od cd8 VarFromTmp [9:0] p
-
-		10 os 7201 11
-		10 id eac [25:16] p
-		10 os 7202 11
-		10 od cd8 VarFromTmp [21:12] p
-				rege94_s1 = result[i][0];
-				rege9c_s1 = result[i][1];
-				regea4_s1 = result[i][2];
-				regeac_s1 = result[i][3];
-				rege94_s0 = result[i][4];
-				rege9c_s0 = result[i][5];
-				regea4_s0 = result[i][6];
-				regeac_s0 = result[i][7];
-		*/
+		odm_set_bb_reg(dm, R_0xcd8, 0x003FF000, reg);
+
+		/*10 os 7201 10
+		 *10 id ea4 [25:16] p
+		 *10 os 7202 10
+		 *10 od cd8 VarFromTmp [9:0] p
+		 *
+		 *10 os 7201 11
+		 *10 id eac [25:16] p
+		 *10 os 7202 11
+		 *10 od cd8 VarFromTmp [21:12] p
+		 *		rege94_s1 = result[i][0];
+		 *		rege9c_s1 = result[i][1];
+		 *		regea4_s1 = result[i][2];
+		 *		regeac_s1 = result[i][3];
+		 *		rege94_s0 = result[i][4];
+		 *		rege9c_s0 = result[i][5];
+		 *		regea4_s0 = result[i][6];
+		 *		regeac_s0 = result[i][7];
+		 */
 	}
 }
 
-void
-_phy_save_adda_registers_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*adda_reg,
-	u32		*adda_backup,
-	u32		register_num
-)
+void _phy_save_adda_registers_8723d(struct dm_struct *dm, u32 *adda_reg,
+				    u32 *adda_backup, u32 register_num)
 {
-	u32	i;
+	u32 i;
 
-	for (i = 0 ; i < register_num ; i++)
-		adda_backup[i] = odm_get_bb_reg(p_dm, adda_reg[i], MASKDWORD);
+	for (i = 0; i < register_num; i++)
+		adda_backup[i] = odm_get_bb_reg(dm, adda_reg[i], MASKDWORD);
 }
 
-
-void
-_phy_save_mac_registers_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*mac_reg,
-	u32		*mac_backup
-)
+void _phy_save_mac_registers_8723d(struct dm_struct *dm, u32 *mac_reg,
+				   u32 *mac_backup)
 {
-	u32	i;
+	u32 i;
 
-	for (i = 0 ; i < (IQK_MAC_REG_NUM - 1); i++)
-		mac_backup[i] = odm_read_1byte(p_dm, mac_reg[i]);
-	mac_backup[i] = odm_read_4byte(p_dm, mac_reg[i]);
+	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
+		mac_backup[i] = odm_read_1byte(dm, mac_reg[i]);
+	mac_backup[i] = odm_read_4byte(dm, mac_reg[i]);
 }
 
-
-void
-_phy_reload_adda_registers_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*adda_reg,
-	u32		*adda_backup,
-	u32		regiester_num
-)
+void _phy_reload_adda_registers_8723d(struct dm_struct *dm, u32 *adda_reg,
+				      u32 *adda_backup, u32 regiester_num)
 {
-	u32	i;
+	u32 i;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Reload ADDA power saving parameters !\n"));
-	for (i = 0 ; i < regiester_num; i++)
-		odm_set_bb_reg(p_dm, adda_reg[i], MASKDWORD, adda_backup[i]);
+	RF_DBG(dm, DBG_RF_IQK, "Reload ADDA power saving parameters !\n");
+	for (i = 0; i < regiester_num; i++)
+		odm_set_bb_reg(dm, adda_reg[i], MASKDWORD, adda_backup[i]);
 }
 
-void
-_phy_reload_mac_registers_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*mac_reg,
-	u32		*mac_backup
-)
+void _phy_reload_mac_registers_8723d(struct dm_struct *dm, u32 *mac_reg,
+				     u32 *mac_backup)
 {
-	u32	i;
+	u32 i;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("Reload MAC parameters !\n"));
-	for (i = 0 ; i < (IQK_MAC_REG_NUM - 1); i++)
-		odm_write_1byte(p_dm, mac_reg[i], (u8)mac_backup[i]);
-	odm_write_4byte(p_dm, mac_reg[i], mac_backup[i]);
+	RF_DBG(dm, DBG_RF_IQK, "Reload MAC parameters !\n");
+	for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
+		odm_write_1byte(dm, mac_reg[i], (u8)mac_backup[i]);
+	odm_write_4byte(dm, mac_reg[i], mac_backup[i]);
 }
 
-
-void
-_phy_path_adda_on_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*adda_reg,
-	boolean		is_path_a_on,
-	boolean		is2T
-)
+void _phy_path_adda_on_8723d(struct dm_struct *dm, u32 *adda_reg,
+			     boolean is_path_a_on, boolean is2T)
 {
-	u32	path_on;
-	u32	i;
+	u32 path_on;
+	u32 i;
 
 	path_on = is_path_a_on ? 0x03c00016 : 0x03c00016;
 
-	if (false == is2T) {
+	if (!is2T) {
 		path_on = 0x03c00016;
-		odm_set_bb_reg(p_dm, adda_reg[0], MASKDWORD, 0x03c00016);
-	} else
-		odm_set_bb_reg(p_dm, adda_reg[0], MASKDWORD, path_on);
-
-	for (i = 1 ; i < IQK_ADDA_REG_NUM ; i++)
-		odm_set_bb_reg(p_dm, adda_reg[i], MASKDWORD, path_on);
+		odm_set_bb_reg(dm, adda_reg[0], MASKDWORD, 0x03c00016);
+	} else {
+		odm_set_bb_reg(dm, adda_reg[0], MASKDWORD, path_on);
+	}
 
+	for (i = 1; i < IQK_ADDA_REG_NUM; i++)
+		odm_set_bb_reg(dm, adda_reg[i], MASKDWORD, path_on);
 }
 
-void
-_phy_mac_setting_calibration_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*mac_reg,
-	u32		*mac_backup
-)
+void _phy_mac_setting_calibration_8723d(struct dm_struct *dm, u32 *mac_reg,
+					u32 *mac_backup)
 {
+#if 0
 	/*
-		odm_write_1byte(p_dm, mac_reg[i], 0x3F);
+		odm_write_1byte(dm, mac_reg[i], 0x3F);
 
 		for(i = 1 ; i < (IQK_MAC_REG_NUM - 1); i++){
-			odm_write_1byte(p_dm, mac_reg[i], (u8)(mac_backup[i]&(~BIT(3))));
+			odm_write_1byte(dm, mac_reg[i], (u8)(mac_backup[i]&(~BIT(3))));
 		}
-		odm_write_1byte(p_dm, mac_reg[i], (u8)(mac_backup[i]&(~BIT(5))));
+		odm_write_1byte(dm, mac_reg[i], (u8)(mac_backup[i]&(~BIT(5))));
 	*/
 
-	/*odm_set_bb_reg(p_dm, 0x522, MASKBYTE0, 0x7f);*/
-	/*odm_set_bb_reg(p_dm, 0x550, MASKBYTE0, 0x15);*/
-	/*odm_set_bb_reg(p_dm, 0x551, MASKBYTE0, 0x00);*/
-	odm_set_bb_reg(p_dm, 0x520, 0x00ff0000, 0xff);
+	/*odm_set_bb_reg(dm, R_0x522, MASKBYTE0, 0x7f);*/
+	/*odm_set_bb_reg(dm, R_0x550, MASKBYTE0, 0x15);*/
+	/*odm_set_bb_reg(dm, R_0x551, MASKBYTE0, 0x00);*/
+#endif
+	odm_set_bb_reg(dm, R_0x520, 0x00ff0000, 0xff);
 }
 
-void
-_phy_path_a_stand_by_8723d(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void _phy_path_a_stand_by_8723d(struct dm_struct *dm)
 {
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path-S1 standby mode!\n"));
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
-	/*	odm_set_bb_reg(p_dm, 0x840, MASKDWORD, 0x00010000);*/
-	odm_set_rf_reg(p_dm, (enum rf_path)0x0, 0x0, RFREGOFFSETMASK, 0x10000);
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	RF_DBG(dm, DBG_RF_IQK, "path-S1 standby mode!\n");
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
+#if 0
+	/*	odm_set_bb_reg(dm, R_0x840, MASKDWORD, 0x00010000);*/
+#endif
+	odm_set_rf_reg(dm, (enum rf_path)0x0, RF_0x0, RFREGOFFSETMASK, 0x10000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 }
 
-void
-_phy_path_b_stand_by_8723d(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void _phy_path_b_stand_by_8723d(struct dm_struct *dm)
 {
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path-S0 standby mode!\n"));
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
-	odm_set_rf_reg(p_dm, (enum rf_path)0x1, 0x0, RFREGOFFSETMASK, 0x10000);
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	RF_DBG(dm, DBG_RF_IQK, "path-S0 standby mode!\n");
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
+	odm_set_rf_reg(dm, (enum rf_path)0x1, RF_0x0, RFREGOFFSETMASK, 0x10000);
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
 }
 
-
-void
-_phy_pi_mode_switch_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean		pi_mode
-)
+void _phy_pi_mode_switch_8723d(struct dm_struct *dm, boolean pi_mode)
 {
-	u32	mode;
+	u32 mode;
 
 	mode = pi_mode ? 0x01000100 : 0x01000000;
-	odm_set_bb_reg(p_dm, REG_FPGA0_XA_HSSI_PARAMETER1, MASKDWORD, mode);
-	odm_set_bb_reg(p_dm, REG_FPGA0_XB_HSSI_PARAMETER1, MASKDWORD, mode);
+	odm_set_bb_reg(dm, R_0x820, MASKDWORD, mode);
+	odm_set_bb_reg(dm, R_0x828, MASKDWORD, mode);
 }
 
 boolean
-phy_simularity_compare_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	s32		result[][8],
-	u8		 c1,
-	u8		 c2
-)
+phy_simularity_compare_8723d(struct dm_struct *dm, s32 result[][8], u8 c1,
+			     u8 c2)
 {
-	u32		i, j, diff, simularity_bit_map, bound = 0;
-	u8		final_candidate[2] = {0xFF, 0xFF};
-	boolean		is_result = true;
+	u32 i, j, diff, simularity_bit_map, bound = 0;
+	u8 final_candidate[2] = {0xFF, 0xFF};
+	boolean is_result = true;
+#if 0
 	/*#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)*/
-	/*	bool		is2T = IS_92C_SERIAL( p_hal_data->version_id);*/
+	/*	bool		is2T = IS_92C_SERIAL( hal_data->version_id);*/
 	/*#else*/
-	boolean		is2T = true;
+#endif
+	boolean is2T = true;
+#if 0
 	/*#endif*/
+#endif
 
 	s32 tmp1 = 0, tmp2 = 0;
 
@@ -1778,14 +1814,13 @@ phy_simularity_compare_8723d(
 	else
 		bound = 4;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("===> IQK:phy_simularity_compare_8723d c1 %d c2 %d!!!\n", c1, c2));
-
+	RF_DBG(dm, DBG_RF_IQK, "===> IQK:%s c1 %d c2 %d!!!\n", __func__, c1,
+	       c2);
 
 	simularity_bit_map = 0;
 
 	for (i = 0; i < bound; i++) {
-
-		if ((i == 1) || (i == 3) || (i == 5) || (i == 7)) {
+		if (i == 1 || i == 3 || i == 5 || i == 7) {
 			if ((result[c1][i] & 0x00000200) != 0)
 				tmp1 = result[c1][i] | 0xFFFFFC00;
 			else
@@ -1803,7 +1838,9 @@ phy_simularity_compare_8723d(
 		diff = (tmp1 > tmp2) ? (tmp1 - tmp2) : (tmp2 - tmp1);
 
 		if (diff > MAX_TOLERANCE) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:differnece overflow %d index %d compare1 0x%x compare2 0x%x!!!\n",  diff, i, result[c1][i], result[c2][i]));
+			RF_DBG(dm, DBG_RF_IQK,
+			       "IQK:differnece overflow %d index %d compare1 0x%x compare2 0x%x!!!\n",
+			       diff, i, result[c1][i], result[c2][i]);
 
 			if ((i == 2 || i == 6) && !simularity_bit_map) {
 				if (result[c1][i] + result[c1][i + 1] == 0)
@@ -1812,12 +1849,14 @@ phy_simularity_compare_8723d(
 					final_candidate[(i / 4)] = c1;
 				else
 					simularity_bit_map = simularity_bit_map | (1 << i);
-			} else
+			} else {
 				simularity_bit_map = simularity_bit_map | (1 << i);
+			}
 		}
 	}
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:phy_simularity_compare_8723d simularity_bit_map   %x !!!\n", simularity_bit_map));
+	RF_DBG(dm, DBG_RF_IQK, "IQK:%s simularity_bit_map   %x !!!\n", __func__,
+	       simularity_bit_map);
 
 	if (simularity_bit_map == 0) {
 		for (i = 0; i < (bound / 4); i++) {
@@ -1828,130 +1867,119 @@ phy_simularity_compare_8723d(
 			}
 		}
 		return is_result;
-	} else {
-
-		if (!(simularity_bit_map & 0x03)) {
-			for (i = 0; i < 2; i++)
-				result[3][i] = result[c1][i];
-		}
-
-		if (!(simularity_bit_map & 0x0c)) {
-			for (i = 2; i < 4; i++)
-				result[3][i] = result[c1][i];
-		}
-
-		if (!(simularity_bit_map & 0x30)) {
-			for (i = 4; i < 6; i++)
-				result[3][i] = result[c1][i];
-
-		}
+	}
 
-		if (!(simularity_bit_map & 0xc0)) {
-			for (i = 6; i < 8; i++)
-				result[3][i] = result[c1][i];
-		}
+	if (!(simularity_bit_map & 0x03)) {
+		for (i = 0; i < 2; i++)
+			result[3][i] = result[c1][i];
+	}
 
-		return false;
+	if (!(simularity_bit_map & 0x0c)) {
+		for (i = 2; i < 4; i++)
+			result[3][i] = result[c1][i];
 	}
 
+	if (!(simularity_bit_map & 0x30)) {
+		for (i = 4; i < 6; i++)
+			result[3][i] = result[c1][i];
+	}
 
+	if (!(simularity_bit_map & 0xc0)) {
+		for (i = 6; i < 8; i++)
+			result[3][i] = result[c1][i];
+	}
 
+	return false;
 }
 
-
-void
-_phy_check_coex_status_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	boolean		beforek
-)
+void _phy_check_coex_status_8723d(struct dm_struct *dm, boolean beforek)
 {
-	u8		u1b_tmp;
-	u16		count = 0;
-	u8		h2c_parameter;
-
 #if MP_DRIVER != 1
+	u8 u1b_tmp;
+	u16 count = 0;
+	u8 h2c_parameter;
+
 	if (beforek) {
 		/* Set H2C cmd to inform FW (enable). */
 		h2c_parameter = 1;
-		odm_fill_h2c_cmd(p_dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
-		/* Check 0x1e6 */
+		odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+		/* Check 0x1e6 or 100ms timeout*/
 		count = 0;
-		u1b_tmp = odm_read_1byte(p_dm, 0x1e6);
-		while (u1b_tmp != 0x1 && count < 1000) {
-			ODM_delay_ms(1);
-			u1b_tmp = odm_read_1byte(p_dm, 0x1e6);
+		u1b_tmp = odm_read_1byte(dm, 0x1e6);
+		while (u1b_tmp != 0x1 && count < 5000) {
+			ODM_delay_us(20);
+			u1b_tmp = odm_read_1byte(dm, 0x1e6);
 			count++;
 		}
 
-		if (count >= 1000)
-			RT_TRACE(COMP_INIT, DBG_LOUD, ("[IQK]Polling 0x1e6 to 1 for WiFi calibration H2C cmd FAIL! count(%d)", count));
+		if (count >= 5000)
+			RF_DBG(dm, DBG_RF_INIT,
+			       "[IQK]Polling 0x1e6 to 1 for WiFi calibration H2C cmd FAIL! count(%d)",
+			       count);
 
 		/* Wait BT IQK finished. */
-		/* polling 0x1e7[0]=1 or 300ms timeout */
-		u1b_tmp = odm_read_1byte(p_dm, 0x1e7);
-		while ((!(u1b_tmp & BIT(0))) && count < 6000) {
-			ODM_delay_ms(50);
-			u1b_tmp = odm_read_1byte(p_dm, 0x1e7);
+		/* polling 0x1e7[0]=1 or 600ms timeout */
+		count = 0;
+		u1b_tmp = odm_read_1byte(dm, 0x1e7);
+		while ((!(u1b_tmp & BIT(0))) && count < 30000) {
+			ODM_delay_us(20);
+			u1b_tmp = odm_read_1byte(dm, 0x1e7);
 			count++;
 		}
+
+		if (count >= 30000)
+			RF_DBG(dm, DBG_RF_INIT,
+			       "[IQK]Waiting BT IQK finish time out! count(%d)",
+			       count);
 	} else {
 		/* Set H2C cmd to inform FW (disable). */
 		h2c_parameter = 0;
-		odm_fill_h2c_cmd(p_dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
-		/* Check 0x1e6 */
+		odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+		/* Check 0x1e6 or 100ms timeout*/
 		count = 0;
-		u1b_tmp = odm_read_1byte(p_dm, 0x1e6);
-		while (u1b_tmp != 0 && count < 1000) {
-			ODM_delay_us(10);
-			u1b_tmp = odm_read_1byte(p_dm, 0x1e6);
+		u1b_tmp = odm_read_1byte(dm, 0x1e6);
+		while (u1b_tmp != 0 && count < 5000) {
+			ODM_delay_us(20);
+			u1b_tmp = odm_read_1byte(dm, 0x1e6);
 			count++;
 		}
 
 		if (count >= 1000)
-			RT_TRACE(COMP_INIT, DBG_LOUD, ("[IQK]Polling 0x1e6 to 0 for WiFi calibration H2C cmd FAIL! count(%d)", count));
-		}
+			RF_DBG(dm, DBG_RF_INIT,
+			       "[IQK]Polling 0x1e6 to 0 for WiFi calibration H2C cmd FAIL! count(%d)",
+			       count);
+	}
 #endif
 }
 
-
-
-void
-_phy_iq_calibrate_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	s32		result[][8],
-	u8		t,
-	boolean		is2T
-)
+void _phy_iq_calibrate_8723d(struct dm_struct *dm, s32 result[][8], u8 t,
+			     boolean is2T)
 {
-	u32			i;
-	u8			path_s1_ok = 0x0, path_s0_ok = 0x0;
-	u8			tmp0xc50 = (u8)odm_get_bb_reg(p_dm, 0xC50, MASKBYTE0);
-	u8			tmp0xc58 = (u8)odm_get_bb_reg(p_dm, 0xC58, MASKBYTE0);
-	u32			ADDA_REG[IQK_ADDA_REG_NUM] = {
-		REG_FPGA0_XCD_SWITCH_CONTROL,	REG_BLUE_TOOTH,
-		REG_RX_WAIT_CCA,		REG_TX_CCK_RFON,
-		REG_TX_CCK_BBON,	REG_TX_OFDM_RFON,
-		REG_TX_OFDM_BBON,	REG_TX_TO_RX,
-		REG_TX_TO_TX,		REG_RX_CCK,
-		REG_RX_OFDM,		REG_RX_WAIT_RIFS,
-		REG_RX_TO_RX,		REG_STANDBY,
-		REG_SLEEP,			REG_PMPD_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] = {
-		REG_OFDM_0_TRX_PATH_ENABLE,		REG_OFDM_0_TR_MUX_PAR,
-		REG_FPGA0_XCD_RF_INTERFACE_SW,	REG_CONFIG_ANT_A,	REG_CONFIG_ANT_B,
-		REG_FPGA0_XAB_RF_INTERFACE_SW,	REG_FPGA0_XA_RF_INTERFACE_OE,
-		REG_FPGA0_XB_RF_INTERFACE_OE, REG_CCK_0_AFE_SETTING
-	};
-	u32	cnt_iqk_fail = 0;
+	u32 i;
+	u8 path_s1_ok = 0x0, path_s0_ok = 0x0;
+	u8 tmp0xc50 = (u8)odm_get_bb_reg(dm, R_0xc50, MASKBYTE0);
+	u8 tmp0xc58 = (u8)odm_get_bb_reg(dm, R_0xc58, MASKBYTE0);
+	u32 ADDA_REG[IQK_ADDA_REG_NUM] = {
+		R_0x85c, R_0xe6c,
+		R_0xe70, R_0xe74,
+		R_0xe78, R_0xe7c,
+		R_0xe80, R_0xe84,
+		R_0xe88, R_0xe8c,
+		R_0xed0, R_0xed4,
+		R_0xed8, R_0xedc,
+		R_0xee0, R_0xeec};
+	u32 IQK_MAC_REG[IQK_MAC_REG_NUM] = {
+		R_0x522, R_0x550,
+		R_0x551, R_0x40};
+
+	u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
+		R_0xc04, R_0xc08,
+		R_0x874, R_0xb68, R_0xb6c,
+		R_0x870, R_0x860,
+		R_0x864, R_0xa04};
+	u32 cnt_iqk_fail = 0;
 	u32 retry_count;
-	
+
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	retry_count = 2;
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
@@ -1961,7 +1989,7 @@ _phy_iq_calibrate_8723d(
 	retry_count = 2;
 #endif
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	if (*(p_dm->p_mp_mode))
+	if (*dm->mp_mode)
 		retry_count = 9;
 	else
 		retry_count = 2;
@@ -1969,261 +1997,261 @@ _phy_iq_calibrate_8723d(
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 #ifdef MP_TEST
-	if (*(p_dm->p_mp_mode))
+	if (*dm->mp_mode)
 		retry_count = 9;
 #endif
 #endif
 
 	if (t == 0) {
-		_phy_save_adda_registers_8723d(p_dm, ADDA_REG, p_dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
-		_phy_save_mac_registers_8723d(p_dm, IQK_MAC_REG, p_dm->rf_calibrate_info.IQK_MAC_backup);
-		_phy_save_adda_registers_8723d(p_dm, IQK_BB_REG_92C, p_dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
+		_phy_save_adda_registers_8723d(dm, ADDA_REG, dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
+		_phy_save_mac_registers_8723d(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
+		_phy_save_adda_registers_8723d(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
 	}
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQ Calibration for 1T1R_S0/S1 for %d times\n", t));
+	RF_DBG(dm, DBG_RF_IQK, "IQ Calibration for 1T1R_S0/S1 for %d times\n",
+	       t);
 
-	_phy_path_adda_on_8723d(p_dm, ADDA_REG, true, is2T);
+	_phy_path_adda_on_8723d(dm, ADDA_REG, true, is2T);
 #if 0
 	if (t == 0)
-		p_dm->rf_calibrate_info.is_rf_pi_enable = (u8)odm_get_bb_reg(p_dm, REG_FPGA0_XA_HSSI_PARAMETER1, BIT(8));
+		dm->rf_calibrate_info.is_rf_pi_enable = (u8)odm_get_bb_reg(dm, R_0x820, BIT(8));
 
-	if (!p_dm->rf_calibrate_info.is_rf_pi_enable) {
+	if (!dm->rf_calibrate_info.is_rf_pi_enable) {
 		/*  Switch BB to PI mode to do IQ Calibration. */
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-		_phy_pi_mode_switch_8723d(p_adapter, true);
+		_phy_pi_mode_switch_8723d(adapter, true);
 #else
-		_phy_pi_mode_switch_8723d(p_dm, true);
+		_phy_pi_mode_switch_8723d(dm, true);
 #endif
 	}
 #endif
-	_phy_mac_setting_calibration_8723d(p_dm, IQK_MAC_REG, p_dm->rf_calibrate_info.IQK_MAC_backup);
+	_phy_mac_setting_calibration_8723d(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
 	/*BB setting*/
-	/*odm_set_bb_reg(p_dm, REG_FPGA0_RFMOD, BIT24, 0x00);*/
-	odm_set_bb_reg(p_dm, REG_CCK_0_AFE_SETTING, 0x0f000000, 0xf);
-	odm_set_bb_reg(p_dm, REG_OFDM_0_TRX_PATH_ENABLE, MASKDWORD, 0x03a05611);
-	odm_set_bb_reg(p_dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800e4);
-	odm_set_bb_reg(p_dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x25204200);
+#if 0
+	/*odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT24, 0x00);*/
+#endif
+	odm_set_bb_reg(dm, R_0xa04, 0x0f000000, 0xf);
+	odm_set_bb_reg(dm, R_0xc04, MASKDWORD, 0x03a05611);
+	odm_set_bb_reg(dm, R_0xc08, MASKDWORD, 0x000800e4);
+	odm_set_bb_reg(dm, R_0x874, MASKDWORD, 0x25204200);
 
 	/*IQ calibration setting*/
-	/*ODM_RT_TRACE(p_dm,ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK setting!\n"));	*/
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+#if 0
+	/*RF_DBG(dm,DBG_RF_IQK, "IQK setting!\n");	*/
+#endif
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, R_0xe40, MASKDWORD, 0x01007c00);
+	odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
 	if (is2T) {
-		_phy_path_b_stand_by_8723d(p_dm);
-		_phy_path_adda_on_8723d(p_dm, ADDA_REG, false, is2T);
+		_phy_path_b_stand_by_8723d(dm);
+		_phy_path_adda_on_8723d(dm, ADDA_REG, false, is2T);
 	}
 
 #if 1
-	for (i = 0 ; i < retry_count ; i++) {
-		path_s1_ok = phy_path_s1_iqk_8723d(p_dm, is2T);
+	for (i = 0; i < retry_count; i++) {
+		path_s1_ok = phy_path_s1_iqk_8723d(dm, is2T);
 		if (path_s1_ok == 0x01) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S1 Tx IQK Success!!\n"));
-			result[t][0] = (odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
-			result[t][1] = (odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+			RF_DBG(dm, DBG_RF_IQK, "path S1 Tx IQK Success!!\n");
+			result[t][0] = (odm_get_bb_reg(dm, R_0xe94, MASKDWORD) & 0x3FF0000) >> 16;
+			result[t][1] = (odm_get_bb_reg(dm, R_0xe9c, MASKDWORD) & 0x3FF0000) >> 16;
 			break;
-		} else {
-			ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S1 Tx IQK Fail!!\n"));
-			result[t][0] = 0x100;
-			result[t][1] = 0x0;
-			cnt_iqk_fail++;
 		}
+
+		RF_DBG(dm, DBG_RF_IQK, "path S1 Tx IQK Fail!!\n");
+		result[t][0] = 0x100;
+		result[t][1] = 0x0;
+		cnt_iqk_fail++;
 #if 0
 		else if (i == (retry_count - 1) && path_s1_ok == 0x01) {
 			RT_DISP(FINIT, INIT_IQK, ("path S1 IQK Only  Tx Success!!\n"));
 
-			result[t][0] = (odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
-			result[t][1] = (odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD) & 0x3FF0000) >> 16;
+			result[t][0] = (odm_get_bb_reg(dm, R_0xe94, MASKDWORD) & 0x3FF0000) >> 16;
+			result[t][1] = (odm_get_bb_reg(dm, R_0xe9c, MASKDWORD) & 0x3FF0000) >> 16;
 		}
 #endif
 	}
 #endif
 #if 1
-	for (i = 0 ; i < retry_count ; i++) {
-		path_s1_ok = phy_path_s1_rx_iqk_8723d(p_dm, is2T);
+	for (i = 0; i < retry_count; i++) {
+		path_s1_ok = phy_path_s1_rx_iqk_8723d(dm, is2T);
 		if (path_s1_ok == 0x03) {
-			ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S1 Rx IQK Success!!\n"));
-			result[t][2] = (odm_get_bb_reg(p_dm, REG_RX_POWER_BEFORE_IQK_A_2, MASKDWORD) & 0x3FF0000) >> 16;
-			result[t][3] = (odm_get_bb_reg(p_dm, REG_RX_POWER_AFTER_IQK_A_2, MASKDWORD) & 0x3FF0000) >> 16;
+			RF_DBG(dm, DBG_RF_IQK, "path S1 Rx IQK Success!!\n");
+			result[t][2] = (odm_get_bb_reg(dm, R_0xea4, MASKDWORD) & 0x3FF0000) >> 16;
+			result[t][3] = (odm_get_bb_reg(dm, R_0xeac, MASKDWORD) & 0x3FF0000) >> 16;
 			break;
-		} else {
-			ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S1 Rx IQK Fail!!\n"));
-			result[t][2] = 0x100;
-			result[t][3] = 0x0;
-			cnt_iqk_fail++;
 		}
+
+		RF_DBG(dm, DBG_RF_IQK, "path S1 Rx IQK Fail!!\n");
+		result[t][2] = 0x100;
+		result[t][3] = 0x0;
+		cnt_iqk_fail++;
 	}
-	if (0x00 == path_s1_ok)
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S1 IQK failed!!\n"));
+
+	if (path_s1_ok == 0x00)
+		RF_DBG(dm, DBG_RF_IQK, "path S1 IQK failed!!\n");
 #endif
 	if (is2T) {
-		_phy_path_a_stand_by_8723d(p_dm);
-		_phy_path_adda_on_8723d(p_dm, ADDA_REG, false, is2T);
-
-		odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
-		odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
-		odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+		_phy_path_a_stand_by_8723d(dm);
+		_phy_path_adda_on_8723d(dm, ADDA_REG, false, is2T);
 
+		odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x808000);
+		odm_set_bb_reg(dm, R_0xe40, MASKDWORD, 0x01007c00);
+		odm_set_bb_reg(dm, R_0xe44, MASKDWORD, 0x01004800);
 
 #if 1
-		for (i = 0 ; i < retry_count ; i++) {
-			path_s0_ok = phy_path_s0_iqk_8723d(p_dm);
+		for (i = 0; i < retry_count; i++) {
+			path_s0_ok = phy_path_s0_iqk_8723d(dm);
 			if (path_s0_ok == 0x01) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 Tx IQK Success!!\n"));
-				result[t][4] = (odm_get_bb_reg(p_dm, 0xe94, MASKDWORD) & 0x3FF0000) >> 16;
-				result[t][5] = (odm_get_bb_reg(p_dm, 0xe9c, MASKDWORD) & 0x3FF0000) >> 16;
+				RF_DBG(dm, DBG_RF_IQK,
+				       "path S0 Tx IQK Success!!\n");
+				result[t][4] = (odm_get_bb_reg(dm, R_0xe94, MASKDWORD) & 0x3FF0000) >> 16;
+				result[t][5] = (odm_get_bb_reg(dm, R_0xe9c, MASKDWORD) & 0x3FF0000) >> 16;
 				break;
-			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 Tx IQK Fail!!\n"));
-				result[t][4] = 0x100;
-				result[t][5] = 0x0;
-				cnt_iqk_fail++;
 			}
+
+			RF_DBG(dm, DBG_RF_IQK, "path S0 Tx IQK Fail!!\n");
+			result[t][4] = 0x100;
+			result[t][5] = 0x0;
+			cnt_iqk_fail++;
 #if 0
 			else if (i == (retry_count - 1) && path_s1_ok == 0x01) {
 				RT_DISP(FINIT, INIT_IQK, ("path S0 IQK Only  Tx Success!!\n"));
 
-				result[t][0] = (odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_B, MASKDWORD) & 0x3FF0000) >> 16;
-				result[t][1] = (odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_B, MASKDWORD) & 0x3FF0000) >> 16;
+				result[t][0] = (odm_get_bb_reg(dm, REG_TX_POWER_BEFORE_IQK_B, MASKDWORD) & 0x3FF0000) >> 16;
+				result[t][1] = (odm_get_bb_reg(dm, REG_TX_POWER_AFTER_IQK_B, MASKDWORD) & 0x3FF0000) >> 16;
 			}
 #endif
 		}
 #endif
 
 #if 1
-		for (i = 0 ; i < retry_count ; i++) {
-			path_s0_ok = phy_path_s0_rx_iqk_8723d(p_dm, is2T);
+		for (i = 0; i < retry_count; i++) {
+			path_s0_ok = phy_path_s0_rx_iqk_8723d(dm, is2T);
 			if (path_s0_ok == 0x03) {
-				ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 Rx IQK Success!!\n"));
-				/*				result[t][0] = (odm_get_bb_reg(p_dm, REG_TX_POWER_BEFORE_IQK_A, MASKDWORD)&0x3FF0000)>>16;*/
-				/*				result[t][1] = (odm_get_bb_reg(p_dm, REG_TX_POWER_AFTER_IQK_A, MASKDWORD)&0x3FF0000)>>16;*/
-				result[t][6] = (odm_get_bb_reg(p_dm, 0xea4, MASKDWORD) & 0x3FF0000) >> 16;
-				result[t][7] = (odm_get_bb_reg(p_dm, 0xeac, MASKDWORD) & 0x3FF0000) >> 16;
+				RF_DBG(dm, DBG_RF_IQK,
+				       "path S0 Rx IQK Success!!\n");
+#if 0
+				/*				result[t][0] = (odm_get_bb_reg(dm, R_0xe94, MASKDWORD)&0x3FF0000)>>16;*/
+				/*				result[t][1] = (odm_get_bb_reg(dm, R_0xe9c, MASKDWORD)&0x3FF0000)>>16;*/
+#endif
+				result[t][6] = (odm_get_bb_reg(dm, R_0xea4, MASKDWORD) & 0x3FF0000) >> 16;
+				result[t][7] = (odm_get_bb_reg(dm, R_0xeac, MASKDWORD) & 0x3FF0000) >> 16;
 				break;
-			} else {
-				ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 Rx IQK Fail!!\n"));
-				result[t][6] = 0x100;
-				result[t][7] = 0x0;
-				cnt_iqk_fail++;
 			}
+
+			RF_DBG(dm, DBG_RF_IQK, "path S0 Rx IQK Fail!!\n");
+			result[t][6] = 0x100;
+			result[t][7] = 0x0;
+			cnt_iqk_fail++;
 		}
 
-		if (0x00 == path_s0_ok)
-			ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("path S0 IQK failed!!\n"));
+		if (path_s0_ok == 0x00)
+			RF_DBG(dm, DBG_RF_IQK, "path S0 IQK failed!!\n");
 #endif
 	}
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:Back to BB mode, load original value!\n"));
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	RF_DBG(dm, DBG_RF_IQK, "IQK:Back to BB mode, load original value!\n");
+	odm_set_bb_reg(dm, R_0xe28, 0xffffff00, 0x000000);
 
 	if (t != 0) {
-		_phy_reload_adda_registers_8723d(p_dm, ADDA_REG, p_dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
+		_phy_reload_adda_registers_8723d(dm, ADDA_REG, dm->rf_calibrate_info.ADDA_backup, IQK_ADDA_REG_NUM);
 		/* Reload MAC parameters*/
-		_phy_reload_mac_registers_8723d(p_dm, IQK_MAC_REG, p_dm->rf_calibrate_info.IQK_MAC_backup);
-		_phy_reload_adda_registers_8723d(p_dm, IQK_BB_REG_92C, p_dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
+		_phy_reload_mac_registers_8723d(dm, IQK_MAC_REG, dm->rf_calibrate_info.IQK_MAC_backup);
+		_phy_reload_adda_registers_8723d(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup, IQK_BB_REG_NUM);
 
-		odm_set_bb_reg(p_dm, 0xc50, MASKBYTE0, 0x50);
-		odm_set_bb_reg(p_dm, 0xc50, MASKBYTE0, tmp0xc50);
+		odm_set_bb_reg(dm, R_0xc50, MASKBYTE0, 0x50);
+		odm_set_bb_reg(dm, R_0xc50, MASKBYTE0, tmp0xc50);
 		if (is2T) {
-			odm_set_bb_reg(p_dm, 0xc58, MASKBYTE0, 0x50);
-			odm_set_bb_reg(p_dm, 0xc58, MASKBYTE0, tmp0xc58);
+			odm_set_bb_reg(dm, R_0xc58, MASKBYTE0, 0x50);
+			odm_set_bb_reg(dm, R_0xc58, MASKBYTE0, tmp0xc58);
 		}
-		odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x01008c00);
-		odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x01008c00);
+		odm_set_bb_reg(dm, R_0xe30, MASKDWORD, 0x01008c00);
+		odm_set_bb_reg(dm, R_0xe34, MASKDWORD, 0x01008c00);
 	}
-	p_dm->n_iqk_cnt++;
+	dm->n_iqk_cnt++;
 	if (cnt_iqk_fail == 0)
-		p_dm->n_iqk_ok_cnt++;
+		dm->n_iqk_ok_cnt++;
 	else
-		p_dm->n_iqk_fail_cnt = p_dm->n_iqk_fail_cnt + cnt_iqk_fail;
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("_phy_iq_calibrate_8723d() <==\n"));
+		dm->n_iqk_fail_cnt = dm->n_iqk_fail_cnt + cnt_iqk_fail;
+	RF_DBG(dm, DBG_RF_IQK, "%s <==\n", __func__);
 }
 
-
-void
-_phy_lc_calibrate_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	is2T
-)
+void _phy_lc_calibrate_8723d(struct dm_struct *dm, boolean is2T)
 {
-	u8	tmp_reg;
-	u32	rf_bmode = 0, lc_cal, cnt;
+	u8 tmp_reg;
+	u32 lc_cal, cnt;
 
-	tmp_reg = odm_read_1byte(p_dm, 0xd03);
+	tmp_reg = odm_read_1byte(dm, 0xd03);
 	if ((tmp_reg & 0x70) != 0)
-		odm_write_1byte(p_dm, 0xd03, tmp_reg & 0x8F);
+		odm_write_1byte(dm, 0xd03, tmp_reg & 0x8F);
 	else
-		odm_write_1byte(p_dm, REG_TXPAUSE, 0xFF);
+		odm_write_1byte(dm, REG_TXPAUSE, 0xFF);
 	/*backup RF0x18*/
-	lc_cal = odm_get_rf_reg(p_dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK);
+	lc_cal = odm_get_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK);
 	/*Start LCK*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal | 0x08000);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal | 0x08000);
 	for (cnt = 0; cnt < 100; cnt++) {
-		if (odm_get_rf_reg(p_dm, RF_PATH_A, RF_CHNLBW, 0x8000) != 0x1)
+		if (odm_get_rf_reg(dm, RF_PATH_A, RF_CHNLBW, 0x8000) != 0x1)
 			break;
 		ODM_delay_ms(10);
 	}
 	/* Recover channel number*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, lc_cal);
 	/*Restore original situation*/
 	if ((tmp_reg & 0x70) != 0)
-		odm_write_1byte(p_dm, 0xd03, tmp_reg);
+		odm_write_1byte(dm, 0xd03, tmp_reg);
 	else
-		odm_write_1byte(p_dm, REG_TXPAUSE, 0x00);
+		odm_write_1byte(dm, REG_TXPAUSE, 0x00);
 }
 
+/* IQK version:0x2    20171109*/
 
-void
-phy_iq_calibrate_8723d(
-	void		*p_dm_void,
-	boolean	is_recovery
-)
+void phy_iq_calibrate_8723d(void *dm_void, boolean is_recovery)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u16			count = 0;
-	s32			result[4][8];
-	u8			i, final_candidate, indexforchannel;
-	boolean			is_path_s1_ok, is_path_s0_ok;
-	s32			rege94_s1, rege9c_s1, regea4_s1, regeac_s1, rege94_s0, rege9c_s0, regea4_s0, regeac_s0, reg_tmp = 0;
-	s32			regc80, regc94, regc14, regca0, regcd0, regcd4, regcd8;
-	boolean			is12simular, is13simular, is23simular;
-	u32			IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
-		REG_OFDM_0_XA_RX_IQ_IMBALANCE,	REG_OFDM_0_XB_RX_IQ_IMBALANCE,
-		REG_OFDM_0_ECCA_THRESHOLD,	REG_OFDM_0_AGC_RSSI_TABLE,
-		REG_OFDM_0_XA_TX_IQ_IMBALANCE,	REG_OFDM_0_XB_TX_IQ_IMBALANCE,
-		REG_OFDM_0_XC_TX_AFE,			REG_OFDM_0_XD_TX_AFE,
-		REG_OFDM_0_RX_IQ_EXT_ANTA
-	};
-	u32			path_sel_bb_phy_iqk;
-	u32			original_path, original_gnt, ori_path_ctrl;
-	u32			iqk_fail_b, iqk_fail_a;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	s32 result[4][8];
+	u8 i, final_candidate, indexforchannel;
+	boolean is_path_s1_ok, is_path_s0_ok;
+	s32 rege94_s1, rege9c_s1, regea4_s1, regeac_s1, rege94_s0, rege9c_s0, regea4_s0, regeac_s0, reg_tmp = 0;
+	s32 regc80, regc94, regc14, regca0, regcd0, regcd4, regcd8;
+	boolean is12simular, is13simular, is23simular;
+	u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
+		R_0xc14, R_0xc1c,
+		R_0xc4c, R_0xc78,
+		R_0xc80, R_0xc88,
+		R_0xc94, R_0xc9c,
+		R_0xca0};
+	u32 path_sel_bb_phy_iqk;
+	u32 original_path, original_gnt, ori_path_ctrl;
+	u32 iqk_fail_b, iqk_fail_a;
 
 #if 1
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("================ IQK Start ===================\n"));
+	RF_DBG(dm, DBG_RF_IQK,
+	       "================ IQK Start ===================\n");
 
-	iqk_fail_b = p_dm->n_iqk_fail_cnt;
+	iqk_fail_b = dm->n_iqk_fail_cnt;
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_INIT, ODM_DBG_LOUD, ("=====>phy_iq_calibrate_8723d\n"));
+	RF_DBG(dm, DBG_RF_INIT, "=====>%s\n", __func__);
 
-	path_sel_bb_phy_iqk = odm_get_bb_reg(p_dm, 0x948, MASKDWORD);
+	path_sel_bb_phy_iqk = odm_get_bb_reg(dm, R_0x948, MASKDWORD);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
-	if (is_recovery)
+	if (is_recovery) {
 #else
-	if (is_recovery && (!p_dm->is_in_hct_test))
+	if (is_recovery && !dm->is_in_hct_test) {
 #endif
-	{
-		ODM_RT_TRACE(p_dm, ODM_COMP_INIT, ODM_DBG_LOUD, ("phy_iq_calibrate_8723d: Return due to is_recovery!\n"));
-		_phy_reload_adda_registers_8723d(p_dm, IQK_BB_REG_92C, p_dm->rf_calibrate_info.IQK_BB_backup_recover, 9);
+		RF_DBG(dm, DBG_RF_INIT, "%s: Return due to is_recovery!\n",
+		       __func__);
+		_phy_reload_adda_registers_8723d(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup_recover, 9);
 		return;
 	}
 	/*Check & wait if BT is doing IQK*/
-	if (*(p_dm->p_mp_mode) == false)
-		_phy_check_coex_status_8723d(p_dm, true);
+	if (!(*dm->mp_mode))
+		_phy_check_coex_status_8723d(dm, true);
 
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK:Start!!!\n"));
-	odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-	p_dm->rf_calibrate_info.is_iqk_in_progress = true;
-	odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);
+	RF_DBG(dm, DBG_RF_IQK, "IQK:Start!!!\n");
+	odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+	dm->rf_calibrate_info.is_iqk_in_progress = true;
+	odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
 
 	for (i = 0; i < 8; i++) {
 		result[0][i] = 0;
@@ -2242,52 +2270,62 @@ phy_iq_calibrate_8723d(
 	for (i = 0; i < 3; i++) {
 #if 1
 		/*set path control to WL*/
-		ori_path_ctrl = odm_get_mac_reg(p_dm, 0x64, MASKBYTE3);  /*save 0x67*/
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]original 0x67 = 0x%x\n", ori_path_ctrl));
-		odm_set_mac_reg(p_dm, 0x64, BIT(31), 0x1);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]set 0x67 = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
+		ori_path_ctrl = odm_get_mac_reg(dm, R_0x64, MASKBYTE3); /*save 0x67*/
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]original 0x67 = 0x%x\n",
+		       ori_path_ctrl);
+		odm_set_mac_reg(dm, R_0x64, BIT(31), 0x1);
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]set 0x67 = 0x%x\n",
+		       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
 		/*backup path & GNT value */
-		original_path = odm_get_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD);  /*save 0x70*/
-		odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
+		original_path = odm_get_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, MASKDWORD); /*save 0x70*/
+		odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0x800f0038);
 		ODM_delay_ms(1);
-		original_gnt = odm_get_bb_reg(p_dm, REG_LTECOEX_READ_DATA, MASKDWORD);  /*save 0x38*/
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]OriginalGNT = 0x%x\n", original_gnt));
+		original_gnt = odm_get_bb_reg(dm, REG_LTECOEX_READ_DATA, MASKDWORD); /*save 0x38*/
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]OriginalGNT = 0x%x\n",
+		       original_gnt);
 		/*set GNT_WL=1/GNT_BT=1  and path owner to WiFi for pause BT traffic*/
-		odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
-		odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038);	/*0x38[15:8] = 0x77*/
-		odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
+		odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, 0x0000ff00);
+		odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc0020038); /*0x38[15:8] = 0x77*/
+		odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, BIT(26), 0x1);
 #endif
-		_phy_iq_calibrate_8723d(p_dm, result, i, true);
+		_phy_iq_calibrate_8723d(dm, result, i, true);
 #if 1
 		/*Restore GNT_WL/GNT_BT  and path owner*/
-		odm_set_bb_reg(p_dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
-		odm_set_bb_reg(p_dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
-		odm_set_mac_reg(p_dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
+		odm_set_bb_reg(dm, REG_LTECOEX_WRITE_DATA, MASKDWORD, original_gnt);
+		odm_set_bb_reg(dm, REG_LTECOEX_CTRL, MASKDWORD, 0xc00f0038);
+		odm_set_mac_reg(dm, REG_LTECOEX_PATH_CONTROL, 0xffffffff, original_path);
 		/*Restore path control owner*/
-		odm_set_mac_reg(p_dm, 0x64, MASKBYTE3, ori_path_ctrl);
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]restore 0x67 = 0x%x\n", odm_get_mac_reg(p_dm, 0x64, MASKBYTE3)));
+		odm_set_mac_reg(dm, R_0x64, MASKBYTE3, ori_path_ctrl);
+		RF_DBG(dm, DBG_RF_IQK, "[IQK]restore 0x67 = 0x%x\n",
+		       odm_get_mac_reg(dm, R_0x64, MASKBYTE3));
 #endif
 		if (i == 1) {
-			is12simular = phy_simularity_compare_8723d(p_dm, result, 0, 1);
+			is12simular = phy_simularity_compare_8723d(dm, result, 0, 1);
 			if (is12simular) {
 				final_candidate = 0;
-				ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: is12simular final_candidate is %x\n", final_candidate));
+				RF_DBG(dm, DBG_RF_IQK,
+				       "IQK: is12simular final_candidate is %x\n",
+				       final_candidate);
 				break;
 			}
 		}
 
 		if (i == 2) {
-			is13simular = phy_simularity_compare_8723d(p_dm, result, 0, 2);
+			is13simular = phy_simularity_compare_8723d(dm, result, 0, 2);
 			if (is13simular) {
 				final_candidate = 0;
-				ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: is13simular final_candidate is %x\n", final_candidate));
+				RF_DBG(dm, DBG_RF_IQK,
+				       "IQK: is13simular final_candidate is %x\n",
+				       final_candidate);
 
 				break;
 			}
-			is23simular = phy_simularity_compare_8723d(p_dm, result, 1, 2);
+			is23simular = phy_simularity_compare_8723d(dm, result, 1, 2);
 			if (is23simular) {
 				final_candidate = 1;
-				ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK: is23simular final_candidate is %x\n", final_candidate));
+				RF_DBG(dm, DBG_RF_IQK,
+				       "IQK: is23simular final_candidate is %x\n",
+				       final_candidate);
 			} else {
 				for (i = 0; i < 8; i++)
 					reg_tmp += result[3][i];
@@ -2309,203 +2347,188 @@ phy_iq_calibrate_8723d(
 		rege9c_s0 = result[i][5];
 		regea4_s0 = result[i][6];
 		regeac_s0 = result[i][7];
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK] rege94_s1=%x rege9c_s1=%x regea4_s1=%x regeac_s1=%x rege94_s0=%x rege9c_s0=%x regea4_s0=%x regeac_s0=%x\n ", rege94_s1, rege9c_s1, regea4_s1, regeac_s1, rege94_s0, rege9c_s0, regea4_s0, regeac_s0));
+		RF_DBG(dm, DBG_RF_IQK,
+		       "[IQK] rege94_s1=%x rege9c_s1=%x regea4_s1=%x regeac_s1=%x rege94_s0=%x rege9c_s0=%x regea4_s0=%x regeac_s0=%x\n ",
+		       rege94_s1, rege9c_s1, regea4_s1, regeac_s1, rege94_s0,
+		       rege9c_s0, regea4_s0, regeac_s0);
 	}
 
 	if (final_candidate != 0xff) {
-		p_dm->rf_calibrate_info.rege94 = rege94_s1 = result[final_candidate][0];
-		p_dm->rf_calibrate_info.rege9c = rege9c_s1 = result[final_candidate][1];
+		dm->rf_calibrate_info.rege94 = result[final_candidate][0];
+		rege94_s1 = result[final_candidate][0];
+		dm->rf_calibrate_info.rege9c = result[final_candidate][1];
+		rege9c_s1 = result[final_candidate][1];
 		regea4_s1 = result[final_candidate][2];
 		regeac_s1 = result[final_candidate][3];
-		p_dm->rf_calibrate_info.regeb4 = rege94_s0 = result[final_candidate][4];
-		p_dm->rf_calibrate_info.regebc = rege9c_s0 = result[final_candidate][5];
+		dm->rf_calibrate_info.regeb4 = result[final_candidate][4];
+		rege94_s0 = result[final_candidate][4];
+		dm->rf_calibrate_info.regebc = result[final_candidate][5];
+		rege9c_s0 = result[final_candidate][5];
 		regea4_s0 = result[final_candidate][6];
 		regeac_s0 = result[final_candidate][7];
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK] final_candidate is %x\n", final_candidate));
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK] TX1_X=%x TX1_Y=%x RX1_X=%x RX1_Y=%x TX0_X=%x TX0_Y=%x RX0_X=%x RX0_Y=%x\n ", rege94_s1, rege9c_s1, regea4_s1, regeac_s1, rege94_s0, rege9c_s0, regea4_s0, regeac_s0));
-		is_path_s1_ok = is_path_s0_ok = true;
+		RF_DBG(dm, DBG_RF_IQK, "[IQK] final_candidate is %x\n",
+		       final_candidate);
+		RF_DBG(dm, DBG_RF_IQK,
+		       "[IQK] TX1_X=%x TX1_Y=%x RX1_X=%x RX1_Y=%x TX0_X=%x TX0_Y=%x RX0_X=%x RX0_Y=%x\n ",
+		       rege94_s1, rege9c_s1, regea4_s1, regeac_s1, rege94_s0,
+		       rege9c_s0, regea4_s0, regeac_s0);
+		is_path_s1_ok = true;
+		is_path_s0_ok = true;
 	} else {
-		ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK] FAIL use default value\n"));
-		p_dm->rf_calibrate_info.rege94 = p_dm->rf_calibrate_info.regeb4 = 0x100;
-		p_dm->rf_calibrate_info.rege9c = p_dm->rf_calibrate_info.regebc = 0x0;
+		RF_DBG(dm, DBG_RF_IQK, "[IQK] FAIL use default value\n");
+		dm->rf_calibrate_info.rege94 = 0x100;
+		dm->rf_calibrate_info.regeb4 = 0x100;
+		dm->rf_calibrate_info.rege9c = 0x0;
+		dm->rf_calibrate_info.regebc = 0x0;
 	}
 
 	if (rege94_s1 != 0)
-		_phy_path_s1_fill_iqk_matrix_8723d(p_dm, is_path_s1_ok, result, final_candidate, (regea4_s1 == 0));
+		_phy_path_s1_fill_iqk_matrix_8723d(dm, is_path_s1_ok, result, final_candidate, (regea4_s1 == 0));
 	if (rege94_s0 != 0)
-		_phy_path_s0_fill_iqk_matrix_8723d(p_dm, is_path_s0_ok, result, final_candidate, (regea4_s0 == 0));
-
-	iqk_fail_a= p_dm->n_iqk_fail_cnt;
-	if( iqk_fail_a - iqk_fail_b > 0 )
-		RT_TRACE(COMP_INIT, DBG_LOUD, ("[8723dIQK]n_iqk_fail_cnt+,IQK restore to default value !\n"));
-	
-	regc80 = odm_get_bb_reg(p_dm, 0xc80, MASKDWORD);
-	regc94 = odm_get_bb_reg(p_dm, 0xc94, MASKDWORD);
-	regc14 = odm_get_bb_reg(p_dm, 0xc14, MASKDWORD);
-	regca0 = odm_get_bb_reg(p_dm, 0xca0, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xc80 = 0x%x 0xc94 = 0x%x 0xc14 = 0x%x 0xca0 = 0x%x\n", regc80, regc94, regc14, regca0));
-
-	regcd0 = odm_get_bb_reg(p_dm, 0xcd0, MASKDWORD);
-	regcd4 = odm_get_bb_reg(p_dm, 0xcd4, MASKDWORD);
-	regcd8 = odm_get_bb_reg(p_dm, 0xcd8, MASKDWORD);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("[IQK]0xcd0 = 0x%x 0xcd4 = 0x%x 0xcd8 = 0x%x\n", regcd0, regcd4, regcd8));
+		_phy_path_s0_fill_iqk_matrix_8723d(dm, is_path_s0_ok, result, final_candidate, (regea4_s0 == 0));
+
+	iqk_fail_a = dm->n_iqk_fail_cnt;
+	if (iqk_fail_a - iqk_fail_b > 0)
+		RF_DBG(dm, DBG_RF_IQK,
+		       "[8723dIQK]n_iqk_fail_cnt+,IQK restore to default value !\n");
+
+	regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
+	regc94 = odm_get_bb_reg(dm, R_0xc94, MASKDWORD);
+	regc14 = odm_get_bb_reg(dm, R_0xc14, MASKDWORD);
+	regca0 = odm_get_bb_reg(dm, R_0xca0, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK,
+	       "[IQK]0xc80 = 0x%x 0xc94 = 0x%x 0xc14 = 0x%x 0xca0 = 0x%x\n",
+	       regc80, regc94, regc14, regca0);
+
+	regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
+	regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
+	regcd8 = odm_get_bb_reg(dm, R_0xcd8, MASKDWORD);
+	RF_DBG(dm, DBG_RF_IQK, "[IQK]0xcd0 = 0x%x 0xcd4 = 0x%x 0xcd8 = 0x%x\n",
+	       regcd0, regcd4, regcd8);
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	indexforchannel = odm_get_right_chnl_place_for_iqk(*p_dm->p_channel);
+	indexforchannel = odm_get_right_chnl_place_for_iqk(*dm->channel);
 #else
 	indexforchannel = 0;
 #endif
 
 	if (final_candidate < 4) {
 		for (i = 0; i < iqk_matrix_reg_num; i++)
-			p_dm->rf_calibrate_info.iqk_matrix_reg_setting[indexforchannel].value[0][i] = result[final_candidate][i];
-		p_dm->rf_calibrate_info.iqk_matrix_reg_setting[indexforchannel].is_iqk_done = true;
+			dm->rf_calibrate_info.iqk_matrix_reg_setting[indexforchannel].value[0][i] = result[final_candidate][i];
+		dm->rf_calibrate_info.iqk_matrix_reg_setting[indexforchannel].is_iqk_done = true;
 	}
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("\nIQK OK indexforchannel %d.\n", indexforchannel));
-	_phy_save_adda_registers_8723d(p_dm, IQK_BB_REG_92C, p_dm->rf_calibrate_info.IQK_BB_backup_recover, IQK_BB_REG_NUM);
+	RF_DBG(dm, DBG_RF_IQK, "\nIQK OK indexforchannel %d.\n",
+	       indexforchannel);
+	_phy_save_adda_registers_8723d(dm, IQK_BB_REG_92C, dm->rf_calibrate_info.IQK_BB_backup_recover, IQK_BB_REG_NUM);
 
-	if (*(p_dm->p_mp_mode) == false)
-		_phy_check_coex_status_8723d(p_dm, false);
+	if (!(*dm->mp_mode))
+		_phy_check_coex_status_8723d(dm, false);
 
-	odm_set_bb_reg(p_dm, 0x948, MASKDWORD, path_sel_bb_phy_iqk);
-	ODM_RT_TRACE(p_dm, ODM_COMP_CALIBRATION, ODM_DBG_LOUD, ("IQK finished\n"));
+	odm_set_bb_reg(dm, R_0x948, MASKDWORD, path_sel_bb_phy_iqk);
+	RF_DBG(dm, DBG_RF_IQK, "IQK finished\n");
 #endif
 }
 
-
-void
-phy_lc_calibrate_8723d(
-	void		*p_dm_void
-)
+void phy_lc_calibrate_8723d(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	_phy_lc_calibrate_8723d(p_dm, false);
+	_phy_lc_calibrate_8723d(dm, false);
 }
 
-void _phy_set_rf_path_switch_8723d(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm,
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+void _phy_set_rf_path_switch_8723d(struct dm_struct *dm,
 #else
-	struct _ADAPTER	*p_adapter,
+void _phy_set_rf_path_switch_8723d(void *adapter,
 #endif
-	boolean		is_main,
-	boolean		is2T
-)
+				   boolean is_main, boolean is2T)
 {
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->odmpriv;
-#endif
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #endif
 
 	if (is_main)
-		odm_set_mac_reg(p_dm, 0x7C4, MASKLWORD, 0x7700);
+		odm_set_mac_reg(dm, R_0x7c4, MASKLWORD, 0x7700);
 	else
-		odm_set_mac_reg(p_dm, 0x7C4, MASKLWORD, 0xDD00);
+		odm_set_mac_reg(dm, R_0x7c4, MASKLWORD, 0xDD00);
 
-	odm_set_mac_reg(p_dm, 0x7C0, MASKDWORD, 0xC00F0038);
-	odm_set_mac_reg(p_dm, 0x70, BIT(26), 1);
-	odm_set_mac_reg(p_dm, 0x64, BIT(31), 1);
+	odm_set_mac_reg(dm, R_0x7c0, MASKDWORD, 0xC00F0038);
+	odm_set_mac_reg(dm, R_0x70, BIT(26), 1);
+	odm_set_mac_reg(dm, R_0x64, BIT(31), 1);
 }
 
-void phy_set_rf_path_switch_8723d(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm,
+
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+void phy_set_rf_path_switch_8723d(struct dm_struct *dm,
 #else
-	struct _ADAPTER	*p_adapter,
+void phy_set_rf_path_switch_8723d(void *adapter,
 #endif
-	boolean		is_main
-)
+				  boolean is_main)
 {
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->odmpriv;
-#endif
-
 #if DISABLE_BB_RF
 	return;
 #endif
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	_phy_set_rf_path_switch_8723d(p_adapter, is_main, true);
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	_phy_set_rf_path_switch_8723d(dm, is_main, true);
+#else
+	_phy_set_rf_path_switch_8723d(adapter, is_main, true);
+#endif
 #endif
-
 }
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 boolean _phy_query_rf_path_switch_8723d(
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm,
+	struct dm_struct *dm,
 #else
-	struct _ADAPTER	*p_adapter,
+	ADAPTER *adapter,
 #endif
-	boolean		is2T
-)
+	boolean is2T)
 {
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->odmpriv;
+	struct dm_struct *dm = &hal_data->odmpriv;
 #endif
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #endif
 #endif
 
-
-	if (odm_get_bb_reg(p_dm, 0x7C4, MASKLWORD) == 0x7700)
+	if (odm_get_bb_reg(dm, R_0x7c4, MASKLWORD) == 0x7700)
 		return true;
 	else
 		return false;
-
 }
 
-
-
-
 boolean phy_query_rf_path_switch_8723d(
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm
+	struct dm_struct *dm
 #else
-	struct _ADAPTER	*p_adapter
+	void *adapter
 #endif
-)
+	)
 {
-
 #if DISABLE_BB_RF
 	return true;
 #endif
 
 #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
-	return _phy_query_rf_path_switch_8723d(p_adapter, false);
+	return _phy_query_rf_path_switch_8723d(adapter, false);
 #else
-	return _phy_query_rf_path_switch_8723d(p_dm, false);
+	return _phy_query_rf_path_switch_8723d(dm, false);
 #endif
-
 }
 #endif
 
-
-
 #else
 
-void
-phy_iq_calibrate_8723d(
-	void		*p_dm_void,
-	boolean	is_recovery
-) {}
-void
-phy_lc_calibrate_8723d(
-	void		*p_dm_void
-) {}
-
-void
-odm_tx_pwr_track_set_pwr_8723d(
-	struct PHY_DM_STRUCT			*p_dm,
-	enum pwrtrack_method	method,
-	u8				rf_path,
-	u8				channel_mapped_index
-) {}
+void phy_iq_calibrate_8723d(void *dm_void, boolean is_recovery) {}
+void phy_lc_calibrate_8723d(void *dm_void) {}
+
+void odm_tx_pwr_track_set_pwr_8723d(struct dm_struct *dm,
+				    enum pwrtrack_method method, u8 rf_path,
+				    u8 channel_mapped_index) {}
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.h
index 614004d370a2..a203767152b5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/halrf/rtl8723d/halrf_8723d.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -13,118 +14,71 @@
  *
  *****************************************************************************/
 
-#ifndef __HAL_PHY_RF_8723D_H__
-#define __HAL_PHY_RF_8723D_H__
+#ifndef __HALRF_8723D_H__
+#define __HALRF_8723D_H__
 
 /*--------------------------Define Parameters-------------------------------*/
-#define	IQK_DELAY_TIME_8723D		10		/* ms */
-#define	index_mapping_NUM_8723D	15
-#define AVG_THERMAL_NUM_8723D	4
+#define IQK_DELAY_TIME_8723D 10 /* ms */
+#define index_mapping_NUM_8723D 15
+#define AVG_THERMAL_NUM_8723D 4
 #define RF_T_METER_8723D 0x42
 
-void configure_txpower_track_8723d(
-	struct _TXPWRTRACK_CFG	*p_config
-);
+void configure_txpower_track_8723d(struct txpwrtrack_cfg *config);
 
-void
-get_delta_swing_table_8723d(
-	void		*p_dm_void,
-	u8 **temperature_up_a,
-	u8 **temperature_down_a,
-	u8 **temperature_up_b,
-	u8 **temperature_down_b
-);
+void get_delta_swing_table_8723d(void *dm_void, u8 **temperature_up_a,
+				 u8 **temperature_down_a, u8 **temperature_up_b,
+				 u8 **temperature_down_b);
 
-void
-set_cck_filter_coefficient_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		cck_swing_index
-);
-
-void do_iqk_8723d(
-	void		*p_dm_void,
-	u8		delta_thermal_index,
-	u8		thermal_value,
-	u8		threshold
-);
+void set_cck_filter_coefficient_8723d(struct dm_struct *dm, u8 cck_swing_index);
 
-void
-odm_tx_pwr_track_set_pwr_8723d(
-	void		*p_dm_void,
-	enum pwrtrack_method	method,
-	u8				rf_path,
-	u8				channel_mapped_index
-);
+void do_iqk_8723d(void *dm_void, u8 delta_thermal_index, u8 thermal_value,
+		  u8 threshold);
 
-void
-odm_txxtaltrack_set_xtal_8723d(
-	void		*p_dm_void
-);
+void odm_tx_pwr_track_set_pwr_8723d(void *dm_void, enum pwrtrack_method method,
+				    u8 rf_path, u8 channel_mapped_index);
 
-/* 1 7.	IQK */
+void odm_txxtaltrack_set_xtal_8723d(void *dm_void);
 
-void
-phy_iq_calibrate_8723d(
-	void		*p_dm_void,
-	boolean	is_recovery);
+/* 1 7.	IQK */
 
+void phy_iq_calibrate_8723d(void *dm_void, boolean is_recovery);
 
 /*
  * LC calibrate
- *   */
-void
-phy_lc_calibrate_8723d(
-	void		*p_dm_void
-);
+ */
+void phy_lc_calibrate_8723d(void *dm_void);
 
 
-void phy_set_rf_path_switch_8723d(
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm,
+#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
+void phy_set_rf_path_switch_8723d(struct dm_struct *dm,
 #else
-	struct _ADAPTER	*p_adapter,
+void phy_set_rf_path_switch_8723d(void *adapter,
 #endif
-	boolean		is_main
-);
+				  boolean is_main);
 
 #if 0
 /*
  * AP calibrate
- *   */
+ */
 void
 phy_ap_calibrate_8723d(
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct PHY_DM_STRUCT		*p_dm,
+	struct dm_struct		*dm,
 #else
-	struct _ADAPTER	*p_adapter,
+	void	*adapter,
 #endif
 	s8		delta);
 void
-phy_digital_predistortion_8723d(struct _ADAPTER	*p_adapter);
+phy_digital_predistortion_8723d(void	*adapter);
 #endif
 
-void
-_phy_save_adda_registers_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*adda_reg,
-	u32		*adda_backup,
-	u32		register_num
-);
-
-void
-_phy_path_adda_on_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*adda_reg,
-	boolean		is_path_a_on,
-	boolean		is2T
-);
+void _phy_save_adda_registers_8723d(struct dm_struct *dm, u32 *adda_reg,
+				    u32 *adda_backup, u32 register_num);
 
-void
-_phy_mac_setting_calibration_8723d(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		*mac_reg,
-	u32		*mac_backup
-);
+void _phy_path_adda_on_8723d(struct dm_struct *dm, u32 *adda_reg,
+			     boolean is_path_a_on, boolean is2T);
 
+void _phy_mac_setting_calibration_8723d(struct dm_struct *dm, u32 *mac_reg,
+					u32 *mac_backup);
 
-#endif	/*  #ifndef __HAL_PHY_RF_8723D_H__ */
+#endif /*#ifndef __HALRF_8723D_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/mp_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/mp_precomp.h
index 99ca5f4e1a76..34208ac03b43 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/mp_precomp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/mp_precomp.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,7 +9,17 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.c
index 63a1194fae38..d0d5db541740 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,2807 +9,2898 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-
-const u16 phy_rate_table[] = {	/*20M*/
+const u16 phy_rate_table[] = {
+	/*@20M*/
 	1, 2, 5, 11,
 	6, 9, 12, 18, 24, 36, 48, 54,
-	6, 13, 19, 26, 39, 52, 58, 65,		/*MCS0~7*/
-	13, 26, 39, 52, 78, 104, 117, 130		/*MCS8~15*/
+	6, 13, 19, 26, 39, 52, 58, 65, /*@MCS0~7*/
+	13, 26, 39, 52, 78, 104, 117, 130 /*@MCS8~15*/
 };
 
-void
-phydm_traffic_load_decision(
-	void	*p_dm_void
-)
+void phydm_traffic_load_decision(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		bit_shift_num = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 shift = 0;
 
-	/*---TP & Trafic-load calculation---*/
+	/*@---TP & Trafic-load calculation---*/
 
-	if (p_dm->last_tx_ok_cnt > (*(p_dm->p_num_tx_bytes_unicast)))
-		p_dm->last_tx_ok_cnt = (*(p_dm->p_num_tx_bytes_unicast));
+	if (dm->last_tx_ok_cnt > *dm->num_tx_bytes_unicast)
+		dm->last_tx_ok_cnt = *dm->num_tx_bytes_unicast;
 
-	if (p_dm->last_rx_ok_cnt > (*(p_dm->p_num_rx_bytes_unicast)))
-		p_dm->last_rx_ok_cnt = (*(p_dm->p_num_rx_bytes_unicast));
+	if (dm->last_rx_ok_cnt > *dm->num_rx_bytes_unicast)
+		dm->last_rx_ok_cnt = *dm->num_rx_bytes_unicast;
 
-	p_dm->cur_tx_ok_cnt =  *(p_dm->p_num_tx_bytes_unicast) - p_dm->last_tx_ok_cnt;
-	p_dm->cur_rx_ok_cnt =  *(p_dm->p_num_rx_bytes_unicast) - p_dm->last_rx_ok_cnt;
-	p_dm->last_tx_ok_cnt =  *(p_dm->p_num_tx_bytes_unicast);
-	p_dm->last_rx_ok_cnt =  *(p_dm->p_num_rx_bytes_unicast);
+	dm->cur_tx_ok_cnt = *dm->num_tx_bytes_unicast - dm->last_tx_ok_cnt;
+	dm->cur_rx_ok_cnt = *dm->num_rx_bytes_unicast - dm->last_rx_ok_cnt;
+	dm->last_tx_ok_cnt = *dm->num_tx_bytes_unicast;
+	dm->last_rx_ok_cnt = *dm->num_rx_bytes_unicast;
 
-	bit_shift_num = 17 + (PHYDM_WATCH_DOG_PERIOD - 1); /*AP:  <<3(8bit), >>20(10^6,M), >>0(1sec)*/
-													/*WIN&CE:  <<3(8bit), >>20(10^6,M), >>1(2sec)*/
+	/*@AP:  <<3(8bit), >>20(10^6,M), >>0(1sec)*/
+	shift = 17 + (PHYDM_WATCH_DOG_PERIOD - 1);
+	/*@WIN&CE:  <<3(8bit), >>20(10^6,M), >>1(2sec)*/
 
-	p_dm->tx_tp = ((p_dm->tx_tp) >> 1) + (u32)(((p_dm->cur_tx_ok_cnt) >> bit_shift_num) >> 1);
-	p_dm->rx_tp = ((p_dm->rx_tp) >> 1) + (u32)(((p_dm->cur_rx_ok_cnt) >> bit_shift_num) >> 1);
+	dm->tx_tp = (dm->tx_tp >> 1) + (u32)((dm->cur_tx_ok_cnt >> shift) >> 1);
+	dm->rx_tp = (dm->rx_tp >> 1) + (u32)((dm->cur_rx_ok_cnt >> shift) >> 1);
 
-	p_dm->total_tp = p_dm->tx_tp + p_dm->rx_tp;
+	dm->total_tp = dm->tx_tp + dm->rx_tp;
 
-	/*[Calculate TX/RX state]*/
-	if (p_dm->tx_tp > (p_dm->rx_tp << 1))
-		p_dm->txrx_state_all = TX_STATE;
-	else if (p_dm->rx_tp > (p_dm->tx_tp << 1))
-		p_dm->txrx_state_all = RX_STATE;
+	/*@[Calculate TX/RX state]*/
+	if (dm->tx_tp > (dm->rx_tp << 1))
+		dm->txrx_state_all = TX_STATE;
+	else if (dm->rx_tp > (dm->tx_tp << 1))
+		dm->txrx_state_all = RX_STATE;
 	else
-		p_dm->txrx_state_all = BI_DIRECTION_STATE;
+		dm->txrx_state_all = BI_DIRECTION_STATE;
+
+	/*@[Traffic load decision]*/
+	dm->pre_traffic_load = dm->traffic_load;
+
+	if (dm->cur_tx_ok_cnt > 1875000 || dm->cur_rx_ok_cnt > 1875000) {
+		/* @( 1.875M * 8bit ) / 2sec= 7.5M bits /sec )*/
+		dm->traffic_load = TRAFFIC_HIGH;
+	} else if (dm->cur_tx_ok_cnt > 500000 || dm->cur_rx_ok_cnt > 500000) {
+		/*@( 0.5M * 8bit ) / 2sec =  2M bits /sec )*/
+		dm->traffic_load = TRAFFIC_MID;
+	} else if (dm->cur_tx_ok_cnt > 100000 || dm->cur_rx_ok_cnt > 100000) {
+		/*@( 0.1M * 8bit ) / 2sec =  0.4M bits /sec )*/
+		dm->traffic_load = TRAFFIC_LOW;
+	} else if (dm->cur_tx_ok_cnt > 25000 || dm->cur_rx_ok_cnt > 25000) {
+		/*@( 0.025M * 8bit ) / 2sec =  0.1M bits /sec )*/
+		dm->traffic_load = TRAFFIC_ULTRA_LOW;
+	} else {
+		dm->traffic_load = TRAFFIC_NO_TP;
+	}
 
-	/*[Calculate consecutive idlel time]*/
-	if (p_dm->total_tp == 0)
-		p_dm->consecutive_idlel_time += PHYDM_WATCH_DOG_PERIOD;
+	/*@[Calculate consecutive idlel time]*/
+	if (dm->traffic_load == 0)
+		dm->consecutive_idlel_time += PHYDM_WATCH_DOG_PERIOD;
 	else
-		p_dm->consecutive_idlel_time = 0;
-
-	/*[Traffic load decision]*/
-	p_dm->pre_traffic_load = p_dm->traffic_load;
-
-	if (p_dm->cur_tx_ok_cnt > 1875000 || p_dm->cur_rx_ok_cnt > 1875000) {		/* ( 1.875M * 8bit ) / 2sec= 7.5M bits /sec )*/
+		dm->consecutive_idlel_time = 0;
 
-		p_dm->traffic_load = TRAFFIC_HIGH;
-		/**/
-	} else if (p_dm->cur_tx_ok_cnt > 500000 || p_dm->cur_rx_ok_cnt > 500000) { /*( 0.5M * 8bit ) / 2sec =  2M bits /sec )*/
-
-		p_dm->traffic_load = TRAFFIC_MID;
-		/**/
-	} else if (p_dm->cur_tx_ok_cnt > 100000 || p_dm->cur_rx_ok_cnt > 100000)  { /*( 0.1M * 8bit ) / 2sec =  0.4M bits /sec )*/
+	#if 0
+	PHYDM_DBG(dm, DBG_COMMON_FLOW,
+		  "cur_tx_ok_cnt = %d, cur_rx_ok_cnt = %d, last_tx_ok_cnt = %d, last_rx_ok_cnt = %d\n",
+		  dm->cur_tx_ok_cnt, dm->cur_rx_ok_cnt, dm->last_tx_ok_cnt,
+		  dm->last_rx_ok_cnt);
 
-		p_dm->traffic_load = TRAFFIC_LOW;
-		/**/
-	} else {
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "tx_tp = %d, rx_tp = %d\n", dm->tx_tp,
+		  dm->rx_tp);
+	#endif
+}
 
-		p_dm->traffic_load = TRAFFIC_ULTRA_LOW;
-		/**/
+void phydm_cck_new_agc_chk(struct dm_struct *dm)
+{
+	dm->cck_new_agc = 0;
+
+#if ((RTL8723D_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || \
+	(RTL8821C_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || \
+	(RTL8710B_SUPPORT == 1) || (RTL8192F_SUPPORT == 1) || \
+	(RTL8195B_SUPPORT == 1) || (RTL8198F_SUPPORT == 1) || \
+	(RTL8822C_SUPPORT == 1) || (RTL8721D_SUPPORT == 1))
+	if (dm->support_ic_type &
+	    (ODM_RTL8723D | ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8197F |
+	    ODM_RTL8710B | ODM_RTL8192F | ODM_RTL8195B | ODM_RTL8721D)) {
+		/*@1: new agc  0: old agc*/
+		dm->cck_new_agc = (boolean)odm_get_bb_reg(dm, R_0xa9c, BIT(17));
+	} else if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8822C)) {
+		/*@1: new agc  0: old agc*/
+		dm->cck_new_agc = (boolean)odm_get_bb_reg(dm, R_0x1a9c,
+							  BIT(17));
 	}
-
-	/*
-	PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("cur_tx_ok_cnt = %d, cur_rx_ok_cnt = %d, last_tx_ok_cnt = %d, last_rx_ok_cnt = %d\n",
-		p_dm->cur_tx_ok_cnt, p_dm->cur_rx_ok_cnt, p_dm->last_tx_ok_cnt, p_dm->last_rx_ok_cnt));
-
-	PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("tx_tp = %d, rx_tp = %d\n",
-		p_dm->tx_tp, p_dm->rx_tp));
-	*/
-		
+#endif
 }
 
-void
-phydm_init_cck_setting(
-	struct PHY_DM_STRUCT		*p_dm
-)
+/*select 3 or 4 bit LNA */
+void phydm_cck_lna_bit_num_chk(struct dm_struct *dm)
 {
-#if (RTL8192E_SUPPORT == 1)
+	boolean report_type = 0;
+	#if (RTL8192E_SUPPORT == 1)
 	u32 value_824, value_82c;
-#endif
-
-	p_dm->is_cck_high_power = (boolean) odm_get_bb_reg(p_dm, ODM_REG(CCK_RPT_FORMAT, p_dm), ODM_BIT(CCK_RPT_FORMAT, p_dm));
+	#endif
 
-	phydm_config_cck_rx_antenna_init(p_dm);
-	phydm_config_cck_rx_path(p_dm, BB_PATH_A);
+	#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+	/* @0x824[9] = 0x82C[9] = 0xA80[7] those registers setting
+	 * should be equal or CCK RSSI report may be incorrect
+	 */
+		value_824 = odm_get_bb_reg(dm, R_0x824, BIT(9));
+		value_82c = odm_get_bb_reg(dm, R_0x82c, BIT(9));
 
-#if (RTL8192E_SUPPORT == 1)
-	if (p_dm->support_ic_type & (ODM_RTL8192E)) {
+		if (value_824 != value_82c)
+			odm_set_bb_reg(dm, R_0x82c, BIT(9), value_824);
+		odm_set_bb_reg(dm, R_0xa80, BIT(7), value_824);
+		report_type = (boolean)value_824;
+	}
+	#endif
 
-		/* 0x824[9] = 0x82C[9] = 0xA80[7]  those registers setting should be equal or CCK RSSI report may be incorrect */
-		value_824 = odm_get_bb_reg(p_dm, 0x824, BIT(9));
-		value_82c = odm_get_bb_reg(p_dm, 0x82c, BIT(9));
+	#if (RTL8703B_SUPPORT || RTL8723D_SUPPORT || RTL8710B_SUPPORT)
+	if (dm->support_ic_type &
+	    (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+		report_type = (boolean)odm_get_bb_reg(dm, R_0x950, BIT(11));
 
-		if (value_824 != value_82c)
-			odm_set_bb_reg(p_dm, 0x82c, BIT(9), value_824);
-		odm_set_bb_reg(p_dm, 0xa80, BIT(7), value_824);
-		p_dm->cck_agc_report_type = (boolean)value_824;
+		if (report_type != 1)
+			pr_debug("[Warning] CCK should be 4bit LNA\n");
+	}
+	#endif
 
-		PHYDM_DBG(p_dm, ODM_COMP_INIT, ("cck_agc_report_type = (( %d )), ext_lna_gain = (( %d ))\n", p_dm->cck_agc_report_type, p_dm->ext_lna_gain));
+	#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) {
+		if (dm->default_rf_set_8821c == SWITCH_TO_BTG)
+			report_type = 1;
 	}
-#endif
+	#endif
 
-#if ((RTL8703B_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
-	if (p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B)) {
+	dm->cck_agc_report_type = report_type;
 
-		p_dm->cck_agc_report_type = odm_get_bb_reg(p_dm, 0x950, BIT(11)) ? 1 : 0; /*1: 4bit LNA, 0: 3bit LNA */
+	PHYDM_DBG(dm, ODM_COMP_INIT, "cck_agc_report_type=((%d))\n",
+		  dm->cck_agc_report_type);
+}
 
-		if (p_dm->cck_agc_report_type != 1) {
-			dbg_print("[Warning] 8703B/8723D/8710B CCK should be 4bit LNA, ie. 0x950[11] = 1\n");
-			/**/
-		}
-	}
-#endif
+void phydm_init_cck_setting(struct dm_struct *dm)
+{
+	u32 reg_tmp = 0;
+	u32 mask_tmp = 0;
 
-#if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8821C) {
-		p_dm->cck_new_agc = odm_get_bb_reg(p_dm, 0xa9c, BIT(17)) ? true : false;          /*1: new agc  0: old agc*/
-		if (p_dm->cck_new_agc == 0 && p_dm->default_rf_set_8821c == SWITCH_TO_BTG)
-			p_dm->cck_agc_report_type = 1;
-	}
-#endif
+	reg_tmp = ODM_REG(CCK_RPT_FORMAT, dm);
+	mask_tmp = ODM_BIT(CCK_RPT_FORMAT, dm);
+	dm->is_cck_high_power = (boolean)odm_get_bb_reg(dm, reg_tmp, mask_tmp);
 
-#if ((RTL8723D_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
-	if (p_dm->support_ic_type & (ODM_RTL8723D | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8710B))
-		p_dm->cck_new_agc = odm_get_bb_reg(p_dm, 0xa9c, BIT(17)) ? true : false;          /*1: new agc  0: old agc*/
-	else
-#endif
-	{
-		p_dm->cck_new_agc = false;
-		/**/
-	}
+	PHYDM_DBG(dm, ODM_COMP_INIT, "ext_lna_gain=((%d))\n", dm->ext_lna_gain);
 
-	phydm_get_cck_rssi_table_from_reg(p_dm);
+	phydm_config_cck_rx_antenna_init(dm);
 
+	if (dm->support_ic_type & (ODM_RTL8192F))
+		phydm_config_cck_rx_path(dm, BB_PATH_AB);
+	else
+		phydm_config_cck_rx_path(dm, BB_PATH_A);
+
+	phydm_cck_new_agc_chk(dm);
+	phydm_cck_lna_bit_num_chk(dm);
+	phydm_get_cck_rssi_table_from_reg(dm);
 }
 
-void
-phydm_init_hw_info_by_rfe(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_init_hw_info_by_rfe(struct dm_struct *dm)
 {
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		phydm_init_hw_info_by_rfe_type_8822b(p_dm);
+	/*@if (dm->support_ic_type & ODM_RTL8822B)*/
+		/*@phydm_init_hw_info_by_rfe_type_8822b(dm);*/
 #endif
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8821C)
-		phydm_init_hw_info_by_rfe_type_8821c(p_dm);
+	if (dm->support_ic_type & ODM_RTL8821C)
+		phydm_init_hw_info_by_rfe_type_8821c(dm);
 #endif
 #if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		phydm_init_hw_info_by_rfe_type_8197f(p_dm);
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_init_hw_info_by_rfe_type_8197f(dm);
 #endif
 }
 
-void
-phydm_common_info_self_init(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_common_info_self_init(struct dm_struct *dm)
 {
-	phydm_init_cck_setting(p_dm);
-	p_dm->rf_path_rx_enable = (u8) odm_get_bb_reg(p_dm, ODM_REG(BB_RX_PATH, p_dm), ODM_BIT(BB_RX_PATH, p_dm));
+	u32 reg_tmp = 0;
+	u32 mask_tmp = 0;
+
+	/*@BB IP Generation*/
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		dm->ic_ip_series = PHYDM_IC_JGR3;
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		dm->ic_ip_series = PHYDM_IC_AC;
+	else if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		dm->ic_ip_series = PHYDM_IC_N;
+
+	/*@BB phy-status Generation*/
+	if (dm->support_ic_type & PHYSTS_3RD_TYPE_IC)
+		dm->ic_phy_sts_type = PHYDM_PHYSTS_TYPE_3;
+	else if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC)
+		dm->ic_phy_sts_type = PHYDM_PHYSTS_TYPE_2;
+	else
+		dm->ic_phy_sts_type = PHYDM_PHYSTS_TYPE_1;
+
+	phydm_init_cck_setting(dm);
+
+	reg_tmp = ODM_REG(BB_RX_PATH, dm);
+	mask_tmp = ODM_BIT(BB_RX_PATH, dm);
+	dm->rf_path_rx_enable = (u8)odm_get_bb_reg(dm, reg_tmp, mask_tmp);
 #if (DM_ODM_SUPPORT_TYPE != ODM_CE)
-	p_dm->p_is_net_closed = &p_dm->BOOLEAN_temp;
-
-	phydm_init_debug_setting(p_dm);
-#endif
-	phydm_init_trx_antenna_setting(p_dm);
-	phydm_init_soft_ml_setting(p_dm);
-
-	p_dm->phydm_period = PHYDM_WATCH_DOG_PERIOD;
-	p_dm->phydm_sys_up_time = 0;
-
-	if (p_dm->support_ic_type & ODM_IC_1SS)
-		p_dm->num_rf_path = 1;
-	else if (p_dm->support_ic_type & ODM_IC_2SS)
-		p_dm->num_rf_path = 2;
-	else if (p_dm->support_ic_type & ODM_IC_3SS)
-		p_dm->num_rf_path = 3;
-	else if (p_dm->support_ic_type & ODM_IC_4SS)
-		p_dm->num_rf_path = 4;
-
-	p_dm->tx_rate = 0xFF;
-	p_dm->rssi_min_by_path = 0xFF;
-
-	p_dm->number_linked_client = 0;
-	p_dm->pre_number_linked_client = 0;
-	p_dm->number_active_client = 0;
-	p_dm->pre_number_active_client = 0;
-
-	p_dm->last_tx_ok_cnt = 0;
-	p_dm->last_rx_ok_cnt = 0;
-	p_dm->tx_tp = 0;
-	p_dm->rx_tp = 0;
-	p_dm->total_tp = 0;
-	p_dm->traffic_load = TRAFFIC_LOW;
-
-	p_dm->nbi_set_result = 0;
-	p_dm->is_init_hw_info_by_rfe = false;
-	p_dm->pre_dbg_priority = BB_DBGPORT_RELEASE;
-	p_dm->tp_active_th = 5;
-	p_dm->disable_phydm_watchdog = 0;
-
-	p_dm->u8_dummy = 0xf;
-	p_dm->u16_dummy = 0xffff;
-	p_dm->u32_dummy = 0xffffffff;
-	
-	/*odm_memory_set(p_dm, &(p_dm->pause_lv_table.lv_dig), 0, sizeof(struct phydm_pause_lv));*/
-	p_dm->pause_lv_table.lv_cckpd = PHYDM_PAUSE_RELEASE;
-	p_dm->pause_lv_table.lv_dig = PHYDM_PAUSE_RELEASE;
+	dm->is_net_closed = &dm->BOOLEAN_temp;
+
+	phydm_init_debug_setting(dm);
+#endif
+	phydm_init_soft_ml_setting(dm);
+
+	dm->phydm_sys_up_time = 0;
+
+	if (dm->support_ic_type & ODM_IC_1SS)
+		dm->num_rf_path = 1;
+	else if (dm->support_ic_type & ODM_IC_2SS)
+		dm->num_rf_path = 2;
+	#if 0
+	/* @RTK do not has IC which is equipped with 3 RF paths,
+	 * so ODM_IC_3SS is an enpty macro and result in coverity check errors
+	 */
+	else if (dm->support_ic_type & ODM_IC_3SS)
+		dm->num_rf_path = 3;
+	#endif
+	else if (dm->support_ic_type & ODM_IC_4SS)
+		dm->num_rf_path = 4;
+	else
+		dm->num_rf_path = 1;
+
+	phydm_trx_antenna_setting_init(dm, dm->num_rf_path);
+
+	dm->tx_rate = 0xFF;
+	dm->rssi_min_by_path = 0xFF;
+
+	dm->number_linked_client = 0;
+	dm->pre_number_linked_client = 0;
+	dm->number_active_client = 0;
+	dm->pre_number_active_client = 0;
+
+	dm->last_tx_ok_cnt = 0;
+	dm->last_rx_ok_cnt = 0;
+	dm->tx_tp = 0;
+	dm->rx_tp = 0;
+	dm->total_tp = 0;
+	dm->traffic_load = TRAFFIC_LOW;
+
+	dm->nbi_set_result = 0;
+	dm->is_init_hw_info_by_rfe = false;
+	dm->pre_dbg_priority = DBGPORT_RELEASE;
+	dm->tp_active_th = 5;
+	dm->disable_phydm_watchdog = 0;
+
+	dm->u8_dummy = 0xf;
+	dm->u16_dummy = 0xffff;
+	dm->u32_dummy = 0xffffffff;
 
+	dm->pause_lv_table.lv_cckpd = PHYDM_PAUSE_RELEASE;
+	dm->pause_lv_table.lv_dig = PHYDM_PAUSE_RELEASE;
 }
 
-void
-phydm_cmn_sta_info_update(
-	void	*p_dm_void,
-	u8	macid
-)
+void phydm_cmn_sta_info_update(void *dm_void, u8 macid)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info			*p_sta = p_dm->p_phydm_sta_info[macid];
-	struct ra_sta_info				*p_ra = NULL;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info *ra = NULL;
 
-	if (is_sta_active(p_sta)) {
-		p_ra = &(p_sta->ra_info);
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA_MASK, ("[Warning] %s invalid sta_info\n", __func__));
+		PHYDM_DBG(dm, DBG_RA_MASK, "[Warning] %s invalid sta_info\n",
+			  __func__);
 		return;
 	}
 
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("MACID=%d\n", p_sta->mac_id));
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA_MASK, "MACID=%d\n", sta->mac_id);
 
-	/*[Calculate TX/RX state]*/
-	if (p_sta->tx_moving_average_tp > (p_sta->rx_moving_average_tp << 1))
-		p_ra->txrx_state= TX_STATE;
-	else if (p_sta->rx_moving_average_tp > (p_sta->tx_moving_average_tp << 1))
-		p_ra->txrx_state = RX_STATE;
+	/*@[Calculate TX/RX state]*/
+	if (sta->tx_moving_average_tp > (sta->rx_moving_average_tp << 1))
+		ra->txrx_state = TX_STATE;
+	else if (sta->rx_moving_average_tp > (sta->tx_moving_average_tp << 1))
+		ra->txrx_state = RX_STATE;
 	else
-		p_ra->txrx_state = BI_DIRECTION_STATE;
+		ra->txrx_state = BI_DIRECTION_STATE;
 
+	ra->is_noisy = dm->noisy_decision;
 }
 
-void
-phydm_common_info_self_update(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_common_info_self_update(struct dm_struct *dm)
 {
-	u8	sta_cnt = 0, num_active_client = 0;
-	u32	i, one_entry_macid = 0;
-	u32	ma_rx_tp = 0;
-	struct cmn_sta_info	*p_sta;
+	u8 sta_cnt = 0, num_active_client = 0;
+	u32 i, one_entry_macid = 0;
+	u32 ma_rx_tp = 0;
+	u32 tp_diff = 0;
+	struct cmn_sta_info *sta;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-	struct _ADAPTER	*adapter =  p_dm->adapter;
-	PMGNT_INFO	p_mgnt_info = &adapter->MgntInfo;
+	PADAPTER adapter = (PADAPTER)dm->adapter;
 
-	p_sta = p_dm->p_phydm_sta_info[0];
-	if (p_mgnt_info->mAssoc) {
-		p_sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
+	PMGNT_INFO mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+
+	sta = dm->phydm_sta_info[0];
+	if (mgnt_info->mAssoc) {
+		sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
 		for (i = 0; i < 6; i++)
-			p_sta->mac_addr[i] = p_mgnt_info->Bssid[i];
+			sta->mac_addr[i] = mgnt_info->Bssid[i];
 	} else if (GetFirstClientPort(adapter)) {
-		struct _ADAPTER	*p_client_adapter = GetFirstClientPort(adapter);
+		//void	*client_adapter = GetFirstClientPort(adapter);
+		struct _ADAPTER *client_adapter = GetFirstClientPort(adapter);
 
-		p_sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
+		sta->dm_ctrl |= STA_DM_CTRL_ACTIVE;
 		for (i = 0; i < 6; i++)
-			p_sta->mac_addr[i] = p_client_adapter->MgntInfo.Bssid[i];
+			sta->mac_addr[i] = client_adapter->MgntInfo.Bssid[i];
 	} else {
-		p_sta->dm_ctrl = p_sta->dm_ctrl & (~STA_DM_CTRL_ACTIVE);
+		sta->dm_ctrl = sta->dm_ctrl & (~STA_DM_CTRL_ACTIVE);
 		for (i = 0; i < 6; i++)
-			p_sta->mac_addr[i] = 0;
+			sta->mac_addr[i] = 0;
 	}
 
 	/* STA mode is linked to AP */
-	if (is_sta_active(p_sta) && !ACTING_AS_AP(adapter))
-		p_dm->bsta_state = true;
+	if (is_sta_active(sta) && !ACTING_AS_AP(adapter))
+		dm->bsta_state = true;
 	else
-		p_dm->bsta_state = false;
+		dm->bsta_state = false;
 #endif
 
 	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		p_sta = p_dm->p_phydm_sta_info[i];
-		if (is_sta_active(p_sta)) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
 			sta_cnt++;
-			
+
 			if (sta_cnt == 1)
 				one_entry_macid = i;
 
-			phydm_cmn_sta_info_update(p_dm, (u8)i);
+			phydm_cmn_sta_info_update(dm, (u8)i);
+			#ifdef PHYDM_BEAMFORMING_SUPPORT
+			/*@phydm_get_txbf_device_num(dm, (u8)i);*/
+			#endif
+
+			ma_rx_tp = sta->rx_moving_average_tp +
+				   sta->tx_moving_average_tp;
 
-			ma_rx_tp = p_sta->rx_moving_average_tp + p_sta->tx_moving_average_tp;
-			PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("TP[%d]: ((%d )) bit/sec\n", i, ma_rx_tp));
+			PHYDM_DBG(dm, DBG_COMMON_FLOW,
+				  "TP[%d]: ((%d )) bit/sec\n", i, ma_rx_tp);
 
 			if (ma_rx_tp > ACTIVE_TP_THRESHOLD)
 				num_active_client++;
 		}
 	}
 
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	dm->is_linked = (sta_cnt != 0) ? true : false;
+#endif
+
 	if (sta_cnt == 1) {
-		p_dm->is_one_entry_only = true;
-		p_dm->one_entry_macid = one_entry_macid;
-		p_dm->one_entry_tp = ma_rx_tp;
+		dm->is_one_entry_only = true;
+		dm->one_entry_macid = one_entry_macid;
+		dm->one_entry_tp = ma_rx_tp;
+
+		dm->tp_active_occur = 0;
 
-		p_dm->tp_active_occur = 0;
+		PHYDM_DBG(dm, DBG_COMMON_FLOW,
+			  "one_entry_tp=((%d)), pre_one_entry_tp=((%d))\n",
+			  dm->one_entry_tp, dm->pre_one_entry_tp);
 
-		PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("one_entry_tp=((%d)), pre_one_entry_tp=((%d))\n",
-			p_dm->one_entry_tp, p_dm->pre_one_entry_tp));
+		if (dm->one_entry_tp > dm->pre_one_entry_tp &&
+		    dm->pre_one_entry_tp <= 2) {
+			tp_diff = dm->one_entry_tp - dm->pre_one_entry_tp;
 
-		if ((p_dm->one_entry_tp > p_dm->pre_one_entry_tp) && (p_dm->pre_one_entry_tp <= 2)) {
-			if ((p_dm->one_entry_tp - p_dm->pre_one_entry_tp) > p_dm->tp_active_th)
-				p_dm->tp_active_occur = 1;
+			if (tp_diff > dm->tp_active_th)
+				dm->tp_active_occur = 1;
 		}
-		p_dm->pre_one_entry_tp = p_dm->one_entry_tp;
-	} else
-		p_dm->is_one_entry_only = false;
+		dm->pre_one_entry_tp = dm->one_entry_tp;
+	} else {
+		dm->is_one_entry_only = false;
+	}
 
-	p_dm->pre_number_linked_client = p_dm->number_linked_client;
-	p_dm->pre_number_active_client = p_dm->number_active_client;
+	dm->pre_number_linked_client = dm->number_linked_client;
+	dm->pre_number_active_client = dm->number_active_client;
 
-	p_dm->number_linked_client = sta_cnt;
-	p_dm->number_active_client = num_active_client;
+	dm->number_linked_client = sta_cnt;
+	dm->number_active_client = num_active_client;
 
 	/*Traffic load information update*/
-	phydm_traffic_load_decision(p_dm);
-
-	p_dm->phydm_sys_up_time += p_dm->phydm_period;
+	phydm_traffic_load_decision(dm);
 
-	p_dm->is_dfs_band = phydm_is_dfs_band(p_dm);
+	dm->phydm_sys_up_time += PHYDM_WATCH_DOG_PERIOD;
 
+	dm->is_dfs_band = phydm_is_dfs_band(dm);
+	dm->phy_dbg_info.show_phy_sts_cnt = 0;
 }
 
-void
-phydm_common_info_self_reset(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_common_info_self_reset(struct dm_struct *dm)
 {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	p_dm->phy_dbg_info.num_qry_beacon_pkt = 0;
-#endif
+	struct odm_phy_dbg_info		*dbg_t = &dm->phy_dbg_info;
+
+	dbg_t->beacon_cnt_in_period = dbg_t->num_qry_beacon_pkt;
+	dbg_t->num_qry_beacon_pkt = 0;
+
+	dm->rxsc_l = 0xff;
+	dm->rxsc_20 = 0xff;
+	dm->rxsc_40 = 0xff;
+	dm->rxsc_80 = 0xff;
 }
 
 void *
-phydm_get_structure(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			structure_type
-)
+phydm_get_structure(struct dm_struct *dm, u8 structure_type)
 
 {
-	void	*p_struct = NULL;
-#if RTL8195A_SUPPORT
-	switch (structure_type) {
-	case	PHYDM_FALSEALMCNT:
-		p_struct = &false_alm_cnt;
-		break;
-
-	case	PHYDM_CFOTRACK:
-		p_struct = &dm_cfo_track;
-		break;
+	void *structure = NULL;
 
-	case	PHYDM_ADAPTIVITY:
-		p_struct = &(p_dm->adaptivity);
-		break;
-
-	default:
-		break;
-	}
-
-#else
 	switch (structure_type) {
-	case	PHYDM_FALSEALMCNT:
-		p_struct = &(p_dm->false_alm_cnt);
+	case PHYDM_FALSEALMCNT:
+		structure = &dm->false_alm_cnt;
 		break;
 
-	case	PHYDM_CFOTRACK:
-		p_struct = &(p_dm->dm_cfo_track);
+	case PHYDM_CFOTRACK:
+		structure = &dm->dm_cfo_track;
 		break;
 
-	case	PHYDM_ADAPTIVITY:
-		p_struct = &(p_dm->adaptivity);
+	case PHYDM_ADAPTIVITY:
+		structure = &dm->adaptivity;
 		break;
 
-	case	PHYDM_DFS:
-		p_struct = &(p_dm->dfs);
+	case PHYDM_DFS:
+		structure = &dm->dfs;
 		break;
 
 	default:
 		break;
 	}
 
+	return structure;
+}
+
+void phydm_phy_info_update(struct dm_struct *dm)
+{
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822B)
+		dm->phy_dbg_info.condi_num = phydm_get_condi_num_8822b(dm);
 #endif
-	return	p_struct;
 }
 
-void
-phydm_hw_setting(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_hw_setting(struct dm_struct *dm)
 {
 #if (RTL8821A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8821)
-		odm_hw_setting_8821a(p_dm);
+	if (dm->support_ic_type & ODM_RTL8821)
+		odm_hw_setting_8821a(dm);
 #endif
 
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		phydm_hwsetting_8814a(p_dm);
+	if (dm->support_ic_type & ODM_RTL8814A)
+		phydm_hwsetting_8814a(dm);
 #endif
 
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		phydm_hwsetting_8822b(p_dm);
+	if (dm->support_ic_type & ODM_RTL8822B)
+		phydm_hwsetting_8822b(dm);
+#endif
+
+#if (RTL8812A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8812)
+		phydm_hwsetting_8812a(dm);
 #endif
 
 #if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		phydm_hwsetting_8197f(p_dm);
+	if (dm->support_ic_type & ODM_RTL8197F)
+		phydm_hwsetting_8197f(dm);
 #endif
-}
 
+#if (RTL8192F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8192F)
+		phydm_hwsetting_8192f(dm);
+#endif
+}
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-u64
-phydm_supportability_init_win(
-	void		*p_dm_void
-)
+u64 phydm_supportability_init_win(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u64			support_ability = 0;
-
-	switch (p_dm->support_ic_type) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u64 support_ability = 0;
 
-	/*---------------N Series--------------------*/
-	#if (RTL8188E_SUPPORT == 1)	
-	case	ODM_RTL8188E:
+	switch (dm->support_ic_type) {
+/*@---------------N Series--------------------*/
+#if (RTL8188E_SUPPORT)
+	case ODM_RTL8188E:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8192E_SUPPORT == 1)
-	case	ODM_RTL8192E:
+#if (RTL8192E_SUPPORT)
+	case ODM_RTL8192E:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8723B_SUPPORT == 1)
-	case	ODM_RTL8723B:
+#if (RTL8723B_SUPPORT)
+	case ODM_RTL8723B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8703B_SUPPORT == 1)
-	case	ODM_RTL8703B:
+#if (RTL8703B_SUPPORT)
+	case ODM_RTL8703B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8723D_SUPPORT == 1)
-	case	ODM_RTL8723D:
+#if (RTL8723D_SUPPORT)
+	case ODM_RTL8723D:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/* ODM_BB_PWR_TRAIN	| */
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			ODM_BB_PWR_TRAIN	|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8710B_SUPPORT == 1)
-	case	ODM_RTL8710B:
+#if (RTL8710B_SUPPORT)
+	case ODM_RTL8710B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			ODM_BB_PWR_TRAIN	|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8188F_SUPPORT == 1)
-	case	ODM_RTL8188F:
+#if (RTL8188F_SUPPORT)
+	case ODM_RTL8188F:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*ODM_BB_PWR_TRAIN	|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
-	
-	/*---------------AC Series-------------------*/
+#endif
 
-	#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-	case	ODM_RTL8812:
-	case	ODM_RTL8821:
+#if (RTL8192F_SUPPORT)
+	case ODM_RTL8192F:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_DYNAMIC_TXPWR	|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			ODM_BB_PWR_TRAIN	|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ADAPTIVE_SOML |
 			ODM_BB_ENV_MONITOR;
+		/*ODM_BB_LNA_SAT_CHK		|*/
+		/*ODM_BB_PRIMARY_CCA*/
+
 		break;
-	#endif
+#endif
 
-	#if (RTL8814A_SUPPORT == 1) 
-	case ODM_RTL8814A:
+/*@---------------AC Series-------------------*/
+
+#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT)
+	case ODM_RTL8812:
+	case ODM_RTL8821:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_DYNAMIC_TXPWR	|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_DYNAMIC_TXPWR |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
-	
-	#if (RTL8814B_SUPPORT == 1) 
-	case ODM_RTL8814B:
+#endif
+
+#if (RTL8814A_SUPPORT)
+	case ODM_RTL8814A:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_DYNAMIC_TXPWR |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8822B_SUPPORT == 1) 
+#if (RTL8822B_SUPPORT)
 	case ODM_RTL8822B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
-			ODM_BB_ADAPTIVE_SOML;
+			/*ODM_BB_ADAPTIVE_SOML |*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8821C_SUPPORT == 1) 
+#if (RTL8821C_SUPPORT)
 	case ODM_RTL8821C:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
+
+/*@---------------JGR3 Series-------------------*/
+
+#if (RTL8822C_SUPPORT)
+	case ODM_RTL8822C:
+		support_ability |=
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/* ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR;
+		break;
+#endif
+
+#if (RTL8814B_SUPPORT)
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			/*ODM_BB_CCK_PD |*/
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING;
+			/*ODM_BB_ENV_MONITOR;*/
+		break;
+#endif
 
 	default:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 
-			dbg_print("[Warning] Supportability Init Warning !!!\n");
+		pr_debug("[Warning] Supportability Init Warning !!!\n");
 		break;
-
 	}
 
-	/*[Config Antenna Diveristy]*/
-	if (*(p_dm->p_enable_antdiv))
-		support_ability |= ODM_BB_ANT_DIV;
-	
-	/*[Config Adaptivity]*/
-	if (*(p_dm->p_enable_adaptivity))
-		support_ability |= ODM_BB_ADAPTIVITY;
-
 	return support_ability;
 }
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-u64
-phydm_supportability_init_ce(
-	void		*p_dm_void
-)
+u64 phydm_supportability_init_ce(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u64			support_ability = 0;
-
-	switch (p_dm->support_ic_type) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u64 support_ability = 0;
 
-	/*---------------N Series--------------------*/
-	#if (RTL8188E_SUPPORT == 1)	
-	case	ODM_RTL8188E:
+	switch (dm->support_ic_type) {
+/*@---------------N Series--------------------*/
+#if (RTL8188E_SUPPORT)
+	case ODM_RTL8188E:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8192E_SUPPORT == 1)
-	case	ODM_RTL8192E:
+#if (RTL8192E_SUPPORT)
+	case ODM_RTL8192E:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8723B_SUPPORT == 1)
-	case	ODM_RTL8723B:
+#if (RTL8723B_SUPPORT)
+	case ODM_RTL8723B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8703B_SUPPORT == 1)
-	case	ODM_RTL8703B:
+#if (RTL8703B_SUPPORT)
+	case ODM_RTL8703B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8723D_SUPPORT == 1)
-	case	ODM_RTL8723D:
+#if (RTL8723D_SUPPORT)
+	case ODM_RTL8723D:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/* ODM_BB_PWR_TRAIN	| */	
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			ODM_BB_PWR_TRAIN	|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8710B_SUPPORT == 1)
-	case	ODM_RTL8710B:
+#if (RTL8710B_SUPPORT)
+	case ODM_RTL8710B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8188F_SUPPORT == 1)
-	case	ODM_RTL8188F:
+#if (RTL8188F_SUPPORT)
+	case ODM_RTL8188F:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
-		
-	/*---------------AC Series-------------------*/
+#endif
 
-	#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-	case	ODM_RTL8812:
-	case	ODM_RTL8821:
+#if (RTL8192F_SUPPORT)
+	case ODM_RTL8192F:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			ODM_BB_PWR_TRAIN		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			/*@ODM_BB_ADAPTIVE_SOML |*/
 			ODM_BB_ENV_MONITOR;
+		/*@ODM_BB_LNA_SAT_CHK		|*/
+		/*@ODM_BB_PRIMARY_CCA*/
 		break;
-	#endif
+#endif
+/*@---------------AC Series-------------------*/
 
-	#if (RTL8814A_SUPPORT == 1) 
-	case ODM_RTL8814A:
+#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT)
+	case ODM_RTL8812:
+	case ODM_RTL8821:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
-	
-	#if (RTL8814B_SUPPORT == 1) 
-	case ODM_RTL8814B:
+#endif
+
+#if (RTL8814A_SUPPORT)
+	case ODM_RTL8814A:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8822B_SUPPORT == 1) 
+#if (RTL8822B_SUPPORT)
 	case ODM_RTL8822B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8821C_SUPPORT == 1) 
+#if (RTL8821C_SUPPORT)
 	case ODM_RTL8821C:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	default:
+/*@---------------JGR3 Series-------------------*/
+
+#if (RTL8822C_SUPPORT)
+	case ODM_RTL8822C:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
-			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/* ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
+		break;
+#endif
 
-			dbg_print("[Warning] Supportability Init Warning !!!\n");
+#if (RTL8814B_SUPPORT)
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR;
+			/*ODM_BB_CCK_PD |*/
+			/*@ODM_BB_PWR_TRAIN		|*/
+			/*ODM_BB_RATE_ADAPTIVE |*/
+			/*ODM_BB_CFO_TRACKING |*/
+			/*ODM_BB_ENV_MONITOR;*/
 		break;
+#endif
+
+	default:
+		support_ability |=
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*@ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*@ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR;
 
+		pr_debug("[Warning] Supportability Init Warning !!!\n");
+		break;
 	}
-	
-	/*[Config Antenna Diveristy]*/
-	if (*(p_dm->p_enable_antdiv))
-		support_ability |= ODM_BB_ANT_DIV;
-	
-	/*[Config Adaptivity]*/
-	if (*(p_dm->p_enable_adaptivity))
-		support_ability |= ODM_BB_ADAPTIVITY;
-	
+
 	return support_ability;
 }
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-u64
-phydm_supportability_init_ap(
-	void		*p_dm_void
-)
+u64 phydm_supportability_init_ap(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u64			support_ability = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u64 support_ability = 0;
 
-	switch (p_dm->support_ic_type) {
-
-	/*---------------N Series--------------------*/
-	#if (RTL8188E_SUPPORT == 1)	
-	case	ODM_RTL8188E:
+	switch (dm->support_ic_type) {
+/*@---------------N Series--------------------*/
+#if (RTL8188E_SUPPORT)
+	case ODM_RTL8188E:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8192E_SUPPORT == 1)
-	case	ODM_RTL8192E:
+#if (RTL8192E_SUPPORT)
+	case ODM_RTL8192E:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
+#endif
 
-	#if (RTL8723B_SUPPORT == 1)
-	case	ODM_RTL8723B:
+#if (RTL8723B_SUPPORT)
+	case ODM_RTL8723B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
-		
-	#if ((RTL8198F_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
-	case	ODM_RTL8198F:
-	case	ODM_RTL8197F:
+#endif
+
+#if (RTL8198F_SUPPORT || RTL8197F_SUPPORT)
+	case ODM_RTL8198F:
+		support_ability |=
+			/*ODM_BB_DIG				|*/
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR;
+		/*ODM_BB_CCK_PD			|*/
+		/*ODM_BB_PWR_TRAIN		|*/
+		/*ODM_BB_RATE_ADAPTIVE	|*/
+		/*ODM_BB_CFO_TRACKING		|*/
+		/*ODM_BB_ADAPTIVE_SOML	|*/
+		/*ODM_BB_ENV_MONITOR		|*/
+		/*ODM_BB_LNA_SAT_CHK		|*/
+		/*ODM_BB_PRIMARY_CCA;*/
+		break;
+	case ODM_RTL8197F:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ADAPTIVE_SOML	|
-			ODM_BB_ENV_MONITOR		|
-			ODM_BB_LNA_SAT_CHK		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ADAPTIVE_SOML |
+			ODM_BB_ENV_MONITOR |
+			ODM_BB_LNA_SAT_CHK |
 			ODM_BB_PRIMARY_CCA;
 		break;
-	#endif
-	
-	/*---------------AC Series-------------------*/
+#endif
 
-	#if (RTL8881A_SUPPORT == 1)
-	case	ODM_RTL8881A:
+#if (RTL8192F_SUPPORT)
+	case ODM_RTL8192F:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR;
+			ODM_BB_RATE_ADAPTIVE |
+			/*ODM_BB_CFO_TRACKING		|*/
+			ODM_BB_ADAPTIVE_SOML |
+			/*ODM_BB_ENV_MONITOR		|*/
+			/*ODM_BB_LNA_SAT_CHK		|*/
+			/*ODM_BB_PRIMARY_CCA		|*/
+			0;
 		break;
-	#endif
+#endif
 
-	#if (RTL8814A_SUPPORT == 1) 
-	case ODM_RTL8814A:
+/*@---------------AC Series-------------------*/
+
+#if (RTL8881A_SUPPORT)
+	case ODM_RTL8881A:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
-	
-	#if (RTL8814B_SUPPORT == 1) 
-	case ODM_RTL8814B:
+#endif
+
+#if (RTL8814A_SUPPORT)
+	case ODM_RTL8814A:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8822B_SUPPORT == 1) 
+#if (RTL8822B_SUPPORT)
 	case ODM_RTL8822B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
-			ODM_BB_ENV_MONITOR			|
-			ODM_BB_ADAPTIVE_SOML;
+			/*ODM_BB_ADAPTIVE_SOML	|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8821C_SUPPORT == 1) 
+#if (RTL8821C_SUPPORT)
 	case ODM_RTL8821C:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 
 		break;
-	#endif
+#endif
+
+/*@---------------JGR3 Series-------------------*/
+
+#if (RTL8814B_SUPPORT)
+	case ODM_RTL8814B:
+		support_ability |=
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR;
+			/*ODM_BB_CCK_PD |*/
+			/*ODM_BB_PWR_TRAIN		|*/
+			/*ODM_BB_RATE_ADAPTIVE |*/
+			/*ODM_BB_CFO_TRACKING |*/
+			/*ODM_BB_ENV_MONITOR;*/
+		break;
+#endif
 
 	default:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 
-			dbg_print("[Warning] Supportability Init Warning !!!\n");
+		pr_debug("[Warning] Supportability Init Warning !!!\n");
 		break;
-
 	}
 
-	#if 0
-	/*[Config Antenna Diveristy]*/
-	if (*(p_dm->p_enable_antdiv))
+#if 0
+	/*@[Config Antenna Diveristy]*/
+	if (*dm->enable_antdiv)
 		support_ability |= ODM_BB_ANT_DIV;
-	
-	/*[Config Adaptivity]*/
-	if (*(p_dm->p_enable_adaptivity))
+
+	/*@[Config Adaptivity]*/
+	if (*dm->enable_adaptivity)
 		support_ability |= ODM_BB_ADAPTIVITY;
-	#endif
+#endif
 
 	return support_ability;
 }
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
-u64
-phydm_supportability_init_iot(
-	void		*p_dm_void
-)
+u64 phydm_supportability_init_iot(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u64			support_ability = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u64 support_ability = 0;
 
-	switch (p_dm->support_ic_type) {
+	switch (dm->support_ic_type) {
+#if (RTL8710B_SUPPORT)
+	case ODM_RTL8710B:
+		support_ability |=
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
+			ODM_BB_ENV_MONITOR;
+		break;
+#endif
 
-	#if (RTL8710B_SUPPORT == 1)
-	case	ODM_RTL8710B:
+#if (RTL8195A_SUPPORT)
+	case ODM_RTL8195A:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
+#endif
 
-	#if (RTL8195A_SUPPORT == 1)
-	case	ODM_RTL8195A:
+#if (RTL8195B_SUPPORT)
+	case ODM_RTL8195B:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING;
+			/*ODM_BB_ENV_MONITOR*/
+		break;
+#endif
+
+#if (RTL8721D_SUPPORT)
+	case ODM_RTL8721D:
+		support_ability |=
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
+			/*ODM_BB_DYNAMIC_TXPWR	|*/
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
+			/*ODM_BB_PWR_TRAIN		|*/
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 		break;
-	#endif
-	
+#endif
+
 	default:
 		support_ability |=
-			ODM_BB_DIG				|
-			ODM_BB_RA_MASK			|
+			ODM_BB_DIG |
+			ODM_BB_RA_MASK |
 			/*ODM_BB_DYNAMIC_TXPWR	|*/
-			ODM_BB_FA_CNT			|
-			ODM_BB_RSSI_MONITOR		|
-			ODM_BB_CCK_PD			|
+			ODM_BB_FA_CNT |
+			ODM_BB_RSSI_MONITOR |
+			ODM_BB_CCK_PD |
 			/*ODM_BB_PWR_TRAIN		|*/
-			ODM_BB_RATE_ADAPTIVE	|
-			ODM_BB_CFO_TRACKING		|
+			ODM_BB_RATE_ADAPTIVE |
+			ODM_BB_CFO_TRACKING |
 			ODM_BB_ENV_MONITOR;
 
-			dbg_print("[Warning] Supportability Init Warning !!!\n");
+		pr_debug("[Warning] Supportability Init Warning !!!\n");
 		break;
-
 	}
-	
-	/*[Config Antenna Diveristy]*/
-	if (*(p_dm->p_enable_antdiv))
-		support_ability |= ODM_BB_ANT_DIV;
-	
-	/*[Config Adaptivity]*/
-	if (*(p_dm->p_enable_adaptivity))
-		support_ability |= ODM_BB_ADAPTIVITY;
-	
+
 	return support_ability;
 }
 #endif
 
-void
-phydm_fwoffload_ability_init(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum phydm_offload_ability	offload_ability
-)
+void phydm_fwoffload_ability_init(struct dm_struct *dm,
+				  enum phydm_offload_ability offload_ability)
 {
-
 	switch (offload_ability) {
-
-	case	PHYDM_PHY_PARAM_OFFLOAD:
-		if (p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
-			p_dm->fw_offload_ability |= PHYDM_PHY_PARAM_OFFLOAD;
+	case PHYDM_PHY_PARAM_OFFLOAD:
+		if (dm->support_ic_type &
+		    (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+			dm->fw_offload_ability |= PHYDM_PHY_PARAM_OFFLOAD;
 		break;
 
-	case	PHYDM_RF_IQK_OFFLOAD:
-		p_dm->fw_offload_ability |= PHYDM_RF_IQK_OFFLOAD;
+	case PHYDM_RF_IQK_OFFLOAD:
+		dm->fw_offload_ability |= PHYDM_RF_IQK_OFFLOAD;
 		break;
 
 	default:
-		PHYDM_DBG(p_dm, ODM_COMP_INIT, ("fwofflad, wrong init type!!\n"));
+		PHYDM_DBG(dm, ODM_COMP_INIT, "fwofflad, wrong init type!!\n");
 		break;
-
 	}
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("fw_offload_ability = %x\n", p_dm->fw_offload_ability));
-
+	PHYDM_DBG(dm, ODM_COMP_INIT, "fw_offload_ability = %x\n",
+		  dm->fw_offload_ability);
 }
-void
-phydm_fwoffload_ability_clear(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum phydm_offload_ability	offload_ability
-)
-{
 
+void phydm_fwoffload_ability_clear(struct dm_struct *dm,
+				   enum phydm_offload_ability offload_ability)
+{
 	switch (offload_ability) {
-
-	case	PHYDM_PHY_PARAM_OFFLOAD:
-		if (p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
-			p_dm->fw_offload_ability &= (~PHYDM_PHY_PARAM_OFFLOAD);
+	case PHYDM_PHY_PARAM_OFFLOAD:
+		if (dm->support_ic_type &
+		    (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+			dm->fw_offload_ability &= (~PHYDM_PHY_PARAM_OFFLOAD);
 		break;
 
-	case	PHYDM_RF_IQK_OFFLOAD:
-		p_dm->fw_offload_ability &= (~PHYDM_RF_IQK_OFFLOAD);
+	case PHYDM_RF_IQK_OFFLOAD:
+		dm->fw_offload_ability &= (~PHYDM_RF_IQK_OFFLOAD);
 		break;
 
 	default:
-		PHYDM_DBG(p_dm, ODM_COMP_INIT, ("fwofflad, wrong init type!!\n"));
+		PHYDM_DBG(dm, ODM_COMP_INIT, "fwofflad, wrong init type!!\n");
 		break;
-
 	}
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("fw_offload_ability = %x\n", p_dm->fw_offload_ability));
-
+	PHYDM_DBG(dm, ODM_COMP_INIT, "fw_offload_ability = %x\n",
+		  dm->fw_offload_ability);
 }
 
-void
-phydm_supportability_init(
-	void		*p_dm_void
-)
+void phydm_supportability_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u64	support_ability;
-	
-	if (*(p_dm->p_mp_mode) == true) {
-		support_ability = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u64 support_ability;
 
-		/**/
+	if (*dm->mp_mode) {
+		support_ability = 0;
 	} else {
-
 		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-		support_ability = phydm_supportability_init_win(p_dm);
+		support_ability = phydm_supportability_init_win(dm);
 		#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-		support_ability = phydm_supportability_init_ap(p_dm);
+		support_ability = phydm_supportability_init_ap(dm);
 		#elif(DM_ODM_SUPPORT_TYPE & (ODM_CE))
-		support_ability = phydm_supportability_init_ce(p_dm);
+		support_ability = phydm_supportability_init_ce(dm);
 		#elif(DM_ODM_SUPPORT_TYPE & (ODM_IOT))
-		support_ability = phydm_supportability_init_iot(p_dm);
+		support_ability = phydm_supportability_init_iot(dm);
 		#endif
+
+		/*@[Config Antenna Diversity]*/
+		if (IS_FUNC_EN(dm->enable_antdiv))
+			support_ability |= ODM_BB_ANT_DIV;
+
+		/*@[Config TXpath Diversity]*/
+		if (IS_FUNC_EN(dm->enable_pathdiv))
+			support_ability |= ODM_BB_PATH_DIV;
+
+		/*@[Config Adaptive SOML]*/
+		if (IS_FUNC_EN(dm->en_adap_soml))
+			support_ability |= ODM_BB_ADAPTIVE_SOML;
+
+		/* @[Config Adaptivity]*/
+		if (IS_FUNC_EN(dm->enable_adaptivity))
+			support_ability |= ODM_BB_ADAPTIVITY;
 	}
-	odm_cmn_info_init(p_dm, ODM_CMNINFO_ABILITY, support_ability);
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("IC = ((0x%x)), Supportability Init = ((0x%llx))\n", p_dm->support_ic_type, p_dm->support_ability));
+	odm_cmn_info_init(dm, ODM_CMNINFO_ABILITY, support_ability);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "IC=0x%x, mp=%d, Supportability=0x%llx\n",
+		  dm->support_ic_type, *dm->mp_mode, dm->support_ability);
 }
 
-void
-phydm_rfe_init(
-	void			*p_dm_void
-)
+void phydm_rfe_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("RFE_Init\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "RFE_Init\n");
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8822B) {
-		phydm_rfe_8822b_init(p_dm);
-		/**/
-	}
+	if (dm->support_ic_type == ODM_RTL8822B)
+		phydm_rfe_8822b_init(dm);
 #endif
 }
 
-void
-phydm_dm_early_init(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void phydm_dm_early_init(struct dm_struct *dm)
 {
-	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	halrf_init(p_dm);
-	#endif
+
 }
 
-void
-odm_dm_init(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void odm_dm_init(struct dm_struct *dm)
 {
-	halrf_init(p_dm);
-	phydm_supportability_init(p_dm);
-	phydm_rfe_init(p_dm);
-	phydm_common_info_self_init(p_dm);
-	phydm_rx_phy_status_init(p_dm);
-	phydm_auto_dbg_engine_init(p_dm);
-	phydm_dig_init(p_dm);
-	phydm_cck_pd_init(p_dm);
-	phydm_env_monitor_init(p_dm);
-	phydm_adaptivity_init(p_dm);
-	phydm_ra_info_init(p_dm);
-	phydm_rssi_monitor_init(p_dm);
-	phydm_cfo_tracking_init(p_dm);
-	phydm_rf_init(p_dm);
-	odm_txpowertracking_init(p_dm);
-	phydm_dc_cancellation(p_dm);
+	halrf_init(dm);
+	phydm_supportability_init(dm);
+	phydm_rfe_init(dm);
+	phydm_common_info_self_init(dm);
+	phydm_rx_phy_status_init(dm);
+#ifdef PHYDM_AUTO_DEGBUG
+	phydm_auto_dbg_engine_init(dm);
+#endif
+	phydm_dig_init(dm);
+#ifdef PHYDM_SUPPORT_CCKPD
+	phydm_cck_pd_init(dm);
+#endif
+	phydm_env_monitor_init(dm);
+	phydm_adaptivity_init(dm);
+	phydm_ra_info_init(dm);
+	phydm_rssi_monitor_init(dm);
+	phydm_cfo_tracking_init(dm);
+	phydm_rf_init(dm);
+	phydm_dc_cancellation(dm);
 #ifdef PHYDM_TXA_CALIBRATION
-	phydm_txcurrentcalibration(p_dm);
-	phydm_get_pa_bias_offset(p_dm);
+	phydm_txcurrentcalibration(dm);
+	phydm_get_pa_bias_offset(dm);
+#endif
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	odm_antenna_diversity_init(dm);
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	phydm_adaptive_soml_init(dm);
 #endif
-	odm_antenna_diversity_init(p_dm);
-	phydm_adaptive_soml_init(p_dm);
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	phydm_dynamic_rx_path_init(p_dm);
+#ifdef CONFIG_PATH_DIVERSITY
+	phydm_tx_path_diversity_init(dm);
+#endif
+#ifdef CONFIG_DYNAMIC_TX_TWR
+	phydm_dynamic_tx_power_init(dm);
 #endif
-	odm_auto_channel_select_init(p_dm);
-	phydm_path_diversity_init(p_dm);
-	phydm_dynamic_tx_power_init(p_dm);
 #if (PHYDM_LA_MODE_SUPPORT == 1)
-	adc_smp_init(p_dm);
+	adc_smp_init(dm);
 #endif
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	phydm_beamforming_init(p_dm);
+#ifdef PHYDM_BEAMFORMING_VERSION1
+	phydm_beamforming_init(dm);
 #endif
+
 #if (RTL8188E_SUPPORT == 1)
-	odm_ra_info_init_all(p_dm);
+	odm_ra_info_init_all(dm);
+#endif
+#ifdef PHYDM_PRIMARY_CCA
+	phydm_primary_cca_init(dm);
+#endif
+#ifdef CONFIG_PSD_TOOL
+	phydm_psd_init(dm);
 #endif
 
-	phydm_primary_cca_init(p_dm);
-
-	#ifdef CONFIG_PSD_TOOL
-	phydm_psd_init(p_dm);
-	#endif
-	
-	#ifdef CONFIG_SMART_ANTENNA
-	phydm_smt_ant_init(p_dm);
+#ifdef CONFIG_SMART_ANTENNA
+	phydm_smt_ant_init(dm);
+#endif
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	phydm_lna_sat_check_init(dm);
+#endif
+#ifdef CONFIG_MCC_DM
+	#if (RTL8822B_SUPPORT == 1)
+	phydm_mcc_init(dm);
 	#endif
-
+#endif
 }
 
-void
-odm_dm_reset(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void odm_dm_reset(struct dm_struct *dm)
 {
-	struct phydm_dig_struct *p_dig_t = &p_dm->dm_dig_table;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
 
-	odm_ant_div_reset(p_dm);
-	phydm_set_edcca_threshold_api(p_dm, p_dig_t->cur_ig_value);
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	odm_ant_div_reset(dm);
+	#endif
+	phydm_set_edcca_threshold_api(dm, dig_t->cur_ig_value);
 }
 
-void
-phydm_support_ability_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+void phydm_supportability_en(void *dm_void, char input[][16], u32 *_used,
+			     char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u64			pre_support_ability, one = 1;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 dm_value[10] = {0};
+	u64 pre_support_ability, one = 1;
+	u64 comp = 0;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u8 i;
 
-	pre_support_ability = p_dm->support_ability;
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+	}
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%s\n", "================================"));
-	if (dm_value[0] == 100) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "[Supportability] PhyDM Selection\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "00. (( %s ))DIG\n", ((p_dm->support_ability & ODM_BB_DIG) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "01. (( %s ))RA_MASK\n", ((p_dm->support_ability & ODM_BB_RA_MASK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "02. (( %s ))DYN_TXPWR\n", ((p_dm->support_ability & ODM_BB_DYNAMIC_TXPWR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "03. (( %s ))FA_CNT\n", ((p_dm->support_ability & ODM_BB_FA_CNT) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "04. (( %s ))RSSI_MNTR\n", ((p_dm->support_ability & ODM_BB_RSSI_MONITOR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "05. (( %s ))CCK_PD\n", ((p_dm->support_ability & ODM_BB_CCK_PD) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "06. (( %s ))ANT_DIV\n", ((p_dm->support_ability & ODM_BB_ANT_DIV) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "07. (( %s ))SMT_ANT\n", ((p_dm->support_ability & ODM_BB_SMT_ANT) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "08. (( %s ))PWR_TRAIN\n", ((p_dm->support_ability & ODM_BB_PWR_TRAIN) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "09. (( %s ))RA\n", ((p_dm->support_ability & ODM_BB_RATE_ADAPTIVE) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "10. (( %s ))PATH_DIV\n", ((p_dm->support_ability & ODM_BB_PATH_DIV) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "11. (( %s ))DFS\n", ((p_dm->support_ability & ODM_BB_DFS) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "12. (( %s ))DYN_ARFR\n", ((p_dm->support_ability & ODM_BB_DYNAMIC_ARFR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "13. (( %s ))ADAPTIVITY\n", ((p_dm->support_ability & ODM_BB_ADAPTIVITY) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "14. (( %s ))CFO_TRACK\n", ((p_dm->support_ability & ODM_BB_CFO_TRACKING) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "15. (( %s ))ENV_MONITOR\n", ((p_dm->support_ability & ODM_BB_ENV_MONITOR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "16. (( %s ))PRI_CCA\n", ((p_dm->support_ability & ODM_BB_PRIMARY_CCA) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "17. (( %s ))ADPTV_SOML\n", ((p_dm->support_ability & ODM_BB_ADAPTIVE_SOML) ? ("V") : ("."))));
-		/*PHYDM_SNPRINTF((output + used, out_len - used, "18. (( %s ))TBD\n", ((p_dm->support_ability & ODM_BB_TBD) ? ("V") : ("."))));*/
-		/*PHYDM_SNPRINTF((output + used, out_len - used, "19. (( %s ))TBD\n", ((p_dm->support_ability & ODM_BB_TBD) ? ("V") : ("."))));*/
-		PHYDM_SNPRINTF((output + used, out_len - used, "20. (( %s ))DYN_RX_PATH\n", ((p_dm->support_ability & ODM_BB_DYNAMIC_RX_PATH) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "[Supportability] PhyDM offload ability\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "00. (( %s ))PHY PARAM OFFLOAD\n", ((p_dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "01. (( %s ))RF IQK OFFLOAD\n", ((p_dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
+	pre_support_ability = dm->support_ability;
+	comp = dm->support_ability;
 
-	}
-	/*
-	else if(dm_value[0] == 101)
-	{
-		p_dm->support_ability = 0 ;
-		dbg_print("Disable all support_ability components\n");
-		PHYDM_SNPRINTF((output+used, out_len-used,"%s\n", "Disable all support_ability components"));
-	}
-	*/
-	else {
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\n================================\n");
 
-		if (dm_value[1] == 1) { /* enable */
-			p_dm->support_ability |= (one << dm_value[0]);
-			if (BIT(dm_value[0]) & ODM_BB_PATH_DIV)
-				phydm_path_diversity_init(p_dm);
-		} else if (dm_value[1] == 2)	/* disable */
-			p_dm->support_ability &= ~(one << dm_value[0]);
-		else
-			PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[Warning!!!]  1:enable,  2:disable"));
+	if (dm_value[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Supportability] PhyDM Selection\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "================================\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "00. (( %s ))DIG\n",
+			 ((comp & ODM_BB_DIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "01. (( %s ))RA_MASK\n",
+			 ((comp & ODM_BB_RA_MASK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "02. (( %s ))DYN_TXPWR\n",
+			 ((comp & ODM_BB_DYNAMIC_TXPWR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "03. (( %s ))FA_CNT\n",
+			 ((comp & ODM_BB_FA_CNT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "04. (( %s ))RSSI_MNTR\n",
+			 ((comp & ODM_BB_RSSI_MONITOR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "05. (( %s ))CCK_PD\n",
+			 ((comp & ODM_BB_CCK_PD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "06. (( %s ))ANT_DIV\n",
+			 ((comp & ODM_BB_ANT_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "07. (( %s ))SMT_ANT\n",
+			 ((comp & ODM_BB_SMT_ANT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "08. (( %s ))PWR_TRAIN\n",
+			 ((comp & ODM_BB_PWR_TRAIN) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "09. (( %s ))RA\n",
+			 ((comp & ODM_BB_RATE_ADAPTIVE) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "10. (( %s ))PATH_DIV\n",
+			 ((comp & ODM_BB_PATH_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "11. (( %s ))DFS\n",
+			 ((comp & ODM_BB_DFS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "12. (( %s ))DYN_ARFR\n",
+			 ((comp & ODM_BB_DYNAMIC_ARFR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "13. (( %s ))ADAPTIVITY\n",
+			 ((comp & ODM_BB_ADAPTIVITY) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "14. (( %s ))CFO_TRACK\n",
+			 ((comp & ODM_BB_CFO_TRACKING) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "15. (( %s ))ENV_MONITOR\n",
+			 ((comp & ODM_BB_ENV_MONITOR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "16. (( %s ))PRI_CCA\n",
+			 ((comp & ODM_BB_PRIMARY_CCA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "17. (( %s ))ADPTV_SOML\n",
+			 ((comp & ODM_BB_ADAPTIVE_SOML) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "18. (( %s ))LNA_SAT_CHK\n",
+			 ((comp & ODM_BB_LNA_SAT_CHK) ? ("V") : (".")));
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "================================\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Supportability] PhyDM offload ability\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "================================\n");
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "00. (( %s ))PHY PARAM OFFLOAD\n",
+			 ((dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) ?
+			 ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "01. (( %s ))RF IQK OFFLOAD\n",
+			 ((dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ?
+			 ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "================================\n");
+
+	} else if (dm_value[0] == 101) {
+		dm->support_ability = 0;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Disable all support_ability components\n");
+	} else {
+		if (dm_value[1] == 1) { /* @enable */
+			dm->support_ability |= (one << dm_value[0]);
+		} else if (dm_value[1] == 2) {/* @disable */
+			dm->support_ability &= ~(one << dm_value[0]);
+		} else {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[Warning!!!]  1:enable,  2:disable\n");
+		}
 	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "pre-support_ability  =  0x%llx\n",  pre_support_ability));
-	PHYDM_SNPRINTF((output + used, out_len - used, "Curr-support_ability =  0x%llx\n", p_dm->support_ability));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "pre-supportability = 0x%llx\n", pre_support_ability);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "Cur-supportability = 0x%llx\n", dm->support_ability);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "================================\n");
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_watchdog_lps_32k(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_watchdog_lps_32k(struct dm_struct *dm)
 {
-	PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("%s ======>\n", __func__));
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
 
-	phydm_common_info_self_update(p_dm);
-	phydm_rssi_monitor_check(p_dm);
-	phydm_dig_lps_32k(p_dm);
-	phydm_common_info_self_reset(p_dm);
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_dig_lps_32k(dm);
+	phydm_common_info_self_reset(dm);
 }
 
-void
-phydm_watchdog_lps(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_watchdog_lps(struct dm_struct *dm)
 {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("%s ======>\n", __func__));
-
-	phydm_common_info_self_update(p_dm);
-	phydm_rssi_monitor_check(p_dm);
-	phydm_basic_dbg_message(p_dm);
-	phydm_receiver_blocking(p_dm);
-	odm_false_alarm_counter_statistics(p_dm);
-	phydm_dig_by_rssi_lps(p_dm);
-	phydm_cck_pd_th(p_dm);
-	phydm_adaptivity(p_dm);
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_IOT))
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
+
+	phydm_common_info_self_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_basic_dbg_message(dm);
+	phydm_receiver_blocking(dm);
+	phydm_false_alarm_counter_statistics(dm);
+	phydm_dig_by_rssi_lps(dm);
+	#ifdef PHYDM_SUPPORT_CCKPD
+	phydm_cck_pd_th(dm);
+	#endif
+	phydm_adaptivity(dm);
 	#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	odm_antenna_diversity(p_dm); /*enable AntDiv in PS mode, request from SD4 Jeff*/
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	/*@enable AntDiv in PS mode, request from SD4 Jeff*/
+	odm_antenna_diversity(dm);
 	#endif
-	phydm_common_info_self_reset(p_dm);
+	#endif
+	phydm_common_info_self_reset(dm);
 #endif
 }
 
-void
-phydm_watchdog_mp(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_watchdog_mp(struct dm_struct *dm)
 {
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	phydm_dynamic_rx_path_caller(p_dm);
-#endif
 }
 
-void
-phydm_pause_dm_watchdog(
-	void					*p_dm_void,
-	enum phydm_pause_type		pause_type
-)
+void phydm_pause_dm_watchdog(void *dm_void, enum phydm_pause_type pause_type)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (pause_type == PHYDM_PAUSE) {
-		p_dm->disable_phydm_watchdog = 1;
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("PHYDM Stop\n"));
+		dm->disable_phydm_watchdog = 1;
+		PHYDM_DBG(dm, ODM_COMP_API, "PHYDM Stop\n");
 	} else {
-		p_dm->disable_phydm_watchdog = 0;
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("PHYDM Start\n"));
+		dm->disable_phydm_watchdog = 0;
+		PHYDM_DBG(dm, ODM_COMP_API, "PHYDM Start\n");
 	}
 }
 
-u8
-phydm_pause_func(
-	void						*p_dm_void,
-	enum phydm_func_idx_e	pause_func,
-	enum phydm_pause_type	pause_type,
-	enum phydm_pause_level	pause_lv,
-	u8						val_lehgth,
-	u32						*val_buf
-)
+u8 phydm_pause_func(void *dm_void, enum phydm_func_idx pause_func,
+		    enum phydm_pause_type pause_type,
+		    enum phydm_pause_level pause_lv, u8 val_lehgth,
+		    u32 *val_buf)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	s8	*pause_lv_pre = &(p_dm->s8_dummy);
-	u32	*bkp_val = &(p_dm->u32_dummy);
-	u32	ori_val[5] = {0};
-	u64	pause_func_bitmap = (u64)BIT(pause_func);
-	u8	i;
-
-
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("[%s][%s] LV=%d, Len=%d\n", __func__, 
-		((pause_type == PHYDM_PAUSE) ? "Pause" : "Resume"),  pause_lv, val_lehgth));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_func_poiner *func_t = &dm->phydm_func_handler;
+	s8 *pause_lv_pre = &dm->s8_dummy;
+	u32 *bkp_val = &dm->u32_dummy;
+	u32 ori_val[5] = {0};
+	u64 pause_func_bitmap = (u64)BIT(pause_func);
+	u8 i = 0;
+	u8 en_2rcca = 0;
+	u8 en_bw40m = 0;
+	u8 pause_result = PAUSE_FAIL;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "\n");
+	PHYDM_DBG(dm, ODM_COMP_API, "[%s][%s] LV=%d, Len=%d\n", __func__,
+		  ((pause_type == PHYDM_PAUSE) ? "Pause" :
+		  ((pause_type == PHYDM_RESUME) ? "Resume" : "Pause no_set")),
+		  pause_lv, val_lehgth);
 
 	if (pause_lv >= PHYDM_PAUSE_MAX_NUM) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[WARNING] Wrong LV=%d\n", pause_lv));
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING]Wrong LV=%d\n", pause_lv);
 		return PAUSE_FAIL;
 	}
 
 	if (pause_func == F00_DIG) {
-
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[DIG]\n"));
+		PHYDM_DBG(dm, ODM_COMP_API, "[DIG]\n");
 
 		if (val_lehgth != 1) {
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("[WARNING] val_length != 1\n"));
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] length != 1\n");
 			return PAUSE_FAIL;
 		}
-		
-		ori_val[0] = (u32)(p_dm->dm_dig_table.cur_ig_value); /*0xc50*/
-		pause_lv_pre = &(p_dm->pause_lv_table.lv_dig);
-		bkp_val = (u32*)(&(p_dm->dm_dig_table.rvrt_val));
-		p_dm->phydm_func_handler.pause_phydm_handler = phydm_set_dig_val; /*function pointer hook*/
-	
-	} else
-	
+
+		ori_val[0] = (u32)(dm->dm_dig_table.cur_ig_value);
+		pause_lv_pre = &dm->pause_lv_table.lv_dig;
+		bkp_val = (u32 *)(&dm->dm_dig_table.rvrt_val);
+		/*@function pointer hook*/
+		func_t->pause_phydm_handler = phydm_set_dig_val;
+
 #ifdef PHYDM_SUPPORT_CCKPD
-	if (pause_func == F05_CCK_PD) {
-		
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[CCK_PD]\n"));
+	} else if (pause_func == F05_CCK_PD) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[CCK_PD]\n");
 
-		if (val_lehgth != 2) {
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("[WARNING] val_length != 2\n"));
+		if (val_lehgth != 1) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] length != 1\n");
 			return PAUSE_FAIL;
 		}
-		
-		ori_val[0] = p_dm->dm_cckpd_table.cur_cck_cca_thres; /*0xa0a*/
-		ori_val[1] = p_dm->dm_cckpd_table.cck_cca_th_aaa;	/*0xaaa*/
-		pause_lv_pre = &(p_dm->pause_lv_table.lv_cckpd);
-		bkp_val = &(p_dm->dm_cckpd_table.rvrt_val[0]);
-		p_dm->phydm_func_handler.pause_phydm_handler = phydm_set_cckpd_val; /*function pointer hook*/
-		
-	} else 
+
+		ori_val[0] = (u32)dm->dm_cckpd_table.cck_pd_lv;
+		pause_lv_pre = &dm->pause_lv_table.lv_cckpd;
+		bkp_val = (u32 *)(&dm->dm_cckpd_table.rvrt_val);
+		/*@function pointer hook*/
+		func_t->pause_phydm_handler = phydm_set_cckpd_val;
 #endif
 
 #ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
-	if (pause_func == F06_ANT_DIV) {
-
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[AntDiv]\n"));
+	} else if (pause_func == F06_ANT_DIV) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[AntDiv]\n");
 
 		if (val_lehgth != 1) {
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("[WARNING] val_length != 1\n"));
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] length != 1\n");
 			return PAUSE_FAIL;
 		}
-		
-		ori_val[0] = (u32)(p_dm->dm_fat_table.rx_idle_ant); /*default antenna*/
-		pause_lv_pre = &(p_dm->pause_lv_table.lv_antdiv);
-		bkp_val = (u32*)(&(p_dm->dm_fat_table.rvrt_val));
-		p_dm->phydm_func_handler.pause_phydm_handler = phydm_set_antdiv_val; /*function pointer hook*/
-	
-	} else
-#endif
-
-	if (pause_func == F13_ADPTVTY) {
+		/*@default antenna*/
+		ori_val[0] = (u32)(dm->dm_fat_table.rx_idle_ant);
+		pause_lv_pre = &dm->pause_lv_table.lv_antdiv;
+		bkp_val = (u32 *)(&dm->dm_fat_table.rvrt_val);
+		/*@function pointer hook*/
+		func_t->pause_phydm_handler = phydm_set_antdiv_val;
 
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[Adaptivity]\n"));
+#endif
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+	} else if (pause_func == F13_ADPTVTY) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Adaptivity]\n");
 
 		if (val_lehgth != 2) {
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("[WARNING] val_length != 2\n"));
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] length != 2\n");
 			return PAUSE_FAIL;
 		}
 
-		ori_val[0] = (u32)(p_dm->adaptivity.th_l2h);	/*th_l2h*/
-		ori_val[1] = (u32)(p_dm->adaptivity.th_h2l);	/*th_h2l*/
-		pause_lv_pre = &(p_dm->pause_lv_table.lv_adapt);
-		bkp_val = (u32 *)(&(p_dm->adaptivity.rvrt_val));
-		p_dm->phydm_func_handler.pause_phydm_handler = phydm_set_edcca_val; /*function pointer hook*/
+		ori_val[0] = (u32)(dm->adaptivity.th_l2h); /*th_l2h*/
+		ori_val[1] = (u32)(dm->adaptivity.th_h2l); /*th_h2l*/
+		pause_lv_pre = &dm->pause_lv_table.lv_adapt;
+		bkp_val = (u32 *)(&dm->adaptivity.rvrt_val);
+		/*@function pointer hook*/
+		func_t->pause_phydm_handler = phydm_set_edcca_val;
 
-	} else
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	} else if (pause_func == F17_ADPTV_SOML) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[AD-SOML]\n");
 
-	{
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[WARNING] error func idx\n"));
+		if (val_lehgth != 1) {
+			PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] length != 1\n");
+			return PAUSE_FAIL;
+		}
+		/*SOML_ON/OFF*/
+		ori_val[0] = (u32)(dm->dm_soml_table.soml_on_off);
+
+		pause_lv_pre = &dm->pause_lv_table.lv_adsl;
+		bkp_val = (u32 *)(&dm->dm_soml_table.rvrt_val);
+		 /*@function pointer hook*/
+		func_t->pause_phydm_handler = phydm_set_adsl_val;
+
+#endif
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] error func idx\n");
 		return PAUSE_FAIL;
 	}
 
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("Pause_LV{new , pre} = {%d ,%d}\n", pause_lv, *pause_lv_pre));
-
-	if ((pause_type == PHYDM_PAUSE) || (pause_type == PHYDM_PAUSE_NO_SET)) {
-		
-		if (pause_lv > *pause_lv_pre) {
+	PHYDM_DBG(dm, ODM_COMP_API, "Pause_LV{new , pre} = {%d ,%d}\n",
+		  pause_lv, *pause_lv_pre);
 
-			if (!(p_dm->pause_ability & pause_func_bitmap)) {
+	if (pause_type == PHYDM_PAUSE || pause_type == PHYDM_PAUSE_NO_SET) {
+		if (pause_lv <= *pause_lv_pre) {
+			PHYDM_DBG(dm, ODM_COMP_API,
+				  "[PAUSE FAIL] Pre_LV >= Curr_LV\n");
+			return PAUSE_FAIL;
+		}
 
-				for (i = 0; i < val_lehgth; i ++)
-					bkp_val[i] = ori_val[i];
-			}
+		if (!(dm->pause_ability & pause_func_bitmap)) {
+			for (i = 0; i < val_lehgth; i++)
+				bkp_val[i] = ori_val[i];
+		}
 
-			p_dm->pause_ability |= pause_func_bitmap;
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("pause_ability=0x%llx\n", p_dm->pause_ability));
-			
-			if (pause_type == PHYDM_PAUSE) {
-
-				for (i = 0; i < val_lehgth; i ++) {
-					PHYDM_DBG(p_dm, ODM_COMP_API, ("[PAUSE SUCCESS] val_idx[%d]{New, Ori}={0x%x, 0x%x}\n",i, val_buf[i], bkp_val[i]));
-				/**/
-				}
-				p_dm->phydm_func_handler.pause_phydm_handler(p_dm, val_buf, val_lehgth);
-			} else {
-			
-				for (i = 0; i < val_lehgth; i ++) {
-					PHYDM_DBG(p_dm, ODM_COMP_API, ("[PAUSE NO Set: SUCCESS] val_idx[%d]{Ori}={0x%x}\n",i, bkp_val[i]));
-				/**/
-				}
-			}
+		dm->pause_ability |= pause_func_bitmap;
+		PHYDM_DBG(dm, ODM_COMP_API, "pause_ability=0x%llx\n",
+			  dm->pause_ability);
 
-			*pause_lv_pre = pause_lv;
-			return PAUSE_SUCCESS;
-			
+		if (pause_type == PHYDM_PAUSE) {
+			for (i = 0; i < val_lehgth; i++)
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "[PAUSE SUCCESS] val_idx[%d]{New, Ori}={0x%x, 0x%x}\n",
+					  i, val_buf[i], bkp_val[i]);
+			func_t->pause_phydm_handler(dm, val_buf, val_lehgth);
 		} else {
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("[PAUSE FAIL] Pre_LV >= Curr_LV\n"));
-			return PAUSE_FAIL;
+			for (i = 0; i < val_lehgth; i++)
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "[PAUSE NO Set: SUCCESS] val_idx[%d]{Ori}={0x%x}\n",
+					  i, bkp_val[i]);
 		}
 
+		*pause_lv_pre = pause_lv;
+		pause_result = PAUSE_SUCCESS;
+
 	} else if (pause_type == PHYDM_RESUME) {
-		p_dm->pause_ability &= ~pause_func_bitmap;
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("pause_ability=0x%llx\n", p_dm->pause_ability));
-		
+		if ((dm->pause_ability & pause_func_bitmap) == 0) {
+			PHYDM_DBG(dm, ODM_COMP_API,
+				  "[RESUME] No Need to Revert\n");
+			return PAUSE_SUCCESS;
+		}
+
+		dm->pause_ability &= ~pause_func_bitmap;
+		PHYDM_DBG(dm, ODM_COMP_API, "pause_ability=0x%llx\n",
+			  dm->pause_ability);
+
 		*pause_lv_pre = PHYDM_PAUSE_RELEASE;
-		
-		for (i = 0; i < val_lehgth; i ++) {
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("[RESUME] val_idx[%d]={0x%x}\n", i, bkp_val[i]));
+
+		for (i = 0; i < val_lehgth; i++) {
+			PHYDM_DBG(dm, ODM_COMP_API,
+				  "[RESUME] val_idx[%d]={0x%x}\n", i,
+				  bkp_val[i]);
 		}
-		
-		p_dm->phydm_func_handler.pause_phydm_handler(p_dm, bkp_val, val_lehgth);
-		
-		return PAUSE_SUCCESS;
+
+		func_t->pause_phydm_handler(dm, bkp_val, val_lehgth);
+
+		pause_result = PAUSE_SUCCESS;
 	} else {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[WARNING] error pause_type\n"));
-		return PAUSE_FAIL;
+		PHYDM_DBG(dm, ODM_COMP_API, "[WARNING] error pause_type\n");
+		pause_result = PAUSE_FAIL;
 	}
-	
+	return pause_result;
 }
 
-void
-phydm_pause_func_console(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_pause_func_console(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u32		i;
-	u8		val_length = 0;
-	u32		val_buf[5] = {0};
-	u8		set_result = 0;
-	enum phydm_func_idx_e	func = 0;
-	enum phydm_pause_type	pause_type = 0;
-	enum phydm_pause_level	pause_lv = 0;
-	
-	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "{Func} {1:pause, 2:Resume} {lv} Val[5:0]\n"));
-		
-	} else {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 i;
+	u8 length = 0;
+	u32 buf[5] = {0};
+	u8 set_result = 0;
+	enum phydm_func_idx func = 0;
+	enum phydm_pause_type type = 0;
+	enum phydm_pause_level lv = 0;
 
-		for (i = 0; i < 10; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-			}
-		}
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{Func} {1:pause,2:pause no set 3:Resume} {lv:0~3} Val[5:0]\n");
 
-		func = (enum phydm_func_idx_e)var1[0];
-		pause_type = (enum phydm_pause_type)var1[1];
-		pause_lv = (enum phydm_pause_level)var1[2];
-	
+		goto out;
+	}
 
-		for (i = 0; i < 5; i++) {
-			val_buf[i] = var1[3 + i];
-		}
+	for (i = 0; i < 10; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+	}
 
-		if (func == F00_DIG) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[DIG]\n"));
-			val_length = 1;
-			
-		} else if (func == F05_CCK_PD) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[CCK_PD]\n"));
-			val_length = 2;
-		} else if (func == F06_ANT_DIV) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Ant_Div]\n"));
-			val_length = 1;
-		} else if (func == F13_ADPTVTY) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Adaptivity]\n"));
-			val_length = 2;
-		} else {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Set Function Error]\n"));
-			val_length = 0;
-		}
+	func = (enum phydm_func_idx)var1[0];
+	type = (enum phydm_pause_type)var1[1];
+	lv = (enum phydm_pause_level)var1[2];
+
+	for (i = 0; i < 5; i++)
+		buf[i] = var1[3 + i];
+
+	if (func == F00_DIG) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[DIG]\n");
+		length = 1;
+
+	} else if (func == F05_CCK_PD) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[CCK_PD]\n");
+		length = 1;
+	} else if (func == F06_ANT_DIV) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Ant_Div]\n");
+		length = 1;
+	} else if (func == F13_ADPTVTY) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Adaptivity]\n");
+		length = 2;
+	} else if (func == F17_ADPTV_SOML) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[ADSL]\n");
+		length = 1;
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Set Function Error]\n");
+		length = 0;
+	}
 
-		if (val_length != 0) {
-			
-			PHYDM_SNPRINTF((output + used, out_len - used, "{%s, lv=%d} val = %d, %d}\n", 
-				((pause_type == PHYDM_PAUSE) ? "Pause" : "Resume"), pause_lv, var1[3], var1[4]));
-			
-			set_result= phydm_pause_func(p_dm, func, pause_type, pause_lv, val_length, val_buf);
-		}
+	if (length != 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{%s, lv=%d} val = %d, %d}\n",
+			 ((type == PHYDM_PAUSE) ? "Pause" :
+			 ((type == PHYDM_RESUME) ? "Resume" : "Pause no_set")),
+			 lv, var1[3], var1[4]);
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "set_result = %d\n", set_result));
+		set_result = phydm_pause_func(dm, func, type, lv, length, buf);
 	}
 
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "set_result = %d\n", set_result);
 
+out:
 	*_used = used;
 	*_out_len = out_len;
 }
 
-u8
-phydm_stop_dm_watchdog_check(
-	void					*p_dm_void
-)
+u8 phydm_stop_dm_watchdog_check(void *dm_void)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (p_dm->disable_phydm_watchdog == 1) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-		PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("Disable phydm\n"));
+	if (dm->disable_phydm_watchdog == 1) {
+		PHYDM_DBG(dm, DBG_COMMON_FLOW, "Disable phydm\n");
 		return true;
-		
-	} else if (phydm_acs_check(p_dm) == true) {
-	
-		PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("Disable phydm by ACS\n"));
-		return true;
-		
-	} else
+	} else {
 		return false;
-	
+	}
 }
 
-/*
- * 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
-phydm_watchdog(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_watchdog(struct dm_struct *dm)
 {
-	PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("%s ======>\n", __func__));
-
-	phydm_common_info_self_update(p_dm);
-	phydm_rssi_monitor_check(p_dm);
-	phydm_basic_dbg_message(p_dm);
-	phydm_auto_dbg_engine(p_dm);
-	phydm_receiver_blocking(p_dm);
-	
-	if (phydm_stop_dm_watchdog_check(p_dm) == true)
-		return;
+	PHYDM_DBG(dm, DBG_COMMON_FLOW, "%s ======>\n", __func__);
 
-	phydm_hw_setting(p_dm);
-
-	#if 0 /*(DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))*/
-	if (*(p_dm->p_is_power_saving) == true) {
-
-		PHYDM_DBG(p_dm, DBG_COMMON_FLOW, ("PHYDM power saving mode\n"));
-		phydm_dig_by_rssi_lps(p_dm);
-		phydm_adaptivity(p_dm);
+	phydm_common_info_self_update(dm);
+	phydm_phy_info_update(dm);
+	phydm_rssi_monitor_check(dm);
+	phydm_basic_dbg_message(dm);
+	phydm_dm_summary(dm, FIRST_MACID);
+#ifdef PHYDM_AUTO_DEGBUG
+	phydm_auto_dbg_engine(dm);
+#endif
+	phydm_receiver_blocking(dm);
 
-		#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-		odm_antenna_diversity(p_dm); /*enable AntDiv in PS mode, request from SD4 Jeff*/
-		#endif
+	if (phydm_stop_dm_watchdog_check(dm) == true)
 		return;
-	}
-	#endif
+
+	phydm_hw_setting(dm);
 
 	#ifdef PHYDM_TDMA_DIG_SUPPORT
-	if (p_dm->original_dig_restore == 0)
-		phydm_tdma_dig_timer_check(p_dm);
-	else 
+	if (dm->original_dig_restore == 0)
+		phydm_tdma_dig_timer_check(dm);
+	else
 	#endif
 	{
-		odm_false_alarm_counter_statistics(p_dm);
-		phydm_noisy_detection(p_dm);
-		phydm_dig(p_dm);
-		phydm_cck_pd_th(p_dm);
+		phydm_false_alarm_counter_statistics(dm);
+		phydm_noisy_detection(dm);
+		phydm_dig(dm);
+		#ifdef PHYDM_SUPPORT_CCKPD
+		phydm_cck_pd_th(dm);
+		#endif
 	}
+
 #ifdef PHYDM_POWER_TRAINING_SUPPORT
-	phydm_update_power_training_state(p_dm);
+	phydm_update_power_training_state(dm);
 #endif
-	phydm_adaptivity(p_dm);
-	phydm_ra_info_watchdog(p_dm);
-	odm_path_diversity(p_dm);
-	odm_cfo_tracking(p_dm);
-	odm_dynamic_tx_power(p_dm);
-	odm_antenna_diversity(p_dm);
-	phydm_adaptive_soml(p_dm);
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	phydm_dynamic_rx_path(p_dm);
+	phydm_adaptivity(dm);
+	phydm_ra_info_watchdog(dm);
+#ifdef CONFIG_PATH_DIVERSITY
+	phydm_tx_path_diversity(dm);
 #endif
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	phydm_beamforming_watchdog(p_dm);
+	phydm_cfo_tracking(dm);
+#ifdef CONFIG_DYNAMIC_TX_TWR
+	phydm_dynamic_tx_power(dm);
+#endif
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	odm_antenna_diversity(dm);
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	phydm_adaptive_soml(dm);
 #endif
 
-	halrf_watchdog(p_dm);
-	phydm_primary_cca(p_dm);
+#ifdef PHYDM_BEAMFORMING_VERSION1
+	phydm_beamforming_watchdog(dm);
+#endif
 
+	halrf_watchdog(dm);
+#ifdef PHYDM_PRIMARY_CCA
+	phydm_primary_cca(dm);
+#endif
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	odm_dtc(p_dm);
+	odm_dtc(dm);
 #endif
 
-	phydm_ccx_monitor(p_dm);
+	phydm_env_mntr_watchdog(dm);
 
 #ifdef PHYDM_LNA_SAT_CHK_SUPPORT
-	phydm_lna_sat_chk_watchdog(p_dm);
+	phydm_lna_sat_chk_watchdog(dm);
 #endif
-
-	phydm_common_info_self_reset(p_dm);
-
+#ifdef CONFIG_MCC_DM
+	#if (RTL8822B_SUPPORT == 1)
+	phydm_mcc_switch(dm);
+	#endif
+#endif
+	phydm_common_info_self_reset(dm);
 }
 
-
-/*
+/*@
  * Init /.. Fixed HW value. Only init time.
- *   */
-void
-odm_cmn_info_init(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum odm_cmninfo_e	cmn_info,
-	u64			value
-)
+ */
+void odm_cmn_info_init(struct dm_struct *dm, enum odm_cmninfo cmn_info,
+		       u64 value)
 {
-	/*  */
 	/* This section is used for init value */
-	/*  */
-	switch	(cmn_info) {
-	/*  */
-	/* Fixed ODM value. */
-	/*  */
-	case	ODM_CMNINFO_ABILITY:
-		p_dm->support_ability = (u64)value;
+	switch (cmn_info) {
+	/* @Fixed ODM value. */
+	case ODM_CMNINFO_ABILITY:
+		dm->support_ability = (u64)value;
 		break;
 
-	case	ODM_CMNINFO_RF_TYPE:
-		p_dm->rf_type = (u8)value;
+	case ODM_CMNINFO_RF_TYPE:
+		dm->rf_type = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_PLATFORM:
-		p_dm->support_platform = (u8)value;
+	case ODM_CMNINFO_PLATFORM:
+		dm->support_platform = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_INTERFACE:
-		p_dm->support_interface = (u8)value;
+	case ODM_CMNINFO_INTERFACE:
+		dm->support_interface = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_MP_TEST_CHIP:
-		p_dm->is_mp_chip = (u8)value;
+	case ODM_CMNINFO_MP_TEST_CHIP:
+		dm->is_mp_chip = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_IC_TYPE:
-		p_dm->support_ic_type = (u32)value;
+	case ODM_CMNINFO_IC_TYPE:
+		dm->support_ic_type = (u32)value;
 		break;
 
-	case	ODM_CMNINFO_CUT_VER:
-		p_dm->cut_version = (u8)value;
+	case ODM_CMNINFO_CUT_VER:
+		dm->cut_version = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_FAB_VER:
-		p_dm->fab_version = (u8)value;
+	case ODM_CMNINFO_FAB_VER:
+		dm->fab_version = (u8)value;
 		break;
-
-	case	ODM_CMNINFO_RFE_TYPE:
-		p_dm->rfe_type = (u8)value;
-		phydm_init_hw_info_by_rfe(p_dm);
+	case ODM_CMNINFO_FW_VER:
+		dm->fw_version = (u8)value;
 		break;
-
-	case    ODM_CMNINFO_RF_ANTENNA_TYPE:
-		p_dm->ant_div_type = (u8)value;
+	case ODM_CMNINFO_FW_SUB_VER:
+		dm->fw_sub_version = (u8)value;
 		break;
-
-	case	ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH:
-		p_dm->with_extenal_ant_switch = (u8)value;
+	case ODM_CMNINFO_RFE_TYPE:
+#if (RTL8821C_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8821C)
+			dm->rfe_type_expand = (u8)value;
+		else
+#endif
+			dm->rfe_type = (u8)value;
+		phydm_init_hw_info_by_rfe(dm);
 		break;
 
-	case    ODM_CMNINFO_BE_FIX_TX_ANT:
-		p_dm->dm_fat_table.b_fix_tx_ant = (u8)value;
+	case ODM_CMNINFO_RF_ANTENNA_TYPE:
+		dm->ant_div_type = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_BOARD_TYPE:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->board_type = (u8)value;
+	case ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH:
+		dm->with_extenal_ant_switch = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_PACKAGE_TYPE:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->package_type = (u8)value;
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	case ODM_CMNINFO_BE_FIX_TX_ANT:
+		dm->dm_fat_table.b_fix_tx_ant = (u8)value;
 		break;
+#endif
 
-	case	ODM_CMNINFO_EXT_LNA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->ext_lna = (u8)value;
+	case ODM_CMNINFO_BOARD_TYPE:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->board_type = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_5G_EXT_LNA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->ext_lna_5g = (u8)value;
+	case ODM_CMNINFO_PACKAGE_TYPE:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->package_type = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_EXT_PA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->ext_pa = (u8)value;
+	case ODM_CMNINFO_EXT_LNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_lna = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_5G_EXT_PA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->ext_pa_5g = (u8)value;
+	case ODM_CMNINFO_5G_EXT_LNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_lna_5g = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_GPA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->type_gpa = (u16)value;
+	case ODM_CMNINFO_EXT_PA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_pa = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_APA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->type_apa = (u16)value;
+	case ODM_CMNINFO_5G_EXT_PA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_pa_5g = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_GLNA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->type_glna = (u16)value;
+	case ODM_CMNINFO_GPA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_gpa = (u16)value;
 		break;
 
-	case	ODM_CMNINFO_ALNA:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->type_alna = (u16)value;
+	case ODM_CMNINFO_APA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_apa = (u16)value;
 		break;
 
-	case	ODM_CMNINFO_EXT_TRSW:
-		if (!p_dm->is_init_hw_info_by_rfe)
-			p_dm->ext_trsw = (u8)value;
+	case ODM_CMNINFO_GLNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_glna = (u16)value;
 		break;
-	case	ODM_CMNINFO_EXT_LNA_GAIN:
-		p_dm->ext_lna_gain = (u8)value;
+
+	case ODM_CMNINFO_ALNA:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->type_alna = (u16)value;
 		break;
-	case	ODM_CMNINFO_PATCH_ID:
-		p_dm->iot_table.win_patch_id = (u8)value;
+
+	case ODM_CMNINFO_EXT_TRSW:
+		if (!dm->is_init_hw_info_by_rfe)
+			dm->ext_trsw = (u8)value;
 		break;
-	case	ODM_CMNINFO_BINHCT_TEST:
-		p_dm->is_in_hct_test = (boolean)value;
+	case ODM_CMNINFO_EXT_LNA_GAIN:
+		dm->ext_lna_gain = (u8)value;
 		break;
-	case	ODM_CMNINFO_BWIFI_TEST:
-		p_dm->wifi_test = (u8)value;
+	case ODM_CMNINFO_PATCH_ID:
+		dm->iot_table.win_patch_id = (u8)value;
 		break;
-	case	ODM_CMNINFO_SMART_CONCURRENT:
-		p_dm->is_dual_mac_smart_concurrent = (boolean)value;
+	case ODM_CMNINFO_BINHCT_TEST:
+		dm->is_in_hct_test = (boolean)value;
 		break;
-	case	ODM_CMNINFO_DOMAIN_CODE_2G:
-		p_dm->odm_regulation_2_4g = (u8)value;
+	case ODM_CMNINFO_BWIFI_TEST:
+		dm->wifi_test = (u8)value;
 		break;
-	case	ODM_CMNINFO_DOMAIN_CODE_5G:
-		p_dm->odm_regulation_5g = (u8)value;
+	case ODM_CMNINFO_SMART_CONCURRENT:
+		dm->is_dual_mac_smart_concurrent = (boolean)value;
 		break;
-#if (DM_ODM_SUPPORT_TYPE &  (ODM_AP))
-	case	ODM_CMNINFO_CONFIG_BB_RF:
-		p_dm->config_bbrf = (boolean)value;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+	case ODM_CMNINFO_CONFIG_BB_RF:
+		dm->config_bbrf = (boolean)value;
 		break;
 #endif
-	case	ODM_CMNINFO_IQKPAOFF:
-		p_dm->rf_calibrate_info.is_iqk_pa_off = (boolean)value;
+	case ODM_CMNINFO_IQKPAOFF:
+		dm->rf_calibrate_info.is_iqk_pa_off = (boolean)value;
 		break;
-	case	ODM_CMNINFO_REGRFKFREEENABLE:
-		p_dm->rf_calibrate_info.reg_rf_kfree_enable = (u8)value;
+	case ODM_CMNINFO_REGRFKFREEENABLE:
+		dm->rf_calibrate_info.reg_rf_kfree_enable = (u8)value;
 		break;
-	case	ODM_CMNINFO_RFKFREEENABLE:
-		p_dm->rf_calibrate_info.rf_kfree_enable = (u8)value;
+	case ODM_CMNINFO_RFKFREEENABLE:
+		dm->rf_calibrate_info.rf_kfree_enable = (u8)value;
 		break;
-	case	ODM_CMNINFO_NORMAL_RX_PATH_CHANGE:
-		p_dm->normal_rx_path = (u8)value;
+	case ODM_CMNINFO_NORMAL_RX_PATH_CHANGE:
+		dm->normal_rx_path = (u8)value;
 		break;
-	case	ODM_CMNINFO_EFUSE0X3D8:
-		p_dm->efuse0x3d8 = (u8)value;
+	case ODM_CMNINFO_EFUSE0X3D8:
+		dm->efuse0x3d8 = (u8)value;
 		break;
-	case	ODM_CMNINFO_EFUSE0X3D7:
-		p_dm->efuse0x3d7 = (u8)value;
+	case ODM_CMNINFO_EFUSE0X3D7:
+		dm->efuse0x3d7 = (u8)value;
 		break;
-	case	ODM_CMNINFO_ADVANCE_OTA:
-		p_dm->p_advance_ota = (u8)value;
+	case ODM_CMNINFO_ADVANCE_OTA:
+		dm->p_advance_ota = (u8)value;
 		break;
-		
+
 #ifdef CONFIG_PHYDM_DFS_MASTER
-	case	ODM_CMNINFO_DFS_REGION_DOMAIN:
-		p_dm->dfs_region_domain = (u8)value;
+	case ODM_CMNINFO_DFS_REGION_DOMAIN:
+		dm->dfs_region_domain = (u8)value;
 		break;
 #endif
-	case	ODM_CMNINFO_SOFT_AP_SPECIAL_SETTING:
-		p_dm->soft_ap_special_setting = (u32)value;
+	case ODM_CMNINFO_SOFT_AP_SPECIAL_SETTING:
+		dm->soft_ap_special_setting = (u32)value;
+		break;
+
+	case ODM_CMNINFO_X_CAP_SETTING:
+		dm->dm_cfo_track.crystal_cap_default = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_DPK_EN:
-		/*p_dm->dpk_en = (u1Byte)value;*/
-		halrf_cmn_info_set(p_dm, HALRF_CMNINFO_DPK_EN, (u64)value);
+	case ODM_CMNINFO_DPK_EN:
+		/*@dm->dpk_en = (u1Byte)value;*/
+		halrf_cmn_info_set(dm, HALRF_CMNINFO_DPK_EN, (u64)value);
 		break;
 
-	case	ODM_CMNINFO_HP_HWID:
-		p_dm->hp_hw_id = (boolean)value;
+	case ODM_CMNINFO_HP_HWID:
+		dm->hp_hw_id = (boolean)value;
 		break;
-	/* To remove the compiler warning, must add an empty default statement to handle the other values. */
 	default:
-		/* do nothing */
 		break;
-
 	}
-
 }
 
-
-void
-odm_cmn_info_hook(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum odm_cmninfo_e	cmn_info,
-	void			*p_value
-)
+void odm_cmn_info_hook(struct dm_struct *dm, enum odm_cmninfo cmn_info,
+		       void *value)
 {
-	/*  */
-	/* Hook call by reference pointer. */
-	/*  */
-	switch	(cmn_info) {
-	/*  */
-	/* Dynamic call by reference pointer. */
-	/*  */
-	case	ODM_CMNINFO_TX_UNI:
-		p_dm->p_num_tx_bytes_unicast = (u64 *)p_value;
+	/* @Hook call by reference pointer. */
+	switch (cmn_info) {
+	/* @Dynamic call by reference pointer. */
+	case ODM_CMNINFO_TX_UNI:
+		dm->num_tx_bytes_unicast = (u64 *)value;
 		break;
 
-	case	ODM_CMNINFO_RX_UNI:
-		p_dm->p_num_rx_bytes_unicast = (u64 *)p_value;
+	case ODM_CMNINFO_RX_UNI:
+		dm->num_rx_bytes_unicast = (u64 *)value;
 		break;
 
-	case	ODM_CMNINFO_BAND:
-		p_dm->p_band_type = (u8 *)p_value;
+	case ODM_CMNINFO_BAND:
+		dm->band_type = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_SEC_CHNL_OFFSET:
-		p_dm->p_sec_ch_offset = (u8 *)p_value;
+	case ODM_CMNINFO_SEC_CHNL_OFFSET:
+		dm->sec_ch_offset = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_SEC_MODE:
-		p_dm->p_security = (u8 *)p_value;
+	case ODM_CMNINFO_SEC_MODE:
+		dm->security = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_BW:
-		p_dm->p_band_width = (u8 *)p_value;
+	case ODM_CMNINFO_BW:
+		dm->band_width = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_CHNL:
-		p_dm->p_channel = (u8 *)p_value;
+	case ODM_CMNINFO_CHNL:
+		dm->channel = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_SCAN:
-		p_dm->p_is_scan_in_process = (boolean *)p_value;
+	case ODM_CMNINFO_SCAN:
+		dm->is_scan_in_process = (boolean *)value;
 		break;
 
-	case	ODM_CMNINFO_POWER_SAVING:
-		p_dm->p_is_power_saving = (boolean *)p_value;
+	case ODM_CMNINFO_POWER_SAVING:
+		dm->is_power_saving = (boolean *)value;
 		break;
 
-	case	ODM_CMNINFO_ONE_PATH_CCA:
-		p_dm->p_one_path_cca = (u8 *)p_value;
+	case ODM_CMNINFO_TDMA:
+		dm->is_tdma = (boolean *)value;
 		break;
 
-	case	ODM_CMNINFO_DRV_STOP:
-		p_dm->p_is_driver_stopped = (boolean *)p_value;
+	case ODM_CMNINFO_ONE_PATH_CCA:
+		dm->one_path_cca = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_PNP_IN:
-		p_dm->p_is_driver_is_going_to_pnp_set_power_sleep = (boolean *)p_value;
+	case ODM_CMNINFO_DRV_STOP:
+		dm->is_driver_stopped = (boolean *)value;
 		break;
-
-	case	ODM_CMNINFO_INIT_ON:
-		p_dm->pinit_adpt_in_progress = (boolean *)p_value;
+	case ODM_CMNINFO_INIT_ON:
+		dm->pinit_adpt_in_progress = (boolean *)value;
 		break;
 
-	case	ODM_CMNINFO_ANT_TEST:
-		p_dm->p_antenna_test = (u8 *)p_value;
+	case ODM_CMNINFO_ANT_TEST:
+		dm->antenna_test = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_NET_CLOSED:
-		p_dm->p_is_net_closed = (boolean *)p_value;
+	case ODM_CMNINFO_NET_CLOSED:
+		dm->is_net_closed = (boolean *)value;
 		break;
 
-	case	ODM_CMNINFO_FORCED_RATE:
-		p_dm->p_forced_data_rate = (u16 *)p_value;
+	case ODM_CMNINFO_FORCED_RATE:
+		dm->forced_data_rate = (u16 *)value;
+		break;
+	case ODM_CMNINFO_ANT_DIV:
+		dm->enable_antdiv = (u8 *)value;
 		break;
-	case	ODM_CMNINFO_ANT_DIV:
-		p_dm->p_enable_antdiv = (u8 *)p_value;
+	case ODM_CMNINFO_PATH_DIV:
+		dm->enable_pathdiv = (u8 *)value;
 		break;
-	case	ODM_CMNINFO_ADAPTIVITY:
-		p_dm->p_enable_adaptivity = (u8 *)p_value;
+	case ODM_CMNINFO_ADAPTIVE_SOML:
+		dm->en_adap_soml = (u8 *)value;
+		break;
+	case ODM_CMNINFO_ADAPTIVITY:
+		dm->enable_adaptivity = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_P2P_LINK:
-		p_dm->dm_dig_table.is_p2p_in_process = (u8 *)p_value;
+	case ODM_CMNINFO_P2P_LINK:
+		dm->dm_dig_table.is_p2p_in_process = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_IS1ANTENNA:
-		p_dm->p_is_1_antenna = (boolean *)p_value;
+	case ODM_CMNINFO_IS1ANTENNA:
+		dm->is_1_antenna = (boolean *)value;
 		break;
 
-	case	ODM_CMNINFO_RFDEFAULTPATH:
-		p_dm->p_rf_default_path = (u8 *)p_value;
+	case ODM_CMNINFO_RFDEFAULTPATH:
+		dm->rf_default_path = (u8 *)value;
 		break;
 
-	case	ODM_CMNINFO_FCS_MODE:
-		p_dm->p_is_fcs_mode_enable = (boolean *)p_value;
+	case ODM_CMNINFO_FCS_MODE:
+		dm->is_fcs_mode_enable = (boolean *)value;
 		break;
-	/*add by YuChen for beamforming PhyDM*/
-	case	ODM_CMNINFO_HUBUSBMODE:
-		p_dm->hub_usb_mode = (u8 *)p_value;
+
+	case ODM_CMNINFO_HUBUSBMODE:
+		dm->hub_usb_mode = (u8 *)value;
 		break;
-	case	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS:
-		p_dm->p_is_fw_dw_rsvd_page_in_progress = (boolean *)p_value;
+	case ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS:
+		dm->is_fw_dw_rsvd_page_in_progress = (boolean *)value;
 		break;
-	case	ODM_CMNINFO_TX_TP:
-		p_dm->p_current_tx_tp = (u32 *)p_value;
+	case ODM_CMNINFO_TX_TP:
+		dm->current_tx_tp = (u32 *)value;
 		break;
-	case	ODM_CMNINFO_RX_TP:
-		p_dm->p_current_rx_tp = (u32 *)p_value;
+	case ODM_CMNINFO_RX_TP:
+		dm->current_rx_tp = (u32 *)value;
 		break;
-	case	ODM_CMNINFO_SOUNDING_SEQ:
-		p_dm->p_sounding_seq = (u8 *)p_value;
+	case ODM_CMNINFO_SOUNDING_SEQ:
+		dm->sounding_seq = (u8 *)value;
 		break;
 #ifdef CONFIG_PHYDM_DFS_MASTER
-	case	ODM_CMNINFO_DFS_MASTER_ENABLE:
-		p_dm->dfs_master_enabled = (u8 *)p_value;
+	case ODM_CMNINFO_DFS_MASTER_ENABLE:
+		dm->dfs_master_enabled = (u8 *)value;
 		break;
 #endif
-	case	ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC:
-		p_dm->dm_fat_table.p_force_tx_ant_by_desc = (u8 *)p_value;
+
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	case ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC:
+		dm->dm_fat_table.p_force_tx_by_desc = (u8 *)value;
 		break;
-	case	ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA:
-		p_dm->dm_fat_table.p_default_s0_s1 = (u8 *)p_value;
+	case ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA:
+		dm->dm_fat_table.p_default_s0_s1 = (u8 *)value;
+		break;
+	case ODM_CMNINFO_BF_ANTDIV_DECISION:
+		dm->dm_fat_table.is_no_csi_feedback = (boolean *)value;
 		break;
-	case	ODM_CMNINFO_SOFT_AP_MODE:
-		p_dm->p_soft_ap_mode = (u32 *)p_value;
+#endif
+
+	case ODM_CMNINFO_SOFT_AP_MODE:
+		dm->soft_ap_mode = (u32 *)value;
 		break;
 	case ODM_CMNINFO_MP_MODE:
-		p_dm->p_mp_mode = (u8 *)p_value;
+		dm->mp_mode = (u8 *)value;
 		break;
-	case	ODM_CMNINFO_INTERRUPT_MASK:
-		p_dm->p_interrupt_mask = (u32 *)p_value;
+	case ODM_CMNINFO_INTERRUPT_MASK:
+		dm->interrupt_mask = (u32 *)value;
 		break;
 	case ODM_CMNINFO_BB_OPERATION_MODE:
-		p_dm->p_bb_op_mode = (u8 *)p_value;
-		break;
-	case ODM_CMNINFO_BF_ANTDIV_DECISION:
-		p_dm->dm_fat_table.is_no_csi_feedback = (boolean *)p_value;
+		dm->bb_op_mode = (u8 *)value;
 		break;
-
 	default:
 		/*do nothing*/
 		break;
-
 	}
-
 }
-/*
+
+/*@
  * Update band/CHannel/.. The values are dynamic but non-per-packet.
- *   */
-void
-odm_cmn_info_update(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			cmn_info,
-	u64			value
-)
+ */
+void odm_cmn_info_update(struct dm_struct *dm, u32 cmn_info, u64 value)
 {
-	/*  */
 	/* This init variable may be changed in run time. */
-	/*  */
-	switch	(cmn_info) {
+	switch (cmn_info) {
 	case ODM_CMNINFO_LINK_IN_PROGRESS:
-		p_dm->is_link_in_process = (boolean)value;
+		dm->is_link_in_process = (boolean)value;
 		break;
 
-	case	ODM_CMNINFO_ABILITY:
-		p_dm->support_ability = (u64)value;
+	case ODM_CMNINFO_ABILITY:
+		dm->support_ability = (u64)value;
 		break;
 
-	case	ODM_CMNINFO_RF_TYPE:
-		p_dm->rf_type = (u8)value;
+	case ODM_CMNINFO_RF_TYPE:
+		dm->rf_type = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_WIFI_DIRECT:
-		p_dm->is_wifi_direct = (boolean)value;
+	case ODM_CMNINFO_WIFI_DIRECT:
+		dm->is_wifi_direct = (boolean)value;
 		break;
 
-	case	ODM_CMNINFO_WIFI_DISPLAY:
-		p_dm->is_wifi_display = (boolean)value;
+	case ODM_CMNINFO_WIFI_DISPLAY:
+		dm->is_wifi_display = (boolean)value;
 		break;
 
-	case	ODM_CMNINFO_LINK:
-		p_dm->is_linked = (boolean)value;
+	case ODM_CMNINFO_LINK:
+		dm->is_linked = (boolean)value;
 		break;
 
-	case	ODM_CMNINFO_CMW500LINK:
-		p_dm->iot_table.is_linked_cmw500 = (boolean)value;
+	case ODM_CMNINFO_CMW500LINK:
+		dm->iot_table.is_linked_cmw500 = (boolean)value;
 		break;
 
-	case	ODM_CMNINFO_STATION_STATE:
-		p_dm->bsta_state = (boolean)value;
+	case ODM_CMNINFO_STATION_STATE:
+		dm->bsta_state = (boolean)value;
 		break;
 
-	case	ODM_CMNINFO_RSSI_MIN:
-		p_dm->rssi_min = (u8)value;
+	case ODM_CMNINFO_RSSI_MIN:
+		dm->rssi_min = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_RSSI_MIN_BY_PATH:
-		p_dm->rssi_min_by_path = (u8)value;
+	case ODM_CMNINFO_RSSI_MIN_BY_PATH:
+		dm->rssi_min_by_path = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_DBG_COMP:
-		p_dm->debug_components = (u64)value;
-		break;
-
-	case	ODM_CMNINFO_DBG_LEVEL:
-		p_dm->debug_level = (u32)value;
+	case ODM_CMNINFO_DBG_COMP:
+		dm->debug_components = (u64)value;
 		break;
 
 #ifdef ODM_CONFIG_BT_COEXIST
 	/* The following is for BT HS mode and BT coexist mechanism. */
 	case ODM_CMNINFO_BT_ENABLED:
-		p_dm->bt_info_table.is_bt_enabled = (boolean)value;
+		dm->bt_info_table.is_bt_enabled = (boolean)value;
 		break;
 
 	case ODM_CMNINFO_BT_HS_CONNECT_PROCESS:
-		p_dm->bt_info_table.is_bt_connect_process = (boolean)value;
+		dm->bt_info_table.is_bt_connect_process = (boolean)value;
 		break;
 
 	case ODM_CMNINFO_BT_HS_RSSI:
-		p_dm->bt_info_table.bt_hs_rssi = (u8)value;
+		dm->bt_info_table.bt_hs_rssi = (u8)value;
 		break;
 
-	case	ODM_CMNINFO_BT_OPERATION:
-		p_dm->bt_info_table.is_bt_hs_operation = (boolean)value;
+	case ODM_CMNINFO_BT_OPERATION:
+		dm->bt_info_table.is_bt_hs_operation = (boolean)value;
 		break;
 
-	case	ODM_CMNINFO_BT_LIMITED_DIG:
-		p_dm->bt_info_table.is_bt_limited_dig = (boolean)value;
+	case ODM_CMNINFO_BT_LIMITED_DIG:
+		dm->bt_info_table.is_bt_limited_dig = (boolean)value;
 		break;
 #endif
 
-	case	ODM_CMNINFO_AP_TOTAL_NUM:
-		p_dm->ap_total_num = (u8)value;
-		break;
-
-	case ODM_CMNINFO_POWER_TRAINING:
-		p_dm->is_disable_power_training = (boolean)value;
+	case ODM_CMNINFO_AP_TOTAL_NUM:
+		dm->ap_total_num = (u8)value;
 		break;
 
 #ifdef CONFIG_PHYDM_DFS_MASTER
-	case	ODM_CMNINFO_DFS_REGION_DOMAIN:
-		p_dm->dfs_region_domain = (u8)value;
+	case ODM_CMNINFO_DFS_REGION_DOMAIN:
+		dm->dfs_region_domain = (u8)value;
 		break;
 #endif
 
-	case	ODM_CMNINFO_BT_CONTINUOUS_TURN:
-		p_dm->is_bt_continuous_turn = (boolean)value;
-		break;
-
-#if 0
-	case	ODM_CMNINFO_OP_MODE:
-		p_dm->op_mode = (u8)value;
-		break;
-
-	case	ODM_CMNINFO_BAND:
-		p_dm->band_type = (u8)value;
-		break;
-
-	case	ODM_CMNINFO_SEC_CHNL_OFFSET:
-		p_dm->sec_ch_offset = (u8)value;
-		break;
-
-	case	ODM_CMNINFO_SEC_MODE:
-		p_dm->security = (u8)value;
-		break;
-
-	case	ODM_CMNINFO_BW:
-		p_dm->band_width = (u8)value;
-		break;
-
-	case	ODM_CMNINFO_CHNL:
-		p_dm->channel = (u8)value;
+	case ODM_CMNINFO_BT_CONTINUOUS_TURN:
+		dm->is_bt_continuous_turn = (boolean)value;
 		break;
-#endif
 	default:
-		/* do nothing */
 		break;
 	}
-
-
 }
 
-u32
-phydm_cmn_info_query(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum phydm_info_query_e		info_type
-)
+u32 phydm_cmn_info_query(struct dm_struct *dm, enum phydm_info_query info_type)
 {
-	struct phydm_fa_struct		*p_fa_t = &(p_dm->false_alm_cnt);
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
 
 	switch (info_type) {
-
-	/*=== [FA Relative] ===========================================*/
+	/*@=== [FA Relative] ===========================================*/
 	case PHYDM_INFO_FA_OFDM:
-		return p_fa_t->cnt_ofdm_fail;
+		return fa_t->cnt_ofdm_fail;
 
 	case PHYDM_INFO_FA_CCK:
-		return p_fa_t->cnt_cck_fail;
+		return fa_t->cnt_cck_fail;
 
 	case PHYDM_INFO_FA_TOTAL:
-		return p_fa_t->cnt_all;
+		return fa_t->cnt_all;
 
 	case PHYDM_INFO_CCA_OFDM:
-		return p_fa_t->cnt_ofdm_cca;
+		return fa_t->cnt_ofdm_cca;
 
 	case PHYDM_INFO_CCA_CCK:
-		return p_fa_t->cnt_cck_cca;
+		return fa_t->cnt_cck_cca;
 
 	case PHYDM_INFO_CCA_ALL:
-		return p_fa_t->cnt_cca_all;
+		return fa_t->cnt_cca_all;
 
 	case PHYDM_INFO_CRC32_OK_VHT:
-		return p_fa_t->cnt_vht_crc32_ok;
+		return fa_t->cnt_vht_crc32_ok;
 
 	case PHYDM_INFO_CRC32_OK_HT:
-		return p_fa_t->cnt_ht_crc32_ok;
+		return fa_t->cnt_ht_crc32_ok;
 
 	case PHYDM_INFO_CRC32_OK_LEGACY:
-		return p_fa_t->cnt_ofdm_crc32_ok;
+		return fa_t->cnt_ofdm_crc32_ok;
 
 	case PHYDM_INFO_CRC32_OK_CCK:
-		return p_fa_t->cnt_cck_crc32_ok;
+		return fa_t->cnt_cck_crc32_ok;
 
 	case PHYDM_INFO_CRC32_ERROR_VHT:
-		return p_fa_t->cnt_vht_crc32_error;
+		return fa_t->cnt_vht_crc32_error;
 
 	case PHYDM_INFO_CRC32_ERROR_HT:
-		return p_fa_t->cnt_ht_crc32_error;
+		return fa_t->cnt_ht_crc32_error;
 
 	case PHYDM_INFO_CRC32_ERROR_LEGACY:
-		return p_fa_t->cnt_ofdm_crc32_error;
+		return fa_t->cnt_ofdm_crc32_error;
 
 	case PHYDM_INFO_CRC32_ERROR_CCK:
-		return p_fa_t->cnt_cck_crc32_error;
+		return fa_t->cnt_cck_crc32_error;
 
 	case PHYDM_INFO_EDCCA_FLAG:
-		return p_fa_t->edcca_flag;
+		return fa_t->edcca_flag;
 
 	case PHYDM_INFO_OFDM_ENABLE:
-		return p_fa_t->ofdm_block_enable;
+		return fa_t->ofdm_block_enable;
 
 	case PHYDM_INFO_CCK_ENABLE:
-		return p_fa_t->cck_block_enable;
+		return fa_t->cck_block_enable;
 
 	case PHYDM_INFO_DBG_PORT_0:
-		return p_fa_t->dbg_port0;
-				
+		return fa_t->dbg_port0;
+
 	case PHYDM_INFO_CRC32_OK_HT_AGG:
-		return p_fa_t->cnt_ht_crc32_ok_agg;
-		
+		return fa_t->cnt_ht_crc32_ok_agg;
+
 	case PHYDM_INFO_CRC32_ERROR_HT_AGG:
-		return p_fa_t->cnt_ht_crc32_error_agg;
-		
-	/*=== [DIG] ================================================*/	
-	
+		return fa_t->cnt_ht_crc32_error_agg;
+
+	/*@=== [DIG] ================================================*/
+
 	case PHYDM_INFO_CURR_IGI:
-		return p_dig_t->cur_ig_value;
+		return dig_t->cur_ig_value;
 
-	/*=== [RSSI] ===============================================*/
+	/*@=== [RSSI] ===============================================*/
 	case PHYDM_INFO_RSSI_MIN:
-		return (u32)p_dm->rssi_min;
-		
+		return (u32)dm->rssi_min;
+
 	case PHYDM_INFO_RSSI_MAX:
-		return (u32)p_dm->rssi_max;
+		return (u32)dm->rssi_max;
 
-	case PHYDM_INFO_CLM_RATIO :
+	case PHYDM_INFO_CLM_RATIO:
 		return (u32)ccx_info->clm_ratio;
-	case PHYDM_INFO_NHM_RATIO :
+	case PHYDM_INFO_NHM_RATIO:
 		return (u32)ccx_info->nhm_ratio;
 	default:
 		return 0xffffffff;
-
 	}
 }
 
-
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-odm_init_all_work_items(struct PHY_DM_STRUCT	*p_dm)
+void odm_init_all_work_items(struct dm_struct *dm)
 {
-
-	struct _ADAPTER		*p_adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 #if USE_WORKITEM
 
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	odm_initialize_work_item(p_dm,
-			 &p_dm->dm_drp_table.phydm_dynamic_rx_path_workitem,
-		 (RT_WORKITEM_CALL_BACK)phydm_dynamic_rx_path_workitem_callback,
-				 (void *)p_adapter,
-				 "DynamicRxPathWorkitem");
-
-#endif
-
 #ifdef CONFIG_ADAPTIVE_SOML
-	odm_initialize_work_item(p_dm,
-			 &p_dm->dm_soml_table.phydm_adaptive_soml_workitem,
-		 (RT_WORKITEM_CALL_BACK)phydm_adaptive_soml_workitem_callback,
-				 (void *)p_adapter,
+	odm_initialize_work_item(dm,
+				 &dm->dm_soml_table.phydm_adaptive_soml_workitem,
+				 (RT_WORKITEM_CALL_BACK)phydm_adaptive_soml_workitem_callback,
+				 (void *)adapter,
 				 "AdaptiveSOMLWorkitem");
 #endif
 
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	odm_initialize_work_item(dm,
+				 &dm->phydm_evm_antdiv_workitem,
+				 (RT_WORKITEM_CALL_BACK)phydm_evm_antdiv_workitem_callback,
+				 (void *)adapter,
+				 "EvmAntdivWorkitem");
+#endif
+
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-	odm_initialize_work_item(p_dm,
-		 &p_dm->dm_swat_table.phydm_sw_antenna_switch_workitem,
-			 (RT_WORKITEM_CALL_BACK)odm_sw_antdiv_workitem_callback,
-				 (void *)p_adapter,
+	odm_initialize_work_item(dm,
+				 &dm->dm_swat_table.phydm_sw_antenna_switch_workitem,
+				 (RT_WORKITEM_CALL_BACK)odm_sw_antdiv_workitem_callback,
+				 (void *)adapter,
 				 "AntennaSwitchWorkitem");
 #endif
 #if (defined(CONFIG_HL_SMART_ANTENNA))
-	odm_initialize_work_item(p_dm,
-			 &p_dm->dm_sat_table.hl_smart_antenna_workitem,
-		 (RT_WORKITEM_CALL_BACK)phydm_beam_switch_workitem_callback,
-				 (void *)p_adapter,
+	odm_initialize_work_item(dm,
+				 &dm->dm_sat_table.hl_smart_antenna_workitem,
+				 (RT_WORKITEM_CALL_BACK)phydm_beam_switch_workitem_callback,
+				 (void *)adapter,
 				 "hl_smart_ant_workitem");
 
-	odm_initialize_work_item(p_dm,
-		 &p_dm->dm_sat_table.hl_smart_antenna_decision_workitem,
-		 (RT_WORKITEM_CALL_BACK)phydm_beam_decision_workitem_callback,
-				 (void *)p_adapter,
+	odm_initialize_work_item(dm,
+				 &dm->dm_sat_table.hl_smart_antenna_decision_workitem,
+				 (RT_WORKITEM_CALL_BACK)phydm_beam_decision_workitem_callback,
+				 (void *)adapter,
 				 "hl_smart_ant_decision_workitem");
 #endif
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->path_div_switch_workitem),
-		(RT_WORKITEM_CALL_BACK)odm_path_div_chk_ant_switch_workitem_callback,
-		(void *)p_adapter,
-		"SWAS_WorkItem");
-
-	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->cck_path_diversity_workitem),
-		(RT_WORKITEM_CALL_BACK)odm_cck_tx_path_diversity_work_item_callback,
-		(void *)p_adapter,
-		"CCKTXPathDiversityWorkItem");
-
-	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->ra_rpt_workitem),
+		dm,
+		&dm->ra_rpt_workitem,
 		(RT_WORKITEM_CALL_BACK)halrf_update_init_rate_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"ra_rpt_workitem");
 
 #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->fast_ant_training_workitem),
+		dm,
+		&dm->fast_ant_training_workitem,
 		(RT_WORKITEM_CALL_BACK)odm_fast_ant_training_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"fast_ant_training_workitem");
 #endif
 
 #endif /*#if USE_WORKITEM*/
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_enter_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_enter_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_enter_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_enter_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_leave_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_leave_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_leave_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_leave_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_fw_ndpa_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_fw_ndpa_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_clk_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_clk_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_clk_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_clk_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_rate_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_rate_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_rate_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_rate_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_status_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_status_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_status_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_status_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_reset_tx_path_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_reset_tx_path_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item),
+		dm,
+		&dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item,
 		(RT_WORKITEM_CALL_BACK)hal_com_txbf_get_tx_rate_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"txbf_get_tx_rate_work_item");
 #endif
 
-	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->adaptivity.phydm_pause_edcca_work_item),
-		(RT_WORKITEM_CALL_BACK)phydm_pause_edcca_work_item_callback,
-		(void *)p_adapter,
-		"phydm_pause_edcca_work_item");
-
-	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->adaptivity.phydm_resume_edcca_work_item),
-		(RT_WORKITEM_CALL_BACK)phydm_resume_edcca_work_item_callback,
-		(void *)p_adapter,
-		"phydm_resume_edcca_work_item");
-
 #if (PHYDM_LA_MODE_SUPPORT == 1)
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->adcsmp.adc_smp_work_item),
+		dm,
+		&dm->adcsmp.adc_smp_work_item,
 		(RT_WORKITEM_CALL_BACK)adc_smp_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"adc_smp_work_item");
 
 	odm_initialize_work_item(
-		p_dm,
-		&(p_dm->adcsmp.adc_smp_work_item_1),
+		dm,
+		&dm->adcsmp.adc_smp_work_item_1,
 		(RT_WORKITEM_CALL_BACK)adc_smp_work_item_callback,
-		(void *)p_adapter,
+		(void *)adapter,
 		"adc_smp_work_item_1");
 #endif
-
 }
 
-void
-odm_free_all_work_items(struct PHY_DM_STRUCT	*p_dm)
+void odm_free_all_work_items(struct dm_struct *dm)
 {
 #if USE_WORKITEM
 
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-	odm_free_work_item(&(p_dm->dm_swat_table.phydm_sw_antenna_switch_workitem));
-#endif
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	odm_free_work_item(&(p_dm->dm_drp_table.phydm_dynamic_rx_path_workitem));
+	odm_free_work_item(&dm->dm_swat_table.phydm_sw_antenna_switch_workitem);
 #endif
 
 #ifdef CONFIG_ADAPTIVE_SOML
-	odm_free_work_item(&(p_dm->dm_soml_table.phydm_adaptive_soml_workitem));
+	odm_free_work_item(&dm->dm_soml_table.phydm_adaptive_soml_workitem);
 #endif
 
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	odm_free_work_item(&dm->phydm_evm_antdiv_workitem);
+#endif
 
 #if (defined(CONFIG_HL_SMART_ANTENNA))
-	odm_free_work_item(&(p_dm->dm_sat_table.hl_smart_antenna_workitem));
-	odm_free_work_item(&(p_dm->dm_sat_table.hl_smart_antenna_decision_workitem));
+	odm_free_work_item(&dm->dm_sat_table.hl_smart_antenna_workitem);
+	odm_free_work_item(&dm->dm_sat_table.hl_smart_antenna_decision_workitem);
 #endif
 
-	odm_free_work_item(&(p_dm->path_div_switch_workitem));
-	odm_free_work_item(&(p_dm->cck_path_diversity_workitem));
 #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-	odm_free_work_item(&(p_dm->fast_ant_training_workitem));
+	odm_free_work_item(&dm->fast_ant_training_workitem);
 #endif
-	odm_free_work_item(&(p_dm->ra_rpt_workitem));
-	/*odm_free_work_item((&p_dm->sbdcnt_workitem));*/
+	odm_free_work_item(&dm->ra_rpt_workitem);
+/*odm_free_work_item((&dm->sbdcnt_workitem));*/
 #endif
 
-#if (BEAMFORMING_SUPPORT == 1)
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_enter_work_item));
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_leave_work_item));
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item));
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_clk_work_item));
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_rate_work_item));
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_status_work_item));
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item));
-	odm_free_work_item((&p_dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item));
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_enter_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_leave_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_fw_ndpa_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_clk_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_rate_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_status_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_reset_tx_path_work_item));
+	odm_free_work_item((&dm->beamforming_info.txbf_info.txbf_get_tx_rate_work_item));
 #endif
 
-	odm_free_work_item((&p_dm->adaptivity.phydm_pause_edcca_work_item));
-	odm_free_work_item((&p_dm->adaptivity.phydm_resume_edcca_work_item));
-
 #if (PHYDM_LA_MODE_SUPPORT == 1)
-	odm_free_work_item((&p_dm->adcsmp.adc_smp_work_item));
-	odm_free_work_item((&p_dm->adcsmp.adc_smp_work_item_1));
+	odm_free_work_item((&dm->adcsmp.adc_smp_work_item));
+	odm_free_work_item((&dm->adcsmp.adc_smp_work_item_1));
 #endif
-
 }
 #endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
 
-void
-odm_init_all_timers(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void odm_init_all_timers(struct dm_struct *dm)
 {
 #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	odm_ant_div_timers(p_dm, INIT_ANTDIV_TIMMER);
+	odm_ant_div_timers(dm, INIT_ANTDIV_TIMMER);
+#endif
+#if (defined(PHYDM_TDMA_DIG_SUPPORT))
+#ifdef IS_USE_NEW_TDMA
+	phydm_tdma_dig_timers(dm, INIT_TDMA_DIG_TIMMER);
+#endif
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	phydm_adaptive_soml_timers(dm, INIT_SOML_TIMMER);
 #endif
-
-	phydm_adaptive_soml_timers(p_dm, INIT_SOML_TIMMER);
-
 #ifdef PHYDM_LNA_SAT_CHK_SUPPORT
-	phydm_lna_sat_chk_timers(p_dm, INIT_LNA_SAT_CHK_TIMMER);
+#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+	phydm_lna_sat_chk_timers(dm, INIT_LNA_SAT_CHK_TIMMER);
 #endif
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	phydm_dynamic_rx_path_timers(p_dm, INIT_DRP_TIMMER);
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	odm_initialize_timer(p_dm, &p_dm->path_div_switch_timer,
-		(void *)odm_path_div_chk_ant_switch_callback, NULL, "PathDivTimer");
-	odm_initialize_timer(p_dm, &p_dm->cck_path_diversity_timer,
-		(void *)odm_cck_tx_path_diversity_callback, NULL, "cck_path_diversity_timer");
-	odm_initialize_timer(p_dm, &p_dm->sbdcnt_timer,
+	odm_initialize_timer(dm, &dm->sbdcnt_timer,
 			     (void *)phydm_sbd_callback, NULL, "SbdTimer");
-#if (BEAMFORMING_SUPPORT == 1)
-	odm_initialize_timer(p_dm, &p_dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer,
-		(void *)hal_com_txbf_fw_ndpa_timer_callback, NULL, "txbf_fw_ndpa_timer");
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	odm_initialize_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer,
+			     (void *)hal_com_txbf_fw_ndpa_timer_callback, NULL,
+			     "txbf_fw_ndpa_timer");
 #endif
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	odm_initialize_timer(p_dm, &p_dm->beamforming_info.beamforming_timer,
-		(void *)beamforming_sw_timer_callback, NULL, "beamforming_timer");
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	odm_initialize_timer(dm, &dm->beamforming_info.beamforming_timer,
+			     (void *)beamforming_sw_timer_callback, NULL,
+			     "beamforming_timer");
 #endif
 #endif
 }
 
-void
-odm_cancel_all_timers(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void odm_cancel_all_timers(struct dm_struct *dm)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	/*  */
-	/* 2012/01/12 MH Temp BSOD fix. We need to find NIC allocate mem fail reason in */
-	/* win7 platform. */
-	/*  */
-	HAL_ADAPTER_STS_CHK(p_dm);
+	/* @2012/01/12 MH Temp BSOD fix. We need to find NIC allocate mem fail reason in win7*/
+	if (dm->adapter == NULL)
+		return;
 #endif
 
 #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	odm_ant_div_timers(p_dm, CANCEL_ANTDIV_TIMMER);
+	odm_ant_div_timers(dm, CANCEL_ANTDIV_TIMMER);
+#endif
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+#ifdef IS_USE_NEW_TDMA
+	phydm_tdma_dig_timers(dm, CANCEL_TDMA_DIG_TIMMER);
+#endif
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	phydm_adaptive_soml_timers(dm, CANCEL_SOML_TIMMER);
 #endif
-
-	phydm_adaptive_soml_timers(p_dm, CANCEL_SOML_TIMMER);
-
 #ifdef PHYDM_LNA_SAT_CHK_SUPPORT
-	phydm_lna_sat_chk_timers(p_dm, CANCEL_LNA_SAT_CHK_TIMMER);
+#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+	phydm_lna_sat_chk_timers(dm, CANCEL_LNA_SAT_CHK_TIMMER);
 #endif
-
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	phydm_dynamic_rx_path_timers(p_dm, CANCEL_DRP_TIMMER);
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	odm_cancel_timer(p_dm, &p_dm->path_div_switch_timer);
-	odm_cancel_timer(p_dm, &p_dm->cck_path_diversity_timer);
-	odm_cancel_timer(p_dm, &p_dm->sbdcnt_timer);
-#if (BEAMFORMING_SUPPORT == 1)
-	odm_cancel_timer(p_dm, &p_dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
+	odm_cancel_timer(dm, &dm->sbdcnt_timer);
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	odm_cancel_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
 #endif
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	odm_cancel_timer(p_dm, &p_dm->beamforming_info.beamforming_timer);
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	odm_cancel_timer(dm, &dm->beamforming_info.beamforming_timer);
 #endif
 #endif
-
 }
 
-
-void
-odm_release_all_timers(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void odm_release_all_timers(struct dm_struct *dm)
 {
 #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	odm_ant_div_timers(p_dm, RELEASE_ANTDIV_TIMMER);
+	odm_ant_div_timers(dm, RELEASE_ANTDIV_TIMMER);
+#endif
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+#ifdef IS_USE_NEW_TDMA
+	phydm_tdma_dig_timers(dm, RELEASE_TDMA_DIG_TIMMER);
+#endif
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	phydm_adaptive_soml_timers(dm, RELEASE_SOML_TIMMER);
 #endif
-	phydm_adaptive_soml_timers(p_dm, RELEASE_SOML_TIMMER);
-
 #ifdef PHYDM_LNA_SAT_CHK_SUPPORT
-	phydm_lna_sat_chk_timers(p_dm, RELEASE_LNA_SAT_CHK_TIMMER);
+#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+	phydm_lna_sat_chk_timers(dm, RELEASE_LNA_SAT_CHK_TIMMER);
 #endif
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	phydm_dynamic_rx_path_timers(p_dm, RELEASE_DRP_TIMMER);
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	odm_release_timer(p_dm, &p_dm->path_div_switch_timer);
-	odm_release_timer(p_dm, &p_dm->cck_path_diversity_timer);
-	odm_release_timer(p_dm, &p_dm->sbdcnt_timer);
-#if (BEAMFORMING_SUPPORT == 1)
-	odm_release_timer(p_dm, &p_dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
+	odm_release_timer(dm, &dm->sbdcnt_timer);
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	odm_release_timer(dm, &dm->beamforming_info.txbf_info.txbf_fw_ndpa_timer);
 #endif
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	odm_release_timer(p_dm, &p_dm->beamforming_info.beamforming_timer);
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	odm_release_timer(dm, &dm->beamforming_info.beamforming_timer);
 #endif
 #endif
 }
 
-
-/* 3============================================================
- * 3 Tx Power Tracking
- * 3============================================================ */
-
-
-
-
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-void
-odm_init_all_threads(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void odm_init_all_threads(
+	struct dm_struct *dm)
 {
 #ifdef TPT_THREAD
-	k_tpt_task_init(p_dm->priv);
+	k_tpt_task_init(dm->priv);
 #endif
 }
 
-void
-odm_stop_all_threads(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void odm_stop_all_threads(
+	struct dm_struct *dm)
 {
 #ifdef TPT_THREAD
-	k_tpt_task_stop(p_dm->priv);
+	k_tpt_task_stop(dm->priv);
 #endif
 }
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-/* Justin: According to the current RRSI to adjust Response Frame TX power, 2012/11/05 */
-void odm_dtc(struct PHY_DM_STRUCT *p_dm)
+/* @Justin: According to the current RRSI to adjust Response Frame TX power,
+ * 2012/11/05
+ */
+void odm_dtc(struct dm_struct *dm)
 {
 #ifdef CONFIG_DM_RESP_TXAGC
-#define DTC_BASE            35	/* RSSI higher than this value, start to decade TX power */
-#define DTC_DWN_BASE       (DTC_BASE-5)	/* RSSI lower than this value, start to increase TX power */
+/* RSSI higher than this value, start to decade TX power */
+#define DTC_BASE 35
+
+/* RSSI lower than this value, start to increase TX power */
+#define DTC_DWN_BASE (DTC_BASE - 5)
 
 	/* RSSI vs TX power step mapping: decade TX power */
 	static const u8 dtc_table_down[] = {
@@ -2817,8 +2909,7 @@ void odm_dtc(struct PHY_DM_STRUCT *p_dm)
 		(DTC_BASE + 10),
 		(DTC_BASE + 15),
 		(DTC_BASE + 20),
-		(DTC_BASE + 25)
-	};
+		(DTC_BASE + 25)};
 
 	/* RSSI vs TX power step mapping: increase TX power */
 	static const u8 dtc_table_up[] = {
@@ -2832,8 +2923,7 @@ void odm_dtc(struct PHY_DM_STRUCT *p_dm)
 		(DTC_DWN_BASE - 25),
 		(DTC_DWN_BASE - 25),
 		(DTC_DWN_BASE - 30),
-		(DTC_DWN_BASE - 35)
-	};
+		(DTC_DWN_BASE - 35)};
 
 	u8 i;
 	u8 dtc_steps = 0;
@@ -2841,28 +2931,28 @@ void odm_dtc(struct PHY_DM_STRUCT *p_dm)
 	u8 resp_txagc = 0;
 
 #if 0
-	/* As DIG is disabled, DTC is also disable */
-	if (!(p_dm->support_ability & ODM_XXXXXX))
+	/* @As DIG is disabled, DTC is also disable */
+	if (!(dm->support_ability & ODM_XXXXXX))
 		return;
 #endif
 
-	if (p_dm->rssi_min > DTC_BASE) {
+	if (dm->rssi_min > DTC_BASE) {
 		/* need to decade the CTS TX power */
 		sign = 1;
 		for (i = 0; i < ARRAY_SIZE(dtc_table_down); i++) {
-			if ((dtc_table_down[i] >= p_dm->rssi_min) || (dtc_steps >= 6))
+			if (dtc_table_down[i] >= dm->rssi_min || dtc_steps >= 6)
 				break;
 			else
 				dtc_steps++;
 		}
 	}
 #if 0
-	else if (p_dm->rssi_min > DTC_DWN_BASE) {
+	else if (dm->rssi_min > DTC_DWN_BASE) {
 		/* needs to increase the CTS TX power */
 		sign = 0;
 		dtc_steps = 1;
 		for (i = 0; i < ARRAY_SIZE(dtc_table_up); i++) {
-			if ((dtc_table_up[i] <= p_dm->rssi_min) || (dtc_steps >= 10))
+			if (dtc_table_up[i] <= dm->rssi_min || dtc_steps >= 10)
 				break;
 			else
 				dtc_steps++;
@@ -2876,191 +2966,303 @@ void odm_dtc(struct PHY_DM_STRUCT *p_dm)
 
 	resp_txagc = dtc_steps | (sign << 4);
 	resp_txagc = resp_txagc | (resp_txagc << 5);
-	odm_write_1byte(p_dm, 0x06d9, resp_txagc);
+	odm_write_1byte(dm, 0x06d9, resp_txagc);
 
-	PHYDM_DBG(p_dm, ODM_COMP_PWR_TRAIN, ("%s rssi_min:%u, set RESP_TXAGC to %s %u\n",
-		__func__, p_dm->rssi_min, sign ? "minus" : "plus", dtc_steps));
-#endif /* CONFIG_RESP_TXAGC_ADJUST */
+	PHYDM_DBG(dm, ODM_COMP_PWR_TRAIN,
+		  "%s rssi_min:%u, set RESP_TXAGC to %s %u\n", __func__,
+		  dm->rssi_min, sign ? "minus" : "plus", dtc_steps);
+#endif /* @CONFIG_RESP_TXAGC_ADJUST */
 }
 
-#endif /* #if (DM_ODM_SUPPORT_TYPE == ODM_CE) */
-
-
-/*<20170126, BB-Kevin>8188F D-CUT DC cancellation and 8821C*/
-void
-phydm_dc_cancellation(
-	struct PHY_DM_STRUCT	*p_dm
+#endif /* @#if (DM_ODM_SUPPORT_TYPE == ODM_CE) */
 
-)
-{	
+/*@<20170126, BB-Kevin>8188F D-CUT DC cancellation and 8821C*/
+void phydm_dc_cancellation(struct dm_struct *dm)
+{
 #ifdef PHYDM_DC_CANCELLATION
-	u32		offset_i_hex[ODM_RF_PATH_MAX] = {0};
-	u32		offset_q_hex[ODM_RF_PATH_MAX] = {0};
-	u32		reg_value32[ODM_RF_PATH_MAX] = {0};
-	u8		path = RF_PATH_A;
+	u32 offset_i_hex[PHYDM_MAX_RF_PATH] = {0};
+	u32 offset_q_hex[PHYDM_MAX_RF_PATH] = {0};
+	u32 reg_value32[PHYDM_MAX_RF_PATH] = {0};
+	u8 path = RF_PATH_A;
+	u8 set_result;
 
-	if (!(p_dm->support_ic_type & ODM_DC_CANCELLATION_SUPPORT))
+	if (!(dm->support_ic_type & ODM_DC_CANCELLATION_SUPPORT))
 		return;
-
-	if ((p_dm->support_ic_type & ODM_RTL8188F) && (p_dm->cut_version < ODM_CUT_D))
+	if ((dm->support_ic_type & ODM_RTL8188F) &&
+	    dm->cut_version < ODM_CUT_D)
 		return;
+	if ((dm->support_ic_type & ODM_RTL8192F) &&
+	    dm->cut_version == ODM_CUT_A)
+		return;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
 
-	/*DC_Estimation (only for 2x2 ic now) */
+	/*@DC_Estimation (only for 2x2 ic now) */
 
-	for (path = RF_PATH_A; path < ODM_RF_PATH_MAX; path++) {
-		if (p_dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
-			if (!phydm_set_bb_dbg_port(p_dm,
-				BB_DBGPORT_PRIORITY_2, 0x235)) {/*set debug port to 0x235*/
-				PHYDM_DBG(p_dm, ODM_COMP_API,
-					("[DC Cancellation] Set Debug port Fail"));
+	for (path = RF_PATH_A; path < PHYDM_MAX_RF_PATH; path++) {
+		if (path > RF_PATH_A &&
+		    dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8188F |
+					  ODM_RTL8710B | ODM_RTL8721D))
+			break;
+		else if (path > RF_PATH_B &&
+			 dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8192F))
+			break;
+		if (phydm_stop_ic_trx(dm, PHYDM_SET) == PHYDM_SET_FAIL) {
+			PHYDM_DBG(dm, ODM_COMP_API, "STOP_TRX_FAIL\n");
+			return;
+		}
+		odm_write_dig(dm, 0x7e);
+		/*@Disable LNA*/
+		if (dm->support_ic_type & ODM_RTL8821C)
+			halrf_rf_lna_setting(dm, HALRF_LNA_DISABLE);
+		/*Turn off 3-wire*/
+		phydm_stop_3_wire(dm, PHYDM_SET);
+		if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
+			/*set debug port to 0x235*/
+			if (!phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x235)) {
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "Set Debug port Fail\n");
+				return;
+			}
+		} else if (dm->support_ic_type & ODM_RTL8721D) {
+			/*set debug port to 0x200*/
+			if (!phydm_set_bb_dbg_port(dm, DBGPORT_PRI_2, 0x200)) {
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "Set Debug port Fail\n");
 				return;
 			}
-		} else if (p_dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B)) {
-			if (!phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_2, 0x200)) {
+		} else if (dm->support_ic_type & ODM_RTL8821C) {
+			if (!phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x200)) {
 				/*set debug port to 0x200*/
-				PHYDM_DBG(p_dm, ODM_COMP_API,
-					("[DC Cancellation] Set Debug port Fail"));
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "Set Debug port Fail\n");
 				return;
 			}
-			phydm_bb_dbg_port_header_sel(p_dm, 0x0);
-			if (p_dm->rf_type > RF_1T1R) {
-				if (!phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_2, 0x202)) {
-					/*set debug port to 0x200*/
-					PHYDM_DBG(p_dm, ODM_COMP_API,
-						("[DC Cancellation] Set Debug port Fail"));
-					return;
-				}
-				phydm_bb_dbg_port_header_sel(p_dm, 0x0);
+			phydm_bb_dbg_port_header_sel(dm, 0x0);
+		} else if (dm->support_ic_type & ODM_RTL8822B) {
+			if (path == RF_PATH_A &&
+			    !phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x200)) {
+				/*set debug port to 0x200*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "Set Debug port Fail\n");
+				return;
+			}
+			if (path == RF_PATH_B &&
+			    !phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x202)) {
+				/*set debug port to 0x200*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "Set Debug port Fail\n");
+				return;
+			}
+			phydm_bb_dbg_port_header_sel(dm, 0x0);
+		} else if (dm->support_ic_type & ODM_RTL8192F) {
+			if (path == RF_PATH_A &&
+			    !phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x235)) {
+				/*set debug port to 0x235*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "Set Debug port Fail\n");
+				return;
+			}
+			if (path == RF_PATH_B &&
+			    !phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x23d)) {
+				/*set debug port to 0x23d*/
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "Set Debug port Fail\n");
+				return;
 			}
 		}
-	
-		odm_write_dig(p_dm, 0x7E);
-	
-		if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-			odm_set_bb_reg(p_dm, 0x88c, BIT(21)|BIT(20), 0x3);
-		else {
-			odm_set_bb_reg(p_dm, 0xc00, BIT(1)|BIT(0), 0x0);
-			if (p_dm->rf_type > RF_1T1R)
-				odm_set_bb_reg(p_dm, 0xe00, BIT(1)|BIT(0), 0x0);
-		}
-		odm_set_bb_reg(p_dm, 0xa78, MASKBYTE1, 0x0); /*disable CCK DCNF*/
-	
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("DC cancellation Begin!!!"));
-	
-		phydm_stop_ck320(p_dm, true);	/*stop ck320*/
+
+		/*@disable CCK DCNF*/
+		odm_set_bb_reg(dm, R_0xa78, MASKBYTE1, 0x0);
+
+		PHYDM_DBG(dm, ODM_COMP_API, "DC cancellation Begin!!!\n");
+
+		phydm_stop_ck320(dm, true); /*stop ck320*/
 
 		/* the same debug port both for path-a and path-b*/
-		reg_value32[path] = phydm_get_bb_dbg_port_value(p_dm);
+		reg_value32[path] = phydm_get_bb_dbg_port_val(dm);
 
-		phydm_stop_ck320(p_dm, false);	/*start ck320*/
+		phydm_stop_ck320(dm, false); /*start ck320*/
 
-		if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-			odm_set_bb_reg(p_dm, 0x88c, BIT(21)|BIT(20), 0x0);
-		} else {
-			odm_set_bb_reg(p_dm, 0xc00, BIT(1)|BIT(0), 0x3);
-			odm_set_bb_reg(p_dm, 0xe00, BIT(1)|BIT(0), 0x3);
-		}
-		odm_write_dig(p_dm, 0x20);
-		phydm_release_bb_dbg_port(p_dm);
+		phydm_release_bb_dbg_port(dm);
+		/* @Turn on 3-wire*/
+		phydm_stop_3_wire(dm, PHYDM_REVERT);
+		/* @Enable LNA*/
+		if (dm->support_ic_type & ODM_RTL8821C)
+			halrf_rf_lna_setting(dm, HALRF_LNA_ENABLE);
+
+		odm_write_dig(dm, 0x20);
 
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("DC cancellation OK!!!"));
+		set_result = phydm_stop_ic_trx(dm, PHYDM_REVERT);
+
+		PHYDM_DBG(dm, ODM_COMP_API, "DC cancellation OK!!!\n");
 	}
-		
-	/*DC_Cancellation*/
-	odm_set_bb_reg(p_dm, 0xa9c, BIT(20), 0x1); /*DC compensation to CCK data path*/
-	if (p_dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
+
+	/*@DC_Cancellation*/
+	/*@DC compensation to CCK data path*/
+	odm_set_bb_reg(dm, R_0xa9c, BIT(20), 0x1);
+	if (dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8710B)) {
 		offset_i_hex[0] = (reg_value32[0] & 0xffc0000) >> 18;
 		offset_q_hex[0] = (reg_value32[0] & 0x3ff00) >> 8;
 
-		/*Before filling into registers, offset should be multiplexed (-1)*/
-		offset_i_hex[0] = (offset_i_hex[0] >= 0x200) ? (0x400 - offset_i_hex[1]) : (0x1ff - offset_i_hex[1]);
-		offset_q_hex[0] = (offset_q_hex[0] >= 0x200) ? (0x400 - offset_q_hex[1]) : (0x1ff - offset_q_hex[1]);
-
-		odm_set_bb_reg(p_dm, 0x950, 0x1ff, offset_i_hex[1]);
-		odm_set_bb_reg(p_dm, 0x950, 0x1ff0000, offset_q_hex[1]);
-	} else if (p_dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B)) {
-	
+		/*@Before filling into registers,
+		 *offset should be multiplexed (-1)
+		 */
+		offset_i_hex[0] = (offset_i_hex[0] >= 0x200) ?
+				  (0x400 - offset_i_hex[0]) :
+				  (0x1ff - offset_i_hex[0]);
+		offset_q_hex[0] = (offset_q_hex[0] >= 0x200) ?
+				  (0x400 - offset_q_hex[0]) :
+				  (0x1ff - offset_q_hex[0]);
+
+		odm_set_bb_reg(dm, R_0x950, 0x1ff, offset_i_hex[0]);
+		odm_set_bb_reg(dm, R_0x950, 0x1ff0000, offset_q_hex[0]);
+	} else if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B)) {
 		/* Path-a */
 		offset_i_hex[0] = (reg_value32[0] & 0xffc00) >> 10;
 		offset_q_hex[0] = reg_value32[0] & 0x3ff;
 
-		/*Before filling into registers, offset should be multiplexed (-1)*/
+		/*@Before filling into registers,
+		 *offset should be multiplexed (-1)
+		 */
 		offset_i_hex[0] = 0x400 - offset_i_hex[0];
 		offset_q_hex[0] = 0x400 - offset_q_hex[0];
 
-		odm_set_bb_reg(p_dm, 0xc10, 0x3c000000, ((0x3c0 & offset_i_hex[0]) >> 6));
-		odm_set_bb_reg(p_dm, 0xc10, 0xfc00, (0x3f & offset_i_hex[0]));
-		odm_set_bb_reg(p_dm, 0xc14, 0x3c000000, ((0x3c0 & offset_q_hex[0]) >> 6));
-		odm_set_bb_reg(p_dm, 0xc14, 0xfc00, (0x3f & offset_q_hex[0]));
+		odm_set_bb_reg(dm, R_0xc10, 0x3c000000,
+			       (0x3c0 & offset_i_hex[0]) >> 6);
+		odm_set_bb_reg(dm, R_0xc10, 0xfc00, 0x3f & offset_i_hex[0]);
+		odm_set_bb_reg(dm, R_0xc14, 0x3c000000,
+			       (0x3c0 & offset_q_hex[0]) >> 6);
+		odm_set_bb_reg(dm, R_0xc14, 0xfc00, 0x3f & offset_q_hex[0]);
 
 		/* Path-b */
-		if (p_dm->rf_type > RF_1T1R) {
-			
+		if (dm->rf_type > RF_1T1R) {
 			offset_i_hex[1] = (reg_value32[1] & 0xffc00) >> 10;
 			offset_q_hex[1] = reg_value32[1] & 0x3ff;
 
-		/*Before filling into registers, offset should be multiplexed (-1)*/
+			/*@Before filling into registers,
+			 *offset should be multiplexed (-1)
+			 */
 			offset_i_hex[1] = 0x400 - offset_i_hex[1];
 			offset_q_hex[1] = 0x400 - offset_q_hex[1];
 
-			odm_set_bb_reg(p_dm, 0xe10, 0x3c000000, ((0x3c0 & offset_i_hex[1]) >> 6));
-			odm_set_bb_reg(p_dm, 0xe10, 0xfc00, (0x3f & offset_i_hex[1]));
-			odm_set_bb_reg(p_dm, 0xe14, 0x3c000000, ((0x3c0 & offset_q_hex[1]) >> 6));
-			odm_set_bb_reg(p_dm, 0xe14, 0xfc00, (0x3f & offset_q_hex[1]));
+			odm_set_bb_reg(dm, R_0xe10, 0x3c000000,
+				       (0x3c0 & offset_i_hex[1]) >> 6);
+			odm_set_bb_reg(dm, R_0xe10, 0xfc00,
+				       0x3f & offset_i_hex[1]);
+			odm_set_bb_reg(dm, R_0xe14, 0x3c000000,
+				       (0x3c0 & offset_q_hex[1]) >> 6);
+			odm_set_bb_reg(dm, R_0xe14, 0xfc00,
+				       0x3f & offset_q_hex[1]);
+		}
+	} else if (dm->support_ic_type & (ODM_RTL8192F)) {
+		/* Path-a I:df4[27:18],Q:df4[17:8]*/
+		offset_i_hex[0] = (reg_value32[0] & 0xffc0000) >> 18;
+		offset_q_hex[0] = (reg_value32[0] & 0x3ff00) >> 8;
+
+		/*@Before filling into registers,
+		 *offset should be multiplexed (-1)
+		 */
+		offset_i_hex[0] = (offset_i_hex[0] >= 0x200) ?
+				  (0x400 - offset_i_hex[0]) :
+				  (0xff - offset_i_hex[0]);
+		offset_q_hex[0] = (offset_q_hex[0] >= 0x200) ?
+				  (0x400 - offset_q_hex[0]) :
+				  (0xff - offset_q_hex[0]);
+		/*Path-a I:c10[7:0],Q:c10[15:8]*/
+		odm_set_bb_reg(dm, R_0xc10, 0xff, offset_i_hex[0]);
+		odm_set_bb_reg(dm, R_0xc10, 0xff00, offset_q_hex[0]);
+
+		/* Path-b */
+		if (dm->rf_type > RF_1T1R) {
+			/* @I:df4[27:18],Q:df4[17:8]*/
+			offset_i_hex[1] = (reg_value32[1] & 0xffc0000) >> 18;
+			offset_q_hex[1] = (reg_value32[1] & 0x3ff00) >> 8;
+
+			/*@Before filling into registers,
+			 *offset should be multiplexed (-1)
+			 */
+			offset_i_hex[1] = (offset_i_hex[1] >= 0x200) ?
+					  (0x400 - offset_i_hex[1]) :
+					  (0xff - offset_i_hex[1]);
+			offset_q_hex[1] = (offset_q_hex[1] >= 0x200) ?
+					  (0x400 - offset_q_hex[1]) :
+					  (0xff - offset_q_hex[1]);
+			/*Path-b I:c18[7:0],Q:c18[15:8]*/
+			odm_set_bb_reg(dm, R_0xc18, 0xff, offset_i_hex[1]);
+			odm_set_bb_reg(dm, R_0xc18, 0xff00, offset_q_hex[1]);
 		}
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+	 /*judy modified 20180517*/
+		offset_i_hex[0] = (reg_value32[0] & 0xff800) >> 11;
+		offset_q_hex[0] = (reg_value32[0] & 0x3fe) >> 1;
+
+		/*@Before filling into registers,
+		 *offset should be multiplexed (-1)
+		 */
+		offset_i_hex[0] = 0x200 - offset_i_hex[0];
+		offset_q_hex[0] = 0x200 - offset_q_hex[0];
+
+		odm_set_bb_reg(dm, R_0x950, 0x1ff, offset_i_hex[0]);
+		odm_set_bb_reg(dm, R_0x950, 0x1ff0000, offset_q_hex[0]);
 	}
 #endif
 }
 
-void
-phydm_receiver_blocking(
-	void *p_dm_void
-)
+void phydm_receiver_blocking(void *dm_void)
 {
 #ifdef CONFIG_RECEIVER_BLOCKING
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	channel = *p_dm->p_channel;
-	u8	bw = *p_dm->p_band_width;
-	u32	bb_regf0 = odm_get_bb_reg(p_dm, 0xf0, MASKDWORD);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 chnl = *dm->channel;
+	u8 bw = *dm->band_width;
+	u32 bb_regf0 = odm_get_bb_reg(dm, R_0xf0, 0xf000);
 
-	if (!(p_dm->support_ic_type & ODM_RECEIVER_BLOCKING_SUPPORT))
+	if (!(dm->support_ic_type & ODM_RECEIVER_BLOCKING_SUPPORT) ||
+	    !(dm->support_ability & ODM_BB_ADAPTIVITY))
 		return;
 
-	if ((p_dm->support_ic_type & ODM_RTL8188E && ((bb_regf0 & 0xf000) >> 12) < 8) ||
-		p_dm->support_ic_type & ODM_RTL8192E) { /*8188E_T version*/
-		if (p_dm->consecutive_idlel_time > 10 && *p_dm->p_mp_mode == false && p_dm->adaptivity_enable == true) {
-			if ((bw == CHANNEL_WIDTH_20) && (channel == 1)) {
-				phydm_nbi_setting(p_dm, FUNC_ENABLE, channel, 20, 2410, PHYDM_DONT_CARE);
-				p_dm->is_receiver_blocking_en = true;
-			} else if ((bw == CHANNEL_WIDTH_20) && (channel == 13)) {
-				phydm_nbi_setting(p_dm, FUNC_ENABLE, channel, 20, 2473, PHYDM_DONT_CARE);
-				p_dm->is_receiver_blocking_en = true;
-			} else if (p_dm->is_receiver_blocking_en && channel != 1 && channel != 13) {
-				phydm_nbi_enable(p_dm, FUNC_DISABLE);
-				odm_set_bb_reg(p_dm, 0xc40, 0x1f000000, 0x1f);
-				p_dm->is_receiver_blocking_en = false;
-			}
-			return;
+	if ((dm->support_ic_type & ODM_RTL8188E && bb_regf0 < 8) ||
+	    dm->support_ic_type & ODM_RTL8192E) {
+	    /*@8188E_T version*/
+		if (dm->consecutive_idlel_time <= 10 || *dm->mp_mode)
+			goto end;
+
+		if (bw == CHANNEL_WIDTH_20 && chnl == 1) {
+			phydm_nbi_setting(dm, FUNC_ENABLE, chnl, 20, 2410,
+					  PHYDM_DONT_CARE);
+			dm->is_rx_blocking_en = true;
+		} else if ((bw == CHANNEL_WIDTH_20) && (chnl == 13)) {
+			phydm_nbi_setting(dm, FUNC_ENABLE, chnl, 20, 2473,
+					  PHYDM_DONT_CARE);
+			dm->is_rx_blocking_en = true;
+		} else if (dm->is_rx_blocking_en && chnl != 1 && chnl != 13) {
+			phydm_nbi_enable(dm, FUNC_DISABLE);
+			odm_set_bb_reg(dm, R_0xc40, 0x1f000000, 0x1f);
+			dm->is_rx_blocking_en = false;
 		}
-	} else if ((p_dm->support_ic_type & ODM_RTL8188E && ((bb_regf0 & 0xf000) >> 12) >= 8)) { /*8188E_S version*/
-		if (p_dm->consecutive_idlel_time > 10 && *p_dm->p_mp_mode == false && p_dm->adaptivity_enable == true) {
-			if ((bw == CHANNEL_WIDTH_20) && (channel == 13)) {
-				phydm_nbi_setting(p_dm, FUNC_ENABLE, channel, 20, 2473, PHYDM_DONT_CARE);
-				p_dm->is_receiver_blocking_en = true;
-			} else if (p_dm->is_receiver_blocking_en && channel != 13) {
-				phydm_nbi_enable(p_dm, FUNC_DISABLE);
-				odm_set_bb_reg(p_dm, 0xc40, 0x1f000000, 0x1f);
-				p_dm->is_receiver_blocking_en = false;
-			}
-			return;
+		return;
+	} else if ((dm->support_ic_type & ODM_RTL8188E && bb_regf0 >= 8)) {
+	/*@8188E_S version*/
+		if (dm->consecutive_idlel_time <= 10 || *dm->mp_mode)
+			goto end;
+
+		if (bw == CHANNEL_WIDTH_20 && chnl == 13) {
+			phydm_nbi_setting(dm, FUNC_ENABLE, chnl, 20, 2473,
+					  PHYDM_DONT_CARE);
+			dm->is_rx_blocking_en = true;
+		} else if (dm->is_rx_blocking_en && chnl != 13) {
+			phydm_nbi_enable(dm, FUNC_DISABLE);
+			odm_set_bb_reg(dm, R_0xc40, 0x1f000000, 0x1f);
+			dm->is_rx_blocking_en = false;
 		}
+		return;
 	}
 
-	if (p_dm->is_receiver_blocking_en) {
-		phydm_nbi_enable(p_dm, FUNC_DISABLE);
-		odm_set_bb_reg(p_dm, 0xc40, 0x1f000000, 0x1f);
-		p_dm->is_receiver_blocking_en = false;
+end:
+	if (dm->is_rx_blocking_en) {
+		phydm_nbi_enable(dm, FUNC_DISABLE);
+		odm_set_bb_reg(dm, R_0xc40, 0x1f000000, 0x1f);
+		dm->is_rx_blocking_en = false;
 	}
-
 #endif
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.h
index e7abfb326310..6d9c23608fe9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,51 +9,93 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-
-#ifndef	__HALDMOUTSRC_H__
+#ifndef __HALDMOUTSRC_H__
 #define __HALDMOUTSRC_H__
 
-/*============================================================*/
-/*include files*/
-/*============================================================*/
+/*@============================================================*/
+/*@include files*/
+/*@============================================================*/
 /*PHYDM header*/
 #include "phydm_pre_define.h"
+#include "phydm_features.h"
 #include "phydm_dig.h"
+#ifdef CONFIG_PATH_DIVERSITY
 #include "phydm_pathdiv.h"
+#endif
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
 #include "phydm_antdiv.h"
+#endif
+
 #include "phydm_soml.h"
+
+#ifdef CONFIG_SMART_ANTENNA
 #include "phydm_smt_ant.h"
+#endif
+#ifdef CONFIG_ANT_DETECTION
 #include "phydm_antdect.h"
+#endif
 #include "phydm_rainfo.h"
+#ifdef CONFIG_DYNAMIC_TX_TWR
 #include "phydm_dynamictxpower.h"
+#endif
 #include "phydm_cfotracking.h"
-#include "phydm_acs.h"
 #include "phydm_adaptivity.h"
 #include "phydm_dfs.h"
 #include "phydm_ccx.h"
 #include "txbf/phydm_hal_txbf_api.h"
+#if (PHYDM_LA_MODE_SUPPORT == 1)
 #include "phydm_adc_sampling.h"
-#include "phydm_dynamic_rx_path.h"
+#endif
+#ifdef CONFIG_PSD_TOOL
 #include "phydm_psd.h"
+#endif
+#ifdef PHYDM_PRIMARY_CCA
 #include "phydm_primary_cca.h"
+#endif
 #include "phydm_cck_pd.h"
 #include "phydm_rssi_monitor.h"
+#ifdef PHYDM_AUTO_DEGBUG
 #include "phydm_auto_dbg.h"
+#endif
 #include "phydm_math_lib.h"
 #include "phydm_noisemonitor.h"
 #include "phydm_api.h"
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
 #include "phydm_pow_train.h"
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
+#endif
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+#include "phydm_lna_sat.h"
+#endif
+#ifdef PHYDM_PMAC_TX_SETTING_SUPPORT
+#include "phydm_pmac_tx_setting.h"
+#endif
+#ifdef PHYDM_MP_SUPPORT
+#include "phydm_mp.h"
+#endif
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
 	#include "phydm_beamforming.h"
 #endif
 
-/*HALRF header*/
+#include "phydm_regtable.h"
+
+/*@HALRF header*/
 #include "halrf/halrf_iqk.h"
+#include "halrf/halrf_dpk.h"
 #include "halrf/halrf.h"
 #include "halrf/halrf_powertracking.h"
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
@@ -61,24 +104,88 @@
 	#include "halrf/halphyrf_ce.h"
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
 	#include "halrf/halphyrf_win.h"
+#elif(DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+	#include "halrf/halphyrf_iot.h"
 #endif
 
-extern const u16 phy_rate_table[28];
+extern const u16	phy_rate_table[28];
 
-/*============================================================*/
-/*Definition */
-/*============================================================*/
+/*@============================================================*/
+/*@Definition */
+/*@============================================================*/
 
 /* Traffic load decision */
-#define	TRAFFIC_ULTRA_LOW	1
+#define TRAFFIC_NO_TP			0
+#define	TRAFFIC_ULTRA_LOW		1
 #define	TRAFFIC_LOW			2
 #define	TRAFFIC_MID			3
 #define	TRAFFIC_HIGH			4
 
-#define	NONE			0
+#define	NONE				0
+
+#if defined(DM_ODM_CE_MAC80211)
+#define MAX_2(x, y)					\
+	__max2(typeof(x), typeof(y),			\
+	      x, y)
+#define __max2(t1, t2, x, y) ({		\
+	t1 m80211_max1 = (x);					\
+	t2 m80211_max2 = (y);					\
+	m80211_max1 > m80211_max2 ? m80211_max1 : m80211_max2; })
+
+#define MIN_2(x, y)					\
+	__min2(typeof(x), typeof(y),			\
+	      x, y)
+#define __min2(t1, t2, x, y) ({		\
+	t1 m80211_min1 = (x);					\
+	t2 m80211_min2 = (y);					\
+	m80211_min1 < m80211_min2 ? m80211_min1 : m80211_min2; })
+
+#define DIFF_2(x, y)					\
+	__diff2(typeof(x), typeof(y),			\
+	      x, y)
+#define __diff2(t1, t2, x, y) ({		\
+	t1 __d1 = (x);					\
+	t2 __d2 = (y);					\
+	(__d1 >= __d2) ? (__d1 - __d2) : (__d2 - __d1); })
+#else
+#define MAX_2(_x_, _y_)	(((_x_) > (_y_)) ? (_x_) : (_y_))
+#define MIN_2(_x_, _y_)	(((_x_) < (_y_)) ? (_x_) : (_y_))
+#define DIFF_2(_x_, _y_)	((_x_ >= _y_) ? (_x_ - _y_) : (_y_ - _x_))
+#endif
+
+#define IS_GREATER(_x_, _y_)	(((_x_) >= (_y_)) ? true : false)
+#define IS_LESS(_x_, _y_)	(((_x_) < (_y_)) ? true : false)
 
-#define MAX_2(_x_, _y_)	(((_x_)>(_y_))? (_x_) : (_y_))
-#define MIN_2(_x_, _y_)	(((_x_)<(_y_))? (_x_) : (_y_))
+#if defined(DM_ODM_CE_MAC80211)
+#define BYTE_DUPLICATE_2_DWORD(B0) ({	\
+	u32 __b_dup = (B0);\
+	(((__b_dup) << 24) | ((__b_dup) << 16) | ((__b_dup) << 8) | (__b_dup));\
+	})
+#else
+#define BYTE_DUPLICATE_2_DWORD(B0)	\
+	(((B0) << 24) | ((B0) << 16) | ((B0) << 8) | (B0))
+#endif
+#define BYTE_2_DWORD(B3, B2, B1, B0)	\
+	(((B3) << 24) | ((B2) << 16) | ((B1) << 8) | (B0))
+#define BIT_2_BYTE(B3, B2, B1, B0)	\
+	(((B3) << 3) | ((B2) << 2) | ((B1) << 1) | (B0))
+
+/*@For cmn sta info*/
+#if defined(DM_ODM_CE_MAC80211)
+#define is_sta_active(sta) ({	\
+	struct cmn_sta_info *__sta = (sta);	\
+	((__sta) && (__sta->dm_ctrl & STA_DM_CTRL_ACTIVE));	\
+	})
+
+#define IS_FUNC_EN(name) ({	\
+	u8 *__is_func_name = (name);	\
+	(__is_func_name) && (*__is_func_name);	\
+	})
+#else
+#define is_sta_active(sta)	((sta) && (sta->dm_ctrl & STA_DM_CTRL_ACTIVE))
+
+#define IS_FUNC_EN(name)	((name) && (*name))
+#endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 	#define PHYDM_WATCH_DOG_PERIOD	1 /*second*/
@@ -86,116 +193,168 @@ extern const u16 phy_rate_table[28];
 	#define PHYDM_WATCH_DOG_PERIOD	2 /*second*/
 #endif
 
-/*============================================================*/
+#define PHY_HIST_SIZE		12
+
+/*@============================================================*/
 /*structure and define*/
-/*============================================================*/
+/*@============================================================*/
+
+#define		dm_type_by_fw		0
+#define		dm_type_by_driver	1
+
+#ifdef BB_RAM_SUPPORT
+
+struct phydm_bb_ram_per_sta {
+	/* @Reg0x1E84 for RAM I/O*/
+	boolean			hw_igi_en;
+	boolean			tx_pwr_offset0_en;
+	boolean			tx_pwr_offset1_en;
+	/* @ macid from 0 to 63, above 63 => mapping to 63*/
+	u8			macid_addr;
+	/* @hw_igi value for paths after packet Tx in a period of time*/
+	u8			hw_igi;
+	/* @tx_pwr_offset0 offset for Tx power index*/
+	s8			tx_pwr_offset0;
+	s8			tx_pwr_offset1;
+
+};
 
-#define		dm_type_by_fw			0
-#define		dm_type_by_driver		1
+struct phydm_bb_ram_ctrl {
+	/*@ For 98F/14B/22C/12F, each TxAGC step will be 0.25dB*/
+	struct phydm_bb_ram_per_sta pram_sta_ctrl[ODM_ASSOCIATE_ENTRY_NUM];
+	/*------------ For table2 do not set power offset by macid --------*/
+	/* For type == 2'b10, 0x1e70[22:16] = tx_pwr_offset_reg0, 0x1e70[23] = enable */
+	boolean			tx_pwr_offset_reg0_en;
+	u8			tx_pwr_offset_reg0;
+	/* For type == 2'b11, 0x1e70[30:24] = tx_pwr_offset_reg1, 0x1e70[31] = enable */
+	boolean			tx_pwr_offset_reg1_en;
+	u8			tx_pwr_offset_reg1;
+};
+
+#endif
 
 struct phydm_phystatus_statistic {
-	
-	/*[CCK]*/
-	u32		rssi_cck_sum;
-	u32		rssi_cck_cnt;
-	/*[OFDM]*/	
-	u32		rssi_ofdm_sum;
-	u32		rssi_ofdm_cnt;
-	u32		evm_ofdm_sum;
-	u32		snr_ofdm_sum;
-	/*[1SS]*/
-	u32		rssi_1ss_cnt;
-	u32		rssi_1ss_sum;
-	u32		evm_1ss_sum;
-	u32		snr_1ss_sum;
-	/*[2SS]*/
+	/*@[CCK]*/
+	u32			rssi_cck_sum;
+	u32			rssi_cck_cnt;
+	/*@[OFDM]*/
+	u32			rssi_ofdm_sum;
+	u32			rssi_ofdm_cnt;
+	u32			evm_ofdm_sum;
+	u32			snr_ofdm_sum;
+	u16			evm_ofdm_hist[PHY_HIST_SIZE];
+	u16			snr_ofdm_hist[PHY_HIST_SIZE];
+	/*@[1SS]*/
+	u32			rssi_1ss_cnt;
+	u32			rssi_1ss_sum;
+	u32			evm_1ss_sum;
+	u32			snr_1ss_sum;
+	u16			evm_1ss_hist[PHY_HIST_SIZE];
+	u16			snr_1ss_hist[PHY_HIST_SIZE];
+	/*@[2SS]*/
 	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
-	u32		rssi_2ss_cnt;
-	u32		rssi_2ss_sum[2];
-	u32		evm_2ss_sum[2];
-	u32		snr_2ss_sum[2];
+	u32			rssi_2ss_cnt;
+	u32			rssi_2ss_sum[2];
+	u32			evm_2ss_sum[2];
+	u32			snr_2ss_sum[2];
+	u16			evm_2ss_hist[2][PHY_HIST_SIZE];
+	u16			snr_2ss_hist[2][PHY_HIST_SIZE];
 	#endif
-	/*[3SS]*/
+	/*@[3SS]*/
 	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
-	u32		rssi_3ss_cnt;
-	u32		rssi_3ss_sum[3];
-	u32		evm_3ss_sum[3];
-	u32		snr_3ss_sum[3];
+	u32			rssi_3ss_cnt;
+	u32			rssi_3ss_sum[3];
+	u32			evm_3ss_sum[3];
+	u32			snr_3ss_sum[3];
+	u16			evm_3ss_hist[3][PHY_HIST_SIZE];
+	u16			snr_3ss_hist[3][PHY_HIST_SIZE];
 	#endif
-	/*[4SS]*/
+	/*@[4SS]*/
 	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
-	u32		rssi_4ss_cnt;
-	u32		rssi_4ss_sum[4];
-	u32		evm_4ss_sum[4];	
-	u32		snr_4ss_sum[4];
+	u32			rssi_4ss_cnt;
+	u32			rssi_4ss_sum[4];
+	u32			evm_4ss_sum[4];
+	u32			snr_4ss_sum[4];
+	u16			evm_4ss_hist[4][PHY_HIST_SIZE];
+	u16			snr_4ss_hist[4][PHY_HIST_SIZE];
 	#endif
 };
 
 struct phydm_phystatus_avg {
-	
-	/*[CCK]*/
-	u8		rssi_cck_avg;
-	/*[OFDM]*/
-	u8		rssi_ofdm_avg;
-	u8		evm_ofdm_avg;
-	u8		snr_ofdm_avg;
-	/*[1SS]*/
-	u8		rssi_1ss_avg;
-	u8		evm_1ss_avg;
-	u8		snr_1ss_avg;
-	/*[2SS]*/
+	/*@[CCK]*/
+	u8			rssi_cck_avg;
+	/*@[OFDM]*/
+	u8			rssi_ofdm_avg;
+	u8			evm_ofdm_avg;
+	u8			snr_ofdm_avg;
+	/*@[1SS]*/
+	u8			rssi_1ss_avg;
+	u8			evm_1ss_avg;
+	u8			snr_1ss_avg;
+	/*@[2SS]*/
 	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
-	u8		rssi_2ss_avg[2];
-	u8		evm_2ss_avg[2];
-	u8		snr_2ss_avg[2];
+	u8			rssi_2ss_avg[2];
+	u8			evm_2ss_avg[2];
+	u8			snr_2ss_avg[2];
 	#endif
-	/*[3SS]*/
+	/*@[3SS]*/
 	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
-	u8		rssi_3ss_avg[3];
-	u8		evm_3ss_avg[3];
-	u8		snr_3ss_avg[3];
+	u8			rssi_3ss_avg[3];
+	u8			evm_3ss_avg[3];
+	u8			snr_3ss_avg[3];
 	#endif
-	/*[4SS]*/
+	/*@[4SS]*/
 	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
-	u8		rssi_4ss_avg[4];
-	u8		evm_4ss_avg[4];	
-	u8		snr_4ss_avg[4];
+	u8			rssi_4ss_avg[4];
+	u8			evm_4ss_avg[4];
+	u8			snr_4ss_avg[4];
 	#endif
 };
 
-struct _odm_phy_dbg_info_ {
-	/*ODM Write,debug info*/
-	s8		rx_snr_db[4];
-	u32		num_qry_phy_status;
-	u32		num_qry_phy_status_cck;
-	u32		num_qry_phy_status_ofdm;
-#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-	u32		num_qry_mu_pkt;
-	u32		num_qry_bf_pkt;
-	u32		num_qry_mu_vht_pkt[40];
-	boolean	is_ldpc_pkt;
-	boolean	is_stbc_pkt;
-	u8		num_of_ppdu[4];
-	u8		gid_num[4];
+struct odm_phy_dbg_info {
+	/*@ODM Write,debug info*/
+	u32			num_qry_phy_status_cck;
+	u32			num_qry_phy_status_ofdm;
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1) || (defined(PHYSTS_3RD_TYPE_SUPPORT))
+	u32			num_qry_mu_pkt;
+	u32			num_qry_bf_pkt;
+	u16			num_mu_vht_pkt[VHT_RATE_NUM];
+	boolean			is_ldpc_pkt;
+	boolean			is_stbc_pkt;
+	u8			num_of_ppdu[4];
+	u8			gid_num[4];
 #endif
-	u8		num_qry_beacon_pkt;
-	/* Others */
-	s32		rx_evm[4];
-
-	u16		num_qry_legacy_pkt[LEGACY_RATE_NUM];
-	u16		num_qry_ht_pkt[HT_RATE_NUM];
-	u8		ht_pkt_not_zero;
-	#if	ODM_IC_11AC_SERIES_SUPPORT
-	u16		num_qry_vht_pkt[VHT_RATE_NUM];
-	u8		vht_pkt_not_zero;
+	u32			condi_num; /*@condition number U(18,4)*/
+	u8			condi_num_cdf[CN_CNT_MAX];
+	u8			num_qry_beacon_pkt;
+	u8			beacon_cnt_in_period; /*@beacon cnt within watchdog period*/
+	u8			beacon_phy_rate;
+	u8			show_phy_sts_all_pkt;	/*@Show phy status witch not match BSSID*/
+	u16			show_phy_sts_max_cnt;	/*@show number of phy-status row data per PHYDM watchdog*/
+	u16			show_phy_sts_cnt;
+	u16			num_qry_legacy_pkt[LEGACY_RATE_NUM];
+	u16			num_qry_ht_pkt[HT_RATE_NUM];
+	u16			num_qry_pkt_sc_20m[LOW_BW_RATE_NUM]; /*@20M SC*/
+	boolean			ht_pkt_not_zero;
+	boolean			low_bw_20_occur;
+	#if ODM_IC_11AC_SERIES_SUPPORT || defined(PHYDM_IC_JGR3_SERIES_SUPPORT)
+	u16			num_qry_vht_pkt[VHT_RATE_NUM];
+	u16			num_qry_pkt_sc_40m[LOW_BW_RATE_NUM]; /*@40M SC*/
+	boolean			vht_pkt_not_zero;
+	boolean			low_bw_40_occur;
+	#endif
+	u16			snr_hist_th[PHY_HIST_SIZE - 1];
+	u16			evm_hist_th[PHY_HIST_SIZE - 1];
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	s16 cfo_tail[4]; /* per-path's cfo_tail */
 	#endif
-	struct phydm_phystatus_statistic	phystatus_statistic_info;
+	struct phydm_phystatus_statistic	physts_statistic_info;
 	struct phydm_phystatus_avg	phystatus_statistic_avg;
 };
 
-enum odm_cmninfo_e {
-	/*Fixed value*/
-	/*-----------HOOK BEFORE REG INIT-----------*/
+enum odm_cmninfo {
+	/*@Fixed value*/
+	/*@-----------HOOK BEFORE REG INIT-----------*/
 	ODM_CMNINFO_PLATFORM = 0,
 	ODM_CMNINFO_ABILITY,
 	ODM_CMNINFO_INTERFACE,
@@ -203,6 +362,8 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_IC_TYPE,
 	ODM_CMNINFO_CUT_VER,
 	ODM_CMNINFO_FAB_VER,
+	ODM_CMNINFO_FW_VER,
+	ODM_CMNINFO_FW_SUB_VER,
 	ODM_CMNINFO_RF_TYPE,
 	ODM_CMNINFO_RFE_TYPE,
 	ODM_CMNINFO_DPK_EN,
@@ -216,6 +377,7 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_APA,
 	ODM_CMNINFO_GLNA,
 	ODM_CMNINFO_ALNA,
+	ODM_CMNINFO_TDMA,
 	ODM_CMNINFO_EXT_TRSW,
 	ODM_CMNINFO_EXT_LNA_GAIN,
 	ODM_CMNINFO_PATCH_ID,
@@ -223,8 +385,6 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_BWIFI_TEST,
 	ODM_CMNINFO_SMART_CONCURRENT,
 	ODM_CMNINFO_CONFIG_BB_RF,
-	ODM_CMNINFO_DOMAIN_CODE_2G,
-	ODM_CMNINFO_DOMAIN_CODE_5G,
 	ODM_CMNINFO_IQKPAOFF,
 	ODM_CMNINFO_HUBUSBMODE,
 	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS,
@@ -237,13 +397,14 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_EFUSE0X3D8,
 	ODM_CMNINFO_EFUSE0X3D7,
 	ODM_CMNINFO_SOFT_AP_SPECIAL_SETTING,
+	ODM_CMNINFO_X_CAP_SETTING,
 	ODM_CMNINFO_ADVANCE_OTA,
 	ODM_CMNINFO_HP_HWID,
-	/*-----------HOOK BEFORE REG INIT-----------*/
+	/*@-----------HOOK BEFORE REG INIT-----------*/
 
-	/*Dynamic value:*/
+	/*@Dynamic value:*/
 
-	/*--------- POINTER REFERENCE-----------*/
+	/*@--------- POINTER REFERENCE-----------*/
 	ODM_CMNINFO_TX_UNI,
 	ODM_CMNINFO_RX_UNI,
 	ODM_CMNINFO_BAND,
@@ -253,6 +414,8 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_CHNL,
 	ODM_CMNINFO_FORCED_RATE,
 	ODM_CMNINFO_ANT_DIV,
+	ODM_CMNINFO_PATH_DIV,
+	ODM_CMNINFO_ADAPTIVE_SOML,
 	ODM_CMNINFO_ADAPTIVITY,
 	ODM_CMNINFO_SCAN,
 	ODM_CMNINFO_POWER_SAVING,
@@ -274,9 +437,9 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_INTERRUPT_MASK,
 	ODM_CMNINFO_BB_OPERATION_MODE,
 	ODM_CMNINFO_BF_ANTDIV_DECISION,
-	/*--------- POINTER REFERENCE-----------*/
+	/*@--------- POINTER REFERENCE-----------*/
 
-	/*------------CALL BY VALUE-------------*/
+	/*@------------CALL BY VALUE-------------*/
 	ODM_CMNINFO_WIFI_DIRECT,
 	ODM_CMNINFO_WIFI_DISPLAY,
 	ODM_CMNINFO_LINK_IN_PROGRESS,
@@ -286,7 +449,6 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_RSSI_MIN,
 	ODM_CMNINFO_RSSI_MIN_BY_PATH,
 	ODM_CMNINFO_DBG_COMP,
-	ODM_CMNINFO_DBG_LEVEL,
 	ODM_CMNINFO_RA_THRESHOLD_HIGH,	/*to be removed*/
 	ODM_CMNINFO_RA_THRESHOLD_LOW,	/*to be removed*/
 	ODM_CMNINFO_RF_ANTENNA_TYPE,
@@ -301,34 +463,34 @@ enum odm_cmninfo_e {
 	ODM_CMNINFO_POWER_TRAINING,
 	ODM_CMNINFO_DFS_REGION_DOMAIN,
 	ODM_CMNINFO_BT_CONTINUOUS_TURN,
-	/*------------CALL BY VALUE-------------*/
+	/*@------------CALL BY VALUE-------------*/
 
-	/*Dynamic ptr array hook itms.*/
+	/*@Dynamic ptr array hook itms.*/
 	ODM_CMNINFO_STA_STATUS,
 	ODM_CMNINFO_MAX,
 
 };
 
 enum phydm_rfe_bb_source_sel {
-	PAPE_2G	= 0,
-	PAPE_5G	= 1,
-	LNA0N_2G	= 2,
-	LNAON_5G	= 3,
-	TRSW		= 4,
-	TRSW_B		= 5,
-	GNT_BT		= 6,
-	ZERO		= 7,
-	ANTSEL_0	= 8,
-	ANTSEL_1	= 9,
-	ANTSEL_2	= 0xa,
-	ANTSEL_3	= 0xb,
-	ANTSEL_4	= 0xc,
-	ANTSEL_5	= 0xd,
-	ANTSEL_6	= 0xe,
-	ANTSEL_7	= 0xf
+	PAPE_2G			= 0,
+	PAPE_5G			= 1,
+	LNA0N_2G		= 2,
+	LNAON_5G		= 3,
+	TRSW			= 4,
+	TRSW_B			= 5,
+	GNT_BT			= 6,
+	ZERO			= 7,
+	ANTSEL_0		= 8,
+	ANTSEL_1		= 9,
+	ANTSEL_2		= 0xa,
+	ANTSEL_3		= 0xb,
+	ANTSEL_4		= 0xc,
+	ANTSEL_5		= 0xd,
+	ANTSEL_6		= 0xe,
+	ANTSEL_7		= 0xf
 };
 
-enum phydm_info_query_e {
+enum phydm_info_query {
 	PHYDM_INFO_FA_OFDM,
 	PHYDM_INFO_FA_CCK,
 	PHYDM_INFO_FA_TOTAL,
@@ -356,25 +518,23 @@ enum phydm_info_query_e {
 	PHYDM_INFO_NHM_RATIO,
 };
 
-enum phydm_api_e {
-
-	PHYDM_API_NBI			= 1,
-	PHYDM_API_CSI_MASK,
-
+enum phydm_api {
+	PHYDM_API_NBI		= 1,
+	PHYDM_API_CSI_MASK	= 2,
 };
 
-enum phydm_func_idx_e { /*F_XXX = PHYDM XXX function*/
+enum phydm_func_idx { /*@F_XXX = PHYDM XXX function*/
 
 	F00_DIG			= 0,
 	F01_RA_MASK		= 1,
 	F02_DYN_TXPWR		= 2,
-	F03_FA_CNT			= 3,
+	F03_FA_CNT		= 3,
 	F04_RSSI_MNTR		= 4,
-	F05_CCK_PD			= 5,
+	F05_CCK_PD		= 5,
 	F06_ANT_DIV		= 6,
 	F07_SMT_ANT		= 7,
 	F08_PWR_TRAIN		= 8,
-	F09_RA				= 9,
+	F09_RA			= 9,
 	F10_PATH_DIV		= 10,
 	F11_DFS			= 11,
 	F12_DYN_ARFR		= 12,
@@ -382,176 +542,202 @@ enum phydm_func_idx_e { /*F_XXX = PHYDM XXX function*/
 	F14_CFO_TRK		= 14,
 	F15_ENV_MNTR		= 15,
 	F16_PRI_CCA		= 16,
-	F17_ADPTV_SOML	= 17,
-	F18_LNA_SAT_CHK = 18,
-	/*BIT18*/
-	/*BIT19*/
-	F20_DYN_RX_PATH	= 20
+	F17_ADPTV_SOML		= 17,
+	F18_LNA_SAT_CHK		= 18,
 };
 
-/*=[PHYDM supportability]==========================================*/
-enum odm_ability_e {
-
-	ODM_BB_DIG				= BIT(F00_DIG),
-	ODM_BB_RA_MASK			= BIT(F01_RA_MASK),
+/*@=[PHYDM supportability]==========================================*/
+enum odm_ability {
+	ODM_BB_DIG		= BIT(F00_DIG),
+	ODM_BB_RA_MASK		= BIT(F01_RA_MASK),
 	ODM_BB_DYNAMIC_TXPWR	= BIT(F02_DYN_TXPWR),
-	ODM_BB_FA_CNT				= BIT(F03_FA_CNT),
-	ODM_BB_RSSI_MONITOR		= BIT(F04_RSSI_MNTR),
-	ODM_BB_CCK_PD				= BIT(F05_CCK_PD),
-	ODM_BB_ANT_DIV			= BIT(F06_ANT_DIV),
-	ODM_BB_SMT_ANT			= BIT(F07_SMT_ANT),
-	ODM_BB_PWR_TRAIN			= BIT(F08_PWR_TRAIN),
-	ODM_BB_RATE_ADAPTIVE		= BIT(F09_RA),
-	ODM_BB_PATH_DIV			= BIT(F10_PATH_DIV),
-	ODM_BB_DFS				= BIT(F11_DFS),
-	ODM_BB_DYNAMIC_ARFR		= BIT(F12_DYN_ARFR),
-	ODM_BB_ADAPTIVITY			= BIT(F13_ADPTVTY),
-	ODM_BB_CFO_TRACKING		= BIT(F14_CFO_TRK),
-	ODM_BB_ENV_MONITOR		= BIT(F15_ENV_MNTR),
-	ODM_BB_PRIMARY_CCA		= BIT(F16_PRI_CCA),
+	ODM_BB_FA_CNT		= BIT(F03_FA_CNT),
+	ODM_BB_RSSI_MONITOR	= BIT(F04_RSSI_MNTR),
+	ODM_BB_CCK_PD		= BIT(F05_CCK_PD),
+	ODM_BB_ANT_DIV		= BIT(F06_ANT_DIV),
+	ODM_BB_SMT_ANT		= BIT(F07_SMT_ANT),
+	ODM_BB_PWR_TRAIN	= BIT(F08_PWR_TRAIN),
+	ODM_BB_RATE_ADAPTIVE	= BIT(F09_RA),
+	ODM_BB_PATH_DIV		= BIT(F10_PATH_DIV),
+	ODM_BB_DFS		= BIT(F11_DFS),
+	ODM_BB_DYNAMIC_ARFR	= BIT(F12_DYN_ARFR),
+	ODM_BB_ADAPTIVITY	= BIT(F13_ADPTVTY),
+	ODM_BB_CFO_TRACKING	= BIT(F14_CFO_TRK),
+	ODM_BB_ENV_MONITOR	= BIT(F15_ENV_MNTR),
+	ODM_BB_PRIMARY_CCA	= BIT(F16_PRI_CCA),
 	ODM_BB_ADAPTIVE_SOML	= BIT(F17_ADPTV_SOML),
-	ODM_BB_LNA_SAT_CHK		= BIT(F18_LNA_SAT_CHK),
-	/*BIT19*/
-	ODM_BB_DYNAMIC_RX_PATH	= BIT(F20_DYN_RX_PATH)
+	ODM_BB_LNA_SAT_CHK	= BIT(F18_LNA_SAT_CHK),
 };
 
-/*=[PHYDM Debug Component]=====================================*/
+/*@=[PHYDM Debug Component]=====================================*/
 enum phydm_dbg_comp {
-	/*BB Driver Functions*/
+	/*@BB Driver Functions*/
 	DBG_DIG			= BIT(F00_DIG),
 	DBG_RA_MASK		= BIT(F01_RA_MASK),
-	DBG_DYN_TXPWR	= BIT(F02_DYN_TXPWR),
+	DBG_DYN_TXPWR		= BIT(F02_DYN_TXPWR),
 	DBG_FA_CNT		= BIT(F03_FA_CNT),
 	DBG_RSSI_MNTR		= BIT(F04_RSSI_MNTR),
-	DBG_CCKPD			= BIT(F05_CCK_PD),
+	DBG_CCKPD		= BIT(F05_CCK_PD),
 	DBG_ANT_DIV		= BIT(F06_ANT_DIV),
 	DBG_SMT_ANT		= BIT(F07_SMT_ANT),
 	DBG_PWR_TRAIN		= BIT(F08_PWR_TRAIN),
-	DBG_RA				= BIT(F09_RA),
+	DBG_RA			= BIT(F09_RA),
 	DBG_PATH_DIV		= BIT(F10_PATH_DIV),
 	DBG_DFS			= BIT(F11_DFS),
 	DBG_DYN_ARFR		= BIT(F12_DYN_ARFR),
 	DBG_ADPTVTY		= BIT(F13_ADPTVTY),
-	DBG_CFO_TRK		= BIT(F14_CFO_TRK), 
+	DBG_CFO_TRK		= BIT(F14_CFO_TRK),
 	DBG_ENV_MNTR		= BIT(F15_ENV_MNTR),
 	DBG_PRI_CCA		= BIT(F16_PRI_CCA),
-	DBG_ADPTV_SOML	= BIT(F17_ADPTV_SOML),
-	DBG_LNA_SAT_CHK = BIT(F18_LNA_SAT_CHK),
-	/*BIT19*/
-	DBG_DYN_RX_PATH	= BIT(F20_DYN_RX_PATH),
+	DBG_ADPTV_SOML		= BIT(F17_ADPTV_SOML),
+	DBG_LNA_SAT_CHK		= BIT(F18_LNA_SAT_CHK),
+	/*BIT(19)*/
 	/*Neet to re-arrange*/
+	DBG_PHY_STATUS		= BIT(20),
 	DBG_TMP			= BIT(21),
 	DBG_FW_TRACE		= BIT(22),
-	DBG_TXBF			= BIT(23),
-	DBG_COMMON_FLOW	= BIT(24),
-	ODM_COMP_TX_PWR_TRACK	= BIT(25),
-	ODM_COMP_CALIBRATION		= BIT(26),
-	ODM_COMP_MP				= BIT(27),
-	ODM_PHY_CONFIG			= BIT(28),
-	ODM_COMP_INIT				= BIT(29),
-	ODM_COMP_COMMON			= BIT(30),
-	ODM_COMP_API				= BIT(31)
+	DBG_TXBF		= BIT(23),
+	DBG_COMMON_FLOW		= BIT(24),
+	DBG_COMP_MCC		= BIT(25),
+	/*BIT(26)*/
+	DBG_DM_SUMMARY		= BIT(27),
+	ODM_PHY_CONFIG		= BIT(28),
+	ODM_COMP_INIT		= BIT(29),
+	DBG_CMN			= BIT(30),/*@common*/
+	ODM_COMP_API		= BIT(31)
 };
 
-/*=========================================================*/
+/*@=========================================================*/
 
-/*ODM_CMNINFO_ONE_PATH_CCA*/
-enum odm_cca_path_e {
+/*@ODM_CMNINFO_ONE_PATH_CCA*/
+enum odm_cca_path {
 	ODM_CCA_2R		= 0,
 	ODM_CCA_1R_A		= 1,
 	ODM_CCA_1R_B		= 2,
 };
 
 enum phy_reg_pg_type {
-	PHY_REG_PG_RELATIVE_VALUE	= 0,
-	PHY_REG_PG_EXACT_VALUE		= 1
+	PHY_REG_PG_RELATIVE_VALUE = 0,
+	PHY_REG_PG_EXACT_VALUE	= 1
 };
 
 enum phydm_offload_ability {
 	PHYDM_PHY_PARAM_OFFLOAD = BIT(0),
-	PHYDM_RF_IQK_OFFLOAD = BIT(1),
+	PHYDM_RF_IQK_OFFLOAD	= BIT(1),
 };
 
 struct phydm_pause_lv {
-	s8	lv_dig;
-	s8	lv_cckpd;
-	s8	lv_antdiv;
-	s8	lv_adapt;
+	s8			lv_dig;
+	s8			lv_cckpd;
+	s8			lv_antdiv;
+	s8			lv_adapt;
+	s8			lv_adsl;
 };
 
 struct phydm_func_poiner {
-	void	(*pause_phydm_handler)(void	 *p_dm_void, u32 *val_buf, u8 val_len);
+	void (*pause_phydm_handler)(void *dm_void, u32 *val_buf, u8 val_len);
 };
 
 struct pkt_process_info {
-	u8	phystatus_smp_mode_en; /*send phystatus every sampling time*/
-	u8	pre_ppdu_cnt;
-	u8	lna_idx;
-	u8	vga_idx;
+	u8			phystatus_smp_mode_en; /*@send phystatus every sampling time*/
+	u8			pre_ppdu_cnt;
+	u8			lna_idx;
+	u8			vga_idx;
 };
 
 #ifdef ODM_CONFIG_BT_COEXIST
 struct	phydm_bt_info {
-	boolean		is_bt_enabled;			/*BT is enabled*/
-	boolean		is_bt_connect_process;	/*BT HS is under connection progress.*/
-	u8			bt_hs_rssi;				/*BT HS mode wifi rssi value.*/
-	boolean		is_bt_hs_operation;		/*BT HS mode is under progress*/
-	boolean		is_bt_limited_dig;		/*BT is busy.*/
+	boolean			is_bt_enabled;		/*@BT is enabled*/
+	boolean			is_bt_connect_process;	/*@BT HS is under connection progress.*/
+	u8			bt_hs_rssi;		/*@BT HS mode wifi rssi value.*/
+	boolean			is_bt_hs_operation;	/*@BT HS mode is under progress*/
+	boolean			is_bt_limited_dig;	/*@BT is busy.*/
 };
 #endif
 
 struct	phydm_iot_center {
-	boolean		is_linked_cmw500;
-	u8			win_patch_id;		/*Customer ID*/
+	boolean			is_linked_cmw500;
+	u8			win_patch_id;		/*@Customer ID*/
 	u32			phydm_patch_id;
 
 };
 
+#if (RTL8822B_SUPPORT == 1)
+struct drp_rtl8822b_struct {
+	enum bb_path path_judge;
+	u16 path_a_cck_fa;
+	u16 path_b_cck_fa;
+};
+#endif
+
+#ifdef CONFIG_MCC_DM
+#define MCC_DM_REG_NUM	32
+struct _phydm_mcc_dm_ {
+	u8		mcc_pre_status;
+	u8		mcc_reg_id[MCC_DM_REG_NUM];
+	u16		mcc_dm_reg[MCC_DM_REG_NUM];
+	u8		mcc_dm_val[MCC_DM_REG_NUM][2];
+	/*mcc DIG*/
+	u8		mcc_rssi[2];
+	/*u8		mcc_igi[2];*/
+
+	/* need to be config by driver*/
+	u8		mcc_status;
+	u8		sta_macid[2][NUM_STA];
+	u16		mcc_rf_channel[2];
+
+};
+#endif
+
+
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	#if (RT_PLATFORM != PLATFORM_LINUX)
 		typedef
 	#endif
 
-	struct PHY_DM_STRUCT
+struct dm_struct {
 #else/*for AP, CE Team*/
-	struct PHY_DM_STRUCT
+struct dm_struct {
 #endif
-{
-	/*Add for different team use temporarily*/
-	struct _ADAPTER		*adapter;		/*For CE/NIC team*/
-	struct rtl8192cd_priv	*priv;			/*For AP team*/
-	/*WHen you use adapter or priv pointer, you must make sure the pointer is ready.*/
-	boolean		odm_ready;
+	/*@Add for different team use temporarily*/
+	void			*adapter;		/*@For CE/NIC team*/
+	struct rtl8192cd_priv	*priv;			/*@For AP team*/
+	boolean			odm_ready;
 	enum phy_reg_pg_type	phy_reg_pg_value_type;
 	u8			phy_reg_pg_version;
-	u64			support_ability;	/*PHYDM function Supportability*/
-	u64			pause_ability;	/*PHYDM function pause Supportability*/
+	u64			support_ability;	/*@PHYDM function Supportability*/
+	u64			pause_ability;		/*@PHYDM function pause Supportability*/
 	u64			debug_components;
+	u8			cmn_dbg_msg_period;
+	u8			cmn_dbg_msg_cnt;
 	u32			fw_debug_components;
-	u32			debug_level;
-	u32			num_qry_phy_status_all;		/*CCK + OFDM*/
+	u32			num_qry_phy_status_all;	/*@CCK + OFDM*/
 	u32			last_num_qry_phy_status_all;
 	u32			rx_pwdb_ave;
-	boolean		is_init_hw_info_by_rfe;
+	boolean			is_init_hw_info_by_rfe;
 
-	/*------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
-	boolean		is_cck_high_power;
+	/*@------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
+	boolean			is_cck_high_power;
 	u8			rf_path_rx_enable;
-	/*------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
-
-	/* COMMON INFORMATION */
-
-	/*Init value*/
-	/*-----------HOOK BEFORE REG INIT-----------*/
-
-	u8			support_platform;/*PHYDM Platform info WIN/AP/CE = 1/2/3 */
-	u8			normal_rx_path;	
-	boolean			brxagcswitch; /* for rx AGC table switch in Microsoft case */
-	u8			support_interface;/*PHYDM PCIE/USB/SDIO = 1/2/3*/
-	u32			support_ic_type;	/*PHYDM supported IC*/
-	u8			cut_version;		/*cut version TestChip/A-cut/B-cut... = 0/1/2/3/...*/
-	u8			fab_version;		/*Fab version TSMC/UMC = 0/1*/
-	u8			rf_type;			/*RF type 4T4R/3T3R/2T2R/1T2R/1T1R/...*/
+	/*@------ ODM HANDLE, DRIVER NEEDS NOT TO HOOK------*/
+
+	/* @COMMON INFORMATION */
+
+	/*@Init value*/
+	/*@-----------HOOK BEFORE REG INIT-----------*/
+
+	u8			support_platform;	/*@PHYDM Platform info WIN/AP/CE = 1/2/3 */
+	u8			normal_rx_path;
+	boolean			brxagcswitch;		/* @for rx AGC table switch in Microsoft case */
+	u8			support_interface;	/*@PHYDM PCIE/USB/SDIO = 1/2/3*/
+	u32			support_ic_type;	/*@PHYDM supported IC*/
+	u8			ic_ip_series;		/*N/AC/JGR3*/
+	enum phydm_phy_sts_type	ic_phy_sts_type;	/*@Type1/type2/type3*/
+	u8			cut_version;		/*@cut version TestChip/A-cut/B-cut... = 0/1/2/3/...*/
+	u8			fab_version;		/*@Fab version TSMC/UMC = 0/1*/
+	u8			fw_version;
+	u8			fw_sub_version;
+	u8			rf_type;		/*@RF type 4T4R/3T3R/2T2R/1T2R/1T1R/...*/
 	u8			rfe_type;
 	u8			board_type;
 	u8			package_type;
@@ -559,26 +745,25 @@ struct	phydm_iot_center {
 	u16			type_gpa;
 	u16			type_alna;
 	u16			type_apa;
-	u8			ext_lna;			/*with 2G external LNA  NO/Yes = 0/1*/
-	u8			ext_lna_5g;		/*with 5G external LNA  NO/Yes = 0/1*/
-	u8			ext_pa;			/*with 2G external PNA  NO/Yes = 0/1*/
-	u8			ext_pa_5g;		/*with 5G external PNA  NO/Yes = 0/1*/
-	u8 			efuse0x3d7;		/*with Efuse number*/
-	u8 			efuse0x3d8;
-	u8			ext_trsw;		/*with external TRSW  NO/Yes = 0/1*/
-	u8			ext_lna_gain;	/*gain of external lna*/
-	boolean		is_in_hct_test;
+	u8			ext_lna;		/*@with 2G external LNA  NO/Yes = 0/1*/
+	u8			ext_lna_5g;		/*@with 5G external LNA  NO/Yes = 0/1*/
+	u8			ext_pa;			/*@with 2G external PNA  NO/Yes = 0/1*/
+	u8			ext_pa_5g;		/*@with 5G external PNA  NO/Yes = 0/1*/
+	u8			efuse0x3d7;		/*@with Efuse number*/
+	u8			efuse0x3d8;
+	u8			ext_trsw;		/*@with external TRSW  NO/Yes = 0/1*/
+	u8			ext_lna_gain;		/*@gain of external lna*/
+	boolean			is_in_hct_test;
 	u8			wifi_test;
-	boolean		is_dual_mac_smart_concurrent;
-	u32			bk_support_ability; /*SD4 only*/
+	boolean			is_dual_mac_smart_concurrent;
+	u32			bk_support_ability;	/*SD4 only*/
 	u8			with_extenal_ant_switch;
-	/*cck agc relative*/
-	boolean		cck_new_agc;
+	/*@cck agc relative*/
+	boolean			cck_new_agc;
 	s8			cck_lna_gain_table[8];
-	/*-------------------------------------*/
-	u8			phydm_period;
+	/*@-------------------------------------*/
 	u32			phydm_sys_up_time;
-	u8			num_rf_path; /*ex: 8821C=1, 8192E=2, 8814B=4*/
+	u8			num_rf_path;		/*@ex: 8821C=1, 8192E=2, 8814B=4*/
 	u32			soft_ap_special_setting;
 	s8			s8_dummy;
 	u8			u8_dummy;
@@ -586,62 +771,67 @@ struct	phydm_iot_center {
 	u32			u32_dummy;
 	u8			rfe_hwsetting_band;
 	u8			p_advance_ota;
-	boolean		hp_hw_id;
-	boolean		BOOLEAN_temp;
-	boolean		is_dfs_band;
-	u8			is_receiver_blocking_en;
+	boolean			hp_hw_id;
+	boolean			BOOLEAN_temp;
+	boolean			is_dfs_band;
+	u8			is_rx_blocking_en;
 	u16			fw_offload_ability;
-/*-----------HOOK BEFORE REG INIT-----------*/
-/*===========================================================*/	
-/*====[ CALL BY Reference ]=========================================*/
-/*===========================================================*/	
-
-	u64			*p_num_tx_bytes_unicast;	/*TX Unicast byte count*/
-	u64			*p_num_rx_bytes_unicast;	/*RX Unicast byte count*/
-	u8			*p_band_type;				/*Frequence band 2.4G/5G = 0/1*/
-	u8			*p_sec_ch_offset;			/*Secondary channel offset don't_care/below/above = 0/1/2*/
-	u8			*p_security;					/*security mode Open/WEP/AES/TKIP = 0/1/2/3*/
-	u8			*p_band_width;				/*BW info 20M/40M/80M = 0/1/2*/
-	u8			*p_channel;					/*central channel number*/
-	boolean		*p_is_scan_in_process;		/*Common info for status*/
-	boolean		*p_is_power_saving;
-	u8			*p_one_path_cca;			/*CCA path 2-path/path-A/path-B = 0/1/2; using enum odm_cca_path_e.*/
-	u8			*p_antenna_test;
-	boolean		*p_is_net_closed;
-	boolean		*p_is_fcs_mode_enable;
-	/*--------- For 8723B IQK-------------------------------------*/
-	boolean		*p_is_1_antenna;
-	u8			*p_rf_default_path;	/* 0:S1, 1:S0 */
-	/*-----------------------------------------------------------*/
-
-	u16			*p_forced_data_rate;
-	u8			*p_enable_antdiv;
-	u8			*p_enable_adaptivity;
-	u8			*hub_usb_mode;		/*1: USB 2.0, 2: USB 3.0*/
-	boolean		*p_is_fw_dw_rsvd_page_in_progress;
-	u32			*p_current_tx_tp;
-	u32			*p_current_rx_tp;
-	u8			*p_sounding_seq;
-	u32			*p_soft_ap_mode;
-	u8			*p_mp_mode;
-	u32			*p_interrupt_mask;
-	u8			*p_bb_op_mode;
-/*===========================================================*/	
-/*====[ CALL BY VALUE ]===========================================*/
-/*===========================================================*/	
+/*@-----------HOOK BEFORE REG INIT-----------*/
+/*@===========================================================*/
+/*@====[ CALL BY Reference ]=========================================*/
+/*@===========================================================*/
+
+	u64			*num_tx_bytes_unicast;	/*@TX Unicast byte cnt*/
+	u64			*num_rx_bytes_unicast;	/*@RX Unicast byte cnt*/
+	u8			*band_type;		/*@2.4G/5G = 0/1*/
+	u8			*sec_ch_offset;		/*@Secondary channel offset don't_care/below/above = 0/1/2*/
+	u8			*security;		/*@security mode Open/WEP/AES/TKIP = 0/1/2/3*/
+	u8			*band_width;		/*@20M/40M/80M = 0/1/2*/
+	u8			*channel;		/*@central CH number*/
+	boolean			*is_scan_in_process;
+	boolean			*is_power_saving;
+	boolean			*is_tdma;
+	u8			*one_path_cca;		/*@CCA path 2-path/path-A/path-B = 0/1/2; using enum odm_cca_path.*/
+	u8			*antenna_test;
+	boolean			*is_net_closed;
+	boolean			*is_fcs_mode_enable;
+	/*@--------- For 8723B IQK-------------------------------------*/
+	boolean			*is_1_antenna;
+	u8			*rf_default_path;	/* @0:S1, 1:S0 */
+	/*@-----------------------------------------------------------*/
+
+	u16			*forced_data_rate;
+	u8			*enable_antdiv;
+	u8			*enable_pathdiv;
+	u8			*en_adap_soml;
+	u8			*enable_adaptivity;
+	u8			*hub_usb_mode;		/*@1:USB2.0, 2:USB3.0*/
+	boolean			*is_fw_dw_rsvd_page_in_progress;
+	u32			*current_tx_tp;
+	u32			*current_rx_tp;
+	u8			*sounding_seq;
+	u32			*soft_ap_mode;
+	u8			*mp_mode;
+	u32			*interrupt_mask;
+	u8			*bb_op_mode;
+/*@===========================================================*/
+/*@====[ CALL BY VALUE ]===========================================*/
+/*@===========================================================*/
 
 	u8			disable_phydm_watchdog;
-	boolean		is_link_in_process;
-	boolean		is_wifi_direct;
-	boolean		is_wifi_display;
-	boolean		is_linked;
-	boolean		bsta_state;
+	boolean			is_link_in_process;
+	boolean			is_wifi_direct;
+	boolean			is_wifi_display;
+	boolean			is_linked;
+	boolean			bsta_state;
 	u8			rssi_min;
+	u8			rssi_min_macid;
 	u8			pre_rssi_min;
 	u8			rssi_max;
+	u8			rssi_max_macid;
 	u8			rssi_min_by_path;
-	boolean		is_mp_chip;
-	boolean		is_one_entry_only;
+	boolean			is_mp_chip;
+	boolean			is_one_entry_only;
 	u32			one_entry_macid;
 	u32			one_entry_tp;
 	u32			pre_one_entry_tp;
@@ -649,15 +839,19 @@ struct	phydm_iot_center {
 	u8			number_linked_client;
 	u8			pre_number_active_client;
 	u8			number_active_client;
-	boolean		is_disable_phy_api;
-	u8			RSSI_A;
-	u8			RSSI_B;
-	u8			RSSI_C;
-	u8			RSSI_D;
-	u64			RSSI_TRSW;
-	u64			RSSI_TRSW_H;
-	u64			RSSI_TRSW_L;
-	u64			RSSI_TRSW_iso;
+	boolean			is_disable_phy_api;
+	u8			rssi_a;
+	u8			rssi_b;
+	u8			rssi_c;
+	u8			rssi_d;
+	s8			rxsc_80;
+	s8			rxsc_40;
+	s8			rxsc_20;
+	s8			rxsc_l;
+	u64			rssi_trsw;
+	u64			rssi_trsw_h;
+	u64			rssi_trsw_l;
+	u64			rssi_trsw_iso;
 	u8			tx_ant_status;
 	u8			rx_ant_status;
 	u8			cck_lna_idx;
@@ -670,49 +864,55 @@ struct	phydm_iot_center {
 	u8			linked_interval;
 	u8			pre_channel;
 	u32			txagc_offset_value_a;
-	boolean		is_txagc_offset_positive_a;
+	boolean			is_txagc_offset_positive_a;
 	u32			txagc_offset_value_b;
-	boolean		is_txagc_offset_positive_b;
-	/*[traffic]*/
+	boolean			is_txagc_offset_positive_b;
+	u8			ap_total_num;
+	/*@[traffic]*/
 	u8			traffic_load;
 	u8			pre_traffic_load;
-	u32			tx_tp;	/*Mbps*/
-	u32			rx_tp;	/*Mbps*/
-	u32			total_tp;/*Mbps*/
-	u8			txrx_state_all;	/*0: tx, 1:rx, 2:bi-direction*/
+	u32			tx_tp;			/*@Mbps*/
+	u32			rx_tp;			/*@Mbps*/
+	u32			total_tp;		/*@Mbps*/
+	u8			txrx_state_all;		/*@0:tx, 1:rx, 2:bi-dir*/
 	u64			cur_tx_ok_cnt;
 	u64			cur_rx_ok_cnt;
 	u64			last_tx_ok_cnt;
 	u64			last_rx_ok_cnt;
-	u16			consecutive_idlel_time;	/*unit: second*/
-	/*---------------------------*/
-	boolean		is_bb_swing_offset_positive_a;
-	boolean		is_bb_swing_offset_positive_b;
+	u16			consecutive_idlel_time;	/*@unit: second*/
+	/*@---------------------------*/
+	boolean			is_bb_swing_offset_positive_a;
+	boolean			is_bb_swing_offset_positive_b;
 
-	/*[DIG]*/
-	boolean		MPDIG_2G;				/*off MPDIG*/
-	u8			times_2g;	/*for MP DIG*/
+	/*@[DIG]*/
+	boolean			MPDIG_2G;		/*off MPDIG*/
+	u8			times_2g;		/*@for MP DIG*/
+	u8			force_igi;		/*@for debug*/
 
-	/*[TDMA-DIG]*/
+	/*@[TDMA-DIG]*/
 	u8			tdma_dig_timer_ms;
 	u8			tdma_dig_state_number;
 	u8			tdma_dig_low_upper_bond;
+	u8			force_tdma_low_igi;
+	u8			force_tdma_high_igi;
 	u8			fix_expire_to_zero;
-	boolean		original_dig_restore;
-	/*---------------------------*/
+	boolean			original_dig_restore;
+	/*@---------------------------*/
 
-	/*[AntDiv]*/
+	/*@[AntDiv]*/
 	u8			ant_div_type;
 	u8			antdiv_rssi;
 	u8			fat_comb_a;
 	u8			fat_comb_b;
 	u8			antdiv_intvl;
 	u8			ant_type;
+	u8			ant_type2;
 	u8			pre_ant_type;
+	u8			pre_ant_type2;
 	u8			antdiv_period;
 	u8			evm_antdiv_period;
 	u8			antdiv_select;
-	u8			antdiv_train_num;/*training time for each antenna in EVM method*/
+	u8			antdiv_train_num; /*@training time for each antenna in EVM method*/
 	u8			stop_antdiv_rssi_th;
 	u16			stop_antdiv_tp_diff_th;
 	u16			stop_antdiv_tp_th;
@@ -722,267 +922,279 @@ struct	phydm_iot_center {
 	u8			path_select;
 	u8			antdiv_evm_en;
 	u8			bdc_holdstate;
-	/*---------------------------*/
-	
+	u8			antdiv_counter;
+	/*@---------------------------*/
+
 	u8			ndpa_period;
-	boolean		h2c_rarpt_connect;
-	boolean		cck_agc_report_type;
+	boolean			h2c_rarpt_connect;
+	boolean			cck_agc_report_type; /*@1:4bit LNA, 0:3bit LNA */
 	u8			print_agc;
 	u8			la_mode;
-	/*---8821C Antenna and RF Set BTG/WLG/WLA Select---------------*/
+	/*@---8821C Antenna and RF Set BTG/WLG/WLA Select---------------*/
 	u8			current_rf_set_8821c;
 	u8			default_rf_set_8821c;
 	u8			current_ant_num_8821c;
 	u8			default_ant_num_8821c;
-	u8			rfe_type_21c;
-	/*-----------------------------------------------------------*/
-	/*---For Adaptivtiy---------------------------------------------*/
+	u8			rfe_type_expand;
+	/*@-----------------------------------------------------------*/
+	/*@---For Adaptivtiy---------------------------------------------*/
 	s8			TH_L2H_default;
 	s8			th_edcca_hl_diff_default;
 	s8			th_l2h_ini;
 	s8			th_edcca_hl_diff;
-	s8			th_l2h_ini_mode2;
-	s8			th_edcca_hl_diff_mode2;
-	boolean		carrier_sense_enable;
-	boolean		adaptivity_flag;	/*Limit IGI upper bound for Adaptivity*/
-	u8			dc_backoff;
-	boolean		adaptivity_enable;
-	u8			ap_total_num;
-	boolean		edcca_enable;
-	u8			odm_regulation_2_4g;
-	u8			odm_regulation_5g;
-	/*-----------------------------------------------------------*/
-	
+	boolean			carrier_sense_enable;
+	/*@-----------------------------------------------------------*/
+
 	u8			pre_dbg_priority;
 	u8			nbi_set_result;
 	u8			c2h_cmd_start;
 	u8			fw_debug_trace[60];
 	u8			pre_c2h_seq;
-	boolean		fw_buff_is_enpty;
+	boolean			fw_buff_is_enpty;
 	u32			data_frame_num;
 
-	/*--- for noise detection ---------------------------------------*/
-	boolean		is_noisy_state;
-	boolean		noisy_decision; /*b_noisy*/
-	boolean		pre_b_noisy;
+	/*@--- for noise detection ---------------------------------------*/
+	boolean			is_noisy_state;
+	boolean			noisy_decision; /*@b_noisy*/
+	boolean			pre_b_noisy;
 	u32			noisy_decision_smooth;
-	u8			lna_sat_chk_cnt;
-	u8			lna_sat_chk_duty_cycle;
-	u32			lna_sat_chk_period_ms;
-	boolean		is_disable_lna_sat_chk;
-	boolean		is_disable_gain_table_switch;
-	/*-----------------------------------------------------------*/
-	
-	boolean		is_disable_dym_ecs;
-	boolean		is_disable_dym_ant_weighting;
-	struct sta_info	*p_odm_sta_info[ODM_ASSOCIATE_ENTRY_NUM];/*_ODM_STA_INFO, 2012/01/12 MH For MP, we need to reduce one array pointer for default port.??*/
-	struct cmn_sta_info	*p_phydm_sta_info[ODM_ASSOCIATE_ENTRY_NUM];
-	u8			phydm_macid_table[ODM_ASSOCIATE_ENTRY_NUM];
-
-#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-	s32			accumulate_pwdb[ODM_ASSOCIATE_ENTRY_NUM];
-#endif
+	/*@-----------------------------------------------------------*/
+
+	/*@--- for MCC ant weighting ------------------------------------*/
+	boolean			is_stop_dym_ant_weighting;
+	/*@-----------------------------------------------------------*/
+
+	boolean			is_disable_dym_ecs;
+	boolean			is_disable_dym_ant_weighting;
+	struct cmn_sta_info	*phydm_sta_info[ODM_ASSOCIATE_ENTRY_NUM];
+	u8			phydm_macid_table[ODM_ASSOCIATE_ENTRY_NUM];/*@sta_idx = phydm_macid_table[HW_macid]*/
 
 #if (RATE_ADAPTIVE_SUPPORT == 1)
 	u16			currmin_rpt_time;
-	struct _odm_ra_info_   ra_info[ODM_ASSOCIATE_ENTRY_NUM];
-	/*Use mac_id as array index. STA mac_id=0, VWiFi Client mac_id={1, ODM_ASSOCIATE_ENTRY_NUM-1} //YJ,add,120119*/
+	struct _phydm_txstatistic_ hw_stats;
+	struct _odm_ra_info_	ra_info[ODM_ASSOCIATE_ENTRY_NUM];
+/*Use mac_id as array index. STA mac_id=0*/
+/*VWiFi Client mac_id={1, ODM_ASSOCIATE_ENTRY_NUM-1} //YJ,add,120119*/
 #endif
-	boolean		ra_support88e;	/*2012/02/14 MH Add to share 88E ra with other SW team.We need to colelct all support abilit to a proper area.*/
-	boolean		*p_is_driver_stopped;
-	boolean		*p_is_driver_is_going_to_pnp_set_power_sleep;
-	boolean		*pinit_adpt_in_progress;
-	boolean		is_user_assign_level;
-	u8			RSSI_BT;			/*come from BT*/
-
-	/*---PSD Relative ---------------------------------------------*/
-	boolean		is_psd_in_process;
-	boolean		is_psd_active;
-	/*-----------------------------------------------------------*/
-	
-	boolean		bsomlenabled;		/* for dynamic SoML control */
-	boolean		bhtstfdisabled;		/* for dynamic HTSTF gain control	*/
-	boolean		disrxhpsoml;			/* for dynamic RxHP control with SoML on/off */
+	/*@2012/02/14 MH Add to share 88E ra with other SW team*/
+	/*We need to colelct all support abilit to a proper area.*/
+	boolean			ra_support88e;
+	boolean			*is_driver_stopped;
+	boolean			*is_driver_is_going_to_pnp_set_power_sleep;
+	boolean			*pinit_adpt_in_progress;
+	boolean			is_user_assign_level;
+	u8			RSSI_BT;		/*@come from BT*/
+
+	/*@---PSD Relative ---------------------------------------------*/
+	boolean			is_psd_in_process;
+	boolean			is_psd_active;
+	/*@-----------------------------------------------------------*/
+
+	boolean			bsomlenabled;	/* @D-SoML control */
+	boolean			bhtstfdisabled;	/* @dynamic HTSTF gain control*/
 	u32			n_iqk_cnt;
 	u32			n_iqk_ok_cnt;
 	u32			n_iqk_fail_cnt;
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	boolean		config_bbrf;
+	boolean			config_bbrf;
+#endif
+	boolean			is_disable_power_training;
+	boolean			is_bt_continuous_turn;
+	u8			enhance_pwr_th[3];
+	u8			set_pwr_th[3];
+	/*@----------Dyn Tx Pwr ---------------------------------------*/
+#ifdef BB_RAM_SUPPORT
+	struct phydm_bb_ram_ctrl p_bb_ram_ctrl;
 #endif
-	boolean		is_disable_power_training;
-	boolean		is_bt_continuous_turn;
 	u8			dynamic_tx_high_power_lvl;
+	void	(*fill_desc_dyntxpwr)(void *dm, u8 *desc, u8 dyn_tx_power);
 	u8			last_dtp_lvl;
+	u8			min_power_index;
 	u32			tx_agc_ofdm_18_6;
+	/*-------------------------------------------------------------*/
 	u8			rx_pkt_type;
 
 #ifdef CONFIG_PHYDM_DFS_MASTER
 	u8			dfs_region_domain;
 	u8			*dfs_master_enabled;
-	/*---phydm_radar_detect_with_dbg_parm start --------------------*/
+	/*@---phydm_radar_detect_with_dbg_parm start --------------------*/
 	u8			radar_detect_dbg_parm_en;
 	u32			radar_detect_reg_918;
 	u32			radar_detect_reg_91c;
 	u32			radar_detect_reg_920;
 	u32			radar_detect_reg_924;
-	/*-----------------------------------------------------------*/
+	u32			radar_detect_reg_f54;
+	u32			radar_detect_reg_f58;
+	u32			radar_detect_reg_f5c;
+	u32			radar_detect_reg_f70;
+	u32			radar_detect_reg_f74;
+/*@-----------------------------------------------------------*/
 #endif
 
-/*=== PHYDM Timer ========================================== (start)*/
+/*@=== PHYDM Timer ========================================== (start)*/
 
-	struct timer_list	mpt_dig_timer;	/*MPT DIG timer*/
-	struct timer_list	path_div_switch_timer;
-	struct timer_list	cck_path_diversity_timer;	/*2011.09.27 add for path Diversity*/
-	struct timer_list	fast_ant_training_timer;
+	struct phydm_timer_list	mpt_dig_timer;
+	struct phydm_timer_list	fast_ant_training_timer;
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-	struct timer_list	evm_fast_ant_training_timer;
+	struct phydm_timer_list	evm_fast_ant_training_timer;
 #endif
-	struct timer_list	sbdcnt_timer;
-
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_timer_list tdma_dig_timer;
+#endif
+	struct phydm_timer_list	sbdcnt_timer;
 
-/*=== PHYDM Workitem ======================================= (start)*/
+/*@=== PHYDM Workitem ======================================= (start)*/
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #if USE_WORKITEM
-	RT_WORK_ITEM	path_div_switch_workitem;
-	RT_WORK_ITEM	cck_path_diversity_workitem;
-	RT_WORK_ITEM	fast_ant_training_workitem;
-	RT_WORK_ITEM	ra_rpt_workitem;
-	RT_WORK_ITEM	sbdcnt_workitem;
+	RT_WORK_ITEM		fast_ant_training_workitem;
+	RT_WORK_ITEM		ra_rpt_workitem;
+	RT_WORK_ITEM		sbdcnt_workitem;
+	RT_WORK_ITEM		phydm_evm_antdiv_workitem;
 #endif
 #endif
 
-
-/*=== PHYDM Structure ======================================== (start)*/
-	struct	phydm_func_poiner			phydm_func_handler;
-	struct	phydm_iot_center				iot_table;
+/*@=== PHYDM Structure ======================================== (start)*/
+	struct	phydm_func_poiner	phydm_func_handler;
+	struct	phydm_iot_center	iot_table;
 
 #ifdef ODM_CONFIG_BT_COEXIST
-	struct	phydm_bt_info				bt_info_table;
+	struct	phydm_bt_info		bt_info_table;
 #endif
 
-	struct	pkt_process_info				pkt_proc_struct;
-	struct phydm_adaptivity_struct			adaptivity;
+	struct	pkt_process_info	pkt_proc_struct;
+	struct phydm_adaptivity_struct	adaptivity;
 	struct _DFS_STATISTICS		dfs;
-
-	struct _ODM_NOISE_MONITOR_			noise_level;
-
-	struct _odm_phy_dbg_info_				phy_dbg_info;
+	struct odm_noise_monitor	noise_level;
+	struct odm_phy_dbg_info		phy_dbg_info;
 
 #ifdef CONFIG_ADAPTIVE_SOML
-	struct adaptive_soml					dm_soml_table;
+	struct adaptive_soml		dm_soml_table;
 #endif
 
 #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
 	#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct _BF_DIV_COEX_					dm_bdc_table;
+	struct _BF_DIV_COEX_		dm_bdc_table;
 	#endif
 
 	#if (defined(CONFIG_HL_SMART_ANTENNA))
-	struct smt_ant_honbo					dm_sat_table;
+	struct smt_ant_honbo		dm_sat_table;
 	#endif
 #endif
 
 #if (defined(CONFIG_SMART_ANTENNA))
-	struct smt_ant						smtant_table;
+	struct smt_ant			smtant_table;
+#endif
+
+	struct _hal_rf_			rf_table;	/*@for HALRF function*/
+	struct dm_rf_calibration_struct	rf_calibrate_info;
+	struct dm_iqk_info		IQK_info;
+	struct dm_dpk_info		dpk_info;
+
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	struct phydm_fat_struct		dm_fat_table;
+	struct sw_antenna_switch	dm_swat_table;
+#endif
+	struct phydm_dig_struct		dm_dig_table;
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	struct phydm_lna_sat_t		dm_lna_sat_info;
 #endif
 
-	struct phydm_fat_struct				dm_fat_table;
-	struct phydm_dig_struct				dm_dig_table;
-	struct phydm_lna_sat_info_struct	dm_lna_sat_info;
+#ifdef CONFIG_MCC_DM
+	struct _phydm_mcc_dm_ mcc_dm;
+#endif
 
 #ifdef PHYDM_SUPPORT_CCKPD
-	struct phydm_cckpd_struct				dm_cckpd_table;
+	struct phydm_cckpd_struct	dm_cckpd_table;
 #endif
-	
+
 #ifdef PHYDM_PRIMARY_CCA
-	struct phydm_pricca_struct				dm_pri_cca;
+	struct phydm_pricca_struct	dm_pri_cca;
 #endif
 
-	struct _rate_adaptive_table_			dm_ra_table;
-	struct phydm_fa_struct					false_alm_cnt;
+	struct ra_table			dm_ra_table;
+	struct phydm_fa_struct		false_alm_cnt;
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-	struct phydm_fa_acc_struct				false_alm_cnt_acc;
+	struct phydm_fa_acc_struct	false_alm_cnt_acc;
+#ifdef IS_USE_NEW_TDMA
+	struct phydm_fa_acc_struct	false_alm_cnt_acc_low;
+#endif
 #endif
-	struct _sw_antenna_switch_				dm_swat_table;
-	struct phydm_cfo_track_struct			dm_cfo_track;
-	struct _ACS_							dm_acs;
-	struct _CCX_INFO						dm_ccx_info;
-	struct _hal_rf_						rf_table; 		/*for HALRF function*/
-	struct odm_rf_calibration_structure		rf_calibrate_info;
-	struct odm_power_trim_data			power_trim_data;	
+	struct phydm_cfo_track_struct	dm_cfo_track;
+	struct ccx_info			dm_ccx_info;
+
+	struct odm_power_trim_data	power_trim_data;
 #if (RTL8822B_SUPPORT == 1)
-	struct drp_rtl8822b_struct			phydm_rtl8822b;
+	struct drp_rtl8822b_struct	phydm_rtl8822b;
 #endif
 
 #ifdef CONFIG_PSD_TOOL
-	struct _PHYDM_PSD_					dm_psd_table;
+	struct psd_info			dm_psd_table;
 #endif
 
 #if (PHYDM_LA_MODE_SUPPORT == 1)
-	struct _RT_ADCSMP					adcsmp;
-#endif
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	struct _DYNAMIC_RX_PATH_			dm_drp_table;
-#endif
-
-	struct _IQK_INFORMATION				IQK_info;
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _path_div_parameter_define_		path_iqk;
+	struct rt_adcsmp		adcsmp;
 #endif
 
 #if (defined(CONFIG_PATH_DIVERSITY))
-	struct _ODM_PATH_DIVERSITY_			dm_path_div;
+	struct _ODM_PATH_DIVERSITY_	dm_path_div;
 #endif
 
 #if (defined(CONFIG_ANT_DETECTION))
-	struct _ANT_DETECTED_INFO			ant_detected_info;	/* Antenna detected information for RSSI tool*/
+	struct _ANT_DETECTED_INFO	ant_detected_info;
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-	struct _RT_BEAMFORMING_INFO 		beamforming_info;
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	struct _RT_BEAMFORMING_INFO 	beamforming_info;
 #endif
 #endif
 #ifdef PHYDM_AUTO_DEGBUG
-	struct	phydm_auto_dbg_struc			auto_dbg_table;
+	struct	phydm_auto_dbg_struct	auto_dbg_table;
 #endif
 
-	struct	phydm_pause_lv				pause_lv_table;	
-	struct	phydm_api_stuc 				api_table;
+	struct	phydm_pause_lv		pause_lv_table;
+	struct	phydm_api_stuc		api_table;
 #ifdef PHYDM_POWER_TRAINING_SUPPORT
-	struct	phydm_pow_train_stuc			pow_train_table;
+	struct	phydm_pow_train_stuc	pow_train_table;
+#endif
+
+#ifdef PHYDM_PMAC_TX_SETTING_SUPPORT
+	struct phydm_pmac_tx dm_pmac_tx_table;
 #endif
-/*==========================================================*/
+
+#ifdef PHYDM_MP_SUPPORT
+	struct phydm_mp dm_mp_table;
+#endif
+/*@==========================================================*/
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 
 #if (RT_PLATFORM != PLATFORM_LINUX)
-}PHY_DM_STRUCT;		/*DM_Dynamic_Mechanism_Structure*/
+} dm_struct;	/*@DM_Dynamic_Mechanism_Structure*/
 #else
 };
 #endif
 
-#else	/*for AP,CE Team*/
+#else	/*@for AP,CE Team*/
 };
 #endif
 
 enum phydm_adv_ota {
-	PHYDM_PATHB_1RCCA = BIT(0),
-	PHYDM_HP_OTA_SETTING_A = BIT(1),
-	PHYDM_HP_OTA_SETTING_B = BIT(2),
-	PHYDM_ASUS_OTA_SETTING = BIT(3),
+	PHYDM_PATHB_1RCCA		= BIT(0),
+	PHYDM_HP_OTA_SETTING_A		= BIT(1),
+	PHYDM_HP_OTA_SETTING_B		= BIT(2),
+	PHYDM_ASUS_OTA_SETTING		= BIT(3),
 	PHYDM_ASUS_OTA_SETTING_CCK_PATH = BIT(4),
-	PHYDM_HP_OTA_SETTING_CCK_PATH = BIT(5),
+	PHYDM_HP_OTA_SETTING_CCK_PATH	= BIT(5),
+	PHYDM_LENOVO_OTA_SETTING_NBI_CSI = BIT(6),
 
 };
 
 enum phydm_bb_op_mode {
-	PHYDM_PERFORMANCE_MODE = 0,	/*Service one device*/
-	PHYDM_BALANCE_MODE = 1,		/*Service more than one device*/
+	PHYDM_PERFORMANCE_MODE	= 0,		/*Service one device*/
+	PHYDM_BALANCE_MODE	= 1,		/*@Service more than one device*/
 };
 
 enum phydm_structure_type {
@@ -1002,11 +1214,13 @@ enum odm_bb_config_type {
 	CONFIG_BB_PHY_REG_PG,
 	CONFIG_BB_PHY_REG_MP,
 	CONFIG_BB_AGC_TAB_DIFF,
+	CONFIG_BB_RF_CAL_INIT,
 };
 
 enum odm_rf_config_type {
 	CONFIG_RF_RADIO,
 	CONFIG_RF_TXPWR_LMT,
+	CONFIG_RF_SYN_RADIO,
 };
 
 enum odm_fw_config_type {
@@ -1033,234 +1247,112 @@ enum rt_status {
 	RT_STATUS_NOT_SUPPORT,
 	RT_STATUS_OS_API_FAILED,
 };
-#endif	/*end of enum rt_status definition*/
-
-
-/*===========================================================*/
-/*AGC RX High Power mode*/
-/*===========================================================*/
-#define	lna_low_gain_1		0x64
-#define	lna_low_gain_2		0x5A
-#define	lna_low_gain_3		0x58
-
-/*Add for cmn sta info*/
-
-#define is_sta_active(p_sta)	((p_sta) && (p_sta->dm_ctrl & STA_DM_CTRL_ACTIVE))
+#endif	/*@end of enum rt_status definition*/
 
 void
-phydm_watchdog_lps(
-	struct PHY_DM_STRUCT		*p_dm
-);
+phydm_watchdog_lps(struct dm_struct *dm);
 
 void
-phydm_watchdog_lps_32k(
-	struct PHY_DM_STRUCT		*p_dm
-);
+phydm_watchdog_lps_32k(struct dm_struct *dm);
 
 void
-phydm_txcurrentcalibration(
-	struct PHY_DM_STRUCT	*p_dm
-);	
+phydm_txcurrentcalibration(struct dm_struct *dm);
 
 void
-phydm_dm_early_init(
-	struct PHY_DM_STRUCT	*p_dm
-);
+phydm_dm_early_init(struct dm_struct *dm);
 
 void
-odm_dm_init(
-	struct PHY_DM_STRUCT	*p_dm
-);
+odm_dm_init(struct dm_struct *dm);
 
 void
-odm_dm_reset(
-	struct PHY_DM_STRUCT	*p_dm
-);
+odm_dm_reset(struct dm_struct *dm);
 
 void
-phydm_fwoffload_ability_init(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum phydm_offload_ability	offload_ability
-);
+phydm_fwoffload_ability_init(struct dm_struct *dm,
+			     enum phydm_offload_ability offload_ability);
 
 void
-phydm_fwoffload_ability_clear(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum phydm_offload_ability	offload_ability
-);
-
+phydm_fwoffload_ability_clear(struct dm_struct *dm,
+			      enum phydm_offload_ability offload_ability);
 
 void
-phydm_support_ability_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
+phydm_supportability_en(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len);
 
 void
-phydm_pause_dm_watchdog(
-	void					*p_dm_void,
-	enum phydm_pause_type		pause_type
-);
+phydm_pause_dm_watchdog(void *dm_void, enum phydm_pause_type pause_type);
 
 void
-phydm_watchdog(
-	struct PHY_DM_STRUCT	*p_dm
-);
+phydm_watchdog(struct dm_struct *dm);
 
 void
-phydm_watchdog_mp(
-	struct PHY_DM_STRUCT	*p_dm
-);
+phydm_watchdog_mp(struct dm_struct *dm);
 
 u8
-phydm_pause_func(
-	void					*p_dm_void,
-	enum phydm_func_idx_e	pause_func,	
-	enum phydm_pause_type	pause_type,
-	enum phydm_pause_level	pause_lv,
-	u8						val_lehgth,
-	u32						*val_buf
-	
-);
+phydm_pause_func(void *dm_void, enum phydm_func_idx pause_func,
+		 enum phydm_pause_type pause_type,
+		 enum phydm_pause_level pause_lv, u8 val_lehgth, u32 *val_buf);
 
 void
-phydm_pause_func_console(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
+phydm_pause_func_console(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len);
 
 void
-odm_cmn_info_init(
-	struct PHY_DM_STRUCT	*p_dm,
-	enum odm_cmninfo_e		cmn_info,
-	u64						value
-);
+odm_cmn_info_init(struct dm_struct *dm, enum odm_cmninfo cmn_info, u64 value);
 
 void
-odm_cmn_info_hook(
-	struct PHY_DM_STRUCT	*p_dm,
-	enum odm_cmninfo_e		cmn_info,
-	void						*p_value
-);
+odm_cmn_info_hook(struct dm_struct *dm, enum odm_cmninfo cmn_info, void *value);
 
 void
-odm_cmn_info_update(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32						cmn_info,
-	u64						value
-);
+odm_cmn_info_update(struct dm_struct *dm, u32 cmn_info, u64 value);
 
 u32
-phydm_cmn_info_query(
-	struct PHY_DM_STRUCT	*p_dm,
-	enum phydm_info_query_e	info_type
-);
+phydm_cmn_info_query(struct dm_struct *dm, enum phydm_info_query info_type);
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 void
-odm_init_all_threads(
-	struct PHY_DM_STRUCT	*p_dm
-);
+odm_init_all_timers(struct dm_struct *dm);
 
 void
-odm_stop_all_threads(
-	struct PHY_DM_STRUCT	*p_dm
-);
-#endif
+odm_cancel_all_timers(struct dm_struct *dm);
 
 void
-odm_init_all_timers(
-	struct PHY_DM_STRUCT	*p_dm
-);
+odm_release_all_timers(struct dm_struct *dm);
 
-void
-odm_cancel_all_timers(
-	struct PHY_DM_STRUCT	*p_dm
-);
+void *
+phydm_get_structure(struct dm_struct *dm, u8 structure_type);
 
 void
-odm_release_all_timers(
-	struct PHY_DM_STRUCT	*p_dm
-);
+phydm_dc_cancellation(struct dm_struct *dm);
 
+void
+phydm_receiver_blocking(void *dm_void);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void odm_init_all_work_items(struct PHY_DM_STRUCT	*p_dm);
-void odm_free_all_work_items(struct PHY_DM_STRUCT	*p_dm);
-
-/*2012/01/12 MH Check afapter status. Temp fix BSOD.*/
-
-#define	HAL_ADAPTER_STS_CHK(p_dm) do {\
-		if (p_dm->adapter == NULL) { \
-			\
-			return;\
-		} \
-	} while (0)
-
-#endif	/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
-
-void *
-phydm_get_structure(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			structure_type
+void
+odm_init_all_work_items(
+	struct dm_struct	*dm
 );
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) || (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	/*===========================================================*/
-	/* The following is for compile only*/
-	/*===========================================================*/
-
-	#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-		#define IS_HARDWARE_TYPE_8188E(_adapter)		false
-		#define IS_HARDWARE_TYPE_8188F(_adapter)		false
-		#define IS_HARDWARE_TYPE_8703B(_adapter)		false
-		#define IS_HARDWARE_TYPE_8723D(_adapter)		false
-		#define IS_HARDWARE_TYPE_8821C(_adapter)		false
-		#define IS_HARDWARE_TYPE_8812AU(_adapter)	false
-		#define IS_HARDWARE_TYPE_8814A(_adapter)		false
-		#define IS_HARDWARE_TYPE_8814AU(_adapter)	false
-		#define IS_HARDWARE_TYPE_8814AE(_adapter)	false
-		#define IS_HARDWARE_TYPE_8814AS(_adapter)	false
-		#define IS_HARDWARE_TYPE_8723BU(_adapter)	false
-		#define IS_HARDWARE_TYPE_8822BU(_adapter)	false
-		#define IS_HARDWARE_TYPE_8822BS(_adapter)		false
-		#define IS_HARDWARE_TYPE_JAGUAR(_Adapter)		\
-			(IS_HARDWARE_TYPE_8812(_Adapter) || IS_HARDWARE_TYPE_8821(_Adapter))
-	#else
-		#define	IS_HARDWARE_TYPE_8723A(_adapter)	false
-	#endif
-	#define	IS_HARDWARE_TYPE_8723AE(_adapter)		false
-	#define	IS_HARDWARE_TYPE_8192C(_adapter)			false
-	#define	IS_HARDWARE_TYPE_8192D(_adapter)		false
-	#define	RF_T_METER_92D	0x42
-
-
-	#define	GET_RX_STATUS_DESC_RX_MCS(__prx_status_desc)	LE_BITS_TO_1BYTE(__prx_status_desc+12, 0, 6)
-
-	#define	REG_CONFIG_RAM64X16		0xb2c
-
-
-	/* *********************************************************** */
-#endif
+void
+odm_free_all_work_items(
+	struct dm_struct	*dm
+);
+#endif	/*@#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	void odm_dtc(struct PHY_DM_STRUCT *p_dm);
+void
+odm_dtc(struct dm_struct *dm);
 #endif
 
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 void
-phydm_dc_cancellation(
-	struct	PHY_DM_STRUCT	*p_dm
+odm_init_all_threads(
+	struct dm_struct	*dm
 );
 
 void
-phydm_receiver_blocking(
-	void *p_dm_void
+odm_stop_all_threads(
+	struct dm_struct	*dm
 );
 #endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.mk b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.mk
index f272636bcdc0..b51385622b04 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.mk
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm.mk
@@ -17,7 +17,6 @@ _PHYDM_FILES := hal/phydm/phydm_debug.o	\
 								hal/phydm/phydm_adaptivity.o\
 								hal/phydm/phydm_cfotracking.o\
 								hal/phydm/phydm_noisemonitor.o\
-								hal/phydm/phydm_acs.o\
 								hal/phydm/phydm_beamforming.o\
 								hal/phydm/phydm_dfs.o\
 								hal/phydm/txbf/halcomtxbf.o\
@@ -33,7 +32,11 @@ _PHYDM_FILES := hal/phydm/phydm_debug.o	\
 								hal/phydm/phydm_math_lib.o\
 								hal/phydm/phydm_api.o\
 								hal/phydm/phydm_pow_train.o\
+								hal/phydm/phydm_lna_sat.o\
+								hal/phydm/phydm_pmac_tx_setting.o\
+								hal/phydm/phydm_mp.o\
 								hal/phydm/halrf/halrf.o\
+								hal/phydm/halrf/halrf_debug.o\
 								hal/phydm/halrf/halphyrf_ce.o\
 								hal/phydm/halrf/halrf_powertracking_ce.o\
 								hal/phydm/halrf/halrf_powertracking.o\
@@ -117,6 +120,7 @@ _PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8703b_bb.o\
 								hal/phydm/$(RTL871X)/halhwimg8703b_mac.o\
 								hal/phydm/$(RTL871X)/halhwimg8703b_rf.o\
 								hal/phydm/$(RTL871X)/phydm_regconfig8703b.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8703b.o\
 								hal/phydm/halrf/$(RTL871X)/halrf_8703b.o
 endif
 
@@ -131,6 +135,17 @@ _PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8723d_bb.o\
 endif
 
 
+ifeq ($(CONFIG_RTL8710B), y)
+RTL871X = rtl8710b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8710b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8710b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8710b_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8710b.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8710b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8710b.o
+endif
+
+
 ifeq ($(CONFIG_RTL8188F), y)
 RTL871X = rtl8188f
 _PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8188f_bb.o\
@@ -149,6 +164,7 @@ _PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8822b_bb.o \
 								hal/phydm/halrf/$(RTL871X)/halrf_8822b.o \
 								hal/phydm/$(RTL871X)/phydm_hal_api8822b.o \
 								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8822b.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_rfk_init_8822b.o \
 								hal/phydm/$(RTL871X)/phydm_regconfig8822b.o \
 								hal/phydm/$(RTL871X)/phydm_rtl8822b.o
 
@@ -165,4 +181,47 @@ _PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8821c_bb.o \
 								hal/phydm/$(RTL871X)/phydm_regconfig8821c.o\
 								hal/phydm/halrf/$(RTL871X)/halrf_8821c.o\
 								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8821c.o
+endif
+ifeq ($(CONFIG_RTL8192F), y)
+RTL871X = rtl8192f
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8192f_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8192f_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8192f_rf.o\
+								hal/phydm/$(RTL871X)/phydm_hal_api8192f.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8192f.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8192f.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8192f.o	
+endif
+
+ifeq ($(CONFIG_RTL8198F), y)
+RTL871X = rtl8198f
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8198f_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8198f_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8198f_rf.o\
+								hal/phydm/$(RTL871X)/phydm_hal_api8198f.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8198f.o
+endif
+
+ifeq ($(CONFIG_RTL8822C), y)
+RTL871X = rtl8822c
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8822c_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8822c_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8822c_rf.o\
+								hal/phydm/$(RTL871X)/phydm_hal_api8822c.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8822c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8822c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8822c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_tssi_8822c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_dpk_8822c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_rfk_init_8822c.o
+endif
+
+ifeq ($(CONFIG_RTL8814B), y)
+RTL871X = rtl8814b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8814b_bb.o\
+								hal/phydm/$(RTL871X)/phydm_hal_api8814b.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8814b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8814b.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8814b.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_rfk_init_8814b.o
 endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_acs.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_acs.c
deleted file mode 100644
index 053ecfcb45b4..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_acs.c
+++ /dev/null
@@ -1,1151 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
- *
- * 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 "mp_precomp.h"
-#include "phydm_precomp.h"
-
-
-u8
-odm_get_auto_channel_select_result(
-	void			*p_dm_void,
-	u8			band
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ACS_					*p_acs = &p_dm->dm_acs;
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("%s ======>\n", __func__));
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	if (band == ODM_BAND_2_4G) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("clean_CH_2g=%d\n", p_acs->clean_channel_2g));
-		return (u8)p_acs->clean_channel_2g;
-	} else {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("clean_CH_5g=%d\n", p_acs->clean_channel_5g));
-		return (u8)p_acs->clean_channel_5g;
-	}
-#else
-	return (u8)p_acs->clean_channel_2g;
-#endif
-
-}
-
-void
-odm_auto_channel_select_init(
-	void			*p_dm_void
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ACS_						*p_acs = &p_dm->dm_acs;
-	u8						i;
-
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR))
-		return;
-
-	if (p_acs->is_force_acs_result)
-		return;
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("%s ======>\n", __func__));
-
-	p_acs->clean_channel_2g = 1;
-	p_acs->clean_channel_5g = 36;
-
-	for (i = 0; i < ODM_MAX_CHANNEL_2G; ++i) {
-		p_acs->channel_info_2g[0][i] = 0;
-		p_acs->channel_info_2g[1][i] = 0;
-	}
-
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		for (i = 0; i < ODM_MAX_CHANNEL_5G; ++i) {
-			p_acs->channel_info_5g[0][i] = 0;
-			p_acs->channel_info_5g[1][i] = 0;
-		}
-	}
-#endif
-}
-
-void
-odm_auto_channel_select_reset(
-	void			*p_dm_void
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ACS_						*p_acs = &p_dm->dm_acs;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
-
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR))
-		return;
-
-	if (p_acs->is_force_acs_result)
-		return;
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("%s ======>\n", __func__));
-
-	ccx_info->nhm_period = 0x1388;	/*20ms*/
-	phydm_nhm_setting(p_dm, SET_NHM_SETTING);
-	phydm_nhm_trigger(p_dm);
-#endif
-}
-
-void
-odm_auto_channel_select(
-	void			*p_dm_void,
-	u8			channel
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ACS_						*p_acs = &p_dm->dm_acs;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
-	u8						channel_idx = 0, search_idx = 0;
-	u8						noisy_nhm_th = 0x52;
-	u8						i, noisy_nhm_th_index, low_pwr_cnt = 0;
-	u16						max_score = 0;
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("%s ======>\n", __func__));
-
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR)) {
-		PHYDM_DBG(p_dm, DBG_DIG, ("Return: Not support\n"));
-		return;
-	}
-
-	if (p_acs->is_force_acs_result) {
-		PHYDM_DBG(p_dm, DBG_DIG, ("Force clean CH{2G,5G}={%d,%d}\n",
-			p_acs->clean_channel_2g, p_acs->clean_channel_5g));
-		return;
-	}
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("CH=%d\n", channel));
-
-	phydm_get_nhm_result(p_dm);
-	noisy_nhm_th_index = (noisy_nhm_th - ccx_info->nhm_th[0]) << 2;
-
-	for (i = 0; i <= 11; i++) {
-		if (i <= noisy_nhm_th_index)
-			low_pwr_cnt += ccx_info->nhm_result[i];
-	}
-
-	ccx_info->nhm_period = 0x2710;
-	phydm_nhm_setting(p_dm, SET_NHM_SETTING);
-
-	if (channel >= 1 && channel <= 14) {
-		channel_idx = channel - 1;
-		p_acs->channel_info_2g[1][channel_idx]++;
-
-		if (p_acs->channel_info_2g[1][channel_idx] >= 2)
-			p_acs->channel_info_2g[0][channel_idx] = (p_acs->channel_info_2g[0][channel_idx] >> 1) +
-				(p_acs->channel_info_2g[0][channel_idx] >> 2) + (low_pwr_cnt >> 2);
-		else
-			p_acs->channel_info_2g[0][channel_idx] = low_pwr_cnt;
-
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("low_pwr_cnt = %d\n", low_pwr_cnt));
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("CH_Info[0][%d]=%d, CH_Info[1][%d]=%d\n", channel_idx, p_acs->channel_info_2g[0][channel_idx], channel_idx, p_acs->channel_info_2g[1][channel_idx]));
-
-		for (search_idx = 0; search_idx < ODM_MAX_CHANNEL_2G; search_idx++) {
-			if (p_acs->channel_info_2g[1][search_idx] != 0 && p_acs->channel_info_2g[0][search_idx] >= max_score) {
-				max_score = p_acs->channel_info_2g[0][search_idx];
-				p_acs->clean_channel_2g = search_idx + 1;
-			}
-		}
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("clean_CH_2g=%d, max_score=%d\n",
-				p_acs->clean_channel_2g, max_score));
-
-	} else if (channel >= 36) {
-		/* Need to do */
-		p_acs->clean_channel_5g = channel;
-	}
-#endif
-}
-
-boolean
-phydm_acs_check(
-	void	*p_dm_void
-)
-{
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct rtl8192cd_priv		*priv = p_dm->priv;
-
-	if ((priv->auto_channel != 0) && (priv->auto_channel != 2)) /* if struct _ACS_ running, do not do FA/CCA counter read */
-		return true;
-	else
-		return false;
-#else
-	return false;
-#endif
-}
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-void
-phydm_auto_channel_select_setting_ap(
-	void   *p_dm_void,
-	u32  setting,             /* 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING */
-	u32  acs_step
-)
-{
-	struct PHY_DM_STRUCT           *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct rtl8192cd_priv       *priv           = p_dm->priv;
-	struct _ACS_                    *p_acs         = &p_dm->dm_acs;
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("%s ======>\n", __func__));
-
-	/* 3 Store Default setting */
-	if (setting == STORE_DEFAULT_NHM_SETTING) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("STORE_DEFAULT_NHM_SETTING\n"));
-
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {  /* store reg0x990, reg0x994, reg0x998, reg0x99c, Reg0x9a0 */
-			p_acs->reg0x990 = odm_read_4byte(p_dm, ODM_REG_CCX_PERIOD_11AC);                /* reg0x990 */
-			p_acs->reg0x994 = odm_read_4byte(p_dm, ODM_REG_NHM_TH9_TH10_11AC);           /* reg0x994 */
-			p_acs->reg0x998 = odm_read_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC);       /* reg0x998 */
-			p_acs->reg0x99c = odm_read_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC);       /* Reg0x99c */
-			p_acs->reg0x9a0 = odm_read_1byte(p_dm, ODM_REG_NHM_TH8_11AC);                   /* Reg0x9a0, u8 */
-		} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-			p_acs->reg0x890 = odm_read_4byte(p_dm, ODM_REG_NHM_TH9_TH10_11N);             /* reg0x890 */
-			p_acs->reg0x894 = odm_read_4byte(p_dm, ODM_REG_CCX_PERIOD_11N);                  /* reg0x894 */
-			p_acs->reg0x898 = odm_read_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N);         /* reg0x898 */
-			p_acs->reg0x89c = odm_read_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N);         /* Reg0x89c */
-			p_acs->reg0xe28 = odm_read_1byte(p_dm, ODM_REG_NHM_TH8_11N);                     /* Reg0xe28, u8 */
-		}
-	}
-
-	/* 3 Restore Default setting */
-	else if (setting == RESTORE_DEFAULT_NHM_SETTING) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("RESTORE_DEFAULT_NHM_SETTING\n"));
-
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {  /* store reg0x990, reg0x994, reg0x998, reg0x99c, Reg0x9a0 */
-			odm_write_4byte(p_dm, ODM_REG_CCX_PERIOD_11AC,          p_acs->reg0x990);
-			odm_write_4byte(p_dm, ODM_REG_NHM_TH9_TH10_11AC,     p_acs->reg0x994);
-			odm_write_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, p_acs->reg0x998);
-			odm_write_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, p_acs->reg0x99c);
-			odm_write_1byte(p_dm, ODM_REG_NHM_TH8_11AC,             p_acs->reg0x9a0);
-		} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-			odm_write_4byte(p_dm, ODM_REG_NHM_TH9_TH10_11N,     p_acs->reg0x890);
-			odm_write_4byte(p_dm, ODM_REG_CCX_PERIOD_11AC,          p_acs->reg0x894);
-			odm_write_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, p_acs->reg0x898);
-			odm_write_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, p_acs->reg0x89c);
-			odm_write_1byte(p_dm, ODM_REG_NHM_TH8_11N,             p_acs->reg0xe28);
-		}
-	}
-
-	/* 3 struct _ACS_ setting */
-	else if (setting == ACS_NHM_SETTING) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("ACS_NHM_SETTING\n"));
-		u16  period;
-		period = 0x61a8;
-		p_acs->acs_step = acs_step;
-
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-			/* 4 Set NHM period, 0x990[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms */
-			odm_write_2byte(p_dm, ODM_REG_CCX_PERIOD_11AC + 2, period);
-			/* 4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0 */
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(8) | BIT(9) | BIT(10), 3);
-
-			if (p_acs->acs_step == 0) {
-				/* 4 Set IGI */
-				odm_set_bb_reg(p_dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
-				if (get_rf_mimo_mode(priv) != RF_1T1R)
-					odm_set_bb_reg(p_dm, 0xe50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
-
-				/* 4 Set struct _ACS_ NHM threshold */
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x82786e64);
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff8c);
-				odm_write_1byte(p_dm, ODM_REG_NHM_TH8_11AC, 0xff);
-				odm_write_2byte(p_dm, ODM_REG_NHM_TH9_TH10_11AC + 2, 0xffff);
-
-			} else if (p_acs->acs_step == 1) {
-				/* 4 Set IGI */
-				odm_set_bb_reg(p_dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
-				if (get_rf_mimo_mode(priv) != RF_1T1R)
-					odm_set_bb_reg(p_dm, 0xe50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
-
-				/* 4 Set struct _ACS_ NHM threshold */
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, 0x5a50463c);
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, 0xffffff64);
-
-			}
-
-		} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-			/* 4 Set NHM period, 0x894[31:16]=0x61a8, Time duration for NHM unit: 4us, 0x61a8=100ms */
-			odm_write_2byte(p_dm, ODM_REG_CCX_PERIOD_11AC + 2, period);
-			/* 4 Set NHM ignore_cca=1, ignore_txon=1, ccx_en=0 */
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(8) | BIT(9) | BIT(10), 3);
-
-			if (p_acs->acs_step == 0) {
-				/* 4 Set IGI */
-				odm_set_bb_reg(p_dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
-				if (get_rf_mimo_mode(priv) != RF_1T1R)
-					odm_set_bb_reg(p_dm, 0xc58, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x3E);
-
-				/* 4 Set struct _ACS_ NHM threshold */
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x82786e64);
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff8c);
-				odm_write_1byte(p_dm, ODM_REG_NHM_TH8_11N, 0xff);
-				odm_write_2byte(p_dm, ODM_REG_NHM_TH9_TH10_11N + 2, 0xffff);
-
-			} else if (p_acs->acs_step == 1) {
-				/* 4 Set IGI */
-				odm_set_bb_reg(p_dm, 0xc50, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
-				if (get_rf_mimo_mode(priv) != RF_1T1R)
-					odm_set_bb_reg(p_dm, 0xc58, BIT(0) | BIT(1) | BIT(2) | BIT(3) | BIT(4) | BIT(5) | BIT(6), 0x2A);
-
-				/* 4 Set struct _ACS_ NHM threshold */
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, 0x5a50463c);
-				odm_write_4byte(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, 0xffffff64);
-
-			}
-		}
-	}
-
-}
-
-void
-phydm_get_nhm_statistics_ap(
-	void       *p_dm_void,
-	u32      idx,                /* @ 2G, Real channel number = idx+1 */
-	u32      acs_step
-)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct rtl8192cd_priv     *priv    = p_dm->priv;
-	struct _ACS_                  *p_acs    = &p_dm->dm_acs;
-	u32                value32 = 0;
-	u8                i;
-
-	p_acs->acs_step = acs_step;
-
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		/* 4 Check if NHM result is ready */
-		for (i = 0; i < 20; i++) {
-
-			ODM_delay_ms(1);
-			if (odm_get_bb_reg(p_dm, REG_FPGA0_PSD_REPORT, BIT(17)))
-				break;
-		}
-
-		/* 4 Get NHM Statistics */
-		if (p_acs->acs_step == 1) {
-
-			value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
-
-			p_acs->nhm_cnt[idx][9] = (value32 & MASKBYTE1) >> 8;
-			p_acs->nhm_cnt[idx][8] = (value32 & MASKBYTE0);
-
-			value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT_11N);   /* ODM_REG_NHM_CNT3_TO_CNT0_11N */
-
-			p_acs->nhm_cnt[idx][7] = (value32 & MASKBYTE3) >> 24;
-			p_acs->nhm_cnt[idx][6] = (value32 & MASKBYTE2) >> 16;
-			p_acs->nhm_cnt[idx][5] = (value32 & MASKBYTE1) >> 8;
-
-		} else if (p_acs->acs_step == 2) {
-
-			value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT_11N);  /* ODM_REG_NHM_CNT3_TO_CNT0_11N */
-
-			p_acs->nhm_cnt[idx][4] = odm_read_1byte(p_dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
-			p_acs->nhm_cnt[idx][3] = (value32 & MASKBYTE3) >> 24;
-			p_acs->nhm_cnt[idx][2] = (value32 & MASKBYTE2) >> 16;
-			p_acs->nhm_cnt[idx][1] = (value32 & MASKBYTE1) >> 8;
-			p_acs->nhm_cnt[idx][0] = (value32 & MASKBYTE0);
-		}
-	} else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		/* 4 Check if NHM result is ready */
-		for (i = 0; i < 20; i++) {
-
-			ODM_delay_ms(1);
-			if (odm_get_bb_reg(p_dm, ODM_REG_NHM_DUR_READY_11AC, BIT(16)))
-				break;
-		}
-
-		if (p_acs->acs_step == 1) {
-
-			value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
-
-			p_acs->nhm_cnt[idx][9] = (value32 & MASKBYTE1) >> 8;
-			p_acs->nhm_cnt[idx][8] = (value32 & MASKBYTE0);
-
-			value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT_11AC);    /* ODM_REG_NHM_CNT3_TO_CNT0_11AC */
-
-			p_acs->nhm_cnt[idx][7] = (value32 & MASKBYTE3) >> 24;
-			p_acs->nhm_cnt[idx][6] = (value32 & MASKBYTE2) >> 16;
-			p_acs->nhm_cnt[idx][5] = (value32 & MASKBYTE1) >> 8;
-
-		} else if (p_acs->acs_step == 2) {
-
-			value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT_11AC);     /* ODM_REG_NHM_CNT3_TO_CNT0_11AC */
-
-			p_acs->nhm_cnt[idx][4] = odm_read_1byte(p_dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
-			p_acs->nhm_cnt[idx][3] = (value32 & MASKBYTE3) >> 24;
-			p_acs->nhm_cnt[idx][2] = (value32 & MASKBYTE2) >> 16;
-			p_acs->nhm_cnt[idx][1] = (value32 & MASKBYTE1) >> 8;
-			p_acs->nhm_cnt[idx][0] = (value32 & MASKBYTE0);
-		}
-	}
-
-}
-
-
-/* #define ACS_DEBUG_INFO */ /* acs debug default off */
-#if 0
-int phydm_AutoChannelSelectAP(
-	void   *p_dm_void,
-	u32  ACS_Type,                      /*  0: RXCount_Type, 1:NHM_Type */
-	u32  available_chnl_num        /*  amount of all channels */
-)
-{
-	struct PHY_DM_STRUCT               *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ACS_                    *p_acs    = &p_dm->dm_acs;
-	struct rtl8192cd_priv			*priv    = p_dm->priv;
-
-	static u32           score2G[MAX_2G_CHANNEL_NUM], score5G[MAX_5G_CHANNEL_NUM];
-	u32                  score[MAX_BSS_NUM], use_nhm = 0;
-	u32                  minScore = 0xffffffff;
-	u32                  tmpScore, tmpIdx = 0;
-	u32                  traffic_check = 0;
-	u32                  fa_count_weighting = 1;
-	int                     i, j, idx = 0, idx_2G_end = -1, idx_5G_begin = -1, minChan = 0;
-	struct bss_desc *pBss = NULL;
-
-#ifdef _DEBUG_RTL8192CD_
-	char tmpbuf[400];
-	int len = 0;
-#endif
-
-	memset(score2G, '\0', sizeof(score2G));
-	memset(score5G, '\0', sizeof(score5G));
-
-	for (i = 0; i < priv->available_chnl_num; i++) {
-		if (priv->available_chnl[i] <= 14)
-			idx_2G_end = i;
-		else
-			break;
-	}
-
-	for (i = 0; i < priv->available_chnl_num; i++) {
-		if (priv->available_chnl[i] > 14) {
-			idx_5G_begin = i;
-			break;
-		}
-	}
-
-	/*  DELETE */
-#ifndef CONFIG_RTL_NEW_AUTOCH
-	for (i = 0; i < priv->site_survey->count; i++) {
-		pBss = &priv->site_survey->bss[i];
-		for (idx = 0; idx < priv->available_chnl_num; idx++) {
-			if (pBss->channel == priv->available_chnl[idx]) {
-				if (pBss->channel <= 14)
-					setChannelScore(idx, score2G, 0, MAX_2G_CHANNEL_NUM - 1);
-				else
-					score5G[idx - idx_5G_begin] += 5;
-				break;
-			}
-		}
-	}
-#endif
-
-	if (idx_2G_end >= 0)
-		for (i = 0; i <= idx_2G_end; i++)
-			score[i] = score2G[i];
-	if (idx_5G_begin >= 0)
-		for (i = idx_5G_begin; i < priv->available_chnl_num; i++)
-			score[i] = score5G[i - idx_5G_begin];
-
-#ifdef CONFIG_RTL_NEW_AUTOCH
-	{
-		u32 y, ch_begin = 0, ch_end = priv->available_chnl_num;
-
-		u32 do_ap_check = 1, ap_ratio = 0;
-
-		if (idx_2G_end >= 0)
-			ch_end = idx_2G_end + 1;
-		if (idx_5G_begin >= 0)
-			ch_begin = idx_5G_begin;
-
-#ifdef ACS_DEBUG_INFO/* for debug */
-		printk("\n");
-		for (y = ch_begin; y < ch_end; y++)
-			printk("1. init: chnl[%d] 20M_rx[%d] 40M_rx[%d] fa_cnt[%d] score[%d]\n",
-			       priv->available_chnl[y],
-			       priv->chnl_ss_mac_rx_count[y],
-			       priv->chnl_ss_mac_rx_count_40M[y],
-			       priv->chnl_ss_fa_count[y],
-			       score[y]);
-		printk("\n");
-#endif
-
-#if defined(CONFIG_RTL_88E_SUPPORT) || defined(CONFIG_WLAN_HAL_8192EE)
-		if (p_dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E) && priv->pmib->dot11RFEntry.acs_type) {
-			u32 tmp_score[MAX_BSS_NUM];
-			memcpy(tmp_score, score, sizeof(score));
-			if (find_clean_channel(priv, ch_begin, ch_end, tmp_score)) {
-				/* memcpy(score, tmp_score, sizeof(score)); */
-#ifdef _DEBUG_RTL8192CD_
-				printk("!! Found clean channel, select minimum FA channel\n");
-#endif
-				goto USE_CLN_CH;
-			}
-#ifdef _DEBUG_RTL8192CD_
-			printk("!! Not found clean channel, use NHM algorithm\n");
-#endif
-			use_nhm = 1;
-USE_CLN_CH:
-			for (y = ch_begin; y < ch_end; y++) {
-				for (i = 0; i <= 9; i++) {
-					u32 val32 = priv->nhm_cnt[y][i];
-					for (j = 0; j < i; j++)
-						val32 *= 3;
-					score[y] += val32;
-				}
-
-#ifdef _DEBUG_RTL8192CD_
-				printk("nhm_cnt_%d: H<-[ %3d %3d %3d %3d %3d %3d %3d %3d %3d %3d]->L, score: %d\n",
-				       y + 1, priv->nhm_cnt[y][9], priv->nhm_cnt[y][8], priv->nhm_cnt[y][7],
-				       priv->nhm_cnt[y][6], priv->nhm_cnt[y][5], priv->nhm_cnt[y][4],
-				       priv->nhm_cnt[y][3], priv->nhm_cnt[y][2], priv->nhm_cnt[y][1],
-				       priv->nhm_cnt[y][0], score[y]);
-#endif
-			}
-
-			if (!use_nhm)
-				memcpy(score, tmp_score, sizeof(score));
-
-			goto choose_ch;
-		}
-#endif
-
-		/*  For each channel, weighting behind channels with MAC RX counter */
-		/* For each channel, weighting the channel with FA counter */
-
-		for (y = ch_begin; y < ch_end; y++) {
-			score[y] += 8 * priv->chnl_ss_mac_rx_count[y];
-			if (priv->chnl_ss_mac_rx_count[y] > 30)
-				do_ap_check = 0;
-			if (priv->chnl_ss_mac_rx_count[y] > MAC_RX_COUNT_THRESHOLD)
-				traffic_check = 1;
-
-#ifdef RTK_5G_SUPPORT
-			if (*p_dm->p_band_type == ODM_BAND_2_4G)
-#endif
-			{
-				if ((int)(y - 4) >= (int)ch_begin)
-					score[y - 4] += 2 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y - 3) >= (int)ch_begin)
-					score[y - 3] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y - 2) >= (int)ch_begin)
-					score[y - 2] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y - 1) >= (int)ch_begin)
-					score[y - 1] += 10 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y + 1) < (int)ch_end)
-					score[y + 1] += 10 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y + 2) < (int)ch_end)
-					score[y + 2] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y + 3) < (int)ch_end)
-					score[y + 3] += 8 * priv->chnl_ss_mac_rx_count[y];
-				if ((int)(y + 4) < (int)ch_end)
-					score[y + 4] += 2 * priv->chnl_ss_mac_rx_count[y];
-			}
-
-			/* this is for CH_LOAD caculation */
-			if (priv->chnl_ss_cca_count[y] > priv->chnl_ss_fa_count[y])
-				priv->chnl_ss_cca_count[y] -= priv->chnl_ss_fa_count[y];
-			else
-				priv->chnl_ss_cca_count[y] = 0;
-		}
-
-#ifdef ACS_DEBUG_INFO/* for debug */
-		printk("\n");
-		for (y = ch_begin; y < ch_end; y++)
-			printk("2. after 20M check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
-		printk("\n");
-#endif
-
-		for (y = ch_begin; y < ch_end; y++) {
-			if (priv->chnl_ss_mac_rx_count_40M[y]) {
-				score[y] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-				if (priv->chnl_ss_mac_rx_count_40M[y] > 30)
-					do_ap_check = 0;
-				if (priv->chnl_ss_mac_rx_count_40M[y] > MAC_RX_COUNT_THRESHOLD)
-					traffic_check = 1;
-
-#ifdef RTK_5G_SUPPORT
-				if (*p_dm->p_band_type == ODM_BAND_2_4G)
-#endif
-				{
-					if ((int)(y - 6) >= (int)ch_begin)
-						score[y - 6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y - 5) >= (int)ch_begin)
-						score[y - 5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y - 4) >= (int)ch_begin)
-						score[y - 4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y - 3) >= (int)ch_begin)
-						score[y - 3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y - 2) >= (int)ch_begin)
-						score[y - 2] += (5 * priv->chnl_ss_mac_rx_count_40M[y]) / 2;
-					if ((int)(y - 1) >= (int)ch_begin)
-						score[y - 1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y + 1) < (int)ch_end)
-						score[y + 1] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y + 2) < (int)ch_end)
-						score[y + 2] += (5 * priv->chnl_ss_mac_rx_count_40M[y]) / 2;
-					if ((int)(y + 3) < (int)ch_end)
-						score[y + 3] += 5 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y + 4) < (int)ch_end)
-						score[y + 4] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y + 5) < (int)ch_end)
-						score[y + 5] += 4 * priv->chnl_ss_mac_rx_count_40M[y];
-					if ((int)(y + 6) < (int)ch_end)
-						score[y + 6] += 1 * priv->chnl_ss_mac_rx_count_40M[y];
-				}
-			}
-		}
-
-#ifdef ACS_DEBUG_INFO/* for debug */
-		printk("\n");
-		for (y = ch_begin; y < ch_end; y++)
-			printk("3. after 40M check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
-		printk("\n");
-		printk("4. do_ap_check=%d traffic_check=%d\n", do_ap_check, traffic_check);
-		printk("\n");
-#endif
-
-		if (traffic_check == 0)
-			fa_count_weighting = 5;
-		else
-			fa_count_weighting = 1;
-
-		for (y = ch_begin; y < ch_end; y++)
-			score[y] += fa_count_weighting * priv->chnl_ss_fa_count[y];
-
-#ifdef ACS_DEBUG_INFO/* for debug */
-		printk("\n");
-		for (y = ch_begin; y < ch_end; y++)
-			printk("5. after fa check: chnl[%d] score[%d]\n", priv->available_chnl[y], score[y]);
-		printk("\n");
-#endif
-
-		if (do_ap_check) {
-			for (i = 0; i < priv->site_survey->count; i++) {
-				pBss = &priv->site_survey->bss[i];
-				for (y = ch_begin; y < ch_end; y++) {
-					if (pBss->channel == priv->available_chnl[y]) {
-						if (pBss->channel <= 14) {
-#ifdef ACS_DEBUG_INFO/* for debug */
-							printk("\n");
-							printk("chnl[%d] has ap rssi=%d bw[0x%02x]\n",
-							       pBss->channel, pBss->rssi, pBss->t_stamp[1]);
-							printk("\n");
-#endif
-							if (pBss->rssi > 60)
-								ap_ratio = 4;
-							else if (pBss->rssi > 35)
-								ap_ratio = 2;
-							else
-								ap_ratio = 1;
-
-							if ((pBss->t_stamp[1] & 0x6) == 0) {
-								score[y] += 50 * ap_ratio;
-								if ((int)(y - 4) >= (int)ch_begin)
-									score[y - 4] += 10 * ap_ratio;
-								if ((int)(y - 3) >= (int)ch_begin)
-									score[y - 3] += 20 * ap_ratio;
-								if ((int)(y - 2) >= (int)ch_begin)
-									score[y - 2] += 30 * ap_ratio;
-								if ((int)(y - 1) >= (int)ch_begin)
-									score[y - 1] += 40 * ap_ratio;
-								if ((int)(y + 1) < (int)ch_end)
-									score[y + 1] += 40 * ap_ratio;
-								if ((int)(y + 2) < (int)ch_end)
-									score[y + 2] += 30 * ap_ratio;
-								if ((int)(y + 3) < (int)ch_end)
-									score[y + 3] += 20 * ap_ratio;
-								if ((int)(y + 4) < (int)ch_end)
-									score[y + 4] += 10 * ap_ratio;
-							} else if ((pBss->t_stamp[1] & 0x4) == 0) {
-								score[y] += 50 * ap_ratio;
-								if ((int)(y - 3) >= (int)ch_begin)
-									score[y - 3] += 20 * ap_ratio;
-								if ((int)(y - 2) >= (int)ch_begin)
-									score[y - 2] += 30 * ap_ratio;
-								if ((int)(y - 1) >= (int)ch_begin)
-									score[y - 1] += 40 * ap_ratio;
-								if ((int)(y + 1) < (int)ch_end)
-									score[y + 1] += 50 * ap_ratio;
-								if ((int)(y + 2) < (int)ch_end)
-									score[y + 2] += 50 * ap_ratio;
-								if ((int)(y + 3) < (int)ch_end)
-									score[y + 3] += 50 * ap_ratio;
-								if ((int)(y + 4) < (int)ch_end)
-									score[y + 4] += 50 * ap_ratio;
-								if ((int)(y + 5) < (int)ch_end)
-									score[y + 5] += 40 * ap_ratio;
-								if ((int)(y + 6) < (int)ch_end)
-									score[y + 6] += 30 * ap_ratio;
-								if ((int)(y + 7) < (int)ch_end)
-									score[y + 7] += 20 * ap_ratio;
-							} else {
-								score[y] += 50 * ap_ratio;
-								if ((int)(y - 7) >= (int)ch_begin)
-									score[y - 7] += 20 * ap_ratio;
-								if ((int)(y - 6) >= (int)ch_begin)
-									score[y - 6] += 30 * ap_ratio;
-								if ((int)(y - 5) >= (int)ch_begin)
-									score[y - 5] += 40 * ap_ratio;
-								if ((int)(y - 4) >= (int)ch_begin)
-									score[y - 4] += 50 * ap_ratio;
-								if ((int)(y - 3) >= (int)ch_begin)
-									score[y - 3] += 50 * ap_ratio;
-								if ((int)(y - 2) >= (int)ch_begin)
-									score[y - 2] += 50 * ap_ratio;
-								if ((int)(y - 1) >= (int)ch_begin)
-									score[y - 1] += 50 * ap_ratio;
-								if ((int)(y + 1) < (int)ch_end)
-									score[y + 1] += 40 * ap_ratio;
-								if ((int)(y + 2) < (int)ch_end)
-									score[y + 2] += 30 * ap_ratio;
-								if ((int)(y + 3) < (int)ch_end)
-									score[y + 3] += 20 * ap_ratio;
-							}
-						} else {
-							if ((pBss->t_stamp[1] & 0x6) == 0)
-								score[y] += 500;
-							else if ((pBss->t_stamp[1] & 0x4) == 0) {
-								score[y] += 500;
-								if ((int)(y + 1) < (int)ch_end)
-									score[y + 1] += 500;
-							} else {
-								score[y] += 500;
-								if ((int)(y - 1) >= (int)ch_begin)
-									score[y - 1] += 500;
-							}
-						}
-						break;
-					}
-				}
-			}
-		}
-
-#ifdef ACS_DEBUG_INFO/* for debug */
-		printk("\n");
-		for (y = ch_begin; y < ch_end; y++)
-			printk("6. after ap check: chnl[%d]:%d\n", priv->available_chnl[y], score[y]);
-		printk("\n");
-#endif
-
-#ifdef SS_CH_LOAD_PROC
-
-		/*  caculate noise level -- suggested by wilson */
-		for (y = ch_begin; y < ch_end; y++)  {
-			int fa_lv = 0, cca_lv = 0;
-			if (priv->chnl_ss_fa_count[y] > 1000)
-				fa_lv = 100;
-			else if (priv->chnl_ss_fa_count[y] > 500)
-				fa_lv = 34 * (priv->chnl_ss_fa_count[y] - 500) / 500 + 66;
-			else if (priv->chnl_ss_fa_count[y] > 200)
-				fa_lv = 33 * (priv->chnl_ss_fa_count[y] - 200) / 300 + 33;
-			else if (priv->chnl_ss_fa_count[y] > 100)
-				fa_lv = 18 * (priv->chnl_ss_fa_count[y] - 100) / 100 + 15;
-			else
-				fa_lv = 15 * priv->chnl_ss_fa_count[y] / 100;
-			if (priv->chnl_ss_cca_count[y] > 400)
-				cca_lv = 100;
-			else if (priv->chnl_ss_cca_count[y] > 200)
-				cca_lv = 34 * (priv->chnl_ss_cca_count[y] - 200) / 200 + 66;
-			else if (priv->chnl_ss_cca_count[y] > 80)
-				cca_lv = 33 * (priv->chnl_ss_cca_count[y] - 80) / 120 + 33;
-			else if (priv->chnl_ss_cca_count[y] > 40)
-				cca_lv = 18 * (priv->chnl_ss_cca_count[y] - 40) / 40 + 15;
-			else
-				cca_lv = 15 * priv->chnl_ss_cca_count[y] / 40;
-
-			priv->chnl_ss_load[y] = (((fa_lv > cca_lv) ? fa_lv : cca_lv) * 75 + ((score[y] > 100) ? 100 : score[y]) * 25) / 100;
-
-			DEBUG_INFO("ch:%d f=%d (%d), c=%d (%d), fl=%d, cl=%d, sc=%d, cu=%d\n",
-				   priv->available_chnl[y],
-				   priv->chnl_ss_fa_count[y], fa_thd,
-				   priv->chnl_ss_cca_count[y], cca_thd,
-				   fa_lv,
-				   cca_lv,
-				   score[y],
-				   priv->chnl_ss_load[y]);
-
-		}
-#endif
-	}
-#endif
-
-choose_ch:
-
-#ifdef DFS
-	/*  heavy weighted DFS channel */
-	if (idx_5G_begin >= 0) {
-		for (i = idx_5G_begin; i < priv->available_chnl_num; i++) {
-			if (!priv->pmib->dot11DFSEntry.disable_DFS && is_DFS_channel(priv->available_chnl[i])
-			    && (score[i] != 0xffffffff))
-				score[i] += 1600;
-		}
-	}
-#endif
-
-
-	/* prevent Auto channel selecting wrong channel in 40M mode----------------- */
-	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
-	    && priv->pshare->is_40m_bw) {
-#if 0
-		if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 1) {
-			/* Upper Primary channel, cannot select the two lowest channels */
-			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
-				score[0] = 0xffffffff;
-				score[1] = 0xffffffff;
-				score[2] = 0xffffffff;
-				score[3] = 0xffffffff;
-				score[4] = 0xffffffff;
-
-				score[13] = 0xffffffff;
-				score[12] = 0xffffffff;
-				score[11] = 0xffffffff;
-			}
-
-			/*			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) { */
-			/*				score[idx_5G_begin] = 0xffffffff; */
-			/*				score[idx_5G_begin + 1] = 0xffffffff; */
-			/*			} */
-		} else if (GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset == 2) {
-			/* Lower Primary channel, cannot select the two highest channels */
-			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11G) {
-				score[0] = 0xffffffff;
-				score[1] = 0xffffffff;
-				score[2] = 0xffffffff;
-
-				score[13] = 0xffffffff;
-				score[12] = 0xffffffff;
-				score[11] = 0xffffffff;
-				score[10] = 0xffffffff;
-				score[9] = 0xffffffff;
-			}
-
-			/*			if (priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) { */
-			/*				score[priv->available_chnl_num - 2] = 0xffffffff; */
-			/*				score[priv->available_chnl_num - 1] = 0xffffffff; */
-			/*			} */
-		}
-#endif
-		for (i = 0; i <= idx_2G_end; ++i)
-			if (priv->available_chnl[i] == 14)
-				score[i] = 0xffffffff;		/*  mask chan14 */
-
-#ifdef RTK_5G_SUPPORT
-		if (idx_5G_begin >= 0) {
-			for (i = idx_5G_begin; i < priv->available_chnl_num; i++) {
-				int ch = priv->available_chnl[i];
-				if (priv->available_chnl[i] > 144)
-					--ch;
-				if ((ch % 4) || ch == 140 || ch == 164)	/* mask ch 140, ch 165, ch 184... */
-					score[i] = 0xffffffff;
-			}
-		}
-#endif
-
-
-	}
-
-	if (priv->pmib->dot11RFEntry.disable_ch1213) {
-		for (i = 0; i <= idx_2G_end; ++i) {
-			int ch = priv->available_chnl[i];
-			if ((ch == 12) || (ch == 13))
-				score[i] = 0xffffffff;
-		}
-	}
-
-	if (((priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_GLOBAL) ||
-	     (priv->pmib->dot11StationConfigEntry.dot11RegDomain == DOMAIN_WORLD_WIDE)) &&
-	    (idx_2G_end >= 11) && (idx_2G_end < 14)) {
-		score[13] = 0xffffffff;	/*  mask chan14 */
-		score[12] = 0xffffffff; /*  mask chan13 */
-		score[11] = 0xffffffff; /*  mask chan12 */
-	}
-
-	/* ------------------------------------------------------------------ */
-
-#ifdef _DEBUG_RTL8192CD_
-	for (i = 0; i < priv->available_chnl_num; i++)
-		len += sprintf(tmpbuf + len, "ch%d:%u ", priv->available_chnl[i], score[i]);
-	strcat(tmpbuf, "\n");
-	panic_printk("%s", tmpbuf);
-
-#endif
-
-	if ((*p_dm->p_band_type == ODM_BAND_5G)
-	    && (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80)) {
-		for (i = 0; i < priv->available_chnl_num; i++) {
-			if (is80MChannel(priv->available_chnl, priv->available_chnl_num, priv->available_chnl[i])) {
-				tmpScore = 0;
-				for (j = 0; j < 4; j++) {
-					if ((tmpScore != 0xffffffff) && (score[i + j] != 0xffffffff))
-						tmpScore += score[i + j];
-					else
-						tmpScore = 0xffffffff;
-				}
-				tmpScore = tmpScore / 4;
-				if (minScore > tmpScore) {
-					minScore = tmpScore;
-
-					tmpScore = 0xffffffff;
-					for (j = 0; j < 4; j++) {
-						if (score[i + j] < tmpScore) {
-							tmpScore = score[i + j];
-							tmpIdx = i + j;
-						}
-					}
-
-					idx = tmpIdx;
-				}
-				i += 3;
-			}
-		}
-		if (minScore == 0xffffffff) {
-			/*  there is no 80M channels */
-			priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
-			for (i = 0; i < priv->available_chnl_num; i++) {
-				if (score[i] < minScore) {
-					minScore = score[i];
-					idx = i;
-				}
-			}
-		}
-	} else if ((*p_dm->p_band_type == ODM_BAND_5G)
-		&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40)) {
-		for (i = 0; i < priv->available_chnl_num; i++) {
-			if (is40MChannel(priv->available_chnl, priv->available_chnl_num, priv->available_chnl[i])) {
-				tmpScore = 0;
-				for (j = 0; j < 2; j++) {
-					if ((tmpScore != 0xffffffff) && (score[i + j] != 0xffffffff))
-						tmpScore += score[i + j];
-					else
-						tmpScore = 0xffffffff;
-				}
-				tmpScore = tmpScore / 2;
-				if (minScore > tmpScore) {
-					minScore = tmpScore;
-
-					tmpScore = 0xffffffff;
-					for (j = 0; j < 2; j++) {
-						if (score[i + j] < tmpScore) {
-							tmpScore = score[i + j];
-							tmpIdx = i + j;
-						}
-					}
-
-					idx = tmpIdx;
-				}
-				i += 1;
-			}
-		}
-		if (minScore == 0xffffffff) {
-			/*  there is no 40M channels */
-			priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
-			for (i = 0; i < priv->available_chnl_num; i++) {
-				if (score[i] < minScore) {
-					minScore = score[i];
-					idx = i;
-				}
-			}
-		}
-	} else if ((*p_dm->p_band_type == ODM_BAND_2_4G)
-		&& (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40)
-		   && (priv->available_chnl_num >= 8)) {
-		u32 groupScore[14];
-
-		memset(groupScore, 0xff, sizeof(groupScore));
-		for (i = 0; i < priv->available_chnl_num - 4; i++) {
-			if (score[i] != 0xffffffff && score[i + 4] != 0xffffffff) {
-				groupScore[i] = score[i] + score[i + 4];
-				DEBUG_INFO("groupScore, ch %d,%d: %d\n", i + 1, i + 5, groupScore[i]);
-				if (groupScore[i] < minScore) {
-#ifdef AUTOCH_SS_SPEEDUP
-					if (priv->pmib->miscEntry.autoch_1611_enable) {
-						if (priv->available_chnl[i] == 1 || priv->available_chnl[i] == 6 || priv->available_chnl[i] == 11) {
-							minScore = groupScore[i];
-							idx = i;
-						}
-					} else
-#endif
-					{
-						minScore = groupScore[i];
-						idx = i;
-					}
-				}
-			}
-		}
-
-		if (score[idx] < score[idx + 4]) {
-			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
-		} else {
-			idx = idx + 4;
-			GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-			priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
-		}
-	} else {
-		for (i = 0; i < priv->available_chnl_num; i++) {
-			if (score[i] < minScore) {
-#ifdef AUTOCH_SS_SPEEDUP
-				if (priv->pmib->miscEntry.autoch_1611_enable) {
-					if (priv->available_chnl[i] == 1 || priv->available_chnl[i] == 6 || priv->available_chnl[i] == 11) {
-						minScore = score[i];
-						idx = i;
-					}
-				} else
-#endif
-				{
-					minScore = score[i];
-					idx = i;
-				}
-			}
-		}
-	}
-
-	if (IS_A_CUT_8881A(priv) &&
-	    (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80)) {
-		if ((priv->available_chnl[idx] == 36) ||
-		    (priv->available_chnl[idx] == 52) ||
-		    (priv->available_chnl[idx] == 100) ||
-		    (priv->available_chnl[idx] == 116) ||
-		    (priv->available_chnl[idx] == 132) ||
-		    (priv->available_chnl[idx] == 149) ||
-		    (priv->available_chnl[idx] == 165))
-			idx++;
-		else if ((priv->available_chnl[idx] == 48) ||
-			 (priv->available_chnl[idx] == 64) ||
-			 (priv->available_chnl[idx] == 112) ||
-			 (priv->available_chnl[idx] == 128) ||
-			 (priv->available_chnl[idx] == 144) ||
-			 (priv->available_chnl[idx] == 161) ||
-			 (priv->available_chnl[idx] == 177))
-			idx--;
-	}
-
-	minChan = priv->available_chnl[idx];
-
-	/*  skip channel 14 if don't support ofdm */
-	if ((priv->pmib->dot11RFEntry.disable_ch14_ofdm) &&
-	    (minChan == 14)) {
-		score[idx] = 0xffffffff;
-
-		minScore = 0xffffffff;
-		for (i = 0; i < priv->available_chnl_num; i++) {
-			if (score[i] < minScore) {
-				minScore = score[i];
-				idx = i;
-			}
-		}
-		minChan = priv->available_chnl[idx];
-	}
-
-#if 0
-	/* Check if selected channel available for 80M/40M BW or NOT ? */
-	if (*p_dm->p_band_type == ODM_BAND_5G) {
-		if (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_80) {
-			if (!is80MChannel(priv->available_chnl, priv->available_chnl_num, minChan)) {
-
-				/* priv->pmib->dot11n_config_entry.dot11nUse40M = CHANNEL_WIDTH_40; */
-				priv->pshare->is_40m_bw = CHANNEL_WIDTH_40;
-			}
-		}
-
-		if (priv->pmib->dot11nConfigEntry.dot11nUse40M == CHANNEL_WIDTH_40) {
-			if (!is40MChannel(priv->available_chnl, priv->available_chnl_num, minChan)) {
-
-				/* priv->pmib->dot11n_config_entry.dot11nUse40M = CHANNEL_WIDTH_20; */
-				priv->pshare->is_40m_bw = CHANNEL_WIDTH_20;
-			}
-		}
-	}
-#endif
-
-#ifdef CONFIG_RTL_NEW_AUTOCH
-	RTL_W32(RXERR_RPT, RXERR_RPT_RST);
-#endif
-
-	/*  auto adjust contro-sideband */
-	if ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11N)
-	    && (priv->pshare->is_40m_bw == 1 || priv->pshare->is_40m_bw == 2)) {
-
-#ifdef RTK_5G_SUPPORT
-		if (*p_dm->p_band_type == ODM_BAND_5G) {
-			if ((minChan > 144) ? ((minChan - 1) % 8) : (minChan % 8)) {
-				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
-			} else {
-				GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-				priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
-			}
-
-		} else
-#endif
-		{
-#if 0
-#ifdef CONFIG_RTL_NEW_AUTOCH
-			unsigned int ch_max;
-
-			if (priv->available_chnl[idx_2G_end] >= 13)
-				ch_max = 13;
-			else
-				ch_max = priv->available_chnl[idx_2G_end];
-
-			if ((minChan >= 5) && (minChan <= (ch_max - 5))) {
-				if (score[minChan + 4] > score[minChan - 4]) { /*  what if some channels were cancelled? */
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
-				} else {
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
-				}
-			} else
-#endif
-			{
-				if (minChan < 5) {
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_ABOVE;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_ABOVE;
-				} else if (minChan > 7) {
-					GET_MIB(priv)->dot11nConfigEntry.dot11n2ndChOffset = HT_2NDCH_OFFSET_BELOW;
-					priv->pshare->offset_2nd_chan	= HT_2NDCH_OFFSET_BELOW;
-				}
-			}
-#endif
-		}
-	}
-	/* ----------------------- */
-
-#if defined(__ECOS) && defined(CONFIG_SDIO_HCI)
-	panic_printk("Auto channel choose ch:%d\n", minChan);
-#else
-#ifdef _DEBUG_RTL8192CD_
-	panic_printk("Auto channel choose ch:%d\n", minChan);
-#endif
-#endif
-#ifdef ACS_DEBUG_INFO/* for debug */
-	printk("7. minChan:%d 2nd_offset:%d\n", minChan, priv->pshare->offset_2nd_chan);
-#endif
-
-	return minChan;
-}
-#endif
-
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_acs.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_acs.h
deleted file mode 100644
index 192a24fc403a..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_acs.h
+++ /dev/null
@@ -1,105 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
- *
- * 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	__PHYDMACS_H__
-#define    __PHYDMACS_H__
-
-#define ACS_VERSION	"1.1"	/*20150729 by YuChen*/
-#define CLM_VERSION "1.0"
-
-#define ODM_MAX_CHANNEL_2G			14
-#define ODM_MAX_CHANNEL_5G			24
-
-/* For phydm_auto_channel_select_setting_ap() */
-#define STORE_DEFAULT_NHM_SETTING               0
-#define RESTORE_DEFAULT_NHM_SETTING             1
-#define ACS_NHM_SETTING                         2
-
-struct _ACS_ {
-	boolean		is_force_acs_result;
-	u8		clean_channel_2g;
-	u8		clean_channel_5g;
-	u16		channel_info_2g[2][ODM_MAX_CHANNEL_2G];		/* Channel_Info[1]: channel score, Channel_Info[2]:Channel_Scan_Times */
-	u16		channel_info_5g[2][ODM_MAX_CHANNEL_5G];
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	u8              acs_step;
-	/* NHM count 0-11 */
-	u8              nhm_cnt[14][11];
-
-	/* AC-Series, for storing previous setting */
-	u32              reg0x990;
-	u32              reg0x994;
-	u32              reg0x998;
-	u32              reg0x99c;
-	u8              reg0x9a0;   /* u8 */
-
-	/* N-Series, for storing previous setting */
-	u32              reg0x890;
-	u32              reg0x894;
-	u32              reg0x898;
-	u32              reg0x89c;
-	u8              reg0xe28;   /* u8 */
-#endif
-
-};
-
-
-void
-odm_auto_channel_select_init(
-	void			*p_dm_void
-);
-
-void
-odm_auto_channel_select_reset(
-	void			*p_dm_void
-);
-
-void
-odm_auto_channel_select(
-	void			*p_dm_void,
-	u8			channel
-);
-
-u8
-odm_get_auto_channel_select_result(
-	void			*p_dm_void,
-	u8			band
-);
-
-boolean
-phydm_acs_check(
-	void	*p_dm_void
-);
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-void
-phydm_auto_channel_select_setting_ap(
-	void   *p_dm_void,
-	u32  setting,             /* 0: STORE_DEFAULT_NHM_SETTING; 1: RESTORE_DEFAULT_NHM_SETTING, 2: ACS_NHM_SETTING */
-	u32  acs_step
-);
-
-void
-phydm_get_nhm_statistics_ap(
-	void       *p_dm_void,
-	u32      idx,                /* @ 2G, Real channel number = idx+1 */
-	u32      acs_step
-);
-
-#endif  /* #if ( DM_ODM_SUPPORT_TYPE & ODM_AP ) */
-
-#endif  /* #ifndef	__PHYDMACS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.c
index d67d21f90440..82254c62d8f0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,14 +9,24 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
@@ -24,380 +35,227 @@
 		#include "PhyDM_Adaptivity.tmh"
 	#endif
 #endif
-
-void
-phydm_dig_up_bound_lmt_en(
-	void			*p_dm_void
-)
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+boolean
+phydm_check_channel_plan(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*p_adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-
-	if (!(p_dm->support_ability & ODM_BB_ADAPTIVITY) ||
-		(p_dm->adaptivity_flag == false) ||
-		(!p_dm->is_linked) ||
-		(p_dm->adaptivity_enable == false)
-	) {
-		p_adaptivity->igi_up_bound_lmt_cnt = 0;
-		p_adaptivity->igi_lmt_en = false;	
-		return;
-	}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adapt = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	void *adapter = dm->adapter;
+	PMGNT_INFO mgnt_info = &((PADAPTER)adapter)->MgntInfo;
 
-	if (p_dm->total_tp > 1) {
-		p_adaptivity->igi_lmt_en = true;			
-		p_adaptivity->igi_up_bound_lmt_cnt = p_adaptivity->igi_up_bound_lmt_val;
-		PHYDM_DBG(p_dm, DBG_ADPTVTY,
-			("TP >1, Start limit IGI upper bound\n"));
-	} else {
-		if (p_adaptivity->igi_up_bound_lmt_cnt == 0)
-			p_adaptivity->igi_lmt_en = false;
-		else
-			p_adaptivity->igi_up_bound_lmt_cnt--;
-	}
-
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("IGI_lmt_cnt = %d\n", p_adaptivity->igi_up_bound_lmt_cnt));
-}
-
-void
-phydm_check_adaptivity(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
+	if (mgnt_info->RegEnableAdaptivity != 2)
+		return false;
 
-	if (!(p_dm->support_ability & ODM_BB_ADAPTIVITY)) {
-		p_dm->adaptivity_enable = false;
-		return;
-	}
-	
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (p_dm->ap_total_num > adaptivity->ap_num_th) {
-		p_dm->adaptivity_enable = false;
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("AP total num > %d!!, disable adaptivity\n", adaptivity->ap_num_th));
-		return;
+	if (!dm->carrier_sense_enable) { /*@check domain Code for adaptivity or CarrierSense*/
+		if ((*dm->band_type == ODM_BAND_5G) &&
+		    !(adapt->regulation_5g == REGULATION_ETSI || adapt->regulation_5g == REGULATION_WW)) {
+			PHYDM_DBG(dm, DBG_ADPTVTY,
+				  "adaptivity skip 5G domain code : %d\n",
+				  adapt->regulation_5g);
+			return true;
+		} else if ((*dm->band_type == ODM_BAND_2_4G) &&
+			   !(adapt->regulation_2g == REGULATION_ETSI || adapt->regulation_2g == REGULATION_WW)) {
+			PHYDM_DBG(dm, DBG_ADPTVTY,
+				  "adaptivity skip 2.4G domain code : %d\n",
+				  adapt->regulation_2g);
+			return true;
+		} else if ((*dm->band_type != ODM_BAND_2_4G) && (*dm->band_type != ODM_BAND_5G)) {
+			PHYDM_DBG(dm, DBG_ADPTVTY,
+				  "adaptivity neither 2G nor 5G band, return\n");
+			return true;
+		}
+	} else {
+		if ((*dm->band_type == ODM_BAND_5G) &&
+		    !(adapt->regulation_5g == REGULATION_MKK || adapt->regulation_5g == REGULATION_WW)) {
+			PHYDM_DBG(dm, DBG_ADPTVTY,
+				  "CarrierSense skip 5G domain code : %d\n",
+				  adapt->regulation_5g);
+			return true;
+		} else if ((*dm->band_type == ODM_BAND_2_4G) &&
+			   !(adapt->regulation_2g == REGULATION_MKK || adapt->regulation_2g == REGULATION_WW)) {
+			PHYDM_DBG(dm, DBG_ADPTVTY,
+				  "CarrierSense skip 2.4G domain code : %d\n",
+				  adapt->regulation_2g);
+			return true;
+		} else if ((*dm->band_type != ODM_BAND_2_4G) && (*dm->band_type != ODM_BAND_5G)) {
+			PHYDM_DBG(dm, DBG_ADPTVTY,
+				  "CarrierSense neither 2G nor 5G band, return\n");
+			return true;
+		}
 	}
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if (adaptivity->dynamic_link_adaptivity) {
-		if (p_dm->is_linked && adaptivity->is_check == false) {
-			phydm_check_environment(p_dm);
-		} else if (!p_dm->is_linked)
-			adaptivity->is_check = false;
 
-		return;
-	}
-#endif
-	
-	p_dm->adaptivity_enable = true;
+	return false;
 }
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 boolean
-phydm_check_channel_plan(
-	void			*p_dm_void
-)
+phydm_soft_ap_special_set(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER		*p_adapter	= p_dm->adapter;
-	PMGNT_INFO		p_mgnt_info = &(p_adapter->MgntInfo);
-
-	if (p_mgnt_info->RegEnableAdaptivity == 2) {
-		if (p_dm->carrier_sense_enable == false) {		/*check domain Code for adaptivity or CarrierSense*/
-			if ((*p_dm->p_band_type == ODM_BAND_5G) &&
-				!(p_dm->odm_regulation_5g == REGULATION_ETSI || p_dm->odm_regulation_5g == REGULATION_WW)) {
-				PHYDM_DBG(p_dm, DBG_ADPTVTY, ("adaptivity skip 5G domain code : %d\n", p_dm->odm_regulation_5g));
-				p_dm->adaptivity_enable = false;
-				return true;
-			} else if ((*p_dm->p_band_type == ODM_BAND_2_4G) &&
-				!(p_dm->odm_regulation_2_4g == REGULATION_ETSI || p_dm->odm_regulation_2_4g == REGULATION_WW)) {
-				PHYDM_DBG(p_dm, DBG_ADPTVTY, ("adaptivity skip 2.4G domain code : %d\n", p_dm->odm_regulation_2_4g));
-				p_dm->adaptivity_enable = false;
-				return true;
-
-			} else if ((*p_dm->p_band_type != ODM_BAND_2_4G) && (*p_dm->p_band_type != ODM_BAND_5G)) {
-				PHYDM_DBG(p_dm, DBG_ADPTVTY, ("adaptivity neither 2G nor 5G band, return\n"));
-				p_dm->adaptivity_enable = false;
-				return true;
-			}
-		} else {
-			if ((*p_dm->p_band_type == ODM_BAND_5G) &&
-				!(p_dm->odm_regulation_5g == REGULATION_MKK || p_dm->odm_regulation_5g == REGULATION_WW)) {
-				PHYDM_DBG(p_dm, DBG_ADPTVTY, ("CarrierSense skip 5G domain code : %d\n", p_dm->odm_regulation_5g));
-				p_dm->adaptivity_enable = false;
-				return true;
-			}
-
-			else if ((*p_dm->p_band_type == ODM_BAND_2_4G) &&
-				!(p_dm->odm_regulation_2_4g == REGULATION_MKK  || p_dm->odm_regulation_2_4g == REGULATION_WW)) {
-				PHYDM_DBG(p_dm, DBG_ADPTVTY, ("CarrierSense skip 2.4G domain code : %d\n", p_dm->odm_regulation_2_4g));
-				p_dm->adaptivity_enable = false;
-				return true;
-
-			} else if ((*p_dm->p_band_type != ODM_BAND_2_4G) && (*p_dm->p_band_type != ODM_BAND_5G)) {
-				PHYDM_DBG(p_dm, DBG_ADPTVTY, ("CarrierSense neither 2G nor 5G band, return\n"));
-				p_dm->adaptivity_enable = false;
-				return true;
-			}
-		}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(dm, PHYDM_ADAPTIVITY);
+	u8 disable_ap_adapt_setting = false;
+
+	if (dm->soft_ap_mode != NULL) {
+		if (*dm->soft_ap_mode != 0 &&
+		    (dm->soft_ap_special_setting & BIT(0)))
+			disable_ap_adapt_setting = true;
+		else
+			disable_ap_adapt_setting = false;
+		PHYDM_DBG(dm, DBG_ADPTVTY,
+			  "soft_ap_setting = %x, soft_ap = %d, dis_ap_adapt = %d\n",
+			  dm->soft_ap_special_setting, *dm->soft_ap_mode,
+			  disable_ap_adapt_setting);
 	}
 
-	return false;
-
+	return disable_ap_adapt_setting;
 }
 #endif
 
-void
-phydm_set_edcca_threshold(
-	void	*p_dm_void,
-	s8	H2L,
-	s8	L2H
-)
+void phydm_dig_up_bound_lmt_en(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adapt = &dm->adaptivity;
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVITY) ||
+	    !dm->is_linked ||
+	    !adapt->is_adapt_en) {
+		adapt->igi_up_bound_lmt_cnt = 0;
+		adapt->igi_lmt_en = false;
+		return;
+	}
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-		odm_set_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)((u8)L2H | (u8)H2L << 16));
-#if (RTL8195A_SUPPORT == 0)
-	else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-		odm_set_bb_reg(p_dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)((u8)L2H | (u8)H2L << 8));
-#endif
+	if (dm->total_tp > 1) {
+		adapt->igi_lmt_en = true;
+		adapt->igi_up_bound_lmt_cnt = adapt->igi_up_bound_lmt_val;
+		PHYDM_DBG(dm, DBG_ADPTVTY,
+			  "TP >1, Start limit IGI upper bound\n");
+	} else {
+		if (adapt->igi_up_bound_lmt_cnt == 0)
+			adapt->igi_lmt_en = false;
+		else
+			adapt->igi_up_bound_lmt_cnt--;
+	}
 
+	PHYDM_DBG(dm, DBG_ADPTVTY, "IGI_lmt_cnt = %d\n",
+		  adapt->igi_up_bound_lmt_cnt);
 }
 
-void
-phydm_set_lna(
-	void				*p_dm_void,
-	enum phydm_set_lna	type
-)
+void phydm_check_adaptivity(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (p_dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E)) {
-		if (type == phydm_disable_lna) {
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0x37f82);	/*disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-			if (p_dm->rf_type > RF_1T1R) {
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x1);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0x37f82);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x0);
-			}
-		} else if (type == phydm_enable_lna) {
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0x77f82);	/*back to normal*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-			if (p_dm->rf_type > RF_1T1R) {
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x1);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0x77f82);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x0);
-			}
-		}
-	} else if (p_dm->support_ic_type & ODM_RTL8723B) {
-		if (type == phydm_disable_lna) {
-			/*S0*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0001f);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xe6137);	/*disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-			/*S1*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xed, 0x00020, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x43, 0xfffff, 0x3008d);	/*select Rx mode and disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xed, 0x00020, 0x0);
-		} else if (type == phydm_enable_lna) {
-			/*S0*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0001f);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xe6177);	/*disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-			/*S1*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xed, 0x00020, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x43, 0xfffff, 0x300bd);	/*select Rx mode and disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xed, 0x00020, 0x0);
-		}
-
-	} else if (p_dm->support_ic_type & ODM_RTL8812) {
-		if (type == phydm_disable_lna) {
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-			if (p_dm->rf_type > RF_1T1R) {
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x1);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0xc22bf);	/*disable LNA*/
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x0);
-			}
-		} else if (type == phydm_enable_lna) {
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x3f7ff);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-			if (p_dm->rf_type > RF_1T1R) {
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x1);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x3f7ff);
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0xc26bf);	/*disable LNA*/
-				odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x0);
-			}
-		}
-	} else if (p_dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
-		if (type == phydm_disable_lna) {
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0002f);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xfb09b);	/*disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-		} else if (type == phydm_enable_lna) {
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*select Rx mode*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0002f);
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xfb0bb);	/*disable LNA*/
-			odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);
-		}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adapt = &dm->adaptivity;
+
+	if (!(dm->support_ability & ODM_BB_ADAPTIVITY)) {
+		adapt->is_adapt_en = false;
+		dm->th_l2h_ini = adapt->th_l2h_ini_mode2;
+		dm->th_edcca_hl_diff = adapt->th_edcca_hl_diff_mode2;
+		PHYDM_DBG(dm, DBG_ADPTVTY,
+			  "adaptivity disable, enable EDCCA mode!!!\n");
+		return;
 	}
-}
-
 
-
-void
-phydm_set_trx_mux(
-	void				*p_dm_void,
-	enum phydm_trx_mux_type	tx_mode,
-	enum phydm_trx_mux_type	rx_mode
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		odm_set_bb_reg(p_dm, ODM_REG_CCK_RPT_FORMAT_11N, BIT(3) | BIT(2) | BIT(1), tx_mode);			/*set TXmod to standby mode to remove outside noise affect*/
-		odm_set_bb_reg(p_dm, ODM_REG_CCK_RPT_FORMAT_11N, BIT(22) | BIT(21) | BIT(20), rx_mode);		/*set RXmod to standby mode to remove outside noise affect*/
-		if (p_dm->rf_type > RF_1T1R) {
-			odm_set_bb_reg(p_dm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT(3) | BIT(2) | BIT(1), tx_mode);		/*set TXmod to standby mode to remove outside noise affect*/
-			odm_set_bb_reg(p_dm, ODM_REG_CCK_RPT_FORMAT_11N_B, BIT(22) | BIT(21) | BIT(20), rx_mode);	/*set RXmod to standby mode to remove outside noise affect*/
-		}
+	adapt->is_adapt_en = true;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (phydm_check_channel_plan(dm) ||
+	    dm->ap_total_num > adapt->ap_num_th ||
+	    phydm_soft_ap_special_set(dm)) {
+		adapt->is_adapt_en = false;
+		PHYDM_DBG(dm, DBG_ADPTVTY,
+			  "AP total num > %d!!, disable adaptivity\n",
+			  adapt->ap_num_th);
 	}
-#if (RTL8195A_SUPPORT == 0)
-	else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		odm_set_bb_reg(p_dm, ODM_REG_TRMUX_11AC, BIT(11) | BIT(10) | BIT(9) | BIT(8), tx_mode);				/*set TXmod to standby mode to remove outside noise affect*/
-		odm_set_bb_reg(p_dm, ODM_REG_TRMUX_11AC, BIT(7) | BIT(6) | BIT(5) | BIT(4), rx_mode);				/*set RXmod to standby mode to remove outside noise affect*/
-		if (p_dm->rf_type > RF_1T1R) {
-			odm_set_bb_reg(p_dm, ODM_REG_TRMUX_11AC_B, BIT(11) | BIT(10) | BIT(9) | BIT(8), tx_mode);		/*set TXmod to standby mode to remove outside noise affect*/
-			odm_set_bb_reg(p_dm, ODM_REG_TRMUX_11AC_B, BIT(7) | BIT(6) | BIT(5) | BIT(4), rx_mode);			/*set RXmod to standby mode to remove outside noise affect*/
-		}
+	if (!adapt->is_adapt_en) {
+		dm->th_l2h_ini = adapt->th_l2h_ini_mode2;
+		dm->th_edcca_hl_diff = adapt->th_edcca_hl_diff_mode2;
+	} else {
+		dm->th_l2h_ini = adapt->th_l2h_ini_backup;
+		dm->th_edcca_hl_diff = adapt->th_edcca_hl_diff_backup;
 	}
 #endif
-
 }
 
-void
-phydm_mac_edcca_state(
-	void					*p_dm_void,
-	enum phydm_mac_edcca_type		state
-)
+void phydm_set_edcca_threshold(void *dm_void, s8 H2L, s8 L2H)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	if (state == phydm_ignore_edcca) {
-		odm_set_mac_reg(p_dm, REG_TX_PTCL_CTRL, BIT(15), 1);	/*ignore EDCCA	reg520[15]=1*/
-		/*		odm_set_mac_reg(p_dm, REG_RD_CTRL, BIT(11), 0);			*/ /*reg524[11]=0*/
-	} else {	/*don't set MAC ignore EDCCA signal*/
-		odm_set_mac_reg(p_dm, REG_TX_PTCL_CTRL, BIT(15), 0);	/*don't ignore EDCCA	 reg520[15]=0*/
-		/*		odm_set_mac_reg(p_dm, REG_RD_CTRL, BIT(11), 1);			*/ /*reg524[11]=1	*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		odm_set_bb_reg(dm, R_0x84c, MASKBYTE2, (u8)L2H + 0x80);
+		odm_set_bb_reg(dm, R_0x84c, MASKBYTE3, (u8)H2L + 0x80);
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0xc4c, MASKBYTE0, (u8)L2H);
+		odm_set_bb_reg(dm, R_0xc4c, MASKBYTE2, (u8)H2L);
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x8a4, MASKBYTE0, (u8)L2H);
+		odm_set_bb_reg(dm, R_0x8a4, MASKBYTE1, (u8)H2L);
 	}
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("EDCCA enable state = %d\n", state));
-
 }
 
-void
-phydm_check_environment(
-	void	*p_dm_void
-)
+void phydm_mac_edcca_state(void *dm_void, enum phydm_mac_edcca_type state)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	boolean	is_clean_environment = false;
-
-	is_clean_environment = phydm_cal_nhm_cnt(p_dm);
-
-	if (is_clean_environment == true) {
-		p_dm->th_l2h_ini = adaptivity->th_l2h_ini_backup;			/*adaptivity mode*/
-		p_dm->th_edcca_hl_diff = adaptivity->th_edcca_hl_diff_backup;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-		p_dm->adaptivity_enable = true;
-	} else {
-		p_dm->th_l2h_ini = p_dm->th_l2h_ini_mode2;			/*mode2*/
-		p_dm->th_edcca_hl_diff = p_dm->th_edcca_hl_diff_mode2;
-
-		p_dm->adaptivity_enable = false;
+	if (state == PHYDM_IGNORE_EDCCA) {
+		odm_set_mac_reg(dm, R_0x520, BIT(15), 1); /*@ignore EDCCA*/
+#if 0
+		/*odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 0);*/
+#endif
+	} else { /*@don't set MAC ignore EDCCA signal*/
+		odm_set_mac_reg(dm, R_0x520, BIT(15), 0); /*@don't ignore EDCCA*/
+#if 0
+		/*odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 1);*/
+#endif
 	}
-
-	adaptivity->is_check = true;
-
+	PHYDM_DBG(dm, DBG_ADPTVTY, "EDCCA enable state = %d\n", state);
 }
 
-void
-phydm_search_pwdb_lower_bound(
-	void		*p_dm_void
-)
+void phydm_search_pwdb_lower_bound(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	u32			value32 = 0, reg_value32 = 0;
-	u8			cnt, try_count = 0;
-	u8			tx_edcca1 = 0;
-	boolean			is_adjust = true;
-	s8			th_l2h_dmc, th_h2l_dmc, igi_target = 0x32;
-	s8			diff;
-	u8			IGI = adaptivity->igi_base + 30 + (u8)p_dm->th_l2h_ini - (u8)p_dm->th_edcca_hl_diff;
-
-	if (p_dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
-		phydm_set_lna(p_dm, phydm_disable_lna);
-
-	diff = igi_target - (s8)IGI;
-	th_l2h_dmc = p_dm->th_l2h_ini + diff;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adapt = &dm->adaptivity;
+	u32 value32 = 0, reg_value32 = 0;
+	u8 cnt = 0, try_count = 0;
+	u8 tx_edcca1 = 0;
+	boolean is_adjust = true;
+	s8 th_l2h_dmc, th_h2l_dmc, igi_target = 0x32;
+	s8 diff = 0;
+	s8 IGI = adapt->igi_base + 30 + dm->th_l2h_ini - dm->th_edcca_hl_diff;
+
+	halrf_rf_lna_setting(dm, HALRF_LNA_DISABLE);
+	diff = igi_target - IGI;
+	th_l2h_dmc = dm->th_l2h_ini + diff;
 	if (th_l2h_dmc > 10)
 		th_l2h_dmc = 10;
 
-	th_h2l_dmc = th_l2h_dmc - p_dm->th_edcca_hl_diff;
-	phydm_set_edcca_threshold(p_dm, th_h2l_dmc, th_l2h_dmc);
+	th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+	phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
 	ODM_delay_ms(30);
 
 	while (is_adjust) {
-
-		/*check CCA status*/
-		if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_1, 0x0)) {/*set debug port to 0x0*/
-			reg_value32 = phydm_get_bb_dbg_port_value(p_dm);
+		/*@check CCA status*/
+		/*set debug port to 0x0*/
+		if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x0)) {
+			reg_value32 = phydm_get_bb_dbg_port_val(dm);
 
 			while (reg_value32 & BIT(3) && try_count < 3) {
 				ODM_delay_ms(3);
 				try_count = try_count + 1;
-				reg_value32 = phydm_get_bb_dbg_port_value(p_dm);
+				reg_value32 = phydm_get_bb_dbg_port_val(dm);
 			}
-			phydm_release_bb_dbg_port(p_dm);
+			phydm_release_bb_dbg_port(dm);
 			try_count = 0;
 		}
 
-		/*count EDCCA signal = 1 times*/
+		/*@count EDCCA signal = 1 times*/
 		for (cnt = 0; cnt < 20; cnt++) {
-
-			if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_1, adaptivity->adaptivity_dbg_port)) {
-				value32 = phydm_get_bb_dbg_port_value(p_dm);
-				phydm_release_bb_dbg_port(p_dm);
+			if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1,
+						  adapt->adaptivity_dbg_port)) {
+				value32 = phydm_get_bb_dbg_port_val(dm);
+				phydm_release_bb_dbg_port(dm);
 			}
 
-			if (value32 & BIT(30) && (p_dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E)))
+			if (value32 & BIT(30) && dm->support_ic_type &
+						 (ODM_RTL8723B | ODM_RTL8188E))
 				tx_edcca1 = tx_edcca1 + 1;
 			else if (value32 & BIT(29))
 				tx_edcca1 = tx_edcca1 + 1;
@@ -409,43 +267,31 @@ phydm_search_pwdb_lower_bound(
 			if (th_l2h_dmc > 10)
 				th_l2h_dmc = 10;
 
-			th_h2l_dmc = th_l2h_dmc - p_dm->th_edcca_hl_diff;
-			phydm_set_edcca_threshold(p_dm, th_h2l_dmc, th_l2h_dmc);
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+			phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
 			tx_edcca1 = 0;
 			if (th_l2h_dmc == 10)
 				is_adjust = false;
 
-		} else
+		} else {
 			is_adjust = false;
-
+		}
 	}
 
-	adaptivity->adapt_igi_up = IGI - p_dm->dc_backoff;
-	adaptivity->h2l_lb = th_h2l_dmc + p_dm->dc_backoff;
-	adaptivity->l2h_lb = th_l2h_dmc + p_dm->dc_backoff;
+	adapt->adapt_igi_up = IGI - ADAPT_DC_BACKOFF;
+	adapt->h2l_lb = th_h2l_dmc + ADAPT_DC_BACKOFF;
+	adapt->l2h_lb = th_l2h_dmc + ADAPT_DC_BACKOFF;
 
-	if (p_dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A))
-		phydm_set_lna(p_dm, phydm_enable_lna);
-
-	phydm_set_edcca_threshold(p_dm, 0x7f, 0x7f);				/*resume to no link state*/
+	halrf_rf_lna_setting(dm, HALRF_LNA_ENABLE);
+	phydm_set_edcca_threshold(dm, 0x7f, 0x7f); /*resume to no link state*/
 }
 
 boolean
-phydm_re_search_condition(
-	void				*p_dm_void
-)
+phydm_re_search_condition(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	u8			adaptivity_igi_upper = adaptivity->adapt_igi_up + p_dm->dc_backoff;
-	/*s8		TH_L2H_dmc, IGI_target = 0x32;*/
-	/*s8		diff;*/
-
-	/*TH_L2H_dmc = 10;*/
-
-	/*diff = TH_L2H_dmc - p_dm->TH_L2H_ini;*/
-	/*lowest_IGI_upper = IGI_target - diff;*/
-	/*if ((adaptivity_igi_upper - lowest_IGI_upper) <= 5)*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adaptivity = &dm->adaptivity;
+	u8 adaptivity_igi_upper = adaptivity->adapt_igi_up + ADAPT_DC_BACKOFF;
 
 	if (adaptivity_igi_upper <= 0x26)
 		return true;
@@ -453,560 +299,467 @@ phydm_re_search_condition(
 		return false;
 }
 
-void
-phydm_adaptivity_info_init(
-	void				*p_dm_void,
-	enum phydm_adapinfo_e	cmn_info,
-	u32				value
-)
+void phydm_set_l2h_th_ini(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-
-	switch (cmn_info)	{
-	case PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE:
-		p_dm->carrier_sense_enable = (boolean)value;
-		break;
-
-	case PHYDM_ADAPINFO_DCBACKOFF:
-		p_dm->dc_backoff = (u8)value;
-		break;
-
-	case PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY:
-		adaptivity->dynamic_link_adaptivity = (boolean)value;
-		break;
-
-	case PHYDM_ADAPINFO_TH_L2H_INI:
-		p_dm->th_l2h_ini = (s8)value;
-		break;
-
-	case PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF:
-		p_dm->th_edcca_hl_diff = (s8)value;
-		break;
-
-	case PHYDM_ADAPINFO_AP_NUM_TH:
-		adaptivity->ap_num_th = (u8)value;
-		break;
-
-	default:
-		break;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (dm->support_ic_type &
+		    (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
+			dm->th_l2h_ini = 0xf2;
+		else
+			dm->th_l2h_ini = 0xef;
+	} else  if (dm->support_ic_type & ODM_RTL8822C) {
+		dm->th_l2h_ini = 0x2d;
+	} else  if (dm->support_ic_type & ODM_RTL8814B) {
+		dm->th_l2h_ini = 0x31;
+	} else {
+		dm->th_l2h_ini = 0xf5;
 	}
-
 }
 
-void
-phydm_adaptivity_init(
-	void		*p_dm_void
-)
+void phydm_set_forgetting_factor(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	s8	igi_target = 0x32;
-	/*struct phydm_dig_struct* p_dig_t = &p_dm->dm_dig_table;*/
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_WIN))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (p_dm->carrier_sense_enable == false) {
-		if (p_dm->th_l2h_ini == 0)
-			phydm_set_l2h_th_ini(p_dm);
-	} else
-		p_dm->th_l2h_ini = 0xa;
-
-	if (p_dm->th_edcca_hl_diff == 0)
-		p_dm->th_edcca_hl_diff = 7;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-	if (p_dm->wifi_test == true || *(p_dm->p_mp_mode) == true)
-#else
-	if ((p_dm->wifi_test & RT_WIFI_LOGO) == true)
-#endif
-		p_dm->edcca_enable = false;		/*even no adaptivity, we still enable EDCCA, AP side use mib control*/
-	else
-		p_dm->edcca_enable = true;
-
-#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	struct rtl8192cd_priv	*priv = p_dm->priv;
+	if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
+		odm_set_bb_reg(dm, R_0x8a0, BIT(1) | BIT(0), 0);
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		odm_set_bb_reg(dm, R_0x83c, BIT(31) | BIT(30) | BIT(29), 0x7);
+}
 
-	if (p_dm->carrier_sense_enable) {
-		p_dm->th_l2h_ini = 0xa;
-		p_dm->th_edcca_hl_diff = 7;
+void phydm_set_pwdb_mode(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ability & ODM_BB_ADAPTIVITY) {
+		if (dm->support_ic_type & ODM_RTL8822B)
+			odm_set_bb_reg(dm, R_0x8dc, BIT(5), 0x1);
+		else if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+			odm_set_bb_reg(dm, R_0xce8, BIT(13), 0x1);
+		else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			odm_set_bb_reg(dm, R_0x844, BIT(30) | BIT(29), 0x0);
 	} else {
-		p_dm->th_l2h_ini = p_dm->TH_L2H_default;	/*set by mib*/
-		p_dm->th_edcca_hl_diff = p_dm->th_edcca_hl_diff_default;
+		if (dm->support_ic_type & ODM_RTL8822B)
+			odm_set_bb_reg(dm, R_0x8dc, BIT(5), 0x0);
+		else if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+			odm_set_bb_reg(dm, R_0xce8, BIT(13), 0x0);
+		else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			odm_set_bb_reg(dm, R_0x844, BIT(30) | BIT(29), 0x2);
 	}
+}
 
-	if (priv->pshare->rf_ft_var.adaptivity_enable == 2)
-		adaptivity->dynamic_link_adaptivity = true;
-	else
-		adaptivity->dynamic_link_adaptivity = false;
-
-#endif
-
-	adaptivity->adapt_igi_up = 0;
-	p_dm->adaptivity_enable = false;	/*use this flag to decide enable or disable*/
-
-	p_dm->th_l2h_ini_mode2 = 20;
-	p_dm->th_edcca_hl_diff_mode2 = 8;
-	adaptivity->debug_mode = false;
-	adaptivity->th_l2h_ini_backup = p_dm->th_l2h_ini;
-	adaptivity->th_edcca_hl_diff_backup = p_dm->th_edcca_hl_diff;
+void phydm_adaptivity_debug(void *dm_void, char input[][16], u32 *_used,
+			    char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adaptivity = &dm->adaptivity;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	char help[] = "-h";
+	u32 dm_value[10] = {0};
+	u8 i = 0, input_idx = 0;
+	u32 reg_value32 = 0;
+	s8 h2l_diff = 0;
 
-	adaptivity->igi_base = 0x32;
-	adaptivity->igi_target = 0x1c;
-	adaptivity->h2l_lb = 0;
-	adaptivity->l2h_lb = 0;
-	adaptivity->is_check = false;
-	adaptivity->adajust_igi_level = 0;
-	adaptivity->is_stop_edcca = false;
-	adaptivity->backup_h2l = 0;
-	adaptivity->backup_l2h = 0;
-	adaptivity->adaptivity_dbg_port = (p_dm->support_ic_type & ODM_IC_11N_SERIES) ? 0x208 : 0x209;
-
-	phydm_mac_edcca_state(p_dm, phydm_dont_ignore_edcca);
-
-	if (p_dm->support_ic_type & ODM_IC_11N_GAIN_IDX_EDCCA) {
-		/*odm_set_bb_reg(p_dm, ODM_REG_EDCCA_DOWN_OPT_11N, BIT(12) | BIT(11) | BIT(10), 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
-		if (p_dm->support_ic_type & ODM_RTL8197F) {
-			odm_set_bb_reg(p_dm, ODM_REG_PAGE_B1_97F, BIT(30), 0x1);								/*set to page B1*/
-			odm_set_bb_reg(p_dm, ODM_REG_EDCCA_DCNF_97F, BIT(27) | BIT(26), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
-			odm_set_bb_reg(p_dm, ODM_REG_PAGE_B1_97F, BIT(30), 0x0);
-		} else
-			odm_set_bb_reg(p_dm, ODM_REG_EDCCA_DCNF_11N, BIT(21) | BIT(20), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
+			input_idx++;
+		}
 	}
-#if (RTL8195A_SUPPORT == 0)
-	if (p_dm->support_ic_type & ODM_IC_11AC_GAIN_IDX_EDCCA) {		/*8814a no need to find pwdB lower bound, maybe*/
-		/*odm_set_bb_reg(p_dm, ODM_REG_EDCCA_DOWN_OPT, BIT(30) | BIT(29) | BIT(28), 0x7);*/		/*interfernce need > 2^x us, and then EDCCA will be 1*/
-		odm_set_bb_reg(p_dm, ODM_REG_ACBB_EDCCA_ENHANCE, BIT(29) | BIT(28), 0x1);		/*0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+	if (strcmp(input[1], help) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Show adaptivity message: {0}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Enter debug mode: {1} {th_l2h_ini} {th_edcca_hl_diff}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Leave debug mode: {2}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Disable EDCCA thr: {3}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Enable EDCCA thr: {4}\n");
+		goto out;
 	}
 
-	if (!(p_dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA))) {
-		phydm_search_pwdb_lower_bound(p_dm);
-		if (phydm_re_search_condition(p_dm))
-			phydm_search_pwdb_lower_bound(p_dm);
-	} else
-		phydm_set_edcca_threshold(p_dm, 0x7f, 0x7f);				/*resume to no link state*/
-#endif
-	/*forgetting factor setting*/
-	phydm_set_forgetting_factor(p_dm);
-
-	/*pwdb mode setting with 0: mean, 1:max*/
-	phydm_set_pwdb_mode(p_dm);
-
-	/*we need to consider PwdB upper bound for 8814 later IC*/
-	adaptivity->adajust_igi_level = (u8)((p_dm->th_l2h_ini + igi_target) - pwdb_upper_bound + dfir_loss);	/*IGI = L2H - PwdB - dfir_loss*/
+	if (input_idx == 0)
+		return;
 
-	/*Check this later on Windows*/
-	/*phydm_set_edcca_threshold_api(p_dm, p_dig_t->cur_ig_value);*/
+	if (dm_value[0] == PHYDM_ADAPT_DEBUG) {
+		adaptivity->debug_mode = true;
+		if (dm_value[1] != 0)
+			dm->th_l2h_ini = (s8)dm_value[1];
+		if (dm_value[2] != 0)
+			dm->th_edcca_hl_diff = (s8)dm_value[2];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "th_l2h_ini = %d, th_edcca_hl_diff = %d\n",
+			 dm->th_l2h_ini, dm->th_edcca_hl_diff);
+	} else if (dm_value[0] == PHYDM_ADAPT_RESUME) {
+		adaptivity->debug_mode = false;
+		dm->th_l2h_ini = adaptivity->th_l2h_ini_backup;
+		dm->th_edcca_hl_diff = adaptivity->th_edcca_hl_diff_backup;
+	} else if (dm_value[0] == PHYDM_EDCCA_TH_PAUSE) {
+		adaptivity->edcca_en = false;
+	} else if (dm_value[0] == PHYDM_EDCCA_TH_RESUME) {
+		adaptivity->edcca_en = true;
+	} else if (dm_value[0] == PHYDM_ADAPT_MSG) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "debug_mode = %s, th_l2h_ini = %d\n",
+			 (adaptivity->debug_mode ? "TRUE" : "FALSE"),
+			 dm->th_l2h_ini);
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			reg_value32 = odm_get_bb_reg(dm, R_0x84c, MASKDWORD);
+			h2l_diff = (s8)((0x00ff0000 & reg_value32) >> 16) -
+				   (s8)((0xff000000 & reg_value32) >> 24);
+		} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			reg_value32 = odm_get_bb_reg(dm, R_0xc4c, MASKDWORD);
+			h2l_diff = (s8)(0x000000ff & reg_value32) -
+				   (s8)((0x00ff0000 & reg_value32) >> 16);
+		} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			reg_value32 = odm_get_bb_reg(dm, R_0x8a4, MASKDWORD);
+			h2l_diff = (s8)(0x000000ff & reg_value32) -
+				   (s8)((0x0000ff00 & reg_value32) >> 8);
+		}
 
-	p_dm->adaptivity_flag = (p_dm->support_ic_type & ODM_IC_GAIN_IDX_EDCCA) ? false : true;
-	
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	adaptivity->igi_up_bound_lmt_val = 180;
-#else
-	adaptivity->igi_up_bound_lmt_val = 90;
-#endif
-	adaptivity->igi_up_bound_lmt_cnt = 0;
-	adaptivity->igi_lmt_en = false;
+		if (h2l_diff == 7)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "adaptivity enable\n");
+		else
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "adaptivity disable\n");
+	}
 
+out:
+	*_used = used;
+	*_out_len = out_len;
 }
 
-
-void
-phydm_adaptivity(
-	void			*p_dm_void
-)
+void phydm_set_edcca_val(void *dm_void, u32 *val_buf, u8 val_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct			*p_dig_t = &p_dm->dm_dig_table;
-	u8			igi = p_dig_t->cur_ig_value;
-	s8			th_l2h_dmc, th_h2l_dmc;
-	s8			diff = 0, igi_target = 0x32;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*p_adapter	= p_dm->adapter;
-	u32			is_fw_current_in_ps_mode = false;
-	u8			disable_ap_adapt_setting;
-
-	p_adapter->HalFunc.GetHwRegHandler(p_adapter, HW_VAR_FW_PSMODE_STATUS, (u8 *)(&is_fw_current_in_ps_mode));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	/*Disable EDCCA mode while under LPS mode, added by Roger, 2012.09.14.*/
-	if (is_fw_current_in_ps_mode)
-		return;
-#endif
-
-	if ((p_dm->edcca_enable == false) || (adaptivity->is_stop_edcca == true)) {
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("Disable EDCCA!!!\n"));
+	if (val_len != 2) {
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "[Error][adaptivity]Need val_len = 2\n");
 		return;
 	}
+	phydm_set_edcca_threshold(dm, (s8)val_buf[1], (s8)val_buf[0]);
+}
 
-	phydm_check_adaptivity(p_dm);	/*Check adaptivity enable*/
-	phydm_dig_up_bound_lmt_en(p_dm);
-
-	if ((!(p_dm->support_ability & ODM_BB_ADAPTIVITY)) && adaptivity->debug_mode == false) {
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("adaptivity disable, enable EDCCA mode!!!\n"));
-		p_dm->th_l2h_ini = p_dm->th_l2h_ini_mode2;
-		p_dm->th_edcca_hl_diff = p_dm->th_edcca_hl_diff_mode2;
-	}
+boolean phydm_edcca_abort(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adapt = &dm->adaptivity;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	else if (adaptivity->debug_mode == false) {
-		disable_ap_adapt_setting = false;
-		if (p_dm->p_soft_ap_mode != NULL) {
-			if (*(p_dm->p_soft_ap_mode) != 0 && (p_dm->soft_ap_special_setting & BIT(0)))
-				disable_ap_adapt_setting = true;
-			PHYDM_DBG(p_dm, DBG_ADPTVTY, ("p_dm->soft_ap_special_setting = %x, *(p_dm->p_soft_ap_mode) = %d, disable_ap_adapt_setting = %d\n", p_dm->soft_ap_special_setting, *(p_dm->p_soft_ap_mode), disable_ap_adapt_setting));
-		}
-		if (phydm_check_channel_plan(p_dm) || (p_dm->ap_total_num > adaptivity->ap_num_th) || disable_ap_adapt_setting) {
-			p_dm->th_l2h_ini = p_dm->th_l2h_ini_mode2;
-			p_dm->th_edcca_hl_diff = p_dm->th_edcca_hl_diff_mode2;
-		} else {
-			p_dm->th_l2h_ini = adaptivity->th_l2h_ini_backup;
-			p_dm->th_edcca_hl_diff = adaptivity->th_edcca_hl_diff_backup;
-		}
-	}
-#endif
-	else if (adaptivity->debug_mode == true) {
-		p_dm->th_l2h_ini = adaptivity->th_l2h_ini_debug;
-		p_dm->th_edcca_hl_diff = 7;
-		adaptivity->adajust_igi_level = (u8)((p_dm->th_l2h_ini + igi_target) - pwdb_upper_bound + dfir_loss);	/*IGI = L2H - PwdB - dfir_loss*/
-	}
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("odm_Adaptivity() =====>\n"));
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("igi_base=0x%x, th_l2h_ini = %d, th_edcca_hl_diff = %d\n",
-		adaptivity->igi_base, p_dm->th_l2h_ini, p_dm->th_edcca_hl_diff));
-#if (RTL8195A_SUPPORT == 0)
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		/*fix AC series when enable EDCCA hang issue*/
-		odm_set_bb_reg(p_dm, 0x800, BIT(10), 1);	/*ADC_mask disable*/
-		odm_set_bb_reg(p_dm, 0x800, BIT(10), 0);	/*ADC_mask enable*/
-	}
+	void *adapter = dm->adapter;
+	u32 is_fw_in_psmode = false;
 #endif
 
-	igi_target = adaptivity->igi_base;
-	adaptivity->igi_target = (u8) igi_target;
-
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("band_width=%s, igi_target=0x%x, dynamic_link_adaptivity = %d\n",
-		(*p_dm->p_band_width == CHANNEL_WIDTH_80) ? "80M" : ((*p_dm->p_band_width == CHANNEL_WIDTH_40) ? "40M" : "20M"), igi_target, adaptivity->dynamic_link_adaptivity));
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("adajust_igi_level= 0x%x, adaptivity_flag = %d, adaptivity_enable = %d\n",
-		adaptivity->adajust_igi_level, p_dm->adaptivity_flag, p_dm->adaptivity_enable));
-
-	if ((adaptivity->dynamic_link_adaptivity == true) && (!p_dm->is_linked) && (p_dm->adaptivity_enable == false)) {
-		phydm_set_edcca_threshold(p_dm, 0x7f, 0x7f);
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("In DynamicLink mode(noisy) and No link, Turn off EDCCA!!\n"));
-		return;
+	if (dm->pause_ability & ODM_BB_ADAPTIVITY) {
+		PHYDM_DBG(dm, DBG_ADPTVTY, "Return: Pause ADPTVTY in LV=%d\n",
+			  dm->pause_lv_table.lv_adapt);
+		return true;
 	}
 
-	if (p_dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
-		if ((adaptivity->adajust_igi_level > igi) && (p_dm->adaptivity_enable == true))
-			diff = adaptivity->adajust_igi_level - igi;
-		else if (p_dm->adaptivity_enable == false)
-			diff = 0x3e - igi;
-
-		th_l2h_dmc = p_dm->th_l2h_ini - diff + igi_target;
-		th_h2l_dmc = th_l2h_dmc - p_dm->th_edcca_hl_diff;
+	if (!adapt->edcca_en) {
+		PHYDM_DBG(dm, DBG_ADPTVTY, "Disable EDCCA!!!\n");
+		return true;
 	}
-#if (RTL8195A_SUPPORT == 0)
-	else	{
-		diff = igi_target - (s8)igi;
-		th_l2h_dmc = p_dm->th_l2h_ini + diff;
-		if (th_l2h_dmc > 10 && (p_dm->adaptivity_enable == true))
-			th_l2h_dmc = 10;
 
-		th_h2l_dmc = th_l2h_dmc - p_dm->th_edcca_hl_diff;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	((PADAPTER)adapter)->HalFunc.GetHwRegHandler(adapter,
+						      HW_VAR_FW_PSMODE_STATUS,
+						      (u8 *)(&is_fw_in_psmode));
 
-		/*replace lower bound to prevent EDCCA always equal 1*/
-		if (th_h2l_dmc < adaptivity->h2l_lb)
-			th_h2l_dmc = adaptivity->h2l_lb;
-		if (th_l2h_dmc < adaptivity->l2h_lb)
-			th_l2h_dmc = adaptivity->l2h_lb;
-	}
+	/*@Disable EDCCA while under LPS mode, added by Roger, 2012.09.14.*/
+	if (is_fw_in_psmode)
+		return true;
 #endif
-	adaptivity->th_l2h = th_l2h_dmc;
-	adaptivity->th_h2l = th_h2l_dmc;
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("IGI=0x%x, th_l2h_dmc = %d, th_h2l_dmc = %d\n", igi, th_l2h_dmc, th_h2l_dmc));
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("adapt_igi_up=0x%x, h2l_lb = 0x%x, l2h_lb = 0x%x\n", adaptivity->adapt_igi_up, adaptivity->h2l_lb, adaptivity->l2h_lb));
-	PHYDM_DBG(p_dm, DBG_ADPTVTY, ("debug_mode = %d\n", adaptivity->debug_mode));
-	phydm_set_edcca_threshold(p_dm, th_h2l_dmc, th_l2h_dmc);
-
-	if (p_dm->adaptivity_enable == true)
-		odm_set_mac_reg(p_dm, REG_RD_CTRL, BIT(11), 1);
 
-	return;
+	return false;
 }
-
-/*This API is for solving USB can't Tx problem due to USB3.0 interference in 2.4G*/
-void
-phydm_pause_edcca(
-	void	*p_dm_void,
-	boolean	is_pasue_edcca
-)
+#endif
+void phydm_set_edcca_threshold_api(void *dm_void, u8 IGI)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	u8	IGI = p_dig_t->cur_ig_value;
-	s8	diff = 0;
-
-	if (is_pasue_edcca) {
-		adaptivity->is_stop_edcca = true;
-
-		if (p_dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adaptivity = &dm->adaptivity;
+	s8 th_l2h_dmc = 0, th_h2l_dmc = 0;
+	s8 diff = 0, igi_target = 0x32;
+
+	if (dm->support_ability & ODM_BB_ADAPTIVITY) {
+		if (!(dm->support_ic_type & ODM_IC_PWDB_EDCCA)) {
 			if (adaptivity->adajust_igi_level > IGI)
 				diff = adaptivity->adajust_igi_level - IGI;
 
-			adaptivity->backup_l2h = p_dm->th_l2h_ini - diff + adaptivity->igi_target;
-			adaptivity->backup_h2l = adaptivity->backup_l2h - p_dm->th_edcca_hl_diff;
-		}
-#if (RTL8195A_SUPPORT == 0)
-		else {
-			diff = adaptivity->igi_target - (s8)IGI;
-			adaptivity->backup_l2h = p_dm->th_l2h_ini + diff;
-			if (adaptivity->backup_l2h > 10)
-				adaptivity->backup_l2h = 10;
+			th_l2h_dmc = dm->th_l2h_ini - diff + igi_target;
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+		} else {
+			diff = igi_target - (s8)IGI;
+			th_l2h_dmc = dm->th_l2h_ini + diff;
+			if (th_l2h_dmc > 10)
+				th_l2h_dmc = 10;
 
-			adaptivity->backup_h2l = adaptivity->backup_l2h - p_dm->th_edcca_hl_diff;
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
 
 			/*replace lower bound to prevent EDCCA always equal 1*/
-			if (adaptivity->backup_h2l < adaptivity->h2l_lb)
-				adaptivity->backup_h2l = adaptivity->h2l_lb;
-			if (adaptivity->backup_l2h < adaptivity->l2h_lb)
-				adaptivity->backup_l2h = adaptivity->l2h_lb;
+			if (th_h2l_dmc < adaptivity->h2l_lb)
+				th_h2l_dmc = adaptivity->h2l_lb;
+			if (th_l2h_dmc < adaptivity->l2h_lb)
+				th_l2h_dmc = adaptivity->l2h_lb;
 		}
-#endif
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("pauseEDCCA : L2Hbak = 0x%x, H2Lbak = 0x%x, IGI = 0x%x\n", adaptivity->backup_l2h, adaptivity->backup_h2l, IGI));
-
-		/*Disable EDCCA*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		if (odm_is_work_item_scheduled(&(adaptivity->phydm_pause_edcca_work_item)) == false)
-			odm_schedule_work_item(&(adaptivity->phydm_pause_edcca_work_item));
-#else
-		phydm_pause_edcca_work_item_callback(p_dm);
-#endif
 
-	} else {
-
-		adaptivity->is_stop_edcca = false;
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("resumeEDCCA : L2Hbak = 0x%x, H2Lbak = 0x%x, IGI = 0x%x\n", adaptivity->backup_l2h, adaptivity->backup_h2l, IGI));
-		/*Resume EDCCA*/
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		if (odm_is_work_item_scheduled(&(adaptivity->phydm_resume_edcca_work_item)) == false)
-			odm_schedule_work_item(&(adaptivity->phydm_resume_edcca_work_item));
-#else
-		phydm_resume_edcca_work_item_callback(p_dm);
-#endif
+		PHYDM_DBG(dm, DBG_ADPTVTY,
+			  "API :IGI=0x%x, th_l2h_dmc = %d, th_h2l_dmc = %d\n",
+			  IGI, th_l2h_dmc, th_h2l_dmc);
 
+		phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
 	}
-
+#endif
 }
 
-
-void
-phydm_pause_edcca_work_item_callback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
-#else
-	void			*p_dm_void
-#endif
-)
+void phydm_adaptivity_info_init(void *dm_void, enum phydm_adapinfo cmn_info,
+				u32 value)
 {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
-#else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-#endif
-
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-		odm_set_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)(0x7f | 0x7f << 16));
-#if (RTL8195A_SUPPORT == 0)
-	else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-		odm_set_bb_reg(p_dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)(0x7f | 0x7f << 8));
-#endif
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adaptivity = &dm->adaptivity;
 
+	switch (cmn_info) {
+	case PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE:
+		dm->carrier_sense_enable = (boolean)value;
+		break;
+	case PHYDM_ADAPINFO_TH_L2H_INI:
+		dm->th_l2h_ini = (s8)value;
+		break;
+	case PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF:
+		dm->th_edcca_hl_diff = (s8)value;
+		break;
+	case PHYDM_ADAPINFO_AP_NUM_TH:
+		adaptivity->ap_num_th = (u8)value;
+		break;
+	default:
+		break;
+	}
 }
 
-void
-phydm_resume_edcca_work_item_callback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
-#else
-	void			*p_dm_void
-#endif
-)
+void phydm_adaptivity_info_update(void *dm_void, enum phydm_adapinfo cmn_info,
+				  u32 value)
 {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
-#else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-#endif
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-		odm_set_bb_reg(p_dm, REG_OFDM_0_ECCA_THRESHOLD, MASKBYTE2 | MASKBYTE0, (u32)((u8)adaptivity->backup_l2h | (u8)adaptivity->backup_h2l << 16));
-#if (RTL8195A_SUPPORT == 0)
-	else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-		odm_set_bb_reg(p_dm, REG_FPGA0_XB_LSSI_READ_BACK, MASKLWORD, (u16)((u8)adaptivity->backup_l2h | (u8)adaptivity->backup_h2l << 8));
-#endif
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adapt = &dm->adaptivity;
 
+	/*This init variable may be changed in run time.*/
+	switch (cmn_info) {
+	case PHYDM_ADAPINFO_DOMAIN_CODE_2G:
+		adapt->regulation_2g = (u8)value;
+		break;
+	case PHYDM_ADAPINFO_DOMAIN_CODE_5G:
+		adapt->regulation_5g = (u8)value;
+		break;
+	default:
+		break;
+	}
 }
 
-
-void
-phydm_set_edcca_threshold_api(
-	void	*p_dm_void,
-	u8	IGI
-)
+void phydm_adaptivity_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	s8			th_l2h_dmc, th_h2l_dmc;
-	s8			diff = 0, igi_target = 0x32;
-
-	if (p_dm->support_ability & ODM_BB_ADAPTIVITY) {
-		if (p_dm->support_ic_type & (ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
-			if (adaptivity->adajust_igi_level > IGI)
-				diff = adaptivity->adajust_igi_level - IGI;
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_adaptivity_struct *adaptivity = &dm->adaptivity;
 
-			th_l2h_dmc = p_dm->th_l2h_ini - diff + igi_target;
-			th_h2l_dmc = th_l2h_dmc - p_dm->th_edcca_hl_diff;
-		}
-#if (RTL8195A_SUPPORT == 0)
-		else	{
-			diff = igi_target - (s8)IGI;
-			th_l2h_dmc = p_dm->th_l2h_ini + diff;
-			if (th_l2h_dmc > 10)
-				th_l2h_dmc = 10;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_WIN))
 
-			th_h2l_dmc = th_l2h_dmc - p_dm->th_edcca_hl_diff;
+	if (!dm->carrier_sense_enable) {
+		if (dm->th_l2h_ini == 0)
+			phydm_set_l2h_th_ini(dm);
+	} else {
+		dm->th_l2h_ini = 0xa;
+	}
 
-			/*replace lower bound to prevent EDCCA always equal 1*/
-			if (th_h2l_dmc < adaptivity->h2l_lb)
-				th_h2l_dmc = adaptivity->h2l_lb;
-			if (th_l2h_dmc < adaptivity->l2h_lb)
-				th_l2h_dmc = adaptivity->l2h_lb;
-		}
+	if (dm->th_edcca_hl_diff == 0)
+		dm->th_edcca_hl_diff = 7;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	if (dm->wifi_test || *dm->mp_mode)
+#else
+	if (dm->wifi_test & RT_WIFI_LOGO) /*@AP side use mib control*/
 #endif
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("API :IGI=0x%x, th_l2h_dmc = %d, th_h2l_dmc = %d\n", IGI, th_l2h_dmc, th_h2l_dmc));
-		PHYDM_DBG(p_dm, DBG_ADPTVTY, ("API :adapt_igi_up=0x%x, h2l_lb = 0x%x, l2h_lb = 0x%x\n", adaptivity->adapt_igi_up, adaptivity->h2l_lb, adaptivity->l2h_lb));
+		/*@even no adaptivity, we still enable EDCCA*/
+		adaptivity->edcca_en = false;
+	else
+		adaptivity->edcca_en = true;
 
-		phydm_set_edcca_threshold(p_dm, th_h2l_dmc, th_l2h_dmc);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	if (dm->carrier_sense_enable) {
+		dm->th_l2h_ini = 0xa;
+		dm->th_edcca_hl_diff = 7;
+	} else {
+		dm->th_l2h_ini = dm->TH_L2H_default; /*set by mib*/
+		dm->th_edcca_hl_diff = dm->th_edcca_hl_diff_default;
 	}
-}
 
-void
-phydm_adaptivity_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	u32 used = *_used;
-	u32 out_len = *_out_len;
-	u32 reg_value32;
-	s8 h2l_diff = 0;
+	adaptivity->edcca_en = true;
+#endif
 
-	if (dm_value[0] == PHYDM_ADAPT_DEBUG) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "Adaptivity Debug Mode ===>\n"));
-		adaptivity->debug_mode = true;
-		adaptivity->th_l2h_ini_debug = (s8)dm_value[1];
-		PHYDM_SNPRINTF((output + used, out_len - used, "th_l2h_ini_debug = %d\n", adaptivity->th_l2h_ini_debug));
-	} else if (dm_value[0] == PHYDM_ADAPT_RESUME) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "===> Adaptivity Resume\n"));
-		adaptivity->debug_mode = false;
-	} else if (dm_value[0] == PHYDM_EDCCA_TH_PAUSE) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "EDCCA Threshold Pause\n"));
-		p_dm->edcca_enable = false;
-	} else if (dm_value[0] == PHYDM_EDCCA_RESUME) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "EDCCA Resume\n"));
-		p_dm->edcca_enable = true;
-	} else if (dm_value[0] == PHYDM_ADAPT_MSG) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "debug_mode = %s, th_l2h_ini = %d\n", (adaptivity->debug_mode ? "TRUE" : "FALSE"), p_dm->th_l2h_ini));
-		if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-			reg_value32 = odm_get_bb_reg(p_dm, 0xc4c, MASKDWORD);
-			h2l_diff = (s8)(0x000000ff & reg_value32) - (s8)((0x00ff0000 & reg_value32)>>16);
-		}
-#if (RTL8195A_SUPPORT == 0)
-		else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-			reg_value32 = odm_get_bb_reg(p_dm, 0x8a4, MASKDWORD);
-			h2l_diff = (s8)(0x000000ff & reg_value32) - (s8)((0x0000ff00 & reg_value32)>>8);
+	adaptivity->is_adapt_en = false; /*@decide enable or not*/
+	adaptivity->debug_mode = false;
+	adaptivity->th_l2h_ini_mode2 = 20;
+	adaptivity->th_edcca_hl_diff_mode2 = 8;
+	adaptivity->th_l2h_ini_backup = dm->th_l2h_ini;
+	adaptivity->th_edcca_hl_diff_backup = dm->th_edcca_hl_diff;
+	adaptivity->igi_base = 0x32;
+	adaptivity->adapt_igi_up = 0;
+	adaptivity->h2l_lb = 0;
+	adaptivity->l2h_lb = 0;
+	adaptivity->adajust_igi_level = 0;
+	adaptivity->th_l2h = 0x7f;
+	adaptivity->th_h2l = 0x7f;
+	phydm_mac_edcca_state(dm, PHYDM_DONT_IGNORE_EDCCA);
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		adaptivity->adaptivity_dbg_port = 0x000;
+		odm_set_bb_reg(dm, R_0x1d6c, BIT(0), 1);
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		adaptivity->adaptivity_dbg_port = 0x208;
+	} else {
+		adaptivity->adaptivity_dbg_port = 0x209;
+	}
+	if (dm->support_ic_type & ODM_IC_11N_SERIES &&
+	    !(dm->support_ic_type & ODM_IC_PWDB_EDCCA)) {
+		/*@interfernce need > 2^x us, and then EDCCA will be 1*/
+#if 0
+		/*odm_set_bb_reg(dm, 0x948, 0x1c00, 0x7);*/
+#endif
+		if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F)) {
+			/*set to page B1*/
+			odm_set_bb_reg(dm, R_0xe28, BIT(30), 0x1);
+			/*@0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+			odm_set_bb_reg(dm, R_0xbc0, BIT(27) | BIT(26), 0x1);
+			odm_set_bb_reg(dm, R_0xe28, BIT(30), 0x0);
+		} else {
+			/*@0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+			odm_set_bb_reg(dm, R_0xe24, BIT(21) | BIT(20), 0x1);
 		}
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES &&
+		   !(dm->support_ic_type & ODM_IC_PWDB_EDCCA)) {
+		/*@interfernce need > 2^x us, and then EDCCA will be 1*/
+#if 0
+		/*odm_set_bb_reg(dm, 0x900, 0x70000000, 0x7);*/
 #endif
-		if (h2l_diff == 7)
-			PHYDM_SNPRINTF((output + used, out_len - used, "adaptivity is enabled\n"));
-		else
-			PHYDM_SNPRINTF((output + used, out_len - used, "adaptivity is disabled\n"));
+		/*@0:rx_dfir, 1: dcnf_out, 2 :rx_iq, 3: rx_nbi_nf_out*/
+		odm_set_bb_reg(dm, R_0x944, BIT(29) | BIT(28), 0x1);
 	}
-	*_used = used;
-	*_out_len = out_len;
-}
 
-void
-phydm_set_l2h_th_ini(
-	void		*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	if (dm->support_ic_type & ODM_IC_PWDB_EDCCA) {
+		phydm_search_pwdb_lower_bound(dm);
+		if (phydm_re_search_condition(dm))
+			phydm_search_pwdb_lower_bound(dm);
+	} else {
+		/*resume to no link state*/
+		phydm_set_edcca_threshold(dm, 0x7f, 0x7f);
+	}
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		if (p_dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
-			p_dm->th_l2h_ini = 0xf2;
-		else
-			p_dm->th_l2h_ini = 0xef;
-	} else
-		p_dm->th_l2h_ini = 0xf5;
-}
+	/*@forgetting factor setting*/
+	phydm_set_forgetting_factor(dm);
 
-void
-phydm_set_forgetting_factor(
-	void		*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	/*pwdb mode setting with 0: mean, 1:max*/
+	phydm_set_pwdb_mode(dm);
 
-	if (p_dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A))
-		odm_set_bb_reg(p_dm, 0x8a0, BIT(1) | BIT(0), 0);
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	adaptivity->igi_up_bound_lmt_val = 180;
+#else
+	adaptivity->igi_up_bound_lmt_val = 90;
+#endif
+	adaptivity->igi_up_bound_lmt_cnt = 0;
+	adaptivity->igi_lmt_en = false;
+#endif
 }
 
-void
-phydm_set_pwdb_mode(
-	void		*p_dm_void
-)
+void phydm_adaptivity(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_adaptivity_struct *adapt = &dm->adaptivity;
+	u8 igi = dig_t->cur_ig_value;
+	s8 th_l2h_dmc = 0, th_h2l_dmc = 0;
+	s8 diff = 0, igi_target = adapt->igi_base;
+
+	if (phydm_edcca_abort(dm))
+		return;
 
-	if (p_dm->support_ability & ODM_BB_ADAPTIVITY) {
-		if (p_dm->support_ic_type & ODM_RTL8822B)
-			odm_set_bb_reg(p_dm, 0x8dc, BIT(5), 0x1);
-		else if (p_dm->support_ic_type & ODM_RTL8197F)
-			odm_set_bb_reg(p_dm, 0xce8, BIT(13), 0x1);
-	} else {
-		if (p_dm->support_ic_type & ODM_RTL8822B)
-			odm_set_bb_reg(p_dm, 0x8dc, BIT(5), 0x0);
-		else if (p_dm->support_ic_type & ODM_RTL8197F)
-			odm_set_bb_reg(p_dm, 0xce8, BIT(13), 0x0);
+	/*@fix AC series when enable EDCCA hang issue*/
+	if (dm->support_ic_type & ODM_RTL8812) {
+		odm_set_bb_reg(dm, R_0x800, BIT(10), 1); /*@ADC_mask disable*/
+		odm_set_bb_reg(dm, R_0x800, BIT(10), 0); /*@ADC_mask enable*/
 	}
-}
 
-void
-phydm_set_edcca_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	if (!adapt->debug_mode)
+		phydm_check_adaptivity(dm); /*@Check adaptivity enable*/
 
-	if (val_len != 2) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[Error][adaptivity]Need val_len = 2\n"));
-		return;
+	PHYDM_DBG(dm, DBG_ADPTVTY, "%s ====>\n", __func__);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "th_l2h_ini = %d, th_edcca_hl_diff = %d\n",
+		  dm->th_l2h_ini, dm->th_edcca_hl_diff);
+	PHYDM_DBG(dm, DBG_ADPTVTY, "is_adapt_en = %d, debug_mode = %d\n",
+		  adapt->is_adapt_en, adapt->debug_mode);
+	if (dm->support_ic_type & ODM_IC_PWDB_EDCCA) {
+		/*@Limit IGI upper bound for adaptivity*/
+		phydm_dig_up_bound_lmt_en(dm);
+
+		diff = igi_target - (s8)igi;
+		th_l2h_dmc = dm->th_l2h_ini + diff;
+		if (th_l2h_dmc > 10 && adapt->is_adapt_en)
+			th_l2h_dmc = 10;
+
+		th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+
+		/*replace lower bound to prevent EDCCA always equal 1*/
+		if (th_h2l_dmc < adapt->h2l_lb)
+			th_h2l_dmc = adapt->h2l_lb;
+		if (th_l2h_dmc < adapt->l2h_lb)
+			th_l2h_dmc = adapt->l2h_lb;
+		PHYDM_DBG(dm, DBG_ADPTVTY,
+			  "adapt_igi_up=0x%x, h2l_lb = 0x%x, l2h_lb = 0x%x\n",
+			  adapt->adapt_igi_up, adapt->h2l_lb, adapt->l2h_lb);
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		adapt->adajust_igi_level = (u8)(dm->th_l2h_ini - ADC_BACKOFF);
+		if (adapt->is_adapt_en) {
+			diff = adapt->adajust_igi_level > igi ?
+			       adapt->adajust_igi_level - igi :
+			       0;
+			th_l2h_dmc = dm->th_l2h_ini - diff;
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+		} else {
+			th_l2h_dmc = igi + 8 > adapt->th_l2h_ini_backup ?
+				     igi + 8 :
+				     adapt->th_l2h_ini_backup;
+			th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+		}
+	} else {
+		/*we need to consider PwdB upper bound for 8814 later IC*/
+		adapt->adajust_igi_level = (u8)(dm->th_l2h_ini + igi_target -
+					   PWDB_UPPER_BOUND + DFIR_LOSS);
+		if (adapt->adajust_igi_level > igi && adapt->is_adapt_en)
+			diff = adapt->adajust_igi_level - igi;
+		else if (!adapt->is_adapt_en)
+			diff = 0x3e - igi;
+
+		th_l2h_dmc = dm->th_l2h_ini - diff + igi_target;
+		if (dm->support_ic_type & ODM_RTL8198F) /* @need to check */
+			th_l2h_dmc -= 4;
+		th_h2l_dmc = th_l2h_dmc - dm->th_edcca_hl_diff;
+		PHYDM_DBG(dm, DBG_ADPTVTY, "adajust_igi_level= 0x%x\n",
+			  adapt->adajust_igi_level);
 	}
-	if (p_dm->pause_ability & BIT(F13_ADPTVTY))
-		p_dm->adaptivity.is_stop_edcca = true;
-	else
-		p_dm->adaptivity.is_stop_edcca = false;
 
-	phydm_set_edcca_threshold(p_dm, (s8)val_buf[1], (s8)val_buf[0]);
+	adapt->th_l2h = th_l2h_dmc;
+	adapt->th_h2l = th_h2l_dmc;
+	PHYDM_DBG(dm, DBG_ADPTVTY, "IGI=0x%x, th_l2h_dmc=%d, th_h2l_dmc=%d\n",
+		  igi, th_l2h_dmc, th_h2l_dmc);
+	phydm_set_edcca_threshold(dm, th_h2l_dmc, th_l2h_dmc);
+
+	if (adapt->is_adapt_en)
+		odm_set_mac_reg(dm, REG_RD_CTRL, BIT(11), 1);
+
+	return;
+#endif
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.h
index 3c58943f020c..bff446b4ec5c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adaptivity.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,20 +9,41 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-
-#ifndef	__PHYDMADAPTIVITY_H__
-#define    __PHYDMADAPTIVITY_H__
-
-#define ADAPTIVITY_VERSION	"9.5.7"	/*20170627 changed by Kevin, move adapt_igi_up from phydm.h to phydm_adaptivity.h*/
-
-#define pwdb_upper_bound	7
-#define dfir_loss	7
-
+#ifndef __PHYDMADAPTIVITY_H__
+#define __PHYDMADAPTIVITY_H__
+
+#define ADAPTIVITY_VERSION "9.6.01" /*@20180814 changed by Kevin,
+				     *add phydm_edcca_abort func.
+				     */
+
+#define PWDB_UPPER_BOUND 7
+#define DFIR_LOSS 7
+#define ADC_BACKOFF 12
+#define ODM_IC_PWDB_EDCCA (ODM_RTL8188E | ODM_RTL8723B | ODM_RTL8192E |\
+			   ODM_RTL8881A | ODM_RTL8821 | ODM_RTL8812)
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+	#define ADAPT_DC_BACKOFF 2
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	#define ADAPT_DC_BACKOFF 4
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	#define ADAPT_DC_BACKOFF 0
+#endif
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
 enum phydm_regulation_type {
 	REGULATION_FCC		= 0,
@@ -32,176 +54,70 @@ enum phydm_regulation_type {
 };
 #endif
 
-enum phydm_adapinfo_e {
+enum phydm_adapinfo {
 	PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE = 0,
-	PHYDM_ADAPINFO_DCBACKOFF,
-	PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY,
 	PHYDM_ADAPINFO_TH_L2H_INI,
 	PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF,
-	PHYDM_ADAPINFO_AP_NUM_TH
-};
-
-enum phydm_set_lna {
-	phydm_disable_lna		= 0,
-	phydm_enable_lna		= 1,
-};
-
-enum phydm_trx_mux_type {
-	phydm_shutdown			= 0,
-	phydm_standby_mode		= 1,
-	phydm_tx_mode			= 2,
-	phydm_rx_mode			= 3
+	PHYDM_ADAPINFO_AP_NUM_TH,
+	PHYDM_ADAPINFO_DOMAIN_CODE_2G,
+	PHYDM_ADAPINFO_DOMAIN_CODE_5G
 };
 
 enum phydm_mac_edcca_type {
-	phydm_ignore_edcca			= 0,
-	phydm_dont_ignore_edcca		= 1
+	PHYDM_IGNORE_EDCCA		= 0,
+	PHYDM_DONT_IGNORE_EDCCA		= 1
 };
 
 enum phydm_adaptivity_mode {
 	PHYDM_ADAPT_MSG			= 0,
 	PHYDM_ADAPT_DEBUG		= 1,
 	PHYDM_ADAPT_RESUME		= 2,
-	PHYDM_EDCCA_TH_PAUSE	= 3,
-	PHYDM_EDCCA_RESUME		= 4
+	PHYDM_EDCCA_TH_PAUSE		= 3,
+	PHYDM_EDCCA_TH_RESUME		= 4
 };
 
 struct phydm_adaptivity_struct {
 	s8			th_l2h_ini_backup;
 	s8			th_edcca_hl_diff_backup;
 	s8			igi_base;
-	u8			igi_target;
 	s8			h2l_lb;
 	s8			l2h_lb;
-	boolean		is_check;
-	boolean		dynamic_link_adaptivity;
 	u8			ap_num_th;
 	u8			adajust_igi_level;
-	s8			backup_l2h;
-	s8			backup_h2l;
-	boolean			is_stop_edcca;
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	RT_WORK_ITEM	phydm_pause_edcca_work_item;
-	RT_WORK_ITEM	phydm_resume_edcca_work_item;
-#endif
 	u32			adaptivity_dbg_port; /*N:0x208, AC:0x209*/
 	u8			debug_mode;
-	s8			th_l2h_ini_debug;
-	u16			igi_up_bound_lmt_cnt;	/*When igi_up_bound_lmt_cnt !=0, limit IGI upper bound to "adapt_igi_up"*/
-	u16			igi_up_bound_lmt_val;	/*max value of igi_up_bound_lmt_cnt*/
-	boolean		igi_lmt_en;
+	u16			igi_up_bound_lmt_cnt;	/*@When igi_up_bound_lmt_cnt !=0, limit IGI upper bound to "adapt_igi_up"*/
+	u16			igi_up_bound_lmt_val;	/*@max value of igi_up_bound_lmt_cnt*/
+	boolean			igi_lmt_en;
 	u8			adapt_igi_up;
-	s8			rvrt_val[2];
+	u32			rvrt_val[2];
 	s8			th_l2h;
 	s8			th_h2l;
+	u8			regulation_2g;
+	u8			regulation_5g;
+	boolean			is_adapt_en;
+	boolean			edcca_en;
+	s8			th_l2h_ini_mode2;
+	s8			th_edcca_hl_diff_mode2;
 };
 
-void
-phydm_pause_edcca(
-	void	*p_dm_void,
-	boolean	is_pasue_edcca
-);
-
-void
-phydm_check_environment(
-	void					*p_dm_void
-);
-
-void
-phydm_mac_edcca_state(
-	void					*p_dm_void,
-	enum phydm_mac_edcca_type		state
-);
-
-void
-phydm_set_edcca_threshold(
-	void		*p_dm_void,
-	s8		H2L,
-	s8		L2H
-);
-
-void
-phydm_set_trx_mux(
-	void			*p_dm_void,
-	enum phydm_trx_mux_type			tx_mode,
-	enum phydm_trx_mux_type			rx_mode
-);
-
-void
-phydm_search_pwdb_lower_bound(
-	void					*p_dm_void
-);
-
-void
-phydm_adaptivity_info_init(
-	void			*p_dm_void,
-	enum phydm_adapinfo_e	cmn_info,
-	u32				value
-);
-
-void
-phydm_adaptivity_init(
-	void					*p_dm_void
-);
-
-void
-phydm_adaptivity(
-	void			*p_dm_void
-);
-
-void
-phydm_set_edcca_threshold_api(
-	void	*p_dm_void,
-	u8	IGI
-);
-
-void
-phydm_pause_edcca_work_item_callback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
-#else
-	void			*p_dm_void
-#endif
-);
-
-void
-phydm_resume_edcca_work_item_callback(
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
-#else
-	void			*p_dm_void
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+void phydm_adaptivity_debug(void *dm_void, char input[][16], u32 *_used,
+			    char *output, u32 *_out_len);
+
+void phydm_set_edcca_val(void *dm_void, u32 *val_buf, u8 val_len);
 #endif
-);
-
-void
-phydm_adaptivity_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-void
-phydm_set_l2h_th_ini(
-	void		*p_dm_void
-);
-
-void
-phydm_set_forgetting_factor(
-	void		*p_dm_void
-);
-
-void
-phydm_set_pwdb_mode(
-	void		*p_dm_void
-);
-
-void
-phydm_set_edcca_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-);
+
+void phydm_set_edcca_threshold_api(void *dm_void, u8 IGI);
+
+void phydm_adaptivity_info_init(void *dm_void, enum phydm_adapinfo cmn_info,
+				u32 value);
+
+void phydm_adaptivity_info_update(void *dm_void, enum phydm_adapinfo cmn_info,
+				  u32 value);
+
+void phydm_adaptivity_init(void *dm_void);
+
+void phydm_adaptivity(void *dm_void);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.c
index 9ce6f1150131..b045467b8f4d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,274 +9,388 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
+#if (PHYDM_LA_MODE_SUPPORT)
+
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	#if ((RTL8197F_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
-		#include "rtl8197f/Hal8197FPhyReg.h"
-		#include "WlanHAL/HalMac88XX/halmac_reg2.h"
-	#else
-		#include "WlanHAL/HalHeader/HalComReg.h"
-	#endif
+#if (RTL8197F_SUPPORT || RTL8822B_SUPPORT || RTL8192F_SUPPORT)
+#include "rtl8197f/Hal8197FPhyReg.h"
+#include "WlanHAL/HalMac88XX/halmac_reg2.h"
+#else
+#include "WlanHAL/HalHeader/HalComReg.h"
 #endif
-
-#if (PHYDM_LA_MODE_SUPPORT == 1)
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
+#elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 #if WPP_SOFTWARE_TRACE
-	#include "phydm_adc_sampling.tmh"
+#include "phydm_adc_sampling.tmh"
 #endif
-
 #endif
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_AP))
 boolean
-phydm_la_buffer_allocate(
-	void			*p_dm_void
-)
+phydm_la_buffer_allocate(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP		*adc_smp = &(p_dm->adcsmp);
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-#endif
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
-	boolean	ret = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	void *adapter = dm->adapter;
+	#endif
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
+	boolean ret = true;
 
-	dbg_print("[LA mode BufferAllocate]\n");
+	pr_debug("[LA mode BufferAllocate]\n");
 
-	if (adc_smp_buf->length == 0) {
+	if (buf->length == 0) {
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		if (PlatformAllocateMemoryWithZero(adapter, (void **)&
+						   buf->octet,
+						   buf->buffer_size) !=
+						   RT_STATUS_SUCCESS)
+			ret = false;
+	#else
+		odm_allocate_memory(dm, (void **)&buf->octet, buf->buffer_size);
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		if (PlatformAllocateMemoryWithZero(adapter, (void **)&(adc_smp_buf->octet), adc_smp_buf->buffer_size) != RT_STATUS_SUCCESS) {
-#else
-		odm_allocate_memory(p_dm, (void **)&adc_smp_buf->octet, adc_smp_buf->buffer_size);
-		if (!adc_smp_buf->octet)	{
-#endif
+		if (!buf->octet)
 			ret = false;
-		} else
-			adc_smp_buf->length = adc_smp_buf->buffer_size;
-			ret = true;
+	#endif
+
+		if (ret)
+			buf->length = buf->buffer_size;
 	}
 
 	return ret;
 }
 #endif
 
-void
-phydm_la_get_tx_pkt_buf(
-	void			*p_dm_void
-)
+void phydm_la_get_tx_pkt_buf(void *dm_void)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP			*adc_smp = &(p_dm->adcsmp);
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
-	u32				i = 0, value32, data_l = 0, data_h = 0;
-	u32				addr, finish_addr;
-	u32				end_addr = (adc_smp_buf->start_pos  + adc_smp_buf->buffer_size) - 1;	/*end_addr = 0x3ffff;*/
-	boolean				is_round_up;
-	static u32			page = 0xFF;
-	u32				smp_cnt = 0, smp_number = 0, addr_8byte = 0;
-	u8				backup_dma = 0;
-
-	odm_memory_set(p_dm, adc_smp_buf->octet, 0, adc_smp_buf->length);
-	odm_write_1byte(p_dm, 0x0106, 0x69);
-
-	dbg_print("GetTxPktBuf\n");
-
-	value32 = odm_read_4byte(p_dm, 0x7c0);
-	is_round_up = (boolean)((value32 & BIT(31)) >> 31);
-	finish_addr = (value32 & 0x7FFF0000) >> 16;	/*Reg7C0[30:16]: finish addr (unit: 8byte)*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
+	u32 i = 0, value32 = 0, data_l = 0, data_h = 0;
+	u32 addr = 0, finish_addr = 0;
+	boolean is_round_up = false;
+	static u32 page = 0xFF;
+	u32 smp_cnt = 0, smp_number = 10, addr_8byte = 0;
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	#if (RTL8197F_SUPPORT || RTL8198F_SUPPORT)
+	u8 backup_dma = 0;
+	#endif
+	#endif
+
+	odm_memory_set(dm, buf->octet, 0, buf->length);
+	pr_debug("GetTxPktBuf\n");
+
+	if (dm->support_ic_type & ODM_RTL8192F) {
+		value32 = odm_read_4byte(dm, R_0x7f0);
+		is_round_up = (boolean)((value32 & BIT(31)) >> 31);
+		/*Reg7F0[30:15]: finish addr (unit: 8byte)*/
+		finish_addr = (value32 & 0x7FFF8000) >> 15;
+	} else {
+		odm_write_1byte(dm, R_0x0106, 0x69);
+		value32 = odm_read_4byte(dm, R_0x7c0);
+		is_round_up = (boolean)((value32 & BIT(31)) >> 31);
+		/*Reg7C0[30:16]: finish addr (unit: 8byte)*/
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8822C |
+		    ODM_RTL8821C | ODM_RTL8814A | ODM_RTL8814B | ODM_RTL8812F |
+		    ODM_RTL8195B))
+			finish_addr = (value32 & 0x7FFF0000) >> 16;
+		/*Reg7C0[30:15]: finish addr (unit: 8byte)*/
+		else if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8197F))
+			finish_addr = (value32 & 0x7FFF8000) >> 15;
+	}
 
 	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	#if (RTL8197F_SUPPORT)
-	if (p_dm->support_ic_type & ODM_RTL8197F) {
-		odm_set_bb_reg(p_dm, 0x7c0, BIT(0), 0x0);
-		
+	#if (RTL8197F_SUPPORT || RTL8198F_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8198F)) {
+		pr_debug("98F GetTxPktBuf from iMEM\n");
+		odm_set_bb_reg(dm, R_0x7c0, BIT(0), 0x0);
+
 		/*Stop DMA*/
-		backup_dma = odm_get_mac_reg(p_dm, 0x300, MASKLWORD);
-		odm_set_mac_reg(p_dm, 0x300, 0x7fff, 0x7fff);
+		backup_dma = odm_get_mac_reg(dm, R_0x300, MASKLWORD);
+		odm_set_mac_reg(dm, R_0x300, 0x7fff, 0x7fff);
 
-		/*move LA mode content from IMEM to TxPktBuffer
+		/*@move LA mode content from IMEM to TxPktBuffer
 			Source : OCPBASE_IMEM 0x00000000
 			Destination : OCPBASE_TXBUF 0x18780000
 			Length : 64K*/
-		GET_HAL_INTERFACE(p_dm->priv)->init_ddma_handler(p_dm->priv, OCPBASE_IMEM, OCPBASE_TXBUF, 0x10000);
+		GET_HAL_INTERFACE(dm->priv)->init_ddma_handler(dm->priv,
+							       OCPBASE_IMEM,
+							       OCPBASE_TXBUF
+							       + buf->start_pos,
+							       0x10000);
 	}
 	#endif
 	#endif
 
+	pr_debug("start_addr = ((0x%x)), end_addr = ((0x%x)), buffer_size = ((0x%x))\n",
+		 buf->start_pos, buf->end_pos, buf->buffer_size);
 	if (is_round_up) {
+		pr_debug("buf_start(0x%x)|----2---->|finish_addr(0x%x)|----1---->|buf_end(0x%x)\n",
+			 buf->start_pos, finish_addr << 3, buf->end_pos);
 		addr = (finish_addr + 1) << 3;
-		dbg_print("is_round_up = ((%d)), finish_addr=((0x%x)), 0x7c0=((0x%x))\n", is_round_up, finish_addr, value32);
-		smp_number = ((adc_smp_buf->buffer_size) >> 3);	/*Byte to 8Byte (64bit)*/
-	} else	 {
-		addr = adc_smp_buf->start_pos;
+		pr_debug("is_round_up = ((%d)), finish_addr=((0x%x)), 0x7c0/0x7F0=((0x%x))\n",
+			 is_round_up, finish_addr, value32);
+		/*@Byte to 8Byte (64bit)*/
+		smp_number = (buf->buffer_size) >> 3;
+	} else {
+		pr_debug("buf_start(0x%x)|------->|finish_addr(0x%x)             |buf_end(0x%x)\n",
+			 buf->start_pos, finish_addr << 3, buf->end_pos);
+		addr = buf->start_pos;
 		addr_8byte = addr >> 3;
-		
+
 		if (addr_8byte > finish_addr)
 			smp_number = addr_8byte - finish_addr;
 		else
 			smp_number = finish_addr - addr_8byte;
 
-		dbg_print("is_round_up = ((%d)), finish_addr=((0x%x * 8Byte)), Start_Addr = ((0x%x * 8Byte)), smp_number = ((%d))\n", is_round_up, finish_addr, addr_8byte, smp_number);
-
+		pr_debug("is_round_up = ((%d)), finish_addr=((0x%x * 8Byte)), Start_Addr = ((0x%x * 8Byte)), smp_number = ((%d))\n",
+			 is_round_up, finish_addr, addr_8byte, smp_number);
 	}
-	/*
-	dbg_print("is_round_up = %d, finish_addr=0x%x, value32=0x%x\n", is_round_up, finish_addr, value32);
-	dbg_print("end_addr = %x, adc_smp_buf->start_pos = 0x%x, adc_smp_buf->buffer_size = 0x%x\n", end_addr, adc_smp_buf->start_pos, adc_smp_buf->buffer_size);
-	*/
+	#if 0
+	dbg_print("is_round_up = %d, finish_addr=0x%x, value32=0x%x\n",
+		  is_round_up, finish_addr, value32);
+	dbg_print(
+		  "end_addr = %x, buf->start_pos = 0x%x, buf->buffer_size = 0x%x\n",
+		  end_addr, buf->start_pos, buf->buffer_size);
+	#endif
 
-	if (p_dm->support_ic_type & ODM_RTL8197F) {
-		for (addr = 0x0, i = 0; addr < end_addr; addr += 8, i += 2) {	/*64K byte*/
+	#if (RTL8197F_SUPPORT || RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type &
+	    (ODM_RTL8197F | ODM_RTL8198F | ODM_RTL8814B)) {
+		for (addr = buf->start_pos, i = 0; addr < buf->end_pos;
+		     addr += 8, i += 2) {
 			if ((addr & 0xfff) == 0)
-				odm_set_bb_reg(p_dm, 0x0140, MASKLWORD, 0x780 + (addr >> 12));
-			data_l = odm_get_bb_reg(p_dm, 0x8000 + (addr & 0xfff), MASKDWORD);
-			data_h = odm_get_bb_reg(p_dm, 0x8000 + (addr & 0xfff) + 4, MASKDWORD);
-
-			dbg_print("%08x%08x\n", data_h, data_l);
+				odm_set_bb_reg(dm, R_0x0140, MASKLWORD, 0x780 +
+					       (addr >> 12));
+			data_l = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff),
+						MASKDWORD);
+			data_h = odm_get_bb_reg(dm, 0x8000 + (addr & 0xfff) +
+						4, MASKDWORD);
+			buf->octet[i] = data_h;
+			buf->octet[i + 1] = data_l;
+
+			if (smp->is_la_print)
+				pr_debug("%08x%08x\n", data_h, data_l);
 		}
-	} else {
-	
-		i = 0;
-		while (addr != (finish_addr << 3)) {
-			if (page != (addr >> 12)) {
-				/*Reg140=0x780+(addr>>12), addr=0x30~0x3F, total 16 pages*/
-				page = (addr >> 12);
-			}
-			odm_set_bb_reg(p_dm, 0x0140, MASKLWORD, 0x780 + page);
-
-			/*pDataL = 0x8000+(addr&0xfff);*/
-			data_l = odm_get_bb_reg(p_dm, 0x8000 + (addr & 0xfff), MASKDWORD);
-			data_h = odm_get_bb_reg(p_dm, 0x8000 + (addr & 0xfff) + 4, MASKDWORD);
-
-			#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-			adc_smp_buf->octet[i] = data_h;
-			adc_smp_buf->octet[i + 1] = data_l;
-			#endif
-
-		#if DBG /*WIN driver check build*/
-			dbg_print("%08x%08x\n", data_h, data_l);
-		#else	/*WIN driver free build*/
+	} else
+	#endif
+	{
+		for (i = 0; smp_cnt < smp_number; smp_cnt++, i += 2) {
+			if (dm->support_ic_type & ODM_RTL8192F) {
 			#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-			RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("%08x%08x\n", adc_smp_buf->octet[i], adc_smp_buf->octet[i + 1]));
+				indirect_access_sdram_8192f(dm->adapter,
+							    TX_PACKET_BUFFER,
+							    TRUE,
+							    (u16)addr >> 3, 0,
+							    &data_h, &data_l);
+			#else
+			odm_write_1byte(dm, R_0x0106, 0x69);
+			odm_set_bb_reg(dm, R_0x0140, MASKDWORD, addr >> 3);
+			data_l = odm_get_bb_reg(dm, R_0x0144, MASKDWORD);
+			data_h = odm_get_bb_reg(dm, R_0x0148, MASKDWORD);
+			odm_write_1byte(dm, R_0x0106, 0x0);
 			#endif
-		#endif
-
-			i = i + 2;
 
-			if ((addr + 8) >= end_addr)
-				addr = adc_smp_buf->start_pos;
+			} else {
+				if (page != (addr >> 12)) {
+				/* Reg140=0x780+(addr>>12),
+				 * addr=0x30~0x3F, total 16 pages
+				 */
+					page = addr >> 12;
+				}
+				odm_set_bb_reg(dm, R_0x0140, MASKLWORD, 0x780 +
+					       page);
+
+				/*pDataL = 0x8000+(addr&0xfff);*/
+				data_l = odm_get_bb_reg(dm, 0x8000 + (addr &
+							0xfff),	MASKDWORD);
+				data_h = odm_get_bb_reg(dm, 0x8000 + (addr &
+							0xfff) + 4, MASKDWORD);
+			}
+			#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+			buf->octet[i] = data_h;
+			buf->octet[i + 1] = data_l;
+			#endif
+			if (smp->is_la_print) {
+				#if DBG /*WIN driver check build*/
+				pr_debug("%08x%08x\n", data_h, data_l);
+				#else	/*WIN driver free build*/
+				#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+				RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD,
+					    ("%08x%08x\n", buf->octet[i],
+					    buf->octet[i + 1]));
+				#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+				pr_debug("%08x%08x\n", data_h, data_l);
+				#endif
+				#endif
+			}
+			if ((addr + 8) > buf->end_pos)
+				addr = buf->start_pos;
 			else
 				addr = addr + 8;
-
-			smp_cnt++;
-			if (smp_cnt >= (smp_number - 1))
-				break;
 		}
-		dbg_print("smp_cnt = ((%d))\n", smp_cnt);
-		
+		pr_debug("smp_cnt = ((%d))\n", smp_cnt);
+
 		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("smp_cnt = ((%d))\n", smp_cnt));
+		RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD,
+			    ("smp_cnt = ((%d))\n", smp_cnt));
 		#endif
 	}
-
 	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
 	#if (RTL8197F_SUPPORT)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		odm_set_mac_reg(p_dm, 0x300, 0x7fff, backup_dma);	/*Resume DMA*/
+	if (dm->support_ic_type & ODM_RTL8197F)
+		odm_set_mac_reg(dm, R_0x300, 0x7fff, backup_dma);/*Resume DMA*/
 	#endif
 	#endif
 }
 
-void
-phydm_la_mode_set_mac_iq_dump(
-	void		*p_dm_void
-)
+void phydm_la_mode_set_mac_iq_dump(void *dm_void, boolean en_fake_trig)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP		*adc_smp = &(p_dm->adcsmp);
-	u32			reg_value;
-
-	odm_write_1byte(p_dm, 0x7c0, 0);		/*clear all 0x7c0*/
-	odm_set_mac_reg(p_dm, 0x7c0, BIT(0), 1);  /*Enable LA mode HW block*/
-
-	if (adc_smp->la_trig_mode == PHYDM_MAC_TRIG) {
-
-		adc_smp->is_bb_trigger = 0;
-		odm_set_mac_reg(p_dm, 0x7c0, BIT(2), 1); /*polling bit for MAC mode*/
-		odm_set_mac_reg(p_dm, 0x7c0, BIT(4) | BIT(3), adc_smp->la_trigger_edge); /*trigger mode for MAC*/
-
-		dbg_print("[MAC_trig] ref_mask = ((0x%x)), ref_value = ((0x%x)), dbg_port = ((0x%x))\n", adc_smp->la_mac_mask_or_hdr_sel, adc_smp->la_trig_sig_sel, adc_smp->la_dbg_port);
-		/*[Set MAC Debug Port]*/
-		odm_set_mac_reg(p_dm, 0xF4, BIT(16), 1);
-		odm_set_mac_reg(p_dm, 0x38, 0xff0000, adc_smp->la_dbg_port);
-		odm_set_mac_reg(p_dm, 0x7c4, MASKDWORD, adc_smp->la_mac_mask_or_hdr_sel);
-		odm_set_mac_reg(p_dm, 0x7c8, MASKDWORD, adc_smp->la_trig_sig_sel);
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	u32 reg_value = 0;
+	u32 reg1 = 0, reg2 = 0, reg3 = 0;
+
+	if (dm->support_ic_type & ODM_RTL8192F) {
+		reg1 = R_0x7f0;
+		reg2 = R_0x7f4;
+		reg3 = R_0x7f8;
 	} else {
+		reg1 = R_0x7c0;
+		reg2 = R_0x7c4;
+		reg3 = R_0x7c8;
+	}
 
-		adc_smp->is_bb_trigger = 1;
-		odm_set_mac_reg(p_dm, 0x7c0, BIT(1), 1); /*polling bit for BB ADC mode*/
-
-		if (adc_smp->la_trig_mode == PHYDM_ADC_MAC_TRIG) {
-
-			odm_set_mac_reg(p_dm, 0x7c0, BIT(3), 1); /*polling bit for MAC trigger event*/
-			odm_set_mac_reg(p_dm, 0x7c0, BIT(7) | BIT(6), adc_smp->la_trig_sig_sel);
+	odm_write_1byte(dm, reg1, 0); /*@clear all reg1*/
+	/*@Enable LA mode HW block*/
+	odm_set_mac_reg(dm, reg1, BIT(0), 1);
+
+	if (smp->la_trig_mode == PHYDM_MAC_TRIG) {
+		smp->is_bb_trigger = 0;
+		/*polling bit for MAC mode*/
+		odm_set_mac_reg(dm, reg1, BIT(2), 1);
+		/*trigger mode for MAC*/
+		odm_set_mac_reg(dm, reg1, BIT(4) | BIT(3),
+				smp->la_trigger_edge);
+		pr_debug("[MAC_trig] ref_mask = ((0x%x)), ref_value = ((0x%x)), dbg_port = ((0x%x))\n",
+			 smp->la_mac_mask_or_hdr_sel, smp->la_trig_sig_sel,
+			 smp->la_dbg_port);
+		/*@[Set MAC Debug Port]*/
+		odm_set_mac_reg(dm, R_0xf4, BIT(16), 1);
+		odm_set_mac_reg(dm, R_0x38, 0xff0000, smp->la_dbg_port);
+		odm_set_mac_reg(dm, reg2, MASKDWORD,
+				smp->la_mac_mask_or_hdr_sel);
+		odm_set_mac_reg(dm, reg3, MASKDWORD, smp->la_trig_sig_sel);
 
-			if (adc_smp->la_trig_sig_sel == ADCSMP_TRIG_REG)
-				odm_set_mac_reg(p_dm, 0x7c0, BIT(5), 1); /* manual trigger 0x7C0[5] = 0->1*/
+	} else {
+		smp->is_bb_trigger = 1;
+
+		if (smp->la_trig_mode == PHYDM_ADC_MAC_TRIG) {
+			/*polling bit for MAC trigger event*/
+			if (!en_fake_trig)
+				odm_set_mac_reg(dm, reg1, BIT(3), 1);
+
+			odm_set_mac_reg(dm, reg1, BIT(7) | BIT(6),
+					smp->la_trig_sig_sel);
+			if (smp->la_trig_sig_sel == ADCSMP_TRIG_REG)
+				/* @manual trigger reg1[5] = 0->1*/
+				odm_set_mac_reg(dm, reg1, BIT(5), 1);
 		}
+		/*polling bit for BB ADC mode*/
+		odm_set_mac_reg(dm, reg1, BIT(1), 1);
 	}
 
-	reg_value = odm_get_bb_reg(p_dm, 0x7c0, 0xff);
-	dbg_print("4. [Set MAC IQ dump] 0x7c0[7:0] = ((0x%x))\n", reg_value);
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("4. [Set MAC IQ dump] 0x7c0[7:0] = ((0x%x))\n", reg_value));
-#endif
+	reg_value = odm_get_bb_reg(dm, reg1, 0xff);
+	pr_debug("4. [Set MAC IQ dump] 0x%x[7:0] = ((0x%x))\n", reg1,
+		 reg_value);
 
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD,
+		    ("4. [Set MAC IQ dump] 0x%x[7:0] = ((0x%x))\n", reg1,
+		    reg_value));
+	#endif
 }
 
-void
-phydm_adc_smp_start(
-	void			*p_dm_void
-)
+void phydm_adc_smp_start(void *dm_void)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP				*adc_smp = &(p_dm->adcsmp);
-	u8					tmp_u1b;
-	u8					while_cnt = 0;
-	u8					polling_ok = false, target_polling_bit;
-
-	phydm_la_mode_bb_setting(p_dm);
-	phydm_la_mode_set_trigger_time(p_dm, adc_smp->la_trigger_time);
-
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		odm_set_bb_reg(p_dm, 0xd00, BIT(26), 0x1);
-	else {	/*for 8814A and 8822B?*/
-		odm_write_1byte(p_dm, 0x8b4, 0x80);
-		/* odm_set_bb_reg(p_dm, 0x8b4, BIT(7), 1); */
-	}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	u8 tmp_u1b = 0;
+	u8 while_cnt = 0;
+	u8 target_polling_bit = 0;
+	boolean polling_ok = false;
+
+	if (smp->en_fake_trig)
+		smp->is_fake_trig = true;
+	else
+		smp->is_fake_trig = false;
+
+	phydm_la_mode_bb_setting(dm, smp->en_fake_trig);
+	phydm_la_mode_set_trigger_time(dm, smp->la_trigger_time);
+
+	if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+		odm_set_bb_reg(dm, R_0xd00, BIT(26), 0x1);
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		odm_set_bb_reg(dm, R_0x1eb4, BIT(23), 0x1);
+	else
+		odm_write_1byte(dm, R_0x8b4, 0x80);
+#if 0
+		/* odm_set_bb_reg(dm, R_0x8b4, BIT(7), 1); */
+#endif
 
-	phydm_la_mode_set_mac_iq_dump(p_dm);
+	phydm_la_mode_set_mac_iq_dump(dm, smp->en_fake_trig);
 
 	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	watchdog_stop(p_dm->priv);
+	watchdog_stop(dm->priv);
 	#endif
 
-	target_polling_bit = (adc_smp->is_bb_trigger) ? BIT(1) : BIT(2);
-	do { /*Polling time always use 100ms, when it exceed 2s, break while loop*/
-		tmp_u1b = odm_read_1byte(p_dm, 0x7c0);
+	if (smp->en_fake_trig) {
+		ODM_delay_ms(100);
+		smp->is_fake_trig = false;
+		phydm_la_mode_bb_setting(dm, smp->en_fake_trig);
+
+		if (smp->la_trig_mode == PHYDM_ADC_MAC_TRIG) {
+			if (dm->support_ic_type & ODM_RTL8192F)
+				odm_set_mac_reg(dm, R_0x7f0, BIT(3), 1);
+			else
+				odm_set_mac_reg(dm, R_0x7c0, BIT(3), 1);
+		}
+	}
+#if RTL8198F_SUPPORT
+	phydm_la_pre_run(dm);
+#endif
+
+	target_polling_bit = (smp->is_bb_trigger) ? BIT(1) : BIT(2);
+	do { /*Polling time always use 100ms, when it exceed 2s, break loop*/
+		if (dm->support_ic_type & ODM_RTL8192F) {
+			tmp_u1b = odm_read_1byte(dm, R_0x7f0);
+			pr_debug("[%d], 0x7F0[7:0] = ((0x%x))\n", while_cnt,
+				 tmp_u1b);
+		} else {
+			tmp_u1b = odm_read_1byte(dm, R_0x7c0);
+			pr_debug("[%d], 0x7C0[7:0] = ((0x%x))\n", while_cnt,
+				 tmp_u1b);
+		}
 
-		if (adc_smp->adc_smp_state != ADCSMP_STATE_SET) {
-			dbg_print("[state Error] adc_smp_state != ADCSMP_STATE_SET\n");
+		if (smp->adc_smp_state != ADCSMP_STATE_SET) {
+			pr_debug("[state Error] adc_smp_state != ADCSMP_STATE_SET\n");
 			break;
 
 		} else if (tmp_u1b & target_polling_bit) {
@@ -283,485 +398,895 @@ phydm_adc_smp_start(
 			while_cnt = while_cnt + 1;
 			continue;
 		} else {
-			dbg_print("[LA Query OK] polling_bit=((0x%x))\n", target_polling_bit);
+			pr_debug("[LA Query OK] polling_bit=((0x%x))\n",
+				 target_polling_bit);
 			polling_ok = true;
 			break;
 		}
 	} while (while_cnt < 20);
 
-	if (adc_smp->adc_smp_state == ADCSMP_STATE_SET) {
-
+	if (smp->adc_smp_state == ADCSMP_STATE_SET) {
 		if (polling_ok)
-			phydm_la_get_tx_pkt_buf(p_dm);
+			phydm_la_get_tx_pkt_buf(dm);
 		else
-			dbg_print("[Polling timeout]\n");
+			pr_debug("[Polling timeout]\n");
 	}
 
 	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	watchdog_resume(p_dm->priv);
+	watchdog_resume(dm->priv);
 	#endif
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	if (adc_smp->adc_smp_state == ADCSMP_STATE_SET)
-		adc_smp->adc_smp_state = ADCSMP_STATE_QUERY;
-#endif
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	if (smp->adc_smp_state == ADCSMP_STATE_SET)
+		smp->adc_smp_state = ADCSMP_STATE_QUERY;
+	#endif
 
-	dbg_print("[LA mode] LA_pattern_count = ((%d))\n", adc_smp->la_count);
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("[LA mode] la_count = ((%d))\n", adc_smp->la_count));
-#endif
+	pr_debug("[LA mode] LA_pattern_count = ((%d))\n", smp->la_count);
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD,
+		    ("[LA mode] la_count = ((%d))\n", smp->la_count));
+	#endif
 
+	adc_smp_stop(dm);
 
-	adc_smp_stop(p_dm);
+	if (smp->la_count == 0) {
+		pr_debug("LA Dump finished ---------->\n\n\n");
+		phydm_release_bb_dbg_port(dm);
 
-	if (adc_smp->la_count == 0) {
-		dbg_print("LA Dump finished ---------->\n\n\n");
-		phydm_release_bb_dbg_port(p_dm);
-		
-		if ((p_dm->support_ic_type & ODM_RTL8821C) && (p_dm->cut_version >= ODM_CUT_B))
-			odm_set_bb_reg(p_dm, 0x95c, BIT(23), 0);
+		if ((dm->support_ic_type & ODM_RTL8821C) &&
+		    dm->cut_version >= ODM_CUT_B)
+			odm_set_bb_reg(dm, R_0x95c, BIT(23), 0);
+		else if (dm->support_ic_type & ODM_RTL8195B)
+			odm_set_bb_reg(dm, R_0x95c, BIT(23), 0);
 
 	} else {
-		adc_smp->la_count--;
-		dbg_print("LA Dump more ---------->\n\n\n");
-		adc_smp_set(p_dm, adc_smp->la_trig_mode, adc_smp->la_trig_sig_sel, adc_smp->la_dma_type, adc_smp->la_trigger_time, 0);
+		smp->la_count--;
+		pr_debug("LA Dump more ---------->\n\n\n");
+		adc_smp_set(dm, smp->la_trig_mode, smp->la_trig_sig_sel,
+			    smp->la_dma_type, smp->la_trigger_time, 0);
 	}
-
 }
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-void
-adc_smp_work_item_callback(
-	void	*p_context
-)
+void adc_smp_work_item_callback(void *context)
 {
-	struct _ADAPTER			*adapter = (struct _ADAPTER *)p_context;
-	PHAL_DATA_TYPE		p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
-	struct _RT_ADCSMP		*adc_smp = &(p_dm->adcsmp);
+	void *adapter = (void *)context;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	struct rt_adcsmp *smp = &dm->adcsmp;
 
-	dbg_print("[WorkItem Call back] LA_State=((%d))\n", adc_smp->adc_smp_state);
-	phydm_adc_smp_start(p_dm);
+	pr_debug("[WorkItem Call back] LA_State=((%d))\n", smp->adc_smp_state);
+	phydm_adc_smp_start(dm);
 }
 #endif
 
-void
-adc_smp_set(
-	void	*p_dm_void,
-	u8	trig_mode,
-	u32	trig_sig_sel,
-	u8	dma_data_sig_sel,
-	u32	trigger_time,
-	u16	polling_time
-)
+void adc_smp_set(void *dm_void, u8 trig_mode, u32 trig_sig_sel,
+		 u8 dma_data_sig_sel, u32 trig_time, u16 polling_time)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean				is_set_success = true;
-	struct _RT_ADCSMP			*adc_smp = &(p_dm->adcsmp);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean is_set_success = true;
+	struct rt_adcsmp *smp = &dm->adcsmp;
 
-	adc_smp->la_trig_mode = trig_mode;
-	adc_smp->la_trig_sig_sel = trig_sig_sel;
-	adc_smp->la_dma_type = dma_data_sig_sel;
-	adc_smp->la_trigger_time = trigger_time;
+	smp->la_trig_mode = trig_mode;
+	smp->la_trig_sig_sel = trig_sig_sel;
+	smp->la_dma_type = dma_data_sig_sel;
+	smp->la_trigger_time = trig_time;
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	if (adc_smp->adc_smp_state != ADCSMP_STATE_IDLE)
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_AP))
+	if (smp->adc_smp_state != ADCSMP_STATE_IDLE)
 		is_set_success = false;
-	else if (adc_smp->adc_smp_buf.length == 0)
-		is_set_success = phydm_la_buffer_allocate(p_dm);
-#endif
+	else if (smp->adc_smp_buf.length == 0)
+		is_set_success = phydm_la_buffer_allocate(dm);
+	#endif
 
 	if (is_set_success) {
-		adc_smp->adc_smp_state = ADCSMP_STATE_SET;
+		smp->adc_smp_state = ADCSMP_STATE_SET;
 
-		dbg_print("[LA Set Success] LA_State=((%d))\n", adc_smp->adc_smp_state);
+		pr_debug("[LA Set Success] LA_State=((%d))\n",
+			 smp->adc_smp_state);
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 
-		dbg_print("ADCSmp_work_item_index = ((%d))\n", adc_smp->la_work_item_index);
-		if (adc_smp->la_work_item_index != 0) {
-			odm_schedule_work_item(&(adc_smp->adc_smp_work_item_1));
-			adc_smp->la_work_item_index = 0;
+		pr_debug("ADCSmp_work_item_index = ((%d))\n",
+			 smp->la_work_item_index);
+		if (smp->la_work_item_index != 0) {
+			odm_schedule_work_item(&smp->adc_smp_work_item_1);
+			smp->la_work_item_index = 0;
 		} else {
-			odm_schedule_work_item(&(adc_smp->adc_smp_work_item));
-			adc_smp->la_work_item_index = 1;
+			odm_schedule_work_item(&smp->adc_smp_work_item);
+			smp->la_work_item_index = 1;
 		}
-#else
-		phydm_adc_smp_start(p_dm);
-#endif
-	} else
-		dbg_print("[LA Set Fail] LA_State=((%d))\n", adc_smp->adc_smp_state);
-
-
+		#else
+		phydm_adc_smp_start(dm);
+		#endif
+	} else {
+		pr_debug("[LA Set Fail] LA_State=((%d))\n", smp->adc_smp_state);
+	}
 }
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 enum rt_status
-adc_smp_query(
-	void				*p_dm_void,
-	ULONG				information_buffer_length,
-	void				*information_buffer,
-	PULONG				bytes_written
-)
+adc_smp_query(void *dm_void, ULONG info_buf_length, void *info_buf,
+	      PULONG bytes_written)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP			*adc_smp = &(p_dm->adcsmp);
-	enum rt_status			ret_status = RT_STATUS_SUCCESS;
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	enum rt_status ret_status = RT_STATUS_SUCCESS;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
 
-	dbg_print("[%s] LA_State=((%d))", __func__, adc_smp->adc_smp_state);
+	pr_debug("[%s] LA_State=((%d))", __func__, smp->adc_smp_state);
 
-	if (information_buffer_length != adc_smp_buf->buffer_size)	{
+	if (info_buf_length != buf->buffer_size) {
 		*bytes_written = 0;
 		ret_status = RT_STATUS_RESOURCE;
-	} else if (adc_smp_buf->length != adc_smp_buf->buffer_size) {
+	} else if (buf->length != buf->buffer_size) {
 		*bytes_written = 0;
 		ret_status = RT_STATUS_RESOURCE;
-	} else if (adc_smp->adc_smp_state != ADCSMP_STATE_QUERY) {
+	} else if (smp->adc_smp_state != ADCSMP_STATE_QUERY) {
 		*bytes_written = 0;
 		ret_status = RT_STATUS_PENDING;
 	} else {
-		odm_move_memory(p_dm, information_buffer, adc_smp_buf->octet, adc_smp_buf->buffer_size);
-		*bytes_written = adc_smp_buf->buffer_size;
+		odm_move_memory(dm, info_buf, buf->octet, buf->buffer_size);
+		*bytes_written = buf->buffer_size;
 
-		adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
+		smp->adc_smp_state = ADCSMP_STATE_IDLE;
 	}
 
-	dbg_print("Return status %d\n", ret_status);
+	pr_debug("Return status %d\n", ret_status);
 
 	return ret_status;
 }
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 
-void
-adc_smp_query(
-	void		*p_dm_void,
-	void		*output,
-	u32		out_len,
-	u32		*pused
-)
+void adc_smp_query(void *dm_void, void *output, u32 out_len, u32 *pused)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP			*adc_smp = &(p_dm->adcsmp);
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
 	u32 used = *pused;
-	u32 i;
+	u32 i = 0;
+#if 0
 	/* struct timespec t; */
 	/* rtw_get_current_timespec(&t); */
+#endif
 
-	dbg_print("%s adc_smp_state %d", __func__, adc_smp->adc_smp_state);
+	pr_debug("%s adc_smp_state %d", __func__, smp->adc_smp_state);
 
-	for (i = 0; i < (adc_smp_buf->length >> 2) - 2; i += 2) {
-		PHYDM_SNPRINTF((output + used, out_len - used,
-			"%08x%08x\n", adc_smp_buf->octet[i], adc_smp_buf->octet[i + 1]));
+	for (i = 0; i < (buf->length >> 2) - 2; i += 2) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%08x%08x\n", buf->octet[i], buf->octet[i + 1]);
 	}
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n"));
-	/* PHYDM_SNPRINTF((output+used, out_len-used, "\n[%lu.%06lu]\n", t.tv_sec, t.tv_nsec)); */
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n");
+	/* PDM_SNPF(output + used, out_len - used, "\n[%lu.%06lu]\n", */
+	/*	    t.tv_sec, t.tv_nsec); */
 	*pused = used;
 }
 
-s32
-adc_smp_get_sample_counts(
-	void		*p_dm_void
-)
+s32 adc_smp_get_sample_counts(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP		*adc_smp = &(p_dm->adcsmp);
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
 
-	return (adc_smp_buf->length >> 2) - 2;
+	return (buf->length >> 2) - 2;
 }
 
-s32
-adc_smp_query_single_data(
-	void		*p_dm_void,
-	void		*output,
-	u32		out_len,
-	u32		index
-)
+s32 adc_smp_query_single_data(void *dm_void, void *output, u32 out_len, u32 idx)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP		*adc_smp = &(p_dm->adcsmp);
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
 	u32 used = 0;
 
-	/* dbg_print("%s adc_smp_state %d\n", __func__, adc_smp->adc_smp_state); */
-	if (adc_smp->adc_smp_state != ADCSMP_STATE_QUERY) {
-		PHYDM_SNPRINTF((output + used, out_len - used,
-				"Error: la data is not ready yet ...\n"));
+	/* @dbg_print("%s adc_smp_state %d\n", __func__,*/
+	/*	      smp->adc_smp_state);*/
+	if (smp->adc_smp_state != ADCSMP_STATE_QUERY) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Error: la data is not ready yet ...\n");
 		return -1;
 	}
 
-	if (index < ((adc_smp_buf->length >> 2) - 2)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "%08x%08x\n",
-			adc_smp_buf->octet[index], adc_smp_buf->octet[index + 1]));
+	if (idx < ((buf->length >> 2) - 2)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%08x%08x\n", buf->octet[idx], buf->octet[idx + 1]);
 	}
 	return 0;
 }
 
 #endif
 
-void
-adc_smp_stop(
-	void			*p_dm_void
-)
+void adc_smp_stop(void *dm_void)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP			*adc_smp = &(p_dm->adcsmp);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+
+	smp->adc_smp_state = ADCSMP_STATE_IDLE;
 
-	adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
-	dbg_print("[LA_Stop] LA_state = ((%d))\n", adc_smp->adc_smp_state);
+	PHYDM_DBG(dm, DBG_TMP, "[LA_Stop] LA_state = %d\n", smp->adc_smp_state);
 }
 
-void
-adc_smp_init(
-	void			*p_dm_void
-)
+void adc_smp_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP			*adc_smp = &(p_dm->adcsmp);
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
-
-	adc_smp->adc_smp_state = ADCSMP_STATE_IDLE;
-
-	if (p_dm->support_ic_type & ODM_RTL8814A) {
-		adc_smp_buf->start_pos = 0x30000;
-		adc_smp_buf->buffer_size = 0x10000;
-	} else if (p_dm->support_ic_type & ODM_RTL8822B) {
-		adc_smp_buf->start_pos = 0x20000;
-		adc_smp_buf->buffer_size = 0x20000;
-	} else if (p_dm->support_ic_type & ODM_RTL8197F) {
-		adc_smp_buf->start_pos = 0x00000;
-		adc_smp_buf->buffer_size = 0x10000;
-	} else if (p_dm->support_ic_type & ODM_RTL8821C) {
-		adc_smp_buf->start_pos = 0x8000;
-		adc_smp_buf->buffer_size = 0x8000;
-	}
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
+
+	smp->adc_smp_state = ADCSMP_STATE_IDLE;
+	smp->is_la_print = true;
+	smp->is_fake_trig = false;
+	smp->en_fake_trig = false;
+	phydm_la_set_buff_mode(dm, ADCSMP_BUFF_HALF);
+
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	phydm_la_bb_adv_reset_jgr3(dm);
+	#endif
 }
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-void
-adc_smp_de_init(
-	void			*p_dm_void
-)
+void adc_smp_de_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP			*adc_smp = &(p_dm->adcsmp);
-	struct _RT_ADCSMP_STRING	*adc_smp_buf = &(adc_smp->adc_smp_buf);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
 
-	adc_smp_stop(p_dm);
+	adc_smp_stop(dm);
 
-	if (adc_smp_buf->length != 0x0) {
-		odm_free_memory(p_dm, adc_smp_buf->octet, adc_smp_buf->length);
-		adc_smp_buf->length = 0x0;
+	if (buf->length != 0x0) {
+		odm_free_memory(dm, buf->octet, buf->length);
+		buf->length = 0x0;
 	}
 }
 
 #endif
 
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
 
-void
-phydm_la_mode_bb_setting(
-	void		*p_dm_void
-)
+void phydm_la_bb_adv_reset_jgr3(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP		*adc_smp = &(p_dm->adcsmp);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+
+	smp->la_en_new_bbtrigger = false;
+
+	smp->la_ori_bb_dis = false;
+	smp->la_and1_sel = 0;
+	smp->la_and1_val = 0;
+	smp->la_and2_sel = 0;
+	smp->la_and2_val = 0;
+	smp->la_and3_sel = 0;
+	smp->la_and3_val = 0;
+	smp->la_and4_en = 0;
+	smp->la_and4_val = 0;
+}
 
-	u8	trig_mode = adc_smp->la_trig_mode;
-	u32	trig_sig_sel = adc_smp->la_trig_sig_sel;
-	u32	dbg_port = adc_smp->la_dbg_port;
-	u8	is_trigger_edge = adc_smp->la_trigger_edge;
-	u8	sampling_rate = adc_smp->la_smp_rate;
-	u8	la_dma_type = adc_smp->la_dma_type;
-	u32	dbg_port_header_sel = 0;
+void phydm_la_bb_adv_cmd_jgr3(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 enable;
+
+	if (!(dm->support_ic_type & ODM_IC_JGR3_SERIES))
+		return;
+
+	PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[0]);
+
+	enable = var1[0];
+
+	if (enable == 1) {
+		smp->la_en_new_bbtrigger = true;
+
+		PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[1]);
+		PHYDM_SSCANF(input[5], DCMD_DECIMAL, &var1[2]);
+		PHYDM_SSCANF(input[6], DCMD_HEX, &var1[3]);
+		PHYDM_SSCANF(input[7], DCMD_DECIMAL, &var1[4]);
+		PHYDM_SSCANF(input[8], DCMD_HEX, &var1[5]);
+		PHYDM_SSCANF(input[9], DCMD_DECIMAL, &var1[6]);
+		PHYDM_SSCANF(input[10], DCMD_HEX, &var1[7]);
+		PHYDM_SSCANF(input[11], DCMD_HEX, &var1[8]);
+		PHYDM_SSCANF(input[12], DCMD_HEX, &var1[9]);
+
+		smp->la_ori_bb_dis = (boolean)var1[1];
+		smp->la_and1_sel = (u8)var1[2];
+		smp->la_and1_val = (u8)var1[3];
+		smp->la_and2_sel = (u8)var1[4];
+		smp->la_and2_val = (u8)var1[5];
+		smp->la_and3_sel = (u8)var1[6];
+		smp->la_and3_val = (u8)var1[7];
+		smp->la_and4_en = (u32)var1[8];
+		smp->la_and4_val = (u32)var1[9];
+	} else {
+		phydm_la_bb_adv_reset_jgr3(dm);
+	}
 
-	dbg_print("1. [BB Setting] trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
-		trig_mode, dbg_port, is_trigger_edge, sampling_rate, trig_sig_sel, la_dma_type);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "{en %d} {C0_dis %d} {C1_sel %d} {C1_val %d} {C2_sel %d} {C2_val %d}\n{C3_sel %d} {C3_val %d} {C4_en %d}{C4_val %d}\n",
+		 enable, smp->la_ori_bb_dis, smp->la_and1_sel, smp->la_and1_val,
+		 smp->la_and2_sel, smp->la_and2_val,
+		 smp->la_and3_sel, smp->la_and3_val,
+		 smp->la_and4_en, smp->la_and4_val);
+}
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("1. [LA mode bb_setting]trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
-		trig_mode, dbg_port, is_trigger_edge, sampling_rate, trig_sig_sel, la_dma_type));
 #endif
 
+void phydm_la_mode_bb_setting(void *dm_void, boolean en_fake_trig)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+
+	u8	trig_mode = smp->la_trig_mode;
+	u32	trig_sel = smp->la_trig_sig_sel;
+	u32	dbg_port = smp->la_dbg_port;
+	u8	edge = smp->la_trigger_edge;
+	u8	smp_rate = smp->la_smp_rate;
+	u8	dma_type = smp->la_dma_type;
+	u8	is_fake_trig = smp->is_fake_trig;
+	u32	dbg_port_hdr_sel = 0;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	boolean en_new_bbtrigger = smp->la_en_new_bbtrigger;
+	boolean ori_bb_dis = smp->la_ori_bb_dis;
+	u8	and1_sel = smp->la_and1_sel;
+	u8	and1_val = smp->la_and1_val;
+	u8	and2_sel = smp->la_and2_sel;
+	u8	and2_val = smp->la_and2_val;
+	u8	and3_sel = smp->la_and3_sel;
+	u8	and3_val = smp->la_and3_val;
+	u32	and4_en = smp->la_and4_en;
+	u32	and4_val = smp->la_and4_val;
+	#endif
+
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD,
+		    ("1. [LA mode bb_setting]trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
+		    trig_mode, dbg_port, edge, smp_rate, trig_sel, dma_type));
+	#endif
+
 	if (trig_mode == PHYDM_MAC_TRIG)
-		trig_sig_sel = 0; /*ignore this setting*/
+		trig_sel = 0; /*@ignore this setting*/
 
 	/*set BB debug port*/
-	if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_3, dbg_port)) {
-		dbg_print("Set dbg_port((0x%x)) success\n", dbg_port);
+	if (is_fake_trig) {
+		if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3, 0xf))
+			pr_debug("Set fake dbg_port success\n");
+		/*@BB debug port bit*/
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, R_0x95c, 0x1f, 0x0);
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			if (!(en_new_bbtrigger))
+				odm_set_bb_reg(dm, R_0x1ce4, 0x3e000, 0x0);
+			else if (!(ori_bb_dis))
+				odm_set_bb_reg(dm, R_0x1ce4, 0x3e000, 0x0);
+		#endif
+		} else {
+			odm_set_bb_reg(dm, R_0x9a0, 0x1f, 0x0);
+		}
+
+		pr_debug("0. [BB Setting] fake-trigger!\n");
+	} else {
+		if (en_fake_trig)
+			phydm_release_bb_dbg_port(dm);
+		if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3, dbg_port))
+			pr_debug("Set dbg_port((0x%x)) success\n", dbg_port);
+		else
+			pr_debug("Set dbg_port fail!\n");
+		/*@debug port bit*/
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, R_0x95c, 0x1f, trig_sel);
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			if (!(en_new_bbtrigger))
+				odm_set_bb_reg(dm, R_0x1ce4, 0x3e000, trig_sel);
+			else if (!(ori_bb_dis))
+				odm_set_bb_reg(dm, R_0x1ce4, 0x3e000, trig_sel);
+		#endif
+		} else {
+			odm_set_bb_reg(dm, R_0x9a0, 0x1f, trig_sel);
+		}
+		pr_debug("1. [BB Setting] trig_mode = ((%d)), dbg_port = ((0x%x)), Trig_Edge = ((%d)), smp_rate = ((%d)), Trig_Sel = ((0x%x)), Dma_type = ((%d))\n",
+			 trig_mode, dbg_port, edge, smp_rate, trig_sel,
+			 dma_type);
+		if (en_fake_trig)
+			return;
 	}
-	
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
 
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
 		if (trig_mode == PHYDM_ADC_RF0_TRIG)
-			dbg_port_header_sel = 9;	/*DBGOUT_RFC_a[31:0]*/
+			dbg_port_hdr_sel = 9; /*@DBGOUT_RFC_a[31:0]*/
 		else if (trig_mode == PHYDM_ADC_RF1_TRIG)
-			dbg_port_header_sel = 8;	/*DBGOUT_RFC_b[31:0]*/
-		else if ((trig_mode == PHYDM_ADC_BB_TRIG) || (trig_mode == PHYDM_ADC_MAC_TRIG)) {
-			
-			if (adc_smp->la_mac_mask_or_hdr_sel <= 0xf) {
-				dbg_port_header_sel = adc_smp->la_mac_mask_or_hdr_sel;
+			dbg_port_hdr_sel = 8; /*@DBGOUT_RFC_b[31:0]*/
+		else if ((trig_mode == PHYDM_ADC_BB_TRIG) ||
+			 (trig_mode == PHYDM_ADC_MAC_TRIG)) {
+			if (smp->la_mac_mask_or_hdr_sel <= 0xf)
+				dbg_port_hdr_sel = smp->la_mac_mask_or_hdr_sel;
+			else
+				dbg_port_hdr_sel = 0;
+		}
+
+		phydm_bb_dbg_port_header_sel(dm, dbg_port_hdr_sel);
+
+		/*@0x95C[11:8]*/
+		odm_set_bb_reg(dm, R_0x95c, 0xf00, dma_type);
+		/*@0: posedge, 1: negedge*/
+		odm_set_bb_reg(dm, R_0x95c, BIT(31), edge);
+		odm_set_bb_reg(dm, R_0x95c, 0xe0, smp_rate);
+		/*	@(0:) '80MHz'
+		 *	(1:) '40MHz'
+		 *	(2:) '20MHz'
+		 *	(3:) '10MHz'
+		 *	(4:) '5MHz'
+		 *	(5:) '2.5MHz'
+		 *	(6:) '1.25MHz'
+		 *	(7:) '160MHz (for BW160 ic)'
+		 */
+		if ((dm->support_ic_type & ODM_RTL8821C) &&
+		    (dm->cut_version >= ODM_CUT_B))
+			odm_set_bb_reg(dm, R_0x95c, BIT(23), 1);
+		else if (dm->support_ic_type & ODM_RTL8195B)
+			odm_set_bb_reg(dm, R_0x95c, BIT(23), 1);
+
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		/*@MAC-PHY timing*/
+		odm_set_bb_reg(dm, R_0x1ce4, BIT(7) | BIT(6), 0);
+		odm_set_bb_reg(dm, R_0x1cf4, BIT(23), 1); /*@LA mode on*/
+		odm_set_bb_reg(dm, R_0x1ce4, 0x3f, dma_type);
+		/*@0: posedge, 1: negedge ??*/
+		odm_set_bb_reg(dm, R_0x1ce4, BIT(26), edge);
+		odm_set_bb_reg(dm, R_0x1ce4, 0x700, smp_rate);
+
+		if (!en_new_bbtrigger) { /*normal LA mode & back to default*/
+
+			pr_debug("Set bb default setting\n");
+
+			/*path 1 default: enable ori. BB trigger*/
+			odm_set_bb_reg(dm, R_0x1ce4, BIT(27), 0);
+
+			/*@AND1~AND4 default: off*/
+			odm_set_bb_reg(dm, R_0x1ce4, MASKH4BITS, 0); /*@AND 1*/
+			odm_set_bb_reg(dm, R_0x1ce8, 0x1f, 0); /*@AND 1 val*/
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(5), 0); /*@AND 1 inv*/
+
+			odm_set_bb_reg(dm, R_0x1ce8, 0x3c0, 0); /*@AND 2*/
+			odm_set_bb_reg(dm, R_0x1ce8, 0x7c00, 0); /*@AND 2 val*/
+			/*@AND 2 inv*/
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(15), 0);
+
+			odm_set_bb_reg(dm, R_0x1ce8, 0xf0000, 0); /*@AND 3*/
+			/*@AND 3 val*/
+			odm_set_bb_reg(dm, R_0x1ce8, 0x1f00000, 0);
+			/*@AND 3 inv*/
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(25), 0);
+
+			/*@AND 4 en*/
+			odm_set_bb_reg(dm, R_0x1cf0, MASKDWORD, 0);
+			/*@AND 4 val*/
+			odm_set_bb_reg(dm, R_0x1cec, MASKDWORD, 0);
+			/*@AND 4 inv*/
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(26), 0);
+
+			pr_debug("Set bb default setting finished\n");
+
+		} else if (en_new_bbtrigger) {
+			/*path 1 default: enable ori. BB trigger*/
+			if (ori_bb_dis)
+				odm_set_bb_reg(dm, R_0x1ce4, BIT(27), 1);
+			else
+				odm_set_bb_reg(dm, R_0x1ce4, BIT(27), 0);
+
+			/* @AND1 */
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(5), 0); /*@invert*/
+
+			if (and1_sel == 0x4 || and1_sel == 0x5 ||
+			    and1_sel == 0x6) {
+				/* rx_state, rx_state_freq, field */
+				odm_set_bb_reg(dm, R_0x1ce4, MASKH4BITS,
+					       and1_sel);
+				odm_set_bb_reg(dm, R_0x1ce8, 0x1f, and1_val);
+
+			} else if (and1_sel == 0x7) {
+				/* @mux state */
+				odm_set_bb_reg(dm, R_0x1ce4, MASKH4BITS,
+					       and1_sel);
+				odm_set_bb_reg(dm, R_0x1ce8, 0xf, and1_val);
+
 			} else {
-				dbg_port_header_sel = 0;
+				odm_set_bb_reg(dm, R_0x1ce4, MASKH4BITS,
+					       and1_sel);
 			}
-		}
 
-		phydm_bb_dbg_port_header_sel(p_dm, dbg_port_header_sel);
-
-		odm_set_bb_reg(p_dm, 0x95c, 0xf00, la_dma_type);	/*0x95C[11:8]*/
-		odm_set_bb_reg(p_dm, 0x95C, 0x1f, trig_sig_sel);	/*0x95C[4:0], BB debug port bit*/
-		odm_set_bb_reg(p_dm, 0x95C, BIT(31), is_trigger_edge); /*0: posedge, 1: negedge*/
-		odm_set_bb_reg(p_dm, 0x95c, 0xe0, sampling_rate);
-		/*	(0:) '80MHz'
-			(1:) '40MHz'
-			(2:) '20MHz'
-			(3:) '10MHz'
-			(4:) '5MHz'
-			(5:) '2.5MHz'
-			(6:) '1.25MHz'
-			(7:) '160MHz (for BW160 ic)'
-		*/
-		if ((p_dm->support_ic_type & ODM_RTL8821C) && (p_dm->cut_version >= ODM_CUT_B)) {
-			odm_set_bb_reg(p_dm, 0x95c, BIT(23), 1);
-		}
+			/* @AND2 */
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(15), 0); /*@invert*/
+
+			if (and2_sel == 0x4 || and2_sel == 0x5 ||
+			    and2_sel == 0x6) {
+				/* rx_state, rx_state_freq, field */
+				odm_set_bb_reg(dm, R_0x1ce8, 0x3c0, and2_sel);
+				odm_set_bb_reg(dm, R_0x1ce8, 0x7c00, and2_val);
+
+			} else if (and2_sel == 0x7) {
+				/* @mux state */
+				odm_set_bb_reg(dm, R_0x1ce8, 0x3c0, and2_sel);
+				odm_set_bb_reg(dm, R_0x1ce8, 0x3c00, and2_val);
+
+			} else {
+				odm_set_bb_reg(dm, R_0x1ce8, 0x3c0, and2_sel);
+			}
+
+			/* @AND3 */
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(25), 0); /*@invert*/
+
+			if (and3_sel == 0x4 || and3_sel == 0x5 ||
+			    and3_sel == 0x6) {
+				/* rx_state, rx_state_freq, field */
+				odm_set_bb_reg(dm, R_0x1ce8, 0xf0000, and3_sel);
+				odm_set_bb_reg(dm, R_0x1ce8, 0x1f00000,
+					       and3_val);
+
+			} else if (and3_sel == 0x7) {
+				/* @mux state */
+				odm_set_bb_reg(dm, R_0x1ce8, 0xf0000, and3_sel);
+				odm_set_bb_reg(dm, R_0x1ce8, 0xf00000,
+					       and3_val);
+			} else {
+				odm_set_bb_reg(dm, R_0x1ce8, 0xf0000, and3_sel);
+			}
+
+			/* @AND4 */
+			odm_set_bb_reg(dm, R_0x1ce8, BIT(26), 0); /*@invert*/
+			odm_set_bb_reg(dm, R_0x1cf0, MASKDWORD, and4_en);
+			odm_set_bb_reg(dm, R_0x1cec, MASKDWORD, and4_val);
+			}
+	#endif
 	} else {
+		#if (RTL8192F_SUPPORT)
+		if ((dm->support_ic_type & ODM_RTL8192F))
+			/*@LA reset HW block enable for true-mac asic*/
+			odm_set_bb_reg(dm, R_0x9a0, BIT(15), 1);
+		#endif
+		/*@0x9A0[11:8]*/
+		odm_set_bb_reg(dm, R_0x9a0, 0xf00, dma_type);
+		/*@0: posedge, 1: negedge*/
+		odm_set_bb_reg(dm, R_0x9a0, BIT(31), edge);
+		odm_set_bb_reg(dm, R_0x9a0, 0xe0, smp_rate);
+		/*	@(0:) '80MHz'
+		 *	(1:) '40MHz'
+		 *	(2:) '20MHz'
+		 *	(3:) '10MHz'
+		 *	(4:) '5MHz'
+		 *	(5:) '2.5MHz'
+		 *	(6:) '1.25MHz'
+		 *	(7:) '160MHz (for BW160 ic)'
+		 */
+	}
+}
 
-		odm_set_bb_reg(p_dm, 0x9a0, 0xf00, la_dma_type);	/*0x9A0[11:8]*/
-		odm_set_bb_reg(p_dm, 0x9a0, 0x1f, trig_sig_sel);	/*0x9A0[4:0], BB debug port bit*/
-		odm_set_bb_reg(p_dm, 0x9A0, BIT(31), is_trigger_edge); /*0: posedge, 1: negedge*/
-		odm_set_bb_reg(p_dm, 0x9A0, 0xe0, sampling_rate);
-		/*	(0:) '80MHz'
-			(1:) '40MHz'
-			(2:) '20MHz'
-			(3:) '10MHz'
-			(4:) '5MHz'
-			(5:) '2.5MHz'
-			(6:) '1.25MHz'
-			(7:) '160MHz (for BW160 ic)'
-		*/
+void phydm_la_mode_set_trigger_time(void *dm_void, u32 trigger_time_mu_sec)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 time_unit_num = 0;
+	u32 unit = 0;
+
+	if (trigger_time_mu_sec < 128)
+		unit = 0; /*unit: 1mu sec*/
+	else if (trigger_time_mu_sec < 256)
+		unit = 1; /*unit: 2mu sec*/
+	else if (trigger_time_mu_sec < 512)
+		unit = 2; /*unit: 4mu sec*/
+	else if (trigger_time_mu_sec < 1024)
+		unit = 3; /*unit: 8mu sec*/
+	else if (trigger_time_mu_sec < 2048)
+		unit = 4; /*unit: 16mu sec*/
+	else if (trigger_time_mu_sec < 4096)
+		unit = 5; /*unit: 32mu sec*/
+	else if (trigger_time_mu_sec < 8192)
+		unit = 6; /*unit: 64mu sec*/
+
+	time_unit_num = (u8)(trigger_time_mu_sec >> unit);
+
+	pr_debug("2. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n",
+		 time_unit_num, unit);
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, (
+		    "3. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n",
+		    time_unit_num, unit));
+	#endif
+
+	if (dm->support_ic_type & ODM_RTL8192F) {
+		odm_set_mac_reg(dm, R_0x7fc, BIT(2) | BIT(1) | BIT(0), unit);
+		odm_set_mac_reg(dm, R_0x7f0, 0x7f00, (time_unit_num & 0x7f));
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		odm_set_mac_reg(dm, R_0x7cc, BIT(18) | BIT(17) | BIT(16), unit);
+		odm_set_mac_reg(dm, R_0x7c0, 0x7f00, (time_unit_num & 0x7f));
+	#endif
+	} else {
+		odm_set_mac_reg(dm, R_0x7cc, BIT(20) | BIT(19) | BIT(18), unit);
+		odm_set_mac_reg(dm, R_0x7c0, 0x7f00, (time_unit_num & 0x7f));
 	}
 }
 
-void
-phydm_la_mode_set_trigger_time(
-	void		*p_dm_void,
-	u32		trigger_time_mu_sec
-)
+void phydm_la_set_buff_mode(void *dm_void, enum la_buff_mode mode)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			trigger_time_unit_num;
-	u32			time_unit = 0;
-
-	if (trigger_time_mu_sec < 128) {
-		time_unit = 0; /*unit: 1mu sec*/
-	} else if (trigger_time_mu_sec < 256) {
-		time_unit = 1; /*unit: 2mu sec*/
-	} else if (trigger_time_mu_sec < 512) {
-		time_unit = 2; /*unit: 4mu sec*/
-	} else if (trigger_time_mu_sec < 1024) {
-		time_unit = 3; /*unit: 8mu sec*/
-	} else if (trigger_time_mu_sec < 2048) {
-		time_unit = 4; /*unit: 16mu sec*/
-	} else if (trigger_time_mu_sec < 4096) {
-		time_unit = 5; /*unit: 32mu sec*/
-	} else if (trigger_time_mu_sec < 8192) {
-		time_unit = 6; /*unit: 64mu sec*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct rtl8192cd_priv		*priv = dm->priv;
+#endif
+	u32 buff_size_base = 0;
+	u32 end_pos_tmp = 0;
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	u8 normal_LA_on = priv->pmib->miscEntry.normal_LA_on;
+#endif
+	smp->la_buff_mode = mode;
+#if 0
+	if (dm->support_ic_type & ODM_RTL8814A)
+		buf->start_pos = 0x30000;
+	else if (dm->support_ic_type &
+		 (ODM_RTL8822B | ODM_RTL8822C | ODM_RTL8812F))
+		buf->start_pos = 0x20000;
+	else if (dm->support_ic_type & ODM_RTL8814B)
+		buf->start_pos = 0x30000;
+	else if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8198F))
+		buf->start_pos = 0x00000;
+	else if (dm->support_ic_type & ODM_RTL8192F)
+		buf->start_pos = 0x2000;
+	else if (dm->support_ic_type & ODM_RTL8821C)
+		buf->start_pos = 0x8000;
+	else if (dm->support_ic_type & ODM_RTL8195B)
+		buf->start_pos = 0x4000;
+#endif
+	switch (dm->support_ic_type) {
+	case ODM_RTL8814A:
+		buff_size_base = 0x10000;
+		end_pos_tmp = 0x40000;
+		break;
+	case ODM_RTL8822B:
+	case ODM_RTL8822C:
+	case ODM_RTL8812F:
+		buff_size_base = 0x20000;
+		end_pos_tmp = 0x40000;
+		break;
+	case ODM_RTL8814B:
+		buff_size_base = 0x30000;
+		end_pos_tmp = 0x60000;
+		break;
+	case ODM_RTL8197F:
+	case ODM_RTL8198F:
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		buff_size_base = 0x10000;
+		end_pos_tmp = (normal_LA_on == 1) ? 0x20000 : 0x10000;
+		break;
+#endif
+	case ODM_RTL8192F:
+		buff_size_base = 0xE000;
+		end_pos_tmp = 0x10000;
+		break;
+	case ODM_RTL8821C:
+		buff_size_base = 0x8000;
+		end_pos_tmp = 0x10000;
+		break;
+	case ODM_RTL8195B:
+		buff_size_base = 0x4000;
+		end_pos_tmp = 0x8000;
+		break;
+	default:
+		pr_debug("[%s] Warning!", __func__);
+		break;
 	}
 
-	trigger_time_unit_num = (u8)(trigger_time_mu_sec >> time_unit);
+	buf->buffer_size = buff_size_base;
 
-	dbg_print("2. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n", trigger_time_unit_num, time_unit);
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("3. [Set Trigger Time] Trig_Time = ((%d)) * unit = ((2^%d us))\n", trigger_time_unit_num, time_unit));
-#endif
+	if (dm->support_ic_type & FULL_BUFF_MODE_SUPPORT) {
+		if (mode == ADCSMP_BUFF_HALF) {
+			odm_set_mac_reg(dm, R_0x7cc, BIT(30), 0);
+		} else {
+			buf->buffer_size = buf->buffer_size << 1;
+			odm_set_mac_reg(dm, R_0x7cc, BIT(30), 1);
+		}
+	}
 
-	odm_set_mac_reg(p_dm, 0x7cc, BIT(20) | BIT(19) | BIT(18), time_unit);
-	odm_set_mac_reg(p_dm, 0x7c0, 0x7f00, (trigger_time_unit_num & 0x7f));
+	buf->end_pos = end_pos_tmp;
+	buf->start_pos = end_pos_tmp - buf->buffer_size;
 
+	PHYDM_DBG(dm, DBG_TMP,
+		  "start_addr = ((0x%x)), end_addr = ((0x%x)), buffer_size = ((0x%x))\n",
+		  buf->start_pos, buf->end_pos, buf->buffer_size);
 }
 
-
-void
-phydm_lamode_trigger_setting(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_lamode_trigger_cmd(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_ADCSMP	*adc_smp = &(p_dm->adcsmp);
-	u8		trig_mode, dma_data_sig_sel;
-	u32		trig_sig_sel;
-	boolean		is_enable_la_mode;
-	u32		trigger_time_mu_sec;
-	char 		help[] = "-h";
-	u32			var1[10] = {0};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	u8 trig_mode = 0, dma_data_sig_sel = 0;
+	u32 trig_sig_sel = 0;
+	u8 enable_la_mode = 0;
+	u32 trigger_time_mu_sec = 0;
+	char help[] = "-h";
+	u32 var1[10] = {0};
 	u32 used = *_used;
 	u32 out_len = *_out_len;
 
-	if (p_dm->support_ic_type & PHYDM_IC_SUPPORT_LA_MODE) {
+	if (!(dm->support_ic_type & PHYDM_IC_SUPPORT_LA_MODE))
+		return;
 
-		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-		is_enable_la_mode = (boolean)var1[0];
-		/*dbg_print("echo cmd input_num = %d\n", input_num);*/
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+	enable_la_mode = (u8)var1[0];
 
-		if ((strcmp(input[1], help) == 0)) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "{En} {0:BB,1:BB_MAC,2:RF0,3:RF1,4:MAC} \n {BB:dbg_port[bit],BB_MAC:0-ok/1-fail/2-cca,MAC:ref} {DMA type} {TrigTime} \n {DbgPort_head/ref_mask} {dbg_port} {0:P_Edge, 1:N_Edge} {SpRate:0-80M,1-40M,2-20M} {Capture num}\n"));
-			/**/
-		} else if ((is_enable_la_mode == 1)) {
+	/*@dbg_print("echo cmd input_num = %d\n", input_num);*/
 
-			PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
-
-			trig_mode = (u8)var1[1];
-
-			if (trig_mode == PHYDM_MAC_TRIG)
-				PHYDM_SSCANF(input[3], DCMD_HEX, &var1[2]);
-			else
-				PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
-			trig_sig_sel = var1[2];
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{En} {0:BB,1:BB_MAC,2:RF0,3:RF1,4:MAC}\n{BB:dbg_port[bit],BB_MAC:0-ok/1-fail/2-cca,MAC:ref} {DMA type} {TrigTime}\n{DbgPort_head/ref_mask} {dbg_port} {0:P_Edge, 1:N_Edge} {SpRate:0-80M,1-40M,2-20M} {Capture num}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "set {1:tx_buff_size} {0: half, 1:all}\n");
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "set {2:adv_bb_trig(JGR3)} {en} {C0_dis} {C1_sel} {C1_val} {C2_sel} {C2_val}\n{C3_sel} {C3_val} {C4_en} {C4_val}\n");
+		#endif
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "set {3:fake_trigger} {0: dis, 1:en}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "set {4:is_la_print} {0: dis, 1:en}\n");
+	} else if ((strcmp(input[1], "set") == 0)) {
+		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
+
+		if (var1[1] == 1) {
+			PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+			phydm_la_set_buff_mode(dm, (enum la_buff_mode)var1[2]);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "buff_mode = (%d/2)\n", smp->la_buff_mode + 1);
+		} else if (var1[1] == 2) {
+			#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+			phydm_la_bb_adv_cmd_jgr3(dm, input,
+						 &used, output, &out_len);
+			#else
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Not Support\n");
+			#endif
+		} else if (var1[1] == 3) {
+			PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+			if (var1[2] == 1) {
+				smp->en_fake_trig = true;
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "Enable fake-trigger\n");
+			} else {
+				smp->en_fake_trig = false;
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "Disable fake-trigger\n");
+			}
+		} else if (var1[1] == 4) {
+			PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+			smp->is_la_print = (boolean)var1[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "is_la_print = %d\n", smp->is_la_print);
+		}
+	} else if (enable_la_mode == 1) {
+		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
 
-			PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
-			PHYDM_SSCANF(input[5], DCMD_DECIMAL, &var1[4]);
-			PHYDM_SSCANF(input[6], DCMD_HEX, &var1[5]);
-			PHYDM_SSCANF(input[7], DCMD_HEX, &var1[6]);
-			PHYDM_SSCANF(input[8], DCMD_DECIMAL, &var1[7]);
-			PHYDM_SSCANF(input[9], DCMD_DECIMAL, &var1[8]);
-			PHYDM_SSCANF(input[10], DCMD_DECIMAL, &var1[9]);
+		trig_mode = (u8)var1[1];
 
-			dma_data_sig_sel = (u8)var1[3];
-			trigger_time_mu_sec = var1[4]; /*unit: us*/
+		if (trig_mode == PHYDM_MAC_TRIG)
+			PHYDM_SSCANF(input[3], DCMD_HEX, &var1[2]);
+		else
+			PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+		trig_sig_sel = var1[2];
+
+		PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
+		PHYDM_SSCANF(input[5], DCMD_DECIMAL, &var1[4]);
+		PHYDM_SSCANF(input[6], DCMD_HEX, &var1[5]);
+		PHYDM_SSCANF(input[7], DCMD_HEX, &var1[6]);
+		PHYDM_SSCANF(input[8], DCMD_DECIMAL, &var1[7]);
+		PHYDM_SSCANF(input[9], DCMD_DECIMAL, &var1[8]);
+		PHYDM_SSCANF(input[10], DCMD_DECIMAL, &var1[9]);
+
+		dma_data_sig_sel = (u8)var1[3];
+		trigger_time_mu_sec = var1[4]; /*unit: us*/
+
+		smp->la_mac_mask_or_hdr_sel = var1[5];
+		smp->la_dbg_port = var1[6];
+		smp->la_trigger_edge = (u8)var1[7];
+		smp->la_smp_rate = (u8)(var1[8] & 0x7);
+		smp->la_count = var1[9];
+
+		pr_debug("echo lamode %d %d %d %d %d %d %x %d %d %d\n",
+			 var1[0], var1[1], var1[2], var1[3], var1[4],
+			 var1[5], var1[6], var1[7], var1[8], var1[9]);
+		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+		RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD,
+			    ("echo lamode %d %d %d %d %d %d %x %d %d %d\n",
+			    var1[0], var1[1], var1[2], var1[3],
+			    var1[4], var1[5], var1[6], var1[7],
+			    var1[8], var1[9]));
+		#endif
 
-			adc_smp->la_mac_mask_or_hdr_sel = var1[5];
-			adc_smp->la_dbg_port = var1[6];
-			adc_smp->la_trigger_edge = (u8) var1[7];
-			adc_smp->la_smp_rate = (u8)(var1[8] & 0x7);
-			adc_smp->la_count = var1[9];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "a.En= ((1)),  b.mode = ((%d)), c.Trig_Sel = ((0x%x)), d.Dma_type = ((%d))\n",
+			 trig_mode, trig_sig_sel, dma_data_sig_sel);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "e.Trig_Time = ((%dus)), f.Dbg_head/mac_ref_mask = ((0x%x)), g.dbg_port = ((0x%x))\n",
+			 trigger_time_mu_sec,
+			 smp->la_mac_mask_or_hdr_sel, smp->la_dbg_port);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "h.Trig_edge = ((%d)), i.smp rate = ((%d MHz)), j.Cap_num = ((%d))\n",
+			 smp->la_trigger_edge, (80 >> smp->la_smp_rate),
+			 smp->la_count);
+
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "k.en_new_bbtrigger = ((%d))\n",
+			 smp->la_en_new_bbtrigger);
+		#endif
 
+		adc_smp_set(dm, trig_mode, trig_sig_sel,
+			    dma_data_sig_sel, trigger_time_mu_sec, 0);
+	} else {
+		adc_smp_stop(dm);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Disable LA mode\n");
+	}
 
-			dbg_print("echo lamode %d %d %d %d %d %d %x %d %d %d\n", var1[0], var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], var1[7], var1[8], var1[9]);
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-			RT_TRACE_EX(COMP_LA_MODE, DBG_LOUD, ("echo lamode %d %d %d %d %d %d %x %d %d %d\n", var1[0], var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], var1[7], var1[8], var1[9]));
-#endif
+	*_used = used;
+	*_out_len = out_len;
+}
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "a.En= ((1)),  b.mode = ((%d)), c.Trig_Sel = ((0x%x)), d.Dma_type = ((%d))\n", trig_mode, trig_sig_sel, dma_data_sig_sel));
-			PHYDM_SNPRINTF((output + used, out_len - used, "e.Trig_Time = ((%dus)), f.Dbg_head/mac_ref_mask = ((0x%x)), g.dbg_port = ((0x%x))\n", trigger_time_mu_sec, adc_smp->la_mac_mask_or_hdr_sel, adc_smp->la_dbg_port));
-			PHYDM_SNPRINTF((output + used, out_len - used, "h.Trig_edge = ((%d)), i.smp rate = ((%d MHz)), j.Cap_num = ((%d))\n", adc_smp->la_trigger_edge, (80 >> adc_smp->la_smp_rate), adc_smp->la_count));
+void phydm_la_pre_run(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct rt_adcsmp *smp = &dm->adcsmp;
+	struct rt_adcsmp_string *buf = &smp->adc_smp_buf;
+	u8 while_cnt = 0;
+	u8 tmp = 0;
+	u8 target_polling_bit = BIT(1);
+
+	if (dm->support_ic_type & ODM_RTL8198F) {
+		/*pre run */
+		/*force to bb trigger*/
+		odm_set_mac_reg(dm, R_0x7c0, BIT(3), 0);
+		/*dma_trig_and(AND1) output 1*/
+		odm_set_bb_reg(dm, R_0x1ce4, 0xf0000000, 0x0);
+		/*r_dma_trigger_AND1_inv = 1*/
+		odm_set_bb_reg(dm, R_0x1ce8, BIT5, 1); /*@AND 1 val*/
+
+		target_polling_bit = BIT(1);
+		/* polling bit for BB ADC mode */
+		odm_set_mac_reg(dm, 0x7c0, BIT(1), 1);
+
+		pr_debug("buf_start(0x%x)buf_end(0x%x)\n",
+			 buf->start_pos, buf->end_pos);
+
+		do {
+			tmp = odm_read_1byte(dm, R_0x7c0);
+			if ((tmp & target_polling_bit) == false) {
+				pr_debug("LA pre-run fail.\n");
+				adc_smp_stop(dm);
+				phydm_release_bb_dbg_port(dm);
+			} else {
+				ODM_delay_ms(100);
+				pr_debug("LA pre-run while_cnt = %d.\n",
+					 while_cnt);
+				while_cnt = while_cnt + 1;
+			}
+		} while (while_cnt < 3);
 
-			adc_smp_set(p_dm, trig_mode, trig_sig_sel, dma_data_sig_sel, trigger_time_mu_sec, 0);
+		/*r_dma_trigger_AND1_inv = 0*/
+		odm_set_bb_reg(dm, R_0x1ce8, BIT5, 0); /*@AND 1 val*/
 
-		} else {
-			adc_smp_stop(p_dm);
-			PHYDM_SNPRINTF((output + used, out_len - used, "Disable LA mode\n"));
+		if (smp->la_trig_mode == PHYDM_ADC_MAC_TRIG) {
+			if (dm->support_ic_type & ODM_RTL8192F)
+				odm_set_mac_reg(dm, R_0x7f0, BIT(3), 1);
+			else
+				odm_set_mac_reg(dm, R_0x7c0, BIT(3), 1);
 		}
 	}
-	*_used = used;
-	*_out_len = out_len;
 }
 
-#endif	/*endif PHYDM_LA_MODE_SUPPORT == 1*/
+#endif /*@endif PHYDM_LA_MODE_SUPPORT*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.h
index 06f66fde94ac..052131dfc99c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_adc_sampling.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,26 +9,39 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 #ifndef __INC_ADCSMP_H
 #define __INC_ADCSMP_H
 
-#define DYNAMIC_LA_MODE	"2.0"  /*2017.02.06  Dino */
+#if (PHYDM_LA_MODE_SUPPORT)
+
+#define DYNAMIC_LA_MODE "3.0"
 
-#if (PHYDM_LA_MODE_SUPPORT == 1)
+#define FULL_BUFF_MODE_SUPPORT (ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8822C |\
+				ODM_RTL8812F | ODM_RTL8814B)
 
-struct _RT_ADCSMP_STRING {
+struct rt_adcsmp_string {
 	u32		*octet;
 	u32		length;
 	u32		buffer_size;
 	u32		start_pos;
+	u32		end_pos;	/*@buf addr*/
 };
 
-
 enum rt_adcsmp_trig_sel {
 	PHYDM_ADC_BB_TRIG	= 0,
 	PHYDM_ADC_MAC_TRIG	= 1,
@@ -36,7 +50,6 @@ enum rt_adcsmp_trig_sel {
 	PHYDM_MAC_TRIG		= 4
 };
 
-
 enum rt_adcsmp_trig_sig_sel {
 	ADCSMP_TRIG_CRCOK	= 0,
 	ADCSMP_TRIG_CRCFAIL	= 1,
@@ -44,28 +57,49 @@ enum rt_adcsmp_trig_sig_sel {
 	ADCSMP_TRIG_REG		= 3
 };
 
-
 enum rt_adcsmp_state {
-	ADCSMP_STATE_IDLE		= 0,
-	ADCSMP_STATE_SET		= 1,
-	ADCSMP_STATE_QUERY	=	2
+	ADCSMP_STATE_IDLE	= 0,
+	ADCSMP_STATE_SET	= 1,
+	ADCSMP_STATE_QUERY	= 2
 };
 
+enum la_buff_mode {
+	ADCSMP_BUFF_HALF	= 0,
+	ADCSMP_BUFF_ALL		= 1	/*Only use in MP Driver*/
+};
 
-struct _RT_ADCSMP {
-	struct _RT_ADCSMP_STRING		adc_smp_buf;
-	enum rt_adcsmp_state		adc_smp_state;
-	u8					la_trig_mode;
-	u32					la_trig_sig_sel;
-	u8					la_dma_type;
-	u32					la_trigger_time;
-	u32					la_mac_mask_or_hdr_sel; /*1.BB mode: for debug port header sel; 2.MAC mode: for reference mask*/
-	u32					la_dbg_port;
-	u8					la_trigger_edge;
-	u8					la_smp_rate;
-	u32					la_count;
-	u8					is_bb_trigger;
-	u8					la_work_item_index;
+struct rt_adcsmp {
+	struct rt_adcsmp_string	adc_smp_buf;
+	enum rt_adcsmp_state	adc_smp_state;
+	enum la_buff_mode	la_buff_mode;
+	u8			la_trig_mode;
+	u32			la_trig_sig_sel;
+	u8			la_dma_type;
+	u32			la_trigger_time;
+	/*
+	 * @1.BB mode: for debug port header sel;
+	 * 2.MAC mode: for reference mask
+	 */
+	u32			la_mac_mask_or_hdr_sel;
+	u32			la_dbg_port;
+	u8			la_trigger_edge;
+	u8			la_smp_rate;
+	u32			la_count;
+	u8			is_bb_trigger;
+	u8			la_work_item_index;
+	boolean			la_en_new_bbtrigger;
+	boolean			la_ori_bb_dis;
+	u8			la_and1_sel;
+	u8			la_and1_val;
+	u8			la_and2_sel;
+	u8			la_and2_val;
+	u8			la_and3_sel;
+	u8			la_and3_val;
+	u32			la_and4_en;
+	u32			la_and4_val;
+	boolean			is_fake_trig;
+	boolean			is_la_print;
+	boolean			en_fake_trig;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 	RT_WORK_ITEM	adc_smp_work_item;
@@ -74,89 +108,45 @@ struct _RT_ADCSMP {
 };
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-void
-adc_smp_work_item_callback(
-	void	*p_context
-);
+void adc_smp_work_item_callback(
+	void *context);
 #endif
 
-void
-adc_smp_set(
-	void	*p_dm_void,
-	u8	trig_mode,
-	u32	trig_sig_sel,
-	u8	dma_data_sig_sel,
-	u32	trigger_time,
-	u16	polling_time
-);
+void adc_smp_set(void *dm_void, u8 trig_mode, u32 trig_sig_sel,
+		 u8 dma_data_sig_sel, u32 trig_time, u16 polling_time);
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 enum rt_status
-adc_smp_query(
-	void	*p_dm_void,
-	ULONG	information_buffer_length,
-	void	*information_buffer,
-	PULONG	bytes_written
-);
+adc_smp_query(void *dm_void, ULONG info_buf_length, void *info_buf,
+	      PULONG bytes_written);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-void
-adc_smp_query(
-	void		*p_dm_void,
-	void		*output,
-	u32		out_len,
-	u32		*pused
-);
-
-s32
-adc_smp_get_sample_counts(
-	void		*p_dm_void
-);
-
-s32
-adc_smp_query_single_data(
-	void		*p_dm_void,
-	void		*output,
-	u32		out_len,
-	u32		index
-);
+void adc_smp_query(void *dm_void, void *output, u32 out_len, u32 *pused);
+
+s32 adc_smp_get_sample_counts(void *dm_void);
+
+s32 adc_smp_query_single_data(void *dm_void, void *output, u32 out_len,
+			      u32 idx);
 
 #endif
-void
-adc_smp_stop(
-	void	*p_dm_void
-);
+void adc_smp_stop(void *dm_void);
 
-void
-adc_smp_init(
-	void	*p_dm_void
-);
+void phydm_la_bb_adv_reset_jgr3(void *dm_void);
+
+void adc_smp_init(void *dm_void);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-void
-adc_smp_de_init(
-	void			*p_dm_void
-);
+void adc_smp_de_init(void *dm_void);
 #endif
 
-void
-phydm_la_mode_bb_setting(
-	void		*p_dm_void
-);
-
-void
-phydm_la_mode_set_trigger_time(
-	void		*p_dm_void,
-	u32		trigger_time_mu_sec
-);
-
-void
-phydm_lamode_trigger_setting(
-	void		*p_dm_void,
-	char			input[][16],
-	u32		*_used,
-	char			*output,
-	u32		*_out_len,
-	u32		input_num
-);
+void phydm_la_set_buff_mode(void *dm_void, enum la_buff_mode mode);
+
+void phydm_la_mode_bb_setting(void *dm_void, boolean en_fake_trig);
+
+void phydm_la_mode_set_trigger_time(void *dm_void, u32 trigger_time_mu_sec);
+
+void phydm_lamode_trigger_cmd(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len);
+void phydm_la_pre_run(void *dm_void);
+
 #endif
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.c
index 1518968f62ba..fcee74fe673f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,9 +9,19 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 /* ************************************************************
@@ -20,47 +31,55 @@
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-/* #if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE)) */
-#if (defined(CONFIG_ANT_DETECTION))
+#ifdef CONFIG_ANT_DETECTION
 
-/* IS_ANT_DETECT_SUPPORT_SINGLE_TONE(adapter)
+/* @IS_ANT_DETECT_SUPPORT_SINGLE_TONE(adapter)
  * IS_ANT_DETECT_SUPPORT_RSSI(adapter)
  * IS_ANT_DETECT_SUPPORT_PSD(adapter) */
 
-/* 1 [1. Single Tone method] =================================================== */
+/* @1 [1. Single Tone method] =================================================== */
 
-/*
+/*@
  * Description:
  *	Set Single/Dual Antenna default setting for products that do not do detection in advance.
  *
  * Added by Joseph, 2012.03.22
  *   */
-void
-odm_single_dual_antenna_default_setting(
-	void		*p_dm_void
-)
+void odm_sw_ant_div_construct_scan_chnl(
+	void *adapter,
+	u8 scan_chnl)
+{
+}
+
+u8 odm_sw_ant_div_select_scan_chnl(
+	void *adapter)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct _ADAPTER	*p_adapter	 =  p_dm->adapter;
+	return 0;
+}
+
+void odm_single_dual_antenna_default_setting(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *dm_swat_table = &dm->dm_swat_table;
+	void *adapter = dm->adapter;
 
-	u8 bt_ant_num = BT_GetPgAntNum(p_adapter);
+	u8 bt_ant_num = BT_GetPgAntNum(adapter);
 	/* Set default antenna A and B status */
 	if (bt_ant_num == 2) {
-		p_dm_swat_table->ANTA_ON = true;
-		p_dm_swat_table->ANTB_ON = true;
+		dm_swat_table->ANTA_ON = true;
+		dm_swat_table->ANTB_ON = true;
 
 	} else if (bt_ant_num == 1) {
 		/* Set antenna A as default */
-		p_dm_swat_table->ANTA_ON = true;
-		p_dm_swat_table->ANTB_ON = false;
+		dm_swat_table->ANTA_ON = true;
+		dm_swat_table->ANTB_ON = false;
 
 	} else
 		RT_ASSERT(false, ("Incorrect antenna number!!\n"));
 }
 
-
-/* 2 8723A ANT DETECT
+/* @2 8723A ANT DETECT
  *
  * Description:
  *	Implement IQK single tone for RF DPK loopback and BB PSD scanning.
@@ -70,113 +89,113 @@ odm_single_dual_antenna_default_setting(
  *   */
 boolean
 odm_single_dual_antenna_detection(
-	void		*p_dm_void,
-	u8			mode
-)
+	void *dm_void,
+	u8 mode)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER	*p_adapter	 =  p_dm->adapter;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
-	u32		current_channel, rf_loop_reg;
-	u8		n;
-	u32		reg88c, regc08, reg874, regc50, reg948, regb2c, reg92c, reg930, reg064, afe_rrx_wait_cca;
-	u8		initial_gain = 0x5a;
-	u32		PSD_report_tmp;
-	u32		ant_a_report = 0x0, ant_b_report = 0x0, ant_0_report = 0x0;
-	boolean		is_result = true;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_single_dual_antenna_detection()============>\n"));
-
-
-	if (!(p_dm->support_ic_type & ODM_RTL8723B))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	struct sw_antenna_switch *dm_swat_table = &dm->dm_swat_table;
+	u32 current_channel, rf_loop_reg;
+	u8 n;
+	u32 reg88c, regc08, reg874, regc50, reg948, regb2c, reg92c, reg930, reg064, afe_rrx_wait_cca;
+	u8 initial_gain = 0x5a;
+	u32 PSD_report_tmp;
+	u32 ant_a_report = 0x0, ant_b_report = 0x0, ant_0_report = 0x0;
+	boolean is_result = true;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "%s============>\n", __func__);
+
+	if (!(dm->support_ic_type & ODM_RTL8723B))
 		return is_result;
 
 	/* Retrieve antenna detection registry info, added by Roger, 2012.11.27. */
-	if (!IS_ANT_DETECT_SUPPORT_SINGLE_TONE(p_adapter))
+	if (!IS_ANT_DETECT_SUPPORT_SINGLE_TONE(((PADAPTER)adapter)))
 		return is_result;
 
-	/* 1 Backup Current RF/BB Settings */
-
-	current_channel = odm_get_rf_reg(p_dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
-	rf_loop_reg = odm_get_rf_reg(p_dm, RF_PATH_A, 0x00, RFREGOFFSETMASK);
-	if (p_dm->support_ic_type & ODM_RTL8723B) {
-		reg92c = odm_get_bb_reg(p_dm, REG_DPDT_CONTROL, MASKDWORD);
-		reg930 = odm_get_bb_reg(p_dm, rfe_ctrl_anta_src, MASKDWORD);
-		reg948 = odm_get_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
-		regb2c = odm_get_bb_reg(p_dm, REG_AGC_TABLE_SELECT, MASKDWORD);
-		reg064 = odm_get_mac_reg(p_dm, REG_SYM_WLBT_PAPE_SEL, BIT(29));
-		odm_set_bb_reg(p_dm, REG_DPDT_CONTROL, 0x3, 0x1);
-		odm_set_bb_reg(p_dm, rfe_ctrl_anta_src, 0xff, 0x77);
-		odm_set_mac_reg(p_dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), 0x1);  /* dbg 7 */
-		odm_set_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, 0x3c0, 0x0);/* dbg 8 */
-		odm_set_bb_reg(p_dm, REG_AGC_TABLE_SELECT, BIT(31), 0x0);
+	/* @1 Backup Current RF/BB Settings */
+
+	current_channel = odm_get_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
+	rf_loop_reg = odm_get_rf_reg(dm, RF_PATH_A, RF_0x00, RFREGOFFSETMASK);
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		reg92c = odm_get_bb_reg(dm, REG_DPDT_CONTROL, MASKDWORD);
+		reg930 = odm_get_bb_reg(dm, rfe_ctrl_anta_src, MASKDWORD);
+		reg948 = odm_get_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
+		regb2c = odm_get_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD);
+		reg064 = odm_get_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29));
+		odm_set_bb_reg(dm, REG_DPDT_CONTROL, 0x3, 0x1);
+		odm_set_bb_reg(dm, rfe_ctrl_anta_src, 0xff, 0x77);
+		odm_set_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), 0x1); /* @dbg 7 */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0x3c0, 0x0); /* @dbg 8 */
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x0);
 	}
 
 	ODM_delay_us(10);
 
 	/* Store A path Register 88c, c08, 874, c50 */
-	reg88c = odm_get_bb_reg(p_dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD);
-	regc08 = odm_get_bb_reg(p_dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD);
-	reg874 = odm_get_bb_reg(p_dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD);
-	regc50 = odm_get_bb_reg(p_dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
+	reg88c = odm_get_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD);
+	regc08 = odm_get_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD);
+	reg874 = odm_get_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD);
+	regc50 = odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
 
 	/* Store AFE Registers */
-	if (p_dm->support_ic_type & ODM_RTL8723B)
-		afe_rrx_wait_cca = odm_get_bb_reg(p_dm, REG_RX_WAIT_CCA, MASKDWORD);
+	if (dm->support_ic_type & ODM_RTL8723B)
+		afe_rrx_wait_cca = odm_get_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD);
 
 	/* Set PSD 128 pts */
-	odm_set_bb_reg(p_dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0); /* 128 pts */
+	odm_set_bb_reg(dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0); /* @128 pts */
 
 	/* To SET CH1 to do */
-	odm_set_rf_reg(p_dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK, 0x7401);     /* channel 1 */
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK, 0x7401); /* @channel 1 */
 
-	/* AFE all on step */
-	if (p_dm->support_ic_type & ODM_RTL8723B)
-		odm_set_bb_reg(p_dm, REG_RX_WAIT_CCA, MASKDWORD, 0x01c00016);
+	/* @AFE all on step */
+	if (dm->support_ic_type & ODM_RTL8723B)
+		odm_set_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD, 0x01c00016);
 
-	/* 3 wire Disable */
-	odm_set_bb_reg(p_dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, 0xCCF000C0);
+	/* @3 wire Disable */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, 0xCCF000C0);
 
-	/* BB IQK setting */
-	odm_set_bb_reg(p_dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800E4);
-	odm_set_bb_reg(p_dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x22208000);
+	/* @BB IQK setting */
+	odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, 0x000800E4);
+	odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, 0x22208000);
 
-	/* IQK setting tone@ 4.34Mhz */
-	odm_set_bb_reg(p_dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x10008C1C);
-	odm_set_bb_reg(p_dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
+	/* @IQK setting tone@ 4.34Mhz */
+	odm_set_bb_reg(dm, REG_TX_IQK_TONE_A, MASKDWORD, 0x10008C1C);
+	odm_set_bb_reg(dm, REG_TX_IQK, MASKDWORD, 0x01007c00);
 
 	/* Page B init */
-	odm_set_bb_reg(p_dm, REG_CONFIG_ANT_A, MASKDWORD, 0x00080000);
-	odm_set_bb_reg(p_dm, REG_CONFIG_ANT_A, MASKDWORD, 0x0f600000);
-	odm_set_bb_reg(p_dm, REG_RX_IQK, MASKDWORD, 0x01004800);
-	odm_set_bb_reg(p_dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x10008c1f);
-	if (p_dm->support_ic_type & ODM_RTL8723B) {
-		odm_set_bb_reg(p_dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82150016);
-		odm_set_bb_reg(p_dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28150016);
+	odm_set_bb_reg(dm, REG_CONFIG_ANT_A, MASKDWORD, 0x00080000);
+	odm_set_bb_reg(dm, REG_CONFIG_ANT_A, MASKDWORD, 0x0f600000);
+	odm_set_bb_reg(dm, REG_RX_IQK, MASKDWORD, 0x01004800);
+	odm_set_bb_reg(dm, REG_RX_IQK_TONE_A, MASKDWORD, 0x10008c1f);
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		odm_set_bb_reg(dm, REG_TX_IQK_PI_A, MASKDWORD, 0x82150016);
+		odm_set_bb_reg(dm, REG_RX_IQK_PI_A, MASKDWORD, 0x28150016);
 	}
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_RSP, MASKDWORD, 0x001028d0);
-	odm_set_bb_reg(p_dm, REG_OFDM_0_XA_AGC_CORE1, 0x7f, initial_gain);
+	odm_set_bb_reg(dm, REG_IQK_AGC_RSP, MASKDWORD, 0x001028d0);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, 0x7f, initial_gain);
 
-	/* IQK Single tone start */
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
-	odm_set_bb_reg(p_dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
+	/* @IQK Single tone start */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, 0xffffff00, 0x808000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf9000000);
+	odm_set_bb_reg(dm, REG_IQK_AGC_PTS, MASKDWORD, 0xf8000000);
 
 	ODM_delay_us(10000);
 
 	/* PSD report of antenna A */
 	PSD_report_tmp = 0x0;
 	for (n = 0; n < 2; n++) {
-		PSD_report_tmp = phydm_get_psd_data(p_dm, 14, initial_gain);
+		PSD_report_tmp = phydm_get_psd_data(dm, 14, initial_gain);
 		if (PSD_report_tmp > ant_a_report)
 			ant_a_report = PSD_report_tmp;
 	}
 
-	/* change to Antenna B */
-	if (p_dm->support_ic_type & ODM_RTL8723B) {
-		/* odm_set_bb_reg(p_dm, REG_DPDT_CONTROL, 0x3, 0x2); */
-		odm_set_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
-		odm_set_bb_reg(p_dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
+	/* @change to Antenna B */
+	if (dm->support_ic_type & ODM_RTL8723B) {
+#if 0
+		/* odm_set_bb_reg(dm, REG_DPDT_CONTROL, 0x3, 0x2); */
+#endif
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
 	}
 
 	ODM_delay_us(10);
@@ -184,650 +203,690 @@ odm_single_dual_antenna_detection(
 	/* PSD report of antenna B */
 	PSD_report_tmp = 0x0;
 	for (n = 0; n < 2; n++) {
-		PSD_report_tmp = phydm_get_psd_data(p_dm, 14, initial_gain);
+		PSD_report_tmp = phydm_get_psd_data(dm, 14, initial_gain);
 		if (PSD_report_tmp > ant_b_report)
 			ant_b_report = PSD_report_tmp;
 	}
 
-	/* Close IQK Single Tone function */
-	odm_set_bb_reg(p_dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
+	/* @Close IQK Single Tone function */
+	odm_set_bb_reg(dm, REG_FPGA0_IQK, 0xffffff00, 0x000000);
 
-	/* 1 Return to antanna A */
-	if (p_dm->support_ic_type & ODM_RTL8723B) {
-		/* external DPDT */
-		odm_set_bb_reg(p_dm, REG_DPDT_CONTROL, MASKDWORD, reg92c);
+	/* @1 Return to antanna A */
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		/* @external DPDT */
+		odm_set_bb_reg(dm, REG_DPDT_CONTROL, MASKDWORD, reg92c);
 
-		/* internal S0/S1 */
-		odm_set_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
-		odm_set_bb_reg(p_dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
-		odm_set_bb_reg(p_dm, rfe_ctrl_anta_src, MASKDWORD, reg930);
-		odm_set_mac_reg(p_dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), reg064);
+		/* @internal S0/S1 */
+		odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
+		odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
+		odm_set_bb_reg(dm, rfe_ctrl_anta_src, MASKDWORD, reg930);
+		odm_set_mac_reg(dm, REG_SYM_WLBT_PAPE_SEL, BIT(29), reg064);
 	}
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, reg88c);
-	odm_set_bb_reg(p_dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, regc08);
-	odm_set_bb_reg(p_dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, reg874);
-	odm_set_bb_reg(p_dm, REG_OFDM_0_XA_AGC_CORE1, 0x7F, 0x40);
-	odm_set_bb_reg(p_dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD, regc50);
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, current_channel);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x00, RFREGOFFSETMASK, rf_loop_reg);
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, MASKDWORD, reg88c);
+	odm_set_bb_reg(dm, REG_OFDM_0_TR_MUX_PAR, MASKDWORD, regc08);
+	odm_set_bb_reg(dm, REG_FPGA0_XCD_RF_INTERFACE_SW, MASKDWORD, reg874);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, 0x7F, 0x40);
+	odm_set_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD, regc50);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, current_channel);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x00, RFREGOFFSETMASK, rf_loop_reg);
 
 	/* Reload AFE Registers */
-	if (p_dm->support_ic_type & ODM_RTL8723B)
-		odm_set_bb_reg(p_dm, REG_RX_WAIT_CCA, MASKDWORD, afe_rrx_wait_cca);
+	if (dm->support_ic_type & ODM_RTL8723B)
+		odm_set_bb_reg(dm, REG_RX_WAIT_CCA, MASKDWORD, afe_rrx_wait_cca);
 
-	if (p_dm->support_ic_type & ODM_RTL8723B) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("psd_report_A[%d]= %d\n", 2416, ant_a_report));
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("psd_report_B[%d]= %d\n", 2416, ant_b_report));
+	if (dm->support_ic_type & ODM_RTL8723B) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "psd_report_A[%d]= %d\n", 2416,
+			  ant_a_report);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "psd_report_B[%d]= %d\n", 2416,
+			  ant_b_report);
 
-		/* 2 Test ant B based on ant A is ON */
-		if ((ant_a_report >= 100) && (ant_b_report >= 100) && (ant_a_report <= 135) && (ant_b_report <= 135)) {
+		/* @2 Test ant B based on ant A is ON */
+		if (ant_a_report >= 100 && ant_b_report >= 100 && ant_a_report <= 135 && ant_b_report <= 135) {
 			u8 TH1 = 2, TH2 = 6;
 
 			if ((ant_a_report - ant_b_report < TH1) || (ant_b_report - ant_a_report < TH1)) {
-				p_dm_swat_table->ANTA_ON = true;
-				p_dm_swat_table->ANTB_ON = true;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_single_dual_antenna_detection(): Dual Antenna\n"));
+				dm_swat_table->ANTA_ON = true;
+				dm_swat_table->ANTB_ON = true;
+				PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Dual Antenna\n",
+					  __func__);
 			} else if (((ant_a_report - ant_b_report >= TH1) && (ant_a_report - ant_b_report <= TH2)) ||
-				((ant_b_report - ant_a_report >= TH1) && (ant_b_report - ant_a_report <= TH2))) {
-				p_dm_swat_table->ANTA_ON = false;
-				p_dm_swat_table->ANTB_ON = false;
+				   ((ant_b_report - ant_a_report >= TH1) && (ant_b_report - ant_a_report <= TH2))) {
+				dm_swat_table->ANTA_ON = false;
+				dm_swat_table->ANTB_ON = false;
 				is_result = false;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_single_dual_antenna_detection(): Need to check again\n"));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "%s: Need to check again\n",
+					  __func__);
 			} else {
-				p_dm_swat_table->ANTA_ON = true;
-				p_dm_swat_table->ANTB_ON = false;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_single_dual_antenna_detection(): Single Antenna\n"));
+				dm_swat_table->ANTA_ON = true;
+				dm_swat_table->ANTB_ON = false;
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "%s: Single Antenna\n", __func__);
 			}
-			p_dm->ant_detected_info.is_ant_detected = true;
-			p_dm->ant_detected_info.db_for_ant_a = ant_a_report;
-			p_dm->ant_detected_info.db_for_ant_b = ant_b_report;
-			p_dm->ant_detected_info.db_for_ant_o = ant_0_report;
+			dm->ant_detected_info.is_ant_detected = true;
+			dm->ant_detected_info.db_for_ant_a = ant_a_report;
+			dm->ant_detected_info.db_for_ant_b = ant_b_report;
+			dm->ant_detected_info.db_for_ant_o = ant_0_report;
 
 		} else {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("return false!!\n"));
+			PHYDM_DBG(dm, DBG_ANT_DIV, "return false!!\n");
 			is_result = false;
 		}
 	}
 	return is_result;
-
 }
 
-
-
-/* 1 [2. Scan AP RSSI method] ================================================== */
-
-
-
+/* @1 [2. Scan AP RSSI method] ================================================== */
 
 boolean
 odm_sw_ant_div_check_before_link(
-	void		*p_dm_void
-)
+	void *dm_void)
 {
-
 #if (RT_MEM_SIZE_LEVEL != RT_MEM_SIZE_MINIMUM)
 
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	PMGNT_INFO		p_mgnt_info = &adapter->MgntInfo;
-	struct _sw_antenna_switch_			*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-	s8			score = 0;
-	PRT_WLAN_BSS	p_tmp_bss_desc, p_test_bss_desc;
-	u8			power_target_L = 9, power_target_H = 16;
-	u8			tmp_power_diff = 0, power_diff = 0, avg_power_diff = 0, max_power_diff = 0, min_power_diff = 0xff;
-	u16			index, counter = 0;
-	static u8		scan_channel;
-	u32			tmp_swas_no_link_bk_reg948;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("ANTA_ON = (( %d )) , ANTB_ON = (( %d ))\n", p_dm->dm_swat_table.ANTA_ON, p_dm->dm_swat_table.ANTB_ON));
-
-	/* if(HP id) */
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	//PMGNT_INFO		mgnt_info = &adapter->MgntInfo;
+	PMGNT_INFO mgnt_info = &(((PADAPTER)(adapter))->MgntInfo);
+	struct sw_antenna_switch *dm_swat_table = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	s8 score = 0;
+	PRT_WLAN_BSS p_tmp_bss_desc, p_test_bss_desc;
+	u8 power_target_L = 9, power_target_H = 16;
+	u8 tmp_power_diff = 0, power_diff = 0, avg_power_diff = 0, max_power_diff = 0, min_power_diff = 0xff;
+	u16 index, counter = 0;
+	static u8 scan_channel;
+	u32 tmp_swas_no_link_bk_reg948;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "ANTA_ON = (( %d )) , ANTB_ON = (( %d ))\n",
+		  dm->dm_swat_table.ANTA_ON, dm->dm_swat_table.ANTB_ON);
+
+	/* @if(HP id) */
 	{
-		if (p_dm->dm_swat_table.rssi_ant_dect_result == true && p_dm->support_ic_type == ODM_RTL8723B) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("8723B RSSI-based Antenna Detection is done\n"));
+		if (dm->dm_swat_table.rssi_ant_dect_result == true && dm->support_ic_type == ODM_RTL8723B) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "8723B RSSI-based Antenna Detection is done\n");
 			return false;
 		}
 
-		if (p_dm->support_ic_type == ODM_RTL8723B) {
-			if (p_dm_swat_table->swas_no_link_bk_reg948 == 0xff)
-				p_dm_swat_table->swas_no_link_bk_reg948 = odm_read_4byte(p_dm, REG_S0_S1_PATH_SWITCH);
+		if (dm->support_ic_type == ODM_RTL8723B) {
+			if (dm_swat_table->swas_no_link_bk_reg948 == 0xff)
+				dm_swat_table->swas_no_link_bk_reg948 = odm_read_4byte(dm, REG_S0_S1_PATH_SWITCH);
 		}
 	}
 
-	if (p_dm->adapter == NULL) { /* For BSOD when plug/unplug fast.  //By YJ,120413 */
+	if (dm->adapter == NULL) { /* @For BSOD when plug/unplug fast.  //By YJ,120413 */
 		/* The ODM structure is not initialized. */
 		return false;
 	}
 
 	/* Retrieve antenna detection registry info, added by Roger, 2012.11.27. */
-	if (!IS_ANT_DETECT_SUPPORT_RSSI(adapter))
+	if (!IS_ANT_DETECT_SUPPORT_RSSI(((PADAPTER)adapter)))
 		return false;
 	else
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Antenna Detection: RSSI method\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Antenna Detection: RSSI method\n");
 
 	/* Since driver is going to set BB register, it shall check if there is another thread controlling BB/RF. */
-	odm_acquire_spin_lock(p_dm, RT_RF_STATE_SPINLOCK);
-	if (p_hal_data->eRFPowerState != eRfOn || p_mgnt_info->RFChangeInProgress || p_mgnt_info->bMediaConnect) {
-		odm_release_spin_lock(p_dm, RT_RF_STATE_SPINLOCK);
+	odm_acquire_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+	if (hal_data->eRFPowerState != eRfOn || mgnt_info->RFChangeInProgress || mgnt_info->bMediaConnect) {
+		odm_release_spin_lock(dm, RT_RF_STATE_SPINLOCK);
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV,
-			("odm_sw_ant_div_check_before_link(): rf_change_in_progress(%x), e_rf_power_state(%x)\n",
-			p_mgnt_info->RFChangeInProgress, p_hal_data->eRFPowerState));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "%s: rf_change_in_progress(%x), e_rf_power_state(%x)\n",
+			  __func__, mgnt_info->RFChangeInProgress,
+			  hal_data->eRFPowerState);
 
-		p_dm_swat_table->swas_no_link_state = 0;
+		dm_swat_table->swas_no_link_state = 0;
 
 		return false;
 	} else
-		odm_release_spin_lock(p_dm, RT_RF_STATE_SPINLOCK);
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("p_dm_swat_table->swas_no_link_state = %d\n", p_dm_swat_table->swas_no_link_state));
-	/* 1 Run AntDiv mechanism "Before Link" part. */
-	if (p_dm_swat_table->swas_no_link_state == 0) {
-		/* 1 Prepare to do Scan again to check current antenna state. */
+		odm_release_spin_lock(dm, RT_RF_STATE_SPINLOCK);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->swas_no_link_state = %d\n",
+		  dm_swat_table->swas_no_link_state);
+	/* @1 Run AntDiv mechanism "Before Link" part. */
+	if (dm_swat_table->swas_no_link_state == 0) {
+		/* @1 Prepare to do Scan again to check current antenna state. */
 
 		/* Set check state to next step. */
-		p_dm_swat_table->swas_no_link_state = 1;
+		dm_swat_table->swas_no_link_state = 1;
 
-		/* Copy Current Scan list. */
-		p_mgnt_info->tmpNumBssDesc = p_mgnt_info->NumBssDesc;
-		PlatformMoveMemory((void *)adapter->MgntInfo.tmpbssDesc, (void *)p_mgnt_info->bssDesc, sizeof(RT_WLAN_BSS) * MAX_BSS_DESC);
+		/* @Copy Current Scan list. */
+		mgnt_info->tmpNumBssDesc = mgnt_info->NumBssDesc;
+		PlatformMoveMemory((void *)mgnt_info->tmpbssDesc, (void *)mgnt_info->bssDesc, sizeof(RT_WLAN_BSS) * MAX_BSS_DESC);
 
-		/* Go back to scan function again. */
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link: Scan one more time\n"));
-		p_mgnt_info->ScanStep = 0;
-		p_mgnt_info->bScanAntDetect = true;
+		/* @Go back to scan function again. */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Scan one more time\n",
+			  __func__);
+		mgnt_info->ScanStep = 0;
+		mgnt_info->bScanAntDetect = true;
 		scan_channel = odm_sw_ant_div_select_scan_chnl(adapter);
 
-
-		if (p_dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
-			if (p_dm_fat_table->rx_idle_ant == MAIN_ANT)
-				odm_update_rx_idle_ant(p_dm, AUX_ANT);
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
+			if (fat_tab->rx_idle_ant == MAIN_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
 			else
-				odm_update_rx_idle_ant(p_dm, MAIN_ANT);
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
 			if (scan_channel == 0) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV,
-					("odm_sw_ant_div_check_before_link(): No AP List Avaiable, Using ant(%s)\n", (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "AUX_ANT" : "MAIN_ANT"));
-
-				if (IS_5G_WIRELESS_MODE(p_mgnt_info->dot11CurrentWirelessMode)) {
-					p_dm_swat_table->ant_5g = p_dm_fat_table->rx_idle_ant;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("p_dm_swat_table->ant_5g=%s\n", (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "%s: No AP List Avaiable, Using ant(%s)\n",
+					  __func__,
+					  (fat_tab->rx_idle_ant == MAIN_ANT) ?
+					  "AUX_ANT" : "MAIN_ANT");
+
+				if (IS_5G_WIRELESS_MODE(mgnt_info->dot11CurrentWirelessMode)) {
+					dm_swat_table->ant_5g = fat_tab->rx_idle_ant;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_5g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
 				} else {
-					p_dm_swat_table->ant_2g = p_dm_fat_table->rx_idle_ant;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("p_dm_swat_table->ant_2g=%s\n", (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+					dm_swat_table->ant_2g = fat_tab->rx_idle_ant;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "dm_swat_table->ant_2g=%s\n", (fat_tab->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
 				}
 				return false;
 			}
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV,
-				("odm_sw_ant_div_check_before_link: Change to %s for testing.\n", ((p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT")));
-		} else if (p_dm->support_ic_type & (ODM_RTL8723B)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "%s: Change to %s for testing.\n", __func__,
+				  ((fat_tab->rx_idle_ant == MAIN_ANT) ?
+				  "MAIN_ANT" : "AUX_ANT"));
+		} else if (dm->support_ic_type & (ODM_RTL8723B)) {
 			/*Switch Antenna to another one.*/
 
-			tmp_swas_no_link_bk_reg948 = odm_read_4byte(p_dm, REG_S0_S1_PATH_SWITCH);
+			tmp_swas_no_link_bk_reg948 = odm_read_4byte(dm, REG_S0_S1_PATH_SWITCH);
 
-			if ((p_dm_swat_table->cur_antenna == MAIN_ANT) && (tmp_swas_no_link_bk_reg948 == 0x200)) {
-				odm_set_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
-				odm_set_bb_reg(p_dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
-				p_dm_swat_table->cur_antenna = AUX_ANT;
+			if (dm_swat_table->cur_antenna == MAIN_ANT && tmp_swas_no_link_bk_reg948 == 0x200) {
+				odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, 0x280);
+				odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, BIT(31), 0x1);
+				dm_swat_table->cur_antenna = AUX_ANT;
 			} else {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Reg[948]= (( %x )) was in wrong state\n", tmp_swas_no_link_bk_reg948));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Reg[948]= (( %x )) was in wrong state\n",
+					  tmp_swas_no_link_bk_reg948);
 				return false;
 			}
 			ODM_delay_us(10);
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link: Change to (( %s-ant))  for testing.\n", (p_dm_swat_table->cur_antenna == MAIN_ANT) ? "MAIN" : "AUX"));
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "%s: Change to (( %s-ant))  for testing.\n",
+				  __func__,
+				  (dm_swat_table->cur_antenna == MAIN_ANT) ?
+				  "MAIN" : "AUX");
 		}
 
 		odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
-		PlatformSetTimer(adapter, &p_mgnt_info->ScanTimer, 5);
+		PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
 
 		return true;
-	} else { /* p_dm_swat_table->swas_no_link_state == 1 */
-		/* 1 ScanComple() is called after antenna swiched. */
-		/* 1 Check scan result and determine which antenna is going */
-		/* 1 to be used. */
+	} else { /* @dm_swat_table->swas_no_link_state == 1 */
+		/* @1 ScanComple() is called after antenna swiched. */
+		/* @1 Check scan result and determine which antenna is going */
+		/* @1 to be used. */
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, (" tmp_num_bss_desc= (( %d ))\n", p_mgnt_info->tmpNumBssDesc)); /* debug for Dino */
+		PHYDM_DBG(dm, DBG_ANT_DIV, " tmp_num_bss_desc= (( %d ))\n",
+			  mgnt_info->tmpNumBssDesc); /* @debug for Dino */
 
-		for (index = 0; index < p_mgnt_info->tmpNumBssDesc; index++) {
-			p_tmp_bss_desc = &(p_mgnt_info->tmpbssDesc[index]); /* Antenna 1 */
-			p_test_bss_desc = &(p_mgnt_info->bssDesc[index]); /* Antenna 2 */
+		for (index = 0; index < mgnt_info->tmpNumBssDesc; index++) {
+			p_tmp_bss_desc = &mgnt_info->tmpbssDesc[index]; /* @Antenna 1 */
+			p_test_bss_desc = &mgnt_info->bssDesc[index]; /* @Antenna 2 */
 
 			if (PlatformCompareMemory(p_test_bss_desc->bdBssIdBuf, p_tmp_bss_desc->bdBssIdBuf, 6) != 0) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link(): ERROR!! This shall not happen.\n"));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "%s: ERROR!! This shall not happen.\n",
+					  __func__);
 				continue;
 			}
 
-			if (p_dm->support_ic_type != ODM_RTL8723B) {
+			if (dm->support_ic_type != ODM_RTL8723B) {
 				if (p_tmp_bss_desc->ChannelNumber == scan_channel) {
 					if (p_tmp_bss_desc->RecvSignalPower > p_test_bss_desc->RecvSignalPower) {
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link: Compare scan entry: score++\n"));
+						PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Compare scan entry: score++\n", __func__);
 						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower));
+						PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
 
 						score++;
 						PlatformMoveMemory(p_test_bss_desc, p_tmp_bss_desc, sizeof(RT_WLAN_BSS));
 					} else if (p_tmp_bss_desc->RecvSignalPower < p_test_bss_desc->RecvSignalPower) {
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link: Compare scan entry: score--\n"));
+						PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Compare scan entry: score--\n", __func__);
 						RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower));
+						PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
 						score--;
 					} else {
 						if (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp < 5000) {
 							RT_PRINT_STR(COMP_SCAN, DBG_WARNING, "GetScanInfo(): new Bss SSID:", p_tmp_bss_desc->bdSsIdBuf, p_tmp_bss_desc->bdSsIdLen);
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("at ch %d, Original: %d, Test: %d\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower));
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("The 2nd Antenna didn't get this AP\n\n"));
+							PHYDM_DBG(dm, DBG_ANT_DIV, "at ch %d, Original: %d, Test: %d\n", p_tmp_bss_desc->ChannelNumber, p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+							PHYDM_DBG(dm, DBG_ANT_DIV, "The 2nd Antenna didn't get this AP\n\n");
 						}
 					}
 				}
-			} else { /* 8723B */
+			} else { /* @8723B */
 				if (p_tmp_bss_desc->ChannelNumber == scan_channel) {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("channel_number == scan_channel->(( %d ))\n", p_tmp_bss_desc->ChannelNumber));
+					PHYDM_DBG(dm, DBG_ANT_DIV, "channel_number == scan_channel->(( %d ))\n", p_tmp_bss_desc->ChannelNumber);
 
 					if (p_tmp_bss_desc->RecvSignalPower > p_test_bss_desc->RecvSignalPower) { /* Pow(Ant1) > Pow(Ant2) */
 						counter++;
 						tmp_power_diff = (u8)(p_tmp_bss_desc->RecvSignalPower - p_test_bss_desc->RecvSignalPower);
 						power_diff = power_diff + tmp_power_diff;
 
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower));
-						PHYDM_PRINT_ADDR(p_dm, DBG_ANT_DIV, ("SSID:"), p_tmp_bss_desc->bdSsIdBuf);
-						PHYDM_PRINT_ADDR(p_dm, DBG_ANT_DIV, ("BSSID:"), p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
 
-						/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("tmp_power_diff: (( %d)),max_power_diff: (( %d)),min_power_diff: (( %d))\n", tmp_power_diff,max_power_diff,min_power_diff)); */
+#if 0
+						/* PHYDM_DBG(dm,DBG_ANT_DIV, "tmp_power_diff: (( %d)),max_power_diff: (( %d)),min_power_diff: (( %d))\n", tmp_power_diff,max_power_diff,min_power_diff); */
+#endif
 						if (tmp_power_diff > max_power_diff)
 							max_power_diff = tmp_power_diff;
 						if (tmp_power_diff < min_power_diff)
 							min_power_diff = tmp_power_diff;
-						/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("max_power_diff: (( %d)),min_power_diff: (( %d))\n",max_power_diff,min_power_diff)); */
+#if 0
+						/* PHYDM_DBG(dm,DBG_ANT_DIV, "max_power_diff: (( %d)),min_power_diff: (( %d))\n",max_power_diff,min_power_diff); */
+#endif
 
 						PlatformMoveMemory(p_test_bss_desc, p_tmp_bss_desc, sizeof(RT_WLAN_BSS));
 					} else if (p_test_bss_desc->RecvSignalPower > p_tmp_bss_desc->RecvSignalPower) { /* Pow(Ant1) < Pow(Ant2) */
 						counter++;
 						tmp_power_diff = (u8)(p_test_bss_desc->RecvSignalPower - p_tmp_bss_desc->RecvSignalPower);
 						power_diff = power_diff + tmp_power_diff;
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower));
-						PHYDM_PRINT_ADDR(p_dm, DBG_ANT_DIV, ("SSID:"), p_tmp_bss_desc->bdSsIdBuf);
-						PHYDM_PRINT_ADDR(p_dm, DBG_ANT_DIV, ("BSSID:"), p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+						PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
 						if (tmp_power_diff > max_power_diff)
 							max_power_diff = tmp_power_diff;
 						if (tmp_power_diff < min_power_diff)
 							min_power_diff = tmp_power_diff;
 					} else { /* Pow(Ant1) = Pow(Ant2) */
 						if (p_test_bss_desc->bdTstamp > p_tmp_bss_desc->bdTstamp) { /* Stamp(Ant1) < Stamp(Ant2) */
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000));
+							PHYDM_DBG(dm, DBG_ANT_DIV, "time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000);
 							if (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp > 5000) {
 								counter++;
-								PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower));
-								PHYDM_PRINT_ADDR(p_dm, DBG_ANT_DIV, ("SSID:"), p_tmp_bss_desc->bdSsIdBuf);
-								PHYDM_PRINT_ADDR(p_dm, DBG_ANT_DIV, ("BSSID:"), p_tmp_bss_desc->bdSsIdBuf);
+								PHYDM_DBG(dm, DBG_ANT_DIV, "Original: %d, Test: %d\n", p_tmp_bss_desc->RecvSignalPower, p_test_bss_desc->RecvSignalPower);
+								PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "SSID:", p_tmp_bss_desc->bdSsIdBuf);
+								PHYDM_PRINT_ADDR(dm, DBG_ANT_DIV, "BSSID:", p_tmp_bss_desc->bdSsIdBuf);
 								min_power_diff = 0;
 							}
 						} else
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Error !!!]: Time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000));
+							PHYDM_DBG(dm, DBG_ANT_DIV, "[Error !!!]: Time_diff: %lld\n", (p_test_bss_desc->bdTstamp - p_tmp_bss_desc->bdTstamp) / 1000);
 					}
 				}
 			}
 		}
 
-		if (p_dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
-			if (p_mgnt_info->NumBssDesc != 0 && score < 0) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV,
-					("odm_sw_ant_div_check_before_link(): Using ant(%s)\n", (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8821)) {
+			if (mgnt_info->NumBssDesc != 0 && score < 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "%s: Using ant(%s)\n", __func__,
+					  (fat_tab->rx_idle_ant == MAIN_ANT) ?
+					  "MAIN_ANT" : "AUX_ANT");
 			} else {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV,
-					("odm_sw_ant_div_check_before_link(): Remain ant(%s)\n", (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "AUX_ANT" : "MAIN_ANT"));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "%s: Remain ant(%s)\n", __func__,
+					  (fat_tab->rx_idle_ant == MAIN_ANT) ?
+					  "AUX_ANT" : "MAIN_ANT");
 
-				if (p_dm_fat_table->rx_idle_ant == MAIN_ANT)
-					odm_update_rx_idle_ant(p_dm, AUX_ANT);
+				if (fat_tab->rx_idle_ant == MAIN_ANT)
+					odm_update_rx_idle_ant(dm, AUX_ANT);
 				else
-					odm_update_rx_idle_ant(p_dm, MAIN_ANT);
+					odm_update_rx_idle_ant(dm, MAIN_ANT);
 			}
 
-			if (IS_5G_WIRELESS_MODE(p_mgnt_info->dot11CurrentWirelessMode)) {
-				p_dm_swat_table->ant_5g = p_dm_fat_table->rx_idle_ant;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("p_dm_swat_table->ant_5g=%s\n", (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+			if (IS_5G_WIRELESS_MODE(mgnt_info->dot11CurrentWirelessMode)) {
+				dm_swat_table->ant_5g = fat_tab->rx_idle_ant;
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "dm_swat_table->ant_5g=%s\n",
+					  (fat_tab->rx_idle_ant == MAIN_ANT) ?
+					  "MAIN_ANT" : "AUX_ANT");
 			} else {
-				p_dm_swat_table->ant_2g = p_dm_fat_table->rx_idle_ant;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("p_dm_swat_table->ant_2g=%s\n", (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+				dm_swat_table->ant_2g = fat_tab->rx_idle_ant;
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "dm_swat_table->ant_2g=%s\n",
+					  (fat_tab->rx_idle_ant == MAIN_ANT) ?
+					  "MAIN_ANT" : "AUX_ANT");
 			}
-		} else if (p_dm->support_ic_type == ODM_RTL8723B) {
+		} else if (dm->support_ic_type == ODM_RTL8723B) {
 			if (counter == 0) {
-				if (p_dm->dm_swat_table.pre_aux_fail_detec == false) {
-					p_dm->dm_swat_table.pre_aux_fail_detec = true;
-					p_dm->dm_swat_table.rssi_ant_dect_result = false;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("counter=(( 0 )) , [[ Cannot find any AP with Aux-ant ]] ->  Scan Target-channel again\n"));
+				if (dm->dm_swat_table.pre_aux_fail_detec == false) {
+					dm->dm_swat_table.pre_aux_fail_detec = true;
+					dm->dm_swat_table.rssi_ant_dect_result = false;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter=(( 0 )) , [[ Cannot find any AP with Aux-ant ]] ->  Scan Target-channel again\n");
 
-					/* 3 [ Scan again ] */
+					/* @3 [ Scan again ] */
 					odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
-					PlatformSetTimer(adapter, &p_mgnt_info->ScanTimer, 5);
+					PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
 					return true;
 				} else { /* pre_aux_fail_detec == true */
-					/* 2 [ Single Antenna ] */
-					p_dm->dm_swat_table.pre_aux_fail_detec = false;
-					p_dm->dm_swat_table.rssi_ant_dect_result = true;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("counter=(( 0 )) , [[  Still cannot find any AP ]]\n"));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link(): Single antenna\n"));
+					/* @2 [ Single Antenna ] */
+					dm->dm_swat_table.pre_aux_fail_detec = false;
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter=(( 0 )) , [[  Still cannot find any AP ]]\n");
+					PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Single antenna\n", __func__);
 				}
-				p_dm->dm_swat_table.aux_fail_detec_counter++;
+				dm->dm_swat_table.aux_fail_detec_counter++;
 			} else {
-				p_dm->dm_swat_table.pre_aux_fail_detec = false;
+				dm->dm_swat_table.pre_aux_fail_detec = false;
 
 				if (counter == 3) {
 					avg_power_diff = ((power_diff - max_power_diff - min_power_diff) >> 1) + ((max_power_diff + min_power_diff) >> 2);
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ counter==3 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff));
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ counter==3 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff);
 				} else if (counter >= 4) {
 					avg_power_diff = (power_diff - max_power_diff - min_power_diff) / (counter - 2);
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ counter>=4 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff));
+					PHYDM_DBG(dm, DBG_ANT_DIV, "counter: (( %d )) ,  power_diff: (( %d ))\n", counter, power_diff);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ counter>=4 ] Modified avg_power_diff: (( %d )) , max_power_diff: (( %d )) ,  min_power_diff: (( %d ))\n", avg_power_diff, max_power_diff, min_power_diff);
 
-				} else { /* counter==1,2 */
+				} else { /* @counter==1,2 */
 					avg_power_diff = power_diff / counter;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("avg_power_diff: (( %d )) , counter: (( %d )) ,  power_diff: (( %d ))\n", avg_power_diff, counter, power_diff));
+					PHYDM_DBG(dm, DBG_ANT_DIV, "avg_power_diff: (( %d )) , counter: (( %d )) ,  power_diff: (( %d ))\n", avg_power_diff, counter, power_diff);
 				}
 
-				/* 2 [ Retry ] */
-				if ((avg_power_diff >= power_target_L) && (avg_power_diff <= power_target_H)) {
-					p_dm->dm_swat_table.retry_counter++;
+				/* @2 [ Retry ] */
+				if (avg_power_diff >= power_target_L && avg_power_diff <= power_target_H) {
+					dm->dm_swat_table.retry_counter++;
 
-					if (p_dm->dm_swat_table.retry_counter <= 3) {
-						p_dm->dm_swat_table.rssi_ant_dect_result = false;
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[[ Low confidence result ]] avg_power_diff= (( %d ))  ->  Scan Target-channel again ]]\n", avg_power_diff));
+					if (dm->dm_swat_table.retry_counter <= 3) {
+						dm->dm_swat_table.rssi_ant_dect_result = false;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[[ Low confidence result ]] avg_power_diff= (( %d ))  ->  Scan Target-channel again ]]\n", avg_power_diff);
 
-						/* 3 [ Scan again ] */
+						/* @3 [ Scan again ] */
 						odm_sw_ant_div_construct_scan_chnl(adapter, scan_channel);
-						PlatformSetTimer(adapter, &p_mgnt_info->ScanTimer, 5);
+						PlatformSetTimer(adapter, &mgnt_info->ScanTimer, 5);
 						return true;
 					} else {
-						p_dm->dm_swat_table.rssi_ant_dect_result = true;
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[[ Still Low confidence result ]]  (( retry_counter > 3 ))\n"));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link(): Single antenna\n"));
+						dm->dm_swat_table.rssi_ant_dect_result = true;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[[ Still Low confidence result ]]  (( retry_counter > 3 ))\n");
+						PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Single antenna\n", __func__);
 					}
-
 				}
-				/* 2 [ Dual Antenna ] */
-				else if ((p_mgnt_info->NumBssDesc != 0) && (avg_power_diff < power_target_L)) {
-					p_dm->dm_swat_table.rssi_ant_dect_result = true;
-					if (p_dm->dm_swat_table.ANTB_ON == false) {
-						p_dm->dm_swat_table.ANTA_ON = true;
-						p_dm->dm_swat_table.ANTB_ON = true;
+				/* @2 [ Dual Antenna ] */
+				else if ((mgnt_info->NumBssDesc != 0) && (avg_power_diff < power_target_L)) {
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					if (dm->dm_swat_table.ANTB_ON == false) {
+						dm->dm_swat_table.ANTA_ON = true;
+						dm->dm_swat_table.ANTB_ON = true;
 					}
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link(): Dual antenna\n"));
-					p_dm->dm_swat_table.dual_ant_counter++;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Dual antenna\n", __func__);
+					dm->dm_swat_table.dual_ant_counter++;
 
 					/* set bt coexDM from 1ant coexDM to 2ant coexDM */
 					BT_SetBtCoexAntNum(adapter, BT_COEX_ANT_TYPE_DETECTED, 2);
 
-					/* 3 [ Init antenna diversity ] */
-					p_dm->support_ability |= ODM_BB_ANT_DIV;
-					odm_ant_div_init(p_dm);
+					/* @3 [ Init antenna diversity ] */
+					dm->support_ability |= ODM_BB_ANT_DIV;
+					odm_ant_div_init(dm);
 				}
-				/* 2 [ Single Antenna ] */
+				/* @2 [ Single Antenna ] */
 				else if (avg_power_diff > power_target_H) {
-					p_dm->dm_swat_table.rssi_ant_dect_result = true;
-					if (p_dm->dm_swat_table.ANTB_ON == true) {
-						p_dm->dm_swat_table.ANTA_ON = true;
-						p_dm->dm_swat_table.ANTB_ON = false;
-						/* bt_set_bt_coex_ant_num(adapter, BT_COEX_ANT_TYPE_DETECTED, 1); */
+					dm->dm_swat_table.rssi_ant_dect_result = true;
+					if (dm->dm_swat_table.ANTB_ON == true) {
+						dm->dm_swat_table.ANTA_ON = true;
+						dm->dm_swat_table.ANTB_ON = false;
+#if 0
+						/* @bt_set_bt_coex_ant_num(adapter, BT_COEX_ANT_TYPE_DETECTED, 1); */
+#endif
 					}
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link(): Single antenna\n"));
-					p_dm->dm_swat_table.single_ant_counter++;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "%s: Single antenna\n", __func__);
+					dm->dm_swat_table.single_ant_counter++;
 				}
 			}
-			/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("is_result=(( %d ))\n",p_dm->dm_swat_table.rssi_ant_dect_result)); */
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("dual_ant_counter = (( %d )), single_ant_counter = (( %d )) , retry_counter = (( %d )) , aux_fail_detec_counter = (( %d ))\n\n\n",
-				p_dm->dm_swat_table.dual_ant_counter, p_dm->dm_swat_table.single_ant_counter, p_dm->dm_swat_table.retry_counter, p_dm->dm_swat_table.aux_fail_detec_counter));
-
-			/* 2 recover the antenna setting */
-
-			if (p_dm->dm_swat_table.ANTB_ON == false)
-				odm_set_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, 0xfff, (p_dm_swat_table->swas_no_link_bk_reg948));
-
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("is_result=(( %d )), Recover  Reg[948]= (( %x ))\n\n", p_dm->dm_swat_table.rssi_ant_dect_result, p_dm_swat_table->swas_no_link_bk_reg948));
-
-
+#if 0
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "is_result=(( %d ))\n",dm->dm_swat_table.rssi_ant_dect_result); */
+#endif
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "dual_ant_counter = (( %d )), single_ant_counter = (( %d )) , retry_counter = (( %d )) , aux_fail_detec_counter = (( %d ))\n\n\n",
+				  dm->dm_swat_table.dual_ant_counter,
+				  dm->dm_swat_table.single_ant_counter,
+				  dm->dm_swat_table.retry_counter,
+				  dm->dm_swat_table.aux_fail_detec_counter);
+
+			/* @2 recover the antenna setting */
+
+			if (dm->dm_swat_table.ANTB_ON == false)
+				odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, 0xfff, (dm_swat_table->swas_no_link_bk_reg948));
+
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "is_result=(( %d )), Recover  Reg[948]= (( %x ))\n\n",
+				  dm->dm_swat_table.rssi_ant_dect_result,
+				  dm_swat_table->swas_no_link_bk_reg948);
 		}
 
-		/* Check state reset to default and wait for next time. */
-		p_dm_swat_table->swas_no_link_state = 0;
-		p_mgnt_info->bScanAntDetect = false;
+		/* @Check state reset to default and wait for next time. */
+		dm_swat_table->swas_no_link_state = 0;
+		mgnt_info->bScanAntDetect = false;
 
 		return false;
 	}
 
 #else
-	return	false;
+	return false;
 #endif
 
 	return false;
 }
 
-
-
-
-
-
-/* 1 [3. PSD method] ========================================================== */
-void
-odm_single_dual_antenna_detection_psd(
-	void	*p_dm_void
-)
+/* @1 [3. PSD method] ========================================================== */
+void odm_single_dual_antenna_detection_psd(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	channel_ori;
-	u8	initial_gain = 0x36;
-	u8	tone_idx;
-	u8	tone_lenth_1 = 7, tone_lenth_2 = 4;
-	u16	tone_idx_1[7] = {88, 104, 120, 8, 24, 40, 56};
-	u16	tone_idx_2[4] = {8, 24, 40, 56};
-	u32	psd_report_main[11] = {0}, psd_report_aux[11] = {0};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 channel_ori;
+	u8 initial_gain = 0x36;
+	u8 tone_idx;
+	u8 tone_lenth_1 = 7, tone_lenth_2 = 4;
+	u16 tone_idx_1[7] = {88, 104, 120, 8, 24, 40, 56};
+	u16 tone_idx_2[4] = {8, 24, 40, 56};
+	u32 psd_report_main[11] = {0}, psd_report_aux[11] = {0};
 	/* u8	tone_lenth_1=4, tone_lenth_2=2; */
 	/* u16	tone_idx_1[4]={88, 120, 24, 56}; */
 	/* u16	tone_idx_2[2]={ 24,  56}; */
 	/* u32	psd_report_main[6]={0}, psd_report_aux[6]={0}; */
 
-	u32	PSD_report_temp, max_psd_report_main = 0, max_psd_report_aux = 0;
-	u32	PSD_power_threshold;
-	u32	main_psd_result = 0, aux_psd_result = 0;
-	u32	regc50, reg948, regb2c, regc14, reg908;
-	u32	i = 0, test_num = 8;
+	u32 PSD_report_temp, max_psd_report_main = 0, max_psd_report_aux = 0;
+	u32 PSD_power_threshold;
+	u32 main_psd_result = 0, aux_psd_result = 0;
+	u32 regc50, reg948, regb2c, regc14, reg908;
+	u32 i = 0, test_num = 8;
 
-
-	if (p_dm->support_ic_type != ODM_RTL8723B)
+	if (dm->support_ic_type != ODM_RTL8723B)
 		return;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_single_dual_antenna_detection_psd()============>\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "%s============>\n", __func__);
 
-	/* 2 [ Backup Current RF/BB Settings ] */
+	/* @2 [ Backup Current RF/BB Settings ] */
 
-	channel_ori = odm_get_rf_reg(p_dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
-	reg948 = odm_get_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
-	regb2c =  odm_get_bb_reg(p_dm, REG_AGC_TABLE_SELECT, MASKDWORD);
-	regc50 = odm_get_bb_reg(p_dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
-	regc14 = odm_get_bb_reg(p_dm, 0xc14, MASKDWORD);
-	reg908 = odm_get_bb_reg(p_dm, 0x908, MASKDWORD);
+	channel_ori = odm_get_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, RFREGOFFSETMASK);
+	reg948 = odm_get_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD);
+	regb2c = odm_get_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD);
+	regc50 = odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKDWORD);
+	regc14 = odm_get_bb_reg(dm, R_0xc14, MASKDWORD);
+	reg908 = odm_get_bb_reg(dm, R_0x908, MASKDWORD);
 
-	/* 2 [ setting for doing PSD function (CH4)] */
-	odm_set_bb_reg(p_dm, REG_FPGA0_RFMOD, BIT(24), 0); /* disable whole CCK block */
-	odm_write_1byte(p_dm, REG_TXPAUSE, 0xFF); /* Turn off TX  ->  Pause TX Queue */
-	odm_set_bb_reg(p_dm, 0xC14, MASKDWORD, 0x0); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
+	/* @2 [ setting for doing PSD function (CH4)] */
+	odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT(24), 0); /* @disable whole CCK block */
+	odm_write_1byte(dm, REG_TXPAUSE, 0xFF); /* Turn off TX  ->  Pause TX Queue */
+	odm_set_bb_reg(dm, R_0xc14, MASKDWORD, 0x0); /* @[ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
 
 	/* PHYTXON while loop */
-	odm_set_bb_reg(p_dm, 0x908, MASKDWORD, 0x803);
-	while (odm_get_bb_reg(p_dm, 0xdf4, BIT(6))) {
+	odm_set_bb_reg(dm, R_0x908, MASKDWORD, 0x803);
+	while (odm_get_bb_reg(dm, R_0xdf4, BIT(6))) {
 		i++;
 		if (i > 1000000) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Wait in %s() more than %d times!\n", __FUNCTION__, i));
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Wait in %s() more than %d times!\n",
+				  __FUNCTION__, i);
 			break;
 		}
 	}
 
-	odm_set_bb_reg(p_dm, 0xc50, 0x7f, initial_gain);
-	odm_set_rf_reg(p_dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     /* Set RF to CH4 & 40M */
-	odm_set_bb_reg(p_dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
-	odm_set_bb_reg(p_dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0);  /* 128 pt	 */ /* Set PSD 128 ptss */
+	odm_set_bb_reg(dm, R_0xc50, 0x7f, initial_gain);
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04); /* Set RF to CH4 & 40M */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf); /* @3 wire Disable    88c[23:20]=0xf */
+	odm_set_bb_reg(dm, REG_FPGA0_PSD_FUNCTION, BIT(14) | BIT15, 0x0); /* 128 pt	 */ /* Set PSD 128 ptss */
 	ODM_delay_us(3000);
 
+	/* @2 [ Doing PSD Function in (CH4)] */
 
-	/* 2 [ Doing PSD Function in (CH4)] */
-
-	/* Antenna A */
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Switch to Main-ant   (CH4)\n"));
-	odm_set_bb_reg(p_dm, 0x948, 0xfff, 0x200);
+	/* @Antenna A */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Main-ant   (CH4)\n");
+	odm_set_bb_reg(dm, R_0x948, 0xfff, 0x200);
 	ODM_delay_us(10);
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("dbg\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "dbg\n");
 	for (i = 0; i < test_num; i++) {
 		for (tone_idx = 0; tone_idx < tone_lenth_1; tone_idx++) {
-			PSD_report_temp = phydm_get_psd_data(p_dm, tone_idx_1[tone_idx], initial_gain);
-			/* if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_1[tone_idx], initial_gain);
+			/* @if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
 			psd_report_main[tone_idx] += PSD_report_temp;
 		}
 	}
-	/* Antenna B */
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Switch to Aux-ant   (CH4)\n"));
-	odm_set_bb_reg(p_dm, 0x948, 0xfff, 0x280);
+	/* @Antenna B */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Aux-ant   (CH4)\n");
+	odm_set_bb_reg(dm, R_0x948, 0xfff, 0x280);
 	ODM_delay_us(10);
 	for (i = 0; i < test_num; i++) {
 		for (tone_idx = 0; tone_idx < tone_lenth_1; tone_idx++) {
-			PSD_report_temp = phydm_get_psd_data(p_dm, tone_idx_1[tone_idx], initial_gain);
-			/* if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_1[tone_idx], initial_gain);
+			/* @if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
 			psd_report_aux[tone_idx] += PSD_report_temp;
 		}
 	}
-	/* 2 [ Doing PSD Function in (CH8)] */
+	/* @2 [ Doing PSD Function in (CH8)] */
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0);	/* 3 wire enable    88c[23:20]=0x0 */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0); /* @3 wire enable    88c[23:20]=0x0 */
 	ODM_delay_us(3000);
 
-	odm_set_bb_reg(p_dm, 0xc50, 0x7f, initial_gain);
-	odm_set_rf_reg(p_dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04);     /* Set RF to CH8 & 40M */
+	odm_set_bb_reg(dm, R_0xc50, 0x7f, initial_gain);
+	odm_set_rf_reg(dm, RF_PATH_A, ODM_CHANNEL, 0x7ff, 0x04); /* Set RF to CH8 & 40M */
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0xf); /* @3 wire Disable    88c[23:20]=0xf */
 	ODM_delay_us(3000);
 
-	/* Antenna A */
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Switch to Main-ant   (CH8)\n"));
-	odm_set_bb_reg(p_dm, 0x948, 0xfff, 0x200);
+	/* @Antenna A */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Main-ant   (CH8)\n");
+	odm_set_bb_reg(dm, R_0x948, 0xfff, 0x200);
 	ODM_delay_us(10);
 
 	for (i = 0; i < test_num; i++) {
 		for (tone_idx = 0; tone_idx < tone_lenth_2; tone_idx++) {
-			PSD_report_temp = phydm_get_psd_data(p_dm, tone_idx_2[tone_idx], initial_gain);
-			/* if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_2[tone_idx], initial_gain);
+			/* @if(  PSD_report_temp>psd_report_main[tone_idx]  ) */
 			psd_report_main[tone_lenth_1 + tone_idx] += PSD_report_temp;
 		}
 	}
 
-	/* Antenna B */
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Switch to Aux-ant   (CH8)\n"));
-	odm_set_bb_reg(p_dm, 0x948, 0xfff, 0x280);
+	/* @Antenna B */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Switch to Aux-ant   (CH8)\n");
+	odm_set_bb_reg(dm, R_0x948, 0xfff, 0x280);
 	ODM_delay_us(10);
 
 	for (i = 0; i < test_num; i++) {
 		for (tone_idx = 0; tone_idx < tone_lenth_2; tone_idx++) {
-			PSD_report_temp = phydm_get_psd_data(p_dm, tone_idx_2[tone_idx], initial_gain);
-			/* if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
+			PSD_report_temp = phydm_get_psd_data(dm, tone_idx_2[tone_idx], initial_gain);
+			/* @if(  PSD_report_temp>psd_report_aux[tone_idx]  ) */
 			psd_report_aux[tone_lenth_1 + tone_idx] += PSD_report_temp;
 		}
 	}
 
-	/* 2 [ Calculate Result ] */
+	/* @2 [ Calculate Result ] */
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\nMain PSD Result: (ALL)\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\nMain PSD Result: (ALL)\n");
 	for (tone_idx = 0; tone_idx < (tone_lenth_1 + tone_lenth_2); tone_idx++) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Tone-%d]: %d,\n", (tone_idx + 1), psd_report_main[tone_idx]));
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Tone-%d]: %d,\n", (tone_idx + 1),
+			  psd_report_main[tone_idx]);
 		main_psd_result += psd_report_main[tone_idx];
 		if (psd_report_main[tone_idx] > max_psd_report_main)
 			max_psd_report_main = psd_report_main[tone_idx];
 	}
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("--------------------------- \nTotal_Main= (( %d ))\n", main_psd_result));
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("MAX_Main = (( %d ))\n", max_psd_report_main));
-
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "--------------------------- \nTotal_Main= (( %d ))\n",
+		  main_psd_result);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "MAX_Main = (( %d ))\n",
+		  max_psd_report_main);
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\nAux PSD Result: (ALL)\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\nAux PSD Result: (ALL)\n");
 	for (tone_idx = 0; tone_idx < (tone_lenth_1 + tone_lenth_2); tone_idx++) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Tone-%d]: %d,\n", (tone_idx + 1), psd_report_aux[tone_idx]));
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Tone-%d]: %d,\n", (tone_idx + 1),
+			  psd_report_aux[tone_idx]);
 		aux_psd_result += psd_report_aux[tone_idx];
 		if (psd_report_aux[tone_idx] > max_psd_report_aux)
 			max_psd_report_aux = psd_report_aux[tone_idx];
 	}
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("--------------------------- \nTotal_Aux= (( %d ))\n", aux_psd_result));
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("MAX_Aux = (( %d ))\n\n", max_psd_report_aux));
-
-	/* main_psd_result=main_psd_result-max_psd_report_main; */
-	/* aux_psd_result=aux_psd_result-max_psd_report_aux; */
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "--------------------------- \nTotal_Aux= (( %d ))\n",
+		  aux_psd_result);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "MAX_Aux = (( %d ))\n\n",
+		  max_psd_report_aux);
+
+	/* @main_psd_result=main_psd_result-max_psd_report_main; */
+	/* @aux_psd_result=aux_psd_result-max_psd_report_aux; */
 	PSD_power_threshold = (main_psd_result * 7) >> 3;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Main_result, Aux_result ] = [ %d , %d ], PSD_power_threshold=(( %d ))\n", main_psd_result, aux_psd_result, PSD_power_threshold));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Main_result, Aux_result ] = [ %d , %d ], PSD_power_threshold=(( %d ))\n",
+		  main_psd_result, aux_psd_result, PSD_power_threshold);
 
-	/* 3 [ Dual Antenna ] */
+	/* @3 [ Dual Antenna ] */
 	if (aux_psd_result >= PSD_power_threshold) {
-		if (p_dm->dm_swat_table.ANTB_ON == false) {
-			p_dm->dm_swat_table.ANTA_ON = true;
-			p_dm->dm_swat_table.ANTB_ON = true;
+		if (dm->dm_swat_table.ANTB_ON == false) {
+			dm->dm_swat_table.ANTA_ON = true;
+			dm->dm_swat_table.ANTB_ON = true;
 		}
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link(): Dual antenna\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "odm_sw_ant_div_check_before_link(): Dual antenna\n");
 
+#if 0
 		/* set bt coexDM from 1ant coexDM to 2ant coexDM */
-		/* bt_set_bt_coex_ant_num(p_adapter, BT_COEX_ANT_TYPE_DETECTED, 2); */
+		/* @bt_set_bt_coex_ant_num(adapter, BT_COEX_ANT_TYPE_DETECTED, 2); */
+#endif
 
-		/* Init antenna diversity */
-		p_dm->support_ability |= ODM_BB_ANT_DIV;
-		odm_ant_div_init(p_dm);
+		/* @Init antenna diversity */
+		dm->support_ability |= ODM_BB_ANT_DIV;
+		odm_ant_div_init(dm);
 	}
-	/* 3 [ Single Antenna ] */
+	/* @3 [ Single Antenna ] */
 	else {
-		if (p_dm->dm_swat_table.ANTB_ON == true) {
-			p_dm->dm_swat_table.ANTA_ON = true;
-			p_dm->dm_swat_table.ANTB_ON = false;
+		if (dm->dm_swat_table.ANTB_ON == true) {
+			dm->dm_swat_table.ANTA_ON = true;
+			dm->dm_swat_table.ANTB_ON = false;
 		}
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_sw_ant_div_check_before_link(): Single antenna\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "odm_sw_ant_div_check_before_link(): Single antenna\n");
 	}
 
-	/* 2 [ Recover all parameters ] */
+	/* @2 [ Recover all parameters ] */
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, channel_ori);
-	odm_set_bb_reg(p_dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0);	/* 3 wire enable    88c[23:20]=0x0 */
-	odm_set_bb_reg(p_dm, 0xc50, 0x7f, regc50);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_CHNLBW, RFREGOFFSETMASK, channel_ori);
+	odm_set_bb_reg(dm, REG_FPGA0_ANALOG_PARAMETER4, 0xf00000, 0x0); /* @3 wire enable    88c[23:20]=0x0 */
+	odm_set_bb_reg(dm, R_0xc50, 0x7f, regc50);
 
-	odm_set_bb_reg(p_dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
-	odm_set_bb_reg(p_dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
+	odm_set_bb_reg(dm, REG_S0_S1_PATH_SWITCH, MASKDWORD, reg948);
+	odm_set_bb_reg(dm, REG_AGC_TABLE_SELECT, MASKDWORD, regb2c);
 
-	odm_set_bb_reg(p_dm, REG_FPGA0_RFMOD, BIT(24), 1); /* enable whole CCK block */
-	odm_write_1byte(p_dm, REG_TXPAUSE, 0x0); /* Turn on TX	 */ /* Resume TX Queue */
-	odm_set_bb_reg(p_dm, 0xC14, MASKDWORD, regc14); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn on CCA] */
-	odm_set_bb_reg(p_dm, 0x908, MASKDWORD, reg908);
+	odm_set_bb_reg(dm, REG_FPGA0_RFMOD, BIT(24), 1); /* @enable whole CCK block */
+	odm_write_1byte(dm, REG_TXPAUSE, 0x0); /* Turn on TX	 */ /* Resume TX Queue */
+	odm_set_bb_reg(dm, R_0xc14, MASKDWORD, regc14); /* @[ Set IQK Matrix = 0 ] equivalent to [ Turn on CCA] */
+	odm_set_bb_reg(dm, R_0x908, MASKDWORD, reg908);
 
 	return;
-
 }
 
-#endif
-void
-odm_sw_ant_detect_init(
-	void		*p_dm_void
-)
+void odm_sw_ant_detect_init(void *dm_void)
 {
-#if (defined(CONFIG_ANT_DETECTION))
 #if (RTL8723B_SUPPORT == 1)
 
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *dm_swat_table = &dm->dm_swat_table;
 
-	if (p_dm->support_ic_type != ODM_RTL8723B)
+	if (dm->support_ic_type != ODM_RTL8723B)
 		return;
 
-	/* p_dm_swat_table->pre_antenna = MAIN_ANT; */
-	/* p_dm_swat_table->cur_antenna = MAIN_ANT; */
-	p_dm_swat_table->swas_no_link_state = 0;
-	p_dm_swat_table->pre_aux_fail_detec = false;
-	p_dm_swat_table->swas_no_link_bk_reg948 = 0xff;
+	/* @dm_swat_table->pre_antenna = MAIN_ANT; */
+	/* @dm_swat_table->cur_antenna = MAIN_ANT; */
+	dm_swat_table->swas_no_link_state = 0;
+	dm_swat_table->pre_aux_fail_detec = false;
+	dm_swat_table->swas_no_link_bk_reg948 = 0xff;
 
-	#ifdef CONFIG_PSD_TOOL
-	phydm_psd_init(p_dm);
-	#endif
+#ifdef CONFIG_PSD_TOOL
+	phydm_psd_init(dm);
 #endif
 #endif
 }
+#endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.h
index 74627fc57ead..c36b936b9725 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdect.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,83 +9,71 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMANTDECT_H__
-#define    __PHYDMANTDECT_H__
+#ifndef __PHYDMANTDECT_H__
+#define __PHYDMANTDECT_H__
 
-#define ANTDECT_VERSION	"2.1"	/*2015.07.29 by YuChen*/
+#define ANTDECT_VERSION "2.1"
 
 #if (defined(CONFIG_ANT_DETECTION))
-/* #if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE)) */
-/* 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*/
-
-#define	MAX_ANTENNA_DETECTION_CNT	10
+/* @#if( DM_ODM_SUPPORT_TYPE & (ODM_WIN |ODM_CE)) */
+/* @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*/
 
+#define MAX_ANTENNA_DETECTION_CNT 10
 
 struct _ANT_DETECTED_INFO {
-	boolean			is_ant_detected;
-	u32			db_for_ant_a;
-	u32			db_for_ant_b;
-	u32			db_for_ant_o;
+	boolean is_ant_detected;
+	u32 db_for_ant_a;
+	u32 db_for_ant_b;
+	u32 db_for_ant_o;
 };
 
-
-enum dm_swas_e {
+enum dm_swas {
 	antenna_a = 1,
 	antenna_b = 2,
 	antenna_max = 3,
 };
 
+/* @1 [1. Single Tone method] =================================================== */
 
-
-/* 1 [1. Single Tone method] =================================================== */
-
-
-
-void
-odm_single_dual_antenna_default_setting(
-	void		*p_dm_void
-);
+void odm_single_dual_antenna_default_setting(
+	void *dm_void);
 
 boolean
 odm_single_dual_antenna_detection(
-	void		*p_dm_void,
-	u8			mode
-);
+	void *dm_void,
+	u8 mode);
 
-/* 1 [2. Scan AP RSSI method] ================================================== */
+/* @1 [2. Scan AP RSSI method] ================================================== */
 
-#define sw_ant_div_check_before_link	odm_sw_ant_div_check_before_link
+#define sw_ant_div_check_before_link odm_sw_ant_div_check_before_link
 
 boolean
 odm_sw_ant_div_check_before_link(
-	void		*p_dm_void
-);
-
-
-
+	void *dm_void);
 
-/* 1 [3. PSD method] ========================================================== */
+/* @1 [3. PSD method] ========================================================== */
 
+void odm_single_dual_antenna_detection_psd(
+	void *dm_void);
 
-void
-odm_single_dual_antenna_detection_psd(
-	void		*p_dm_void
-);
-
+void odm_sw_ant_detect_init(void *dm_void);
 #endif
-
-void
-odm_sw_ant_detect_init(
-	void		*p_dm_void
-);
-
-
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.c
index b11390b54a1a..92c14f00bc98 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,386 +9,473 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-/* ******************************************************
- * when antenna test utility is on or some testing need to disable antenna diversity
- * call this function to disable all ODM related mechanisms which will switch antenna.
- * ****************************************************** */
-void
-odm_stop_antenna_switch_dm(
-	void			*p_dm_void
-)
+/*******************************************************
+ * when antenna test utility is on or some testing need to disable antenna
+ * diversity call this function to disable all ODM related mechanisms which
+ * will switch antenna.
+ *****************************************************
+ */
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+void odm_stop_antenna_switch_dm(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	/* disable ODM antenna diversity */
-	p_dm->support_ability &= ~ODM_BB_ANT_DIV;
-	odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-	odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("STOP Antenna Diversity\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	/* @disable ODM antenna diversity */
+	dm->support_ability &= ~ODM_BB_ANT_DIV;
+	if (fat_tab->div_path_type == ANT_PATH_A)
+		odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+	else if (fat_tab->div_path_type == ANT_PATH_B)
+		odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_B);
+	else if (fat_tab->div_path_type == ANT_PATH_AB)
+		odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_AB);
+	odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "STOP Antenna Diversity\n");
 }
 
-void
-phydm_enable_antenna_diversity(
-	void			*p_dm_void
-)
+void phydm_enable_antenna_diversity(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	p_dm->support_ability |= ODM_BB_ANT_DIV;
-	p_dm->antdiv_select = 0;
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("AntDiv is enabled & Re-Init AntDiv\n"));
-	odm_antenna_diversity_init(p_dm);
+	dm->support_ability |= ODM_BB_ANT_DIV;
+	dm->antdiv_select = 0;
+	PHYDM_DBG(dm, DBG_ANT_DIV, "AntDiv is enabled & Re-Init AntDiv\n");
+	odm_antenna_diversity_init(dm);
 }
 
-void
-odm_set_ant_config(
-	void	*p_dm_void,
-	u8		ant_setting	/* 0=A, 1=B, 2=C, .... */
-)
+void odm_set_ant_config(void *dm_void, u8 ant_setting /* @0=A, 1=B, 2=C,...*/)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	if (p_dm->support_ic_type == ODM_RTL8723B) {
-		if (ant_setting == 0)		/* ant A*/
-			odm_set_bb_reg(p_dm, 0x948, MASKDWORD, 0x00000000);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (ant_setting == 0) /* @ant A*/
+			odm_set_bb_reg(dm, R_0x948, MASKDWORD, 0x00000000);
 		else if (ant_setting == 1)
-			odm_set_bb_reg(p_dm, 0x948, MASKDWORD, 0x00000280);
-	} else if (p_dm->support_ic_type == ODM_RTL8723D) {
-		if (ant_setting == 0)		/* ant A*/
-			odm_set_bb_reg(p_dm, 0x948, MASKLWORD, 0x0000);
+			odm_set_bb_reg(dm, R_0x948, MASKDWORD, 0x00000280);
+	} else if (dm->support_ic_type == ODM_RTL8723D) {
+		if (ant_setting == 0) /* @ant A*/
+			odm_set_bb_reg(dm, R_0x948, MASKLWORD, 0x0000);
 		else if (ant_setting == 1)
-			odm_set_bb_reg(p_dm, 0x948, MASKLWORD, 0x0280);
+			odm_set_bb_reg(dm, R_0x948, MASKLWORD, 0x0280);
 	}
 }
 
 /* ****************************************************** */
 
-
-void
-odm_sw_ant_div_rest_after_link(
-	void		*p_dm_void
-)
+void odm_sw_ant_div_rest_after_link(void *dm_void)
 {
 #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-	u32	i;
-
-	if (p_dm->ant_div_type == S0S1_SW_ANTDIV) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u32 i;
 
-		p_dm_swat_table->try_flag = SWAW_STEP_INIT;
-		p_dm_swat_table->rssi_trying = 0;
-		p_dm_swat_table->double_chk_flag = 0;
-		p_dm_fat_table->rx_idle_ant = MAIN_ANT;
+	if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+		swat_tab->try_flag = SWAW_STEP_INIT;
+		swat_tab->rssi_trying = 0;
+		swat_tab->double_chk_flag = 0;
+		fat_tab->rx_idle_ant = MAIN_ANT;
 
 		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
-			phydm_antdiv_reset_statistic(p_dm, i);
+			phydm_antdiv_reset_statistic(dm, i);
 	}
-	
-#endif	
+
+#endif
 }
 
-void
-odm_ant_div_on_off(
-	void		*p_dm_void,
-	u8		swch
-)
+void phydm_n_on_off(void *dm_void, u8 swch, u8 path)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-
-	if (p_dm_fat_table->ant_div_on_off != swch) {
-		if (p_dm->ant_div_type == S0S1_SW_ANTDIV)
-			return;
-
-		if (p_dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("(( Turn %s )) N-Series HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF"));
-			odm_set_bb_reg(p_dm, 0xc50, BIT(7), swch);
-			odm_set_bb_reg(p_dm, 0xa00, BIT(15), swch);
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+	if (path == ANT_PATH_A) {
+		odm_set_bb_reg(dm, R_0xc50, BIT(7), swch);
+	} else if (path == ANT_PATH_B) {
+		odm_set_bb_reg(dm, R_0xc58, BIT(7), swch);
+	} else if (path == ANT_PATH_AB) {
+		odm_set_bb_reg(dm, R_0xc50, BIT(7), swch);
+		odm_set_bb_reg(dm, R_0xc58, BIT(7), swch);
+	}
+	odm_set_bb_reg(dm, R_0xa00, BIT(15), swch);
 #if (RTL8723D_SUPPORT == 1)
-			/*Mingzhi 2017-05-08*/
-			if (p_dm->support_ic_type == ODM_RTL8723D) {
-				if (swch == ANTDIV_ON) {
-					odm_set_bb_reg(p_dm, 0xce0, BIT(1), 1);
-					odm_set_bb_reg(p_dm, 0x948, BIT(6), 1);          /*1:HW ctrl  0:SW ctrl*/
-					}
-				else{
-					odm_set_bb_reg(p_dm, 0xce0, BIT(1), 0);
-					odm_set_bb_reg(p_dm, 0x948, BIT(6), 0);          /*1:HW ctrl  0:SW ctrl*/
-				}
-			}			
+	/*@Mingzhi 2017-05-08*/
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (swch == ANTDIV_ON) {
+			odm_set_bb_reg(dm, R_0xce0, BIT(1), 1);
+			odm_set_bb_reg(dm, R_0x948, BIT(6), 1);
+			/*@1:HW ctrl  0:SW ctrl*/
+		} else {
+			odm_set_bb_reg(dm, R_0xce0, BIT(1), 0);
+			odm_set_bb_reg(dm, R_0x948, BIT(6), 0);
+			/*@1:HW ctrl  0:SW ctrl*/
+		}
+	}
 #endif
+}
 
-		} else if (p_dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("(( Turn %s )) AC-Series HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF"));
-			if (p_dm->support_ic_type & ODM_RTL8812) {
-				odm_set_bb_reg(p_dm, 0xc50, BIT(7), swch); /* OFDM AntDiv function block enable */
-				odm_set_bb_reg(p_dm, 0xa00, BIT(15), swch); /* CCK AntDiv function block enable */
-			} else {
-				odm_set_bb_reg(p_dm, 0x8D4, BIT(24), swch); /* OFDM AntDiv function block enable */
-
-				if ((p_dm->cut_version >= ODM_CUT_C) && (p_dm->support_ic_type == ODM_RTL8821) && (p_dm->ant_div_type != S0S1_SW_ANTDIV)) {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("(( Turn %s )) CCK HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF"));
-					odm_set_bb_reg(p_dm, 0x800, BIT(25), swch);
-					odm_set_bb_reg(p_dm, 0xA00, BIT(15), swch); /* CCK AntDiv function block enable */
-				} else if (p_dm->support_ic_type == ODM_RTL8821C) {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("(( Turn %s )) CCK HW-AntDiv block\n", (swch == ANTDIV_ON) ? "ON" : "OFF"));
-					odm_set_bb_reg(p_dm, 0x800, BIT(25), swch);
-					odm_set_bb_reg(p_dm, 0xA00, BIT(15), swch); /* CCK AntDiv function block enable */
-				}
-			}
+void phydm_ac_on_off(void *dm_void, u8 swch, u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+	if (dm->support_ic_type & ODM_RTL8812) {
+		odm_set_bb_reg(dm, R_0xc50, BIT(7), swch);
+		/* OFDM AntDiv function block enable */
+		odm_set_bb_reg(dm, R_0xa00, BIT(15), swch);
+		/* @CCK AntDiv function block enable */
+	} else if (dm->support_ic_type & ODM_RTL8822B) {
+		odm_set_bb_reg(dm, R_0x800, BIT(25), swch);
+		odm_set_bb_reg(dm, R_0xa00, BIT(15), swch);
+		if (path == ANT_PATH_A) {
+			odm_set_bb_reg(dm, R_0xc50, BIT(7), swch);
+		} else if (path == ANT_PATH_B) {
+			odm_set_bb_reg(dm, R_0xe50, BIT(7), swch);
+		} else if (path == ANT_PATH_AB) {
+			odm_set_bb_reg(dm, R_0xc50, BIT(7), swch);
+			odm_set_bb_reg(dm, R_0xe50, BIT(7), swch);
+		}
+	} else {
+		odm_set_bb_reg(dm, R_0x8d4, BIT(24), swch);
+		/* OFDM AntDiv function block enable */
+
+		if (dm->cut_version >= ODM_CUT_C &&
+		    dm->support_ic_type == ODM_RTL8821 &&
+		    dm->ant_div_type != S0S1_SW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "(Turn %s) CCK HW-AntDiv\n",
+				  (swch == ANTDIV_ON) ? "ON" : "OFF");
+			odm_set_bb_reg(dm, R_0x800, BIT(25), swch);
+			odm_set_bb_reg(dm, R_0xa00, BIT(15), swch);
+			/* @CCK AntDiv function block enable */
+		} else if (dm->support_ic_type == ODM_RTL8821C) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "(Turn %s) CCK HW-AntDiv\n",
+				  (swch == ANTDIV_ON) ? "ON" : "OFF");
+			odm_set_bb_reg(dm, R_0x800, BIT(25), swch);
+			odm_set_bb_reg(dm, R_0xa00, BIT(15), swch);
+			/* @CCK AntDiv function block enable */
 		}
 	}
-	p_dm_fat_table->ant_div_on_off = swch;
+}
+
+void odm_ant_div_on_off(void *dm_void, u8 swch, u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
+	if (fat_tab->ant_div_on_off != swch) {
+		if (dm->ant_div_type == S0S1_SW_ANTDIV)
+			return;
+
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "(( Turn %s )) N-Series HW-AntDiv block\n",
+				  (swch == ANTDIV_ON) ? "ON" : "OFF");
+			phydm_n_on_off(dm, swch, path);
+
+		} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "(( Turn %s )) AC-Series HW-AntDiv block\n",
+				  (swch == ANTDIV_ON) ? "ON" : "OFF");
+			phydm_ac_on_off(dm, swch, path);
+		}
+	}
+	fat_tab->ant_div_on_off = swch;
 }
 
-void
-odm_tx_by_tx_desc_or_reg(
-	void		*p_dm_void,
-	u8			swch
-)
+void odm_tx_by_tx_desc_or_reg(void *dm_void, u8 swch)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 	u8 enable;
 
-	if (p_dm_fat_table->b_fix_tx_ant == NO_FIX_TX_ANT)
+	if (fat_tab->b_fix_tx_ant == NO_FIX_TX_ANT)
 		enable = (swch == TX_BY_DESC) ? 1 : 0;
 	else
-		enable = 0;/*Force TX by Reg*/
+		enable = 0; /*@Force TX by Reg*/
 
-	if (p_dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
-		if (p_dm->support_ic_type & ODM_N_ANTDIV_SUPPORT)
-			odm_set_bb_reg(p_dm, 0x80c, BIT(21), enable);
-		else if (p_dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT)
-			odm_set_bb_reg(p_dm, 0x900, BIT(18), enable);
+	if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT)
+			odm_set_bb_reg(dm, R_0x80c, BIT(21), enable);
+		else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT)
+			odm_set_bb_reg(dm, R_0x900, BIT(18), enable);
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[AntDiv] TX_Ant_BY (( %s ))\n", (enable == TX_BY_DESC) ? "DESC" : "REG"));
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[AntDiv] TX_Ant_BY (( %s ))\n",
+			  (enable == TX_BY_DESC) ? "DESC" : "REG");
 	}
 }
 
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-void
-phydm_antdiv_reset_statistic(
-	void	*p_dm_void,
-	u32	macid
-)
+void phydm_antdiv_reset_statistic(void *dm_void, u32 macid)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-
-	p_dm_fat_table->main_ant_sum[macid] = 0;
-	p_dm_fat_table->aux_ant_sum[macid] = 0;
-	p_dm_fat_table->main_ant_cnt[macid] = 0;
-	p_dm_fat_table->aux_ant_cnt[macid] = 0;
-	p_dm_fat_table->main_ant_sum_cck[macid] = 0;
-	p_dm_fat_table->aux_ant_sum_cck[macid] = 0;
-	p_dm_fat_table->main_ant_cnt_cck[macid] = 0;
-	p_dm_fat_table->aux_ant_cnt_cck[macid] = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+	fat_tab->main_sum[macid] = 0;
+	fat_tab->aux_sum[macid] = 0;
+	fat_tab->main_cnt[macid] = 0;
+	fat_tab->aux_cnt[macid] = 0;
+	fat_tab->main_sum_cck[macid] = 0;
+	fat_tab->aux_sum_cck[macid] = 0;
+	fat_tab->main_cnt_cck[macid] = 0;
+	fat_tab->aux_cnt_cck[macid] = 0;
 }
 
-void
-phydm_fast_training_enable(
-	void		*p_dm_void,
-	u8			swch
-)
+void phydm_fast_training_enable(void *dm_void, u8 swch)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			enable;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 enable;
 
 	if (swch == FAT_ON)
 		enable = 1;
 	else
 		enable = 0;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Fast ant Training_en = ((%d))\n", enable));
-
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
-		odm_set_bb_reg(p_dm, 0xe08, BIT(16), enable);	/*enable fast training*/
-		/**/
-	} else if (p_dm->support_ic_type == ODM_RTL8192E) {
-		odm_set_bb_reg(p_dm, 0xB34, BIT(28), enable);	/*enable fast training (path-A)*/
-		/*odm_set_bb_reg(p_dm, 0xB34, BIT(29), enable);*/	/*enable fast training (path-B)*/
-	} else if (p_dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8822B)) {
-		odm_set_bb_reg(p_dm, 0x900, BIT(19), enable);	/*enable fast training */
-		/**/
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Fast ant Training_en = ((%d))\n", enable);
+
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		odm_set_bb_reg(dm, R_0xe08, BIT(16), enable);
+			/*@enable fast training*/
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, R_0xb34, BIT(28), enable);
+			/*@enable fast training (path-A)*/
+#if 0
+		odm_set_bb_reg(dm, R_0xb34, BIT(29), enable);
+			/*enable fast training (path-B)*/
+#endif
+	} else if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8822B)) {
+		odm_set_bb_reg(dm, R_0x900, BIT(19), enable);
+			/*@enable fast training */
 	}
 }
 
-void
-phydm_keep_rx_ack_ant_by_tx_ant_time(
-	void		*p_dm_void,
-	u32		time
-)
+void phydm_keep_rx_ack_ant_by_tx_ant_time(void *dm_void, u32 time)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	/* Timming issue: keep Rx ant after tx for ACK ( time x 3.2 mu sec)*/
-	if (p_dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+	if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT)
+		odm_set_bb_reg(dm, R_0xe20, 0xf00000, time);
+	else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT)
+		odm_set_bb_reg(dm, R_0x818, 0xf00000, time);
+}
+
+void phydm_update_rx_idle_ac(void *dm_void, u8 ant, u32 default_ant,
+			     u32 optional_ant, u32 default_tx_ant)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	u16 value16 = odm_read_2byte(dm, ODM_REG_TRMUX_11AC + 2);
+	/* @2014/01/14 MH/Luke.Lee Add direct write for register 0xc0a to  */
+	/* @prevnt incorrect 0xc08 bit0-15.We still not know why it is changed*/
+	value16 &= ~(BIT(11) | BIT(10) | BIT(9) | BIT(8) | BIT(7) | BIT(6) |
+		   BIT(5) | BIT(4) | BIT(3));
+	value16 |= ((u16)default_ant << 3);
+	value16 |= ((u16)optional_ant << 6);
+	value16 |= ((u16)default_tx_ant << 9);
+	odm_write_2byte(dm, ODM_REG_TRMUX_11AC + 2, value16);
+#if 0
+	odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, 0x380000, default_ant);
+		/* @Default RX */
+	odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, 0x1c00000, optional_ant);
+		/* Optional RX */
+	odm_set_bb_reg(dm, ODM_REG_TRMUX_11AC, 0xe000000, default_ant);
+		/* @Default TX */
+#endif
+}
+
+void phydm_update_rx_idle_n(void *dm_void, u8 ant, u32 default_ant,
+			    u32 optional_ant, u32 default_tx_ant)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 value32;
+
+	if (dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F)) {
+		odm_set_bb_reg(dm, R_0xb38, 0x38, default_ant);
+			/* @Default RX */
+		odm_set_bb_reg(dm, R_0xb38, 0x1c0, optional_ant);
+			/* Optional RX */
+		odm_set_bb_reg(dm, R_0x860, 0x7000, default_ant);
+			/* @Default TX */
+#if (RTL8723B_SUPPORT == 1)
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
+		value32 = odm_get_bb_reg(dm, R_0x948, 0xFFF);
+
+		if (value32 != 0x280)
+			odm_update_rx_idle_ant_8723b(dm, ant, default_ant,
+						     optional_ant);
+		else
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to 0x948 = 0x280\n");
+#endif
+
+#if (RTL8723D_SUPPORT == 1) /*@Mingzhi 2017-05-08*/
+	} else if (dm->support_ic_type == ODM_RTL8723D) {
+		phydm_set_tx_ant_pwr_8723d(dm, ant);
+		odm_update_rx_idle_ant_8723d(dm, ant, default_ant,
+					     optional_ant);
+#endif
 
-		odm_set_bb_reg(p_dm, 0xE20, BIT(23) | BIT(22) | BIT(21) | BIT(20), time);
-		/**/
-	} else if (p_dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+/*#if (RTL8721D_SUPPORT == 1)*/
+/*	} else if (dm->support_ic_type == ODM_RTL8721D) {*/
+/*		odm_update_rx_idle_ant_8721d(dm, ant, default_ant, */
+/*						   optional_ant);*/
+/*#endif*/
+	} else {
+/*@8188E & 8188F*/
+/*@		if (dm->support_ic_type == ODM_RTL8723D) {*/
+/*#if (RTL8723D_SUPPORT == 1)*/
+/*			phydm_set_tx_ant_pwr_8723d(dm, ant);*/
+/*#endif*/
+/*		}*/
+#if (RTL8188F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8188F)
+			phydm_update_rx_idle_antenna_8188F(dm, default_ant);
+#endif
 
-		odm_set_bb_reg(p_dm, 0x818, BIT(23) | BIT(22) | BIT(21) | BIT(20), time);
-		/**/
+		odm_set_bb_reg(dm, R_0x864, 0x38, default_ant);/*@Default RX*/
+		odm_set_bb_reg(dm, R_0x864, 0x1c0, optional_ant);
+			/*Optional RX*/
+		odm_set_bb_reg(dm, R_0x860, 0x7000, default_tx_ant);
+			/*@Default TX*/
 	}
 }
 
-void
-odm_update_rx_idle_ant(
-	void		*p_dm_void,
-	u8		ant
-)
+void odm_update_rx_idle_ant(void *dm_void, u8 ant)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	u32			default_ant, optional_ant, value32, default_tx_ant;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u32 default_ant, optional_ant, value32, default_tx_ant;
 
-	if (p_dm_fat_table->rx_idle_ant != ant) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] rx_idle_ant =%s\n", (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+	if (fat_tab->rx_idle_ant != ant) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ Update Rx-Idle-ant ] rx_idle_ant =%s\n",
+			  (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
 
-		if (!(p_dm->support_ic_type & ODM_RTL8723B))
-			p_dm_fat_table->rx_idle_ant = ant;
+		if (!(dm->support_ic_type & ODM_RTL8723B))
+			fat_tab->rx_idle_ant = ant;
 
 		if (ant == MAIN_ANT) {
-			default_ant   =  ANT1_2G;
-			optional_ant =  ANT2_2G;
+			default_ant = ANT1_2G;
+			optional_ant = ANT2_2G;
 		} else {
-			default_ant  =   ANT2_2G;
-			optional_ant =  ANT1_2G;
+			default_ant = ANT2_2G;
+			optional_ant = ANT1_2G;
 		}
 
-		if (p_dm_fat_table->b_fix_tx_ant != NO_FIX_TX_ANT)
-			default_tx_ant = (p_dm_fat_table->b_fix_tx_ant == FIX_TX_AT_MAIN) ? 0 : 1;
+		if (fat_tab->b_fix_tx_ant != NO_FIX_TX_ANT)
+			default_tx_ant = (fat_tab->b_fix_tx_ant ==
+					 FIX_TX_AT_MAIN) ? 0 : 1;
 		else
 			default_tx_ant = default_ant;
 
-		if (p_dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
-			if (p_dm->support_ic_type == ODM_RTL8192E) {
-				odm_set_bb_reg(p_dm, 0xB38, BIT(5) | BIT(4) | BIT(3), default_ant); /* Default RX */
-				odm_set_bb_reg(p_dm, 0xB38, BIT(8) | BIT(7) | BIT(6), optional_ant); /* Optional RX */
-				odm_set_bb_reg(p_dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant); /* Default TX */
-			}
-#if (RTL8723B_SUPPORT == 1)
-			else if (p_dm->support_ic_type == ODM_RTL8723B) {
-
-				value32 = odm_get_bb_reg(p_dm, 0x948, 0xFFF);
-
-				if (value32 != 0x280)
-					odm_update_rx_idle_ant_8723b(p_dm, ant, default_ant, optional_ant);
-				else
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to 0x948 = 0x280\n"));
-			}
-#endif
-
-#if (RTL8723D_SUPPORT == 1)         /*Mingzhi 2017-05-08*/
-			else if (p_dm->support_ic_type == ODM_RTL8723D) {
-					phydm_set_tx_ant_pwr_8723d(p_dm, ant);
-					odm_update_rx_idle_ant_8723d(p_dm, ant, default_ant, optional_ant);
-
-			}
-#endif
-
-			else { /*8188E & 8188F*/
-/*
-				if (p_dm->support_ic_type == ODM_RTL8723D) {
-#if (RTL8723D_SUPPORT == 1)
-					phydm_set_tx_ant_pwr_8723d(p_dm, ant);
-#endif
-				}
-*/
-#if (RTL8188F_SUPPORT == 1)
-				if (p_dm->support_ic_type == ODM_RTL8188F) {
-					phydm_update_rx_idle_antenna_8188F(p_dm, default_ant);
-					/**/
-				}
-#endif
-
-				odm_set_bb_reg(p_dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);		/*Default RX*/
-				odm_set_bb_reg(p_dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);	/*Optional RX*/
-				odm_set_bb_reg(p_dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_tx_ant);	/*Default TX*/
-			}
-		} else if (p_dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
-			u16	value16 = odm_read_2byte(p_dm, ODM_REG_TRMUX_11AC + 2);
-			/*  */
-			/* 2014/01/14 MH/Luke.Lee Add direct write for register 0xc0a to prevnt */
-			/* incorrect 0xc08 bit0-15 .We still not know why it is changed. */
-			/*  */
-			value16 &= ~(BIT(11) | BIT(10) | BIT(9) | BIT(8) | BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3));
-			value16 |= ((u16)default_ant << 3);
-			value16 |= ((u16)optional_ant << 6);
-			value16 |= ((u16)default_ant << 9);
-			odm_write_2byte(p_dm, ODM_REG_TRMUX_11AC + 2, value16);
-#if 0
-			odm_set_bb_reg(p_dm, ODM_REG_TRMUX_11AC, BIT(21) | BIT20 | BIT19, default_ant);	 /* Default RX */
-			odm_set_bb_reg(p_dm, ODM_REG_TRMUX_11AC, BIT(24) | BIT23 | BIT22, optional_ant); /* Optional RX */
-			odm_set_bb_reg(p_dm, ODM_REG_TRMUX_11AC, BIT(27) | BIT26 | BIT25, default_ant);	 /* Default TX */
-#endif
+		if (dm->support_ic_type & ODM_N_ANTDIV_SUPPORT) {
+			phydm_update_rx_idle_n(dm, ant, default_ant,
+					       optional_ant, default_tx_ant);
+		} else if (dm->support_ic_type & ODM_AC_ANTDIV_SUPPORT) {
+			phydm_update_rx_idle_ac(dm, ant, default_ant,
+						optional_ant, default_tx_ant);
 		}
+		/*PathA Resp Tx*/
+		if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B |
+		    ODM_RTL8814A))
+			odm_set_mac_reg(dm, R_0x6d8, 0x7, default_tx_ant);
+		else if (dm->support_ic_type == ODM_RTL8188E)
+			odm_set_mac_reg(dm, R_0x6d8, 0xc0, default_tx_ant);
+		else
+			odm_set_mac_reg(dm, R_0x6d8, 0x700, default_tx_ant);
+
+	} else { /* @fat_tab->rx_idle_ant == ant */
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ Stay in Ori-ant ]  rx_idle_ant =%s\n",
+			  (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+		fat_tab->rx_idle_ant = ant;
+	}
+}
 
-		if (p_dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814A)) {
-			odm_set_mac_reg(p_dm, 0x6D8, 0x7, default_tx_ant);		/*PathA Resp Tx*/
-			/**/
-		} else if (p_dm->support_ic_type == ODM_RTL8188E) {
-			odm_set_mac_reg(p_dm, 0x6D8, BIT(7) | BIT(6), default_tx_ant);		/*PathA Resp Tx*/
-			/**/
+void phydm_update_rx_idle_ant_pathb(void *dm_void, u8 ant)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u32 default_ant, optional_ant, value32, default_tx_ant;
+
+	if (fat_tab->rx_idle_ant2 != ant) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ Update Rx-Idle-ant2 ] rx_idle_ant2 =%s\n",
+			  (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+		if (ant == MAIN_ANT) {
+			default_ant = ANT1_2G;
+			optional_ant = ANT2_2G;
 		} else {
-			odm_set_mac_reg(p_dm, 0x6D8, BIT(10) | BIT(9) | BIT(8), default_tx_ant);	/*PathA Resp Tx*/
-			/**/
+			default_ant = ANT2_2G;
+			optional_ant = ANT1_2G;
 		}
 
-	} else { /* p_dm_fat_table->rx_idle_ant == ant */
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Stay in Ori-ant ]  rx_idle_ant =%s\n", (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
-		p_dm_fat_table->rx_idle_ant = ant;
+		if (fat_tab->b_fix_tx_ant != NO_FIX_TX_ANT)
+			default_tx_ant = (fat_tab->b_fix_tx_ant ==
+					  FIX_TX_AT_MAIN) ? 0 : 1;
+		else
+			default_tx_ant = default_ant;
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			u16 v16 = odm_read_2byte(dm, ODM_REG_ANT_11AC_B + 2);
+
+			v16 &= ~(0xff8);/*0xE08[11:3]*/
+			v16 |= ((u16)default_ant << 3);
+			v16 |= ((u16)optional_ant << 6);
+			v16 |= ((u16)default_tx_ant << 9);
+			odm_write_2byte(dm, ODM_REG_ANT_11AC_B + 2, v16);
+			odm_set_mac_reg(dm, R_0x6d8, 0x38, default_tx_ant);
+			/*PathB Resp Tx*/
+		}
+	} else {
+		/* fat_tab->rx_idle_ant2 == ant */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Stay Ori Ant] rx_idle_ant2 = %s\n",
+			  (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+		fat_tab->rx_idle_ant2 = ant;
 	}
 }
 
-void
-phydm_set_antdiv_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-)
+void phydm_set_antdiv_val(void *dm_void, u32 *val_buf,	u8 val_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (val_len != 1) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[Error][antdiv]Need val_len=1\n"));
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][antdiv]Need val_len=1\n");
 		return;
 	}
-	
-	odm_update_rx_idle_ant(p_dm, (u8)(*val_buf));
+
+	odm_update_rx_idle_ant(dm, (u8)(*val_buf));
 }
 
-void
-odm_update_tx_ant(
-	void		*p_dm_void,
-	u8		ant,
-	u32		mac_id
-)
+void odm_update_tx_ant(void *dm_void, u8 ant, u32 mac_id)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-	u8	tx_ant;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u8 tx_ant;
 
-	if (p_dm_fat_table->b_fix_tx_ant != NO_FIX_TX_ANT)
-		ant = (p_dm_fat_table->b_fix_tx_ant == FIX_TX_AT_MAIN) ? MAIN_ANT : AUX_ANT;
+	if (fat_tab->b_fix_tx_ant != NO_FIX_TX_ANT)
+		ant = (fat_tab->b_fix_tx_ant == FIX_TX_AT_MAIN) ?
+		       MAIN_ANT : AUX_ANT;
 
-	if (p_dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+	if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
 		tx_ant = ant;
 	else {
 		if (ant == MAIN_ANT)
@@ -396,595 +484,626 @@ odm_update_tx_ant(
 			tx_ant = ANT2_2G;
 	}
 
-	p_dm_fat_table->antsel_a[mac_id] = tx_ant & BIT(0);
-	p_dm_fat_table->antsel_b[mac_id] = (tx_ant & BIT(1)) >> 1;
-	p_dm_fat_table->antsel_c[mac_id] = (tx_ant & BIT(2)) >> 2;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Set TX-DESC value]: mac_id:(( %d )),  tx_ant = (( %s ))\n", mac_id, (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
-	/* PHYDM_DBG(p_dm,DBG_ANT_DIV,("antsel_tr_mux=(( 3'b%d%d%d ))\n",p_dm_fat_table->antsel_c[mac_id] , p_dm_fat_table->antsel_b[mac_id] , p_dm_fat_table->antsel_a[mac_id] )); */
+	fat_tab->antsel_a[mac_id] = tx_ant & BIT(0);
+	fat_tab->antsel_b[mac_id] = (tx_ant & BIT(1)) >> 1;
+	fat_tab->antsel_c[mac_id] = (tx_ant & BIT(2)) >> 2;
 
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[Set TX-DESC value]: mac_id:(( %d )),  tx_ant = (( %s ))\n",
+		  mac_id, (ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+#if 0
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "antsel_tr_mux=(( 3'b%d%d%d ))\n",
+		  fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id],
+		  fat_tab->antsel_a[mac_id]);
+#endif
 }
 
-#ifdef BEAMFORMING_SUPPORT
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-void
-odm_bdc_init(
-	void		*p_dm_void
-)
+void odm_bdc_init(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _BF_DIV_COEX_	*p_dm_bdc_table = &p_dm->dm_bdc_table;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\n[ BDC Initialization......]\n"));
-	p_dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
-	p_dm_bdc_table->bdc_mode = BDC_MODE_NULL;
-	p_dm_bdc_table->bdc_try_flag = 0;
-	p_dm_bdc_table->bd_ccoex_type_wbfer = 0;
-	p_dm->bdc_holdstate = 0xff;
-
-	if (p_dm->support_ic_type == ODM_RTL8192E) {
-		odm_set_bb_reg(p_dm, 0xd7c, 0x0FFFFFFF, 0x1081008);
-		odm_set_bb_reg(p_dm, 0xd80, 0x0FFFFFFF, 0);
-	} else if (p_dm->support_ic_type == ODM_RTL8812) {
-		odm_set_bb_reg(p_dm, 0x9b0, 0x0FFFFFFF, 0x1081008);     /* 0x9b0[30:0] = 01081008 */
-		odm_set_bb_reg(p_dm, 0x9b4, 0x0FFFFFFF, 0);                 /* 0x9b4[31:0] = 00000000 */
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_ *dm_bdc_table = &dm->dm_bdc_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n[ BDC Initialization......]\n");
+	dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+	dm_bdc_table->bdc_mode = BDC_MODE_NULL;
+	dm_bdc_table->bdc_try_flag = 0;
+	dm_bdc_table->bd_ccoex_type_wbfer = 0;
+	dm->bdc_holdstate = 0xff;
+
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, R_0xd7c, 0x0FFFFFFF, 0x1081008);
+		odm_set_bb_reg(dm, R_0xd80, 0x0FFFFFFF, 0);
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		odm_set_bb_reg(dm, R_0x9b0, 0x0FFFFFFF, 0x1081008);
+			/* @0x9b0[30:0] = 01081008 */
+		odm_set_bb_reg(dm, R_0x9b4, 0x0FFFFFFF, 0);
+			/* @0x9b4[31:0] = 00000000 */
 	}
-
 }
 
-
-void
-odm_CSI_on_off(
-	void		*p_dm_void,
-	u8			CSI_en
-)
+void odm_CSI_on_off(
+	void *dm_void,
+	u8 CSI_en)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	if (CSI_en == CSI_ON) {
-		if (p_dm->support_ic_type == ODM_RTL8192E)
-			odm_set_mac_reg(p_dm, 0xd84, BIT(11), 1);  /* 0xd84[11]=1 */
-		else if (p_dm->support_ic_type == ODM_RTL8812)
-			odm_set_mac_reg(p_dm, 0x9b0, BIT(31), 1);  /* 0x9b0[31]=1 */
+		if (dm->support_ic_type == ODM_RTL8192E)
+			odm_set_mac_reg(dm, R_0xd84, BIT(11), 1);
+				/* @0xd84[11]=1 */
+		else if (dm->support_ic_type == ODM_RTL8812)
+			odm_set_mac_reg(dm, R_0x9b0, BIT(31), 1);
+				/* @0x9b0[31]=1 */
 
 	} else if (CSI_en == CSI_OFF) {
-		if (p_dm->support_ic_type == ODM_RTL8192E)
-			odm_set_mac_reg(p_dm, 0xd84, BIT(11), 0);  /* 0xd84[11]=0 */
-		else if (p_dm->support_ic_type == ODM_RTL8812)
-			odm_set_mac_reg(p_dm, 0x9b0, BIT(31), 0);  /* 0x9b0[31]=0 */
+		if (dm->support_ic_type == ODM_RTL8192E)
+			odm_set_mac_reg(dm, R_0xd84, BIT(11), 0);
+				/* @0xd84[11]=0 */
+		else if (dm->support_ic_type == ODM_RTL8812)
+			odm_set_mac_reg(dm, R_0x9b0, BIT(31), 0);
+				/* @0x9b0[31]=0 */
 	}
 }
 
-void
-odm_bd_ccoex_type_with_bfer_client(
-	void		*p_dm_void,
-	u8			swch
-)
+void odm_bd_ccoex_type_with_bfer_client(
+	void *dm_void,
+	u8 swch)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _BF_DIV_COEX_	*p_dm_bdc_table = &p_dm->dm_bdc_table;
-	u8     bd_ccoex_type_wbfer;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_ *dm_bdc_table = &dm->dm_bdc_table;
+	u8 bd_ccoex_type_wbfer;
 
 	if (swch == DIVON_CSIOFF) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[BDCcoexType: 1] {DIV,CSI} ={1,0}\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[BDCcoexType: 1] {DIV,CSI} ={1,0}\n");
 		bd_ccoex_type_wbfer = 1;
 
-		if (bd_ccoex_type_wbfer != p_dm_bdc_table->bd_ccoex_type_wbfer) {
-			odm_ant_div_on_off(p_dm, ANTDIV_ON);
-			odm_CSI_on_off(p_dm, CSI_OFF);
-			p_dm_bdc_table->bd_ccoex_type_wbfer = 1;
+		if (bd_ccoex_type_wbfer != dm_bdc_table->bd_ccoex_type_wbfer) {
+			odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+			odm_CSI_on_off(dm, CSI_OFF);
+			dm_bdc_table->bd_ccoex_type_wbfer = 1;
 		}
 	} else if (swch == DIVOFF_CSION) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[BDCcoexType: 2] {DIV,CSI} ={0,1}\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[BDCcoexType: 2] {DIV,CSI} ={0,1}\n");
 		bd_ccoex_type_wbfer = 2;
 
-		if (bd_ccoex_type_wbfer != p_dm_bdc_table->bd_ccoex_type_wbfer) {
-			odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-			odm_CSI_on_off(p_dm, CSI_ON);
-			p_dm_bdc_table->bd_ccoex_type_wbfer = 2;
+		if (bd_ccoex_type_wbfer != dm_bdc_table->bd_ccoex_type_wbfer) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+			odm_CSI_on_off(dm, CSI_ON);
+			dm_bdc_table->bd_ccoex_type_wbfer = 2;
 		}
 	}
 }
 
-void
-odm_bf_ant_div_mode_arbitration(
-	void		*p_dm_void
-)
+void odm_bf_ant_div_mode_arbitration(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _BF_DIV_COEX_			*p_dm_bdc_table = &p_dm->dm_bdc_table;
-	u8			current_bdc_mode;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_ *dm_bdc_table = &dm->dm_bdc_table;
+	u8 current_bdc_mode;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n");
 
-	/* 2 mode 1 */
-	if ((p_dm_bdc_table->num_txbfee_client != 0) && (p_dm_bdc_table->num_txbfer_client == 0)) {
+	/* @2 mode 1 */
+	if (dm_bdc_table->num_txbfee_client != 0 &&
+	    dm_bdc_table->num_txbfer_client == 0) {
 		current_bdc_mode = BDC_MODE_1;
 
-		if (current_bdc_mode != p_dm_bdc_table->bdc_mode) {
-			p_dm_bdc_table->bdc_mode = BDC_MODE_1;
-			odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
-			p_dm_bdc_table->bdc_rx_idle_update_counter = 1;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Change to (( Mode1 ))\n"));
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_1;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			dm_bdc_table->bdc_rx_idle_update_counter = 1;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode1 ))\n");
 		}
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Antdiv + BF coextance mode] : (( Mode1 ))\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[Antdiv + BF coextance mode] : (( Mode1 ))\n");
 	}
-	/* 2 mode 2 */
-	else if ((p_dm_bdc_table->num_txbfee_client == 0) && (p_dm_bdc_table->num_txbfer_client != 0)) {
+	/* @2 mode 2 */
+	else if ((dm_bdc_table->num_txbfee_client == 0) &&
+		 (dm_bdc_table->num_txbfer_client != 0)) {
 		current_bdc_mode = BDC_MODE_2;
 
-		if (current_bdc_mode != p_dm_bdc_table->bdc_mode) {
-			p_dm_bdc_table->bdc_mode = BDC_MODE_2;
-			p_dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
-			p_dm_bdc_table->bdc_try_flag = 0;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Change to (( Mode2 ))\n"));
-
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_2;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			dm_bdc_table->bdc_try_flag = 0;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode2 ))\n");
 		}
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Antdiv + BF coextance mode] : (( Mode2 ))\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[Antdiv + BF coextance mode] : (( Mode2 ))\n");
 	}
-	/* 2 mode 3 */
-	else if ((p_dm_bdc_table->num_txbfee_client != 0) && (p_dm_bdc_table->num_txbfer_client != 0)) {
+	/* @2 mode 3 */
+	else if ((dm_bdc_table->num_txbfee_client != 0) &&
+		 (dm_bdc_table->num_txbfer_client != 0)) {
 		current_bdc_mode = BDC_MODE_3;
 
-		if (current_bdc_mode != p_dm_bdc_table->bdc_mode) {
-			p_dm_bdc_table->bdc_mode = BDC_MODE_3;
-			p_dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
-			p_dm_bdc_table->bdc_try_flag = 0;
-			p_dm_bdc_table->bdc_rx_idle_update_counter = 1;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Change to (( Mode3 ))\n"));
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_3;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->bdc_rx_idle_update_counter = 1;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode3 ))\n");
 		}
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Antdiv + BF coextance mode] : (( Mode3 ))\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[Antdiv + BF coextance mode] : (( Mode3 ))\n");
 	}
-	/* 2 mode 4 */
-	else if ((p_dm_bdc_table->num_txbfee_client == 0) && (p_dm_bdc_table->num_txbfer_client == 0)) {
+	/* @2 mode 4 */
+	else if ((dm_bdc_table->num_txbfee_client == 0) &&
+		 (dm_bdc_table->num_txbfer_client == 0)) {
 		current_bdc_mode = BDC_MODE_4;
 
-		if (current_bdc_mode != p_dm_bdc_table->bdc_mode) {
-			p_dm_bdc_table->bdc_mode = BDC_MODE_4;
-			odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Change to (( Mode4 ))\n"));
+		if (current_bdc_mode != dm_bdc_table->bdc_mode) {
+			dm_bdc_table->bdc_mode = BDC_MODE_4;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Change to (( Mode4 ))\n");
 		}
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Antdiv + BF coextance mode] : (( Mode4 ))\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[Antdiv + BF coextance mode] : (( Mode4 ))\n");
 	}
 #endif
-
 }
 
-void
-odm_div_train_state_setting(
-	void		*p_dm_void
-)
+void odm_div_train_state_setting(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _BF_DIV_COEX_	*p_dm_bdc_table = &p_dm->dm_bdc_table;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\n*****[S T A R T ]*****  [2-0. DIV_TRAIN_STATE]\n"));
-	p_dm_bdc_table->bdc_try_counter = 2;
-	p_dm_bdc_table->bdc_try_flag = 1;
-	p_dm_bdc_table->BDC_state = bdc_bfer_train_state;
-	odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_ *dm_bdc_table = &dm->dm_bdc_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "\n*****[S T A R T ]*****  [2-0. DIV_TRAIN_STATE]\n");
+	dm_bdc_table->bdc_try_counter = 2;
+	dm_bdc_table->bdc_try_flag = 1;
+	dm_bdc_table->BDC_state = bdc_bfer_train_state;
+	odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
 }
 
-void
-odm_bd_ccoex_bfee_rx_div_arbitration(
-	void		*p_dm_void
-)
+void odm_bd_ccoex_bfee_rx_div_arbitration(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _BF_DIV_COEX_    *p_dm_bdc_table = &p_dm->dm_bdc_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _BF_DIV_COEX_ *dm_bdc_table = &dm->dm_bdc_table;
 	boolean stop_bf_flag;
-	u8	bdc_active_mode;
-
+	u8 bdc_active_mode;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***{ num_BFee,  num_BFer, num_client}  = (( %d  ,  %d  ,  %d))\n", p_dm_bdc_table->num_txbfee_client, p_dm_bdc_table->num_txbfer_client, p_dm_bdc_table->num_client));
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***{ num_BF_tars,  num_DIV_tars }  = ((  %d  ,  %d ))\n", p_dm_bdc_table->num_bf_tar, p_dm_bdc_table->num_div_tar));
-
-	/* 2 [ MIB control ] */
-	if (p_dm->bdc_holdstate == 2) {
-		odm_bd_ccoex_type_with_bfer_client(p_dm, DIVOFF_CSION);
-		p_dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Force in [ BF STATE]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***{ num_BFee,  num_BFer, num_client}  = (( %d  ,  %d  ,  %d))\n",
+		  dm_bdc_table->num_txbfee_client,
+		  dm_bdc_table->num_txbfer_client, dm_bdc_table->num_client);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***{ num_BF_tars,  num_DIV_tars }  = ((  %d  ,  %d ))\n",
+		  dm_bdc_table->num_bf_tar, dm_bdc_table->num_div_tar);
+
+	/* @2 [ MIB control ] */
+	if (dm->bdc_holdstate == 2) {
+		odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+		dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ BF STATE]\n");
 		return;
-	} else if (p_dm->bdc_holdstate == 1) {
-		p_dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
-		odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Force in [ DIV STATE]\n"));
+	} else if (dm->bdc_holdstate == 1) {
+		dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+		odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ DIV STATE]\n");
 		return;
 	}
 
-	/* ------------------------------------------------------------ */
-
-
-
-	/* 2 mode 2 & 3 */
-	if (p_dm_bdc_table->bdc_mode == BDC_MODE_2 || p_dm_bdc_table->bdc_mode == BDC_MODE_3) {
-
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\n{ Try_flag,  Try_counter } = {  %d , %d  }\n", p_dm_bdc_table->bdc_try_flag, p_dm_bdc_table->bdc_try_counter));
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("BDCcoexType = (( %d ))\n\n", p_dm_bdc_table->bd_ccoex_type_wbfer));
-
-		/* All Client have Bfer-Cap------------------------------- */
-		if (p_dm_bdc_table->num_txbfer_client == p_dm_bdc_table->num_client) { /* BFer STA Only?: yes */
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("BFer STA only?  (( Yes ))\n"));
-			p_dm_bdc_table->bdc_try_flag = 0;
-			p_dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
-			odm_bd_ccoex_type_with_bfer_client(p_dm, DIVOFF_CSION);
+	/* @------------------------------------------------------------ */
+
+	/* @2 mode 2 & 3 */
+	if (dm_bdc_table->bdc_mode == BDC_MODE_2 ||
+	    dm_bdc_table->bdc_mode == BDC_MODE_3) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "\n{ Try_flag,  Try_counter } = {  %d , %d  }\n",
+			  dm_bdc_table->bdc_try_flag,
+			  dm_bdc_table->bdc_try_counter);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "BDCcoexType = (( %d ))\n\n",
+			  dm_bdc_table->bd_ccoex_type_wbfer);
+
+		/* @All Client have Bfer-Cap------------------------------- */
+		if (dm_bdc_table->num_txbfer_client == dm_bdc_table->num_client) {
+			/* @BFer STA Only?: yes */
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "BFer STA only?  (( Yes ))\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
 			return;
 		} else
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("BFer STA only?  (( No ))\n"));
-		/*  */
-		if (p_dm_bdc_table->is_all_bf_sta_idle == false && p_dm_bdc_table->is_all_div_sta_idle == true) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("All DIV-STA are idle, but BF-STA not\n"));
-			p_dm_bdc_table->bdc_try_flag = 0;
-			p_dm_bdc_table->BDC_state = bdc_bfer_train_state;
-			odm_bd_ccoex_type_with_bfer_client(p_dm, DIVOFF_CSION);
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "BFer STA only?  (( No ))\n");
+		if (dm_bdc_table->is_all_bf_sta_idle == false && dm_bdc_table->is_all_div_sta_idle == true) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "All DIV-STA are idle, but BF-STA not\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = bdc_bfer_train_state;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
 			return;
-		} else if (p_dm_bdc_table->is_all_bf_sta_idle == true && p_dm_bdc_table->is_all_div_sta_idle == false) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("All BF-STA are idle, but DIV-STA not\n"));
-			p_dm_bdc_table->bdc_try_flag = 0;
-			p_dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
-			odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
+		} else if (dm_bdc_table->is_all_bf_sta_idle == true && dm_bdc_table->is_all_div_sta_idle == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "All BF-STA are idle, but DIV-STA not\n");
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
 			return;
 		}
 
 		/* Select active mode-------------------------------------- */
-		if (p_dm_bdc_table->num_bf_tar == 0) { /* Selsect_1,  Selsect_2 */
-			if (p_dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Select active mode (( 1 ))\n"));
-				p_dm_bdc_table->bdc_active_mode = 1;
+		if (dm_bdc_table->num_bf_tar == 0) { /* Selsect_1,  Selsect_2 */
+			if (dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Select active mode (( 1 ))\n");
+				dm_bdc_table->bdc_active_mode = 1;
 			} else {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Select active mode  (( 2 ))\n"));
-				p_dm_bdc_table->bdc_active_mode = 2;
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Select active mode  (( 2 ))\n");
+				dm_bdc_table->bdc_active_mode = 2;
 			}
-			p_dm_bdc_table->bdc_try_flag = 0;
-			p_dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
-			odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
 			return;
 		} else { /* num_bf_tar > 0 */
-			if (p_dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Select active mode (( 3 ))\n"));
-				p_dm_bdc_table->bdc_active_mode = 3;
-				p_dm_bdc_table->bdc_try_flag = 0;
-				p_dm_bdc_table->BDC_state = bdc_bfer_train_state;
-				odm_bd_ccoex_type_with_bfer_client(p_dm, DIVOFF_CSION);
+			if (dm_bdc_table->num_div_tar == 0) { /* Selsect_3 */
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Select active mode (( 3 ))\n");
+				dm_bdc_table->bdc_active_mode = 3;
+				dm_bdc_table->bdc_try_flag = 0;
+				dm_bdc_table->BDC_state = bdc_bfer_train_state;
+				odm_bd_ccoex_type_with_bfer_client(dm,
+								   DIVOFF_CSION)
+								   ;
 				return;
 			} else { /* Selsect_4 */
 				bdc_active_mode = 4;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Select active mode (( 4 ))\n"));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Select active mode (( 4 ))\n");
 
-				if (bdc_active_mode != p_dm_bdc_table->bdc_active_mode) {
-					p_dm_bdc_table->bdc_active_mode = 4;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Change to active mode (( 4 ))  &  return!!!\n"));
+				if (bdc_active_mode != dm_bdc_table->bdc_active_mode) {
+					dm_bdc_table->bdc_active_mode = 4;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "Change to active mode (( 4 ))  &  return!!!\n");
 					return;
 				}
 			}
 		}
 
 #if 1
-		if (p_dm->bdc_holdstate == 0xff) {
-			p_dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
-			odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Force in [ DIV STATE]\n"));
+		if (dm->bdc_holdstate == 0xff) {
+			dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+			odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Force in [ DIV STATE]\n");
 			return;
 		}
 #endif
 
-		/* Does Client number changed ? ------------------------------- */
-		if (p_dm_bdc_table->num_client != p_dm_bdc_table->pre_num_client) {
-			p_dm_bdc_table->bdc_try_flag = 0;
-			p_dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[  The number of client has been changed !!!]   return to (( BDC_DIV_TRAIN_STATE ))\n"));
+		/* @Does Client number changed ? ------------------------------- */
+		if (dm_bdc_table->num_client != dm_bdc_table->pre_num_client) {
+			dm_bdc_table->bdc_try_flag = 0;
+			dm_bdc_table->BDC_state = BDC_DIV_TRAIN_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[  The number of client has been changed !!!]   return to (( BDC_DIV_TRAIN_STATE ))\n");
 		}
-		p_dm_bdc_table->pre_num_client = p_dm_bdc_table->num_client;
-
-		if (p_dm_bdc_table->bdc_try_flag == 0) {
-			/* 2 DIV_TRAIN_STATE (mode 2-0) */
-			if (p_dm_bdc_table->BDC_state == BDC_DIV_TRAIN_STATE)
-				odm_div_train_state_setting(p_dm);
-			/* 2 BFer_TRAIN_STATE (mode 2-1) */
-			else if (p_dm_bdc_table->BDC_state == bdc_bfer_train_state) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*****[2-1. BFer_TRAIN_STATE ]*****\n"));
-
-				/* if(p_dm_bdc_table->num_bf_tar==0) */
-				/* { */
-				/*	PHYDM_DBG(p_dm,DBG_ANT_DIV, ("BF_tars exist?  : (( No )),   [ bdc_bfer_train_state ] >> [BDC_DIV_TRAIN_STATE]\n")); */
-				/*	odm_div_train_state_setting( p_dm); */
-				/* } */
+		dm_bdc_table->pre_num_client = dm_bdc_table->num_client;
+
+		if (dm_bdc_table->bdc_try_flag == 0) {
+			/* @2 DIV_TRAIN_STATE (mode 2-0) */
+			if (dm_bdc_table->BDC_state == BDC_DIV_TRAIN_STATE)
+				odm_div_train_state_setting(dm);
+			/* @2 BFer_TRAIN_STATE (mode 2-1) */
+			else if (dm_bdc_table->BDC_state == bdc_bfer_train_state) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "*****[2-1. BFer_TRAIN_STATE ]*****\n");
+
+#if 0
+				/* @if(dm_bdc_table->num_bf_tar==0) */
+				/* @{ */
+				/*	PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( No )),   [ bdc_bfer_train_state ] >> [BDC_DIV_TRAIN_STATE]\n"); */
+				/*	odm_div_train_state_setting( dm); */
+				/* @} */
 				/* else */ /* num_bf_tar != 0 */
-				/* { */
-				p_dm_bdc_table->bdc_try_counter = 2;
-				p_dm_bdc_table->bdc_try_flag = 1;
-				p_dm_bdc_table->BDC_state = BDC_DECISION_STATE;
-				odm_bd_ccoex_type_with_bfer_client(p_dm, DIVOFF_CSION);
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("BF_tars exist?  : (( Yes )),   [ bdc_bfer_train_state ] >> [BDC_DECISION_STATE]\n"));
-				/* } */
+				/* @{ */
+#endif
+				dm_bdc_table->bdc_try_counter = 2;
+				dm_bdc_table->bdc_try_flag = 1;
+				dm_bdc_table->BDC_state = BDC_DECISION_STATE;
+				odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "BF_tars exist?  : (( Yes )),   [ bdc_bfer_train_state ] >> [BDC_DECISION_STATE]\n");
+				/* @} */
 			}
-			/* 2 DECISION_STATE (mode 2-2) */
-			else if (p_dm_bdc_table->BDC_state == BDC_DECISION_STATE) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*****[2-2. DECISION_STATE]*****\n"));
-				/* if(p_dm_bdc_table->num_bf_tar==0) */
-				/* { */
+			/* @2 DECISION_STATE (mode 2-2) */
+			else if (dm_bdc_table->BDC_state == BDC_DECISION_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "*****[2-2. DECISION_STATE]*****\n");
+#if 0
+				/* @if(dm_bdc_table->num_bf_tar==0) */
+				/* @{ */
 				/*	ODM_AntDiv_Printk(("BF_tars exist?  : (( No )),   [ DECISION_STATE ] >> [BDC_DIV_TRAIN_STATE]\n")); */
-				/*	odm_div_train_state_setting( p_dm); */
-				/* } */
+				/*	odm_div_train_state_setting( dm); */
+				/* @} */
 				/* else */ /* num_bf_tar != 0 */
-				/* { */
-				if (p_dm_bdc_table->BF_pass == false || p_dm_bdc_table->DIV_pass == false)
+				/* @{ */
+#endif
+				if (dm_bdc_table->BF_pass == false || dm_bdc_table->DIV_pass == false)
 					stop_bf_flag = true;
 				else
 					stop_bf_flag = false;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("BF_tars exist?  : (( Yes )),  {BF_pass, DIV_pass, stop_bf_flag }  = { %d, %d, %d }\n", p_dm_bdc_table->BF_pass, p_dm_bdc_table->DIV_pass, stop_bf_flag));
-
-				if (stop_bf_flag == true) { /* DIV_en */
-					p_dm_bdc_table->bdc_hold_counter = 10; /* 20 */
-					odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
-					p_dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ stop_bf_flag= ((true)),   BDC_DECISION_STATE ] >> [BDC_DIV_HOLD_STATE]\n"));
-				} else { /* BF_en */
-					p_dm_bdc_table->bdc_hold_counter = 10; /* 20 */
-					odm_bd_ccoex_type_with_bfer_client(p_dm, DIVOFF_CSION);
-					p_dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[stop_bf_flag= ((false)),   BDC_DECISION_STATE ] >> [BDC_BF_HOLD_STATE]\n"));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "BF_tars exist?  : (( Yes )),  {BF_pass, DIV_pass, stop_bf_flag }  = { %d, %d, %d }\n",
+					  dm_bdc_table->BF_pass,
+					  dm_bdc_table->DIV_pass, stop_bf_flag);
+
+				if (stop_bf_flag == true) { /* @DIV_en */
+					dm_bdc_table->bdc_hold_counter = 10; /* @20 */
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+					dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ stop_bf_flag= ((true)),   BDC_DECISION_STATE ] >> [BDC_DIV_HOLD_STATE]\n");
+				} else { /* @BF_en */
+					dm_bdc_table->bdc_hold_counter = 10; /* @20 */
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+					dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[stop_bf_flag= ((false)),   BDC_DECISION_STATE ] >> [BDC_BF_HOLD_STATE]\n");
 				}
-				/* } */
+				/* @} */
 			}
-			/* 2 BF-HOLD_STATE (mode 2-3) */
-			else if (p_dm_bdc_table->BDC_state == BDC_BF_HOLD_STATE) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*****[2-3. BF_HOLD_STATE ]*****\n"));
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("bdc_hold_counter = (( %d ))\n", p_dm_bdc_table->bdc_hold_counter));
-
-				if (p_dm_bdc_table->bdc_hold_counter == 1) {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n"));
-					odm_div_train_state_setting(p_dm);
+			/* @2 BF-HOLD_STATE (mode 2-3) */
+			else if (dm_bdc_table->BDC_state == BDC_BF_HOLD_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "*****[2-3. BF_HOLD_STATE ]*****\n");
+
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "bdc_hold_counter = (( %d ))\n",
+					  dm_bdc_table->bdc_hold_counter);
+
+				if (dm_bdc_table->bdc_hold_counter == 1) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n");
+					odm_div_train_state_setting(dm);
 				} else {
-					p_dm_bdc_table->bdc_hold_counter--;
+					dm_bdc_table->bdc_hold_counter--;
 
-					/* if(p_dm_bdc_table->num_bf_tar==0) */
-					/* { */
-					/*	PHYDM_DBG(p_dm,DBG_ANT_DIV, ("BF_tars exist?  : (( No )),   [ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n")); */
-					/*	odm_div_train_state_setting( p_dm); */
-					/* } */
+#if 0
+					/* @if(dm_bdc_table->num_bf_tar==0) */
+					/* @{ */
+					/*	PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( No )),   [ BDC_BF_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n"); */
+					/*	odm_div_train_state_setting( dm); */
+					/* @} */
 					/* else */ /* num_bf_tar != 0 */
-					/* { */
-					/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("BF_tars exist?  : (( Yes ))\n")); */
-					p_dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
-					odm_bd_ccoex_type_with_bfer_client(p_dm, DIVOFF_CSION);
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ BDC_BF_HOLD_STATE ] >> [BDC_BF_HOLD_STATE]\n"));
-					/* } */
+					/* @{ */
+					/* PHYDM_DBG(dm,DBG_ANT_DIV, "BF_tars exist?  : (( Yes ))\n"); */
+#endif
+					dm_bdc_table->BDC_state = BDC_BF_HOLD_STATE;
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVOFF_CSION);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_BF_HOLD_STATE ] >> [BDC_BF_HOLD_STATE]\n");
+					/* @} */
 				}
-
 			}
-			/* 2 DIV-HOLD_STATE (mode 2-4) */
-			else if (p_dm_bdc_table->BDC_state == BDC_DIV_HOLD_STATE) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*****[2-4. DIV_HOLD_STATE ]*****\n"));
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("bdc_hold_counter = (( %d ))\n", p_dm_bdc_table->bdc_hold_counter));
-
-				if (p_dm_bdc_table->bdc_hold_counter == 1) {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n"));
-					odm_div_train_state_setting(p_dm);
+			/* @2 DIV-HOLD_STATE (mode 2-4) */
+			else if (dm_bdc_table->BDC_state == BDC_DIV_HOLD_STATE) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "*****[2-4. DIV_HOLD_STATE ]*****\n");
+
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "bdc_hold_counter = (( %d ))\n",
+					  dm_bdc_table->bdc_hold_counter);
+
+				if (dm_bdc_table->bdc_hold_counter == 1) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_TRAIN_STATE]\n");
+					odm_div_train_state_setting(dm);
 				} else {
-					p_dm_bdc_table->bdc_hold_counter--;
-					p_dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
-					odm_bd_ccoex_type_with_bfer_client(p_dm, DIVON_CSIOFF);
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_HOLD_STATE]\n"));
+					dm_bdc_table->bdc_hold_counter--;
+					dm_bdc_table->BDC_state = BDC_DIV_HOLD_STATE;
+					odm_bd_ccoex_type_with_bfer_client(dm, DIVON_CSIOFF);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ BDC_DIV_HOLD_STATE ] >> [BDC_DIV_HOLD_STATE]\n");
 				}
-
 			}
 
-		} else if (p_dm_bdc_table->bdc_try_flag == 1) {
-			/* 2 Set Training counter */
-			if (p_dm_bdc_table->bdc_try_counter > 1) {
-				p_dm_bdc_table->bdc_try_counter--;
-				if (p_dm_bdc_table->bdc_try_counter == 1)
-					p_dm_bdc_table->bdc_try_flag = 0;
+		} else if (dm_bdc_table->bdc_try_flag == 1) {
+			/* @2 Set Training counter */
+			if (dm_bdc_table->bdc_try_counter > 1) {
+				dm_bdc_table->bdc_try_counter--;
+				if (dm_bdc_table->bdc_try_counter == 1)
+					dm_bdc_table->bdc_try_flag = 0;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Training !!\n"));
+				PHYDM_DBG(dm, DBG_ANT_DIV, "Training !!\n");
 				/* return ; */
 			}
-
 		}
-
 	}
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\n[end]\n"));
-
-#endif /* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
-
-
-
-
-
+	PHYDM_DBG(dm, DBG_ANT_DIV, "\n[end]\n");
 
+#endif /* @#if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
 }
 
 #endif
-#endif /* #ifdef BEAMFORMING_SUPPORT */
-
+#endif /* @#ifdef PHYDM_BEAMFORMING_SUPPORT*/
 
 #if (RTL8188E_SUPPORT == 1)
 
-
-void
-odm_rx_hw_ant_div_init_88e(
-	void		*p_dm_void
-)
+void odm_rx_hw_ant_div_init_88e(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	value32;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-
-#if 0
-	if (*(p_dm->p_mp_mode) == true) {
-		odm_set_bb_reg(p_dm, ODM_REG_IGI_A_11N, BIT(7), 0); /* disable HW AntDiv */
-		odm_set_bb_reg(p_dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);  /* 1:CG, 0:CS */
-		return;
-	}
-#endif
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 value32;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8188E AntDiv_Init =>  ant_div_type=[CGCS_RX_HW_ANTDIV]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
-	/* MAC setting */
-	value32 = odm_get_mac_reg(p_dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
-	odm_set_mac_reg(p_dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	/* @MAC setting */
+	value32 = odm_get_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
+	odm_set_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD,
+			value32 | (BIT(23) | BIT(25)));
+			/* Reg4C[25]=1, Reg4C[23]=1 for pin output */
 	/* Pin Settings */
-	odm_set_bb_reg(p_dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
-	odm_set_bb_reg(p_dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
-	odm_set_bb_reg(p_dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 1);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
-	odm_set_bb_reg(p_dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);	/* regb2c[31]=1'b1	 */ /* output at CG only */
+	odm_set_bb_reg(dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);
+			/* reg870[8]=1'b0, reg870[9]=1'b0 */
+			/* antsel antselb by HW */
+	odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);
+			/* reg864[10]=1'b0 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 1);
+			/* regb2c[22]=1'b0 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);
+			/* regb2c[31]=1'b1 */ /* output at CG only */
 	/* OFDM Settings */
-	odm_set_bb_reg(p_dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
-	/* CCK Settings */
-	odm_set_bb_reg(p_dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1); /* Fix CCK PHY status report issue */
-	odm_set_bb_reg(p_dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+	odm_set_bb_reg(dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
+	/* @CCK Settings */
+	odm_set_bb_reg(dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1);
+			/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1);
+			/* @CCK complete HW AntDiv within 64 samples */
 
-	odm_set_bb_reg(p_dm, ODM_REG_ANT_MAPPING1_11N, 0xFFFF, 0x0001);	/* antenna mapping table */
+	odm_set_bb_reg(dm, ODM_REG_ANT_MAPPING1_11N, 0xFFFF, 0x0001);
+			/* @antenna mapping table */
 
-	p_dm_fat_table->enable_ctrl_frame_antdiv = 1;
+	fat_tab->enable_ctrl_frame_antdiv = 1;
 }
 
-void
-odm_trx_hw_ant_div_init_88e(
-	void		*p_dm_void
-)
+void odm_trx_hw_ant_div_init_88e(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	value32;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 value32;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-#if 0
-	if (*(p_dm->p_mp_mode) == true) {
-		odm_set_bb_reg(p_dm, ODM_REG_IGI_A_11N, BIT(7), 0); /* disable HW AntDiv */
-		odm_set_bb_reg(p_dm, ODM_REG_RX_ANT_CTRL_11N, BIT(5) | BIT4 | BIT3, 0); /* Default RX   (0/1) */
-		return;
-	}
-#endif
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8188E AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV (SPDT)]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
-	/* MAC setting */
-	value32 = odm_get_mac_reg(p_dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
-	odm_set_mac_reg(p_dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	/* @MAC setting */
+	value32 = odm_get_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD);
+	odm_set_mac_reg(dm, ODM_REG_ANTSEL_PIN_11N, MASKDWORD,
+			value32 | (BIT(23) | BIT(25)));
+			/* Reg4C[25]=1, Reg4C[23]=1 for pin output */
 	/* Pin Settings */
-	odm_set_bb_reg(p_dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
-	odm_set_bb_reg(p_dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
-	odm_set_bb_reg(p_dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 0);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
-	odm_set_bb_reg(p_dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);	/* regb2c[31]=1'b1	 */ /* output at CG only */
+	odm_set_bb_reg(dm, ODM_REG_PIN_CTRL_11N, BIT(9) | BIT(8), 0);
+			/* reg870[8]=1'b0, reg870[9]=1'b0 */
+			/* antsel antselb by HW */
+	odm_set_bb_reg(dm, ODM_REG_RX_ANT_CTRL_11N, BIT(10), 0);
+			/* reg864[10]=1'b0 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(22), 0);
+			/* regb2c[22]=1'b0 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, ODM_REG_LNA_SWITCH_11N, BIT(31), 1);
+			/* regb2c[31]=1'b1 */ /* output at CG only */
 	/* OFDM Settings */
-	odm_set_bb_reg(p_dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
-	/* CCK Settings */
-	odm_set_bb_reg(p_dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1); /* Fix CCK PHY status report issue */
-	odm_set_bb_reg(p_dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
-
-	/* antenna mapping table */
-	if (!p_dm->is_mp_chip) { /* testchip */
-		odm_set_bb_reg(p_dm, ODM_REG_RX_DEFUALT_A_11N, BIT(10) | BIT(9) | BIT(8), 1);	/* Reg858[10:8]=3'b001 */
-		odm_set_bb_reg(p_dm, ODM_REG_RX_DEFUALT_A_11N, BIT(13) | BIT(12) | BIT(11), 2);	/* Reg858[13:11]=3'b010 */
-	} else /* MPchip */
-		odm_set_bb_reg(p_dm, ODM_REG_ANT_MAPPING1_11N, MASKDWORD, 0x0201);	/*Reg914=3'b010, Reg915=3'b001*/
-
-	p_dm_fat_table->enable_ctrl_frame_antdiv = 1;
+	odm_set_bb_reg(dm, ODM_REG_ANTDIV_PARA1_11N, MASKDWORD, 0x000000a0);
+	/* @CCK Settings */
+	odm_set_bb_reg(dm, ODM_REG_BB_PWR_SAV4_11N, BIT(7), 1);
+			/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, ODM_REG_CCK_ANTDIV_PARA2_11N, BIT(4), 1);
+			/* @CCK complete HW AntDiv within 64 samples */
+
+	/* @antenna mapping table */
+	if (!dm->is_mp_chip) { /* testchip */
+		odm_set_bb_reg(dm, ODM_REG_RX_DEFAULT_A_11N, 0x700, 1);
+				/* Reg858[10:8]=3'b001 */
+		odm_set_bb_reg(dm, ODM_REG_RX_DEFAULT_A_11N, 0x3800, 2);
+				/* Reg858[13:11]=3'b010 */
+	} else /* @MPchip */
+		odm_set_bb_reg(dm, ODM_REG_ANT_MAPPING1_11N, MASKDWORD, 0x0201);
+				/*Reg914=3'b010, Reg915=3'b001*/
+
+	fat_tab->enable_ctrl_frame_antdiv = 1;
 }
 
-
 #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-void
-odm_smart_hw_ant_div_init_88e(
-	void		*p_dm_void
-)
+void odm_smart_hw_ant_div_init_88e(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	value32, i;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 value32, i;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8188E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***8188E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n");
 
 #if 0
-	if (*(p_dm->p_mp_mode) == true) {
-		PHYDM_DBG(p_dm, ODM_COMP_INIT, ("p_dm->ant_div_type: %d\n", p_dm->ant_div_type));
+	if (*dm->mp_mode == true) {
+		PHYDM_DBG(dm, ODM_COMP_INIT, "dm->ant_div_type: %d\n",
+			  dm->ant_div_type);
 		return;
 	}
 #endif
 
-	p_dm_fat_table->train_idx = 0;
-	p_dm_fat_table->fat_state = FAT_PREPARE_STATE;
+	fat_tab->train_idx = 0;
+	fat_tab->fat_state = FAT_PREPARE_STATE;
 
-	p_dm->fat_comb_a = 5;
-	p_dm->antdiv_intvl = 0x64; /* 100ms */
+	dm->fat_comb_a = 5;
+	dm->antdiv_intvl = 0x64; /* @100ms */
 
 	for (i = 0; i < 6; i++)
-		p_dm_fat_table->bssid[i] = 0;
-	for (i = 0; i < (p_dm->fat_comb_a) ; i++) {
-		p_dm_fat_table->ant_sum_rssi[i] = 0;
-		p_dm_fat_table->ant_rssi_cnt[i] = 0;
-		p_dm_fat_table->ant_ave_rssi[i] = 0;
+		fat_tab->bssid[i] = 0;
+	for (i = 0; i < (dm->fat_comb_a); i++) {
+		fat_tab->ant_sum_rssi[i] = 0;
+		fat_tab->ant_rssi_cnt[i] = 0;
+		fat_tab->ant_ave_rssi[i] = 0;
 	}
 
-	/* MAC setting */
-	value32 = odm_get_mac_reg(p_dm, 0x4c, MASKDWORD);
-	odm_set_mac_reg(p_dm, 0x4c, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
-	value32 = odm_get_mac_reg(p_dm,  0x7B4, MASKDWORD);
-	odm_set_mac_reg(p_dm, 0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17))); /* Reg7B4[16]=1 enable antenna training, Reg7B4[17]=1 enable A2 match */
+	/* @MAC setting */
+	value32 = odm_get_mac_reg(dm, R_0x4c, MASKDWORD);
+	odm_set_mac_reg(dm, R_0x4c, MASKDWORD, value32 | (BIT(23) | BIT(25))); /* Reg4C[25]=1, Reg4C[23]=1 for pin output */
+	value32 = odm_get_mac_reg(dm, R_0x7b4, MASKDWORD);
+	odm_set_mac_reg(dm, R_0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17))); /* Reg7B4[16]=1 enable antenna training, Reg7B4[17]=1 enable A2 match */
 	/* value32 = platform_efio_read_4byte(adapter, 0x7B4); */
 	/* platform_efio_write_4byte(adapter, 0x7b4, value32|BIT(18));	 */ /* append MACID in reponse packet */
 
-	/* Match MAC ADDR */
-	odm_set_mac_reg(p_dm, 0x7b4, 0xFFFF, 0);
-	odm_set_mac_reg(p_dm, 0x7b0, MASKDWORD, 0);
-
-	odm_set_bb_reg(p_dm, 0x870, BIT(9) | BIT(8), 0);/* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
-	odm_set_bb_reg(p_dm, 0x864, BIT(10), 0);	/* reg864[10]=1'b0	 */ /* antsel2 by HW */
-	odm_set_bb_reg(p_dm, 0xb2c, BIT(22), 0);	/* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
-	odm_set_bb_reg(p_dm, 0xb2c, BIT(31), 0);	/* regb2c[31]=1'b1	 */ /* output at CS only */
-	odm_set_bb_reg(p_dm, 0xca4, MASKDWORD, 0x000000a0);
-
-	/* antenna mapping table */
-	if (p_dm->fat_comb_a == 2) {
-		if (!p_dm->is_mp_chip) { /* testchip */
-			odm_set_bb_reg(p_dm, 0x858, BIT(10) | BIT(9) | BIT(8), 1);	/* Reg858[10:8]=3'b001 */
-			odm_set_bb_reg(p_dm, 0x858, BIT(13) | BIT(12) | BIT(11), 2);	/* Reg858[13:11]=3'b010 */
-		} else { /* MPchip */
-			odm_set_bb_reg(p_dm, 0x914, MASKBYTE0, 1);
-			odm_set_bb_reg(p_dm, 0x914, MASKBYTE1, 2);
+	/* @Match MAC ADDR */
+	odm_set_mac_reg(dm, R_0x7b4, 0xFFFF, 0);
+	odm_set_mac_reg(dm, R_0x7b0, MASKDWORD, 0);
+
+	odm_set_bb_reg(dm, R_0x870, BIT(9) | BIT(8), 0); /* reg870[8]=1'b0, reg870[9]=1'b0		 */ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, R_0x864, BIT(10), 0); /* reg864[10]=1'b0	 */ /* antsel2 by HW */
+	odm_set_bb_reg(dm, R_0xb2c, BIT(22), 0); /* regb2c[22]=1'b0	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, R_0xb2c, BIT(31), 0); /* regb2c[31]=1'b1	 */ /* output at CS only */
+	odm_set_bb_reg(dm, R_0xca4, MASKDWORD, 0x000000a0);
+
+	/* @antenna mapping table */
+	if (dm->fat_comb_a == 2) {
+		if (!dm->is_mp_chip) { /* testchip */
+			odm_set_bb_reg(dm, R_0x858, BIT(10) | BIT(9) | BIT(8), 1); /* Reg858[10:8]=3'b001 */
+			odm_set_bb_reg(dm, R_0x858, BIT(13) | BIT(12) | BIT(11), 2); /* Reg858[13:11]=3'b010 */
+		} else { /* @MPchip */
+			odm_set_bb_reg(dm, R_0x914, MASKBYTE0, 1);
+			odm_set_bb_reg(dm, R_0x914, MASKBYTE1, 2);
 		}
 	} else {
-		if (!p_dm->is_mp_chip) { /* testchip */
-			odm_set_bb_reg(p_dm, 0x858, BIT(10) | BIT(9) | BIT(8), 0);	/* Reg858[10:8]=3'b000 */
-			odm_set_bb_reg(p_dm, 0x858, BIT(13) | BIT(12) | BIT(11), 1);	/* Reg858[13:11]=3'b001 */
-			odm_set_bb_reg(p_dm, 0x878, BIT(16), 0);
-			odm_set_bb_reg(p_dm, 0x858, BIT(15) | BIT(14), 2);	/* (Reg878[0],Reg858[14:15])=3'b010 */
-			odm_set_bb_reg(p_dm, 0x878, BIT(19) | BIT(18) | BIT(17), 3); /* Reg878[3:1]=3b'011 */
-			odm_set_bb_reg(p_dm, 0x878, BIT(22) | BIT(21) | BIT(20), 4); /* Reg878[6:4]=3b'100 */
-			odm_set_bb_reg(p_dm, 0x878, BIT(25) | BIT(24) | BIT(23), 5); /* Reg878[9:7]=3b'101 */
-			odm_set_bb_reg(p_dm, 0x878, BIT(28) | BIT(27) | BIT(26), 6); /* Reg878[12:10]=3b'110 */
-			odm_set_bb_reg(p_dm, 0x878, BIT(31) | BIT(30) | BIT(29), 7); /* Reg878[15:13]=3b'111 */
-		} else { /* MPchip */
-			odm_set_bb_reg(p_dm, 0x914, MASKBYTE0, 4);     /* 0: 3b'000 */
-			odm_set_bb_reg(p_dm, 0x914, MASKBYTE1, 2);     /* 1: 3b'001 */
-			odm_set_bb_reg(p_dm, 0x914, MASKBYTE2, 0);     /* 2: 3b'010 */
-			odm_set_bb_reg(p_dm, 0x914, MASKBYTE3, 1);     /* 3: 3b'011 */
-			odm_set_bb_reg(p_dm, 0x918, MASKBYTE0, 3);     /* 4: 3b'100 */
-			odm_set_bb_reg(p_dm, 0x918, MASKBYTE1, 5);     /* 5: 3b'101 */
-			odm_set_bb_reg(p_dm, 0x918, MASKBYTE2, 6);     /* 6: 3b'110 */
-			odm_set_bb_reg(p_dm, 0x918, MASKBYTE3, 255); /* 7: 3b'111 */
+		if (!dm->is_mp_chip) { /* testchip */
+			odm_set_bb_reg(dm, R_0x858, BIT(10) | BIT(9) | BIT(8), 0); /* Reg858[10:8]=3'b000 */
+			odm_set_bb_reg(dm, R_0x858, BIT(13) | BIT(12) | BIT(11), 1); /* Reg858[13:11]=3'b001 */
+			odm_set_bb_reg(dm, R_0x878, BIT(16), 0);
+			odm_set_bb_reg(dm, R_0x858, BIT(15) | BIT(14), 2); /* @(Reg878[0],Reg858[14:15])=3'b010 */
+			odm_set_bb_reg(dm, R_0x878, BIT(19) | BIT(18) | BIT(17), 3); /* Reg878[3:1]=3b'011 */
+			odm_set_bb_reg(dm, R_0x878, BIT(22) | BIT(21) | BIT(20), 4); /* Reg878[6:4]=3b'100 */
+			odm_set_bb_reg(dm, R_0x878, BIT(25) | BIT(24) | BIT(23), 5); /* Reg878[9:7]=3b'101 */
+			odm_set_bb_reg(dm, R_0x878, BIT(28) | BIT(27) | BIT(26), 6); /* Reg878[12:10]=3b'110 */
+			odm_set_bb_reg(dm, R_0x878, BIT(31) | BIT(30) | BIT(29), 7); /* Reg878[15:13]=3b'111 */
+		} else { /* @MPchip */
+			odm_set_bb_reg(dm, R_0x914, MASKBYTE0, 4); /* @0: 3b'000 */
+			odm_set_bb_reg(dm, R_0x914, MASKBYTE1, 2); /* @1: 3b'001 */
+			odm_set_bb_reg(dm, R_0x914, MASKBYTE2, 0); /* @2: 3b'010 */
+			odm_set_bb_reg(dm, R_0x914, MASKBYTE3, 1); /* @3: 3b'011 */
+			odm_set_bb_reg(dm, R_0x918, MASKBYTE0, 3); /* @4: 3b'100 */
+			odm_set_bb_reg(dm, R_0x918, MASKBYTE1, 5); /* @5: 3b'101 */
+			odm_set_bb_reg(dm, R_0x918, MASKBYTE2, 6); /* @6: 3b'110 */
+			odm_set_bb_reg(dm, R_0x918, MASKBYTE3, 255); /* @7: 3b'111 */
 		}
 	}
 
-	/* Default ant setting when no fast training */
-	odm_set_bb_reg(p_dm, 0x864, BIT(5) | BIT(4) | BIT(3), 0);	/* Default RX */
-	odm_set_bb_reg(p_dm, 0x864, BIT(8) | BIT(7) | BIT(6), 1);	/* Optional RX */
-	odm_set_bb_reg(p_dm, 0x860, BIT(14) | BIT(13) | BIT(12), 0); /* Default TX */
+	/* @Default ant setting when no fast training */
+	odm_set_bb_reg(dm, R_0x864, BIT(5) | BIT(4) | BIT(3), 0); /* @Default RX */
+	odm_set_bb_reg(dm, R_0x864, BIT(8) | BIT(7) | BIT(6), 1); /* Optional RX */
+	odm_set_bb_reg(dm, R_0x860, BIT(14) | BIT(13) | BIT(12), 0); /* @Default TX */
 
-	/* Enter Traing state */
-	odm_set_bb_reg(p_dm, 0x864, BIT(2) | BIT(1) | BIT(0), (p_dm->fat_comb_a - 1));	/* reg864[2:0]=3'd6	 */ /* ant combination=reg864[2:0]+1 */
+	/* @Enter Traing state */
+	odm_set_bb_reg(dm, R_0x864, BIT(2) | BIT(1) | BIT(0), (dm->fat_comb_a - 1)); /* reg864[2:0]=3'd6	 */ /* ant combination=reg864[2:0]+1 */
 
+#if 0
 	/* SW Control */
 	/* phy_set_bb_reg(adapter, 0x864, BIT10, 1); */
 	/* phy_set_bb_reg(adapter, 0x870, BIT9, 1); */
@@ -992,907 +1111,1320 @@ odm_smart_hw_ant_div_init_88e(
 	/* phy_set_bb_reg(adapter, 0x864, BIT11, 1); */
 	/* phy_set_bb_reg(adapter, 0x860, BIT9, 0); */
 	/* phy_set_bb_reg(adapter, 0x860, BIT8, 0); */
+#endif
 }
 #endif
 
-#endif /* #if (RTL8188E_SUPPORT == 1) */
-
+#endif /* @#if (RTL8188E_SUPPORT == 1) */
 
 #if (RTL8192E_SUPPORT == 1)
-void
-odm_rx_hw_ant_div_init_92e(
-	void		*p_dm_void
-)
+void odm_rx_hw_ant_div_init_92e(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
 #if 0
-	if (*(p_dm->p_mp_mode) == true) {
-		odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-		odm_set_bb_reg(p_dm, 0xc50, BIT(8), 0); /* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
-		odm_set_bb_reg(p_dm, 0xc50, BIT(9), 1);  /* 1:CG, 0:CS */
+	if (*dm->mp_mode == true) {
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		odm_set_bb_reg(dm, R_0xc50, BIT(8), 0);
+		/* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
+		odm_set_bb_reg(dm, R_0xc50, BIT(9), 1);
+		/* @1:CG, 0:CS */
 		return;
 	}
 #endif
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8192E AntDiv_Init =>  ant_div_type=[CGCS_RX_HW_ANTDIV]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
 	/* Pin Settings */
-	odm_set_bb_reg(p_dm, 0x870, BIT(8), 0);/* reg870[8]=1'b0,     */ /* "antsel" is controled by HWs */
-	odm_set_bb_reg(p_dm, 0xc50, BIT(8), 1); /* regc50[8]=1'b1   */ /* " CS/CG switching" is controled by HWs */
+	odm_set_bb_reg(dm, R_0x870, BIT(8), 0);
+		/* reg870[8]=1'b0,   antsel is controled by HWs */
+	odm_set_bb_reg(dm, R_0xc50, BIT(8), 1);
+		/* regc50[8]=1'b1    CS/CG switching is controled by HWs*/
 
-	/* Mapping table */
-	odm_set_bb_reg(p_dm, 0x914, 0xFFFF, 0x0100); /* antenna mapping table */
+	/* @Mapping table */
+	odm_set_bb_reg(dm, R_0x914, 0xFFFF, 0x0100);
+		/* @antenna mapping table */
 
 	/* OFDM Settings */
-	odm_set_bb_reg(p_dm, 0xca4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0xca4, 0x7FF000, 0x0); /* bias */
-
-	/* CCK Settings */
-	odm_set_bb_reg(p_dm, 0xa04, 0xF000000, 0); /* Select which path to receive for CCK_1 & CCK_2 */
-	odm_set_bb_reg(p_dm, 0xb34, BIT(30), 0); /* (92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
-	odm_set_bb_reg(p_dm, 0xa74, BIT(7), 1); /* Fix CCK PHY status report issue */
-	odm_set_bb_reg(p_dm, 0xa0c, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x0); /* @bias */
+
+	/* @CCK Settings */
+	odm_set_bb_reg(dm, R_0xa04, 0xF000000, 0);
+		/* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, R_0xb34, BIT(30), 0);
+		/* @(92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+		/* @CCK complete HW AntDiv within 64 samples */
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-	phydm_evm_sw_antdiv_init(p_dm);
+	phydm_evm_sw_antdiv_init(dm);
 #endif
-
 }
 
-void
-odm_trx_hw_ant_div_init_92e(
-	void		*p_dm_void
-)
+void odm_trx_hw_ant_div_init_92e(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 #if 0
-	if (*(p_dm->p_mp_mode) == true) {
-		odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-		odm_set_bb_reg(p_dm, 0xc50, BIT(8), 0); /* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
-		odm_set_bb_reg(p_dm, 0xc50, BIT(9), 1);  /* 1:CG, 0:CS */
+	if (*dm->mp_mode == true) {
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		odm_set_bb_reg(dm, R_0xc50, BIT(8), 0); /* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
+		odm_set_bb_reg(dm, R_0xc50, BIT(9), 1);  /* @1:CG, 0:CS */
 		return;
 	}
 #endif
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8192E AntDiv_Init =>  ant_div_type=[ Only for DIR605, CG_TRX_HW_ANTDIV]\n"));
-
-	/* 3 --RFE pin setting--------- */
-	/* [MAC] */
-	odm_set_mac_reg(p_dm, 0x38, BIT(11), 1);            /* DBG PAD Driving control (GPIO 8) */
-	odm_set_mac_reg(p_dm, 0x4c, BIT(23), 0);            /* path-A, RFE_CTRL_3 */
-	odm_set_mac_reg(p_dm, 0x4c, BIT(29), 1);            /* path-A, RFE_CTRL_8 */
-	/* [BB] */
-	odm_set_bb_reg(p_dm, 0x944, BIT(3), 1);              /* RFE_buffer */
-	odm_set_bb_reg(p_dm, 0x944, BIT(8), 1);
-	odm_set_bb_reg(p_dm, 0x940, BIT(7) | BIT(6), 0x0); /* r_rfe_path_sel_   (RFE_CTRL_3) */
-	odm_set_bb_reg(p_dm, 0x940, BIT(17) | BIT(16), 0x0); /* r_rfe_path_sel_   (RFE_CTRL_8) */
-	odm_set_bb_reg(p_dm, 0x944, BIT(31), 0);     /* RFE_buffer */
-	odm_set_bb_reg(p_dm, 0x92C, BIT(3), 0);     /* rfe_inv  (RFE_CTRL_3) */
-	odm_set_bb_reg(p_dm, 0x92C, BIT(8), 1);     /* rfe_inv  (RFE_CTRL_8) */
-	odm_set_bb_reg(p_dm, 0x930, 0xF000, 0x8);           /* path-A, RFE_CTRL_3 */
-	odm_set_bb_reg(p_dm, 0x934, 0xF, 0x8);           /* path-A, RFE_CTRL_8 */
-	/* 3 ------------------------- */
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
+
+	/* @3 --RFE pin setting--------- */
+	/* @[MAC] */
+	odm_set_mac_reg(dm, R_0x38, BIT(11), 1);
+		/* @DBG PAD Driving control (GPIO 8) */
+	odm_set_mac_reg(dm, R_0x4c, BIT(23), 0); /* path-A, RFE_CTRL_3 */
+	odm_set_mac_reg(dm, R_0x4c, BIT(29), 1); /* path-A, RFE_CTRL_8 */
+	/* @[BB] */
+	odm_set_bb_reg(dm, R_0x944, BIT(3), 1); /* RFE_buffer */
+	odm_set_bb_reg(dm, R_0x944, BIT(8), 1);
+	odm_set_bb_reg(dm, R_0x940, BIT(7) | BIT(6), 0x0);
+		/* r_rfe_path_sel_   (RFE_CTRL_3) */
+	odm_set_bb_reg(dm, R_0x940, BIT(17) | BIT(16), 0x0);
+		/* r_rfe_path_sel_   (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, R_0x944, BIT(31), 0); /* RFE_buffer */
+	odm_set_bb_reg(dm, R_0x92c, BIT(3), 0); /* rfe_inv  (RFE_CTRL_3) */
+	odm_set_bb_reg(dm, R_0x92c, BIT(8), 1); /* rfe_inv  (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, R_0x930, 0xF000, 0x8); /* path-A, RFE_CTRL_3 */
+	odm_set_bb_reg(dm, R_0x934, 0xF, 0x8); /* path-A, RFE_CTRL_8 */
+	/* @3 ------------------------- */
 
 	/* Pin Settings */
-	odm_set_bb_reg(p_dm, 0xC50, BIT(8), 0);	/* path-A  	 */ /* disable CS/CG switch */
+	odm_set_bb_reg(dm, R_0xc50, BIT(8), 0);
+		/* path-A  */ /* disable CS/CG switch */
 
 #if 0
-	/* Let it follows PHY_REG for bit9 setting */
-	if (p_dm->priv->pshare->rf_ft_var.use_ext_pa || p_dm->priv->pshare->rf_ft_var.use_ext_lna)
-		odm_set_bb_reg(p_dm, 0xC50, BIT(9), 1);	/* path-A 	output at CS */
+	/* @Let it follows PHY_REG for bit9 setting */
+	if (dm->priv->pshare->rf_ft_var.use_ext_pa ||
+	    dm->priv->pshare->rf_ft_var.use_ext_lna)
+		odm_set_bb_reg(dm, R_0xc50, BIT(9), 1);/* path-A output at CS */
 	else
-		odm_set_bb_reg(p_dm, 0xC50, BIT(9), 0);	/* path-A 	output at CG ->normal power */
+		odm_set_bb_reg(dm, R_0xc50, BIT(9), 0);
+			/* path-A output at CG ->normal power */
 #endif
 
-	odm_set_bb_reg(p_dm, 0x870, BIT(9) | BIT(8), 0);	/* path-A*/	/* antsel antselb by HW */
-	odm_set_bb_reg(p_dm, 0xB38, BIT(10), 0);	/* path-A	*/	/* antsel2 by HW */
+	odm_set_bb_reg(dm, R_0x870, BIT(9) | BIT(8), 0);
+		/* path-A*/ /* antsel antselb by HW */
+	odm_set_bb_reg(dm, R_0xb38, BIT(10), 0);/* path-A*/ /* antsel2 by HW */
 
-	/* Mapping table */
-	odm_set_bb_reg(p_dm, 0x914, 0xFFFF, 0x0100); /* antenna mapping table */
+	/* @Mapping table */
+	odm_set_bb_reg(dm, R_0x914, 0xFFFF, 0x0100);
+		/* @antenna mapping table */
 
 	/* OFDM Settings */
-	odm_set_bb_reg(p_dm, 0xca4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0xca4, 0x7FF000, 0x0); /* bias */
-
-	/* CCK Settings */
-	odm_set_bb_reg(p_dm, 0xa04, 0xF000000, 0); /* Select which path to receive for CCK_1 & CCK_2 */
-	odm_set_bb_reg(p_dm, 0xb34, BIT(30), 0); /* (92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
-	odm_set_bb_reg(p_dm, 0xa74, BIT(7), 1); /* Fix CCK PHY status report issue */
-	odm_set_bb_reg(p_dm, 0xa0c, BIT(4), 1); /* CCK complete HW AntDiv within 64 samples */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x0); /* @bias */
+
+	/* @CCK Settings */
+	odm_set_bb_reg(dm, R_0xa04, 0xF000000, 0);
+		/* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, R_0xb34, BIT(30), 0);
+		/* @(92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+		/* @CCK complete HW AntDiv within 64 samples */
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-	phydm_evm_sw_antdiv_init(p_dm);
+	phydm_evm_sw_antdiv_init(dm);
 #endif
 }
 
 #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-void
-odm_smart_hw_ant_div_init_92e(
-	void		*p_dm_void
-)
+void odm_smart_hw_ant_div_init_92e(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8192E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***8192E AntDiv_Init =>  ant_div_type=[CG_TRX_SMART_ANTDIV]\n");
 }
 #endif
 
-#endif /* #if (RTL8192E_SUPPORT == 1) */
+#endif /* @#if (RTL8192E_SUPPORT == 1) */
 
-#if (RTL8723D_SUPPORT == 1)
-void
-odm_trx_hw_ant_div_init_8723d(
-	void		*p_dm_void
-)
+#if (RTL8192F_SUPPORT == 1)
+void odm_rx_hw_ant_div_init_92f(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[8723D] AntDiv_Init =>  ant_div_type=[S0S1_HW_TRX_AntDiv]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
-	/*BT Coexistence*/
-	/*keep antsel_map when GNT_BT = 1*/
-	odm_set_bb_reg(p_dm, 0x864, BIT(12), 1);
-	/* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
-	odm_set_bb_reg(p_dm, 0x874, BIT(23), 0);
-	/* Disable hw antsw & fast_train.antsw when BT TX/RX */
-	odm_set_bb_reg(p_dm, 0xE64, 0xFFFF0000, 0x000c);
+	/* Pin Settings */
+	odm_set_bb_reg(dm, R_0x870, BIT(8), 0);
+		/* reg870[8]=1'b0, "antsel" is controlled by HWs */
+	odm_set_bb_reg(dm, R_0xc50, BIT(8), 1);
+		/* regc50[8]=1'b1, " CS/CG switching" is controlled by HWs */
 
+	/* @Mapping table */
+	odm_set_bb_reg(dm, R_0x914, 0xFFFF, 0x0100);
+		/* @antenna mapping table */
 
-	odm_set_bb_reg(p_dm, 0x870, BIT(9) | BIT(8), 0);
-	/*PTA setting: WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL)*/
-	/*odm_set_bb_reg(p_dm, 0x948, BIT6, 0);*/
-	/*odm_set_bb_reg(p_dm, 0x948, BIT8, 0);*/
-	/*GNT_WL tx*/
-	odm_set_bb_reg(p_dm, 0x950, BIT(29), 0);
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x0); /* @bias */
+
+	/* @CCK Settings */
+	odm_set_bb_reg(dm, R_0xa04, 0xF000000, 0);
+		/* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, R_0xb34, BIT(30), 0);
+		/* @(92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+		/* @CCK complete HW AntDiv within 64 samples */
 
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+}
 
-	/*Mapping Table*/
-	odm_set_bb_reg(p_dm, 0x914, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0x914, MASKBYTE1, 3);
-	/* odm_set_bb_reg(p_dm, 0x864, BIT5|BIT4|BIT3, 0); */
-	/* odm_set_bb_reg(p_dm, 0x864, BIT8|BIT7|BIT6, 1); */
+void odm_trx_hw_ant_div_init_92f(void *dm_void)
 
-	/* Set WLBB_SEL_RF_ON 1 if RXFIR_PWDB > 0xCcc[3:0] */
-	odm_set_bb_reg(p_dm, 0xCcc, BIT(12), 0);
-	/* Low-to-High threshold for WLBB_SEL_RF_ON when OFDM enable */
-	odm_set_bb_reg(p_dm, 0xCcc, 0x0F, 0x01);
-	/* High-to-Low threshold for WLBB_SEL_RF_ON when OFDM enable */
-	odm_set_bb_reg(p_dm, 0xCcc, 0xF0, 0x0);
-	/* b Low-to-High threshold for WLBB_SEL_RF_ON when OFDM disable ( only CCK ) */
-	odm_set_bb_reg(p_dm, 0xAbc, 0xFF, 0x06);
-	/* High-to-Low threshold for WLBB_SEL_RF_ON when OFDM disable ( only CCK ) */
-	odm_set_bb_reg(p_dm, 0xAbc, 0xFF00, 0x00);
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
+	/* @3 --RFE pin setting--------- */
+	/* @[MAC] */
+	odm_set_mac_reg(dm, R_0x1048, BIT(0), 1);
+		/* @DBG PAD Driving control (gpioA_0) */
+	odm_set_mac_reg(dm, R_0x1048, BIT(1), 1);
+		/* @DBG PAD Driving control (gpioA_1) */
+	odm_set_mac_reg(dm, R_0x4c, BIT(24), 1);
+	odm_set_mac_reg(dm, R_0x1038, BIT(25) | BIT(24) | BIT(23), 0);
+		/* @gpioA_0,gpioA_1*/
+	odm_set_mac_reg(dm, R_0x4c, BIT(23), 0);
+	/* @[BB] */
+	odm_set_bb_reg(dm, R_0x944, BIT(8), 1); /* output enable */
+	odm_set_bb_reg(dm, R_0x944, BIT(9), 1);
+	odm_set_bb_reg(dm, R_0x940, BIT(16) | BIT(17), 0x0);
+		/* r_rfe_path_sel_   (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, R_0x940, BIT(18) | BIT(19), 0x0);
+		/* r_rfe_path_sel_   (RFE_CTRL_9) */
+	odm_set_bb_reg(dm, R_0x944, BIT(31), 0); /* RFE_buffer_en */
+	odm_set_bb_reg(dm, R_0x92c, BIT(8), 0); /* rfe_inv  (RFE_CTRL_8) */
+	odm_set_bb_reg(dm, R_0x92c, BIT(9), 1); /* rfe_inv  (RFE_CTRL_9) */
+	odm_set_bb_reg(dm, R_0x934, 0xF, 0x8); /* path-A, RFE_CTRL_8 */
+	odm_set_bb_reg(dm, R_0x934, 0xF0, 0x8); /* path-A, RFE_CTRL_9 */
+	/* @3 ------------------------- */
 
+	/* Pin Settings */
+	odm_set_bb_reg(dm, R_0xc50, BIT(8), 0);
+		/* path-A,disable CS/CG switch */
+	odm_set_bb_reg(dm, R_0x870, BIT(9) | BIT(8), 0);
+		/* path-A*, antsel antselb by HW */
+	odm_set_bb_reg(dm, R_0xb38, BIT(10), 0); /* path-A ,antsel2 by HW */
 
-	/*OFDM HW AntDiv Parameters*/
-	odm_set_bb_reg(p_dm, 0xCA4, 0x7FF, 0xa0);
-	odm_set_bb_reg(p_dm, 0xCA4, 0x7FF000, 0x00);
-	odm_set_bb_reg(p_dm, 0xC5C, BIT(20) | BIT(19) | BIT(18), 0x04);
+	/* @Mapping table */
+	odm_set_bb_reg(dm, R_0x914, 0xFFFF, 0x0100);
+		/* @antenna mapping table */
+
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x0); /* @bias */
+
+	/* @CCK Settings */
+	odm_set_bb_reg(dm, R_0xa04, 0xF000000, 0);
+		/* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, R_0xb34, BIT(30), 0);
+		/* @(92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+		/* @CCK complete HW AntDiv within 64 samples */
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+}
+
+#endif /* @#if (RTL8192F_SUPPORT == 1) */
+
+#if (RTL8822B_SUPPORT == 1)
+void phydm_trx_hw_ant_div_init_22b(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
+
+	/* Pin Settings */
+	odm_set_bb_reg(dm, R_0xcb8, BIT(21) | BIT(20), 0x1);
+	odm_set_bb_reg(dm, R_0xcb8, BIT(23) | BIT(22), 0x1);
+	odm_set_bb_reg(dm, R_0xc1c, BIT(7) | BIT(6), 0x0);
+	/* @------------------------- */
+
+	/* @Mapping table */
+	/* @antenna mapping table */
+	odm_set_bb_reg(dm, R_0xca4, 0xFFFF, 0x0100);
+
+	/* OFDM Settings */
+	/* thershold */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF, 0xA0);
+	/* @bias */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF000, 0x0);
+	odm_set_bb_reg(dm, R_0x668, BIT(3), 0x1);
+
+	/* @CCK Settings */
+	/* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, R_0xa04, 0xF000000, 0);
+	/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+	/* @CCK complete HW AntDiv within 64 samples */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+	/* @BT Coexistence */
+	/* @keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, R_0xcac, BIT(9), 1);
+	/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	odm_set_bb_reg(dm, R_0x804, BIT(4), 1);
+	/* response TX ant by RX ant */
+	odm_set_mac_reg(dm, R_0x668, BIT(3), 1);
+#if (defined(CONFIG_2T4R_ANTENNA))
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***8822B AntDiv_Init =>  2T4R case\n");
+	/* Pin Settings */
+	odm_set_bb_reg(dm, R_0xeb8, BIT(21) | BIT(20), 0x1);
+	odm_set_bb_reg(dm, R_0xeb8, BIT(23) | BIT(22), 0x1);
+	odm_set_bb_reg(dm, R_0xe1c, BIT(7) | BIT(6), 0x0);
+	/* @BT Coexistence */
+	odm_set_bb_reg(dm, R_0xeac, BIT(9), 1);
+	/* @keep antsel_map when GNT_BT = 1 */
+	/* Mapping table */
+	/* antenna mapping table */
+	odm_set_bb_reg(dm, R_0xea4, 0xFFFF, 0x0100);
+	/*odm_set_bb_reg(dm, R_0x900, 0x30000, 0x3);*/
+#endif
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+}
+#endif /* @#if (RTL8822B_SUPPORT == 1) */
+
+#if (RTL8197F_SUPPORT == 1)
+void phydm_rx_hw_ant_div_init_97f(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+#if 0
+	if (*dm->mp_mode == true) {
+		odm_ant_div_on_off(dm, ANTDIV_OFF);
+		odm_set_bb_reg(dm, R_0xc50, BIT(8), 0);
+		/* r_rxdiv_enable_anta  regc50[8]=1'b0  0: control by c50[9] */
+		odm_set_bb_reg(dm, R_0xc50, BIT(9), 1);  /* @1:CG, 0:CS */
+		return;
+	}
+#endif
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
-	/*CCK HW AntDiv Parameters*/
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1);
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1);
-	odm_set_bb_reg(p_dm, 0xAA8, BIT(8), 0);
+	/* Pin Settings */
+	odm_set_bb_reg(dm, R_0x870, BIT(8), 0);
+		/* reg870[8]=1'b0, */ /* "antsel" is controlled by HWs */
+	odm_set_bb_reg(dm, R_0xc50, BIT(8), 1);
+		/* regc50[8]=1'b1 *//*"CS/CG switching" is controlled by HWs */
+
+	/* @Mapping table */
+	odm_set_bb_reg(dm, R_0x914, 0xFFFF, 0x0100);
+		/* @antenna mapping table */
+
+	/* OFDM Settings */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x0); /* @bias */
+
+	/* @CCK Settings */
+	odm_set_bb_reg(dm, R_0xa04, 0xF000000, 0);
+		/* Select which path to receive for CCK_1 & CCK_2 */
+	odm_set_bb_reg(dm, R_0xb34, BIT(30), 0);
+		/* @(92E) ANTSEL_CCK_opt = r_en_antsel_cck? ANTSEL_CCK: 1'b0 */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* @Fix CCK PHY status report issue */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+		/* @CCK complete HW AntDiv within 64 samples */
+
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+	phydm_evm_sw_antdiv_init(dm);
+#endif
+}
+#endif //#if (RTL8197F_SUPPORT == 1)
+
+#if (RTL8723D_SUPPORT == 1)
+void odm_trx_hw_ant_div_init_8723d(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
+
+	/*@BT Coexistence*/
+	/*@keep antsel_map when GNT_BT = 1*/
+	odm_set_bb_reg(dm, R_0x864, BIT(12), 1);
+	/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	odm_set_bb_reg(dm, R_0x874, BIT(23), 0);
+	/* @Disable hw antsw & fast_train.antsw when BT TX/RX */
+	odm_set_bb_reg(dm, R_0xe64, 0xFFFF0000, 0x000c);
+
+	odm_set_bb_reg(dm, R_0x870, BIT(9) | BIT(8), 0);
+#if 0
+	/*PTA setting: WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL)*/
+	/*odm_set_bb_reg(dm, R_0x948, BIT6, 0);*/
+	/*odm_set_bb_reg(dm, R_0x948, BIT8, 0);*/
+#endif
+	/*@GNT_WL tx*/
+	odm_set_bb_reg(dm, R_0x950, BIT(29), 0);
 
-	odm_set_bb_reg(p_dm, 0xA0C, 0x0F, 0xf);
-	odm_set_bb_reg(p_dm, 0xA14, 0x1F, 0x8);
-	odm_set_bb_reg(p_dm, 0xA10, BIT(13), 0x1);
-	odm_set_bb_reg(p_dm, 0xA74, BIT(8), 0x0);
-	odm_set_bb_reg(p_dm, 0xB34, BIT(30), 0x1);
+	/*@Mapping Table*/
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE1, 3);
+#if 0
+	/* odm_set_bb_reg(dm, R_0x864, BIT5|BIT4|BIT3, 0); */
+	/* odm_set_bb_reg(dm, R_0x864, BIT8|BIT7|BIT6, 1); */
+#endif
 
-	/*disable antenna training	*/
-	odm_set_bb_reg(p_dm, 0xE08, BIT(16), 0);
-	odm_set_bb_reg(p_dm, 0xc50, BIT(8), 0);
+	/* Set WLBB_SEL_RF_ON 1 if RXFIR_PWDB > 0xCcc[3:0] */
+	odm_set_bb_reg(dm, R_0xccc, BIT(12), 0);
+	/* @Low-to-High threshold for WLBB_SEL_RF_ON when OFDM enable */
+	odm_set_bb_reg(dm, R_0xccc, 0x0F, 0x01);
+	/* @High-to-Low threshold for WLBB_SEL_RF_ON when OFDM enable */
+	odm_set_bb_reg(dm, R_0xccc, 0xF0, 0x0);
+	/* @b Low-to-High threshold for WLBB_SEL_RF_ON when OFDM disable (CCK)*/
+	odm_set_bb_reg(dm, R_0xabc, 0xFF, 0x06);
+	/* @High-to-Low threshold for WLBB_SEL_RF_ON when OFDM disable (CCK) */
+	odm_set_bb_reg(dm, R_0xabc, 0xFF00, 0x00);
 
+	/*OFDM HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xa0);
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x00);
+	odm_set_bb_reg(dm, R_0xc5c, BIT(20) | BIT(19) | BIT(18), 0x04);
+
+	/*@CCK HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+	odm_set_bb_reg(dm, R_0xaa8, BIT(8), 0);
+
+	odm_set_bb_reg(dm, R_0xa0c, 0x0F, 0xf);
+	odm_set_bb_reg(dm, R_0xa14, 0x1F, 0x8);
+	odm_set_bb_reg(dm, R_0xa10, BIT(13), 0x1);
+	odm_set_bb_reg(dm, R_0xa74, BIT(8), 0x0);
+	odm_set_bb_reg(dm, R_0xb34, BIT(30), 0x1);
+
+	/*@disable antenna training	*/
+	odm_set_bb_reg(dm, R_0xe08, BIT(16), 0);
+	odm_set_bb_reg(dm, R_0xc50, BIT(8), 0);
 }
-/*Mingzhi 2017-05-08*/
-
-void
-odm_update_rx_idle_ant_8723d(
-	void			*p_dm_void,
-	u8			ant,
-	u32			default_ant,
-	u32			optional_ant
-)
+/*@Mingzhi 2017-05-08*/
+
+void odm_s0s1_sw_ant_div_init_8723d(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct _ADAPTER		*p_adapter = p_dm->adapter;
-	u8			count = 0;
-	
-
-/*	odm_set_bb_reg(p_dm, 0x948, BIT(6), 0x1);	*/
-	odm_set_bb_reg(p_dm, 0x948, BIT(7), default_ant);
-	odm_set_bb_reg(p_dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);      /*Default RX*/
-	odm_set_bb_reg(p_dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);     /*Optional RX*/
-	odm_set_bb_reg(p_dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant);    /*Default TX*/
-	p_dm_fat_table->rx_idle_ant = ant;
+	struct dm_struct		*dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch	*swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct		*fat_tab = &dm->dm_fat_table;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***8723D AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
+
+	/*@keep antsel_map when GNT_BT = 1*/
+	odm_set_bb_reg(dm, R_0x864, BIT(12), 1);
 
+	/* @Disable antsw when GNT_BT=1 */
+	odm_set_bb_reg(dm, R_0x874, BIT(23), 0);
+
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE1, 1);
+
+	/* Output Pin Settings */
+#if 0
+	/* odm_set_bb_reg(dm, R_0x948, BIT6, 0x1); */
+#endif
+	odm_set_bb_reg(dm, R_0x870, BIT(8), 1);
+	odm_set_bb_reg(dm, R_0x870, BIT(9), 1);
+
+	/* Status init */
+	fat_tab->is_become_linked  = false;
+	swat_tab->try_flag = SWAW_STEP_INIT;
+	swat_tab->double_chk_flag = 0;
+	swat_tab->cur_antenna = MAIN_ANT;
+	swat_tab->pre_ant = MAIN_ANT;
+	dm->antdiv_counter = CONFIG_ANTDIV_PERIOD;
+
+	/* @2 [--For HW Bug setting] */
+	odm_set_bb_reg(dm, R_0x80c, BIT(21), 0); /* TX ant  by Reg */
+}
+
+void odm_update_rx_idle_ant_8723d(void *dm_void, u8 ant, u32 default_ant,
+				  u32 optional_ant)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	void *adapter = dm->adapter;
+	u8 count = 0;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	/*score board to BT ,a002:WL to do ant-div*/
+	odm_set_mac_reg(dm, R_0xa8, MASKHWORD, 0xa002);
+	ODM_delay_us(50);
+#endif
+#if 0
+	/*	odm_set_bb_reg(dm, R_0x948, BIT(6), 0x1);	*/
+#endif
+	if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+	odm_set_bb_reg(dm, R_0x860, BIT(8), default_ant);
+	odm_set_bb_reg(dm, R_0x860, BIT(9), default_ant);
+	}
+	odm_set_bb_reg(dm, R_0x864, BIT(5) | BIT(4) | BIT(3), default_ant);
+		/*@Default RX*/
+	odm_set_bb_reg(dm, R_0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);
+		/*Optional RX*/
+	odm_set_bb_reg(dm, R_0x860, BIT(14) | BIT(13) | BIT(12), default_ant);
+		/*@Default TX*/
+	fat_tab->rx_idle_ant = ant;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
+	/*score board to BT ,a000:WL@S1 a001:WL@S0*/
+	if (default_ant == ANT1_2G)
+		odm_set_mac_reg(dm, R_0xa8, MASKHWORD, 0xa000);
+	else
+		odm_set_mac_reg(dm, R_0xa8, MASKHWORD, 0xa001);
+#endif
 }
 
-void
-phydm_set_tx_ant_pwr_8723d(
-	void			*p_dm_void,
-	u8			ant
-)
+void phydm_set_tx_ant_pwr_8723d(void *dm_void, u8 ant)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct _ADAPTER		*p_adapter = p_dm->adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	void *adapter = dm->adapter;
 
-	p_dm_fat_table->rx_idle_ant = ant;
+	fat_tab->rx_idle_ant = ant;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	p_adapter->HalFunc.SetTxPowerLevelHandler(p_adapter, *p_dm->p_channel);
+	((PADAPTER)adapter)->HalFunc.SetTxPowerLevelHandler(adapter, *dm->channel);
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	rtw_hal_set_tx_power_level(p_adapter, *p_dm->p_channel);
+	rtw_hal_set_tx_power_level(adapter, *dm->channel);
+#endif
+}
 #endif
 
+#if (RTL8721D_SUPPORT)
+#if 0
+void odm_update_rx_idle_ant_8721d(void *dm_void, u8 ant, u32 default_ant,
+				  u32 optional_ant)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+	odm_set_bb_reg(dm, R_0x864, BIT(5) | BIT(4) | BIT(3), default_ant);
+	/*@Default RX*/
+	odm_set_bb_reg(dm, R_0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);
+	/*@Optional RX*/
+	odm_set_bb_reg(dm, R_0x860, BIT(14) | BIT(13) | BIT(12), default_ant);
+	/*@Default TX*/
+	fat_tab->rx_idle_ant = ant;
 }
 #endif
 
+void odm_trx_hw_ant_div_init_8721d(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[8721D] AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV]\n");
+
+	/*@BT Coexistence*/
+	/*@keep antsel_map when GNT_BT = 1*/
+	odm_set_bb_reg(dm, R_0x864, BIT(12), 1);
+	/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	odm_set_bb_reg(dm, R_0x874, BIT(23), 0);
+	/* @Disable hw antsw & fast_train.antsw when BT TX/RX */
+	odm_set_bb_reg(dm, R_0xe64, 0xFFFF0000, 0x000c);
+
+	odm_set_bb_reg(dm, R_0x870, BIT(9) | BIT(8), 0);
+	odm_set_bb_reg(dm, R_0x804, 0xF00, 1); /* r_keep_rfpin */
+	odm_set_bb_reg(dm, R_0x930, 0xF, 8); /* RFE CTRL_0 ANTSEL */
+	odm_set_bb_reg(dm, R_0x930, 0xF0, 9); /* RFE CTRL_1 ANTSEL_B */
+	/*PTA setting: WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL)*/
+	/*odm_set_bb_reg(dm, R_0x948, BIT6, 0);*/
+	/*odm_set_bb_reg(dm, R_0x948, BIT8, 0);*/
+	/*@GNT_WL tx*/
+	odm_set_bb_reg(dm, R_0x950, BIT(29), 0);
+
+	/*@Mapping Table*/
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE1, 1);
+	/* odm_set_bb_reg(dm, R_0x864, BIT5|BIT4|BIT3, 0); */
+	/* odm_set_bb_reg(dm, R_0x864, BIT8|BIT7|BIT6, 1); */
+
+	/* Set WLBB_SEL_RF_ON 1 if RXFIR_PWDB > 0xCcc[3:0] */
+	odm_set_bb_reg(dm, R_0xccc, BIT(12), 0);
+	/* @Low-to-High threshold for WLBB_SEL_RF_ON */
+	/*when OFDM enable */
+	odm_set_bb_reg(dm, R_0xccc, 0x0F, 0x01);
+	/* @High-to-Low threshold for WLBB_SEL_RF_ON */
+	/* when OFDM enable */
+	odm_set_bb_reg(dm, R_0xccc, 0xF0, 0x0);
+	/* @b Low-to-High threshold for WLBB_SEL_RF_ON*/
+	/*when OFDM disable ( only CCK ) */
+	odm_set_bb_reg(dm, R_0xabc, 0xFF, 0x06);
+	/* @High-to-Low threshold for WLBB_SEL_RF_ON*/
+	/* when OFDM disable ( only CCK ) */
+	odm_set_bb_reg(dm, R_0xabc, 0xFF00, 0x00);
+
+	/*OFDM HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xa0);
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x00);
+	odm_set_bb_reg(dm, R_0xc5c, BIT(20) | BIT(19) | BIT(18), 0x04);
+
+	/*@CCK HW AntDiv Parameters*/
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+	odm_set_bb_reg(dm, R_0xaa8, BIT(8), 0);
+
+	odm_set_bb_reg(dm, R_0xa0c, 0x0F, 0xf);
+	odm_set_bb_reg(dm, R_0xa14, 0x1F, 0x8);
+	odm_set_bb_reg(dm, R_0xa10, BIT(13), 0x1);
+	odm_set_bb_reg(dm, R_0xa74, BIT(8), 0x0);
+	odm_set_bb_reg(dm, R_0xb34, BIT(30), 0x1);
+
+	/*@disable antenna training	*/
+	odm_set_bb_reg(dm, R_0xe08, BIT(16), 0);
+	odm_set_bb_reg(dm, R_0xc50, BIT(8), 0);
+}
+#endif
 #if (RTL8723B_SUPPORT == 1)
-void
-odm_trx_hw_ant_div_init_8723b(
-	void		*p_dm_void
-)
+void odm_trx_hw_ant_div_init_8723b(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8723B AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV(DPDT)]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***8723B AntDiv_Init =>  ant_div_type=[CG_TRX_HW_ANTDIV(DPDT)]\n");
 
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0x914, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0x914, MASKBYTE1, 1);
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE1, 1);
 
 	/* OFDM HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xCA4, 0x7FF, 0xa0); /* thershold */
-	odm_set_bb_reg(p_dm, 0xCA4, 0x7FF000, 0x00); /* bias */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF, 0xa0); /* thershold */
+	odm_set_bb_reg(dm, R_0xca4, 0x7FF000, 0x00); /* @bias */
 
-	/* CCK HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+	/* @CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1);
+		/* @do 64 samples */
 
-	/* BT Coexistence */
-	odm_set_bb_reg(p_dm, 0x864, BIT(12), 0); /* keep antsel_map when GNT_BT = 1 */
-	odm_set_bb_reg(p_dm, 0x874, BIT(23), 0); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	/* @BT Coexistence */
+	odm_set_bb_reg(dm, R_0x864, BIT(12), 0);
+		/* @keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, R_0x874, BIT(23), 0);
+		/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
 
 	/* Output Pin Settings */
-	odm_set_bb_reg(p_dm, 0x870, BIT(8), 0);
-
-	odm_set_bb_reg(p_dm, 0x948, BIT(6), 0); /* WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL) */
-	odm_set_bb_reg(p_dm, 0x948, BIT(7), 0);
+	odm_set_bb_reg(dm, R_0x870, BIT(8), 0);
 
-	odm_set_mac_reg(p_dm, 0x40, BIT(3), 1);
-	odm_set_mac_reg(p_dm, 0x38, BIT(11), 1);
-	odm_set_mac_reg(p_dm, 0x4C,  BIT(24) | BIT(23), 2); /* select DPDT_P and DPDT_N as output pin */
+	odm_set_bb_reg(dm, R_0x948, BIT(6), 0);
+		/* WL_BB_SEL_BTG_TRXG_anta,  (1: HW CTRL  0: SW CTRL) */
+	odm_set_bb_reg(dm, R_0x948, BIT(7), 0);
 
-	odm_set_bb_reg(p_dm, 0x944, BIT(0) | BIT(1), 3); /* in/out */
-	odm_set_bb_reg(p_dm, 0x944, BIT(31), 0);
+	odm_set_mac_reg(dm, R_0x40, BIT(3), 1);
+	odm_set_mac_reg(dm, R_0x38, BIT(11), 1);
+	odm_set_mac_reg(dm, R_0x4c, BIT(24) | BIT(23), 2);
+		/* select DPDT_P and DPDT_N as output pin */
 
-	odm_set_bb_reg(p_dm, 0x92C, BIT(1), 0); /* DPDT_P non-inverse */
-	odm_set_bb_reg(p_dm, 0x92C, BIT(0), 1); /* DPDT_N inverse */
+	odm_set_bb_reg(dm, R_0x944, BIT(0) | BIT(1), 3); /* @in/out */
+	odm_set_bb_reg(dm, R_0x944, BIT(31), 0);
 
-	odm_set_bb_reg(p_dm, 0x930, 0xF0, 8); /* DPDT_P = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0x930, 0xF, 8); /* DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0x92c, BIT(1), 0); /* @DPDT_P non-inverse */
+	odm_set_bb_reg(dm, R_0x92c, BIT(0), 1); /* @DPDT_N inverse */
 
-	/* 2 [--For HW Bug setting] */
-	if (p_dm->ant_type == ODM_AUTO_ANT)
-		odm_set_bb_reg(p_dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+	odm_set_bb_reg(dm, R_0x930, 0xF0, 8); /* @DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0x930, 0xF, 8); /* @DPDT_N = ANTSEL[0] */
 
+	/* @2 [--For HW Bug setting] */
+	if (dm->ant_type == ODM_AUTO_ANT)
+		odm_set_bb_reg(dm, R_0xa00, BIT(15), 0);
+			/* @CCK AntDiv function block enable */
 }
 
-
-
-void
-odm_s0s1_sw_ant_div_init_8723b(
-	void		*p_dm_void
-)
+void odm_s0s1_sw_ant_div_init_8723b(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8723B AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***8723B AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n");
 
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0x914, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0x914, MASKBYTE1, 1);
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0x914, MASKBYTE1, 1);
 
+#if 0
 	/* Output Pin Settings */
-	/* odm_set_bb_reg(p_dm, 0x948, BIT6, 0x1); */
-	odm_set_bb_reg(p_dm, 0x870, BIT(9) | BIT(8), 0);
-
-	p_dm_fat_table->is_become_linked  = false;
-	p_dm_swat_table->try_flag = SWAW_STEP_INIT;
-	p_dm_swat_table->double_chk_flag = 0;
+	/* odm_set_bb_reg(dm, R_0x948, BIT6, 0x1); */
+#endif
+	odm_set_bb_reg(dm, R_0x870, BIT(9) | BIT(8), 0);
 
-	/* 2 [--For HW Bug setting] */
-	odm_set_bb_reg(p_dm, 0x80C, BIT(21), 0); /* TX ant  by Reg */
+	fat_tab->is_become_linked = false;
+	swat_tab->try_flag = SWAW_STEP_INIT;
+	swat_tab->double_chk_flag = 0;
 
+	/* @2 [--For HW Bug setting] */
+	odm_set_bb_reg(dm, R_0x80c, BIT(21), 0); /* TX ant  by Reg */
 }
 
-void
-odm_update_rx_idle_ant_8723b(
-	void			*p_dm_void,
-	u8			ant,
-	u32			default_ant,
-	u32			optional_ant
-)
+void odm_update_rx_idle_ant_8723b(
+	void *dm_void,
+	u8 ant,
+	u32 default_ant,
+	u32 optional_ant)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct _ADAPTER		*p_adapter = p_dm->adapter;
-	u8			count = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	void *adapter = dm->adapter;
+	u8 count = 0;
 	/*u8			u1_temp;*/
 	/*u8			h2c_parameter;*/
 
-	if ((!p_dm->is_linked) && (p_dm->ant_type == ODM_AUTO_ANT)) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to no link\n"));
+	if (!dm->is_linked && dm->ant_type == ODM_AUTO_ANT) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to no link\n");
 		return;
 	}
 
 #if 0
 	/* Send H2C command to FW */
-	/* Enable wifi calibration */
+	/* @Enable wifi calibration */
 	h2c_parameter = true;
-	odm_fill_h2c_cmd(p_dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+	odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
 
-	/* Check if H2C command sucess or not (0x1e6) */
-	u1_temp = odm_read_1byte(p_dm, 0x1e6);
+	/* @Check if H2C command sucess or not (0x1e6) */
+	u1_temp = odm_read_1byte(dm, 0x1e6);
 	while ((u1_temp != 0x1) && (count < 100)) {
 		ODM_delay_us(10);
-		u1_temp = odm_read_1byte(p_dm, 0x1e6);
+		u1_temp = odm_read_1byte(dm, 0x1e6);
 		count++;
 	}
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: H2C command status = %d, count = %d\n", u1_temp, count));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Update Rx-Idle-ant ] 8723B: H2C command status = %d, count = %d\n",
+		  u1_temp, count);
 
 	if (u1_temp == 0x1) {
-		/* Check if BT is doing IQK (0x1e7) */
+		/* @Check if BT is doing IQK (0x1e7) */
 		count = 0;
-		u1_temp = odm_read_1byte(p_dm, 0x1e7);
+		u1_temp = odm_read_1byte(dm, 0x1e7);
 		while ((!(u1_temp & BIT(0)))  && (count < 100)) {
 			ODM_delay_us(50);
-			u1_temp = odm_read_1byte(p_dm, 0x1e7);
+			u1_temp = odm_read_1byte(dm, 0x1e7);
 			count++;
 		}
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: BT IQK status = %d, count = %d\n", u1_temp, count));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ Update Rx-Idle-ant ] 8723B: BT IQK status = %d, count = %d\n",
+			  u1_temp, count);
 
 		if (u1_temp & BIT(0)) {
-			odm_set_bb_reg(p_dm, 0x948, BIT(6), 0x1);
-			odm_set_bb_reg(p_dm, 0x948, BIT(9), default_ant);
-			odm_set_bb_reg(p_dm, 0x864, BIT(5) | BIT4 | BIT3, default_ant);	/* Default RX */
-			odm_set_bb_reg(p_dm, 0x864, BIT(8) | BIT7 | BIT6, optional_ant);	/* Optional RX */
-			odm_set_bb_reg(p_dm, 0x860, BIT(14) | BIT13 | BIT12, default_ant); /* Default TX */
-			p_dm_fat_table->rx_idle_ant = ant;
+			odm_set_bb_reg(dm, R_0x948, BIT(6), 0x1);
+			odm_set_bb_reg(dm, R_0x948, BIT(9), default_ant);
+			odm_set_bb_reg(dm, R_0x864, 0x38, default_ant);
+					/* @Default RX */
+			odm_set_bb_reg(dm, R_0x864, 0x1c0, optional_ant);
+					/* @Optional RX */
+			odm_set_bb_reg(dm, R_0x860, 0x7000, default_ant);
+					/* @Default TX */
+			fat_tab->rx_idle_ant = ant;
 
 			/* Set TX AGC by S0/S1 */
 			/* Need to consider Linux driver */
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			p_adapter->hal_func.set_tx_power_level_handler(p_adapter, *p_dm->p_channel);
+			adapter->hal_func.set_tx_power_level_handler(adapter, *dm->channel);
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-			rtw_hal_set_tx_power_level(p_adapter, *p_dm->p_channel);
+			rtw_hal_set_tx_power_level(adapter, *dm->channel);
 #endif
 
 			/* Set IQC by S0/S1 */
-			odm_set_iqc_by_rfpath(p_dm, default_ant);
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n"));
+			odm_set_iqc_by_rfpath(dm, default_ant);
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n");
 		} else
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to BT IQK\n"));
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to BT IQK\n");
 	} else
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to H2C command fail\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ Update Rx-Idle-ant ] 8723B: Fail to set RX antenna due to H2C command fail\n");
 
 	/* Send H2C command to FW */
-	/* Disable wifi calibration */
+	/* @Disable wifi calibration */
 	h2c_parameter = false;
-	odm_fill_h2c_cmd(p_dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
+	odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
 #else
 
-	odm_set_bb_reg(p_dm, 0x948, BIT(6), 0x1);
-	odm_set_bb_reg(p_dm, 0x948, BIT(9), default_ant);
-	odm_set_bb_reg(p_dm, 0x864, BIT(5) | BIT(4) | BIT(3), default_ant);      /*Default RX*/
-	odm_set_bb_reg(p_dm, 0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);     /*Optional RX*/
-	odm_set_bb_reg(p_dm, 0x860, BIT(14) | BIT(13) | BIT(12), default_ant);    /*Default TX*/
-	p_dm_fat_table->rx_idle_ant = ant;
-
-	/* Set TX AGC by S0/S1 */
-	/* Need to consider Linux driver */
+	odm_set_bb_reg(dm, R_0x948, BIT(6), 0x1);
+	odm_set_bb_reg(dm, R_0x948, BIT(9), default_ant);
+	odm_set_bb_reg(dm, R_0x864, BIT(5) | BIT(4) | BIT(3), default_ant);
+			/*@Default RX*/
+	odm_set_bb_reg(dm, R_0x864, BIT(8) | BIT(7) | BIT(6), optional_ant);
+			/*Optional RX*/
+	odm_set_bb_reg(dm, R_0x860, BIT(14) | BIT(13) | BIT(12), default_ant);
+			/*@Default TX*/
+	fat_tab->rx_idle_ant = ant;
+
+/* Set TX AGC by S0/S1 */
+/* Need to consider Linux driver */
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	p_adapter->HalFunc.SetTxPowerLevelHandler(p_adapter, *p_dm->p_channel);
+	((PADAPTER)adapter)->HalFunc.SetTxPowerLevelHandler(adapter, *dm->channel);
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	rtw_hal_set_tx_power_level(p_adapter, *p_dm->p_channel);
+	rtw_hal_set_tx_power_level(adapter, *dm->channel);
 #endif
 
 	/* Set IQC by S0/S1 */
-	odm_set_iqc_by_rfpath(p_dm, default_ant);
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n"));
+	odm_set_iqc_by_rfpath(dm, default_ant);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Update Rx-Idle-ant ] 8723B: Success to set RX antenna\n");
 
 #endif
 }
 
 boolean
-phydm_is_bt_enable_8723b(
-	void			*p_dm_void
-)
+phydm_is_bt_enable_8723b(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			bt_state;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 bt_state;
+#if 0
 	/*u32			reg75;*/
 
-	/*reg75 = odm_get_bb_reg(p_dm, 0x74, BIT8);*/
-	/*odm_set_bb_reg(p_dm, 0x74, BIT8, 0x0);*/
-	odm_set_bb_reg(p_dm, 0xa0, BIT(24) | BIT(25) | BIT(26), 0x5);
-	bt_state = odm_get_bb_reg(p_dm, 0xa0, (BIT(3) | BIT(2) | BIT(1) | BIT(0)));
-	/*odm_set_bb_reg(p_dm, 0x74, BIT8, reg75);*/
+	/*reg75 = odm_get_bb_reg(dm, R_0x74, BIT8);*/
+	/*odm_set_bb_reg(dm, R_0x74, BIT8, 0x0);*/
+#endif
+	odm_set_bb_reg(dm, R_0xa0, BIT(24) | BIT(25) | BIT(26), 0x5);
+	bt_state = odm_get_bb_reg(dm, R_0xa0, 0xf);
+#if 0
+	/*odm_set_bb_reg(dm, R_0x74, BIT8, reg75);*/
+#endif
 
-	if ((bt_state == 4) || (bt_state == 7) || (bt_state == 9) || (bt_state == 13))
+	if (bt_state == 4 || bt_state == 7 || bt_state == 9 || bt_state == 13)
 		return true;
 	else
 		return false;
 }
-#endif /* #if (RTL8723B_SUPPORT == 1) */
+#endif /* @#if (RTL8723B_SUPPORT == 1) */
 
 #if (RTL8821A_SUPPORT == 1)
 
-void
-odm_trx_hw_ant_div_init_8821a(
-	void		*p_dm_void
-)
+void odm_trx_hw_ant_div_init_8821a(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8821A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (DPDT)]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
 	/* Output Pin Settings */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(25), 0);
+	odm_set_mac_reg(dm, R_0x4c, BIT(25), 0);
 
-	odm_set_mac_reg(p_dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
-	odm_set_mac_reg(p_dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(28), 1); /* @LNAON by WLAN control */
 
-	odm_set_bb_reg(p_dm, 0xCB8, BIT(16), 0);
+	odm_set_bb_reg(dm, R_0xcb8, BIT(16), 0);
 
-	odm_set_mac_reg(p_dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(24), 1); /* by WLAN control */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+	odm_set_mac_reg(dm, R_0x4c, BIT(23), 0);
+			/* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, R_0x4c, BIT(24), 1); /* @by WLAN control */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF, 8); /* @DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF0, 8); /* @DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(29), 0); /* @DPDT_P non-inverse */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(28), 1); /* @DPDT_N inverse */
 
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE1, 1);
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE1, 1);
 
 	/* OFDM HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF000, 0x10); /* @bias */
 
-	/* CCK HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+	/* @CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1); /* @do 64 samples */
 
-	odm_set_bb_reg(p_dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
-	odm_set_bb_reg(p_dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+	odm_set_bb_reg(dm, R_0x800, BIT(25), 0);
+		/* @ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, R_0xa00, BIT(15), 0);
+		/* @CCK AntDiv function block enable */
 
-	/* BT Coexistence */
-	odm_set_bb_reg(p_dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
-	odm_set_bb_reg(p_dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	/* @BT Coexistence */
+	odm_set_bb_reg(dm, R_0xcac, BIT(9), 1);
+		/* @keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, R_0x804, BIT(4), 1);
+		/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
 
-	odm_set_bb_reg(p_dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+	odm_set_bb_reg(dm, R_0x8cc, BIT(20) | BIT(19) | BIT(18), 3);
+		/* settling time of antdiv by RF LNA = 100ns */
 
 	/* response TX ant by RX ant */
-	odm_set_mac_reg(p_dm, 0x668, BIT(3), 1);
-
+	odm_set_mac_reg(dm, R_0x668, BIT(3), 1);
 }
 
-void
-odm_s0s1_sw_ant_div_init_8821a(
-	void		*p_dm_void
-)
+void odm_s0s1_sw_ant_div_init_8821a(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8821A AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
 	/* Output Pin Settings */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(25), 0);
+	odm_set_mac_reg(dm, R_0x4c, BIT(25), 0);
 
-	odm_set_mac_reg(p_dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
-	odm_set_mac_reg(p_dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(28), 1); /* @LNAON by WLAN control */
 
-	odm_set_bb_reg(p_dm, 0xCB8, BIT(16), 0);
+	odm_set_bb_reg(dm, R_0xcb8, BIT(16), 0);
 
-	odm_set_mac_reg(p_dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(24), 1); /* by WLAN control */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+	odm_set_mac_reg(dm, R_0x4c, BIT(23), 0);
+		/* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, R_0x4c, BIT(24), 1); /* @by WLAN control */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF, 8); /* @DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF0, 8); /* @DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(29), 0); /* @DPDT_P non-inverse */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(28), 1); /* @DPDT_N inverse */
 
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE1, 1);
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE1, 1);
 
 	/* OFDM HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF000, 0x10); /* @bias */
 
-	/* CCK HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+	/* @CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1); /* @do 64 samples */
 
-	odm_set_bb_reg(p_dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
-	odm_set_bb_reg(p_dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+	odm_set_bb_reg(dm, R_0x800, BIT(25), 0);
+		/* @ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, R_0xa00, BIT(15), 0);
+		/* @CCK AntDiv function block enable */
 
-	/* BT Coexistence */
-	odm_set_bb_reg(p_dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
-	odm_set_bb_reg(p_dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	/* @BT Coexistence */
+	odm_set_bb_reg(dm, R_0xcac, BIT(9), 1);
+		/* @keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, R_0x804, BIT(4), 1);
+		/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
 
-	odm_set_bb_reg(p_dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+	odm_set_bb_reg(dm, R_0x8cc, BIT(20) | BIT(19) | BIT(18), 3);
+		/* settling time of antdiv by RF LNA = 100ns */
 
 	/* response TX ant by RX ant */
-	odm_set_mac_reg(p_dm, 0x668, BIT(3), 1);
+	odm_set_mac_reg(dm, R_0x668, BIT(3), 1);
 
+	odm_set_bb_reg(dm, R_0x900, BIT(18), 0);
 
-	odm_set_bb_reg(p_dm, 0x900, BIT(18), 0);
-
-	p_dm_swat_table->try_flag = SWAW_STEP_INIT;
-	p_dm_swat_table->double_chk_flag = 0;
-	p_dm_swat_table->cur_antenna = MAIN_ANT;
-	p_dm_swat_table->pre_antenna = MAIN_ANT;
-	p_dm_swat_table->swas_no_link_state = 0;
-
-}
-#endif /* #if (RTL8821A_SUPPORT == 1) */
+	swat_tab->try_flag = SWAW_STEP_INIT;
+	swat_tab->double_chk_flag = 0;
+	swat_tab->cur_antenna = MAIN_ANT;
+	swat_tab->pre_ant = MAIN_ANT;
+	swat_tab->swas_no_link_state = 0;
+}
+#endif /* @#if (RTL8821A_SUPPORT == 1) */
 
 #if (RTL8821C_SUPPORT == 1)
-void
-odm_trx_hw_ant_div_init_8821c(
-	void		*p_dm_void
-)
+void odm_trx_hw_ant_div_init_8821c(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8821C AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (DPDT)]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 	/* Output Pin Settings */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(25), 0);
+	odm_set_mac_reg(dm, R_0x4c, BIT(25), 0);
 
-	odm_set_mac_reg(p_dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
-	odm_set_mac_reg(p_dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(28), 1); /* @LNAON by WLAN control */
 
-	odm_set_bb_reg(p_dm, 0xCB8, BIT(16), 0);
+	odm_set_bb_reg(dm, R_0xcb8, BIT(16), 0);
 
-	odm_set_mac_reg(p_dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(24), 1); /* by WLAN control */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+	odm_set_mac_reg(dm, R_0x4c, BIT(23), 0);
+		/* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, R_0x4c, BIT(24), 1); /* @by WLAN control */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF, 8); /* @DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF0, 8); /* @DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(29), 0); /* @DPDT_P non-inverse */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(28), 1); /* @DPDT_N inverse */
 
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE1, 1);
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE1, 1);
 
 	/* OFDM HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF000, 0x10); /* bias */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF000, 0x10); /* @bias */
 
-	/* CCK HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+	/* @CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1); /* @do 64 samples */
 
-	odm_set_bb_reg(p_dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
-	odm_set_bb_reg(p_dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+	odm_set_bb_reg(dm, R_0x800, BIT(25), 0);
+		/* @ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, R_0xa00, BIT(15), 0);
+		/* @CCK AntDiv function block enable */
 
-	/* BT Coexistence */
-	odm_set_bb_reg(p_dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
-	odm_set_bb_reg(p_dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	/* @BT Coexistence */
+	odm_set_bb_reg(dm, R_0xcac, BIT(9), 1);
+		/* @keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, R_0x804, BIT(4), 1);
+		/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
 
 	/* Timming issue */
-	odm_set_bb_reg(p_dm, 0x818, BIT(23) | BIT(22) | BIT(21) | BIT(20), 0); /*keep antidx after tx for ACK ( unit x 3.2 mu sec)*/
-	odm_set_bb_reg(p_dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+	odm_set_bb_reg(dm, R_0x818, BIT(23) | BIT(22) | BIT(21) | BIT(20), 0);
+		/*@keep antidx after tx for ACK ( unit x 3.2 mu sec)*/
+	odm_set_bb_reg(dm, R_0x8cc, BIT(20) | BIT(19) | BIT(18), 3);
+		/* settling time of antdiv by RF LNA = 100ns */
 
 	/* response TX ant by RX ant */
-	odm_set_mac_reg(p_dm, 0x668, BIT(3), 1);
-
+	odm_set_mac_reg(dm, R_0x668, BIT(3), 1);
 }
 
-void
-phydm_s0s1_sw_ant_div_init_8821c(
-	void		*p_dm_void
-)
+void phydm_s0s1_sw_ant_div_init_8821c(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8821C AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
 	/* Output Pin Settings */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(25), 0);
+	odm_set_mac_reg(dm, R_0x4c, BIT(25), 0);
 
-	odm_set_mac_reg(p_dm, 0x64, BIT(29), 1); /* PAPE by WLAN control */
-	odm_set_mac_reg(p_dm, 0x64, BIT(28), 1); /* LNAON by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(29), 1); /* PAPE by WLAN control */
+	odm_set_mac_reg(dm, R_0x64, BIT(28), 1); /* @LNAON by WLAN control */
 
-	odm_set_bb_reg(p_dm, 0xCB8, BIT(16), 0);
+	odm_set_bb_reg(dm, R_0xcb8, BIT(16), 0);
 
-	odm_set_mac_reg(p_dm, 0x4C, BIT(23), 0); /* select DPDT_P and DPDT_N as output pin */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(24), 1); /* by WLAN control */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF, 8); /* DPDT_P = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, 0xF0, 8); /* DPDT_N = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(29), 0); /* DPDT_P non-inverse */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(28), 1); /* DPDT_N inverse */
+	odm_set_mac_reg(dm, R_0x4c, BIT(23), 0);
+		/* select DPDT_P and DPDT_N as output pin */
+	odm_set_mac_reg(dm, R_0x4c, BIT(24), 1); /* @by WLAN control */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF, 8); /* @DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, 0xF0, 8); /* @DPDT_N = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(29), 0); /* @DPDT_P non-inverse */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(28), 1); /* @DPDT_N inverse */
 
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE1, 1);
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE1, 1);
 
 	/* OFDM HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF000, 0x00); /* bias */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF000, 0x00); /* @bias */
 
-	/* CCK HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+	/* @CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1); /* @do 64 samples */
 
-	odm_set_bb_reg(p_dm, 0x800, BIT(25), 0); /* ANTSEL_CCK sent to the smart_antenna circuit */
-	odm_set_bb_reg(p_dm, 0xA00, BIT(15), 0); /* CCK AntDiv function block enable */
+	odm_set_bb_reg(dm, R_0x800, BIT(25), 0);
+		/* @ANTSEL_CCK sent to the smart_antenna circuit */
+	odm_set_bb_reg(dm, R_0xa00, BIT(15), 0);
+		/* @CCK AntDiv function block enable */
 
-	/* BT Coexistence */
-	odm_set_bb_reg(p_dm, 0xCAC, BIT(9), 1); /* keep antsel_map when GNT_BT = 1 */
-	odm_set_bb_reg(p_dm, 0x804, BIT(4), 1); /* Disable hw antsw & fast_train.antsw when GNT_BT=1 */
+	/* @BT Coexistence */
+	odm_set_bb_reg(dm, R_0xcac, BIT(9), 1);
+		/* @keep antsel_map when GNT_BT = 1 */
+	odm_set_bb_reg(dm, R_0x804, BIT(4), 1);
+		/* @Disable hw antsw & fast_train.antsw when GNT_BT=1 */
 
-	odm_set_bb_reg(p_dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+	odm_set_bb_reg(dm, R_0x8cc, BIT(20) | BIT(19) | BIT(18), 3);
+		/* settling time of antdiv by RF LNA = 100ns */
 
 	/* response TX ant by RX ant */
-	odm_set_mac_reg(p_dm, 0x668, BIT(3), 1);
-
+	odm_set_mac_reg(dm, R_0x668, BIT(3), 1);
 
-	odm_set_bb_reg(p_dm, 0x900, BIT(18), 0);
-
-	p_dm_swat_table->try_flag = SWAW_STEP_INIT;
-	p_dm_swat_table->double_chk_flag = 0;
-	p_dm_swat_table->cur_antenna = MAIN_ANT;
-	p_dm_swat_table->pre_antenna = MAIN_ANT;
-	p_dm_swat_table->swas_no_link_state = 0;
+	odm_set_bb_reg(dm, R_0x900, BIT(18), 0);
 
+	swat_tab->try_flag = SWAW_STEP_INIT;
+	swat_tab->double_chk_flag = 0;
+	swat_tab->cur_antenna = MAIN_ANT;
+	swat_tab->pre_ant = MAIN_ANT;
+	swat_tab->swas_no_link_state = 0;
 }
-#endif /* #if (RTL8821C_SUPPORT == 1) */
-
+#endif /* @#if (RTL8821C_SUPPORT == 1) */
 
 #if (RTL8881A_SUPPORT == 1)
-void
-odm_trx_hw_ant_div_init_8881a(
-	void		*p_dm_void
-)
+void odm_trx_hw_ant_div_init_8881a(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8881A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (SPDT)]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
 	/* Output Pin Settings */
-	/* [SPDT related] */
-	odm_set_mac_reg(p_dm, 0x4C, BIT(25), 0);
-	odm_set_mac_reg(p_dm, 0x4C, BIT(26), 0);
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(31), 0); /* delay buffer */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(22), 0);
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(24), 1);
-	odm_set_bb_reg(p_dm, 0xCB0, 0xF00, 8); /* DPDT_P = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB0, 0xF0000, 8); /* DPDT_N = ANTSEL[0] */
-
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE1, 1);
+	/* @[SPDT related] */
+	odm_set_mac_reg(dm, R_0x4c, BIT(25), 0);
+	odm_set_mac_reg(dm, R_0x4c, BIT(26), 0);
+	odm_set_bb_reg(dm, R_0xcb4, BIT(31), 0); /* @delay buffer */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(22), 0);
+	odm_set_bb_reg(dm, R_0xcb4, BIT(24), 1);
+	odm_set_bb_reg(dm, R_0xcb0, 0xF00, 8); /* @DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb0, 0xF0000, 8); /* @DPDT_N = ANTSEL[0] */
+
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE1, 1);
 
 	/* OFDM HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF000, 0x0); /* bias */
-	odm_set_bb_reg(p_dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF000, 0x0); /* @bias */
+	odm_set_bb_reg(dm, R_0x8cc, BIT(20) | BIT(19) | BIT(18), 3);
+		/* settling time of antdiv by RF LNA = 100ns */
 
-	/* CCK HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+	/* @CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1); /* @do 64 samples */
 
-	/* 2 [--For HW Bug setting] */
+	/* @2 [--For HW Bug setting] */
 
-	odm_set_bb_reg(p_dm, 0x900, BIT(18), 0); /* TX ant  by Reg */ /* A-cut bug */
+	odm_set_bb_reg(dm, R_0x900, BIT(18), 0);
+		/* TX ant  by Reg *//* A-cut bug */
 }
 
-#endif /* #if (RTL8881A_SUPPORT == 1) */
-
+#endif /* @#if (RTL8881A_SUPPORT == 1) */
 
 #if (RTL8812A_SUPPORT == 1)
-void
-odm_trx_hw_ant_div_init_8812a(
-	void		*p_dm_void
-)
+void odm_trx_hw_ant_div_init_8812a(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8812A AntDiv_Init => ant_div_type=[ CG_TRX_HW_ANTDIV (SPDT)]\n"));
-
-	/* 3 */ /* 3 --RFE pin setting--------- */
-	/* [BB] */
-	odm_set_bb_reg(p_dm, 0x900, BIT(10) | BIT(9) | BIT(8), 0x0);	 /* disable SW switch */
-	odm_set_bb_reg(p_dm, 0x900, BIT(17) | BIT(16), 0x0);
-	odm_set_bb_reg(p_dm, 0x974, BIT(7) | BIT(6), 0x3);   /* in/out */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(31), 0); /* delay buffer */
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(26), 0);
-	odm_set_bb_reg(p_dm, 0xCB4, BIT(27), 1);
-	odm_set_bb_reg(p_dm, 0xCB0, 0xF000000, 8); /* DPDT_P = ANTSEL[0] */
-	odm_set_bb_reg(p_dm, 0xCB0, 0xF0000000, 8); /* DPDT_N = ANTSEL[0] */
-	/* 3 ------------------------- */
-
-	/* Mapping Table */
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE0, 0);
-	odm_set_bb_reg(p_dm, 0xCA4, MASKBYTE1, 1);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
+
+	/* @3 */ /* @3 --RFE pin setting--------- */
+	/* @[BB] */
+	odm_set_bb_reg(dm, R_0x900, BIT(10) | BIT(9) | BIT(8), 0x0);
+		/* @disable SW switch */
+	odm_set_bb_reg(dm, R_0x900, BIT(17) | BIT(16), 0x0);
+	odm_set_bb_reg(dm, R_0x974, BIT(7) | BIT(6), 0x3); /* @in/out */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(31), 0); /* @delay buffer */
+	odm_set_bb_reg(dm, R_0xcb4, BIT(26), 0);
+	odm_set_bb_reg(dm, R_0xcb4, BIT(27), 1);
+	odm_set_bb_reg(dm, R_0xcb0, 0xF000000, 8); /* @DPDT_P = ANTSEL[0] */
+	odm_set_bb_reg(dm, R_0xcb0, 0xF0000000, 8); /* @DPDT_N = ANTSEL[0] */
+	/* @3 ------------------------- */
+
+	/* @Mapping Table */
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE0, 0);
+	odm_set_bb_reg(dm, R_0xca4, MASKBYTE1, 1);
 
 	/* OFDM HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF, 0xA0); /* thershold */
-	odm_set_bb_reg(p_dm, 0x8D4, 0x7FF000, 0x0); /* bias */
-	odm_set_bb_reg(p_dm, 0x8CC, BIT(20) | BIT(19) | BIT(18), 3); /* settling time of antdiv by RF LNA = 100ns */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF, 0xA0); /* thershold */
+	odm_set_bb_reg(dm, R_0x8d4, 0x7FF000, 0x0); /* @bias */
+	odm_set_bb_reg(dm, R_0x8cc, BIT(20) | BIT(19) | BIT(18), 3);
+		/* settling time of antdiv by RF LNA = 100ns */
 
-	/* CCK HW AntDiv Parameters */
-	odm_set_bb_reg(p_dm, 0xA74, BIT(7), 1); /* patch for clk from 88M to 80M */
-	odm_set_bb_reg(p_dm, 0xA0C, BIT(4), 1); /* do 64 samples */
+	/* @CCK HW AntDiv Parameters */
+	odm_set_bb_reg(dm, R_0xa74, BIT(7), 1);
+		/* patch for clk from 88M to 80M */
+	odm_set_bb_reg(dm, R_0xa0c, BIT(4), 1); /* @do 64 samples */
 
-	/* 2 [--For HW Bug setting] */
-
-	odm_set_bb_reg(p_dm, 0x900, BIT(18), 0); /* TX ant  by Reg */ /* A-cut bug */
+	/* @2 [--For HW Bug setting] */
 
+	odm_set_bb_reg(dm, R_0x900, BIT(18), 0);
+		/* TX ant  by Reg */ /* A-cut bug */
 }
 
-#endif /* #if (RTL8812A_SUPPORT == 1) */
+#endif /* @#if (RTL8812A_SUPPORT == 1) */
 
 #if (RTL8188F_SUPPORT == 1)
-void
-odm_s0s1_sw_ant_div_init_8188f(
-	void		*p_dm_void
-)
+void odm_s0s1_sw_ant_div_init_8188f(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8188F AntDiv_Init => ant_div_type=[ S0S1_SW_AntDiv]\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s]=====>\n", __func__);
 
-	/*GPIO setting*/
-	/*odm_set_mac_reg(p_dm, 0x64, BIT(18), 0); */
-	/*odm_set_mac_reg(p_dm, 0x44, BIT(28)|BIT(27), 0);*/
-	/*odm_set_mac_reg(p_dm, 0x44, BIT(20) | BIT(19), 0x3);*/	/*enable_output for P_GPIO[4:3]*/
-	/*odm_set_mac_reg(p_dm, 0x44, BIT(12)|BIT(11), 0);*/ /*output value*/
-	/*odm_set_mac_reg(p_dm, 0x40, BIT(1)|BIT(0), 0);*/		/*GPIO function*/
+#if 0
+	/*@GPIO setting*/
+	/*odm_set_mac_reg(dm, R_0x64, BIT(18), 0); */
+	/*odm_set_mac_reg(dm, R_0x44, BIT(28)|BIT(27), 0);*/
+	/*odm_set_mac_reg(dm, R_0x44, BIT(20) | BIT(19), 0x3);*/
+		/*enable_output for P_GPIO[4:3]*/
+	/*odm_set_mac_reg(dm, R_0x44, BIT(12)|BIT(11), 0);*/ /*output value*/
+	/*odm_set_mac_reg(dm, R_0x40, BIT(1)|BIT(0), 0);*/ /*GPIO function*/
+#endif
 
-	if (p_dm->support_ic_type == ODM_RTL8188F) {
-		if (p_dm->support_interface == ODM_ITRF_USB)
-			odm_set_mac_reg(p_dm, 0x44, BIT(20) | BIT(19), 0x3);	/*enable_output for P_GPIO[4:3]*/
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
-			odm_set_mac_reg(p_dm, 0x44, BIT(18), 0x1);	/*enable_output for P_GPIO[2]*/
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB)
+			odm_set_mac_reg(dm, R_0x44, BIT(20) | BIT(19), 0x3);
+				/*@enable_output for P_GPIO[4:3]*/
+		else if (dm->support_interface == ODM_ITRF_SDIO)
+			odm_set_mac_reg(dm, R_0x44, BIT(18), 0x1);
+				/*@enable_output for P_GPIO[2]*/
 	}
-	
-	p_dm_fat_table->is_become_linked  = false;
-	p_dm_swat_table->try_flag = SWAW_STEP_INIT;
-	p_dm_swat_table->double_chk_flag = 0;
+
+	fat_tab->is_become_linked = false;
+	swat_tab->try_flag = SWAW_STEP_INIT;
+	swat_tab->double_chk_flag = 0;
 }
 
-void
-phydm_update_rx_idle_antenna_8188F(
-	void	*p_dm_void,
-	u32	default_ant
-)
+void phydm_update_rx_idle_antenna_8188F(void *dm_void, u32 default_ant)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		codeword;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 codeword;
 
-	if (p_dm->support_ic_type == ODM_RTL8188F) {
-		if (p_dm->support_interface == ODM_ITRF_USB) {
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB) {
 			if (default_ant == ANT1_2G)
-				codeword = 1; /*2'b01*/
+				codeword = 1; /*@2'b01*/
 			else
-				codeword = 2;/*2'b10*/
-			odm_set_mac_reg(p_dm, 0x44, (BIT(12) | BIT(11)), codeword); /*GPIO[4:3] output value*/
-		} else if (p_dm->support_interface == ODM_ITRF_SDIO) {
+				codeword = 2; /*@2'b10*/
+			odm_set_mac_reg(dm, R_0x44, 0x1800, codeword);
+				/*@GPIO[4:3] output value*/
+		} else if (dm->support_interface == ODM_ITRF_SDIO) {
 			if (default_ant == ANT1_2G) {
-				codeword = 0; /*1'b0*/
-				odm_set_bb_reg(p_dm, 0x870, BIT(9)|BIT(8), 0x3);
-				odm_set_bb_reg(p_dm, 0x860, BIT(9)|BIT(8), 0x1);
+				codeword = 0; /*@1'b0*/
+				odm_set_bb_reg(dm, R_0x870, 0x300, 0x3);
+				odm_set_bb_reg(dm, R_0x860, 0x300, 0x1);
 			} else {
-				codeword = 1;/*1'b1*/
-				odm_set_bb_reg(p_dm, 0x870, BIT(9)|BIT(8), 0x3);
-				odm_set_bb_reg(p_dm, 0x860, BIT(9)|BIT(8), 0x2);
+				codeword = 1; /*@1'b1*/
+				odm_set_bb_reg(dm, R_0x870, 0x300, 0x3);
+				odm_set_bb_reg(dm, R_0x860, 0x300, 0x2);
 			}
-			odm_set_mac_reg(p_dm, 0x44, BIT(10), codeword); /*GPIO[2] output value*/
-		}	
+			odm_set_mac_reg(dm, R_0x44, BIT(10), codeword);
+				/*@GPIO[2] output value*/
+		}
 	}
 }
 #endif
 
+#ifdef ODM_EVM_ENHANCE_ANTDIV
+void phydm_statistics_evm_1ss(void *dm_void,	void *phy_info_void,
+			      u8 antsel_tr_mux, u32 id, u32 utility)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct phydm_phyinfo_struct *phy_info = NULL;
 
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	if (antsel_tr_mux == ANT1_2G) {
+		fat_tab->main_evm_sum[id] += ((phy_info->rx_mimo_evm_dbm[0])
+					     << 5);
+		fat_tab->main_evm_cnt[id]++;
+	} else {
+		fat_tab->aux_evm_sum[id] += ((phy_info->rx_mimo_evm_dbm[0])
+					    << 5);
+		fat_tab->aux_evm_cnt[id]++;
+	}
+}
 
-#ifdef ODM_EVM_ENHANCE_ANTDIV
-void
-phydm_evm_sw_antdiv_init(
-	void		*p_dm_void
-)
+void phydm_statistics_evm_2ss(void *dm_void,	void *phy_info_void,
+			      u8 antsel_tr_mux, u32 id, u32 utility)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-
-	/*EVM enhance AntDiv method init----------------------------------------------------------------------*/
-	p_dm_fat_table->EVM_method_enable = 0;
-	p_dm_fat_table->fat_state = NORMAL_STATE_MIAN;
-	p_dm_fat_table->fat_state_cnt = 0;
-	p_dm_fat_table->pre_antdiv_rssi = 0;
-
-	p_dm->antdiv_intvl = 30;
-	p_dm->antdiv_train_num = 2;
-	odm_set_bb_reg(p_dm, 0x910, 0x3f, 0xf);
-	p_dm->antdiv_evm_en = 1;
-	/*p_dm->antdiv_period=1;*/
-	p_dm->evm_antdiv_period = 3;
-	p_dm->stop_antdiv_rssi_th = 3;
-	p_dm->stop_antdiv_tp_th = 80;
-	p_dm->antdiv_tp_period = 3;
-	p_dm->stop_antdiv_tp_diff_th = 5;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct phydm_phyinfo_struct *phy_info = NULL;
+
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	if (antsel_tr_mux == ANT1_2G) {
+		fat_tab->main_evm_2ss_sum[id][0] += phy_info->rx_mimo_evm_dbm[0]
+						    << 5;
+		fat_tab->main_evm_2ss_sum[id][1] += phy_info->rx_mimo_evm_dbm[1]
+						    << 5;
+		fat_tab->main_evm_2ss_cnt[id]++;
+
+	} else {
+		fat_tab->aux_evm_2ss_sum[id][0] += (phy_info->rx_mimo_evm_dbm[0]
+						   << 5);
+		fat_tab->aux_evm_2ss_sum[id][1] += (phy_info->rx_mimo_evm_dbm[1]
+						   << 5);
+		fat_tab->aux_evm_2ss_cnt[id]++;
+	}
 }
 
-void
-odm_evm_fast_ant_reset(
-	void		*p_dm_void
-)
+void phydm_evm_sw_antdiv_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-
-	p_dm_fat_table->EVM_method_enable = 0;
-	odm_ant_div_on_off(p_dm, ANTDIV_ON);
-	p_dm_fat_table->fat_state = NORMAL_STATE_MIAN;
-	p_dm_fat_table->fat_state_cnt = 0;
-	p_dm->antdiv_period = 0;
-	odm_set_mac_reg(p_dm, 0x608, BIT(8), 0);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+	/*@EVM enhance AntDiv method init----------------*/
+	fat_tab->evm_method_enable = 0;
+	fat_tab->fat_state = NORMAL_STATE_MIAN;
+	fat_tab->fat_state_cnt = 0;
+	fat_tab->pre_antdiv_rssi = 0;
+
+	dm->antdiv_intvl = 30;
+	dm->antdiv_train_num = 2;
+	odm_set_bb_reg(dm, R_0x910, 0x3f, 0xf);
+	dm->antdiv_evm_en = 1;
+	/*@dm->antdiv_period=1;*/
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	dm->evm_antdiv_period = 1;
+#else
+	dm->evm_antdiv_period = 3;
+#endif
+	dm->stop_antdiv_rssi_th = 3;
+	dm->stop_antdiv_tp_th = 80;
+	dm->antdiv_tp_period = 3;
+	dm->stop_antdiv_tp_diff_th = 5;
 }
 
+void odm_evm_fast_ant_reset(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+	fat_tab->evm_method_enable = 0;
+	if (fat_tab->div_path_type == ANT_PATH_A)
+		odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+	else if (fat_tab->div_path_type == ANT_PATH_B)
+		odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_B);
+	else if (fat_tab->div_path_type == ANT_PATH_AB)
+		odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_AB);
+	fat_tab->fat_state = NORMAL_STATE_MIAN;
+	fat_tab->fat_state_cnt = 0;
+	dm->antdiv_period = 0;
+	odm_set_mac_reg(dm, R_0x608, BIT(8), 0);
+}
 
-void
-odm_evm_enhance_ant_div(
-	void		*p_dm_void
-)
+void odm_evm_enhance_ant_div(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	main_rssi, aux_rssi ;
-	u32	main_crc_utility = 0, aux_crc_utility = 0, utility_ratio = 1;
-	u32	main_evm, aux_evm, diff_rssi = 0, diff_EVM = 0;
-	u32	main_2ss_evm[2], aux_2ss_evm[2];
-	u32	main_1ss_evm, aux_1ss_evm;
-	u32	main_2ss_evm_sum, aux_2ss_evm_sum;
-	u8	score_EVM = 0, score_CRC = 0;
-	u8	rssi_larger_ant = 0;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-	u32	value32, i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 main_rssi, aux_rssi;
+	u32 main_crc_utility = 0, aux_crc_utility = 0, utility_ratio = 1;
+	u32 main_evm, aux_evm, diff_rssi = 0, diff_EVM = 0;
+	u32 main_2ss_evm[2], aux_2ss_evm[2];
+	u32 main_1ss_evm, aux_1ss_evm;
+	u32 main_2ss_evm_sum, aux_2ss_evm_sum;
+	u8 score_EVM = 0, score_CRC = 0;
+	u8 rssi_larger_ant = 0;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u32 value32, i;
 	boolean main_above1 = false, aux_above1 = false;
 	boolean force_antenna = false;
-	struct cmn_sta_info	*p_sta;
-	u32	antdiv_tp_main_avg, antdiv_tp_aux_avg;
-	u8	curr_rssi, rssi_diff;
-	u32	tp_diff;
-	u8	tp_diff_return = 0, tp_return = 0, rssi_return = 0;
-	u8	target_ant_evm_1ss, target_ant_evm_2ss;
-	u8	decision_evm_ss;
-	u8	next_ant;
-
-	p_dm_fat_table->target_ant_enhance = 0xFF;
-
-	if ((p_dm->support_ic_type & ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC)) {
-		if (p_dm->is_one_entry_only) {
-			/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("[One Client only]\n")); */
-			i = p_dm->one_entry_macid;
-			p_sta = p_dm->p_phydm_sta_info[i];
-
-			main_rssi = (p_dm_fat_table->main_ant_cnt[i] != 0) ? (p_dm_fat_table->main_ant_sum[i] / p_dm_fat_table->main_ant_cnt[i]) : 0;
-			aux_rssi = (p_dm_fat_table->aux_ant_cnt[i] != 0) ? (p_dm_fat_table->aux_ant_sum[i] / p_dm_fat_table->aux_ant_cnt[i]) : 0;
+	struct cmn_sta_info *sta;
+	u32 main_tp_avg, aux_tp_avg;
+	u8 curr_rssi, rssi_diff;
+	u32 tp_diff;
+	u8 tp_diff_return = 0, tp_return = 0, rssi_return = 0;
+	u8 target_ant_evm_1ss, target_ant_evm_2ss;
+	u8 decision_evm_ss;
+	u8 next_ant;
+
+	fat_tab->target_ant_enhance = 0xFF;
+
+	if ((dm->support_ic_type & ODM_EVM_ANTDIV_IC)) {
+		if (dm->is_one_entry_only) {
+#if 0
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "[One Client only]\n"); */
+#endif
+			i = dm->one_entry_macid;
+			sta = dm->phydm_sta_info[i];
+
+			main_rssi = (fat_tab->main_cnt[i] != 0) ? (fat_tab->main_sum[i] / fat_tab->main_cnt[i]) : 0;
+			aux_rssi = (fat_tab->aux_cnt[i] != 0) ? (fat_tab->aux_sum[i] / fat_tab->aux_cnt[i]) : 0;
 
 			if ((main_rssi == 0 && aux_rssi != 0 && aux_rssi >= FORCE_RSSI_DIFF) || (main_rssi != 0 && aux_rssi == 0 && main_rssi >= FORCE_RSSI_DIFF))
 				diff_rssi = FORCE_RSSI_DIFF;
@@ -1904,139 +2436,145 @@ odm_evm_enhance_ant_div(
 			else
 				rssi_larger_ant = AUX_ANT;
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Main_Cnt=(( %d )), main_rssi=(( %d ))\n", p_dm_fat_table->main_ant_cnt[i], main_rssi));
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Aux_Cnt=(( %d )), aux_rssi=(( %d ))\n", p_dm_fat_table->aux_ant_cnt[i], aux_rssi));
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Main_Cnt=(( %d )), main_rssi=(( %d ))\n",
+				  fat_tab->main_cnt[i], main_rssi);
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Aux_Cnt=(( %d )), aux_rssi=(( %d ))\n",
+				  fat_tab->aux_cnt[i], aux_rssi);
 
-			if (((main_rssi >= evm_rssi_th_high || aux_rssi >= evm_rssi_th_high) || (p_dm_fat_table->EVM_method_enable == 1))
-			/* && (diff_rssi <= FORCE_RSSI_DIFF + 1) */
-			) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("> TH_H || EVM_method_enable==1\n"));
+			if (((main_rssi >= evm_rssi_th_high || aux_rssi >= evm_rssi_th_high) || fat_tab->evm_method_enable == 1)
+			    /* @&& (diff_rssi <= FORCE_RSSI_DIFF + 1) */
+			    ) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "> TH_H || evm_method_enable==1\n");
 
-				if (((main_rssi >= evm_rssi_th_low) || (aux_rssi >= evm_rssi_th_low))) {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("> TH_L, fat_state_cnt =((%d))\n", p_dm_fat_table->fat_state_cnt));
+				if ((main_rssi >= evm_rssi_th_low || aux_rssi >= evm_rssi_th_low)) {
+					PHYDM_DBG(dm, DBG_ANT_DIV, "> TH_L, fat_state_cnt =((%d))\n", fat_tab->fat_state_cnt);
 
 					/*Traning state: 0(alt) 1(ori) 2(alt) 3(ori)============================================================*/
-					if (p_dm_fat_table->fat_state_cnt < ((p_dm->antdiv_train_num)<<1)) {
-
-						if (p_dm_fat_table->fat_state_cnt == 0) {
+					if (fat_tab->fat_state_cnt < (dm->antdiv_train_num << 1)) {
+						if (fat_tab->fat_state_cnt == 0) {
 							/*Reset EVM 1SS Method */
-							p_dm_fat_table->main_ant_evm_sum[i] = 0;
-							p_dm_fat_table->aux_ant_evm_sum[i] = 0;
-							p_dm_fat_table->main_ant_evm_cnt[i] = 0;
-							p_dm_fat_table->aux_ant_evm_cnt[i] = 0;
+							fat_tab->main_evm_sum[i] = 0;
+							fat_tab->aux_evm_sum[i] = 0;
+							fat_tab->main_evm_cnt[i] = 0;
+							fat_tab->aux_evm_cnt[i] = 0;
 							/*Reset EVM 2SS Method */
-							p_dm_fat_table->main_ant_evm_2ss_sum[i][0] = 0;
-							p_dm_fat_table->main_ant_evm_2ss_sum[i][1] = 0;
-							p_dm_fat_table->aux_ant_evm_2ss_sum[i][0] = 0;
-							p_dm_fat_table->aux_ant_evm_2ss_sum[i][1] = 0;
-							p_dm_fat_table->main_ant_evm_2ss_cnt[i] = 0;
-							p_dm_fat_table->aux_ant_evm_2ss_cnt[i] = 0;
-							#if 0
+							fat_tab->main_evm_2ss_sum[i][0] = 0;
+							fat_tab->main_evm_2ss_sum[i][1] = 0;
+							fat_tab->aux_evm_2ss_sum[i][0] = 0;
+							fat_tab->aux_evm_2ss_sum[i][1] = 0;
+							fat_tab->main_evm_2ss_cnt[i] = 0;
+							fat_tab->aux_evm_2ss_cnt[i] = 0;
+#if 0
 							/*Reset TP Method */
-							p_dm_fat_table->antdiv_tp_main = 0;
-							p_dm_fat_table->antdiv_tp_aux = 0;
-							p_dm_fat_table->antdiv_tp_main_cnt = 0;
-							p_dm_fat_table->antdiv_tp_aux_cnt = 0;
-							#endif
+							fat_tab->main_tp = 0;
+							fat_tab->aux_tp = 0;
+							fat_tab->main_tp_cnt = 0;
+							fat_tab->aux_tp_cnt = 0;
+#endif
 							/*Reset CRC Method */
-							p_dm_fat_table->main_crc32_ok_cnt = 0;
-							p_dm_fat_table->main_crc32_fail_cnt = 0;
-							p_dm_fat_table->aux_crc32_ok_cnt = 0;
-							p_dm_fat_table->aux_crc32_fail_cnt = 0;
-
-							#ifdef SKIP_EVM_ANTDIV_TRAINING_PATCH
-							if ((*p_dm->p_band_width == CHANNEL_WIDTH_20) && (p_sta->mimo_type == RF_2T2R)) {
-								/*1. Skip training: RSSI*/
-								/*PHYDM_DBG(pDM_Odm,DBG_ANT_DIV, ("TargetAnt_enhance=((%d)), RxIdleAnt=((%d))\n", pDM_FatTable->TargetAnt_enhance, pDM_FatTable->RxIdleAnt));*/
-								curr_rssi = (u8)((p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? main_rssi : aux_rssi);
-								rssi_diff = (curr_rssi > p_dm_fat_table->pre_antdiv_rssi) ? (curr_rssi - p_dm_fat_table->pre_antdiv_rssi) : (p_dm_fat_table->pre_antdiv_rssi - curr_rssi);
-
-								PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[1] rssi_return, curr_rssi=((%d)), pre_rssi=((%d))\n", curr_rssi, p_dm_fat_table->pre_antdiv_rssi));
-
-								p_dm_fat_table->pre_antdiv_rssi = curr_rssi;
-								if ((rssi_diff < (p_dm->stop_antdiv_rssi_th)) && (curr_rssi != 0))
+							fat_tab->main_crc32_ok_cnt = 0;
+							fat_tab->main_crc32_fail_cnt = 0;
+							fat_tab->aux_crc32_ok_cnt = 0;
+							fat_tab->aux_crc32_fail_cnt = 0;
+
+#ifdef SKIP_EVM_ANTDIV_TRAINING_PATCH
+							if ((*dm->band_width == CHANNEL_WIDTH_20) && sta->mimo_type == RF_2T2R) {
+								/*@1. Skip training: RSSI*/
+#if 0
+								/*PHYDM_DBG(pDM_Odm,DBG_ANT_DIV, "TargetAnt_enhance=((%d)), RxIdleAnt=((%d))\n", pDM_FatTable->TargetAnt_enhance, pDM_FatTable->RxIdleAnt);*/
+#endif
+								curr_rssi = (u8)((fat_tab->rx_idle_ant == MAIN_ANT) ? main_rssi : aux_rssi);
+								rssi_diff = (curr_rssi > fat_tab->pre_antdiv_rssi) ? (curr_rssi - fat_tab->pre_antdiv_rssi) : (fat_tab->pre_antdiv_rssi - curr_rssi);
+
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[1] rssi_return, curr_rssi=((%d)), pre_rssi=((%d))\n", curr_rssi, fat_tab->pre_antdiv_rssi);
+
+								fat_tab->pre_antdiv_rssi = curr_rssi;
+								if (rssi_diff < dm->stop_antdiv_rssi_th && curr_rssi != 0)
 									rssi_return = 1;
 
-								/*2. Skip training: TP Diff*/
-								tp_diff = (p_dm->rx_tp > p_dm_fat_table->pre_antdiv_tp) ? (p_dm->rx_tp  - p_dm_fat_table->pre_antdiv_tp) : (p_dm_fat_table->pre_antdiv_tp - p_dm->rx_tp);
+								/*@2. Skip training: TP Diff*/
+								tp_diff = (dm->rx_tp > fat_tab->pre_antdiv_tp) ? (dm->rx_tp - fat_tab->pre_antdiv_tp) : (fat_tab->pre_antdiv_tp - dm->rx_tp);
 
-								PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[2] tp_diff_return, curr_tp=((%d)), pre_tp=((%d))\n", p_dm->rx_tp, p_dm_fat_table->pre_antdiv_tp));
-								p_dm_fat_table->pre_antdiv_tp = p_dm->rx_tp;
-								if ((tp_diff < (u32)(p_dm->stop_antdiv_tp_diff_th)  && (p_dm->rx_tp != 0)))
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[2] tp_diff_return, curr_tp=((%d)), pre_tp=((%d))\n", dm->rx_tp, fat_tab->pre_antdiv_tp);
+								fat_tab->pre_antdiv_tp = dm->rx_tp;
+								if ((tp_diff < (u32)(dm->stop_antdiv_tp_diff_th) && dm->rx_tp != 0))
 									tp_diff_return = 1;
 
-								PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[3] tp_return, curr_rx_tp=((%d))\n", p_dm->rx_tp));
-								/*3. Skip training: TP*/
-								if (p_dm->rx_tp >= (u32)(p_dm->stop_antdiv_tp_th))
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[3] tp_return, curr_rx_tp=((%d))\n", dm->rx_tp);
+								/*@3. Skip training: TP*/
+								if (dm->rx_tp >= (u32)(dm->stop_antdiv_tp_th))
 									tp_return = 1;
 
-								PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[4] Return {rssi, tp_diff, tp} = {%d, %d, %d}\n", rssi_return, tp_diff_return, tp_return));
-								/*4. Joint Return Decision*/
+								PHYDM_DBG(dm, DBG_ANT_DIV, "[4] Return {rssi, tp_diff, tp} = {%d, %d, %d}\n", rssi_return, tp_diff_return, tp_return);
+								/*@4. Joint Return Decision*/
 								if (tp_return) {
 									if (tp_diff_return || rssi_diff) {
-
-										PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***Return EVM SW AntDiv\n"));
+										PHYDM_DBG(dm, DBG_ANT_DIV, "***Return EVM SW AntDiv\n");
 										return;
 									}
 								}
 							}
-							#endif
-
-							p_dm_fat_table->EVM_method_enable = 1;
-							odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-							p_dm->antdiv_period = p_dm->evm_antdiv_period;
-							odm_set_mac_reg(p_dm, 0x608, BIT(8), 1); /*RCR accepts CRC32-Error packets*/
+#endif
 
+							fat_tab->evm_method_enable = 1;
+							if (fat_tab->div_path_type == ANT_PATH_A)
+								odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+							else if (fat_tab->div_path_type == ANT_PATH_B)
+								odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_B);
+							else if (fat_tab->div_path_type == ANT_PATH_AB)
+								odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_AB);
+							dm->antdiv_period = dm->evm_antdiv_period;
+							odm_set_mac_reg(dm, R_0x608, BIT(8), 1); /*RCR accepts CRC32-Error packets*/
 						}
 
-
-					p_dm_fat_table->fat_state_cnt++;
-					next_ant = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
-					odm_update_rx_idle_ant(p_dm, next_ant);
-					odm_set_timer(p_dm, &p_dm->evm_fast_ant_training_timer, p_dm->antdiv_intvl); //ms
-
+						fat_tab->fat_state_cnt++;
+						next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+						odm_update_rx_idle_ant(dm, next_ant);
+						odm_set_timer(dm, &dm->evm_fast_ant_training_timer, dm->antdiv_intvl); //ms
 					}
-					/*Decision state: 4==============================================================*/
+					/*@Decision state: 4==============================================================*/
 					else {
+						fat_tab->fat_state_cnt = 0;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "[Decisoin state ]\n");
 
-						p_dm_fat_table->fat_state_cnt = 0;
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Decisoin state ]\n"));
-
-						/* 3 [CRC32 statistic] */
-						#if 0
-						if ((p_dm_fat_table->main_crc32_ok_cnt > ((p_dm_fat_table->aux_crc32_ok_cnt) << 1)) || ((diff_rssi >= 40) && (rssi_larger_ant == MAIN_ANT))) {
-							p_dm_fat_table->target_ant_crc32 = MAIN_ANT;
+/* @3 [CRC32 statistic] */
+#if 0
+						if ((fat_tab->main_crc32_ok_cnt > (fat_tab->aux_crc32_ok_cnt << 1)) || (diff_rssi >= 40 && rssi_larger_ant == MAIN_ANT)) {
+							fat_tab->target_ant_crc32 = MAIN_ANT;
 							force_antenna = true;
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("CRC32 Force Main\n"));
-						} else if ((p_dm_fat_table->aux_crc32_ok_cnt > ((p_dm_fat_table->main_crc32_ok_cnt) << 1)) || ((diff_rssi >= 40) && (rssi_larger_ant == AUX_ANT))) {
-							p_dm_fat_table->target_ant_crc32 = AUX_ANT;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "CRC32 Force Main\n");
+						} else if ((fat_tab->aux_crc32_ok_cnt > ((fat_tab->main_crc32_ok_cnt) << 1)) || ((diff_rssi >= 40) && (rssi_larger_ant == AUX_ANT))) {
+							fat_tab->target_ant_crc32 = AUX_ANT;
 							force_antenna = true;
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("CRC32 Force Aux\n"));
+							PHYDM_DBG(dm, DBG_ANT_DIV, "CRC32 Force Aux\n");
 						} else
-						#endif
+#endif
 						{
-							if (p_dm_fat_table->main_crc32_fail_cnt <= 5)
-								p_dm_fat_table->main_crc32_fail_cnt = 5;
+							if (fat_tab->main_crc32_fail_cnt <= 5)
+								fat_tab->main_crc32_fail_cnt = 5;
 
-							if (p_dm_fat_table->aux_crc32_fail_cnt <= 5)
-								p_dm_fat_table->aux_crc32_fail_cnt = 5;
+							if (fat_tab->aux_crc32_fail_cnt <= 5)
+								fat_tab->aux_crc32_fail_cnt = 5;
 
-							if (p_dm_fat_table->main_crc32_ok_cnt > p_dm_fat_table->main_crc32_fail_cnt)
+							if (fat_tab->main_crc32_ok_cnt > fat_tab->main_crc32_fail_cnt)
 								main_above1 = true;
 
-							if (p_dm_fat_table->aux_crc32_ok_cnt > p_dm_fat_table->aux_crc32_fail_cnt)
+							if (fat_tab->aux_crc32_ok_cnt > fat_tab->aux_crc32_fail_cnt)
 								aux_above1 = true;
 
 							if (main_above1 == true && aux_above1 == false) {
 								force_antenna = true;
-								p_dm_fat_table->target_ant_crc32 = MAIN_ANT;
+								fat_tab->target_ant_crc32 = MAIN_ANT;
 							} else if (main_above1 == false && aux_above1 == true) {
 								force_antenna = true;
-								p_dm_fat_table->target_ant_crc32 = AUX_ANT;
+								fat_tab->target_ant_crc32 = AUX_ANT;
 							} else if (main_above1 == true && aux_above1 == true) {
-								main_crc_utility = ((p_dm_fat_table->main_crc32_ok_cnt) << 7) / p_dm_fat_table->main_crc32_fail_cnt;
-								aux_crc_utility = ((p_dm_fat_table->aux_crc32_ok_cnt) << 7) / p_dm_fat_table->aux_crc32_fail_cnt;
-								p_dm_fat_table->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (p_dm_fat_table->pre_target_ant_enhance) : ((main_crc_utility >= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
+								main_crc_utility = ((fat_tab->main_crc32_ok_cnt) << 7) / fat_tab->main_crc32_fail_cnt;
+								aux_crc_utility = ((fat_tab->aux_crc32_ok_cnt) << 7) / fat_tab->aux_crc32_fail_cnt;
+								fat_tab->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (fat_tab->pre_target_ant_enhance) : ((main_crc_utility >= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
 
 								if (main_crc_utility != 0 && aux_crc_utility != 0) {
 									if (main_crc_utility >= aux_crc_utility)
@@ -2045,14 +2583,14 @@ odm_evm_enhance_ant_div(
 										utility_ratio = (aux_crc_utility << 1) / main_crc_utility;
 								}
 							} else if (main_above1 == false && aux_above1 == false) {
-								if (p_dm_fat_table->main_crc32_ok_cnt == 0)
-									p_dm_fat_table->main_crc32_ok_cnt = 1;
-								if (p_dm_fat_table->aux_crc32_ok_cnt == 0)
-									p_dm_fat_table->aux_crc32_ok_cnt = 1;
+								if (fat_tab->main_crc32_ok_cnt == 0)
+									fat_tab->main_crc32_ok_cnt = 1;
+								if (fat_tab->aux_crc32_ok_cnt == 0)
+									fat_tab->aux_crc32_ok_cnt = 1;
 
-								main_crc_utility = ((p_dm_fat_table->main_crc32_fail_cnt) << 7) / p_dm_fat_table->main_crc32_ok_cnt;
-								aux_crc_utility = ((p_dm_fat_table->aux_crc32_fail_cnt) << 7) / p_dm_fat_table->aux_crc32_ok_cnt;
-								p_dm_fat_table->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (p_dm_fat_table->pre_target_ant_enhance) : ((main_crc_utility <= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
+								main_crc_utility = ((fat_tab->main_crc32_fail_cnt) << 7) / fat_tab->main_crc32_ok_cnt;
+								aux_crc_utility = ((fat_tab->aux_crc32_fail_cnt) << 7) / fat_tab->aux_crc32_ok_cnt;
+								fat_tab->target_ant_crc32 = (main_crc_utility == aux_crc_utility) ? (fat_tab->pre_target_ant_enhance) : ((main_crc_utility <= aux_crc_utility) ? MAIN_ANT : AUX_ANT);
 
 								if (main_crc_utility != 0 && aux_crc_utility != 0) {
 									if (main_crc_utility >= aux_crc_utility)
@@ -2062,46 +2600,46 @@ odm_evm_enhance_ant_div(
 								}
 							}
 						}
-						odm_set_mac_reg(p_dm, 0x608, BIT(8), 0);/* NOT Accept CRC32 Error packets. */
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("MAIN_CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", p_dm_fat_table->main_crc32_ok_cnt, p_dm_fat_table->main_crc32_fail_cnt, main_crc_utility));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("AUX__CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", p_dm_fat_table->aux_crc32_ok_cnt, p_dm_fat_table->aux_crc32_fail_cnt, aux_crc_utility));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***1.TargetAnt_CRC32 = ((%s))\n", (p_dm_fat_table->target_ant_crc32 == MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-
-						/* 3 [EVM statistic] */
-						/*1SS EVM*/
-						main_1ss_evm = (p_dm_fat_table->main_ant_evm_cnt[i] != 0) ? (p_dm_fat_table->main_ant_evm_sum[i] / p_dm_fat_table->main_ant_evm_cnt[i]) : 0;
-						aux_1ss_evm = (p_dm_fat_table->aux_ant_evm_cnt[i] != 0) ? (p_dm_fat_table->aux_ant_evm_sum[i] / p_dm_fat_table->aux_ant_evm_cnt[i]) : 0;
-						target_ant_evm_1ss = (main_1ss_evm == aux_1ss_evm) ? (p_dm_fat_table->pre_target_ant_enhance) : ((main_1ss_evm >= aux_1ss_evm) ? MAIN_ANT : AUX_ANT);
-
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Cnt = ((%d)), Main1ss_EVM= ((  %d ))\n", p_dm_fat_table->main_ant_evm_cnt[i], main_1ss_evm));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Cnt = ((%d)), Aux_1ss_EVM = ((  %d ))\n", p_dm_fat_table->main_ant_evm_cnt[i], aux_1ss_evm));
-
-						/*2SS EVM*/
-						main_2ss_evm[0] = (p_dm_fat_table->main_ant_evm_2ss_cnt[i] != 0) ? (p_dm_fat_table->main_ant_evm_2ss_sum[i][0] / p_dm_fat_table->main_ant_evm_2ss_cnt[i]) : 0;
-						main_2ss_evm[1] = (p_dm_fat_table->main_ant_evm_2ss_cnt[i] != 0) ? (p_dm_fat_table->main_ant_evm_2ss_sum[i][1] / p_dm_fat_table->main_ant_evm_2ss_cnt[i]) : 0;
+						odm_set_mac_reg(dm, R_0x608, BIT(8), 0); /* NOT Accept CRC32 Error packets. */
+						PHYDM_DBG(dm, DBG_ANT_DIV, "MAIN_CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", fat_tab->main_crc32_ok_cnt, fat_tab->main_crc32_fail_cnt, main_crc_utility);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "AUX__CRC: Ok=((%d)), Fail = ((%d)), Utility = ((%d))\n", fat_tab->aux_crc32_ok_cnt, fat_tab->aux_crc32_fail_cnt, aux_crc_utility);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***1.TargetAnt_CRC32 = ((%s))\n", (fat_tab->target_ant_crc32 == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+						/* @3 [EVM statistic] */
+						/*@1SS EVM*/
+						main_1ss_evm = (fat_tab->main_evm_cnt[i] != 0) ? (fat_tab->main_evm_sum[i] / fat_tab->main_evm_cnt[i]) : 0;
+						aux_1ss_evm = (fat_tab->aux_evm_cnt[i] != 0) ? (fat_tab->aux_evm_sum[i] / fat_tab->aux_evm_cnt[i]) : 0;
+						target_ant_evm_1ss = (main_1ss_evm == aux_1ss_evm) ? (fat_tab->pre_target_ant_enhance) : ((main_1ss_evm >= aux_1ss_evm) ? MAIN_ANT : AUX_ANT);
+
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main1ss_EVM= ((  %d ))\n", fat_tab->main_evm_cnt[i], main_1ss_evm);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_1ss_EVM = ((  %d ))\n", fat_tab->aux_evm_cnt[i], aux_1ss_evm);
+
+						/*@2SS EVM*/
+						main_2ss_evm[0] = (fat_tab->main_evm_2ss_cnt[i] != 0) ? (fat_tab->main_evm_2ss_sum[i][0] / fat_tab->main_evm_2ss_cnt[i]) : 0;
+						main_2ss_evm[1] = (fat_tab->main_evm_2ss_cnt[i] != 0) ? (fat_tab->main_evm_2ss_sum[i][1] / fat_tab->main_evm_2ss_cnt[i]) : 0;
 						main_2ss_evm_sum = main_2ss_evm[0] + main_2ss_evm[1];
 
-						aux_2ss_evm[0] = (p_dm_fat_table->aux_ant_evm_2ss_cnt[i] != 0) ? (p_dm_fat_table->aux_ant_evm_2ss_sum[i][0] / p_dm_fat_table->aux_ant_evm_2ss_cnt[i]) : 0;
-						aux_2ss_evm[1] = (p_dm_fat_table->aux_ant_evm_2ss_cnt[i] != 0) ? (p_dm_fat_table->aux_ant_evm_2ss_sum[i][1] / p_dm_fat_table->aux_ant_evm_2ss_cnt[i]) : 0;
+						aux_2ss_evm[0] = (fat_tab->aux_evm_2ss_cnt[i] != 0) ? (fat_tab->aux_evm_2ss_sum[i][0] / fat_tab->aux_evm_2ss_cnt[i]) : 0;
+						aux_2ss_evm[1] = (fat_tab->aux_evm_2ss_cnt[i] != 0) ? (fat_tab->aux_evm_2ss_sum[i][1] / fat_tab->aux_evm_2ss_cnt[i]) : 0;
 						aux_2ss_evm_sum = aux_2ss_evm[0] + aux_2ss_evm[1];
 
-						target_ant_evm_2ss = (main_2ss_evm_sum == aux_2ss_evm_sum) ? (p_dm_fat_table->pre_target_ant_enhance) : ((main_2ss_evm_sum >= aux_2ss_evm_sum) ? MAIN_ANT : AUX_ANT);
+						target_ant_evm_2ss = (main_2ss_evm_sum == aux_2ss_evm_sum) ? (fat_tab->pre_target_ant_enhance) : ((main_2ss_evm_sum >= aux_2ss_evm_sum) ? MAIN_ANT : AUX_ANT);
 
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Cnt = ((%d)), Main2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
-							p_dm_fat_table->main_ant_evm_2ss_cnt[i], main_2ss_evm[0], main_2ss_evm[1], main_2ss_evm_sum));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Cnt = ((%d)), Aux_2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
-							p_dm_fat_table->aux_ant_evm_2ss_cnt[i], aux_2ss_evm[0], aux_2ss_evm[1], aux_2ss_evm_sum));
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
+							  fat_tab->main_evm_2ss_cnt[i], main_2ss_evm[0], main_2ss_evm[1], main_2ss_evm_sum);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_2ss_EVM{A,B,Sum} = {%d, %d, %d}\n",
+							  fat_tab->aux_evm_2ss_cnt[i], aux_2ss_evm[0], aux_2ss_evm[1], aux_2ss_evm_sum);
 
 						if ((main_2ss_evm_sum + aux_2ss_evm_sum) != 0) {
 							decision_evm_ss = 2;
 							main_evm = main_2ss_evm_sum;
 							aux_evm = aux_2ss_evm_sum;
-							p_dm_fat_table->target_ant_evm = target_ant_evm_2ss;
+							fat_tab->target_ant_evm = target_ant_evm_2ss;
 						} else {
 							decision_evm_ss = 1;
 							main_evm = main_1ss_evm;
 							aux_evm = aux_1ss_evm;
-							p_dm_fat_table->target_ant_evm = target_ant_evm_1ss;
+							fat_tab->target_ant_evm = target_ant_evm_1ss;
 						}
 
 						if ((main_evm == 0 || aux_evm == 0))
@@ -2111,53 +2649,52 @@ odm_evm_enhance_ant_div(
 						else
 							diff_EVM = aux_evm - main_evm;
 
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***2.TargetAnt_EVM((%d-ss)) = ((%s))\n", decision_evm_ss, (p_dm_fat_table->target_ant_evm == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
-
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***2.TargetAnt_EVM((%d-ss)) = ((%s))\n", decision_evm_ss, (fat_tab->target_ant_evm == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
 
 						//3 [TP statistic]
-						antdiv_tp_main_avg = (p_dm_fat_table->antdiv_tp_main_cnt != 0) ? (p_dm_fat_table->antdiv_tp_main / p_dm_fat_table->antdiv_tp_main_cnt) : 0;
-						antdiv_tp_aux_avg = (p_dm_fat_table->antdiv_tp_aux_cnt != 0) ? (p_dm_fat_table->antdiv_tp_aux / p_dm_fat_table->antdiv_tp_aux_cnt) : 0;
-						p_dm_fat_table->target_ant_tp = (antdiv_tp_main_avg == antdiv_tp_aux_avg) ? (p_dm_fat_table->pre_target_ant_enhance) : ((antdiv_tp_main_avg >= antdiv_tp_aux_avg) ? MAIN_ANT : AUX_ANT);
+						main_tp_avg = (fat_tab->main_tp_cnt != 0) ? (fat_tab->main_tp / fat_tab->main_tp_cnt) : 0;
+						aux_tp_avg = (fat_tab->aux_tp_cnt != 0) ? (fat_tab->aux_tp / fat_tab->aux_tp_cnt) : 0;
+						fat_tab->target_ant_tp = (main_tp_avg == aux_tp_avg) ? (fat_tab->pre_target_ant_enhance) : ((main_tp_avg >= aux_tp_avg) ? MAIN_ANT : AUX_ANT);
 
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Cnt = ((%d)), Main_TP = ((%d))\n", p_dm_fat_table->antdiv_tp_main_cnt, antdiv_tp_main_avg));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Cnt = ((%d)), Aux_TP = ((%d))\n", p_dm_fat_table->antdiv_tp_aux_cnt, antdiv_tp_aux_avg));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***3.TargetAnt_TP = ((%s))\n", (p_dm_fat_table->target_ant_tp == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Main_TP = ((%d))\n", fat_tab->main_tp_cnt, main_tp_avg);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Cnt = ((%d)), Aux_TP = ((%d))\n", fat_tab->aux_tp_cnt, aux_tp_avg);
+						PHYDM_DBG(dm, DBG_ANT_DIV, "***3.TargetAnt_TP = ((%s))\n", (fat_tab->target_ant_tp == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
 
 						/*Reset TP Method */
-						p_dm_fat_table->antdiv_tp_main = 0;
-						p_dm_fat_table->antdiv_tp_aux = 0;
-						p_dm_fat_table->antdiv_tp_main_cnt = 0;
-						p_dm_fat_table->antdiv_tp_aux_cnt = 0;
+						fat_tab->main_tp = 0;
+						fat_tab->aux_tp = 0;
+						fat_tab->main_tp_cnt = 0;
+						fat_tab->aux_tp_cnt = 0;
 
-						/* 2 [ Decision state ] */
-						if (p_dm_fat_table->target_ant_evm == p_dm_fat_table->target_ant_crc32) {
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Decision type 1, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM));
+						/* @2 [ Decision state ] */
+						if (fat_tab->target_ant_evm == fat_tab->target_ant_crc32) {
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 1, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
 
 							if ((utility_ratio < 2 && force_antenna == false) && diff_EVM <= 30)
-								p_dm_fat_table->target_ant_enhance = p_dm_fat_table->pre_target_ant_enhance;
+								fat_tab->target_ant_enhance = fat_tab->pre_target_ant_enhance;
 							else
-								p_dm_fat_table->target_ant_enhance = p_dm_fat_table->target_ant_evm;
+								fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
 						}
 						#if 0
 						else if ((diff_EVM <= 50 && (utility_ratio > 4 && force_antenna == false)) || (force_antenna == true)) {
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Decision type 2, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM));
-							p_dm_fat_table->target_ant_enhance = p_dm_fat_table->target_ant_crc32;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 2, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
 						}
 						#endif
 						else if (diff_EVM >= 20) {
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Decision type 3, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM));
-							p_dm_fat_table->target_ant_enhance = p_dm_fat_table->target_ant_evm;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 3, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
 						} else if (utility_ratio >= 6 && force_antenna == false) {
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Decision type 4, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM));
-							p_dm_fat_table->target_ant_enhance = p_dm_fat_table->target_ant_crc32;
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 4, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
+							fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
 						} else {
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Decision type 5, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM));
+							PHYDM_DBG(dm, DBG_ANT_DIV, "Decision type 5, CRC_utility = ((%d)), EVM_diff = ((%d))\n", utility_ratio, diff_EVM);
 
 							if (force_antenna == true)
 								score_CRC = 2;
-							else if (utility_ratio >= 5) /*>2.5*/
+							else if (utility_ratio >= 5) /*@>2.5*/
 								score_CRC = 2;
-							else if (utility_ratio >= 4) /*>2*/
+							else if (utility_ratio >= 4) /*@>2*/
 								score_CRC = 1;
 							else
 								score_CRC = 0;
@@ -2172,2093 +2709,2593 @@ odm_evm_enhance_ant_div(
 								score_EVM = 0;
 
 							if (score_CRC > score_EVM)
-								p_dm_fat_table->target_ant_enhance = p_dm_fat_table->target_ant_crc32;
+								fat_tab->target_ant_enhance = fat_tab->target_ant_crc32;
 							else if (score_CRC < score_EVM)
-								p_dm_fat_table->target_ant_enhance = p_dm_fat_table->target_ant_evm;
+								fat_tab->target_ant_enhance = fat_tab->target_ant_evm;
 							else
-								p_dm_fat_table->target_ant_enhance = p_dm_fat_table->pre_target_ant_enhance;
+								fat_tab->target_ant_enhance = fat_tab->pre_target_ant_enhance;
 						}
-						p_dm_fat_table->pre_target_ant_enhance = p_dm_fat_table->target_ant_enhance;
-
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** 4.TargetAnt_enhance = (( %s ))******\n", (p_dm_fat_table->target_ant_enhance == MAIN_ANT)?"MAIN_ANT":"AUX_ANT"));
-
+						fat_tab->pre_target_ant_enhance = fat_tab->target_ant_enhance;
 
+						PHYDM_DBG(dm, DBG_ANT_DIV, "*** 4.TargetAnt_enhance = (( %s ))******\n", (fat_tab->target_ant_enhance == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
 					}
 				} else { /* RSSI< = evm_rssi_th_low */
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ <TH_L: escape from > TH_L ]\n"));
-					odm_evm_fast_ant_reset(p_dm);
+					PHYDM_DBG(dm, DBG_ANT_DIV, "[ <TH_L: escape from > TH_L ]\n");
+					odm_evm_fast_ant_reset(dm);
 				}
 			} else {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[escape from> TH_H || EVM_method_enable==1]\n"));
-				odm_evm_fast_ant_reset(p_dm);
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[escape from> TH_H || evm_method_enable==1]\n");
+				odm_evm_fast_ant_reset(dm);
 			}
 		} else {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[multi-Client]\n"));
-			odm_evm_fast_ant_reset(p_dm);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[multi-Client]\n");
+			odm_evm_fast_ant_reset(dm);
 		}
 	}
 }
 
-void
-odm_evm_fast_ant_training_callback(
-	void		*p_dm_void
-)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phydm_evm_antdiv_callback(
+	struct phydm_timer_list *timer)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	void *adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+
+	#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	#if USE_WORKITEM
+	odm_schedule_work_item(&dm->phydm_evm_antdiv_workitem);
+	#else
+	{
+		odm_hw_ant_div(dm);
+	}
+	#endif
+	#else
+	odm_schedule_work_item(&dm->phydm_evm_antdiv_workitem);
+	#endif
+}
+
+void phydm_evm_antdiv_workitem_callback(
+	void *context)
+{
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("******AntDiv_Callback******\n"));
-	odm_hw_ant_div(p_dm);
+	odm_hw_ant_div(dm);
 }
-#endif
 
-void
-odm_hw_ant_div(
-	void		*p_dm_void
-)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void phydm_evm_antdiv_callback(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	i, min_max_rssi = 0xFF,  ant_div_max_rssi = 0, max_rssi = 0, local_max_rssi;
-	u32	main_rssi, aux_rssi, mian_cnt, aux_cnt;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-	u8	rx_idle_ant = p_dm_fat_table->rx_idle_ant, target_ant = 7;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct cmn_sta_info	*p_sta;
-
-#if (BEAMFORMING_SUPPORT == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	struct _BF_DIV_COEX_    *p_dm_bdc_table = &p_dm->dm_bdc_table;
-	u32	TH1 = 500000;
-	u32	TH2 = 10000000;
-	u32	ma_rx_temp, degrade_TP_temp, improve_TP_temp;
-	u8	monitor_rssi_threshold = 30;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *padapter = dm->adapter;
 
-	p_dm_bdc_table->BF_pass = true;
-	p_dm_bdc_table->DIV_pass = true;
-	p_dm_bdc_table->is_all_div_sta_idle = true;
-	p_dm_bdc_table->is_all_bf_sta_idle = true;
-	p_dm_bdc_table->num_bf_tar = 0 ;
-	p_dm_bdc_table->num_div_tar = 0;
-	p_dm_bdc_table->num_client = 0;
-#endif
+	if (*dm->is_net_closed)
+		return;
+	if (dm->support_interface == ODM_ITRF_PCIE) {
+		odm_hw_ant_div(dm);
+	} else {
+		/* @Can't do I/O in timer callback*/
+		phydm_run_in_thread_cmd(dm,
+					phydm_evm_antdiv_workitem_callback,
+					padapter);
+	}
+}
+
+void phydm_evm_antdiv_workitem_callback(void *context)
+{
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->odmpriv;
+
+	odm_hw_ant_div(dm);
+}
+
+#else
+void phydm_evm_antdiv_callback(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******AntDiv_Callback******\n");
+	odm_hw_ant_div(dm);
+}
 #endif
 
-	if (!p_dm->is_linked) { /* is_linked==False */
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[No Link!!!]\n"));
+#endif
 
-		if (p_dm_fat_table->is_become_linked == true) {
-			odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-			odm_update_rx_idle_ant(p_dm, MAIN_ANT);
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
-			p_dm->antdiv_period = 0;
+void odm_hw_ant_div(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 i, min_max_rssi = 0xFF, ant_div_max_rssi = 0, max_rssi = 0;
+	u32 main_rssi, aux_rssi, mian_cnt, aux_cnt, local_max_rssi;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u8 rx_idle_ant = fat_tab->rx_idle_ant, target_ant = 7;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct cmn_sta_info *sta;
+
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+	struct _BF_DIV_COEX_ *dm_bdc_table = &dm->dm_bdc_table;
+	u32 TH1 = 500000;
+	u32 TH2 = 10000000;
+	u32 ma_rx_temp, degrade_TP_temp, improve_TP_temp;
+	u8 monitor_rssi_threshold = 30;
+
+	dm_bdc_table->BF_pass = true;
+	dm_bdc_table->DIV_pass = true;
+	dm_bdc_table->is_all_div_sta_idle = true;
+	dm_bdc_table->is_all_bf_sta_idle = true;
+	dm_bdc_table->num_bf_tar = 0;
+	dm_bdc_table->num_div_tar = 0;
+	dm_bdc_table->num_client = 0;
+#endif
+#endif
 
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+	if (!dm->is_linked) { /* @is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			if (fat_tab->div_path_type == ANT_PATH_A)
+				odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+			else if (fat_tab->div_path_type == ANT_PATH_B)
+				odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_B);
+			else if (fat_tab->div_path_type == ANT_PATH_AB)
+				odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_AB);
+			odm_update_rx_idle_ant(dm, MAIN_ANT);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			dm->antdiv_period = 0;
+
+			fat_tab->is_become_linked = dm->is_linked;
 		}
 		return;
 	} else {
-		if (p_dm_fat_table->is_become_linked == false) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Linked !!!]\n"));
-			odm_ant_div_on_off(p_dm, ANTDIV_ON);
-			/*odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_DESC);*/
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
+			if (fat_tab->div_path_type == ANT_PATH_A)
+				odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+			else if (fat_tab->div_path_type == ANT_PATH_B)
+				odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_B);
+			else if (fat_tab->div_path_type == ANT_PATH_AB)
+				odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_AB);
+#if 0
+			/*odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);*/
+#endif
 
-			/* if(p_dm->support_ic_type == ODM_RTL8821 ) */
-			/* odm_set_bb_reg(p_dm, 0x800, BIT(25), 0); */ /* CCK AntDiv function disable */
+#if 0
+			/* @if(dm->support_ic_type == ODM_RTL8821 ) */
+			/* odm_set_bb_reg(dm, R_0x800, BIT(25), 0); */
+			/* CCK AntDiv function disable */
+#endif
 
-			/* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
-			/* else if(p_dm->support_ic_type == ODM_RTL8881A) */
-			/* odm_set_bb_reg(p_dm, 0x800, BIT(25), 0); */ /* CCK AntDiv function disable */
-			/* #endif */
+#if 0
+			/* @#if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+			/* @else if(dm->support_ic_type == ODM_RTL8881A) */
+			/* odm_set_bb_reg(dm, R_0x800, BIT(25), 0); */
+			/* CCK AntDiv function disable */
+			/* @#endif */
+#endif
 
-			/* else if(p_dm->support_ic_type == ODM_RTL8723B ||p_dm->support_ic_type == ODM_RTL8812) */
-			/* odm_set_bb_reg(p_dm, 0xA00, BIT(15), 0); */ /* CCK AntDiv function disable */
+#if 0
+			/* @else if(dm->support_ic_type == ODM_RTL8723B ||*/
+			/* @dm->support_ic_type == ODM_RTL8812) */
+			/* odm_set_bb_reg(dm, R_0xa00, BIT(15), 0); */
+			/* CCK AntDiv function disable */
+#endif
 
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+			fat_tab->is_become_linked = dm->is_linked;
 
-			if (p_dm->support_ic_type == ODM_RTL8723B && p_dm->ant_div_type == CG_TRX_HW_ANTDIV) {
-				odm_set_bb_reg(p_dm, 0x930, 0xF0, 8); /* DPDT_P = ANTSEL[0]   */ /* for 8723B AntDiv function patch.  BB  Dino  130412 */
-				odm_set_bb_reg(p_dm, 0x930, 0xF, 8); /* DPDT_N = ANTSEL[0] */
+			if (dm->support_ic_type == ODM_RTL8723B &&
+			    dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+				odm_set_bb_reg(dm, R_0x930, 0xF0, 8);
+				/* @DPDT_P = ANTSEL[0] for 8723B AntDiv */
+				/* @ function patch. BB  Dino 130412 */
+				odm_set_bb_reg(dm, R_0x930, 0xF, 8);
+				/* @DPDT_N = ANTSEL[0] */
 			}
 
-			/* 2 BDC Init */
-#if (BEAMFORMING_SUPPORT == 1)
+/* @2 BDC Init */
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-			odm_bdc_init(p_dm);
+			odm_bdc_init(dm);
 #endif
 #endif
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-			odm_evm_fast_ant_reset(p_dm);
+			odm_evm_fast_ant_reset(dm);
 #endif
 		}
 	}
 
-	if (*(p_dm_fat_table->p_force_tx_ant_by_desc) == false) {
-		if (p_dm->is_one_entry_only == true)
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
+	if (!(*fat_tab->p_force_tx_by_desc)) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
 		else
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_DESC);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
 	}
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-	if (p_dm->antdiv_evm_en == 1) {
-		odm_evm_enhance_ant_div(p_dm);
-		if (p_dm_fat_table->fat_state_cnt != 0)
+	if (dm->antdiv_evm_en == 1) {
+		odm_evm_enhance_ant_div(dm);
+		if (fat_tab->fat_state_cnt != 0)
 			return;
 	} else
-		odm_evm_fast_ant_reset(p_dm);
+		odm_evm_fast_ant_reset(dm);
 #endif
 
-	/* 2 BDC mode Arbitration */
-#if (BEAMFORMING_SUPPORT == 1)
+/* @2 BDC mode Arbitration */
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if (p_dm->antdiv_evm_en == 0 || p_dm_fat_table->EVM_method_enable == 0)
-		odm_bf_ant_div_mode_arbitration(p_dm);
+	if (dm->antdiv_evm_en == 0 || fat_tab->evm_method_enable == 0)
+		odm_bf_ant_div_mode_arbitration(dm);
 #endif
 #endif
 
 	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		p_sta = p_dm->p_phydm_sta_info[i];
-		if (is_sta_active(p_sta)) {
-			/* 2 Caculate RSSI per Antenna */
-			if ((p_dm_fat_table->main_ant_cnt[i] != 0) || (p_dm_fat_table->aux_ant_cnt[i] != 0)) {
-				mian_cnt = p_dm_fat_table->main_ant_cnt[i];
-				aux_cnt = p_dm_fat_table->aux_ant_cnt[i];
-				main_rssi = (mian_cnt != 0) ? (p_dm_fat_table->main_ant_sum[i] / mian_cnt) : 0;
-				aux_rssi = (aux_cnt != 0) ? (p_dm_fat_table->aux_ant_sum[i] / aux_cnt) : 0;
-				target_ant = (mian_cnt == aux_cnt) ? p_dm_fat_table->rx_idle_ant : ((mian_cnt >= aux_cnt) ? MAIN_ANT : AUX_ANT); /*Use counter number for OFDM*/
-
-			} else {	/*CCK only case*/
-				mian_cnt = p_dm_fat_table->main_ant_cnt_cck[i];
-				aux_cnt = p_dm_fat_table->aux_ant_cnt_cck[i];
-				main_rssi = (mian_cnt != 0) ? (p_dm_fat_table->main_ant_sum_cck[i] / mian_cnt) : 0;
-				aux_rssi = (aux_cnt != 0) ? (p_dm_fat_table->aux_ant_sum_cck[i] / aux_cnt) : 0;
-				target_ant = (main_rssi == aux_rssi) ? p_dm_fat_table->rx_idle_ant : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT); /*Use RSSI for CCK only case*/
-			}
+		sta = dm->phydm_sta_info[i];
+		if (!is_sta_active(sta)) {
+			phydm_antdiv_reset_statistic(dm, i);
+			continue;
+		}
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** Client[ %d ] : Main_Cnt = (( %d ))  ,  CCK_Main_Cnt = (( %d )) ,  main_rssi= ((  %d ))\n", i, p_dm_fat_table->main_ant_cnt[i], p_dm_fat_table->main_ant_cnt_cck[i], main_rssi));
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** Client[ %d ] : Aux_Cnt   = (( %d ))  , CCK_Aux_Cnt   = (( %d )) ,  aux_rssi = ((  %d ))\n", i, p_dm_fat_table->aux_ant_cnt[i], p_dm_fat_table->aux_ant_cnt_cck[i], aux_rssi));
-			/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("*** MAC ID:[ %d ] , target_ant = (( %s ))\n", i ,( target_ant ==MAIN_ANT)?"MAIN_ANT":"AUX_ANT")); */
-
-			local_max_rssi = (main_rssi > aux_rssi) ? main_rssi : aux_rssi;
-			/* 2 Select max_rssi for DIG */
-			if ((local_max_rssi > ant_div_max_rssi) && (local_max_rssi < 40))
-				ant_div_max_rssi = local_max_rssi;
-			if (local_max_rssi > max_rssi)
-				max_rssi = local_max_rssi;
-
-			/* 2 Select RX Idle Antenna */
-			if ((local_max_rssi != 0) && (local_max_rssi < min_max_rssi)) {
-				rx_idle_ant = target_ant;
-				min_max_rssi = local_max_rssi;
-			}
+		/* @2 Caculate RSSI per Antenna */
+		if (fat_tab->main_cnt[i] != 0 || fat_tab->aux_cnt[i] != 0) {
+			mian_cnt = fat_tab->main_cnt[i];
+			aux_cnt = fat_tab->aux_cnt[i];
+			main_rssi = (mian_cnt != 0) ?
+				    (fat_tab->main_sum[i] / mian_cnt) : 0;
+			aux_rssi = (aux_cnt != 0) ?
+				   (fat_tab->aux_sum[i] / aux_cnt) : 0;
+			target_ant = (mian_cnt == aux_cnt) ?
+				     fat_tab->rx_idle_ant :
+				     ((mian_cnt >= aux_cnt) ?
+				     MAIN_ANT : AUX_ANT);
+				     /*Use counter number for OFDM*/
+
+		} else { /*@CCK only case*/
+			mian_cnt = fat_tab->main_cnt_cck[i];
+			aux_cnt = fat_tab->aux_cnt_cck[i];
+			main_rssi = (mian_cnt != 0) ?
+				    (fat_tab->main_sum_cck[i] / mian_cnt) : 0;
+			aux_rssi = (aux_cnt != 0) ?
+				   (fat_tab->aux_sum_cck[i] / aux_cnt) : 0;
+			target_ant = (main_rssi == aux_rssi) ?
+				     fat_tab->rx_idle_ant :
+				     ((main_rssi >= aux_rssi) ?
+				     MAIN_ANT : AUX_ANT);
+				     /*Use RSSI for CCK only case*/
+		}
+
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "*** Client[ %d ] : Main_Cnt = (( %d ))  ,  CCK_Main_Cnt = (( %d )) ,  main_rssi= ((  %d ))\n",
+			  i, fat_tab->main_cnt[i],
+			  fat_tab->main_cnt_cck[i], main_rssi);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "*** Client[ %d ] : Aux_Cnt   = (( %d ))  , CCK_Aux_Cnt   = (( %d )) ,  aux_rssi = ((  %d ))\n",
+			  i, fat_tab->aux_cnt[i],
+			  fat_tab->aux_cnt_cck[i], aux_rssi);
+#if 0
+		/* PHYDM_DBG(dm,DBG_ANT_DIV, "*** MAC ID:[ %d ] , target_ant =*/
+		/*( %s )\n", i ,(target_ant==MAIN_ANT)?"MAIN_ANT":"AUX_ANT"); */
+#endif
+
+		local_max_rssi = (main_rssi > aux_rssi) ? main_rssi : aux_rssi;
+		/* @2 Select max_rssi for DIG */
+		if (local_max_rssi > ant_div_max_rssi && local_max_rssi < 40)
+			ant_div_max_rssi = local_max_rssi;
+		if (local_max_rssi > max_rssi)
+			max_rssi = local_max_rssi;
+
+		/* @2 Select RX Idle Antenna */
+		if (local_max_rssi != 0 && local_max_rssi < min_max_rssi) {
+			rx_idle_ant = target_ant;
+			min_max_rssi = local_max_rssi;
+		}
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-			if (p_dm->antdiv_evm_en == 1) {
-				if (p_dm_fat_table->target_ant_enhance != 0xFF) {
-					target_ant = p_dm_fat_table->target_ant_enhance;
-					rx_idle_ant = p_dm_fat_table->target_ant_enhance;
-				}
+		if (dm->antdiv_evm_en == 1) {
+			if (fat_tab->target_ant_enhance != 0xFF) {
+				target_ant = fat_tab->target_ant_enhance;
+				rx_idle_ant = fat_tab->target_ant_enhance;
 			}
+		}
 #endif
 
-			/* 2 Select TX Antenna */
-			if (p_dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
-#if (BEAMFORMING_SUPPORT == 1)
+		/* @2 Select TX Antenna */
+		if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-				if (p_dm_bdc_table->w_bfee_client[i] == 0)
+			if (dm_bdc_table->w_bfee_client[i] == 0)
 #endif
 #endif
-				{
-					odm_update_tx_ant(p_dm, target_ant, i);
-				}
+			{
+				odm_update_tx_ant(dm, target_ant, i);
 			}
+		}
 
-			/* ------------------------------------------------------------ */
+/* @------------------------------------------------------------ */
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-			p_dm_bdc_table->num_client++;
-
-			if (p_dm_bdc_table->bdc_mode == BDC_MODE_2 || p_dm_bdc_table->bdc_mode == BDC_MODE_3) {
-				/* 2 Byte counter */
+		dm_bdc_table->num_client++;
 
-				ma_rx_temp = p_sta->rx_moving_average_tp; /* RX  TP   ( bit /sec) */
+		if (dm_bdc_table->bdc_mode == BDC_MODE_2 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+			/* @2 Byte counter */
 
-				if (p_dm_bdc_table->BDC_state == bdc_bfer_train_state)
-					p_dm_bdc_table->MA_rx_TP_DIV[i] =  ma_rx_temp ;
-				else
-					p_dm_bdc_table->MA_rx_TP[i] = ma_rx_temp ;
+			ma_rx_temp = sta->rx_moving_average_tp; /* RX  TP   ( bit /sec) */
 
-				if ((ma_rx_temp < TH2)   && (ma_rx_temp > TH1) && (local_max_rssi <= monitor_rssi_threshold)) {
-					if (p_dm_bdc_table->w_bfer_client[i] == 1) { /* Bfer_Target */
-						p_dm_bdc_table->num_bf_tar++;
+			if (dm_bdc_table->BDC_state == bdc_bfer_train_state)
+				dm_bdc_table->MA_rx_TP_DIV[i] = ma_rx_temp;
+			else
+				dm_bdc_table->MA_rx_TP[i] = ma_rx_temp;
 
-						if (p_dm_bdc_table->BDC_state == BDC_DECISION_STATE && p_dm_bdc_table->bdc_try_flag == 0) {
-							improve_TP_temp = (p_dm_bdc_table->MA_rx_TP_DIV[i] * 9) >> 3 ; /* * 1.125 */
-							p_dm_bdc_table->BF_pass = (p_dm_bdc_table->MA_rx_TP[i] > improve_TP_temp) ? true : false;
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** Client[ %d ] :  { MA_rx_TP,improve_TP_temp, MA_rx_TP_DIV,  BF_pass}={ %d,  %d, %d , %d }\n", i, p_dm_bdc_table->MA_rx_TP[i], improve_TP_temp, p_dm_bdc_table->MA_rx_TP_DIV[i], p_dm_bdc_table->BF_pass));
-						}
-					} else { /* DIV_Target */
-						p_dm_bdc_table->num_div_tar++;
+			if (ma_rx_temp < TH2 && ma_rx_temp > TH1 && local_max_rssi <= monitor_rssi_threshold) {
+				if (dm_bdc_table->w_bfer_client[i] == 1) { /* @Bfer_Target */
+					dm_bdc_table->num_bf_tar++;
 
-						if (p_dm_bdc_table->BDC_state == BDC_DECISION_STATE && p_dm_bdc_table->bdc_try_flag == 0) {
-							degrade_TP_temp = (p_dm_bdc_table->MA_rx_TP_DIV[i] * 5) >> 3; /* * 0.625 */
-							p_dm_bdc_table->DIV_pass = (p_dm_bdc_table->MA_rx_TP[i] > degrade_TP_temp) ? true : false;
-							PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** Client[ %d ] :  { MA_rx_TP, degrade_TP_temp, MA_rx_TP_DIV,  DIV_pass}=\n{ %d,  %d, %d , %d }\n", i, p_dm_bdc_table->MA_rx_TP[i], degrade_TP_temp, p_dm_bdc_table->MA_rx_TP_DIV[i], p_dm_bdc_table->DIV_pass));
-						}
+					if (dm_bdc_table->BDC_state == BDC_DECISION_STATE && dm_bdc_table->bdc_try_flag == 0) {
+						improve_TP_temp = (dm_bdc_table->MA_rx_TP_DIV[i] * 9) >> 3; /* @* 1.125 */
+						dm_bdc_table->BF_pass = (dm_bdc_table->MA_rx_TP[i] > improve_TP_temp) ? true : false;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { MA_rx_TP,improve_TP_temp, MA_rx_TP_DIV,  BF_pass}={ %d,  %d, %d , %d }\n", i, dm_bdc_table->MA_rx_TP[i], improve_TP_temp, dm_bdc_table->MA_rx_TP_DIV[i], dm_bdc_table->BF_pass);
 					}
-				}
+				} else { /* @DIV_Target */
+					dm_bdc_table->num_div_tar++;
 
-				if (ma_rx_temp > TH1) {
-					if (p_dm_bdc_table->w_bfer_client[i] == 1) /* Bfer_Target */
-						p_dm_bdc_table->is_all_bf_sta_idle = false;
-					else/* DIV_Target */
-						p_dm_bdc_table->is_all_div_sta_idle = false;
+					if (dm_bdc_table->BDC_state == BDC_DECISION_STATE && dm_bdc_table->bdc_try_flag == 0) {
+						degrade_TP_temp = (dm_bdc_table->MA_rx_TP_DIV[i] * 5) >> 3; /* @* 0.625 */
+						dm_bdc_table->DIV_pass = (dm_bdc_table->MA_rx_TP[i] > degrade_TP_temp) ? true : false;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :  { MA_rx_TP, degrade_TP_temp, MA_rx_TP_DIV,  DIV_pass}=\n{ %d,  %d, %d , %d }\n", i, dm_bdc_table->MA_rx_TP[i], degrade_TP_temp, dm_bdc_table->MA_rx_TP_DIV[i], dm_bdc_table->DIV_pass);
+					}
 				}
+			}
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** Client[ %d ] :  { BFmeeCap, BFmerCap}  = { %d , %d }\n", i, p_dm_bdc_table->w_bfee_client[i], p_dm_bdc_table->w_bfer_client[i]));
+			if (ma_rx_temp > TH1) {
+				if (dm_bdc_table->w_bfer_client[i] == 1) /* @Bfer_Target */
+					dm_bdc_table->is_all_bf_sta_idle = false;
+				else /* @DIV_Target */
+					dm_bdc_table->is_all_div_sta_idle = false;
+			}
 
-				if (p_dm_bdc_table->BDC_state == bdc_bfer_train_state)
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** Client[ %d ] :    MA_rx_TP_DIV = (( %d ))\n", i, p_dm_bdc_table->MA_rx_TP_DIV[i]));
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "*** Client[ %d ] :  { BFmeeCap, BFmerCap}  = { %d , %d }\n",
+				  i, dm_bdc_table->w_bfee_client[i],
+				  dm_bdc_table->w_bfer_client[i]);
 
-				else
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** Client[ %d ] :    MA_rx_TP = (( %d ))\n", i, p_dm_bdc_table->MA_rx_TP[i]));
+			if (dm_bdc_table->BDC_state == bdc_bfer_train_state)
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :    MA_rx_TP_DIV = (( %d ))\n", i, dm_bdc_table->MA_rx_TP_DIV[i]);
 
-			}
+			else
+				PHYDM_DBG(dm, DBG_ANT_DIV, "*** Client[ %d ] :    MA_rx_TP = (( %d ))\n", i, dm_bdc_table->MA_rx_TP[i]);
+		}
 #endif
 #endif
 
-		}
-
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-		if (p_dm_bdc_table->bdc_try_flag == 0)
+		if (dm_bdc_table->bdc_try_flag == 0)
 #endif
 #endif
 		{
-			phydm_antdiv_reset_statistic(p_dm, i);
+			phydm_antdiv_reset_statistic(dm, i);
 		}
 	}
 
-
-
-	/* 2 Set RX Idle Antenna & TX Antenna(Because of HW Bug ) */
+/* @2 Set RX Idle Antenna & TX Antenna(Because of HW Bug ) */
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** rx_idle_ant = (( %s ))\n", (rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "*** rx_idle_ant = (( %s ))\n",
+		  (rx_idle_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if (p_dm_bdc_table->bdc_mode == BDC_MODE_1 || p_dm_bdc_table->bdc_mode == BDC_MODE_3) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** bdc_rx_idle_update_counter = (( %d ))\n", p_dm_bdc_table->bdc_rx_idle_update_counter));
-
-		if (p_dm_bdc_table->bdc_rx_idle_update_counter == 1) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***Update RxIdle Antenna!!!\n"));
-			p_dm_bdc_table->bdc_rx_idle_update_counter = 30;
-			odm_update_rx_idle_ant(p_dm, rx_idle_ant);
+	if (dm_bdc_table->bdc_mode == BDC_MODE_1 || dm_bdc_table->bdc_mode == BDC_MODE_3) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "*** bdc_rx_idle_update_counter = (( %d ))\n",
+			  dm_bdc_table->bdc_rx_idle_update_counter);
+
+		if (dm_bdc_table->bdc_rx_idle_update_counter == 1) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "***Update RxIdle Antenna!!!\n");
+			dm_bdc_table->bdc_rx_idle_update_counter = 30;
+			odm_update_rx_idle_ant(dm, rx_idle_ant);
 		} else {
-			p_dm_bdc_table->bdc_rx_idle_update_counter--;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***NOT update RxIdle Antenna because of BF  ( need to fix TX-ant)\n"));
+			dm_bdc_table->bdc_rx_idle_update_counter--;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "***NOT update RxIdle Antenna because of BF  ( need to fix TX-ant)\n");
 		}
 	} else
 #endif
 #endif
-		odm_update_rx_idle_ant(p_dm, rx_idle_ant);
+		odm_update_rx_idle_ant(dm, rx_idle_ant);
 #else
 
-	odm_update_rx_idle_ant(p_dm, rx_idle_ant);
+	odm_update_rx_idle_ant(dm, rx_idle_ant);
 
-#endif/* #if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
+#endif /* @#if(DM_ODM_SUPPORT_TYPE  == ODM_AP) */
 
-
-
-	/* 2 BDC Main Algorithm */
-#if (BEAMFORMING_SUPPORT == 1)
+/* @2 BDC Main Algorithm */
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if (p_dm->antdiv_evm_en == 0 || p_dm_fat_table->EVM_method_enable == 0)
-		odm_bd_ccoex_bfee_rx_div_arbitration(p_dm);
+	if (dm->antdiv_evm_en == 0 || fat_tab->evm_method_enable == 0)
+		odm_bd_ccoex_bfee_rx_div_arbitration(dm);
+
+	dm_bdc_table->num_txbfee_client = 0;
+	dm_bdc_table->num_txbfer_client = 0;
 #endif
 #endif
 
 	if (ant_div_max_rssi == 0)
-		p_dig_t->ant_div_rssi_max = p_dm->rssi_min;
+		dig_t->ant_div_rssi_max = dm->rssi_min;
 	else
-		p_dig_t->ant_div_rssi_max = ant_div_max_rssi;
+		dig_t->ant_div_rssi_max = ant_div_max_rssi;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***AntDiv End***\n\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "***AntDiv End***\n\n");
 }
 
-
-
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
 
-void
-odm_s0s1_sw_ant_div_reset(
-	void		*p_dm_void
-)
+void odm_s0s1_sw_ant_div_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_		*p_dm_swat_table	= &p_dm->dm_swat_table;
-	struct phydm_fat_struct		*p_dm_fat_table		= &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	p_dm_fat_table->is_become_linked  = false;
-	p_dm_swat_table->try_flag = SWAW_STEP_INIT;
-	p_dm_swat_table->double_chk_flag = 0;
+	fat_tab->is_become_linked = false;
+	swat_tab->try_flag = SWAW_STEP_INIT;
+	swat_tab->double_chk_flag = 0;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_s0s1_sw_ant_div_reset(): p_dm_fat_table->is_become_linked = %d\n", p_dm_fat_table->is_become_linked));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "%s: fat_tab->is_become_linked = %d\n",
+		  __func__, fat_tab->is_become_linked);
 }
 
-void
-odm_s0s1_sw_ant_div(
-	void			*p_dm_void,
-	u8			step
-)
+void phydm_sw_antdiv_train_time(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_			*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	u32			i, min_max_rssi = 0xFF, local_max_rssi, local_min_rssi;
-	u32			main_rssi, aux_rssi;
-	u8			high_traffic_train_time_u = 0x32, high_traffic_train_time_l = 0, train_time_temp;
-	u8			low_traffic_train_time_u = 200, low_traffic_train_time_l = 0;
-	u8			rx_idle_ant = p_dm_swat_table->pre_antenna, target_ant, next_ant = 0;
-	struct cmn_sta_info		*p_entry = NULL;
-	u32			value32;
-	u32			main_ant_sum = 0;
-	u32			aux_ant_sum = 0;
-	u32			main_ant_cnt = 0;
-	u32			aux_ant_cnt = 0;
-
-
-	if (!p_dm->is_linked) { /* is_linked==False */
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[No Link!!!]\n"));
-		if (p_dm_fat_table->is_become_linked == true) {
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
-			if (p_dm->support_ic_type == ODM_RTL8723B) {
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Set REG 948[9:6]=0x0\n"));
-				odm_set_bb_reg(p_dm, 0x948, (BIT(9) | BIT(8) | BIT(7) | BIT(6)), 0x0);
-			}
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
-		}
-		return;
-	} else {
-		if (p_dm_fat_table->is_become_linked == false) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Linked !!!]\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	u8 high_traffic_train_time_u = 0x32, high_traffic_train_time_l = 0;
+	u8 low_traffic_train_time_u = 200, low_traffic_train_time_l = 0;
+	u8 train_time_temp;
 
-			if (p_dm->support_ic_type == ODM_RTL8723B) {
-				value32 = odm_get_bb_reg(p_dm, 0x864, BIT(5) | BIT(4) | BIT(3));
+	if (dm->traffic_load == TRAFFIC_HIGH) {
+		train_time_temp = swat_tab->train_time;
 
-#if (RTL8723B_SUPPORT == 1)
-				if (value32 == 0x0)
-					odm_update_rx_idle_ant_8723b(p_dm, MAIN_ANT, ANT1_2G, ANT2_2G);
-				else if (value32 == 0x1)
-					odm_update_rx_idle_ant_8723b(p_dm, AUX_ANT, ANT2_2G, ANT1_2G);
-#endif
+		if (swat_tab->train_time_flag == 3) {
+			high_traffic_train_time_l = 0xa;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("8723B: First link! Force antenna to  %s\n", (value32 == 0x0 ? "MAIN" : "AUX")));
-			}
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+			if (train_time_temp <= 16)
+				train_time_temp = high_traffic_train_time_l;
+			else
+				train_time_temp -= 16;
+
+		} else if (swat_tab->train_time_flag == 2) {
+			train_time_temp -= 8;
+			high_traffic_train_time_l = 0xf;
+		} else if (swat_tab->train_time_flag == 1) {
+			train_time_temp -= 4;
+			high_traffic_train_time_l = 0x1e;
+		} else if (swat_tab->train_time_flag == 0) {
+			train_time_temp += 8;
+			high_traffic_train_time_l = 0x28;
 		}
-	}
-
-	if (*(p_dm_fat_table->p_force_tx_ant_by_desc) == false) {
-		if (p_dm->is_one_entry_only == true)
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
-		else
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_DESC);
-	}
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[%d] { try_flag=(( %d )), step=(( %d )), double_chk_flag = (( %d )) }\n",
-		__LINE__, p_dm_swat_table->try_flag, step, p_dm_swat_table->double_chk_flag));
+		if (dm->support_ic_type == ODM_RTL8188F) {
+			if (dm->support_interface == ODM_ITRF_SDIO)
+				high_traffic_train_time_l += 0xa;
+		}
 
-	/* Handling step mismatch condition. */
-	/* Peak step is not finished at last time. Recover the variable and check again. */
-	if (step != p_dm_swat_table->try_flag) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[step != try_flag]    Need to Reset After Link\n"));
-		odm_sw_ant_div_rest_after_link(p_dm);
-	}
+		/* @-- */
+		if (train_time_temp > high_traffic_train_time_u)
+			train_time_temp = high_traffic_train_time_u;
 
-	if (p_dm_swat_table->try_flag == SWAW_STEP_INIT) {
+		else if (train_time_temp < high_traffic_train_time_l)
+			train_time_temp = high_traffic_train_time_l;
 
-		p_dm_swat_table->try_flag = SWAW_STEP_PEEK;
-		p_dm_swat_table->train_time_flag = 0;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[set try_flag = 0]  Prepare for peek!\n\n"));
-		return;
+		swat_tab->train_time = train_time_temp; /*@10ms~200ms*/
 
-	} else {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "train_time_flag=((%d)), train_time=((%d))\n",
+			  swat_tab->train_time_flag,
+			  swat_tab->train_time);
 
-		/* 1 Normal state (Begin Trying) */
-		if (p_dm_swat_table->try_flag == SWAW_STEP_PEEK) {
+	} else if ((dm->traffic_load == TRAFFIC_MID) ||
+		   (dm->traffic_load == TRAFFIC_LOW)) {
+		train_time_temp = swat_tab->train_time;
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("TxOkCnt=(( %llu )), RxOkCnt=(( %llu )), traffic_load = (%d))\n", p_dm->cur_tx_ok_cnt, p_dm->cur_rx_ok_cnt, p_dm->traffic_load));
-
-			if (p_dm->traffic_load == TRAFFIC_HIGH) {
-				train_time_temp = p_dm_swat_table->train_time ;
-
-				if (p_dm_swat_table->train_time_flag == 3) {
-					high_traffic_train_time_l = 0xa;
+		if (swat_tab->train_time_flag == 3) {
+			low_traffic_train_time_l = 10;
+			if (train_time_temp < 50)
+				train_time_temp = low_traffic_train_time_l;
+			else
+				train_time_temp -= 50;
+		} else if (swat_tab->train_time_flag == 2) {
+			train_time_temp -= 30;
+			low_traffic_train_time_l = 36;
+		} else if (swat_tab->train_time_flag == 1) {
+			train_time_temp -= 10;
+			low_traffic_train_time_l = 40;
+		} else {
+			train_time_temp += 10;
+			low_traffic_train_time_l = 50;
+		}
 
-					if (train_time_temp <= 16)
-						train_time_temp = high_traffic_train_time_l;
-					else
-						train_time_temp -= 16;
-
-				} else if (p_dm_swat_table->train_time_flag == 2) {
-					train_time_temp -= 8;
-					high_traffic_train_time_l = 0xf;
-				} else if (p_dm_swat_table->train_time_flag == 1) {
-					train_time_temp -= 4;
-					high_traffic_train_time_l = 0x1e;
-				} else if (p_dm_swat_table->train_time_flag == 0) {
-					train_time_temp += 8;
-					high_traffic_train_time_l = 0x28;
-				}
-				
-				if (p_dm->support_ic_type == ODM_RTL8188F) {
-					if (p_dm->support_interface == ODM_ITRF_SDIO)
-						high_traffic_train_time_l += 0xa;
-				}
+		if (dm->support_ic_type == ODM_RTL8188F) {
+			if (dm->support_interface == ODM_ITRF_SDIO)
+				low_traffic_train_time_l += 10;
+		}
 
-				/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("*** train_time_temp = ((%d))\n",train_time_temp)); */
+		/* @-- */
+		if (train_time_temp >= low_traffic_train_time_u)
+			train_time_temp = low_traffic_train_time_u;
 
-				/* -- */
-				if (train_time_temp > high_traffic_train_time_u)
-					train_time_temp = high_traffic_train_time_u;
+		else if (train_time_temp <= low_traffic_train_time_l)
+			train_time_temp = low_traffic_train_time_l;
 
-				else if (train_time_temp < high_traffic_train_time_l)
-					train_time_temp = high_traffic_train_time_l;
+		swat_tab->train_time = train_time_temp; /*@10ms~200ms*/
 
-				p_dm_swat_table->train_time = train_time_temp; /*10ms~200ms*/
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "train_time_flag=((%d)) , train_time=((%d))\n",
+			  swat_tab->train_time_flag, swat_tab->train_time);
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("train_time_flag=((%d)), train_time=((%d))\n", p_dm_swat_table->train_time_flag, p_dm_swat_table->train_time));
+	} else {
+		swat_tab->train_time = 0xc8; /*@200ms*/
+	}
+}
 
-			} else if ((p_dm->traffic_load == TRAFFIC_MID) || (p_dm->traffic_load == TRAFFIC_LOW)) {
+void phydm_sw_antdiv_decision(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u32 i, min_max_rssi = 0xFF, local_max_rssi, local_min_rssi;
+	u32 main_rssi, aux_rssi;
+	u8 rx_idle_ant = swat_tab->pre_ant;
+	u8 target_ant = swat_tab->pre_ant, next_ant = 0;
+	struct cmn_sta_info *entry = NULL;
+	u32 main_cnt = 0, aux_cnt = 0, main_sum = 0, aux_sum = 0;
+	u32 main_ctrl_cnt = 0, aux_ctrl_cnt = 0;
+	boolean is_by_ctrl_frame = false;
+	boolean cond_23d_main, cond_23d_aux;
+	u64 pkt_cnt_total = 0;
 
-				train_time_temp = p_dm_swat_table->train_time ;
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		entry = dm->phydm_sta_info[i];
+		if (!is_sta_active(entry)) {
+			phydm_antdiv_reset_statistic(dm, i);
+			continue;
+		}
 
-				if (p_dm_swat_table->train_time_flag == 3) {
-					low_traffic_train_time_l = 10;
-					if (train_time_temp < 50)
-						train_time_temp = low_traffic_train_time_l;
+		/* @2 Caculate RSSI per Antenna */
+		if (fat_tab->main_cnt[i] != 0 || fat_tab->aux_cnt[i] != 0) {
+			main_cnt = (u32)fat_tab->main_cnt[i];
+			aux_cnt = (u32)fat_tab->aux_cnt[i];
+			main_rssi = (main_cnt != 0) ?
+				    (fat_tab->main_sum[i] / main_cnt) : 0;
+			aux_rssi = (aux_cnt != 0) ?
+				   (fat_tab->aux_sum[i] / aux_cnt) : 0;
+			if (dm->support_ic_type == ODM_RTL8723D) {
+				cond_23d_main = (aux_cnt > main_cnt) &&
+						((main_rssi - aux_rssi < 5) ||
+						(aux_rssi > main_rssi));
+				cond_23d_aux = (main_cnt > aux_cnt) &&
+					       ((aux_rssi - main_rssi < 5) ||
+					       (main_rssi > aux_rssi));
+				if (swat_tab->pre_ant == MAIN_ANT) {
+					if (main_cnt == 0)
+						target_ant = (aux_cnt != 0) ?
+							     AUX_ANT :
+							     swat_tab->pre_ant;
 					else
-						train_time_temp -= 50;
-				} else if (p_dm_swat_table->train_time_flag == 2) {
-					train_time_temp -= 30;
-					low_traffic_train_time_l = 36;
-				} else if (p_dm_swat_table->train_time_flag == 1) {
-					train_time_temp -= 10;
-					low_traffic_train_time_l = 40;
+						target_ant = cond_23d_main ?
+							     AUX_ANT :
+							     swat_tab->pre_ant;
 				} else {
-
-					train_time_temp += 10;
-					low_traffic_train_time_l = 50;
-				}
-
-				if (p_dm->support_ic_type == ODM_RTL8188F) {
-					if (p_dm->support_interface == ODM_ITRF_SDIO)
-						low_traffic_train_time_l += 10;
+					if (aux_cnt == 0)
+						target_ant = (main_cnt != 0) ?
+							     MAIN_ANT :
+							     swat_tab->pre_ant;
+					else
+						target_ant = cond_23d_aux ?
+							     MAIN_ANT :
+							     swat_tab->pre_ant;
 				}
-
-				/* -- */
-				if (train_time_temp >= low_traffic_train_time_u)
-					train_time_temp = low_traffic_train_time_u;
-
-				else if (train_time_temp <= low_traffic_train_time_l)
-					train_time_temp = low_traffic_train_time_l;
-
-				p_dm_swat_table->train_time = train_time_temp; /*10ms~200ms*/
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("train_time_flag=((%d)) , train_time=((%d))\n", p_dm_swat_table->train_time_flag, p_dm_swat_table->train_time));
-
 			} else {
-				p_dm_swat_table->train_time = 0xc8; /*200ms*/
-
+				if (swat_tab->pre_ant == MAIN_ANT) {
+					target_ant = (aux_rssi > main_rssi) ?
+						     AUX_ANT :
+						     swat_tab->pre_ant;
+				} else if (swat_tab->pre_ant == AUX_ANT) {
+					target_ant = (main_rssi > aux_rssi) ?
+						     MAIN_ANT :
+						     swat_tab->pre_ant;
+				}
 			}
-
-			/* ----------------- */
-
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Current min_max_rssi is ((%d))\n", p_dm_fat_table->min_max_rssi));
-
-			/* ---reset index--- */
-			if (p_dm_swat_table->reset_idx >= RSSI_CHECK_RESET_PERIOD) {
-
-				p_dm_fat_table->min_max_rssi = 0;
-				p_dm_swat_table->reset_idx = 0;
+		} else { /*@CCK only case*/
+			main_cnt = fat_tab->main_cnt_cck[i];
+			aux_cnt = fat_tab->aux_cnt_cck[i];
+			main_rssi = (main_cnt != 0) ?
+				    (fat_tab->main_sum_cck[i] / main_cnt) : 0;
+			aux_rssi = (aux_cnt != 0) ?
+				   (fat_tab->aux_sum_cck[i] / aux_cnt) : 0;
+			target_ant = (main_rssi == aux_rssi) ?
+				     swat_tab->pre_ant :
+				     ((main_rssi >= aux_rssi) ?
+				     MAIN_ANT : AUX_ANT);
+				     /*Use RSSI for CCK only case*/
+		}
+		local_max_rssi = (main_rssi >= aux_rssi) ? main_rssi : aux_rssi;
+		local_min_rssi = (main_rssi >= aux_rssi) ? aux_rssi : main_rssi;
+
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "***  CCK_counter_main = (( %d ))  , CCK_counter_aux= ((  %d ))\n",
+			  fat_tab->main_cnt_cck[i], fat_tab->aux_cnt_cck[i]);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "***  OFDM_counter_main = (( %d ))  , OFDM_counter_aux= ((  %d ))\n",
+			  fat_tab->main_cnt[i], fat_tab->aux_cnt[i]);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "***  main_Cnt = (( %d ))  , aux_Cnt   = (( %d ))\n",
+			  main_cnt, aux_cnt);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "***  main_rssi= ((  %d )) , aux_rssi = ((  %d ))\n",
+			  main_rssi, aux_rssi);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "*** MAC ID:[ %d ] , target_ant = (( %s ))\n", i,
+			  (target_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
+
+		/* @2 Select RX Idle Antenna */
+
+		if (local_max_rssi != 0 && local_max_rssi < min_max_rssi) {
+			rx_idle_ant = target_ant;
+			min_max_rssi = local_max_rssi;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "*** local_max_rssi-local_min_rssi = ((%d))\n",
+				  (local_max_rssi - local_min_rssi));
+
+			if ((local_max_rssi - local_min_rssi) > 8) {
+				if (local_min_rssi != 0) {
+					swat_tab->train_time_flag = 3;
+				} else {
+					if (min_max_rssi > RSSI_CHECK_THRESHOLD)
+						swat_tab->train_time_flag = 0;
+					else
+						swat_tab->train_time_flag = 3;
+				}
+			} else if ((local_max_rssi - local_min_rssi) > 5) {
+				swat_tab->train_time_flag = 2;
+			} else if ((local_max_rssi - local_min_rssi) > 2) {
+				swat_tab->train_time_flag = 1;
+			} else {
+				swat_tab->train_time_flag = 0;
 			}
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reset_idx = (( %d ))\n", p_dm_swat_table->reset_idx));
+		}
 
-			p_dm_swat_table->reset_idx++;
+		/* @2 Select TX Antenna */
+		if (target_ant == MAIN_ANT)
+			fat_tab->antsel_a[i] = ANT1_2G;
+		else
+			fat_tab->antsel_a[i] = ANT2_2G;
 
-			/* ---double check flag--- */
-			if ((p_dm_fat_table->min_max_rssi > RSSI_CHECK_THRESHOLD) && (p_dm_swat_table->double_chk_flag == 0)) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, (" min_max_rssi is ((%d)), and > %d\n",
-					p_dm_fat_table->min_max_rssi, RSSI_CHECK_THRESHOLD));
+		phydm_antdiv_reset_statistic(dm, i);
+		pkt_cnt_total += (main_cnt + aux_cnt);
+	}
 
-				p_dm_swat_table->double_chk_flag = 1;
-				p_dm_swat_table->try_flag = SWAW_STEP_DETERMINE;
-				p_dm_swat_table->rssi_trying = 0;
+	if (swat_tab->is_sw_ant_div_by_ctrl_frame) {
+		odm_s0s1_sw_ant_div_by_ctrl_frame(dm, SWAW_STEP_DETERMINE);
+		is_by_ctrl_frame = true;
+	}
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Test the current ant for (( %d )) ms again\n", p_dm_swat_table->train_time));
-				odm_update_rx_idle_ant(p_dm, p_dm_fat_table->rx_idle_ant);
-				odm_set_timer(p_dm, &(p_dm_swat_table->phydm_sw_antenna_switch_timer), p_dm_swat_table->train_time); /*ms*/
-				return;
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "Control frame packet counter = %d, data frame packet counter = %llu\n",
+		  swat_tab->pkt_cnt_sw_ant_div_by_ctrl_frame, pkt_cnt_total);
+
+	if (min_max_rssi == 0xff || ((pkt_cnt_total <
+	    (swat_tab->pkt_cnt_sw_ant_div_by_ctrl_frame >> 1)) &&
+	    dm->phy_dbg_info.num_qry_beacon_pkt < 2)) {
+		min_max_rssi = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "Check RSSI of control frame because min_max_rssi == 0xff\n");
+		PHYDM_DBG(dm, DBG_ANT_DIV, "is_by_ctrl_frame = %d\n",
+			  is_by_ctrl_frame);
+
+		if (is_by_ctrl_frame) {
+			main_ctrl_cnt = fat_tab->main_ctrl_cnt;
+			aux_ctrl_cnt = fat_tab->aux_ctrl_cnt;
+			main_rssi = (main_ctrl_cnt != 0) ?
+				    (fat_tab->main_ctrl_sum / main_ctrl_cnt) :
+				    0;
+			aux_rssi = (aux_ctrl_cnt != 0) ?
+				   (fat_tab->aux_ctrl_sum / aux_ctrl_cnt) : 0;
+
+			if (main_ctrl_cnt <= 1 &&
+			    fat_tab->cck_ctrl_frame_cnt_main >= 1)
+				main_rssi = 0;
+
+			if (aux_ctrl_cnt <= 1 &&
+			    fat_tab->cck_ctrl_frame_cnt_aux >= 1)
+				aux_rssi = 0;
+
+			if (main_rssi != 0 || aux_rssi != 0) {
+				rx_idle_ant = (main_rssi == aux_rssi) ?
+					      swat_tab->pre_ant :
+					      ((main_rssi >= aux_rssi) ?
+					      MAIN_ANT : AUX_ANT);
+				local_max_rssi = (main_rssi >= aux_rssi) ?
+						 main_rssi : aux_rssi;
+				local_min_rssi = (main_rssi >= aux_rssi) ?
+						 aux_rssi : main_rssi;
+
+				if ((local_max_rssi - local_min_rssi) > 8)
+					swat_tab->train_time_flag = 3;
+				else if ((local_max_rssi - local_min_rssi) > 5)
+					swat_tab->train_time_flag = 2;
+				else if ((local_max_rssi - local_min_rssi) > 2)
+					swat_tab->train_time_flag = 1;
+				else
+					swat_tab->train_time_flag = 0;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Control frame: main_rssi = %d, aux_rssi = %d\n",
+					  main_rssi, aux_rssi);
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "rx_idle_ant decided by control frame = %s\n",
+					  (rx_idle_ant == MAIN_ANT ?
+					  "MAIN" : "AUX"));
 			}
-
-			next_ant = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
-
-			p_dm_swat_table->try_flag = SWAW_STEP_DETERMINE;
-
-			if (p_dm_swat_table->reset_idx <= 1)
-				p_dm_swat_table->rssi_trying = 2;
-			else
-				p_dm_swat_table->rssi_trying = 1;
-
-			odm_s0s1_sw_ant_div_by_ctrl_frame(p_dm, SWAW_STEP_PEEK);
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[set try_flag=1]  Normal state:  Begin Trying!!\n"));
-
-		} else if ((p_dm_swat_table->try_flag == SWAW_STEP_DETERMINE) && (p_dm_swat_table->double_chk_flag == 0)) {
-
-			next_ant = (p_dm_fat_table->rx_idle_ant  == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
-			p_dm_swat_table->rssi_trying--;
 		}
+	}
 
-		/* 1 Decision state */
-		if ((p_dm_swat_table->try_flag == SWAW_STEP_DETERMINE) && (p_dm_swat_table->rssi_trying == 0)) {
-
-			boolean is_by_ctrl_frame = false;
-			u64	pkt_cnt_total = 0;
-
-			for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-				p_entry = p_dm->p_phydm_sta_info[i];
-				if (is_sta_active(p_entry)) {
-					/* 2 Caculate RSSI per Antenna */
-
-					main_ant_sum = (u32)p_dm_fat_table->main_ant_sum[i] + (u32)p_dm_fat_table->main_ant_sum_cck[i];
-					aux_ant_sum = (u32)p_dm_fat_table->aux_ant_sum[i] + (u32)p_dm_fat_table->aux_ant_sum_cck[i];
-					main_ant_cnt = (u32)p_dm_fat_table->main_ant_cnt[i] + (u32)p_dm_fat_table->main_ant_cnt_cck[i];
-					aux_ant_cnt = (u32)p_dm_fat_table->aux_ant_cnt[i] + (u32)p_dm_fat_table->aux_ant_cnt_cck[i];
-
-					main_rssi = (main_ant_cnt != 0) ? (main_ant_sum / main_ant_cnt) : 0;
-					aux_rssi = (aux_ant_cnt != 0) ? (aux_ant_sum / aux_ant_cnt) : 0;
-
-					if (p_dm_fat_table->main_ant_cnt[i] <= 1 && p_dm_fat_table->main_ant_cnt_cck[i] >= 1)
-						main_rssi = 0;
+	fat_tab->min_max_rssi = min_max_rssi;
+	swat_tab->try_flag = SWAW_STEP_PEEK;
 
-					if (p_dm_fat_table->aux_ant_cnt[i] <= 1 && p_dm_fat_table->aux_ant_cnt_cck[i] >= 1)
-						aux_rssi = 0;
+	if (swat_tab->double_chk_flag == 1) {
+		swat_tab->double_chk_flag = 0;
 
-					target_ant = (main_rssi == aux_rssi) ? p_dm_swat_table->pre_antenna : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT);
-					local_max_rssi = (main_rssi >= aux_rssi) ? main_rssi : aux_rssi;
-					local_min_rssi = (main_rssi >= aux_rssi) ? aux_rssi : main_rssi;
+		if (fat_tab->min_max_rssi > RSSI_CHECK_THRESHOLD) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  " [Double check] min_max_rssi ((%d)) > %d again!!\n",
+				  fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
 
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***  CCK_counter_main = (( %d ))  , CCK_counter_aux= ((  %d ))\n", p_dm_fat_table->main_ant_cnt_cck[i], p_dm_fat_table->aux_ant_cnt_cck[i]));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***  OFDM_counter_main = (( %d ))  , OFDM_counter_aux= ((  %d ))\n", p_dm_fat_table->main_ant_cnt[i], p_dm_fat_table->aux_ant_cnt[i]));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***  Main_Cnt = (( %d ))  , main_rssi= ((  %d ))\n", main_ant_cnt, main_rssi));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***  Aux_Cnt   = (( %d ))  , aux_rssi = ((  %d ))\n", aux_ant_cnt, aux_rssi));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** MAC ID:[ %d ] , target_ant = (( %s ))\n", i, (target_ant == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT"));
+			odm_update_rx_idle_ant(dm, rx_idle_ant);
 
-					/* 2 Select RX Idle Antenna */
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[reset try_flag = 0] Training accomplished !!!]\n\n\n");
+		} else {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  " [Double check] min_max_rssi ((%d)) <= %d !!\n",
+				  fat_tab->min_max_rssi, RSSI_CHECK_THRESHOLD);
+
+			next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ?
+				   AUX_ANT : MAIN_ANT;
+			swat_tab->try_flag = SWAW_STEP_PEEK;
+			swat_tab->reset_idx = RSSI_CHECK_RESET_PERIOD;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[set try_flag=0]  Normal state:  Need to tryg again!!\n\n\n");
+		}
+	} else {
+		if (fat_tab->min_max_rssi < RSSI_CHECK_THRESHOLD)
+			swat_tab->reset_idx = RSSI_CHECK_RESET_PERIOD;
 
-					if (local_max_rssi != 0 && local_max_rssi < min_max_rssi) {
-						rx_idle_ant = target_ant;
-						min_max_rssi = local_max_rssi;
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** local_max_rssi-local_min_rssi = ((%d))\n", (local_max_rssi - local_min_rssi)));
+		swat_tab->pre_ant = rx_idle_ant;
+		odm_update_rx_idle_ant(dm, rx_idle_ant);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[reset try_flag = 0] Training accomplished !!!]\n\n\n");
+	}
+}
 
-						if ((local_max_rssi - local_min_rssi) > 8) {
-							if (local_min_rssi != 0)
-								p_dm_swat_table->train_time_flag = 3;
-							else {
-								if (min_max_rssi > RSSI_CHECK_THRESHOLD)
-									p_dm_swat_table->train_time_flag = 0;
-								else
-									p_dm_swat_table->train_time_flag = 3;
-							}
-						} else if ((local_max_rssi - local_min_rssi) > 5)
-							p_dm_swat_table->train_time_flag = 2;
-						else if ((local_max_rssi - local_min_rssi) > 2)
-							p_dm_swat_table->train_time_flag = 1;
-						else
-							p_dm_swat_table->train_time_flag = 0;
+void odm_s0s1_sw_ant_div(void *dm_void, u8 step)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u32 value32;
+	u8 next_ant = 0;
+
+	if (!dm->is_linked) { /* @is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+		if (fat_tab->is_become_linked == true) {
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			if (dm->support_ic_type == ODM_RTL8723B) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Set REG 948[9:6]=0x0\n");
+				odm_set_bb_reg(dm, R_0x948, 0x3c0, 0x0);
+			}
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+		return;
+	} else {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
 
-					}
+			if (dm->support_ic_type == ODM_RTL8723B) {
+				value32 = odm_get_bb_reg(dm, R_0x864, 0x38);
 
-					/* 2 Select TX Antenna */
-					if (target_ant == MAIN_ANT)
-						p_dm_fat_table->antsel_a[i] = ANT1_2G;
-					else
-						p_dm_fat_table->antsel_a[i] = ANT2_2G;
+#if (RTL8723B_SUPPORT == 1)
+				if (value32 == 0x0)
+					odm_update_rx_idle_ant_8723b(dm,
+								     MAIN_ANT,
+								     ANT1_2G,
+								     ANT2_2G);
+				else if (value32 == 0x1)
+					odm_update_rx_idle_ant_8723b(dm,
+								     AUX_ANT,
+								     ANT2_2G,
+								     ANT1_2G);
+#endif
 
-				}
-				phydm_antdiv_reset_statistic(p_dm, i);
-				pkt_cnt_total += (main_ant_cnt + aux_ant_cnt);
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "8723B: First link! Force antenna to  %s\n",
+					  (value32 == 0x0 ? "MAIN" : "AUX"));
 			}
 
-			if (p_dm_swat_table->is_sw_ant_div_by_ctrl_frame) {
-				odm_s0s1_sw_ant_div_by_ctrl_frame(p_dm, SWAW_STEP_DETERMINE);
-				is_by_ctrl_frame = true;
+			if (dm->support_ic_type == ODM_RTL8723D) {
+				value32 = odm_get_bb_reg(dm, R_0x864, 0x38);
+#if (RTL8723D_SUPPORT == 1)
+				if (value32 == 0x0)
+					odm_update_rx_idle_ant_8723d(dm,
+								     MAIN_ANT,
+								     ANT1_2G,
+								     ANT2_2G);
+				else if (value32 == 0x1)
+					odm_update_rx_idle_ant_8723d(dm,
+								     AUX_ANT,
+								     ANT2_2G,
+								     ANT1_2G);
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "8723D: First link! Force antenna to  %s\n",
+					  (value32 == 0x0 ? "MAIN" : "AUX"));
+#endif
 			}
+			fat_tab->is_become_linked = dm->is_linked;
+		}
+	}
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Control frame packet counter = %d, data frame packet counter = %llu\n",
-				p_dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame, pkt_cnt_total));
-
-			if (min_max_rssi == 0xff || ((pkt_cnt_total < (p_dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame >> 1)) && p_dm->phy_dbg_info.num_qry_beacon_pkt < 2)) {
-				min_max_rssi = 0;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Check RSSI of control frame because min_max_rssi == 0xff\n"));
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("is_by_ctrl_frame = %d\n", is_by_ctrl_frame));
-
-				if (is_by_ctrl_frame) {
-					main_rssi = (p_dm_fat_table->main_ant_ctrl_frame_cnt != 0) ? (p_dm_fat_table->main_ant_ctrl_frame_sum / p_dm_fat_table->main_ant_ctrl_frame_cnt) : 0;
-					aux_rssi = (p_dm_fat_table->aux_ant_ctrl_frame_cnt != 0) ? (p_dm_fat_table->aux_ant_ctrl_frame_sum / p_dm_fat_table->aux_ant_ctrl_frame_cnt) : 0;
-
-					if (p_dm_fat_table->main_ant_ctrl_frame_cnt <= 1 && p_dm_fat_table->cck_ctrl_frame_cnt_main >= 1)
-						main_rssi = 0;
-
-					if (p_dm_fat_table->aux_ant_ctrl_frame_cnt <= 1 && p_dm_fat_table->cck_ctrl_frame_cnt_aux >= 1)
-						aux_rssi = 0;
+	if (!(*fat_tab->p_force_tx_by_desc)) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+		else
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+	}
 
-					if (main_rssi != 0 || aux_rssi != 0) {
-						rx_idle_ant = (main_rssi == aux_rssi) ? p_dm_swat_table->pre_antenna : ((main_rssi >= aux_rssi) ? MAIN_ANT : AUX_ANT);
-						local_max_rssi = (main_rssi >= aux_rssi) ? main_rssi : aux_rssi;
-						local_min_rssi = (main_rssi >= aux_rssi) ? aux_rssi : main_rssi;
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[%d] { try_flag=(( %d )), step=(( %d )), double_chk_flag = (( %d )) }\n",
+		  __LINE__, swat_tab->try_flag, step,
+		  swat_tab->double_chk_flag);
+
+	/* @ Handling step mismatch condition. */
+	/* @ Peak step is not finished at last time. */
+	/* @ Recover the variable and check again. */
+	if (step != swat_tab->try_flag) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[step != try_flag]    Need to Reset After Link\n");
+		odm_sw_ant_div_rest_after_link(dm);
+	}
 
-						if ((local_max_rssi - local_min_rssi) > 8)
-							p_dm_swat_table->train_time_flag = 3;
-						else if ((local_max_rssi - local_min_rssi) > 5)
-							p_dm_swat_table->train_time_flag = 2;
-						else if ((local_max_rssi - local_min_rssi) > 2)
-							p_dm_swat_table->train_time_flag = 1;
-						else
-							p_dm_swat_table->train_time_flag = 0;
+	if (swat_tab->try_flag == SWAW_STEP_INIT) {
+		swat_tab->try_flag = SWAW_STEP_PEEK;
+		swat_tab->train_time_flag = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[set try_flag = 0]  Prepare for peek!\n\n");
+		return;
 
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Control frame: main_rssi = %d, aux_rssi = %d\n", main_rssi, aux_rssi));
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("rx_idle_ant decided by control frame = %s\n", (rx_idle_ant == MAIN_ANT ? "MAIN" : "AUX")));
-					}
-				}
+	} else {
+		/* @1 Normal state (Begin Trying) */
+		if (swat_tab->try_flag == SWAW_STEP_PEEK) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "TxOkCnt=(( %llu )), RxOkCnt=(( %llu )), traffic_load = (%d))\n",
+				  dm->cur_tx_ok_cnt, dm->cur_rx_ok_cnt,
+				  dm->traffic_load);
+			phydm_sw_antdiv_train_time(dm);
+
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Current min_max_rssi is ((%d))\n",
+				  fat_tab->min_max_rssi);
+
+			/* @---reset index--- */
+			if (swat_tab->reset_idx >= RSSI_CHECK_RESET_PERIOD) {
+				fat_tab->min_max_rssi = 0;
+				swat_tab->reset_idx = 0;
+			}
+			PHYDM_DBG(dm, DBG_ANT_DIV, "reset_idx = (( %d ))\n",
+				  swat_tab->reset_idx);
+
+			swat_tab->reset_idx++;
+
+			/* @---double check flag--- */
+			if (fat_tab->min_max_rssi > RSSI_CHECK_THRESHOLD &&
+			    swat_tab->double_chk_flag == 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  " min_max_rssi is ((%d)), and > %d\n",
+					  fat_tab->min_max_rssi,
+					  RSSI_CHECK_THRESHOLD);
+
+				swat_tab->double_chk_flag = 1;
+				swat_tab->try_flag = SWAW_STEP_DETERMINE;
+				swat_tab->rssi_trying = 0;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Test the current ant for (( %d )) ms again\n",
+					  swat_tab->train_time);
+				odm_update_rx_idle_ant(dm,
+						       fat_tab->rx_idle_ant);
+				odm_set_timer(dm, &swat_tab->sw_antdiv_timer,
+					      swat_tab->train_time); /*@ms*/
+				return;
 			}
 
-			p_dm_fat_table->min_max_rssi = min_max_rssi;
-			p_dm_swat_table->try_flag = SWAW_STEP_PEEK;
-
-			if (p_dm_swat_table->double_chk_flag == 1) {
-				p_dm_swat_table->double_chk_flag = 0;
-
-				if (p_dm_fat_table->min_max_rssi > RSSI_CHECK_THRESHOLD) {
-
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, (" [Double check] min_max_rssi ((%d)) > %d again!!\n",
-						p_dm_fat_table->min_max_rssi, RSSI_CHECK_THRESHOLD));
-
-					odm_update_rx_idle_ant(p_dm, rx_idle_ant);
+			next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ?
+				   AUX_ANT : MAIN_ANT;
 
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[reset try_flag = 0] Training accomplished !!!]\n\n\n"));
-					return;
-				} else {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, (" [Double check] min_max_rssi ((%d)) <= %d !!\n",
-						p_dm_fat_table->min_max_rssi, RSSI_CHECK_THRESHOLD));
+			swat_tab->try_flag = SWAW_STEP_DETERMINE;
 
-					next_ant = (p_dm_fat_table->rx_idle_ant  == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
-					p_dm_swat_table->try_flag = SWAW_STEP_PEEK;
-					p_dm_swat_table->reset_idx = RSSI_CHECK_RESET_PERIOD;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[set try_flag=0]  Normal state:  Need to tryg again!!\n\n\n"));
-					return;
-				}
-			} else {
-				if (p_dm_fat_table->min_max_rssi < RSSI_CHECK_THRESHOLD)
-					p_dm_swat_table->reset_idx = RSSI_CHECK_RESET_PERIOD;
+			if (swat_tab->reset_idx <= 1)
+				swat_tab->rssi_trying = 2;
+			else
+				swat_tab->rssi_trying = 1;
 
-				p_dm_swat_table->pre_antenna = rx_idle_ant;
-				odm_update_rx_idle_ant(p_dm, rx_idle_ant);
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[reset try_flag = 0] Training accomplished !!!]\n\n\n"));
-				return;
-			}
+			odm_s0s1_sw_ant_div_by_ctrl_frame(dm, SWAW_STEP_PEEK);
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[set try_flag=1]  Normal state:  Begin Trying!!\n");
 
+		} else if ((swat_tab->try_flag == SWAW_STEP_DETERMINE) &&
+			   (swat_tab->double_chk_flag == 0)) {
+			next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ?
+				   AUX_ANT : MAIN_ANT;
+			swat_tab->rssi_trying--;
 		}
 
+		/* @1 Decision state */
+		if (swat_tab->try_flag == SWAW_STEP_DETERMINE &&
+		    swat_tab->rssi_trying == 0) {
+			phydm_sw_antdiv_decision(dm);
+			return;
+		}
 	}
 
-	/* 1 4.Change TRX antenna */
+	/* @1 4.Change TRX antenna */
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("rssi_trying = (( %d )),    ant: (( %s )) >>> (( %s ))\n",
-		p_dm_swat_table->rssi_trying, (p_dm_fat_table->rx_idle_ant  == MAIN_ANT ? "MAIN" : "AUX"), (next_ant == MAIN_ANT ? "MAIN" : "AUX")));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "rssi_trying = (( %d )),    ant: (( %s )) >>> (( %s ))\n",
+		  swat_tab->rssi_trying,
+		  (fat_tab->rx_idle_ant == MAIN_ANT ? "MAIN" : "AUX"),
+		  (next_ant == MAIN_ANT ? "MAIN" : "AUX"));
 
-	odm_update_rx_idle_ant(p_dm, next_ant);
+	odm_update_rx_idle_ant(dm, next_ant);
 
-	/* 1 5.Reset Statistics */
+	/* @1 5.Reset Statistics */
 
-	p_dm_fat_table->rx_idle_ant  = next_ant;
+	fat_tab->rx_idle_ant = next_ant;
 
-	if (p_dm->support_ic_type == ODM_RTL8188F) {
-		if (p_dm->support_interface == ODM_ITRF_SDIO) {
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (fat_tab->rx_idle_ant == MAIN_ANT) {
+			fat_tab->main_sum[0] = 0;
+			fat_tab->main_cnt[0] = 0;
+			fat_tab->main_sum_cck[0] = 0;
+			fat_tab->main_cnt_cck[0] = 0;
+		} else {
+			fat_tab->aux_sum[0] = 0;
+			fat_tab->aux_cnt[0] = 0;
+			fat_tab->aux_sum_cck[0] = 0;
+			fat_tab->aux_cnt_cck[0] = 0;
+		}
+	}
 
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_SDIO) {
 			ODM_delay_us(200);
-			
-			if (p_dm_fat_table->rx_idle_ant == MAIN_ANT) {
-				p_dm_fat_table->main_ant_sum[0] = 0;
-				p_dm_fat_table->main_ant_cnt[0] = 0;
-				p_dm_fat_table->main_ant_sum_cck[0] = 0;
-				p_dm_fat_table->main_ant_cnt_cck[0] = 0;	
+
+			if (fat_tab->rx_idle_ant == MAIN_ANT) {
+				fat_tab->main_sum[0] = 0;
+				fat_tab->main_cnt[0] = 0;
+				fat_tab->main_sum_cck[0] = 0;
+				fat_tab->main_cnt_cck[0] = 0;
 			} else {
-				p_dm_fat_table->aux_ant_sum[0] = 0;
-				p_dm_fat_table->aux_ant_cnt[0] = 0;
-				p_dm_fat_table->aux_ant_sum_cck[0] = 0;
-				p_dm_fat_table->aux_ant_cnt_cck[0] = 0;	
-			}	
-		}	
+				fat_tab->aux_sum[0] = 0;
+				fat_tab->aux_cnt[0] = 0;
+				fat_tab->aux_sum_cck[0] = 0;
+				fat_tab->aux_cnt_cck[0] = 0;
+			}
+		}
 	}
-
-	/* 1 6.Set next timer   (Trying state) */
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, (" Test ((%s)) ant for (( %d )) ms\n", (next_ant == MAIN_ANT ? "MAIN" : "AUX"), p_dm_swat_table->train_time));
-	odm_set_timer(p_dm, &(p_dm_swat_table->phydm_sw_antenna_switch_timer), p_dm_swat_table->train_time); /*ms*/
+	/* @1 6.Set next timer   (Trying state) */
+	PHYDM_DBG(dm, DBG_ANT_DIV, " Test ((%s)) ant for (( %d )) ms\n",
+		  (next_ant == MAIN_ANT ? "MAIN" : "AUX"),
+		  swat_tab->train_time);
+	odm_set_timer(dm, &swat_tab->sw_antdiv_timer, swat_tab->train_time);
+								/*@ms*/
 }
 
-
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-odm_sw_antdiv_callback(
-	struct timer_list		*p_timer
-)
+void odm_sw_antdiv_callback(struct phydm_timer_list *timer)
 {
-	struct _ADAPTER		*adapter = (struct _ADAPTER *)p_timer->Adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct _sw_antenna_switch_			*p_dm_swat_table = &p_hal_data->DM_OutSrc.dm_swat_table;
+	void *adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct sw_antenna_switch *swat_tab = &hal_data->DM_OutSrc.dm_swat_table;
 
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
 #if USE_WORKITEM
-	odm_schedule_work_item(&p_dm_swat_table->phydm_sw_antenna_switch_workitem);
+	odm_schedule_work_item(&swat_tab->phydm_sw_antenna_switch_workitem);
 #else
 	{
-		/* dbg_print("SW_antdiv_Callback"); */
-		odm_s0s1_sw_ant_div(&p_hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
+#if 0
+		/* @dbg_print("SW_antdiv_Callback"); */
+#endif
+		odm_s0s1_sw_ant_div(&hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
 	}
 #endif
 #else
-	odm_schedule_work_item(&p_dm_swat_table->phydm_sw_antenna_switch_workitem);
+	odm_schedule_work_item(&swat_tab->phydm_sw_antenna_switch_workitem);
 #endif
 }
-void
-odm_sw_antdiv_workitem_callback(
-	void            *p_context
-)
+
+void odm_sw_antdiv_workitem_callback(void *context)
 {
-	struct _ADAPTER		*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 
-	/* dbg_print("SW_antdiv_Workitem_Callback"); */
-	odm_s0s1_sw_ant_div(&p_hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
+#if 0
+	/* @dbg_print("SW_antdiv_Workitem_Callback"); */
+#endif
+	odm_s0s1_sw_ant_div(&hal_data->DM_OutSrc, SWAW_STEP_DETERMINE);
 }
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 
-void
-odm_sw_antdiv_workitem_callback(
-	void	*p_context
-)
+void odm_sw_antdiv_workitem_callback(void *context)
 {
-	struct _ADAPTER *
-	p_adapter = (struct _ADAPTER *)p_context;
+	void *
+		adapter = (void *)context;
 	HAL_DATA_TYPE
-	*p_hal_data = GET_HAL_DATA(p_adapter);
+	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 
-	/*dbg_print("SW_antdiv_Workitem_Callback");*/
-	odm_s0s1_sw_ant_div(&p_hal_data->odmpriv, SWAW_STEP_DETERMINE);
+#if 0
+	/*@dbg_print("SW_antdiv_Workitem_Callback");*/
+#endif
+	odm_s0s1_sw_ant_div(&hal_data->odmpriv, SWAW_STEP_DETERMINE);
 }
 
-void
-odm_sw_antdiv_callback(void *function_context)
+void odm_sw_antdiv_callback(void *function_context)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)function_context;
-	struct _ADAPTER	*padapter = p_dm->adapter;
-	if (padapter->net_closed == true)
+	struct dm_struct *dm = (struct dm_struct *)function_context;
+	void *padapter = dm->adapter;
+	if (*dm->is_net_closed == true)
 		return;
 
-#if 0 /* Can't do I/O in timer callback*/
-	odm_s0s1_sw_ant_div(p_dm, SWAW_STEP_DETERMINE);
+#if 0 /* @Can't do I/O in timer callback*/
+	odm_s0s1_sw_ant_div(dm, SWAW_STEP_DETERMINE);
 #else
-	rtw_run_in_thread_cmd(padapter, odm_sw_antdiv_workitem_callback, padapter);
+	rtw_run_in_thread_cmd(padapter, odm_sw_antdiv_workitem_callback,
+			      padapter);
 #endif
 }
 
-
 #endif
 
-void
-odm_s0s1_sw_ant_div_by_ctrl_frame(
-	void			*p_dm_void,
-	u8			step
-)
+void odm_s0s1_sw_ant_div_by_ctrl_frame(void *dm_void, u8 step)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _sw_antenna_switch_	*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
 	switch (step) {
 	case SWAW_STEP_PEEK:
-		p_dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame = 0;
-		p_dm_swat_table->is_sw_ant_div_by_ctrl_frame = true;
-		p_dm_fat_table->main_ant_ctrl_frame_cnt = 0;
-		p_dm_fat_table->aux_ant_ctrl_frame_cnt = 0;
-		p_dm_fat_table->main_ant_ctrl_frame_sum = 0;
-		p_dm_fat_table->aux_ant_ctrl_frame_sum = 0;
-		p_dm_fat_table->cck_ctrl_frame_cnt_main = 0;
-		p_dm_fat_table->cck_ctrl_frame_cnt_aux = 0;
-		p_dm_fat_table->ofdm_ctrl_frame_cnt_main = 0;
-		p_dm_fat_table->ofdm_ctrl_frame_cnt_aux = 0;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_S0S1_SwAntDivForAPMode(): Start peek and reset counter\n"));
+		swat_tab->pkt_cnt_sw_ant_div_by_ctrl_frame = 0;
+		swat_tab->is_sw_ant_div_by_ctrl_frame = true;
+		fat_tab->main_ctrl_cnt = 0;
+		fat_tab->aux_ctrl_cnt = 0;
+		fat_tab->main_ctrl_sum = 0;
+		fat_tab->aux_ctrl_sum = 0;
+		fat_tab->cck_ctrl_frame_cnt_main = 0;
+		fat_tab->cck_ctrl_frame_cnt_aux = 0;
+		fat_tab->ofdm_ctrl_frame_cnt_main = 0;
+		fat_tab->ofdm_ctrl_frame_cnt_aux = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "odm_S0S1_SwAntDivForAPMode(): Start peek and reset counter\n");
 		break;
 	case SWAW_STEP_DETERMINE:
-		p_dm_swat_table->is_sw_ant_div_by_ctrl_frame = false;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_S0S1_SwAntDivForAPMode(): Stop peek\n"));
+		swat_tab->is_sw_ant_div_by_ctrl_frame = false;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "odm_S0S1_SwAntDivForAPMode(): Stop peek\n");
 		break;
 	default:
-		p_dm_swat_table->is_sw_ant_div_by_ctrl_frame = false;
+		swat_tab->is_sw_ant_div_by_ctrl_frame = false;
 		break;
 	}
 }
 
-void
-odm_antsel_statistics_of_ctrl_frame(
-	void			*p_dm_void,
-	u8			antsel_tr_mux,
-	u32			rx_pwdb_all
-
-)
+void odm_antsel_statistics_ctrl(void *dm_void, u8 antsel_tr_mux,
+				u32 rx_pwdb_all)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
 	if (antsel_tr_mux == ANT1_2G) {
-		p_dm_fat_table->main_ant_ctrl_frame_sum += rx_pwdb_all;
-		p_dm_fat_table->main_ant_ctrl_frame_cnt++;
+		fat_tab->main_ctrl_sum += rx_pwdb_all;
+		fat_tab->main_ctrl_cnt++;
 	} else {
-		p_dm_fat_table->aux_ant_ctrl_frame_sum += rx_pwdb_all;
-		p_dm_fat_table->aux_ant_ctrl_frame_cnt++;
+		fat_tab->aux_ctrl_sum += rx_pwdb_all;
+		fat_tab->aux_ctrl_cnt++;
 	}
 }
 
-void
-odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	void			*p_pkt_info_void
-	/*	struct phydm_phyinfo_struct*		p_phy_info, */
-	/*	struct phydm_perpkt_info_struct*		p_pktinfo */
-)
+void odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(void *dm_void,
+						    void *phy_info_void,
+						    void *pkt_info_void
+	/*	struct phydm_phyinfo_struct*		phy_info, */
+	/*	struct phydm_perpkt_info_struct*		pktinfo */
+	)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_phyinfo_struct	*p_phy_info = (struct phydm_phyinfo_struct *)p_phy_info_void;
-	struct phydm_perpkt_info_struct	*p_pktinfo = (struct phydm_perpkt_info_struct *)p_pkt_info_void;
-	struct _sw_antenna_switch_	*p_dm_swat_table = &p_dm->dm_swat_table;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-	boolean		is_cck_rate;
-
-	if (!(p_dm->support_ability & ODM_BB_ANT_DIV))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct *phy_info = NULL;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u8 rssi_cck;
+
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
 		return;
 
-	if (p_dm->ant_div_type != S0S1_SW_ANTDIV)
+	if (dm->ant_div_type != S0S1_SW_ANTDIV)
 		return;
 
-	/* In try state */
-	if (!p_dm_swat_table->is_sw_ant_div_by_ctrl_frame)
+	/* @In try state */
+	if (!swat_tab->is_sw_ant_div_by_ctrl_frame)
 		return;
 
 	/* No HW error and match receiver address */
-	if (!p_pktinfo->is_to_self)
+	if (!pktinfo->is_to_self)
 		return;
 
-	p_dm_swat_table->pkt_cnt_sw_ant_div_by_ctrl_frame++;
-	is_cck_rate = ((p_pktinfo->data_rate >= DESC_RATE1M) && (p_pktinfo->data_rate <= DESC_RATE11M)) ? true : false;
+	swat_tab->pkt_cnt_sw_ant_div_by_ctrl_frame++;
 
-	if (is_cck_rate) {
-		p_dm_fat_table->antsel_rx_keep_0 = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
+	if (pktinfo->is_cck_rate) {
+		rssi_cck = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+		fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ?
+					    ANT1_2G : ANT2_2G;
 
-		if (p_dm_fat_table->antsel_rx_keep_0 == ANT1_2G)
-			p_dm_fat_table->cck_ctrl_frame_cnt_main++;
+		if (fat_tab->antsel_rx_keep_0 == ANT1_2G)
+			fat_tab->cck_ctrl_frame_cnt_main++;
 		else
-			p_dm_fat_table->cck_ctrl_frame_cnt_aux++;
+			fat_tab->cck_ctrl_frame_cnt_aux++;
 
-		odm_antsel_statistics_of_ctrl_frame(p_dm, p_dm_fat_table->antsel_rx_keep_0, p_phy_info->rx_mimo_signal_strength[RF_PATH_A]);
+		odm_antsel_statistics_ctrl(dm, fat_tab->antsel_rx_keep_0,
+					   rssi_cck);
 	} else {
-		p_dm_fat_table->antsel_rx_keep_0 = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
-		
-		if (p_dm_fat_table->antsel_rx_keep_0 == ANT1_2G)
-			p_dm_fat_table->ofdm_ctrl_frame_cnt_main++;
+		fat_tab->antsel_rx_keep_0 = (fat_tab->rx_idle_ant == MAIN_ANT) ?
+					    ANT1_2G : ANT2_2G;
+
+		if (fat_tab->antsel_rx_keep_0 == ANT1_2G)
+			fat_tab->ofdm_ctrl_frame_cnt_main++;
 		else
-			p_dm_fat_table->ofdm_ctrl_frame_cnt_aux++;
+			fat_tab->ofdm_ctrl_frame_cnt_aux++;
 
-		odm_antsel_statistics_of_ctrl_frame(p_dm, p_dm_fat_table->antsel_rx_keep_0, p_phy_info->rx_pwdb_all);
+		odm_antsel_statistics_ctrl(dm, fat_tab->antsel_rx_keep_0,
+					   phy_info->rx_pwdb_all);
 	}
 }
 
-#endif /* #if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) */
-
-
+#endif /* @#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) */
 
-
-void
-odm_set_next_mac_addr_target(
-	void		*p_dm_void
-)
+void odm_set_next_mac_addr_target(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct cmn_sta_info	*p_entry;
-	u32			value32, i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct cmn_sta_info *entry;
+	u32 value32, i;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("odm_set_next_mac_addr_target() ==>\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "%s ==>\n", __func__);
 
-	if (p_dm->is_linked) {
+	if (dm->is_linked) {
 		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-
-			if ((p_dm_fat_table->train_idx + 1) == ODM_ASSOCIATE_ENTRY_NUM)
-				p_dm_fat_table->train_idx = 0;
+			if ((fat_tab->train_idx + 1) == ODM_ASSOCIATE_ENTRY_NUM)
+				fat_tab->train_idx = 0;
 			else
-				p_dm_fat_table->train_idx++;
+				fat_tab->train_idx++;
 
-			p_entry = p_dm->p_phydm_sta_info[p_dm_fat_table->train_idx];
+			entry = dm->phydm_sta_info[fat_tab->train_idx];
 
-			if (is_sta_active(p_entry)) {
+			if (is_sta_active(entry)) {
+				/*@Match MAC ADDR*/
+				value32 = (entry->mac_addr[5] << 8) | entry->mac_addr[4];
 
-				/*Match MAC ADDR*/
-				value32 = (p_entry->mac_addr[5] << 8) | p_entry->mac_addr[4];
+				odm_set_mac_reg(dm, R_0x7b4, 0xFFFF, value32); /*@0x7b4~0x7b5*/
 
-				odm_set_mac_reg(p_dm, 0x7b4, 0xFFFF, value32);/*0x7b4~0x7b5*/
+				value32 = (entry->mac_addr[3] << 24) | (entry->mac_addr[2] << 16) | (entry->mac_addr[1] << 8) | entry->mac_addr[0];
 
-				value32 = (p_entry->mac_addr[3] << 24) | (p_entry->mac_addr[2] << 16) | (p_entry->mac_addr[1] << 8) | p_entry->mac_addr[0];
+				odm_set_mac_reg(dm, R_0x7b0, MASKDWORD, value32); /*@0x7b0~0x7b3*/
 
-				odm_set_mac_reg(p_dm, 0x7b0, MASKDWORD, value32);/*0x7b0~0x7b3*/
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "fat_tab->train_idx=%d\n",
+					  fat_tab->train_idx);
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("p_dm_fat_table->train_idx=%d\n", p_dm_fat_table->train_idx));
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Training MAC addr = %x:%x:%x:%x:%x:%x\n",
-					p_entry->mac_addr[5], p_entry->mac_addr[4], p_entry->mac_addr[3], p_entry->mac_addr[2], p_entry->mac_addr[1], p_entry->mac_addr[0]));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Training MAC addr = %x:%x:%x:%x:%x:%x\n",
+					  entry->mac_addr[5],
+					  entry->mac_addr[4],
+					  entry->mac_addr[3],
+					  entry->mac_addr[2],
+					  entry->mac_addr[1],
+					  entry->mac_addr[0]);
 
 				break;
 			}
 		}
 	}
-
 }
 
 #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
 
-void
-odm_fast_ant_training(
-	void		*p_dm_void
-)
+void odm_fast_ant_training(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	u32	max_rssi_path_a = 0, pckcnt_path_a = 0;
-	u8	i, target_ant_path_a = 0;
-	boolean	is_pkt_filter_macth_path_a = false;
+	u32 max_rssi_path_a = 0, pckcnt_path_a = 0;
+	u8 i, target_ant_path_a = 0;
+	boolean is_pkt_filter_macth_path_a = false;
 #if (RTL8192E_SUPPORT == 1)
-	u32	max_rssi_path_b = 0, pckcnt_path_b = 0;
-	u8	target_ant_path_b = 0;
-	boolean	is_pkt_filter_macth_path_b = false;
+	u32 max_rssi_path_b = 0, pckcnt_path_b = 0;
+	u8 target_ant_path_b = 0;
+	boolean is_pkt_filter_macth_path_b = false;
 #endif
 
+	if (!dm->is_linked) { /* @is_linked==False */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
 
-	if (!p_dm->is_linked) { /* is_linked==False */
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[No Link!!!]\n"));
-
-		if (p_dm_fat_table->is_become_linked == true) {
-			odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-			phydm_fast_training_enable(p_dm, FAT_OFF);
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+		if (fat_tab->is_become_linked == true) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+			phydm_fast_training_enable(dm, FAT_OFF);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			fat_tab->is_become_linked = dm->is_linked;
 		}
 		return;
 	} else {
-		if (p_dm_fat_table->is_become_linked == false) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Linked!!!]\n"));
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked!!!]\n");
+			fat_tab->is_become_linked = dm->is_linked;
 		}
 	}
 
-	if (*(p_dm_fat_table->p_force_tx_ant_by_desc) == false) {
-		if (p_dm->is_one_entry_only == true)
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
+	if (!(*fat_tab->p_force_tx_by_desc)) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
 		else
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_DESC);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
 	}
 
-
-	if (p_dm->support_ic_type == ODM_RTL8188E)
-		odm_set_bb_reg(p_dm, 0x864, BIT(2) | BIT(1) | BIT(0), ((p_dm->fat_comb_a) - 1));
+	if (dm->support_ic_type == ODM_RTL8188E)
+		odm_set_bb_reg(dm, R_0x864, BIT(2) | BIT(1) | BIT(0), ((dm->fat_comb_a) - 1));
 #if (RTL8192E_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8192E) {
-		odm_set_bb_reg(p_dm, 0xB38, BIT(2) | BIT(1) | BIT(0), ((p_dm->fat_comb_a) - 1));	   /* path-A  */ /* ant combination=regB38[2:0]+1 */
-		odm_set_bb_reg(p_dm, 0xB38, BIT(18) | BIT(17) | BIT(16), ((p_dm->fat_comb_b) - 1));  /* path-B  */ /* ant combination=regB38[18:16]+1 */
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		odm_set_bb_reg(dm, R_0xb38, BIT(2) | BIT(1) | BIT(0), ((dm->fat_comb_a) - 1)); /* path-A  */ /* ant combination=regB38[2:0]+1 */
+		odm_set_bb_reg(dm, R_0xb38, BIT(18) | BIT(17) | BIT(16), ((dm->fat_comb_b) - 1)); /* path-B  */ /* ant combination=regB38[18:16]+1 */
 	}
 #endif
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("==>odm_fast_ant_training()\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "==>%s\n", __func__);
 
-	/* 1 TRAINING STATE */
-	if (p_dm_fat_table->fat_state == FAT_TRAINING_STATE) {
-		/* 2 Caculate RSSI per Antenna */
+	/* @1 TRAINING STATE */
+	if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		/* @2 Caculate RSSI per Antenna */
 
-		/* 3 [path-A]--------------------------- */
-		for (i = 0; i < (p_dm->fat_comb_a); i++) { /* i : antenna index */
-			if (p_dm_fat_table->ant_rssi_cnt[i] == 0)
-				p_dm_fat_table->ant_ave_rssi[i] = 0;
+		/* @3 [path-A]--------------------------- */
+		for (i = 0; i < (dm->fat_comb_a); i++) { /* @i : antenna index */
+			if (fat_tab->ant_rssi_cnt[i] == 0)
+				fat_tab->ant_ave_rssi[i] = 0;
 			else {
-				p_dm_fat_table->ant_ave_rssi[i] = p_dm_fat_table->ant_sum_rssi[i] / p_dm_fat_table->ant_rssi_cnt[i];
+				fat_tab->ant_ave_rssi[i] = fat_tab->ant_sum_rssi[i] / fat_tab->ant_rssi_cnt[i];
 				is_pkt_filter_macth_path_a = true;
 			}
 
-			if (p_dm_fat_table->ant_ave_rssi[i] > max_rssi_path_a) {
-				max_rssi_path_a = p_dm_fat_table->ant_ave_rssi[i];
-				pckcnt_path_a = p_dm_fat_table->ant_rssi_cnt[i];
-				target_ant_path_a =  i ;
-			} else if (p_dm_fat_table->ant_ave_rssi[i] == max_rssi_path_a) {
-				if ((p_dm_fat_table->ant_rssi_cnt[i])   >   pckcnt_path_a) {
-					max_rssi_path_a = p_dm_fat_table->ant_ave_rssi[i];
-					pckcnt_path_a = p_dm_fat_table->ant_rssi_cnt[i];
-					target_ant_path_a = i ;
+			if (fat_tab->ant_ave_rssi[i] > max_rssi_path_a) {
+				max_rssi_path_a = fat_tab->ant_ave_rssi[i];
+				pckcnt_path_a = fat_tab->ant_rssi_cnt[i];
+				target_ant_path_a = i;
+			} else if (fat_tab->ant_ave_rssi[i] == max_rssi_path_a) {
+				if (fat_tab->ant_rssi_cnt[i] > pckcnt_path_a) {
+					max_rssi_path_a = fat_tab->ant_ave_rssi[i];
+					pckcnt_path_a = fat_tab->ant_rssi_cnt[i];
+					target_ant_path_a = i;
 				}
 			}
 
-			PHYDM_DBG("*** ant-index : [ %d ],      counter = (( %d )),     Avg RSSI = (( %d ))\n", i, p_dm_fat_table->ant_rssi_cnt[i],  p_dm_fat_table->ant_ave_rssi[i]);
+			PHYDM_DBG(
+				  "*** ant-index : [ %d ],      counter = (( %d )),     Avg RSSI = (( %d ))\n",
+				  i, fat_tab->ant_rssi_cnt[i],
+				  fat_tab->ant_ave_rssi[i]);
 		}
 
-
 #if 0
 #if (RTL8192E_SUPPORT == 1)
-		/* 3 [path-B]--------------------------- */
-		for (i = 0; i < (p_dm->fat_comb_b); i++) {
-			if (p_dm_fat_table->antRSSIcnt_pathB[i] == 0)
-				p_dm_fat_table->antAveRSSI_pathB[i] = 0;
-			else { /*  (ant_rssi_cnt[i] != 0) */
-				p_dm_fat_table->antAveRSSI_pathB[i] = p_dm_fat_table->antSumRSSI_pathB[i] / p_dm_fat_table->antRSSIcnt_pathB[i];
+		/* @3 [path-B]--------------------------- */
+		for (i = 0; i < (dm->fat_comb_b); i++) {
+			if (fat_tab->antRSSIcnt_pathB[i] == 0)
+				fat_tab->antAveRSSI_pathB[i] = 0;
+			else { /*  @(ant_rssi_cnt[i] != 0) */
+				fat_tab->antAveRSSI_pathB[i] = fat_tab->antSumRSSI_pathB[i] / fat_tab->antRSSIcnt_pathB[i];
 				is_pkt_filter_macth_path_b = true;
 			}
-			if (p_dm_fat_table->antAveRSSI_pathB[i] > max_rssi_path_b) {
-				max_rssi_path_b = p_dm_fat_table->antAveRSSI_pathB[i];
-				pckcnt_path_b = p_dm_fat_table->antRSSIcnt_pathB[i];
-				target_ant_path_b = (u8) i;
+			if (fat_tab->antAveRSSI_pathB[i] > max_rssi_path_b) {
+				max_rssi_path_b = fat_tab->antAveRSSI_pathB[i];
+				pckcnt_path_b = fat_tab->antRSSIcnt_pathB[i];
+				target_ant_path_b = (u8)i;
 			}
-			if (p_dm_fat_table->antAveRSSI_pathB[i] == max_rssi_path_b) {
-				if (p_dm_fat_table->antRSSIcnt_pathB > pckcnt_path_b) {
-					max_rssi_path_b = p_dm_fat_table->antAveRSSI_pathB[i];
-					target_ant_path_b = (u8) i;
+			if (fat_tab->antAveRSSI_pathB[i] == max_rssi_path_b) {
+				if (fat_tab->antRSSIcnt_pathB > pckcnt_path_b) {
+					max_rssi_path_b = fat_tab->antAveRSSI_pathB[i];
+					target_ant_path_b = (u8)i;
 				}
 			}
-			if (p_dm->fat_print_rssi == 1) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***{path-B}: Sum RSSI[%d] = (( %d )),      cnt RSSI [%d] = (( %d )),     Avg RSSI[%d] = (( %d ))\n",
-					i, p_dm_fat_table->antSumRSSI_pathB[i], i, p_dm_fat_table->antRSSIcnt_pathB[i], i, p_dm_fat_table->antAveRSSI_pathB[i]));
+			if (dm->fat_print_rssi == 1) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "***{path-B}: Sum RSSI[%d] = (( %d )),      cnt RSSI [%d] = (( %d )),     Avg RSSI[%d] = (( %d ))\n",
+					  i, fat_tab->antSumRSSI_pathB[i], i,
+					  fat_tab->antRSSIcnt_pathB[i], i,
+					  fat_tab->antAveRSSI_pathB[i]);
 			}
 		}
 #endif
 #endif
 
-		/* 1 DECISION STATE */
+		/* @1 DECISION STATE */
 
-		/* 2 Select TRX Antenna */
+		/* @2 Select TRX Antenna */
 
-		phydm_fast_training_enable(p_dm, FAT_OFF);
+		phydm_fast_training_enable(dm, FAT_OFF);
 
-		/* 3 [path-A]--------------------------- */
-		if (is_pkt_filter_macth_path_a  == false) {
-			/* PHYDM_DBG(p_dm,DBG_ANT_DIV, ("{path-A}: None Packet is matched\n")); */
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("{path-A}: None Packet is matched\n"));
-			odm_ant_div_on_off(p_dm, ANTDIV_OFF);
+		/* @3 [path-A]--------------------------- */
+		if (is_pkt_filter_macth_path_a == false) {
+#if 0
+			/* PHYDM_DBG(dm,DBG_ANT_DIV, "{path-A}: None Packet is matched\n"); */
+#endif
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "{path-A}: None Packet is matched\n");
+			odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
 		} else {
-			PHYDM_DBG("target_ant_path_a = (( %d )) , max_rssi_path_a = (( %d ))\n", target_ant_path_a, max_rssi_path_a);
+			PHYDM_DBG(
+				  "target_ant_path_a = (( %d )) , max_rssi_path_a = (( %d ))\n",
+				  target_ant_path_a, max_rssi_path_a);
 
-			/* 3 [ update RX-optional ant ]        Default RX is Omni, Optional RX is the best decision by FAT */
-			if (p_dm->support_ic_type == ODM_RTL8188E)
-				odm_set_bb_reg(p_dm, 0x864, BIT(8) | BIT(7) | BIT(6), target_ant_path_a);
-			else if (p_dm->support_ic_type == ODM_RTL8192E)
-				odm_set_bb_reg(p_dm, 0xB38, BIT(8) | BIT(7) | BIT(6), target_ant_path_a); /* Optional RX [pth-A] */
+			/* @3 [ update RX-optional ant ]        Default RX is Omni, Optional RX is the best decision by FAT */
+			if (dm->support_ic_type == ODM_RTL8188E)
+				odm_set_bb_reg(dm, R_0x864, BIT(8) | BIT(7) | BIT(6), target_ant_path_a);
+			else if (dm->support_ic_type == ODM_RTL8192E)
+				odm_set_bb_reg(dm, R_0xb38, BIT(8) | BIT(7) | BIT(6), target_ant_path_a); /* Optional RX [pth-A] */
 
-			/* 3 [ update TX ant ] */
-			odm_update_tx_ant(p_dm, target_ant_path_a, (p_dm_fat_table->train_idx));
+			/* @3 [ update TX ant ] */
+			odm_update_tx_ant(dm, target_ant_path_a, (fat_tab->train_idx));
 
 			if (target_ant_path_a == 0)
-				odm_ant_div_on_off(p_dm, ANTDIV_OFF);
+				odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
 		}
 #if 0
 #if (RTL8192E_SUPPORT == 1)
-		/* 3 [path-B]--------------------------- */
+		/* @3 [path-B]--------------------------- */
 		if (is_pkt_filter_macth_path_b == false) {
-			if (p_dm->fat_print_rssi == 1)
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***[%d]{path-B}: None Packet is matched\n\n\n", __LINE__));
+			if (dm->fat_print_rssi == 1)
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "***[%d]{path-B}: None Packet is matched\n\n\n",
+					  __LINE__);
 		} else {
-			if (p_dm->fat_print_rssi == 1) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV,
-					(" ***target_ant_path_b = (( %d )) *** max_rssi = (( %d ))***\n\n\n", target_ant_path_b, max_rssi_path_b));
+			if (dm->fat_print_rssi == 1) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  " ***target_ant_path_b = (( %d )) *** max_rssi = (( %d ))***\n\n\n",
+					  target_ant_path_b, max_rssi_path_b);
 			}
-			odm_set_bb_reg(p_dm, 0xB38, BIT(21) | BIT20 | BIT19, target_ant_path_b);	/* Default RX is Omni, Optional RX is the best decision by FAT */
-			odm_set_bb_reg(p_dm, 0x80c, BIT(21), 1); /* Reg80c[21]=1'b1		//from TX Info */
+			odm_set_bb_reg(dm, R_0xb38, BIT(21) | BIT20 | BIT19, target_ant_path_b);	/* @Default RX is Omni, Optional RX is the best decision by FAT */
+			odm_set_bb_reg(dm, R_0x80c, BIT(21), 1); /* Reg80c[21]=1'b1		//from TX Info */
 
-			p_dm_fat_table->antsel_pathB[p_dm_fat_table->train_idx] = target_ant_path_b;
+			fat_tab->antsel_pathB[fat_tab->train_idx] = target_ant_path_b;
 		}
 #endif
 #endif
 
-		/* 2 Reset counter */
-		for (i = 0; i < (p_dm->fat_comb_a); i++) {
-			p_dm_fat_table->ant_sum_rssi[i] = 0;
-			p_dm_fat_table->ant_rssi_cnt[i] = 0;
+		/* @2 Reset counter */
+		for (i = 0; i < (dm->fat_comb_a); i++) {
+			fat_tab->ant_sum_rssi[i] = 0;
+			fat_tab->ant_rssi_cnt[i] = 0;
 		}
-		/*
+		/*@
 		#if (RTL8192E_SUPPORT == 1)
-		for(i=0; i<=(p_dm->fat_comb_b); i++)
+		for(i=0; i<=(dm->fat_comb_b); i++)
 		{
-			p_dm_fat_table->antSumRSSI_pathB[i] = 0;
-			p_dm_fat_table->antRSSIcnt_pathB[i] = 0;
+			fat_tab->antSumRSSI_pathB[i] = 0;
+			fat_tab->antRSSIcnt_pathB[i] = 0;
 		}
 		#endif
 		*/
 
-		p_dm_fat_table->fat_state = FAT_PREPARE_STATE;
+		fat_tab->fat_state = FAT_PREPARE_STATE;
 		return;
 	}
 
-	/* 1 NORMAL STATE */
-	if (p_dm_fat_table->fat_state == FAT_PREPARE_STATE) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Start Prepare state ]\n"));
+	/* @1 NORMAL STATE */
+	if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ Start Prepare state ]\n");
 
-		odm_set_next_mac_addr_target(p_dm);
+		odm_set_next_mac_addr_target(dm);
 
-		/* 2 Prepare Training */
-		p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
-		phydm_fast_training_enable(p_dm, FAT_ON);
-		odm_ant_div_on_off(p_dm, ANTDIV_ON);		/* enable HW AntDiv */
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Start Training state]\n"));
+		/* @2 Prepare Training */
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+		phydm_fast_training_enable(dm, FAT_ON);
+		odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+		/* @enable HW AntDiv */
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[Start Training state]\n");
 
-		odm_set_timer(p_dm, &p_dm->fast_ant_training_timer, p_dm->antdiv_intvl); /* ms */
+		odm_set_timer(dm, &dm->fast_ant_training_timer, dm->antdiv_intvl); /* @ms */
 	}
-
 }
 
-void
-odm_fast_ant_training_callback(
-	void		*p_dm_void
-)
+void odm_fast_ant_training_callback(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct _ADAPTER	*padapter = p_dm->adapter;
-	if (padapter->net_closed == true)
+	if (*(dm->is_net_closed) == true)
 		return;
-	/* if(*p_dm->p_is_net_closed == true) */
-	/* return; */
 #endif
 
 #if USE_WORKITEM
-	odm_schedule_work_item(&p_dm->fast_ant_training_workitem);
+	odm_schedule_work_item(&dm->fast_ant_training_workitem);
 #else
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("******odm_fast_ant_training_callback******\n"));
-	odm_fast_ant_training(p_dm);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******%s******\n", __func__);
+	odm_fast_ant_training(dm);
 #endif
 }
 
-void
-odm_fast_ant_training_work_item_callback(
-	void		*p_dm_void
-)
+void odm_fast_ant_training_work_item_callback(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("******odm_fast_ant_training_work_item_callback******\n"));
-	odm_fast_ant_training(p_dm);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "******%s******\n", __func__);
+	odm_fast_ant_training(dm);
 }
 
 #endif
 
-void
-odm_ant_div_init(
-	void		*p_dm_void
-)
+void odm_ant_div_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct _sw_antenna_switch_			*p_dm_swat_table = &p_dm->dm_swat_table;
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct sw_antenna_switch *swat_tab = &dm->dm_swat_table;
 
-	if (!(p_dm->support_ability & ODM_BB_ANT_DIV)) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!]   Not Support Antenna Diversity Function\n"));
+	if (!(dm->support_ability & ODM_BB_ANT_DIV)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[Return!!!]   Not Support Antenna Diversity Function\n");
 		return;
 	}
-	/* --- */
+/* @--- */
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	if (p_dm_fat_table->ant_div_2g_5g == ODM_ANTDIV_2G) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[2G AntDiv Init]: Only Support 2G Antenna Diversity Function\n"));
-		if (!(p_dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
+	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_2G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[2G AntDiv Init]: Only Support 2G Antenna Diversity Function\n");
+		if (!(dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
 			return;
-	} else	if (p_dm_fat_table->ant_div_2g_5g == ODM_ANTDIV_5G) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[5G AntDiv Init]: Only Support 5G Antenna Diversity Function\n"));
-		if (!(p_dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
+	} else if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_5G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[5G AntDiv Init]: Only Support 5G Antenna Diversity Function\n");
+		if (!(dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
 			return;
-	} else	if (p_dm_fat_table->ant_div_2g_5g == (ODM_ANTDIV_2G | ODM_ANTDIV_5G))
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[2G & 5G AntDiv Init]:Support Both 2G & 5G Antenna Diversity Function\n"));
+	} else if (fat_tab->ant_div_2g_5g == (ODM_ANTDIV_2G | ODM_ANTDIV_5G))
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[2G & 5G AntDiv Init]:Support Both 2G & 5G Antenna Diversity Function\n");
 
 #endif
-	/* --- */
+	/* @--- */
 
-	/* 2 [--General---] */
-	p_dm->antdiv_period = 0;
+	/* @2 [--General---] */
+	dm->antdiv_period = 0;
 
-	p_dm_fat_table->is_become_linked = false;
-	p_dm_fat_table->ant_div_on_off = 0xff;
+	fat_tab->is_become_linked = false;
+	fat_tab->ant_div_on_off = 0xff;
 
-	/* 3       -   AP   - */
+/* @3       -   AP   - */
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	odm_bdc_init(p_dm);
+	odm_bdc_init(dm);
 #endif
 #endif
 
-	/* 3     -   WIN   - */
+/* @3     -   WIN   - */
 #elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	p_dm_swat_table->ant_5g = MAIN_ANT;
-	p_dm_swat_table->ant_2g = MAIN_ANT;
+	swat_tab->ant_5g = MAIN_ANT;
+	swat_tab->ant_2g = MAIN_ANT;
 #endif
 
-	/* 2 [---Set MAIN_ANT as default antenna if Auto-ant enable---] */
-	odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-
-	p_dm->ant_type = ODM_AUTO_ANT;
-
-	p_dm_fat_table->rx_idle_ant = 0xff; /*to make RX-idle-antenna will be updated absolutly*/
-	odm_update_rx_idle_ant(p_dm, MAIN_ANT);
-	phydm_keep_rx_ack_ant_by_tx_ant_time(p_dm, 0);  /* Timming issue: keep Rx ant after tx for ACK ( 5 x 3.2 mu = 16mu sec)*/
-
-	/* 2 [---Set TX Antenna---] */
-	if (p_dm_fat_table->p_force_tx_ant_by_desc == NULL) {
-	p_dm_fat_table->force_tx_ant_by_desc = 0;
-	p_dm_fat_table->p_force_tx_ant_by_desc = &(p_dm_fat_table->force_tx_ant_by_desc);
+	/* @2 [---Set MAIN_ANT as default antenna if Auto-ant enable---] */
+	if (fat_tab->div_path_type == ANT_PATH_A)
+		odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+	else if (fat_tab->div_path_type == ANT_PATH_B)
+		odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_B);
+	else if (fat_tab->div_path_type == ANT_PATH_AB)
+		odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_AB);
+
+	dm->ant_type = ODM_AUTO_ANT;
+
+	fat_tab->rx_idle_ant = 0xff;
+		/*to make RX-idle-antenna will be updated absolutly*/
+	odm_update_rx_idle_ant(dm, MAIN_ANT);
+	phydm_keep_rx_ack_ant_by_tx_ant_time(dm, 0);
+	/* Timming issue: keep Rx ant after tx for ACK(5 x 3.2 mu = 16mu sec)*/
+
+	/* @2 [---Set TX Antenna---] */
+	if (!fat_tab->p_force_tx_by_desc) {
+		fat_tab->force_tx_by_desc = 0;
+		fat_tab->p_force_tx_by_desc = &fat_tab->force_tx_by_desc;
 	}
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("p_force_tx_ant_by_desc = %d\n", *p_dm_fat_table->p_force_tx_ant_by_desc));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "p_force_tx_by_desc = %d\n",
+		  *fat_tab->p_force_tx_by_desc);
 
-	if (*(p_dm_fat_table->p_force_tx_ant_by_desc) == true)
-		odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_DESC);
+	if (*fat_tab->p_force_tx_by_desc)
+		odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
 	else
-	odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
-
+		odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
 
-	/* 2 [--88E---] */
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
+	/* @2 [--88E---] */
+	if (dm->support_ic_type == ODM_RTL8188E) {
 #if (RTL8188E_SUPPORT == 1)
-		/* p_dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
-		/* p_dm->ant_div_type = CG_TRX_HW_ANTDIV; */
-		/* p_dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
-
-		if ((p_dm->ant_div_type != CGCS_RX_HW_ANTDIV)  && (p_dm->ant_div_type != CG_TRX_HW_ANTDIV) && (p_dm->ant_div_type != CG_TRX_SMART_ANTDIV)) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!]  88E Not Supprrt This AntDiv type\n"));
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+		/* @dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* @dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+		/* @dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
+
+		if (dm->ant_div_type != CGCS_RX_HW_ANTDIV &&
+		    dm->ant_div_type != CG_TRX_HW_ANTDIV &&
+		    dm->ant_div_type != CG_TRX_SMART_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!]  88E Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 			return;
 		}
 
-		if (p_dm->ant_div_type == CGCS_RX_HW_ANTDIV)
-			odm_rx_hw_ant_div_init_88e(p_dm);
-		else if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-			odm_trx_hw_ant_div_init_88e(p_dm);
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_rx_hw_ant_div_init_88e(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_88e(dm);
 #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		else if (p_dm->ant_div_type == CG_TRX_SMART_ANTDIV)
-			odm_smart_hw_ant_div_init_88e(p_dm);
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_smart_hw_ant_div_init_88e(dm);
 #endif
 #endif
 	}
 
-	/* 2 [--92E---] */
+/* @2 [--92E---] */
 #if (RTL8192E_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8192E) {
-		/* p_dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
-		/* p_dm->ant_div_type = CG_TRX_HW_ANTDIV; */
-		/* p_dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
-
-		if ((p_dm->ant_div_type != CGCS_RX_HW_ANTDIV) && (p_dm->ant_div_type != CG_TRX_HW_ANTDIV)   && (p_dm->ant_div_type != CG_TRX_SMART_ANTDIV)) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!]  8192E Not Supprrt This AntDiv type\n"));
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		/* @dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* @dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+		/* @dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
+
+		if (dm->ant_div_type != CGCS_RX_HW_ANTDIV &&
+		    dm->ant_div_type != CG_TRX_HW_ANTDIV &&
+		    dm->ant_div_type != CG_TRX_SMART_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!]  8192E Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_rx_hw_ant_div_init_92e(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_92e(dm);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_smart_hw_ant_div_init_92e(dm);
+#endif
+	}
+#endif
+
+	/* @2 [--92F---] */
+#if (RTL8192F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8192F) {
+	/* @dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+	/* @dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+	/* @dm->ant_div_type = CG_TRX_SMART_ANTDIV; */
+
+	if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+		if (dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!]  8192F Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 			return;
 		}
-
-		if (p_dm->ant_div_type == CGCS_RX_HW_ANTDIV)
-			odm_rx_hw_ant_div_init_92e(p_dm);
-		else if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-			odm_trx_hw_ant_div_init_92e(p_dm);
-#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		else if (p_dm->ant_div_type == CG_TRX_SMART_ANTDIV)
-			odm_smart_hw_ant_div_init_92e(p_dm);
+	}
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+		odm_rx_hw_ant_div_init_92f(dm);
+	else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+	odm_trx_hw_ant_div_init_92f(dm);
+	}
 #endif
 
+#if (RTL8197F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8197F) {
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+
+		if (dm->ant_div_type != CGCS_RX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!]  8197F Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+		phydm_rx_hw_ant_div_init_97f(dm);
 	}
 #endif
-
-	/* 2 [--8723B---] */
+/* @2 [--8723B---] */
 #if (RTL8723B_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8723B) {
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
-		/* p_dm->ant_div_type = CG_TRX_HW_ANTDIV; */
-
-		if (p_dm->ant_div_type != S0S1_SW_ANTDIV && p_dm->ant_div_type != CG_TRX_HW_ANTDIV) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!] 8723B  Not Supprrt This AntDiv type\n"));
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		/* @dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type != S0S1_SW_ANTDIV &&
+		    dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!] 8723B  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 			return;
 		}
 
-		if (p_dm->ant_div_type == S0S1_SW_ANTDIV)
-			odm_s0s1_sw_ant_div_init_8723b(p_dm);
-		else if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-			odm_trx_hw_ant_div_init_8723b(p_dm);
+		if (dm->ant_div_type == S0S1_SW_ANTDIV)
+			odm_s0s1_sw_ant_div_init_8723b(dm);
+		else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_8723b(dm);
 	}
 #endif
-	/*2 [--8723D---]*/
+/*@2 [--8723D---]*/
 #if (RTL8723D_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8723D) {
-		if (p_dm_fat_table->p_default_s0_s1 == NULL) {
-			p_dm_fat_table->default_s0_s1 = 1;
-			p_dm_fat_table->p_default_s0_s1 = &(p_dm_fat_table->default_s0_s1);
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		if (fat_tab->p_default_s0_s1 == NULL) {
+			fat_tab->default_s0_s1 = 1;
+			fat_tab->p_default_s0_s1 = &fat_tab->default_s0_s1;
 		}
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("default_s0_s1 = %d\n", *p_dm_fat_table->p_default_s0_s1));
+		PHYDM_DBG(dm, DBG_ANT_DIV, "default_s0_s1 = %d\n",
+			  *fat_tab->p_default_s0_s1);
 
-		if (*(p_dm_fat_table->p_default_s0_s1) == true)
-			odm_update_rx_idle_ant(p_dm, MAIN_ANT);
+		if (*fat_tab->p_default_s0_s1 == true)
+			odm_update_rx_idle_ant(dm, MAIN_ANT);
 		else
-			odm_update_rx_idle_ant(p_dm, AUX_ANT);
+			odm_update_rx_idle_ant(dm, AUX_ANT);
 
-		if (p_dm->ant_div_type == S0S1_TRX_HW_ANTDIV)
-			odm_trx_hw_ant_div_init_8723d(p_dm);
+		if (dm->ant_div_type == S0S1_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_8723d(dm);
+		else if (dm->ant_div_type == S0S1_SW_ANTDIV)
+			odm_s0s1_sw_ant_div_init_8723d(dm);
 		else {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!] 8723D  Not Supprrt This AntDiv type\n"));
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				"[Return!!!] 8723D  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 			return;
 		}
-
 	}
 #endif
-	/* 2 [--8811A 8821A---] */
+#if (RTL8721D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8721D) {
+		/* @dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+
+		if (dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!]  8721D Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_trx_hw_ant_div_init_8721d(dm);
+	}
+#endif
+/* @2 [--8811A 8821A---] */
 #if (RTL8821A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8821) {
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-		p_dm->ant_div_type = HL_SW_SMART_ANT_TYPE1;
-
-		if (p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+	else if (dm->support_ic_type == ODM_RTL8821) {
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		dm->ant_div_type = HL_SW_SMART_ANT_TYPE1;
 
-			odm_trx_hw_ant_div_init_8821a(p_dm);
-			phydm_hl_smart_ant_type1_init_8821a(p_dm);
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+			odm_trx_hw_ant_div_init_8821a(dm);
+			phydm_hl_smart_ant_type1_init_8821a(dm);
 		} else
-		#endif
+#endif
 		{
-			#ifdef ODM_CONFIG_BT_COEXIST
-			p_dm->ant_div_type = S0S1_SW_ANTDIV;
-			#else
-			p_dm->ant_div_type = CG_TRX_HW_ANTDIV;
-			#endif
+#ifdef ODM_CONFIG_BT_COEXIST
+			dm->ant_div_type = S0S1_SW_ANTDIV;
+#else
+			dm->ant_div_type = CG_TRX_HW_ANTDIV;
+#endif
 
-			if (p_dm->ant_div_type != CG_TRX_HW_ANTDIV && p_dm->ant_div_type != S0S1_SW_ANTDIV) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!] 8821A & 8811A  Not Supprrt This AntDiv type\n"));
-				p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			if (dm->ant_div_type != CG_TRX_HW_ANTDIV &&
+			    dm->ant_div_type != S0S1_SW_ANTDIV) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[Return!!!] 8821A & 8811A  Not Supprrt This AntDiv type\n");
+				dm->support_ability &= ~(ODM_BB_ANT_DIV);
 				return;
 			}
-			if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-				odm_trx_hw_ant_div_init_8821a(p_dm);
-			else if (p_dm->ant_div_type == S0S1_SW_ANTDIV)
-				odm_s0s1_sw_ant_div_init_8821a(p_dm);
+			if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_trx_hw_ant_div_init_8821a(dm);
+			else if (dm->ant_div_type == S0S1_SW_ANTDIV)
+				odm_s0s1_sw_ant_div_init_8821a(dm);
 		}
 	}
 #endif
 
-	/* 2 [--8821C---] */
+/* @2 [--8821C---] */
 #if (RTL8821C_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8821C) {
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
-		if (p_dm->ant_div_type != S0S1_SW_ANTDIV) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!] 8821C  Not Supprrt This AntDiv type\n"));
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		if (dm->ant_div_type != S0S1_SW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!] 8821C  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 			return;
 		}
-		phydm_s0s1_sw_ant_div_init_8821c(p_dm);
-		odm_trx_hw_ant_div_init_8821c(p_dm);
+		phydm_s0s1_sw_ant_div_init_8821c(dm);
+		odm_trx_hw_ant_div_init_8821c(dm);
 	}
 #endif
 
-	/* 2 [--8881A---] */
+/* @2 [--8881A---] */
 #if (RTL8881A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8881A) {
-		/* p_dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
-		/* p_dm->ant_div_type = CG_TRX_HW_ANTDIV; */
-
-		if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+	else if (dm->support_ic_type == ODM_RTL8881A) {
+		/* @dm->ant_div_type = CGCS_RX_HW_ANTDIV; */
+		/* @dm->ant_div_type = CG_TRX_HW_ANTDIV; */
 
-			odm_trx_hw_ant_div_init_8881a(p_dm);
-			/**/
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+			odm_trx_hw_ant_div_init_8881a(dm);
 		} else {
-
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!] 8881A  Not Supprrt This AntDiv type\n"));
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!] 8881A  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 			return;
 		}
 
-		odm_trx_hw_ant_div_init_8881a(p_dm);
+		odm_trx_hw_ant_div_init_8881a(dm);
 	}
 #endif
 
-	/* 2 [--8812---] */
+/* @2 [--8812---] */
 #if (RTL8812A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8812) {
-		/* p_dm->ant_div_type = CG_TRX_HW_ANTDIV; */
+	else if (dm->support_ic_type == ODM_RTL8812) {
+		/* @dm->ant_div_type = CG_TRX_HW_ANTDIV; */
 
-		if (p_dm->ant_div_type != CG_TRX_HW_ANTDIV) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!] 8812A  Not Supprrt This AntDiv type\n"));
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+		if (dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!] 8812A  Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 			return;
 		}
-		odm_trx_hw_ant_div_init_8812a(p_dm);
+		odm_trx_hw_ant_div_init_8812a(dm);
 	}
 #endif
 
-	/*[--8188F---]*/
+/*@[--8188F---]*/
 #if (RTL8188F_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8188F) {
-
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
-		odm_s0s1_sw_ant_div_init_8188f(p_dm);
+	else if (dm->support_ic_type == ODM_RTL8188F) {
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		odm_s0s1_sw_ant_div_init_8188f(dm);
 	}
 #endif
 
-	/*[--8822B---]*/
+/*@[--8822B---]*/
 #if (RTL8822B_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8822B) {
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-		p_dm->ant_div_type = HL_SW_SMART_ANT_TYPE2;
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
 
-		if (p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE2)
-			phydm_hl_smart_ant_type2_init_8822b(p_dm);
-		#endif
+		if (dm->ant_div_type != CG_TRX_HW_ANTDIV) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[Return!!!]  8822B Not Supprrt This AntDiv type\n");
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
+			return;
+		}
+		phydm_trx_hw_ant_div_init_22b(dm);
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		dm->ant_div_type = HL_SW_SMART_ANT_TYPE2;
+
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE2)
+			phydm_hl_smart_ant_type2_init_8822b(dm);
+#endif
 	}
 #endif
 
-	/*
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** support_ic_type=[%lu]\n",p_dm->support_ic_type));
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** AntDiv support_ability=[%lu]\n",(p_dm->support_ability & ODM_BB_ANT_DIV)>>6));
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("*** AntDiv type=[%d]\n",p_dm->ant_div_type));
-	*/
+/*@PHYDM_DBG(dm, DBG_ANT_DIV, "*** support_ic_type=[%lu]\n",*/
+/*dm->support_ic_type);*/
+/*PHYDM_DBG(dm, DBG_ANT_DIV, "*** AntDiv support_ability=[%lu]\n",*/
+/*	  (dm->support_ability & ODM_BB_ANT_DIV)>>6);*/
+/*PHYDM_DBG(dm, DBG_ANT_DIV, "*** AntDiv type=[%d]\n",dm->ant_div_type);*/
 }
 
-void
-odm_ant_div(
-	void		*p_dm_void
-)
+void odm_ant_div(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER		*p_adapter	= p_dm->adapter;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 #if (defined(CONFIG_HL_SMART_ANTENNA))
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
 #endif
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
 
-	if (p_dm->is_linked) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("tp_active_occur=((%d)), EVM_method_enable=((%d))\n",
-		p_dm->tp_active_occur, p_dm_fat_table->EVM_method_enable));
-
-		if ((p_dm->tp_active_occur == 1) && (p_dm_fat_table->EVM_method_enable == 1)) {
+	if (dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "tp_active_occur=((%d)), evm_method_enable=((%d))\n",
+			  dm->tp_active_occur, fat_tab->evm_method_enable);
 
-			p_dm_fat_table->idx_ant_div_counter_5g = p_dm->antdiv_period;
-			p_dm_fat_table->idx_ant_div_counter_2g = p_dm->antdiv_period;
+		if (dm->tp_active_occur == 1 &&
+		    fat_tab->evm_method_enable == 1) {
+			fat_tab->idx_ant_div_counter_5g = dm->antdiv_period;
+			fat_tab->idx_ant_div_counter_2g = dm->antdiv_period;
 		}
 	}
 #endif
 
-	if (*p_dm->p_band_type == ODM_BAND_5G) {
-		if (p_dm_fat_table->idx_ant_div_counter_5g <  p_dm->antdiv_period) {
-			p_dm_fat_table->idx_ant_div_counter_5g++;
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (fat_tab->idx_ant_div_counter_5g < dm->antdiv_period) {
+			fat_tab->idx_ant_div_counter_5g++;
 			return;
 		} else
-			p_dm_fat_table->idx_ant_div_counter_5g = 0;
-	} else	if (*p_dm->p_band_type == ODM_BAND_2_4G) {
-		if (p_dm_fat_table->idx_ant_div_counter_2g <  p_dm->antdiv_period) {
-			p_dm_fat_table->idx_ant_div_counter_2g++;
+			fat_tab->idx_ant_div_counter_5g = 0;
+	} else if (*dm->band_type == ODM_BAND_2_4G) {
+		if (fat_tab->idx_ant_div_counter_2g < dm->antdiv_period) {
+			fat_tab->idx_ant_div_counter_2g++;
 			return;
 		} else
-			p_dm_fat_table->idx_ant_div_counter_2g = 0;
+			fat_tab->idx_ant_div_counter_2g = 0;
 	}
 
-	/* ---------- */
+/* @---------- */
 
-	/* ---------- */
+/* @---------- */
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN || DM_ODM_SUPPORT_TYPE == ODM_CE)
 
-	if (p_dm_fat_table->enable_ctrl_frame_antdiv) {
-
-		if ((p_dm->data_frame_num <= 10) && (p_dm->is_linked))
-			p_dm_fat_table->use_ctrl_frame_antdiv = 1;
+	if (fat_tab->enable_ctrl_frame_antdiv) {
+		if (dm->data_frame_num <= 10 && dm->is_linked)
+			fat_tab->use_ctrl_frame_antdiv = 1;
 		else
-			p_dm_fat_table->use_ctrl_frame_antdiv = 0;
+			fat_tab->use_ctrl_frame_antdiv = 0;
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("use_ctrl_frame_antdiv = (( %d )), data_frame_num = (( %d ))\n", p_dm_fat_table->use_ctrl_frame_antdiv, p_dm->data_frame_num));
-		p_dm->data_frame_num = 0;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "use_ctrl_frame_antdiv = (( %d )), data_frame_num = (( %d ))\n",
+			  fat_tab->use_ctrl_frame_antdiv, dm->data_frame_num);
+		dm->data_frame_num = 0;
 	}
 
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (p_adapter->MgntInfo.AntennaTest)
-		return;
-	#endif
-
 	{
-#if (BEAMFORMING_SUPPORT == 1)
-
-		enum beamforming_cap		beamform_cap = phydm_get_beamform_cap(p_dm);
-
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("is_bt_continuous_turn = ((%d))\n", p_dm->is_bt_continuous_turn));
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ AntDiv Beam Cap ]   cap= ((%d))\n", beamform_cap));
-	if (!p_dm->is_bt_continuous_turn) {
-			if ((beamform_cap & BEAMFORMEE_CAP) && (!(*p_dm_fat_table->is_no_csi_feedback))) { /* BFmee On  &&   Div On->Div Off */
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ AntDiv : OFF ]   BFmee ==1; cap= ((%d))\n", beamform_cap));
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ AntDiv BF]   is_no_csi_feedback= ((%d))\n", *(p_dm_fat_table->is_no_csi_feedback)));
-				if (p_dm_fat_table->fix_ant_bfee == 0) {
-					odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-					p_dm_fat_table->fix_ant_bfee = 1;
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+
+		enum beamforming_cap beamform_cap = phydm_get_beamform_cap(dm);
+		PHYDM_DBG(dm, DBG_ANT_DIV, "is_bt_continuous_turn = ((%d))\n",
+			  dm->is_bt_continuous_turn);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ AntDiv Beam Cap ]   cap= ((%d))\n", beamform_cap);
+		if (!dm->is_bt_continuous_turn) {
+			if ((beamform_cap & BEAMFORMEE_CAP) &&
+			    (!(*fat_tab->is_no_csi_feedback))) {
+			    /* @BFmee On  &&   Div On->Div Off */
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[ AntDiv : OFF ]   BFmee ==1; cap= ((%d))\n",
+					  beamform_cap);
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[ AntDiv BF]   is_no_csi_feedback= ((%d))\n",
+					  *(fat_tab->is_no_csi_feedback));
+				if (fat_tab->fix_ant_bfee == 0) {
+					odm_ant_div_on_off(dm, ANTDIV_OFF,
+							   ANT_PATH_A);
+					fat_tab->fix_ant_bfee = 1;
 				}
 				return;
-			} else { /* BFmee Off   &&   Div Off->Div On */
-				if ((p_dm_fat_table->fix_ant_bfee == 1)  &&  p_dm->is_linked) {
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ AntDiv : ON ]   BFmee ==0; cap=((%d))\n", beamform_cap));
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ AntDiv BF]   is_no_csi_feedback= ((%d))\n", *(p_dm_fat_table->is_no_csi_feedback)));
-					if (p_dm->ant_div_type != S0S1_SW_ANTDIV)
-						odm_ant_div_on_off(p_dm, ANTDIV_ON);
-
-					p_dm_fat_table->fix_ant_bfee = 0;
+			} else { /* @BFmee Off   &&   Div Off->Div On */
+				if (fat_tab->fix_ant_bfee == 1 &&
+				    dm->is_linked) {
+					PHYDM_DBG(dm, DBG_ANT_DIV,
+						  "[ AntDiv : ON ]   BFmee ==0; cap=((%d))\n",
+						  beamform_cap);
+					PHYDM_DBG(dm, DBG_ANT_DIV,
+						  "[ AntDiv BF]   is_no_csi_feedback= ((%d))\n",
+						  *fat_tab->is_no_csi_feedback);
+					if (dm->ant_div_type != S0S1_SW_ANTDIV)
+						odm_ant_div_on_off(dm, ANTDIV_ON
+								   , ANT_PATH_A)
+								   ;
+					fat_tab->fix_ant_bfee = 0;
 				}
 			}
-	}
+		} else {
+			if (fat_tab->div_path_type == ANT_PATH_A)
+				odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+			else if (fat_tab->div_path_type == ANT_PATH_B)
+				odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_B);
+			else if (fat_tab->div_path_type == ANT_PATH_AB)
+				odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_AB);
+		}
 #endif
 	}
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	/* ----------just for fool proof */
+	/* @----------just for fool proof */
 
-	if (p_dm->antdiv_rssi)
-		p_dm->debug_components |= DBG_ANT_DIV;
+	if (dm->antdiv_rssi)
+		dm->debug_components |= DBG_ANT_DIV;
 	else
-		p_dm->debug_components &= ~DBG_ANT_DIV;
+		dm->debug_components &= ~DBG_ANT_DIV;
 
-	if (p_dm_fat_table->ant_div_2g_5g == ODM_ANTDIV_2G) {
-		/* PHYDM_DBG(p_dm, DBG_ANT_DIV,("[ 2G AntDiv Running ]\n")); */
-		if (!(p_dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
+	if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_2G) {
+#if 0
+		/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 2G AntDiv Running ]\n"); */
+#endif
+		if (!(dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC))
 			return;
-	} else if (p_dm_fat_table->ant_div_2g_5g == ODM_ANTDIV_5G) {
-		/* PHYDM_DBG(p_dm, DBG_ANT_DIV,("[ 5G AntDiv Running ]\n")); */
-		if (!(p_dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
+	} else if (fat_tab->ant_div_2g_5g == ODM_ANTDIV_5G) {
+#if 0
+		/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 5G AntDiv Running ]\n"); */
+#endif
+		if (!(dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC))
 			return;
 	}
-	/* else 	if(p_dm_fat_table->ant_div_2g_5g == (ODM_ANTDIV_2G|ODM_ANTDIV_5G)) */
-	/* { */
-	/* PHYDM_DBG(p_dm, DBG_ANT_DIV,("[ 2G & 5G AntDiv Running ]\n")); */
-	/* } */
+#if 0
+/* @else 	if(fat_tab->ant_div_2g_5g == (ODM_ANTDIV_2G|ODM_ANTDIV_5G)) */
+/* @{ */
+/* PHYDM_DBG(dm, DBG_ANT_DIV,"[ 2G & 5G AntDiv Running ]\n"); */
+/* @} */
+#endif
 #endif
 
-	/* ---------- */
+	/* @---------- */
 
-	if (p_dm->antdiv_select == 1)
-		p_dm->ant_type = ODM_FIX_MAIN_ANT;
-	else if (p_dm->antdiv_select == 2)
-		p_dm->ant_type = ODM_FIX_AUX_ANT;
-	else { /* if (p_dm->antdiv_select==0) */
-		p_dm->ant_type = ODM_AUTO_ANT;
+	if (dm->antdiv_select == 1)
+		dm->ant_type = ODM_FIX_MAIN_ANT;
+	else if (dm->antdiv_select == 2)
+		dm->ant_type = ODM_FIX_AUX_ANT;
+	else { /* @if (dm->antdiv_select==0) */
+		dm->ant_type = ODM_AUTO_ANT;
 
-		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 		/*Stop Antenna diversity for CMW500 testing case*/
-		if (p_dm->consecutive_idlel_time >= 10) {
-			p_dm->ant_type = ODM_FIX_MAIN_ANT;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[AntDiv: OFF] No TP case, consecutive_idlel_time=((%d))\n", p_dm->consecutive_idlel_time));
+		if (dm->consecutive_idlel_time >= 10) {
+			dm->ant_type = ODM_FIX_MAIN_ANT;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "[AntDiv: OFF] No TP case, consecutive_idlel_time=((%d))\n",
+				  dm->consecutive_idlel_time);
 		}
-		#endif
+#endif
 	}
 
-	/* PHYDM_DBG(p_dm, DBG_ANT_DIV,("ant_type= (( %d )) , pre_ant_type= (( %d ))\n",p_dm->ant_type,p_dm->pre_ant_type)); */
+#if 0
+	/* PHYDM_DBG(dm, DBG_ANT_DIV,"ant_type= (%d), pre_ant_type= (%d)\n",*/
+	/*dm->ant_type,dm->pre_ant_type); */
+#endif
 
-	if (p_dm->ant_type != ODM_AUTO_ANT) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Fix Antenna at (( %s ))\n", (p_dm->ant_type == ODM_FIX_MAIN_ANT) ? "MAIN" : "AUX"));
+	if (dm->ant_type != ODM_AUTO_ANT) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Fix Antenna at (( %s ))\n",
+			  (dm->ant_type == ODM_FIX_MAIN_ANT) ? "MAIN" : "AUX");
 
-		if (p_dm->ant_type != p_dm->pre_ant_type) {
-			odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
+		if (dm->ant_type != dm->pre_ant_type) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
 
-			if (p_dm->ant_type == ODM_FIX_MAIN_ANT)
-				odm_update_rx_idle_ant(p_dm, MAIN_ANT);
-			else if (p_dm->ant_type == ODM_FIX_AUX_ANT)
-				odm_update_rx_idle_ant(p_dm, AUX_ANT);
+			if (dm->ant_type == ODM_FIX_MAIN_ANT)
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			else if (dm->ant_type == ODM_FIX_AUX_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
 		}
-		p_dm->pre_ant_type = p_dm->ant_type;
+		dm->pre_ant_type = dm->ant_type;
 		return;
 	} else {
-		if (p_dm->ant_type != p_dm->pre_ant_type) {
-			odm_ant_div_on_off(p_dm, ANTDIV_ON);
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_DESC);
+		if (dm->ant_type != dm->pre_ant_type) {
+			odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
+		}
+		dm->pre_ant_type = dm->ant_type;
+	}
+#if (defined(CONFIG_2T4R_ANTENNA))
+	if (dm->ant_type2 != ODM_AUTO_ANT) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "PathB Fix Ant at (( %s ))\n",
+			  (dm->ant_type2 == ODM_FIX_MAIN_ANT) ? "MAIN" : "AUX");
+
+		if (dm->ant_type2 != dm->pre_ant_type2) {
+			odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_B);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+
+			if (dm->ant_type2 == ODM_FIX_MAIN_ANT)
+				phydm_update_rx_idle_ant_pathb(dm, MAIN_ANT);
+			else if (dm->ant_type2 == ODM_FIX_AUX_ANT)
+				phydm_update_rx_idle_ant_pathb(dm, AUX_ANT);
 		}
-		p_dm->pre_ant_type = p_dm->ant_type;
+		dm->pre_ant_type2 = dm->ant_type2;
+		return;
+	}
+	if (dm->ant_type2 != dm->pre_ant_type2) {
+		odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_B);
+		odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
 	}
+	dm->pre_ant_type2 = dm->ant_type2;
 
+#endif
 
-	/* 3 ----------------------------------------------------------------------------------------------------------- */
-	/* 2 [--88E---] */
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
+	/* @3 ----------------------------------------------- */
+	/* @2 [--88E---] */
+	if (dm->support_ic_type == ODM_RTL8188E) {
 #if (RTL8188E_SUPPORT == 1)
-		if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV || p_dm->ant_div_type == CGCS_RX_HW_ANTDIV)
-			odm_hw_ant_div(p_dm);
-
-#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		else if (p_dm->ant_div_type == CG_TRX_SMART_ANTDIV)
-			odm_fast_ant_training(p_dm);
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV ||
+		    dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\
+	(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_fast_ant_training(dm);
 #endif
 
 #endif
-
 	}
-	/* 2 [--92E---] */
+/* @2 [--92E---] */
 #if (RTL8192E_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8192E) {
-		if (p_dm->ant_div_type == CGCS_RX_HW_ANTDIV || p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-			odm_hw_ant_div(p_dm);
-
-#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		else if (p_dm->ant_div_type == CG_TRX_SMART_ANTDIV)
-			odm_fast_ant_training(p_dm);
+	else if (dm->support_ic_type == ODM_RTL8192E) {
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV ||
+		    dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\
+	(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		else if (dm->ant_div_type == CG_TRX_SMART_ANTDIV)
+			odm_fast_ant_training(dm);
 #endif
-
+	}
+#endif
+/* @2 [--97F---] */
+#if (RTL8197F_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8197F) {
+		if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
 	}
 #endif
 
 #if (RTL8723B_SUPPORT == 1)
-	/* 2 [--8723B---] */
-	else if (p_dm->support_ic_type == ODM_RTL8723B) {
-		if (phydm_is_bt_enable_8723b(p_dm)) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[BT is enable!!!]\n"));
-			if (p_dm_fat_table->is_become_linked == true) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Set REG 948[9:6]=0x0\n"));
-				if (p_dm->support_ic_type == ODM_RTL8723B)
-					odm_set_bb_reg(p_dm, 0x948, BIT(9) | BIT(8) | BIT(7) | BIT(6), 0x0);
-
-				p_dm_fat_table->is_become_linked = false;
+	/* @2 [--8723B---] */
+	else if (dm->support_ic_type == ODM_RTL8723B) {
+		if (phydm_is_bt_enable_8723b(dm)) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[BT is enable!!!]\n");
+			if (fat_tab->is_become_linked == true) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Set REG 948[9:6]=0x0\n");
+				if (dm->support_ic_type == ODM_RTL8723B)
+					odm_set_bb_reg(dm, R_0x948, 0x3c0, 0x0)
+						       ;
+
+				fat_tab->is_become_linked = false;
 			}
 		} else {
-			if (p_dm->ant_div_type == S0S1_SW_ANTDIV) {
-
+			if (dm->ant_div_type == S0S1_SW_ANTDIV) {
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-				odm_s0s1_sw_ant_div(p_dm, SWAW_STEP_PEEK);
+				odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
 #endif
-			} else if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-				odm_hw_ant_div(p_dm);
+			} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_hw_ant_div(dm);
 		}
 	}
 #endif
-	/*8723D*/
+/*@8723D*/
 #if (RTL8723D_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8723D) {
-
-		odm_hw_ant_div(p_dm);
-		/**/
+	else if (dm->support_ic_type == ODM_RTL8723D) {
+		if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+			if (dm->antdiv_counter ==
+				CONFIG_ANTDIV_PERIOD) {
+				odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+				dm->antdiv_counter--;
+			} else {
+				dm->antdiv_counter--;
+			}
+			if (dm->antdiv_counter == 0)
+				dm->antdiv_counter = CONFIG_ANTDIV_PERIOD;
+#endif
+		} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+			odm_hw_ant_div(dm);
+		}
 	}
 #endif
-
-	/* 2 [--8821A---] */
+#if (RTL8721D_SUPPORT == 1)
+	else if (dm->support_ic_type == ODM_RTL8721D) {
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+			odm_hw_ant_div(dm);
+		}
+	}
+#endif
+/* @2 [--8821A---] */
 #if (RTL8821A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8821) {
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-		if (p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
-
-			if (pdm_sat_table->fix_beam_pattern_en != 0) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, (" [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n", pdm_sat_table->fix_beam_pattern_codeword));
+	else if (dm->support_ic_type == ODM_RTL8821) {
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+			if (sat_tab->fix_beam_pattern_en != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  " [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n",
+					  sat_tab->fix_beam_pattern_codeword);
 				/*return;*/
 			} else {
-				/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] ant_div_type = HL_SW_SMART_ANT_TYPE1\n"));*/
-				odm_fast_ant_training_hl_smart_antenna_type1(p_dm);
+#if 0
+/*PHYDM_DBG(dm,DBG_ANT_DIV,"[SmartAnt] ant_div_type=HL_SW_SMART_ANT_TYPE1\n");*/
+#endif
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
 			}
 
 		} else
-		#endif
+#endif
 		{
-
-			#ifdef ODM_CONFIG_BT_COEXIST
-			if (!p_dm->bt_info_table.is_bt_enabled) { /*BT disabled*/
-				if (p_dm->ant_div_type == S0S1_SW_ANTDIV) {
-					p_dm->ant_div_type = CG_TRX_HW_ANTDIV;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, (" [S0S1_SW_ANTDIV]  ->  [CG_TRX_HW_ANTDIV]\n"));
-					/*odm_set_bb_reg(p_dm, 0x8D4, BIT24, 1); */
-					if (p_dm_fat_table->is_become_linked == true)
-						odm_ant_div_on_off(p_dm, ANTDIV_ON);
+#ifdef ODM_CONFIG_BT_COEXIST
+			if (!dm->bt_info_table.is_bt_enabled) { /*@BT disabled*/
+				if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+					dm->ant_div_type = CG_TRX_HW_ANTDIV;
+					PHYDM_DBG(dm, DBG_ANT_DIV,
+						  " [S0S1_SW_ANTDIV]  ->  [CG_TRX_HW_ANTDIV]\n");
+#if 0
+				/*odm_set_bb_reg(dm, R_0x8d4, BIT24, 1); */
+#endif
+					if (fat_tab->is_become_linked == true)
+						odm_ant_div_on_off(dm,
+								   ANTDIV_ON,
+								   ANT_PATH_A);
 				}
 
-			} else { /*BT enabled*/
+			} else { /*@BT enabled*/
 
-				if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV) {
-					p_dm->ant_div_type = S0S1_SW_ANTDIV;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, (" [CG_TRX_HW_ANTDIV]  ->  [S0S1_SW_ANTDIV]\n"));
-					/*odm_set_bb_reg(p_dm, 0x8D4, BIT24, 0);*/
-					odm_ant_div_on_off(p_dm, ANTDIV_OFF);
+				if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+					dm->ant_div_type = S0S1_SW_ANTDIV;
+					PHYDM_DBG(dm, DBG_ANT_DIV,
+						  " [CG_TRX_HW_ANTDIV]  ->  [S0S1_SW_ANTDIV]\n");
+#if 0
+				/*odm_set_bb_reg(dm, R_0x8d4, BIT24, 0);*/
+#endif
+					odm_ant_div_on_off(dm, ANTDIV_OFF,
+							   ANT_PATH_A);
 				}
 			}
-			#endif
-
-			if (p_dm->ant_div_type == S0S1_SW_ANTDIV) {
+#endif
 
-				#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-				odm_s0s1_sw_ant_div(p_dm, SWAW_STEP_PEEK);
-				#endif
-			} else if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-				odm_hw_ant_div(p_dm);
+			if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+				odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
+#endif
+			} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+				odm_hw_ant_div(dm);
 		}
 	}
 #endif
 
-	/* 2 [--8821C---] */
+/* @2 [--8821C---] */
 #if (RTL8821C_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8821C) {
-		if (!p_dm->is_bt_continuous_turn) {
-			p_dm->ant_div_type = S0S1_SW_ANTDIV;
-			ODM_RT_TRACE(p_dm, DBG_ANT_DIV, ODM_DBG_LOUD, ("is_bt_continuous_turn = ((%d))   ==> SW AntDiv\n", p_dm->is_bt_continuous_turn));
+	else if (dm->support_ic_type == ODM_RTL8821C) {
+		if (!dm->is_bt_continuous_turn) {
+			dm->ant_div_type = S0S1_SW_ANTDIV;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "is_bt_continuous_turn = ((%d))   ==> SW AntDiv\n",
+				  dm->is_bt_continuous_turn);
 
 		} else {
-			p_dm->ant_div_type = CG_TRX_HW_ANTDIV;
-			ODM_RT_TRACE(p_dm, DBG_ANT_DIV, ODM_DBG_LOUD, ("is_bt_continuous_turn = ((%d))   ==> HW AntDiv\n", p_dm->is_bt_continuous_turn));
+			dm->ant_div_type = CG_TRX_HW_ANTDIV;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "is_bt_continuous_turn = ((%d))   ==> HW AntDiv\n",
+				  dm->is_bt_continuous_turn);
+			odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
 		}
 
-		if (p_dm->ant_div_type == S0S1_SW_ANTDIV) {
+		if (fat_tab->force_antdiv_type)
+			dm->ant_div_type = fat_tab->antdiv_type_dbg;
 
+		if (dm->ant_div_type == S0S1_SW_ANTDIV) {
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-			odm_s0s1_sw_ant_div(p_dm, SWAW_STEP_PEEK);
+			odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
 #endif
-		} else if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV)
-			odm_hw_ant_div(p_dm);
+		} else if (dm->ant_div_type == CG_TRX_HW_ANTDIV) {
+			odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+			odm_hw_ant_div(dm);
+		}
 	}
 #endif
 
-	/* 2 [--8881A---] */
+/* @2 [--8881A---] */
 #if (RTL8881A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8881A)
-		odm_hw_ant_div(p_dm);
+	else if (dm->support_ic_type == ODM_RTL8881A)
+		odm_hw_ant_div(dm);
 #endif
 
-	/* 2 [--8812A---] */
+/* @2 [--8812A---] */
 #if (RTL8812A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8812)
-		odm_hw_ant_div(p_dm);
+	else if (dm->support_ic_type == ODM_RTL8812)
+		odm_hw_ant_div(dm);
 #endif
 
 #if (RTL8188F_SUPPORT == 1)
-	/* [--8188F---]*/
-	else if (p_dm->support_ic_type == ODM_RTL8188F)	{
-
+	/* @[--8188F---]*/
+	else if (dm->support_ic_type == ODM_RTL8188F) {
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		odm_s0s1_sw_ant_div(p_dm, SWAW_STEP_PEEK);
+		odm_s0s1_sw_ant_div(dm, SWAW_STEP_PEEK);
 #endif
 	}
 #endif
 
-	/* [--8822B---]*/
+/* @[--8822B---]*/
 #if (RTL8822B_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8822B) {
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-		if (p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) {
-
-			if (pdm_sat_table->fix_beam_pattern_en != 0)
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, (" [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n", pdm_sat_table->fix_beam_pattern_codeword));
+	else if (dm->support_ic_type == ODM_RTL8822B) {
+		if (dm->ant_div_type == CG_TRX_HW_ANTDIV)
+			odm_hw_ant_div(dm);
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) {
+			if (sat_tab->fix_beam_pattern_en != 0)
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  " [ SmartAnt ] Fix SmartAnt Pattern = 0x%x\n",
+					  sat_tab->fix_beam_pattern_codeword);
 			else
-				phydm_fast_ant_training_hl_smart_antenna_type2(p_dm);
+				phydm_fast_ant_training_hl_smart_antenna_type2(dm);
 		}
-		#endif
+#endif
 	}
 #endif
-
-
 }
 
-
-void
-odm_antsel_statistics(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	u8			antsel_tr_mux,
-	u32			mac_id,
-	u32			utility,
-	u8			method,
-	u8			is_cck_rate
-
-)
+void odm_antsel_statistics(void *dm_void, void *phy_info_void,
+			   u8 antsel_tr_mux, u32 mac_id, u32 utility, u8 method,
+			   u8 is_cck_rate)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct phydm_phyinfo_struct	*p_phy_info = (struct phydm_phyinfo_struct *)p_phy_info_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct phydm_phyinfo_struct *phy_info = NULL;
 
-	if (method == RSSI_METHOD) {
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
 
+	if (method == RSSI_METHOD) {
 		if (is_cck_rate) {
 			if (antsel_tr_mux == ANT1_2G) {
-				if (p_dm_fat_table->main_ant_sum_cck[mac_id] > 65435) /*to prevent u16 overflow, max(RSSI)=100, 65435+100 = 65535 (u16)*/
+	/*to prevent u16 overflow, max(RSSI)=100, 65435+100 = 65535 (u16)*/
+				if (fat_tab->main_sum_cck[mac_id] > 65435)
 					return;
 
-				p_dm_fat_table->main_ant_sum_cck[mac_id] += (u16)utility;
-				p_dm_fat_table->main_ant_cnt_cck[mac_id]++;
+				fat_tab->main_sum_cck[mac_id] += (u16)utility;
+				fat_tab->main_cnt_cck[mac_id]++;
 			} else {
-				if (p_dm_fat_table->aux_ant_sum_cck[mac_id] > 65435)
+				if (fat_tab->aux_sum_cck[mac_id] > 65435)
 					return;
 
-				p_dm_fat_table->aux_ant_sum_cck[mac_id] += (u16)utility;
-				p_dm_fat_table->aux_ant_cnt_cck[mac_id]++;
+				fat_tab->aux_sum_cck[mac_id] += (u16)utility;
+				fat_tab->aux_cnt_cck[mac_id]++;
 			}
 
 		} else { /*ofdm rate*/
 
 			if (antsel_tr_mux == ANT1_2G) {
-				if (p_dm_fat_table->main_ant_sum[mac_id] > 65435)
+				if (fat_tab->main_sum[mac_id] > 65435)
 					return;
 
-				p_dm_fat_table->main_ant_sum[mac_id] += (u16)utility;
-				p_dm_fat_table->main_ant_cnt[mac_id]++;
+				fat_tab->main_sum[mac_id] += (u16)utility;
+				fat_tab->main_cnt[mac_id]++;
 			} else {
-				if (p_dm_fat_table->aux_ant_sum[mac_id] > 65435)
+				if (fat_tab->aux_sum[mac_id] > 65435)
 					return;
 
-				p_dm_fat_table->aux_ant_sum[mac_id] += (u16)utility;
-				p_dm_fat_table->aux_ant_cnt[mac_id]++;
+				fat_tab->aux_sum[mac_id] += (u16)utility;
+				fat_tab->aux_cnt[mac_id]++;
 			}
 		}
 	}
 #ifdef ODM_EVM_ENHANCE_ANTDIV
 	else if (method == EVM_METHOD) {
-		if (p_dm->rate_ss == 1) {
-
-			if (antsel_tr_mux == ANT1_2G) {
-				p_dm_fat_table->main_ant_evm_sum[mac_id] += ((p_phy_info->rx_mimo_evm_dbm[0])<<5);
-				p_dm_fat_table->main_ant_evm_cnt[mac_id]++;
-			} else {
-				p_dm_fat_table->aux_ant_evm_sum[mac_id] += ((p_phy_info->rx_mimo_evm_dbm[0])<<5);
-				p_dm_fat_table->aux_ant_evm_cnt[mac_id]++;
-			}
-
-		} else {/*>= 2SS*/
-
-			if (antsel_tr_mux == ANT1_2G) {
-
-				p_dm_fat_table->main_ant_evm_2ss_sum[mac_id][0] += (p_phy_info->rx_mimo_evm_dbm[0]<<5);
-				p_dm_fat_table->main_ant_evm_2ss_sum[mac_id][1] += (p_phy_info->rx_mimo_evm_dbm[1]<<5);
-				p_dm_fat_table->main_ant_evm_2ss_cnt[mac_id]++;
-
-			} else {
-
-				p_dm_fat_table->aux_ant_evm_2ss_sum[mac_id][0] += (p_phy_info->rx_mimo_evm_dbm[0]<<5);
-				p_dm_fat_table->aux_ant_evm_2ss_sum[mac_id][1] += (p_phy_info->rx_mimo_evm_dbm[1]<<5);
-				p_dm_fat_table->aux_ant_evm_2ss_cnt[mac_id]++;
-			}
+		if (dm->rate_ss == 1) {
+			phydm_statistics_evm_1ss(dm, phy_info, antsel_tr_mux,
+						 mac_id, utility);
+		} else { /*@>= 2SS*/
+			phydm_statistics_evm_2ss(dm, phy_info, antsel_tr_mux,
+						 mac_id, utility);
 		}
 
 	} else if (method == CRC32_METHOD) {
-
 		if (antsel_tr_mux == ANT1_2G) {
-			p_dm_fat_table->main_crc32_ok_cnt += utility;
-			p_dm_fat_table->main_crc32_fail_cnt++;
+			fat_tab->main_crc32_ok_cnt += utility;
+			fat_tab->main_crc32_fail_cnt++;
 		} else {
-			p_dm_fat_table->aux_crc32_ok_cnt += utility;
-			p_dm_fat_table->aux_crc32_fail_cnt++;
+			fat_tab->aux_crc32_ok_cnt += utility;
+			fat_tab->aux_crc32_fail_cnt++;
 		}
 
 	} else if (method == TP_METHOD) {
-		if (((utility <= ODM_RATEMCS15) && (utility >= ODM_RATEMCS0)) &&
-			(p_dm_fat_table->fat_state_cnt <= p_dm->antdiv_tp_period)
-		) {
-
+		if ((utility <= ODM_RATEMCS15 && utility >= ODM_RATEMCS0) &&
+		    fat_tab->fat_state_cnt <= dm->antdiv_tp_period) {
 			if (antsel_tr_mux == ANT1_2G) {
-				p_dm_fat_table->antdiv_tp_main += (phy_rate_table[utility])<<5;
-				p_dm_fat_table->antdiv_tp_main_cnt++;
+				fat_tab->main_tp += (phy_rate_table[utility])
+						    << 5;
+				fat_tab->main_tp_cnt++;
 			} else {
-				p_dm_fat_table->antdiv_tp_aux += (phy_rate_table[utility])<<5;
-				p_dm_fat_table->antdiv_tp_aux_cnt++;
+				fat_tab->aux_tp += (phy_rate_table[utility])
+						   << 5;
+				fat_tab->aux_tp_cnt++;
 			}
 		}
 	}
 #endif
 }
 
-void
-odm_process_rssi_for_ant_div(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	void			*p_pkt_info_void
-)
+void odm_process_rssi_smart(void *dm_void, void *phy_info_void,
+			    void *pkt_info_void, u8 rx_power_ant0)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_phyinfo_struct			*p_phy_info = (struct phydm_phyinfo_struct *)p_phy_info_void;
-	struct phydm_perpkt_info_struct				*p_pktinfo = (struct phydm_perpkt_info_struct *)p_pkt_info_void;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-#if (defined(CONFIG_HL_SMART_ANTENNA))
-	struct smt_ant_honbo	*pdm_sat_table = &(p_dm->dm_sat_table);
-	u32			beam_tmp;
-	u8			next_ant;
-	u8			train_pkt_number;
-#endif
-	u8			is_cck_rate = FALSE;
-	u8			rx_power_ant0 = p_phy_info->rx_mimo_signal_strength[0];
-	u8			rx_power_ant1 = p_phy_info->rx_mimo_signal_strength[1];
-	u8			rx_evm_ant0 = p_phy_info->rx_mimo_signal_quality[0];
-	u8			rx_evm_ant1 = p_phy_info->rx_mimo_signal_quality[1];
-	u8			rssi_avg;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct *phy_info = NULL;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+
+	if ((dm->support_ic_type & ODM_SMART_ANT_SUPPORT) &&
+	    pktinfo->is_packet_to_self &&
+	    fat_tab->fat_state == FAT_TRAINING_STATE) {
+	/* @(pktinfo->is_packet_match_bssid && (!pktinfo->is_packet_beacon)) */
+		u8 antsel_tr_mux;
+
+		antsel_tr_mux = (fat_tab->antsel_rx_keep_2 << 2) |
+				(fat_tab->antsel_rx_keep_1 << 1) |
+				fat_tab->antsel_rx_keep_0;
+		fat_tab->ant_sum_rssi[antsel_tr_mux] += rx_power_ant0;
+		fat_tab->ant_rssi_cnt[antsel_tr_mux]++;
+	}
+}
+
+void odm_process_rssi_normal(void *dm_void, void *phy_info_void,
+			     void *pkt_info_void, u8 rx_power_ant0)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct *phy_info = NULL;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u8 rx_evm_ant0, rx_evm_ant1;
+
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	rx_evm_ant0 = phy_info->rx_mimo_signal_quality[0];
+	rx_evm_ant1 = phy_info->rx_mimo_signal_quality[1];
+
+	if ((dm->support_ic_type & ODM_ANTDIV_SUPPORT) &&
+	    (pktinfo->is_packet_to_self ||
+	    fat_tab->use_ctrl_frame_antdiv)) {
+		if (dm->ant_div_type == S0S1_SW_ANTDIV) {
+			if (pktinfo->is_cck_rate ||
+			    dm->support_ic_type == ODM_RTL8188F) {
+				boolean b_main;
+
+				b_main = (fat_tab->rx_idle_ant == MAIN_ANT);
+				fat_tab->antsel_rx_keep_0 = b_main ? ANT1_2G :
+							    ANT2_2G;
+			}
+
+			odm_antsel_statistics(dm, phy_info,
+					      fat_tab->antsel_rx_keep_0,
+					      pktinfo->station_id,
+					      rx_power_ant0, RSSI_METHOD,
+					      pktinfo->is_cck_rate);
+		} else {
+			odm_antsel_statistics(dm, phy_info,
+					      fat_tab->antsel_rx_keep_0,
+					      pktinfo->station_id,
+					      rx_power_ant0, RSSI_METHOD,
+					      pktinfo->is_cck_rate);
+
+			#ifdef ODM_EVM_ENHANCE_ANTDIV
+			if (!(dm->support_ic_type & ODM_EVM_ANTDIV_IC))
+				return;
+			if (pktinfo->is_cck_rate)
+				return;
+
+			odm_antsel_statistics(dm, phy_info,
+					      fat_tab->antsel_rx_keep_0,
+					      pktinfo->station_id,
+					      rx_evm_ant0, EVM_METHOD,
+					      pktinfo->is_cck_rate);
+			odm_antsel_statistics(dm, phy_info,
+					      fat_tab->antsel_rx_keep_0,
+					      pktinfo->station_id,
+					      rx_evm_ant0, TP_METHOD,
+					      pktinfo->is_cck_rate);
 
-	is_cck_rate = (p_pktinfo->data_rate <= ODM_RATE11M) ? true : false;
+			#endif
+		}
+	}
+}
 
-	if ((p_dm->support_ic_type & ODM_IC_2SS) && (!is_cck_rate)) {
+void odm_process_rssi_for_ant_div(void *dm_void, void *phy_info_void,
+				  void *pkt_info_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct *phy_info = NULL;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u32 beam_tmp;
+	u8 next_ant;
+	u8 train_pkt_number;
+#endif
+	boolean b_main;
+	u8 rx_power_ant0, rx_power_ant1;
+	u8 rx_evm_ant0, rx_evm_ant1;
+	u8 rssi_avg;
+	u64 rssi_linear = 0;
+
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	rx_power_ant0 = phy_info->rx_mimo_signal_strength[0];
+	rx_power_ant1 = phy_info->rx_mimo_signal_strength[1];
+	rx_evm_ant0 = phy_info->rx_mimo_signal_quality[0];
+	rx_evm_ant1 = phy_info->rx_mimo_signal_quality[1];
+
+	if ((dm->support_ic_type & ODM_IC_2SS) && !pktinfo->is_cck_rate) {
+		if (rx_power_ant1 < 100) {
+			rssi_linear = phydm_db_2_linear(rx_power_ant0) +
+				      phydm_db_2_linear(rx_power_ant1);
+			/* @Rounding and removing fractional bits */
+			rssi_linear = (rssi_linear +
+				       (1 << (FRAC_BITS - 1))) >> FRAC_BITS;
+			/* @Calculate average RSSI */
+			rssi_linear = DIVIDED_2(rssi_linear);
+			/* @averaged PWDB */
+			rssi_avg = (u8)odm_convert_to_db(rssi_linear);
+		}
 
-		if (rx_power_ant1 < 100)
-			rssi_avg = (u8)odm_convert_to_db((odm_convert_to_linear(rx_power_ant0) + odm_convert_to_linear(rx_power_ant1))>>1); /*averaged PWDB*/
-		
 	} else {
-		rx_power_ant0 = (u8)p_phy_info->rx_pwdb_all;
+		rx_power_ant0 = (u8)phy_info->rx_pwdb_all;
 		rssi_avg = rx_power_ant0;
 	}
-	
+
 #ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-	if ((p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) && (p_dm_fat_table->fat_state == FAT_TRAINING_STATE))
-		phydm_process_rssi_for_hb_smtant_type2(p_dm, p_phy_info, p_pktinfo, rssi_avg);	/*for 8822B*/
+	if ((dm->ant_div_type == HL_SW_SMART_ANT_TYPE2) && (fat_tab->fat_state == FAT_TRAINING_STATE))
+		phydm_process_rssi_for_hb_smtant_type2(dm, phy_info, pktinfo, rssi_avg); /*@for 8822B*/
 	else
 #endif
 
 #ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
 #ifdef CONFIG_FAT_PATCH
-	if ((p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) && (p_dm_fat_table->fat_state == FAT_TRAINING_STATE)) {
-
-		/*[Beacon]*/
-		if (p_pktinfo->is_packet_beacon) {
-
-			pdm_sat_table->beacon_counter++;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("MatchBSSID_beacon_counter = ((%d))\n", pdm_sat_table->beacon_counter));
-
-			if (pdm_sat_table->beacon_counter >= pdm_sat_table->pre_beacon_counter + 2) {
-
-				if (pdm_sat_table->ant_num > 1) {
-					next_ant = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
-					odm_update_rx_idle_ant(p_dm, next_ant);
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1 && fat_tab->fat_state == FAT_TRAINING_STATE) {
+		/*@[Beacon]*/
+		if (pktinfo->is_packet_beacon) {
+			sat_tab->beacon_counter++;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "MatchBSSID_beacon_counter = ((%d))\n",
+				  sat_tab->beacon_counter);
+
+			if (sat_tab->beacon_counter >= sat_tab->pre_beacon_counter + 2) {
+				if (sat_tab->ant_num > 1) {
+					next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+					odm_update_rx_idle_ant(dm, next_ant);
 				}
 
-				pdm_sat_table->update_beam_idx++;
+				sat_tab->update_beam_idx++;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
-					pdm_sat_table->pre_beacon_counter, pdm_sat_table->pkt_counter, pdm_sat_table->update_beam_idx));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
+					  sat_tab->pre_beacon_counter,
+					  sat_tab->pkt_counter,
+					  sat_tab->update_beam_idx);
 
-				pdm_sat_table->pre_beacon_counter = pdm_sat_table->beacon_counter;
-				pdm_sat_table->pkt_counter = 0;
+				sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+				sat_tab->pkt_counter = 0;
 			}
 		}
-		/*[data]*/
-		else if (p_pktinfo->is_packet_to_self) {
-
-			if (pdm_sat_table->pkt_skip_statistic_en == 0) {
-				/*
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
-					p_pktinfo->station_id, p_dm_fat_table->antsel_rx_keep_0, p_dm_fat_table->hw_antsw_occur, pdm_sat_table->fast_training_beam_num, rx_power_ant0));
+		/*@[data]*/
+		else if (pktinfo->is_packet_to_self) {
+			if (sat_tab->pkt_skip_statistic_en == 0) {
+				/*@
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, fat_tab->hw_antsw_occur, sat_tab->fast_training_beam_num, rx_power_ant0);
 				*/
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("ID[%d][pkt_cnt = %d]: {ANT, Beam} = {%d, %d}, RSSI = ((%d))\n",
-					p_pktinfo->station_id, pdm_sat_table->pkt_counter, p_dm_fat_table->antsel_rx_keep_0, pdm_sat_table->fast_training_beam_num, rx_power_ant0));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "ID[%d][pkt_cnt = %d]: {ANT, Beam} = {%d, %d}, RSSI = ((%d))\n",
+					  pktinfo->station_id,
+					  sat_tab->pkt_counter,
+					  fat_tab->antsel_rx_keep_0,
+					  sat_tab->fast_training_beam_num,
+					  rx_power_ant0);
+
+				sat_tab->pkt_rssi_sum[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num] += rx_power_ant0;
+				sat_tab->pkt_rssi_cnt[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num]++;
+				sat_tab->pkt_counter++;
 
-				pdm_sat_table->pkt_rssi_sum[p_dm_fat_table->antsel_rx_keep_0][pdm_sat_table->fast_training_beam_num] += rx_power_ant0;
-				pdm_sat_table->pkt_rssi_cnt[p_dm_fat_table->antsel_rx_keep_0][pdm_sat_table->fast_training_beam_num]++;
-				pdm_sat_table->pkt_counter++;
-
-				#if 1
-				train_pkt_number = pdm_sat_table->beam_train_cnt[p_dm_fat_table->rx_idle_ant - 1][pdm_sat_table->fast_training_beam_num];
-				#else
-				train_pkt_number =  pdm_sat_table->per_beam_training_pkt_num;
-				#endif
+#if 1
+				train_pkt_number = sat_tab->beam_train_cnt[fat_tab->rx_idle_ant - 1][sat_tab->fast_training_beam_num];
+#else
+				train_pkt_number = sat_tab->per_beam_training_pkt_num;
+#endif
 
 				/*Swich Antenna erery N pkts*/
-				if (pdm_sat_table->pkt_counter == train_pkt_number) {
-
-					if (pdm_sat_table->ant_num > 1) {
-
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("packet enugh ((%d ))pkts ---> Switch antenna\n", train_pkt_number));
-						next_ant = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
-						odm_update_rx_idle_ant(p_dm, next_ant);
+				if (sat_tab->pkt_counter == train_pkt_number) {
+					if (sat_tab->ant_num > 1) {
+						PHYDM_DBG(dm, DBG_ANT_DIV, "packet enugh ((%d ))pkts ---> Switch antenna\n", train_pkt_number);
+						next_ant = (fat_tab->rx_idle_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
+						odm_update_rx_idle_ant(dm, next_ant);
 					}
 
-					pdm_sat_table->update_beam_idx++;
-					PHYDM_DBG(p_dm, DBG_ANT_DIV, ("pre_beacon_counter = ((%d)), update_beam_idx_counter = ((%d))\n",
-						pdm_sat_table->pre_beacon_counter, pdm_sat_table->update_beam_idx));
+					sat_tab->update_beam_idx++;
+					PHYDM_DBG(dm, DBG_ANT_DIV, "pre_beacon_counter = ((%d)), update_beam_idx_counter = ((%d))\n",
+						  sat_tab->pre_beacon_counter, sat_tab->update_beam_idx);
 
-					pdm_sat_table->pre_beacon_counter = pdm_sat_table->beacon_counter;
-					pdm_sat_table->pkt_counter = 0;
+					sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+					sat_tab->pkt_counter = 0;
 				}
 			}
 		}
 
-		/*Swich Beam after switch "pdm_sat_table->ant_num" antennas*/
-		if (pdm_sat_table->update_beam_idx == pdm_sat_table->ant_num) {
+		/*Swich Beam after switch "sat_tab->ant_num" antennas*/
+		if (sat_tab->update_beam_idx == sat_tab->ant_num) {
+			sat_tab->update_beam_idx = 0;
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
 
-			pdm_sat_table->update_beam_idx = 0;
-			pdm_sat_table->pkt_counter = 0;
-			beam_tmp = pdm_sat_table->fast_training_beam_num;
-
-			if (pdm_sat_table->fast_training_beam_num >= (pdm_sat_table->beam_patten_num_each_ant - 1)) {
-
-				p_dm_fat_table->fat_state = FAT_DECISION_STATE;
-
-				#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-				odm_fast_ant_training_hl_smart_antenna_type1(p_dm);
-				#else
-				odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_decision_workitem);
-				#endif
+			if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+				fat_tab->fat_state = FAT_DECISION_STATE;
 
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+				if (dm->support_interface == ODM_ITRF_PCIE)
+					odm_fast_ant_training_hl_smart_antenna_type1(dm);
+#endif
+#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+				if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+					odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+#endif
 
 			} else {
-				pdm_sat_table->fast_training_beam_num++;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Update Beam_num (( %d )) -> (( %d ))\n", beam_tmp, pdm_sat_table->fast_training_beam_num));
-				phydm_set_all_ant_same_beam_num(p_dm);
-
-				p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
+				sat_tab->fast_training_beam_num++;
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Update Beam_num (( %d )) -> (( %d ))\n",
+					  beam_tmp,
+					  sat_tab->fast_training_beam_num);
+				phydm_set_all_ant_same_beam_num(dm);
+
+				fat_tab->fat_state = FAT_TRAINING_STATE;
 			}
 		}
-
 	}
 #else
 
-	if (p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
-		if ((p_dm->support_ic_type & ODM_HL_SMART_ANT_TYPE1_SUPPORT) &&
-		    (p_pktinfo->is_packet_to_self)   &&
-		    (p_dm_fat_table->fat_state == FAT_TRAINING_STATE)
-		   ) {
-
-			if (pdm_sat_table->pkt_skip_statistic_en == 0) {
-				/*
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
-					p_pktinfo->station_id, p_dm_fat_table->antsel_rx_keep_0, p_dm_fat_table->hw_antsw_occur, pdm_sat_table->fast_training_beam_num, rx_power_ant0));
+		if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) {
+		if ((dm->support_ic_type & ODM_HL_SMART_ANT_TYPE1_SUPPORT) &&
+		    pktinfo->is_packet_to_self &&
+		    fat_tab->fat_state == FAT_TRAINING_STATE) {
+			if (sat_tab->pkt_skip_statistic_en == 0) {
+				/*@
+				PHYDM_DBG(dm, DBG_ANT_DIV, "StaID[%d]:  antsel_pathA = ((%d)), hw_antsw_occur = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					pktinfo->station_id, fat_tab->antsel_rx_keep_0, fat_tab->hw_antsw_occur, sat_tab->fast_training_beam_num, rx_power_ant0);
 				*/
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("StaID[%d]:  antsel_pathA = ((%d)), is_packet_to_self = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
-					p_pktinfo->station_id, p_dm_fat_table->antsel_rx_keep_0, p_pktinfo->is_packet_to_self, pdm_sat_table->fast_training_beam_num, rx_power_ant0));
-
-
-				pdm_sat_table->pkt_rssi_sum[p_dm_fat_table->antsel_rx_keep_0][pdm_sat_table->fast_training_beam_num] += rx_power_ant0;
-				pdm_sat_table->pkt_rssi_cnt[p_dm_fat_table->antsel_rx_keep_0][pdm_sat_table->fast_training_beam_num]++;
-				pdm_sat_table->pkt_counter++;
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "StaID[%d]:  antsel_pathA = ((%d)), is_packet_to_self = ((%d)), Beam_num = ((%d)), RSSI = ((%d))\n",
+					  pktinfo->station_id,
+					  fat_tab->antsel_rx_keep_0,
+					  pktinfo->is_packet_to_self,
+					  sat_tab->fast_training_beam_num,
+					  rx_power_ant0);
+
+				sat_tab->pkt_rssi_sum[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num] += rx_power_ant0;
+				sat_tab->pkt_rssi_cnt[fat_tab->antsel_rx_keep_0][sat_tab->fast_training_beam_num]++;
+				sat_tab->pkt_counter++;
 
 				/*swich beam every N pkt*/
-				if ((pdm_sat_table->pkt_counter) >= (pdm_sat_table->per_beam_training_pkt_num)) {
-
-					pdm_sat_table->pkt_counter = 0;
-					beam_tmp = pdm_sat_table->fast_training_beam_num;
+				if (sat_tab->pkt_counter >= sat_tab->per_beam_training_pkt_num) {
+					sat_tab->pkt_counter = 0;
+					beam_tmp = sat_tab->fast_training_beam_num;
 
-					if (pdm_sat_table->fast_training_beam_num >= (pdm_sat_table->beam_patten_num_each_ant - 1)) {
-
-						p_dm_fat_table->fat_state = FAT_DECISION_STATE;
-
-						#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-						odm_fast_ant_training_hl_smart_antenna_type1(p_dm);
-						#else
-						odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_decision_workitem);
-						#endif
+					if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+						fat_tab->fat_state = FAT_DECISION_STATE;
 
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+						if (dm->support_interface == ODM_ITRF_PCIE)
+							odm_fast_ant_training_hl_smart_antenna_type1(dm);
+#endif
+#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+						if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+							odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
+#endif
 
 					} else {
-						pdm_sat_table->fast_training_beam_num++;
-						phydm_set_all_ant_same_beam_num(p_dm);
+						sat_tab->fast_training_beam_num++;
+						phydm_set_all_ant_same_beam_num(dm);
 
-						p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
-						PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Update  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, pdm_sat_table->fast_training_beam_num));
+						fat_tab->fat_state = FAT_TRAINING_STATE;
+						PHYDM_DBG(dm, DBG_ANT_DIV, "Update  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, sat_tab->fast_training_beam_num);
 					}
 				}
 			}
@@ -4267,460 +5304,595 @@ odm_process_rssi_for_ant_div(
 #endif
 	else
 #endif
-		if (p_dm->ant_div_type == CG_TRX_SMART_ANTDIV) {
-			if ((p_dm->support_ic_type & ODM_SMART_ANT_SUPPORT) && (p_pktinfo->is_packet_to_self)   && (p_dm_fat_table->fat_state == FAT_TRAINING_STATE)) { /* (p_pktinfo->is_packet_match_bssid && (!p_pktinfo->is_packet_beacon)) */
-				u8	antsel_tr_mux;
-				antsel_tr_mux = (p_dm_fat_table->antsel_rx_keep_2 << 2) | (p_dm_fat_table->antsel_rx_keep_1 << 1) | p_dm_fat_table->antsel_rx_keep_0;
-				p_dm_fat_table->ant_sum_rssi[antsel_tr_mux] += rx_power_ant0;
-				p_dm_fat_table->ant_rssi_cnt[antsel_tr_mux]++;
-			}
-		} else { /* ant_div_type != CG_TRX_SMART_ANTDIV */
-			if ((p_dm->support_ic_type & ODM_ANTDIV_SUPPORT) && (p_pktinfo->is_packet_to_self || p_dm_fat_table->use_ctrl_frame_antdiv)) {
-
-				if (p_dm->ant_div_type == S0S1_SW_ANTDIV) {
-
-					if (is_cck_rate || (p_dm->support_ic_type == ODM_RTL8188F))
-						p_dm_fat_table->antsel_rx_keep_0 = (p_dm_fat_table->rx_idle_ant == MAIN_ANT) ? ANT1_2G : ANT2_2G;
-
-						odm_antsel_statistics(p_dm, p_phy_info, p_dm_fat_table->antsel_rx_keep_0, p_pktinfo->station_id, rx_power_ant0, RSSI_METHOD, is_cck_rate);
-
-				} else {
-					
-					odm_antsel_statistics(p_dm, p_phy_info, p_dm_fat_table->antsel_rx_keep_0, p_pktinfo->station_id, rx_power_ant0, RSSI_METHOD, is_cck_rate);
-
-					#ifdef ODM_EVM_ENHANCE_ANTDIV
-					if (p_dm->support_ic_type == ODM_RTL8192E) {
-						if (!is_cck_rate) {
-							odm_antsel_statistics(p_dm, p_phy_info, p_dm_fat_table->antsel_rx_keep_0, p_pktinfo->station_id, rx_evm_ant0, EVM_METHOD, is_cck_rate);
-							odm_antsel_statistics(p_dm, p_phy_info, p_dm_fat_table->antsel_rx_keep_0, p_pktinfo->station_id, rx_evm_ant0, TP_METHOD, is_cck_rate);
-						}
-
-					}
-					#endif
-				}
-			}
+		if (dm->ant_div_type == CG_TRX_SMART_ANTDIV) {
+			odm_process_rssi_smart(dm, phy_info, pktinfo,
+					       rx_power_ant0);
+		} else { /* @ant_div_type != CG_TRX_SMART_ANTDIV */
+			odm_process_rssi_normal(dm, phy_info, pktinfo,
+						rx_power_ant0);
 		}
-	/* PHYDM_DBG(p_dm,DBG_ANT_DIV,("is_cck_rate=%d, PWDB_ALL=%d\n",is_cck_rate, p_phy_info->rx_pwdb_all)); */
-	/* PHYDM_DBG(p_dm,DBG_ANT_DIV,("antsel_tr_mux=3'b%d%d%d\n",p_dm_fat_table->antsel_rx_keep_2, p_dm_fat_table->antsel_rx_keep_1, p_dm_fat_table->antsel_rx_keep_0)); */
+#if 0
+/* PHYDM_DBG(dm,DBG_ANT_DIV,"is_cck_rate=%d, pwdb_all=%d\n",
+ *	     pktinfo->is_cck_rate, phy_info->rx_pwdb_all);
+ * PHYDM_DBG(dm,DBG_ANT_DIV,"antsel_tr_mux=3'b%d%d%d\n",
+ *	     fat_tab->antsel_rx_keep_2, fat_tab->antsel_rx_keep_1,
+ *	     fat_tab->antsel_rx_keep_0);
+ */
+#endif
 }
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-void
-odm_set_tx_ant_by_tx_info(
-	void			*p_dm_void,
-	u8			*p_desc,
-	u8			mac_id
-
-)
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_IOT))
+void odm_set_tx_ant_by_tx_info(void *dm_void, u8 *desc, u8 mac_id)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct	*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	if (!(p_dm->support_ability & ODM_BB_ANT_DIV))
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
 		return;
 
-	if (p_dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
 		return;
 
-
-	if (p_dm->support_ic_type == ODM_RTL8723B) {
-#if (RTL8723B_SUPPORT == 1)
-		SET_TX_DESC_ANTSEL_A_8723B(p_desc, p_dm_fat_table->antsel_a[mac_id]);
-		/*PHYDM_DBG(p_dm,DBG_ANT_DIV, ("[8723B] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
-			mac_id, p_dm_fat_table->antsel_c[mac_id], p_dm_fat_table->antsel_b[mac_id], p_dm_fat_table->antsel_a[mac_id]));*/
+	if (dm->support_ic_type == (ODM_RTL8723B | ODM_RTL8721D)) {
+#if (RTL8723B_SUPPORT == 1 || RTL8721D_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8723B(desc, fat_tab->antsel_a[mac_id]);
+/*PHYDM_DBG(dm,DBG_ANT_DIV,
+ *	   "[8723B] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+ *	    mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id],
+ *	    fat_tab->antsel_a[mac_id]);
+ */
 #endif
-	} else if (p_dm->support_ic_type == ODM_RTL8821) {
+	} else if (dm->support_ic_type == ODM_RTL8821) {
 #if (RTL8821A_SUPPORT == 1)
-		SET_TX_DESC_ANTSEL_A_8812(p_desc, p_dm_fat_table->antsel_a[mac_id]);
-		/*PHYDM_DBG(p_dm,DBG_ANT_DIV, ("[8821A] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
-			mac_id, p_dm_fat_table->antsel_c[mac_id], p_dm_fat_table->antsel_b[mac_id], p_dm_fat_table->antsel_a[mac_id]));*/
+		SET_TX_DESC_ANTSEL_A_8812(desc, fat_tab->antsel_a[mac_id]);
+/*PHYDM_DBG(dm,DBG_ANT_DIV,
+ *	   "[8821A] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+ *	    mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id],
+ *	    fat_tab->antsel_a[mac_id]);
+ */
 #endif
-	} else if (p_dm->support_ic_type == ODM_RTL8188E) {
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
 #if (RTL8188E_SUPPORT == 1)
-		SET_TX_DESC_ANTSEL_A_88E(p_desc, p_dm_fat_table->antsel_a[mac_id]);
-		SET_TX_DESC_ANTSEL_B_88E(p_desc, p_dm_fat_table->antsel_b[mac_id]);
-		SET_TX_DESC_ANTSEL_C_88E(p_desc, p_dm_fat_table->antsel_c[mac_id]);
-		/*PHYDM_DBG(p_dm,DBG_ANT_DIV, ("[8188E] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
-			mac_id, p_dm_fat_table->antsel_c[mac_id], p_dm_fat_table->antsel_b[mac_id], p_dm_fat_table->antsel_a[mac_id]));*/
+		SET_TX_DESC_ANTSEL_A_88E(desc, fat_tab->antsel_a[mac_id]);
+		SET_TX_DESC_ANTSEL_B_88E(desc, fat_tab->antsel_b[mac_id]);
+		SET_TX_DESC_ANTSEL_C_88E(desc, fat_tab->antsel_c[mac_id]);
+/*PHYDM_DBG(dm,DBG_ANT_DIV,
+ *	   "[8188E] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+ *	    mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id],
+ *	    fat_tab->antsel_a[mac_id]);
+ */
 #endif
-	} else if (p_dm->support_ic_type == ODM_RTL8821C) {
+	} else if (dm->support_ic_type == ODM_RTL8821C) {
 #if (RTL8821C_SUPPORT == 1)
-		SET_TX_DESC_ANTSEL_A_8821C(p_desc, p_dm_fat_table->antsel_a[mac_id]);
-		/*PHYDM_DBG(p_dm,DBG_ANT_DIV, ("[8821C] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
-			mac_id, p_dm_fat_table->antsel_c[mac_id], p_dm_fat_table->antsel_b[mac_id], p_dm_fat_table->antsel_a[mac_id]));*/
+		SET_TX_DESC_ANTSEL_A_8821C(desc, fat_tab->antsel_a[mac_id]);
+/*PHYDM_DBG(dm,DBG_ANT_DIV,
+ *	   "[8821C] SetTxAntByTxInfo_WIN: mac_id=%d, antsel_tr_mux=3'b%d%d%d\n",
+ *	    mac_id, fat_tab->antsel_c[mac_id], fat_tab->antsel_b[mac_id],
+ *	    fat_tab->antsel_a[mac_id]);
+ */
+#endif
+	} else if (dm->support_ic_type == ODM_RTL8822B) {
+#if (RTL8822B_SUPPORT == 1)
+		SET_TX_DESC_ANTSEL_A_8822B(desc, fat_tab->antsel_a[mac_id]);
 #endif
+
 	}
 }
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-void
-odm_set_tx_ant_by_tx_info(
-	struct	rtl8192cd_priv		*priv,
-	struct	tx_desc	*pdesc,
-	unsigned short			aid
-)
+void odm_set_tx_ant_by_tx_info(
+	struct rtl8192cd_priv *priv,
+	struct tx_desc *pdesc,
+	unsigned short aid)
 {
-	struct PHY_DM_STRUCT	*p_dm = GET_PDM_ODM(priv);/*&(priv->pshare->_dmODM);*/
-	struct phydm_fat_struct		*p_dm_fat_table = &(p_dm->dm_fat_table);
+	struct dm_struct *dm = GET_PDM_ODM(priv); /*@&(priv->pshare->_dmODM);*/
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 
-	if (!(p_dm->support_ability & ODM_BB_ANT_DIV))
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
 		return;
 
-	if (p_dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
 		return;
 
-	if (p_dm->support_ic_type == ODM_RTL8881A) {
+	if (dm->support_ic_type == ODM_RTL8881A) {
+#if 0
 		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);	*/
+#endif
 		pdesc->Dword6 &= set_desc(~(BIT(18) | BIT(17) | BIT(16)));
-		pdesc->Dword6 |= set_desc(p_dm_fat_table->antsel_a[aid] << 16);
-	} else if (p_dm->support_ic_type == ODM_RTL8192E) {
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
+#if 0
 		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8192E******\n",__FUNCTION__,__LINE__);	*/
+#endif
 		pdesc->Dword6 &= set_desc(~(BIT(18) | BIT(17) | BIT(16)));
-		pdesc->Dword6 |= set_desc(p_dm_fat_table->antsel_a[aid] << 16);
-	} else if (p_dm->support_ic_type == ODM_RTL8188E) {
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8197F) {
+#if 0
+		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8192E******\n",__FUNCTION__,__LINE__);	*/
+#endif
+		pdesc->Dword6 &= set_desc(~(BIT(17) | BIT(16)));
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8822B) {
+		pdesc->Dword6 &= set_desc(~(BIT(17) | BIT(16)));
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+#if 0
 		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8188E******\n",__FUNCTION__,__LINE__);*/
+#endif
 		pdesc->Dword2 &= set_desc(~BIT(24));
 		pdesc->Dword2 &= set_desc(~BIT(25));
 		pdesc->Dword7 &= set_desc(~BIT(29));
 
-		pdesc->Dword2 |= set_desc(p_dm_fat_table->antsel_a[aid] << 24);
-		pdesc->Dword2 |= set_desc(p_dm_fat_table->antsel_b[aid] << 25);
-		pdesc->Dword7 |= set_desc(p_dm_fat_table->antsel_c[aid] << 29);
-
+		pdesc->Dword2 |= set_desc(fat_tab->antsel_a[aid] << 24);
+		pdesc->Dword2 |= set_desc(fat_tab->antsel_b[aid] << 25);
+		pdesc->Dword7 |= set_desc(fat_tab->antsel_c[aid] << 29);
 
-	} else if (p_dm->support_ic_type == ODM_RTL8812) {
-		/*[path-A]*/
+	} else if (dm->support_ic_type == ODM_RTL8812) {
+		/*@[path-A]*/
+#if 0
 		/*panic_printk("[%s] [%d]   ******ODM_SetTxAntByTxInfo_8881E******\n",__FUNCTION__,__LINE__);*/
+#endif
 
 		pdesc->Dword6 &= set_desc(~BIT(16));
 		pdesc->Dword6 &= set_desc(~BIT(17));
 		pdesc->Dword6 &= set_desc(~BIT(18));
 
-		pdesc->Dword6 |= set_desc(p_dm_fat_table->antsel_a[aid] << 16);
-		pdesc->Dword6 |= set_desc(p_dm_fat_table->antsel_b[aid] << 17);
-		pdesc->Dword6 |= set_desc(p_dm_fat_table->antsel_c[aid] << 18);
-
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_a[aid] << 16);
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_b[aid] << 17);
+		pdesc->Dword6 |= set_desc(fat_tab->antsel_c[aid] << 18);
 	}
 }
 
-
-#if 1 /*def CONFIG_WLAN_HAL*/
-void
-odm_set_tx_ant_by_tx_info_hal(
-	struct	rtl8192cd_priv		*priv,
-	void	*pdesc_data,
-	u16					aid
-)
+#if 1 /*@def CONFIG_WLAN_HAL*/
+void odm_set_tx_ant_by_tx_info_hal(
+	struct rtl8192cd_priv *priv,
+	void *pdesc_data,
+	u16 aid)
 {
-	struct PHY_DM_STRUCT	*p_dm = GET_PDM_ODM(priv);/*&(priv->pshare->_dmODM);*/
-	struct phydm_fat_struct		*p_dm_fat_table = &(p_dm->dm_fat_table);
-	PTX_DESC_DATA_88XX	pdescdata = (PTX_DESC_DATA_88XX)pdesc_data;
+	struct dm_struct *dm = GET_PDM_ODM(priv); /*@&(priv->pshare->_dmODM);*/
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	PTX_DESC_DATA_88XX pdescdata = (PTX_DESC_DATA_88XX)pdesc_data;
 
-	if (!(p_dm->support_ability & ODM_BB_ANT_DIV))
+	if (!(dm->support_ability & ODM_BB_ANT_DIV))
 		return;
 
-	if (p_dm->ant_div_type == CGCS_RX_HW_ANTDIV)
+	if (dm->ant_div_type == CGCS_RX_HW_ANTDIV)
 		return;
 
-	if (p_dm->support_ic_type & (ODM_RTL8881A | ODM_RTL8192E | ODM_RTL8814A)) {
-		/*panic_printk("[%s] [%d] ******odm_set_tx_ant_by_tx_info_hal******\n",__FUNCTION__,__LINE__);*/
+	if (dm->support_ic_type & (ODM_RTL8881A | ODM_RTL8192E | ODM_RTL8814A |
+	    ODM_RTL8197F | ODM_RTL8822B)) {
+#if 0
+		/*panic_printk("[%s] [%d] **odm_set_tx_ant_by_tx_info_hal**\n",
+		 *	       __FUNCTION__,__LINE__);
+		 */
+#endif
 		pdescdata->ant_sel = 1;
-		pdescdata->ant_sel_a = p_dm_fat_table->antsel_a[aid];
+		pdescdata->ant_sel_a = fat_tab->antsel_a[aid];
 	}
 }
-#endif	/*#ifdef CONFIG_WLAN_HAL*/
+#endif /*@#ifdef CONFIG_WLAN_HAL*/
 
 #endif
 
-
-void
-odm_ant_div_config(
-	void		*p_dm_void
-)
+void odm_ant_div_config(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("WIN Config Antenna Diversity\n"));
-	/*
-	if(p_dm->support_ic_type==ODM_RTL8723B)
+	PHYDM_DBG(dm, DBG_ANT_DIV, "WIN Config Antenna Diversity\n");
+	/*@
+	if(dm->support_ic_type==ODM_RTL8723B)
 	{
-		if((!p_dm->dm_swat_table.ANTA_ON || !p_dm->dm_swat_table.ANTB_ON))
-			p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+		if((!dm->swat_tab.ANTA_ON || !dm->swat_tab.ANTB_ON))
+			dm->support_ability &= ~(ODM_BB_ANT_DIV);
 	}
 	*/
-	if (p_dm->support_ic_type == ODM_RTL8723D) {
+	#if (defined(CONFIG_2T3R_ANTENNA))
+	#if (RTL8822B_SUPPORT == 1)
+		dm->rfe_type = ANT_2T3R_RFE_TYPE;
+	#endif
+	#endif
 
-		p_dm->ant_div_type = S0S1_TRX_HW_ANTDIV;
-		/**/
-	}
+	#if (defined(CONFIG_2T4R_ANTENNA))
+	#if (RTL8822B_SUPPORT == 1)
+		dm->rfe_type = ANT_2T4R_RFE_TYPE;
+	#endif
+	#endif
+
+	if (dm->support_ic_type == ODM_RTL8723D)
+		dm->ant_div_type = S0S1_TRX_HW_ANTDIV;
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("CE Config Antenna Diversity\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "CE Config Antenna Diversity\n");
+
+	if (dm->support_ic_type == ODM_RTL8723B)
+		dm->ant_div_type = S0S1_SW_ANTDIV;
 
-	if (p_dm->support_ic_type == ODM_RTL8723B)
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
+	if (dm->support_ic_type == ODM_RTL8723D)
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+#elif (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
 
+	PHYDM_DBG(dm, DBG_ANT_DIV, "IOT Config Antenna Diversity\n");
 
+	if (dm->support_ic_type == ODM_RTL8721D)
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
 
 #elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("AP Config Antenna Diversity\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "AP Config Antenna Diversity\n");
 
-	/* 2 [ NOT_SUPPORT_ANTDIV ] */
+	/* @2 [ NOT_SUPPORT_ANTDIV ] */
 #if (defined(CONFIG_NOT_SUPPORT_ANTDIV))
-	p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Disable AntDiv function] : Not Support 2.4G & 5G Antenna Diversity\n"));
+	dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Disable AntDiv function] : Not Support 2.4G & 5G Antenna Diversity\n");
 
-	/* 2 [ 2G&5G_SUPPORT_ANTDIV ] */
+	/* @2 [ 2G&5G_SUPPORT_ANTDIV ] */
 #elif (defined(CONFIG_2G5G_SUPPORT_ANTDIV))
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Enable AntDiv function] : 2.4G & 5G Support Antenna Diversity Simultaneously\n"));
-	p_dm_fat_table->ant_div_2g_5g = (ODM_ANTDIV_2G | ODM_ANTDIV_5G);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Enable AntDiv function] : 2.4G & 5G Support Antenna Diversity Simultaneously\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_2G | ODM_ANTDIV_5G);
 
-	if (p_dm->support_ic_type & ODM_ANTDIV_SUPPORT)
-		p_dm->support_ability |= ODM_BB_ANT_DIV;
-	if (*p_dm->p_band_type == ODM_BAND_5G) {
+	if (dm->support_ic_type & ODM_ANTDIV_SUPPORT)
+		dm->support_ability |= ODM_BB_ANT_DIV;
+	if (*dm->band_type == ODM_BAND_5G) {
 #if (defined(CONFIG_5G_CGCS_RX_DIVERSITY))
-		p_dm->ant_div_type = CGCS_RX_HW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n"));
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
 		panic_printk("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
-#elif (defined(CONFIG_5G_CG_TRX_DIVERSITY) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
-		p_dm->ant_div_type = CG_TRX_HW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n"));
+#elif (defined(CONFIG_5G_CG_TRX_DIVERSITY) ||\
+	defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
 		panic_printk("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
 #elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
-		p_dm->ant_div_type = CG_TRX_SMART_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = CG_SMART_ANTDIV\n"));
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = CG_SMART_ANTDIV\n");
 #elif (defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY))
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n"));
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n");
 #endif
-	} else if (*p_dm->p_band_type == ODM_BAND_2_4G) {
+	} else if (*dm->band_type == ODM_BAND_2_4G) {
 #if (defined(CONFIG_2G_CGCS_RX_DIVERSITY))
-		p_dm->ant_div_type = CGCS_RX_HW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n"));
-#elif (defined(CONFIG_2G_CG_TRX_DIVERSITY) || defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
-		p_dm->ant_div_type = CG_TRX_HW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n"));
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
+#elif (defined(CONFIG_2G_CG_TRX_DIVERSITY) ||\
+	defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A))
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
 #elif (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		p_dm->ant_div_type = CG_TRX_SMART_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n"));
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n");
 #elif (defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY))
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n"));
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n");
 #endif
 	}
 
-	/* 2 [ 5G_SUPPORT_ANTDIV ] */
+	/* @2 [ 5G_SUPPORT_ANTDIV ] */
 #elif (defined(CONFIG_5G_SUPPORT_ANTDIV))
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n");
 	panic_printk("[ Enable AntDiv function] : Only 5G Support Antenna Diversity\n");
-	p_dm_fat_table->ant_div_2g_5g = (ODM_ANTDIV_5G);
-	if (*p_dm->p_band_type == ODM_BAND_5G) {
-		if (p_dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC)
-			p_dm->support_ability |= ODM_BB_ANT_DIV;
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_5G);
+	if (*dm->band_type == ODM_BAND_5G) {
+		if (dm->support_ic_type & ODM_ANTDIV_5G_SUPPORT_IC)
+			dm->support_ability |= ODM_BB_ANT_DIV;
 #if (defined(CONFIG_5G_CGCS_RX_DIVERSITY))
-		p_dm->ant_div_type = CGCS_RX_HW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n"));
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
 		panic_printk("[ 5G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
 #elif (defined(CONFIG_5G_CG_TRX_DIVERSITY))
-		p_dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
 		panic_printk("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n"));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
 #elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY))
-		p_dm->ant_div_type = CG_TRX_SMART_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = CG_SMART_ANTDIV\n"));
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = CG_SMART_ANTDIV\n");
 #elif (defined(CONFIG_5G_S0S1_SW_ANT_DIVERSITY))
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n"));
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 5G] : AntDiv type = S0S1_SW_ANTDIV\n");
 #endif
-	} else if (*p_dm->p_band_type == ODM_BAND_2_4G) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Not Support 2G ant_div_type\n"));
-		p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	} else if (*dm->band_type == ODM_BAND_2_4G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Not Support 2G ant_div_type\n");
+		dm->support_ability &= ~(ODM_BB_ANT_DIV);
 	}
 
-	/* 2 [ 2G_SUPPORT_ANTDIV ] */
+	/* @2 [ 2G_SUPPORT_ANTDIV ] */
 #elif (defined(CONFIG_2G_SUPPORT_ANTDIV))
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Enable AntDiv function] : Only 2.4G Support Antenna Diversity\n"));
-	p_dm_fat_table->ant_div_2g_5g = (ODM_ANTDIV_2G);
-	if (*p_dm->p_band_type == ODM_BAND_2_4G) {
-		if (p_dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC)
-			p_dm->support_ability |= ODM_BB_ANT_DIV;
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Enable AntDiv function] : Only 2.4G Support Antenna Diversity\n");
+	fat_tab->ant_div_2g_5g = (ODM_ANTDIV_2G);
+	if (*dm->band_type == ODM_BAND_2_4G) {
+		if (dm->support_ic_type & ODM_ANTDIV_2G_SUPPORT_IC)
+			dm->support_ability |= ODM_BB_ANT_DIV;
 #if (defined(CONFIG_2G_CGCS_RX_DIVERSITY))
-		p_dm->ant_div_type = CGCS_RX_HW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n"));
+		dm->ant_div_type = CGCS_RX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = CGCS_RX_HW_ANTDIV\n");
 #elif (defined(CONFIG_2G_CG_TRX_DIVERSITY))
-		p_dm->ant_div_type = CG_TRX_HW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n"));
+		dm->ant_div_type = CG_TRX_HW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = CG_TRX_HW_ANTDIV\n");
 #elif (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		p_dm->ant_div_type = CG_TRX_SMART_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n"));
+		dm->ant_div_type = CG_TRX_SMART_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = CG_SMART_ANTDIV\n");
 #elif (defined(CONFIG_2G_S0S1_SW_ANT_DIVERSITY))
-		p_dm->ant_div_type = S0S1_SW_ANTDIV;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n"));
+		dm->ant_div_type = S0S1_SW_ANTDIV;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ 2.4G] : AntDiv type = S0S1_SW_ANTDIV\n");
 #endif
-	} else if (*p_dm->p_band_type == ODM_BAND_5G) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Not Support 5G ant_div_type\n"));
-		p_dm->support_ability &= ~(ODM_BB_ANT_DIV);
+	} else if (*dm->band_type == ODM_BAND_5G) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Not Support 5G ant_div_type\n");
+		dm->support_ability &= ~(ODM_BB_ANT_DIV);
 	}
 #endif
 #endif
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[AntDiv Config Info] AntDiv_SupportAbility = (( %x ))\n", ((p_dm->support_ability & ODM_BB_ANT_DIV) ? 1 : 0)));
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[AntDiv Config Info] be_fix_tx_ant = ((%d))\n", p_dm->dm_fat_table.b_fix_tx_ant));
-
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[AntDiv Config Info] AntDiv_SupportAbility = (( %x ))\n",
+		  ((dm->support_ability & ODM_BB_ANT_DIV) ? 1 : 0));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[AntDiv Config Info] be_fix_tx_ant = ((%d))\n",
+		  dm->dm_fat_table.b_fix_tx_ant);
 }
 
-
-void
-odm_ant_div_timers(
-	void		*p_dm_void,
-	u8		state
-)
+void odm_ant_div_timers(void *dm_void, u8 state)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	if (state == INIT_ANTDIV_TIMMER) {
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		odm_initialize_timer(p_dm, &(p_dm->dm_swat_table.phydm_sw_antenna_switch_timer),
-			(void *)odm_sw_antdiv_callback, NULL, "phydm_sw_antenna_switch_timer");
-#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		odm_initialize_timer(p_dm, &p_dm->fast_ant_training_timer,
-			(void *)odm_fast_ant_training_callback, NULL, "fast_ant_training_timer");
+		odm_initialize_timer(dm,
+				     &dm->dm_swat_table.sw_antdiv_timer,
+				     (void *)odm_sw_antdiv_callback, NULL,
+				     "sw_antdiv_timer");
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\
+	(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_initialize_timer(dm, &dm->fast_ant_training_timer,
+				     (void *)odm_fast_ant_training_callback,
+				     NULL, "fast_ant_training_timer");
 #endif
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-		odm_initialize_timer(p_dm, &p_dm->evm_fast_ant_training_timer,
-			(void *)odm_evm_fast_ant_training_callback, NULL, "evm_fast_ant_training_timer");
+		odm_initialize_timer(dm, &dm->evm_fast_ant_training_timer,
+				     (void *)phydm_evm_antdiv_callback, NULL,
+				     "evm_fast_ant_training_timer");
 #endif
 	} else if (state == CANCEL_ANTDIV_TIMMER) {
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		odm_cancel_timer(p_dm, &(p_dm->dm_swat_table.phydm_sw_antenna_switch_timer));
-#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		odm_cancel_timer(p_dm, &p_dm->fast_ant_training_timer);
+		odm_cancel_timer(dm,
+				 &dm->dm_swat_table.sw_antdiv_timer);
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\
+	(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_cancel_timer(dm, &dm->fast_ant_training_timer);
 #endif
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-		odm_cancel_timer(p_dm, &p_dm->evm_fast_ant_training_timer);
+		odm_cancel_timer(dm, &dm->evm_fast_ant_training_timer);
 #endif
 	} else if (state == RELEASE_ANTDIV_TIMMER) {
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		odm_release_timer(p_dm, &(p_dm->dm_swat_table.phydm_sw_antenna_switch_timer));
-#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-		odm_release_timer(p_dm, &p_dm->fast_ant_training_timer);
+		odm_release_timer(dm,
+				  &dm->dm_swat_table.sw_antdiv_timer);
+#elif (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\
+	(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+		odm_release_timer(dm, &dm->fast_ant_training_timer);
 #endif
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-		odm_release_timer(p_dm, &p_dm->evm_fast_ant_training_timer);
+		odm_release_timer(dm, &dm->evm_fast_ant_training_timer);
 #endif
 	}
-
 }
 
-void
-phydm_antdiv_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char			*output,
-	u32		*_out_len
-)
+void phydm_antdiv_debug(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	/*struct phydm_fat_struct*			p_dm_fat_table = &p_dm->dm_fat_table;*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct	*fat_tab = &dm->dm_fat_table;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u32 dm_value[10] = {0};
+	char help[] = "-h";
+	u8 i, input_idx = 0;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
+			input_idx++;
+		}
+	}
+
+	if (input_idx == 0)
+		return;
 
-	if (dm_value[0] == 1) { /*fixed or auto antenna*/
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} {0:auto, 1:fix main, 2:fix auto}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{2} {antdiv_period}\n");
+		#if (RTL8821C_SUPPORT == 1)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{3} {en} {0:Default, 1:HW_Div, 2:SW_Div}\n");
+		#endif
 
+	} else if (dm_value[0] == 1) {
+	/*@fixed or auto antenna*/
 		if (dm_value[1] == 0) {
-			p_dm->ant_type = ODM_AUTO_ANT;
-			PHYDM_SNPRINTF((output + used, out_len - used, "AntDiv: Auto\n"));
+			dm->ant_type = ODM_AUTO_ANT;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "AntDiv: Auto\n");
 		} else if (dm_value[1] == 1) {
-			p_dm->ant_type = ODM_FIX_MAIN_ANT;
-			PHYDM_SNPRINTF((output + used, out_len - used, "AntDiv: Fix Main\n"));
+			dm->ant_type = ODM_FIX_MAIN_ANT;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "AntDiv: Fix Main\n");
 		} else if (dm_value[1] == 2) {
-			p_dm->ant_type = ODM_FIX_AUX_ANT;
-			PHYDM_SNPRINTF((output + used, out_len - used, "AntDiv: Fix Aux\n"));
+			dm->ant_type = ODM_FIX_AUX_ANT;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "AntDiv: Fix Aux\n");
 		}
 
-		if (p_dm->ant_type != ODM_AUTO_ANT) {
-
-			odm_stop_antenna_switch_dm(p_dm);
-			if (p_dm->ant_type == ODM_FIX_MAIN_ANT)
-				odm_update_rx_idle_ant(p_dm, MAIN_ANT);
-			else if (p_dm->ant_type == ODM_FIX_AUX_ANT)
-				odm_update_rx_idle_ant(p_dm, AUX_ANT);
+		if (dm->ant_type != ODM_AUTO_ANT) {
+			odm_stop_antenna_switch_dm(dm);
+			if (dm->ant_type == ODM_FIX_MAIN_ANT)
+				odm_update_rx_idle_ant(dm, MAIN_ANT);
+			else if (dm->ant_type == ODM_FIX_AUX_ANT)
+				odm_update_rx_idle_ant(dm, AUX_ANT);
 		} else {
-			phydm_enable_antenna_diversity(p_dm);
+			phydm_enable_antenna_diversity(dm);
+		}
+		dm->pre_ant_type = dm->ant_type;
+	} else if (dm_value[0] == 2) {
+	/*@dynamic period for AntDiv*/
+		dm->antdiv_period = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "AntDiv_period=((%d))\n", dm->antdiv_period);
+	}
+	#if (RTL8821C_SUPPORT == 1)
+	else if (dm_value[0] == 3 &&
+		 dm->support_ic_type == ODM_RTL8821C) {
+		/*Only for 8821C*/
+		if (dm_value[1] == 0) {
+			fat_tab->force_antdiv_type = false;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[8821C] AntDiv: Default\n");
+		} else if (dm_value[1] == 1) {
+			fat_tab->force_antdiv_type = true;
+			fat_tab->antdiv_type_dbg = CG_TRX_HW_ANTDIV;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[8821C] AntDiv: HW diversity\n");
+		} else if (dm_value[1] == 2) {
+			fat_tab->force_antdiv_type = true;
+			fat_tab->antdiv_type_dbg = S0S1_SW_ANTDIV;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[8821C] AntDiv: SW diversity\n");
+		}
+	}
+	#endif
+	#ifdef ODM_EVM_ENHANCE_ANTDIV
+	else if (dm_value[0] == 4) {
+		if (dm_value[1] == 0) {
+			/*@init parameters for EVM AntDiv*/
+			phydm_evm_sw_antdiv_init(dm);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "init evm antdiv parameters\n");
+		} else if (dm_value[1] == 1) {
+			/*training number for EVM AntDiv*/
+			dm->antdiv_train_num = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "antdiv_train_num = ((%d))\n",
+				 dm->antdiv_train_num);
+		} else if (dm_value[1] == 2) {
+			/*training interval for EVM AntDiv*/
+			dm->antdiv_intvl = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "antdiv_intvl = ((%d))\n",
+				 dm->antdiv_intvl);
+		} else if (dm_value[1] == 3) {
+			/*@function period for EVM AntDiv*/
+			dm->evm_antdiv_period = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "evm_antdiv_period = ((%d))\n",
+				 dm->evm_antdiv_period);
+		} else if (dm_value[1] == 100) {/*show parameters*/
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "ant_type = ((%d))\n", dm->ant_type);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "antdiv_train_num = ((%d))\n",
+				 dm->antdiv_train_num);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "antdiv_intvl = ((%d))\n",
+				 dm->antdiv_intvl);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "evm_antdiv_period = ((%d))\n",
+				 dm->evm_antdiv_period);
+		}
+	}
+	#ifdef CONFIG_2T4R_ANTENNA
+	else if (dm_value[0] == 5) { /*Only for 8822B 2T4R case*/
+
+		if (dm_value[1] == 0) {
+			dm->ant_type2 = ODM_AUTO_ANT;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "AntDiv: PathB Auto\n");
+		} else if (dm_value[1] == 1) {
+			dm->ant_type2 = ODM_FIX_MAIN_ANT;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "AntDiv: PathB Fix Main\n");
+		} else if (dm_value[1] == 2) {
+			dm->ant_type2 = ODM_FIX_AUX_ANT;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "AntDiv: PathB Fix Aux\n");
 		}
-		p_dm->pre_ant_type = p_dm->ant_type;
-	} else if (dm_value[0] == 2) { /*dynamic period for AntDiv*/
 
-		p_dm->antdiv_period = (u8)dm_value[1];
-		PHYDM_SNPRINTF((output + used, out_len - used, "AntDiv_period = ((%d))\n", p_dm->antdiv_period));
+		if (dm->ant_type2 != ODM_AUTO_ANT) {
+			odm_stop_antenna_switch_dm(dm);
+			if (dm->ant_type2 == ODM_FIX_MAIN_ANT)
+				phydm_update_rx_idle_ant_pathb(dm, MAIN_ANT);
+			else if (dm->ant_type2 == ODM_FIX_AUX_ANT)
+				phydm_update_rx_idle_ant_pathb(dm, AUX_ANT);
+		} else {
+			phydm_enable_antenna_diversity(dm);
+		}
+		dm->pre_ant_type2 = dm->ant_type2;
 	}
+	#endif
+	#endif
 	*_used = used;
 	*_out_len = out_len;
 }
 
-#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
-
-void
-odm_ant_div_reset(
-	void		*p_dm_void
-)
+void odm_ant_div_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (p_dm->ant_div_type == S0S1_SW_ANTDIV) {
-#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-		odm_s0s1_sw_ant_div_reset(p_dm);
-#endif
-	}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+	#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	if (dm->ant_div_type == S0S1_SW_ANTDIV)
+		odm_s0s1_sw_ant_div_reset(dm);
+	#endif
 }
 
-void
-odm_antenna_diversity_init(
-	void		*p_dm_void
-)
+void odm_antenna_diversity_init(void *dm_void)
 {
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-#if 0
-	if (*(p_dm->p_mp_mode) == true)
-		return;
-#endif
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	odm_ant_div_config(p_dm);
-	odm_ant_div_init(p_dm);
-#endif
+	odm_ant_div_config(dm);
+	odm_ant_div_init(dm);
 }
 
-void
-odm_antenna_diversity(
-	void		*p_dm_void
-)
+void odm_antenna_diversity(void *dm_void)
 {
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (*(p_dm->p_mp_mode) == true)
+	if (*dm->mp_mode)
 		return;
 
-	if (!(p_dm->support_ability & ODM_BB_ANT_DIV)) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Return!!!]   Not Support Antenna Diversity Function\n"));
+	if (!(dm->support_ability & ODM_BB_ANT_DIV)) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[Return!!!]   Not Support Antenna Diversity Function\n");
 		return;
 	}
 
-	if (p_dm->pause_ability & ODM_BB_ANT_DIV) {
-		
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Return: Pause AntDIv in LV=%d\n", p_dm->pause_lv_table.lv_antdiv));
+	if (dm->pause_ability & ODM_BB_ANT_DIV) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Return: Pause AntDIv in LV=%d\n",
+			  dm->pause_lv_table.lv_antdiv);
 		return;
 	}
 
-	odm_ant_div(p_dm);
-#endif
+	odm_ant_div(dm);
 }
+#endif /*@#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY*/
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.h
index 9eb11e85fe87..6fbfe7642484 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_antdiv.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,40 +9,64 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMANTDIV_H__
-#define    __PHYDMANTDIV_H__
-
-/*#define ANTDIV_VERSION	"2.0"  //2014.11.04*/
-/*#define ANTDIV_VERSION	"2.1"  //2015.01.13  Dino*/
-/*#define ANTDIV_VERSION	"2.2"  2015.01.16  Dino*/
-/*#define ANTDIV_VERSION	"3.1"  2015.07.29  YuChen, remove 92c 92d 8723a*/
-/*#define ANTDIV_VERSION	"3.2"  2015.08.11  Stanley, disable antenna diversity when BT is enable for 8723B*/
-/*#define ANTDIV_VERSION	"3.3"  2015.08.12  Stanley. 8723B does not need to check the antenna is control by BT,
-							because antenna diversity only works when BT is disable or radio off*/
-/*#define ANTDIV_VERSION	"3.4"  2015.08.28  Dino  1.Add 8821A Smart Antenna 2. Add 8188F SW S0S1 Antenna Diversity*/
-/*#define ANTDIV_VERSION	"3.5"  2015.10.07  Stanley  Always check antenna detection result from BT-coex. for 8723B, not from PHYDM*/
-/*#define ANTDIV_VERSION	"3.6"*/  /*2015.11.16  Stanley  */
-/*#define ANTDIV_VERSION	"3.7"*/  /*2015.11.20  Dino Add SmartAnt FAT Patch */
-/*#define ANTDIV_VERSION	"3.8"  2015.12.21  Dino, Add SmartAnt dynamic training packet num */
-/*#define ANTDIV_VERSION	"3.9"  2016.01.05  Dino, Add SmartAnt cmd for converting single & two smtant, and add cmd for adjust truth table */
-#define ANTDIV_VERSION	"4.0"  /*2017.05.25  Mark, Add SW antenna diversity for 8821c because HW transient issue */
-
-/* 1 ============================================================
+#ifndef __PHYDMANTDIV_H__
+#define __PHYDMANTDIV_H__
+
+/*@#define ANTDIV_VERSION	"2.0"  //2014.11.04*/
+/*@#define ANTDIV_VERSION	"2.1"  //2015.01.13  Dino*/
+/*@#define ANTDIV_VERSION	"2.2"  2015.01.16  Dino*/
+/*@#define ANTDIV_VERSION	"3.1"  2015.07.29  YuChen,remove 92c 92d 8723a*/
+/*@#define ANTDIV_VERSION	"3.2"  2015.08.11  Stanley, disable antenna*/
+				/*@diversity when BT is enable for 8723B*/
+/*@#define ANTDIV_VERSION	"3.3"  2015.08.12  Stanley. 8723B does not*/
+				/*@need to check the antenna is control by BT,*/
+				/*@because antenna diversity only works when */
+				/*@BT is disable or radio off*/
+/*@#define ANTDIV_VERSION	"3.4"  2015.08.28 Dino 1.Add 8821A Smart */
+				/*@Antenna 2. Add 8188F SW S0S1 Antenna*/
+				/*@Diversity*/
+/*@#define ANTDIV_VERSION	"3.5"  2015.10.07 Stanley Always check antenna*/
+				/*@detection result from BT-coex. for 8723B,*/
+				/*@not from PHYDM*/
+/*@#define ANTDIV_VERSION	"3.6"*/ /*@2015.11.16  Stanley  */
+/*@#define ANTDIV_VERSION	"3.7"  2015.11.20 Dino Add SmartAnt FAT Patch */
+/*@#define ANTDIV_VERSION	"3.8"  2015.12.21 Dino, Add SmartAnt dynamic*/
+				/*@training packet num */
+/*@#define ANTDIV_VERSION	"3.9"  2016.01.05 Dino, Add SmartAnt cmd for*/
+				/*@converting single & two smtant, and add cmd*/
+				/*@for adjust truth table */
+#define ANTDIV_VERSION "4.0"	/*@2017.05.25  Mark, Add SW antenna diversity*/
+				/*@for 8821c because HW transient issue */
+
+/* @1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
 #define	ANTDIV_INIT		0xff
-#define	MAIN_ANT	1		/*ant A or ant Main   or S1*/
-#define	AUX_ANT		2		/*AntB or ant Aux   or S0*/
-#define	MAX_ANT		3		/* 3 for AP using*/
-
-#define ANT1_2G 0 /* = ANT2_5G	for 8723D  BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */
-#define ANT2_2G 1 /* = ANT1_5G	for 8723D  BTG S0  RX S0S1 diversity for 8723D, TX fixed at S1 */
+#define	MAIN_ANT	1		/*@ant A or ant Main   or S1*/
+#define	AUX_ANT		2		/*@AntB or ant Aux   or S0*/
+#define	MAX_ANT		3		/* @3 for AP using*/
+
+#define ANT1_2G 0
+/* @= ANT2_5G for 8723D  BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */
+#define ANT2_2G 1
+/* @= ANT1_5G for 8723D  BTG S0  RX S0S1 diversity for 8723D, TX fixed at S1 */
 /*smart antenna*/
 #define SUPPORT_RF_PATH_NUM 4
 #define SUPPORT_BEAM_PATTERN_NUM 4
@@ -53,21 +78,27 @@
 #define	FIX_TX_AT_MAIN	1
 #define	FIX_AUX_AT_MAIN	2
 
-/* Antenna Diversty Control type */
+/* @Antenna Diversty Control type */
 #define	ODM_AUTO_ANT		0
 #define	ODM_FIX_MAIN_ANT	1
 #define	ODM_FIX_AUX_ANT	2
 
-#define ODM_N_ANTDIV_SUPPORT		(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A)
-#define ODM_AC_ANTDIV_SUPPORT	(ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)
-#define ODM_ANTDIV_SUPPORT		(ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)
+#define ODM_N_ANTDIV_SUPPORT (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B |\
+			ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A |\
+			ODM_RTL8197F | ODM_RTL8721D)
+#define ODM_AC_ANTDIV_SUPPORT (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 |\
+			ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)
+#define ODM_ANTDIV_SUPPORT	(ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)
 #define ODM_SMART_ANT_SUPPORT	(ODM_RTL8188E | ODM_RTL8192E)
 #define ODM_HL_SMART_ANT_TYPE1_SUPPORT		(ODM_RTL8821 | ODM_RTL8822B)
 
-#define ODM_ANTDIV_2G_SUPPORT_IC			(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D)
-#define ODM_ANTDIV_5G_SUPPORT_IC			(ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C)
+#define ODM_ANTDIV_2G_SUPPORT_IC (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B |\
+			ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D |\
+			ODM_RTL8197F)
+#define ODM_ANTDIV_5G_SUPPORT_IC (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 |\
+			ODM_RTL8821C | ODM_RTL8822B)
 
-#define ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC	(ODM_RTL8192E)
+#define ODM_EVM_ANTDIV_IC (ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8822B)
 
 #define ODM_ANTDIV_2G	BIT(0)
 #define ODM_ANTDIV_5G	BIT(1)
@@ -75,6 +106,10 @@
 #define ANTDIV_ON	1
 #define ANTDIV_OFF	0
 
+#define ANT_PATH_A	0
+#define ANT_PATH_B	1
+#define ANT_PATH_AB	2
+
 #define FAT_ON	1
 #define FAT_OFF	0
 
@@ -128,25 +163,34 @@
 #define RSSI_CHECK_RESET_PERIOD	10
 #define RSSI_CHECK_THRESHOLD		50
 
-/*Hong Lin Smart antenna*/
+/*@Hong Lin Smart antenna*/
 #define HL_SMTANT_2WIRE_DATA_LEN 24
 
-/* 1 ============================================================
+#if (RTL8723D_SUPPORT == 1)
+	#ifndef CONFIG_ANTDIV_PERIOD
+		#define CONFIG_ANTDIV_PERIOD 1
+	#endif
+#endif
+/* @1 ============================================================
  * 1  structure
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
 
-struct _sw_antenna_switch_ {
-	u8		double_chk_flag;	/*If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than check this antenna again*/
+struct sw_antenna_switch {
+	u8		double_chk_flag;
+	/*@If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than*/
+	/*@check this antenna again*/
 	u8		try_flag;
 	s32		pre_rssi;
 	u8		cur_antenna;
-	u8		pre_antenna;
+	u8		pre_ant;
 	u8		rssi_trying;
 	u8		reset_idx;
 	u8		train_time;
-	u8		train_time_flag; /*base on RSSI difference between two antennas*/
-	struct timer_list	phydm_sw_antenna_switch_timer;
+	u8		train_time_flag;
+	/*@base on RSSI difference between two antennas*/
+	struct phydm_timer_list	sw_antdiv_timer;
 	u32		pkt_cnt_sw_ant_div_by_ctrl_frame;
 	boolean		is_sw_ant_div_by_ctrl_frame;
 
@@ -156,7 +200,7 @@ struct _sw_antenna_switch_ {
 #endif
 #endif
 
-	/* AntDect (Before link Antenna Switch check) need to be moved*/
+	/* @AntDect (Before link Antenna Switch check) need to be moved*/
 	u16		single_ant_counter;
 	u16		dual_ant_counter;
 	u16		aux_fail_detec_counter;
@@ -164,25 +208,22 @@ struct _sw_antenna_switch_ {
 	u8		swas_no_link_state;
 	u32		swas_no_link_bk_reg948;
 	boolean		ANTA_ON;	/*To indicate ant A is or not*/
-	boolean		ANTB_ON;	/*To indicate ant B is on or not*/
+	boolean		ANTB_ON;	/*@To indicate ant B is on or not*/
 	boolean		pre_aux_fail_detec;
 	boolean		rssi_ant_dect_result;
 	u8		ant_5g;
 	u8		ant_2g;
-
-
 };
 
-
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
 struct _BF_DIV_COEX_ {
 	boolean w_bfer_client[ODM_ASSOCIATE_ENTRY_NUM];
 	boolean w_bfee_client[ODM_ASSOCIATE_ENTRY_NUM];
-	u32	MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
-	u32	MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
+	u32 MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
+	u32 MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
 
-	u8  bd_ccoex_type_wbfer;
+	u8 bd_ccoex_type_wbfer;
 	u8 num_txbfee_client;
 	u8 num_txbfer_client;
 	u8 bdc_try_counter;
@@ -205,7 +246,6 @@ struct _BF_DIV_COEX_ {
 #endif
 #endif
 
-
 struct phydm_fat_struct {
 	u8	bssid[6];
 	u8	antsel_rx_keep_0;
@@ -221,17 +261,19 @@ struct phydm_fat_struct {
 	u8	antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
 	u8	antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
 	u8	antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	main_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	aux_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	main_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	aux_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	main_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	aux_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	main_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
-	u16	aux_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	main_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
+	u16	aux_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
 	u8	rx_idle_ant;
+	u8	rx_idle_ant2;
 	u8	rvrt_val;
 	u8	ant_div_on_off;
+	u8	div_path_type;
 	boolean	is_become_linked;
 	u32	min_max_rssi;
 	u8	idx_ant_div_counter_2g;
@@ -239,19 +281,19 @@ struct phydm_fat_struct {
 	u8	ant_div_2g_5g;
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-	/*For 1SS RX phy rate*/
-	u32	main_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u32	aux_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
-	u32	main_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u32	aux_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
-
-	/*For 2SS RX phy rate*/
-	u32	main_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];	/*2SS with A1+B*/
-	u32	aux_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];	/*2SS with A2+B*/
-	u32	main_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
-	u32	aux_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
-
-	boolean	EVM_method_enable;
+	/*@For 1SS RX phy rate*/
+	u32	main_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	main_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+
+	/*@For 2SS RX phy rate*/
+	u32	main_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];/*@2SS with A1+B*/
+	u32	aux_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];/*@2SS with A2+B*/
+	u32	main_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+	u32	aux_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
+
+	boolean	evm_method_enable;
 	u8	target_ant_evm;
 	u8	target_ant_crc32;
 	u8	target_ant_tp;
@@ -267,10 +309,10 @@ struct phydm_fat_struct {
 	u32	main_crc32_fail_cnt;
 	u32	aux_crc32_fail_cnt;
 
-	u32	antdiv_tp_main;
-	u32	antdiv_tp_aux;
-	u32	antdiv_tp_main_cnt;
-	u32	antdiv_tp_aux_cnt;
+	u32	main_tp;
+	u32	aux_tp;
+	u32	main_tp_cnt;
+	u32	aux_tp_cnt;
 
 	u8	pre_antdiv_rssi;
 	u8	pre_antdiv_tp;
@@ -280,31 +322,32 @@ struct phydm_fat_struct {
 	u32    cck_ctrl_frame_cnt_aux;
 	u32    ofdm_ctrl_frame_cnt_main;
 	u32    ofdm_ctrl_frame_cnt_aux;
-	u32	main_ant_ctrl_frame_sum;
-	u32	aux_ant_ctrl_frame_sum;
-	u32	main_ant_ctrl_frame_cnt;
-	u32	aux_ant_ctrl_frame_cnt;
+	u32	main_ctrl_sum;
+	u32	aux_ctrl_sum;
+	u32	main_ctrl_cnt;
+	u32	aux_ctrl_cnt;
 #endif
 	u8	b_fix_tx_ant;
 	boolean	fix_ant_bfee;
 	boolean	enable_ctrl_frame_antdiv;
 	boolean	use_ctrl_frame_antdiv;
 	boolean	*is_no_csi_feedback;
+	boolean	force_antdiv_type;
+	u8	antdiv_type_dbg;
 	u8	hw_antsw_occur;
-	u8	*p_force_tx_ant_by_desc;
-	u8	force_tx_ant_by_desc; /*A temp value, will hook to driver team's outer parameter later*/
-	u8    *p_default_s0_s1;
-	u8    default_s0_s1;
+	u8	*p_force_tx_by_desc;
+	u8	force_tx_by_desc;
+	/*@A temp value, will hook to driver team's outer parameter later*/
+	u8	*p_default_s0_s1;
+	u8	default_s0_s1;
 };
 
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  enumeration
- * 1 ============================================================ */
-
+ * 1 ============================================================
+ */
 
-
-enum fat_state_e /*Fast antenna training*/
+enum fat_state /*@Fast antenna training*/
 {
 	FAT_BEFORE_LINK_STATE	= 0,
 	FAT_PREPARE_STATE			= 1,
@@ -312,296 +355,166 @@ enum fat_state_e /*Fast antenna training*/
 	FAT_DECISION_STATE		= 3
 };
 
-enum ant_div_type_e {
+enum ant_div_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,
-	S0S1_SW_ANTDIV          = 0x06, /*8723B intrnal switch S0 S1*/
-	S0S1_TRX_HW_ANTDIV     = 0x07, /*TRX S0S1 diversity for 8723D*/
-	HL_SW_SMART_ANT_TYPE1	= 0x10, /*Hong-Lin Smart antenna use for 8821AE which is a 2 ant. entitys, and each ant. is equipped with 4 antenna patterns*/
-	HL_SW_SMART_ANT_TYPE2	= 0x11 /*Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/
+	S0S1_SW_ANTDIV	= 0x06, /*@8723B intrnal switch S0 S1*/
+	S0S1_TRX_HW_ANTDIV	= 0x07, /*TRX S0S1 diversity for 8723D*/
+	HL_SW_SMART_ANT_TYPE1	= 0x10,
+	/*@Hong-Lin Smart antenna use for 8821AE which is a 2 ant. entitys,*/
+	/*@and each ant. is equipped with 4 antenna patterns*/
+	HL_SW_SMART_ANT_TYPE2	= 0x11
+	/*@Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/
 };
 
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  function prototype
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
+void odm_stop_antenna_switch_dm(void *dm_void);
 
-void
-odm_stop_antenna_switch_dm(
-	void	*p_dm_void
-);
+void phydm_enable_antenna_diversity(void *dm_void);
 
-void
-phydm_enable_antenna_diversity(
-	void			*p_dm_void
-);
+void odm_set_ant_config(void *dm_void, u8 ant_setting /* @0=A, 1=B, 2=C,....*/
+			);
 
-void
-odm_set_ant_config(
-	void	*p_dm_void,
-	u8		ant_setting	/* 0=A, 1=B, 2=C, .... */
-);
+#define sw_ant_div_rest_after_link odm_sw_ant_div_rest_after_link
 
+void odm_sw_ant_div_rest_after_link(void *dm_void);
 
-#define sw_ant_div_rest_after_link	odm_sw_ant_div_rest_after_link
+void odm_ant_div_on_off(void *dm_void, u8 swch, u8 path);
 
-void odm_sw_ant_div_rest_after_link(
-	void	*p_dm_void
-);
+void odm_tx_by_tx_desc_or_reg(void *dm_void, u8 swch);
 
-void
-odm_ant_div_on_off(
-	void		*p_dm_void,
-	u8		swch
-);
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
 
-void
-odm_tx_by_tx_desc_or_reg(
-	void		*p_dm_void,
-	u8		swch
-);
+void phydm_antdiv_reset_statistic(void *dm_void, u32 macid);
 
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+void odm_update_rx_idle_ant(void *dm_void, u8 ant);
 
-void
-phydm_antdiv_reset_statistic(
-	void	*p_dm_void,
-	u32	macid
-);
-
-void
-odm_update_rx_idle_ant(
-	void		*p_dm_void,
-	u8		ant
-);
-
-void
-phydm_set_antdiv_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-);
+void phydm_update_rx_idle_ant_pathb(void *dm_void, u8 ant);
+
+void phydm_set_antdiv_val(void *dm_void, u32 *val_buf,	u8 val_len);
 
 #if (RTL8723B_SUPPORT == 1)
-void
-odm_update_rx_idle_ant_8723b(
-	void			*p_dm_void,
-	u8			ant,
-	u32			default_ant,
-	u32			optional_ant
-);
+void odm_update_rx_idle_ant_8723b(void *dm_void, u8 ant, u32 default_ant,
+				  u32 optional_ant);
 #endif
 
 #if (RTL8188F_SUPPORT == 1)
-void
-phydm_update_rx_idle_antenna_8188F(
-	void	*p_dm_void,
-	u32	default_ant
-);
+void phydm_update_rx_idle_antenna_8188F(void *dm_void,	u32 default_ant);
 #endif
 
 #if (RTL8723D_SUPPORT == 1)
 
-void
-phydm_set_tx_ant_pwr_8723d(
-	void			*p_dm_void,
-	u8			ant
-);
+void phydm_set_tx_ant_pwr_8723d(void *dm_void, u8 ant);
 
-void
-odm_update_rx_idle_ant_8723d(
-	void			*p_dm_void,
-	u8			ant,
-	u32			default_ant,
-	u32			optional_ant
-);
+void odm_update_rx_idle_ant_8723d(void *dm_void, u8 ant, u32 default_ant,
+				  u32 optional_ant);
 
 #endif
 
 #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-odm_sw_antdiv_callback(
-	struct timer_list		*p_timer
-);
-
-void
-odm_sw_antdiv_workitem_callback(
-	void	*p_context
-);
+void odm_sw_antdiv_callback(struct phydm_timer_list *timer);
 
+void odm_sw_antdiv_workitem_callback(void *context);
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 
-void
-odm_sw_antdiv_workitem_callback(
-	void	*p_context
-);
+void odm_sw_antdiv_workitem_callback(void *context);
 
-void
-odm_sw_antdiv_callback(
-	void		*function_context
-);
+void odm_sw_antdiv_callback(void *function_context);
 
 #endif
 
-void
-odm_s0s1_sw_ant_div_by_ctrl_frame(
-	void			*p_dm_void,
-	u8			step
-);
-
-void
-odm_antsel_statistics_of_ctrl_frame(
-	void			*p_dm_void,
-	u8			antsel_tr_mux,
-	u32			rx_pwdb_all
-);
-
-void
-odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
-	void				*p_dm_void,
-	void		*p_phy_info_void,
-	void		*p_pkt_info_void
-);
+void odm_s0s1_sw_ant_div_by_ctrl_frame(void *dm_void, u8 step);
+
+void odm_antsel_statistics_ctrl(void *dm_void,	u8 antsel_tr_mux,
+				u32 rx_pwdb_all);
+
+void odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(void *dm_void,
+						    void *phy_info_void,
+						    void *pkt_info_void);
 
 #endif
 
 #ifdef ODM_EVM_ENHANCE_ANTDIV
-VOID
-phydm_evm_sw_antdiv_init(
-	void		*p_dm_void
-);
-
-void
-odm_evm_fast_ant_training_callback(
-	void		*p_dm_void
-);
+void phydm_evm_sw_antdiv_init(void *dm_void);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phydm_evm_antdiv_callback(struct phydm_timer_list *timer);
+
+void phydm_evm_antdiv_workitem_callback(void *context);
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void phydm_evm_antdiv_callback(void *dm_void);
+
+void phydm_evm_antdiv_workitem_callback(void *context);
+
+#else
+void phydm_evm_antdiv_callback(void *dm_void);
 #endif
 
-void
-odm_hw_ant_div(
-	void		*p_dm_void
-);
-
-#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
-void
-odm_fast_ant_training(
-	void		*p_dm_void
-);
-
-void
-odm_fast_ant_training_callback(
-	void		*p_dm_void
-);
-
-void
-odm_fast_ant_training_work_item_callback(
-	void		*p_dm_void
-);
 #endif
 
-void
-odm_ant_div_init(
-	void		*p_dm_void
-);
+void odm_hw_ant_div(void *dm_void);
 
-void
-odm_ant_div(
-	void		*p_dm_void
-);
+#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\
+	(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
+void odm_fast_ant_training(
+	void *dm_void);
 
-void
-odm_antsel_statistics(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	u8			antsel_tr_mux,
-	u32			mac_id,
-	u32			utility,
-	u8			method,
-	u8			is_cck_rate
-);
+void odm_fast_ant_training_callback(void *dm_void);
 
-void
-odm_process_rssi_for_ant_div(
-	void		*p_dm_void,
-	void		*p_phy_info_void,
-	void		*p_pkt_info_void
-);
+void odm_fast_ant_training_work_item_callback(void *dm_void);
+#endif
+
+void odm_ant_div_init(void *dm_void);
+
+void odm_ant_div(void *dm_void);
 
+void odm_antsel_statistics(void *dm_void, void *phy_info_void,
+			   u8 antsel_tr_mux, u32 mac_id, u32 utility, u8 method,
+			   u8 is_cck_rate);
 
+void odm_process_rssi_for_ant_div(void *dm_void, void *phy_info_void,
+				  void *pkt_info_void);
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-void
-odm_set_tx_ant_by_tx_info(
-	void			*p_dm_void,
-	u8			*p_desc,
-	u8			mac_id
-);
+void odm_set_tx_ant_by_tx_info(void *dm_void,	 u8 *desc, u8 mac_id);
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-struct tx_desc; /*declared tx_desc here or compile error happened when enabled 8822B*/
-
-void
-odm_set_tx_ant_by_tx_info(
-	struct	rtl8192cd_priv		*priv,
-	struct	tx_desc			*pdesc,
-	unsigned short			aid
-);
-
-#if 1/*def def CONFIG_WLAN_HAL*/
-void
-odm_set_tx_ant_by_tx_info_hal(
-	struct	rtl8192cd_priv		*priv,
-	void	*pdesc_data,
-	u16		aid
-);
-#endif	/*#ifdef CONFIG_WLAN_HAL*/
+struct tx_desc;
+/*@declared tx_desc here or compile error happened when enabled 8822B*/
+
+void odm_set_tx_ant_by_tx_info(struct rtl8192cd_priv *priv,
+			       struct tx_desc *pdesc, unsigned short aid);
+
+#if 1 /*@def def CONFIG_WLAN_HAL*/
+void odm_set_tx_ant_by_tx_info_hal(struct rtl8192cd_priv *priv,
+				   void *pdesc_data, u16 aid);
+#endif /*@#ifdef CONFIG_WLAN_HAL*/
 #endif
 
+void odm_ant_div_config(void *dm_void);
+
+void odm_ant_div_timers(void *dm_void, u8 state);
+
+void phydm_antdiv_debug(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len);
+
+void odm_ant_div_reset(void *dm_void);
+
+void odm_antenna_diversity_init(void *dm_void);
 
-void
-odm_ant_div_config(
-	void		*p_dm_void
-);
-
-void
-odm_ant_div_timers(
-	void		*p_dm_void,
-	u8		state
-);
-
-void
-phydm_antdiv_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char			*output,
-	u32		*_out_len
-);
-
-#endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
-
-void
-odm_ant_div_reset(
-	void		*p_dm_void
-);
-
-void
-odm_antenna_diversity_init(
-	void		*p_dm_void
-);
-
-void
-odm_antenna_diversity(
-	void		*p_dm_void
-);
-
-#endif /*#ifndef	__ODMANTDIV_H__*/
+void odm_antenna_diversity(void *dm_void);
+#endif /*@#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY*/
+#endif /*@#ifndef	__ODMANTDIV_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.c
index b23a0ccf445e..4d05a902189c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,177 +9,421 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ * ************************************************************
+ */
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
+void phydm_reset_bb_hw_cnt(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	/*@ Reset all counter when 1 */
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		odm_set_bb_reg(dm, R_0x1eb4, BIT(25), 1);
+		odm_set_bb_reg(dm, R_0x1eb4, BIT(25), 0);
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		/*@ Reset all counter when 1 (including PMAC and PHY)*/
+		/* Reset Page F counter*/
+		odm_set_bb_reg(dm, R_0xb58, BIT(0), 1);
+		odm_set_bb_reg(dm, R_0xb58, BIT(0), 0);
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0xf14, BIT(16), 0x1);
+		odm_set_bb_reg(dm, R_0xf14, BIT(16), 0x0);
+	}
+}
 
-void
-phydm_init_trx_antenna_setting(
-	void		*p_dm_void
-)
+void phydm_dynamic_ant_weighting(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	
-	if (p_dm->support_ic_type & (ODM_RTL8814A)) {
-		u8	rx_ant = 0, tx_ant = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-		rx_ant = (u8)odm_get_bb_reg(p_dm, ODM_REG(BB_RX_PATH, p_dm), ODM_BIT(BB_RX_PATH, p_dm));
-		tx_ant = (u8)odm_get_bb_reg(p_dm, ODM_REG(BB_TX_PATH, p_dm), ODM_BIT(BB_TX_PATH, p_dm));
-		p_dm->tx_ant_status = (tx_ant & 0xf);
-		p_dm->rx_ant_status = (rx_ant & 0xf);
-	} else if (p_dm->support_ic_type & (ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B)) {/* JJ ADD 20161014 */
-		p_dm->tx_ant_status = 0x1;
-		p_dm->rx_ant_status = 0x1;
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+	#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8197F))
+		phydm_dynamic_ant_weighting_8197f(dm);
+	#endif
 
+	#if (RTL8812A_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8812)) {
+		phydm_dynamic_ant_weighting_8812a(dm);
 	}
+	#endif
+
+	#if (RTL8822B_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8822B))
+		phydm_dynamic_ant_weighting_8822b(dm);
+	#endif
+#endif
 }
 
-void
-phydm_config_ofdm_tx_path(
-	void			*p_dm_void,
-	u32			path
-)
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void phydm_ant_weight_dbg(void *dm_void, char input[][16], u32 *_used,
+			  char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-#if ((RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1))
-	u8	ofdm_tx_path = 0x33;
-#endif
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
 
-#if (RTL8192E_SUPPORT == 1)
-	if (p_dm->support_ic_type & (ODM_RTL8192E)) {
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "echo dis_dym_ant_weighting {0/1}\n");
 
-		if (path == BB_PATH_A) {
-			odm_set_bb_reg(p_dm, 0x90c, MASKDWORD, 0x81121111);
-			/**/
-		} else if (path == BB_PATH_B) {
-			odm_set_bb_reg(p_dm, 0x90c, MASKDWORD, 0x82221222);
-			/**/
-		} else  if (path == BB_PATH_AB) {
-			odm_set_bb_reg(p_dm, 0x90c, MASKDWORD, 0x83321333);
-			/**/
+	} else {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 1) {
+			dm->is_disable_dym_ant_weighting = 1;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Disable dyn-ant-weighting\n");
+		} else {
+			dm->is_disable_dym_ant_weighting = 0;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Enable dyn-ant-weighting\n");
 		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
 
+void phydm_iq_gen_en(void *dm_void)
+{
+#ifdef PHYDM_COMPILE_IC_2SS
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	enum rf_path path = RF_PATH_A;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (!(dm->support_ic_type & ODM_IC_11AC_SERIES))
+		return;
 
+	for (i = RF_PATH_A; i <= RF_PATH_B; i++) {
+		path = (enum rf_path)i;
+
+		/*RF mode table write enable*/
+		odm_set_rf_reg(dm, path, RF_0xef, BIT(19), 0x1);
+		/*Select RX mode*/
+		odm_set_rf_reg(dm, path, RF_0x33, 0xF, 3);
+		/*Set Table data*/
+		odm_set_rf_reg(dm, path, RF_0x3e, 0xfffff, 0x00036);
+		/*Set Table data*/
+		odm_set_rf_reg(dm, path, RF_0x3f, 0xfffff, 0x5AFCE);
+		/*RF mode table write disable*/
+		odm_set_rf_reg(dm, path, RF_0xef, BIT(19), 0x0);
+	}
+	#endif
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	if (!(dm->support_ic_type & ODM_IC_11N_SERIES))
+		return;
+	if (dm->support_ic_type & ODM_RTL8192F) {
+		 /*RF mode table write enable*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, 0x80000, 0x1);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0xef, 0x80000, 0x1);
+		/* Path A */
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x30, 0xfffff, 0x08000);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x31, 0xfffff, 0x0005f);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x32, 0xfffff, 0x01042);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x30, 0xfffff, 0x18000);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x31, 0xfffff, 0x0004f);
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x32, 0xfffff, 0x71fc2);
+		/* Path B */
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x30, 0xfffff, 0x08000);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x31, 0xfffff, 0x00050);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x32, 0xfffff, 0x01042);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x30, 0xfffff, 0x18000);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x31, 0xfffff, 0x00040);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x32, 0xfffff, 0x71fc2);
+		/*RF mode table write disable*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, 0x80000, 0x0);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0xef, 0x80000, 0x0);
 	}
+	#endif
 #endif
+}
 
-#if (RTL8812A_SUPPORT == 1)
-	if (p_dm->support_ic_type & (ODM_RTL8812)) {
+void phydm_dis_cdd(void *dm_void)
+{
+#ifdef PHYDM_COMPILE_IC_2SS
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x808, 0x3ffff00, 0);
+		odm_set_bb_reg(dm, R_0x9ac, 0x1fff, 0);
+		odm_set_bb_reg(dm, R_0x9ac, BIT(13), 1);
+	}
+	#endif
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0x90c, 0xffffffff, 0x83321333);
+		/* Set Tx delay setting for CCK pathA,B*/
+		odm_set_bb_reg(dm, R_0xa2c, 0xf0000000, 0);
+		//Enable Tx CDD for HT-portion when spatial expansion is applied
+		odm_set_bb_reg(dm, R_0xd00, BIT(8), 0);
+		/* Tx CDD for Legacy*/
+		odm_set_bb_reg(dm, R_0xd04, 0xf0000, 0);
+		/* Tx CDD for non-HT*/
+		odm_set_bb_reg(dm, R_0xd0c, 0x3c0, 0);
+		/* Tx CDD for HT SS1*/
+		odm_set_bb_reg(dm, R_0xd0c, 0xf8000, 0);
+	}
+	#endif
+#endif
+}
 
-		if (path == BB_PATH_A) {
-			ofdm_tx_path = 0x11;
-			/**/
-		} else if (path == BB_PATH_B) {
-			ofdm_tx_path = 0x22;
-			/**/
-		} else  if (path == BB_PATH_AB) {
-			ofdm_tx_path = 0x33;
-			/**/
-		}
+void phydm_pathb_q_matrix_rotate_en(void *dm_void)
+{
+#ifdef PHYDM_COMPILE_IC_2SS
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		phydm_iq_gen_en(dm);
+
+		#ifdef PHYDM_COMMON_API_SUPPORT
+		if (!phydm_api_trx_mode(dm, BB_PATH_AB, BB_PATH_AB, true))
+			return;
+		#endif
+
+		phydm_dis_cdd(dm);
+		/*Set Q matrix r_v11 =1*/
+		odm_set_bb_reg(dm, R_0x195c, MASKDWORD, 0x40000);
+		phydm_pathb_q_matrix_rotate(dm, 0);
+		/*Set Q matrix enable*/
+		odm_set_bb_reg(dm, R_0x191c, BIT(7), 1);
+	}
+	#endif
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		phydm_iq_gen_en(dm);
 
-		odm_set_bb_reg(p_dm, 0x80c, 0xff00, ofdm_tx_path);
+		#ifdef PHYDM_COMMON_API_SUPPORT
+		if (!phydm_api_trx_mode(dm, BB_PATH_AB, BB_PATH_AB, true))
+			return;
+		#endif
+		phydm_dis_cdd(dm);
+		phydm_pathb_q_matrix_rotate(dm, 0);
 	}
+	#endif
 #endif
 }
 
-void
-phydm_config_ofdm_rx_path(
-	void			*p_dm_void,
-	u32			path
-)
+void phydm_pathb_q_matrix_rotate(void *dm_void, u16 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	ofdm_rx_path = 0;
+#ifdef PHYDM_COMPILE_IC_2SS
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	u32 phase_table_0[12] = {0x40000, 0x376CF, 0x20000, 0x00000,
+				 0xFE0000, 0xFC8930, 0xFC0000, 0xFC8930,
+				 0xFDFFFF, 0x000000, 0x020000, 0x0376CF};
+	u32 phase_table_1[12] = {0x00000, 0x1FFFF, 0x376CF, 0x40000,
+				 0x0376CF, 0x01FFFF, 0x000000, 0xFDFFFF,
+				 0xFC8930, 0xFC0000, 0xFC8930, 0xFDFFFF};
+	#endif
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	u32 phase_table_N_0[12] = {0x00, 0x0B, 0x02, 0x00, 0x02, 0x02, 0x04,
+				   0x02, 0x0D, 0x09, 0x04, 0x0B};
+	u32 phase_table_N_1[12] = {0x40000100, 0x377F00DD, 0x201D8880,
+				   0x00000000, 0xE01D8B80, 0xC8BF0322,
+				   0xC000FF00, 0xC8BF0322, 0xDFE2777F,
+				   0xFFC003FF, 0x20227480, 0x377F00DD};
+	u32 phase_table_N_2[12] = {0x00, 0x1E, 0x3C, 0x4C, 0x3C, 0x1E, 0x0F,
+				   0xD2, 0xC3, 0xC4, 0xC3, 0xD2};
+	#endif
+	if (idx >= 12) {
+		PHYDM_DBG(dm, ODM_COMP_API, "Phase Set Error: %d\n", idx);
+		return;
+	}
 
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		/*Set Q matrix r_v21*/
+		odm_set_bb_reg(dm, R_0x1954, 0xffffff, phase_table_0[idx]);
+		odm_set_bb_reg(dm, R_0x1950, 0xffffff, phase_table_1[idx]);
+	}
+	#endif
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/*Set Q matrix r_v21*/
+		odm_set_bb_reg(dm, R_0xc4c, 0xff000000, phase_table_N_0[idx]);
+		odm_set_bb_reg(dm, R_0xc88, 0xffffffff, phase_table_N_1[idx]);
+		odm_set_bb_reg(dm, R_0xc9c, 0xff000000, phase_table_N_2[idx]);
+	}
+	#endif
+#endif
+}
 
-	if (p_dm->support_ic_type & (ODM_RTL8192E)) {
-#if (RTL8192E_SUPPORT == 1)
-		if (path == BB_PATH_A) {
-			ofdm_rx_path = 1;
-			/**/
-		} else if (path == BB_PATH_B) {
-			ofdm_rx_path = 2;
-			/**/
-		} else  if (path == BB_PATH_AB) {
-			ofdm_rx_path = 3;
-			/**/
-		}
+void phydm_trx_antenna_setting_init(void *dm_void, u8 num_rf_path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rx_ant = 0, tx_ant = 0;
+	u8 path_bitmap = 1;
 
-		odm_set_bb_reg(p_dm, 0xC04, 0xff, (((ofdm_rx_path) << 4) | ofdm_rx_path));
-		odm_set_bb_reg(p_dm, 0xD04, 0xf, ofdm_rx_path);
+	path_bitmap = (u8)phydm_gen_bitmask(num_rf_path);
+#if 0
+	/*PHYDM_DBG(dm, ODM_COMP_INIT, "path_bitmap=0x%x\n", path_bitmap);*/
 #endif
+
+	dm->tx_ant_status = path_bitmap;
+	dm->rx_ant_status = path_bitmap;
+
+	if (num_rf_path == PDM_1SS)
+		return;
+
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type &
+		   (ODM_RTL8192F | ODM_RTL8192E | ODM_RTL8197F)) {
+		dm->rx_ant_status = (u8)odm_get_bb_reg(dm, R_0xc04, 0x3);
+		dm->tx_ant_status = (u8)odm_get_bb_reg(dm, R_0x90c, 0x3);
+	} else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8814A)) {
+		dm->rx_ant_status = (u8)odm_get_bb_reg(dm, R_0x808, 0xf);
+		dm->tx_ant_status = (u8)odm_get_bb_reg(dm, R_0x80c, 0xf);
 	}
-#if (RTL8812A_SUPPORT || RTL8822B_SUPPORT)
-	else if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8822B)) {
+	#endif
+	#if (defined(PHYDM_IC_JGR3_SERIES_SUPPORT))
+	if (dm->support_ic_type & ODM_RTL8814B) {
+		dm->rx_ant_status = (u8)odm_get_bb_reg(dm, R_0x824, 0xf0000);
+		dm->tx_ant_status = (u8)odm_get_bb_reg(dm, R_0x820, 0xf);
+	}
+	#endif
 
-		if (path == BB_PATH_A) {
-			ofdm_rx_path = 1;
-			/**/
-		} else if (path == BB_PATH_B) {
-			ofdm_rx_path = 2;
-			/**/
-		} else  if (path == BB_PATH_AB) {
-			ofdm_rx_path = 3;
-			/**/
-		}
+	PHYDM_DBG(dm, ODM_COMP_INIT, "[%s]ant_status{tx,rx}={0x%x, 0x%x}\n",
+		  __func__, dm->tx_ant_status, dm->rx_ant_status);
+}
+
+void phydm_config_ofdm_tx_path(void *dm_void, u32 path)
+{
+#if (RTL8192E_SUPPORT || RTL8812A_SUPPORT)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 ofdm_tx_path = 0x33;
+
+	if (dm->num_rf_path == PDM_1SS)
+		return;
 
-		odm_set_bb_reg(p_dm, 0x808, MASKBYTE0, ((ofdm_rx_path << 4) | ofdm_rx_path));
+	switch (dm->support_ic_type) {
+	#if (RTL8192E_SUPPORT)
+	case ODM_RTL8192E:
+		if (path == BB_PATH_A)
+			odm_set_bb_reg(dm, R_0x90c, MASKDWORD, 0x81121111);
+		else if (path == BB_PATH_B)
+			odm_set_bb_reg(dm, R_0x90c, MASKDWORD, 0x82221222);
+		else if (path == BB_PATH_AB)
+			odm_set_bb_reg(dm, R_0x90c, MASKDWORD, 0x83321333);
+
+		break;
+	#endif
+
+	#if (RTL8812A_SUPPORT)
+	case ODM_RTL8812:
+		if (path == BB_PATH_A)
+			ofdm_tx_path = 0x11;
+		else if (path == BB_PATH_B)
+			ofdm_tx_path = 0x22;
+		else if (path == BB_PATH_AB)
+			ofdm_tx_path = 0x33;
+
+		odm_set_bb_reg(dm, R_0x80c, 0xff00, ofdm_tx_path);
+
+		break;
+	#endif
+
+	default:
+		break;
+	}
+#endif
+}
+
+void phydm_config_ofdm_rx_path(void *dm_void, u32 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 val = 0;
+
+	if (dm->support_ic_type & (ODM_RTL8192E)) {
+#if (RTL8192E_SUPPORT)
+		if (path == BB_PATH_A)
+			val = 1;
+		else if (path == BB_PATH_B)
+			val = 2;
+		else if (path == BB_PATH_AB)
+			val = 3;
+
+		odm_set_bb_reg(dm, R_0xc04, 0xff, ((val << 4) | val));
+		odm_set_bb_reg(dm, R_0xd04, 0xf, val);
+#endif
+	}
+#if (RTL8812A_SUPPORT || RTL8822B_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8822B)) {
+		if (path == BB_PATH_A)
+			val = 1;
+		else if (path == BB_PATH_B)
+			val = 2;
+		else if (path == BB_PATH_AB)
+			val = 3;
+
+		odm_set_bb_reg(dm, R_0x808, MASKBYTE0, ((val << 4) | val));
 	}
 #endif
 }
 
-void
-phydm_config_cck_rx_antenna_init(
-	void		*p_dm_void
-)
+void phydm_config_cck_rx_antenna_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 #if (defined(PHYDM_COMPILE_ABOVE_2SS))
-	/*CCK 2R CCA parameters*/
-	odm_set_bb_reg(p_dm, 0xa00, BIT(15), 0x0); /*Disable antenna diversity*/
-	odm_set_bb_reg(p_dm, 0xa70, BIT(7), 0); /*Concurrent CCA at LSB & USB*/
-	odm_set_bb_reg(p_dm, 0xa74, BIT(8), 0); /*RX path diversity enable*/
-	odm_set_bb_reg(p_dm, 0xa14, BIT(7), 0); /*r_en_mrc_antsel*/
-	odm_set_bb_reg(p_dm, 0xa20, (BIT(5) | BIT(4)), 1); /*MBC weighting*/
-
-	if (p_dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F)) {
-		odm_set_bb_reg(p_dm, 0xa08, BIT(28), 1); /*r_cck_2nd_sel_eco*/
-		/**/
-	} else if (p_dm->support_ic_type & ODM_RTL8814A) {
-		odm_set_bb_reg(p_dm, 0xa84, BIT(28), 1); /*2R CCA only*/
-		/**/
-	}
+	if (dm->support_ic_type & ODM_IC_1SS)
+		return;
+
+	/*@CCK 2R CCA parameters*/
+	odm_set_bb_reg(dm, R_0xa00, BIT(15), 0x0); /*@Disable Ant diversity*/
+	odm_set_bb_reg(dm, R_0xa70, BIT(7), 0); /*@Concurrent CCA at LSB & USB*/
+	odm_set_bb_reg(dm, R_0xa74, BIT(8), 0); /*RX path diversity enable*/
+	odm_set_bb_reg(dm, R_0xa14, BIT(7), 0); /*r_en_mrc_antsel*/
+	odm_set_bb_reg(dm, R_0xa20, (BIT(5) | BIT(4)), 1); /*@MBC weighting*/
+
+	if (dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8192F))
+		odm_set_bb_reg(dm, R_0xa08, BIT(28), 1); /*r_cck_2nd_sel_eco*/
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		odm_set_bb_reg(dm, R_0xa84, BIT(28), 1); /*@2R CCA only*/
 #endif
 }
 
-void
-phydm_config_cck_rx_path(
-	void		*p_dm_void,
-	enum bb_path			path
-)
+void phydm_config_cck_rx_path(void *dm_void, enum bb_path path)
 {
 #if (defined(PHYDM_COMPILE_ABOVE_2SS))
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	path_div_select = 0;
-	u8	cck_path[2] = {0};
-	u8	en_2R_path = 0;
-	u8	en_2R_mrc = 0;
-	u8	i = 0, j =0; 
-	u8	num_enable_path = 0;
-	u8	cck_mrc_max_path = 2;
-	
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 path_div_select = 0;
+	u8 cck_path[2] = {0};
+	u8 en_2R_path = 0;
+	u8 en_2R_mrc = 0;
+	u8 i = 0, j = 0;
+	u8 num_enable_path = 0;
+	u8 cck_mrc_max_path = 2;
+
+	if (dm->support_ic_type & ODM_IC_1SS)
+		return;
+
 	for (i = 0; i < 4; i++) {
-		if (path & BIT(i)) { /*ex: PHYDM_ABCD*/
+		if (path & BIT(i)) { /*@ex: PHYDM_ABCD*/
 			num_enable_path++;
 			cck_path[j] = i;
 			j++;
@@ -196,299 +441,551 @@ phydm_config_cck_rx_path(
 		en_2R_path = 0;
 		en_2R_mrc = 0;
 	}
-		
-	odm_set_bb_reg(p_dm, 0xa04, (BIT(27) | BIT(26)), cck_path[0]);	/*CCK_1 input signal path*/
-	odm_set_bb_reg(p_dm, 0xa04, (BIT(25) | BIT(24)), cck_path[1]);	/*CCK_2 input signal path*/
-	odm_set_bb_reg(p_dm, 0xa74, BIT(8), path_div_select);	/*enable Rx path diversity*/
-	odm_set_bb_reg(p_dm, 0xa2c, BIT(18), en_2R_path);	/*enable 2R Rx path*/
-	odm_set_bb_reg(p_dm, 0xa2c, BIT(22), en_2R_mrc);	/*enable 2R MRC*/
-	
+	/*@CCK_1 input signal path*/
+	odm_set_bb_reg(dm, R_0xa04, (BIT(27) | BIT(26)), cck_path[0]);
+	/*@CCK_2 input signal path*/
+	odm_set_bb_reg(dm, R_0xa04, (BIT(25) | BIT(24)), cck_path[1]);
+	/*@enable Rx path diversity*/
+	odm_set_bb_reg(dm, R_0xa74, BIT(8), path_div_select);
+	/*@enable 2R Rx path*/
+	odm_set_bb_reg(dm, R_0xa2c, BIT(18), en_2R_path);
+	/*@enable 2R MRC*/
+	odm_set_bb_reg(dm, R_0xa2c, BIT(22), en_2R_mrc);
+	if (dm->support_ic_type & ODM_RTL8192F) {
+		if (path == BB_PATH_A) {
+			odm_set_bb_reg(dm, R_0xa04, (BIT(27) | BIT(26)), 0);
+			odm_set_bb_reg(dm, R_0xa04, (BIT(25) | BIT(24)), 0);
+			odm_set_bb_reg(dm, R_0xa74, BIT(8), 0);
+			odm_set_bb_reg(dm, R_0xa2c, (BIT(18) | BIT(17)), 0);
+			odm_set_bb_reg(dm, R_0xa2c, (BIT(22) | BIT(21)), 0);
+		} else if (path == BB_PATH_B) {/*@for DC cancellation*/
+			odm_set_bb_reg(dm, R_0xa04, (BIT(27) | BIT(26)), 1);
+			odm_set_bb_reg(dm, R_0xa04, (BIT(25) | BIT(24)), 1);
+			odm_set_bb_reg(dm, R_0xa74, BIT(8), 0);
+			odm_set_bb_reg(dm, R_0xa2c, (BIT(18) | BIT(17)), 0);
+			odm_set_bb_reg(dm, R_0xa2c, (BIT(22) | BIT(21)), 0);
+		} else if (path == BB_PATH_AB) {
+			odm_set_bb_reg(dm, R_0xa04, (BIT(27) | BIT(26)), 0);
+			odm_set_bb_reg(dm, R_0xa04, (BIT(25) | BIT(24)), 1);
+			odm_set_bb_reg(dm, R_0xa74, BIT(8), 1);
+			odm_set_bb_reg(dm, R_0xa2c, (BIT(18) | BIT(17)), 1);
+			odm_set_bb_reg(dm, R_0xa2c, (BIT(22) | BIT(21)), 1);
+		}
+	}
+
+#endif
+}
+
+void phydm_config_cck_tx_path(void *dm_void, enum bb_path path)
+{
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (path == BB_PATH_A)
+		odm_set_bb_reg(dm, R_0xa04, 0xf0000000, 0x8);
+	else if (path == BB_PATH_B)
+		odm_set_bb_reg(dm, R_0xa04, 0xf0000000, 0x4);
+	else if (path == BB_PATH_AB)
+		odm_set_bb_reg(dm, R_0xa04, 0xf0000000, 0xc);
 #endif
 }
 
-void
-phydm_config_trx_path(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void phydm_config_trx_path_v2(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT ||\
+	RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u32 val[10] = {0};
+	char help[] = "-h";
+	u8 i = 0, input_idx = 0;
+	enum bb_path tx_path, rx_path;
+	boolean dbg_mode_en, tx2_path_en;
+
+	if (!(dm->support_ic_type &
+	    (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8192F | ODM_RTL8822C |
+	     ODM_RTL8814B)))
+		return;
 
-	/* CCK */
-	if (dm_value[0] == 0) {
-
-		if (dm_value[1] == 1) { /*TX*/
-			if (dm_value[2] == 1)
-				odm_set_bb_reg(p_dm, 0xa04, 0xf0000000, 0x8);
-			else if (dm_value[2] == 2)
-				odm_set_bb_reg(p_dm, 0xa04, 0xf0000000, 0x4);
-			else if (dm_value[2] == 3)
-				odm_set_bb_reg(p_dm, 0xa04, 0xf0000000, 0xc);
-		} else if (dm_value[1] == 2) { /*RX*/
-
-			phydm_config_cck_rx_antenna_init(p_dm);
-
-			if (dm_value[2] == 1)
-				phydm_config_cck_rx_path(p_dm, BB_PATH_A);
-			else  if (dm_value[2] == 2)
-				phydm_config_cck_rx_path(p_dm, BB_PATH_B);
-			else  if (dm_value[2] == 3) {
-				phydm_config_cck_rx_path(p_dm, BB_PATH_AB);
-			}
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &val[i]);
+			input_idx++;
 		}
 	}
-	/* OFDM */
-	else if (dm_value[0] == 1) {
-
-		if (dm_value[1] == 1) { /*TX*/
-			phydm_config_ofdm_tx_path(p_dm, dm_value[2]);
-			/**/
-		} else if (dm_value[1] == 2) { /*RX*/
-			phydm_config_ofdm_rx_path(p_dm, dm_value[2]);
-			/**/
+
+	if (input_idx == 0)
+		return;
+
+	dbg_mode_en = (boolean)val[0];
+	tx_path = (enum bb_path)val[1];
+	rx_path = (enum bb_path)val[2];
+	tx2_path_en = (boolean)val[3];
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{en} {tx_path} {rx_path} {1ss_tx_2_path_en}\n");
+
+	} else if (dbg_mode_en) {
+		dm->is_disable_phy_api = false;
+		phydm_api_trx_mode(dm, tx_path, rx_path, tx2_path_en);
+		dm->is_disable_phy_api = true;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "tx_path = 0x%x, rx_path = 0x%x, tx2_path_en = %d\n",
+			 tx_path, rx_path, tx2_path_en);
+	} else {
+		dm->is_disable_phy_api = false;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Disable API debug mode\n");
+	}
+#endif
+}
+
+void phydm_config_trx_path_v1(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len)
+{
+#if (RTL8192E_SUPPORT || RTL8812A_SUPPORT)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 val[10] = {0};
+	char help[] = "-h";
+	u8 i = 0, input_idx = 0;
+
+	if (!(dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8812)))
+		return;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &val[i]);
+			input_idx++;
+		}
+	}
+
+	if (input_idx == 0)
+		return;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{0:CCK, 1:OFDM} {1:TX, 2:RX} {1:path_A, 2:path_B, 3:path_AB}\n");
+
+		*_used = used;
+		*_out_len = out_len;
+		return;
+
+	} else if (val[0] == 0) {
+	/* @CCK */
+		if (val[1] == 1) { /*TX*/
+			if (val[2] == 1)
+				phydm_config_cck_tx_path(dm, BB_PATH_A);
+			else if (val[2] == 2)
+				phydm_config_cck_tx_path(dm, BB_PATH_B);
+			else if (val[2] == 3)
+				phydm_config_cck_tx_path(dm, BB_PATH_AB);
+		} else if (val[1] == 2) { /*RX*/
+
+			phydm_config_cck_rx_antenna_init(dm);
+
+			if (val[2] == 1)
+				phydm_config_cck_rx_path(dm, BB_PATH_A);
+			else if (val[2] == 2)
+				phydm_config_cck_rx_path(dm, BB_PATH_B);
+			else if (val[2] == 3)
+				phydm_config_cck_rx_path(dm, BB_PATH_AB);
+			}
 		}
+	/* OFDM */
+	else if (val[0] == 1) {
+		if (val[1] == 1) /*TX*/
+			phydm_config_ofdm_tx_path(dm, val[2]);
+		else if (val[1] == 2) /*RX*/
+			phydm_config_ofdm_rx_path(dm, val[2]);
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "PHYDM Set path [%s] [%s] = [%s%s%s%s]\n",
+		 (val[0] == 1) ? "OFDM" : "CCK",
+		 (val[1] == 1) ? "TX" : "RX",
+		 (val[2] & 0x1) ? "A" : "", (val[2] & 0x2) ? "B" : "",
+		 (val[2] & 0x4) ? "C" : "",
+		 (val[2] & 0x8) ? "D" : "");
+
+	*_used = used;
+	*_out_len = out_len;
+#endif
+}
+
+void phydm_config_trx_path(void *dm_void, char input[][16], u32 *_used,
+			   char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8812)) {
+		#if (RTL8192E_SUPPORT || RTL8812A_SUPPORT || RTL8814B_SUPPORT)
+		phydm_config_trx_path_v1(dm, input, _used, output, _out_len);
+		#endif
+	} else if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F |
+		   ODM_RTL8192F | ODM_RTL8822C)) {
+		#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT ||\
+		     RTL8192F_SUPPORT || RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+		phydm_config_trx_path_v2(dm, input, _used, output, _out_len);
+		#endif
 	}
+}
+
+void phydm_tx_2path(void *dm_void)
+{
+#if (defined(PHYDM_COMPILE_IC_2SS))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	enum bb_path rx_path = (enum bb_path)dm->rx_ant_status;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>\n", __func__);
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "PHYDM Set path [%s] [%s] = [%s%s%s%s]\n",
-			(dm_value[0] == 1) ? "OFDM" : "CCK",
-			(dm_value[1] == 1) ? "TX" : "RX",
-			(dm_value[2] & 0x1) ? "A" : "",
-			(dm_value[2] & 0x2) ? "B" : "",
-			(dm_value[2] & 0x4) ? "C" : "",
-			(dm_value[2] & 0x8) ? "D" : ""
-		       ));
 
+	if (!(dm->support_ic_type & ODM_IC_2SS))
+		return;
+
+	#if (RTL8822B_SUPPORT || RTL8192F_SUPPORT || RTL8197F_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8192F))
+		phydm_api_trx_mode(dm, BB_PATH_AB, rx_path, true);
+	#endif
+
+	#if (RTL8812A_SUPPORT || RTL8192E_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) {
+		phydm_config_cck_tx_path(dm, BB_PATH_AB);
+		phydm_config_ofdm_tx_path(dm, BB_PATH_AB);
+	}
+	#endif
+#endif
 }
 
-void
-phydm_stop_3_wire(
-	void		*p_dm_void,
-	u8		set_type
-)
+void phydm_stop_3_wire(void *dm_void, u8 set_type)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (set_type == PHYDM_SET) {
+		/*@[Stop 3-wires]*/
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			odm_set_bb_reg(dm, R_0x180c, 0x3, 0x0);
+			odm_set_bb_reg(dm, R_0x180c, BIT(28), 0x1);
+
+			#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+			if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS) {
+				odm_set_bb_reg(dm, R_0x410c, 0x3, 0x0);
+				odm_set_bb_reg(dm, R_0x410c, BIT(28), 0x1);
+			}
+			#endif
 
-		/*[Stop 3-wires]*/
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-			odm_set_bb_reg(p_dm, 0xc00, 0xf, 0x4);/*	hardware 3-wire off */
-			odm_set_bb_reg(p_dm, 0xe00, 0xf, 0x4);/*	hardware 3-wire off */
+			#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+			if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+				odm_set_bb_reg(dm, R_0x520c, 0x3, 0x0);
+				odm_set_bb_reg(dm, R_0x520c, BIT(28), 0x1);
+				odm_set_bb_reg(dm, R_0x530c, 0x3, 0x0);
+				odm_set_bb_reg(dm, R_0x530c, BIT(28), 0x1);
+			}
+			#endif
+		} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, R_0xc00, 0xf, 0x4);
+			odm_set_bb_reg(dm, R_0xe00, 0xf, 0x4);
 		} else {
-			odm_set_bb_reg(p_dm, 0x88c, 0xf00000, 0xf);	/* 3 wire Disable    88c[23:20]=0xf */
+			odm_set_bb_reg(dm, R_0x88c, 0xf00000, 0xf);
 		}
-		
-	} else {  /*if (set_type == PHYDM_REVERT)*/
-		
-		/*[Start 3-wires]*/
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-			odm_set_bb_reg(p_dm, 0xc00, 0xf, 0x7);/*	hardware 3-wire on */
-			odm_set_bb_reg(p_dm, 0xe00, 0xf, 0x7);/*	hardware 3-wire on */
+
+	} else { /*@if (set_type == PHYDM_REVERT)*/
+
+		/*@[Start 3-wires]*/
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			odm_set_bb_reg(dm, R_0x180c, 0x3, 0x3);
+			odm_set_bb_reg(dm, R_0x180c, BIT(28), 0x1);
+
+			#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+			if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS) {
+				odm_set_bb_reg(dm, R_0x410c, 0x3, 0x3);
+				odm_set_bb_reg(dm, R_0x410c, BIT(28), 0x1);
+			}
+			#endif
+
+			#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+			if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+				odm_set_bb_reg(dm, R_0x520c, 0x3, 0x3);
+				odm_set_bb_reg(dm, R_0x520c, BIT(28), 0x1);
+				odm_set_bb_reg(dm, R_0x530c, 0x3, 0x3);
+				odm_set_bb_reg(dm, R_0x530c, BIT(28), 0x1);
+			}
+			#endif
+		} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			odm_set_bb_reg(dm, R_0xc00, 0xf, 0x7);
+			odm_set_bb_reg(dm, R_0xe00, 0xf, 0x7);
 		} else {
-			odm_set_bb_reg(p_dm, 0x88c, 0xf00000, 0x0);	/* 3 wire enable 88c[23:20]=0x0 */
+			odm_set_bb_reg(dm, R_0x88c, 0xf00000, 0x0);
 		}
 	}
 }
 
-u8
-phydm_stop_ic_trx(
-	void		*p_dm_void,
-	u8		set_type
-	)
+u8 phydm_stop_ic_trx(void *dm_void, u8 set_type)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	phydm_api_stuc 	*p_api = &(p_dm->api_table);
-	u32		i;
-	u8		trx_idle_success = false;
-	u32		dbg_port_value = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_api_stuc *api = &dm->api_table;
+	u32 i = 0;
+	u8 trx_idle_success = false;
+	u32 dbg_port_value = 0;
 
 	if (set_type == PHYDM_SET) {
-		/*[Stop TRX]---------------------------------------------------------------------*/
-		if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_3, 0x0) == false) /*set debug port to 0x0*/
+	/*@[Stop TRX]---------------------------------------------------------*/
+		/*set debug port to 0x0*/
+		if (!phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3, 0x0))
 			return PHYDM_SET_FAIL;
-		
-		for (i = 0; i<10000; i++) {
-			dbg_port_value = phydm_get_bb_dbg_port_value(p_dm);
-			if ((dbg_port_value & (BIT(17) | BIT(3))) == 0)	/* PHYTXON && CCA_all */ {
-				PHYDM_DBG(p_dm, ODM_COMP_API, ("PSD wait for ((%d)) times\n", i));
-				
-				trx_idle_success = true;
-				break;
+
+		for (i = 0; i < 100; i++) {
+			dbg_port_value = phydm_get_bb_dbg_port_val(dm);
+
+			if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+				/* BB idle */
+				if ((dbg_port_value & 0x1FFEFF3F) == 0 &&
+				    (dbg_port_value & 0xC0010000) ==
+				    0xC0010000) {
+					PHYDM_DBG(dm, ODM_COMP_API,
+						  "Stop trx wait for (%d) times\n",
+						  i);
+
+					trx_idle_success = true;
+					break;
+				}
+			} else {
+				/* PHYTXON && CCA_all */
+				if ((dbg_port_value & (BIT(17) | BIT(3)))
+				     == 0) {
+					PHYDM_DBG(dm, ODM_COMP_API,
+						  "Stop trx wait for (%d) times\n",
+						  i);
+
+					trx_idle_success = true;
+					break;
+				}
 			}
+			ODM_delay_ms(1);
 		}
-		phydm_release_bb_dbg_port(p_dm);
-		
-		if (trx_idle_success) {
+		phydm_release_bb_dbg_port(dm);
 
-			p_api->tx_queue_bitmap = (u8)odm_get_bb_reg(p_dm, 0x520, 0xff0000);
-			
-			odm_set_bb_reg(p_dm, 0x520, 0xff0000, 0xff); /*pause all TX queue*/
-			
-			if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-				odm_set_bb_reg(p_dm, 0x808, BIT(28), 0); /*disable CCK block*/
-				odm_set_bb_reg(p_dm, 0x838, BIT(1), 1); /*disable OFDM RX CCA*/
-			} else {
-				/*TBD*/
-				odm_set_bb_reg(p_dm, 0x800, BIT(24), 0); /* disable whole CCK block */
+		if (trx_idle_success) {
+			api->tx_queue_bitmap = odm_read_1byte(dm, R_0x522);
 
+			/*pause all TX queue*/
+			odm_set_mac_reg(dm, R_0x520, 0xff0000, 0xff);
 
-				p_api->rx_iqc_reg_1 = odm_get_bb_reg(p_dm, 0xc14, MASKDWORD);
-				p_api->rx_iqc_reg_2 = odm_get_bb_reg(p_dm, 0xc1c, MASKDWORD);
-				
-				odm_set_bb_reg(p_dm, 0xc14, MASKDWORD, 0x0); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
-				odm_set_bb_reg(p_dm, 0xc1c, MASKDWORD, 0x0);
+			if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+				/*@disable OFDM RX CCA*/
+				odm_set_bb_reg(dm, R_0x1c68, BIT(24), 1);
+			} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				/*@disable OFDM RX CCA*/
+				odm_set_bb_reg(dm, R_0x838, BIT(1), 1);
+			} else {
+				api->rxiqc_reg1 = odm_read_4byte(dm, R_0xc14);
+				api->rxiqc_reg2 = odm_read_4byte(dm, R_0xc1c);
+				/* @[ Set IQK Matrix = 0 ]
+				 * equivalent to [ Turn off CCA]
+				 */
+				odm_set_bb_reg(dm, R_0xc14, MASKDWORD, 0x0);
+				odm_set_bb_reg(dm, R_0xc1c, MASKDWORD, 0x0);
 			}
-				
+			phydm_dis_cck_trx(dm, PHYDM_SET);
 		} else {
 			return PHYDM_SET_FAIL;
 		}
-		
+
 		return PHYDM_SET_SUCCESS;
-		
-	} else {  /*if (set_type == PHYDM_REVERT)*/
 
-		odm_set_bb_reg(p_dm, 0x520, 0xff0000, (u32)(p_api->tx_queue_bitmap)); /*Release all TX queue*/
+	} else { /*@if (set_type == PHYDM_REVERT)*/
+		/*Release all TX queue*/
+		odm_write_1byte(dm, R_0x522, api->tx_queue_bitmap);
 
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-			odm_set_bb_reg(p_dm, 0x808, BIT(28), 1); /*enable CCK block*/
-			odm_set_bb_reg(p_dm, 0x838, BIT(1), 0); /*enable OFDM RX CCA*/
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			/*@enable OFDM RX CCA*/
+			odm_set_bb_reg(dm, R_0x1c68, BIT(24), 0);
+		} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			/*@enable OFDM RX CCA*/
+			odm_set_bb_reg(dm, R_0x838, BIT(1), 0);
 		} else {
-			/*TBD*/
-			odm_set_bb_reg(p_dm, 0x800, BIT(24), 1); /* enable whole CCK block */
-			
-			odm_set_bb_reg(p_dm, 0xc14, MASKDWORD, p_api->rx_iqc_reg_1); /* [ Set IQK Matrix = 0 ] equivalent to [ Turn off CCA] */
-			odm_set_bb_reg(p_dm, 0xc1c, MASKDWORD, p_api->rx_iqc_reg_2);
+			/* @[Set IQK Matrix = 0] equivalent to [ Turn off CCA]*/
+			odm_write_4byte(dm, R_0xc14, api->rxiqc_reg1);
+			odm_write_4byte(dm, R_0xc1c, api->rxiqc_reg2);
 		}
-
+		phydm_dis_cck_trx(dm, PHYDM_REVERT);
 		return PHYDM_SET_SUCCESS;
 	}
-	
 }
 
-void
-phydm_set_ext_switch(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void phydm_dis_cck_trx(void *dm_void, u8 set_type)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			ext_ant_switch =  dm_value[0];
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_api_stuc *api = &dm->api_table;
 
-#if (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1)
-	if (p_dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
-
-		/*Output Pin Settings*/
-		odm_set_mac_reg(p_dm, 0x4C, BIT(23), 0); /*select DPDT_P and DPDT_N as output pin*/
-		odm_set_mac_reg(p_dm, 0x4C, BIT(24), 1); /*by WLAN control*/
-
-		odm_set_bb_reg(p_dm, 0xCB4, 0xFF, 77); /*DPDT_N = 1b'0*/  /*DPDT_P = 1b'0*/
-
-		if (ext_ant_switch == MAIN_ANT) {
-			odm_set_bb_reg(p_dm, 0xCB4, (BIT(29) | BIT(28)), 1);
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("***8821A set ant switch = 2b'01 (Main)\n"));
-		} else if (ext_ant_switch == AUX_ANT) {
-			odm_set_bb_reg(p_dm, 0xCB4, BIT(29) | BIT(28), 2);
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("***8821A set ant switch = 2b'10 (Aux)\n"));
+	if (set_type == PHYDM_SET) {
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			api->ccktx_path = (u8)odm_get_bb_reg(dm, R_0x1a04,
+							     0xf0000000);
+			/* @CCK RxIQ weighting = [0,0] */
+			odm_set_bb_reg(dm, R_0x1a14, 0x300, 0x3);
+			/* @disable CCK Tx */
+			odm_set_bb_reg(dm, R_0x1a04, 0xf0000000, 0x0);
+		} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			api->ccktx_path = (u8)odm_get_bb_reg(dm, R_0xa04,
+							     0xf0000000);
+			/* @disable CCK block */
+			odm_set_bb_reg(dm, R_0x808, BIT(28), 0);
+			/* @disable CCK Tx */
+			odm_set_bb_reg(dm, R_0xa04, 0xf0000000, 0x0);
+		} else {
+			api->ccktx_path = (u8)odm_get_bb_reg(dm, R_0xa04,
+							     0xf0000000);
+			/* @disable whole CCK block */
+			odm_set_bb_reg(dm, R_0x800, BIT(24), 0);
+			/* @disable CCK Tx */
+			odm_set_bb_reg(dm, R_0xa04, 0xf0000000, 0x0);
+		}
+	} else if (set_type == PHYDM_REVERT) {
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			/* @CCK RxIQ weighting = [1,1] */
+			odm_set_bb_reg(dm, R_0x1a14, 0x300, 0x0);
+			/* @enable CCK Tx */
+			odm_set_bb_reg(dm, R_0x1a04, 0xf0000000,
+				       api->ccktx_path);
+		} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			/* @enable CCK block */
+			odm_set_bb_reg(dm, R_0x808, BIT(28), 1);
+			/* @enable CCK Tx */
+			odm_set_bb_reg(dm, R_0xa04, 0xf0000000,
+				       api->ccktx_path);
+		} else {
+			/* @enable whole CCK block */
+			odm_set_bb_reg(dm, R_0x800, BIT(24), 1);
+			/* @enable CCK Tx */
+			odm_set_bb_reg(dm, R_0xa04, 0xf0000000,
+				       api->ccktx_path);
 		}
 	}
-#endif
 }
-
-void
-phydm_csi_mask_enable(
-	void		*p_dm_void,
-	u32		enable
-)
+void phydm_set_ext_switch(void *dm_void, u32 ext_ant_switch)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		reg_value = 0;
+#if (RTL8821A_SUPPORT || RTL8881A_SUPPORT)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)))
+		return;
 
-	reg_value = (enable == FUNC_ENABLE) ? 1 : 0;
+	/*Output Pin Settings*/
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	/*select DPDT_P and DPDT_N as output pin*/
+	odm_set_mac_reg(dm, R_0x4c, BIT(23), 0);
 
-		odm_set_bb_reg(p_dm, 0xD2C, BIT(28), reg_value);
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("Enable CSI Mask:  Reg 0xD2C[28] = ((0x%x))\n", reg_value));
+	/*@by WLAN control*/
+	odm_set_mac_reg(dm, R_0x4c, BIT(24), 1);
 
-	} else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	/*@DPDT_N = 1b'0*/ /*@DPDT_P = 1b'0*/
+	odm_set_bb_reg(dm, R_0xcb4, 0xFF, 77);
 
-		odm_set_bb_reg(p_dm, 0x874, BIT(0), reg_value);
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("Enable CSI Mask:  Reg 0x874[0] = ((0x%x))\n", reg_value));
+	if (ext_ant_switch == 1) { /*@2b'01*/
+		odm_set_bb_reg(dm, R_0xcb4, (BIT(29) | BIT(28)), 1);
+		PHYDM_DBG(dm, ODM_COMP_API, "8821A ant swh=2b'01\n");
+	} else if (ext_ant_switch == 2) { /*@2b'10*/
+		odm_set_bb_reg(dm, R_0xcb4, BIT(29) | BIT(28), 2);
+		PHYDM_DBG(dm, ODM_COMP_API, "*8821A ant swh=2b'10\n");
 	}
-
+#endif
 }
 
-void
-phydm_clean_all_csi_mask(
-	void		*p_dm_void
-)
+void phydm_csi_mask_enable(void *dm_void, u32 enable)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-
-		odm_set_bb_reg(p_dm, 0xD40, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0xD44, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0xD48, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0xD4c, MASKDWORD, 0);
-
-	} else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean en = false;
+
+	en = (enable == FUNC_ENABLE) ? true : false;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0xd2c, BIT(28), en);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Enable CSI Mask:  Reg 0xD2C[28] = ((0x%x))\n", en);
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		odm_set_bb_reg(dm, R_0xc0c, BIT(3), en);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Enable CSI Mask:  Reg 0xc0c[3] = ((0x%x))\n", en);
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x874, BIT(0), en);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Enable CSI Mask:  Reg 0x874[0] = ((0x%x))\n", en);
+	}
+}
 
-		odm_set_bb_reg(p_dm, 0x880, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0x884, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0x888, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0x88c, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0x890, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0x894, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0x898, MASKDWORD, 0);
-		odm_set_bb_reg(p_dm, 0x89c, MASKDWORD, 0);
+void phydm_clean_all_csi_mask(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0xd40, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0xd44, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0xd48, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0xd4c, MASKDWORD, 0);
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		u8 i = 0, idx_lmt = 0;
+
+		if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8812F))
+			idx_lmt = 127;
+		else /*@for IC supporting 80 + 80*/
+			idx_lmt = 255;
+
+		odm_set_bb_reg(dm, R_0x1ee8, 0x3, 0x3);
+		odm_set_bb_reg(dm, R_0x1d94, BIT(31) | BIT(30), 0x1);
+		for (i = 0; i < idx_lmt; i++) {
+			odm_set_bb_reg(dm, R_0x1d94, MASKBYTE2, i);
+			odm_set_bb_reg(dm, R_0x1d94, MASKBYTE0, 0x0);
+		}
+		odm_set_bb_reg(dm, R_0x1ee8, 0x3, 0x0);
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x880, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0x884, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0x888, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0x88c, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0x890, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0x894, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0x898, MASKDWORD, 0);
+		odm_set_bb_reg(dm, R_0x89c, MASKDWORD, 0);
 	}
 }
 
-void
-phydm_set_csi_mask_reg(
-	void		*p_dm_void,
-	u32		tone_idx_tmp,
-	u8		tone_direction
-)
+void phydm_set_csi_mask(void *dm_void, u32 tone_idx_tmp, u8 tone_direction)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		byte_offset, bit_offset;
-	u32		target_reg;
-	u8		reg_tmp_value;
-	u32		tone_num = 64;
-	u32		tone_num_shift = 0;
-	u32		csi_mask_reg_p = 0, csi_mask_reg_n = 0;
-
-	/* calculate real tone idx*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 byte_offset = 0, bit_offset = 0;
+	u32 target_reg = 0;
+	u8 reg_tmp_value = 0;
+	u32 tone_num = 64;
+	u32 tone_num_shift = 0;
+	u32 csi_mask_reg_p = 0, csi_mask_reg_n = 0;
+
+	/* @calculate real tone idx*/
 	if ((tone_idx_tmp % 10) >= 5)
 		tone_idx_tmp += 10;
 
 	tone_idx_tmp = (tone_idx_tmp / 10);
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
 		tone_num = 64;
 		csi_mask_reg_p = 0xD40;
 		csi_mask_reg_n = 0xD48;
 
-	} else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
 		tone_num = 128;
 		csi_mask_reg_p = 0x880;
 		csi_mask_reg_n = 0x890;
 	}
 
 	if (tone_direction == FREQ_POSITIVE) {
-
 		if (tone_idx_tmp >= (tone_num - 1))
 			tone_idx_tmp = (tone_num - 1);
 
@@ -509,184 +1006,180 @@ phydm_set_csi_mask_reg(
 		target_reg = csi_mask_reg_n + byte_offset;
 	}
 
-	reg_tmp_value = odm_read_1byte(p_dm, target_reg);
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("Pre Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n", (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value));
+	reg_tmp_value = odm_read_1byte(dm, target_reg);
+	PHYDM_DBG(dm, ODM_COMP_API,
+		  "Pre Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n",
+		  (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value);
 	reg_tmp_value |= BIT(bit_offset);
-	odm_write_1byte(p_dm, target_reg, reg_tmp_value);
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("New Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n", (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value));
+	odm_write_1byte(dm, target_reg, reg_tmp_value);
+	PHYDM_DBG(dm, ODM_COMP_API,
+		  "New Mask tone idx[%d]:  Reg0x%x = ((0x%x))\n",
+		  (tone_idx_tmp + tone_num_shift), target_reg, reg_tmp_value);
 }
 
-void
-phydm_set_nbi_reg(
-	void		*p_dm_void,
-	u32		tone_idx_tmp,
-	u32		bw
-)
+void phydm_set_nbi_reg(void *dm_void, u32 tone_idx_tmp, u32 bw)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	nbi_table_128[NBI_TABLE_SIZE_128] = {25, 55, 85, 115, 135, 155, 185, 205, 225, 245,		/*1~10*/		/*tone_idx X 10*/
-		     265, 285, 305, 335, 355, 375, 395, 415, 435, 455,	/*11~20*/
-					     485, 505, 525, 555, 585, 615, 635
-						};				/*21~27*/
-
-	u32	nbi_table_256[NBI_TABLE_SIZE_256] = { 25,   55,   85, 115, 135, 155, 175, 195, 225, 245,	/*1~10*/
-		265, 285, 305, 325, 345, 365, 385, 405, 425, 445,	/*11~20*/
-		465, 485, 505, 525, 545, 565, 585, 605, 625, 645,	/*21~30*/
-		665, 695, 715, 735, 755, 775, 795, 815, 835, 855,	/*31~40*/
-		875, 895, 915, 935, 955, 975, 995, 1015, 1035, 1055,	/*41~50*/
-		      1085, 1105, 1125, 1145, 1175, 1195, 1225, 1255, 1275
-						};	/*51~59*/
-
-	u32	reg_idx = 0;
-	u32	i;
-	u8	nbi_table_idx = FFT_128_TYPE;
-
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	/*tone_idx X 10*/
+	u32 nbi_128[NBI_128TONE] = {25, 55, 85, 115, 135,
+				    155, 185, 205, 225, 245,
+				    265, 285, 305, 335, 355,
+				    375, 395, 415, 435, 455,
+				    485, 505, 525, 555, 585, 615, 635};
+	/*tone_idx X 10*/
+	u32 nbi_256[NBI_256TONE] = {25, 55, 85, 115, 135,
+				    155, 175, 195, 225, 245,
+				    265, 285, 305, 325, 345,
+				    365, 385, 405, 425, 445,
+				    465, 485, 505, 525, 545,
+				    565, 585, 605, 625, 645,
+				    665, 695, 715, 735, 755,
+				    775, 795, 815, 835, 855,
+				    875, 895, 915, 935, 955,
+				    975, 995, 1015, 1035, 1055,
+				    1085, 1105, 1125, 1145, 1175,
+				    1195, 1225, 1255, 1275};
+	u32 reg_idx = 0;
+	u32 i;
+	u8 nbi_table_idx = FFT_128_TYPE;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
 		nbi_table_idx = FFT_128_TYPE;
-	else if (p_dm->support_ic_type & ODM_IC_11AC_1_SERIES)
-
+	} else if (dm->support_ic_type & ODM_IC_11AC_1_SERIES) {
 		nbi_table_idx = FFT_256_TYPE;
-	else if (p_dm->support_ic_type & ODM_IC_11AC_2_SERIES) {
-
+	} else if (dm->support_ic_type & ODM_IC_11AC_2_SERIES) {
 		if (bw == 80)
 			nbi_table_idx = FFT_256_TYPE;
-		else /*20M, 40M*/
+		else /*@20M, 40M*/
 			nbi_table_idx = FFT_128_TYPE;
 	}
 
 	if (nbi_table_idx == FFT_128_TYPE) {
-
-		for (i = 0; i < NBI_TABLE_SIZE_128; i++) {
-			if (tone_idx_tmp < nbi_table_128[i]) {
+		for (i = 0; i < NBI_128TONE; i++) {
+			if (tone_idx_tmp < nbi_128[i]) {
 				reg_idx = i + 1;
 				break;
 			}
 		}
 
 	} else if (nbi_table_idx == FFT_256_TYPE) {
-
-		for (i = 0; i < NBI_TABLE_SIZE_256; i++) {
-			if (tone_idx_tmp < nbi_table_256[i]) {
+		for (i = 0; i < NBI_256TONE; i++) {
+			if (tone_idx_tmp < nbi_256[i]) {
 				reg_idx = i + 1;
 				break;
 			}
 		}
 	}
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		odm_set_bb_reg(p_dm, 0xc40, 0x1f000000, reg_idx);
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("Set tone idx:  Reg0xC40[28:24] = ((0x%x))\n", reg_idx));
-		/**/
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		odm_set_bb_reg(dm, R_0xc40, 0x1f000000, reg_idx);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Set tone idx:  Reg0xC40[28:24] = ((0x%x))\n",
+			  reg_idx);
 	} else {
-		odm_set_bb_reg(p_dm, 0x87c, 0xfc000, reg_idx);
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("Set tone idx: Reg0x87C[19:14] = ((0x%x))\n", reg_idx));
-		/**/
+		odm_set_bb_reg(dm, R_0x87c, 0xfc000, reg_idx);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Set tone idx: Reg0x87C[19:14] = ((0x%x))\n",
+			  reg_idx);
 	}
 }
 
-
-void
-phydm_nbi_enable(
-	void		*p_dm_void,
-	u32		enable
-)
+void phydm_nbi_enable(void *dm_void, u32 enable)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		reg_value = 0;
-
-	reg_value = (enable == FUNC_ENABLE) ? 1 : 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 val = 0;
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	val = (enable == FUNC_ENABLE) ? 1 : 0;
 
-		odm_set_bb_reg(p_dm, 0xc40, BIT(9), reg_value);
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("Enable NBI Reg0xC40[9] = ((0x%x))\n", reg_value));
+	PHYDM_DBG(dm, ODM_COMP_API, "Enable NBI=%d\n", val);
 
-	} else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-
-		if (p_dm->support_ic_type & (ODM_RTL8822B|ODM_RTL8821C)) {
-			odm_set_bb_reg(p_dm, 0x87c, BIT(13), reg_value);
-			odm_set_bb_reg(p_dm, 0xc20, BIT(28), reg_value);
-			if (p_dm->rf_type > RF_1T1R)
-				odm_set_bb_reg(p_dm, 0xe20, BIT(28), reg_value);
-		} else
-			odm_set_bb_reg(p_dm, 0x87c, BIT(13), reg_value);
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("Enable NBI Reg0x87C[13] = ((0x%x))\n", reg_value));
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (dm->support_ic_type & (ODM_RTL8192F | ODM_RTL8197F)) {
+			val = (enable == FUNC_ENABLE) ? 0xf : 0;
+			odm_set_bb_reg(dm, R_0xc50, 0xf000000, val);
+		} else {
+			odm_set_bb_reg(dm, R_0xc40, BIT(9), val);
+		}
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+			odm_set_bb_reg(dm, R_0x87c, BIT(13), val);
+			odm_set_bb_reg(dm, R_0xc20, BIT(28), val);
+			if (dm->rf_type > RF_1T1R)
+				odm_set_bb_reg(dm, R_0xe20, BIT(28), val);
+		} else {
+			odm_set_bb_reg(dm, R_0x87c, BIT(13), val);
+		}
 	}
 }
 
-u8
-phydm_calculate_fc(
-	void		*p_dm_void,
-	u32		channel,
-	u32		bw,
-	u32		second_ch,
-	u32		*fc_in
-)
+u8 phydm_find_fc(void *dm_void, u32 channel, u32 bw, u32 second_ch, u32 *fc_in)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		fc = *fc_in;
-	u32		start_ch_per_40m[NUM_START_CH_40M] = {36, 44, 52, 60, 100, 108, 116, 124, 132, 140, 149, 157, 165, 173};
-	u32		start_ch_per_80m[NUM_START_CH_80M] = {36, 52, 100, 116, 132, 149, 165};
-	u32		*p_start_ch = &(start_ch_per_40m[0]);
-	u32		num_start_channel = NUM_START_CH_40M;
-	u32		channel_offset = 0;
-	u32		i;
-
-	/*2.4G*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 fc = *fc_in;
+	u32 start_ch_per_40m[NUM_START_CH_40M] = {36, 44, 52, 60, 100,
+						  108, 116, 124, 132, 140,
+						  149, 157, 165, 173};
+	u32 start_ch_per_80m[NUM_START_CH_80M] = {36, 52, 100, 116, 132,
+						  149, 165};
+	u32 *start_ch = &start_ch_per_40m[0];
+	u32 num_start_channel = NUM_START_CH_40M;
+	u32 channel_offset = 0;
+	u32 i;
+
+	/*@2.4G*/
 	if (channel <= 14 && channel > 0) {
-
 		if (bw == 80)
-			return	PHYDM_SET_FAIL;
+			return PHYDM_SET_FAIL;
 
 		fc = 2412 + (channel - 1) * 5;
 
-		if (bw == 40 && (second_ch == PHYDM_ABOVE)) {
-
+		if (bw == 40 && second_ch == PHYDM_ABOVE) {
 			if (channel >= 10) {
-				PHYDM_DBG(p_dm, ODM_COMP_API, ("CH = ((%d)), Scnd_CH = ((%d)) Error setting\n", channel, second_ch));
-				return	PHYDM_SET_FAIL;
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "CH = ((%d)), Scnd_CH = ((%d)) Error setting\n",
+					  channel, second_ch);
+				return PHYDM_SET_FAIL;
 			}
 			fc += 10;
 		} else if (bw == 40 && (second_ch == PHYDM_BELOW)) {
-
 			if (channel <= 2) {
-				PHYDM_DBG(p_dm, ODM_COMP_API, ("CH = ((%d)), Scnd_CH = ((%d)) Error setting\n", channel, second_ch));
-				return	PHYDM_SET_FAIL;
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "CH = ((%d)), Scnd_CH = ((%d)) Error setting\n",
+					  channel, second_ch);
+				return PHYDM_SET_FAIL;
 			}
 			fc -= 10;
 		}
 	}
-	/*5G*/
+	/*@5G*/
 	else if (channel >= 36 && channel <= 177) {
-
 		if (bw != 20) {
-
 			if (bw == 40) {
 				num_start_channel = NUM_START_CH_40M;
-				p_start_ch = &(start_ch_per_40m[0]);
+				start_ch = &start_ch_per_40m[0];
 				channel_offset = CH_OFFSET_40M;
 			} else if (bw == 80) {
 				num_start_channel = NUM_START_CH_80M;
-				p_start_ch = &(start_ch_per_80m[0]);
+				start_ch = &start_ch_per_80m[0];
 				channel_offset = CH_OFFSET_80M;
 			}
 
 			for (i = 0; i < (num_start_channel - 1); i++) {
-
-				if (channel < p_start_ch[i + 1]) {
-					channel = p_start_ch[i] + channel_offset;
+				if (channel < start_ch[i + 1]) {
+					channel = start_ch[i] + channel_offset;
 					break;
 				}
 			}
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("Mod_CH = ((%d))\n", channel));
+			PHYDM_DBG(dm, ODM_COMP_API, "Mod_CH = ((%d))\n",
+				  channel);
 		}
 
 		fc = 5180 + (channel - 36) * 5;
 
 	} else {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("CH = ((%d)) Error setting\n", channel));
-		return	PHYDM_SET_FAIL;
+		PHYDM_DBG(dm, ODM_COMP_API, "CH = ((%d)) Error setting\n",
+			  channel);
+		return PHYDM_SET_FAIL;
 	}
 
 	*fc_in = fc;
@@ -694,492 +1187,1764 @@ phydm_calculate_fc(
 	return PHYDM_SET_SUCCESS;
 }
 
-
-u8
-phydm_calculate_intf_distance(
-	void		*p_dm_void,
-	u32		bw,
-	u32		fc,
-	u32		f_interference,
-	u32		*p_tone_idx_tmp_in
-)
+u8 phydm_find_intf_distance(void *dm_void, u32 bw, u32 fc, u32 f_interference,
+			    u32 *tone_idx_tmp_in)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		bw_up, bw_low;
-	u32		int_distance;
-	u32		tone_idx_tmp;
-	u8		set_result = PHYDM_SET_NO_NEED;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 bw_up = 0, bw_low = 0;
+	u32 int_distance = 0;
+	u32 tone_idx_tmp = 0;
+	u8 set_result = PHYDM_SET_NO_NEED;
 
 	bw_up = fc + bw / 2;
 	bw_low = fc - bw / 2;
 
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("[f_l, fc, fh] = [ %d, %d, %d ], f_int = ((%d))\n", bw_low, fc, bw_up, f_interference));
-
-	if ((f_interference >= bw_low) && (f_interference <= bw_up)) {
-
-		int_distance = (fc >= f_interference) ? (fc - f_interference) : (f_interference - fc);
-		tone_idx_tmp = (int_distance << 5); /* =10*(int_distance /0.3125) */
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("int_distance = ((%d MHz)) Mhz, tone_idx_tmp = ((%d.%d))\n", int_distance, (tone_idx_tmp / 10), (tone_idx_tmp % 10)));
-		*p_tone_idx_tmp_in = tone_idx_tmp;
+	PHYDM_DBG(dm, ODM_COMP_API,
+		  "[f_l, fc, fh] = [ %d, %d, %d ], f_int = ((%d))\n", bw_low,
+		  fc, bw_up, f_interference);
+
+	if (f_interference >= bw_low && f_interference <= bw_up) {
+		int_distance = DIFF_2(fc, f_interference);
+		/*@10*(int_distance /0.3125)*/
+		tone_idx_tmp = (int_distance << 5);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "int_distance = ((%d MHz)) Mhz, tone_idx_tmp = ((%d.%d))\n",
+			  int_distance, tone_idx_tmp / 10,
+			  tone_idx_tmp % 10);
+		*tone_idx_tmp_in = tone_idx_tmp;
 		set_result = PHYDM_SET_SUCCESS;
 	}
 
-	return	set_result;
-
+	return set_result;
 }
 
-
-u8
-phydm_csi_mask_setting(
-	void		*p_dm_void,
-	u32		enable,
-	u32		channel,
-	u32		bw,
-	u32		f_interference,
-	u32		second_ch
-)
+u8 phydm_csi_mask_setting(void *dm_void, u32 enable, u32 ch, u32 bw,
+			  u32 f_intf, u32 sec_ch)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		fc = 2412;
-	u8		tone_direction;
-	u32		tone_idx_tmp;
-	u8		set_result = PHYDM_SET_SUCCESS;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 fc = 2412;
+	u8 direction = FREQ_POSITIVE;
+	u32 tone_idx = 0;
+	u8 set_result = PHYDM_SET_SUCCESS;
+	u8 rpt = 0;
 
 	if (enable == FUNC_DISABLE) {
 		set_result = PHYDM_SET_SUCCESS;
-		phydm_clean_all_csi_mask(p_dm);
+		phydm_clean_all_csi_mask(dm);
 
 	} else {
-
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[Set CSI MASK_] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
-			channel, bw, f_interference, (((bw == 20) || (channel > 14)) ? "Don't care" : (second_ch == PHYDM_ABOVE) ? "H" : "L")));
-
-		/*calculate fc*/
-		if (phydm_calculate_fc(p_dm, channel, bw, second_ch, &fc) == PHYDM_SET_FAIL)
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "[Set CSI MASK_] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			  ch, bw, f_intf,
+			  (((bw == 20) || (ch > 14)) ? "Don't care" :
+			  (sec_ch == PHYDM_ABOVE) ? "H" : "L"));
+
+		/*@calculate fc*/
+		if (phydm_find_fc(dm, ch, bw, sec_ch, &fc) == PHYDM_SET_FAIL) {
 			set_result = PHYDM_SET_FAIL;
-
-		else {
-			/*calculate interference distance*/
-			if (phydm_calculate_intf_distance(p_dm, bw, fc, f_interference, &tone_idx_tmp) == PHYDM_SET_SUCCESS) {
-
-				tone_direction = (f_interference >= fc) ? FREQ_POSITIVE : FREQ_NEGATIVE;
-				phydm_set_csi_mask_reg(p_dm, tone_idx_tmp, tone_direction);
+		} else {
+			/*@calculate interference distance*/
+			rpt = phydm_find_intf_distance(dm, bw, fc, f_intf,
+						       &tone_idx);
+			if (rpt == PHYDM_SET_SUCCESS) {
+				if (f_intf >= fc)
+					direction = FREQ_POSITIVE;
+				else
+					direction = FREQ_NEGATIVE;
+
+				phydm_set_csi_mask(dm, tone_idx, direction);
 				set_result = PHYDM_SET_SUCCESS;
-			} else
+			} else {
 				set_result = PHYDM_SET_NO_NEED;
+			}
 		}
 	}
 
 	if (set_result == PHYDM_SET_SUCCESS)
-		phydm_csi_mask_enable(p_dm, enable);
+		phydm_csi_mask_enable(dm, enable);
 	else
-		phydm_csi_mask_enable(p_dm, FUNC_DISABLE);
+		phydm_csi_mask_enable(dm, FUNC_DISABLE);
 
-	return	set_result;
+	return set_result;
 }
 
-u8
-phydm_nbi_setting(
-	void		*p_dm_void,
-	u32		enable,
-	u32		channel,
-	u32		bw,
-	u32		f_interference,
-	u32		second_ch
-)
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+u8 phydm_find_intf_distance_jgr3(void *dm_void, u32 bw, u32 fc,
+				 u32 f_interference, u32 *tone_idx_tmp_in)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 bw_up = 0, bw_low = 0;
+	u32 int_distance = 0;
+	u32 tone_idx_tmp = 0;
+	u8 set_result = PHYDM_SET_NO_NEED;
+
+	bw_up = 1000 * (fc + bw / 2);
+	bw_low = 1000 * (fc - bw / 2);
+	fc = 1000 * fc;
+
+	PHYDM_DBG(dm, ODM_COMP_API,
+		  "[f_l, fc, fh] = [ %d, %d, %d ], f_int = ((%d))\n", bw_low,
+		  fc, bw_up, f_interference);
+
+	if (f_interference >= bw_low && f_interference <= bw_up) {
+		int_distance = DIFF_2(fc, f_interference);
+		/*@10*(int_distance /0.3125)*/
+		tone_idx_tmp = (int_distance / 312);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "int_distance = ((%d)) , tone_idx_tmp = ((%d))\n",
+			  int_distance, tone_idx_tmp);
+		*tone_idx_tmp_in = tone_idx_tmp;
+		set_result = PHYDM_SET_SUCCESS;
+	}
+
+	return set_result;
+}
+u8 phydm_csi_mask_setting_jgr3(void *dm_void, u32 enable, u32 ch, u32 bw,
+			       u32 f_intf, u32 sec_ch, u8 wgt)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		fc = 2412;
-	u32		tone_idx_tmp;
-	u8		set_result = PHYDM_SET_SUCCESS;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 fc = 2412;
+	u8 direction = FREQ_POSITIVE;
+	u32 tone_idx = 0;
+	u8 set_result = PHYDM_SET_SUCCESS;
+	u8 rpt = 0;
 
-	if (enable == FUNC_DISABLE)
+	if (enable == FUNC_DISABLE) {
+		phydm_csi_mask_enable(dm, FUNC_ENABLE);
+		phydm_clean_all_csi_mask(dm);
+		phydm_csi_mask_enable(dm, FUNC_DISABLE);
 		set_result = PHYDM_SET_SUCCESS;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "[Set CSI MASK] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s)), wgt = ((%d))\n",
+			  ch, bw, f_intf,
+			  (((bw == 20) || (ch > 14)) ? "Don't care" :
+			  (sec_ch == PHYDM_ABOVE) ? "H" : "L"), wgt);
+
+		/*@calculate fc*/
+		if (phydm_find_fc(dm, ch, bw, sec_ch, &fc) == PHYDM_SET_FAIL) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			/*@calculate interference distance*/
+			rpt = phydm_find_intf_distance_jgr3(dm, bw, fc, f_intf,
+							    &tone_idx);
+			if (rpt == PHYDM_SET_SUCCESS) {
+				if (f_intf >= 1000 * fc)
+					direction = FREQ_POSITIVE;
+				else
+					direction = FREQ_NEGATIVE;
+
+				phydm_csi_mask_enable(dm, FUNC_ENABLE);
+				phydm_set_csi_mask_jgr3(dm, tone_idx, direction,
+							wgt);
+				set_result = PHYDM_SET_SUCCESS;
+			} else {
+				set_result = PHYDM_SET_NO_NEED;
+			}
+		}
+		if (!(set_result == PHYDM_SET_SUCCESS))
+			phydm_csi_mask_enable(dm, FUNC_DISABLE);
+	}
 
-	else {
+	return set_result;
+}
 
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[Set NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
-			channel, bw, f_interference, (((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "Don't care" : (second_ch == PHYDM_ABOVE) ? "H" : "L")));
+void phydm_set_csi_mask_jgr3(void *dm_void, u32 tone_idx_tmp, u8 tone_direction,
+			     u8 wgt)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 reg_tmp_value = 0;
+	u32 tone_num = 64;
+	u32 table_addr = 0;
+	u32 addr = 0;
+	u8 rf_bw = 0;
+	u8 value = 0;
+
+	rf_bw = odm_read_1byte(dm, R_0x9b0);
+	if (((rf_bw & 0xc) >> 2) == 0x2)
+		tone_num = 128; /* @RF80 : tone(-1) at tone_idx=255 */
+	else
+		tone_num = 64; /* @RF20/40 : tone(-1) at tone_idx=127 */
 
-		/*calculate fc*/
-		if (phydm_calculate_fc(p_dm, channel, bw, second_ch, &fc) == PHYDM_SET_FAIL)
-			set_result = PHYDM_SET_FAIL;
+	if (tone_direction == FREQ_POSITIVE) {
+		if (tone_idx_tmp >= (tone_num - 1))
+			tone_idx_tmp = (tone_num - 1);
+	} else {
+		if (tone_idx_tmp >= tone_num)
+			tone_idx_tmp = tone_num;
+
+		tone_idx_tmp = (tone_num << 1) - tone_idx_tmp;
+	}
+	table_addr = tone_idx_tmp >> 1;
+
+	reg_tmp_value = odm_read_4byte(dm, R_0x1d94);
+	PHYDM_DBG(dm, ODM_COMP_API,
+		  "Pre Mask tone idx[%d]: Reg0x1d94 = ((0x%x))\n",
+		  tone_idx_tmp, reg_tmp_value);
+	odm_set_bb_reg(dm, R_0x1ee8, 0x3, 0x3);
+	odm_set_bb_reg(dm, R_0x1d94, BIT(31) | BIT(30), 0x1);
+	odm_set_bb_reg(dm, R_0x1d94, MASKBYTE2, (table_addr & 0xff));
+	if (tone_idx_tmp % 2)
+		value = (BIT(3) | (wgt & 0x7)) << 4;
+	else
+		value = BIT(3) | (wgt & 0x7);
+
+	odm_set_bb_reg(dm, R_0x1d94, 0xff, value);
+	reg_tmp_value = odm_read_4byte(dm, R_0x1d94);
+	PHYDM_DBG(dm, ODM_COMP_API,
+		  "New Mask tone idx[%d]: Reg0x1d94 = ((0x%x))\n",
+		  tone_idx_tmp, reg_tmp_value);
+	odm_set_bb_reg(dm, R_0x1ee8, 0x3, 0x0);
+}
 
-		else {
-			/*calculate interference distance*/
-			if (phydm_calculate_intf_distance(p_dm, bw, fc, f_interference, &tone_idx_tmp) == PHYDM_SET_SUCCESS) {
+u8 phydm_nbi_setting_jgr3(void *dm_void, u32 enable, u32 ch, u32 bw, u32 f_intf,
+			  u32 sec_ch, u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 fc = 2412;
+	u8 direction = FREQ_POSITIVE;
+	u32 tone_idx = 0;
+	u8 set_result = PHYDM_SET_SUCCESS;
+	u8 rpt = 0;
 
-				phydm_set_nbi_reg(p_dm, tone_idx_tmp, bw);
+	if (enable == FUNC_DISABLE) {
+		set_result = PHYDM_SET_SUCCESS;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "[Set NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			  ch, bw, f_intf,
+			  (((sec_ch == PHYDM_DONT_CARE) || (bw == 20) ||
+			  (ch > 14)) ? "Don't care" :
+			  (sec_ch == PHYDM_ABOVE) ? "H" : "L"));
+
+		/*@calculate fc*/
+		if (phydm_find_fc(dm, ch, bw, sec_ch, &fc) == PHYDM_SET_FAIL) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			/*@calculate interference distance*/
+			rpt = phydm_find_intf_distance(dm, bw, fc, f_intf,
+						       &tone_idx);
+			if (rpt == PHYDM_SET_SUCCESS) {
+				if (f_intf >= fc)
+					direction = FREQ_POSITIVE;
+				else
+					direction = FREQ_NEGATIVE;
+
+				phydm_set_nbi_reg_jgr3(dm, tone_idx, direction,
+						       path);
 				set_result = PHYDM_SET_SUCCESS;
-			} else
+			} else {
 				set_result = PHYDM_SET_NO_NEED;
 		}
 	}
+	}
 
 	if (set_result == PHYDM_SET_SUCCESS)
-		phydm_nbi_enable(p_dm, enable);
+		phydm_nbi_enable_jgr3(dm, enable, path);
 	else
-		phydm_nbi_enable(p_dm, FUNC_DISABLE);
+		phydm_nbi_enable_jgr3(dm, FUNC_DISABLE, path);
 
-	return	set_result;
+	return set_result;
 }
 
-void
-phydm_api_debug(
-	void		*p_dm_void,
-	u32		function_map,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void phydm_set_nbi_reg_jgr3(void *dm_void, u32 tone_idx_tmp, u8 tone_direction,
+			    u8 path)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-	u32			channel =  dm_value[1];
-	u32			bw =  dm_value[2];
-	u32			f_interference =  dm_value[3];
-	u32			second_ch =  dm_value[4];
-	u8			set_result = 0;
-
-	/*PHYDM_API_NBI*/
-	/*-------------------------------------------------------------------------------------------------------------------------------*/
-	if (function_map == PHYDM_API_NBI) {
-
-		if (dm_value[0] == 100) {
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "[HELP-NBI]  EN(on=1, off=2)   CH   BW(20/40/80)  f_intf(Mhz)    Scnd_CH(L=1, H=2)\n"));
-			return;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 reg_tmp_value = 0;
+	u32 tone_num = 64;
+	u32 tone_num_shift = 0;
+	u32 addr = 0;
+	u8 rf_bw = 0;
+
+	/* @calculate real tone idx*/
+	if ((tone_idx_tmp % 10) >= 5)
+		tone_idx_tmp += 10;
+
+	tone_idx_tmp = (tone_idx_tmp / 10);
+
+	rf_bw = odm_read_1byte(dm, R_0x9b0);
+	if (((rf_bw & 0xc) >> 2) == 0x2)
+		tone_num = 128; /* RF80 : tone-1 at tone_idx=255 */
+	else
+		tone_num = 64; /* RF20/40 : tone-1 at tone_idx=127 */
+
+	if (tone_direction == FREQ_POSITIVE) {
+		if (tone_idx_tmp >= (tone_num - 1))
+			tone_idx_tmp = (tone_num - 1);
+	} else {
+		tone_num_shift = tone_num;
+		if (tone_idx_tmp >= tone_num)
+			tone_idx_tmp = tone_num;
+
+		tone_idx_tmp = (tone_num << 1) - tone_idx_tmp;
+	}
 
-		} else if (dm_value[0] == FUNC_ENABLE) {
+	switch (path) {
+	case RF_PATH_A:
+		odm_set_bb_reg(dm, R_0x1944, 0x001FF000, tone_idx_tmp);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Set tone idx[%d]:PATH-A = ((0x%x))\n",
+			  (tone_idx_tmp + tone_num_shift), tone_idx_tmp);
+		break;
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	case RF_PATH_B:
+		odm_set_bb_reg(dm, R_0x4044, 0x001FF000, tone_idx_tmp);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Set tone idx[%d]:PATH-B = ((0x%x))\n",
+			  (tone_idx_tmp + tone_num_shift), tone_idx_tmp);
+		break;
+	#endif
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	case RF_PATH_C:
+		odm_set_bb_reg(dm, R_0x5044, 0x001FF000, tone_idx_tmp);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Set tone idx[%d]:PATH-C = ((0x%x))\n",
+			  (tone_idx_tmp + tone_num_shift), tone_idx_tmp);
+		break;
+	#endif
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	case RF_PATH_D:
+		odm_set_bb_reg(dm, R_0x5144, 0x001FF000, tone_idx_tmp);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "Set tone idx[%d]:PATH-D = ((0x%x))\n",
+			  (tone_idx_tmp + tone_num_shift), tone_idx_tmp);
+		break;
+	#endif
+	default:
+		break;
+	}
+}
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Enable NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
-				channel, bw, f_interference, ((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "Don't care" : ((second_ch == PHYDM_ABOVE) ? "H" : "L")));
-			set_result = phydm_nbi_setting(p_dm, FUNC_ENABLE, channel, bw, f_interference, second_ch);
+void phydm_nbi_enable_jgr3(void *dm_void, u32 enable, u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean val = false;
 
-		} else if (dm_value[0] == FUNC_DISABLE) {
+	val = (enable == FUNC_ENABLE) ? true : false;
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Disable NBI]\n"));
-			set_result = phydm_nbi_setting(p_dm, FUNC_DISABLE, channel, bw, f_interference, second_ch);
+	PHYDM_DBG(dm, ODM_COMP_API, "Enable NBI=%d\n", val);
 
-		} else
+	odm_set_bb_reg(dm, R_0x818, BIT(11), val);
+	if (enable == FUNC_ENABLE) {
+		switch (path) {
+		case RF_PATH_A:
+			odm_set_bb_reg(dm, R_0x1940, BIT(31), val);
+			break;
+		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		case RF_PATH_B:
+			odm_set_bb_reg(dm, R_0x4040, BIT(31), val);
+			break;
+		#endif
+		#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+		case RF_PATH_C:
+			odm_set_bb_reg(dm, R_0x5040, BIT(31), val);
+			break;
+		#endif
+		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		case RF_PATH_D:
+			odm_set_bb_reg(dm, R_0x5140, BIT(31), val);
+			break;
+		#endif
+		default:
+			break;
+		}
+	} else {
+		odm_set_bb_reg(dm, R_0x1940, BIT(31), val);
+		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		odm_set_bb_reg(dm, R_0x4040, BIT(31), val);
+		#endif
+		#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+		odm_set_bb_reg(dm, R_0x5040, BIT(31), val);
+		#endif
+		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		odm_set_bb_reg(dm, R_0x5140, BIT(31), val);
+		#endif
+	}
+}
+
+u8 phydm_phystat_rpt_jgr3(void *dm_void, enum phystat_rpt info,
+			  enum rf_path ant_path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	s8 evm_org, cfo_org, rxsnr_org;
+	u8 i, return_info = 0, tmp_lsb = 0, tmp_msb = 0, tmp_info = 0;
+
+	/* Update the status for each pkt */
+	odm_set_bb_reg(dm, R_0x8c4, 0xfff000, 0x448);
+	odm_set_bb_reg(dm, R_0x8c0, MASKLWORD, 0x4001);
+	/* PHY status Page1 */
+	odm_set_bb_reg(dm, R_0x8c0, 0x3C00000, 0x1);
+	/*choose debug port for phystatus */
+	odm_set_bb_reg(dm, R_0x1c3c, 0xFFF00, 0x380);
+
+	if (info == PHY_PWDB) {
+		/* Choose the report of the diff path */
+		if (ant_path == RF_PATH_A)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x1);
+		else if (ant_path == RF_PATH_B)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x2);
+		else if (ant_path == RF_PATH_C)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x3);
+		else if (ant_path == RF_PATH_D)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x4);
+	} else if (info == PHY_EVM) {
+		/* Choose the report of the diff path */
+		if (ant_path == RF_PATH_A)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x10);
+		else if (ant_path == RF_PATH_B)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x11);
+		else if (ant_path == RF_PATH_C)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x12);
+		else if (ant_path == RF_PATH_D)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x13);
+		return_info = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0xff);
+	} else if (info == PHY_CFO) {
+		/* Choose the report of the diff path */
+		if (ant_path == RF_PATH_A)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x14);
+		else if (ant_path == RF_PATH_B)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x15);
+		else if (ant_path == RF_PATH_C)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x16);
+		else if (ant_path == RF_PATH_D)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x17);
+		return_info = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0xff);
+	} else if (info == PHY_RXSNR) {
+		/* Choose the report of the diff path */
+		if (ant_path == RF_PATH_A)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x18);
+		else if (ant_path == RF_PATH_B)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x19);
+		else if (ant_path == RF_PATH_C)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x1a);
+		else if (ant_path == RF_PATH_D)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x1b);
+		return_info = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0xff);
+	} else if (info == PHY_LGAIN) {
+		/* choose page */
+		odm_set_bb_reg(dm, R_0x8c0, 0x3c00000, 0x2);
+		/* Choose the report of the diff path */
+		if (ant_path == RF_PATH_A) {
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0xd);
+			tmp_info = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0x3f);
+			return_info = tmp_info;
+		} else if (ant_path == RF_PATH_B) {
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0xd);
+			tmp_lsb = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0xc0);
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0xe);
+			tmp_msb = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0xf);
+			tmp_info |= (tmp_msb << 2) | tmp_lsb;
+			return_info = tmp_info;
+		} else if (ant_path == RF_PATH_C) {
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0xe);
+			tmp_lsb = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0xf0);
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0xf);
+			tmp_msb = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0x3);
+			tmp_info |= (tmp_msb << 4) | tmp_lsb;
+			return_info = tmp_info;
+		} else if (ant_path == RF_PATH_D) {
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x10);
+			tmp_info = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0x3f);
+			return_info = tmp_info;
+		}
+	} else if (info == PHY_HT_AAGC_GAIN) {
+		/* choose page */
+		odm_set_bb_reg(dm, R_0x8c0, 0x3c00000, 0x2);
+		/* Choose the report of the diff path */
+		if (ant_path == RF_PATH_A)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x12);
+		else if (ant_path == RF_PATH_B)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x13);
+		else if (ant_path == RF_PATH_C)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x14);
+		else if (ant_path == RF_PATH_D)
+			odm_set_bb_reg(dm, R_0x8c4, 0x3ff, 0x15);
+		return_info = (u8)odm_get_bb_reg(dm, R_0x2dbc, 0xff);
+	}
+	return return_info;
+}
+
+void phydm_ex_hal8814b_wifi_only_hw_config(void *dm_void)
+{
+	/*BB control*/
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0x4c, 0x01800000, 0x2);*/
+	/*SW control*/
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcb4, 0xff, 0x77);*/
+	/*antenna mux switch */
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0x974, 0x300, 0x3);*/
+
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1990, 0x300, 0x0);*/
+
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0xcbc, 0x80000, 0x0);*/
+	/*switch to WL side controller and gnt_wl gnt_bt debug signal */
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0x70, 0xff000000, 0x0e);*/
+	/*gnt_wl=1 , gnt_bt=0*/
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1704, 0xffffffff,
+	 *			     0x7700);
+	 */
+	/*halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1700, 0xffffffff,
+	 *			     0xc00f0038);
+	 */
+}
+
+void phydm_user_position_for_sniffer(void *dm_void, u8 user_position)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	/* user position valid */
+	odm_set_bb_reg(dm, R_0xa68, BIT(17), 1);
+	/* Select user seat from pmac */
+	odm_set_bb_reg(dm, R_0xa68, BIT(16), 1);
+	/*user seat*/
+	odm_set_bb_reg(dm, R_0xa68, (BIT(19) | BIT(18)), user_position);
+}
 
+void phydm_txagc_power_limit(void *dm_void, boolean is_bf, u8 ss, u8 pwr)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 tx_bw = 0;
+
+	if (!(dm->support_ic_type & ODM_IC_JGR3_SERIES)) {
+		PHYDM_DBG(dm, ODM_COMP_API, "Not JGR3!\n");
+		return;
+	}
+
+	tx_bw = (u8)odm_get_bb_reg(dm, R_0x9b0, 0x3);
+
+	if (is_bf) {
+		switch (tx_bw) {
+		case 1:
+			if (ss == 1) {
+				odm_set_bb_reg(dm, R_0x18f8, 0x007F0000, pwr);
+				odm_set_bb_reg(dm, R_0x41f8, 0x007F0000, pwr);
+			} else if (ss == 2) {
+				odm_set_bb_reg(dm, R_0x18f8, 0x7F000000, pwr);
+				odm_set_bb_reg(dm, R_0x41f8, 0x7F000000, pwr);
+			}
+			break;
+		case 2:
+			if (ss == 1) {
+				odm_set_bb_reg(dm, R_0x18fc, 0x007F0000, pwr);
+				odm_set_bb_reg(dm, R_0x41fc, 0x007F0000, pwr);
+			} else if (ss == 2) {
+				odm_set_bb_reg(dm, R_0x18fc, 0x7F000000, pwr);
+				odm_set_bb_reg(dm, R_0x41fc, 0x7F000000, pwr);
+			}
+			break;
+		case 3:
+			if (ss == 1) {
+				odm_set_bb_reg(dm, R_0x1864, 0x7F000000, pwr);
+				odm_set_bb_reg(dm, R_0x4164, 0x7F000000, pwr);
+			} else if (ss == 2) {
+				odm_set_bb_reg(dm, R_0x18f0, 0x7F000000, pwr);
+				odm_set_bb_reg(dm, R_0x41f0, 0x7F000000, pwr);
+			}
+			break;
+		default:
+			break;
+		}
+	} else {
+		switch (tx_bw) {
+		case 1:
+			if (ss == 1) {
+				odm_set_bb_reg(dm, R_0x18f8, 0x0000007F, pwr);
+				odm_set_bb_reg(dm, R_0x41f8, 0x0000007F, pwr);
+			} else if (ss == 2) {
+				odm_set_bb_reg(dm, R_0x18f8, 0x00007F00, pwr);
+				odm_set_bb_reg(dm, R_0x41f8, 0x00007F00, pwr);
+			}
+			break;
+		case 2:
+			if (ss == 1) {
+				odm_set_bb_reg(dm, R_0x18fc, 0x0000007F, pwr);
+				odm_set_bb_reg(dm, R_0x41fc, 0x0000007F, pwr);
+			} else if (ss == 2) {
+				odm_set_bb_reg(dm, R_0x18fc, 0x00007F00, pwr);
+				odm_set_bb_reg(dm, R_0x41fc, 0x00007F00, pwr);
+			}
+			break;
+		case 3:
+			if (ss == 1) {
+				odm_set_bb_reg(dm, R_0x180c, 0x07F00000, pwr);
+				odm_set_bb_reg(dm, R_0x410c, 0x07F00000, pwr);
+			} else if (ss == 2) {
+				odm_set_bb_reg(dm, R_0x1860, 0x000007F0, pwr);
+				odm_set_bb_reg(dm, R_0x4160, 0x000007F0, pwr);
+			}
+			break;
+		default:
+			break;
+		}
+	}
+}
+#endif
+u8 phydm_nbi_setting(void *dm_void, u32 enable, u32 ch, u32 bw, u32 f_intf,
+		     u32 sec_ch)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 fc = 2412;
+	u8 direction = FREQ_POSITIVE;
+	u32 tone_idx = 0;
+	u8 set_result = PHYDM_SET_SUCCESS;
+	u8 rpt = 0;
+
+	if (enable == FUNC_DISABLE) {
+		set_result = PHYDM_SET_SUCCESS;
+	} else {
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "[Set NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			  ch, bw, f_intf,
+			  (((sec_ch == PHYDM_DONT_CARE) || (bw == 20) ||
+			  (ch > 14)) ? "Don't care" :
+			  (sec_ch == PHYDM_ABOVE) ? "H" : "L"));
+
+		/*@calculate fc*/
+		if (phydm_find_fc(dm, ch, bw, sec_ch, &fc) == PHYDM_SET_FAIL) {
 			set_result = PHYDM_SET_FAIL;
-		PHYDM_SNPRINTF((output + used, out_len - used, "[NBI set result: %s]\n", (set_result == PHYDM_SET_SUCCESS) ? "Success" : ((set_result == PHYDM_SET_NO_NEED) ? "No need" : "Error")));
+		} else {
+			/*@calculate interference distance*/
+			rpt = phydm_find_intf_distance(dm, bw, fc, f_intf,
+						       &tone_idx);
+			if (rpt == PHYDM_SET_SUCCESS) {
+				if (f_intf >= fc)
+					direction = FREQ_POSITIVE;
+				else
+					direction = FREQ_NEGATIVE;
+
+				phydm_set_nbi_reg(dm, tone_idx, bw);
 
+				set_result = PHYDM_SET_SUCCESS;
+			} else {
+				set_result = PHYDM_SET_NO_NEED;
+		}
+	}
 	}
 
-	/*PHYDM_CSI_MASK*/
-	/*-------------------------------------------------------------------------------------------------------------------------------*/
-	else if (function_map == PHYDM_API_CSI_MASK) {
+	if (set_result == PHYDM_SET_SUCCESS)
+		phydm_nbi_enable(dm, enable);
+	else
+		phydm_nbi_enable(dm, FUNC_DISABLE);
 
-		if (dm_value[0] == 100) {
+	return set_result;
+}
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "[HELP-CSI MASK]  EN(on=1, off=2)   CH   BW(20/40/80)  f_intf(Mhz)    Scnd_CH(L=1, H=2)\n"));
-			return;
+void phydm_nbi_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+		     u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 val[10] = {0};
+	char help[] = "-h";
+	u8 i = 0, input_idx = 0, idx_lmt = 0;
+	u32 enable = 0; /*@function enable*/
+	u32 ch = 0;
+	u32 bw = 0;
+	u32 f_int = 0; /*@interference frequency*/
+	u32 sec_ch = 0; /*secondary channel*/
+	u8 rpt = 0;
+	u8 path = 0;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		idx_lmt = 6;
+	else
+		idx_lmt = 5;
+	for (i = 0; i < idx_lmt; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &val[i]);
+			input_idx++;
+		}
+	}
+
+	if (input_idx == 0)
+		return;
+
+	enable = val[0];
+	ch = val[1];
+	bw = val[2];
+	f_int = val[3];
+	sec_ch = val[4];
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	path = (u8)val[5];
+	#endif
+
+	if ((strcmp(input[1], help) == 0)) {
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "{en:1 Dis:2} {ch} {BW:20/40/80} {f_intf(Mhz)} {Scnd_CH(L=1, H=2)} {Path:A~D(0~3)}\n");
+		else
+		#endif
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "{en:1 Dis:2} {ch} {BW:20/40/80} {f_intf(Mhz)} {Scnd_CH(L=1, H=2)}\n");
+		*_used = used;
+		*_out_len = out_len;
+		return;
+	} else if (val[0] == FUNC_ENABLE) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Enable NBI] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			 ch, bw, f_int,
+			 ((sec_ch == PHYDM_DONT_CARE) ||
+			 (bw == 20) || (ch > 14)) ? "Don't care" :
+			 ((sec_ch == PHYDM_ABOVE) ? "H" : "L"));
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			rpt = phydm_nbi_setting_jgr3(dm, enable, ch, bw, f_int,
+						     sec_ch, path);
+		else
+		#endif
+			rpt = phydm_nbi_setting(dm, enable, ch, bw, f_int,
+						sec_ch);
+	} else if (val[0] == FUNC_DISABLE) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Disable NBI]\n");
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			rpt = phydm_nbi_setting_jgr3(dm, enable, ch, bw, f_int,
+						     sec_ch, path);
+		else
+		#endif
+			rpt = phydm_nbi_setting(dm, enable, ch, bw, f_int,
+						sec_ch);
+	} else {
+		rpt = PHYDM_SET_FAIL;
+	}
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "[NBI set result: %s]\n",
+		 (rpt == PHYDM_SET_SUCCESS) ? "Success" :
+		 ((rpt == PHYDM_SET_NO_NEED) ? "No need" : "Error"));
 
-		} else if (dm_value[0] == FUNC_ENABLE) {
+	*_used = used;
+	*_out_len = out_len;
+}
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Enable CSI MASK] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
-				channel, bw, f_interference, (channel > 14) ? "Don't care" : (((second_ch == PHYDM_DONT_CARE) || (bw == 20) || (channel > 14)) ? "H" : "L")));
-			set_result = phydm_csi_mask_setting(p_dm,	FUNC_ENABLE, channel, bw, f_interference, second_ch);
+void phydm_csi_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+		     u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 val[10] = {0};
+	char help[] = "-h";
+	u8 i = 0, input_idx = 0, idx_lmt = 0;
+	u32 enable = 0;  /*@function enable*/
+	u32 ch = 0;
+	u32 bw = 0;
+	u32 f_int = 0; /*@interference frequency*/
+	u32 sec_ch = 0;  /*secondary channel*/
+	u8 rpt = 0;
+	u8 wgt = 0;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		idx_lmt = 6;
+	else
+		idx_lmt = 5;
 
-		} else if (dm_value[0] == FUNC_DISABLE) {
+	for (i = 0; i < idx_lmt; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &val[i]);
+			input_idx++;
+		}
+	}
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Disable CSI MASK]\n"));
-			set_result = phydm_csi_mask_setting(p_dm, FUNC_DISABLE, channel, bw, f_interference, second_ch);
+	if (input_idx == 0)
+		return;
 
-		} else
+	enable = val[0];
+	ch = val[1];
+	bw = val[2];
+	f_int = val[3];
+	sec_ch = val[4];
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	wgt = (u8)val[5];
+	#endif
+
+	if ((strcmp(input[1], help) == 0)) {
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "{en:1 Dis:2} {ch} {BW:20/40/80} {f_intf(KHz)} {Scnd_CH(L=1, H=2)}\n{wgt:(7:3/4),(6~1: 1/2 ~ 1/64),(0:0)}\n");
+		else
+		#endif
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "{en:1 Dis:2} {ch} {BW:20/40/80} {f_intf(Mhz)} {Scnd_CH(L=1, H=2)}\n");
 
-			set_result = PHYDM_SET_FAIL;
-		PHYDM_SNPRINTF((output + used, out_len - used, "[CSI MASK set result: %s]\n", (set_result == PHYDM_SET_SUCCESS) ? "Success" : ((set_result == PHYDM_SET_NO_NEED) ? "No need" : "Error")));
+		*_used = used;
+		*_out_len = out_len;
+		return;
+
+	} else if (val[0] == FUNC_ENABLE) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Enable CSI MASK] CH = ((%d)), BW = ((%d)), f_intf = ((%d)), Scnd_CH = ((%s))\n",
+			 ch, bw, f_int,
+			 (ch > 14) ? "Don't care" :
+			 (((sec_ch == PHYDM_DONT_CARE) ||
+			 (bw == 20) || (ch > 14)) ? "H" : "L"));
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			rpt = phydm_csi_mask_setting_jgr3(dm, enable, ch, bw,
+							  f_int, sec_ch, wgt);
+		else
+		#endif
+			rpt = phydm_csi_mask_setting(dm, enable, ch, bw, f_int,
+						     sec_ch);
+	} else if (val[0] == FUNC_DISABLE) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Disable CSI MASK]\n");
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			rpt = phydm_csi_mask_setting_jgr3(dm, enable, ch, bw,
+							  f_int, sec_ch, wgt);
+		else
+		#endif
+			rpt = phydm_csi_mask_setting(dm, enable, ch, bw, f_int,
+						     sec_ch);
+	} else {
+		rpt = PHYDM_SET_FAIL;
 	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "[CSI MASK set result: %s]\n",
+		 (rpt == PHYDM_SET_SUCCESS) ? "Success" :
+		 ((rpt == PHYDM_SET_NO_NEED) ? "No need" : "Error"));
+
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_stop_ck320(
-	void			*p_dm_void,
-	u8			enable
-) {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		reg_value = (enable == true) ? 1 : 0;
-	
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		odm_set_bb_reg(p_dm, 0x8b4, BIT(6), reg_value);
-		/**/
-	} else { 
-
-		if (p_dm->support_ic_type & ODM_IC_N_2SS) {	/*N-2SS*/
-			odm_set_bb_reg(p_dm, 0x87c, BIT(29), reg_value);
-			/**/
-		} else {	/*N-1SS*/
-			odm_set_bb_reg(p_dm, 0x87c, BIT(31), reg_value);
-			/**/
+void phydm_stop_ck320(void *dm_void, u8 enable)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 val = enable ? 1 : 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x8b4, BIT(6), val);
+	} else {
+		if (dm->support_ic_type & ODM_IC_N_2SS) /*N-2SS*/
+			odm_set_bb_reg(dm, R_0x87c, BIT(29), val);
+		else /*N-1SS*/
+			odm_set_bb_reg(dm, R_0x87c, BIT(31), val);
+	}
+}
+
+boolean
+phydm_set_bb_txagc_offset(void *dm_void, s8 power_offset, /*@(unit: dB)*/
+			  u8 add_half_db /*@(+0.5 dB)*/)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	s8 power_idx = power_offset * 2;
+	boolean set_success = false;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "power_offset=%d, add_half_db =%d\n",
+		  power_offset, add_half_db);
+
+	#if ODM_IC_11AC_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (power_offset > -16 && power_offset < 15) {
+			if (add_half_db)
+				power_idx += 1;
+
+			power_idx &= 0x3f;
+
+			PHYDM_DBG(dm, ODM_COMP_API, "Reg_idx =0x%x\n",
+				  power_idx);
+			odm_set_bb_reg(dm, R_0x8b4, 0x3f, power_idx);
+			set_success = true;
+		} else {
+			pr_debug("[Warning] TX AGC Offset Setting error!");
+		}
+	}
+	#endif
+
+	#if ODM_IC_11N_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (power_offset > -8 || power_offset < 7) {
+			if (add_half_db)
+				power_idx += 1;
+
+			power_idx &= 0x1f;
+
+			PHYDM_DBG(dm, ODM_COMP_API, "Reg_idx =0x%x\n",
+				  power_idx);
+			/*r_txagc_offset_a*/
+			odm_set_bb_reg(dm, R_0x80c, 0x1f00, power_idx);
+			/*r_txagc_offset_b*/
+			odm_set_bb_reg(dm, R_0x80c, 0x3e000, power_idx);
+			set_success = true;
+		} else {
+			pr_debug("[Warning] TX AGC Offset Setting error!");
 		}
 	}
+	#endif
+
+	return set_success;
 }
 
 #ifdef PHYDM_COMMON_API_SUPPORT
 boolean
-phydm_api_set_txagc(
-	void				*p_dm_void,
-	u32				power_index,
-	enum rf_path		path,
-	u8				hw_rate,
-	boolean			is_single_rate
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean		ret = false;
-	u8	i;
+phydm_api_shift_txagc(void *dm_void, u32 pwr_offset, enum rf_path path,
+		      boolean is_positive) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret = false;
+	u32 txagc_cck = 0;
+	u32 txagc_ofdm = 0;
+	u32 r_txagc_ofdm[4] = {0x18e8, 0x41e8, 0x52e8, 0x53e8};
+	u32 r_txagc_cck[4] = {0x18a0, 0x41a0, 0x52a0, 0x53a0};
+
+	#if (RTL8822C_SUPPORT || RTL8812F_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8812F)) {
+		if (path > RF_PATH_B) {
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "Unsupported path (%d)\n",
+				  path);
+			return false;
+		}
+		txagc_cck = (u8)odm_get_bb_reg(dm, r_txagc_cck[path],
+						   0x7F0000);
+		txagc_ofdm = (u8)odm_get_bb_reg(dm, r_txagc_ofdm[path],
+						    0x1FC00);
+		if (is_positive) {
+			if (((txagc_cck + pwr_offset) > 127) ||
+			    ((txagc_ofdm + pwr_offset) > 127))
+				return false;
+
+			txagc_cck += pwr_offset;
+			txagc_ofdm += pwr_offset;
+		} else {
+			if (pwr_offset > txagc_cck || pwr_offset > txagc_ofdm)
+				return false;
 
-#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
-	if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+			txagc_cck -= pwr_offset;
+			txagc_ofdm -= pwr_offset;
+		}
+		#if (RTL8822C_SUPPORT)
+		ret = config_phydm_write_txagc_ref_8822c(dm, (u8)txagc_cck,
+							 path, PDM_CCK);
+		ret &= config_phydm_write_txagc_ref_8822c(dm, (u8)txagc_ofdm,
+							 path, PDM_OFDM);
+		#endif
+		#if (RTL8812F_SUPPORT)
+		ret = config_phydm_write_txagc_ref_8812f(dm, (u8)txagc_cck,
+							 path, PDM_CCK);
+		ret &= config_phydm_write_txagc_ref_8812f(dm, (u8)txagc_ofdm,
+							 path, PDM_OFDM);
+		#endif
+		PHYDM_DBG(dm, ODM_PHY_CONFIG,
+			  "%s: path-%d txagc_cck_ref=%x txagc_ofdm_ref=0x%x\n",
+			  __func__, path, txagc_cck, txagc_ofdm);
+	}
+	#endif
+
+	#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B)) {
+		if (path > RF_PATH_D) {
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "Unsupported path (%d)\n",
+				  path);
+			return false;
+		}
+		txagc_cck = (u8)odm_get_bb_reg(dm, r_txagc_cck[path],
+						   0x7F0000);
+		txagc_ofdm = (u8)odm_get_bb_reg(dm, r_txagc_ofdm[path],
+						    0x1FC00);
+		if (is_positive) {
+			if (((txagc_cck + pwr_offset) > 127) ||
+			    ((txagc_ofdm + pwr_offset) > 127))
+				return false;
+
+			txagc_cck += pwr_offset;
+			txagc_ofdm += pwr_offset;
+		} else {
+			if (pwr_offset > txagc_cck || pwr_offset > txagc_ofdm)
+				return false;
+
+			txagc_cck -= pwr_offset;
+			txagc_ofdm -= pwr_offset;
+		}
+		#if (RTL8198F_SUPPORT)
+		ret = config_phydm_write_txagc_ref_8198f(dm, (u8)txagc_cck,
+							 path, PDM_CCK);
+		ret &= config_phydm_write_txagc_ref_8198f(dm, (u8)txagc_ofdm,
+							 path, PDM_OFDM);
+		#endif
+		#if (RTL8814B_SUPPORT)
+		ret = config_phydm_write_txagc_ref_8814b(dm, (u8)txagc_cck,
+							 path, PDM_CCK);
+		ret &= config_phydm_write_txagc_ref_8814b(dm, (u8)txagc_ofdm,
+							 path, PDM_OFDM);
+		#endif
+		PHYDM_DBG(dm, ODM_PHY_CONFIG,
+			  "%s: path-%d txagc_cck_ref=%x txagc_ofdm_ref=0x%x\n",
+			  __func__, path, txagc_cck, txagc_ofdm);
+	}
+	#endif
+
+	return ret;
+}
+
+boolean
+phydm_api_set_txagc(void *dm_void, u32 pwr_idx, enum rf_path path,
+		    u8 rate, boolean is_single_rate)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret = false;
+	#if (RTL8198F_SUPPORT || RTL8822C_SUPPORT || RTL8812F_SUPPORT ||\
+	     RTL8814B_SUPPORT)
+	u8 base = 0;
+	u8 txagc_tmp = 0;
+	s8 pw_by_rate_tmp = 0;
+	s8 pw_by_rate_new = 0;
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	u8 i = 0;
+	#endif
+
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT || RTL8195B_SUPPORT)
+	if (dm->support_ic_type &
+	    (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8195B)) {
 		if (is_single_rate) {
-			
-			#if (RTL8822B_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8822B)
-				ret = phydm_write_txagc_1byte_8822b(p_dm, power_index, path, hw_rate);
+			#if (RTL8822B_SUPPORT)
+			if (dm->support_ic_type == ODM_RTL8822B)
+				ret = phydm_write_txagc_1byte_8822b(dm, pwr_idx,
+								    path, rate);
 			#endif
-			
-			#if (RTL8821C_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8821C)
-				ret = phydm_write_txagc_1byte_8821c(p_dm, power_index, path, hw_rate);
+
+			#if (RTL8821C_SUPPORT)
+			if (dm->support_ic_type == ODM_RTL8821C)
+				ret = phydm_write_txagc_1byte_8821c(dm, pwr_idx,
+								    path, rate);
 			#endif
-			
+
+			#if (RTL8195B_SUPPORT)
+			if (dm->support_ic_type == ODM_RTL8195B)
+				ret = phydm_write_txagc_1byte_8195b(dm, pwr_idx,
+								    path, rate);
+			#endif
+
 			#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-			set_current_tx_agc(p_dm->priv, path, hw_rate, (u8)power_index);
+			set_current_tx_agc(dm->priv, path, rate, (u8)pwr_idx);
 			#endif
 
 		} else {
+			#if (RTL8822B_SUPPORT)
+			if (dm->support_ic_type == ODM_RTL8822B)
+				ret = config_phydm_write_txagc_8822b(dm,
+								     pwr_idx,
+								     path,
+								     rate);
+			#endif
 
-			#if (RTL8822B_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8822B)
-				ret = config_phydm_write_txagc_8822b(p_dm, power_index, path, hw_rate);
+			#if (RTL8821C_SUPPORT)
+			if (dm->support_ic_type == ODM_RTL8821C)
+				ret = config_phydm_write_txagc_8821c(dm,
+								     pwr_idx,
+								     path,
+								     rate);
 			#endif
-			
-			#if (RTL8821C_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8821C)
-				ret = config_phydm_write_txagc_8821c(p_dm, power_index, path, hw_rate);
+
+			#if (RTL8195B_SUPPORT)
+			if (dm->support_ic_type == ODM_RTL8195B)
+				ret = config_phydm_write_txagc_8195b(dm,
+								     pwr_idx,
+								     path,
+								     rate);
 			#endif
-			
+
 			#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
 			for (i = 0; i < 4; i++)
-				set_current_tx_agc(p_dm->priv, path, (hw_rate + i), (u8)power_index);
+				set_current_tx_agc(dm->priv, path, (rate + i),
+						   (u8)pwr_idx);
 			#endif
 		}
 	}
 #endif
 
+#if (RTL8198F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8198F) {
+		if (rate < 0x4)
+			txagc_tmp = config_phydm_read_txagc_8198f(dm, path,
+								  rate,
+								  PDM_CCK);
+		else
+			txagc_tmp = config_phydm_read_txagc_8198f(dm, path,
+								  rate,
+								  PDM_OFDM);
+
+		pw_by_rate_tmp = config_phydm_read_txagc_diff_8198f(dm, rate);
+		base = txagc_tmp -  pw_by_rate_tmp;
+		base = base & 0x7f;
+		if (DIFF_2((pwr_idx & 0x7f), base) > 64 || pwr_idx > 127)
+			return false;
+
+		pw_by_rate_new = (s8)(pwr_idx - base);
+		ret = phydm_write_txagc_1byte_8198f(dm, pw_by_rate_new, rate);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG,
+			  "%s: path-%d rate_idx=%x base=0x%x new_diff=0x%x\n",
+			  __func__, path, rate, base, pw_by_rate_new);
+	}
+#endif
+
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822C) {
+		if (rate < 0x4)
+			txagc_tmp = config_phydm_read_txagc_8822c(dm, path,
+								  rate,
+								  PDM_CCK);
+		else
+			txagc_tmp = config_phydm_read_txagc_8822c(dm, path,
+								  rate,
+								  PDM_OFDM);
+
+		pw_by_rate_tmp = config_phydm_read_txagc_diff_8822c(dm, rate);
+		base = txagc_tmp - pw_by_rate_tmp;
+		base = base & 0x7f;
+		if (DIFF_2((pwr_idx & 0x7f), base) > 63 || pwr_idx > 127)
+			return false;
+
+		pw_by_rate_new = (s8)(pwr_idx - base);
+		ret = phydm_write_txagc_1byte_8822c(dm, pw_by_rate_new, rate);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG,
+			  "%s: path-%d rate_idx=%x base=0x%x new_diff=0x%x\n",
+			  __func__, path, rate, base, pw_by_rate_new);
+	}
+#endif
 
-#if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		ret = config_phydm_write_txagc_8197f(p_dm, power_index, path, hw_rate);
+#if (RTL8814B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8814B) {
+		if (rate < 0x4)
+			txagc_tmp = config_phydm_read_txagc_8814b(dm, path,
+								  rate,
+								  PDM_CCK);
+		else
+			txagc_tmp = config_phydm_read_txagc_8814b(dm, path,
+								  rate,
+								  PDM_OFDM);
+
+		pw_by_rate_tmp = config_phydm_read_txagc_diff_8814b(dm, rate);
+		base = txagc_tmp -  pw_by_rate_tmp;
+		base = base & 0x7f;
+		if (DIFF_2((pwr_idx & 0x7f), base) > 64)
+			return false;
+
+		pw_by_rate_new = (s8)(pwr_idx - base);
+		ret = phydm_write_txagc_1byte_8814b(dm, pw_by_rate_new, rate);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG,
+			  "%s: path-%d rate_idx=%x base=0x%x new_diff=0x%x\n",
+			  __func__, path, rate, base, pw_by_rate_new);
+	}
 #endif
 
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8812F) {
+		if (rate < 0x4)
+			txagc_tmp = config_phydm_read_txagc_8812f(dm, path,
+								  rate,
+								  PDM_CCK);
+		else
+			txagc_tmp = config_phydm_read_txagc_8812f(dm, path,
+								  rate,
+								  PDM_OFDM);
+
+		pw_by_rate_tmp = config_phydm_read_txagc_diff_8812f(dm, rate);
+		base = txagc_tmp - pw_by_rate_tmp;
+		base = base & 0x7f;
+		if (DIFF_2((pwr_idx & 0x7f), base) > 63 || pwr_idx > 127)
+			return false;
+
+		pw_by_rate_new = (s8)(pwr_idx - base);
+		ret = phydm_write_txagc_1byte_8812f(dm, pw_by_rate_new, rate);
+		PHYDM_DBG(dm, ODM_PHY_CONFIG,
+			  "%s: path-%d rate_idx=%x base=0x%x new_diff=0x%x\n",
+			  __func__, path, rate, base, pw_by_rate_new);
+	}
+#endif
+
+#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_write_txagc_8197f(dm, pwr_idx, path, rate);
+#endif
+
+#if (RTL8192F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8192F)
+		ret = config_phydm_write_txagc_8192f(dm, pwr_idx, path, rate);
+#endif
+
+#if (RTL8721D_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8721D)
+		ret = config_phydm_write_txagc_8721d(dm, pwr_idx, path, rate);
+#endif
 	return ret;
 }
 
-u8
-phydm_api_get_txagc(
-	void				*p_dm_void,
-	enum rf_path		path,
-	u8				hw_rate
-)
+u8 phydm_api_get_txagc(void *dm_void, enum rf_path path, u8 hw_rate)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	ret = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 ret = 0;
 
-#if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		ret = config_phydm_read_txagc_8822b(p_dm, path, hw_rate);
+#if (RTL8822B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_read_txagc_8822b(dm, path, hw_rate);
 #endif
 
-#if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		ret = config_phydm_read_txagc_8197f(p_dm, path, hw_rate);
+#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_read_txagc_8197f(dm, path, hw_rate);
+#endif
+
+#if (RTL8821C_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8821C)
+		ret = config_phydm_read_txagc_8821c(dm, path, hw_rate);
+#endif
+
+#if (RTL8195B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8195B)
+		ret = config_phydm_read_txagc_8195b(dm, path, hw_rate);
+#endif
+
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8192F)
+		ret = config_phydm_read_txagc_8192f(dm, path, hw_rate);
+#endif
+
+#if (RTL8198F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8198F) {
+		if (hw_rate < 0x4) {
+			ret = config_phydm_read_txagc_8198f(dm, path, hw_rate,
+							    PDM_CCK);
+		} else {
+			ret = config_phydm_read_txagc_8198f(dm, path, hw_rate,
+							    PDM_OFDM);
+		}
+	}
+#endif
+
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822C) {
+		if (hw_rate < 0x4) {
+			ret = config_phydm_read_txagc_8822c(dm, path, hw_rate,
+							    PDM_CCK);
+		} else {
+			ret = config_phydm_read_txagc_8822c(dm, path, hw_rate,
+							    PDM_OFDM);
+		}
+	}
+#endif
+
+#if (RTL8814B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8814B) {
+		if (hw_rate < 0x4) {
+			ret = config_phydm_read_txagc_8814b(dm, path, hw_rate,
+							    PDM_CCK);
+		} else {
+			ret = config_phydm_read_txagc_8814b(dm, path, hw_rate,
+							    PDM_OFDM);
+		}
+	}
 #endif
 
-#if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8821C)
-		ret = config_phydm_read_txagc_8821c(p_dm, path, hw_rate);
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8812F) {
+		if (hw_rate < 0x4) {
+			ret = config_phydm_read_txagc_8812f(dm, path, hw_rate,
+							    PDM_CCK);
+		} else {
+			ret = config_phydm_read_txagc_8812f(dm, path, hw_rate,
+							    PDM_OFDM);
+		}
+	}
 #endif
 
+#if (RTL8721D_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8721D)
+		ret = config_phydm_read_txagc_8721d(dm, path, hw_rate);
+#endif
 	return ret;
 }
 
-
 boolean
-phydm_api_switch_bw_channel(
-	void					*p_dm_void,
-	u8					central_ch,
-	u8					primary_ch_idx,
-	enum channel_width	bandwidth
-)
+phydm_api_switch_bw_channel(void *dm_void, u8 ch, u8 pri_ch,
+			    enum channel_width bw)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;	
-	boolean		ret = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret = false;
+
+	switch (dm->support_ic_type) {
+#if (RTL8822B_SUPPORT)
+	case ODM_RTL8822B:
+		ret = config_phydm_switch_channel_bw_8822b(dm, ch, pri_ch, bw);
+	break;
+#endif
+
+#if (RTL8197F_SUPPORT)
+	case ODM_RTL8197F:
+		ret = config_phydm_switch_channel_bw_8197f(dm, ch, pri_ch, bw);
+	break;
+#endif
 
-#if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		ret = config_phydm_switch_channel_bw_8822b(p_dm, central_ch, primary_ch_idx, bandwidth);
+#if (RTL8821C_SUPPORT)
+	case ODM_RTL8821C:
+		ret = config_phydm_switch_channel_bw_8821c(dm, ch, pri_ch, bw);
+	break;
 #endif
 
-#if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		ret = config_phydm_switch_channel_bw_8197f(p_dm, central_ch, primary_ch_idx, bandwidth);
+#if (RTL8192F_SUPPORT)
+	case ODM_RTL8192F:
+		ret = config_phydm_switch_channel_bw_8192f(dm, ch, pri_ch, bw);
+	break;
 #endif
 
-#if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8821C)
-		ret = config_phydm_switch_channel_bw_8821c(p_dm, central_ch, primary_ch_idx, bandwidth);
+#if (RTL8198F_SUPPORT)
+	case ODM_RTL8198F:
+		ret = config_phydm_switch_channel_bw_8198f(dm, ch, pri_ch, bw);
+	break;
 #endif
 
+#if (RTL8822C_SUPPORT)
+	case ODM_RTL8822C:
+		ret = config_phydm_switch_channel_bw_8822c(dm, ch, pri_ch, bw);
+	break;
+#endif
+
+#if (RTL8814B_SUPPORT)
+	case ODM_RTL8814B:
+		ret = config_phydm_switch_channel_bw_8814b(dm, ch, pri_ch, bw);
+	break;
+#endif
+
+#if (RTL8812F_SUPPORT)
+	case ODM_RTL8812F:
+		ret = config_phydm_switch_channel_bw_8812f(dm, ch, pri_ch, bw);
+	break;
+#endif
+
+#if (RTL8721D_SUPPORT)
+	case ODM_RTL8721D:
+		ret = config_phydm_switch_channel_bw_8721d(dm, ch, pri_ch, bw);
+#endif
+
+	default:
+		break;
+	}
 	return ret;
 }
 
 boolean
-phydm_api_trx_mode(
-	void				*p_dm_void,
-	enum bb_path	tx_path,
-	enum bb_path	rx_path,
-	boolean			is_tx2_path
-)
+phydm_api_trx_mode(void *dm_void, enum bb_path tx_path, enum bb_path rx_path,
+		   boolean is_2tx)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean		ret = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret = false;
 
-#if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		ret = config_phydm_trx_mode_8822b(p_dm, tx_path, rx_path, is_tx2_path);
+#if (RTL8822B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret = config_phydm_trx_mode_8822b(dm, tx_path, rx_path, is_2tx);
 #endif
 
-#if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		ret = config_phydm_trx_mode_8197f(p_dm, tx_path, rx_path, is_tx2_path);
+#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		ret = config_phydm_trx_mode_8197f(dm, tx_path, rx_path, is_2tx);
+#endif
+
+#if (RTL8192F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8192F)
+		ret = config_phydm_trx_mode_8192f(dm, tx_path, rx_path, is_2tx);
+#endif
+
+#if (RTL8198F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8198F)
+		ret = config_phydm_trx_mode_8198f(dm, tx_path, rx_path, is_2tx);
+#endif
+
+/*#if (RTL8814B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8814B)
+		ret = config_phydm_trx_mode_8814b(dm, tx_path, rx_path, is_2tx);
+#endif
+*/
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822C)
+		ret = config_phydm_trx_mode_8822c(dm, tx_path, rx_path, is_2tx);
+#endif
+
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8812F)
+		ret = config_phydm_trx_mode_8812f(dm, tx_path, rx_path, is_2tx);
+#endif
+
+#if (RTL8721D_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8721D)
+		ret = config_phydm_trx_mode_8721d(dm, tx_path, rx_path, is_2tx);
 #endif
 
 	return ret;
 }
-#endif
+#else
+u8 config_phydm_read_txagc_n(void *dm_void, enum rf_path path, u8 hw_rate)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 read_back_data = INVALID_TXAGC_DATA;
+	u32 reg_txagc;
+	u32 reg_mask;
+	/* This function is for 92E/88E etc... */
+	/* @Input need to be HW rate index, not driver rate index!!!! */
+
+	/* @Error handling */
+	if (path > RF_PATH_B || hw_rate > ODM_RATEMCS15) {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: unsupported path (%d)\n",
+			  __func__, path);
+		return INVALID_TXAGC_DATA;
+	}
+
+	if (path == RF_PATH_A) {
+		switch (hw_rate) {
+		case ODM_RATE1M:
+			reg_txagc = R_0xe08;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATE2M:
+			reg_txagc = R_0x86c;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATE5_5M:
+			reg_txagc = R_0x86c;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATE11M:
+			reg_txagc = R_0x86c;
+			reg_mask = 0x7f000000;
+			break;
 
+		case ODM_RATE6M:
+			reg_txagc = R_0xe00;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATE9M:
+			reg_txagc = R_0xe00;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATE12M:
+			reg_txagc = R_0xe00;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATE18M:
+			reg_txagc = R_0xe00;
+			reg_mask = 0x7f000000;
+			break;
+		case ODM_RATE24M:
+			reg_txagc = R_0xe04;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATE36M:
+			reg_txagc = R_0xe04;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATE48M:
+			reg_txagc = R_0xe04;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATE54M:
+			reg_txagc = R_0xe04;
+			reg_mask = 0x7f000000;
+			break;
+
+		case ODM_RATEMCS0:
+			reg_txagc = R_0xe10;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS1:
+			reg_txagc = R_0xe10;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS2:
+			reg_txagc = R_0xe10;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS3:
+			reg_txagc = R_0xe10;
+			reg_mask = 0x7f000000;
+			break;
+		case ODM_RATEMCS4:
+			reg_txagc = R_0xe14;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS5:
+			reg_txagc = R_0xe14;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS6:
+			reg_txagc = R_0xe14;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS7:
+			reg_txagc = R_0xe14;
+			reg_mask = 0x7f000000;
+			break;
+
+		case ODM_RATEMCS8:
+			reg_txagc = R_0xe18;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS9:
+			reg_txagc = R_0xe18;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS10:
+			reg_txagc = R_0xe18;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS11:
+			reg_txagc = R_0xe18;
+			reg_mask = 0x7f000000;
+			break;
+		case ODM_RATEMCS12:
+			reg_txagc = R_0xe1c;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS13:
+			reg_txagc = R_0xe1c;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS14:
+			reg_txagc = R_0xe1c;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS15:
+			reg_txagc = R_0xe1c;
+			reg_mask = 0x7f000000;
+			break;
+
+		default:
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "Invalid HWrate!\n");
+			break;
+		}
+	} else if (path == RF_PATH_B) {
+		switch (hw_rate) {
+		case ODM_RATE1M:
+			reg_txagc = R_0x838;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATE2M:
+			reg_txagc = R_0x838;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATE5_5M:
+			reg_txagc = R_0x838;
+			reg_mask = 0x7f000000;
+			break;
+		case ODM_RATE11M:
+			reg_txagc = R_0x86c;
+			reg_mask = 0x0000007f;
+			break;
+
+		case ODM_RATE6M:
+			reg_txagc = R_0x830;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATE9M:
+			reg_txagc = R_0x830;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATE12M:
+			reg_txagc = R_0x830;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATE18M:
+			reg_txagc = R_0x830;
+			reg_mask = 0x7f000000;
+			break;
+		case ODM_RATE24M:
+			reg_txagc = R_0x834;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATE36M:
+			reg_txagc = R_0x834;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATE48M:
+			reg_txagc = R_0x834;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATE54M:
+			reg_txagc = R_0x834;
+			reg_mask = 0x7f000000;
+			break;
+
+		case ODM_RATEMCS0:
+			reg_txagc = R_0x83c;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS1:
+			reg_txagc = R_0x83c;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS2:
+			reg_txagc = R_0x83c;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS3:
+			reg_txagc = R_0x83c;
+			reg_mask = 0x7f000000;
+			break;
+		case ODM_RATEMCS4:
+			reg_txagc = R_0x848;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS5:
+			reg_txagc = R_0x848;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS6:
+			reg_txagc = R_0x848;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS7:
+			reg_txagc = R_0x848;
+			reg_mask = 0x7f000000;
+			break;
+
+		case ODM_RATEMCS8:
+			reg_txagc = R_0x84c;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS9:
+			reg_txagc = R_0x84c;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS10:
+			reg_txagc = R_0x84c;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS11:
+			reg_txagc = R_0x84c;
+			reg_mask = 0x7f000000;
+			break;
+		case ODM_RATEMCS12:
+			reg_txagc = R_0x868;
+			reg_mask = 0x0000007f;
+			break;
+		case ODM_RATEMCS13:
+			reg_txagc = R_0x868;
+			reg_mask = 0x00007f00;
+			break;
+		case ODM_RATEMCS14:
+			reg_txagc = R_0x868;
+			reg_mask = 0x007f0000;
+			break;
+		case ODM_RATEMCS15:
+			reg_txagc = R_0x868;
+			reg_mask = 0x7f000000;
+			break;
+
+		default:
+			PHYDM_DBG(dm, ODM_PHY_CONFIG, "Invalid HWrate!\n");
+			break;
+		}
+	} else {
+		PHYDM_DBG(dm, ODM_PHY_CONFIG, "Invalid RF path!!\n");
+	}
+	read_back_data = (u8)odm_get_bb_reg(dm, reg_txagc, reg_mask);
+	PHYDM_DBG(dm, ODM_PHY_CONFIG, "%s: path-%d rate index 0x%x = 0x%x\n",
+		  __func__, path, hw_rate, read_back_data);
+	return read_back_data;
+}
+#endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-phydm_normal_driver_rx_sniffer(
-	struct PHY_DM_STRUCT			*p_dm,
-	u8				*p_desc,
-	PRT_RFD_STATUS		p_rt_rfd_status,
-	u8				*p_drv_info,
-	u8				phy_status
-)
+void phydm_normal_driver_rx_sniffer(
+	struct dm_struct *dm,
+	u8 *desc,
+	PRT_RFD_STATUS rt_rfd_status,
+	u8 *drv_info,
+	u8 phy_status)
 {
 #if (defined(CONFIG_PHYDM_RX_SNIFFER_PARSING))
-	u32		*p_msg;
-	u16		seq_num;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
+	u32 *msg;
+	u16 seq_num;
 
-	if (p_rt_rfd_status->packet_report_type != NORMAL_RX)
+	if (rt_rfd_status->packet_report_type != NORMAL_RX)
 		return;
 
-	if (!p_dm->is_linked) {
-		if (p_rt_rfd_status->is_hw_error)
+	if (!dm->is_linked) {
+		if (rt_rfd_status->is_hw_error)
 			return;
 	}
 
-	if (!(p_dm_fat_table->fat_state == FAT_TRAINING_STATE))
-		return;
-
 	if (phy_status == true) {
-
-		if ((p_dm->rx_pkt_type == type_block_ack) || (p_dm->rx_pkt_type == type_rts) || (p_dm->rx_pkt_type == type_cts))
+		if (dm->rx_pkt_type == type_block_ack ||
+		    dm->rx_pkt_type == type_rts || dm->rx_pkt_type == type_cts)
 			seq_num = 0;
 		else
-			seq_num = p_rt_rfd_status->seq_num;
-
-		PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, ("%04d , %01s, rate=0x%02x, L=%04d , %s , %s",
-				seq_num,
-				/*p_rt_rfd_status->mac_id,*/
-			((p_rt_rfd_status->is_crc) ? "C" : (p_rt_rfd_status->is_ampdu) ? "A" : "_"),
-				p_rt_rfd_status->data_rate,
-				p_rt_rfd_status->length,
-			((p_rt_rfd_status->band_width == 0) ? "20M" : ((p_rt_rfd_status->band_width == 1) ? "40M" : "80M")),
-				((p_rt_rfd_status->is_ldpc) ? "LDP" : "BCC")));
-
-		if (p_dm->rx_pkt_type == type_asoc_req) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "AS_REQ"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_asoc_rsp) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "AS_RSP"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_probe_req) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "PR_REQ"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_probe_rsp) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "PR_RSP"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_deauth) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "DEAUTH"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_beacon) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "BEACON"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_block_ack_req) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "BA_REQ"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_rts) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "__RTS_"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_cts) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "__CTS_"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_ack) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "__ACK_"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_block_ack) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "__BA__"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_data) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "_DATA_"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_data_ack) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "Data_Ack"));
-			/**/
-		} else if (p_dm->rx_pkt_type == type_qos_data) {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [%s]", "QoS_Data"));
-			/**/
-		} else {
-			PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [0x%x]", p_dm->rx_pkt_type));
-			/**/
-		}
+			seq_num = rt_rfd_status->seq_num;
+
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER,
+			    "%04d , %01s, rate=0x%02x, L=%04d , %s , %s",
+			    seq_num,
+			    /*rt_rfd_status->mac_id,*/
+			    (rt_rfd_status->is_crc ? "C" :
+			    rt_rfd_status->is_ampdu ? "A" : "_"),
+			    rt_rfd_status->data_rate,
+			    rt_rfd_status->length,
+			    ((rt_rfd_status->band_width == 0) ? "20M" :
+			    ((rt_rfd_status->band_width == 1) ? "40M" : "80M")),
+			    (rt_rfd_status->is_ldpc ? "LDP" : "BCC"));
+
+		if (dm->rx_pkt_type == type_asoc_req)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "AS_REQ");
+		else if (dm->rx_pkt_type == type_asoc_rsp)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "AS_RSP");
+		else if (dm->rx_pkt_type == type_probe_req)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "PR_REQ");
+		else if (dm->rx_pkt_type == type_probe_rsp)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "PR_RSP");
+		else if (dm->rx_pkt_type == type_deauth)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "DEAUTH");
+		else if (dm->rx_pkt_type == type_beacon)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "BEACON");
+		else if (dm->rx_pkt_type == type_block_ack_req)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "BA_REQ");
+		else if (dm->rx_pkt_type == type_rts)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__RTS_");
+		else if (dm->rx_pkt_type == type_cts)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__CTS_");
+		else if (dm->rx_pkt_type == type_ack)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__ACK_");
+		else if (dm->rx_pkt_type == type_block_ack)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "__BA__");
+		else if (dm->rx_pkt_type == type_data)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "_DATA_");
+		else if (dm->rx_pkt_type == type_data_ack)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "Data_Ack");
+		else if (dm->rx_pkt_type == type_qos_data)
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [%s]", "QoS_Data");
+		else
+			PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [0x%x]",
+				    dm->rx_pkt_type);
 
-		PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , [RSSI=%d,%d,%d,%d ]",
-				p_dm->RSSI_A,
-				p_dm->RSSI_B,
-				p_dm->RSSI_C,
-				p_dm->RSSI_D));
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER, " , [RSSI=%d,%d,%d,%d ]",
+			    dm->rssi_a,
+			    dm->rssi_b,
+			    dm->rssi_c,
+			    dm->rssi_d);
 
-		p_msg = (u32 *)p_drv_info;
+		msg = (u32 *)drv_info;
 
-		PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, (" , P-STS[28:0]=%08x-%08x-%08x-%08x-%08x-%08x-%08x\n",
-			p_msg[6], p_msg[5], p_msg[4], p_msg[3], p_msg[2], p_msg[1], p_msg[1]));
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER,
+			    " , P-STS[28:0]=%08x-%08x-%08x-%08x-%08x-%08x-%08x\n",
+			    msg[6], msg[5], msg[4], msg[3],
+			    msg[2], msg[1], msg[1]);
 	} else {
-
-		PHYDM_DBG_F(p_dm, ODM_COMP_SNIFFER, ("%04d , %01s, rate=0x%02x, L=%04d , %s , %s\n",
-				p_rt_rfd_status->seq_num,
-				/*p_rt_rfd_status->mac_id,*/
-			((p_rt_rfd_status->is_crc) ? "C" : (p_rt_rfd_status->is_ampdu) ? "A" : "_"),
-				p_rt_rfd_status->data_rate,
-				p_rt_rfd_status->length,
-			((p_rt_rfd_status->band_width == 0) ? "20M" : ((p_rt_rfd_status->band_width == 1) ? "40M" : "80M")),
-				((p_rt_rfd_status->is_ldpc) ? "LDP" : "BCC")));
+		PHYDM_DBG_F(dm, ODM_COMP_SNIFFER,
+			    "%04d , %01s, rate=0x%02x, L=%04d , %s , %s\n",
+			    rt_rfd_status->seq_num,
+			    /*rt_rfd_status->mac_id,*/
+			    (rt_rfd_status->is_crc ? "C" :
+			    (rt_rfd_status->is_ampdu) ? "A" : "_"),
+			    rt_rfd_status->data_rate,
+			    rt_rfd_status->length,
+			    ((rt_rfd_status->band_width == 0) ? "20M" :
+			    ((rt_rfd_status->band_width == 1) ? "40M" : "80M")),
+			    (rt_rfd_status->is_ldpc ? "LDP" : "BCC"));
 	}
 
-
 #endif
 }
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.h
index 446350e75b7a..9a356672527e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_api.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,193 +9,178 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDM_API_H__
+#define __PHYDM_API_H__
 
-#ifndef	__PHYDM_API_H__
-#define    __PHYDM_API_H__
+#define PHYDM_API_VERSION "1.0" /* @2017.07.10  Dino, Add phydm_api.h*/
 
-#define PHYDM_API_VERSION	"1.0"		/* 2017.07.10  Dino, Add phydm_api.h*/
-
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
+#define CN_CNT_MAX 10 /*@max condition number threshold*/
 
+#define FUNC_ENABLE 1
+#define FUNC_DISABLE 2
 
-#define	FUNC_ENABLE 1
-#define	FUNC_DISABLE 2
+/*@NBI API------------------------------------*/
+#define NBI_128TONE 27 /*register table size*/
+#define NBI_256TONE 59 /*register table size*/
 
-/*NBI API------------------------------------*/
-#define	NBI_TABLE_SIZE_128	27
-#define	NBI_TABLE_SIZE_256	59
+#define NUM_START_CH_80M 7
+#define NUM_START_CH_40M 14
 
-#define	NUM_START_CH_80M	7
-#define	NUM_START_CH_40M	14
+#define CH_OFFSET_40M 2
+#define CH_OFFSET_80M 6
 
-#define	CH_OFFSET_40M		2
-#define	CH_OFFSET_80M		6
+#define FFT_128_TYPE 1
+#define FFT_256_TYPE 2
 
-#define	FFT_128_TYPE	1
-#define	FFT_256_TYPE	2
+#define FREQ_POSITIVE 1
+#define FREQ_NEGATIVE 2
+/*@------------------------------------------------*/
 
-#define	FREQ_POSITIVE	1
-#define	FREQ_NEGATIVE	2
-/*------------------------------------------------*/
+enum phystat_rpt {
+	PHY_PWDB = 0,
+	PHY_EVM = 1,
+	PHY_CFO = 2,
+	PHY_RXSNR = 3,
+	PHY_LGAIN = 4,
+	PHY_HT_AAGC_GAIN = 5,
+};
 
-/* 1 ============================================================
+#ifndef PHYDM_COMMON_API_SUPPORT
+#define INVALID_RF_DATA 0xffffffff
+#define INVALID_TXAGC_DATA 0xff
+#endif
+
+/* @1 ============================================================
  * 1  structure
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
 struct phydm_api_stuc {
-
-	u32	rx_iqc_reg_1;	/*N-mode: for pathA REG0xc14*/
-	u32	rx_iqc_reg_2;	/*N-mode: for pathB REG0xc1c*/
-	u8	tx_queue_bitmap;/*REG0x520[23:16]*/
-
+	u32 rxiqc_reg1; /*N-mode: for pathA REG0xc14*/
+	u32 rxiqc_reg2; /*N-mode: for pathB REG0xc1c*/
+	u8 tx_queue_bitmap; /*REG0x520[23:16]*/
+	u8 ccktx_path;
 };
 
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  enumeration
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
+
+/* @1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================
+ */
+void phydm_reset_bb_hw_cnt(void *dm_void);
 
+void phydm_dynamic_ant_weighting(void *dm_void);
 
+#ifdef DYN_ANT_WEIGHTING_SUPPORT
+void phydm_ant_weight_dbg(void *dm_void, char input[][16], u32 *_used,
+			  char *output, u32 *_out_len);
+#endif
 
-/* 1 ============================================================
- * 1  function prototype
- * 1 ============================================================ */
-
-void
-phydm_init_trx_antenna_setting(
-	void		*p_dm_void
-);
-
-void
-phydm_config_ofdm_rx_path(
-	void		*p_dm_void,
-	u32		path
-);
-
-void
-phydm_config_cck_rx_path(
-	void		*p_dm_void,
-	enum bb_path	path
-);
-
-void
-phydm_config_cck_rx_antenna_init(
-	void		*p_dm_void
-);
-
-void
-phydm_config_trx_path(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-void
-phydm_stop_3_wire(
-	void		*p_dm_void,
-	u8		set_type
-);
-
-u8
-phydm_stop_ic_trx(
-	void		*p_dm_void,
-	u8		set_type
-);
-
-void
-phydm_set_ext_switch(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-void
-phydm_nbi_enable(
-	void		*p_dm_void,
-	u32		enable
-);
-
-u8
-phydm_csi_mask_setting(
-	void		*p_dm_void,
-	u32		enable,
-	u32		channel,
-	u32		bw,
-	u32		f_interference,
-	u32		Second_ch
-);
-
-u8
-phydm_nbi_setting(
-	void		*p_dm_void,
-	u32		enable,
-	u32		channel,
-	u32		bw,
-	u32		f_interference,
-	u32		second_ch
-);
-
-
-void
-phydm_api_debug(
-	void		*p_dm_void,
-	u32		function_map,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-void
-phydm_stop_ck320(
-	void			*p_dm_void,
-	u8			enable
-);
+void phydm_pathb_q_matrix_rotate_en(void *dm_void);
 
-#ifdef PHYDM_COMMON_API_SUPPORT
+void phydm_pathb_q_matrix_rotate(void *dm_void, u16 phase_idx);
+
+void phydm_trx_antenna_setting_init(void *dm_void, u8 num_rf_path);
+
+void phydm_config_ofdm_rx_path(void *dm_void, u32 path);
+
+void phydm_config_cck_rx_path(void *dm_void, enum bb_path path);
+
+void phydm_config_cck_rx_antenna_init(void *dm_void);
+
+void phydm_config_trx_path(void *dm_void, char input[][16], u32 *_used,
+			   char *output, u32 *_out_len);
+
+void phydm_tx_2path(void *dm_void);
+
+void phydm_stop_3_wire(void *dm_void, u8 set_type);
+
+u8 phydm_stop_ic_trx(void *dm_void, u8 set_type);
+
+void phydm_dis_cck_trx(void *dm_void, u8 set_type);
+
+void phydm_set_ext_switch(void *dm_void, u32 ext_ant_switch);
+
+void phydm_nbi_enable(void *dm_void, u32 enable);
+
+u8 phydm_csi_mask_setting(void *dm_void, u32 enable, u32 ch, u32 bw, u32 f_intf,
+			  u32 sec_ch);
+
+u8 phydm_nbi_setting(void *dm_void, u32 enable, u32 ch, u32 bw, u32 f_intf,
+		     u32 sec_ch);
+
+void phydm_nbi_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len);
+
+void phydm_csi_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len);
+
+void phydm_stop_ck320(void *dm_void, u8 enable);
 
 boolean
-phydm_api_set_txagc(
-	void				*p_dm_void,
-	u32				power_index,
-	enum rf_path		path,
-	u8				hw_rate,
-	boolean			is_single_rate
-);
-
-u8
-phydm_api_get_txagc(
-	void				*p_dm_void,
-	enum rf_path		path,
-	u8				hw_rate
-);
+phydm_set_bb_txagc_offset(void *dm_void, s8 power_offset, u8 add_half_db);
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+u8 phydm_csi_mask_setting_jgr3(void *dm_void, u32 enable, u32 ch, u32 bw,
+			       u32 f_intf, u32 sec_ch, u8 wgt);
+
+void phydm_set_csi_mask_jgr3(void *dm_void, u32 tone_idx_tmp, u8 tone_direction,
+			     u8 wgt);
+
+u8 phydm_nbi_setting_jgr3(void *dm_void, u32 enable, u32 ch, u32 bw, u32 f_intf,
+			  u32 sec_ch, u8 path);
+
+void phydm_set_nbi_reg_jgr3(void *dm_void, u32 tone_idx_tmp, u8 tone_direction,
+			    u8 path);
+
+void phydm_nbi_enable_jgr3(void *dm_void, u32 enable, u8 path);
+
+u8 phydm_phystat_rpt_jgr3(void *dm_void, enum phystat_rpt info,
+			  enum rf_path ant_path);
+void phydm_user_position_for_sniffer(void *dm_void, u8 user_position);
+
+void phydm_txagc_power_limit(void *dm_void, boolean is_bf, u8 ss, u8 pwr);
+#endif
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+boolean
+phydm_api_shift_txagc(void *dm_void, u32 pwr_offset, enum rf_path path,
+		      boolean is_positive);
+boolean
+phydm_api_set_txagc(void *dm_void, u32 power_index, enum rf_path path,
+		    u8 hw_rate, boolean is_single_rate);
+
+u8 phydm_api_get_txagc(void *dm_void, enum rf_path path, u8 hw_rate);
 
 boolean
-phydm_api_switch_bw_channel(
-	void					*p_dm_void,
-	u8					central_ch,
-	u8					primary_ch_idx,
-	enum channel_width	bandwidth
-);
+phydm_api_switch_bw_channel(void *dm_void, u8 central_ch, u8 primary_ch_idx,
+			    enum channel_width bandwidth);
 
 boolean
-phydm_api_trx_mode(
-	void				*p_dm_void,
-	enum bb_path	tx_path,
-	enum bb_path	rx_path,
-	boolean			is_tx2_path
-);
+phydm_api_trx_mode(void *dm_void, enum bb_path tx_path, enum bb_path rx_path,
+		   boolean is_tx2_path);
 
 #endif
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.c
index e396a2f9514c..95a311dc7799 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,628 +9,706 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
 #ifdef PHYDM_AUTO_DEGBUG
 
-void
-phydm_check_hang_reset(
-	void			*p_dm_void
-)
+void phydm_check_hang_reset(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_auto_dbg_struc	*p_atd_t = &(p_dm->auto_dbg_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struct *atd_t = &dm->auto_dbg_table;
 
-	dbg_print("%s ======>\n", __func__);
+	atd_t->dbg_step = 0;
+	atd_t->auto_dbg_type = AUTO_DBG_STOP;
+	phydm_pause_dm_watchdog(dm, PHYDM_RESUME);
+	dm->debug_components &= (~ODM_COMP_API);
+}
+
+void phydm_check_hang_init(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struct *atd_t = &dm->auto_dbg_table;
 
-	p_atd_t->dbg_step = 0;
-	p_atd_t->auto_dbg_type = AUTO_DBG_STOP;
-	phydm_pause_dm_watchdog(p_dm, PHYDM_RESUME);
-	p_dm->debug_components &= (~ODM_COMP_API);
+	atd_t->dbg_step = 0;
+	atd_t->auto_dbg_type = AUTO_DBG_STOP;
+	phydm_pause_dm_watchdog(dm, PHYDM_RESUME);
 }
 
 #if (ODM_IC_11N_SERIES_SUPPORT == 1)
-void
-phydm_auto_check_hang_engine_n(
-	void			*p_dm_void
-)
+void phydm_auto_check_hang_engine_n(
+	void *dm_void)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	phydm_auto_dbg_struc	*p_atd_t = &(p_dm->auto_dbg_table);
-	struct	n_dbgport_803	dbgport_803 = {0};
-	u32		value32_tmp = 0, value32_tmp_2 = 0;
-	u8		i;
-	u32		curr_dbg_port_val[DBGPORT_CHK_NUM];
-	u16		curr_ofdm_t_cnt;
-	u16		curr_ofdm_r_cnt;
-	u16		curr_cck_t_cnt;
-	u16		curr_cck_r_cnt;
-	u16		curr_ofdm_crc_error_cnt;
-	u16		curr_cck_crc_error_cnt;
-	u16		diff_ofdm_t_cnt;
-	u16		diff_ofdm_r_cnt;
-	u16		diff_cck_t_cnt;
-	u16		diff_cck_r_cnt;
-	u16		diff_ofdm_crc_error_cnt;
-	u16		diff_cck_crc_error_cnt;
-	u8		rf_mode;
-
-
-	if (p_atd_t->auto_dbg_type == AUTO_DBG_STOP)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struct *atd_t = &dm->auto_dbg_table;
+	struct n_dbgport_803 dbgport_803 = {0};
+	u32 value32_tmp = 0, value32_tmp_2 = 0;
+	u8 i;
+	u32 curr_dbg_port_val[DBGPORT_CHK_NUM];
+	u16 curr_ofdm_t_cnt;
+	u16 curr_ofdm_r_cnt;
+	u16 curr_cck_t_cnt;
+	u16 curr_cck_r_cnt;
+	u16 curr_ofdm_crc_error_cnt;
+	u16 curr_cck_crc_error_cnt;
+	u16 diff_ofdm_t_cnt;
+	u16 diff_ofdm_r_cnt;
+	u16 diff_cck_t_cnt;
+	u16 diff_cck_r_cnt;
+	u16 diff_ofdm_crc_error_cnt;
+	u16 diff_cck_crc_error_cnt;
+	u8 rf_mode;
+
+	if (atd_t->auto_dbg_type == AUTO_DBG_STOP)
 		return;
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-
-		phydm_check_hang_reset(p_dm);
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		phydm_check_hang_reset(dm);
 		return;
 	}
 
-	if (p_atd_t->dbg_step == 0) {
+	if (atd_t->dbg_step == 0) {
+		pr_debug("dbg_step=0\n\n");
 
-		dbg_print("dbg_step=0\n\n");
-		
 		/*Reset all packet counter*/
-		odm_set_bb_reg(p_dm, 0xf14, BIT(16), 1);
-		odm_set_bb_reg(p_dm, 0xf14, BIT(16), 0);
-
-
+		odm_set_bb_reg(dm, R_0xf14, BIT(16), 1);
+		odm_set_bb_reg(dm, R_0xf14, BIT(16), 0);
 
-	} else if (p_atd_t->dbg_step == 1)  {
-
-		dbg_print("dbg_step=1\n\n");
+	} else if (atd_t->dbg_step == 1) {
+		pr_debug("dbg_step=1\n\n");
 
 		/*Check packet counter Register*/
-		p_atd_t->ofdm_t_cnt = (u16)odm_get_bb_reg(p_dm, 0x9cc, MASKHWORD);
-		p_atd_t->ofdm_r_cnt = (u16)odm_get_bb_reg(p_dm, 0xf94, MASKLWORD);
-		p_atd_t->ofdm_crc_error_cnt = (u16)odm_get_bb_reg(p_dm, 0xf94, MASKHWORD);
-		
-		p_atd_t->cck_t_cnt = (u16)odm_get_bb_reg(p_dm, 0x9d0, MASKHWORD);;
-		p_atd_t->cck_r_cnt = (u16)odm_get_bb_reg(p_dm, 0xfa0, MASKHWORD);
-		p_atd_t->cck_crc_error_cnt = (u16)odm_get_bb_reg(p_dm, 0xf84, 0x3fff);	
+		atd_t->ofdm_t_cnt = (u16)odm_get_bb_reg(dm, R_0x9cc, MASKHWORD);
+		atd_t->ofdm_r_cnt = (u16)odm_get_bb_reg(dm, R_0xf94, MASKLWORD);
+		atd_t->ofdm_crc_error_cnt = (u16)odm_get_bb_reg(dm, R_0xf94,
+								MASKHWORD);
 
+		atd_t->cck_t_cnt = (u16)odm_get_bb_reg(dm, R_0x9d0, MASKHWORD);
+		atd_t->cck_r_cnt = (u16)odm_get_bb_reg(dm, R_0xfa0, MASKHWORD);
+		atd_t->cck_crc_error_cnt = (u16)odm_get_bb_reg(dm, R_0xf84,
+							       0x3fff);
 
 		/*Check Debug Port*/
 		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
-			
-			if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_3, (u32)p_atd_t->dbg_port_table[i])) {
-				p_atd_t->dbg_port_val[i] = phydm_get_bb_dbg_port_value(p_dm);
-				phydm_release_bb_dbg_port(p_dm);
+			if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3,
+						  (u32)atd_t->dbg_port_table[i])
+						  ) {
+				atd_t->dbg_port_val[i] =
+					phydm_get_bb_dbg_port_val(dm);
+				phydm_release_bb_dbg_port(dm);
 			}
 		}
-	
-	} else if (p_atd_t->dbg_step == 2)  {
 
-		dbg_print("dbg_step=2\n\n");
+	} else if (atd_t->dbg_step == 2) {
+		pr_debug("dbg_step=2\n\n");
 
 		/*Check packet counter Register*/
-		curr_ofdm_t_cnt = (u16)odm_get_bb_reg(p_dm, 0x9cc, MASKHWORD);
-		curr_ofdm_r_cnt = (u16)odm_get_bb_reg(p_dm, 0xf94, MASKLWORD);
-		curr_ofdm_crc_error_cnt = (u16)odm_get_bb_reg(p_dm, 0xf94, MASKHWORD);
-		
-		curr_cck_t_cnt = (u16)odm_get_bb_reg(p_dm, 0x9d0, MASKHWORD);;
-		curr_cck_r_cnt = (u16)odm_get_bb_reg(p_dm, 0xfa0, MASKHWORD);
-		curr_cck_crc_error_cnt = (u16)odm_get_bb_reg(p_dm, 0xf84, 0x3fff);	
+		curr_ofdm_t_cnt = (u16)odm_get_bb_reg(dm, R_0x9cc, MASKHWORD);
+		curr_ofdm_r_cnt = (u16)odm_get_bb_reg(dm, R_0xf94, MASKLWORD);
+		curr_ofdm_crc_error_cnt = (u16)odm_get_bb_reg(dm, R_0xf94,
+							      MASKHWORD);
+
+		curr_cck_t_cnt = (u16)odm_get_bb_reg(dm, R_0x9d0, MASKHWORD);
+		curr_cck_r_cnt = (u16)odm_get_bb_reg(dm, R_0xfa0, MASKHWORD);
+		curr_cck_crc_error_cnt = (u16)odm_get_bb_reg(dm, R_0xf84,
+							     0x3fff);
 
 		/*Check Debug Port*/
 		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
-			
-			if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_3, (u32)p_atd_t->dbg_port_table[i])) {
-				curr_dbg_port_val[i] = phydm_get_bb_dbg_port_value(p_dm);
-				phydm_release_bb_dbg_port(p_dm);
+			if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3,
+						  (u32)atd_t->dbg_port_table[i])
+						  ) {
+				curr_dbg_port_val[i] =
+					phydm_get_bb_dbg_port_val(dm);
+				phydm_release_bb_dbg_port(dm);
 			}
 		}
-	
-		/*=== Make check hang decision ================================*/
-		dbg_print("Check Hang Decision\n\n");
 
-		/* ----- Check RF Register -----------------------------------*/
-		for (i = 0; i < p_dm->num_rf_path; i++) {
-		
-			rf_mode = (u8)odm_get_rf_reg(p_dm, i, 0x0, 0xf0000);
-				
-			dbg_print("RF0x0[%d] = 0x%x\n", i, rf_mode);
+		/*=== Make check hang decision ===============================*/
+		pr_debug("Check Hang Decision\n\n");
 
+		/* ----- Check RF Register -----------------------------------*/
+		for (i = 0; i < dm->num_rf_path; i++) {
+			rf_mode = (u8)odm_get_rf_reg(dm, i, RF_0x0, 0xf0000);
+			pr_debug("RF0x0[%d] = 0x%x\n", i, rf_mode);
 			if (rf_mode > 3) {
-				dbg_print("Incorrect RF mode\n");
-				dbg_print("ReasonCode:RHN-1\n");
-
-				
+				pr_debug("Incorrect RF mode\n");
+				pr_debug("ReasonCode:RHN-1\n");
 			}
 		}
-
-		value32_tmp = odm_get_rf_reg(p_dm, 0, 0xb0, 0xf0000);
-			
-		if (p_dm->support_ic_type == ODM_RTL8188E) {
+		value32_tmp = odm_get_rf_reg(dm, 0, RF_0xb0, 0xf0000);
+		if (dm->support_ic_type == ODM_RTL8188E) {
 			if (value32_tmp != 0xff8c8) {
-				dbg_print("ReasonCode:RHN-3\n");
+				pr_debug("ReasonCode:RHN-3\n");
 			}
 		}
-
-		/* ----- Check BB Register -----------------------------------*/
-		
+		/* ----- Check BB Register ----------------------------------*/
 		/*BB mode table*/
-		value32_tmp = odm_get_bb_reg(p_dm, 0x824, 0xe);
-		value32_tmp_2 = odm_get_bb_reg(p_dm, 0x82c, 0xe);
-		dbg_print("BB TX mode table {A, B}= {%d, %d}\n", value32_tmp, value32_tmp_2);
+		value32_tmp = odm_get_bb_reg(dm, R_0x824, 0xe);
+		value32_tmp_2 = odm_get_bb_reg(dm, R_0x82c, 0xe);
+		pr_debug("BB TX mode table {A, B}= {%d, %d}\n",
+			 value32_tmp, value32_tmp_2);
 
-		if ((value32_tmp > 3) || (value32_tmp_2 > 3)) {
-			
-			dbg_print("ReasonCode:RHN-2\n");
+		if (value32_tmp > 3 || value32_tmp_2 > 3) {
+			pr_debug("ReasonCode:RHN-2\n");
 		}
 
-		value32_tmp = odm_get_bb_reg(p_dm, 0x824, 0x700000);
-		value32_tmp_2 = odm_get_bb_reg(p_dm, 0x82c, 0x700000);
-		dbg_print("BB RX mode table {A, B}= {%d, %d}\n", value32_tmp, value32_tmp_2);
+		value32_tmp = odm_get_bb_reg(dm, R_0x824, 0x700000);
+		value32_tmp_2 = odm_get_bb_reg(dm, R_0x82c, 0x700000);
+		pr_debug("BB RX mode table {A, B}= {%d, %d}\n", value32_tmp,
+			 value32_tmp_2);
 
-		if ((value32_tmp > 3) || (value32_tmp_2 > 3)) {
-			
-			dbg_print("ReasonCode:RHN-2\n");
+		if (value32_tmp > 3 || value32_tmp_2 > 3) {
+			pr_debug("ReasonCode:RHN-2\n");
 		}
-		
 
 		/*BB HW Block*/
-		value32_tmp = odm_get_bb_reg(p_dm, 0x800, MASKDWORD);
-		
+		value32_tmp = odm_get_bb_reg(dm, R_0x800, MASKDWORD);
+
 		if (!(value32_tmp & BIT(24))) {
-			dbg_print("Reg0x800[24] = 0, CCK BLK is disabled\n");
-			dbg_print("ReasonCode: THN-3\n");
+			pr_debug("Reg0x800[24] = 0, CCK BLK is disabled\n");
+			pr_debug("ReasonCode: THN-3\n");
 		}
-		
+
 		if (!(value32_tmp & BIT(25))) {
-			dbg_print("Reg0x800[24] = 0, OFDM BLK is disabled\n");
-			dbg_print("ReasonCode:THN-3\n");
+			pr_debug("Reg0x800[24] = 0, OFDM BLK is disabled\n");
+			pr_debug("ReasonCode:THN-3\n");
 		}
 
 		/*BB Continue TX*/
-		value32_tmp = odm_get_bb_reg(p_dm, 0xd00, 0x70000000);
-		dbg_print("Continue TX=%d\n", value32_tmp);
+		value32_tmp = odm_get_bb_reg(dm, R_0xd00, 0x70000000);
+		pr_debug("Continue TX=%d\n", value32_tmp);
 		if (value32_tmp != 0) {
-			dbg_print("ReasonCode: THN-4\n");
+			pr_debug("ReasonCode: THN-4\n");
 		}
-		
 
 		/* ----- Check Packet Counter --------------------------------*/
-		diff_ofdm_t_cnt = curr_ofdm_t_cnt - p_atd_t->ofdm_t_cnt;
-		diff_ofdm_r_cnt = curr_ofdm_r_cnt - p_atd_t->ofdm_r_cnt;
-		diff_ofdm_crc_error_cnt = curr_ofdm_crc_error_cnt - p_atd_t->ofdm_crc_error_cnt;
-		
-		diff_cck_t_cnt = curr_cck_t_cnt - p_atd_t->cck_t_cnt;
-		diff_cck_r_cnt = curr_cck_r_cnt - p_atd_t->cck_r_cnt;
-		diff_cck_crc_error_cnt = curr_cck_crc_error_cnt - p_atd_t->cck_crc_error_cnt;
-
-		dbg_print("OFDM[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
-			p_atd_t->ofdm_t_cnt, p_atd_t->ofdm_r_cnt, p_atd_t->ofdm_crc_error_cnt);
-		dbg_print("OFDM[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
-			curr_ofdm_t_cnt, curr_ofdm_r_cnt, curr_ofdm_crc_error_cnt);
-		dbg_print("OFDM_diff {TX, RX, CRC_error} = {%d, %d, %d}\n", 
-			diff_ofdm_t_cnt, diff_ofdm_r_cnt, diff_ofdm_crc_error_cnt);
-
-		dbg_print("CCK[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
-			p_atd_t->cck_t_cnt, p_atd_t->cck_r_cnt, p_atd_t->cck_crc_error_cnt);
-		dbg_print("CCK[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n", 
-			curr_cck_t_cnt, curr_cck_r_cnt, curr_cck_crc_error_cnt);
-		dbg_print("CCK_diff {TX, RX, CRC_error} = {%d, %d, %d}\n", 
-			diff_cck_t_cnt, diff_cck_r_cnt, diff_cck_crc_error_cnt);
+		diff_ofdm_t_cnt = curr_ofdm_t_cnt - atd_t->ofdm_t_cnt;
+		diff_ofdm_r_cnt = curr_ofdm_r_cnt - atd_t->ofdm_r_cnt;
+		diff_ofdm_crc_error_cnt = curr_ofdm_crc_error_cnt -
+					  atd_t->ofdm_crc_error_cnt;
+
+		diff_cck_t_cnt = curr_cck_t_cnt - atd_t->cck_t_cnt;
+		diff_cck_r_cnt = curr_cck_r_cnt - atd_t->cck_r_cnt;
+		diff_cck_crc_error_cnt = curr_cck_crc_error_cnt -
+					 atd_t->cck_crc_error_cnt;
+
+		pr_debug("OFDM[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n",
+			 atd_t->ofdm_t_cnt, atd_t->ofdm_r_cnt,
+			 atd_t->ofdm_crc_error_cnt);
+		pr_debug("OFDM[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n",
+			 curr_ofdm_t_cnt, curr_ofdm_r_cnt,
+			 curr_ofdm_crc_error_cnt);
+		pr_debug("OFDM_diff {TX, RX, CRC_error} = {%d, %d, %d}\n",
+			 diff_ofdm_t_cnt, diff_ofdm_r_cnt,
+			 diff_ofdm_crc_error_cnt);
+
+		pr_debug("CCK[t=0~1] {TX, RX, CRC_error} = {%d, %d, %d}\n",
+			 atd_t->cck_t_cnt, atd_t->cck_r_cnt,
+			 atd_t->cck_crc_error_cnt);
+		pr_debug("CCK[t=1~2] {TX, RX, CRC_error} = {%d, %d, %d}\n",
+			 curr_cck_t_cnt, curr_cck_r_cnt,
+			 curr_cck_crc_error_cnt);
+		pr_debug("CCK_diff {TX, RX, CRC_error} = {%d, %d, %d}\n",
+			 diff_cck_t_cnt, diff_cck_r_cnt,
+			 diff_cck_crc_error_cnt);
 
 		/* ----- Check Dbg Port --------------------------------*/
 
 		for (i = 0; i < DBGPORT_CHK_NUM; i++) {
-
-			dbg_print("Dbg_port=((0x%x))\n", p_atd_t->dbg_port_table[i]);
-			dbg_print("Val{pre, curr}={0x%x, 0x%x}\n", p_atd_t->dbg_port_val[i], curr_dbg_port_val[i]);
-
-			if ((p_atd_t->dbg_port_table[i]) == 0) {
-
-				if (p_atd_t->dbg_port_val[i] == curr_dbg_port_val[i]) {
-					
-					dbg_print("BB state hang\n");
-					dbg_print("ReasonCode:\n");
+			pr_debug("Dbg_port=((0x%x))\n",
+				 atd_t->dbg_port_table[i]);
+			pr_debug("Val{pre, curr}={0x%x, 0x%x}\n",
+				 atd_t->dbg_port_val[i], curr_dbg_port_val[i]);
+
+			if (atd_t->dbg_port_table[i] == 0) {
+				if (atd_t->dbg_port_val[i] ==
+				    curr_dbg_port_val[i]) {
+					pr_debug("BB state hang\n");
+					pr_debug("ReasonCode:\n");
 				}
 
-			} else if (p_atd_t->dbg_port_table[i] == 0x803) {
-
-				if (p_atd_t->dbg_port_val[i] == curr_dbg_port_val[i]) {
-
-					//dbgport_803 = (struct n_dbgport_803 )(p_atd_t->dbg_port_val[i]);
-
-					odm_move_memory(p_dm, &(dbgport_803),  &(p_atd_t->dbg_port_val[i]), sizeof(struct n_dbgport_803));
-
-					dbg_print("RSTB{BB, GLB, OFDM}={%d, %d, %d}\n", dbgport_803.bb_rst_b, dbgport_803.glb_rst_b, dbgport_803.ofdm_rst_b);
-					dbg_print("{ofdm_tx_en, cck_tx_en, phy_tx_on}={%d, %d, %d}\n", dbgport_803.ofdm_tx_en, dbgport_803.cck_tx_en, dbgport_803.phy_tx_on);
-					dbg_print("CCA_PP{OFDM, CCK}={%d, %d}\n", dbgport_803.ofdm_cca_pp, dbgport_803.cck_cca_pp);
+			} else if (atd_t->dbg_port_table[i] == 0x803) {
+				if (atd_t->dbg_port_val[i] ==
+				    curr_dbg_port_val[i]) {
+					/* dbgport_803 =  */
+					/* (struct n_dbgport_803 )   */
+					/* (atd_t->dbg_port_val[i]); */
+					odm_move_memory(dm, &dbgport_803,
+							&atd_t->dbg_port_val[i],
+							sizeof(struct n_dbgport_803));
+					pr_debug("RSTB{BB, GLB, OFDM}={%d, %d,%d}\n",
+						 dbgport_803.bb_rst_b,
+						 dbgport_803.glb_rst_b,
+						 dbgport_803.ofdm_rst_b);
+					pr_debug("{ofdm_tx_en, cck_tx_en, phy_tx_on}={%d, %d, %d}\n",
+						 dbgport_803.ofdm_tx_en,
+						 dbgport_803.cck_tx_en,
+						 dbgport_803.phy_tx_on);
+					pr_debug("CCA_PP{OFDM, CCK}={%d, %d}\n",
+						 dbgport_803.ofdm_cca_pp,
+						 dbgport_803.cck_cca_pp);
 
 					if (dbgport_803.phy_tx_on)
-						dbg_print("Maybe TX Hang\n");
-					else if (dbgport_803.ofdm_cca_pp || dbgport_803.cck_cca_pp)
-						dbg_print("Maybe RX Hang\n");	
+						pr_debug("Maybe TX Hang\n");
+					else if (dbgport_803.ofdm_cca_pp ||
+						 dbgport_803.cck_cca_pp)
+						pr_debug("Maybe RX Hang\n");
 				}
 
-			} else if (p_atd_t->dbg_port_table[i] == 0x208) {
-
-				if ((p_atd_t->dbg_port_val[i] & BIT(30)) && (curr_dbg_port_val[i] & BIT(30))) {
-					
-					dbg_print("EDCCA Pause TX\n");
-					dbg_print("ReasonCode: THN-2\n");
+			} else if (atd_t->dbg_port_table[i] == 0x208) {
+				if ((atd_t->dbg_port_val[i] & BIT(30)) &&
+				    (curr_dbg_port_val[i] & BIT(30))) {
+					pr_debug("EDCCA Pause TX\n");
+					pr_debug("ReasonCode: THN-2\n");
 				}
 
-			} else if (p_atd_t->dbg_port_table[i] == 0xab0) {
-
-				if (((p_atd_t->dbg_port_val[i] & 0xffffff) == 0) || 
-					((curr_dbg_port_val[i] & 0xffffff) == 0)) {
-					
-					dbg_print("Wrong L-SIG formate\n");
-					dbg_print("ReasonCode: THN-1\n");
+			} else if (atd_t->dbg_port_table[i] == 0xab0) {
+				/* atd_t->dbg_port_val[i] & 0xffffff == 0 */
+				/* curr_dbg_port_val[i] & 0xffffff == 0 */
+				if (((atd_t->dbg_port_val[i] &
+				      MASK24BITS) == 0) ||
+				    ((curr_dbg_port_val[i] &
+				      MASK24BITS) == 0)) {
+					pr_debug("Wrong L-SIG formate\n");
+					pr_debug("ReasonCode: THN-1\n");
 				}
 			}
 		}
-		
-		phydm_check_hang_reset(p_dm);
+
+		phydm_check_hang_reset(dm);
 	}
 
-	p_atd_t->dbg_step++;
-	
+	atd_t->dbg_step++;
 }
 
-void
-phydm_bb_auto_check_hang_start_n(
-	void			*p_dm_void,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+void phydm_bb_auto_check_hang_start_n(
+	void *dm_void,
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
 {
-	u32	value32 = 0;
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_auto_dbg_struc	*p_atd_t = &(p_dm->auto_dbg_table);
+	u32 value32 = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struct *atd_t = &dm->auto_dbg_table;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
 		return;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, 
-		"PHYDM auto check hang (N-series) is started, Please check the system log\n"));
-
-	p_dm->debug_components |= ODM_COMP_API;
-	p_atd_t->auto_dbg_type = AUTO_DBG_CHECK_HANG;
-	p_atd_t->dbg_step = 0;
-	
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "PHYDM auto check hang (N-series) is started, Please check the system log\n");
 
-	phydm_pause_dm_watchdog(p_dm, PHYDM_PAUSE);
+	dm->debug_components |= ODM_COMP_API;
+	atd_t->auto_dbg_type = AUTO_DBG_CHECK_HANG;
+	atd_t->dbg_step = 0;
 
+	phydm_pause_dm_watchdog(dm, PHYDM_PAUSE);
 
-	
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_bb_rx_hang_info_n(
-	void			*p_dm_void,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+void phydm_dbg_port_dump_n(void *dm_void, u32 *_used, char *output,
+			   u32 *_out_len)
 {
-	u32	value32 = 0;
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u32 value32 = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
 		return;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "not support now\n"));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "not support now\n");
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-#endif	
+#endif
 
 #if (ODM_IC_11AC_SERIES_SUPPORT == 1)
-void
-phydm_bb_rx_hang_info_ac(
-	void			*p_dm_void,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+void phydm_dbg_port_dump_ac(void *dm_void, u32 *_used, char *output,
+			    u32 *_out_len)
 {
-	u32	value32 = 0;
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u32 value32 = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
 		return;
 
-	value32 = odm_get_bb_reg(p_dm, 0xF80, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used,  "\r\n %-35s = 0x%x", "rptreg of sc/bw/ht/...", value32));
+	value32 = odm_get_bb_reg(dm, R_0xf80, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = 0x%x", "rptreg of sc/bw/ht/...", value32);
 
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		odm_set_bb_reg(p_dm, 0x198c, BIT(2) | BIT(1) | BIT(0), 7);
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, R_0x198c, BIT(2) | BIT(1) | BIT(0), 7);
 
 	/* dbg_port = basic state machine */
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x000);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "basic state machine", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x000);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "basic state machine", value32);
 	}
 
 	/* dbg_port = state machine */
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x007);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "state machine", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x007);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "state machine", value32);
 	}
 
 	/* dbg_port = CCA-related*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x204);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "CCA-related", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x204);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "CCA-related", value32);
 	}
 
-
 	/* dbg_port = edcca/rxd*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x278);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "edcca/rxd", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x278);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "edcca/rxd", value32);
 	}
 
 	/* dbg_port = rx_state/mux_state/ADC_MASK_OFDM*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x290);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "rx_state/mux_state/ADC_MASK_OFDM", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x290);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x",
+			 "rx_state/mux_state/ADC_MASK_OFDM", value32);
 	}
 
 	/* dbg_port = bf-related*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B2);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "bf-related", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B2);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "bf-related", value32);
 	}
 
 	/* dbg_port = bf-related*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B8);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "bf-related", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0x2B8);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "bf-related", value32);
 	}
 
 	/* dbg_port = txon/rxd*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA03);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "txon/rxd", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA03);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "txon/rxd", value32);
 	}
 
 	/* dbg_port = l_rate/l_length*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0B);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "l_rate/l_length", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0B);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "l_rate/l_length", value32);
 	}
 
 	/* dbg_port = rxd/rxd_hit*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0D);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "rxd/rxd_hit", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xA0D);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "rxd/rxd_hit", value32);
 	}
 
 	/* dbg_port = dis_cca*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAA0);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "dis_cca", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAA0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "dis_cca", value32);
 	}
 
-
 	/* dbg_port = tx*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAB0);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "tx", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAB0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "tx", value32);
 	}
 
 	/* dbg_port = rx plcp*/
 	{
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD0);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "rx plcp", value32));
-
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD1);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
-
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "rx plcp", value32));
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD0);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD1);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD2);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "rx plcp", value32);
+
+		odm_set_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD3);
+		value32 = odm_get_bb_reg(dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "0x8fc", value32);
+
+		value32 = odm_get_bb_reg(dm, ODM_REG_RPT_11AC, MASKDWORD);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = 0x%x", "rx plcp", value32);
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
 
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD2);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_dbg_port_dump_jgr3(void *dm_void, u32 *_used, char *output,
+			      u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 dbg_port_idx_all[3] = {0x000, 0x001, 0x002};
+	u32 val = 0;
+	u32 dbg_port_idx = 0;
+	u32 i = 0;
 
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "rx plcp", value32));
+	if (!(dm->support_ic_type & ODM_IC_JGR3_SERIES))
+		return;
 
-		odm_set_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD, 0xAD3);
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_DBG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "0x8fc", value32));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "%-16s = %s\n", "DbgPort index", "Value");
+
+	/*0x000/0x001/0x002*/
+	for (i = 0; i < 3; i++) {
+		dbg_port_idx = dbg_port_idx_all[i];
+		if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3, dbg_port_idx)) {
+			val = phydm_get_bb_dbg_port_val(dm);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "0x%-15x = 0x%x\n", dbg_port_idx, val);
+			phydm_release_bb_dbg_port(dm);
+		}
+	}
 
-		value32 = odm_get_bb_reg(p_dm, ODM_REG_RPT_11AC, MASKDWORD);
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = 0x%x", "rx plcp", value32));
+	/*0x3a0/0x3a1/.../0x3ab/0x3ac*/
+	for (dbg_port_idx = 0x3a0; dbg_port_idx <= 0x3ac; dbg_port_idx++) {
+		if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3, dbg_port_idx)) {
+			val = phydm_get_bb_dbg_port_val(dm);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "0x%-15x = 0x%x\n", dbg_port_idx, val);
+			phydm_release_bb_dbg_port(dm);
+		}
 	}
 	*_used = used;
 	*_out_len = out_len;
 }
 #endif
-
-void
-phydm_auto_dbg_console(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_auto_dbg_console(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
 
 	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 
 	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "Show dbg port: {1} {1}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "Auto check hang: {1} {2}\n"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "hang: {1} {1:Show DbgPort, 2:Auto check hang}\n");
 		return;
 	} else if (var1[0] == 1) {
-
 		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &var1[1]);
-
 		if (var1[1] == 1) {
-			if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-				#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
-				phydm_bb_rx_hang_info_ac(p_dm, &used, output, &out_len);
-				#else
-				PHYDM_SNPRINTF((output + used, out_len - used, "Not support\n"));
-				#endif
-			} else {
-				#if (ODM_IC_11N_SERIES_SUPPORT == 1)
-				phydm_bb_rx_hang_info_n(p_dm, &used, output, &out_len);
-				#else
-				PHYDM_SNPRINTF((output + used, out_len - used, "Not support\n"));
-				#endif
+			switch (dm->ic_ip_series) {
+			#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+			case PHYDM_IC_JGR3:
+				phydm_dbg_port_dump_jgr3(dm, &used, output,
+							 &out_len);
+				break;
+			#endif
+
+			#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+			case PHYDM_IC_AC:
+				phydm_dbg_port_dump_ac(dm, &used, output,
+						       &out_len);
+				break;
+			#endif
+
+			#if (ODM_IC_11N_SERIES_SUPPORT == 1)
+			case PHYDM_IC_N:
+				phydm_dbg_port_dump_n(dm, &used, output,
+						      &out_len);
+				break;
+			#endif
+
+			default:
+				break;
+
 			}
 		} else if (var1[1] == 2) {
-		
-			if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-				PHYDM_SNPRINTF((output + used, out_len - used, "Not support\n"));
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used, "Not support\n");
 			} else {
 				#if (ODM_IC_11N_SERIES_SUPPORT == 1)
-				phydm_bb_auto_check_hang_start_n(p_dm, &used, output, &out_len);
+				phydm_bb_auto_check_hang_start_n(dm, &used,
+								 output,
+								 &out_len);
 				#else
-				PHYDM_SNPRINTF((output + used, out_len - used, "Not support\n"));
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used, "Not support\n");
 				#endif
 			}
 		}
-	} 
+	}
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-
-#endif
-
-void
-phydm_auto_dbg_engine(
-	void			*p_dm_void
-)
+void phydm_auto_dbg_engine(void *dm_void)
 {
-#ifdef PHYDM_AUTO_DEGBUG
-	u32	value32 = 0;
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_auto_dbg_struc	*p_atd_t = &(p_dm->auto_dbg_table);
+	u32 value32 = 0;
 
-	if (p_atd_t->auto_dbg_type == AUTO_DBG_STOP)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struct *atd_t = &dm->auto_dbg_table;
+
+	if (atd_t->auto_dbg_type == AUTO_DBG_STOP)
 		return;
 
-	dbg_print("%s ======>\n", __func__);
-	
-	if (p_atd_t->auto_dbg_type == AUTO_DBG_CHECK_HANG) {
+	pr_debug("%s ======>\n", __func__);
 
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-			dbg_print("Not Support\n");
+	if (atd_t->auto_dbg_type == AUTO_DBG_CHECK_HANG) {
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			pr_debug("Not Support\n");
 		} else {
 			#if (ODM_IC_11N_SERIES_SUPPORT == 1)
-			phydm_auto_check_hang_engine_n(p_dm);
+			phydm_auto_check_hang_engine_n(dm);
 			#else
-			dbg_print("Not Support\n");
+			pr_debug("Not Support\n");
 			#endif
 		}
 
-	} else if (p_atd_t->auto_dbg_type == AUTO_DBG_CHECK_RA) {
-	
-		dbg_print("Not Support\n");
-
+	} else if (atd_t->auto_dbg_type == AUTO_DBG_CHECK_RA) {
+		pr_debug("Not Support\n");
 	}
-#endif
 }
 
-void
-phydm_auto_dbg_engine_init(
-	void		*p_dm_void
-)
+void phydm_auto_dbg_engine_init(void *dm_void)
 {
-#ifdef PHYDM_AUTO_DEGBUG
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_auto_dbg_struc	*p_atd_t = &(p_dm->auto_dbg_table);
-	u16 dbg_port_table[DBGPORT_CHK_NUM] = {0x0, 0x803, 0x208, 0xab0, 0xab1, 0xab2};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_auto_dbg_struct *atd_t = &dm->auto_dbg_table;
+	u16 dbg_port_table[DBGPORT_CHK_NUM] = {0x0, 0x803, 0x208, 0xab0,
+					       0xab1, 0xab2};
 
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("%s ======>n", __func__));
+	PHYDM_DBG(dm, ODM_COMP_API, "%s ======>n", __func__);
 
-	odm_move_memory(p_dm, &(p_atd_t->dbg_port_table[0]),  &(dbg_port_table[0]), (DBGPORT_CHK_NUM * 2));
+	odm_move_memory(dm, &atd_t->dbg_port_table[0],
+			&dbg_port_table[0], (DBGPORT_CHK_NUM * 2));
 
-	phydm_check_hang_reset(p_dm);
-#endif
+	phydm_check_hang_init(dm);
 }
-
-
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.h
index 784c5d12f4c5..1b4e6fe2f0d8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_auto_dbg.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,108 +9,106 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDM_AUTO_DBG_H__
+#define __PHYDM_AUTO_DBG_H__
 
-#ifndef	__PHYDM_AUTO_DBG_H__
-#define    __PHYDM_AUTO_DBG_H__
-
-#define AUTO_DBG_VERSION	"1.0"		/* 2017.05.015  Dino, Add phydm_auto_dbg.h*/
+#define AUTO_DBG_VERSION "1.0" /* @2017.05.015  Dino, Add phydm_auto_dbg.h*/
 
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
-#define	AUTO_CHK_HANG_STEP_MAX	3
-#define	DBGPORT_CHK_NUM			6
+#define AUTO_CHK_HANG_STEP_MAX 3
+#define DBGPORT_CHK_NUM 6
 
 #ifdef PHYDM_AUTO_DEGBUG
 
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  enumeration
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
-enum auto_dbg_type_e{
-	AUTO_DBG_STOP 		= 0,
-	AUTO_DBG_CHECK_HANG 	= 1,
+enum auto_dbg_type_e {
+	AUTO_DBG_STOP		= 0,
+	AUTO_DBG_CHECK_HANG	= 1,
 	AUTO_DBG_CHECK_RA	= 2,
-	AUTO_DBG_CHECK_DIG	= 3	
+	AUTO_DBG_CHECK_DIG	= 3
 };
 
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  structure
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
 struct n_dbgport_803 {
-	/*BYTE 3*/
-	u8 bb_rst_b: 1;
-	u8 glb_rst_b: 1;
-	u8 zero_1bit_1:1;
-	u8 ofdm_rst_b: 1;
-	u8 cck_txpe: 1;
-	u8 ofdm_txpe: 1;
-	u8 phy_tx_on: 1;
-	u8 tdrdy: 1;
-	/*BYTE 2*/
-	u8 txd:8;
-	/*BYTE 1*/
-	u8 cck_cca_pp: 1; 
-	u8 ofdm_cca_pp: 1;
-	u8 rx_rst: 1;
-	u8 rdrdy: 1;
-	u8 rxd_7_4: 4;
-	/*BYTE 0*/
-	u8 rxd_3_0: 4;
-	u8 ofdm_tx_en: 1; 
-	u8 cck_tx_en: 1;
-	u8 zero_1bit_2:1;
-	u8 clk_80m: 1;
+	/*@BYTE 3*/
+	u8 bb_rst_b : 1;
+	u8 glb_rst_b : 1;
+	u8 zero_1bit_1 : 1;
+	u8 ofdm_rst_b : 1;
+	u8 cck_txpe : 1;
+	u8 ofdm_txpe : 1;
+	u8 phy_tx_on : 1;
+	u8 tdrdy : 1;
+	/*@BYTE 2*/
+	u8 txd : 8;
+	/*@BYTE 1*/
+	u8 cck_cca_pp : 1;
+	u8 ofdm_cca_pp : 1;
+	u8 rx_rst : 1;
+	u8 rdrdy : 1;
+	u8 rxd_7_4 : 4;
+	/*@BYTE 0*/
+	u8 rxd_3_0 : 4;
+	u8 ofdm_tx_en : 1;
+	u8 cck_tx_en : 1;
+	u8 zero_1bit_2 : 1;
+	u8 clk_80m : 1;
 };
 
-struct phydm_auto_dbg_struc {
-
-	enum	auto_dbg_type_e	auto_dbg_type;
-	u8		dbg_step;
-	u16		dbg_port_table[DBGPORT_CHK_NUM];
-	u32		dbg_port_val[DBGPORT_CHK_NUM];
-	u16		ofdm_t_cnt;
-	u16		ofdm_r_cnt;
-	u16		cck_t_cnt;
-	u16		cck_r_cnt;
-	u16		ofdm_crc_error_cnt;
-	u16		cck_crc_error_cnt;
-
+struct phydm_auto_dbg_struct {
+	enum auto_dbg_type_e auto_dbg_type;
+	u8 dbg_step;
+	u16 dbg_port_table[DBGPORT_CHK_NUM];
+	u32 dbg_port_val[DBGPORT_CHK_NUM];
+	u16 ofdm_t_cnt;
+	u16 ofdm_r_cnt;
+	u16 cck_t_cnt;
+	u16 cck_r_cnt;
+	u16 ofdm_crc_error_cnt;
+	u16 cck_crc_error_cnt;
 };
 
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  function prototype
- * 1 ============================================================ */
-
+ * 1 ============================================================
+ */
 
-void
-phydm_auto_dbg_console(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
-#endif
+void phydm_auto_dbg_console(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len);
 
-void
-phydm_auto_dbg_engine(
-	void			*p_dm_void
-);
+void phydm_auto_dbg_engine(void *dm_void);
 
-void
-phydm_auto_dbg_engine_init(
-	void		*p_dm_void
-);
-#endif
\ No newline at end of file
+void phydm_auto_dbg_engine_init(void *dm_void);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.c
index c2a9af56952b..689f63ec9467 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,9 +9,19 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 #include "mp_precomp.h"
@@ -22,119 +33,160 @@
 	#endif
 #endif
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
-struct _RT_BEAMFORM_STAINFO *
-phydm_sta_info_init(
-	struct PHY_DM_STRUCT		*p_dm,
-	u16			sta_idx
-)
+void phydm_get_txbf_device_num(
+	void *dm_void,
+	u8 macid)
 {
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORM_STAINFO		*p_entry = &(p_beam_info->beamform_sta_info);
-	struct sta_info					*p_sta = p_dm->p_odm_sta_info[sta_idx];
-	struct cmn_sta_info				*p_cmn_sta = p_dm->p_phydm_sta_info[sta_idx];
-	struct _ADAPTER					*adapter = p_dm->adapter;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PMGNT_INFO					p_MgntInfo = &adapter->MgntInfo;
-	PRT_HIGH_THROUGHPUT		p_ht_info = GET_HT_INFO(p_MgntInfo);
-	PRT_VERY_HIGH_THROUGHPUT	p_vht_info = GET_VHT_INFO(p_MgntInfo);
-	u1Byte						iotpeer = 0;
-
-	iotpeer = p_MgntInfo->IOTPeer;
-	odm_move_memory(p_dm, p_entry->my_mac_addr, adapter->CurrentAddress, 6);
-
-	p_entry->ht_beamform_cap = p_ht_info->HtBeamformCap;
-	p_entry->vht_beamform_cap = p_vht_info->VhtBeamformCap;
-	
-	/*IBSS, AP mode*/
-	if (sta_idx != 0) {
-		p_entry->aid = p_cmn_sta->aid;
-		p_entry->ra = p_cmn_sta->mac_addr;
-		p_entry->mac_id = p_cmn_sta->mac_id;
-		p_entry->wireless_mode = p_sta->WirelessMode;
-		p_entry->bw = p_cmn_sta->bw_mode;
-		p_entry->cur_beamform = p_cmn_sta->bf_info.ht_beamform_cap;
-	} else {/*client mode*/
-		p_entry->aid = p_MgntInfo->mAId;
-		p_entry->ra = p_MgntInfo->Bssid;
-		p_entry->mac_id = p_MgntInfo->mMacId;
-		p_entry->wireless_mode = p_MgntInfo->dot11CurrentWirelessMode;
-		p_entry->bw = p_MgntInfo->dot11CurrentChannelBandWidth;
-		p_entry->cur_beamform = p_ht_info->HtCurBeamform;
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*@For BDC*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[macid];
+	struct bf_cmn_info *bf = NULL;
+	struct _BF_DIV_COEX_ *dm_bdc_table = &dm->dm_bdc_table;
+	u8 act_as_bfer = 0;
+	u8 act_as_bfee = 0;
+
+	if (is_sta_active(sta)) {
+		bf = &(sta->bf_info);
+	} else {
+		PHYDM_DBG(dm, DBG_TXBF, "[Warning] %s invalid sta_info\n",
+			  __func__);
+		return;
 	}
 
-	if ((p_entry->wireless_mode & WIRELESS_MODE_AC_5G) || (p_entry->wireless_mode & WIRELESS_MODE_AC_24G)) {
-		if (sta_idx != 0)
-			p_entry->cur_beamform_vht = p_cmn_sta->bf_info.vht_beamform_cap;
-		else
-			p_entry->cur_beamform_vht = p_vht_info->VhtCurBeamform;
+	if (sta->support_wireless_set & WIRELESS_VHT) {
+		if (bf->vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMEE_ENABLE)
+			act_as_bfer = 1;
+
+		if (bf->vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMER_ENABLE)
+			act_as_bfee = 1;
+
+	} else if (sta->support_wireless_set & WIRELESS_HT) {
+		if (bf->ht_beamform_cap & BEAMFORMING_HT_BEAMFORMEE_ENABLE)
+			act_as_bfer = 1;
+
+		if (bf->ht_beamform_cap & BEAMFORMING_HT_BEAMFORMER_ENABLE)
+			act_as_bfee = 1;
 	}
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("p_sta->wireless_mode = 0x%x, staidx = %d\n", p_sta->WirelessMode, sta_idx));
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	if (act_as_bfer))
+		{ /* Our Device act as BFer */
+			dm_bdc_table->w_bfee_client[macid] = true;
+			dm_bdc_table->num_txbfee_client++;
+		}
+	else
+		dm_bdc_table->w_bfee_client[macid] = false;
 
-	if (!is_sta_active(p_cmn_sta)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s => sta_info(mac_id:%d) failed\n", __func__, sta_idx));
+	if (act_as_bfee))
+		{ /* Our Device act as BFee */
+			dm_bdc_table->w_bfer_client[macid] = true;
+			dm_bdc_table->num_txbfer_client++;
+		}
+	else
+		dm_bdc_table->w_bfer_client[macid] = false;
+
+#endif
+#endif
+}
+
+struct _RT_BEAMFORM_STAINFO *
+phydm_sta_info_init(struct dm_struct *dm, u16 sta_idx, u8 *my_mac_addr)
+{
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORM_STAINFO *entry = &beam_info->beamform_sta_info;
+	struct cmn_sta_info *cmn_sta = dm->phydm_sta_info[sta_idx];
+	//void					*adapter = dm->adapter;
+	ADAPTER * adapter = dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	PMGNT_INFO p_MgntInfo = &((adapter)->MgntInfo);
+	PRT_HIGH_THROUGHPUT p_ht_info = GET_HT_INFO(p_MgntInfo);
+	PRT_VERY_HIGH_THROUGHPUT p_vht_info = GET_VHT_INFO(p_MgntInfo);
+#endif
+
+	if (!is_sta_active(cmn_sta)) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s => sta_info(mac_id:%d) failed\n",
+			  __func__, sta_idx);
+		#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
 		rtw_warn_on(1);
-		return p_entry;
+		#endif
+
+		return entry;
 	}
 
-	odm_move_memory(p_dm, p_entry->my_mac_addr, adapter_mac_addr(p_sta->padapter), 6);
-	#ifdef CONFIG_80211N_HT
-	p_entry->ht_beamform_cap = p_cmn_sta->bf_info.ht_beamform_cap;
-	#endif
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	/*odm_move_memory(dm, (PVOID)(entry->my_mac_addr),*/
+	/*(PVOID)(adapter->CurrentAddress), 6);*/
+	odm_move_memory(dm, entry->my_mac_addr, my_mac_addr, 6);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	/*odm_move_memory(dm, entry->my_mac_addr,*/
+	/*adapter_mac_addr(sta->padapter), 6);*/
+	odm_move_memory(dm, entry->my_mac_addr, my_mac_addr, 6);
+#endif
 
-	p_entry->aid = p_cmn_sta->aid;
-	p_entry->ra = p_cmn_sta->mac_addr;
-	p_entry->mac_id = p_cmn_sta->mac_id;
-	p_entry->wireless_mode = p_sta->wireless_mode;
-	p_entry->bw = p_cmn_sta->bw_mode;
-	#ifdef CONFIG_80211N_HT
-	p_entry->cur_beamform = p_cmn_sta->bf_info.ht_beamform_cap;
-	#endif
-#if	ODM_IC_11AC_SERIES_SUPPORT
-	if ((p_entry->wireless_mode & WIRELESS_MODE_AC_5G) || (p_entry->wireless_mode & WIRELESS_MODE_AC_24G)) {
-		p_entry->cur_beamform_vht = p_cmn_sta->bf_info.vht_beamform_cap;
-		p_entry->vht_beamform_cap = p_cmn_sta->bf_info.vht_beamform_cap;
+	entry->aid = cmn_sta->aid;
+	entry->ra = cmn_sta->mac_addr;
+	entry->mac_id = cmn_sta->mac_id;
+	entry->bw = cmn_sta->bw_mode;
+	entry->cur_beamform = cmn_sta->bf_info.ht_beamform_cap;
+	entry->ht_beamform_cap = cmn_sta->bf_info.ht_beamform_cap;
+
+#if ODM_IC_11AC_SERIES_SUPPORT
+	if (cmn_sta->support_wireless_set & WIRELESS_VHT) {
+		entry->cur_beamform_vht = cmn_sta->bf_info.vht_beamform_cap;
+		entry->vht_beamform_cap = cmn_sta->bf_info.vht_beamform_cap;
 	}
 #endif
-	PHYDM_DBG(p_dm, DBG_TXBF, ("p_sta->wireless_mode = 0x%x, staidx = %d\n", p_sta->wireless_mode, sta_idx));
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) /*To Be Removed */
+	entry->ht_beamform_cap = p_ht_info->HtBeamformCap; /*To Be Removed*/
+	entry->vht_beamform_cap = p_vht_info->VhtBeamformCap; /*To Be Removed*/
+
+	if (sta_idx == 0) { /*@client mode*/
+		#if ODM_IC_11AC_SERIES_SUPPORT
+		if (cmn_sta->support_wireless_set & WIRELESS_VHT)
+			entry->cur_beamform_vht = p_vht_info->VhtCurBeamform;
+		#endif
+	}
 #endif
-	PHYDM_DBG(p_dm, DBG_TXBF, ("p_entry->cur_beamform = 0x%x, p_entry->cur_beamform_vht = 0x%x\n", p_entry->cur_beamform, p_entry->cur_beamform_vht));
-	return p_entry;
 
+	PHYDM_DBG(dm, DBG_TXBF, "wireless_set = 0x%x, staidx = %d\n",
+		  cmn_sta->support_wireless_set, sta_idx);
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "entry->cur_beamform = 0x%x, entry->cur_beamform_vht = 0x%x\n",
+		  entry->cur_beamform, entry->cur_beamform_vht);
+	return entry;
 }
 void phydm_sta_info_update(
-	struct PHY_DM_STRUCT			*p_dm,
-	u16				sta_idx,
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry
-)
+	struct dm_struct *dm,
+	u16 sta_idx,
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry)
 {
-	struct cmn_sta_info *p_sta = p_dm->p_phydm_sta_info[sta_idx];
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
 
-	if (!is_sta_active(p_sta))
+	if (!is_sta_active(sta))
 		return;
 
-	p_sta->bf_info.p_aid = p_beamform_entry->p_aid;
-	p_sta->bf_info.g_id = p_beamform_entry->g_id;
+	sta->bf_info.p_aid = beamform_entry->p_aid;
+	sta->bf_info.g_id = beamform_entry->g_id;
 }
 
 struct _RT_BEAMFORMEE_ENTRY *
 phydm_beamforming_get_bfee_entry_by_addr(
-	void		*p_dm_void,
-	u8		*RA,
-	u8		*idx
-)
+	void *dm_void,
+	u8 *RA,
+	u8 *idx)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	i = 0;
-	struct _RT_BEAMFORMING_INFO *p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (p_beam_info->beamformee_entry[i].is_used && (eq_mac_addr(RA, p_beam_info->beamformee_entry[i].mac_addr))) {
+		if (beam_info->beamformee_entry[i].is_used && (eq_mac_addr(RA, beam_info->beamformee_entry[i].mac_addr))) {
 			*idx = i;
-			return &(p_beam_info->beamformee_entry[i]);
+			return &beam_info->beamformee_entry[i];
 		}
 	}
 
@@ -143,62 +195,57 @@ phydm_beamforming_get_bfee_entry_by_addr(
 
 struct _RT_BEAMFORMER_ENTRY *
 phydm_beamforming_get_bfer_entry_by_addr(
-	void	*p_dm_void,
-	u8	*TA,
-	u8	*idx
-)
+	void *dm_void,
+	u8 *TA,
+	u8 *idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		i = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
-		if (p_beam_info->beamformer_entry[i].is_used && (eq_mac_addr(TA, p_beam_info->beamformer_entry[i].mac_addr))) {
+		if (beam_info->beamformer_entry[i].is_used && (eq_mac_addr(TA, beam_info->beamformer_entry[i].mac_addr))) {
 			*idx = i;
-			return &(p_beam_info->beamformer_entry[i]);
+			return &beam_info->beamformer_entry[i];
 		}
 	}
 
 	return NULL;
 }
 
-
 struct _RT_BEAMFORMEE_ENTRY *
 phydm_beamforming_get_entry_by_mac_id(
-	void		*p_dm_void,
-	u8		mac_id,
-	u8		*idx
-)
+	void *dm_void,
+	u8 mac_id,
+	u8 *idx)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	i = 0;
-	struct _RT_BEAMFORMING_INFO *p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (p_beam_info->beamformee_entry[i].is_used && (mac_id == p_beam_info->beamformee_entry[i].mac_id)) {
+		if (beam_info->beamformee_entry[i].is_used && mac_id == beam_info->beamformee_entry[i].mac_id) {
 			*idx = i;
-			return &(p_beam_info->beamformee_entry[i]);
+			return &beam_info->beamformee_entry[i];
 		}
 	}
 
 	return NULL;
 }
 
-
 enum beamforming_cap
 phydm_beamforming_get_entry_beam_cap_by_mac_id(
-	void		*p_dm_void,
-	u8		mac_id
-)
+	void *dm_void,
+	u8 mac_id)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	i = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	enum beamforming_cap			beamform_entry_cap = BEAMFORMING_CAP_NONE;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	enum beamforming_cap beamform_entry_cap = BEAMFORMING_CAP_NONE;
 
 	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (p_beam_info->beamformee_entry[i].is_used && (mac_id == p_beam_info->beamformee_entry[i].mac_id)) {
-			beamform_entry_cap =  p_beam_info->beamformee_entry[i].beamform_entry_cap;
+		if (beam_info->beamformee_entry[i].is_used && mac_id == beam_info->beamformee_entry[i].mac_id) {
+			beamform_entry_cap = beam_info->beamformee_entry[i].beamform_entry_cap;
 			i = BEAMFORMEE_ENTRY_NUM;
 		}
 	}
@@ -206,21 +253,19 @@ phydm_beamforming_get_entry_beam_cap_by_mac_id(
 	return beamform_entry_cap;
 }
 
-
 struct _RT_BEAMFORMEE_ENTRY *
 phydm_beamforming_get_free_bfee_entry(
-	void		*p_dm_void,
-	u8		*idx
-)
+	void *dm_void,
+	u8 *idx)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	i = 0;
-	struct _RT_BEAMFORMING_INFO *p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		if (p_beam_info->beamformee_entry[i].is_used == false) {
+		if (beam_info->beamformee_entry[i].is_used == false) {
 			*idx = i;
-			return &(p_beam_info->beamformee_entry[i]);
+			return &beam_info->beamformee_entry[i];
 		}
 	}
 	return NULL;
@@ -228,26 +273,25 @@ phydm_beamforming_get_free_bfee_entry(
 
 struct _RT_BEAMFORMER_ENTRY *
 phydm_beamforming_get_free_bfer_entry(
-	void		*p_dm_void,
-	u8		*idx
-)
+	void *dm_void,
+	u8 *idx)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	i = 0;
-	struct _RT_BEAMFORMING_INFO *p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s ===>\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s ===>\n", __func__);
 
 	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
-		if (p_beam_info->beamformer_entry[i].is_used == false) {
+		if (beam_info->beamformer_entry[i].is_used == false) {
 			*idx = i;
-			return &(p_beam_info->beamformer_entry[i]);
+			return &beam_info->beamformer_entry[i];
 		}
 	}
 	return NULL;
 }
 
-/*
+/*@
  * Description: Get the first entry index of MU Beamformee.
  *
  * Return value: index of the first MU sta.
@@ -255,19 +299,18 @@ phydm_beamforming_get_free_bfer_entry(
  * 2015.05.25. Created by tynli.
  *
  */
-u8
-phydm_beamforming_get_first_mu_bfee_entry_idx(
-	void		*p_dm_void
-)
+u8 phydm_beamforming_get_first_mu_bfee_entry_idx(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8					idx = 0xFF;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	boolean					is_found = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 idx = 0xFF;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	boolean is_found = false;
 
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		if (p_beam_info->beamformee_entry[idx].is_used && p_beam_info->beamformee_entry[idx].is_mu_sta) {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] idx=%d!\n", __func__, idx));
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].is_mu_sta) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] idx=%d!\n", __func__,
+				  idx);
 			is_found = true;
 			break;
 		}
@@ -279,137 +322,141 @@ phydm_beamforming_get_first_mu_bfee_entry_idx(
 	return idx;
 }
 
-
-/*Add SU BFee and MU BFee*/
+/*@Add SU BFee and MU BFee*/
 struct _RT_BEAMFORMEE_ENTRY *
 beamforming_add_bfee_entry(
-	void					*p_dm_void,
-	struct _RT_BEAMFORM_STAINFO	*p_sta,
-	enum beamforming_cap		beamform_cap,
-	u8					num_of_sounding_dim,
-	u8					comp_steering_num_of_bfer,
-	u8					*idx
-)
+	void *dm_void,
+	struct _RT_BEAMFORM_STAINFO *sta,
+	enum beamforming_cap beamform_cap,
+	u8 num_of_sounding_dim,
+	u8 comp_steering_num_of_bfer,
+	u8 *idx)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry = phydm_beamforming_get_free_bfee_entry(p_dm, idx);
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
-
-	if (p_entry != NULL) {
-		p_entry->is_used = true;
-		p_entry->aid = p_sta->aid;
-		p_entry->mac_id = p_sta->mac_id;
-		p_entry->sound_bw = p_sta->bw;
-		odm_move_memory(p_dm, p_entry->my_mac_addr, p_sta->my_mac_addr, 6);
-
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ap)) {
-			/*BSSID[44:47] xor BSSID[40:43]*/
-			u16 bssid = ((p_sta->my_mac_addr[5] & 0xf0) >> 4) ^ (p_sta->my_mac_addr[5] & 0xf);
-			/*(dec(A) + dec(B)*32) mod 512*/
-			p_entry->p_aid = (p_sta->aid + bssid * 32) & 0x1ff;
-			p_entry->g_id = 63;
-			PHYDM_DBG(p_dm, DBG_TXBF, ("%s: BFee P_AID addressed to STA=%d\n", __func__, p_entry->p_aid));
-		} else if (phydm_acting_determine(p_dm, phydm_acting_as_ibss)) {
-			/*ad hoc mode*/
-			p_entry->p_aid = 0;
-			p_entry->g_id = 63;
-			PHYDM_DBG(p_dm, DBG_TXBF, ("%s: BFee P_AID as IBSS=%d\n", __func__, p_entry->p_aid));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY *entry = phydm_beamforming_get_free_bfee_entry(dm, idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (entry != NULL) {
+		entry->is_used = true;
+		entry->aid = sta->aid;
+		entry->mac_id = sta->mac_id;
+		entry->sound_bw = sta->bw;
+		odm_move_memory(dm, entry->my_mac_addr, sta->my_mac_addr, 6);
+
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) {
+			/*@BSSID[44:47] xor BSSID[40:43]*/
+			u16 bssid = ((sta->my_mac_addr[5] & 0xf0) >> 4) ^ (sta->my_mac_addr[5] & 0xf);
+			/*@(dec(A) + dec(B)*32) mod 512*/
+			entry->p_aid = (sta->aid + bssid * 32) & 0x1ff;
+			entry->g_id = 63;
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "%s: BFee P_AID addressed to STA=%d\n",
+				  __func__, entry->p_aid);
+		} else if (phydm_acting_determine(dm, phydm_acting_as_ibss)) {
+			/*@ad hoc mode*/
+			entry->p_aid = 0;
+			entry->g_id = 63;
+			PHYDM_DBG(dm, DBG_TXBF, "%s: BFee P_AID as IBSS=%d\n",
+				  __func__, entry->p_aid);
 		} else {
-			/*client mode*/
-			p_entry->p_aid =  p_sta->ra[5];
-			/*BSSID[39:47]*/
-			p_entry->p_aid = (p_entry->p_aid << 1) | (p_sta->ra[4] >> 7);
-			p_entry->g_id = 0;
-			PHYDM_DBG(p_dm, DBG_TXBF, ("%s: BFee P_AID addressed to AP=0x%X\n", __func__, p_entry->p_aid));
+			/*@client mode*/
+			entry->p_aid = sta->ra[5];
+			/*@BSSID[39:47]*/
+			entry->p_aid = (entry->p_aid << 1) | (sta->ra[4] >> 7);
+			entry->g_id = 0;
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "%s: BFee P_AID addressed to AP=0x%X\n",
+				  __func__, entry->p_aid);
 		}
-		cp_mac_addr(p_entry->mac_addr, p_sta->ra);
-		p_entry->is_txbf = false;
-		p_entry->is_sound = false;
-		p_entry->sound_period = 400;
-		p_entry->beamform_entry_cap = beamform_cap;
-		p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		cp_mac_addr(entry->mac_addr, sta->ra);
+		entry->is_txbf = false;
+		entry->is_sound = false;
+		entry->sound_period = 400;
+		entry->beamform_entry_cap = beamform_cap;
+		entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
 
-		/*		p_entry->log_seq = 0xff;				Move to beamforming_add_bfer_entry*/
-		/*		p_entry->log_retry_cnt = 0;			Move to beamforming_add_bfer_entry*/
-		/*		p_entry->LogSuccessCnt = 0;		Move to beamforming_add_bfer_entry*/
+		/*		@entry->log_seq = 0xff;				Move to beamforming_add_bfer_entry*/
+		/*		@entry->log_retry_cnt = 0;			Move to beamforming_add_bfer_entry*/
+		/*		@entry->LogSuccessCnt = 0;		Move to beamforming_add_bfer_entry*/
 
-		p_entry->log_status_fail_cnt = 0;
+		entry->log_status_fail_cnt = 0;
 
-		p_entry->num_of_sounding_dim = num_of_sounding_dim;
-		p_entry->comp_steering_num_of_bfer = comp_steering_num_of_bfer;
+		entry->num_of_sounding_dim = num_of_sounding_dim;
+		entry->comp_steering_num_of_bfer = comp_steering_num_of_bfer;
 
 		if (beamform_cap & BEAMFORMER_CAP_VHT_MU) {
-			p_dm->beamforming_info.beamformee_mu_cnt += 1;
-			p_entry->is_mu_sta = true;
-			p_dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(p_dm);
+			dm->beamforming_info.beamformee_mu_cnt += 1;
+			entry->is_mu_sta = true;
+			dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(dm);
 		} else if (beamform_cap & (BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP_HT_EXPLICIT)) {
-			p_dm->beamforming_info.beamformee_su_cnt += 1;
-			p_entry->is_mu_sta = false;
+			dm->beamforming_info.beamformee_su_cnt += 1;
+			entry->is_mu_sta = false;
 		}
 
-		return p_entry;
+		return entry;
 	} else
 		return NULL;
 }
 
-/*Add SU BFee and MU BFer*/
+/*@Add SU BFee and MU BFer*/
 struct _RT_BEAMFORMER_ENTRY *
 beamforming_add_bfer_entry(
-	void					*p_dm_void,
-	struct _RT_BEAMFORM_STAINFO	*p_sta,
-	enum beamforming_cap		beamform_cap,
-	u8					num_of_sounding_dim,
-	u8					*idx
-)
+	void *dm_void,
+	struct _RT_BEAMFORM_STAINFO *sta,
+	enum beamforming_cap beamform_cap,
+	u8 num_of_sounding_dim,
+	u8 *idx)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMER_ENTRY	*p_entry = phydm_beamforming_get_free_bfer_entry(p_dm, idx);
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
-
-	if (p_entry != NULL) {
-		p_entry->is_used = true;
-		odm_move_memory(p_dm, p_entry->my_mac_addr, p_sta->my_mac_addr, 6);
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ap)) {
-			/*BSSID[44:47] xor BSSID[40:43]*/
-			u16 bssid = ((p_sta->my_mac_addr[5] & 0xf0) >> 4) ^ (p_sta->my_mac_addr[5] & 0xf);
-
-			p_entry->p_aid = (p_sta->aid + bssid * 32) & 0x1ff;
-			p_entry->g_id = 63;
-			/*(dec(A) + dec(B)*32) mod 512*/
-		} else if (phydm_acting_determine(p_dm, phydm_acting_as_ibss)) {
-			p_entry->p_aid = 0;
-			p_entry->g_id = 63;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMER_ENTRY *entry = phydm_beamforming_get_free_bfer_entry(dm, idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+
+	if (entry != NULL) {
+		entry->is_used = true;
+		odm_move_memory(dm, entry->my_mac_addr, sta->my_mac_addr, 6);
+		if (phydm_acting_determine(dm, phydm_acting_as_ap)) {
+			/*@BSSID[44:47] xor BSSID[40:43]*/
+			u16 bssid = ((sta->my_mac_addr[5] & 0xf0) >> 4) ^ (sta->my_mac_addr[5] & 0xf);
+
+			entry->p_aid = (sta->aid + bssid * 32) & 0x1ff;
+			entry->g_id = 63;
+			/*@(dec(A) + dec(B)*32) mod 512*/
+		} else if (phydm_acting_determine(dm, phydm_acting_as_ibss)) {
+			entry->p_aid = 0;
+			entry->g_id = 63;
 		} else {
-			p_entry->p_aid =  p_sta->ra[5];
-			/*BSSID[39:47]*/
-			p_entry->p_aid = (p_entry->p_aid << 1) | (p_sta->ra[4] >> 7);
-			p_entry->g_id = 0;
-			PHYDM_DBG(p_dm, DBG_TXBF, ("%s: P_AID addressed to AP=0x%X\n", __func__, p_entry->p_aid));
+			entry->p_aid = sta->ra[5];
+			/*@BSSID[39:47]*/
+			entry->p_aid = (entry->p_aid << 1) | (sta->ra[4] >> 7);
+			entry->g_id = 0;
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "%s: P_AID addressed to AP=0x%X\n", __func__,
+				  entry->p_aid);
 		}
 
-		cp_mac_addr(p_entry->mac_addr, p_sta->ra);
-		p_entry->beamform_entry_cap = beamform_cap;
+		cp_mac_addr(entry->mac_addr, sta->ra);
+		entry->beamform_entry_cap = beamform_cap;
 
-		p_entry->pre_log_seq = 0;	/*Modified by Jeffery @2015-04-13*/
-		p_entry->log_seq = 0;		/*Modified by Jeffery @2014-10-29*/
-		p_entry->log_retry_cnt = 0;	/*Modified by Jeffery @2014-10-29*/
-		p_entry->log_success = 0;	/*log_success is NOT needed to be accumulated, so  LogSuccessCnt->log_success, 2015-04-13, Jeffery*/
-		p_entry->clock_reset_times = 0;	/*Modified by Jeffery @2015-04-13*/
+		entry->pre_log_seq = 0; /*@Modified by Jeffery @2015-04-13*/
+		entry->log_seq = 0; /*@Modified by Jeffery @2014-10-29*/
+		entry->log_retry_cnt = 0; /*@Modified by Jeffery @2014-10-29*/
+		entry->log_success = 0; /*@log_success is NOT needed to be accumulated, so  LogSuccessCnt->log_success, 2015-04-13, Jeffery*/
+		entry->clock_reset_times = 0; /*@Modified by Jeffery @2015-04-13*/
 
-		p_entry->num_of_sounding_dim = num_of_sounding_dim;
+		entry->num_of_sounding_dim = num_of_sounding_dim;
 
 		if (beamform_cap & BEAMFORMEE_CAP_VHT_MU) {
-			p_dm->beamforming_info.beamformer_mu_cnt += 1;
-			p_entry->is_mu_ap = true;
-			p_entry->aid = p_sta->aid;
+			dm->beamforming_info.beamformer_mu_cnt += 1;
+			entry->is_mu_ap = true;
+			entry->aid = sta->aid;
 		} else if (beamform_cap & (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP_HT_EXPLICIT)) {
-			p_dm->beamforming_info.beamformer_su_cnt += 1;
-			p_entry->is_mu_ap = false;
+			dm->beamforming_info.beamformer_su_cnt += 1;
+			entry->is_mu_ap = false;
 		}
 
-		return p_entry;
+		return entry;
 	} else
 		return NULL;
 }
@@ -417,54 +464,51 @@ beamforming_add_bfer_entry(
 #if 0
 boolean
 beamforming_remove_entry(
-	struct _ADAPTER			*adapter,
+	void			*adapter,
 	u8		*RA,
 	u8		*idx
 )
 {
-	HAL_DATA_TYPE			*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT				*p_dm = &p_hal_data->DM_OutSrc;
+	HAL_DATA_TYPE			*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct				*dm = &hal_data->DM_OutSrc;
 
-	struct _RT_BEAMFORMER_ENTRY	*p_bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(p_dm, RA, idx);
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, idx);
+	struct _RT_BEAMFORMER_ENTRY	*bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, RA, idx);
+	struct _RT_BEAMFORMEE_ENTRY	*entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, idx);
 	boolean ret = false;
 
 	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s Start!\n", __func__));
-	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, p_bfer_entry=0x%x\n", __func__, p_bfer_entry));
-	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, p_entry=0x%x\n", __func__, p_entry));
-
-	if (p_entry != NULL) {
-		p_entry->is_used = false;
-		p_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
-		/*p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;*/
-		p_entry->is_beamforming_in_progress = false;
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, bfer_entry=0x%x\n", __func__, bfer_entry));
+	RT_DISP(FBEAM, FBEAM_FUN, ("[Beamforming]@%s, entry=0x%x\n", __func__, entry));
+
+	if (entry != NULL) {
+		entry->is_used = false;
+		entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		/*@entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;*/
+		entry->is_beamforming_in_progress = false;
 		ret = true;
 	}
-	if (p_bfer_entry != NULL) {
-		p_bfer_entry->is_used = false;
-		p_bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+	if (bfer_entry != NULL) {
+		bfer_entry->is_used = false;
+		bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
 		ret = true;
 	}
 	return ret;
-
 }
 #endif
 
 /* Used for beamforming_start_v1 */
-void
-phydm_beamforming_ndpa_rate(
-	void		*p_dm_void,
-	enum channel_width	BW,
-	u8			rate
-)
+void phydm_beamforming_ndpa_rate(
+	void *dm_void,
+	enum channel_width BW,
+	u8 rate)
 {
-	u16			ndpa_rate = rate;
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u16 ndpa_rate = rate;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
 	if (ndpa_rate == 0) {
-		if (p_dm->rssi_min > 30) /* link RSSI > 30% */
+		if (dm->rssi_min > 30) /* @link RSSI > 30% */
 			ndpa_rate = ODM_RATE24M;
 		else
 			ndpa_rate = ODM_RATE6M;
@@ -474,219 +518,213 @@ phydm_beamforming_ndpa_rate(
 		BW = (enum channel_width)CHANNEL_WIDTH_20;
 
 	ndpa_rate = (ndpa_rate << 8) | BW;
-	hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
-
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
 }
 
-
 /* Used for beamforming_start_sw and  beamforming_start_fw */
-void
-phydm_beamforming_dym_ndpa_rate(
-	void		*p_dm_void
-)
+void phydm_beamforming_dym_ndpa_rate(
+	void *dm_void)
 {
-	u16			ndpa_rate = ODM_RATE6M, BW;
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u16 ndpa_rate = ODM_RATE6M, BW;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	ndpa_rate = ODM_RATE6M;
 	BW = CHANNEL_WIDTH_20;
 
 	ndpa_rate = ndpa_rate << 8 | BW;
-	hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s End, NDPA rate = 0x%X\n", __func__, ndpa_rate));
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_RATE, (u8 *)&ndpa_rate);
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, NDPA rate = 0x%X\n", __func__,
+		  ndpa_rate);
 }
 
-/*
+/*@
 *	SW Sounding : SW Timer unit 1ms
 *				 HW Timer unit (1/32000) s  32k is clock.
 *	FW Sounding : FW Timer unit 10ms
 */
-void
-beamforming_dym_period(
-	void		*p_dm_void,
-	u8          status
-)
+void beamforming_dym_period(
+	void *dm_void,
+	u8 status)
 {
-	u8					idx;
-	boolean					is_change_period = false;
-	u16					sound_period_sw, sound_period_fw;
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u8 idx;
+	boolean is_change_period = false;
+	u16 sound_period_sw, sound_period_fw;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_SOUNDING_INFO		*p_sound_info = &(p_beam_info->sounding_info);
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO *sound_info = &beam_info->sounding_info;
 
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry = &(p_beam_info->beamformee_entry[p_beam_info->beamformee_cur_idx]);
+	struct _RT_BEAMFORMEE_ENTRY *entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	/* 3 TODO  per-client throughput caculation. */
+	/* @3 TODO  per-client throughput caculation. */
 
-	if ((*(p_dm->p_current_tx_tp) + *(p_dm->p_current_rx_tp) > 2) && ((p_entry->log_status_fail_cnt <= 20) || status)) {
-		sound_period_sw = 40;	/* 40ms */
-		sound_period_fw = 40;	/* From  H2C cmd, unit = 10ms */
+	if ((*dm->current_tx_tp + *dm->current_rx_tp > 2) && (entry->log_status_fail_cnt <= 20 || status)) {
+		sound_period_sw = 40; /* @40ms */
+		sound_period_fw = 40; /* @From  H2C cmd, unit = 10ms */
 	} else {
-		sound_period_sw = 4000;/* 4s */
+		sound_period_sw = 4000; /* @4s */
 		sound_period_fw = 400;
 	}
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]sound_period_sw=%d, sound_period_fw=%d\n",	__func__, sound_period_sw, sound_period_fw));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]sound_period_sw=%d, sound_period_fw=%d\n",
+		  __func__, sound_period_sw, sound_period_fw);
 
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		p_beamform_entry = p_beam_info->beamformee_entry + idx;
+		beamform_entry = beam_info->beamformee_entry + idx;
 
-		if (p_beamform_entry->default_csi_cnt > 20) {
-			/*Modified by David*/
+		if (beamform_entry->default_csi_cnt > 20) {
+			/*@Modified by David*/
 			sound_period_sw = 4000;
 			sound_period_fw = 400;
 		}
 
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] period = %d\n", __func__, sound_period_sw));
-		if (p_beamform_entry->beamform_entry_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) {
-			if (p_sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_FW_HT_TIMER) {
-				if (p_beamform_entry->sound_period != sound_period_fw) {
-					p_beamform_entry->sound_period = sound_period_fw;
-					is_change_period = true;		/*Only FW sounding need to send H2C packet to change sound period. */
-				}
-			} else if (p_beamform_entry->sound_period != sound_period_sw)
-				p_beamform_entry->sound_period = sound_period_sw;
-		}
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] period = %d\n", __func__,
+			  sound_period_sw);
+		if ((beamform_entry->beamform_entry_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) == 0)
+			continue;
+
+		if (sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || sound_info->sound_mode == SOUNDING_FW_HT_TIMER) {
+			if (beamform_entry->sound_period != sound_period_fw) {
+				beamform_entry->sound_period = sound_period_fw;
+				is_change_period = true; /*Only FW sounding need to send H2C packet to change sound period. */
+			}
+		} else if (beamform_entry->sound_period != sound_period_sw)
+			beamform_entry->sound_period = sound_period_sw;
 	}
 
 	if (is_change_period)
-		hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
 }
 
-
-
-
 boolean
 beamforming_send_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW,
-	u8			q_idx
-)
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW,
+	u8 q_idx)
 {
-	boolean		ret = true;
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	boolean ret = true;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (q_idx == BEACON_QUEUE)
-		ret = send_fw_ht_ndpa_packet(p_dm, RA, BW);
+		ret = send_fw_ht_ndpa_packet(dm, RA, BW);
 	else
-		ret = send_sw_ht_ndpa_packet(p_dm, RA, BW);
+		ret = send_sw_ht_ndpa_packet(dm, RA, BW);
 
 	return ret;
 }
 
-
-
 boolean
 beamforming_send_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW,
-	u8			q_idx
-)
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW,
+	u8 q_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	boolean					ret = true;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	boolean ret = true;
 
-	hal_com_txbf_set(p_dm, TXBF_SET_GET_TX_RATE, NULL);
+	hal_com_txbf_set(dm, TXBF_SET_GET_TX_RATE, NULL);
 
-	if ((p_beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7) && (p_beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9) && (p_beam_info->snding3ss == false))
-		PHYDM_DBG(p_dm, DBG_TXBF, ("@%s: 3SS VHT 789 don't sounding\n", __func__));
+	if (beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7 && beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9 && !beam_info->snding3ss)
+		PHYDM_DBG(dm, DBG_TXBF, "@%s: 3SS VHT 789 don't sounding\n",
+			  __func__);
 
-	else  {
+	else {
 		if (q_idx == BEACON_QUEUE) /* Send to reserved page => FW NDPA */
-			ret = send_fw_vht_ndpa_packet(p_dm, RA, AID, BW);
+			ret = send_fw_vht_ndpa_packet(dm, RA, AID, BW);
 		else {
 #ifdef SUPPORT_MU_BF
 #if (SUPPORT_MU_BF == 1)
-			p_beam_info->is_mu_sounding = true;
-			ret = send_sw_vht_mu_ndpa_packet(p_dm, BW);
+			beam_info->is_mu_sounding = true;
+			ret = send_sw_vht_mu_ndpa_packet(dm, BW);
 #else
-			p_beam_info->is_mu_sounding = false;
-			ret = send_sw_vht_ndpa_packet(p_dm, RA, AID, BW);
+			beam_info->is_mu_sounding = false;
+			ret = send_sw_vht_ndpa_packet(dm, RA, AID, BW);
 #endif
 #else
-			p_beam_info->is_mu_sounding = false;
-			ret = send_sw_vht_ndpa_packet(p_dm, RA, AID, BW);
+			beam_info->is_mu_sounding = false;
+			ret = send_sw_vht_ndpa_packet(dm, RA, AID, BW);
 #endif
 		}
 	}
 	return ret;
 }
 
-
 enum beamforming_notify_state
 phydm_beamfomring_is_sounding(
-	void				*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info,
-	u8					*idx
-)
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info,
+	u8 *idx)
 {
-	enum beamforming_notify_state	is_sounding = BEAMFORMING_NOTIFY_NONE;
-	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = p_beam_info->beamforming_oid_info;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	enum beamforming_notify_state is_sounding = BEAMFORMING_NOTIFY_NONE;
+	struct _RT_BEAMFORMING_OID_INFO beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	/*if(( Beamforming_GetBeamCap(p_beam_info) & BEAMFORMER_CAP) == 0)*/
-	/*is_sounding = BEAMFORMING_NOTIFY_RESET;*/
-	if (beam_oid_info.sound_oid_mode == sounding_stop_all_timer)
+	/*@if(( Beamforming_GetBeamCap(beam_info) & BEAMFORMER_CAP) == 0)*/
+	/*@is_sounding = BEAMFORMING_NOTIFY_RESET;*/
+	if (beam_oid_info.sound_oid_mode == sounding_stop_all_timer) {
 		is_sounding = BEAMFORMING_NOTIFY_RESET;
-	else {
-		u8 i;
+		goto out;
+	}
 
-		for (i = 0 ; i < BEAMFORMEE_ENTRY_NUM ; i++) {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("@%s: BFee Entry %d is_used=%d, is_sound=%d\n", __func__, i, p_beam_info->beamformee_entry[i].is_used, p_beam_info->beamformee_entry[i].is_sound));
-			if (p_beam_info->beamformee_entry[i].is_used && (!p_beam_info->beamformee_entry[i].is_sound)) {
-				PHYDM_DBG(p_dm, DBG_TXBF, ("%s: Add BFee entry %d\n", __func__, i));
-				*idx = i;
-				if (p_beam_info->beamformee_entry[i].is_mu_sta)
-					is_sounding = BEAMFORMEE_NOTIFY_ADD_MU;
-				else
-					is_sounding = BEAMFORMEE_NOTIFY_ADD_SU;
-			}
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "@%s: BFee Entry %d is_used=%d, is_sound=%d\n",
+			  __func__, i, beam_info->beamformee_entry[i].is_used,
+			  beam_info->beamformee_entry[i].is_sound);
+		if (beam_info->beamformee_entry[i].is_used && !beam_info->beamformee_entry[i].is_sound) {
+			PHYDM_DBG(dm, DBG_TXBF, "%s: Add BFee entry %d\n",
+				  __func__, i);
+			*idx = i;
+			if (beam_info->beamformee_entry[i].is_mu_sta)
+				is_sounding = BEAMFORMEE_NOTIFY_ADD_MU;
+			else
+				is_sounding = BEAMFORMEE_NOTIFY_ADD_SU;
+		}
 
-			if ((!p_beam_info->beamformee_entry[i].is_used) && p_beam_info->beamformee_entry[i].is_sound) {
-				PHYDM_DBG(p_dm, DBG_TXBF, ("%s: Delete BFee entry %d\n", __func__, i));
-				*idx = i;
-				if (p_beam_info->beamformee_entry[i].is_mu_sta)
-					is_sounding = BEAMFORMEE_NOTIFY_DELETE_MU;
-				else
-					is_sounding = BEAMFORMEE_NOTIFY_DELETE_SU;
-			}
+		if (!beam_info->beamformee_entry[i].is_used && beam_info->beamformee_entry[i].is_sound) {
+			PHYDM_DBG(dm, DBG_TXBF, "%s: Delete BFee entry %d\n",
+				  __func__, i);
+			*idx = i;
+			if (beam_info->beamformee_entry[i].is_mu_sta)
+				is_sounding = BEAMFORMEE_NOTIFY_DELETE_MU;
+			else
+				is_sounding = BEAMFORMEE_NOTIFY_DELETE_SU;
 		}
 	}
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s End, is_sounding = %d\n", __func__, is_sounding));
+out:
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, is_sounding = %d\n", __func__,
+		  is_sounding);
 	return is_sounding;
 }
 
-
 /* This function is unused */
-u8
-phydm_beamforming_sounding_idx(
-	void				*p_dm_void,
-	struct _RT_BEAMFORMING_INFO		*p_beam_info
-)
+u8 phydm_beamforming_sounding_idx(
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info)
 {
-	u8					idx = 0;
-	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = p_beam_info->beamforming_oid_info;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u8 idx = 0;
+	struct _RT_BEAMFORMING_OID_INFO beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
 	if (beam_oid_info.sound_oid_mode == SOUNDING_SW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_SW_VHT_TIMER ||
 	    beam_oid_info.sound_oid_mode == SOUNDING_HW_HT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_VHT_TIMER)
 		idx = beam_oid_info.sound_oid_idx;
 	else {
-		u8	i;
+		u8 i;
 		for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-			if (p_beam_info->beamformee_entry[i].is_used && (false == p_beam_info->beamformee_entry[i].is_sound)) {
+			if (beam_info->beamformee_entry[i].is_used && !beam_info->beamformee_entry[i].is_sound) {
 				idx = i;
 				break;
 			}
@@ -696,20 +734,18 @@ phydm_beamforming_sounding_idx(
 	return idx;
 }
 
-
 enum sounding_mode
 phydm_beamforming_sounding_mode(
-	void				*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info,
-	u8					idx
-)
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			support_interface = p_dm->support_interface;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 support_interface = dm->support_interface;
 
-	struct _RT_BEAMFORMEE_ENTRY		beam_entry = p_beam_info->beamformee_entry[idx];
-	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = p_beam_info->beamforming_oid_info;
-	enum sounding_mode				mode = beam_oid_info.sound_oid_mode;
+	struct _RT_BEAMFORMEE_ENTRY beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO beam_oid_info = beam_info->beamforming_oid_info;
+	enum sounding_mode mode = beam_oid_info.sound_oid_mode;
 
 	if (beam_oid_info.sound_oid_mode == SOUNDING_SW_VHT_TIMER || beam_oid_info.sound_oid_mode == SOUNDING_HW_VHT_TIMER) {
 		if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
@@ -722,103 +758,100 @@ phydm_beamforming_sounding_mode(
 		else
 			mode = sounding_stop_all_timer;
 	} else if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_VHT_SU) {
-		if ((support_interface == ODM_ITRF_USB) && !(p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
+		if (support_interface == ODM_ITRF_USB && !(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
 			mode = SOUNDING_FW_VHT_TIMER;
 		else
 			mode = SOUNDING_SW_VHT_TIMER;
 	} else if (beam_entry.beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT) {
-		if ((support_interface == ODM_ITRF_USB) && !(p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
+		if (support_interface == ODM_ITRF_USB && !(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)))
 			mode = SOUNDING_FW_HT_TIMER;
 		else
 			mode = SOUNDING_SW_HT_TIMER;
 	} else
 		mode = sounding_stop_all_timer;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] support_interface=%d, mode=%d\n", __func__, support_interface, mode));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] support_interface=%d, mode=%d\n",
+		  __func__, support_interface, mode);
 
 	return mode;
 }
 
-
-u16
-phydm_beamforming_sounding_time(
-	void				*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info,
-	enum sounding_mode			mode,
-	u8					idx
-)
+u16 phydm_beamforming_sounding_time(
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info,
+	enum sounding_mode mode,
+	u8 idx)
 {
-	u16						sounding_time = 0xffff;
-	struct _RT_BEAMFORMEE_ENTRY		beam_entry = p_beam_info->beamformee_entry[idx];
-	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = p_beam_info->beamforming_oid_info;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u16 sounding_time = 0xffff;
+	struct _RT_BEAMFORMEE_ENTRY beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
 	if (mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_HW_VHT_TIMER)
 		sounding_time = beam_oid_info.sound_oid_period * 32;
 	else if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_SW_VHT_TIMER)
-		/*Modified by David*/
-		sounding_time = beam_entry.sound_period;	/*beam_oid_info.sound_oid_period;*/
+		/*@Modified by David*/
+		sounding_time = beam_entry.sound_period; /*@beam_oid_info.sound_oid_period;*/
 	else
 		sounding_time = beam_entry.sound_period;
 
 	return sounding_time;
 }
 
-
 enum channel_width
 phydm_beamforming_sounding_bw(
-	void				*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info,
-	enum sounding_mode			mode,
-	u8					idx
-)
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info,
+	enum sounding_mode mode,
+	u8 idx)
 {
-	enum channel_width				sounding_bw = CHANNEL_WIDTH_20;
-	struct _RT_BEAMFORMEE_ENTRY		beam_entry = p_beam_info->beamformee_entry[idx];
-	struct _RT_BEAMFORMING_OID_INFO	beam_oid_info = p_beam_info->beamforming_oid_info;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	enum channel_width sounding_bw = CHANNEL_WIDTH_20;
+	struct _RT_BEAMFORMEE_ENTRY beam_entry = beam_info->beamformee_entry[idx];
+	struct _RT_BEAMFORMING_OID_INFO beam_oid_info = beam_info->beamforming_oid_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_HW_VHT_TIMER)
 		sounding_bw = beam_oid_info.sound_oid_bw;
 	else if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_SW_VHT_TIMER)
-		/*Modified by David*/
-		sounding_bw = beam_entry.sound_bw;		/*beam_oid_info.sound_oid_bw;*/
+		/*@Modified by David*/
+		sounding_bw = beam_entry.sound_bw; /*@beam_oid_info.sound_oid_bw;*/
 	else
 		sounding_bw = beam_entry.sound_bw;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s, sounding_bw=0x%X\n", __func__, sounding_bw));
+	PHYDM_DBG(dm, DBG_TXBF, "%s, sounding_bw=0x%X\n", __func__,
+		  sounding_bw);
 
 	return sounding_bw;
 }
 
-
 boolean
 phydm_beamforming_select_beam_entry(
-	void				*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info
-)
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info)
 {
-	struct _RT_SOUNDING_INFO		*p_sound_info = &(p_beam_info->sounding_info);
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct _RT_SOUNDING_INFO *sound_info = &beam_info->sounding_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	/*p_entry.is_sound is different between first and latter NDPA, and should not be used as BFee entry selection*/
-	/*BTW, latter modification should sync to the selection mechanism of AP/ADSL instead of the fixed sound_idx.*/
-	p_sound_info->sound_idx = phydm_beamforming_sounding_idx(p_dm, p_beam_info);
-	/*p_sound_info->sound_idx = 0;*/
+	/*@entry.is_sound is different between first and latter NDPA, and should not be used as BFee entry selection*/
+	/*@BTW, latter modification should sync to the selection mechanism of AP/ADSL instead of the fixed sound_idx.*/
+	sound_info->sound_idx = phydm_beamforming_sounding_idx(dm, beam_info);
+	/*sound_info->sound_idx = 0;*/
 
-	if (p_sound_info->sound_idx < BEAMFORMEE_ENTRY_NUM)
-		p_sound_info->sound_mode = phydm_beamforming_sounding_mode(p_dm, p_beam_info, p_sound_info->sound_idx);
+	if (sound_info->sound_idx < BEAMFORMEE_ENTRY_NUM)
+		sound_info->sound_mode = phydm_beamforming_sounding_mode(dm, beam_info, sound_info->sound_idx);
 	else
-		p_sound_info->sound_mode = sounding_stop_all_timer;
+		sound_info->sound_mode = sounding_stop_all_timer;
 
-	if (sounding_stop_all_timer == p_sound_info->sound_mode) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Return because of sounding_stop_all_timer\n", __func__));
+	if (sounding_stop_all_timer == sound_info->sound_mode) {
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "[%s] Return because of sounding_stop_all_timer\n",
+			  __func__);
 		return false;
 	} else {
-		p_sound_info->sound_bw = phydm_beamforming_sounding_bw(p_dm, p_beam_info, p_sound_info->sound_mode, p_sound_info->sound_idx);
-		p_sound_info->sound_period = phydm_beamforming_sounding_time(p_dm, p_beam_info, p_sound_info->sound_mode, p_sound_info->sound_idx);
+		sound_info->sound_bw = phydm_beamforming_sounding_bw(dm, beam_info, sound_info->sound_mode, sound_info->sound_idx);
+		sound_info->sound_period = phydm_beamforming_sounding_time(dm, beam_info, sound_info->sound_mode, sound_info->sound_idx);
 		return true;
 	}
 }
@@ -826,181 +859,184 @@ phydm_beamforming_select_beam_entry(
 /*SU BFee Entry Only*/
 boolean
 phydm_beamforming_start_period(
-	void				*p_dm_void
-)
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean						ret = true;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_SOUNDING_INFO			*p_sound_info = &(p_beam_info->sounding_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret = true;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO *sound_info = &beam_info->sounding_info;
 
-	phydm_beamforming_dym_ndpa_rate(p_dm);
+	phydm_beamforming_dym_ndpa_rate(dm);
 
-	phydm_beamforming_select_beam_entry(p_dm, p_beam_info);		/* Modified */
+	phydm_beamforming_select_beam_entry(dm, beam_info); /* @Modified */
 
-	if (p_sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
-		odm_set_timer(p_dm, &p_beam_info->beamforming_timer, p_sound_info->sound_period);
-	else if (p_sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
-		p_sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER) {
+	if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+		odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);
+	else if (sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
+		 sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER) {
 		HAL_HW_TIMER_TYPE timer_type = HAL_TIMER_TXBF;
-		u32	val = (p_sound_info->sound_period | (timer_type << 16));
-
-		/* HW timer stop: All IC has the same setting */
-		phydm_set_hw_reg_handler_interface(p_dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
-		/* odm_write_1byte(p_dm, 0x15F, 0); */
-		/* HW timer init: All IC has the same setting, but 92E & 8812A only write 2 bytes */
-		phydm_set_hw_reg_handler_interface(p_dm, HW_VAR_HW_REG_TIMER_INIT, (u8 *)(&val));
-		/* odm_write_1byte(p_dm, 0x164, 1); */
-		/* odm_write_4byte(p_dm, 0x15C, val); */
-		/* HW timer start: All IC has the same setting */
-		phydm_set_hw_reg_handler_interface(p_dm, HW_VAR_HW_REG_TIMER_START, (u8 *)(&timer_type));
-		/* odm_write_1byte(p_dm, 0x15F, 0x5); */
-	} else if (p_sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_FW_HT_TIMER)
-		ret = beamforming_start_fw(p_dm, p_sound_info->sound_idx);
+		u32 val = (sound_info->sound_period | (timer_type << 16));
+
+		/* @HW timer stop: All IC has the same setting */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
+		/* odm_write_1byte(dm, 0x15F, 0); */
+		/* @HW timer init: All IC has the same setting, but 92E & 8812A only write 2 bytes */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_INIT, (u8 *)(&val));
+		/* odm_write_1byte(dm, 0x164, 1); */
+		/* odm_write_4byte(dm, 0x15C, val); */
+		/* @HW timer start: All IC has the same setting */
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_START, (u8 *)(&timer_type));
+		/* odm_write_1byte(dm, 0x15F, 0x5); */
+	} else if (sound_info->sound_mode == SOUNDING_FW_VHT_TIMER || sound_info->sound_mode == SOUNDING_FW_HT_TIMER)
+		ret = beamforming_start_fw(dm, sound_info->sound_idx);
 	else
 		ret = false;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] sound_idx=%d, sound_mode=%d, sound_bw=%d, sound_period=%d\n", __func__,
-		p_sound_info->sound_idx, p_sound_info->sound_mode, p_sound_info->sound_bw, p_sound_info->sound_period));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] sound_idx=%d, sound_mode=%d, sound_bw=%d, sound_period=%d\n",
+		  __func__, sound_info->sound_idx, sound_info->sound_mode,
+		  sound_info->sound_bw, sound_info->sound_period);
 
 	return ret;
 }
 
 /* Used after beamforming_leave, and will clear the setting of the "already deleted" entry
  *SU BFee Entry Only*/
-void
-phydm_beamforming_end_period_sw(
-	void				*p_dm_void
-)
+void phydm_beamforming_end_period_sw(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	/*struct _ADAPTER					*adapter = p_dm->adapter;*/
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_SOUNDING_INFO			*p_sound_info = &(p_beam_info->sounding_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	/*void					*adapter = dm->adapter;*/
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO *sound_info = &beam_info->sounding_info;
 
 	HAL_HW_TIMER_TYPE timer_type = HAL_TIMER_TXBF;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	if (p_sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
-		odm_cancel_timer(p_dm, &p_beam_info->beamforming_timer);
-	else if (p_sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
-		p_sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER)
-		/*HW timer stop: All IC has the same setting*/
-		phydm_set_hw_reg_handler_interface(p_dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
-	/*odm_write_1byte(p_dm, 0x15F, 0);*/
+	if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+		odm_cancel_timer(dm, &beam_info->beamforming_timer);
+	else if (sound_info->sound_mode == SOUNDING_HW_VHT_TIMER || sound_info->sound_mode == SOUNDING_HW_HT_TIMER ||
+		 sound_info->sound_mode == SOUNDING_AUTO_VHT_TIMER || sound_info->sound_mode == SOUNDING_AUTO_HT_TIMER)
+		/*@HW timer stop: All IC has the same setting*/
+		phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_STOP, (u8 *)(&timer_type));
+	/*odm_write_1byte(dm, 0x15F, 0);*/
 }
 
-void
-phydm_beamforming_end_period_fw(
-	void				*p_dm_void
-)
+void phydm_beamforming_end_period_fw(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8				idx = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 idx = 0;
 
-	hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]\n", __func__));
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]\n", __func__);
 }
 
-
 /*SU BFee Entry Only*/
-void
-phydm_beamforming_clear_entry_sw(
-	void			*p_dm_void,
-	boolean				is_delete,
-	u8				delete_idx
-)
+void phydm_beamforming_clear_entry_sw(
+	void *dm_void,
+	boolean is_delete,
+	u8 delete_idx)
 {
-	u8						idx = 0;
-	struct _RT_BEAMFORMEE_ENTRY		*p_beamform_entry = NULL;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
+	u8 idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = NULL;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	if (is_delete) {
 		if (delete_idx < BEAMFORMEE_ENTRY_NUM) {
-			p_beamform_entry = p_beam_info->beamformee_entry + delete_idx;
-			if (!((!p_beamform_entry->is_used) && p_beamform_entry->is_sound)) {
-				PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] SW delete_idx is wrong!!!!!\n", __func__));
+			beamform_entry = beam_info->beamformee_entry + delete_idx;
+			if (!(!beamform_entry->is_used && beamform_entry->is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "[%s] SW delete_idx is wrong!!!!!\n",
+					  __func__);
 				return;
 			}
 		}
 
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] SW delete BFee entry %d\n", __func__, delete_idx));
-		if (p_beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING) {
-			p_beamform_entry->is_beamforming_in_progress = false;
-			p_beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-		} else if (p_beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			p_beamform_entry->beamform_entry_state  = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-			hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&delete_idx);
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] SW delete BFee entry %d\n",
+			  __func__, delete_idx);
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING) {
+			beamform_entry->is_beamforming_in_progress = false;
+			beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		} else if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&delete_idx);
 		}
-		p_beamform_entry->is_sound = false;
-	} else {
-		for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-			p_beamform_entry = p_beam_info->beamformee_entry + idx;
+		beamform_entry->is_sound = false;
+		return;
+	}
 
-			/*Used after is_sounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
-			/*This function is mainly used in case "beam_oid_info.sound_oid_mode == sounding_stop_all_timer".*/
-			/*However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
+	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
+		beamform_entry = beam_info->beamformee_entry + idx;
 
-			if (p_beamform_entry->is_sound) {
-				PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] SW reset BFee entry %d\n", __func__, idx));
-				/*
-				*	If End procedure is
-				*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
-				*	After C2H packet return , status bit will be set to zero.
-				*
-				*	2. After C2H packet, then reset state to initialized and clear status bit.
-				*/
+		/*Used after is_sounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
+		/*This function is mainly used in case "beam_oid_info.sound_oid_mode == sounding_stop_all_timer".*/
+		/*@However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
 
-				if (p_beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-					phydm_beamforming_end_sw(p_dm, 0);
-				else if (p_beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-					p_beamform_entry->beamform_entry_state  = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-					hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
-				}
+		if (!beamform_entry->is_sound)
+			continue;
 
-				p_beamform_entry->is_sound = false;
-			}
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] SW reset BFee entry %d\n",
+			  __func__, idx);
+		/*@
+		*	If End procedure is
+		*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
+		*	After C2H packet return , status bit will be set to zero.
+		*
+		*	2. After C2H packet, then reset state to initialized and clear status bit.
+		*/
+
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
+			phydm_beamforming_end_sw(dm, 0);
+		else if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
 		}
+
+		beamform_entry->is_sound = false;
 	}
 }
 
-void
-phydm_beamforming_clear_entry_fw(
-	void			*p_dm_void,
-	boolean				is_delete,
-	u8				delete_idx
-)
+void phydm_beamforming_clear_entry_fw(
+	void *dm_void,
+	boolean is_delete,
+	u8 delete_idx)
 {
-	u8						idx = 0;
-	struct _RT_BEAMFORMEE_ENTRY		*p_beamform_entry = NULL;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
+	u8 idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = NULL;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	if (is_delete) {
 		if (delete_idx < BEAMFORMEE_ENTRY_NUM) {
-			p_beamform_entry = p_beam_info->beamformee_entry + delete_idx;
+			beamform_entry = beam_info->beamformee_entry + delete_idx;
 
-			if (!((!p_beamform_entry->is_used) && p_beamform_entry->is_sound)) {
-				PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] FW delete_idx is wrong!!!!!\n", __func__));
+			if (!(!beamform_entry->is_used && beamform_entry->is_sound)) {
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "[%s] FW delete_idx is wrong!!!!!\n",
+					  __func__);
 				return;
 			}
 		}
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: FW delete BFee entry %d\n", __func__, delete_idx));
-		p_beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
-		p_beamform_entry->is_sound = false;
+		PHYDM_DBG(dm, DBG_TXBF, "%s: FW delete BFee entry %d\n",
+			  __func__, delete_idx);
+		beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_UNINITIALIZE;
+		beamform_entry->is_sound = false;
 	} else {
 		for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-			p_beamform_entry = p_beam_info->beamformee_entry + idx;
+			beamform_entry = beam_info->beamformee_entry + idx;
 
 			/*Used after is_sounding=RESET, and will clear the setting of "ever sounded" entry, which is not necessarily be deleted.*/
 			/*This function is mainly used in case "beam_oid_info.sound_oid_mode == sounding_stop_all_timer".*/
-			/*However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
+			/*@However, setting oid doesn't delete entries (is_used is still true), new entries may fail to be added in.*/
 
-			if (p_beamform_entry->is_sound) {
-				PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]FW reset BFee entry %d\n", __func__, idx));
-				/*
+			if (beamform_entry->is_sound) {
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "[%s]FW reset BFee entry %d\n",
+					  __func__, idx);
+				/*@
 				*	If End procedure is
 				*	1. Between (Send NDPA, C2H packet return), reset state to initialized.
 				*	After C2H packet return , status bit will be set to zero.
@@ -1008,88 +1044,97 @@ phydm_beamforming_clear_entry_fw(
 				*	2. After C2H packet, then reset state to initialized and clear status bit.
 				*/
 
-				p_beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-				p_beamform_entry->is_sound = false;
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+				beamform_entry->is_sound = false;
 			}
 		}
 	}
 }
 
-/*
+/*@
 *	Called :
 *	1. Add and delete entry : beamforming_enter/beamforming_leave
 *	2. FW trigger :  Beamforming_SetTxBFen
 *	3. Set OID_RT_BEAMFORMING_PERIOD : beamforming_control_v2
 */
-void
-phydm_beamforming_notify(
-	void			*p_dm_void
-)
+void phydm_beamforming_notify(
+	void *dm_void)
 {
-	u8						idx = BEAMFORMEE_ENTRY_NUM;
-	enum beamforming_notify_state	is_sounding = BEAMFORMING_NOTIFY_NONE;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_SOUNDING_INFO			*p_sound_info = &(p_beam_info->sounding_info);
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	u8 idx = BEAMFORMEE_ENTRY_NUM;
+	enum beamforming_notify_state is_sounding = BEAMFORMING_NOTIFY_NONE;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_SOUNDING_INFO *sound_info = &beam_info->sounding_info;
 
-	is_sounding = phydm_beamfomring_is_sounding(p_dm, p_beam_info, &idx);
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s, Before notify, is_sounding=%d, idx=%d\n", __func__, is_sounding, idx));
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s: p_beam_info->beamformee_su_cnt = %d\n", __func__, p_beam_info->beamformee_su_cnt));
+	is_sounding = phydm_beamfomring_is_sounding(dm, beam_info, &idx);
 
+	PHYDM_DBG(dm, DBG_TXBF, "%s, Before notify, is_sounding=%d, idx=%d\n",
+		  __func__, is_sounding, idx);
+	PHYDM_DBG(dm, DBG_TXBF, "%s: beam_info->beamformee_su_cnt = %d\n",
+		  __func__, beam_info->beamformee_su_cnt);
 
 	switch (is_sounding) {
 	case BEAMFORMEE_NOTIFY_ADD_SU:
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: BEAMFORMEE_NOTIFY_ADD_SU\n", __func__));
-		phydm_beamforming_start_period(p_dm);
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_ADD_SU\n",
+			  __func__);
+		phydm_beamforming_start_period(dm);
 		break;
 
 	case BEAMFORMEE_NOTIFY_DELETE_SU:
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: BEAMFORMEE_NOTIFY_DELETE_SU\n", __func__));
-		if (p_sound_info->sound_mode == SOUNDING_FW_HT_TIMER || p_sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
-			phydm_beamforming_clear_entry_fw(p_dm, true, idx);
-			if (p_beam_info->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
-				phydm_beamforming_end_period_fw(p_dm);
-				PHYDM_DBG(p_dm, DBG_TXBF, ("%s: No BFee left\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_DELETE_SU\n",
+			  __func__);
+		if (sound_info->sound_mode == SOUNDING_FW_HT_TIMER || sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
+			phydm_beamforming_clear_entry_fw(dm, true, idx);
+			if (beam_info->beamformee_su_cnt == 0) { /* @For 2->1 entry, we should not cancel SW timer */
+				phydm_beamforming_end_period_fw(dm);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: No BFee left\n",
+					  __func__);
 			}
 		} else {
-			phydm_beamforming_clear_entry_sw(p_dm, true, idx);
-			if (p_beam_info->beamformee_su_cnt == 0) { /* For 2->1 entry, we should not cancel SW timer */
-				phydm_beamforming_end_period_sw(p_dm);
-				PHYDM_DBG(p_dm, DBG_TXBF, ("%s: No BFee left\n", __func__));
+			phydm_beamforming_clear_entry_sw(dm, true, idx);
+			if (beam_info->beamformee_su_cnt == 0) { /* @For 2->1 entry, we should not cancel SW timer */
+				phydm_beamforming_end_period_sw(dm);
+				PHYDM_DBG(dm, DBG_TXBF, "%s: No BFee left\n",
+					  __func__);
 			}
 		}
 		break;
 
 	case BEAMFORMEE_NOTIFY_ADD_MU:
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: BEAMFORMEE_NOTIFY_ADD_MU\n", __func__));
-		if (p_beam_info->beamformee_mu_cnt == 2) {
-			/*if (p_sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
-				odm_set_timer(p_dm, &p_beam_info->beamforming_timer, p_sound_info->sound_period);*/
-			odm_set_timer(p_dm, &p_beam_info->beamforming_timer, 1000); /*Do MU sounding every 1sec*/
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_ADD_MU\n",
+			  __func__);
+		if (beam_info->beamformee_mu_cnt == 2) {
+			/*@if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+				odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);*/
+			odm_set_timer(dm, &beam_info->beamforming_timer, 1000); /*@Do MU sounding every 1sec*/
 		} else
-			PHYDM_DBG(p_dm, DBG_TXBF, ("%s: Less or larger than 2 MU STAs, not to set timer\n", __func__));
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "%s: Less or larger than 2 MU STAs, not to set timer\n",
+				  __func__);
 		break;
 
 	case BEAMFORMEE_NOTIFY_DELETE_MU:
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: BEAMFORMEE_NOTIFY_DELETE_MU\n", __func__));
-		if (p_beam_info->beamformee_mu_cnt == 1) {
-			/*if (p_sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_SW_HT_TIMER)*/{
-				odm_cancel_timer(p_dm, &p_beam_info->beamforming_timer);
-				PHYDM_DBG(p_dm, DBG_TXBF, ("%s: Less than 2 MU STAs, stop sounding\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s: BEAMFORMEE_NOTIFY_DELETE_MU\n",
+			  __func__);
+		if (beam_info->beamformee_mu_cnt == 1) {
+			/*@if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)*/ {
+				odm_cancel_timer(dm, &beam_info->beamforming_timer);
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "%s: Less than 2 MU STAs, stop sounding\n",
+					  __func__);
 			}
 		}
 		break;
 
 	case BEAMFORMING_NOTIFY_RESET:
-		if (p_sound_info->sound_mode == SOUNDING_FW_HT_TIMER || p_sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
-			phydm_beamforming_clear_entry_fw(p_dm, false, idx);
-			phydm_beamforming_end_period_fw(p_dm);
+		if (sound_info->sound_mode == SOUNDING_FW_HT_TIMER || sound_info->sound_mode == SOUNDING_FW_VHT_TIMER) {
+			phydm_beamforming_clear_entry_fw(dm, false, idx);
+			phydm_beamforming_end_period_fw(dm);
 		} else {
-			phydm_beamforming_clear_entry_sw(p_dm, false, idx);
-			phydm_beamforming_end_period_sw(p_dm);
+			phydm_beamforming_clear_entry_sw(dm, false, idx);
+			phydm_beamforming_end_period_sw(dm);
 		}
 
 		break;
@@ -1097,606 +1142,637 @@ phydm_beamforming_notify(
 	default:
 		break;
 	}
-
 }
 
-
-
 boolean
-beamforming_init_entry(
-	void		*p_dm_void,
-	u16		sta_idx,
-	u8			*bfer_bfee_idx
-)
+beamforming_init_entry(void *dm_void, u16 sta_idx, u8 *bfer_bfee_idx,
+		       u8 *my_mac_addr)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMEE_ENTRY		*p_beamform_entry = NULL;
-	struct _RT_BEAMFORMER_ENTRY		*p_beamformer_entry = NULL;
-	struct _RT_BEAMFORM_STAINFO		*p_sta = NULL;
-	enum beamforming_cap			beamform_cap = BEAMFORMING_CAP_NONE;
-	u8						bfer_idx = 0xF, bfee_idx = 0xF;
-	u8						num_of_sounding_dim = 0, comp_steering_num_of_bfer = 0;
-
-	p_sta = phydm_sta_info_init(p_dm, sta_idx);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *cmn_sta = dm->phydm_sta_info[sta_idx];
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = NULL;
+	struct _RT_BEAMFORMER_ENTRY *beamformer_entry = NULL;
+	struct _RT_BEAMFORM_STAINFO *sta = NULL;
+	enum beamforming_cap beamform_cap = BEAMFORMING_CAP_NONE;
+	u8 bfer_idx = 0xF, bfee_idx = 0xF;
+	u8 num_of_sounding_dim = 0, comp_steering_num_of_bfer = 0;
+
+	if (!is_sta_active(cmn_sta)) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s => sta_info(mac_id:%d) failed\n",
+			  __func__, sta_idx);
+		#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		rtw_warn_on(1);
+		#endif
+		return false;
+	}
 
+	sta = phydm_sta_info_init(dm, sta_idx, my_mac_addr);
 	/*The current setting does not support Beaforming*/
-	if (BEAMFORMING_CAP_NONE == p_sta->ht_beamform_cap && BEAMFORMING_CAP_NONE == p_sta->vht_beamform_cap) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("The configuration disabled Beamforming! Skip...\n"));
+	if (BEAMFORMING_CAP_NONE == sta->ht_beamform_cap && BEAMFORMING_CAP_NONE == sta->vht_beamform_cap) {
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "The configuration disabled Beamforming! Skip...\n");
 		return false;
 	}
 
-	if (p_sta->wireless_mode < WIRELESS_MODE_N_24G)
+	if (!(cmn_sta->support_wireless_set & (WIRELESS_VHT | WIRELESS_HT)))
 		return false;
 	else {
-		if (p_sta->wireless_mode & WIRELESS_MODE_N_5G || p_sta->wireless_mode & WIRELESS_MODE_N_24G) {/*HT*/
-			if (TEST_FLAG(p_sta->cur_beamform, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {/*We are Beamformee because the STA is Beamformer*/
+		if (cmn_sta->support_wireless_set & WIRELESS_HT) { /*@HT*/
+			if (TEST_FLAG(sta->cur_beamform, BEAMFORMING_HT_BEAMFORMER_ENABLE)) { /*We are Beamformee because the STA is Beamformer*/
 				beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_HT_EXPLICIT);
-				num_of_sounding_dim = (p_sta->cur_beamform & BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP) >> 6;
+				num_of_sounding_dim = (sta->cur_beamform & BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP) >> 6;
 			}
 			/*We are Beamformer because the STA is Beamformee*/
-			if (TEST_FLAG(p_sta->cur_beamform, BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
-			    TEST_FLAG(p_sta->ht_beamform_cap, BEAMFORMING_HT_BEAMFORMER_TEST)) {
+			if (TEST_FLAG(sta->cur_beamform, BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
+			    TEST_FLAG(sta->ht_beamform_cap, BEAMFORMING_HT_BEAMFORMER_TEST)) {
 				beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_HT_EXPLICIT);
-				comp_steering_num_of_bfer = (p_sta->cur_beamform & BEAMFORMING_HT_BEAMFORMER_STEER_NUM) >> 4;
+				comp_steering_num_of_bfer = (sta->cur_beamform & BEAMFORMING_HT_BEAMFORMER_STEER_NUM) >> 4;
 			}
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] HT cur_beamform=0x%X, beamform_cap=0x%X\n", __func__, p_sta->cur_beamform, beamform_cap));
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] HT num_of_sounding_dim=%d, comp_steering_num_of_bfer=%d\n", __func__, num_of_sounding_dim, comp_steering_num_of_bfer));
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s] HT cur_beamform=0x%X, beamform_cap=0x%X\n",
+				  __func__, sta->cur_beamform, beamform_cap);
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s] HT num_of_sounding_dim=%d, comp_steering_num_of_bfer=%d\n",
+				  __func__, num_of_sounding_dim,
+				  comp_steering_num_of_bfer);
 		}
 #if (ODM_IC_11AC_SERIES_SUPPORT == 1)
-		if (p_sta->wireless_mode & WIRELESS_MODE_AC_5G || p_sta->wireless_mode & WIRELESS_MODE_AC_24G) {	/*VHT*/
+		if (cmn_sta->support_wireless_set & WIRELESS_VHT) { /*VHT*/
 
 			/* We are Beamformee because the STA is SU Beamformer*/
-			if (TEST_FLAG(p_sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
+			if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
 				beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_VHT_SU);
-				num_of_sounding_dim = (p_sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
+				num_of_sounding_dim = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
 			}
 			/* We are Beamformer because the STA is SU Beamformee*/
-			if (TEST_FLAG(p_sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) ||
-			    TEST_FLAG(p_sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
+			if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) ||
+			    TEST_FLAG(sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
 				beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_VHT_SU);
-				comp_steering_num_of_bfer = (p_sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
+				comp_steering_num_of_bfer = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
 			}
 			/* We are Beamformee because the STA is MU Beamformer*/
-			if (TEST_FLAG(p_sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
+			if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
 				beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMEE_CAP_VHT_MU);
-				num_of_sounding_dim = (p_sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
+				num_of_sounding_dim = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
 			}
 			/* We are Beamformer because the STA is MU Beamformee*/
-			if (phydm_acting_determine(p_dm, phydm_acting_as_ap)) { /* Only AP mode supports to act an MU beamformer */
-				if (TEST_FLAG(p_sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE) ||
-				    TEST_FLAG(p_sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
+			if (phydm_acting_determine(dm, phydm_acting_as_ap)) { /* Only AP mode supports to act an MU beamformer */
+				if (TEST_FLAG(sta->cur_beamform_vht, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE) ||
+				    TEST_FLAG(sta->vht_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_TEST)) {
 					beamform_cap = (enum beamforming_cap)(beamform_cap | BEAMFORMER_CAP_VHT_MU);
-					comp_steering_num_of_bfer = (p_sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
+					comp_steering_num_of_bfer = (sta->cur_beamform_vht & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
 				}
 			}
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]VHT cur_beamform_vht=0x%X, beamform_cap=0x%X\n", __func__, p_sta->cur_beamform_vht, beamform_cap));
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]VHT num_of_sounding_dim=0x%X, comp_steering_num_of_bfer=0x%X\n", __func__, num_of_sounding_dim, comp_steering_num_of_bfer));
-
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s]VHT cur_beamform_vht=0x%X, beamform_cap=0x%X\n",
+				  __func__, sta->cur_beamform_vht,
+				  beamform_cap);
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s]VHT num_of_sounding_dim=0x%X, comp_steering_num_of_bfer=0x%X\n",
+				  __func__, num_of_sounding_dim,
+				  comp_steering_num_of_bfer);
 		}
 #endif
 	}
 
-
 	if (beamform_cap == BEAMFORMING_CAP_NONE)
 		return false;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Self BF Entry Cap = 0x%02X\n", __func__, beamform_cap));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Self BF Entry Cap = 0x%02X\n", __func__,
+		  beamform_cap);
 
 	/*We are BFee, so the entry is BFer*/
 	if (beamform_cap & (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP_HT_EXPLICIT)) {
-		p_beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(p_dm, p_sta->ra, &bfer_idx);
-
-		if (p_beamformer_entry == NULL) {
-			p_beamformer_entry = beamforming_add_bfer_entry(p_dm, p_sta, beamform_cap, num_of_sounding_dim, &bfer_idx);
-			if (p_beamformer_entry == NULL)
-				PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]Not enough BFer entry!!!!!\n", __func__));
+		beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, sta->ra, &bfer_idx);
+
+		if (beamformer_entry == NULL) {
+			beamformer_entry = beamforming_add_bfer_entry(dm, sta, beamform_cap, num_of_sounding_dim, &bfer_idx);
+			if (beamformer_entry == NULL)
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "[%s]Not enough BFer entry!!!!!\n",
+					  __func__);
 		}
 	}
 
 	/*We are BFer, so the entry is BFee*/
 	if (beamform_cap & (BEAMFORMER_CAP_VHT_MU | BEAMFORMER_CAP_VHT_SU | BEAMFORMER_CAP_HT_EXPLICIT)) {
-		p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, p_sta->ra, &bfee_idx);
+		beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, sta->ra, &bfee_idx);
 
-		/*如果BFeeIdx = 0xF 則代表目前entry當中沒有相同的MACID在內*/
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Get BFee entry 0x%X by address\n", __func__, bfee_idx));
-		if (p_beamform_entry == NULL) {
-			p_beamform_entry = beamforming_add_bfee_entry(p_dm, p_sta, beamform_cap, num_of_sounding_dim, comp_steering_num_of_bfer, &bfee_idx);
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]: p_sta->AID=%d, p_sta->mac_id=%d\n", __func__, p_sta->aid, p_sta->mac_id));
+		/*@if BFeeIdx = 0xF, that represent for no matched MACID among all linked entrys */
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] Get BFee entry 0x%X by address\n",
+			  __func__, bfee_idx);
+		if (beamform_entry == NULL) {
+			beamform_entry = beamforming_add_bfee_entry(dm, sta, beamform_cap, num_of_sounding_dim, comp_steering_num_of_bfer, &bfee_idx);
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s]: sta->AID=%d, sta->mac_id=%d\n",
+				  __func__, sta->aid, sta->mac_id);
 
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]: Add BFee entry %d\n", __func__, bfee_idx));
+			PHYDM_DBG(dm, DBG_TXBF, "[%s]: Add BFee entry %d\n",
+				  __func__, bfee_idx);
 
-			if (p_beamform_entry == NULL)
+			if (beamform_entry == NULL)
 				return false;
 			else
-				p_beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
 		} else {
-			/*Entry has been created. If entry is initialing or progressing then errors occur.*/
-			if (p_beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED &&
-			    p_beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED)
+			/*@Entry has been created. If entry is initialing or progressing then errors occur.*/
+			if (beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED &&
+			    beamform_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED)
 				return false;
 			else
-				p_beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
+				beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZEING;
 		}
-		p_beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-		phydm_sta_info_update(p_dm, sta_idx, p_beamform_entry);
+		beamform_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+		phydm_sta_info_update(dm, sta_idx, beamform_entry);
 	}
 
 	*bfer_bfee_idx = (bfer_idx << 4) | bfee_idx;
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] End: bfer_idx=0x%X, bfee_idx=0x%X, bfer_bfee_idx=0x%X\n", __func__, bfer_idx, bfee_idx, *bfer_bfee_idx));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] End: bfer_idx=0x%X, bfee_idx=0x%X, bfer_bfee_idx=0x%X\n",
+		  __func__, bfer_idx, bfee_idx, *bfer_bfee_idx);
 
 	return true;
 }
 
-
-void
-beamforming_deinit_entry(
-	void		*p_dm_void,
-	u8			*RA
-)
+void beamforming_deinit_entry(
+	void *dm_void,
+	u8 *RA)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8				idx = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 idx = 0;
 
-	struct _RT_BEAMFORMER_ENTRY	*p_bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(p_dm, RA, &idx);
-	struct _RT_BEAMFORMEE_ENTRY	*p_bfee_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
+	struct _RT_BEAMFORMER_ENTRY *bfer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, RA, &idx);
+	struct _RT_BEAMFORMEE_ENTRY *bfee_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
 	boolean ret = false;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n",  __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	if (p_bfee_entry != NULL) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s, p_bfee_entry\n", __func__));
-		p_bfee_entry->is_used = false;
-		p_bfee_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
-		p_bfee_entry->is_beamforming_in_progress = false;
-		if (p_bfee_entry->is_mu_sta) {
-			p_dm->beamforming_info.beamformee_mu_cnt -= 1;
-			p_dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(p_dm);
+	if (bfee_entry != NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, bfee_entry\n", __func__);
+		bfee_entry->is_used = false;
+		bfee_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		bfee_entry->is_beamforming_in_progress = false;
+		if (bfee_entry->is_mu_sta) {
+			dm->beamforming_info.beamformee_mu_cnt -= 1;
+			dm->beamforming_info.first_mu_bfee_index = phydm_beamforming_get_first_mu_bfee_entry_idx(dm);
 		} else
-			p_dm->beamforming_info.beamformee_su_cnt -= 1;
+			dm->beamforming_info.beamformee_su_cnt -= 1;
 		ret = true;
 	}
 
-	if (p_bfer_entry != NULL) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s, p_bfer_entry\n", __func__));
-		p_bfer_entry->is_used = false;
-		p_bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
-		if (p_bfer_entry->is_mu_ap)
-			p_dm->beamforming_info.beamformer_mu_cnt -= 1;
+	if (bfer_entry != NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s, bfer_entry\n", __func__);
+		bfer_entry->is_used = false;
+		bfer_entry->beamform_entry_cap = BEAMFORMING_CAP_NONE;
+		if (bfer_entry->is_mu_ap)
+			dm->beamforming_info.beamformer_mu_cnt -= 1;
 		else
-			p_dm->beamforming_info.beamformer_su_cnt -= 1;
+			dm->beamforming_info.beamformer_su_cnt -= 1;
 		ret = true;
 	}
 
 	if (ret == true)
-		hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_LEAVE, (u8 *)&idx);
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_LEAVE, (u8 *)&idx);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s End, idx = 0x%X\n", __func__, idx));
+	PHYDM_DBG(dm, DBG_TXBF, "%s End, idx = 0x%X\n", __func__, idx);
 }
 
-
 boolean
 beamforming_start_v1(
-	void		*p_dm_void,
-	u8			*RA,
-	boolean			mode,
-	enum channel_width	BW,
-	u8			rate
-)
+	void *dm_void,
+	u8 *RA,
+	boolean mode,
+	enum channel_width BW,
+	u8 rate)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8					idx = 0;
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry;
-	boolean					ret = true;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY *entry;
+	boolean ret = true;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
-	p_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
+	entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
 
-	if (p_entry->is_used == false) {
-		p_entry->is_beamforming_in_progress = false;
+	if (entry->is_used == false) {
+		entry->is_beamforming_in_progress = false;
 		return false;
 	} else {
-		if (p_entry->is_beamforming_in_progress)
+		if (entry->is_beamforming_in_progress)
 			return false;
 
-		p_entry->is_beamforming_in_progress = true;
+		entry->is_beamforming_in_progress = true;
 
 		if (mode == 1) {
-			if (!(p_entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
-				p_entry->is_beamforming_in_progress = false;
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
+				entry->is_beamforming_in_progress = false;
 				return false;
 			}
 		} else if (mode == 0) {
-			if (!(p_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
-				p_entry->is_beamforming_in_progress = false;
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
+				entry->is_beamforming_in_progress = false;
 				return false;
 			}
 		}
 
-		if (p_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && p_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			p_entry->is_beamforming_in_progress = false;
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			entry->is_beamforming_in_progress = false;
 			return false;
 		} else {
-			p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
-			p_entry->is_sound = true;
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+			entry->is_sound = true;
 		}
 	}
 
-	p_entry->sound_bw = BW;
-	p_beam_info->beamformee_cur_idx = idx;
-	phydm_beamforming_ndpa_rate(p_dm, BW, rate);
-	hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
+	entry->sound_bw = BW;
+	beam_info->beamformee_cur_idx = idx;
+	phydm_beamforming_ndpa_rate(dm, BW, rate);
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&idx);
 
 	if (mode == 1)
-		ret = beamforming_send_ht_ndpa_packet(p_dm, RA, BW, NORMAL_QUEUE);
+		ret = beamforming_send_ht_ndpa_packet(dm, RA, BW, NORMAL_QUEUE);
 	else
-		ret = beamforming_send_vht_ndpa_packet(p_dm, RA, p_entry->aid, BW, NORMAL_QUEUE);
+		ret = beamforming_send_vht_ndpa_packet(dm, RA, entry->aid, BW, NORMAL_QUEUE);
 
 	if (ret == false) {
-		beamforming_leave(p_dm, RA);
-		p_entry->is_beamforming_in_progress = false;
+		beamforming_leave(dm, RA);
+		entry->is_beamforming_in_progress = false;
 		return false;
 	}
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s  idx %d\n", __func__, idx));
+	PHYDM_DBG(dm, DBG_TXBF, "%s  idx %d\n", __func__, idx);
 	return true;
 }
 
-
 boolean
 beamforming_start_sw(
-	void		*p_dm_void,
-	u8			idx,
-	u8			mode,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 idx,
+	u8 mode,
+	enum channel_width BW)
 {
-	u8					*ra = NULL;
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry;
-	boolean					ret = true;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
+	u8 *ra = NULL;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY *entry;
+	boolean ret = true;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+#ifdef SUPPORT_MU_BF
+#if (SUPPORT_MU_BF == 1)
+	u8 i, poll_sta_cnt = 0;
+	boolean is_get_first_bfee = false;
+#endif
+#endif
 
-	if (p_beam_info->is_mu_sounding) {
-		p_beam_info->is_mu_sounding_in_progress = true;
-		p_entry = &(p_beam_info->beamformee_entry[idx]);
-		ra = p_entry->mac_addr;
+	if (beam_info->is_mu_sounding) {
+		beam_info->is_mu_sounding_in_progress = true;
+		entry = &beam_info->beamformee_entry[idx];
+		ra = entry->mac_addr;
 
 	} else {
-		p_entry = &(p_beam_info->beamformee_entry[idx]);
+		entry = &beam_info->beamformee_entry[idx];
 
-		if (p_entry->is_used == false) {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("Skip Beamforming, no entry for idx =%d\n", idx));
-			p_entry->is_beamforming_in_progress = false;
+		if (entry->is_used == false) {
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "Skip Beamforming, no entry for idx =%d\n",
+				  idx);
+			entry->is_beamforming_in_progress = false;
 			return false;
-		} else {
-			if (p_entry->is_beamforming_in_progress) {
-				PHYDM_DBG(p_dm, DBG_TXBF, ("is_beamforming_in_progress, skip...\n"));
-				return false;
-			}
+		}
 
-			p_entry->is_beamforming_in_progress = true;
-			ra = p_entry->mac_addr;
+		if (entry->is_beamforming_in_progress) {
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "is_beamforming_in_progress, skip...\n");
+			return false;
+		}
 
-			if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_AUTO_HT_TIMER) {
-				if (!(p_entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
-					p_entry->is_beamforming_in_progress = false;
-					PHYDM_DBG(p_dm, DBG_TXBF, ("%s Return by not support BEAMFORMER_CAP_HT_EXPLICIT <==\n", __func__));
-					return false;
-				}
-			} else if (mode == SOUNDING_SW_VHT_TIMER || mode == SOUNDING_HW_VHT_TIMER || mode == SOUNDING_AUTO_VHT_TIMER) {
-				if (!(p_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
-					p_entry->is_beamforming_in_progress = false;
-					PHYDM_DBG(p_dm, DBG_TXBF, ("%s Return by not support BEAMFORMER_CAP_VHT_SU <==\n", __func__));
-					return false;
-				}
+		entry->is_beamforming_in_progress = true;
+		ra = entry->mac_addr;
+
+		if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_AUTO_HT_TIMER) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)) {
+				entry->is_beamforming_in_progress = false;
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "%s Return by not support BEAMFORMER_CAP_HT_EXPLICIT <==\n",
+					  __func__);
+				return false;
 			}
-			if (p_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && p_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-				p_entry->is_beamforming_in_progress = false;
-				PHYDM_DBG(p_dm, DBG_TXBF, ("%s Return by incorrect beamform_entry_state(%d) <==\n", __func__, p_entry->beamform_entry_state));
+		} else if (mode == SOUNDING_SW_VHT_TIMER || mode == SOUNDING_HW_VHT_TIMER || mode == SOUNDING_AUTO_VHT_TIMER) {
+			if (!(entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)) {
+				entry->is_beamforming_in_progress = false;
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "%s Return by not support BEAMFORMER_CAP_VHT_SU <==\n",
+					  __func__);
 				return false;
-			} else {
-				p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
-				p_entry->is_sound = true;
 			}
 		}
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_INITIALIZED && entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			entry->is_beamforming_in_progress = false;
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "%s Return by incorrect beamform_entry_state(%d) <==\n",
+				  __func__, entry->beamform_entry_state);
+			return false;
+		} else {
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+			entry->is_sound = true;
+		}
 
-		p_beam_info->beamformee_cur_idx = idx;
+		beam_info->beamformee_cur_idx = idx;
 	}
 
-	/*2014.12.22 Luke: Need to be checked*/
-	/*GET_TXBF_INFO(adapter)->fTxbfSet(adapter, TXBF_SET_SOUNDING_STATUS, (u8*)&idx);*/
+	/*@2014.12.22 Luke: Need to be checked*/
+	/*@GET_TXBF_INFO(adapter)->fTxbfSet(adapter, TXBF_SET_SOUNDING_STATUS, (u8*)&idx);*/
 
 	if (mode == SOUNDING_SW_HT_TIMER || mode == SOUNDING_HW_HT_TIMER || mode == SOUNDING_AUTO_HT_TIMER)
-		ret = beamforming_send_ht_ndpa_packet(p_dm, ra, BW, NORMAL_QUEUE);
+		ret = beamforming_send_ht_ndpa_packet(dm, ra, BW, NORMAL_QUEUE);
 	else
-		ret = beamforming_send_vht_ndpa_packet(p_dm, ra, p_entry->aid, BW, NORMAL_QUEUE);
+		ret = beamforming_send_vht_ndpa_packet(dm, ra, entry->aid, BW, NORMAL_QUEUE);
 
 	if (ret == false) {
-		beamforming_leave(p_dm, ra);
-		p_entry->is_beamforming_in_progress = false;
+		beamforming_leave(dm, ra);
+		entry->is_beamforming_in_progress = false;
 		return false;
 	}
 
-
-	/*--------------------------
+/*@--------------------------
 	 * Send BF Report Poll for MU BF
 	--------------------------*/
 #ifdef SUPPORT_MU_BF
 #if (SUPPORT_MU_BF == 1)
-	{
-		u8				idx, poll_sta_cnt = 0;
-		boolean				is_get_first_bfee = false;
-
-		if (p_beam_info->beamformee_mu_cnt > 1) { /* More than 1 MU STA*/
-
-			for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-				p_entry = &(p_beam_info->beamformee_entry[idx]);
-				if (p_entry->is_mu_sta) {
-					if (is_get_first_bfee) {
-						poll_sta_cnt++;
-						if (poll_sta_cnt == (p_beam_info->beamformee_mu_cnt - 1))/* The last STA*/
-							send_sw_vht_bf_report_poll(p_dm, p_entry->mac_addr, true);
-						else
-							send_sw_vht_bf_report_poll(p_dm, p_entry->mac_addr, false);
-					} else
-						is_get_first_bfee = true;
-				}
-			}
+	if (beam_info->beamformee_mu_cnt <= 1)
+		goto out;
+
+	/* @More than 1 MU STA*/
+	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
+		entry = &beam_info->beamformee_entry[i];
+		if (!entry->is_mu_sta)
+			continue;
+
+		if (!is_get_first_bfee) {
+			is_get_first_bfee = true;
+			continue;
 		}
+
+		poll_sta_cnt++;
+		if (poll_sta_cnt == (beam_info->beamformee_mu_cnt - 1)) /* The last STA*/
+			send_sw_vht_bf_report_poll(dm, entry->mac_addr, true);
+		else
+			send_sw_vht_bf_report_poll(dm, entry->mac_addr, false);
 	}
+out:
 #endif
 #endif
 	return true;
 }
 
-
 boolean
 beamforming_start_fw(
-	void		*p_dm_void,
-	u8			idx
-)
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-
-	p_entry = &(p_beam_info->beamformee_entry[idx]);
-	if (p_entry->is_used == false) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("Skip Beamforming, no entry for idx =%d\n", idx));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMEE_ENTRY *entry;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+
+	entry = &beam_info->beamformee_entry[idx];
+	if (entry->is_used == false) {
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "Skip Beamforming, no entry for idx =%d\n", idx);
 		return false;
 	}
 
-	p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
-	p_entry->is_sound = true;
-	hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
+	entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSING;
+	entry->is_sound = true;
+	hal_com_txbf_set(dm, TXBF_SET_SOUNDING_FW_NDPA, (u8 *)&idx);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] End, idx=0x%X\n", __func__, idx));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End, idx=0x%X\n", __func__, idx);
 	return true;
 }
 
-void
-beamforming_check_sounding_success(
-	void			*p_dm_void,
-	boolean			status
-)
+void beamforming_check_sounding_success(
+	void *dm_void,
+	boolean status)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry = &(p_beam_info->beamformee_entry[p_beam_info->beamformee_cur_idx]);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[David]@%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[David]@%s Start!\n", __func__);
 
 	if (status == 1) {
-		if (p_entry->log_status_fail_cnt == 21)
-			beamforming_dym_period(p_dm, status);
-		p_entry->log_status_fail_cnt = 0;
-	} else if (p_entry->log_status_fail_cnt <= 20) {
-		p_entry->log_status_fail_cnt++;
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s log_status_fail_cnt %d\n", __func__, p_entry->log_status_fail_cnt));
+		if (entry->log_status_fail_cnt == 21)
+			beamforming_dym_period(dm, status);
+		entry->log_status_fail_cnt = 0;
+	} else if (entry->log_status_fail_cnt <= 20) {
+		entry->log_status_fail_cnt++;
+		PHYDM_DBG(dm, DBG_TXBF, "%s log_status_fail_cnt %d\n", __func__,
+			  entry->log_status_fail_cnt);
 	}
-	if (p_entry->log_status_fail_cnt > 20) {
-		p_entry->log_status_fail_cnt = 21;
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s log_status_fail_cnt > 20, Stop SOUNDING\n", __func__));
-		beamforming_dym_period(p_dm, status);
+	if (entry->log_status_fail_cnt > 20) {
+		entry->log_status_fail_cnt = 21;
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "%s log_status_fail_cnt > 20, Stop SOUNDING\n",
+			  __func__);
+		beamforming_dym_period(dm, status);
 	}
 }
 
-void
-phydm_beamforming_end_sw(
-	void		*p_dm_void,
-	boolean			status
-)
+void phydm_beamforming_end_sw(
+	void *dm_void,
+	boolean status)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry = &(p_beam_info->beamformee_entry[p_beam_info->beamformee_cur_idx]);
-
-	if (p_beam_info->is_mu_sounding) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: MU sounding done\n", __func__));
-		p_beam_info->is_mu_sounding_in_progress = false;
-		hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&(p_beam_info->beamformee_cur_idx));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *entry = &beam_info->beamformee_entry[beam_info->beamformee_cur_idx];
+
+	if (beam_info->is_mu_sounding) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s: MU sounding done\n", __func__);
+		beam_info->is_mu_sounding_in_progress = false;
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+				 (u8 *)&beam_info->beamformee_cur_idx);
 	} else {
-		if (p_entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSING) {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] BeamformStatus %d\n", __func__, p_entry->beamform_entry_state));
+		if (entry->beamform_entry_state != BEAMFORMING_ENTRY_STATE_PROGRESSING) {
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] BeamformStatus %d\n",
+				  __func__, entry->beamform_entry_state);
 			return;
 		}
 
-		if ((p_beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7) && (p_beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9) && (p_beam_info->snding3ss == false)) {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] VHT3SS 7,8,9, do not apply V matrix.\n", __func__));
-			p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-			hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&(p_beam_info->beamformee_cur_idx));
+		if (beam_info->tx_bf_data_rate >= ODM_RATEVHTSS3MCS7 && beam_info->tx_bf_data_rate <= ODM_RATEVHTSS3MCS9 && !beam_info->snding3ss) {
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s] VHT3SS 7,8,9, do not apply V matrix.\n",
+				  __func__);
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+					 (u8 *)&beam_info->beamformee_cur_idx);
 		} else if (status == 1) {
-			p_entry->log_status_fail_cnt = 0;
-			p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
-			hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_STATUS, (u8 *)&(p_beam_info->beamformee_cur_idx));
+			entry->log_status_fail_cnt = 0;
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
+			hal_com_txbf_set(dm, TXBF_SET_SOUNDING_STATUS,
+					 (u8 *)&beam_info->beamformee_cur_idx);
 		} else {
-			p_entry->log_status_fail_cnt++;
-			p_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
-			hal_com_txbf_set(p_dm, TXBF_SET_TX_PATH_RESET, (u8 *)&(p_beam_info->beamformee_cur_idx));
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] log_status_fail_cnt %d\n", __func__, p_entry->log_status_fail_cnt));
+			entry->log_status_fail_cnt++;
+			entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_INITIALIZED;
+			hal_com_txbf_set(dm, TXBF_SET_TX_PATH_RESET,
+					 (u8 *)&beam_info->beamformee_cur_idx);
+			PHYDM_DBG(dm, DBG_TXBF, "[%s] log_status_fail_cnt %d\n",
+				  __func__, entry->log_status_fail_cnt);
 		}
 
-		if (p_entry->log_status_fail_cnt > 50) {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("%s log_status_fail_cnt > 50, Stop SOUNDING\n", __func__));
-			p_entry->is_sound = false;
-			beamforming_deinit_entry(p_dm, p_entry->mac_addr);
+		if (entry->log_status_fail_cnt > 50) {
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "%s log_status_fail_cnt > 50, Stop SOUNDING\n",
+				  __func__);
+			entry->is_sound = false;
+			beamforming_deinit_entry(dm, entry->mac_addr);
 
-			/*Modified by David - Every action of deleting entry should follow by Notify*/
-			phydm_beamforming_notify(p_dm);
+			/*@Modified by David - Every action of deleting entry should follow by Notify*/
+			phydm_beamforming_notify(dm);
 		}
 
-		p_entry->is_beamforming_in_progress = false;
+		entry->is_beamforming_in_progress = false;
 	}
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s: status=%d\n", __func__, status));
+	PHYDM_DBG(dm, DBG_TXBF, "%s: status=%d\n", __func__, status);
 }
 
-
-void
-beamforming_timer_callback(
+void beamforming_timer_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	void			*p_dm_void
+	void *dm_void
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	void            *p_context
+	void *context
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct _ADAPTER					*adapter = (struct _ADAPTER *)p_context;
-	PHAL_DATA_TYPE				p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT					*p_dm = &p_hal_data->odmpriv;
+	void *adapter = (void *)context;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->odmpriv;
 #endif
-	boolean						ret = false;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY		*p_entry = &(p_beam_info->beamformee_entry[p_beam_info->beamformee_cur_idx]);
-	struct _RT_SOUNDING_INFO			*p_sound_info = &(p_beam_info->sounding_info);
-	boolean					is_beamforming_in_progress;
+	boolean ret = false;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY *entry = &(beam_info->beamformee_entry[beam_info->beamformee_cur_idx]);
+	struct _RT_SOUNDING_INFO *sound_info = &(beam_info->sounding_info);
+	boolean is_beamforming_in_progress;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	if (p_beam_info->is_mu_sounding)
-		is_beamforming_in_progress = p_beam_info->is_mu_sounding_in_progress;
+	if (beam_info->is_mu_sounding)
+		is_beamforming_in_progress = beam_info->is_mu_sounding_in_progress;
 	else
-		is_beamforming_in_progress = p_entry->is_beamforming_in_progress;
+		is_beamforming_in_progress = entry->is_beamforming_in_progress;
 
 	if (is_beamforming_in_progress) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("is_beamforming_in_progress, reset it\n"));
-		phydm_beamforming_end_sw(p_dm, 0);
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "is_beamforming_in_progress, reset it\n");
+		phydm_beamforming_end_sw(dm, 0);
 	}
 
-	ret = phydm_beamforming_select_beam_entry(p_dm, p_beam_info);
+	ret = phydm_beamforming_select_beam_entry(dm, beam_info);
 #if (SUPPORT_MU_BF == 1)
-	if (ret && p_beam_info->beamformee_mu_cnt > 1)
+	if (ret && beam_info->beamformee_mu_cnt > 1)
 		ret = 1;
 	else
 		ret = 0;
 #endif
 	if (ret)
-		ret = beamforming_start_sw(p_dm, p_sound_info->sound_idx, p_sound_info->sound_mode, p_sound_info->sound_bw);
+		ret = beamforming_start_sw(dm, sound_info->sound_idx, sound_info->sound_mode, sound_info->sound_bw);
 	else
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s, Error value return from BeamformingStart_V2\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "%s, Error value return from BeamformingStart_V2\n",
+			  __func__);
 
-	if ((p_beam_info->beamformee_su_cnt != 0) || (p_beam_info->beamformee_mu_cnt > 1)) {
-		if (p_sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || p_sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
-			odm_set_timer(p_dm, &p_beam_info->beamforming_timer, p_sound_info->sound_period);
+	if (beam_info->beamformee_su_cnt != 0 || beam_info->beamformee_mu_cnt > 1) {
+		if (sound_info->sound_mode == SOUNDING_SW_VHT_TIMER || sound_info->sound_mode == SOUNDING_SW_HT_TIMER)
+			odm_set_timer(dm, &beam_info->beamforming_timer, sound_info->sound_period);
 		else {
-			u32	val = (p_sound_info->sound_period << 16) | HAL_TIMER_TXBF;
-			phydm_set_hw_reg_handler_interface(p_dm, HW_VAR_HW_REG_TIMER_RESTART, (u8 *)(&val));
+			u32 val = (sound_info->sound_period << 16) | HAL_TIMER_TXBF;
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_HW_REG_TIMER_RESTART, (u8 *)(&val));
 		}
 	}
 }
 
-
-void
-beamforming_sw_timer_callback(
+void beamforming_sw_timer_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct timer_list		*p_timer
+	struct phydm_timer_list *timer
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 	void *function_context
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter = (struct _ADAPTER *)p_timer->Adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	void *adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
-	beamforming_timer_callback(p_dm);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+	beamforming_timer_callback(dm);
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)function_context;
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	struct dm_struct *dm = (struct dm_struct *)function_context;
+	void *adapter = dm->adapter;
 
-	if (adapter->net_closed == true)
+	if (*dm->is_net_closed == true)
 		return;
-	rtw_run_in_thread_cmd(adapter, beamforming_timer_callback, adapter);
+	phydm_run_in_thread_cmd(dm, beamforming_timer_callback, adapter);
 #endif
-
 }
 
-
-void
-phydm_beamforming_init(
-	void			*p_dm_void
-)
+void phydm_beamforming_init(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMING_OID_INFO	*p_beam_oid_info = &(p_beam_info->beamforming_oid_info);
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	
-	#ifdef BEAMFORMING_VERSION_1
-	if (p_hal_data->beamforming_version != BEAMFORMING_VERSION_1) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMING_OID_INFO *beam_oid_info = &beam_info->beamforming_oid_info;
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	void *adapter = dm->adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+
+#ifdef BEAMFORMING_VERSION_1
+	if (hal_data->beamforming_version != BEAMFORMING_VERSION_1) {
 		return;
 	}
-	#endif
-	#endif
-
-	p_beam_oid_info->sound_oid_mode = SOUNDING_STOP_OID_TIMER;
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s mode (%d)\n", __func__, p_beam_oid_info->sound_oid_mode));
+#endif
+#endif
 
-	p_beam_info->beamformee_su_cnt = 0;
-	p_beam_info->beamformer_su_cnt = 0;
-	p_beam_info->beamformee_mu_cnt = 0;
-	p_beam_info->beamformer_mu_cnt = 0;
-	p_beam_info->beamformee_mu_reg_maping = 0;
-	p_beam_info->mu_ap_index = 0;
-	p_beam_info->is_mu_sounding = false;
-	p_beam_info->first_mu_bfee_index = 0xFF;
-	p_beam_info->apply_v_matrix = true;
-	p_beam_info->snding3ss = false;
+	beam_oid_info->sound_oid_mode = SOUNDING_STOP_OID_TIMER;
+	PHYDM_DBG(dm, DBG_TXBF, "%s mode (%d)\n", __func__,
+		  beam_oid_info->sound_oid_mode);
+
+	beam_info->beamformee_su_cnt = 0;
+	beam_info->beamformer_su_cnt = 0;
+	beam_info->beamformee_mu_cnt = 0;
+	beam_info->beamformer_mu_cnt = 0;
+	beam_info->beamformee_mu_reg_maping = 0;
+	beam_info->mu_ap_index = 0;
+	beam_info->is_mu_sounding = false;
+	beam_info->first_mu_bfee_index = 0xFF;
+	beam_info->apply_v_matrix = true;
+	beam_info->snding3ss = false;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	p_beam_info->source_adapter = p_dm->adapter;
+	beam_info->source_adapter = dm->adapter;
 #endif
-	hal_com_txbf_beamform_init(p_dm);
+	hal_com_txbf_beamform_init(dm);
 }
 
-
 boolean
 phydm_acting_determine(
-	void			*p_dm_void,
-	enum phydm_acting_type	type
-)
+	void *dm_void,
+	enum phydm_acting_type type)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean		ret = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret = false;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER	*adapter = p_dm->beamforming_info.source_adapter;
+	void *adapter = dm->beamforming_info.source_adapter;
 #else
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	struct _ADAPTER *adapter = dm->adapter;
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	if (type == phydm_acting_as_ap)
 		ret = ACTING_AS_AP(adapter);
 	else if (type == phydm_acting_as_ibss)
-		ret = ACTING_AS_IBSS(adapter);
+		ret = ACTING_AS_IBSS(((PADAPTER)(adapter)));
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct mlme_priv			*pmlmepriv = &(adapter->mlmepriv);
+	struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
 
 	if (type == phydm_acting_as_ap)
 		ret = check_fwstate(pmlmepriv, WIFI_AP_STATE);
@@ -1705,101 +1781,97 @@ phydm_acting_determine(
 #endif
 
 	return ret;
-
 }
 
-void
-beamforming_enter(
-	void			*p_dm_void,
-	u16		sta_idx
-)
+void beamforming_enter(void *dm_void, u16 sta_idx, u8 *my_mac_addr)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			bfer_bfee_idx = 0xff;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 bfer_bfee_idx = 0xff;
 
-	if (beamforming_init_entry(p_dm, sta_idx, &bfer_bfee_idx))
-		hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_ENTER, (u8 *)&bfer_bfee_idx);
+	if (beamforming_init_entry(dm, sta_idx, &bfer_bfee_idx, my_mac_addr))
+		hal_com_txbf_set(dm, TXBF_SET_SOUNDING_ENTER, (u8 *)&bfer_bfee_idx);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] End!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End!\n", __func__);
 }
 
-
-void
-beamforming_leave(
-	void			*p_dm_void,
-	u8			*RA
-)
+void beamforming_leave(
+	void *dm_void,
+	u8 *RA)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (RA != NULL) {
-		beamforming_deinit_entry(p_dm, RA);
-		phydm_beamforming_notify(p_dm);
+		beamforming_deinit_entry(dm, RA);
+		phydm_beamforming_notify(dm);
 	}
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] End!!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End!!\n", __func__);
 }
 
 #if 0
 /* Nobody calls this function */
 void
 phydm_beamforming_set_txbf_en(
-	void		*p_dm_void,
+	void		*dm_void,
 	u8			mac_id,
 	boolean			is_txbf
 )
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct				*dm = (struct dm_struct *)dm_void;
 	u8					idx = 0;
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry;
+	struct _RT_BEAMFORMEE_ENTRY	*entry;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	p_entry = phydm_beamforming_get_entry_by_mac_id(p_dm, mac_id, &idx);
+	entry = phydm_beamforming_get_entry_by_mac_id(dm, mac_id, &idx);
 
-	if (p_entry == NULL)
+	if (entry == NULL)
 		return;
 	else
-		p_entry->is_txbf = is_txbf;
+		entry->is_txbf = is_txbf;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s mac_id %d TxBF %d\n", __func__, p_entry->mac_id, p_entry->is_txbf));
+	PHYDM_DBG(dm, DBG_TXBF, "%s mac_id %d TxBF %d\n", __func__,
+		  entry->mac_id, entry->is_txbf);
 
-	phydm_beamforming_notify(p_dm);
+	phydm_beamforming_notify(dm);
 }
 #endif
 
 enum beamforming_cap
 phydm_beamforming_get_beam_cap(
-	void						*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info
-)
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info)
 {
-	u8					i;
-	boolean				is_self_beamformer = false;
-	boolean				is_self_beamformee = false;
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
-	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
-	enum beamforming_cap		beamform_cap = BEAMFORMING_CAP_NONE;
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u8 i;
+	boolean is_self_beamformer = false;
+	boolean is_self_beamformee = false;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY beamformer_entry;
+	enum beamforming_cap beamform_cap = BEAMFORMING_CAP_NONE;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-		beamformee_entry = p_beam_info->beamformee_entry[i];
+		beamformee_entry = beam_info->beamformee_entry[i];
 
 		if (beamformee_entry.is_used) {
 			is_self_beamformer = true;
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] BFee entry %d is_used=true\n", __func__, i));
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s] BFee entry %d is_used=true\n", __func__,
+				  i);
 			break;
 		}
 	}
 
 	for (i = 0; i < BEAMFORMER_ENTRY_NUM; i++) {
-		beamformer_entry = p_beam_info->beamformer_entry[i];
+		beamformer_entry = beam_info->beamformer_entry[i];
 
 		if (beamformer_entry.is_used) {
 			is_self_beamformee = true;
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]: BFer entry %d is_used=true\n", __func__, i));
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s]: BFer entry %d is_used=true\n",
+				  __func__, i);
 			break;
 		}
 	}
@@ -1812,38 +1884,37 @@ phydm_beamforming_get_beam_cap(
 	return beamform_cap;
 }
 
-
 boolean
 beamforming_control_v1(
-	void			*p_dm_void,
-	u8			*RA,
-	u8			AID,
-	u8			mode,
-	enum channel_width	BW,
-	u8			rate
-)
+	void *dm_void,
+	u8 *RA,
+	u8 AID,
+	u8 mode,
+	enum channel_width BW,
+	u8 rate)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean		ret = true;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret = true;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("AID (%d), mode (%d), BW (%d)\n", AID, mode, BW));
+	PHYDM_DBG(dm, DBG_TXBF, "AID (%d), mode (%d), BW (%d)\n", AID, mode,
+		  BW);
 
 	switch (mode) {
 	case 0:
-		ret = beamforming_start_v1(p_dm, RA, 0, BW, rate);
+		ret = beamforming_start_v1(dm, RA, 0, BW, rate);
 		break;
 	case 1:
-		ret = beamforming_start_v1(p_dm, RA, 1, BW, rate);
+		ret = beamforming_start_v1(dm, RA, 1, BW, rate);
 		break;
 	case 2:
-		phydm_beamforming_ndpa_rate(p_dm, BW, rate);
-		ret = beamforming_send_vht_ndpa_packet(p_dm, RA, AID, BW, NORMAL_QUEUE);
+		phydm_beamforming_ndpa_rate(dm, BW, rate);
+		ret = beamforming_send_vht_ndpa_packet(dm, RA, AID, BW, NORMAL_QUEUE);
 		break;
 	case 3:
-		phydm_beamforming_ndpa_rate(p_dm, BW, rate);
-		ret = beamforming_send_ht_ndpa_packet(p_dm, RA, BW, NORMAL_QUEUE);
+		phydm_beamforming_ndpa_rate(dm, BW, rate);
+		ret = beamforming_send_ht_ndpa_packet(dm, RA, BW, NORMAL_QUEUE);
 		break;
 	}
 	return ret;
@@ -1852,71 +1923,68 @@ beamforming_control_v1(
 /*Only OID uses this function*/
 boolean
 phydm_beamforming_control_v2(
-	void		*p_dm_void,
-	u8			idx,
-	u8			mode,
-	enum channel_width	BW,
-	u16			period
-)
+	void *dm_void,
+	u8 idx,
+	u8 mode,
+	enum channel_width BW,
+	u16 period)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info =  &p_dm->beamforming_info;
-	struct _RT_BEAMFORMING_OID_INFO	*p_beam_oid_info = &(p_beam_info->beamforming_oid_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMING_OID_INFO *beam_oid_info = &beam_info->beamforming_oid_info;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
-	PHYDM_DBG(p_dm, DBG_TXBF, ("idx (%d), mode (%d), BW (%d), period (%d)\n", idx, mode, BW, period));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
+	PHYDM_DBG(dm, DBG_TXBF, "idx (%d), mode (%d), BW (%d), period (%d)\n",
+		  idx, mode, BW, period);
 
-	p_beam_oid_info->sound_oid_idx = idx;
-	p_beam_oid_info->sound_oid_mode = (enum sounding_mode) mode;
-	p_beam_oid_info->sound_oid_bw = BW;
-	p_beam_oid_info->sound_oid_period = period;
+	beam_oid_info->sound_oid_idx = idx;
+	beam_oid_info->sound_oid_mode = (enum sounding_mode)mode;
+	beam_oid_info->sound_oid_bw = BW;
+	beam_oid_info->sound_oid_period = period;
 
-	phydm_beamforming_notify(p_dm);
+	phydm_beamforming_notify(dm);
 
 	return true;
 }
 
-
-void
-phydm_beamforming_watchdog(
-	void		*p_dm_void
-)
+void phydm_beamforming_watchdog(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO		*p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s Start!\n", __func__);
 
-	if (p_beam_info->beamformee_su_cnt == 0)
+	if (beam_info->beamformee_su_cnt == 0)
 		return;
 
-	beamforming_dym_period(p_dm, 0);
+	beamforming_dym_period(dm, 0);
 }
 enum beamforming_cap
 phydm_get_beamform_cap(
-	void			*p_dm_void
-)
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT                    *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info                     *p_sta = NULL;
-	struct bf_cmn_info                      *p_bf_info = NULL;
-	struct _RT_BEAMFORMING_INFO             *p_beam_info = &p_dm->beamforming_info;
-	struct _ADAPTER                         *adapter = p_dm->adapter;
-	enum beamforming_cap                     beamform_cap = BEAMFORMING_CAP_NONE;
-	u8                                       macid;
-	u8                                       ht_curbeamformcap = 0;
-	u16                                      vht_curbeamformcap = 0;
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = NULL;
+	struct bf_cmn_info *bf_info = NULL;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	void *adapter = dm->adapter;
+	enum beamforming_cap beamform_cap = BEAMFORMING_CAP_NONE;
+	u8 macid;
+	u8 ht_curbeamformcap = 0;
+	u16 vht_curbeamformcap = 0;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PMGNT_INFO                              p_MgntInfo = &adapter->MgntInfo;
-	PRT_VERY_HIGH_THROUGHPUT                p_vht_info = GET_VHT_INFO(p_MgntInfo);
-	PRT_HIGH_THROUGHPUT                     p_ht_info  = GET_HT_INFO(p_MgntInfo);
+	PMGNT_INFO p_MgntInfo = &(((PADAPTER)(adapter))->MgntInfo);
+	PRT_VERY_HIGH_THROUGHPUT p_vht_info = GET_VHT_INFO(p_MgntInfo);
+	PRT_HIGH_THROUGHPUT p_ht_info = GET_HT_INFO(p_MgntInfo);
 
 	ht_curbeamformcap = p_ht_info->HtCurBeamform;
 	vht_curbeamformcap = p_vht_info->VhtCurBeamform;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[%s] WIN ht_curcap = %d ; vht_curcap = %d\n", __func__, ht_curbeamformcap, vht_curbeamformcap));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[%s] WIN ht_curcap = %d ; vht_curcap = %d\n", __func__,
+		  ht_curbeamformcap, vht_curbeamformcap);
 
 	if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) /*We are Beamformee because the STA is Beamformer*/
 		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP));
@@ -1925,7 +1993,7 @@ phydm_get_beamform_cap(
 	if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
 		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP));
 
-	#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
 
 	/* We are Beamformee because the STA is SU Beamformer*/
 	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
@@ -1938,20 +2006,18 @@ phydm_get_beamform_cap(
 	/* We are Beamformee because the STA is MU Beamformer*/
 	if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE))
 		beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP));
-	#endif
+#endif
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 
+	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		sta = dm->phydm_sta_info[macid];
 
-		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
-
-		p_sta = p_dm->p_phydm_sta_info[macid];
-
-		if (!is_sta_active(p_sta))
+		if (!is_sta_active(sta))
 			continue;
 
-		p_bf_info = &(p_sta->bf_info);
-		vht_curbeamformcap = p_bf_info->vht_beamform_cap;
-		ht_curbeamformcap  = p_bf_info->ht_beamform_cap;
+		bf_info = &sta->bf_info;
+		vht_curbeamformcap = bf_info->vht_beamform_cap;
+		ht_curbeamformcap = bf_info->ht_beamform_cap;
 
 		if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) /*We are Beamformee because the STA is Beamformer*/
 			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP));
@@ -1960,7 +2026,7 @@ phydm_get_beamform_cap(
 		if (TEST_FLAG(ht_curbeamformcap, BEAMFORMING_HT_BEAMFORMEE_ENABLE))
 			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP));
 
-	#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
+#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
 		/* We are Beamformee because the STA is SU Beamformer*/
 		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_BEAMFORMER_ENABLE))
 			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_SU | BEAMFORMEE_CAP));
@@ -1972,14 +2038,14 @@ phydm_get_beamform_cap(
 		/* We are Beamformee because the STA is MU Beamformer*/
 		if (TEST_FLAG(vht_curbeamformcap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE))
 			beamform_cap = (enum beamforming_cap)(beamform_cap | (BEAMFORMEE_CAP_VHT_MU | BEAMFORMEE_CAP));
-	#endif
-}
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[%s] CE ht_curcap = %d ; vht_curcap = %d\n", __func__, ht_curbeamformcap, vht_curbeamformcap));
-
 #endif
+	}
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[%s] CE ht_curcap = %d ; vht_curcap = %d\n",
+		  __func__, ht_curbeamformcap, vht_curbeamformcap);
 
-return beamform_cap;
+#endif
 
+	return beamform_cap;
 }
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.h
index 4b8d22157f8f..98b81f44abae 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_beamforming.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,19 +9,25 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 #ifndef __INC_PHYDM_BEAMFORMING_H
 #define __INC_PHYDM_BEAMFORMING_H
 
-#ifndef BEAMFORMING_SUPPORT
-	#define	BEAMFORMING_SUPPORT		0
-#endif
-
-/*Beamforming Related*/
+/*@Beamforming Related*/
 #include "txbf/halcomtxbf.h"
 #include "txbf/haltxbfjaguar.h"
 #include "txbf/haltxbf8192e.h"
@@ -28,34 +35,34 @@
 #include "txbf/haltxbf8822b.h"
 #include "txbf/haltxbfinterface.h"
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-#define eq_mac_addr(a,b)						( ((a)[0]==(b)[0] && (a)[1]==(b)[1] && (a)[2]==(b)[2] && (a)[3]==(b)[3] && (a)[4]==(b)[4] && (a)[5]==(b)[5]) ? 1:0 )
-#define cp_mac_addr(des,src)					((des)[0]=(src)[0],(des)[1]=(src)[1],(des)[2]=(src)[2],(des)[3]=(src)[3],(des)[4]=(src)[4],(des)[5]=(src)[5])
+#define eq_mac_addr(a, b) (((a)[0] == (b)[0] && (a)[1] == (b)[1] && (a)[2] == (b)[2] && (a)[3] == (b)[3] && (a)[4] == (b)[4] && (a)[5] == (b)[5]) ? 1 : 0)
+#define cp_mac_addr(des, src) ((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3], (des)[4] = (src)[4], (des)[5] = (src)[5])
 
 #endif
 
-#define MAX_BEAMFORMEE_SU	2
-#define MAX_BEAMFORMER_SU	2
+#define MAX_BEAMFORMEE_SU 2
+#define MAX_BEAMFORMER_SU 2
 #if (RTL8822B_SUPPORT == 1)
-	#define MAX_BEAMFORMEE_MU	6
-	#define MAX_BEAMFORMER_MU	1
+#define MAX_BEAMFORMEE_MU 6
+#define MAX_BEAMFORMER_MU 1
 #else
-	#define MAX_BEAMFORMEE_MU	0
-	#define MAX_BEAMFORMER_MU	0
+#define MAX_BEAMFORMEE_MU 0
+#define MAX_BEAMFORMER_MU 0
 #endif
 
-#define BEAMFORMEE_ENTRY_NUM		(MAX_BEAMFORMEE_SU + MAX_BEAMFORMEE_MU)
-#define BEAMFORMER_ENTRY_NUM		(MAX_BEAMFORMER_SU + MAX_BEAMFORMER_MU)
+#define BEAMFORMEE_ENTRY_NUM (MAX_BEAMFORMEE_SU + MAX_BEAMFORMEE_MU)
+#define BEAMFORMER_ENTRY_NUM (MAX_BEAMFORMER_SU + MAX_BEAMFORMER_MU)
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	/*for different naming between WIN and CE*/
-	#define BEACON_QUEUE	BCN_QUEUE_INX
-	#define NORMAL_QUEUE	MGT_QUEUE_INX
-	#define RT_DISABLE_FUNC RTW_DISABLE_FUNC
-	#define RT_ENABLE_FUNC RTW_ENABLE_FUNC
+/*@for different naming between WIN and CE*/
+#define BEACON_QUEUE BCN_QUEUE_INX
+#define NORMAL_QUEUE MGT_QUEUE_INX
+#define RT_DISABLE_FUNC RTW_DISABLE_FUNC
+#define RT_ENABLE_FUNC RTW_ENABLE_FUNC
 #endif
 
 enum beamforming_entry_state {
@@ -66,7 +73,6 @@ enum beamforming_entry_state {
 	BEAMFORMING_ENTRY_STATE_PROGRESSED
 };
 
-
 enum beamforming_notify_state {
 	BEAMFORMING_NOTIFY_NONE,
 	BEAMFORMING_NOTIFY_ADD,
@@ -82,15 +88,14 @@ enum beamforming_cap {
 	BEAMFORMING_CAP_NONE = 0x0,
 	BEAMFORMER_CAP_HT_EXPLICIT = BIT(1),
 	BEAMFORMEE_CAP_HT_EXPLICIT = BIT(2),
-	BEAMFORMER_CAP_VHT_SU = BIT(5),			/* Self has er Cap, because Reg er  & peer ee */
-	BEAMFORMEE_CAP_VHT_SU = BIT(6),			/* Self has ee Cap, because Reg ee & peer er */
-	BEAMFORMER_CAP_VHT_MU = BIT(7),			/* Self has er Cap, because Reg er  & peer ee */
-	BEAMFORMEE_CAP_VHT_MU = BIT(8),			/* Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP_VHT_SU = BIT(5), /* @Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_SU = BIT(6), /* @Self has ee Cap, because Reg ee & peer er */
+	BEAMFORMER_CAP_VHT_MU = BIT(7), /* @Self has er Cap, because Reg er  & peer ee */
+	BEAMFORMEE_CAP_VHT_MU = BIT(8), /* @Self has ee Cap, because Reg ee & peer er */
 	BEAMFORMER_CAP = BIT(9),
 	BEAMFORMEE_CAP = BIT(10),
 };
 
-
 enum sounding_mode {
 	SOUNDING_SW_VHT_TIMER = 0x0,
 	SOUNDING_SW_HT_TIMER = 0x1,
@@ -105,132 +110,131 @@ enum sounding_mode {
 };
 
 struct _RT_BEAMFORM_STAINFO {
-	u8						*ra;
-	u16						aid;
-	u16						mac_id;
-	u8						my_mac_addr[6];
-	WIRELESS_MODE				wireless_mode;
-	enum channel_width				bw;
-	enum beamforming_cap			beamform_cap;
-	u8						ht_beamform_cap;
-	u16						vht_beamform_cap;
-	u8						cur_beamform;
-	u16						cur_beamform_vht;
+	u8 *ra;
+	u16 aid;
+	u16 mac_id;
+	u8 my_mac_addr[6];
+	/*WIRELESS_MODE				wireless_mode;*/
+	enum channel_width bw;
+	enum beamforming_cap beamform_cap;
+	u8 ht_beamform_cap;
+	u16 vht_beamform_cap;
+	u8 cur_beamform;
+	u16 cur_beamform_vht;
 };
 
-
 struct _RT_BEAMFORMEE_ENTRY {
 	boolean is_used;
-	boolean	is_txbf;
+	boolean is_txbf;
 	boolean is_sound;
-	u16	aid;				/*Used to construct AID field of NDPA packet.*/
-	u16	mac_id;				/*Used to Set Reg42C in IBSS mode. */
-	u16	p_aid;				/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
-	u8	g_id;				/*Used to fill Tx DESC*/
-	u8	my_mac_addr[6];
-	u8	mac_addr[6];			/*Used to fill Reg6E4 to fill Mac address of CSI report frame.*/
-	enum channel_width			sound_bw;		/*Sounding band_width*/
-	u16					sound_period;
-	enum beamforming_cap			beamform_entry_cap;
-	enum beamforming_entry_state	beamform_entry_state;
-	boolean						is_beamforming_in_progress;
-	/*u8	log_seq;									// Move to _RT_BEAMFORMER_ENTRY*/
-	/*u16	log_retry_cnt:3;		// 0~4				// Move to _RT_BEAMFORMER_ENTRY*/
-	/*u16	LogSuccessCnt:2;		// 0~2				// Move to _RT_BEAMFORMER_ENTRY*/
-	u16	log_status_fail_cnt:5;	/* 0~21 */
-	u16	default_csi_cnt:5;		/* 0~21 */
-	u8	csi_matrix[327];
-	u16	csi_matrix_len;
-	u8	num_of_sounding_dim;
-	u8	comp_steering_num_of_bfer;
-	u8	su_reg_index;
-	/*For MU-MIMO*/
-	boolean	is_mu_sta;
-	u8	mu_reg_index;
-	u8	gid_valid[8];
-	u8	user_position[16];
+	u16 aid; /*Used to construct AID field of NDPA packet.*/
+	u16 mac_id; /*Used to Set Reg42C in IBSS mode. */
+	u16 p_aid; /*@Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u8 g_id; /*Used to fill Tx DESC*/
+	u8 my_mac_addr[6];
+	u8 mac_addr[6]; /*@Used to fill Reg6E4 to fill Mac address of CSI report frame.*/
+	enum channel_width sound_bw; /*Sounding band_width*/
+	u16 sound_period;
+	enum beamforming_cap beamform_entry_cap;
+	enum beamforming_entry_state beamform_entry_state;
+	boolean is_beamforming_in_progress;
+	/*@u8	log_seq;									// Move to _RT_BEAMFORMER_ENTRY*/
+	/*@u16	log_retry_cnt:3;		// 0~4				// Move to _RT_BEAMFORMER_ENTRY*/
+	/*@u16	LogSuccessCnt:2;		// 0~2				// Move to _RT_BEAMFORMER_ENTRY*/
+	u16 log_status_fail_cnt : 5; /* @0~21 */
+	u16 default_csi_cnt : 5; /* @0~21 */
+	u8 csi_matrix[327];
+	u16 csi_matrix_len;
+	u8 num_of_sounding_dim;
+	u8 comp_steering_num_of_bfer;
+	u8 su_reg_index;
+	/*@For MU-MIMO*/
+	boolean is_mu_sta;
+	u8 mu_reg_index;
+	u8 gid_valid[8];
+	u8 user_position[16];
 };
 
 struct _RT_BEAMFORMER_ENTRY {
-	boolean			is_used;
+	boolean is_used;
 	/*P_AID of BFer entry is probably not used*/
-	u16				p_aid;					/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
-	u8				g_id;
-	u8				my_mac_addr[6];
-	u8				mac_addr[6];
-	enum beamforming_cap		beamform_entry_cap;
-	u8				num_of_sounding_dim;
-	u8				clock_reset_times;		/*Modified by Jeffery @2015-04-10*/
-	u8				pre_log_seq;				/*Modified by Jeffery @2015-03-30*/
-	u8				log_seq;					/*Modified by Jeffery @2014-10-29*/
-	u16				log_retry_cnt:3;			/*Modified by Jeffery @2014-10-29*/
-	u16				log_success:2;			/*Modified by Jeffery @2014-10-29*/
-	u8				su_reg_index;
-	/*For MU-MIMO*/
-	boolean				is_mu_ap;
-	u8				gid_valid[8];
-	u8				user_position[16];
-	u16				aid;
+	u16 p_aid; /*@Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
+	u8 g_id;
+	u8 my_mac_addr[6];
+	u8 mac_addr[6];
+	enum beamforming_cap beamform_entry_cap;
+	u8 num_of_sounding_dim;
+	u8 clock_reset_times; /*@Modified by Jeffery @2015-04-10*/
+	u8 pre_log_seq; /*@Modified by Jeffery @2015-03-30*/
+	u8 log_seq; /*@Modified by Jeffery @2014-10-29*/
+	u16 log_retry_cnt : 3; /*@Modified by Jeffery @2014-10-29*/
+	u16 log_success : 2; /*@Modified by Jeffery @2014-10-29*/
+	u8 su_reg_index;
+	/*@For MU-MIMO*/
+	boolean is_mu_ap;
+	u8 gid_valid[8];
+	u8 user_position[16];
+	u16 aid;
 };
 
 struct _RT_SOUNDING_INFO {
-	u8			sound_idx;
-	enum channel_width	sound_bw;
-	enum sounding_mode	sound_mode;
-	u16			sound_period;
+	u8 sound_idx;
+	enum channel_width sound_bw;
+	enum sounding_mode sound_mode;
+	u16 sound_period;
 };
 
-
-
 struct _RT_BEAMFORMING_OID_INFO {
-	u8			sound_oid_idx;
-	enum channel_width	sound_oid_bw;
-	enum sounding_mode	sound_oid_mode;
-	u16			sound_oid_period;
+	u8 sound_oid_idx;
+	enum channel_width sound_oid_bw;
+	enum sounding_mode sound_oid_mode;
+	u16 sound_oid_period;
 };
 
-
 struct _RT_BEAMFORMING_INFO {
-	enum beamforming_cap			beamform_cap;
-	struct _RT_BEAMFORMEE_ENTRY		beamformee_entry[BEAMFORMEE_ENTRY_NUM];
-	struct _RT_BEAMFORMER_ENTRY		beamformer_entry[BEAMFORMER_ENTRY_NUM];
-	struct _RT_BEAMFORM_STAINFO		beamform_sta_info;
-	u8					beamformee_cur_idx;
-	struct timer_list					beamforming_timer;
-	struct timer_list					mu_timer;
-	struct _RT_SOUNDING_INFO			sounding_info;
-	struct _RT_BEAMFORMING_OID_INFO	beamforming_oid_info;
-	struct _HAL_TXBF_INFO			txbf_info;
-	u8					sounding_sequence;
-	u8					beamformee_su_cnt;
-	u8					beamformer_su_cnt;
-	u32					beamformee_su_reg_maping;
-	u32					beamformer_su_reg_maping;
-	/*For MU-MINO*/
-	u8					beamformee_mu_cnt;
-	u8					beamformer_mu_cnt;
-	u32					beamformee_mu_reg_maping;
-	u8					mu_ap_index;
-	boolean					is_mu_sounding;
-	u8					first_mu_bfee_index;
-	boolean					is_mu_sounding_in_progress;
-	boolean					dbg_disable_mu_tx;
-	boolean					apply_v_matrix;
-	boolean					snding3ss;
+	enum beamforming_cap beamform_cap;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry[BEAMFORMEE_ENTRY_NUM];
+	struct _RT_BEAMFORMER_ENTRY beamformer_entry[BEAMFORMER_ENTRY_NUM];
+	struct _RT_BEAMFORM_STAINFO beamform_sta_info;
+	u8 beamformee_cur_idx;
+	struct phydm_timer_list beamforming_timer;
+	struct phydm_timer_list mu_timer;
+	struct _RT_SOUNDING_INFO sounding_info;
+	struct _RT_BEAMFORMING_OID_INFO beamforming_oid_info;
+	struct _HAL_TXBF_INFO txbf_info;
+	u8 sounding_sequence;
+	u8 beamformee_su_cnt;
+	u8 beamformer_su_cnt;
+	u32 beamformee_su_reg_maping;
+	u32 beamformer_su_reg_maping;
+	/*@For MU-MINO*/
+	u8 beamformee_mu_cnt;
+	u8 beamformer_mu_cnt;
+	u32 beamformee_mu_reg_maping;
+	u8 mu_ap_index;
+	boolean is_mu_sounding;
+	u8 first_mu_bfee_index;
+	boolean is_mu_sounding_in_progress;
+	boolean dbg_disable_mu_tx;
+	boolean apply_v_matrix;
+	boolean snding3ss;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER				*source_adapter;
+	void *source_adapter;
 #endif
-	/* Control register */
-	u32					reg_mu_tx_ctrl;		/* For USB/SDIO interfaces aync I/O */
-	u8					tx_bf_data_rate;
-	u8					last_usb_hub;
+	/* @Control register */
+	u32 reg_mu_tx_ctrl; /* @For USB/SDIO interfaces aync I/O */
+	u8 tx_bf_data_rate;
+	u8 last_usb_hub;
 };
 
+void phydm_get_txbf_device_num(
+	void *dm_void,
+	u8 macid);
 
 struct _RT_NDPA_STA_INFO {
-	u16	aid:12;
-	u16	feedback_type:1;
-	u16	nc_index:3;
+	u16 aid : 12;
+	u16 feedback_type : 1;
+	u16 nc_index : 3;
 };
 
 enum phydm_acting_type {
@@ -238,158 +242,123 @@ enum phydm_acting_type {
 	phydm_acting_as_ap = 1
 };
 
-
 enum beamforming_cap
 phydm_beamforming_get_entry_beam_cap_by_mac_id(
-	void	*p_dm_void,
-	u8	mac_id
-);
+	void *dm_void,
+	u8 mac_id);
 
 struct _RT_BEAMFORMEE_ENTRY *
 phydm_beamforming_get_bfee_entry_by_addr(
-	void		*p_dm_void,
-	u8		*RA,
-	u8		*idx
-);
+	void *dm_void,
+	u8 *RA,
+	u8 *idx);
 
 struct _RT_BEAMFORMER_ENTRY *
 phydm_beamforming_get_bfer_entry_by_addr(
-	void	*p_dm_void,
-	u8	*TA,
-	u8	*idx
-);
+	void *dm_void,
+	u8 *TA,
+	u8 *idx);
 
-void
-phydm_beamforming_notify(
-	void	*p_dm_void
-);
+void phydm_beamforming_notify(
+	void *dm_void);
 
 boolean
 phydm_acting_determine(
-	void		*p_dm_void,
-	enum phydm_acting_type	type
-);
-
-void
-beamforming_enter(
-	void		*p_dm_void,
-	u16	sta_idx
-);
-
-void
-beamforming_leave(
-	void		*p_dm_void,
-	u8			*RA
-);
+	void *dm_void,
+	enum phydm_acting_type type);
 
-boolean
-beamforming_start_fw(
-	void			*p_dm_void,
-	u8			idx
-);
+void beamforming_enter(void *dm_void, u16 sta_idx, u8 *my_mac_addr);
 
-void
-beamforming_check_sounding_success(
-	void			*p_dm_void,
-	boolean			status
-);
+void beamforming_leave(
+	void *dm_void,
+	u8 *RA);
 
-void
-phydm_beamforming_end_sw(
-	void		*p_dm_void,
-	boolean			status
-);
+boolean
+beamforming_start_fw(
+	void *dm_void,
+	u8 idx);
 
-void
-beamforming_timer_callback(
-	void			*p_dm_void
-);
+void beamforming_check_sounding_success(
+	void *dm_void,
+	boolean status);
 
-void
-phydm_beamforming_init(
-	void		*p_dm_void
-);
+void phydm_beamforming_end_sw(
+	void *dm_void,
+	boolean status);
 
+void beamforming_timer_callback(
+	void *dm_void);
 
+void phydm_beamforming_init(
+	void *dm_void);
 
 enum beamforming_cap
 phydm_beamforming_get_beam_cap(
-	void			*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info
-);
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info);
 
 enum beamforming_cap
 phydm_get_beamform_cap(
-	void			*p_dm_void
-);
+	void *dm_void);
 
 boolean
 beamforming_control_v1(
-	void			*p_dm_void,
-	u8			*RA,
-	u8			AID,
-	u8			mode,
-	enum channel_width	BW,
-	u8			rate
-);
-
+	void *dm_void,
+	u8 *RA,
+	u8 AID,
+	u8 mode,
+	enum channel_width BW,
+	u8 rate);
 
 boolean
 phydm_beamforming_control_v2(
-	void		*p_dm_void,
-	u8			idx,
-	u8			mode,
-	enum channel_width	BW,
-	u16			period
-);
-
-void
-phydm_beamforming_watchdog(
-	void		*p_dm_void
-);
-
-void
-beamforming_sw_timer_callback(
+	void *dm_void,
+	u8 idx,
+	u8 mode,
+	enum channel_width BW,
+	u16 period);
+
+void phydm_beamforming_watchdog(
+	void *dm_void);
+
+void beamforming_sw_timer_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct timer_list		*p_timer
+	struct phydm_timer_list *timer
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 	void *function_context
 #endif
-);
+	);
 
 boolean
 beamforming_send_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW,
-	u8			q_idx
-);
-
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW,
+	u8 q_idx);
 
 boolean
 beamforming_send_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW,
-	u8			q_idx
-);
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW,
+	u8 q_idx);
 
 #else
-#define beamforming_gid_paid(adapter, p_tcb)
-#define	phydm_acting_determine(p_dm, type)	false
-#define beamforming_enter(p_dm, sta_idx)
-#define beamforming_leave(p_dm, RA)
-#define beamforming_end_fw(p_dm)
-#define beamforming_control_v1(p_dm, RA, AID, mode, BW, rate)		true
-#define beamforming_control_v2(p_dm, idx, mode, BW, period)		true
-#define phydm_beamforming_end_sw(p_dm, _status)
-#define beamforming_timer_callback(p_dm)
-#define phydm_beamforming_init(p_dm)
-#define phydm_beamforming_control_v2(p_dm, _idx, _mode, _BW, _period)	false
-#define beamforming_watchdog(p_dm)
-#define phydm_beamforming_watchdog(p_dm)
-
-
-#endif
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_AP))
+#define beamforming_gid_paid(adapter, tcb)
+#define phydm_acting_determine(dm, type) false
+#define beamforming_enter(dm, sta_idx, my_mac_addr)
+#define beamforming_leave(dm, RA)
+#define beamforming_end_fw(dm)
+#define beamforming_control_v1(dm, RA, AID, mode, BW, rate) true
+#define beamforming_control_v2(dm, idx, mode, BW, period) true
+#define phydm_beamforming_end_sw(dm, _status)
+#define beamforming_timer_callback(dm)
+#define phydm_beamforming_init(dm)
+#define phydm_beamforming_control_v2(dm, _idx, _mode, _BW, _period) false
+#define beamforming_watchdog(dm)
+#define phydm_beamforming_watchdog(dm)
+#endif /*@(DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))*/
+#endif /*@#ifdef PHYDM_BEAMFORMING_SUPPORT*/
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.c
index 1f1eba95cb8d..2d1f7472ac3d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,448 +9,1079 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
- 
+
 #ifdef PHYDM_SUPPORT_CCKPD
+#ifdef PHYDM_COMPILE_CCKPD_TYPE1
+void phydm_write_cck_pd_type1(void *dm_void, u8 cca_th)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "[%s] cck_cca_th=((0x%x))\n",
+		  __func__, cca_th);
+
+	odm_write_1byte(dm, R_0xa0a, cca_th);
+	cckpd_t->cur_cck_cca_thres = cca_th;
+}
 
-void
-phydm_write_cck_cca_th_new_cs_ratio(
-	void			*p_dm_void,
-	u8			cca_th,
-	u8			cca_th_aaa
-)
+void phydm_set_cckpd_lv_type1(void *dm_void, enum cckpd_lv lv)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cckpd_struct	*p_cckpd_t = &p_dm->dm_cckpd_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u8 pd_th = 0;
 
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("[New] pd_th=0x%x, cs_ratio=0x%x\n\n", cca_th, cca_th_aaa));
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "lv: (%d) -> (%d)\n", cckpd_t->cck_pd_lv, lv);
 
-	if (p_cckpd_t->cur_cck_cca_thres != cca_th) {
-		
-		p_cckpd_t->cur_cck_cca_thres = cca_th;
-		odm_set_bb_reg(p_dm, 0xa08, 0xf0000, cca_th);
-		p_cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
-		
+	if (cckpd_t->cck_pd_lv == lv) {
+		PHYDM_DBG(dm, DBG_CCKPD, "stay in lv=%d\n", lv);
+		return;
 	}
 
-	if (p_cckpd_t->cck_cca_th_aaa != cca_th_aaa) {
-		
-		p_cckpd_t->cck_cca_th_aaa = cca_th_aaa;
-		odm_set_bb_reg(p_dm, 0xaa8, 0x1f0000, cca_th_aaa);
-		p_cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
-	}
-	
+	cckpd_t->cck_pd_lv = lv;
+	cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+
+	if (lv == CCK_PD_LV_4)
+		pd_th = 0xed;
+	else if (lv == CCK_PD_LV_3)
+		pd_th = 0xdd;
+	else if (lv == CCK_PD_LV_2)
+		pd_th = 0xcd;
+	else if (lv == CCK_PD_LV_1)
+		pd_th = 0x83;
+	else if (lv == CCK_PD_LV_0)
+		pd_th = 0x40;
+
+	phydm_write_cck_pd_type1(dm, pd_th);
 }
 
-void
-phydm_write_cck_cca_th(
-	void			*p_dm_void,
-	u8			cca_th
-)
+void phydm_cckpd_type1(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cckpd_struct	*p_cckpd_t = &p_dm->dm_cckpd_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	enum cckpd_lv lv = CCK_PD_LV_INIT;
+	boolean is_update = true;
 
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("New cck_cca_th=((0x%x))\n\n", cca_th));
+	if (dm->is_linked) {
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		if (dm->rssi_min > 60) {
+			lv = CCK_PD_LV_3;
+		} else if (dm->rssi_min > 35) {
+			lv = CCK_PD_LV_2;
+		} else if (dm->rssi_min > 20) {
+			if (cckpd_t->cck_fa_ma > 500)
+				lv = CCK_PD_LV_2;
+			else if (cckpd_t->cck_fa_ma < 250)
+				lv = CCK_PD_LV_1;
+			else
+				is_update = false;
+		} else { /*RSSI < 20*/
+			lv = CCK_PD_LV_1;
+		}
+	#else /*ODM_AP*/
+		if (dig_t->cur_ig_value > 0x32)
+			lv = CCK_PD_LV_4;
+		else if (dig_t->cur_ig_value > 0x2a)
+			lv = CCK_PD_LV_3;
+		else if (dig_t->cur_ig_value > 0x24)
+			lv = CCK_PD_LV_2;
+		else
+			lv = CCK_PD_LV_1;
+	#endif
+	} else {
+		if (cckpd_t->cck_fa_ma > 1000)
+			lv = CCK_PD_LV_1;
+		else if (cckpd_t->cck_fa_ma < 500)
+			lv = CCK_PD_LV_0;
+		else
+			is_update = false;
+	}
 
-	if (p_cckpd_t->cur_cck_cca_thres != cca_th) {
-		
-		odm_write_1byte(p_dm, ODM_REG(CCK_CCA, p_dm), cca_th);
-		p_cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+	/*[Abnormal case] =================================================*/
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	/*@HP 22B LPS power consumption issue & [PCIE-1596]*/
+	if (dm->hp_hw_id && dm->traffic_load == TRAFFIC_ULTRA_LOW) {
+		lv = CCK_PD_LV_0;
+		PHYDM_DBG(dm, DBG_CCKPD, "CCKPD Abnormal case1\n");
+	} else if ((dm->p_advance_ota & PHYDM_ASUS_OTA_SETTING) &&
+	    cckpd_t->cck_fa_ma > 200 && dm->rssi_min <= 20) {
+		lv = CCK_PD_LV_1;
+		cckpd_t->cck_pd_lv = lv;
+		phydm_write_cck_pd_type1(dm, 0xc3); /*@for ASUS OTA test*/
+		is_update = false;
+		PHYDM_DBG(dm, DBG_CCKPD, "CCKPD Abnormal case2\n");
 	}
-	p_cckpd_t->cur_cck_cca_thres = cca_th;
+	#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+		#ifdef MCR_WIRELESS_EXTEND
+		lv = CCK_PD_LV_2;
+		cckpd_t->cck_pd_lv = lv;
+		phydm_write_cck_pd_type1(dm, 0x43);
+		is_update = false;
+		PHYDM_DBG(dm, DBG_CCKPD, "CCKPD Abnormal case3\n");
+		#endif
+	#endif
+	/*=================================================================*/
+
+	if (is_update)
+		phydm_set_cckpd_lv_type1(dm, lv);
+
+	PHYDM_DBG(dm, DBG_CCKPD, "is_linked=%d, lv=%d, pd_th=0x%x\n\n",
+		  dm->is_linked, cckpd_t->cck_pd_lv,
+		  cckpd_t->cur_cck_cca_thres);
+}
+#endif /*#ifdef PHYDM_COMPILE_CCKPD_TYPE1*/
+
+#ifdef PHYDM_COMPILE_CCKPD_TYPE2
+void phydm_write_cck_pd_type2(void *dm_void, u8 cca_th, u8 cca_th_aaa)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "[%s] pd_th=0x%x, cs_ratio=0x%x\n",
+		  __func__, cca_th, cca_th_aaa);
+
+	odm_set_bb_reg(dm, R_0xa08, 0x3f0000, cca_th);
+	odm_set_bb_reg(dm, R_0xaa8, 0x1f0000, cca_th_aaa);
+	cckpd_t->cur_cck_cca_thres = cca_th;
+	cckpd_t->cck_cca_th_aaa = cca_th_aaa;
 }
 
-void
-phydm_set_cckpd_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-)
+void phydm_set_cckpd_lv_type2(void *dm_void, enum cckpd_lv lv)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u8 pd_th = 0, cs_ratio = 0, cs_2r_offset = 0;
+	u8 cck_n_rx = 1;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "lv: (%d) -> (%d)\n", cckpd_t->cck_pd_lv, lv);
 
+	/*@r_mrx & r_cca_mrc*/
+	cck_n_rx = (odm_get_bb_reg(dm, R_0xa2c, BIT(18)) &&
+		    odm_get_bb_reg(dm, R_0xa2c, BIT(22))) ? 2 : 1;
 
-	if (val_len != 2) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[Error][CCKPD]Need val_len=2\n"));
+	if (cckpd_t->cck_pd_lv == lv && cckpd_t->cck_n_rx == cck_n_rx) {
+		PHYDM_DBG(dm, DBG_CCKPD, "stay in lv=%d\n", lv);
 		return;
 	}
-	
-	/*val_buf[0]: 0xa0a*/
-	/*val_buf[1]: 0xaaa*/
-	
-	if (p_dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC) {
-		phydm_write_cck_cca_th_new_cs_ratio(p_dm, (u8)val_buf[0], (u8)val_buf[1]);
-	} else {
-		phydm_write_cck_cca_th(p_dm, (u8)val_buf[0]);
+
+	cckpd_t->cck_n_rx = cck_n_rx;
+	cckpd_t->cck_pd_lv = lv;
+	cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+
+	if (lv == CCK_PD_LV_4) {
+		cs_ratio = cckpd_t->aaa_default + 8;
+		cs_2r_offset = 5;
+		pd_th = 0xd;
+	} else if (lv == CCK_PD_LV_3) {
+		cs_ratio = cckpd_t->aaa_default + 6;
+		cs_2r_offset = 4;
+		pd_th = 0xd;
+	} else if (lv == CCK_PD_LV_2) {
+		cs_ratio = cckpd_t->aaa_default + 4;
+		cs_2r_offset = 3;
+		pd_th = 0xd;
+	} else if (lv == CCK_PD_LV_1) {
+		cs_ratio = cckpd_t->aaa_default + 2;
+		cs_2r_offset = 1;
+		pd_th = 0x7;
+	} else if (lv == CCK_PD_LV_0) {
+		cs_ratio = cckpd_t->aaa_default;
+		cs_2r_offset = 0;
+		pd_th = 0x3;
 	}
 
+	if (cckpd_t->cck_n_rx == 2) {
+		if (cs_ratio >= cs_2r_offset)
+			cs_ratio = cs_ratio - cs_2r_offset;
+		else
+			cs_ratio = 0;
+	}
+	phydm_write_cck_pd_type2(dm, pd_th, cs_ratio);
 }
 
-boolean
-phydm_stop_cck_pd_th(
-	void		*p_dm_void
-)
+void phydm_cckpd_type2(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	enum cckpd_lv lv = CCK_PD_LV_INIT;
+	u8 igi = dig_t->cur_ig_value;
+	u8 rssi_min = dm->rssi_min;
+	boolean is_update = true;
 
-	if (!(p_dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT))) {
-		
-		PHYDM_DBG(p_dm, DBG_CCKPD, ("Not Support\n"));
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
 
-		#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-		#ifdef MCR_WIRELESS_EXTEND
-		phydm_write_cck_cca_th(p_dm, 0x43);
-		#endif
-		#endif
-		
-		return true;
+	if (dm->is_linked) {
+		if (igi > 0x38 && rssi_min > 32) {
+			lv = CCK_PD_LV_4;
+		} else if (igi > 0x2a && rssi_min > 32) {
+			lv = CCK_PD_LV_3;
+		} else if (igi > 0x24 || (rssi_min > 24 && rssi_min <= 30)) {
+			lv = CCK_PD_LV_2;
+		} else if (igi <= 0x24 || rssi_min < 22) {
+			if (cckpd_t->cck_fa_ma > 1000) {
+				lv = CCK_PD_LV_1;
+			} else if (cckpd_t->cck_fa_ma < 500) {
+				lv = CCK_PD_LV_0;
+			} else {
+				is_update = false;
+			}
+		} else {
+			is_update = false;
+		}
+	} else {
+		if (cckpd_t->cck_fa_ma > 1000) {
+			lv = CCK_PD_LV_1;
+		} else if (cckpd_t->cck_fa_ma < 500) {
+			lv = CCK_PD_LV_0;
+		} else {
+			is_update = false;
+		}
 	}
 
-	if (p_dm->pause_ability & ODM_BB_CCK_PD) {
-		
-		PHYDM_DBG(p_dm, DBG_CCKPD, ("Return: Pause CCKPD in LV=%d\n", p_dm->pause_lv_table.lv_cckpd));
-		return true;
+	/*[Abnormal case] =================================================*/
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	/*@21C Miracast lag issue & [PCIE-3298]*/
+	if (dm->support_ic_type & ODM_RTL8821C && rssi_min > 60) {
+		lv = CCK_PD_LV_4;
+		cckpd_t->cck_pd_lv = lv;
+		phydm_write_cck_pd_type2(dm, 0x1d, (cckpd_t->aaa_default + 8));
+		is_update = false;
+		PHYDM_DBG(dm, DBG_CCKPD, "CCKPD Abnormal case1\n");
 	}
-
-	#if 0/*(DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))*/
-	if (p_dm->ext_lna)
-		return true;
 	#endif
+	/*=================================================================*/
 
-	return false;
-	
+	if (is_update) {
+		phydm_set_cckpd_lv_type2(dm, lv);
+	}
+
+	PHYDM_DBG(dm, DBG_CCKPD,
+		  "is_linked=%d, lv=%d, n_rx=%d, cs_ratio=0x%x, pd_th=0x%x\n\n",
+		  dm->is_linked, cckpd_t->cck_pd_lv, cckpd_t->cck_n_rx,
+		  cckpd_t->cck_cca_th_aaa, cckpd_t->cur_cck_cca_thres);
 }
+#endif /*#ifdef PHYDM_COMPILE_CCKPD_TYPE2*/
 
-void
-phydm_cckpd(
-	void			*p_dm_void
-)
+#ifdef PHYDM_COMPILE_CCKPD_TYPE3
+void phydm_write_cck_pd_type3(void *dm_void, u8 pd_th, u8 cs_ratio,
+			      enum cckpd_mode mode)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct phydm_cckpd_struct	*p_cckpd_t = &p_dm->dm_cckpd_table;
-	u8	cur_cck_cca_th= p_cckpd_t->cur_cck_cca_thres;
-
-	if (p_dm->is_linked) {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-
-		/*Add hp_hw_id condition due to 22B LPS power consumption issue and [PCIE-1596]*/
-		if (p_dm->hp_hw_id && (p_dm->traffic_load == TRAFFIC_ULTRA_LOW))
-			cur_cck_cca_th = 0x40;
-		else if (p_dm->rssi_min > 35)
-			cur_cck_cca_th = 0xcd;
-		else if (p_dm->rssi_min > 20) {
-			
-			if (p_cckpd_t->cck_fa_ma > 500)
-				cur_cck_cca_th = 0xcd;
-			else if (p_cckpd_t->cck_fa_ma < 250)
-				cur_cck_cca_th = 0x83;
-			
-		} else {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
 
-			if((p_dm->p_advance_ota & PHYDM_ASUS_OTA_SETTING) && (p_cckpd_t->cck_fa_ma > 200))
-				cur_cck_cca_th = 0xc3; /*for ASUS OTA test*/
-			else
-				cur_cck_cca_th = 0x83;
+	PHYDM_DBG(dm, DBG_CCKPD,
+		  "[%s] mode=%d, pd_th=0x%x, cs_ratio=0x%x\n", __func__,
+		  mode, pd_th, cs_ratio);
+
+	switch (mode) {
+	case CCK_BW20_1R: /*RFBW20_1R*/
+	{
+		cckpd_t->cur_cck_pd_20m_1r = pd_th;
+		cckpd_t->cur_cck_cs_ratio_20m_1r = cs_ratio;
+		odm_set_bb_reg(dm, R_0xac8, 0xff, pd_th);
+		odm_set_bb_reg(dm, R_0xad0, 0x1f, cs_ratio);
+	} break;
+	case CCK_BW20_2R: /*RFBW20_2R*/
+	{
+		cckpd_t->cur_cck_pd_20m_2r = pd_th;
+		cckpd_t->cur_cck_cs_ratio_20m_2r = cs_ratio;
+		odm_set_bb_reg(dm, R_0xac8, 0xff00, pd_th);
+		odm_set_bb_reg(dm, R_0xad0, 0x3e0, cs_ratio);
+	} break;
+	case CCK_BW40_1R: /*RFBW40_1R*/
+	{
+		cckpd_t->cur_cck_pd_40m_1r = pd_th;
+		cckpd_t->cur_cck_cs_ratio_40m_1r = cs_ratio;
+		odm_set_bb_reg(dm, R_0xacc, 0xff, pd_th);
+		odm_set_bb_reg(dm, R_0xad0, 0x1f00000, cs_ratio);
+	} break;
+	case CCK_BW40_2R: /*RFBW40_2R*/
+	{
+		cckpd_t->cur_cck_pd_40m_2r = pd_th;
+		cckpd_t->cur_cck_cs_ratio_40m_2r = cs_ratio;
+		odm_set_bb_reg(dm, R_0xacc, 0xff00, pd_th);
+		odm_set_bb_reg(dm, R_0xad0, 0x3e000000, cs_ratio);
+	} break;
+
+	default:
+		/*@pr_debug("[%s] warning!\n", __func__);*/
+		break;
+	}
+}
+
+void phydm_set_cckpd_lv_type3(void *dm_void, enum cckpd_lv lv)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	enum cckpd_mode cck_mode = CCK_BW20_2R;
+	enum channel_width cck_bw = CHANNEL_WIDTH_20;
+	u8 cck_n_rx = 1;
+	u8 pd_th;
+	u8 cs_ratio;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "lv: (%d) -> (%d)\n", cckpd_t->cck_pd_lv, lv);
+
+	/*[Check Nrx]*/
+	cck_n_rx = (odm_get_bb_reg(dm, R_0xa2c, BIT(17))) ? 2 : 1;
+
+	/*[Check BW]*/
+	if (odm_get_bb_reg(dm, R_0x800, BIT(0)))
+		cck_bw = CHANNEL_WIDTH_40;
+	else
+		cck_bw = CHANNEL_WIDTH_20;
+
+	/*[Check LV]*/
+	if (cckpd_t->cck_pd_lv == lv &&
+	    cckpd_t->cck_n_rx == cck_n_rx &&
+	    cckpd_t->cck_bw == cck_bw) {
+		PHYDM_DBG(dm, DBG_CCKPD, "stay in lv=%d\n", lv);
+		return;
+	}
+
+	cckpd_t->cck_bw = cck_bw;
+	cckpd_t->cck_n_rx = cck_n_rx;
+	cckpd_t->cck_pd_lv = lv;
+	cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+
+	if (cck_n_rx == 2) {
+		if (cck_bw == CHANNEL_WIDTH_20) {
+			pd_th = cckpd_t->cck_pd_20m_2r;
+			cs_ratio = cckpd_t->cck_cs_ratio_20m_2r;
+			cck_mode = CCK_BW20_2R;
+		} else {
+			pd_th = cckpd_t->cck_pd_40m_2r;
+			cs_ratio = cckpd_t->cck_cs_ratio_40m_2r;
+			cck_mode = CCK_BW40_2R;
 		}
-		
-#else	/*ODM_AP*/
-		if (p_dig_t->cur_ig_value > 0x32)
-			cur_cck_cca_th = 0xed;
-		else if (p_dig_t->cur_ig_value > 0x2a)
-			cur_cck_cca_th = 0xdd;
-		else if (p_dig_t->cur_ig_value > 0x24)
-			cur_cck_cca_th = 0xcd;
-		else 
-			cur_cck_cca_th = 0x83;
-		
-#endif
 	} else {
-	
-		if (p_cckpd_t->cck_fa_ma > 1000)
-			cur_cck_cca_th = 0x83;
-		else if (p_cckpd_t->cck_fa_ma < 500)
-			cur_cck_cca_th = 0x40;
+		if (cck_bw == CHANNEL_WIDTH_20) {
+			pd_th = cckpd_t->cck_pd_20m_1r;
+			cs_ratio = cckpd_t->cck_cs_ratio_20m_1r;
+			cck_mode = CCK_BW20_1R;
+		} else {
+			pd_th = cckpd_t->cck_pd_40m_1r;
+			cs_ratio = cckpd_t->cck_cs_ratio_40m_1r;
+			cck_mode = CCK_BW40_1R;
+		}
 	}
 
-	phydm_write_cck_cca_th(p_dm, cur_cck_cca_th);
-	/*PHYDM_DBG(p_dm, DBG_CCKPD, ("New cck_cca_th=((0x%x))\n\n", cur_cck_cca_th));*/
+	if (lv == CCK_PD_LV_4) {
+		if (cck_n_rx == 2) {
+			pd_th += 4;
+			cs_ratio += 2;
+		} else {
+			pd_th += 4;
+			cs_ratio += 3;
+		}
+	} else if (lv == CCK_PD_LV_3) {
+		if (cck_n_rx == 2) {
+			pd_th += 3;
+			cs_ratio += 1;
+		} else {
+			pd_th += 3;
+			cs_ratio += 2;
+		}
+	} else if (lv == CCK_PD_LV_2) {
+		pd_th += 2;
+		cs_ratio += 1;
+	} else if (lv == CCK_PD_LV_1) {
+		pd_th += 1;
+		cs_ratio += 1;
+	}
+	#if 0
+	else if (lv == CCK_PD_LV_0) {
+		pd_th += 0;
+		cs_ratio += 0;
+	}
+	#endif
 
+	phydm_write_cck_pd_type3(dm, pd_th, cs_ratio, cck_mode);
 }
 
-void
-phydm_cckpd_new_cs_ratio(
-	void			*p_dm_void
-)
+void phydm_cckpd_type3(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct phydm_cckpd_struct	*p_cckpd_t = &p_dm->dm_cckpd_table;
-	u8	pd_th = 0, cs_ration = 0, cs_2r_offset = 0;
-	u8	igi_curr = p_dig_t->cur_ig_value;
-	u8	en_2rcca;
-
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("%s ======>\n", __func__));
-
-	en_2rcca = (u8)(odm_get_bb_reg(p_dm, 0xa2c, BIT(18)) && odm_get_bb_reg(p_dm, 0xa2c, BIT(22)));
-
-	if (p_dm->is_linked) {
-		
-		if ((igi_curr > 0x38) && (p_dm->rssi_min > 32)) {
-			cs_ration = p_dig_t->aaa_default + AAA_BASE + AAA_STEP * 2;
-			cs_2r_offset = 5;
-			pd_th = 0xd;
-		} else if ((igi_curr > 0x2a) && (p_dm->rssi_min > 32)) {
-			cs_ration = p_dig_t->aaa_default + AAA_BASE + AAA_STEP;
-			cs_2r_offset = 4;
-			pd_th = 0xd;
-		} else if ((igi_curr > 0x24) || (p_dm->rssi_min > 24 && p_dm->rssi_min <= 30)) {
-			cs_ration = p_dig_t->aaa_default + AAA_BASE;
-			cs_2r_offset = 3;
-			pd_th = 0xd;
-		} else if ((igi_curr <= 0x24) || (p_dm->rssi_min < 22)) {
-			
-			if (p_cckpd_t->cck_fa_ma > 1000) {
-				cs_ration = p_dig_t->aaa_default + AAA_STEP;
-				cs_2r_offset = 1;
-				pd_th = 0x7;
-			} else if (p_cckpd_t->cck_fa_ma < 500) {
-				cs_ration = p_dig_t->aaa_default;
-				pd_th = 0x3;
-			} else {
-				cs_ration = p_cckpd_t->cck_cca_th_aaa;
-				pd_th = p_cckpd_t->cur_cck_cca_thres;
-			}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	enum cckpd_lv lv = CCK_PD_LV_INIT;
+	u8 igi = dm->dm_dig_table.cur_ig_value;
+	boolean is_update = true;
+	u8 pd_th = 0;
+	u8 cs_ratio = 0;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	if (dm->is_linked) {
+		if (igi > 0x38 && dm->rssi_min > 32) {
+			lv = CCK_PD_LV_4;
+		} else if ((igi > 0x2a) && (dm->rssi_min > 32)) {
+			lv = CCK_PD_LV_3;
+		} else if ((igi > 0x24) ||
+			   (dm->rssi_min > 24 && dm->rssi_min <= 30)) {
+			lv = CCK_PD_LV_2;
+		} else if ((igi <= 0x24) || (dm->rssi_min < 22)) {
+			if (cckpd_t->cck_fa_ma > 1000)
+				lv = CCK_PD_LV_1;
+			else if (cckpd_t->cck_fa_ma < 500)
+				lv = CCK_PD_LV_0;
+			else
+				is_update = false;
 		}
 	} else {
-	
-		if (p_cckpd_t->cck_fa_ma > 1000) {
-			cs_ration = p_dig_t->aaa_default + AAA_STEP;
-			cs_2r_offset = 1;
-			pd_th = 0x7;
-		} else if (p_cckpd_t->cck_fa_ma < 500) {
-			cs_ration = p_dig_t->aaa_default;
-			pd_th = 0x3;
+		if (cckpd_t->cck_fa_ma > 1000)
+			lv = CCK_PD_LV_1;
+		else if (cckpd_t->cck_fa_ma < 500)
+			lv = CCK_PD_LV_0;
+		else
+			is_update = false;
+	}
+
+	if (is_update)
+		phydm_set_cckpd_lv_type3(dm, lv);
+
+	if (cckpd_t->cck_n_rx == 2) {
+		if (cckpd_t->cck_bw == CHANNEL_WIDTH_20) {
+			pd_th = cckpd_t->cur_cck_pd_20m_2r;
+			cs_ratio = cckpd_t->cur_cck_cs_ratio_20m_2r;
+		} else {
+			pd_th = cckpd_t->cur_cck_pd_40m_2r;
+			cs_ratio = cckpd_t->cur_cck_cs_ratio_40m_2r;
+		}
+	} else {
+		if (cckpd_t->cck_bw == CHANNEL_WIDTH_20) {
+			pd_th = cckpd_t->cur_cck_pd_20m_1r;
+			cs_ratio = cckpd_t->cur_cck_cs_ratio_20m_1r;
 		} else {
-			cs_ration = p_cckpd_t->cck_cca_th_aaa;
-			pd_th = p_cckpd_t->cur_cck_cca_thres;
+			pd_th = cckpd_t->cur_cck_pd_40m_1r;
+			cs_ratio = cckpd_t->cur_cck_cs_ratio_40m_1r;
 		}
 	}
-	
-	if (en_2rcca)
-		cs_ration = (cs_ration >= cs_2r_offset) ? (cs_ration - cs_2r_offset) : 0;
+	PHYDM_DBG(dm, DBG_CCKPD,
+		  "[%dR][%dM] is_linked=%d, lv=%d, cs_ratio=0x%x, pd_th=0x%x\n\n",
+		  cckpd_t->cck_n_rx, 20 << cckpd_t->cck_bw, dm->is_linked,
+		  cckpd_t->cck_pd_lv, cs_ratio, pd_th);
+}
 
-	p_cckpd_t->cur_cck_cca_thres = pd_th;
-	p_cckpd_t->cck_cca_th_aaa = cs_ration;
+void phydm_cck_pd_init_type3(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u32 reg_tmp = 0;
 
-	PHYDM_DBG(p_dm, DBG_CCKPD, 
-	("[New] cs_ratio=0x%x, pd_th=0x%x\n", cs_ration, pd_th));
+	/*Get Default value*/
+	cckpd_t->cck_pd_20m_1r = (u8)odm_get_bb_reg(dm, R_0xac8, 0xff);
+	cckpd_t->cck_pd_20m_2r = (u8)odm_get_bb_reg(dm, R_0xac8, 0xff00);
+	cckpd_t->cck_pd_40m_1r = (u8)odm_get_bb_reg(dm, R_0xacc, 0xff);
+	cckpd_t->cck_pd_40m_2r = (u8)odm_get_bb_reg(dm, R_0xacc, 0xff00);
 
-	odm_set_bb_reg(p_dm, 0xa08, 0xf0000, pd_th);
-	odm_set_bb_reg(p_dm, 0xaa8, 0x1f0000, cs_ration);
+	reg_tmp = odm_get_bb_reg(dm, R_0xad0, MASKDWORD);
+	cckpd_t->cck_cs_ratio_20m_1r = (u8)(reg_tmp & 0x1f);
+	cckpd_t->cck_cs_ratio_20m_2r = (u8)((reg_tmp & 0x3e0) >> 5);
+	cckpd_t->cck_cs_ratio_40m_1r = (u8)((reg_tmp & 0x1f00000) >> 20);
+	cckpd_t->cck_cs_ratio_40m_2r = (u8)((reg_tmp & 0x3e000000) >> 25);
 
-	/*phydm_write_cck_cca_th_new_cs_ratio(p_dm, pd_th, cs_ration);*/
+	phydm_set_cckpd_lv_type3(dm, CCK_PD_LV_0);
 }
+#endif /*#ifdef PHYDM_COMPILE_CCKPD_TYPE3*/
 
-#endif
-
-void
-phydm_cck_pd_th(
-	void		*p_dm_void
-)
+#ifdef PHYDM_COMPILE_CCKPD_TYPE4
+void phydm_write_cck_pd_type4(void *dm_void, enum cckpd_lv lv,
+			      enum cckpd_mode mode)
 {
-#ifdef PHYDM_SUPPORT_CCKPD
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_struct		*p_fa_t= &p_dm->false_alm_cnt;
-	struct phydm_cckpd_struct	*p_cckpd_t = &p_dm->dm_cckpd_table;
-	u32	cnt_cck_fail_tmp = p_fa_t->cnt_cck_fail;
-	#ifdef PHYDM_TDMA_DIG_SUPPORT
-	struct phydm_fa_acc_struct	*p_fa_acc_t = &p_dm->false_alm_cnt_acc;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u32 val = 0;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "write CCK CCA parameters(CS_ratio & PD)\n");
+	switch (mode) {
+	case CCK_BW20_1R: /*RFBW20_1R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[0][0][0][lv];
+		odm_set_bb_reg(dm, R_0x1ac8, 0xff, val);
+		val = cckpd_t->cck_pd_table_jgr3[0][0][1][lv];
+		odm_set_bb_reg(dm, R_0x1ad0, 0x1f, val);
+	} break;
+	case CCK_BW40_1R: /*RFBW40_1R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[1][0][0][lv];
+		odm_set_bb_reg(dm, R_0x1acc, 0xff, val);
+		val = cckpd_t->cck_pd_table_jgr3[1][0][1][lv];
+		odm_set_bb_reg(dm, R_0x1ad0, 0x01F00000, val);
+	} break;
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	case CCK_BW20_2R: /*RFBW20_2R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[0][1][0][lv];
+		odm_set_bb_reg(dm, R_0x1ac8, 0xff00, val);
+		val = cckpd_t->cck_pd_table_jgr3[0][1][1][lv];
+		odm_set_bb_reg(dm, R_0x1ad0, 0x3e0, val);
+	} break;
+	case CCK_BW40_2R: /*RFBW40_2R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[1][1][0][lv];
+		odm_set_bb_reg(dm, R_0x1acc, 0xff00, val);
+		val = cckpd_t->cck_pd_table_jgr3[1][1][1][lv];
+		odm_set_bb_reg(dm, R_0x1ad0, 0x3E000000, val);
+	} break;
 	#endif
-	
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("%s ======>\n", __func__));
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	case CCK_BW20_3R: /*RFBW20_3R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[0][2][0][lv];
+		odm_set_bb_reg(dm, R_0x1ac8, 0xff0000, val);
+		val = cckpd_t->cck_pd_table_jgr3[0][2][1][lv];
+		odm_set_bb_reg(dm, R_0x1ad0, 0x7c00, val);
+	} break;
+	case CCK_BW40_3R: /*RFBW40_3R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[1][2][0][lv];
+		odm_set_bb_reg(dm, R_0x1acc, 0xff0000, val);
+		val = cckpd_t->cck_pd_table_jgr3[1][2][1][lv] & 0x3;
+		odm_set_bb_reg(dm, R_0x1ad0, 0xC0000000, val);
+		val = (cckpd_t->cck_pd_table_jgr3[1][2][1][lv] & 0x1c) >> 2;
+		odm_set_bb_reg(dm, R_0x1ad4, 0x7, val);
+	} break;
+	#endif
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	case CCK_BW20_4R: /*RFBW20_4R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[0][3][0][lv];
+		odm_set_bb_reg(dm, R_0x1ac8, 0xff000000, val);
+		val = cckpd_t->cck_pd_table_jgr3[0][3][1][lv];
+		odm_set_bb_reg(dm, R_0x1ad0, 0xF8000, val);
+	} break;
+	case CCK_BW40_4R: /*RFBW40_4R*/
+	{
+		val = cckpd_t->cck_pd_table_jgr3[1][3][0][lv];
+		odm_set_bb_reg(dm, R_0x1acc, 0xff000000, val);
+		val = cckpd_t->cck_pd_table_jgr3[1][3][1][lv];
+		odm_set_bb_reg(dm, R_0x1ad4, 0xf8, val);
+	} break;
+	#endif
+	default:
+		/*@pr_debug("[%s] warning!\n", __func__);*/
+		break;
+	}
+}
 
-	if (phydm_stop_cck_pd_th(p_dm) == true)
-		return;
+void phydm_set_cck_pd_lv_type4(void *dm_void, enum cckpd_lv lv)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	enum cckpd_mode cck_mode = CCK_BW20_2R;
+	enum channel_width cck_bw = CHANNEL_WIDTH_20;
+	u8 cck_n_rx = 0;
+	u32 val = 0;
+	/*u32 val_dbg = 0;*/
 
-#ifdef PHYDM_TDMA_DIG_SUPPORT
-	cnt_cck_fail_tmp = (p_dm->original_dig_restore) ? (p_fa_t->cnt_cck_fail) : (p_fa_acc_t->cnt_cck_fail_1sec);
-#endif
-	
-	if (p_cckpd_t->cck_fa_ma == CCK_FA_MA_RESET)
-		p_cckpd_t->cck_fa_ma = cnt_cck_fail_tmp;
-	else {
-		p_cckpd_t->cck_fa_ma = ((p_cckpd_t->cck_fa_ma << 1) +
-									p_cckpd_t->cck_fa_ma + cnt_cck_fail_tmp) >> 2;
-	}
-	
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("CCK FA=%d\n", p_cckpd_t->cck_fa_ma));
-
-	if (p_dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC)
-		phydm_cckpd_new_cs_ratio(p_dm);
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_CCKPD, "lv: (%d) -> (%d)\n", cckpd_t->cck_pd_lv, lv);
+
+	/*[Check Nrx]*/
+	cck_n_rx = (u8)odm_get_bb_reg(dm, R_0x1a2c, 0x60000) + 1;
+
+	/*[Check BW]*/
+	val = odm_get_bb_reg(dm, R_0x9b0, 0xc);
+	if (val == 0)
+		cck_bw = CHANNEL_WIDTH_20;
+	else if (val == 1)
+		cck_bw = CHANNEL_WIDTH_40;
 	else
-		phydm_cckpd(p_dm);
-	
-#endif
+		cck_bw = CHANNEL_WIDTH_80;
+
+	/*[Check LV]*/
+	if (cckpd_t->cck_pd_lv == lv &&
+	    cckpd_t->cck_n_rx == cck_n_rx &&
+	    cckpd_t->cck_bw == cck_bw) {
+		PHYDM_DBG(dm, DBG_CCKPD, "stay in lv=%d\n", lv);
+		return;
+	}
+
+	cckpd_t->cck_bw = cck_bw;
+	cckpd_t->cck_n_rx = cck_n_rx;
+	cckpd_t->cck_pd_lv = lv;
+	cckpd_t->cck_fa_ma = CCK_FA_MA_RESET;
+
+	switch (cck_n_rx) {
+	case 1: /*1R*/
+	{
+		if (cck_bw == CHANNEL_WIDTH_20)
+			cck_mode = CCK_BW20_1R;
+		else if (cck_bw == CHANNEL_WIDTH_40)
+			cck_mode = CCK_BW40_1R;
+	} break;
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	case 2: /*2R*/
+	{
+		if (cck_bw == CHANNEL_WIDTH_20)
+			cck_mode = CCK_BW20_2R;
+		else if (cck_bw == CHANNEL_WIDTH_40)
+			cck_mode = CCK_BW40_2R;
+	} break;
+	#endif
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	case 3: /*3R*/
+	{
+		if (cck_bw == CHANNEL_WIDTH_20)
+			cck_mode = CCK_BW20_3R;
+		else if (cck_bw == CHANNEL_WIDTH_40)
+			cck_mode = CCK_BW40_3R;
+	} break;
+	#endif
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	case 4: /*4R*/
+	{
+		if (cck_bw == CHANNEL_WIDTH_20)
+			cck_mode = CCK_BW20_4R;
+		else if (cck_bw == CHANNEL_WIDTH_40)
+			cck_mode = CCK_BW40_4R;
+	} break;
+	#endif
+	default:
+		/*@pr_debug("[%s] warning!\n", __func__);*/
+		break;
+	}
+phydm_write_cck_pd_type4(dm, lv, cck_mode);
 }
 
-void
-odm_pause_cck_packet_detection(
-	void					*p_dm_void,
-	enum phydm_pause_type		pause_type,
-	enum phydm_pause_level		pause_lv,
-	u8					cck_pd_th
-)
+void phydm_read_cckpd_para_type4(void *dm_void)
 {
-#ifdef PHYDM_SUPPORT_CCKPD
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cckpd_struct	*p_cckpd_t = &p_dm->dm_cckpd_table;
-	s8	max_level;
-	u8	i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u8 bw = 0; /*r_RX_RF_BW*/
+	u8 n_rx = 0;
+	u8 curr_cck_pd_t[2][4][2];
+	u32 reg0 = 0;
+	u32 reg1 = 0;
+	u32 reg2 = 0;
+	u32 reg3 = 0;
 
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("%s ======>\n", __func__));
+	bw = (u8)odm_get_bb_reg(dm, R_0x9b0, 0xc);
+	n_rx = (u8)odm_get_bb_reg(dm, R_0x1a2c, 0x60000) + 1;
 
-	if ((p_cckpd_t->pause_bitmap == 0) &&
-		(!(p_dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT)))) {
-		
-		PHYDM_DBG(p_dm, DBG_CCKPD, ("Return: not support\n"));
-		return;
+	reg0 = odm_get_bb_reg(dm, R_0x1ac8, MASKDWORD);
+	reg1 = odm_get_bb_reg(dm, R_0x1acc, MASKDWORD);
+	reg2 = odm_get_bb_reg(dm, R_0x1ad0, MASKDWORD);
+	reg3 = odm_get_bb_reg(dm, R_0x1ad4, MASKDWORD);
+	curr_cck_pd_t[0][0][0] = (u8)(reg0 & 0x000000ff);
+	curr_cck_pd_t[1][0][0] = (u8)(reg1 & 0x000000ff);
+	curr_cck_pd_t[0][0][1] = (u8)(reg2 & 0x0000001f);
+	curr_cck_pd_t[1][0][1] = (u8)((reg2 & 0x01f00000) >> 20);
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS) {
+		curr_cck_pd_t[0][1][0] = (u8)((reg0 & 0x0000ff00) >> 8);
+		curr_cck_pd_t[1][1][0] = (u8)((reg1 & 0x0000ff00) >> 8);
+		curr_cck_pd_t[0][1][1] = (u8)((reg2 & 0x000003E0) >> 5);
+		curr_cck_pd_t[1][1][1] = (u8)((reg2 & 0x3E000000) >> 25);
 	}
+	#endif
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_3SS) {
+		curr_cck_pd_t[0][2][0] = (u8)((reg0 & 0x00ff0000) >> 16);
+		curr_cck_pd_t[1][2][0] = (u8)((reg1 & 0x00ff0000) >> 16);
+		curr_cck_pd_t[0][2][1] = (u8)((reg2 & 0x00007C00) >> 10);
+		curr_cck_pd_t[1][2][1] = (u8)((reg2 & 0xC0000000) >> 30) |
+					 (u8)((reg3 & 0x00000007) << 3);
+	}
+	#endif
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+		curr_cck_pd_t[0][3][0] = (u8)((reg0 & 0xff000000) >> 24);
+		curr_cck_pd_t[1][3][0] = (u8)((reg1 & 0xff000000) >> 24);
+		curr_cck_pd_t[0][3][1] = (u8)((reg2 & 0x000F8000) >> 15);
+		curr_cck_pd_t[1][3][1] = (u8)((reg3 & 0x000000F8) >> 3);
+	}
+	#endif
 
-	if (pause_lv >= PHYDM_PAUSE_MAX_NUM) {
-		PHYDM_DBG(p_dm, DBG_CCKPD, ("Return: Wrong LV !\n"));
-		return;
+	PHYDM_DBG(dm, DBG_CCKPD, "bw=%dM, Nrx=%d\n", 20 << bw, n_rx);
+	PHYDM_DBG(dm, DBG_CCKPD, "lv=%d, readback CS_th=0x%x, PD th=0x%x\n",
+		  cckpd_t->cck_pd_lv,
+		  curr_cck_pd_t[bw][n_rx - 1][1],
+		  curr_cck_pd_t[bw][n_rx - 1][0]);
+}
+
+void phydm_cckpd_type4(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u8 igi = dm->dm_dig_table.cur_ig_value;
+	enum cckpd_lv lv = 0;
+	boolean is_update = true;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "%s ======>\n", __func__);
+
+	if (dm->is_linked) {
+		PHYDM_DBG(dm, DBG_CCKPD, "Linked!!!\n");
+		if (igi > 0x38 && dm->rssi_min > 32) {
+			lv = CCK_PD_LV_4;
+			PHYDM_DBG(dm, DBG_CCKPD, "Order 1\n");
+		} else if (igi > 0x2a && dm->rssi_min > 32) {
+			lv = CCK_PD_LV_3;
+			PHYDM_DBG(dm, DBG_CCKPD, "Order 2\n");
+		} else if (igi > 0x24 || dm->rssi_min > 24) {
+			lv = CCK_PD_LV_2;
+			PHYDM_DBG(dm, DBG_CCKPD, "Order 3\n");
+		} else {
+			if (cckpd_t->cck_fa_ma > 1000) {
+				lv = CCK_PD_LV_1;
+				PHYDM_DBG(dm, DBG_CCKPD, "Order 4-1\n");
+			} else if (cckpd_t->cck_fa_ma < 500) {
+				lv = CCK_PD_LV_0;
+				PHYDM_DBG(dm, DBG_CCKPD, "Order 4-2\n");
+			} else {
+				is_update = false;
+				PHYDM_DBG(dm, DBG_CCKPD, "Order 4-3\n");
+			}
+		}
+	} else {
+		PHYDM_DBG(dm, DBG_CCKPD, "UnLinked!!!\n");
+		if (cckpd_t->cck_fa_ma > 1000) {
+			lv = CCK_PD_LV_1;
+			PHYDM_DBG(dm, DBG_CCKPD, "Order 1\n");
+		} else if (cckpd_t->cck_fa_ma < 500) {
+			lv = CCK_PD_LV_0;
+			PHYDM_DBG(dm, DBG_CCKPD, "Order 2\n");
+		} else {
+			is_update = false;
+			PHYDM_DBG(dm, DBG_CCKPD, "Order 3\n");
+		}
 	}
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("Set pause{Type, LV, val} = {%d, %d, 0x%x}\n", 
-		pause_type, pause_lv, cck_pd_th));
 
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("pause LV=0x%x\n", p_cckpd_t->pause_bitmap));
+	if (is_update) {
+		phydm_set_cck_pd_lv_type4(dm, lv);
 
-	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
-		PHYDM_DBG(p_dm, DBG_CCKPD, ("pause val[%d]=0x%x\n", 
-										i, p_cckpd_t->pause_cckpd_value[i]));
+		PHYDM_DBG(dm, DBG_CCKPD, "setting CS_th = 0x%x, PD th = 0x%x\n",
+			  cckpd_t->cck_pd_table_jgr3[cckpd_t->cck_bw]
+			  [cckpd_t->cck_n_rx - 1][1][lv],
+			  cckpd_t->cck_pd_table_jgr3[cckpd_t->cck_bw]
+			  [cckpd_t->cck_n_rx - 1][0][lv]);
 	}
 
-	switch (pause_type) {
+	phydm_read_cckpd_para_type4(dm);
+}
 
-	case PHYDM_PAUSE:
-	{
-		/* Disable CCK PD */
-		p_dm->support_ability &= ~ODM_BB_CCK_PD;
-		
-		PHYDM_DBG(p_dm, DBG_CCKPD, ("Pause CCK PD th\n"));
-
-		/* Backup original CCK PD threshold decided by CCK PD mechanism */
-		if (p_cckpd_t->pause_bitmap == 0) {
-			
-			p_cckpd_t->cckpd_bkp = p_cckpd_t->cur_cck_cca_thres;
-			
-			PHYDM_DBG(p_dm, DBG_CCKPD, ("cckpd_bkp=0x%x\n", 
-				p_cckpd_t->cckpd_bkp));
-		}
+void phydm_cck_pd_init_type4(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u32 reg0 = 0;
+	u32 reg1 = 0;
+	u32 reg2 = 0;
+	u32 reg3 = 0;
+	u8 pd_step = 0;
+	u8 cck_bw = 0; /*r_RX_RF_BW*/
+	u8 cck_n_rx = 0;
+	u8 val = 0;
+	u8 i = 0;
 
-		p_cckpd_t->pause_bitmap |= BIT(pause_lv); /* Update pause level */
-		p_cckpd_t->pause_cckpd_value[pause_lv] = cck_pd_th; 
+	PHYDM_DBG(dm, DBG_CCKPD, "[%s]======>\n", __func__);
 
-		/* Write new CCK PD threshold */
-		if (BIT(pause_lv + 1) > p_cckpd_t->pause_bitmap) {
+	#if 0
+	/*@
+	 *cckpd_t[0][0][0][0] =  1ac8[7:0]	r_PD_lim_RFBW20_1R
+	 *cckpd_t[0][1][0][0] =  1ac8[15:8]	r_PD_lim_RFBW20_2R
+	 *cckpd_t[0][2][0][0] =  1ac8[23:16]	r_PD_lim_RFBW20_3R
+	 *cckpd_t[0][3][0][0] =  1ac8[31:24]	r_PD_lim_RFBW20_4R
+	 *cckpd_t[1][0][0][0] =  1acc[7:0]	r_PD_lim_RFBW40_1R
+	 *cckpd_t[1][1][0][0] =  1acc[15:8]	r_PD_lim_RFBW40_2R
+	 *cckpd_t[1][2][0][0] =  1acc[23:16]	r_PD_lim_RFBW40_3R
+	 *cckpd_t[1][3][0][0] =  1acc[31:24]	r_PD_lim_RFBW40_4R
+	 *
+	 *
+	 *cckpd_t[0][0][1][0] =  1ad0[4:0]	r_CS_ratio_RFBW20_1R[4:0]
+	 *cckpd_t[0][1][1][0] =  1ad0[9:5]	r_CS_ratio_RFBW20_2R[4:0]
+	 *cckpd_t[0][2][1][0] =  1ad0[14:10]	r_CS_ratio_RFBW20_3R[4:0]
+	 *cckpd_t[0][3][1][0] =  1ad0[19:15]	r_CS_ratio_RFBW20_4R[4:0]
+	 *cckpd_t[1][0][1][0] =  1ad0[24:20]	r_CS_ratio_RFBW40_1R[4:0]
+	 *cckpd_t[1][1][1][0] =  1ad0[29:25]	r_CS_ratio_RFBW40_2R[4:0]
+	 *cckpd_t[1][2][1][0] =  1ad0[31:30]	r_CS_ratio_RFBW40_3R[1:0]
+	 *			  1ad4[2:0]	r_CS_ratio_RFBW40_3R[4:2]
+	 *cckpd_t[1][3][1][0] =  1ad4[7:3]	r_CS_ratio_RFBW40_4R[4:0]
+	 */
+	#endif
+	/*[Check Nrx]*/
+	cck_n_rx = (u8)odm_get_bb_reg(dm, R_0x1a2c, 0x60000) + 1;
 
-			PHYDM_DBG(p_dm, DBG_CCKPD, ("> ori pause LV=0x%x\n", 
-				p_cckpd_t->pause_bitmap));
-			
-			phydm_write_cck_cca_th(p_dm, cck_pd_th);
-		}
-		break;
-	}
-	case PHYDM_RESUME:
-	{
-		/* check if the level is illegal or not */
-		if ((p_cckpd_t->pause_bitmap & (BIT(pause_lv))) != 0) {
-			
-			p_cckpd_t->pause_bitmap &= (~(BIT(pause_lv)));
-			p_cckpd_t->pause_cckpd_value[pause_lv] = 0;
-			PHYDM_DBG(p_dm, DBG_CCKPD, ("Resume CCK PD\n"));
-		} else {
-		
-			PHYDM_DBG(p_dm, DBG_CCKPD, ("Wrong resume LV\n"));
-			break;
+	/*[Check BW]*/
+	val = (u8)odm_get_bb_reg(dm, R_0x9b0, 0xc);
+	if (val == 0)
+		cck_bw = CHANNEL_WIDTH_20;
+	else if (val == 1)
+		cck_bw = CHANNEL_WIDTH_40;
+	else
+		cck_bw = CHANNEL_WIDTH_80;
+
+	cckpd_t->cck_bw = cck_bw;
+	cckpd_t->cck_n_rx = cck_n_rx;
+	reg0 = odm_get_bb_reg(dm, R_0x1ac8, MASKDWORD);
+	reg1 = odm_get_bb_reg(dm, R_0x1acc, MASKDWORD);
+	reg2 = odm_get_bb_reg(dm, R_0x1ad0, MASKDWORD);
+	reg3 = odm_get_bb_reg(dm, R_0x1ad4, MASKDWORD);
+
+	for (i = 0 ; i < CCK_PD_LV_MAX ; i++) {
+		pd_step = i * 2;
+
+		val = (u8)(reg0 & 0x000000ff) + pd_step;
+		PHYDM_DBG(dm, DBG_CCKPD, "lvl %d val = %x\n\n", i, val);
+		cckpd_t->cck_pd_table_jgr3[0][0][0][i] = val;
+
+		val = (u8)(reg1 & 0x000000ff) + pd_step;
+		cckpd_t->cck_pd_table_jgr3[1][0][0][i] = val;
+
+		val = (u8)(reg2 & 0x0000001F) + pd_step;
+		cckpd_t->cck_pd_table_jgr3[0][0][1][i] = val;
+
+		val = (u8)((reg2 & 0x01F00000) >> 20) + pd_step;
+		cckpd_t->cck_pd_table_jgr3[1][0][1][i] = val;
+
+		#ifdef PHYDM_COMPILE_ABOVE_2SS
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS) {
+			val = (u8)((reg0 & 0x0000ff00) >> 8) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[0][1][0][i] = val;
+
+			val = (u8)((reg1 & 0x0000ff00) >> 8) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[1][1][0][i] = val;
+
+			val = (u8)((reg2 & 0x000003E0) >> 5) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[0][1][1][i] = val;
+
+			val = (u8)((reg2 & 0x3E000000) >> 25) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[1][1][1][i] = val;
 		}
+		#endif
 
-		/* Resume CCKPD */
-		if (p_cckpd_t->pause_bitmap == 0) {
-			
-			PHYDM_DBG(p_dm, DBG_CCKPD,("Revert bkp_CCKPD=0x%x\n", 
-														p_cckpd_t->cckpd_bkp));
-			
-			phydm_write_cck_cca_th(p_dm, p_cckpd_t->cckpd_bkp);
-			p_dm->support_ability |= ODM_BB_CCK_PD;/* Enable CCKPD */
-			break;
+		#ifdef PHYDM_COMPILE_ABOVE_3SS
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_3SS) {
+			val = (u8)((reg0 & 0x00ff0000) >> 16) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[0][2][0][i] = val;
+
+			val = (u8)((reg1 & 0x00ff0000) >> 16) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[1][2][0][i] = val;
+			val = (u8)((reg2 & 0x00007C00) >> 10) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[0][2][1][i] = val;
+			val = (u8)(((reg2 & 0xC0000000) >> 30) |
+			      ((reg3 & 0x7) << 3)) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[1][2][1][i] = val;
 		}
+		#endif
 
-		if (BIT(pause_lv) > p_cckpd_t->pause_bitmap) {
+		#ifdef PHYDM_COMPILE_ABOVE_4SS
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+			val = (u8)((reg0 & 0xff000000) >> 24) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[0][3][0][i] = val;
 
-			/* Calculate the maximum level now */
-			for (max_level = (pause_lv - 1); max_level >= 0; max_level--) {
-				if (p_cckpd_t->pause_bitmap & BIT(max_level))
-					break;
-			}
+			val = (u8)((reg1 & 0xff000000) >> 24) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[1][3][0][i] = val;
+
+			val = (u8)((reg2 & 0x000F8000) >> 15) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[0][3][1][i] = val;
 
-			/* write CCKPD of lower level */
-			phydm_write_cck_cca_th(p_dm, p_cckpd_t->pause_cckpd_value[max_level]);
-			PHYDM_DBG(p_dm, DBG_CCKPD, ("Write CCKPD=0x%x for max_LV=%d\n",
-				p_cckpd_t->pause_cckpd_value[max_level], max_level));
-			break;
+			val = (u8)((reg3 & 0x000000F8) >> 3) + pd_step;
+			cckpd_t->cck_pd_table_jgr3[1][3][1][i] = val;
 		}
-		break;
+		#endif
+	}
+}
+#endif /*#ifdef PHYDM_COMPILE_CCKPD_TYPE4*/
+
+void phydm_set_cckpd_val(void *dm_void, u32 *val_buf, u8 val_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	enum cckpd_lv lv;
+
+	if (val_len != 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][CCKPD]Need val_len=1\n");
+		return;
+	}
+
+	lv = (enum cckpd_lv)val_buf[0];
+
+	if (lv > CCK_PD_LV_4) {
+		pr_debug("[%s] warning! lv=%d\n", __func__, lv);
+		return;
 	}
+
+	switch (cckpd_t->cckpd_hw_type) {
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE1
+	case 1:
+		phydm_set_cckpd_lv_type1(dm, lv);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE2
+	case 2:
+		phydm_set_cckpd_lv_type2(dm, lv);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE3
+	case 3:
+		phydm_set_cckpd_lv_type3(dm, lv);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE4
+	case 4:
+		phydm_set_cck_pd_lv_type4(dm, lv);
+		break;
+	#endif
 	default:
-		PHYDM_DBG(p_dm, DBG_CCKPD,("Wrong  type\n"));
+		pr_debug("[%s]warning\n", __func__);
 		break;
 	}
+}
+
+boolean
+phydm_stop_cck_pd_th(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & (ODM_BB_CCK_PD | ODM_BB_FA_CNT))) {
+		PHYDM_DBG(dm, DBG_CCKPD, "Not Support\n");
+		return true;
+	}
 
-	PHYDM_DBG(p_dm, DBG_CCKPD, ("New pause bitmap=0x%x\n", 
-													p_cckpd_t->pause_bitmap));
-	
-	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
-		PHYDM_DBG(p_dm, DBG_CCKPD, ("pause val[%d]=0x%x\n", 
-										i, p_cckpd_t->pause_cckpd_value[i]));
+	if (dm->pause_ability & ODM_BB_CCK_PD) {
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: Pause CCKPD in LV=%d\n",
+			  dm->pause_lv_table.lv_cckpd);
+		return true;
+	}
+
+	if (dm->is_linked && (*dm->channel > 36)) {
+		PHYDM_DBG(dm, DBG_CCKPD, "Return: 5G CH=%d\n", *dm->channel);
+		return true;
 	}
-#endif
+	return false;
 }
 
-void
-phydm_cck_pd_init(
-	void		*p_dm_void
-)
+void phydm_cck_pd_th(void *dm_void)
 {
-#ifdef PHYDM_SUPPORT_CCKPD
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cckpd_struct		*p_cckpd_t = &p_dm->dm_cckpd_table;
-	struct phydm_dig_struct		*p_dig_t = &p_dm->dm_dig_table;
-
-	p_cckpd_t->cur_cck_cca_thres = 0;
-	p_cckpd_t->cck_cca_th_aaa = 0;
-	
-	p_cckpd_t->pause_bitmap = 0;
-
-	if (p_dm->support_ic_type & EXTEND_CCK_CCATH_AAA_IC)
-		p_dig_t->aaa_default = odm_read_1byte(p_dm, 0xaaa) & 0x1f;
-	
-	odm_memory_set(p_dm, p_cckpd_t->pause_cckpd_value, 0, PHYDM_PAUSE_MAX_NUM);
-#endif
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+	u32 cck_fa = fa_t->cnt_cck_fail;
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	struct phydm_fa_acc_struct *fa_acc_t = &dm->false_alm_cnt_acc;
+	#endif
+
+	PHYDM_DBG(dm, DBG_CCKPD, "[%s] ======>\n", __func__);
+
+	if (phydm_stop_cck_pd_th(dm))
+		return;
+
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (dm->original_dig_restore)
+		cck_fa = fa_t->cnt_cck_fail;
+	else
+		cck_fa = fa_acc_t->cnt_cck_fail_1sec;
+	#endif
+
+	if (cckpd_t->cck_fa_ma == CCK_FA_MA_RESET)
+		cckpd_t->cck_fa_ma = cck_fa;
+	else
+		cckpd_t->cck_fa_ma = (cckpd_t->cck_fa_ma * 3 + cck_fa) >> 2;
+
+	PHYDM_DBG(dm, DBG_CCKPD,
+		  "IGI=0x%x, rssi_min=%d, cck_fa=%d, cck_fa_ma=%d\n",
+		  dm->dm_dig_table.cur_ig_value, dm->rssi_min,
+		  cck_fa, cckpd_t->cck_fa_ma);
+
+	switch (cckpd_t->cckpd_hw_type) {
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE1
+	case 1:
+		phydm_cckpd_type1(dm);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE2
+	case 2:
+		phydm_cckpd_type2(dm);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE3
+	case 3:
+		phydm_cckpd_type3(dm);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE4
+	case 4:
+		phydm_cckpd_type4(dm);
+		break;
+	#endif
+	default:
+		pr_debug("[%s]warning\n", __func__);
+		break;
+	}
 }
 
+void phydm_cck_pd_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cckpd_struct *cckpd_t = &dm->dm_cckpd_table;
+
+	if (dm->support_ic_type & CCK_PD_IC_TYPE1)
+		cckpd_t->cckpd_hw_type = 1;
+	else if (dm->support_ic_type & CCK_PD_IC_TYPE2)
+		cckpd_t->cckpd_hw_type = 2;
+	else if (dm->support_ic_type & CCK_PD_IC_TYPE3)
+		cckpd_t->cckpd_hw_type = 3;
+	else if (dm->support_ic_type & CCK_PD_IC_TYPE4)
+		cckpd_t->cckpd_hw_type = 4;
+
+	PHYDM_DBG(dm, DBG_CCKPD, "[%s] cckpd_hw_type=%d\n",
+		  __func__, cckpd_t->cckpd_hw_type);
+
+	cckpd_t->cck_pd_lv = CCK_PD_LV_INIT;
+	cckpd_t->cck_n_rx = 0xff;
+	cckpd_t->cck_bw = CHANNEL_WIDTH_MAX;
+
+	switch (cckpd_t->cckpd_hw_type) {
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE1
+	case 1:
+		phydm_set_cckpd_lv_type1(dm, CCK_PD_LV_0);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE2
+	case 2:
+		cckpd_t->aaa_default = odm_read_1byte(dm, 0xaaa) & 0x1f;
+		phydm_set_cckpd_lv_type2(dm, CCK_PD_LV_0);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE3
+	case 3:
+		phydm_cck_pd_init_type3(dm);
+		break;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE4
+	case 4:
+		phydm_cck_pd_init_type4(dm);
+		break;
+	#endif
+	default:
+		pr_debug("[%s]warning\n", __func__);
+		break;
+	}
+}
+#endif /*#ifdef PHYDM_SUPPORT_CCKPD*/
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.h
index 9337b7660f37..845383d64a44 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cck_pd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,78 +9,148 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDM_CCK_PD_H__
+#define __PHYDM_CCK_PD_H__
 
-#ifndef	__PHYDM_CCK_PD_H__
-#define    __PHYDM_CCK_PD_H__
-
-#define CCK_PD_VERSION	"1.0"		/* 2017.05.09  Dino, Add phydm_cck_pd.h*/
-
+#define CCK_PD_VERSION "3.1"
 
-/* 1 ============================================================
+/*@
+ * 1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
+#define CCK_FA_MA_RESET 0xffffffff
+
+/*@Run time flag of CCK_PD HW type*/
+#define CCK_PD_IC_TYPE1 (ODM_RTL8188E | ODM_RTL8812 | ODM_RTL8821 |\
+			ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8814A |\
+			ODM_RTL8881A | ODM_RTL8822B | ODM_RTL8703B |\
+			ODM_RTL8195A | ODM_RTL8188F)
+
+#define CCK_PD_IC_TYPE2 (ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8723D |\
+			ODM_RTL8710B | ODM_RTL8195B) /*extend 0xaaa*/
+
+#define CCK_PD_IC_TYPE3 (ODM_RTL8192F | ODM_RTL8721D)
+/*@extend for different bw & path*/
+
+#define CCK_PD_IC_TYPE4 ODM_IC_JGR3_SERIES /*@extend for different bw & path*/
+
+/*@Compile time flag of CCK_PD HW type*/
+#if (RTL8188E_SUPPORT || RTL8812A_SUPPORT || RTL8821A_SUPPORT ||\
+	RTL8192E_SUPPORT || RTL8723B_SUPPORT || RTL8814A_SUPPORT ||\
+	RTL8881A_SUPPORT || RTL8822B_SUPPORT || RTL8703B_SUPPORT ||\
+	RTL8195A_SUPPORT || RTL8188F_SUPPORT)
+	#define PHYDM_COMPILE_CCKPD_TYPE1 /*@only 0xa0a*/
+#endif
 
+#if (RTL8197F_SUPPORT || RTL8821C_SUPPORT || RTL8723D_SUPPORT ||\
+	RTL8710B_SUPPORT || RTL8195B_SUPPORT)
+	#define PHYDM_COMPILE_CCKPD_TYPE2 /*@extend 0xaaa*/
+#endif
 
-#define	AAA_BASE	4
-#define	AAA_STEP	2
+#if (RTL8192F_SUPPORT || RTL8721D_SUPPORT)
+	#define PHYDM_COMPILE_CCKPD_TYPE3 /*@extend for different & path*/
+#endif
 
-#define	CCK_FA_MA_RESET	0xffffffff
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	#define PHYDM_COMPILE_CCKPD_TYPE4 /*@extend for different bw & path*/
+#endif
+/*@
+ * 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================
+ */
+enum cckpd_lv {
+	CCK_PD_LV_INIT = 0xff,
+	CCK_PD_LV_0 = 0,
+	CCK_PD_LV_1 = 1,
+	CCK_PD_LV_2 = 2,
+	CCK_PD_LV_3 = 3,
+	CCK_PD_LV_4 = 4,
+	CCK_PD_LV_MAX = 5
+};
+
+enum cckpd_mode {
+	CCK_BW20_1R = 0,
+	CCK_BW20_2R = 1,
+	CCK_BW20_3R = 2,
+	CCK_BW20_4R = 3,
+	CCK_BW40_1R = 4,
+	CCK_BW40_2R = 5,
+	CCK_BW40_3R = 6,
+	CCK_BW40_4R = 7
+};
 
-#define	EXTEND_CCK_CCATH_AAA_IC	(ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8723D |ODM_RTL8710B)
-/* 1 ============================================================
+/*@
+ * 1 ============================================================
  * 1  structure
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
 #ifdef PHYDM_SUPPORT_CCKPD
 struct phydm_cckpd_struct {
-
-	u8		cur_cck_cca_thres; /*0xA0A*/
-	u8		cck_cca_th_aaa; /*0xAAA*/
+	u8		cckpd_hw_type;
+	u8		cur_cck_cca_thres; /*@current cck_pd value 0xa0a*/
 	u32		cck_fa_ma;
-	u8		cckpd_bkp;
-	u32		rvrt_val[2];
-	u8		pause_bitmap;/*will be removed*/
+	u8		rvrt_val;
 	u8		pause_lv;
-	u8		pause_cckpd_value[PHYDM_PAUSE_MAX_NUM]; /*will be removed*/
+	u8		cck_n_rx;
+	enum channel_width cck_bw;
+	enum cckpd_lv	cck_pd_lv;
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE2
+	u8		cck_cca_th_aaa; /*@current cs_ratio value 0xaaa*/
+	u8		aaa_default;	/*@Init cs_ratio value - 0xaaa*/
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE3
+	/*Default value*/
+	u8		cck_pd_20m_1r;
+	u8		cck_pd_20m_2r;
+	u8		cck_pd_40m_1r;
+	u8		cck_pd_40m_2r;
+	u8		cck_cs_ratio_20m_1r;
+	u8		cck_cs_ratio_20m_2r;
+	u8		cck_cs_ratio_40m_1r;
+	u8		cck_cs_ratio_40m_2r;
+	/*Current value*/
+	u8		cur_cck_pd_20m_1r;
+	u8		cur_cck_pd_20m_2r;
+	u8		cur_cck_pd_40m_1r;
+	u8		cur_cck_pd_40m_2r;
+	u8		cur_cck_cs_ratio_20m_1r;
+	u8		cur_cck_cs_ratio_20m_2r;
+	u8		cur_cck_cs_ratio_40m_1r;
+	u8		cur_cck_cs_ratio_40m_2r;
+	#endif
+	#ifdef PHYDM_COMPILE_CCKPD_TYPE4
+	/*@[bw][nrx][0:PD/1:CS][lv]*/
+	u8		cck_pd_table_jgr3[2][4][2][CCK_PD_LV_MAX];
+	#endif
 };
 #endif
 
-/* 1 ============================================================
- * 1  enumeration
- * 1 ============================================================ */
-
-/* 1 ============================================================
+/*@
+ * 1 ============================================================
  * 1  function prototype
- * 1 ============================================================ */
-
-void
-phydm_set_cckpd_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-);
-
-void
-phydm_cck_pd_th(
-	void		*p_dm_void
-);
-
-void
-odm_pause_cck_packet_detection(
-	void					*p_dm_void,
-	enum phydm_pause_type		pause_type,
-	enum phydm_pause_level		pause_level,
-	u8					cck_pd_threshold
-);
-
-void
-phydm_cck_pd_init(
-	void		*p_dm_void
-);
+ * 1 ============================================================
+ */
+void phydm_set_cckpd_val(void *dm_void, u32 *val_buf, u8 val_len);
+
+void phydm_cck_pd_th(void *dm_void);
 
+void phydm_cck_pd_init(void *dm_void);
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.c
index 183dd2481df7..b5e8c4f166c0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,1156 +9,1795 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
+void phydm_ccx_hw_restart(void *dm_void)
+			  /*@Will Restart NHM/CLM/FAHM simultaneously*/
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 reg1 = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		reg1 = R_0x994;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		reg1 = R_0x1e60;
+	#endif
+	else
+		reg1 = R_0x890;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	/*@disable NHM,CLM, FAHM*/
+	odm_set_bb_reg(dm, reg1, 0x7, 0x0);
+	odm_set_bb_reg(dm, reg1, BIT(8), 0x0);
+	odm_set_bb_reg(dm, reg1, BIT(8), 0x1);
+}
+
 #ifdef FAHM_SUPPORT
 
-u16
-phydm_hw_divider(
-	void	*p_dm_void,
-	u16	numerator,
-	u16	denumerator
-)
+u16 phydm_hw_divider(void *dm_void, u16 numerator, u16 denumerator)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u16	result = DEVIDER_ERROR;
-	u32	tmp_u32 = ((numerator << 16) | denumerator);
-	u32	reg_devider_input;
-	u32	reg_devider_rpt;
-	u8	i;
-
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
-
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		reg_devider_input =  0x1cbc;
-		reg_devider_rpt = 0x1f98;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 result = DEVIDER_ERROR;
+	u32 tmp_u32 = ((numerator << 16) | denumerator);
+	u32 reg_devider_input;
+	u32 reg;
+	u8 i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg_devider_input = 0x1cbc;
+		reg = 0x1f98;
 	} else {
-		reg_devider_input =  0x980;
-		reg_devider_rpt = 0x9f0;
+		reg_devider_input = 0x980;
+		reg = 0x9f0;
 	}
 
-	odm_set_bb_reg(p_dm, reg_devider_input, MASKDWORD, tmp_u32);
+	odm_set_bb_reg(dm, reg_devider_input, MASKDWORD, tmp_u32);
 
 	for (i = 0; i < 10; i++) {
 		ODM_delay_ms(1);
-		if (odm_get_bb_reg(p_dm, reg_devider_rpt, BIT(24))) { /*Chk HW rpt is ready*/
-			
-			result = (u16)odm_get_bb_reg(p_dm, reg_devider_rpt, MASKBYTE2);
+		if (odm_get_bb_reg(dm, reg, BIT(24))) {
+		/*@Chk HW rpt is ready*/
+
+			result = (u16)odm_get_bb_reg(dm, reg, MASKBYTE2);
 			break;
 		}
 	}
-	return	result;
+	return result;
 }
 
-void
-phydm_fahm_trigger(
-	void		*p_dm_void,
-	u16		trigger_period	/*unit (4us)*/
-)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
-	u32		fahm_reg1;
-	u32		fahm_reg2;
+void phydm_fahm_trigger(void *dm_void, u16 tgr_period)
+{ /*@unit (4us)*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 fahm_reg1;
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x1cf8, 0xffff00, tgr_period);
 
-		odm_set_bb_reg(p_dm, 0x1cf8, 0xffff00, trigger_period);
-		
-		fahm_reg1 =  0x994;
+		fahm_reg1 = 0x994;
 	} else {
-	
-		odm_set_bb_reg(p_dm, 0x978, 0xff000000, (trigger_period & 0xff));		
-		odm_set_bb_reg(p_dm, 0x97c, 0xff, (trigger_period & 0xff00)>>8);
-		
-		fahm_reg1 =  0x890;
+		odm_set_bb_reg(dm, R_0x978, 0xff000000, (tgr_period & 0xff));
+		odm_set_bb_reg(dm, R_0x97c, 0xff, (tgr_period & 0xff00) >> 8);
+
+		fahm_reg1 = 0x890;
 	}
 
-	odm_set_bb_reg(p_dm, fahm_reg1, BIT(2), 0);
-	odm_set_bb_reg(p_dm, fahm_reg1, BIT(2), 1);
+	odm_set_bb_reg(dm, fahm_reg1, BIT(2), 0);
+	odm_set_bb_reg(dm, fahm_reg1, BIT(2), 1);
 }
 
-void
-phydm_fahm_set_valid_cnt(
-	void		*p_dm_void,
-	u8		numerator_sel,
-	u8		denumerator_sel
-)
+void phydm_fahm_set_valid_cnt(void *dm_void, u8 numerator_sel,
+			      u8 denominator_sel)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
-	u32		fahm_reg1;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
+	u32 fahm_reg1;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
 
-	if ((ccx_info->fahm_nume_sel == numerator_sel) && 
-		(ccx_info->fahm_denum_sel == denumerator_sel)) {
-
-		PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("no need to update\n", __FUNCTION__));
+	if (ccx_info->fahm_nume_sel == numerator_sel &&
+	    ccx_info->fahm_denom_sel == denominator_sel) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "no need to update\n");
 		return;
 	}
 
 	ccx_info->fahm_nume_sel = numerator_sel;
-	ccx_info->fahm_denum_sel = denumerator_sel;
-	
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		fahm_reg1 =  0x994;
-	} else {
-		fahm_reg1 =  0x890;
-	}
+	ccx_info->fahm_denom_sel = denominator_sel;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		fahm_reg1 = 0x994;
+	else
+		fahm_reg1 = 0x890;
 
-	odm_set_bb_reg(p_dm, fahm_reg1, 0xe0, numerator_sel);
-	odm_set_bb_reg(p_dm, fahm_reg1, 0x7000, denumerator_sel);
+	odm_set_bb_reg(dm, fahm_reg1, 0xe0, numerator_sel);
+	odm_set_bb_reg(dm, fahm_reg1, 0x7000, denominator_sel);
 }
 
-void
-phydm_get_fahm_result(
-	void		*p_dm_void
-)
+void phydm_fahm_get_result(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
-	u16		fahm_rpt_cnt[12];	/*packet count*/
-	u16		fahm_rpt[12];		/*percentage*/
-	u16		fahm_denumerator;	/*packet count*/
-	u32		reg_rpt, reg_rpt_2;
-	u32		reg_val_tmp;
-	boolean	is_ready = false;
-	u8		i;
-
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
-	
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		reg_rpt =  0x1f80;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 fahm_cnt[12]; /*packet count*/
+	u16 fahm_rpt[12]; /*percentage*/
+	u16 denominator; /*@fahm_denominator packet count*/
+	u32 reg_rpt, reg_rpt_2;
+	u32 reg_tmp;
+	boolean is_ready = false;
+	u8 i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg_rpt = 0x1f80;
 		reg_rpt_2 = 0x1f98;
 	} else {
-		reg_rpt =  0x9d8;
+		reg_rpt = 0x9d8;
 		reg_rpt_2 = 0x9f0;
 	}
 
-	for (i = 0; i < 10; i++) {
-		
-		if (odm_get_bb_reg(p_dm, reg_rpt_2, BIT(31))) { /*Chk HW rpt is ready*/
-			
+	for (i = 0; i < 3; i++) {
+		if (odm_get_bb_reg(dm, reg_rpt_2, BIT(31))) {
+		/*@Chk HW rpt is ready*/
 			is_ready = true;
 			break;
 		}
 		ODM_delay_ms(1);
 	}
 
-	if (is_ready == false)
+	if (!is_ready)
 		return;
 
-	/*Get Denumerator*/
-	fahm_denumerator = (u16)odm_get_bb_reg(p_dm, reg_rpt_2, MASKLWORD);
+	/*@Get FAHM Denominator*/
+	denominator = (u16)odm_get_bb_reg(dm, reg_rpt_2, MASKLWORD);
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Reg[0x%x] fahm_denmrtr = %d\n", reg_rpt_2, fahm_denumerator));
-	
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Reg[0x%x] fahm_denmrtr = %d\n", reg_rpt_2,
+		  denominator);
 
-	/*Get nemerator*/
-	for (i = 0; i<6; i++) {
-		reg_val_tmp = odm_get_bb_reg(p_dm, reg_rpt + (i<<2), MASKDWORD);
-		
-		PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Reg[0x%x] fahm_denmrtr = %d\n", (p_dm, reg_rpt + (i*4), reg_val_tmp)));
-		
-		fahm_rpt_cnt[i*2] = (u16)(reg_val_tmp & MASKLWORD);
-		fahm_rpt_cnt[i*2 +1] = (u16)((reg_val_tmp & MASKHWORD)>>16);
-	}
+	/*@Get FAHM nemerator*/
+	for (i = 0; i < 6; i++) {
+		reg_tmp = odm_get_bb_reg(dm, reg_rpt + (i << 2), MASKDWORD);
 
-	for (i = 0; i<12; i++) {
-		fahm_rpt[i] = phydm_hw_divider(p_dm, fahm_rpt_cnt[i], fahm_denumerator);
-	}
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Reg[0x%x] fahm_denmrtr = %d\n",
+			  reg_rpt + (i * 4), reg_tmp);
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR,("FAHM_RPT_cnt[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
-		fahm_rpt_cnt[11], fahm_rpt_cnt[10], fahm_rpt_cnt[9], fahm_rpt_cnt[8], fahm_rpt_cnt[7], fahm_rpt_cnt[6], 
-		fahm_rpt_cnt[5], fahm_rpt_cnt[4], fahm_rpt_cnt[3], fahm_rpt_cnt[2], fahm_rpt_cnt[1], fahm_rpt_cnt[0]));
+		fahm_cnt[i * 2] = (u16)(reg_tmp & MASKLWORD);
+		fahm_cnt[i * 2 + 1] = (u16)((reg_tmp & MASKHWORD) >> 16);
+	}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR,("FAHM_RPT_%[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
-		fahm_rpt[11], fahm_rpt[10], fahm_rpt[9], fahm_rpt[8], fahm_rpt[7], fahm_rpt[6], 
-		fahm_rpt[5], fahm_rpt[4], fahm_rpt[3], fahm_rpt[2], fahm_rpt[1], fahm_rpt[0]));
-	
+	for (i = 0; i < 12; i++)
+		fahm_rpt[i] = phydm_hw_divider(dm, fahm_cnt[i], denominator);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RPT_cnt[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
+		  fahm_cnt[11], fahm_cnt[10], fahm_cnt[9],
+		  fahm_cnt[8], fahm_cnt[7], fahm_cnt[6],
+		  fahm_cnt[5], fahm_cnt[4], fahm_cnt[3],
+		  fahm_cnt[2], fahm_cnt[1], fahm_cnt[0]);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RPT[10:0]=[%d, %d, %d, %d, %d(IGI), %d, %d, %d, %d, %d, %d, %d]\n",
+		  fahm_rpt[11], fahm_rpt[10], fahm_rpt[9], fahm_rpt[8],
+		  fahm_rpt[7], fahm_rpt[6], fahm_rpt[5], fahm_rpt[4],
+		  fahm_rpt[3], fahm_rpt[2], fahm_rpt[1], fahm_rpt[0]);
 }
 
-void
-phydm_set_fahm_th_by_igi(
-	void		*p_dm_void,
-	u8		igi
-)
+void phydm_fahm_set_th_by_igi(void *dm_void, u8 igi)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
-	u8	fahm_th[11];
-	u8	rssi_th[11];	/*in RSSI scale*/
-	u8	th_gap = 2 * IGI_TO_NHM_TH_MULTIPLIER;	/*beacuse unit is 0.5dB for FAHM*/
-	u8	i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
+	u32 val = 0;
+	u8 f_th[11]; /*@FAHM Threshold*/
+	u8 rssi_th[11]; /*@in RSSI scale*/
+	u8 th_gap = 2 * IGI_TO_NHM_TH_MULTIPLIER; /*unit is 0.5dB for FAHM*/
+	u8 i;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
 
 	if (ccx_info->env_mntr_igi == igi) {
-		PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("No need to update FAHM_th, IGI=0x%x\n", ccx_info->env_mntr_igi));
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "No need to update FAHM_th, IGI=0x%x\n",
+			  ccx_info->env_mntr_igi);
 		return;
 	}
 
-	ccx_info->env_mntr_igi = igi;	/*bkp IGI*/
+	ccx_info->env_mntr_igi = igi; /*@bkp IGI*/
 
-	if (igi >= CCA_CAP) 
-		fahm_th[0] = (igi - CCA_CAP) * IGI_TO_NHM_TH_MULTIPLIER;
+	if (igi >= CCA_CAP)
+		f_th[0] = (igi - CCA_CAP) * IGI_TO_NHM_TH_MULTIPLIER;
 	else
-		fahm_th[0] = 0;
-	
-	rssi_th[0] = igi -10 - CCA_CAP;
-	
+		f_th[0] = 0;
+
+	rssi_th[0] = igi - 10 - CCA_CAP;
+
 	for (i = 1; i <= 10; i++) {
-		fahm_th[i] = fahm_th[0] + th_gap * i;
-		rssi_th[i] = rssi_th[0] +  (i<<1);
+		f_th[i] = f_th[0] + th_gap * i;
+		rssi_th[i] = rssi_th[0] + (i << 1);
 	}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR,("FAHM_RSSI_th[10:0]=[%d, %d, %d, (IGI)%d, %d, %d, %d, %d, %d, %d, %d]\n",
-		rssi_th[10], rssi_th[9], rssi_th[8], rssi_th[7], rssi_th[6], rssi_th[5], rssi_th[4], rssi_th[3], rssi_th[2], rssi_th[1], rssi_th[0]));
-
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		
-		odm_set_bb_reg(p_dm, 0x1c38, 0xffffff00, ((fahm_th[2]<<24) |(fahm_th[1]<<16) | (fahm_th[0]<<8)));
-		odm_set_bb_reg(p_dm, 0x1c78, 0xffffff00, ((fahm_th[5]<<24) |(fahm_th[4]<<16) | (fahm_th[3]<<8)));
-		odm_set_bb_reg(p_dm, 0x1c7c, 0xffffff00, ((fahm_th[7]<<24) |(fahm_th[6]<<16)));
-		odm_set_bb_reg(p_dm, 0x1cb8, 0xffffff00, ((fahm_th[10]<<24) |(fahm_th[9]<<16) | (fahm_th[8]<<8)));
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "FAHM_RSSI_th[10:0]=[%d, %d, %d, (IGI)%d, %d, %d, %d, %d, %d, %d, %d]\n",
+		  rssi_th[10], rssi_th[9], rssi_th[8], rssi_th[7], rssi_th[6],
+		  rssi_th[5], rssi_th[4], rssi_th[3], rssi_th[2], rssi_th[1],
+		  rssi_th[0]);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		val = BYTE_2_DWORD(0, f_th[2], f_th[1], f_th[0]);
+		odm_set_bb_reg(dm, R_0x1c38, 0xffffff00, val);
+		val = BYTE_2_DWORD(0, f_th[5], f_th[4], f_th[3]);
+		odm_set_bb_reg(dm, R_0x1c78, 0xffffff00, val);
+		val = BYTE_2_DWORD(0, 0, f_th[7], f_th[6]);
+		odm_set_bb_reg(dm, R_0x1c7c, 0xffff0000, val);
+		val = BYTE_2_DWORD(0, f_th[10], f_th[9], f_th[8]);
+		odm_set_bb_reg(dm, R_0x1cb8, 0xffffff00, val);
 	} else {
-
-		odm_set_bb_reg(p_dm, 0x970, MASKDWORD, ((fahm_th[3]<<24) |(fahm_th[2]<<16) | (fahm_th[1]<<8) | fahm_th[0]));
-		odm_set_bb_reg(p_dm, 0x974, MASKDWORD, ((fahm_th[7]<<24) |(fahm_th[6]<<16) | (fahm_th[5]<<8) | fahm_th[4]));
-		odm_set_bb_reg(p_dm, 0x978, MASKDWORD, ((fahm_th[10]<<16) | (fahm_th[9]<<8) | fahm_th[8]));
-	}	
+		val = BYTE_2_DWORD(f_th[3], f_th[2], f_th[1], f_th[0]);
+		odm_set_bb_reg(dm, R_0x970, MASKDWORD, val);
+		val = BYTE_2_DWORD(f_th[7], f_th[6], f_th[5], f_th[4]);
+		odm_set_bb_reg(dm, R_0x974, MASKDWORD, val);
+		val = BYTE_2_DWORD(0, f_th[10], f_th[9], f_th[8]);
+		odm_set_bb_reg(dm, R_0x978, 0xffffff, val);
+	}
 }
 
-void
-phydm_fahm_init(
-	void			*p_dm_void
-)
+void phydm_fahm_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
-	u32	fahm_reg1;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
+	u32 fahm_reg1;
+	u8 denumerator_sel = 0;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("IGI=0x%x\n", p_dm->dm_dig_table.cur_ig_value));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "IGI=0x%x\n",
+		  dm->dm_dig_table.cur_ig_value);
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		fahm_reg1 =  0x994;
-	} else {
-		fahm_reg1 =  0x890;
-	}
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		fahm_reg1 = 0x994;
+	else
+		fahm_reg1 = 0x890;
 
 	ccx_info->fahm_period = 65535;
-	
-	odm_set_bb_reg(p_dm, fahm_reg1, 0x6, 3);	/*FAHM HW block enable*/
-	
-	phydm_fahm_set_valid_cnt(p_dm, FAHM_INCLD_FA, (FAHM_INCLD_FA| FAHM_INCLD_CRC_OK |FAHM_INCLD_CRC_ER));
-	phydm_set_fahm_th_by_igi(p_dm, p_dm->dm_dig_table.cur_ig_value);
+
+	odm_set_bb_reg(dm, fahm_reg1, 0x6, 3); /*@FAHM HW block enable*/
+
+	denumerator_sel = FAHM_INCLD_FA | FAHM_INCLD_CRC_OK | FAHM_INCLD_CRC_ER;
+	phydm_fahm_set_valid_cnt(dm, FAHM_INCLD_FA, denumerator_sel);
+	phydm_fahm_set_th_by_igi(dm, dm->dm_dig_table.cur_ig_value);
 }
 
-void
-phydm_fahm_dbg(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_fahm_dbg(void *dm_void, char input[][16], u32 *_used, char *output,
+		    u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO	*ccx_info = &p_dm->dm_ccx_info;
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u32		i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 i;
 
 	for (i = 0; i < 2; i++) {
-		if (input[i + 1]) {
+		if (input[i + 1])
 			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-		}
 	}
 
 	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "{1: trigger, 2:get result}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{3: MNTR mode sel} {1: driver, 2. FW}\n"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1: trigger, 2:get result}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{3: MNTR mode sel} {1: driver, 2. FW}\n");
 		return;
 	} else if (var1[0] == 1) { /* Set & trigger CLM */
-		
-		phydm_set_fahm_th_by_igi(p_dm, p_dm->dm_dig_table.cur_ig_value);
-		phydm_fahm_trigger(p_dm, ccx_info->fahm_period);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Monitor FAHM for %d * 4us\n", ccx_info->fahm_period));
-		
-	} else if (var1[0] == 2) { /* Get CLM results */
-
-		phydm_get_fahm_result(p_dm);
-		PHYDM_SNPRINTF((output + used, out_len - used, "FAHM_result=%d us\n", (ccx_info->clm_result<<2)));
-
-	} /*else if (var1[0] == 3) {
-
-		if (var1[1] == 1)
-			ccx_info->clm_mntr_mode = CLM_DRIVER_MNTR;
-		else if (var1[1] == 2)
-			ccx_info->clm_mntr_mode = CLM_FW_MNTR;
-
-	}*/ else {
-		
-		PHYDM_SNPRINTF((output + used, out_len - used, "Error\n"));
+
+		phydm_fahm_set_th_by_igi(dm, dm->dm_dig_table.cur_ig_value);
+		phydm_fahm_trigger(dm, ccx_info->fahm_period);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Monitor FAHM for %d * 4us\n", ccx_info->fahm_period);
+
+	} else if (var1[0] == 2) { /* @Get CLM results */
+
+		phydm_fahm_get_result(dm);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "FAHM_result=%d us\n", (ccx_info->clm_result << 2));
+
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Error\n");
 	}
-	
+
 	*_used = used;
 	*_out_len = out_len;
 }
 
+#endif /*@#ifdef FAHM_SUPPORT*/
 
-#endif
+#ifdef NHM_SUPPORT
 
-void
-phydm_c2h_clm_report_handler(
-	void	*p_dm_void,
-	u8	*cmd_buf,
-	u8	cmd_len
-)
+void phydm_nhm_racing_release(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
-	u8	clm_report = cmd_buf[0];
-	u8	clm_report_idx = cmd_buf[1];
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 value32 = 0;
 
-	if (cmd_len >=12)
-		return;
-	
-	ccx_info->clm_fw_result_acc += clm_report;
-	ccx_info->clm_fw_result_cnt++;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "lv:(%d)->(0)\n", ccx->nhm_set_lv);
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%d] clm_report= %d\n", ccx_info->clm_fw_result_cnt, clm_report));
-	
+	ccx->nhm_ongoing = false;
+	ccx->nhm_set_lv = NHM_RELEASE;
+
+	if (!(ccx->nhm_app == NHM_BACKGROUND || ccx->nhm_app == NHM_ACS)) {
+		phydm_pause_func(dm, F00_DIG, PHYDM_RESUME,
+				 PHYDM_PAUSE_LEVEL_1, 1, &value32);
+	}
+
+	ccx->nhm_app = NHM_BACKGROUND;
 }
 
-void
-phydm_clm_h2c(
-	void	*p_dm_void,
-	u16	obs_time,
-	u8	fw_clm_en
-)
+u8 phydm_nhm_racing_ctrl(void *dm_void, enum phydm_nhm_level nhm_lv)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		h2c_val[H2C_MAX_LENGTH] = {0};
-	u8		i = 0;
-	u8		obs_time_idx = 0;
-	
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("obs_time_index=%d *4 ms\n", obs_time));
-
-	for (i =1; i<=16; i++) {
-		if (obs_time & BIT(16 -i)) {
-			obs_time_idx = 16-i;
-			break;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u8 set_result = PHYDM_SET_SUCCESS;
+	/*@acquire to control NHM API*/
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_ongoing=%d, lv:(%d)->(%d)\n",
+		  ccx->nhm_ongoing, ccx->nhm_set_lv, nhm_lv);
+	if (ccx->nhm_ongoing) {
+		if (nhm_lv <= ccx->nhm_set_lv) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			phydm_ccx_hw_restart(dm);
+			ccx->nhm_ongoing = false;
 		}
 	}
-	
-	/*
-	obs_time =(2^16 -1) ~ (2^15)  => obs_time_idx = 15  (65535 ~ 32768)
-	obs_time =(2^15 -1) ~ (2^14)  => obs_time_idx = 14
-	...
-	...
-	...
-	obs_time =(2^1 -1) ~ (2^0)  => obs_time_idx = 0
-
-	*/
-
-	h2c_val[0] = obs_time_idx | (((fw_clm_en) ? 1 : 0)<< 7);
-	h2c_val[1] = CLM_MAX_REPORT_TIME;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("PHYDM h2c[0x4d]=0x%x %x %x %x %x %x %x\n",
-		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]));
+	if (set_result)
+		ccx->nhm_set_lv = nhm_lv;
 
-	odm_fill_h2c_cmd(p_dm, PHYDM_H2C_FW_CLM_MNTR, H2C_MAX_LENGTH, h2c_val);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm racing success=%d\n", set_result);
+	return set_result;
+}
 
+void phydm_nhm_trigger(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 nhm_reg1 = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		nhm_reg1 = R_0x994;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		nhm_reg1 = R_0x1e60;
+	#endif
+	else
+		nhm_reg1 = R_0x890;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	/*Trigger NHM*/
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 0);
+	pdm_set_reg(dm, nhm_reg1, BIT(1), 1);
+	ccx->nhm_trigger_time = dm->phydm_sys_up_time;
+	ccx->nhm_rpt_stamp++;
+	ccx->nhm_ongoing = true;
 }
 
 boolean
-phydm_cal_nhm_cnt(
-	void		*p_dm_void
-)
+phydm_nhm_check_rdy(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
-	u8						noisy_nhm_th_index, low_pwr_cnt = 0, high_pwr_cnt = 0;
-	u8						noisy_nhm_th = 0x52;
-	u8						i;
-	boolean					noisy = false, clean = true;
-
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
-
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR))
-		return noisy;
-
-	/*nhm_th = 0x52 means 0x52/2-110 = -69dbm*/
-	/* IGI < 0x14 */
-	if (ccx_info->nhm_th[10] < noisy_nhm_th)
-		return	clean;
-	else if (ccx_info->nhm_th[0] > noisy_nhm_th)
-		return	(p_dm->noisy_decision) ? noisy : clean;
-	/* 0x14 <= IGI <= 0x37*/
-	else {
-		/* search index */
-		noisy_nhm_th_index = (noisy_nhm_th - ccx_info->nhm_th[0]) << 2;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean is_ready = false;
+	u32 reg1 = 0, reg1_bit = 0;
+#if (ENV_MNTR_DBG || ENV_MNTR_DBG_1)
+	u16 i = 0;
+	u64 start_time = 0, progressing_time = 0;
+	u32 reg_val_start = 0, reg_val = 0;
+	u8 print_rpt = 0;
+#endif
 
-		for (i = 0; i <= 11; i++) {
-			if (i <= noisy_nhm_th_index)
-				low_pwr_cnt += ccx_info->nhm_result[i];
-			else
-				high_pwr_cnt += ccx_info->nhm_result[i];
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = R_0xfb4;
+		reg1_bit = 16;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		reg1 = R_0x2d4c;
+		reg1_bit = 16;
+	#endif
+	} else {
+		reg1 = R_0x8b4;
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			reg1_bit = 25;
+		} else {
+			reg1_bit = 17;
 		}
-
-		if (low_pwr_cnt + high_pwr_cnt == 0)
-			return noisy;		/* noisy environment */
-		else if (low_pwr_cnt - high_pwr_cnt >= 100)
-			return clean;		/* clean environment */
-		else
-			return noisy;		/* noisy environment */
 	}
-}
 
-void
-phydm_nhm_setting(
-	void		*p_dm_void,
-	u8	nhm_setting
-)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO	*ccx_info = &p_dm->dm_ccx_info;
-
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
-
-	
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("IGI=0x%x\n", ccx_info->echo_igi));
-	
-	if (nhm_setting == SET_NHM_SETTING) {
-		PHYDM_DBG(p_dm, DBG_ENV_MNTR,
-		("NHM_th[H->L]=[0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x]\n",
-		ccx_info->nhm_th[10], ccx_info->nhm_th[9], ccx_info->nhm_th[8],
-		ccx_info->nhm_th[7], ccx_info->nhm_th[6], ccx_info->nhm_th[5],
-		ccx_info->nhm_th[4], ccx_info->nhm_th[3], ccx_info->nhm_th[2],
-		ccx_info->nhm_th[1], ccx_info->nhm_th[0]));
-	}
+#if (ENV_MNTR_DBG_1)
+	start_time = odm_get_current_time(dm);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM_period = %d\n",
+			  odm_get_bb_reg(dm, R_0x990, MASKDWORD));
+
+		 /*NHM trigger bit*/
+		reg_val_start = odm_get_bb_reg(dm, R_0x994, BIT(1));
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "reg_val_start = %d\n",
+			  reg_val_start);
+
+		for (i = 0; i <= 400; i++) {
+			if (print_rpt == 0) {
+				reg_val = odm_get_bb_reg(dm, R_0x994, BIT(1));
+				if (reg_val != reg_val_start) {
+					print_rpt = 1;
+					PHYDM_DBG(dm, DBG_ENV_MNTR,
+						  "Trig[%d] (%d) -> (%d)\n",
+						  i, reg_val_start, reg_val);
+				}
+			}
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-
-		if (nhm_setting == SET_NHM_SETTING) {
-
-			/*Set inexclude_cca, inexclude_txon*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9), ccx_info->nhm_inexclude_cca);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10), ccx_info->nhm_inexclude_txon);
-
-			/*Set NHM period*/
-			odm_set_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD, ccx_info->nhm_period);
-
-			/*Set NHM threshold*/ /*Unit: PWdB U(8,1)*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0, ccx_info->nhm_th[0]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1, ccx_info->nhm_th[1]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2, ccx_info->nhm_th[2]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3, ccx_info->nhm_th[3]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0, ccx_info->nhm_th[4]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1, ccx_info->nhm_th[5]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2, ccx_info->nhm_th[6]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3, ccx_info->nhm_th[7]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0, ccx_info->nhm_th[8]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2, ccx_info->nhm_th[9]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3, ccx_info->nhm_th[10]);
-
-			/*CCX EN*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(8), CCX_EN);
-
-		} else if (nhm_setting == STORE_NHM_SETTING) {
-
-			/*Store pervious disable_ignore_cca, disable_ignore_txon*/
-			ccx_info->nhm_inexclude_cca_restore = (enum nhm_inexclude_cca)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9));
-			ccx_info->nhm_inexclude_txon_restore = (enum nhm_inexclude_txon)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10));
-
-			/*Store pervious NHM period*/
-			ccx_info->nhm_period_restore = (u16)odm_get_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD);
-
-			/*Store NHM threshold*/
-			ccx_info->nhm_th_restore[0] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0);
-			ccx_info->nhm_th_restore[1] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1);
-			ccx_info->nhm_th_restore[2] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2);
-			ccx_info->nhm_th_restore[3] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3);
-			ccx_info->nhm_th_restore[4] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0);
-			ccx_info->nhm_th_restore[5] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1);
-			ccx_info->nhm_th_restore[6] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2);
-			ccx_info->nhm_th_restore[7] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3);
-			ccx_info->nhm_th_restore[8] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0);
-			ccx_info->nhm_th_restore[9] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2);
-			ccx_info->nhm_th_restore[10] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3);
-		} else if (nhm_setting == RESTORE_NHM_SETTING) {
-
-			/*Set disable_ignore_cca, disable_ignore_txon*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(9), ccx_info->nhm_inexclude_cca_restore);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(10), ccx_info->nhm_inexclude_txon_restore);
-
-			/*Set NHM period*/
-			odm_set_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11AC, MASKHWORD, ccx_info->nhm_period);
-
-			/*Set NHM threshold*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0, ccx_info->nhm_th_restore[0]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1, ccx_info->nhm_th_restore[1]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2, ccx_info->nhm_th_restore[2]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3, ccx_info->nhm_th_restore[3]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0, ccx_info->nhm_th_restore[4]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1, ccx_info->nhm_th_restore[5]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2, ccx_info->nhm_th_restore[6]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3, ccx_info->nhm_th_restore[7]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0, ccx_info->nhm_th_restore[8]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2, ccx_info->nhm_th_restore[9]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3, ccx_info->nhm_th_restore[10]);
-		} else
-			return;
+			if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit))) {
+				is_ready = true;
+				break;
+			}
+			ODM_delay_ms(1);
+		}
+	} else {
+		if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit)))
+			is_ready = true;
 	}
 
-	else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-
-		if (nhm_setting == SET_NHM_SETTING) {
-
-			/*Set disable_ignore_cca, disable_ignore_txon*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9), ccx_info->nhm_inexclude_cca);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10), ccx_info->nhm_inexclude_txon);
-
-			/*Set NHM period*/
-			odm_set_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD, ccx_info->nhm_period);
-
-			/*Set NHM threshold*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0, ccx_info->nhm_th[0]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1, ccx_info->nhm_th[1]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2, ccx_info->nhm_th[2]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3, ccx_info->nhm_th[3]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0, ccx_info->nhm_th[4]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1, ccx_info->nhm_th[5]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2, ccx_info->nhm_th[6]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3, ccx_info->nhm_th[7]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH8_11N, MASKBYTE0, ccx_info->nhm_th[8]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2, ccx_info->nhm_th[9]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3, ccx_info->nhm_th[10]);
-
-			/*CCX EN*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(8), CCX_EN);
-		} else if (nhm_setting == STORE_NHM_SETTING) {
-
-			/*Store pervious disable_ignore_cca, disable_ignore_txon*/
-			ccx_info->nhm_inexclude_cca_restore = (enum nhm_inexclude_cca)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9));
-			ccx_info->nhm_inexclude_txon_restore = (enum nhm_inexclude_txon)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10));
-
-			/*Store pervious NHM period*/
-			ccx_info->nhm_period_restore = (u16)odm_get_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD);
-
-			/*Store NHM threshold*/
-			ccx_info->nhm_th_restore[0] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0);
-			ccx_info->nhm_th_restore[1] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1);
-			ccx_info->nhm_th_restore[2] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2);
-			ccx_info->nhm_th_restore[3] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3);
-			ccx_info->nhm_th_restore[4] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0);
-			ccx_info->nhm_th_restore[5] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1);
-			ccx_info->nhm_th_restore[6] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2);
-			ccx_info->nhm_th_restore[7] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3);
-			ccx_info->nhm_th_restore[8] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH8_11N, MASKBYTE0);
-			ccx_info->nhm_th_restore[9] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2);
-			ccx_info->nhm_th_restore[10] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3);
-
-		} else if (nhm_setting == RESTORE_NHM_SETTING) {
-
-			/*Set disable_ignore_cca, disable_ignore_txon*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(9), ccx_info->nhm_inexclude_cca_restore);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(10), ccx_info->nhm_inexclude_txon_restore);
-
-			/*Set NHM period*/
-			odm_set_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11N, MASKHWORD, ccx_info->nhm_period_restore);
-
-			/*Set NHM threshold*/
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0, ccx_info->nhm_th_restore[0]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1, ccx_info->nhm_th_restore[1]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2, ccx_info->nhm_th_restore[2]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3, ccx_info->nhm_th_restore[3]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0, ccx_info->nhm_th_restore[4]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1, ccx_info->nhm_th_restore[5]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2, ccx_info->nhm_th_restore[6]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3, ccx_info->nhm_th_restore[7]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH8_11N, MASKBYTE0, ccx_info->nhm_th_restore[8]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2, ccx_info->nhm_th_restore[9]);
-			odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3, ccx_info->nhm_th_restore[10]);
-		} else
-			return;
+	progressing_time = odm_get_progressing_time(dm, start_time);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM rdy=%d, i=%d, NHM_polling_time=%lld\n",
+		  is_ready, i, progressing_time);
 
+#elif (ENV_MNTR_DBG)
+	start_time = odm_get_current_time(dm);
+	for (i = 0; i <= 400; i++) {
+		if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit))) {
+			is_ready = true;
+			break;
+		}
+		ODM_delay_ms(1);
 	}
-}
-
-void
-phydm_nhm_trigger(
-	void		*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	progressing_time = odm_get_progressing_time(dm, start_time);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM rdy=%d, i=%d, NHM_polling_time=%lld\n",
+		  is_ready, i, progressing_time);
+#else
+	if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit)))
+		is_ready = true;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM rdy=%d\n", is_ready);
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+#endif
+	return is_ready;
+}
 
-		/*Trigger NHM*/
-		odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(1), 0);
-		odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, BIT(1), 1);
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+void phydm_nhm_get_utility(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u8 nhm_rpt_non_0 = 0;
 
-		/*Trigger NHM*/
-		odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(1), 0);
-		odm_set_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, BIT(1), 1);
+	if (ccx->nhm_rpt_sum >= ccx->nhm_result[0]) {
+		nhm_rpt_non_0 = ccx->nhm_rpt_sum - ccx->nhm_result[0];
+		ccx->nhm_ratio = (nhm_rpt_non_0 * 100) >> 8;
+	} else {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[warning] nhm_rpt_sum invalid\n");
+		ccx->nhm_ratio = 0;
 	}
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_ratio=%d\n", ccx->nhm_ratio);
 }
 
-void
-phydm_get_nhm_result(
-	void		*p_dm_void
-)
+boolean
+phydm_nhm_get_result(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
-	u32			value32;
-	u8			i;
-
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT_11AC);
-		ccx_info->nhm_result[0] = (u8)(value32 & MASKBYTE0);
-		ccx_info->nhm_result[1] = (u8)((value32 & MASKBYTE1) >> 8);
-		ccx_info->nhm_result[2] = (u8)((value32 & MASKBYTE2) >> 16);
-		ccx_info->nhm_result[3] = (u8)((value32 & MASKBYTE3) >> 24);
-
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT7_TO_CNT4_11AC);
-		ccx_info->nhm_result[4] = (u8)(value32 & MASKBYTE0);
-		ccx_info->nhm_result[5] = (u8)((value32 & MASKBYTE1) >> 8);
-		ccx_info->nhm_result[6] = (u8)((value32 & MASKBYTE2) >> 16);
-		ccx_info->nhm_result[7] = (u8)((value32 & MASKBYTE3) >> 24);
-
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT11_TO_CNT8_11AC);
-		ccx_info->nhm_result[8] = (u8)(value32 & MASKBYTE0);
-		ccx_info->nhm_result[9] = (u8)((value32 & MASKBYTE1) >> 8);
-		ccx_info->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
-		ccx_info->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
-
-		/*Get NHM duration*/
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_DUR_READY_11AC);
-		ccx_info->nhm_duration = (u16)(value32 & MASKLWORD);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 value32 = 0;
+	u8 i = 0;
+	u32 nhm_reg1 = 0;
+	u16 nhm_rpt_sum_tmp = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		nhm_reg1 = R_0x994;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		nhm_reg1 = R_0x1e60;
+	#endif
+	else
+		nhm_reg1 = R_0x890;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (!(dm->support_ic_type == ODM_RTL8822C))
+		pdm_set_reg(dm, nhm_reg1, BIT(1), 0);
+
+#if (ENV_MNTR_DBG_2)
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "[DBG][3] 0xc50=0x%x, 0x994=0x%x, 0x998=0x%x\n",
+		  odm_get_bb_reg(dm, R_0xc50, MASKDWORD),
+		  odm_get_bb_reg(dm, R_0x994, MASKDWORD),
+		  odm_get_bb_reg(dm, R_0x998, MASKDWORD));
+#endif
 
+	if (!(phydm_nhm_check_rdy(dm))) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM report Fail\n");
+		phydm_nhm_racing_release(dm);
+		return false;
 	}
 
-	else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		value32 = odm_read_4byte(dm, R_0xfa8);
+		odm_move_memory(dm, &ccx->nhm_result[0], &value32, 4);
+
+		value32 = odm_read_4byte(dm, R_0xfac);
+		odm_move_memory(dm, &ccx->nhm_result[4], &value32, 4);
 
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT_11N);
-		ccx_info->nhm_result[0] = (u8)(value32 & MASKBYTE0);
-		ccx_info->nhm_result[1] = (u8)((value32 & MASKBYTE1) >> 8);
-		ccx_info->nhm_result[2] = (u8)((value32 & MASKBYTE2) >> 16);
-		ccx_info->nhm_result[3] = (u8)((value32 & MASKBYTE3) >> 24);
+		value32 = odm_read_4byte(dm, R_0xfb0);
+		odm_move_memory(dm, &ccx->nhm_result[8], &value32, 4);
+
+		/*@Get NHM duration*/
+		value32 = odm_read_4byte(dm, R_0xfb4);
+		ccx->nhm_duration = (u16)(value32 & MASKLWORD);
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		value32 = odm_read_4byte(dm, R_0x2d40);
+		odm_move_memory(dm, &ccx->nhm_result[0], &value32, 4);
+
+		value32 = odm_read_4byte(dm, R_0x2d44);
+		odm_move_memory(dm, &ccx->nhm_result[4], &value32, 4);
+
+		value32 = odm_read_4byte(dm, R_0x2d48);
+		odm_move_memory(dm, &ccx->nhm_result[8], &value32, 4);
+
+		/*@Get NHM duration*/
+		value32 = odm_read_4byte(dm, R_0x2d4c);
+		ccx->nhm_duration = (u16)(value32 & MASKLWORD);
+	#endif
+	} else {
+		value32 = odm_read_4byte(dm, R_0x8d8);
+		odm_move_memory(dm, &ccx->nhm_result[0], &value32, 4);
 
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT7_TO_CNT4_11N);
-		ccx_info->nhm_result[4] = (u8)(value32 & MASKBYTE0);
-		ccx_info->nhm_result[5] = (u8)((value32 & MASKBYTE1) >> 8);
-		ccx_info->nhm_result[6] = (u8)((value32 & MASKBYTE2) >> 16);
-		ccx_info->nhm_result[7] = (u8)((value32 & MASKBYTE3) >> 24);
+		value32 = odm_read_4byte(dm, R_0x8dc);
+		odm_move_memory(dm, &ccx->nhm_result[4], &value32, 4);
 
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT9_TO_CNT8_11N);
-		ccx_info->nhm_result[8] = (u8)((value32 & MASKBYTE2) >> 16);
-		ccx_info->nhm_result[9] = (u8)((value32 & MASKBYTE3) >> 24);
+		value32 = odm_get_bb_reg(dm, R_0x8d0, 0xffff0000);
+		odm_move_memory(dm, &ccx->nhm_result[8], &value32, 2);
 
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT10_TO_CNT11_11N);
-		ccx_info->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
-		ccx_info->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
+		value32 = odm_read_4byte(dm, R_0x8d4);
 
-		/*Get NHM duration*/
-		value32 = odm_read_4byte(p_dm, ODM_REG_NHM_CNT10_TO_CNT11_11N);
-		ccx_info->nhm_duration = (u16)(value32 & MASKLWORD);
+		ccx->nhm_result[10] = (u8)((value32 & MASKBYTE2) >> 16);
+		ccx->nhm_result[11] = (u8)((value32 & MASKBYTE3) >> 24);
 
+		/*@Get NHM duration*/
+		ccx->nhm_duration = (u16)(value32 & MASKLWORD);
 	}
 
 	/* sum all nhm_result */
-	ccx_info->nhm_result_total = 0;
-	for (i = 0; i <= 11; i++)
-		ccx_info->nhm_result_total += ccx_info->nhm_result[i];
-
-		PHYDM_DBG(p_dm, DBG_ENV_MNTR,
-		("NHM_result=(H->L)[%d %d %d %d (igi) %d %d %d %d %d %d %d %d]\n",
-			ccx_info->nhm_result[11], ccx_info->nhm_result[10], ccx_info->nhm_result[9],
-			ccx_info->nhm_result[8], ccx_info->nhm_result[7], ccx_info->nhm_result[6],
-			ccx_info->nhm_result[5], ccx_info->nhm_result[4], ccx_info->nhm_result[3],
-			ccx_info->nhm_result[2], ccx_info->nhm_result[1], ccx_info->nhm_result[0]));
+	if (ccx->nhm_period >= 65530) {
+		value32 = (ccx->nhm_duration * 100) >> 16;
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "NHM valid time = %d, valid: %d percent\n",
+			  ccx->nhm_duration, value32);
+	}
+
+	for (i = 0; i < NHM_RPT_NUM; i++)
+		nhm_rpt_sum_tmp += (u16)ccx->nhm_result[i];
+
+	ccx->nhm_rpt_sum = (u8)nhm_rpt_sum_tmp;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "NHM_Rpt[%d](H->L)[%d %d %d %d %d %d %d %d %d %d %d %d]\n",
+		  ccx->nhm_rpt_stamp, ccx->nhm_result[11], ccx->nhm_result[10],
+		  ccx->nhm_result[9], ccx->nhm_result[8], ccx->nhm_result[7],
+		  ccx->nhm_result[6], ccx->nhm_result[5], ccx->nhm_result[4],
+		  ccx->nhm_result[3], ccx->nhm_result[2], ccx->nhm_result[1],
+		  ccx->nhm_result[0]);
+
+	phydm_nhm_racing_release(dm);
+
+#if (ENV_MNTR_DBG_2)
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "[DBG][4] 0xc50=0x%x, 0x994=0x%x, 0x998=0x%x\n",
+		  odm_get_bb_reg(dm, R_0xc50, MASKDWORD),
+		  odm_get_bb_reg(dm, R_0x994, MASKDWORD),
+		  odm_get_bb_reg(dm, R_0x998, MASKDWORD));
+#endif
+
+	if (nhm_rpt_sum_tmp > 255) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "[Warning] Invalid NHM RPT, total=%d\n",
+			  nhm_rpt_sum_tmp);
+		return false;
+	}
+
+	return true;
 }
 
-boolean
-phydm_check_nhm_rdy(
-	void		*p_dm_void
-)
+void phydm_nhm_set_th_reg(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			i;
-	boolean			is_ready = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 reg1 = 0, reg2 = 0, reg3 = 0, reg4 = 0, reg4_bit = 0;
+	u32 val = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = R_0x994;
+		reg2 = R_0x998;
+		reg3 = R_0x99c;
+		reg4 = R_0x9a0;
+		reg4_bit = MASKBYTE0;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		reg1 = R_0x1e60;
+		reg2 = R_0x1e44;
+		reg3 = R_0x1e48;
+		reg4 = R_0x1e5c;
+		reg4_bit = MASKBYTE2;
+	#endif
+	} else {
+		reg1 = R_0x890;
+		reg2 = R_0x898;
+		reg3 = R_0x89c;
+		reg4 = R_0xe28;
+		reg4_bit = MASKBYTE0;
+	}
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	/*Set NHM threshold*/ /*Unit: PWdB U(8,1)*/
+	val = BYTE_2_DWORD(ccx->nhm_th[3], ccx->nhm_th[2],
+			   ccx->nhm_th[1], ccx->nhm_th[0]);
+	pdm_set_reg(dm, reg2, MASKDWORD, val);
+	val = BYTE_2_DWORD(ccx->nhm_th[7], ccx->nhm_th[6],
+			   ccx->nhm_th[5], ccx->nhm_th[4]);
+	pdm_set_reg(dm, reg3, MASKDWORD, val);
+	pdm_set_reg(dm, reg4, reg4_bit, ccx->nhm_th[8]);
+	val = BYTE_2_DWORD(0, 0, ccx->nhm_th[10], ccx->nhm_th[9]);
+	pdm_set_reg(dm, reg1, 0xffff0000, val);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "Update NHM_th[H->L]=[%d %d %d %d %d %d %d %d %d %d %d]\n",
+		  ccx->nhm_th[10], ccx->nhm_th[9], ccx->nhm_th[8],
+		  ccx->nhm_th[7], ccx->nhm_th[6], ccx->nhm_th[5],
+		  ccx->nhm_th[4], ccx->nhm_th[3], ccx->nhm_th[2],
+		  ccx->nhm_th[1], ccx->nhm_th[0]);
+}
 
-		for (i = 0; i < 200; i++) {
-			ODM_delay_ms(1);
-			if (odm_get_bb_reg(p_dm, ODM_REG_NHM_DUR_READY_11AC, BIT(16))) {
-				is_ready = 1;
-				break;
-			}
+boolean
+phydm_nhm_th_update_chk(void *dm_void, enum nhm_application nhm_app, u8 *nhm_th,
+			u32 *igi_new)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	boolean is_update = false;
+	u8 igi_curr = phydm_get_igi(dm, BB_PATH_A);
+	u8 nhm_igi_th_11k_low[NHM_TH_NUM] = {0x12, 0x15, 0x18, 0x1b, 0x1e,
+					     0x23, 0x28, 0x2c, 0x78,
+					     0x78, 0x78};
+	u8 nhm_igi_th_11k_high[NHM_TH_NUM] = {0x1e, 0x23, 0x28, 0x2d, 0x32,
+					      0x37, 0x78, 0x78, 0x78, 0x78,
+					      0x78};
+	u8 nhm_igi_th_xbox[NHM_TH_NUM] = {0x1a, 0x2c, 0x2e, 0x30, 0x32, 0x34,
+					  0x36, 0x38, 0x3a, 0x3c, 0x3d};
+	u8 i;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "App=%d, nhm_igi=0x%x, igi_curr=0x%x\n",
+		  nhm_app, ccx->nhm_igi, igi_curr);
+
+	if (igi_curr < 0x10) /* Protect for invalid IGI*/
+		return false;
+
+	switch (nhm_app) {
+	case NHM_BACKGROUND: /*@Get IGI form driver parameter(cur_ig_value)*/
+	case NHM_ACS:
+		if (ccx->nhm_igi != igi_curr || ccx->nhm_app != nhm_app) {
+			is_update = true;
+			*igi_new = (u32)igi_curr;
+			nhm_th[0] = (u8)IGI_2_NHM_TH(igi_curr - CCA_CAP);
+			for (i = 1; i <= 10; i++)
+				nhm_th[i] = nhm_th[0] + IGI_2_NHM_TH(2 * i);
+		}
+		break;
+
+	case IEEE_11K_HIGH:
+		is_update = true;
+		*igi_new = 0x2c;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_11k_high[i]);
+		break;
+
+	case IEEE_11K_LOW:
+		is_update = true;
+		*igi_new = 0x20;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_11k_low[i]);
+		break;
+
+	case INTEL_XBOX:
+		is_update = true;
+		*igi_new = 0x36;
+		for (i = 0; i < NHM_TH_NUM; i++)
+			nhm_th[i] = IGI_2_NHM_TH(nhm_igi_th_xbox[i]);
+		break;
+
+	case NHM_DBG: /*@Get IGI form register*/
+		igi_curr = phydm_get_igi(dm, BB_PATH_A);
+		if (ccx->nhm_igi != igi_curr || ccx->nhm_app != nhm_app) {
+			is_update = true;
+			*igi_new = (u32)igi_curr;
+			nhm_th[0] = (u8)IGI_2_NHM_TH(igi_curr - CCA_CAP);
+			for (i = 1; i <= 10; i++)
+				nhm_th[i] = nhm_th[0] + IGI_2_NHM_TH(2 * i);
 		}
+		break;
 	}
 
-	else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	if (is_update) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[Update NHM_TH] igi_RSSI=%d\n",
+			  IGI_2_RSSI(*igi_new));
 
-		for (i = 0; i < 200; i++) {
-			ODM_delay_ms(1);
-			if (odm_get_bb_reg(p_dm, 0x8b4, BIT(17))) {
-				is_ready = 1;
-				break;
-			}
+		for (i = 0; i < NHM_TH_NUM; i++) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM_th[%d](RSSI) = %d\n",
+				  i, NTH_TH_2_RSSI(nhm_th[i]));
 		}
+	} else {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "No need to update NHM_TH\n");
 	}
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("NHM rdy=%d\n", is_ready));
-	return is_ready;
+	return is_update;
 }
 
-void
-phydm_store_nhm_setting(
-	void		*p_dm_void
-)
+void phydm_nhm_set(void *dm_void, enum nhm_option_txon_all include_tx,
+		   enum nhm_option_cca_all include_cca,
+		   enum nhm_divider_opt_all divi_opt,
+		   enum nhm_application nhm_app, u16 period)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
-
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u8 nhm_th[NHM_TH_NUM] = {0};
+	u32 igi = 0x20;
+	u32 reg1 = 0, reg2 = 0;
+	u32 val_tmp = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "incld{tx, cca}={%d, %d}, divi_opt=%d, period=%d\n",
+		  include_tx, include_cca, divi_opt, period);
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = R_0x994;
+		reg2 = R_0x990;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		reg1 = R_0x1e60;
+		reg2 = R_0x1e40;
+	#endif
+	} else {
+		reg1 = R_0x890;
+		reg2 = R_0x894;
+	}
 
+	/*Set disable_ignore_cca, disable_ignore_txon, ccx_en*/
+	if (include_tx != ccx->nhm_include_txon ||
+	    include_cca != ccx->nhm_include_cca ||
+	    divi_opt != ccx->nhm_divider_opt) {
+	    /* some old ic is not supported on NHM divider option */
+		if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8723B |
+		    ODM_RTL8195A | ODM_RTL8192E)) {
+			val_tmp = (u32)((include_tx << 2) |
+				  (include_cca << 1) | 1);
+			pdm_set_reg(dm, reg1, R_0x700, val_tmp);
+		} else {
+			val_tmp = (u32)BIT_2_BYTE(divi_opt, include_tx,
+				  include_cca, 1);
+			pdm_set_reg(dm, reg1, R_0xf00, val_tmp);
+		}
+		ccx->nhm_include_txon = include_tx;
+		ccx->nhm_include_cca = include_cca;
+		ccx->nhm_divider_opt = divi_opt;
+		#if 0
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "val_tmp=%d, incld{tx, cca}={%d, %d}, divi_opt=%d, period=%d\n",
+			  val_tmp, include_tx, include_cca, divi_opt, period);
+
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "0x994=0x%x\n",
+			  odm_get_bb_reg(dm, 0x994, 0xf00));
+		#endif
+	}
 
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	/*Set NHM period*/
+	if (period != ccx->nhm_period) {
+		pdm_set_reg(dm, reg2, MASKHWORD, period);
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "Update NHM period ((%d)) -> ((%d))\n",
+			  ccx->nhm_period, period);
 
+		ccx->nhm_period = period;
+	}
 
+	/*Set NHM threshold*/
+	if (phydm_nhm_th_update_chk(dm, nhm_app, &(nhm_th[0]), &igi)) {
+		/*Pause IGI*/
+		if (nhm_app == NHM_BACKGROUND || nhm_app == NHM_ACS) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "DIG Free Run\n");
+		} else if (phydm_pause_func(dm, F00_DIG, PHYDM_PAUSE,
+					    PHYDM_PAUSE_LEVEL_1, 1, &igi)
+					    == PAUSE_FAIL) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pause DIG Fail\n");
+			return;
+		} else {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "pause DIG=0x%x\n", igi);
+		}
+		ccx->nhm_app = nhm_app;
+		ccx->nhm_igi = (u8)igi;
+		odm_move_memory(dm, &ccx->nhm_th[0], &nhm_th, NHM_TH_NUM);
 
+		/*Set NHM th*/
+		phydm_nhm_set_th_reg(dm);
 	}
 }
 
-void
-phydm_clm_setting(
-	void			*p_dm_void
-)
+u8 phydm_nhm_mntr_set(void *dm_void, struct nhm_para_info *nhm_para)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO	*ccx_info = &p_dm->dm_ccx_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 nhm_time = 0; /*unit: 4us*/
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
 
-		odm_set_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11AC, MASKLWORD, ccx_info->clm_period);	/*4us sample 1 time*/
-		/**/
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	if (nhm_para->mntr_time == 0)
+		return PHYDM_SET_FAIL;
 
-		odm_set_bb_reg(p_dm, ODM_REG_CCX_PERIOD_11N, MASKLWORD, ccx_info->clm_period);
-		/**/
+	if (nhm_para->nhm_lv >= NHM_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Wrong LV=%d\n", nhm_para->nhm_lv);
+		return PHYDM_SET_FAIL;
 	}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Set CLM period=%d * 4us\n", ccx_info->clm_period));
+	if (phydm_nhm_racing_ctrl(dm, nhm_para->nhm_lv) == PHYDM_SET_FAIL)
+		return PHYDM_SET_FAIL;
+
+	if (nhm_para->mntr_time >= 262)
+		nhm_time = NHM_PERIOD_MAX;
+	else
+		nhm_time = nhm_para->mntr_time * MS_TO_4US_RATIO;
+
+	phydm_nhm_set(dm, nhm_para->incld_txon, nhm_para->incld_cca,
+		      nhm_para->div_opt, nhm_para->nhm_app, nhm_time);
 
+	return PHYDM_SET_SUCCESS;
 }
 
-void
-phydm_clm_hw_restart(
-	void			*p_dm_void
-)
+/*@Environment Monitor*/
+boolean
+phydm_nhm_mntr_chk(void *dm_void, u16 monitor_time /*unit ms*/)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO	*ccx_info = &p_dm->dm_ccx_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	struct nhm_para_info nhm_para = {0};
+	boolean nhm_chk_result = false;
+	u32 sys_return_time = 0;
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
 
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11AC, BIT(8), 0x0); /*Enable CCX for CLM*/
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11AC, BIT(8), 0x1); /*Enable CCX for CLM*/
-
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	if (ccx->nhm_manual_ctrl) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "NHM in manual ctrl\n");
+		return nhm_chk_result;
+	}
+	sys_return_time = ccx->nhm_trigger_time + MAX_ENV_MNTR_TIME;
+	if (ccx->nhm_app != NHM_BACKGROUND &&
+	    (sys_return_time > dm->phydm_sys_up_time)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "nhm_app=%d, trigger_time %d, sys_time=%d\n",
+			  ccx->nhm_app, ccx->nhm_trigger_time,
+			  dm->phydm_sys_up_time);
+
+		return nhm_chk_result;
+	}
 
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11AC, BIT(8), 0x0); /*Enable CCX for CLM*/
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11N, BIT(8), 0x1);	/*Enable CCX for CLM*/
+	/*@[NHM get result & calculate Utility----------------------------*/
+	if (phydm_nhm_get_result(dm)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM_rpt success\n");
+		phydm_nhm_get_utility(dm);
 	}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Set CLM period=%d * 4us\n", ccx_info->clm_period));
+	/*@[NHM trigger]-------------------------------------------------*/
+	nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+	nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+	nhm_para.div_opt = NHM_CNT_ALL;
+	nhm_para.nhm_app = NHM_BACKGROUND;
+	nhm_para.nhm_lv = NHM_LV_1;
+	nhm_para.mntr_time = monitor_time;
+
+	nhm_chk_result = phydm_nhm_mntr_set(dm, &nhm_para);
 
+	return nhm_chk_result;
 }
 
-void
-phydm_clm_trigger(
-	void			*p_dm_void
-)
+void phydm_nhm_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "cur_igi=0x%x\n",
+		  dm->dm_dig_table.cur_ig_value);
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11AC, BIT(0), 0x0);	/*Trigger CLM*/
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11AC, BIT(0), 0x1);
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11N, BIT(0), 0x0);	/*Trigger CLM*/
-		odm_set_bb_reg(p_dm, ODM_REG_CLM_11N, BIT(0), 0x1);
-	}
+	ccx->nhm_app = NHM_BACKGROUND;
+	ccx->nhm_igi = 0xff;
+
+	/*Set NHM threshold*/
+	ccx->nhm_ongoing = false;
+	ccx->nhm_set_lv = NHM_RELEASE;
+
+	if (phydm_nhm_th_update_chk(dm, ccx->nhm_app, &ccx->nhm_th[0],
+				    (u32 *)&ccx->nhm_igi))
+		phydm_nhm_set_th_reg(dm);
+
+	ccx->nhm_period = 0;
+
+	ccx->nhm_include_cca = NHM_CCA_INIT;
+	ccx->nhm_include_txon = NHM_TXON_INIT;
+	ccx->nhm_divider_opt = NHM_CNT_INIT;
+
+	ccx->nhm_manual_ctrl = 0;
+	ccx->nhm_rpt_stamp = 0;
 }
 
-boolean
-phydm_check_clm_rdy(
-	void			*p_dm_void
-)
+void phydm_nhm_dbg(void *dm_void, char input[][16], u32 *_used, char *output,
+		   u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean			is_ready = false;
-	u8				i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	struct nhm_para_info nhm_para;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	boolean nhm_rpt_success = true;
+	u8 result_tmp = 0;
+	u8 i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		for (i = 0; i < 200; i++) {
-			ODM_delay_ms(1);
-			if (odm_get_bb_reg(p_dm, ODM_REG_CLM_RESULT_11AC, BIT(16))) {
-				is_ready = 1;
-				break;
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "NHM Basic-Trigger 262ms: {1}\n");
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "NHM Adv-Trigger: {2} {Include TXON} {Include CCA}\n{0:Cnt_all, 1:Cnt valid} {App} {LV} {0~262ms}\n");
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "NHM Get Result: {100}\n");
+	} else if (var1[0] == 100) { /*@Get NHM results*/
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "IGI=0x%x, rpt_stamp=%d\n", ccx->nhm_igi,
+			 ccx->nhm_rpt_stamp);
+
+		nhm_rpt_success = phydm_nhm_get_result(dm);
+
+		if (nhm_rpt_success) {
+			for (i = 0; i <= 11; i++) {
+				result_tmp = ccx->nhm_result[i];
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "nhm_rpt[%d] = %d (%d percent)\n",
+					 i, result_tmp,
+					 (((result_tmp * 100) + 128) >> 8));
 			}
+		} else {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Get NHM_rpt Fail\n");
 		}
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		for (i = 0; i < 200; i++) {
-			ODM_delay_ms(1);
-			if (odm_get_bb_reg(p_dm, ODM_REG_CLM_READY_11N, BIT(16))) {
-				is_ready = 1;
-				break;
+		ccx->nhm_manual_ctrl = 0;
+
+	} else { /*NMH trigger*/
+
+		ccx->nhm_manual_ctrl = 1;
+
+		for (i = 1; i < 7; i++) {
+			if (input[i + 1]) {
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL,
+					     &var1[i]);
+			}
+		}
+
+		if (var1[0] == 1) {
+			nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+			nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+			nhm_para.div_opt = NHM_CNT_ALL;
+			nhm_para.nhm_app = NHM_DBG;
+			nhm_para.nhm_lv = NHM_LV_4;
+			nhm_para.mntr_time = 262;
+		} else {
+			nhm_para.incld_txon = (enum nhm_option_txon_all)var1[1];
+			nhm_para.incld_cca = (enum nhm_option_cca_all)var1[2];
+			nhm_para.div_opt = (enum nhm_divider_opt_all)var1[3];
+			nhm_para.nhm_app = (enum nhm_application)var1[4];
+			nhm_para.nhm_lv = (enum phydm_nhm_level)var1[5];
+			nhm_para.mntr_time = (u16)var1[6];
+
+			/* some old ic is not supported on NHM divider option */
+			if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8723B |
+			    ODM_RTL8195A | ODM_RTL8192E)) {
+				nhm_para.div_opt = NHM_CNT_ALL;
 			}
 		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "txon=%d, cca=%d, dev=%d, app=%d, lv=%d, time=%d ms\n",
+			 nhm_para.incld_txon, nhm_para.incld_cca,
+			 nhm_para.div_opt, nhm_para.nhm_app,
+			 nhm_para.nhm_lv, nhm_para.mntr_time);
+
+		if (phydm_nhm_mntr_set(dm, &nhm_para) == PHYDM_SET_SUCCESS)
+			phydm_nhm_trigger(dm);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "IGI=0x%x, rpt_stamp=%d\n", ccx->nhm_igi,
+			 ccx->nhm_rpt_stamp);
+
+		for (i = 0; i <= 10; i++) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "NHM_th[%d] RSSI = %d\n", i,
+				 NTH_TH_2_RSSI(ccx->nhm_th[i]));
+		}
 	}
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("CLM rdy=%d\n", is_ready));
-	return is_ready;
+
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif /*@#ifdef NHM_SUPPORT*/
+
+#ifdef CLM_SUPPORT
+
+void phydm_clm_racing_release(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "lv:(%d)->(0)\n", ccx->clm_set_lv);
+
+	ccx->clm_ongoing = false;
+	ccx->clm_set_lv = CLM_RELEASE;
+	ccx->clm_app = CLM_BACKGROUND;
 }
 
-void
-phydm_get_clm_result(
-	void			*p_dm_void
-)
+u8 phydm_clm_racing_ctrl(void *dm_void, enum phydm_nhm_level clm_lv)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO	*ccx_info = &p_dm->dm_ccx_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u8 set_result = PHYDM_SET_SUCCESS;
+	/*@acquire to control CLM API*/
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_ongoing=%d, lv:(%d)->(%d)\n",
+		  ccx->clm_ongoing, ccx->clm_set_lv, clm_lv);
+	if (ccx->clm_ongoing) {
+		if (clm_lv <= ccx->clm_set_lv) {
+			set_result = PHYDM_SET_FAIL;
+		} else {
+			phydm_ccx_hw_restart(dm);
+			ccx->clm_ongoing = false;
+		}
+	}
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-		ccx_info->clm_result = (u16)odm_get_bb_reg(p_dm, ODM_REG_CLM_RESULT_11AC, MASKDWORD);
-	else if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-		ccx_info->clm_result = (u16)odm_get_bb_reg(p_dm, ODM_REG_CLM_RESULT_11N, MASKDWORD);
+	if (set_result)
+		ccx->clm_set_lv = clm_lv;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("CLM result = %d *4 us\n", ccx_info->clm_result));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm racing success=%d\n", set_result);
+	return set_result;
 }
 
-void
-phydm_set_nhm_th_by_igi(
-	void			*p_dm_void,
-	u8				igi
-)
+void phydm_clm_c2h_report_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
-	u8	th_gap = 2 * IGI_TO_NHM_TH_MULTIPLIER;
-	u8	i;
-
-	ccx_info->echo_igi = igi;
-	ccx_info->nhm_th[0] = (ccx_info->echo_igi - CCA_CAP) * IGI_TO_NHM_TH_MULTIPLIER;
-	for (i = 1; i <= 10; i++)
-		ccx_info->nhm_th[i] = ccx_info->nhm_th[0] + th_gap * i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
+	u8 clm_report = cmd_buf[0];
+	/*@u8 clm_report_idx = cmd_buf[1];*/
+
+	if (cmd_len >= 12)
+		return;
+
+	ccx_info->clm_fw_result_acc += clm_report;
+	ccx_info->clm_fw_result_cnt++;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%d] clm_report= %d\n",
+		  ccx_info->clm_fw_result_cnt, clm_report);
 }
 
-void
-phydm_set_clm_mntr_mode(
-	void			*p_dm_void,
-	enum clm_monitor_mode_e mode
-)
+void phydm_clm_h2c(void *dm_void, u16 obs_time, u8 fw_clm_en)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 h2c_val[H2C_MAX_LENGTH] = {0};
+	u8 i = 0;
+	u8 obs_time_idx = 0;
 
-	if (ccx_info->clm_mntr_mode != mode) {
-		ccx_info->clm_mntr_mode = mode;
-		phydm_clm_hw_restart(p_dm);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "obs_time_index=%d *4 us\n", obs_time);
 
-		if (mode == CLM_DRIVER_MNTR) {
-			phydm_clm_h2c(p_dm,0, 0);
+	for (i = 1; i <= 16; i++) {
+		if (obs_time & BIT(16 - i)) {
+			obs_time_idx = 16 - i;
+			break;
 		}
 	}
+#if 0
+	obs_time = (2 ^ 16 - 1)~(2 ^ 15)  => obs_time_idx = 15  (65535 ~32768)
+	obs_time = (2 ^ 15 - 1)~(2 ^ 14)  => obs_time_idx = 14
+	...
+	...
+	...
+	obs_time = (2 ^ 1 - 1)~(2 ^ 0)  => obs_time_idx = 0
+
+#endif
+
+	h2c_val[0] = obs_time_idx | (((fw_clm_en) ? 1 : 0) << 7);
+	h2c_val[1] = CLM_MAX_REPORT_TIME;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "PHYDM h2c[0x4d]=0x%x %x %x %x %x %x %x\n",
+		  h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2],
+		  h2c_val[1], h2c_val[0]);
+
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_FW_CLM_MNTR, H2C_MAX_LENGTH, h2c_val);
 }
 
-void
-phydm_ccx_monitor_trigger(
-	void			*p_dm_void,
-	u16			monitor_time		/*unit ms*/
-)
+void phydm_clm_setting(void *dm_void, u16 clm_period /*@4us sample 1 time*/)
 {
-	u8			nhm_th[11], i, igi;
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
-	u16 	monitor_time_4us = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+
+	if (ccx->clm_period != clm_period) {
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+			odm_set_bb_reg(dm, R_0x990, MASKLWORD, clm_period);
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			odm_set_bb_reg(dm, R_0x1e40, MASKLWORD, clm_period);
+		#endif
+		else if (dm->support_ic_type & ODM_IC_11N_SERIES)
+			odm_set_bb_reg(dm, R_0x894, MASKLWORD, clm_period);
+
+		ccx->clm_period = clm_period;
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "Update CLM period ((%d)) -> ((%d))\n",
+			  ccx->clm_period, clm_period);
+	}
 
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR))
-		return;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "Set CLM period=%d * 4us\n",
+		  ccx->clm_period);
+}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+void phydm_clm_trigger(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 reg1 = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		reg1 = R_0x994;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		reg1 = R_0x1e60;
+	#endif
+	else
+		reg1 = R_0x890;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
 
-	if (monitor_time == 0)
-		return;
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x0);
+	odm_set_bb_reg(dm, reg1, BIT(0), 0x1);
 
-	if (monitor_time >= 262)
-		monitor_time_4us = 65534;
+	ccx->clm_trigger_time = dm->phydm_sys_up_time;
+	ccx->clm_rpt_stamp++;
+	ccx->clm_ongoing = true;
+}
+
+boolean
+phydm_clm_check_rdy(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean is_ready = false;
+	u32 reg1 = 0, reg1_bit = 0;
+#if (ENV_MNTR_DBG)
+	u16 i = 0;
+	u64 start_time = 0, progressing_time = 0;
+#endif
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		reg1 = R_0xfa4;
+		reg1_bit = 16;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		reg1 = R_0x2d88;
+		reg1_bit = 16;
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (dm->support_ic_type == ODM_RTL8710B) {
+			reg1 = R_0x8b4;
+			reg1_bit = 24;
+		} else {
+			reg1 = R_0x8b4;
+			reg1_bit = 16;
+		}
+	}
+#if (ENV_MNTR_DBG)
+	start_time = odm_get_current_time(dm);
+	for (i = 0; i <= 400; i++) {
+		if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit))) {
+			is_ready = true;
+			break;
+		}
+		ODM_delay_ms(1);
+	}
+	progressing_time = odm_get_progressing_time(dm, start_time);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM rdy=%d, i=%d, CLM_polling_time=%lld\n",
+		  is_ready, i, progressing_time);
+#else
+	if (odm_get_bb_reg(dm, reg1, BIT(reg1_bit)))
+		is_ready = true;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM rdy=%d\n", is_ready);
+#endif
+	return is_ready;
+}
+
+void phydm_clm_get_utility(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 clm_result_tmp;
+
+	if (ccx->clm_period == 0) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[warning] clm_period = 0\n");
+		ccx->clm_ratio = 0;
+	} else if (ccx->clm_period >= 65530) {
+		clm_result_tmp = (u32)(ccx->clm_result * 100);
+		ccx->clm_ratio = (u8)((clm_result_tmp + (1 << 15)) >> 16);
+	} else {
+		clm_result_tmp = (u32)(ccx->clm_result * 100);
+		ccx->clm_ratio = (u8)(clm_result_tmp / (u32)ccx->clm_period);
+	}
+}
+
+boolean
+phydm_clm_get_result(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
+	u32 reg1 = 0;
+	u32 val = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		reg1 = R_0x994;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		reg1 = R_0x1e60;
+	#endif
 	else
-		monitor_time_4us = monitor_time * MS_TO_4US_RATIO;
-
-	/* check if NHM threshold is changed */
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		
-		nhm_th[0] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE0);
-		nhm_th[1] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE1);
-		nhm_th[2] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE2);
-		nhm_th[3] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11AC, MASKBYTE3);
-		nhm_th[4] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE0);
-		nhm_th[5] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE1);
-		nhm_th[6] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE2);
-		nhm_th[7] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11AC, MASKBYTE3);
-		nhm_th[8] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH8_11AC, MASKBYTE0);
-		nhm_th[9] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE2);
-		nhm_th[10] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11AC, MASKBYTE3);
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		
-		nhm_th[0] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE0);
-		nhm_th[1] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE1);
-		nhm_th[2] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE2);
-		nhm_th[3] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH3_TO_TH0_11N, MASKBYTE3);
-		nhm_th[4] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE0);
-		nhm_th[5] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE1);
-		nhm_th[6] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE2);
-		nhm_th[7] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH7_TO_TH4_11N, MASKBYTE3);
-		nhm_th[8] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH8_11N, MASKBYTE0);
-		nhm_th[9] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE2);
-		nhm_th[10] = (u8)odm_get_bb_reg(p_dm, ODM_REG_NHM_TH9_TH10_11N, MASKBYTE3);
+		reg1 = R_0x890;
+	if (!(dm->support_ic_type == ODM_RTL8822C))
+		odm_set_bb_reg(dm, reg1, BIT(0), 0x0);
+	if (phydm_clm_check_rdy(dm) == false) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM report Fail\n");
+		phydm_clm_racing_release(dm);
+		return false;
 	}
 
-	for (i = 0; i <= 10; i++) {
-		
-		if (nhm_th[i] != ccx_info->nhm_th[i]) {	
-			PHYDM_DBG(p_dm, DBG_ENV_MNTR,
-				("nhm_th[%d] != ccx_info->nhm_th[%d]!!\n", i, i));
-		}
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		val = odm_get_bb_reg(dm, R_0xfa4, MASKLWORD);
+		ccx_info->clm_result = (u16)val;
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		val = odm_get_bb_reg(dm, R_0x2d88, MASKLWORD);
+		ccx_info->clm_result = (u16)val;
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		val = odm_get_bb_reg(dm, R_0x8d0, MASKLWORD);
+		ccx_info->clm_result = (u16)val;
 	}
-	/*[NHM]*/
-	igi = (u8)odm_get_bb_reg(p_dm, 0xC50, MASKBYTE0);
-	phydm_set_nhm_th_by_igi(p_dm, igi);
-
-	ccx_info->nhm_period = monitor_time_4us;
-	ccx_info->nhm_inexclude_cca = NHM_EXCLUDE_CCA;
-	ccx_info->nhm_inexclude_txon = NHM_EXCLUDE_TXON;
-
-	phydm_nhm_setting(p_dm, SET_NHM_SETTING);
-	phydm_nhm_trigger(p_dm);
-
-	/*[CLM]*/
-	ccx_info->clm_period = monitor_time_4us;
-	
-	if (ccx_info->clm_mntr_mode == CLM_DRIVER_MNTR) {
-		phydm_clm_setting(p_dm);
-		phydm_clm_trigger(p_dm);
-	} else if (ccx_info->clm_mntr_mode == CLM_FW_MNTR){
-		phydm_clm_h2c(p_dm, monitor_time_4us, TRUE);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM result = %d *4 us\n",
+		  ccx_info->clm_result);
+	phydm_clm_racing_release(dm);
+	return true;
+}
+
+void phydm_clm_mntr_fw(void *dm_void, u16 monitor_time /*unit ms*/)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 val = 0;
+
+	/*@[Get CLM report]*/
+	if (ccx->clm_fw_result_cnt != 0) {
+		val = ccx->clm_fw_result_acc / ccx->clm_fw_result_cnt;
+		ccx->clm_ratio = (u8)val;
 	} else {
-		PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("CLM_ECHO_DBG_MODE\n"));
+		ccx->clm_ratio = 0;
 	}
 
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+		  ccx->clm_fw_result_acc, ccx->clm_fw_result_cnt);
+
+	ccx->clm_fw_result_acc = 0;
+	ccx->clm_fw_result_cnt = 0;
+
+	/*@[CLM trigger]*/
+	if (monitor_time >= 262)
+		ccx->clm_period = 65535;
+	else
+		ccx->clm_period = monitor_time * MS_TO_4US_RATIO;
+
+	phydm_clm_h2c(dm, ccx->clm_period, true);
 }
 
-void
-phydm_ccx_monitor_result(
-	void			*p_dm_void
-)
+u8 phydm_clm_mntr_set(void *dm_void, struct clm_para_info *clm_para)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
-	u32					clm_result_tmp = 0;
+	/*@Driver Monitor CLM*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u16 clm_period = 0;
+
+	if (clm_para->mntr_time == 0)
+		return PHYDM_SET_FAIL;
+
+	if (clm_para->clm_lv >= CLM_MAX_NUM) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "[WARNING] Wrong LV=%d\n",
+			  clm_para->clm_lv);
+		return PHYDM_SET_FAIL;
+	}
 
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR))
-		return;
+	if (phydm_clm_racing_ctrl(dm, clm_para->clm_lv) == PHYDM_SET_FAIL)
+		return PHYDM_SET_FAIL;
+
+	if (clm_para->mntr_time >= 262)
+		clm_period = CLM_PERIOD_MAX;
+	else
+		clm_period = clm_para->mntr_time * MS_TO_4US_RATIO;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("%s ======>\n", __func__));
+	ccx->clm_app = clm_para->clm_app;
+	phydm_clm_setting(dm, clm_period);
 
-	if (phydm_check_nhm_rdy(p_dm)) {
-		phydm_get_nhm_result(p_dm);
+	return PHYDM_SET_SUCCESS;
+}
 
-		if (ccx_info->nhm_result_total != 0)
-			ccx_info->nhm_ratio  = (u8)(((ccx_info->nhm_result_total - ccx_info->nhm_result[0])*100) >> 8);
+boolean
+phydm_clm_mntr_chk(void *dm_void, u16 monitor_time /*unit ms*/)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	struct clm_para_info clm_para = {0};
+	boolean clm_chk_result = false;
+	u32 sys_return_time = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	if (ccx->clm_manual_ctrl) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "CLM in manual ctrl\n");
+		return clm_chk_result;
 	}
 
-	if (ccx_info->clm_mntr_mode == CLM_DRIVER_MNTR) {
-		
-		if (phydm_check_clm_rdy(p_dm)) {
-			phydm_get_clm_result(p_dm);
-
-			if (ccx_info->clm_period != 0) {
-
-				if (ccx_info->clm_period == 64000)
-					ccx_info->clm_ratio = (u8)(((ccx_info->clm_result >> 6) + 5) /10);
-				else if (ccx_info->clm_period == 65535) {
-					
-					clm_result_tmp = (u32)(ccx_info->clm_result * 100);
-					ccx_info->clm_ratio = (u8)((clm_result_tmp + (1<<15)) >> 16);
-				} else
-					ccx_info->clm_ratio = (u8)((ccx_info->clm_result*100) / ccx_info->clm_period);
-			}
+	sys_return_time = ccx->clm_trigger_time + MAX_ENV_MNTR_TIME;
+
+	if (ccx->clm_app != CLM_BACKGROUND &&
+	    sys_return_time > dm->phydm_sys_up_time) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "trigger_time %d, sys_time=%d\n",
+			  ccx->clm_trigger_time, dm->phydm_sys_up_time);
+
+		return clm_chk_result;
+	}
+
+	clm_para.clm_app = CLM_BACKGROUND;
+	clm_para.clm_lv = CLM_LV_1;
+	clm_para.mntr_time = monitor_time;
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		/*@[Get CLM report]*/
+		if (phydm_clm_get_result(dm)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM_rpt success\n");
+			phydm_clm_get_utility(dm);
 		}
-		
+
+		/*@[CLM trigger]----------------------------------------------*/
+		if (phydm_clm_mntr_set(dm, &clm_para) == PHYDM_SET_SUCCESS)
+			clm_chk_result = true;
 	} else {
-		if (ccx_info->clm_fw_result_cnt != 0)
-			ccx_info->clm_ratio = (u8)(ccx_info->clm_fw_result_acc /ccx_info->clm_fw_result_cnt);
-		else
-			ccx_info->clm_ratio = 0;
-
-		PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
-			ccx_info->clm_fw_result_acc, ccx_info->clm_fw_result_cnt));
-		
-		ccx_info->clm_fw_result_acc = 0;
-		ccx_info->clm_fw_result_cnt = 0;
+		phydm_clm_mntr_fw(dm, monitor_time);
 	}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("IGI=0x%x, nhm_ratio=%d, clm_ratio=%d\n\n",
-		ccx_info->echo_igi, ccx_info->nhm_ratio, ccx_info->clm_ratio));
-		
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_ratio=%d\n", ccx->clm_ratio);
+
+	/*@PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_chk_result=%d\n",clm_chk_result);*/
+
+	return clm_chk_result;
 }
 
-void
-phydm_ccx_monitor(
-	void			*p_dm_void
-)
+void phydm_set_clm_mntr_mode(void *dm_void, enum clm_monitor_mode mode)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
 
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR))
-		return;
+	if (ccx_info->clm_mntr_mode != mode) {
+		ccx_info->clm_mntr_mode = mode;
+		phydm_ccx_hw_restart(dm);
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+		if (mode == CLM_DRIVER_MNTR)
+			phydm_clm_h2c(dm, 0, 0);
+	}
+}
 
-	phydm_ccx_monitor_result(p_dm);
-	phydm_ccx_monitor_trigger(p_dm, 262);	/*monitor 262ms*/
+void phydm_clm_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	ccx->clm_ongoing = false;
+	ccx->clm_manual_ctrl = 0;
+	ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+	ccx->clm_period = 0;
+	ccx->clm_rpt_stamp = 0;
+	phydm_clm_setting(dm, 65535);
 }
 
-void
-phydm_nhm_init(
-	void			*p_dm_void
-)
+void phydm_clm_dbg(void *dm_void, char input[][16], u32 *_used, char *output,
+		   u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	struct clm_para_info clm_para = {0};
+	u32 i;
+
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+	}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("cur_ig_value=0x%x\n", p_dm->dm_dig_table.cur_ig_value));
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "CLM Driver Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "CLM Driver Adv-Trigger: {2} {app} {LV} {0~262ms}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "CLM FW Trigger: {3} {1:drv, 2:fw}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "CLM Get Result: {100}\n");
+	} else if (var1[0] == 100) { /* @Get CLM results */
 
-	phydm_set_nhm_th_by_igi(p_dm, p_dm->dm_dig_table.cur_ig_value);
+		if (phydm_clm_get_result(dm))
+			phydm_clm_get_utility(dm);
 
-	ccx_info->nhm_period = 64000;
-	ccx_info->nhm_inexclude_cca = NHM_EXCLUDE_CCA;
-	ccx_info->nhm_inexclude_txon = NHM_EXCLUDE_TXON;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "clm_rpt_stamp=%d\n", ccx->clm_rpt_stamp);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "clm_ratio:((%d percent)) = (%d us/ %d us)\n",
+			 ccx->clm_ratio, ccx->clm_result << 2,
+			 ccx->clm_period << 2);
+
+		ccx->clm_manual_ctrl = 0;
+
+	} else if (var1[0] == 3) {
+		phydm_set_clm_mntr_mode(dm, (enum clm_monitor_mode)var1[1]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "CLM mode: %s mode\n",
+			 ((ccx->clm_mntr_mode == CLM_FW_MNTR) ? "FW" : "Drv"));
+	} else { /* Set & trigger CLM */
+		ccx->clm_manual_ctrl = 1;
+
+		if (var1[0] == 1) {
+			clm_para.clm_app = CLM_BACKGROUND;
+			clm_para.clm_lv = CLM_LV_4;
+			clm_para.mntr_time = 262;
+			ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+
+		} else if (var1[0] == 2) {
+			clm_para.clm_app = (enum clm_application)var1[1];
+			clm_para.clm_lv = (enum phydm_clm_level)var1[2];
+			ccx->clm_mntr_mode = CLM_DRIVER_MNTR;
+			clm_para.mntr_time = (u16)var1[3];
+
+		}
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "app=%d, lv=%d, mode=%s, time=%d ms\n",
+			 clm_para.clm_app, clm_para.clm_lv,
+			 ((ccx->clm_mntr_mode == CLM_FW_MNTR) ? "FW" :
+			 "driver"), clm_para.mntr_time);
+
+		if (phydm_clm_mntr_set(dm, &clm_para) == PHYDM_SET_SUCCESS)
+			phydm_clm_trigger(dm);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "clm_rpt_stamp=%d\n", ccx->clm_rpt_stamp);
+	}
 
-	phydm_nhm_setting(p_dm, SET_NHM_SETTING);
+	*_used = used;
+	*_out_len = out_len;
 }
 
-void
-phydm_clm_init(
-	void			*p_dm_void
-)
+#endif /*@#ifdef CLM_SUPPORT*/
+
+u8 phydm_env_mntr_trigger(void *dm_void, struct nhm_para_info *nhm_para,
+			  struct clm_para_info *clm_para,
+			  struct env_trig_rpt *trig_rpt)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO		*ccx_info = &p_dm->dm_ccx_info;
+#if (defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	boolean nhm_set_ok = false;
+	boolean clm_set_ok = false;
+	u8 trigger_result = 0;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+
+#if (ENV_MNTR_DBG_2)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "[DBG][2] 0xc50=0x%x, 0x994=0x%x, 0x998=0x%x\n",
+		  odm_get_bb_reg(dm, R_0xc50, MASKDWORD),
+		  odm_get_bb_reg(dm, R_0x994, MASKDWORD),
+		  odm_get_bb_reg(dm, R_0x998, MASKDWORD));
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "[DBG][2] 0x1d70=0x%x, 0x1e60=0x%x, 0x1e44=0x%x\n",
+			 odm_get_bb_reg(dm, R_0x1d70, MASKDWORD),
+			 odm_get_bb_reg(dm, R_0x1e60, MASKDWORD),
+			 odm_get_bb_reg(dm, R_0x1e44, MASKDWORD));
+	#endif
+	}
+#endif
+
+	/*@[NHM]*/
+	nhm_set_ok = phydm_nhm_mntr_set(dm, nhm_para);
+
+	/*@[CLM]*/
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		clm_set_ok = phydm_clm_mntr_set(dm, clm_para);
+	} else if (ccx->clm_mntr_mode == CLM_FW_MNTR) {
+		phydm_clm_h2c(dm, CLM_PERIOD_MAX, true);
+		trigger_result |= CLM_SUCCESS;
+	}
+
+	if (nhm_set_ok) {
+		phydm_nhm_trigger(dm);
+		trigger_result |= NHM_SUCCESS;
+	}
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+	if (clm_set_ok) {
+		phydm_clm_trigger(dm);
+		trigger_result |= CLM_SUCCESS;
+	}
+
+	/*@monitor for the test duration*/
+	ccx->start_time = odm_get_current_time(dm);
+
+	trig_rpt->nhm_rpt_stamp = ccx->nhm_rpt_stamp;
+	trig_rpt->clm_rpt_stamp = ccx->clm_rpt_stamp;
 
-	ccx_info->clm_mntr_mode = CLM_DRIVER_MNTR;
-	ccx_info->clm_period = 65535;
-	phydm_clm_setting(p_dm);
-	phydm_clm_hw_restart(p_dm);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_rpt_stamp=%d, clm_rpt_stamp=%d,\n\n",
+		  trig_rpt->nhm_rpt_stamp, trig_rpt->clm_rpt_stamp);
+
+	return trigger_result;
+#endif
 }
 
-void
-phydm_env_monitor_init(
-	void			*p_dm_void
-)
+u8 phydm_env_mntr_result(void *dm_void, struct env_mntr_rpt *rpt)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+#if (defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u8 env_mntr_rpt = 0;
+	u64 progressing_time = 0;
+	u32 val_tmp = 0;
+
+	/*@monitor for the test duration*/
+	progressing_time = odm_get_progressing_time(dm, ccx->start_time);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s] ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "env_time=%lld\n", progressing_time);
+
+#if (ENV_MNTR_DBG_2)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "[DBG][2] 0xc50=0x%x, 0x994=0x%x, 0x998=0x%x\n",
+			  odm_get_bb_reg(dm, R_0xc50, MASKDWORD),
+			  odm_get_bb_reg(dm, R_0x994, MASKDWORD),
+			  odm_get_bb_reg(dm, R_0x998, MASKDWORD));
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "[DBG][2] 0x1d70=0x%x, 0x1e60=0x%x, 0x1e44=0x%x\n",
+			  odm_get_bb_reg(dm, R_0x1d70, MASKDWORD),
+			  odm_get_bb_reg(dm, R_0x1e60, MASKDWORD),
+			  odm_get_bb_reg(dm, R_0x1e44, MASKDWORD));
+	#endif
+	}
+#endif
+
+	/*@Get NHM result*/
+	if (phydm_nhm_get_result(dm)) {
+		PHYDM_DBG(dm, DBG_ENV_MNTR, "Get NHM_rpt success\n");
+		phydm_nhm_get_utility(dm);
+		rpt->nhm_ratio = ccx->nhm_ratio;
+		env_mntr_rpt |= NHM_SUCCESS;
 
-	if (!(p_dm->support_ability & ODM_BB_ENV_MONITOR))
+		odm_move_memory(dm, &rpt->nhm_result[0],
+				&ccx->nhm_result[0], NHM_RPT_NUM);
+	} else {
+		rpt->nhm_ratio = ENV_MNTR_FAIL;
+	}
+
+	/*@Get CLM result*/
+	if (ccx->clm_mntr_mode == CLM_DRIVER_MNTR) {
+		if (phydm_clm_get_result(dm)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Get CLM_rpt success\n");
+			phydm_clm_get_utility(dm);
+			env_mntr_rpt |= CLM_SUCCESS;
+			rpt->clm_ratio = ccx->clm_ratio;
+		} else {
+			rpt->clm_ratio = ENV_MNTR_FAIL;
+		}
+
+	} else {
+		if (ccx->clm_fw_result_cnt != 0) {
+			val_tmp = ccx->clm_fw_result_acc
+			/ ccx->clm_fw_result_cnt;
+			ccx->clm_ratio = (u8)val_tmp;
+		} else {
+			ccx->clm_ratio = 0;
+		}
+
+		rpt->clm_ratio = ccx->clm_ratio;
+		PHYDM_DBG(dm, DBG_ENV_MNTR,
+			  "clm_fw_result_acc=%d, clm_fw_result_cnt=%d\n",
+			  ccx->clm_fw_result_acc, ccx->clm_fw_result_cnt);
+
+		ccx->clm_fw_result_acc = 0;
+		ccx->clm_fw_result_cnt = 0;
+		env_mntr_rpt |= CLM_SUCCESS;
+	}
+
+	rpt->nhm_rpt_stamp = ccx->nhm_rpt_stamp;
+	rpt->clm_rpt_stamp = ccx->clm_rpt_stamp;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "IGI=0x%x, nhm_ratio=%d, clm_ratio=%d, nhm_rpt_stamp=%d, clm_rpt_stamp=%d\n\n",
+		  ccx->nhm_igi, rpt->nhm_ratio, rpt->clm_ratio,
+		  rpt->nhm_rpt_stamp, rpt->clm_rpt_stamp);
+
+	return env_mntr_rpt;
+#endif
+}
+
+/*@Environment Monitor*/
+void phydm_env_mntr_watchdog(void *dm_void)
+{
+#if (defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	boolean nhm_chk_ok = false;
+	boolean clm_chk_ok = false;
+
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
 		return;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("[%s]===>\n", __FUNCTION__));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	nhm_chk_ok = phydm_nhm_mntr_chk(dm, 262); /*@monitor 262ms*/
+	clm_chk_ok = phydm_clm_mntr_chk(dm, 262); /*@monitor 262ms*/
+
+	/*@PHYDM_DBG(dm, DBG_ENV_MNTR, "nhm_chk_ok %d\n\n",nhm_chk_ok);*/
+	/*@PHYDM_DBG(dm, DBG_ENV_MNTR, "clm_chk_ok %d\n\n",clm_chk_ok);*/
+
+	if (nhm_chk_ok)
+		phydm_nhm_trigger(dm);
 
-	phydm_nhm_init(p_dm);
-	phydm_clm_init(p_dm);
+	if (clm_chk_ok)
+		phydm_clm_trigger(dm);
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "Summary: nhm_ratio=((%d)) clm_ratio=((%d))\n\n",
+		  ccx->nhm_ratio, ccx->clm_ratio);
+#endif
 }
 
-void
-phydm_clm_dbg(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_env_monitor_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO	*ccx_info = &p_dm->dm_ccx_info;
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u32		i;
+#if (defined(NHM_SUPPORT) && defined(CLM_SUPPORT))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	for (i = 0; i < 2; i++) {
-		if (input[i + 1]) {
-			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-		}
-	}
+	if (!(dm->support_ability & ODM_BB_ENV_MONITOR))
+		return;
+
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "[%s]===>\n", __func__);
+	phydm_ccx_hw_restart(dm);
+	phydm_nhm_init(dm);
+	phydm_clm_init(dm);
+#endif
+}
+
+void phydm_env_mntr_dbg(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	struct clm_para_info clm_para = {0};
+	struct nhm_para_info nhm_para = {0};
+	struct env_mntr_rpt rpt = {0};
+	struct env_trig_rpt trig_rpt = {0};
+	u8 set_result;
+	u8 i;
+
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 
 	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "{1: trigger, 2:get result}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{3: MNTR mode sel} {1: driver, 2. FW}\n"));
-		return;
-	} else if (var1[0] == 1) { /* Set & trigger CLM */
-		
-		ccx_info->clm_period = 65535;		/* 65535*4us = 262.14ms*/
-		phydm_clm_setting(p_dm);
-		phydm_clm_hw_restart(p_dm);
-		phydm_clm_trigger(p_dm);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Monitor CLM for 262ms\n"));
-		
-	} else if (var1[0] == 2) { /* Get CLM results */
-
-		phydm_get_clm_result(p_dm);
-		PHYDM_SNPRINTF((output + used, out_len - used, "CLM_result=%d us\n", (ccx_info->clm_result<<2)));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Basic-Trigger 262ms: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Get Result: {100}\n");
+	} else if (var1[0] == 100) { /* @Get CLM results */
 
-	} else if (var1[0] == 3) {
+		set_result = phydm_env_mntr_result(dm, &rpt);
 
-		if (var1[1] == 1)
-			ccx_info->clm_mntr_mode = CLM_DRIVER_MNTR;
-		else if (var1[1] == 2)
-			ccx_info->clm_mntr_mode = CLM_FW_MNTR;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Set Result=%d\n nhm_ratio=%d clm_ratio=%d\n nhm_rpt_stamp=%d, clm_rpt_stamp=%d,\n",
+			 set_result, rpt.nhm_ratio, rpt.clm_ratio,
+			 rpt.nhm_rpt_stamp, rpt.clm_rpt_stamp);
 
-	} else {
-		
-		PHYDM_SNPRINTF((output + used, out_len - used, "Error\n"));
+		for (i = 0; i <= 11; i++) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "nhm_rpt[%d] = %d (%d percent)\n", i,
+				 rpt.nhm_result[i],
+				 (((rpt.nhm_result[i] * 100) + 128) >> 8));
+		}
+
+	} else { /* Set & trigger CLM */
+		/*nhm para*/
+		nhm_para.incld_txon = NHM_EXCLUDE_TXON;
+		nhm_para.incld_cca = NHM_EXCLUDE_CCA;
+		nhm_para.div_opt = NHM_CNT_ALL;
+		nhm_para.nhm_app = NHM_ACS;
+		nhm_para.nhm_lv = NHM_LV_2;
+		nhm_para.mntr_time = 262;
+
+		/*@clm para*/
+		clm_para.clm_app = CLM_ACS;
+		clm_para.clm_lv = CLM_LV_2;
+		clm_para.mntr_time = 262;
+
+		set_result = phydm_env_mntr_trigger(dm, &nhm_para,
+						    &clm_para, &trig_rpt);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Set Result=%d, nhm_rpt_stamp=%d, clm_rpt_stamp=%d\n",
+			 set_result, trig_rpt.nhm_rpt_stamp,
+			 trig_rpt.clm_rpt_stamp);
 	}
-	
+
 	*_used = used;
 	*_out_len = out_len;
-}
\ No newline at end of file
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.h
index 3719fede256f..f1774780130a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_ccx.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,35 +9,85 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMCCX_H__
-#define    __PHYDMCCX_H__
+#ifndef __PHYDMCCX_H__
+#define __PHYDMCCX_H__
 
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
+#define	ENV_MNTR_DBG	0	/*@debug for the HW processing time from NHM/CLM trigger and get result*/
+#define	ENV_MNTR_DBG_1	0	/*@debug 8812A & 8821A P2P Fail to get result*/
+#define	ENV_MNTR_DBG_2	0	/*@debug for read reister*/
 
 #define CCX_EN 1
 
-#define	IGI_TO_NHM_TH_MULTIPLIER	2
-#define	MS_TO_4US_RATIO				250
-#define	CCA_CAP	14
+#define	MAX_ENV_MNTR_TIME	8	/*second*/
+#define	IGI_TO_NHM_TH_MULTIPLIER 2
+#define	MS_TO_4US_RATIO		250
+#define	CCA_CAP			14
 #define	CLM_MAX_REPORT_TIME	10
-#define	DEVIDER_ERROR	0xffff
+#define	DEVIDER_ERROR		0xffff
+#define CLM_PERIOD_MAX		65535
+#define NHM_PERIOD_MAX		65534
+#define	NHM_TH_NUM		11	/*threshold number of NHM*/
+#define	NHM_RPT_NUM		12
 
-/*FAHM*/
-#define	FAHM_INCLD_FA			BIT(0)
+#define	IGI_2_NHM_TH(igi)	((igi) << 1)/*NHM_threshold = IGI * 2*/
+#define	NTH_TH_2_RSSI(th)	((th >> 1) - 10)
+
+/*@FAHM*/
+#define	FAHM_INCLD_FA		BIT(0)
 #define	FAHM_INCLD_CRC_OK	BIT(1)
-#define	FAHM_INCLD_CRC_ER		BIT(2)
+#define	FAHM_INCLD_CRC_ER	BIT(2)
 
+#define NHM_SUCCESS		BIT(0)
+#define CLM_SUCCESS		BIT(1)
+#define FAHM_SUCCESS		BIT(2)
+#define	ENV_MNTR_FAIL		0xff
 
-/* 1 ============================================================
+/* @1 ============================================================
  * 1 enumrate
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
+enum phydm_clm_level {
+	CLM_RELEASE		= 0,
+	CLM_LV_1		= 1,	/* @Low Priority function */
+	CLM_LV_2		= 2,	/* @Middle Priority function */
+	CLM_LV_3		= 3,	/* @High priority function (ex: Check hang function) */
+	CLM_LV_4		= 4,	/* @Debug function (the highest priority) */
+	CLM_MAX_NUM		= 5
+};
+
+enum phydm_nhm_level {
+	NHM_RELEASE		= 0,
+	NHM_LV_1		= 1,	/* @Low Priority function */
+	NHM_LV_2		= 2,	/* @Middle Priority function */
+	NHM_LV_3		= 3,	/* @High priority function (ex: Check hang function) */
+	NHM_LV_4		= 4,	/* @Debug function (the highest priority) */
+	NHM_MAX_NUM		= 5
+};
+
+enum nhm_divider_opt_all {
+	NHM_CNT_ALL		= 0,	/*nhm SUM report <= 255*/
+	NHM_VALID		= 1,	/*nhm SUM report = 255*/
+	NHM_CNT_INIT
+};
 
 enum nhm_setting {
 	SET_NHM_SETTING,
@@ -44,166 +95,175 @@ enum nhm_setting {
 	RESTORE_NHM_SETTING
 };
 
-enum nhm_inexclude_cca {
-	NHM_EXCLUDE_CCA,
-	NHM_INCLUDE_CCA
+enum nhm_option_cca_all {
+	NHM_EXCLUDE_CCA		= 0,
+	NHM_INCLUDE_CCA		= 1,
+	NHM_CCA_INIT
+};
+
+enum nhm_option_txon_all {
+	NHM_EXCLUDE_TXON	= 0,
+	NHM_INCLUDE_TXON	= 1,
+	NHM_TXON_INIT
 };
 
-enum nhm_inexclude_txon {
-	NHM_EXCLUDE_TXON,
-	NHM_INCLUDE_TXON
+enum nhm_application {
+	NHM_BACKGROUND		= 0,/*@default*/
+	NHM_ACS			= 1,
+	IEEE_11K_HIGH		= 2,
+	IEEE_11K_LOW		= 3,
+	INTEL_XBOX		= 4,
+	NHM_DBG			= 5, /*@manual trigger*/
 };
 
-enum clm_monitor_mode_e {
-	CLM_ECHO_DBG_MODE	= 0,
+enum clm_application {
+	CLM_BACKGROUND		= 0,/*@default*/
+	CLM_ACS			= 1,
+};
+
+enum clm_monitor_mode {
 	CLM_DRIVER_MNTR		= 1,
-	CLM_FW_MNTR			= 2
+	CLM_FW_MNTR		= 2
 };
 
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  structure
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
+struct env_trig_rpt {
+	u8			nhm_rpt_stamp;
+	u8			clm_rpt_stamp;
+};
+
+
+struct env_mntr_rpt {
+	u8			nhm_ratio;
+	u8			nhm_result[NHM_RPT_NUM];
+	u8			clm_ratio;
+	u8			nhm_rpt_stamp;
+	u8			clm_rpt_stamp;
+};
 
-struct _CCX_INFO {
+struct nhm_para_info {
+	enum nhm_option_txon_all	incld_txon;	/*@Include TX on*/
+	enum nhm_option_cca_all		incld_cca;	/*@Include CCA*/
+	enum nhm_divider_opt_all	div_opt;	/*@divider option*/
+	enum nhm_application		nhm_app;
+	enum phydm_nhm_level		nhm_lv;
+	u16				mntr_time;	/*@0~262 unit ms*/
 
-	/*Settings*/
-	u8					nhm_th[11];
-	u16					nhm_period;				/* 4us per unit */
-	u16					clm_period;				/* 4us per unit */
-	enum nhm_inexclude_txon		nhm_inexclude_txon;
-	enum nhm_inexclude_cca		nhm_inexclude_cca;
+};
 
-	/*Previous Settings*/
-	u8					nhm_th_restore[11];
-	u16					nhm_period_restore;				/* 4us per unit */
-	u16					clm_period_restore;				/* 4us per unit */
-	enum nhm_inexclude_txon		nhm_inexclude_txon_restore;
-	enum nhm_inexclude_cca		nhm_inexclude_cca_restore;
+struct clm_para_info {
+	enum clm_application		clm_app;
+	enum phydm_clm_level		clm_lv;
+	u16				mntr_time;	/*@0~262 unit ms*/
+};
 
+struct ccx_info {
+	u32			nhm_trigger_time;
+	u32			clm_trigger_time;
+	u64			start_time;	/*@monitor for the test duration*/
+#ifdef NHM_SUPPORT
+	enum nhm_application		nhm_app;
+	enum nhm_option_txon_all	nhm_include_txon;
+	enum nhm_option_cca_all		nhm_include_cca;
+	enum nhm_divider_opt_all 	nhm_divider_opt;
 	/*Report*/
-	u8		nhm_result[12];
-	u8		nhm_ratio;		/*1% per nuit, it means the interference igi can't overcome.*/
-	u8		nhm_result_total;
-	u16		nhm_duration;
-	u16		clm_result;
-	u8		clm_ratio;
-	u8		echo_igi;	/* nhm_result comes from this igi */
-	u32		clm_fw_result_acc;
-	u8		clm_fw_result_cnt;
-	enum clm_monitor_mode_e		clm_mntr_mode;
-	u8		env_mntr_igi;
+	u8			nhm_th[NHM_TH_NUM];
+	u8			nhm_result[NHM_RPT_NUM];
+	u16			nhm_period;	/* @4us per unit */
+	u8			nhm_igi;
+	u8			nhm_manual_ctrl;
+	u8			nhm_ratio;	/*@1% per nuit, it means the interference igi can't overcome.*/
+	u8			nhm_rpt_sum;
+	u16			nhm_duration;	/*@Real time of NHM_VALID */
+	u8			nhm_set_lv;
+	boolean			nhm_ongoing;
+	u8			nhm_rpt_stamp;
+#endif
+#ifdef CLM_SUPPORT
+	enum clm_application	clm_app;
+	u8			clm_manual_ctrl;
+	u8			clm_set_lv;
+	boolean			clm_ongoing;
+	u16			clm_period;	/* @4us per unit */
+	u16			clm_result;
+	u8			clm_ratio;
+	u32			clm_fw_result_acc;
+	u8			clm_fw_result_cnt;
+	enum clm_monitor_mode	clm_mntr_mode;
+	u8			clm_rpt_stamp;
+#endif
 #ifdef FAHM_SUPPORT
-	u8		fahm_nume_sel;		/*fahm_numerator_sel: select {FA, CRCOK, CRC_fail} */
-	u8		fahm_denum_sel;	/*fahm_denumerator_sel: select {FA, CRCOK, CRC_fail} */
-	u16		fahm_period;			/*unit: 4us*/
+	boolean			fahm_ongoing;
+	u8			env_mntr_igi;
+	u8			fahm_nume_sel;	/*@fahm_numerator_sel: select {FA, CRCOK, CRC_fail} */
+	u8			fahm_denom_sel;	/*@fahm_denominator_sel: select {FA, CRCOK, CRC_fail} */
+	u16			fahm_period;	/*unit: 4us*/
 #endif
-
 };
 
-/* 1 ============================================================
- * 1 structure
- * 1 ============================================================ */
+/* @1 ============================================================
+ * 1 Function Prototype
+ * 1 ============================================================
+ */
 
 #ifdef FAHM_SUPPORT
 
-void
-phydm_fahm_init(
-	void			*p_dm_void
-);
-
-void
-phydm_fahm_dbg(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
+void phydm_fahm_init(void *dm_void);
+
+void phydm_fahm_dbg(void *dm_void, char input[][16], u32 *_used, char *output,
+		    u32 *_out_len);
+
+#endif
+
+/*@NHM*/
+#ifdef NHM_SUPPORT
+void phydm_nhm_trigger(void *dm_void);
+
+void phydm_nhm_init(void *dm_void);
 
+void phydm_nhm_dbg(void *dm_void, char input[][16], u32 *_used, char *output,
+		   u32 *_out_len);
+u8 phydm_get_igi(void *dm_void, enum bb_path path);
 #endif
 
-void
-phydm_c2h_clm_report_handler(
-	void	*p_dm_void,
-	u8	*cmd_buf,
-	u8	cmd_len
-);
-/*NHM*/
-
-boolean
-phydm_cal_nhm_cnt(
-	void		*p_dm_void
-);
-
-void
-phydm_nhm_setting(
-	void		*p_dm_void,
-	u8	nhm_setting
-);
-
-void
-phydm_nhm_trigger(
-	void		*p_dm_void
-);
-
-void
-phydm_get_nhm_result(
-	void		*p_dm_void
-);
-
-/*CLM*/
-
-void
-phydm_clm_setting(
-	void			*p_dm_void
-);
-
-void
-phydm_clm_trigger(
-	void			*p_dm_void
-);
-
-void
-phydm_get_clm_result(
-	void			*p_dm_void
-);
-
-void
-phydm_ccx_monitor(
-	void			*p_dm_void
-);
-
-void
-phydm_ccx_monitor_trigger(
-	void			*p_dm_void,
-	u16				monitor_time
-);
-
-void
-phydm_ccx_monitor_result(
-	void			*p_dm_void
-);
-
-void
-phydm_set_clm_mntr_mode(
-	void			*p_dm_void,
-	enum clm_monitor_mode_e mode
-);
-
-void
-phydm_env_monitor_init(
-	void			*p_dm_void
-);
-
-void
-phydm_clm_dbg(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
+/*@CLM*/
+#ifdef CLM_SUPPORT
+void phydm_clm_c2h_report_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+void phydm_clm_h2c(void *dm_void, u16 obs_time, u8 fw_clm_en);
+
+void phydm_clm_setting(void *dm_void, u16 clm_period);
+
+void phydm_clm_trigger(void *dm_void);
+
+boolean phydm_clm_check_rdy(void *dm_void);
+
+void phydm_clm_get_utility(void *dm_void);
+
+boolean phydm_clm_get_result(void *dm_void);
+
+u8 phydm_clm_mntr_set(void *dm_void, struct clm_para_info *clm_para);
+
+void phydm_set_clm_mntr_mode(void *dm_void, enum clm_monitor_mode mode);
+
+void phydm_clm_dbg(void *dm_void, char input[][16], u32 *_used, char *output,
+		   u32 *_out_len);
+#endif
+
+u8 phydm_env_mntr_trigger(void *dm_void, struct nhm_para_info *nhm_para,
+			  struct clm_para_info *clm_para,
+			  struct env_trig_rpt *rpt);
+
+u8 phydm_env_mntr_result(void *dm_void, struct env_mntr_rpt *rpt);
+
+void phydm_env_mntr_watchdog(void *dm_void);
+
+void phydm_env_monitor_init(void *dm_void);
+
+void phydm_env_mntr_dbg(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.c
index 161fafd3b8d5..65bfcc936d27 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,374 +9,587 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-void
-phydm_set_crystal_cap(
-	void					*p_dm_void,
-	u8					crystal_cap
-)
+s32 phydm_get_cfo_hz(void *dm_void, u32 val, u8 bit_num, u8 frac_num)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cfo_track_struct				*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
+	s32 val_s = 0;
 
-	if (p_cfo_track->crystal_cap == crystal_cap)
-		return;
+	val_s = phydm_cnvrt_2_sign(val, bit_num);
 
-	crystal_cap = crystal_cap & 0x3F;
-	p_cfo_track->crystal_cap = crystal_cap;
+	if (frac_num == 10) /*@ (X*312500)/1024 ~= X*305*/
+		val_s *= 305;
+	else if (frac_num == 11) /*@ (X*312500)/2048 ~= X*152*/
+		val_s *= 152;
+	else if (frac_num == 12) /*@ (X*312500)/4096 ~= X*76*/
+		val_s *= 76;
 
-	if (p_dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8188F)) {
-		#if (RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
-		/* write 0x24[22:17] = 0x24[16:11] = crystal_cap */
-		odm_set_bb_reg(p_dm, REG_AFE_XTAL_CTRL, 0x007ff800, (crystal_cap | (crystal_cap << 6)));
-		#endif
-	}
-	#if (RTL8812A_SUPPORT == 1)
-	else if (p_dm->support_ic_type & ODM_RTL8812) {
-	
-		/* write 0x2C[30:25] = 0x2C[24:19] = crystal_cap */
-		odm_set_bb_reg(p_dm, REG_MAC_PHY_CTRL, 0x7FF80000, (crystal_cap | (crystal_cap << 6)));
-		
-	} 
+	return val_s;
+}
+
+#if (ODM_IC_11AC_SERIES_SUPPORT)
+void phydm_get_cfo_info_ac(void *dm_void, struct phydm_cfo_rpt *cfo)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	u32 val[4] = {0};
+	u32 val_1[4] = {0};
+	u32 val_2[4] = {0};
+	u32 val_tmp = 0;
+
+	val[0] = odm_read_4byte(dm, R_0xd0c);
+	val_1[0] = odm_read_4byte(dm, R_0xd10);
+	val_2[0] = odm_get_bb_reg(dm, R_0xd14, 0x1fff0000);
+
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	val[1] = odm_read_4byte(dm, R_0xd4c);
+	val_1[1] = odm_read_4byte(dm, R_0xd50);
+	val_2[1] = odm_get_bb_reg(dm, R_0xd54, 0x1fff0000);
 	#endif
-	#if (RTL8703B_SUPPORT == 1) || (RTL8723B_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8723D_SUPPORT == 1)
-	else if ((p_dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723B | ODM_RTL8192E | ODM_RTL8821 | ODM_RTL8723D))) {
-	
-		/* 0x2C[23:18] = 0x2C[17:12] = crystal_cap */
-		odm_set_bb_reg(p_dm, REG_MAC_PHY_CTRL, 0x00FFF000, (crystal_cap | (crystal_cap << 6)));
-		
-	}
+
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	val[2] = odm_read_4byte(dm, R_0xd8c);
+	val_1[2] = odm_read_4byte(dm, R_0xd90);
+	val_2[2] = odm_get_bb_reg(dm, R_0xd94, 0x1fff0000);
 	#endif
-	#if (RTL8814A_SUPPORT == 1)	
-	else if (p_dm->support_ic_type & ODM_RTL8814A) {
-	
-		/* write 0x2C[26:21] = 0x2C[20:15] = crystal_cap */
-		odm_set_bb_reg(p_dm, REG_MAC_PHY_CTRL, 0x07FF8000, (crystal_cap | (crystal_cap << 6)));
-		
-	}
+
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	val[3] = odm_read_4byte(dm, R_0xdcc);
+	val_1[3] = odm_read_4byte(dm, R_0xdd0);
+	val_2[3] = odm_get_bb_reg(dm, R_0xdd4, 0x1fff0000);
 	#endif
-	#if (RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
-	else if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8197F)) {
-	
-		/* write 0x24[30:25] = 0x28[6:1] = crystal_cap */
-		odm_set_bb_reg(p_dm, REG_AFE_XTAL_CTRL, 0x7e000000, crystal_cap);
-		odm_set_bb_reg(p_dm, REG_AFE_PLL_CTRL, 0x7e, crystal_cap);
-		
+
+	for (i = 0; i < dm->num_rf_path; i++) {
+		val_tmp = val[i] & 0xfff;	/*@ Short CFO, S(12,11)*/
+		cfo->cfo_rpt_s[i] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+
+		val_tmp = val[i] >> 16;		/*@ Long CFO, S(13,12)*/
+		cfo->cfo_rpt_l[i] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
+
+		val_tmp = val_1[i] & 0x7ff;	/*@ SCFO, S(11,10)*/
+		cfo->cfo_rpt_sec[i] = phydm_get_cfo_hz(dm, val_tmp, 11, 10);
+
+		val_tmp = val_1[i] >> 16;	/*@ Acq CFO, S(13,12)*/
+		cfo->cfo_rpt_acq[i] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
+
+		val_tmp = val_2[i];		/*@ End CFO, S(13,12)*/
+		cfo->cfo_rpt_end[i] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
 	}
-	#endif
-	#if (RTL8710B_SUPPORT == 1)
-	else if (p_dm->support_ic_type & (ODM_RTL8710B)) {
-	
-		#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)		
-		/* write 0x60[29:24] = 0x60[23:18] = crystal_cap */
-		HAL_SetSYSOnReg(p_dm->adapter, REG_SYS_XTAL_CTRL0, 0x3FFC0000, (crystal_cap | (crystal_cap << 6)));
-		#endif
+}
+#endif
+
+#if (ODM_IC_11N_SERIES_SUPPORT)
+void phydm_get_cfo_info_n(void *dm_void, struct phydm_cfo_rpt *cfo)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 val[5] = {0};
+	u32 val_tmp = 0;
+
+	odm_set_bb_reg(dm, R_0xd00, BIT(26), 1);
+
+	val[0] = odm_read_4byte(dm, R_0xdac); /*@ Short CFO*/
+	val[1] = odm_read_4byte(dm, R_0xdb0); /*@ Long CFO*/
+	val[2] = odm_read_4byte(dm, R_0xdb8); /*@ Sec CFO*/
+	val[3] = odm_read_4byte(dm, R_0xde0); /*@ Acq CFO*/
+	val[4] = odm_read_4byte(dm, R_0xdbc); /*@ End CFO*/
+
+	/*@[path-A]*/
+	if (dm->support_ic_type == ODM_RTL8721D) {
+		val_tmp = (val[0] & 0x0fff0000) >> 16; /*@ Short CFO, S(12,11)*/
+		cfo->cfo_rpt_s[0] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+		val_tmp = (val[1] & 0x0fff0000) >> 16;	/*@ Long CFO, S(12,11)*/
+		cfo->cfo_rpt_l[0] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+		val_tmp = (val[2] & 0x0fff0000) >> 16;	/*@ Sec CFO, S(12,11)*/
+		cfo->cfo_rpt_sec[0] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+		val_tmp = (val[3] & 0x0fff0000) >> 16;	/*@ Acq CFO, S(12,11)*/
+		cfo->cfo_rpt_acq[0] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+		val_tmp = (val[4] & 0x0fff0000) >> 16;	/*@ Acq CFO, S(12,11)*/
+		cfo->cfo_rpt_end[0] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+	} else {
+		val_tmp = (val[0] & 0x0fff0000) >> 16; /*@ Short CFO, S(12,11)*/
+		cfo->cfo_rpt_s[0] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+		val_tmp = (val[1] & 0x1fff0000) >> 16;	/*@ Long CFO, S(13,12)*/
+		cfo->cfo_rpt_l[0] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
+		val_tmp = (val[2] & 0x7ff0000) >> 16;	/*@ Sec CFO, S(11,10)*/
+		cfo->cfo_rpt_sec[0] = phydm_get_cfo_hz(dm, val_tmp, 11, 10);
+		val_tmp = (val[3] & 0x1fff0000) >> 16;	/*@ Acq CFO, S(13,12)*/
+		cfo->cfo_rpt_acq[0] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
+		val_tmp = (val[4] & 0x1fff0000) >> 16;	/*@ Acq CFO, S(13,12)*/
+		cfo->cfo_rpt_end[0] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
 	}
-	#endif
-	PHYDM_DBG(p_dm, DBG_CFO_TRK, ("Set rystal_cap = 0x%x\n", p_cfo_track->crystal_cap));
 
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	/*@[path-B]*/
+	val_tmp = val[0] & 0xfff;		/*@ Short CFO, S(12,11)*/
+	cfo->cfo_rpt_s[1] = phydm_get_cfo_hz(dm, val_tmp, 12, 11);
+	val_tmp = val[1] & 0x1fff;		/*@ Long CFO, S(13,12)*/
+	cfo->cfo_rpt_l[1] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
+	val_tmp = val[2] & 0x7ff;		/*@ Sec CFO, S(11,10)*/
+	cfo->cfo_rpt_sec[1] = phydm_get_cfo_hz(dm, val_tmp, 11, 10);
+	val_tmp = val[3] & 0x1fff;		/*@ Acq CFO, S(13,12)*/
+	cfo->cfo_rpt_acq[1] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
+	val_tmp = val[4] & 0x1fff;		/*@ Acq CFO, S(13,12)*/
+	cfo->cfo_rpt_end[1] = phydm_get_cfo_hz(dm, val_tmp, 13, 12);
+	#endif
 }
 
-u8
-odm_get_default_crytaltal_cap(
-	void					*p_dm_void
-)
+void phydm_set_atc_status(void *dm_void, boolean atc_status)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8						crystal_cap = 0x20;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
+	u32 reg_tmp = 0;
+	u32 mask_tmp = 0;
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
-	struct rtl_efuse *rtlefuse = rtl_efuse(rtlpriv);
+	PHYDM_DBG(dm, DBG_CFO_TRK, "[%s]ATC_en=%d\n", __func__, atc_status);
 
-	crystal_cap = rtlefuse->crystalcap;
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	struct _ADAPTER					*adapter = p_dm->adapter;
-	HAL_DATA_TYPE				*p_hal_data = GET_HAL_DATA(adapter);
+	if (cfo_track->is_atc_status == atc_status)
+		return;
 
-	crystal_cap = p_hal_data->crystal_cap;
-#else
-	struct rtl8192cd_priv	*priv		= p_dm->priv;
+	reg_tmp = ODM_REG(BB_ATC, dm);
+	mask_tmp = ODM_BIT(BB_ATC, dm);
+	odm_set_bb_reg(dm, reg_tmp, mask_tmp, atc_status);
+	cfo_track->is_atc_status = atc_status;
+}
+
+boolean
+phydm_get_atc_status(void *dm_void)
+{
+	boolean atc_status = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 reg_tmp = 0;
+	u32 mask_tmp = 0;
+
+	reg_tmp = ODM_REG(BB_ATC, dm);
+	mask_tmp = ODM_BIT(BB_ATC, dm);
 
-	if (priv->pmib->dot11RFEntry.xcap > 0)
-		crystal_cap = priv->pmib->dot11RFEntry.xcap;
+	atc_status = (boolean)odm_get_bb_reg(dm, reg_tmp, mask_tmp);
+
+	PHYDM_DBG(dm, DBG_CFO_TRK, "[%s]atc_status=%d\n", __func__, atc_status);
+	return atc_status;
+}
 #endif
 
-	crystal_cap = crystal_cap & 0x3f;
+void phydm_get_cfo_info(void *dm_void, struct phydm_cfo_rpt *cfo)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	return crystal_cap;
+	switch (dm->ic_ip_series) {
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	case PHYDM_IC_N:
+		phydm_get_cfo_info_n(dm, cfo);
+		break;
+	#endif
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	case PHYDM_IC_AC:
+		phydm_get_cfo_info_ac(dm, cfo);
+		break;
+	#endif
+	default:
+		break;
+	}
 }
 
-void
-odm_set_atc_status(
-	void					*p_dm_void,
-	boolean					atc_status
-)
+void phydm_set_crystal_cap(void *dm_void, u8 crystal_cap)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cfo_track_struct				*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
 
-	if (p_cfo_track->is_atc_status == atc_status)
+	if (cfo_track->crystal_cap == crystal_cap)
 		return;
 
-	odm_set_bb_reg(p_dm, ODM_REG(BB_ATC, p_dm), ODM_BIT(BB_ATC, p_dm), atc_status);
-	p_cfo_track->is_atc_status = atc_status;
+	if (phydm_set_crystal_cap_reg(dm, crystal_cap))
+		PHYDM_DBG(dm, DBG_CFO_TRK, "Set crystal_cap = 0x%x\n",
+			  cfo_track->crystal_cap);
+	else
+		PHYDM_DBG(dm, DBG_CFO_TRK, "Set fail\n");
 }
 
 boolean
-odm_get_atc_status(
-	void					*p_dm_void
-)
+phydm_set_crystal_cap_reg(void *dm_void, u8 crystal_cap)
 {
-	boolean						atc_status;
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
+	u32 reg_val = 0;
+
+	if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8814B |
+	    ODM_RTL8195B | ODM_RTL8812F | ODM_RTL8721D)) {
+		crystal_cap &= 0x7F;
+		reg_val = crystal_cap | (crystal_cap << 7);
+	} else {
+		crystal_cap &= 0x3F;
+		reg_val = crystal_cap | (crystal_cap << 6);
+	}
 
-	atc_status = (boolean)odm_get_bb_reg(p_dm, ODM_REG(BB_ATC, p_dm), ODM_BIT(BB_ATC, p_dm));
-	return atc_status;
+	cfo_track->crystal_cap = crystal_cap;
+
+	if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8188F)) {
+		#if (RTL8188E_SUPPORT || RTL8188F_SUPPORT)
+		/* write 0x24[22:17] = 0x24[16:11] = crystal_cap */
+		odm_set_mac_reg(dm, R_0x24, 0x7ff800, reg_val);
+		#endif
+	}
+	#if (RTL8812A_SUPPORT)
+	else if (dm->support_ic_type & ODM_RTL8812) {
+		/* write 0x2C[30:25] = 0x2C[24:19] = crystal_cap */
+		odm_set_mac_reg(dm, R_0x2c, 0x7FF80000, reg_val);
+	}
+	#endif
+	#if (RTL8703B_SUPPORT || RTL8723B_SUPPORT || RTL8192E_SUPPORT ||\
+	     RTL8821A_SUPPORT || RTL8723D_SUPPORT)
+	else if ((dm->support_ic_type &
+		 (ODM_RTL8703B | ODM_RTL8723B | ODM_RTL8192E | ODM_RTL8821 |
+		 ODM_RTL8723D))) {
+		/* @0x2C[23:18] = 0x2C[17:12] = crystal_cap */
+		odm_set_mac_reg(dm, R_0x2c, 0x00FFF000, reg_val);
+	}
+	#endif
+	#if (RTL8814A_SUPPORT)
+	else if (dm->support_ic_type & ODM_RTL8814A) {
+		/* write 0x2C[26:21] = 0x2C[20:15] = crystal_cap */
+		odm_set_mac_reg(dm, R_0x2c, 0x07FF8000, reg_val);
+	}
+	#endif
+	#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT || RTL8197F_SUPPORT ||\
+	     RTL8192F_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C |
+		 ODM_RTL8197F | ODM_RTL8192F)) {
+		/* write 0x24[30:25] = 0x28[6:1] = crystal_cap */
+		odm_set_mac_reg(dm, R_0x24, 0x7e000000, crystal_cap);
+		odm_set_mac_reg(dm, R_0x28, 0x7e, crystal_cap);
+	}
+	#endif
+	#if (RTL8710B_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8710B)) {
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		/* write 0x60[29:24] = 0x60[23:18] = crystal_cap */
+		HAL_SetSYSOnReg(dm->adapter, R_0x60, 0x3FFC0000, reg_val);
+		#endif
+	}
+	#endif
+	#if (RTL8195B_SUPPORT)
+	else if (dm->support_ic_type & ODM_RTL8195B) {
+		phydm_set_crystalcap(dm, (u8)(reg_val & 0x7f));
+	}
+	#endif
+	#if (RTL8721D_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		/* write 0x4800_0228[30:24] crystal_cap */
+		/*HAL_SetSYSOnReg(dm->adapter, */
+		/*REG_SYS_XTAL_8721d, 0x7F000000, crystal_cap);*/
+		u32 temp_val = HAL_READ32(SYSTEM_CTRL_BASE_LP,
+					   REG_SYS_EFUSE_SYSCFG2);
+		temp_val = ((crystal_cap << 24) & 0x7F000000)
+						| (temp_val & (~0x7F000000));
+		HAL_WRITE32(SYSTEM_CTRL_BASE_LP, REG_SYS_EFUSE_SYSCFG2,
+			    temp_val);
+	}
+	#endif
+#if (RTL8822C_SUPPORT || RTL8814B_SUPPORT || RTL8812F_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8814B |
+		 ODM_RTL8812F)) {
+		/* write 0x1040[23:17] = 0x1040[16:10] = crystal_cap */
+		odm_set_mac_reg(dm, R_0x1040, 0x00FFFC00, reg_val);
+	} else {
+		return false;
+	}
+#endif
+	return true;
 }
 
-void
-odm_cfo_tracking_reset(
-	void					*p_dm_void
-)
+void phydm_cfo_tracking_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cfo_track_struct				*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
-
-	p_cfo_track->def_x_cap = odm_get_default_crytaltal_cap(p_dm);
-	p_cfo_track->is_adjust = true;
-
-	if (p_cfo_track->crystal_cap > p_cfo_track->def_x_cap) {
-		phydm_set_crystal_cap(p_dm, p_cfo_track->crystal_cap - 1);
-		PHYDM_DBG(p_dm, DBG_CFO_TRK,
-			("odm_cfo_tracking_reset(): approch default value (0x%x)\n", p_cfo_track->crystal_cap));
-	} else if (p_cfo_track->crystal_cap < p_cfo_track->def_x_cap) {
-		phydm_set_crystal_cap(p_dm, p_cfo_track->crystal_cap + 1);
-		PHYDM_DBG(p_dm, DBG_CFO_TRK,
-			("odm_cfo_tracking_reset(): approch default value (0x%x)\n", p_cfo_track->crystal_cap));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
+
+	PHYDM_DBG(dm, DBG_CFO_TRK, "%s ======>\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8814B | ODM_RTL8195B |
+	    ODM_RTL8812F))
+		cfo_track->def_x_cap = cfo_track->crystal_cap_default & 0x7f;
+	else
+		cfo_track->def_x_cap = cfo_track->crystal_cap_default & 0x3f;
+
+	cfo_track->is_adjust = true;
+
+	if (cfo_track->crystal_cap > cfo_track->def_x_cap) {
+		phydm_set_crystal_cap(dm, cfo_track->crystal_cap - 1);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "approch to Init-val (0x%x)\n",
+			  cfo_track->crystal_cap);
+
+	} else if (cfo_track->crystal_cap < cfo_track->def_x_cap) {
+		phydm_set_crystal_cap(dm, cfo_track->crystal_cap + 1);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "approch to init-val 0x%x\n",
+			  cfo_track->crystal_cap);
 	}
 
+#if ODM_IC_11N_SERIES_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	odm_set_atc_status(p_dm, true);
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		phydm_set_atc_status(dm, true);
+#endif
 #endif
 }
 
-void
-phydm_cfo_tracking_init(
-	void					*p_dm_void
-)
+void phydm_cfo_tracking_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cfo_track_struct				*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
-
-	p_cfo_track->def_x_cap = p_cfo_track->crystal_cap = odm_get_default_crytaltal_cap(p_dm);
-	p_cfo_track->is_atc_status = odm_get_atc_status(p_dm);
-	p_cfo_track->is_adjust = true;
-	PHYDM_DBG(p_dm, DBG_CFO_TRK, ("ODM_CfoTracking_init()=========>\n"));
-	PHYDM_DBG(p_dm, DBG_CFO_TRK, ("ODM_CfoTracking_init(): is_atc_status = %d, crystal_cap = 0x%x\n", p_cfo_track->is_atc_status, p_cfo_track->def_x_cap));
-
-#if RTL8822B_SUPPORT
-	/* Crystal cap. control by WiFi */
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		odm_set_bb_reg(p_dm, 0x10, 0x40, 0x1);
-#endif
-
-#if RTL8821C_SUPPORT
-	/* Crystal cap. control by WiFi */
-	if (p_dm->support_ic_type & ODM_RTL8821C)
-		odm_set_bb_reg(p_dm, 0x10, 0x40, 0x1);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
+
+	PHYDM_DBG(dm, DBG_CFO_TRK, "[%s]=========>\n", __func__);
+	if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8814B | ODM_RTL8195B |
+	    ODM_RTL8812F))
+		cfo_track->crystal_cap = cfo_track->crystal_cap_default & 0x7f;
+	else
+		cfo_track->crystal_cap = cfo_track->crystal_cap_default & 0x3f;
+
+	cfo_track->def_x_cap = cfo_track->crystal_cap;
+	cfo_track->is_adjust = true;
+	PHYDM_DBG(dm, DBG_CFO_TRK, "crystal_cap=0x%x\n", cfo_track->def_x_cap);
+
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT)
+	/* @Crystal cap. control by WiFi */
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
+		odm_set_mac_reg(dm, R_0x10, 0x40, 0x1);
 #endif
 }
 
-void
-odm_cfo_tracking(
-	void					*p_dm_void
-)
+void phydm_cfo_tracking(void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cfo_track_struct				*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
-	s32						CFO_ave = 0;
-	u32						CFO_rpt_sum, cfo_khz_avg[4] = {0};
-	s32						CFO_ave_diff;
-	s8						crystal_cap = p_cfo_track->crystal_cap;
-	u8						adjust_xtal = 1, i, valid_path_cnt = 0;
-
-	/* 4 Support ability */
-	if (!(p_dm->support_ability & ODM_BB_CFO_TRACKING)) {
-		PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): Return: support_ability ODM_BB_CFO_TRACKING is disabled\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
+	s32 cfo_avg = 0, cfo_path_sum = 0, cfo_abs = 0;
+	u32 cfo_rpt_sum = 0, cfo_khz_avg[4] = {0};
+	s8 crystal_cap = cfo_track->crystal_cap;
+	u8 i = 0, valid_path_cnt = 0;
+
+	if (!(dm->support_ability & ODM_BB_CFO_TRACKING))
 		return;
-	}
 
-	PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking()=========>\n"));
+	PHYDM_DBG(dm, DBG_CFO_TRK, "%s ======>\n", __func__);
+
+	if (!dm->is_linked || !dm->is_one_entry_only) {
+		phydm_cfo_tracking_reset(dm);
+		PHYDM_DBG(dm, DBG_CFO_TRK, "is_linked=%d, one_entry_only=%d\n",
+			  dm->is_linked, dm->is_one_entry_only);
 
-	if (!p_dm->is_linked || !p_dm->is_one_entry_only) {
-		/* 4 No link or more than one entry */
-		odm_cfo_tracking_reset(p_dm);
-		PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): Reset: is_linked = %d, is_one_entry_only = %d\n",
-			p_dm->is_linked, p_dm->is_one_entry_only));
 	} else {
-		/* 3 1. CFO Tracking */
-		/* 4 1.1 No new packet */
-		if (p_cfo_track->packet_count == p_cfo_track->packet_count_pre) {
-			PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): packet counter doesn't change\n"));
+		/* No new packet */
+		if (cfo_track->packet_count == cfo_track->packet_count_pre) {
+			PHYDM_DBG(dm, DBG_CFO_TRK, "Pkt cnt doesn't change\n");
 			return;
 		}
-		p_cfo_track->packet_count_pre = p_cfo_track->packet_count;
-
-		/* 4 1.2 Calculate CFO */
-		for (i = 0; i < p_dm->num_rf_path; i++) {
+		cfo_track->packet_count_pre = cfo_track->packet_count;
 
-			if (p_cfo_track->CFO_cnt[i] == 0)
+		/*@Calculate CFO */
+		for (i = 0; i < dm->num_rf_path; i++) {
+			if (!(dm->rx_ant_status & BIT(i)))
 				continue;
 
 			valid_path_cnt++;
-			CFO_rpt_sum = (u32)((p_cfo_track->CFO_tail[i] < 0) ? (0 - p_cfo_track->CFO_tail[i]) :  p_cfo_track->CFO_tail[i]);
-			cfo_khz_avg[i] = CFO_HW_RPT_2_MHZ(CFO_rpt_sum) / p_cfo_track->CFO_cnt[i];
 
-			PHYDM_DBG(p_dm, DBG_CFO_TRK, ("[path %d] CFO_rpt_sum = (( %d )), CFO_cnt = (( %d )) , CFO_avg= (( %s%d )) kHz\n",
-				i, CFO_rpt_sum, p_cfo_track->CFO_cnt[i], ((p_cfo_track->CFO_tail[i] < 0) ? "-" : " "), cfo_khz_avg[i]));
-		}
+			if (cfo_track->CFO_tail[i] < 0)
+				cfo_abs = 0 - cfo_track->CFO_tail[i];
+			else
+				cfo_abs = cfo_track->CFO_tail[i];
+
+			cfo_rpt_sum = (u32)CFO_HW_RPT_2_KHZ(cfo_abs);
+			cfo_khz_avg[i] = cfo_rpt_sum / cfo_track->CFO_cnt[i];
 
-		for (i = 0; i < valid_path_cnt; i++) {
+			PHYDM_DBG(dm, DBG_CFO_TRK,
+				  "[Path-%d] CFO_sum=((%d)), cnt=((%d)), CFO_avg=((%s%d))kHz\n",
+				  i, cfo_rpt_sum, cfo_track->CFO_cnt[i],
+				  ((cfo_track->CFO_tail[i] < 0) ? "-" : " "),
+				  cfo_khz_avg[i]);
 
-			/* PHYDM_DBG(p_dm, DBG_CFO_TRK, ("path [%d], p_cfo_track->CFO_tail = %d\n", i, p_cfo_track->CFO_tail[i])); */
-			if (p_cfo_track->CFO_tail[i] < 0) {
-				CFO_ave += (0 - (s32)cfo_khz_avg[i]);
-				/* PHYDM_DBG(p_dm, DBG_CFO_TRK, ("CFO_ave = %d\n", CFO_ave)); */
-			} else
-				CFO_ave += (s32)cfo_khz_avg[i];
+			if (cfo_track->CFO_tail[i] < 0)
+				cfo_path_sum += (0 - (s32)cfo_khz_avg[i]);
+			else
+				cfo_path_sum += (s32)cfo_khz_avg[i];
 		}
 
 		if (valid_path_cnt >= 2)
-			CFO_ave = CFO_ave / valid_path_cnt;
+			cfo_avg = cfo_path_sum / valid_path_cnt;
+		else
+			cfo_avg = cfo_path_sum;
+
+		cfo_track->CFO_ave_pre = cfo_avg;
 
-		PHYDM_DBG(p_dm, DBG_CFO_TRK, ("valid_path_cnt = ((%d)), CFO_ave = ((%d kHz))\n", valid_path_cnt, CFO_ave));
+		PHYDM_DBG(dm, DBG_CFO_TRK, "path_cnt=%d, CFO_avg_path=%d kHz\n",
+			  valid_path_cnt, cfo_avg);
 
 		/*reset counter*/
-		for (i = 0; i < p_dm->num_rf_path; i++) {
-			p_cfo_track->CFO_tail[i] = 0;
-			p_cfo_track->CFO_cnt[i] = 0;
+		for (i = 0; i < dm->num_rf_path; i++) {
+			cfo_track->CFO_tail[i] = 0;
+			cfo_track->CFO_cnt[i] = 0;
 		}
 
-		/* 4 1.3 Avoid abnormal large CFO */
-		CFO_ave_diff = (p_cfo_track->CFO_ave_pre >= CFO_ave) ? (p_cfo_track->CFO_ave_pre - CFO_ave) : (CFO_ave - p_cfo_track->CFO_ave_pre);
-		if (CFO_ave_diff > 20 && p_cfo_track->large_cfo_hit == 0 && !p_cfo_track->is_adjust) {
-			PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): first large CFO hit\n"));
-			p_cfo_track->large_cfo_hit = 1;
-			return;
-		} else
-			p_cfo_track->large_cfo_hit = 0;
-		p_cfo_track->CFO_ave_pre = CFO_ave;
-
-		/* 4 1.4 Dynamic Xtal threshold */
-		if (p_cfo_track->is_adjust == false) {
-			if (CFO_ave > CFO_TH_XTAL_HIGH || CFO_ave < (-CFO_TH_XTAL_HIGH))
-				p_cfo_track->is_adjust = true;
+		/* To adjust crystal cap or not */
+		if (!cfo_track->is_adjust) {
+			if (cfo_avg > CFO_TRK_ENABLE_TH ||
+			    cfo_avg < (-CFO_TRK_ENABLE_TH))
+				cfo_track->is_adjust = true;
 		} else {
-			if (CFO_ave < CFO_TH_XTAL_LOW && CFO_ave > (-CFO_TH_XTAL_LOW))
-				p_cfo_track->is_adjust = false;
+			if (cfo_avg < CFO_TRK_STOP_TH &&
+			    cfo_avg > (-CFO_TRK_STOP_TH))
+				cfo_track->is_adjust = false;
 		}
 
-#ifdef ODM_CONFIG_BT_COEXIST
-		/* 4 1.5 BT case: Disable CFO tracking */
-		if (p_dm->bt_info_table.is_bt_enabled) {
-			p_cfo_track->is_adjust = false;
-			phydm_set_crystal_cap(p_dm, p_cfo_track->def_x_cap);
-			PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): Disable CFO tracking for BT!!\n"));
+		#ifdef ODM_CONFIG_BT_COEXIST
+		/*@BT case: Disable CFO tracking */
+		if (dm->bt_info_table.is_bt_enabled) {
+			cfo_track->is_adjust = false;
+			phydm_set_crystal_cap(dm, cfo_track->def_x_cap);
+			PHYDM_DBG(dm, DBG_CFO_TRK, "[BT]Disable CFO_track\n");
 		}
-#if 0
-		/* 4 1.6 Big jump */
-		if (p_cfo_track->is_adjust) {
-			if (CFO_ave > CFO_TH_XTAL_LOW)
-				adjust_xtal =  adjust_xtal + ((CFO_ave - CFO_TH_XTAL_LOW) >> 2);
-			else if (CFO_ave < (-CFO_TH_XTAL_LOW))
-				adjust_xtal =  adjust_xtal + ((CFO_TH_XTAL_LOW - CFO_ave) >> 2);
-
-			PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): Crystal cap offset = %d\n", adjust_xtal));
-		}
-#endif
-#endif
-		/* 4 1.7 Adjust Crystal Cap. */
-		if (p_cfo_track->is_adjust) {
-			if (CFO_ave > CFO_TH_XTAL_LOW)
-				crystal_cap = crystal_cap + adjust_xtal;
-			else if (CFO_ave < (-CFO_TH_XTAL_LOW))
-				crystal_cap = crystal_cap - adjust_xtal;
-
-			if (crystal_cap > 0x3f)
-				crystal_cap = 0x3f;
-			else if (crystal_cap < 0)
+		#endif
+
+		/*@Adjust Crystal Cap. */
+		if (cfo_track->is_adjust) {
+			if (cfo_avg > CFO_TRK_STOP_TH)
+				crystal_cap += 1;
+			else if (cfo_avg < (-CFO_TRK_STOP_TH))
+				crystal_cap -= 1;
+
+			if (dm->support_ic_type & (ODM_RTL8822C |
+			    ODM_RTL8814B | ODM_RTL8195B | ODM_RTL8812F)) {
+				if (crystal_cap > 0x7F)
+					crystal_cap = 0x7F;
+			} else {
+				if (crystal_cap > 0x3F)
+					crystal_cap = 0x3F;
+			}
+			if (crystal_cap < 0)
 				crystal_cap = 0;
 
-			phydm_set_crystal_cap(p_dm, (u8)crystal_cap);
+			phydm_set_crystal_cap(dm, (u8)crystal_cap);
 		}
-		PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): Crystal cap = 0x%x, Default Crystal cap = 0x%x\n",
-			p_cfo_track->crystal_cap, p_cfo_track->def_x_cap));
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-			return;
+		PHYDM_DBG(dm, DBG_CFO_TRK, "X_cap{Curr,Default}={0x%x,0x%x}\n",
+			  cfo_track->crystal_cap, cfo_track->def_x_cap);
+
+		/* @Dynamic ATC switch */
+		#if ODM_IC_11N_SERIES_SUPPORT
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+			if (cfo_avg < CFO_TH_ATC && cfo_avg > -CFO_TH_ATC)
+				phydm_set_atc_status(dm, false);
+			else
+				phydm_set_atc_status(dm, true);
 
-		/* 3 2. Dynamic ATC switch */
-		if (CFO_ave < CFO_TH_ATC && CFO_ave > -CFO_TH_ATC) {
-			odm_set_atc_status(p_dm, false);
-			PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): Disable ATC!!\n"));
-		} else {
-			odm_set_atc_status(p_dm, true);
-			PHYDM_DBG(p_dm, DBG_CFO_TRK, ("odm_cfo_tracking(): Enable ATC!!\n"));
 		}
-#endif
+		#endif
+		#endif
 	}
 }
 
-void
-odm_parsing_cfo(
-	void			*p_dm_void,
-	void			*p_pktinfo_void,
-	s8			*pcfotail,
-	u8			num_ss
-)
+void phydm_parsing_cfo(void *dm_void, void *pktinfo_void, s8 *pcfotail,
+		       u8 num_ss)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_perpkt_info_struct		*p_pktinfo = (struct phydm_perpkt_info_struct *)p_pktinfo_void;
-	struct phydm_cfo_track_struct			*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
-	u8					i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
+	boolean valid_info = false;
+	u8 i = 0;
 
-	if (!(p_dm->support_ability & ODM_BB_CFO_TRACKING))
+	if (!(dm->support_ability & ODM_BB_CFO_TRACKING))
 		return;
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	if (p_pktinfo->is_packet_match_bssid)
+	pktinfo = (struct phydm_perpkt_info_struct *)pktinfo_void;
+
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_IOT))
+	if (pktinfo->is_packet_match_bssid)
+		valid_info = true;
 #else
-	if (p_pktinfo->station_id != 0)
+	if (dm->number_active_client == 1)
+		valid_info = true;
 #endif
-	{
-		if (num_ss > p_dm->num_rf_path) /*For fool proof*/
-			num_ss = p_dm->num_rf_path;
-
-		/*PHYDM_DBG(p_dm, DBG_CFO_TRK, ("num_ss = ((%d)),  p_dm->num_rf_path = ((%d))\n", num_ss,  p_dm->num_rf_path));*/
-
+	if (valid_info) {
+		if (num_ss > dm->num_rf_path) /*@For fool proof*/
+			num_ss = dm->num_rf_path;
+		#if 0
+		PHYDM_DBG(dm, DBG_CFO_TRK, "num_ss=%d, num_rf_path=%d\n",
+			  num_ss, dm->num_rf_path);
+		#endif
 
-		/* 3 Update CFO report for path-A & path-B */
+		/* @ Update CFO report for path-A & path-B */
 		/* Only paht-A and path-B have CFO tail and short CFO */
-		for (i = 0; i < num_ss; i++) {
-			p_cfo_track->CFO_tail[i] += pcfotail[i];
-			p_cfo_track->CFO_cnt[i]++;
-			/*PHYDM_DBG(p_dm, DBG_CFO_TRK, ("[ID %d][path %d][rate 0x%x] CFO_tail = ((%d)), CFO_tail_sum = ((%d)), CFO_cnt = ((%d))\n",
-				p_pktinfo->station_id, i, p_pktinfo->data_rate, pcfotail[i], p_cfo_track->CFO_tail[i], p_cfo_track->CFO_cnt[i]));
-			*/
+		for (i = 0; i < dm->num_rf_path; i++) {
+			if (!(dm->rx_ant_status & BIT(i)))
+				continue;
+			cfo_track->CFO_tail[i] += pcfotail[i];
+			cfo_track->CFO_cnt[i]++;
+			#if 0
+			PHYDM_DBG(dm, DBG_CFO_TRK,
+				  "[ID %d][path %d][rate 0x%x] CFO_tail = ((%d)), CFO_tail_sum = ((%d)), CFO_cnt = ((%d))\n",
+				  pktinfo->station_id, i, pktinfo->data_rate,
+				  pcfotail[i], cfo_track->CFO_tail[i],
+				  cfo_track->CFO_cnt[i]);
+			#endif
 		}
 
-		/* 3 Update packet counter */
-		if (p_cfo_track->packet_count == 0xffffffff)
-			p_cfo_track->packet_count = 0;
+		/* @ Update packet counter */
+		if (cfo_track->packet_count == 0xffffffff)
+			cfo_track->packet_count = 0;
 		else
-			p_cfo_track->packet_count++;
+			cfo_track->packet_count++;
 	}
 }
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phy_Init_crystal_capacity(void *dm_void, u8 crystal_cap)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (!phydm_set_crystal_cap_reg(dm, crystal_cap))
+		RT_TRACE_F(COMP_INIT, DBG_SERIOUS,
+			   ("Crystal is not initialized!\n"));
+}
+#endif
+
+void phydm_cfo_tracking_debug(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_track = &dm->dm_cfo_track;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "set Xcap: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "show Xcap: {100}\n");
+	} else {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		if (var1[0] == 1) {
+			PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
+			phydm_set_crystal_cap(dm, (u8)var1[1]);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Set X_cap=0x%x\n", cfo_track->crystal_cap);
+		} else if (var1[0] == 100) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "X_cap=0x%x\n", cfo_track->crystal_cap);
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.h
index 43815f21a6a0..aec407333659 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_cfotracking.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,63 +9,66 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMCFOTRACK_H__
-#define    __PHYDMCFOTRACK_H__
+#ifndef __PHYDMCFOTRACK_H__
+#define __PHYDMCFOTRACK_H__
 
-#define CFO_TRACKING_VERSION	"1.4" /*2015.10.01	Stanley, Modify for 8822B*/
+#define CFO_TRACKING_VERSION "2.0"
 
-#define		CFO_TH_XTAL_HIGH			20			/* kHz */
-#define		CFO_TH_XTAL_LOW			10			/* kHz */
-#define		CFO_TH_ATC					80			/* kHz */
+#define		CFO_TRK_ENABLE_TH	20 /* @kHz enable CFO_Track threshold*/
+#define		CFO_TRK_STOP_TH		10 /* @kHz disable CFO_Track threshold*/
+#define		CFO_TH_ATC		80 /* @kHz */
 
 struct phydm_cfo_track_struct {
-	boolean			is_atc_status;
-	boolean			large_cfo_hit;
-	boolean			is_adjust;
-	u8			crystal_cap;
-	u8			def_x_cap;
-	s32			CFO_tail[4];
-	u32			CFO_cnt[4];
-	s32			CFO_ave_pre;
-	u32			packet_count;
-	u32			packet_count_pre;
+	boolean		is_atc_status;
+	boolean		is_adjust;	/*@already modify crystal cap*/
+	u8		crystal_cap;
+	u8		crystal_cap_default;
+	u8		def_x_cap;
+	s32		CFO_tail[4];
+	u32		CFO_cnt[4];
+	s32		CFO_ave_pre;
+	u32		packet_count;
+	u32		packet_count_pre;
+};
 
-	boolean			is_force_xtal_cap;
-	boolean			is_reset;
+struct phydm_cfo_rpt {
+	s32 cfo_rpt_s[PHYDM_MAX_RF_PATH];
+	s32 cfo_rpt_l[PHYDM_MAX_RF_PATH];
+	s32 cfo_rpt_acq[PHYDM_MAX_RF_PATH];
+	s32 cfo_rpt_sec[PHYDM_MAX_RF_PATH];
+	s32 cfo_rpt_end[PHYDM_MAX_RF_PATH];
 };
 
-void
-phydm_set_crystal_cap(
-	void					*p_dm_void,
-	u8					crystal_cap
-);
+void phydm_get_cfo_info(void *dm_void, struct phydm_cfo_rpt *cfo);
 
-void
-odm_cfo_tracking_reset(
-	void					*p_dm_void
-);
+void phydm_set_crystal_cap(void *dm_void, u8 crystal_cap);
 
-void
-phydm_cfo_tracking_init(
-	void					*p_dm_void
-);
+boolean phydm_set_crystal_cap_reg(void *dm_void, u8 crystal_cap);
 
-void
-odm_cfo_tracking(
-	void					*p_dm_void
-);
+void phydm_cfo_tracking_init(void *dm_void);
 
-void
-odm_parsing_cfo(
-	void					*p_dm_void,
-	void					*p_pktinfo_void,
-	s8					*pcfotail,
-	u8					num_ss
-);
+void phydm_cfo_tracking(void *dm_void);
 
+void phydm_parsing_cfo(void *dm_void, void *pktinfo_void, s8 *pcfotail,
+		       u8 num_ss);
+void phydm_cfo_tracking_debug(void *dm_void, char input[][16], u32 *_used,
+			      char *output, u32 *_out_len);
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phy_Init_crystal_capacity(void *dm_void, u8 crystal_cap);
+#endif
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.c
index 8bb4faf40b50..ef23893441b0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,206 +9,192 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-void
-phydm_init_debug_setting(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_init_debug_setting(struct dm_struct *dm)
 {
-	p_dm->debug_level = ODM_DBG_TRACE;
+	dm->fw_debug_components = 0;
+	dm->debug_components =
 
-	p_dm->fw_debug_components = 0;
-	p_dm->debug_components =
-		\
 #if DBG
-		/*BB Functions*/
-		/*									DBG_DIG					|*/
-		/*									DBG_RA_MASK				|*/
-		/*									DBG_DYN_TXPWR		|*/
-		/*									DBG_FA_CNT				|*/
-		/*									DBG_RSSI_MNTR			|*/
-		/*									DBG_CCKPD					|*/
-		/*									DBG_ANT_DIV				|*/
-		/*									DBG_SMT_ANT				|*/
-		/*									DBG_PWR_TRAIN					|*/
-		/*									DBG_RA					|*/
-		/*									DBG_PATH_DIV				|*/
-		/*									DBG_DFS					|*/
-		/*									DBG_DYN_ARFR			|*/
-		/*									DBG_ADPTVTY			|*/
-		/*									DBG_CFO_TRK		|*/
-		/*									DBG_ENV_MNTR					|*/
-		/*									DBG_PRI_CCA		|*/
-		/*									DBG_ADPTV_SOML		|*/
-		
-		
-		/*									DBG_DYN_RX_PATH		|*/
-		/*									DBG_TMP					|*/
-		/*									DBG_FW_TRACE			|*/
-		/*									DBG_TXBF				|*/
-		/*									DBG_COMMON_FLOW				|*/
-		/*									ODM_COMP_TX_PWR_TRACK		|*/
-		/*									ODM_COMP_CALIBRATION			|*/
-		/*									ODM_COMP_MP					|*/
-		/*									ODM_PHY_CONFIG					|*/
-		/*									ODM_COMP_INIT					|*/
-		/*									ODM_COMP_COMMON				|*/
-		/*									ODM_COMP_API					|*/
-
-
-#endif
-		0;
-
-	p_dm->fw_buff_is_enpty = true;
-	p_dm->pre_c2h_seq = 0;
-	p_dm->c2h_cmd_start = 0;
+	/*@BB Functions*/
+	/*@DBG_DIG					|*/
+	/*@DBG_RA_MASK					|*/
+	/*@DBG_DYN_TXPWR				|*/
+	/*@DBG_FA_CNT					|*/
+	/*@DBG_RSSI_MNTR				|*/
+	/*@DBG_CCKPD					|*/
+	/*@DBG_ANT_DIV					|*/
+	/*@DBG_SMT_ANT					|*/
+	/*@DBG_PWR_TRAIN				|*/
+	/*@DBG_RA					|*/
+	/*@DBG_PATH_DIV					|*/
+	/*@DBG_DFS					|*/
+	/*@DBG_DYN_ARFR					|*/
+	/*@DBG_ADPTVTY					|*/
+	/*@DBG_CFO_TRK					|*/
+	/*@DBG_ENV_MNTR					|*/
+	/*@DBG_PRI_CCA					|*/
+	/*@DBG_ADPTV_SOML				|*/
+	/*@DBG_LNA_SAT_CHK				|*/
+	/*@DBG_PHY_STATUS				|*/
+	/*@DBG_TMP					|*/
+	/*@DBG_FW_TRACE					|*/
+	/*@DBG_TXBF					|*/
+	/*@DBG_COMMON_FLOW				|*/
+	/*@ODM_PHY_CONFIG				|*/
+	/*@ODM_COMP_INIT				|*/
+	/*@DBG_CMN					|*/
+	/*@ODM_COMP_API					|*/
+#endif
+	0;
+
+	dm->fw_buff_is_enpty = true;
+	dm->pre_c2h_seq = 0;
+	dm->c2h_cmd_start = 0;
+	dm->cmn_dbg_msg_cnt = PHYDM_WATCH_DOG_PERIOD;
+	dm->cmn_dbg_msg_period = PHYDM_WATCH_DOG_PERIOD;
+	phydm_reset_rx_rate_distribution(dm);
 }
 
-void
-phydm_bb_dbg_port_header_sel(
-	void			*p_dm_void,
-	u32			header_idx
-) {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		
-		odm_set_bb_reg(p_dm, 0x8f8, (BIT(25) | BIT(24) | BIT(23) | BIT(22)), header_idx);
-		
-		/*
-		header_idx:
-			(0:) '{ofdm_dbg[31:0]}'
-			(1:) '{cca,crc32_fail,dbg_ofdm[29:0]}'
-			(2:) '{vbon,crc32_fail,dbg_ofdm[29:0]}'
-			(3:) '{cca,crc32_ok,dbg_ofdm[29:0]}'
-			(4:) '{vbon,crc32_ok,dbg_ofdm[29:0]}'
-			(5:) '{dbg_iqk_anta}'
-			(6:) '{cca,ofdm_crc_ok,dbg_dp_anta[29:0]}'
-			(7:) '{dbg_iqk_antb}'
-			(8:) '{DBGOUT_RFC_b[31:0]}'
-			(9:) '{DBGOUT_RFC_a[31:0]}'
-			(a:) '{dbg_ofdm}'
-			(b:) '{dbg_cck}'
-		*/
+void phydm_bb_dbg_port_header_sel(void *dm_void, u32 header_idx)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x8f8, 0x3c00000, header_idx);
+
+		/*@
+		 * header_idx:
+		 *	(0:) '{ofdm_dbg[31:0]}'
+		 *	(1:) '{cca,crc32_fail,dbg_ofdm[29:0]}'
+		 *	(2:) '{vbon,crc32_fail,dbg_ofdm[29:0]}'
+		 *	(3:) '{cca,crc32_ok,dbg_ofdm[29:0]}'
+		 *	(4:) '{vbon,crc32_ok,dbg_ofdm[29:0]}'
+		 *	(5:) '{dbg_iqk_anta}'
+		 *	(6:) '{cca,ofdm_crc_ok,dbg_dp_anta[29:0]}'
+		 *	(7:) '{dbg_iqk_antb}'
+		 *	(8:) '{DBGOUT_RFC_b[31:0]}'
+		 *	(9:) '{DBGOUT_RFC_a[31:0]}'
+		 *	(a:) '{dbg_ofdm}'
+		 *	(b:) '{dbg_cck}'
+		 */
 	}
 }
 
-void
-phydm_bb_dbg_port_clock_en(
-	void			*p_dm_void,
-	u8			enable
-) {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		reg_value = 0;
-	
-	if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814A | ODM_RTL8814B)) {
-		
-		reg_value = (enable == true) ? 0x7 : 0;
-		odm_set_bb_reg(p_dm, 0x198c, 0x7, reg_value); /*enable/disable debug port clock, for power saving*/
+void phydm_bb_dbg_port_clock_en(void *dm_void, u8 enable)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 reg_value = 0;
+
+	if (dm->support_ic_type &
+	    (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814A | ODM_RTL8814B |
+	    ODM_RTL8195B)) {
+		/*@enable/disable debug port clock, for power saving*/
+		reg_value = enable ? 0x7 : 0;
+		odm_set_bb_reg(dm, R_0x198c, 0x7, reg_value);
 	}
 }
 
-u8
-phydm_set_bb_dbg_port(
-	void			*p_dm_void,
-	u8			curr_dbg_priority,
-	u32			debug_port
-)
+u8 phydm_set_bb_dbg_port(void *dm_void, u8 curr_dbg_priority, u32 debug_port)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	dbg_port_result = false;
-
-	if (curr_dbg_priority > p_dm->pre_dbg_priority) {
-
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-			
-			phydm_bb_dbg_port_clock_en(p_dm, true);
-			
-			odm_set_bb_reg(p_dm, 0x8fc, MASKDWORD, debug_port);
-			/**/
-		} else /*if (p_dm->support_ic_type & ODM_IC_11N_SERIES)*/ {
-			odm_set_bb_reg(p_dm, 0x908, MASKDWORD, debug_port);
-			/**/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 dbg_port_result = false;
+
+	if (curr_dbg_priority > dm->pre_dbg_priority) {
+		if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+			phydm_bb_dbg_port_clock_en(dm, true);
+
+			odm_set_bb_reg(dm, R_0x8fc, MASKDWORD, debug_port);
+		} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			odm_set_bb_reg(dm, R_0x1c3c, 0xfff00, debug_port);
+
+		} else { /*@if (dm->support_ic_type & ODM_IC_11N_SERIES)*/
+			odm_set_bb_reg(dm, R_0x908, MASKDWORD, debug_port);
 		}
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("DbgPort ((0x%x)) set success, Cur_priority=((%d)), Pre_priority=((%d))\n", debug_port, curr_dbg_priority, p_dm->pre_dbg_priority));
-		p_dm->pre_dbg_priority = curr_dbg_priority;
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "DbgPort ((0x%x)) set success, Cur_priority=((%d)), Pre_priority=((%d))\n",
+			  debug_port, curr_dbg_priority, dm->pre_dbg_priority);
+		dm->pre_dbg_priority = curr_dbg_priority;
 		dbg_port_result = true;
 	}
-		
+
 	return dbg_port_result;
 }
 
-void
-phydm_release_bb_dbg_port(
-	void			*p_dm_void
-)
+void phydm_release_bb_dbg_port(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	phydm_bb_dbg_port_clock_en(p_dm, false);
-	phydm_bb_dbg_port_header_sel(p_dm, 0);
+	phydm_bb_dbg_port_clock_en(dm, false);
+	phydm_bb_dbg_port_header_sel(dm, 0);
 
-	p_dm->pre_dbg_priority = BB_DBGPORT_RELEASE;
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("Release BB dbg_port\n"));
+	dm->pre_dbg_priority = DBGPORT_RELEASE;
+	PHYDM_DBG(dm, ODM_COMP_API, "Release BB dbg_port\n");
 }
 
-u32
-phydm_get_bb_dbg_port_value(
-	void			*p_dm_void
-)
+u32 phydm_get_bb_dbg_port_val(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	dbg_port_value = 0;
-
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		dbg_port_value = odm_get_bb_reg(p_dm, 0xfa0, MASKDWORD);
-		/**/
-	} else /*if (p_dm->support_ic_type & ODM_IC_11N_SERIES)*/ {
-		dbg_port_value = odm_get_bb_reg(p_dm, 0xdf4, MASKDWORD);
-		/**/
-	}
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("dbg_port_value = 0x%x\n", dbg_port_value));
-	return	dbg_port_value;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 dbg_port_value = 0;
+
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		dbg_port_value = odm_get_bb_reg(dm, R_0xfa0, MASKDWORD);
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		dbg_port_value = odm_get_bb_reg(dm, R_0x2dbc, MASKDWORD);
+	else /*@if (dm->support_ic_type & ODM_IC_11N_SERIES)*/
+		dbg_port_value = odm_get_bb_reg(dm, R_0xdf4, MASKDWORD);
+
+	PHYDM_DBG(dm, ODM_COMP_API, "dbg_port_value = 0x%x\n", dbg_port_value);
+	return dbg_port_value;
 }
 
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-
-void
-phydm_bb_debug_info_n_series(
-	void			*p_dm_void,
-	u32			*_used,
-	char				*output,
-	u32			*_out_len
-)
+#if (ODM_IC_11N_SERIES_SUPPORT)
+void phydm_bb_hw_dbg_info_n(void *dm_void, u32 *_used, char *output,
+			    u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u32 value32 = 0, value32_1 = 0;
+	u8 rf_gain_a = 0, rf_gain_b = 0, rf_gain_c = 0, rf_gain_d = 0;
+	u8 rx_snr_a = 0, rx_snr_b = 0, rx_snr_c = 0, rx_snr_d = 0;
+	s8 rxevm_0 = 0, rxevm_1 = 0;
+	#if 1
+	struct phydm_cfo_rpt cfo;
+	u8 i = 0;
+	#else
+	s32 short_cfo_a = 0, short_cfo_b = 0, long_cfo_a = 0, long_cfo_b = 0;
+	s32 scfo_a = 0, scfo_b = 0, avg_cfo_a = 0, avg_cfo_b = 0;
+	s32 cfo_end_a = 0, cfo_end_b = 0, acq_cfo_a = 0, acq_cfo_b = 0;
+	#endif
 
-	u32	value32 = 0, value32_1 = 0;
-	u8	rf_gain_a = 0, rf_gain_b = 0, rf_gain_c = 0, rf_gain_d = 0;
-	u8	rx_snr_a = 0, rx_snr_b = 0, rx_snr_c = 0, rx_snr_d = 0;
-
-	s8    rxevm_0 = 0, rxevm_1 = 0;
-	s32	short_cfo_a = 0, short_cfo_b = 0, long_cfo_a = 0, long_cfo_b = 0;
-	s32	scfo_a = 0, scfo_b = 0, avg_cfo_a = 0, avg_cfo_b = 0;
-	s32	cfo_end_a = 0, cfo_end_b = 0, acq_cfo_a = 0, acq_cfo_b = 0;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s\n", "BB Report Info"));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\r\n %-35s\n",
+		 "BB Report Info");
 
-	/*AGC result*/
-	value32 = odm_get_bb_reg(p_dm, 0xdd0, MASKDWORD);
+	/*@AGC result*/
+	value32 = odm_get_bb_reg(dm, R_0xdd0, MASKDWORD);
 	rf_gain_a = (u8)(value32 & 0x3f);
 	rf_gain_a = rf_gain_a << 1;
 
@@ -220,10 +207,12 @@ phydm_bb_debug_info_n_series(
 	rf_gain_d = (u8)((value32 >> 24) & 0x3f);
 	rf_gain_d = rf_gain_d << 1;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d / %d", "OFDM RX RF Gain(A/B/C/D)", rf_gain_a, rf_gain_b, rf_gain_c, rf_gain_d));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d / %d / %d", "OFDM RX RF Gain(A/B/C/D)",
+		 rf_gain_a, rf_gain_b, rf_gain_c, rf_gain_d);
 
 	/*SNR report*/
-	value32 = odm_get_bb_reg(p_dm, 0xdd4, MASKDWORD);
+	value32 = odm_get_bb_reg(dm, R_0xdd4, MASKDWORD);
 	rx_snr_a = (u8)(value32 & 0xff);
 	rx_snr_a = rx_snr_a >> 1;
 
@@ -236,10 +225,12 @@ phydm_bb_debug_info_n_series(
 	rx_snr_d = (u8)((value32 >> 24) & 0xff);
 	rx_snr_d = rx_snr_d >> 1;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)", rx_snr_a, rx_snr_b, rx_snr_c, rx_snr_d));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)",
+		 rx_snr_a, rx_snr_b, rx_snr_c, rx_snr_d);
 
 	/* PostFFT related info*/
-	value32 = odm_get_bb_reg(p_dm, 0xdd8, MASKDWORD);
+	value32 = odm_get_bb_reg(dm, R_0xdd8, MASKDWORD);
 
 	rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
 	rxevm_0 /= 2;
@@ -251,19 +242,30 @@ phydm_bb_debug_info_n_series(
 	if (rxevm_1 < -63)
 		rxevm_1 = 0;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "RXEVM (1ss/2ss)", rxevm_0, rxevm_1));
-
-	/*CFO Report Info*/
-	odm_set_bb_reg(p_dm, 0xd00, BIT(26), 1);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "RXEVM (1ss/2ss)", rxevm_0, rxevm_1);
+
+#if 1
+	phydm_get_cfo_info(dm, &cfo);
+	for (i = 0; i < dm->num_rf_path; i++) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %s[%d] %-28s = {%d, %d, %d, %d, %d}",
+			 "CFO", i, "{S, L, Sec, Acq, End}",
+			 cfo.cfo_rpt_s[i], cfo.cfo_rpt_l[i], cfo.cfo_rpt_sec[i],
+			 cfo.cfo_rpt_acq[i], cfo.cfo_rpt_end[i]);
+	}
+#else
+	/*@CFO Report Info*/
+	odm_set_bb_reg(dm, R_0xd00, BIT(26), 1);
 
 	/*Short CFO*/
-	value32 = odm_get_bb_reg(p_dm, 0xdac, MASKDWORD);
-	value32_1 = odm_get_bb_reg(p_dm, 0xdb0, MASKDWORD);
+	value32 = odm_get_bb_reg(dm, R_0xdac, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, R_0xdb0, MASKDWORD);
 
-	short_cfo_b = (s32)(value32 & 0xfff);			/*S(12,11)*/
+	short_cfo_b = (s32)(value32 & 0xfff); /*S(12,11)*/
 	short_cfo_a = (s32)((value32 & 0x0fff0000) >> 16);
 
-	long_cfo_b = (s32)(value32_1 & 0x1fff);		/*S(13,12)*/
+	long_cfo_b = (s32)(value32_1 & 0x1fff); /*S(13,12)*/
 	long_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
 
 	/*SFO 2's to dec*/
@@ -275,7 +277,7 @@ phydm_bb_debug_info_n_series(
 	short_cfo_a = (short_cfo_a * 312500) / 2048;
 	short_cfo_b = (short_cfo_b * 312500) / 2048;
 
-	/*LFO 2's to dec*/
+	/*@LFO 2's to dec*/
 
 	if (long_cfo_a > 4095)
 		long_cfo_a = long_cfo_a - 8192;
@@ -286,15 +288,20 @@ phydm_bb_debug_info_n_series(
 	long_cfo_a = long_cfo_a * 312500 / 4096;
 	long_cfo_b = long_cfo_b * 312500 / 4096;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "CFO Report Info"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "Short CFO(Hz) <A/B>", short_cfo_a, short_cfo_b));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "Long CFO(Hz) <A/B>", long_cfo_a, long_cfo_b));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\r\n %-35s",
+		 "CFO Report Info");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "Short CFO(Hz) <A/B>", short_cfo_a,
+		 short_cfo_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "Long CFO(Hz) <A/B>", long_cfo_a,
+		 long_cfo_b);
 
 	/*SCFO*/
-	value32 = odm_get_bb_reg(p_dm, 0xdb8, MASKDWORD);
-	value32_1 = odm_get_bb_reg(p_dm, 0xdb4, MASKDWORD);
+	value32 = odm_get_bb_reg(dm, R_0xdb8, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, R_0xdb4, MASKDWORD);
 
-	scfo_b = (s32)(value32 & 0x7ff);			/*S(11,10)*/
+	scfo_b = (s32)(value32 & 0x7ff); /*S(11,10)*/
 	scfo_a = (s32)((value32 & 0x07ff0000) >> 16);
 
 	if (scfo_a > 1023)
@@ -306,7 +313,7 @@ phydm_bb_debug_info_n_series(
 	scfo_a = scfo_a * 312500 / 1024;
 	scfo_b = scfo_b * 312500 / 1024;
 
-	avg_cfo_b = (s32)(value32_1 & 0x1fff);	/*S(13,12)*/
+	avg_cfo_b = (s32)(value32_1 & 0x1fff); /*S(13,12)*/
 	avg_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
 
 	if (avg_cfo_a > 4095)
@@ -318,13 +325,17 @@ phydm_bb_debug_info_n_series(
 	avg_cfo_a = avg_cfo_a * 312500 / 4096;
 	avg_cfo_b = avg_cfo_b * 312500 / 4096;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "value SCFO(Hz) <A/B>", scfo_a, scfo_b));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "Avg CFO(Hz) <A/B>", avg_cfo_a, avg_cfo_b));
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "value SCFO(Hz) <A/B>", scfo_a,
+		 scfo_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "Avg CFO(Hz) <A/B>", avg_cfo_a,
+		 avg_cfo_b);
 
-	value32 = odm_get_bb_reg(p_dm, 0xdbc, MASKDWORD);
-	value32_1 = odm_get_bb_reg(p_dm, 0xde0, MASKDWORD);
+	value32 = odm_get_bb_reg(dm, R_0xdbc, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, R_0xde0, MASKDWORD);
 
-	cfo_end_b = (s32)(value32 & 0x1fff);		/*S(13,12)*/
+	cfo_end_b = (s32)(value32 & 0x1fff); /*S(13,12)*/
 	cfo_end_a = (s32)((value32 & 0x1fff0000) >> 16);
 
 	if (cfo_end_a > 4095)
@@ -336,7 +347,7 @@ phydm_bb_debug_info_n_series(
 	cfo_end_a = cfo_end_a * 312500 / 4096;
 	cfo_end_b = cfo_end_b * 312500 / 4096;
 
-	acq_cfo_b = (s32)(value32_1 & 0x1fff);	/*S(13,12)*/
+	acq_cfo_b = (s32)(value32_1 & 0x1fff); /*S(13,12)*/
 	acq_cfo_a = (s32)((value32_1 & 0x1fff0000) >> 16);
 
 	if (acq_cfo_a > 4095)
@@ -348,1652 +359,3528 @@ phydm_bb_debug_info_n_series(
 	acq_cfo_a = acq_cfo_a * 312500 / 4096;
 	acq_cfo_b = acq_cfo_b * 312500 / 4096;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "End CFO(Hz) <A/B>", cfo_end_a, cfo_end_b));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "ACQ CFO(Hz) <A/B>", acq_cfo_a, acq_cfo_b));
-
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "End CFO(Hz) <A/B>", cfo_end_a,
+		 cfo_end_b);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "ACQ CFO(Hz) <A/B>", acq_cfo_a,
+		 acq_cfo_b);
+#endif
 }
+#endif
 
-
-void
-phydm_bb_debug_info(
-	void			*p_dm_void,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+#if (ODM_IC_11AC_SERIES_SUPPORT)
+#if (RTL8822B_SUPPORT)
+void phydm_bb_hw_dbg_info_8822b(void *dm_void, u32 *_used, char *output,
+				u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u32 condi_num = 0;
+	u8 i = 0;
 
-	char *tmp_string = NULL;
+	if (!(dm->support_ic_type == ODM_RTL8822B))
+		return;
 
-	u8	RX_HT_BW, RX_VHT_BW, RXSC, RX_HT, RX_BW;
-	static u8 v_rx_bw ;
-	u32	value32, value32_1, value32_2, value32_3;
-	s32	SFO_A, SFO_B, SFO_C, SFO_D;
-	s32	LFO_A, LFO_B, LFO_C, LFO_D;
-	static u8	MCSS, tail, parity, rsv, vrsv, idx, smooth, htsound, agg, stbc, vstbc, fec, fecext, sgi, sgiext, htltf, vgid, v_nsts, vtxops, vrsv2, vbrsv, bf, vbcrc;
-	static u16	h_length, htcrc8, length;
-	static u16 vpaid;
-	static u16	v_length, vhtcrc8, v_mcss, v_tail, vb_tail;
-	static u8	HMCSS, HRX_BW;
+	condi_num = phydm_get_condi_num_8822b(dm);
+	phydm_get_condi_num_acc_8822b(dm);
 
-	u8    pwdb;
-	s8    RXEVM_0, RXEVM_1, RXEVM_2 ;
-	u8    rf_gain_path_a, rf_gain_path_b, rf_gain_path_c, rf_gain_path_d;
-	u8    rx_snr_path_a, rx_snr_path_b, rx_snr_path_c, rx_snr_path_d;
-	s32    sig_power;
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d.%.4d", "condi_num",
+		 condi_num >> 4, phydm_show_fraction_num(condi_num & 0xf, 4));
 
-	const char *L_rate[8] = {"6M", "9M", "12M", "18M", "24M", "36M", "48M", "54M"};
+	for (i = 0; i < CN_CNT_MAX; i++) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n Tone_num[CN>%d]%-21s = %d",
+			 i, " ", dm->phy_dbg_info.condi_num_cdf[i]);
+	}
 
-#if 0
-	const double evm_comp_20M = 0.579919469776867; /* 10*log10(64.0/56.0) */
-	const double evm_comp_40M = 0.503051183113957; /* 10*log10(128.0/114.0) */
-	const double evm_comp_80M = 0.244245993314183; /* 10*log10(256.0/242.0) */
-	const double evm_comp_160M = 0.244245993314183; /* 10*log10(512.0/484.0) */
+	*_used = used;
+	*_out_len = out_len;
+}
 #endif
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		phydm_bb_debug_info_n_series(p_dm, &used, output, &out_len);
-		return;
+void phydm_bb_hw_dbg_info_ac(void *dm_void, u32 *_used, char *output,
+			     u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	char *tmp_string = NULL;
+	u8 rx_ht_bw, rx_vht_bw, rxsc, rx_ht, bw_idx = 0;
+	static u8 v_rx_bw;
+	u32 value32, value32_1, value32_2, value32_3;
+	struct phydm_cfo_rpt cfo;
+	u8 i = 0;
+	static u8 tail, parity, rsv, vrsv, smooth, htsound, agg;
+	static u8 stbc, vstbc, fec, fecext, sgi, sgiext, htltf, vgid, v_nsts;
+	static u8 vtxops, vrsv2, vbrsv, bf, vbcrc;
+	static u16 h_length, htcrc8, length;
+	static u16 vpaid;
+	static u16 v_length, vhtcrc8, v_mcss, v_tail, vb_tail;
+	static u8 hmcss, hrx_bw;
+	u8 pwdb;
+	s8 rxevm_0, rxevm_1, rxevm_2;
+	u8 rf_gain[4];
+	u8 rx_snr[4];
+	s32 sig_power;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\r\n %-35s\n",
+		 "BB Report Info");
+
+	/*@ [BW & Mode] =====================================================*/
+
+	value32 = odm_get_bb_reg(dm, R_0xf80, MASKDWORD);
+	rx_ht = (u8)((value32 & 0x180) >> 7);
+
+	if (rx_ht == AD_VHT_MODE) {
+		tmp_string = "VHT";
+		bw_idx = (u8)((value32 >> 1) & 0x3);
+	} else if (rx_ht == AD_HT_MODE) {
+		tmp_string = "HT";
+		bw_idx = (u8)(value32 & 0x1);
+	} else {
+		tmp_string = "Legacy";
+		bw_idx = 0;
 	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s %s %dM", "mode", tmp_string, (20 << bw_idx));
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s\n", "BB Report Info"));
-
-	/*BW & mode Detection*/
+	if (rx_ht != AD_LEGACY_MODE) {
+		rxsc = (u8)(value32 & 0x78);
 
-	value32 = odm_get_bb_reg(p_dm, 0xf80, MASKDWORD);
-	value32_2 = value32;
-	RX_HT_BW = (u8)(value32 & 0x1);
-	RX_VHT_BW = (u8)((value32 >> 1) & 0x3);
-	RXSC = (u8)(value32 & 0x78);
-	value32_1 = (value32 & 0x180) >> 7;
-	RX_HT = (u8)(value32_1);
-
-	RX_BW = 0;
-
-	if (RX_HT == 2) {
-		if (RX_VHT_BW == 0)
-			tmp_string = "20M";
-		else if (RX_VHT_BW == 1)
-			tmp_string = "40M";
-		else
-			tmp_string = "80M";
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s %s %s", "mode", "VHT", tmp_string));
-		RX_BW = RX_VHT_BW;
-	} else if (RX_HT == 1) {
-		if (RX_HT_BW == 0)
-			tmp_string = "20M";
-		else if (RX_HT_BW == 1)
-			tmp_string = "40M";
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s %s %s", "mode", "HT", tmp_string));
-		RX_BW = RX_HT_BW;
-	} else
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s %s", "mode", "Legacy"));
-
-	if (RX_HT != 0) {
-		if (RXSC == 0)
+		if (rxsc == 0)
 			tmp_string = "duplicate/full bw";
-		else if (RXSC == 1)
+		else if (rxsc == 1)
 			tmp_string = "usc20-1";
-		else if (RXSC == 2)
+		else if (rxsc == 2)
 			tmp_string = "lsc20-1";
-		else if (RXSC == 3)
+		else if (rxsc == 3)
 			tmp_string = "usc20-2";
-		else if (RXSC == 4)
+		else if (rxsc == 4)
 			tmp_string = "lsc20-2";
-		else if (RXSC == 9)
+		else if (rxsc == 9)
 			tmp_string = "usc40";
-		else if (RXSC == 10)
+		else if (rxsc == 10)
 			tmp_string = "lsc40";
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s", tmp_string));
-	}
-
-	/* RX signal power and AGC related info*/
-
-	value32 = odm_get_bb_reg(p_dm, 0xF90, MASKDWORD);
-	pwdb = (u8)((value32 & MASKBYTE1) >> 8);
-	pwdb = pwdb >> 1;
-	sig_power = -110 + pwdb;
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d", "OFDM RX Signal Power(dB)", sig_power));
-
-	value32 = odm_get_bb_reg(p_dm, 0xd14, MASKDWORD);
-	rx_snr_path_a = (u8)(value32 & 0xFF) >> 1;
-	rf_gain_path_a = (s8)((value32 & MASKBYTE1) >> 8);
-	rf_gain_path_a *= 2;
-	value32 = odm_get_bb_reg(p_dm, 0xd54, MASKDWORD);
-	rx_snr_path_b = (u8)(value32 & 0xFF) >> 1;
-	rf_gain_path_b = (s8)((value32 & MASKBYTE1) >> 8);
-	rf_gain_path_b *= 2;
-	value32 = odm_get_bb_reg(p_dm, 0xd94, MASKDWORD);
-	rx_snr_path_c = (u8)(value32 & 0xFF) >> 1;
-	rf_gain_path_c = (s8)((value32 & MASKBYTE1) >> 8);
-	rf_gain_path_c *= 2;
-	value32 = odm_get_bb_reg(p_dm, 0xdd4, MASKDWORD);
-	rx_snr_path_d = (u8)(value32 & 0xFF) >> 1;
-	rf_gain_path_d = (s8)((value32 & MASKBYTE1) >> 8);
-	rf_gain_path_d *= 2;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d / %d", "OFDM RX RF Gain(A/B/C/D)", rf_gain_path_a, rf_gain_path_b, rf_gain_path_c, rf_gain_path_d));
 
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "  %-35s", tmp_string);
+	}
 
-	/* RX counter related info*/
-
-	value32 = odm_get_bb_reg(p_dm, 0xF08, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d", "OFDM CCA counter", ((value32 & 0xFFFF0000) >> 16)));
-
-	value32 = odm_get_bb_reg(p_dm, 0xFD0, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d", "OFDM SBD Fail counter", value32 & 0xFFFF));
-
-	value32 = odm_get_bb_reg(p_dm, 0xFC4, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "VHT SIGA/SIGB CRC8 Fail counter", value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16)));
-
-	value32 = odm_get_bb_reg(p_dm, 0xFCC, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d", "CCK CCA counter", value32 & 0xFFFF));
-
-	value32 = odm_get_bb_reg(p_dm, 0xFBC, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "LSIG (parity Fail/rate Illegal) counter", value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16)));
-
-	value32_1 = odm_get_bb_reg(p_dm, 0xFC8, MASKDWORD);
-	value32_2 = odm_get_bb_reg(p_dm, 0xFC0, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "HT/VHT MCS NOT SUPPORT counter", ((value32_2 & 0xFFFF0000) >> 16), value32_1 & 0xFFFF));
-
-	/* PostFFT related info*/
-	value32 = odm_get_bb_reg(p_dm, 0xF8c, MASKDWORD);
-	RXEVM_0 = (s8)((value32 & MASKBYTE2) >> 16);
-	RXEVM_0 /= 2;
-	if (RXEVM_0 < -63)
-		RXEVM_0 = 0;
+	/*@ [RX signal power and AGC related info] ==========================*/
 
-	RXEVM_1 = (s8)((value32 & MASKBYTE3) >> 24);
-	RXEVM_1 /= 2;
-	value32 = odm_get_bb_reg(p_dm, 0xF88, MASKDWORD);
-	RXEVM_2 = (s8)((value32 & MASKBYTE2) >> 16);
-	RXEVM_2 /= 2;
+	pwdb = (u8)odm_get_bb_reg(dm, R_0xf90, MASKBYTE1);
+	sig_power = -110 + (pwdb >> 1);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d", "OFDM RX Signal Power(dB)", sig_power);
 
-	if (RXEVM_1 < -63)
-		RXEVM_1 = 0;
-	if (RXEVM_2 < -63)
-		RXEVM_2 = 0;
+	value32 = odm_get_bb_reg(dm, R_0xd14, MASKDWORD);
+	rx_snr[RF_PATH_A] = (u8)(value32 & 0xFF) >> 1; /*@ S(8,1)*/
+	rf_gain[RF_PATH_A] = (s8)(((value32 & MASKBYTE1) >> 8) * 2);
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d", "RXEVM (1ss/2ss/3ss)", RXEVM_0, RXEVM_1, RXEVM_2));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D, dB)", rx_snr_path_a, rx_snr_path_b, rx_snr_path_c, rx_snr_path_d));
+	value32 = odm_get_bb_reg(dm, R_0xd54, MASKDWORD);
+	rx_snr[RF_PATH_B] = (u8)(value32 & 0xFF) >> 1; /*@ S(8,1)*/
+	rf_gain[RF_PATH_B] = (s8)(((value32 & MASKBYTE1) >> 8) * 2);
 
-	value32 = odm_get_bb_reg(p_dm, 0xF8C, MASKDWORD);
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d", "CSI_1st /CSI_2nd", value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16)));
+	value32 = odm_get_bb_reg(dm, R_0xd94, MASKDWORD);
+	rx_snr[RF_PATH_C] = (u8)(value32 & 0xFF) >> 1; /*@ S(8,1)*/
+	rf_gain[RF_PATH_C] = (s8)(((value32 & MASKBYTE1) >> 8) * 2);
 
-	/*BW & mode Detection*/
+	value32 = odm_get_bb_reg(dm, R_0xdd4, MASKDWORD);
+	rx_snr[RF_PATH_D] = (u8)(value32 & 0xFF) >> 1; /*@ S(8,1)*/
+	rf_gain[RF_PATH_D] = (s8)(((value32 & MASKBYTE1) >> 8) * 2);
 
-	/*Reset Page F counter*/
-	odm_set_bb_reg(p_dm, 0xB58, BIT(0), 1);
-	odm_set_bb_reg(p_dm, 0xB58, BIT(0), 0);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d / %d / %d", "OFDM RX RF Gain(A/B/C/D)",
+		 rf_gain[RF_PATH_A], rf_gain[RF_PATH_B],
+		 rf_gain[RF_PATH_C], rf_gain[RF_PATH_D]);
 
-	/*CFO Report Info*/
-	/*Short CFO*/
-	value32 = odm_get_bb_reg(p_dm, 0xd0c, MASKDWORD);
-	value32_1 = odm_get_bb_reg(p_dm, 0xd4c, MASKDWORD);
-	value32_2 = odm_get_bb_reg(p_dm, 0xd8c, MASKDWORD);
-	value32_3 = odm_get_bb_reg(p_dm, 0xdcc, MASKDWORD);
+	/*@ [RX counter Info] ===============================================*/
 
-	SFO_A = (s32)(value32 & 0xfff);
-	SFO_B = (s32)(value32_1 & 0xfff);
-	SFO_C = (s32)(value32_2 & 0xfff);
-	SFO_D = (s32)(value32_3 & 0xfff);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d", "OFDM CCA cnt",
+		 odm_get_bb_reg(dm, R_0xf08, 0xFFFF0000));
 
-	LFO_A = (s32)(value32 >> 16);
-	LFO_B = (s32)(value32_1 >> 16);
-	LFO_C = (s32)(value32_2 >> 16);
-	LFO_D = (s32)(value32_3 >> 16);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d", "OFDM SBD Fail cnt",
+		 odm_get_bb_reg(dm, R_0xfd0, 0xFFFF));
 
-	/*SFO 2's to dec*/
-	if (SFO_A > 2047)
-		SFO_A = SFO_A - 4096;
-	SFO_A = (SFO_A * 312500) / 2048;
-	if (SFO_B > 2047)
-		SFO_B = SFO_B - 4096;
-	SFO_B = (SFO_B * 312500) / 2048;
-	if (SFO_C > 2047)
-		SFO_C = SFO_C - 4096;
-	SFO_C = (SFO_C * 312500) / 2048;
-	if (SFO_D > 2047)
-		SFO_D = SFO_D - 4096;
-	SFO_D = (SFO_D * 312500) / 2048;
-
-	/*LFO 2's to dec*/
-
-	if (LFO_A > 4095)
-		LFO_A = LFO_A - 8192;
-
-	if (LFO_B > 4095)
-		LFO_B = LFO_B - 8192;
-
-	if (LFO_C > 4095)
-		LFO_C = LFO_C - 8192;
-
-	if (LFO_D > 4095)
-		LFO_D = LFO_D - 8192;
-	LFO_A = LFO_A * 312500 / 4096;
-	LFO_B = LFO_B * 312500 / 4096;
-	LFO_C = LFO_C * 312500 / 4096;
-	LFO_D = LFO_D * 312500 / 4096;
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "CFO Report Info"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d /%d", "Short CFO(Hz) <A/B/C/D>", SFO_A, SFO_B, SFO_C, SFO_D));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d /%d", "Long CFO(Hz) <A/B/C/D>", LFO_A, LFO_B, LFO_C, LFO_D));
+	value32 = odm_get_bb_reg(dm, R_0xfc4, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "VHT SIGA/SIGB CRC8 Fail cnt",
+		 value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16));
 
-	/*SCFO*/
-	value32 = odm_get_bb_reg(p_dm, 0xd10, MASKDWORD);
-	value32_1 = odm_get_bb_reg(p_dm, 0xd50, MASKDWORD);
-	value32_2 = odm_get_bb_reg(p_dm, 0xd90, MASKDWORD);
-	value32_3 = odm_get_bb_reg(p_dm, 0xdd0, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d", "CCK CCA cnt",
+		 odm_get_bb_reg(dm, R_0xfcc, 0xFFFF));
 
-	SFO_A = (s32)(value32 & 0x7ff);
-	SFO_B = (s32)(value32_1 & 0x7ff);
-	SFO_C = (s32)(value32_2 & 0x7ff);
-	SFO_D = (s32)(value32_3 & 0x7ff);
+	value32 = odm_get_bb_reg(dm, R_0xfbc, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d",
+		 "LSIG (parity Fail/rate Illegal) cnt", value32 & 0xFFFF,
+		 ((value32 & 0xFFFF0000) >> 16));
 
-	if (SFO_A > 1023)
-		SFO_A = SFO_A - 2048;
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "HT/VHT MCS NOT SUPPORT cnt",
+		 odm_get_bb_reg(dm, R_0xfc0, (0xFFFF0000 >> 16)),
+		 odm_get_bb_reg(dm, R_0xfc8, 0xFFFF));
 
-	if (SFO_B > 2047)
-		SFO_B = SFO_B - 4096;
+	/*@ [PostFFT Info] =================================================*/
+	value32 = odm_get_bb_reg(dm, R_0xf8c, MASKDWORD);
+	rxevm_0 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_0 /= 2;
+	if (rxevm_0 < -63)
+		rxevm_0 = 0;
 
-	if (SFO_C > 2047)
-		SFO_C = SFO_C - 4096;
+	rxevm_1 = (s8)((value32 & MASKBYTE3) >> 24);
+	rxevm_1 /= 2;
+	value32 = odm_get_bb_reg(dm, R_0xf88, MASKDWORD);
+	rxevm_2 = (s8)((value32 & MASKBYTE2) >> 16);
+	rxevm_2 /= 2;
 
-	if (SFO_D > 2047)
-		SFO_D = SFO_D - 4096;
+	if (rxevm_1 < -63)
+		rxevm_1 = 0;
+	if (rxevm_2 < -63)
+		rxevm_2 = 0;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d / %d", "RXEVM (1ss/2ss/3ss)", rxevm_0,
+		 rxevm_1, rxevm_2);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d / %d / %d", "RXSNR(A/B/C/D dB)",
+		 rx_snr[RF_PATH_A], rx_snr[RF_PATH_B],
+		 rx_snr[RF_PATH_C], rx_snr[RF_PATH_D]);
+
+	value32 = odm_get_bb_reg(dm, R_0xf8c, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "CSI_1st /CSI_2nd", value32 & 0xFFFF,
+		 ((value32 & 0xFFFF0000) >> 16));
+
+	/*@ [CFO Report Info] ===============================================*/
+	phydm_get_cfo_info(dm, &cfo);
+	for (i = 0; i < dm->num_rf_path; i++) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %s[%d] %-28s = {%d, %d, %d, %d, %d}",
+			 "CFO", i, "{S, L, Sec, Acq, End}",
+			 cfo.cfo_rpt_s[i], cfo.cfo_rpt_l[i], cfo.cfo_rpt_sec[i],
+			 cfo.cfo_rpt_acq[i], cfo.cfo_rpt_end[i]);
+	}
 
-	SFO_A = SFO_A * 312500 / 1024;
-	SFO_B = SFO_B * 312500 / 1024;
-	SFO_C = SFO_C * 312500 / 1024;
-	SFO_D = SFO_D * 312500 / 1024;
+	/*@ [L-SIG Content] =================================================*/
+	value32 = odm_get_bb_reg(dm, R_0xf20, MASKDWORD);
+
+	tail = (u8)((value32 & 0xfc0000) >> 18);/*@[23:18]*/
+	parity = (u8)((value32 & 0x20000) >> 17);/*@[17]*/
+	length = (u16)((value32 & 0x1ffe0) >> 5);/*@[16:5]*/
+	rsv = (u8)((value32 & 0x10) >> 4);/*@[4]*/
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\r\n %-35s",
+		 "L-SIG");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d M", "rate",
+		 phydm_get_l_sig_rate(dm, (u8)(value32 & 0x0f)));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %x / %d / %d", "Rsv/length/parity", rsv, length,
+		 parity);
+
+	if (rx_ht == AD_HT_MODE) {
+	/*@ [HT SIG 1] ======================================================*/
+		value32 = odm_get_bb_reg(dm, R_0xf2c, MASKDWORD);
+
+		hmcss = (u8)(value32 & 0x7F);
+		hrx_bw = (u8)((value32 & 0x80) >> 7);
+		h_length = (u16)((value32 & 0x0fff00) >> 8);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s", "HT-SIG1");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %d / %d / %d", "MCS/BW/length",
+			 hmcss, hrx_bw, h_length);
+	/*@ [HT SIG 2] ======================================================*/
+		value32 = odm_get_bb_reg(dm, R_0xf30, MASKDWORD);
+		smooth = (u8)(value32 & 0x01);
+		htsound = (u8)((value32 & 0x02) >> 1);
+		rsv = (u8)((value32 & 0x04) >> 2);
+		agg = (u8)((value32 & 0x08) >> 3);
+		stbc = (u8)((value32 & 0x30) >> 4);
+		fec = (u8)((value32 & 0x40) >> 6);
+		sgi = (u8)((value32 & 0x80) >> 7);
+		htltf = (u8)((value32 & 0x300) >> 8);
+		htcrc8 = (u16)((value32 & 0x3fc00) >> 10);
+		tail = (u8)((value32 & 0xfc0000) >> 18);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s",
+			 "HT-SIG2");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x / %x / %x",
+			 "Smooth/NoSound/Rsv/Aggregate/STBC/LDPC",
+			 smooth, htsound, rsv, agg, stbc, fec);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x",
+			 "SGI/E-HT-LTFs/CRC/tail",
+			 sgi, htltf, htcrc8, tail);
+	} else if (rx_ht == AD_VHT_MODE) {
+	/*@ [VHT SIG A1] ====================================================*/
+		value32 = odm_get_bb_reg(dm, R_0xf2c, MASKDWORD);
 
-	LFO_A = (s32)(value32 >> 16);
-	LFO_B = (s32)(value32_1 >> 16);
-	LFO_C = (s32)(value32_2 >> 16);
-	LFO_D = (s32)(value32_3 >> 16);
+		v_rx_bw = (u8)(value32 & 0x03);
+		vrsv = (u8)((value32 & 0x04) >> 2);
+		vstbc = (u8)((value32 & 0x08) >> 3);
+		vgid = (u8)((value32 & 0x3f0) >> 4);
+		v_nsts = (u8)(((value32 & 0x1c00) >> 10) + 1);
+		vpaid = (u16)((value32 & 0x3fe000) >> 13);
+		vtxops = (u8)((value32 & 0x400000) >> 22);
+		vrsv2 = (u8)((value32 & 0x800000) >> 23);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s",
+			 "VHT-SIG-A1");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x / %x",
+			 "BW/Rsv1/STBC/GID/Nsts/PAID/TXOPPS/Rsv2", v_rx_bw,
+			 vrsv, vstbc, vgid, v_nsts, vpaid, vtxops, vrsv2);
+
+	/*@ [VHT SIG A2] ====================================================*/
+		value32 = odm_get_bb_reg(dm, R_0xf30, MASKDWORD);
+
+		/* @sgi=(u8)(value32&0x01); */
+		sgiext = (u8)(value32 & 0x03);
+		/* @fec = (u8)(value32&0x04); */
+		fecext = (u8)((value32 & 0x0C) >> 2);
 
-	if (LFO_A > 4095)
-		LFO_A = LFO_A - 8192;
+		v_mcss = (u8)((value32 & 0xf0) >> 4);
+		bf = (u8)((value32 & 0x100) >> 8);
+		vrsv = (u8)((value32 & 0x200) >> 9);
+		vhtcrc8 = (u16)((value32 & 0x3fc00) >> 10);
+		v_tail = (u8)((value32 & 0xfc0000) >> 18);
 
-	if (LFO_B > 4095)
-		LFO_B = LFO_B - 8192;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s", "VHT-SIG-A2");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x",
+			 "SGI/FEC/MCS/BF/Rsv/CRC/tail",
+			 sgiext, fecext, v_mcss, bf, vrsv, vhtcrc8, v_tail);
 
-	if (LFO_C > 4095)
-		LFO_C = LFO_C - 8192;
+	/*@ [VHT SIG B] ====================================================*/
+		value32 = odm_get_bb_reg(dm, R_0xf34, MASKDWORD);
 
-	if (LFO_D > 4095)
-		LFO_D = LFO_D - 8192;
-	LFO_A = LFO_A * 312500 / 4096;
-	LFO_B = LFO_B * 312500 / 4096;
-	LFO_C = LFO_C * 312500 / 4096;
-	LFO_D = LFO_D * 312500 / 4096;
+		#if 0
+		v_length = (u16)(value32 & 0x1fffff);
+		vbrsv = (u8)((value32 & 0x600000) >> 21);
+		vb_tail = (u16)((value32 & 0x1f800000) >> 23);
+		vbcrc = (u8)((value32 & 0x80000000) >> 31);
+		#endif
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d /%d", "value SCFO(Hz) <A/B/C/D>", SFO_A, SFO_B, SFO_C, SFO_D));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d /%d", "ACQ CFO(Hz) <A/B/C/D>", LFO_A, LFO_B, LFO_C, LFO_D));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s", "VHT-SIG-B");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x",
+			 "Codeword", value32);
+
+		#if 0
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x",
+			 "length/Rsv/tail/CRC",
+			 v_length, vbrsv, vb_tail, vbcrc);
+		#endif
+	}
 
-	value32 = odm_get_bb_reg(p_dm, 0xd14, MASKDWORD);
-	value32_1 = odm_get_bb_reg(p_dm, 0xd54, MASKDWORD);
-	value32_2 = odm_get_bb_reg(p_dm, 0xd94, MASKDWORD);
-	value32_3 = odm_get_bb_reg(p_dm, 0xdd4, MASKDWORD);
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
 
-	LFO_A = (s32)(value32 >> 16);
-	LFO_B = (s32)(value32_1 >> 16);
-	LFO_C = (s32)(value32_2 >> 16);
-	LFO_D = (s32)(value32_3 >> 16);
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_bb_hw_dbg_info_jgr3(void *dm_void, u32 *_used, char *output,
+			       u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	char *tmp_string = NULL;
+	u8 rx_ht_bw = 0, rx_vht_bw = 0, rx_ht = 0;
+	static u8 v_rx_bw;
+	u32 value32 = 0;
+	u8 i = 0;
+	static u8 tail, parity, rsv, vrsv, smooth, htsound, agg;
+	static u8 stbc, vstbc, fec, fecext, sgi, sgiext, htltf, vgid, v_nsts;
+	static u8 vtxops, vrsv2, vbrsv, bf, vbcrc;
+	static u16 h_length, htcrc8, length;
+	static u16 vpaid;
+	static u16 v_length, vhtcrc8, v_mcss, v_tail, vb_tail;
+	static u8 hmcss, hrx_bw;
 
-	if (LFO_A > 4095)
-		LFO_A = LFO_A - 8192;
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\r\n %-35s\n",
+		 "BB Report Info");
 
-	if (LFO_B > 4095)
-		LFO_B = LFO_B - 8192;
+	/*@ [Mode] =====================================================*/
 
-	if (LFO_C > 4095)
-		LFO_C = LFO_C - 8192;
+	value32 = odm_get_bb_reg(dm, R_0x2c20, MASKDWORD);
+	rx_ht = (u8)((value32 & 0xC0000) >> 18);
+	if (rx_ht == AD_VHT_MODE)
+		tmp_string = "VHT";
+	else if (rx_ht == AD_HT_MODE)
+		tmp_string = "HT";
+	else
+		tmp_string = "Legacy";
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s %s", "mode", tmp_string);
+	/*@ [RX counter Info] ===============================================*/
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d", "CCK CCA cnt",
+		 odm_get_bb_reg(dm, R_0x2c08, 0xFFFF));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d", "OFDM CCA cnt",
+		 odm_get_bb_reg(dm, R_0x2c08, 0xFFFF0000));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d", "OFDM SBD Fail cnt",
+		 odm_get_bb_reg(dm, R_0x2d20, 0xFFFF0000));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d",
+		 "LSIG (parity Fail/rate Illegal) cnt",
+		 odm_get_bb_reg(dm, R_0x2d04, 0xFFFF0000),
+		 odm_get_bb_reg(dm, R_0x2d08, 0xFFFF));
+
+	value32 = odm_get_bb_reg(dm, R_0x2d10, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "HT/VHT MCS NOT SUPPORT cnt",
+		 value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16));
+
+	value32 = odm_get_bb_reg(dm, R_0x2d0c, MASKDWORD);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d / %d", "VHT SIGA/SIGB CRC8 Fail cnt",
+		 value32 & 0xFFFF, ((value32 & 0xFFFF0000) >> 16));
+	/*@ [L-SIG Content] =================================================*/
+	value32 = odm_get_bb_reg(dm, R_0x2c20, MASKDWORD);
+
+	parity = (u8)((value32 & 0x20000) >> 17);/*@[17]*/
+	length = (u16)((value32 & 0x1ffe0) >> 5);/*@[16:5]*/
+	rsv = (u8)((value32 & 0x10) >> 4);/*@[4]*/
+
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\r\n %-35s",
+		 "L-SIG");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %d M", "rate",
+		 phydm_get_l_sig_rate(dm, (u8)(value32 & 0x0f)));
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\r\n %-35s = %x / %d / %d", "Rsv/length/parity", rsv, length,
+		 parity);
+
+	if (rx_ht == AD_HT_MODE) {
+	/*@ [HT SIG 1] ======================================================*/
+		value32 = odm_get_bb_reg(dm, R_0x2c2c, MASKDWORD);
+
+		hmcss = (u8)(value32 & 0x7F);
+		hrx_bw = (u8)((value32 & 0x80) >> 7);
+		h_length = (u16)((value32 & 0x0fff00) >> 8);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s", "HT-SIG1");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %d / %d / %d", "MCS/BW/length",
+			 hmcss, hrx_bw, h_length);
+	/*@ [HT SIG 2] ======================================================*/
+		value32 = odm_get_bb_reg(dm, R_0x2c30, MASKDWORD);
+		smooth = (u8)(value32 & 0x01);
+		htsound = (u8)((value32 & 0x02) >> 1);
+		rsv = (u8)((value32 & 0x04) >> 2);
+		agg = (u8)((value32 & 0x08) >> 3);
+		stbc = (u8)((value32 & 0x30) >> 4);
+		fec = (u8)((value32 & 0x40) >> 6);
+		sgi = (u8)((value32 & 0x80) >> 7);
+		htltf = (u8)((value32 & 0x300) >> 8);
+		htcrc8 = (u16)((value32 & 0x3fc00) >> 10);
+		tail = (u8)((value32 & 0xfc0000) >> 18);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s",
+			 "HT-SIG2");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x / %x / %x",
+			 "Smooth/NoSound/Rsv/Aggregate/STBC/LDPC",
+			 smooth, htsound, rsv, agg, stbc, fec);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x",
+			 "SGI/E-HT-LTFs/CRC/tail",
+			 sgi, htltf, htcrc8, tail);
+	} else if (rx_ht == AD_VHT_MODE) {
+	/*@ [VHT SIG A1] ====================================================*/
+		value32 = odm_get_bb_reg(dm, R_0x2c2c, MASKDWORD);
 
-	if (LFO_D > 4095)
-		LFO_D = LFO_D - 8192;
+		v_rx_bw = (u8)(value32 & 0x03);
+		vrsv = (u8)((value32 & 0x04) >> 2);
+		vstbc = (u8)((value32 & 0x08) >> 3);
+		vgid = (u8)((value32 & 0x3f0) >> 4);
+		v_nsts = (u8)(((value32 & 0x1c00) >> 10) + 1);
+		vpaid = (u16)((value32 & 0x3fe000) >> 13);
+		vtxops = (u8)((value32 & 0x400000) >> 22);
+		vrsv2 = (u8)((value32 & 0x800000) >> 23);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s",
+			 "VHT-SIG-A1");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x / %x",
+			 "BW/Rsv1/STBC/GID/Nsts/PAID/TXOPPS/Rsv2", v_rx_bw,
+			 vrsv, vstbc, vgid, v_nsts, vpaid, vtxops, vrsv2);
+
+	/*@ [VHT SIG A2] ====================================================*/
+		value32 = odm_get_bb_reg(dm, R_0x2c30, MASKDWORD);
+
+		/* @sgi=(u8)(value32&0x01); */
+		sgiext = (u8)(value32 & 0x03);
+		/* @fec = (u8)(value32&0x04); */
+		fecext = (u8)((value32 & 0x0C) >> 2);
 
-	LFO_A = LFO_A * 312500 / 4096;
-	LFO_B = LFO_B * 312500 / 4096;
-	LFO_C = LFO_C * 312500 / 4096;
-	LFO_D = LFO_D * 312500 / 4096;
+		v_mcss = (u8)((value32 & 0xf0) >> 4);
+		bf = (u8)((value32 & 0x100) >> 8);
+		vrsv = (u8)((value32 & 0x200) >> 9);
+		vhtcrc8 = (u16)((value32 & 0x3fc00) >> 10);
+		v_tail = (u8)((value32 & 0xfc0000) >> 18);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s", "VHT-SIG-A2");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x",
+			 "SGI/FEC/MCS/BF/Rsv/CRC/tail",
+			 sgiext, fecext, v_mcss, bf, vrsv, vhtcrc8, v_tail);
+
+	/*@ [VHT SIG B] ====================================================*/
+		value32 = odm_get_bb_reg(dm, R_0x2c34, MASKDWORD);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s", "VHT-SIG-B");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x",
+			 "Codeword", value32);
+
+		if (v_rx_bw == 0) {
+			v_length = (u16)(value32 & 0x1ffff);
+			vbrsv = (u8)((value32 & 0xE0000) >> 17);
+			vb_tail = (u16)((value32 & 0x03F00000) >> 20);
+		} else if (v_rx_bw == 1) {
+			v_length = (u16)(value32 & 0x7FFFF);
+			vbrsv = (u8)((value32 & 0x180000) >> 19);
+			vb_tail = (u16)((value32 & 0x07E00000) >> 21);
+		} else if (v_rx_bw == 2) {
+			v_length = (u16)(value32 & 0x1fffff);
+			vbrsv = (u8)((value32 & 0x600000) >> 21);
+			vb_tail = (u16)((value32 & 0x1f800000) >> 23);
+		}
+		vbcrc = (u8)((value32 & 0x80000000) >> 31);
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d / %d / %d /%d", "End CFO(Hz) <A/B/C/D>", LFO_A, LFO_B, LFO_C, LFO_D));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "\r\n %-35s = %x / %x / %x / %x",
+			 "length/Rsv/tail/CRC",
+			 v_length, vbrsv, vb_tail, vbcrc);
+	}
 
-	value32 = odm_get_bb_reg(p_dm, 0xf20, MASKDWORD);  /*L SIG*/
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
 
-	tail = (u8)((value32 & 0xfc0000) >> 16);
-	parity = (u8)((value32 & 0x20000) >> 16);
-	length = (u16)((value32 & 0x1ffe00) >> 8);
-	rsv = (u8)(value32 & 0x10);
-	MCSS = (u8)(value32 & 0x0f);
+u8 phydm_get_l_sig_rate(void *dm_void, u8 rate_idx_l_sig)
+{
+	u8 rate_idx = 0xff;
 
-	switch (MCSS) {
+	switch (rate_idx_l_sig) {
 	case 0x0b:
-		idx = 0;
+		rate_idx = 6;
 		break;
 	case 0x0f:
-		idx = 1;
+		rate_idx = 9;
 		break;
 	case 0x0a:
-		idx = 2;
+		rate_idx = 12;
 		break;
 	case 0x0e:
-		idx = 3;
+		rate_idx = 18;
 		break;
 	case 0x09:
-		idx = 4;
+		rate_idx = 24;
+		break;
+	case 0x0d:
+		rate_idx = 36;
 		break;
 	case 0x08:
-		idx = 5;
+		rate_idx = 48;
 		break;
 	case 0x0c:
-		idx = 6;
+		rate_idx = 54;
 		break;
 	default:
-		idx = 6;
+		rate_idx = 0xff;
 		break;
-
 	}
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "L-SIG"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s : %s", "rate", L_rate[idx]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %x / %x / %x", "Rsv/length/parity", rsv, RX_BW, length));
+	return rate_idx;
+}
+
+void phydm_bb_hw_dbg_info(void *dm_void, char input[][16], u32 *_used,
+			  char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	switch (dm->ic_ip_series) {
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	case PHYDM_IC_N:
+		phydm_bb_hw_dbg_info_n(dm, &used, output, &out_len);
+		break;
+	#endif
 
-	value32 = odm_get_bb_reg(p_dm, 0xf2c, MASKDWORD);  /*HT SIG*/
-	if (RX_HT == 1) {
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	case PHYDM_IC_AC:
+		phydm_bb_hw_dbg_info_ac(dm, &used, output, &out_len);
+		phydm_reset_bb_hw_cnt(dm);
+		#if (RTL8822B_SUPPORT)
+		phydm_bb_hw_dbg_info_8822b(dm, &used, output, &out_len);
+		#endif
+		break;
+	#endif
 
-		HMCSS = (u8)(value32 & 0x7F);
-		HRX_BW = (u8)(value32 & 0x80);
-		h_length = (u16)((value32 >> 8) & 0xffff);
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	case PHYDM_IC_JGR3:
+		phydm_bb_hw_dbg_info_jgr3(dm, &used, output, &out_len);
+		phydm_reset_bb_hw_cnt(dm);
+		break;
+	#endif
+	default:
+		break;
 	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "HT-SIG1"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %x / %x / %x", "MCS/BW/length", HMCSS, HRX_BW, h_length));
 
-	value32 = odm_get_bb_reg(p_dm, 0xf30, MASKDWORD);  /*HT SIG*/
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif /*@#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
 
-	if (RX_HT == 1) {
-		smooth = (u8)(value32 & 0x01);
-		htsound = (u8)(value32 & 0x02);
-		rsv = (u8)(value32 & 0x04);
-		agg = (u8)(value32 & 0x08);
-		stbc = (u8)(value32 & 0x30);
-		fec = (u8)(value32 & 0x40);
-		sgi = (u8)(value32 & 0x80);
-		htltf = (u8)((value32 & 0x300) >> 8);
-		htcrc8 = (u16)((value32 & 0x3fc00) >> 8);
-		tail = (u8)((value32 & 0xfc0000) >> 16);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+
+void phydm_dm_summary_cli_win(void *dm_void, char *buf, u8 macid)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_cfo_track_struct *cfo_t = &dm->dm_cfo_track;
+	struct cmn_sta_info *sta = NULL;
+	struct ra_sta_info *ra = NULL;
+	struct dtp_info *dtp = NULL;
+	u64 comp = dm->support_ability;
+	u64 pause_comp = dm->pause_ability;
+
+	if (!dm->is_linked) {
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "[%s]No Link !!!\n", __func__);
+		RT_PRINT(buf);
+		return;
 	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "HT-SIG2"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %x / %x / %x / %x / %x / %x", "Smooth/NoSound/Rsv/Aggregate/STBC/LDPC", smooth, htsound, rsv, agg, stbc, fec));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %x / %x / %x / %x", "SGI/E-HT-LTFs/CRC/tail", sgi, htltf, htcrc8, tail));
 
-	value32 = odm_get_bb_reg(p_dm, 0xf2c, MASKDWORD);  /*VHT SIG A1*/
-	if (RX_HT == 2) {
-		/* value32 = odm_get_bb_reg(p_dm, 0xf2c,MASKDWORD);*/
-		v_rx_bw = (u8)(value32 & 0x03);
-		vrsv = (u8)(value32 & 0x04);
-		vstbc = (u8)(value32 & 0x08);
-		vgid = (u8)((value32 & 0x3f0) >> 4);
-		v_nsts = (u8)(((value32 & 0x1c00) >> 8) + 1);
-		vpaid = (u16)(value32 & 0x3fe);
-		vtxops = (u8)((value32 & 0x400000) >> 20);
-		vrsv2 = (u8)((value32 & 0x800000) >> 20);
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "00.(%s) %-12s: IGI=0x%x, Dyn_Rng=0x%x~0x%x, FA_th={%d,%d,%d}\n",
+		   ((comp & ODM_BB_DIG) ?
+		   ((pause_comp & ODM_BB_DIG) ? "P" : "V") : "."),
+		   "DIG",
+		   dig_t->cur_ig_value,
+		   dig_t->rx_gain_range_min, dig_t->rx_gain_range_max,
+		   dig_t->fa_th[0], dig_t->fa_th[1], dig_t->fa_th[2]);
+        RT_PRINT(buf);
+
+	sta = dm->phydm_sta_info[macid];
+	if (is_sta_active(sta)) {
+		RT_PRINT(buf);
+
+		ra = &sta->ra_info;
+		dtp = &sta->dtp_stat;
+
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "01.(%s) %-12s: rssi_lv=%d, mask=0x%llx\n",
+			   ((comp & ODM_BB_RA_MASK) ?
+			   ((pause_comp & ODM_BB_RA_MASK) ? "P" : "V") : "."),
+			   "RaMask",
+			   ra->rssi_level, ra->ramask);
+		RT_PRINT(buf);
+
+		#ifdef CONFIG_DYNAMIC_TX_TWR
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "02.(%s) %-12s: pwr_lv=%d\n",
+			   ((comp & ODM_BB_DYNAMIC_TXPWR) ?
+			   ((pause_comp & ODM_BB_DYNAMIC_TXPWR) ? "P" : "V") : "."),
+			   "DynTxPwr",
+			   dtp->sta_tx_high_power_lvl);
+		RT_PRINT(buf);
+		#endif
 	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "VHT-SIG-A1"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x / %x", "BW/Rsv1/STBC/GID/Nsts/PAID/TXOPPS/Rsv2", v_rx_bw, vrsv, vstbc, vgid, v_nsts, vpaid, vtxops, vrsv2));
 
-	value32 = odm_get_bb_reg(p_dm, 0xf30, MASKDWORD);  /*VHT SIG*/
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "05.(%s) %-12s: cck_pd_lv=%d\n",
+		   ((comp & ODM_BB_CCK_PD) ?
+		   ((pause_comp & ODM_BB_CCK_PD) ? "P" : "V") : "."),
+		   "CCK_PD", dm->dm_cckpd_table.cck_pd_lv);
+	RT_PRINT(buf);
+
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "06.(%s) %-12s: div_type=%d, curr_ant=%s\n",
+		   ((comp & ODM_BB_ANT_DIV) ?
+		   ((pause_comp & ODM_BB_ANT_DIV) ? "P" : "V") : "."),
+		   "ANT_DIV",
+		   dm->ant_div_type,
+		   (dm->dm_fat_table.rx_idle_ant == MAIN_ANT) ? "MAIN" : "AUX");
+	RT_PRINT(buf);
+#endif
 
-	if (RX_HT == 2) {
-		/*value32 = odm_get_bb_reg(p_dm, 0xf30,MASKDWORD); */  /*VHT SIG*/
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "08.(%s) %-12s: PT_score=%d, disable_PT=%d\n",
+		   ((comp & ODM_BB_PWR_TRAIN) ?
+		   ((pause_comp & ODM_BB_PWR_TRAIN) ? "P" : "V") : "."),
+		   "PwrTrain",
+		   dm->pow_train_table.pow_train_score,
+		   dm->is_disable_power_training);
+	RT_PRINT(buf);
+#endif
 
-		/* sgi=(u8)(value32&0x01); */
-		sgiext = (u8)(value32 & 0x03);
-		/* fec = (u8)(value32&0x04); */
-		fecext = (u8)(value32 & 0x0C);
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "11.(%s) %-12s: dbg_mode=%d, region_domain=%d\n",
+		   ((comp & ODM_BB_DFS) ?
+		   ((pause_comp & ODM_BB_DFS) ? "P" : "V") : "."),
+		   "DFS",
+		   dm->dfs.dbg_mode, dm->dfs_region_domain);
+	RT_PRINT(buf);
+#endif
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "13.(%s) %-12s: th{l2h, h2l}={%d, %d}, edcca_flag=%d\n",
+		   ((comp & ODM_BB_ADAPTIVITY) ?
+		   ((pause_comp & ODM_BB_ADAPTIVITY) ? "P" : "V") : "."),
+		   "Adaptivity",
+		   dm->adaptivity.th_l2h, dm->adaptivity.th_h2l,
+		   dm->false_alm_cnt.edcca_flag);
+	RT_PRINT(buf);
+#endif
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "14.(%s) %-12s: CFO_avg=%d kHz, CFO_traking=%s%d\n",
+		   ((comp & ODM_BB_CFO_TRACKING) ?
+		   ((pause_comp & ODM_BB_CFO_TRACKING) ? "P" : "V") : "."),
+		   "CfoTrack",
+		   cfo_t->CFO_ave_pre,
+		   ((cfo_t->crystal_cap > cfo_t->def_x_cap) ? "+" : "-"),
+		   DIFF_2(cfo_t->crystal_cap, cfo_t->def_x_cap));
+	RT_PRINT(buf);
+
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "15.(%s) %-12s: ratio{nhm, clm}={%d, %d}\n",
+		   ((comp & ODM_BB_ENV_MONITOR) ?
+		   ((pause_comp & ODM_BB_ENV_MONITOR) ? "P" : "V") : "."),
+		   "EnvMntr",
+		   dm->dm_ccx_info.nhm_ratio, dm->dm_ccx_info.clm_ratio);
+	RT_PRINT(buf);
+#ifdef PHYDM_PRIMARY_CCA
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "16.(%s) %-12s: CCA @ (%s SB)\n",
+		   ((comp & ODM_BB_PRIMARY_CCA) ?
+		   ((pause_comp & ODM_BB_PRIMARY_CCA) ? "P" : "V") : "."),
+		   "PriCCA",
+		   ((dm->dm_pri_cca.mf_state == MF_USC_LSC) ? "D" :
+		   ((dm->dm_pri_cca.mf_state == MF_LSC) ? "L" : "U")));
+	RT_PRINT(buf);
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "17.(%s) %-12s: soml_en = %s\n",
+		   ((comp & ODM_BB_ADAPTIVE_SOML) ?
+		   ((pause_comp & ODM_BB_ADAPTIVE_SOML) ? "P" : "V") : "."),
+		   "A-SOML",
+		   (dm->dm_soml_table.soml_last_state == SOML_ON) ?
+		   "ON" : "OFF");
+	RT_PRINT(buf);
+#endif
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "18.(%s) %-12s:\n",
+		   ((comp & ODM_BB_LNA_SAT_CHK) ?
+		   ((pause_comp & ODM_BB_LNA_SAT_CHK) ? "P" : "V") : "."),
+		   "LNA_SAT_CHK");
+	RT_PRINT(buf);
+#endif
+}
 
-		v_mcss = (u8)(value32 & 0xf0);
-		bf = (u8)((value32 & 0x100) >> 8);
-		vrsv = (u8)((value32 & 0x200) >> 8);
-		vhtcrc8 = (u16)((value32 & 0x3fc00) >> 8);
-		v_tail = (u8)((value32 & 0xfc0000) >> 16);
-	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "VHT-SIG-A2"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %x / %x / %x / %x / %x / %x / %x", "SGI/FEC/MCS/BF/Rsv/CRC/tail", sgiext, fecext, v_mcss, bf, vrsv, vhtcrc8, v_tail));
+void phydm_basic_dbg_msg_cli_win(void *dm_void, char *buf)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+	struct phydm_cfo_track_struct *cfo_t = &dm->dm_cfo_track;
+	struct odm_phy_dbg_info *dbg = &dm->phy_dbg_info;
+	struct phydm_phystatus_statistic *dbg_s = &dbg->physts_statistic_info;
+	struct phydm_phystatus_avg *dbg_avg = &dbg->phystatus_statistic_avg;
+	u8 macid, target_macid = 0;
+	u8 i = 0;
+	u8 rate_num = dm->num_rf_path;
+	u8 ss_ofst = 0;
+	struct cmn_sta_info *entry = NULL;
+	char dbg_buf[PHYDM_SNPRINT_SIZE] = {0};
+
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n PHYDM Common Dbg Msg --------->");
+	RT_PRINT(buf);
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n System up time=%d", dm->phydm_sys_up_time);
+	RT_PRINT(buf);
+
+	if (dm->is_linked) {
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n ID=((%d)), BW=((%d)), fc=((CH-%d))",
+			   dm->curr_station_id, 20 << *dm->band_width, *dm->channel);
+		RT_PRINT(buf);
+
+		if (((*dm->channel <= 14) && (*dm->band_width == CHANNEL_WIDTH_40)) &&
+		    (dm->support_ic_type & ODM_IC_11N_SERIES)) {
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n Primary CCA at ((%s SB))",
+				   (*dm->sec_ch_offset == SECOND_CH_AT_LSB) ? "U" : "L");
+			RT_PRINT(buf);
+		}
 
-	value32 = odm_get_bb_reg(p_dm, 0xf34, MASKDWORD);  /*VHT SIG*/
-	{
-		v_length = (u16)(value32 & 0x1fffff);
-		vbrsv = (u8)((value32 & 0x600000) >> 20);
-		vb_tail = (u16)((value32 & 0x1f800000) >> 20);
-		vbcrc = (u8)((value32 & 0x80000000) >> 28);
+		if ((dm->support_ic_type & PHYSTS_2ND_TYPE_IC) || dm->rx_rate > ODM_RATE11M) {
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n [AGC Idx] {0x%x, 0x%x, 0x%x, 0x%x}",
+				   dm->ofdm_agc_idx[0], dm->ofdm_agc_idx[1],
+				   dm->ofdm_agc_idx[2], dm->ofdm_agc_idx[3]);
+			RT_PRINT(buf);
+		} else {
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n [CCK AGC Idx] {LNA,VGA}={0x%x, 0x%x}",
+				   dm->cck_lna_idx, dm->cck_vga_idx);
+			RT_PRINT(buf);
+		}
 
-	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s", "VHT-SIG-B"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %x / %x / %x / %x", "length/Rsv/tail/CRC", v_length, vbrsv, vb_tail, vbcrc));
+		phydm_print_rate_2_buff(dm, dm->rx_rate, dbg_buf, PHYDM_SNPRINT_SIZE);
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n RSSI:{%d, %d, %d, %d}, RxRate:%s (0x%x)",
+			   (dm->rssi_a == 0xff) ? 0 : dm->rssi_a,
+			   (dm->rssi_b == 0xff) ? 0 : dm->rssi_b,
+			   (dm->rssi_c == 0xff) ? 0 : dm->rssi_c,
+			   (dm->rssi_d == 0xff) ? 0 : dm->rssi_d,
+			  dbg_buf, dm->rx_rate);
+		RT_PRINT(buf);
+
+		phydm_print_rate_2_buff(dm, dm->phy_dbg_info.beacon_phy_rate, dbg_buf, PHYDM_SNPRINT_SIZE);
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n Beacon_cnt=%d, rate_idx:%s (0x%x)",
+			   dm->phy_dbg_info.beacon_cnt_in_period,
+			   dbg_buf,
+			   dm->phy_dbg_info.beacon_phy_rate);
+		RT_PRINT(buf);
+
+		/*Show phydm_rx_rate_distribution;*/
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n [RxRate Cnt] =============>");
+		RT_PRINT(buf);
+
+		/*@======CCK=================================================*/
+		if (*dm->channel <= 14) {
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * CCK = {%d, %d, %d, %d}",
+				   dbg->num_qry_legacy_pkt[0], dbg->num_qry_legacy_pkt[1],
+				   dbg->num_qry_legacy_pkt[2], dbg->num_qry_legacy_pkt[3]);
+			RT_PRINT(buf);
+		}
+		/*@======OFDM================================================*/
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * OFDM = {%d, %d, %d, %d, %d, %d, %d, %d}",
+			   dbg->num_qry_legacy_pkt[4], dbg->num_qry_legacy_pkt[5],
+			   dbg->num_qry_legacy_pkt[6], dbg->num_qry_legacy_pkt[7],
+			   dbg->num_qry_legacy_pkt[8], dbg->num_qry_legacy_pkt[9],
+			   dbg->num_qry_legacy_pkt[10], dbg->num_qry_legacy_pkt[11]);
+		RT_PRINT(buf);
+
+		/*@======HT==================================================*/
+		if (dbg->ht_pkt_not_zero) {
+			for (i = 0; i < rate_num; i++) {
+				ss_ofst = (i << 3);
+
+				RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}",
+					   (ss_ofst), (ss_ofst + 7),
+					   dbg->num_qry_ht_pkt[ss_ofst + 0], dbg->num_qry_ht_pkt[ss_ofst + 1],
+					   dbg->num_qry_ht_pkt[ss_ofst + 2], dbg->num_qry_ht_pkt[ss_ofst + 3],
+					   dbg->num_qry_ht_pkt[ss_ofst + 4], dbg->num_qry_ht_pkt[ss_ofst + 5],
+					   dbg->num_qry_ht_pkt[ss_ofst + 6], dbg->num_qry_ht_pkt[ss_ofst + 7]);
+				RT_PRINT(buf);
+			}
 
-	/*for Condition number*/
-	if (p_dm->support_ic_type & ODM_RTL8822B) {
-		s32	condition_num = 0;
-		char *factor = NULL;
+			if (dbg->low_bw_20_occur) {
+				for (i = 0; i < rate_num; i++) {
+					ss_ofst = (i << 3);
+
+					RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * [Low BW 20M] HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}",
+						   (ss_ofst), (ss_ofst + 7),
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 0], dbg->num_qry_pkt_sc_20m[ss_ofst + 1],
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 2], dbg->num_qry_pkt_sc_20m[ss_ofst + 3],
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 4], dbg->num_qry_pkt_sc_20m[ss_ofst + 5],
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 6], dbg->num_qry_pkt_sc_20m[ss_ofst + 7]);
+					RT_PRINT(buf);
+				}
+			}
+		}
 
-		odm_set_bb_reg(p_dm, 0x1988, BIT(22), 0x1);	/*enable report condition number*/
+#if (ODM_IC_11AC_SERIES_SUPPORT || defined(PHYDM_IC_JGR3_SERIES_SUPPORT))
+		/*@======VHT=================================================*/
+		if (dbg->vht_pkt_not_zero) {
+			for (i = 0; i < rate_num; i++) {
+				ss_ofst = 10 * i;
+
+				RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}",
+					   (i + 1),
+					   dbg->num_qry_vht_pkt[ss_ofst + 0], dbg->num_qry_vht_pkt[ss_ofst + 1],
+					   dbg->num_qry_vht_pkt[ss_ofst + 2], dbg->num_qry_vht_pkt[ss_ofst + 3],
+					   dbg->num_qry_vht_pkt[ss_ofst + 4], dbg->num_qry_vht_pkt[ss_ofst + 5],
+					   dbg->num_qry_vht_pkt[ss_ofst + 6], dbg->num_qry_vht_pkt[ss_ofst + 7],
+					   dbg->num_qry_vht_pkt[ss_ofst + 8], dbg->num_qry_vht_pkt[ss_ofst + 9]);
+				RT_PRINT(buf);
+			}
 
-		condition_num = odm_get_bb_reg(p_dm, 0xf84, MASKDWORD);
-		condition_num = (condition_num & 0x3ffff) >> 4;
+			if (dbg->low_bw_20_occur) {
+				for (i = 0; i < rate_num; i++) {
+					ss_ofst = 10 * i;
+
+					RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n *[Low BW 20M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}",
+						   (i + 1),
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 0], dbg->num_qry_pkt_sc_20m[ss_ofst + 1],
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 2], dbg->num_qry_pkt_sc_20m[ss_ofst + 3],
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 4], dbg->num_qry_pkt_sc_20m[ss_ofst + 5],
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 6], dbg->num_qry_pkt_sc_20m[ss_ofst + 7],
+						   dbg->num_qry_pkt_sc_20m[ss_ofst + 8], dbg->num_qry_pkt_sc_20m[ss_ofst + 9]);
+					RT_PRINT(buf);
+				}
+			}
 
-		if (*p_dm->p_band_width == CHANNEL_WIDTH_80)
-			factor = "256/234";
-		else if (*p_dm->p_band_width == CHANNEL_WIDTH_40)
-			factor = "128/108";
-		else if (*p_dm->p_band_width == CHANNEL_WIDTH_20) {
-			if (RX_HT != 2 || RX_HT != 1)
-				factor = "64/52";	/*HT or VHT*/
-			else
-				factor = "64/48";	/*legacy*/
+			if (dbg->low_bw_40_occur) {
+				for (i = 0; i < rate_num; i++) {
+					ss_ofst = 10 * i;
+
+					RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n *[Low BW 40M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}",
+						   (i + 1),
+						   dbg->num_qry_pkt_sc_40m[ss_ofst + 0], dbg->num_qry_pkt_sc_40m[ss_ofst + 1],
+						   dbg->num_qry_pkt_sc_40m[ss_ofst + 2], dbg->num_qry_pkt_sc_40m[ss_ofst + 3],
+						   dbg->num_qry_pkt_sc_40m[ss_ofst + 4], dbg->num_qry_pkt_sc_40m[ss_ofst + 5],
+						   dbg->num_qry_pkt_sc_40m[ss_ofst + 6], dbg->num_qry_pkt_sc_40m[ss_ofst + 7],
+						   dbg->num_qry_pkt_sc_40m[ss_ofst + 8], dbg->num_qry_pkt_sc_40m[ss_ofst + 9]);
+					RT_PRINT(buf);
+				}
+			}
+		}
+#endif
+
+		phydm_reset_rx_rate_distribution(dm);
+
+		//1 Show phydm_avg_phystatus_val
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n [Avg PHY Statistic] ==============>");
+		RT_PRINT(buf);
+
+		phydm_reset_phystatus_avg(dm);
+
+		/*@CCK*/
+		dbg_avg->rssi_cck_avg = (u8)((dbg_s->rssi_cck_cnt != 0) ? (dbg_s->rssi_cck_sum / dbg_s->rssi_cck_cnt) : 0);
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * cck Cnt= ((%d)) RSSI:{%d}",
+			   dbg_s->rssi_cck_cnt, dbg_avg->rssi_cck_avg);
+		RT_PRINT(buf);
+
+		/*OFDM*/
+		if (dbg_s->rssi_ofdm_cnt != 0) {
+			dbg_avg->rssi_ofdm_avg = (u8)(dbg_s->rssi_ofdm_sum / dbg_s->rssi_ofdm_cnt);
+			dbg_avg->evm_ofdm_avg = (u8)(dbg_s->evm_ofdm_sum / dbg_s->rssi_ofdm_cnt);
+			dbg_avg->snr_ofdm_avg = (u8)(dbg_s->snr_ofdm_sum / dbg_s->rssi_ofdm_cnt);
+		}
+
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * ofdm Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}",
+			   dbg_s->rssi_ofdm_cnt, dbg_avg->rssi_ofdm_avg,
+			   dbg_avg->evm_ofdm_avg, dbg_avg->snr_ofdm_avg);
+		RT_PRINT(buf);
+
+		if (dbg_s->rssi_1ss_cnt != 0) {
+			dbg_avg->rssi_1ss_avg = (u8)(dbg_s->rssi_1ss_sum / dbg_s->rssi_1ss_cnt);
+			dbg_avg->evm_1ss_avg = (u8)(dbg_s->evm_1ss_sum / dbg_s->rssi_1ss_cnt);
+			dbg_avg->snr_1ss_avg = (u8)(dbg_s->snr_1ss_sum / dbg_s->rssi_1ss_cnt);
+		}
+
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * 1-ss Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}",
+			   dbg_s->rssi_1ss_cnt, dbg_avg->rssi_1ss_avg,
+			   dbg_avg->evm_1ss_avg, dbg_avg->snr_1ss_avg);
+		RT_PRINT(buf);
+
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {
+			if (dbg_s->rssi_2ss_cnt != 0) {
+				dbg_avg->rssi_2ss_avg[0] = (u8)(dbg_s->rssi_2ss_sum[0] / dbg_s->rssi_2ss_cnt);
+				dbg_avg->rssi_2ss_avg[1] = (u8)(dbg_s->rssi_2ss_sum[1] / dbg_s->rssi_2ss_cnt);
+
+				dbg_avg->evm_2ss_avg[0] = (u8)(dbg_s->evm_2ss_sum[0] / dbg_s->rssi_2ss_cnt);
+				dbg_avg->evm_2ss_avg[1] = (u8)(dbg_s->evm_2ss_sum[1] / dbg_s->rssi_2ss_cnt);
+
+				dbg_avg->snr_2ss_avg[0] = (u8)(dbg_s->snr_2ss_sum[0] / dbg_s->rssi_2ss_cnt);
+				dbg_avg->snr_2ss_avg[1] = (u8)(dbg_s->snr_2ss_sum[1] / dbg_s->rssi_2ss_cnt);
+			}
+
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * 2-ss Cnt= ((%d)) RSSI:{%d, %d}, EVM:{%d, %d}, SNR:{%d, %d}",
+				   dbg_s->rssi_2ss_cnt, dbg_avg->rssi_2ss_avg[0],
+				   dbg_avg->rssi_2ss_avg[1], dbg_avg->evm_2ss_avg[0],
+				   dbg_avg->evm_2ss_avg[1], dbg_avg->snr_2ss_avg[0],
+				   dbg_avg->snr_2ss_avg[1]);
+			RT_PRINT(buf);
+		}
+#endif
+
+#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+		if (dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
+			if (dbg_s->rssi_3ss_cnt != 0) {
+				dbg_avg->rssi_3ss_avg[0] = (u8)(dbg_s->rssi_3ss_sum[0] / dbg_s->rssi_3ss_cnt);
+				dbg_avg->rssi_3ss_avg[1] = (u8)(dbg_s->rssi_3ss_sum[1] / dbg_s->rssi_3ss_cnt);
+				dbg_avg->rssi_3ss_avg[2] = (u8)(dbg_s->rssi_3ss_sum[2] / dbg_s->rssi_3ss_cnt);
+
+				dbg_avg->evm_3ss_avg[0] = (u8)(dbg_s->evm_3ss_sum[0] / dbg_s->rssi_3ss_cnt);
+				dbg_avg->evm_3ss_avg[1] = (u8)(dbg_s->evm_3ss_sum[1] / dbg_s->rssi_3ss_cnt);
+				dbg_avg->evm_3ss_avg[2] = (u8)(dbg_s->evm_3ss_sum[2] / dbg_s->rssi_3ss_cnt);
+
+				dbg_avg->snr_3ss_avg[0] = (u8)(dbg_s->snr_3ss_sum[0] / dbg_s->rssi_3ss_cnt);
+				dbg_avg->snr_3ss_avg[1] = (u8)(dbg_s->snr_3ss_sum[1] / dbg_s->rssi_3ss_cnt);
+				dbg_avg->snr_3ss_avg[2] = (u8)(dbg_s->snr_3ss_sum[2] / dbg_s->rssi_3ss_cnt);
+			}
+
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * 3-ss Cnt= ((%d)) RSSI:{%d, %d, %d} EVM:{%d, %d, %d} SNR:{%d, %d, %d}",
+				   dbg_s->rssi_3ss_cnt, dbg_avg->rssi_3ss_avg[0],
+				   dbg_avg->rssi_3ss_avg[1], dbg_avg->rssi_3ss_avg[2],
+				   dbg_avg->evm_3ss_avg[0], dbg_avg->evm_3ss_avg[1],
+				   dbg_avg->evm_3ss_avg[2], dbg_avg->snr_3ss_avg[0],
+				   dbg_avg->snr_3ss_avg[1], dbg_avg->snr_3ss_avg[2]);
+			RT_PRINT(buf);
+		}
+#endif
+
+#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+			if (dbg_s->rssi_4ss_cnt != 0) {
+				dbg_avg->rssi_4ss_avg[0] = (u8)(dbg_s->rssi_4ss_sum[0] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->rssi_4ss_avg[1] = (u8)(dbg_s->rssi_4ss_sum[1] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->rssi_4ss_avg[2] = (u8)(dbg_s->rssi_4ss_sum[2] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->rssi_4ss_avg[3] = (u8)(dbg_s->rssi_4ss_sum[3] / dbg_s->rssi_4ss_cnt);
+
+				dbg_avg->evm_4ss_avg[0] = (u8)(dbg_s->evm_4ss_sum[0] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->evm_4ss_avg[1] = (u8)(dbg_s->evm_4ss_sum[1] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->evm_4ss_avg[2] = (u8)(dbg_s->evm_4ss_sum[2] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->evm_4ss_avg[3] = (u8)(dbg_s->evm_4ss_sum[3] / dbg_s->rssi_4ss_cnt);
+
+				dbg_avg->snr_4ss_avg[0] = (u8)(dbg_s->snr_4ss_sum[0] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->snr_4ss_avg[1] = (u8)(dbg_s->snr_4ss_sum[1] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->snr_4ss_avg[2] = (u8)(dbg_s->snr_4ss_sum[2] / dbg_s->rssi_4ss_cnt);
+				dbg_avg->snr_4ss_avg[3] = (u8)(dbg_s->snr_4ss_sum[3] / dbg_s->rssi_4ss_cnt);
+			}
+
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n * 4-ss Cnt= ((%d)) RSSI:{%d, %d, %d, %d} EVM:{%d, %d, %d, %d} SNR:{%d, %d, %d, %d}",
+				   dbg_s->rssi_4ss_cnt, dbg_avg->rssi_4ss_avg[0],
+				   dbg_avg->rssi_4ss_avg[1], dbg_avg->rssi_4ss_avg[2],
+				   dbg_avg->rssi_4ss_avg[3], dbg_avg->evm_4ss_avg[0],
+				   dbg_avg->evm_4ss_avg[1], dbg_avg->evm_4ss_avg[2],
+				   dbg_avg->evm_4ss_avg[3], dbg_avg->snr_4ss_avg[0],
+				   dbg_avg->snr_4ss_avg[1], dbg_avg->snr_4ss_avg[2],
+				   dbg_avg->snr_4ss_avg[3]);
+			RT_PRINT(buf);
+		}
+#endif
+		phydm_reset_phystatus_statistic(dm);
+		/*@----------------------------------------------------------*/
+
+		/*Print TX rate*/
+		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+			entry = dm->phydm_sta_info[macid];
+
+			if (is_sta_active(entry)) {
+				phydm_print_rate_2_buff(dm, entry->ra_info.curr_tx_rate, dbg_buf, PHYDM_SNPRINT_SIZE);
+				RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n TxRate[%d]=%s (0x%x)", macid, dbg_buf, entry->ra_info.curr_tx_rate);
+				RT_PRINT(buf);
+				target_macid = macid;
+				break;
+			}
+		}
+
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE,
+			   "\r\n TP {Tx, Rx, Total} = {%d, %d, %d}Mbps, Traffic_Load=(%d))",
+			   dm->tx_tp, dm->rx_tp, dm->total_tp, dm->traffic_load);
+		RT_PRINT(buf);
+
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n CFO_avg=((%d kHz)), CFO_traking = ((%s%d))",
+			   cfo_t->CFO_ave_pre,
+			   ((cfo_t->crystal_cap > cfo_t->def_x_cap) ? "+" : "-"),
+			   DIFF_2(cfo_t->crystal_cap, cfo_t->def_x_cap));
+		RT_PRINT(buf);
+
+		/* @Condition number */
+		#if (RTL8822B_SUPPORT)
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n Condi_Num=((%d.%.4d))",
+				   dm->phy_dbg_info.condi_num >> 4,
+				   phydm_show_fraction_num(dm->phy_dbg_info.condi_num & 0xf, 4));
+			RT_PRINT(buf);
 		}
+		#endif
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = %d (factor = %s)", "Condition number", condition_num, factor));
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT || defined(PHYSTS_3RD_TYPE_SUPPORT))
+		/*STBC or LDPC pkt*/
+		if (dm->support_ic_type & (PHYSTS_2ND_TYPE_IC |
+					   PHYSTS_3RD_TYPE_IC))
+			RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n Coding: LDPC=((%s)), STBC=((%s))",
+				   (dm->phy_dbg_info.is_ldpc_pkt) ? "Y" : "N",
+				   (dm->phy_dbg_info.is_stbc_pkt) ? "Y" : "N");
+			RT_PRINT(buf);
+#endif
 
+	} else {
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n No Link !!!");
+		RT_PRINT(buf);
 	}
-	*_used = used;
-	*_out_len = out_len;
 
-}
-#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n [CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}",
+		   fa_t->cnt_cck_cca, fa_t->cnt_ofdm_cca, fa_t->cnt_cca_all);
+	RT_PRINT(buf);
+
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE, "\r\n [FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}",
+		   fa_t->cnt_cck_fail, fa_t->cnt_ofdm_fail, fa_t->cnt_all);
+	RT_PRINT(buf);
+
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE,
+			   "\r\n [OFDM FA Detail] Parity_Fail=%d, Rate_Illegal=%d, CRC8=%d, MCS_fail=%d, Fast_sync=%d, SB_Search_fail=%d",
+			   fa_t->cnt_parity_fail, fa_t->cnt_rate_illegal,
+			   fa_t->cnt_crc8_fail, fa_t->cnt_mcs_fail,
+			   fa_t->cnt_fast_fsync, fa_t->cnt_sb_search_fail);
+		RT_PRINT(buf);
+	}
+	#endif
+	RT_SPRINTF(buf, DBGM_CLI_BUF_SIZE,
+		   "\r\n is_linked = %d, Num_client = %d, rssi_min = %d, IGI = 0x%x, bNoisy=%d",
+		   dm->is_linked, dm->number_linked_client, dm->rssi_min,
+		   dm->dm_dig_table.cur_ig_value, dm->noisy_decision);
+	RT_PRINT(buf);
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	phydm_dm_summary_cli_win(dm, buf, target_macid);
+}
 
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
 void phydm_sbd_check(
-	struct PHY_DM_STRUCT					*p_dm
-)
+	struct dm_struct *dm)
 {
-	static u32	pkt_cnt = 0;
-	static boolean sbd_state = 0;
-	u32	sym_count, count, value32;
+	static u32 pkt_cnt;
+	static boolean sbd_state;
+	u32 sym_count, count, value32;
 
 	if (sbd_state == 0) {
 		pkt_cnt++;
-		if (pkt_cnt % 5 == 0) { /*read SBD conter once every 5 packets*/
-			odm_set_timer(p_dm, &p_dm->sbdcnt_timer, 0); /*ms*/
+		/*read SBD conter once every 5 packets*/
+		if (pkt_cnt % 5 == 0) {
+			odm_set_timer(dm, &dm->sbdcnt_timer, 0); /*@ms*/
 			sbd_state = 1;
 		}
 	} else { /*read counter*/
-		value32 = odm_get_bb_reg(p_dm, 0xF98, MASKDWORD);
+		value32 = odm_get_bb_reg(dm, R_0xf98, MASKDWORD);
 		sym_count = (value32 & 0x7C000000) >> 26;
 		count = (value32 & 0x3F00000) >> 20;
-		dbg_print("#SBD#    sym_count   %d   count   %d\n", sym_count, count);
+		pr_debug("#SBD# sym_count %d count %d\n", sym_count, count);
 		sbd_state = 0;
 	}
 }
 #endif
 
 void phydm_sbd_callback(
-	struct timer_list		*p_timer
-)
+	struct phydm_timer_list *timer)
 {
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-	struct _ADAPTER		*adapter = (struct _ADAPTER *)p_timer->Adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	void *adapter = timer->Adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 
-	#if USE_WORKITEM
-	odm_schedule_work_item(&p_dm->sbdcnt_workitem);
-	#else
-	phydm_sbd_check(p_dm);
-	#endif
+#if USE_WORKITEM
+	odm_schedule_work_item(&dm->sbdcnt_workitem);
+#else
+	phydm_sbd_check(dm);
+#endif
 #endif
 }
 
 void phydm_sbd_workitem_callback(
-	void            *p_context
-)
+	void *context)
 {
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-	struct _ADAPTER	*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 
-	phydm_sbd_check(p_dm);
+	phydm_sbd_check(dm);
 #endif
 }
 #endif
 
-void
-phydm_reset_rx_rate_distribution(
-	struct PHY_DM_STRUCT	*p_dm_odm
-)
+void phydm_reset_rx_rate_distribution(struct dm_struct *dm)
 {
-	struct _odm_phy_dbg_info_		*p_dbg = &(p_dm_odm->phy_dbg_info);
-
-	odm_memory_set(p_dm_odm, &(p_dbg->num_qry_legacy_pkt[0]), 0, (LEGACY_RATE_NUM * 2));
-	odm_memory_set(p_dm_odm, &(p_dbg->num_qry_ht_pkt[0]), 0, (HT_RATE_NUM * 2));
-	p_dbg->ht_pkt_not_zero = false;
-	
-#if	ODM_IC_11AC_SERIES_SUPPORT
-	odm_memory_set(p_dm_odm, &(p_dbg->num_qry_vht_pkt[0]), 0, (VHT_RATE_NUM * 2));
-	p_dbg->vht_pkt_not_zero = false;
+	struct odm_phy_dbg_info *dbg = &dm->phy_dbg_info;
+
+	odm_memory_set(dm, &dbg->num_qry_legacy_pkt[0], 0,
+		       (LEGACY_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_ht_pkt[0], 0,
+		       (HT_RATE_NUM * 2));
+	odm_memory_set(dm, &dbg->num_qry_pkt_sc_20m[0], 0,
+		       (LOW_BW_RATE_NUM * 2));
+
+	dbg->ht_pkt_not_zero = false;
+	dbg->low_bw_20_occur = false;
+
+#if (ODM_IC_11AC_SERIES_SUPPORT || defined(PHYDM_IC_JGR3_SERIES_SUPPORT))
+	odm_memory_set(dm, &dbg->num_qry_vht_pkt[0], 0, VHT_RATE_NUM * 2);
+	odm_memory_set(dm, &dbg->num_qry_pkt_sc_40m[0], 0, LOW_BW_RATE_NUM * 2);
+	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1) || (defined(PHYSTS_3RD_TYPE_SUPPORT))
+	odm_memory_set(dm, &dbg->num_mu_vht_pkt[0], 0, VHT_RATE_NUM * 2);
+	#endif
+	dbg->vht_pkt_not_zero = false;
+	dbg->low_bw_40_occur = false;
 #endif
 }
 
-void
-phydm_rx_rate_distribution
-(
-	void			*p_dm_void
-)
+void phydm_rx_rate_distribution(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _odm_phy_dbg_info_		*p_dbg = &(p_dm->phy_dbg_info);
-	u8	i = 0, j = 0;
-	u8	rate_num = 1, rate_ss_shift = 0;
-
-	if (p_dm->support_ic_type & ODM_IC_4SS)
-		rate_num = 4;
-	else if (p_dm->support_ic_type & ODM_IC_3SS)
-		rate_num = 3;
-	else if (p_dm->support_ic_type & ODM_IC_2SS)
-		rate_num = 2;
-
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[RxRate Cnt] =============>\n"));
-
-	/*======CCK=============================================================*/
-	if (*(p_dm->p_channel) <= 14) {
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* CCK = {%d, %d, %d, %d}\n",
-			p_dbg->num_qry_legacy_pkt[0],
-			p_dbg->num_qry_legacy_pkt[1],
-			p_dbg->num_qry_legacy_pkt[2],
-			p_dbg->num_qry_legacy_pkt[3]
-			));
-	}
-	/*======OFDM============================================================*/
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* OFDM = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
-		p_dbg->num_qry_legacy_pkt[4], p_dbg->num_qry_legacy_pkt[5],
-		p_dbg->num_qry_legacy_pkt[6], p_dbg->num_qry_legacy_pkt[7],
-		p_dbg->num_qry_legacy_pkt[8], p_dbg->num_qry_legacy_pkt[9],
-		p_dbg->num_qry_legacy_pkt[10], p_dbg->num_qry_legacy_pkt[11]));
-
-	/*======HT==============================================================*/
-	if (p_dbg->ht_pkt_not_zero) {
-		
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg = &dm->phy_dbg_info;
+	u8 i = 0;
+	u8 rate_num = dm->num_rf_path, ss_ofst = 0;
+
+	PHYDM_DBG(dm, DBG_CMN, "[RxRate Cnt] =============>\n");
+
+	/*@======CCK=========================================================*/
+	if (*dm->channel <= 14) {
+		PHYDM_DBG(dm, DBG_CMN, "* CCK = {%d, %d, %d, %d}\n",
+			  dbg->num_qry_legacy_pkt[0],
+			  dbg->num_qry_legacy_pkt[1],
+			  dbg->num_qry_legacy_pkt[2],
+			  dbg->num_qry_legacy_pkt[3]);
+	}
+	/*@======OFDM========================================================*/
+	PHYDM_DBG(dm, DBG_CMN, "* OFDM = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+		  dbg->num_qry_legacy_pkt[4], dbg->num_qry_legacy_pkt[5],
+		  dbg->num_qry_legacy_pkt[6], dbg->num_qry_legacy_pkt[7],
+		  dbg->num_qry_legacy_pkt[8], dbg->num_qry_legacy_pkt[9],
+		  dbg->num_qry_legacy_pkt[10], dbg->num_qry_legacy_pkt[11]);
+
+	/*@======HT==========================================================*/
+	if (dbg->ht_pkt_not_zero) {
 		for (i = 0; i < rate_num; i++) {
-			
-			rate_ss_shift = (i << 3);
-			
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
-				(rate_ss_shift), (rate_ss_shift+7),
-				p_dbg->num_qry_ht_pkt[rate_ss_shift + 0], p_dbg->num_qry_ht_pkt[rate_ss_shift + 1],
-				p_dbg->num_qry_ht_pkt[rate_ss_shift + 2], p_dbg->num_qry_ht_pkt[rate_ss_shift + 3],
-				p_dbg->num_qry_ht_pkt[rate_ss_shift + 4], p_dbg->num_qry_ht_pkt[rate_ss_shift + 5],
-				p_dbg->num_qry_ht_pkt[rate_ss_shift + 6], p_dbg->num_qry_ht_pkt[rate_ss_shift + 7]));
+			ss_ofst = (i << 3);
+
+			PHYDM_DBG(dm, DBG_CMN,
+				  "* HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+				  (ss_ofst), (ss_ofst + 7),
+				  dbg->num_qry_ht_pkt[ss_ofst + 0],
+				  dbg->num_qry_ht_pkt[ss_ofst + 1],
+				  dbg->num_qry_ht_pkt[ss_ofst + 2],
+				  dbg->num_qry_ht_pkt[ss_ofst + 3],
+				  dbg->num_qry_ht_pkt[ss_ofst + 4],
+				  dbg->num_qry_ht_pkt[ss_ofst + 5],
+				  dbg->num_qry_ht_pkt[ss_ofst + 6],
+				  dbg->num_qry_ht_pkt[ss_ofst + 7]);
+		}
 
+		if (dbg->low_bw_20_occur) {
+			for (i = 0; i < rate_num; i++) {
+				ss_ofst = (i << 3);
+
+				PHYDM_DBG(dm, DBG_CMN,
+					  "* [Low BW 20M] HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+					  (ss_ofst), (ss_ofst + 7),
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 0],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 1],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 2],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 3],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 4],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 5],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 6],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 7]);
+			}
 		}
 	}
-	
-#if	ODM_IC_11AC_SERIES_SUPPORT
-	/*======VHT=============================================================*/
-	if (p_dbg->vht_pkt_not_zero){
-		
+
+#if (ODM_IC_11AC_SERIES_SUPPORT || defined(PHYDM_IC_JGR3_SERIES_SUPPORT))
+	/*@======VHT==========================================================*/
+	if (dbg->vht_pkt_not_zero) {
 		for (i = 0; i < rate_num; i++) {
-			
-			rate_ss_shift = 10 * i;
-			
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
-				(i + 1),
-				p_dbg->num_qry_vht_pkt[rate_ss_shift + 0], p_dbg->num_qry_vht_pkt[rate_ss_shift + 1],
-				p_dbg->num_qry_vht_pkt[rate_ss_shift + 2], p_dbg->num_qry_vht_pkt[rate_ss_shift + 3],
-				p_dbg->num_qry_vht_pkt[rate_ss_shift + 4], p_dbg->num_qry_vht_pkt[rate_ss_shift + 5],
-				p_dbg->num_qry_vht_pkt[rate_ss_shift + 6], p_dbg->num_qry_vht_pkt[rate_ss_shift + 7],
-				p_dbg->num_qry_vht_pkt[rate_ss_shift + 8], p_dbg->num_qry_vht_pkt[rate_ss_shift + 9]));
+			ss_ofst = 10 * i;
+
+			PHYDM_DBG(dm, DBG_CMN,
+				  "* VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+				  (i + 1),
+				  dbg->num_qry_vht_pkt[ss_ofst + 0],
+				  dbg->num_qry_vht_pkt[ss_ofst + 1],
+				  dbg->num_qry_vht_pkt[ss_ofst + 2],
+				  dbg->num_qry_vht_pkt[ss_ofst + 3],
+				  dbg->num_qry_vht_pkt[ss_ofst + 4],
+				  dbg->num_qry_vht_pkt[ss_ofst + 5],
+				  dbg->num_qry_vht_pkt[ss_ofst + 6],
+				  dbg->num_qry_vht_pkt[ss_ofst + 7],
+				  dbg->num_qry_vht_pkt[ss_ofst + 8],
+				  dbg->num_qry_vht_pkt[ss_ofst + 9]);
+		}
+
+		if (dbg->low_bw_20_occur) {
+			for (i = 0; i < rate_num; i++) {
+				ss_ofst = 10 * i;
+
+				PHYDM_DBG(dm, DBG_CMN,
+					  "*[Low BW 20M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+					  (i + 1),
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 0],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 1],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 2],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 3],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 4],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 5],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 6],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 7],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 8],
+					  dbg->num_qry_pkt_sc_20m[ss_ofst + 9]);
+			}
+		}
 
+		if (dbg->low_bw_40_occur) {
+			for (i = 0; i < rate_num; i++) {
+				ss_ofst = 10 * i;
+
+				PHYDM_DBG(dm, DBG_CMN,
+					  "*[Low BW 40M] VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
+					  (i + 1),
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 0],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 1],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 2],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 3],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 4],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 5],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 6],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 7],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 8],
+					  dbg->num_qry_pkt_sc_40m[ss_ofst + 9]);
+			}
 		}
 	}
 #endif
-	
 }
 
-void
-phydm_get_avg_phystatus_val
-(
-	void		*p_dm_void
-)
+void phydm_print_hist_2_buf(void *dm_void, u16 *val, u16 len, char *buf,
+			    u16 buf_size)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_phystatus_statistic		*p_dbg_statistic = &(p_dm->phy_dbg_info.phystatus_statistic_info);
-	struct phydm_phystatus_avg		*p_dbg_avg = &(p_dm->phy_dbg_info.phystatus_statistic_avg);
-	
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[Avg PHY Statistic] ==============>\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (len == PHY_HIST_SIZE) {
+		PHYDM_SNPRINTF(buf, buf_size,
+			       "[%.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d]",
+			       val[0], val[1], val[2], val[3], val[4],
+			       val[5], val[6], val[7], val[8], val[9],
+			       val[10], val[11]);
+	} else if (len == (PHY_HIST_SIZE - 1)) {
+		PHYDM_SNPRINTF(buf, buf_size,
+			       "[%.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d, %.2d]",
+			       val[0], val[1], val[2], val[3], val[4],
+			       val[5], val[6], val[7], val[8], val[9],
+			       val[10]);
+	}
+}
 
-	phydm_reset_phystatus_avg(p_dm);
+void phydm_nss_hitogram(void *dm_void, enum PDM_RATE_TYPE rate_type)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	struct phydm_phystatus_statistic *dbg_s = &dbg_i->physts_statistic_info;
+	char buf[PHYDM_SNPRINT_SIZE] = {0};
+	u16 buf_size = PHYDM_SNPRINT_SIZE;
+	u16 h_size = PHY_HIST_SIZE;
+	u16 *evm_hist = &dbg_s->evm_1ss_hist[0];
+	u16 *snr_hist = &dbg_s->snr_1ss_hist[0];
+	u8 i = 0;
+	u8 ss = phydm_rate_type_2_num_ss(dm, rate_type);
+
+	for (i = 0; i < ss; i++) {
+		if (rate_type == PDM_1SS) {
+			evm_hist = &dbg_s->evm_1ss_hist[0];
+			snr_hist = &dbg_s->snr_1ss_hist[0];
+		} else if (rate_type == PDM_2SS) {
+			#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+			evm_hist = &dbg_s->evm_2ss_hist[i][0];
+			snr_hist = &dbg_s->snr_2ss_hist[i][0];
+			#endif
+		} else if (rate_type == PDM_3SS) {
+			#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+			evm_hist = &dbg_s->evm_3ss_hist[i][0];
+			snr_hist = &dbg_s->snr_3ss_hist[i][0];
+			#endif
+		} else if (rate_type == PDM_4SS) {
+			#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+			evm_hist = &dbg_s->evm_4ss_hist[i][0];
+			snr_hist = &dbg_s->snr_4ss_hist[i][0];
+			#endif
+		}
 
-	/*CCK*/
-	p_dbg_avg->rssi_cck_avg = (u8)((p_dbg_statistic->rssi_cck_cnt != 0) ? (p_dbg_statistic->rssi_cck_sum/p_dbg_statistic->rssi_cck_cnt) : 0);
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* cck Cnt= ((%d)) RSSI:{%d}\n", p_dbg_statistic->rssi_cck_cnt, p_dbg_avg->rssi_cck_avg));
-	
-	/*OFDM*/
-	if (p_dbg_statistic->rssi_ofdm_cnt != 0) {
-		p_dbg_avg->rssi_ofdm_avg = (u8)(p_dbg_statistic->rssi_ofdm_sum/p_dbg_statistic->rssi_ofdm_cnt);
-		p_dbg_avg->evm_ofdm_avg = (u8)(p_dbg_statistic->evm_ofdm_sum/p_dbg_statistic->rssi_ofdm_cnt);
-		p_dbg_avg->snr_ofdm_avg = (u8)(p_dbg_statistic->snr_ofdm_sum/p_dbg_statistic->rssi_ofdm_cnt);
+		phydm_print_hist_2_buf(dm, evm_hist, h_size, buf, buf_size);
+		PHYDM_DBG(dm, DBG_CMN, "[%d-SS][EVM][%d]=%s\n", ss, i, buf);
+		phydm_print_hist_2_buf(dm, snr_hist, h_size, buf, buf_size);
+		PHYDM_DBG(dm, DBG_CMN, "[%d-SS][SNR][%d]=%s\n",  ss, i, buf);
 	}
+}
 
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* ofdm Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
-		p_dbg_statistic->rssi_ofdm_cnt, p_dbg_avg->rssi_ofdm_avg, p_dbg_avg->evm_ofdm_avg, p_dbg_avg->snr_ofdm_avg));
-	
-	if (p_dbg_statistic->rssi_1ss_cnt != 0) {
-		p_dbg_avg->rssi_1ss_avg = (u8)(p_dbg_statistic->rssi_1ss_sum/p_dbg_statistic->rssi_1ss_cnt);
-		p_dbg_avg->evm_1ss_avg = (u8)(p_dbg_statistic->evm_1ss_sum/p_dbg_statistic->rssi_1ss_cnt);
-		p_dbg_avg->snr_1ss_avg = (u8)(p_dbg_statistic->snr_1ss_sum/p_dbg_statistic->rssi_1ss_cnt);
+void phydm_show_phy_hitogram(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	struct phydm_phystatus_statistic *dbg_s = &dbg_i->physts_statistic_info;
+	char buf[PHYDM_SNPRINT_SIZE] = {0};
+	u16 buf_size = PHYDM_SNPRINT_SIZE;
+	u16 th_size = PHY_HIST_SIZE - 1;
+	u8 i = 0;
+
+	PHYDM_DBG(dm, DBG_CMN, "[PHY Histogram] ==============>\n");
+/*@===[Threshold]=============================================================*/
+	phydm_print_hist_2_buf(dm, dbg_i->evm_hist_th, th_size, buf, buf_size);
+	PHYDM_DBG(dm, DBG_CMN, "%-16s=%s\n", "[EVM_TH]", buf);
+
+	phydm_print_hist_2_buf(dm, dbg_i->snr_hist_th, th_size, buf, buf_size);
+	PHYDM_DBG(dm, DBG_CMN, "%-16s=%s\n", "[SNR_TH]", buf);
+/*@===[OFDM]==================================================================*/
+	if (dbg_s->rssi_ofdm_cnt) {
+		phydm_print_hist_2_buf(dm, dbg_s->evm_ofdm_hist, PHY_HIST_SIZE,
+				       buf, buf_size);
+		PHYDM_DBG(dm, DBG_CMN, "%-14s=%s\n", "[OFDM][EVM]", buf);
+
+		phydm_print_hist_2_buf(dm, dbg_s->snr_ofdm_hist, PHY_HIST_SIZE,
+				       buf, buf_size);
+		PHYDM_DBG(dm, DBG_CMN, "%-14s=%s\n", "[OFDM][SNR]", buf);
 	}
-
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* 1-ss Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
-		p_dbg_statistic->rssi_1ss_cnt, p_dbg_avg->rssi_1ss_avg, p_dbg_avg->evm_1ss_avg, p_dbg_avg->snr_1ss_avg));
-
+/*@===[1-SS]==================================================================*/
+	if (dbg_s->rssi_1ss_cnt)
+		phydm_nss_hitogram(dm, PDM_1SS);
+/*@===[2-SS]==================================================================*/
 	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
-	if (p_dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {
-
-		if (p_dbg_statistic->rssi_2ss_cnt != 0) {
-			p_dbg_avg->rssi_2ss_avg[0] = (u8)(p_dbg_statistic->rssi_2ss_sum[0] /p_dbg_statistic->rssi_2ss_cnt);
-			p_dbg_avg->rssi_2ss_avg[1] = (u8)(p_dbg_statistic->rssi_2ss_sum[1] /p_dbg_statistic->rssi_2ss_cnt);
-			
-			p_dbg_avg->evm_2ss_avg[0] = (u8)(p_dbg_statistic->evm_2ss_sum[0] /p_dbg_statistic->rssi_2ss_cnt);
-			p_dbg_avg->evm_2ss_avg[1] = (u8)(p_dbg_statistic->evm_2ss_sum[1] /p_dbg_statistic->rssi_2ss_cnt);
-			
-			p_dbg_avg->snr_2ss_avg[0] = (u8)(p_dbg_statistic->snr_2ss_sum[0] /p_dbg_statistic->rssi_2ss_cnt);
-			p_dbg_avg->snr_2ss_avg[1] = (u8)(p_dbg_statistic->snr_2ss_sum[1] /p_dbg_statistic->rssi_2ss_cnt);
-		}
-		
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* 2-ss Cnt= ((%d)) RSSI:{%d, %d}, EVM:{%d, %d}, SNR:{%d, %d}\n",
-			p_dbg_statistic->rssi_2ss_cnt, 
-			p_dbg_avg->rssi_2ss_avg[0], p_dbg_avg->rssi_2ss_avg[1], 
-			p_dbg_avg->evm_2ss_avg[0], p_dbg_avg->evm_2ss_avg[1], 
-			p_dbg_avg->snr_2ss_avg[0], p_dbg_avg->snr_2ss_avg[1]));
-	}
+	if ((dm->support_ic_type & PHYDM_IC_ABOVE_2SS) && dbg_s->rssi_2ss_cnt)
+		phydm_nss_hitogram(dm, PDM_2SS);
 	#endif
-
+/*@===[3-SS]==================================================================*/
 	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
-	if (p_dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
-
-		if (p_dbg_statistic->rssi_3ss_cnt != 0) {
-			p_dbg_avg->rssi_3ss_avg[0] = (u8)(p_dbg_statistic->rssi_3ss_sum[0] /p_dbg_statistic->rssi_3ss_cnt);
-			p_dbg_avg->rssi_3ss_avg[1] = (u8)(p_dbg_statistic->rssi_3ss_sum[1] /p_dbg_statistic->rssi_3ss_cnt);
-			p_dbg_avg->rssi_3ss_avg[2] = (u8)(p_dbg_statistic->rssi_3ss_sum[2] /p_dbg_statistic->rssi_3ss_cnt);
-			
-			p_dbg_avg->evm_3ss_avg[0] = (u8)(p_dbg_statistic->evm_3ss_sum[0] /p_dbg_statistic->rssi_3ss_cnt);
-			p_dbg_avg->evm_3ss_avg[1] = (u8)(p_dbg_statistic->evm_3ss_sum[1] /p_dbg_statistic->rssi_3ss_cnt);
-			p_dbg_avg->evm_3ss_avg[2] = (u8)(p_dbg_statistic->evm_3ss_sum[2] /p_dbg_statistic->rssi_3ss_cnt);
-
-			p_dbg_avg->snr_3ss_avg[0] = (u8)(p_dbg_statistic->snr_3ss_sum[0] /p_dbg_statistic->rssi_3ss_cnt);
-			p_dbg_avg->snr_3ss_avg[1] = (u8)(p_dbg_statistic->snr_3ss_sum[1] /p_dbg_statistic->rssi_3ss_cnt);
-			p_dbg_avg->snr_3ss_avg[2] = (u8)(p_dbg_statistic->snr_3ss_sum[2] /p_dbg_statistic->rssi_3ss_cnt);
-		}
-		
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* 3-ss Cnt= ((%d)) RSSI:{%d, %d, %d} EVM:{%d, %d, %d} SNR:{%d, %d, %d}\n",
-			p_dbg_statistic->rssi_3ss_cnt, 
-			p_dbg_avg->rssi_3ss_avg[0], p_dbg_avg->rssi_3ss_avg[1], p_dbg_avg->rssi_3ss_avg[2],
-			p_dbg_avg->evm_3ss_avg[0], p_dbg_avg->evm_3ss_avg[1], p_dbg_avg->evm_3ss_avg[2],
-			p_dbg_avg->snr_3ss_avg[0], p_dbg_avg->snr_3ss_avg[1], p_dbg_avg->snr_3ss_avg[2]));
-	}
+	if ((dm->support_ic_type & PHYDM_IC_ABOVE_3SS) && dbg_s->rssi_3ss_cnt)
+		phydm_nss_hitogram(dm, PDM_3SS);
 	#endif
-
+/*@===[4-SS]==================================================================*/
 	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
-	if (p_dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
-
-		if (p_dbg_statistic->rssi_4ss_cnt != 0) {
-			p_dbg_avg->rssi_4ss_avg[0] = (u8)(p_dbg_statistic->rssi_4ss_sum[0] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->rssi_4ss_avg[1] = (u8)(p_dbg_statistic->rssi_4ss_sum[1] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->rssi_4ss_avg[2] = (u8)(p_dbg_statistic->rssi_4ss_sum[2] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->rssi_4ss_avg[3] = (u8)(p_dbg_statistic->rssi_4ss_sum[3] /p_dbg_statistic->rssi_4ss_cnt);
-
-			p_dbg_avg->evm_4ss_avg[0] = (u8)(p_dbg_statistic->evm_4ss_sum[0] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->evm_4ss_avg[1] = (u8)(p_dbg_statistic->evm_4ss_sum[1] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->evm_4ss_avg[2] = (u8)(p_dbg_statistic->evm_4ss_sum[2] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->evm_4ss_avg[3] = (u8)(p_dbg_statistic->evm_4ss_sum[3] /p_dbg_statistic->rssi_4ss_cnt);
-
-			p_dbg_avg->snr_4ss_avg[0] = (u8)(p_dbg_statistic->snr_4ss_sum[0] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->snr_4ss_avg[1] = (u8)(p_dbg_statistic->snr_4ss_sum[1] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->snr_4ss_avg[2] = (u8)(p_dbg_statistic->snr_4ss_sum[2] /p_dbg_statistic->rssi_4ss_cnt);
-			p_dbg_avg->snr_4ss_avg[3] = (u8)(p_dbg_statistic->snr_4ss_sum[3] /p_dbg_statistic->rssi_4ss_cnt);
-		}
-		
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("* 4-ss Cnt= ((%d)) RSSI:{%d, %d, %d, %d} EVM:{%d, %d, %d, %d} SNR:{%d, %d, %d, %d}\n",
-			p_dbg_statistic->rssi_4ss_cnt, 
-			p_dbg_avg->rssi_4ss_avg[0], p_dbg_avg->rssi_4ss_avg[1], p_dbg_avg->rssi_4ss_avg[2], p_dbg_avg->rssi_4ss_avg[3],
-			p_dbg_avg->evm_4ss_avg[0], p_dbg_avg->evm_4ss_avg[1], p_dbg_avg->evm_4ss_avg[2], p_dbg_avg->evm_4ss_avg[3],
-			p_dbg_avg->snr_4ss_avg[0], p_dbg_avg->snr_4ss_avg[1], p_dbg_avg->snr_4ss_avg[2], p_dbg_avg->snr_4ss_avg[3]));
-	}
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS && dbg_s->rssi_4ss_cnt)
+		phydm_nss_hitogram(dm, PDM_4SS);
 	#endif
-
-	
-
 }
 
-void
-phydm_get_phy_statistic(
-	void		*p_dm_void
-)
+void phydm_get_avg_phystatus_val(void *dm_void)
 {
-	struct	PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	
-	phydm_rx_rate_distribution(p_dm);
-	phydm_reset_rx_rate_distribution(p_dm);
-	
-	phydm_get_avg_phystatus_val(p_dm);
-	phydm_reset_phystatus_statistic(p_dm);
-};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	struct phydm_phystatus_statistic *dbg_s = &dbg_i->physts_statistic_info;
+	struct phydm_phystatus_avg *dbg_avg = &dbg_i->phystatus_statistic_avg;
+
+	PHYDM_DBG(dm, DBG_CMN, "[PHY Avg] ==============>\n");
+	phydm_reset_phystatus_avg(dm);
+
+/*@===[CCK]===================================================================*/
+	if (dbg_s->rssi_cck_cnt != 0)
+		dbg_avg->rssi_cck_avg = (u8)(dbg_s->rssi_cck_sum /
+					dbg_s->rssi_cck_cnt);
+	else
+		dbg_avg->rssi_cck_avg = 0;
+
+	PHYDM_DBG(dm, DBG_CMN, "* cck Cnt= ((%d)) RSSI:{%d}\n",
+		  dbg_s->rssi_cck_cnt, dbg_avg->rssi_cck_avg);
+
+/*@===[OFDM]==================================================================*/
+	if (dbg_s->rssi_ofdm_cnt != 0) {
+		dbg_avg->rssi_ofdm_avg = (u8)(dbg_s->rssi_ofdm_sum /
+					      dbg_s->rssi_ofdm_cnt);
+		dbg_avg->evm_ofdm_avg = (u8)(dbg_s->evm_ofdm_sum /
+					     dbg_s->rssi_ofdm_cnt);
+		dbg_avg->snr_ofdm_avg = (u8)(dbg_s->snr_ofdm_sum /
+					     dbg_s->rssi_ofdm_cnt);
+	}
 
-void
-phydm_basic_dbg_message
-(
-	void			*p_dm_void
-)
-{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_struct *false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(p_dm, PHYDM_FALSEALMCNT);
-	struct phydm_cfo_track_struct				*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct _rate_adaptive_table_	*p_ra_table = &p_dm->dm_ra_table;
-	u16	macid, phydm_macid, client_cnt = 0;
-	struct cmn_sta_info	*p_entry = NULL;
-	s32	tmp_val = 0;
-	u8	tmp_val_u1 = 0;
-
-	if (!(p_dm->debug_components & ODM_COMP_COMMON))
-		return;
+	PHYDM_DBG(dm, DBG_CMN,
+		  "* ofdm Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
+		  dbg_s->rssi_ofdm_cnt, dbg_avg->rssi_ofdm_avg,
+		  dbg_avg->evm_ofdm_avg, dbg_avg->snr_ofdm_avg);
+/*@===[1-SS]==================================================================*/
+	if (dbg_s->rssi_1ss_cnt != 0) {
+		dbg_avg->rssi_1ss_avg = (u8)(dbg_s->rssi_1ss_sum /
+					     dbg_s->rssi_1ss_cnt);
+		dbg_avg->evm_1ss_avg = (u8)(dbg_s->evm_1ss_sum /
+					    dbg_s->rssi_1ss_cnt);
+		dbg_avg->snr_1ss_avg = (u8)(dbg_s->snr_1ss_sum /
+					    dbg_s->rssi_1ss_cnt);
+	}
 
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[PHYDM Common MSG] System up time: ((%d sec))----->\n", p_dm->phydm_sys_up_time));
+	PHYDM_DBG(dm, DBG_CMN,
+		  "* 1-ss Cnt= ((%d)) RSSI:{%d} EVM:{%d} SNR:{%d}\n",
+		  dbg_s->rssi_1ss_cnt, dbg_avg->rssi_1ss_avg,
+		  dbg_avg->evm_1ss_avg, dbg_avg->snr_1ss_avg);
+
+/*@===[2-SS]==================================================================*/
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {
+		if (dbg_s->rssi_2ss_cnt != 0) {
+			dbg_avg->rssi_2ss_avg[0] = (u8)(dbg_s->rssi_2ss_sum[0] /
+							dbg_s->rssi_2ss_cnt);
+			dbg_avg->rssi_2ss_avg[1] = (u8)(dbg_s->rssi_2ss_sum[1] /
+							dbg_s->rssi_2ss_cnt);
+
+			dbg_avg->evm_2ss_avg[0] = (u8)(dbg_s->evm_2ss_sum[0] /
+						       dbg_s->rssi_2ss_cnt);
+			dbg_avg->evm_2ss_avg[1] = (u8)(dbg_s->evm_2ss_sum[1] /
+						       dbg_s->rssi_2ss_cnt);
+
+			dbg_avg->snr_2ss_avg[0] = (u8)(dbg_s->snr_2ss_sum[0] /
+						       dbg_s->rssi_2ss_cnt);
+			dbg_avg->snr_2ss_avg[1] = (u8)(dbg_s->snr_2ss_sum[1] /
+						       dbg_s->rssi_2ss_cnt);
+		}
 
-	if (p_dm->is_linked) {
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("ID=((%d)), BW=((%d)), fc=((CH-%d))\n", p_dm->curr_station_id, 20<<(*(p_dm->p_band_width)), *(p_dm->p_channel)));
+		PHYDM_DBG(dm, DBG_CMN,
+			  "* 2-ss Cnt= ((%d)) RSSI:{%d, %d}, EVM:{%d, %d}, SNR:{%d, %d}\n",
+			  dbg_s->rssi_2ss_cnt, dbg_avg->rssi_2ss_avg[0],
+			  dbg_avg->rssi_2ss_avg[1], dbg_avg->evm_2ss_avg[0],
+			  dbg_avg->evm_2ss_avg[1], dbg_avg->snr_2ss_avg[0],
+			  dbg_avg->snr_2ss_avg[1]);
+	}
+#endif
 
-		if ((*(p_dm->p_channel) <= 14) && (*(p_dm->p_band_width) == CHANNEL_WIDTH_40)) {
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("Primary CCA at ((%s SB))\n",
-				(((*(p_dm->p_sec_ch_offset)) == SECOND_CH_AT_LSB)?"U":"L")));
+/*@===[3-SS]==================================================================*/
+#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
+		if (dbg_s->rssi_3ss_cnt != 0) {
+			dbg_avg->rssi_3ss_avg[0] = (u8)(dbg_s->rssi_3ss_sum[0] /
+							dbg_s->rssi_3ss_cnt);
+			dbg_avg->rssi_3ss_avg[1] = (u8)(dbg_s->rssi_3ss_sum[1] /
+							dbg_s->rssi_3ss_cnt);
+			dbg_avg->rssi_3ss_avg[2] = (u8)(dbg_s->rssi_3ss_sum[2] /
+							dbg_s->rssi_3ss_cnt);
+
+			dbg_avg->evm_3ss_avg[0] = (u8)(dbg_s->evm_3ss_sum[0] /
+						       dbg_s->rssi_3ss_cnt);
+			dbg_avg->evm_3ss_avg[1] = (u8)(dbg_s->evm_3ss_sum[1] /
+						       dbg_s->rssi_3ss_cnt);
+			dbg_avg->evm_3ss_avg[2] = (u8)(dbg_s->evm_3ss_sum[2] /
+						       dbg_s->rssi_3ss_cnt);
+
+			dbg_avg->snr_3ss_avg[0] = (u8)(dbg_s->snr_3ss_sum[0] /
+						       dbg_s->rssi_3ss_cnt);
+			dbg_avg->snr_3ss_avg[1] = (u8)(dbg_s->snr_3ss_sum[1] /
+						       dbg_s->rssi_3ss_cnt);
+			dbg_avg->snr_3ss_avg[2] = (u8)(dbg_s->snr_3ss_sum[2] /
+						       dbg_s->rssi_3ss_cnt);
 		}
 
-		if ((p_dm->support_ic_type & ODM_IC_PHY_STATUE_NEW_TYPE) || p_dm->rx_rate > ODM_RATE11M) {
-			
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[AGC Idx] {0x%x, 0x%x, 0x%x, 0x%x}\n",
-				p_dm->ofdm_agc_idx[0], p_dm->ofdm_agc_idx[1], p_dm->ofdm_agc_idx[2], p_dm->ofdm_agc_idx[3]));
-		} else {
-		
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[CCK AGC Idx] {LNA, VGA}={0x%x, 0x%x}\n",
-				p_dm->cck_lna_idx, p_dm->cck_vga_idx));
+		PHYDM_DBG(dm, DBG_CMN,
+			  "* 3-ss Cnt= ((%d)) RSSI:{%d, %d, %d} EVM:{%d, %d, %d} SNR:{%d, %d, %d}\n",
+			  dbg_s->rssi_3ss_cnt, dbg_avg->rssi_3ss_avg[0],
+			  dbg_avg->rssi_3ss_avg[1], dbg_avg->rssi_3ss_avg[2],
+			  dbg_avg->evm_3ss_avg[0], dbg_avg->evm_3ss_avg[1],
+			  dbg_avg->evm_3ss_avg[2], dbg_avg->snr_3ss_avg[0],
+			  dbg_avg->snr_3ss_avg[1], dbg_avg->snr_3ss_avg[2]);
+	}
+#endif
+
+/*@===[4-SS]==================================================================*/
+#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+		if (dbg_s->rssi_4ss_cnt != 0) {
+			dbg_avg->rssi_4ss_avg[0] = (u8)(dbg_s->rssi_4ss_sum[0] /
+							dbg_s->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[1] = (u8)(dbg_s->rssi_4ss_sum[1] /
+							dbg_s->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[2] = (u8)(dbg_s->rssi_4ss_sum[2] /
+							dbg_s->rssi_4ss_cnt);
+			dbg_avg->rssi_4ss_avg[3] = (u8)(dbg_s->rssi_4ss_sum[3] /
+							dbg_s->rssi_4ss_cnt);
+
+			dbg_avg->evm_4ss_avg[0] = (u8)(dbg_s->evm_4ss_sum[0] /
+						       dbg_s->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[1] = (u8)(dbg_s->evm_4ss_sum[1] /
+						       dbg_s->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[2] = (u8)(dbg_s->evm_4ss_sum[2] /
+						       dbg_s->rssi_4ss_cnt);
+			dbg_avg->evm_4ss_avg[3] = (u8)(dbg_s->evm_4ss_sum[3] /
+						       dbg_s->rssi_4ss_cnt);
+
+			dbg_avg->snr_4ss_avg[0] = (u8)(dbg_s->snr_4ss_sum[0] /
+						       dbg_s->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[1] = (u8)(dbg_s->snr_4ss_sum[1] /
+						       dbg_s->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[2] = (u8)(dbg_s->snr_4ss_sum[2] /
+						       dbg_s->rssi_4ss_cnt);
+			dbg_avg->snr_4ss_avg[3] = (u8)(dbg_s->snr_4ss_sum[3] /
+						       dbg_s->rssi_4ss_cnt);
 		}
 
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("RSSI:{%d, %d, %d, %d}, RxRate:",
-			(p_dm->RSSI_A == 0xff) ? 0 : p_dm->RSSI_A,
-			(p_dm->RSSI_B == 0xff) ? 0 : p_dm->RSSI_B,
-			(p_dm->RSSI_C == 0xff) ? 0 : p_dm->RSSI_C,
-			(p_dm->RSSI_D == 0xff) ? 0 : p_dm->RSSI_D));
+		PHYDM_DBG(dm, DBG_CMN,
+			  "* 4-ss Cnt= ((%d)) RSSI:{%d, %d, %d, %d} EVM:{%d, %d, %d, %d} SNR:{%d, %d, %d, %d}\n",
+			  dbg_s->rssi_4ss_cnt, dbg_avg->rssi_4ss_avg[0],
+			  dbg_avg->rssi_4ss_avg[1], dbg_avg->rssi_4ss_avg[2],
+			  dbg_avg->rssi_4ss_avg[3], dbg_avg->evm_4ss_avg[0],
+			  dbg_avg->evm_4ss_avg[1], dbg_avg->evm_4ss_avg[2],
+			  dbg_avg->evm_4ss_avg[3], dbg_avg->snr_4ss_avg[0],
+			  dbg_avg->snr_4ss_avg[1], dbg_avg->snr_4ss_avg[2],
+			  dbg_avg->snr_4ss_avg[3]);
+	}
+#endif
+}
 
-		phydm_print_rate(p_dm, p_dm->rx_rate, ODM_COMP_COMMON);
+void phydm_get_phy_statistic(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-		phydm_get_phy_statistic(p_dm);
+	phydm_rx_rate_distribution(dm);
+	phydm_reset_rx_rate_distribution(dm);
 
-		/*Print TX rate*/
-		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+	phydm_show_phy_hitogram(dm);
+	phydm_get_avg_phystatus_val(dm);
+	phydm_reset_phystatus_statistic(dm);
+};
 
-			p_entry = p_dm->p_phydm_sta_info[macid];
-			if (!is_sta_active(p_entry)) {
-				continue;
-			}
+void phydm_basic_dbg_msg_linked(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_cfo_track_struct *cfo_t = &dm->dm_cfo_track;
+	struct odm_phy_dbg_info *dbg_t = &dm->phy_dbg_info;
+	u16 macid, client_cnt = 0;
+	u8 rate = 0;
+	struct cmn_sta_info *entry = NULL;
+	char dbg_buf[PHYDM_SNPRINT_SIZE] = {0};
+	struct phydm_cfo_rpt cfo;
+	u8 i = 0;
+
+	PHYDM_DBG(dm, DBG_CMN, "ID=((%d)), BW=((%d)), fc=((CH-%d))\n",
+		  dm->curr_station_id, 20 << *dm->band_width, *dm->channel);
+
+	#ifdef ODM_IC_11N_SERIES_SUPPORT
+	#ifdef PHYDM_PRIMARY_CCA
+	if (((*dm->channel <= 14) && (*dm->band_width == CHANNEL_WIDTH_40)) &&
+	    (dm->support_ic_type & ODM_IC_11N_SERIES)) {
+		PHYDM_DBG(dm, DBG_CMN, "Primary CCA at ((%s SB))\n",
+			  ((*dm->sec_ch_offset == SECOND_CH_AT_LSB) ? "U" :
+			  "L"));
+	}
+	#endif
+	#endif
 
-			phydm_macid = (p_dm->phydm_macid_table[macid]);
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("TxRate[%d]:", macid));
-			phydm_print_rate(p_dm, p_entry->ra_info.curr_tx_rate, ODM_COMP_COMMON);
+	if ((dm->support_ic_type & PHYSTS_2ND_TYPE_IC) ||
+	    dm->rx_rate > ODM_RATE11M) {
+		PHYDM_DBG(dm, DBG_CMN, "[AGC Idx] {0x%x, 0x%x, 0x%x, 0x%x}\n",
+			  dm->ofdm_agc_idx[0], dm->ofdm_agc_idx[1],
+			  dm->ofdm_agc_idx[2], dm->ofdm_agc_idx[3]);
+	} else {
+		PHYDM_DBG(dm, DBG_CMN, "[CCK AGC Idx] {LNA,VGA}={0x%x, 0x%x}\n",
+			  dm->cck_lna_idx, dm->cck_vga_idx);
+	}
 
-			client_cnt++;
+	phydm_print_rate_2_buff(dm, dm->rx_rate, dbg_buf, PHYDM_SNPRINT_SIZE);
+	PHYDM_DBG(dm, DBG_CMN, "RSSI:{%d, %d, %d, %d}, RxRate:%s (0x%x)\n",
+		  (dm->rssi_a == 0xff) ? 0 : dm->rssi_a,
+		  (dm->rssi_b == 0xff) ? 0 : dm->rssi_b,
+		  (dm->rssi_c == 0xff) ? 0 : dm->rssi_c,
+		  (dm->rssi_d == 0xff) ? 0 : dm->rssi_d,
+		  dbg_buf, dm->rx_rate);
 
-			if (client_cnt >= p_dm->number_linked_client)
-				break;
-		}
+	rate = dbg_t->beacon_phy_rate;
+	phydm_print_rate_2_buff(dm, rate, dbg_buf, PHYDM_SNPRINT_SIZE);
 
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("TP {Tx, Rx, Total} = {%d, %d, %d}Mbps, Traffic_Load=(%d))\n",
-			p_dm->tx_tp, p_dm->rx_tp, p_dm->total_tp, p_dm->traffic_load));
+	PHYDM_DBG(dm, DBG_CMN, "Beacon_cnt=%d, rate_idx=%s (0x%x)\n",
+		  dbg_t->num_qry_beacon_pkt, dbg_buf, dbg_t->beacon_phy_rate);
 
-		tmp_val_u1 = (p_cfo_track->crystal_cap > p_cfo_track->def_x_cap) ? (p_cfo_track->crystal_cap - p_cfo_track->def_x_cap) : (p_cfo_track->def_x_cap - p_cfo_track->crystal_cap);
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("CFO_avg = ((%d kHz)) , CFO_tracking = ((%s%d))\n",
-			p_cfo_track->CFO_ave_pre, ((p_cfo_track->crystal_cap > p_cfo_track->def_x_cap) ? "+" : "-"), tmp_val_u1));
+	phydm_get_phy_statistic(dm);
 
-		/* Condition number */
-	#if (RTL8822B_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8822B) {
-			tmp_val = phydm_get_condition_number_8822B(p_dm);
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("Condi_Num=((%d))\n", tmp_val));
-		}
-	#endif
+	PHYDM_DBG(dm, DBG_CMN,
+		  "rxsc_idx {Legacy, 20, 40, 80} = {%d, %d, %d, %d}\n",
+		  dm->rxsc_l, dm->rxsc_20, dm->rxsc_40, dm->rxsc_80);
 
-	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-		/*STBC or LDPC pkt*/
-		if (p_dm->support_ic_type & ODM_IC_PHY_STATUE_NEW_TYPE)
-			PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("Coding: LDPC=((%s)), STBC=((%s))\n", (p_dm->phy_dbg_info.is_ldpc_pkt) ? "Y" : "N", (p_dm->phy_dbg_info.is_stbc_pkt) ? "Y" : "N"));
-	#endif
-	} else
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("No Link !!!\n"));
+	/*Print TX rate*/
+	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		entry = dm->phydm_sta_info[macid];
 
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
-		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all));
+		if (!is_sta_active(entry))
+			continue;
 
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
-		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all));
+		rate = entry->ra_info.curr_tx_rate;
+		phydm_print_rate_2_buff(dm, rate, dbg_buf, PHYDM_SNPRINT_SIZE);
+		PHYDM_DBG(dm, DBG_CMN, "TxRate[%d]=%s (0x%x)\n",
+			  macid, dbg_buf, entry->ra_info.curr_tx_rate);
 
-	#if (ODM_IC_11N_SERIES_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), CRC8_fail = (( %d )), Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d ))\n",
-			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail));
+		client_cnt++;
+
+		if (client_cnt >= dm->number_linked_client)
+			break;
 	}
+
+	PHYDM_DBG(dm, DBG_CMN,
+		  "TP {Tx, Rx, Total} = {%d, %d, %d}Mbps, Traffic_Load=(%d))\n",
+		  dm->tx_tp, dm->rx_tp, dm->total_tp, dm->traffic_load);
+
+	PHYDM_DBG(dm, DBG_CMN, "CFO_avg=((%d kHz)), CFO_traking = ((%s%d))\n",
+		  cfo_t->CFO_ave_pre,
+		  ((cfo_t->crystal_cap > cfo_t->def_x_cap) ? "+" : "-"),
+		  DIFF_2(cfo_t->crystal_cap, cfo_t->def_x_cap));
+
+	/* @CFO report */
+	switch (dm->ic_ip_series) {
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	case PHYDM_IC_JGR3:
+		PHYDM_DBG(dm, DBG_CMN, "cfo_tail = {%d, %d, %d, %d}\n",
+			  dbg_t->cfo_tail[0], dbg_t->cfo_tail[1],
+			  dbg_t->cfo_tail[2], dbg_t->cfo_tail[3]);
+		break;
 	#endif
+	default:
+		phydm_get_cfo_info(dm, &cfo);
+		for (i = 0; i < dm->num_rf_path; i++) {
+			PHYDM_DBG(dm, DBG_CMN,
+				  "CFO[%d] {S, L, Sec, Acq, End} = {%d, %d, %d, %d, %d}\n",
+				  i, cfo.cfo_rpt_s[i], cfo.cfo_rpt_l[i],
+				  cfo.cfo_rpt_sec[i], cfo.cfo_rpt_acq[i],
+				  cfo.cfo_rpt_end[i]);
+		}
+		break;
+	}
 
-	PHYDM_DBG(p_dm, ODM_COMP_COMMON, ("is_linked = %d, Num_client = %d, rssi_min = %d, IGI = 0x%x, bNoisy=%d\n\n",
-		p_dm->is_linked, p_dm->number_linked_client, p_dm->rssi_min, p_dig_t->cur_ig_value, p_dm->noisy_decision));
+/* @Condition number */
+#if (RTL8822B_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		PHYDM_DBG(dm, DBG_CMN, "Condi_Num=((%d.%.4d)), %d\n",
+			  dbg_t->condi_num >> 4,
+			  phydm_show_fraction_num(dbg_t->condi_num & 0xf, 4),
+			  dbg_t->condi_num);
+	}
+#endif
+#ifdef PHYSTS_3RD_TYPE_SUPPORT
+	if (dm->support_ic_type & PHYSTS_3RD_TYPE_IC) {
+		PHYDM_DBG(dm, DBG_CMN, "Condi_Num=((%d.%4d dB))\n",
+			  dbg_t->condi_num >> 1,
+			  phydm_show_fraction_num(dbg_t->condi_num & 0x1, 1));
+	}
+#endif
+
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT || defined(PHYSTS_3RD_TYPE_SUPPORT))
+	/*STBC or LDPC pkt*/
+	if (dm->support_ic_type & (PHYSTS_2ND_TYPE_IC | PHYSTS_3RD_TYPE_IC))
+		PHYDM_DBG(dm, DBG_CMN, "Coding: LDPC=((%s)), STBC=((%s))\n",
+			  (dbg_t->is_ldpc_pkt) ? "Y" : "N",
+			  (dbg_t->is_stbc_pkt) ? "Y" : "N");
+#endif
+}
+
+void phydm_dm_summary(void *dm_void, u8 macid)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_cfo_track_struct *cfo_t = &dm->dm_cfo_track;
+	struct cmn_sta_info *sta = NULL;
+	struct ra_sta_info *ra = NULL;
+	struct dtp_info *dtp = NULL;
+	u64 comp = dm->support_ability;
+	u64 pause_comp = dm->pause_ability;
+
+	if (!(dm->debug_components & DBG_DM_SUMMARY))
+		return;
+
+	if (!dm->is_linked) {
+		pr_debug("[%s]No Link !!!\n", __func__);
+		return;
+	}
+
+	sta = dm->phydm_sta_info[macid];
 
+	if (!is_sta_active(sta)) {
+		pr_debug("[Warning] %s invalid STA, macid=%d\n",
+			 __func__, macid);
+		return;
+	}
+
+	ra = &sta->ra_info;
+	dtp = &sta->dtp_stat;
+	pr_debug("[%s]===========>\n", __func__);
+
+	pr_debug("00.(%s) %-12s: IGI=0x%x, Dyn_Rng=0x%x~0x%x, FA_th={%d,%d,%d}\n",
+		 ((comp & ODM_BB_DIG) ?
+		 ((pause_comp & ODM_BB_DIG) ? "P" : "V") : "."),
+		 "DIG",
+		 dig_t->cur_ig_value,
+		 dig_t->rx_gain_range_min, dig_t->rx_gain_range_max,
+		 dig_t->fa_th[0], dig_t->fa_th[1], dig_t->fa_th[2]);
+
+	pr_debug("01.(%s) %-12s: rssi_lv=%d, mask=0x%llx\n",
+		 ((comp & ODM_BB_RA_MASK) ?
+		 ((pause_comp & ODM_BB_RA_MASK) ? "P" : "V") : "."),
+		 "RaMask",
+		 ra->rssi_level, ra->ramask);
+
+#ifdef CONFIG_DYNAMIC_TX_TWR
+	pr_debug("02.(%s) %-12s: pwr_lv=%d\n",
+		 ((comp & ODM_BB_DYNAMIC_TXPWR) ?
+		 ((pause_comp & ODM_BB_DYNAMIC_TXPWR) ? "P" : "V") : "."),
+		 "DynTxPwr",
+		 dtp->sta_tx_high_power_lvl);
+#endif
+
+	pr_debug("05.(%s) %-12s: cck_pd_lv=%d\n",
+		 ((comp & ODM_BB_CCK_PD) ?
+		 ((pause_comp & ODM_BB_CCK_PD) ? "P" : "V") : "."),
+		 "CCK_PD", dm->dm_cckpd_table.cck_pd_lv);
+
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	pr_debug("06.(%s) %-12s: div_type=%d, curr_ant=%s\n",
+		 ((comp & ODM_BB_ANT_DIV) ?
+		 ((pause_comp & ODM_BB_ANT_DIV) ? "P" : "V") : "."),
+		 "ANT_DIV",
+		 dm->ant_div_type,
+		 (dm->dm_fat_table.rx_idle_ant == MAIN_ANT) ? "MAIN" : "AUX");
+#endif
+
+#ifdef PHYDM_POWER_TRAINING_SUPPORT
+	pr_debug("08.(%s) %-12s: PT_score=%d, disable_PT=%d\n",
+		 ((comp & ODM_BB_PWR_TRAIN) ?
+		 ((pause_comp & ODM_BB_PWR_TRAIN) ? "P" : "V") : "."),
+		 "PwrTrain",
+		 dm->pow_train_table.pow_train_score,
+		 dm->is_disable_power_training);
+#endif
+
+#ifdef CONFIG_PHYDM_DFS_MASTER
+	pr_debug("11.(%s) %-12s: dbg_mode=%d, region_domain=%d\n",
+		 ((comp & ODM_BB_DFS) ?
+		 ((pause_comp & ODM_BB_DFS) ? "P" : "V") : "."),
+		 "DFS",
+		 dm->dfs.dbg_mode, dm->dfs_region_domain);
+#endif
+#ifdef PHYDM_SUPPORT_ADAPTIVITY
+	pr_debug("13.(%s) %-12s: th{l2h, h2l}={%d, %d}, edcca_flag=%d\n",
+		 ((comp & ODM_BB_ADAPTIVITY) ?
+		 ((pause_comp & ODM_BB_ADAPTIVITY) ? "P" : "V") : "."),
+		 "Adaptivity",
+		 dm->adaptivity.th_l2h, dm->adaptivity.th_h2l,
+		 dm->false_alm_cnt.edcca_flag);
+#endif
+	pr_debug("14.(%s) %-12s: CFO_avg=%d kHz, CFO_traking=%s%d\n",
+		 ((comp & ODM_BB_CFO_TRACKING) ?
+		 ((pause_comp & ODM_BB_CFO_TRACKING) ? "P" : "V") : "."),
+		 "CfoTrack",
+		 cfo_t->CFO_ave_pre,
+		 ((cfo_t->crystal_cap > cfo_t->def_x_cap) ? "+" : "-"),
+		 DIFF_2(cfo_t->crystal_cap, cfo_t->def_x_cap));
+
+	pr_debug("15.(%s) %-12s: ratio{nhm, clm}={%d, %d}\n",
+		 ((comp & ODM_BB_ENV_MONITOR) ?
+		 ((pause_comp & ODM_BB_ENV_MONITOR) ? "P" : "V") : "."),
+		 "EnvMntr",
+		 dm->dm_ccx_info.nhm_ratio, dm->dm_ccx_info.clm_ratio);
+
+#ifdef PHYDM_PRIMARY_CCA
+	pr_debug("16.(%s) %-12s: CCA @ (%s SB)\n",
+		 ((comp & ODM_BB_PRIMARY_CCA) ?
+		 ((pause_comp & ODM_BB_PRIMARY_CCA) ? "P" : "V") : "."),
+		 "PriCCA",
+		 ((dm->dm_pri_cca.mf_state == MF_USC_LSC) ? "D" :
+		 ((dm->dm_pri_cca.mf_state == MF_LSC) ? "L" : "U")));
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	pr_debug("17.(%s) %-12s: soml_en = %s\n",
+		 ((comp & ODM_BB_ADAPTIVE_SOML) ?
+		 ((pause_comp & ODM_BB_ADAPTIVE_SOML) ? "P" : "V") : "."),
+		 "A-SOML",
+		 (dm->dm_soml_table.soml_last_state == SOML_ON) ?
+		 "ON" : "OFF");
+#endif
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+	pr_debug("18.(%s) %-12s:\n",
+		 ((comp & ODM_BB_LNA_SAT_CHK) ?
+		 ((pause_comp & ODM_BB_LNA_SAT_CHK) ? "P" : "V") : "."),
+		 "LNA_SAT_CHK");
 #endif
 }
 
+void phydm_basic_dbg_message(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+
+	/*if (!(dm->debug_components & DBG_CMN))*/
+	/*	return;				*/
+	
+
+	if (dm->cmn_dbg_msg_cnt >= dm->cmn_dbg_msg_period) {
+		dm->cmn_dbg_msg_cnt = PHYDM_WATCH_DOG_PERIOD;
+	} else {
+		dm->cmn_dbg_msg_cnt += PHYDM_WATCH_DOG_PERIOD;
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_CMN, "[%s] System up time: ((%d sec))---->\n",
+		  __func__, dm->phydm_sys_up_time);
+
+	if (dm->is_linked)
+		phydm_basic_dbg_msg_linked(dm);
+	else
+		PHYDM_DBG(dm, DBG_CMN, "No Link !!!\n");
+
+	PHYDM_DBG(dm, DBG_CMN, "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		  fa_t->cnt_cck_cca, fa_t->cnt_ofdm_cca, fa_t->cnt_cca_all);
+
+	PHYDM_DBG(dm, DBG_CMN, "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		  fa_t->cnt_cck_fail, fa_t->cnt_ofdm_fail, fa_t->cnt_all);
+
+	PHYDM_DBG(dm, DBG_CMN,
+		  "[OFDM FA Detail] Parity_Fail=%d, Rate_Illegal=%d, CRC8=%d, MCS_fail=%d, Fast_sync=%d, SB_Search_fail=%d\n",
+		  fa_t->cnt_parity_fail, fa_t->cnt_rate_illegal,
+		  fa_t->cnt_crc8_fail, fa_t->cnt_mcs_fail,
+		  fa_t->cnt_fast_fsync, fa_t->cnt_sb_search_fail);
+
+#if (ODM_IC_11AC_SERIES_SUPPORT || defined(PHYDM_IC_JGR3_SERIES_SUPPORT))
+	if (dm->support_ic_type & (ODM_IC_11AC_SERIES | ODM_IC_JGR3_SERIES)) {
+		PHYDM_DBG(dm, DBG_CMN,
+			  "[OFDM FA Detail VHT] CRC8_VHT=%d, MCS_Fail_VHT=%d\n",
+			  fa_t->cnt_crc8_fail_vht, fa_t->cnt_mcs_fail_vht);
+	}
+#endif
+
+	PHYDM_DBG(dm, DBG_CMN,
+		  "is_linked = %d, Num_client = %d, rssi_min = %d, IGI = 0x%x, bNoisy=%d\n\n",
+		  dm->is_linked, dm->number_linked_client, dm->rssi_min,
+		  dm->dm_dig_table.cur_ig_value, dm->noisy_decision);
+}
 
-void phydm_basic_profile(
-	void			*p_dm_void,
-	u32			*_used,
-	char				*output,
-	u32			*_out_len
-)
+void phydm_basic_profile(void *dm_void, u32 *_used, char *output, u32 *_out_len)
 {
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	char  *cut = NULL;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char *cut = NULL;
 	char *ic_type = NULL;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
-	u32	date = 0;
-	char	*commit_by = NULL;
-	u32	release_ver = 0;
+	u32 date = 0;
+	char *commit_by = NULL;
+	u32 release_ver = 0;
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-35s\n", "% Basic Profile %"));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-35s\n",
+		 "% Basic Profile %");
 
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
-#if (RTL8188E_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8188E) {
+#if (RTL8188E_SUPPORT)
 		ic_type = "RTL8188E";
 		date = RELEASE_DATE_8188E;
 		commit_by = COMMIT_BY_8188E;
 		release_ver = RELEASE_VERSION_8188E;
 #endif
-	}
-#if (RTL8812A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8812) {
+#if (RTL8812A_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8812) {
 		ic_type = "RTL8812A";
 		date = RELEASE_DATE_8812A;
 		commit_by = COMMIT_BY_8812A;
 		release_ver = RELEASE_VERSION_8812A;
-	}
 #endif
-#if (RTL8821A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8821) {
+#if (RTL8821A_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8821) {
 		ic_type = "RTL8821A";
 		date = RELEASE_DATE_8821A;
 		commit_by = COMMIT_BY_8821A;
 		release_ver = RELEASE_VERSION_8821A;
-	}
 #endif
-#if (RTL8192E_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8192E) {
+#if (RTL8192E_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8192E) {
 		ic_type = "RTL8192E";
 		date = RELEASE_DATE_8192E;
 		commit_by = COMMIT_BY_8192E;
 		release_ver = RELEASE_VERSION_8192E;
-	}
 #endif
-#if (RTL8723B_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8723B) {
+#if (RTL8723B_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8723B) {
 		ic_type = "RTL8723B";
 		date = RELEASE_DATE_8723B;
 		commit_by = COMMIT_BY_8723B;
 		release_ver = RELEASE_VERSION_8723B;
-	}
 #endif
-#if (RTL8814A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8814A) {
+#if (RTL8814A_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8814A) {
 		ic_type = "RTL8814A";
 		date = RELEASE_DATE_8814A;
 		commit_by = COMMIT_BY_8814A;
 		release_ver = RELEASE_VERSION_8814A;
-	}
 #endif
-#if (RTL8881A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8881A) {
+#if (RTL8881A_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8881A) {
 		ic_type = "RTL8881A";
-		/**/
-	}
 #endif
-#if (RTL8822B_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8822B) {
+#if (RTL8822B_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8822B) {
 		ic_type = "RTL8822B";
 		date = RELEASE_DATE_8822B;
 		commit_by = COMMIT_BY_8822B;
 		release_ver = RELEASE_VERSION_8822B;
-	}
 #endif
-#if (RTL8197F_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8197F) {
+#if (RTL8197F_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8197F) {
 		ic_type = "RTL8197F";
 		date = RELEASE_DATE_8197F;
 		commit_by = COMMIT_BY_8197F;
 		release_ver = RELEASE_VERSION_8197F;
-	}
 #endif
-
-#if (RTL8703B_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8703B) {
-
+#if (RTL8703B_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8703B) {
 		ic_type = "RTL8703B";
 		date = RELEASE_DATE_8703B;
 		commit_by = COMMIT_BY_8703B;
 		release_ver = RELEASE_VERSION_8703B;
-
-	}
 #endif
-#if (RTL8195A_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8195A) {
+#if (RTL8195A_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8195A) {
 		ic_type = "RTL8195A";
-		/**/
-	}
 #endif
-#if (RTL8188F_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8188F) {
+#if (RTL8188F_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8188F) {
 		ic_type = "RTL8188F";
 		date = RELEASE_DATE_8188F;
 		commit_by = COMMIT_BY_8188F;
 		release_ver = RELEASE_VERSION_8188F;
-	}
 #endif
-#if (RTL8723D_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8723D) {
+#if (RTL8723D_SUPPORT)
+	} else if (dm->support_ic_type == ODM_RTL8723D) {
 		ic_type = "RTL8723D";
 		date = RELEASE_DATE_8723D;
 		commit_by = COMMIT_BY_8723D;
 		release_ver = RELEASE_VERSION_8723D;
-		/**/
-	}
 #endif
+	}
 
-/* JJ ADD 20161014 */
-#if (RTL8710B_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8710B) {
+/* @JJ ADD 20161014 */
+#if (RTL8710B_SUPPORT)
+	else if (dm->support_ic_type == ODM_RTL8710B) {
 		ic_type = "RTL8710B";
 		date = RELEASE_DATE_8710B;
 		commit_by = COMMIT_BY_8710B;
 		release_ver = RELEASE_VERSION_8710B;
-		/**/
 	}
 #endif
 
-#if (RTL8821C_SUPPORT == 1)
-	else if (p_dm->support_ic_type == ODM_RTL8821C) {
+#if (RTL8721D_SUPPORT)
+	else if (dm->support_ic_type == ODM_RTL8721D) {
+		ic_type = "RTL8721D";
+		date = RELEASE_DATE_8721D;
+		commit_by = COMMIT_BY_8721D;
+		release_ver = RELEASE_VERSION_8721D;
+	}
+#endif
+#if (RTL8821C_SUPPORT)
+	else if (dm->support_ic_type == ODM_RTL8821C) {
 		ic_type = "RTL8821C";
 		date = RELEASE_DATE_8821C;
 		commit_by = COMMIT_BY_8821C;
 		release_ver = RELEASE_VERSION_8821C;
 	}
 #endif
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s (MP Chip: %s)\n", "IC type", ic_type, p_dm->is_mp_chip ? "Yes" : "No"));
 
-	if (p_dm->cut_version == ODM_CUT_A)
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT)
+	else if (dm->support_ic_type == ODM_RTL8192F) {
+		ic_type = "RTL8192F";
+		date = RELEASE_DATE_8192F;
+		commit_by = COMMIT_BY_8192F;
+		release_ver = RELEASE_VERSION_8192F;
+	}
+#endif
+
+#if (RTL8198F_SUPPORT)
+	else if (dm->support_ic_type == ODM_RTL8198F) {
+		ic_type = "RTL8198F";
+		date = RELEASE_DATE_8198F;
+		commit_by = COMMIT_BY_8198F;
+		release_ver = RELEASE_VERSION_8198F;
+	}
+#endif
+
+#if (RTL8822C_SUPPORT)
+	else if (dm->support_ic_type == ODM_RTL8822C) {
+		ic_type = "RTL8822C";
+		date = RELEASE_DATE_8822C;
+		commit_by = COMMIT_BY_8822C;
+		release_ver = RELEASE_VERSION_8822C;
+	}
+#endif
+
+#if (RTL8812F_SUPPORT)
+	else if (dm->support_ic_type == ODM_RTL8812F) {
+		ic_type = "RTL8812F";
+		date = RELEASE_DATE_8812F;
+		commit_by = COMMIT_BY_8812F;
+		release_ver = RELEASE_VERSION_8812F;
+	}
+#endif
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "  %-35s: %s (MP Chip: %s)\n", "IC type", ic_type,
+		 dm->is_mp_chip ? "Yes" : "No");
+
+	if (dm->cut_version == ODM_CUT_A)
 		cut = "A";
-	else if (p_dm->cut_version == ODM_CUT_B)
+	else if (dm->cut_version == ODM_CUT_B)
 		cut = "B";
-	else if (p_dm->cut_version == ODM_CUT_C)
+	else if (dm->cut_version == ODM_CUT_C)
 		cut = "C";
-	else if (p_dm->cut_version == ODM_CUT_D)
+	else if (dm->cut_version == ODM_CUT_D)
 		cut = "D";
-	else if (p_dm->cut_version == ODM_CUT_E)
+	else if (dm->cut_version == ODM_CUT_E)
 		cut = "E";
-	else if (p_dm->cut_version == ODM_CUT_F)
+	else if (dm->cut_version == ODM_CUT_F)
 		cut = "F";
-	else if (p_dm->cut_version == ODM_CUT_I)
+	else if (dm->cut_version == ODM_CUT_I)
 		cut = "I";
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d\n", "RFE type", p_dm->rfe_type));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Cut Ver", cut));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d\n", "PHY Para Ver", odm_get_hw_img_version(p_dm)));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d\n", "PHY Para Commit date", date));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "PHY Para Commit by", commit_by));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d\n", "PHY Para Release Ver", release_ver));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %d\n",
+		 "RFE type", dm->rfe_type);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Cut Ver", cut);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %d\n",
+		 "PHY Para Ver", odm_get_hw_img_version(dm));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %d\n",
+		 "PHY Para Commit date", date);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "PHY Para Commit by", commit_by);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %d\n",
+		 "PHY Para Release Ver", release_ver);
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "  %-35s: %d (Subversion: %d)\n", "FW Ver", dm->fw_version,
+		 dm->fw_sub_version);
+
+	/* @1 PHY DM version List */
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-35s\n",
+		 "% PHYDM version %");
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Code base", PHYDM_CODE_BASE);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Release Date", PHYDM_RELEASE_DATE);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Adaptivity", ADAPTIVITY_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "DIG", DIG_VERSION);
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "CFO Tracking", CFO_TRACKING_VERSION);
+#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "AntDiv", ANTDIV_VERSION);
+#endif
+#ifdef CONFIG_DYNAMIC_TX_TWR
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Dynamic TxPower", DYNAMIC_TXPWR_VERSION);
+#endif
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "RA Info", RAINFO_VERSION);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "AntDetect", ANTDECT_VERSION);
+#endif
+#ifdef CONFIG_PATH_DIVERSITY
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "PathDiv", PATHDIV_VERSION);
+#endif
+#ifdef CONFIG_ADAPTIVE_SOML
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Adaptive SOML", ADAPTIVE_SOML_VERSION);
+#endif
+#if (PHYDM_LA_MODE_SUPPORT)
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "LA mode", DYNAMIC_LA_MODE);
+#endif
+#ifdef PHYDM_PRIMARY_CCA
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "Primary CCA", PRIMARYCCA_VERSION);
+#endif
+	PDM_SNPF(out_len, used, output + used, out_len - used, "  %-35s: %s\n",
+		 "DFS", DFS_VERSION);
+
+#if (RTL8822B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8822B)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "  %-35s: %s\n", "PHY config 8822B",
+			 PHY_CONFIG_VERSION_8822B);
+
+#endif
+#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "  %-35s: %s\n", "PHY config 8197F",
+			 PHY_CONFIG_VERSION_8197F);
+#endif
+
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8192F)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "  %-35s: %s\n", "PHY config 8192F",
+			 PHY_CONFIG_VERSION_8192F);
+#endif
+#if (RTL8721D_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8721D)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "  %-35s: %s\n", "PHY config 8721D",
+			 PHY_CONFIG_VERSION_8721D);
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+
+#endif /*@#if CONFIG_PHYDM_DEBUG_FUNCTION*/
+}
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+void phydm_fw_trace_en_h2c(void *dm_void, boolean enable,
+			   u32 fw_dbg_comp, u32 monitor_mode, u32 macid)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 h2c_parameter[7] = {0};
+	u8 cmd_length;
+
+	if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+		h2c_parameter[0] = enable;
+		h2c_parameter[1] = (u8)(fw_dbg_comp & MASKBYTE0);
+		h2c_parameter[2] = (u8)((fw_dbg_comp & MASKBYTE1) >> 8);
+		h2c_parameter[3] = (u8)((fw_dbg_comp & MASKBYTE2) >> 16);
+		h2c_parameter[4] = (u8)((fw_dbg_comp & MASKBYTE3) >> 24);
+		h2c_parameter[5] = (u8)monitor_mode;
+		h2c_parameter[6] = (u8)macid;
+		cmd_length = 7;
+
+	} else {
+		h2c_parameter[0] = enable;
+		h2c_parameter[1] = (u8)monitor_mode;
+		h2c_parameter[2] = (u8)macid;
+		cmd_length = 3;
+	}
+
+	PHYDM_DBG(dm, DBG_FW_TRACE,
+		  "[H2C] FW_debug_en: (( %d )), mode: (( %d )), macid: (( %d ))\n",
+		  enable, monitor_mode, macid);
+
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_FW_TRACE_EN, cmd_length, h2c_parameter);
+}
+
+void phydm_get_per_path_txagc(void *dm_void, u8 path, u32 *_used, char *output,
+			      u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rate_idx;
+	u8 txagc;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+	if (!(dm->support_ic_type & CMN_API_SUPPORT_IC))
+		return;
+
+	if (dm->num_rf_path == 1 && path > RF_PATH_A)
+		return;
+	else if (dm->num_rf_path == 2 && path > RF_PATH_B)
+		return;
+	else if (dm->num_rf_path == 3 && path > RF_PATH_C)
+		return;
+	else if (dm->num_rf_path == 4 && path > RF_PATH_D)
+		return;
+
+	for (rate_idx = 0; rate_idx <= 0x53; rate_idx++) {
+		if (!(dm->support_ic_type & PHYDM_IC_ABOVE_3SS) &&
+		    ((rate_idx >= ODM_RATEMCS16 &&
+		    rate_idx < ODM_RATEVHTSS1MCS0) ||
+		    rate_idx >= ODM_RATEVHTSS3MCS0))
+			continue;
+
+		if (rate_idx == ODM_RATE1M)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "  %-35s\n", "CCK====>");
+		else if (rate_idx == ODM_RATE6M)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "OFDM====>");
+		else if (rate_idx == ODM_RATEMCS0)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "HT 1ss====>");
+		else if (rate_idx == ODM_RATEMCS8)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "HT 2ss====>");
+		else if (rate_idx == ODM_RATEMCS16)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "HT 3ss====>");
+		else if (rate_idx == ODM_RATEMCS24)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "HT 4ss====>");
+		else if (rate_idx == ODM_RATEVHTSS1MCS0)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "VHT 1ss====>");
+		else if (rate_idx == ODM_RATEVHTSS2MCS0)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "VHT 2ss====>");
+		else if (rate_idx == ODM_RATEVHTSS3MCS0)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "VHT 3ss====>");
+		else if (rate_idx == ODM_RATEVHTSS4MCS0)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\n  %-35s\n", "VHT 4ss====>");
+
+		txagc = phydm_api_get_txagc(dm, (enum rf_path)path, rate_idx);
+		if (config_phydm_read_txagc_check(txagc))
+			PDM_SNPF(out_len, used, output + used,
+				 out_len - used, "  0x%02x    ", txagc);
+		else
+			PDM_SNPF(out_len, used, output + used,
+				 out_len - used, "  0x%s    ", "xx");
+	}
+#endif
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_get_txagc(void *dm_void, u32 *_used, char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/* path-A */
+	PDM_SNPF(out_len, used, output + used, out_len - used, "%-35s\n",
+		 "path-A====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_A, &used, output, &out_len);
+
+	/* path-B */
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%-35s\n",
+		 "path-B====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_B, &used, output, &out_len);
+
+	/* path-C */
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%-35s\n",
+		 "path-C====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_C, &used, output, &out_len);
+
+	/* path-D */
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n%-35s\n",
+		 "path-D====================");
+	phydm_get_per_path_txagc(dm, RF_PATH_D, &used, output, &out_len);
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_set_txagc(void *dm_void, u32 *const val, u32 *_used,
+		     char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i = 0;
+	u32 pow = 0; /*power index*/
+	u8 vht_start_rate = ODM_RATEVHTSS1MCS0;
+	boolean rpt = true;
+	enum rf_path path = RF_PATH_A;
+
+/*@val[1] = path*/
+/*@val[2] = hw_rate*/
+/*@val[3] = power_index*/
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+	if (!(dm->support_ic_type & CMN_API_SUPPORT_IC))
+		return;
+
+	path = (enum rf_path)val[1];
+
+	if (val[1] >= dm->num_rf_path) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Write path-%d rate_idx-0x%x fail\n", val[1], val[2]);
+	} else if ((u8)val[2] != 0xff) {
+		if (phydm_api_set_txagc(dm, val[3], path, (u8)val[2], true))
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Write path-%d rate_idx-0x%x = 0x%x\n",
+				 val[1], val[2], val[3]);
+		else
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Write path-%d rate index-0x%x fail\n",
+				 val[1], val[2]);
+	} else {
+
+		if (dm->support_ic_type &
+		    (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8195B)) {
+			pow = (val[3] & 0x3f);
+			pow = BYTE_DUPLICATE_2_DWORD(pow);
+
+			for (i = 0; i < ODM_RATEVHTSS2MCS9; i += 4)
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 0);
+		} else if (dm->support_ic_type &
+			   (ODM_RTL8197F | ODM_RTL8192F)) {
+			pow = (val[3] & 0x3f);
+			for (i = 0; i <= ODM_RATEMCS15; i++)
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 0);
+		} else if (dm->support_ic_type & ODM_RTL8198F) {
+			pow = (val[3] & 0x7f);
+			for (i = 0; i <= ODM_RATEVHTSS4MCS9; i++)
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 0);
+		} else if (dm->support_ic_type &
+			   (ODM_RTL8822C | ODM_RTL8812F)) {
+			pow = (val[3] & 0x7f);
+			for (i = 0; i <= ODM_RATEMCS15; i++)
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 0);
+			for (i = vht_start_rate; i <= ODM_RATEVHTSS2MCS9; i++)
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 0);
+		} else if (dm->support_ic_type &
+			   (ODM_RTL8721D)) {
+			pow = (val[3] & 0x3f);
+			for (i = 0; i <= ODM_RATEMCS7; i++)
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 0);
+		}
+
+		if (rpt)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Write all TXAGC of path-%d = 0x%x\n",
+				 val[1], val[3]);
+		else
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Write all TXAGC of path-%d fail\n", val[1]);
+	}
+
+#endif
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_shift_txagc(void *dm_void, u32 *const val, u32 *_used, char *output,
+		       u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i = 0;
+	u32 pow = 0; /*Power index*/
+	boolean rpt = true;
+	u8 vht_start_rate = ODM_RATEVHTSS1MCS0;
+	enum rf_path path = RF_PATH_A;
+
+#ifdef PHYDM_COMMON_API_SUPPORT
+	if (!(dm->support_ic_type & CMN_API_SUPPORT_IC))
+		return;
+
+	if (val[1] >= dm->num_rf_path) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Write path-%d fail\n", val[1]);
+		return;
+	}
+
+	path = (enum rf_path)val[1];
+
+	if ((u8)val[2] == 0) {
+	/*@{0:-, 1:+} {Pwr Offset}*/
+		if (dm->support_ic_type & (ODM_RTL8195B | ODM_RTL8821C)) {
+			for (i = 0; i <= ODM_RATEMCS7; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) - val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+			for (i = vht_start_rate; i <= ODM_RATEVHTSS1MCS9; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) - val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		} else if (dm->support_ic_type & (ODM_RTL8822B)) {
+			for (i = 0; i <= ODM_RATEMCS15; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) - val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+			for (i = vht_start_rate; i <= ODM_RATEVHTSS2MCS9; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) - val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		} else if (dm->support_ic_type &
+			   (ODM_RTL8197F | ODM_RTL8192F)) {
+			for (i = 0; i <= ODM_RATEMCS15; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) - val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			rpt &= phydm_api_shift_txagc(dm, val[3], path, 0);
+		} else if (dm->support_ic_type &
+			   (ODM_RTL8721D)) {
+			for (i = 0; i <= ODM_RATEMCS7; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) - val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		}
+	} else if ((u8)val[2] == 1) {
+	/*@{0:-, 1:+} {Pwr Offset}*/
+		if (dm->support_ic_type & (ODM_RTL8195B | ODM_RTL8821C)) {
+			for (i = 0; i <= ODM_RATEMCS7; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) + val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+			for (i = vht_start_rate; i <= ODM_RATEVHTSS1MCS9; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) + val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		} else if (dm->support_ic_type & (ODM_RTL8822B)) {
+			for (i = 0; i <= ODM_RATEMCS15; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) + val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+			for (i = vht_start_rate; i <= ODM_RATEVHTSS2MCS9; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) + val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		} else if (dm->support_ic_type &
+			   (ODM_RTL8197F | ODM_RTL8192F)) {
+			for (i = 0; i <= ODM_RATEMCS15; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) + val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		} else if (dm->support_ic_type & ODM_RTL8721D) {
+			for (i = 0; i <= ODM_RATEMCS7; i++) {
+				pow = phydm_api_get_txagc(dm, path, i) + val[3];
+				rpt &= phydm_api_set_txagc(dm, pow, path, i, 1);
+			}
+		} else if (dm->support_ic_type &
+			   (ODM_RTL8822C | ODM_RTL8812F)) {
+			rpt &= phydm_api_shift_txagc(dm, val[3], path, 1);
+		}
+	}
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[All rate] Set Path-%d Pow_idx: %s %d\n",
+			 val[1], (val[2] ? "+" : "-"), val[3]);
+	else
+	#endif
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[All rate] Set Path-%d Pow_idx: %s %d(%d.%s dB)\n",
+			 val[1], (val[2] ? "+" : "-"), val[3], val[3] >> 1,
+			 ((val[3] & 1) ? "5" : "0"));
+
+#endif
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_set_txagc_dbg(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 var1[10] = {0};
+	char help[] = "-h";
+	u8 i = 0, input_idx = 0;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+			input_idx++;
+		}
+	}
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{Dis:0, En:1} {pathA~D(0~3)} {rate_idx(Hex), All_rate:0xff} {txagc_idx (Hex)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{Pwr Shift(All rate):2} {pathA~D(0~3)} {0:-, 1:+} {Pwr Offset(Hex)}\n");
+	} else if (var1[0] == 0) {
+		dm->is_disable_phy_api = false;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Disable API debug mode\n");
+	} else if (var1[0] == 1) {
+		dm->is_disable_phy_api = false;
+		phydm_set_txagc(dm, (u32 *)var1, &used, output, &out_len);
+		dm->is_disable_phy_api = true;
+	} else if (var1[0] == 2) {
+		PHYDM_SSCANF(input[4], DCMD_HEX, &var1[3]);
+		dm->is_disable_phy_api = false;
+		phydm_shift_txagc(dm, (u32 *)var1, &used, output, &out_len);
+		dm->is_disable_phy_api = true;
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_debug_trace(void *dm_void, char input[][16], u32 *_used,
+		       char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u64 pre_debug_components, one = 1;
+	u64 comp = 0;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 val[10] = {0};
+	u8 i;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &val[i]);
+	}
+	comp = dm->debug_components;
+	pre_debug_components = dm->debug_components;
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "\n================================\n");
+	if (val[0] == 100) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[DBG MSG] Component Selection\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "================================\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "00. (( %s ))DIG\n",
+			 ((comp & DBG_DIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "01. (( %s ))RA_MASK\n",
+			 ((comp & DBG_RA_MASK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "02. (( %s ))DYN_TXPWR\n",
+			 ((comp & DBG_DYN_TXPWR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "03. (( %s ))FA_CNT\n",
+			 ((comp & DBG_FA_CNT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "04. (( %s ))RSSI_MNTR\n",
+			 ((comp & DBG_RSSI_MNTR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "05. (( %s ))CCKPD\n",
+			 ((comp & DBG_CCKPD) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "06. (( %s ))ANT_DIV\n",
+			 ((comp & DBG_ANT_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "07. (( %s ))SMT_ANT\n",
+			 ((comp & DBG_SMT_ANT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "08. (( %s ))PWR_TRAIN\n",
+			 ((comp & DBG_PWR_TRAIN) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "09. (( %s ))RA\n",
+			 ((comp & DBG_RA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "10. (( %s ))PATH_DIV\n",
+			 ((comp & DBG_PATH_DIV) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "11. (( %s ))DFS\n",
+			 ((comp & DBG_DFS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "12. (( %s ))DYN_ARFR\n",
+			 ((comp & DBG_DYN_ARFR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "13. (( %s ))ADAPTIVITY\n",
+			 ((comp & DBG_ADPTVTY) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "14. (( %s ))CFO_TRK\n",
+			 ((comp & DBG_CFO_TRK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "15. (( %s ))ENV_MNTR\n",
+			 ((comp & DBG_ENV_MNTR) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "16. (( %s ))PRI_CCA\n",
+			 ((comp & DBG_PRI_CCA) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "17. (( %s ))ADPTV_SOML\n",
+			 ((comp & DBG_ADPTV_SOML) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "18. (( %s ))LNA_SAT_CHK\n",
+			 ((comp & DBG_LNA_SAT_CHK) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "20. (( %s ))PHY_STATUS\n",
+			 ((comp & DBG_PHY_STATUS) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "21. (( %s ))TMP\n",
+			 ((comp & DBG_TMP) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "22. (( %s ))FW_DBG_TRACE\n",
+			 ((comp & DBG_FW_TRACE) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "23. (( %s ))TXBF\n",
+			 ((comp & DBG_TXBF) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "24. (( %s ))COMMON_FLOW\n",
+			 ((comp & DBG_COMMON_FLOW) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "28. (( %s ))PHY_CONFIG\n",
+			 ((comp & ODM_PHY_CONFIG) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "29. (( %s ))INIT\n",
+			 ((comp & ODM_COMP_INIT) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "30. (( %s ))COMMON\n",
+			 ((comp & DBG_CMN) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "31. (( %s ))API\n",
+			 ((comp & ODM_COMP_API) ? ("V") : (".")));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "================================\n");
+
+	} else if (val[0] == 101) {
+		dm->debug_components = 0;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Disable all debug components\n");
+	} else {
+		if (val[1] == 1) /*@enable*/
+			dm->debug_components |= (one << val[0]);
+		else if (val[1] == 2) /*@disable*/
+			dm->debug_components &= ~(one << val[0]);
+		else
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[Warning]  1:on,  2:off\n");
+
+		if ((BIT(val[0]) == DBG_PHY_STATUS) && val[1] == 1) {
+			dm->phy_dbg_info.show_phy_sts_all_pkt = (u8)val[2];
+			dm->phy_dbg_info.show_phy_sts_max_cnt = (u16)val[3];
+
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "show_all_pkt=%d, show_max_num=%d\n\n",
+				 dm->phy_dbg_info.show_phy_sts_all_pkt,
+				 dm->phy_dbg_info.show_phy_sts_max_cnt);
+
+		} else if ((BIT(val[0]) == DBG_CMN) && (val[1] == 1)) {
+			dm->cmn_dbg_msg_period = (u8)val[2];
+
+			if (dm->cmn_dbg_msg_period < PHYDM_WATCH_DOG_PERIOD)
+				dm->cmn_dbg_msg_period = PHYDM_WATCH_DOG_PERIOD;
+
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "cmn_dbg_msg_period=%d\n",
+				 dm->cmn_dbg_msg_period);
+		}
+	}
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "pre-DbgComponents = 0x%llx\n", pre_debug_components);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "Curr-DbgComponents = 0x%llx\n", dm->debug_components);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "================================\n");
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_fw_debug_trace(void *dm_void, char input[][16], u32 *_used,
+			  char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 val[10] = {0};
+	u8 i, input_idx = 0;
+	char help[] = "-h";
+	u32 pre_fw_debug_components = 0, one = 1;
+	u32 comp = 0;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &val[i]);
+			input_idx++;
+		}
+	}
+
+	if (input_idx == 0)
+		return;
+
+	pre_fw_debug_components = dm->fw_debug_components;
+	comp = dm->fw_debug_components;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "{dbg_comp} {1:en, 2:dis} {mode} {macid}\n");
+	} else {
+		if (val[0] == 101) {
+			dm->fw_debug_components = 0;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "%s\n", "Clear all fw debug components");
+		} else {
+			if (val[1] == 1) /*@enable*/
+				dm->fw_debug_components |= (one << val[0]);
+			else if (val[1] == 2) /*@disable*/
+				dm->fw_debug_components &= ~(one << val[0]);
+			else
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used, "%s\n",
+					 "[Warning!!!]  1:enable,  2:disable");
+		}
+
+		comp = dm->fw_debug_components;
+
+		if (comp == 0) {
+			dm->debug_components &= ~DBG_FW_TRACE;
+			/*@H2C to enable C2H Msg*/
+			phydm_fw_trace_en_h2c(dm, false, comp, val[2], val[3]);
+		} else {
+			dm->debug_components |= DBG_FW_TRACE;
+			/*@H2C to enable C2H Msg*/
+			phydm_fw_trace_en_h2c(dm, true, comp, val[2], val[3]);
+		}
+	}
+}
+
+#if (ODM_IC_11N_SERIES_SUPPORT)
+void phydm_dump_bb_reg_n(void *dm_void, u32 *_used, char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 addr = 0;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	/*@For Nseries IC we only need to dump page8 to pageF using 3 digits*/
+	for (addr = 0x800; addr < 0xfff; addr += 4) {
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%03x 0x%08x\n",
+			      addr, odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+}
+#endif
+
+#if (ODM_IC_11AC_SERIES_SUPPORT)
+void phydm_dump_bb_reg_ac(void *dm_void, u32 *_used, char *output,
+			  u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 addr = 0;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	for (addr = 0x800; addr < 0xfff; addr += 4) {
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%04x 0x%08x\n",
+			      addr, odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	if (!(dm->support_ic_type &
+	    (ODM_RTL8822B | ODM_RTL8814A | ODM_RTL8821C)))
+		goto rpt_reg;
+
+	if (dm->rf_type > RF_2T2R) {
+		for (addr = 0x1800; addr < 0x18ff; addr += 4)
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%04x 0x%08x\n",
+				      addr,
+				      odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	if (dm->rf_type > RF_3T3R) {
+		for (addr = 0x1a00; addr < 0x1aff; addr += 4)
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%04x 0x%08x\n",
+				      addr,
+				      odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+
+	for (addr = 0x1900; addr < 0x19ff; addr += 4)
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%04x 0x%08x\n",
+			      addr, odm_get_bb_reg(dm, addr, MASKDWORD));
+
+	for (addr = 0x1c00; addr < 0x1cff; addr += 4)
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%04x 0x%08x\n",
+			      addr, odm_get_bb_reg(dm, addr, MASKDWORD));
+
+	for (addr = 0x1f00; addr < 0x1fff; addr += 4)
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%04x 0x%08x\n",
+			      addr, odm_get_bb_reg(dm, addr, MASKDWORD));
+
+rpt_reg:
+
+	*_used = used;
+	*_out_len = out_len;
+}
+
+#endif
+
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_dump_bb_reg_jgr3(void *dm_void, u32 *_used, char *output,
+			    u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 addr = 0;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		for (addr = 0x800; addr < 0xdff; addr += 4)
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%04x 0x%08x\n", addr,
+				      odm_get_bb_reg(dm, addr, MASKDWORD));
+
+		for (addr = 0x1800; addr < 0x1aff; addr += 4)
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%04x 0x%08x\n", addr,
+				      odm_get_bb_reg(dm, addr, MASKDWORD));
+
+		for (addr = 0x1c00; addr < 0x1eff; addr += 4)
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%04x 0x%08x\n", addr,
+				      odm_get_bb_reg(dm, addr, MASKDWORD));
+
+		for (addr = 0x4000; addr < 0x41ff; addr += 4)
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%04x 0x%08x\n", addr,
+				      odm_get_bb_reg(dm, addr, MASKDWORD));
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_dump_bb_reg2_jgr3(void *dm_void, u32 *_used, char *output,
+			     u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 addr = 0;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	{
-		struct _ADAPTER		*adapter = p_dm->adapter;
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d (Subversion: %d)\n", "FW Ver", adapter->MgntInfo.FirmwareVersion, adapter->MgntInfo.FirmwareSubVersion));
-	}
-#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	{
-		struct rtl8192cd_priv *priv = p_dm->priv;
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d (Subversion: %d)\n", "FW Ver", priv->pshare->fw_version, priv->pshare->fw_sub_version));
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+		if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+			for (addr = 0x5000; addr < 0x53ff; addr += 4)
+				PDM_VAST_SNPF(out_len, used, output + used,
+					      out_len - used, "0x%04x 0x%08x\n",
+					      addr, odm_get_bb_reg(dm, addr,
+					      MASKDWORD));
+		}
+		#endif
+		/* @Do not change the order of page-2C/2D*/
+		for (addr = 0x2c00; addr < 0x2dff; addr += 4)
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%04x 0x%08x\n", addr,
+				      odm_get_bb_reg(dm, addr, MASKDWORD));
 	}
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	{
-		struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
-		struct rtl_hal *rtlhal = rtl_hal(rtlpriv);
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d (Subversion: %d)\n", "FW Ver", rtlhal->fw_version, rtlhal->fw_subversion));
-	}
-#else
-	{
-		struct _ADAPTER		*adapter = p_dm->adapter;
-		HAL_DATA_TYPE		*p_hal_data = GET_HAL_DATA(adapter);
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %d (Subversion: %d)\n", "FW Ver", p_hal_data->firmware_version, p_hal_data->firmware_sub_version));
-	}
-#endif
-	/* 1 PHY DM version List */
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-35s\n", "% PHYDM version %"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Code base", PHYDM_CODE_BASE));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Release Date", PHYDM_RELEASE_DATE));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Adaptivity", ADAPTIVITY_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "DIG", DIG_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "CFO Tracking", CFO_TRACKING_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "AntDiv", ANTDIV_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Dynamic TxPower", DYNAMIC_TXPWR_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "RA Info", RAINFO_VERSION));
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "AntDetect", ANTDECT_VERSION));
+	*_used = used;
+	*_out_len = out_len;
+}
 #endif
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "ACS", ACS_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "PathDiv", PATHDIV_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "LA mode", DYNAMIC_LA_MODE));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "Primary CCA", PRIMARYCCA_VERSION));
-	PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "DFS", DFS_VERSION));
 
-#if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "PHY config 8822B", PHY_CONFIG_VERSION_8822B));
+void phydm_dump_bb_reg(void *dm_void, u32 *_used, char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+		      "BB==========\n");
 
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+#if (ODM_IC_11N_SERIES_SUPPORT)
+		phydm_dump_bb_reg_n(dm, &used, output, &out_len);
+#else
+		;
+#endif
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	else if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_dump_bb_reg_jgr3(dm, &used, output, &out_len);
 #endif
-#if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s: %s\n", "PHY config 8197F", PHY_CONFIG_VERSION_8197F));
+	else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+#if (ODM_IC_11AC_SERIES_SUPPORT)
+		phydm_dump_bb_reg_ac(dm, &used, output, &out_len);
+#else
+		;
 #endif
+
 	*_used = used;
 	*_out_len = out_len;
-#endif /*#if CONFIG_PHYDM_DEBUG_FUNCTION*/
 }
 
-#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-void
-phydm_fw_trace_en_h2c(
-	void		*p_dm_void,
-	boolean		enable,
-	u32		fw_debug_component,
-	u32		monitor_mode,
-	u32		macid
-)
+void phydm_dump_rf_reg(void *dm_void, u32 *_used, char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			h2c_parameter[7] = {0};
-	u8			cmd_length;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 addr = 0;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 reg = 0;
 
-	if (p_dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+	/* @dump RF register */
+	PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+		      "RF-A==========\n");
 
-		h2c_parameter[0] = enable;
-		h2c_parameter[1] = (u8)(fw_debug_component & MASKBYTE0);
-		h2c_parameter[2] = (u8)((fw_debug_component & MASKBYTE1) >> 8);
-		h2c_parameter[3] = (u8)((fw_debug_component & MASKBYTE2) >> 16);
-		h2c_parameter[4] = (u8)((fw_debug_component & MASKBYTE3) >> 24);
-		h2c_parameter[5] = (u8)monitor_mode;
-		h2c_parameter[6] = (u8)macid;
-		cmd_length = 7;
+	for (addr = 0; addr < 0xFF; addr++) {
+		reg = odm_get_rf_reg(dm, RF_PATH_A, addr, RFREG_MASK);
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%02x 0x%05x\n", addr, reg);
+		}
 
-	} else {
+#ifdef PHYDM_COMPILE_ABOVE_2SS
+	if (dm->rf_type > RF_1T1R) {
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "RF-B==========\n");
 
-		h2c_parameter[0] = enable;
-		h2c_parameter[1] = (u8)monitor_mode;
-		h2c_parameter[2] = (u8)macid;
-		cmd_length = 3;
+		for (addr = 0; addr < 0xFF; addr++) {
+			reg = odm_get_rf_reg(dm, RF_PATH_B, addr, RFREG_MASK);
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%02x 0x%05x\n",
+				      addr, reg);
+		}
 	}
+#endif
 
+#ifdef PHYDM_COMPILE_ABOVE_3SS
+	if (dm->rf_type > RF_2T2R) {
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "RF-C==========\n");
 
-	PHYDM_DBG(p_dm, DBG_FW_TRACE, ("---->\n"));
-	if (monitor_mode == 0)
-		PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[H2C] FW_debug_en: (( %d ))\n", enable));
-	else
-		PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[H2C] FW_debug_en: (( %d )), mode: (( %d )), macid: (( %d ))\n", enable, monitor_mode, macid));
-	odm_fill_h2c_cmd(p_dm, PHYDM_H2C_FW_TRACE_EN, cmd_length, h2c_parameter);
-}
+		for (addr = 0; addr < 0xFF; addr++) {
+			reg = odm_get_rf_reg(dm, RF_PATH_C, addr, RFREG_MASK);
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%02x 0x%05x\n",
+				      addr, reg);
+		}
+	}
+#endif
 
-void
-phydm_get_per_path_txagc(
-	void			*p_dm_void,
-	u8			path,
-	u32			*_used,
-	char				*output,
-	u32			*_out_len
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			rate_idx;
-	u8			txagc;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
+#ifdef PHYDM_COMPILE_ABOVE_4SS
+	if (dm->rf_type > RF_3T3R) {
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "RF-D==========\n");
 
-#ifdef PHYDM_COMMON_API_SUPPORT
-	if (((p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) && (path <= RF_PATH_B)) ||
-		((p_dm->support_ic_type & (ODM_RTL8821C)) && (path <= RF_PATH_A))) {
-		for (rate_idx = 0; rate_idx <= 0x53; rate_idx++) {
-			if (rate_idx == ODM_RATE1M)
-				PHYDM_SNPRINTF((output + used, out_len - used, "  %-35s\n", "CCK====>"));
-			else if (rate_idx == ODM_RATE6M)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "OFDM====>"));
-			else if (rate_idx == ODM_RATEMCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 1ss====>"));
-			else if (rate_idx == ODM_RATEMCS8)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 2ss====>"));
-			else if (rate_idx == ODM_RATEMCS16)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 3ss====>"));
-			else if (rate_idx == ODM_RATEMCS24)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "HT 4ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS1MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 1ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS2MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 2ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS3MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 3ss====>"));
-			else if (rate_idx == ODM_RATEVHTSS4MCS0)
-				PHYDM_SNPRINTF((output + used, out_len - used, "\n  %-35s\n", "VHT 4ss====>"));
-
-			txagc = phydm_api_get_txagc(p_dm, (enum rf_path) path, rate_idx);
-			if (config_phydm_read_txagc_check(txagc))
-				PHYDM_SNPRINTF((output + used, out_len - used, "  0x%02x    ", txagc));
-			else
-				PHYDM_SNPRINTF((output + used, out_len - used, "  0x%s    ", "xx"));
+		for (addr = 0; addr < 0xFF; addr++) {
+			reg = odm_get_rf_reg(dm, RF_PATH_D, addr, RFREG_MASK);
+			PDM_VAST_SNPF(out_len, used, output + used,
+				      out_len - used, "0x%02x 0x%05x\n",
+				      addr, reg);
 		}
 	}
 #endif
 
 	*_used = used;
 	*_out_len = out_len;
-
 }
 
-
-void
-phydm_get_txagc(
-	void			*p_dm_void,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+void phydm_dump_mac_reg(void *dm_void, u32 *_used, char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-
-	/* path-A */
-	PHYDM_SNPRINTF((output + used, out_len - used, "%-35s\n", "path-A===================="));
-	phydm_get_per_path_txagc(p_dm, RF_PATH_A, &used, output, &out_len);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 addr = 0;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
 
-	/* path-B */
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%-35s\n", "path-B===================="));
-	phydm_get_per_path_txagc(p_dm, RF_PATH_B, &used, output, &out_len);
+	/* @dump MAC register */
+	PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+		      "MAC==========\n");
 
-	/* path-C */
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%-35s\n", "path-C===================="));
-	phydm_get_per_path_txagc(p_dm, RF_PATH_C, &used, output, &out_len);
+	for (addr = 0; addr < 0x7ff; addr += 4)
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%04x 0x%08x\n",
+			      addr, odm_get_bb_reg(dm, addr, MASKDWORD));
 
-	/* path-D */
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%-35s\n", "path-D===================="));
-	phydm_get_per_path_txagc(p_dm, RF_PATH_D, &used, output, &out_len);
+	for (addr = 0x1000; addr < 0x17ff; addr += 4)
+		PDM_VAST_SNPF(out_len, used, output + used, out_len - used,
+			      "0x%04x 0x%08x\n",
+			      addr, odm_get_bb_reg(dm, addr, MASKDWORD));
 
 	*_used = used;
 	*_out_len = out_len;
-
 }
 
-void
-phydm_set_txagc(
-	void			*p_dm_void,
-	u32			*const dm_value,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
+void phydm_dump_reg(void *dm_void, char input[][16], u32 *_used, char *output,
+		    u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-
-	/*dm_value[1] = path*/
-	/*dm_value[2] = hw_rate*/
-	/*dm_value[3] = power_index*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 addr = 0;
 
-#ifdef PHYDM_COMMON_API_SUPPORT
-	if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)) {
-		if (dm_value[1] <= 1) {
-			if ((u8)dm_value[2] != 0xff) {
-				if (phydm_api_set_txagc(p_dm, dm_value[3], (enum rf_path) dm_value[1], (u8)dm_value[2], true))
-					PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s%x%s%x\n", "Write path-", dm_value[1], "rate index-0x", dm_value[2], " = 0x", dm_value[3]));
-				else
-					PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s%x%s\n", "Write path-", (dm_value[1] & 0x1), "rate index-0x", (dm_value[2] & 0x7f), " fail"));
-			} else {
-				u8	i;
-				u32	power_index;
-				boolean	status = true;
-
-				power_index = (dm_value[3] & 0x3f);
-
-				if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
-					power_index = (power_index << 24) | (power_index << 16) | (power_index << 8) | (power_index);
-
-					for (i = 0; i < ODM_RATEVHTSS2MCS9; i += 4)
-						status = (status & phydm_api_set_txagc(p_dm, power_index, (enum rf_path) dm_value[1], i, false));
-				} else if (p_dm->support_ic_type & ODM_RTL8197F) {
-					for (i = 0; i <= ODM_RATEMCS15; i++)
-						status = (status & phydm_api_set_txagc(p_dm, power_index, (enum rf_path) dm_value[1], i, false));
-				}
+	if (input[1])
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 
-				if (status)
-					PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s%x\n", "Write all TXAGC of path-", dm_value[1], " = 0x", dm_value[3]));
-				else
-					PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s\n", "Write all TXAGC of path-", dm_value[1], " fail"));
-			}
-		} else
-			PHYDM_SNPRINTF((output + used, out_len - used, "  %s%d   %s%x%s\n", "Write path-", (dm_value[1] & 0x1), "rate index-0x", (dm_value[2] & 0x7f), " fail"));
-	}
-#endif
-	*_used = used;
-	*_out_len = out_len;
-}
+	if ((strcmp(input[1], help) == 0)) {
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "dumpreg {0:all, 1:BB, 2:RF, 3:MAC 4:BB2 for jgr3}\n");
+		else
+		#endif
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "dumpreg {0:all, 1:BB, 2:RF, 3:MAC}\n");
+	} else if (var1[0] == 0) {
+		phydm_dump_mac_reg(dm, &used, output, &out_len);
+		phydm_dump_bb_reg(dm, &used, output, &out_len);
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			phydm_dump_bb_reg2_jgr3(dm, &used, output, &out_len);
+		#endif
 
-void
-phydm_debug_trace(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u64			pre_debug_components, one = 1;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-
-	pre_debug_components = p_dm->debug_components;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%s\n", "================================"));
-	if (dm_value[0] == 100) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[Debug Message] PhyDM Selection"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "00. (( %s ))DIG\n", ((p_dm->debug_components & DBG_DIG) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "01. (( %s ))RA_MASK\n", ((p_dm->debug_components & DBG_RA_MASK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "02. (( %s ))DYNAMIC_TXPWR\n", ((p_dm->debug_components & DBG_DYN_TXPWR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "03. (( %s ))FA_CNT\n", ((p_dm->debug_components & DBG_FA_CNT) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "04. (( %s ))RSSI_MONITOR\n", ((p_dm->debug_components & DBG_RSSI_MNTR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "05. (( %s ))CCKPD\n", ((p_dm->debug_components & DBG_CCKPD) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "06. (( %s ))ANT_DIV\n", ((p_dm->debug_components & DBG_ANT_DIV) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "07. (( %s ))SMT_ANT\n", ((p_dm->debug_components & DBG_SMT_ANT) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "08. (( %s ))PWR_TRAIN\n", ((p_dm->debug_components & F08_PWR_TRAIN) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "09. (( %s ))RA\n", ((p_dm->debug_components & DBG_RA) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "10. (( %s ))PATH_DIV\n", ((p_dm->debug_components & DBG_PATH_DIV) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "11. (( %s ))DFS\n", ((p_dm->debug_components & DBG_DFS) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "12. (( %s ))DYN_ARFR\n", ((p_dm->debug_components & DBG_DYN_ARFR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "13. (( %s ))ADAPTIVITY\n", ((p_dm->debug_components & DBG_ADPTVTY) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "14. (( %s ))CFO_TRK\n", ((p_dm->debug_components & DBG_CFO_TRK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "15. (( %s ))ENV_MNTR\n", ((p_dm->debug_components & DBG_ENV_MNTR) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "16. (( %s ))PRI_CCA\n", ((p_dm->debug_components & DBG_PRI_CCA) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "17. (( %s ))ADPTV_SOML\n", ((p_dm->debug_components & DBG_ADPTV_SOML) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "18. (( %s ))LNA_SAT_CHK\n", ((p_dm->debug_components & DBG_LNA_SAT_CHK) ? ("V") : ("."))));
-		/*PHYDM_SNPRINTF((output + used, out_len - used, "19. (( %s ))TBD1\n", ((p_dm->debug_components & DBG_TBD1) ? ("V") : ("."))));*/
-		PHYDM_SNPRINTF((output + used, out_len - used, "20. (( %s ))DRP\n", ((p_dm->debug_components & DBG_DYN_RX_PATH) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "21. (( %s ))TMP\n", ((p_dm->debug_components & DBG_TMP) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "22. (( %s ))FW_DEBUG_TRACE\n", ((p_dm->debug_components & DBG_FW_TRACE) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "23. (( %s ))TXBF\n", ((p_dm->debug_components & DBG_TXBF) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "24. (( %s ))COMMON_FLOW\n", ((p_dm->debug_components & DBG_COMMON_FLOW) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "25. (( %s ))TX_PWR_TRK\n", ((p_dm->debug_components & ODM_COMP_TX_PWR_TRACK) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "26. (( %s ))CALIBRATION\n", ((p_dm->debug_components & ODM_COMP_CALIBRATION) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "27. (( %s ))MP\n", ((p_dm->debug_components & ODM_COMP_MP) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "28. (( %s ))PHY_CONFIG\n", ((p_dm->debug_components & ODM_PHY_CONFIG) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "29. (( %s ))INIT\n", ((p_dm->debug_components & ODM_COMP_INIT) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "30. (( %s ))COMMON\n", ((p_dm->debug_components & ODM_COMP_COMMON) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "31. (( %s ))API\n", ((p_dm->debug_components & ODM_COMP_API) ? ("V") : ("."))));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-
-	} else if (dm_value[0] == 101) {
-		p_dm->debug_components = 0;
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "Disable all debug components"));
-	} else {
-		if (dm_value[1] == 1)   /*enable*/
-			p_dm->debug_components |= (one << dm_value[0]);
-		else if (dm_value[1] == 2)   /*disable*/
-			p_dm->debug_components &= ~(one << dm_value[0]);
+		phydm_dump_rf_reg(dm, &used, output, &out_len);
+	} else if (var1[0] == 1) {
+		phydm_dump_bb_reg(dm, &used, output, &out_len);
+	} else if (var1[0] == 2) {
+		phydm_dump_rf_reg(dm, &used, output, &out_len);
+	} else if (var1[0] == 3) {
+		phydm_dump_mac_reg(dm, &used, output, &out_len);
+	} else if (var1[0] == 4) {
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			phydm_dump_bb_reg2_jgr3(dm, &used, output, &out_len);
 		else
-			PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[Warning!!!]  1:enable,  2:disable"));
+		#endif
+			;
 	}
-	PHYDM_SNPRINTF((output + used, out_len - used, "pre-DbgComponents = 0x%llx\n", pre_debug_components));
-	PHYDM_SNPRINTF((output + used, out_len - used, "Curr-DbgComponents = 0x%llx\n", p_dm->debug_components));
-	PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_fw_debug_trace(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char			*output,
-	u32		*_out_len
-)
+void phydm_enable_big_jump(void *dm_void, char input[][16], u32 *_used,
+			   char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			pre_fw_debug_components, one = 1;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-
-	pre_fw_debug_components = p_dm->fw_debug_components;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n%s\n", "================================"));
-	if (dm_value[0] == 100) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[FW Debug Component]"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "00. (( %s ))RA\n", ((p_dm->fw_debug_components & PHYDM_FW_COMP_RA) ? ("V") : ("."))));
-
-		if (p_dm->support_ic_type & PHYDM_IC_3081_SERIES) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "01. (( %s ))MU\n", ((p_dm->fw_debug_components & PHYDM_FW_COMP_MU) ? ("V") : ("."))));
-			PHYDM_SNPRINTF((output + used, out_len - used, "02. (( %s ))path Div\n", ((p_dm->fw_debug_components & PHYDM_FW_COMP_PATH_DIV) ? ("V") : ("."))));
-			PHYDM_SNPRINTF((output + used, out_len - used, "03. (( %s ))Power training\n", ((p_dm->fw_debug_components & PHYDM_FW_COMP_PT) ? ("V") : ("."))));
-		}
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "================================"));
-
-	} else {
-		if (dm_value[0] == 101) {
-			p_dm->fw_debug_components = 0;
-			PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "Clear all fw debug components"));
-		} else {
-			if (dm_value[1] == 1)   /*enable*/
-				p_dm->fw_debug_components |= (one << dm_value[0]);
-			else if (dm_value[1] == 2)   /*disable*/
-				p_dm->fw_debug_components &= ~(one << dm_value[0]);
-			else
-				PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "[Warning!!!]  1:enable,  2:disable"));
-		}
+#if (RTL8822B_SUPPORT)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u32 dm_value[10] = {0};
+	u8 i, input_idx = 0;
+	u32 val;
+
+	if (!(dm->support_ic_type & ODM_RTL8822B))
+		return;
 
-		if (p_dm->fw_debug_components == 0) {
-			p_dm->debug_components &= ~DBG_FW_TRACE;
-			phydm_fw_trace_en_h2c(p_dm, false, p_dm->fw_debug_components, dm_value[2], dm_value[3]); /*H2C to enable C2H Msg*/
-		} else {
-			p_dm->debug_components |= DBG_FW_TRACE;
-			phydm_fw_trace_en_h2c(p_dm, true, p_dm->fw_debug_components, dm_value[2], dm_value[3]); /*H2C to enable C2H Msg*/
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
+			input_idx++;
 		}
 	}
-}
 
-void
-phydm_dump_bb_reg(
-	void			*p_dm_void,
-	u32			*_used,
-	char				*output,
-	u32			*_out_len
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			addr = 0;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
+	if (input_idx == 0)
+		return;
 
+	if (dm_value[0] == 0) {
+		dm->dm_dig_table.enable_adjust_big_jump = false;
 
-	/* BB Reg, For Nseries IC we only need to dump page8 to pageF using 3 digits*/
-	for (addr = 0x800; addr < 0xfff; addr += 4) {
-		if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%03x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
-		else
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
+		val = (dig_t->big_jump_step3 << 5) |
+		      (dig_t->big_jump_step2 << 3) |
+		      dig_t->big_jump_step1;
+
+		odm_set_bb_reg(dm, R_0x8c8, 0xfe, val);
+	} else {
+		dm->dm_dig_table.enable_adjust_big_jump = true;
 	}
+#endif
+}
 
-	if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8814A | ODM_RTL8821C)) {
+void phydm_show_rx_rate(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len)
+{
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT || RTL8814B_SUPPORT ||\
+	RTL8195B_SUPPORT || RTL8822C_SUPPORT)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg = &dm->phy_dbg_info;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 var1[10] = {0};
+	char help[] = "-h";
+	u8 i, input_idx = 0;
 
-		if (p_dm->rf_type > RF_2T2R) {
-			for (addr = 0x1800; addr < 0x18ff; addr += 4)
-				PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+			input_idx++;
 		}
+	}
 
-		if (p_dm->rf_type > RF_3T3R) {
-			for (addr = 0x1a00; addr < 0x1aff; addr += 4)
-				PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
-		}
+	if (input_idx == 0)
+		return;
 
-		for (addr = 0x1900; addr < 0x19ff; addr += 4)
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1: show Rx rate, 0:reset counter}\n");
+		*_used = used;
+		*_out_len = out_len;
+		return;
+
+	} else if (var1[0] == 0) {
+		phydm_reset_rx_rate_distribution(dm);
+		*_used = used;
+		*_out_len = out_len;
+		return;
+	}
 
-		for (addr = 0x1c00; addr < 0x1cff; addr += 4)
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
+	/* @==Show SU Rate====================================================*/
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "=====Rx SU rate Statistics=====\n");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "[SU][1SS] {%d, %d, %d, %d | %d, %d, %d, %d | %d, %d}\n",
+		 dbg->num_qry_vht_pkt[0], dbg->num_qry_vht_pkt[1],
+		 dbg->num_qry_vht_pkt[2], dbg->num_qry_vht_pkt[3],
+		 dbg->num_qry_vht_pkt[4], dbg->num_qry_vht_pkt[5],
+		 dbg->num_qry_vht_pkt[6], dbg->num_qry_vht_pkt[7],
+		 dbg->num_qry_vht_pkt[8], dbg->num_qry_vht_pkt[9]);
 
-		for (addr = 0x1f00; addr < 0x1fff; addr += 4)
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[SU][2SS] {%d, %d, %d, %d | %d, %d, %d, %d | %d, %d}\n",
+			 dbg->num_qry_vht_pkt[10], dbg->num_qry_vht_pkt[11],
+			 dbg->num_qry_vht_pkt[12], dbg->num_qry_vht_pkt[13],
+			 dbg->num_qry_vht_pkt[14], dbg->num_qry_vht_pkt[15],
+			 dbg->num_qry_vht_pkt[16], dbg->num_qry_vht_pkt[17],
+			 dbg->num_qry_vht_pkt[18], dbg->num_qry_vht_pkt[19]);
 	}
+	#endif
+	/* @==Show MU Rate====================================================*/
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT) || (defined(PHYSTS_3RD_TYPE_SUPPORT))
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "=====Rx MU rate Statistics=====\n");
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "[MU][1SS] {%d, %d, %d, %d | %d, %d, %d, %d | %d, %d}\n",
+		 dbg->num_mu_vht_pkt[0], dbg->num_mu_vht_pkt[1],
+		 dbg->num_mu_vht_pkt[2], dbg->num_mu_vht_pkt[3],
+		 dbg->num_mu_vht_pkt[4], dbg->num_mu_vht_pkt[5],
+		 dbg->num_mu_vht_pkt[6], dbg->num_mu_vht_pkt[7],
+		 dbg->num_mu_vht_pkt[8], dbg->num_mu_vht_pkt[9]);
 
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_2SS)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[MU][2SS] {%d, %d, %d, %d | %d, %d, %d, %d | %d, %d}\n",
+			 dbg->num_mu_vht_pkt[10], dbg->num_mu_vht_pkt[11],
+			 dbg->num_mu_vht_pkt[12], dbg->num_mu_vht_pkt[13],
+			 dbg->num_mu_vht_pkt[14], dbg->num_mu_vht_pkt[15],
+			 dbg->num_mu_vht_pkt[16], dbg->num_mu_vht_pkt[17],
+			 dbg->num_mu_vht_pkt[18], dbg->num_mu_vht_pkt[19]);
+	}
+	#endif
+#endif
 	*_used = used;
 	*_out_len = out_len;
+#endif
 }
 
-void
-phydm_dump_all_reg(
-	void			*p_dm_void,
-	u32			*_used,
-	char				*output,
-	u32			*_out_len
-)
+void phydm_per_tone_evm(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			addr = 0;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-
-	/* dump MAC register */
-	PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "MAC==========\n"));
-	for (addr = 0; addr < 0x7ff; addr += 4)
-		PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
-
-	for (addr = 0x1000; addr < 0x17ff; addr += 4)
-		PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%04x 0x%08x\n", addr, odm_get_bb_reg(p_dm, addr, MASKDWORD)));
-
-	/* dump BB register */
-	PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "BB==========\n"));
-	phydm_dump_bb_reg(p_dm, &used, output, &out_len);
-
-	/* dump RF register */
-	PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "RF-A==========\n"));
-	for (addr = 0; addr < 0xFF; addr++)
-		PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%02x 0x%05x\n", addr, odm_get_rf_reg(p_dm, RF_PATH_A, addr, RFREGOFFSETMASK)));
-
-	if (p_dm->rf_type > RF_1T1R) {
-		PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "RF-B==========\n"));
-		for (addr = 0; addr < 0xFF; addr++)
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%02x 0x%05x\n", addr, odm_get_rf_reg(p_dm, RF_PATH_B, addr, RFREGOFFSETMASK)));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i, j;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 var1[4] = {0};
+	u32 val, tone_num, round;
+	s8 rxevm_0, rxevm_1;
+	s32 avg_num, evm_tone_0[256] = {0}, evm_tone_1[256] = {0};
+	s32 rxevm_sum_0, rxevm_sum_1;
+
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		pr_debug("n series not support yet !\n");
+		return;
 	}
 
-	if (p_dm->rf_type > RF_2T2R) {
-		PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "RF-C==========\n"));
-		for (addr = 0; addr < 0xFF; addr++)
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%02x 0x%05x\n", addr, odm_get_rf_reg(p_dm, RF_PATH_C, addr, RFREGOFFSETMASK)));
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
 	}
 
-	if (p_dm->rf_type > RF_3T3R) {
-		PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "RF-D==========\n"));
-		for (addr = 0; addr < 0xFF; addr++)
-			PHYDM_VAST_INFO_SNPRINTF((output + used, out_len - used, "0x%02x 0x%05x\n", addr, odm_get_rf_reg(p_dm, RF_PATH_D, addr, RFREGOFFSETMASK)));
-	}
+	avg_num = var1[0];
+	round = var1[1];
 
-	*_used = used;
-	*_out_len = out_len;
-}
+	if (!dm->is_linked) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "No Link !!\n");
 
-void
-phydm_enable_big_jump(
-	struct PHY_DM_STRUCT	*p_dm,
-	boolean		state
-)
-{
-#if (RTL8822B_SUPPORT == 1)
-	struct phydm_dig_struct			*p_dig_t = &p_dm->dm_dig_table;
+		*_used = used;
+		*_out_len = out_len;
+
+		return;
+	}
 
-	if (state == false) {
-		p_dm->dm_dig_table.enable_adjust_big_jump = false;
-		odm_set_bb_reg(p_dm, 0x8c8, 0xfe, ((p_dig_t->big_jump_step3 << 5) | (p_dig_t->big_jump_step2 << 3) | p_dig_t->big_jump_step1));
-	} else
-		p_dm->dm_dig_table.enable_adjust_big_jump = true;
+	pr_debug("ID=((%d)), BW=((%d)), fc=((CH-%d))\n", dm->curr_station_id,
+		 20 << *dm->band_width, *dm->channel);
+	pr_debug("avg_num =((%d)), round =((%d))\n", avg_num, round);
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+	watchdog_stop(dm->priv);
 #endif
-}
+	for (j = 0; j < round; j++) {
+		pr_debug("\nround((%d))\n", (j + 1));
+		if (*dm->band_width == CHANNEL_WIDTH_20) {
+			for (tone_num = 228; tone_num <= 255; tone_num++) {
+				odm_set_bb_reg(dm, R_0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					val = odm_read_4byte(dm, R_0xf8c);
+
+					rxevm_0 = (s8)((val & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((val & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(-%-3d) RXEVM(1ss/2ss)=%d, %d\n",
+					 (256 - tone_num), evm_tone_0[tone_num],
+					 evm_tone_1[tone_num]);
+			}
 
-#if (RTL8822B_SUPPORT == 1 | RTL8821C_SUPPORT == 1 | RTL8814B_SUPPORT == 1)
+			for (tone_num = 1; tone_num <= 28; tone_num++) {
+				odm_set_bb_reg(dm, R_0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					val = odm_read_4byte(dm, R_0xf8c);
+
+					rxevm_0 = (s8)((val & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((val & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(%-3d) RXEVM(1ss/2ss)=%d, %d\n",
+					 tone_num, evm_tone_0[tone_num],
+					 evm_tone_1[tone_num]);
+			}
+		} else if (*dm->band_width == CHANNEL_WIDTH_40) {
+			for (tone_num = 198; tone_num <= 254; tone_num++) {
+				odm_set_bb_reg(dm, R_0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					val = odm_read_4byte(dm, R_0xf8c);
+
+					rxevm_0 = (s8)((val & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((val & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(-%-3d) RXEVM(1ss/2ss)=%d, %d\n",
+					 (256 - tone_num), evm_tone_0[tone_num],
+					 evm_tone_1[tone_num]);
+			}
 
-void
-phydm_show_rx_rate(
-	struct PHY_DM_STRUCT			*p_dm,
-	u32			*_used,
-	char			*output,
-	u32			*_out_len
-)
-{
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "=====Rx SU rate Statistics=====\n"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "1SS MCS0 = %d, 1SS MCS1 = %d, 1SS MCS2 = %d, 1SS MCS 3 = %d\n",
-		p_dm->phy_dbg_info.num_qry_vht_pkt[0], p_dm->phy_dbg_info.num_qry_vht_pkt[1], p_dm->phy_dbg_info.num_qry_vht_pkt[2], p_dm->phy_dbg_info.num_qry_vht_pkt[3]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "1SS MCS4 = %d, 1SS MCS5 = %d, 1SS MCS6 = %d, 1SS MCS 7 = %d\n",
-		p_dm->phy_dbg_info.num_qry_vht_pkt[4], p_dm->phy_dbg_info.num_qry_vht_pkt[5], p_dm->phy_dbg_info.num_qry_vht_pkt[6], p_dm->phy_dbg_info.num_qry_vht_pkt[7]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "1SS MCS8 = %d, 1SS MCS9 = %d\n",
-		p_dm->phy_dbg_info.num_qry_vht_pkt[8], p_dm->phy_dbg_info.num_qry_vht_pkt[9]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "2SS MCS0 = %d, 2SS MCS1 = %d, 2SS MCS2 = %d, 2SS MCS 3 = %d\n",
-		p_dm->phy_dbg_info.num_qry_vht_pkt[10], p_dm->phy_dbg_info.num_qry_vht_pkt[11], p_dm->phy_dbg_info.num_qry_vht_pkt[12], p_dm->phy_dbg_info.num_qry_vht_pkt[13]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "2SS MCS4 = %d, 2SS MCS5 = %d, 2SS MCS6 = %d, 2SS MCS 7 = %d\n",
-		p_dm->phy_dbg_info.num_qry_vht_pkt[14], p_dm->phy_dbg_info.num_qry_vht_pkt[15], p_dm->phy_dbg_info.num_qry_vht_pkt[16], p_dm->phy_dbg_info.num_qry_vht_pkt[17]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "2SS MCS8 = %d, 2SS MCS9 = %d\n",
-		p_dm->phy_dbg_info.num_qry_vht_pkt[18], p_dm->phy_dbg_info.num_qry_vht_pkt[19]));
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "=====Rx MU rate Statistics=====\n"));
-	PHYDM_SNPRINTF((output + used, out_len - used, "1SS MCS0 = %d, 1SS MCS1 = %d, 1SS MCS2 = %d, 1SS MCS 3 = %d\n",
-		p_dm->phy_dbg_info.num_qry_mu_vht_pkt[0], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[1], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[2], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[3]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "1SS MCS4 = %d, 1SS MCS5 = %d, 1SS MCS6 = %d, 1SS MCS 7 = %d\n",
-		p_dm->phy_dbg_info.num_qry_mu_vht_pkt[4], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[5], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[6], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[7]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "1SS MCS8 = %d, 1SS MCS9 = %d\n",
-		p_dm->phy_dbg_info.num_qry_mu_vht_pkt[8], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[9]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "2SS MCS0 = %d, 2SS MCS1 = %d, 2SS MCS2 = %d, 2SS MCS 3 = %d\n",
-		p_dm->phy_dbg_info.num_qry_mu_vht_pkt[10], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[11], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[12], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[13]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "2SS MCS4 = %d, 2SS MCS5 = %d, 2SS MCS6 = %d, 2SS MCS 7 = %d\n",
-		p_dm->phy_dbg_info.num_qry_mu_vht_pkt[14], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[15], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[16], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[17]));
-	PHYDM_SNPRINTF((output + used, out_len - used, "2SS MCS8 = %d, 2SS MCS9 = %d\n",
-		p_dm->phy_dbg_info.num_qry_mu_vht_pkt[18], p_dm->phy_dbg_info.num_qry_mu_vht_pkt[19]));
+			for (tone_num = 2; tone_num <= 58; tone_num++) {
+				odm_set_bb_reg(dm, R_0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					val = odm_read_4byte(dm, R_0xf8c);
+
+					rxevm_0 = (s8)((val & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((val & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(%-3d) RXEVM(1ss/2ss)=%d, %d\n",
+					 tone_num, evm_tone_0[tone_num],
+					 evm_tone_1[tone_num]);
+			}
+		} else if (*dm->band_width == CHANNEL_WIDTH_80) {
+			for (tone_num = 134; tone_num <= 254; tone_num++) {
+				odm_set_bb_reg(dm, R_0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					val = odm_read_4byte(dm, R_0xf8c);
+
+					rxevm_0 = (s8)((val & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((val & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(-%-3d) RXEVM(1ss/2ss)=%d, %d\n",
+					 (256 - tone_num), evm_tone_0[tone_num],
+					 evm_tone_1[tone_num]);
+			}
 
+			for (tone_num = 2; tone_num <= 122; tone_num++) {
+				odm_set_bb_reg(dm, R_0x8c4, 0xff8, tone_num);
+				rxevm_sum_0 = 0;
+				rxevm_sum_1 = 0;
+				for (i = 0; i < avg_num; i++) {
+					val = odm_read_4byte(dm, R_0xf8c);
+
+					rxevm_0 = (s8)((val & MASKBYTE2) >> 16);
+					rxevm_0 = (rxevm_0 / 2);
+					if (rxevm_0 < -63)
+						rxevm_0 = 0;
+
+					rxevm_1 = (s8)((val & MASKBYTE3) >> 24);
+					rxevm_1 = (rxevm_1 / 2);
+					if (rxevm_1 < -63)
+						rxevm_1 = 0;
+					rxevm_sum_0 += rxevm_0;
+					rxevm_sum_1 += rxevm_1;
+					ODM_delay_ms(1);
+				}
+				evm_tone_0[tone_num] = (rxevm_sum_0 / avg_num);
+				evm_tone_1[tone_num] = (rxevm_sum_1 / avg_num);
+				pr_debug("Tone(%-3d) RXEVM (1ss/2ss)=%d, %d\n",
+					 tone_num, evm_tone_0[tone_num],
+					 evm_tone_1[tone_num]);
+			}
+		}
+	}
 	*_used = used;
 	*_out_len = out_len;
 }
 
-#endif
-
-void
-phydm_api_adjust(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_bw_ch_adjust(void *dm_void, char input[][16],
+			u32 *_used, char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u8		i;
-	boolean	is_enable_dbg_mode;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i;
+	boolean is_enable_dbg_mode;
 	u8 central_ch, primary_ch_idx;
-	enum channel_width	bandwidth;
-	
+	enum channel_width bw;
+
 #ifdef PHYDM_COMMON_API_SUPPORT
 
 	if ((strcmp(input[1], help) == 0)) {
-		
-		PHYDM_SNPRINTF((output + used, out_len - used, "{en} {ch_num} {prm_ch 1/2/3/4/9/10} {0:20M, 1:40M, 2:80M}\n"));
-		
-	} else {
-	
-		if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{en} {CH} {pr_ch_idx 1/2/3/4/9/10} {0:20M,1:40M,2:80M}\n");
+		goto out;
+	}
 
-			for (i = 0; i < 4; i++) {
-				if (input[i + 1])
-					PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-			}
+	if (!(dm->support_ic_type & CMN_API_SUPPORT_IC)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Not support this API\n");
+		goto out;
+	}
 
-			is_enable_dbg_mode = (boolean)var1[0];
-			central_ch = (u8) var1[1];
-			primary_ch_idx = (u8) var1[2];
-			bandwidth = (enum channel_width)var1[3];
-
-			if (is_enable_dbg_mode) {
-				p_dm->is_disable_phy_api = false;
-				phydm_api_switch_bw_channel(p_dm, central_ch, primary_ch_idx, bandwidth);
-				p_dm->is_disable_phy_api = true;
-				PHYDM_SNPRINTF((output + used, out_len - used, "central_ch = %d, primary_ch_idx = %d, bandwidth = %d\n", central_ch, primary_ch_idx, bandwidth));
-			} else {
-				p_dm->is_disable_phy_api = false;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Disable API debug mode\n"));
-			}
-		} else {
-			PHYDM_SNPRINTF((output + used, out_len - used, "This IC doesn't support PHYDM API function\n"));
-			/**/
-		}
+	for (i = 0; i < 4; i++) {
+		if (input[i + 1])
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
 	}
 
-#else
-		PHYDM_SNPRINTF((output + used, out_len - used, "This IC doesn't support PHYDM API function\n"));
+	is_enable_dbg_mode = (boolean)var1[0];
+	central_ch = (u8)var1[1];
+	primary_ch_idx = (u8)var1[2];
+	bw = (enum channel_width)var1[3];
+
+	if (is_enable_dbg_mode) {
+		dm->is_disable_phy_api = false;
+		phydm_api_switch_bw_channel(dm, central_ch, primary_ch_idx, bw);
+		dm->is_disable_phy_api = true;
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "central_ch = %d, primary_ch_idx = %d, bw = %d\n",
+			 central_ch, primary_ch_idx, bw);
+	}
+out:
 #endif
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_parameter_adjust(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_ext_rf_element_ctrl(void *dm_void, char input[][16], u32 *_used,
+			       char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_cfo_track_struct				*p_cfo_track = (struct phydm_cfo_track_struct *)phydm_get_structure(p_dm, PHYDM_CFOTRACK);
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u8		i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 val[10] = {0};
+	u8 i = 0, input_idx = 0;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &val[i]);
+			input_idx++;
+		}
+	}
 
-	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "1. X_cap = ((0x%x))\n", p_cfo_track->crystal_cap));
+	if (input_idx == 0)
+		return;
 
-	} else {
-	
-		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+	if (val[0] == 1) /*@ext switch*/ {
+		phydm_set_ext_switch(dm, val[1]);
+	}
+}
 
-		if (var1[0] == 0) {
+void phydm_print_dbgport(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 dbg_port_value = 0;
+	u8 val[32];
+	u8 tmp = 0;
+	u8 i;
+
+	if (strcmp(input[1], help) == 0) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{dbg_port_idx}\n");
+		goto out;
+	}
+
+	PHYDM_SSCANF(input[1], DCMD_HEX, &var1[0]);
+
+	dm->debug_components |= ODM_COMP_API;
+	if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_3, var1[0])) {
+		dbg_port_value = phydm_get_bb_dbg_port_val(dm);
+		phydm_release_bb_dbg_port(dm);
 
-			PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
-			phydm_set_crystal_cap(p_dm, (u8)var1[1]);
-			PHYDM_SNPRINTF((output + used, out_len - used, "X_cap = ((0x%x))\n", p_cfo_track->crystal_cap));
+		for (i = 0; i < 32; i++)
+			val[i] = (u8)((dbg_port_value & BIT(i)) >> i);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Dbg Port[0x%x] = ((0x%x))\n", var1[0],
+			 dbg_port_value);
+
+		for (i = 4; i != 0; i--) {
+			tmp = 8 * (i - 1);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "val[%d:%d] = 8b'%d %d %d %d %d %d %d %d\n",
+				 tmp + 7, tmp, val[tmp + 7], val[tmp + 6],
+				 val[tmp + 5], val[tmp + 4], val[tmp + 3],
+				 val[tmp + 2], val[tmp + 1], val[tmp + 0]);
 		}
 	}
+	dm->debug_components &= (~ODM_COMP_API);
+out:
 	*_used = used;
 	*_out_len = out_len;
 }
 
-struct _PHYDM_COMMAND {
+struct phydm_command {
 	char name[16];
 	u8 id;
 };
@@ -2001,6 +3888,7 @@ struct _PHYDM_COMMAND {
 enum PHYDM_CMD_ID {
 	PHYDM_HELP,
 	PHYDM_DEMO,
+	PHYDM_RF_CMD,
 	PHYDM_DIG,
 	PHYDM_RA,
 	PHYDM_PROFILE,
@@ -2009,15 +3897,10 @@ enum PHYDM_CMD_ID {
 	PHYDM_DEBUG,
 	PHYDM_FW_DEBUG,
 	PHYDM_SUPPORT_ABILITY,
-	PHYDM_RF_SUPPORTABILITY,
-	PHYDM_RF_PROFILE,
-	PHYDM_RF_IQK_INFO,
-	PHYDM_IQK,
-	PHYDM_IQK_DEBUG,
 	PHYDM_GET_TXAGC,
 	PHYDM_SET_TXAGC,
 	PHYDM_SMART_ANT,
-	PHYDM_API,
+	PHYDM_CH_BW,
 	PHYDM_TRX_PATH,
 	PHYDM_LA_MODE,
 	PHYDM_DUMP_REG,
@@ -2027,30 +3910,35 @@ enum PHYDM_CMD_ID {
 	PHYDM_NBI_EN,
 	PHYDM_CSI_MASK_EN,
 	PHYDM_DFS_DEBUG,
+	PHYDM_DFS_HIST,
 	PHYDM_NHM,
 	PHYDM_CLM,
+	PHYDM_FAHM,
+	PHYDM_ENV_MNTR,
 	PHYDM_BB_INFO,
 	PHYDM_TXBF,
 	PHYDM_H2C,
-	PHYDM_ANT_SWITCH,
-	PHYDM_DYNAMIC_RA_PATH,
+	PHYDM_EXT_RF_E_CTRL,
 	PHYDM_ADAPTIVE_SOML,
 	PHYDM_PSD,
 	PHYDM_DEBUG_PORT,
 	PHYDM_DIS_HTSTF_CONTROL,
-	PHYDM_TUNE_PARAMETER,
+	PHYDM_CFO_TRK,
 	PHYDM_ADAPTIVITY_DEBUG,
 	PHYDM_DIS_DYM_ANT_WEIGHTING,
 	PHYDM_FORECE_PT_STATE,
-	PHYDM_DIS_RXHP_CTR,
 	PHYDM_STA_INFO,
-	PHYDM_PAUSE_FUNC
+	PHYDM_PAUSE_FUNC,
+	PHYDM_PER_TONE_EVM,
+	PHYDM_DYN_TXPWR,
+	PHYDM_LNA_SAT
 };
 
-struct _PHYDM_COMMAND phy_dm_ary[] = {
-	{"-h", PHYDM_HELP},		/*do not move this element to other position*/
-	{"demo", PHYDM_DEMO},	/*do not move this element to other position*/
-	{"dig", PHYDM_DIG},	
+struct phydm_command phy_dm_ary[] = {
+	{"-h", PHYDM_HELP}, /*@do not move this element to other position*/
+	{"demo", PHYDM_DEMO}, /*@do not move this element to other position*/
+	{"rf", PHYDM_RF_CMD},
+	{"dig", PHYDM_DIG},
 	{"ra", PHYDM_RA},
 	{"profile", PHYDM_PROFILE},
 	{"antdiv", PHYDM_ANTDIV},
@@ -2058,15 +3946,10 @@ struct _PHYDM_COMMAND phy_dm_ary[] = {
 	{"dbg", PHYDM_DEBUG},
 	{"fw_dbg", PHYDM_FW_DEBUG},
 	{"ability", PHYDM_SUPPORT_ABILITY},
-	{"rf_ability", PHYDM_RF_SUPPORTABILITY},
-	{"rf_profile", PHYDM_RF_PROFILE},
-	{"iqk_info", PHYDM_RF_IQK_INFO},
-	{"iqk", PHYDM_IQK},
-	{"iqk_dbg", PHYDM_IQK_DEBUG},
 	{"get_txagc", PHYDM_GET_TXAGC},
 	{"set_txagc", PHYDM_SET_TXAGC},
 	{"smtant", PHYDM_SMART_ANT},
-	{"api", PHYDM_API},
+	{"ch_bw", PHYDM_CH_BW},
 	{"trxpath", PHYDM_TRX_PATH},
 	{"lamode", PHYDM_LA_MODE},
 	{"dumpreg", PHYDM_DUMP_REG},
@@ -2076,55 +3959,51 @@ struct _PHYDM_COMMAND phy_dm_ary[] = {
 	{"nbi", PHYDM_NBI_EN},
 	{"csi_mask", PHYDM_CSI_MASK_EN},
 	{"dfs", PHYDM_DFS_DEBUG},
+	{"dfs_hist", PHYDM_DFS_HIST},
 	{"nhm", PHYDM_NHM},
 	{"clm", PHYDM_CLM},
+	{"fahm", PHYDM_FAHM},
+	{"env_mntr", PHYDM_ENV_MNTR},
 	{"bbinfo", PHYDM_BB_INFO},
 	{"txbf", PHYDM_TXBF},
 	{"h2c", PHYDM_H2C},
-	{"ant_switch", PHYDM_ANT_SWITCH},
-	{"drp", PHYDM_DYNAMIC_RA_PATH},
+	{"ext_rfe", PHYDM_EXT_RF_E_CTRL},
 	{"soml", PHYDM_ADAPTIVE_SOML},
 	{"psd", PHYDM_PSD},
 	{"dbgport", PHYDM_DEBUG_PORT},
 	{"dis_htstf", PHYDM_DIS_HTSTF_CONTROL},
-	{"tune_para", PHYDM_TUNE_PARAMETER},
+	{"cfo_trk", PHYDM_CFO_TRK},
 	{"adapt_debug", PHYDM_ADAPTIVITY_DEBUG},
 	{"dis_dym_ant_wgt", PHYDM_DIS_DYM_ANT_WEIGHTING},
 	{"force_pt_state", PHYDM_FORECE_PT_STATE},
-	{"dis_drxhp", PHYDM_DIS_RXHP_CTR},
 	{"sta_info", PHYDM_STA_INFO},
-	{"pause", PHYDM_PAUSE_FUNC}
-};
+	{"pause", PHYDM_PAUSE_FUNC},
+	{"evm", PHYDM_PER_TONE_EVM},
+	{"dyn_txpwr", PHYDM_DYN_TXPWR},
+	{"lna_sat", PHYDM_LNA_SAT} };
+
+#endif /*@#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
 
-#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
-
-void
-phydm_cmd_parser(
-	struct PHY_DM_STRUCT	*p_dm,
-	char		input[][MAX_ARGV],
-	u32	input_num,
-	u8	flag,
-	char		*output,
-	u32	out_len
-)
+void phydm_cmd_parser(struct dm_struct *dm, char input[][MAX_ARGV],
+		      u32 input_num, u8 flag, char *output, u32 out_len)
 {
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
 	u32 used = 0;
 	u8 id = 0;
-	int var1[10] = {0};
-	int i, input_idx = 0, phydm_ary_size = sizeof(phy_dm_ary) / sizeof(struct _PHYDM_COMMAND);
-	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 i;
+	u32 phydm_ary_size = sizeof(phy_dm_ary) / sizeof(struct phydm_command);
 
 	if (flag == 0) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "GET, nothing to print\n"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "GET, nothing to print\n");
 		return;
 	}
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "\n"));
+	PDM_SNPF(out_len, used, output + used, out_len - used, "\n");
 
 	/* Parsing Cmd ID */
 	if (input_num) {
-
 		for (i = 0; i < phydm_ary_size; i++) {
 			if (strcmp(phy_dm_ary[i].name, input[0]) == 0) {
 				id = phy_dm_ary[i].id;
@@ -2132,778 +4011,318 @@ phydm_cmd_parser(
 			}
 		}
 		if (i == phydm_ary_size) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "SET, command not found!\n"));
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "PHYDM command not found!\n");
 			return;
 		}
 	}
 
 	switch (id) {
+	case PHYDM_HELP: {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "BB cmd ==>\n");
 
-	case PHYDM_HELP:
-	{
-		PHYDM_SNPRINTF((output + used, out_len - used, "BB cmd ==>\n"));
-		for (i = 0; i < phydm_ary_size - 2; i++) {
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "  %-5d: %s\n", i, phy_dm_ary[i + 2].name));
-			/**/
-		}
-	}
-	break;
+		for (i = 0; i < phydm_ary_size - 2; i++)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "  %-5d: %s\n", i, phy_dm_ary[i + 2].name);
+	} break;
 
-	case PHYDM_DEMO: { /*echo demo 10 0x3a z abcde >cmd*/
+	case PHYDM_DEMO: { /*@echo demo 10 0x3a z abcde >cmd*/
 		u32 directory = 0;
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
 		char char_temp;
-#else
+		#else
 		u32 char_temp = ' ';
-#endif
+		#endif
 
 		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &directory);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Decimal value = %d\n", directory));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Decimal value = %d\n", directory);
 		PHYDM_SSCANF(input[2], DCMD_HEX, &directory);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Hex value = 0x%x\n", directory));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Hex value = 0x%x\n", directory);
 		PHYDM_SSCANF(input[3], DCMD_CHAR, &char_temp);
-		PHYDM_SNPRINTF((output + used, out_len - used, "Char = %c\n", char_temp));
-		PHYDM_SNPRINTF((output + used, out_len - used, "String = %s\n", input[4]));
-	}
-	break;
-	
-	case PHYDM_DIG:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Char = %c\n", char_temp);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "String = %s\n", input[4]);
+	} break;
+	case PHYDM_RF_CMD:
+		halrf_cmd_parser(dm, input, &used, output, &out_len, input_num);
+		break;
 
-		phydm_dig_debug(p_dm, &input[0], &used, output, &out_len, input_num);
+	case PHYDM_DIG:
+		phydm_dig_debug(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_RA:
-		phydm_ra_debug(p_dm, &input[0], &used, output, &out_len);
+		phydm_ra_debug(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_ANTDIV:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, PATHDIV_var[%d]= (( %d ))\n", i, var1[i]));*/
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "odm_PATHDIV_debug\n"));*/
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-			phydm_antdiv_debug(p_dm, (u32 *)var1, &used, output, &out_len);
-#endif
-		}
-
+		#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+		phydm_antdiv_debug(dm, input, &used, output, &out_len);
+		#endif
 		break;
 
 	case PHYDM_PATHDIV:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, PATHDIV_var[%d]= (( %d ))\n", i, var1[i]));*/
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "odm_PATHDIV_debug\n"));*/
-#if (defined(CONFIG_PATH_DIVERSITY))
-			odm_pathdiv_debug(p_dm, (u32 *)var1, &used, output, &out_len);
-#endif
-		}
-
-		break;
-
-	case PHYDM_DEBUG:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, Debug_var[%d]= (( %d ))\n", i, var1[i]));*/
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "odm_debug_comp\n"));*/
-			phydm_debug_trace(p_dm, (u32 *)var1, &used, output, &out_len);
-		}
-
-
-		break;
-
-	case PHYDM_FW_DEBUG:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1)
-			phydm_fw_debug_trace(p_dm, (u32 *)var1, &used, output, &out_len);
-
-		break;
-
-	case PHYDM_SUPPORT_ABILITY:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-
-				/*PHYDM_SNPRINTF((output+used, out_len-used, "new SET, support ablity_var[%d]= (( %d ))\n", i, var1[i]));*/
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-			/*PHYDM_SNPRINTF((output+used, out_len-used, "support ablity\n"));*/
-			phydm_support_ability_debug(p_dm, (u32 *)var1, &used, output, &out_len);
-		}
-
-		break;
-
-	case PHYDM_RF_SUPPORTABILITY:
-		halrf_support_ability_debug(p_dm, &input[0], &used, output, &out_len);
-		break;
-
-	case PHYDM_RF_PROFILE:
-		halrf_basic_profile(p_dm, &used, output, &out_len);
-		break;
-		
-	case PHYDM_RF_IQK_INFO:
-		#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-		if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
-			halrf_iqk_info_dump(p_dm, &used, output, &out_len);
+		#if (defined(CONFIG_PATH_DIVERSITY))
+		phydm_pathdiv_debug(dm, input, &used, output, &out_len);
 		#endif
 		break;
 
-	case PHYDM_IQK:
-
-		PHYDM_SNPRINTF((output + used, out_len - used, "TRX IQK Trigger\n"));
-		halrf_iqk_trigger(p_dm, false);
-
-		#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-		if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
-			halrf_iqk_info_dump(p_dm, &used, output, &out_len);
-		#endif
-		
+	case PHYDM_DEBUG:
+		phydm_debug_trace(dm, input, &used, output, &out_len);
 		break;
-		
-	case PHYDM_IQK_DEBUG:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-				input_idx++;
-			}
-		}
 
-		if (input_idx >= 1) {
-			#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
-			if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
-				halrf_iqk_debug(p_dm, (u32 *)var1, &used, output, &out_len);
-			#endif
-		}
+	case PHYDM_FW_DEBUG:
+		phydm_fw_debug_trace(dm, input, &used, output, &out_len);
 		break;
-		
-	case PHYDM_SMART_ANT:
 
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-				input_idx++;
-			}
-		}
+	case PHYDM_SUPPORT_ABILITY:
+		phydm_supportability_en(dm, input, &used, output, &out_len);
+		break;
 
-		if (input_idx >= 1) {
-	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	case PHYDM_SMART_ANT:
+		#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
 
 		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-		phydm_hl_smart_ant_debug_type2(p_dm, &input[0], &used, output, &out_len, input_num);
+		phydm_hl_smt_ant_dbg_type2(dm, input, &used, output, &out_len);
 		#elif (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
-		phydm_hl_smart_ant_debug(p_dm, &input[0], &used, output, &out_len, input_num);
+		phydm_hl_smart_ant_debug(dm, input, &used, output, &out_len);
 		#endif
-	
-	#endif
 
-	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
-		phydm_cumitek_smt_ant_debug(p_dm, &input[0], &used, output, &out_len, input_num);
-	#endif
-		}
+		#elif (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+		phydm_cumitek_smt_ant_debug(dm, input, &used, output, &out_len);
+		#endif
 
 		break;
 
-	case PHYDM_API:
-		phydm_api_adjust(p_dm, &input[0], &used, output, &out_len, input_num);
+	case PHYDM_CH_BW:
+		phydm_bw_ch_adjust(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_PROFILE:
-		phydm_basic_profile(p_dm, &used, output, &out_len);
+		phydm_basic_profile(dm, &used, output, &out_len);
 		break;
 
 	case PHYDM_GET_TXAGC:
-		phydm_get_txagc(p_dm, &used, output, &out_len);
+		phydm_get_txagc(dm, &used, output, &out_len);
 		break;
 
 	case PHYDM_SET_TXAGC:
-	{
-		boolean		is_enable_dbg_mode;
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if ((strcmp(input[1], help) == 0)) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "{En} {pathA~D(0~3)} {rate_idx(Hex), All_rate:0xff} {txagc_idx (Hex)}\n"));
-			/**/
-
-		} else {
-
-			is_enable_dbg_mode = (boolean)var1[0];
-			if (is_enable_dbg_mode) {
-				p_dm->is_disable_phy_api = false;
-				phydm_set_txagc(p_dm, (u32 *)var1, &used, output, &out_len);
-				p_dm->is_disable_phy_api = true;
-			} else {
-				p_dm->is_disable_phy_api = false;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Disable API debug mode\n"));
-			}
-		}
-	}
-	break;
+		phydm_set_txagc_dbg(dm, input, &used, output, &out_len);
+		break;
 
 	case PHYDM_TRX_PATH:
-
-		for (i = 0; i < 4; i++) {
-			if (input[i + 1])
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-		}
-#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
-		if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
-			u8		tx_path, rx_path;
-			boolean		is_enable_dbg_mode, is_tx2_path;
-
-			is_enable_dbg_mode = (boolean)var1[0];
-			tx_path = (u8) var1[1];
-			rx_path = (u8) var1[2];
-			is_tx2_path = (boolean) var1[3];
-
-			if (is_enable_dbg_mode) {
-				p_dm->is_disable_phy_api = false;
-				phydm_api_trx_mode(p_dm, (enum bb_path) tx_path, (enum bb_path) rx_path, is_tx2_path);
-				p_dm->is_disable_phy_api = true;
-				PHYDM_SNPRINTF((output + used, out_len - used, "tx_path = 0x%x, rx_path = 0x%x, is_tx2_path = %d\n", tx_path, rx_path, is_tx2_path));
-			} else {
-				p_dm->is_disable_phy_api = false;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Disable API debug mode\n"));
-			}
-		} else
-#endif
-			phydm_config_trx_path(p_dm, (u32 *)var1, &used, output, &out_len);
-
+		phydm_config_trx_path(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_LA_MODE:
-
-		#if (PHYDM_LA_MODE_SUPPORT == 1)
-		phydm_lamode_trigger_setting(p_dm, &input[0], &used, output, &out_len, input_num);
-		#else
-		PHYDM_SNPRINTF((output + used, out_len - used, "This IC doesn't support LA mode\n"));
+		#if (PHYDM_LA_MODE_SUPPORT)
+		phydm_lamode_trigger_cmd(dm, input, &used, output, &out_len);
 		#endif
-
 		break;
 
 	case PHYDM_DUMP_REG:
-	{
-		u8	type = 0;
-
-		if (input[1]) {
-			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-			type = (u8)var1[0];
-		}
-
-		if (type == 0)
-			phydm_dump_bb_reg(p_dm, &used, output, &out_len);
-		else if (type == 1)
-			phydm_dump_all_reg(p_dm, &used, output, &out_len);
-	}
-	break;
+		phydm_dump_reg(dm, input, &used, output, &out_len);
+		break;
 
 	case PHYDM_BIG_JUMP:
-	{
-#if (RTL8822B_SUPPORT == 1)
-		if (p_dm->support_ic_type & ODM_RTL8822B) {
-			if (input[1]) {
-				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-				phydm_enable_big_jump(p_dm, (boolean)(var1[0]));
-			} else
-				PHYDM_SNPRINTF((output + used, out_len - used, "unknown command!\n"));
-		} else
-			PHYDM_SNPRINTF((output + used, out_len - used, "The command is only for 8822B!\n"));
-#endif
+		phydm_enable_big_jump(dm, input, &used, output, &out_len);
 		break;
-	}
 
 	case PHYDM_AUTO_DBG:
 		#ifdef PHYDM_AUTO_DEGBUG
-		phydm_auto_dbg_console(p_dm, &input[0], &used, output, &out_len, input_num);
+		phydm_auto_dbg_console(dm, input, &used, output, &out_len);
 		#endif
 		break;
 
 	case PHYDM_SHOW_RXRATE:
-#if (RTL8822B_SUPPORT == 1 | RTL8821C_SUPPORT == 1 | RTL8814B_SUPPORT == 1)
-		if (p_dm->support_ic_type & PHYDM_IC_SUPPORT_MU_BFEE) {
-			u8	rate_idx;
-
-			if (input[1])
-				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-
-			if (var1[0] == 1)
-				phydm_show_rx_rate(p_dm, &used, output, &out_len);
-			else {
-				PHYDM_SNPRINTF((output + used, out_len - used, "Reset Rx rate counter\n"));
-
-				for (rate_idx = 0; rate_idx < 40; rate_idx++) {
-					p_dm->phy_dbg_info.num_qry_vht_pkt[rate_idx] = 0;
-					p_dm->phy_dbg_info.num_qry_mu_vht_pkt[rate_idx] = 0;
-				}
-			}
-		}
-#endif
+		phydm_show_rx_rate(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_NBI_EN:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-
-			phydm_api_debug(p_dm, PHYDM_API_NBI, (u32 *)var1, &used, output, &out_len);
-			/**/
-		}
-
-
+		phydm_nbi_debug(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_CSI_MASK_EN:
-
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-
-			phydm_api_debug(p_dm, PHYDM_API_CSI_MASK, (u32 *)var1, &used, output, &out_len);
-			/**/
-		}
-
-
+		phydm_csi_debug(dm, input, &used, output, &out_len);
 		break;
 
+	#ifdef CONFIG_PHYDM_DFS_MASTER
 	case PHYDM_DFS_DEBUG:
-#ifdef CONFIG_PHYDM_DFS_MASTER
-		{
-			u32 var[4] = {0};
-
-			for (i = 0; i < 4; i++) {
-				if (input[i + 1]) {
-					PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var[i]);
-					input_idx++;
-				}
-			}
+		phydm_dfs_debug(dm, input, &used, output, &out_len);
+		break;
 
-			if (input_idx >= 1)
-				phydm_dfs_debug(p_dm, var, &used, output, &out_len);
-		}
-#endif
+	case PHYDM_DFS_HIST:
+		phydm_dfs_hist_dbg(dm, input, &used, output, &out_len);
 		break;
+	#endif
 
 	case PHYDM_NHM:
-	{
-		u8		target_rssi;
-		u16		nhm_period = 0xC350;	/* 200ms */
-		u8		IGI;
-		struct _CCX_INFO	*ccx_info = &p_dm->dm_ccx_info;
-
-		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-
-		if (input_num == 1) {
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Trigger NHM: echo nhm 1\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r (Exclude CCA)\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r Trigger NHM: echo nhm 2\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r (Include CCA)\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r Get NHM results: echo nhm 3\n"));
-
-			return;
-		}
-
-		/* NMH trigger */
-		if ((var1[0] <= 2) && (var1[0] != 0)) {
-
-			ccx_info->echo_igi = (u8)odm_get_bb_reg(p_dm, 0xC50, MASKBYTE0);
-
-			target_rssi = ccx_info->echo_igi - 10;
-
-			ccx_info->nhm_th[0] = (target_rssi - 15 + 10) * 2; /*Unit: PWdB U(8,1)*/
-
-			for (i = 1; i <= 10; i++)
-				ccx_info->nhm_th[i] = ccx_info->nhm_th[0] + 6 * i;
-
-			/* 4 1. store previous NHM setting */
-			phydm_nhm_setting(p_dm, STORE_NHM_SETTING);
-
-			/* 4 2. Set NHM period, 0x990[31:16]=0xC350, Time duration for NHM unit: 4us, 0xC350=200ms */
-			ccx_info->nhm_period = nhm_period;
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Monitor NHM for %d us", nhm_period * 4));
-
-			/* 4 3. Set NHM inexclude_txon, inexclude_cca, ccx_en */
-
-
-			ccx_info->nhm_inexclude_cca = (var1[0] == 1) ? NHM_EXCLUDE_CCA : NHM_INCLUDE_CCA;
-			ccx_info->nhm_inexclude_txon = NHM_EXCLUDE_TXON;
-
-			phydm_nhm_setting(p_dm, SET_NHM_SETTING);
-
-			for (i = 0; i <= 10; i++) {
-
-				if (i == 5)
-					PHYDM_SNPRINTF((output + used, out_len - used, "\r\n NHM_th[%d] = 0x%x, echo_igi = 0x%x", i, ccx_info->nhm_th[i], ccx_info->echo_igi));
-				else if (i == 10)
-					PHYDM_SNPRINTF((output + used, out_len - used, "\r\n NHM_th[%d] = 0x%x\n", i, ccx_info->nhm_th[i]));
-				else
-					PHYDM_SNPRINTF((output + used, out_len - used, "\r\n NHM_th[%d] = 0x%x", i, ccx_info->nhm_th[i]));
-			}
-
-			/* 4 4. Trigger NHM */
-			phydm_nhm_trigger(p_dm);
-
-		}
-
-		/*Get NHM results*/
-		else if (var1[0] == 3) {
-
-			IGI = (u8)odm_get_bb_reg(p_dm, 0xC50, MASKBYTE0);
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Cur_IGI = 0x%x", IGI));
-
-			phydm_get_nhm_result(p_dm);
-
-			/* 4 Resotre NHM setting */
-			phydm_nhm_setting(p_dm, RESTORE_NHM_SETTING);
-
-			for (i = 0; i <= 11; i++) {
-
-				if (i == 5)
-					PHYDM_SNPRINTF((output + used, out_len - used, "\r\n nhm_result[%d] = %d, echo_igi = 0x%x", i, ccx_info->nhm_result[i], ccx_info->echo_igi));
-				else if (i == 11)
-					PHYDM_SNPRINTF((output + used, out_len - used, "\r\n nhm_result[%d] = %d\n", i, ccx_info->nhm_result[i]));
-				else
-					PHYDM_SNPRINTF((output + used, out_len - used, "\r\n nhm_result[%d] = %d", i, ccx_info->nhm_result[i]));
-			}
-
-		} else {
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Trigger NHM: echo nhm 1\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r (Exclude CCA)\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r Trigger NHM: echo nhm 2\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r (Include CCA)\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r Get NHM results: echo nhm 3\n"));
-
-			return;
-		}
-	}
-	break;
+		#ifdef NHM_SUPPORT
+		phydm_nhm_dbg(dm, input, &used, output, &out_len);
+		#endif
+		break;
 
 	case PHYDM_CLM:
-		phydm_clm_dbg(p_dm, &input[0], &used, output, &out_len, input_num);
+		#ifdef CLM_SUPPORT
+		phydm_clm_dbg(dm, input, &used, output, &out_len);
+		#endif
 		break;
 
 	#ifdef FAHM_SUPPORT
 	case PHYDM_FAHM:
-		phydm_fahm_dbg(p_dm, &input[0], &used, output, &out_len, input_num);
-	break;
+		phydm_fahm_dbg(dm, input, &used, output, &out_len);
+		break;
 	#endif
 
-	case PHYDM_BB_INFO:
-	{
-		s32 value32 = 0;
+	case PHYDM_ENV_MNTR:
+		phydm_env_mntr_dbg(dm, input, &used, output, &out_len);
+		break;
 
-		phydm_bb_debug_info(p_dm, &used, output, &out_len);
+	case PHYDM_BB_INFO:
+		phydm_bb_hw_dbg_info(dm, input, &used, output, &out_len);
+		break;
 
-		if (p_dm->support_ic_type & ODM_RTL8822B && input[1]) {
-			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-			odm_set_bb_reg(p_dm, 0x1988, 0x003fff00, var1[0]);
-			value32 = odm_get_bb_reg(p_dm, 0xf84, MASKDWORD);
-			value32 = (value32 & 0xff000000) >> 24;
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n %-35s = condition num = %d, subcarriers = %d\n", "Over condition num subcarrier", var1[0], value32));
-			odm_set_bb_reg(p_dm, 0x1988, BIT(22), 0x0);	/*disable report condition number*/
-		}
-	}
-	break;
+	case PHYDM_TXBF: {
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	#ifdef PHYDM_BEAMFORMING_SUPPORT
+		struct _RT_BEAMFORMING_INFO *beamforming_info = NULL;
 
-	case PHYDM_TXBF:
-	{
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (BEAMFORMING_SUPPORT == 1)
-		struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
+		beamforming_info = &dm->beamforming_info;
 
 		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 		if (var1[0] == 0) {
-			p_beamforming_info->apply_v_matrix = false;
-			p_beamforming_info->snding3ss = true;
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n dont apply V matrix and 3SS 789 snding\n"));
+			beamforming_info->apply_v_matrix = false;
+			beamforming_info->snding3ss = true;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\r\n dont apply V matrix and 3SS 789 snding\n");
 		} else if (var1[0] == 1) {
-			p_beamforming_info->apply_v_matrix = true;
-			p_beamforming_info->snding3ss = true;
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n apply V matrix and 3SS 789 snding\n"));
+			beamforming_info->apply_v_matrix = true;
+			beamforming_info->snding3ss = true;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\r\n apply V matrix and 3SS 789 snding\n");
 		} else if (var1[0] == 2) {
-			p_beamforming_info->apply_v_matrix = true;
-			p_beamforming_info->snding3ss = false;
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n default txbf setting\n"));
+			beamforming_info->apply_v_matrix = true;
+			beamforming_info->snding3ss = false;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\r\n default txbf setting\n");
 		} else
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n unknown cmd!!\n"));
-#else
-		PHYDM_SNPRINTF((output + used, out_len - used, "\r\n no TxBF !!\n"));
-#endif
-#endif
-	}
-		break;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "\r\n unknown cmd!!\n");
+	#endif
+	#endif
+	} break;
 
 	case PHYDM_H2C:
-
-		for (i = 0; i < 8; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1)
-			phydm_h2C_debug(p_dm, (u32 *)var1, &used, output, &out_len);
-
-
-		break;
-
-	case PHYDM_ANT_SWITCH:
-
-		for (i = 0; i < 8; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1) {
-
-#if (RTL8821A_SUPPORT == 1)
-			phydm_set_ext_switch(p_dm, (u32 *)var1, &used, output, &out_len);
-#else
-			PHYDM_SNPRINTF((output + used, out_len - used, "Not Support IC"));
-#endif
-		}
-
-
+		phydm_h2C_debug(dm, input, &used, output, &out_len);
 		break;
 
-	case PHYDM_DYNAMIC_RA_PATH:
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-		for (i = 0; i < 8; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1)
-			phydm_drp_debug(p_dm, (u32 *)var1, &used, output, &out_len);
-
-#else
-		PHYDM_SNPRINTF((output + used, out_len - used, "Not Support IC"));
-#endif
-
+	case PHYDM_EXT_RF_E_CTRL:
+		phydm_ext_rf_element_ctrl(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_ADAPTIVE_SOML:
-
-#ifdef CONFIG_ADAPTIVE_SOML
-		for (i = 0; i < 8; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-				input_idx++;
-			}
-		}
-
-		if (input_idx >= 1)
-			phydm_soml_debug(p_dm, (u32 *)var1, &used, output, &out_len);
-
-#else
-		PHYDM_SNPRINTF((output + used, out_len - used, "Not Support IC"));
-#endif
-
+		#ifdef CONFIG_ADAPTIVE_SOML
+		phydm_soml_debug(dm, input, &used, output, &out_len);
+		#endif
 		break;
 
 	case PHYDM_PSD:
 
 		#ifdef CONFIG_PSD_TOOL
-		phydm_psd_debug(p_dm, &input[0], &used, output, &out_len, input_num);
+		phydm_psd_debug(dm, input, &used, output, &out_len);
 		#endif
 
 		break;
-		
-	case PHYDM_DEBUG_PORT:
-		{
-			u32	dbg_port_value;
-
-			PHYDM_SSCANF(input[1], DCMD_HEX, &var1[0]);
 
-			p_dm->debug_components |= ODM_COMP_API;
-			if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_3, var1[0])) {/*set debug port to 0x0*/
-
-				dbg_port_value = phydm_get_bb_dbg_port_value(p_dm);
-				phydm_release_bb_dbg_port(p_dm);
-				
-				PHYDM_SNPRINTF((output + used, out_len - used, "Dbg Port[0x%x] = ((0x%x))\n", var1[0], dbg_port_value));
-			}
-			p_dm->debug_components &= (~ODM_COMP_API);
-		}
-		break;
-		
-	case PHYDM_DIS_HTSTF_CONTROL:
-		{
-			if (input[1])
-				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-
-			if (var1[0] == 1) {
-				
-				/* setting being false is for debug */
-				p_dm->bhtstfdisabled = true;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Dynamic HT-STF Gain Control is Disable\n"));
-			}
-			else {
-				
-				/* default setting should be true, always be dynamic control*/
-				p_dm->bhtstfdisabled = false;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Dynamic HT-STF Gain Control is Enable\n"));
-			}
-		}
-		break;
-		
-	case PHYDM_TUNE_PARAMETER:
-		phydm_parameter_adjust(p_dm, &input[0], &used, output, &out_len, input_num);
+	case PHYDM_DEBUG_PORT:
+		phydm_print_dbgport(dm, input, &used, output, &out_len);
 		break;
 
-	case PHYDM_ADAPTIVITY_DEBUG:
+	case PHYDM_DIS_HTSTF_CONTROL: {
+		if (input[1])
+			PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 
-		for (i = 0; i < 5; i++) {
-			if (input[i + 1]) {
-				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-				input_idx++;
-			}
+		if (var1[0] == 1) {
+			/* setting being false is for debug */
+			dm->bhtstfdisabled = true;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Dynamic HT-STF Gain Control is Disable\n");
+		} else {
+			/* @default setting should be true,
+			 * always be dynamic control
+			 */
+			dm->bhtstfdisabled = false;
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Dynamic HT-STF Gain Control is Enable\n");
 		}
+	} break;
 
-		if (input_idx >= 1)
-			phydm_adaptivity_debug(p_dm, (u32 *)var1, &used, output, &out_len);
+	case PHYDM_CFO_TRK:
+		phydm_cfo_tracking_debug(dm, input, &used, output, &out_len);
+		break;
 
+	case PHYDM_ADAPTIVITY_DEBUG:
+		#ifdef PHYDM_SUPPORT_ADAPTIVITY
+		phydm_adaptivity_debug(dm, input, &used, output, &out_len);
+		#endif
 		break;
 
-	case PHYDM_DIS_DYM_ANT_WEIGHTING:	
-		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-		if (input_num == 1) {		
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Disable dynamic antenna weighting: echo dis_dym_ant_weighting 1\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Enable dynamic antenna weighting: echo dis_dym_ant_weighting 0\n"));
-			return;
-		}
-		
-		if (var1[0] == 1) {
-			p_dm->is_disable_dym_ant_weighting = 1;
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Disable dynmic antenna weighting !\n"));
-		} else if(var1[0] == 0) {
-			p_dm->is_disable_dym_ant_weighting = 0;
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Enable dynmic antenna weighting !\n"));
-		} else {
-			p_dm->is_disable_dym_ant_weighting = 0;
-			PHYDM_SNPRINTF((output + used, out_len - used, "\r\n Enable dynmic antenna weighting !\n"));
-		}
+	case PHYDM_DIS_DYM_ANT_WEIGHTING:
+		#ifdef DYN_ANT_WEIGHTING_SUPPORT
+		phydm_ant_weight_dbg(dm, input, &used, output, &out_len);
+		#endif
 		break;
 
 	case PHYDM_FORECE_PT_STATE:
-		{
-
-		#ifdef PHYDM_POWER_TRAINING_SUPPORT	
-			phydm_pow_train_debug(p_dm, &input[0], &used, output, &out_len, input_num);
-		#else
-			PHYDM_SNPRINTF((output + used, out_len - used, "Pow training: Not Support\n"));
+		#ifdef PHYDM_POWER_TRAINING_SUPPORT
+		phydm_pow_train_debug(dm, input, &used, output, &out_len);
 		#endif
-		
 		break;
-		}
-
-	case PHYDM_DIS_RXHP_CTR:
-		{
-			if (input[1])
-				PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 
-			if (var1[0] == 1) {
-				/* the setting being on is at debug mode to disconnect RxHP seeting with SoML on/odd */
-				p_dm->disrxhpsoml = true;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Dynamic RxHP Control with SoML on/off is Disable\n"));
-			}
-			else if (var1[0] == 0) {
-				/* default setting, RxHP setting will follow SoML on/off setting */
-				p_dm->disrxhpsoml = false;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Dynamic RxHP Control with SoML on/off is Enable\n"));
-			}
-			else {
-				p_dm->disrxhpsoml = false;
-				PHYDM_SNPRINTF((output + used, out_len - used, "Default Setting, Dynamic RxHP Control with SoML on/off is Enable\n"));
-			}
-		}
-		break;
-		
 	case PHYDM_STA_INFO:
-		phydm_show_sta_info(p_dm, &input[0], &used, output, &out_len, input_num);
+		phydm_show_sta_info(dm, input, &used, output, &out_len);
 		break;
 
 	case PHYDM_PAUSE_FUNC:
-		phydm_pause_func_console(p_dm, &input[0], &used, output, &out_len, input_num);
+		phydm_pause_func_console(dm, input, &used, output, &out_len);
 		break;
 
-	default:
-		PHYDM_SNPRINTF((output + used, out_len - used, "SET, unknown command!\n"));
+	case PHYDM_PER_TONE_EVM:
+		phydm_per_tone_evm(dm, input, &used, output, &out_len);
+		break;
+
+	#ifdef CONFIG_DYNAMIC_TX_TWR
+	case PHYDM_DYN_TXPWR:
+		phydm_dtp_debug(dm, input, &used, output, &out_len);
+		break;
+	#endif
+
+	case PHYDM_LNA_SAT:
+		#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+		phydm_lna_sat_debug(dm, input, &used, output, &out_len);
+		#endif
 		break;
 
+	default:
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Do not support this command\n");
+		break;
 	}
-#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+#endif /*@#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
 }
 
-#ifdef __ECOS
+#if defined __ECOS || defined __ICCARM__
 char *strsep(char **s, const char *ct)
 {
 	char *sbegin = *s;
 	char *end;
 
-	if (sbegin == NULL)
+	if (!sbegin)
 		return NULL;
 
 	end = strpbrk(sbegin, ct);
@@ -2914,320 +4333,367 @@ char *strsep(char **s, const char *ct)
 }
 #endif
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
-s32
-phydm_cmd(
-	struct PHY_DM_STRUCT	*p_dm,
-	char		*input,
-	u32	in_len,
-	u8	flag,
-	char	*output,
-	u32	out_len
-)
+#if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP | ODM_IOT))
+s32 phydm_cmd(struct dm_struct *dm, char *input, u32 in_len, u8 flag,
+	      char *output, u32 out_len)
 {
 	char *token;
-	u32	argc = 0;
-	char		argv[MAX_ARGC][MAX_ARGV];
+	u32 argc = 0;
+	char argv[MAX_ARGC][MAX_ARGV];
 
 	do {
 		token = strsep(&input, ", ");
 		if (token) {
-			strcpy(argv[argc], token);
+			if (strlen(token) <= MAX_ARGV)
+				strcpy(argv[argc], token);
+
 			argc++;
-		} else
+		} else {
 			break;
+		}
 	} while (argc < MAX_ARGC);
 
 	if (argc == 1)
 		argv[0][strlen(argv[0]) - 1] = '\0';
 
-	phydm_cmd_parser(p_dm, argv, argc, flag, output, out_len);
+	phydm_cmd_parser(dm, argv, argc, flag, output, out_len);
 
 	return 0;
 }
 #endif
 
-
-void
-phydm_fw_trace_handler(
-	void	*p_dm_void,
-	u8	*cmd_buf,
-	u8	cmd_len
-)
+void phydm_fw_trace_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len)
 {
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	/*u8	debug_trace_11byte[60];*/
-	u8		freg_num, c2h_seq, buf_0 = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+	/*@u8	debug_trace_11byte[60];*/
+	u8 freg_num, c2h_seq, buf_0 = 0;
 
-	if (!(p_dm->support_ic_type & PHYDM_IC_3081_SERIES))
+	if (!(dm->support_ic_type & PHYDM_IC_3081_SERIES))
 		return;
 
-	if ((cmd_len > 12) || (cmd_len == 0)) {
-		dbg_print("[Warning] Error C2H cmd_len=%d\n", cmd_len);
+	if (cmd_len > 12 || cmd_len == 0) {
+		pr_debug("[Warning] Error C2H cmd_len=%d\n", cmd_len);
 		return;
 	}
 
 	buf_0 = cmd_buf[0];
 	freg_num = (buf_0 & 0xf);
 	c2h_seq = (buf_0 & 0xf0) >> 4;
-	/*PHYDM_DBG(p_dm, DBG_FW_TRACE,("[FW debug message] freg_num = (( %d )), c2h_seq = (( %d ))\n", freg_num,c2h_seq ));*/
-
-	/*strncpy(debug_trace_11byte,&cmd_buf[1],(cmd_len-1));*/
-	/*debug_trace_11byte[cmd_len-1] = '\0';*/
-	/*PHYDM_DBG(p_dm, DBG_FW_TRACE,("[FW debug message] %s\n", debug_trace_11byte));*/
-	/*PHYDM_DBG(p_dm, DBG_FW_TRACE,("[FW debug message] cmd_len = (( %d ))\n", cmd_len));*/
-	/*PHYDM_DBG(p_dm, DBG_FW_TRACE,("[FW debug message] c2h_cmd_start  = (( %d ))\n", p_dm->c2h_cmd_start));*/
-
 
+	#if 0
+	PHYDM_DBG(dm, DBG_FW_TRACE,
+		  "[FW debug message] freg_num = (( %d )), c2h_seq=(( %d ))\n",
+		  freg_num, c2h_seq);
+
+	strncpy(debug_trace_11byte, &cmd_buf[1], (cmd_len - 1));
+	debug_trace_11byte[cmd_len - 1] = '\0';
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW debug message] %s\n",
+		  debug_trace_11byte);
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW debug message] cmd_len = (( %d ))\n",
+		  cmd_len);
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW debug message] c2h_cmd_start=((%d))\n",
+		  dm->c2h_cmd_start);
+
+	PHYDM_DBG(dm, DBG_FW_TRACE, "pre_seq = (( %d )), current_seq=((%d))\n",
+		  dm->pre_c2h_seq, c2h_seq);
+	PHYDM_DBG(dm, DBG_FW_TRACE, "fw_buff_is_enpty = (( %d ))\n",
+		  dm->fw_buff_is_enpty);
+	#endif
 
-	/*PHYDM_DBG(p_dm, DBG_FW_TRACE,("pre_seq = (( %d )), current_seq = (( %d ))\n", p_dm->pre_c2h_seq, c2h_seq));*/
-	/*PHYDM_DBG(p_dm, DBG_FW_TRACE,("fw_buff_is_enpty = (( %d ))\n", p_dm->fw_buff_is_enpty));*/
-
-	if ((c2h_seq != p_dm->pre_c2h_seq)  &&  p_dm->fw_buff_is_enpty == false) {
-		p_dm->fw_debug_trace[p_dm->c2h_cmd_start] = '\0';
-		PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW Dbg Queue Overflow] %s\n", p_dm->fw_debug_trace));
-		p_dm->c2h_cmd_start = 0;
+	if (c2h_seq != dm->pre_c2h_seq && dm->fw_buff_is_enpty == false) {
+		dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW Dbg Queue Overflow] %s\n",
+			  dm->fw_debug_trace);
+		dm->c2h_cmd_start = 0;
 	}
 
-	if ((cmd_len - 1) > (60 - p_dm->c2h_cmd_start)) {
-		p_dm->fw_debug_trace[p_dm->c2h_cmd_start] = '\0';
-		PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW Dbg Queue error: wrong C2H length] %s\n", p_dm->fw_debug_trace));
-		p_dm->c2h_cmd_start = 0;
+	if ((cmd_len - 1) > (60 - dm->c2h_cmd_start)) {
+		dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
+		PHYDM_DBG(dm, DBG_FW_TRACE,
+			  "[FW Dbg Queue error: wrong C2H length] %s\n",
+			  dm->fw_debug_trace);
+		dm->c2h_cmd_start = 0;
 		return;
 	}
 
-	strncpy((char *)&(p_dm->fw_debug_trace[p_dm->c2h_cmd_start]), (char *)&cmd_buf[1], (cmd_len - 1));
-	p_dm->c2h_cmd_start += (cmd_len - 1);
-	p_dm->fw_buff_is_enpty = false;
+	strncpy((char *)&dm->fw_debug_trace[dm->c2h_cmd_start],
+		(char *)&cmd_buf[1], (cmd_len - 1));
+	dm->c2h_cmd_start += (cmd_len - 1);
+	dm->fw_buff_is_enpty = false;
 
-	if (freg_num == 0 || p_dm->c2h_cmd_start >= 60) {
-		if (p_dm->c2h_cmd_start < 60)
-			p_dm->fw_debug_trace[p_dm->c2h_cmd_start] = '\0';
+	if (freg_num == 0 || dm->c2h_cmd_start >= 60) {
+		if (dm->c2h_cmd_start < 60)
+			dm->fw_debug_trace[dm->c2h_cmd_start] = '\0';
 		else
-			p_dm->fw_debug_trace[59] = '\0';
+			dm->fw_debug_trace[59] = '\0';
 
-		PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW DBG Msg] %s\n", p_dm->fw_debug_trace));
-		/*dbg_print("[FW DBG Msg] %s\n", p_dm->fw_debug_trace);*/
-		p_dm->c2h_cmd_start = 0;
-		p_dm->fw_buff_is_enpty = true;
+		PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s\n",
+			  dm->fw_debug_trace);
+#if 0
+		/*@dbg_print("[FW DBG Msg] %s\n", dm->fw_debug_trace);*/
+#endif
+		dm->c2h_cmd_start = 0;
+		dm->fw_buff_is_enpty = true;
 	}
 
-	p_dm->pre_c2h_seq = c2h_seq;
-#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+	dm->pre_c2h_seq = c2h_seq;
+#endif /*@#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
 }
 
-void
-phydm_fw_trace_handler_code(
-	void	*p_dm_void,
-	u8	*buffer,
-	u8	cmd_len
-)
+void phydm_fw_trace_handler_code(void *dm_void, u8 *buffer, u8 cmd_len)
 {
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	function = buffer[0];
-	u8	dbg_num = buffer[1];
-	u16	content_0 = (((u16)buffer[3]) << 8) | ((u16)buffer[2]);
-	u16	content_1 = (((u16)buffer[5]) << 8) | ((u16)buffer[4]);
-	u16	content_2 = (((u16)buffer[7]) << 8) | ((u16)buffer[6]);
-	u16	content_3 = (((u16)buffer[9]) << 8) | ((u16)buffer[8]);
-	u16	content_4 = (((u16)buffer[11]) << 8) | ((u16)buffer[10]);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 function = buffer[0];
+	u8 dbg_num = buffer[1];
+	u16 content_0 = (((u16)buffer[3]) << 8) | ((u16)buffer[2]);
+	u16 content_1 = (((u16)buffer[5]) << 8) | ((u16)buffer[4]);
+	u16 content_2 = (((u16)buffer[7]) << 8) | ((u16)buffer[6]);
+	u16 content_3 = (((u16)buffer[9]) << 8) | ((u16)buffer[8]);
+	u16 content_4 = (((u16)buffer[11]) << 8) | ((u16)buffer[10]);
 
 	if (cmd_len > 12)
-		PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW Msg] Invalid cmd length (( %d )) >12\n", cmd_len));
-
-	/* PHYDM_DBG(p_dm, DBG_FW_TRACE,("[FW Msg] Func=((%d)),  num=((%d)), ct_0=((%d)), ct_1=((%d)), ct_2=((%d)), ct_3=((%d)), ct_4=((%d))\n", */
-	/*	function, dbg_num, content_0, content_1, content_2, content_3, content_4)); */
-
-	/*--------------------------------------------*/
+		PHYDM_DBG(dm, DBG_FW_TRACE,
+			  "[FW Msg] Invalid cmd length (( %d )) >12\n",
+			  cmd_len);
+/*@--------------------------------------------*/
 #ifdef CONFIG_RA_FW_DBG_CODE
 	if (function == RATE_DECISION) {
 		if (dbg_num == 0) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] RA_CNT=((%d))  Max_device=((%d))--------------------------->\n", content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] RA_CNT=((%d))  Max_device=((%d))--------------------------->\n",
+					  content_1, content_2);
 			else if (content_0 == 2)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] Check RA macid= ((%d)), MediaStatus=((%d)), Dis_RA=((%d)),  try_bit=((0x%x))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] Check RA macid= ((%d)), MediaStatus=((%d)), Dis_RA=((%d)),  try_bit=((0x%x))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 			else if (content_0 == 3)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] Check RA  total=((%d)),  drop=((0x%x)), TXRPT_TRY_bit=((%x)), bNoisy=((%x))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] Check RA  total=((%d)),  drop=((0x%x)), TXRPT_TRY_bit=((%x)), bNoisy=((%x))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 		} else if (dbg_num == 1) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] RTY[0,1,2,3]=[ %d , %d , %d , %d ]\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] RTY[0,1,2,3]=[ %d , %d , %d , %d ]\n",
+					  content_1, content_2, content_3,
+					  content_4);
 			else if (content_0 == 2) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] RTY[4]=[ %d ], drop=(( %d )), total=(( %d )), current_rate=((0x %x ))", content_1, content_2, content_3, content_4));
-				phydm_print_rate(p_dm, (u8)content_4, DBG_FW_TRACE);
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] RTY[4]=[ %d ], drop=(( %d )), total=(( %d )), current_rate=((0x %x ))",
+					  content_1, content_2, content_3,
+					  content_4);
+				phydm_print_rate(dm, (u8)content_4,
+						 DBG_FW_TRACE);
 			} else if (content_0 == 3)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] penality_idx=(( %d ))\n", content_1));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] penality_idx=(( %d ))\n",
+					  content_1);
 			else if (content_0 == 4)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] RSSI=(( %d )), ra_stage = (( %d ))\n", content_1, content_2));
-		}
-
-		else if (dbg_num == 3) {
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] RSSI=(( %d )), ra_stage = (( %d ))\n",
+					  content_1, content_2);
+		} else if (dbg_num == 3) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] Fast_RA (( DOWN ))  total=((%d)),  total>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] Fast_RA (( DOWN ))  total=((%d)),  total>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 			else if (content_0 == 2)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] Fast_RA (( UP ))  total_acc=((%d)),  total_acc>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] Fast_RA (( UP ))  total_acc=((%d)),  total_acc>>1=((%d)), R4+R3+R2 = ((%d)), RateDownHold = ((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 			else if (content_0 == 3)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] Fast_RA (( UP )) ((rate Down Hold))  RA_CNT=((%d))\n", content_1));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] Fast_RA (( UP )) ((rate Down Hold))  RA_CNT=((%d))\n",
+					  content_1);
 			else if (content_0 == 4)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] Fast_RA (( UP )) ((tota_accl<5 skip))  RA_CNT=((%d))\n", content_1));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] Fast_RA (( UP )) ((tota_accl<5 skip))  RA_CNT=((%d))\n",
+					  content_1);
 			else if (content_0 == 8)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] Fast_RA (( Reset Tx Rpt )) RA_CNT=((%d))\n", content_1));
-		}
-
-		else if (dbg_num == 4) {
-			if (content_0 == 3) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] RER_CNT   PCR_ori =(( %d )),  ratio_ori =(( %d )), pcr_updown_bitmap =(( 0x%x )), pcr_var_diff =(( %d ))\n", content_1, content_2, content_3, content_4));
-				/**/
-			} else if (content_0 == 4) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] pcr_shift_value =(( %s%d )), rate_down_threshold =(( %d )), rate_up_threshold =(( %d ))\n", ((content_1) ? "+" : "-"), content_2, content_3, content_4));
-				/**/
-			} else if (content_0 == 5) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] pcr_mean =(( %d )), PCR_VAR =(( %d )), offset =(( %d )), decision_offset_p =(( %d ))\n", content_1, content_2, content_3, content_4));
-				/**/
-			}
-		}
-
-		else if (dbg_num == 5) {
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] Fast_RA (( Reset Tx Rpt )) RA_CNT=((%d))\n",
+					  content_1);
+		} else if (dbg_num == 4) {
+			if (content_0 == 3)
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] RER_CNT   PCR_ori =(( %d )),  ratio_ori =(( %d )), pcr_updown_bitmap =(( 0x%x )), pcr_var_diff =(( %d ))\n",
+					  content_1, content_2, content_3,
+					  content_4);
+			else if (content_0 == 4)
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] pcr_shift_value =(( %s%d )), rate_down_threshold =(( %d )), rate_up_threshold =(( %d ))\n",
+					  ((content_1) ? "+" : "-"), content_2,
+					  content_3, content_4);
+			else if (content_0 == 5)
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] pcr_mean =(( %d )), PCR_VAR =(( %d )), offset =(( %d )), decision_offset_p =(( %d ))\n",
+					  content_1, content_2, content_3,
+					  content_4);
+		} else if (dbg_num == 5) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] (( UP))  Nsc=(( %d )), N_High=(( %d )), RateUp_Waiting=(( %d )), RateUp_Fail=(( %d ))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] (( UP))  Nsc=(( %d )), N_High=(( %d )), RateUp_Waiting=(( %d )), RateUp_Fail=(( %d ))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 			else if (content_0 == 2)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] ((DOWN))  Nsc=(( %d )), N_Low=(( %d ))\n", content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] ((DOWN))  Nsc=(( %d )), N_Low=(( %d ))\n",
+					  content_1, content_2);
 			else if (content_0 == 3)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] ((HOLD))  Nsc=((%d)), N_High=((%d)), N_Low=((%d)), Reset_CNT=((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] ((HOLD))  Nsc=((%d)), N_High=((%d)), N_Low=((%d)), Reset_CNT=((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 		} else if (dbg_num == 0x60) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] ((AP RPT))  macid=((%d)), BUPDATE[macid]=((%d))\n", content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] ((AP RPT))  macid=((%d)), BUPDATE[macid]=((%d))\n",
+					  content_1, content_2);
 			else if (content_0 == 4)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] ((AP RPT))  pass=((%d)), rty_num=((%d)), drop=((%d)), total=((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] ((AP RPT))  pass=((%d)), rty_num=((%d)), drop=((%d)), total=((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 			else if (content_0 == 5)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW] ((AP RPT))  PASS=((%d)), RTY_NUM=((%d)), DROP=((%d)), TOTAL=((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW] ((AP RPT))  PASS=((%d)), RTY_NUM=((%d)), DROP=((%d)), TOTAL=((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 		}
-	}
-	/*--------------------------------------------*/
-	else if (function == INIT_RA_TABLE) {
+	} else if (function == INIT_RA_TABLE) {
 		if (dbg_num == 3)
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][INIT_RA_INFO] Ra_init, RA_SKIP_CNT = (( %d ))\n", content_0));
-
-	}
-	/*--------------------------------------------*/
-	else if (function == RATE_UP) {
+			PHYDM_DBG(dm, DBG_FW_TRACE,
+				  "[FW][INIT_RA_INFO] Ra_init, RA_SKIP_CNT = (( %d ))\n",
+				  content_0);
+	} else if (function == RATE_UP) {
 		if (dbg_num == 2) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][RateUp]  ((Highest rate->return)), macid=((%d))  Nsc=((%d))\n", content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][RateUp]  ((Highest rate->return)), macid=((%d))  Nsc=((%d))\n",
+					  content_1, content_2);
 		} else if (dbg_num == 5) {
 			if (content_0 == 0)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][RateUp]  ((rate UP)), up_rate_tmp=((0x%x)), rate_idx=((0x%x)), SGI_en=((%d)),  SGI=((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][RateUp]  ((rate UP)), up_rate_tmp=((0x%x)), rate_idx=((0x%x)), SGI_en=((%d)),  SGI=((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 			else if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][RateUp]  ((rate UP)), rate_1=((0x%x)), rate_2=((0x%x)), BW=((%d)), Try_Bit=((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][RateUp]  ((rate UP)), rate_1=((0x%x)), rate_2=((0x%x)), BW=((%d)), Try_Bit=((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 		}
-
-	}
-	/*--------------------------------------------*/
-	else if (function == RATE_DOWN) {
+	} else if (function == RATE_DOWN) {
 		if (dbg_num == 5) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][RateDownStep]  ((rate Down)), macid=((%d)), rate1=((0x%x)),  rate2=((0x%x)), BW=((%d))\n", content_1, content_2, content_3, content_4));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][RateDownStep]  ((rate Down)), macid=((%d)), rate1=((0x%x)),  rate2=((0x%x)), BW=((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 		}
 	} else if (function == TRY_DONE) {
 		if (dbg_num == 1) {
-			if (content_0 == 1) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][Try Done]  ((try succsess )) macid=((%d)), Try_Done_cnt=((%d))\n", content_1, content_2));
-				/**/
-			}
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][Try Done]  ((try succsess )) macid=((%d)), Try_Done_cnt=((%d))\n",
+					  content_1, content_2);
 		} else if (dbg_num == 2) {
-			if (content_0 == 1) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][Try Done]  ((try)) macid=((%d)), Try_Done_cnt=((%d)),  rate_2=((%d)),  try_succes=((%d))\n", content_1, content_2, content_3, content_4));
-				/**/
-			}
+			if (content_0 == 1)
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][Try Done]  ((try)) macid=((%d)), Try_Done_cnt=((%d)),  rate_2=((%d)),  try_succes=((%d))\n",
+					  content_1, content_2, content_3,
+					  content_4);
 		}
-	}
-	/*--------------------------------------------*/
-	else if (function == RA_H2C) {
+	} else if (function == RA_H2C) {
 		if (dbg_num == 1) {
-			if (content_0 == 0) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][H2C=0x49]  fw_trace_en=((%d)), mode =((%d)),  macid=((%d))\n", content_1, content_2, content_3));
-				/**/
-				/*C2H_RA_Dbg_code(F_RA_H2C,1,0, SysMib.ODM.DEBUG.fw_trace_en, mode, macid, 0);    //RA MASK*/
-			}
-#if 0
-			else if (dbg_num == 2) {
-
-				if (content_0 == 1) {
-					PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][H2C=0x40]  MACID=((%d)), rate ID=((%d)),  SGI=((%d)),  BW=((%d))\n", content_1, content_2, content_3, content_4));
-					/**/
-				} else if (content_0 == 2) {
-					PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][H2C=0x40]   VHT_en=((%d)), Disable_PowerTraining=((%d)),  Disable_RA=((%d)),  No_Update=((%d))\n", content_1, content_2, content_3, content_4));
-					/**/
-				} else if (content_0 == 3) {
-					PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][H2C=0x40]   RA_MSK=[%x | %x | %x | %x ]\n", content_1, content_2, content_3, content_4));
-					/**/
-				}
-			}
-#endif
+			if (content_0 == 0)
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][H2C=0x49]  fw_trace_en=((%d)), mode =((%d)),  macid=((%d))\n",
+					  content_1, content_2, content_3);
 		}
-	}
-	/*--------------------------------------------*/
-	else if (function == F_RATE_AP_RPT) {
+	} else if (function == F_RATE_AP_RPT) {
 		if (dbg_num == 1) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][AP RPT]  ((1)), SPE_STATIS=((0x%x))---------->\n", content_3));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][AP RPT]  ((1)), SPE_STATIS=((0x%x))---------->\n",
+					  content_3);
 		} else if (dbg_num == 2) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][AP RPT]  RTY_all=((%d))\n", content_1));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][AP RPT]  RTY_all=((%d))\n",
+					  content_1);
 		} else if (dbg_num == 3) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][AP RPT]  MACID1[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][AP RPT]  MACID1[%d], TOTAL=((%d)),  RTY=((%d))\n",
+					  content_3, content_1, content_2);
 		} else if (dbg_num == 4) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][AP RPT]  MACID2[%d], TOTAL=((%d)),  RTY=((%d))\n", content_3, content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][AP RPT]  MACID2[%d], TOTAL=((%d)),  RTY=((%d))\n",
+					  content_3, content_1, content_2);
 		} else if (dbg_num == 5) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][AP RPT]  MACID1[%d], PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][AP RPT]  MACID1[%d], PASS=((%d)),  DROP=((%d))\n",
+					  content_3, content_1, content_2);
 		} else if (dbg_num == 6) {
 			if (content_0 == 1)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][AP RPT]  MACID2[%d],, PASS=((%d)),  DROP=((%d))\n", content_3, content_1, content_2));
+				PHYDM_DBG(dm, DBG_FW_TRACE,
+					  "[FW][AP RPT]  MACID2[%d],, PASS=((%d)),  DROP=((%d))\n",
+					  content_3, content_1, content_2);
 		}
+	} else if (function == DBC_FW_CLM) {
+		PHYDM_DBG(dm, DBG_FW_TRACE,
+			  "[FW][CLM][%d, %d] = {%d, %d, %d, %d}\n", dbg_num,
+			  content_0, content_1, content_2, content_3,
+			  content_4);
 	} else {
-		PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n", function, dbg_num, content_0, content_1, content_2, content_3, content_4));
-		/**/
+		PHYDM_DBG(dm, DBG_FW_TRACE,
+			  "[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n",
+			  function, dbg_num, content_0, content_1, content_2,
+			  content_3, content_4);
 	}
 #else
-	PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n", function, dbg_num, content_0, content_1, content_2, content_3, content_4));
+	PHYDM_DBG(dm, DBG_FW_TRACE,
+		  "[FW][general][%d, %d, %d] = {%d, %d, %d, %d}\n", function,
+		  dbg_num, content_0, content_1, content_2, content_3,
+		  content_4);
 #endif
-	/*--------------------------------------------*/
+/*@--------------------------------------------*/
 
-#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+#endif /*@#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
 }
 
-void
-phydm_fw_trace_handler_8051(
-	void	*p_dm_void,
-	u8	*buffer,
-	u8	cmd_len
-)
+void phydm_fw_trace_handler_8051(void *dm_void, u8 *buffer, u8 cmd_len)
 {
 #ifdef CONFIG_PHYDM_DEBUG_FUNCTION
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if 0
 	if (cmd_len >= 3)
 		cmd_buf[cmd_len - 1] = '\0';
-	PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW DBG Msg] %s\n", &(cmd_buf[3])));
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s\n", &cmd_buf[3]);
 #else
 
 	int i = 0;
-	u8	extend_c2h_sub_id = 0, extend_c2h_dbg_len = 0, extend_c2h_dbg_seq = 0;
-	u8	fw_debug_trace[128];
-	u8	*extend_c2h_dbg_content = 0;
+	u8 extend_c2h_sub_id = 0, extend_c2h_dbg_len = 0;
+	u8 extend_c2h_dbg_seq = 0;
+	u8 fw_debug_trace[128];
+	u8 *extend_c2h_dbg_content = 0;
 
 	if (cmd_len > 127)
 		return;
 
 	extend_c2h_sub_id = buffer[0];
 	extend_c2h_dbg_len = buffer[1];
-	extend_c2h_dbg_content = buffer + 2; /*DbgSeq+DbgContent  for show HEX*/
+	extend_c2h_dbg_content = buffer + 2; /*@DbgSeq+DbgContent for show HEX*/
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 	RT_DISP(FC2H, C2H_Summary, ("[Extend C2H packet], Extend_c2hSubId=0x%x, extend_c2h_dbg_len=%d\n",
@@ -3245,21 +4711,22 @@ go_backfor_aggre_dbg_pkt:
 	RT_DISP(FC2H, C2H_Summary, ("[RTKFW, SEQ= %d] :", extend_c2h_dbg_seq));
 #endif
 
-	for (; ; i++) {
+	for (;; i++) {
 		fw_debug_trace[i] = extend_c2h_dbg_content[i];
 		if (extend_c2h_dbg_content[i + 1] == '\0') {
 			fw_debug_trace[i + 1] = '\0';
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW DBG Msg] %s", &(fw_debug_trace[0])));
+			PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s",
+				  &fw_debug_trace[0]);
 			break;
 		} else if (extend_c2h_dbg_content[i] == '\n') {
 			fw_debug_trace[i + 1] = '\0';
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("[FW DBG Msg] %s", &(fw_debug_trace[0])));
+			PHYDM_DBG(dm, DBG_FW_TRACE, "[FW DBG Msg] %s",
+				  &fw_debug_trace[0]);
 			buffer = extend_c2h_dbg_content + i + 3;
 			goto go_backfor_aggre_dbg_pkt;
 		}
 	}
 
-
 #endif
-#endif /*#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
+#endif /*@#ifdef CONFIG_PHYDM_DEBUG_FUNCTION*/
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.h
index dbe86a2a1534..b7735b55a753 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_debug.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,107 +9,101 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-
-#ifndef	__ODM_DBG_H__
+#ifndef __ODM_DBG_H__
 #define __ODM_DBG_H__
 
-/*#define DEBUG_VERSION	"1.1"*/  /*2015.07.29 YuChen*/
-/*#define DEBUG_VERSION	"1.2"*/  /*2015.08.28 Dino*/
-/*#define DEBUG_VERSION	"1.3"*/  /*2016.04.28 YuChen*/
-#define DEBUG_VERSION	"1.4"  /*2017.03.13 Dino*/
-
-/* -----------------------------------------------------------------------------
- *	Define the debug levels
- *
- *	1.	DBG_TRACE and DBG_LOUD are used for normal cases.
- *	So that, they can help SW engineer to develope 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
-
-/*FW DBG MSG*/
-#define	RATE_DECISION	BIT(0)
-#define	INIT_RA_TABLE	BIT(1)
-#define	RATE_UP		BIT(2)
-#define	RATE_DOWN		BIT(3)
-#define	TRY_DONE		BIT(4)
-#define	RA_H2C			BIT(5)
-#define	F_RATE_AP_RPT	BIT(7)
-
-/* -----------------------------------------------------------------------------
+/*@#define DEBUG_VERSION	"1.1"*/ /*@2015.07.29 YuChen*/
+/*@#define DEBUG_VERSION	"1.2"*/ /*@2015.08.28 Dino*/
+/*@#define DEBUG_VERSION	"1.3"*/ /*@2016.04.28 YuChen*/
+/*@#define DEBUG_VERSION	"1.4"*/ /*@2017.03.13 Dino*/
+#define DEBUG_VERSION "2.0" /*@2018.01.10 Dino*/
+
+/*@
+ * ============================================================
+ *  Definition
+ * ============================================================
+ */
+
+/*@FW DBG MSG*/
+#define	RATE_DECISION		1
+#define	INIT_RA_TABLE		2
+#define	RATE_UP			4
+#define	RATE_DOWN		8
+#define	TRY_DONE		16
+#define	RA_H2C			32
+#define	F_RATE_AP_RPT		64
+#define	DBC_FW_CLM		9
+
+#define PHYDM_SNPRINT_SIZE	64
+/* @----------------------------------------------------------------------------
  * Define the tracing components
  *
  * -----------------------------------------------------------------------------
- *BB FW Functions*/
-#define	PHYDM_FW_COMP_RA			BIT(0)
-#define	PHYDM_FW_COMP_MU			BIT(1)
-#define	PHYDM_FW_COMP_PATH_DIV		BIT(2)
-#define	PHYDM_FW_COMP_PT			BIT(3)
-
-
+ * BB FW Functions
+ */
+#define	PHYDM_FW_COMP_RA	BIT(0)
+#define	PHYDM_FW_COMP_MU	BIT(1)
+#define	PHYDM_FW_COMP_PATH_DIV	BIT(2)
+#define	PHYDM_FW_COMP_PT	BIT(3)
 
+/*@------------------------Export Marco Definition---------------------------*/
 
-/*------------------------Export Marco Definition---------------------------*/
-
-#define	config_phydm_read_txagc_check(data)		(data != INVALID_TXAGC_DATA)
+#define config_phydm_read_txagc_check(data) (data != INVALID_TXAGC_DATA)
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define	dbg_print				DbgPrint
-	#define	dcmd_printf				DCMD_Printf
-	#define	dcmd_scanf				DCMD_Scanf
-	#define RT_PRINTK				dbg_print
+	#if (DBG_CMD_SUPPORT == 1)
+		extern	VOID DCMD_Printf(const char *pMsg);
+	#else
+		#define DCMD_Printf(_pMsg)
+	#endif
+
+	#if OS_WIN_FROM_WIN10(OS_VERSION)
+	#define	pr_debug(fmt, ...) DbgPrintEx(DPFLTR_IHVNETWORK_ID, DPFLTR_ERROR_LEVEL, fmt, ##__VA_ARGS__)
+	#else
+	#define	pr_debug		DbgPrint
+	#endif
+
+	#define	dcmd_printf		DCMD_Printf
+	#define	dcmd_scanf		DCMD_Scanf
+	#define	RT_PRINTK		pr_debug
+	#define	PRINT_MAX_SIZE		512
+	#define PHYDM_SNPRINTF		RT_SPRINTF
+	#define	PHYDM_TRACE(_MSG_) 	EXhalPHYDMoutsrc_Print(_MSG_)
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	#define dbg_print(args...)
-	#define RT_PRINTK(fmt, args...)	\
-			RT_TRACE(((struct rtl_priv *)p_dm->adapter),	\
-				 COMP_PHYDM, DBG_DMESG, fmt, ## args)
-	#define	RT_DISP(dbgtype, dbgflag, printstr)
+	#define PHYDM_SNPRINTF		snprintf
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#define dbg_print	printk
-	#define RT_PRINTK(fmt, args...)	dbg_print(fmt, ## args)
+	#undef	pr_debug
+	#define pr_debug		printk
+	#define RT_PRINTK(fmt, args...)	pr_debug(fmt, ## args)
 	#define	RT_DISP(dbgtype, dbgflag, printstr)
+	#define RT_TRACE(adapter, comp, drv_level, fmt, args...)	\
+		RTW_INFO(fmt, ## args)
+	#define PHYDM_SNPRINTF		snprintf
+#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	#define pr_debug(fmt, args...)		RTW_PRINT_MSG(fmt, ## args)
+	#define RT_DEBUG(comp, drv_level, fmt, args...)	\
+		RTW_PRINT_MSG(fmt, ## args)
+	#define PHYDM_SNPRINTF		snprintf
 #else
-	#define dbg_print	panic_printk
-	/*#define RT_PRINTK(fmt, args...)	dbg_print("%s(): " fmt, __FUNCTION__, ## args);*/
-	#define RT_PRINTK(args...)	dbg_print(args)
+	#define pr_debug	panic_printk
+	/*@#define RT_PRINTK(fmt, args...)	pr_debug("%s(): " fmt, __FUNCTION__, ## args);*/
+	#define RT_PRINTK(fmt, args...)	pr_debug(fmt, ## args)
+	#define PHYDM_SNPRINTF		snprintf
 #endif
 
 #ifndef ASSERT
@@ -116,250 +111,369 @@
 #endif
 
 #if DBG
-#define PHYDM_DBG(p_dm, comp, fmt)				\
-	do {													\
-		if ((comp) & (p_dm->debug_components)) {	\
-														\
-			dbg_print("[PHYDM] ");						\
-			RT_PRINTK fmt;								\
-		}												\
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+#define PHYDM_DBG(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & dm->debug_components) {          \
+			pr_debug("[PHYDM] ");			\
+			RT_PRINTK(fmt, ## args);		\
+		}						\
 	} while (0)
 
-#define PHYDM_DBG_F(p_dm, comp, fmt)									 do {\
-		if ((comp) & p_dm->debug_components) { \
-			\
-			RT_PRINTK fmt;															\
+#define PHYDM_DBG_F(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			RT_PRINTK(fmt, ## args);		\
+		}						\
+	} while (0)
+
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)		\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			int __i;				\
+			u8 *__ptr = (u8 *)addr;			\
+			pr_debug("[PHYDM] ");			\
+			pr_debug(title_str);			\
+			pr_debug(" ");				\
+			for (__i = 0; __i < 6; __i++)		\
+				pr_debug("%02X%s", __ptr[__i], (__i == 5) ? "" : "-");\
+			pr_debug("\n");				\
+		}						\
+	} while (0)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+
+static __inline void PHYDM_DBG(PDM_ODM_T dm, int comp, char *fmt, ...)
+{
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->debug_components) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		DbgPrint("Failed (%d) to print message to buffer\n", rt_status);
+		return;
+	}
+
+	#if OS_WIN_FROM_WIN10(OS_VERSION)
+	DbgPrintEx(DPFLTR_IHVNETWORK_ID, DPFLTR_ERROR_LEVEL, "%s", buf);
+	#else
+	DbgPrint("%s", buf);
+	#endif
+}
+
+static __inline void PHYDM_DBG_F(PDM_ODM_T dm, int comp, char *fmt, ...)
+{
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->debug_components) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		/*@DbgPrint("DM Print Fail\n");*/
+		return;
+	}
+
+	#if OS_WIN_FROM_WIN10(OS_VERSION)
+	DbgPrintEx(DPFLTR_IHVNETWORK_ID, DPFLTR_ERROR_LEVEL, "%s", buf);
+	#else
+	DbgPrint("%s", buf);
+	#endif
+}
+
+#define PHYDM_PRINT_ADDR(p_dm, comp, title_str, ptr)		\
+	do {							\
+		if ((comp) & p_dm->debug_components) {		\
+								\
+			int __i;				\
+			u8 *__ptr = (u8 *)ptr;			\
+			pr_debug("[PHYDM] ");			\
+			pr_debug(title_str);			\
+			pr_debug(" ");				\
+			for (__i = 0; __i < 6; __i++)		\
+				pr_debug("%02X%s", __ptr[__i], (__i == 5) ? "" : "-");	\
+			pr_debug("\n");				\
 		}	\
 	} while (0)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+
+#define PHYDM_DBG(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			RT_DEBUG(COMP_PHYDM, \
+				 DBG_DMESG, "[PHYDM] " fmt, ##args);	\
+		}						\
+	} while (0)
 
-#define PHYDM_PRINT_ADDR(p_dm, comp, title_str, ptr)							 do {\
-		if ((comp) & p_dm->debug_components) { \
-			\
-			int __i;																\
-			u8 *__ptr = (u8 *)ptr;											\
-			dbg_print("[PHYDM] ");													\
-			dbg_print(title_str);													\
-			dbg_print(" ");														\
-			for (__i = 0; __i < 6; __i++)												\
-				dbg_print("%02X%s", __ptr[__i], (__i == 5) ? "" : "-");						\
-			dbg_print("\n");														\
+#define PHYDM_DBG_F(dm, comp, fmt, args...)			\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			RT_DEBUG(COMP_PHYDM, \
+				 DBG_DMESG, fmt, ##args);	\
 		}	\
 	} while (0)
 
-#define ODM_RT_TRACE(p_dm, comp, level, fmt)									\
-	do {	\
-		if (((comp) & p_dm->debug_components) && (level <= p_dm->debug_level || level == ODM_DBG_SERIOUS)) { \
-			\
-			if (p_dm->support_ic_type == ODM_RTL8188E)							\
-				dbg_print("[PhyDM-8188E] ");											\
-			else if (p_dm->support_ic_type == ODM_RTL8192E)						\
-				dbg_print("[PhyDM-8192E] ");											\
-			else if (p_dm->support_ic_type == ODM_RTL8812)							\
-				dbg_print("[PhyDM-8812A] ");											\
-			else if (p_dm->support_ic_type == ODM_RTL8821)							\
-				dbg_print("[PhyDM-8821A] ");											\
-			else if (p_dm->support_ic_type == ODM_RTL8814A)							\
-				dbg_print("[PhyDM-8814A] ");											\
-			else if (p_dm->support_ic_type == ODM_RTL8703B)							\
-				dbg_print("[PhyDM-8703B] ");											\
-			else if (p_dm->support_ic_type == ODM_RTL8822B)							\
-				dbg_print("[PhyDM-8822B] ");											\
-			else if (p_dm->support_ic_type == ODM_RTL8188F)							\
-				dbg_print("[PhyDM-8188F] ");											\
-			RT_PRINTK fmt;															\
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)		\
+	do {							\
+		if ((comp) & dm->debug_components) {		\
+			RT_DEBUG(COMP_PHYDM, \
+				 DBG_DMESG, "[PHYDM] " title_str "%pM\n",	\
+				 addr);				\
+		}						\
+	} while (0)
+
+#elif defined(DM_ODM_CE_MAC80211_V2)
+
+#define PHYDM_DBG(dm, comp, fmt, args...)
+#define PHYDM_DBG_F(dm, comp, fmt, args...)
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)
+
+#else
+
+#define PHYDM_DBG(dm, comp, fmt, args...)			\
+	do {							\
+		struct dm_struct *__dm = (dm);			\
+		if ((comp) & __dm->debug_components) {		\
+			RT_TRACE(((struct rtl_priv *)__dm->adapter),\
+				 COMP_PHYDM, DBG_DMESG,		\
+				 "[PHYDM] " fmt, ##args);	\
+		}						\
+	} while (0)
+
+#define PHYDM_DBG_F(dm, comp, fmt, args...)			\
+	do {							\
+		struct dm_struct *__dm = (dm);			\
+		if ((comp) & __dm->debug_components) {		\
+			RT_TRACE(((struct rtl_priv *)__dm->adapter),\
+				 COMP_PHYDM, DBG_DMESG, fmt, ##args);	\
 		}	\
 	} while (0)
 
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, addr)		\
+	do {							\
+		struct dm_struct *__dm = (dm);			\
+		if ((comp) & __dm->debug_components) {		\
+			RT_TRACE(((struct rtl_priv *)__dm->adapter),\
+				 COMP_PHYDM, DBG_DMESG,		\
+				 "[PHYDM] " title_str "%pM\n", addr);\
+		}						\
+	} while (0)
+#endif
+
+#else /*@#if DBG*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+static __inline void PHYDM_DBG(struct dm_struct *dm, int comp, char *fmt, ...)
+{
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if ((comp & dm->debug_components) == 0)
+		return;
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		DbgPrint("Failed (%d) to print message to buffer\n", rt_status);
+		return;
+	}
+
+	PHYDM_TRACE(buf);
+}
+static __inline void PHYDM_DBG_F(struct dm_struct *dm, int comp, char *fmt, ...)
+{
+}
 #else
-#define PHYDM_DBG(p_dm, comp, fmt)
-#define PHYDM_DBG_F(p_dm, comp, fmt)
-#define PHYDM_PRINT_ADDR(p_dm, comp, title_str, ptr)
+#define PHYDM_DBG(dm, comp, fmt, args...)
+#define PHYDM_DBG_F(dm, comp, fmt, args...)
+#endif
+#define PHYDM_PRINT_ADDR(dm, comp, title_str, ptr)
 
-#define ODM_RT_TRACE(p_dm, comp, level, fmt)
 #endif
 
-#define	BB_DBGPORT_PRIORITY_3	3	/*Debug function (the highest priority)*/
-#define	BB_DBGPORT_PRIORITY_2	2	/*Check hang function & Strong function*/
-#define	BB_DBGPORT_PRIORITY_1	1	/*Watch dog function*/
-#define	BB_DBGPORT_RELEASE		0	/*Init value (the lowest priority)*/
+#define	DBGPORT_PRI_3	3	/*@Debug function (the highest priority)*/
+#define	DBGPORT_PRI_2	2	/*@Check hang function & Strong function*/
+#define	DBGPORT_PRI_1	1	/*Watch dog function*/
+#define	DBGPORT_RELEASE	0	/*@Init value (the lowest priority)*/
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #define	PHYDM_DBGPRINT		0
 #define	PHYDM_SSCANF(x, y, z)	dcmd_scanf(x, y, z)
-#define	PHYDM_VAST_INFO_SNPRINTF	PHYDM_SNPRINTF
+#define	PDM_VAST_SNPF		PDM_SNPF
 #if (PHYDM_DBGPRINT == 1)
-#define	PHYDM_SNPRINTF(msg)	\
-	do {\
-		rsprintf msg;\
-		dbg_print(output);\
-	} while (0)
-#else
-#define	PHYDM_SNPRINTF(msg)	\
+#define	PDM_SNPF(msg)	\
 	do {\
 		rsprintf msg;\
-		dcmd_printf(output);\
+		pr_debug("%s", output);\
 	} while (0)
-#endif
-#else
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) || defined(__OSK__)
-	#define	PHYDM_DBGPRINT		0
 #else
-	#define	PHYDM_DBGPRINT		1
-#endif
-#define	MAX_ARGC				20
-#define	MAX_ARGV				16
-#define	DCMD_DECIMAL			"%d"
-#define	DCMD_CHAR				"%c"
-#define	DCMD_HEX				"%x"
+
+static __inline void PDM_SNPF(u32 out_len, u32 used, char *buff, int len,
+			      char *fmt, ...)
+{
+	RT_STATUS rt_status;
+	va_list args;
+	char buf[PRINT_MAX_SIZE] = {0};
+
+	if (fmt == NULL)
+		return;
+
+	va_start(args, fmt);
+	rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
+	va_end(args);
+
+	if (rt_status != RT_STATUS_SUCCESS) {
+		/*@DbgPrint("DM Print Fail\n");*/
+		return;
+	}
+
+	DCMD_Printf(buf);
+}
+
+
+
+#endif	/*@#if (PHYDM_DBGPRINT == 1)*/
+#else	/*@(DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))*/
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE) || defined(__OSK__)
+	#define	PHYDM_DBGPRINT	0
+	#else
+	#define	PHYDM_DBGPRINT	1
+	#endif
+#define	MAX_ARGC		20
+#define	MAX_ARGV		16
+#define	DCMD_DECIMAL		"%d"
+#define	DCMD_CHAR		"%c"
+#define	DCMD_HEX		"%x"
 
 #define	PHYDM_SSCANF(x, y, z)	sscanf(x, y, z)
 
-#define	PHYDM_VAST_INFO_SNPRINTF(msg)\
-	do {\
-		snprintf msg;\
-		dbg_print(output);\
+#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
+#define PDM_VAST_SNPF(out_len, used, buff, len, fmt, args...) RT_PRINTK(fmt, ## args)
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+#define	PDM_VAST_SNPF(out_len, used, buff, len, fmt, args...)	\
+	do {								\
+		RT_DEBUG(COMP_PHYDM, DBG_DMESG, fmt, ##args);		\
 	} while (0)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+#define	PDM_VAST_SNPF(out_len, used, buff, len, fmt, args...)
+#else
+#define	PDM_VAST_SNPF(out_len, used, buff, len, fmt, args...)	\
+		RT_TRACE(((struct rtl_priv *)dm->adapter), COMP_PHYDM, \
+			DBG_DMESG, fmt, ##args)
+#endif
 
 #if (PHYDM_DBGPRINT == 1)
-#define	PHYDM_SNPRINTF(msg)\
-	do {\
-		snprintf msg;\
-		dbg_print(output);\
+#define	PDM_SNPF(out_len, used, buff, len, fmt, args...)		\
+	do {								\
+		snprintf(buff, len, fmt, ##args);			\
+		pr_debug("%s", output);					\
 	} while (0)
 #else
-#define	PHYDM_SNPRINTF(msg)\
-	do {\
-		if (out_len > used)\
-			used += snprintf msg;\
+#define	PDM_SNPF(out_len, used, buff, len, fmt, args...)		\
+	do {								\
+		u32 *__pdm_snpf_u = &(used);				\
+		if (out_len > *__pdm_snpf_u)				\
+			*__pdm_snpf_u += snprintf(buff, len, fmt, ##args);\
 	} while (0)
 #endif
 #endif
+/* @1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================
+ */
+
+enum auto_detection_state { /*@Fast antenna training*/
+	AD_LEGACY_MODE	= 0,
+	AD_HT_MODE	= 1,
+	AD_VHT_MODE	= 2
+};
+
+/*@
+ * ============================================================
+ * 1  structure
+ * ============================================================
+ */
+
+#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
+u8 phydm_get_l_sig_rate(void *dm_void, u8 rate_idx_l_sig);
+#endif
 
-void
-phydm_init_debug_setting(
-	struct	PHY_DM_STRUCT	*p_dm
-);
-
-void
-phydm_bb_dbg_port_header_sel(
-	void		*p_dm_void,
-	u32		header_idx
-);
-
-u8
-phydm_set_bb_dbg_port(
-	void		*p_dm_void,
-	u8		curr_dbg_priority,
-	u32		debug_port
-);
-
-void
-phydm_release_bb_dbg_port(
-	void		*p_dm_void
-);
-
-u32
-phydm_get_bb_dbg_port_value(
-	void		*p_dm_void
-);
-
-void
-phydm_reset_rx_rate_distribution(
-	struct PHY_DM_STRUCT	*p_dm_odm
-);
-
-void
-phydm_rx_rate_distribution
-(
-	void			*p_dm_void
-);
-
-void
-phydm_get_avg_phystatus_val
-(
-	void		*p_dm_void
-);
-
-void
-phydm_get_phy_statistic(
-	void		*p_dm_void
-);
-
-void 
-phydm_basic_dbg_message(
-	void		*p_dm_void
-);
-
-void 
-phydm_basic_profile(
-	void		*p_dm_void,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
+void phydm_init_debug_setting(struct dm_struct *dm);
+
+void phydm_bb_dbg_port_header_sel(void *dm_void, u32 header_idx);
+
+u8 phydm_set_bb_dbg_port(void *dm_void, u8 curr_dbg_priority, u32 debug_port);
+
+void phydm_release_bb_dbg_port(void *dm_void);
+
+u32 phydm_get_bb_dbg_port_val(void *dm_void);
+
+void phydm_reset_rx_rate_distribution(struct dm_struct *dm);
+
+void phydm_rx_rate_distribution(void *dm_void);
+
+void phydm_show_phy_hitogram(void *dm_void);
+
+void phydm_get_avg_phystatus_val(void *dm_void);
+
+void phydm_get_phy_statistic(void *dm_void);
+
+void phydm_dm_summary(void *dm_void, u8 macid);
+
+void phydm_basic_dbg_message(void *dm_void);
+
+void phydm_basic_profile(void *dm_void, u32 *_used, char *output,
+			 u32 *_out_len);
 #if (DM_ODM_SUPPORT_TYPE & (ODM_CE | ODM_AP))
-s32
-phydm_cmd(
-	struct PHY_DM_STRUCT	*p_dm,
-	char		*input,
-	u32		in_len,
-	u8		flag,
-	char		*output,
-	u32		out_len
-);
+s32 phydm_cmd(struct dm_struct *dm, char *input, u32 in_len, u8 flag,
+	      char *output, u32 out_len);
 #endif
-void
-phydm_cmd_parser(
-	struct PHY_DM_STRUCT	*p_dm,
-	char		input[][16],
-	u32		input_num,
-	u8		flag,
-	char		*output,
-	u32		out_len
-);
+void phydm_cmd_parser(struct dm_struct *dm, char input[][16], u32 input_num,
+		      u8 flag, char *output, u32 out_len);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phydm_basic_dbg_msg_cli_win(void *dm_void, char *buf);
+
 void phydm_sbd_check(
-	struct	PHY_DM_STRUCT	*p_dm
-);
+	struct dm_struct *dm);
 
 void phydm_sbd_callback(
-	struct timer_list		*p_timer
-);
+	struct phydm_timer_list *timer);
 
 void phydm_sbd_workitem_callback(
-	void	*p_context
-);
+	void *context);
 #endif
 
-void
-phydm_fw_trace_en_h2c(
-	void		*p_dm_void,
-	boolean	enable,
-	u32		fw_debug_component,
-	u32		monitor_mode,
-	u32		macid
-);
-
-void
-phydm_fw_trace_handler(
-	void	*p_dm_void,
-	u8	*cmd_buf,
-	u8	cmd_len
-);
-
-void
-phydm_fw_trace_handler_code(
-	void	*p_dm_void,
-	u8	*buffer,
-	u8	cmd_len
-);
-
-void
-phydm_fw_trace_handler_8051(
-	void	*p_dm_void,
-	u8	*cmd_buf,
-	u8	cmd_len
-);
-
-#endif /* __ODM_DBG_H__ */
+void phydm_fw_trace_en_h2c(void *dm_void, boolean enable,
+			   u32 fw_debug_component, u32 monitor_mode, u32 macid);
+
+void phydm_fw_trace_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+void phydm_fw_trace_handler_code(void *dm_void, u8 *buffer, u8 cmd_len);
+
+void phydm_fw_trace_handler_8051(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+#endif /* @__ODM_DBG_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.c
index 53f00801f1b1..5f4cd42bee9a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,262 +9,603 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/*
-============================================================
- include files
-============================================================
-*/
+/*@
+ * ============================================================
+ * include files
+ * ============================================================
+ */
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
 #if defined(CONFIG_PHYDM_DFS_MASTER)
 
-boolean phydm_dfs_is_meteorology_channel(void *p_dm_void){
+boolean phydm_dfs_is_meteorology_channel(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	
-	u8 c_channel = *(p_dm->p_channel);
-	u8 band_width = *(p_dm->p_band_width);
-	
-	return ( (band_width == CHANNEL_WIDTH_80 && (c_channel) >= 116 && (c_channel) <= 128) || 
-	  (band_width == CHANNEL_WIDTH_40 && (c_channel) >= 116 && (c_channel) <= 128) ||
-	  (band_width == CHANNEL_WIDTH_20 && (c_channel) >= 120 && (c_channel) <= 128) );
+	u8 ch = *dm->channel;
+	u8 bw = *dm->band_width;
+
+	return ((bw  == CHANNEL_WIDTH_80 && (ch) >= 116 && (ch) <= 128) ||
+		(bw  == CHANNEL_WIDTH_40 && (ch) >= 116 && (ch) <= 128) ||
+		(bw  == CHANNEL_WIDTH_20 && (ch) >= 120 && (ch) <= 128));
 }
 
-void phydm_radar_detect_reset(void *p_dm_void)
+void phydm_radar_detect_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	odm_set_bb_reg(p_dm, 0x924, BIT(15), 0);
-	odm_set_bb_reg(p_dm, 0x924, BIT(15), 1);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		odm_set_bb_reg(dm, R_0xa40, BIT(15), 0);
+		odm_set_bb_reg(dm, R_0xa40, BIT(15), 1);
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		odm_set_bb_reg(dm, R_0xf58, BIT(29), 0);
+		odm_set_bb_reg(dm, R_0xf58, BIT(29), 1);
+	#endif
+	} else {
+		odm_set_bb_reg(dm, R_0x924, BIT(15), 0);
+		odm_set_bb_reg(dm, R_0x924, BIT(15), 1);
+	}
 }
 
-void phydm_radar_detect_disable(void *p_dm_void)
+void phydm_radar_detect_disable(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		odm_set_bb_reg(dm, R_0xa40, BIT(15), 0);
+	#if (RTL8721D_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8721D))
+		odm_set_bb_reg(dm, R_0xf58, BIT(29), 0);
+	#endif
+	else
+		odm_set_bb_reg(dm, R_0x924, BIT(15), 0);
 
-	odm_set_bb_reg(p_dm, 0x924, BIT(15), 0);
-	PHYDM_DBG(p_dm, DBG_DFS, ("\n"));
+	PHYDM_DBG(dm, DBG_DFS, "\n");
 }
 
-static void phydm_radar_detect_with_dbg_parm(void *p_dm_void)
+static void phydm_radar_detect_with_dbg_parm(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	odm_set_bb_reg(p_dm, 0x918, MASKDWORD, p_dm->radar_detect_reg_918);
-	odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, p_dm->radar_detect_reg_91c);
-	odm_set_bb_reg(p_dm, 0x920, MASKDWORD, p_dm->radar_detect_reg_920);
-	odm_set_bb_reg(p_dm, 0x924, MASKDWORD, p_dm->radar_detect_reg_924);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_RTL8721D) {
+		odm_set_bb_reg(dm, R_0xf54, MASKDWORD,
+			       dm->radar_detect_reg_f54);
+		odm_set_bb_reg(dm, R_0xf58, MASKDWORD,
+			       dm->radar_detect_reg_f58);
+		odm_set_bb_reg(dm, R_0xf5c, MASKDWORD,
+			       dm->radar_detect_reg_f5c);
+		odm_set_bb_reg(dm, R_0xf70, MASKDWORD,
+			       dm->radar_detect_reg_f70);
+		odm_set_bb_reg(dm, R_0xf74, MASKDWORD,
+			       dm->radar_detect_reg_f74);
+	} else {
+		odm_set_bb_reg(dm, R_0x918, MASKDWORD,
+			       dm->radar_detect_reg_918);
+		odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+			       dm->radar_detect_reg_91c);
+		odm_set_bb_reg(dm, R_0x920, MASKDWORD,
+			       dm->radar_detect_reg_920);
+		odm_set_bb_reg(dm, R_0x924, MASKDWORD,
+			       dm->radar_detect_reg_924);
+	}
 }
 
-/* Init radar detection parameters, called after ch, bw is set */
-void phydm_radar_detect_enable(void *p_dm_void)
+/* @Init radar detection parameters, called after ch, bw is set */
+
+void phydm_radar_detect_enable(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DFS_STATISTICS	*p_dfs = (struct _DFS_STATISTICS *)phydm_get_structure(p_dm, PHYDM_DFS);
-	u8 region_domain = p_dm->dfs_region_domain;
-	u8 c_channel = *(p_dm->p_channel);
-	u8 band_width = *(p_dm->p_band_width);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
+	u8 region_domain = dm->dfs_region_domain;
+	u8 c_channel = *dm->channel;
+	u8 band_width = *dm->band_width;
 	u8 enable = 0;
+	u8 short_pw_upperbound = 0;
 
-	PHYDM_DBG(p_dm, DBG_DFS, ("test, region_domain = %d\n", region_domain));
+	PHYDM_DBG(dm, DBG_DFS, "test, region_domain = %d\n", region_domain);
 	if (region_domain == PHYDM_DFS_DOMAIN_UNKNOWN) {
-		PHYDM_DBG(p_dm, DBG_DFS, ("PHYDM_DFS_DOMAIN_UNKNOWN\n"));
+		PHYDM_DBG(dm, DBG_DFS, "PHYDM_DFS_DOMAIN_UNKNOWN\n");
 		goto exit;
 	}
 
-	if (p_dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8812 | ODM_RTL8881A)) {
-
-		odm_set_bb_reg(p_dm, 0x814, 0x3fffffff, 0x04cc4d10);
-		odm_set_bb_reg(p_dm, 0x834, MASKBYTE0, 0x06);
+	if (dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8812 | ODM_RTL8881A)) {
+		odm_set_bb_reg(dm, R_0x814, 0x3fffffff, 0x04cc4d10);
+		odm_set_bb_reg(dm, R_0x834, MASKBYTE0, 0x06);
 
-		if (p_dm->radar_detect_dbg_parm_en) {
-			phydm_radar_detect_with_dbg_parm(p_dm);
+		if (dm->radar_detect_dbg_parm_en) {
+			phydm_radar_detect_with_dbg_parm(dm);
 			enable = 1;
 			goto exit;
 		}
 
 		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
-			odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c17ecdf);
-			odm_set_bb_reg(p_dm, 0x924, MASKDWORD, 0x01528500);
-			odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x0fa21a20);
-			odm_set_bb_reg(p_dm, 0x920, MASKDWORD, 0xe0f69204);
+			odm_set_bb_reg(dm, R_0x918, MASKDWORD, 0x1c17ecdf);
+			odm_set_bb_reg(dm, R_0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, R_0x91c, MASKDWORD, 0x0fa21a20);
+			odm_set_bb_reg(dm, R_0x920, MASKDWORD, 0xe0f69204);
 
 		} else if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
-			odm_set_bb_reg(p_dm, 0x924, MASKDWORD, 0x01528500);
-			odm_set_bb_reg(p_dm, 0x920, MASKDWORD, 0xe0d67234);
+			odm_set_bb_reg(dm, R_0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, R_0x920, MASKDWORD, 0xe0d67234);
 
 			if (c_channel >= 52 && c_channel <= 64) {
-				odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c16ecdf);
-				odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x0f141a20);
+				odm_set_bb_reg(dm, R_0x918, MASKDWORD,
+					       0x1c16ecdf);
+				odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+					       0x0f141a20);
 			} else {
-				odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c16acdf);
+				odm_set_bb_reg(dm, R_0x918, MASKDWORD,
+					       0x1c16acdf);
 				if (band_width == CHANNEL_WIDTH_20)
-					odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x64721a20);
+					odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+						       0x64721a20);
 				else
-					odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x68721a20);
+					odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+						       0x68721a20);
 			}
 
 		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
-			odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c16acdf);
-			odm_set_bb_reg(p_dm, 0x924, MASKDWORD, 0x01528500);
-			odm_set_bb_reg(p_dm, 0x920, MASKDWORD, 0xe0d67231);
+			odm_set_bb_reg(dm, R_0x918, MASKDWORD, 0x1c16acdf);
+			odm_set_bb_reg(dm, R_0x924, MASKDWORD, 0x01528500);
+			odm_set_bb_reg(dm, R_0x920, MASKDWORD, 0xe0d67231);
 			if (band_width == CHANNEL_WIDTH_20)
-				odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x64741a20);
+				odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+					       0x64741a20);
 			else
-				odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x68741a20);
+				odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+					       0x68741a20);
 
 		} else {
 			/* not supported */
-			PHYDM_DBG(p_dm, DBG_DFS, ("Unsupported dfs_region_domain:%d\n", region_domain));
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Unsupported dfs_region_domain:%d\n",
+				  region_domain);
 			goto exit;
 		}
 
-	} else if (p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
+	} else if (dm->support_ic_type &
+		   (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
 
-		odm_set_bb_reg(p_dm, 0x814, 0x3fffffff, 0x04cc4d10);
-		odm_set_bb_reg(p_dm, 0x834, MASKBYTE0, 0x06);
+		odm_set_bb_reg(dm, R_0x814, 0x3fffffff, 0x04cc4d10);
+		odm_set_bb_reg(dm, R_0x834, MASKBYTE0, 0x06);
 
-		/* 8822B only, when BW = 20M, DFIR output is 40Mhz, but DFS input is 80MMHz, so it need to upgrade to 80MHz */
-		if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+		/* @8822B only, when BW = 20M, DFIR output is 40Mhz,
+		 * but DFS input is 80MMHz, so it need to upgrade to 80MHz
+		 */
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
 			if (band_width == CHANNEL_WIDTH_20)
-				odm_set_bb_reg(p_dm, 0x1984, BIT(26), 1);
+				odm_set_bb_reg(dm, R_0x1984, BIT(26), 1);
 			else
-				odm_set_bb_reg(p_dm, 0x1984, BIT(26), 0);
+				odm_set_bb_reg(dm, R_0x1984, BIT(26), 0);
 		}
 
-		if (p_dm->radar_detect_dbg_parm_en) {
-			phydm_radar_detect_with_dbg_parm(p_dm);
+		if (dm->radar_detect_dbg_parm_en) {
+			phydm_radar_detect_with_dbg_parm(dm);
 			enable = 1;
 			goto exit;
 		}
 
 		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
-			odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c16acdf);
-			odm_set_bb_reg(p_dm, 0x924, MASKDWORD, 0x095a8500);
-			odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x0fa21a20);
-			odm_set_bb_reg(p_dm, 0x920, MASKDWORD, 0xe0f57204);
+			odm_set_bb_reg(dm, R_0x918, MASKDWORD, 0x1c16acdf);
+			odm_set_bb_reg(dm, R_0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, R_0x91c, MASKDWORD, 0x0fc01a1f);
+			odm_set_bb_reg(dm, R_0x920, MASKDWORD, 0xe0f57204);
 
 		} else if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
-			odm_set_bb_reg(p_dm, 0x924, MASKDWORD, 0x095a8500);
-			odm_set_bb_reg(p_dm, 0x920, MASKDWORD, 0xe0d67234);
+			odm_set_bb_reg(dm, R_0x924, MASKDWORD, 0x095a8500);
+			odm_set_bb_reg(dm, R_0x920, MASKDWORD, 0xe0d67234);
 
 			if (c_channel >= 52 && c_channel <= 64) {
-				odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c16ecdf);
-				odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x0f141a20);
+				odm_set_bb_reg(dm, R_0x918, MASKDWORD,
+					       0x1c16ecdf);
+				odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+					       0x0f141a1f);
 			} else {
-				odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c166cdf);
+				odm_set_bb_reg(dm, R_0x918, MASKDWORD,
+					       0x1c166cdf);
 				if (band_width == CHANNEL_WIDTH_20)
-					odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x64721a20);
+					odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+						       0x64721a1f);
 				else
-					odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x68721a20);
+					odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+						       0x68721a1f);
 			}
 
 		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
-			odm_set_bb_reg(p_dm, 0x918, MASKDWORD, 0x1c166cdf);
-			odm_set_bb_reg(p_dm, 0x924, MASKDWORD, 0x095a8500);
-			odm_set_bb_reg(p_dm, 0x920, MASKDWORD, 0xe0d67231);
+			odm_set_bb_reg(dm, R_0x918, MASKDWORD, 0x1c176cdf);
+			odm_set_bb_reg(dm, R_0x924, MASKDWORD, 0x095a8400);
+			odm_set_bb_reg(dm, R_0x920, MASKDWORD, 0xe076d231);
 			if (band_width == CHANNEL_WIDTH_20)
-				odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x64741a20);
+				odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+					       0x64901a1f);
 			else
-				odm_set_bb_reg(p_dm, 0x91c, MASKDWORD, 0x68741a20);
+				odm_set_bb_reg(dm, R_0x91c, MASKDWORD,
+					       0x62901a1f);
 
 		} else {
 			/* not supported */
-			PHYDM_DBG(p_dm, DBG_DFS, ("Unsupported dfs_region_domain:%d\n", region_domain));
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Unsupported dfs_region_domain:%d\n",
+				  region_domain);
 			goto exit;
 		}
+		/*RXHP low corner will extend the pulse width,
+		 *so we need to increase the upper bound.
+		 */
+		if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+			if (odm_get_bb_reg(dm, 0x8d8,
+					   BIT28 | BIT27 | BIT26) == 0) {
+				short_pw_upperbound =
+					(u8)odm_get_bb_reg(dm, 0x91c,
+						       BIT23 | BIT22 |
+						       BIT21 | BIT20);
+				if ((short_pw_upperbound + 4) > 15)
+					odm_set_bb_reg(dm, 0x91c,
+						       BIT23 | BIT22 |
+						       BIT21 | BIT20, 15);
+				else
+					odm_set_bb_reg(dm, 0x91c,
+						       BIT23 | BIT22 |
+						       BIT21 | BIT20,
+						       short_pw_upperbound + 4);
+			}
+			/*@if peak index -1~+1, use original NB method*/
+			odm_set_bb_reg(dm, 0x19e4, 0x003C0000, 13);
+			odm_set_bb_reg(dm, 0x924, 0x70000, 0);
+		}
+
+		if (dm->support_ic_type & (ODM_RTL8881A))
+			odm_set_bb_reg(dm, 0xb00, 0xc0000000, 3);
+
+		/*@for 8814 new dfs mechanism setting*/
+		if (dm->support_ic_type &
+		    (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
+			/*Turn off dfs scaling factor*/
+			odm_set_bb_reg(dm, 0x19e4, 0x1fff, 0x0c00);
+			/*NonDC peak_th = 2times DC peak_th*/
+			odm_set_bb_reg(dm, 0x19e4, 0x30000, 1);
+			/*power for debug and auto test flow latch after ST*/
+			odm_set_bb_reg(dm, 0x9f8, 0xc0000000, 3);
+
+			/*@low pulse width radar pattern will cause wrong drop*/
+			/*@disable peak index should the same
+			 *during the same short pulse (new mechan)
+			 */
+			odm_set_bb_reg(dm, 0x9f4, 0x80000000, 0);
+
+			/*@disable peak index should the same
+			 *during the same short pulse (old mechan)
+			 */
+			odm_set_bb_reg(dm, 0x924, 0x20000000, 0);
+
+			/*@if peak index diff >=2, then drop the result*/
+			odm_set_bb_reg(dm, 0x19e4, 0xe000, 2);
+			if (region_domain == 2) {
+				if ((c_channel >= 52) && (c_channel <= 64)) {
+					/*pulse width hist th setting*/
+					/*th1=2*04us*/
+					odm_set_bb_reg(dm, 0x19e4,
+						       0xff000000, 2);
+					/*th2 = 3*0.4us, th3 = 4*0.4us
+					 *th4 = 7*0.4, th5 = 34*0.4
+					 */
+					odm_set_bb_reg(dm, 0x19e8,
+						       MASKDWORD, 0x22070403);
+
+					/*PRI hist th setting*/
+					/*th1=42*32us*/
+					odm_set_bb_reg(dm, 0x19b8,
+						       0x00007f80, 42);
+					/*th2=47*32us, th3=115*32us,
+					 *th4=123*32us, th5=130*32us
+					 */
+					odm_set_bb_reg(dm, 0x19ec,
+						       MASKDWORD, 0x827b732f);
+				} else {
+					/*pulse width hist th setting*/
+					/*th1=2*04us*/
+					odm_set_bb_reg(dm, 0x19e4,
+						       0xff000000, 1);
+					/*th2 = 13*0.4us, th3 = 26*0.4us
+					 *th4 = 75*0.4us, th5 = 255*0.4us
+					 */
+					odm_set_bb_reg(dm, 0x19e8,
+						       MASKDWORD, 0xff4b1a0d);
+					/*PRI hist th setting*/
+					/*th1=4*32us*/
+
+					odm_set_bb_reg(dm, 0x19b8,
+						       0x00007f80, 4);
+					/*th2=8*32us, th3=16*32us,
+					 *th4=32*32us, th5=128*32=4096us
+					 */
+					odm_set_bb_reg(dm, 0x19ec,
+						       MASKDWORD, 0x80201008);
+				}
+			}
+			/*@ETSI*/
+			else if (region_domain == 3) {
+				/*pulse width hist th setting*/
+				/*th1=2*04us*/
+				odm_set_bb_reg(dm, 0x19e4, 0xff000000, 1);
+				odm_set_bb_reg(dm, 0x19e8,
+					       MASKDWORD, 0x68260d06);
+				/*PRI hist th setting*/
+				/*th1=7*32us*/
+				odm_set_bb_reg(dm, 0x19b8, 0x00007f80, 7);
+				/*th2=40*32us, th3=80*32us,
+				 *th4=110*32us, th5=157*32=5024
+				 */
+				odm_set_bb_reg(dm, 0x19ec,
+					       MASKDWORD, 0xc06e2010);
+			}
+			/*@FCC*/
+			else if (region_domain == 1) {
+				/*pulse width hist th setting*/
+				/*th1=2*04us*/
+				odm_set_bb_reg(dm, 0x19e4, 0xff000000, 2);
+				/*th2 = 13*0.4us, th3 = 26*0.4us,
+				 *th4 = 75*0.4us, th5 = 255*0.4us
+				 */
+				odm_set_bb_reg(dm, 0x19e8,
+					       MASKDWORD, 0xff4b1a0d);
+
+				/*PRI hist th setting*/
+				/*th1=4*32us*/
+				odm_set_bb_reg(dm, 0x19b8, 0x00007f80, 4);
+				/*th2=8*32us, th3=21*32us,
+				 *th4=32*32us, th5=96*32=3072
+				 */
+				if (band_width == CHANNEL_WIDTH_20)
+					odm_set_bb_reg(dm, 0x19ec,
+						       MASKDWORD, 0x60282010);
+				else
+					odm_set_bb_reg(dm, 0x19ec,
+						       MASKDWORD, 0x60282420);
+			} else {
+			}
+		}
+	} else if (dm->support_ic_type &
+		   ODM_IC_JGR3_SERIES) {
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & ODM_RTL8721D) {
+		odm_set_bb_reg(dm, R_0x814, 0x3fffffff, 0x04cc4d10);
+		/*CCA MASK*/
+		odm_set_bb_reg(dm, R_0xc38, 0x07c00000, 0x06);
+		/*CCA Threshold*/
+		odm_set_bb_reg(dm, R_0xc3c, 0x00000007, 0x0);
+
+		if (dm->radar_detect_dbg_parm_en) {
+			phydm_radar_detect_with_dbg_parm(dm);
+			enable = 1;
+			goto exit;
+		}
+
+		if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+			odm_set_bb_reg(dm, R_0xf54, MASKDWORD, 0x230006a8);
+			odm_set_bb_reg(dm, R_0xf58, MASKDWORD, 0x354cd7dd);
+			odm_set_bb_reg(dm, R_0xf5c, MASKDWORD, 0x9984ab25);
+			odm_set_bb_reg(dm, R_0xf70, MASKDWORD, 0xbd9fab98);
+			odm_set_bb_reg(dm, R_0xf74, MASKDWORD, 0xcc45029f);
+
+		} else if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			odm_set_bb_reg(dm, R_0xf54, MASKDWORD, 0x230006a8);
+			odm_set_bb_reg(dm, R_0xf5c, MASKDWORD, 0x9984ab25);
+			odm_set_bb_reg(dm, R_0xf70, MASKDWORD, 0xbd9fb398);
+			odm_set_bb_reg(dm, R_0xf74, MASKDWORD, 0xcc450e9d);
+
+			if (c_channel >= 52 && c_channel <= 64) {
+				odm_set_bb_reg(dm, R_0xf58, MASKDWORD,
+					       0x354cd7fd);
+			} else {
+				odm_set_bb_reg(dm, R_0xf58, MASKDWORD,
+					       0x354cd7bd);
+			}
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			odm_set_bb_reg(dm, R_0xf54, MASKDWORD, 0x230006a8);
+			odm_set_bb_reg(dm, R_0xf58, MASKDWORD, 0x3558d7bd);
+			odm_set_bb_reg(dm, R_0xf5c, MASKDWORD, 0x9984ab35);
+			odm_set_bb_reg(dm, R_0xf70, MASKDWORD, 0xbd9fb398);
+			odm_set_bb_reg(dm, R_0xf74, MASKDWORD, 0xcc444e9d);
+		} else {
+			/* not supported */
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Unsupported dfs_region_domain:%d\n",
+				  region_domain);
+			goto exit;
+		}
+
+		/*if peak index -1~+1, use original NB method*/
+		odm_set_bb_reg(dm, R_0xf70, 0x00070000, 0x7);
+		odm_set_bb_reg(dm, R_0xf74, 0x000c0000, 0);
+
+		/*Turn off dfs scaling factor*/
+		odm_set_bb_reg(dm, R_0xf70, 0x00080000, 0x0);
+		/*NonDC peak_th = 2times DC peak_th*/
+		odm_set_bb_reg(dm, R_0xf58, 0x00007800, 1);
+
+		/*low pulse width radar pattern will cause wrong drop*/
+		/*disable peak index should the same*/
+		/*during the same short pulse (new mechan)*/
+		odm_set_bb_reg(dm, R_0xf70, 0x00100000, 0x0);
+		/*if peak index diff >=2, then drop the result*/
+		odm_set_bb_reg(dm, R_0xf70, 0x30000000, 0x2);
+	#endif
 	} else {
-		/* not supported IC type*/
-		PHYDM_DBG(p_dm, DBG_DFS, ("Unsupported IC type:%d\n", p_dm->support_ic_type));
+		/*not supported IC type*/
+		PHYDM_DBG(dm, DBG_DFS, "Unsupported IC type:%d\n",
+			  dm->support_ic_type);
 		goto exit;
 	}
 
 	enable = 1;
 
-	p_dfs->st_l2h_cur = (u8)odm_get_bb_reg(p_dm, 0x91c, 0x000000ff);
-	p_dfs->pwdb_th = (u8)odm_get_bb_reg(p_dm, 0x918, 0x00001f00);
-	p_dfs->peak_th = (u8)odm_get_bb_reg(p_dm, 0x918, 0x00030000);
-	p_dfs->short_pulse_cnt_th = (u8)odm_get_bb_reg(p_dm, 0x920, 0x000f0000);
-	p_dfs->long_pulse_cnt_th = (u8)odm_get_bb_reg(p_dm, 0x920, 0x00f00000);
-	p_dfs->peak_window = (u8)odm_get_bb_reg(p_dm, 0x920, 0x00000300);
-	p_dfs->nb2wb_th = (u8)odm_get_bb_reg(p_dm, 0x920, 0x0000e000);
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, R_0xa40, 0x00007f00);
+		dfs->pwdb_th_cur = (u8)odm_get_bb_reg(dm, R_0xa50, 0x000000f0);
+		dfs->peak_th = (u8)odm_get_bb_reg(dm, R_0xa48, 0x00c00000);
+		dfs->short_pulse_cnt_th = (u8)odm_get_bb_reg(dm, R_0xa50,
+							     0x00f00000);
+		dfs->long_pulse_cnt_th = (u8)odm_get_bb_reg(dm, R_0xa4c,
+							    0xf0000000);
+		dfs->peak_window = (u8)odm_get_bb_reg(dm, R_0xa40, 0x00030000);
+		dfs->three_peak_opt = (u8)odm_get_bb_reg(dm, R_0xa40,
+							 0x30000000);
+		dfs->three_peak_th2 = (u8)odm_get_bb_reg(dm, R_0xa44,
+							 0x00000007);
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, R_0xf54,
+						     0x0000001f) << 2);
+		dfs->st_l2h_cur += (u8)odm_get_bb_reg(dm, R_0xf58, 0xc0000000);
+		dfs->pwdb_th_cur = (u8)odm_get_bb_reg(dm, R_0xf70, 0x03c00000);
+		dfs->peak_th = (u8)odm_get_bb_reg(dm, R_0xf5c, 0x00000030);
+		dfs->short_pulse_cnt_th = (u8)odm_get_bb_reg(dm, R_0xf70,
+							     0x00007800);
+		dfs->long_pulse_cnt_th = (u8)odm_get_bb_reg(dm, R_0xf74,
+							    0x0000000f);
+		dfs->peak_window = (u8)odm_get_bb_reg(dm, R_0xf58, 0x18000000);
+		dfs->three_peak_opt = (u8)odm_get_bb_reg(dm, R_0xf58,
+							 0x00030000);
+		dfs->three_peak_th2 = (u8)odm_get_bb_reg(dm,
+							 R_0xf58, 0x00007c00);
+	#endif
+	} else {
+		dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, R_0x91c, 0x000000ff);
+		dfs->pwdb_th_cur = (u8)odm_get_bb_reg(dm, R_0x918, 0x00001f00);
+		dfs->peak_th = (u8)odm_get_bb_reg(dm, R_0x918, 0x00030000);
+		dfs->short_pulse_cnt_th = (u8)odm_get_bb_reg(dm, R_0x920,
+							     0x000f0000);
+		dfs->long_pulse_cnt_th = (u8)odm_get_bb_reg(dm, R_0x920,
+							    0x00f00000);
+		dfs->peak_window = (u8)odm_get_bb_reg(dm, R_0x920, 0x00000300);
+		dfs->three_peak_opt = (u8)odm_get_bb_reg(dm, 0x924, 0x00000180);
+		dfs->three_peak_th2 = (u8)odm_get_bb_reg(dm, 0x924, 0x00007000);
+	}
 
-	phydm_dfs_parameter_init(p_dm);
+	phydm_dfs_parameter_init(dm);
 
 exit:
 	if (enable) {
-		phydm_radar_detect_reset(p_dm);
-		PHYDM_DBG(p_dm, DBG_DFS, ("on cch:%u, bw:%u\n", c_channel, band_width));
+		phydm_radar_detect_reset(dm);
+		PHYDM_DBG(dm, DBG_DFS, "on cch:%u, bw:%u\n", c_channel,
+			  band_width);
 	} else
-		phydm_radar_detect_disable(p_dm);
+		phydm_radar_detect_disable(dm);
 }
 
-void phydm_dfs_parameter_init(void *p_dm_void)
+void phydm_dfs_parameter_init(void *dm_void)
 {
-
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DFS_STATISTICS	*p_dfs = (struct _DFS_STATISTICS *)phydm_get_structure(p_dm, PHYDM_DFS);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
 
 	u8 i;
-	
-	p_dfs->fa_mask_th = 30;
-	p_dfs->det_print = 1;
-	p_dfs->det_print2 = 0;
-	p_dfs->st_l2h_min = 0x20;
-	p_dfs->st_l2h_max = 0x4e;
-	p_dfs->pwdb_scalar_factor = 12;
-	p_dfs->pwdb_th = 8;
-	for (i = 0 ; i < 5 ; i++) {
-		p_dfs->pulse_flag_hist[i] = 0;
-		p_dfs->radar_det_mask_hist[i] = 0;
-		p_dfs->fa_inc_hist[i] = 0;
+	for (i = 0; i < 5; i++) {
+		dfs->pulse_flag_hist[i] = 0;
+		dfs->pulse_type_hist[i] = 0;
+		dfs->radar_det_mask_hist[i] = 0;
+		dfs->fa_inc_hist[i] = 0;
 	}
 
+	/*@for dfs mode*/
+	dfs->force_TP_mode = 0;
+	dfs->sw_trigger_mode = 0;
+	dfs->det_print = 0;
+	dfs->det_print2 = 0;
+	dfs->print_hist_rpt = 0;
+	dfs->hist_cond_on = 1;
+
+	/*@for dynamic dfs*/
+	dfs->pwdb_th = 8;
+	dfs->fa_mask_th = 30;
+	dfs->st_l2h_min = 0x20;
+	dfs->st_l2h_max = 0x4e;
+	dfs->pwdb_scalar_factor = 12;
+
+	/*@for dfs histogram*/
+	dfs->pri_hist_th = 5;
+	dfs->pri_sum_g1_th = 9;
+	dfs->pri_sum_g5_th = 5;
+	dfs->pri_sum_g1_fcc_th = 4;		/*@FCC Type6*/
+	dfs->pri_sum_g3_fcc_th = 6;
+	dfs->pri_sum_safe_th = 50;
+	dfs->pri_sum_safe_fcc_th = 110;		/*@30 for AP*/
+	dfs->pri_sum_type4_th = 16;
+	dfs->pri_sum_type6_th = 12;
+	dfs->pri_sum_g5_under_g1_th = 4;
+	dfs->pri_pw_diff_th = 4;
+	dfs->pri_pw_diff_fcc_th = 8;
+	dfs->pri_pw_diff_fcc_idle_th = 2;
+	dfs->pri_pw_diff_w53_th = 10;
+	dfs->pw_std_th = 7;			/*@FCC Type4*/
+	dfs->pw_std_idle_th = 10;
+	dfs->pri_std_th = 6;			/*@FCC Type3,4,6*/
+	dfs->pri_std_idle_th = 10;
+	dfs->pri_type1_upp_fcc_th = 110;
+	dfs->pri_type1_low_fcc_th = 50;
+	dfs->pri_type1_cen_fcc_th = 70;
+	dfs->pw_g0_th = 8;
+	dfs->pw_long_lower_th = 6;		/*@7->6*/
+	dfs->pri_long_upper_th = 30;
+	dfs->pw_long_lower_20m_th = 7;		/*@7 for AP*/
+	dfs->pw_long_sum_upper_th = 60;
+	dfs->type4_pw_max_cnt = 7;
+	dfs->type4_safe_pri_sum_th = 5;
 }
 
 void phydm_dfs_dynamic_setting(
-	void *p_dm_void
-){
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DFS_STATISTICS	*p_dfs = (struct _DFS_STATISTICS *)phydm_get_structure(p_dm, PHYDM_DFS);
-
-	u8 peak_th_cur=0, short_pulse_cnt_th_cur=0, long_pulse_cnt_th_cur=0, three_peak_opt_cur=0, three_peak_th2_cur=0;
-	u8 peak_window_cur=0, nb2wb_th_cur=0;
-	u8 region_domain = p_dm->dfs_region_domain;
-	u8 c_channel = *(p_dm->p_channel);
-	
-	if (p_dm->rx_tp <= 2) {
-		p_dfs->idle_mode = 1;
-		if(p_dfs->force_TP_mode)
-			p_dfs->idle_mode = 0;
-	} else{
-		p_dfs->idle_mode = 0;
-	}
-
-	if ((p_dfs->idle_mode == 1)) { /*idle (no traffic)*/
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
+
+	u8 peak_th_cur = 0, short_pulse_cnt_th_cur = 0;
+	u8 long_pulse_cnt_th_cur = 0, three_peak_opt_cur = 0;
+	u8 three_peak_th2_cur = 0;
+	u8 peak_window_cur = 0;
+	u8 region_domain = dm->dfs_region_domain;
+	u8 c_channel = *dm->channel;
+
+	if (dm->rx_tp + dm->tx_tp <= 2) {
+		dfs->idle_mode = 1;
+		if (dfs->force_TP_mode)
+			dfs->idle_mode = 0;
+	} else {
+		dfs->idle_mode = 0;
+	}
+
+	if (dfs->idle_mode == 1) { /*@idle (no traffic)*/
 		peak_th_cur = 3;
 		short_pulse_cnt_th_cur = 6;
-		long_pulse_cnt_th_cur = 13;
+		long_pulse_cnt_th_cur = 9;
 		peak_window_cur = 2;
-		nb2wb_th_cur = 6;
-		three_peak_opt_cur = 1;
+		three_peak_opt_cur = 0;
 		three_peak_th2_cur = 2;
 		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
-			if ((c_channel >= 52) && (c_channel <= 64)) {
+			if (c_channel >= 52 && c_channel <= 64) {
 				short_pulse_cnt_th_cur = 14;
 				long_pulse_cnt_th_cur = 15;
-				nb2wb_th_cur = 3;
-				three_peak_th2_cur = 0;                
+				three_peak_th2_cur = 0;
 			} else {
 				short_pulse_cnt_th_cur = 6;
-				nb2wb_th_cur = 3;
 				three_peak_th2_cur = 0;
 				long_pulse_cnt_th_cur = 10;
 			}
@@ -271,183 +613,421 @@ void phydm_dfs_dynamic_setting(
 			three_peak_th2_cur = 0;
 		} else if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
 			long_pulse_cnt_th_cur = 15;
-			if (phydm_dfs_is_meteorology_channel(p_dm)) {/*need to add check cac end condition*/
+			if (phydm_dfs_is_meteorology_channel(dm)) {
+			/*need to add check cac end condition*/
 				peak_th_cur = 2;
-				nb2wb_th_cur = 3;
-				three_peak_opt_cur = 1;
-				three_peak_th2_cur = 0;	
+				three_peak_opt_cur = 0;
+				three_peak_th2_cur = 0;
 				short_pulse_cnt_th_cur = 7;
 			} else {
-				three_peak_opt_cur = 1;
-				three_peak_th2_cur = 0;	
+				three_peak_opt_cur = 0;
+				three_peak_th2_cur = 0;
 				short_pulse_cnt_th_cur = 7;
-				nb2wb_th_cur = 3;
 			}
-		} else	/*default: FCC*/
+		} else /*@default: FCC*/
 			three_peak_th2_cur = 0;
 
-	} else { /*in service (with TP)*/
+	} else { /*@in service (with TP)*/
 		peak_th_cur = 2;
 		short_pulse_cnt_th_cur = 6;
-		long_pulse_cnt_th_cur = 9;
+		long_pulse_cnt_th_cur = 7;
 		peak_window_cur = 2;
-		nb2wb_th_cur = 3;
-		three_peak_opt_cur = 1;
+		three_peak_opt_cur = 0;
 		three_peak_th2_cur = 2;
-		if(region_domain == PHYDM_DFS_DOMAIN_MKK){
-			if ((c_channel >= 52) && (c_channel <= 64)) {
+		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			if (c_channel >= 52 && c_channel <= 64) {
 				long_pulse_cnt_th_cur = 15;
-				short_pulse_cnt_th_cur = 5; /*for high duty cycle*/
-				three_peak_th2_cur = 0;			
-			}
-			else {
+				/*@for high duty cycle*/
+				short_pulse_cnt_th_cur = 5;
+				three_peak_th2_cur = 0;
+			} else {
 				three_peak_opt_cur = 0;
 				three_peak_th2_cur = 0;
 				long_pulse_cnt_th_cur = 8;
 			}
-		}		
-		else if(region_domain == PHYDM_DFS_DOMAIN_FCC){
-		}
-		else if(region_domain == PHYDM_DFS_DOMAIN_ETSI){
+		} else if (region_domain == PHYDM_DFS_DOMAIN_FCC) {
+			long_pulse_cnt_th_cur = 5;	/*for 80M FCC*/
+			short_pulse_cnt_th_cur = 5;	/*for 80M FCC*/
+		} else if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
 			long_pulse_cnt_th_cur = 15;
 			short_pulse_cnt_th_cur = 5;
 			three_peak_opt_cur = 0;
 		}
-		else{
-		}
 	}
 
-}
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		if (dfs->peak_th != peak_th_cur)
+			odm_set_bb_reg(dm, R_0xa48, 0x00c00000, peak_th_cur);
+		if (dfs->short_pulse_cnt_th != short_pulse_cnt_th_cur)
+			odm_set_bb_reg(dm, R_0xa50, 0x00f00000,
+				       short_pulse_cnt_th_cur);
+		if (dfs->long_pulse_cnt_th != long_pulse_cnt_th_cur)
+			odm_set_bb_reg(dm, R_0xa4c, 0xf0000000,
+				       long_pulse_cnt_th_cur);
+		if (dfs->peak_window != peak_window_cur)
+			odm_set_bb_reg(dm, R_0xa40, 0x00030000,
+				       peak_window_cur);
+		if (dfs->three_peak_opt != three_peak_opt_cur)
+			odm_set_bb_reg(dm, R_0xa40, 0x30000000,
+				       three_peak_opt_cur);
+		if (dfs->three_peak_th2 != three_peak_th2_cur)
+			odm_set_bb_reg(dm, R_0xa44, 0x00000007,
+				       three_peak_th2_cur);
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		if (dfs->peak_th != peak_th_cur)
+			odm_set_bb_reg(dm, R_0xf5c, 0x00000030, peak_th_cur);
+		if (dfs->short_pulse_cnt_th != short_pulse_cnt_th_cur)
+			odm_set_bb_reg(dm, R_0xf70, 0x00007800,
+				       short_pulse_cnt_th_cur);
+		if (dfs->long_pulse_cnt_th != long_pulse_cnt_th_cur)
+			odm_set_bb_reg(dm, R_0xf74, 0x0000000f,
+				       long_pulse_cnt_th_cur);
+		if (dfs->peak_window != peak_window_cur)
+			odm_set_bb_reg(dm, R_0xf58, 0x18000000,
+				       peak_window_cur);
+		if (dfs->three_peak_opt != three_peak_opt_cur)
+			odm_set_bb_reg(dm, R_0xf58, 0x00030000,
+				       three_peak_opt_cur);
+		if (dfs->three_peak_th2 != three_peak_th2_cur)
+			odm_set_bb_reg(dm, R_0xf58, 0x00007c00,
+				       three_peak_th2_cur);
+	#endif
+	} else {
+		if (dfs->peak_th != peak_th_cur)
+			odm_set_bb_reg(dm, R_0x918, 0x00030000, peak_th_cur);
+		if (dfs->short_pulse_cnt_th != short_pulse_cnt_th_cur)
+			odm_set_bb_reg(dm, R_0x920, 0x000f0000,
+				       short_pulse_cnt_th_cur);
+		if (dfs->long_pulse_cnt_th != long_pulse_cnt_th_cur)
+			odm_set_bb_reg(dm, R_0x920, 0x00f00000,
+				       long_pulse_cnt_th_cur);
+		if (dfs->peak_window != peak_window_cur)
+			odm_set_bb_reg(dm, R_0x920, 0x00000300,
+				       peak_window_cur);
+		if (dfs->three_peak_opt != three_peak_opt_cur)
+			odm_set_bb_reg(dm, R_0x924, 0x00000180,
+				       three_peak_opt_cur);
+		if (dfs->three_peak_th2 != three_peak_th2_cur)
+			odm_set_bb_reg(dm, R_0x924, 0x00007000,
+				       three_peak_th2_cur);
+	}
 
+	dfs->peak_th = peak_th_cur;
+	dfs->short_pulse_cnt_th = short_pulse_cnt_th_cur;
+	dfs->long_pulse_cnt_th = long_pulse_cnt_th_cur;
+	dfs->peak_window = peak_window_cur;
+	dfs->three_peak_opt = three_peak_opt_cur;
+	dfs->three_peak_th2 = three_peak_th2_cur;
+}
 
 boolean
 phydm_radar_detect_dm_check(
-	void *p_dm_void
-){
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DFS_STATISTICS	*p_dfs = (struct _DFS_STATISTICS *)phydm_get_structure(p_dm, PHYDM_DFS);
-	u8 region_domain = p_dm->dfs_region_domain, index = 0;
-
-	u16 i = 0, k = 0, fa_count_cur = 0, fa_count_inc = 0, total_fa_in_hist = 0, pre_post_now_acc_fa_in_hist = 0, max_fa_in_hist = 0, vht_crc_ok_cnt_cur = 0;
-	u16 vht_crc_ok_cnt_inc = 0, ht_crc_ok_cnt_cur = 0, ht_crc_ok_cnt_inc = 0, leg_crc_ok_cnt_cur = 0, leg_crc_ok_cnt_inc = 0;
-	u16 total_crc_ok_cnt_inc = 0, short_pulse_cnt_cur = 0, short_pulse_cnt_inc = 0, long_pulse_cnt_cur = 0, long_pulse_cnt_inc = 0, total_pulse_count_inc = 0;
-	u32 regf98_value = 0, reg918_value = 0, reg91c_value = 0, reg920_value = 0, reg924_value = 0;
-	boolean tri_short_pulse = 0, tri_long_pulse = 0, radar_type = 0, fault_flag_det = 0, fault_flag_psd = 0, fa_flag = 0, radar_detected = 0;
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
+	u8 region_domain = dm->dfs_region_domain, index = 0;
+
+	u16 i = 0, j = 0, k = 0, fa_count_cur = 0, fa_count_inc = 0;
+	u16 total_fa_in_hist = 0, pre_post_now_acc_fa_in_hist = 0;
+	u16 max_fa_in_hist = 0, vht_crc_ok_cnt_cur = 0;
+	u16 vht_crc_ok_cnt_inc = 0, ht_crc_ok_cnt_cur = 0;
+	u16 ht_crc_ok_cnt_inc = 0, leg_crc_ok_cnt_cur = 0;
+	u16 leg_crc_ok_cnt_inc = 0;
+	u16 total_crc_ok_cnt_inc = 0, short_pulse_cnt_cur = 0;
+	u16 short_pulse_cnt_inc = 0, long_pulse_cnt_cur = 0;
+	u16 long_pulse_cnt_inc = 0, total_pulse_count_inc = 0;
+	u32 regf98_value = 0, reg918_value = 0, reg91c_value = 0;
+	u32 reg920_value = 0, reg924_value = 0, dbgport2dbc_value = 0;
+	u32 regf54_value = 0, regf58_value = 0, regf5c_value = 0;
+	u32 regdf4_value = 0, regf70_value = 0, regf74_value = 0;
+	u32 rega40_value = 0, rega44_value = 0, rega48_value = 0;
+	u32 rega4c_value = 0, rega50_value = 0, rega54_value = 0;
+	#if (RTL8721D_SUPPORT)
+	u32 reg908_value = 0, regdf4_value = 0;
+	u32 regf54_value = 0, regf58_value = 0, regf5c_value = 0;
+	u32 regf70_value = 0, regf74_value = 0;
+	#endif
+	boolean tri_short_pulse = 0, tri_long_pulse = 0, radar_type = 0;
+	boolean fault_flag_det = 0, fault_flag_psd = 0, fa_flag = 0;
+	boolean radar_detected = 0;
 	u8 st_l2h_new = 0, fa_mask_th = 0, sum = 0;
-	u8 c_channel = *(p_dm->p_channel);
-		
-	/*Get FA count during past 100ms*/
-	fa_count_cur = (u16)odm_get_bb_reg(p_dm, 0xf48, 0x0000ffff);
-	
-	if (p_dfs->fa_count_pre == 0)
+	u8 c_channel = *dm->channel;
+
+	/*@Get FA count during past 100ms, R_0xf48 for AC series*/
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		fa_count_cur = (u16)odm_get_bb_reg(dm, R_0x2d00, MASKLWORD);
+	#if (RTL8721D_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		fa_count_cur = (u16)odm_get_bb_reg(dm,
+						   ODM_REG_OFDM_FA_TYPE2_11N,
+						   MASKHWORD);
+		fa_count_cur += (u16)odm_get_bb_reg(dm,
+						    ODM_REG_OFDM_FA_TYPE3_11N,
+						    MASKLWORD);
+		fa_count_cur += (u16)odm_get_bb_reg(dm,
+						    ODM_REG_OFDM_FA_TYPE3_11N,
+						    MASKHWORD);
+		fa_count_cur += (u16)odm_get_bb_reg(dm,
+						    ODM_REG_OFDM_FA_TYPE4_11N,
+						    MASKLWORD);
+		fa_count_cur += (u16)odm_get_bb_reg(dm,
+						    ODM_REG_OFDM_FA_TYPE1_11N,
+						    MASKLWORD);
+		fa_count_cur += (u16)odm_get_bb_reg(dm,
+						    ODM_REG_OFDM_FA_TYPE1_11N,
+						    MASKHWORD);
+	}
+	#endif
+	else
+		fa_count_cur = (u16)odm_get_bb_reg(dm, R_0xf48, 0x0000ffff);
+
+	if (dfs->fa_count_pre == 0)
 		fa_count_inc = 0;
-	else if (fa_count_cur >= p_dfs->fa_count_pre)
-		fa_count_inc = fa_count_cur - p_dfs->fa_count_pre;
+	else if (fa_count_cur >= dfs->fa_count_pre)
+		fa_count_inc = fa_count_cur - dfs->fa_count_pre;
 	else
 		fa_count_inc = fa_count_cur;
-	p_dfs->fa_count_pre = fa_count_cur;
-
-	p_dfs->fa_inc_hist[p_dfs->mask_idx] = fa_count_inc;
-	
-	for (i=0; i<5; i++) {		
-		total_fa_in_hist = total_fa_in_hist + p_dfs->fa_inc_hist[i];		
-		if (p_dfs->fa_inc_hist[i] > max_fa_in_hist)			
-			max_fa_in_hist = p_dfs->fa_inc_hist[i];	
-	}	
-	if (p_dfs->mask_idx >= 2)		
-		index = p_dfs->mask_idx - 2;
-	else		
-		index = 5 + p_dfs->mask_idx - 2;	
-	if (index == 0)		
-		pre_post_now_acc_fa_in_hist = p_dfs->fa_inc_hist[index] + p_dfs->fa_inc_hist[index+1] + p_dfs->fa_inc_hist[4];	
-	else if (index == 4)		
-		pre_post_now_acc_fa_in_hist = p_dfs->fa_inc_hist[index] + p_dfs->fa_inc_hist[0] + p_dfs->fa_inc_hist[index-1];	
-	else		
-		pre_post_now_acc_fa_in_hist = p_dfs->fa_inc_hist[index] + p_dfs->fa_inc_hist[index+1] + p_dfs->fa_inc_hist[index-1];
-		
-	/*Get VHT CRC32 ok count during past 100ms*/
-	vht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(p_dm, 0xf0c, 0x00003fff);
-	if (vht_crc_ok_cnt_cur >= p_dfs->vht_crc_ok_cnt_pre)
-		vht_crc_ok_cnt_inc = vht_crc_ok_cnt_cur - p_dfs->vht_crc_ok_cnt_pre;
+	dfs->fa_count_pre = fa_count_cur;
+
+	dfs->fa_inc_hist[dfs->mask_idx] = fa_count_inc;
+
+	for (i = 0; i < 5; i++) {
+		total_fa_in_hist = total_fa_in_hist + dfs->fa_inc_hist[i];
+		if (dfs->fa_inc_hist[i] > max_fa_in_hist)
+			max_fa_in_hist = dfs->fa_inc_hist[i];
+	}
+	if (dfs->mask_idx >= 2)
+		index = dfs->mask_idx - 2;
 	else
+		index = 5 + dfs->mask_idx - 2;
+	if (index == 0) {
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] +
+					      dfs->fa_inc_hist[index + 1] +
+					      dfs->fa_inc_hist[4];
+	} else if (index == 4) {
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] +
+					      dfs->fa_inc_hist[0] +
+					      dfs->fa_inc_hist[index - 1];
+	} else {
+		pre_post_now_acc_fa_in_hist = dfs->fa_inc_hist[index] +
+					      dfs->fa_inc_hist[index + 1] +
+					      dfs->fa_inc_hist[index - 1];
+	}
+
+	/*@Get VHT CRC32 ok count during past 100ms*/
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		vht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, R_0x2c0c, 0xffff);
+	#if (RTL8721D_SUPPORT)
+	else if (dm->support_ic_type & ODM_RTL8721D)
+		vht_crc_ok_cnt_cur = 0;
+	#endif
+	else
+		vht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, R_0xf0c,
+							 0x00003fff);
+
+	if (vht_crc_ok_cnt_cur >= dfs->vht_crc_ok_cnt_pre) {
+		vht_crc_ok_cnt_inc = vht_crc_ok_cnt_cur -
+				     dfs->vht_crc_ok_cnt_pre;
+	} else {
 		vht_crc_ok_cnt_inc = vht_crc_ok_cnt_cur;
-	p_dfs->vht_crc_ok_cnt_pre = vht_crc_ok_cnt_cur;
+	}
+	dfs->vht_crc_ok_cnt_pre = vht_crc_ok_cnt_cur;
+
+	/*@Get HT CRC32 ok count during past 100ms*/
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		ht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, R_0x2c10, 0xffff);
+	#if (RTL8721D_SUPPORT)
+	else if (dm->support_ic_type & (ODM_RTL8721D))
+		ht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, R_0xf90, MASKLWORD);
+	#endif
+	else
+		ht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, R_0xf10,
+							0x00003fff);
 
-	/*Get HT CRC32 ok count during past 100ms*/
-	ht_crc_ok_cnt_cur = (u16)odm_get_bb_reg(p_dm, 0xf10, 0x00003fff);
-	if (ht_crc_ok_cnt_cur >= p_dfs->ht_crc_ok_cnt_pre)
-		ht_crc_ok_cnt_inc = ht_crc_ok_cnt_cur - p_dfs->ht_crc_ok_cnt_pre;
+	if (ht_crc_ok_cnt_cur >= dfs->ht_crc_ok_cnt_pre)
+		ht_crc_ok_cnt_inc = ht_crc_ok_cnt_cur - dfs->ht_crc_ok_cnt_pre;
 	else
 		ht_crc_ok_cnt_inc = ht_crc_ok_cnt_cur;
-	p_dfs->ht_crc_ok_cnt_pre = ht_crc_ok_cnt_cur;
+	dfs->ht_crc_ok_cnt_pre = ht_crc_ok_cnt_cur;
+
+	/*@Get Legacy CRC32 ok count during past 100ms*/
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		leg_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, R_0x2c14, 0xffff);
+	#if (RTL8721D_SUPPORT)
+	else if (dm->support_ic_type & ODM_RTL8721D)
+		leg_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm,
+							 R_0xf94, MASKLWORD);
+	#endif
+	else
+		leg_crc_ok_cnt_cur = (u16)odm_get_bb_reg(dm, R_0xf14,
+							 0x00003fff);
 
-	/*Get Legacy CRC32 ok count during past 100ms*/
-	leg_crc_ok_cnt_cur = (u16)odm_get_bb_reg(p_dm, 0xf14, 0x00003fff);
-	if (leg_crc_ok_cnt_cur >= p_dfs->leg_crc_ok_cnt_pre)
-		leg_crc_ok_cnt_inc = leg_crc_ok_cnt_cur - p_dfs->leg_crc_ok_cnt_pre;
+	if (leg_crc_ok_cnt_cur >= dfs->leg_crc_ok_cnt_pre)
+		leg_crc_ok_cnt_inc = leg_crc_ok_cnt_cur - dfs->leg_crc_ok_cnt_pre;
 	else
 		leg_crc_ok_cnt_inc = leg_crc_ok_cnt_cur;
-	p_dfs->leg_crc_ok_cnt_pre = leg_crc_ok_cnt_cur;
+	dfs->leg_crc_ok_cnt_pre = leg_crc_ok_cnt_cur;
 
-	if ((vht_crc_ok_cnt_cur == 0x3fff) ||
-		(ht_crc_ok_cnt_cur == 0x3fff) ||
-		(leg_crc_ok_cnt_cur == 0x3fff)) {
-		odm_set_bb_reg(p_dm, 0xb58, BIT(0), 1);
-		odm_set_bb_reg(p_dm, 0xb58, BIT(0), 0);
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		if (vht_crc_ok_cnt_cur == 0xffff ||
+			ht_crc_ok_cnt_cur == 0xffff ||
+			leg_crc_ok_cnt_cur == 0xffff) {
+			phydm_reset_bb_hw_cnt(dm);
+		}
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		if (ht_crc_ok_cnt_cur == 0xffff ||
+		    leg_crc_ok_cnt_cur == 0xffff) {
+			odm_set_bb_reg(dm, R_0xf14, BIT(16), 1);
+			odm_set_bb_reg(dm, R_0xf14, BIT(16), 0);
+		}
+	#endif
+	} else {
+		if (vht_crc_ok_cnt_cur == 0x3fff ||
+		    ht_crc_ok_cnt_cur == 0x3fff ||
+		    leg_crc_ok_cnt_cur == 0x3fff) {
+			phydm_reset_bb_hw_cnt(dm);
+		}
 	}
 
-	total_crc_ok_cnt_inc = vht_crc_ok_cnt_inc + ht_crc_ok_cnt_inc + leg_crc_ok_cnt_inc;
+	total_crc_ok_cnt_inc = vht_crc_ok_cnt_inc +
+			       ht_crc_ok_cnt_inc +
+			       leg_crc_ok_cnt_inc;
 
-	/*Get short pulse count, need carefully handle the counter overflow*/
-	regf98_value = odm_get_bb_reg(p_dm, 0xf98, 0xffffffff);
-	short_pulse_cnt_cur = (u16)(regf98_value & 0x000000ff);
-	if (short_pulse_cnt_cur >= p_dfs->short_pulse_cnt_pre)
-		short_pulse_cnt_inc = short_pulse_cnt_cur - p_dfs->short_pulse_cnt_pre;
-	else
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_2, 0x3b0)) {
+			odm_set_bb_reg(dm, 0x1e28, 0x03c00000, 8);
+			dbgport2dbc_value = phydm_get_bb_dbg_port_val(dm);
+			phydm_release_bb_dbg_port(dm);
+		}
+		short_pulse_cnt_cur = (u16)((dbgport2dbc_value & 0x000ff800)
+					    >> 11);
+		long_pulse_cnt_cur = (u16)((dbgport2dbc_value & 0x0fc00000)
+					    >> 22);
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		reg908_value = (u32)odm_get_bb_reg(dm, R_0x908, MASKDWORD);
+		odm_set_bb_reg(dm, R_0x908, MASKDWORD, 0x254);
+		regdf4_value = odm_get_bb_reg(dm, R_0xdf4, MASKDWORD);
+		short_pulse_cnt_cur = (u16)((regdf4_value & 0x000ff000) >> 12);
+		long_pulse_cnt_cur = (u16)((regdf4_value & 0x0fc00000) >> 22);
+
+		tri_short_pulse = (regdf4_value & BIT(20)) ? 1 : 0;
+		tri_long_pulse = (regdf4_value & BIT(28)) ? 1 : 0;
+		if (tri_short_pulse || tri_long_pulse) {
+			odm_set_bb_reg(dm, R_0xf58, BIT(29), 0);
+			odm_set_bb_reg(dm, R_0xf58, BIT(29), 1);
+		}
+	#endif
+	} else {
+		regf98_value = odm_get_bb_reg(dm, R_0xf98, 0xffffffff);
+		short_pulse_cnt_cur = (u16)(regf98_value & 0x000000ff);
+		long_pulse_cnt_cur = (u16)((regf98_value & 0x0000ff00) >> 8);
+	}
+
+	/*@Get short pulse count, need carefully handle the counter overflow*/
+
+	if (short_pulse_cnt_cur >= dfs->short_pulse_cnt_pre) {
+		short_pulse_cnt_inc = short_pulse_cnt_cur -
+				      dfs->short_pulse_cnt_pre;
+	} else {
 		short_pulse_cnt_inc = short_pulse_cnt_cur;
-	p_dfs->short_pulse_cnt_pre = short_pulse_cnt_cur;
+	}
+	dfs->short_pulse_cnt_pre = short_pulse_cnt_cur;
 
-	/*Get long pulse count, need carefully handle the counter overflow*/
-	long_pulse_cnt_cur = (u16)((regf98_value & 0x0000ff00) >> 8);
-	if (long_pulse_cnt_cur >= p_dfs->long_pulse_cnt_pre)
-		long_pulse_cnt_inc = long_pulse_cnt_cur - p_dfs->long_pulse_cnt_pre;
-	else
+	/*@Get long pulse count, need carefully handle the counter overflow*/
+
+	if (long_pulse_cnt_cur >= dfs->long_pulse_cnt_pre) {
+		long_pulse_cnt_inc = long_pulse_cnt_cur -
+				     dfs->long_pulse_cnt_pre;
+	} else {
 		long_pulse_cnt_inc = long_pulse_cnt_cur;
-	p_dfs->long_pulse_cnt_pre = long_pulse_cnt_cur;
+	}
+	dfs->long_pulse_cnt_pre = long_pulse_cnt_cur;
 
 	total_pulse_count_inc = short_pulse_cnt_inc + long_pulse_cnt_inc;
 
-	if (p_dfs->det_print){
-		PHYDM_DBG(p_dm, DBG_DFS, ("=====================================================================\n"));
-		PHYDM_DBG(p_dm, DBG_DFS, ("Total_CRC_OK_cnt_inc[%d] VHT_CRC_ok_cnt_inc[%d] HT_CRC_ok_cnt_inc[%d] LEG_CRC_ok_cnt_inc[%d] FA_count_inc[%d]\n",
-			total_crc_ok_cnt_inc, vht_crc_ok_cnt_inc, ht_crc_ok_cnt_inc, leg_crc_ok_cnt_inc, fa_count_inc));
-		PHYDM_DBG(p_dm, DBG_DFS, ("Init_Gain[%x] 0x91c[%x] 0xf98[%08x] short_pulse_cnt_inc[%d] long_pulse_cnt_inc[%d]\n",
-			p_dfs->igi_cur, p_dfs->st_l2h_cur, regf98_value, short_pulse_cnt_inc, long_pulse_cnt_inc));
-		PHYDM_DBG(p_dm, DBG_DFS, ("Throughput: %dMbps\n", p_dm->rx_tp));
-		reg918_value = odm_get_bb_reg(p_dm, 0x918, 0xffffffff);
-		reg91c_value = odm_get_bb_reg(p_dm, 0x91c, 0xffffffff);
-		reg920_value = odm_get_bb_reg(p_dm, 0x920, 0xffffffff);
-		reg924_value = odm_get_bb_reg(p_dm, 0x924, 0xffffffff);
-		PHYDM_DBG(p_dm, DBG_DFS, ("0x918[%08x] 0x91c[%08x] 0x920[%08x] 0x924[%08x]\n", reg918_value, reg91c_value, reg920_value, reg924_value));
-		PHYDM_DBG(p_dm, DBG_DFS, ("dfs_regdomain = %d, dbg_mode = %d, idle_mode = %d\n", region_domain, p_dfs->dbg_mode, p_dfs->idle_mode));
-	}
-	tri_short_pulse = (regf98_value & BIT(17))? 1 : 0;
-	tri_long_pulse = (regf98_value & BIT(19))? 1 : 0;
-
-	if(tri_short_pulse)
-		radar_type = 0;
-	else if(tri_long_pulse)
-		radar_type = 1;
+	if (dfs->det_print) {
+		PHYDM_DBG(dm, DBG_DFS,
+			  "===============================================\n");
+		PHYDM_DBG(dm, DBG_DFS,
+			  "Total_CRC_OK_cnt_inc[%d] VHT_CRC_ok_cnt_inc[%d] HT_CRC_ok_cnt_inc[%d] LEG_CRC_ok_cnt_inc[%d] FA_count_inc[%d]\n",
+			  total_crc_ok_cnt_inc, vht_crc_ok_cnt_inc,
+			  ht_crc_ok_cnt_inc, leg_crc_ok_cnt_inc, fa_count_inc);
+		if (dm->support_ic_type & (ODM_RTL8721D)) {
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Init_Gain[%x] st_l2h_cur[%x] 0xdf4[%08x] short_pulse_cnt_inc[%d] long_pulse_cnt_inc[%d]\n",
+				  dfs->igi_cur, dfs->st_l2h_cur, regdf4_value,
+				  short_pulse_cnt_inc, long_pulse_cnt_inc);
+			regf54_value = odm_get_bb_reg(dm, R_0xf54, MASKDWORD);
+			regf58_value = odm_get_bb_reg(dm, R_0xf58, MASKDWORD);
+			regf5c_value = odm_get_bb_reg(dm, R_0xf5c, MASKDWORD);
+			regf70_value = odm_get_bb_reg(dm, R_0xf70, MASKDWORD);
+			regf74_value = odm_get_bb_reg(dm, R_0xf74, MASKDWORD);
+			PHYDM_DBG(dm, DBG_DFS,
+				  "0xf54[%08x] 0xf58[%08x] 0xf5c[%08x] 0xf70[%08x] 0xf74[%08x]\n",
+				  regf54_value, regf58_value, regf5c_value,
+				  regf70_value, regf74_value);
+		} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Init_Gain[%x] st_l2h_cur[%x] 0x2dbc[%08x] short_pulse_cnt_inc[%d] long_pulse_cnt_inc[%d]\n",
+				  dfs->igi_cur, dfs->st_l2h_cur,
+				  dbgport2dbc_value, short_pulse_cnt_inc,
+				  long_pulse_cnt_inc);
+			rega40_value = odm_get_bb_reg(dm, R_0xa40, MASKDWORD);
+			rega44_value = odm_get_bb_reg(dm, R_0xa44, MASKDWORD);
+			rega48_value = odm_get_bb_reg(dm, R_0xa48, MASKDWORD);
+			rega4c_value = odm_get_bb_reg(dm, R_0xa4c, MASKDWORD);
+			rega50_value = odm_get_bb_reg(dm, R_0xa50, MASKDWORD);
+			rega54_value = odm_get_bb_reg(dm, R_0xa54, MASKDWORD);
+			PHYDM_DBG(dm, DBG_DFS,
+				  "0xa40[%08x] 0xa44[%08x] 0xa48[%08x] 0xa4c[%08x] 0xa50[%08x] 0xa54[%08x]\n",
+				  rega40_value, rega44_value, rega48_value,
+				  rega4c_value, rega50_value, rega54_value);
+		} else {
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Init_Gain[%x] 0x91c[%x] 0xf98[%08x] short_pulse_cnt_inc[%d] long_pulse_cnt_inc[%d]\n",
+				  dfs->igi_cur, dfs->st_l2h_cur, regf98_value,
+				  short_pulse_cnt_inc, long_pulse_cnt_inc);
+			reg918_value = odm_get_bb_reg(dm, R_0x918,
+						      0xffffffff);
+			reg91c_value = odm_get_bb_reg(dm, R_0x91c,
+						      0xffffffff);
+			reg920_value = odm_get_bb_reg(dm, R_0x920,
+						      0xffffffff);
+			reg924_value = odm_get_bb_reg(dm, R_0x924,
+						      0xffffffff);
+			PHYDM_DBG(dm, DBG_DFS,
+				  "0x918[%08x] 0x91c[%08x] 0x920[%08x] 0x924[%08x]\n",
+				  reg918_value, reg91c_value,
+				  reg920_value, reg924_value);
+		}
+		PHYDM_DBG(dm, DBG_DFS, "Throughput: %dMbps\n",
+			  (dm->rx_tp + dm->tx_tp));
+
+		PHYDM_DBG(dm, DBG_DFS,
+			  "dfs_regdomain = %d, dbg_mode = %d, idle_mode = %d, print_hist_rpt = %d, hist_cond_on = %d\n",
+			  region_domain, dfs->dbg_mode,
+			  dfs->idle_mode, dfs->print_hist_rpt,
+			  dfs->hist_cond_on);
+	}
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		tri_short_pulse = (dbgport2dbc_value & BIT(20)) ? 1 : 0;
+		tri_long_pulse = (dbgport2dbc_value & BIT(28)) ? 1 : 0;
+	} else {
+		tri_short_pulse = (regf98_value & BIT(17)) ? 1 : 0;
+		tri_long_pulse = (regf98_value & BIT(19)) ? 1 : 0;
+	}
 
 	if (tri_short_pulse) {
-		odm_set_bb_reg(p_dm, 0x924, BIT(15), 0);
-		odm_set_bb_reg(p_dm, 0x924, BIT(15), 1);
+		phydm_radar_detect_reset(dm);
 	}
 	if (tri_long_pulse) {
-		odm_set_bb_reg(p_dm, 0x924, BIT(15), 0);
-		odm_set_bb_reg(p_dm, 0x924, BIT(15), 1);
-		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {	
-			if ((c_channel >= 52) && (c_channel <= 64)) {
+		phydm_radar_detect_reset(dm);
+		if (region_domain == PHYDM_DFS_DOMAIN_MKK) {
+			if (c_channel >= 52 && c_channel <= 64) {
 				tri_long_pulse = 0;
 			}
 		}
@@ -456,189 +1036,1226 @@ phydm_radar_detect_dm_check(
 		}
 	}
 
-	st_l2h_new = p_dfs->st_l2h_cur;
-	p_dfs->pulse_flag_hist[p_dfs->mask_idx] = tri_short_pulse | tri_long_pulse;
+	st_l2h_new = dfs->st_l2h_cur;
+	dfs->pulse_flag_hist[dfs->mask_idx] = tri_short_pulse | tri_long_pulse;
+	dfs->pulse_type_hist[dfs->mask_idx] = (tri_long_pulse) ? 1 : 0;
 
 	/* PSD(not ready) */
 
 	fault_flag_det = 0;
 	fault_flag_psd = 0;
 	fa_flag = 0;
-	if(region_domain == PHYDM_DFS_DOMAIN_ETSI){
-		fa_mask_th = p_dfs->fa_mask_th + 20;		
-	}
-	else{
-		fa_mask_th = p_dfs->fa_mask_th;		
-	}
-	if (max_fa_in_hist >= fa_mask_th || total_fa_in_hist >= fa_mask_th || pre_post_now_acc_fa_in_hist >= fa_mask_th || (p_dfs->igi_cur >= 0x30)){		
-		st_l2h_new = p_dfs->st_l2h_max;
-		p_dfs->radar_det_mask_hist[index] = 1;		
-		if (p_dfs->pulse_flag_hist[index] == 1){			
-			p_dfs->pulse_flag_hist[index] = 0;			
-			if (p_dfs->det_print2){
-				PHYDM_DBG(p_dm, DBG_DFS, ("Radar is masked : FA mask\n"));
+	if (region_domain == PHYDM_DFS_DOMAIN_ETSI) {
+		fa_mask_th = dfs->fa_mask_th + 20;
+	} else {
+		fa_mask_th = dfs->fa_mask_th;
+	}
+	if (max_fa_in_hist >= fa_mask_th ||
+	    total_fa_in_hist >= fa_mask_th ||
+	    pre_post_now_acc_fa_in_hist >= fa_mask_th ||
+	    dfs->igi_cur >= 0x30) {
+		st_l2h_new = dfs->st_l2h_max;
+		dfs->radar_det_mask_hist[index] = 1;
+		if (dfs->pulse_flag_hist[index] == 1) {
+			dfs->pulse_flag_hist[index] = 0;
+			if (dfs->det_print2) {
+				PHYDM_DBG(dm, DBG_DFS,
+					  "Radar is masked : FA mask\n");
 			}
 		}
 		fa_flag = 1;
+	} else {
+		dfs->radar_det_mask_hist[index] = 0;
 	}
 
-	if (p_dfs->det_print) {
-		PHYDM_DBG(p_dm, DBG_DFS, ("mask_idx: %d\n", p_dfs->mask_idx));
-		PHYDM_DBG(p_dm, DBG_DFS, ("radar_det_mask_hist: "));
-		for (i=0; i<5; i++)
-			PHYDM_DBG(p_dm, DBG_DFS, ("%d ", p_dfs->radar_det_mask_hist[i]));
-		PHYDM_DBG(p_dm, DBG_DFS, ("pulse_flag_hist: "));
-		for (i=0; i<5; i++)
-			PHYDM_DBG(p_dm, DBG_DFS, ("%d ", p_dfs->pulse_flag_hist[i]));
-		PHYDM_DBG(p_dm, DBG_DFS, ("fa_inc_hist: "));
-		for (i=0; i<5; i++)			
-			PHYDM_DBG(p_dm, DBG_DFS, ("%d ", p_dfs->fa_inc_hist[i]));
-		PHYDM_DBG(p_dm, DBG_DFS,
-			("\nmax_fa_in_hist: %d pre_post_now_acc_fa_in_hist: %d ", max_fa_in_hist, pre_post_now_acc_fa_in_hist));
+	if (dfs->det_print) {
+		PHYDM_DBG(dm, DBG_DFS, "mask_idx: %d\n", dfs->mask_idx);
+		PHYDM_DBG(dm, DBG_DFS, "radar_det_mask_hist: ");
+		for (i = 0; i < 5; i++)
+			PHYDM_DBG(dm, DBG_DFS, "%d ",
+				  dfs->radar_det_mask_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS, "pulse_flag_hist: ");
+		for (i = 0; i < 5; i++)
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->pulse_flag_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS, "fa_inc_hist: ");
+		for (i = 0; i < 5; i++)
+			PHYDM_DBG(dm, DBG_DFS, "%d ", dfs->fa_inc_hist[i]);
+		PHYDM_DBG(dm, DBG_DFS,
+			  "\nfa_mask_th: %d max_fa_in_hist: %d total_fa_in_hist: %d pre_post_now_acc_fa_in_hist: %d ",
+			  fa_mask_th, max_fa_in_hist, total_fa_in_hist,
+			  pre_post_now_acc_fa_in_hist);
 	}
 
 	sum = 0;
-	for (k=0; k<5; k++) {
-		if (p_dfs->radar_det_mask_hist[k] == 1)
+	for (k = 0; k < 5; k++) {
+		if (dfs->radar_det_mask_hist[k] == 1)
 			sum++;
 	}
 
-	if (p_dfs->mask_hist_checked <= 5)
-		p_dfs->mask_hist_checked++;
+	if (dfs->mask_hist_checked <= 5)
+		dfs->mask_hist_checked++;
 
-	if ((p_dfs->mask_hist_checked >= 5) && p_dfs->pulse_flag_hist[index])
-	{
-		if (sum <= 2) 
-		{
-			radar_detected = 1 ;
-			PHYDM_DBG(p_dm, DBG_DFS, ("Detected type %d radar signal!\n", radar_type));
-		}
-		else {
+	if (dfs->mask_hist_checked >= 5 && dfs->pulse_flag_hist[index]) {
+		if (sum <= 2) {
+			if (dfs->hist_cond_on &&
+			    (!(dm->support_ic_type & ODM_RTL8721D))) {
+				/*return the value from hist_radar_detected*/
+				radar_detected = phydm_dfs_hist_log(dm, index);
+			} else {
+				if (dfs->pulse_type_hist[index] == 0)
+					dfs->radar_type = 0;
+				else if (dfs->pulse_type_hist[index] == 1)
+					dfs->radar_type = 1;
+				radar_detected = 1;
+				PHYDM_DBG(dm, DBG_DFS,
+					  "Detected type %d radar signal!\n",
+					  dfs->radar_type);
+			}
+		} else {
 			fault_flag_det = 1;
-			if (p_dfs->det_print2){
-				PHYDM_DBG(p_dm, DBG_DFS, ("Radar is masked : mask_hist large than thd\n"));
+			if (dfs->det_print2) {
+				PHYDM_DBG(dm, DBG_DFS,
+					  "Radar is masked : mask_hist large than thd\n");
 			}
 		}
 	}
 
-	p_dfs->mask_idx++;
-	if (p_dfs->mask_idx == 5)
-		p_dfs->mask_idx = 0;
+	dfs->mask_idx++;
+	if (dfs->mask_idx == 5)
+		dfs->mask_idx = 0;
 
-	if ((fault_flag_det == 0) && (fault_flag_psd == 0) && (fa_flag ==0)) {		
-		if (p_dfs->igi_cur < 0x30) {
-			st_l2h_new = p_dfs->st_l2h_min;
+	if (fault_flag_det == 0 && fault_flag_psd == 0 && fa_flag == 0) {
+		if (dfs->igi_cur < 0x30) {
+			st_l2h_new = dfs->st_l2h_min;
 		}
 	}
-	
-	if ((st_l2h_new != p_dfs->st_l2h_cur)) {
-		if (st_l2h_new < p_dfs->st_l2h_min) {			
-			p_dfs->st_l2h_cur = p_dfs->st_l2h_min;			
+
+	if (st_l2h_new != dfs->st_l2h_cur) {
+		if (st_l2h_new < dfs->st_l2h_min) {
+			dfs->st_l2h_cur = dfs->st_l2h_min;
+		} else if (st_l2h_new > dfs->st_l2h_max)
+			dfs->st_l2h_cur = dfs->st_l2h_max;
+		else
+			dfs->st_l2h_cur = st_l2h_new;
+		/*odm_set_bb_reg(dm, R_0x91c, 0xff, dfs->st_l2h_cur);*/
+
+		dfs->pwdb_th_cur = ((int)dfs->st_l2h_cur - (int)dfs->igi_cur)
+				    / 2 + dfs->pwdb_scalar_factor;
+
+		/*@limit the pwdb value to absolute lower bound 8*/
+		dfs->pwdb_th_cur = MAX_2(dfs->pwdb_th_cur, (int)dfs->pwdb_th);
+
+		/*@limit the pwdb value to absolute upper bound 0x1f*/
+		dfs->pwdb_th_cur = MIN_2(dfs->pwdb_th_cur, 0x1f);
+
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			odm_set_bb_reg(dm, R_0xa50, 0x000000f0,
+				       dfs->pwdb_th_cur);
+		#if (RTL8721D_SUPPORT)
+		else if (dm->support_ic_type & ODM_RTL8721D) {
+			odm_set_bb_reg(dm, R_0xf54, 0x0000001f,
+				       ((dfs->st_l2h_cur & 0x0000007c) >> 2));
+			odm_set_bb_reg(dm, R_0xf58, 0xc0000000,
+				       (dfs->st_l2h_cur & 0x00000003));
+			odm_set_bb_reg(dm, R_0xf70, 0x03c00000,
+				       dfs->pwdb_th_cur);
 		}
-		else if (st_l2h_new > p_dfs->st_l2h_max)
-			p_dfs->st_l2h_cur = p_dfs->st_l2h_max;
+		#endif
 		else
-			p_dfs->st_l2h_cur = st_l2h_new;
-		odm_set_bb_reg(p_dm, 0x91c, 0xff, p_dfs->st_l2h_cur);
-
-		p_dfs->pwdb_th = ((int)p_dfs->st_l2h_cur - (int)p_dfs->igi_cur)/2 + p_dfs->pwdb_scalar_factor;
-		p_dfs->pwdb_th = MAX_2(p_dfs->pwdb_th, (int)p_dfs->pwdb_th); /*limit the pwdb value to absoulte lower bound 8*/
-		p_dfs->pwdb_th = MIN_2(p_dfs->pwdb_th, 0x1f);    /*limit the pwdb value to absoulte upper bound 0x1f*/
-		odm_set_bb_reg(p_dm, 0x918, 0x00001f00, p_dfs->pwdb_th);
+			odm_set_bb_reg(dm, R_0x918, 0x00001f00,
+				       dfs->pwdb_th_cur);
 	}
 
-	if (p_dfs->det_print2) {
-		PHYDM_DBG(p_dm, DBG_DFS,
-			("fault_flag_det[%d], fault_flag_psd[%d], DFS_detected [%d]\n", fault_flag_det, fault_flag_psd, radar_detected));
+	if (dfs->det_print) {
+		PHYDM_DBG(dm, DBG_DFS,
+			  "fault_flag_det[%d], fault_flag_psd[%d], DFS_detected [%d]\n",
+			  fault_flag_det, fault_flag_psd, radar_detected);
 	}
+	#if (RTL8721D_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8721D))
+		odm_set_bb_reg(dm, R_0x908, MASKDWORD, reg908_value);
+	#endif
 
 	return radar_detected;
+}
+
+void phydm_dfs_histogram_radar_distinguish(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
+	u8 region_domain = dm->dfs_region_domain;
+	u8 c_channel = *dm->channel;
+	u8 band_width = *dm->band_width;
+
+	u8 dfs_pw_thd1 = 0, dfs_pw_thd2 = 0, dfs_pw_thd3 = 0;
+	u8 dfs_pw_thd4 = 0, dfs_pw_thd5 = 0;
+	u8 dfs_pri_thd1 = 0, dfs_pri_thd2 = 0, dfs_pri_thd3 = 0;
+	u8 dfs_pri_thd4 = 0, dfs_pri_thd5 = 0;
+	u8 pri_th = 0, i = 0;
+	u8 max_pri_idx = 0, max_pw_idx = 0, max_pri_cnt_th = 0;
+	u8 max_pri_cnt_fcc_g1_th = 0, max_pri_cnt_fcc_g3_th = 0;
+	u8 safe_pri_pw_diff_th = 0, safe_pri_pw_diff_fcc_th = 0;
+	u8 safe_pri_pw_diff_w53_th = 0, safe_pri_pw_diff_fcc_idle_th = 0;
+	u16 j = 0;
+	u32 dfs_hist1_peak_index = 0, dfs_hist2_peak_index = 0;
+	u32 dfs_hist1_pw = 0, dfs_hist2_pw = 0, g_pw[6] = {0};
+	u32 g_peakindex[16] = {0}, g_mask_32 = 0, false_peak_hist1 = 0;
+	u32 false_peak_hist2_above10 = 0, false_peak_hist2_above0 = 0;
+	u32 dfs_hist1_pri = 0, dfs_hist2_pri = 0, g_pri[6] = {0};
+	u32 pw_sum_g0g5 = 0, pw_sum_g1g2g3g4 = 0;
+	u32 pri_sum_g0g5 = 0, pri_sum_g1g2g3g4 = 0;
+	u32 pw_sum_ss_g1g2g3g4 = 0, pri_sum_ss_g1g2g3g4 = 0;
+	u32 max_pri_cnt = 0, max_pw_cnt = 0;
+	#if (RTL8721D_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8721D))
+		return;
+	#endif
+
+	/*read peak index hist report*/
+	odm_set_bb_reg(dm, 0x19e4, BIT(22) | BIT(23), 0x0);
+	dfs_hist1_peak_index = odm_get_bb_reg(dm, 0xf5c, 0xffffffff);
+	dfs_hist2_peak_index = odm_get_bb_reg(dm, 0xf74, 0xffffffff);
+
+	g_peakindex[15] = ((dfs_hist1_peak_index & 0x0000000f) >> 0);
+	g_peakindex[14] = ((dfs_hist1_peak_index & 0x000000f0) >> 4);
+	g_peakindex[13] = ((dfs_hist1_peak_index & 0x00000f00) >> 8);
+	g_peakindex[12] = ((dfs_hist1_peak_index & 0x0000f000) >> 12);
+	g_peakindex[11] = ((dfs_hist1_peak_index & 0x000f0000) >> 16);
+	g_peakindex[10] = ((dfs_hist1_peak_index & 0x00f00000) >> 20);
+	g_peakindex[9] = ((dfs_hist1_peak_index & 0x0f000000) >> 24);
+	g_peakindex[8] = ((dfs_hist1_peak_index & 0xf0000000) >> 28);
+	g_peakindex[7] = ((dfs_hist2_peak_index & 0x0000000f) >> 0);
+	g_peakindex[6] = ((dfs_hist2_peak_index & 0x000000f0) >> 4);
+	g_peakindex[5] = ((dfs_hist2_peak_index & 0x00000f00) >> 8);
+	g_peakindex[4] = ((dfs_hist2_peak_index & 0x0000f000) >> 12);
+	g_peakindex[3] = ((dfs_hist2_peak_index & 0x000f0000) >> 16);
+	g_peakindex[2] = ((dfs_hist2_peak_index & 0x00f00000) >> 20);
+	g_peakindex[1] = ((dfs_hist2_peak_index & 0x0f000000) >> 24);
+	g_peakindex[0] = ((dfs_hist2_peak_index & 0xf0000000) >> 28);
+
+	/*read pulse width hist report*/
+	odm_set_bb_reg(dm, 0x19e4, BIT(22) | BIT(23), 0x1);
+	dfs_hist1_pw = odm_get_bb_reg(dm, 0xf5c, 0xffffffff);
+	dfs_hist2_pw = odm_get_bb_reg(dm, 0xf74, 0xffffffff);
+
+	g_pw[0] = (unsigned int)((dfs_hist2_pw & 0xff000000) >> 24);
+	g_pw[1] = (unsigned int)((dfs_hist2_pw & 0x00ff0000) >> 16);
+	g_pw[2] = (unsigned int)((dfs_hist2_pw & 0x0000ff00) >> 8);
+	g_pw[3] = (unsigned int)dfs_hist2_pw & 0x000000ff;
+	g_pw[4] = (unsigned int)((dfs_hist1_pw & 0xff000000) >> 24);
+	g_pw[5] = (unsigned int)((dfs_hist1_pw & 0x00ff0000) >> 16);
+
+	/*read pulse repetition interval hist report*/
+	odm_set_bb_reg(dm, 0x19e4, BIT(22) | BIT(23), 0x3);
+	dfs_hist1_pri = odm_get_bb_reg(dm, 0xf5c, 0xffffffff);
+	dfs_hist2_pri = odm_get_bb_reg(dm, 0xf74, 0xffffffff);
+	odm_set_bb_reg(dm, 0x19b4, 0x10000000, 1); /*reset histo report*/
+	odm_set_bb_reg(dm, 0x19b4, 0x10000000, 0); /*@continue histo report*/
+
+	g_pri[0] = (unsigned int)((dfs_hist2_pri & 0xff000000) >> 24);
+	g_pri[1] = (unsigned int)((dfs_hist2_pri & 0x00ff0000) >> 16);
+	g_pri[2] = (unsigned int)((dfs_hist2_pri & 0x0000ff00) >> 8);
+	g_pri[3] = (unsigned int)dfs_hist2_pri & 0x000000ff;
+	g_pri[4] = (unsigned int)((dfs_hist1_pri & 0xff000000) >> 24);
+	g_pri[5] = (unsigned int)((dfs_hist1_pri & 0x00ff0000) >> 16);
+
+	dfs->pri_cond1 = 0;
+	dfs->pri_cond2 = 0;
+	dfs->pri_cond3 = 0;
+	dfs->pri_cond4 = 0;
+	dfs->pri_cond5 = 0;
+	dfs->pw_cond1 = 0;
+	dfs->pw_cond2 = 0;
+	dfs->pw_cond3 = 0;
+	dfs->pri_type3_4_cond1 = 0;	/*@for ETSI*/
+	dfs->pri_type3_4_cond2 = 0;	/*@for ETSI*/
+	dfs->pw_long_cond1 = 0;		/*@for long radar*/
+	dfs->pw_long_cond2 = 0;		/*@for long radar*/
+	dfs->pri_long_cond1 = 0;	/*@for long radar*/
+	dfs->pw_flag = 0;
+	dfs->pri_flag = 0;
+	dfs->pri_type3_4_flag = 0;	/*@for ETSI*/
+	dfs->long_radar_flag = 0;
+	dfs->pw_std = 0;	/*The std(var) of reasonable num of pw group*/
+	dfs->pri_std = 0;	/*The std(var) of reasonable num of pri group*/
+
+	for (i = 0; i < 6; i++) {
+		dfs->pw_hold_sum[i] = 0;
+		dfs->pri_hold_sum[i] = 0;
+		dfs->pw_long_hold_sum[i] = 0;
+		dfs->pri_long_hold_sum[i] = 0;
+	}
+
+	if (dfs->idle_mode == 1)
+		pri_th = dfs->pri_hist_th;
+	else
+		pri_th = dfs->pri_hist_th - 1;
+
+	for (i = 0; i < 6; i++) {
+		dfs->pw_hold[dfs->hist_idx][i] = (u8)g_pw[i];
+		dfs->pri_hold[dfs->hist_idx][i] = (u8)g_pri[i];
+		/*@collect whole histogram report may take some time
+		 *so we add the counter of 2 time slots in FCC and ETSI
+		 */
+		if (region_domain == 1 || region_domain == 3) {
+			dfs->pw_hold_sum[i] = dfs->pw_hold_sum[i] +
+				dfs->pw_hold[(dfs->hist_idx + 1) % 3][i] +
+				dfs->pw_hold[(dfs->hist_idx + 2) % 3][i];
+			dfs->pri_hold_sum[i] = dfs->pri_hold_sum[i] +
+				dfs->pri_hold[(dfs->hist_idx + 1) % 3][i] +
+				dfs->pri_hold[(dfs->hist_idx + 2) % 3][i];
+		} else{
+		/*@collect whole histogram report may take some time,
+		 *so we add the counter of 3 time slots in MKK or else
+		 */
+			dfs->pw_hold_sum[i] = dfs->pw_hold_sum[i] +
+				dfs->pw_hold[(dfs->hist_idx + 1) % 4][i] +
+				dfs->pw_hold[(dfs->hist_idx + 2) % 4][i] +
+				dfs->pw_hold[(dfs->hist_idx + 3) % 4][i];
+			dfs->pri_hold_sum[i] = dfs->pri_hold_sum[i] +
+				dfs->pri_hold[(dfs->hist_idx + 1) % 4][i] +
+				dfs->pri_hold[(dfs->hist_idx + 2) % 4][i] +
+				dfs->pri_hold[(dfs->hist_idx + 3) % 4][i];
+		}
+	}
+	/*@For long radar type*/
+	for (i = 0; i < 6; i++) {
+		dfs->pw_long_hold[dfs->hist_long_idx][i] = (u8)g_pw[i];
+		dfs->pri_long_hold[dfs->hist_long_idx][i] = (u8)g_pri[i];
+		/*@collect whole histogram report may take some time,
+		 *so we add the counter of 299 time slots for long radar
+		 */
+		for (j = 1; j < 300; j++) {
+		dfs->pw_long_hold_sum[i] = dfs->pw_long_hold_sum[i] +
+			dfs->pw_long_hold[(dfs->hist_long_idx + j) % 300][i];
+		dfs->pri_long_hold_sum[i] = dfs->pri_long_hold_sum[i] +
+			dfs->pri_long_hold[(dfs->hist_long_idx + j) % 300][i];
+		}
+	}
+	dfs->hist_idx++;
+	dfs->hist_long_idx++;
+	if (dfs->hist_long_idx == 300)
+		dfs->hist_long_idx = 0;
+	if (region_domain == 1 || region_domain == 3) {
+		if (dfs->hist_idx == 3)
+			dfs->hist_idx = 0;
+	} else if (dfs->hist_idx == 4) {
+		dfs->hist_idx = 0;
+	}
+
+	max_pri_cnt = 0;
+	max_pri_idx = 0;
+	max_pw_cnt = 0;
+	max_pw_idx = 0;
+	max_pri_cnt_th = dfs->pri_sum_g1_th;
+	max_pri_cnt_fcc_g1_th = dfs->pri_sum_g1_fcc_th;
+	max_pri_cnt_fcc_g3_th = dfs->pri_sum_g3_fcc_th;
+	safe_pri_pw_diff_th = dfs->pri_pw_diff_th;
+	safe_pri_pw_diff_fcc_th = dfs->pri_pw_diff_fcc_th;
+	safe_pri_pw_diff_fcc_idle_th = dfs->pri_pw_diff_fcc_idle_th;
+	safe_pri_pw_diff_w53_th = dfs->pri_pw_diff_w53_th;
+
+	/*@g1 to g4 is the reseasonable range of pri and pw*/
+	for (i = 1; i <= 4; i++) {
+		if (dfs->pri_hold_sum[i] > max_pri_cnt) {
+			max_pri_cnt = dfs->pri_hold_sum[i];
+			max_pri_idx = i;
+		}
+		if (dfs->pw_hold_sum[i] > max_pw_cnt) {
+			max_pw_cnt = dfs->pw_hold_sum[i];
+			max_pw_idx = i;
+		}
+		if (dfs->pri_hold_sum[i] >= pri_th)
+			dfs->pri_cond1 = 1;
+	}
+
+	pri_sum_g0g5 = dfs->pri_hold_sum[0];
+	if (pri_sum_g0g5 == 0)
+		pri_sum_g0g5 = 1;
+	pri_sum_g1g2g3g4 = dfs->pri_hold_sum[1] + dfs->pri_hold_sum[2]
+			 + dfs->pri_hold_sum[3] + dfs->pri_hold_sum[4];
+
+	/*pw will reduce because of dc, so we do not treat g0 as illegal group*/
+	pw_sum_g0g5 = dfs->pw_hold_sum[5];
+	if (pw_sum_g0g5 == 0)
+		pw_sum_g0g5 = 1;
+	pw_sum_g1g2g3g4 = dfs->pw_hold_sum[1] + dfs->pw_hold_sum[2] +
+				dfs->pw_hold_sum[3] + dfs->pw_hold_sum[4];
+
+	/*@Calculate the variation from g1 to g4*/
+	for (i = 1; i < 5; i++) {
+		/*Sum of square*/
+		pw_sum_ss_g1g2g3g4 = pw_sum_ss_g1g2g3g4 +
+		(dfs->pw_hold_sum[i] - (pw_sum_g1g2g3g4 / 4)) *
+		(dfs->pw_hold_sum[i] - (pw_sum_g1g2g3g4 / 4));
+		pri_sum_ss_g1g2g3g4 = pri_sum_ss_g1g2g3g4 +
+		(dfs->pri_hold_sum[i] - (pri_sum_g1g2g3g4 / 4)) *
+		(dfs->pri_hold_sum[i] - (pri_sum_g1g2g3g4 / 4));
+	}
+	/*The value may less than the normal variance,
+	 *since the variable type is int (not float)
+	 */
+		dfs->pw_std = (u16)(pw_sum_ss_g1g2g3g4 / 4);
+		dfs->pri_std = (u16)(pri_sum_ss_g1g2g3g4 / 4);
+
+	if (region_domain == 1) {
+		dfs->pri_type3_4_flag = 1;	/*@ETSI flag*/
+
+		/*PRI judgment conditions for short radar type*/
+		/*ratio of reasonable group and illegal group &&
+		 *pri variation of short radar should be large (=6)
+		 */
+		if (max_pri_idx != 4 && dfs->pri_hold_sum[5] > 0)
+			dfs->pri_cond2 = 0;
+		else
+			dfs->pri_cond2 = 1;
+
+		/*reasonable group shouldn't large*/
+		if ((pri_sum_g0g5 + pri_sum_g1g2g3g4) / pri_sum_g0g5 > 2 &&
+		    pri_sum_g1g2g3g4 <= dfs->pri_sum_safe_fcc_th)
+			dfs->pri_cond3 = 1;
+
+		/*@Cancel the condition that the abs between pri and pw*/
+		if (dfs->pri_std >= dfs->pri_std_th)
+			dfs->pri_cond4 = 1;
+		else if (max_pri_idx == 1 &&
+			 max_pri_cnt >= max_pri_cnt_fcc_g1_th)
+			dfs->pri_cond4 = 1;
+
+		/*we set threshold = 7 (>4) for distinguishing type 3,4 (g3)*/
+		if (max_pri_idx == 1 && dfs->pri_hold_sum[3] +
+		    dfs->pri_hold_sum[4] + dfs->pri_hold_sum[5] > 0)
+			dfs->pri_cond5 = 0;
+		else
+			dfs->pri_cond5 = 1;
+
+		if (dfs->pri_cond1 && dfs->pri_cond2 && dfs->pri_cond3 &&
+		    dfs->pri_cond4 && dfs->pri_cond5)
+			dfs->pri_flag = 1;
+
+		/* PW judgment conditions for short radar type */
+		/*ratio of reasonable and illegal group && g5 should be zero*/
+		if (((pw_sum_g0g5 + pw_sum_g1g2g3g4) / pw_sum_g0g5 > 2) &&
+		    (dfs->pw_hold_sum[5] <= 1))
+			dfs->pw_cond1 = 1;
+		/*unreasonable group*/
+		if (dfs->pw_hold_sum[4] == 0 && dfs->pw_hold_sum[5] == 0)
+			dfs->pw_cond2 = 1;
+		/*pw's std (short radar) should be large(=7)*/
+		if (dfs->pw_std >= dfs->pw_std_th)
+			dfs->pw_cond3 = 1;
+		if (dfs->pw_cond1 && dfs->pw_cond2 && dfs->pw_cond3)
+			dfs->pw_flag = 1;
+
+		/* @Judgment conditions of long radar type */
+		if (band_width == CHANNEL_WIDTH_20) {
+			if (dfs->pw_long_hold_sum[4] >=
+			    dfs->pw_long_lower_20m_th)
+				dfs->pw_long_cond1 = 1;
+		} else{
+			if (dfs->pw_long_hold_sum[4] >= dfs->pw_long_lower_th)
+				dfs->pw_long_cond1 = 1;
+		}
+		/* @Disable the condition that dfs->pw_long_hold_sum[1] */
+		if (dfs->pw_long_hold_sum[2] + dfs->pw_long_hold_sum[3] +
+		    dfs->pw_long_hold_sum[4] <= dfs->pw_long_sum_upper_th &&
+		    dfs->pw_long_hold_sum[2] <= dfs->pw_long_hold_sum[4] &&
+		    dfs->pw_long_hold_sum[3] <= dfs->pw_long_hold_sum[4])
+			dfs->pw_long_cond2 = 1;
+		/*@g4 should be large for long radar*/
+		if (dfs->pri_long_hold_sum[4] <= dfs->pri_long_upper_th)
+			dfs->pri_long_cond1 = 1;
+		if (dfs->pw_long_cond1 && dfs->pw_long_cond2 &&
+		    dfs->pri_long_cond1)
+			dfs->long_radar_flag = 1;
+	} else if (region_domain == 2) {
+		dfs->pri_type3_4_flag = 1;	/*@ETSI flag*/
+
+		/*PRI judgment conditions for short radar type*/
+		if ((pri_sum_g0g5 + pri_sum_g1g2g3g4) / pri_sum_g0g5 > 2)
+			dfs->pri_cond2 = 1;
+
+		/*reasonable group shouldn't too large*/
+		if (pri_sum_g1g2g3g4 <= dfs->pri_sum_safe_fcc_th)
+			dfs->pri_cond3 = 1;
+
+		/*Cancel the abs diff between pri and pw for idle mode (thr=2)*/
+		dfs->pri_cond4 = 1;
+
+		if (dfs->idle_mode == 1) {
+			if (dfs->pri_std >= dfs->pri_std_idle_th) {
+				if (max_pw_idx == 3 &&
+				    pri_sum_g1g2g3g4 <= dfs->pri_sum_type4_th){
+		/*To distinguish between type 4 radar and false detection*/
+					dfs->pri_cond5 = 1;
+				} else if (max_pw_idx == 1 &&
+					   pri_sum_g1g2g3g4 >=
+					   dfs->pri_sum_type6_th) {
+		/*To distinguish between type 6 radar and false detection*/
+					dfs->pri_cond5 = 1;
+				} else {
+		/*pri variation of short radar should be large (idle mode)*/
+					dfs->pri_cond5 = 1;
+				}
+			}
+		} else {
+		/*pri variation of short radar should be large (TP mode)*/
+			if (dfs->pri_std >= dfs->pri_std_th)
+				dfs->pri_cond5 = 1;
+		}
+
+		if (dfs->pri_cond1 && dfs->pri_cond2 && dfs->pri_cond3 &&
+		    dfs->pri_cond4 && dfs->pri_cond5)
+			dfs->pri_flag = 1;
+
+		/* PW judgment conditions for short radar type */
+		if (((pw_sum_g0g5 + pw_sum_g1g2g3g4) / pw_sum_g0g5 > 2) &&
+		    (dfs->pw_hold_sum[5] <= 1))
+		/*ratio of reasonable and illegal group && g5 should be zero*/
+			dfs->pw_cond1 = 1;
+
+		if ((c_channel >= 52) && (c_channel <= 64))
+			dfs->pw_cond2 = 1;
+		/*unreasonable group shouldn't too large*/
+		else if (dfs->pw_hold_sum[0] <= dfs->pw_g0_th)
+			dfs->pw_cond2 = 1;
+
+		if (dfs->idle_mode == 1) {
+		/*pw variation of short radar should be large (idle mode)*/
+			if (dfs->pw_std >= dfs->pw_std_idle_th)
+				dfs->pw_cond3 = 1;
+		} else {
+		/*pw variation of short radar should be large (TP mode)*/
+			if (dfs->pw_std >= dfs->pw_std_th)
+				dfs->pw_cond3 = 1;
+		}
+		if (dfs->pw_cond1 && dfs->pw_cond2 && dfs->pw_cond3)
+			dfs->pw_flag = 1;
+
+		/* @Judgment conditions of long radar type */
+		if (band_width == CHANNEL_WIDTH_20) {
+			if (dfs->pw_long_hold_sum[4] >=
+			    dfs->pw_long_lower_20m_th)
+				dfs->pw_long_cond1 = 1;
+		} else{
+			if (dfs->pw_long_hold_sum[4] >= dfs->pw_long_lower_th)
+				dfs->pw_long_cond1 = 1;
+		}
+		if (dfs->pw_long_hold_sum[1] + dfs->pw_long_hold_sum[2] +
+		    dfs->pw_long_hold_sum[3] + dfs->pw_long_hold_sum[4]
+		    <= dfs->pw_long_sum_upper_th)
+			dfs->pw_long_cond2 = 1;
+		/*@g4 should be large for long radar*/
+		if (dfs->pri_long_hold_sum[4] <= dfs->pri_long_upper_th)
+			dfs->pri_long_cond1 = 1;
+		if (dfs->pw_long_cond1 &&
+		    dfs->pw_long_cond2 && dfs->pri_long_cond1)
+			dfs->long_radar_flag = 1;
+	} else if (region_domain == 3) {
+		/*ratio of reasonable group and illegal group */
+		if ((pri_sum_g0g5 + pri_sum_g1g2g3g4) / pri_sum_g0g5 > 2)
+			dfs->pri_cond2 = 1;
+
+		if (pri_sum_g1g2g3g4 <= dfs->pri_sum_safe_th)
+			dfs->pri_cond3 = 1;
+
+		/*@Cancel the condition that the abs between pri and pw*/
+			dfs->pri_cond4 = 1;
+
+		if (dfs->pri_hold_sum[5] <= dfs->pri_sum_g5_th)
+			dfs->pri_cond5 = 1;
+
+		if (band_width == CHANNEL_WIDTH_40) {
+			if (max_pw_idx == 4) {
+				if (max_pw_cnt >= dfs->type4_pw_max_cnt &&
+				    pri_sum_g1g2g3g4 >=
+				    dfs->type4_safe_pri_sum_th) {
+					dfs->pri_cond1 = 1;
+					dfs->pri_cond4 = 1;
+					dfs->pri_type3_4_cond1 = 1;
+				}
+			}
+		}
+
+		if (dfs->pri_cond1 && dfs->pri_cond2 &&
+		    dfs->pri_cond3 && dfs->pri_cond4 && dfs->pri_cond5)
+			dfs->pri_flag = 1;
+
+		if (((pw_sum_g0g5 + pw_sum_g1g2g3g4) / pw_sum_g0g5 > 2))
+			dfs->pw_flag = 1;
+
+		/*@max num pri group is g1 means radar type3 or type4*/
+		if (max_pri_idx == 1) {
+			if (max_pri_cnt >= max_pri_cnt_th)
+				dfs->pri_type3_4_cond1 = 1;
+			if (dfs->pri_hold_sum[4] <=
+			    dfs->pri_sum_g5_under_g1_th &&
+			    dfs->pri_hold_sum[5] <= dfs->pri_sum_g5_under_g1_th)
+				dfs->pri_type3_4_cond2 = 1;
+		} else {
+			dfs->pri_type3_4_cond1 = 1;
+			dfs->pri_type3_4_cond2 = 1;
+		}
+		if (dfs->pri_type3_4_cond1 && dfs->pri_type3_4_cond2)
+			dfs->pri_type3_4_flag = 1;
+	} else {
+	}
+
+	if (dfs->print_hist_rpt) {
+		dfs_pw_thd1 = (u8)odm_get_bb_reg(dm, 0x19e4, 0xff000000);
+		dfs_pw_thd2 = (u8)odm_get_bb_reg(dm, 0x19e8, 0x000000ff);
+		dfs_pw_thd3 = (u8)odm_get_bb_reg(dm, 0x19e8, 0x0000ff00);
+		dfs_pw_thd4 = (u8)odm_get_bb_reg(dm, 0x19e8, 0x00ff0000);
+		dfs_pw_thd5 = (u8)odm_get_bb_reg(dm, 0x19e8, 0xff000000);
+
+		dfs_pri_thd1 = (u8)odm_get_bb_reg(dm, 0x19b8, 0x7F80);
+		dfs_pri_thd2 = (u8)odm_get_bb_reg(dm, 0x19ec, 0x000000ff);
+		dfs_pri_thd3 = (u8)odm_get_bb_reg(dm, 0x19ec, 0x0000ff00);
+		dfs_pri_thd4 = (u8)odm_get_bb_reg(dm, 0x19ec, 0x00ff0000);
+		dfs_pri_thd5 = (u8)odm_get_bb_reg(dm, 0x19ec, 0xff000000);
+
+		PHYDM_DBG(dm, DBG_DFS, "peak index hist\n");
+		PHYDM_DBG(dm, DBG_DFS, "dfs_hist_peak_index=%x %x\n",
+			  dfs_hist1_peak_index, dfs_hist2_peak_index);
+		PHYDM_DBG(dm, DBG_DFS, "g_peak_index_hist = ");
+		for (i = 0; i < 16; i++)
+			PHYDM_DBG(dm, DBG_DFS, " %x", g_peakindex[i]);
+		PHYDM_DBG(dm, DBG_DFS, "\ndfs_pw_thd=%d %d %d %d %d\n",
+			  dfs_pw_thd1, dfs_pw_thd2, dfs_pw_thd3,
+			  dfs_pw_thd4, dfs_pw_thd5);
+		PHYDM_DBG(dm, DBG_DFS, "-----pulse width hist-----\n");
+		PHYDM_DBG(dm, DBG_DFS, "dfs_hist_pw=%x %x\n",
+			  dfs_hist1_pw, dfs_hist2_pw);
+		PHYDM_DBG(dm, DBG_DFS, "g_pw_hist = %x %x %x %x %x %x\n",
+			  g_pw[0], g_pw[1], g_pw[2], g_pw[3],
+			  g_pw[4], g_pw[5]);
+		PHYDM_DBG(dm, DBG_DFS, "dfs_pri_thd=%d %d %d %d %d\n",
+			  dfs_pri_thd1, dfs_pri_thd2, dfs_pri_thd3,
+			  dfs_pri_thd4, dfs_pri_thd5);
+		PHYDM_DBG(dm, DBG_DFS, "-----pulse interval hist-----\n");
+		PHYDM_DBG(dm, DBG_DFS, "dfs_hist_pri=%x %x\n",
+			  dfs_hist1_pri, dfs_hist2_pri);
+		PHYDM_DBG(dm, DBG_DFS,
+			  "g_pri_hist = %x %x %x %x %x %x, pw_flag = %d, pri_flag = %d\n",
+			  g_pri[0], g_pri[1], g_pri[2], g_pri[3], g_pri[4],
+			  g_pri[5], dfs->pw_flag, dfs->pri_flag);
+		if (region_domain == 1 || region_domain == 3) {
+			PHYDM_DBG(dm, DBG_DFS, "hist_idx= %d\n",
+				  (dfs->hist_idx + 2) % 3);
+		} else {
+			PHYDM_DBG(dm, DBG_DFS, "hist_idx= %d\n",
+				  (dfs->hist_idx + 3) % 4);
+		}
+		PHYDM_DBG(dm, DBG_DFS, "hist_long_idx= %d\n",
+			  (dfs->hist_long_idx + 299) % 300);
+		PHYDM_DBG(dm, DBG_DFS,
+			  "pw_sum_g0g5 = %d, pw_sum_g1g2g3g4 = %d\n",
+			  pw_sum_g0g5, pw_sum_g1g2g3g4);
+		PHYDM_DBG(dm, DBG_DFS,
+			  "pri_sum_g0g5 = %d, pri_sum_g1g2g3g4 = %d\n",
+			  pri_sum_g0g5, pri_sum_g1g2g3g4);
+		PHYDM_DBG(dm, DBG_DFS, "pw_hold_sum = %d %d %d %d %d %d\n",
+			  dfs->pw_hold_sum[0], dfs->pw_hold_sum[1],
+			  dfs->pw_hold_sum[2], dfs->pw_hold_sum[3],
+			  dfs->pw_hold_sum[4], dfs->pw_hold_sum[5]);
+		PHYDM_DBG(dm, DBG_DFS, "pri_hold_sum = %d %d %d %d %d %d\n",
+			  dfs->pri_hold_sum[0], dfs->pri_hold_sum[1],
+			  dfs->pri_hold_sum[2], dfs->pri_hold_sum[3],
+			  dfs->pri_hold_sum[4], dfs->pri_hold_sum[5]);
+		PHYDM_DBG(dm, DBG_DFS, "pw_long_hold_sum = %d %d %d %d %d %d\n",
+			  dfs->pw_long_hold_sum[0], dfs->pw_long_hold_sum[1],
+			  dfs->pw_long_hold_sum[2], dfs->pw_long_hold_sum[3],
+			  dfs->pw_long_hold_sum[4], dfs->pw_long_hold_sum[5]);
+		PHYDM_DBG(dm, DBG_DFS,
+			  "pri_long_hold_sum = %d %d %d %d %d %d\n",
+			  dfs->pri_long_hold_sum[0], dfs->pri_long_hold_sum[1],
+			  dfs->pri_long_hold_sum[2], dfs->pri_long_hold_sum[3],
+			  dfs->pri_long_hold_sum[4], dfs->pri_long_hold_sum[5]);
+		PHYDM_DBG(dm, DBG_DFS, "idle_mode = %d\n", dfs->idle_mode);
+		PHYDM_DBG(dm, DBG_DFS, "pw_standard = %d\n", dfs->pw_std);
+		PHYDM_DBG(dm, DBG_DFS, "pri_standard = %d\n", dfs->pri_std);
+		for (j = 0; j < 4; j++) {
+			for (i = 0; i < 6; i++) {
+				PHYDM_DBG(dm, DBG_DFS, "pri_hold = %d ",
+					  dfs->pri_hold[j][i]);
+			}
+			PHYDM_DBG(dm, DBG_DFS, "\n");
+		}
+		PHYDM_DBG(dm, DBG_DFS, "\n");
+		PHYDM_DBG(dm, DBG_DFS,
+			  "pri_cond1 = %d, pri_cond2 = %d, pri_cond3 = %d, pri_cond4 = %d, pri_cond5 = %d\n",
+			  dfs->pri_cond1, dfs->pri_cond2, dfs->pri_cond3,
+			  dfs->pri_cond4, dfs->pri_cond5);
+		PHYDM_DBG(dm, DBG_DFS,
+			  "bandwidth = %d, pri_th = %d, max_pri_cnt_th = %d, safe_pri_pw_diff_th = %d\n",
+			  band_width, pri_th, max_pri_cnt_th,
+			  safe_pri_pw_diff_th);
+	}
+}
 
+boolean phydm_dfs_hist_log(void *dm_void, u8 index)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
+	u8 i = 0, j = 0;
+	boolean hist_radar_detected = 0;
+
+	if (dfs->pulse_type_hist[index] == 0) {
+		dfs->radar_type = 0;
+		if (dfs->pw_flag && dfs->pri_flag &&
+		    dfs->pri_type3_4_flag) {
+			hist_radar_detected = 1;
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Detected type %d radar signal!\n",
+				  dfs->radar_type);
+			if (dfs->det_print2) {
+				PHYDM_DBG(dm, DBG_DFS,
+					  "hist_idx= %d\n",
+					  (dfs->hist_idx + 3) % 4);
+				for (j = 0; j < 4; j++) {
+				for (i = 0; i < 6; i++) {
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_hold = %d ",
+						  dfs->pri_hold[j][i]);
+				}
+				PHYDM_DBG(dm, DBG_DFS, "\n");
+				}
+				PHYDM_DBG(dm, DBG_DFS, "\n");
+				for (j = 0; j < 4; j++) {
+				for (i = 0; i < 6; i++) {
+					PHYDM_DBG(dm, DBG_DFS, "pw_hold = %d ",
+						  dfs->pw_hold[j][i]);
+				}
+					PHYDM_DBG(dm, DBG_DFS, "\n");
+				}
+				PHYDM_DBG(dm, DBG_DFS, "\n");
+				PHYDM_DBG(dm, DBG_DFS, "idle_mode = %d\n",
+					  dfs->idle_mode);
+				PHYDM_DBG(dm, DBG_DFS,
+					  "pw_hold_sum = %d %d %d %d %d %d\n",
+					  dfs->pw_hold_sum[0],
+					  dfs->pw_hold_sum[1],
+					  dfs->pw_hold_sum[2],
+					  dfs->pw_hold_sum[3],
+					  dfs->pw_hold_sum[4],
+					  dfs->pw_hold_sum[5]);
+				PHYDM_DBG(dm, DBG_DFS,
+					  "pri_hold_sum = %d %d %d %d %d %d\n",
+					  dfs->pri_hold_sum[0],
+					  dfs->pri_hold_sum[1],
+					  dfs->pri_hold_sum[2],
+					  dfs->pri_hold_sum[3],
+					  dfs->pri_hold_sum[4],
+					  dfs->pri_hold_sum[5]);
+			}
+		} else {
+		if (dfs->det_print2) {
+			if (dfs->pulse_flag_hist[index] &&
+			    dfs->pri_flag == 0) {
+				PHYDM_DBG(dm, DBG_DFS, "pri_variation = %d\n",
+					  dfs->pri_std);
+				PHYDM_DBG(dm, DBG_DFS,
+					  "PRI criterion is not satisfied!\n");
+				if (dfs->pri_cond1 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_cond1 is not satisfied!\n");
+				if (dfs->pri_cond2 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_cond2 is not satisfied!\n");
+				if (dfs->pri_cond3 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_cond3 is not satisfied!\n");
+				if (dfs->pri_cond4 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_cond4 is not satisfied!\n");
+				if (dfs->pri_cond5 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_cond5 is not satisfied!\n");
+			}
+			if (dfs->pulse_flag_hist[index] &&
+			    dfs->pw_flag == 0) {
+				PHYDM_DBG(dm, DBG_DFS, "pw_variation = %d\n",
+					  dfs->pw_std);
+				PHYDM_DBG(dm, DBG_DFS,
+					  "PW criterion is not satisfied!\n");
+				if (dfs->pw_cond1 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pw_cond1 is not satisfied!\n");
+				if (dfs->pw_cond2 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pw_cond2 is not satisfied!\n");
+				if (dfs->pw_cond3 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pw_cond3 is not satisfied!\n");
+			}
+			if (dfs->pulse_flag_hist[index] &&
+			    (dfs->pri_type3_4_flag == 0)) {
+				PHYDM_DBG(dm, DBG_DFS,
+					  "pri_type3_4 criterion is not satisfied!\n");
+				if (dfs->pri_type3_4_cond1 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_type3_4_cond1 is not satisfied!\n");
+				if (dfs->pri_type3_4_cond2 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_type3_4_cond2 is not satisfied!\n");
+			}
+			PHYDM_DBG(dm, DBG_DFS, "hist_idx= %d\n",
+				  (dfs->hist_idx + 3) % 4);
+			for (j = 0; j < 4; j++) {
+				for (i = 0; i < 6; i++) {
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pri_hold = %d ",
+						  dfs->pri_hold[j][i]);
+				}
+				PHYDM_DBG(dm, DBG_DFS, "\n");
+			}
+			PHYDM_DBG(dm, DBG_DFS, "\n");
+			for (j = 0; j < 4; j++) {
+				for (i = 0; i < 6; i++)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "pw_hold = %d ",
+						  dfs->pw_hold[j][i]);
+				PHYDM_DBG(dm, DBG_DFS, "\n");
+			}
+			PHYDM_DBG(dm, DBG_DFS, "\n");
+			PHYDM_DBG(dm, DBG_DFS, "idle_mode = %d\n",
+				  dfs->idle_mode);
+			PHYDM_DBG(dm, DBG_DFS,
+				  "pw_hold_sum = %d %d %d %d %d %d\n",
+				  dfs->pw_hold_sum[0], dfs->pw_hold_sum[1],
+				  dfs->pw_hold_sum[2], dfs->pw_hold_sum[3],
+				  dfs->pw_hold_sum[4], dfs->pw_hold_sum[5]);
+			PHYDM_DBG(dm, DBG_DFS,
+				  "pri_hold_sum = %d %d %d %d %d %d\n",
+				  dfs->pri_hold_sum[0], dfs->pri_hold_sum[1],
+				  dfs->pri_hold_sum[2], dfs->pri_hold_sum[3],
+				  dfs->pri_hold_sum[4], dfs->pri_hold_sum[5]);
+		}
+		}
+	} else {
+		dfs->radar_type = 1;
+		if (dfs->det_print2) {
+			PHYDM_DBG(dm, DBG_DFS, "\n");
+			PHYDM_DBG(dm, DBG_DFS, "idle_mode = %d\n",
+				  dfs->idle_mode);
+			PHYDM_DBG(dm, DBG_DFS,
+				  "long_radar_pw_hold_sum = %d %d %d %d %d %d\n",
+				  dfs->pw_long_hold_sum[0],
+				  dfs->pw_long_hold_sum[1],
+				  dfs->pw_long_hold_sum[2],
+				  dfs->pw_long_hold_sum[3],
+				  dfs->pw_long_hold_sum[4],
+				  dfs->pw_long_hold_sum[5]);
+			PHYDM_DBG(dm, DBG_DFS,
+				  "long_radar_pri_hold_sum = %d %d %d %d %d %d\n",
+				  dfs->pri_long_hold_sum[0],
+				  dfs->pri_long_hold_sum[1],
+				  dfs->pri_long_hold_sum[2],
+				  dfs->pri_long_hold_sum[3],
+				  dfs->pri_long_hold_sum[4],
+				  dfs->pri_long_hold_sum[5]);
+		}
+		/* @Long radar should satisfy three conditions */
+		if (dfs->long_radar_flag == 1) {
+			hist_radar_detected = 1;
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Detected type %d radar signal!\n",
+				  dfs->radar_type);
+		} else {
+			if (dfs->det_print2) {
+				if (dfs->pw_long_cond1 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "--pw_long_cond1 is not satisfied!--\n");
+				if (dfs->pw_long_cond2 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "--pw_long_cond2 is not satisfied!--\n");
+				if (dfs->pri_long_cond1 == 0)
+					PHYDM_DBG(dm, DBG_DFS,
+						  "--pri_long_cond1 is not satisfied!--\n");
+			}
+		}
+	}
+	return hist_radar_detected;
 }
 
-boolean phydm_radar_detect(void *p_dm_void)
+boolean phydm_radar_detect(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DFS_STATISTICS	*p_dfs = (struct _DFS_STATISTICS *)phydm_get_structure(p_dm, PHYDM_DFS);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
 	boolean enable_DFS = false;
 	boolean radar_detected = false;
 
-	p_dfs->igi_cur = (u8)odm_get_bb_reg(p_dm, 0xc50, 0x0000007f);
-
-	p_dfs->st_l2h_cur = (u8)odm_get_bb_reg(p_dm, 0x91c, 0x000000ff);
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		dfs->igi_cur = (u8)odm_get_bb_reg(dm, R_0x1d70, 0x0000007f);
+		dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, R_0xa40, 0x00007f00);
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		dfs->st_l2h_cur = (u8)(odm_get_bb_reg(dm, R_0xf54,
+						      0x0000001f) << 2);
+		dfs->st_l2h_cur += (u8)odm_get_bb_reg(dm, R_0xf58, 0xc0000000);
+	#endif
+	} else {
+		dfs->igi_cur = (u8)odm_get_bb_reg(dm, R_0xc50, 0x0000007f);
+		dfs->st_l2h_cur = (u8)odm_get_bb_reg(dm, R_0x91c, 0x000000ff);
+	}
 
-	/* dynamic pwdb calibration */
-	if (p_dfs->igi_pre != p_dfs->igi_cur) {
-		p_dfs->pwdb_th = ((int)p_dfs->st_l2h_cur - (int)p_dfs->igi_cur)/2 + p_dfs->pwdb_scalar_factor;
-		p_dfs->pwdb_th = MAX_2(p_dfs->pwdb_th_cur, (int)p_dfs->pwdb_th); /* limit the pwdb value to absoulte lower bound 0xa */
-		p_dfs->pwdb_th = MIN_2(p_dfs->pwdb_th_cur, 0x1f);    /* limit the pwdb value to absoulte upper bound 0x1f */
-		odm_set_bb_reg(p_dm,  0x918, 0x00001f00, p_dfs->pwdb_th);
+	/* @dynamic pwdb calibration */
+	if (dfs->igi_pre != dfs->igi_cur) {
+		dfs->pwdb_th_cur = ((int)dfs->st_l2h_cur - (int)dfs->igi_cur)
+				    / 2 + dfs->pwdb_scalar_factor;
+
+		/* @limit the pwdb value to absolute lower bound 0xa */
+		dfs->pwdb_th_cur = MAX_2(dfs->pwdb_th_cur, (int)dfs->pwdb_th);
+		/* @limit the pwdb value to absolute upper bound 0x1f */
+		dfs->pwdb_th_cur = MIN_2(dfs->pwdb_th_cur, 0x1f);
+
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			odm_set_bb_reg(dm, R_0xa50, 0x000000f0,
+				       dfs->pwdb_th_cur);
+		#if (RTL8721D_SUPPORT)
+		else if (dm->support_ic_type & (ODM_RTL8721D))
+			odm_set_bb_reg(dm, R_0xf70, 0x03c00000,
+				       dfs->pwdb_th_cur);
+		#endif
+		else
+			odm_set_bb_reg(dm, R_0x918, 0x00001f00,
+				       dfs->pwdb_th_cur);
 	}
 
-	p_dfs->igi_pre = p_dfs->igi_cur;
+	dfs->igi_pre = dfs->igi_cur;
 
-	phydm_dfs_dynamic_setting(p_dm);
-	radar_detected = phydm_radar_detect_dm_check(p_dm);
+	phydm_dfs_dynamic_setting(dm);
+	phydm_dfs_histogram_radar_distinguish(dm);
+	radar_detected = phydm_radar_detect_dm_check(dm);
 
-	if (odm_get_bb_reg(p_dm, 0x924, BIT(15)))
-		enable_DFS = true;
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		if (odm_get_bb_reg(dm, R_0xa40, BIT(15)))
+			enable_DFS = true;
+	#if (RTL8721D_SUPPORT)
+	} else if (dm->support_ic_type & (ODM_RTL8721D)) {
+		if (odm_get_bb_reg(dm, R_0xf58, BIT(29)))
+			enable_DFS = true;
+	#endif
+	} else {
+		if (odm_get_bb_reg(dm, R_0x924, BIT(15)))
+			enable_DFS = true;
+	}
 
 	if (enable_DFS && radar_detected) {
-		PHYDM_DBG(p_dm, DBG_DFS, ("Radar detect: enable_DFS:%d, radar_detected:%d\n", enable_DFS, radar_detected));
-		phydm_radar_detect_reset(p_dm);
-                if (p_dfs->dbg_mode == 1){
-			PHYDM_DBG(p_dm, DBG_DFS, ("Radar is detected in DFS dbg mode.\n"));
+		PHYDM_DBG(dm, DBG_DFS,
+			  "Radar detect: enable_DFS:%d, radar_detected:%d\n",
+			  enable_DFS, radar_detected);
+		phydm_radar_detect_reset(dm);
+		if (dfs->dbg_mode == 1) {
+			PHYDM_DBG(dm, DBG_DFS,
+				  "Radar is detected in DFS dbg mode.\n");
 			radar_detected = 0;
 		}
 	}
 
+	if (enable_DFS && dfs->sw_trigger_mode == 1) {
+		radar_detected = 1;
+		PHYDM_DBG(dm, DBG_DFS,
+			  "Radar is detected in DFS SW trigger mode.\n");
+	}
+
 	return enable_DFS && radar_detected;
 }
 
+void phydm_dfs_hist_dbg(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
+	char help[] = "-h";
+	u32 argv[30] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i;
 
-void
-phydm_dfs_debug(
-	void		*p_dm_void,
-	u32		*const argv,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{0} pri_hist_th = %d\n", dfs->pri_hist_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} pri_sum_g1_th = %d\n", dfs->pri_sum_g1_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{2} pri_sum_g5_th = %d\n", dfs->pri_sum_g5_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{3} pri_sum_g1_fcc_th = %d\n",
+			 dfs->pri_sum_g1_fcc_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{4} pri_sum_g3_fcc_th = %d\n",
+			 dfs->pri_sum_g3_fcc_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{5} pri_sum_safe_fcc_th = %d\n",
+			 dfs->pri_sum_safe_fcc_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{6} pri_sum_type4_th = %d\n", dfs->pri_sum_type4_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{7} pri_sum_type6_th = %d\n", dfs->pri_sum_type6_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{8} pri_sum_safe_th = %d\n", dfs->pri_sum_safe_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{9} pri_sum_g5_under_g1_th = %d\n",
+			 dfs->pri_sum_g5_under_g1_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{10} pri_pw_diff_th = %d\n", dfs->pri_pw_diff_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{11} pri_pw_diff_fcc_th = %d\n",
+			 dfs->pri_pw_diff_fcc_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{12} pri_pw_diff_fcc_idle_th = %d\n",
+			 dfs->pri_pw_diff_fcc_idle_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{13} pri_pw_diff_w53_th = %d\n",
+			 dfs->pri_pw_diff_w53_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{14} pri_type1_low_fcc_th = %d\n",
+			 dfs->pri_type1_low_fcc_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{15} pri_type1_upp_fcc_th = %d\n",
+			 dfs->pri_type1_upp_fcc_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{16} pri_type1_cen_fcc_th = %d\n",
+			 dfs->pri_type1_cen_fcc_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{17} pw_g0_th = %d\n", dfs->pw_g0_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{18} pw_long_lower_20m_th = %d\n",
+			 dfs->pw_long_lower_20m_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{19} pw_long_lower_th = %d\n",
+			 dfs->pw_long_lower_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{20} pri_long_upper_th = %d\n",
+			 dfs->pri_long_upper_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{21} pw_long_sum_upper_th = %d\n",
+			 dfs->pw_long_sum_upper_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{22} pw_std_th = %d\n", dfs->pw_std_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{23} pw_std_idle_th = %d\n", dfs->pw_std_idle_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{24} pri_std_th = %d\n", dfs->pri_std_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{25} pri_std_idle_th = %d\n", dfs->pri_std_idle_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{26} type4_pw_max_cnt = %d\n", dfs->type4_pw_max_cnt);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{27} type4_safe_pri_sum_th = %d\n",
+			 dfs->type4_safe_pri_sum_th);
+	} else {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &argv[0]);
+
+		for (i = 1; i < 30; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL,
+					     &argv[i]);
+		}
+		if (argv[0] == 0) {
+			dfs->pri_hist_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_hist_th = %d\n",
+				 dfs->pri_hist_th);
+		} else if (argv[0] == 1) {
+			dfs->pri_sum_g1_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_g1_th = %d\n",
+				 dfs->pri_sum_g1_th);
+		} else if (argv[0] == 2) {
+			dfs->pri_sum_g5_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_g5_th = %d\n",
+				 dfs->pri_sum_g5_th);
+		} else if (argv[0] == 3) {
+			dfs->pri_sum_g1_fcc_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_g1_fcc_th = %d\n",
+				 dfs->pri_sum_g1_fcc_th);
+		} else if (argv[0] == 4) {
+			dfs->pri_sum_g3_fcc_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_g3_fcc_th = %d\n",
+				 dfs->pri_sum_g3_fcc_th);
+		} else if (argv[0] == 5) {
+			dfs->pri_sum_safe_fcc_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_safe_fcc_th = %d\n",
+				 dfs->pri_sum_safe_fcc_th);
+		} else if (argv[0] == 6) {
+			dfs->pri_sum_type4_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_type4_th = %d\n",
+				 dfs->pri_sum_type4_th);
+		} else if (argv[0] == 7) {
+			dfs->pri_sum_type6_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_type6_th = %d\n",
+				 dfs->pri_sum_type6_th);
+		} else if (argv[0] == 8) {
+			dfs->pri_sum_safe_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_safe_th = %d\n",
+				 dfs->pri_sum_safe_th);
+		} else if (argv[0] == 9) {
+			dfs->pri_sum_g5_under_g1_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_sum_g5_under_g1_th = %d\n",
+				 dfs->pri_sum_g5_under_g1_th);
+		} else if (argv[0] == 10) {
+			dfs->pri_pw_diff_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_pw_diff_th = %d\n",
+				 dfs->pri_pw_diff_th);
+		} else if (argv[0] == 11) {
+			dfs->pri_pw_diff_fcc_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_pw_diff_fcc_th = %d\n",
+				 dfs->pri_pw_diff_fcc_th);
+		} else if (argv[0] == 12) {
+			dfs->pri_pw_diff_fcc_idle_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_pw_diff_fcc_idle_th = %d\n",
+				 dfs->pri_pw_diff_fcc_idle_th);
+		} else if (argv[0] == 13) {
+			dfs->pri_pw_diff_w53_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_pw_diff_w53_th = %d\n",
+				 dfs->pri_pw_diff_w53_th);
+		} else if (argv[0] == 14) {
+			dfs->pri_type1_low_fcc_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_type1_low_fcc_th = %d\n",
+				 dfs->pri_type1_low_fcc_th);
+		} else if (argv[0] == 15) {
+			dfs->pri_type1_upp_fcc_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_type1_upp_fcc_th = %d\n",
+				 dfs->pri_type1_upp_fcc_th);
+		} else if (argv[0] == 16) {
+			dfs->pri_type1_cen_fcc_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_type1_cen_fcc_th = %d\n",
+				 dfs->pri_type1_cen_fcc_th);
+		} else if (argv[0] == 17) {
+			dfs->pw_g0_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pw_g0_th = %d\n",
+				 dfs->pw_g0_th);
+		} else if (argv[0] == 18) {
+			dfs->pw_long_lower_20m_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pw_long_lower_20m_th = %d\n",
+				 dfs->pw_long_lower_20m_th);
+		} else if (argv[0] == 19) {
+			dfs->pw_long_lower_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pw_long_lower_th = %d\n",
+				 dfs->pw_long_lower_th);
+		} else if (argv[0] == 20) {
+			dfs->pri_long_upper_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_long_upper_th = %d\n",
+				 dfs->pri_long_upper_th);
+		} else if (argv[0] == 21) {
+			dfs->pw_long_sum_upper_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pw_long_sum_upper_th = %d\n",
+				 dfs->pw_long_sum_upper_th);
+		} else if (argv[0] == 22) {
+			dfs->pw_std_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pw_std_th = %d\n",
+				 dfs->pw_std_th);
+		} else if (argv[0] == 23) {
+			dfs->pw_std_idle_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pw_std_idle_th = %d\n",
+				 dfs->pw_std_idle_th);
+		} else if (argv[0] == 24) {
+			dfs->pri_std_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_std_th = %d\n",
+				 dfs->pri_std_th);
+		} else if (argv[0] == 25) {
+			dfs->pri_std_idle_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "pri_std_idle_th = %d\n",
+				 dfs->pri_std_idle_th);
+		} else if (argv[0] == 26) {
+			dfs->type4_pw_max_cnt = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "type4_pw_max_cnt = %d\n",
+				 dfs->type4_pw_max_cnt);
+		} else if (argv[0] == 27) {
+			dfs->type4_safe_pri_sum_th = (u8)argv[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "type4_safe_pri_sum_th = %d\n",
+				 dfs->type4_safe_pri_sum_th);
+		}
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_dfs_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm_odm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DFS_STATISTICS	*p_dfs = (struct _DFS_STATISTICS *)phydm_get_structure(p_dm_odm, PHYDM_DFS);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _DFS_STATISTICS *dfs = &dm->dfs;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u32 argv[10] = {0};
+	u8 i, input_idx = 0;
+
+	for (i = 0; i < 7; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &argv[i]);
+			input_idx++;
+		}
+	}
 
-	p_dfs->dbg_mode = (boolean)argv[0];
-	p_dfs->force_TP_mode = (boolean)argv[1];
-	p_dfs->det_print = (boolean)argv[2];
-	p_dfs->det_print2 = (boolean)argv[3];
+	if (input_idx == 0)
+		return;
+
+	dfs->dbg_mode = (boolean)argv[0];
+	dfs->sw_trigger_mode = (boolean)argv[1];
+	dfs->force_TP_mode = (boolean)argv[2];
+	dfs->det_print = (boolean)argv[3];
+	dfs->det_print2 = (boolean)argv[4];
+	dfs->print_hist_rpt = (boolean)argv[5];
+	dfs->hist_cond_on = (boolean)argv[6];
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "dbg_mode: %d, sw_trigger_mode: %d, force_TP_mode: %d, det_print: %d,det_print2: %d, print_hist_rpt: %d, hist_cond_on: %d\n",
+		 dfs->dbg_mode, dfs->sw_trigger_mode, dfs->force_TP_mode,
+		 dfs->det_print, dfs->det_print2, dfs->print_hist_rpt,
+		 dfs->hist_cond_on);
 
-	PHYDM_SNPRINTF((output + used, out_len - used, "dbg_mode: %d, force_TP_mode: %d, det_print: %d, det_print2: %d\n", p_dfs->dbg_mode, p_dfs->force_TP_mode, p_dfs->det_print, p_dfs->det_print2));
-	
 	/*switch (argv[0]) {
 	case 1:
 #if defined(CONFIG_PHYDM_DFS_MASTER)
-		 set dbg parameters for radar detection instead of the default value 
+		 set dbg parameters for radar detection instead of the default value
 		if (argv[1] == 1) {
-			p_dm_odm->radar_detect_reg_918 = argv[2];
-			p_dm_odm->radar_detect_reg_91c = argv[3];
-			p_dm_odm->radar_detect_reg_920 = argv[4];
-			p_dm_odm->radar_detect_reg_924 = argv[5];
-			p_dm_odm->radar_detect_dbg_parm_en = 1;
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "Radar detection with dbg parameter\n"));
-			PHYDM_SNPRINTF((output + used, out_len - used, "reg918:0x%08X\n", p_dm_odm->radar_detect_reg_918));
-			PHYDM_SNPRINTF((output + used, out_len - used, "reg91c:0x%08X\n", p_dm_odm->radar_detect_reg_91c));
-			PHYDM_SNPRINTF((output + used, out_len - used, "reg920:0x%08X\n", p_dm_odm->radar_detect_reg_920));
-			PHYDM_SNPRINTF((output + used, out_len - used, "reg924:0x%08X\n", p_dm_odm->radar_detect_reg_924));
+			dm->radar_detect_reg_918 = argv[2];
+			dm->radar_detect_reg_91c = argv[3];
+			dm->radar_detect_reg_920 = argv[4];
+			dm->radar_detect_reg_924 = argv[5];
+			dm->radar_detect_dbg_parm_en = 1;
+
+			PDM_SNPF((output + used, out_len - used, "Radar detection with dbg parameter\n"));
+			PDM_SNPF((output + used, out_len - used, "reg918:0x%08X\n", dm->radar_detect_reg_918));
+			PDM_SNPF((output + used, out_len - used, "reg91c:0x%08X\n", dm->radar_detect_reg_91c));
+			PDM_SNPF((output + used, out_len - used, "reg920:0x%08X\n", dm->radar_detect_reg_920));
+			PDM_SNPF((output + used, out_len - used, "reg924:0x%08X\n", dm->radar_detect_reg_924));
 		} else {
-			p_dm_odm->radar_detect_dbg_parm_en = 0;
-			PHYDM_SNPRINTF((output + used, out_len - used, "Radar detection with default parameter\n"));
+			dm->radar_detect_dbg_parm_en = 0;
+			PDM_SNPF((output + used, out_len - used, "Radar detection with default parameter\n"));
 		}
-		phydm_radar_detect_enable(p_dm_odm);
-#endif  defined(CONFIG_PHYDM_DFS_MASTER) 
+		phydm_radar_detect_enable(dm);
+#endif  defined(CONFIG_PHYDM_DFS_MASTER)
 
 		break;
 	default:
@@ -646,35 +2263,62 @@ phydm_dfs_debug(
 	}*/
 }
 
+u8 phydm_dfs_polling_time(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 dfs_polling_time = 0;
 
+	if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
+		dfs_polling_time = 40;
+	else
+		dfs_polling_time = 100;
 
-#endif /* defined(CONFIG_PHYDM_DFS_MASTER) */
+	return dfs_polling_time;
+}
+
+#endif /* @defined(CONFIG_PHYDM_DFS_MASTER) */
 
 boolean
-phydm_is_dfs_band(
-	void		*p_dm_void
-)
+phydm_is_dfs_band(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (((*p_dm->p_channel >= 52) && (*p_dm->p_channel <= 64)) ||
-		((*p_dm->p_channel >= 100) && (*p_dm->p_channel <= 140)))
+	if (((*dm->channel >= 52) && (*dm->channel <= 64)) ||
+	    ((*dm->channel >= 100) && (*dm->channel <= 144)))
 		return true;
 	else
 		return false;
 }
 
 boolean
-phydm_dfs_master_enabled(
-	void		*p_dm_void
-)
+phydm_dfs_master_enabled(void *dm_void)
 {
 #ifdef CONFIG_PHYDM_DFS_MASTER
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean ret_val = false;
+
+	if (dm->dfs_master_enabled) /*pointer protection*/
+		ret_val = *dm->dfs_master_enabled ? true : false;
 
-	return *p_dm->dfs_master_enabled ? true : false;
+	return ret_val;
 #else
 	return false;
 #endif
 }
 
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_dfs_ap_reset_radar_detect_counter_and_flag(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	/* @Clear Radar Counter and Radar flag */
+	odm_set_bb_reg(dm, R_0xa40, BIT(15), 0);
+	odm_set_bb_reg(dm, R_0xa40, BIT(15), 1);
+
+	/* RT_TRACE(COMP_DFS, DBG_LOUD, ("[DFS], After reset radar counter, 0xcf8 = 0x%x, 0xcf4 = 0x%x\n", */
+	/* PHY_QueryBBReg(Adapter, 0xcf8, bMaskDWord), */
+	/* PHY_QueryBBReg(Adapter, 0xcf4, bMaskDWord))); */
+}
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.h
index 761a403fe048..d5a228df917b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dfs.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,101 +9,183 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 #ifndef __PHYDM_DFS_H__
 #define __PHYDM_DFS_H__
 
-#define DFS_VERSION	"1.1"
+#define DFS_VERSION "1.1"
 
-/* ============================================================
-  Definition
- ============================================================
-*/
+/*@
+ * ============================================================
+ *  Definition
+ * ============================================================
+ */
 
-/*
-============================================================
-1  structure
- ============================================================
-*/
+/*@
+ * ============================================================
+ * 1  structure
+ * ============================================================
+ */
 
 struct _DFS_STATISTICS {
-	u8			mask_idx;
-	u8			igi_cur;
-	u8			igi_pre;
-	u8			st_l2h_cur;
-	u16			fa_count_pre;
-	u16			fa_inc_hist[5];	
-	u16			vht_crc_ok_cnt_pre;
-	u16			ht_crc_ok_cnt_pre;
-	u16			leg_crc_ok_cnt_pre;
-	u16			short_pulse_cnt_pre;
-	u16			long_pulse_cnt_pre;
-	u8			pwdb_th;
-	u8			pwdb_th_cur;
-	u8			pwdb_scalar_factor;	
-	u8			peak_th;
-	u8			short_pulse_cnt_th;
-	u8			long_pulse_cnt_th;
-	u8			peak_window;
-	u8			nb2wb_th;
-	u8			fa_mask_th;
-	u8			det_flag_offset;
-	u8			st_l2h_max;
-	u8			st_l2h_min;
-	u8			mask_hist_checked;
+	u8		mask_idx;
+	u8		igi_cur;
+	u8		igi_pre;
+	u8		st_l2h_cur;
+	u16		fa_count_pre;
+	u16		fa_inc_hist[5];
+	u16		vht_crc_ok_cnt_pre;
+	u16		ht_crc_ok_cnt_pre;
+	u16		leg_crc_ok_cnt_pre;
+	u16		short_pulse_cnt_pre;
+	u16		long_pulse_cnt_pre;
+	u8		pwdb_th;
+	u8		pwdb_th_cur;
+	u8		pwdb_scalar_factor;
+	u8		peak_th;
+	u8		short_pulse_cnt_th;
+	u8		long_pulse_cnt_th;
+	u8		peak_window;
+	u8		three_peak_opt;
+	u8		three_peak_th2;
+	u8		fa_mask_th;
+	u8		det_flag_offset;
+	u8		st_l2h_max;
+	u8		st_l2h_min;
+	u8		mask_hist_checked;
 	boolean		pulse_flag_hist[5];
+	boolean		pulse_type_hist[5];
 	boolean		radar_det_mask_hist[5];
 	boolean		idle_mode;
 	boolean		force_TP_mode;
 	boolean		dbg_mode;
+	boolean		sw_trigger_mode;
 	boolean		det_print;
 	boolean		det_print2;
+	boolean		radar_type;
+	/*@dfs histogram*/
+	boolean		print_hist_rpt;
+	boolean		hist_cond_on;
+	boolean		pri_cond1;
+	boolean		pri_cond2;
+	boolean		pri_cond3;
+	boolean		pri_cond4;
+	boolean		pri_cond5;
+	boolean		pw_cond1;
+	boolean		pw_cond2;
+	boolean		pw_cond3;
+	boolean		pri_type3_4_cond1;	/*@for ETSI*/
+	boolean		pri_type3_4_cond2;	/*@for ETSI*/
+	boolean		pw_long_cond1;	/*@for long radar*/
+	boolean		pw_long_cond2;	/*@for long radar*/
+	boolean		pri_long_cond1;	/*@for long radar*/
+	boolean		pw_flag;
+	boolean		pri_flag;
+	boolean		pri_type3_4_flag;	/*@for ETSI*/
+	boolean		long_radar_flag;
+	u16		pri_hold_sum[6];
+	u16		pw_hold_sum[6];
+	u16		pri_long_hold_sum[6];
+	u16		pw_long_hold_sum[6];
+	u8		hist_idx;
+	u8		hist_long_idx;
+	u8		pw_hold[4][6];
+	u8		pri_hold[4][6];
+	u8		pw_long_hold[300][6];
+	u8		pri_long_hold[300][6];
+	u16		pw_std;	/*@The std(var) of reasonable num of pw group*/
+	u16		pri_std;/*@The std(var) of reasonable num of pri group*/
+	/*@dfs histogram threshold*/
+	u8		pri_hist_th;
+	u8		pri_sum_g1_th;
+	u8		pri_sum_g5_th;
+	u8		pri_sum_g1_fcc_th;
+	u8		pri_sum_g3_fcc_th;
+	u8		pri_sum_safe_fcc_th;
+	u8		pri_sum_type4_th;
+	u8		pri_sum_type6_th;
+	u8		pri_sum_safe_th;
+	u8		pri_sum_g5_under_g1_th;
+	u8		pri_pw_diff_th;
+	u8		pri_pw_diff_fcc_th;
+	u8		pri_pw_diff_fcc_idle_th;
+	u8		pri_pw_diff_w53_th;
+	u8		pri_type1_low_fcc_th;
+	u8		pri_type1_upp_fcc_th;
+	u8		pri_type1_cen_fcc_th;
+	u8		pw_g0_th;
+	u8		pw_long_lower_20m_th;
+	u8		pw_long_lower_th;
+	u8		pri_long_upper_th;
+	u8		pw_long_sum_upper_th;
+	u8		pw_std_th;
+	u8		pw_std_idle_th;
+	u8		pri_std_th;
+	u8		pri_std_idle_th;
+	u8		type4_pw_max_cnt;
+	u8		type4_safe_pri_sum_th;
 };
 
-
-/* ============================================================
-  enumeration
- ============================================================
-*/
+/*@
+ * ============================================================
+ * enumeration
+ * ============================================================
+ */
 
 enum phydm_dfs_region_domain {
-	PHYDM_DFS_DOMAIN_UNKNOWN = 0,
-	PHYDM_DFS_DOMAIN_FCC = 1,
-	PHYDM_DFS_DOMAIN_MKK = 2,
-	PHYDM_DFS_DOMAIN_ETSI = 3,
+	PHYDM_DFS_DOMAIN_UNKNOWN =	0,
+	PHYDM_DFS_DOMAIN_FCC =		1,
+	PHYDM_DFS_DOMAIN_MKK =		2,
+	PHYDM_DFS_DOMAIN_ETSI =		3,
 };
 
-/*
-============================================================
-  function prototype
-============================================================
-*/
+/*@
+ * ============================================================
+ * function prototype
+ * ============================================================
+ */
 #if defined(CONFIG_PHYDM_DFS_MASTER)
-void phydm_radar_detect_reset(void *p_dm_void);
-void phydm_radar_detect_disable(void *p_dm_void);
-void phydm_radar_detect_enable(void *p_dm_void);
-boolean phydm_radar_detect(void *p_dm_void);
-void phydm_dfs_parameter_init(void *p_dm_void);
-void phydm_dfs_debug(void *p_dm_void, u32 *const argv, u32 *_used, char *output, u32 *_out_len);
-#endif /* defined(CONFIG_PHYDM_DFS_MASTER) */
+void phydm_radar_detect_reset(void *dm_void);
+void phydm_radar_detect_disable(void *dm_void);
+void phydm_radar_detect_enable(void *dm_void);
+boolean phydm_radar_detect(void *dm_void);
+void phydm_dfs_histogram_radar_distinguish(void *dm_void);
+boolean phydm_dfs_hist_log(void *dm_void, u8 index);
+void phydm_dfs_parameter_init(void *dm_void);
+void phydm_dfs_hist_dbg(void *dm_void, char input[][16], u32 *_used,
+			char *output, u32 *_out_len);
+void phydm_dfs_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len);
+u8 phydm_dfs_polling_time(void *dm_void);
+#endif /* @defined(CONFIG_PHYDM_DFS_MASTER) */
 
-boolean 
-phydm_dfs_is_meteorology_channel(
-	void		*p_dm_void
-);
+boolean
+phydm_dfs_is_meteorology_channel(void *dm_void);
 
 boolean
-phydm_is_dfs_band(
-	void		*p_dm_void
-);
+phydm_is_dfs_band(void *dm_void);
 
 boolean
-phydm_dfs_master_enabled(
-	void		*p_dm_void
-);
+phydm_dfs_master_enabled(void *dm_void);
+
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_dfs_ap_reset_radar_detect_counter_and_flag(void *dm_void);
+#endif
+#endif
 
-#endif /*#ifndef __PHYDM_DFS_H__ */
+#endif /*@#ifndef __PHYDM_DFS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.c
index 90165ace4e02..80a939826710 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,414 +9,713 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ * ************************************************************
+ */
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
+#ifdef CFG_DIG_DAMPING_CHK
+void phydm_dig_recorder_reset(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_dig_recorder_strcut *dig_rc = &dig_t->dig_recorder_t;
+
+	PHYDM_DBG(dm, DBG_DIG, "%s ======>\n", __func__);
+
+	odm_memory_set(dm, &dig_rc->igi_bitmap, 0,
+		       sizeof(struct phydm_dig_recorder_strcut));
+}
+
+void phydm_dig_recorder(void *dm_void, boolean first_connect, u8 igi_curr,
+			u32 fa_cnt)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_dig_recorder_strcut *dig_rc = &dig_t->dig_recorder_t;
+	u8 igi_pre = dig_rc->igi_history[0];
+	u8 igi_up = 0;
+
+	if (!dm->is_linked)
+		return;
+
+	PHYDM_DBG(dm, DBG_DIG, "%s ======>\n", __func__);
+
+	if (first_connect) {
+		phydm_dig_recorder_reset(dm);
+		dig_rc->igi_history[0] = igi_curr;
+		dig_rc->fa_history[0] = fa_cnt;
+		return;
+	}
+
+	if (igi_curr % 2)
+		igi_curr--;
+
+	igi_pre = dig_rc->igi_history[0];
+	igi_up = (igi_curr > igi_pre) ? 1 : 0;
+	dig_rc->igi_bitmap = ((dig_rc->igi_bitmap << 1) & 0xfe) | igi_up;
+
+	dig_rc->igi_history[3] = dig_rc->igi_history[2];
+	dig_rc->igi_history[2] = dig_rc->igi_history[1];
+	dig_rc->igi_history[1] = dig_rc->igi_history[0];
+	dig_rc->igi_history[0] = igi_curr;
+
+	dig_rc->fa_history[3] = dig_rc->fa_history[2];
+	dig_rc->fa_history[2] = dig_rc->fa_history[1];
+	dig_rc->fa_history[1] = dig_rc->fa_history[0];
+	dig_rc->fa_history[0] = fa_cnt;
+
+	PHYDM_DBG(dm, DBG_DIG, "igi_history[3:0] = {0x%x, 0x%x, 0x%x, 0x%x}\n",
+		  dig_rc->igi_history[3], dig_rc->igi_history[2],
+		  dig_rc->igi_history[1], dig_rc->igi_history[0]);
+	PHYDM_DBG(dm, DBG_DIG, "fa_history[3:0] = {%d, %d, %d, %d}\n",
+		  dig_rc->fa_history[3], dig_rc->fa_history[2],
+		  dig_rc->fa_history[1], dig_rc->fa_history[0]);
+	PHYDM_DBG(dm, DBG_DIG, "igi_bitmap = {%d, %d, %d, %d} = 0x%x\n",
+		  (u8)((dig_rc->igi_bitmap & BIT(3)) >> 3),
+		  (u8)((dig_rc->igi_bitmap & BIT(2)) >> 2),
+		  (u8)((dig_rc->igi_bitmap & BIT(1)) >> 1),
+		  (u8)(dig_rc->igi_bitmap & BIT(0)),
+		  dig_rc->igi_bitmap);
+}
+
+void phydm_dig_damping_chk(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_dig_recorder_strcut *dig_rc = &dig_t->dig_recorder_t;
+	u8 igi_bitmap_4bit = dig_rc->igi_bitmap & 0xf;
+	u8 diff1 = 0, diff2 = 0;
+	u32 fa_low_th = dig_t->fa_th[0];
+	u32 fa_high_th = dig_t->fa_th[1];
+	u32 fa_high_th2 = dig_t->fa_th[2];
+	u8 fa_pattern_match = 0;
+	u32 time_tmp = 0;
+
+	if (!dm->is_linked)
+		return;
+
+	PHYDM_DBG(dm, DBG_DIG, "%s ======>\n", __func__);
+
+	/*@== Release Damping ================================================*/
+	if (dig_rc->damping_limit_en) {
+		PHYDM_DBG(dm, DBG_DIG,
+			  "[Damping Limit!] limit_time=%d, phydm_sys_up_time=%d\n",
+			  dig_rc->limit_time, dm->phydm_sys_up_time);
+
+		time_tmp = dig_rc->limit_time + DIG_LIMIT_PERIOD;
+
+		if (DIFF_2(dm->rssi_min, dig_rc->limit_rssi) > 3 ||
+		    time_tmp < dm->phydm_sys_up_time) {
+			dig_rc->damping_limit_en = 0;
+			PHYDM_DBG(dm, DBG_DIG, "rssi_min=%d, limit_rssi=%d\n",
+				  dm->rssi_min, dig_rc->limit_rssi);
+		}
+		return;
+	}
+
+	/*@== Damping Pattern Check===========================================*/
+	PHYDM_DBG(dm, DBG_DIG, "fa_th{H, L}= {%d,%d}\n", fa_high_th, fa_low_th);
+
+	switch (igi_bitmap_4bit) {
+	case 0x5:
+	/*@ 4b'0101 
+	* IGI:[3]down(0x24)->[2]up(0x26)->[1]down(0x24)->[0]up(0x26)->[new](Lock @ 0x26)
+	* FA: [3] >high1   ->[2] <low   ->[1] >high1   ->[0] <low   ->[new]   <low
+	*
+	* IGI:[3]down(0x24)->[2]up(0x28)->[1]down(0x24)->[0]up(0x28)->[new](Lock @ 0x28)
+	* FA: [3] >high2   ->[2] <low   ->[1] >high2   ->[0] <low   ->[new]   <low
+	*/
+		if (dig_rc->igi_history[0] > dig_rc->igi_history[1])
+			diff1 = dig_rc->igi_history[0] - dig_rc->igi_history[1];
+
+		if (dig_rc->igi_history[2] > dig_rc->igi_history[3])
+			diff2 = dig_rc->igi_history[2] - dig_rc->igi_history[3];
+
+		if (dig_rc->fa_history[0] < fa_low_th &&
+		    dig_rc->fa_history[1] > fa_high_th &&
+		    dig_rc->fa_history[2] < fa_low_th &&
+		    dig_rc->fa_history[3] > fa_high_th) {
+		    /*@Check each fa element*/
+			fa_pattern_match = 1;
+		}
+		break;
+	case 0x9:
+	/*@ 4b'1001
+	* IGI:[3]up(0x28)->[2]down(0x26)->[1]down(0x24)->[0]up(0x28)->[new](Lock @ 0x28)
+	* FA: [3]  <low  ->[2] <low     ->[1] >high2   ->[0] <low   ->[new]  <low
+	*/
+		if (dig_rc->igi_history[0] > dig_rc->igi_history[1])
+			diff1 = dig_rc->igi_history[0] - dig_rc->igi_history[1];
+
+		if (dig_rc->igi_history[2] < dig_rc->igi_history[3])
+			diff2 = dig_rc->igi_history[3] - dig_rc->igi_history[2];
+
+		if (dig_rc->fa_history[0] < fa_low_th &&
+		    dig_rc->fa_history[1] > fa_high_th2 &&
+		    dig_rc->fa_history[2] < fa_low_th &&
+		    dig_rc->fa_history[3] < fa_low_th) {
+		    /*@Check each fa element*/
+			fa_pattern_match = 1;
+		}
+		break;
+	default:
+		break;
+	}
+
+	if (diff1 >= 2 && diff2 >= 2 && fa_pattern_match) {
+		dig_rc->damping_limit_en = 1;
+		dig_rc->damping_limit_val = dig_rc->igi_history[0];
+		dig_rc->limit_time = dm->phydm_sys_up_time;
+		dig_rc->limit_rssi = dm->rssi_min;
+
+		PHYDM_DBG(dm, DBG_DIG,
+			  "[Start damping_limit!] IGI_dyn_min=0x%x, limit_time=%d, limit_rssi=%d\n",
+			  dig_rc->damping_limit_val,
+			  dig_rc->limit_time, dig_rc->limit_rssi);
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "damping_limit=%d\n", dig_rc->damping_limit_en);
+}
+#endif
 
 boolean
-phydm_dig_go_up_check(
-	void		*p_dm_void
-)
+phydm_dig_go_up_check(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _CCX_INFO			*ccx_info = &p_dm->dm_ccx_info;
-	struct phydm_dig_struct		*p_dig_t = &p_dm->dm_dig_table;
-	u8		cur_ig_value = p_dig_t->cur_ig_value;
-	u8		max_cover_bond;
-	u8		rx_gain_range_max = p_dig_t->rx_gain_range_max;
-	u8		i = 0, j = 0;
-	u8		total_nhm_cnt = ccx_info->nhm_result_total;
-	u32		dig_cover_cnt = 0;
-	u32		over_dig_cover_cnt = 0;
-	boolean		ret = true;
-
-	if (*p_dm->p_bb_op_mode == PHYDM_PERFORMANCE_MODE)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ccx_info *ccx_info = &dm->dm_ccx_info;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u8 cur_ig_value = dig_t->cur_ig_value;
+	u8 max_cover_bond = 0;
+	u8 rx_gain_range_max = dig_t->rx_gain_range_max;
+	u8 i = 0, j = 0;
+	u8 total_nhm_cnt = ccx_info->nhm_rpt_sum;
+	u32 dig_cnt = 0;
+	u32 over_dig_cnt = 0;
+	boolean ret = true;
+
+	if (*dm->bb_op_mode == PHYDM_PERFORMANCE_MODE)
 		return ret;
 
-	max_cover_bond = DIG_MAX_BALANCE_MODE - p_dig_t->dig_upcheck_initial_value;
+	max_cover_bond = DIG_MAX_BALANCE_MODE - dig_t->upcheck_init_val;
 
 	if (cur_ig_value < max_cover_bond - 6)
-		p_dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_0;
+		dig_t->go_up_chk_lv = DIG_GOUPCHECK_LEVEL_0;
 	else if (cur_ig_value <= DIG_MAX_BALANCE_MODE)
-		p_dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_1;
-	else	/* cur_ig_value > DM_DIG_MAX_AP, foolproof */
-		p_dig_t->dig_go_up_check_level = DIG_GOUPCHECK_LEVEL_2;
-	
-
-	PHYDM_DBG(p_dm, DBG_DIG, ("check_lv = %d, max_cover_bond = 0x%x\n",
-			p_dig_t->dig_go_up_check_level,
-			max_cover_bond));
-
-	if (total_nhm_cnt != 0) {
-		if (p_dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_0) {
-			for (i = 3; i<=11; i++)
-				dig_cover_cnt += ccx_info->nhm_result[i];
-			ret = ((p_dig_t->dig_level0_ratio_reciprocal * dig_cover_cnt) >= total_nhm_cnt) ? true : false;
-		} else if (p_dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_1) {
-			
-			/* search index */
-			for (i = 0; i<=10; i++) {
-				if ((max_cover_bond * 2) == ccx_info->nhm_th[i]) {
-					for(j =(i+1); j <= 11; j++)
-						over_dig_cover_cnt += ccx_info->nhm_result[j];
-					break;
-				}
-			}
-			ret = (p_dig_t->dig_level1_ratio_reciprocal * over_dig_cover_cnt < total_nhm_cnt) ? true : false;
+		dig_t->go_up_chk_lv = DIG_GOUPCHECK_LEVEL_1;
+	else /* @cur_ig_value > DM_DIG_MAX_AP, foolproof */
+		dig_t->go_up_chk_lv = DIG_GOUPCHECK_LEVEL_2;
+
+	PHYDM_DBG(dm, DBG_DIG, "check_lv = %d, max_cover_bond = 0x%x\n",
+		  dig_t->go_up_chk_lv, max_cover_bond);
+
+	if (total_nhm_cnt == 0)
+		return true;
 
-			if (!ret) {
-				/* update p_dig_t->rx_gain_range_max */
-				p_dig_t->rx_gain_range_max = (rx_gain_range_max >= max_cover_bond - 6) ? (max_cover_bond - 6) : rx_gain_range_max;
+	if (dig_t->go_up_chk_lv == DIG_GOUPCHECK_LEVEL_0) {
+		for (i = 3; i <= 11; i++)
+			dig_cnt += ccx_info->nhm_result[i];
 
-				PHYDM_DBG(p_dm, DBG_DIG,
-					("Noise pwr over DIG can filter, lock rx_gain_range_max to 0x%x\n",
-					p_dig_t->rx_gain_range_max));
+		if ((dig_t->lv0_ratio_reciprocal * dig_cnt) >= total_nhm_cnt)
+			ret = true;
+		else
+			ret = false;
+
+	} else if (dig_t->go_up_chk_lv == DIG_GOUPCHECK_LEVEL_1) {
+		/* search index */
+		for (i = 0; i <= 10; i++) {
+			if ((max_cover_bond * 2) == ccx_info->nhm_th[i]) {
+				for (j = (i + 1); j <= 11; j++)
+					over_dig_cnt += ccx_info->nhm_result[j];
+				break;
 			}
-		} else if (p_dig_t->dig_go_up_check_level == DIG_GOUPCHECK_LEVEL_2) {
-			/* cur_ig_value > DM_DIG_MAX_AP, foolproof */
+		}
+
+		if (dig_t->lv1_ratio_reciprocal * over_dig_cnt < total_nhm_cnt)
 			ret = true;
+		else
+			ret = false;
+
+		if (!ret) {
+			/* update dig_t->rx_gain_range_max */
+			if (rx_gain_range_max + 6 >= max_cover_bond)
+				dig_t->rx_gain_range_max =  max_cover_bond - 6;
+			else
+				dig_t->rx_gain_range_max =  rx_gain_range_max;
+
+			PHYDM_DBG(dm, DBG_DIG,
+				  "Noise pwr over DIG can filter, lock rx_gain_range_max to 0x%x\n",
+				  dig_t->rx_gain_range_max);
 		}
-	} else
+	} else if (dig_t->go_up_chk_lv == DIG_GOUPCHECK_LEVEL_2) {
+		/* @cur_ig_value > DM_DIG_MAX_AP, foolproof */
 		ret = true;
+	}
 
 	return ret;
 }
 
-void
-odm_fa_threshold_check(
-	void			*p_dm_void,
-	boolean			is_dfs_band,
-	boolean			is_performance
-)
+void phydm_fa_threshold_check(void *dm_void, boolean is_dfs_band)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-
-	if (p_dig_t->is_dbg_fa_th == true)
-		return;
-	
-	if (p_dm->is_linked && (is_performance || is_dfs_band)) {
-		if ((p_dm->rx_tp >> 2) > p_dm->tx_tp && p_dm->rx_tp < 10 && p_dm->rx_tp > 1) {			/*10Mbps & 1Mbps*/
-			p_dig_t->fa_th[0] = 125;
-			p_dig_t->fa_th[1] = 250;
-			p_dig_t->fa_th[2] = 500;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	if (dig_t->is_dbg_fa_th) {
+		PHYDM_DBG(dm, DBG_DIG, "Manual Fix FA_th\n");
+	} else if (dm->is_linked) {
+		if (dm->rssi_min < 20) { /*@[PHYDM-252]*/
+			dig_t->fa_th[0] = 500;
+			dig_t->fa_th[1] = 750;
+			dig_t->fa_th[2] = 1000;
+		} else if (((dm->rx_tp >> 2) > dm->tx_tp) && /*Test RX TP*/
+			   (dm->rx_tp < 10) && (dm->rx_tp > 1)) { /*TP=1~10Mb*/
+			dig_t->fa_th[0] = 125;
+			dig_t->fa_th[1] = 250;
+			dig_t->fa_th[2] = 500;
 		} else {
-			p_dig_t->fa_th[0] = 250;
-			p_dig_t->fa_th[1] = 500;
-			p_dig_t->fa_th[2] = 750;
+			dig_t->fa_th[0] = 250;
+			dig_t->fa_th[1] = 500;
+			dig_t->fa_th[2] = 750;
 		}
 	} else {
+		if (is_dfs_band) { /* @For DFS band and no link */
 
-		if (is_dfs_band) {	/* For DFS band and no link */
-			
-			p_dig_t->fa_th[0] = 250;
-			p_dig_t->fa_th[1] = 1000;
-			p_dig_t->fa_th[2] = 2000;
+			dig_t->fa_th[0] = 250;
+			dig_t->fa_th[1] = 1000;
+			dig_t->fa_th[2] = 2000;
 		} else {
-			p_dig_t->fa_th[0] = 2000;
-			p_dig_t->fa_th[1] = 4000;
-			p_dig_t->fa_th[2] = 5000;
+			dig_t->fa_th[0] = 2000;
+			dig_t->fa_th[1] = 4000;
+			dig_t->fa_th[2] = 5000;
 		}
 	}
 
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("FA_th={%d,%d,%d}\n",
-		p_dig_t->fa_th[0],
-		p_dig_t->fa_th[1],
-		p_dig_t->fa_th[2]));
-
+	PHYDM_DBG(dm, DBG_DIG, "FA_th={%d,%d,%d}\n", dig_t->fa_th[0],
+		  dig_t->fa_th[1], dig_t->fa_th[2]);
 }
 
-void
-phydm_set_big_jump_step(
-	void			*p_dm_void,
-	u8			current_igi
-)
+void phydm_set_big_jump_step(void *dm_void, u8 curr_igi)
 {
-#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	u8		step1[8] = {24, 30, 40, 50, 60, 70, 80, 90};
-	u8		i;
-
-	if (p_dig_t->enable_adjust_big_jump == 0)
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u8 step1[8] = {24, 30, 40, 50, 60, 70, 80, 90};
+	u8 big_jump_lmt = dig_t->big_jump_lmt[dig_t->agc_table_idx];
+	u8 i;
+
+	if (dig_t->enable_adjust_big_jump == 0)
 		return;
 
-	for (i = 0; i <= p_dig_t->big_jump_step1; i++) {
-		if ((current_igi + step1[i]) > p_dig_t->big_jump_lmt[p_dig_t->agc_table_idx]) {
+	for (i = 0; i <= dig_t->big_jump_step1; i++) {
+		if ((curr_igi + step1[i]) > big_jump_lmt) {
 			if (i != 0)
 				i = i - 1;
 			break;
-		} else if (i == p_dig_t->big_jump_step1)
+		} else if (i == dig_t->big_jump_step1) {
 			break;
+		}
 	}
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		odm_set_bb_reg(p_dm, 0x8c8, 0xe, i);
-	else if (p_dm->support_ic_type & ODM_RTL8197F)
-		odm_set_bb_reg(p_dm, ODM_REG_BB_AGC_SET_2_11N, 0xe, i);
+	if (dm->support_ic_type & ODM_RTL8822B)
+		odm_set_bb_reg(dm, R_0x8c8, 0xe, i);
+	else if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+		odm_set_bb_reg(dm, ODM_REG_BB_AGC_SET_2_11N, 0xe, i);
 
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("phydm_set_big_jump_step(): bigjump = %d (ori = 0x%x), LMT=0x%x\n",
-		i, p_dig_t->big_jump_step1, p_dig_t->big_jump_lmt[p_dig_t->agc_table_idx]));
+	PHYDM_DBG(dm, DBG_DIG, "Bigjump = %d (ori = 0x%x), LMT=0x%x\n", i,
+		  dig_t->big_jump_step1, big_jump_lmt);
 #endif
 }
 
-void
-odm_write_dig(
-	void			*p_dm_void,
-	u8			current_igi
-)
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_write_dig_reg_jgr3(void *dm_void, u8 igi)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct phydm_adaptivity_struct	*p_adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	PHYDM_DBG(dm, DBG_DIG, "%s===>\n", __func__);
+
+	/* Set IGI value */
+	if (!(dm->support_ic_type & ODM_IC_JGR3_SERIES))
+		return;
 
-	PHYDM_DBG(p_dm, DBG_DIG, ("odm_write_dig===>\n"));
+	odm_set_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_11AC, igi);
 
-	/* 1 Check IGI by upper bound */
-	if (p_adaptivity->igi_lmt_en && 
-		(current_igi > p_adaptivity->adapt_igi_up) && p_dm->is_linked) {
-		
-		current_igi = p_adaptivity->adapt_igi_up;
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS)
+		odm_set_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_B_11AC3, igi);
+	#endif
 
-		PHYDM_DBG(p_dm, DBG_DIG,
-			("Force to Adaptivity Upper bound=((0x%x))\n", current_igi));
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+		odm_set_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_C_11AC3, igi);
+		odm_set_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_D_11AC3, igi);
 	}
+	#endif
+}
 
-	if (p_dig_t->cur_ig_value != current_igi) {
+u8 phydm_get_igi_reg_val_jgr3(void *dm_void, enum bb_path path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 val = 0;
 
-		#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
-		/* Modify big jump step for 8822B and 8197F */
-		if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F))
-			phydm_set_big_jump_step(p_dm, current_igi);
-		#endif
+	PHYDM_DBG(dm, DBG_DIG, "%s===>\n", __func__);
 
-		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-		/* Set IGI value of CCK for new CCK AGC */
-		if (p_dm->cck_new_agc && (p_dm->support_ic_type & ODM_IC_PHY_STATUE_NEW_TYPE))
-			odm_set_bb_reg(p_dm, 0xa0c, 0x3f00, (current_igi >> 1));
-		#endif
+	/* Set IGI value */
+	if (!(dm->support_ic_type & ODM_IC_JGR3_SERIES))
+		return (u8)val;
 
-		/*Add by YuChen for USB IO too slow issue*/
-		if (p_dm->support_ic_type &
-			(ODM_IC_11AC_GAIN_IDX_EDCCA | ODM_IC_11N_GAIN_IDX_EDCCA)) {
-			if ((p_dm->support_ability & ODM_BB_ADAPTIVITY) &&
-				(current_igi < p_dig_t->cur_ig_value)) {
-				p_dig_t->cur_ig_value = current_igi;
-				phydm_adaptivity(p_dm);
-			}
-		} else {
-			if ((p_dm->support_ability & ODM_BB_ADAPTIVITY) &&
-				(current_igi > p_dig_t->cur_ig_value)) {
-				p_dig_t->cur_ig_value = current_igi;
-				phydm_adaptivity(p_dm);
-			}
-		}
+	if (path == BB_PATH_A)
+		val = odm_get_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_11AC);
+#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	else if (path == BB_PATH_B)
+		val = odm_get_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_B_11AC3);
+#endif
+
+#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	else if (path == BB_PATH_C)
+		val = odm_get_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_C_11AC3);
+#endif
 
-		/* Set IGI value */
-		odm_set_bb_reg(p_dm, ODM_REG(IGI_A, p_dm), ODM_BIT(IGI, p_dm), current_igi);
+#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	else if (path == BB_PATH_D)
+		val = odm_get_bb_reg(dm, R_0x1d70, ODM_BIT_IGI_D_11AC3);
+#endif
+	return (u8)val;
+}
 
-		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
-		if (p_dm->support_ic_type & PHYDM_IC_ABOVE_2SS)
-			odm_set_bb_reg(p_dm, ODM_REG(IGI_B, p_dm), ODM_BIT(IGI, p_dm), current_igi);
-		#endif
+void phydm_fa_cnt_statistics_jgr3(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+	u32 ret_value = 0;
+	u32 cck_enable = 0;
+	u16 ofdm_tx_counter = 0;
+	u16 cck_tx_counter = 0;
+
+	if (!(dm->support_ic_type & ODM_IC_JGR3_SERIES))
+		return;
 
-		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
-		if (p_dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
-			odm_set_bb_reg(p_dm, ODM_REG(IGI_C, p_dm), ODM_BIT(IGI, p_dm), current_igi);
-			odm_set_bb_reg(p_dm, ODM_REG(IGI_D, p_dm), ODM_BIT(IGI, p_dm), current_igi);
-		}
-		#endif
-		
-		p_dig_t->cur_ig_value = current_igi;
+	ofdm_tx_counter = (u16)odm_get_bb_reg(dm, R_0x2de0, MASKLWORD);
+	cck_tx_counter = (u16)odm_get_bb_reg(dm, R_0x2de4, MASKLWORD);
+
+	ret_value = odm_get_bb_reg(dm, R_0x2d20, MASKDWORD);
+	fa_t->cnt_fast_fsync = (ret_value & 0xffff);
+	fa_t->cnt_sb_search_fail = ((ret_value & 0xffff0000) >> 16);
+
+	ret_value = odm_get_bb_reg(dm, R_0x2d04, MASKDWORD);
+	fa_t->cnt_parity_fail = ((ret_value & 0xffff0000) >> 16);
+
+	ret_value = odm_get_bb_reg(dm, R_0x2d08, MASKDWORD);
+	fa_t->cnt_rate_illegal = (ret_value & 0xffff);
+	fa_t->cnt_crc8_fail = ((ret_value & 0xffff0000) >> 16);
+
+	ret_value = odm_get_bb_reg(dm, R_0x2d10, MASKDWORD);
+	fa_t->cnt_mcs_fail = (ret_value & 0xffff);
+
+	/* @read OFDM FA counter, subtract tx_cnt due to new design of brk_cnt*/
+	fa_t->cnt_ofdm_fail = odm_get_bb_reg(dm, R_0x2d00, MASKLWORD)
+			      - ofdm_tx_counter;
+
+	/* Read CCK FA counter */
+	fa_t->cnt_cck_fail = odm_get_bb_reg(dm, R_0x1a5c, MASKLWORD);
+
+	/* read CCK/OFDM CCA counter */
+	ret_value = odm_get_bb_reg(dm, R_0x2c08, MASKDWORD);
+	fa_t->cnt_ofdm_cca = ((ret_value & 0xffff0000) >> 16);
+	fa_t->cnt_cck_cca = ret_value & 0xffff;
+
+	/* read CCK CRC32 counter */
+	ret_value = odm_get_bb_reg(dm, R_0x2c04, MASKDWORD);
+	fa_t->cnt_cck_crc32_error = ((ret_value & 0xffff0000) >> 16);
+	fa_t->cnt_cck_crc32_ok = ret_value & 0xffff;
+
+	/* read OFDM CRC32 counter */
+	ret_value = odm_get_bb_reg(dm, R_0x2c14, MASKDWORD);
+	fa_t->cnt_ofdm_crc32_error = ((ret_value & 0xffff0000) >> 16);
+	fa_t->cnt_ofdm_crc32_ok = ret_value & 0xffff;
+
+	/* read HT CRC32 counter */
+	ret_value = odm_get_bb_reg(dm, R_0x2c10, MASKDWORD);
+	fa_t->cnt_ht_crc32_error = ((ret_value & 0xffff0000) >> 16);
+	fa_t->cnt_ht_crc32_ok = ret_value & 0xffff;
+
+	/* @for VHT part */
+	if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8812F |
+	    ODM_RTL8814B)) {
+		/* read VHT CRC32 counter */
+		ret_value = odm_get_bb_reg(dm, R_0x2c0c, MASKDWORD);
+		fa_t->cnt_vht_crc32_error = ((ret_value & 0xffff0000) >> 16);
+		fa_t->cnt_vht_crc32_ok = ret_value & 0xffff;
+
+		ret_value = odm_get_bb_reg(dm, R_0x2d10, MASKDWORD);
+		fa_t->cnt_mcs_fail_vht = ((ret_value & 0xffff0000) >> 16);
+
+		ret_value = odm_get_bb_reg(dm, R_0x2d0c, MASKDWORD);
+		fa_t->cnt_crc8_fail_vht = (ret_value & 0xffff) +
+					  ((ret_value & 0xffff0000) >> 16);
+	} else {
+		fa_t->cnt_vht_crc32_error = 0;
+		fa_t->cnt_vht_crc32_ok = 0;
+		fa_t->cnt_mcs_fail_vht = 0;
+		fa_t->cnt_crc8_fail_vht = 0;
 	}
 
-	PHYDM_DBG(p_dm, DBG_DIG, ("New_igi=((0x%x))\n\n", current_igi));
+	/* @CCK RxIQ weighting = 1 => 0x1a14[9:8]=0x0 */
+	cck_enable = odm_get_bb_reg(dm, R_0x1a14, 0x300);
+	if (cck_enable == 0x0) { /* @if(*dm->band_type == ODM_BAND_2_4G) */
+		fa_t->cnt_all = fa_t->cnt_ofdm_fail + fa_t->cnt_cck_fail;
+		fa_t->cnt_cca_all = fa_t->cnt_cck_cca + fa_t->cnt_ofdm_cca;
+		PHYDM_DBG(dm, DBG_FA_CNT, "ac3 OFDM FA = %d, CCK FA = %d\n",
+			  fa_t->cnt_ofdm_fail, fa_t->cnt_cck_fail);
+	} else {
+		fa_t->cnt_all = fa_t->cnt_ofdm_fail;
+		fa_t->cnt_cca_all = fa_t->cnt_ofdm_cca;
+		PHYDM_DBG(dm, DBG_FA_CNT, "ac3 CCK disable OFDM FA = %d\n",
+			  fa_t->cnt_ofdm_fail);
+	}
+
+	PHYDM_DBG(dm, DBG_FA_CNT,
+		  "ac3 [OFDM FA Detail] Parity_fail=((%d)), Rate_Illegal=((%d)), CRC8_fail=((%d)), Mcs_fail=((%d)), Fast_Fsync=((%d)), SBD_fail=((%d))\n",
+		  fa_t->cnt_parity_fail, fa_t->cnt_rate_illegal,
+		  fa_t->cnt_crc8_fail, fa_t->cnt_mcs_fail, fa_t->cnt_fast_fsync,
+		  fa_t->cnt_sb_search_fail);
 }
 
-void
-phydm_set_dig_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-)
+#endif
+
+void phydm_write_dig_reg_c50(void *dm_void, u8 igi)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (val_len != 1) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[Error][DIG]Need val_len=1\n"));
-		return;
+	PHYDM_DBG(dm, DBG_DIG, "%s===>\n", __func__);
+
+	odm_set_bb_reg(dm, ODM_REG(IGI_A, dm), ODM_BIT(IGI, dm), igi);
+
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_2SS)
+		odm_set_bb_reg(dm, ODM_REG(IGI_B, dm), ODM_BIT(IGI, dm), igi);
+	#endif
+
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	if (dm->support_ic_type & PHYDM_IC_ABOVE_4SS) {
+		odm_set_bb_reg(dm, ODM_REG(IGI_C, dm), ODM_BIT(IGI, dm), igi);
+		odm_set_bb_reg(dm, ODM_REG(IGI_D, dm), ODM_BIT(IGI, dm), igi);
 	}
-	
-	odm_write_dig(p_dm, (u8)(*val_buf));
+	#endif
 }
 
-void
-odm_pause_dig(
-	void					*p_dm_void,
-	enum phydm_pause_type		pause_type,
-	enum phydm_pause_level		pause_level,
-	u8					igi_value
-)
+void phydm_write_dig_reg(void *dm_void, u8 igi)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	u8	i = 0;
-	s8	max_level;
-	
-	PHYDM_DBG(p_dm, DBG_DIG, ("%s ======>\n", __func__));
-
-	if ((p_dig_t->pause_lv_bitmap == 0) && 
-		(!(p_dm->support_ability & (ODM_BB_DIG | ODM_BB_FA_CNT)))) {
-		
-		PHYDM_DBG(p_dm, DBG_DIG, ("Return: DIG or FA is disabled\n"));
-		return;
-	}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
 
-	if (pause_level >= PHYDM_PAUSE_MAX_NUM) {
-		PHYDM_DBG(p_dm, DBG_DIG, ("Return: Wrong Lv\n"));
-		return;
-	}
+	PHYDM_DBG(dm, DBG_DIG, "%s===>\n", __func__);
+
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_write_dig_reg_jgr3(dm, igi);
+	else
+	#endif
+		phydm_write_dig_reg_c50(dm, igi);
+
+	dig_t->cur_ig_value = igi;
+}
+
+void odm_write_dig(void *dm_void, u8 new_igi)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_adaptivity_struct *adaptivity = &dm->adaptivity;
+
+	PHYDM_DBG(dm, DBG_DIG, "%s===>\n", __func__);
 
-	PHYDM_DBG(p_dm, DBG_DIG, ("Set pause {type, lv, IGI}={%d, %d, 0x%x}\n",
-		pause_type, pause_level, igi_value));
-	
-	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
-		PHYDM_DBG(p_dm, DBG_DIG, ("pause val[%d]=0x%x\n", 
-										i, p_dig_t->pause_dig_value[i]));
+	/* @1 Check IGI by upper bound */
+	if (adaptivity->igi_lmt_en &&
+	    new_igi > adaptivity->adapt_igi_up && dm->is_linked) {
+		new_igi = adaptivity->adapt_igi_up;
+
+		PHYDM_DBG(dm, DBG_DIG, "Force Adaptivity Up-bound=((0x%x))\n",
+			  new_igi);
 	}
 
-	switch (pause_type) {
-	
-	case PHYDM_PAUSE:
-	{
-		PHYDM_DBG(p_dm, DBG_DIG, ("Pause DIG\n"));
-		
-		p_dm->support_ability &= ~ODM_BB_DIG;
-		
-		if (p_dig_t->pause_lv_bitmap == 0) {
-			p_dig_t->igi_backup = p_dig_t->cur_ig_value; /* Backup IGI value */
-			PHYDM_DBG(p_dm, DBG_DIG, ("Backup IGI=0x%x\n", 
-														p_dig_t->igi_backup));
-		}
+	#if (RTL8192F_SUPPORT)
+	if ((dm->support_ic_type & ODM_RTL8192F) &&
+	    dm->cut_version == ODM_CUT_A &&
+	    new_igi > 0x38) {
+		new_igi = 0x38;
+		PHYDM_DBG(dm, DBG_DIG,
+			  "Force 92F Adaptivity Up-bound=((0x%x))\n", new_igi);
+	}
+	#endif
+
+	if (dig_t->cur_ig_value != new_igi) {
+		#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+		/* @Modify big jump step for 8822B and 8197F */
+		if (dm->support_ic_type &
+		    (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8192F))
+			phydm_set_big_jump_step(dm, new_igi);
+		#endif
 
-		p_dig_t->pause_dig_value[pause_level] = igi_value; /* Record IGI value */
-		p_dig_t->pause_lv_bitmap |= BIT(pause_level); /* Update pause level bit-map*/
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT)
+		/* Set IGI value of CCK for new CCK AGC */
+		if (dm->cck_new_agc &&
+		    (dm->support_ic_type & PHYSTS_2ND_TYPE_IC))
+			odm_set_bb_reg(dm, R_0xa0c, 0x3f00, (new_igi >> 1));
+		#endif
 
-		if (BIT(pause_level + 1) > p_dig_t->pause_lv_bitmap) {
-			PHYDM_DBG(p_dm, DBG_DIG, ("[SUCCESS ]Pause DIG\n"));
-			odm_write_dig(p_dm, igi_value);
+		/*@Add by YuChen for USB IO too slow issue*/
+		if (!(dm->support_ic_type & ODM_IC_PWDB_EDCCA)) {
+			if (dm->support_ability & ODM_BB_ADAPTIVITY &&
+			    new_igi < dig_t->cur_ig_value) {
+				dig_t->cur_ig_value = new_igi;
+				phydm_adaptivity(dm);
+			}
 		} else {
-			PHYDM_DBG(p_dm, DBG_DIG, 
-				("[FAIL] Pause DIG, pause_bitmap=0x%x\n", p_dig_t->pause_lv_bitmap));
+			if (dm->support_ability & ODM_BB_ADAPTIVITY &&
+			    new_igi > dig_t->cur_ig_value) {
+				dig_t->cur_ig_value = new_igi;
+				phydm_adaptivity(dm);
+			}
 		}
+		phydm_write_dig_reg(dm, new_igi);
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "New_igi=((0x%x))\n\n", new_igi);
+}
+
+u8 phydm_get_igi_reg_val(void *dm_void, enum bb_path path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 val = 0;
+	u32 bit_map = ODM_BIT(IGI, dm);
+
+	switch (path) {
+	case BB_PATH_A:
+		val = odm_get_bb_reg(dm, ODM_REG(IGI_A, dm), bit_map);
+		break;
+	#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+	case BB_PATH_B:
+		val = odm_get_bb_reg(dm, ODM_REG(IGI_B, dm), bit_map);
+		break;
+	#endif
+
+	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+	case BB_PATH_C:
+		val = odm_get_bb_reg(dm, ODM_REG(IGI_C, dm), bit_map);
+		break;
+	#endif
+
+	#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	case BB_PATH_D:
+		val = odm_get_bb_reg(dm, ODM_REG(IGI_D, dm), bit_map);
+		break;
+	#endif
+
+	default:
 		break;
 	}
-	
-	case PHYDM_RESUME:
-	{
-		PHYDM_DBG(p_dm, DBG_DIG, ("Resume DIG\n"));
-		
-		/* check if the level is illegal or not */
-		if ((p_dig_t->pause_lv_bitmap & (BIT(pause_level))) != 0) {
-			
-			p_dig_t->pause_lv_bitmap &= ~(BIT(pause_level));
-			p_dig_t->pause_dig_value[pause_level] = 0;
-		} else {
-		
-			PHYDM_DBG(p_dm, DBG_DIG, ("Wrong resume Lv\n"));
-			break;
-		}
 
-		PHYDM_DBG(p_dm, DBG_DIG, ("Pause_bitmap =0x%x\n", 
-													p_dig_t->pause_lv_bitmap));
+	return (u8)val;
+}
 
-		/* Resume DIG */
-		if (p_dig_t->pause_lv_bitmap == 0) {
+u8 phydm_get_igi(void *dm_void, enum bb_path path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 val = 0;
 
-			PHYDM_DBG(p_dm, DBG_DIG, ("Revert ori_IGI\n"));
-			odm_write_dig(p_dm, p_dig_t->igi_backup); /* Revert IGI*/
-			p_dig_t->is_ignore_dig = true;
-			p_dm->support_ability |= ODM_BB_DIG;/* Enable DIG */
-			break;
-		}
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		val = phydm_get_igi_reg_val_jgr3(dm, path);
+	else
+	#endif
+		val = phydm_get_igi_reg_val(dm, path);
 
-		if (BIT(pause_level) > p_dig_t->pause_lv_bitmap) {
+	return val;
+}
 
-			/* Calculate the maximum level now */
-			for (max_level = (pause_level - 1); max_level >= 0; max_level--) {
-				if (p_dig_t->pause_lv_bitmap & BIT(max_level))
-					break;
-			}
+void phydm_set_dig_val(void *dm_void, u32 *val_buf, u8 val_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-			/* write IGI to lower level */
-			PHYDM_DBG(p_dm, DBG_DIG, ("Pause @ IGI{Lv=0x%x}=%d)\n",
-				max_level, p_dig_t->pause_dig_value[max_level]));
-			
-			odm_write_dig(p_dm, p_dig_t->pause_dig_value[max_level]);
+	if (val_len != 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][DIG]Need val_len=1\n");
+		return;
+	}
 
-			break;
-		}
+	odm_write_dig(dm, (u8)(*val_buf));
+}
+
+void odm_pause_dig(void *dm_void, enum phydm_pause_type type,
+		   enum phydm_pause_level lv, u8 igi_input)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rpt = false;
+	u32 igi = (u32)igi_input;
+
+	PHYDM_DBG(dm, DBG_DIG, "[%s]type=%d, LV=%d, igi=0x%x\n", __func__, type,
+		  lv, igi);
+
+	switch (type) {
+	case PHYDM_PAUSE:
+	case PHYDM_PAUSE_NO_SET: {
+		rpt = phydm_pause_func(dm, F00_DIG, PHYDM_PAUSE, lv, 1, &igi);
 		break;
 	}
-	default:
-		PHYDM_DBG(p_dm, DBG_DIG, ("Wrong pause  type\n"));
+
+	case PHYDM_RESUME: {
+		rpt = phydm_pause_func(dm, F00_DIG, PHYDM_RESUME, lv, 1, &igi);
 		break;
 	}
-
-	PHYDM_DBG(p_dm, DBG_DIG, ("New pause bitmap = 0x%x\n",
-		p_dig_t->pause_lv_bitmap));
-	
-	for (i = 0; i < PHYDM_PAUSE_MAX_NUM; i ++) {
-		PHYDM_DBG(p_dm, DBG_DIG, ("pause val[%d]=0x%x\n", 
-										i, p_dig_t->pause_dig_value[i]));
+	default:
+		PHYDM_DBG(dm, DBG_DIG, "Wrong type\n");
+		break;
 	}
 
+	PHYDM_DBG(dm, DBG_DIG, "pause_result=%d\n", rpt);
 }
 
 boolean
-odm_dig_abort(
-	void			*p_dm_void
-)
+phydm_dig_abort(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*p_adapter	= p_dm->adapter;
+	void *adapter = dm->adapter;
 #endif
 
 	/* support_ability */
-	if ((!(p_dm->support_ability & ODM_BB_FA_CNT)) ||
-		(!(p_dm->support_ability & ODM_BB_DIG)) ||
-		(*(p_dm->p_is_scan_in_process))) {
-		PHYDM_DBG(p_dm, DBG_DIG, ("Not Support\n"));
+	if ((!(dm->support_ability & ODM_BB_FA_CNT)) ||
+	    (!(dm->support_ability & ODM_BB_DIG)) ||
+	    *dm->is_scan_in_process) {
+		PHYDM_DBG(dm, DBG_DIG, "Not Support\n");
 		return true;
 	}
 
-	if (p_dm->pause_ability & ODM_BB_DIG) {
-		
-		PHYDM_DBG(p_dm, DBG_DIG, ("Return: Pause DIG in LV=%d\n", p_dm->pause_lv_table.lv_dig));
-		return true;
-	}
-	
-	if (p_dig_t->is_ignore_dig) {
-		p_dig_t->is_ignore_dig = false;
-		PHYDM_DBG(p_dm, DBG_DIG, ("Return: Ignore DIG\n"));
+	if (dm->pause_ability & ODM_BB_DIG) {
+		PHYDM_DBG(dm, DBG_DIG, "Return: Pause DIG in LV=%d\n",
+			  dm->pause_lv_table.lv_dig);
 		return true;
 	}
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #if OS_WIN_FROM_WIN7(OS_VERSION)
-	if (IsAPModeExist(p_adapter) && p_adapter->bInHctTest) {
-		PHYDM_DBG(p_dm, DBG_DIG, (" Return: Is AP mode or In HCT Test\n"));
+	if (IsAPModeExist(adapter) && ((PADAPTER)(adapter))->bInHctTest) {
+		PHYDM_DBG(dm, DBG_DIG, " Return: Is AP mode or In HCT Test\n");
 		return true;
 	}
 #endif
@@ -424,508 +724,467 @@ odm_dig_abort(
 	return false;
 }
 
-void
-phydm_dig_init(
-	void		*p_dm_void
-)
+void phydm_dig_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct		*p_dig_t = &p_dm->dm_dig_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct phydm_fa_struct	*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(p_dm, PHYDM_FALSEALMCNT);
+	struct phydm_fa_struct *false_alm_cnt = &dm->false_alm_cnt;
 #endif
-	u32			ret_value = 0;
-	u8			i;
+	u32 ret_value = 0;
+	u8 i;
 
-	p_dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
-	p_dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
-	p_dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+	dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+	dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
+	dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
 
-	p_dig_t->is_ignore_dig = false;
-	p_dig_t->cur_ig_value = (u8) odm_get_bb_reg(p_dm, ODM_REG(IGI_A, p_dm), ODM_BIT(IGI, p_dm));
-	p_dig_t->is_media_connect = false;
+	dig_t->cur_ig_value = phydm_get_igi(dm, BB_PATH_A);
 
-	p_dig_t->fa_th[0] = 250;
-	p_dig_t->fa_th[1] = 500;
-	p_dig_t->fa_th[2] = 750;
-	p_dig_t->is_dbg_fa_th = false;
+	dig_t->is_media_connect = false;
+
+	dig_t->fa_th[0] = 250;
+	dig_t->fa_th[1] = 500;
+	dig_t->fa_th[2] = 750;
+	dig_t->is_dbg_fa_th = false;
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	/* For RTL8881A */
+	/* @For RTL8881A */
 	false_alm_cnt->cnt_ofdm_fail_pre = 0;
 #endif
 
-	odm_memory_set(p_dm, p_dig_t->pause_dig_value, 0, PHYDM_PAUSE_MAX_NUM);
-	p_dig_t->pause_lv_bitmap = 0;
-
-	p_dig_t->rx_gain_range_max = DIG_MAX_BALANCE_MODE;
-	p_dig_t->rx_gain_range_min = p_dig_t->cur_ig_value;
-
-#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
-	p_dig_t->enable_adjust_big_jump = 1;
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		ret_value = odm_get_bb_reg(p_dm, 0x8c8, MASKLWORD);
-	else if (p_dm->support_ic_type & ODM_RTL8197F)
-		ret_value = odm_get_bb_reg(p_dm, 0xc74, MASKLWORD);
-
-	p_dig_t->big_jump_step1 = (u8)(ret_value & 0xe) >> 1;
-	p_dig_t->big_jump_step2 = (u8)(ret_value & 0x30) >> 4;
-	p_dig_t->big_jump_step3 = (u8)(ret_value & 0xc0) >> 6;
-
-	if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8197F)) {
-		for (i = 0; i < sizeof(p_dig_t->big_jump_lmt); i++) {
-			if (p_dig_t->big_jump_lmt[i] == 0)
-				p_dig_t->big_jump_lmt[i] = 0x64;		/* Set -10dBm as default value */
+	dig_t->rx_gain_range_max = DIG_MAX_BALANCE_MODE;
+	dig_t->rx_gain_range_min = dig_t->cur_ig_value;
+
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+	dig_t->enable_adjust_big_jump = 1;
+	if (dm->support_ic_type & ODM_RTL8822B)
+		ret_value = odm_get_bb_reg(dm, R_0x8c8, MASKLWORD);
+	else if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+		ret_value = odm_get_bb_reg(dm, R_0xc74, MASKLWORD);
+
+	dig_t->big_jump_step1 = (u8)(ret_value & 0xe) >> 1;
+	dig_t->big_jump_step2 = (u8)(ret_value & 0x30) >> 4;
+	dig_t->big_jump_step3 = (u8)(ret_value & 0xc0) >> 6;
+
+	if (dm->support_ic_type &
+	    (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8192F)) {
+		for (i = 0; i < sizeof(dig_t->big_jump_lmt); i++) {
+			if (dig_t->big_jump_lmt[i] == 0)
+				dig_t->big_jump_lmt[i] = 0x64;
+				/* Set -10dBm as default value */
 		}
 	}
 #endif
 
-	p_dm->pre_rssi_min = 0;
-
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-	p_dm->original_dig_restore = 1;
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		dm->original_dig_restore = true;
+		dm->tdma_dig_state_number = DIG_NUM_OF_TDMA_STATES;
+		dm->tdma_dig_timer_ms = DIG_TIMER_MS;
+	#endif
 #endif
-}
-
-boolean
-phydm_dig_performance_mode_decision(
-	struct PHY_DM_STRUCT		*p_dm
-)
-{
-	boolean	is_performance = true;
-
-#ifdef PHYDM_DIG_MODE_DECISION_SUPPORT
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-
-	switch (p_dig_t->dig_mode_decision) {
-	case PHYDM_DIG_PERFORAMNCE_MODE:
-		is_performance = true;
-		break;
-	case PHYDM_DIG_COVERAGE_MODE:
-		is_performance = false;
-		break;
-	default:
-		is_performance = true;
-		break;
-	}
+#ifdef CFG_DIG_DAMPING_CHK
+	phydm_dig_recorder_reset(dm);
+	dig_t->dig_dl_en = 1;
 #endif
-
-	return is_performance;
 }
 
-void
-phydm_dig_abs_boundary_decision(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	is_performance,
-	boolean	is_dfs_band
-)
+void phydm_dig_abs_boundary_decision(struct dm_struct *dm, boolean is_dfs_band)
 {
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-
-	if (!p_dm->is_linked) {
-		p_dig_t->dm_dig_max = DIG_MAX_COVERAGR;
-		p_dig_t->dm_dig_min = DIG_MIN_COVERAGE;
-	} else if (is_dfs_band == true) {
-		if (*p_dm->p_band_width == CHANNEL_WIDTH_20)
-			p_dig_t->dm_dig_min = DIG_MIN_DFS + 2;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_adaptivity_struct *adapt = &dm->adaptivity;
+
+	if (!dm->is_linked) {
+		dig_t->dm_dig_max = DIG_MAX_COVERAGR;
+		dig_t->dm_dig_min = DIG_MIN_COVERAGE;
+	} else if (is_dfs_band) {
+		if (*dm->band_width == CHANNEL_WIDTH_20)
+			dig_t->dm_dig_min = DIG_MIN_DFS + 2;
 		else
-			p_dig_t->dm_dig_min = DIG_MIN_DFS;
-
-		p_dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
-		p_dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+			dig_t->dm_dig_min = DIG_MIN_DFS;
 
-	} else if (!is_performance) {
-		p_dig_t->dm_dig_max = DIG_MAX_COVERAGR;
-		p_dig_t->dm_dig_min = DIG_MIN_COVERAGE;
-		#if (DIG_HW == 1)
-		p_dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
-		#else
-		p_dig_t->dig_max_of_min = DIG_MAX_OF_MIN_COVERAGE;
-		#endif
+		dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+		dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
 	} else {
-		if (*p_dm->p_bb_op_mode == PHYDM_BALANCE_MODE) {	/*service > 2 devices*/
-			p_dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+		if (*dm->bb_op_mode == PHYDM_BALANCE_MODE) {
+		/*service > 2 devices*/
+			dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
 			#if (DIG_HW == 1)
-			p_dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
+			dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
 			#else
-			p_dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
 			#endif
-		} else if (*p_dm->p_bb_op_mode == PHYDM_PERFORMANCE_MODE) {	/*service 1 devices*/
-			p_dig_t->dm_dig_max = DIG_MAX_PERFORMANCE_MODE;
-			p_dig_t->dig_max_of_min = DIG_MAX_OF_MIN_PERFORMANCE_MODE;
+		} else if (*dm->bb_op_mode == PHYDM_PERFORMANCE_MODE) {
+		/*service 1 devices*/
+			if (adapt->is_adapt_en && (dm->support_ic_type &
+			    (ODM_RTL8197F | ODM_RTL8192F)))
+			/*dig_max shouldn't be too high because of adaptivity*/
+				dig_t->dm_dig_max =
+					MIN_2((adapt->th_l2h + 40),
+					      DIG_MAX_PERFORMANCE_MODE);
+			else
+				dig_t->dm_dig_max = DIG_MAX_PERFORMANCE_MODE;
+
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_PERFORMANCE_MODE;
 		}
 
-		if (p_dm->support_ic_type &
-			(ODM_RTL8814A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8822B))
-			p_dig_t->dm_dig_min = 0x1c;
-		else if (p_dm->support_ic_type & ODM_RTL8197F)
-			p_dig_t->dm_dig_min = 0x1e;		/*For HW setting*/
+		if (dm->support_ic_type &
+		    (ODM_RTL8814A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8822B))
+			dig_t->dm_dig_min = 0x1c;
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			dig_t->dm_dig_min = 0x1e; /*@For HW setting*/
 		else
-			p_dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
+			dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
 	}
 
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("Abs-bound{Max, Min}={0x%x, 0x%x}, Max_of_min =  0x%x\n",
-		p_dig_t->dm_dig_max,
-		p_dig_t->dm_dig_min,
-		p_dig_t->dig_max_of_min));
-
+	PHYDM_DBG(dm, DBG_DIG, "Abs{Max, Min}={0x%x, 0x%x}, Max_of_min=0x%x\n",
+		  dig_t->dm_dig_max, dig_t->dm_dig_min, dig_t->dig_max_of_min);
 }
 
-void
-phydm_dig_dym_boundary_decision(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	is_performance
-)
+void phydm_dig_dym_boundary_decision(struct dm_struct *dm)
 {
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+#ifdef CFG_DIG_DAMPING_CHK
+	struct phydm_dig_recorder_strcut *dig_rc = &dig_t->dig_recorder_t;
+#endif
 	u8 offset = 15, tmp_max = 0;
+	u8 max_of_rssi_min = 0;
 
-	PHYDM_DBG(p_dm, DBG_DIG,
-			("Offset=((%d))\n", offset));
+	PHYDM_DBG(dm, DBG_DIG, "%s ======>\n", __func__);
 
-	/* DIG lower bound */
-	if (p_dm->rssi_min > p_dig_t->dig_max_of_min)
-		p_dig_t->rx_gain_range_min = p_dig_t->dig_max_of_min;
-	else if (p_dm->rssi_min < p_dig_t->dm_dig_min)
-		p_dig_t->rx_gain_range_min = p_dig_t->dm_dig_min;
-	else
-		p_dig_t->rx_gain_range_min = p_dm->rssi_min;
+	if (!dm->is_linked) {
+		/*@if no link, always stay at lower bound*/
+		dig_t->rx_gain_range_max = dig_t->dig_max_of_min;
+		dig_t->rx_gain_range_min = dig_t->dm_dig_min;
+
+		PHYDM_DBG(dm, DBG_DIG, "No-Link, Dyn{Max, Min}={0x%x, 0x%x}\n",
+			  dig_t->rx_gain_range_max, dig_t->rx_gain_range_min);
+		return;
+	}
 
-	/* DIG upper bound */
-	tmp_max = p_dig_t->rx_gain_range_min + offset;
+	PHYDM_DBG(dm, DBG_DIG, "rssi_min=%d, ofst=%d\n", dm->rssi_min, offset);
 
-	if (tmp_max > p_dig_t->dm_dig_max)
-		p_dig_t->rx_gain_range_max = p_dig_t->dm_dig_max;
+	/* @DIG lower bound */
+	if (dm->rssi_min > dig_t->dig_max_of_min)
+		dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+	else if (dm->rssi_min < dig_t->dm_dig_min)
+		dig_t->rx_gain_range_min = dig_t->dm_dig_min;
 	else
-		p_dig_t->rx_gain_range_max = tmp_max;
-
-	/* 1 Force Lower Bound for AntDiv */
-	if (!p_dm->is_one_entry_only) {
-		if ((p_dm->support_ic_type & ODM_ANTDIV_SUPPORT) && (p_dm->support_ability & ODM_BB_ANT_DIV)) {
-			if (p_dm->ant_div_type == CG_TRX_HW_ANTDIV || p_dm->ant_div_type == CG_TRX_SMART_ANTDIV) {
-				if (p_dig_t->ant_div_rssi_max > p_dig_t->dig_max_of_min)
-					p_dig_t->rx_gain_range_min = p_dig_t->dig_max_of_min;
-				else
-					p_dig_t->rx_gain_range_min = (u8)p_dig_t->ant_div_rssi_max;
-				
-				PHYDM_DBG(p_dm, DBG_DIG,
-					("AntDiv: Force Dyn-Min = 0x%x, RSSI_max = 0x%x\n",
-					p_dig_t->rx_gain_range_min, p_dig_t->ant_div_rssi_max));
-			}
-		}
+		dig_t->rx_gain_range_min = dm->rssi_min;
+
+#ifdef CFG_DIG_DAMPING_CHK
+	/*@Limit Dyn min by damping*/
+	if (dig_t->dig_dl_en &&
+	    dig_rc->damping_limit_en &&
+	    dig_t->rx_gain_range_min < dig_rc->damping_limit_val) {
+		PHYDM_DBG(dm, DBG_DIG,
+			  "[Limit by Damping] Dig_dyn_min=0x%x -> 0x%x\n",
+			  dig_t->rx_gain_range_min, dig_rc->damping_limit_val);
+
+		dig_t->rx_gain_range_min = dig_rc->damping_limit_val;
 	}
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("Dym-bound{Max, Min}={0x%x, 0x%x}\n",
-		p_dig_t->rx_gain_range_max, p_dig_t->rx_gain_range_min));
-}
+#endif
 
-void
-phydm_dig_abnormal_case(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8	current_igi,
-	boolean	is_performance,
-	boolean	is_dfs_band
-)
-{
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	boolean	first_connect = false, first_dis_connect = false;
+	/* @DIG upper bound */
+	tmp_max = dig_t->rx_gain_range_min + offset;
+	if (dig_t->rx_gain_range_min != dm->rssi_min) {
+		max_of_rssi_min = dm->rssi_min + offset;
+		if (tmp_max > max_of_rssi_min)
+			tmp_max = max_of_rssi_min;
+	}
 
-	first_connect = (p_dm->is_linked) && (p_dig_t->is_media_connect == false);
-	first_dis_connect = (!p_dm->is_linked) && (p_dig_t->is_media_connect == true);
+	if (tmp_max > dig_t->dm_dig_max)
+		dig_t->rx_gain_range_max = dig_t->dm_dig_max;
+	else if (tmp_max < dig_t->dm_dig_min)
+		dig_t->rx_gain_range_max = dig_t->dm_dig_min;
+	else
+		dig_t->rx_gain_range_max = tmp_max;
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	/* @1 Force Lower Bound for AntDiv */
+	if (!dm->is_one_entry_only &&
+	    (dm->support_ability & ODM_BB_ANT_DIV) &&
+	    (dm->ant_div_type == CG_TRX_HW_ANTDIV ||
+	     dm->ant_div_type == CG_TRX_SMART_ANTDIV)) {
+		if (dig_t->ant_div_rssi_max > dig_t->dig_max_of_min)
+			dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+		else
+			dig_t->rx_gain_range_min = (u8)dig_t->ant_div_rssi_max;
 
-	/* Modify DIG lower bound, deal with abnormal case */
-	if (!p_dm->is_linked && is_dfs_band && is_performance) {
-		p_dig_t->rx_gain_range_max = DIG_MAX_DFS;
-		PHYDM_DBG(p_dm, DBG_DIG,
-			("DFS band: Force max to 0x%x before link\n", p_dig_t->rx_gain_range_max));
+		PHYDM_DBG(dm, DBG_DIG, "Force Dyn-Min=0x%x, RSSI_max=0x%x\n",
+			  dig_t->rx_gain_range_min, dig_t->ant_div_rssi_max);
 	}
+	#endif
 
-	if (is_dfs_band)
-		p_dig_t->rx_gain_range_min = p_dig_t->dm_dig_min;
+	PHYDM_DBG(dm, DBG_DIG, "Dyn{Max, Min}={0x%x, 0x%x}\n",
+		  dig_t->rx_gain_range_max, dig_t->rx_gain_range_min);
+}
 
-	/* Abnormal lower bound case */
-	if (p_dig_t->rx_gain_range_min > p_dig_t->rx_gain_range_max)
-		p_dig_t->rx_gain_range_min = p_dig_t->rx_gain_range_max;
+void phydm_dig_abnormal_case(struct dm_struct *dm)
+{
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
 
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("Abnoraml checked {Max, Min}={0x%x, 0x%x}\n",
-		p_dig_t->rx_gain_range_max, p_dig_t->rx_gain_range_min));
+	/* @Abnormal lower bound case */
+	if (dig_t->rx_gain_range_min > dig_t->rx_gain_range_max)
+		dig_t->rx_gain_range_min = dig_t->rx_gain_range_max;
 
+	PHYDM_DBG(dm, DBG_DIG, "Abnoraml checked {Max, Min}={0x%x, 0x%x}\n",
+		  dig_t->rx_gain_range_max, dig_t->rx_gain_range_min);
 }
 
-u8
-phydm_dig_current_igi_by_fa_th(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			current_igi,
-	u32			false_alm_cnt,
-	u8			*step_size
-)
+u8 phydm_new_igi_by_fa(struct dm_struct *dm, u8 igi, u32 fa_cnt, u8 *step_size)
 {
-	boolean	dig_go_up_check = true;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	
-	dig_go_up_check = phydm_dig_go_up_check(p_dm);
+	boolean dig_go_up_check = true;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
 
-	if ((false_alm_cnt > p_dig_t->fa_th[2]) && dig_go_up_check)
-		current_igi = current_igi + step_size[0];
-	else if ((false_alm_cnt > p_dig_t->fa_th[1]) && dig_go_up_check)
-		current_igi = current_igi + step_size[1];
-	else if (false_alm_cnt < p_dig_t->fa_th[0])
-		current_igi = current_igi - step_size[2];
+#if 0
+	/*@dig_go_up_check = phydm_dig_go_up_check(dm);*/
+#endif
 
-	return current_igi;
+	if (fa_cnt > dig_t->fa_th[2] && dig_go_up_check)
+		igi = igi + step_size[0];
+	else if ((fa_cnt > dig_t->fa_th[1]) && dig_go_up_check)
+		igi = igi + step_size[1];
+	else if (fa_cnt < dig_t->fa_th[0])
+		igi = igi - step_size[2];
 
+	return igi;
 }
 
-u8
-phydm_dig_igi_start_value(
-	struct PHY_DM_STRUCT		*p_dm,
-	boolean	is_performance,
-	u8		current_igi,
-	u32		false_alm_cnt,
-	boolean	is_dfs_band
-)
+u8 phydm_get_new_igi(struct dm_struct *dm, u8 igi, u32 fa_cnt,
+		     boolean is_dfs_band)
 {
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	u8		step_size[3] = {0};
-	boolean	first_connect = false, first_dis_connect = false;
-
-	first_connect = (p_dm->is_linked) && (p_dig_t->is_media_connect == false);
-	first_dis_connect = (!p_dm->is_linked) && (p_dig_t->is_media_connect == true);
-
-	if (p_dm->is_linked) {
-		if (p_dm->pre_rssi_min <= p_dm->rssi_min) {
-			step_size[0] = 2;
-			step_size[1] = 1;
-			step_size[2] = 2;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u8 step[3] = {0};
+	boolean first_connect = false, first_dis_connect = false;
+
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	if (dm->is_linked) {
+		if (dm->pre_rssi_min <= dm->rssi_min) {
+			PHYDM_DBG(dm, DBG_DIG, "pre_rssi_min <= rssi_min\n");
+			step[0] = 2;
+			step[1] = 1;
+			step[2] = 2;
 		} else {
-			step_size[0] = 4;
-			step_size[1] = 2;
-			step_size[2] = 2;
+			step[0] = 4;
+			step[1] = 2;
+			step[2] = 2;
 		}
-		p_dm->pre_rssi_min = p_dm->rssi_min;
 	} else {
-		step_size[0] = 2;
-		step_size[1] = 1;
-		step_size[2] = 2;
-	}
-	
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("step_size = {-%d,  +%d, +%d}\n", step_size[2], step_size[1], step_size[0]));
-
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("rssi_min = %d, pre_rssi_min = %d\n", p_dm->rssi_min, p_dm->pre_rssi_min));
-
-	if (p_dm->is_linked && is_performance) {
-		/* 2 After link */
-		PHYDM_DBG(p_dm, DBG_DIG, ("Adjust IGI after link\n"));
-
-		if (first_connect && is_performance) {
-
-			if (is_dfs_band) {
-				if (p_dm->rssi_min > DIG_MAX_DFS)
-					current_igi = DIG_MAX_DFS;
-				else
-					current_igi = p_dm->rssi_min;
-				PHYDM_DBG(p_dm, DBG_DIG,
-					("DFS band: one shot IGI to 0x%x most\n", p_dig_t->rx_gain_range_max));
-			} else
-				current_igi = p_dig_t->rx_gain_range_min;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-#if (RTL8812A_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8812)
-				odm_config_bb_with_header_file(p_dm, CONFIG_BB_AGC_TAB_DIFF);
-#endif
-#endif
-			PHYDM_DBG(p_dm, DBG_DIG,
-				("First connect case: IGI does on-shot to 0x%x\n", current_igi));
+		step[0] = 2;
+		step[1] = 1;
+		step[2] = 2;
+	}
+
+	PHYDM_DBG(dm, DBG_DIG, "step = {-%d, +%d, +%d}\n", step[2], step[1],
+		  step[0]);
+
+	if (first_connect) {
+		if (is_dfs_band) {
+			if (dm->rssi_min > DIG_MAX_DFS)
+				igi = DIG_MAX_DFS;
+			else
+				igi = dm->rssi_min;
+			PHYDM_DBG(dm, DBG_DIG, "DFS band:IgiMax=0x%x\n",
+				  dig_t->rx_gain_range_max);
 		} else {
+			igi = dig_t->rx_gain_range_min;
+		}
 
-			/* 4 Abnormal # beacon case */
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))		
-			if ((p_dm->phy_dbg_info.num_qry_beacon_pkt < 5) &&
-				(false_alm_cnt < DM_DIG_FA_TH1) && (p_dm->bsta_state)) {
-				if (p_dm->support_ic_type != ODM_RTL8723D) {
-					p_dig_t->rx_gain_range_min = 0x1c;
-					current_igi = p_dig_t->rx_gain_range_min;
-					PHYDM_DBG(p_dm, DBG_DIG,
-						("Abnormal #beacon (%d) case: IGI does one-shot to 0x%x\n",
-						p_dm->phy_dbg_info.num_qry_beacon_pkt, current_igi));
-				}
-			} else
-#endif
-				current_igi = phydm_dig_current_igi_by_fa_th(p_dm,
-						current_igi, false_alm_cnt, step_size);
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		#if (RTL8812A_SUPPORT)
+		if (dm->support_ic_type == ODM_RTL8812)
+			odm_config_bb_with_header_file(dm,
+						       CONFIG_BB_AGC_TAB_DIFF);
+		#endif
+		#endif
+		PHYDM_DBG(dm, DBG_DIG, "First connect: foce IGI=0x%x\n", igi);
+	} else if (dm->is_linked) {
+		PHYDM_DBG(dm, DBG_DIG, "Adjust IGI @ linked\n");
+		/* @4 Abnormal # beacon case */
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		if (dm->phy_dbg_info.num_qry_beacon_pkt < 5 &&
+		    fa_cnt < DM_DIG_FA_TH1 && dm->bsta_state &&
+		    dm->support_ic_type != ODM_RTL8723D) {
+			dig_t->rx_gain_range_min = 0x1c;
+			igi = dig_t->rx_gain_range_min;
+			PHYDM_DBG(dm, DBG_DIG, "Beacon_num=%d,force igi=0x%x\n",
+				  dm->phy_dbg_info.num_qry_beacon_pkt, igi);
+		} else {
+			igi = phydm_new_igi_by_fa(dm, igi, fa_cnt, step);
 		}
+		#else
+		igi = phydm_new_igi_by_fa(dm, igi, fa_cnt, step);
+		#endif
 	} else {
-		/* 2 Before link */
-		PHYDM_DBG(p_dm, DBG_DIG, ("Adjust IGI before link\n"));
+		/* @2 Before link */
+		PHYDM_DBG(dm, DBG_DIG, "Adjust IGI before link\n");
 
 		if (first_dis_connect) {
-			current_igi = p_dig_t->dm_dig_min;
-			PHYDM_DBG(p_dm, DBG_DIG, ("First disconnect case: IGI does on-shot to lower bound\n"));
+			igi = dig_t->dm_dig_min;
+			PHYDM_DBG(dm, DBG_DIG,
+				  "First disconnect:foce IGI to lower bound\n");
 		} else {
-			PHYDM_DBG(p_dm, DBG_DIG,
-				("Pre_IGI=((0x%x)), FA=((%d))\n", current_igi, false_alm_cnt));
+			PHYDM_DBG(dm, DBG_DIG, "Pre_IGI=((0x%x)), FA=((%d))\n",
+				  igi, fa_cnt);
 
-			current_igi = phydm_dig_current_igi_by_fa_th(p_dm,
-						current_igi, false_alm_cnt, step_size);
+			igi = phydm_new_igi_by_fa(dm, igi, fa_cnt, step);
 		}
 	}
 
-	return current_igi;
+	/*@Check IGI by dyn-upper/lower bound */
+	if (igi < dig_t->rx_gain_range_min)
+		igi = dig_t->rx_gain_range_min;
+
+	if (igi > dig_t->rx_gain_range_max)
+		igi = dig_t->rx_gain_range_max;
+
+	PHYDM_DBG(dm, DBG_DIG, "fa_cnt = %d, IGI: 0x%x -> 0x%x\n",
+		  fa_cnt, dig_t->cur_ig_value, igi);
+
+	return igi;
+}
+
+boolean phydm_dig_dfs_mode_en(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean dfs_mode_en = false;
 
+	/* @Modify lower bound for DFS band */
+	if (dm->is_dfs_band) {
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
+		dfs_mode_en = true;
+		#else
+		if (phydm_dfs_master_enabled(dm))
+			dfs_mode_en = true;
+		#endif
+		PHYDM_DBG(dm, DBG_DIG, "In DFS band\n");
+	}
+	return dfs_mode_en;
 }
 
-void
-phydm_dig(
-	void		*p_dm_void
-)
+void phydm_dig(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct phydm_fa_struct		*p_falm_cnt = &p_dm->false_alm_cnt;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-	struct phydm_fa_acc_struct *p_falm_cnt_acc = &p_dm->false_alm_cnt_acc;
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
 #endif
-	boolean		first_connect, first_dis_connect;
-	u8			current_igi = p_dig_t->cur_ig_value;
-	u32			false_alm_cnt= p_falm_cnt->cnt_all;
-	boolean		is_dfs_band = false, is_performance = true;
+	boolean first_connect, first_disconnect;
+	u8 igi = dig_t->cur_ig_value;
+	u8 new_igi = 0x20;
+	u32 fa_cnt = falm_cnt->cnt_all;
+	boolean dfs_mode_en = false;
 
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-	if (p_dm->original_dig_restore == 0) {
-		if (p_dig_t->cur_ig_value_tdma == 0)
-			p_dig_t->cur_ig_value_tdma = p_dig_t->cur_ig_value;
-		
-		current_igi = p_dig_t->cur_ig_value_tdma;
-		false_alm_cnt = p_falm_cnt_acc->cnt_all_1sec;
+	if (!(dm->original_dig_restore)) {
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+
+		igi = dig_t->cur_ig_value_tdma;
+		fa_cnt = falm_cnt_acc->cnt_all_1sec;
 	}
 #endif
 
-	if (odm_dig_abort(p_dm) == true)
+	if (phydm_dig_abort(dm)) {
+		dig_t->cur_ig_value = phydm_get_igi(dm, BB_PATH_A);
 		return;
-
-	PHYDM_DBG(p_dm, DBG_DIG, ("%s Start===>\n", __func__));
-
-	/* 1 Update status */
-	first_connect = (p_dm->is_linked) && (p_dig_t->is_media_connect == false);
-	first_dis_connect = (!p_dm->is_linked) && (p_dig_t->is_media_connect == true);
-
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("is_linked = %d, RSSI = %d, 1stConnect = %d, 1stDisconnect = %d\n",
-		p_dm->is_linked, p_dm->rssi_min, first_connect, first_dis_connect));
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_AP | ODM_CE))
-	/* Modify lower bound for DFS band */
-	if (p_dm->is_dfs_band) {
-		#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-		if (phydm_dfs_master_enabled(p_dm))
-		#endif
-			is_dfs_band = true;
-		
-		PHYDM_DBG(p_dm, DBG_DIG, ("In DFS band\n"));
 	}
-#endif
 
-	is_performance = phydm_dig_performance_mode_decision(p_dm);
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("DIG ((%s)) mode\n", (is_performance ? "Performance" : "Coverage")));
+	PHYDM_DBG(dm, DBG_DIG, "%s Start===>\n", __func__);
 
-	/* Boundary Decision */
-	phydm_dig_abs_boundary_decision(p_dm, is_performance, is_dfs_band);
+	/* @1 Update status */
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_disconnect = (!dm->is_linked) && dig_t->is_media_connect;
 
-	/*init dym boundary*/
-	p_dig_t->rx_gain_range_max = p_dig_t->dig_max_of_min;	/*if no link, always stay at lower bound*/
-	p_dig_t->rx_gain_range_min = p_dig_t->dm_dig_min;
+	PHYDM_DBG(dm, DBG_DIG,
+		  "is_linked=%d, RSSI=%d, 1stConnect=%d, 1stDisconnect=%d\n",
+		  dm->is_linked, dm->rssi_min, first_connect, first_disconnect);
 
-	/* Adjust boundary by RSSI */
-	if (p_dm->is_linked)
-		phydm_dig_dym_boundary_decision(p_dm, is_performance);
+	PHYDM_DBG(dm, DBG_DIG, "DIG ((%s)) mode\n",
+		  (*dm->bb_op_mode ? "Balance" : "Performance"));
 
-	/*Abnormal case check*/
-	phydm_dig_abnormal_case(p_dm, current_igi, is_performance, is_dfs_band);
+	/*@DFS mode enable check*/
+	dfs_mode_en = phydm_dig_dfs_mode_en(dm);
 
-	/* False alarm threshold decision */
-	odm_fa_threshold_check(p_dm, is_dfs_band, is_performance);
+#ifdef CFG_DIG_DAMPING_CHK
+	/*Record IGI History*/
+	phydm_dig_recorder(dm, first_connect, igi, fa_cnt);
 
-	/* 1 Adjust initial gain by false alarm */
-	current_igi = phydm_dig_igi_start_value(p_dm,
-		is_performance, current_igi, false_alm_cnt, is_dfs_band);
+	/*@DIG Damping Check*/
+	phydm_dig_damping_chk(dm);
+#endif
 
-	/* 1 Check initial gain by upper/lower bound */
-	if (current_igi < p_dig_t->rx_gain_range_min)
-		current_igi = p_dig_t->rx_gain_range_min;
+	/*@Absolute Boundary Decision */
+	phydm_dig_abs_boundary_decision(dm, dfs_mode_en);
 
-	if (current_igi > p_dig_t->rx_gain_range_max)
-		current_igi = p_dig_t->rx_gain_range_max;
+	/*@Dynamic Boundary Decision*/
+	phydm_dig_dym_boundary_decision(dm);
 
-	PHYDM_DBG(p_dm, DBG_DIG, ("New_IGI=((0x%x))\n", current_igi));
+	/*@Abnormal case check*/
+	phydm_dig_abnormal_case(dm);
 
-	/* 1 Update status */
-#ifdef PHYDM_TDMA_DIG_SUPPORT
-	if (p_dm->original_dig_restore == 0) {
+	/*@FA threshold decision */
+	phydm_fa_threshold_check(dm, dfs_mode_en);
 
-		p_dig_t->cur_ig_value_tdma = current_igi;
-		/*It is possible fa_acc_1sec_tsf >= */
-		/*1sec while tdma_dig_state == 0*/
-		if (p_dig_t->tdma_dig_state != 0)
-			odm_write_dig(p_dm, p_dig_t->cur_ig_value_tdma);
+	/*Select new IGI by FA */
+	new_igi = phydm_get_new_igi(dm, igi, fa_cnt, dfs_mode_en);
+
+	/* @1 Update status */
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	if (!(dm->original_dig_restore)) {
+		dig_t->cur_ig_value_tdma = new_igi;
+		/*@It is possible fa_acc_1sec_tsf >= */
+		/*@1sec while tdma_dig_state == 0*/
+		if (dig_t->tdma_dig_state != 0)
+			odm_write_dig(dm, dig_t->cur_ig_value_tdma);
 	} else
-#endif 
-		odm_write_dig(p_dm, current_igi);
+	#endif
+		odm_write_dig(dm, new_igi);
 
-	p_dig_t->is_media_connect = p_dm->is_linked;
-	
-	PHYDM_DBG(p_dm, DBG_DIG, ("DIG end\n"));
+	dig_t->is_media_connect = dm->is_linked;
 }
 
-void
-phydm_dig_lps_32k(
-	void		*p_dm_void
-)
+void phydm_dig_lps_32k(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	current_igi = p_dm->rssi_min;
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 current_igi = dm->rssi_min;
 
-	odm_write_dig(p_dm, current_igi);
+	odm_write_dig(dm, current_igi);
 }
 
-void
-phydm_dig_by_rssi_lps(
-	void		*p_dm_void
-)
+void phydm_dig_by_rssi_lps(void *dm_void)
 {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_struct	*p_falm_cnt;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_IOT))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt;
 
-	u8	rssi_lower = DIG_MIN_LPS; /* 0x1E or 0x1C */
-	u8	current_igi = p_dm->rssi_min;
+	u8 rssi_lower = DIG_MIN_LPS; /* @0x1E or 0x1C */
+	u8 current_igi = dm->rssi_min;
 
-	p_falm_cnt = &p_dm->false_alm_cnt;
-	if (odm_dig_abort(p_dm) == true)
+	falm_cnt = &dm->false_alm_cnt;
+	if (phydm_dig_abort(dm))
 		return;
 
 	current_igi = current_igi + RSSI_OFFSET_DIG_LPS;
-	PHYDM_DBG(p_dm, DBG_DIG, ("%s==>\n", __func__));
+	PHYDM_DBG(dm, DBG_DIG, "%s==>\n", __func__);
 
 	/* Using FW PS mode to make IGI */
-	/* Adjust by  FA in LPS MODE */
-	if (p_falm_cnt->cnt_all > DM_DIG_FA_TH2_LPS)
+	/* @Adjust by  FA in LPS MODE */
+	if (falm_cnt->cnt_all > DM_DIG_FA_TH2_LPS)
 		current_igi = current_igi + 4;
-	else if (p_falm_cnt->cnt_all > DM_DIG_FA_TH1_LPS)
+	else if (falm_cnt->cnt_all > DM_DIG_FA_TH1_LPS)
 		current_igi = current_igi + 2;
-	else if (p_falm_cnt->cnt_all < DM_DIG_FA_TH0_LPS)
+	else if (falm_cnt->cnt_all < DM_DIG_FA_TH0_LPS)
 		current_igi = current_igi - 2;
 
-
-	/* Lower bound checking */
+	/* @Lower bound checking */
 
 	/* RSSI Lower bound check */
-	if ((p_dm->rssi_min - 10) > DIG_MIN_LPS)
-		rssi_lower = (p_dm->rssi_min - 10);
+	if ((dm->rssi_min - 10) > DIG_MIN_LPS)
+		rssi_lower = (dm->rssi_min - 10);
 	else
 		rssi_lower = DIG_MIN_LPS;
 
@@ -935,962 +1194,1666 @@ phydm_dig_by_rssi_lps(
 	else if (current_igi < rssi_lower)
 		current_igi = rssi_lower;
 
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("%s p_falm_cnt->cnt_all = %d\n", __func__,
-		p_falm_cnt->cnt_all));
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("%s p_dm->rssi_min = %d\n", __func__,
-		p_dm->rssi_min));
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("%s current_igi = 0x%x\n", __func__,
-		current_igi));
-
-	/* odm_write_dig(p_dm, p_dig_t->cur_ig_value); */
-	odm_write_dig(p_dm, current_igi);
+	PHYDM_DBG(dm, DBG_DIG, "fa_cnt_all=%d, rssi_min=%d, curr_igi=0x%x\n",
+		  falm_cnt->cnt_all, dm->rssi_min, current_igi);
+	odm_write_dig(dm, current_igi);
 #endif
 }
 
-/* 3============================================================
+/* @3============================================================
  * 3 FASLE ALARM CHECK
- * 3============================================================ */
-void
-phydm_false_alarm_counter_reg_reset(
-	void					*p_dm_void
-)
+ * 3============================================================
+ */
+void phydm_false_alarm_counter_reg_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct phydm_fa_struct *p_falm_cnt = &p_dm->false_alm_cnt;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-	struct phydm_fa_acc_struct *p_falm_cnt_acc = &p_dm->false_alm_cnt_acc;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
 #endif
-	u32	false_alm_cnt;
+	u32 false_alm_cnt = 0;
 
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-	if (p_dm->original_dig_restore == 0) {
-
-		if (p_dig_t->cur_ig_value_tdma == 0)
-			p_dig_t->cur_ig_value_tdma = p_dig_t->cur_ig_value;
+	if (!(dm->original_dig_restore)) {
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
 
-		false_alm_cnt = p_falm_cnt_acc->cnt_all_1sec;
-	} else 
+		false_alm_cnt = falm_cnt_acc->cnt_all_1sec;
+	} else
 #endif
 	{
-		false_alm_cnt = p_falm_cnt->cnt_all;
-	}
-
-#if (ODM_IC_11N_SERIES_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		/*reset false alarm counter registers*/
-		odm_set_bb_reg(p_dm, 0xC0C, BIT(31), 1);
-		odm_set_bb_reg(p_dm, 0xC0C, BIT(31), 0);
-		odm_set_bb_reg(p_dm, 0xD00, BIT(27), 1);
-		odm_set_bb_reg(p_dm, 0xD00, BIT(27), 0);
-
-		/*update ofdm counter*/
-		/*update page C counter*/
-		odm_set_bb_reg(p_dm, 0xD00, BIT(31), 0);
-		/*update page D counter*/
-		odm_set_bb_reg(p_dm, 0xD00, BIT(31), 0);
-
-		/*reset CCK CCA counter*/
-		odm_set_bb_reg(p_dm, 0xA2C, BIT(13) | BIT(12), 0);
-		odm_set_bb_reg(p_dm, 0xA2C, BIT(13) | BIT(12), 2);
-
-		/*reset CCK FA counter*/
-		odm_set_bb_reg(p_dm, 0xA2C, BIT(15) | BIT(14), 0);
-		odm_set_bb_reg(p_dm, 0xA2C, BIT(15) | BIT(14), 2);
-
-		/*reset CRC32 counter*/
-		odm_set_bb_reg(p_dm, 0xF14, BIT(16), 1);
-		odm_set_bb_reg(p_dm, 0xF14, BIT(16), 0);
-	}
-#endif	/* #if (ODM_IC_11N_SERIES_SUPPORT == 1) */
-
-#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
-		if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-	#if (RTL8881A_SUPPORT == 1)
-			/* Reset FA counter by enable/disable OFDM */
-			if (false_alm_cnt->cnt_ofdm_fail_pre >= 0x7fff) {
-				/* reset OFDM */
-				odm_set_bb_reg(p_dm, 0x808, BIT(29), 0);
-				odm_set_bb_reg(p_dm, 0x808, BIT(29), 1);
-				false_alm_cnt->cnt_ofdm_fail_pre = 0;
-				PHYDM_DBG(p_dm, DBG_FA_CNT, ("Reset FA_cnt\n"));
-			}
-	#endif	/* #if (RTL8881A_SUPPORT == 1) */
-			/* reset OFDM FA countner */
-			odm_set_bb_reg(p_dm, 0x9A4, BIT(17), 1);
-			odm_set_bb_reg(p_dm, 0x9A4, BIT(17), 0);
-
-			/* reset CCK FA counter */
-			odm_set_bb_reg(p_dm, 0xA2C, BIT(15), 0);
-			odm_set_bb_reg(p_dm, 0xA2C, BIT(15), 1);
-
-			/* reset CCA counter */
-			odm_set_bb_reg(p_dm, 0xB58, BIT(0), 1);
-			odm_set_bb_reg(p_dm, 0xB58, BIT(0), 0);
+		false_alm_cnt = falm_cnt->cnt_all;
+	}
+
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		/* @reset CCK FA counter */
+		odm_set_bb_reg(dm, R_0x1a2c, BIT(15) | BIT(14), 0);
+		odm_set_bb_reg(dm, R_0x1a2c, BIT(15) | BIT(14), 2);
+
+		/* @reset CCK CCA counter */
+		odm_set_bb_reg(dm, R_0x1a2c, BIT(13) | BIT(12), 0);
+		odm_set_bb_reg(dm, R_0x1a2c, BIT(13) | BIT(12), 2);
+
+		/* @Disable common rx clk gating => WLANBB-1106*/
+		odm_set_bb_reg(dm, R_0x1d2c, BIT(31), 0);
+		/* @reset OFDM CCA counter, OFDM FA counter*/
+		phydm_reset_bb_hw_cnt(dm);
+		/* @Enable common rx clk gating => WLANBB-1106*/
+		odm_set_bb_reg(dm, R_0x1d2c, BIT(31), 1);
+	}
+#endif
+#if (ODM_IC_11N_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/* @reset false alarm counter registers*/
+		odm_set_bb_reg(dm, R_0xc0c, BIT(31), 1);
+		odm_set_bb_reg(dm, R_0xc0c, BIT(31), 0);
+		odm_set_bb_reg(dm, R_0xd00, BIT(27), 1);
+		odm_set_bb_reg(dm, R_0xd00, BIT(27), 0);
+
+		/* @update ofdm counter*/
+		/* @update page C counter*/
+		odm_set_bb_reg(dm, R_0xc00, BIT(31), 0);
+		/* @update page D counter*/
+		odm_set_bb_reg(dm, R_0xd00, BIT(31), 0);
+
+		/* @reset CCK CCA counter*/
+		odm_set_bb_reg(dm, R_0xa2c, BIT(13) | BIT(12), 0);
+		odm_set_bb_reg(dm, R_0xa2c, BIT(13) | BIT(12), 2);
+
+		/* @reset CCK FA counter*/
+		odm_set_bb_reg(dm, R_0xa2c, BIT(15) | BIT(14), 0);
+		odm_set_bb_reg(dm, R_0xa2c, BIT(15) | BIT(14), 2);
+
+		/* @reset CRC32 counter*/
+		odm_set_bb_reg(dm, R_0xf14, BIT(16), 1);
+		odm_set_bb_reg(dm, R_0xf14, BIT(16), 0);
+	}
+#endif /* @#if (ODM_IC_11N_SERIES_SUPPORT) */
+
+#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		#if (RTL8881A_SUPPORT)
+		/* @Reset FA counter by enable/disable OFDM */
+		if ((dm->support_ic_type == ODM_RTL8881A) &&
+		    false_alm_cnt->cnt_ofdm_fail_pre >= 0x7fff) {
+			/* reset OFDM */
+			odm_set_bb_reg(dm, R_0x808, BIT(29), 0);
+			odm_set_bb_reg(dm, R_0x808, BIT(29), 1);
+			false_alm_cnt->cnt_ofdm_fail_pre = 0;
+			PHYDM_DBG(dm, DBG_FA_CNT, "Reset FA_cnt\n");
 		}
-#endif	/* #if (ODM_IC_11AC_SERIES_SUPPORT == 1) */
-}
+		#endif /* @#if (RTL8881A_SUPPORT) */
 
-void
-phydm_false_alarm_counter_reg_hold(
-	void					*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+		/* @reset OFDM FA countner */
+		odm_set_bb_reg(dm, R_0x9a4, BIT(17), 1);
+		odm_set_bb_reg(dm, R_0x9a4, BIT(17), 0);
 
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		/*hold ofdm counter*/
-		/*hold page C counter*/
-		odm_set_bb_reg(p_dm, 0xC00, BIT(31), 1);
-		/*hold page D counter*/
-		odm_set_bb_reg(p_dm, 0xD00, BIT(31), 1);
+		/* @reset CCK FA counter */
+		odm_set_bb_reg(dm, R_0xa2c, BIT(15), 0);
+		odm_set_bb_reg(dm, R_0xa2c, BIT(15), 1);
 
-		//hold cck counter
-		odm_set_bb_reg(p_dm, 0xA2C, BIT(12), 1);
-		odm_set_bb_reg(p_dm, 0xA2C, BIT(14), 1);
+		/* @reset CCA counter */
+		phydm_reset_bb_hw_cnt(dm);
 	}
+#endif /* @#if (ODM_IC_11AC_SERIES_SUPPORT) */
 }
 
-void
-odm_false_alarm_counter_statistics(
-	void		*p_dm_void
-)
+void phydm_false_alarm_counter_reg_hold(void *dm_void)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_struct	*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(p_dm, PHYDM_FALSEALMCNT);
-	struct phydm_adaptivity_struct	*adaptivity = (struct phydm_adaptivity_struct *)phydm_get_structure(p_dm, PHYDM_ADAPTIVITY);
-	u32						ret_value;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		/* @hold cck counter */
+		odm_set_bb_reg(dm, R_0x1a2c, BIT(12), 1);
+		odm_set_bb_reg(dm, R_0x1a2c, BIT(14), 1);
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		/*@hold ofdm counter*/
+		/*@hold page C counter*/
+		odm_set_bb_reg(dm, R_0xc00, BIT(31), 1);
+		/*@hold page D counter*/
+		odm_set_bb_reg(dm, R_0xd00, BIT(31), 1);
+
+		/*@hold cck counter*/
+		odm_set_bb_reg(dm, R_0xa2c, BIT(12), 1);
+		odm_set_bb_reg(dm, R_0xa2c, BIT(14), 1);
+	}
+}
 
-	if (!(p_dm->support_ability & ODM_BB_FA_CNT))
-		return;
+#if (ODM_IC_11N_SERIES_SUPPORT)
+void phydm_fa_cnt_statistics_n(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+	u32 reg = 0;
 
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("FA_Counter()======>\n"));
+	if (!(dm->support_ic_type & ODM_IC_11N_SERIES))
+		return;
 
-#if (ODM_IC_11N_SERIES_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
+	/* @hold ofdm & cck counter */
+	phydm_false_alarm_counter_reg_hold(dm);
+
+	reg = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE1_11N, MASKDWORD);
+	fa_t->cnt_fast_fsync = (reg & 0xffff);
+	fa_t->cnt_sb_search_fail = ((reg & 0xffff0000) >> 16);
+
+	reg = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE2_11N, MASKDWORD);
+	fa_t->cnt_ofdm_cca = (reg & 0xffff);
+	fa_t->cnt_parity_fail = ((reg & 0xffff0000) >> 16);
+
+	reg = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE3_11N, MASKDWORD);
+	fa_t->cnt_rate_illegal = (reg & 0xffff);
+	fa_t->cnt_crc8_fail = ((reg & 0xffff0000) >> 16);
+
+	reg = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE4_11N, MASKDWORD);
+	fa_t->cnt_mcs_fail = (reg & 0xffff);
+
+	fa_t->cnt_ofdm_fail =
+		fa_t->cnt_parity_fail + fa_t->cnt_rate_illegal +
+		fa_t->cnt_crc8_fail + fa_t->cnt_mcs_fail +
+		fa_t->cnt_fast_fsync + fa_t->cnt_sb_search_fail;
+
+	/* read CCK CRC32 counter */
+	fa_t->cnt_cck_crc32_error = odm_get_bb_reg(dm, R_0xf84, MASKDWORD);
+	fa_t->cnt_cck_crc32_ok = odm_get_bb_reg(dm, R_0xf88, MASKDWORD);
+
+	/* read OFDM CRC32 counter */
+	reg = odm_get_bb_reg(dm, ODM_REG_OFDM_CRC32_CNT_11N, MASKDWORD);
+	fa_t->cnt_ofdm_crc32_error = (reg & 0xffff0000) >> 16;
+	fa_t->cnt_ofdm_crc32_ok = reg & 0xffff;
+
+	/* read HT CRC32 counter */
+	reg = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11N, MASKDWORD);
+	fa_t->cnt_ht_crc32_error = (reg & 0xffff0000) >> 16;
+	fa_t->cnt_ht_crc32_ok = reg & 0xffff;
+
+	/* read VHT CRC32 counter */
+	fa_t->cnt_vht_crc32_error = 0;
+	fa_t->cnt_vht_crc32_ok = 0;
+
+	#if (RTL8723D_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		/* read HT CRC32 agg counter */
+		reg = odm_get_bb_reg(dm, R_0xfb8, MASKDWORD);
+		fa_t->cnt_ht_crc32_error_agg = (reg & 0xffff0000) >> 16;
+		fa_t->cnt_ht_crc32_ok_agg = reg & 0xffff;
+	}
+	#endif
 
-		/* hold ofdm & cck counter */
-		phydm_false_alarm_counter_reg_hold(p_dm);
+	#if (RTL8188E_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		reg = odm_get_bb_reg(dm, ODM_REG_SC_CNT_11N, MASKDWORD);
+		fa_t->cnt_bw_lsc = (reg & 0xffff);
+		fa_t->cnt_bw_usc = ((reg & 0xffff0000) >> 16);
+	}
+	#endif
 
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_OFDM_FA_TYPE1_11N, MASKDWORD);
-		false_alm_cnt->cnt_fast_fsync = (ret_value & 0xffff);
-		false_alm_cnt->cnt_sb_search_fail = ((ret_value & 0xffff0000) >> 16);
+	reg = odm_get_bb_reg(dm, ODM_REG_CCK_FA_LSB_11N, MASKBYTE0);
+	fa_t->cnt_cck_fail = reg;
 
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_OFDM_FA_TYPE2_11N, MASKDWORD);
-		false_alm_cnt->cnt_ofdm_cca = (ret_value & 0xffff);
-		false_alm_cnt->cnt_parity_fail = ((ret_value & 0xffff0000) >> 16);
+	reg = odm_get_bb_reg(dm, ODM_REG_CCK_FA_MSB_11N, MASKBYTE3);
+	fa_t->cnt_cck_fail += (reg & 0xff) << 8;
 
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_OFDM_FA_TYPE3_11N, MASKDWORD);
-		false_alm_cnt->cnt_rate_illegal = (ret_value & 0xffff);
-		false_alm_cnt->cnt_crc8_fail = ((ret_value & 0xffff0000) >> 16);
+	reg = odm_get_bb_reg(dm, ODM_REG_CCK_CCA_CNT_11N, MASKDWORD);
+	fa_t->cnt_cck_cca = ((reg & 0xFF) << 8) | ((reg & 0xFF00) >> 8);
 
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_OFDM_FA_TYPE4_11N, MASKDWORD);
-		false_alm_cnt->cnt_mcs_fail = (ret_value & 0xffff);
+	fa_t->cnt_all_pre = fa_t->cnt_all;
 
-		false_alm_cnt->cnt_ofdm_fail =
-			false_alm_cnt->cnt_parity_fail + false_alm_cnt->cnt_rate_illegal +
-			false_alm_cnt->cnt_crc8_fail + false_alm_cnt->cnt_mcs_fail +
-			false_alm_cnt->cnt_fast_fsync + false_alm_cnt->cnt_sb_search_fail;
+	fa_t->cnt_all = fa_t->cnt_fast_fsync +
+			fa_t->cnt_sb_search_fail +
+			fa_t->cnt_parity_fail +
+			fa_t->cnt_rate_illegal +
+			fa_t->cnt_crc8_fail +
+			fa_t->cnt_mcs_fail +
+			fa_t->cnt_cck_fail;
 
-		/* read CCK CRC32 counter */
-		false_alm_cnt->cnt_cck_crc32_error = odm_get_bb_reg(p_dm, ODM_REG_CCK_CRC32_ERROR_CNT_11N, MASKDWORD);
-		false_alm_cnt->cnt_cck_crc32_ok = odm_get_bb_reg(p_dm, ODM_REG_CCK_CRC32_OK_CNT_11N, MASKDWORD);
+	fa_t->cnt_cca_all = fa_t->cnt_ofdm_cca + fa_t->cnt_cck_cca;
 
-		/* read OFDM CRC32 counter */
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_OFDM_CRC32_CNT_11N, MASKDWORD);
-		false_alm_cnt->cnt_ofdm_crc32_error = (ret_value & 0xffff0000) >> 16;
-		false_alm_cnt->cnt_ofdm_crc32_ok = ret_value & 0xffff;
+	PHYDM_DBG(dm, DBG_FA_CNT,
+		  "[OFDM FA Detail] Parity_Fail=((%d)), Rate_Illegal=((%d)), CRC8_fail=((%d)), Mcs_fail=((%d)), Fast_Fsync=(( %d )), SBD_fail=((%d))\n",
+		  fa_t->cnt_parity_fail, fa_t->cnt_rate_illegal,
+		  fa_t->cnt_crc8_fail, fa_t->cnt_mcs_fail, fa_t->cnt_fast_fsync,
+		  fa_t->cnt_sb_search_fail);
+}
+#endif
 
-		/* read HT CRC32 counter */
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_HT_CRC32_CNT_11N, MASKDWORD);
-		false_alm_cnt->cnt_ht_crc32_error = (ret_value & 0xffff0000) >> 16;
-		false_alm_cnt->cnt_ht_crc32_ok = ret_value & 0xffff;
+#if (ODM_IC_11AC_SERIES_SUPPORT)
+void phydm_fa_cnt_statistics_ac(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+	u32 ret_value = 0;
+	u32 cck_enable = 0;
 
-		/* read VHT CRC32 counter */
-		false_alm_cnt->cnt_vht_crc32_error = 0;
-		false_alm_cnt->cnt_vht_crc32_ok = 0;
-		
-#if (RTL8723D_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8723D) {
-			/* read HT CRC32 agg counter */
-			ret_value = odm_get_bb_reg(p_dm, ODM_REG_HT_CRC32_CNT_11N_AGG, MASKDWORD);
-			false_alm_cnt->cnt_ht_crc32_error_agg = (ret_value & 0xffff0000) >> 16;
-			false_alm_cnt->cnt_ht_crc32_ok_agg= ret_value & 0xffff;
-		}
-#endif
-		
-#if (RTL8188E_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8188E) {
-			ret_value = odm_get_bb_reg(p_dm, ODM_REG_SC_CNT_11N, MASKDWORD);
-			false_alm_cnt->cnt_bw_lsc = (ret_value & 0xffff);
-			false_alm_cnt->cnt_bw_usc = ((ret_value & 0xffff0000) >> 16);
-		}
-#endif
+	if (!(dm->support_ic_type & ODM_IC_11AC_SERIES))
+		return;
 
-		{
-			ret_value = odm_get_bb_reg(p_dm, ODM_REG_CCK_FA_LSB_11N, MASKBYTE0);
-			false_alm_cnt->cnt_cck_fail = ret_value;
+	ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE1_11AC, MASKDWORD);
+	fa_t->cnt_fast_fsync = ((ret_value & 0xffff0000) >> 16);
 
-			ret_value = odm_get_bb_reg(p_dm, ODM_REG_CCK_FA_MSB_11N, MASKBYTE3);
-			false_alm_cnt->cnt_cck_fail += (ret_value & 0xff) << 8;
+	ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE2_11AC, MASKDWORD);
+	fa_t->cnt_sb_search_fail = (ret_value & 0xffff);
 
-			ret_value = odm_get_bb_reg(p_dm, ODM_REG_CCK_CCA_CNT_11N, MASKDWORD);
-			false_alm_cnt->cnt_cck_cca = ((ret_value & 0xFF) << 8) | ((ret_value & 0xFF00) >> 8);
-		}
+	ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE3_11AC, MASKDWORD);
+	fa_t->cnt_parity_fail = (ret_value & 0xffff);
+	fa_t->cnt_rate_illegal = ((ret_value & 0xffff0000) >> 16);
 
-		false_alm_cnt->cnt_all_pre = false_alm_cnt->cnt_all;
+	ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE4_11AC, MASKDWORD);
+	fa_t->cnt_crc8_fail = (ret_value & 0xffff);
+	fa_t->cnt_mcs_fail = ((ret_value & 0xffff0000) >> 16);
 
-		false_alm_cnt->cnt_all = (false_alm_cnt->cnt_fast_fsync +
-					  false_alm_cnt->cnt_sb_search_fail +
-					  false_alm_cnt->cnt_parity_fail +
-					  false_alm_cnt->cnt_rate_illegal +
-					  false_alm_cnt->cnt_crc8_fail +
-					  false_alm_cnt->cnt_mcs_fail +
-					  false_alm_cnt->cnt_cck_fail);
+	ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE5_11AC, MASKDWORD);
+	fa_t->cnt_crc8_fail_vht = (ret_value & 0xffff) +
+				  (ret_value & 0xffff0000 >> 16);
 
-		false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_ofdm_cca + false_alm_cnt->cnt_cck_cca;
+	ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_FA_TYPE6_11AC, MASKDWORD);
+	fa_t->cnt_mcs_fail_vht = (ret_value & 0xffff);
 
-		PHYDM_DBG(p_dm, DBG_FA_CNT,
-			("[OFDM FA Detail] Parity_Fail = (( %d )), Rate_Illegal = (( %d )), CRC8_fail = (( %d )), Mcs_fail = (( %d )), Fast_Fsync = (( %d )), SB_Search_fail = (( %d ))\n",
-			false_alm_cnt->cnt_parity_fail, false_alm_cnt->cnt_rate_illegal, false_alm_cnt->cnt_crc8_fail, false_alm_cnt->cnt_mcs_fail, false_alm_cnt->cnt_fast_fsync, false_alm_cnt->cnt_sb_search_fail));
-		
-	}
-#endif
+	/* read OFDM FA counter */
+	fa_t->cnt_ofdm_fail = odm_get_bb_reg(dm, R_0xf48, MASKLWORD);
 
-#if (ODM_IC_11AC_SERIES_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		u32 cck_enable;
+	/* Read CCK FA counter */
+	fa_t->cnt_cck_fail = odm_get_bb_reg(dm, ODM_REG_CCK_FA_11AC, MASKLWORD);
 
-		/* read OFDM FA counter */
-		false_alm_cnt->cnt_ofdm_fail = odm_get_bb_reg(p_dm, ODM_REG_OFDM_FA_11AC, MASKLWORD);
+	/* read CCK/OFDM CCA counter */
+	ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CCA_CNT_11AC, MASKDWORD);
+	fa_t->cnt_ofdm_cca = (ret_value & 0xffff0000) >> 16;
+	fa_t->cnt_cck_cca = ret_value & 0xffff;
 
-		/* Read CCK FA counter */
-		false_alm_cnt->cnt_cck_fail = odm_get_bb_reg(p_dm, ODM_REG_CCK_FA_11AC, MASKLWORD);
+	/* read CCK CRC32 counter */
+	ret_value = odm_get_bb_reg(dm, ODM_REG_CCK_CRC32_CNT_11AC, MASKDWORD);
+	fa_t->cnt_cck_crc32_error = (ret_value & 0xffff0000) >> 16;
+	fa_t->cnt_cck_crc32_ok = ret_value & 0xffff;
 
-		/* read CCK/OFDM CCA counter */
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_CCK_CCA_CNT_11AC, MASKDWORD);
-		false_alm_cnt->cnt_ofdm_cca = (ret_value & 0xffff0000) >> 16;
-		false_alm_cnt->cnt_cck_cca = ret_value & 0xffff;
+	/* read OFDM CRC32 counter */
+	ret_value = odm_get_bb_reg(dm, ODM_REG_OFDM_CRC32_CNT_11AC, MASKDWORD);
+	fa_t->cnt_ofdm_crc32_error = (ret_value & 0xffff0000) >> 16;
+	fa_t->cnt_ofdm_crc32_ok = ret_value & 0xffff;
 
-		/* read CCK CRC32 counter */
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_CCK_CRC32_CNT_11AC, MASKDWORD);
-		false_alm_cnt->cnt_cck_crc32_error = (ret_value & 0xffff0000) >> 16;
-		false_alm_cnt->cnt_cck_crc32_ok = ret_value & 0xffff;
+	/* read HT CRC32 counter */
+	ret_value = odm_get_bb_reg(dm, ODM_REG_HT_CRC32_CNT_11AC, MASKDWORD);
+	fa_t->cnt_ht_crc32_error = (ret_value & 0xffff0000) >> 16;
+	fa_t->cnt_ht_crc32_ok = ret_value & 0xffff;
 
-		/* read OFDM CRC32 counter */
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_OFDM_CRC32_CNT_11AC, MASKDWORD);
-		false_alm_cnt->cnt_ofdm_crc32_error = (ret_value & 0xffff0000) >> 16;
-		false_alm_cnt->cnt_ofdm_crc32_ok = ret_value & 0xffff;
+	/* read VHT CRC32 counter */
+	ret_value = odm_get_bb_reg(dm, ODM_REG_VHT_CRC32_CNT_11AC, MASKDWORD);
+	fa_t->cnt_vht_crc32_error = (ret_value & 0xffff0000) >> 16;
+	fa_t->cnt_vht_crc32_ok = ret_value & 0xffff;
 
-		/* read HT CRC32 counter */
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_HT_CRC32_CNT_11AC, MASKDWORD);
-		false_alm_cnt->cnt_ht_crc32_error = (ret_value & 0xffff0000) >> 16;
-		false_alm_cnt->cnt_ht_crc32_ok = ret_value & 0xffff;
+	#if (RTL8881A_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8881A) {
+		u32 tmp = 0;
 
-		/* read VHT CRC32 counter */
-		ret_value = odm_get_bb_reg(p_dm, ODM_REG_VHT_CRC32_CNT_11AC, MASKDWORD);
-		false_alm_cnt->cnt_vht_crc32_error = (ret_value & 0xffff0000) >> 16;
-		false_alm_cnt->cnt_vht_crc32_ok = ret_value & 0xffff;
-
-#if (RTL8881A_SUPPORT == 1)
-		/* For 8881A */
-		if (p_dm->support_ic_type == ODM_RTL8881A) {
-			u32 cnt_ofdm_fail_temp = 0;
-
-			if (false_alm_cnt->cnt_ofdm_fail >= false_alm_cnt->cnt_ofdm_fail_pre) {
-				cnt_ofdm_fail_temp = false_alm_cnt->cnt_ofdm_fail_pre;
-				false_alm_cnt->cnt_ofdm_fail_pre = false_alm_cnt->cnt_ofdm_fail;
-				false_alm_cnt->cnt_ofdm_fail = false_alm_cnt->cnt_ofdm_fail - cnt_ofdm_fail_temp;
-			} else
-				false_alm_cnt->cnt_ofdm_fail_pre = false_alm_cnt->cnt_ofdm_fail;
-			PHYDM_DBG(p_dm, DBG_FA_CNT, ("odm_false_alarm_counter_statistics(): cnt_ofdm_fail=%d\n",	false_alm_cnt->cnt_ofdm_fail_pre));
-			PHYDM_DBG(p_dm, DBG_FA_CNT, ("odm_false_alarm_counter_statistics(): cnt_ofdm_fail_pre=%d\n",	cnt_ofdm_fail_temp));
-		}
-#endif
-		cck_enable =  odm_get_bb_reg(p_dm, ODM_REG_BB_RX_PATH_11AC, BIT(28));
-		if (cck_enable) { /* if(*p_dm->p_band_type == ODM_BAND_2_4G) */
-			false_alm_cnt->cnt_all = false_alm_cnt->cnt_ofdm_fail + false_alm_cnt->cnt_cck_fail;
-			false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_cck_cca + false_alm_cnt->cnt_ofdm_cca;
+		if (fa_t->cnt_ofdm_fail >= fa_t->cnt_ofdm_fail_pre) {
+			tmp = fa_t->cnt_ofdm_fail_pre;
+			fa_t->cnt_ofdm_fail_pre = fa_t->cnt_ofdm_fail;
+			fa_t->cnt_ofdm_fail = fa_t->cnt_ofdm_fail - tmp;
 		} else {
-			false_alm_cnt->cnt_all = false_alm_cnt->cnt_ofdm_fail;
-			false_alm_cnt->cnt_cca_all = false_alm_cnt->cnt_ofdm_cca;
+			fa_t->cnt_ofdm_fail_pre = fa_t->cnt_ofdm_fail;
 		}
+
+		PHYDM_DBG(dm, DBG_FA_CNT,
+			  "[8881]cnt_ofdm_fail{curr,pre}={%d,%d}\n",
+			  fa_t->cnt_ofdm_fail_pre, tmp);
 	}
-#endif
+	#endif
 
-	if (p_dm->support_ic_type != ODM_RTL8723D) {
-		if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_1, 0x0)) {/*set debug port to 0x0*/
-			false_alm_cnt->dbg_port0 = phydm_get_bb_dbg_port_value(p_dm);
-			phydm_release_bb_dbg_port(p_dm);
-		}
+	cck_enable = odm_get_bb_reg(dm, ODM_REG_BB_RX_PATH_11AC, BIT(28));
 
-		if (phydm_set_bb_dbg_port(p_dm, BB_DBGPORT_PRIORITY_1, adaptivity->adaptivity_dbg_port)) {
-			if (p_dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E))
-				false_alm_cnt->edcca_flag = (boolean)((phydm_get_bb_dbg_port_value(p_dm) & BIT(30)) >> 30);
-			else
-				false_alm_cnt->edcca_flag = (boolean)((phydm_get_bb_dbg_port_value(p_dm) & BIT(29)) >> 29);
-			phydm_release_bb_dbg_port(p_dm);
-		}
+	if (cck_enable) { /* @if(*dm->band_type == ODM_BAND_2_4G) */
+		fa_t->cnt_all = fa_t->cnt_ofdm_fail + fa_t->cnt_cck_fail;
+		fa_t->cnt_cca_all = fa_t->cnt_cck_cca + fa_t->cnt_ofdm_cca;
 	} else {
-		false_alm_cnt->edcca_flag = (boolean)(odm_get_bb_reg(p_dm, 0x9a0, BIT(29)));
+		fa_t->cnt_all = fa_t->cnt_ofdm_fail;
+		fa_t->cnt_cca_all = fa_t->cnt_ofdm_cca;
+	}
+}
+#endif
+
+void phydm_get_dbg_port_info(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
+	u32 dbg_port = dm->adaptivity.adaptivity_dbg_port;
+	u32 val = 0;
+
+	/*set debug port to 0x0*/
+	if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x0)) {
+		fa_t->dbg_port0 = phydm_get_bb_dbg_port_val(dm);
+		phydm_release_bb_dbg_port(dm);
+	}
+
+	if (dm->support_ic_type & ODM_RTL8723D) {
+		val = odm_get_bb_reg(dm, R_0x9a0, BIT(29));
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		val = odm_get_bb_reg(dm, R_0x2d38, BIT(24));
+	} else if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, dbg_port)) {
+		if (dm->support_ic_type & (ODM_RTL8723B | ODM_RTL8188E))
+			val = (phydm_get_bb_dbg_port_val(dm) & BIT(30)) >> 30;
+		else
+			val = (phydm_get_bb_dbg_port_val(dm) & BIT(29)) >> 29;
+		phydm_release_bb_dbg_port(dm);
 	}
 
+	fa_t->edcca_flag = (boolean)val;
 
-	phydm_false_alarm_counter_reg_reset(p_dm_void);
+	PHYDM_DBG(dm, DBG_FA_CNT, "FA_Cnt: Dbg port 0x0 = 0x%x, EDCCA = %d\n\n",
+		  fa_t->dbg_port0, fa_t->edcca_flag);
+}
+
+void phydm_false_alarm_counter_statistics(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *fa_t = &dm->false_alm_cnt;
 
-	false_alm_cnt->cnt_crc32_error_all = false_alm_cnt->cnt_vht_crc32_error + false_alm_cnt->cnt_ht_crc32_error + false_alm_cnt->cnt_ofdm_crc32_error + false_alm_cnt->cnt_cck_crc32_error;
-	false_alm_cnt->cnt_crc32_ok_all = false_alm_cnt->cnt_vht_crc32_ok + false_alm_cnt->cnt_ht_crc32_ok + false_alm_cnt->cnt_ofdm_crc32_ok + false_alm_cnt->cnt_cck_crc32_ok;
+	if (!(dm->support_ability & ODM_BB_FA_CNT))
+		return;
 
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
-		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all));
+	PHYDM_DBG(dm, DBG_FA_CNT, "%s======>\n", __func__);
 
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
-		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all));
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		phydm_fa_cnt_statistics_jgr3(dm);
+		#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		#if (ODM_IC_11N_SERIES_SUPPORT)
+		phydm_fa_cnt_statistics_n(dm);
+		#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		#if (ODM_IC_11AC_SERIES_SUPPORT)
+		phydm_fa_cnt_statistics_ac(dm);
+		#endif
+	}
 
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("[CCK]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_cck_crc32_error, false_alm_cnt->cnt_cck_crc32_ok));
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("[OFDM]CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_ofdm_crc32_error, false_alm_cnt->cnt_ofdm_crc32_ok));
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("[ HT ]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_ht_crc32_error, false_alm_cnt->cnt_ht_crc32_ok));
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("[VHT]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_vht_crc32_error, false_alm_cnt->cnt_vht_crc32_ok));
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("[VHT]  CRC32 {error, ok}= {%d, %d}\n", false_alm_cnt->cnt_crc32_error_all, false_alm_cnt->cnt_crc32_ok_all));
-	PHYDM_DBG(p_dm, DBG_FA_CNT, ("FA_Cnt: Dbg port 0x0 = 0x%x, EDCCA = %d\n\n", false_alm_cnt->dbg_port0, false_alm_cnt->edcca_flag));
+	phydm_get_dbg_port_info(dm);
+	phydm_false_alarm_counter_reg_reset(dm_void);
+
+	fa_t->time_fa_all = fa_t->cnt_fast_fsync * 12 +
+			    fa_t->cnt_sb_search_fail * 12 +
+			    fa_t->cnt_parity_fail * 28 +
+			    fa_t->cnt_rate_illegal * 28 +
+			    fa_t->cnt_crc8_fail * 36 +
+			    fa_t->cnt_crc8_fail_vht * 36 +
+			    fa_t->cnt_mcs_fail_vht * 36 +
+			    fa_t->cnt_mcs_fail * 32 +
+			    fa_t->cnt_cck_fail * 80;
+
+	fa_t->cnt_crc32_error_all = fa_t->cnt_vht_crc32_error +
+				    fa_t->cnt_ht_crc32_error +
+				    fa_t->cnt_ofdm_crc32_error +
+				    fa_t->cnt_cck_crc32_error;
+
+	fa_t->cnt_crc32_ok_all = fa_t->cnt_vht_crc32_ok +
+				 fa_t->cnt_ht_crc32_ok +
+				 fa_t->cnt_ofdm_crc32_ok +
+				 fa_t->cnt_cck_crc32_ok;
+
+	PHYDM_DBG(dm, DBG_FA_CNT,
+		  "[OFDM FA Detail-1] Parity=((%d)), Rate_Illegal=((%d)), HT_CRC8=((%d)), HT_MCS=((%d))\n",
+		  fa_t->cnt_parity_fail, fa_t->cnt_rate_illegal,
+		  fa_t->cnt_crc8_fail, fa_t->cnt_mcs_fail);
+	PHYDM_DBG(dm, DBG_FA_CNT,
+		  "[OFDM FA Detail-2] Fast_Fsync=((%d)), SBD=((%d)), VHT_CRC8=((%d)), VHT_MCS=((%d))\n",
+		  fa_t->cnt_fast_fsync, fa_t->cnt_sb_search_fail,
+		  fa_t->cnt_crc8_fail_vht, fa_t->cnt_mcs_fail_vht);
+	PHYDM_DBG(dm, DBG_FA_CNT,
+		  "[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		  fa_t->cnt_cck_cca, fa_t->cnt_ofdm_cca, fa_t->cnt_cca_all);
+	PHYDM_DBG(dm, DBG_FA_CNT,
+		  "[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+		  fa_t->cnt_cck_fail, fa_t->cnt_ofdm_fail, fa_t->cnt_all);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[CCK]  CRC32 {error, ok}= {%d, %d}\n",
+		  fa_t->cnt_cck_crc32_error, fa_t->cnt_cck_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[OFDM]CRC32 {error, ok}= {%d, %d}\n",
+		  fa_t->cnt_ofdm_crc32_error, fa_t->cnt_ofdm_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[ HT ]  CRC32 {error, ok}= {%d, %d}\n",
+		  fa_t->cnt_ht_crc32_error, fa_t->cnt_ht_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[VHT]  CRC32 {error, ok}= {%d, %d}\n",
+		  fa_t->cnt_vht_crc32_error, fa_t->cnt_vht_crc32_ok);
+	PHYDM_DBG(dm, DBG_FA_CNT, "[TOTAL]  CRC32 {error, ok}= {%d, %d}\n",
+		  fa_t->cnt_crc32_error_all, fa_t->cnt_crc32_ok_all);
 }
 
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-void
-phydm_set_tdma_dig_timer(
-	void		*p_dm_void
-	)
+void phydm_set_tdma_dig_timer(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	delta_time_us = p_dm->tdma_dig_timer_ms * 1000;
-	struct phydm_dig_struct	*p_dig_t;
-	u32	timeout;
-	u32	current_time_stamp, diff_time_stamp, regb0;
-	
-	p_dig_t = &p_dm->dm_dig_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 delta_time_us = dm->tdma_dig_timer_ms * 1000;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u32 timeout = 0;
+	u32 current_time_stamp, diff_time_stamp, regb0 = 0;
+
 	/*some IC has no FREERUN_CUNT register, like 92E*/
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		current_time_stamp = odm_get_bb_reg(p_dm, 0x568, bMaskDWord);
+	if (dm->support_ic_type & ODM_RTL8197F)
+		current_time_stamp = odm_get_bb_reg(dm, R_0x568, 0xffffffff);
 	else
 		return;
 
 	timeout = current_time_stamp + delta_time_us;
 
-	diff_time_stamp = current_time_stamp - p_dig_t->cur_timestamp;
-	p_dig_t->pre_timestamp = p_dig_t->cur_timestamp;
-	p_dig_t->cur_timestamp = current_time_stamp;
-
-	/*HIMR0, it shows HW interrupt mask*/
-	regb0 = odm_get_bb_reg(p_dm, 0xb0, bMaskDWord);
-
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("Set next tdma_dig_timer\n"));
-	PHYDM_DBG(p_dm, DBG_DIG,
-		("current_time_stamp=%d, delta_time_us=%d, timeout=%d, diff_time_stamp=%d, Reg0xb0 = 0x%x\n",
-		current_time_stamp,
-		delta_time_us,
-		timeout,
-		diff_time_stamp,
-		regb0));
-
-	if (p_dm->support_ic_type & ODM_RTL8197F)		/*REG_PS_TIMER2*/
-		odm_set_bb_reg(p_dm, 0x588, bMaskDWord, timeout);
+	diff_time_stamp = current_time_stamp - dig_t->cur_timestamp;
+	dig_t->pre_timestamp = dig_t->cur_timestamp;
+	dig_t->cur_timestamp = current_time_stamp;
+
+	/*@HIMR0, it shows HW interrupt mask*/
+	regb0 = odm_get_bb_reg(dm, R_0xb0, 0xffffffff);
+
+	PHYDM_DBG(dm, DBG_DIG, "Set next timer\n");
+	PHYDM_DBG(dm, DBG_DIG,
+		  "curr_time_stamp=%d, delta_time_us=%d\n",
+		  current_time_stamp, delta_time_us);
+	PHYDM_DBG(dm, DBG_DIG,
+		  "timeout=%d, diff_time_stamp=%d, Reg0xb0 = 0x%x\n",
+		  timeout, diff_time_stamp, regb0);
+
+	if (dm->support_ic_type & ODM_RTL8197F) /*REG_PS_TIMER2*/
+		odm_set_bb_reg(dm, R_0x588, 0xffffffff, timeout);
 	else {
-		PHYDM_DBG(p_dm, DBG_DIG,
-					("NOT 97F, TDMA-DIG timer does NOT start!\n"));
+		PHYDM_DBG(dm, DBG_DIG, "NOT 97F, NOT start\n");
 		return;
 	}
 }
 
-void
-phydm_tdma_dig_timer_check(
-	void		*p_dm_void
-	)
+void phydm_tdma_dig_timer_check(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t;
-
-	p_dig_t = &p_dm->dm_dig_table;
-	
-	PHYDM_DBG(p_dm, DBG_DIG,
-				("tdma_dig_cnt=%d, pre_tdma_dig_cnt=%d\n",
-				p_dig_t->tdma_dig_cnt,
-				p_dig_t->pre_tdma_dig_cnt));
-
-	if ((p_dig_t->tdma_dig_cnt == 0) ||
-		(p_dig_t->tdma_dig_cnt == p_dig_t->pre_tdma_dig_cnt)) {
-
-		if (p_dm->support_ability & ODM_BB_DIG) {
-			/*if interrupt mask info is got.*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	PHYDM_DBG(dm, DBG_DIG, "tdma_dig_cnt=%d, pre_tdma_dig_cnt=%d\n",
+		  dig_t->tdma_dig_cnt, dig_t->pre_tdma_dig_cnt);
+
+	if (dig_t->tdma_dig_cnt == 0 ||
+	    dig_t->tdma_dig_cnt == dig_t->pre_tdma_dig_cnt) {
+		if (dm->support_ability & ODM_BB_DIG) {
+#ifdef IS_USE_NEW_TDMA
+			if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B |
+			    ODM_RTL8812F | ODM_RTL8822B | ODM_RTL8192F |
+			    ODM_RTL8821C)) {
+				PHYDM_DBG(dm, DBG_DIG,
+					  "Check fail, Restart timer\n\n");
+				phydm_false_alarm_counter_reset(dm);
+				odm_set_timer(dm, &dm->tdma_dig_timer,
+					      dm->tdma_dig_timer_ms);
+			} else {
+				PHYDM_DBG(dm, DBG_DIG,
+					  "Not 98F/14B/12F/22B/92F/21C no SW timer\n");
+			}
+#else
+			/*@if interrupt mask info is got.*/
 			/*Reg0xb0 is no longer needed*/
-			/*regb0 = odm_get_bb_reg(p_dm, 0xb0, bMaskDWord);*/
-			PHYDM_DBG(p_dm, DBG_DIG,
-						("Check fail, IntMask[0]=0x%x, restart tdma_dig_timer !!!\n",
-						*p_dm->p_interrupt_mask));
-
-			phydm_tdma_dig_add_interrupt_mask_handler(p_dm);
-			phydm_enable_rx_related_interrupt_handler(p_dm);
-			phydm_set_tdma_dig_timer(p_dm);
+#if 0
+			/*regb0 = odm_get_bb_reg(dm, R_0xb0, bMaskDWord);*/
+#endif
+			PHYDM_DBG(dm, DBG_DIG,
+				  "Check fail, Mask[0]=0x%x, restart timer\n",
+				  *dm->interrupt_mask);
+
+			phydm_tdma_dig_add_interrupt_mask_handler(dm);
+			phydm_enable_rx_related_interrupt_handler(dm);
+			phydm_set_tdma_dig_timer(dm);
+#endif
 		}
-	} else
-		PHYDM_DBG(p_dm, DBG_DIG,
-					("Check pass, update pre_tdma_dig_cnt\n"));
+	} else {
+		PHYDM_DBG(dm, DBG_DIG, "Check pass, update pre_tdma_dig_cnt\n");
+	}
 
-	p_dig_t->pre_tdma_dig_cnt = p_dig_t->tdma_dig_cnt;
+	dig_t->pre_tdma_dig_cnt = dig_t->tdma_dig_cnt;
 }
 
-/*different IC/team may use different timer for tdma-dig*/
-void
-phydm_tdma_dig_add_interrupt_mask_handler(
-	void		*p_dm_void
-	)
+/*@different IC/team may use different timer for tdma-dig*/
+void phydm_tdma_dig_add_interrupt_mask_handler(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 #if (DM_ODM_SUPPORT_TYPE == (ODM_AP))
-	if (p_dm->support_ic_type & ODM_RTL8197F)
-		phydm_add_interrupt_mask_handler(p_dm, HAL_INT_TYPE_PSTIMEOUT2);	/*HAL_INT_TYPE_PSTIMEOUT2*/
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		/*@HAL_INT_TYPE_PSTIMEOUT2*/
+		phydm_add_interrupt_mask_handler(dm, HAL_INT_TYPE_PSTIMEOUT2);
+	}
 #elif (DM_ODM_SUPPORT_TYPE == (ODM_WIN))
 #elif (DM_ODM_SUPPORT_TYPE == (ODM_CE))
 #endif
 }
 
-void
-phydm_tdma_dig(
-	void		*p_dm_void
-	)
+/* will be triggered by HW timer*/
+void phydm_tdma_dig(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm;
-	struct phydm_dig_struct	*p_dig_t;
-	struct phydm_fa_struct *p_falm_cnt;
-	u32	reg_c50;
-	
-	p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	p_dig_t = &p_dm->dm_dig_table;
-	p_falm_cnt = &p_dm->false_alm_cnt;
-	reg_c50 = odm_get_bb_reg(p_dm, 0xc50, MASKBYTE0);
-
-	p_dig_t->tdma_dig_state =
-		p_dig_t->tdma_dig_cnt % p_dm->tdma_dig_state_number;
-
-	PHYDM_DBG(p_dm, DBG_DIG,
-				("tdma_dig_state=%d, regc50=0x%x\n",
-				p_dig_t->tdma_dig_state,
-				reg_c50));
-
-	p_dig_t->tdma_dig_cnt++;
-
-	if (p_dig_t->tdma_dig_state == 1) {
-		// update IGI from tdma_dig_state == 0
-		if (p_dig_t->cur_ig_value_tdma == 0)
-			p_dig_t->cur_ig_value_tdma = p_dig_t->cur_ig_value;
-
-		odm_write_dig(p_dm, p_dig_t->cur_ig_value_tdma);
-		phydm_tdma_false_alarm_counter_check(p_dm);
-		PHYDM_DBG(p_dm, DBG_DIG,
-			("tdma_dig_state=%d, reset FA counter !!!\n",
-			p_dig_t->tdma_dig_state));
-
-	} else if (p_dig_t->tdma_dig_state == 0) {
-		/* update p_dig_t->CurIGValue,*/
-		/* it may different from p_dig_t->cur_ig_value_tdma */
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+	u32 reg_c50 = 0;
+
+#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT || RTL8812F_SUPPORT ||\
+	RTL8822B_SUPPORT || RTL8192F_SUPPORT || RTL8821C_SUPPORT)
+#ifdef IS_USE_NEW_TDMA
+	if (dm->support_ic_type &
+	    (ODM_RTL8198F | ODM_RTL8814B | ODM_RTL8812F | ODM_RTL8822B |
+	     ODM_RTL8192F | ODM_RTL8821C)) {
+		PHYDM_DBG(dm, DBG_DIG, "98F/14B/12F/22B/92F/21C, new tdma\n");
+		return;
+	}
+#endif
+#endif
+	reg_c50 = odm_get_bb_reg(dm, R_0xc50, MASKBYTE0);
+
+	dig_t->tdma_dig_state =
+		dig_t->tdma_dig_cnt % dm->tdma_dig_state_number;
+
+	PHYDM_DBG(dm, DBG_DIG, "tdma_dig_state=%d, regc50=0x%x\n",
+		  dig_t->tdma_dig_state, reg_c50);
+
+	dig_t->tdma_dig_cnt++;
+
+	if (dig_t->tdma_dig_state == 1) {
+		/* update IGI from tdma_dig_state == 0*/
+		if (dig_t->cur_ig_value_tdma == 0)
+			dig_t->cur_ig_value_tdma = dig_t->cur_ig_value;
+
+		odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+		phydm_tdma_false_alarm_counter_check(dm);
+		PHYDM_DBG(dm, DBG_DIG, "tdma_dig_state=%d, reset FA counter\n",
+			  dig_t->tdma_dig_state);
+
+	} else if (dig_t->tdma_dig_state == 0) {
+		/* update dig_t->CurIGValue,*/
+		/* @it may different from dig_t->cur_ig_value_tdma */
 		/* TDMA IGI upperbond @ L-state = */
 		/* rf_ft_var.tdma_dig_low_upper_bond = 0x26 */
 
-		if (p_dig_t->cur_ig_value >= p_dm->tdma_dig_low_upper_bond)
-			p_dig_t->low_ig_value = p_dm->tdma_dig_low_upper_bond;
+		if (dig_t->cur_ig_value >= dm->tdma_dig_low_upper_bond)
+			dig_t->low_ig_value = dm->tdma_dig_low_upper_bond;
 		else
-			p_dig_t->low_ig_value = p_dig_t->cur_ig_value;
+			dig_t->low_ig_value = dig_t->cur_ig_value;
 
-		odm_write_dig(p_dm, p_dig_t->low_ig_value);
-		phydm_tdma_false_alarm_counter_check(p_dm);
-	} else
-		phydm_tdma_false_alarm_counter_check(p_dm);
+		odm_write_dig(dm, dig_t->low_ig_value);
+		phydm_tdma_false_alarm_counter_check(dm);
+	} else {
+		phydm_tdma_false_alarm_counter_check(dm);
+	}
 }
 
-/*============================================================*/
-/*FASLE ALARM CHECK*/
-/*============================================================*/
-
-void
-phydm_tdma_false_alarm_counter_check(
-	void		*p_dm_void
-	)
+/*@============================================================*/
+/*@FASLE ALARM CHECK*/
+/*@============================================================*/
+void phydm_tdma_false_alarm_counter_check(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm;
-	struct phydm_fa_struct	*p_falm_cnt;
-	struct phydm_fa_acc_struct	*p_falm_cnt_acc;
-	struct phydm_dig_struct	*p_dig_t;
-	boolean	rssi_dump_en = 0;
-	u32 timestamp;
-	u8 tdma_dig_state_number;
-
-	p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	p_falm_cnt = &p_dm->false_alm_cnt;
-	p_falm_cnt_acc = &p_dm->false_alm_cnt_acc;
-	p_dig_t = &p_dm->dm_dig_table;
-
-	if (p_dig_t->tdma_dig_state == 1)
-		phydm_false_alarm_counter_reset(p_dm);
-		/* Reset FalseAlarmCounterStatistics */
-		/* fa_acc_1sec_tsf = fa_acc_1sec_tsf, keep */
-		/* fa_end_tsf = fa_start_tsf = TSF */
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	boolean rssi_dump_en = 0;
+	u32 timestamp = 0;
+	u8 tdma_dig_state_number = 0;
+	u32 start_th = 0;
+
+	if (dig_t->tdma_dig_state == 1)
+		phydm_false_alarm_counter_reset(dm);
+	/* Reset FalseAlarmCounterStatistics */
+	/* @fa_acc_1sec_tsf = fa_acc_1sec_tsf, keep */
+	/* @fa_end_tsf = fa_start_tsf = TSF */
 	else {
-		odm_false_alarm_counter_statistics(p_dm);
-		if (p_dm->support_ic_type & ODM_RTL8197F)		/*REG_FREERUN_CNT*/
-			timestamp = odm_get_bb_reg(p_dm, 0x568, bMaskDWord);
+		phydm_false_alarm_counter_statistics(dm);
+		if (dm->support_ic_type & ODM_RTL8197F) /*REG_FREERUN_CNT*/
+			timestamp = odm_get_bb_reg(dm, R_0x568, bMaskDWord);
 		else {
-			PHYDM_DBG(p_dm, DBG_DIG,
-						("Caution! NOT 97F! TDMA-DIG timer does NOT start!!!\n"));
+			PHYDM_DBG(dm, DBG_DIG, "NOT 97F! NOT start\n");
 			return;
 		}
-		p_dig_t->fa_end_timestamp = timestamp;
-		p_dig_t->fa_acc_1sec_timestamp +=
-			(p_dig_t->fa_end_timestamp - p_dig_t->fa_start_timestamp);
+		dig_t->fa_end_timestamp = timestamp;
+		dig_t->fa_acc_1sec_timestamp +=
+			(dig_t->fa_end_timestamp - dig_t->fa_start_timestamp);
 
 		/*prevent dumb*/
-		if (p_dm->tdma_dig_state_number == 1)
-			p_dm->tdma_dig_state_number = 2;
+		if (dm->tdma_dig_state_number == 1)
+			dm->tdma_dig_state_number = 2;
 
-		tdma_dig_state_number = p_dm->tdma_dig_state_number;
-		p_dig_t->sec_factor =
+		tdma_dig_state_number = dm->tdma_dig_state_number;
+		dig_t->sec_factor =
 			tdma_dig_state_number / (tdma_dig_state_number - 1);
 
-		/*1sec = 1000000us*/
-		if (p_dig_t->fa_acc_1sec_timestamp >= (u32)(1000000 / p_dig_t->sec_factor)) {
+		/*@1sec = 1000000us*/
+		if (dig_t->sec_factor)
+			start_th = (u32)(1000000 / dig_t->sec_factor);
+
+		if (dig_t->fa_acc_1sec_timestamp >= start_th) {
 			rssi_dump_en = 1;
-			phydm_false_alarm_counter_acc(p_dm, rssi_dump_en);
-			PHYDM_DBG(p_dm, DBG_DIG,
-						("sec_factor = %u, total FA = %u, is_linked=%u\n",
-						p_dig_t->sec_factor,
-						p_falm_cnt_acc->cnt_all,
-						p_dm->is_linked));
-
-			phydm_noisy_detection(p_dm);
-			phydm_cck_pd_th(p_dm);
-			phydm_dig(p_dm);
-			phydm_false_alarm_counter_acc_reset(p_dm);
+			phydm_false_alarm_counter_acc(dm, rssi_dump_en);
+			PHYDM_DBG(dm, DBG_DIG,
+				  "sec_factor=%d, total FA=%d, is_linked=%d\n",
+				  dig_t->sec_factor, falm_cnt_acc->cnt_all,
+				  dm->is_linked);
+
+			phydm_noisy_detection(dm);
+			#ifdef PHYDM_SUPPORT_CCKPD
+			phydm_cck_pd_th(dm);
+			#endif
+			phydm_dig(dm);
+			phydm_false_alarm_counter_acc_reset(dm);
 
 			/* Reset FalseAlarmCounterStatistics */
-			/* fa_end_tsf = fa_start_tsf = TSF, keep */
-			/* fa_acc_1sec_tsf = 0 */
-			phydm_false_alarm_counter_reset(p_dm);
-		} else
-			phydm_false_alarm_counter_acc(p_dm, rssi_dump_en);
+			/* @fa_end_tsf = fa_start_tsf = TSF, keep */
+			/* @fa_acc_1sec_tsf = 0 */
+			phydm_false_alarm_counter_reset(dm);
+		} else {
+			phydm_false_alarm_counter_acc(dm, rssi_dump_en);
+		}
 	}
 }
 
-void
-phydm_false_alarm_counter_acc(
-	void		*p_dm_void,
-	boolean		rssi_dump_en
-	)
+void phydm_false_alarm_counter_acc(void *dm_void, boolean rssi_dump_en)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_struct			*p_falm_cnt;
-	struct phydm_fa_acc_struct		*p_falm_cnt_acc;
-	struct phydm_dig_struct	*p_dig_t;
-	
-	p_falm_cnt = &p_dm->false_alm_cnt;
-	p_falm_cnt_acc = &p_dm->false_alm_cnt_acc;
-	p_dig_t = &p_dm->dm_dig_table;
-
-	p_falm_cnt_acc->cnt_parity_fail += p_falm_cnt->cnt_parity_fail;
-	p_falm_cnt_acc->cnt_rate_illegal += p_falm_cnt->cnt_rate_illegal;
-	p_falm_cnt_acc->cnt_crc8_fail += p_falm_cnt->cnt_crc8_fail;
-	p_falm_cnt_acc->cnt_mcs_fail += p_falm_cnt->cnt_mcs_fail;
-	p_falm_cnt_acc->cnt_ofdm_fail += p_falm_cnt->cnt_ofdm_fail;
-	p_falm_cnt_acc->cnt_cck_fail += p_falm_cnt->cnt_cck_fail;
-	p_falm_cnt_acc->cnt_all += p_falm_cnt->cnt_all;
-	p_falm_cnt_acc->cnt_fast_fsync += p_falm_cnt->cnt_fast_fsync;
-	p_falm_cnt_acc->cnt_sb_search_fail += p_falm_cnt->cnt_sb_search_fail;
-	p_falm_cnt_acc->cnt_ofdm_cca += p_falm_cnt->cnt_ofdm_cca;
-	p_falm_cnt_acc->cnt_cck_cca += p_falm_cnt->cnt_cck_cca;
-	p_falm_cnt_acc->cnt_cca_all += p_falm_cnt->cnt_cca_all;
-	p_falm_cnt_acc->cnt_cck_crc32_error += p_falm_cnt->cnt_cck_crc32_error;
-	p_falm_cnt_acc->cnt_cck_crc32_ok += p_falm_cnt->cnt_cck_crc32_ok;
-	p_falm_cnt_acc->cnt_ofdm_crc32_error += p_falm_cnt->cnt_ofdm_crc32_error;
-	p_falm_cnt_acc->cnt_ofdm_crc32_ok += p_falm_cnt->cnt_ofdm_crc32_ok;
-	p_falm_cnt_acc->cnt_ht_crc32_error += p_falm_cnt->cnt_ht_crc32_error;
-	p_falm_cnt_acc->cnt_ht_crc32_ok += p_falm_cnt->cnt_ht_crc32_ok;
-	p_falm_cnt_acc->cnt_vht_crc32_error += p_falm_cnt->cnt_vht_crc32_error;
-	p_falm_cnt_acc->cnt_vht_crc32_ok += p_falm_cnt->cnt_vht_crc32_ok;
-	p_falm_cnt_acc->cnt_crc32_error_all += p_falm_cnt->cnt_crc32_error_all;
-	p_falm_cnt_acc->cnt_crc32_ok_all += p_falm_cnt->cnt_crc32_ok_all;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	falm_cnt_acc->cnt_parity_fail += falm_cnt->cnt_parity_fail;
+	falm_cnt_acc->cnt_rate_illegal += falm_cnt->cnt_rate_illegal;
+	falm_cnt_acc->cnt_crc8_fail += falm_cnt->cnt_crc8_fail;
+	falm_cnt_acc->cnt_mcs_fail += falm_cnt->cnt_mcs_fail;
+	falm_cnt_acc->cnt_ofdm_fail += falm_cnt->cnt_ofdm_fail;
+	falm_cnt_acc->cnt_cck_fail += falm_cnt->cnt_cck_fail;
+	falm_cnt_acc->cnt_all += falm_cnt->cnt_all;
+	falm_cnt_acc->cnt_fast_fsync += falm_cnt->cnt_fast_fsync;
+	falm_cnt_acc->cnt_sb_search_fail += falm_cnt->cnt_sb_search_fail;
+	falm_cnt_acc->cnt_ofdm_cca += falm_cnt->cnt_ofdm_cca;
+	falm_cnt_acc->cnt_cck_cca += falm_cnt->cnt_cck_cca;
+	falm_cnt_acc->cnt_cca_all += falm_cnt->cnt_cca_all;
+	falm_cnt_acc->cnt_cck_crc32_error += falm_cnt->cnt_cck_crc32_error;
+	falm_cnt_acc->cnt_cck_crc32_ok += falm_cnt->cnt_cck_crc32_ok;
+	falm_cnt_acc->cnt_ofdm_crc32_error += falm_cnt->cnt_ofdm_crc32_error;
+	falm_cnt_acc->cnt_ofdm_crc32_ok += falm_cnt->cnt_ofdm_crc32_ok;
+	falm_cnt_acc->cnt_ht_crc32_error += falm_cnt->cnt_ht_crc32_error;
+	falm_cnt_acc->cnt_ht_crc32_ok += falm_cnt->cnt_ht_crc32_ok;
+	falm_cnt_acc->cnt_vht_crc32_error += falm_cnt->cnt_vht_crc32_error;
+	falm_cnt_acc->cnt_vht_crc32_ok += falm_cnt->cnt_vht_crc32_ok;
+	falm_cnt_acc->cnt_crc32_error_all += falm_cnt->cnt_crc32_error_all;
+	falm_cnt_acc->cnt_crc32_ok_all += falm_cnt->cnt_crc32_ok_all;
 
 	if (rssi_dump_en == 1) {
-		p_falm_cnt_acc->cnt_all_1sec =
-			p_falm_cnt_acc->cnt_all * p_dig_t->sec_factor;
-		p_falm_cnt_acc->cnt_cca_all_1sec =
-			p_falm_cnt_acc->cnt_cca_all * p_dig_t->sec_factor;
-		p_falm_cnt_acc->cnt_cck_fail_1sec =
-			p_falm_cnt_acc->cnt_cck_fail * p_dig_t->sec_factor;
+		falm_cnt_acc->cnt_all_1sec =
+			falm_cnt_acc->cnt_all * dig_t->sec_factor;
+		falm_cnt_acc->cnt_cca_all_1sec =
+			falm_cnt_acc->cnt_cca_all * dig_t->sec_factor;
+		falm_cnt_acc->cnt_cck_fail_1sec =
+			falm_cnt_acc->cnt_cck_fail * dig_t->sec_factor;
 	}
 }
 
-void
-phydm_false_alarm_counter_acc_reset(
-	void		*p_dm_void
-	)
+void phydm_false_alarm_counter_acc_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_acc_struct *p_falm_cnt_acc;
-
-	p_falm_cnt_acc = &p_dm->false_alm_cnt_acc;
-
-	/* Cnt_all_for_rssi_dump & Cnt_CCA_all_for_rssi_dump */
-	/* do NOT need to be reset */
-	odm_memory_set(p_dm, p_falm_cnt_acc, 0, sizeof(p_falm_cnt_acc));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_acc_struct *falm_cnt_acc = NULL;
+
+#ifdef IS_USE_NEW_TDMA
+	struct phydm_fa_acc_struct *falm_cnt_acc_low = NULL;
+	u32 tmp_cca_1sec = 0;
+	u32 tmp_fa_1sec = 0;
+
+	/*@clear L-fa_acc struct*/
+	falm_cnt_acc_low = &dm->false_alm_cnt_acc_low;
+	tmp_cca_1sec = falm_cnt_acc_low->cnt_cca_all_1sec;
+	tmp_fa_1sec = falm_cnt_acc_low->cnt_all_1sec;
+	odm_memory_set(dm, falm_cnt_acc_low, 0, sizeof(dm->false_alm_cnt_acc));
+	falm_cnt_acc_low->cnt_cca_all_1sec = tmp_cca_1sec;
+	falm_cnt_acc_low->cnt_all_1sec = tmp_fa_1sec;
+
+	/*@clear H-fa_acc struct*/
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+	tmp_cca_1sec = falm_cnt_acc->cnt_cca_all_1sec;
+	tmp_fa_1sec = falm_cnt_acc->cnt_all_1sec;
+	odm_memory_set(dm, falm_cnt_acc, 0, sizeof(dm->false_alm_cnt_acc));
+	falm_cnt_acc->cnt_cca_all_1sec = tmp_cca_1sec;
+	falm_cnt_acc->cnt_all_1sec = tmp_fa_1sec;
+#else
+	falm_cnt_acc = &dm->false_alm_cnt_acc;
+	/* @Cnt_all_for_rssi_dump & Cnt_CCA_all_for_rssi_dump */
+	/* @do NOT need to be reset */
+	odm_memory_set(dm, falm_cnt_acc, 0, sizeof(falm_cnt_acc));
+#endif
 }
 
-void
-phydm_false_alarm_counter_reset(
-	void		*p_dm_void
-	)
+void phydm_false_alarm_counter_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT *p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_struct *p_falm_cnt;
-	struct phydm_dig_struct	*p_dig_t;
-	u32	timestamp;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt;
+	struct phydm_dig_struct *dig_t;
+	u32 timestamp;
 
-	p_falm_cnt = &p_dm->false_alm_cnt;
-	p_dig_t = &p_dm->dm_dig_table;
+	falm_cnt = &dm->false_alm_cnt;
+	dig_t = &dm->dm_dig_table;
 
-	memset(p_falm_cnt, 0, sizeof(p_dm->false_alm_cnt));
-	phydm_false_alarm_counter_reg_reset(p_dm);
+	memset(falm_cnt, 0, sizeof(dm->false_alm_cnt));
+	phydm_false_alarm_counter_reg_reset(dm);
 
-	if (p_dig_t->tdma_dig_state != 1)
-		p_dig_t->fa_acc_1sec_timestamp = 0;
+#ifdef IS_USE_NEW_TDMA
+	return;
+#endif
+	if (dig_t->tdma_dig_state != 1)
+		dig_t->fa_acc_1sec_timestamp = 0;
 	else
-		p_dig_t->fa_acc_1sec_timestamp = p_dig_t->fa_acc_1sec_timestamp;
+		dig_t->fa_acc_1sec_timestamp = dig_t->fa_acc_1sec_timestamp;
 
 	/*REG_FREERUN_CNT*/
-	timestamp = odm_get_bb_reg(p_dm, 0x568, bMaskDWord);
-	p_dig_t->fa_start_timestamp = timestamp;
-	p_dig_t->fa_end_timestamp = timestamp;
+	timestamp = odm_get_bb_reg(dm, R_0x568, bMaskDWord);
+	dig_t->fa_start_timestamp = timestamp;
+	dig_t->fa_end_timestamp = timestamp;
 }
 
-#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+void phydm_tdma_dig_para_upd(void *dm_void, enum upd_type type, u8 input)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
-void
-phydm_lna_sat_chk_init(
-	void		*p_dm_void
-	)
+	switch (type) {
+	case ENABLE_TDMA:
+		dm->original_dig_restore = !((boolean)input);
+		break;
+	case MODE_DECISION:
+		if (input == MODE_PERFORMANCE)
+			dm->tdma_dig_state_number = DIG_NUM_OF_TDMA_STATES + 2;
+		else if (input == MODE_COVERAGE)
+			dm->tdma_dig_state_number = DIG_NUM_OF_TDMA_STATES;
+		else
+			dm->tdma_dig_state_number = DIG_NUM_OF_TDMA_STATES;
+		break;
+	}
+}
+
+#ifdef IS_USE_NEW_TDMA
+void phydm_tdma_dig_timers(void *dm_void, u8 state)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	if (state == INIT_TDMA_DIG_TIMMER)
+		odm_initialize_timer(dm, &dm->tdma_dig_timer,
+				     (void *)phydm_tdma_dig_cbk,
+				     NULL, "phydm_tdma_dig_timer");
+	else if (state == CANCEL_TDMA_DIG_TIMMER)
+		odm_cancel_timer(dm, &dm->tdma_dig_timer);
+	else if (state == RELEASE_TDMA_DIG_TIMMER)
+		odm_release_timer(dm, &dm->tdma_dig_timer);
+}
 
-	struct phydm_lna_sat_info_struct *p_lna_info = &p_dm->dm_lna_sat_info;
+u8 get_new_igi_bound(struct dm_struct *dm, u8 igi, u32 fa_cnt, u8 *rx_gain_max,
+		     u8 *rx_gain_min, boolean is_dfs_band)
+{
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u8 step[3] = {0};
+	u8 cur_igi = igi;
+	boolean first_connect = false, first_dis_connect = false;
+
+	first_connect = (dm->is_linked) && !dig_t->is_media_connect;
+	first_dis_connect = (!dm->is_linked) && dig_t->is_media_connect;
+
+	if (dm->is_linked) {
+		if (dm->pre_rssi_min <= dm->rssi_min) {
+			PHYDM_DBG(dm, DBG_DIG, "pre_rssi_min <= rssi_min\n");
+			step[0] = 2;
+			step[1] = 1;
+			step[2] = 2;
+		} else {
+			step[0] = 4;
+			step[1] = 2;
+			step[2] = 2;
+		}
+	} else {
+		step[0] = 2;
+		step[1] = 1;
+		step[2] = 2;
+	}
 
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("%s ==>\n", __FUNCTION__));
+	PHYDM_DBG(dm, DBG_DIG, "step = {-%d, +%d, +%d}\n", step[2], step[1],
+		  step[0]);
 
-	p_lna_info->check_time = 0;
-	p_lna_info->sat_cnt_acc_patha = 0;
-	p_lna_info->sat_cnt_acc_pathb = 0;
-	p_lna_info->cur_sat_status = 0;
-	p_lna_info->pre_sat_status = 0;
-	p_lna_info->cur_timer_check_cnt = 0;
-	p_lna_info->pre_timer_check_cnt = 0;
+	if (first_connect) {
+		if (is_dfs_band) {
+			if (dm->rssi_min > DIG_MAX_DFS)
+				igi = DIG_MAX_DFS;
+			else
+				igi = dm->rssi_min;
+			PHYDM_DBG(dm, DBG_DIG, "DFS band:IgiMax=0x%x\n",
+				  *rx_gain_max);
+		} else {
+			igi = *rx_gain_min;
+		}
+
+		#if 0
+		#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+		#if (RTL8812A_SUPPORT)
+		if (dm->support_ic_type == ODM_RTL8812)
+			odm_config_bb_with_header_file(dm,
+						       CONFIG_BB_AGC_TAB_DIFF);
+		#endif
+		#endif
+		#endif
+		PHYDM_DBG(dm, DBG_DIG, "First connect: foce IGI=0x%x\n", igi);
+	} else {
+		/* @2 Before link */
+		PHYDM_DBG(dm, DBG_DIG, "Adjust IGI before link\n");
+
+		if (first_dis_connect) {
+			igi = dig_t->dm_dig_min;
+			PHYDM_DBG(dm, DBG_DIG,
+				  "First disconnect:foce IGI to lower bound\n");
+		} else {
+			PHYDM_DBG(dm, DBG_DIG, "Pre_IGI=((0x%x)), FA=((%d))\n",
+				  igi, fa_cnt);
+
+			igi = phydm_new_igi_by_fa(dm, igi, fa_cnt, step);
+		}
+	}
+	/*@Check IGI by dyn-upper/lower bound */
+	if (igi < *rx_gain_min)
+		igi = *rx_gain_min;
+
+	if (igi > *rx_gain_max)
+		igi = *rx_gain_max;
+
+	PHYDM_DBG(dm, DBG_DIG, "fa_cnt = %d, IGI: 0x%x -> 0x%x\n",
+		  fa_cnt, cur_igi, igi);
+
+	return igi;
 }
 
-void
-phydm_set_ofdm_agc_tab(
-	void	*p_dm_void,
-	u8		tab_sel
-)
+/*@callback function triggered by SW timer*/
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void phydm_tdma_dig_cbk(struct phydm_timer_list *timer)
+{
+	void *adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	if (phydm_dig_abort(dm) || dm->original_dig_restore)
+		return;
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG, "timer callback =======> tdma_dig_state=%d\n");
+	 *	  dig_t->tdma_dig_state);
+	 *PHYDM_DBG(dm, DBG_DIG, "tdma_h_igi=0x%x, tdma_l_igi=0x%x\n",
+	 *	  dig_t->cur_ig_value_tdma,
+	 *	  dig_t->low_ig_value);
+	 */
+	phydm_tdma_fa_cnt_chk(dm);
+
+	/*@prevent dumb*/
+	if (dm->tdma_dig_state_number < 2)
+		dm->tdma_dig_state_number = 2;
+
+	/*@update state*/
+	dig_t->tdma_dig_cnt++;
+	dig_t->tdma_dig_state = dig_t->tdma_dig_cnt % dm->tdma_dig_state_number;
+
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG, "enter state %d, dig count %d\n",
+	 *	  dig_t->tdma_dig_state, dig_t->tdma_dig_cnt);
+	 */
+
+	if (dig_t->tdma_dig_state == TDMA_DIG_LOW_STATE)
+		odm_write_dig(dm, dig_t->low_ig_value);
+	else if (dig_t->tdma_dig_state >= TDMA_DIG_HIGH_STATE)
+		odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+
+	odm_set_timer(dm, &dm->tdma_dig_timer, dm->tdma_dig_timer_ms);
+}
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void phydm_tdma_dig_cbk(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *padapter = dm->adapter;
 
-	/* table sel:0/2, 1 is used for CCK */
-	if (tab_sel == OFDM_AGC_TAB_0)
-		odm_set_bb_reg(p_dm, 0xc70, 0x1e00, OFDM_AGC_TAB_0);
-	else if (tab_sel == OFDM_AGC_TAB_2)
-		odm_set_bb_reg(p_dm, 0xc70, 0x1e00, OFDM_AGC_TAB_2);
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_tdma_dig_workitem_callback(dm);
+	/* @Can't do I/O in timer callback*/
 	else
-		odm_set_bb_reg(p_dm, 0xc70, 0x1e00, OFDM_AGC_TAB_0);
+		phydm_run_in_thread_cmd(dm, phydm_tdma_dig_workitem_callback,
+					dm);
 }
 
-u8
-phydm_get_ofdm_agc_tab(
-	void	*p_dm_void
-)
+void phydm_tdma_dig_workitem_callback(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
 
-	return (u1Byte)odm_get_bb_reg(p_dm, 0xc70, 0x1e00);
+	if (phydm_dig_abort(dm) || (dm->original_dig_restore))
+		return;
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG, "timer callback =======> tdma_dig_state=%d\n");
+	 *	  dig_t->tdma_dig_state);
+	 *PHYDM_DBG(dm, DBG_DIG, "tdma_h_igi=0x%x, tdma_l_igi=0x%x\n",
+	 *	  dig_t->cur_ig_value_tdma,
+	 *	  dig_t->low_ig_value);
+	 */
+	phydm_tdma_fa_cnt_chk(dm);
+
+	/*@prevent dumb*/
+	if (dm->tdma_dig_state_number < 2)
+		dm->tdma_dig_state_number = 2;
+
+	/*@update state*/
+	dig_t->tdma_dig_cnt++;
+	dig_t->tdma_dig_state = dig_t->tdma_dig_cnt % dm->tdma_dig_state_number;
+
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG, "enter state %d, dig count %d\n",
+	 *	  dig_t->tdma_dig_state, dig_t->tdma_dig_cnt);
+	 */
+
+	if (dig_t->tdma_dig_state == TDMA_DIG_LOW_STATE)
+		odm_write_dig(dm, dig_t->low_ig_value);
+	else if (dig_t->tdma_dig_state >= TDMA_DIG_HIGH_STATE)
+		odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+
+	odm_set_timer(dm, &dm->tdma_dig_timer, dm->tdma_dig_timer_ms);
 }
-
-void
-phydm_lna_sat_chk(
-	void		*p_dm_void
-	)
+#else
+void phydm_tdma_dig_cbk(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	struct phydm_lna_sat_info_struct *p_lna_info = &p_dm->dm_lna_sat_info;
-
-	u1Byte			igi_rssi_min, rssi_min = p_dm->rssi_min;
-	u4Byte			sat_status_patha, sat_status_pathb;
-	u1Byte			igi_restore = p_dig_t->cur_ig_value;
-	u1Byte			i, lna_sat_chk_cnt = p_dm->lna_sat_chk_cnt;
-	u4Byte			lna_sat_cnt_thd = 0;
-	u1Byte			agc_tab;
-	u4Byte			max_check_time = 0;
-
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("\n%s ==>\n", __FUNCTION__));
-
-	if (!(p_dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-			("support ability is disabled, return.\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+
+	if (phydm_dig_abort(dm) || dm->original_dig_restore)
 		return;
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG, "timer callback =======> tdma_dig_state=%d\n");
+	 *	  dig_t->tdma_dig_state);
+	 *PHYDM_DBG(dm, DBG_DIG, "tdma_h_igi=0x%x, tdma_l_igi=0x%x\n",
+	 *	  dig_t->cur_ig_value_tdma,
+	 *	  dig_t->low_ig_value);
+	 */
+	phydm_tdma_fa_cnt_chk(dm);
+
+	/*@prevent dumb*/
+	if (dm->tdma_dig_state_number < 2)
+		dm->tdma_dig_state_number = 2;
+
+	/*@update state*/
+	dig_t->tdma_dig_cnt++;
+	dig_t->tdma_dig_state = dig_t->tdma_dig_cnt % dm->tdma_dig_state_number;
+
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG, "enter state %d, dig count %d\n",
+	 *	  dig_t->tdma_dig_state, dig_t->tdma_dig_cnt);
+	 */
+
+	if (dig_t->tdma_dig_state == TDMA_DIG_LOW_STATE)
+		odm_write_dig(dm, dig_t->low_ig_value);
+	else if (dig_t->tdma_dig_state >= TDMA_DIG_HIGH_STATE)
+		odm_write_dig(dm, dig_t->cur_ig_value_tdma);
+
+	odm_set_timer(dm, &dm->tdma_dig_timer, dm->tdma_dig_timer_ms);
+}
+#endif
+/*@============================================================*/
+/*@FASLE ALARM CHECK*/
+/*@============================================================*/
+void phydm_tdma_fa_cnt_chk(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+	struct phydm_fa_acc_struct *fa_t_acc = &dm->false_alm_cnt_acc;
+	struct phydm_fa_acc_struct *fa_t_acc_low = &dm->false_alm_cnt_acc_low;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	boolean rssi_dump_en = false;
+	u32 timestamp = 0;
+	u8 states_per_block = dm->tdma_dig_state_number;
+	u8 cur_tdma_dig_state = 0;
+	u32 start_th = 0;
+	u8 state_diff = 0;
+	u32 tdma_dig_block_period_ms = 0;
+	u32 tdma_dig_block_cnt_thd = 0;
+	u32 timestamp_diff = 0;
+
+	/*@calculate duration of a tdma block*/
+	tdma_dig_block_period_ms = dm->tdma_dig_timer_ms * states_per_block;
+
+	/*@
+	 *caution!ONE_SEC_MS must be divisible by tdma_dig_block_period_ms,
+	 *or FA will be fewer.
+	 */
+	tdma_dig_block_cnt_thd = ONE_SEC_MS / tdma_dig_block_period_ms;
+
+	/*@tdma_dig_state == 0, collect H-state FA, else, collect L-state FA*/
+	if (dig_t->tdma_dig_state == TDMA_DIG_LOW_STATE)
+		cur_tdma_dig_state = TDMA_DIG_LOW_STATE;
+	else if (dig_t->tdma_dig_state >= TDMA_DIG_HIGH_STATE)
+		cur_tdma_dig_state = TDMA_DIG_HIGH_STATE;
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG, "in state %d, dig count %d\n",
+	 *	  cur_tdma_dig_state, dig_t->tdma_dig_cnt);
+	 */
+	if (cur_tdma_dig_state == 0) {
+		/*@L-state indicates next block*/
+		dig_t->tdma_dig_block_cnt++;
+
+		/*@1sec dump check*/
+		if (dig_t->tdma_dig_block_cnt >= tdma_dig_block_cnt_thd)
+			rssi_dump_en = true;
+
+		/*@
+		 *PHYDM_DBG(dm, DBG_DIG,"[L-state] tdma_dig_block_cnt=%d\n",
+		 *	  dig_t->tdma_dig_block_cnt);
+		 */
+
+		/*@collect FA till this block end*/
+		phydm_false_alarm_counter_statistics(dm);
+		phydm_fa_cnt_acc(dm, rssi_dump_en, cur_tdma_dig_state);
+		/*@1s L-FA collect end*/
+
+		/*@1sec dump reached*/
+		if (rssi_dump_en) {
+			/*@L-DIG*/
+			phydm_noisy_detection(dm);
+			#ifdef PHYDM_SUPPORT_CCKPD
+			phydm_cck_pd_th(dm);
+			#endif
+			PHYDM_DBG(dm, DBG_DIG, "run tdma L-state dig ====>\n");
+			phydm_tdma_low_dig(dm);
+			PHYDM_DBG(dm, DBG_DIG, "\n\n");
+		}
+	} else if (cur_tdma_dig_state == 1) {
+		/*@1sec dump check*/
+		if (dig_t->tdma_dig_block_cnt >= tdma_dig_block_cnt_thd)
+			rssi_dump_en = true;
+
+		/*@
+		 *PHYDM_DBG(dm, DBG_DIG,"[H-state] tdma_dig_block_cnt=%d\n",
+		 *	  dig_t->tdma_dig_block_cnt);
+		 */
+
+		/*@collect FA till this block end*/
+		phydm_false_alarm_counter_statistics(dm);
+		phydm_fa_cnt_acc(dm, rssi_dump_en, cur_tdma_dig_state);
+		/*@1s H-FA collect end*/
+
+		/*@1sec dump reached*/
+		state_diff = dm->tdma_dig_state_number - dig_t->tdma_dig_state;
+		if (rssi_dump_en && (state_diff == 1)) {
+			/*@H-DIG*/
+			phydm_noisy_detection(dm);
+			#ifdef PHYDM_SUPPORT_CCKPD
+			phydm_cck_pd_th(dm);
+			#endif
+			PHYDM_DBG(dm, DBG_DIG, "run tdma H-state dig ====>\n");
+			phydm_tdma_high_dig(dm);
+			PHYDM_DBG(dm, DBG_DIG, "\n\n");
+			PHYDM_DBG(dm, DBG_DIG, "1 sec reached, is_linked=%d\n",
+				  dm->is_linked);
+			PHYDM_DBG(dm, DBG_DIG, "1 sec L-CCA=%d, L-FA=%d\n",
+				  fa_t_acc_low->cnt_cca_all_1sec,
+				  fa_t_acc_low->cnt_all_1sec);
+			PHYDM_DBG(dm, DBG_DIG, "1 sec H-CCA=%d, H-FA=%d\n",
+				  fa_t_acc->cnt_cca_all_1sec,
+				  fa_t_acc->cnt_all_1sec);
+			PHYDM_DBG(dm, DBG_DIG,
+				  "1 sec TOTAL-CCA=%d, TOTAL-FA=%d\n\n",
+				  fa_t_acc->cnt_cca_all +
+				  fa_t_acc_low->cnt_cca_all,
+				  fa_t_acc->cnt_all + fa_t_acc_low->cnt_all);
+
+			/*@Reset AccFalseAlarmCounterStatistics */
+			phydm_false_alarm_counter_acc_reset(dm);
+			dig_t->tdma_dig_block_cnt = 0;
+		}
+	}
+	/*@Reset FalseAlarmCounterStatistics */
+	phydm_false_alarm_counter_reset(dm);
+}
+
+void phydm_tdma_low_dig(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc_low;
+#ifdef CFG_DIG_DAMPING_CHK
+	struct phydm_dig_recorder_strcut *dig_rc = &dig_t->dig_recorder_t;
+#endif
+	boolean first_connect, first_disconnect = false;
+	u8 igi = dig_t->cur_ig_value;
+	u8 new_igi = 0x20;
+	u8 tdma_l_igi = dig_t->low_ig_value;
+	u8 tdma_l_dym_min = dig_t->tdma_rx_gain_min[TDMA_DIG_LOW_STATE];
+	u8 tdma_l_dym_max = dig_t->tdma_rx_gain_max[TDMA_DIG_LOW_STATE];
+	u32 fa_cnt = falm_cnt->cnt_all;
+	boolean dfs_mode_en = false, is_performance = true;
+	u8 rssi_min = dm->rssi_min;
+	u8 igi_upper_rssi_min = 0;
+	u8 offset = 15;
+
+	if (!(dm->original_dig_restore)) {
+		if (tdma_l_igi == 0)
+			tdma_l_igi = igi;
+
+		fa_cnt = falm_cnt_acc->cnt_all_1sec;
 	}
 
-	if (p_dm->is_disable_lna_sat_chk) {
-		phydm_lna_sat_chk_init(p_dm);
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-			("is_disable_lna_sat_chk=%d, return.\n", p_dm->is_disable_lna_sat_chk));
+	if (phydm_dig_abort(dm)) {
+		dig_t->low_ig_value = phydm_get_igi(dm, BB_PATH_A);
 		return;
 	}
 
-	//func_start = ODM_GetBBReg(pDM_Odm, 0x560, bMaskDWord);
+	/*@Mode Decision*/
+	dfs_mode_en = false;
+	is_performance = true;
 
-	// move igi to target pin of rssi_min
-	if ((rssi_min == 0) || (rssi_min == 0xff)) {
-		// adapt agc table 0
-		phydm_set_ofdm_agc_tab(p_dm, OFDM_AGC_TAB_0);
-		phydm_lna_sat_chk_init(p_dm);
-		return;
-	} else if (rssi_min % 2 != 0)
-		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI - 1;
-	else
-		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI;
+	/* @Abs Boundary Decision*/
+	dig_t->dm_dig_max = DIG_MAX_COVERAGR; //0x26
+	dig_t->dm_dig_min = DIG_MIN_PERFORMANCE; //0x20
+	dig_t->dig_max_of_min = DIG_MAX_OF_MIN_COVERAGE; //0x22
 
-	if ((p_dm->lna_sat_chk_period_ms > 0) && (p_dm->lna_sat_chk_period_ms <= ONE_SEC_MS))
-		max_check_time = lna_sat_chk_cnt*(ONE_SEC_MS/(p_dm->lna_sat_chk_period_ms))*5;
-	else
-		max_check_time = lna_sat_chk_cnt * 5;
-
-	lna_sat_cnt_thd = (max_check_time * p_dm->lna_sat_chk_duty_cycle)/100;
-
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-		("check_time=%d, rssi_min=%d, igi_rssi_min=0x%x\nlna_sat_chk_cnt=%d, lna_sat_chk_period_ms=%d, max_check_time=%d, lna_sat_cnt_thd=%d\n",
-		p_lna_info->check_time,
-		rssi_min,
-		igi_rssi_min,
-		lna_sat_chk_cnt,
-		p_dm->lna_sat_chk_period_ms,
-		max_check_time,
-		lna_sat_cnt_thd));
-
-	odm_write_dig(p_dm, igi_rssi_min);
-
-	// adapt agc table 0 check saturation status
-	phydm_set_ofdm_agc_tab(p_dm, OFDM_AGC_TAB_0);
-	// open rf power detection ckt & set detection range
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x86, 0x1f, 0x10);
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0x86, 0x1f, 0x10);
-
-	// check saturation status
-	for (i = 0; i < lna_sat_chk_cnt; i++) {
-		sat_status_patha = odm_get_rf_reg(p_dm, RF_PATH_A, 0xae, 0xc0000);
-		sat_status_pathb = odm_get_rf_reg(p_dm, RF_PATH_B, 0xae, 0xc0000);
-		if (sat_status_patha != 0)
-			p_lna_info->sat_cnt_acc_patha++;
-		if (sat_status_pathb != 0)
-			p_lna_info->sat_cnt_acc_pathb++;
-
-		if ((p_lna_info->sat_cnt_acc_patha >= lna_sat_cnt_thd) ||
-			(p_lna_info->sat_cnt_acc_pathb >= lna_sat_cnt_thd)) {
-			p_lna_info->cur_sat_status = 1;
-			PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-			("cur_sat_status=%d, check_time=%d\n",
-			p_lna_info->cur_sat_status,
-			p_lna_info->check_time));
-			break;
-		} else
-			p_lna_info->cur_sat_status = 0;
-	}
-
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-		("cur_sat_status=%d, pre_sat_status=%d, sat_cnt_acc_patha=%d, sat_cnt_acc_pathb=%d\n",
-		p_lna_info->cur_sat_status,
-		p_lna_info->pre_sat_status,
-		p_lna_info->sat_cnt_acc_patha,
-		p_lna_info->sat_cnt_acc_pathb));
-
-	// agc table decision
-	if (p_lna_info->cur_sat_status) {
-		if (!p_dm->is_disable_gain_table_switch)
-			phydm_set_ofdm_agc_tab(p_dm, OFDM_AGC_TAB_2);
-		p_lna_info->check_time = 0;
-		p_lna_info->sat_cnt_acc_patha = 0;
-		p_lna_info->sat_cnt_acc_pathb = 0;
-		p_lna_info->pre_sat_status = p_lna_info->cur_sat_status;
-
-	} else if (p_lna_info->check_time <= (max_check_time - 1)) {
-		if (p_lna_info->pre_sat_status && (!p_dm->is_disable_gain_table_switch))
-			phydm_set_ofdm_agc_tab(p_dm, OFDM_AGC_TAB_2);
-		p_lna_info->check_time++;
-
-	} else if (p_lna_info->check_time == max_check_time) {
-		if (!p_dm->is_disable_gain_table_switch && (p_lna_info->pre_sat_status == 1))
-			phydm_set_ofdm_agc_tab(p_dm, OFDM_AGC_TAB_0);
-		p_lna_info->check_time = 0;
-		p_lna_info->sat_cnt_acc_patha = 0;
-		p_lna_info->sat_cnt_acc_pathb = 0;
-		p_lna_info->pre_sat_status = p_lna_info->cur_sat_status;
-	}
-
-	agc_tab = phydm_get_ofdm_agc_tab(p_dm);
-
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("use AGC tab %d\n", agc_tab));
-	//func_end = ODM_GetBBReg(pDM_Odm, 0x560, bMaskDWord);
-
-	//PHYDM_DBG(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("function process time=%d\n",
-	//	func_end - func_start));
-
-	// restore previous igi
-	odm_write_dig(p_dm, igi_restore);
-	p_lna_info->cur_timer_check_cnt++;
-	odm_set_timer(p_dm, &p_lna_info->phydm_lna_sat_chk_timer, p_dm->lna_sat_chk_period_ms);
-}
+	if (dfs_mode_en) {
+		if (*dm->band_width == CHANNEL_WIDTH_20)
+			dig_t->dm_dig_min = DIG_MIN_DFS + 2;
+		else
+			dig_t->dm_dig_min = DIG_MIN_DFS;
 
-void
-phydm_lna_sat_chk_callback(
-	void		*p_dm_void
+	} else {
+		#if 0
+		if (dm->support_ic_type &
+		    (ODM_RTL8814A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8822B))
+			dig_t->dm_dig_min = 0x1c;
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			dig_t->dm_dig_min = 0x1e; /*@For HW setting*/
+		#endif
+	}
 
-	)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	PHYDM_DBG(dm, DBG_DIG, "Abs{Max, Min}={0x%x, 0x%x}, Max_of_min=0x%x\n",
+		  dig_t->dm_dig_max, dig_t->dm_dig_min, dig_t->dig_max_of_min);
 
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("\n%s ==>\n", __FUNCTION__));
-	phydm_lna_sat_chk(p_dm);
-}
+	/* @Dyn Boundary by RSSI*/
+	if (!dm->is_linked) {
+		/*@if no link, always stay at lower bound*/
+		tdma_l_dym_max = 0x26;
+		tdma_l_dym_min = dig_t->dm_dig_min;
 
-void
-phydm_lna_sat_chk_timers(
-	void		*p_dm_void,
-	u8			state
-	)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_lna_sat_info_struct *p_lna_info = &p_dm->dm_lna_sat_info;
+		PHYDM_DBG(dm, DBG_DIG, "No-Link, Dyn{Max, Min}={0x%x, 0x%x}\n",
+			  tdma_l_dym_max, tdma_l_dym_min);
+	} else {
+		PHYDM_DBG(dm, DBG_DIG, "rssi_min=%d, ofst=%d\n",
+			  dm->rssi_min, offset);
+
+		/* @DIG lower bound in L-state*/
+		tdma_l_dym_min = dig_t->dm_dig_min;
+
+#ifdef CFG_DIG_DAMPING_CHK
+		/*@Limit Dyn min by damping*/
+		if (dig_t->dig_dl_en &&
+		    dig_rc->damping_limit_en &&
+		    tdma_l_dym_min < dig_rc->damping_limit_val) {
+			PHYDM_DBG(dm, DBG_DIG,
+				  "[Limit by Damping] dyn_min=0x%x -> 0x%x\n",
+				  tdma_l_dym_min, dig_rc->damping_limit_val);
+
+			tdma_l_dym_min = dig_rc->damping_limit_val;
+		}
+#endif
 
-	if (state == INIT_LNA_SAT_CHK_TIMMER) {
-		odm_initialize_timer(p_dm, &(p_lna_info->phydm_lna_sat_chk_timer),
-			(void *)phydm_lna_sat_chk_callback, NULL, "phydm_lna_sat_chk_timer");
-	} else if (state == CANCEL_LNA_SAT_CHK_TIMMER) {
-		odm_cancel_timer(p_dm, &(p_lna_info->phydm_lna_sat_chk_timer));
-	} else if (state == RELEASE_LNA_SAT_CHK_TIMMER) {
-		odm_release_timer(p_dm, &(p_lna_info->phydm_lna_sat_chk_timer));
+		/*@DIG upper bound in L-state*/
+		igi_upper_rssi_min = rssi_min + offset;
+		if (igi_upper_rssi_min > dig_t->dm_dig_max)
+			tdma_l_dym_max = dig_t->dm_dig_max;
+		else if (igi_upper_rssi_min < dig_t->dm_dig_min)
+			tdma_l_dym_max = dig_t->dm_dig_min;
+		else
+			tdma_l_dym_max = igi_upper_rssi_min;
+
+		/* @1 Force Lower Bound for AntDiv */
+		/*@
+		 *if (!dm->is_one_entry_only &&
+		 *(dm->support_ability & ODM_BB_ANT_DIV) &&
+		 *(dm->ant_div_type == CG_TRX_HW_ANTDIV ||
+		 *dm->ant_div_type == CG_TRX_SMART_ANTDIV)) {
+		 *if (dig_t->ant_div_rssi_max > dig_t->dig_max_of_min)
+		 *	dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+		 *else
+		 *	dig_t->rx_gain_range_min = (u8)dig_t->ant_div_rssi_max;
+		 *
+		 *PHYDM_DBG(dm, DBG_DIG, "Force Dyn-Min=0x%x, RSSI_max=0x%x\n",
+		 *	  dig_t->rx_gain_range_min, dig_t->ant_div_rssi_max);
+		 *}
+		 */
+
+		PHYDM_DBG(dm, DBG_DIG, "Dyn{Max, Min}={0x%x, 0x%x}\n",
+			  tdma_l_dym_max, tdma_l_dym_min);
 	}
-}
 
-void
-phydm_lna_sat_chk_watchdog(
-	void		*p_dm_void
-	)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_lna_sat_info_struct *p_lna_info = &p_dm->dm_lna_sat_info;
+	/*@Abnormal Case Check*/
+	/*@Abnormal lower bound case*/
+	if (tdma_l_dym_min > tdma_l_dym_max)
+		tdma_l_dym_min = tdma_l_dym_max;
+
+	PHYDM_DBG(dm, DBG_DIG,
+		  "Abnoraml chk, force {Max, Min}={0x%x, 0x%x}\n",
+		  tdma_l_dym_max, tdma_l_dym_min);
+
+	/*@False Alarm Threshold Decision*/
+	phydm_fa_threshold_check(dm, dfs_mode_en);
+
+	/*@Adjust Initial Gain by False Alarm*/
+	/*Select new IGI by FA */
+	if (!(dm->original_dig_restore)) {
+		tdma_l_igi = get_new_igi_bound(dm, tdma_l_igi, fa_cnt,
+					       &tdma_l_dym_max,
+					       &tdma_l_dym_min,
+					       dfs_mode_en);
+	} else {
+		new_igi = phydm_get_new_igi(dm, igi, fa_cnt, dfs_mode_en);
+	}
 
-	u1Byte rssi_min = p_dm->rssi_min;
+	/*Update status*/
+	if (!(dm->original_dig_restore)) {
+		dig_t->low_ig_value = tdma_l_igi;
+		dig_t->tdma_rx_gain_min[TDMA_DIG_LOW_STATE] = tdma_l_dym_min;
+		dig_t->tdma_rx_gain_max[TDMA_DIG_LOW_STATE] = tdma_l_dym_max;
+#if 0
+		/*odm_write_dig(dm, tdma_l_igi);*/
+#endif
+	} else {
+		odm_write_dig(dm, new_igi);
+	}
 
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("\n%s ==>\n", __FUNCTION__));
+	dig_t->is_media_connect = dm->is_linked;
+}
+
+void phydm_tdma_high_dig(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+	struct phydm_fa_acc_struct *falm_cnt_acc = &dm->false_alm_cnt_acc;
+#ifdef CFG_DIG_DAMPING_CHK
+	struct phydm_dig_recorder_strcut *dig_rc = &dig_t->dig_recorder_t;
+#endif
+	boolean first_connect, first_disconnect = false;
+	u8 igi = dig_t->cur_ig_value;
+	u8 new_igi = 0x20;
+	u8 tdma_h_igi = dig_t->cur_ig_value_tdma;
+	u8 tdma_h_dym_min = dig_t->tdma_rx_gain_min[TDMA_DIG_HIGH_STATE];
+	u8 tdma_h_dym_max = dig_t->tdma_rx_gain_max[TDMA_DIG_HIGH_STATE];
+	u32 fa_cnt = falm_cnt->cnt_all;
+	boolean dfs_mode_en = false, is_performance = true;
+	u8 rssi_min = dm->rssi_min;
+	u8 igi_upper_rssi_min = 0;
+	u8 offset = 15;
+
+	if (!(dm->original_dig_restore)) {
+		if (tdma_h_igi == 0)
+			tdma_h_igi = igi;
+
+		fa_cnt = falm_cnt_acc->cnt_all_1sec;
+	}
 
-	if (!(p_dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-			("support ability is disabled, return.\n"));
+	if (phydm_dig_abort(dm)) {
+		dig_t->cur_ig_value_tdma = phydm_get_igi(dm, BB_PATH_A);
 		return;
 	}
 
-	PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("pre_timer_check_cnt=%d, cur_timer_check_cnt=%d\n",
-		p_lna_info->pre_timer_check_cnt,
-		p_lna_info->cur_timer_check_cnt));
+	/*@Mode Decision*/
+	dfs_mode_en = false;
+	is_performance = true;
 
-	if (p_dm->is_disable_lna_sat_chk) {
-		phydm_lna_sat_chk_init(p_dm);
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-			("is_disable_lna_sat_chk=%d, return.\n", p_dm->is_disable_lna_sat_chk));
-		return;
+	/*@Abs Boundary Decision*/
+	dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE; // 0x2a
+
+	if (!dm->is_linked) {
+		dig_t->dm_dig_max = DIG_MAX_COVERAGR;
+		dig_t->dm_dig_min = DIG_MIN_PERFORMANCE; // 0x20
+	} else if (dfs_mode_en) {
+		if (*dm->band_width == CHANNEL_WIDTH_20)
+			dig_t->dm_dig_min = DIG_MIN_DFS + 2;
+		else
+			dig_t->dm_dig_min = DIG_MIN_DFS;
+
+		dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+		dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+	} else {
+		if (*dm->bb_op_mode == PHYDM_BALANCE_MODE) {
+		/*service > 2 devices*/
+			dig_t->dm_dig_max = DIG_MAX_BALANCE_MODE;
+			#if (DIG_HW == 1)
+			dig_t->dig_max_of_min = DIG_MIN_COVERAGE;
+			#else
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_BALANCE_MODE;
+			#endif
+		} else if (*dm->bb_op_mode == PHYDM_PERFORMANCE_MODE) {
+		/*service 1 devices*/
+			dig_t->dm_dig_max = DIG_MAX_PERFORMANCE_MODE;
+			dig_t->dig_max_of_min = DIG_MAX_OF_MIN_PERFORMANCE_MODE;
+		}
+
+		#if 0
+		if (dm->support_ic_type &
+		    (ODM_RTL8814A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8822B))
+			dig_t->dm_dig_min = 0x1c;
+		else if (dm->support_ic_type & ODM_RTL8197F)
+			dig_t->dm_dig_min = 0x1e; /*@For HW setting*/
+		else
+		#endif
+			dig_t->dm_dig_min = DIG_MIN_PERFORMANCE;
 	}
+	PHYDM_DBG(dm, DBG_DIG, "Abs{Max, Min}={0x%x, 0x%x}, Max_of_min=0x%x\n",
+		  dig_t->dm_dig_max, dig_t->dm_dig_min, dig_t->dig_max_of_min);
 
-	if ((p_dm->support_ic_type & ODM_RTL8197F) == 0) {
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-			("SupportICType != ODM_RTL8197F, return.\n"));
-		return;
+	/*@Dyn Boundary by RSSI*/
+	if (!dm->is_linked) {
+		/*@if no link, always stay at lower bound*/
+		tdma_h_dym_max = dig_t->dig_max_of_min;
+		tdma_h_dym_min = dig_t->dm_dig_min;
+
+		PHYDM_DBG(dm, DBG_DIG, "No-Link, Dyn{Max, Min}={0x%x, 0x%x}\n",
+			  tdma_h_dym_max, tdma_h_dym_min);
+	} else {
+		PHYDM_DBG(dm, DBG_DIG, "rssi_min=%d, ofst=%d\n",
+			  dm->rssi_min, offset);
+
+		/* @DIG lower bound in H-state*/
+		if (rssi_min < dig_t->dm_dig_min)
+			tdma_h_dym_min = dig_t->dm_dig_min;
+		else
+			tdma_h_dym_min = rssi_min; // turbo not considered yet
+
+#ifdef CFG_DIG_DAMPING_CHK
+		/*@Limit Dyn min by damping*/
+		if (dig_t->dig_dl_en &&
+		    dig_rc->damping_limit_en &&
+		    tdma_h_dym_min < dig_rc->damping_limit_val) {
+			PHYDM_DBG(dm, DBG_DIG,
+				  "[Limit by Damping] dyn_min=0x%x -> 0x%x\n",
+				  tdma_h_dym_min, dig_rc->damping_limit_val);
+
+			tdma_h_dym_min = dig_rc->damping_limit_val;
+		}
+#endif
+
+		/*@DIG upper bound in H-state*/
+		igi_upper_rssi_min = rssi_min + offset;
+		if (igi_upper_rssi_min > dig_t->dm_dig_max)
+			tdma_h_dym_max = dig_t->dm_dig_max;
+		else
+			tdma_h_dym_max = igi_upper_rssi_min;
+
+		/* @1 Force Lower Bound for AntDiv */
+		/*@
+		 *if (!dm->is_one_entry_only &&
+		 *(dm->support_ability & ODM_BB_ANT_DIV) &&
+		 *(dm->ant_div_type == CG_TRX_HW_ANTDIV ||
+		 *dm->ant_div_type == CG_TRX_SMART_ANTDIV)) {
+		 *	if (dig_t->ant_div_rssi_max > dig_t->dig_max_of_min)
+		 *	dig_t->rx_gain_range_min = dig_t->dig_max_of_min;
+		 *	else
+		 *	dig_t->rx_gain_range_min = (u8)dig_t->ant_div_rssi_max;
+		 */
+		/*@
+		 *PHYDM_DBG(dm, DBG_DIG, "Force Dyn-Min=0x%x, RSSI_max=0x%x\n",
+		 *	  dig_t->rx_gain_range_min, dig_t->ant_div_rssi_max);
+		 *}
+		 */
+		PHYDM_DBG(dm, DBG_DIG, "Dyn{Max, Min}={0x%x, 0x%x}\n",
+			  tdma_h_dym_max, tdma_h_dym_min);
 	}
 
-	if ((rssi_min == 0) || (rssi_min == 0xff)) {
-		// adapt agc table 0
-		phydm_set_ofdm_agc_tab(p_dm, OFDM_AGC_TAB_0);
-		phydm_lna_sat_chk_init(p_dm);
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK,
-			("rssi_min=%d, return.\n", rssi_min));
-		return;
+	/*@Abnormal Case Check*/
+	/*@Abnormal low higher bound case*/
+	if (tdma_h_dym_max < dig_t->dm_dig_min)
+		tdma_h_dym_max = dig_t->dm_dig_min;
+	/*@Abnormal lower bound case*/
+	if (tdma_h_dym_min > tdma_h_dym_max)
+		tdma_h_dym_min = tdma_h_dym_max;
+
+	PHYDM_DBG(dm, DBG_DIG, "Abnoraml chk, force {Max, Min}={0x%x, 0x%x}\n",
+		  tdma_h_dym_max, tdma_h_dym_min);
+
+	/*@False Alarm Threshold Decision*/
+	phydm_fa_threshold_check(dm, dfs_mode_en);
+
+	/*@Adjust Initial Gain by False Alarm*/
+	/*Select new IGI by FA */
+	if (!(dm->original_dig_restore)) {
+		tdma_h_igi = get_new_igi_bound(dm, tdma_h_igi, fa_cnt,
+					       &tdma_h_dym_max,
+					       &tdma_h_dym_min,
+					       dfs_mode_en);
+	} else {
+		new_igi = phydm_get_new_igi(dm, igi, fa_cnt, dfs_mode_en);
 	}
 
-	if (p_lna_info->cur_timer_check_cnt == p_lna_info->pre_timer_check_cnt) {
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("Timer check fail, restart timer.\n"));
-		phydm_lna_sat_chk(p_dm);
+	/*Update status*/
+	if (!(dm->original_dig_restore)) {
+		dig_t->cur_ig_value_tdma = tdma_h_igi;
+		dig_t->tdma_rx_gain_min[TDMA_DIG_HIGH_STATE] = tdma_h_dym_min;
+		dig_t->tdma_rx_gain_max[TDMA_DIG_HIGH_STATE] = tdma_h_dym_max;
+#if 0
+		/*odm_write_dig(dm, tdma_h_igi);*/
+#endif
 	} else {
-		PHYDM_DBG(p_dm, DBG_LNA_SAT_CHK, ("Timer check pass.\n"));
+		odm_write_dig(dm, new_igi);
 	}
-	p_lna_info->pre_timer_check_cnt = p_lna_info->cur_timer_check_cnt;
+
+	dig_t->is_media_connect = dm->is_linked;
 }
-#endif	/*#if (PHYDM_LNA_SAT_CHK_SUPPORT == 1)*/
-
-void
-phydm_dig_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+
+void phydm_fa_cnt_acc(void *dm_void, boolean rssi_dump_en,
+		      u8 cur_tdma_dig_state)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_dig_struct	*p_dig_t = &p_dm->dm_dig_table;
-	char		help[] = "-h";
-	char		monitor[] = "-m";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u8		i;
-
-	if ((strcmp(input[1], help) == 0))
-		PHYDM_SNPRINTF((output + used, out_len - used, "{0} fa[0] fa[1] fa[2]\n"));
-	else if ((strcmp(input[1], monitor) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used,
-			"Read DIG fa_th[0:2]= {%d, %d, %d}\n", 
-			p_dig_t->fa_th[0], p_dig_t->fa_th[1], p_dig_t->fa_th[2]));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fa_struct *falm_cnt = &dm->false_alm_cnt;
+	struct phydm_fa_acc_struct *falm_cnt_acc = NULL;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u8 factor_num = 0;
+	u8 factor_denum = 1;
+	u8 total_state_number = 0;
+
+	if (cur_tdma_dig_state == TDMA_DIG_LOW_STATE)
+		falm_cnt_acc = &dm->false_alm_cnt_acc_low;
+	else if (cur_tdma_dig_state == TDMA_DIG_HIGH_STATE)
+
+		falm_cnt_acc = &dm->false_alm_cnt_acc;
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG,
+	 *	  "[%s] ==> dig_state=%d, one_sec=%d\n", __func__,
+	 *	  cur_tdma_dig_state, rssi_dump_en);
+	 */
+	falm_cnt_acc->cnt_parity_fail += falm_cnt->cnt_parity_fail;
+	falm_cnt_acc->cnt_rate_illegal += falm_cnt->cnt_rate_illegal;
+	falm_cnt_acc->cnt_crc8_fail += falm_cnt->cnt_crc8_fail;
+	falm_cnt_acc->cnt_mcs_fail += falm_cnt->cnt_mcs_fail;
+	falm_cnt_acc->cnt_ofdm_fail += falm_cnt->cnt_ofdm_fail;
+	falm_cnt_acc->cnt_cck_fail += falm_cnt->cnt_cck_fail;
+	falm_cnt_acc->cnt_all += falm_cnt->cnt_all;
+	falm_cnt_acc->cnt_fast_fsync += falm_cnt->cnt_fast_fsync;
+	falm_cnt_acc->cnt_sb_search_fail += falm_cnt->cnt_sb_search_fail;
+	falm_cnt_acc->cnt_ofdm_cca += falm_cnt->cnt_ofdm_cca;
+	falm_cnt_acc->cnt_cck_cca += falm_cnt->cnt_cck_cca;
+	falm_cnt_acc->cnt_cca_all += falm_cnt->cnt_cca_all;
+	falm_cnt_acc->cnt_cck_crc32_error += falm_cnt->cnt_cck_crc32_error;
+	falm_cnt_acc->cnt_cck_crc32_ok += falm_cnt->cnt_cck_crc32_ok;
+	falm_cnt_acc->cnt_ofdm_crc32_error += falm_cnt->cnt_ofdm_crc32_error;
+	falm_cnt_acc->cnt_ofdm_crc32_ok += falm_cnt->cnt_ofdm_crc32_ok;
+	falm_cnt_acc->cnt_ht_crc32_error += falm_cnt->cnt_ht_crc32_error;
+	falm_cnt_acc->cnt_ht_crc32_ok += falm_cnt->cnt_ht_crc32_ok;
+	falm_cnt_acc->cnt_vht_crc32_error += falm_cnt->cnt_vht_crc32_error;
+	falm_cnt_acc->cnt_vht_crc32_ok += falm_cnt->cnt_vht_crc32_ok;
+	falm_cnt_acc->cnt_crc32_error_all += falm_cnt->cnt_crc32_error_all;
+	falm_cnt_acc->cnt_crc32_ok_all += falm_cnt->cnt_crc32_ok_all;
+
+	/*@
+	 *PHYDM_DBG(dm, DBG_DIG,
+	 *	"[CCA Cnt]     {CCK, OFDM, Total} = {%d, %d, %d}\n",
+	 *	falm_cnt->cnt_cck_cca,
+	 *	falm_cnt->cnt_ofdm_cca,
+	 *	falm_cnt->cnt_cca_all);
+	 *PHYDM_DBG(dm, DBG_DIG,
+	 *	"[FA Cnt]      {CCK, OFDM, Total} = {%d, %d, %d}\n",
+	 *	falm_cnt->cnt_cck_fail,
+	 *	falm_cnt->cnt_ofdm_fail,
+	 *	falm_cnt->cnt_all);
+	 */
+	if (rssi_dump_en == 1) {
+		total_state_number = dm->tdma_dig_state_number;
+
+		if (cur_tdma_dig_state == TDMA_DIG_HIGH_STATE) {
+			factor_num = total_state_number;
+			factor_denum = total_state_number - 1;
+		} else if (cur_tdma_dig_state == TDMA_DIG_LOW_STATE) {
+			factor_num = total_state_number;
+			factor_denum = 1;
+		}
 
-	} else {
+		falm_cnt_acc->cnt_all_1sec =
+			falm_cnt_acc->cnt_all * factor_num / factor_denum;
+		falm_cnt_acc->cnt_cca_all_1sec =
+			falm_cnt_acc->cnt_cca_all * factor_num / factor_denum;
+		falm_cnt_acc->cnt_cck_fail_1sec =
+			falm_cnt_acc->cnt_cck_fail * factor_num / factor_denum;
+
+		PHYDM_DBG(dm, DBG_DIG,
+			  "[ACC CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
+			  falm_cnt_acc->cnt_cck_cca,
+			  falm_cnt_acc->cnt_ofdm_cca,
+			  falm_cnt_acc->cnt_cca_all);
+		PHYDM_DBG(dm, DBG_DIG,
+			  "[ACC FA Cnt]  {CCK, OFDM, Total} = {%d, %d, %d}\n\n",
+			  falm_cnt_acc->cnt_cck_fail,
+			  falm_cnt_acc->cnt_ofdm_fail,
+			  falm_cnt_acc->cnt_all);
+
+	}
+}
+#endif /*@#ifdef IS_USE_NEW_TDMA*/
+#endif /*@#ifdef PHYDM_TDMA_DIG_SUPPORT*/
 
+void phydm_dig_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+		     u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i = 0;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{0} {en} fa_th[0] fa_th[1] fa_th[2]\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} {Damping Limit en}\n");
+		#ifdef PHYDM_TDMA_DIG_SUPPORT
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{2} {original_dig_restore = %d}\n",
+			 dm->original_dig_restore);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{3} {tdma_dig_timer_ms = %d}\n",
+			 dm->tdma_dig_timer_ms);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{4} {tdma_dig_state_number = %d}\n",
+			 dm->tdma_dig_state_number);
+		#endif
+	} else {
 		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
 
-		for (i = 1; i < 10; i++) {
-			if (input[i + 1])
-				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-		}
+		for (i = 1; i < 10; i++)
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
 
 		if (var1[0] == 0) {
-			p_dig_t->is_dbg_fa_th = true;
-			p_dig_t->fa_th[0] =  (u16)var1[1];
-			p_dig_t->fa_th[1] =  (u16)var1[2];
-			p_dig_t->fa_th[2] =  (u16)var1[3];
+			if (var1[1] == 1) {
+				dig_t->is_dbg_fa_th = true;
+				dig_t->fa_th[0] = (u16)var1[2];
+				dig_t->fa_th[1] = (u16)var1[3];
+				dig_t->fa_th[2] = (u16)var1[4];
+
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "Set DIG fa_th[0:2]= {%d, %d, %d}\n",
+					 dig_t->fa_th[0], dig_t->fa_th[1],
+					 dig_t->fa_th[2]);
+			} else {
+				dig_t->is_dbg_fa_th = false;
+			}
+		#ifdef PHYDM_TDMA_DIG_SUPPORT
+		} else if (var1[0] == 2) {
+			dm->original_dig_restore = (u8)var1[1];
+			if (dm->original_dig_restore == 1) {
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used, "Disable TDMA-DIG\n");
+			} else {
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used, "Enable TDMA-DIG\n");
+			}
+		} else if (var1[0] == 3) {
+			dm->tdma_dig_timer_ms = (u8)var1[1];
+			PDM_SNPF(out_len, used, output + used,
+				 out_len - used, "tdma_dig_timer_ms = %d\n",
+				 dm->tdma_dig_timer_ms);
+		} else if (var1[0] == 4) {
+			dm->tdma_dig_state_number = (u8)var1[1];
+			PDM_SNPF(out_len, used, output + used,
+				 out_len - used, "tdma_dig_state_number = %d\n",
+				 dm->tdma_dig_state_number);
+		#endif
+		}
 
-			PHYDM_SNPRINTF((output + used, out_len - used,
-				"Set DIG fa_th[0:2]= {%d, %d, %d}\n", 
-				p_dig_t->fa_th[0], p_dig_t->fa_th[1], p_dig_t->fa_th[2]));
-		} else
-			p_dig_t->is_dbg_fa_th = false;
+		#ifdef CFG_DIG_DAMPING_CHK
+		else if (var1[0] == 1) {
+			dig_t->dig_dl_en = (u8)var1[1];
+			/*@*/
+		}
+		#endif
 	}
 	*_used = used;
 	*_out_len = out_len;
 }
 
+#ifdef CONFIG_MCC_DM
+#if (RTL8822B_SUPPORT)
+void phydm_mcc_igi_clr(void *dm_void, u8 clr_port)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _phydm_mcc_dm_ *mcc_dm = &dm->mcc_dm;
+	mcc_dm->mcc_rssi[clr_port] = 0xff;
+	mcc_dm->mcc_dm_val[0][clr_port] = 0xff; /* 0xc50 clr */
+	mcc_dm->mcc_dm_val[1][clr_port] = 0xff; /* 0xe50 clr */
+}
+
+void phydm_mcc_igi_chk(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _phydm_mcc_dm_ *mcc_dm = &dm->mcc_dm;
+
+	if (mcc_dm->mcc_dm_val[0][0] == 0xff &&
+	    mcc_dm->mcc_dm_val[0][1] == 0xff) {
+		mcc_dm->mcc_dm_reg[0] = 0xffff;
+		mcc_dm->mcc_reg_id[0] = 0xff;
+	}
+	if (mcc_dm->mcc_dm_val[1][0] == 0xff &&
+	    mcc_dm->mcc_dm_val[1][1] == 0xff) {
+		mcc_dm->mcc_dm_reg[1] = 0xffff;
+		mcc_dm->mcc_reg_id[1] = 0xff;
+	}
+}
+
+void phydm_mcc_igi_cal(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _phydm_mcc_dm_ *mcc_dm = &dm->mcc_dm;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	u8	shift = 0;
+	u8	igi_val0, igi_val1;
+	if (mcc_dm->mcc_rssi[0] == 0xff)
+		phydm_mcc_igi_clr(dm, 0);
+	if (mcc_dm->mcc_rssi[1] == 0xff)
+		phydm_mcc_igi_clr(dm, 1);
+	phydm_mcc_igi_chk(dm);
+	igi_val0 = mcc_dm->mcc_rssi[0] - shift;
+	igi_val1 = mcc_dm->mcc_rssi[1] - shift;
+	phydm_fill_mcccmd(dm, 0, 0xc50, igi_val0, igi_val1);
+	phydm_fill_mcccmd(dm, 1, 0xe50, igi_val0, igi_val1);
+	PHYDM_DBG(dm, DBG_COMP_MCC, "RSSI_min: %d %d, MCC_igi: %d %d\n",
+		  mcc_dm->mcc_rssi[0], mcc_dm->mcc_rssi[1],
+		  mcc_dm->mcc_dm_val[0][0], mcc_dm->mcc_dm_val[0][1]);
+}
+#endif /*#if (RTL8822B_SUPPORT)*/
+#endif /*#ifdef CONFIG_MCC_DM*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.h
index 17e25da02615..48db150a4395 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dig.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,69 +9,79 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMDIG_H__
-#define	__PHYDMDIG_H__
+#ifndef __PHYDMDIG_H__
+#define __PHYDMDIG_H__
+
+#define DIG_VERSION "2.3"
 
-/*#define DIG_VERSION	"1.4"*/		/* 2017.04.18  YuChen. refine DIG code structure*/
-/*#define DIG_VERSION	"2.0"*/		/* 2017.05.09  Dino. Move CCKPD to new files*/
-/*#define DIG_VERSION	"2.1"*/		/* 2017.06.01  YuChen. Refine DFS condition*/
-#define DIG_VERSION	"2.2"		/* 2017.06.13  YuChen. Remove MP dig*/
+#define	DIG_HW		0
+#define DIG_LIMIT_PERIOD 60 /*@60 sec*/
 
-#define DIG_HW		0
+/*@--------------------Define ---------------------------------------*/
 
-/*--------------------Define ---------------------------------------*/
+/*@=== [DIG Boundary] ========================================*/
+/*@DIG coverage mode*/
+#define	DIG_MAX_COVERAGR		0x26
+#define	DIG_MIN_COVERAGE		0x1c
+#define	DIG_MAX_OF_MIN_COVERAGE		0x22
 
-/*=== [DIG Boundary] ========================================*/
-/*DIG coverage mode*/
-#define		DIG_MAX_COVERAGR				0x26
-#define		DIG_MIN_COVERAGE				0x1c
-#define		DIG_MAX_OF_MIN_COVERAGE		0x22
-/*DIG performance mode*/
+/*@[DIG Balance mode]*/
 #if (DIG_HW == 1)
-#define		DIG_MAX_BALANCE_MODE		0x32
+#define	DIG_MAX_BALANCE_MODE		0x32
 #else
-#define		DIG_MAX_BALANCE_MODE		0x3e
+#define	DIG_MAX_BALANCE_MODE		0x3e
 #endif
-#define		DIG_MAX_OF_MIN_BALANCE_MODE		0x2a
+#define	DIG_MAX_OF_MIN_BALANCE_MODE	0x2a
 
-#define		DIG_MAX_PERFORMANCE_MODE		0x5a
-#define		DIG_MAX_OF_MIN_PERFORMANCE_MODE		0x2a	/*from 3E -> 2A, refine by YuChen 2017/04/18*/
+/*@[DIG Performance mode]*/
+#define	DIG_MAX_PERFORMANCE_MODE	0x5a
+#define	DIG_MAX_OF_MIN_PERFORMANCE_MODE	0x40	/*@[WLANBB-871]*/
+#define	DIG_MIN_PERFORMANCE		0x20
 
-#define		DIG_MIN_PERFORMANCE			0x20
+/*@DIG DFS function*/
+#define	DIG_MAX_DFS			0x28
+#define	DIG_MIN_DFS			0x20
 
-/*DIG DFS function*/
-#define		DIG_MAX_DFS					0x28
-#define		DIG_MIN_DFS					0x20
+/*@DIG LPS function*/
+#define	DIG_MAX_LPS			0x3e
+#define	DIG_MIN_LPS			0x20
 
-/*DIG LPS function*/
-#define		DIG_MAX_LPS					0x3e
-#define		DIG_MIN_LPS					0x20
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+#define DIG_NUM_OF_TDMA_STATES	2 /*@L, H state*/
+#define DIG_TIMER_MS			250
+#define	ONE_SEC_MS			1000
+#endif
 
-/*=== [DIG FA Threshold] ======================================*/
+/*@=== [DIG FA Threshold] ======================================*/
 
 /*Normal*/
-#define		DM_DIG_FA_TH0					500
-#define		DM_DIG_FA_TH1					750
-
-/*LPS*/
-#define		DM_DIG_FA_TH0_LPS			4	/* -> 4 lps */
-#define		DM_DIG_FA_TH1_LPS			15	/* -> 15 lps */
-#define		DM_DIG_FA_TH2_LPS			30	/* -> 30 lps */
+#define	DM_DIG_FA_TH0			500
+#define	DM_DIG_FA_TH1			750
 
-#define		RSSI_OFFSET_DIG_LPS			5
+/*@LPS*/
+#define	DM_DIG_FA_TH0_LPS		4	/* @-> 4 lps */
+#define	DM_DIG_FA_TH1_LPS		15	/* @-> 15 lps */
+#define	DM_DIG_FA_TH2_LPS		30	/* @-> 30 lps */
 
-/*LNA saturation check*/
-#define OFDM_AGC_TAB_0			0
-#define	OFDM_AGC_TAB_2			2
-#define	DIFF_RSSI_TO_IGI		10
-#define	ONE_SEC_MS				1000
+#define	RSSI_OFFSET_DIG_LPS		5
+#define DIG_RECORD_NUM			4
 
-/*--------------------Enum-----------------------------------*/
+/*@--------------------Enum-----------------------------------*/
 enum dig_goupcheck_level {
 	DIG_GOUPCHECK_LEVEL_0,
 	DIG_GOUPCHECK_LEVEL_1,
@@ -79,38 +90,76 @@ enum dig_goupcheck_level {
 
 enum phydm_dig_mode {
 	PHYDM_DIG_PERFORAMNCE_MODE	= 0,
-	PHYDM_DIG_COVERAGE_MODE	= 1,
+	PHYDM_DIG_COVERAGE_MODE		= 1,
 };
 
-enum lna_sat_timer_state {
-	INIT_LNA_SAT_CHK_TIMMER,
-	CANCEL_LNA_SAT_CHK_TIMMER,
-	RELEASE_LNA_SAT_CHK_TIMMER
+#ifdef PHYDM_TDMA_DIG_SUPPORT
+enum upd_type {
+	ENABLE_TDMA,
+	MODE_DECISION
 };
-/*--------------------Define Struct-----------------------------------*/
 
-struct phydm_dig_struct {
+enum tdma_opmode {
+	MODE_PERFORMANCE = 1,
+	MODE_COVERAGE = 2
+};
+
+#ifdef IS_USE_NEW_TDMA
+enum tdma_dig_timer {
+	INIT_TDMA_DIG_TIMMER,
+	CANCEL_TDMA_DIG_TIMMER,
+	RELEASE_TDMA_DIG_TIMMER
+};
+
+enum tdma_dig_state {
+	TDMA_DIG_LOW_STATE = 0,
+	TDMA_DIG_HIGH_STATE = 1,
+	NORMAL_DIG = 2
+};
+#endif
+#endif
+
+/*@--------------------Define Struct-----------------------------------*/
+#ifdef CFG_DIG_DAMPING_CHK
+struct phydm_dig_recorder_strcut {
+	u8		igi_bitmap; /*@Don't add any new parameter before this*/
+	u8		igi_history[DIG_RECORD_NUM];
+	u32		fa_history[DIG_RECORD_NUM];
+	u8		damping_limit_en;
+	u8		damping_limit_val; /*@Limit IGI_dyn_min*/
+	u32		limit_time;
+	u8		limit_rssi;
+};
+#endif
+
+struct phydm_mcc_dig {
+	u8		mcc_rssi_A;
+	u8		mcc_rssi_B;
+};
 
-	boolean	is_ignore_dig; /*for old pause function*/
-	boolean	is_dbg_fa_th;
-	u8		dig_mode_decision;
+struct phydm_dig_struct {
+#ifdef CFG_DIG_DAMPING_CHK
+	struct phydm_dig_recorder_strcut dig_recorder_t;
+	u8		dig_dl_en; /*@damping limit function enable*/
+#endif
+	boolean		is_dbg_fa_th;
 	u8		cur_ig_value;
 	u8		rvrt_val;
 	u8		igi_backup;
-	u8		rx_gain_range_max;	/*dig_dynamic_max*/
-	u8		rx_gain_range_min;	/*dig_dynamic_min*/
-	u8		dm_dig_max;			/*Absolutly upper bound*/
-	u8		dm_dig_min;			/*Absolutly lower bound*/
-	u8		dig_max_of_min;		/*Absolutly max of min*/
-	boolean	is_media_connect;
+	u8		rx_gain_range_max;	/*@dig_dynamic_max*/
+	u8		rx_gain_range_min;	/*@dig_dynamic_min*/
+	u8		dm_dig_max;		/*@Absolutly upper bound*/
+	u8		dm_dig_min;		/*@Absolutly lower bound*/
+	u8		dig_max_of_min;		/*@Absolutly max of min*/
+	boolean		is_media_connect;
 	u32		ant_div_rssi_max;
 	u8		*is_p2p_in_process;
-	u8		pause_lv_bitmap; /*bit-map of pause level*/
-	u8		pause_dig_value[PHYDM_PAUSE_MAX_NUM];
-	enum dig_goupcheck_level		dig_go_up_check_level;
-	u8		aaa_default;
+	enum dig_goupcheck_level	go_up_chk_lv;
 	u16		fa_th[3];
-#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8821C_SUPPORT ||\
+	RTL8198F_SUPPORT || RTL8192F_SUPPORT || RTL8195B_SUPPORT ||\
+	RTL8822C_SUPPORT || RTL8814B_SUPPORT || RTL8721D_SUPPORT ||\
+	RTL8812F_SUPPORT || RTL8197G_SUPPORT)
 	u8		rf_gain_idx;
 	u8		agc_table_idx;
 	u8		big_jump_lmt[16];
@@ -119,14 +168,14 @@ struct phydm_dig_struct {
 	u8		big_jump_step2:2;
 	u8		big_jump_step3:2;
 #endif
-	u8		dig_upcheck_initial_value;
-	u8		dig_level0_ratio_reciprocal;
-	u8		dig_level1_ratio_reciprocal;
+	u8		upcheck_init_val;
+	u8		lv0_ratio_reciprocal;
+	u8		lv1_ratio_reciprocal;
 #ifdef PHYDM_TDMA_DIG_SUPPORT
 	u8		cur_ig_value_tdma;
 	u8		low_ig_value;
-	u8		tdma_dig_state;	/*To distinguish which state is now.(L-sate or H-state)*/
-	u8		tdma_dig_cnt;	/*for phydm_tdma_dig_timer_check use*/
+	u8		tdma_dig_state;	/*@To distinguish which state is now.(L-sate or H-state)*/
+	u8		tdma_dig_cnt;	/*@for phydm_tdma_dig_timer_check use*/
 	u8		pre_tdma_dig_cnt;
 	u8		sec_factor;
 	u32		cur_timestamp;
@@ -134,18 +183,29 @@ struct phydm_dig_struct {
 	u32		fa_start_timestamp;
 	u32		fa_end_timestamp;
 	u32		fa_acc_1sec_timestamp;
-#endif	
+#ifdef IS_USE_NEW_TDMA
+	u8		tdma_dig_block_cnt;/*@for 1 second dump indicator use*/
+			/*@dynamic upper bound for L/H state*/
+	u8		tdma_rx_gain_max[DIG_NUM_OF_TDMA_STATES];
+			/*@dynamic lower bound for L/H state*/
+	u8		tdma_rx_gain_min[DIG_NUM_OF_TDMA_STATES];
+			/*To distinguish current state(L-sate or H-state)*/
+#endif
+#endif
 };
 
 struct phydm_fa_struct {
 	u32		cnt_parity_fail;
 	u32		cnt_rate_illegal;
 	u32		cnt_crc8_fail;
+	u32		cnt_crc8_fail_vht;
 	u32		cnt_mcs_fail;
+	u32		cnt_mcs_fail_vht;
 	u32		cnt_ofdm_fail;
-	u32		cnt_ofdm_fail_pre;	/* For RTL8881A */
+	u32		cnt_ofdm_fail_pre;	/* @For RTL8881A */
 	u32		cnt_cck_fail;
 	u32		cnt_all;
+	u32		cnt_all_accumulated;
 	u32		cnt_all_pre;
 	u32		cnt_fast_fsync;
 	u32		cnt_sb_search_fail;
@@ -166,10 +226,11 @@ struct phydm_fa_struct {
 	u32		cnt_vht_crc32_ok;
 	u32		cnt_crc32_error_all;
 	u32		cnt_crc32_ok_all;
-	boolean	cck_block_enable;
-	boolean	ofdm_block_enable;
+	u32		time_fa_all;
+	boolean		cck_block_enable;
+	boolean		ofdm_block_enable;
 	u32		dbg_port0;
-	boolean	edcca_flag;
+	boolean		edcca_flag;
 };
 
 #ifdef PHYDM_TDMA_DIG_SUPPORT
@@ -179,7 +240,7 @@ struct phydm_fa_acc_struct {
 	u32		cnt_crc8_fail;
 	u32		cnt_mcs_fail;
 	u32		cnt_ofdm_fail;
-	u32		cnt_ofdm_fail_pre;	/*For RTL8881A*/
+	u32		cnt_ofdm_fail_pre;	/*@For RTL8881A*/
 	u32		cnt_cck_fail;
 	u32		cnt_all;
 	u32		cnt_all_pre;
@@ -203,148 +264,75 @@ struct phydm_fa_acc_struct {
 	u32		cnt_cck_fail_1sec;
 };
 
-#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
-
-struct phydm_lna_sat_info_struct {
-	u32			sat_cnt_acc_patha;
-	u32			sat_cnt_acc_pathb;
-	u32			check_time;
-	boolean		pre_sat_status;
-	boolean		cur_sat_status;
-	struct timer_list	phydm_lna_sat_chk_timer;
-	u32			cur_timer_check_cnt;
-	u32			pre_timer_check_cnt;
-};
+#endif	/*@#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+/*@--------------------Function declaration-----------------------------*/
+void phydm_write_dig_reg(void *dm_void, u8 igi);
+
+void odm_write_dig(void *dm_void, u8 current_igi);
 
-/*--------------------Function declaration-----------------------------*/
-void
-odm_write_dig(
-	void					*p_dm_void,
-	u8					current_igi
-);
-
-void
-phydm_set_dig_val(
-	void			*p_dm_void,
-	u32			*val_buf,
-	u8			val_len
-);
-
-void
-odm_pause_dig(
-	void					*p_dm_void,
-	enum phydm_pause_type		pause_type,
-	enum phydm_pause_level		pause_level,
-	u8					igi_value
-);
-
-void
-phydm_dig_init(
-	void					*p_dm_void
-);
-
-void
-phydm_dig(
-	void					*p_dm_void
-);
-
-void
-phydm_dig_lps_32k(
-	void		*p_dm_void
-);
-
-void
-phydm_dig_by_rssi_lps(
-	void					*p_dm_void
-);
-
-void
-odm_false_alarm_counter_statistics(
-	void					*p_dm_void
-);
+u8 phydm_get_igi(void *dm_void, enum bb_path path);
+
+void phydm_set_dig_val(void *dm_void, u32 *val_buf, u8 val_len);
+
+void odm_pause_dig(void *dm_void, enum phydm_pause_type pause_type,
+		   enum phydm_pause_level pause_level, u8 igi_value);
+
+void phydm_dig_init(void *dm_void);
+
+void phydm_dig(void *dm_void);
+
+void phydm_dig_lps_32k(void *dm_void);
+
+void phydm_dig_by_rssi_lps(void *dm_void);
+
+void phydm_false_alarm_counter_statistics(void *dm_void);
 
 #ifdef PHYDM_TDMA_DIG_SUPPORT
-void
-phydm_set_tdma_dig_timer(
-	void					*p_dm_void
-);
-
-void
-phydm_tdma_dig_timer_check(
-	void					*p_dm_void
-);
-
-void
-phydm_tdma_dig(
-	void		*p_dm_void
-);
-
-void
-phydm_tdma_false_alarm_counter_check(
-	void		*p_dm_void
-);
-
-void
-phydm_tdma_dig_add_interrupt_mask_handler(
-	void		*p_dm_void
-);
-
-void
-phydm_false_alarm_counter_reset(
-	void		*p_dm_void
-);
-
-void
-phydm_false_alarm_counter_acc(
-	void		*p_dm_void,
-	boolean		rssi_dump_en
-	);
-
-void
-phydm_false_alarm_counter_acc_reset(
-	void		*p_dm_void
-	);
-
-#endif	/*#ifdef PHYDM_TDMA_DIG_SUPPORT*/
-
-void
-phydm_set_ofdm_agc_tab(
-	void	*p_dm_void,
-	u8		tab_sel
-);
-
-#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
-u8
-phydm_get_ofdm_agc_tab(
-	void	*p_dm_void
-);
-
-void
-phydm_lna_sat_chk(
-	void		*p_dm_void
-);
-
-void
-phydm_lna_sat_chk_timers(
-	void		*p_dm_void,
-	u8			state
-);
-
-void
-phydm_lna_sat_chk_watchdog(
-	void		*p_dm_void
-);
-
-#endif	/*#if (PHYDM_LNA_SAT_CHK_SUPPORT == 1)*/
-
-void
-phydm_dig_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
+void phydm_set_tdma_dig_timer(void *dm_void);
+
+void phydm_tdma_dig_timer_check(void *dm_void);
+
+void phydm_tdma_dig(void *dm_void);
+
+void phydm_tdma_false_alarm_counter_check(void *dm_void);
+
+void phydm_tdma_dig_add_interrupt_mask_handler(void *dm_void);
+
+void phydm_false_alarm_counter_reset(void *dm_void);
+
+void phydm_false_alarm_counter_acc(void *dm_void, boolean rssi_dump_en);
+
+void phydm_false_alarm_counter_acc_reset(void *dm_void);
+
+void phydm_tdma_dig_para_upd(void *dm_void, enum upd_type type, u8 input);
+
+#ifdef IS_USE_NEW_TDMA
+void phydm_tdma_dig_timers(void *dm_void, u8 state);
+
+void phydm_tdma_dig_cbk(void *dm_void);
+
+void phydm_tdma_dig_workitem_callback(void *dm_void);
+
+void phydm_tdma_fa_cnt_chk(void *dm_void);
+
+void phydm_tdma_low_dig(void *dm_void);
+
+void phydm_tdma_high_dig(void *dm_void);
+
+void phydm_fa_cnt_acc(void *dm_void, boolean rssi_dump_en,
+		      u8 cur_tdma_dig_state);
+#endif /*@#ifdef IS_USE_NEW_TDMA*/
+#endif /*@#ifdef PHYDM_TDMA_DIG_SUPPORT*/
+
+void phydm_set_ofdm_agc_tab(void *dm_void, u8 tab_sel);
+
+void phydm_dig_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+		     u32 *_out_len);
+
+#ifdef CONFIG_MCC_DM
+void phydm_mcc_igi_cal(void *dm_void);
+#endif
+
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamic_rx_path.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamic_rx_path.c
deleted file mode 100644
index 84b6db9846d9..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamic_rx_path.c
+++ /dev/null
@@ -1,355 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
- *
- * 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 "mp_precomp.h"
-#include "phydm_precomp.h"
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-
-void
-phydm_process_phy_status_for_dynamic_rx_path(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	void			*p_pkt_info_void
-)
-{
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_phyinfo_struct		*p_phy_info = (struct phydm_phyinfo_struct *)p_phy_info_void;
-	struct phydm_perpkt_info_struct		*p_pktinfo = (struct phydm_perpkt_info_struct *)p_pkt_info_void;
-	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(p_dm->dm_drp_table);
-	/*u8					is_cck_rate=0;*/
-
-
-
-}
-
-void
-phydm_drp_get_statistic(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DYNAMIC_RX_PATH_						*p_dm_drp_table = &(p_dm->dm_drp_table);
-	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(p_dm, PHYDM_FALSEALMCNT);
-
-	odm_false_alarm_counter_statistics(p_dm);
-
-	PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[CCA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
-		false_alm_cnt->cnt_cck_cca, false_alm_cnt->cnt_ofdm_cca, false_alm_cnt->cnt_cca_all));
-
-	PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[FA Cnt] {CCK, OFDM, Total} = {%d, %d, %d}\n",
-		false_alm_cnt->cnt_cck_fail, false_alm_cnt->cnt_ofdm_fail, false_alm_cnt->cnt_all));
-}
-
-void
-phydm_dynamic_rx_path(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(p_dm->dm_drp_table);
-	u8		training_set_timmer_en;
-	u8		curr_drp_state;
-	u32		rx_ok_cal;
-	u32		RSSI = 0;
-	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(p_dm, PHYDM_FALSEALMCNT);
-
-	if (!(p_dm->support_ability & ODM_BB_DYNAMIC_RX_PATH)) {
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[Return Init]   Not Support Dynamic RX PAth\n"));
-		return;
-	}
-
-	PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("Current drp_state = ((%d))\n", p_dm_drp_table->drp_state));
-
-	curr_drp_state = p_dm_drp_table->drp_state;
-
-	if (p_dm_drp_table->drp_state == DRP_INIT_STATE) {
-
-		phydm_drp_get_statistic(p_dm);
-
-		if (false_alm_cnt->cnt_crc32_ok_all > 20) {
-			PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[Stop DRP Training] cnt_crc32_ok_all = ((%d))\n", false_alm_cnt->cnt_crc32_ok_all));
-			p_dm_drp_table->drp_state  = DRP_INIT_STATE;
-			training_set_timmer_en = false;
-		} else {
-			PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[Start DRP Training] cnt_crc32_ok_all = ((%d))\n", false_alm_cnt->cnt_crc32_ok_all));
-			p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_0;
-			p_dm_drp_table->curr_rx_path = BB_PATH_AB;
-			training_set_timmer_en = true;
-		}
-
-	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_0) {
-
-		phydm_drp_get_statistic(p_dm);
-
-		p_dm_drp_table->curr_cca_all_cnt_0 = false_alm_cnt->cnt_cca_all;
-		p_dm_drp_table->curr_fa_all_cnt_0 = false_alm_cnt->cnt_all;
-
-		p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_1;
-		p_dm_drp_table->curr_rx_path = BB_PATH_B;
-		training_set_timmer_en = true;
-
-	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_1) {
-
-		phydm_drp_get_statistic(p_dm);
-
-		p_dm_drp_table->curr_cca_all_cnt_1 = false_alm_cnt->cnt_cca_all;
-		p_dm_drp_table->curr_fa_all_cnt_1 = false_alm_cnt->cnt_all;
-
-#if 1
-		p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
-#else
-
-		if (*(p_dm->p_mp_mode)) {
-			rx_ok_cal = p_dm->phy_dbg_info.num_qry_phy_status_cck + p_dm->phy_dbg_info.num_qry_phy_status_ofdm;
-			RSSI = (rx_ok_cal != 0) ? p_dm->rx_pwdb_ave / rx_ok_cal : 0;
-			PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("MP RSSI = ((%d))\n", RSSI));
-		}
-
-		if (RSSI > p_dm_drp_table->rssi_threshold)
-
-			p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
-
-		else  {
-
-			p_dm_drp_table->drp_state  = DRP_TRAINING_STATE_2;
-			p_dm_drp_table->curr_rx_path = BB_PATH_A;
-			training_set_timmer_en = true;
-		}
-#endif
-	} else if (p_dm_drp_table->drp_state == DRP_TRAINING_STATE_2) {
-
-		phydm_drp_get_statistic(p_dm);
-
-		p_dm_drp_table->curr_cca_all_cnt_2 = false_alm_cnt->cnt_cca_all;
-		p_dm_drp_table->curr_fa_all_cnt_2 = false_alm_cnt->cnt_all;
-		p_dm_drp_table->drp_state  = DRP_DECISION_STATE;
-	}
-
-	if (p_dm_drp_table->drp_state == DRP_DECISION_STATE) {
-
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("Current drp_state = ((%d))\n", p_dm_drp_table->drp_state));
-
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[0] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_0, p_dm_drp_table->curr_fa_all_cnt_0));
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[1] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_1, p_dm_drp_table->curr_fa_all_cnt_1));
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[2] {CCA, FA} = {%d, %d}\n", p_dm_drp_table->curr_cca_all_cnt_2, p_dm_drp_table->curr_fa_all_cnt_2));
-
-		if (p_dm_drp_table->curr_fa_all_cnt_1 < p_dm_drp_table->curr_fa_all_cnt_0) {
-
-			if ((p_dm_drp_table->curr_fa_all_cnt_0 - p_dm_drp_table->curr_fa_all_cnt_1) > p_dm_drp_table->fa_diff_threshold)
-				p_dm_drp_table->curr_rx_path = BB_PATH_B;
-			else
-				p_dm_drp_table->curr_rx_path = BB_PATH_AB;
-		} else
-			p_dm_drp_table->curr_rx_path = BB_PATH_AB;
-
-		phydm_config_ofdm_rx_path(p_dm, p_dm_drp_table->curr_rx_path);
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[Training Result]  curr_rx_path = ((%s%s)),\n",
-			((p_dm_drp_table->curr_rx_path & BB_PATH_A)  ? "A"  : " "), ((p_dm_drp_table->curr_rx_path & BB_PATH_B)  ? "B"  : " ")));
-
-		p_dm_drp_table->drp_state = DRP_INIT_STATE;
-		training_set_timmer_en = false;
-	}
-
-	PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("DRP_state: ((%d)) -> ((%d))\n", curr_drp_state, p_dm_drp_table->drp_state));
-
-	if (training_set_timmer_en) {
-
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[Training en]  curr_rx_path = ((%s%s)), training_time = ((%d ms))\n",
-			((p_dm_drp_table->curr_rx_path & BB_PATH_A)  ? "A"  : " "), ((p_dm_drp_table->curr_rx_path & BB_PATH_B)  ? "B"  : " "), p_dm_drp_table->training_time));
-
-		phydm_config_ofdm_rx_path(p_dm, p_dm_drp_table->curr_rx_path);
-		odm_set_timer(p_dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer), p_dm_drp_table->training_time); /*ms*/
-	} else
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("DRP period end\n\n", curr_drp_state, p_dm_drp_table->drp_state));
-
-}
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-phydm_dynamic_rx_path_callback(
-	struct timer_list		*p_timer
-)
-{
-	struct _ADAPTER		*adapter = (struct _ADAPTER *)p_timer->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &(p_hal_data->DM_OutSrc);
-	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table = &(p_dm->dm_drp_table);
-
-#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-#if USE_WORKITEM
-	odm_schedule_work_item(&(p_dm_drp_table->phydm_dynamic_rx_path_workitem));
-#else
-	{
-		/* dbg_print("phydm_dynamic_rx_path\n"); */
-		phydm_dynamic_rx_path(p_dm);
-	}
-#endif
-#else
-	odm_schedule_work_item(&(p_dm_drp_table->phydm_dynamic_rx_path_workitem));
-#endif
-}
-
-void
-phydm_dynamic_rx_path_workitem_callback(
-	void		*p_context
-)
-{
-	struct _ADAPTER		*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct PHY_DM_STRUCT		*p_dm = &(p_hal_data->DM_OutSrc);
-
-	/* dbg_print("phydm_dynamic_rx_path\n"); */
-	phydm_dynamic_rx_path(p_dm);
-}
-#else if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-void
-phydm_dynamic_rx_path_callback(
-	void *function_context
-)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)function_context;
-	struct _ADAPTER	*padapter = p_dm->adapter;
-
-	if (padapter->net_closed == true)
-		return;
-
-#if 0 /* Can't do I/O in timer callback*/
-	odm_s0s1_sw_ant_div(p_dm, SWAW_STEP_DETERMINE);
-#else
-	/*rtw_run_in_thread_cmd(padapter, odm_sw_antdiv_workitem_callback, padapter);*/
-#endif
-}
-
-#endif
-
-void
-phydm_dynamic_rx_path_timers(
-	void		*p_dm_void,
-	u8		state
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table	= &(p_dm->dm_drp_table);
-
-	if (state == INIT_DRP_TIMMER) {
-
-		odm_initialize_timer(p_dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer),
-			(void *)phydm_dynamic_rx_path_callback, NULL, "phydm_sw_antenna_switch_timer");
-	} else if (state == CANCEL_DRP_TIMMER)
-
-		odm_cancel_timer(p_dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer));
-
-	else if (state == RELEASE_DRP_TIMMER)
-
-		odm_release_timer(p_dm, &(p_dm_drp_table->phydm_dynamic_rx_path_timer));
-
-}
-
-void
-phydm_dynamic_rx_path_init(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DYNAMIC_RX_PATH_					*p_dm_drp_table	= &(p_dm->dm_drp_table);
-	boolean			ret_value;
-
-	if (!(p_dm->support_ability & ODM_BB_DYNAMIC_RX_PATH)) {
-		PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("[Return]   Not Support Dynamic RX PAth\n"));
-		return;
-	}
-	PHYDM_DBG(p_dm, DBG_DYN_RX_PATH, ("phydm_dynamic_rx_path_init\n"));
-
-	p_dm_drp_table->drp_state = DRP_INIT_STATE;
-	p_dm_drp_table->rssi_threshold = DRP_RSSI_TH;
-	p_dm_drp_table->fa_count_thresold = 50;
-	p_dm_drp_table->fa_diff_threshold = 50;
-	p_dm_drp_table->training_time = 100; /*ms*/
-	p_dm_drp_table->drp_skip_counter = 0;
-	p_dm_drp_table->drp_period  = 0;
-	p_dm_drp_table->drp_init_finished = true;
-
-	ret_value = phydm_api_trx_mode(p_dm, (enum bb_path)BB_PATH_AB, (enum bb_path)BB_PATH_AB, true);
-
-}
-
-void
-phydm_drp_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table = &(p_dm->dm_drp_table);
-
-	switch (dm_value[0])	{
-
-	case DRP_TRAINING_TIME:
-		p_dm_drp_table->training_time = (u16)dm_value[1];
-		break;
-	case DRP_TRAINING_PERIOD:
-		p_dm_drp_table->drp_period = (u8)dm_value[1];
-		break;
-	case DRP_RSSI_THRESHOLD:
-		p_dm_drp_table->rssi_threshold = (u8)dm_value[1];
-		break;
-	case DRP_FA_THRESHOLD:
-		p_dm_drp_table->fa_count_thresold = dm_value[1];
-		break;
-	case DRP_FA_DIFF_THRESHOLD:
-		p_dm_drp_table->fa_diff_threshold = dm_value[1];
-		break;
-	default:
-		PHYDM_SNPRINTF((output + used, out_len - used, "[DRP] unknown command\n"));
-		break;
-	}
-
-	*_used = used;
-	*_out_len = out_len;
-}
-
-void
-phydm_dynamic_rx_path_caller(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _DYNAMIC_RX_PATH_			*p_dm_drp_table	= &(p_dm->dm_drp_table);
-
-	if (p_dm_drp_table->drp_skip_counter <  p_dm_drp_table->drp_period)
-		p_dm_drp_table->drp_skip_counter++;
-	else
-		p_dm_drp_table->drp_skip_counter = 0;
-
-	if (p_dm_drp_table->drp_skip_counter != 0)
-		return;
-
-	if (p_dm_drp_table->drp_init_finished != true)
-		return;
-
-	phydm_dynamic_rx_path(p_dm);
-
-}
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamic_rx_path.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamic_rx_path.h
deleted file mode 100644
index 2b1a82d15805..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamic_rx_path.h
+++ /dev/null
@@ -1,141 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
- *
- * 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	__PHYDMDYMICRXPATH_H__
-#define    __PHYDMDYMICRXPATH_H__
-
-#define DYNAMIC_RX_PATH_VERSION	"1.0"  /*2016.07.15  Dino */
-
-
-#define	DRP_RSSI_TH	35
-
-#define INIT_DRP_TIMMER		0
-#define CANCEL_DRP_TIMMER		1
-#define RELEASE_DRP_TIMMER		2
-
-#if (RTL8822B_SUPPORT == 1)
-struct drp_rtl8822b_struct {
-	enum bb_path	path_judge;
-	u16	path_a_cck_fa;
-	u16	path_b_cck_fa;
-	
-};
-#endif
-
-#ifdef CONFIG_DYNAMIC_RX_PATH
-
-enum drp_state_e {
-	DRP_INIT_STATE				= 0,
-	DRP_TRAINING_STATE_0	= 1,
-	DRP_TRAINING_STATE_1		= 2,
-	DRP_TRAINING_STATE_2		= 3,
-	DRP_DECISION_STATE		= 4
-};
-
-enum adjustable_value_e {
-	DRP_TRAINING_TIME		= 0,
-	DRP_TRAINING_PERIOD	= 1,
-	DRP_RSSI_THRESHOLD	= 2,
-	DRP_FA_THRESHOLD		= 3,
-	DRP_FA_DIFF_THRESHOLD = 4
-};
-
-struct _DYNAMIC_RX_PATH_ {
-	u8			curr_rx_path;
-	u8			drp_state;
-	u16			training_time;
-	u8			rssi_threshold;
-	u32			fa_count_thresold;
-	u32			fa_diff_threshold;
-	u32			curr_cca_all_cnt_0;
-	u32			curr_fa_all_cnt_0;
-	u32			curr_cca_all_cnt_1;
-	u32			curr_fa_all_cnt_1;
-	u32			curr_cca_all_cnt_2;
-	u32			curr_fa_all_cnt_2;
-	u8			drp_skip_counter;
-	u8			drp_period;
-	u8			drp_init_finished;
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#if USE_WORKITEM
-	RT_WORK_ITEM	phydm_dynamic_rx_path_workitem;
-#endif
-#endif
-	struct timer_list		phydm_dynamic_rx_path_timer;
-
-};
-
-
-
-void
-phydm_process_phy_status_for_dynamic_rx_path(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	void			*p_pkt_info_void
-);
-
-void
-phydm_dynamic_rx_path(
-	void			*p_dm_void
-);
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-phydm_dynamic_rx_path_callback(
-	struct timer_list		*p_timer
-);
-
-void
-phydm_dynamic_rx_path_workitem_callback(
-	void		*p_context
-);
-
-#else if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-
-void
-phydm_dynamic_rx_path_callback(
-	void *function_context
-);
-
-#endif
-
-void
-phydm_dynamic_rx_path_timers(
-	void		*p_dm_void,
-	u8		state
-);
-
-void
-phydm_dynamic_rx_path_init(
-	void			*p_dm_void
-);
-
-void
-phydm_drp_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char			*output,
-	u32		*_out_len
-);
-
-void
-phydm_dynamic_rx_path_caller(
-	void			*p_dm_void
-);
-
-#endif
-#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.c
index cc3a149222fb..7a2d000e23c2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,449 +9,510 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
+#ifdef CONFIG_DYNAMIC_TX_TWR
+
+#ifdef BB_RAM_SUPPORT
 void
-phydm_dynamic_tx_power_init(
-	void					*p_dm_void
-)
+phydm_2ndtype_dtp_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER	*adapter = p_dm->adapter;
-	PMGNT_INFO			p_mgnt_info = &adapter->MgntInfo;
-	HAL_DATA_TYPE		*p_hal_data = GET_HAL_DATA(adapter);
-
-	/*if (!IS_HARDWARE_TYPE_8814A(adapter)) {*/
-	/*	PHYDM_DBG(p_dm,DBG_DYN_TXPWR, */
-	/*	("phydm_dynamic_tx_power_init DynamicTxPowerEnable=%d\n", p_mgnt_info->is_dynamic_tx_power_enable));*/
-	/*	return;*/
-	/*} else*/
-	{
-		p_mgnt_info->bDynamicTxPowerEnable = true;
-		PHYDM_DBG(p_dm, DBG_DYN_TXPWR,
-			("phydm_dynamic_tx_power_init DynamicTxPowerEnable=%d\n", p_mgnt_info->bDynamicTxPowerEnable));
-	}
-
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
-	if (RT_GetInterfaceSelection(adapter) == INTF_SEL1_USB_High_Power) {
-		odm_dynamic_tx_power_save_power_index(p_dm);
-		p_mgnt_info->bDynamicTxPowerEnable = true;
-	} else
-#else
-	/* so 92c pci do not need dynamic tx power? vivi check it later */
-	p_mgnt_info->bDynamicTxPowerEnable = false;
-#endif
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8	pwr_offset_minus3, pwr_offset_minus7;
+	/*@ 2's com, for offset 3dB and 7dB, which 1 step will be 0.25dB*/
+	pwr_offset_minus3 = BIT(7) | 0x74;
+	pwr_offset_minus7 = BIT(7) | 0x64;
+	odm_set_bb_reg(dm, 0x1e70, 0x00ff0000, pwr_offset_minus3);
+	odm_set_bb_reg(dm, 0x1e70, 0xff000000, pwr_offset_minus7);
+};
 
-		p_hal_data->LastDTPLvl = tx_high_pwr_level_normal;
-	p_hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
+void
+phdm_2ndtype_rd_ram_pwr(void *dm_void,	u8	macid)
+{
+};
 
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void
+phdm_2ndtype_wt_ram_pwr(void *dm_void, u8	macid, boolean pwr_offset0_en,
+			     boolean	pwr_offset1_en, s8 pwr_offset0, s8 pwr_offset1)
+{
+	u32 reg_io_0x1e84 = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_bb_ram_per_sta *dm_ram_per_sta = NULL;
+	dm_ram_per_sta = &dm->p_bb_ram_ctrl.pram_sta_ctrl[macid];
+	dm_ram_per_sta->tx_pwr_offset0_en = pwr_offset0_en;
+	dm_ram_per_sta->tx_pwr_offset1_en = pwr_offset1_en;
+	dm_ram_per_sta->tx_pwr_offset0 = pwr_offset0;
+	dm_ram_per_sta->tx_pwr_offset1 = pwr_offset1;
+	reg_io_0x1e84 = (dm_ram_per_sta->hw_igi_en<<7) + dm_ram_per_sta->hw_igi;
+	reg_io_0x1e84 |= (pwr_offset0_en<<15) + ((pwr_offset0&0x7f)<<8);
+	reg_io_0x1e84 |= (pwr_offset1_en<<23) + ((pwr_offset1&0x7f)<<16);
+	reg_io_0x1e84 |= (macid&0x3f)<<24;
+	reg_io_0x1e84 |= BIT(30);
+	odm_set_bb_reg(dm, 0x1e84, 0xffffffff, reg_io_0x1e84);
+};
+
+u8 phydm_pwr_lv_mapping_2ndtype(u8 tx_pwr_lv)
+{
+	if (tx_pwr_lv == tx_high_pwr_level_level3)
+		/*PHYDM_2ND_OFFSET_MINUS_11DB;*/
+		return PHYDM_2ND_OFFSET_MINUS_7DB;
+	else if (tx_pwr_lv == tx_high_pwr_level_level2)
+		return PHYDM_2ND_OFFSET_MINUS_7DB;
+	else if (tx_pwr_lv == tx_high_pwr_level_level1)
+		return PHYDM_2ND_OFFSET_MINUS_3DB;
+	else
+		return PHYDM_2ND_OFFSET_ZERO;
+}
 
-	p_dm->last_dtp_lvl = tx_high_pwr_level_normal;
-	p_dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
-	p_dm->tx_agc_ofdm_18_6 = odm_get_bb_reg(p_dm, 0xC24, MASKDWORD); /*TXAGC {18M 12M 9M 6M}*/
+void phydm_dtp_fill_cmninfo_2ndtype(void *dm_void, u8 macid, u8 dtp_lvl)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dtp_info *dtp = NULL;
+	dtp = &dm->phydm_sta_info[macid]->dtp_stat;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	dtp->dyn_tx_power = phydm_pwr_lv_mapping_2ndtype(dtp_lvl);
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		  "Fill cmninfo TxPwr: macid=(%d), PwrLv (%d)\n", macid,
+		  dtp->dyn_tx_power);
+	/* dyn_tx_power is 2 bit at 8822C/14B/98F/12F*/
+}
 
 #endif
 
-}
-
-void
-odm_dynamic_tx_power_save_power_index(
-	void					*p_dm_void
-)
+boolean
+phydm_check_rates(void *dm_void, u8 rate_idx)
 {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		index;
-	u32		power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 check_rate_bitmap0 = 0x08080808; /* @check CCK11M, OFDM54M, MCS7, MCS15*/
+	u32 check_rate_bitmap1 = 0x80200808; /* @check MCS23, MCS31, VHT1SS M9, VHT2SS M9*/
+	u32 check_rate_bitmap2 = 0x00080200; /* @check VHT3SS M9, VHT4SS M9*/
+	u32 bitmap_result;
+
+#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8822B) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0xfffff000;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER	*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	for (index = 0; index < 6; index++)
-		p_hal_data->PowerIndex_backup[index] = PlatformEFIORead1Byte(adapter, power_index_reg[index]);
+#if (RTL8197F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
 
+#if (RTL8192E_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8192E) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
 
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8192F) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0;
+		check_rate_bitmap0 &= 0x0fffffff;
+	}
+#endif
+#if (RTL8721D_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8721D) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0;
+		check_rate_bitmap0 &= 0x000fffff;
+	}
 #endif
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821C) {
+		check_rate_bitmap2 &= 0;
+		check_rate_bitmap1 &= 0x003ff000;
+		check_rate_bitmap0 &= 0x000fffff;
+	}
 #endif
+
+	if (rate_idx >= 64)
+		bitmap_result = BIT(rate_idx - 64) & check_rate_bitmap2;
+	else if (rate_idx >= 32)
+		bitmap_result = BIT(rate_idx - 32) & check_rate_bitmap1;
+	else if (rate_idx <= 31)
+		bitmap_result = BIT(rate_idx) & check_rate_bitmap0;
+
+	if (bitmap_result != 0)
+		return true;
+	else
+		return false;
 }
 
-void
-odm_dynamic_tx_power_restore_power_index(
-	void					*p_dm_void
-)
+enum rf_path
+phydm_check_paths(void *dm_void)
 {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			index;
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	u32			power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
-
-	for (index = 0; index < 6; index++)
-		PlatformEFIOWrite1Byte(adapter, power_index_reg[index], p_hal_data->PowerIndex_backup[index]);
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	enum rf_path max_path = RF_PATH_A;
+
+	if (dm->num_rf_path == 1)
+		max_path = RF_PATH_A;
+	if (dm->num_rf_path == 2)
+		max_path = RF_PATH_B;
+	if (dm->num_rf_path == 3)
+		max_path = RF_PATH_C;
+	if (dm->num_rf_path == 4)
+		max_path = RF_PATH_D;
+
+	return max_path;
+}
 
+#ifndef PHYDM_COMMON_API_SUPPORT
+u8 phydm_dtp_get_txagc(void *dm_void, enum rf_path path, u8 hw_rate)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 ret = 0xff;
 
+#if (RTL8192E_SUPPORT == 1)
+	ret = config_phydm_read_txagc_n(dm, path, hw_rate);
 #endif
+	return ret;
 }
+#endif
 
-void
-odm_dynamic_tx_power_write_power_index(
-	void					*p_dm_void,
-	u8		value)
+u8 phydm_search_min_power_index(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			index;
-	u32			power_index_reg[6] = {0xc90, 0xc91, 0xc92, 0xc98, 0xc99, 0xc9a};
-
-	for (index = 0; index < 6; index++)
-		/* platform_efio_write_1byte(adapter, power_index_reg[index], value); */
-		odm_write_1byte(p_dm, power_index_reg[index], value);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	enum rf_path path;
+	enum rf_path max_path;
+	u8 min_gain_index = 0x3f;
+	u8 gain_index;
+	u8 rate_idx;
+
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "%s\n", __func__);
+	max_path = phydm_check_paths(dm);
+	for (path = 0; path <= max_path; path++)
+		for (rate_idx = 0; rate_idx < 84; rate_idx++)
+			if (phydm_check_rates(dm, rate_idx)) {
+#ifdef PHYDM_COMMON_API_SUPPORT
+				/*This is for API support IC : 97F,8822B,92F,8821C*/
+				gain_index = phydm_api_get_txagc(dm, path, rate_idx);
+#else
+				/*This is for API non-support IC : 92E */
+				gain_index = phydm_dtp_get_txagc(dm, path, rate_idx);
+#endif
+				if (gain_index == 0xff) {
+					min_gain_index = 0x20;
+					PHYDM_DBG(dm, DBG_DYN_TXPWR, 
+						"Error Gain idx!! Rewite to: ((%d))\n", min_gain_index);
+					break;
+				}
+				PHYDM_DBG(dm, DBG_DYN_TXPWR,
+					  "Support Rate: ((%d)) -> Gain idx: ((%d))\n",
+					  rate_idx, gain_index);
+				if (gain_index < min_gain_index)
+					min_gain_index = gain_index;
+			}
 
+	return min_gain_index;
 }
 
-void
-odm_dynamic_tx_power_nic_ce(
-	void					*p_dm_void
-)
+void phydm_dynamic_tx_power_init(void *dm_void)
 {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-#if (RTL8821A_SUPPORT == 1)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			val;
-	u8			rssi_tmp = p_dm->rssi_min;
-
-	if (!(p_dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
-		return;
-
-	if (rssi_tmp >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
-		p_dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_level2;
-		/**/
-	} else if (rssi_tmp >= TX_POWER_NEAR_FIELD_THRESH_LVL1) {
-		p_dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_level1;
-		/**/
-	} else if (rssi_tmp < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
-		p_dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
-		/**/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i;
+	dm->last_dtp_lvl = tx_high_pwr_level_normal;
+	dm->dynamic_tx_high_power_lvl = tx_high_pwr_level_normal;
+	for (i = 0; i < 3; i++) {
+		dm->enhance_pwr_th[i] = 0xff;
 	}
+	dm->set_pwr_th[0] = TX_POWER_NEAR_FIELD_THRESH_LVL1;
+	dm->set_pwr_th[1] = TX_POWER_NEAR_FIELD_THRESH_LVL2;
+	dm->set_pwr_th[2] = 0xff;
+	dm->min_power_index = phydm_search_min_power_index(dm);
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "DTP init: Min Gain idx: ((%d))\n",
+		  dm->min_power_index);
+}
 
-	if (p_dm->last_dtp_lvl != p_dm->dynamic_tx_high_power_lvl) {
-
-		PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("update_DTP_lv: ((%d)) -> ((%d))\n", p_dm->last_dtp_lvl, p_dm->dynamic_tx_high_power_lvl));
-
-		p_dm->last_dtp_lvl = p_dm->dynamic_tx_high_power_lvl;
-
-		if (p_dm->support_ic_type & (ODM_RTL8821)) {
-
-			if (p_dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_level2) {
-
-				odm_set_mac_reg(p_dm, 0x6D8, BIT(20) | BIT19 | BIT18, 1); /* Resp TXAGC offset = -3dB*/
+void phydm_noisy_enhance_hp_th(void *dm_void, u8 noisy_state)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	if (noisy_state == 0) {
+		dm->enhance_pwr_th[0] = dm->set_pwr_th[0];
+		dm->enhance_pwr_th[1] = dm->set_pwr_th[1];
+		dm->enhance_pwr_th[2] = dm->set_pwr_th[2];
+	} else {
+		dm->enhance_pwr_th[0] = dm->set_pwr_th[0] + 8;
+		dm->enhance_pwr_th[1] = dm->set_pwr_th[1] + 5;
+		dm->enhance_pwr_th[2] = dm->set_pwr_th[2];
+	}
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		  "DTP hp_th: Lv1_th =%d ,Lv2_th = %d ,Lv3_th = %d\n",
+		  dm->enhance_pwr_th[0], dm->enhance_pwr_th[1],
+		  dm->enhance_pwr_th[2]);
+}
 
-				val = p_dm->tx_agc_ofdm_18_6 & 0xff;
-				if (val >= 0x20)
-					val -= 0x16;
+u8 phydm_pwr_lvl_check(void *dm_void, u8 input_rssi)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 th0,th1,th2;
+	th2 = dm->enhance_pwr_th[2];
+	th1 = dm->enhance_pwr_th[1];
+	th0 = dm->enhance_pwr_th[0];
+	if (input_rssi >= th2)
+		return tx_high_pwr_level_level3;
+	else if (input_rssi < (th2 - 3) && input_rssi >= th1)
+		return tx_high_pwr_level_level2;
+	else if (input_rssi < (th1 - 3) && input_rssi >= th0)
+		return tx_high_pwr_level_level1;
+	else if (input_rssi < (th0 - 3))
+		return tx_high_pwr_level_normal;
+	else
+		return tx_high_pwr_level_unchange;
+}
 
-				odm_set_bb_reg(p_dm, 0xC24, 0xff, val);
-				PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("Set TX power: level 2\n"));
-			} else if (p_dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_level1) {
+u8 phydm_pwr_lv_mapping(u8 tx_pwr_lv)
+{
+	if (tx_pwr_lv == tx_high_pwr_level_level3)
+		return PHYDM_OFFSET_MINUS_11DB;
+	else if (tx_pwr_lv == tx_high_pwr_level_level2)
+		return PHYDM_OFFSET_MINUS_7DB;
+	else if (tx_pwr_lv == tx_high_pwr_level_level1)
+		return PHYDM_OFFSET_MINUS_3DB;
+	else
+		return PHYDM_OFFSET_ZERO;
+}
 
-				odm_set_mac_reg(p_dm, 0x6D8, BIT(20) | BIT19 | BIT18, 1); /* Resp TXAGC offset = -3dB*/
+void phydm_dynamic_response_power(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rpwr;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	if (dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_unchange) {
+		dm->dynamic_tx_high_power_lvl = dm->last_dtp_lvl;
+		PHYDM_DBG(dm, DBG_DYN_TXPWR, "RespPwr not change\n");
+		return;
+	}
 
-				val = p_dm->tx_agc_ofdm_18_6 & 0xff;
-				if (val >= 0x20)
-					val -= 0x10;
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		  "RespPwr update_DTP_lv: ((%d)) -> ((%d))\n", dm->last_dtp_lvl,
+		  dm->dynamic_tx_high_power_lvl);
+	dm->last_dtp_lvl = dm->dynamic_tx_high_power_lvl;
+	rpwr = phydm_pwr_lv_mapping(dm->dynamic_tx_high_power_lvl);
+	odm_set_mac_reg(dm, ODM_REG_RESP_TX_11AC, BIT(20) | BIT(19) | BIT(18), rpwr);
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "RespPwr Set TxPwr: Lv (%d)\n",
+		  dm->dynamic_tx_high_power_lvl);
+}
 
-				odm_set_bb_reg(p_dm, 0xC24, 0xff, val);
-				PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("Set TX power: level 1\n"));
-			} else if (p_dm->dynamic_tx_high_power_lvl == tx_high_pwr_level_normal) {
+void phydm_dtp_fill_cmninfo(void *dm_void, u8 macid, u8 dtp_lvl)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dtp_info *dtp = NULL;
+	dtp = &dm->phydm_sta_info[macid]->dtp_stat;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
+	dtp->dyn_tx_power = phydm_pwr_lv_mapping(dtp_lvl);
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		  "Fill cmninfo TxPwr: macid=(%d), PwrLv (%d)\n", macid,
+		  dtp->dyn_tx_power);
+}
 
-				odm_set_mac_reg(p_dm, 0x6D8, BIT(20) | BIT19 | BIT18, 0); /* Resp TXAGC offset = 0dB*/
-				odm_set_bb_reg(p_dm, 0xC24, MASKDWORD, p_dm->tx_agc_ofdm_18_6);
-				PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("Set TX power: normal\n"));
-			}
+void phydm_dtp_per_sta(void *dm_void, u8 macid)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[macid];
+	struct dtp_info *dtp = NULL;
+	struct rssi_info *rssi = NULL;
+	if (is_sta_active(sta)) {
+		dtp = &sta->dtp_stat;
+		rssi = &sta->rssi_stat;
+		dtp->sta_tx_high_power_lvl = phydm_pwr_lvl_check(dm, rssi->rssi);
+		PHYDM_DBG(dm, DBG_DYN_TXPWR,
+			  "STA=%d , RSSI: %d , GetPwrLv: %d\n", macid,
+			  rssi->rssi, dtp->sta_tx_high_power_lvl);
+		if (dtp->sta_tx_high_power_lvl == tx_high_pwr_level_unchange 
+			|| dtp->sta_tx_high_power_lvl == dtp->sta_last_dtp_lvl) {
+			dtp->sta_tx_high_power_lvl = dtp->sta_last_dtp_lvl;
+			PHYDM_DBG(dm, DBG_DYN_TXPWR,
+				  "DTP_lv not change: ((%d))\n",
+				  dtp->sta_tx_high_power_lvl);
+			return;
 		}
-	}
 
+		PHYDM_DBG(dm, DBG_DYN_TXPWR,
+			  "DTP_lv update: ((%d)) -> ((%d))\n", dm->last_dtp_lvl,
+			  dm->dynamic_tx_high_power_lvl);
+		dtp->sta_last_dtp_lvl = dtp->sta_tx_high_power_lvl;
+#ifdef BB_RAM_SUPPORT
+		phydm_dtp_fill_cmninfo_2ndtype(dm, macid, dtp->sta_tx_high_power_lvl);
+#else
+		phydm_dtp_fill_cmninfo(dm, macid, dtp->sta_tx_high_power_lvl);
 #endif
-#endif
+	}
 }
 
 
-void
-odm_dynamic_tx_power(
-	void					*p_dm_void
-)
+void odm_set_dyntxpwr(void *dm_void, u8 *desc, u8 macid)
 {
-	/*  */
-	/* For AP/ADSL use struct rtl8192cd_priv* */
-	/* For CE/NIC use struct _ADAPTER* */
-	/*  */
-	/* struct _ADAPTER*		p_adapter = p_dm->adapter;
-	*	struct rtl8192cd_priv*	priv		= p_dm->priv; */
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (!(p_dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct dtp_info *dtp = NULL;
+	dtp = &dm->phydm_sta_info[macid]->dtp_stat;
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
 		return;
-	/*  */
-	/* 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. */
-	/*  */
-	switch	(p_dm->support_platform) {
-	case	ODM_WIN:
-		odm_dynamic_tx_power_nic(p_dm);
-		break;
-	case	ODM_CE:
-		odm_dynamic_tx_power_nic_ce(p_dm);
-		break;
-	default:
-		break;
+	if (dm->fill_desc_dyntxpwr)
+		dm->fill_desc_dyntxpwr(dm, desc, dtp->dyn_tx_power);
+	else
+		PHYDM_DBG(dm, DBG_DYN_TXPWR,
+			  "%s: fill_desc_dyntxpwr is null!\n", __func__);
+	if (dtp->last_tx_power != dtp->dyn_tx_power) {
+		PHYDM_DBG(dm, DBG_DYN_TXPWR,
+			  "%s: last_offset=%d, txpwr_offset=%d\n", __func__,
+			  dtp->last_tx_power, dtp->dyn_tx_power);
+		dtp->last_tx_power = dtp->dyn_tx_power;
 	}
-
-
 }
 
-
-void
-odm_dynamic_tx_power_nic(
-	void					*p_dm_void
-)
+void phydm_dtp_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+			     u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (!(p_dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
-		return;
-
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-
-	if (p_dm->support_ic_type == ODM_RTL8814A)
-		odm_dynamic_tx_power_8814a(p_dm);
-	else if (p_dm->support_ic_type & ODM_RTL8821) {
-		struct _ADAPTER		*adapter	 =  p_dm->adapter;
-		PMGNT_INFO		p_mgnt_info = GetDefaultMgntInfo(adapter);
-
-		if (p_mgnt_info->RegRspPwr == 1)	{
-			if (p_dm->rssi_min > 60)
-				odm_set_mac_reg(p_dm, ODM_REG_RESP_TX_11AC, BIT(20) | BIT19 | BIT18, 1); /*Resp TXAGC offset = -3dB*/
-			else if (p_dm->rssi_min < 55)
-				odm_set_mac_reg(p_dm, ODM_REG_RESP_TX_11AC, BIT(20) | BIT19 | BIT18, 0); /*Resp TXAGC offset = 0dB*/
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[3] = {0};
+	u8 set_pwr_th1, set_pwr_th2, set_pwr_th3;
+	u8 i;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Set DTP threhosld: {1} {TH[0]} {TH[1]} {TH[2]}\n");
+	} else {
+		for (i = 0; i < 3; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
+		}
+		if (var1[0] == 1) {
+			for (i = 0; i < 3; i++)
+				if (var1[i] == 0 || var1[i] > 100)
+					dm->set_pwr_th[i] = 0xff;
+				else
+					dm->set_pwr_th[i] = (u8)var1[1 + i];
+
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "DTP_TH[0:2] = {%d, %d, %d}\n",
+				 dm->set_pwr_th[0], dm->set_pwr_th[1],
+				 dm->set_pwr_th[2]);
 		}
 	}
-#endif
+	*_used = used;
+	*_out_len = out_len;
 }
 
 
-void
-odm_dynamic_tx_power_8821(
-	void			*p_dm_void,
-	u8			*p_desc,
-	u8			mac_id
-)
+void phydm_dynamic_tx_power(void *dm_void)
 {
-#if (RTL8821A_SUPPORT == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info		*p_entry;
-	u8			reg0xc56_byte;
-	u8			txpwr_offset = 0;
-
-	p_entry = p_dm->p_phydm_sta_info[mac_id];
 
-	reg0xc56_byte = odm_read_1byte(p_dm, 0xc56);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = NULL;
+	u8 i;
+	u8 cnt = 0;
+	u8 rssi_min = dm->rssi_min;
+	u8 rssi_tmp = 0;
 
-	PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("reg0xc56_byte=%d\n", reg0xc56_byte));
-
-	if (p_entry[mac_id].rssi_stat.rssi > 85) {
-
-		/* Avoid TXAGC error after TX power offset is applied.
-		For example: Reg0xc56=0x6, if txpwr_offset=3( reduce 11dB )
-		Total power = 6-11= -5( overflow!! ), PA may be burned !
-		so txpwr_offset should be adjusted by Reg0xc56*/
-
-		if (reg0xc56_byte < 7)
-			txpwr_offset = 1;
-		else if (reg0xc56_byte < 11)
-			txpwr_offset = 2;
-		else
-			txpwr_offset = 3;
-
-		SET_TX_DESC_TX_POWER_OFFSET_8812(p_desc, txpwr_offset);
-		PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("odm_dynamic_tx_power_8821: RSSI=%d, txpwr_offset=%d\n", p_entry[mac_id].rssi_stat.rssi, txpwr_offset));
-
-	} else {
-		SET_TX_DESC_TX_POWER_OFFSET_8812(p_desc, txpwr_offset);
-		PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("odm_dynamic_tx_power_8821: RSSI=%d, txpwr_offset=%d\n", p_entry[mac_id].rssi_stat.rssi, txpwr_offset));
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
 
+	PHYDM_DBG(dm, DBG_DYN_TXPWR,
+		  "[%s] RSSI_min = %d, Noisy_dec = %d\n", __func__, rssi_min,
+		  dm->noisy_decision);
+	phydm_noisy_enhance_hp_th(dm, dm->noisy_decision);
+#ifndef BB_RAM_SUPPORT
+	/* Response Power */
+	dm->dynamic_tx_high_power_lvl = phydm_pwr_lvl_check(dm, rssi_min);
+	phydm_dynamic_response_power(dm);
+#endif /* #ifndef BB_RAM_SUPPORT */
+	/* Per STA Tx power */
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		phydm_dtp_per_sta(dm, i);
+		cnt++;
+		if (cnt >= dm->number_linked_client)
+			break;
 	}
-#endif	/*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
-#endif	/*#if (RTL8821A_SUPPORT==1)*/
 }
-
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-odm_dynamic_tx_power_8814a(
-	void					*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER *adapter = p_dm->adapter;
-	PMGNT_INFO			p_mgnt_info = &adapter->MgntInfo;
-	HAL_DATA_TYPE		*p_hal_data = GET_HAL_DATA(adapter);
-	s32				undecorated_smoothed_pwdb;
-
-	PHYDM_DBG(p_dm, DBG_DYN_TXPWR,
-		("TxLevel=%d p_mgnt_info->iot_action=%x p_mgnt_info->is_dynamic_tx_power_enable=%d\n",
-		p_hal_data->DynamicTxHighPowerLvl, p_mgnt_info->IOTAction, p_mgnt_info->bDynamicTxPowerEnable));
-
-	/*STA not connected and AP not connected*/
-	if ((!p_mgnt_info->bMediaConnect) && (p_hal_data->EntryMinUndecoratedSmoothedPWDB == 0)) {
-		PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("Not connected to any reset power lvl\n"));
-		p_hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
-		return;
-	}
-
-
-	if ((p_mgnt_info->bDynamicTxPowerEnable != true) || p_mgnt_info->IOTAction & HT_IOT_ACT_DISABLE_HIGH_POWER)
-		p_hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
-	else {
-		if (p_mgnt_info->bMediaConnect) {	/*Default port*/
-			if (ACTING_AS_AP(adapter) || ACTING_AS_IBSS(adapter)) {
-				undecorated_smoothed_pwdb = p_hal_data->EntryMinUndecoratedSmoothedPWDB;
-				PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("AP Client PWDB = 0x%x\n", undecorated_smoothed_pwdb));
-			} else {
-				undecorated_smoothed_pwdb = p_hal_data->UndecoratedSmoothedPWDB;
-				PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("STA Default Port PWDB = 0x%x\n", undecorated_smoothed_pwdb));
-			}
-		} else {/*associated entry pwdb*/
-			undecorated_smoothed_pwdb = p_hal_data->EntryMinUndecoratedSmoothedPWDB;
-			PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("AP Ext Port PWDB = 0x%x\n", undecorated_smoothed_pwdb));
-		}
 
-		/*Should we separate as 2.4G/5G band?*/
-
-		if (undecorated_smoothed_pwdb >= TX_POWER_NEAR_FIELD_THRESH_LVL2) {
-			p_hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_level2;
-			PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("tx_high_pwr_level_level1 (TxPwr=0x0)\n"));
-		} else if ((undecorated_smoothed_pwdb < (TX_POWER_NEAR_FIELD_THRESH_LVL2 - 3)) &&
-			(undecorated_smoothed_pwdb >= TX_POWER_NEAR_FIELD_THRESH_LVL1)) {
-			p_hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_level1;
-			PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("tx_high_pwr_level_level1 (TxPwr=0x10)\n"));
-		} else if (undecorated_smoothed_pwdb < (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) {
-			p_hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
-			PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("tx_high_pwr_level_normal\n"));
-		}
-	}
+void phydm_dynamic_tx_power_init_win(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	PMGNT_INFO mgnt_info = &((PADAPTER)adapter)->MgntInfo;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA((PADAPTER)adapter);
 
+	mgnt_info->bDynamicTxPowerEnable = false;
 
-	if (p_hal_data->DynamicTxHighPowerLvl != p_hal_data->LastDTPLvl) {
-		PHYDM_DBG(p_dm, DBG_DYN_TXPWR, ("odm_dynamic_tx_power_8814a() channel = %d\n", p_hal_data->CurrentChannel));
-		odm_set_tx_power_level8814(adapter, p_hal_data->CurrentChannel, p_hal_data->DynamicTxHighPowerLvl);
+	#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (RT_GetInterfaceSelection((PADAPTER)adapter) ==
+	    INTF_SEL1_USB_High_Power) {
+		mgnt_info->bDynamicTxPowerEnable = true;
 	}
+	#endif
 
+	hal_data->LastDTPLvl = tx_high_pwr_level_normal;
+	hal_data->DynamicTxHighPowerLvl = tx_high_pwr_level_normal;
 
-	PHYDM_DBG(p_dm, DBG_DYN_TXPWR,
-		("odm_dynamic_tx_power_8814a() channel = %d  TXpower lvl=%d/%d\n",
-		p_hal_data->CurrentChannel, p_hal_data->LastDTPLvl, p_hal_data->DynamicTxHighPowerLvl));
-
-	p_hal_data->LastDTPLvl = p_hal_data->DynamicTxHighPowerLvl;
-
+	PHYDM_DBG(dm, DBG_DYN_TXPWR, "[%s] DTP=%d\n", __func__,
+		  mgnt_info->bDynamicTxPowerEnable);
 }
 
-
-
-/**/
-/*For normal driver we always use the FW method to configure TX power index to reduce I/O transaction.*/
-/**/
-/**/
-void
-odm_set_tx_power_level8814(
-	struct _ADAPTER		*adapter,
-	u8			channel,
-	u8			pwr_lvl
-)
+void phydm_dynamic_tx_power_win(void *dm_void)
 {
-#if (DEV_BUS_TYPE == RT_USB_INTERFACE)
-	u32			i, j, k = 0;
-	u32			value[264] = {0};
-	u32			path = 0, power_index, txagc_table_wd = 0x00801000;
-
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-
-	u8	jaguar2_rates[][4] = { {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M},
-		{MGN_6M, MGN_9M, MGN_12M, MGN_18M},
-		{MGN_24M, MGN_36M, MGN_48M, MGN_54M},
-		{MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3},
-		{MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7},
-		{MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11},
-		{MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15},
-		{MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19},
-		{MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23},
-		{MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3},
-		{MGN_VHT1SS_MCS4, MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7},
-		{MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9, MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1},
-		{MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4, MGN_VHT2SS_MCS5},
-		{MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9},
-		{MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3},
-		{MGN_VHT3SS_MCS4, MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7},
-		{MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9, 0, 0}
-	};
-
-	for (path = RF_PATH_A; path <= RF_PATH_D; ++path) {
-
-		u8	usb_host = UsbModeQueryHubUsbType(adapter);
-		u8	usb_rfset = UsbModeQueryRfSet(adapter);
-		u8	usb_rf_type = RT_GetRFType(adapter);
-
-		for (i = 0; i <= 16; i++) {
-			for (j = 0; j <= 3; j++) {
-				if (jaguar2_rates[i][j] == 0)
-					continue;
-
-				txagc_table_wd =  0x00801000;
-				power_index = (u32) PHY_GetTxPowerIndex(adapter, (u8)path, jaguar2_rates[i][j], p_hal_data->CurrentChannelBW, channel);
-
-				/*for Query bus type to recude tx power.*/
-				if (usb_host != USB_MODE_U3 && usb_rfset == 1 && IS_HARDWARE_TYPE_8814AU(adapter) && usb_rf_type == RF_3T3R) {
-					if (channel <= 14) {
-						if (power_index >= 16)
-							power_index -= 16;
-						else
-							power_index = 0;
-					} else
-						power_index = 0;
-				}
-
-				if (pwr_lvl == tx_high_pwr_level_level1) {
-					if (power_index >= 0x10)
-						power_index -= 0x10;
-					else
-						power_index = 0;
-				} else if (pwr_lvl == tx_high_pwr_level_level2)
-					power_index = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-				txagc_table_wd |= (path << 8) | MRateToHwRate(jaguar2_rates[i][j]) | (power_index << 24);
-
-				PHY_SetTxPowerIndexShadow(adapter, (u8)power_index, (u8)path, jaguar2_rates[i][j]);
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_TXPWR))
+		return;
 
-				value[k++] = txagc_table_wd;
+	#if (RTL8814A_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814A)
+		odm_dynamic_tx_power_8814a(dm);
+	#endif
+
+	#if (RTL8821A_SUPPORT == 1)
+	if (dm->support_ic_type & ODM_RTL8821) {
+		void *adapter = dm->adapter;
+		PMGNT_INFO mgnt_info = GetDefaultMgntInfo((PADAPTER)adapter);
+
+		if (mgnt_info->RegRspPwr == 1) {
+			if (dm->rssi_min > 60) {
+				/*Resp TXAGC offset = -3dB*/
+				odm_set_mac_reg(dm, 0x6d8, 0x1C0000, 1);
+			} else if (dm->rssi_min < 55) {
+				/*Resp TXAGC offset = 0dB*/
+				odm_set_mac_reg(dm, 0x6d8, 0x1C0000, 0);
 			}
 		}
 	}
-
-	if (adapter->MgntInfo.bScanInProgress == false &&  adapter->MgntInfo.RegFWOffload == 2)
-		HalDownloadTxPowerLevel8814(adapter, value);
-#endif
+	#endif
 }
-#endif
+#endif /*@#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+#endif /* @#ifdef CONFIG_DYNAMIC_TX_TWR */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.h
index c79f88c39f83..3ae624dbfa70 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_dynamictxpower.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,93 +9,96 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMDYNAMICTXPOWER_H__
-#define    __PHYDMDYNAMICTXPOWER_H__
+#ifndef __PHYDMDYNAMICTXPOWER_H__
+#define __PHYDMDYNAMICTXPOWER_H__
 
-/*#define DYNAMIC_TXPWR_VERSION	"1.0"*/
-/*#define DYNAMIC_TXPWR_VERSION	"1.3" */ /*2015.08.26, Add 8814 Dynamic TX power*/
-#define DYNAMIC_TXPWR_VERSION	"1.4" /*2015.11.06, Add CE 8821A Dynamic TX power*/
+#ifdef CONFIG_DYNAMIC_TX_TWR
+/* @============================================================
+ *  Definition
+ * ============================================================
+ */
+
+/*@#define DYNAMIC_TXPWR_VERSION	"1.0"*/
+/*@#define DYNAMIC_TXPWR_VERSION	"1.3" */ /*@2015.08.26, Add 8814 Dynamic TX power*/
+#define DYNAMIC_TXPWR_VERSION "1.4" /*@2015.11.06, Add CE 8821A Dynamic TX power*/
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
-	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	60
-	#define		TX_POWER_NEAR_FIELD_THRESH_AP	0x3F
+#define TX_POWER_NEAR_FIELD_THRESH_LVL2 74
+#define TX_POWER_NEAR_FIELD_THRESH_LVL1 60
+#define TX_POWER_NEAR_FIELD_THRESH_AP 0x3F
 #elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
-	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	67
+#define TX_POWER_NEAR_FIELD_THRESH_LVL2 74
+#define TX_POWER_NEAR_FIELD_THRESH_LVL1 67
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#define		TX_POWER_NEAR_FIELD_THRESH_LVL2	74
-	#define		TX_POWER_NEAR_FIELD_THRESH_LVL1	60
+#define TX_POWER_NEAR_FIELD_THRESH_LVL2 74
+#define TX_POWER_NEAR_FIELD_THRESH_LVL1 60
 #endif
 
-#define		tx_high_pwr_level_normal		0
-#define		tx_high_pwr_level_level1		1
-#define		tx_high_pwr_level_level2		2
-
-#define		tx_high_pwr_level_bt1			3
-#define		tx_high_pwr_level_bt2			4
-#define		tx_high_pwr_level_15			5
-#define		tx_high_pwr_level_35			6
-#define		tx_high_pwr_level_50			7
-#define		tx_high_pwr_level_70			8
-#define		tx_high_pwr_level_100			9
-
-void
-phydm_dynamic_tx_power_init(
-	void					*p_dm_void
-);
-
-void
-odm_dynamic_tx_power_restore_power_index(
-	void					*p_dm_void
-);
-
-void
-odm_dynamic_tx_power_nic(
-	void					*p_dm_void
-);
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-void
-odm_dynamic_tx_power_save_power_index(
-	void					*p_dm_void
-);
-
-void
-odm_dynamic_tx_power_write_power_index(
-	void					*p_dm_void,
-	u8		value);
-
-void
-odm_dynamic_tx_power_8821(
-	void					*p_dm_void,
-	u8					*p_desc,
-	u8					mac_id
-);
+#define tx_high_pwr_level_normal 0
+#define tx_high_pwr_level_level1 1
+#define tx_high_pwr_level_level2 2
+#define tx_high_pwr_level_level3 3
+#define tx_high_pwr_level_unchange 4
+
+/* @============================================================
+ * enumrate
+ * ============================================================
+ */
+enum phydm_dtp_power_offset {
+	PHYDM_OFFSET_ZERO = 0,
+	PHYDM_OFFSET_MINUS_3DB = 1,
+	PHYDM_OFFSET_MINUS_7DB = 2,
+	PHYDM_OFFSET_MINUS_11DB = 3,
+	PHYDM_OFFSET_ADD_3DB = 4,
+	PHYDM_OFFSET_ADD_6DB = 5
+};
+
+enum phydm_dtp_power_offset_2ndtype {
+	PHYDM_2ND_OFFSET_ZERO = 0,
+	PHYDM_2ND_OFFSET_MINUS_3DB = 2,
+	PHYDM_2ND_OFFSET_MINUS_7DB = 3,
+	PHYDM_2ND_OFFSET_MINUS_11DB = 1
+};
+
+
+/* @============================================================
+ *  structure
+ * ============================================================
+ */
+
+/* @============================================================
+ *  Function Prototype
+ * ============================================================
+ */
+
+extern void
+odm_set_dyntxpwr(void *dm_void, u8 *desc, u8 mac_id);
+
+void phydm_dynamic_tx_power(void *dm_void);
+
+void phydm_dynamic_tx_power_init(void *dm_void);
+
+void phydm_dtp_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+			     u32 *_out_len);
+
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-odm_dynamic_tx_power_8814a(
-	void					*p_dm_void
-);
-
-
-void
-odm_set_tx_power_level8814(
-	struct _ADAPTER		*adapter,
-	u8			channel,
-	u8			pwr_lvl
-);
-#endif
+void odm_dynamic_tx_power_win(void *dm_void);
 #endif
 
-void
-odm_dynamic_tx_power(
-	void					*p_dm_void
-);
-
+#endif
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features.h
index 2932582586ee..088cf2c6af72 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,35 +9,65 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDM_FEATURES_H__
-#define __PHYDM_FEATURES
+#ifndef __PHYDM_FEATURES_H__
+#define __PHYDM_FEATURES_H__
 
-#define ODM_DC_CANCELLATION_SUPPORT		(ODM_RTL8188F | ODM_RTL8710B)
+#define CONFIG_RUN_IN_DRV
+#define ODM_DC_CANCELLATION_SUPPORT		(ODM_RTL8188F | \
+						 ODM_RTL8710B | \
+						 ODM_RTL8192F | \
+						 ODM_RTL8821C | \
+						 ODM_RTL8721D)
 #define ODM_RECEIVER_BLOCKING_SUPPORT	(ODM_RTL8188E | ODM_RTL8192E)
 
-#if ((RTL8814A_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
-	#define PHYDM_LA_MODE_SUPPORT			1
-#else
-	#define PHYDM_LA_MODE_SUPPORT			0
-#endif
-
-/*20170103 YuChen add for FW API*/
-#define PHYDM_FW_API_ENABLE_8822B			1
+/*@20170103 YuChen add for FW API*/
+#define PHYDM_FW_API_ENABLE_8822B		1
 #define PHYDM_FW_API_FUNC_ENABLE_8822B		1
-#define PHYDM_FW_API_ENABLE_8821C			1
+#define PHYDM_FW_API_ENABLE_8821C		1
 #define PHYDM_FW_API_FUNC_ENABLE_8821C		1
+#define PHYDM_FW_API_ENABLE_8195B		1
+#define PHYDM_FW_API_FUNC_ENABLE_8195B		1
+#define PHYDM_FW_API_ENABLE_8198F		1
+#define PHYDM_FW_API_FUNC_ENABLE_8198F		1
+#define PHYDM_FW_API_ENABLE_8822C 1
+#define PHYDM_FW_API_FUNC_ENABLE_8822C 1
+#define PHYDM_FW_API_ENABLE_8814B 1
+#define PHYDM_FW_API_FUNC_ENABLE_8814B 1
+#define PHYDM_FW_API_ENABLE_8812F 1
+#define PHYDM_FW_API_FUNC_ENABLE_8812F 1
+
+#define CONFIG_POWERSAVING 0
+
+#ifdef BEAMFORMING_SUPPORT
+#if (BEAMFORMING_SUPPORT)
+	#define PHYDM_BEAMFORMING_SUPPORT
+#endif
+#endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 	#include	"phydm_features_win.h"
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 	#include	"phydm_features_ce.h"
+	/*@#include	"phydm_features_ce2_kernel.h"*/
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 	#include	"phydm_features_ap.h"
+#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	#include	"phydm_features_iot.h"
 #endif
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ap.h
index ac13c4edce7a..20a3c60ffc3b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ap.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ap.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -14,70 +15,140 @@
  *****************************************************************************/
 
 #ifndef	__PHYDM_FEATURES_AP_H__
-#define __PHYDM_FEATURES_AP
+#define __PHYDM_FEATURES_AP_H__
+
+#if (RTL8814A_SUPPORT || RTL8821C_SUPPORT || RTL8822B_SUPPORT ||\
+	RTL8197F_SUPPORT || RTL8192F_SUPPORT || RTL8198F_SUPPORT ||\
+	RTL8822C_SUPPORT || RTL8812F_SUPPORT || RTL8814B_SUPPORT)
+	#define PHYDM_LA_MODE_SUPPORT			1
+#else
+	#define PHYDM_LA_MODE_SUPPORT			0
+#endif
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8822B_SUPPORT || RTL8812A_SUPPORT || RTL8197F_SUPPORT ||\
+	RTL8192F_SUPPORT)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT)
 	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
 #endif
 
-#if (RTL8197F_SUPPORT == 1)
+#if (RTL8197F_SUPPORT)
 	/*#define PHYDM_TDMA_DIG_SUPPORT*/
 #endif
 
-#if (RTL8197F_SUPPORT == 1)
+#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT || RTL8812F_SUPPORT)
+	#define PHYDM_TDMA_DIG_SUPPORT 1
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	#define IS_USE_NEW_TDMA /*new tdma dig test*/
+	#endif
+#endif
+
+#if (RTL8197F_SUPPORT || RTL8822B_SUPPORT ||\
+	RTL8198F_SUPPORT || RTL8814B_SUPPORT || RTL8812F_SUPPORT)
 	#define PHYDM_LNA_SAT_CHK_SUPPORT
+	#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+
+		#if (RTL8197F_SUPPORT)
+		/*#define PHYDM_LNA_SAT_CHK_SUPPORT_TYPE1*/
+		#endif
+
+		#if (RTL8822B_SUPPORT)
+		/*#define PHYDM_LNA_SAT_CHK_TYPE2*/
+		#endif
+
+		#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT || RTL8812F_SUPPORT)
+		#define PHYDM_LNA_SAT_CHK_TYPE1
+		#endif
+	#endif
 #endif
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8822B_SUPPORT)
 	/*#define PHYDM_POWER_TRAINING_SUPPORT*/
 #endif
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8814B_SUPPORT)
+	/* #define PHYDM_PMAC_TX_SETTING_SUPPORT */
+#endif
+
+#if (RTL8814B_SUPPORT)
+	/* #define PHYDM_MP_SUPPORT */
+#endif
+
+#if (RTL8822B_SUPPORT)
 	#define PHYDM_TXA_CALIBRATION
 #endif
 
-#if (RTL8188E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
+#if (RTL8188E_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
 	#define	PHYDM_PRIMARY_CCA
 #endif
 
-#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+#if (RTL8188F_SUPPORT || RTL8710B_SUPPORT || RTL8821C_SUPPORT ||\
+	RTL8822B_SUPPORT || RTL8192F_SUPPORT)
 	#define	PHYDM_DC_CANCELLATION
 #endif
 
-#if (RTL8822B_SUPPORT == 1)
-	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+	#define	CONFIG_ADAPTIVE_SOML
+#endif
+
+#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT || RTL8881A_SUPPORT ||\
+	RTL8192E_SUPPORT || RTL8723B_SUPPORT)
+	/*#define	CONFIG_RA_FW_DBG_CODE*/
 #endif
 
-#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
-	/*#define	CONFIG_ADAPTIVE_SOML*/
+#if (RTL8192F_SUPPORT == 1)
+	/*#define	CONFIG_8912F_SPUR_CALIBRATION*/
 #endif
 
-#define PHYDM_DIG_MODE_DECISION_SUPPORT
+#if (RTL8822B_SUPPORT == 1)
+	/* #define	CONFIG_8822B_SPUR_CALIBRATION */
+#endif
+
+#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
+#define CONFIG_DYNAMIC_TX_TWR
+#endif
 /*#define	CONFIG_PSD_TOOL*/
 #define PHYDM_SUPPORT_CCKPD
-#define RA_MASK_PHYDMLIZE_AP
-/* #define	CONFIG_RA_DBG_CMD*/
-/*#define	CONFIG_RA_FW_DBG_CODE*/
-
+#define PHYDM_SUPPORT_ADAPTIVITY
 /*#define	CONFIG_PATH_DIVERSITY*/
 /*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
-#define	CONFIG_RA_DYNAMIC_RATE_ID
+/*#define	CONFIG_RA_DYNAMIC_RATE_ID*/
 #define	CONFIG_BB_TXBF_API
 /*#define	ODM_CONFIG_BT_COEXIST*/
-/*#define	PHYDM_3RD_REFORM_RA_MASK*/
-#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
 #define	PHYDM_SUPPORT_RSSI_MONITOR
 #if !defined(CONFIG_DISABLE_PHYDM_DEBUG_FUNCTION)
 	#define CONFIG_PHYDM_DEBUG_FUNCTION
 #endif
 
 /* [ Configure Antenna Diversity ] */
-#if defined(CONFIG_RTL_8881A_ANT_SWITCH) || defined(CONFIG_SLOT_0_ANT_SWITCH) || defined(CONFIG_SLOT_1_ANT_SWITCH)
+#if (RTL8188F_SUPPORT)
+	#ifdef CONFIG_ANTENNA_DIVERSITY
+		#define CONFIG_PHYDM_ANTENNA_DIVERSITY
+		#define CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	#endif
+#endif
+
+#if defined(CONFIG_RTL_8881A_ANT_SWITCH) || defined(CONFIG_SLOT_0_ANT_SWITCH) || defined(CONFIG_SLOT_1_ANT_SWITCH) || defined(CONFIG_RTL_8197F_ANT_SWITCH)
 	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
 	#define ODM_EVM_ENHANCE_ANTDIV
 	#define SKIP_EVM_ANTDIV_TRAINING_PATCH
 
 	/*----------*/
+	#ifdef CONFIG_NO_2G_DIVERSITY_8197F
+		#define CONFIG_NO_2G_DIVERSITY
+	#elif defined(CONFIG_2G_CGCS_RX_DIVERSITY_8197F)
+		#define CONFIG_2G_CGCS_RX_DIVERSITY
+	#elif defined(CONFIG_2G_CG_TRX_DIVERSITY_8197F)
+		#define CONFIG_2G_CG_TRX_DIVERSITY
+	#endif
 
 	#if (!defined(CONFIG_NO_2G_DIVERSITY) && !defined(CONFIG_2G5G_CG_TRX_DIVERSITY_8881A) && !defined(CONFIG_2G_CGCS_RX_DIVERSITY) && !defined(CONFIG_2G_CG_TRX_DIVERSITY) && !defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
 		#define CONFIG_NO_2G_DIVERSITY
@@ -113,6 +184,14 @@
 #ifdef CONFIG_SMART_ANTENNA
 	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
 #endif
+#define CFG_DIG_DAMPING_CHK
 /* --------------------------------------------------*/
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	#if (RTL8192F_SUPPORT || RTL8195B_SUPPORT || RTL8821C_SUPPORT ||\
+	     RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8198F_SUPPORT ||\
+	     RTL8814B_SUPPORT || RTL8812F_SUPPORT)
+		#define	DRIVER_BEAMFORMING_VERSION2
+	#endif
+#endif
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ce.h
index befed451388a..98635061e7cf 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ce.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,100 +9,207 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDM_FEATURES_CE_H__
-#define __PHYDM_FEATURES_CE
+#ifndef __PHYDM_FEATURES_CE_H__
+#define __PHYDM_FEATURES_CE_H__
 
-#if (RTL8822B_SUPPORT == 1)
-	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#if (RTL8814A_SUPPORT || RTL8821C_SUPPORT || RTL8822B_SUPPORT ||\
+	RTL8197F_SUPPORT || RTL8192F_SUPPORT || RTL8198F_SUPPORT ||\
+	RTL8822C_SUPPORT)
+	#define PHYDM_LA_MODE_SUPPORT			1
+#else
+	#define PHYDM_LA_MODE_SUPPORT			0
 #endif
 
-/*#define PHYDM_TDMA_DIG_SUPPORT*/
-/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+#if (RTL8822B_SUPPORT || RTL8812A_SUPPORT || RTL8197F_SUPPORT ||\
+	RTL8192F_SUPPORT)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT)
+	/*@#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+/*@#define PHYDM_TDMA_DIG_SUPPORT*/
+
+#if (RTL8822B_SUPPORT || RTL8192F_SUPPORT || RTL8821C_SUPPORT)
+	#ifdef CONFIG_TDMADIG
+	#define PHYDM_TDMA_DIG_SUPPORT
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	#define IS_USE_NEW_TDMA /*new tdma dig test*/
+	#endif
+	#endif
+#endif
+
+#if (RTL8814B_SUPPORT)
+	/*@#define PHYDM_TDMA_DIG_SUPPORT*/
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	/*@#define IS_USE_NEW_TDMA*/ /*new tdma dig test*/
+	#endif
+#endif
+
+#if (RTL8197F_SUPPORT || RTL8822B_SUPPORT || RTL8814B_SUPPORT)
+	/*@#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+	#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+
+		#if (RTL8197F_SUPPORT)
+		/*@#define PHYDM_LNA_SAT_CHK_SUPPORT_TYPE1*/
+		#endif
+
+		#if (RTL8822B_SUPPORT)
+		/*@#define PHYDM_LNA_SAT_CHK_TYPE2*/
+		#endif
+
+		#if (RTL8814B_SUPPORT)
+		/*@#define PHYDM_LNA_SAT_CHK_TYPE1*/
+		#endif
+	#endif
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8192F_SUPPORT)
 	#define PHYDM_POWER_TRAINING_SUPPORT
 #endif
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8822C_SUPPORT)
+	#define PHYDM_PMAC_TX_SETTING_SUPPORT
+#endif
+
+#if (RTL8822C_SUPPORT)
+	#define PHYDM_MP_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT)
 	#define PHYDM_TXA_CALIBRATION
 #endif
 
-#if (RTL8188E_SUPPORT == 1)
+#if (RTL8188E_SUPPORT)
 	#define	PHYDM_PRIMARY_CCA
 #endif
 
-#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+#if (RTL8188F_SUPPORT || RTL8710B_SUPPORT || RTL8821C_SUPPORT ||\
+	RTL8822B_SUPPORT || RTL8192F_SUPPORT)
 	#define	PHYDM_DC_CANCELLATION
 #endif
 
-#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
-	/*#define	CONFIG_ADAPTIVE_SOML*/
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+	#define	CONFIG_ADAPTIVE_SOML
 #endif
 
+#if (RTL8188E_SUPPORT || RTL8192E_SUPPORT)
+	#define	CONFIG_RECEIVER_BLOCKING
+#endif
 
+#if (RTL8192F_SUPPORT == 1)
+	/*#define	CONFIG_8912F_SPUR_CALIBRATION*/
+#endif
 
 #if (RTL8822B_SUPPORT == 1)
-	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+	#define	CONFIG_8822B_SPUR_CALIBRATION
 #endif
 
-#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
-	#define	CONFIG_RECEIVER_BLOCKING
+#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
+#define CONFIG_DYNAMIC_TX_TWR
 #endif
 #define PHYDM_SUPPORT_CCKPD
-#define RA_MASK_PHYDMLIZE_CE
+#define PHYDM_SUPPORT_ADAPTIVITY
 
-/*Antenna Diversity*/
+/*@Antenna Diversity*/
 #ifdef CONFIG_ANTENNA_DIVERSITY
 	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
 
 	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
 
-		#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1)
+		#if (RTL8723B_SUPPORT || RTL8821A_SUPPORT ||\
+		     RTL8188F_SUPPORT || RTL8821C_SUPPORT ||\
+		     RTL8723D_SUPPORT)
 			#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
 		#endif
 
-		#if (RTL8821A_SUPPORT == 1)
-			/*#define CONFIG_HL_SMART_ANTENNA_TYPE1*/
+		#if (RTL8821A_SUPPORT)
+			/*@#define CONFIG_HL_SMART_ANTENNA_TYPE1*/
 		#endif
 
-		#if (RTL8822B_SUPPORT == 1)
-			/*#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
+		#if (RTL8822B_SUPPORT)
+			/*@#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
 		#endif
+
 	#endif
 #endif
 
-/*[SmartAntenna]*/
-/*#define	CONFIG_SMART_ANTENNA*/
+/*@[SmartAntenna]*/
+/*@#define	CONFIG_SMART_ANTENNA*/
 #ifdef CONFIG_SMART_ANTENNA
-	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+	/*@#define	CONFIG_CUMITEK_SMART_ANTENNA*/
 #endif
-/* --------------------------------------------------*/
+/* @--------------------------------------------------*/
 
 #ifdef CONFIG_DFS_MASTER
 	#define CONFIG_PHYDM_DFS_MASTER
 #endif
 
-/*#define PHYDM_DIG_MODE_DECISION_SUPPORT*/
+#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT || RTL8881A_SUPPORT ||\
+	RTL8192E_SUPPORT || RTL8723B_SUPPORT)
+	/*@#define	CONFIG_RA_FW_DBG_CODE*/
+#endif
+
 #define	CONFIG_PSD_TOOL
-/*#define	CONFIG_RA_DBG_CMD*/
-/*#define	CONFIG_RA_FW_DBG_CODE*/
-/*#define	CONFIG_ANT_DETECTION*/
-/*#define	CONFIG_PATH_DIVERSITY*/
-/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+/*@#define	CONFIG_ANT_DETECTION*/
+/*@#define	CONFIG_PATH_DIVERSITY*/
+/*@#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
 #define	CONFIG_BB_TXBF_API
 #define	CONFIG_PHYDM_DEBUG_FUNCTION
 
 #ifdef CONFIG_BT_COEXIST
 	#define	ODM_CONFIG_BT_COEXIST
 #endif
-#define	PHYDM_3RD_REFORM_RA_MASK
-#define	PHYDM_3RD_REFORM_RSSI_MONOTOR
 #define	PHYDM_SUPPORT_RSSI_MONITOR
-/*#define	PHYDM_AUTO_DEGBUG*/
+/*@#define	PHYDM_AUTO_DEGBUG*/
+#define CFG_DIG_DAMPING_CHK
+
+
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT || RTL8192E_SUPPORT ||\
+	     RTL8814A_SUPPORT || RTL8881A_SUPPORT)
+		#define	PHYDM_BEAMFORMING_VERSION1
+	#endif
+	#if (RTL8192F_SUPPORT || RTL8195B_SUPPORT || RTL8821C_SUPPORT ||\
+	     RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8198F_SUPPORT ||\
+	     RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+		#define	DRIVER_BEAMFORMING_VERSION2
+	#endif
+#endif
+
+#if (RTL8822B_SUPPORT)
+	#ifdef CONFIG_MCC_MODE
+	#define	CONFIG_MCC_DM
+	#endif
+#endif
+
+#if (RTL8822B_SUPPORT)
+	#ifdef CONFIG_DYNAMIC_BYPASS_MODE
+	#define	CONFIG_DYNAMIC_BYPASS
+	#endif
+#endif
+
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ce2_kernel.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ce2_kernel.h
new file mode 100644
index 000000000000..b7ee91548183
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_ce2_kernel.h
@@ -0,0 +1,85 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __PHYDM_FEATURES_CE_H__
+#define __PHYDM_FEATURES_CE_H__
+
+#define PHYDM_LA_MODE_SUPPORT			0
+
+#if (RTL8822B_SUPPORT || RTL8812A_SUPPORT || RTL8197F_SUPPORT ||\
+	RTL8192F_SUPPORT)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT)
+	#define PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188F_SUPPORT || RTL8710B_SUPPORT || RTL8821C_SUPPORT ||\
+	RTL8822B_SUPPORT || RTL8192F_SUPPORT)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8192F_SUPPORT == 1)
+	/*#define	CONFIG_8912F_SPUR_CALIBRATION*/
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	/* #define	CONFIG_8822B_SPUR_CALIBRATION */
+#endif
+
+#define PHYDM_SUPPORT_CCKPD
+#define PHYDM_SUPPORT_ADAPTIVITY
+
+#ifdef CONFIG_DFS_MASTER
+	#define CONFIG_PHYDM_DFS_MASTER
+#endif
+
+#define	CONFIG_BB_TXBF_API
+#define	CONFIG_PHYDM_DEBUG_FUNCTION
+
+#ifdef CONFIG_BT_COEXIST
+	#define	ODM_CONFIG_BT_COEXIST
+#endif
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+#define CFG_DIG_DAMPING_CHK
+
+
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	#if (RTL8192F_SUPPORT || RTL8195B_SUPPORT || RTL8821C_SUPPORT ||\
+	     RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8198F_SUPPORT ||\
+	     RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+		#define	DRIVER_BEAMFORMING_VERSION2
+	#endif
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_iot.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_iot.h
new file mode 100644
index 000000000000..8cec4f9c09e5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_iot.h
@@ -0,0 +1,175 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef	__PHYDM_FEATURES_IOT_H__
+#define __PHYDM_FEATURES_IOT_H__
+
+#if (RTL8814A_SUPPORT || RTL8821C_SUPPORT || RTL8822B_SUPPORT ||\
+	RTL8197F_SUPPORT || RTL8192F_SUPPORT || RTL8198F_SUPPORT ||\
+	RTL8822C_SUPPORT || RTL8195B_SUPPORT)
+	#define PHYDM_LA_MODE_SUPPORT			1
+#else
+	#define PHYDM_LA_MODE_SUPPORT			0
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8812A_SUPPORT || RTL8197F_SUPPORT ||\
+	RTL8192F_SUPPORT)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
+
+#if (RTL8822B_SUPPORT)
+	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
+#endif
+
+/*#define PHYDM_TDMA_DIG_SUPPORT*/
+
+#if (RTL8197F_SUPPORT || RTL8822B_SUPPORT)
+	/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+	#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+		#if (RTL8197F_SUPPORT)
+		/*#define PHYDM_LNA_SAT_CHK_SUPPORT_TYPE1*/
+		#endif
+
+		#if (RTL8822B_SUPPORT)
+		/*#define PHYDM_LNA_SAT_CHK_TYPE2*/
+		#endif
+	#endif
+#endif
+
+#if (RTL8822B_SUPPORT)
+	#define PHYDM_POWER_TRAINING_SUPPORT
+#endif
+
+#if (RTL8822C_SUPPORT)
+	/* #define PHYDM_PMAC_TX_SETTING_SUPPORT */
+#endif
+
+#if (RTL8822C_SUPPORT)
+	/* #define PHYDM_MP_SUPPORT */
+#endif
+
+#if (RTL8822B_SUPPORT)
+	#define PHYDM_TXA_CALIBRATION
+#endif
+
+#if (RTL8188E_SUPPORT)
+	#define	PHYDM_PRIMARY_CCA
+#endif
+
+#if (RTL8188F_SUPPORT || RTL8710B_SUPPORT || RTL8821C_SUPPORT ||\
+	RTL8822B_SUPPORT || RTL8721D_SUPPORT)
+	#define	PHYDM_DC_CANCELLATION
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+	#define	CONFIG_ADAPTIVE_SOML
+#endif
+
+#if (RTL8822B_SUPPORT)
+	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#endif
+
+#if (RTL8822B_SUPPORT == 1)
+	/* #define	CONFIG_8822B_SPUR_CALIBRATION */
+#endif
+
+#if (RTL8188E_SUPPORT || RTL8192E_SUPPORT)
+	#define	CONFIG_RECEIVER_BLOCKING
+#endif
+
+#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
+#define CONFIG_DYNAMIC_TX_TWR
+#endif
+#define PHYDM_SUPPORT_CCKPD
+#define PHYDM_SUPPORT_ADAPTIVITY
+
+/*Antenna Diversity*/
+#ifdef CONFIG_ANTENNA_DIVERSITY
+	#define CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+
+		#if (RTL8723B_SUPPORT || RTL8821A_SUPPORT ||\
+		     RTL8188F_SUPPORT || RTL8821C_SUPPORT)
+			#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+		#endif
+
+		#if (RTL8821A_SUPPORT)
+			/*#define CONFIG_HL_SMART_ANTENNA_TYPE1*/
+		#endif
+
+		#if (RTL8822B_SUPPORT)
+			/*#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
+		#endif
+	#endif
+#endif
+
+/*[SmartAntenna]*/
+/*#define	CONFIG_SMART_ANTENNA*/
+#ifdef CONFIG_SMART_ANTENNA
+	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+#endif
+/* --------------------------------------------------*/
+
+#ifdef CONFIG_DFS_MASTER
+	#define CONFIG_PHYDM_DFS_MASTER
+#endif
+
+#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT || RTL8881A_SUPPORT ||\
+	RTL8192E_SUPPORT || RTL8723B_SUPPORT)
+	/*#define	CONFIG_RA_FW_DBG_CODE*/
+#endif
+
+#define	CONFIG_PSD_TOOL
+/*#define	CONFIG_RA_DBG_CMD*/
+/*#define	CONFIG_ANT_DETECTION*/
+/*#define	CONFIG_PATH_DIVERSITY*/
+/*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+#define	CONFIG_BB_TXBF_API
+#define	CONFIG_PHYDM_DEBUG_FUNCTION
+
+#ifdef CONFIG_BT_COEXIST
+	#define	ODM_CONFIG_BT_COEXIST
+#endif
+#define	PHYDM_SUPPORT_RSSI_MONITOR
+/*#define	PHYDM_AUTO_DEGBUG*/
+#define CFG_DIG_DAMPING_CHK
+
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	#if (RTL8192F_SUPPORT || RTL8195B_SUPPORT || RTL8821C_SUPPORT ||\
+	     RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8198F_SUPPORT ||\
+	     RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+		#define	DRIVER_BEAMFORMING_VERSION2
+	#endif
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_win.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_win.h
index f2141b59e3ca..c93dfe26f0e2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_win.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_features_win.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -14,51 +15,114 @@
  *****************************************************************************/
 
 #ifndef	__PHYDM_FEATURES_WIN_H__
-#define __PHYDM_FEATURES_WIN
+#define __PHYDM_FEATURES_WIN_H__
+
+#if (RTL8814A_SUPPORT || RTL8821C_SUPPORT || RTL8822B_SUPPORT ||\
+	RTL8197F_SUPPORT || RTL8192F_SUPPORT || RTL8198F_SUPPORT ||\
+	RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+	#define PHYDM_LA_MODE_SUPPORT			1
+#else
+	#define PHYDM_LA_MODE_SUPPORT			0
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8812A_SUPPORT || RTL8197F_SUPPORT ||\
+	RTL8192F_SUPPORT)
+	#define DYN_ANT_WEIGHTING_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT)
+	#define FAHM_SUPPORT
+#endif
+	#define NHM_SUPPORT
+	#define CLM_SUPPORT
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8822B_SUPPORT)
 	/*#define PHYDM_PHYSTAUS_SMP_MODE*/
 #endif
 
 /*#define PHYDM_TDMA_DIG_SUPPORT*/
-/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8814B_SUPPORT)
+	/*#define PHYDM_TDMA_DIG_SUPPORT*/
+	#ifdef PHYDM_TDMA_DIG_SUPPORT
+	/*#define IS_USE_NEW_TDMA*/ /*new tdma dig test*/
+	#endif
+#endif
+
+#if (RTL8197F_SUPPORT || RTL8822B_SUPPORT || RTL8814B_SUPPORT)
+	/*#define PHYDM_LNA_SAT_CHK_SUPPORT*/
+	#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+
+		#if (RTL8197F_SUPPORT)
+		/*#define PHYDM_LNA_SAT_CHK_SUPPORT_TYPE1*/
+		#endif
+
+		#if (RTL8822B_SUPPORT)
+		/*#define PHYDM_LNA_SAT_CHK_TYPE2*/
+		#endif
+
+		#if (RTL8814B_SUPPORT)
+		/*#define PHYDM_LNA_SAT_CHK_TYPE1*/
+		#endif
+	#endif
+#endif
+
+#if (RTL8822B_SUPPORT || RTL8710B_SUPPORT || RTL8723D_SUPPORT ||\
+	RTL8192F_SUPPORT)
 	#define	PHYDM_POWER_TRAINING_SUPPORT
 #endif
 
-#if (RTL8822B_SUPPORT == 1)
+#if (RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+	#define	PHYDM_PMAC_TX_SETTING_SUPPORT
+#endif
+
+#if (RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+	#define	PHYDM_MP_SUPPORT
+#endif
+
+#if (RTL8822B_SUPPORT)
 	#define	PHYDM_TXA_CALIBRATION
 #endif
 
-#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
+#if (RTL8188E_SUPPORT || RTL8192E_SUPPORT)
 	#define	PHYDM_PRIMARY_CCA
 #endif
 
-#if (RTL8188F_SUPPORT == 1 || RTL8710B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8822B_SUPPORT == 1)
+#if (RTL8188F_SUPPORT || RTL8710B_SUPPORT || RTL8821C_SUPPORT ||\
+	RTL8822B_SUPPORT || RTL8192F_SUPPORT)
 	#define	PHYDM_DC_CANCELLATION
 #endif
 
-#if (RTL8822B_SUPPORT == 1 || RTL8197F_SUPPORT == 1)
-	/*#define	CONFIG_ADAPTIVE_SOML*/
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+	#define	CONFIG_ADAPTIVE_SOML
 #endif
 
+#if (RTL8192F_SUPPORT == 1)
+	#define	CONFIG_8912F_SPUR_CALIBRATION
+#endif
 
 /*Antenna Diversity*/
 #define	CONFIG_PHYDM_ANTENNA_DIVERSITY
 #ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
 
-	#if (RTL8723B_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1)
+	#if (RTL8723B_SUPPORT || RTL8821A_SUPPORT || RTL8188F_SUPPORT ||\
+	     RTL8821C_SUPPORT)
 		#define	CONFIG_S0S1_SW_ANTENNA_DIVERSITY
 	#endif
 
+	#if (RTL8822B_SUPPORT)
+		/*#define	ODM_EVM_ENHANCE_ANTDIV*/
+		/*#define	CONFIG_2T3R_ANTENNA*/
+		/*#define	CONFIG_2T4R_ANTENNA*/
+	#endif
+
 	/* --[SmtAnt]-----------------------------------------*/
-	#if (RTL8821A_SUPPORT == 1)
+	#if (RTL8821A_SUPPORT)
 		/*#define	CONFIG_HL_SMART_ANTENNA_TYPE1*/
 		#define	CONFIG_FAT_PATCH
 	#endif
 	
-	#if (RTL8822B_SUPPORT == 1)
+	#if (RTL8822B_SUPPORT)
 		/*#define CONFIG_HL_SMART_ANTENNA_TYPE2*/
 	#endif
 	
@@ -70,37 +134,53 @@
 
 #endif
 
+#if (RTL8822C_SUPPORT)
+	#define CONFIG_PATH_DIVERSITY
+#endif
+
 /*[SmartAntenna]*/
 #define	CONFIG_SMART_ANTENNA
 #ifdef CONFIG_SMART_ANTENNA
-		/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
+	/*#define	CONFIG_CUMITEK_SMART_ANTENNA*/
 #endif
 	/* --------------------------------------------------*/
 
-#if (RTL8822B_SUPPORT == 1)
-	/*#define	CONFIG_DYNAMIC_RX_PATH*/
+#if (RTL8188E_SUPPORT || RTL8192E_SUPPORT)
+	#define	CONFIG_RECEIVER_BLOCKING
 #endif
 
-#if (RTL8188E_SUPPORT == 1 || RTL8192E_SUPPORT == 1)
-	#define	CONFIG_RECEIVER_BLOCKING
+#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT || RTL8881A_SUPPORT ||\
+	RTL8192E_SUPPORT || RTL8723B_SUPPORT)
+	#define	CONFIG_RA_FW_DBG_CODE
 #endif
 
-/*#define PHYDM_DIG_MODE_DECISION_SUPPORT	*/
+/* #ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR */
+#define CONFIG_DYNAMIC_TX_TWR
+/* #endif */
 #define	CONFIG_PSD_TOOL
+#define PHYDM_SUPPORT_ADAPTIVITY
 #define	PHYDM_SUPPORT_CCKPD
-#define	RA_MASK_PHYDMLIZE_WIN
 /*#define	CONFIG_PATH_DIVERSITY*/
 /*#define	CONFIG_RA_DYNAMIC_RTY_LIMIT*/
 #define CONFIG_ANT_DETECTION
-/*#define	CONFIG_RA_DBG_CMD*/
-#define	CONFIG_RA_FW_DBG_CODE
 #define	CONFIG_BB_TXBF_API
 #define	ODM_CONFIG_BT_COEXIST
-#define	PHYDM_3RD_REFORM_RA_MASK
-/*#define	PHYDM_3RD_REFORM_RSSI_MONOTOR*/
 #define	CONFIG_PHYDM_DFS_MASTER
 #define	PHYDM_SUPPORT_RSSI_MONITOR
 #define	PHYDM_AUTO_DEGBUG
 #define CONFIG_PHYDM_DEBUG_FUNCTION
+#define CFG_DIG_DAMPING_CHK
+
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+	#if (RTL8812A_SUPPORT || RTL8821A_SUPPORT ||  RTL8192E_SUPPORT ||\
+	     RTL8814A_SUPPORT || RTL8881A_SUPPORT)
+		#define	PHYDM_BEAMFORMING_VERSION1
+	#endif
+	#if (RTL8192F_SUPPORT || RTL8195B_SUPPORT || RTL8821C_SUPPORT ||\
+	     RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8198F_SUPPORT ||\
+	     RTL8822C_SUPPORT || RTL8814B_SUPPORT)
+		#define	DRIVER_BEAMFORMING_VERSION2
+	#endif
+#endif
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.c
index 09cd218a96d7..1788cfcb0e10 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,65 +9,73 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-#define READ_AND_CONFIG_MP(ic, txt) (odm_read_and_config_mp_##ic##txt(p_dm))
-#define READ_AND_CONFIG_TC(ic, txt) (odm_read_and_config_tc_##ic##txt(p_dm))
-
+#define READ_AND_CONFIG_MP(ic, txt) (odm_read_and_config_mp_##ic##txt(dm))
+#define READ_AND_CONFIG_TC(ic, txt) (odm_read_and_config_tc_##ic##txt(dm))
 
 #if (PHYDM_TESTCHIP_SUPPORT == 1)
-#define READ_AND_CONFIG(ic, txt) do {\
-		if (p_dm->is_mp_chip)\
-			READ_AND_CONFIG_MP(ic, txt);\
-		else\
-			READ_AND_CONFIG_TC(ic, txt);\
+#define READ_AND_CONFIG(ic, txt)                     \
+	do {                                         \
+		if (dm->is_mp_chip)                  \
+			READ_AND_CONFIG_MP(ic, txt); \
+		else                                 \
+			READ_AND_CONFIG_TC(ic, txt); \
 	} while (0)
 #else
-#define READ_AND_CONFIG     READ_AND_CONFIG_MP
+#define READ_AND_CONFIG READ_AND_CONFIG_MP
 #endif
 
-#define GET_VERSION_MP(ic, txt)		(odm_get_version_mp_##ic##txt())
-#define GET_VERSION_TC(ic, txt)		(odm_get_version_tc_##ic##txt())
+#define GET_VERSION_MP(ic, txt) (odm_get_version_mp_##ic##txt())
+#define GET_VERSION_TC(ic, txt) (odm_get_version_tc_##ic##txt())
 
 #if (PHYDM_TESTCHIP_SUPPORT == 1)
-	#define GET_VERSION(ic, txt) (p_dm->is_mp_chip ? GET_VERSION_MP(ic, txt) : GET_VERSION_TC(ic, txt))
+#define GET_VERSION(ic, txt) (dm->is_mp_chip ? GET_VERSION_MP(ic, txt) : GET_VERSION_TC(ic, txt))
 #else
-	#define GET_VERSION(ic, txt) GET_VERSION_MP(ic, txt)
+#define GET_VERSION(ic, txt) GET_VERSION_MP(ic, txt)
 #endif
 
 enum hal_status
-odm_config_rf_with_header_file(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum odm_rf_config_type		config_type,
-	u8			e_rf_path
-)
+odm_config_rf_with_header_file(struct dm_struct *dm,
+			       enum odm_rf_config_type config_type,
+			       u8 e_rf_path)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	PMGNT_INFO		p_mgnt_info = &(adapter->MgntInfo);
+	void *adapter = dm->adapter;
+	PMGNT_INFO mgnt_info = &((PADAPTER)adapter)->MgntInfo;
 #endif
-	enum hal_status	result = HAL_STATUS_SUCCESS;
+	enum hal_status result = HAL_STATUS_SUCCESS;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("===>odm_config_rf_with_header_file (%s)\n", (p_dm->is_mp_chip) ? "MPChip" : "TestChip"));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
-		p_dm->support_platform, p_dm->support_interface, p_dm->board_type));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===>%s (%s)\n", __func__,
+		  (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		  dm->support_platform, dm->support_interface, dm->board_type);
 
-	/* 1 AP doesn't use PHYDM power tracking table in these ICs */
+/* @1 AP doesn't use PHYDM power tracking table in these ICs */
 #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 #if (RTL8812A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8812) {
+	if (dm->support_ic_type == ODM_RTL8812) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8812a, _radioa);
@@ -74,10 +83,10 @@ odm_config_rf_with_header_file(
 				READ_AND_CONFIG_MP(8812a, _radiob);
 		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-			HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-			if ((p_hal_data->EEPROMSVID == 0x17AA && p_hal_data->EEPROMSMID == 0xA811) ||
-			    (p_hal_data->EEPROMSVID == 0x10EC && p_hal_data->EEPROMSMID == 0xA812) ||
-			    (p_hal_data->EEPROMSVID == 0x10EC && p_hal_data->EEPROMSMID == 0x8812))
+			HAL_DATA_TYPE * hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+			if ((hal_data->EEPROMSVID == 0x17AA && hal_data->EEPROMSMID == 0xA811) ||
+			    (hal_data->EEPROMSVID == 0x10EC && hal_data->EEPROMSMID == 0xA812) ||
+			    (hal_data->EEPROMSVID == 0x10EC && hal_data->EEPROMSMID == 0x8812))
 				READ_AND_CONFIG_MP(8812a, _txpwr_lmt_hm812a03);
 			else
 #endif
@@ -86,21 +95,21 @@ odm_config_rf_with_header_file(
 	}
 #endif
 #if (RTL8821A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821) {
+	if (dm->support_ic_type == ODM_RTL8821) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8821a, _radioa);
 		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
-			if (p_dm->support_interface == ODM_ITRF_USB) {
-				if (p_dm->ext_pa_5g || p_dm->ext_lna_5g)
+			if (dm->support_interface == ODM_ITRF_USB) {
+				if (dm->ext_pa_5g || dm->ext_lna_5g)
 					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8811a_u_fem);
 				else
 					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8811a_u_ipa);
 			} else {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-				if (p_mgnt_info->CustomerID == RT_CID_8821AE_ASUS_MB)
+				if (mgnt_info->CustomerID == RT_CID_8821AE_ASUS_MB)
 					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a_sar_8mm);
-				else if (p_mgnt_info->CustomerID == RT_CID_ASUS_NB)
+				else if (mgnt_info->CustomerID == RT_CID_ASUS_NB)
 					READ_AND_CONFIG_MP(8821a, _txpwr_lmt_8821a_sar_5mm);
 				else
 #endif
@@ -110,18 +119,18 @@ odm_config_rf_with_header_file(
 	}
 #endif
 #if (RTL8192E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8192E) {
+	if (dm->support_ic_type == ODM_RTL8192E) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8192e, _radioa);
 			else if (e_rf_path == RF_PATH_B)
 				READ_AND_CONFIG_MP(8192e, _radiob);
 		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE)	/*Refine by Vincent Lan for 5mm SAR pwr limit*/
-			HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN) && (DEV_BUS_TYPE == RT_PCI_INTERFACE) /*Refine by Vincent Lan for 5mm SAR pwr limit*/
+			HAL_DATA_TYPE * hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 
-			if ((p_hal_data->EEPROMSVID == 0x11AD && p_hal_data->EEPROMSMID == 0x8192) ||
-			    (p_hal_data->EEPROMSVID == 0x11AD && p_hal_data->EEPROMSMID == 0x8193))
+			if ((hal_data->EEPROMSVID == 0x11AD && hal_data->EEPROMSMID == 0x8192) ||
+			    (hal_data->EEPROMSVID == 0x11AD && hal_data->EEPROMSMID == 0x8193))
 				READ_AND_CONFIG_MP(8192e, _txpwr_lmt_8192e_sar_5mm);
 			else
 #endif
@@ -130,17 +139,18 @@ odm_config_rf_with_header_file(
 	}
 #endif
 #if (RTL8723D_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723D) {
+	if (dm->support_ic_type == ODM_RTL8723D) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8723d, _radioa);
-		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
 			READ_AND_CONFIG_MP(8723d, _txpwr_lmt);
+		}
 	}
 #endif
-/* JJ ADD 20161014 */
+/* @JJ ADD 20161014 */
 #if (RTL8710B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8710B) {
+	if (dm->support_ic_type == ODM_RTL8710B) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8710b, _radioa);
@@ -149,11 +159,10 @@ odm_config_rf_with_header_file(
 	}
 #endif
 
-#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
-
-	/* 1 All platforms support */
+#endif /* @(DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+/* @1 All platforms support */
 #if (RTL8188E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
+	if (dm->support_ic_type == ODM_RTL8188E) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8188e, _radioa);
@@ -162,7 +171,7 @@ odm_config_rf_with_header_file(
 	}
 #endif
 #if (RTL8723B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723B) {
+	if (dm->support_ic_type == ODM_RTL8723B) {
 		if (config_type == CONFIG_RF_RADIO)
 			READ_AND_CONFIG_MP(8723b, _radioa);
 		else if (config_type == CONFIG_RF_TXPWR_LMT)
@@ -170,7 +179,7 @@ odm_config_rf_with_header_file(
 	}
 #endif
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8814A) {
+	if (dm->support_ic_type == ODM_RTL8814A) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8814a, _radioa);
@@ -181,27 +190,27 @@ odm_config_rf_with_header_file(
 			else if (e_rf_path == RF_PATH_D)
 				READ_AND_CONFIG_MP(8814a, _radiod);
 		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
-			if (p_dm->rfe_type == 0)
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type0);
-			else if (p_dm->rfe_type == 1)
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type1);				
-			else if (p_dm->rfe_type == 2)
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type2);		
-			else if (p_dm->rfe_type == 3)
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type3);		
-			else if (p_dm->rfe_type == 5)
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type5);		
-			else if (p_dm->rfe_type == 7)
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type7);
-			else if (p_dm->rfe_type == 8)
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt_type8);
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt_type0);
+			else if (dm->rfe_type == 1)
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt_type1);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt_type3);
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt_type5);
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt_type8);
 			else
-				READ_AND_CONFIG_MP(8814a,_txpwr_lmt);
+				READ_AND_CONFIG_MP(8814a, _txpwr_lmt);
 		}
 	}
 #endif
 #if (RTL8703B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8703B) {
+	if (dm->support_ic_type == ODM_RTL8703B) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8703b, _radioa);
@@ -209,7 +218,7 @@ odm_config_rf_with_header_file(
 	}
 #endif
 #if (RTL8188F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188F) {
+	if (dm->support_ic_type == ODM_RTL8188F) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8188f, _radioa);
@@ -218,29 +227,31 @@ odm_config_rf_with_header_file(
 	}
 #endif
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8822B) {
+	if (dm->support_ic_type == ODM_RTL8822B) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8822b, _radioa);
 			else if (e_rf_path == RF_PATH_B)
 				READ_AND_CONFIG_MP(8822b, _radiob);
 		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
-			if (p_dm->rfe_type == 5)
+			if (dm->rfe_type == 5)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type5);
-			else if (p_dm->rfe_type == 2)
+			else if (dm->rfe_type == 2)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type2);
-			else if (p_dm->rfe_type == 3)
+			else if (dm->rfe_type == 3)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type3);
-			else if (p_dm->rfe_type == 4)
+			else if (dm->rfe_type == 4)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type4);
-			else if (p_dm->rfe_type == 12)
+			else if (dm->rfe_type == 12)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type12);
-			else if (p_dm->rfe_type == 15)
+			else if (dm->rfe_type == 15)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type15);
-			else if (p_dm->rfe_type == 16)
+			else if (dm->rfe_type == 16)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type16);
-			else if (p_dm->rfe_type == 17)
+			else if (dm->rfe_type == 17)
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type17);
+			else if (dm->rfe_type == 18)
+				READ_AND_CONFIG_MP(8822b, _txpwr_lmt_type18);
 			else
 				READ_AND_CONFIG_MP(8822b, _txpwr_lmt);
 		}
@@ -248,7 +259,7 @@ odm_config_rf_with_header_file(
 #endif
 
 #if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8197F) {
+	if (dm->support_ic_type == ODM_RTL8197F) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG_MP(8197f, _radioa);
@@ -257,29 +268,200 @@ odm_config_rf_with_header_file(
 		}
 	}
 #endif
-
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192F) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8192f, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8192f, _radiob);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type0);
+			else if (dm->rfe_type == 1)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type1);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type3);
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type4);
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type5);
+			else if (dm->rfe_type == 6)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type6);
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type8);
+			else if (dm->rfe_type == 9)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type9);
+			else if (dm->rfe_type == 10)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type10);
+			else if (dm->rfe_type == 11)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type11);
+			else if (dm->rfe_type == 12)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type12);
+			else if (dm->rfe_type == 13)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type13);
+			else if (dm->rfe_type == 14)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type14);
+			else if (dm->rfe_type == 15)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type15);
+			else if (dm->rfe_type == 16)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type16);
+			else if (dm->rfe_type == 17)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type17);
+			else if (dm->rfe_type == 18)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type18);
+			else if (dm->rfe_type == 19)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type19);
+			else if (dm->rfe_type == 20)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type20);
+			else if (dm->rfe_type == 21)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type21);
+			else if (dm->rfe_type == 22)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type22);
+			else if (dm->rfe_type == 23)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type23);
+			else if (dm->rfe_type == 24)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type24);
+			else if (dm->rfe_type == 25)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type25);
+			else if (dm->rfe_type == 26)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type26);
+			else if (dm->rfe_type == 27)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type27);
+			else if (dm->rfe_type == 28)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type28);
+			else if (dm->rfe_type == 29)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type29);
+			else if (dm->rfe_type == 30)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type30);
+			else if (dm->rfe_type == 31)
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt_type31);
+			else
+				READ_AND_CONFIG_MP(8192f, _txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8721D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8721D) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8721d, _radioa);
+		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+			READ_AND_CONFIG_MP(8721d, _txpwr_lmt);
+	}
+#endif
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C) {
+	if (dm->support_ic_type == ODM_RTL8821C) {
 		if (config_type == CONFIG_RF_RADIO) {
 			if (e_rf_path == RF_PATH_A)
 				READ_AND_CONFIG(8821c, _radioa);
-		} else if (config_type == CONFIG_RF_TXPWR_LMT)
+		} else if (config_type == CONFIG_RF_TXPWR_LMT) {
 			READ_AND_CONFIG(8821c, _txpwr_lmt);
+		}
+	}
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG(8195b, _radioa);
+		}
+		#if 0
+		else if (config_type == CONFIG_RF_TXPWR_LMT) {
+			READ_AND_CONFIG(8821c, _txpwr_lmt);
+			/*@*/
+		}
+		#endif
+	}
+#endif
+#if (RTL8198F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8198F) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8198f, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8198f, _radiob);
+			else if (e_rf_path == RF_PATH_C)
+				READ_AND_CONFIG_MP(8198f, _radioc);
+			else if (e_rf_path == RF_PATH_D)
+				READ_AND_CONFIG_MP(8198f, _radiod);
+		}
+	}
+#endif
+/*#if (RTL8814B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8814b, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8814b, _radiob);
+			else if (e_rf_path == RF_PATH_C)
+				READ_AND_CONFIG_MP(8814b, _radioc);
+			else if (e_rf_path == RF_PATH_D)
+				READ_AND_CONFIG_MP(8814b, _radiod);
+		}
+	}
+#endif
+*/
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8822C) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8822c, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8822c, _radiob);
+		}
+	}
+#endif
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8812F) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8812f, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8812f, _radiob);
+		}
 	}
 #endif
 
+ /*8814B need review, when phydm has related files*/
+ #if (RTL8814B_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8814B) {
+		if (config_type == CONFIG_RF_RADIO) {
+			if (e_rf_path == RF_PATH_A)
+				READ_AND_CONFIG_MP(8814b, _radioa);
+			else if (e_rf_path == RF_PATH_B)
+				READ_AND_CONFIG_MP(8814b, _radiob);
+			else if (e_rf_path == RF_PATH_C)
+				READ_AND_CONFIG_MP(8814b, _radioc);
+			else if (e_rf_path == RF_PATH_D)
+				READ_AND_CONFIG_MP(8814b, _radiod);
+		}
+		if (config_type == CONFIG_RF_SYN_RADIO) {
+			if (e_rf_path == RF_SYN0)
+				READ_AND_CONFIG_MP(8814b, _radiosyn0);
+			else if (e_rf_path == RF_SYN1)
+				READ_AND_CONFIG_MP(8814b, _radiosyn1);
+		}
+	}
+  #endif
+
 	if (config_type == CONFIG_RF_RADIO) {
-		if (p_dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
-
-			result = phydm_set_reg_by_fw(p_dm,
-							PHYDM_HALMAC_CMD_END,
-							0,
-							0,
-							0,
-							(enum rf_path)0,
-							0);
-			PHYDM_DBG(p_dm, ODM_COMP_INIT,
-				("rf param offload end!result = %d", result));
+		if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+			result = phydm_set_reg_by_fw(dm,
+						     PHYDM_HALMAC_CMD_END,
+						     0,
+						     0,
+						     0,
+						     (enum rf_path)0,
+						     0);
+			PHYDM_DBG(dm, ODM_COMP_INIT,
+				  "rf param offload end!result = %d", result);
 		}
 	}
 
@@ -287,122 +469,113 @@ odm_config_rf_with_header_file(
 }
 
 enum hal_status
-odm_config_rf_with_tx_pwr_track_header_file(
-	struct PHY_DM_STRUCT		*p_dm
-)
+odm_config_rf_with_tx_pwr_track_header_file(struct dm_struct *dm)
 {
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("===>odm_config_rf_with_tx_pwr_track_header_file (%s)\n", (p_dm->is_mp_chip) ? "MPChip" : "TestChip"));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
-		p_dm->support_platform, p_dm->support_interface, p_dm->board_type));
-
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===>%s (%s)\n", __func__,
+		  (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		  dm->support_platform, dm->support_interface, dm->board_type);
 
-	/* 1 AP doesn't use PHYDM power tracking table in these ICs */
+/* @1 AP doesn't use PHYDM power tracking table in these ICs */
 #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 #if RTL8821A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8821) {
-		if (p_dm->support_interface == ODM_ITRF_PCIE)
+	if (dm->support_ic_type == ODM_RTL8821) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
 			READ_AND_CONFIG_MP(8821a, _txpowertrack_pcie);
-		else if (p_dm->support_interface == ODM_ITRF_USB)
+		else if (dm->support_interface == ODM_ITRF_USB)
 			READ_AND_CONFIG_MP(8821a, _txpowertrack_usb);
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
+		else if (dm->support_interface == ODM_ITRF_SDIO)
 			READ_AND_CONFIG_MP(8821a, _txpowertrack_sdio);
 	}
 #endif
 #if RTL8812A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8812) {
-		if (p_dm->support_interface == ODM_ITRF_PCIE)
+	if (dm->support_ic_type == ODM_RTL8812) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
 			READ_AND_CONFIG_MP(8812a, _txpowertrack_pcie);
-		else if (p_dm->support_interface == ODM_ITRF_USB) {
-			if (p_dm->rfe_type == 3 && p_dm->is_mp_chip)
+		else if (dm->support_interface == ODM_ITRF_USB) {
+			if (dm->rfe_type == 3 && dm->is_mp_chip)
 				READ_AND_CONFIG_MP(8812a, _txpowertrack_rfe3);
 			else
 				READ_AND_CONFIG_MP(8812a, _txpowertrack_usb);
 		}
-
 	}
 #endif
 #if RTL8192E_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8192E) {
-		if (p_dm->support_interface == ODM_ITRF_PCIE)
+	if (dm->support_ic_type == ODM_RTL8192E) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
 			READ_AND_CONFIG_MP(8192e, _txpowertrack_pcie);
-		else if (p_dm->support_interface == ODM_ITRF_USB)
+		else if (dm->support_interface == ODM_ITRF_USB)
 			READ_AND_CONFIG_MP(8192e, _txpowertrack_usb);
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
+		else if (dm->support_interface == ODM_ITRF_SDIO)
 			READ_AND_CONFIG_MP(8192e, _txpowertrack_sdio);
 	}
 #endif
 #if RTL8723D_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8723D) {
-		if (p_dm->support_interface == ODM_ITRF_PCIE)
+	if (dm->support_ic_type == ODM_RTL8723D) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
 			READ_AND_CONFIG_MP(8723d, _txpowertrack_pcie);
-		else if (p_dm->support_interface == ODM_ITRF_USB)
+		else if (dm->support_interface == ODM_ITRF_USB)
 			READ_AND_CONFIG_MP(8723d, _txpowertrack_usb);
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
+		else if (dm->support_interface == ODM_ITRF_SDIO)
 			READ_AND_CONFIG_MP(8723d, _txpowertrack_sdio);
 
 		READ_AND_CONFIG_MP(8723d, _txxtaltrack);
 	}
 #endif
-/* JJ ADD 20161014 */
+/* @JJ ADD 20161014 */
 #if RTL8710B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8710B) {
-		if (p_dm->support_interface == ODM_ITRF_PCIE)
-			READ_AND_CONFIG_MP(8710b, _txpowertrack_pcie);
-		else if (p_dm->support_interface == ODM_ITRF_USB)
-			READ_AND_CONFIG_MP(8710b, _txpowertrack_usb);
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
-			READ_AND_CONFIG_MP(8710b, _txpowertrack_sdio);
+	if (dm->support_ic_type == ODM_RTL8710B) {
+		if (dm->package_type == 1)
+			READ_AND_CONFIG_MP(8710b, _txpowertrack_qfn48m_smic);
+		else if (dm->package_type == 5)
+			READ_AND_CONFIG_MP(8710b, _txpowertrack_qfn48m_umc);
 
 		READ_AND_CONFIG_MP(8710b, _txxtaltrack);
 	}
 #endif
-
 #if RTL8188E_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
-		if (odm_get_mac_reg(p_dm, 0xF0, 0xF000) >= 8) {		/*if 0xF0[15:12] >= 8, SMIC*/
-			if (p_dm->support_interface == ODM_ITRF_PCIE)
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (odm_get_mac_reg(dm, R_0xf0, 0xF000) >= 8) { /*@if 0xF0[15:12] >= 8, SMIC*/
+			if (dm->support_interface == ODM_ITRF_PCIE)
 				READ_AND_CONFIG_MP(8188e, _txpowertrack_pcie_icut);
-			else if (p_dm->support_interface == ODM_ITRF_USB)
+			else if (dm->support_interface == ODM_ITRF_USB)
 				READ_AND_CONFIG_MP(8188e, _txpowertrack_usb_icut);
-			else if (p_dm->support_interface == ODM_ITRF_SDIO)
+			else if (dm->support_interface == ODM_ITRF_SDIO)
 				READ_AND_CONFIG_MP(8188e, _txpowertrack_sdio_icut);
-		} else {	/*else 0xF0[15:12] < 8, TSMC*/
-			if (p_dm->support_interface == ODM_ITRF_PCIE)
+		} else { /*@else 0xF0[15:12] < 8, TSMC*/
+			if (dm->support_interface == ODM_ITRF_PCIE)
 				READ_AND_CONFIG_MP(8188e, _txpowertrack_pcie);
-			else if (p_dm->support_interface == ODM_ITRF_USB)
+			else if (dm->support_interface == ODM_ITRF_USB)
 				READ_AND_CONFIG_MP(8188e, _txpowertrack_usb);
-			else if (p_dm->support_interface == ODM_ITRF_SDIO)
+			else if (dm->support_interface == ODM_ITRF_SDIO)
 				READ_AND_CONFIG_MP(8188e, _txpowertrack_sdio);
 		}
-
 	}
 #endif
-#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
-
-	/* 1 All platforms support */
+#endif /* @(DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+/* @1 All platforms support */
 #if RTL8723B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8723B) {
-		if (p_dm->support_interface == ODM_ITRF_PCIE)
+	if (dm->support_ic_type == ODM_RTL8723B) {
+		if (dm->support_interface == ODM_ITRF_PCIE)
 			READ_AND_CONFIG_MP(8723b, _txpowertrack_pcie);
-		else if (p_dm->support_interface == ODM_ITRF_USB)
+		else if (dm->support_interface == ODM_ITRF_USB)
 			READ_AND_CONFIG_MP(8723b, _txpowertrack_usb);
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
+		else if (dm->support_interface == ODM_ITRF_SDIO)
 			READ_AND_CONFIG_MP(8723b, _txpowertrack_sdio);
 	}
 #endif
 #if RTL8814A_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8814A) {
-		if (p_dm->rfe_type == 0)
+	if (dm->support_ic_type == ODM_RTL8814A) {
+		if (dm->rfe_type == 0)
 			READ_AND_CONFIG_MP(8814a, _txpowertrack_type0);
-		else if (p_dm->rfe_type == 2)
+		else if (dm->rfe_type == 2)
 			READ_AND_CONFIG_MP(8814a, _txpowertrack_type2);
-		else if (p_dm->rfe_type == 5)
+		else if (dm->rfe_type == 5)
 			READ_AND_CONFIG_MP(8814a, _txpowertrack_type5);
-		else if (p_dm->rfe_type == 7)
+		else if (dm->rfe_type == 7)
 			READ_AND_CONFIG_MP(8814a, _txpowertrack_type7);
-		else if (p_dm->rfe_type == 8)
+		else if (dm->rfe_type == 8)
 			READ_AND_CONFIG_MP(8814a, _txpowertrack_type8);
 		else
 			READ_AND_CONFIG_MP(8814a, _txpowertrack);
@@ -411,124 +584,228 @@ odm_config_rf_with_tx_pwr_track_header_file(
 	}
 #endif
 #if RTL8703B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8703B) {
-		if (p_dm->support_interface == ODM_ITRF_USB)
+	if (dm->support_ic_type == ODM_RTL8703B) {
+		if (dm->support_interface == ODM_ITRF_USB)
 			READ_AND_CONFIG_MP(8703b, _txpowertrack_usb);
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
+		else if (dm->support_interface == ODM_ITRF_SDIO)
 			READ_AND_CONFIG_MP(8703b, _txpowertrack_sdio);
 
 		READ_AND_CONFIG_MP(8703b, _txxtaltrack);
 	}
 #endif
-
 #if RTL8188F_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8188F) {
-		if (p_dm->support_interface == ODM_ITRF_USB)
+	if (dm->support_ic_type == ODM_RTL8188F) {
+		if (dm->support_interface == ODM_ITRF_USB)
 			READ_AND_CONFIG_MP(8188f, _txpowertrack_usb);
-		else if (p_dm->support_interface == ODM_ITRF_SDIO)
+		else if (dm->support_interface == ODM_ITRF_SDIO)
 			READ_AND_CONFIG_MP(8188f, _txpowertrack_sdio);
 	}
 #endif
-
 #if RTL8822B_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8822B) {
-		if (p_dm->rfe_type == 0)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (dm->rfe_type == 0)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type0);
-		else if (p_dm->rfe_type == 1)
+		else if (dm->rfe_type == 1)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type1);
-		else if (p_dm->rfe_type == 2)
+		else if (dm->rfe_type == 2)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type2);
-		else if ((p_dm->rfe_type == 3) || (p_dm->rfe_type == 5))
+		else if ((dm->rfe_type == 3) || (dm->rfe_type == 5))
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type3_type5);
-		else if (p_dm->rfe_type == 4)
+		else if (dm->rfe_type == 4)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type4);
-		else if (p_dm->rfe_type == 6)
+		else if (dm->rfe_type == 6)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type6);
-		else if (p_dm->rfe_type == 7)
+		else if (dm->rfe_type == 7)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type7);
-		else if (p_dm->rfe_type == 8)
+		else if (dm->rfe_type == 8)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type8);
-		else if (p_dm->rfe_type == 9)
+		else if (dm->rfe_type == 9)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type9);
-		else if (p_dm->rfe_type == 10)
+		else if (dm->rfe_type == 10)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type10);
-		else if (p_dm->rfe_type == 11)
+		else if (dm->rfe_type == 11)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type11);
-		else if (p_dm->rfe_type == 12)
+		else if (dm->rfe_type == 12)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type12);
-		else if (p_dm->rfe_type == 13)
+		else if (dm->rfe_type == 13)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type13);
-		else if (p_dm->rfe_type == 14)
+		else if (dm->rfe_type == 14)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type14);
-		else if (p_dm->rfe_type == 15)
+		else if (dm->rfe_type == 15)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type15);
-		else if (p_dm->rfe_type == 16)
+		else if (dm->rfe_type == 16)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type16);
-		else if (p_dm->rfe_type == 17)
+		else if (dm->rfe_type == 17)
 			READ_AND_CONFIG_MP(8822b, _txpowertrack_type17);
+		else if (dm->rfe_type == 18)
+			READ_AND_CONFIG_MP(8822b, _txpowertrack_type18);
 		else
 			READ_AND_CONFIG_MP(8822b, _txpowertrack);
 	}
 #endif
-
 #if RTL8197F_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8197F) {
-		if (p_dm->rfe_type == 0)
+	if (dm->support_ic_type == ODM_RTL8197F) {
+		if (dm->rfe_type == 0)
 			READ_AND_CONFIG_MP(8197f, _txpowertrack_type0);
-		else if (p_dm->rfe_type == 1)
+		else if (dm->rfe_type == 1)
 			READ_AND_CONFIG_MP(8197f, _txpowertrack_type1);
 		else
 			READ_AND_CONFIG_MP(8197f, _txpowertrack);
 	}
 #endif
+/*@jj add 20170822*/
+#if RTL8192F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8192F) {
+		if (dm->rfe_type == 0)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type0);
+		else if (dm->rfe_type == 1)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type1);
+		else if (dm->rfe_type == 2)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type2);
+		else if (dm->rfe_type == 3)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type3);
+		else if (dm->rfe_type == 4)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type4);
+		else if (dm->rfe_type == 5)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type5);
+		else if (dm->rfe_type == 6)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type6);
+		else if (dm->rfe_type == 7)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type7);
+		else if (dm->rfe_type == 8)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type8);
+		else if (dm->rfe_type == 9)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type9);
+		else if (dm->rfe_type == 10)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type10);
+		else if (dm->rfe_type == 11)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type11);
+		else if (dm->rfe_type == 12)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type12);
+		else if (dm->rfe_type == 13)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type13);
+		else if (dm->rfe_type == 14)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type14);
+		else if (dm->rfe_type == 15)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type15);
+		else if (dm->rfe_type == 16)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type16);
+		else if (dm->rfe_type == 17)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type17);
+		else if (dm->rfe_type == 18)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type18);
+		else if (dm->rfe_type == 19)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type19);
+		else if (dm->rfe_type == 20)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type20);
+		else if (dm->rfe_type == 21)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type21);
+		else if (dm->rfe_type == 22)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type22);
+		else if (dm->rfe_type == 23)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type23);
+		else if (dm->rfe_type == 24)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type24);
+		else if (dm->rfe_type == 25)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type25);
+		else if (dm->rfe_type == 26)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type26);
+		else if (dm->rfe_type == 27)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type27);
+		else if (dm->rfe_type == 28)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type28);
+		else if (dm->rfe_type == 29)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type29);
+		else if (dm->rfe_type == 30)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type30);
+		else if (dm->rfe_type == 31)
+			READ_AND_CONFIG_MP(8192f, _txpowertrack_type31);
+		else
+			READ_AND_CONFIG_MP(8192f, _txpowertrack);
+
+		READ_AND_CONFIG_MP(8192f, _txxtaltrack);
+	}
+#endif
 
+#if RTL8721D_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8721D) {
+		#if 0
+		if (dm->package_type == 1)
+			READ_AND_CONFIG_MP(8721d, _txpowertrack_qfn48m_smic);
+		else if (dm->package_type == 5)
+			READ_AND_CONFIG_MP(8721d, _txpowertrack_qfn48m_umc);
+		#endif
+		READ_AND_CONFIG_MP(8721d, _txpowertrack);
+		READ_AND_CONFIG_MP(8721d, _txxtaltrack);
+	}
+#endif
 #if RTL8821C_SUPPORT
-	if (p_dm->support_ic_type == ODM_RTL8821C) {
-		if (p_dm->rfe_type == 0x5)
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (dm->rfe_type == 0x5)
 			READ_AND_CONFIG(8821c, _txpowertrack_type0x28);
-		else if (p_dm->rfe_type == 0x4)
+		else if (dm->rfe_type == 0x4)
 			READ_AND_CONFIG(8821c, _txpowertrack_type0x20);
 		else
 			READ_AND_CONFIG(8821c, _txpowertrack);
 	}
 #endif
 
+#if RTL8198F_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8198F)
+		READ_AND_CONFIG_MP(8198f, _txpowertrack);
+#endif
+
+#if RTL8195B_SUPPORT
+	if (dm->support_ic_type == ODM_RTL8195B) {
+		READ_AND_CONFIG_MP(8195b, _txpowertrack);
+		READ_AND_CONFIG_MP(8195b, _txxtaltrack);
+	}
+#endif
+
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8822C)
+		READ_AND_CONFIG_MP(8822c, _txpowertrack);
+#endif
+
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8812F)
+		READ_AND_CONFIG_MP(8812f, _txpowertrack);
+#endif
+
 	return HAL_STATUS_SUCCESS;
 }
 
 enum hal_status
-odm_config_bb_with_header_file(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum odm_bb_config_type		config_type
-)
+odm_config_bb_with_header_file(struct dm_struct *dm,
+			       enum odm_bb_config_type config_type)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	PMGNT_INFO		p_mgnt_info = &(adapter->MgntInfo);
+	void *adapter = dm->adapter;
+	PMGNT_INFO mgnt_info = &((PADAPTER)adapter)->MgntInfo;
 #endif
-	enum hal_status	result = HAL_STATUS_SUCCESS;
+	enum hal_status result = HAL_STATUS_SUCCESS;
 
-	/* 1 AP doesn't use PHYDM initialization in these ICs */
+/* @1 AP doesn't use PHYDM initialization in these ICs */
 #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 #if (RTL8812A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8812) {
+	if (dm->support_ic_type == ODM_RTL8812) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8812a, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
 			READ_AND_CONFIG_MP(8812a, _agc_tab);
 		else if (config_type == CONFIG_BB_PHY_REG_PG) {
-			if (p_dm->rfe_type == 3 && p_dm->is_mp_chip)
+			if (dm->rfe_type == 3 && dm->is_mp_chip)
 				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_asus);
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-			else if (p_mgnt_info->CustomerID == RT_CID_WNC_NEC && p_dm->is_mp_chip)
+			else if (mgnt_info->CustomerID == RT_CID_WNC_NEC && dm->is_mp_chip)
 				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_nec);
 #if RT_PLATFORM == PLATFORM_MACOSX
-			/*{1827}{1024} for BUFFALO power by rate table. Isaiah 2013-11-29*/
-			else if (p_mgnt_info->CustomerID == RT_CID_DNI_BUFFALO)
+			/*@{1827}{1024} for BUFFALO power by rate table. Isaiah 2013-11-29*/
+			else if (mgnt_info->CustomerID == RT_CID_DNI_BUFFALO)
 				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_dni);
 			/* TP-Link T4UH, Isaiah 2015-03-16*/
-			else if (p_mgnt_info->CustomerID == RT_CID_TPLINK_HPWR) {
-				dbg_print("RT_CID_TPLINK_HPWR:: _PHY_REG_PG_TPLINK\n");
+			else if (mgnt_info->CustomerID == RT_CID_TPLINK_HPWR) {
+				pr_debug("RT_CID_TPLINK_HPWR:: _PHY_REG_PG_TPLINK\n");
 				READ_AND_CONFIG_MP(8812a, _phy_reg_pg_tplink);
 			}
 #endif
@@ -538,17 +815,17 @@ odm_config_bb_with_header_file(
 		} else if (config_type == CONFIG_BB_PHY_REG_MP)
 			READ_AND_CONFIG_MP(8812a, _phy_reg_mp);
 		else if (config_type == CONFIG_BB_AGC_TAB_DIFF) {
-			p_dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
-			/*AGC_TAB DIFF dont support FW offload*/
-			if ((*p_dm->p_channel >= 36)  && (*p_dm->p_channel  <= 64))
+			dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
+			/*@AGC_TAB DIFF dont support FW offload*/
+			if ((*dm->channel >= 36) && (*dm->channel <= 64))
 				AGC_DIFF_CONFIG_MP(8812a, lb);
-			else if (*p_dm->p_channel >= 100)
+			else if (*dm->channel >= 100)
 				AGC_DIFF_CONFIG_MP(8812a, hb);
 		}
 	}
 #endif
 #if (RTL8821A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821) {
+	if (dm->support_ic_type == ODM_RTL8821) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8821a, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -556,29 +833,29 @@ odm_config_bb_with_header_file(
 		else if (config_type == CONFIG_BB_PHY_REG_PG) {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 #if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-			HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+			HAL_DATA_TYPE * hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 
-			if ((p_hal_data->EEPROMSVID == 0x1043 && p_hal_data->EEPROMSMID == 0x207F))
+			if ((hal_data->EEPROMSVID == 0x1043 && hal_data->EEPROMSMID == 0x207F))
 				READ_AND_CONFIG_MP(8821a, _phy_reg_pg_e202_sa);
 			else
 #endif
 #if (RT_PLATFORM == PLATFORM_MACOSX)
-				/*{1827}{1022} for BUFFALO power by rate table. Isaiah 2013-10-18*/
-				if (p_mgnt_info->CustomerID == RT_CID_DNI_BUFFALO) {
-					/*{1024} for BUFFALO power by rate table. (JP/US)*/
-					if (p_mgnt_info->ChannelPlan == RT_CHANNEL_DOMAIN_US_2G_CANADA_5G)
-						READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_us);
-					else
-						READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_jp);
-				} else
+				/*@  for BUFFALO pwr by rate table */
+				if (mgnt_info->CustomerID == RT_CID_DNI_BUFFALO) {
+				/*@  for BUFFALO pwr by rate table (JP/US)*/
+				if (mgnt_info->ChannelPlan == RT_CHANNEL_DOMAIN_US_2G_CANADA_5G)
+					READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_us);
+				else
+					READ_AND_CONFIG_MP(8821a, _phy_reg_pg_dni_jp);
+			} else
 #endif
 #endif
-					READ_AND_CONFIG_MP(8821a, _phy_reg_pg);
+				READ_AND_CONFIG_MP(8821a, _phy_reg_pg);
 		}
 	}
 #endif
 #if (RTL8192E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8192E) {
+	if (dm->support_ic_type == ODM_RTL8192E) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8192e, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -588,7 +865,7 @@ odm_config_bb_with_header_file(
 	}
 #endif
 #if (RTL8723D_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723D) {
+	if (dm->support_ic_type == ODM_RTL8723D) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8723d, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -597,9 +874,9 @@ odm_config_bb_with_header_file(
 			READ_AND_CONFIG_MP(8723d, _phy_reg_pg);
 	}
 #endif
-/* JJ ADD 20161014 */
+/* @JJ ADD 20161014 */
 #if (RTL8710B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8710B) {
+	if (dm->support_ic_type == ODM_RTL8710B) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8710b, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -609,12 +886,10 @@ odm_config_bb_with_header_file(
 	}
 #endif
 
-#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
-
-
-	/* 1 All platforms support */
+#endif /* @(DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+/* @1 All platforms support */
 #if (RTL8188E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
+	if (dm->support_ic_type == ODM_RTL8188E) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8188e, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -624,7 +899,7 @@ odm_config_bb_with_header_file(
 	}
 #endif
 #if (RTL8723B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723B) {
+	if (dm->support_ic_type == ODM_RTL8723B) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8723b, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -634,35 +909,34 @@ odm_config_bb_with_header_file(
 	}
 #endif
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8814A) {
+	if (dm->support_ic_type == ODM_RTL8814A) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8814a, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
 			READ_AND_CONFIG_MP(8814a, _agc_tab);
 		else if (config_type == CONFIG_BB_PHY_REG_PG) {
-			if (p_dm->rfe_type == 0)
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type0);
-			else if (p_dm->rfe_type == 2)
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type2);				
-			else if (p_dm->rfe_type == 3)
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type3);		
-			else if (p_dm->rfe_type == 4)
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type4);		
-			else if (p_dm->rfe_type == 5)
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type5);		
-			else if (p_dm->rfe_type == 7)
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type7);
-			else if (p_dm->rfe_type == 8)
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg_type8);
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg_type0);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg_type3);
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg_type4);
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg_type5);
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg_type8);
 			else
-				READ_AND_CONFIG_MP(8814a,_phy_reg_pg);
-		}
-		else if (config_type == CONFIG_BB_PHY_REG_MP)
+				READ_AND_CONFIG_MP(8814a, _phy_reg_pg);
+		} else if (config_type == CONFIG_BB_PHY_REG_MP)
 			READ_AND_CONFIG_MP(8814a, _phy_reg_mp);
 	}
 #endif
 #if (RTL8703B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8703B) {
+	if (dm->support_ic_type == ODM_RTL8703B) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8703b, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -672,7 +946,7 @@ odm_config_bb_with_header_file(
 	}
 #endif
 #if (RTL8188F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188F) {
+	if (dm->support_ic_type == ODM_RTL8188F) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG_MP(8188f, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -682,74 +956,162 @@ odm_config_bb_with_header_file(
 	}
 #endif
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8822B) {
-		if (config_type == CONFIG_BB_PHY_REG)
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		if (config_type == CONFIG_BB_PHY_REG) {
 			READ_AND_CONFIG_MP(8822b, _phy_reg);
-		else if (config_type == CONFIG_BB_AGC_TAB)
+		} else if (config_type == CONFIG_BB_AGC_TAB) {
 			READ_AND_CONFIG_MP(8822b, _agc_tab);
-		else if (config_type == CONFIG_BB_PHY_REG_PG) {
-			if (p_dm->rfe_type == 2)
+		} else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 2)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type2);
-			else if (p_dm->rfe_type == 3)
+			else if (dm->rfe_type == 3)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type3);
-			else if (p_dm->rfe_type == 4)
+			else if (dm->rfe_type == 4)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type4);
-			else if (p_dm->rfe_type == 5)
+			else if (dm->rfe_type == 5)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type5);
-			else if (p_dm->rfe_type == 12)
+			else if (dm->rfe_type == 12)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type12);
-			else if (p_dm->rfe_type == 15)
+			else if (dm->rfe_type == 15)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type15);
-			else if (p_dm->rfe_type == 16)
+			else if (dm->rfe_type == 16)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type16);
-			else if (p_dm->rfe_type == 17)
+			else if (dm->rfe_type == 17)
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type17);
+			else if (dm->rfe_type == 18)
+				READ_AND_CONFIG_MP(8822b, _phy_reg_pg_type18);
 			else
 				READ_AND_CONFIG_MP(8822b, _phy_reg_pg);
 		}
-
 	}
 #endif
 
 #if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8197F) {
+	if (dm->support_ic_type == ODM_RTL8197F) {
 		if (config_type == CONFIG_BB_PHY_REG) {
 			READ_AND_CONFIG_MP(8197f, _phy_reg);
-			if (p_dm->cut_version == ODM_CUT_A)
-				phydm_phypara_a_cut(p_dm);
+			if (dm->cut_version == ODM_CUT_A)
+				phydm_phypara_a_cut(dm);
 		} else if (config_type == CONFIG_BB_AGC_TAB)
 			READ_AND_CONFIG_MP(8197f, _agc_tab);
 	}
 #endif
-
-#if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C) {
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192F) {
+		if (config_type == CONFIG_BB_PHY_REG) {
+			READ_AND_CONFIG_MP(8192f, _phy_reg);
+		} else if (config_type == CONFIG_BB_AGC_TAB) {
+			READ_AND_CONFIG_MP(8192f, _agc_tab);
+		} else if (config_type == CONFIG_BB_PHY_REG_PG) {
+			if (dm->rfe_type == 0)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type0);
+			else if (dm->rfe_type == 1)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type1);
+			else if (dm->rfe_type == 2)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type2);
+			else if (dm->rfe_type == 3)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type3);
+			else if (dm->rfe_type == 4)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type4);
+			else if (dm->rfe_type == 5)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type5);
+			else if (dm->rfe_type == 6)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type6);
+			else if (dm->rfe_type == 7)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type7);
+			else if (dm->rfe_type == 8)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type8);
+			else if (dm->rfe_type == 9)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type9);
+			else if (dm->rfe_type == 10)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type10);
+			else if (dm->rfe_type == 11)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type11);
+			else if (dm->rfe_type == 12)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type12);
+			else if (dm->rfe_type == 13)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type13);
+			else if (dm->rfe_type == 14)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type14);
+			else if (dm->rfe_type == 15)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type15);
+			else if (dm->rfe_type == 16)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type16);
+			else if (dm->rfe_type == 17)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type17);
+			else if (dm->rfe_type == 18)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type18);
+			else if (dm->rfe_type == 19)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type19);
+			else if (dm->rfe_type == 20)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type20);
+			else if (dm->rfe_type == 21)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type21);
+			else if (dm->rfe_type == 22)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type22);
+			else if (dm->rfe_type == 23)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type23);
+			else if (dm->rfe_type == 24)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type24);
+			else if (dm->rfe_type == 25)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type25);
+			else if (dm->rfe_type == 26)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type26);
+			else if (dm->rfe_type == 27)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type27);
+			else if (dm->rfe_type == 28)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type28);
+			else if (dm->rfe_type == 29)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type29);
+			else if (dm->rfe_type == 30)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type30);
+			else if (dm->rfe_type == 31)
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg_type31);
+			else
+				READ_AND_CONFIG_MP(8192f, _phy_reg_pg);
+		}
+	}
+#endif
+#if (RTL8721D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8721D) {
 		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8721d, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8721d, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG_MP(8721d, _phy_reg_pg);
+	}
+#endif
+#if (RTL8821C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8821C) {
+		if (config_type == CONFIG_BB_PHY_REG) {
 			READ_AND_CONFIG(8821c, _phy_reg);
-		else if (config_type == CONFIG_BB_AGC_TAB) {
+		} else if (config_type == CONFIG_BB_AGC_TAB) {
 			READ_AND_CONFIG(8821c, _agc_tab);
-			/* According to RFEtype, choosing correct AGC table*/
-			if (p_dm->default_rf_set_8821c == SWITCH_TO_BTG)
+			/* @According to RFEtype, choosing correct AGC table*/
+			if (dm->default_rf_set_8821c == SWITCH_TO_BTG)
 				AGC_DIFF_CONFIG_MP(8821c, btg);
 		} else if (config_type == CONFIG_BB_PHY_REG_PG) {
-			if (p_dm->rfe_type == 0x5)
+			if (dm->rfe_type == 0x5)
 				READ_AND_CONFIG(8821c, _phy_reg_pg_type0x28);
 			else
 				READ_AND_CONFIG(8821c, _phy_reg_pg);
 		} else if (config_type == CONFIG_BB_AGC_TAB_DIFF) {
-			p_dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
-			/*AGC_TAB DIFF dont support FW offload*/
-			if (p_dm->current_rf_set_8821c == SWITCH_TO_BTG)
+			dm->fw_offload_ability &= ~PHYDM_PHY_PARAM_OFFLOAD;
+			/*@AGC_TAB DIFF dont support FW offload*/
+			if (dm->current_rf_set_8821c == SWITCH_TO_BTG)
 				AGC_DIFF_CONFIG_MP(8821c, btg);
-			else if (p_dm->current_rf_set_8821c == SWITCH_TO_WLG)
+			else if (dm->current_rf_set_8821c == SWITCH_TO_WLG)
 				AGC_DIFF_CONFIG_MP(8821c, wlg);
-		} else if (config_type == CONFIG_BB_PHY_REG_MP)
+		} else if (config_type == CONFIG_BB_PHY_REG_MP) {
 			READ_AND_CONFIG(8821c, _phy_reg_mp);
+		}
 	}
 #endif
 
 #if (RTL8195A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8195A) {
+	if (dm->support_ic_type == ODM_RTL8195A) {
 		if (config_type == CONFIG_BB_PHY_REG)
 			READ_AND_CONFIG(8195a, _phy_reg);
 		else if (config_type == CONFIG_BB_AGC_TAB)
@@ -758,263 +1120,353 @@ odm_config_bb_with_header_file(
 			READ_AND_CONFIG(8195a, _phy_reg_pg);
 	}
 #endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG(8195b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG(8195b, _agc_tab);
+		else if (config_type == CONFIG_BB_PHY_REG_PG)
+			READ_AND_CONFIG(8195b, _phy_reg_pg);
+	}
+#endif
+#if (RTL8198F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8198F) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8198f, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8198f, _agc_tab);
+	}
+#endif
+#if (RTL8814B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814B) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8814b, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8814b, _agc_tab);
+	}
+#endif
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8822C) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8822c, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8822c, _agc_tab);
+	}
+#endif
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8812F) {
+		if (config_type == CONFIG_BB_PHY_REG)
+			READ_AND_CONFIG_MP(8812f, _phy_reg);
+		else if (config_type == CONFIG_BB_AGC_TAB)
+			READ_AND_CONFIG_MP(8812f, _agc_tab);
+	}
+#endif
 
-	if (config_type == CONFIG_BB_PHY_REG || config_type == CONFIG_BB_AGC_TAB)
-		if (p_dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
-
-			result = phydm_set_reg_by_fw(p_dm,
-								PHYDM_HALMAC_CMD_END,
-								0,
-								0,
-								0,
-								(enum rf_path)0,
-								0);
-			PHYDM_DBG(p_dm, ODM_COMP_INIT,
-				("phy param offload end!result = %d", result));
+	if (config_type == CONFIG_BB_PHY_REG ||
+	    config_type == CONFIG_BB_AGC_TAB)
+		if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+			result = phydm_set_reg_by_fw(dm,
+						     PHYDM_HALMAC_CMD_END,
+						     0,
+						     0,
+						     0,
+						     (enum rf_path)0,
+						     0);
+			PHYDM_DBG(dm, ODM_COMP_INIT,
+				  "phy param offload end!result = %d", result);
 		}
 
 	return result;
 }
 
 enum hal_status
-odm_config_mac_with_header_file(
-	struct PHY_DM_STRUCT	*p_dm
-)
+odm_config_mac_with_header_file(struct dm_struct *dm)
 {
-	enum hal_status	result = HAL_STATUS_SUCCESS;
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("===>odm_config_mac_with_header_file (%s)\n", (p_dm->is_mp_chip) ? "MPChip" : "TestChip"));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-		("support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
-		p_dm->support_platform, p_dm->support_interface, p_dm->board_type));
-
-	/* 1 AP doesn't use PHYDM initialization in these ICs */
+	enum hal_status result = HAL_STATUS_SUCCESS;
+
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===>%s (%s)\n", __func__,
+		  (dm->is_mp_chip) ? "MPChip" : "TestChip");
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "support_platform: 0x%X, support_interface: 0x%X, board_type: 0x%X\n",
+		  dm->support_platform, dm->support_interface, dm->board_type);
+
+/* @1 AP doesn't use PHYDM initialization in these ICs */
 #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 #if (RTL8812A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8812)
+	if (dm->support_ic_type == ODM_RTL8812)
 		READ_AND_CONFIG_MP(8812a, _mac_reg);
 #endif
 #if (RTL8821A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821)
+	if (dm->support_ic_type == ODM_RTL8821)
 		READ_AND_CONFIG_MP(8821a, _mac_reg);
 #endif
 #if (RTL8192E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8192E)
+	if (dm->support_ic_type == ODM_RTL8192E)
 		READ_AND_CONFIG_MP(8192e, _mac_reg);
 #endif
 #if (RTL8723D_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723D)
+	if (dm->support_ic_type == ODM_RTL8723D)
 		READ_AND_CONFIG_MP(8723d, _mac_reg);
 #endif
-/* JJ ADD 20161014 */
+/* @JJ ADD 20161014 */
 #if (RTL8710B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8710B)
+	if (dm->support_ic_type == ODM_RTL8710B)
 		READ_AND_CONFIG_MP(8710b, _mac_reg);
 #endif
-
-#endif/* (DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
-
-	/* 1 All platforms support */
+#endif /* @(DM_ODM_SUPPORT_TYPE !=  ODM_AP) */
+/* @1 All platforms support */
 #if (RTL8188E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188E)
+	if (dm->support_ic_type == ODM_RTL8188E)
 		READ_AND_CONFIG_MP(8188e, _mac_reg);
 #endif
 #if (RTL8723B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723B)
+	if (dm->support_ic_type == ODM_RTL8723B)
 		READ_AND_CONFIG_MP(8723b, _mac_reg);
 #endif
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8814A)
+	if (dm->support_ic_type == ODM_RTL8814A)
 		READ_AND_CONFIG_MP(8814a, _mac_reg);
 #endif
 #if (RTL8703B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8703B)
+	if (dm->support_ic_type == ODM_RTL8703B)
 		READ_AND_CONFIG_MP(8703b, _mac_reg);
 #endif
 #if (RTL8188F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188F)
+	if (dm->support_ic_type == ODM_RTL8188F)
 		READ_AND_CONFIG_MP(8188f, _mac_reg);
 #endif
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8822B)
+	if (dm->support_ic_type == ODM_RTL8822B)
 		READ_AND_CONFIG_MP(8822b, _mac_reg);
 #endif
-
 #if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8197F)
+	if (dm->support_ic_type == ODM_RTL8197F)
 		READ_AND_CONFIG_MP(8197f, _mac_reg);
 #endif
 
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192F)
+		READ_AND_CONFIG_MP(8192f, _mac_reg);
+#endif
+
+#if (RTL8721D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8721D)
+		READ_AND_CONFIG_MP(8721d, _mac_reg);
+#endif
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C)
+	if (dm->support_ic_type == ODM_RTL8821C)
 		READ_AND_CONFIG(8821c, _mac_reg);
 #endif
-
 #if (RTL8195A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8195A)
+	if (dm->support_ic_type == ODM_RTL8195A)
 		READ_AND_CONFIG_MP(8195a, _mac_reg);
 #endif
-
-	if (p_dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
-
-		result = phydm_set_reg_by_fw(p_dm,
-							PHYDM_HALMAC_CMD_END,
-							0,
-							0,
-							0,
-							(enum rf_path)0,
-							0);
-		PHYDM_DBG(p_dm, ODM_COMP_INIT,
-			("mac param offload end!result = %d", result));
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B)
+		READ_AND_CONFIG_MP(8195b, _mac_reg);
+#endif
+#if (RTL8198F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8198F)
+		READ_AND_CONFIG_MP(8198f, _mac_reg);
+#endif
+#if (RTL8814B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814B)
+		READ_AND_CONFIG_MP(8814b, _mac_reg);
+#endif
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8822C)
+		READ_AND_CONFIG_MP(8822c, _mac_reg);
+#endif
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8812F)
+		READ_AND_CONFIG_MP(8812f, _mac_reg);
+#endif
+
+	if (dm->fw_offload_ability & PHYDM_PHY_PARAM_OFFLOAD) {
+		result = phydm_set_reg_by_fw(dm,
+					     PHYDM_HALMAC_CMD_END,
+					     0,
+					     0,
+					     0,
+					     (enum rf_path)0,
+					     0);
+		PHYDM_DBG(dm, ODM_COMP_INIT,
+			  "mac param offload end!result = %d", result);
 	}
 
 	return result;
 }
 
-u32
-odm_get_hw_img_version(
-	struct PHY_DM_STRUCT	*p_dm
-)
+u32 odm_get_hw_img_version(struct dm_struct *dm)
 {
-	u32  version = 0;
+	u32 version = 0;
 
-	/* 1 AP doesn't use PHYDM initialization in these ICs */
+/* @1 AP doesn't use PHYDM initialization in these ICs */
 #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 #if (RTL8821A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821)
+	if (dm->support_ic_type == ODM_RTL8821)
 		version = GET_VERSION_MP(8821a, _mac_reg);
 #endif
 #if (RTL8192E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8192E)
+	if (dm->support_ic_type == ODM_RTL8192E)
 		version = GET_VERSION_MP(8192e, _mac_reg);
 #endif
 #if (RTL8812A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8812)
+	if (dm->support_ic_type == ODM_RTL8812)
 		version = GET_VERSION_MP(8812a, _mac_reg);
 #endif
 #if (RTL8723D_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723D)
+	if (dm->support_ic_type == ODM_RTL8723D)
 		version = GET_VERSION_MP(8723d, _mac_reg);
 #endif
-/* JJ ADD 20161014 */
+/* @JJ ADD 20161014 */
 #if (RTL8710B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8710B)
+	if (dm->support_ic_type == ODM_RTL8710B)
 		version = GET_VERSION_MP(8710b, _mac_reg);
 #endif
+#endif /* @(DM_ODM_SUPPORT_TYPE != ODM_AP) */
 
-#endif /* (DM_ODM_SUPPORT_TYPE != ODM_AP) */
-
-	/*1 All platforms support*/
+/*@1 All platforms support*/
 #if (RTL8188E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188E)
+	if (dm->support_ic_type == ODM_RTL8188E)
 		version = GET_VERSION_MP(8188e, _mac_reg);
 #endif
 #if (RTL8723B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8723B)
+	if (dm->support_ic_type == ODM_RTL8723B)
 		version = GET_VERSION_MP(8723b, _mac_reg);
 #endif
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8814A)
+	if (dm->support_ic_type == ODM_RTL8814A)
 		version = GET_VERSION_MP(8814a, _mac_reg);
 #endif
 #if (RTL8703B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8703B)
+	if (dm->support_ic_type == ODM_RTL8703B)
 		version = GET_VERSION_MP(8703b, _mac_reg);
 #endif
 #if (RTL8188F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188F)
+	if (dm->support_ic_type == ODM_RTL8188F)
 		version = GET_VERSION_MP(8188f, _mac_reg);
 #endif
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8822B)
+	if (dm->support_ic_type == ODM_RTL8822B)
 		version = GET_VERSION_MP(8822b, _mac_reg);
 #endif
-
 #if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8197F)
+	if (dm->support_ic_type == ODM_RTL8197F)
 		version = GET_VERSION_MP(8197f, _mac_reg);
 #endif
 
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8192F)
+		version = GET_VERSION_MP(8192f, _mac_reg);
+#endif
+#if (RTL8721D_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8721D)
+		version = GET_VERSION_MP(8721d, _mac_reg);
+#endif
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C)
+	if (dm->support_ic_type == ODM_RTL8821C)
 		version = GET_VERSION(8821c, _mac_reg);
 #endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B)
+		version = GET_VERSION(8195b, _mac_reg);
+#endif
+#if (RTL8198F_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8198F)
+		version = GET_VERSION_MP(8198f, _mac_reg);
+#endif
+#if (RTL8822C_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8822C)
+		version = GET_VERSION_MP(8822c, _mac_reg);
+#endif
+#if (RTL8812F_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8812F)
+		version = GET_VERSION_MP(8812f, _mac_reg);
+#endif
+#if (RTL8814B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8814B)
+		version = GET_VERSION_MP(8814b, _mac_reg);
+#endif
 
 	return version;
 }
 
-
-u32
-query_phydm_trx_capability(
-	struct PHY_DM_STRUCT					*p_dm
-)
+u32 query_phydm_trx_capability(struct dm_struct *dm)
 {
 	u32 value32 = 0xFFFFFFFF;
 
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C)
-		value32 = query_phydm_trx_capability_8821c(p_dm);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_trx_capability_8821c(dm);
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B)
+		value32 = query_phydm_trx_capability_8195b(dm);
 #endif
-
 	return value32;
 }
 
-u32
-query_phydm_stbc_capability(
-	struct PHY_DM_STRUCT					*p_dm
-)
+u32 query_phydm_stbc_capability(struct dm_struct *dm)
 {
 	u32 value32 = 0xFFFFFFFF;
 
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C)
-		value32 = query_phydm_stbc_capability_8821c(p_dm);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_stbc_capability_8821c(dm);
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B)
+		value32 = query_phydm_stbc_capability_8195b(dm);
 #endif
 
 	return value32;
 }
 
-u32
-query_phydm_ldpc_capability(
-	struct PHY_DM_STRUCT					*p_dm
-)
+u32 query_phydm_ldpc_capability(struct dm_struct *dm)
 {
 	u32 value32 = 0xFFFFFFFF;
 
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C)
-		value32 = query_phydm_ldpc_capability_8821c(p_dm);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_ldpc_capability_8821c(dm);
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B)
+		value32 = query_phydm_ldpc_capability_8195b(dm);
 #endif
-
 	return value32;
 }
 
-u32
-query_phydm_txbf_parameters(
-	struct PHY_DM_STRUCT					*p_dm
-)
+u32 query_phydm_txbf_parameters(struct dm_struct *dm)
 {
 	u32 value32 = 0xFFFFFFFF;
 
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C)
-		value32 = query_phydm_txbf_parameters_8821c(p_dm);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_txbf_parameters_8821c(dm);
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B)
+		value32 = query_phydm_txbf_parameters_8195b(dm);
 #endif
-
 	return value32;
 }
 
-u32
-query_phydm_txbf_capability(
-	struct PHY_DM_STRUCT					*p_dm
-)
+u32 query_phydm_txbf_capability(struct dm_struct *dm)
 {
 	u32 value32 = 0xFFFFFFFF;
 
 #if (RTL8821C_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8821C)
-		value32 = query_phydm_txbf_capability_8821c(p_dm);
+	if (dm->support_ic_type == ODM_RTL8821C)
+		value32 = query_phydm_txbf_capability_8821c(dm);
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8195B)
+		value32 = query_phydm_txbf_capability_8195b(dm);
 #endif
-
 	return value32;
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.h
index e3c65e33e4f8..229d7c0fd502 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_hwconfig.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,86 +9,72 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-
-#ifndef	__HALHWOUTSRC_H__
+#ifndef __HALHWOUTSRC_H__
 #define __HALHWOUTSRC_H__
 
-
-/*--------------------------Define -------------------------------------------*/
-#define AGC_DIFF_CONFIG_MP(ic, band) (odm_read_and_config_mp_##ic##_agc_tab_diff(p_dm, array_mp_##ic##_agc_tab_diff_##band, \
-		      sizeof(array_mp_##ic##_agc_tab_diff_##band)/sizeof(u32)))
-#define AGC_DIFF_CONFIG_TC(ic, band) (odm_read_and_config_tc_##ic##_agc_tab_diff(p_dm, array_tc_##ic##_agc_tab_diff_##band, \
-		      sizeof(array_tc_##ic##_agc_tab_diff_##band)/sizeof(u32)))
-
-#define AGC_DIFF_CONFIG(ic, band) do {\
-		if (p_dm->is_mp_chip)\
-			AGC_DIFF_CONFIG_MP(ic, band);\
-		else\
-			AGC_DIFF_CONFIG_TC(ic, band);\
+/*@--------------------------Define -------------------------------------------*/
+#define AGC_DIFF_CONFIG_MP(ic, band)				\
+	(odm_read_and_config_mp_##ic##_agc_tab_diff(dm,		\
+	array_mp_##ic##_agc_tab_diff_##band,			\
+	sizeof(array_mp_##ic##_agc_tab_diff_##band) / sizeof(u32)))
+#define AGC_DIFF_CONFIG_TC(ic, band)				\
+	(odm_read_and_config_tc_##ic##_agc_tab_diff(dm,		\
+	array_tc_##ic##_agc_tab_diff_##band,			\
+	sizeof(array_tc_##ic##_agc_tab_diff_##band) / sizeof(u32)))
+#if defined(DM_ODM_CE_MAC80211)
+#else
+#define AGC_DIFF_CONFIG(ic, band)                     \
+	do {                                          \
+		if (dm->is_mp_chip)                   \
+			AGC_DIFF_CONFIG_MP(ic, band); \
+		else                                  \
+			AGC_DIFF_CONFIG_TC(ic, band); \
 	} while (0)
-
-
-/* ************************************************************
+#endif
+/*@************************************************************
  * structure and define
- * ************************************************************ */
+ ************************************************************/
 
 enum hal_status
-odm_config_rf_with_tx_pwr_track_header_file(
-	struct PHY_DM_STRUCT		*p_dm
-);
+odm_config_rf_with_tx_pwr_track_header_file(struct dm_struct *dm);
 
 enum hal_status
-odm_config_rf_with_header_file(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum odm_rf_config_type		config_type,
-	u8						e_rf_path
-);
+odm_config_rf_with_header_file(struct dm_struct *dm,
+			       enum odm_rf_config_type config_type,
+			       u8 e_rf_path);
 
 enum hal_status
-odm_config_bb_with_header_file(
-	struct PHY_DM_STRUCT	*p_dm,
-	enum odm_bb_config_type		config_type
-);
+odm_config_bb_with_header_file(struct dm_struct *dm,
+			       enum odm_bb_config_type config_type);
 
 enum hal_status
-odm_config_mac_with_header_file(
-	struct PHY_DM_STRUCT	*p_dm
-);
-
-u32
-odm_get_hw_img_version(
-	struct PHY_DM_STRUCT	*p_dm
-);
+odm_config_mac_with_header_file(struct dm_struct *dm);
 
+u32 odm_get_hw_img_version(struct dm_struct *dm);
 
-u32
-query_phydm_trx_capability(
-	struct PHY_DM_STRUCT					*p_dm
-);
+u32 query_phydm_trx_capability(struct dm_struct *dm);
 
-u32
-query_phydm_stbc_capability(
-	struct PHY_DM_STRUCT					*p_dm
-);
+u32 query_phydm_stbc_capability(struct dm_struct *dm);
 
-u32
-query_phydm_ldpc_capability(
-	struct PHY_DM_STRUCT					*p_dm
-);
+u32 query_phydm_ldpc_capability(struct dm_struct *dm);
 
-u32
-query_phydm_txbf_parameters(
-	struct PHY_DM_STRUCT					*p_dm
-);
+u32 query_phydm_txbf_parameters(struct dm_struct *dm);
 
-u32
-query_phydm_txbf_capability(
-	struct PHY_DM_STRUCT					*p_dm
-);
+u32 query_phydm_txbf_capability(struct dm_struct *dm);
 
-#endif /*#ifndef	__HALHWOUTSRC_H__*/
+#endif /*@#ifndef	__HALHWOUTSRC_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.c
index 88b15ed71ad4..e3132dfd4b26 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,501 +9,523 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-/*
+/*@
  * ODM IO Relative API.
- *   */
+ */
 
-u8
-odm_read_1byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr
-)
+u8 odm_read_1byte(struct dm_struct *dm, u32 reg_addr)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct rtl8192cd_priv	*priv	= p_dm->priv;
-	return	RTL_R8(reg_addr);
+	struct rtl8192cd_priv *priv = dm->priv;
+	return RTL_R8(reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	return rtl_read_byte(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	return rtw_read8(rtwdev, reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	return rtw_read8(adapter, reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	return	PlatformEFIORead1Byte(adapter, reg_addr);
-#endif
+	void *adapter = dm->adapter;
+	return PlatformEFIORead1Byte(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
 
+	return rtw_read8(adapter, reg_addr);
+#endif
 }
 
-
-u16
-odm_read_2byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr
-)
+u16 odm_read_2byte(struct dm_struct *dm, u32 reg_addr)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct rtl8192cd_priv	*priv	= p_dm->priv;
-	return	RTL_R16(reg_addr);
+	struct rtl8192cd_priv *priv = dm->priv;
+	return RTL_R16(reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	return rtl_read_word(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	return rtw_read16(rtwdev, reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	return rtw_read16(adapter, reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	return	PlatformEFIORead2Byte(adapter, reg_addr);
-#endif
+	void *adapter = dm->adapter;
+	return PlatformEFIORead2Byte(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
 
+	return rtw_read16(adapter, reg_addr);
+#endif
 }
 
-
-u32
-odm_read_4byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr
-)
+u32 odm_read_4byte(struct dm_struct *dm, u32 reg_addr)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct rtl8192cd_priv	*priv	= p_dm->priv;
-	return	RTL_R32(reg_addr);
+	struct rtl8192cd_priv *priv = dm->priv;
+	return RTL_R32(reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	return rtl_read_dword(rtlpriv, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	return rtw_read32(rtwdev, reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	return rtw_read32(adapter, reg_addr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	return	PlatformEFIORead4Byte(adapter, reg_addr);
-#endif
+	void *adapter = dm->adapter;
+	return PlatformEFIORead4Byte(adapter, reg_addr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
 
+	return rtw_read32(adapter, reg_addr);
+#endif
 }
 
-
-void
-odm_write_1byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr,
-	u8			data
-)
+void odm_write_1byte(struct dm_struct *dm, u32 reg_addr, u8 data)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct rtl8192cd_priv	*priv	= p_dm->priv;
+	struct rtl8192cd_priv *priv = dm->priv;
 	RTL_W8(reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	rtl_write_byte(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	rtw_write8(rtwdev, reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	rtw_write8(adapter, reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PlatformEFIOWrite1Byte(adapter, reg_addr, data);
-#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
 
+	rtw_write8(adapter, reg_addr, data);
+#endif
 }
 
-
-void
-odm_write_2byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr,
-	u16			data
-)
+void odm_write_2byte(struct dm_struct *dm, u32 reg_addr, u16 data)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct rtl8192cd_priv	*priv	= p_dm->priv;
+	struct rtl8192cd_priv *priv = dm->priv;
 	RTL_W16(reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	rtl_write_word(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	rtw_write16(rtwdev, reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	rtw_write16(adapter, reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PlatformEFIOWrite2Byte(adapter, reg_addr, data);
-#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
 
+	rtw_write16(adapter, reg_addr, data);
+#endif
 }
 
-
-void
-odm_write_4byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr,
-	u32			data
-)
+void odm_write_4byte(struct dm_struct *dm, u32 reg_addr, u32 data)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	struct rtl8192cd_priv	*priv	= p_dm->priv;
+	struct rtl8192cd_priv *priv = dm->priv;
 	RTL_W32(reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	rtl_write_dword(rtlpriv, reg_addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	rtw_write32(rtwdev, reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	rtw_write32(adapter, reg_addr, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PlatformEFIOWrite4Byte(adapter, reg_addr, data);
-#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
 
+	rtw_write32(adapter, reg_addr, data);
+#endif
 }
 
-
-void
-odm_set_mac_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask,
-	u32		data
-)
+void odm_set_mac_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask, u32 data)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	phy_set_bb_reg(p_dm->priv, reg_addr, bit_mask, data);
+	phy_set_bb_reg(dm->priv, reg_addr, bit_mask, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PHY_SetBBReg(adapter, reg_addr, bit_mask, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	rtl_set_bbreg(rtlpriv->hw, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	rtw_set_reg_with_mask(rtwdev, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
 #else
-	phy_set_bb_reg(p_dm->adapter, reg_addr, bit_mask, data);
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
 #endif
 }
 
-
-u32
-odm_get_mac_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask
-)
+u32 odm_get_mac_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	return phy_query_bb_reg(p_dm->priv, reg_addr, bit_mask);
+	return phy_query_bb_reg(dm->priv, reg_addr, bit_mask);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	return PHY_QueryMacReg(p_dm->adapter, reg_addr, bit_mask);
+	return PHY_QueryMacReg(dm->adapter, reg_addr, bit_mask);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	return rtl_get_bbreg(rtlpriv->hw, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	return rtw_get_reg_with_mask(rtwdev, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	return phy_query_bb_reg(dm->adapter, reg_addr, bit_mask);
 #else
-	return phy_query_mac_reg(p_dm->adapter, reg_addr, bit_mask);
+	return phy_query_mac_reg(dm->adapter, reg_addr, bit_mask);
 #endif
 }
 
-
-void
-odm_set_bb_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask,
-	u32		data
-)
+void odm_set_bb_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask, u32 data)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	phy_set_bb_reg(p_dm->priv, reg_addr, bit_mask, data);
+	phy_set_bb_reg(dm->priv, reg_addr, bit_mask, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PHY_SetBBReg(adapter, reg_addr, bit_mask, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	rtl_set_bbreg(rtlpriv->hw, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	rtw_set_reg_with_mask(rtwdev, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
 #else
-	phy_set_bb_reg(p_dm->adapter, reg_addr, bit_mask, data);
+	phy_set_bb_reg(dm->adapter, reg_addr, bit_mask, data);
 #endif
 }
 
-
-u32
-odm_get_bb_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask
-)
+u32 odm_get_bb_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	return phy_query_bb_reg(p_dm->priv, reg_addr, bit_mask);
+	return phy_query_bb_reg(dm->priv, reg_addr, bit_mask);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	return PHY_QueryBBReg(adapter, reg_addr, bit_mask);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	return rtl_get_bbreg(rtlpriv->hw, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	return rtw_get_reg_with_mask(rtwdev, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	return phy_query_bb_reg(dm->adapter, reg_addr, bit_mask);
 #else
-	return phy_query_bb_reg(p_dm->adapter, reg_addr, bit_mask);
+	return phy_query_bb_reg(dm->adapter, reg_addr, bit_mask);
 #endif
 }
 
-
-void
-odm_set_rf_reg(
-	struct PHY_DM_STRUCT			*p_dm,
-	u8			e_rf_path,
-	u32				reg_addr,
-	u32				bit_mask,
-	u32				data
-)
+void odm_set_rf_reg(struct dm_struct *dm, u8 e_rf_path, u32 reg_addr,
+		    u32 bit_mask, u32 data)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	phy_set_rf_reg(p_dm->priv, e_rf_path, reg_addr, bit_mask, data);
+	phy_set_rf_reg(dm->priv, e_rf_path, reg_addr, bit_mask, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PHY_SetRFReg(adapter, e_rf_path, reg_addr, bit_mask, data);
 	ODM_delay_us(2);
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	rtl_set_rfreg(rtlpriv->hw, e_rf_path, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	rtw_write_rf(rtwdev, e_rf_path, reg_addr, bit_mask, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	phy_set_rf_reg(p_dm->adapter, e_rf_path, reg_addr, bit_mask, data);
+	phy_set_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	phy_set_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask, data);
+	ODM_delay_us(2);
 #endif
 }
 
-u32
-odm_get_rf_reg(
-	struct PHY_DM_STRUCT			*p_dm,
-	u8			e_rf_path,
-	u32				reg_addr,
-	u32				bit_mask
-)
+u32 odm_get_rf_reg(struct dm_struct *dm, u8 e_rf_path, u32 reg_addr,
+		   u32 bit_mask)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	return phy_query_rf_reg(p_dm->priv, e_rf_path, reg_addr, bit_mask, 1);
+	return phy_query_rf_reg(dm->priv, e_rf_path, reg_addr, bit_mask, 1);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	return PHY_QueryRFReg(adapter, e_rf_path, reg_addr, bit_mask);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
 
 	return rtl_get_rfreg(rtlpriv->hw, e_rf_path, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	return rtw_read_rf(rtwdev, e_rf_path, reg_addr, bit_mask);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	return phy_query_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask);
 #else
-	return phy_query_rf_reg(p_dm->adapter, e_rf_path, reg_addr, bit_mask);
+	return phy_query_rf_reg(dm->adapter, e_rf_path, reg_addr, bit_mask);
 #endif
 }
 
 enum hal_status
-phydm_set_reg_by_fw(
-	struct PHY_DM_STRUCT			*p_dm,
-	enum phydm_halmac_param	config_type,
-	u32	offset,
-	u32	data,
-	u32	mask,
-	enum rf_path	e_rf_path,
-	u32 delay_time
-)
+phydm_set_reg_by_fw(struct dm_struct *dm, enum phydm_halmac_param config_type,
+		    u32 offset, u32 data, u32 mask, enum rf_path e_rf_path,
+		    u32 delay_time)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	return HAL_MAC_Config_PHY_WriteNByte(p_dm,
-									config_type,
-									offset,
-									data,
-									mask,
-									e_rf_path,
-									delay_time);
+	return HAL_MAC_Config_PHY_WriteNByte(dm,
+					     config_type,
+					     offset,
+					     data,
+					     mask,
+					     e_rf_path,
+					     delay_time);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	return rtw_phydm_cfg_phy_para(p_dm,
-							config_type,
-							offset,
-							data,
-							mask,
-							e_rf_path,
-							delay_time);
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, DBG_CMN, "Not support for CE MAC80211 driver!\n");
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	return -ENOTSUPP;
+#else
+	return rtw_phydm_cfg_phy_para(dm,
+				      config_type,
+				      offset,
+				      data,
+				      mask,
+				      e_rf_path,
+				      delay_time);
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	PHYDM_DBG(dm, DBG_CMN, "Not support for CE MAC80211 driver!\n");
 #endif
-
 }
 
-
-/*
+/*@
  * ODM Memory relative API.
- *   */
-void
-odm_allocate_memory(
-	struct PHY_DM_STRUCT	*p_dm,
-	void **p_ptr,
-	u32		length
-)
+ */
+void odm_allocate_memory(struct dm_struct *dm, void **ptr, u32 length)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	*p_ptr = kmalloc(length, GFP_ATOMIC);
+	*ptr = kmalloc(length, GFP_ATOMIC);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	*p_ptr = kmalloc(length, GFP_ATOMIC);
+	*ptr = kmalloc(length, GFP_ATOMIC);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	*ptr = kmalloc(length, GFP_ATOMIC);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	*p_ptr = rtw_zvmalloc(length);
+	*ptr = rtw_zvmalloc(length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	PlatformAllocateMemory(adapter, p_ptr, length);
+	void *adapter = dm->adapter;
+	PlatformAllocateMemory(adapter, ptr, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	*ptr = rtw_zvmalloc(length);
 #endif
 }
 
-/* length could be ignored, used to detect memory leakage. */
-void
-odm_free_memory(
-	struct PHY_DM_STRUCT	*p_dm,
-	void		*p_ptr,
-	u32		length
-)
+/* @length could be ignored, used to detect memory leakage. */
+void odm_free_memory(struct dm_struct *dm, void *ptr, u32 length)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	kfree(p_ptr);
+	kfree(ptr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	kfree(p_ptr);
+	kfree(ptr);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	kfree(ptr);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	rtw_vmfree(p_ptr, length);
+	rtw_vmfree(ptr, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	/* struct _ADAPTER*    adapter = p_dm->adapter; */
-	PlatformFreeMemory(p_ptr, length);
+	/* struct void*    adapter = dm->adapter; */
+	PlatformFreeMemory(ptr, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_vmfree(ptr, length);
 #endif
 }
 
-void
-odm_move_memory(
-	struct PHY_DM_STRUCT	*p_dm,
-	void		*p_dest,
-	void		*p_src,
-	u32		length
-)
+void odm_move_memory(struct dm_struct *dm, void *dest, void *src, u32 length)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	memcpy(p_dest, p_src, length);
+	memcpy(dest, src, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	memcpy(p_dest, p_src, length);
+	memcpy(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	memcpy(dest, src, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	_rtw_memcpy(p_dest, p_src, length);
+	_rtw_memcpy(dest, src, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PlatformMoveMemory(p_dest, p_src, length);
+	PlatformMoveMemory(dest, src, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_memcpy(dest, src, length);
 #endif
 }
 
-void odm_memory_set(
-	struct PHY_DM_STRUCT	*p_dm,
-	void		*pbuf,
-	s8		value,
-	u32		length
-)
+void odm_memory_set(struct dm_struct *dm, void *pbuf, s8 value, u32 length)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
 	memset(pbuf, value, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
 	memset(pbuf, value, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	memset(pbuf, value, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 	_rtw_memset(pbuf, value, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	PlatformFillMemory(pbuf, length, value);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_memset(pbuf, value, length);
 #endif
 }
-s32 odm_compare_memory(
-	struct PHY_DM_STRUCT		*p_dm,
-	void           *p_buf1,
-	void           *p_buf2,
-	u32          length
-)
+
+s32 odm_compare_memory(struct dm_struct *dm, void *buf1, void *buf2, u32 length)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	return memcmp(p_buf1, p_buf2, length);
+	return memcmp(buf1, buf2, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	return memcmp(p_buf1, p_buf2, length);
+	return memcmp(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	return memcmp(buf1, buf2, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	return _rtw_memcmp(p_buf1, p_buf2, length);
+	return _rtw_memcmp(buf1, buf2, length);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	return PlatformCompareMemory(p_buf1, p_buf2, length);
+	return PlatformCompareMemory(buf1, buf2, length);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	return rtw_memcmp(buf1, buf2, length);
 #endif
 }
 
-
-
-/*
+/*@
  * ODM MISC relative API.
- *   */
-void
-odm_acquire_spin_lock(
-	struct PHY_DM_STRUCT			*p_dm,
-	enum rt_spinlock_type	type
-)
+ */
+void odm_acquire_spin_lock(struct dm_struct *dm, enum rt_spinlock_type type)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_odm_acquirespinlock(rtlpriv, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	spin_lock(&rtwdev->hal.dm_lock);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER *adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	rtw_odm_acquirespinlock(adapter, type);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PlatformAcquireSpinLock(adapter, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
+
+	rtw_odm_acquirespinlock(adapter, type);
 #endif
 }
-void
-odm_release_spin_lock(
-	struct PHY_DM_STRUCT			*p_dm,
-	enum rt_spinlock_type	type
-)
+
+void odm_release_spin_lock(struct dm_struct *dm, enum rt_spinlock_type type)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+
+	rtl_odm_releasespinlock(rtlpriv, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+
+	spin_unlock(&rtwdev->hal.dm_lock);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER *adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	rtw_odm_releasespinlock(adapter, type);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 	PlatformReleaseSpinLock(adapter, type);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
+
+	rtw_odm_releasespinlock(adapter, type);
 #endif
 }
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-/*
+/*@
  * Work item relative API. FOr MP driver only~!
  *   */
-void
-odm_initialize_work_item(
-	struct PHY_DM_STRUCT					*p_dm,
-	PRT_WORK_ITEM				p_rt_work_item,
-	RT_WORKITEM_CALL_BACK		rt_work_item_callback,
-	void						*p_context,
-	const char					*sz_id
-)
+void odm_initialize_work_item(
+	struct dm_struct *dm,
+	PRT_WORK_ITEM work_item,
+	RT_WORKITEM_CALL_BACK callback,
+	void *context,
+	const char *id)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	PlatformInitializeWorkItem(adapter, p_rt_work_item, rt_work_item_callback, p_context, sz_id);
+	void *adapter = dm->adapter;
+	PlatformInitializeWorkItem(adapter, work_item, callback, context, id);
 #endif
 }
 
-
-void
-odm_start_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-)
+void odm_start_work_item(
+	PRT_WORK_ITEM p_rt_work_item)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
@@ -513,11 +536,8 @@ odm_start_work_item(
 #endif
 }
 
-
-void
-odm_stop_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-)
+void odm_stop_work_item(
+	PRT_WORK_ITEM p_rt_work_item)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
@@ -528,11 +548,8 @@ odm_stop_work_item(
 #endif
 }
 
-
-void
-odm_free_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-)
+void odm_free_work_item(
+	PRT_WORK_ITEM p_rt_work_item)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
@@ -543,11 +560,8 @@ odm_free_work_item(
 #endif
 }
 
-
-void
-odm_schedule_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-)
+void odm_schedule_work_item(
+	PRT_WORK_ITEM p_rt_work_item)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
@@ -558,11 +572,9 @@ odm_schedule_work_item(
 #endif
 }
 
-
 boolean
 odm_is_work_item_scheduled(
-	PRT_WORK_ITEM	p_rt_work_item
-)
+	PRT_WORK_ITEM p_rt_work_item)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
@@ -574,142 +586,144 @@ odm_is_work_item_scheduled(
 }
 #endif
 
-
-/*
+/*@
  * ODM Timer relative API.
- *   */
+ */
 
-void
-ODM_delay_ms(u32	ms)
+void ODM_delay_ms(u32 ms)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	delay_ms(ms);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
 	mdelay(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	mdelay(ms);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 	rtw_mdelay_os(ms);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	delay_ms(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_mdelay_os(ms);
 #endif
 }
 
-void
-ODM_delay_us(u32	us)
+void ODM_delay_us(u32 us)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	delay_us(us);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
 	udelay(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	udelay(us);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 	rtw_udelay_os(us);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	PlatformStallExecution(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_udelay_os(us);
 #endif
 }
 
-void
-ODM_sleep_ms(u32	ms)
+void ODM_sleep_ms(u32 ms)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	delay_ms(ms);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
 	msleep(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	msleep(ms);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 	rtw_msleep_os(ms);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	delay_ms(ms);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_msleep_os(ms);
 #endif
 }
 
-void
-ODM_sleep_us(u32	us)
+void ODM_sleep_us(u32 us)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	delay_us(us);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
 	usleep_range(us, us + 1);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	usleep_range(us, us + 1);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 	rtw_usleep_os(us);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	PlatformStallExecution(us);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_usleep_os(us);
 #endif
 }
 
-void
-odm_set_timer(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct timer_list		*p_timer,
-	u32			ms_delay
-)
+void odm_set_timer(struct dm_struct *dm, struct phydm_timer_list *timer,
+		   u32 ms_delay)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	mod_timer(p_timer, jiffies + RTL_MILISECONDS_TO_JIFFIES(ms_delay));
+	mod_timer(timer, jiffies + RTL_MILISECONDS_TO_JIFFIES(ms_delay));
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	mod_timer(p_timer, jiffies + msecs_to_jiffies(ms_delay));
+	mod_timer(timer, jiffies + msecs_to_jiffies(ms_delay));
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	mod_timer(&timer->timer, jiffies + msecs_to_jiffies(ms_delay));
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	_set_timer(p_timer, ms_delay); /* ms */
+	_set_timer(timer, ms_delay); /* @ms */
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	PlatformSetTimer(adapter, p_timer, ms_delay);
+	void *adapter = dm->adapter;
+	PlatformSetTimer(adapter, timer, ms_delay);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_set_timer(timer, ms_delay); /* @ms */
 #endif
-
 }
 
-void
-odm_initialize_timer(
-	struct PHY_DM_STRUCT			*p_dm,
-	struct timer_list			*p_timer,
-	void	*call_back_func,
-	void				*p_context,
-	const char			*sz_id
-)
+void odm_initialize_timer(struct dm_struct *dm, struct phydm_timer_list *timer,
+			  void *call_back_func, void *context,
+			  const char *sz_id)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	init_timer(p_timer);
-	p_timer->function = call_back_func;
-	p_timer->data = (unsigned long)p_dm;
-	/*mod_timer(p_timer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	*/
+	init_timer(timer);
+	timer->function = call_back_func;
+	timer->data = (unsigned long)dm;
+#if 0
+	/*@mod_timer(timer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	*/
+#endif
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	init_timer(p_timer);
-	p_timer->function = call_back_func;
-	p_timer->data = (unsigned long)p_dm;
-	/*mod_timer(p_timer, jiffies+RTL_MILISECONDS_TO_JIFFIES(10));	*/
+	timer_setup(timer, call_back_func, 0);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	struct _ADAPTER *adapter = p_dm->adapter;
+	struct _ADAPTER *adapter = dm->adapter;
 
-	_init_timer(p_timer, adapter->pnetdev, call_back_func, p_dm);
+	_init_timer(timer, adapter->pnetdev, call_back_func, dm);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER *adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
-	PlatformInitializeTimer(adapter, p_timer, (RT_TIMER_CALL_BACK)call_back_func, p_context, sz_id);
+	PlatformInitializeTimer(adapter, timer, (RT_TIMER_CALL_BACK)call_back_func, context, sz_id);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	struct _ADAPTER *adapter = dm->adapter;
+
+	rtw_init_timer(timer, adapter->pnetdev, (TIMER_FUN)call_back_func, dm, NULL);
 #endif
 }
 
-
-void
-odm_cancel_timer(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct timer_list		*p_timer
-)
+void odm_cancel_timer(struct dm_struct *dm, struct phydm_timer_list *timer)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	del_timer(p_timer);
+	del_timer(timer);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	del_timer(p_timer);
+	del_timer(timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	del_timer(&timer->timer);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	_cancel_timer_ex(p_timer);
+	_cancel_timer_ex(timer);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER *adapter = p_dm->adapter;
-	PlatformCancelTimer(adapter, p_timer);
+	void *adapter = dm->adapter;
+	PlatformCancelTimer(adapter, timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_cancel_timer(timer);
 #endif
 }
 
-
-void
-odm_release_timer(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct timer_list		*p_timer
-)
+void odm_release_timer(struct dm_struct *dm, struct phydm_timer_list *timer)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 
@@ -717,61 +731,64 @@ odm_release_timer(
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 
-	struct _ADAPTER *adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
-	/* <20120301, Kordan> If the initilization fails, InitializeAdapterXxx will return regardless of InitHalDm.
-	 * Hence, uninitialized timers cause BSOD when the driver releases resources since the init fail. */
-	if (p_timer == 0) {
-		PHYDM_DBG(p_dm, ODM_COMP_INIT, ("=====>odm_release_timer(), The timer is NULL! Please check it!\n"));
+	/* @<20120301, Kordan> If the initilization fails,
+	 * InitializeAdapterXxx will return regardless of InitHalDm.
+	 * Hence, uninitialized timers cause BSOD when the driver
+	 * releases resources since the init fail.
+	 */
+	if (timer == 0) {
+		PHYDM_DBG(dm, ODM_COMP_INIT,
+			  "[%s] Timer is NULL! Please check!\n", __func__);
 		return;
 	}
 
-	PlatformReleaseTimer(adapter, p_timer);
+	PlatformReleaseTimer(adapter, timer);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_del_timer(timer);
 #endif
 }
 
-
-u8
-phydm_trans_h2c_id(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		phydm_h2c_id
-)
+u8 phydm_trans_h2c_id(struct dm_struct *dm, u8 phydm_h2c_id)
 {
 	u8 platform_h2c_id = phydm_h2c_id;
 
 	switch (phydm_h2c_id) {
-	/* 1 [0] */
+	/* @1 [0] */
 	case ODM_H2C_RSSI_REPORT:
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		if (p_dm->support_ic_type == ODM_RTL8188E)
+		#if (RTL8188E_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8188E)
 			platform_h2c_id = H2C_88E_RSSI_REPORT;
-		else if (p_dm->support_ic_type == ODM_RTL8814A)
-			platform_h2c_id = H2C_8814A_RSSI_REPORT;
 		else
+		#endif
 			platform_h2c_id = H2C_RSSI_REPORT;
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 		platform_h2c_id = H2C_RSSI_SETTING;
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
-		if (p_dm->support_ic_type == ODM_RTL8881A || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type & PHYDM_IC_3081_SERIES)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)) /*@jj add 20170822*/
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
 			platform_h2c_id = H2C_88XX_RSSI_REPORT;
 		else
 #endif
 #if (RTL8812A_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8812)
-				platform_h2c_id = H2C_8812_RSSI_REPORT;
-			else
+			if (dm->support_ic_type == ODM_RTL8812)
+			platform_h2c_id = H2C_8812_RSSI_REPORT;
+		else
 #endif
-			{}
+		{
+		}
 #endif
 
 		break;
 
-	/* 1 [3] */
+	/* @1 [3] */
 	case ODM_H2C_WIFI_CALIBRATION:
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 		platform_h2c_id = H2C_WIFI_CALIBRATION;
@@ -785,8 +802,7 @@ phydm_trans_h2c_id(
 #endif
 		break;
 
-
-	/* 1 [4] */
+	/* @1 [4] */
 	case ODM_H2C_IQ_CALIBRATION:
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 		platform_h2c_id = H2C_IQ_CALIBRATION;
@@ -799,15 +815,13 @@ phydm_trans_h2c_id(
 #endif
 
 		break;
-	/* 1 [5] */
+	/* @1 [5] */
 	case ODM_H2C_RA_PARA_ADJUST:
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		if (p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B))
-			platform_h2c_id = H2C_8814A_RA_PARA_ADJUST;
-		else
-			platform_h2c_id = H2C_RA_PARA_ADJUST;
+		platform_h2c_id = H2C_RA_PARA_ADJUST;
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 #if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
 		platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
@@ -820,36 +834,38 @@ phydm_trans_h2c_id(
 #endif
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
-		if (p_dm->support_ic_type == ODM_RTL8881A || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type & PHYDM_IC_3081_SERIES)
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)) /*@jj add 20170822*/
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
 			platform_h2c_id = H2C_88XX_RA_PARA_ADJUST;
 		else
 #endif
 #if (RTL8812A_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8812)
-				platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
-			else
+			if (dm->support_ic_type == ODM_RTL8812)
+			platform_h2c_id = H2C_8812_RA_PARA_ADJUST;
+		else
 #endif
-			{}
+		{
+		}
 #endif
 
 		break;
 
-
-	/* 1 [6] */
+	/* @1 [6] */
 	case PHYDM_H2C_DYNAMIC_TX_PATH:
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		if (p_dm->support_ic_type == ODM_RTL8814A)
+	#if (RTL8814A_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8814A)
 			platform_h2c_id = H2C_8814A_DYNAMIC_TX_PATH;
+	#endif
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 #if (RTL8814A_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8814A)
+		if (dm->support_ic_type == ODM_RTL8814A)
 			platform_h2c_id = H2C_DYNAMIC_TX_PATH;
 #endif
 #elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
 #if (RTL8814A_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8814A)
+		if (dm->support_ic_type == ODM_RTL8814A)
 			platform_h2c_id = H2C_88XX_DYNAMIC_TX_PATH;
 #endif
 
@@ -857,31 +873,30 @@ phydm_trans_h2c_id(
 
 		break;
 
-	/* [7]*/
+	/* @[7]*/
 	case PHYDM_H2C_FW_TRACE_EN:
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		if (p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B))
-			platform_h2c_id = H2C_8814A_FW_TRACE_EN;
-		else
-			platform_h2c_id = H2C_FW_TRACE_EN;
+
+		platform_h2c_id = H2C_FW_TRACE_EN;
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 
 		platform_h2c_id = 0x49;
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1))
-		if (p_dm->support_ic_type == ODM_RTL8881A || p_dm->support_ic_type == ODM_RTL8192E || p_dm->support_ic_type & PHYDM_IC_3081_SERIES)
-			platform_h2c_id  = H2C_88XX_FW_TRACE_EN;
+#if ((RTL8881A_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)) /*@jj add 20170822*/
+		if (dm->support_ic_type == ODM_RTL8881A || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type & PHYDM_IC_3081_SERIES)
+			platform_h2c_id = H2C_88XX_FW_TRACE_EN;
 		else
 #endif
 #if (RTL8812A_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8812)
-				platform_h2c_id = H2C_8812_FW_TRACE_EN;
-			else
+		if (dm->support_ic_type == ODM_RTL8812)
+			platform_h2c_id = H2C_8812_FW_TRACE_EN;
+		else
 #endif
-			{}
+		{
+		}
 
 #endif
 
@@ -889,13 +904,13 @@ phydm_trans_h2c_id(
 
 	case PHYDM_H2C_TXBF:
 #if ((RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1))
-		platform_h2c_id  = 0x41;	/*H2C_TxBF*/
+		platform_h2c_id = 0x41; /*@H2C_TxBF*/
 #endif
 		break;
 
 	case PHYDM_H2C_MU:
 #if (RTL8822B_SUPPORT == 1)
-		platform_h2c_id  = 0x4a;	/*H2C_MU*/
+		platform_h2c_id = 0x4a; /*@H2C_MU*/
 #endif
 		break;
 
@@ -905,128 +920,133 @@ phydm_trans_h2c_id(
 	}
 
 	return platform_h2c_id;
-
 }
 
-/*ODM FW relative API.*/
+/*@ODM FW relative API.*/
 
-void
-odm_fill_h2c_cmd(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			phydm_h2c_id,
-	u32			cmd_len,
-	u8			*p_cmd_buffer
-)
+void odm_fill_h2c_cmd(struct dm_struct *dm, u8 phydm_h2c_id, u32 cmd_len,
+		      u8 *cmd_buf)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	struct rtl_priv *rtlpriv = (struct rtl_priv *)p_dm->adapter;
+	struct rtl_priv *rtlpriv = (struct rtl_priv *)dm->adapter;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	struct rtw_dev *rtwdev = dm->adapter;
+	u8 cmd_id, cmd_class;
+	u8 h2c_pkt[8];
 #else
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 #endif
-	u8		h2c_id = phydm_trans_h2c_id(p_dm, phydm_h2c_id);
+	u8 h2c_id = phydm_trans_h2c_id(dm, phydm_h2c_id);
 
-	PHYDM_DBG(p_dm, DBG_RA, ("[H2C]  h2c_id=((0x%x))\n", h2c_id));
+	PHYDM_DBG(dm, DBG_RA, "[H2C]  h2c_id=((0x%x))\n", h2c_id);
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	if (p_dm->support_ic_type == ODM_RTL8188E)	{
-		if (!p_dm->ra_support88e)
-			FillH2CCmd88E(adapter, h2c_id, cmd_len, p_cmd_buffer);
-	} else if (p_dm->support_ic_type == ODM_RTL8814A)
-		FillH2CCmd8814A(adapter, h2c_id, cmd_len, p_cmd_buffer);
-	else if (p_dm->support_ic_type == ODM_RTL8822B)
-		FillH2CCmd8822B(adapter, h2c_id, cmd_len, p_cmd_buffer);
+	if (dm->support_ic_type == ODM_RTL8188E) {
+		if (!dm->ra_support88e)
+			FillH2CCmd88E(adapter, h2c_id, cmd_len, cmd_buf);
+	} else if (dm->support_ic_type == ODM_RTL8814A)
+		FillH2CCmd8814A(adapter, h2c_id, cmd_len, cmd_buf);
+	else if (dm->support_ic_type == ODM_RTL8822B)
+		FillH2CCmd8822B(adapter, h2c_id, cmd_len, cmd_buf);
 	else
-		FillH2CCmd(adapter, h2c_id, cmd_len, p_cmd_buffer);
+		FillH2CCmd(adapter, h2c_id, cmd_len, cmd_buf);
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 
 	#ifdef DM_ODM_CE_MAC80211
-	rtlpriv->cfg->ops->fill_h2c_cmd(rtlpriv->hw, h2c_id,cmd_len, p_cmd_buffer);
+	rtlpriv->cfg->ops->fill_h2c_cmd(rtlpriv->hw, h2c_id, cmd_len, cmd_buf);
+	#elif defined(DM_ODM_CE_MAC80211_V2)
+	cmd_id = phydm_h2c_id & 0x1f;
+	cmd_class = (phydm_h2c_id >> RTW_H2C_CLASS_OFFSET) & 0x7;
+	memcpy(h2c_pkt + 1, cmd_buf, 7);
+	h2c_pkt[0] = phydm_h2c_id;
+	rtw_fw_send_h2c_packet(rtwdev, h2c_pkt, cmd_id, cmd_class);
+	/* TODO: implement fill h2c command for rtwlan */
 	#else
-	rtw_hal_fill_h2c_cmd(adapter, h2c_id, cmd_len, p_cmd_buffer);
+	rtw_hal_fill_h2c_cmd(adapter, h2c_id, cmd_len, cmd_buf);
 	#endif
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
 
 	#if (RTL8812A_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8812) {
-		fill_h2c_cmd8812(p_dm->priv, h2c_id, cmd_len, p_cmd_buffer);
+	if (dm->support_ic_type == ODM_RTL8812) {
+		fill_h2c_cmd8812(dm->priv, h2c_id, cmd_len, cmd_buf);
 	} else
 	#endif
 	{
-		GET_HAL_INTERFACE(p_dm->priv)->fill_h2c_cmd_handler(p_dm->priv, h2c_id, cmd_len, p_cmd_buffer);
+		GET_HAL_INTERFACE(dm->priv)->fill_h2c_cmd_handler(dm->priv, h2c_id, cmd_len, cmd_buf);
 	}
+
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	rtw_hal_fill_h2c_cmd(adapter, h2c_id, cmd_len, cmd_buf);
+
 #endif
 }
 
-u8
-phydm_c2H_content_parsing(
-	void			*p_dm_void,
-	u8			c2h_cmd_id,
-	u8			c2h_cmd_len,
-	u8			*tmp_buf
-)
+u8 phydm_c2H_content_parsing(void *dm_void, u8 c2h_cmd_id, u8 c2h_cmd_len,
+			     u8 *tmp_buf)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER	*adapter = p_dm->adapter;
-#endif
-	u8	extend_c2h_sub_id = 0;
-	u8	find_c2h_cmd = true;
-	
-	if ((c2h_cmd_len > 12) || (c2h_cmd_len == 0)) {
-		dbg_print("[Warning] Error C2H ID=%d, len=%d\n", c2h_cmd_id, c2h_cmd_len);
-		
+	void *adapter = dm->adapter;
+#endif
+	u8 extend_c2h_sub_id = 0;
+	u8 find_c2h_cmd = true;
+
+	if (c2h_cmd_len > 12 || c2h_cmd_len == 0) {
+		pr_debug("[Warning] Error C2H ID=%d, len=%d\n",
+			 c2h_cmd_id, c2h_cmd_len);
+
 		find_c2h_cmd = false;
 		return find_c2h_cmd;
 	}
-	
+
 	switch (c2h_cmd_id) {
 	case PHYDM_C2H_DBG:
-		phydm_fw_trace_handler(p_dm, tmp_buf, c2h_cmd_len);
+		phydm_fw_trace_handler(dm, tmp_buf, c2h_cmd_len);
 		break;
 
 	case PHYDM_C2H_RA_RPT:
-		phydm_c2h_ra_report_handler(p_dm, tmp_buf, c2h_cmd_len);
+		phydm_c2h_ra_report_handler(dm, tmp_buf, c2h_cmd_len);
 		break;
 
 	case PHYDM_C2H_RA_PARA_RPT:
-		odm_c2h_ra_para_report_handler(p_dm, tmp_buf, c2h_cmd_len);
+		odm_c2h_ra_para_report_handler(dm, tmp_buf, c2h_cmd_len);
 		break;
-
+#ifdef CONFIG_PATH_DIVERSITY
 	case PHYDM_C2H_DYNAMIC_TX_PATH_RPT:
-		if (p_dm->support_ic_type & (ODM_RTL8814A))
-			phydm_c2h_dtp_handler(p_dm, tmp_buf, c2h_cmd_len);
+		if (dm->support_ic_type & (ODM_RTL8814A))
+			phydm_c2h_dtp_handler(dm, tmp_buf, c2h_cmd_len);
 		break;
+#endif
 
 	case PHYDM_C2H_IQK_FINISH:
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-		if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821)) {
-
+		if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821)) {
 			RT_TRACE(COMP_MP, DBG_LOUD, ("== FW IQK Finish ==\n"));
-			odm_acquire_spin_lock(p_dm, RT_IQK_SPINLOCK);
-			p_dm->rf_calibrate_info.is_iqk_in_progress = false;
-			odm_release_spin_lock(p_dm, RT_IQK_SPINLOCK);
-			p_dm->rf_calibrate_info.iqk_progressing_time = 0;
-			p_dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(p_dm, p_dm->rf_calibrate_info.iqk_start_time);
+			odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
+			dm->rf_calibrate_info.is_iqk_in_progress = false;
+			odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
+			dm->rf_calibrate_info.iqk_progressing_time = 0;
+			dm->rf_calibrate_info.iqk_progressing_time = odm_get_progressing_time(dm, dm->rf_calibrate_info.iqk_start_time);
 		}
 
 #endif
 		break;
 
 	case PHYDM_C2H_CLM_MONITOR:
-		phydm_c2h_clm_report_handler(p_dm, tmp_buf, c2h_cmd_len);
+		phydm_clm_c2h_report_handler(dm, tmp_buf, c2h_cmd_len);
 		break;
 
 	case PHYDM_C2H_DBG_CODE:
-		phydm_fw_trace_handler_code(p_dm, tmp_buf, c2h_cmd_len);
+		phydm_fw_trace_handler_code(dm, tmp_buf, c2h_cmd_len);
 		break;
 
 	case PHYDM_C2H_EXTEND:
 		extend_c2h_sub_id = tmp_buf[0];
 		if (extend_c2h_sub_id == PHYDM_EXTEND_C2H_DBG_PRINT)
-			phydm_fw_trace_handler_8051(p_dm, tmp_buf, c2h_cmd_len);
+			phydm_fw_trace_handler_8051(dm, tmp_buf, c2h_cmd_len);
 
 		break;
 
@@ -1036,78 +1056,71 @@ phydm_c2H_content_parsing(
 	}
 
 	return find_c2h_cmd;
-
 }
 
-u64
-odm_get_current_time(
-	struct PHY_DM_STRUCT		*p_dm
-)
+u64 odm_get_current_time(struct dm_struct *dm)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	return (u64)rtw_get_current_time();
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
 	return jiffies;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	return jiffies;
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 	return rtw_get_current_time();
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	return  PlatformGetCurrentTime();
+	return PlatformGetCurrentTime();
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	return rtw_get_current_time();
 #endif
 }
 
-u64
-odm_get_progressing_time(
-	struct PHY_DM_STRUCT		*p_dm,
-	u64			start_time
-)
+u64 odm_get_progressing_time(struct dm_struct *dm, u64 start_time)
 {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	return rtw_get_passing_time_ms((u32)start_time);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
 	return jiffies_to_msecs(jiffies - start_time);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	return jiffies_to_msecs(jiffies - start_time);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
 	return rtw_get_passing_time_ms((systime)start_time);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 	return ((PlatformGetCurrentTime() - start_time) >> 10);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	return rtw_get_passing_time_ms(start_time);
 #endif
 }
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE)) && !defined(DM_ODM_CE_MAC80211)
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE)) && \
+	(!defined(DM_ODM_CE_MAC80211) && !defined(DM_ODM_CE_MAC80211_V2))
 
-void
-phydm_set_hw_reg_handler_interface (
-	struct PHY_DM_STRUCT		*p_dm,
-	u8				RegName,
-	u8				*val
-	)
+void phydm_set_hw_reg_handler_interface(struct dm_struct *dm, u8 RegName,
+					u8 *val)
 {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	struct _ADAPTER *adapter = p_dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct _ADAPTER *adapter = dm->adapter;
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	adapter->HalFunc.SetHwRegHandler(adapter, RegName, val);
+	((PADAPTER)adapter)->HalFunc.SetHwRegHandler(adapter, RegName, val);
 #else
 	adapter->hal_func.set_hw_reg_handler(adapter, RegName, val);
 #endif
 
 #endif
-
 }
 
-void
-phydm_get_hal_def_var_handler_interface (
-	struct PHY_DM_STRUCT		*p_dm,
-	enum _HAL_DEF_VARIABLE		e_variable,
-	void						*p_value
-	)
+void phydm_get_hal_def_var_handler_interface(struct dm_struct *dm,
+					     enum _HAL_DEF_VARIABLE e_variable,
+					     void *value)
 {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE))
-	struct _ADAPTER *adapter = p_dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	struct _ADAPTER *adapter = dm->adapter;
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	adapter->HalFunc.GetHalDefVarHandler(adapter, e_variable, p_value);
+	((PADAPTER)adapter)->HalFunc.GetHalDefVarHandler(adapter, e_variable, value);
 #else
-	adapter->hal_func.get_hal_def_var_handler(adapter, e_variable, p_value);
+	adapter->hal_func.get_hal_def_var_handler(adapter, e_variable, value);
 #endif
 
 #endif
@@ -1115,192 +1128,182 @@ phydm_get_hal_def_var_handler_interface (
 
 #endif
 
-void
-odm_set_tx_power_index_by_rate_section (
-	struct PHY_DM_STRUCT	*p_dm,
-	enum rf_path		path,
-	u8				Channel,
-	u8				RateSection
-	)
+void odm_set_tx_power_index_by_rate_section(struct dm_struct *dm,
+					    enum rf_path path, u8 ch,
+					    u8 section)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	PHY_SetTxPowerIndexByRateSection(adapter, path, Channel, RateSection);
+	void *adapter = dm->adapter;
+	PHY_SetTxPowerIndexByRateSection(adapter, path, ch, section);
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	void *adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
-	phy_set_tx_power_index_by_rs(adapter, Channel, path, RateSection);
+	phy_set_tx_power_index_by_rs(adapter, ch, path, section);
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	phy_set_tx_power_index_by_rate_section(p_dm->adapter, path, Channel, RateSection);
+	phy_set_tx_power_index_by_rate_section(dm->adapter, path, ch, section);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
+
+	PHY_SetTxPowerIndexByRateSection(adapter, path, ch, section);
 #endif
 }
 
-
-u8
-odm_get_tx_power_index (
-	struct PHY_DM_STRUCT	*p_dm,
-	enum rf_path		path,
-	u8				tx_rate,
-	u8				band_width,
-	u8				Channel
-	)
+u8 odm_get_tx_power_index(struct dm_struct *dm, enum rf_path path, u8 rate,
+			  u8 bw, u8 ch)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
-	return PHY_GetTxPowerIndex(p_dm->adapter, path, tx_rate, (CHANNEL_WIDTH)band_width, Channel);
+	return PHY_GetTxPowerIndex(dm->adapter, path, rate, (CHANNEL_WIDTH)bw, ch);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	void		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
-	return phy_get_tx_power_index(adapter, (enum rf_path)path, tx_rate, band_width, Channel);
+	return phy_get_tx_power_index(adapter, path, rate, bw, ch);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	void *adapter = dm->adapter;
+
+	return phy_get_tx_power_index(adapter, path, rate, bw, ch);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	return phy_get_tx_power_index(p_dm->adapter, path, tx_rate, band_width, Channel);
+	return phy_get_tx_power_index(dm->adapter, path, rate, bw, ch);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
+
+	return PHY_GetTxPowerIndex(dm->adapter, path, rate, bw, ch);
 #endif
 }
 
-
-
-u8
-odm_efuse_one_byte_read(
-	struct PHY_DM_STRUCT	*p_dm,
-	u16			addr,
-	u8			*data,
-	boolean		b_pseu_do_test
-	)
+u8 odm_efuse_one_byte_read(struct dm_struct *dm, u16 addr, u8 *data,
+			   boolean b_pseu_do_test)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct	_ADAPTER	*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
 	return (u8)EFUSE_OneByteRead(adapter, addr, data, b_pseu_do_test);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	void		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
 	return rtl_efuse_onebyte_read(adapter, addr, data, b_pseu_do_test);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+	return -1;
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	return efuse_onebyte_read(p_dm->adapter, addr, data, b_pseu_do_test);
+	return efuse_onebyte_read(dm->adapter, addr, data, b_pseu_do_test);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	/*ReadEFuseByte(p_dm->priv, addr, data);*/
-	/*return true;*/
+	return Efuse_OneByteRead(dm, addr, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
+
+	return (u8)efuse_OneByteRead(adapter, addr, data, b_pseu_do_test);
 #endif
 }
 
-
-
-void
-odm_efuse_logical_map_read(
-	struct	PHY_DM_STRUCT	*p_dm,
-	u8	type,
-	u16	offset,
-	u32	*data
-)
+void odm_efuse_logical_map_read(struct dm_struct *dm, u8 type, u16 offset,
+				u32 *data)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct	_ADAPTER *adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
 	EFUSE_ShadowRead(adapter, type, offset, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	void		*adapter = p_dm->adapter;
+	void *adapter = dm->adapter;
 
 	rtl_efuse_logical_map_read(adapter, type, offset, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	efuse_logical_map_read(p_dm->adapter, type, offset, data);
+	efuse_logical_map_read(dm->adapter, type, offset, data);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	void *adapter = dm->adapter;
+
+	EFUSE_ShadowRead(adapter, type, offset, data);
 #endif
 }
 
 enum hal_status
-odm_iq_calibrate_by_fw(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8 clear,
-	u8 segment
-	)
+odm_iq_calibrate_by_fw(struct dm_struct *dm, u8 clear, u8 segment)
 {
 	enum hal_status iqk_result = HAL_STATUS_FAILURE;
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	struct	_ADAPTER	*adapter = p_dm->adapter;
+	struct _ADAPTER *adapter = dm->adapter;
 
 	if (HAL_MAC_FWIQK_Trigger(&GET_HAL_MAC_INFO(adapter), clear, segment) == 0)
 		iqk_result = HAL_STATUS_SUCCESS;
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	iqk_result = rtw_phydm_fw_iqk(p_dm, clear, segment);
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	void *adapter = dm->adapter;
+
+	iqk_result = rtl_phydm_fw_iqk(adapter, clear, segment);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+#else
+	iqk_result = rtw_phydm_fw_iqk(dm, clear, segment);
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_IOT)
+	iqk_result = rtw_phydm_fw_iqk(dm, clear, segment);
 #endif
 	return iqk_result;
 }
 
-void
-odm_cmn_info_ptr_array_hook(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum odm_cmninfo_e	cmn_info,
-	u16			index,
-	void			*p_value
-)
+void odm_cmn_info_ptr_array_hook(struct dm_struct *dm,
+				 enum odm_cmninfo cmn_info, u16 index,
+				 void *value)
 {
-	switch	(cmn_info) {
-	/*Dynamic call by reference pointer.	*/
-	case	ODM_CMNINFO_STA_STATUS:
-		p_dm->p_odm_sta_info[index] = (struct sta_info *)p_value;
-		break;
-	/* To remove the compiler warning, must add an empty default statement to handle the other values. */
-	default:
-		/* do nothing */
-		break;
-	}
-
+	/*ODM_CMNINFO_STA_STATUS*/
 }
 
-void
-phydm_cmn_sta_info_hook(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			mac_id,
-	struct cmn_sta_info *pcmn_sta_info
-)
+void phydm_cmn_sta_info_hook(struct dm_struct *dm, u8 mac_id,
+			     struct cmn_sta_info *pcmn_sta_info)
 {
-	p_dm->p_phydm_sta_info[mac_id] = pcmn_sta_info;
+	dm->phydm_sta_info[mac_id] = pcmn_sta_info;
 
 	if (is_sta_active(pcmn_sta_info))
-		p_dm->phydm_macid_table[pcmn_sta_info->mac_id] = mac_id;
+		dm->phydm_macid_table[pcmn_sta_info->mac_id] = mac_id;
 }
 
-void
-phydm_add_interrupt_mask_handler(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8							interrupt_type
-)
+void phydm_macid2sta_idx_table(struct dm_struct *dm, u8 entry_idx,
+			       struct cmn_sta_info *pcmn_sta_info)
+{
+	if (is_sta_active(pcmn_sta_info))
+		dm->phydm_macid_table[pcmn_sta_info->mac_id] = entry_idx;
+}
+
+void phydm_add_interrupt_mask_handler(struct dm_struct *dm, u8 interrupt_type)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-	struct rtl8192cd_priv	*priv = p_dm->priv;
+	struct rtl8192cd_priv *priv = dm->priv;
 
 	#if IS_EXIST_PCI || IS_EXIST_EMBEDDED
-	GET_HAL_INTERFACE(priv)->AddInterruptMaskHandler(priv, interrupt_type);
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		GET_HAL_INTERFACE(priv)->AddInterruptMaskHandler(priv,
+								 interrupt_type)
+								 ;
 	#endif
-	
+
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 #endif
 }
 
-void
-phydm_enable_rx_related_interrupt_handler(
-	struct PHY_DM_STRUCT		*p_dm
-)
+void phydm_enable_rx_related_interrupt_handler(struct dm_struct *dm)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-	struct rtl8192cd_priv	*priv = p_dm->priv;
+	struct rtl8192cd_priv *priv = dm->priv;
 
 	#if IS_EXIST_PCI || IS_EXIST_EMBEDDED
-	GET_HAL_INTERFACE(priv)->EnableRxRelatedInterruptHandler(priv);
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		GET_HAL_INTERFACE(priv)->EnableRxRelatedInterruptHandler(priv);
 	#endif
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 #endif
 }
 
+#if 0
 boolean
 phydm_get_txbf_en(
-	struct PHY_DM_STRUCT		*p_dm,
+	struct dm_struct		*dm,
 	u16							mac_id,
 	u8							i
 )
@@ -1310,13 +1313,13 @@ phydm_get_txbf_en(
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 #elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && !defined(DM_ODM_CE_MAC80211)
 
-	#ifdef CONFIG_BEAMFORMING
+#ifdef CONFIG_BEAMFORMING
 	enum beamforming_cap beamform_cap;
-	struct _ADAPTER *adapter = p_dm->adapter;
-	#if (BEAMFORMING_SUPPORT == 1)
+	void *adapter = dm->adapter;
+	#ifdef PHYDM_BEAMFORMING_SUPPORT
 	beamform_cap =
-	phydm_beamforming_get_entry_beam_cap_by_mac_id(p_dm, mac_id);
-	#else/*for drv beamforming*/
+	phydm_beamforming_get_entry_beam_cap_by_mac_id(dm, mac_id);
+	#else/*@for drv beamforming*/
 	beamform_cap =
 	beamforming_get_entry_beam_cap_by_mac_id(&adapter->mlmepriv, mac_id);
 	#endif
@@ -1324,64 +1327,143 @@ phydm_get_txbf_en(
 		txbf_en = true;
 	else
 		txbf_en = false;
-	#endif /*#ifdef CONFIG_BEAMFORMING*/
+#endif /*@#ifdef CONFIG_BEAMFORMING*/
 
 #elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
 
-	#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 	u8 idx = 0xff;
 	boolean act_bfer = false;
 	BEAMFORMING_CAP beamform_cap = BEAMFORMING_CAP_NONE;
-	PRT_BEAMFORMING_ENTRY	p_entry = NULL;
-	struct rtl8192cd_priv *priv			= p_dm->priv;
+	PRT_BEAMFORMING_ENTRY	entry = NULL;
+	struct rtl8192cd_priv *priv			= dm->priv;
 	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	struct _BF_DIV_COEX_	*p_dm_bdc_table = &p_dm->dm_bdc_table;
+	struct _BF_DIV_COEX_	*dm_bdc_table = &dm->dm_bdc_table;
 
-	p_dm_bdc_table->num_txbfee_client = 0;
-	p_dm_bdc_table->num_txbfer_client = 0;
-	#endif
+	dm_bdc_table->num_txbfee_client = 0;
+	dm_bdc_table->num_txbfer_client = 0;
 	#endif
+#endif
 
-	#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 	beamform_cap = Beamforming_GetEntryBeamCapByMacId(priv, mac_id);
-	p_entry = Beamforming_GetEntryByMacId(priv, mac_id, &idx);
+	entry = Beamforming_GetEntryByMacId(priv, mac_id, &idx);
 	if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU)) {
-		if (p_entry->Sounding_En)
+		if (entry->Sounding_En)
 			txbf_en = true;
 		else
 			txbf_en = false;
 		act_bfer = true;
 	}
-	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*BDC*/
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY)) /*@BDC*/
 	if (act_bfer == true) {
-		p_dm_bdc_table->w_bfee_client[i] = true; /* AP act as BFer */
-		p_dm_bdc_table->num_txbfee_client++;
+		dm_bdc_table->w_bfee_client[i] = true; /* @AP act as BFer */
+		dm_bdc_table->num_txbfee_client++;
 	} else
-		p_dm_bdc_table->w_bfee_client[i] = false; /* AP act as BFer */
-	
+		dm_bdc_table->w_bfee_client[i] = false; /* @AP act as BFer */
+
 	if (beamform_cap & (BEAMFORMEE_CAP_HT_EXPLICIT | BEAMFORMEE_CAP_VHT_SU)) {
-		p_dm_bdc_table->w_bfer_client[i] = true; /* AP act as BFee */
-		p_dm_bdc_table->num_txbfer_client++;
+		dm_bdc_table->w_bfer_client[i] = true; /* @AP act as BFee */
+		dm_bdc_table->num_txbfer_client++;
 	} else
-		p_dm_bdc_table->w_bfer_client[i] = false; /* AP act as BFer */
+		dm_bdc_table->w_bfer_client[i] = false; /* @AP act as BFer */
 
 	#endif
-	#endif
+#endif
 
 #endif
 	return txbf_en;
-
 }
+#endif
 
-void
-phydm_iqk_wait(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		timeout
-)
+void phydm_iqk_wait(struct dm_struct *dm, u32 timeout)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct _ADAPTER		*p_adapter = p_dm->adapter;
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, DBG_CMN, "Not support for CE MAC80211 driver!\n");
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+#else
+	void *adapter = dm->adapter;
+
+	rtl8812_iqk_wait(adapter, timeout);
+#endif
+#endif
+}
+
+u8 phydm_get_hwrate_to_mrate(struct dm_struct *dm, u8 rate)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	return HwRateToMRate(rate);
+#endif
+	return 0;
+}
+
+void phydm_set_crystalcap(struct dm_struct *dm, u8 crystal_cap)
+{
+#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	ROM_odm_SetCrystalCap(dm, crystal_cap);
+#endif
+}
 
-	rtl8812_iqk_wait(p_adapter, timeout);
+void phydm_run_in_thread_cmd(struct dm_struct *dm, void (*func)(void *),
+			     void *context)
+{
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+	PHYDM_DBG(dm, DBG_CMN, "Not support for CE MAC80211 driver!\n");
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+	void *adapter = dm->adapter;
+
+	rtw_run_in_thread_cmd(adapter, func, context);
 #endif
 }
+
+u32 phydm_get_tx_rate(struct dm_struct *dm)
+{
+	struct _hal_rf_ *rf = &dm->rf_table;
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	struct _ADAPTER *adapter = dm->adapter;
+#endif
+	u8 tx_rate = 0xFF;
+	u8 mpt_rate_index = 0;
+
+	if (*dm->mp_mode == 1) {
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+#if (MP_DRIVER == 1)
+		PMPT_CONTEXT p_mpt_ctx = &adapter->MptCtx;
+
+		tx_rate = MptToMgntRate(p_mpt_ctx->MptRateIndex);
+#endif
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+#ifdef CONFIG_MP_INCLUDED
+		if (rf->mp_rate_index)
+			mpt_rate_index = *rf->mp_rate_index;
+
+		tx_rate = mpt_to_mgnt_rate(mpt_rate_index);
+#endif
+#endif
+#endif
+	} else {
+		u16 rate = *dm->forced_data_rate;
+
+		if (!rate) { /*auto rate*/
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+			struct _ADAPTER *adapter = dm->adapter;
+
+			tx_rate = ((PADAPTER)adapter)->HalFunc.GetHwRateFromMRateHandler(dm->tx_rate);
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE) && defined(DM_ODM_CE_MAC80211)
+			tx_rate = dm->tx_rate;
+#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
+			if (dm->number_linked_client != 0)
+				tx_rate = hw_rate_to_m_rate(dm->tx_rate);
+			else
+				tx_rate = rf->p_rate_index;
+#endif
+		} else { /*force rate*/
+			tx_rate = (u8)rate;
+		}
+	}
+
+	return tx_rate;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.h
index 1b0f6c2d6d8c..bbfc094a6a81 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_interface.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,49 +9,63 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-
-#ifndef	__ODM_INTERFACE_H__
+#ifndef __ODM_INTERFACE_H__
 #define __ODM_INTERFACE_H__
 
-#define INTERFACE_VERSION	"1.2"		/*2017.05.03  YuChen add phy param offload HAL MAC API*/
+#define INTERFACE_VERSION "1.2"
+
+#define pdm_set_reg odm_set_bb_reg
 
-/*=========== Constant/Structure/Enum/... Define*/
+/*@=========== Constant/Structure/Enum/... Define*/
 
 enum phydm_h2c_cmd {
 	PHYDM_H2C_RA_MASK		= 0x40,
 	PHYDM_H2C_TXBF			= 0x41,
 	ODM_H2C_RSSI_REPORT		= 0x42,
-	ODM_H2C_IQ_CALIBRATION	= 0x45,
-	PHYDM_RA_MASK_ABOVE_3SS = 0x46,
-	ODM_H2C_RA_PARA_ADJUST	= 0x47,
-	PHYDM_H2C_DYNAMIC_TX_PATH = 0x48,
-	PHYDM_H2C_FW_TRACE_EN	= 0x49,
+	ODM_H2C_IQ_CALIBRATION		= 0x45,
+	PHYDM_RA_MASK_ABOVE_3SS		= 0x46,
+	ODM_H2C_RA_PARA_ADJUST		= 0x47,
+	PHYDM_H2C_DYNAMIC_TX_PATH	= 0x48,
+	PHYDM_H2C_FW_TRACE_EN		= 0x49,
 	ODM_H2C_WIFI_CALIBRATION	= 0x6d,
-	PHYDM_H2C_MU				= 0x4a,
-	PHYDM_H2C_FW_GENERAL_INIT = 0x4c,
-	PHYDM_H2C_FW_CLM_MNTR = 0x4d,
+	PHYDM_H2C_MU			= 0x4a,
+	PHYDM_H2C_FW_GENERAL_INIT	= 0x4c,
+	PHYDM_H2C_FW_CLM_MNTR		= 0x4d,
+	PHYDM_H2C_MCC			= 0x4f,
+	PHYDM_H2C_RESP_TX_PATH_CTRL	= 0x50,
+	PHYDM_H2C_RESP_TX_ANT_CTRL	= 0x51,
 	ODM_MAX_H2CCMD
 };
 
 enum phydm_c2h_evt {
-	PHYDM_C2H_DBG = 0,
-	PHYDM_C2H_LB = 1,
-	PHYDM_C2H_XBF = 2,
-	PHYDM_C2H_TX_REPORT = 3,
-	PHYDM_C2H_INFO = 9,
-	PHYDM_C2H_BT_MP = 11,
-	PHYDM_C2H_RA_RPT = 12,
+	PHYDM_C2H_DBG =		0,
+	PHYDM_C2H_LB =		1,
+	PHYDM_C2H_XBF =		2,
+	PHYDM_C2H_TX_REPORT =	3,
+	PHYDM_C2H_INFO =	9,
+	PHYDM_C2H_BT_MP =	11,
+	PHYDM_C2H_RA_RPT =	12,
 	PHYDM_C2H_RA_PARA_RPT = 14,
 	PHYDM_C2H_DYNAMIC_TX_PATH_RPT = 15,
-	PHYDM_C2H_IQK_FINISH = 17, /*0x11*/
-	PHYDM_C2H_CLM_MONITOR = 0x2a,
-	PHYDM_C2H_DBG_CODE = 0xFE,
-	PHYDM_C2H_EXTEND = 0xFF,
+	PHYDM_C2H_IQK_FINISH =	17, /*@0x11*/
+	PHYDM_C2H_CLM_MONITOR =	0x2a,
+	PHYDM_C2H_DBG_CODE =	0xFE,
+	PHYDM_C2H_EXTEND =	0xFF,
 };
 
 enum phydm_extend_c2h_evt {
@@ -71,435 +86,259 @@ enum phydm_halmac_param {
 	PHYDM_HALMAC_CMD_END = 0XFF,
 };
 
-/*=========== Macro Define*/
+/*@=========== Macro Define*/
 
 #define _reg_all(_name)			ODM_##_name
 #define _reg_ic(_name, _ic)		ODM_##_name##_ic
 #define _bit_all(_name)			BIT_##_name
 #define _bit_ic(_name, _ic)		BIT_##_name##_ic
 
-/* _cat: implemented by Token-Pasting Operator. */
+/* @_cat: implemented by Token-Pasting Operator. */
 #if 0
-#define _cat(_name, _ic_type, _func)								\
-	(\
-	 _func##_all(_name)										\
-	)
+#define _cat(_name, _ic_type, _func) \
+	(                            \
+		_func##_all(_name))
 #endif
 
-/*===================================
+#if 0
 
 #define ODM_REG_DIG_11N		0xC50
 #define ODM_REG_DIG_11AC	0xDDD
 
 ODM_REG(DIG,_pdm_odm)
-=====================================*/
+#endif
 
+#if defined(DM_ODM_CE_MAC80211)
+#define ODM_BIT(name, dm)				\
+	((dm->support_ic_type & ODM_IC_11N_SERIES) ?	\
+	 ODM_BIT_##name##_11N : ODM_BIT_##name##_11AC)
+
+#define ODM_REG(name, dm)				\
+	((dm->support_ic_type & ODM_IC_11N_SERIES) ?	\
+	 ODM_REG_##name##_11N : ODM_REG_##name##_11AC)
+#else
 #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
 
 #ifdef __ECOS
-#define _rtk_cat(_name, _ic_type, _func)		\
-	(\
-	 ((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) :		\
-	 _func##_11AC(_name)	\
-	)
+#define _rtk_cat(_name, _ic_type, _func)                                \
+	(                                                               \
+		((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) : \
+						   _func##_11AC(_name))
 #else
 
-#define _cat(_name, _ic_type, _func)									\
-	(\
-	 ((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) :		\
-	 _func##_11AC(_name)									\
-	)
+#define _cat(_name, _ic_type, _func)                                    \
+	(                                                               \
+		((_ic_type) & ODM_IC_11N_SERIES) ? _func##_11N(_name) : \
+						   _func##_11AC(_name))
 #endif
-/*
+/*@
  * only sample code
- *#define _cat(_name, _ic_type, _func)									\
- *	(															\
- *		((_ic_type) & ODM_RTL8188E) ? _func##_ic(_name, _8188E) :		\
- *		_func##_ic(_name, _8195)									\
+ *#define _cat(_name, _ic_type, _func)					\
+ *	(								\
+ *		((_ic_type) & ODM_RTL8188E) ? _func##_ic(_name, _8188E) :\
+ *		_func##_ic(_name, _8195)				\
  *	)
  */
 
-/* _name: name of register or bit.
- * Example: "ODM_REG(R_A_AGC_CORE1, p_dm)"
- * gets "ODM_R_A_AGC_CORE1" or "ODM_R_A_AGC_CORE1_8192C", depends on support_ic_type. */
+/* @_name: name of register or bit.
+ * Example: "ODM_REG(R_A_AGC_CORE1, dm)"
+ * gets "ODM_R_A_AGC_CORE1" or "ODM_R_A_AGC_CORE1_8192C",
+ * depends on support_ic_type.
+ */
 #ifdef __ECOS
-	#define ODM_REG(_name, _pdm_odm)	_rtk_cat(_name, _pdm_odm->support_ic_type, _reg)
-	#define ODM_BIT(_name, _pdm_odm)	_rtk_cat(_name, _pdm_odm->support_ic_type, _bit)
+	#define ODM_REG(_name, _pdm_odm)	\
+		_rtk_cat(_name, _pdm_odm->support_ic_type, _reg)
+	#define ODM_BIT(_name, _pdm_odm)	\
+		_rtk_cat(_name, _pdm_odm->support_ic_type, _bit)
 #else
-	#define ODM_REG(_name, _pdm_odm)	_cat(_name, _pdm_odm->support_ic_type, _reg)
-	#define ODM_BIT(_name, _pdm_odm)	_cat(_name, _pdm_odm->support_ic_type, _bit)
+	#define ODM_REG(_name, _pdm_odm)	\
+		_cat(_name, _pdm_odm->support_ic_type, _reg)
+	#define ODM_BIT(_name, _pdm_odm)	\
+		_cat(_name, _pdm_odm->support_ic_type, _bit)
 #endif
 
-/*
+#endif
+/*@
  * =========== Extern Variable ??? It should be forbidden.
- *   */
-
+ */
 
-/*
+/*@
  * =========== EXtern Function Prototype
- *   */
+ */
 
+u8 odm_read_1byte(struct dm_struct *dm, u32 reg_addr);
 
-u8
-odm_read_1byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr
-);
+u16 odm_read_2byte(struct dm_struct *dm, u32 reg_addr);
 
-u16
-odm_read_2byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr
-);
+u32 odm_read_4byte(struct dm_struct *dm, u32 reg_addr);
 
-u32
-odm_read_4byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr
-);
+void odm_write_1byte(struct dm_struct *dm, u32 reg_addr, u8 data);
 
-void
-odm_write_1byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr,
-	u8			data
-);
+void odm_write_2byte(struct dm_struct *dm, u32 reg_addr, u16 data);
 
-void
-odm_write_2byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr,
-	u16			data
-);
+void odm_write_4byte(struct dm_struct *dm, u32 reg_addr, u32 data);
 
-void
-odm_write_4byte(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32			reg_addr,
-	u32			data
-);
+void odm_set_mac_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask,
+		     u32 data);
 
-void
-odm_set_mac_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask,
-	u32		data
-);
+u32 odm_get_mac_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask);
 
-u32
-odm_get_mac_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask
-);
+void odm_set_bb_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask, u32 data);
 
-void
-odm_set_bb_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask,
-	u32		data
-);
+u32 odm_get_bb_reg(struct dm_struct *dm, u32 reg_addr, u32 bit_mask);
 
-u32
-odm_get_bb_reg(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		reg_addr,
-	u32		bit_mask
-);
-
-void
-odm_set_rf_reg(
-	struct PHY_DM_STRUCT			*p_dm,
-	u8			e_rf_path,
-	u32				reg_addr,
-	u32				bit_mask,
-	u32				data
-);
+void odm_set_rf_reg(struct dm_struct *dm, u8 e_rf_path, u32 reg_addr,
+		    u32 bit_mask, u32 data);
 
-u32
-odm_get_rf_reg(
-	struct PHY_DM_STRUCT			*p_dm,
-	u8			e_rf_path,
-	u32				reg_addr,
-	u32				bit_mask
-);
+u32 odm_get_rf_reg(struct dm_struct *dm, u8 e_rf_path, u32 reg_addr,
+		   u32 bit_mask);
 
-
-/*
+/*@
  * Memory Relative Function.
- *   */
-void
-odm_allocate_memory(
-	struct PHY_DM_STRUCT	*p_dm,
-	void **p_ptr,
-	u32		length
-);
-void
-odm_free_memory(
-	struct PHY_DM_STRUCT	*p_dm,
-	void		*p_ptr,
-	u32		length
-);
+ */
+void odm_allocate_memory(struct dm_struct *dm, void **ptr, u32 length);
+void odm_free_memory(struct dm_struct *dm, void *ptr, u32 length);
 
-void
-odm_move_memory(
-	struct PHY_DM_STRUCT	*p_dm,
-	void		*p_dest,
-	void		*p_src,
-	u32		length
-);
+void odm_move_memory(struct dm_struct *dm, void *dest, void *src, u32 length);
 
-s32 odm_compare_memory(
-	struct PHY_DM_STRUCT	*p_dm,
-	void           *p_buf1,
-	void           *p_buf2,
-	u32          length
-);
+s32 odm_compare_memory(struct dm_struct *dm, void *buf1, void *buf2,
+		       u32 length);
 
-void odm_memory_set(
-	struct PHY_DM_STRUCT	*p_dm,
-	void	*pbuf,
-	s8	value,
-	u32	length
-);
+void odm_memory_set(struct dm_struct *dm, void *pbuf, s8 value, u32 length);
 
-/*
+/*@
  * ODM MISC-spin lock relative API.
- *   */
-void
-odm_acquire_spin_lock(
-	struct PHY_DM_STRUCT			*p_dm,
-	enum rt_spinlock_type	type
-);
+ */
+void odm_acquire_spin_lock(struct dm_struct *dm, enum rt_spinlock_type type);
 
-void
-odm_release_spin_lock(
-	struct PHY_DM_STRUCT			*p_dm,
-	enum rt_spinlock_type	type
-);
+void odm_release_spin_lock(struct dm_struct *dm, enum rt_spinlock_type type);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-/*
+/*@
  * ODM MISC-workitem relative API.
- *   */
-void
-odm_initialize_work_item(
-	struct PHY_DM_STRUCT					*p_dm,
-	PRT_WORK_ITEM				p_rt_work_item,
-	RT_WORKITEM_CALL_BACK		rt_work_item_callback,
-	void						*p_context,
-	const char					*sz_id
-);
+ */
+void odm_initialize_work_item(
+	struct dm_struct *dm,
+	PRT_WORK_ITEM p_rt_work_item,
+	RT_WORKITEM_CALL_BACK rt_work_item_callback,
+	void *context,
+	const char *sz_id);
 
-void
-odm_start_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-);
+void odm_start_work_item(
+	PRT_WORK_ITEM p_rt_work_item);
 
-void
-odm_stop_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-);
+void odm_stop_work_item(
+	PRT_WORK_ITEM p_rt_work_item);
 
-void
-odm_free_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-);
+void odm_free_work_item(
+	PRT_WORK_ITEM p_rt_work_item);
 
-void
-odm_schedule_work_item(
-	PRT_WORK_ITEM	p_rt_work_item
-);
+void odm_schedule_work_item(
+	PRT_WORK_ITEM p_rt_work_item);
 
 boolean
 odm_is_work_item_scheduled(
-	PRT_WORK_ITEM	p_rt_work_item
-);
+	PRT_WORK_ITEM p_rt_work_item);
 #endif
 
-/*
+/*@
  * ODM Timer relative API.
- *   */
-void
-ODM_delay_ms(u32	ms);
+ */
+void ODM_delay_ms(u32 ms);
 
-void
-ODM_delay_us(u32	us);
+void ODM_delay_us(u32 us);
 
-void
-ODM_sleep_ms(u32	ms);
+void ODM_sleep_ms(u32 ms);
 
-void
-ODM_sleep_us(u32	us);
+void ODM_sleep_us(u32 us);
 
-void
-odm_set_timer(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct timer_list		*p_timer,
-	u32			ms_delay
-);
+void odm_set_timer(struct dm_struct *dm, struct phydm_timer_list *timer,
+		   u32 ms_delay);
 
-void
-odm_initialize_timer(
-	struct PHY_DM_STRUCT			*p_dm,
-	struct timer_list			*p_timer,
-	void	*call_back_func,
-	void				*p_context,
-	const char			*sz_id
-);
+void odm_initialize_timer(struct dm_struct *dm, struct phydm_timer_list *timer,
+			  void *call_back_func, void *context,
+			  const char *sz_id);
 
-void
-odm_cancel_timer(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct timer_list		*p_timer
-);
+void odm_cancel_timer(struct dm_struct *dm, struct phydm_timer_list *timer);
 
-void
-odm_release_timer(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct timer_list		*p_timer
-);
+void odm_release_timer(struct dm_struct *dm, struct phydm_timer_list *timer);
 
 /*ODM FW relative API.*/
 
-
 enum hal_status
-phydm_set_reg_by_fw(
-	struct PHY_DM_STRUCT			*p_dm,
-	enum phydm_halmac_param	config_type,
-	u32	offset,
-	u32	data,
-	u32	mask,
-	enum rf_path	e_rf_path,
-	u32 delay_time
-);
+phydm_set_reg_by_fw(struct dm_struct *dm, enum phydm_halmac_param config_type,
+		    u32 offset, u32 data, u32 mask, enum rf_path e_rf_path,
+		    u32 delay_time);
 
-void
-odm_fill_h2c_cmd(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			element_id,
-	u32			cmd_len,
-	u8			*p_cmd_buffer
-);
+void odm_fill_h2c_cmd(struct dm_struct *dm, u8 element_id, u32 cmd_len,
+		      u8 *cmd_buffer);
 
-u8
-phydm_c2H_content_parsing(
-	void			*p_dm_void,
-	u8			c2h_cmd_id,
-	u8			c2h_cmd_len,
-	u8			*tmp_buf
-);
+u8 phydm_c2H_content_parsing(void *dm_void, u8 c2h_cmd_id, u8 c2h_cmd_len,
+			     u8 *tmp_buf);
 
-u64
-odm_get_current_time(
-	struct PHY_DM_STRUCT		*p_dm
-);
-u64
-odm_get_progressing_time(
-	struct PHY_DM_STRUCT		*p_dm,
-	u64			start_time
-);
+u64 odm_get_current_time(struct dm_struct *dm);
+u64 odm_get_progressing_time(struct dm_struct *dm, u64 start_time);
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN|ODM_CE)) && !defined(DM_ODM_CE_MAC80211)
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE)) && \
+	(!defined(DM_ODM_CE_MAC80211) && !defined(DM_ODM_CE_MAC80211_V2))
 
-void
-phydm_set_hw_reg_handler_interface (
-	struct PHY_DM_STRUCT		*p_dm,
-	u8				reg_Name,
-	u8				*val
-	);
+void phydm_set_hw_reg_handler_interface(struct dm_struct *dm, u8 reg_Name,
+					u8 *val);
 
-void
-phydm_get_hal_def_var_handler_interface (
-	struct PHY_DM_STRUCT		*p_dm,
-	enum _HAL_DEF_VARIABLE		e_variable,
-	void						*p_value
-	);
+void phydm_get_hal_def_var_handler_interface(struct dm_struct *dm,
+					     enum _HAL_DEF_VARIABLE e_variable,
+					     void *value);
 
 #endif
 
-void
-odm_set_tx_power_index_by_rate_section (
-	struct PHY_DM_STRUCT	*p_dm,
-	enum rf_path		path,
-	u8				Channel,
-	u8				RateSection
-);
+void odm_set_tx_power_index_by_rate_section(struct dm_struct *dm,
+					    enum rf_path path, u8 channel,
+					    u8 rate_section);
 
-u8
-odm_get_tx_power_index (
-	struct PHY_DM_STRUCT	*p_dm,
-	enum rf_path		path,
-	u8				tx_rate,
-	u8				band_width,
-	u8				Channel
-);
+u8 odm_get_tx_power_index(struct dm_struct *dm, enum rf_path path, u8 tx_rate,
+			  u8 band_width, u8 channel);
 
-u8
-odm_efuse_one_byte_read(
-	struct PHY_DM_STRUCT	*p_dm,
-	u16			addr,
-	u8			*data,
-	boolean		b_pseu_do_test
-);
+u8 odm_efuse_one_byte_read(struct dm_struct *dm, u16 addr, u8 *data,
+			   boolean b_pseu_do_test);
 
-void
-odm_efuse_logical_map_read(
-	struct	PHY_DM_STRUCT	*p_dm,
-	u8	type,
-	u16	offset,
-	u32	*data
-);
+void odm_efuse_logical_map_read(struct dm_struct *dm, u8 type, u16 offset,
+				u32 *data);
 
 enum hal_status
-odm_iq_calibrate_by_fw(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8 clear,
-	u8 segment
-);
+odm_iq_calibrate_by_fw(struct dm_struct *dm, u8 clear, u8 segment);
 
-void
-odm_cmn_info_ptr_array_hook(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum odm_cmninfo_e	cmn_info,
-	u16			index,
-	void			*p_value
-);
+void odm_cmn_info_ptr_array_hook(struct dm_struct *dm,
+				 enum odm_cmninfo cmn_info, u16 index,
+				 void *value);
 
-void
-phydm_cmn_sta_info_hook(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			index,
-	struct cmn_sta_info *pcmn_sta_info
-);
+void phydm_cmn_sta_info_hook(struct dm_struct *dm, u8 index,
+			     struct cmn_sta_info *pcmn_sta_info);
 
-void
-phydm_add_interrupt_mask_handler(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8							interrupt_type
-);
+void phydm_macid2sta_idx_table(struct dm_struct *dm, u8 entry_idx,
+			       struct cmn_sta_info *pcmn_sta_info);
 
-void
-phydm_enable_rx_related_interrupt_handler(
-	struct PHY_DM_STRUCT		*p_dm
-);
+void phydm_add_interrupt_mask_handler(struct dm_struct *dm, u8 interrupt_type);
+
+void phydm_enable_rx_related_interrupt_handler(struct dm_struct *dm);
 
+#if 0
 boolean
 phydm_get_txbf_en(
-	struct PHY_DM_STRUCT		*p_dm,
+	struct dm_struct		*dm,
 	u16		mac_id,
 	u8		i
 );
+#endif
 
-void
-phydm_iqk_wait(
-	struct PHY_DM_STRUCT		*p_dm,
-	u32		timeout
-);
-#endif /* __ODM_INTERFACE_H__ */
+void phydm_iqk_wait(struct dm_struct *dm, u32 timeout);
+
+u8 phydm_get_hwrate_to_mrate(struct dm_struct *dm, u8 rate);
 
+void phydm_set_crystalcap(struct dm_struct *dm, u8 crystal_cap);
+void phydm_run_in_thread_cmd(struct dm_struct *dm, void (*func)(void *),
+			     void *context);
+u32 phydm_get_tx_rate(struct dm_struct *dm);
+#endif /* @__ODM_INTERFACE_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_lna_sat.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_lna_sat.c
new file mode 100644
index 000000000000..f89d4895913f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_lna_sat.c
@@ -0,0 +1,1344 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*************************************************************
+ * include files
+ * *************************************************************/
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+
+#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+void phydm_lna_sat_chk_init(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t *lna_info = &dm->dm_lna_sat_info;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);
+
+	lna_info->check_time = 0;
+	lna_info->sat_cnt_acc_patha = 0;
+	lna_info->sat_cnt_acc_pathb = 0;
+	#ifdef PHYDM_IC_ABOVE_3SS
+	lna_info->sat_cnt_acc_pathc = 0;
+	#endif
+	#ifdef PHYDM_IC_ABOVE_4SS
+	lna_info->sat_cnt_acc_pathd = 0;
+	#endif
+	lna_info->cur_sat_status = 0;
+	lna_info->pre_sat_status = 0;
+	lna_info->cur_timer_check_cnt = 0;
+	lna_info->pre_timer_check_cnt = 0;
+
+	#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type &
+	    (ODM_RTL8198F | ODM_RTL8814B))
+		phydm_lna_sat_chk_bb_init(dm);
+	#endif
+}
+
+#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+void phydm_lna_sat_chk_bb_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t *lna_info = &dm->dm_lna_sat_info;
+
+	boolean disable_bb_switch_tab = false;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);
+
+	/*@set table switch mux r_6table_sel_anten*/
+	odm_set_bb_reg(dm, 0x18ac, BIT(8), 0);
+
+	/*@tab decision when idle*/
+	odm_set_bb_reg(dm, 0x18ac, BIT(16), disable_bb_switch_tab);
+	odm_set_bb_reg(dm, 0x41ac, BIT(16), disable_bb_switch_tab);
+	odm_set_bb_reg(dm, 0x52ac, BIT(16), disable_bb_switch_tab);
+	odm_set_bb_reg(dm, 0x53ac, BIT(16), disable_bb_switch_tab);
+	/*@tab decision when ofdmcca*/
+	odm_set_bb_reg(dm, 0x18ac, BIT(17), disable_bb_switch_tab);
+	odm_set_bb_reg(dm, 0x41ac, BIT(17), disable_bb_switch_tab);
+	odm_set_bb_reg(dm, 0x52ac, BIT(17), disable_bb_switch_tab);
+	odm_set_bb_reg(dm, 0x53ac, BIT(17), disable_bb_switch_tab);
+}
+
+void phydm_set_ofdm_agc_tab_path(
+	void *dm_void,
+	u8 tab_sel,
+	enum rf_path path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);
+	if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B)) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "set AGC Tab%d\n", tab_sel);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "r_6table_sel_anten = 0x%x\n",
+			  odm_get_bb_reg(dm, 0x18ac, BIT(8)));
+	}
+
+	if (dm->support_ic_type & ODM_RTL8198F) {
+		/*@table sel:0/2, mapping 2 to 1 */
+		if (tab_sel == OFDM_AGC_TAB_0) {
+			odm_set_bb_reg(dm, 0x18ac, BIT(4), 0);
+			odm_set_bb_reg(dm, 0x41ac, BIT(4), 0);
+			odm_set_bb_reg(dm, 0x52ac, BIT(4), 0);
+			odm_set_bb_reg(dm, 0x53ac, BIT(4), 0);
+		} else if (tab_sel == OFDM_AGC_TAB_2) {
+			odm_set_bb_reg(dm, 0x18ac, BIT(4), 1);
+			odm_set_bb_reg(dm, 0x41ac, BIT(4), 1);
+			odm_set_bb_reg(dm, 0x52ac, BIT(4), 1);
+			odm_set_bb_reg(dm, 0x53ac, BIT(4), 1);
+		} else {
+			odm_set_bb_reg(dm, 0x18ac, BIT(4), 0);
+			odm_set_bb_reg(dm, 0x41ac, BIT(4), 0);
+			odm_set_bb_reg(dm, 0x52ac, BIT(4), 0);
+			odm_set_bb_reg(dm, 0x53ac, BIT(4), 0);
+		}
+	} else if (dm->support_ic_type & ODM_RTL8814B) {
+		if (tab_sel == OFDM_AGC_TAB_0) {
+			odm_set_bb_reg(dm, 0x18ac, 0xf0, 0);
+			odm_set_bb_reg(dm, 0x41ac, 0xf0, 0);
+			odm_set_bb_reg(dm, 0x52ac, 0xf0, 0);
+			odm_set_bb_reg(dm, 0x53ac, 0xf0, 0);
+		} else if (tab_sel == OFDM_AGC_TAB_2) {
+			odm_set_bb_reg(dm, 0x18ac, 0xf0, 2);
+			odm_set_bb_reg(dm, 0x41ac, 0xf0, 2);
+			odm_set_bb_reg(dm, 0x52ac, 0xf0, 2);
+			odm_set_bb_reg(dm, 0x53ac, 0xf0, 2);
+		} else {
+			odm_set_bb_reg(dm, 0x18ac, 0xf0, 0);
+			odm_set_bb_reg(dm, 0x41ac, 0xf0, 0);
+			odm_set_bb_reg(dm, 0x52ac, 0xf0, 0);
+			odm_set_bb_reg(dm, 0x53ac, 0xf0, 0);
+		}
+	}
+}
+
+u8 phydm_get_ofdm_agc_tab_path(
+	void *dm_void,
+	enum rf_path path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 tab_sel = 0;
+
+	if (dm->support_ic_type & ODM_RTL8198F) {
+		tab_sel = (u8)odm_get_bb_reg(dm, R_0x18ac, BIT(4));
+		if (tab_sel == 0)
+			tab_sel = OFDM_AGC_TAB_0;
+		else if (tab_sel == 1)
+			tab_sel = OFDM_AGC_TAB_2;
+	} else if (dm->support_ic_type & ODM_RTL8814B) {
+		tab_sel = (u8)odm_get_bb_reg(dm, R_0x18ac, 0xf0);
+		if (tab_sel == 0)
+			tab_sel = OFDM_AGC_TAB_0;
+		else if (tab_sel == 2)
+			tab_sel = OFDM_AGC_TAB_2;
+	}
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "get path %d AGC Tab %d\n",
+		  path, tab_sel);
+	return tab_sel;
+}
+#endif /*@#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)*/
+
+void phydm_set_ofdm_agc_tab(
+	void *dm_void,
+	u8 tab_sel)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	/*@table sel:0/2, 1 is used for CCK */
+	if (tab_sel == OFDM_AGC_TAB_0)
+		odm_set_bb_reg(dm, R_0xc70, 0x1e00, OFDM_AGC_TAB_0);
+	else if (tab_sel == OFDM_AGC_TAB_2)
+		odm_set_bb_reg(dm, R_0xc70, 0x1e00, OFDM_AGC_TAB_2);
+	else
+		odm_set_bb_reg(dm, R_0xc70, 0x1e00, OFDM_AGC_TAB_0);
+}
+
+u8 phydm_get_ofdm_agc_tab(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	return (u8)odm_get_bb_reg(dm, R_0xc70, 0x1e00);
+}
+
+void phydm_lna_sat_chk(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_dig_struct *dig_t = &dm->dm_dig_table;
+	struct phydm_lna_sat_t *lna_info = &dm->dm_lna_sat_info;
+	u8 igi_rssi_min;
+	u8 rssi_min = dm->rssi_min;
+	u32 sat_status_a, sat_status_b;
+	#ifdef PHYDM_IC_ABOVE_3SS
+	u32 sat_status_c;
+	#endif
+	#ifdef PHYDM_IC_ABOVE_4SS
+	u32 sat_status_d;
+	#endif
+	u8 igi_restore = dig_t->cur_ig_value;
+	u8 i, chk_cnt = lna_info->chk_cnt;
+	u32 lna_sat_cnt_thd = 0;
+	u8 agc_tab;
+	u32 max_check_time = 0;
+	/*@use rssi_max if rssi_min is not stable;*/
+	/*@rssi_min = dm->rssi_max;*/
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __func__);
+
+	if (!(dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "Func disable\n");
+		return;
+	}
+
+	if (lna_info->is_disable_lna_sat_chk) {
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "disable_lna_sat_chk\n");
+		return;
+	}
+
+	/*@move igi to target pin of rssi_min */
+	if (rssi_min == 0 || rssi_min == 0xff) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			  "rssi_min=%d, set AGC Tab0\n", rssi_min);
+		/*@adapt agc table 0*/
+		phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		phydm_lna_sat_chk_init(dm);
+		return;
+	} else if (rssi_min % 2 != 0) {
+		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI - 1;
+	} else {
+		igi_rssi_min = rssi_min + DIFF_RSSI_TO_IGI;
+	}
+
+	if ((lna_info->chk_period > 0) && (lna_info->chk_period <= ONE_SEC_MS))
+		max_check_time = chk_cnt * (ONE_SEC_MS / (lna_info->chk_period)) * 5;
+	else
+		max_check_time = chk_cnt * 5;
+
+	lna_sat_cnt_thd = (max_check_time * lna_info->chk_duty_cycle) / 100;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		  "check_time=%d, rssi_min=%d, igi_rssi_min=0x%x\nchk_cnt=%d, chk_period=%d, max_check_time=%d, lna_sat_cnt_thd=%d\n",
+		  lna_info->check_time,
+		  rssi_min,
+		  igi_rssi_min,
+		  chk_cnt,
+		  lna_info->chk_period,
+		  max_check_time,
+		  lna_sat_cnt_thd);
+
+	odm_write_dig(dm, igi_rssi_min);
+
+	/*@adapt agc table 0 check saturation status*/
+	#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B))
+		phydm_set_ofdm_agc_tab_path(dm, OFDM_AGC_TAB_0, RF_PATH_A);
+	else
+	#endif
+		phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+	/*@open rf power detection ckt & set detection range */
+	#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8198F) {
+		/*@set rf detection range (threshold)*/
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_A, 0x85,
+						0x3f, 0x3f);
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_B, 0x85,
+						0x3f, 0x3f);
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_C, 0x85,
+						0x3f, 0x3f);
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_D, 0x85,
+						0x3f, 0x3f);
+		/*@open rf power detection ckt*/
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_A, 0x86, 0x10, 1);
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_B, 0x86, 0x10, 1);
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_C, 0x86, 0x10, 1);
+		config_phydm_write_rf_reg_8198f(dm, RF_PATH_D, 0x86, 0x10, 1);
+	} else if (dm->support_ic_type & ODM_RTL8814B) {
+		/*@set rf detection range (threshold)*/
+#if 0
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_A, 0x87, 0x3, 0x3);
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_B, 0x87, 0x3, 0x3);
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_C, 0x87, 0x3, 0x3);
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_D, 0x87, 0x3, 0x3);
+#endif
+		/*@open rf power detection ckt*/
+#if 0
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_A, 0x87, 0x10, 1);
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_B, 0x87, 0x10, 1);
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_C, 0x87, 0x10, 1);
+		config_phydm_write_rf_reg_8814b(dm, RF_PATH_D, 0x87, 0x10, 1);
+#endif
+	} else
+	#endif
+	{
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x86, 0x1f, 0x10);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x86, 0x1f, 0x10);
+		#ifdef PHYDM_IC_ABOVE_3SS
+		odm_set_rf_reg(dm, RF_PATH_C, RF_0x86, 0x1f, 0x10);
+		#endif
+		#ifdef PHYDM_IC_ABOVE_4SS
+		odm_set_rf_reg(dm, RF_PATH_D, RF_0x86, 0x1f, 0x10);
+		#endif
+	}
+
+	/*@check saturation status*/
+	for (i = 0; i < chk_cnt; i++) {
+	#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8198F) {
+		sat_status_a = config_phydm_read_rf_reg_8198f(dm, RF_PATH_A,
+							      RF_0xae,
+							      0xe0000);
+		sat_status_b = config_phydm_read_rf_reg_8198f(dm, RF_PATH_B,
+							      RF_0xae,
+							      0xe0000);
+		sat_status_c = config_phydm_read_rf_reg_8198f(dm, RF_PATH_C,
+							      RF_0xae,
+							      0xe0000);
+		sat_status_d = config_phydm_read_rf_reg_8198f(dm, RF_PATH_D,
+							      RF_0xae,
+							      0xe0000);
+	} else if (dm->support_ic_type & ODM_RTL8814B) {
+	/*@read peak detector info from 8814B rf reg*/
+#if 0
+		sat_status_a = config_phydm_read_rf_reg_8814b(dm, RF_PATH_A,
+							      RF_0xae,
+							      0xc0000);
+		sat_status_b = config_phydm_read_rf_reg_8814b(dm, RF_PATH_B,
+							      RF_0xae,
+							      0xc0000);
+		sat_status_c = config_phydm_read_rf_reg_8814b(dm, RF_PATH_C,
+							      RF_0xae,
+							      0xc0000);
+		sat_status_d = config_phydm_read_rf_reg_8814b(dm, RF_PATH_D,
+							      RF_0xae,
+							      0xc0000);
+#endif
+	} else
+	#endif
+	{
+		sat_status_a = odm_get_rf_reg(dm, RF_PATH_A, RF_0xae, 0xc0000);
+		sat_status_b = odm_get_rf_reg(dm, RF_PATH_B, RF_0xae, 0xc0000);
+		#ifdef PHYDM_IC_ABOVE_3SS
+		sat_status_c = odm_get_rf_reg(dm, RF_PATH_C, RF_0xae, 0xc0000);
+		#endif
+		#ifdef PHYDM_IC_ABOVE_4SS
+		sat_status_d = odm_get_rf_reg(dm, RF_PATH_D, RF_0xae, 0xc0000);
+		#endif
+	}
+
+		if (sat_status_a != 0)
+			lna_info->sat_cnt_acc_patha++;
+		if (sat_status_b != 0)
+			lna_info->sat_cnt_acc_pathb++;
+		#ifdef PHYDM_IC_ABOVE_3SS
+		if (sat_status_c != 0)
+			lna_info->sat_cnt_acc_pathc++;
+		#endif
+		#ifdef PHYDM_IC_ABOVE_4SS
+		if (sat_status_d != 0)
+			lna_info->sat_cnt_acc_pathd++;
+		#endif
+
+		if (lna_info->sat_cnt_acc_patha >= lna_sat_cnt_thd ||
+		    lna_info->sat_cnt_acc_pathb >= lna_sat_cnt_thd ||
+		    #ifdef PHYDM_IC_ABOVE_3SS
+		    lna_info->sat_cnt_acc_pathc >= lna_sat_cnt_thd ||
+		    #endif
+		    #ifdef PHYDM_IC_ABOVE_4SS
+		    lna_info->sat_cnt_acc_pathd >= lna_sat_cnt_thd ||
+		    #endif
+		    0) {
+			lna_info->cur_sat_status = 1;
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+				  "cur_sat_status=%d, check_time=%d\n",
+				  lna_info->cur_sat_status,
+				  lna_info->check_time);
+			break;
+		}
+		lna_info->cur_sat_status = 0;
+	}
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		  "cur_sat_status=%d, pre_sat_status=%d, sat_cnt_acc_patha=%d, sat_cnt_acc_pathb=%d\n",
+		  lna_info->cur_sat_status,
+		  lna_info->pre_sat_status,
+		  lna_info->sat_cnt_acc_patha,
+		  lna_info->sat_cnt_acc_pathb);
+
+	#ifdef PHYDM_IC_ABOVE_4SS
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		  "cur_sat_status=%d, pre_sat_status=%d, sat_cnt_acc_pathc=%d, sat_cnt_acc_pathd=%d\n",
+		  lna_info->cur_sat_status,
+		  lna_info->pre_sat_status,
+		  lna_info->sat_cnt_acc_pathc,
+		  lna_info->sat_cnt_acc_pathd);
+	#endif
+	/*@agc table decision*/
+	if (lna_info->cur_sat_status) {
+		if (!lna_info->dis_agc_table_swh)
+			#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+			if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B))
+				phydm_set_ofdm_agc_tab_path(dm,
+							    OFDM_AGC_TAB_2,
+							    RF_PATH_A);
+			else
+			#endif
+				phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_2);
+		else
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+				  "disable set to AGC Tab%d\n", OFDM_AGC_TAB_2);
+		lna_info->check_time = 0;
+		lna_info->sat_cnt_acc_patha = 0;
+		lna_info->sat_cnt_acc_pathb = 0;
+		#ifdef PHYDM_IC_ABOVE_3SS
+		lna_info->sat_cnt_acc_pathc = 0;
+		#endif
+		#ifdef PHYDM_IC_ABOVE_4SS
+		lna_info->sat_cnt_acc_pathd = 0;
+		#endif
+		lna_info->pre_sat_status = lna_info->cur_sat_status;
+
+	} else if (lna_info->check_time <= (max_check_time - 1)) {
+		if (lna_info->pre_sat_status && !lna_info->dis_agc_table_swh)
+			#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+			if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B))
+				phydm_set_ofdm_agc_tab_path(dm,
+							    OFDM_AGC_TAB_2,
+							    RF_PATH_A);
+			else
+			#endif
+				phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_2);
+
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "ckeck time not reached\n");
+		if (lna_info->dis_agc_table_swh)
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+				  "disable set to AGC Tab%d\n", OFDM_AGC_TAB_2);
+		lna_info->check_time++;
+
+	} else if (lna_info->check_time >= max_check_time) {
+		if (!lna_info->dis_agc_table_swh)
+			#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+			if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B))
+				phydm_set_ofdm_agc_tab_path(dm,
+							    OFDM_AGC_TAB_0,
+							    RF_PATH_A);
+			else
+			#endif
+				phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "ckeck time reached\n");
+		if (lna_info->dis_agc_table_swh)
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+				  "disable set to AGC Tab%d\n", OFDM_AGC_TAB_0);
+		lna_info->check_time = 0;
+		lna_info->sat_cnt_acc_patha = 0;
+		lna_info->sat_cnt_acc_pathb = 0;
+		#ifdef PHYDM_IC_ABOVE_3SS
+		lna_info->sat_cnt_acc_pathc = 0;
+		#endif
+		#ifdef PHYDM_IC_ABOVE_4SS
+		lna_info->sat_cnt_acc_pathd = 0;
+		#endif
+		lna_info->pre_sat_status = lna_info->cur_sat_status;
+	}
+
+	#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B))
+		agc_tab = phydm_get_ofdm_agc_tab_path(dm, RF_PATH_A);
+	else
+	#endif
+		agc_tab = phydm_get_ofdm_agc_tab(dm);
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "use AGC tab %d\n", agc_tab);
+
+	/*@restore previous igi*/
+	odm_write_dig(dm, igi_restore);
+	lna_info->cur_timer_check_cnt++;
+	odm_set_timer(dm, &lna_info->phydm_lna_sat_chk_timer,
+		      lna_info->chk_period);
+}
+
+void phydm_lna_sat_chk_callback(
+	void *dm_void
+
+	)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __func__);
+	phydm_lna_sat_chk(dm);
+}
+
+void phydm_lna_sat_chk_timers(
+	void *dm_void,
+	u8 state)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t *lna_info = &dm->dm_lna_sat_info;
+
+	if (state == INIT_LNA_SAT_CHK_TIMMER) {
+		odm_initialize_timer(dm,
+				     &lna_info->phydm_lna_sat_chk_timer,
+				     (void *)phydm_lna_sat_chk_callback, NULL,
+				     "phydm_lna_sat_chk_timer");
+	} else if (state == CANCEL_LNA_SAT_CHK_TIMMER) {
+		odm_cancel_timer(dm, &lna_info->phydm_lna_sat_chk_timer);
+	} else if (state == RELEASE_LNA_SAT_CHK_TIMMER) {
+		odm_release_timer(dm, &lna_info->phydm_lna_sat_chk_timer);
+	}
+}
+
+void phydm_lna_sat_chk_watchdog_type1(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t *lna_info = &dm->dm_lna_sat_info;
+
+	u8 rssi_min = dm->rssi_min;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n%s ==>\n", __func__);
+
+	if (!(dm->support_ability & ODM_BB_LNA_SAT_CHK)) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			  "func disable\n");
+		return;
+	}
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		  "pre_timer_check_cnt=%d, cur_timer_check_cnt=%d\n",
+		  lna_info->pre_timer_check_cnt,
+		  lna_info->cur_timer_check_cnt);
+
+	if (lna_info->is_disable_lna_sat_chk) {
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			  "is_disable_lna_sat_chk=%d, return\n",
+			  lna_info->is_disable_lna_sat_chk);
+		return;
+	}
+
+	if (!(dm->support_ic_type &
+	    (ODM_RTL8197F | ODM_RTL8198F | ODM_RTL8814B))) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			  "support_ic_type not 97F/98F/14B, return\n");
+		return;
+	}
+
+	if (rssi_min == 0 || rssi_min == 0xff) {
+		/*@adapt agc table 0 */
+		phydm_set_ofdm_agc_tab(dm, OFDM_AGC_TAB_0);
+		phydm_lna_sat_chk_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			  "rssi_min=%d, return\n", rssi_min);
+		return;
+	}
+
+	if (lna_info->cur_timer_check_cnt == lna_info->pre_timer_check_cnt) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "fail, restart timer\n");
+		odm_set_timer(dm, &lna_info->phydm_lna_sat_chk_timer,
+			      lna_info->chk_period);
+	} else {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "Timer check pass\n");
+	}
+	lna_info->pre_timer_check_cnt = lna_info->cur_timer_check_cnt;
+}
+
+#endif /*@#ifdef PHYDM_LNA_SAT_CHK_TYPE1*/
+
+#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+
+void phydm_bubble_sort(
+	void *dm_void,
+	u8 *array,
+	u16 array_length)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 i, j;
+	u8 temp;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);
+	for (i = 0; i < (array_length - 1); i++) {
+		for (j = (i + 1); j < (array_length); j++) {
+			if (array[i] > array[j]) {
+				temp = array[i];
+				array[i] = array[j];
+				array[j] = temp;
+			}
+		}
+	}
+}
+
+void phydm_lna_sat_chk_type2_init(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+	u8 real_shift = pinfo->total_bit_shift;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);
+
+	pinfo->total_cnt_snr = 1 << real_shift;
+	pinfo->is_sm_done = TRUE;
+	pinfo->is_snr_done = FALSE;
+	pinfo->cur_snr_mean = 0;
+	pinfo->cur_snr_var = 0;
+	pinfo->cur_lower_snr_mean = 0;
+	pinfo->pre_snr_mean = 0;
+	pinfo->pre_snr_var = 0;
+	pinfo->pre_lower_snr_mean = 0;
+	pinfo->nxt_state = ORI_TABLE_MONITOR;
+	pinfo->pre_state = ORI_TABLE_MONITOR;
+}
+
+void phydm_snr_collect(
+	void *dm_void,
+	u8 rx_snr)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	if (pinfo->is_sm_done) {
+#if 0
+		/*PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);*/
+#endif
+
+		/* @adapt only path-A for calculation */
+		pinfo->snr_statistic[pinfo->cnt_snr_statistic] = rx_snr;
+
+		if (pinfo->cnt_snr_statistic == (pinfo->total_cnt_snr - 1)) {
+			pinfo->is_snr_done = TRUE;
+			pinfo->cnt_snr_statistic = 0;
+		} else {
+			pinfo->cnt_snr_statistic++;
+		}
+	} else {
+		return;
+	}
+}
+
+void phydm_parsing_snr(void *dm_void, void *pktinfo_void, s8 *rx_snr)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*lna_t = &dm->dm_lna_sat_info;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	u8 target_macid = dm->rssi_min_macid;
+
+	if (!(dm->support_ability & ODM_BB_LNA_SAT_CHK))
+		return;
+
+	pktinfo = (struct phydm_perpkt_info_struct *)pktinfo_void;
+
+	if (!pktinfo->is_packet_match_bssid)
+		return;
+
+	if (lna_t->force_traget_macid != 0)
+		target_macid = lna_t->force_traget_macid;
+
+	if (target_macid != pktinfo->station_id)
+		return;
+
+	phydm_snr_collect(dm, rx_snr[0]); /*path-A B C D???*/
+}
+
+void phydm_snr_data_processing(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+	u8 real_shift = pinfo->total_bit_shift;
+	u16 total_snr_cnt = pinfo->total_cnt_snr;
+	u16 total_loop_cnt = (total_snr_cnt - 1), i;
+	u32 temp;
+	u32 sum_snr_statistic = 0;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+		  "total_loop_cnt=%d\n", total_loop_cnt);
+
+	for (i = 0; (i <= total_loop_cnt); i++) {
+		if (pinfo->is_snr_detail_en) {
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+				  "snr[%d]=%d\n", i, pinfo->snr_statistic[i]);
+		}
+
+		sum_snr_statistic += (u32)(pinfo->snr_statistic[i]);
+
+		pinfo->snr_statistic_sqr[i] = (u16)(pinfo->snr_statistic[i] * pinfo->snr_statistic[i]);
+	}
+
+	phydm_bubble_sort(dm, pinfo->snr_statistic, pinfo->total_cnt_snr);
+
+	/*update SNR's cur mean*/
+	pinfo->cur_snr_mean = (sum_snr_statistic >> real_shift);
+
+	for (i = 0; (i <= total_loop_cnt); i++) {
+		if (pinfo->snr_statistic[i] >= pinfo->cur_snr_mean)
+			temp = pinfo->snr_statistic[i] - pinfo->cur_snr_mean;
+		else
+			temp = pinfo->cur_snr_mean - pinfo->snr_statistic[i];
+
+		pinfo->cur_snr_var += (temp * temp);
+	}
+
+	/*update SNR's VAR*/
+	pinfo->cur_snr_var = (pinfo->cur_snr_var >> real_shift);
+
+	/*@acquire lower SNR's statistics*/
+	temp = 0;
+	pinfo->cnt_lower_snr_statistic = (total_snr_cnt >> pinfo->lwr_snr_ratio_bit_shift);
+	pinfo->cnt_lower_snr_statistic = MAX_2(pinfo->cnt_lower_snr_statistic, SNR_RPT_MAX);
+
+	for (i = 0; i < pinfo->cnt_lower_snr_statistic; i++)
+		temp += pinfo->snr_statistic[i];
+
+	pinfo->cur_lower_snr_mean = temp >> (real_shift - pinfo->lwr_snr_ratio_bit_shift);
+}
+
+boolean phydm_is_snr_improve(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+	boolean is_snr_improve;
+	u8 cur_state = pinfo->nxt_state;
+	u32 cur_mean = pinfo->cur_snr_mean;
+	u32 pre_mean = pinfo->pre_snr_mean;
+	u32 cur_lower_mean = pinfo->cur_lower_snr_mean;
+	u32 pre_lower_mean = pinfo->pre_lower_snr_mean;
+	u32 cur_var = pinfo->cur_snr_var;
+
+	/*special case, zero VAR, interference is gone*/
+	 /*@make sure pre_var is larger enough*/
+	if (cur_state == SAT_TABLE_MONITOR ||
+	    cur_state == ORI_TABLE_TRAINING) {
+		if (cur_mean >= pre_mean) {
+			if (cur_var == 0)
+				return true;
+		}
+	}
+#if 0
+	/*special case, mean degrade less than VAR improvement*/
+	/*@make sure pre_var is larger enough*/
+	if (cur_state == ORI_TABLE_MONITOR &&
+	    cur_mean < pre_mean &&
+	    cur_var < pre_var) {
+		diff_mean = pre_mean - cur_mean;
+		diff_var = pre_var - cur_var;
+		return (diff_var > (2 * diff_mean * diff_mean)) ? true : false;
+	}
+
+#endif
+	if (cur_lower_mean >= (pre_lower_mean + pinfo->delta_snr_mean))
+		is_snr_improve = true;
+	else
+		is_snr_improve = false;
+#if 0
+/* @condition refine, mean is bigger enough or VAR is smaller enough*/
+/* @1. from mean's view, mean improve delta_snr_mean(2), VAR not degrade lot*/
+	if (cur_mean > (pre_mean + pinfo->delta_snr_mean)) {
+		is_mean_improve = TRUE;
+		is_var_improve = (cur_var <= pre_var + dm->delta_snr_var)
+				 ? TRUE : FALSE;
+
+	} else if (cur_var + dm->delta_snr_var <= pre_var) {
+		is_var_improve = TRUE;
+		is_mean_improve = ((cur_mean + 1) >= pre_mean) ? TRUE : FALSE;
+	} else {
+		return false;
+	}
+#endif
+	return is_snr_improve;
+}
+
+boolean phydm_is_snr_degrade(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+	u32 cur_lower_mean = pinfo->cur_lower_snr_mean;
+	u32 pre_lower_mean = pinfo->pre_lower_snr_mean;
+	boolean is_degrade;
+
+	if (cur_lower_mean <= (pre_lower_mean - pinfo->delta_snr_mean))
+		is_degrade = TRUE;
+	else
+		is_degrade = FALSE;
+#if 0
+	is_mean_dgrade = (pinfo->cur_snr_mean + pinfo->delta_snr_mean <= pinfo->pre_snr_mean) ? TRUE : FALSE;
+	is_var_degrade = (pinfo->cur_snr_var > (pinfo->pre_snr_var + pinfo->delta_snr_mean)) ? TRUE : FALSE;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s: cur_mean=%d, pre_mean=%d, cur_var=%d, pre_var=%d\n",
+		  __func__,
+		  pinfo->cur_snr_mean,
+		  pinfo->pre_snr_mean,
+		  pinfo->cur_snr_var,
+		  pinfo->pre_snr_var);
+
+	return (is_mean_dgrade & is_var_degrade);
+#endif
+	return is_degrade;
+}
+
+boolean phydm_is_large_var(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+	boolean is_large_var = (pinfo->cur_snr_var >= pinfo->snr_var_thd) ? TRUE : FALSE;
+
+	return is_large_var;
+}
+
+void phydm_update_pre_status(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	pinfo->pre_lower_snr_mean = pinfo->cur_lower_snr_mean;
+	pinfo->pre_snr_mean = pinfo->cur_snr_mean;
+	pinfo->pre_snr_var = pinfo->cur_snr_var;
+}
+
+void phydm_ori_table_monitor(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	if (phydm_is_large_var(dm)) {
+		pinfo->nxt_state = SAT_TABLE_TRAINING;
+		config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+	} else {
+		pinfo->nxt_state = ORI_TABLE_MONITOR;
+		/*switch to anti-sat table*/
+		config_phydm_switch_agc_tab_8822b(dm, *dm->channel, DEFAULT_AGC_TABLE);
+	}
+	phydm_update_pre_status(dm);
+	pinfo->pre_state = ORI_TABLE_MONITOR;
+}
+
+void phydm_sat_table_training(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	#if 0
+	if pre_state = ORI_TABLE_MONITOR || SAT_TABLE_TRY_FAIL,
+	/*@"pre" adapt ori-table, "cur" adapt sat-table*/
+	/*@adapt ori table*/
+	if (pinfo->pre_state == ORI_TABLE_MONITOR) {
+		pinfo->nxt_state = SAT_TABLE_TRAINING;
+		config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+	} else {
+	#endif
+	if (phydm_is_snr_improve(dm)) {
+		pinfo->nxt_state = SAT_TABLE_MONITOR;
+	} else {
+		pinfo->nxt_state = SAT_TABLE_TRY_FAIL;
+		config_phydm_switch_agc_tab_8822b(dm, *dm->channel, DEFAULT_AGC_TABLE);
+	}
+	/*@}*/
+
+	phydm_update_pre_status(dm);
+	pinfo->pre_state = SAT_TABLE_TRAINING;
+}
+
+void phydm_sat_table_try_fail(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	/* @if pre_state = SAT_TABLE_TRAINING, "pre" adapt sat-table, "cur" adapt ori-table */
+	/* @if pre_state = SAT_TABLE_TRY_FAIL, "pre" adapt ori-table, "cur" adapt ori-table */
+
+	if (phydm_is_large_var(dm)) {
+		if (phydm_is_snr_degrade(dm)) {
+			pinfo->nxt_state = SAT_TABLE_TRAINING;
+			config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+		} else {
+			pinfo->nxt_state = SAT_TABLE_TRY_FAIL;
+		}
+	} else {
+		pinfo->nxt_state = ORI_TABLE_MONITOR;
+	}
+	phydm_update_pre_status(dm);
+	pinfo->pre_state = SAT_TABLE_TRY_FAIL;
+}
+
+void phydm_sat_table_monitor(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	if (phydm_is_snr_improve(dm)) {
+		pinfo->sat_table_monitor_times = 0;
+
+		/* @if pre_state = SAT_TABLE_MONITOR, "pre" adapt sat-table, "cur" adapt sat-table */
+		if (pinfo->pre_state == SAT_TABLE_MONITOR) {
+			pinfo->nxt_state = ORI_TABLE_TRAINING;
+			config_phydm_switch_agc_tab_8822b(dm, *dm->channel, DEFAULT_AGC_TABLE);
+			//phydm_update_pre_status(dm);
+		} else {
+			pinfo->nxt_state = SAT_TABLE_MONITOR;
+		}
+
+		/* @if pre_state = SAT_TABLE_TRAINING, "pre" adapt sat-table, "cur" adapt sat-table */
+		/* @if pre_state = ORI_TABLE_TRAINING, "pre" adapt ori-table, "cur" adapt sat-table */
+		/*pre_state above is no need to update*/
+	} else {
+		if (pinfo->sat_table_monitor_times == pinfo->force_change_period) {
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s: sat_table_monitor_times=%d\n",
+				  __func__, pinfo->sat_table_monitor_times);
+
+			pinfo->nxt_state = ORI_TABLE_TRAINING;
+			pinfo->sat_table_monitor_times = 0;
+			config_phydm_switch_agc_tab_8822b(dm, *dm->channel, DEFAULT_AGC_TABLE);
+		} else {
+			pinfo->nxt_state = SAT_TABLE_MONITOR;
+			pinfo->sat_table_monitor_times++;
+		}
+	}
+	phydm_update_pre_status(dm);
+	pinfo->pre_state = SAT_TABLE_MONITOR;
+}
+
+void phydm_ori_table_training(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	/* pre_state = SAT_TABLE_MONITOR, "pre" adapt sat-table, "cur" adapt ori-table */
+
+	if (phydm_is_snr_degrade(dm) == FALSE) {
+		pinfo->nxt_state = ORI_TABLE_MONITOR;
+	} else {
+		if (pinfo->pre_snr_var == 0)
+			pinfo->nxt_state = ORI_TABLE_TRY_FAIL;
+		else
+			pinfo->nxt_state = SAT_TABLE_MONITOR;
+
+		config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+	}
+	phydm_update_pre_status(dm);
+	pinfo->pre_state = ORI_TABLE_TRAINING;
+}
+
+void phydm_ori_table_try_fail(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+
+	if (pinfo->pre_state == ORI_TABLE_TRY_FAIL) {
+		if (phydm_is_snr_improve(dm)) {
+			pinfo->nxt_state = ORI_TABLE_TRAINING;
+			pinfo->ori_table_try_fail_times = 0;
+			config_phydm_switch_agc_tab_8822b(dm, *dm->channel, DEFAULT_AGC_TABLE);
+		} else {
+			if (pinfo->ori_table_try_fail_times == pinfo->force_change_period) {
+				PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+					  "%s: ori_table_try_fail_times=%d\n", __func__, pinfo->ori_table_try_fail_times);
+
+				pinfo->nxt_state = ORI_TABLE_TRY_FAIL;
+				pinfo->ori_table_try_fail_times = 0;
+				phydm_update_pre_status(dm);
+			} else {
+				pinfo->nxt_state = ORI_TABLE_TRY_FAIL;
+				pinfo->ori_table_try_fail_times++;
+				phydm_update_pre_status(dm);
+				//config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+			}
+		}
+	} else {
+		pinfo->nxt_state = ORI_TABLE_TRY_FAIL;
+		pinfo->ori_table_try_fail_times = 0;
+		phydm_update_pre_status(dm);
+		//config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+	}
+
+#if 0
+	if (phydm_is_large_var(dm)) {
+		if (phydm_is_snr_degrade(dm)) {
+			pinfo->nxt_state = SAT_TABLE_TRAINING;
+			config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+		} else {
+			pinfo->nxt_state = SAT_TABLE_TRY_FAIL;
+		}
+	} else {
+		pinfo->nxt_state = ORI_TABLE_MONITOR;
+	}
+
+	phydm_update_pre_status(dm);
+#endif
+	pinfo->pre_state = ORI_TABLE_TRY_FAIL;
+}
+
+char *phydm_lna_sat_state_msg(
+	void *dm_void,
+	IN u8 state)
+{
+	char *dbg_message;
+
+	switch (state) {
+	case ORI_TABLE_MONITOR:
+		dbg_message = "ORI_TABLE_MONITOR";
+		break;
+
+	case SAT_TABLE_TRAINING:
+		dbg_message = "SAT_TABLE_TRAINING";
+		break;
+
+	case SAT_TABLE_TRY_FAIL:
+		dbg_message = "SAT_TABLE_TRY_FAIL";
+		break;
+
+	case SAT_TABLE_MONITOR:
+		dbg_message = "SAT_TABLE_MONITOR";
+		break;
+
+	case ORI_TABLE_TRAINING:
+		dbg_message = "ORI_TABLE_TRAINING";
+		break;
+
+	case ORI_TABLE_TRY_FAIL:
+		dbg_message = "ORI_TABLE_TRY_FAIL";
+		break;
+
+	default:
+		dbg_message = "ORI_TABLE_MONITOR";
+		break;
+	}
+
+	return dbg_message;
+}
+
+void phydm_lna_sat_type2_sm(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*pinfo = &dm->dm_lna_sat_info;
+	u8 state = pinfo->nxt_state;
+	u8 agc_tab = (u8)odm_get_bb_reg(dm, 0x958, 0x1f);
+	char *dbg_message, *nxt_dbg_message;
+	u8 real_shift = pinfo->total_bit_shift;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "\n\n%s ==>\n", __func__);
+
+	if ((dm->support_ic_type & ODM_RTL8822B) == FALSE) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "ODM_BB_LNA_SAT_CHK_TYPE2 only support 22B.\n");
+		return;
+	}
+
+	if ((dm->support_ability & ODM_BB_LNA_SAT_CHK) == FALSE) {
+		phydm_lna_sat_chk_type2_init(dm);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "ODM_BB_LNA_SAT_CHK_TYPE2 is NOT supported, cur table=%d\n", agc_tab);
+		return;
+	}
+
+	if (pinfo->is_snr_done)
+		phydm_snr_data_processing(dm);
+	else
+		return;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "cur agc table %d\n", agc_tab);
+
+	if (pinfo->is_force_lna_sat_table != AUTO_AGC_TABLE) {
+		/*reset state machine*/
+		pinfo->nxt_state = ORI_TABLE_MONITOR;
+		if (pinfo->is_snr_done) {
+			if (pinfo->is_force_lna_sat_table == DEFAULT_AGC_TABLE)
+				config_phydm_switch_agc_tab_8822b(dm, *dm->channel, DEFAULT_AGC_TABLE);
+			else if (pinfo->is_force_lna_sat_table == LNA_SAT_AGC_TABLE)
+				config_phydm_switch_agc_tab_8822b(dm, *dm->channel, LNA_SAT_AGC_TABLE);
+			else
+				config_phydm_switch_agc_tab_8822b(dm, *dm->channel, DEFAULT_AGC_TABLE);
+
+			PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+				  "%s: cur_mean=%d, pre_mean=%d, cur_var=%d, pre_var=%d,cur_lower_mean=%d, pre_lower_mean=%d, cnt_lower_snr=%d\n",
+				  __func__,
+				  pinfo->cur_snr_mean,
+				  pinfo->pre_snr_mean,
+				  pinfo->cur_snr_var,
+				  pinfo->pre_snr_var,
+				  pinfo->cur_lower_snr_mean,
+				  pinfo->pre_lower_snr_mean,
+				  pinfo->cnt_lower_snr_statistic);
+
+			pinfo->is_snr_done = FALSE;
+			pinfo->is_sm_done = TRUE;
+			phydm_update_pre_status(dm);
+		} else {
+			return;
+		}
+	} else if (pinfo->is_snr_done) {
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK,
+			  "%s: cur_mean=%d, pre_mean=%d, cur_var=%d, pre_var=%d,cur_lower_mean=%d, pre_lower_mean=%d, cnt_lower_snr=%d\n",
+			  __func__,
+			  pinfo->cur_snr_mean,
+			  pinfo->pre_snr_mean,
+			  pinfo->cur_snr_var,
+			  pinfo->pre_snr_var,
+			  pinfo->cur_lower_snr_mean,
+			  pinfo->pre_lower_snr_mean,
+			  pinfo->cnt_lower_snr_statistic);
+
+		switch (state) {
+		case ORI_TABLE_MONITOR:
+			dbg_message = "ORI_TABLE_MONITOR";
+			phydm_ori_table_monitor(dm);
+			break;
+
+		case SAT_TABLE_TRAINING:
+			dbg_message = "SAT_TABLE_TRAINING";
+			phydm_sat_table_training(dm);
+			break;
+
+		case SAT_TABLE_TRY_FAIL:
+			dbg_message = "SAT_TABLE_TRY_FAIL";
+			phydm_sat_table_try_fail(dm);
+			break;
+
+		case SAT_TABLE_MONITOR:
+			dbg_message = "SAT_TABLE_MONITOR";
+			phydm_sat_table_monitor(dm);
+			break;
+
+		case ORI_TABLE_TRAINING:
+			dbg_message = "ORI_TABLE_TRAINING";
+			phydm_ori_table_training(dm);
+			break;
+
+		case ORI_TABLE_TRY_FAIL:
+			dbg_message = "ORI_TABLE_TRAINING";
+			phydm_ori_table_try_fail(dm);
+			break;
+
+		default:
+			dbg_message = "ORI_TABLE_MONITOR";
+			phydm_ori_table_monitor(dm);
+			break;
+		}
+
+		dbg_message = phydm_lna_sat_state_msg(dm, state);
+		nxt_dbg_message = phydm_lna_sat_state_msg(dm, pinfo->nxt_state);
+		PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "state: [%s]->[%s]\n",
+			  dbg_message, nxt_dbg_message);
+
+		pinfo->is_snr_done = FALSE;
+		pinfo->is_sm_done = TRUE;
+		pinfo->total_cnt_snr = 1 << real_shift;
+
+	} else {
+		return;
+	}
+}
+
+
+#endif /*@#ifdef PHYDM_LNA_SAT_CHK_TYPE2*/
+
+void phydm_lna_sat_debug(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*lna_t = &dm->dm_lna_sat_info;
+	char help[] = "-h";
+	char monitor[] = "-m";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i;
+	u8 agc_tab = 0;
+
+	if ((strcmp(input[1], help) == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "monitor: -m\n");
+		#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{0} {lna_sat_chk_en}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} {agc_table_switch_en}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{2} {chk_cnt per callback}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{3} {chk_period(ms)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{4} {chk_duty_cycle(%)}\n");
+		#endif
+	} else if ((strcmp(input[1], monitor) == 0)) {
+#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+		#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+		if (dm->support_ic_type & (ODM_RTL8198F | ODM_RTL8814B))
+			agc_tab = phydm_get_ofdm_agc_tab_path(dm, RF_PATH_A);
+		else
+		#endif
+			agc_tab = phydm_get_ofdm_agc_tab(dm);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "%s%d, %s%d, %s%d, %s%d\n",
+			 "check_time = ", lna_t->check_time,
+			 "pre_sat_status = ", lna_t->pre_sat_status,
+			 "cur_sat_status = ", lna_t->cur_sat_status,
+			 "current AGC tab = ", agc_tab);
+#endif
+	} else {
+		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+		for (i = 1; i < 10; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL,
+					     &var1[i]);
+		}
+		#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+		if (var1[0] == 0) {
+			if (var1[1] == 1)
+				lna_t->is_disable_lna_sat_chk = false;
+			else if (var1[1] == 0)
+				lna_t->is_disable_lna_sat_chk = true;
+
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "dis_lna_sat_chk=%d\n",
+				 lna_t->is_disable_lna_sat_chk);
+		} else if (var1[0] == 1) {
+			if (var1[1] == 1)
+				lna_t->dis_agc_table_swh = false;
+			else if (var1[1] == 0)
+				lna_t->dis_agc_table_swh = true;
+
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "dis_agc_table_swh=%d\n",
+				 lna_t->dis_agc_table_swh);
+
+		} else if (var1[0] == 2) {
+			lna_t->chk_cnt = (u8)var1[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "chk_cnt=%d\n", lna_t->chk_cnt);
+		} else if (var1[0] == 3) {
+			lna_t->chk_period = var1[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "chk_period=%d\n", lna_t->chk_period);
+		} else if (var1[0] == 4) {
+			lna_t->chk_duty_cycle = (u8)var1[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "chk_duty_cycle=%d\n",
+				 lna_t->chk_duty_cycle);
+		}
+		#endif
+		#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+		if (var1[0] == 1)
+			lna_t->force_traget_macid = var1[1];
+		#endif
+	}
+	*_used = used;
+	*_out_len = out_len;
+}
+
+void phydm_lna_sat_chk_watchdog(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t *lna_sat = &dm->dm_lna_sat_info;
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "%s ==>\n", __func__);
+
+	if (lna_sat->lna_sat_type == LNA_SAT_WITH_PEAK_DET) {
+		#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+		phydm_lna_sat_chk_watchdog_type1(dm);
+		#endif
+	} else if (lna_sat->lna_sat_type == LNA_SAT_WITH_TRAIN) {
+		#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+
+		#endif
+	}
+
+}
+
+void phydm_lna_sat_config(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*lna_sat = &dm->dm_lna_sat_info;
+
+	#if (RTL8822B_SUPPORT == 1)
+	if (dm->support_ic_type & (ODM_RTL8822B))
+		lna_sat->lna_sat_type = LNA_SAT_WITH_TRAIN;
+	#endif
+
+	#if (RTL8197F_SUPPORT || RTL8192F_SUPPORT ||\
+	     RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+	if (dm->support_ic_type &
+	    (ODM_RTL8197F | ODM_RTL8192F | ODM_RTL8198F | ODM_RTL8814B))
+		lna_sat->lna_sat_type = LNA_SAT_WITH_PEAK_DET;
+	#endif
+
+	PHYDM_DBG(dm, DBG_LNA_SAT_CHK, "[%s] lna_sat_type=%d\n",
+		  __func__, lna_sat->lna_sat_type);
+}
+
+void phydm_lna_sat_check_init(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_lna_sat_t	*lna_sat = &dm->dm_lna_sat_info;
+
+	if ((dm->support_ability & ODM_BB_LNA_SAT_CHK))
+		return;
+
+	/*@2018.04.17 Johnson*/
+	phydm_lna_sat_config(dm);
+	#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+	lna_sat->chk_period = LNA_CHK_PERIOD;
+	lna_sat->chk_cnt = LNA_CHK_CNT;
+	lna_sat->chk_duty_cycle = LNA_CHK_DUTY_CYCLE;
+	lna_sat->dis_agc_table_swh = false;
+	#endif
+	/*@2018.04.17 Johnson end*/
+
+	if (lna_sat->lna_sat_type == LNA_SAT_WITH_PEAK_DET) {
+		#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+		phydm_lna_sat_chk_init(dm);
+		#endif
+	} else if (lna_sat->lna_sat_type == LNA_SAT_WITH_TRAIN) {
+		#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+		phydm_lna_sat_chk_type2_init(dm);
+		#endif
+	}
+}
+
+#endif /*@#ifdef PHYDM_LNA_SAT_CHK_SUPPORT*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_lna_sat.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_lna_sat.h
new file mode 100644
index 000000000000..10d21feb4526
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_lna_sat.h
@@ -0,0 +1,174 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __PHYDM_LNA_SAT_H__
+#define __PHYDM_LNA_SAT_H__
+#ifdef PHYDM_LNA_SAT_CHK_SUPPORT
+/* @1 ============================================================
+ * 1  Definition
+ * 1 ============================================================
+ */
+
+#define LNA_SAT_VERSION "1.0"
+
+/*@LNA saturation check*/
+#define	OFDM_AGC_TAB_0			0
+#define	OFDM_AGC_TAB_2			2
+
+#define	DIFF_RSSI_TO_IGI		10
+#define	ONE_SEC_MS			1000
+
+#define LNA_CHK_PERIOD			100 /*@ms*/
+#define LNA_CHK_CNT			10 /*@checks per callback*/
+#define LNA_CHK_DUTY_CYCLE		5 /*@percentage*/
+
+#define	DELTA_STD	2
+#define	DELTA_MEAN	2
+#define	SNR_STATISTIC_SHIFT	8
+#define	SNR_RPT_MAX	256
+
+/* @1 ============================================================
+ * 1 enumrate
+ * 1 ============================================================
+ */
+
+enum lna_sat_timer_state {
+	INIT_LNA_SAT_CHK_TIMMER,
+	CANCEL_LNA_SAT_CHK_TIMMER,
+	RELEASE_LNA_SAT_CHK_TIMMER
+};
+
+#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+enum lna_sat_chk_type2_status {
+	ORI_TABLE_MONITOR,
+	ORI_TABLE_TRAINING,
+	SAT_TABLE_MONITOR,
+	SAT_TABLE_TRAINING,
+	SAT_TABLE_TRY_FAIL,
+	ORI_TABLE_TRY_FAIL
+};
+
+#endif
+
+enum lna_sat_type {
+	LNA_SAT_WITH_PEAK_DET	= 1,	/*type1*/
+	LNA_SAT_WITH_TRAIN	= 2,	/*type2*/
+};
+
+/* @1 ============================================================
+ * 1  structure
+ * 1 ============================================================
+ */
+
+struct phydm_lna_sat_t {
+#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+	u8			chk_cnt;
+	u8			chk_duty_cycle;
+	u32			chk_period;/*@ms*/
+	boolean			is_disable_lna_sat_chk;
+	boolean			dis_agc_table_swh;
+#endif
+#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+	u8			force_traget_macid;
+	u32			snr_var_thd;
+	u32			delta_snr_mean;
+	u16			ori_table_try_fail_times;
+	u16			cnt_lower_snr_statistic;
+	u16			sat_table_monitor_times;
+	u16			force_change_period;
+	u8			is_snr_detail_en;
+	u8			is_force_lna_sat_table;
+	u8			lwr_snr_ratio_bit_shift;
+	u8			cnt_snr_statistic;
+	u16			snr_statistic_sqr[SNR_RPT_MAX];
+	u8			snr_statistic[SNR_RPT_MAX];
+	u8			is_sm_done;
+	u8			is_snr_done;
+	u32			cur_snr_var;
+	u8			total_bit_shift;
+	u8			total_cnt_snr;
+	u32			cur_snr_mean;
+	u8			cur_snr_var0;
+	u32			cur_lower_snr_mean;
+	u32			pre_snr_mean;
+	u32			pre_snr_var;
+	u32			pre_lower_snr_mean;
+	u8			nxt_state;
+	u8			pre_state;
+#endif
+	enum lna_sat_type	lna_sat_type;
+	u32			sat_cnt_acc_patha;
+	u32			sat_cnt_acc_pathb;
+#ifdef PHYDM_IC_ABOVE_3SS
+	u32			sat_cnt_acc_pathc;
+#endif
+#ifdef PHYDM_IC_ABOVE_4SS
+	u32			sat_cnt_acc_pathd;
+#endif
+	u32			check_time;
+	boolean			pre_sat_status;
+	boolean			cur_sat_status;
+	struct phydm_timer_list	phydm_lna_sat_chk_timer;
+	u32			cur_timer_check_cnt;
+	u32			pre_timer_check_cnt;
+};
+
+/* @1 ============================================================
+ * 1 function prototype
+ * 1 ============================================================
+ */
+void phydm_lna_sat_chk_init(void *dm_void);
+
+u8 phydm_get_ofdm_agc_tab(void *dm_void);
+
+void phydm_lna_sat_chk(void *dm_void);
+
+void phydm_lna_sat_chk_timers(void *dm_void, u8 state);
+
+#ifdef PHYDM_LNA_SAT_CHK_TYPE1
+#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)
+void phydm_lna_sat_chk_bb_init(void *dm_void);
+
+void phydm_set_ofdm_agc_tab_path(void *dm_void,
+				 u8 tab_sel, enum rf_path path);
+
+u8 phydm_get_ofdm_agc_tab_path(void *dm_void, enum rf_path path);
+#endif /*@#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT)*/
+#endif
+
+#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+void phydm_parsing_snr(void *dm_void, void *pktinfo_void, s8 *rx_snr);
+#endif
+
+void phydm_lna_sat_debug(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len);
+
+void phydm_lna_sat_chk_watchdog(void *dm_void);
+
+void phydm_lna_sat_check_init(void *dm_void);
+
+#endif /*@#if (PHYDM_LNA_SAT_CHK_SUPPORT == 1)*/
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.c
index 85e747d04107..9ce38ba30fc1 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.c
@@ -1,112 +1,131 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
- *
- * 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 "mp_precomp.h"
-#include "phydm_precomp.h"
-
-const u16 db_invert_table[12][8] = {
-	{	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}
-};
-
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*@************************************************************
+ * include files
+ ************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+const u32 db_invert_table[12][8] = {
+	{10, 13, 16, 20, 25, 32, 40, 50}, /* @U(32,3) */
+	{64, 80, 101, 128, 160, 201, 256, 318}, /* @U(32,3) */
+	{401, 505, 635, 800, 1007, 1268, 1596, 2010}, /* @U(32,3) */
+	{316, 398, 501, 631, 794, 1000, 1259, 1585}, /* @U(32,0) */
+	{1995, 2512, 3162, 3981, 5012, 6310, 7943, 10000}, /* @U(32,0) */
+	{12589, 15849, 19953, 25119, 31623, 39811, 50119, 63098}, /* @U(32,0) */
+	{79433, 100000, 125893, 158489, 199526, 251189, 316228,
+	 398107}, /* @U(32,0) */
+	{501187, 630957, 794328, 1000000, 1258925, 1584893, 1995262,
+	 2511886}, /* @U(32,0) */
+	{3162278, 3981072, 5011872, 6309573, 7943282, 1000000, 12589254,
+	 15848932}, /* @U(32,0) */
+	{19952623, 25118864, 31622777, 39810717, 50118723, 63095734,
+	 79432823, 100000000}, /* @U(32,0) */
+	{125892541, 158489319, 199526232, 251188643, 316227766, 398107171,
+	 501187234, 630957345}, /* @U(32,0) */
+	{794328235, 1000000000, 1258925412, 1584893192, 1995262315,
+	 2511886432U, 3162277660U, 3981071706U} }; /* @U(32,0) */
 
 /*Y = 10*log(X)*/
-s32
-odm_pwdb_conversion(
-	s32 X,
-	u32 total_bit,
-	u32 decimal_bit
-)
+s32 odm_pwdb_conversion(s32 X, u32 total_bit, u32 decimal_bit)
 {
 	s32 Y, integer = 0, decimal = 0;
 	u32 i;
 
 	if (X == 0)
-		X = 1; /* log2(x), x can't be 0 */
+		X = 1; /* @log2(x), x can't be 0 */
 
 	for (i = (total_bit - 1); i > 0; i--) {
 		if (X & BIT(i)) {
 			integer = i;
-			if (i > 0)
-				decimal = (X & BIT(i - 1)) ? 2 : 0; /* decimal is 0.5dB*3=1.5dB~=2dB */
+			if (i > 0) {
+				/*decimal is 0.5dB*3=1.5dB~=2dB */
+				decimal = (X & BIT(i - 1)) ? 2 : 0;
+			}
 			break;
 		}
 	}
 
-	Y = 3 * (integer - decimal_bit) + decimal; /* 10*log(x)=3*log2(x), */
+	Y = 3 * (integer - decimal_bit) + decimal; /* @10*log(x)=3*log2(x), */
 
 	return Y;
 }
 
-s32
-odm_sign_conversion(
-	s32 value,
-	u32 total_bit
-)
+s32 odm_sign_conversion(s32 value, u32 total_bit)
 {
 	if (value & BIT(total_bit - 1))
-		value -= BIT(total_bit);
-	
+		value -= BIT(total_bit);
+
 	return value;
 }
 
-void
-phydm_seq_sorting(
-	void	*p_dm_void,
-	u32	*p_value,
-	u32	*rank_idx,
-	u32	*p_idx_out,
-	u8	seq_length
-)
+/*threshold must form low to high*/
+u16 phydm_find_intrvl(void *dm_void, u16 val, u16 *threshold, u16 th_len)
 {
-	u8		i = 0, j = 0;
-	u32		tmp_a, tmp_b;
-	u32		tmp_idx_a, tmp_idx_b;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 i = 0;
+	u16 ret_val = 0;
+	u16 max_th = threshold[th_len - 1];
+
+	for (i = 0; i < th_len; i++) {
+		if (val < threshold[i]) {
+			ret_val = i;
+			break;
+		} else if (val >= max_th) {
+			ret_val = th_len;
+			break;
+		}
+	}
 
-	for (i = 0; i < seq_length; i++) {
+	return ret_val;
+}
+
+void phydm_seq_sorting(void *dm_void, u32 *value, u32 *rank_idx, u32 *idx_out,
+		       u8 seq_length)
+{
+	u8 i = 0, j = 0;
+	u32 tmp_a, tmp_b;
+	u32 tmp_idx_a, tmp_idx_b;
+
+	for (i = 0; i < seq_length; i++)
 		rank_idx[i] = i;
-		/**/
-	}
 
 	for (i = 0; i < (seq_length - 1); i++) {
-
 		for (j = 0; j < (seq_length - 1 - i); j++) {
-
-			tmp_a = p_value[j];
-			tmp_b = p_value[j + 1];
+			tmp_a = value[j];
+			tmp_b = value[j + 1];
 
 			tmp_idx_a = rank_idx[j];
 			tmp_idx_b = rank_idx[j + 1];
 
 			if (tmp_a < tmp_b) {
-				p_value[j] = tmp_b;
-				p_value[j + 1] = tmp_a;
+				value[j] = tmp_b;
+				value[j + 1] = tmp_a;
 
 				rank_idx[j] = tmp_idx_b;
 				rank_idx[j + 1] = tmp_idx_a;
@@ -114,50 +133,72 @@ phydm_seq_sorting(
 		}
 	}
 
-	for (i = 0; i < seq_length; i++) {
-		p_idx_out[rank_idx[i]] = i + 1;
-		/**/
-	}
+	for (i = 0; i < seq_length; i++)
+		idx_out[rank_idx[i]] = i + 1;
 }
-
-u32
-odm_convert_to_db(
-	u32	value)
+
+u32 odm_convert_to_db(u64 value)
 {
 	u8 i;
 	u8 j;
 	u32 dB;
 
-	value = value & 0xFFFF;
+	if (value >= db_invert_table[11][7]) {
+		pr_debug("[%s] ====>\n", __func__);
+		return 96; /* @maximum 96 dB */
+	}
 
 	for (i = 0; i < 12; i++) {
-		if (value <= db_invert_table[i][7])
+		if (i <= 2 && (value << FRAC_BITS) <= db_invert_table[i][7])
+			break;
+		else if (i > 2 && value <= db_invert_table[i][7])
 			break;
-	}
-
-	if (i >= 12) {
-		return 96;	/* maximum 96 dB */
 	}
 
 	for (j = 0; j < 8; j++) {
-		if (value <= db_invert_table[i][j])
+		if (i <= 2 && (value << FRAC_BITS) <= db_invert_table[i][j])
+			break;
+		else if (i > 2 && i < 12 && value <= db_invert_table[i][j])
 			break;
 	}
 
+	if (j == 0 && i == 0)
+		goto end;
+
+	if (j == 0) {
+		if (i != 3) {
+			if (db_invert_table[i][0] - value >
+			    value - db_invert_table[i - 1][7]) {
+				i = i - 1;
+				j = 7;
+			}
+		} else {
+			if (db_invert_table[3][0] - value >
+			    value - db_invert_table[2][7]) {
+				i = 2;
+				j = 7;
+			}
+		}
+	} else {
+		if (db_invert_table[i][j] - value >
+		    value - db_invert_table[i][j - 1]) {
+			i = i;
+			j = j - 1;
+		}
+	}
+end:
 	dB = (i << 3) + j + 1;
 
 	return dB;
 }
 
-u32
-odm_convert_to_linear(
-	u32	value)
+u64 phydm_db_2_linear(u32 value)
 {
 	u8 i;
 	u8 j;
-	u32 linear;
+	u64 linear;
 
-	/* 1dB~96dB */
+	/* @1dB~96dB */
 
 	value = value & 0xFF;
 
@@ -166,6 +207,44 @@ odm_convert_to_linear(
 
 	linear = db_invert_table[i][j];
 
+	if (i > 2)
+		linear = linear << FRAC_BITS;
+
 	return linear;
-}
-
+}
+
+u16 phydm_show_fraction_num(u32 frac_val, u8 bit_num)
+{
+	u8 i = 0;
+	u16 val = 0;
+	u16 base = 5000;
+
+	for (i = bit_num; i > 0; i--) {
+		if (frac_val & BIT(i - 1))
+			val += (base >> (bit_num - i));
+	}
+	return val;
+}
+
+u32 phydm_gen_bitmask(u8 mask_num)
+{
+	u8 i = 0;
+	u32 bitmask = 0;
+
+	if (mask_num > 32)
+		return 1;
+
+	for (i = 0; i < mask_num; i++)
+		bitmask = (bitmask << 1) | BIT(0);
+
+	return bitmask;
+}
+
+s32 phydm_cnvrt_2_sign(u32 val, u8 bit_num)
+{
+	if (val & BIT(bit_num - 1)) /*Sign BIT*/
+		val -= (1 << bit_num); /*@2's*/
+
+	return val;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.h
index a8fb77368481..d5e0ecb16e44 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_math_lib.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,70 +9,107 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDM_MATH_LIB_H__
+#define __PHYDM_MATH_LIB_H__
 
-#ifndef	__PHYDM_MATH_LIB_H__
-#define    __PHYDM_MATH_LIB_H__
+#define AUTO_MATH_LIB_VERSION "1.0" /* @2017.06.06*/
 
-#define AUTO_MATH_LIB_VERSION	"1.0"		/* 2017.06.06*/
+/*@
+ * 1 ============================================================
+ * 1  Definition
+ * 1 ============================================================
+ */
+
+#define DIVIDED_2(X) ((X) >> 1)
+/*@1/3 ~ 11/32*/
+#if defined(DM_ODM_CE_MAC80211)
+#define DIVIDED_3(X) ({	\
+	u32 div_3_tmp = (X);	\
+	(((div_3_tmp) + ((div_3_tmp) << 1) + ((div_3_tmp) << 3)) >> 5); })
+#else
+#define DIVIDED_3(X) (((X) + ((X) << 1) + ((X) << 3)) >> 5)
+#endif
+#define DIVIDED_4(X) ((X) >> 2)
+
+/*Store Ori Value*/
+#if defined(DM_ODM_CE_MAC80211)
+#define WEIGHTING_AVG(v1, w1, v2, w2)	\
+	__WEIGHTING_AVG(v1, w1, v2, w2, typeof(v1), typeof(w1), typeof(v2), \
+			typeof(w2))
+#define __WEIGHTING_AVG(v1, w1, v2, w2, t1, t2, t3, t4)	({	\
+	t1 __w_a_v1 = (v1);	\
+	t2 __w_a_w1 = (w1);	\
+	t3 __w_a_v2 = (v2);	\
+	t4 __w_a_w2 = (w2);	\
+	((__w_a_v1) * (__w_a_w1) + (__w_a_v2) * (__w_a_w2))	\
+	/ ((__w_a_w2) + (__w_a_w1)); })
+#else
+#define WEIGHTING_AVG(v1, w1, v2, w2) \
+	(((v1) * (w1) + (v2) * (w2)) / ((w2) + (w1)))
+#endif
 
+/*Store 2^ma x Value*/
+#if defined(DM_ODM_CE_MAC80211)
+#define MA_ACC(old, new_val, ma) ({	\
+	s16 __ma_acc_o = (old);		\
+	(__ma_acc_o) - ((__ma_acc_o) >> (ma)) + (new_val); })
+#define GET_MA_VAL(val, ma) ({	\
+	s16 __get_ma_tmp = (ma);\
+	((val) + (1 << ((__get_ma_tmp) - 1))) >> (__get_ma_tmp); })
+#else
+#define MA_ACC(old, new_val, ma) ((old) - ((old) >> (ma)) + (new_val))
+#define GET_MA_VAL(val, ma) (((val) + (1 << ((ma) - 1))) >> (ma))
+#endif
+#define FRAC_BITS 3
+/*@
+ * 1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================
+ */
 
-/* 1 ============================================================
- * 1  Definition
- * 1 ============================================================ */
+/*@
+ * 1 ============================================================
+ * 1  structure
+ * 1 ============================================================
+ */
 
+/*@
+ * 1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================
+ */
 
+s32 odm_pwdb_conversion(s32 X, u32 total_bit, u32 decimal_bit);
 
+s32 odm_sign_conversion(s32 value, u32 total_bit);
 
-/* 1 ============================================================
- * 1  enumeration
- * 1 ============================================================ */
+u16 phydm_find_intrvl(void *dm_void, u16 val, u16 *threshold, u16 th_len);
 
+void phydm_seq_sorting(void *dm_void, u32 *value, u32 *rank_idx, u32 *idx_out,
+		       u8 seq_length);
 
+u32 odm_convert_to_db(u64 value);
 
-/* 1 ============================================================
- * 1  structure
- * 1 ============================================================ */
+u64 phydm_db_2_linear(u32 value);
 
+u16 phydm_show_fraction_num(u32 frac_val, u8 bit_num);
 
-/* 1 ============================================================
- * 1  function prototype
- * 1 ============================================================ */
-
-s32
-odm_pwdb_conversion(
-	s32 X,
-	u32 total_bit,
-	u32 decimal_bit
-);
-
-s32
-odm_sign_conversion(
-	s32 value,
-	u32 total_bit
-);
-
-void
-phydm_seq_sorting(
-	void	*p_dm_void,
-	u32	*p_value,
-	u32	*rank_idx,
-	u32	*p_idx_out,
-	u8	seq_length
-);
-
-u32 
-odm_convert_to_db(
-	u32	 value
-);
-
-u32
-odm_convert_to_linear(
-	u32	value
-);
+u32 phydm_gen_bitmask(u8 mask_num);
 
+s32 phydm_cnvrt_2_sign(u32 val, u8 bit_num);
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_mp.c
new file mode 100644
index 000000000000..acb62880f1f4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_mp.c
@@ -0,0 +1,349 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*@************************************************************
+ * include files
+ ************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef PHYDM_MP_SUPPORT
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+
+void phydm_mp_set_single_tone_jgr3(void *dm_void, boolean is_single_tone,
+				   u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_mp *mp = &dm->dm_mp_table;
+	u8 start = RF_PATH_A, end = RF_PATH_A;
+
+	switch (path) {
+	case RF_PATH_A:
+	case RF_PATH_B:
+	case RF_PATH_C:
+	case RF_PATH_D:
+		start = path;
+		end = path;
+		break;
+	case RF_PATH_AB:
+		start = RF_PATH_A;
+		end = RF_PATH_B;
+		break;
+#if (RTL8814B_SUPPORT == 1 || RTL8198F_SUPPORT == 1)
+	case RF_PATH_AC:
+		start = RF_PATH_A;
+		end = RF_PATH_C;
+		break;
+	case RF_PATH_AD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_BC:
+		start = RF_PATH_B;
+		end = RF_PATH_C;
+		break;
+	case RF_PATH_BD:
+		start = RF_PATH_B;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_CD:
+		start = RF_PATH_C;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_ABC:
+		start = RF_PATH_A;
+		end = RF_PATH_C;
+		break;
+	case RF_PATH_ABD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_ACD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_BCD:
+		start = RF_PATH_B;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_ABCD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+#endif
+	}
+	if (is_single_tone) {
+		mp->rf_reg0 = odm_get_rf_reg(dm, RF_PATH_A, RF_0x00, 0xfffff);
+#if 0
+		mp->rfe_sel_a_0 = odm_get_bb_reg(dm, R_0x1840, MASKDWORD);
+		mp->rfe_sel_b_0 = odm_get_bb_reg(dm, R_0x4140, MASKDWORD);
+		mp->rfe_sel_c_0 = odm_get_bb_reg(dm, R_0x5240, MASKDWORD);
+		mp->rfe_sel_d_0 = odm_get_bb_reg(dm, R_0x5340, MASKDWORD);
+		mp->rfe_sel_a_1 = odm_get_bb_reg(dm, R_0x1844, MASKDWORD);
+		mp->rfe_sel_b_1 = odm_get_bb_reg(dm, R_0x4144, MASKDWORD);
+		mp->rfe_sel_c_1 = odm_get_bb_reg(dm, R_0x5244, MASKDWORD);
+		mp->rfe_sel_d_1 = odm_get_bb_reg(dm, R_0x5344, MASKDWORD);
+#endif
+		/* Disable CCK and OFDM */
+		odm_set_bb_reg(dm, R_0x1c3c, 0x3, 0x0);
+		for (start; start <= end; start++) {
+			/* @Tx mode: RF0x00[19:16]=4'b0010 */
+			odm_set_rf_reg(dm, start, RF_0x0, 0xF0000, 0x2);
+			/* @Lowest RF gain index: RF_0x0[4:0] = 0*/
+			odm_set_rf_reg(dm, start, RF_0x0, 0x1F, 0x0);
+			/* @RF LO enabled */
+			odm_set_rf_reg(dm, start, RF_0x58, BIT(1), 0x1);
+		}
+		#if (RTL8814B_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8814B) {
+			/* @Tx mode: RF0x00[19:16]=4'b0010 */
+			config_phydm_write_rf_syn_8814b(dm, RF_SYN0, RF_0x0,
+							0xF0000, 0x2);
+			/* @Lowest RF gain index: RF_0x0[4:0] = 0*/
+			config_phydm_write_rf_syn_8814b(dm, RF_SYN0, RF_0x0,
+							0x1F, 0x0);
+			/* @RF LO enabled */
+			config_phydm_write_rf_syn_8814b(dm, RF_SYN0, RF_0x58,
+							BIT(1), 0x1);
+		}
+		#endif
+	} else {
+		/* Eable CCK and OFDM */
+		odm_set_bb_reg(dm, R_0x1c3c, 0x3, 0x3);
+		if (!(dm->support_ic_type & ODM_RTL8814B)) {
+			for (start; start <= end; start++) {
+				odm_set_rf_reg(dm, start, RF_0x00, 0xfffff,
+					       mp->rf_reg0);
+				/* RF LO disabled */
+				odm_set_rf_reg(dm, start, RF_0x58, BIT(1),
+					       0x0);
+			}
+		}
+#if 0
+		odm_set_bb_reg(dm, R_0x1840, MASKDWORD, mp->rfe_sel_a_0);
+		odm_set_bb_reg(dm, R_0x4140, MASKDWORD, mp->rfe_sel_b_0);
+		odm_set_bb_reg(dm, R_0x5240, MASKDWORD, mp->rfe_sel_c_0);
+		odm_set_bb_reg(dm, R_0x5340, MASKDWORD, mp->rfe_sel_d_0);
+		odm_set_bb_reg(dm, R_0x1844, MASKDWORD, mp->rfe_sel_a_1);
+		odm_set_bb_reg(dm, R_0x4144, MASKDWORD, mp->rfe_sel_b_1);
+		odm_set_bb_reg(dm, R_0x5244, MASKDWORD, mp->rfe_sel_c_1);
+		odm_set_bb_reg(dm, R_0x5344, MASKDWORD, mp->rfe_sel_d_1);
+#endif
+	}
+}
+
+void phydm_mp_set_carrier_supp_jgr3(void *dm_void, boolean is_carrier_supp,
+				    u32 rate_index)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_mp *mp = &dm->dm_mp_table;
+
+	if (is_carrier_supp) {
+		if (phydm_is_cck_rate(dm, (u8)rate_index)) {
+			/* @if CCK block on? */
+			if (!odm_get_bb_reg(dm, R_0x1c3c, BIT(1)))
+				odm_set_bb_reg(dm, R_0x1c3c, BIT(1), 1);
+
+			/* @Turn Off All Test mode */
+			odm_set_bb_reg(dm, R_0x1ca4, 0x7, 0x0);
+
+			/* @transmit mode */
+			odm_set_bb_reg(dm, R_0x1a00, 0x3, 0x2);
+			/* @turn off scramble setting */
+			odm_set_bb_reg(dm, R_0x1a00, 0x8, 0x0);
+			/* @Set CCK Tx Test Rate, set FTxRate to 1Mbps */
+			odm_set_bb_reg(dm, R_0x1a00, 0x3000, 0x0);
+		}
+	} else { /* @Stop Carrier Suppression. */
+		if (phydm_is_cck_rate(dm, (u8)rate_index)) {
+			/* @normal mode */
+			odm_set_bb_reg(dm, R_0x1a00, 0x3, 0x0);
+			/* @turn on scramble setting */
+			odm_set_bb_reg(dm, R_0x1a00, 0x8, 0x1);
+			/* @BB Reset */
+			odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x0);
+			odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x1);
+		}
+	}
+}
+#endif
+
+void phydm_mp_set_crystal_cap(void *dm_void, u8 crystal_cap)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	phydm_set_crystal_cap(dm, crystal_cap);
+}
+
+void phydm_mp_set_single_tone(void *dm_void, boolean is_single_tone, u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_mp_set_single_tone_jgr3(dm, is_single_tone, path);
+}
+
+void phydm_mp_set_carrier_supp(void *dm_void, boolean is_carrier_supp,
+			       u32 rate_index)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_mp_set_carrier_supp_jgr3(dm, is_carrier_supp, rate_index);
+}
+
+void phydm_mp_set_single_carrier(void *dm_void, boolean is_single_carrier)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_mp *mp = &dm->dm_mp_table;
+
+	if (is_single_carrier) {
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			/* @1. if OFDM block on? */
+			if (!odm_get_bb_reg(dm, R_0x1c3c, BIT(0)))
+				odm_set_bb_reg(dm, R_0x1c3c, BIT(0), 1);
+
+			/* @2. set CCK test mode off, set to CCK normal mode */
+			odm_set_bb_reg(dm, R_0x1a00, 0x3, 0);
+
+			/* @3. turn on scramble setting */
+			odm_set_bb_reg(dm, R_0x1a00, 0x8, 1);
+
+			/* @4. Turn On single carrier. */
+			odm_set_bb_reg(dm, R_0x1ca4, 0x7, OFDM_SINGLE_CARRIER);
+		} else {
+			/* @1. if OFDM block on? */
+			if (!odm_get_bb_reg(dm, R_0x800, 0x2000000))
+				odm_set_bb_reg(dm, R_0x800, 0x2000000, 1);
+
+			/* @2. set CCK test mode off, set to CCK normal mode */
+			odm_set_bb_reg(dm, R_0xa00, 0x3, 0);
+
+			/* @3. turn on scramble setting */
+			odm_set_bb_reg(dm, R_0xa00, 0x8, 1);
+
+			/* @4. Turn On single carrier. */
+			if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+				odm_set_bb_reg(dm, R_0x914, 0x70000,
+					       OFDM_SINGLE_CARRIER);
+			else if (dm->support_ic_type & ODM_IC_11N_SERIES)
+				odm_set_bb_reg(dm, R_0xd00, 0x70000000,
+					       OFDM_SINGLE_CARRIER);
+		}
+	} else { /* @Stop Single Carrier. */
+	    /* @Turn off all test modes. */
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			odm_set_bb_reg(dm, R_0x1ca4, 0x7, OFDM_OFF);
+		else if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+			odm_set_bb_reg(dm, R_0x914, 0x70000, OFDM_OFF);
+		else if (dm->support_ic_type & ODM_IC_11N_SERIES)
+			odm_set_bb_reg(dm, R_0xd00, 0x70000000, OFDM_OFF);
+		/* @Delay 10 ms */
+		ODM_delay_ms(10);
+
+		/* @BB Reset */
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+			odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x0);
+			odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x1);
+		} else {
+			odm_set_bb_reg(dm, R_0x100, 0x100, 0x0);
+			odm_set_bb_reg(dm, R_0x100, 0x100, 0x1);
+		}
+	} 
+}
+void phydm_mp_reset_rx_counters_phy(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	phydm_reset_bb_hw_cnt(dm);
+}
+
+void phydm_mp_get_tx_ok(void *dm_void, u32 rate_index)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_mp *mp = &dm->dm_mp_table;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		if (phydm_is_cck_rate(dm, (u8)rate_index))
+			mp->tx_phy_ok_cnt = odm_get_bb_reg(dm, R_0x2de4,
+							   0xffff);
+		else
+			mp->tx_phy_ok_cnt = odm_get_bb_reg(dm, R_0x2de0,
+							   0xffff);
+	} else {
+		if (phydm_is_cck_rate(dm, (u8)rate_index))
+			mp->tx_phy_ok_cnt = odm_get_bb_reg(dm, R_0xf50,
+							   0xffff);
+		else
+			mp->tx_phy_ok_cnt = odm_get_bb_reg(dm, R_0xf50,
+							   0xffff0000);
+	}
+}
+
+void phydm_mp_get_rx_ok(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_mp *mp = &dm->dm_mp_table;	
+
+	u32 cck_ok = 0, ofdm_ok = 0, ht_ok = 0, vht_ok = 0;	
+	u32 cck_err = 0, ofdm_err = 0, ht_err = 0, vht_err = 0;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		cck_ok = odm_get_bb_reg(dm, R_0x2c04, 0xffff);
+		ofdm_ok = odm_get_bb_reg(dm, R_0x2c14, 0xffff);
+		ht_ok = odm_get_bb_reg(dm, R_0x2c10, 0xffff);
+		vht_ok = odm_get_bb_reg(dm, R_0x2c0c, 0xffff);
+  
+		cck_err = odm_get_bb_reg(dm, R_0x2c04, 0xffff0000);
+		ofdm_err = odm_get_bb_reg(dm, R_0x2c14, 0xffff0000);
+		ht_err = odm_get_bb_reg(dm, R_0x2c10, 0xffff0000);
+		vht_err = odm_get_bb_reg(dm, R_0x2c0c, 0xffff0000);
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		cck_ok = odm_get_bb_reg(dm, R_0xf04, 0x3FFF);
+		ofdm_ok = odm_get_bb_reg(dm, R_0xf14, 0x3FFF);
+		ht_ok = odm_get_bb_reg(dm, R_0xf10, 0x3FFF);
+		vht_ok = odm_get_bb_reg(dm, R_0xf0c, 0x3FFF);
+  
+		cck_err = odm_get_bb_reg(dm, R_0xf04, 0x3FFF0000);
+		ofdm_err = odm_get_bb_reg(dm, R_0xf14, 0x3FFF0000);
+		ht_err = odm_get_bb_reg(dm, R_0xf10, 0x3FFF0000);
+		vht_err = odm_get_bb_reg(dm, R_0xf0c, 0x3FFF0000);
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		cck_ok = odm_get_bb_reg(dm, R_0xf88, MASKDWORD);
+		ofdm_ok = odm_get_bb_reg(dm, R_0xf94, 0xffff);
+		ht_ok = odm_get_bb_reg(dm, R_0xf90, 0xffff);
+	    
+		cck_err = odm_get_bb_reg(dm, R_0xf84, MASKDWORD);
+		ofdm_err = odm_get_bb_reg(dm, R_0xf94, 0xffff0000);
+		ht_err = odm_get_bb_reg(dm, R_0xf90, 0xffff0000);
+	}
+
+	mp->rx_phy_ok_cnt = cck_ok + ofdm_ok + ht_ok + vht_ok;
+	mp->rx_phy_crc_err_cnt = cck_err + ofdm_err + ht_err + vht_err;
+	mp->io_value = (u32)mp->rx_phy_ok_cnt;
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_mp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_mp.h
new file mode 100644
index 000000000000..4b372ce94373
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_mp.h
@@ -0,0 +1,95 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __PHYDM_MP_H__
+#define __PHYDM_MP_H__
+
+#define MP_VERSION "1.0"
+
+/* @1 ============================================================
+ * 1  Definition
+ * 1 ============================================================
+ */
+/* @1 ============================================================
+ * 1  structure
+ * 1 ============================================================
+ */
+struct phydm_mp {
+	/* @Rx OK count, statistics used in Mass Production Test.*/
+	u64 tx_phy_ok_cnt;
+	u64 rx_phy_ok_cnt;
+	/* @Rx CRC32 error count, statistics used in Mass Production Test.*/
+	u64 rx_phy_crc_err_cnt;
+	/* @The Value of IO operation is depend of MptActType.*/
+	u32 io_value;
+	u32 rf_reg0;
+	/* @u32 rfe_sel_a_0;*/
+	/* @u32 rfe_sel_b_0;*/
+	/* @u32 rfe_sel_c_0;*/
+	/* @u32 rfe_sel_d_0;*/
+	/* @u32 rfe_sel_a_1;*/
+	/* @u32 rfe_sel_b_1;*/
+	/* @u32 rfe_sel_c_1;*/
+	/* @u32 rfe_sel_d_1;*/
+};
+
+/* @1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================
+ */
+enum TX_MODE_OFDM {
+	OFDM_OFF = 0,	
+	OFDM_CONT_TX = 1,
+	OFDM_SINGLE_CARRIER = 2,
+	OFDM_SINGLE_TONE = 4,
+};
+/* @1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================
+ */
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_mp_set_single_tone_jgr3(void *dm_void, boolean is_single_tone,
+				   u8 path);
+
+void phydm_mp_set_carrier_supp_jgr3(void *dm_void, boolean is_carrier_supp,
+				    u32 rate_index);
+#endif
+
+void phydm_mp_set_crystal_cap(void *dm_void, u8 crystal_cap);
+
+void phydm_mp_set_single_tone(void *dm_void, boolean is_single_tone, u8 path);
+
+void phydm_mp_set_carrier_supp(void *dm_void, boolean is_carrier_supp,
+			       u32 rate_index);
+
+void phydm_mp_set_single_carrier(void *dm_void, boolean is_single_carrier);
+
+void phydm_mp_reset_rx_counters_phy(void *dm_void);
+
+void phydm_mp_get_tx_ok(void *dm_void, u32 rate_index);
+
+void phydm_mp_get_rx_ok(void *dm_void);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.c
index 6f62dd7c9ccc..ddcab0c39969 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,18 +9,28 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-/* *************************************************
+/**************************************************
  * This function is for inband noise test utility only
  * To obtain the inband noise level(dbm), do the following.
  * 1. disable DIG and Power Saving
@@ -27,371 +38,398 @@
  * 3. Stop updating idle time pwer report (for driver read)
  *	- 0x80c[25]
  *
- * ************************************************* */
-
-#define VALID_CNT				5
+ *************************************************/
 
 void phydm_set_noise_data_sum(struct noise_level *noise_data, u8 max_rf_path)
 {
-	u8 rf_path;
+	u8 i = 0;
 
-	for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
-		if (noise_data->valid_cnt[rf_path])
-			noise_data->sum[rf_path] /= noise_data->valid_cnt[rf_path];
+	for (i = RF_PATH_A; i < max_rf_path; i++) {
+		if (noise_data->valid_cnt[i])
+			noise_data->sum[i] /= noise_data->valid_cnt[i];
 		else
-			noise_data->sum[rf_path]  = 0;
+			noise_data->sum[i] = 0;
 	}
 }
 
-s16 odm_inband_noise_monitor_n_series(struct PHY_DM_STRUCT	*p_dm, u8 is_pause_dig, u8 igi_value, u32 max_time)
+#if (ODM_IC_11N_SERIES_SUPPORT)
+s16 odm_inband_noise_monitor_n(struct dm_struct *dm, u8 is_pause_dig, u8 igi,
+			       u32 max_time)
 {
-	u32				tmp4b;
-	u8				max_rf_path = 0, rf_path;
-	u8				reg_c50, reg_c58, valid_done = 0;
-	struct noise_level		noise_data;
-	u64	start  = 0, func_start = 0,	func_end = 0;
+	u32 tmp4b;
+	u8 max_rf_path = 0, i = 0;
+	u8 reg_c50, reg_c58, valid_done = 0;
+	struct noise_level noise_data;
+	u64 start = 0, func_start = 0, func_end = 0;
+	s8 val_s8 = 0;
 
-	func_start = odm_get_current_time(p_dm);
-	p_dm->noise_level.noise_all = 0;
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
 
-	if ((p_dm->rf_type == RF_1T2R) || (p_dm->rf_type == RF_2T2R))
+	if (dm->rf_type == RF_1T2R || dm->rf_type == RF_2T2R)
 		max_rf_path = 2;
 	else
 		max_rf_path = 1;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("odm_DebugControlInbandNoise_Nseries() ==>\n"));
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "odm_DebugControlInbandNoise_Nseries() ==>\n");
 
-	odm_memory_set(p_dm, &noise_data, 0, sizeof(struct noise_level));
+	odm_memory_set(dm, &noise_data, 0, sizeof(struct noise_level));
 	/* step 1. Disable DIG && Set initial gain. */
 
 	if (is_pause_dig)
-		odm_pause_dig(p_dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi);
 
 	/* step 3. Get noise power level */
-	start = odm_get_current_time(p_dm);
+	start = odm_get_current_time(dm);
 	while (1) {
-
 		/* Stop updating idle time pwer report (for driver read) */
-		odm_set_bb_reg(p_dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 1);
+		odm_set_bb_reg(dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 1);
 
 		/* Read Noise Floor Report */
-		tmp4b = odm_get_bb_reg(p_dm, 0x8f8, MASKDWORD);
+		tmp4b = odm_get_bb_reg(dm, R_0x8f8, MASKDWORD);
 
 		/* update idle time pwer report per 5us */
-		odm_set_bb_reg(p_dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 0);
+		odm_set_bb_reg(dm, REG_FPGA0_TX_GAIN_STAGE, BIT(25), 0);
 
 		ODM_delay_us(5);
 
 		noise_data.value[RF_PATH_A] = (u8)(tmp4b & 0xff);
-		noise_data.value[RF_PATH_B]  = (u8)((tmp4b & 0xff00) >> 8);
+		noise_data.value[RF_PATH_B] = (u8)((tmp4b & 0xff00) >> 8);
 
-		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
-			noise_data.sval[rf_path] = (s8)noise_data.value[rf_path];
-			noise_data.sval[rf_path] /= 2;
+		for (i = RF_PATH_A; i < max_rf_path; i++) {
+			noise_data.sval[i] = (s8)noise_data.value[i];
+			noise_data.sval[i] /= 2;
 		}
 
-		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
-			if (noise_data.valid_cnt[rf_path] < VALID_CNT) {
-				noise_data.valid_cnt[rf_path]++;
-				noise_data.sum[rf_path] += noise_data.sval[rf_path];
-				PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("rf_path:%d Valid sval = %d\n", rf_path, noise_data.sval[rf_path]));
-				PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Sum of sval = %d,\n", noise_data.sum[rf_path]));
-				if (noise_data.valid_cnt[rf_path] == VALID_CNT)
-					valid_done++;
-			}
+		for (i = RF_PATH_A; i < max_rf_path; i++) {
+			if (noise_data.valid_cnt[i] >= VALID_CNT)
+				continue;
+
+			noise_data.valid_cnt[i]++;
+			noise_data.sum[i] += noise_data.sval[i];
+			PHYDM_DBG(dm, DBG_ENV_MNTR,
+				  "rf_path:%d Valid sval=%d\n", i,
+				  noise_data.sval[i]);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d,\n",
+				  noise_data.sum[i]);
+			if (noise_data.valid_cnt[i] == VALID_CNT)
+				valid_done++;
 		}
-		if ((valid_done == max_rf_path) || (odm_get_progressing_time(p_dm, start) > max_time)) {
+		if (valid_done == max_rf_path ||
+		    (odm_get_progressing_time(dm, start) > max_time)) {
 			phydm_set_noise_data_sum(&noise_data, max_rf_path);
 			break;
 		}
 	}
-	reg_c50 = (u8)odm_get_bb_reg(p_dm, REG_OFDM_0_XA_AGC_CORE1, MASKBYTE0);
+	reg_c50 = (u8)odm_get_bb_reg(dm, REG_OFDM_0_XA_AGC_CORE1, MASKBYTE0);
 	reg_c50 &= ~BIT(7);
-	p_dm->noise_level.noise[RF_PATH_A] = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
-	p_dm->noise_level.noise_all += p_dm->noise_level.noise[RF_PATH_A];
+	val_s8 = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
+	dm->noise_level.noise[RF_PATH_A] = val_s8;
+	dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_A];
 
 	if (max_rf_path == 2) {
-		reg_c58 = (u8)odm_get_bb_reg(p_dm, REG_OFDM_0_XB_AGC_CORE1, MASKBYTE0);
+		reg_c58 = (u8)odm_get_bb_reg(dm, R_0xc58, MASKBYTE0);
 		reg_c58 &= ~BIT(7);
-		p_dm->noise_level.noise[RF_PATH_B] = (s8)(-110 + reg_c58 + noise_data.sum[RF_PATH_B]);
-		p_dm->noise_level.noise_all += p_dm->noise_level.noise[RF_PATH_B];
+		val_s8 = (s8)(-110 + reg_c58 + noise_data.sum[RF_PATH_B]);
+		dm->noise_level.noise[RF_PATH_B] = val_s8;
+		dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_B];
 	}
-	p_dm->noise_level.noise_all /= max_rf_path;
+	dm->noise_level.noise_all /= max_rf_path;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("noise_a = %d, noise_b = %d, noise_all = %d\n",
-		p_dm->noise_level.noise[RF_PATH_A], p_dm->noise_level.noise[RF_PATH_B],
-		p_dm->noise_level.noise_all));
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "noise_a = %d, noise_b = %d, noise_all = %d\n",
+		  dm->noise_level.noise[RF_PATH_A],
+		  dm->noise_level.noise[RF_PATH_B], dm->noise_level.noise_all);
 
 	/* step 4. Recover the Dig */
 	if (is_pause_dig)
-		odm_pause_dig(p_dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
-	func_end = odm_get_progressing_time(p_dm, func_start);
-
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("end\n"));
-	return p_dm->noise_level.noise_all;
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi);
+	func_end = odm_get_progressing_time(dm, func_start);
 
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "end\n");
+	return dm->noise_level.noise_all;
 }
+#endif
 
-
-s16
-phydm_idle_noise_measurement_ac(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8	is_pause_dig,
-	u8	igi_value,
-	u32	max_time
-	)
+#if (ODM_IC_11AC_SERIES_SUPPORT)
+s16 phydm_idle_noise_measure_ac(struct dm_struct *dm, u8 pause_dig,
+				u8 igi, u32 max_time)
 {
-	u32				tmp4b;
-	u8				max_rf_path = 0, rf_path;
-	u8				reg_c50, reg_e50, valid_done = 0;
-	u64				start  = 0, func_start = 0, func_end = 0;
-	struct noise_level	noise_data;
+	u32 tmp4b;
+	u8 max_rf_path = 0, i = 0;
+	u8 reg_c50, reg_e50, valid_done = 0;
+	u64 start = 0, func_start = 0, func_end = 0;
+	struct noise_level noise_data;
+	s8 val_s8 = 0;
 
-	func_start = odm_get_current_time(p_dm);
-	p_dm->noise_level.noise_all = 0;
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
 
-	if ((p_dm->rf_type == RF_1T2R) || (p_dm->rf_type == RF_2T2R))
+	if (dm->rf_type == RF_1T2R || dm->rf_type == RF_2T2R)
 		max_rf_path = 2;
 	else
 		max_rf_path = 1;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("phydm_idle_noise_measurement_ac==>\n"));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "%s==>\n", __func__);
 
-	odm_memory_set(p_dm, &noise_data, 0, sizeof(struct noise_level));
+	odm_memory_set(dm, &noise_data, 0, sizeof(struct noise_level));
 
 	/*Step 1. Disable DIG && Set initial gain.*/
 
-	if (is_pause_dig)
-		odm_pause_dig(p_dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+	if (pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi);
 
 	/*Step 2. Get noise power level*/
-	start = odm_get_current_time(p_dm);
+	start = odm_get_current_time(dm);
 
 	while (1) {
-
 		/*Stop updating idle time pwer report (for driver read)*/
-		odm_set_bb_reg(p_dm, 0x9e4, BIT(30), 0x1);
+		odm_set_bb_reg(dm, R_0x9e4, BIT(30), 0x1);
 
 		/*Read Noise Floor Report*/
-		tmp4b = odm_get_bb_reg(p_dm, 0xff0, MASKDWORD);
+		tmp4b = odm_get_bb_reg(dm, R_0xff0, MASKDWORD);
 
 		/*update idle time pwer report per 5us*/
-		odm_set_bb_reg(p_dm, 0x9e4, BIT(30), 0x0);
+		odm_set_bb_reg(dm, R_0x9e4, BIT(30), 0x0);
 
 		ODM_delay_us(5);
 
 		noise_data.value[RF_PATH_A] = (u8)(tmp4b & 0xff);
 		noise_data.value[RF_PATH_B] = (u8)((tmp4b & 0xff00) >> 8);
 
-		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
-			noise_data.sval[rf_path] = (s8)noise_data.value[rf_path];
-			noise_data.sval[rf_path] = noise_data.sval[rf_path] >> 1;
+		for (i = RF_PATH_A; i < max_rf_path; i++) {
+			noise_data.sval[i] = (s8)noise_data.value[i];
+			noise_data.sval[i] = noise_data.sval[i] >> 1;
 		}
 
-		for (rf_path = RF_PATH_A; rf_path < max_rf_path; rf_path++) {
-			if (noise_data.valid_cnt[rf_path] < VALID_CNT) {
-				noise_data.valid_cnt[rf_path]++;
-				noise_data.sum[rf_path] += noise_data.sval[rf_path];
-				PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Path:%d Valid sval = %d\n", rf_path, noise_data.sval[rf_path]));
-				PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Sum of sval = %d\n", noise_data.sum[rf_path]));
-				if (noise_data.valid_cnt[rf_path] == VALID_CNT)
-					valid_done++;
-			}
+		for (i = RF_PATH_A; i < max_rf_path; i++) {
+			if (noise_data.valid_cnt[i] >= VALID_CNT)
+				continue;
+
+			noise_data.valid_cnt[i]++;
+			noise_data.sum[i] += noise_data.sval[i];
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Path:%d Valid sval = %d\n",
+				  i, noise_data.sval[i]);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d\n",
+				  noise_data.sum[i]);
+			if (noise_data.valid_cnt[i] == VALID_CNT)
+				valid_done++;
 		}
 
-		if ((valid_done == max_rf_path) || (odm_get_progressing_time(p_dm, start) > max_time)) {
+		if (valid_done == max_rf_path ||
+		    (odm_get_progressing_time(dm, start) > max_time)) {
 			phydm_set_noise_data_sum(&noise_data, max_rf_path);
 			break;
 		}
 	}
-	reg_c50 = (u8)odm_get_bb_reg(p_dm, 0xc50, MASKBYTE0);
+	reg_c50 = (u8)odm_get_bb_reg(dm, R_0xc50, MASKBYTE0);
 	reg_c50 &= ~BIT(7);
-	p_dm->noise_level.noise[RF_PATH_A] = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
-	p_dm->noise_level.noise_all += p_dm->noise_level.noise[RF_PATH_A];
+	val_s8 = (s8)(-110 + reg_c50 + noise_data.sum[RF_PATH_A]);
+	dm->noise_level.noise[RF_PATH_A] = val_s8;
+	dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_A];
 
 	if (max_rf_path == 2) {
-		reg_e50 = (u8)odm_get_bb_reg(p_dm, 0xe50, MASKBYTE0);
+		reg_e50 = (u8)odm_get_bb_reg(dm, R_0xe50, MASKBYTE0);
 		reg_e50 &= ~BIT(7);
-		p_dm->noise_level.noise[RF_PATH_B] = (s8)(-110 + reg_e50 + noise_data.sum[RF_PATH_B]);
-		p_dm->noise_level.noise_all += p_dm->noise_level.noise[RF_PATH_B];
+		val_s8 = (s8)(-110 + reg_e50 + noise_data.sum[RF_PATH_B]);
+		dm->noise_level.noise[RF_PATH_B] = val_s8;
+		dm->noise_level.noise_all += dm->noise_level.noise[RF_PATH_B];
 	}
-	p_dm->noise_level.noise_all /= max_rf_path;
+	dm->noise_level.noise_all /= max_rf_path;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("noise_a = %d, noise_b = %d, noise_all = %d\n",
-		p_dm->noise_level.noise[RF_PATH_A], p_dm->noise_level.noise[RF_PATH_B],
-		p_dm->noise_level.noise_all));
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "noise_a = %d, noise_b = %d, noise_all = %d\n",
+		  dm->noise_level.noise[RF_PATH_A],
+		  dm->noise_level.noise[RF_PATH_B], dm->noise_level.noise_all);
 
 	/*Step 3. Recover the Dig*/
-	if (is_pause_dig)
-		odm_pause_dig(p_dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
-	func_end = odm_get_progressing_time(p_dm, func_start);
-
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("end\n"));
-	return p_dm->noise_level.noise_all;
+	if (pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi);
+	func_end = odm_get_progressing_time(dm, func_start);
 
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "end\n");
+	return dm->noise_level.noise_all;
 }
 
-
-s16
-odm_inband_noise_monitor_ac_series(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8 is_pause_dig,
-	u8 igi_value,
-	u32 max_time
-	)
+s16 odm_inband_noise_monitor_ac(struct dm_struct *dm, u8 pause_dig, u8 igi,
+				u32 max_time)
 {
-	s32          rxi_buf_anta, rxq_buf_anta; /*rxi_buf_antb, rxq_buf_antb;*/
-	s32	        value32, pwdb_A = 0, sval, noise, sum = 0;
-	boolean	        pd_flag;
-	u8		valid_cnt = 0;
-	u64	start = 0, func_start = 0, func_end = 0;
-
-	if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
-		return phydm_idle_noise_measurement_ac(p_dm, is_pause_dig, igi_value, max_time);
+	s32 rxi_buf_anta, rxq_buf_anta; /*rxi_buf_antb, rxq_buf_antb;*/
+	s32 value32, pwdb_A = 0, sval, noise, sum = 0;
+	boolean pd_flag;
+	u8 valid_cnt = 0;
+	u64 start = 0, func_start = 0, func_end = 0;
+	s32 val_s32 = 0;
+	s16 rpt = 0;
+	u8 val_u8 = 0;
+
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)) {
+		rpt = phydm_idle_noise_measure_ac(dm, pause_dig, igi, max_time);
+		return rpt;
+	}
 
-	if (!(p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A)))
+	if (!(dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A)))
 		return 0;
 
-	func_start = odm_get_current_time(p_dm);
-	p_dm->noise_level.noise_all = 0;
+	func_start = odm_get_current_time(dm);
+	dm->noise_level.noise_all = 0;
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("odm_inband_noise_monitor_ac_series() ==>\n"));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "%s ==>\n", __func__);
 
 	/* step 1. Disable DIG && Set initial gain. */
-	if (is_pause_dig)
-		odm_pause_dig(p_dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi_value);
+	if (pause_dig)
+		odm_pause_dig(dm, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_1, igi);
 
 	/* step 3. Get noise power level */
-	start = odm_get_current_time(p_dm);
+	start = odm_get_current_time(dm);
 
 	/* step 3. Get noise power level */
 	while (1) {
 		/*Set IGI=0x1C */
-		odm_write_dig(p_dm, 0x1C);
+		odm_write_dig(dm, 0x1C);
 		/*stop CK320&CK88 */
-		odm_set_bb_reg(p_dm, 0x8B4, BIT(6), 1);
+		odm_set_bb_reg(dm, R_0x8b4, BIT(6), 1);
 		/*Read path-A */
-		odm_set_bb_reg(p_dm, 0x8FC, MASKDWORD, 0x200); /*set debug port*/
-		value32 = odm_get_bb_reg(p_dm, 0xFA0, MASKDWORD); /*read debug port*/
-
-		rxi_buf_anta = (value32 & 0xFFC00) >> 10; /*rxi_buf_anta=RegFA0[19:10]*/
+		/*set debug port*/
+		odm_set_bb_reg(dm, R_0x8fc, MASKDWORD, 0x200);
+		/*read debug port*/
+		value32 = odm_get_bb_reg(dm, R_0xfa0, MASKDWORD);
+		/*rxi_buf_anta=RegFA0[19:10]*/
+		rxi_buf_anta = (value32 & 0xFFC00) >> 10;
 		rxq_buf_anta = value32 & 0x3FF; /*rxq_buf_anta=RegFA0[19:10]*/
 
 		pd_flag = (boolean)((value32 & BIT(31)) >> 31);
 
 		/*Not in packet detection period or Tx state */
-		if ((!pd_flag) || (rxi_buf_anta != 0x200)) {
+		if (!pd_flag || rxi_buf_anta != 0x200) {
 			/*sign conversion*/
 			rxi_buf_anta = odm_sign_conversion(rxi_buf_anta, 10);
 			rxq_buf_anta = odm_sign_conversion(rxq_buf_anta, 10);
 
-			pwdb_A = odm_pwdb_conversion(rxi_buf_anta * rxi_buf_anta + rxq_buf_anta * rxq_buf_anta, 20, 18); /*S(10,9)*S(10,9)=S(20,18)*/
+			val_s32 = rxi_buf_anta * rxi_buf_anta +
+				  rxq_buf_anta * rxq_buf_anta;
+			/*S(10,9)*S(10,9)=S(20,18)*/
+			pwdb_A = odm_pwdb_conversion(val_s32, 20, 18);
 
-			PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("pwdb_A= %d dB, rxi_buf_anta= 0x%x, rxq_buf_anta= 0x%x\n", pwdb_A, rxi_buf_anta & 0x3FF, rxq_buf_anta & 0x3FF));
+			PHYDM_DBG(dm, DBG_ENV_MNTR,
+				  "pwdb_A= %d dB, rxi_buf_anta= 0x%x, rxq_buf_anta= 0x%x\n",
+				  pwdb_A, rxi_buf_anta & 0x3FF,
+				  rxq_buf_anta & 0x3FF);
 		}
 		/*Start CK320&CK88*/
-		odm_set_bb_reg(p_dm, 0x8B4, BIT(6), 0);
-		/*BB Reset*/
-		odm_write_1byte(p_dm, 0x02, odm_read_1byte(p_dm, 0x02) & (~BIT(0)));
-		odm_write_1byte(p_dm, 0x02, odm_read_1byte(p_dm, 0x02) | BIT(0));
+		odm_set_bb_reg(dm, R_0x8b4, BIT(6), 0);
+		/*@BB Reset*/
+		val_u8 = odm_read_1byte(dm, 0x02) & (~BIT(0));
+		odm_write_1byte(dm, 0x02, val_u8);
+		val_u8 = odm_read_1byte(dm, 0x02) | BIT(0);
+		odm_write_1byte(dm, 0x02, val_u8);
 		/*PMAC Reset*/
-		odm_write_1byte(p_dm, 0xB03, odm_read_1byte(p_dm, 0xB03) & (~BIT(0)));
-		odm_write_1byte(p_dm, 0xB03, odm_read_1byte(p_dm, 0xB03) | BIT(0));
-		/*CCK Reset*/
-		if (odm_read_1byte(p_dm, 0x80B) & BIT(4)) {
-			odm_write_1byte(p_dm, 0x80B, odm_read_1byte(p_dm, 0x80B) & (~BIT(4)));
-			odm_write_1byte(p_dm, 0x80B, odm_read_1byte(p_dm, 0x80B) | BIT(4));
+		val_u8 = odm_read_1byte(dm, 0xB03) & (~BIT(0));
+		odm_write_1byte(dm, 0xB03, val_u8);
+		val_u8 = odm_read_1byte(dm, 0xB03) | BIT(0);
+		odm_write_1byte(dm, 0xB03, val_u8);
+		/*@CCK Reset*/
+		if (odm_read_1byte(dm, 0x80B) & BIT(4)) {
+			val_u8 = odm_read_1byte(dm, 0x80B) & (~BIT(4));
+			odm_write_1byte(dm, 0x80B, val_u8);
+			val_u8 = odm_read_1byte(dm, 0x80B) | BIT(4);
+			odm_write_1byte(dm, 0x80B, val_u8);
 		}
 
 		sval = pwdb_A;
 
-		if ((sval < 0 && sval >= -27) && (valid_cnt < VALID_CNT)){
+		if ((sval < 0 && sval >= -27) && valid_cnt < VALID_CNT) {
 			valid_cnt++;
 			sum += sval;
-			PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Valid sval = %d\n", sval));
-			PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("Sum of sval = %d,\n", sum));
-			if ((valid_cnt >= VALID_CNT) || (odm_get_progressing_time(p_dm, start) > max_time)) {
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Valid sval = %d\n", sval);
+			PHYDM_DBG(dm, DBG_ENV_MNTR, "Sum of sval = %d,\n", sum);
+			if (valid_cnt >= VALID_CNT ||
+			    (odm_get_progressing_time(dm, start) > max_time)) {
 				sum /= VALID_CNT;
-				PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("After divided, sum = %d\n", sum));
+				PHYDM_DBG(dm, DBG_ENV_MNTR,
+					  "After divided, sum = %d\n", sum);
 				break;
 			}
 		}
 	}
 
-	/*ADC backoff is 12dB,*/
+	/*@ADC backoff is 12dB,*/
 	/*Ptarget=0x1C-110=-82dBm*/
 	noise = sum + 12 + 0x1C - 110;
 
 	/*Offset*/
 	noise = noise - 3;
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("noise = %d\n", noise));
-	p_dm->noise_level.noise_all = (s16)noise;
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "noise = %d\n", noise);
+	dm->noise_level.noise_all = (s16)noise;
 
 	/* step 4. Recover the Dig*/
-	if (is_pause_dig)
-		odm_pause_dig(p_dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi_value);
+	if (pause_dig)
+		odm_pause_dig(dm, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_1, igi);
 
-	func_end = odm_get_progressing_time(p_dm, func_start);
+	func_end = odm_get_progressing_time(dm, func_start);
 
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR, ("odm_inband_noise_monitor_ac_series() <==\n"));
+	PHYDM_DBG(dm, DBG_ENV_MNTR, "%s <==\n", __func__);
 
-	return p_dm->noise_level.noise_all;
+	return dm->noise_level.noise_all;
 }
+#endif
 
+s16 odm_inband_noise_monitor(void *dm_void, u8 pause_dig, u8 igi,
+			     u32 max_time)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	s16 val = 0;
 
+	igi = 0x32;
 
-s16
-odm_inband_noise_monitor(
-	void *p_dm_void,
-	u8 is_pause_dig,
-	u8 igi_value,
-	u32 max_time
-	)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	/* since HW ability is about +15~-35,
+	 * we fix IGI = -60 for maximum coverage
+	 */
+	#if (ODM_IC_11AC_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES)
+		val = odm_inband_noise_monitor_ac(dm, pause_dig, igi, max_time);
+	#endif
 
-	igi_value = 0x32;	/*since HW ability is about +15~-35, we fix IGI = -60 for maximum coverage*/
+	#if (ODM_IC_11N_SERIES_SUPPORT)
+	if (dm->support_ic_type & ODM_IC_11N_SERIES)
+		val = odm_inband_noise_monitor_n(dm, pause_dig, igi, max_time);
+	#endif
 
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES)
-		return odm_inband_noise_monitor_ac_series(p_dm, is_pause_dig, igi_value, max_time);
-	else
-		return odm_inband_noise_monitor_n_series(p_dm, is_pause_dig, igi_value, max_time);
+	return val;
 }
 
-void
-phydm_noisy_detection(
-	void *p_dm_void
-)
+void phydm_noisy_detection(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32  total_fa_cnt, total_cca_cnt;
-	u32  score = 0, i, score_smooth;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 total_fa_cnt, total_cca_cnt;
+	u32 score = 0, i, score_smooth;
 
-	total_cca_cnt = p_dm->false_alm_cnt.cnt_cca_all;
-	total_fa_cnt  = p_dm->false_alm_cnt.cnt_all;
+	total_cca_cnt = dm->false_alm_cnt.cnt_cca_all;
+	total_fa_cnt = dm->false_alm_cnt.cnt_all;
 
 #if 0
-	if (total_fa_cnt * 16 >= total_cca_cnt * 14)    /*  87.5 */
+	if (total_fa_cnt * 16 >= total_cca_cnt * 14)    /*  @87.5 */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 12) /*  75 */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 12) /*  @75 */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 10) /*  56.25 */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 10) /*  @56.25 */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 8) /*  50 */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 8) /*  @50 */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 7) /*  43.75 */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 7) /*  @43.75 */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 6) /*  37.5 */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 6) /*  @37.5 */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 5) /*  31.25% */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 5) /*  @31.25% */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 4) /*  25% */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 4) /*  @25% */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 3) /*  18.75% */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 3) /*  @18.75% */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 2) /*  12.5% */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 2) /*  @12.5% */
 		;
-	else if (total_fa_cnt * 16 >= total_cca_cnt * 1) /*  6.25% */
+	else if (total_fa_cnt * 16 >= total_cca_cnt * 1) /*  @6.25% */
 		;
 #endif
 	for (i = 0; i <= 16; i++) {
@@ -402,16 +440,19 @@ phydm_noisy_detection(
 	}
 
 	/* noisy_decision_smooth = noisy_decision_smooth>>1 + (score<<3)>>1; */
-	p_dm->noisy_decision_smooth = (p_dm->noisy_decision_smooth >> 1) + (score << 2);
+	dm->noisy_decision_smooth = (dm->noisy_decision_smooth >> 1) +
+				    (score << 2);
 
 	/* Round the noisy_decision_smooth: +"3" comes from (2^3)/2-1 */
-	score_smooth = (total_cca_cnt >= 300) ? ((p_dm->noisy_decision_smooth + 3) >> 3) : 0;
+	if (total_cca_cnt >= 300)
+		score_smooth = (dm->noisy_decision_smooth + 3) >> 3;
+	else
+		score_smooth = 0;
 
-	p_dm->noisy_decision = (score_smooth >= 3) ? 1 : 0;
-	
-	PHYDM_DBG(p_dm, DBG_ENV_MNTR,
-		("[NoisyDetection] CCA_cnt=%d,FA_cnt=%d, noisy_dec_smooth=%d, score=%d, score_smooth=%d, noisy_dec=%d\n",
-		total_cca_cnt, total_fa_cnt, p_dm->noisy_decision_smooth, score, score_smooth, p_dm->noisy_decision));
+	dm->noisy_decision = (score_smooth >= 3) ? 1 : 0;
 
+	PHYDM_DBG(dm, DBG_ENV_MNTR,
+		  "[NoisyDetection] CCA_cnt=%d,FA_cnt=%d, noisy_dec_smooth=%d, score=%d, score_smooth=%d, noisy_dec=%d\n",
+		  total_cca_cnt, total_fa_cnt, dm->noisy_decision_smooth, score,
+		  score_smooth, dm->noisy_decision);
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.h
index 97a745fb49dc..b73b6e4b4781 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_noisemonitor.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,38 +9,41 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
-#ifndef	__ODMNOISEMONITOR_H__
+#ifndef __ODMNOISEMONITOR_H__
 #define __ODMNOISEMONITOR_H__
 
-#define	ODM_MAX_CHANNEL_NUM					38/* 14+24 */
+#define VALID_CNT 5
+
 struct noise_level {
-	u8				value[PHYDM_MAX_RF_PATH];
-	s8				sval[PHYDM_MAX_RF_PATH];
-	s32				sum[PHYDM_MAX_RF_PATH];
-	u8				valid[PHYDM_MAX_RF_PATH];
-	u8				valid_cnt[PHYDM_MAX_RF_PATH];
+	u8 value[PHYDM_MAX_RF_PATH];
+	s8 sval[PHYDM_MAX_RF_PATH];
+	s32 sum[PHYDM_MAX_RF_PATH];
+	u8 valid[PHYDM_MAX_RF_PATH];
+	u8 valid_cnt[PHYDM_MAX_RF_PATH];
 };
 
-
-struct _ODM_NOISE_MONITOR_ {
-	s8			noise[PHYDM_MAX_RF_PATH];
-	s16			noise_all;
+struct odm_noise_monitor {
+	s8 noise[PHYDM_MAX_RF_PATH];
+	s16 noise_all;
 };
 
-s16 odm_inband_noise_monitor(
-	void *p_dm_void,
-	u8 is_pause_dig,
-	u8 igi_value,
-	u32 max_time
-);
+s16 odm_inband_noise_monitor(void *dm_void, u8 is_pause_dig, u8 igi_value,
+			     u32 max_time);
 
-void
-phydm_noisy_detection(
-	void *p_dm_void
-);
+void phydm_noisy_detection(void *dm_void);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.c
index 72e4bcb51512..4fe10d78eb38 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,685 +9,921 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-#if (defined(CONFIG_PATH_DIVERSITY))
+#ifdef CONFIG_PATH_DIVERSITY
 #if RTL8814A_SUPPORT
-
-void
-phydm_dtp_fix_tx_path(
-	void	*p_dm_void,
-	u8	path
-)
+void phydm_dtp_fix_tx_path(
+	void *dm_void,
+	u8 path)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ODM_PATH_DIVERSITY_		*p_dm_path_div = &p_dm->dm_path_div;
-	u8			i, num_enable_path = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u8 i, num_enable_path = 0;
 
-	if (path == p_dm_path_div->pre_tx_path)
+	if (path == p_div->pre_tx_path)
 		return;
 	else
-		p_dm_path_div->pre_tx_path = path;
+		p_div->pre_tx_path = path;
 
-	odm_set_bb_reg(p_dm, 0x93c, BIT(18) | BIT(19), 3);
+	odm_set_bb_reg(dm, R_0x93c, BIT(18) | BIT(19), 3);
 
 	for (i = 0; i < 4; i++) {
 		if (path & BIT(i))
 			num_enable_path++;
 	}
-	PHYDM_DBG(p_dm, DBG_PATH_DIV, (" number of turn-on path : (( %d ))\n", num_enable_path));
+	PHYDM_DBG(dm, DBG_PATH_DIV, " number of turn-on path : (( %d ))\n",
+		  num_enable_path);
 
 	if (num_enable_path == 1) {
-		odm_set_bb_reg(p_dm, 0x93c, 0xf00000, path);
-
-		if (path == BB_PATH_A) { /* 1-1 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( A ))\n"));
-			odm_set_bb_reg(p_dm, 0x93c, BIT(25) | BIT(24), 0);
-		} else 	if (path == BB_PATH_B) { /* 1-2 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( B ))\n"));
-			odm_set_bb_reg(p_dm, 0x93c, BIT(27) | BIT(26), 0);
-		} else 	if (path == BB_PATH_C) { /* 1-3 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( C ))\n"));
-			odm_set_bb_reg(p_dm, 0x93c, BIT(29) | BIT(28), 0);
-
-		} else 	if (path == BB_PATH_D) { /* 1-4 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( D ))\n"));
-			odm_set_bb_reg(p_dm, 0x93c, BIT(31) | BIT(30), 0);
+		odm_set_bb_reg(dm, R_0x93c, 0xf00000, path);
+
+		if (path == BB_PATH_A) { /* @1-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( A ))\n");
+			odm_set_bb_reg(dm, R_0x93c, BIT(25) | BIT(24), 0);
+		} else if (path == BB_PATH_B) { /* @1-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( B ))\n");
+			odm_set_bb_reg(dm, R_0x93c, BIT(27) | BIT(26), 0);
+		} else if (path == BB_PATH_C) { /* @1-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( C ))\n");
+			odm_set_bb_reg(dm, R_0x93c, BIT(29) | BIT(28), 0);
+
+		} else if (path == BB_PATH_D) { /* @1-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path (( D ))\n");
+			odm_set_bb_reg(dm, R_0x93c, BIT(31) | BIT(30), 0);
 		}
 
-	} else	if (num_enable_path == 2) {
-		odm_set_bb_reg(p_dm, 0x93c, 0xf00000, path);
-		odm_set_bb_reg(p_dm, 0x940, 0xf0, path);
+	} else if (num_enable_path == 2) {
+		odm_set_bb_reg(dm, R_0x93c, 0xf00000, path);
+		odm_set_bb_reg(dm, R_0x940, 0xf0, path);
 
-		if (path == (BB_PATH_AB)) { /* 2-1 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( A B ))\n"));
+		if (path == (BB_PATH_AB)) { /* @2-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( A B ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(25) | BIT(24), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(27) | BIT(26), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(27) | BIT(26), 1);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(9) | BIT(8), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(11) | BIT(10), 1);
-		} else 	if (path == BB_PATH_AC) { /* 2-2 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( A C ))\n"));
+			odm_set_bb_reg(dm, R_0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(11) | BIT(10), 1);
+		} else if (path == BB_PATH_AC) { /* @2-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( A C ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(25) | BIT(24), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(29) | BIT(28), 1);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(9) | BIT(8), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(13) | BIT(12), 1);
-		} else 	if (path == BB_PATH_AD) { /* 2-3 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( A D ))\n"));
+			odm_set_bb_reg(dm, R_0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(13) | BIT(12), 1);
+		} else if (path == BB_PATH_AD) { /* @2-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( A D ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(25) | BIT(24), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(31) | BIT(30), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(31) | BIT(30), 1);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(9) | BIT(8), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(15) | BIT(14), 1);
-		} else 	if (path == BB_PATH_BC) { /* 2-4 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( B C ))\n"));
+			odm_set_bb_reg(dm, R_0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(15) | BIT(14), 1);
+		} else if (path == BB_PATH_BC) { /* @2-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( B C ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(27) | BIT(26), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(29) | BIT(28), 1);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(11) | BIT(10), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(13) | BIT(12), 1);
-		} else 	if (path == BB_PATH_BD) { /* 2-5 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( B D ))\n"));
+			odm_set_bb_reg(dm, R_0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(13) | BIT(12), 1);
+		} else if (path == BB_PATH_BD) { /* @2-5 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( B D ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(27) | BIT(26), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(31) | BIT(30), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(31) | BIT(30), 1);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(11) | BIT(10), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(15) | BIT(14), 1);
-		} else 	if (path == BB_PATH_CD) { /* 2-6 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( C D ))\n"));
+			odm_set_bb_reg(dm, R_0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(15) | BIT(14), 1);
+		} else if (path == BB_PATH_CD) { /* @2-6 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( C D ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(29) | BIT(28), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(31) | BIT(30), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(29) | BIT(28), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(31) | BIT(30), 1);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(13) | BIT(12), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(15) | BIT(14), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(13) | BIT(12), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(15) | BIT(14), 1);
 		}
 
-	} else	if (num_enable_path == 3) {
-		odm_set_bb_reg(p_dm, 0x93c, 0xf00000, path);
-		odm_set_bb_reg(p_dm, 0x940, 0xf0, path);
-		odm_set_bb_reg(p_dm, 0x940, 0xf0000, path);
+	} else if (num_enable_path == 3) {
+		odm_set_bb_reg(dm, R_0x93c, 0xf00000, path);
+		odm_set_bb_reg(dm, R_0x940, 0xf0, path);
+		odm_set_bb_reg(dm, R_0x940, 0xf0000, path);
 
-		if (path == BB_PATH_ABC) { /* 3-1 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( A B C))\n"));
+		if (path == BB_PATH_ABC) { /* @3-1 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( A B C))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(25) | BIT(24), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(27) | BIT(26), 1);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(29) | BIT(28), 2);
+			odm_set_bb_reg(dm, R_0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(27) | BIT(26), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(29) | BIT(28), 2);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(9) | BIT(8), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(11) | BIT(10), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(13) | BIT(12), 2);
+			odm_set_bb_reg(dm, R_0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(11) | BIT(10), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(13) | BIT(12), 2);
 			/* set for 3ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(21) | BIT(20), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(23) | BIT(22), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(25) | BIT(24), 2);
-		} else 	if (path == BB_PATH_ABD) { /* 3-2 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( A B D ))\n"));
+			odm_set_bb_reg(dm, R_0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(23) | BIT(22), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(25) | BIT(24), 2);
+		} else if (path == BB_PATH_ABD) { /* @3-2 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( A B D ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(25) | BIT(24), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(27) | BIT(26), 1);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(31) | BIT(30), 2);
+			odm_set_bb_reg(dm, R_0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(27) | BIT(26), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(31) | BIT(30), 2);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(9) | BIT(8), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(11) | BIT(10), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(15) | BIT(14), 2);
+			odm_set_bb_reg(dm, R_0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(11) | BIT(10), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(15) | BIT(14), 2);
 			/* set for 3ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(21) | BIT(20), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(23) | BIT(22), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(27) | BIT(26), 2);
+			odm_set_bb_reg(dm, R_0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(23) | BIT(22), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(27) | BIT(26), 2);
 
-		} else 	if (path == BB_PATH_ACD) { /* 3-3 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( A C D ))\n"));
+		} else if (path == BB_PATH_ACD) { /* @3-3 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( A C D ))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(25) | BIT(24), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(29) | BIT(28), 1);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(31) | BIT(30), 2);
+			odm_set_bb_reg(dm, R_0x93c, BIT(25) | BIT(24), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(31) | BIT(30), 2);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(9) | BIT(8), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(13) | BIT(12), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(15) | BIT(14), 2);
+			odm_set_bb_reg(dm, R_0x940, BIT(9) | BIT(8), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(13) | BIT(12), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(15) | BIT(14), 2);
 			/* set for 3ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(21) | BIT(20), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(25) | BIT(24), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(27) | BIT(26), 2);
-		} else 	if (path == BB_PATH_BCD) { /* 3-4 */
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path (( B C D))\n"));
+			odm_set_bb_reg(dm, R_0x940, BIT(21) | BIT(20), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(25) | BIT(24), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(27) | BIT(26), 2);
+		} else if (path == BB_PATH_BCD) { /* @3-4 */
+			PHYDM_DBG(dm, DBG_PATH_DIV,
+				  " Turn on path (( B C D))\n");
 			/* set for 1ss */
-			odm_set_bb_reg(p_dm, 0x93c, BIT(27) | BIT(26), 0);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(29) | BIT(28), 1);
-			odm_set_bb_reg(p_dm, 0x93c, BIT(31) | BIT(30), 2);
+			odm_set_bb_reg(dm, R_0x93c, BIT(27) | BIT(26), 0);
+			odm_set_bb_reg(dm, R_0x93c, BIT(29) | BIT(28), 1);
+			odm_set_bb_reg(dm, R_0x93c, BIT(31) | BIT(30), 2);
 			/* set for 2ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(11) | BIT(10), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(13) | BIT(12), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(15) | BIT(14), 2);
+			odm_set_bb_reg(dm, R_0x940, BIT(11) | BIT(10), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(13) | BIT(12), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(15) | BIT(14), 2);
 			/* set for 3ss */
-			odm_set_bb_reg(p_dm, 0x940, BIT(23) | BIT(22), 0);
-			odm_set_bb_reg(p_dm, 0x940, BIT(25) | BIT(24), 1);
-			odm_set_bb_reg(p_dm, 0x940, BIT(27) | BIT(26), 2);
+			odm_set_bb_reg(dm, R_0x940, BIT(23) | BIT(22), 0);
+			odm_set_bb_reg(dm, R_0x940, BIT(25) | BIT(24), 1);
+			odm_set_bb_reg(dm, R_0x940, BIT(27) | BIT(26), 2);
 		}
-	} else	if (num_enable_path == 4)
-		PHYDM_DBG(p_dm, DBG_PATH_DIV, (" Turn on path ((A  B C D))\n"));
-
+	} else if (num_enable_path == 4)
+		PHYDM_DBG(dm, DBG_PATH_DIV, " Turn on path ((A  B C D))\n");
 }
 
-void
-phydm_find_default_path(
-	void	*p_dm_void
-)
+void phydm_find_default_path(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ODM_PATH_DIVERSITY_		*p_dm_path_div = &p_dm->dm_path_div;
-	u32	rssi_avg_a = 0, rssi_avg_b = 0, rssi_avg_c = 0, rssi_avg_d = 0, rssi_avg_bcd = 0;
-	u32	rssi_total_a = 0, rssi_total_b = 0, rssi_total_c = 0, rssi_total_d = 0;
-
-	/* 2 Default path Selection By RSSI */
-
-	rssi_avg_a = (p_dm_path_div->path_a_cnt_all > 0) ? (p_dm_path_div->path_a_sum_all / p_dm_path_div->path_a_cnt_all) : 0 ;
-	rssi_avg_b = (p_dm_path_div->path_b_cnt_all > 0) ? (p_dm_path_div->path_b_sum_all / p_dm_path_div->path_b_cnt_all) : 0 ;
-	rssi_avg_c = (p_dm_path_div->path_c_cnt_all > 0) ? (p_dm_path_div->path_c_sum_all / p_dm_path_div->path_c_cnt_all) : 0 ;
-	rssi_avg_d = (p_dm_path_div->path_d_cnt_all > 0) ? (p_dm_path_div->path_d_sum_all / p_dm_path_div->path_d_cnt_all) : 0 ;
-
-
-	p_dm_path_div->path_a_sum_all = 0;
-	p_dm_path_div->path_a_cnt_all = 0;
-	p_dm_path_div->path_b_sum_all = 0;
-	p_dm_path_div->path_b_cnt_all = 0;
-	p_dm_path_div->path_c_sum_all = 0;
-	p_dm_path_div->path_c_cnt_all = 0;
-	p_dm_path_div->path_d_sum_all = 0;
-	p_dm_path_div->path_d_cnt_all = 0;
-
-	if (p_dm_path_div->use_path_a_as_default_ant == 1) {
-		rssi_avg_bcd = (rssi_avg_b + rssi_avg_c + rssi_avg_d) / 3;
-
-		if ((rssi_avg_a + ANT_DECT_RSSI_TH) > rssi_avg_bcd) {
-			p_dm_path_div->is_path_a_exist = true;
-			p_dm_path_div->default_path = PATH_A;
-		} else
-			p_dm_path_div->is_path_a_exist = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u32 rssi_a = 0, rssi_b = 0, rssi_c = 0, rssi_d = 0, rssi_bcd = 0;
+	u32 rssi_total_a = 0, rssi_total_b = 0;
+	u32 rssi_total_c = 0, rssi_total_d = 0;
+
+	/* @2 Default path Selection By RSSI */
+
+	rssi_a = (p_div->path_a_cnt_all > 0) ?
+		 (p_div->path_a_sum_all / p_div->path_a_cnt_all) : 0;
+	rssi_b = (p_div->path_b_cnt_all > 0) ?
+		 (p_div->path_b_sum_all / p_div->path_b_cnt_all) : 0;
+	rssi_c = (p_div->path_c_cnt_all > 0) ?
+		 (p_div->path_c_sum_all / p_div->path_c_cnt_all) : 0;
+	rssi_d = (p_div->path_d_cnt_all > 0) ?
+		 (p_div->path_d_sum_all / p_div->path_d_cnt_all) : 0;
+
+	p_div->path_a_sum_all = 0;
+	p_div->path_a_cnt_all = 0;
+	p_div->path_b_sum_all = 0;
+	p_div->path_b_cnt_all = 0;
+	p_div->path_c_sum_all = 0;
+	p_div->path_c_cnt_all = 0;
+	p_div->path_d_sum_all = 0;
+	p_div->path_d_cnt_all = 0;
+
+	if (p_div->use_path_a_as_default_ant == 1) {
+		rssi_bcd = (rssi_b + rssi_c + rssi_d) / 3;
+
+		if ((rssi_a + ANT_DECT_RSSI_TH) > rssi_bcd) {
+			p_div->is_path_a_exist = true;
+			p_div->default_path = PATH_A;
+		} else {
+			p_div->is_path_a_exist = false;
+		}
 	} else {
-		if ((rssi_avg_a >= rssi_avg_b) && (rssi_avg_a >= rssi_avg_c) && (rssi_avg_a >= rssi_avg_d))
-			p_dm_path_div->default_path = PATH_A;
-		else if ((rssi_avg_b >= rssi_avg_c) && (rssi_avg_b >= rssi_avg_d))
-			p_dm_path_div->default_path = PATH_B;
-		else if (rssi_avg_c >= rssi_avg_d)
-			p_dm_path_div->default_path = PATH_C;
+		if (rssi_a >= rssi_b &&
+		    rssi_a >= rssi_c &&
+		    rssi_a >= rssi_d)
+			p_div->default_path = PATH_A;
+		else if ((rssi_b >= rssi_c) && (rssi_b >= rssi_d))
+			p_div->default_path = PATH_B;
+		else if (rssi_c >= rssi_d)
+			p_div->default_path = PATH_C;
 		else
-			p_dm_path_div->default_path = PATH_D;
+			p_div->default_path = PATH_D;
 	}
-
-
 }
 
-
-void
-phydm_candidate_dtp_update(
-	void	*p_dm_void
-)
+void phydm_candidate_dtp_update(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ODM_PATH_DIVERSITY_		*p_dm_path_div = &p_dm->dm_path_div;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
 
-	p_dm_path_div->num_candidate = 3;
+	p_div->num_candidate = 3;
 
-	if (p_dm_path_div->use_path_a_as_default_ant == 1) {
-		if (p_dm_path_div->num_tx_path == 3) {
-			if (p_dm_path_div->is_path_a_exist) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_ACD;
+	if (p_div->use_path_a_as_default_ant == 1) {
+		if (p_div->num_tx_path == 3) {
+			if (p_div->is_path_a_exist) {
+				p_div->ant_candidate_1 = BB_PATH_ABC;
+				p_div->ant_candidate_2 = BB_PATH_ABD;
+				p_div->ant_candidate_3 = BB_PATH_ACD;
 			} else { /* use path BCD */
-				p_dm_path_div->num_candidate = 1;
-				phydm_dtp_fix_tx_path(p_dm, BB_PATH_BCD);
+				p_div->num_candidate = 1;
+				phydm_dtp_fix_tx_path(dm, BB_PATH_BCD);
 				return;
 			}
-		} else	if (p_dm_path_div->num_tx_path == 2) {
-			if (p_dm_path_div->is_path_a_exist) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_AB;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_AC;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_AD;
+		} else if (p_div->num_tx_path == 2) {
+			if (p_div->is_path_a_exist) {
+				p_div->ant_candidate_1 = BB_PATH_AB;
+				p_div->ant_candidate_2 = BB_PATH_AC;
+				p_div->ant_candidate_3 = BB_PATH_AD;
 			} else {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_BC;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_BD;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+				p_div->ant_candidate_1 = BB_PATH_BC;
+				p_div->ant_candidate_2 = BB_PATH_BD;
+				p_div->ant_candidate_3 = BB_PATH_CD;
 			}
 		}
 	} else {
-		/* 2 3 TX mode */
-		if (p_dm_path_div->num_tx_path == 3) { /* choose 3 ant form 4 */
-			if (p_dm_path_div->default_path == PATH_A) { /* choose 2 ant form 3 */
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_ACD;
-			} else if (p_dm_path_div->default_path == PATH_B) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_ABD;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
-			} else if (p_dm_path_div->default_path == PATH_C) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_ABC;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_ACD;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
-			} else if (p_dm_path_div->default_path == PATH_D) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_ABD;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_ACD;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_BCD;
+		/* @2 3 TX mode */
+		if (p_div->num_tx_path == 3) { /* @choose 3 ant form 4 */
+			if (p_div->default_path == PATH_A) {
+			/* @choose 2 ant form 3 */
+				p_div->ant_candidate_1 = BB_PATH_ABC;
+				p_div->ant_candidate_2 = BB_PATH_ABD;
+				p_div->ant_candidate_3 = BB_PATH_ACD;
+			} else if (p_div->default_path == PATH_B) {
+				p_div->ant_candidate_1 = BB_PATH_ABC;
+				p_div->ant_candidate_2 = BB_PATH_ABD;
+				p_div->ant_candidate_3 = BB_PATH_BCD;
+			} else if (p_div->default_path == PATH_C) {
+				p_div->ant_candidate_1 = BB_PATH_ABC;
+				p_div->ant_candidate_2 = BB_PATH_ACD;
+				p_div->ant_candidate_3 = BB_PATH_BCD;
+			} else if (p_div->default_path == PATH_D) {
+				p_div->ant_candidate_1 = BB_PATH_ABD;
+				p_div->ant_candidate_2 = BB_PATH_ACD;
+				p_div->ant_candidate_3 = BB_PATH_BCD;
 			}
 		}
 
-		/* 2 2 TX mode */
-		else if (p_dm_path_div->num_tx_path == 2) { /* choose 2 ant form 4 */
-			if (p_dm_path_div->default_path == PATH_A) { /* choose 2 ant form 3 */
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_AB;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_AC;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_AD;
-			} else if (p_dm_path_div->default_path == PATH_B) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_AB;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_BC;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_BD;
-			} else if (p_dm_path_div->default_path == PATH_C) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_AC;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_BC;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_CD;
-			} else if (p_dm_path_div->default_path == PATH_D) {
-				p_dm_path_div->ant_candidate_1 =  BB_PATH_AD;
-				p_dm_path_div->ant_candidate_2 =  BB_PATH_BD;
-				p_dm_path_div->ant_candidate_3 =  BB_PATH_CD;
+		/* @2 2 TX mode */
+		else if (p_div->num_tx_path == 2) { /* @choose 2 ant form 4 */
+			if (p_div->default_path == PATH_A) {
+			/* @choose 2 ant form 3 */
+				p_div->ant_candidate_1 = BB_PATH_AB;
+				p_div->ant_candidate_2 = BB_PATH_AC;
+				p_div->ant_candidate_3 = BB_PATH_AD;
+			} else if (p_div->default_path == PATH_B) {
+				p_div->ant_candidate_1 = BB_PATH_AB;
+				p_div->ant_candidate_2 = BB_PATH_BC;
+				p_div->ant_candidate_3 = BB_PATH_BD;
+			} else if (p_div->default_path == PATH_C) {
+				p_div->ant_candidate_1 = BB_PATH_AC;
+				p_div->ant_candidate_2 = BB_PATH_BC;
+				p_div->ant_candidate_3 = BB_PATH_CD;
+			} else if (p_div->default_path == PATH_D) {
+				p_div->ant_candidate_1 = BB_PATH_AD;
+				p_div->ant_candidate_2 = BB_PATH_BD;
+				p_div->ant_candidate_3 = BB_PATH_CD;
 			}
 		}
 	}
 }
 
-
-void
-phydm_dynamic_tx_path(
-	void	*p_dm_void
-)
+void phydm_dynamic_tx_path(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ODM_PATH_DIVERSITY_		*p_dm_path_div = &p_dm->dm_path_div;
-
-	struct sta_info	*p_entry;
-	u32	i;
-	u8	num_client = 0;
-	u8	h2c_parameter[6] = {0};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
 
+	struct sta_info *entry;
+	u32 i;
+	u8 num_client = 0;
+	u8 h2c_parameter[6] = {0};
 
-	if (!p_dm->is_linked) { /* is_linked==False */
-		PHYDM_DBG(p_dm, DBG_PATH_DIV, ("DTP_8814 [No Link!!!]\n"));
+	if (!dm->is_linked) { /* @is_linked==False */
+		PHYDM_DBG(dm, DBG_PATH_DIV, "DTP_8814 [No Link!!!]\n");
 
-		if (p_dm_path_div->is_become_linked == true) {
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" [Be disconnected]----->\n"));
-			p_dm_path_div->is_become_linked = p_dm->is_linked;
+		if (p_div->is_become_linked) {
+			PHYDM_DBG(dm, DBG_PATH_DIV, "[Be disconnected]---->\n");
+			p_div->is_become_linked = dm->is_linked;
 		}
 		return;
 	} else {
-		if (p_dm_path_div->is_become_linked == false) {
-			PHYDM_DBG(p_dm, DBG_PATH_DIV, (" [Be Linked !!!]----->\n"));
-			p_dm_path_div->is_become_linked = p_dm->is_linked;
+		if (!p_div->is_become_linked) {
+			PHYDM_DBG(dm, DBG_PATH_DIV, " [Be Linked !!!]----->\n");
+			p_div->is_become_linked = dm->is_linked;
 		}
 	}
 
-	/* 2 [period CTRL] */
-	if (p_dm_path_div->dtp_period >= 2)
-		p_dm_path_div->dtp_period = 0;
-	else {
-		/* PHYDM_DBG(p_dm,DBG_PATH_DIV, ("Phydm_Dynamic_Tx_Path_8814A()  Stay = (( %d ))\n",p_dm_path_div->dtp_period)); */
-		p_dm_path_div->dtp_period++;
+	/* @2 [period CTRL] */
+	if (p_div->dtp_period >= 2) {
+		p_div->dtp_period = 0;
+	} else {
+		p_div->dtp_period++;
 		return;
 	}
 
-
-	/* 2 [Fix path] */
-	if (p_dm->path_select != PHYDM_AUTO_PATH)
+	/* @2 [Fix path] */
+	if (dm->path_select != PHYDM_AUTO_PATH)
 		return;
 
-	/* 2 [Check Bfer] */
+/* @2 [Check Bfer] */
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 	{
-		enum beamforming_cap		beamform_cap = (p_dm->beamforming_info.beamform_cap);
+		enum beamforming_cap beamform_cap = (dm->beamforming_info.beamform_cap);
 
-		if (beamform_cap & BEAMFORMER_CAP) { /* BFmer On  &&   Div On->Div Off */
-			if (p_dm_path_div->fix_path_bfer == 0) {
-				PHYDM_DBG(p_dm, DBG_PATH_DIV, ("[ PathDiv : OFF ]   BFmer ==1\n"));
-				p_dm_path_div->fix_path_bfer = 1 ;
+		if (beamform_cap & BEAMFORMER_CAP) { /* @BFmer On  &&   Div On->Div Off */
+			if (p_div->fix_path_bfer == 0) {
+				PHYDM_DBG(dm, DBG_PATH_DIV,
+					  "[ PathDiv : OFF ]   BFmer ==1\n");
+				p_div->fix_path_bfer = 1;
 			}
 			return;
-		} else { /* BFmer Off   &&   Div Off->Div On */
-			if (p_dm_path_div->fix_path_bfer == 1) {
-				PHYDM_DBG(p_dm, DBG_PATH_DIV, ("[ PathDiv : ON ]   BFmer ==0\n"));
-				p_dm_path_div->fix_path_bfer = 0;
+		} else { /* @BFmer Off   &&   Div Off->Div On */
+			if (p_div->fix_path_bfer == 1) {
+				PHYDM_DBG(dm, DBG_PATH_DIV,
+					  "[ PathDiv : ON ]   BFmer ==0\n");
+				p_div->fix_path_bfer = 0;
 			}
 		}
 	}
 #endif
 #endif
 
-	if (p_dm_path_div->use_path_a_as_default_ant == 1) {
-		phydm_find_default_path(p_dm);
-		phydm_candidate_dtp_update(p_dm);
+	if (p_div->use_path_a_as_default_ant == 1) {
+		phydm_find_default_path(dm);
+		phydm_candidate_dtp_update(dm);
 	} else {
-		if (p_dm_path_div->phydm_dtp_state == PHYDM_DTP_INIT) {
-			phydm_find_default_path(p_dm);
-			phydm_candidate_dtp_update(p_dm);
-			p_dm_path_div->phydm_dtp_state = PHYDM_DTP_RUNNING_1;
+		if (p_div->phydm_dtp_state == PHYDM_DTP_INIT) {
+			phydm_find_default_path(dm);
+			phydm_candidate_dtp_update(dm);
+			p_div->phydm_dtp_state = PHYDM_DTP_RUNNING_1;
 		}
 
-		else	if (p_dm_path_div->phydm_dtp_state == PHYDM_DTP_RUNNING_1) {
-			p_dm_path_div->dtp_check_patha_counter++;
+		else if (p_div->phydm_dtp_state == PHYDM_DTP_RUNNING_1) {
+			p_div->dtp_check_patha_counter++;
 
-			if (p_dm_path_div->dtp_check_patha_counter >= NUM_RESET_DTP_PERIOD) {
-				p_dm_path_div->dtp_check_patha_counter = 0;
-				p_dm_path_div->phydm_dtp_state = PHYDM_DTP_INIT;
+			if (p_div->dtp_check_patha_counter >=
+			    NUM_RESET_DTP_PERIOD) {
+				p_div->dtp_check_patha_counter = 0;
+				p_div->phydm_dtp_state = PHYDM_DTP_INIT;
 			}
-			/* 2 Search space update */
+#if 0
+			/* @2 Search space update */
 			else {
-				/* 1.  find the worst candidate */
+				/* @1.  find the worst candidate */
 
 
-				/* 2. repalce the worst candidate */
+				/* @2. repalce the worst candidate */
 			}
+#endif
 		}
 	}
 
-	/* 2 Dynamic path Selection H2C */
+	/* @2 Dynamic path Selection H2C */
 
-	if (p_dm_path_div->num_candidate == 1)
+	if (p_div->num_candidate == 1) {
 		return;
-	else {
-		h2c_parameter[0] =  p_dm_path_div->num_candidate;
-		h2c_parameter[1] =  p_dm_path_div->num_tx_path;
-		h2c_parameter[2] =  p_dm_path_div->ant_candidate_1;
-		h2c_parameter[3] =  p_dm_path_div->ant_candidate_2;
-		h2c_parameter[4] =  p_dm_path_div->ant_candidate_3;
-
-		odm_fill_h2c_cmd(p_dm, PHYDM_H2C_DYNAMIC_TX_PATH, 6, h2c_parameter);
-	}
+	} else {
+		h2c_parameter[0] = p_div->num_candidate;
+		h2c_parameter[1] = p_div->num_tx_path;
+		h2c_parameter[2] = p_div->ant_candidate_1;
+		h2c_parameter[3] = p_div->ant_candidate_2;
+		h2c_parameter[4] = p_div->ant_candidate_3;
 
+		odm_fill_h2c_cmd(dm, PHYDM_H2C_DYNAMIC_TX_PATH, 6, h2c_parameter);
+	}
 }
 
-
-
-void
-phydm_dynamic_tx_path_init(
-	void	*p_dm_void
-)
+void phydm_dynamic_tx_path_init(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ODM_PATH_DIVERSITY_		*p_dm_path_div  = &(p_dm->dm_path_div);
-	struct _ADAPTER		*p_adapter = p_dm->adapter;
-	u8			search_space_2[NUM_CHOOSE2_FROM4] = {BB_PATH_AB, BB_PATH_AC, BB_PATH_AD, BB_PATH_BC, BB_PATH_BD, BB_PATH_CD };
-	u8			search_space_3[NUM_CHOOSE3_FROM4] = {BB_PATH_BCD, BB_PATH_ACD,  BB_PATH_ABD, BB_PATH_ABC};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	void *adapter = dm->adapter;
+	u8 search_space_2[NUM_CHOOSE2_FROM4] = {BB_PATH_AB, BB_PATH_AC, BB_PATH_AD, BB_PATH_BC, BB_PATH_BD, BB_PATH_CD};
+	u8 search_space_3[NUM_CHOOSE3_FROM4] = {BB_PATH_BCD, BB_PATH_ACD, BB_PATH_ABD, BB_PATH_ABC};
 
 #if ((DM_ODM_SUPPORT_TYPE == ODM_WIN) && USB_SWITCH_SUPPORT)
-	p_dm_path_div->is_u3_mode = (*p_dm->hub_usb_mode == 2) ? 1 : 0;
-	PHYDM_DBG(p_dm, DBG_PATH_DIV, ("[WIN USB] is_u3_mode = (( %d ))\n", p_dm_path_div->is_u3_mode));
+	p_div->is_u3_mode = (*dm->hub_usb_mode == 2) ? 1 : 0;
+	PHYDM_DBG(dm, DBG_PATH_DIV, "[WIN USB] is_u3_mode = (( %d ))\n",
+		  p_div->is_u3_mode);
 #else
-	p_dm_path_div->is_u3_mode = 1;
+	p_div->is_u3_mode = 1;
 #endif
-	PHYDM_DBG(p_dm, DBG_PATH_DIV, ("Dynamic TX path Init 8814\n"));
-
-	memcpy(&(p_dm_path_div->search_space_2[0]), &(search_space_2[0]), NUM_CHOOSE2_FROM4);
-	memcpy(&(p_dm_path_div->search_space_3[0]), &(search_space_3[0]), NUM_CHOOSE3_FROM4);
+	PHYDM_DBG(dm, DBG_PATH_DIV, "Dynamic TX path Init 8814\n");
 
-	p_dm_path_div->use_path_a_as_default_ant = 1;
-	p_dm_path_div->phydm_dtp_state = PHYDM_DTP_INIT;
-	p_dm->path_select = PHYDM_AUTO_PATH;
-	p_dm_path_div->phydm_path_div_type = PHYDM_4R_PATH_DIV;
+	memcpy(&p_div->search_space_2[0], &search_space_2[0],
+	       NUM_CHOOSE2_FROM4);
+	memcpy(&p_div->search_space_3[0], &search_space_3[0],
+	       NUM_CHOOSE3_FROM4);
 
+	p_div->use_path_a_as_default_ant = 1;
+	p_div->phydm_dtp_state = PHYDM_DTP_INIT;
+	dm->path_select = PHYDM_AUTO_PATH;
+	p_div->phydm_path_div_type = PHYDM_4R_PATH_DIV;
 
-	if (p_dm_path_div->is_u3_mode) {
-		p_dm_path_div->num_tx_path = 3;
-		phydm_dtp_fix_tx_path(p_dm, BB_PATH_BCD);/* 3TX  Set Init TX path*/
+	if (p_div->is_u3_mode) {
+		p_div->num_tx_path = 3;
+		phydm_dtp_fix_tx_path(dm, BB_PATH_BCD); /* @3TX  Set Init TX path*/
 
 	} else {
-		p_dm_path_div->num_tx_path = 2;
-		phydm_dtp_fix_tx_path(p_dm, BB_PATH_BC);/* 2TX // Set Init TX path*/
+		p_div->num_tx_path = 2;
+		phydm_dtp_fix_tx_path(dm, BB_PATH_BC); /* @2TX // Set Init TX path*/
 	}
-
 }
 
-
-void
-phydm_process_rssi_for_path_div(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	void			*p_pkt_info_void
-)
+void phydm_process_rssi_for_path_div_8814a(void *dm_void, void *phy_info_void,
+					   void *pkt_info_void)
 {
-	struct PHY_DM_STRUCT			*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_phyinfo_struct		*p_phy_info = (struct phydm_phyinfo_struct *)p_phy_info_void;
-	struct phydm_perpkt_info_struct	*p_pktinfo = (struct phydm_perpkt_info_struct *)p_pkt_info_void;
-	struct _ODM_PATH_DIVERSITY_			*p_dm_path_div  = &(p_dm->dm_path_div);
-
-	if (p_pktinfo->is_packet_to_self || p_pktinfo->is_packet_match_bssid) {
-		if (p_pktinfo->data_rate > ODM_RATE11M) {
-			if (p_dm_path_div->phydm_path_div_type == PHYDM_4R_PATH_DIV) {
-#if RTL8814A_SUPPORT
-				if (p_dm->support_ic_type & ODM_RTL8814A) {
-					p_dm_path_div->path_a_sum_all += p_phy_info->rx_mimo_signal_strength[0];
-					p_dm_path_div->path_a_cnt_all++;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct *phy_info = NULL;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
 
-					p_dm_path_div->path_b_sum_all += p_phy_info->rx_mimo_signal_strength[1];
-					p_dm_path_div->path_b_cnt_all++;
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
 
-					p_dm_path_div->path_c_sum_all += p_phy_info->rx_mimo_signal_strength[2];
-					p_dm_path_div->path_c_cnt_all++;
+	if (!(pktinfo->is_packet_to_self || pktinfo->is_packet_match_bssid))
+		return;
 
-					p_dm_path_div->path_d_sum_all += p_phy_info->rx_mimo_signal_strength[3];
-					p_dm_path_div->path_d_cnt_all++;
-				}
-#endif
-			} else {
-				p_dm_path_div->path_a_sum[p_pktinfo->station_id] += p_phy_info->rx_mimo_signal_strength[0];
-				p_dm_path_div->path_a_cnt[p_pktinfo->station_id]++;
+	if (pktinfo->data_rate <= ODM_RATE11M)
+		return;
 
-				p_dm_path_div->path_b_sum[p_pktinfo->station_id] += p_phy_info->rx_mimo_signal_strength[1];
-				p_dm_path_div->path_b_cnt[p_pktinfo->station_id]++;
-			}
-		}
-	}
+	if (p_div->phydm_path_div_type == PHYDM_4R_PATH_DIV) {
+		p_div->path_a_sum_all += phy_info->rx_mimo_signal_strength[0];
+		p_div->path_a_cnt_all++;
 
+		p_div->path_b_sum_all += phy_info->rx_mimo_signal_strength[1];
+		p_div->path_b_cnt_all++;
 
-}
+		p_div->path_c_sum_all += phy_info->rx_mimo_signal_strength[2];
+		p_div->path_c_cnt_all++;
 
-#endif /* #if RTL8814A_SUPPORT */
+		p_div->path_d_sum_all += phy_info->rx_mimo_signal_strength[3];
+		p_div->path_d_cnt_all++;
+	}
+}
 
-void
-odm_pathdiv_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void phydm_pathdiv_debug_8814a(void *dm_void, char input[][16], u32 *_used,
+			       char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ODM_PATH_DIVERSITY_			*p_dm_path_div  = &(p_dm->dm_path_div);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u32 dm_value[10] = {0};
+	u8 i, input_idx = 0;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
+			input_idx++;
+		}
+	}
 
-	p_dm->path_select = (dm_value[0] & 0xf);
-	PHYDM_SNPRINTF((output + used, out_len - used, "Path_select = (( 0x%x ))\n", p_dm->path_select));
+	if (input_idx == 0)
+		return;
 
-	/* 2 [Fix path] */
-	if (p_dm->path_select != PHYDM_AUTO_PATH) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "Trun on path  [%s%s%s%s]\n",
-				((p_dm->path_select) & 0x1) ? "A" : "",
-				((p_dm->path_select) & 0x2) ? "B" : "",
-				((p_dm->path_select) & 0x4) ? "C" : "",
-				((p_dm->path_select) & 0x8) ? "D" : ""));
+	dm->path_select = (u8)(dm_value[0] & 0xf);
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "Path_select = (( 0x%x ))\n", dm->path_select);
 
-		phydm_dtp_fix_tx_path(p_dm, p_dm->path_select);
-	} else
-		PHYDM_SNPRINTF((output + used, out_len - used, "%s\n", "Auto path"));
+	/* @2 [Fix path] */
+	if (dm->path_select != PHYDM_AUTO_PATH) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Turn on path  [%s%s%s%s]\n",
+			 ((dm->path_select) & 0x1) ? "A" : "",
+			 ((dm->path_select) & 0x2) ? "B" : "",
+			 ((dm->path_select) & 0x4) ? "C" : "",
+			 ((dm->path_select) & 0x8) ? "D" : "");
+
+		phydm_dtp_fix_tx_path(dm, dm->path_select);
+	} else {
+		PDM_SNPF(out_len, used, output + used, out_len - used, "%s\n",
+			 "Auto path");
+	}
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-#endif /*  #if(defined(CONFIG_PATH_DIVERSITY)) */
+#endif /* @#if RTL8814A_SUPPORT */
 
-void
-phydm_c2h_dtp_handler(
-	void	*p_dm_void,
-	u8   *cmd_buf,
-	u8	cmd_len
-)
+#if RTL8812A_SUPPORT
+void phydm_update_tx_path_8812a(void *dm_void, enum bb_path path)
 {
-#if (defined(CONFIG_PATH_DIVERSITY))
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ODM_PATH_DIVERSITY_		*p_dm_path_div  = &(p_dm->dm_path_div);
-
-	u8  macid = cmd_buf[0];
-	u8  target = cmd_buf[1];
-	u8  nsc_1 = cmd_buf[2];
-	u8  nsc_2 = cmd_buf[3];
-	u8  nsc_3 = cmd_buf[4];
-
-	PHYDM_DBG(p_dm, DBG_PATH_DIV, ("Target_candidate = (( %d ))\n", target));
-	/*
-	if( (nsc_1 >= nsc_2) &&  (nsc_1 >= nsc_3))
-	{
-		phydm_dtp_fix_tx_path(p_dm, p_dm_path_div->ant_candidate_1);
-	}
-	else	if( nsc_2 >= nsc_3)
-	{
-		phydm_dtp_fix_tx_path(p_dm, p_dm_path_div->ant_candidate_2);
-	}
-	else
-	{
-		phydm_dtp_fix_tx_path(p_dm, p_dm_path_div->ant_candidate_3);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+
+	if (p_div->default_tx_path != path) {
+		PHYDM_DBG(dm, DBG_PATH_DIV, "Need to Update Tx path\n");
+
+		if (path == BB_PATH_A) {
+			/*Tx by Reg*/
+			odm_set_bb_reg(dm, R_0x80c, 0xFFF0, 0x111);
+			/*Resp Tx by Txinfo*/
+			odm_set_bb_reg(dm, R_0x6d8, 0xc0, 1);
+		} else {
+			/*Tx by Reg*/
+			odm_set_bb_reg(dm, R_0x80c, 0xFFF0, 0x222);
+			 /*Resp Tx by Txinfo*/
+			odm_set_bb_reg(dm, R_0x6d8, 0xc0, 2);
+		}
 	}
-	*/
+	p_div->default_tx_path = path;
+
+	PHYDM_DBG(dm, DBG_PATH_DIV, "path=%s\n",
+		  (path == BB_PATH_A) ? "A" : "B");
+}
+
+void phydm_path_diversity_init_8812a(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u32 i;
+
+	odm_set_bb_reg(dm, R_0x80c, BIT(29), 1); /* Tx path from Reg */
+	odm_set_bb_reg(dm, R_0x80c, 0xFFF0, 0x111); /* Tx by Reg */
+	odm_set_bb_reg(dm, R_0x6d8, BIT(7) | BIT6, 1); /* Resp Tx by Txinfo */
+	phydm_set_tx_path_by_bb_reg(dm, RF_PATH_A);
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
+		p_div->path_sel[i] = 1; /* TxInfo default at path-A */
+}
 #endif
+
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_tx_path_diversity_init_jgr3(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u32 i;
+
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
+		p_div->path_sel[i] = BB_PATH_A; /* TxInfo default at path-A */
 }
 
-void
-odm_path_diversity(
-	void	*p_dm_void
-)
+void phydm_tx_by_mac_or_reg_jgr3(void *dm_void, enum phydm_path_ctrl ctrl)
 {
-#if (defined(CONFIG_PATH_DIVERSITY))
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (!(p_dm->support_ability & ODM_BB_PATH_DIV)) {
-		PHYDM_DBG(p_dm, DBG_PATH_DIV, ("Return: Not Support PathDiv\n"));
-		return;
+	if (ctrl == TX_PATH_BY_REG) {
+		odm_set_bb_reg(dm, R_0x1e24, BIT(16), 0);
+	} else {
+		odm_set_bb_reg(dm, R_0x1e24, BIT(16), 1);
 	}
+}
 
-#if RTL8812A_SUPPORT
+void phydm_set_resp_tx_path_by_fw(void *dm_void, u8 macid, enum bb_path path,
+				  boolean enable)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u8 h2c_para[6] = {0};
+	u8 path_map[4];
+	u8 num_enable_path = 0;
+	u8 n_tx_path_ctrl_map = 0;
+	u8 i = 0, n_sts = 0;
 
-	if (p_dm->support_ic_type & ODM_RTL8812)
-		odm_path_diversity_8812a(p_dm);
-	else
-#endif
+	/*Response TX is controlled in FW ctrl info*/
 
-#if RTL8814A_SUPPORT
-		if (p_dm->support_ic_type & ODM_RTL8814A)
-			phydm_dynamic_tx_path(p_dm);
-		else
-#endif
-		{}
+	PHYDM_DBG(dm, DBG_PATH_DIV, "[%s] =====>\n", __func__);
+
+	if (enable) {
+		n_tx_path_ctrl_map = path;
+
+		for (i = 0; i < 4; i++) {
+			path_map[i] = 0;
+			if (path & BIT(i))
+				num_enable_path++;
+		}
+
+		for (i = 0; i < 4; i++) {
+			if (path & BIT(i)) {
+				path_map[i] = n_sts;
+				n_sts++;
+
+				if (n_sts == num_enable_path)
+					break;
+			}
+		}
+	}
+
+	PHYDM_DBG(dm, DBG_PATH_DIV, "ctrl_map=0x%x Map[D:A]={%d, %d, %d, %d}\n",
+		  n_tx_path_ctrl_map,
+		  path_map[3], path_map[2], path_map[1], path_map[0]);
+
+	h2c_para[0] = macid;
+	h2c_para[1] = n_tx_path_ctrl_map;
+	h2c_para[2] = (path_map[3] << 6) | (path_map[2] << 4) |
+		      (path_map[1] << 2) | path_map[0];
+
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_DYNAMIC_TX_PATH, 6, h2c_para);
+}
 #endif
+
+void phydm_set_tx_path_by_bb_reg(void *dm_void, enum bb_path path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+
+	PHYDM_DBG(dm, DBG_PATH_DIV, "[%s] path=%s\n",
+		  __func__, (path == BB_PATH_A) ? "A" : "B");
+
+	switch (dm->support_ic_type) {
+	#if RTL8822C_SUPPORT
+	case ODM_RTL8822C:
+		phydm_config_tx_path_8822c(dm, path);
+		break;
+	#endif
+
+	#if RTL8812A_SUPPORT
+	case ODM_RTL8812:
+		phydm_update_tx_path_8812a(dm, path);
+		break;
+	#endif
+	default:
+		break;
+	}
 }
 
-void
-phydm_path_diversity_init(
-	void	*p_dm_void
-)
+u8 phydm_get_tx_path_txdesc(void *dm_void, u8 macid)
 {
-#if (defined(CONFIG_PATH_DIVERSITY))
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u8 rpt_val = 0;
 
-	/*p_dm->support_ability |= ODM_BB_PATH_DIV;*/
+	if (p_div->path_sel[macid] == BB_PATH_A)
+		rpt_val = 1;
+	else if (p_div->path_sel[macid] == BB_PATH_B)
+		rpt_val = 2;
 
-	if (*(p_dm->p_mp_mode) == true)
-		return;
+	return rpt_val;
+}
 
-	if (!(p_dm->support_ability & ODM_BB_PATH_DIV)) {
-		PHYDM_DBG(p_dm, DBG_PATH_DIV, ("Return: Not Support PathDiv\n"));
-		return;
+void phydm_tx_path_diversity_2ss(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	struct cmn_sta_info *sta;
+	enum bb_path default_path = BB_PATH_A, path = BB_PATH_A;
+	u32 rssi_a = 0, rssi_b = 0;
+	u32 local_max_rssi, min_rssi = 0xff;
+	u8 i = 0;
+
+	PHYDM_DBG(dm, DBG_PATH_DIV, "[%s] =======>\n", __func__);
+
+	#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		if (dm->is_one_entry_only)
+			phydm_tx_by_mac_or_reg_jgr3(dm, TX_PATH_BY_REG);
+		else
+			phydm_tx_by_mac_or_reg_jgr3(dm, TX_PATH_BY_DESC);
 	}
+	#endif
 
-#if RTL8812A_SUPPORT
-	if (p_dm->support_ic_type & ODM_RTL8812)
-		odm_path_diversity_init_8812a(p_dm);
-	else
-#endif
+	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta))
+			continue;
 
-#if RTL8814A_SUPPORT
-		if (p_dm->support_ic_type & ODM_RTL8814A)
-			phydm_dynamic_tx_path_init(p_dm);
+		/* 2 Caculate RSSI per path */
+		rssi_a = (p_div->path_a_cnt[i]) ?
+			 (p_div->path_a_sum[i] / p_div->path_a_cnt[i]) : 0;
+		rssi_b = (p_div->path_b_cnt[i]) ?
+			 (p_div->path_b_sum[i] / p_div->path_b_cnt[i]) : 0;
+
+		if (rssi_a == rssi_b)
+			path =  p_div->default_tx_path;
 		else
-#endif
-		{}
-#endif
-}
+			path = (rssi_a > rssi_b) ? BB_PATH_A : BB_PATH_B;
+
+		local_max_rssi = (rssi_a > rssi_b) ? rssi_a : rssi_b;
+
+		PHYDM_DBG(dm, DBG_PATH_DIV,
+			  "[%d]PathA sum=%d, cnt=%d, avg_rssi=%d\n",
+			  i, p_div->path_a_sum[i],
+			  p_div->path_a_cnt[i], rssi_a);
+		PHYDM_DBG(dm, DBG_PATH_DIV,
+			  "[%d]PathB sum=%d, cnt=%d, avg_rssi=%d\n",
+			  i, p_div->path_b_sum[i],
+			  p_div->path_b_cnt[i], rssi_b);
+
+		/*Select default Tx path */
+		if (local_max_rssi < min_rssi) {
+			min_rssi = local_max_rssi;
+			default_path = path;
+		}
 
+		if (p_div->path_sel[i] != path) {
+			p_div->path_sel[i] = path;
+			#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+			if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+				phydm_set_resp_tx_path_by_fw(dm, i, path, true);
+			#endif
+		}
 
+		p_div->path_a_cnt[i] = 0;
+		p_div->path_a_sum[i] = 0;
+		p_div->path_b_cnt[i] = 0;
+		p_div->path_b_sum[i] = 0;
+	}
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-/*
- * 2011/12/02 MH Copy from MP oursrc for temporarily test.
- *   */
-
-void
-odm_path_div_chk_ant_switch_callback(
-	struct timer_list		*p_timer
-)
-{
+	/* 2 Update default Tx path */
+	if (default_path != p_div->default_tx_path)
+		phydm_set_tx_path_by_bb_reg(dm, default_path);
 }
 
-void
-odm_path_div_chk_ant_switch_workitem_callback(
-	void            *p_context
-)
+void phydm_tx_path_diversity(void *dm_void)
 {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_PATH_DIV))
+		return;
+
+	switch (dm->support_ic_type) {
+	#if (RTL8822C_SUPPORT || RTL8812A_SUPPORT)
+	case ODM_RTL8812:
+	case ODM_RTL8822C:
+		phydm_tx_path_diversity_2ss(dm);
+		break;
+	#endif
+
+	#if RTL8814A_SUPPORT
+	case ODM_RTL8814A:
+		phydm_dynamic_tx_path(dm);
+		break;
+	#endif
+	}
 }
 
-void
-odm_cck_tx_path_diversity_callback(
-	struct timer_list		*p_timer
-)
+void phydm_tx_path_diversity_init(void *dm_void)
 {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (!(dm->support_ability & ODM_BB_PATH_DIV))
+		return;
+
+	switch (dm->support_ic_type) {
+	#if RTL8822C_SUPPORT
+	case ODM_RTL8822C:
+	phydm_tx_path_diversity_init_jgr3(dm);
+	break;
+	#endif
+
+	#if RTL8812A_SUPPORT
+	case ODM_RTL8812:
+	phydm_path_diversity_init_8812a(dm);
+	break;
+	#endif
+
+	#if RTL8814A_SUPPORT
+	case ODM_RTL8814A:
+	phydm_dynamic_tx_path_init(dm);
+	break;
+	#endif
+	}
 }
 
-void
-odm_cck_tx_path_diversity_work_item_callback(
-	void            *p_context
-)
+void phydm_process_rssi_for_path_div(void *dm_void, void *phy_info_void,
+				     void *pkt_info_void)
 {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct *phy_info = NULL;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u8 id = 0;
+
+	phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+
+	if (!(pktinfo->is_packet_to_self || pktinfo->is_packet_match_bssid))
+		return;
+
+	if (pktinfo->data_rate <= ODM_RATE11M)
+		return;
+
+	id = pktinfo->station_id;
+	p_div->path_a_sum[id] += phy_info->rx_mimo_signal_strength[0];
+	p_div->path_a_cnt[id]++;
+
+	p_div->path_b_sum[id] += phy_info->rx_mimo_signal_strength[1];
+	p_div->path_b_cnt[id]++;
 }
-u8
-odm_sw_ant_div_select_scan_chnl(
-	struct _ADAPTER	*adapter
-)
+
+void phydm_pathdiv_debug(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len)
 {
-	return	0;
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 val[10] = {0};
+	u8 i, input_idx = 0;
+
+	if (input_idx == 0)
+		return;
+
+	PHYDM_SSCANF(input[1], DCMD_HEX, &val[0]);
+	PHYDM_SSCANF(input[2], DCMD_HEX, &val[1]);
+
+	if ((strcmp(input[1], "-h") == 0)) {
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1:TX Ctrl Sig} {0:BB, 1:MAC}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{2:BB Default TX REG} {path}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{3:MAC DESC TX} {path} {macid}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{4:MAC Resp TX} {path} {macid}\n");
+	} else if (val[0] == 1) {
+		phydm_tx_by_mac_or_reg_jgr3(dm, (enum phydm_path_ctrl)val[1]);
+	} else if (val[0] == 2) {
+		phydm_set_tx_path_by_bb_reg(dm, (enum bb_path)val[1]);
+	} else if (val[0] == 3) {
+		p_div->path_sel[val[2]] = (enum bb_path)val[1];
+	} else if (val[0] == 4) {
+		phydm_set_resp_tx_path_by_fw(dm, (u8)val[2],
+					     (enum bb_path)val[1], true);
+	}
+
+	*_used = used;
+	*_out_len = out_len;
+#endif
 }
-void
-odm_sw_ant_div_construct_scan_chnl(
-	struct _ADAPTER	*adapter,
-	u8		scan_chnl
-)
+
+void phydm_c2h_dtp_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len)
 {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ODM_PATH_DIVERSITY_ *p_div = &dm->dm_path_div;
+
+	u8 macid = cmd_buf[0];
+	u8 target = cmd_buf[1];
+	u8 nsc_1 = cmd_buf[2];
+	u8 nsc_2 = cmd_buf[3];
+	u8 nsc_3 = cmd_buf[4];
+
+	PHYDM_DBG(dm, DBG_PATH_DIV, "Target_candidate = (( %d ))\n", target);
+/*@
+	if( (nsc_1 >= nsc_2) &&  (nsc_1 >= nsc_3))
+	{
+		phydm_dtp_fix_tx_path(dm, p_div->ant_candidate_1);
+	}
+	else	if( nsc_2 >= nsc_3)
+	{
+		phydm_dtp_fix_tx_path(dm, p_div->ant_candidate_2);
+	}
+	else
+	{
+		phydm_dtp_fix_tx_path(dm, p_div->ant_candidate_3);
+	}
+	*/
 }
 
-#endif	/*  #if (DM_ODM_SUPPORT_TYPE == ODM_WIN) */
+#endif /*  @#ifdef CONFIG_PATH_DIVERSITY */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.h
index 0db72997378a..e52e0da8ee03 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pathdiv.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,29 +9,39 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMPATHDIV_H__
-#define    __PHYDMPATHDIV_H__
-/*#define PATHDIV_VERSION "2.0" //2014.11.04*/
-#define PATHDIV_VERSION	"3.1" /*2015.07.29 by YuChen*/
+#ifndef __PHYDMPATHDIV_H__
+#define __PHYDMPATHDIV_H__
 
-#if (defined(CONFIG_PATH_DIVERSITY))
-#define USE_PATH_A_AS_DEFAULT_ANT   /* for 8814 dynamic TX path selection */
+#ifdef CONFIG_PATH_DIVERSITY
+#define PATHDIV_VERSION "4.0"
 
-#define	NUM_RESET_DTP_PERIOD 5
-#define	ANT_DECT_RSSI_TH 3
+#define USE_PATH_A_AS_DEFAULT_ANT /* @for 8814 dynamic TX path selection */
+
+#define NUM_RESET_DTP_PERIOD 5
+#define ANT_DECT_RSSI_TH 3
 
 #define PATH_A 1
 #define PATH_B 2
 #define PATH_C 3
 #define PATH_D 4
 
-#define PHYDM_AUTO_PATH	0
-#define PHYDM_FIX_PATH		1
+#define PHYDM_AUTO_PATH 0
+#define PHYDM_FIX_PATH 1
 
 #define NUM_CHOOSE2_FROM4 6
 #define NUM_CHOOSE3_FROM4 4
@@ -38,7 +49,6 @@
 enum phydm_dtp_state {
 	PHYDM_DTP_INIT = 1,
 	PHYDM_DTP_RUNNING_1
-
 };
 
 enum phydm_path_div_type {
@@ -46,16 +56,14 @@ enum phydm_path_div_type {
 	PHYDM_4R_PATH_DIV = 2
 };
 
-void
-phydm_process_rssi_for_path_div(
-	void			*p_dm_void,
-	void			*p_phy_info_void,
-	void			*p_pkt_info_void
-);
+enum phydm_path_ctrl {
+	TX_PATH_BY_REG = 0,
+	TX_PATH_BY_DESC = 1
+};
 
 struct _ODM_PATH_DIVERSITY_ {
-	u8	resp_tx_path;
-	u8	path_sel[ODM_ASSOCIATE_ENTRY_NUM];
+	enum bb_path default_tx_path;
+	enum bb_path path_sel[ODM_ASSOCIATE_ENTRY_NUM];
 	u32	path_a_sum[ODM_ASSOCIATE_ENTRY_NUM];
 	u32	path_b_sum[ODM_ASSOCIATE_ENTRY_NUM];
 	u16	path_a_cnt[ODM_ASSOCIATE_ENTRY_NUM];
@@ -90,205 +98,27 @@ struct _ODM_PATH_DIVERSITY_ {
 
 	u8	pre_tx_path;
 	u8	use_path_a_as_default_ant;
-	boolean is_path_a_exist;
+	boolean	is_path_a_exist;
 
 #endif
 };
 
+void phydm_set_tx_path_by_bb_reg(void *dm_void, u8 path);
 
-#endif /* #if(defined(CONFIG_PATH_DIVERSITY)) */
-
-void
-phydm_c2h_dtp_handler(
-	void	*p_dm_void,
-	u8   *cmd_buf,
-	u8	cmd_len
-);
-
-void
-phydm_path_diversity_init(
-	void	*p_dm_void
-);
-
-void
-odm_path_diversity(
-	void	*p_dm_void
-);
-
-void
-odm_pathdiv_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-
-
-/* 1 [OLD IC]-------------------------------------------------------------------------------- */
-
-
-
-
-
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-
-/* #define   PATHDIV_ENABLE	 1 */
-#define dm_path_div_rssi_check	odm_path_div_chk_per_pkt_rssi
-#define path_div_check_before_link8192c	odm_path_diversity_before_link92c
-
-
-
-
-struct _path_div_parameter_define_ {
-	u32 org_5g_rege30;
-	u32 org_5g_regc14;
-	u32 org_5g_regca0;
-	u32 swt_5g_rege30;
-	u32 swt_5g_regc14;
-	u32 swt_5g_regca0;
-	/* for 2G IQK information */
-	u32 org_2g_regc80;
-	u32 org_2g_regc4c;
-	u32 org_2g_regc94;
-	u32 org_2g_regc14;
-	u32 org_2g_regca0;
-
-	u32 swt_2g_regc80;
-	u32 swt_2g_regc4c;
-	u32 swt_2g_regc94;
-	u32 swt_2g_regc14;
-	u32 swt_2g_regca0;
-};
-
-void
-odm_path_diversity_init_92c(
-	struct _ADAPTER	*adapter
-);
-
-void
-odm_2t_path_diversity_init_92c(
-	struct _ADAPTER	*adapter
-);
-
-void
-odm_1t_path_diversity_init_92c(
-	struct _ADAPTER	*adapter
-);
-
-boolean
-odm_is_connected_92c(
-	struct _ADAPTER	*adapter
-);
-
-boolean
-odm_path_diversity_before_link92c(
-	/* struct _ADAPTER*	adapter */
-	struct PHY_DM_STRUCT		*p_dm
-);
-
-void
-odm_path_diversity_after_link_92c(
-	struct _ADAPTER	*adapter
-);
-
-void
-odm_set_resp_path_92c(
-	struct _ADAPTER	*adapter,
-	u8	default_resp_path
-);
-
-void
-odm_ofdm_tx_path_diversity_92c(
-	struct _ADAPTER	*adapter
-);
-
-void
-odm_cck_tx_path_diversity_92c(
-	struct _ADAPTER	*adapter
-);
-
-void
-odm_reset_path_diversity_92c(
-	struct _ADAPTER	*adapter
-);
-
-void
-odm_cck_tx_path_diversity_callback(
-	struct timer_list		*p_timer
-);
-
-void
-odm_cck_tx_path_diversity_work_item_callback(
-	void            *p_context
-);
-
-void
-odm_path_div_chk_ant_switch_callback(
-	struct timer_list		*p_timer
-);
-
-void
-odm_path_div_chk_ant_switch_workitem_callback(
-	void            *p_context
-);
-
-
-void
-odm_path_div_chk_ant_switch(
-	struct PHY_DM_STRUCT    *p_dm
-);
-
-void
-odm_cck_path_diversity_chk_per_pkt_rssi(
-	struct _ADAPTER		*adapter,
-	boolean			is_def_port,
-	boolean			is_match_bssid,
-	struct _WLAN_STA	*p_entry,
-	PRT_RFD			p_rfd,
-	u8			*p_desc
-);
-
-void
-odm_path_div_chk_per_pkt_rssi(
-	struct _ADAPTER		*adapter,
-	boolean			is_def_port,
-	boolean			is_match_bssid,
-	struct _WLAN_STA	*p_entry,
-	PRT_RFD			p_rfd
-);
-
-void
-odm_path_div_rest_after_link(
-	struct PHY_DM_STRUCT		*p_dm
-);
+u8 phydm_get_tx_path_txdesc(void *dm_void, u8 macid);
 
-void
-odm_fill_tx_path_in_txdesc(
-	struct _ADAPTER	*adapter,
-	PRT_TCB		p_tcb,
-	u8		*p_desc
-);
+void phydm_c2h_dtp_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len);
 
-void
-odm_path_div_init_92d(
-	struct PHY_DM_STRUCT	*p_dm
-);
+void phydm_tx_path_diversity_init(void *dm_void);
 
-u8
-odm_sw_ant_div_select_scan_chnl(
-	struct _ADAPTER	*adapter
-);
+void phydm_tx_path_diversity(void *dm_void);
 
-void
-odm_sw_ant_div_construct_scan_chnl(
-	struct _ADAPTER	*adapter,
-	u8		scan_chnl
-);
+void phydm_process_rssi_for_path_div(void *dm_void, void *phy_info_void,
+				     void *pkt_info_void);
 
-#endif       /* #if(DM_ODM_SUPPORT_TYPE & (ODM_WIN)) */
+void phydm_pathdiv_debug(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len);
 
+#endif /* @#ifdef CONFIG_PATH_DIVERSITY */
+#endif /* @#ifndef  __PHYDMPATHDIV_H__ */
 
-#endif		 /* #ifndef  __ODMPATHDIV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.c
index 02f9be755986..bcbaa0961de9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,229 +9,380 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-void
-phydm_rx_statistic_cal(
-	struct PHY_DM_STRUCT				*p_phydm,
-	u8									*p_phy_status,
-	struct phydm_perpkt_info_struct				*p_pktinfo
-)
+#ifdef PHYDM_COMPILE_MU
+u8 phydm_get_gid(struct dm_struct *dm, u8 *phy_status_inf)
 {
-#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-	struct _phy_status_rpt_jaguar2_type1	*p_phy_sta_rpt = (struct _phy_status_rpt_jaguar2_type1 *)p_phy_status;
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT)
+	struct phy_sts_rpt_jgr2_type1 *rpt_jgr2 = NULL;
 #endif
-	u8									date_rate = (p_pktinfo->data_rate & 0x7f);
-
-	if (date_rate <= ODM_RATE54M) {
+#ifdef PHYSTS_3RD_TYPE_SUPPORT
+	struct phy_sts_rpt_jgr3_type1 *rpt_jgr3 = NULL;
+#endif
+	u8 gid = 0;
 
-		p_phydm->phy_dbg_info.num_qry_legacy_pkt[date_rate]++;
-		/**/
-	} else if (date_rate <= ODM_RATEMCS31) {
+	if (dm->ic_phy_sts_type == PHYDM_PHYSTS_TYPE_1)
+		return 0;
 
-		p_phydm->phy_dbg_info.num_qry_ht_pkt[date_rate - ODM_RATEMCS0]++;
-		p_phydm->phy_dbg_info.ht_pkt_not_zero = true;
+	if ((*phy_status_inf & 0xf) != 1)
+		return 0;
 
+	switch (dm->ic_phy_sts_type) {
+	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT)
+	case PHYDM_PHYSTS_TYPE_2:
+		rpt_jgr2 = (struct phy_sts_rpt_jgr2_type1 *)phy_status_inf;
+		gid = rpt_jgr2->gid;
+		break;
+	#endif
+	#ifdef PHYSTS_3RD_TYPE_SUPPORT
+	case PHYDM_PHYSTS_TYPE_3:
+		rpt_jgr3 = (struct phy_sts_rpt_jgr3_type1 *)phy_status_inf;
+		gid = rpt_jgr3->gid;
+		break;
+	#endif
+	default:
+		break;
 	}
-	#if ODM_IC_11AC_SERIES_SUPPORT
-	else if (date_rate <= ODM_RATEVHTSS4MCS9) {
 
-		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-		if ((p_phy_sta_rpt->gid != 0) && (p_phy_sta_rpt->gid != 63) && (p_phydm->support_ic_type & ODM_IC_PHY_STATUE_NEW_TYPE)) {
+	return gid;
+}
+#endif
+
+void phydm_rx_statistic_cal(struct dm_struct *dm,
+			    struct phydm_phyinfo_struct *phy_info,
+			    u8 *phy_status_inf,
+			    struct phydm_perpkt_info_struct *pktinfo)
+{
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	u8 rate = (pktinfo->data_rate & 0x7f);
+	u8 bw_idx = phy_info->band_width;
+	u8 offset = 0;
+	u8 gid = 0;
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT || defined(PHYSTS_3RD_TYPE_SUPPORT))
+	u8 val = 0;
+#endif
+	#ifdef PHYDM_COMPILE_MU
+	u8 is_mu_pkt = 0;
+	#endif
+
+	if (rate <= ODM_RATE54M) {
+		dbg_i->num_qry_legacy_pkt[rate]++;
+	} else if (rate <= ODM_RATEMCS31) {
+		dbg_i->ht_pkt_not_zero = true;
+		offset = rate - ODM_RATEMCS0;
+
+		if (offset > (HT_RATE_NUM - 1))
+			offset = HT_RATE_NUM - 1;
+
+		if (dm->support_ic_type &
+		    (PHYSTS_2ND_TYPE_IC | PHYSTS_3RD_TYPE_IC)) {
+			if (bw_idx == *dm->band_width) {
+				dbg_i->num_qry_ht_pkt[offset]++;
 
-			p_phydm->phy_dbg_info.num_qry_mu_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
-			if (p_pktinfo->ppdu_cnt < 4) {
-				p_phydm->phy_dbg_info.num_of_ppdu[p_pktinfo->ppdu_cnt] = date_rate | BIT(7);
-				p_phydm->phy_dbg_info.gid_num[p_pktinfo->ppdu_cnt] = p_phy_sta_rpt->gid;
+			} else if (bw_idx == CHANNEL_WIDTH_20) {
+				dbg_i->num_qry_pkt_sc_20m[offset]++;
+				dbg_i->low_bw_20_occur = true;
 			}
+		} else {
+			dbg_i->num_qry_ht_pkt[offset]++;
+		}
+	}
+#if (ODM_IC_11AC_SERIES_SUPPORT || defined(PHYSTS_3RD_TYPE_SUPPORT))
+	else if (rate <= ODM_RATEVHTSS4MCS9) {
+		offset = rate - ODM_RATEVHTSS1MCS0;
+
+		if (offset > (VHT_RATE_NUM - 1))
+			offset = VHT_RATE_NUM - 1;
+
+		#ifdef PHYDM_COMPILE_MU
+		gid = phydm_get_gid(dm, phy_status_inf);
+
+		if (gid != 0 && gid != 63)
+			is_mu_pkt = true;
+
+		if (is_mu_pkt) {
+			#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT ||\
+			     (defined(PHYSTS_3RD_TYPE_SUPPORT)))
+			dbg_i->num_mu_vht_pkt[offset]++;
+			#else
+			dbg_i->num_qry_vht_pkt[offset]++; /*@for debug*/
+			#endif
 		} else
 		#endif
 		{
-			p_phydm->phy_dbg_info.num_qry_vht_pkt[date_rate - ODM_RATEVHTSS1MCS0]++;
-			p_phydm->phy_dbg_info.vht_pkt_not_zero = true;
-			#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-			if (p_pktinfo->ppdu_cnt < 4) {
-				p_phydm->phy_dbg_info.num_of_ppdu[p_pktinfo->ppdu_cnt] = date_rate;
-				p_phydm->phy_dbg_info.gid_num[p_pktinfo->ppdu_cnt] = p_phy_sta_rpt->gid;
+			dbg_i->vht_pkt_not_zero = true;
+
+			if (dm->support_ic_type &
+			    (PHYSTS_2ND_TYPE_IC | PHYSTS_3RD_TYPE_IC)) {
+				if (bw_idx == *dm->band_width) {
+					dbg_i->num_qry_vht_pkt[offset]++;
+
+				} else if (bw_idx == CHANNEL_WIDTH_20) {
+					dbg_i->num_qry_pkt_sc_20m[offset]++;
+					dbg_i->low_bw_20_occur = true;
+				} else {/*@if (bw_idx == CHANNEL_WIDTH_40)*/
+					dbg_i->num_qry_pkt_sc_40m[offset]++;
+					dbg_i->low_bw_40_occur = true;
+				}
+			} else {
+				dbg_i->num_qry_vht_pkt[offset]++;
 			}
+		}
+
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT ||\
+		     (defined(PHYSTS_3RD_TYPE_SUPPORT)))
+		if (pktinfo->ppdu_cnt < 4) {
+			val = rate;
+
+			#ifdef PHYDM_COMPILE_MU
+			if (is_mu_pkt)
+				val |= BIT(7);
 			#endif
+
+			dbg_i->num_of_ppdu[pktinfo->ppdu_cnt] = val;
+			dbg_i->gid_num[pktinfo->ppdu_cnt] = gid;
 		}
+		#endif
 	}
-	#endif
+#endif
 }
 
-void
-phydm_reset_phystatus_avg(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void phydm_reset_phystatus_avg(struct dm_struct *dm)
 {
-	struct phydm_phystatus_avg		*p_dbg_avg = &(p_dm->phy_dbg_info.phystatus_statistic_avg);
+	struct phydm_phystatus_avg *dbg_avg = NULL;
 
-	odm_memory_set(p_dm, &(p_dbg_avg->rssi_cck_avg), 0, sizeof(struct phydm_phystatus_avg));
+	dbg_avg = &dm->phy_dbg_info.phystatus_statistic_avg;
+	odm_memory_set(dm, &dbg_avg->rssi_cck_avg, 0,
+		       sizeof(struct phydm_phystatus_avg));
 }
 
-void
-phydm_reset_phystatus_statistic(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void phydm_reset_phystatus_statistic(struct dm_struct *dm)
 {
-	struct phydm_phystatus_statistic		*p_dbg_statistic = &(p_dm->phy_dbg_info.phystatus_statistic_info);
+	struct phydm_phystatus_statistic *dbg_s = NULL;
+
+	dbg_s = &dm->phy_dbg_info.physts_statistic_info;
 
-	odm_memory_set(p_dm, &(p_dbg_statistic->rssi_cck_sum), 0, sizeof(struct phydm_phystatus_statistic));
+	odm_memory_set(dm, &dbg_s->rssi_cck_sum, 0,
+		       sizeof(struct phydm_phystatus_statistic));
 }
 
-void
-phydm_avg_phystatus_index(
-	struct PHY_DM_STRUCT			*p_dm,
-	struct phydm_phyinfo_struct		*p_phy_info,
-	struct phydm_perpkt_info_struct			*p_pktinfo
-)
+void phydm_avg_phystatus_index(void *dm_void,
+			       struct phydm_phyinfo_struct *phy_info,
+			       struct phydm_perpkt_info_struct *pktinfo)
 {
-	u8	rate_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
-	struct phydm_phystatus_statistic		*p_dbg_statistic = &(p_dm->phy_dbg_info.phystatus_statistic_info);
-
-	if (p_pktinfo->data_rate <= ODM_RATE11M) {
-
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	struct phydm_phystatus_statistic *dbg_s = &dbg_i->physts_statistic_info;
+	u8 rssi[PHYSTS_PATH_NUM] = {0};
+	u8 evm[PHYSTS_PATH_NUM] = {0};
+	s8 snr[PHYSTS_PATH_NUM] = {0};
+	u32 size = PHYSTS_PATH_NUM; /*size of path=4*/
+	u16 size_th = PHY_HIST_SIZE - 1; /*size of threshold*/
+	u16 val = 0, intvl = 0;
+	u8 i = 0;
+
+	odm_move_memory(dm, rssi, phy_info->rx_mimo_signal_strength, size);
+	odm_move_memory(dm, evm, phy_info->rx_mimo_evm_dbm, size);
+	odm_move_memory(dm, snr, phy_info->rx_snr, size);
+
+	if (pktinfo->data_rate <= ODM_RATE11M) {
 		/*RSSI*/
-		p_dbg_statistic->rssi_cck_sum += p_phy_info->rx_mimo_signal_strength[0];
-		p_dbg_statistic->rssi_cck_cnt++;
-	} else if (p_pktinfo->data_rate <= ODM_RATE54M) {
-
-		/*evm*/
-		p_dbg_statistic->evm_ofdm_sum += p_phy_info->rx_mimo_evm_dbm[0];
+		dbg_s->rssi_cck_sum += rssi[0];
+		dbg_s->rssi_cck_cnt++;
+		return;
+	} else if (pktinfo->data_rate <= ODM_RATE54M) {
+		/*@evm*/
+		dbg_s->evm_ofdm_sum += evm[0];
 
 		/*SNR*/
-		p_dbg_statistic->snr_ofdm_sum += p_phy_info->rx_snr[0];
+		dbg_s->snr_ofdm_sum += snr[0];
 
 		/*RSSI*/
-		p_dbg_statistic->rssi_ofdm_sum += p_phy_info->rx_mimo_signal_strength[0];
-		p_dbg_statistic->rssi_ofdm_cnt++;
-	} else if (rate_ss == 1) {
+		dbg_s->rssi_ofdm_sum += rssi[0];
+		dbg_s->rssi_ofdm_cnt++;
 
-		/*evm*/
-		p_dbg_statistic->evm_1ss_sum += p_phy_info->rx_mimo_evm_dbm[0];
+		val = (u16)evm[0];
+		intvl = phydm_find_intrvl(dm, val, dbg_i->evm_hist_th, size_th);
+		dbg_s->evm_ofdm_hist[intvl]++;
 
-		/*SNR*/
-		p_dbg_statistic->snr_1ss_sum += p_phy_info->rx_snr[0];
+		val = (u16)snr[0];
+		intvl = phydm_find_intrvl(dm, val, dbg_i->snr_hist_th, size_th);
+		dbg_s->snr_ofdm_hist[intvl]++;
 
-		p_dbg_statistic->rssi_1ss_sum += p_phy_info->rx_mimo_signal_strength[0];
-		p_dbg_statistic->rssi_1ss_cnt++;
-	} else if (rate_ss == 2) {
-		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
-		/*evm*/
-		p_dbg_statistic->evm_2ss_sum[0] += p_phy_info->rx_mimo_evm_dbm[0];
-		p_dbg_statistic->evm_2ss_sum[1] += p_phy_info->rx_mimo_evm_dbm[1];
+	} else if (pktinfo->rate_ss == 1) {
+/*@===[1-SS]==================================================================*/
+		/*@evm*/
+		dbg_s->evm_1ss_sum += evm[0];
 
 		/*SNR*/
-		p_dbg_statistic->snr_2ss_sum[0] += p_phy_info->rx_snr[0];
-		p_dbg_statistic->snr_2ss_sum[1] += p_phy_info->rx_snr[1];
+		dbg_s->snr_1ss_sum += snr[0];
 
 		/*RSSI*/
-		p_dbg_statistic->rssi_2ss_sum[0] += p_phy_info->rx_mimo_signal_strength[0];
-		p_dbg_statistic->rssi_2ss_sum[1] += p_phy_info->rx_mimo_signal_strength[1];
-		p_dbg_statistic->rssi_2ss_cnt++;
-		#endif
-	} else if (rate_ss == 3) {
-		#if (defined(PHYDM_COMPILE_ABOVE_3SS))
-		/*evm*/
-		p_dbg_statistic->evm_3ss_sum[0] += p_phy_info->rx_mimo_evm_dbm[0];
-		p_dbg_statistic->evm_3ss_sum[1] += p_phy_info->rx_mimo_evm_dbm[1];
-		p_dbg_statistic->evm_3ss_sum[2] += p_phy_info->rx_mimo_evm_dbm[2];
+		dbg_s->rssi_1ss_sum += rssi[0];
 
-		/*SNR*/
-		p_dbg_statistic->snr_3ss_sum[0] += p_phy_info->rx_snr[0];
-		p_dbg_statistic->snr_3ss_sum[1] += p_phy_info->rx_snr[1];
-		p_dbg_statistic->snr_3ss_sum[2] += p_phy_info->rx_snr[2];
+		/*@EVM Histogram*/
+		val = (u16)evm[0];
+		intvl = phydm_find_intrvl(dm, val, dbg_i->evm_hist_th, size_th);
+		dbg_s->evm_1ss_hist[intvl]++;
 
-		/*RSSI*/
-		p_dbg_statistic->rssi_3ss_sum[0] += p_phy_info->rx_mimo_signal_strength[0];
-		p_dbg_statistic->rssi_3ss_sum[1] += p_phy_info->rx_mimo_signal_strength[1];
-		p_dbg_statistic->rssi_3ss_sum[2] += p_phy_info->rx_mimo_signal_strength[2];
-		p_dbg_statistic->rssi_3ss_cnt++;
+		/*SNR Histogram*/
+		val = (u16)snr[0];
+		intvl = phydm_find_intrvl(dm, val, dbg_i->snr_hist_th, size_th);
+		dbg_s->snr_1ss_hist[intvl]++;
+
+		dbg_s->rssi_1ss_cnt++;
+	} else if (pktinfo->rate_ss == 2) {
+/*@===[2-SS]==================================================================*/
+		#if (defined(PHYDM_COMPILE_ABOVE_2SS))
+		for (i = 0; i < pktinfo->rate_ss; i++) {
+			/*@evm*/
+			dbg_s->evm_2ss_sum[i] += evm[i];
+			/*SNR*/
+			dbg_s->snr_2ss_sum[i] += snr[i];
+			/*RSSI*/
+			dbg_s->rssi_2ss_sum[i] += rssi[i];
+			/*@EVM Histogram*/
+			val = (u16)evm[i];
+			intvl = phydm_find_intrvl(dm, val, dbg_i->evm_hist_th,
+						  size_th);
+			dbg_s->evm_2ss_hist[i][intvl]++;
+
+			/*SNR Histogram*/
+			val = (u16)snr[i];
+			intvl = phydm_find_intrvl(dm, val, dbg_i->snr_hist_th,
+						  size_th);
+			dbg_s->snr_2ss_hist[i][intvl]++;
+		}
+		dbg_s->rssi_2ss_cnt++;
+		#endif
+	} else if (pktinfo->rate_ss == 3) {
+/*@===[3-SS]==================================================================*/
+		#if (defined(PHYDM_COMPILE_ABOVE_3SS))
+		for (i = 0; i < pktinfo->rate_ss; i++) {
+			/*@evm*/
+			dbg_s->evm_3ss_sum[i] += evm[i];
+			/*SNR*/
+			dbg_s->snr_3ss_sum[i] += snr[i];
+			/*RSSI*/
+			dbg_s->rssi_3ss_sum[i] += rssi[i];
+			/*@EVM Histogram*/
+			val = (u16)evm[i];
+			intvl = phydm_find_intrvl(dm, val, dbg_i->evm_hist_th,
+						  size_th);
+			dbg_s->evm_3ss_hist[i][intvl]++;
+
+			/*SNR Histogram*/
+			val = (u16)snr[i];
+			intvl = phydm_find_intrvl(dm, val, dbg_i->snr_hist_th,
+						  size_th);
+			dbg_s->snr_3ss_hist[i][intvl]++;
+		}
+		dbg_s->rssi_3ss_cnt++;
 		#endif
-	} else if (rate_ss == 4) {
+	} else if (pktinfo->rate_ss == 4) {
+/*@===[4-SS]==================================================================*/
 		#if (defined(PHYDM_COMPILE_ABOVE_4SS))
-		/*evm*/
-		p_dbg_statistic->evm_4ss_sum[0] += p_phy_info->rx_mimo_evm_dbm[0];
-		p_dbg_statistic->evm_4ss_sum[1] += p_phy_info->rx_mimo_evm_dbm[1];
-		p_dbg_statistic->evm_4ss_sum[2] += p_phy_info->rx_mimo_evm_dbm[2];
-		p_dbg_statistic->evm_4ss_sum[3] += p_phy_info->rx_mimo_evm_dbm[3];
-
-		/*SNR*/
-		p_dbg_statistic->snr_4ss_sum[0] += p_phy_info->rx_snr[0];
-		p_dbg_statistic->snr_4ss_sum[1] += p_phy_info->rx_snr[1];
-		p_dbg_statistic->snr_4ss_sum[2] += p_phy_info->rx_snr[2];
-		p_dbg_statistic->snr_4ss_sum[3] += p_phy_info->rx_snr[3];
-
-		/*RSSI*/
-		p_dbg_statistic->rssi_4ss_sum[0] += p_phy_info->rx_mimo_signal_strength[0];
-		p_dbg_statistic->rssi_4ss_sum[1] += p_phy_info->rx_mimo_signal_strength[1];
-		p_dbg_statistic->rssi_4ss_sum[2] += p_phy_info->rx_mimo_signal_strength[2];
-		p_dbg_statistic->rssi_4ss_sum[3] += p_phy_info->rx_mimo_signal_strength[3];
-		p_dbg_statistic->rssi_4ss_cnt++;
+		for (i = 0; i < pktinfo->rate_ss; i++) {
+			/*@evm*/
+			dbg_s->evm_4ss_sum[i] += evm[i];
+			/*SNR*/
+			dbg_s->snr_4ss_sum[i] += snr[i];
+			/*RSSI*/
+			dbg_s->rssi_4ss_sum[i] += rssi[i];
+			/*@EVM Histogram*/
+			val = (u16)evm[i];
+			intvl = phydm_find_intrvl(dm, val, dbg_i->evm_hist_th,
+						  size_th);
+			dbg_s->evm_4ss_hist[i][intvl]++;
+
+			/*SNR Histogram*/
+			val = (u16)snr[i];
+			intvl = phydm_find_intrvl(dm, val, dbg_i->snr_hist_th,
+						  size_th);
+			dbg_s->snr_4ss_hist[i][intvl]++;
+		}
+		dbg_s->rssi_4ss_cnt++;
 		#endif
 	}
 }
 
-u8 phydm_get_signal_quality(
-	struct phydm_phyinfo_struct *p_phy_info,
-	struct PHY_DM_STRUCT *p_dm,
-	struct _phy_status_rpt_8192cd *p_phy_sta_rpt
-	)
+void phydm_avg_phystatus_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	u16 snr_hist_th[PHY_HIST_SIZE - 1] = {5, 8, 11, 14, 17, 20, 23, 26,
+					      29, 32, 35};
+	u16 evm_hist_th[PHY_HIST_SIZE - 1] = {5, 8, 11, 14, 17, 20, 23, 26,
+					      29, 32, 35};
+	u32 size = (PHY_HIST_SIZE - 1) * 2;
+
+	odm_move_memory(dm, dbg_i->snr_hist_th, snr_hist_th, size);
+	odm_move_memory(dm, dbg_i->evm_hist_th, evm_hist_th, size);
+}
+
+u8 phydm_get_signal_quality(struct phydm_phyinfo_struct *phy_info,
+			    struct dm_struct *dm,
+			    struct phy_status_rpt_8192cd *phy_sts)
 {
-	u8 SQ_rpt;
+	u8 sq_rpt;
 	u8 result = 0;
 
-	if (p_phy_info->rx_pwdb_all > 40 && !p_dm->is_in_hct_test)
+	if (phy_info->rx_pwdb_all > 40 && !dm->is_in_hct_test) {
 		result = 100;
-	else {
-		SQ_rpt = p_phy_sta_rpt->cck_sig_qual_ofdm_pwdb_all;
+	} else {
+		sq_rpt = phy_sts->cck_sig_qual_ofdm_pwdb_all;
 
-		if (SQ_rpt > 64)
+		if (sq_rpt > 64)
 			result = 0;
-		else if (SQ_rpt < 20)
+		else if (sq_rpt < 20)
 			result = 100;
 		else
-			result = ((64 - SQ_rpt) * 100) / 44;
-
+			result = ((64 - sq_rpt) * 100) / 44;
 	}
 
 	return result;
 }
 
-u8
-phydm_query_rx_pwr_percentage(
-	s8		ant_power
-)
+u8 phydm_pwr_2_percent(s8 ant_power)
 {
-	if ((ant_power <= -100) || (ant_power >= 20))
-		return	0;
+	if ((ant_power <= -100) || ant_power >= 20)
+		return 0;
 	else if (ant_power >= 0)
-		return	100;
+		return 100;
 	else
 		return 100 + ant_power;
 }
 
+#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
 
-s32
-phydm_signal_scale_mapping_92c_series(
-	struct PHY_DM_STRUCT *p_dm,
-	s32 curr_sig
-)
+#if 0 /*(DM_ODM_SUPPORT_TYPE == ODM_CE)*/
+s32 phydm_signal_scale_mapping_92c_series(struct dm_struct *dm, s32 curr_sig)
 {
 	s32 ret_sig = 0;
+
 #if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-	if (p_dm->support_interface  == ODM_ITRF_PCIE) {
+	if (dm->support_interface == ODM_ITRF_PCIE) {
 		/* step 1. Scale mapping. */
 		if (curr_sig >= 61 && curr_sig <= 100)
 			ret_sig = 90 + ((curr_sig - 60) / 4);
@@ -256,7 +408,8 @@ phydm_signal_scale_mapping_92c_series(
 #endif
 
 #if ((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-	if ((p_dm->support_interface  == ODM_ITRF_USB) || (p_dm->support_interface  == ODM_ITRF_SDIO)) {
+	if (dm->support_interface == ODM_ITRF_USB ||
+	    dm->support_interface == ODM_ITRF_SDIO) {
 		if (curr_sig >= 51 && curr_sig <= 100)
 			ret_sig = 100;
 		else if (curr_sig >= 41 && curr_sig <= 50)
@@ -279,204 +432,268 @@ phydm_signal_scale_mapping_92c_series(
 	return ret_sig;
 }
 
-s32
-phydm_signal_scale_mapping(
-	struct PHY_DM_STRUCT *p_dm,
-	s32 curr_sig
-)
+s32 phydm_signal_scale_mapping(struct dm_struct *dm, s32 curr_sig)
 {
 #ifdef CONFIG_SIGNAL_SCALE_MAPPING
-		return phydm_signal_scale_mapping_92c_series(p_dm, curr_sig);
+	return phydm_signal_scale_mapping_92c_series(dm, curr_sig);
 #else
-		return curr_sig;
+	return curr_sig;
+#endif
+}
 #endif
 
+void phydm_process_signal_strength(struct dm_struct *dm,
+				   struct phydm_phyinfo_struct *phy_info,
+				   struct phydm_perpkt_info_struct *pktinfo)
+{
+	u8 avg_rssi = 0, tmp_rssi = 0, best_rssi = 0, second_rssi = 0;
+	u8 ss = 0; /*signal strenth after scale mapping*/
+	u8 pwdb = phy_info->rx_pwdb_all;
+	u8 i;
+
+	/*use the best two RSSI only*/
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		tmp_rssi = phy_info->rx_mimo_signal_strength[i];
+
+		/*@Get the best two RSSI*/
+		if (tmp_rssi > best_rssi && tmp_rssi > second_rssi) {
+			second_rssi = best_rssi;
+			best_rssi = tmp_rssi;
+		} else if (tmp_rssi > second_rssi && tmp_rssi <= best_rssi) {
+			second_rssi = tmp_rssi;
+		}
+	}
+
+	if (best_rssi == 0)
+		return;
+
+	if (pktinfo->rate_ss == 1)
+		avg_rssi = best_rssi;
+	else
+		avg_rssi = (best_rssi + second_rssi) >> 1;
+
+	if (dm->support_ic_type & PHYSTS_3RD_TYPE_IC) {
+	#ifdef PHYSTS_3RD_TYPE_SUPPORT
+		/* Update signal strength to UI,
+		 * and phy_info->rx_pwdb_all is the maximum RSSI of all path
+		 */
+		#if 1 /*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+		ss = SignalScaleProc(dm->adapter, pwdb, false, false);
+		#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		ss = (u8)phydm_signal_scale_mapping(dm, pwdb);
+		#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+		ss = (u8)phydm_signal_scale_mapping(dm, pwdb);
+		#endif
+
+	#endif
+	} else if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+	#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT)
+		/* Update signal strength to UI,
+		 * and phy_info->rx_pwdb_all is the maximum RSSI of all path
+		 */
+		#if 1 /*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+		ss = SignalScaleProc(dm->adapter, pwdb, false, false);
+		#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		ss = (u8)phydm_signal_scale_mapping(dm, pwdb);
+		#endif
+
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+	#if ODM_IC_11AC_SERIES_SUPPORT
+		if (pktinfo->is_cck_rate)
+			#if 1/*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+			ss = SignalScaleProc(dm->adapter, pwdb, 0, 1);
+			#else
+			ss = (u8)phydm_signal_scale_mapping(dm, pwdb);
+			#endif
+		else
+			#if 1 /*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+			ss = SignalScaleProc(dm->adapter, avg_rssi, 0, 1);
+			#else
+			ss = (u8)phydm_signal_scale_mapping(dm, avg_rssi);
+			#endif
+	#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+	#if ODM_IC_11N_SERIES_SUPPORT
+		if (pktinfo->is_cck_rate)
+			#if 1/*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+			ss = SignalScaleProc(dm->adapter, pwdb, 1, 1);
+			#else
+			ss = (u8)phydm_signal_scale_mapping(dm, pwdb);
+			#endif
+		else
+			#if 1 /*(DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+			ss = SignalScaleProc(dm->adapter, avg_rssi, 1, 0);
+			#else
+			ss = (u8)phydm_signal_scale_mapping(dm, avg_rssi);
+			#endif
+	#endif
+	}
+	phy_info->signal_strength = ss;
 }
+#endif
 
 #if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-static u8 phydm_sq_patch_rt_cid_819x_lenovo(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		is_cck_rate,
-	u8		PWDB_ALL,
-	u8		path,
-	u8		RSSI
-)
+static u8 phydm_sq_patch_lenovo(
+	struct dm_struct *dm,
+	u8 is_cck_rate,
+	u8 pwdb_all,
+	u8 path,
+	u8 RSSI)
 {
-	u8	SQ = 0;
+	u8 sq = 0;
 
 	if (is_cck_rate) {
-
-		if (IS_HARDWARE_TYPE_8192E(p_dm->adapter)) {
-
-			/*  */
-			/* <Roger_Notes> Expected signal strength and bars indication at Lenovo lab. 2013.04.11 */
-			/* 802.11n, 802.11b, 802.11g only at channel 6 */
-			/*  */
-			/*		Attenuation (dB)	OS Signal Bars	RSSI by Xirrus (dBm) */
-			/*			50				5			-49 */
-			/*			55				5			-49 */
-			/*			60				5			-50 */
-			/*			65				5			-51 */
-			/*			70				5			-52 */
-			/*			75				5			-54 */
-			/*			80				5			-55 */
-			/*			85				4			-60 */
-			/*			90				3			-63 */
-			/*			95				3			-65 */
-			/*			100				2			-67 */
-			/*			102				2			-67 */
-			/*			104				1			-70 */
-			/*  */
-
-			if (PWDB_ALL >= 50)
-				SQ = 100;
-			else if (PWDB_ALL >= 35 && PWDB_ALL < 50)
-				SQ = 80;
-			else if (PWDB_ALL >= 31 && PWDB_ALL < 35)
-				SQ = 60;
-			else if (PWDB_ALL >= 22 && PWDB_ALL < 31)
-				SQ = 40;
-			else if (PWDB_ALL >= 18 && PWDB_ALL < 22)
-				SQ = 20;
+		if (dm->support_ic_type & ODM_RTL8192E) {
+/*@
+ * <Roger_Notes>
+ * Expected signal strength and bars indication at Lenovo lab. 2013.04.11
+ * 802.11n, 802.11b, 802.11g only at channel 6
+ *
+ *	Attenuation (dB)	OS Signal Bars	RSSI by Xirrus (dBm)
+ *		50				5			-49
+ *		55				5			-49
+ *		60				5			-50
+ *		65				5			-51
+ *		70				5			-52
+ *		75				5			-54
+ *		80				5			-55
+ *		85				4			-60
+ *		90				3			-63
+ *		95				3			-65
+ *		100				2			-67
+ *		102				2			-67
+ *		104				1			-70
+ */
+			if (pwdb_all >= 50)
+				sq = 100;
+			else if (pwdb_all >= 35 && pwdb_all < 50)
+				sq = 80;
+			else if (pwdb_all >= 31 && pwdb_all < 35)
+				sq = 60;
+			else if (pwdb_all >= 22 && pwdb_all < 31)
+				sq = 40;
+			else if (pwdb_all >= 18 && pwdb_all < 22)
+				sq = 20;
 			else
-				SQ = 10;
+				sq = 10;
 		} else {
-			if (PWDB_ALL >= 50)
-				SQ = 100;
-			else if (PWDB_ALL >= 35 && PWDB_ALL < 50)
-				SQ = 80;
-			else if (PWDB_ALL >= 22 && PWDB_ALL < 35)
-				SQ = 60;
-			else if (PWDB_ALL >= 18 && PWDB_ALL < 22)
-				SQ = 40;
+			if (pwdb_all >= 50)
+				sq = 100;
+			else if (pwdb_all >= 35 && pwdb_all < 50)
+				sq = 80;
+			else if (pwdb_all >= 22 && pwdb_all < 35)
+				sq = 60;
+			else if (pwdb_all >= 18 && pwdb_all < 22)
+				sq = 40;
 			else
-				SQ = 10;
+				sq = 10;
 		}
 
 	} else {
 		/* OFDM rate */
 
-		if (IS_HARDWARE_TYPE_8192E(p_dm->adapter)) {
+		if (dm->support_ic_type & ODM_RTL8192E) {
 			if (RSSI >= 45)
-				SQ = 100;
+				sq = 100;
 			else if (RSSI >= 22 && RSSI < 45)
-				SQ = 80;
+				sq = 80;
 			else if (RSSI >= 18 && RSSI < 22)
-				SQ = 40;
+				sq = 40;
 			else
-				SQ = 20;
+				sq = 20;
 		} else {
 			if (RSSI >= 45)
-				SQ = 100;
+				sq = 100;
 			else if (RSSI >= 22 && RSSI < 45)
-				SQ = 80;
+				sq = 80;
 			else if (RSSI >= 18 && RSSI < 22)
-				SQ = 40;
+				sq = 40;
 			else
-				SQ = 20;
+				sq = 20;
 		}
 	}
-
-	RT_TRACE(COMP_DBG, DBG_TRACE, ("is_cck_rate(%#d), PWDB_ALL(%#d), RSSI(%#d), SQ(%#d)\n", is_cck_rate, PWDB_ALL, RSSI, SQ));
-
-
-	return SQ;
+	return sq;
 }
 
 static u8 phydm_sq_patch_rt_cid_819x_acer(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		is_cck_rate,
-	u8		PWDB_ALL,
-	u8		path,
-	u8		RSSI
-)
+	struct dm_struct *dm,
+	u8 is_cck_rate,
+	u8 pwdb_all,
+	u8 path,
+	u8 RSSI)
 {
-	u8	SQ = 0;
+	u8 sq = 0;
 
 	if (is_cck_rate) {
-
-		RT_TRACE(COMP_DBG, DBG_WARNING, ("odm_SQ_process_patch_RT_Acer\n"));
-
 #if OS_WIN_FROM_WIN8(OS_VERSION)
-
-		if (PWDB_ALL >= 50)
-			SQ = 100;
-		else if (PWDB_ALL >= 35 && PWDB_ALL < 50)
-			SQ = 80;
-		else if (PWDB_ALL >= 30 && PWDB_ALL < 35)
-			SQ = 60;
-		else if (PWDB_ALL >= 25 && PWDB_ALL < 30)
-			SQ = 40;
-		else if (PWDB_ALL >= 20 && PWDB_ALL < 25)
-			SQ = 20;
+		if (pwdb_all >= 50)
+			sq = 100;
+		else if (pwdb_all >= 35 && pwdb_all < 50)
+			sq = 80;
+		else if (pwdb_all >= 30 && pwdb_all < 35)
+			sq = 60;
+		else if (pwdb_all >= 25 && pwdb_all < 30)
+			sq = 40;
+		else if (pwdb_all >= 20 && pwdb_all < 25)
+			sq = 20;
 		else
-			SQ = 10;
+			sq = 10;
 #else
-		if (PWDB_ALL >= 50)
-			SQ = 100;
-		else if (PWDB_ALL >= 35 && PWDB_ALL < 50)
-			SQ = 80;
-		else if (PWDB_ALL >= 30 && PWDB_ALL < 35)
-			SQ = 60;
-		else if (PWDB_ALL >= 25 && PWDB_ALL < 30)
-			SQ = 40;
-		else if (PWDB_ALL >= 20 && PWDB_ALL < 25)
-			SQ = 20;
+		if (pwdb_all >= 50)
+			sq = 100;
+		else if (pwdb_all >= 35 && pwdb_all < 50)
+			sq = 80;
+		else if (pwdb_all >= 30 && pwdb_all < 35)
+			sq = 60;
+		else if (pwdb_all >= 25 && pwdb_all < 30)
+			sq = 40;
+		else if (pwdb_all >= 20 && pwdb_all < 25)
+			sq = 20;
 		else
-			SQ = 10;
+			sq = 10;
 
-		if (PWDB_ALL == 0) /* Abnormal case, do not indicate the value above 20 on Win7 */
-			SQ = 20;
+		/* @Abnormal case, do not indicate the value above 20 on Win7 */
+		if (pwdb_all == 0)
+			sq = 20;
 #endif
 
-
-
 	} else {
 		/* OFDM rate */
-
-		if (IS_HARDWARE_TYPE_8192E(p_dm->adapter)) {
+		if (dm->support_ic_type & ODM_RTL8192E) {
 			if (RSSI >= 45)
-				SQ = 100;
+				sq = 100;
 			else if (RSSI >= 22 && RSSI < 45)
-				SQ = 80;
+				sq = 80;
 			else if (RSSI >= 18 && RSSI < 22)
-				SQ = 40;
+				sq = 40;
 			else
-				SQ = 20;
+				sq = 20;
 		} else {
 			if (RSSI >= 35)
-				SQ = 100;
+				sq = 100;
 			else if (RSSI >= 30 && RSSI < 35)
-				SQ = 80;
+				sq = 80;
 			else if (RSSI >= 25 && RSSI < 30)
-				SQ = 40;
+				sq = 40;
 			else
-				SQ = 20;
+				sq = 20;
 		}
 	}
-
-	RT_TRACE(COMP_DBG, DBG_LOUD, ("is_cck_rate(%#d), PWDB_ALL(%#d), RSSI(%#d), SQ(%#d)\n", is_cck_rate, PWDB_ALL, RSSI, SQ));
-
-
-	return SQ;
+	return sq;
 }
 #endif
 
 static u8
-phydm_evm_db_to_percentage(
-	s8 value
-)
+phydm_evm_2_percent(s8 value)
 {
-	/*  */
-	/* -33dB~0dB to 0%~99% */
-	/*  */
+	/* @-33dB~0dB to 0%~99% */
 	s8 ret_val;
 
 	ret_val = value;
 	ret_val /= 2;
 
-	/*dbg_print("value=%d\n", value);*/
-	/*ODM_RT_DISP(FRX, RX_PHY_SQ, ("EVMdbToPercentage92C value=%d / %x\n", ret_val, ret_val));*/
+/*@dbg_print("value=%d\n", value);*/
 #ifdef ODM_EVM_ENHANCE_ANTDIV
 	if (ret_val >= 0)
 		ret_val = 0;
@@ -504,1710 +721,2128 @@ phydm_evm_db_to_percentage(
 }
 
 static u8
-phydm_evm_dbm_jaguar_series(
-	s8 value
-)
+phydm_evm_dbm(s8 value)
 {
 	s8 ret_val = value;
 
-	/* -33dB~0dB to 33dB ~ 0dB */
+	/* @-33dB~0dB to 33dB ~ 0dB */
 	if (ret_val == -128)
 		ret_val = 127;
 	else if (ret_val < 0)
 		ret_val = 0 - ret_val;
 
-	ret_val  = ret_val >> 1;
+	ret_val = ret_val >> 1;
 	return (u8)ret_val;
 }
 
 static s16
-phydm_cfo(
-	s8 value
-)
+phydm_cfo(s8 value)
 {
-	s16  ret_val;
+	s16 ret_val;
 
 	if (value < 0) {
 		ret_val = 0 - value;
-		ret_val = (ret_val << 1) + (ret_val >> 1) ;  /* *2.5~=312.5/2^7 */
-		ret_val = ret_val | BIT(12);  /* set bit12 as 1 for negative cfo */
+		ret_val = (ret_val << 1) + (ret_val >> 1); /*@2.5~=312.5/2^7 */
+		ret_val = ret_val | BIT(12); /*set bit12 as 1 for negative cfo*/
 	} else {
 		ret_val = value;
-		ret_val = (ret_val << 1) + (ret_val >> 1) ; /* *2.5~=312.5/2^7 */
+		ret_val = (ret_val << 1) + (ret_val >> 1); /* @*2.5~=312.5/2^7*/
 	}
 	return ret_val;
 }
 
-s8
-phydm_cck_rssi_convert(
-	struct PHY_DM_STRUCT	*p_dm,
-	u16		lna_idx,
-	u8		vga_idx
-)
+s8 phydm_cck_rssi_convert(struct dm_struct *dm, u16 lna_idx, u8 vga_idx)
 {
-	return (p_dm->cck_lna_gain_table[lna_idx] - (vga_idx << 1));
+	/*@phydm_get_cck_rssi_table_from_reg*/
+	return (dm->cck_lna_gain_table[lna_idx] - (vga_idx << 1));
 }
 
-void
-phydm_get_cck_rssi_table_from_reg(
-	struct PHY_DM_STRUCT	*p_dm
-)
+void phydm_get_cck_rssi_table_from_reg(struct dm_struct *dm)
 {
-	u8	used_lna_idx_tmp;
-	u32	reg_0xa80 = 0x7431, reg_0xabc = 0xcbe5edfd; /*example: {-53, -43, -33, -27, -19, -13, -3, 1}*/ /*{0xCB, 0xD5, 0xDF, 0xE5, 0xED, 0xF3, 0xFD, 0x2}*/
-	u8	i;
+	u8 used_lna_idx_tmp;
+	u32 reg_0xa80 = 0x7431, reg_0xabc = 0xcbe5edfd;
+	u32 val = 0;
+	u8 i;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("CCK LNA Gain table init\n"));
+	/*@example: {-53, -43, -33, -27, -19, -13, -3, 1}*/
+	/*@{0xCB, 0xD5, 0xDF, 0xE5, 0xED, 0xF3, 0xFD, 0x2}*/
 
-	if (!(p_dm->support_ic_type & (ODM_RTL8197F)))
+	PHYDM_DBG(dm, ODM_COMP_INIT, "CCK LNA Gain table init\n");
+
+	if (!(dm->support_ic_type & (ODM_RTL8197F)))
 		return;
 
-	reg_0xa80 = odm_get_bb_reg(p_dm, 0xa80, 0xFFFF);
-	reg_0xabc = odm_get_bb_reg(p_dm, 0xabc, MASKDWORD);
+	reg_0xa80 = odm_get_bb_reg(dm, R_0xa80, 0xFFFF);
+	reg_0xabc = odm_get_bb_reg(dm, R_0xabc, MASKDWORD);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("reg_0xa80 = 0x%x\n", reg_0xa80));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("reg_0xabc = 0x%x\n", reg_0xabc));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "reg_0xa80 = 0x%x\n", reg_0xa80);
+	PHYDM_DBG(dm, ODM_COMP_INIT, "reg_0xabc = 0x%x\n", reg_0xabc);
 
 	for (i = 0; i <= 3; i++) {
-		used_lna_idx_tmp = (u8)((reg_0xa80 >> (4*i)) & 0x7);
-		p_dm->cck_lna_gain_table[used_lna_idx_tmp] = (s8)((reg_0xabc >> (8*i)) & 0xff);
+		used_lna_idx_tmp = (u8)((reg_0xa80 >> (4 * i)) & 0x7);
+		val = (reg_0xabc >> (8 * i)) & 0xff;
+		dm->cck_lna_gain_table[used_lna_idx_tmp] = (s8)val;
 	}
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("cck_lna_gain_table = {%d,%d,%d,%d,%d,%d,%d,%d}\n",
-		p_dm->cck_lna_gain_table[0],
-		p_dm->cck_lna_gain_table[1],
-		p_dm->cck_lna_gain_table[2],
-		p_dm->cck_lna_gain_table[3],
-		p_dm->cck_lna_gain_table[4],
-		p_dm->cck_lna_gain_table[5],
-		p_dm->cck_lna_gain_table[6],
-		p_dm->cck_lna_gain_table[7]));
-
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "cck_lna_gain_table = {%d,%d,%d,%d,%d,%d,%d,%d}\n",
+		  dm->cck_lna_gain_table[0], dm->cck_lna_gain_table[1],
+		  dm->cck_lna_gain_table[2], dm->cck_lna_gain_table[3],
+		  dm->cck_lna_gain_table[4], dm->cck_lna_gain_table[5],
+		  dm->cck_lna_gain_table[6], dm->cck_lna_gain_table[7]);
 }
 
-u8
-phydm_rate_to_num_ss(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			data_rate
-)
-{
-	u8	num_ss = 1;
-
-	if (data_rate  <= ODM_RATE54M)
-		num_ss = 1;
-	else if (data_rate  <= ODM_RATEMCS31)
-		num_ss = ((data_rate  - ODM_RATEMCS0) >> 3) + 1;
-	else if (data_rate  <= ODM_RATEVHTSS1MCS9)
-		num_ss = 1;
-	else if (data_rate  <= ODM_RATEVHTSS2MCS9)
-		num_ss = 2;
-	else if (data_rate  <= ODM_RATEVHTSS3MCS9)
-		num_ss = 3;
-	else if (data_rate  <= ODM_RATEVHTSS4MCS9)
-		num_ss = 4;
-
-	return num_ss;
-}
-
-
-
-#if (RTL8703B_SUPPORT == 1)
-s8
-phydm_cck_rssi_8703B(
-	u16	LNA_idx,
-	u8	VGA_idx
-)
+s8 phydm_get_cck_rssi(void *dm_void, u8 lna_idx, u8 vga_idx)
 {
-	s8	rx_pwr_all = 0x00;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	s8 rx_pow = 0;
 
-	switch (LNA_idx) {
-	case 0xf:
-		rx_pwr_all = -48 - (2 * VGA_idx);
-		break;
-	case 0xb:
-		rx_pwr_all = -42 - (2 * VGA_idx); /*TBD*/
-		break;
-	case 0xa:
-		rx_pwr_all = -36 - (2 * VGA_idx);
-		break;
-	case 8:
-		rx_pwr_all = -32 - (2 * VGA_idx);
-		break;
-	case 7:
-		rx_pwr_all = -19 - (2 * VGA_idx);
-		break;
-	case 4:
-		rx_pwr_all = -6 - (2 * VGA_idx);
-		break;
-	case 0:
-		rx_pwr_all = -2 - (2 * VGA_idx);
+	switch (dm->support_ic_type) {
+	#if (RTL8197F_SUPPORT == 1)
+	case ODM_RTL8197F:
+		rx_pow = phydm_cck_rssi_convert(dm, lna_idx, vga_idx);
 		break;
-	default:
-		/*rx_pwr_all = -53+(2*(31-VGA_idx));*/
-		/*dbg_print("wrong LNA index\n");*/
+	#endif
+
+	#if (RTL8723D_SUPPORT == 1)
+	case ODM_RTL8723D:
+		rx_pow = phydm_cckrssi_8723d(dm, lna_idx, vga_idx);
 		break;
+	#endif
 
-	}
-	return	rx_pwr_all;
-}
-#endif
+	#if (RTL8710B_SUPPORT == 1)
+	case ODM_RTL8710B:
+		rx_pow = phydm_cckrssi_8710b(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-#if (RTL8195A_SUPPORT == 1)
-s8
-phydm_cck_rssi_8195a(
-	struct PHY_DM_STRUCT	*p_dm,
-	u16		LNA_idx,
-	u8		VGA_idx
-)
-{
-	s8	rx_pwr_all = 0;
-	s8	lna_gain = 0;
-	s8	lna_gain_table_0[8] = {0, -8, -15, -22, -29, -36, -45, -54};
-	s8	lna_gain_table_1[8] = {0, -8, -15, -22, -29, -36, -45, -54};/*use 8195A to calibrate this table. 2016.06.24, Dino*/
+	#if (RTL8721D_SUPPORT == 1)
+	case ODM_RTL8721D:
+		rx_pow = phydm_cckrssi_8721d(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	if (p_dm->cck_agc_report_type == 0)
-		lna_gain = lna_gain_table_0[LNA_idx];
-	else
-		lna_gain = lna_gain_table_1[LNA_idx];
+	#if (RTL8192F_SUPPORT == 1)
+	case ODM_RTL8192F:
+		rx_pow = phydm_cckrssi_8192f(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	rx_pwr_all = lna_gain - (2 * VGA_idx);
+	#if (RTL8821C_SUPPORT == 1)
+	case ODM_RTL8821C:
+		rx_pow = phydm_cck_rssi_8821c(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	return	rx_pwr_all;
-}
-#endif
+	#if (RTL8195B_SUPPORT == 1)
+	case ODM_RTL8195B:
+		rx_pow = phydm_cck_rssi_8195B(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-#if (RTL8192E_SUPPORT == 1)
-s8
-phydm_cck_rssi_8192e(
-	struct PHY_DM_STRUCT	*p_dm,
-	u16		LNA_idx,
-	u8		VGA_idx
-)
-{
-	s8	rx_pwr_all = 0;
-	s8	lna_gain = 0;
-	s8	lna_gain_table_0[8] = {15, 9, -10, -21, -23, -27, -43, -44};
-	s8	lna_gain_table_1[8] = {24, 18, 13, -4, -11, -18, -31, -36};/*use 8192EU to calibrate this table. 2015.12.15, Dino*/
+	#if (RTL8188E_SUPPORT == 1)
+	case ODM_RTL8188E:
+		rx_pow = phydm_cck_rssi_8188e(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	if (p_dm->cck_agc_report_type == 0)
-		lna_gain = lna_gain_table_0[LNA_idx];
-	else
-		lna_gain = lna_gain_table_1[LNA_idx];
+	#if (RTL8192E_SUPPORT == 1)
+	case ODM_RTL8192E:
+		rx_pow = phydm_cck_rssi_8192e(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	rx_pwr_all = lna_gain - (2 * VGA_idx);
+	#if (RTL8723B_SUPPORT == 1)
+	case ODM_RTL8723B:
+		rx_pow = phydm_cck_rssi_8723b(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	return	rx_pwr_all;
-}
-#endif
+	#if (RTL8703B_SUPPORT == 1)
+	case ODM_RTL8703B:
+		rx_pow = phydm_cck_rssi_8703b(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-#if (RTL8188E_SUPPORT == 1)
-s8
-phydm_cck_rssi_8188e(
-	struct PHY_DM_STRUCT	*p_dm,
-	u16		LNA_idx,
-	u8		VGA_idx
-)
-{
-	s8	rx_pwr_all = 0;
-	s8	lna_gain = 0;
-	s8	lna_gain_table_0[8] = {17, -1, -13, -29, -32, -35, -38, -41};/*only use lna0/1/2/3/7*/
-	s8	lna_gain_table_1[8] = {29, 20, 12, 3, -6, -15, -24, -33}; /*only use lna3 /7*/
+	#if (RTL8188F_SUPPORT == 1)
+	case ODM_RTL8188F:
+		rx_pow = phydm_cck_rssi_8188f(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	if (p_dm->cut_version >= ODM_CUT_I) /*SMIC*/
-		lna_gain = lna_gain_table_0[LNA_idx];
-	else	 /*TSMC*/
-		lna_gain = lna_gain_table_1[LNA_idx];
+	#if (RTL8195A_SUPPORT == 1)
+	case ODM_RTL8195A:
+		rx_pow = phydm_cck_rssi_8195a(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	rx_pwr_all = lna_gain - (2 * VGA_idx);
+	#if (RTL8812A_SUPPORT == 1)
+	case ODM_RTL8812:
+		rx_pow = phydm_cck_rssi_8812a(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	return	rx_pwr_all;
-}
-#endif
+	#if (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1)
+	case ODM_RTL8821:
+	case ODM_RTL8881A:
+		rx_pow = phydm_cck_rssi_8821a(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-#if (RTL8821C_SUPPORT == 1)
-s8
-phydm_cck_rssi_8821c(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		LNA_idx,
-	u8		VGA_idx
-)
-{
-	s8	rx_pwr_all = 0;
-	s8	lna_gain = 0;
-	s8	lna_gain_table_0[8] = {22, 8, -6, -22, -31, -40, -46, -52};/*only use lna2/3/5/7*/
-	s8	lna_gain_table_1[16] = {10, 6, 2, -2, -6, -10, -14, -17,
-		-20, -24, -28, -31, -34, -37, -40, -44}; /*only use lna4/8/C/F*/
-
-	if (p_dm->cck_agc_report_type == 0)
-		lna_gain = lna_gain_table_0[LNA_idx];
-	else
-		lna_gain = lna_gain_table_1[LNA_idx];
+	#if (RTL8814A_SUPPORT == 1)
+	case ODM_RTL8814A:
+		rx_pow = phydm_cck_rssi_8814a(dm, lna_idx, vga_idx);
+		break;
+	#endif
 
-	rx_pwr_all = lna_gain - (2 * VGA_idx);
+	default:
+		break;
+	}
 
-	return	rx_pwr_all;
+	return rx_pow;
 }
-#endif
 
 #if (ODM_IC_11N_SERIES_SUPPORT == 1)
-void
-phydm_rx_phy_status92c_series_parsing(
-	struct PHY_DM_STRUCT					*p_dm,
-	struct phydm_phyinfo_struct			*p_phy_info,
-	u8						*p_phy_status,
-	struct phydm_perpkt_info_struct			*p_pktinfo
-)
+void phydm_phy_sts_n_parsing(struct dm_struct *dm,
+			     struct phydm_phyinfo_struct *phy_info,
+			     u8 *phy_status_inf,
+			     struct phydm_perpkt_info_struct *pktinfo)
 {
-	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;
-	boolean				is_cck_rate = false;
-	u8				rf_rx_num = 0;
-	u8				LNA_idx = 0;
-	u8				VGA_idx = 0;
-	u8				cck_agc_rpt;
-	u8				num_ss;
-	u8				stream_rxevm_tmp = 0;
-	struct _phy_status_rpt_8192cd *p_phy_sta_rpt = (struct _phy_status_rpt_8192cd *)p_phy_status;
-
-	is_cck_rate = (p_pktinfo->data_rate <= ODM_RATE11M) ? true : false;
-	p_dm->rate_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
-
-	if (p_pktinfo->is_to_self)
-		p_dm->curr_station_id = p_pktinfo->station_id;
-
-	p_phy_info->rx_mimo_signal_quality[RF_PATH_A] = -1;
-	p_phy_info->rx_mimo_signal_quality[RF_PATH_B] = -1;
-
-
-	if (is_cck_rate) {
-		p_dm->phy_dbg_info.num_qry_phy_status_cck++;
-		cck_agc_rpt = p_phy_sta_rpt->cck_agc_rpt_ofdm_cfosho_a;
-
-		if (p_dm->support_ic_type & (ODM_RTL8703B)) {
-
-#if (RTL8703B_SUPPORT == 1)
-			if (p_dm->cck_agc_report_type == 1) {  /*4 bit LNA*/
-
-				u8 cck_agc_rpt_b = (p_phy_sta_rpt->cck_rpt_b_ofdm_cfosho_b & BIT(7)) ? 1 : 0;
-
-				LNA_idx = (cck_agc_rpt_b << 3) | ((cck_agc_rpt & 0xE0) >> 5);
-				VGA_idx = (cck_agc_rpt & 0x1F);
-
-				rx_pwr_all = phydm_cck_rssi_8703B(LNA_idx, VGA_idx);
-			}
-#endif
-		} else { /*3 bit LNA*/
-
-			LNA_idx = ((cck_agc_rpt & 0xE0) >> 5);
-			VGA_idx = (cck_agc_rpt & 0x1F);
-
-			if (p_dm->support_ic_type & (ODM_RTL8188E)) {
+	u8 i = 0;
+	s8 rx_pwr[4], rx_pwr_all = 0;
+	u8 EVM, pwdb_all = 0, pwdb_all_bt = 0;
+	u8 RSSI, total_rssi = 0;
+	u8 rf_rx_num = 0;
+	u8 lna_idx = 0;
+	u8 vga_idx = 0;
+	u8 cck_agc_rpt;
+	s8 evm_tmp = 0;
+	u8 sq = 0;
+	u8 val_tmp = 0;
+	s8 val_s8 = 0;
+	struct phy_status_rpt_8192cd *phy_sts = NULL;
+
+	phy_sts = (struct phy_status_rpt_8192cd *)phy_status_inf;
+
+	if (pktinfo->is_cck_rate) {
+		cck_agc_rpt = phy_sts->cck_agc_rpt_ofdm_cfosho_a;
+
+		/*@3 bit LNA*/
+		lna_idx = ((cck_agc_rpt & 0xE0) >> 5);
+		vga_idx = (cck_agc_rpt & 0x1F);
+
+		#if (RTL8703B_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8703B) &&
+		    dm->cck_agc_report_type == 1) {
+			/*@4 bit LNA*/
+			if (phy_sts->cck_rpt_b_ofdm_cfosho_b & BIT(7))
+				val_tmp = 1;
+			else
+				val_tmp = 0;
+			lna_idx = (val_tmp << 3) | lna_idx;
+		}
+		#endif
 
-#if (RTL8188E_SUPPORT == 1)
-				rx_pwr_all = phydm_cck_rssi_8188e(p_dm, LNA_idx, VGA_idx);
-				/**/
-#endif
-			}
-#if (RTL8192E_SUPPORT == 1)
-			else if (p_dm->support_ic_type & (ODM_RTL8192E)) {
+		rx_pwr_all = phydm_get_cck_rssi(dm, lna_idx, vga_idx);
 
-				rx_pwr_all = phydm_cck_rssi_8192e(p_dm, LNA_idx, VGA_idx);
-				/**/
-			}
-#endif
-#if (RTL8723B_SUPPORT == 1)
-			else if (p_dm->support_ic_type & (ODM_RTL8723B)) {
+		PHYDM_DBG(dm, DBG_RSSI_MNTR,
+			  "ext_lna_gain (( %d )), lna_idx: (( 0x%x )), vga_idx: (( 0x%x )), rx_pwr_all: (( %d ))\n",
+			  dm->ext_lna_gain, lna_idx, vga_idx, rx_pwr_all);
 
-				rx_pwr_all = odm_CCKRSSI_8723B(LNA_idx, VGA_idx);
-				/**/
-			}
-#endif
-#if (RTL8188F_SUPPORT == 1)
-			else if (p_dm->support_ic_type & (ODM_RTL8188F)) {
+		if (dm->board_type & ODM_BOARD_EXT_LNA)
+			rx_pwr_all -= dm->ext_lna_gain;
 
-				rx_pwr_all = odm_CCKRSSI_8188F(LNA_idx, VGA_idx);
-				/**/
-			}
-#endif
-#if (RTL8195A_SUPPORT == 1)
-			else if (p_dm->support_ic_type & (ODM_RTL8195A)) {
+		pwdb_all = phydm_pwr_2_percent(rx_pwr_all);
 
-				rx_pwr_all = phydm_cck_rssi_8195a(LNA_idx, VGA_idx);
-				/**/
-			}
-#endif
+		if (pktinfo->is_to_self) {
+			dm->cck_lna_idx = lna_idx;
+			dm->cck_vga_idx = vga_idx;
 		}
 
-		PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("ext_lna_gain (( %d )), LNA_idx: (( 0x%x )), VGA_idx: (( 0x%x )), rx_pwr_all: (( %d ))\n",
-			p_dm->ext_lna_gain, LNA_idx, VGA_idx, rx_pwr_all));
-
-		if (p_dm->board_type & ODM_BOARD_EXT_LNA)
-			rx_pwr_all -= p_dm->ext_lna_gain;
+		phy_info->rx_pwdb_all = pwdb_all;
+		phy_info->bt_rx_rssi_percentage = pwdb_all;
+		phy_info->recv_signal_power = rx_pwr_all;
 
-		PWDB_ALL = phydm_query_rx_pwr_percentage(rx_pwr_all);
-
-		if (p_pktinfo->is_to_self) {
-			p_dm->cck_lna_idx = LNA_idx;
-			p_dm->cck_vga_idx = VGA_idx;
-		}
-		p_phy_info->rx_pwdb_all = PWDB_ALL;
+		/* @(3) Get Signal Quality (EVM) */
+		#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+		if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO)
+			sq = phydm_sq_patch_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+		else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER)
+			sq = phydm_sq_patch_rt_cid_819x_acer(dm, pktinfo->is_cck_rate, pwdb_all, 0, 0);
+		else
+		#endif
+			sq = phydm_get_signal_quality(phy_info, dm, phy_sts);
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		p_phy_info->bt_rx_rssi_percentage = PWDB_ALL;
-		p_phy_info->recv_signal_power = rx_pwr_all;
-#endif
-		
-		/* (3) Get Signal Quality (EVM) */
-		
-		
-		{
-			u8	SQ;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			if (p_dm->iot_table.win_patch_id == RT_CID_819X_LENOVO)
-				SQ = phydm_sq_patch_rt_cid_819x_lenovo(p_dm, is_cck_rate, PWDB_ALL, 0, 0);
-			else if (p_dm->iot_table.win_patch_id == RT_CID_819X_ACER)
-				SQ = phydm_sq_patch_rt_cid_819x_acer(p_dm, is_cck_rate, PWDB_ALL, 0, 0);
-			else
+#if 0
+		/* @dbg_print("cck sq = %d\n", sq); */
 #endif
-				SQ = phydm_get_signal_quality(p_phy_info, p_dm, p_phy_sta_rpt);
-
-			/* dbg_print("cck SQ = %d\n", SQ); */
-			p_phy_info->signal_quality = SQ;
-			p_phy_info->rx_mimo_signal_quality[RF_PATH_A] = SQ;
-			p_phy_info->rx_mimo_signal_quality[RF_PATH_B] = -1;
-		}
+		phy_info->signal_quality = sq;
+		phy_info->rx_mimo_signal_quality[RF_PATH_A] = sq;
+		phy_info->rx_mimo_signal_quality[RF_PATH_B] = -1;
 
-		for (i = RF_PATH_A; i < ODM_RF_PATH_MAX; i++) {
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
 			if (i == 0)
-				p_phy_info->rx_mimo_signal_strength[0] = PWDB_ALL;
+				phy_info->rx_mimo_signal_strength[0] = pwdb_all;
 			else
-				p_phy_info->rx_mimo_signal_strength[1] = 0;
+				phy_info->rx_mimo_signal_strength[i] = 0;
 		}
-	} else { /* 2 is OFDM rate */
-		p_dm->phy_dbg_info.num_qry_phy_status_ofdm++;
+	} else { /* @2 is OFDM rate */
 
-		/*  */
-		/* (1)Get RSSI for HT rate */
-		/*  */
+		/* @(1)Get RSSI for HT rate */
 
-		for (i = RF_PATH_A; i < ODM_RF_PATH_MAX; i++) {
-			/* 2008/01/30 MH we will judge RF RX path now. */
-			if (p_dm->rf_path_rx_enable & BIT(i))
+		for (i = RF_PATH_A; i < dm->num_rf_path; i++) {
+			if (dm->rf_path_rx_enable & BIT(i))
 				rf_rx_num++;
-			/* else */
-			/* continue; */
 
-			rx_pwr[i] = ((p_phy_sta_rpt->path_agc[i].gain & 0x3F) * 2) - 110;
+			val_s8 = phy_sts->path_agc[i].gain & 0x3F;
+			rx_pwr[i] = (val_s8 * 2) - 110;
 
-			if (p_pktinfo->is_to_self) {
-				p_dm->ofdm_agc_idx[i] = (p_phy_sta_rpt->path_agc[i].gain & 0x3F);
-				/**/
-			}
-
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-			p_phy_info->rx_pwr[i] = rx_pwr[i];
-#endif
+			if (pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = val_s8;
 
-			/* Translate DBM to percentage. */
-			RSSI = phydm_query_rx_pwr_percentage(rx_pwr[i]);
+			phy_info->rx_pwr[i] = rx_pwr[i];
+			RSSI = phydm_pwr_2_percent(rx_pwr[i]);
 			total_rssi += RSSI;
-			/* RT_DISP(FRX, RX_PHY_SS, ("RF-%d RXPWR=%x RSSI=%d\n", i, rx_pwr[i], RSSI)); */
 
-			p_phy_info->rx_mimo_signal_strength[i] = (u8) RSSI;
+			phy_info->rx_mimo_signal_strength[i] = (u8)RSSI;
 
-			/* Get Rx snr value in DB */
-			p_phy_info->rx_snr[i] = p_dm->phy_dbg_info.rx_snr_db[i] = (s8)(p_phy_sta_rpt->path_rxsnr[i] / 2);
+			/* @Get Rx snr value in DB */
+			val_s8 = (s8)(phy_sts->path_rxsnr[i] / 2);
+			phy_info->rx_snr[i] = val_s8;
 
 			/* Record Signal Strength for next packet */
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+			#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 			if (i == RF_PATH_A) {
-				if (p_dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
-					p_phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_lenovo(p_dm, is_cck_rate, PWDB_ALL, i, RSSI);
-				} else if (p_dm->iot_table.win_patch_id == RT_CID_819X_ACER)
-					p_phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_acer(p_dm, is_cck_rate, PWDB_ALL, 0, RSSI);
+				if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+					phy_info->signal_quality = phydm_sq_patch_lenovo(dm, pktinfo->is_cck_rate, pwdb_all, i, RSSI);
+				} else if (dm->iot_table.win_patch_id == RT_CID_819X_ACER)
+					phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_acer(dm, pktinfo->is_cck_rate, pwdb_all, 0, RSSI);
 			}
-#endif
+			#endif
 		}
 
+		/* @(2)PWDB, Average PWDB calculated by hardware (for RA) */
+		val_s8 = phy_sts->cck_sig_qual_ofdm_pwdb_all >> 1;
+		rx_pwr_all = (val_s8  & 0x7f) - 110;
 
-		/*  */
-		/* (2)PWDB, Average PWDB calculated by hardware (for rate adaptive) */
-		/*  */
-		rx_pwr_all = (((p_phy_sta_rpt->cck_sig_qual_ofdm_pwdb_all) >> 1) & 0x7f) - 110;
-
-		PWDB_ALL_BT = PWDB_ALL = phydm_query_rx_pwr_percentage(rx_pwr_all);
-
-
-		p_phy_info->rx_pwdb_all = PWDB_ALL;
-		/* PHYDM_DBG(p_dm,DBG_RSSI_MNTR, ("ODM OFDM RSSI=%d\n",p_phy_info->rx_pwdb_all)); */
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		p_phy_info->bt_rx_rssi_percentage = PWDB_ALL_BT;
-		p_phy_info->rx_power = rx_pwr_all;
-		p_phy_info->recv_signal_power = rx_pwr_all;
-#endif
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		if (p_dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
-			/* do nothing */
-		} else if (p_dm->iot_table.win_patch_id == RT_CID_819X_ACER) {
-			/* do nothing */
-		} else 
-#endif
-		{
-			/* (3)EVM of HT rate */
-
-			if (p_pktinfo->data_rate >= ODM_RATEMCS8 && p_pktinfo->data_rate <= ODM_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 = phydm_evm_db_to_percentage((p_phy_sta_rpt->stream_rxevm[i]));	/* dbm */
-
-				/* GET_RX_STATUS_DESC_RX_MCS(p_desc), p_drv_info->rxevm[i], "%", EVM)); */
+		pwdb_all = phydm_pwr_2_percent(rx_pwr_all);
+		pwdb_all_bt = pwdb_all;
 
-				if (i == RF_PATH_A) /* Fill value in RFD, Get the first spatial stream only */
-					p_phy_info->signal_quality = (u8)(EVM & 0xff);
-				
-				p_phy_info->rx_mimo_signal_quality[i] = (u8)(EVM & 0xff);
+		phy_info->rx_pwdb_all = pwdb_all;
+		phy_info->bt_rx_rssi_percentage = pwdb_all_bt;
+		phy_info->rx_power = rx_pwr_all;
+		phy_info->recv_signal_power = rx_pwr_all;
 
-				if (p_phy_sta_rpt->stream_rxevm[i] < 0)
-					stream_rxevm_tmp = (u8)(0 - (p_phy_sta_rpt->stream_rxevm[i]));
+		/* @(3)EVM of HT rate */
+		for (i = 0; i < pktinfo->rate_ss; 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 = phydm_evm_2_percent(phy_sts->stream_rxevm[i]);
 
-				if (stream_rxevm_tmp == 64)
-					stream_rxevm_tmp = 0;
+			/*@Fill value in RFD, Get the 1st spatial stream only*/
+			if (i == RF_PATH_A)
+				phy_info->signal_quality = (u8)(EVM & 0xff);
 
-				p_phy_info->rx_mimo_evm_dbm[i] = stream_rxevm_tmp;
+			phy_info->rx_mimo_signal_quality[i] = (u8)(EVM & 0xff);
 
-			}
-		}
+			if (phy_sts->stream_rxevm[i] < 0)
+				evm_tmp = 0 - phy_sts->stream_rxevm[i];
 
-		num_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
-		odm_parsing_cfo(p_dm, p_pktinfo, p_phy_sta_rpt->path_cfotail, num_ss);
+			if (evm_tmp == 64)
+				evm_tmp = 0;
 
-	}
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	/* UI BSS List signal strength(in percentage), make it good looking, from 0~100. */
-	/* It is assigned to the BSS List in GetValueFromBeaconOrProbeRsp(). */
-	if (is_cck_rate) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/ */
-		p_phy_info->signal_strength = SignalScaleProc(p_dm->adapter, PWDB_ALL, true, true);
-#else
-		p_phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(p_dm, PWDB_ALL));/*PWDB_ALL;*/
-#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
-	} else {
-		if (rf_rx_num != 0) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/ */
-			p_phy_info->signal_strength = SignalScaleProc(p_dm->adapter, (total_rssi /= rf_rx_num), true, false);
-#else
-			p_phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(p_dm, total_rssi /= rf_rx_num));
-#endif
+			phy_info->rx_mimo_evm_dbm[i] = (u8)evm_tmp;
 		}
-	}
-#endif /*#if (DM_ODM_SUPPORT_TYPE &  (ODM_WIN|ODM_CE))*/
-
-	/* dbg_print("is_cck_rate = %d, p_phy_info->rx_pwdb_all = %d, p_phy_sta_rpt->cck_agc_rpt_ofdm_cfosho_a = 0x%x\n", */
-	/* is_cck_rate, p_phy_info->rx_pwdb_all, p_phy_sta_rpt->cck_agc_rpt_ofdm_cfosho_a); */
-
-	/* For 92C/92D HW (Hybrid) Antenna Diversity */
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	/* For 88E HW Antenna Diversity */
-	p_dm->dm_fat_table.antsel_rx_keep_0 = p_phy_sta_rpt->ant_sel;
-	p_dm->dm_fat_table.antsel_rx_keep_1 = p_phy_sta_rpt->ant_sel_b;
-	p_dm->dm_fat_table.antsel_rx_keep_2 = p_phy_sta_rpt->antsel_rx_keep_2;
-#endif
-
-	if (p_pktinfo->is_packet_match_bssid) {
-		phydm_avg_phystatus_index(p_dm, p_phy_info, p_pktinfo);
-		phydm_rx_statistic_cal(p_dm, p_phy_status, p_pktinfo);
+		phydm_parsing_cfo(dm, pktinfo,
+				  phy_sts->path_cfotail, pktinfo->rate_ss);
 	}
 
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sts->ant_sel;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sts->ant_sel_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sts->antsel_rx_keep_2;
+	#endif
 }
 #endif
 
-#if	ODM_IC_11AC_SERIES_SUPPORT
+#if ODM_IC_11AC_SERIES_SUPPORT
 
-void
-phydm_rx_phy_bw_jaguar_series_parsing(
-	struct phydm_phyinfo_struct			*p_phy_info,
-	struct phydm_perpkt_info_struct			*p_pktinfo,
-	struct _phy_status_rpt_8812		*p_phy_sta_rpt
-)
+void phydm_rx_physts_bw_parsing(struct phydm_phyinfo_struct *phy_info,
+				struct phydm_perpkt_info_struct *
+				pktinfo,
+				struct phy_status_rpt_8812 *
+				phy_sts)
 {
-
-	if (p_pktinfo->data_rate <= ODM_RATE54M) {
-		switch (p_phy_sta_rpt->r_RFMOD) {
+	if (pktinfo->data_rate <= ODM_RATE54M) {
+		switch (phy_sts->r_RFMOD) {
 		case 1:
-			if (p_phy_sta_rpt->sub_chnl == 0)
-				p_phy_info->band_width = 1;
+			if (phy_sts->sub_chnl == 0)
+				phy_info->band_width = 1;
 			else
-				p_phy_info->band_width = 0;
+				phy_info->band_width = 0;
 			break;
 
 		case 2:
-			if (p_phy_sta_rpt->sub_chnl == 0)
-				p_phy_info->band_width = 2;
-			else if (p_phy_sta_rpt->sub_chnl == 9 || p_phy_sta_rpt->sub_chnl == 10)
-				p_phy_info->band_width = 1;
+			if (phy_sts->sub_chnl == 0)
+				phy_info->band_width = 2;
+			else if (phy_sts->sub_chnl == 9 ||
+				 phy_sts->sub_chnl == 10)
+				phy_info->band_width = 1;
 			else
-				p_phy_info->band_width = 0;
+				phy_info->band_width = 0;
 			break;
 
 		default:
 		case 0:
-			p_phy_info->band_width = 0;
+			phy_info->band_width = 0;
 			break;
 		}
 	}
-
 }
 
-void
-phydm_rx_phy_status_jaguar_series_parsing(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct phydm_phyinfo_struct	*p_phy_info,
-	u8							*p_phy_status,
-	struct phydm_perpkt_info_struct		*p_pktinfo
-)
+void phydm_get_sq(struct dm_struct *dm, struct phydm_phyinfo_struct *phy_info,
+		  u8 is_cck_rate)
 {
-	u8					i, max_spatial_stream;
-	s8					rx_pwr[4], rx_pwr_all = 0;
-	u8					EVM = 0, evm_dbm, PWDB_ALL = 0, PWDB_ALL_BT;
-	u8					RSSI, avg_rssi = 0, best_rssi = 0, second_rssi = 0;
-	u8					is_cck_rate = 0;
-	u8					rf_rx_num = 0;
-	u8					cck_highpwr = 0;
-	u8					LNA_idx, VGA_idx;
-	struct _phy_status_rpt_8812 *p_phy_sta_rpt = (struct _phy_status_rpt_8812 *)p_phy_status;
-	struct phydm_fat_struct					*p_dm_fat_table = &p_dm->dm_fat_table;
-	u8					num_ss;
-
-	phydm_rx_phy_bw_jaguar_series_parsing(p_phy_info, p_pktinfo, p_phy_sta_rpt);
-
-	is_cck_rate = (p_pktinfo->data_rate <= ODM_RATE11M) ? true : false;
-	p_dm->rate_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
-
-	if (p_pktinfo->is_to_self)
-		p_dm->curr_station_id = p_pktinfo->station_id;
-	else
-		p_dm->curr_station_id = 0xff;
-
-	p_phy_info->rx_mimo_signal_quality[RF_PATH_A] = -1;
-	p_phy_info->rx_mimo_signal_quality[RF_PATH_B] = -1;
-	p_phy_info->rx_mimo_signal_quality[RF_PATH_C] = -1;
-	p_phy_info->rx_mimo_signal_quality[RF_PATH_D] = -1;
-
-	if (is_cck_rate) {
-		u8 cck_agc_rpt;
-
-		p_dm->phy_dbg_info.num_qry_phy_status_cck++;
-
-		/*(1)Hardware does not provide RSSI for CCK*/
-		/*(2)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
-
-		/*if(p_hal_data->e_rf_power_state == e_rf_on)*/
-		cck_highpwr = p_dm->is_cck_high_power;
-		/*else*/
-		/*cck_highpwr = false;*/
-
-		cck_agc_rpt = p_phy_sta_rpt->cfosho[0];
-		LNA_idx = ((cck_agc_rpt & 0xE0) >> 5);
-		VGA_idx = (cck_agc_rpt & 0x1F);
+	u8 sq = 0;
+	u8 pwdb_all = phy_info->rx_pwdb_all; /*precentage*/
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	u8 rssi = phy_info->rx_mimo_signal_strength[0];
+	#endif
 
-		if (p_dm->support_ic_type == ODM_RTL8812) {
-			switch (LNA_idx) {
-			case 7:
-				if (VGA_idx <= 27)
-					rx_pwr_all = -100 + 2 * (27 - VGA_idx); /*VGA_idx = 27~2*/
-				else
-					rx_pwr_all = -100;
-				break;
-			case 6:
-				rx_pwr_all = -48 + 2 * (2 - VGA_idx); /*VGA_idx = 2~0*/
-				break;
-			case 5:
-				rx_pwr_all = -42 + 2 * (7 - VGA_idx); /*VGA_idx = 7~5*/
-				break;
-			case 4:
-				rx_pwr_all = -36 + 2 * (7 - VGA_idx); /*VGA_idx = 7~4*/
-				break;
-			case 3:
-				/*rx_pwr_all = -28 + 2*(7-VGA_idx); VGA_idx = 7~0*/
-				rx_pwr_all = -24 + 2 * (7 - VGA_idx); /*VGA_idx = 7~0*/
-				break;
-			case 2:
-				if (cck_highpwr)
-					rx_pwr_all = -12 + 2 * (5 - VGA_idx); /*VGA_idx = 5~0*/
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	if (dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
+		if (is_cck_rate)
+			sq = phydm_sq_patch_lenovo(dm, 1, pwdb_all, 0, 0);
+		else
+			sq = phydm_sq_patch_lenovo(dm, 0, pwdb_all, 0, rssi);
+	} else
+	#endif
+	{
+		if (is_cck_rate) {
+			if (pwdb_all > 40 && !dm->is_in_hct_test) {
+				sq = 100;
+			} else {
+				if (pwdb_all > 64)
+					sq = 0;
+				else if (pwdb_all < 20)
+					sq = 100;
 				else
-					rx_pwr_all = -6 + 2 * (5 - VGA_idx);
-				break;
-			case 1:
-				rx_pwr_all = 8 - 2 * VGA_idx;
-				break;
-			case 0:
-				rx_pwr_all = 14 - 2 * VGA_idx;
-				break;
-			default:
-				/*dbg_print("CCK Exception default\n");*/
-				break;
-			}
-			rx_pwr_all += 6;
-			PWDB_ALL = phydm_query_rx_pwr_percentage(rx_pwr_all);
-
-			if (cck_highpwr == false) {
-				if (PWDB_ALL >= 80)
-					PWDB_ALL = ((PWDB_ALL - 80) << 1) + ((PWDB_ALL - 80) >> 1) + 80;
-				else if ((PWDB_ALL <= 78) && (PWDB_ALL >= 20))
-					PWDB_ALL += 3;
-				if (PWDB_ALL > 100)
-					PWDB_ALL = 100;
+					sq = ((64 - pwdb_all) * 100) / 44;
 			}
-		} else if (p_dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A)) {
-			s8 pout = -6;
-
-			switch (LNA_idx) {
-			case 5:
-				rx_pwr_all = pout - 32 - (2 * VGA_idx);
-				break;
-			case 4:
-				rx_pwr_all = pout - 24 - (2 * VGA_idx);
-				break;
-			case 2:
-				rx_pwr_all = pout - 11 - (2 * VGA_idx);
-				break;
-			case 1:
-				rx_pwr_all = pout + 5 - (2 * VGA_idx);
-				break;
-			case 0:
-				rx_pwr_all = pout + 21 - (2 * VGA_idx);
-				break;
-			}
-			PWDB_ALL = phydm_query_rx_pwr_percentage(rx_pwr_all);
-		} else if (p_dm->support_ic_type == ODM_RTL8814A || p_dm->support_ic_type == ODM_RTL8822B) {
-			s8 pout = -6;
-
-			switch (LNA_idx) {
-			/*CCK only use LNA: 2, 3, 5, 7*/
-			case 7:
-				rx_pwr_all = pout - 32 - (2 * VGA_idx);
-				break;
-			case 5:
-				rx_pwr_all = pout - 22 - (2 * VGA_idx);
-				break;
-			case 3:
-				rx_pwr_all = pout - 2 - (2 * VGA_idx);
-				break;
-			case 2:
-				rx_pwr_all = pout + 5 - (2 * VGA_idx);
-				break;
-			/*case 6:*/
-			/*rx_pwr_all = pout -26 - (2*VGA_idx);*/
-			/*break;*/
-			/*case 4:*/
-			/*rx_pwr_all = pout - 8 - (2*VGA_idx);*/
-			/*break;*/
-			/*case 1:*/
-			/*rx_pwr_all = pout + 21 - (2*VGA_idx);*/
-			/*break;*/
-			/*case 0:*/
-			/*rx_pwr_all = pout + 10 - (2*VGA_idx);*/
-			/*	break; */
-			default:
-				/* dbg_print("CCK Exception default\n"); */
-				break;
-			}
-			PWDB_ALL = phydm_query_rx_pwr_percentage(rx_pwr_all);
+		} else {
+			sq = phy_info->rx_mimo_signal_quality[0];
 		}
+	}
 
-		p_dm->cck_lna_idx = LNA_idx;
-		p_dm->cck_vga_idx = VGA_idx;
-		p_phy_info->rx_pwdb_all = PWDB_ALL;
-		/* if(p_pktinfo->station_id == 0) */
-		/* { */
-		/*	dbg_print("CCK: LNA_idx = %d, VGA_idx = %d, p_phy_info->rx_pwdb_all = %d\n", */
-		/*		LNA_idx, VGA_idx, p_phy_info->rx_pwdb_all); */
-		/* } */
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		p_phy_info->bt_rx_rssi_percentage = PWDB_ALL;
-		p_phy_info->recv_signal_power = rx_pwr_all;
+#if 0
+	/* @dbg_print("cck sq = %d\n", sq); */
 #endif
-		/*(3) Get Signal Quality (EVM)*/
-		/*if (p_pktinfo->is_packet_match_bssid)*/
-		{
-			u8	SQ, SQ_rpt;
+	phy_info->signal_quality = sq;
+}
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			if (p_dm->iot_table.win_patch_id == RT_CID_819X_LENOVO)
-				SQ = phydm_sq_patch_rt_cid_819x_lenovo(p_dm, is_cck_rate, PWDB_ALL, 0, 0);
-			else 
-#endif
-			if (p_phy_info->rx_pwdb_all > 40 && !p_dm->is_in_hct_test)
-				SQ = 100;
-			else {
-				SQ_rpt = p_phy_sta_rpt->pwdb_all;
-
-				if (SQ_rpt > 64)
-					SQ = 0;
-				else if (SQ_rpt < 20)
-					SQ = 100;
-				else
-					SQ = ((64 - SQ_rpt) * 100) / 44;
-			}
+void phydm_rx_physts_1st_type(struct dm_struct *dm,
+			      struct phydm_phyinfo_struct *phy_info,
+			      u8 *phy_status_inf,
+			      struct phydm_perpkt_info_struct *pktinfo)
+{
+	u8 i = 0;
+	s8 rx_pwr_db = 0;
+	u8 val = 0; /*tmp value*/
+	s8 val_s8 = 0; /*tmp value*/
+	u8 rssi = 0; /*pre path RSSI*/
+	u8 rf_rx_num = 0;
+	u8 lna_idx = 0, vga_idx = 0;
+	u8 cck_agc_rpt = 0;
+	struct phy_status_rpt_8812 *phy_sts = NULL;
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	#endif
 
-			/* dbg_print("cck SQ = %d\n", SQ); */
-			p_phy_info->signal_quality = SQ;
-			p_phy_info->rx_mimo_signal_quality[RF_PATH_A] = SQ;
+	phy_sts = (struct phy_status_rpt_8812 *)phy_status_inf;
+	phydm_rx_physts_bw_parsing(phy_info, pktinfo, phy_sts);
+
+	/* @== [CCK rate] ====================================================*/
+	if (pktinfo->is_cck_rate) {
+		cck_agc_rpt = phy_sts->cfosho[0];
+		lna_idx = (cck_agc_rpt & 0xE0) >> 5;
+		vga_idx = cck_agc_rpt & 0x1F;
+
+		rx_pwr_db = phydm_get_cck_rssi(dm, lna_idx, vga_idx);
+		rssi = phydm_pwr_2_percent(rx_pwr_db);
+
+		if (dm->support_ic_type == ODM_RTL8812 &&
+		    !dm->is_cck_high_power) {
+			if (rssi >= 80) {
+				rssi = ((rssi - 80) << 1) +
+					   ((rssi - 80) >> 1) + 80;
+			} else if ((rssi <= 78) && (rssi >= 20)) {
+				rssi += 3;
+			}
 		}
+		dm->cck_lna_idx = lna_idx;
+		dm->cck_vga_idx = vga_idx;
 
-		for (i = RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-			if (i == 0)
-				p_phy_info->rx_mimo_signal_strength[0] = PWDB_ALL;
-			else
-				p_phy_info->rx_mimo_signal_strength[i] = 0;
-		}
+		phy_info->rx_pwdb_all = rssi;
+		phy_info->rx_mimo_signal_strength[0] = rssi;
 	} else {
-		/*is OFDM rate*/
-		p_dm_fat_table->hw_antsw_occur = p_phy_sta_rpt->hw_antsw_occur;
+	/* @== [OFDM rate] ===================================================*/
+		for (i = RF_PATH_A; i < dm->num_rf_path; i++) {
+			/*@[RSSI]*/
+			if (dm->rf_path_rx_enable & BIT(i))
+				rf_rx_num++;
+
+			if (i < RF_PATH_C)
+				val = phy_sts->gain_trsw[i];
+			else
+				val = phy_sts->gain_trsw_cd[i - 2];
 
-		p_dm->phy_dbg_info.num_qry_phy_status_ofdm++;
+			phy_info->rx_pwr[i] = (val & 0x7F) - 110;
+			rssi = phydm_pwr_2_percent(phy_info->rx_pwr[i]);
+			phy_info->rx_mimo_signal_strength[i] = rssi;
 
-		/*(1)Get RSSI for OFDM rate*/
+			/*@[SNR]*/
+			if (i < RF_PATH_C)
+				val_s8 = phy_sts->rxsnr[i];
+			else if (dm->support_ic_type & (ODM_RTL8814A))
+				val_s8 = (s8)phy_sts->csi_current[i - 2];
 
-		for (i = RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-			/*2008/01/30 MH we will judge RF RX path now.*/
-			/* dbg_print("p_dm->rf_path_rx_enable = %x\n", p_dm->rf_path_rx_enable); */
-			if (p_dm->rf_path_rx_enable & BIT(i))
-				rf_rx_num++;
-			/* else */
-			/* continue; */
-			/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
-			/* if((p_dm->support_ic_type & (ODM_RTL8812|ODM_RTL8821)) && (!p_dm->is_mp_chip)) */
+			phy_info->rx_snr[i] = val_s8 >> 1;
+
+			/*@[CFO_short  & CFO_tail]*/
 			if (i < RF_PATH_C) {
-				rx_pwr[i] = (p_phy_sta_rpt->gain_trsw[i] & 0x7F) - 110;
+				val_s8 = phy_sts->cfosho[i];
+				phy_info->cfo_short[i] = phydm_cfo(val_s8);
+				val_s8 = phy_sts->cfotail[i];
+				phy_info->cfo_tail[i] = phydm_cfo(val_s8);
+			}
 
-				if (p_pktinfo->is_to_self)
-					p_dm->ofdm_agc_idx[i] = p_phy_sta_rpt->gain_trsw[i];
+			if (i < RF_PATH_C && pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = phy_sts->gain_trsw[i];
+		}
 
-			} else
-				rx_pwr[i] = (p_phy_sta_rpt->gain_trsw_cd[i - 2] & 0x7F) - 110;
-			/* else */
-			/*rx_pwr[i] = ((p_phy_sta_rpt->gain_trsw[i]& 0x3F)*2) - 110;  OLD FORMULA*/
+	/* @== [PWDB] ========================================================*/
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-			p_phy_info->rx_pwr[i] = rx_pwr[i];
-#endif
+		/*@(Avg PWDB calculated by hardware*/
+		if (!dm->is_mp_chip) /*@8812, 8821*/
+			val = phy_sts->pwdb_all;
+		else
+			val = phy_sts->pwdb_all >> 1; /*old fomula*/
 
-			/* Translate DBM to percentage. */
-			RSSI = phydm_query_rx_pwr_percentage(rx_pwr[i]);
+		rx_pwr_db = (val & 0x7f) - 110;
+		phy_info->rx_pwdb_all = phydm_pwr_2_percent(rx_pwr_db);
 
-			/*total_rssi += RSSI;*/
-			/*Get the best two RSSI*/
-			if (RSSI > best_rssi && RSSI > second_rssi) {
-				second_rssi = best_rssi;
-				best_rssi = RSSI;
-			} else if (RSSI > second_rssi && RSSI <= best_rssi)
-				second_rssi = RSSI;
+		/*@(4)EVM of OFDM rate*/
+		for (i = 0; i < pktinfo->rate_ss; i++) {
+			if (!pktinfo->is_cck_rate &&
+			    pktinfo->data_rate <= ODM_RATE54M) {
+				val_s8 = phy_sts->sigevm;
+			} else if (i < RF_PATH_C) {
+				if (phy_sts->rxevm[i] == -128)
+					phy_sts->rxevm[i] = -25;
 
-			/*RT_DISP(FRX, RX_PHY_SS, ("RF-%d RXPWR=%x RSSI=%d\n", i, rx_pwr[i], RSSI));*/
+				val_s8 = phy_sts->rxevm[i];
+			} else {
+				if (phy_sts->rxevm_cd[i - 2] == -128)
+					phy_sts->rxevm_cd[i - 2] = -25;
 
-			p_phy_info->rx_mimo_signal_strength[i] = (u8) RSSI;
+				val_s8 = phy_sts->rxevm_cd[i - 2];
+			}
+			/*@[EVM to 0~100%]*/
+			val = phydm_evm_2_percent(val_s8);
+			phy_info->rx_mimo_signal_quality[i] = val;
+			/*@[EVM dBm]*/
+			phy_info->rx_mimo_evm_dbm[i] = phydm_evm_dbm(val_s8);
+		}
+		phydm_parsing_cfo(dm, pktinfo,
+				  phy_sts->cfotail, pktinfo->rate_ss);
+	}
 
+	/* @== [General Info] ================================================*/
 
-			/*Get Rx snr value in DB*/
-			if (i < RF_PATH_C)
-				p_phy_info->rx_snr[i] = p_dm->phy_dbg_info.rx_snr_db[i] = p_phy_sta_rpt->rxsnr[i] / 2;
-			else if (p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B))
-				p_phy_info->rx_snr[i] = p_dm->phy_dbg_info.rx_snr_db[i] = p_phy_sta_rpt->csi_current[i - 2] / 2;
+	phy_info->rx_power = rx_pwr_db;
+	phy_info->bt_rx_rssi_percentage = phy_info->rx_pwdb_all;
+	phy_info->recv_signal_power = phy_info->rx_power;
+	phydm_get_sq(dm, phy_info, pktinfo->is_cck_rate);
+
+	dm->rx_pwdb_ave = dm->rx_pwdb_ave + phy_info->rx_pwdb_all;
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	fat_tab->hw_antsw_occur = phy_sts->hw_antsw_occur;
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sts->antidx_anta;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sts->antidx_antb;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sts->antidx_antc;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sts->antidx_antd;
+	#endif
+}
 
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-			/*(2) CFO_short  & CFO_tail*/
-			if (i < RF_PATH_C) {
-				p_phy_info->cfo_short[i] = phydm_cfo((p_phy_sta_rpt->cfosho[i]));
-				p_phy_info->cfo_tail[i] = phydm_cfo((p_phy_sta_rpt->cfotail[i]));
-			}
-#endif
-			/* Record Signal Strength for next packet */
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			if (p_pktinfo->is_packet_match_bssid && (i == RF_PATH_A)) {
-				if (p_dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
-					p_phy_info->signal_quality = phydm_sq_patch_rt_cid_819x_lenovo(p_dm, is_cck_rate, PWDB_ALL, i, RSSI);
-				}
-			}
 #endif
+
+void phydm_reset_rssi_for_dm(struct dm_struct *dm, u8 station_id)
+{
+	struct cmn_sta_info *sta;
+
+	sta = dm->phydm_sta_info[station_id];
+
+	if (!is_sta_active(sta))
+		return;
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "Reset RSSI for macid = (( %d ))\n",
+		  station_id);
+
+	sta->rssi_stat.rssi_cck = -1;
+	sta->rssi_stat.rssi_ofdm = -1;
+	sta->rssi_stat.rssi = -1;
+	sta->rssi_stat.ofdm_pkt_cnt = 0;
+	sta->rssi_stat.cck_pkt_cnt = 0;
+	sta->rssi_stat.cck_sum_power = 0;
+	sta->rssi_stat.is_send_rssi = RA_RSSI_STATE_INIT;
+	sta->rssi_stat.packet_map = 0;
+	sta->rssi_stat.valid_bit = 0;
+}
+
+#if (ODM_IC_11N_SERIES_SUPPORT || ODM_IC_11AC_SERIES_SUPPORT)
+
+s32 phydm_get_rssi_8814_ofdm(struct dm_struct *dm, u8 *rssi_in)
+{
+	s32 rssi_avg;
+	u8 rx_count = 0;
+	u64 rssi_linear = 0;
+
+	if (dm->rx_ant_status & BB_PATH_A) {
+		rx_count++;
+		rssi_linear += phydm_db_2_linear(rssi_in[RF_PATH_A]);
+	}
+
+	if (dm->rx_ant_status & BB_PATH_B) {
+		rx_count++;
+		rssi_linear += phydm_db_2_linear(rssi_in[RF_PATH_B]);
+	}
+
+	if (dm->rx_ant_status & BB_PATH_C) {
+		rx_count++;
+		rssi_linear += phydm_db_2_linear(rssi_in[RF_PATH_C]);
+	}
+
+	if (dm->rx_ant_status & BB_PATH_D) {
+		rx_count++;
+		rssi_linear += phydm_db_2_linear(rssi_in[RF_PATH_D]);
+	}
+
+	/* @Rounding and removing fractional bits */
+	rssi_linear = (rssi_linear + (1 << (FRAC_BITS - 1))) >> FRAC_BITS;
+
+	/* @Calculate average RSSI */
+	switch (rx_count) {
+	case 2:
+		rssi_linear = DIVIDED_2(rssi_linear);
+		break;
+	case 3:
+		rssi_linear = DIVIDED_3(rssi_linear);
+		break;
+	case 4:
+		rssi_linear = DIVIDED_4(rssi_linear);
+		break;
+	}
+	rssi_avg = odm_convert_to_db(rssi_linear);
+
+	return rssi_avg;
+}
+
+void phydm_process_rssi_for_dm(struct dm_struct *dm,
+			       struct phydm_phyinfo_struct *phy_info,
+			       struct phydm_perpkt_info_struct *pktinfo)
+{
+	s32 rssi_ave = 0; /*@average among all paths*/
+	s8 rssi_all = 0; /*@average value of CCK & OFDM*/
+	s8 rssi_cck_tmp = 0, rssi_ofdm_tmp = 0;
+	u8 i = 0;
+	u8 rssi_max = 0, rssi_min = 0;
+	u32 w1 = 0, w2 = 0; /*weighting*/
+	u8 send_rssi_2_fw = 0;
+	u8 *rssi_tmp = NULL;
+	struct cmn_sta_info *sta = NULL;
+	struct rssi_info *rssi_t = NULL;
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	#endif
+	#endif
+
+	if (pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
+		return;
+
+	#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
+	odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(dm, phy_info, pktinfo);
+	#endif
+
+	sta = dm->phydm_sta_info[pktinfo->station_id];
+
+	if (!is_sta_active(sta))
+		return;
+
+	rssi_t = &sta->rssi_stat;
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+	if ((dm->support_ability & ODM_BB_ANT_DIV) &&
+	    fat_tab->enable_ctrl_frame_antdiv) {
+		if (pktinfo->is_packet_match_bssid)
+			dm->data_frame_num++;
+
+		if (fat_tab->use_ctrl_frame_antdiv) {
+			if (!pktinfo->is_to_self) /*@data frame + CTRL frame*/
+				return;
+		} else {
+			/*@data frame only*/
+			if (!pktinfo->is_packet_match_bssid)
+				return;
 		}
+	} else
+	#endif
+	#endif
+	{
+		if (!pktinfo->is_packet_match_bssid) /*@data frame only*/
+			return;
+	}
 
-		/*(3)PWDB, Average PWDB calculated by hardware (for rate adaptive)*/
+	if (pktinfo->is_packet_beacon) {
+		dm->phy_dbg_info.num_qry_beacon_pkt++;
+		dm->phy_dbg_info.beacon_phy_rate = pktinfo->data_rate;
+	}
 
-		/*2012.05.25 LukeLee: Testchip AGC report is wrong, it should be restored back to old formula in MP chip*/
-		if ((p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)) && (!p_dm->is_mp_chip))
-			rx_pwr_all = (p_phy_sta_rpt->pwdb_all & 0x7f) - 110;
-		else
-			rx_pwr_all = (((p_phy_sta_rpt->pwdb_all) >> 1) & 0x7f) - 110;	 /*OLD FORMULA*/
+	/* @--------------Statistic for antenna/path diversity--------------- */
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	if (dm->support_ability & ODM_BB_ANT_DIV)
+		odm_process_rssi_for_ant_div(dm, phy_info, pktinfo);
+	#endif
 
-		PWDB_ALL_BT = PWDB_ALL = phydm_query_rx_pwr_percentage(rx_pwr_all);
+	#if (defined(CONFIG_PATH_DIVERSITY))
+	if (dm->support_ability & ODM_BB_PATH_DIV)
+		phydm_process_rssi_for_path_div(dm, phy_info, pktinfo);
+	#endif
+	/* @----------------------------------------------------------------- */
 
-		p_phy_info->rx_pwdb_all = PWDB_ALL;
-		/*PHYDM_DBG(p_dm,DBG_RSSI_MNTR, ("ODM OFDM RSSI=%d\n",p_phy_info->rx_pwdb_all));*/
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-		p_phy_info->bt_rx_rssi_percentage = PWDB_ALL_BT;
-		p_phy_info->rx_power = rx_pwr_all;
-		p_phy_info->recv_signal_power = rx_pwr_all;
-#endif
+	rssi_cck_tmp = rssi_t->rssi_cck;
+	rssi_ofdm_tmp = rssi_t->rssi_ofdm;
+	rssi_all = rssi_t->rssi;
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		if (p_dm->iot_table.win_patch_id == RT_CID_819X_LENOVO) {
-			/*do nothing*/
-		} else 
-#endif
+	if (!(pktinfo->is_packet_to_self || pktinfo->is_packet_beacon))
+		return;
+
+	if (!pktinfo->is_cck_rate) {
+/* @=== [ofdm RSSI] ======================================================== */
+		rssi_tmp = phy_info->rx_mimo_signal_strength;
+
+		#if (RTL8814A_SUPPORT == 1)
+		if (dm->support_ic_type & (ODM_RTL8814A)) {
+			rssi_ave = phydm_get_rssi_8814_ofdm(dm, rssi_tmp);
+		} else
+		#endif
 		{
-			/*(4)EVM of OFDM rate*/
-
-			if ((p_pktinfo->data_rate >= ODM_RATEMCS8) &&
-				(p_pktinfo->data_rate <= ODM_RATEMCS15))
-				max_spatial_stream = 2;
-			else if ((p_pktinfo->data_rate >= ODM_RATEVHTSS2MCS0) &&
-				 (p_pktinfo->data_rate <= ODM_RATEVHTSS2MCS9))
-				max_spatial_stream = 2;
-			else if ((p_pktinfo->data_rate >= ODM_RATEMCS16) &&
-				 (p_pktinfo->data_rate <= ODM_RATEMCS23))
-				max_spatial_stream = 3;
-			else if ((p_pktinfo->data_rate >= ODM_RATEVHTSS3MCS0) &&
-				 (p_pktinfo->data_rate <= ODM_RATEVHTSS3MCS9))
-				max_spatial_stream = 3;
-			else
-				max_spatial_stream = 1;
-
-			/*if (p_pktinfo->is_packet_match_bssid) */
-			{
-				/*dbg_print("p_pktinfo->data_rate = %d\n", p_pktinfo->data_rate);*/
-
-				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.*/
-
-					if (p_pktinfo->data_rate >= ODM_RATE6M && p_pktinfo->data_rate <= ODM_RATE54M) {
-						if (i == RF_PATH_A) {
-							EVM = phydm_evm_db_to_percentage((p_phy_sta_rpt->sigevm));	/*dbm*/
-							EVM += 20;
-							if (EVM > 100)
-								EVM = 100;
-						}
-					} else {
-						if (i < RF_PATH_C) {
-							if (p_phy_sta_rpt->rxevm[i] == -128)
-								p_phy_sta_rpt->rxevm[i] = -25;
-							EVM = phydm_evm_db_to_percentage((p_phy_sta_rpt->rxevm[i]));	/*dbm*/
-						} else {
-							if (p_phy_sta_rpt->rxevm_cd[i - 2] == -128)
-								p_phy_sta_rpt->rxevm_cd[i - 2] = -25;
-							EVM = phydm_evm_db_to_percentage((p_phy_sta_rpt->rxevm_cd[i - 2]));	/*dbm*/
-						}
-					}
-
-					if (i < RF_PATH_C)
-						evm_dbm = phydm_evm_dbm_jaguar_series(p_phy_sta_rpt->rxevm[i]);
-					else
-						evm_dbm = phydm_evm_dbm_jaguar_series(p_phy_sta_rpt->rxevm_cd[i - 2]);
-					/*RT_DISP(FRX, RX_PHY_SQ, ("RXRATE=%x RXEVM=%x EVM=%s%d\n",*/
-					/*p_pktinfo->data_rate, p_phy_sta_rpt->rxevm[i], "%", EVM));*/
-
-					{
-						if (i == RF_PATH_A) {
-							/*Fill value in RFD, Get the first spatial stream only*/
-							p_phy_info->signal_quality = EVM;
-						}
-						p_phy_info->rx_mimo_signal_quality[i] = EVM;
-#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-						p_phy_info->rx_mimo_evm_dbm[i] = evm_dbm;
-#endif
-					}
+			if (rssi_tmp[RF_PATH_B] == 0) {
+				rssi_ave = rssi_tmp[RF_PATH_A];
+			} else {
+				if (rssi_tmp[RF_PATH_A] > rssi_tmp[RF_PATH_B]) {
+					rssi_max = rssi_tmp[RF_PATH_A];
+					rssi_min = rssi_tmp[RF_PATH_B];
+				} else {
+					rssi_max = rssi_tmp[RF_PATH_B];
+					rssi_min = rssi_tmp[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;
 			}
 		}
 
-		num_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
-		odm_parsing_cfo(p_dm, p_pktinfo, p_phy_sta_rpt->cfotail, num_ss);
+		/* OFDM MA RSSI */
+		if (rssi_ofdm_tmp <= 0) { /* @initialize */
+			rssi_ofdm_tmp = (s8)phy_info->rx_pwdb_all;
+		} else {
+			rssi_ofdm_tmp = (s8)WEIGHTING_AVG(rssi_ofdm_tmp,
+							  (1 << RSSI_MA) - 1,
+							  rssi_ave, 1);
+			if (phy_info->rx_pwdb_all > (u32)rssi_ofdm_tmp)
+				rssi_ofdm_tmp++;
+		}
+
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "rssi_ofdm=%d\n", rssi_ofdm_tmp);
+	} else {
+/* @=== [cck RSSI] ========================================================= */
+		rssi_ave = phy_info->rx_pwdb_all;
+
+		if (rssi_t->cck_pkt_cnt <= 63)
+			rssi_t->cck_pkt_cnt++;
+
+		/* @1 Process CCK RSSI */
+		if (rssi_cck_tmp <= 0) { /* @initialize */
+			rssi_cck_tmp = (s8)phy_info->rx_pwdb_all;
+			rssi_t->cck_sum_power = (u16)phy_info->rx_pwdb_all;
+			rssi_t->cck_pkt_cnt = 1; /*reset*/
+			PHYDM_DBG(dm, DBG_RSSI_MNTR, "[1]CCK_INIT\n");
+		} else if (rssi_t->cck_pkt_cnt <= CCK_RSSI_INIT_COUNT) {
+			rssi_t->cck_sum_power = rssi_t->cck_sum_power +
+						(u16)phy_info->rx_pwdb_all;
+
+			rssi_cck_tmp = rssi_t->cck_sum_power /
+				       rssi_t->cck_pkt_cnt;
+
+			PHYDM_DBG(dm, DBG_RSSI_MNTR,
+				  "[2]SumPow=%d, cck_pkt=%d\n",
+				  rssi_t->cck_sum_power, rssi_t->cck_pkt_cnt);
+		} else {
+			rssi_cck_tmp = (s8)WEIGHTING_AVG(rssi_cck_tmp,
+							 (1 << RSSI_MA) - 1,
+							 phy_info->rx_pwdb_all,
+							 1);
+			if (phy_info->rx_pwdb_all > (u32)rssi_cck_tmp)
+				rssi_cck_tmp++;
+		}
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "rssi_cck=%d\n", rssi_cck_tmp);
+	}
+
+/* @=== [ofdm + cck weighting RSSI] ========================================= */
+	if (!pktinfo->is_cck_rate) {
+		if (rssi_t->ofdm_pkt_cnt < 8 && !(rssi_t->packet_map & BIT(7)))
+			rssi_t->ofdm_pkt_cnt++; /*OFDM packet cnt in bitmap*/
 
+		rssi_t->packet_map = (rssi_t->packet_map << 1) | BIT(0);
+	} else {
+		if (rssi_t->ofdm_pkt_cnt > 0 && rssi_t->packet_map & BIT(7))
+			rssi_t->ofdm_pkt_cnt--;
+
+		rssi_t->packet_map = rssi_t->packet_map << 1;
 	}
-	/* dbg_print("is_cck_rate= %d, p_phy_info->signal_strength=%d % PWDB_AL=%d rf_rx_num=%d\n", is_cck_rate, p_phy_info->signal_strength, PWDB_ALL, rf_rx_num); */
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
-	/*UI BSS List signal strength(in percentage), make it good looking, from 0~100.*/
-	/*It is assigned to the BSS List in GetValueFromBeaconOrProbeRsp().*/
-	if (is_cck_rate) {
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		/*2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/
-		p_phy_info->signal_strength = SignalScaleProc(p_dm->adapter, PWDB_ALL, false, true);
-#else
-		p_phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(p_dm, PWDB_ALL));/*PWDB_ALL;*/
-#endif
+	if (rssi_t->ofdm_pkt_cnt == 8) {
+		rssi_all = rssi_ofdm_tmp;
 	} else {
-		if (rf_rx_num != 0) {
-			/* 2015/01 Sean, use the best two RSSI only, suggested by Ynlin and ChenYu.*/
-			if (rf_rx_num == 1)
-				avg_rssi = best_rssi;
+		if (rssi_t->valid_bit < 8)
+			rssi_t->valid_bit++;
+
+		if (rssi_t->valid_bit == 8) {
+			if (rssi_t->ofdm_pkt_cnt > 4)
+				w1 = 64;
 			else
-				avg_rssi = (best_rssi + second_rssi) / 2;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-			/* 2012/01/12 MH Use customeris signal strength from HalComRxdDesc.c/*/
-			p_phy_info->signal_strength = SignalScaleProc(p_dm->adapter, avg_rssi, false, false);
-#else
-			p_phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(p_dm, avg_rssi));
-#endif
+				w1 = (u32)(rssi_t->ofdm_pkt_cnt << 4);
+
+			w2 = 64 - w1;
+
+			rssi_all = (s8)((w1 * (u32)rssi_ofdm_tmp +
+					 w2 * (u32)rssi_cck_tmp) >> 6);
+		} else if (rssi_t->valid_bit != 0) { /*@(valid_bit > 8)*/
+			w1 = (u32)rssi_t->ofdm_pkt_cnt;
+			w2 = (u32)(rssi_t->valid_bit - rssi_t->ofdm_pkt_cnt);
+			rssi_all = (s8)WEIGHTING_AVG((u32)rssi_ofdm_tmp, w1,
+						     (u32)rssi_cck_tmp, w2);
+		} else {
+			rssi_all = 0;
 		}
 	}
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "rssi=%d,w1=%d,w2=%d\n", rssi_all, w1, w2);
+
+	if ((rssi_t->ofdm_pkt_cnt >= 1 || rssi_t->cck_pkt_cnt >= 5) &&
+	    rssi_t->is_send_rssi == RA_RSSI_STATE_INIT) {
+		send_rssi_2_fw = 1;
+		rssi_t->is_send_rssi = RA_RSSI_STATE_SEND;
+	}
+
+	rssi_t->rssi_cck = rssi_cck_tmp;
+	rssi_t->rssi_ofdm = rssi_ofdm_tmp;
+	rssi_t->rssi = rssi_all;
+
+	if (send_rssi_2_fw) { /* Trigger init rate by RSSI */
+		if (rssi_t->ofdm_pkt_cnt != 0)
+			rssi_t->rssi = rssi_ofdm_tmp;
+
+		PHYDM_DBG(dm, DBG_RSSI_MNTR,
+			  "[Send to FW] PWDB=%d, ofdm_pkt=%d, cck_pkt=%d\n",
+			  rssi_all, rssi_t->ofdm_pkt_cnt, rssi_t->cck_pkt_cnt);
+	}
+
+#if 0
+	/* @dbg_print("ofdm_pkt=%d, weighting=%d\n", ofdm_pkt_cnt, weighting);*/
+	/* @dbg_print("rssi_ofdm_tmp=%d, rssi_all=%d, rssi_cck_tmp=%d\n", */
+	/*	rssi_ofdm_tmp, rssi_all, rssi_cck_tmp); */
 #endif
-	p_dm->rx_pwdb_ave = p_dm->rx_pwdb_ave + p_phy_info->rx_pwdb_all;
-
-	p_dm->dm_fat_table.antsel_rx_keep_0 = p_phy_sta_rpt->antidx_anta;
-	p_dm->dm_fat_table.antsel_rx_keep_1 = p_phy_sta_rpt->antidx_antb;
-	p_dm->dm_fat_table.antsel_rx_keep_2 = p_phy_sta_rpt->antidx_antc;
-	p_dm->dm_fat_table.antsel_rx_keep_3 = p_phy_sta_rpt->antidx_antd;
-
-	if (p_pktinfo->is_packet_match_bssid) {
-		phydm_avg_phystatus_index(p_dm, p_phy_info, p_pktinfo);
-		phydm_rx_statistic_cal(p_dm, p_phy_status, p_pktinfo);
-	}
-	/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("StaID[%d]:  antidx_anta = ((%d)), MatchBSSID =  ((%d))\n", p_pktinfo->station_id, p_phy_sta_rpt->antidx_anta, p_pktinfo->is_packet_match_bssid));*/
-
-
-	/*		dbg_print("p_phy_sta_rpt->antidx_anta = %d, p_phy_sta_rpt->antidx_antb = %d\n",*/
-	/*			p_phy_sta_rpt->antidx_anta, p_phy_sta_rpt->antidx_antb);*/
-	/*		dbg_print("----------------------------\n");*/
-	/*		dbg_print("p_pktinfo->station_id=%d, p_pktinfo->data_rate=0x%x\n",p_pktinfo->station_id, p_pktinfo->data_rate);*/
-	/*		dbg_print("p_phy_sta_rpt->r_RFMOD = %d\n", p_phy_sta_rpt->r_RFMOD);*/
-	/*		dbg_print("p_phy_sta_rpt->gain_trsw[0]=0x%x, p_phy_sta_rpt->gain_trsw[1]=0x%x\n",*/
-	/*				p_phy_sta_rpt->gain_trsw[0],p_phy_sta_rpt->gain_trsw[1]);*/
-	/*		dbg_print("p_phy_sta_rpt->gain_trsw[2]=0x%x, p_phy_sta_rpt->gain_trsw[3]=0x%x\n",*/
-	/*				p_phy_sta_rpt->gain_trsw_cd[0],p_phy_sta_rpt->gain_trsw_cd[1]);*/
-	/*		dbg_print("p_phy_sta_rpt->pwdb_all = 0x%x, p_phy_info->rx_pwdb_all = %d\n", p_phy_sta_rpt->pwdb_all, p_phy_info->rx_pwdb_all);*/
-	/*		dbg_print("p_phy_sta_rpt->cfotail[i] = 0x%x, p_phy_sta_rpt->CFO_tail[i] = 0x%x\n", p_phy_sta_rpt->cfotail[0], p_phy_sta_rpt->cfotail[1]);*/
-	/*		dbg_print("p_phy_sta_rpt->rxevm[0] = %d, p_phy_sta_rpt->rxevm[1] = %d\n", p_phy_sta_rpt->rxevm[0], p_phy_sta_rpt->rxevm[1]);*/
-	/*		dbg_print("p_phy_sta_rpt->rxevm[2] = %d, p_phy_sta_rpt->rxevm[3] = %d\n", p_phy_sta_rpt->rxevm_cd[0], p_phy_sta_rpt->rxevm_cd[1]);*/
-	/*		dbg_print("p_phy_info->rx_mimo_signal_strength[0]=%d, p_phy_info->rx_mimo_signal_strength[1]=%d, rx_pwdb_all=%d\n",*/
-	/*				p_phy_info->rx_mimo_signal_strength[0], p_phy_info->rx_mimo_signal_strength[1], p_phy_info->rx_pwdb_all);*/
-	/*		dbg_print("p_phy_info->rx_mimo_signal_strength[2]=%d, p_phy_info->rx_mimo_signal_strength[3]=%d\n",*/
-	/*				p_phy_info->rx_mimo_signal_strength[2], p_phy_info->rx_mimo_signal_strength[3]);*/
-	/*		dbg_print("ppPhyInfo->rx_mimo_signal_quality[0]=%d, p_phy_info->rx_mimo_signal_quality[1]=%d\n",*/
-	/*				p_phy_info->rx_mimo_signal_quality[0], p_phy_info->rx_mimo_signal_quality[1]);*/
-	/*		dbg_print("ppPhyInfo->rx_mimo_signal_quality[2]=%d, p_phy_info->rx_mimo_signal_quality[3]=%d\n",*/
-	/*				p_phy_info->rx_mimo_signal_quality[2], p_phy_info->rx_mimo_signal_quality[3]);*/
+}
+#endif
+
+#ifdef PHYSTS_3RD_TYPE_SUPPORT
+void phydm_print_phystat_jaguar3(struct dm_struct *dm, u8 *phy_sts,
+				 struct phydm_perpkt_info_struct *pktinfo,
+				 struct phydm_phyinfo_struct *phy_info)
+{
+	struct phy_sts_rpt_jgr3_type0 *rpt0 = NULL;
+	struct phy_sts_rpt_jgr3_type1 *rpt1 = NULL;
+	struct phy_sts_rpt_jgr3_type2_3 *rpt2 = NULL;
+	struct phy_sts_rpt_jgr3_type4 *rpt3 = NULL;
+	struct phy_sts_rpt_jgr3_type5 *rpt4 = NULL;
+	struct odm_phy_dbg_info *dbg = &dm->phy_dbg_info;
+	u8 phy_status_page_num = (*phy_sts & 0xf);
+	u32 phy_status_tmp[PHY_STATUS_JRGUAR3_DW_LEN] = {0};
+	u8 i = 0;
+	u32 size = PHY_STATUS_JRGUAR3_DW_LEN << 2;
+
+	rpt0 = (struct phy_sts_rpt_jgr3_type0 *)phy_sts;
+	rpt1 = (struct phy_sts_rpt_jgr3_type1 *)phy_sts;
+	rpt2 = (struct phy_sts_rpt_jgr3_type2_3 *)phy_sts;
+	rpt3 = (struct phy_sts_rpt_jgr3_type4 *)phy_sts;
+	rpt4 = (struct phy_sts_rpt_jgr3_type5 *)phy_sts;
+
+	odm_move_memory(dm, phy_status_tmp, phy_sts, size);
+	if (!(dm->debug_components & DBG_PHY_STATUS))
+		return;
+
+	if (dbg->show_phy_sts_all_pkt == 0) {
+		if (!pktinfo->is_packet_match_bssid)
+			return;
+	}
 
+	dbg->show_phy_sts_cnt++;
+
+	if (dbg->show_phy_sts_max_cnt != SHOW_PHY_STATUS_UNLIMITED) {
+		if (dbg->show_phy_sts_cnt > dbg->show_phy_sts_max_cnt)
+			return;
+	}
+
+	if (phy_status_page_num == 0)
+		pr_debug("Phy Status Rpt: CCK\n");
+	else
+		pr_debug("Phy Status Rpt: OFDM_%d\n", phy_status_page_num);
+
+	pr_debug("StaID=%d, RxRate = 0x%x match_bssid=%d\n",
+		 pktinfo->station_id, pktinfo->data_rate,
+		 pktinfo->is_packet_match_bssid);
+
+	for (i = 0; i < PHY_STATUS_JRGUAR3_DW_LEN; i++)
+		pr_debug("Offset[%d:%d] = 0x%x\n",
+			 ((4 * i) + 3), (4 * i), phy_status_tmp[i]);
+
+	if (phy_status_page_num == 0) { /* @CCK(default) */
+		pr_debug("[0] Pkt_cnt=%d, Channel_msb=%d, Pwdb_a=%d, Gain_a=%d, TRSW=%d, AGC_table_b=%d, AGC_table_c=%d,\n",
+			 rpt0->pkt_cnt, rpt0->channel_msb, rpt0->pwdb_a,
+			 rpt0->gain_a, rpt0->trsw, rpt0->agc_table_b,
+			 rpt0->agc_table_c);
+		pr_debug("[4] Path_Sel_o=%d, Gnt_BT_keep_cnt=%d, HW_AntSW_occur_keep_cck=%d,\n Band=%d, Channel=%d, AGC_table_a=%d, l_RXSC=%d, AGC_table_d=%d\n",
+			 rpt0->path_sel_o, rpt0->gnt_bt_keep_cck,
+			 rpt0->hw_antsw_occur_keep_cck, rpt0->band,
+			 rpt0->channel, rpt0->agc_table_a, rpt0->l_rxsc,
+			 rpt0->agc_table_d);
+		pr_debug("[8] AntIdx={%d, %d, %d, %d}, Length=%d\n",
+			 rpt0->antidx_d, rpt0->antidx_c, rpt0->antidx_b,
+			 rpt0->antidx_a, rpt0->length);
+		pr_debug("[12] MF_off=%d, SQloss=%d, lockbit=%d, raterr=%d, rxrate=%d, lna_h_a=%d, CCK_BB_power_a=%d, lna_l_a=%d, vga_a=%d, sq=%d\n",
+			 rpt0->mf_off, rpt0->sqloss, rpt0->lockbit,
+			 rpt0->raterr, rpt0->rxrate, rpt0->lna_h_a,
+			 rpt0->bb_power_a, rpt0->lna_l_a, rpt0->vga_a,
+			 rpt0->signal_quality);
+		pr_debug("[16] Gain_b=%d, lna_h_b=%d, CCK_BB_power_b=%d, lna_l_b=%d, vga_b=%d, Pwdb_b=%d\n",
+			 rpt0->gain_b, rpt0->lna_h_b, rpt0->bb_power_b,
+			 rpt0->lna_l_b, rpt0->vga_b, rpt0->pwdb_b);
+		pr_debug("[20] Gain_c=%d, lna_h_c=%d, CCK_BB_power_c=%d, lna_l_c=%d, vga_c=%d, Pwdb_c=%d\n",
+			 rpt0->gain_c, rpt0->lna_h_c, rpt0->bb_power_c,
+			 rpt0->lna_l_c, rpt0->vga_c, rpt0->pwdb_c);
+		pr_debug("[24] Gain_d=%d, lna_h_d=%d, CCK_BB_power_d=%d, lna_l_d=%d, vga_d=%d, Pwdb_d=%d\n",
+			 rpt0->gain_c, rpt0->lna_h_c, rpt0->bb_power_c,
+			 rpt0->lna_l_c, rpt0->vga_c, rpt0->pwdb_c);
+	} else if (phy_status_page_num == 1) {
+		pr_debug("[0] pwdb[C:A]={%d, %d, %d}, Channel_pri_msb=%d, Pkt_cnt=%d,\n",
+			 rpt1->pwdb_c, rpt1->pwdb_b, rpt1->pwdb_a,
+			 rpt1->channel_pri_msb, rpt1->pkt_cnt);
+		pr_debug("[4] BF: %d, stbc=%d, ldpc=%d, gnt_bt=%d, band=%d, Ch_pri_lsb=%d, rxsc[ht, l]={%d, %d}, pwdb[D]=%d\n",
+			 rpt1->beamformed, rpt1->stbc, rpt1->ldpc, rpt1->gnt_bt,
+			 rpt1->band, rpt1->channel_pri_lsb, rpt1->ht_rxsc,
+			 rpt1->l_rxsc, rpt1->pwdb_d);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, HW_AntSW_occur[D:A]={%d, %d, %d, %d}, Channel_sec[msb,lsb]={%d, %d}\n",
+			 rpt1->antidx_d, rpt1->antidx_c,
+			 rpt1->antidx_b, rpt1->antidx_a,
+			 rpt1->hw_antsw_occur_d, rpt1->hw_antsw_occur_c,
+			 rpt1->hw_antsw_occur_b, rpt1->hw_antsw_occur_a,
+			 rpt1->channel_sec_msb, rpt1->channel_sec_lsb);
+		pr_debug("[12] GID=%d, PAID[msb,lsb]={%d,%d}\n",
+			 rpt1->gid, rpt1->paid_msb, rpt1->paid);
+		pr_debug("[16] RX_EVM[D:A]={%d, %d, %d, %d}\n",
+			 rpt1->rxevm[3], rpt1->rxevm[2],
+			 rpt1->rxevm[1], rpt1->rxevm[0]);
+		pr_debug("[20] CFO_tail[D:A]={%d, %d, %d, %d}\n",
+			 rpt1->cfo_tail[3], rpt1->cfo_tail[2],
+			 rpt1->cfo_tail[1], rpt1->cfo_tail[0]);
+		pr_debug("[24] RX_SNR[D:A]={%d, %d, %d, %d}\n\n",
+			 rpt1->rxsnr[3], rpt1->rxsnr[2],
+			 rpt1->rxsnr[1], rpt1->rxsnr[0]);
+	} else if (phy_status_page_num == 2 || phy_status_page_num == 3) {
+		pr_debug("[0] pwdb[C:A]={%d, %d, %d}, Channel_mdb=%d, Pkt_cnt=%d\n",
+			 rpt2->pwdb[2], rpt2->pwdb[1], rpt2->pwdb[0],
+			 rpt2->channel_msb, rpt2->pkt_cnt);
+		pr_debug("[4] BF=%d, STBC=%d, LDPC=%d, Gnt_BT=%d, band=%d, CH_lsb=%d, rxsc[ht, l]={%d, %d}, pwdb_D=%d\n",
+			 rpt2->beamformed, rpt2->stbc, rpt2->ldpc, rpt2->gnt_bt,
+			 rpt2->band, rpt2->channel_lsb,
+			 rpt2->ht_rxsc, rpt2->l_rxsc, rpt2->pwdb[3]);
+		pr_debug("[8] AgcTab[D:A]={%d, %d, %d, %d}, pwed_th=%d, shift_l_map=%d\n",
+			 rpt2->agc_table_d, rpt2->agc_table_c,
+			 rpt2->agc_table_b, rpt2->agc_table_a,
+			 rpt2->pwed_th, rpt2->shift_l_map);
+		pr_debug("[12] AvgNoisePowerdB=%d, mp_gain_c[msb, lsb]={%d, %d}, mp_gain_b[msb, lsb]={%d, %d}, mp_gain_a=%d, cnt_cca2agc_rdy=%d\n",
+			 rpt2->avg_noise_pwr_lsb, rpt2->mp_gain_c_msb,
+			 rpt2->mp_gain_c_lsb, rpt2->mp_gain_b_msb,
+			 rpt2->mp_gain_b_lsb, rpt2->mp_gain_a,
+			 rpt2->cnt_cca2agc_rdy);
+		pr_debug("[16] HT AAGC gain[B:A]={%d, %d}, AAGC step[D:A]={%d, %d, %d, %d}, IsFreqSelectFadimg=%d, mp_gain_d=%d\n",
+			 rpt2->ht_aagc_gain[1], rpt2->ht_aagc_gain[0],
+			 rpt2->aagc_step_d, rpt2->aagc_step_c,
+			 rpt2->aagc_step_b, rpt2->aagc_step_a,
+			 rpt2->is_freq_select_fading, rpt2->mp_gain_d);
+		pr_debug("[20] DAGC gain ant[B:A]={%d, %d}, HT AAGC gain[D:C]={%d, %d}\n",
+			 rpt2->dagc_gain[1], rpt2->dagc_gain[0],
+			 rpt2->ht_aagc_gain[3], rpt2->ht_aagc_gain[2]);
+		pr_debug("[24] AvgNoisePwerdB=%d, syn_count[msb, lsb]={%d, %d}, counter=%d, DAGC gain ant[D:C]={%d, %d}\n",
+			 rpt2->avg_noise_pwr_msb, rpt2->syn_count_msb,
+			 rpt2->syn_count_lsb, rpt2->counter,
+			 rpt2->dagc_gain[3], rpt2->dagc_gain[2]);
+	} else if (phy_status_page_num == 4) { /*type 4*/
+		pr_debug("[0] pwdb[C:A]={%d, %d, %d}, Channel_mdb=%d, Pkt_cnt=%d\n",
+			 rpt3->pwdb[2], rpt3->pwdb[1], rpt3->pwdb[0],
+			 rpt3->channel_msb, rpt3->pkt_cnt);
+		pr_debug("[4] BF=%d, STBC=%d, LDPC=%d, GNT_BT=%d, band=%d, CH_pri=%d, rxsc[ht, l]={%d, %d}, pwdb_D=%d\n",
+			 rpt3->beamformed, rpt3->stbc, rpt3->ldpc, rpt3->gnt_bt,
+			 rpt3->band, rpt3->channel_lsb, rpt3->ht_rxsc,
+			 rpt3->l_rxsc, rpt3->pwdb[3]);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, HW_AntSW_occur[D:A]={%d, %d, %d, %d}, Training_done[D:A]={%d, %d, %d, %d},\n    BadToneCnt_CN_excess_0=%d, BadToneCnt_min_eign_0=%d\n",
+			 rpt3->antidx_d, rpt3->antidx_c,
+			 rpt3->antidx_b, rpt3->antidx_a,
+			 rpt3->hw_antsw_occur_d, rpt3->hw_antsw_occur_c,
+			 rpt3->hw_antsw_occur_b, rpt3->hw_antsw_occur_a,
+			 rpt3->training_done_d, rpt3->training_done_c,
+			 rpt3->training_done_b, rpt3->training_done_a,
+			 rpt3->bad_tone_cnt_cn_excess_0,
+			 rpt3->bad_tone_cnt_min_eign_0);
+		pr_debug("[12] avg_cond_num_1_msb=%d, avg_cond_num_1_lsb=%d, avg_cond_num_0=%d, bad_tone_cnt_cn_excess_1=%d,\n     bad_tone_cnt_min_eign_1=%d, Tx_pkt_cnt=%d\n",
+			 rpt3->avg_cond_num_1_msb, rpt3->avg_cond_num_1_lsb,
+			 rpt3->avg_cond_num_0, rpt3->bad_tone_cnt_cn_excess_1,
+			 rpt3->bad_tone_cnt_min_eign_1, rpt3->tx_pkt_cnt);
+		pr_debug("[16] Stream RXEVM[D:A]={%d, %d, %d, %d}\n",
+			 rpt3->rxevm[3], rpt3->rxevm[2],
+			 rpt3->rxevm[1], rpt3->rxevm[0]);
+		pr_debug("[20] Eigenvalue[D:A]={%d, %d, %d, %d}\n",
+			 rpt3->eigenvalue[3], rpt3->eigenvalue[2],
+			 rpt3->eigenvalue[1], rpt3->eigenvalue[0]);
+		pr_debug("[24] RX SNR[D:A]={%d, %d, %d, %d}\n",
+			 rpt3->rxsnr[3], rpt3->rxsnr[2],
+			 rpt3->rxsnr[1], rpt3->rxsnr[0]);
+	} else if (phy_status_page_num == 5) { /*type 5*/
+		pr_debug("[0] pwdb[C:A]={%d, %d, %d}, Channel_mdb=%d, Pkt_cnt=%d\n",
+			 rpt4->pwdb[2], rpt4->pwdb[1], rpt4->pwdb[0],
+			 rpt4->channel_msb, rpt4->pkt_cnt);
+		pr_debug("[4] BF=%d, STBC=%d, LDPC=%d, GNT_BT=%d, band=%d, CH_pri=%d, rxsc[ht, l]={%d, %d}, pwdb_D=%d\n",
+			 rpt4->beamformed, rpt4->stbc, rpt4->ldpc, rpt4->gnt_bt,
+			 rpt4->band, rpt4->channel_lsb, rpt4->ht_rxsc,
+			 rpt4->l_rxsc, rpt4->pwdb[3]);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, HW_AntSW_occur[D:A]={%d, %d, %d, %d}\n",
+			 rpt4->antidx_d, rpt4->antidx_c,
+			 rpt4->antidx_b, rpt4->antidx_a,
+			 rpt4->hw_antsw_occur_d, rpt4->hw_antsw_occur_c,
+			 rpt4->hw_antsw_occur_b, rpt4->hw_antsw_occur_a);
+		pr_debug("[12] Inf_posD[1,0]={%d, %d}, Inf_posC[1,0]={%d, %d}, Inf_posB[1,0]={%d, %d}, Inf_posA[1,0]={%d, %d}, Tx_pkt_cnt=%d\n",
+			 rpt4->inf_pos_1_D_flg, rpt4->inf_pos_0_D_flg,
+			 rpt4->inf_pos_1_C_flg, rpt4->inf_pos_0_C_flg,
+			 rpt4->inf_pos_1_B_flg, rpt4->inf_pos_0_B_flg,
+			 rpt4->inf_pos_1_A_flg, rpt4->inf_pos_0_A_flg,
+			 rpt4->tx_pkt_cnt);
+		pr_debug("[16] Inf_pos_B[1,0]={%d, %d}, Inf_pos_A[1,0]={%d, %d}\n",
+			 rpt4->inf_pos_1_b, rpt4->inf_pos_0_b,
+			 rpt4->inf_pos_1_a, rpt4->inf_pos_0_a);
+		pr_debug("[20] Inf_pos_D[1,0]={%d, %d}, Inf_pos_C[1,0]={%d, %d}\n",
+			 rpt4->inf_pos_1_d, rpt4->inf_pos_0_d,
+			 rpt4->inf_pos_1_c, rpt4->inf_pos_0_c);
+	}
 }
 
-#endif
+void phydm_reset_phy_info_3rd(struct dm_struct *phydm,
+			      struct phydm_phyinfo_struct *phy_info)
+{
+	phy_info->rx_pwdb_all = 0;
+	phy_info->signal_quality = 0;
+	phy_info->band_width = 0;
+	phy_info->rx_count = 0;
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_quality, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_strength, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_snr, 0, 4);
+
+	phy_info->rx_power = -110;
+	phy_info->recv_signal_power = -110;
+	phy_info->bt_rx_rssi_percentage = 0;
+	phy_info->signal_strength = 0;
+	phy_info->channel = 0;
+	phy_info->is_mu_packet = 0;
+	phy_info->is_beamformed = 0;
+	phy_info->rxsc = 0;
+	odm_memory_set(phydm, phy_info->rx_pwr, -110, 4);
+	odm_memory_set(phydm, phy_info->cfo_short, 0, 8);
+	odm_memory_set(phydm, phy_info->cfo_tail, 0, 8);
+
+	odm_memory_set(phydm, phy_info->rx_mimo_evm_dbm, 0, 4);
+}
 
-void
-phydm_reset_rssi_for_dm(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		station_id
-)
+void phydm_per_path_info_3rd(u8 rx_path, s8 pwr, s8 rx_evm, s8 cfo_tail,
+			     s8 rx_snr, struct phydm_phyinfo_struct *phy_info)
 {
-	struct cmn_sta_info		*p_sta;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-#endif
-	p_sta = p_dm->p_phydm_sta_info[station_id];
+	u8 evm_dbm = 0;
+	u8 evm_percentage = 0;
 
-	if (!is_sta_active(p_sta)) {
-		/**/
-		return;
+	/* SNR is S(8,1), EVM is S(8,1), CFO is S(8,7) */
+
+	if (rx_evm < 0) {
+		/* @Calculate EVM in dBm */
+		evm_dbm = ((u8)(0 - rx_evm) >> 1);
+
+		if (evm_dbm == 64)
+			evm_dbm = 0; /*@if 1SS rate, evm_dbm [2nd stream] =64*/
+
+		if (evm_dbm != 0) {
+			/* @Convert EVM to 0%~100% percentage */
+			if (evm_dbm >= 34)
+				evm_percentage = 100;
+			else
+				evm_percentage = (evm_dbm << 1) + (evm_dbm);
+		}
 	}
-	PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("Reset RSSI for macid = (( %d ))\n", station_id));
 
+	phy_info->rx_pwr[rx_path] = pwr;
 
-	p_sta->rssi_stat.rssi_cck = -1;
-	p_sta->rssi_stat.rssi_ofdm = -1;
-	p_sta->rssi_stat.rssi = -1;
-	p_sta->rssi_stat.ofdm_pkt_cnt = 0;
-	p_sta->rssi_stat.cck_pkt_cnt = 0;
-	p_sta->rssi_stat.cck_sum_power = 0;
-	p_sta->rssi_stat.is_send_rssi = RA_RSSI_STATE_INIT;
-	p_sta->rssi_stat.packet_map = 0;
-	p_sta->rssi_stat.valid_bit = 0;
+	/*@CFO(kHz) = CFO_tail * 312.5(kHz) / 2^7 ~= CFO tail * 5/2 (kHz)*/
+	phy_info->cfo_tail[rx_path] = (cfo_tail * 5) >> 1;
+	phy_info->rx_mimo_evm_dbm[rx_path] = evm_dbm;
+	phy_info->rx_mimo_signal_strength[rx_path] = phydm_pwr_2_percent(pwr);
+	phy_info->rx_mimo_signal_quality[rx_path] = evm_percentage;
+	phy_info->rx_snr[rx_path] = rx_snr >> 1;
+}
 
-	/*in WIN Driver: sta_ID==0->p_entry==NULL -> default port HAL_Data*/
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	p_sta->dm_ctrl = p_sta->dm_ctrl & (~STA_DM_CTRL_ACTIVE);
-	if (station_id == 0) {
+void phydm_common_phy_info_3rd(s8 rx_power, u8 channel, boolean is_beamformed,
+			       boolean is_mu_packet, u8 bandwidth,
+			       u8 signal_quality, u8 rxsc,
+			       struct phydm_phyinfo_struct *phy_info)
+{
+	phy_info->rx_power = rx_power; /* RSSI in dB */
+	phy_info->recv_signal_power = rx_power; /* RSSI in dB */
+	phy_info->channel = channel; /* @channel number */
+	phy_info->is_beamformed = is_beamformed; /* @apply BF */
+	phy_info->is_mu_packet = is_mu_packet; /* @MU packet */
+	phy_info->rxsc = rxsc;
+
+	phy_info->rx_pwdb_all = phydm_pwr_2_percent(rx_power); /*percentage */
+	phy_info->signal_quality = signal_quality; /* signal quality */
+	phy_info->band_width = bandwidth; /* @bandwidth */
 
-		p_hal_data->UndecoratedSmoothedPWDB = -1;
-		/**/
+#if 0
+	/* @if (pktinfo->is_packet_match_bssid) */
+	{
+		dbg_print("rx_pwdb_all = %d, rx_power = %d, recv_signal_power = %d\n", phy_info->rx_pwdb_all, phy_info->rx_power, phy_info->recv_signal_power);
+		dbg_print("signal_quality = %d\n", phy_info->signal_quality);
+		dbg_print("is_beamformed = %d, is_mu_packet = %d, rx_count = %d\n", phy_info->is_beamformed, phy_info->is_mu_packet, phy_info->rx_count + 1);
+		dbg_print("channel = %d, rxsc = %d, band_width = %d\n", channel, rxsc, bandwidth);
 	}
 #endif
+}
+
+void phydm_get_physts_jarguar3_0(struct dm_struct *dm, u8 *phy_status_inf,
+				 struct phydm_perpkt_info_struct *pktinfo,
+				 struct phydm_phyinfo_struct *phy_info)
+{
+	/* type 0 is used for cck packet */
+	struct phy_sts_rpt_jgr3_type0 *phy_sts = NULL;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	u8 sq = 0, i;
+	s8 rx_power[4];
+	s8 rx_pwr_db_max = -120;
+
+	phy_sts = (struct phy_sts_rpt_jgr3_type0 *)phy_status_inf;
+
+	/* Setting the RX power: agc_idx -110 dBm*/
+	rx_power[0] = phy_sts->pwdb_a - 110;
+	rx_power[1] = phy_sts->pwdb_b - 110;
+	rx_power[2] = phy_sts->pwdb_c - 110;
+	rx_power[3] = phy_sts->pwdb_d - 110;
+
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (rx_power[i] > rx_pwr_db_max)
+			rx_pwr_db_max = rx_power[0];   /*only one path*/
+	}
+	if (pktinfo->is_to_self) {
+		dm->ofdm_agc_idx[0] = phy_sts->pwdb_a;
+		dm->ofdm_agc_idx[1] = phy_sts->pwdb_b;
+		dm->ofdm_agc_idx[2] = phy_sts->pwdb_c;
+		dm->ofdm_agc_idx[3] = phy_sts->pwdb_d;
+	}
+
+	/* @Calculate Signal Quality*/
+	if (phy_sts->signal_quality >= 64) {
+		sq = 0;
+	} else if (phy_sts->signal_quality <= 20) {
+		sq = 100;
+	} else {
+		/* @mapping to 2~99% */
+		sq = 64 - phy_sts->signal_quality;
+		sq = ((sq << 3) + sq) >> 2;
+	}
 
+	/* @Modify CCK PWDB if old AGC */
+	if (!dm->cck_new_agc) {
+		u8 lna_idx[4], vga_idx[4];
+
+		lna_idx[0] = ((phy_sts->lna_h_a << 3) | phy_sts->lna_l_a);
+		vga_idx[0] = phy_sts->vga_a;
+		lna_idx[1] = ((phy_sts->lna_h_b << 3) | phy_sts->lna_l_b);
+		vga_idx[1] = phy_sts->vga_b;
+		lna_idx[2] = ((phy_sts->lna_h_c << 3) | phy_sts->lna_l_c);
+		vga_idx[2] = phy_sts->vga_c;
+		lna_idx[3] = ((phy_sts->lna_h_d << 3) | phy_sts->lna_l_d);
+		vga_idx[3] = phy_sts->vga_d;
+		#if (RTL8198F_SUPPORT)
+			/*phydm_cck_rssi_8198f*/
+		#endif
+	}
+
+	/*@CCK no STBC and LDPC*/
+	dbg_i->is_ldpc_pkt = false;
+	dbg_i->is_stbc_pkt = false;
+
+	/* Update Common information */
+	phydm_common_phy_info_3rd(rx_pwr_db_max, phy_sts->channel, false,
+				  false, CHANNEL_WIDTH_20, sq,
+				  phy_sts->l_rxsc, phy_info);
+
+	/* Update CCK pwdb */
+	/* Update per-path information */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++)
+		phydm_per_path_info_3rd(i, rx_power[i], 0, 0, 0, phy_info);
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sts->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sts->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sts->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sts->antidx_d;
+	#endif
 }
 
-void
-phydm_process_rssi_for_dm(
-	struct PHY_DM_STRUCT					*p_dm,
-	struct phydm_phyinfo_struct			*p_phy_info,
-	struct phydm_perpkt_info_struct			*p_pktinfo
-)
+void phydm_get_physts_jarguar3_1(struct dm_struct *dm, u8 *phy_status_inf,
+				 struct phydm_perpkt_info_struct *pktinfo,
+				 struct phydm_phyinfo_struct *phy_info)
 {
+	/* type 1 is used for ofdm packet */
+	struct phy_sts_rpt_jgr3_type1 *phy_sts = NULL;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	s8 rx_pwr_db = -120;
+	s8 rx_path_pwr_db;
+	u8 i, rxsc, bw = CHANNEL_WIDTH_20, rx_cnt = 0;
+	u8 pwdb[4];
+	boolean is_mu;
 
-	s32			rssi_ave;
-	s8			undecorated_smoothed_pwdb, undecorated_smoothed_cck, undecorated_smoothed_ofdm;
-	u8			i, is_cck_rate = 0;
-	u8			RSSI_max, RSSI_min;
-	u32			weighting = 0;
-	u8			send_rssi_2_fw = 0;
-	struct cmn_sta_info		*p_sta;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-#endif
+	phy_sts = (struct phy_sts_rpt_jgr3_type1 *)phy_status_inf;
 
-	if (p_pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
-		return;
+	pwdb[0] = phy_sts->pwdb_a;
+	pwdb[1] = phy_sts->pwdb_b;
+	pwdb[2] = phy_sts->pwdb_c;
+	pwdb[3] = phy_sts->pwdb_d;
+
+	/* Update per-path information */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			rx_cnt++; /* @check the number of the ant */
+
+			if (rx_cnt > dm->num_rf_path)
+				break;
+
+			/* Update per-path information
+			 * (RSSI_dB RSSI_percentage EVM SNR CFO sq)
+			 */
+			/* @EVM report is reported by stream, not path */
+			rx_path_pwr_db = pwdb[i] - 110; /* per-path pw (dB)*/
+
+			if (pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = pwdb[i];
+
+			phydm_per_path_info_3rd(i, rx_path_pwr_db,
+						phy_sts->rxevm[rx_cnt - 1],
+						phy_sts->cfo_tail[i],
+						phy_sts->rxsnr[i], phy_info);
+
+			/*@CFO(kHz) = CFO_tail*312.5/2^7 ~= CFO tail*5/2*/
+			dbg_i->cfo_tail[i] = (phy_sts->cfo_tail[i] * 5) >> 1;
+			/* search maximum pwdb */
+			if (rx_path_pwr_db > rx_pwr_db)
+				rx_pwr_db = rx_path_pwr_db;
+		}
+	}
+
+	/* @mapping RX counter from 1~4 to 0~3 */
+	if (rx_cnt > 0)
+		phy_info->rx_count = rx_cnt - 1;
+
+	/* @Check if MU packet or not */
+	if (phy_sts->gid != 0 && phy_sts->gid != 63) {
+		is_mu = true;
+		dbg_i->num_qry_mu_pkt++;
+	} else {
+		is_mu = false;
+	}
+
+	/* @count BF packet */
+	dbg_i->num_qry_bf_pkt = dbg_i->num_qry_bf_pkt + phy_sts->beamformed;
+
+	/*STBC or LDPC pkt*/
+	dbg_i->is_ldpc_pkt = phy_sts->ldpc;
+	dbg_i->is_stbc_pkt = phy_sts->stbc;
+
+	/* @Check sub-channel */
+	if (pktinfo->data_rate > ODM_RATE11M &&
+	    pktinfo->data_rate < ODM_RATEMCS0)
+		rxsc = phy_sts->l_rxsc; /*@Legacy*/
+	else
+		rxsc = phy_sts->ht_rxsc; /* @HT and VHT */
+
+	/* @Check RX bandwidth */
+	if (rxsc >= 1 && rxsc <= 8)
+		bw = CHANNEL_WIDTH_20;
+	else if ((rxsc >= 9) && (rxsc <= 12))
+		bw = CHANNEL_WIDTH_40;
+	else if (rxsc >= 13)
+		bw = CHANNEL_WIDTH_80;
+	else
+		bw = *dm->band_width;
+
+	/* Update packet information */
+	/* RX power choose the path with the maximum power */
+	phydm_common_phy_info_3rd(rx_pwr_db, phy_sts->channel_pri_lsb,
+				  (boolean)phy_sts->beamformed, is_mu,
+				  bw, phy_info->rx_mimo_signal_quality[0],
+				  rxsc, phy_info);
+
+	phydm_parsing_cfo(dm, pktinfo, phy_sts->cfo_tail, pktinfo->rate_ss);
 
-#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
-	odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(p_dm, p_phy_info, p_pktinfo);
+#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sts->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sts->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sts->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sts->antidx_d;
 #endif
+}
+
+void phydm_get_physts_jarguar3_2_3(struct dm_struct *dm, u8 *phy_status_inf,
+				   struct phydm_perpkt_info_struct *pktinfo,
+				   struct phydm_phyinfo_struct *phy_info)
+{
+	/* type 2 & 3 is used for ofdm packet */
+	struct phy_sts_rpt_jgr3_type2_3 *phy_sts = NULL;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	s8 rx_pwr_db_max = -120;
+	s8 rx_path_pwr_db = 0;
+	u8 i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
 
-	p_sta = p_dm->p_phydm_sta_info[p_pktinfo->station_id];
+	phy_sts = (struct phy_sts_rpt_jgr3_type2_3 *)phy_status_inf;
 
-	if (!is_sta_active(p_sta)) {
-		return;
-		/**/
+	/* Update per-path information */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			rx_count++; /* @check the number of the ant */
+
+			if (rx_count > dm->num_rf_path)
+				break;
+
+			/* Update per-path information
+			 * (RSSI_dB RSSI_percentage EVM SNR CFO sq)
+			 */
+			/* @EVM report is reported by stream, not path */
+			rx_path_pwr_db = phy_sts->pwdb[i] - 110; /*@dB*/
+
+			if (pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = phy_sts->pwdb[i];
+
+			phydm_per_path_info_3rd(i, rx_path_pwr_db, 0,
+						0, 0, phy_info);
+
+			/* search maximum pwdb */
+			if (rx_path_pwr_db > rx_pwr_db_max)
+				rx_pwr_db_max = rx_path_pwr_db;
+		}
 	}
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	if ((p_dm->support_ability & ODM_BB_ANT_DIV) &&
-	    (p_dm_fat_table->enable_ctrl_frame_antdiv)
-	   ) {
-		if (p_pktinfo->is_packet_match_bssid)
-			p_dm->data_frame_num++;
+	/* @mapping RX counter from 1~4 to 0~3 */
+	if (rx_count > 0)
+		phy_info->rx_count = rx_count - 1;
 
-		if ((p_dm_fat_table->use_ctrl_frame_antdiv)) {
-			if (!p_pktinfo->is_to_self)/*data frame + CTRL frame*/
-				return;
-		} else {
-			if ((!p_pktinfo->is_packet_match_bssid))/*data frame only*/
-				return;
+	/* @count BF packet */
+	dbg_i->num_qry_bf_pkt = dm->phy_dbg_info.num_qry_bf_pkt +
+					  phy_sts->beamformed;
+
+	/*STBC or LDPC pkt*/
+	dbg_i->is_ldpc_pkt = phy_sts->ldpc;
+	dbg_i->is_stbc_pkt = phy_sts->stbc;
+
+	/* @Check sub-channel */
+	if (pktinfo->data_rate > ODM_RATE11M &&
+	    pktinfo->data_rate < ODM_RATEMCS0)
+		rxsc = phy_sts->l_rxsc; /*@Legacy*/
+	else
+		rxsc = phy_sts->ht_rxsc; /* @HT and VHT */
+
+	/* @Check RX bandwidth */
+	if (rxsc >= 1 && rxsc <= 8)
+		bw = CHANNEL_WIDTH_20;
+	else if ((rxsc >= 9) && (rxsc <= 12))
+		bw = CHANNEL_WIDTH_40;
+	else if (rxsc >= 13)
+		bw = CHANNEL_WIDTH_80;
+	else
+		bw = *dm->band_width;
+
+	/* Update packet information */
+	/* RX power choose the path with the maximum power */
+	phydm_common_phy_info_3rd(rx_pwr_db_max, phy_sts->channel_lsb,
+				  (boolean)phy_sts->beamformed,
+				  false, bw, 0, rxsc, phy_info);
+}
+
+void phydm_get_physts_jarguar3_4(struct dm_struct *dm, u8 *phy_status_inf,
+				 struct phydm_perpkt_info_struct *pktinfo,
+				 struct phydm_phyinfo_struct *phy_info)
+{
+	/* type 4 is used for ofdm packet */
+	struct phy_sts_rpt_jgr3_type4 *phy_sts = NULL;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	s8 rx_pwr_db_max = -120;
+	s8 rx_path_pwr_db = 0;
+	u8 i, rxsc, bw = CHANNEL_WIDTH_20, rx_cnt = 0;
+
+	phy_sts = (struct phy_sts_rpt_jgr3_type4 *)phy_status_inf;
+
+	/* Update per-path information */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			rx_cnt++; /* @check the number of the ant */
+
+			if (rx_cnt > dm->num_rf_path)
+				break;
+
+			/* Update per-path information
+			 * (RSSI_dB RSSI_percentage EVM SNR CFO sq)
+			 */
+			/* @EVM report is reported by stream, not path */
+			rx_path_pwr_db = phy_sts->pwdb[i] - 110; /*@dB*/
+
+			if (pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = phy_sts->pwdb[i];
+
+			phydm_per_path_info_3rd(i, rx_path_pwr_db,
+						phy_sts->rxevm[rx_cnt - 1],
+						0, phy_sts->rxsnr[i],
+						phy_info);
+
+			/* search maximum pwdb */
+			if (rx_path_pwr_db > rx_pwr_db_max)
+				rx_pwr_db_max = rx_path_pwr_db;
 		}
-	} else
-#endif
-	{
-		if ((!p_pktinfo->is_packet_match_bssid))/*data frame only*/
-			return;
 	}
 
-	if (p_pktinfo->is_packet_beacon)
-		p_dm->phy_dbg_info.num_qry_beacon_pkt++;
+	/* @mapping RX counter from 1~4 to 0~3 */
+	if (rx_cnt > 0)
+		phy_info->rx_count = rx_cnt - 1;
+
+	/* @count BF packet */
+	dbg_i->num_qry_bf_pkt = dm->phy_dbg_info.num_qry_bf_pkt +
+					  phy_sts->beamformed;
+
+	/* @STBC or LDPC pkt*/
+	dbg_i->is_ldpc_pkt = phy_sts->ldpc;
+	dbg_i->is_stbc_pkt = phy_sts->stbc;
+
+	/* @Check sub-channel */
+	if (pktinfo->data_rate > ODM_RATE11M &&
+	    pktinfo->data_rate < ODM_RATEMCS0)
+		rxsc = phy_sts->l_rxsc; /*@Legacy*/
+	else
+		rxsc = phy_sts->ht_rxsc; /* @HT and VHT */
+
+	/* @Check RX bandwidth */
+	if (rxsc >= 1 && rxsc <= 8)
+		bw = CHANNEL_WIDTH_20;
+	else if ((rxsc >= 9) && (rxsc <= 12))
+		bw = CHANNEL_WIDTH_40;
+	else if (rxsc >= 13)
+		bw = CHANNEL_WIDTH_80;
+	else
+		bw = *dm->band_width;
+
+	/* @Conditional number */
+	dbg_i->condi_num = (u32)phy_sts->avg_cond_num_0;
+
+	/* Update packet information */
+	/* RX power choose the path with the maximum power */
+	phydm_common_phy_info_3rd(rx_pwr_db_max, phy_sts->channel_lsb,
+				  (boolean)phy_sts->beamformed,
+				  false, bw, 0, rxsc, phy_info);
+}
+
+void phydm_get_physts_jarguar3_5(struct dm_struct *dm, u8 *phy_status_inf,
+				 struct phydm_perpkt_info_struct *pktinfo,
+				 struct phydm_phyinfo_struct *phy_info)
+{
+	/* type 5 is used for ofdm packet */
+	struct phy_sts_rpt_jgr3_type5 *phy_sts = NULL;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	s8 rx_pwr_db_max = -120;
+	s8 rx_path_pwr_db = 0;
+	u8 i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
+
+	phy_sts = (struct phy_sts_rpt_jgr3_type5 *)phy_status_inf;
+
+	/* Update per-path information */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (dm->rx_ant_status & BIT(i)) {
+			rx_count++; /* @check the number of the ant */
+
+			if (rx_count > dm->num_rf_path)
+				break;
+
+			/* Update per-path information
+			 * (RSSI_dB RSSI_percentage EVM SNR CFO sq)
+			 */
+			/* @EVM report is reported by stream, not path */
+			rx_path_pwr_db = phy_sts->pwdb[i] - 110; /*@dB*/
+
+			if (pktinfo->is_to_self)
+				dm->ofdm_agc_idx[i] = phy_sts->pwdb[i];
+
+			phydm_per_path_info_3rd(i, rx_path_pwr_db,
+						0, 0, 0, phy_info);
+
+			/* search maximum pwdb */
+			if (rx_path_pwr_db > rx_pwr_db_max)
+				rx_pwr_db_max = rx_path_pwr_db;
+		}
+	}
 
-	is_cck_rate = (p_pktinfo->data_rate <= ODM_RATE11M) ? true : false;
-	p_dm->rx_rate = p_pktinfo->data_rate;
+	/* @mapping RX counter from 1~4 to 0~3 */
+	if (rx_count > 0)
+		phy_info->rx_count = rx_count - 1;
 
-	/* --------------Statistic for antenna/path diversity------------------ */
-	if (p_dm->support_ability & ODM_BB_ANT_DIV) {
-#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-		odm_process_rssi_for_ant_div(p_dm, p_phy_info, p_pktinfo);
-#endif
-	}
-#if (defined(CONFIG_PATH_DIVERSITY))
-	else if (p_dm->support_ability & ODM_BB_PATH_DIV)
-		phydm_process_rssi_for_path_div(p_dm, p_phy_info, p_pktinfo);
-#endif
-	/* -----------------Smart Antenna Debug Message------------------ */
-
-	undecorated_smoothed_cck =  p_sta->rssi_stat.rssi_cck;
-	undecorated_smoothed_ofdm = p_sta->rssi_stat.rssi_ofdm;
-	undecorated_smoothed_pwdb = p_sta->rssi_stat.rssi;
-
-	if (p_pktinfo->is_packet_to_self || p_pktinfo->is_packet_beacon) {
-
-		if (!is_cck_rate) { /* ofdm rate */
-#if (RTL8814A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1)
-			if (p_dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B)) {
-				u8 RX_count = 0;
-				u32 RSSI_linear = 0;
-
-				if (p_dm->rx_ant_status & BB_PATH_A) {
-					p_dm->RSSI_A = p_phy_info->rx_mimo_signal_strength[RF_PATH_A];
-					RX_count++;
-					RSSI_linear += odm_convert_to_linear(p_phy_info->rx_mimo_signal_strength[RF_PATH_A]);
-				} else
-					p_dm->RSSI_A = 0;
-
-				if (p_dm->rx_ant_status & BB_PATH_B) {
-					p_dm->RSSI_B = p_phy_info->rx_mimo_signal_strength[RF_PATH_B];
-					RX_count++;
-					RSSI_linear += odm_convert_to_linear(p_phy_info->rx_mimo_signal_strength[RF_PATH_B]);
-				} else
-					p_dm->RSSI_B = 0;
-
-				if (p_dm->rx_ant_status & BB_PATH_C) {
-					p_dm->RSSI_C = p_phy_info->rx_mimo_signal_strength[RF_PATH_C];
-					RX_count++;
-					RSSI_linear += odm_convert_to_linear(p_phy_info->rx_mimo_signal_strength[RF_PATH_C]);
-				} else
-					p_dm->RSSI_C = 0;
-
-				if (p_dm->rx_ant_status & BB_PATH_D) {
-					p_dm->RSSI_D = p_phy_info->rx_mimo_signal_strength[RF_PATH_D];
-					RX_count++;
-					RSSI_linear += odm_convert_to_linear(p_phy_info->rx_mimo_signal_strength[RF_PATH_D]);
-				} else
-					p_dm->RSSI_D = 0;
-
-				/* Calculate average RSSI */
-				switch (RX_count) {
-				case 2:
-					RSSI_linear = (RSSI_linear >> 1);
-					break;
-				case 3:
-					RSSI_linear = ((RSSI_linear) + (RSSI_linear << 1) + (RSSI_linear << 3)) >> 5;	/* RSSI_linear/3 ~ RSSI_linear*11/32 */
-					break;
-				case 4:
-					RSSI_linear = (RSSI_linear >> 2);
-					break;
-				}
-				rssi_ave = odm_convert_to_db(RSSI_linear);
-			} else
-#endif
-			{
-				if (p_phy_info->rx_mimo_signal_strength[RF_PATH_B] == 0) {
-					rssi_ave = p_phy_info->rx_mimo_signal_strength[RF_PATH_A];
-					p_dm->RSSI_A = p_phy_info->rx_mimo_signal_strength[RF_PATH_A];
-					p_dm->RSSI_B = 0;
-				} else {
-					/*dbg_print("p_rfd->status.rx_mimo_signal_strength[0] = %d, p_rfd->status.rx_mimo_signal_strength[1] = %d\n",*/
-					/*p_rfd->status.rx_mimo_signal_strength[0], p_rfd->status.rx_mimo_signal_strength[1]);*/
-					p_dm->RSSI_A =  p_phy_info->rx_mimo_signal_strength[RF_PATH_A];
-					p_dm->RSSI_B = p_phy_info->rx_mimo_signal_strength[RF_PATH_B];
-
-					if (p_phy_info->rx_mimo_signal_strength[RF_PATH_A] > p_phy_info->rx_mimo_signal_strength[RF_PATH_B]) {
-						RSSI_max = p_phy_info->rx_mimo_signal_strength[RF_PATH_A];
-						RSSI_min = p_phy_info->rx_mimo_signal_strength[RF_PATH_B];
-					} else {
-						RSSI_max = p_phy_info->rx_mimo_signal_strength[RF_PATH_B];
-						RSSI_min = p_phy_info->rx_mimo_signal_strength[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;
-				}
-			}
+	/* @count BF packet */
+	dbg_i->num_qry_bf_pkt = dm->phy_dbg_info.num_qry_bf_pkt +
+					  phy_sts->beamformed;
 
-			/* 1 Process OFDM RSSI */
-			if (undecorated_smoothed_ofdm <= 0) {	/* initialize */
-				undecorated_smoothed_ofdm = (s8)p_phy_info->rx_pwdb_all;
-				PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("OFDM_INIT: (( %d ))\n", undecorated_smoothed_ofdm));
-			} else {
-				if (p_phy_info->rx_pwdb_all > (u32)undecorated_smoothed_ofdm) {
-					undecorated_smoothed_ofdm =
-						(s8)((((undecorated_smoothed_ofdm)*(RX_SMOOTH_FACTOR - 1)) +
-						(rssi_ave)) / (RX_SMOOTH_FACTOR));
-					undecorated_smoothed_ofdm = undecorated_smoothed_ofdm + 1;
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("OFDM_1: (( %d ))\n", undecorated_smoothed_ofdm));
-				} else {
-					undecorated_smoothed_ofdm =
-						(s8)((((undecorated_smoothed_ofdm)*(RX_SMOOTH_FACTOR - 1)) +
-						(rssi_ave)) / (RX_SMOOTH_FACTOR));
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("OFDM_2: (( %d ))\n", undecorated_smoothed_ofdm));
-				}
-			}
-			if (p_sta->rssi_stat.ofdm_pkt_cnt != 64) {
-				i = 63;
-				p_sta->rssi_stat.ofdm_pkt_cnt -= (u8)(((p_sta->rssi_stat.packet_map >> i) & BIT(0)) - 1);
-			}
-			p_sta->rssi_stat.packet_map = (p_sta->rssi_stat.packet_map << 1) | BIT(0);
+	/*STBC or LDPC pkt*/
+	dbg_i->is_ldpc_pkt = phy_sts->ldpc;
+	dbg_i->is_stbc_pkt = phy_sts->stbc;
 
-		} else {
-			rssi_ave = p_phy_info->rx_pwdb_all;
-			p_dm->RSSI_A = (u8) p_phy_info->rx_pwdb_all;
-			p_dm->RSSI_B = 0xFF;
-			p_dm->RSSI_C = 0xFF;
-			p_dm->RSSI_D = 0xFF;
-
-			if (p_sta->rssi_stat.cck_pkt_cnt <= 63)
-				p_sta->rssi_stat.cck_pkt_cnt++;
-
-			/* 1 Process CCK RSSI */
-			if (undecorated_smoothed_cck <= 0) {	/* initialize */
-				undecorated_smoothed_cck = (s8)p_phy_info->rx_pwdb_all;
-				p_sta->rssi_stat.cck_sum_power = (u16)p_phy_info->rx_pwdb_all ; /*reset*/
-				p_sta->rssi_stat.cck_pkt_cnt = 1; /*reset*/
-				PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("CCK_INIT: (( %d ))\n", undecorated_smoothed_cck));
-			} else if (p_sta->rssi_stat.cck_pkt_cnt <= CCK_RSSI_INIT_COUNT) {
-
-				p_sta->rssi_stat.cck_sum_power = p_sta->rssi_stat.cck_sum_power + (u16)p_phy_info->rx_pwdb_all;
-				undecorated_smoothed_cck = p_sta->rssi_stat.cck_sum_power / p_sta->rssi_stat.cck_pkt_cnt;
-
-				PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("CCK_0: (( %d )), SumPow = (( %d )), cck_pkt = (( %d ))\n",
-					undecorated_smoothed_cck, p_sta->rssi_stat.cck_sum_power, p_sta->rssi_stat.cck_pkt_cnt));
-			} else {
-				if (p_phy_info->rx_pwdb_all > (u32)undecorated_smoothed_cck) {
-					undecorated_smoothed_cck =
-						(s8)((((undecorated_smoothed_cck)*(RX_SMOOTH_FACTOR - 1)) +
-						(p_phy_info->rx_pwdb_all)) / (RX_SMOOTH_FACTOR));
-					undecorated_smoothed_cck = undecorated_smoothed_cck + 1;
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("CCK_1: (( %d ))\n", undecorated_smoothed_cck));
-				} else {
-					undecorated_smoothed_cck =
-						(s8)((((undecorated_smoothed_cck)*(RX_SMOOTH_FACTOR - 1)) +
-						(p_phy_info->rx_pwdb_all)) / (RX_SMOOTH_FACTOR));
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("CCK_2: (( %d ))\n", undecorated_smoothed_cck));
-				}
-			}
-			i = 63;
-			p_sta->rssi_stat.ofdm_pkt_cnt -= (u8)((p_sta->rssi_stat.packet_map >> i) & BIT(0));
-			p_sta->rssi_stat.packet_map = p_sta->rssi_stat.packet_map << 1;
-		}
+	/* @Check sub-channel */
+	if (pktinfo->data_rate > ODM_RATE11M &&
+	    pktinfo->data_rate < ODM_RATEMCS0)
+		rxsc = phy_sts->l_rxsc; /*@Legacy*/
+	else
+		rxsc = phy_sts->ht_rxsc; /* @HT and VHT */
+
+	/* @Check RX bandwidth */
+	if (rxsc >= 1 && rxsc <= 8)
+		bw = CHANNEL_WIDTH_20;
+	else if ((rxsc >= 9) && (rxsc <= 12))
+		bw = CHANNEL_WIDTH_40;
+	else if (rxsc >= 13)
+		bw = CHANNEL_WIDTH_80;
+	else
+		bw = *dm->band_width;
 
-		/* if(p_entry) */
-		{
-			/* 2011.07.28 LukeLee: modified to prevent unstable CCK RSSI */
-			if (p_sta->rssi_stat.ofdm_pkt_cnt == 64) { /* speed up when all packets are OFDM*/
-				undecorated_smoothed_pwdb = undecorated_smoothed_ofdm;
-				PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("PWDB_0[%d] = (( %d ))\n", p_pktinfo->station_id, undecorated_smoothed_cck));
-			} else {
-				if (p_sta->rssi_stat.valid_bit < 64)
-					p_sta->rssi_stat.valid_bit++;
+	/* Update packet information */
+	/* RX power choose the path with the maximum power */
+	phydm_common_phy_info_3rd(rx_pwr_db_max, phy_sts->channel_lsb,
+				  (boolean)phy_sts->beamformed,
+				  false, bw, 0, rxsc, phy_info);
+}
 
-				if (p_sta->rssi_stat.valid_bit == 64) {
-					weighting = ((p_sta->rssi_stat.ofdm_pkt_cnt) > 4) ? 64 : (p_sta->rssi_stat.ofdm_pkt_cnt << 4);
-					undecorated_smoothed_pwdb = (s8)((weighting * undecorated_smoothed_ofdm + (64 - weighting) * undecorated_smoothed_cck) >> 6);
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("PWDB_1[%d] = (( %d )), W = (( %d ))\n", p_pktinfo->station_id, undecorated_smoothed_cck, weighting));
-				} else {
-					if (p_sta->rssi_stat.valid_bit != 0)
-						undecorated_smoothed_pwdb =
-						(p_sta->rssi_stat.ofdm_pkt_cnt * undecorated_smoothed_ofdm + (p_sta->rssi_stat.valid_bit - p_sta->rssi_stat.ofdm_pkt_cnt) * undecorated_smoothed_cck) / p_sta->rssi_stat.valid_bit;
-					else
-						undecorated_smoothed_pwdb = 0;
-
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("PWDB_2[%d] = (( %d )), ofdm_pkt = (( %d )), Valid_Bit = (( %d ))\n",
-						p_pktinfo->station_id, undecorated_smoothed_cck, p_sta->rssi_stat.ofdm_pkt_cnt, p_sta->rssi_stat.valid_bit));
-				}
-			}
+void phydm_process_dm_rssi_3rd_type(struct dm_struct *dm,
+				    struct phydm_phyinfo_struct *phy_info,
+				    struct phydm_perpkt_info_struct *pktinfo)
+{
+	struct cmn_sta_info *sta = NULL;
+	struct rssi_info *rssi_t = NULL;
+	u8 rssi_tmp = 0;
+	u64 rssi_linear = 0;
+	s16 rssi_db = 0;
+	u8 i = 0;
 
+	/*@[Step4]*/
 
-			if ((p_sta->rssi_stat.ofdm_pkt_cnt >= 1 || p_sta->rssi_stat.cck_pkt_cnt >= 5) && (p_sta->rssi_stat.is_send_rssi == RA_RSSI_STATE_INIT)) {
+	if (pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
+		return;
 
-				send_rssi_2_fw = 1;
-				p_sta->rssi_stat.is_send_rssi = RA_RSSI_STATE_SEND;
-			}
+	sta = dm->phydm_sta_info[pktinfo->station_id];
 
-			p_sta->rssi_stat.rssi_cck = undecorated_smoothed_cck;
-			p_sta->rssi_stat.rssi_ofdm = undecorated_smoothed_ofdm;
-			p_sta->rssi_stat.rssi = undecorated_smoothed_pwdb;
+	if (!is_sta_active(sta))
+		return;
 
+	if (!pktinfo->is_packet_match_bssid) /*@data frame only*/
+		return;
 
+	if (!(pktinfo->is_packet_to_self) && !(pktinfo->is_packet_beacon))
+		return;
 
-			if (send_rssi_2_fw) { /* Trigger init rate by RSSI */
+	if (pktinfo->is_packet_beacon) {
+		dm->phy_dbg_info.num_qry_beacon_pkt++;
+		dm->phy_dbg_info.beacon_phy_rate = pktinfo->data_rate;
+	}
 
-				if (p_sta->rssi_stat.ofdm_pkt_cnt != 0)
-					p_sta->rssi_stat.rssi = undecorated_smoothed_ofdm;
+	#if (defined(CONFIG_PATH_DIVERSITY))
+	if (dm->support_ability & ODM_BB_PATH_DIV)
+		phydm_process_rssi_for_path_div(dm, phy_info, pktinfo);
+	#endif
 
-				PHYDM_DBG(p_dm, DBG_RSSI_MNTR,
-					("[Send to FW] PWDB = (( %d )), ofdm_pkt = (( %d )), cck_pkt = (( %d ))\n",
-					undecorated_smoothed_pwdb, p_sta->rssi_stat.ofdm_pkt_cnt, p_sta->rssi_stat.cck_pkt_cnt));
+	rssi_t = &sta->rssi_stat;
 
-			}
+	if (pktinfo->is_cck_rate) {
+		rssi_db = phy_info->rx_mimo_signal_strength[0]; /*Path-A*/
+		if (rssi_t->rssi_acc == 0) {
+			rssi_t->rssi_acc = (s16)(rssi_db << RSSI_MA);
+			rssi_t->rssi = (s8)(rssi_db);
+		} else {
+			rssi_t->rssi_acc = MA_ACC(rssi_t->rssi_acc,
+						  rssi_db, RSSI_MA);
+			rssi_t->rssi = (s8)GET_MA_VAL(rssi_t->rssi_acc,
+						      RSSI_MA);
+		}
+		rssi_t->rssi_cck = (s8)rssi_db;
+	} else {
+		for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+			rssi_tmp = phy_info->rx_mimo_signal_strength[i];
+			if (rssi_tmp != 0)
+				rssi_linear += phydm_db_2_linear(rssi_tmp);
+		}
+		/* @Rounding and removing fractional bits */
+		rssi_linear = (rssi_linear +
+			       (1 << (FRAC_BITS - 1))) >> FRAC_BITS;
 
+		switch (phy_info->rx_count + 1) {
+		case 2:
+			rssi_linear = DIVIDED_2(rssi_linear);
+			break;
+		case 3:
+			rssi_linear = DIVIDED_3(rssi_linear);
+			break;
+		case 4:
+			rssi_linear = DIVIDED_4(rssi_linear);
+			break;
+		}
+		rssi_db = (s16)odm_convert_to_db(rssi_linear);
 
-			/*in WIN Driver: sta_ID==0->p_entry==NULL -> default port HAL_Data*/
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
+		if (rssi_t->rssi_acc == 0) {
+			rssi_t->rssi_acc = (s16)(rssi_db << RSSI_MA);
+			rssi_t->rssi = (s8)(rssi_db);
+		} else {
+			rssi_t->rssi_acc = MA_ACC(rssi_t->rssi_acc,
+						  rssi_db, RSSI_MA);
+			rssi_t->rssi = (s8)GET_MA_VAL(rssi_t->rssi_acc,
+						      RSSI_MA);
+		}
+		rssi_t->rssi_ofdm = (s8)rssi_db;
+	}
+}
 
-			if (p_pktinfo->station_id == 0) {
-				/**/
-				p_hal_data->UndecoratedSmoothedPWDB = undecorated_smoothed_pwdb;
-			}
+void phydm_rx_physts_3rd_type(void *dm_void, u8 *phy_sts,
+			      struct phydm_perpkt_info_struct *pktinfo,
+			      struct phydm_phyinfo_struct *phy_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+#ifdef PHYDM_PHYSTAUS_SMP_MODE
+	struct pkt_process_info *pkt_process = &dm->pkt_proc_struct;
 #endif
+	u8 phy_status_type = (*phy_sts & 0xf);
 
-			/* dbg_print("ofdm_pkt=%d, weighting=%d\n", ofdm_pkt_cnt, weighting); */
-			/* dbg_print("undecorated_smoothed_ofdm=%d, undecorated_smoothed_pwdb=%d, undecorated_smoothed_cck=%d\n", */
-			/*	undecorated_smoothed_ofdm, undecorated_smoothed_pwdb, undecorated_smoothed_cck); */
+#ifdef PHYDM_PHYSTAUS_SMP_MODE
+	if (pkt_process->phystatus_smp_mode_en && phy_status_type != 0) {
+		if (pkt_process->pre_ppdu_cnt == pktinfo->ppdu_cnt)
+			return;
+		pkt_process->pre_ppdu_cnt = pktinfo->ppdu_cnt;
+	}
+#endif
 
-		}
+	/*@[Step 2]*/
+	phydm_reset_phy_info_3rd(dm, phy_info); /* @Memory reset */
 
+	/* Phy status parsing */
+	switch (phy_status_type) {
+	case 0: /*@CCK*/
+		phydm_get_physts_jarguar3_0(dm, phy_sts, pktinfo, phy_info);
+		break;
+	case 1:
+		phydm_get_physts_jarguar3_1(dm, phy_sts, pktinfo, phy_info);
+		break;
+	case 2:
+	case 3:
+		phydm_get_physts_jarguar3_2_3(dm, phy_sts, pktinfo, phy_info);
+		break;
+	case 4:
+		phydm_get_physts_jarguar3_4(dm, phy_sts, pktinfo, phy_info);
+		break;
+	case 5:
+		phydm_get_physts_jarguar3_5(dm, phy_sts, pktinfo, phy_info);
+		break;
+	default:
+		break;
 	}
+
+
+	/*@[Step 1]*/
+	phydm_print_phystat_jaguar3(dm, phy_sts, pktinfo, phy_info);
 }
 
-/*
- * Endianness before calling this API
- *   */
+#endif
 
-#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-/* For 8822B only!! need to move to FW finally */
-/*==============================================*/
+#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT)
+/* @For 8822B only!! need to move to FW finally */
+/*@==============================================*/
 
 boolean
-phydm_query_is_mu_api(
-	struct PHY_DM_STRUCT					*p_phydm,
-	u8							ppdu_idx,
-	u8							*p_data_rate,
-	u8							*p_gid
-)
+phydm_query_is_mu_api(struct dm_struct *phydm, u8 ppdu_idx, u8 *p_data_rate,
+		      u8 *p_gid)
 {
-	u8	data_rate = 0, gid = 0;
+	u8 data_rate = 0, gid = 0;
 	boolean is_mu = false;
 
-	data_rate = p_phydm->phy_dbg_info.num_of_ppdu[ppdu_idx];
-	gid = p_phydm->phy_dbg_info.gid_num[ppdu_idx];
+	data_rate = phydm->phy_dbg_info.num_of_ppdu[ppdu_idx];
+	gid = phydm->phy_dbg_info.gid_num[ppdu_idx];
 
 	if (data_rate & BIT(7)) {
 		is_mu = true;
 		data_rate = data_rate & ~(BIT(7));
-	} else
+	} else {
 		is_mu = false;
+	}
 
 	*p_data_rate = data_rate;
 	*p_gid = gid;
 
 	return is_mu;
+}
 
+void phydm_reset_phy_info(struct dm_struct *phydm,
+			  struct phydm_phyinfo_struct *phy_info)
+{
+	phy_info->rx_pwdb_all = 0;
+	phy_info->signal_quality = 0;
+	phy_info->band_width = 0;
+	phy_info->rx_count = 0;
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_quality, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_mimo_signal_strength, 0, 4);
+	odm_memory_set(phydm, phy_info->rx_snr, 0, 4);
+
+	phy_info->rx_power = -110;
+	phy_info->recv_signal_power = -110;
+	phy_info->bt_rx_rssi_percentage = 0;
+	phy_info->signal_strength = 0;
+	phy_info->channel = 0;
+	phy_info->is_mu_packet = 0;
+	phy_info->is_beamformed = 0;
+	phy_info->rxsc = 0;
+	odm_memory_set(phydm, phy_info->rx_pwr, -110, 4);
+	odm_memory_set(phydm, phy_info->cfo_short, 0, 8);
+	odm_memory_set(phydm, phy_info->cfo_tail, 0, 8);
+	odm_memory_set(phydm, phy_info->ant_idx, 0, 4);
+
+	odm_memory_set(phydm, phy_info->rx_mimo_evm_dbm, 0, 4);
 }
 
-void
-phydm_reset_phy_info(
-	struct PHY_DM_STRUCT					*p_phydm,
-	struct phydm_phyinfo_struct			*p_phy_info
-)
+void phydm_print_phy_sts_jgr2(struct dm_struct *dm, u8 *phy_status_inf,
+			      struct phydm_perpkt_info_struct *pktinfo,
+			      struct phydm_phyinfo_struct *phy_info)
 {
-	p_phy_info->rx_pwdb_all = 0;
-	p_phy_info->signal_quality = 0;
-	p_phy_info->band_width = 0;
-	p_phy_info->rx_count = 0;
-	odm_memory_set(p_phydm, p_phy_info->rx_mimo_signal_quality, 0, 4);
-	odm_memory_set(p_phydm, p_phy_info->rx_mimo_signal_strength, 0, 4);
-	odm_memory_set(p_phydm, p_phy_info->rx_snr, 0, 4);
-
-	p_phy_info->rx_power = -110;
-	p_phy_info->recv_signal_power = -110;
-	p_phy_info->bt_rx_rssi_percentage = 0;
-	p_phy_info->signal_strength = 0;
-	p_phy_info->channel = 0;
-	p_phy_info->is_mu_packet = 0;
-	p_phy_info->is_beamformed = 0;
-	p_phy_info->rxsc = 0;
-	odm_memory_set(p_phydm, p_phy_info->rx_pwr, -110, 4);
-	/*odm_memory_set(p_phydm, p_phy_info->rx_mimo_evm_dbm, 0, 4);*/
-	odm_memory_set(p_phydm, p_phy_info->cfo_short, 0, 8);
-	odm_memory_set(p_phydm, p_phy_info->cfo_tail, 0, 8);
-
-	odm_memory_set(p_phydm, p_phy_info->rx_mimo_evm_dbm, 0, 4);
+	struct phy_sts_rpt_jgr2_type0 *rpt0 = NULL;
+	struct phy_sts_rpt_jgr2_type1 *rpt = NULL;
+	struct phy_sts_rpt_jgr2_type2 *rpt2 = NULL;
+	struct odm_phy_dbg_info *dbg = &dm->phy_dbg_info;
+	u8 phy_status_page_num = (*phy_status_inf & 0xf);
+	u32 phy_status[PHY_STATUS_JRGUAR2_DW_LEN] = {0};
+	u8 i;
+	u32 size = PHY_STATUS_JRGUAR2_DW_LEN << 2;
+
+	rpt0 = (struct phy_sts_rpt_jgr2_type0 *)phy_status_inf;
+	rpt = (struct phy_sts_rpt_jgr2_type1 *)phy_status_inf;
+	rpt2 = (struct phy_sts_rpt_jgr2_type2 *)phy_status_inf;
+
+	odm_move_memory(dm, phy_status, phy_status_inf, size);
+
+	if (!(dm->debug_components & DBG_PHY_STATUS))
+		return;
+
+	if (dbg->show_phy_sts_all_pkt == 0) {
+		if (!pktinfo->is_packet_match_bssid)
+			return;
+	}
+
+	dbg->show_phy_sts_cnt++;
+	#if 0
+	dbg_print("cnt=%d, max=%d\n",
+		  dbg->show_phy_sts_cnt, dbg->show_phy_sts_max_cnt);
+	#endif
+
+	if (dbg->show_phy_sts_max_cnt != SHOW_PHY_STATUS_UNLIMITED) {
+		if (dbg->show_phy_sts_cnt > dbg->show_phy_sts_max_cnt)
+			return;
+	}
+
+	pr_debug("Phy Status Rpt: OFDM_%d\n", phy_status_page_num);
+	pr_debug("StaID=%d, RxRate = 0x%x match_bssid=%d\n",
+		 pktinfo->station_id, pktinfo->data_rate,
+		 pktinfo->is_packet_match_bssid);
+
+	for (i = 0; i < PHY_STATUS_JRGUAR2_DW_LEN; i++)
+		pr_debug("Offset[%d:%d] = 0x%x\n",
+			 ((4 * i) + 3), (4 * i), phy_status[i]);
+
+	if (phy_status_page_num == 0) {
+		pr_debug("[0] TRSW=%d, MP_gain_idx=%d, pwdb=%d\n",
+			 rpt0->trsw, rpt0->gain, rpt0->pwdb);
+		pr_debug("[4] band=%d, CH=%d, agc_table = %d, rxsc = %d\n",
+			 rpt0->band, rpt0->channel,
+			 rpt0->agc_table, rpt0->rxsc);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, LSIG_len=%d\n",
+			 rpt0->antidx_d, rpt0->antidx_c, rpt0->antidx_b,
+			 rpt0->antidx_a, rpt0->length);
+		pr_debug("[12] lna_h=%d, bb_pwr=%d, lna_l=%d, vga=%d, sq=%d\n",
+			 rpt0->lna_h, rpt0->bb_power, rpt0->lna_l,
+			 rpt0->vga, rpt0->signal_quality);
+
+	} else if (phy_status_page_num == 1) {
+		pr_debug("[0] pwdb[D:A]={%d, %d, %d, %d}\n",
+			 rpt->pwdb[3], rpt->pwdb[2],
+			 rpt->pwdb[1], rpt->pwdb[0]);
+		pr_debug("[4] BF: %d, ldpc=%d, stbc=%d, g_bt=%d, antsw=%d, band=%d, CH=%d, rxsc[ht, l]={%d, %d}\n",
+			 rpt->beamformed, rpt->ldpc, rpt->stbc, rpt->gnt_bt,
+			 rpt->hw_antsw_occu, rpt->band, rpt->channel,
+			 rpt->ht_rxsc, rpt->l_rxsc);
+		pr_debug("[8] AntIdx[D:A]={%d, %d, %d, %d}, LSIG_len=%d\n",
+			 rpt->antidx_d, rpt->antidx_c, rpt->antidx_b,
+			 rpt->antidx_a, rpt->lsig_length);
+		pr_debug("[12] rf_mode=%d, NBI=%d, Intf_pos=%d, GID=%d, PAID=%d\n",
+			 rpt->rf_mode, rpt->nb_intf_flag,
+			 (rpt->intf_pos + (rpt->intf_pos_msb << 8)), rpt->gid,
+			 (rpt->paid + (rpt->paid_msb << 8)));
+		pr_debug("[16] EVM[D:A]={%d, %d, %d, %d}\n",
+			 rpt->rxevm[3], rpt->rxevm[2],
+			 rpt->rxevm[1], rpt->rxevm[0]);
+		pr_debug("[20] CFO[D:A]={%d, %d, %d, %d}\n",
+			 rpt->cfo_tail[3], rpt->cfo_tail[2], rpt->cfo_tail[1],
+			 rpt->cfo_tail[0]);
+		pr_debug("[24] SNR[D:A]={%d, %d, %d, %d}\n\n",
+			 rpt->rxsnr[3], rpt->rxsnr[2], rpt->rxsnr[1],
+			 rpt->rxsnr[0]);
+
+	} else if (phy_status_page_num == 2) {
+		pr_debug("[0] pwdb[D:A]={%d, %d, %d, %d}\n",
+			 rpt2->pwdb[3], rpt2->pwdb[2], rpt2->pwdb[1],
+			 rpt2->pwdb[0]);
+		pr_debug("[4] BF: %d, ldpc=%d, stbc=%d, g_bt=%d, antsw=%d, band=%d, CH=%d, rxsc[ht,l]={%d, %d}\n",
+			 rpt2->beamformed, rpt2->ldpc, rpt2->stbc, rpt2->gnt_bt,
+			 rpt2->hw_antsw_occu, rpt2->band, rpt2->channel,
+			 rpt2->ht_rxsc, rpt2->l_rxsc);
+		pr_debug("[8] AgcTab[D:A]={%d, %d, %d, %d}, cnt_pw2cca=%d, shift_l_map=%d\n",
+			 rpt2->agc_table_d, rpt2->agc_table_c,
+			 rpt2->agc_table_b, rpt2->agc_table_a,
+			 rpt2->cnt_pw2cca, rpt2->shift_l_map);
+		pr_debug("[12] (TRSW|Gain)[D:A]={%d %d, %d %d, %d %d, %d %d}, cnt_cca2agc_rdy=%d\n",
+			 rpt2->trsw_d, rpt2->gain_d, rpt2->trsw_c, rpt2->gain_c,
+			 rpt2->trsw_b, rpt2->gain_b, rpt2->trsw_a,
+			 rpt2->gain_a, rpt2->cnt_cca2agc_rdy);
+		pr_debug("[16] AAGC step[D:A]={%d, %d, %d, %d} HT AAGC gain[D:A]={%d, %d, %d, %d}\n",
+			 rpt2->aagc_step_d, rpt2->aagc_step_c,
+			 rpt2->aagc_step_b, rpt2->aagc_step_a,
+			 rpt2->ht_aagc_gain[3], rpt2->ht_aagc_gain[2],
+			 rpt2->ht_aagc_gain[1], rpt2->ht_aagc_gain[0]);
+		pr_debug("[20] DAGC gain[D:A]={%d, %d, %d, %d}\n",
+			 rpt2->dagc_gain[3],
+			 rpt2->dagc_gain[2], rpt2->dagc_gain[1],
+			 rpt2->dagc_gain[0]);
+		pr_debug("[24] syn_cnt: %d, Cnt=%d\n\n",
+			 rpt2->syn_count, rpt2->counter);
+	}
 }
 
-void
-phydm_set_per_path_phy_info(
-	u8							rx_path,
-	s8							rx_pwr,
-	s8							rx_evm,
-	s8							cfo_tail,
-	s8							rx_snr,
-	struct phydm_phyinfo_struct	*p_phy_info
-)
+void phydm_set_per_path_phy_info(u8 rx_path, s8 pwr, s8 rx_evm, s8 cfo_tail,
+				 s8 rx_snr, u8 ant_idx,
+				 struct phydm_phyinfo_struct *phy_info)
 {
-	u8			evm_dbm = 0;
-	u8			evm_percentage = 0;
+	u8 evm_dbm = 0;
+	u8 evm_percentage = 0;
 
 	/* SNR is S(8,1), EVM is S(8,1), CFO is S(8,7) */
 
 	if (rx_evm < 0) {
-		/* Calculate EVM in dBm */
+		/* @Calculate EVM in dBm */
 		evm_dbm = ((u8)(0 - rx_evm) >> 1);
 
-		/* Calculate EVM in percentage */
-		if (evm_dbm >= 34)
-			evm_percentage = 100;
-		else
-			evm_percentage = (evm_dbm << 1) + (evm_dbm);
-	}
+		if (evm_dbm == 64)
+			evm_dbm = 0; /*@if 1SS rate, evm_dbm [2nd stream] =64*/
 
-	p_phy_info->rx_pwr[rx_path] = rx_pwr;
+		if (evm_dbm != 0) {
+			/* @Convert EVM to 0%~100% percentage */
+			if (evm_dbm >= 34)
+				evm_percentage = 100;
+			else
+				evm_percentage = (evm_dbm << 1) + (evm_dbm);
+		}
+	}
 
-	/* CFO = CFO_tail * 312.5 / 2^7 ~= CFO tail * 39/512 (kHz)*/
-	p_phy_info->cfo_tail[rx_path] = cfo_tail;
-	p_phy_info->cfo_tail[rx_path] = ((p_phy_info->cfo_tail[rx_path] << 5) + (p_phy_info->cfo_tail[rx_path] << 2) +
-		(p_phy_info->cfo_tail[rx_path] << 1) + (p_phy_info->cfo_tail[rx_path])) >> 9;
+	phy_info->rx_pwr[rx_path] = pwr;
 
-	if (evm_dbm == 64)
-		evm_dbm = 0; /*if 1SS rate, evm_dbm [2nd stream] =64*/
+	/*@CFO(kHz) = CFO_tail * 312.5(kHz) / 2^7 ~= CFO tail * 5/2 (kHz)*/
+	phy_info->cfo_tail[rx_path] = (cfo_tail * 5) >> 1;
+	phy_info->rx_mimo_evm_dbm[rx_path] = evm_dbm;
+	phy_info->rx_mimo_signal_strength[rx_path] = phydm_pwr_2_percent(pwr);
+	phy_info->rx_mimo_signal_quality[rx_path] = evm_percentage;
+	phy_info->rx_snr[rx_path] = rx_snr >> 1;
+	phy_info->ant_idx[rx_path] = ant_idx;
 
-	p_phy_info->rx_mimo_evm_dbm[rx_path] = evm_dbm;
+#if 0
+	if (!pktinfo->is_packet_match_bssid)
+		return;
 
-	p_phy_info->rx_mimo_signal_strength[rx_path] = phydm_query_rx_pwr_percentage(rx_pwr);
-	p_phy_info->rx_mimo_signal_quality[rx_path] = evm_percentage;
-	p_phy_info->rx_snr[rx_path] = rx_snr >> 1;
+	dbg_print("path (%d)--------\n", rx_path);
+	dbg_print("rx_pwr = %d, Signal strength = %d\n",
+		  phy_info->rx_pwr[rx_path],
+		  phy_info->rx_mimo_signal_strength[rx_path]);
+	dbg_print("evm_dbm = %d, Signal quality = %d\n",
+		  phy_info->rx_mimo_evm_dbm[rx_path],
+		  phy_info->rx_mimo_signal_quality[rx_path]);
+	dbg_print("CFO = %d, SNR = %d\n",
+		  phy_info->cfo_tail[rx_path], phy_info->rx_snr[rx_path]);
 
-#if 0
-	/* if (p_pktinfo->is_packet_match_bssid) */
-	{
-		dbg_print("path (%d)--------\n", rx_path);
-		dbg_print("rx_pwr = %d, Signal strength = %d\n", p_phy_info->rx_pwr[rx_path], p_phy_info->rx_mimo_signal_strength[rx_path]);
-		dbg_print("evm_dbm = %d, Signal quality = %d\n", p_phy_info->rx_mimo_evm_dbm[rx_path], p_phy_info->rx_mimo_signal_quality[rx_path]);
-		dbg_print("CFO = %d, SNR = %d\n", p_phy_info->cfo_tail[rx_path], p_phy_info->rx_snr[rx_path]);
-	}
 #endif
 }
 
-void
-phydm_set_common_phy_info(
-	s8							rx_power,
-	u8							channel,
-	boolean							is_beamformed,
-	boolean							is_mu_packet,
-	u8							bandwidth,
-	u8							signal_quality,
-	u8							rxsc,
-	struct phydm_phyinfo_struct				*p_phy_info
-)
+void phydm_set_common_phy_info(s8 rx_power, u8 channel, boolean is_beamformed,
+			       boolean is_mu_packet, u8 bandwidth,
+			       u8 signal_quality, u8 rxsc,
+			       struct phydm_phyinfo_struct *phy_info)
 {
-	p_phy_info->rx_power = rx_power;											/* RSSI in dB */
-	p_phy_info->recv_signal_power = rx_power;										/* RSSI in dB */
-	p_phy_info->channel = channel;												/* channel number */
-	p_phy_info->is_beamformed = is_beamformed;									/* apply BF */
-	p_phy_info->is_mu_packet = is_mu_packet;										/* MU packet */
-	p_phy_info->rxsc = rxsc;
-
-	p_phy_info->rx_pwdb_all = phydm_query_rx_pwr_percentage(rx_power);				/* RSSI in percentage */
-	p_phy_info->signal_quality = signal_quality;										/* signal quality */
-	p_phy_info->band_width = bandwidth;											/* bandwidth */
+	phy_info->rx_power = rx_power; /* RSSI in dB */
+	phy_info->recv_signal_power = rx_power; /* RSSI in dB */
+	phy_info->channel = channel; /* @channel number */
+	phy_info->is_beamformed = is_beamformed; /* @apply BF */
+	phy_info->is_mu_packet = is_mu_packet; /* @MU packet */
+	phy_info->rxsc = rxsc;
+
+	/* RSSI in percentage */
+	phy_info->rx_pwdb_all = phydm_pwr_2_percent(rx_power);
+	phy_info->signal_quality = signal_quality; /* signal quality */
+	phy_info->band_width = bandwidth; /* @bandwidth */
 
 #if 0
-	/* if (p_pktinfo->is_packet_match_bssid) */
-	{
-		dbg_print("rx_pwdb_all = %d, rx_power = %d, recv_signal_power = %d\n", p_phy_info->rx_pwdb_all, p_phy_info->rx_power, p_phy_info->recv_signal_power);
-		dbg_print("signal_quality = %d\n", p_phy_info->signal_quality);
-		dbg_print("is_beamformed = %d, is_mu_packet = %d, rx_count = %d\n", p_phy_info->is_beamformed, p_phy_info->is_mu_packet, p_phy_info->rx_count + 1);
-		dbg_print("channel = %d, rxsc = %d, band_width = %d\n", channel, rxsc, bandwidth);
-	}
+	if (!pktinfo->is_packet_match_bssid)
+		return;
+
+	dbg_print("rx_pwdb_all = %d, rx_power = %d, recv_signal_power = %d\n",
+		  phy_info->rx_pwdb_all, phy_info->rx_power,
+		  phy_info->recv_signal_power);
+	dbg_print("signal_quality = %d\n", phy_info->signal_quality);
+	dbg_print("is_beamformed = %d, is_mu_packet = %d, rx_count = %d\n",
+		  phy_info->is_beamformed, phy_info->is_mu_packet,
+		  phy_info->rx_count + 1);
+	dbg_print("channel = %d, rxsc = %d, band_width = %d\n", channel,
+		  rxsc, bandwidth);
+
 #endif
 }
 
-void
-phydm_get_rx_phy_status_type0(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8							*p_phy_status,
-	struct phydm_perpkt_info_struct		*p_pktinfo,
-	struct phydm_phyinfo_struct	*p_phy_info
-)
+void phydm_get_phy_sts_type0(struct dm_struct *dm, u8 *phy_status_inf,
+			     struct phydm_perpkt_info_struct *pktinfo,
+			     struct phydm_phyinfo_struct *phy_info)
 {
 	/* type 0 is used for cck packet */
-	struct _phy_status_rpt_jaguar2_type0	*p_phy_sta_rpt = (struct _phy_status_rpt_jaguar2_type0 *)p_phy_status;
-	u8							SQ = 0;
-	s8							rx_power = p_phy_sta_rpt->pwdb - 110;
+	struct phy_sts_rpt_jgr2_type0 *phy_sts = NULL;
+	u8 sq = 0;
+	s8 rx_pow = 0;
+	u8 lna_idx = 0, vga_idx = 0;
+	u8 ant_idx;
 
+	phy_sts = (struct phy_sts_rpt_jgr2_type0 *)phy_status_inf;
+	rx_pow = phy_sts->pwdb - 110;
 
-	if (p_dm->support_ic_type & ODM_RTL8723D) {
-#if (RTL8723D_SUPPORT == 1)
-		rx_power = p_phy_sta_rpt->pwdb - 97;
-#endif
-	}
-/*#if (RTL8710B_SUPPORT == 1)*/
-	/*if (p_dm->support_ic_type & ODM_RTL8710B)*/
-		/*rx_power = p_phy_sta_rpt->pwdb - 97;*/
-/*#endif*/
+	/* Fill in per-path antenna index */
+	ant_idx = phy_sts->antidx_a;
 
-#if (RTL8821C_SUPPORT == 1)
-	else if (p_dm->support_ic_type & ODM_RTL8821C) {
-		if (p_phy_sta_rpt->pwdb >= -57)
-			rx_power = p_phy_sta_rpt->pwdb - 100;
+	if (dm->support_ic_type & ODM_RTL8723D) {
+		#if (RTL8723D_SUPPORT)
+		rx_pow = phy_sts->pwdb - 97;
+		#endif
+	}
+	#if (RTL8821C_SUPPORT)
+	else if (dm->support_ic_type & ODM_RTL8821C) {
+		if (phy_sts->pwdb >= -57)
+			rx_pow = phy_sts->pwdb - 100;
 		else
-			rx_power = p_phy_sta_rpt->pwdb - 102;
+			rx_pow = phy_sts->pwdb - 102;
 	}
-#endif
+	#endif
 
-	if (p_pktinfo->is_to_self) {
-		p_dm->ofdm_agc_idx[0] = p_phy_sta_rpt->pwdb;
-		p_dm->ofdm_agc_idx[1] = 0;
-		p_dm->ofdm_agc_idx[2] = 0;
-		p_dm->ofdm_agc_idx[3] = 0;
+	if (pktinfo->is_to_self) {
+		dm->ofdm_agc_idx[0] = phy_sts->pwdb;
+		dm->ofdm_agc_idx[1] = 0;
+		dm->ofdm_agc_idx[2] = 0;
+		dm->ofdm_agc_idx[3] = 0;
 	}
 
-
-	/* Calculate Signal Quality*/
-	if (p_pktinfo->is_packet_match_bssid) {
-		if (p_phy_sta_rpt->signal_quality >= 64)
-			SQ = 0;
-		else if (p_phy_sta_rpt->signal_quality <= 20)
-			SQ = 100;
-		else {
-			/* mapping to 2~99% */
-			SQ = 64 - p_phy_sta_rpt->signal_quality;
-			SQ = ((SQ << 3) + SQ) >> 2;
-		}
+	/* @Calculate Signal Quality*/
+	if (phy_sts->signal_quality >= 64) {
+		sq = 0;
+	} else if (phy_sts->signal_quality <= 20) {
+		sq = 100;
+	} else {
+		/* @mapping to 2~99% */
+		sq = 64 - phy_sts->signal_quality;
+		sq = ((sq << 3) + sq) >> 2;
 	}
 
-	/* Modify CCK PWDB if old AGC */
-	if (p_dm->cck_new_agc == false) {
-
-		#if (RTL8197F_SUPPORT == 1)
-		if (p_dm->support_ic_type & ODM_RTL8197F)
-			rx_power = phydm_cck_rssi_convert(p_dm, p_phy_sta_rpt->lna_l, p_phy_sta_rpt->vga);
-		else
-		#endif
-		{
-			u8	lna_idx, vga_idx;
-
-			lna_idx = ((p_phy_sta_rpt->lna_h << 3) | p_phy_sta_rpt->lna_l);
-			vga_idx = p_phy_sta_rpt->vga;
-
-			#if (RTL8723D_SUPPORT == 1)
-			if (p_dm->support_ic_type & ODM_RTL8723D)
-				rx_power = odm_cckrssi_8723d(lna_idx, vga_idx);
-			#endif
-
-			#if (RTL8710B_SUPPORT == 1)
-			if (p_dm->support_ic_type & ODM_RTL8710B)
-				rx_power = odm_cckrssi_8710b(lna_idx, vga_idx);
-			#endif
-
-			#if (RTL8822B_SUPPORT == 1)
-			/* Need to do !! */
-			/*if (p_dm->support_ic_type & ODM_RTL8822B) */
-			/*rx_power = odm_CCKRSSI_8822B(LNA_idx, VGA_idx);*/
-			#endif
+	/* @Get RSSI for old CCK AGC */
+	if (!dm->cck_new_agc) {
+		vga_idx = phy_sts->vga;
 
-			#if (RTL8821C_SUPPORT == 1)
-				if (p_dm->support_ic_type & ODM_RTL8821C)
-					rx_power = phydm_cck_rssi_8821c(p_dm, lna_idx, vga_idx);
-			#endif
+		if (dm->support_ic_type & ODM_RTL8197F) {
+			/*@3bit LNA*/
+			lna_idx = phy_sts->lna_l;
+		} else {
+			/*@4bit LNA*/
+			lna_idx = (phy_sts->lna_h << 3) | phy_sts->lna_l;
 		}
-
+		rx_pow = phydm_get_cck_rssi(dm, lna_idx, vga_idx);
 	}
 
-	/* Confirm CCK RSSI */
-	#if (RTL8197F_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8197F) {
-		u8	bb_pwr_th_l = 5; /* round( 31*0.15 ) */
-		u8	bb_pwr_th_h = 27; /* round( 31*0.85 ) */
+	/* @Confirm CCK RSSI */
+	#if (RTL8197F_SUPPORT)
+	if (dm->support_ic_type & ODM_RTL8197F) {
+		u8 bb_pwr_th_l = 5; /* round( 31*0.15 ) */
+		u8 bb_pwr_th_h = 27; /* round( 31*0.85 ) */
 
-		if ((p_phy_sta_rpt->bb_power < bb_pwr_th_l) || (p_phy_sta_rpt->bb_power > bb_pwr_th_h))
-			rx_power = 0; /* Error RSSI for CCK ; set 100*/
+		if (phy_sts->bb_power < bb_pwr_th_l ||
+		    phy_sts->bb_power > bb_pwr_th_h)
+			rx_pow = 0; /* @Error RSSI for CCK ; set 100*/
 	}
 	#endif
 
-	/* Update CCK packet counter */
-	p_dm->phy_dbg_info.num_qry_phy_status_cck++;
-
-	/*CCK no STBC and LDPC*/
-	p_dm->phy_dbg_info.is_ldpc_pkt = false;
-	p_dm->phy_dbg_info.is_stbc_pkt = false;
+	/*@CCK no STBC and LDPC*/
+	dm->phy_dbg_info.is_ldpc_pkt = false;
+	dm->phy_dbg_info.is_stbc_pkt = false;
 
 	/* Update Common information */
-	phydm_set_common_phy_info(rx_power, p_phy_sta_rpt->channel, false,
-		  false, CHANNEL_WIDTH_20, SQ, p_phy_sta_rpt->rxsc, p_phy_info);
-
+	phydm_set_common_phy_info(rx_pow, phy_sts->channel, false,
+				  false, CHANNEL_WIDTH_20, sq,
+				  phy_sts->rxsc, phy_info);
 	/* Update CCK pwdb */
-	phydm_set_per_path_phy_info(RF_PATH_A, rx_power, 0, 0, 0, p_phy_info);					/* Update per-path information */
-
-	p_dm->dm_fat_table.antsel_rx_keep_0 = p_phy_sta_rpt->antidx_a;
-	p_dm->dm_fat_table.antsel_rx_keep_1 = p_phy_sta_rpt->antidx_b;
-	p_dm->dm_fat_table.antsel_rx_keep_2 = p_phy_sta_rpt->antidx_c;
-	p_dm->dm_fat_table.antsel_rx_keep_3 = p_phy_sta_rpt->antidx_d;
-#if 0
-	/* if (p_pktinfo->is_packet_match_bssid) */
-	{
-		dbg_print("pwdb = 0x%x, MP gain index = 0x%x, TRSW = 0x%x\n", p_phy_sta_rpt->pwdb, p_phy_sta_rpt->gain, p_phy_sta_rpt->trsw);
-		dbg_print("channel = %d, band = %d, rxsc = %d\n", p_phy_sta_rpt->channel, p_phy_sta_rpt->band, p_phy_sta_rpt->rxsc);
-		dbg_print("agc_table = 0x%x, agc_rpt 0x%x, bb_power = 0x%x\n", p_phy_sta_rpt->agc_table, p_phy_sta_rpt->agc_rpt, p_phy_sta_rpt->bb_power);
-		dbg_print("length = %d, SQ = %d\n", p_phy_sta_rpt->length, p_phy_sta_rpt->signal_quality);
-		dbg_print("antidx a = 0x%x, b = 0x%x, c = 0x%x, d = 0x%x\n", p_phy_sta_rpt->antidx_a, p_phy_sta_rpt->antidx_b, p_phy_sta_rpt->antidx_c, p_phy_sta_rpt->antidx_d);
-		dbg_print("rsvd_0 = 0x%x, rsvd_1 = 0x%x, rsvd_2 = 0x%x\n", p_phy_sta_rpt->rsvd_0, p_phy_sta_rpt->rsvd_1, p_phy_sta_rpt->rsvd_2);
-		dbg_print("rsvd_3 = 0x%x, rsvd_4 = 0x%x, rsvd_5 = 0x%x\n", p_phy_sta_rpt->rsvd_3, p_phy_sta_rpt->rsvd_4, p_phy_sta_rpt->rsvd_5);
-		dbg_print("rsvd_6 = 0x%x, rsvd_7 = 0x%x, rsvd_8 = 0x%x\n", p_phy_sta_rpt->rsvd_6, p_phy_sta_rpt->rsvd_7, p_phy_sta_rpt->rsvd_8);
-	}
-#endif
+	phydm_set_per_path_phy_info(RF_PATH_A, rx_pow, 0, 0, 0, ant_idx,
+				    phy_info);
+
+	#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sts->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sts->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sts->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sts->antidx_d;
+	#endif
 }
 
-void
-phydm_get_rx_phy_status_type1(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8							*p_phy_status,
-	struct phydm_perpkt_info_struct		*p_pktinfo,
-	struct phydm_phyinfo_struct	*p_phy_info
-)
+void phydm_get_phy_sts_type1(struct dm_struct *dm, u8 *phy_status_inf,
+			     struct phydm_perpkt_info_struct *pktinfo,
+			     struct phydm_phyinfo_struct *phy_info)
 {
 	/* type 1 is used for ofdm packet */
-
-	struct _phy_status_rpt_jaguar2_type1	*p_phy_sta_rpt = (struct _phy_status_rpt_jaguar2_type1 *)p_phy_status;
-	s8							rx_pwr_db = -120;
-	u8							i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
-	boolean						is_mu;
-	u8							num_ss;
-
-	/* Update OFDM packet counter */
-	p_dm->phy_dbg_info.num_qry_phy_status_ofdm++;
+	struct phy_sts_rpt_jgr2_type1 *phy_sts = NULL;
+	struct odm_phy_dbg_info *dbg_i = &dm->phy_dbg_info;
+	s8 rx_pwr_db = -120;
+	s8 rx_pwr = 0;
+	u8 i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
+	boolean is_mu;
+	u8 ant_idx[4];
+
+	phy_sts = (struct phy_sts_rpt_jgr2_type1 *)phy_status_inf;
+
+	/* Fill in per-path antenna index */
+	ant_idx[0] = phy_sts->antidx_a;
+	ant_idx[1] = phy_sts->antidx_b;
+	ant_idx[2] = phy_sts->antidx_c;
+	ant_idx[3] = phy_sts->antidx_d;
 
 	/* Update per-path information */
-	for (i = RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-		if (p_dm->rx_ant_status & BIT(i)) {
-			s8	rx_path_pwr_db;
-
-			/* RX path counter */
-			rx_count++;
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (!(dm->rx_ant_status & BIT(i)))
+			continue;
+		rx_count++;
 
-			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO SQ) */
-			/* EVM report is reported by stream, not path */
-			rx_path_pwr_db = p_phy_sta_rpt->pwdb[i] - 110;					/* per-path pwdb in dB domain */
-
-			if (p_pktinfo->is_to_self)
-				p_dm->ofdm_agc_idx[i] = p_phy_sta_rpt->pwdb[i];
-
-			phydm_set_per_path_phy_info(i, rx_path_pwr_db, p_phy_sta_rpt->rxevm[rx_count - 1],
-				p_phy_sta_rpt->cfo_tail[i], p_phy_sta_rpt->rxsnr[i], p_phy_info);
+		if (rx_count > dm->num_rf_path)
+			break;
 
-			/* search maximum pwdb */
-			if (rx_path_pwr_db > rx_pwr_db)
-				rx_pwr_db = rx_path_pwr_db;
-		}
+		/* Update per-path information
+		 * (RSSI_dB RSSI_percentage EVM SNR CFO sq)
+		 */
+		/* @EVM report is reported by stream, not path */
+		rx_pwr = phy_sts->pwdb[i] - 110; /* per-path pwdb(dB)*/
+
+		if (pktinfo->is_to_self)
+			dm->ofdm_agc_idx[i] = phy_sts->pwdb[i];
+
+		phydm_set_per_path_phy_info(i, rx_pwr,
+					    phy_sts->rxevm[rx_count - 1],
+					    phy_sts->cfo_tail[i],
+					    phy_sts->rxsnr[i],
+					    ant_idx[i], phy_info);
+		/* search maximum pwdb */
+		if (rx_pwr > rx_pwr_db)
+			rx_pwr_db = rx_pwr;
 	}
 
-	/* mapping RX counter from 1~4 to 0~3 */
+	/* @mapping RX counter from 1~4 to 0~3 */
 	if (rx_count > 0)
-		p_phy_info->rx_count = rx_count - 1;
+		phy_info->rx_count = rx_count - 1;
 
-	/* Check if MU packet or not */
-	if ((p_phy_sta_rpt->gid != 0) && (p_phy_sta_rpt->gid != 63)) {
+	/* @Check if MU packet or not */
+	if (phy_sts->gid != 0 && phy_sts->gid != 63) {
 		is_mu = true;
-		p_dm->phy_dbg_info.num_qry_mu_pkt++;
-	} else
+		dbg_i->num_qry_mu_pkt++;
+	} else {
 		is_mu = false;
+	}
 
-	/* count BF packet */
-	p_dm->phy_dbg_info.num_qry_bf_pkt = p_dm->phy_dbg_info.num_qry_bf_pkt + p_phy_sta_rpt->beamformed;
+	/* @count BF packet */
+	dbg_i->num_qry_bf_pkt = dbg_i->num_qry_bf_pkt + phy_sts->beamformed;
 
 	/*STBC or LDPC pkt*/
-	p_dm->phy_dbg_info.is_ldpc_pkt = p_phy_sta_rpt->ldpc;
-	p_dm->phy_dbg_info.is_stbc_pkt = p_phy_sta_rpt->stbc;
+	dbg_i->is_ldpc_pkt = phy_sts->ldpc;
+	dbg_i->is_stbc_pkt = phy_sts->stbc;
 
-	/* Check sub-channel */
-	if ((p_pktinfo->data_rate > ODM_RATE11M) && (p_pktinfo->data_rate < ODM_RATEMCS0))
-		rxsc = p_phy_sta_rpt->l_rxsc;
+	/* @Check sub-channel */
+	if (pktinfo->data_rate > ODM_RATE11M &&
+	    pktinfo->data_rate < ODM_RATEMCS0)
+		rxsc = phy_sts->l_rxsc;
 	else
-		rxsc = p_phy_sta_rpt->ht_rxsc;
+		rxsc = phy_sts->ht_rxsc;
 
-	/* Check RX bandwidth */
-	if (p_dm->support_ic_type & ODM_RTL8822B) {
-		if ((rxsc >= 1) && (rxsc <= 8))
+	/* @Check RX bandwidth */
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (rxsc >= 1 && rxsc <= 8)
 			bw = CHANNEL_WIDTH_20;
 		else if ((rxsc >= 9) && (rxsc <= 12))
 			bw = CHANNEL_WIDTH_40;
 		else if (rxsc >= 13)
 			bw = CHANNEL_WIDTH_80;
 		else
-			bw = p_phy_sta_rpt->rf_mode;
-	} else if (p_dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8723D | ODM_RTL8710B)) {
-		if (p_phy_sta_rpt->rf_mode == 0)
+			bw = phy_sts->rf_mode;
+
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (phy_sts->rf_mode == 0)
 			bw = CHANNEL_WIDTH_20;
 		else if ((rxsc == 1) || (rxsc == 2))
 			bw = CHANNEL_WIDTH_20;
@@ -2216,366 +2851,337 @@ phydm_get_rx_phy_status_type1(
 	}
 
 	/* Update packet information */
-	phydm_set_common_phy_info(rx_pwr_db, p_phy_sta_rpt->channel, (boolean)p_phy_sta_rpt->beamformed,
-		is_mu, bw, p_phy_info->rx_mimo_signal_quality[0], rxsc, p_phy_info);
-
-	num_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
-
-	odm_parsing_cfo(p_dm, p_pktinfo, p_phy_sta_rpt->cfo_tail, num_ss);
-	p_dm->dm_fat_table.antsel_rx_keep_0 = p_phy_sta_rpt->antidx_a;
-	p_dm->dm_fat_table.antsel_rx_keep_1 = p_phy_sta_rpt->antidx_b;
-	p_dm->dm_fat_table.antsel_rx_keep_2 = p_phy_sta_rpt->antidx_c;
-	p_dm->dm_fat_table.antsel_rx_keep_3 = p_phy_sta_rpt->antidx_d;
-
-	#if 0
-	if (p_pktinfo->is_packet_match_bssid) {
-
-		dbg_print("channel = %d, band = %d, l_rxsc = %d, ht_rxsc = %d, rf_mode = %d\n", p_phy_sta_rpt->channel, p_phy_sta_rpt->band, p_phy_sta_rpt->l_rxsc, p_phy_sta_rpt->ht_rxsc, p_phy_sta_rpt->rf_mode);
-		dbg_print("Antidx A = %d, B = %d, C = %d, D = %d\n", p_phy_sta_rpt->antidx_a, p_phy_sta_rpt->antidx_b, p_phy_sta_rpt->antidx_c, p_phy_sta_rpt->antidx_d);
-		dbg_print("pwdb A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->pwdb[0], p_phy_sta_rpt->pwdb[1], p_phy_sta_rpt->pwdb[2], p_phy_sta_rpt->pwdb[3]);
-		dbg_print("EVM  A: %d, B: %d, C: %d, D: %d\n", p_phy_sta_rpt->rxevm[0], p_phy_sta_rpt->rxevm[1], p_phy_sta_rpt->rxevm[2], p_phy_sta_rpt->rxevm[3]);
-		dbg_print("SNR  A: %d, B: %d, C: %d, D: %d\n", p_phy_sta_rpt->rxsnr[0], p_phy_sta_rpt->rxsnr[1], p_phy_sta_rpt->rxsnr[2], p_phy_sta_rpt->rxsnr[3]);
-		dbg_print("CFO  A: %d, B: %d, C: %d, D: %d\n", p_phy_sta_rpt->cfo_tail[0], p_phy_sta_rpt->cfo_tail[1], p_phy_sta_rpt->cfo_tail[2], p_phy_sta_rpt->cfo_tail[3]);
-		dbg_print("paid = %d, gid = %d, length = %d\n", (p_phy_sta_rpt->paid + (p_phy_sta_rpt->paid_msb<<8)), p_phy_sta_rpt->gid, p_phy_sta_rpt->lsig_length);
-		dbg_print("ldpc: %d, stbc: %d, bf: %d, gnt_bt: %d, antsw: %d\n", p_phy_sta_rpt->ldpc, p_phy_sta_rpt->stbc, p_phy_sta_rpt->beamformed, p_phy_sta_rpt->gnt_bt, p_phy_sta_rpt->hw_antsw_occu);
-		dbg_print("NBI: %d, pos: %d\n", p_phy_sta_rpt->nb_intf_flag, (p_phy_sta_rpt->intf_pos + (p_phy_sta_rpt->intf_pos_msb<<8)));
-		dbg_print("rsvd_0 = %d, rsvd_1 = %d, rsvd_2 = %d, rsvd_3 = %d, rsvd_4 = %d, rsvd_5 = %d\n", p_phy_sta_rpt->rsvd_0, p_phy_sta_rpt->rsvd_1, p_phy_sta_rpt->rsvd_2, p_phy_sta_rpt->rsvd_3, p_phy_sta_rpt->rsvd_4, p_phy_sta_rpt->rsvd_5);
-
-	}
+	phydm_set_common_phy_info(rx_pwr_db, phy_sts->channel,
+				  (boolean)phy_sts->beamformed, is_mu, bw,
+				  phy_info->rx_mimo_signal_quality[0],
+				  rxsc, phy_info);
+
+	phydm_parsing_cfo(dm, pktinfo, phy_sts->cfo_tail, pktinfo->rate_ss);
+	#ifdef PHYDM_LNA_SAT_CHK_TYPE2
+	phydm_parsing_snr(dm, pktinfo, phy_sts->rxsnr);
+	#endif
 
-	dbg_print("phydm_get_rx_phy_status_type1   p_pktinfo->is_packet_match_bssid = %d\n", p_pktinfo->is_packet_match_bssid);
-	dbg_print("p_pktinfo->data_rate = 0x%x\n", p_pktinfo->data_rate);
+	#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
+	dm->dm_fat_table.antsel_rx_keep_0 = phy_sts->antidx_a;
+	dm->dm_fat_table.antsel_rx_keep_1 = phy_sts->antidx_b;
+	dm->dm_fat_table.antsel_rx_keep_2 = phy_sts->antidx_c;
+	dm->dm_fat_table.antsel_rx_keep_3 = phy_sts->antidx_d;
 	#endif
 }
 
-void
-phydm_get_rx_phy_status_type2(
-	struct PHY_DM_STRUCT						*p_dm,
-	u8							*p_phy_status,
-	struct phydm_perpkt_info_struct				*p_pktinfo,
-	struct phydm_phyinfo_struct				*p_phy_info
-)
+void phydm_get_phy_sts_type2(struct dm_struct *dm, u8 *phy_status_inf,
+			     struct phydm_perpkt_info_struct *pktinfo,
+			     struct phydm_phyinfo_struct *phy_info)
 {
-	struct _phy_status_rpt_jaguar2_type2	*p_phy_sta_rpt = (struct _phy_status_rpt_jaguar2_type2 *)p_phy_status;
-	s8							rx_pwr_db = -120;
-	u8							i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
+	struct phy_sts_rpt_jgr2_type2 *phy_sts = NULL;
+	s8 rx_pwr_db_max = -120;
+	s8 rx_pwr = 0;
+	u8 i, rxsc, bw = CHANNEL_WIDTH_20, rx_count = 0;
 
-	/* Update OFDM packet counter */
-	p_dm->phy_dbg_info.num_qry_phy_status_ofdm++;
+	phy_sts = (struct phy_sts_rpt_jgr2_type2 *)phy_status_inf;
 
-	/* Update per-path information */
-	for (i = RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-		if (p_dm->rx_ant_status & BIT(i)) {
-			s8	rx_path_pwr_db;
-
-			/* RX path counter */
-			rx_count++;
-
-			/* Update per-path information (RSSI_dB RSSI_percentage EVM SNR CFO SQ) */
-#if (RTL8197F_SUPPORT == 1)
-			if ((p_dm->support_ic_type & ODM_RTL8197F) && (p_phy_sta_rpt->pwdb[i] == 0x7f)) { /*for 97f workaround*/
-
-				if (i == RF_PATH_A) {
-					rx_path_pwr_db = (p_phy_sta_rpt->gain_a) << 1;
-					rx_path_pwr_db = rx_path_pwr_db - 110;
-				} else if (i == RF_PATH_B) {
-					rx_path_pwr_db = (p_phy_sta_rpt->gain_b) << 1;
-					rx_path_pwr_db = rx_path_pwr_db - 110;
-				} else
-					rx_path_pwr_db = 0;
-			} else
-#endif
-				rx_path_pwr_db = p_phy_sta_rpt->pwdb[i] - 110;					/* per-path pwdb in dB domain */
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		if (!(dm->rx_ant_status & BIT(i)))
+			continue;
+		rx_count++;
 
-			phydm_set_per_path_phy_info(i, rx_path_pwr_db, 0, 0, 0, p_phy_info);
+		if (rx_count > dm->num_rf_path)
+			break;
 
-			/* search maximum pwdb */
-			if (rx_path_pwr_db > rx_pwr_db)
-				rx_pwr_db = rx_path_pwr_db;
-		}
+		/* Update per-path information*/
+		/* RSSI_dB, RSSI_percentage, EVM, SNR, CFO, sq */
+		#if (RTL8197F_SUPPORT)
+		if ((dm->support_ic_type & ODM_RTL8197F) &&
+		    phy_sts->pwdb[i] == 0x7f) { /*@97f workaround*/
+
+			if (i == RF_PATH_A) {
+				rx_pwr = (phy_sts->gain_a) << 1;
+				rx_pwr = rx_pwr - 110;
+			} else if (i == RF_PATH_B) {
+				rx_pwr = (phy_sts->gain_b) << 1;
+				rx_pwr = rx_pwr - 110;
+			} else {
+				rx_pwr = 0;
+			}
+		} else
+		#endif
+			rx_pwr = phy_sts->pwdb[i] - 110; /*@dBm*/
+
+		phydm_set_per_path_phy_info(i, rx_pwr, 0, 0, 0, 0, phy_info);
+
+		if (rx_pwr > rx_pwr_db_max) /* search max pwdb */
+			rx_pwr_db_max = rx_pwr;
 	}
 
-	/* mapping RX counter from 1~4 to 0~3 */
+	/* @mapping RX counter from 1~4 to 0~3 */
 	if (rx_count > 0)
-		p_phy_info->rx_count = rx_count - 1;
+		phy_info->rx_count = rx_count - 1;
 
-	/* Check RX sub-channel */
-	if ((p_pktinfo->data_rate > ODM_RATE11M) && (p_pktinfo->data_rate < ODM_RATEMCS0))
-		rxsc = p_phy_sta_rpt->l_rxsc;
+	/* @Check RX sub-channel */
+	if (pktinfo->data_rate > ODM_RATE11M &&
+	    pktinfo->data_rate < ODM_RATEMCS0)
+		rxsc = phy_sts->l_rxsc;
 	else
-		rxsc = p_phy_sta_rpt->ht_rxsc;
+		rxsc = phy_sts->ht_rxsc;
 
 	/*STBC or LDPC pkt*/
-	p_dm->phy_dbg_info.is_ldpc_pkt = p_phy_sta_rpt->ldpc;
-	p_dm->phy_dbg_info.is_stbc_pkt = p_phy_sta_rpt->stbc;
-
-	/* Check RX bandwidth */
-	/* the BW information of sc=0 is useless, because there is no information of RF mode*/
-
-	if (p_dm->support_ic_type & ODM_RTL8822B) {
-		if ((rxsc >= 1) && (rxsc <= 8))
+	dm->phy_dbg_info.is_ldpc_pkt = phy_sts->ldpc;
+	dm->phy_dbg_info.is_stbc_pkt = phy_sts->stbc;
+
+	/* @Check RX bandwidth */
+	/* @BW information of sc=0 is useless,
+	 *because there is no information of RF mode
+	 */
+	if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		if (rxsc >= 1 && rxsc <= 8)
 			bw = CHANNEL_WIDTH_20;
 		else if ((rxsc >= 9) && (rxsc <= 12))
 			bw = CHANNEL_WIDTH_40;
 		else if (rxsc >= 13)
 			bw = CHANNEL_WIDTH_80;
-		else
-			bw = CHANNEL_WIDTH_20;
-	} else if (p_dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8723D | ODM_RTL8710B)) {/* JJ ADD 20161014 */
+
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
 		if (rxsc == 3)
 			bw = CHANNEL_WIDTH_40;
 		else if ((rxsc == 1) || (rxsc == 2))
 			bw = CHANNEL_WIDTH_20;
-		else
-			bw = CHANNEL_WIDTH_20;
 	}
 
 	/* Update packet information */
-	phydm_set_common_phy_info(rx_pwr_db, p_phy_sta_rpt->channel, (boolean)p_phy_sta_rpt->beamformed,
-				  false, bw, 0, rxsc, p_phy_info);
-
-#if 0
-	/* if (p_pktinfo->is_packet_match_bssid) */
-	{
-		dbg_print("channel = %d, band = %d, l_rxsc = %d, ht_rxsc = %d\n", p_phy_sta_rpt->channel, p_phy_sta_rpt->band, p_phy_sta_rpt->l_rxsc, p_phy_sta_rpt->ht_rxsc);
-		dbg_print("pwdb A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->pwdb[0], p_phy_sta_rpt->pwdb[1], p_phy_sta_rpt->pwdb[2], p_phy_sta_rpt->pwdb[3]);
-		dbg_print("Agc table A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->agc_table_a, p_phy_sta_rpt->agc_table_b, p_phy_sta_rpt->agc_table_c, p_phy_sta_rpt->agc_table_d);
-		dbg_print("Gain A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->gain_a, p_phy_sta_rpt->gain_b, p_phy_sta_rpt->gain_c, p_phy_sta_rpt->gain_d);
-		dbg_print("TRSW A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->trsw_a, p_phy_sta_rpt->trsw_b, p_phy_sta_rpt->trsw_c, p_phy_sta_rpt->trsw_d);
-		dbg_print("AAGC step A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->aagc_step_a, p_phy_sta_rpt->aagc_step_b, p_phy_sta_rpt->aagc_step_c, p_phy_sta_rpt->aagc_step_d);
-		dbg_print("HT AAGC gain A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->ht_aagc_gain[0], p_phy_sta_rpt->ht_aagc_gain[1], p_phy_sta_rpt->ht_aagc_gain[2], p_phy_sta_rpt->ht_aagc_gain[3]);
-		dbg_print("DAGC gain A: 0x%x, B: 0x%x, C: 0x%x, D: 0x%x\n", p_phy_sta_rpt->dagc_gain[0], p_phy_sta_rpt->dagc_gain[1], p_phy_sta_rpt->dagc_gain[2], p_phy_sta_rpt->dagc_gain[3]);
-		dbg_print("ldpc: %d, stbc: %d, bf: %d, gnt_bt: %d, antsw: %d\n", p_phy_sta_rpt->ldpc, p_phy_sta_rpt->stbc, p_phy_sta_rpt->beamformed, p_phy_sta_rpt->gnt_bt, p_phy_sta_rpt->hw_antsw_occu);
-		dbg_print("counter: %d, syn_count: %d\n", p_phy_sta_rpt->counter, p_phy_sta_rpt->syn_count);
-		dbg_print("cnt_cca2agc_rdy: %d, cnt_pw2cca: %d, shift_l_map\n", p_phy_sta_rpt->cnt_cca2agc_rdy, p_phy_sta_rpt->cnt_pw2cca, p_phy_sta_rpt->shift_l_map);
-		dbg_print("rsvd_0 = %d, rsvd_1 = %d, rsvd_2 = %d, rsvd_3 = %d, rsvd_4 = %d, rsvd_5 = %d\n", p_phy_sta_rpt->rsvd_0, p_phy_sta_rpt->rsvd_1, p_phy_sta_rpt->rsvd_2, p_phy_sta_rpt->rsvd_3, p_phy_sta_rpt->rsvd_4);
-		dbg_print("rsvd_5 = %d, rsvd_6 = %d, rsvd_6 = %d\n", p_phy_sta_rpt->rsvd_5, p_phy_sta_rpt->rsvd_6, p_phy_sta_rpt->rsvd_7);
-	}
-#endif
-}
-
-void
-phydm_get_rx_phy_status_type5(
-	u8				*p_phy_status
-)
-{
-	/*
-		dbg_print("DW0: 0x%02x%02x%02x%02x\n", *(p_phy_status + 3), *(p_phy_status + 2), *(p_phy_status + 1), *(p_phy_status + 0));
-		dbg_print("DW1: 0x%02x%02x%02x%02x\n", *(p_phy_status + 7), *(p_phy_status + 6), *(p_phy_status + 5), *(p_phy_status + 4));
-		dbg_print("DW2: 0x%02x%02x%02x%02x\n", *(p_phy_status + 11), *(p_phy_status + 10), *(p_phy_status + 9), *(p_phy_status + 8));
-		dbg_print("DW3: 0x%02x%02x%02x%02x\n", *(p_phy_status + 15), *(p_phy_status + 14), *(p_phy_status + 13), *(p_phy_status + 12));
-		dbg_print("DW4: 0x%02x%02x%02x%02x\n", *(p_phy_status + 19), *(p_phy_status + 18), *(p_phy_status + 17), *(p_phy_status + 16));
-		dbg_print("DW5: 0x%02x%02x%02x%02x\n", *(p_phy_status + 23), *(p_phy_status + 22), *(p_phy_status + 21), *(p_phy_status + 20));
-		dbg_print("DW6: 0x%02x%02x%02x%02x\n", *(p_phy_status + 27), *(p_phy_status + 26), *(p_phy_status + 25), *(p_phy_status + 24));
-	*/
+	phydm_set_common_phy_info(rx_pwr_db_max, phy_sts->channel,
+				  (boolean)phy_sts->beamformed,
+				  false, bw, 0, rxsc, phy_info);
 }
 
-void
-phydm_process_rssi_for_dm_new_type(
-	struct PHY_DM_STRUCT			*p_dm,
-	struct phydm_phyinfo_struct		*p_phy_info,
-	struct phydm_perpkt_info_struct			*p_pktinfo
-)
+void phydm_process_rssi_for_dm_2nd_type(struct dm_struct *dm,
+					struct phydm_phyinfo_struct *phy_info,
+					struct phydm_perpkt_info_struct *pktinfo
+					)
 {
-	s32				undecorated_smoothed_pwdb, accumulate_pwdb;
-	u32				rssi_ave, rssi_linear = 0;
-	u8				i;
-	struct cmn_sta_info	*p_sta;
-	u8				scaling_factor = 4;
-	u8				is_cck_rate = (p_pktinfo->data_rate <= ODM_RATE11M) ? true : false;
-
-	if (p_pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
+	struct cmn_sta_info *sta = NULL;
+	struct rssi_info *rssi_t = NULL;
+	u8 rssi_tmp = 0;
+	u64 rssi_linear = 0;
+	s16 rssi_db = 0;
+	u8 i = 0;
+
+	if (pktinfo->station_id >= ODM_ASSOCIATE_ENTRY_NUM)
 		return;
 
-	p_sta = p_dm->p_phydm_sta_info[p_pktinfo->station_id];
+	sta = dm->phydm_sta_info[pktinfo->station_id];
 
-	if (!is_sta_active(p_sta))
+	if (!is_sta_active(sta))
 		return;
 
-	if ((!p_pktinfo->is_packet_match_bssid))/*data frame only*/
+	if (!pktinfo->is_packet_match_bssid) /*@data frame only*/
 		return;
 
-	if (p_pktinfo->is_packet_beacon)
-		p_dm->phy_dbg_info.num_qry_beacon_pkt++;
-
 #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
-	if (p_dm->support_ability & ODM_BB_ANT_DIV)
-		odm_process_rssi_for_ant_div(p_dm, p_phy_info, p_pktinfo);
+	if (dm->support_ability & ODM_BB_ANT_DIV)
+		odm_process_rssi_for_ant_div(dm, phy_info, pktinfo);
 #endif
 
-#ifdef CONFIG_DYNAMIC_RX_PATH
-	phydm_process_phy_status_for_dynamic_rx_path(p_dm, p_phy_info, p_pktinfo);
+#ifdef CONFIG_ADAPTIVE_SOML
+	phydm_rx_qam_for_soml(dm, pktinfo);
+	phydm_rx_rate_for_soml(dm, pktinfo);
 #endif
 
-	if (p_pktinfo->is_packet_to_self || p_pktinfo->is_packet_beacon) {
-
-		p_dm->rx_rate = p_pktinfo->data_rate;
-		undecorated_smoothed_pwdb = p_sta->rssi_stat.rssi;
-		accumulate_pwdb = p_dm->accumulate_pwdb[p_pktinfo->station_id];
-		p_dm->RSSI_A = p_phy_info->rx_mimo_signal_strength[RF_PATH_A];
-		p_dm->RSSI_B = p_phy_info->rx_mimo_signal_strength[RF_PATH_B];
-		p_dm->RSSI_C = p_phy_info->rx_mimo_signal_strength[RF_PATH_C];
-		p_dm->RSSI_D = p_phy_info->rx_mimo_signal_strength[RF_PATH_D];
-
-		for (i = RF_PATH_A; i < ODM_RF_PATH_MAX_JAGUAR; i++) {
-			if (p_phy_info->rx_mimo_signal_strength[i] != 0)
-				rssi_linear += odm_convert_to_linear(p_phy_info->rx_mimo_signal_strength[i]);
-		}
+	if (!(pktinfo->is_packet_to_self) && !(pktinfo->is_packet_beacon))
+		return;
 
-		switch (p_phy_info->rx_count + 1) {
-		case 2:
-			rssi_linear = (rssi_linear >> 1);
-			break;
-		case 3:
-			rssi_linear = ((rssi_linear) + (rssi_linear << 1) + (rssi_linear << 3)) >> 5;	/* RSSI_linear/3 ~ RSSI_linear*11/32 */
-			break;
-		case 4:
-			rssi_linear = (rssi_linear >> 2);
-			break;
-		}
-		rssi_ave = odm_convert_to_db(rssi_linear);
+	if (pktinfo->is_packet_beacon) {
+		dm->phy_dbg_info.num_qry_beacon_pkt++;
+		dm->phy_dbg_info.beacon_phy_rate = pktinfo->data_rate;
+	}
 
-		if (undecorated_smoothed_pwdb <= 0) {
-			accumulate_pwdb = (p_phy_info->rx_pwdb_all << scaling_factor);
-			undecorated_smoothed_pwdb = p_phy_info->rx_pwdb_all;
-		} else {
-			accumulate_pwdb = accumulate_pwdb - (accumulate_pwdb >> scaling_factor) + rssi_ave;
-			undecorated_smoothed_pwdb = (accumulate_pwdb + (1 << (scaling_factor - 1))) >> scaling_factor;
-		}
+	rssi_t = &sta->rssi_stat;
 
-		p_sta->rssi_stat.rssi = (s8)undecorated_smoothed_pwdb;
+	for (i = RF_PATH_A; i < PHYDM_MAX_RF_PATH; i++) {
+		rssi_tmp = phy_info->rx_mimo_signal_strength[i];
+		if (rssi_tmp != 0)
+			rssi_linear += phydm_db_2_linear(rssi_tmp);
+	}
+	/* @Rounding and removing fractional bits */
+	rssi_linear = (rssi_linear + (1 << (FRAC_BITS - 1))) >> FRAC_BITS;
 
-		if (is_cck_rate)
-			p_sta->rssi_stat.rssi_cck = (s8)rssi_ave;
-		else
-			p_sta->rssi_stat.rssi_ofdm = (s8)rssi_ave;
+	switch (phy_info->rx_count + 1) {
+	case 2:
+		rssi_linear = DIVIDED_2(rssi_linear);
+		break;
+	case 3:
+		rssi_linear = DIVIDED_3(rssi_linear);
+		break;
+	case 4:
+		rssi_linear = DIVIDED_4(rssi_linear);
+		break;
+	}
 
+	rssi_db = (s16)odm_convert_to_db(rssi_linear);
 
-		p_dm->accumulate_pwdb[p_pktinfo->station_id] = accumulate_pwdb;
+	if (rssi_t->rssi_acc == 0) {
+		rssi_t->rssi_acc = (s16)(rssi_db << RSSI_MA);
+		rssi_t->rssi = (s8)(rssi_db);
+	} else {
+		rssi_t->rssi_acc = MA_ACC(rssi_t->rssi_acc, rssi_db, RSSI_MA);
+		rssi_t->rssi = (s8)GET_MA_VAL(rssi_t->rssi_acc, RSSI_MA);
+	}
 
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-		if (p_pktinfo->station_id == 0) {
-			HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_dm->adapter);
+	#if 0
+	PHYDM_DBG(dm, DBG_TMP, "RSSI[%d]{A,B,C,D}={%d, %d, %d, %d} AVG=%d\n",
+		  pktinfo->station_id,
+		  phy_info->rx_mimo_signal_strength[0],
+		  phy_info->rx_mimo_signal_strength[1],
+		  phy_info->rx_mimo_signal_strength[2],
+		  phy_info->rx_mimo_signal_strength[3], rssi_db);
+	PHYDM_DBG(dm, DBG_TMP, "rssi_acc = %d, rssi=%d\n",
+		  rssi_t->rssi_acc, rssi_t->rssi);
+	#endif
 
-			p_hal_data->UndecoratedSmoothedPWDB = undecorated_smoothed_pwdb;
-		}
-#endif
-	}
+	if (pktinfo->is_cck_rate)
+		rssi_t->rssi_cck = (s8)rssi_db;
+	else
+		rssi_t->rssi_ofdm = (s8)rssi_db;
 }
 
-void
-phydm_rx_phy_status_new_type(
-	void							*p_dm_void,
-	u8							*p_phy_status,
-	struct phydm_perpkt_info_struct		*p_pktinfo,
-	struct phydm_phyinfo_struct	*p_phy_info
-)
+void phydm_rx_physts_2nd_type(void *dm_void, u8 *phy_sts,
+			      struct phydm_perpkt_info_struct *pktinfo,
+			      struct phydm_phyinfo_struct *phy_info)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #ifdef PHYDM_PHYSTAUS_SMP_MODE
-	struct pkt_process_info			*p_pkt_process = &(p_dm->pkt_proc_struct);
+	struct pkt_process_info *pkt_process = &dm->pkt_proc_struct;
 #endif
-	u8		phy_status_type = (*p_phy_status & 0xf);
+	u8 page = (*phy_sts & 0xf);
 
 #ifdef PHYDM_PHYSTAUS_SMP_MODE
-	if (p_pkt_process->phystatus_smp_mode_en && phy_status_type != 0) {
-
-		if (p_pkt_process->pre_ppdu_cnt == p_pktinfo->ppdu_cnt)
+	if (pkt_process->phystatus_smp_mode_en && page != 0) {
+		if (pkt_process->pre_ppdu_cnt == pktinfo->ppdu_cnt)
 			return;
 
-		p_pkt_process->pre_ppdu_cnt = p_pktinfo->ppdu_cnt;
+		pkt_process->pre_ppdu_cnt = pktinfo->ppdu_cnt;
 	}
 #endif
 
-	/*dbg_print("phydm_rx_phy_status_new_type================> (page: %d)\n", phy_status_type);*/
-
-	/* Memory reset */
-	phydm_reset_phy_info(p_dm, p_phy_info);
-	p_dm->rate_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
+	phydm_reset_phy_info(dm, phy_info); /* @Memory reset */
 
 	/* Phy status parsing */
-	switch (phy_status_type) {
-	case 0:	/*CCK*/
-		phydm_get_rx_phy_status_type0(p_dm, p_phy_status, p_pktinfo, p_phy_info);
+	switch (page) {
+	case 0: /*@CCK*/
+		phydm_get_phy_sts_type0(dm, phy_sts, pktinfo, phy_info);
 		break;
 	case 1:
-		phydm_get_rx_phy_status_type1(p_dm, p_phy_status, p_pktinfo, p_phy_info);
+		phydm_get_phy_sts_type1(dm, phy_sts, pktinfo, phy_info);
 		break;
 	case 2:
-		phydm_get_rx_phy_status_type2(p_dm, p_phy_status, p_pktinfo, p_phy_info);
+		phydm_get_phy_sts_type2(dm, phy_sts, pktinfo, phy_info);
 		break;
-#if 0
-	case 5:
-		phydm_get_rx_phy_status_type5(p_phy_status);
-		return;
-#endif
 	default:
-		return;
-	}
-
-	if (p_pktinfo->is_packet_match_bssid) {
-		phydm_avg_phystatus_index(p_dm, p_phy_info, p_pktinfo);
-		phydm_rx_statistic_cal(p_dm, p_phy_status, p_pktinfo);
+		break;
 	}
 
-	/* Update signal strength to UI, and p_phy_info->rx_pwdb_all is the maximum RSSI of all path */
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	p_phy_info->signal_strength = SignalScaleProc(p_dm->adapter, p_phy_info->rx_pwdb_all, false, false);
-#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	p_phy_info->signal_strength = (u8)(phydm_signal_scale_mapping(p_dm, p_phy_info->rx_pwdb_all));
+#if (RTL8822B_SUPPORT || RTL8821C_SUPPORT || RTL8195B_SUPPORT)
+	if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8195B))
+		phydm_print_phy_sts_jgr2(dm, phy_sts, pktinfo, phy_info);
 #endif
-
-
-
 }
-/*==============================================*/
+
+/*@==============================================*/
 #endif
 
-void
-odm_phy_status_query(
-	struct PHY_DM_STRUCT		*p_dm,
-	struct phydm_phyinfo_struct	*p_phy_info,
-	u8							*p_phy_status,
-	struct phydm_perpkt_info_struct		*p_pktinfo
-)
+void odm_phy_status_query(struct dm_struct *dm,
+			  struct phydm_phyinfo_struct *phy_info,
+			  u8 *phy_status_inf,
+			  struct phydm_perpkt_info_struct *pktinfo)
 {
+	u8 rate = pktinfo->data_rate;
 
-	if (p_dm->support_ic_type & ODM_IC_PHY_STATUE_NEW_TYPE) {
-		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
-		phydm_rx_phy_status_new_type(p_dm, p_phy_status, p_pktinfo, p_phy_info);
-		phydm_process_rssi_for_dm_new_type(p_dm, p_phy_info, p_pktinfo);
+	pktinfo->is_cck_rate = (rate <= ODM_RATE11M) ? true : false;
+	pktinfo->rate_ss = phydm_rate_to_num_ss(dm, rate);
+	dm->rate_ss = pktinfo->rate_ss; /*@For AP EVM SW antenna diversity use*/
+
+	if (pktinfo->is_cck_rate)
+		dm->phy_dbg_info.num_qry_phy_status_cck++;
+	else
+		dm->phy_dbg_info.num_qry_phy_status_ofdm++;
+
+	/*Reset phy_info*/
+	odm_memory_set(dm, phy_info->rx_mimo_signal_strength, 0, 4);
+	odm_memory_set(dm, phy_info->rx_mimo_signal_quality, 0, 4);
+	if (dm->support_ic_type & PHYSTS_3RD_TYPE_IC) {
+		#ifdef PHYSTS_3RD_TYPE_SUPPORT
+		phydm_rx_physts_3rd_type(dm, phy_status_inf, pktinfo, phy_info);
+		phydm_process_dm_rssi_3rd_type(dm, phy_info, pktinfo);
 		#endif
-	} else if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		#if	ODM_IC_11AC_SERIES_SUPPORT
-		phydm_rx_phy_status_jaguar_series_parsing(p_dm, p_phy_info, p_phy_status, p_pktinfo);
-		phydm_process_rssi_for_dm(p_dm, p_phy_info, p_pktinfo);
+	} else if (dm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
+		#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT)
+		phydm_rx_physts_2nd_type(dm, phy_status_inf, pktinfo, phy_info);
+		phydm_process_rssi_for_dm_2nd_type(dm, phy_info, pktinfo);
 		#endif
-	} else if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-		#if	ODM_IC_11N_SERIES_SUPPORT
-		phydm_rx_phy_status92c_series_parsing(p_dm, p_phy_info, p_phy_status, p_pktinfo);
-		phydm_process_rssi_for_dm(p_dm, p_phy_info, p_pktinfo);
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		#if ODM_IC_11AC_SERIES_SUPPORT
+		phydm_rx_physts_1st_type(dm, phy_info, phy_status_inf, pktinfo);
+		phydm_process_rssi_for_dm(dm, phy_info, pktinfo);
 		#endif
+	} else if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		#if ODM_IC_11N_SERIES_SUPPORT
+		phydm_phy_sts_n_parsing(dm, phy_info, phy_status_inf, pktinfo);
+		phydm_process_rssi_for_dm(dm, phy_info, pktinfo);
+		#endif
+	}
+	phy_info->signal_strength = phy_info->rx_pwdb_all;
+	#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
+	phydm_process_signal_strength(dm, phy_info, pktinfo);
+	#endif
+
+	if (pktinfo->is_packet_match_bssid) {
+		dm->curr_station_id = pktinfo->station_id;
+		dm->rx_rate = rate;
+		dm->rssi_a = phy_info->rx_mimo_signal_strength[RF_PATH_A];
+		dm->rssi_b = phy_info->rx_mimo_signal_strength[RF_PATH_B];
+		dm->rssi_c = phy_info->rx_mimo_signal_strength[RF_PATH_C];
+		dm->rssi_d = phy_info->rx_mimo_signal_strength[RF_PATH_D];
+
+		if (rate >= ODM_RATE6M && rate <= ODM_RATE54M)
+			dm->rxsc_l = (s8)phy_info->rxsc;
+		else if (phy_info->band_width == CHANNEL_WIDTH_20)
+			dm->rxsc_20 = (s8)phy_info->rxsc;
+		else if (phy_info->band_width == CHANNEL_WIDTH_40)
+			dm->rxsc_40 = (s8)phy_info->rxsc;
+		else if (phy_info->band_width == CHANNEL_WIDTH_80)
+			dm->rxsc_80 = (s8)phy_info->rxsc;
+
+		phydm_avg_phystatus_index(dm, phy_info, pktinfo);
+		phydm_rx_statistic_cal(dm, phy_info, phy_status_inf, pktinfo);
 	}
 }
 
-void
-phydm_rx_phy_status_init(
-	void			*p_dm_void
-)
+void phydm_rx_phy_status_init(void *dm_void)
 {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct odm_phy_dbg_info *dbg = &dm->phy_dbg_info;
 #ifdef PHYDM_PHYSTAUS_SMP_MODE
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct pkt_process_info			*p_pkt_process = &(p_dm->pkt_proc_struct);
-
-	if (p_dm->support_ic_type == ODM_RTL8822B) {
-
-		p_pkt_process->phystatus_smp_mode_en = 1;
-		p_pkt_process->pre_ppdu_cnt = 0xff;
-
-		odm_set_mac_reg(p_dm, 0x60f, BIT(7), 1); /*phystatus sampling mode enable*/
-
-		odm_set_bb_reg(p_dm, 0x9e4, 0x3ff, 0x0); /*First update timming*/
-		odm_set_bb_reg(p_dm, 0x9e4, 0xfc00, 0x0); /*Update Sampling time*/
+	struct pkt_process_info *pkt_process = &dm->pkt_proc_struct;
+
+	if (dm->support_ic_type & ODM_RTL8822B) {
+		pkt_process->phystatus_smp_mode_en = 1;
+		pkt_process->pre_ppdu_cnt = 0xff;
+		/*phystatus sampling mode enable*/
+		odm_set_mac_reg(dm, R_0x60f, BIT(7), 1);
+		/*@First update timming*/
+		odm_set_bb_reg(dm, R_0x9e4, 0x3ff, 0x0);
+		/*Update Sampling time*/
+		odm_set_bb_reg(dm, R_0x9e4, 0xfc00, 0x0);
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		/*@First update timming*/
+		odm_set_bb_reg(dm, R_0x8c0, 0x3ff0, 0x0);
+		/*Update Sampling time*/
+		odm_set_bb_reg(dm, R_0x8c0, 0xfc000, 0x0);
 	}
 #endif
+
+	dbg->show_phy_sts_all_pkt = 0;
+	dbg->show_phy_sts_max_cnt = 1;
+	dbg->show_phy_sts_cnt = 0;
+
+	phydm_avg_phystatus_init(dm);
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.h
index ce8f6c5eed80..0bcc3007e954 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_phystatus.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,45 +9,70 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDM_PHYSTATUS_H__
+#define __PHYDM_PHYSTATUS_H__
 
-#ifndef	__PHYDM_PHYSTATUS_H__
-#define	__PHYDM_PHYSTATUS_H__
+/*@--------------------------Define ------------------------------------------*/
+#define CCK_RSSI_INIT_COUNT 5
 
+#define RA_RSSI_STATE_INIT 0
+#define RA_RSSI_STATE_SEND 1
+#define RA_RSSI_STATE_HOLD 2
+
+#if defined(DM_ODM_CE_MAC80211)
+#define CFO_HW_RPT_2_KHZ(val) ({		\
+	s32 cfo_hw_rpt_2_khz_tmp = (val);	\
+	(cfo_hw_rpt_2_khz_tmp << 1) + (cfo_hw_rpt_2_khz_tmp >> 1);	\
+	})
+#else
+#define CFO_HW_RPT_2_KHZ(val) ((val << 1) + (val >> 1))
+#endif
 
-/*--------------------------Define -------------------------------------------*/
-#define	CCK_RSSI_INIT_COUNT 5
+/* @(X* 312.5 Khz)>>7 ~=  X*2.5 Khz= (X<<1 + X>>1)Khz  */
 
-#define	RA_RSSI_STATE_INIT	0
-#define	RA_RSSI_STATE_SEND	1
-#define	RA_RSSI_STATE_HOLD	2
+#define IGI_2_RSSI(igi) (igi - 10)
 
-#define	CFO_HW_RPT_2_MHZ(val) ((val<<1) + (val>>1))
-/* ((X* 3125)  / 10)>>7 = (X*10)>>2 = X*2.5 = X<<1 + X>>1  */
+#define PHY_STATUS_JRGUAR2_DW_LEN 7 /* @7*4 = 28 Byte */
+#define PHY_STATUS_JRGUAR3_DW_LEN 7 /* @7*4 = 28 Byte */
+#define SHOW_PHY_STATUS_UNLIMITED 0
+#define RSSI_MA 4 /*moving average factor for RSSI: 2^4=16 */
 
-/* ************************************************************
+#define PHYSTS_PATH_NUM 4
+
+/*@************************************************************
  * structure and define
- * ************************************************************ */
+ ************************************************************/
 
-__PACK struct _phy_rx_agc_info {
+__PACK struct phy_rx_agc_info {
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8	gain: 7, trsw: 1;
+	u8 gain : 7, trsw : 1;
 #else
-	u8	trsw: 1, gain: 7;
+	u8 trsw : 1, gain : 7;
 #endif
 };
 
-__PACK struct _phy_status_rpt_8192cd {
-	struct _phy_rx_agc_info path_agc[2];
+__PACK struct phy_status_rpt_8192cd {
+	struct phy_rx_agc_info path_agc[2];
 	u8	ch_corr[2];
 	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	rsvd_1;/*@ch_corr_msb;*/
 	u8	noise_power_db_msb;
 	s8	path_cfotail[2];
 	u8	pcts_mask[2];
@@ -60,610 +86,655 @@ __PACK struct _phy_status_rpt_8192cd {
 	u8	rsvd_3;
 
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8	antsel_rx_keep_2: 1;	/*ex_intf_flg:1;*/
+	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_	*/
+#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;*/
+	u8	antsel_rx_keep_2: 1;/*@ex_intf_flg:1;*/
 #endif
 };
 
-struct _phy_status_rpt_8812 {
-	/*	DWORD 0*/
-	u8			gain_trsw[2];							/*path-A and path-B {TRSW, gain[6:0] }*/
-	u8			chl_num_LSB;							/*channel number[7:0]*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8			chl_num_MSB: 2;							/*channel number[9:8]*/
-	u8			sub_chnl: 4;								/*sub-channel location[3:0]*/
-	u8			r_RFMOD: 2;								/*RF mode[1:0]*/
-#else	/*_BIG_ENDIAN_	*/
-	u8			r_RFMOD: 2;
-	u8			sub_chnl: 4;
-	u8			chl_num_MSB: 2;
-#endif
-
-	/*	DWORD 1*/
-	u8			pwdb_all;								/*CCK signal quality / OFDM pwdb all*/
-	s8			cfosho[2];		/*DW1 byte 1 DW1 byte2	CCK AGC report and CCK_BB_Power / OFDM path-A and path-B short CFO*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	/*this should be checked again because the definition of 8812 and 8814 is different*/
-	/*	u8			r_cck_rx_enable_pathc:2;					cck rx enable pathc[1:0]*/
-	/*	u8			cck_rx_path:4;							cck rx path[3:0]*/
-	u8			resvd_0: 6;
-	u8			bt_RF_ch_MSB: 2;						/*8812A:2'b0			8814A: bt rf channel keep[7:6]*/
-#else	/*_BIG_ENDIAN_*/
-	u8			bt_RF_ch_MSB: 2;
-	u8			resvd_0: 6;
-#endif
-
-	/*	DWORD 2*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8			ant_div_sw_a: 1;							/*8812A: ant_div_sw_a    8814A: 1'b0*/
-	u8			ant_div_sw_b: 1;							/*8812A: ant_div_sw_b    8814A: 1'b0*/
-	u8			bt_RF_ch_LSB: 6;						/*8812A: 6'b0                   8814A: bt rf channel keep[5:0]*/
-#else	/*_BIG_ENDIAN_	*/
-	u8			bt_RF_ch_LSB: 6;
-	u8			ant_div_sw_b: 1;
-	u8			ant_div_sw_a: 1;
-#endif
-	s8			cfotail[2];		   /*DW2 byte 1 DW2 byte 2	path-A and path-B CFO tail*/
-	u8			PCTS_MSK_RPT_0;						/*PCTS mask report[7:0]*/
-	u8			PCTS_MSK_RPT_1;						/*PCTS mask report[15:8]*/
-
-	/*	DWORD 3*/
-	s8			rxevm[2];	         /*DW3 byte 1 DW3 byte 2	stream 1 and stream 2 RX EVM*/
-	s8			rxsnr[2];	         /*DW3 byte 3 DW4 byte 0	path-A and path-B RX SNR*/
-
-	/*	DWORD 4*/
-	u8			PCTS_MSK_RPT_2;						/*PCTS mask report[23:16]*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8			PCTS_MSK_RPT_3: 6;						/*PCTS mask report[29:24]*/
-	u8			pcts_rpt_valid: 1;							/*pcts_rpt_valid*/
-	u8			resvd_1: 1;								/*1'b0*/
-#else	/*_BIG_ENDIAN_*/
-	u8			resvd_1: 1;
-	u8			pcts_rpt_valid: 1;
-	u8			PCTS_MSK_RPT_3: 6;
-#endif
-	s8			rxevm_cd[2];	   /*DW 4 byte 3 DW5 byte 0  8812A: 16'b0	8814A: stream 3 and stream 4 RX EVM*/
-
-	/*	DWORD 5*/
-	u8			csi_current[2];	   /*DW5 byte 1 DW5 byte 2	8812A: stream 1 and 2 CSI	8814A:  path-C and path-D RX SNR*/
-	u8			gain_trsw_cd[2];	   /*DW5 byte 3 DW6 byte 0	path-C and path-D {TRSW, gain[6:0] }*/
-
-	/*	DWORD 6*/
-	s8			sigevm;									/*signal field EVM*/
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8			antidx_antc: 3;							/*8812A: 3'b0		8814A: antidx_antc[2:0]*/
-	u8			antidx_antd: 3;							/*8812A: 3'b0		8814A: antidx_antd[2:0]*/
-	u8			dpdt_ctrl_keep: 1;						/*8812A: 1'b0		8814A: dpdt_ctrl_keep*/
-	u8			GNT_BT_keep: 1;							/*8812A: 1'b0		8814A: GNT_BT_keep*/
-#else	/*_BIG_ENDIAN_*/
-	u8			GNT_BT_keep: 1;
-	u8			dpdt_ctrl_keep: 1;
-	u8			antidx_antd: 3;
-	u8			antidx_antc: 3;
-#endif
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8			antidx_anta: 3;							/*antidx_anta[2:0]*/
-	u8			antidx_antb: 3;							/*antidx_antb[2:0]*/
-	u8			hw_antsw_occur: 2;								/*1'b0*/
-#else	/*_BIG_ENDIAN_*/
-	u8			hw_antsw_occur: 2;
-	u8			antidx_antb: 3;
-	u8			antidx_anta: 3;
+struct phy_status_rpt_8812 {
+	/*	@DWORD 0*/
+	u8 gain_trsw[2]; /*path-A and path-B {TRSW, gain[6:0] }*/
+	u8 chl_num_LSB; /*@channel number[7:0]*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 chl_num_MSB : 2; /*@channel number[9:8]*/
+	u8 sub_chnl : 4; /*sub-channel location[3:0]*/
+	u8 r_RFMOD : 2; /*RF mode[1:0]*/
+#else /*@_BIG_ENDIAN_	*/
+	u8 r_RFMOD : 2;
+	u8 sub_chnl : 4;
+	u8 chl_num_MSB : 2;
 #endif
-};
 
+	/*	@DWORD 1*/
+	u8 pwdb_all; /*@CCK signal quality / OFDM pwdb all*/
+	s8 cfosho[2]; /*@CCK AGC report and CCK_BB_Power*/
+		      /*OFDM path-A and path-B short CFO*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 resvd_0 : 6;
+	u8 bt_RF_ch_MSB : 2; /*@8812A:2'b0  8814A: bt rf channel keep[7:6]*/
+#else /*@_BIG_ENDIAN_*/
+	u8 bt_RF_ch_MSB : 2;
+	u8 resvd_0 : 6;
+#endif
+
+/*	@DWORD 2*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 ant_div_sw_a : 1; /*@8812A: ant_div_sw_a    8814A: 1'b0*/
+	u8 ant_div_sw_b : 1; /*@8812A: ant_div_sw_b    8814A: 1'b0*/
+	u8 bt_RF_ch_LSB : 6; /*@8812A: 6'b0     8814A: bt rf channel keep[5:0]*/
+#else /*@_BIG_ENDIAN_	*/
+	u8 bt_RF_ch_LSB : 6;
+	u8 ant_div_sw_b : 1;
+	u8 ant_div_sw_a : 1;
+#endif
+	s8 cfotail[2]; /*@DW2 byte 1 DW2 byte 2	path-A and path-B CFO tail*/
+	u8 PCTS_MSK_RPT_0; /*PCTS mask report[7:0]*/
+	u8 PCTS_MSK_RPT_1; /*PCTS mask report[15:8]*/
+
+	/*	@DWORD 3*/
+	s8 rxevm[2]; /*@DW3 byte 1 DW3 byte 2	stream 1 and stream 2 RX EVM*/
+	s8 rxsnr[2]; /*@DW3 byte 3 DW4 byte 0	path-A and path-B RX SNR*/
+
+	/*	@DWORD 4*/
+	u8 PCTS_MSK_RPT_2; /*PCTS mask report[23:16]*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 PCTS_MSK_RPT_3 : 6; /*PCTS mask report[29:24]*/
+	u8 pcts_rpt_valid : 1; /*pcts_rpt_valid*/
+	u8 resvd_1 : 1; /*@1'b0*/
+#else /*@_BIG_ENDIAN_*/
+	u8 resvd_1 : 1;
+	u8 pcts_rpt_valid : 1;
+	u8 PCTS_MSK_RPT_3 : 6;
+#endif
+	s8 rxevm_cd[2]; /*@8812A: 16'b0*/
+			/*@8814A: stream 3 and stream 4 RX EVM*/
+	/*	@DWORD 5*/
+	u8 csi_current[2]; /*@8812A: stream 1 and 2 CSI*/
+			   /*@8814A:  path-C and path-D RX SNR*/
+	u8 gain_trsw_cd[2]; /*path-C and path-D {TRSW, gain[6:0] }*/
+
+	/*	@DWORD 6*/
+	s8 sigevm; /*signal field EVM*/
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_antc : 3;	/*@8812A: 3'b0	8814A: antidx_antc[2:0]*/
+	u8 antidx_antd : 3;	/*@8812A: 3'b0	8814A: antidx_antd[2:0]*/
+	u8 dpdt_ctrl_keep : 1;	/*@8812A: 1'b0	8814A: dpdt_ctrl_keep*/
+	u8 GNT_BT_keep : 1;	/*@8812A: 1'b0	8814A: GNT_BT_keep*/
+#else /*@_BIG_ENDIAN_*/
+	u8 GNT_BT_keep : 1;
+	u8 dpdt_ctrl_keep : 1;
+	u8 antidx_antd : 3;
+	u8 antidx_antc : 3;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_anta : 3; /*@antidx_anta[2:0]*/
+	u8 antidx_antb : 3; /*@antidx_antb[2:0]*/
+	u8 hw_antsw_occur : 2; /*@1'b0*/
+#else /*@_BIG_ENDIAN_*/
+	u8 hw_antsw_occur : 2;
+	u8 antidx_antb : 3;
+	u8 antidx_anta : 3;
+#endif
+};
 
 #if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
 
-__PACK struct _phy_status_rpt_jaguar2_type0 {
-	/* DW0 */
-	u8		page_num;
-	u8		pwdb;
+__PACK struct phy_sts_rpt_jgr2_type0 {
+	/* @DW0 */
+	u8 page_num;
+	u8 pwdb;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		gain: 6;
-	u8		rsvd_0: 1;
-	u8		trsw: 1;
+	u8 gain : 6;
+	u8 rsvd_0 : 1;
+	u8 trsw : 1;
 #else
-	u8		trsw: 1;
-	u8		rsvd_0: 1;
-	u8		gain: 6;
+	u8 trsw : 1;
+	u8 rsvd_0 : 1;
+	u8 gain : 6;
 #endif
-	u8		rsvd_1;
+	u8 rsvd_1;
 
-	/* DW1 */
-	u8		rsvd_2;
+	/* @DW1 */
+	u8 rsvd_2;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		rxsc: 4;
-	u8		agc_table: 4;
+	u8 rxsc : 4;
+	u8 agc_table : 4;
 #else
-	u8		agc_table: 4;
-	u8		rxsc: 4;
+	u8 agc_table : 4;
+	u8 rxsc : 4;
 #endif
-	u8		channel;
-	u8		band;
+	u8 channel;
+	u8 band;
 
-	/* DW2 */
-	u16		length;
+	/* @DW2 */
+	u16 length;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		antidx_a: 3;
-	u8		antidx_b: 3;
-	u8		rsvd_3: 2;
-	u8		antidx_c: 3;
-	u8		antidx_d: 3;
-	u8		rsvd_4:2;
+	u8 antidx_a : 3;
+	u8 antidx_b : 3;
+	u8 rsvd_3 : 2;
+	u8 antidx_c : 3;
+	u8 antidx_d : 3;
+	u8 rsvd_4 : 2;
 #else
-	u8		rsvd_3: 2;
-	u8		antidx_b: 3;
-	u8		antidx_a: 3;
-	u8		rsvd_4:2;
-	u8		antidx_d: 3;
-	u8		antidx_c: 3;
+	u8 rsvd_3 : 2;
+	u8 antidx_b : 3;
+	u8 antidx_a : 3;
+	u8 rsvd_4 : 2;
+	u8 antidx_d : 3;
+	u8 antidx_c : 3;
 #endif
 
-	/* DW3 */
-	u8		signal_quality;
+	/* @DW3 */
+	u8 signal_quality;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		vga:5;
-	u8		lna_l:3;
-	u8		bb_power:6;
-	u8		rsvd_9:1;
-	u8		lna_h:1;
+	u8 vga : 5;
+	u8 lna_l : 3;
+	u8 bb_power : 6;
+	u8 rsvd_9 : 1;
+	u8 lna_h : 1;
 #else
-	u8		lna_l:3;
-	u8		vga:5;
-	u8		lna_h:1;
-	u8		rsvd_9:1;
-	u8		bb_power:6;
+	u8 lna_l : 3;
+	u8 vga : 5;
+	u8 lna_h : 1;
+	u8 rsvd_9 : 1;
+	u8 bb_power : 6;
 #endif
-	u8		rsvd_5;
+	u8 rsvd_5;
 
-	/* DW4 */
-	u32		rsvd_6;
+	/* @DW4 */
+	u32 rsvd_6;
 
-	/* DW5 */
-	u32		rsvd_7;
+	/* @DW5 */
+	u32 rsvd_7;
 
-	/* DW6 */
-	u32		rsvd_8;
+	/* @DW6 */
+	u32 rsvd_8;
 };
 
-__PACK struct _phy_status_rpt_jaguar2_type1 {
-	/* DW0 and DW1 */
-	u8		page_num;
-	u8		pwdb[4];
+__PACK struct phy_sts_rpt_jgr2_type1 {
+	/* @DW0 and DW1 */
+	u8 page_num;
+	u8 pwdb[4];
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		l_rxsc: 4;
-	u8		ht_rxsc: 4;
+	u8 l_rxsc : 4;
+	u8 ht_rxsc : 4;
 #else
-	u8		ht_rxsc: 4;
-	u8		l_rxsc: 4;
+	u8 ht_rxsc : 4;
+	u8 l_rxsc : 4;
 #endif
-	u8		channel;
+	u8 channel;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		band: 2;
-	u8		rsvd_0: 1;
-	u8		hw_antsw_occu: 1;
-	u8		gnt_bt: 1;
-	u8		ldpc: 1;
-	u8		stbc: 1;
-	u8		beamformed: 1;
+	u8 band : 2;
+	u8 rsvd_0 : 1;
+	u8 hw_antsw_occu : 1;
+	u8 gnt_bt : 1;
+	u8 ldpc : 1;
+	u8 stbc : 1;
+	u8 beamformed : 1;
 #else
-	u8		beamformed: 1;
-	u8		stbc: 1;
-	u8		ldpc: 1;
-	u8		gnt_bt: 1;
-	u8		hw_antsw_occu: 1;
-	u8		rsvd_0: 1;
-	u8		band: 2;
+	u8 beamformed : 1;
+	u8 stbc : 1;
+	u8 ldpc : 1;
+	u8 gnt_bt : 1;
+	u8 hw_antsw_occu : 1;
+	u8 rsvd_0 : 1;
+	u8 band : 2;
 #endif
 
-	/* DW2 */
-	u16		lsig_length;
+	/* @DW2 */
+	u16 lsig_length;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		antidx_a: 3;
-	u8		antidx_b: 3;
-	u8		rsvd_1: 2;
-	u8		antidx_c: 3;
-	u8		antidx_d: 3;
-	u8		rsvd_2: 2;
+	u8 antidx_a : 3;
+	u8 antidx_b : 3;
+	u8 rsvd_1 : 2;
+	u8 antidx_c : 3;
+	u8 antidx_d : 3;
+	u8 rsvd_2 : 2;
 #else
-	u8		rsvd_1: 2;
-	u8		antidx_b: 3;
-	u8		antidx_a: 3;
-	u8		rsvd_2: 2;
-	u8		antidx_d: 3;
-	u8		antidx_c: 3;
+	u8 rsvd_1 : 2;
+	u8 antidx_b : 3;
+	u8 antidx_a : 3;
+	u8 rsvd_2 : 2;
+	u8 antidx_d : 3;
+	u8 antidx_c : 3;
 #endif
 
-	/* DW3 */
-	u8		paid;
+	/* @DW3 */
+	u8 paid;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		paid_msb: 1;
-	u8		gid: 6;
-	u8		rsvd_3: 1;
+	u8 paid_msb : 1;
+	u8 gid : 6;
+	u8 rsvd_3 : 1;
 #else
-	u8		rsvd_3: 1;
-	u8		gid: 6;
-	u8		paid_msb: 1;
+	u8 rsvd_3 : 1;
+	u8 gid : 6;
+	u8 paid_msb : 1;
 #endif
-	u8		intf_pos;
+	u8 intf_pos;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		intf_pos_msb: 1;
-	u8		rsvd_4: 2;
-	u8		nb_intf_flag: 1;
-	u8		rf_mode: 2;
-	u8		rsvd_5: 2;
+	u8 intf_pos_msb : 1;
+	u8 rsvd_4 : 2;
+	u8 nb_intf_flag : 1;
+	u8 rf_mode : 2;
+	u8 rsvd_5 : 2;
 #else
-	u8		rsvd_5: 2;
-	u8		rf_mode: 2;
-	u8		nb_intf_flag: 1;
-	u8		rsvd_4: 2;
-	u8		intf_pos_msb: 1;
+	u8 rsvd_5 : 2;
+	u8 rf_mode : 2;
+	u8 nb_intf_flag : 1;
+	u8 rsvd_4 : 2;
+	u8 intf_pos_msb : 1;
 #endif
 
-	/* DW4 */
-	s8		rxevm[4];			/* s(8,1) */
+	/* @DW4 */
+	s8 rxevm[4]; /* s(8,1) */
 
-	/* DW5 */
-	s8		cfo_tail[4];			/* s(8,7) */
+	/* @DW5 */
+	s8 cfo_tail[4]; /* s(8,7) */
 
-	/* DW6 */
-	s8		rxsnr[4];			/* s(8,1) */
+	/* @DW6 */
+	s8 rxsnr[4]; /* s(8,1) */
 };
 
-__PACK struct _phy_status_rpt_jaguar2_type2 {
-	/* DW0 ane DW1 */
-	u8		page_num;
-	u8		pwdb[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		l_rxsc: 4;
-	u8		ht_rxsc: 4;
-#else
-	u8		ht_rxsc: 4;
-	u8		l_rxsc: 4;
-#endif
-	u8		channel;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		band: 2;
-	u8		rsvd_0: 1;
-	u8		hw_antsw_occu: 1;
-	u8		gnt_bt: 1;
-	u8		ldpc: 1;
-	u8		stbc: 1;
-	u8		beamformed: 1;
-#else
-	u8		beamformed: 1;
-	u8		stbc: 1;
-	u8		ldpc: 1;
-	u8		gnt_bt: 1;
-	u8		hw_antsw_occu: 1;
-	u8		rsvd_0: 1;
-	u8		band: 2;
-#endif
-
-	/* DW2 */
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		shift_l_map: 6;
-	u8		rsvd_1: 2;
-#else
-	u8		rsvd_1: 2;
-	u8		shift_l_map: 6;
-#endif
-	u8		cnt_pw2cca;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		agc_table_a: 4;
-	u8		agc_table_b: 4;
-	u8		agc_table_c: 4;
-	u8		agc_table_d: 4;
-#else
-	u8		agc_table_b: 4;
-	u8		agc_table_a: 4;
-	u8		agc_table_d: 4;
-	u8		agc_table_c: 4;
-#endif
-
-	/* DW3 ~ DW6*/
-	u8		cnt_cca2agc_rdy;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		gain_a: 6;
-	u8		rsvd_2: 1;
-	u8		trsw_a: 1;
-	u8		gain_b: 6;
-	u8		rsvd_3: 1;
-	u8		trsw_b: 1;
-	u8		gain_c: 6;
-	u8		rsvd_4: 1;
-	u8		trsw_c: 1;
-	u8		gain_d: 6;
-	u8		rsvd_5: 1;
-	u8		trsw_d: 1;
-	u8		aagc_step_a: 2;
-	u8		aagc_step_b: 2;
-	u8		aagc_step_c: 2;
-	u8		aagc_step_d: 2;
-#else
-	u8		trsw_a: 1;
-	u8		rsvd_2: 1;
-	u8		gain_a: 6;
-	u8		trsw_b: 1;
-	u8		rsvd_3: 1;
-	u8		gain_b: 6;
-	u8		trsw_c: 1;
-	u8		rsvd_4: 1;
-	u8		gain_c: 6;
-	u8		trsw_d: 1;
-	u8		rsvd_5: 1;
-	u8		gain_d: 6;
-	u8		aagc_step_d: 2;
-	u8		aagc_step_c: 2;
-	u8		aagc_step_b: 2;
-	u8		aagc_step_a: 2;
-#endif
-	u8		ht_aagc_gain[4];
-	u8		dagc_gain[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		counter: 6;
-	u8		rsvd_6: 2;
-	u8		syn_count: 5;
-	u8		rsvd_7:3;
-#else
-	u8		rsvd_6: 2;
-	u8		counter: 6;
-	u8		rsvd_7:3;
-	u8		syn_count: 5;
+__PACK struct phy_sts_rpt_jgr2_type2 {
+	/* @DW0 ane DW1 */
+	u8 page_num;
+	u8 pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 l_rxsc : 4;
+	u8 ht_rxsc : 4;
+#else
+	u8 ht_rxsc : 4;
+	u8 l_rxsc : 4;
+#endif
+	u8 channel;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 band : 2;
+	u8 rsvd_0 : 1;
+	u8 hw_antsw_occu : 1;
+	u8 gnt_bt : 1;
+	u8 ldpc : 1;
+	u8 stbc : 1;
+	u8 beamformed : 1;
+#else
+	u8 beamformed : 1;
+	u8 stbc : 1;
+	u8 ldpc : 1;
+	u8 gnt_bt : 1;
+	u8 hw_antsw_occu : 1;
+	u8 rsvd_0 : 1;
+	u8 band : 2;
+#endif
+
+/* @DW2 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 shift_l_map : 6;
+	u8 rsvd_1 : 2;
+#else
+	u8 rsvd_1 : 2;
+	u8 shift_l_map : 6;
+#endif
+	u8 cnt_pw2cca;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 agc_table_a : 4;
+	u8 agc_table_b : 4;
+	u8 agc_table_c : 4;
+	u8 agc_table_d : 4;
+#else
+	u8 agc_table_b : 4;
+	u8 agc_table_a : 4;
+	u8 agc_table_d : 4;
+	u8 agc_table_c : 4;
+#endif
+
+	/* @DW3 ~ DW6*/
+	u8 cnt_cca2agc_rdy;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 gain_a : 6;
+	u8 rsvd_2 : 1;
+	u8 trsw_a : 1;
+	u8 gain_b : 6;
+	u8 rsvd_3 : 1;
+	u8 trsw_b : 1;
+	u8 gain_c : 6;
+	u8 rsvd_4 : 1;
+	u8 trsw_c : 1;
+	u8 gain_d : 6;
+	u8 rsvd_5 : 1;
+	u8 trsw_d : 1;
+	u8 aagc_step_a : 2;
+	u8 aagc_step_b : 2;
+	u8 aagc_step_c : 2;
+	u8 aagc_step_d : 2;
+#else
+	u8 trsw_a : 1;
+	u8 rsvd_2 : 1;
+	u8 gain_a : 6;
+	u8 trsw_b : 1;
+	u8 rsvd_3 : 1;
+	u8 gain_b : 6;
+	u8 trsw_c : 1;
+	u8 rsvd_4 : 1;
+	u8 gain_c : 6;
+	u8 trsw_d : 1;
+	u8 rsvd_5 : 1;
+	u8 gain_d : 6;
+	u8 aagc_step_d : 2;
+	u8 aagc_step_c : 2;
+	u8 aagc_step_b : 2;
+	u8 aagc_step_a : 2;
+#endif
+	u8 ht_aagc_gain[4];
+	u8 dagc_gain[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 counter : 6;
+	u8 rsvd_6 : 2;
+	u8 syn_count : 5;
+	u8 rsvd_7 : 3;
+#else
+	u8 rsvd_6 : 2;
+	u8 counter : 6;
+	u8 rsvd_7 : 3;
+	u8 syn_count : 5;
 #endif
 };
-/*==============================================*/
-#elif (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 2)
-__PACK struct _phy_status_rpt_jaguar2_type0 {
-	/* DW0 : Offset 0 */
+#endif
+
+/*@==============================================*/
+#ifdef PHYSTS_3RD_TYPE_SUPPORT
+__PACK struct phy_sts_rpt_jgr3_type0 {
+/* @DW0 : Offset 0 */
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		page_num:4;
-	u8		pkt_cnt:2;
-	u8		channel_msb:2;
+	u8 page_num : 4;
+	u8 pkt_cnt : 2;
+	u8 channel_msb : 2;
 #else
-	u8		channel_msb:2;
-	u8		pkt_cnt:2;
-	u8		page_num:4;
+	u8 channel_msb : 2;
+	u8 pkt_cnt : 2;
+	u8 page_num : 4;
 #endif
-	u8		pwdb_a;
+	u8 pwdb_a;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		gain_a: 6;
-	u8		rsvd_0: 1;
-	u8		trsw: 1;
+	u8 gain_a : 6;
+	u8 rsvd_0 : 1;
+	u8 trsw : 1;
 #else
-	u8		trsw: 1;
-	u8		rsvd_0: 1;
-	u8		gain_a: 6;
+	u8 trsw : 1;
+	u8 rsvd_0 : 1;
+	u8 gain_a : 6;
 #endif
 
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		agc_table_b:4;
-	u8		agc_table_c:4;
+	u8 agc_table_b : 4;
+	u8 agc_table_c : 4;
 #else
-	u8		agc_table_c:4;
-	u8		agc_table_b:4;
+	u8 agc_table_c : 4;
+	u8 agc_table_b : 4;
 #endif
 
-	/* DW1 : Offset 4 */
+/* @DW1 : Offset 4 */
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		rsvd_1: 4;
-	u8		agc_table_d: 4;
+	u8 rsvd_1 : 4;
+	u8 agc_table_d : 4;
 #else
-	u8		agc_table_d: 4;
-	u8		rsvd_1: 4;
+	u8 agc_table_d : 4;
+	u8 rsvd_1 : 4;
 #endif
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		l_rxsc: 4;
-	u8		agc_table_a: 4;
+	u8 l_rxsc : 4;
+	u8 agc_table_a : 4;
 #else
-	u8		agc_table_a: 4;
-	u8		l_rxsc: 4;
+	u8 agc_table_a : 4;
+	u8 l_rxsc : 4;
 #endif
-	u8		channel;
+	u8 channel;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		band:2;
-	u8		rsvd_2_1: 1;
-	u8		hw_antsw_occur_keep_cck:1;
-	u8		gnt_bt_keep_cck:1;
-	u8		rsvd_2_2:3;
+	u8 band : 2;
+	u8 rsvd_2_1 : 1;
+	u8 hw_antsw_occur_keep_cck : 1;
+	u8 gnt_bt_keep_cck : 1;
+	u8 rsvd_2_2 : 1;
+	u8 path_sel_o : 2;
 #else
-	u8		rsvd_2_2:3;
-	u8		gnt_bt_keep_cck:1;
-	u8		hw_antsw_occur_keep_cck:1;
-	u8		rsvd_2_1: 1;
-	u8		band:2;
+	u8 path_sel_o : 2;
+	u8 rsvd_2_2 : 1;
+	u8 gnt_bt_keep_cck : 1;
+	u8 hw_antsw_occur_keep_cck : 1;
+	u8 rsvd_2_1 : 1;
+	u8 band : 2;
 #endif
 
-	/* DW2 : Offset 8 */
-	u16		length;
+	/* @DW2 : Offset 8 */
+	u16 length;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_a : 4;
+	u8 antidx_b : 4;
+#else
+	u8 antidx_b : 4;
+	u8 antidx_a : 4;
+#endif
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		antidx_a: 4;
-	u8		antidx_b: 4;
-	u8		antidx_c: 4;
-	u8		antidx_d: 4;
+	u8 antidx_c : 4;
+	u8 antidx_d : 4;
 #else
-	u8		antidx_b: 4;
-	u8		antidx_a: 4;
-	u8		antidx_d: 4;
-	u8		antidx_c: 4;
+	u8 antidx_d : 4;
+	u8 antidx_c : 4;
 #endif
 
-	/* DW3 : Offset 12 */
-	u8		signal_quality;
+	/* @DW3 : Offset 12 */
+	u8 signal_quality;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 vga_a : 5;
+	u8 lna_l_a : 3;
+#else
+	u8 lna_l_a : 3;
+	u8 vga_a : 5;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 bb_power_a : 6;
+	u8 rsvd_3_1 : 1;
+	u8 lna_h_a : 1;
+#else
+
+	u8 lna_h_a : 1;
+	u8 rsvd_3_1 : 1;
+	u8 bb_power_a : 6;
+#endif
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		vga_a:5;
-	u8		lna_l_a:3;
-	u8		bb_power_a:6;
-	u8		rsvd_3_1:1;
-	u8		lna_h_a:1;
+	u8 rxrate : 2;
+	u8 raterr : 1;
+	u8 lockbit : 1;
+	u8 sqloss : 1;
+	u8 mf_off : 1;
+	u8 rsvd_3_2 : 2;
 #else
-	u8		lna_l_a:3;
-	u8		vga_a:5;
-	u8		lna_h_a:1;
-	u8		rsvd_3_1:1;
-	u8		bb_power_a:6;
+	u8 rsvd_3_2 : 2;
+	u8 mf_off : 1;
+	u8 sqloss : 1;
+	u8 lockbit : 1;
+	u8 raterr : 1;
+	u8 rxrate : 2;
 #endif
-	u8		rsvd_3_2;
 
-	/* DW4 : Offset 16 */
-	u8		pwdb_b;
+	/* @DW4 : Offset 16 */
+	u8 pwdb_b;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 vga_b : 5;
+	u8 lna_l_b : 3;
+#else
+	u8 lna_l_b : 3;
+	u8 vga_b : 5;
+#endif
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		vga_b:5;
-	u8		lna_l_b:3;
-	u8		bb_power_b:6;
-	u8		rsvd_4_1:1;
-	u8		lna_h_b:1;
-	u8		gain_b: 6;
-	u8		rsvd_4_2:2;
+	u8 bb_power_b : 6;
+	u8 rsvd_4_1 : 1;
+	u8 lna_h_b : 1;
 #else
-	u8		lna_l_b:3;
-	u8		vga_b:5;
-	u8		lna_h_b:1;
-	u8		rsvd_4_1:1;
-	u8		bb_power_b:6;
-	u8		rsvd_4_2:2;
-	u8		gain_b: 6;
+	u8 lna_h_b : 1;
+	u8 rsvd_4_1 : 1;
+	u8 bb_power_b : 6;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 gain_b : 6;
+	u8 rsvd_4_2 : 2;
+#else
+	u8 rsvd_4_2 : 2;
+	u8 gain_b : 6;
 #endif
 
-	/* DW5 : Offset 20 */
-	u8		pwdb_c;
+	/* @DW5 : Offset 20 */
+	u8 pwdb_c;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		vga_c:5;
-	u8		lna_l_c:3;
-	u8		bb_power_c:6;
-	u8		rsvd_5_1:1;
-	u8		lna_h_c:1;
-	u8		gain_c: 6;
-	u8		rsvd_5_2:2;
+	u8 vga_c : 5;
+	u8 lna_l_c : 3;
 #else
-	u8		lna_l_c:3;
-	u8		vga_c:5;
-	u8		lna_h_c:1;
-	u8		rsvd_5_1:1;
-	u8		bb_power_c:6;
-	u8		rsvd_5_2:2;
-	u8		gain_c: 6;
+	u8 lna_l_c : 3;
+	u8 vga_c : 5;
 #endif
-
-	/* DW6 : Offset 24 */
-	u8		pwdb_d;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		vga_d:5;
-	u8		lna_l_d:3;
-	u8		bb_power_d:6;
-	u8		rsvd_6_1:1;
-	u8		lna_h_d:1;
-	u8		gain_d: 6;
-	u8		rsvd_6_2:2;
-#else
-	u8		lna_l_d:3;
-	u8		vga_d:5;
-	u8		lna_h_d:1;
-	u8		rsvd_6_1:1;
-	u8		bb_power_d:6;
-	u8		rsvd_6_2:2;
-	u8		gain_d: 6;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 bb_power_c : 6;
+	u8 rsvd_5_1 : 1;
+	u8 lna_h_c : 1;
+#else
+	u8 lna_h_c : 1;
+	u8 rsvd_5_1 : 1;
+	u8 bb_power_c : 6;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 gain_c : 6;
+	u8 rsvd_5_2 : 2;
+#else
+	u8 rsvd_5_2 : 2;
+	u8 gain_c : 6;
+#endif
+
+	/* @DW6 : Offset 24 */
+	u8 pwdb_d;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 vga_d : 5;
+	u8 lna_l_d : 3;
+#else
+	u8 lna_l_d : 3;
+	u8 vga_d : 5;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 bb_power_d : 6;
+	u8 rsvd_6_1 : 1;
+	u8 lna_h_d : 1;
+#else
+	u8 lna_h_d : 1;
+	u8 rsvd_6_1 : 1;
+	u8 bb_power_d : 6;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 gain_d : 6;
+	u8 rsvd_6_2 : 2;
+#else
+	u8 rsvd_6_2 : 2;
+	u8 gain_d : 6;
 #endif
 };
 
-__PACK struct _phy_status_rpt_jaguar2_type1 {
-	/* DW0 : Offset 0 */
+__PACK struct phy_sts_rpt_jgr3_type1 {
+/* @DW0 : Offset 0 */
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		page_num:4;
-	u8		pkt_cnt:2;
-	u8		channel_pri_msb:2;
+	u8 page_num : 4;
+	u8 pkt_cnt : 2;
+	u8 channel_pri_msb : 2;
 #else
-	u8		channel_pri_msb:2;
-	u8		pkt_cnt:2;
-	u8		page_num:4;
+	u8 channel_pri_msb : 2;
+	u8 pkt_cnt : 2;
+	u8 page_num : 4;
 #endif
-	u8		pwdb_a;
-	u8		pwdb_b;
-	u8		pwdb_c;
+	u8 pwdb_a;
+	u8 pwdb_b;
+	u8 pwdb_c;
 
-	/* DW1 : Offset 4 */
-	u8		pwdb_d;
+	/* @DW1 : Offset 4 */
+	u8 pwdb_d;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		l_rxsc: 4;
-	u8		ht_rxsc: 4;
+	u8 l_rxsc : 4;
+	u8 ht_rxsc : 4;
 #else
-	u8		ht_rxsc: 4;
-	u8		l_rxsc: 4;
+	u8 ht_rxsc : 4;
+	u8 l_rxsc : 4;
 #endif
-	u8		channel_pri_lsb;
+	u8 channel_pri_lsb;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		band: 2;
-	u8		rsvd_0: 2;
-	u8		gnt_bt: 1;
-	u8		ldpc: 1;
-	u8		stbc: 1;
-	u8		beamformed: 1;
+	u8 band : 2;
+	u8 rsvd_0 : 2;
+	u8 gnt_bt : 1;
+	u8 ldpc : 1;
+	u8 stbc : 1;
+	u8 beamformed : 1;
 #else
-	u8		beamformed: 1;
-	u8		stbc: 1;
-	u8		ldpc: 1;
-	u8		gnt_bt: 1;
-	u8		rsvd_0: 2;
-	u8		band: 2;
+	u8 beamformed : 1;
+	u8 stbc : 1;
+	u8 ldpc : 1;
+	u8 gnt_bt : 1;
+	u8 rsvd_0 : 2;
+	u8 band : 2;
 #endif
 
-	/* DW2 : Offset 8 */
-	u8		channel_sec_lsb;
+	/* @DW2 : Offset 8 */
+	u8 channel_sec_lsb;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		channel_sec_msb:2;
-	u8		rsvd_1: 2;
-	u8		hw_antsw_occur_a:1;
-	u8		hw_antsw_occur_b:1;
-	u8		hw_antsw_occur_c:1;
-	u8		hw_antsw_occur_d:1;
+	u8 channel_sec_msb : 2;
+	u8 rsvd_1 : 2;
+	u8 hw_antsw_occur_a : 1;
+	u8 hw_antsw_occur_b : 1;
+	u8 hw_antsw_occur_c : 1;
+	u8 hw_antsw_occur_d : 1;
 #else
-	u8		hw_antsw_occur_d:1;
-	u8		hw_antsw_occur_c:1;
-	u8		hw_antsw_occur_b:1;
-	u8		hw_antsw_occur_a:1;
-	u8		rsvd_1: 2;
-	u8		channel_sec_msb:2;
+	u8 hw_antsw_occur_d : 1;
+	u8 hw_antsw_occur_c : 1;
+	u8 hw_antsw_occur_b : 1;
+	u8 hw_antsw_occur_a : 1;
+	u8 rsvd_1 : 2;
+	u8 channel_sec_msb : 2;
 
 #endif
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		antidx_a: 4;
-	u8		antidx_b: 4;
-	u8		antidx_c: 4;
-	u8		antidx_d: 4;
+	u8 antidx_a : 4;
+	u8 antidx_b : 4;
 #else
-	u8		antidx_b: 4;
-	u8		antidx_a: 4;
-	u8		antidx_d: 4;
-	u8		antidx_c: 4;
+	u8 antidx_b : 4;
+	u8 antidx_a : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_c : 4;
+	u8 antidx_d : 4;
+#else
+	u8 antidx_d : 4;
+	u8 antidx_c : 4;
 #endif
 
-	/* DW3 : Offset 12 */
-	u8		paid;
+	/* @DW3 : Offset 12 */
+	u8 paid;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		paid_msb: 1;
-	u8		gid: 6;
-	u8		rsvd_3: 1;
+	u8 paid_msb : 1;
+	u8 gid : 6;
+	u8 rsvd_3 : 1;
 #else
-	u8		rsvd_3: 1;
-	u8		gid: 6;
-	u8		paid_msb: 1;
+	u8 rsvd_3 : 1;
+	u8 gid : 6;
+	u8 paid_msb : 1;
 #endif
-	u16		rsvd_4;
-/*
+	u16 rsvd_4;
+#if 0
+	/*@
 	u8		rsvd_4;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
 	u8		rsvd_5: 6;
@@ -673,391 +744,395 @@ __PACK struct _phy_status_rpt_jaguar2_type1 {
 	u8		rsvd_5: 6;
 #endif
 */
-	/* DW4 */
-	s8		rxevm[4];			/* s(8,1) */
+#endif
+	/* @DW4 : Offset 16 */
+	s8 rxevm[4]; /* s(8,1) */
 
-	/* DW5 */
-	s8		cfo_tail[4];			/* s(8,7) */
+	/* @DW5 : Offset 20 */
+	s8 cfo_tail[4]; /* s(8,7) */
 
-	/* DW6 */
-	s8		rxsnr[4];			/* s(8,1) */
+	/* @DW6 : Offset 24 */
+	s8 rxsnr[4]; /* s(8,1) */
 };
-__PACK struct _phy_status_rpt_jaguar2_type2_type3 {
-	/* Type2 is primary channel & type3 is secondary channel */
-	/* DW0 ane DW1 */
+
+__PACK struct phy_sts_rpt_jgr3_type2_3 {
+/* Type2 is primary channel & type3 is secondary channel */
+/* @DW0 and DW1: Offest 0 and Offset 4 */
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		page_num:4;
-	u8		pkt_cnt:2;
-	u8		channel_msb:2;
+	u8 page_num : 4;
+	u8 pkt_cnt : 2;
+	u8 channel_msb : 2;
 #else
-	u8		channel_msb:2;
-	u8		pkt_cnt:2;
-	u8		page_num:4;
+	u8 channel_msb : 2;
+	u8 pkt_cnt : 2;
+	u8 page_num : 4;
 #endif
-	u8		pwdb[4];
+	u8 pwdb[4];
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		l_rxsc: 4;
-	u8		ht_rxsc: 4;
+	u8 l_rxsc : 4;
+	u8 ht_rxsc : 4;
 #else
-	u8		ht_rxsc: 4;
-	u8		l_rxsc: 4;
+	u8 ht_rxsc : 4;
+	u8 l_rxsc : 4;
 #endif
-	u8		channel_lsb;
+	u8 channel_lsb;
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		band: 2;
-	u8		rsvd_0: 1;
-	u8		hw_antsw_occu: 1;
-	u8		gnt_bt: 1;
-	u8		ldpc: 1;
-	u8		stbc: 1;
-	u8		beamformed: 1;
+	u8 band : 2;
+	u8 rsvd_0 : 2;
+	u8 gnt_bt : 1;
+	u8 ldpc : 1;
+	u8 stbc : 1;
+	u8 beamformed : 1;
 #else
-	u8		beamformed: 1;
-	u8		stbc: 1;
-	u8		ldpc: 1;
-	u8		gnt_bt: 1;
-	u8		hw_antsw_occu: 1;
-	u8		rsvd_0: 1;
-	u8		band: 2;
+	u8 beamformed : 1;
+	u8 stbc : 1;
+	u8 ldpc : 1;
+	u8 gnt_bt : 1;
+	u8 rsvd_0 : 2;
+	u8 band : 2;
 #endif
 
-	/* DW2 */
+/* @DW2 : Offset 8 */
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		shift_l_map: 6;
-	u8		rsvd_1: 2;
+	u8 shift_l_map : 6;
+	u8 rsvd_1 : 2;
 #else
-	u8		rsvd_1: 2;
-	u8		shift_l_map: 6;
+	u8 rsvd_1 : 2;
+	u8 shift_l_map : 6;
 #endif
-	s8		pwed_th;	/* dynamic energy threshold S(8,2) */
+	s8 pwed_th; /* @dynamic energy threshold S(8,2) */
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		agc_table_a: 4;
-	u8		agc_table_b: 4;
-	u8		agc_table_c: 4;
-	u8		agc_table_d: 4;
+	u8 agc_table_a : 4;
+	u8 agc_table_b : 4;
 #else
-	u8		agc_table_b: 4;
-	u8		agc_table_a: 4;
-	u8		agc_table_d: 4;
-	u8		agc_table_c: 4;
+	u8 agc_table_b : 4;
+	u8 agc_table_a : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 agc_table_c : 4;
+	u8 agc_table_d : 4;
+#else
+	u8 agc_table_d : 4;
+	u8 agc_table_c : 4;
 #endif
 
-	/* DW3 ~ DW6*/
-	u8		cnt_cca2agc_rdy; /* Time(ns) = cnt_cca2agc_ready*25 */
+	/* @DW3 : Offset 12 */
+	u8 cnt_cca2agc_rdy; /* Time(ns) = cnt_cca2agc_ready*25 */
 #if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		mp_gain_a: 6;
-	u8		mp_gain_b_lsb: 2;
-	u8		mp_gain_b_msb: 4;
-	u8		mp_gain_c_lsb: 4;
-	u8		mp_gain_c_msb: 2;
-	u8		avg_noise_pwr_lsb: 4;
-	u8		rsvd_3:2;
+	u8 mp_gain_a : 6;
+	u8 mp_gain_b_lsb : 2;
+#else
+	u8 mp_gain_b_lsb : 2;
+	u8 mp_gain_a : 6;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 mp_gain_b_msb : 4;
+	u8 mp_gain_c_lsb : 4;
+#else
+	u8 mp_gain_c_lsb : 4;
+	u8 mp_gain_b_msb : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 mp_gain_c_msb : 2;
+	u8 avg_noise_pwr_lsb : 4;
+	u8 rsvd_3 : 2;
 	/* u8		r_rfmod:2; */
-	u8		mp_gain_d: 6;
-	u8		is_freq_select_fading: 1;
-	u8		rsvd_2: 1;
-	u8		aagc_step_a: 2;
-	u8		aagc_step_b: 2;
-	u8		aagc_step_c: 2;
-	u8		aagc_step_d: 2;
-#else
-	u8		mp_gain_b_lsb: 2;
-	u8		mp_gain_a: 6;
-	u8		mp_gain_c_lsb: 4;
-	u8		mp_gain_b_msb: 4;
-	u8		rsvd_3:2;
+#else
 	/* u8		r_rfmod:2; */
-	u8		avg_noise_pwr_lsb: 4;
-	u8		mp_gain_c_msb: 2;
-	u8		rsvd_2: 1;
-	u8		is_freq_select_fading: 1;
-	u8		mp_gain_d: 6;
-	u8		aagc_step_d: 2;
-	u8		aagc_step_c: 2;
-	u8		aagc_step_b: 2;
-	u8		aagc_step_a: 2;
-#endif
-	u8		ht_aagc_gain[4];
-	u8		dagc_gain[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		counter: 6;
-	u8		syn_count_lsb: 2;
-	u8		syn_count_msb: 3;
-	u8		avg_noise_pwr_msb:5;
-#else
-	u8		syn_count_lsb: 2;
-	u8		counter: 6;
-	u8		avg_noise_pwr_msb:5;
-	u8		syn_count_msb: 3;
+	u8 rsvd_3 : 2;
+	u8 avg_noise_pwr_lsb : 4;
+	u8 mp_gain_c_msb : 2;
+#endif
+	/* @DW4 ~ 5: offset 16 ~20 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 mp_gain_d : 6;
+	u8 is_freq_select_fading : 1;
+	u8 rsvd_2 : 1;
+#else
+	u8 rsvd_2 : 1;
+	u8 is_freq_select_fading : 1;
+	u8 mp_gain_d : 6;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 aagc_step_a : 2;
+	u8 aagc_step_b : 2;
+	u8 aagc_step_c : 2;
+	u8 aagc_step_d : 2;
+#else
+	u8 aagc_step_d : 2;
+	u8 aagc_step_c : 2;
+	u8 aagc_step_b : 2;
+	u8 aagc_step_a : 2;
+#endif
+	u8 ht_aagc_gain[4];
+	u8 dagc_gain[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 counter : 6;
+	u8 syn_count_lsb : 2;
+#else
+	u8 syn_count_lsb : 2;
+	u8 counter : 6;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 syn_count_msb : 3;
+	u8 avg_noise_pwr_msb : 5;
+#else
+	u8 avg_noise_pwr_msb : 5;
+	u8 syn_count_msb : 3;
 #endif
 };
 
-__PACK struct _phy_status_rpt_jaguar2_type4 {
-	/* smart antenna */
-	/* DW0 ane DW1 */
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		page_num:4;
-	u8		pkt_cnt:2;
-	u8		channel_msb:2;
-#else
-	u8		channel_msb:2;
-	u8		pkt_cnt:2;
-	u8		page_num:4;
-#endif
-	u8		pwdb[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		l_rxsc: 4;
-	u8		ht_rxsc: 4;
-#else
-	u8		ht_rxsc: 4;
-	u8		l_rxsc: 4;
-#endif
-	u8		channel_lsb;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		band: 2;
-	u8		rsvd_0: 1;
-	u8		hw_antsw_occu: 1;
-	u8		gnt_bt: 1;
-	u8		ldpc: 1;
-	u8		stbc: 1;
-	u8		beamformed: 1;
-#else
-	u8		beamformed: 1;
-	u8		stbc: 1;
-	u8		ldpc: 1;
-	u8		gnt_bt: 1;
-	u8		hw_antsw_occu: 1;
-	u8		rsvd_0: 1;
-	u8		band: 2;
-#endif
-
-	/* DW2 ~ DW3 */
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		bad_tone_cnt_min_eign_0:4;
-	u8		bad_tone_cnt_cn_excess_0:4;
-	u8		training_done_a:1;
-	u8		training_done_b:1;
-	u8		training_done_c:1;
-	u8		training_done_d:1;
-	u8		hw_antsw_occur_a:1;
-	u8		hw_antsw_occur_b:1;
-	u8		hw_antsw_occur_c:1;
-	u8		hw_antsw_occur_d:1;
-	u8		antidx_a: 4;
-	u8		antidx_b: 4;
-	u8		antidx_c: 4;
-	u8		antidx_d: 4;
-#else
-	u8		bad_tone_cnt_cn_excess_0:4;
-	u8		bad_tone_cnt_min_eign_0:4;
-	u8		hw_antsw_occur_d:1;
-	u8		hw_antsw_occur_c:1;
-	u8		hw_antsw_occur_b:1;
-	u8		hw_antsw_occur_a:1;
-	u8		training_done_d:1;
-	u8		training_done_c:1;
-	u8		training_done_b:1;
-	u8		training_done_a:1;
-	u8		antidx_b: 4;
-	u8		antidx_a: 4;
-	u8		antidx_d: 4;
-	u8		antidx_c: 4;
-#endif
-	u8		tx_pkt_cnt;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		bad_tone_cnt_min_eign_1:4;
-	u8		bad_tone_cnt_cn_excess_1:4;
-	u8		avg_cond_num_0:7;
-	u8		avg_cond_num_1_lsb:1;
-	u8		avg_cond_num_1_msb:6;
-	u8		rsvd_1:2;
-#else
-	u8		bad_tone_cnt_cn_excess_1:4;
-	u8		bad_tone_cnt_min_eign_1:4;
-	u8		avg_cond_num_1_lsb:1;
-	u8		avg_cond_num_0:7;
-	u8		rsvd_1:2;
-	u8		avg_cond_num_1_msb:6;
-#endif
-
-	/* DW4 */
-	s8		rxevm[4];			/* s(8,1) */
-
-	/* DW5 */
-	u8		eigenvalue[4];			/* eigenvalue or eigenvalue of seg0 (in dB) */
-
-	/* DW6 */
-	s8		rxsnr[4];			/* s(8,1) */
+__PACK struct phy_sts_rpt_jgr3_type4 {
+/* smart antenna */
+/* @DW0 and DW1 : offset 0 and 4  */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 page_num : 4;
+	u8 pkt_cnt : 2;
+	u8 channel_msb : 2;
+#else
+	u8 channel_msb : 2;
+	u8 pkt_cnt : 2;
+	u8 page_num : 4;
+#endif
+	u8 pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 l_rxsc : 4;
+	u8 ht_rxsc : 4;
+#else
+	u8 ht_rxsc : 4;
+	u8 l_rxsc : 4;
+#endif
+	u8 channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 band : 2;
+	u8 rsvd_0 : 2;
+	u8 gnt_bt : 1;
+	u8 ldpc : 1;
+	u8 stbc : 1;
+	u8 beamformed : 1;
+#else
+	u8 beamformed : 1;
+	u8 stbc : 1;
+	u8 ldpc : 1;
+	u8 gnt_bt : 1;
+	u8 rsvd_0 : 1;
+	u8 band : 2;
+#endif
+
+/* @DW2 : offset 8 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 bad_tone_cnt_min_eign_0 : 4;
+	u8 bad_tone_cnt_cn_excess_0 : 4;
+#else
+	u8 bad_tone_cnt_cn_excess_0 : 4;
+	u8 bad_tone_cnt_min_eign_0 : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 training_done_a : 1;
+	u8 training_done_b : 1;
+	u8 training_done_c : 1;
+	u8 training_done_d : 1;
+	u8 hw_antsw_occur_a : 1;
+	u8 hw_antsw_occur_b : 1;
+	u8 hw_antsw_occur_c : 1;
+	u8 hw_antsw_occur_d : 1;
+#else
+	u8 hw_antsw_occur_d : 1;
+	u8 hw_antsw_occur_c : 1;
+	u8 hw_antsw_occur_b : 1;
+	u8 hw_antsw_occur_a : 1;
+	u8 training_done_d : 1;
+	u8 training_done_c : 1;
+	u8 training_done_b : 1;
+	u8 training_done_a : 1;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_a : 4;
+	u8 antidx_b : 4;
+#else
+	u8 antidx_b : 4;
+	u8 antidx_a : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_c : 4;
+	u8 antidx_d : 4;
+#else
+	u8 antidx_d : 4;
+	u8 antidx_c : 4;
+#endif
+/* @DW3 : offset 12 */
+	u8 tx_pkt_cnt;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 bad_tone_cnt_min_eign_1 : 4;
+	u8 bad_tone_cnt_cn_excess_1 : 4;
+#else
+	u8 bad_tone_cnt_cn_excess_1 : 4;
+	u8 bad_tone_cnt_min_eign_1 : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 avg_cond_num_0 : 7;
+	u8 avg_cond_num_1_lsb : 1;
+#else
+	u8 avg_cond_num_1_lsb : 1;
+	u8 avg_cond_num_0 : 7;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 avg_cond_num_1_msb : 6;
+	u8 rsvd_1 : 2;
+#else
+	u8 rsvd_1 : 2;
+	u8 avg_cond_num_1_msb : 6;
+#endif
+
+	/* @DW4 : offset 16 */
+	s8 rxevm[4]; /* s(8,1) */
+
+	/* @DW5 : offset 20 */
+	u8 eigenvalue[4]; /* @eigenvalue or eigenvalue of seg0 (in dB) */
+
+	/* @DW6 : ofset 24 */
+	s8 rxsnr[4]; /* s(8,1) */
 };
 
-__PACK struct _phy_status_rpt_jaguar2_type5 {
-	/* smart antenna */
-	/* DW0 ane DW1 */
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		page_num:4;
-	u8		pkt_cnt:2;
-	u8		channel_msb:2;
-#else
-	u8		channel_msb:2;
-	u8		pkt_cnt:2;
-	u8		page_num:4;
-#endif
-	u8		pwdb[4];
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		l_rxsc: 4;
-	u8		ht_rxsc: 4;
-#else
-	u8		ht_rxsc: 4;
-	u8		l_rxsc: 4;
-#endif
-	u8		channel_lsb;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		band: 2;
-	u8		rsvd_0: 1;
-	u8		hw_antsw_occu: 1;
-	u8		gnt_bt: 1;
-	u8		ldpc: 1;
-	u8		stbc: 1;
-	u8		beamformed: 1;
-#else
-	u8		beamformed: 1;
-	u8		stbc: 1;
-	u8		ldpc: 1;
-	u8		gnt_bt: 1;
-	u8		hw_antsw_occu: 1;
-	u8		rsvd_0: 1;
-	u8		band: 2;
-#endif
-	/* DW2 ~ DW5 */
-	u8		rsvd_1;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		rsvd_2:4;
-	u8		hw_antsw_occur_a:1;
-	u8		hw_antsw_occur_b:1;
-	u8		hw_antsw_occur_c:1;
-	u8		hw_antsw_occur_d:1;
-	u8		antidx_a: 4;
-	u8		antidx_b: 4;
-	u8		antidx_c: 4;
-	u8		antidx_d: 4;
-#else
-	u8		hw_antsw_occur_d:1;
-	u8		hw_antsw_occur_c:1;
-	u8		hw_antsw_occur_b:1;
-	u8		hw_antsw_occur_a:1;
-	u8		rsvd_2:4;
-	u8		antidx_b: 4;
-	u8		antidx_a: 4;
-	u8		antidx_d: 4;
-	u8		antidx_c: 4;
-#endif
-	u8		tx_pkt_cnt;
-#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
-	u8		inf_pos_0_A_flg:1;
-	u8		inf_pos_1_A_flg:1;
-	u8		inf_pos_0_B_flg:1;
-	u8		inf_pos_1_B_flg:1;
-	u8		inf_pos_0_C_flg:1;
-	u8		inf_pos_1_C_flg:1;
-	u8		inf_pos_0_D_flg:1;
-	u8		inf_pos_1_D_flg:1;
-#else
-	u8		inf_pos_1_D_flg:1;
-	u8		inf_pos_0_D_flg:1;
-	u8		inf_pos_1_C_flg:1;
-	u8		inf_pos_0_C_flg:1;
-	u8		inf_pos_1_B_flg:1;
-	u8		inf_pos_0_B_flg:1;
-	u8		inf_pos_1_A_flg:1;
-	u8		inf_pos_0_A_flg:1;
-#endif
-	u8		rsvd_3;
-	u8		rsvd_4;
-	u8		inf_pos_0_a;
-	u8		inf_pos_1_a;
-	u8		inf_pos_0_b;
-	u8		inf_pos_1_b;
-	u8		inf_pos_0_c;
-	u8		inf_pos_1_c;
-	u8		inf_pos_0_d;
-	u8		inf_pos_1_d;
+__PACK struct phy_sts_rpt_jgr3_type5 {
+/* @Debug */
+/* @DW0 ane DW1 : offset 0 and 4 */
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 page_num : 4;
+	u8 pkt_cnt : 2;
+	u8 channel_msb : 2;
+#else
+	u8 channel_msb : 2;
+	u8 pkt_cnt : 2;
+	u8 page_num : 4;
+#endif
+	u8 pwdb[4];
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 l_rxsc : 4;
+	u8 ht_rxsc : 4;
+#else
+	u8 ht_rxsc : 4;
+	u8 l_rxsc : 4;
+#endif
+	u8 channel_lsb;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 band : 2;
+	u8 rsvd_0 : 2;
+	u8 gnt_bt : 1;
+	u8 ldpc : 1;
+	u8 stbc : 1;
+	u8 beamformed : 1;
+#else
+	u8 beamformed : 1;
+	u8 stbc : 1;
+	u8 ldpc : 1;
+	u8 gnt_bt : 1;
+	u8 rsvd_0 : 2;
+	u8 band : 2;
+#endif
+	/* @DW2 : offset 8 */
+	u8 rsvd_1;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 rsvd_2 : 4;
+	u8 hw_antsw_occur_a : 1;
+	u8 hw_antsw_occur_b : 1;
+	u8 hw_antsw_occur_c : 1;
+	u8 hw_antsw_occur_d : 1;
+#else
+	u8 hw_antsw_occur_d : 1;
+	u8 hw_antsw_occur_c : 1;
+	u8 hw_antsw_occur_b : 1;
+	u8 hw_antsw_occur_a : 1;
+	u8 rsvd_2 : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_a : 4;
+	u8 antidx_b : 4;
+#else
+	u8 antidx_b : 4;
+	u8 antidx_a : 4;
+#endif
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 antidx_c : 4;
+	u8 antidx_d : 4;
+#else
+	u8 antidx_d : 4;
+	u8 antidx_c : 4;
+#endif
+	/* @DW3 : offset 12 */
+	u8 tx_pkt_cnt;
+#if (ODM_ENDIAN_TYPE == ODM_ENDIAN_LITTLE)
+	u8 inf_pos_0_A_flg : 1;
+	u8 inf_pos_1_A_flg : 1;
+	u8 inf_pos_0_B_flg : 1;
+	u8 inf_pos_1_B_flg : 1;
+	u8 inf_pos_0_C_flg : 1;
+	u8 inf_pos_1_C_flg : 1;
+	u8 inf_pos_0_D_flg : 1;
+	u8 inf_pos_1_D_flg : 1;
+#else
+	u8 inf_pos_1_D_flg : 1;
+	u8 inf_pos_0_D_flg : 1;
+	u8 inf_pos_1_C_flg : 1;
+	u8 inf_pos_0_C_flg : 1;
+	u8 inf_pos_1_B_flg : 1;
+	u8 inf_pos_0_B_flg : 1;
+	u8 inf_pos_1_A_flg : 1;
+	u8 inf_pos_0_A_flg : 1;
+#endif
+	u8 rsvd_3;
+	u8 rsvd_4;
+	/* @DW4 : offset 16 */
+	u8 inf_pos_0_a;
+	u8 inf_pos_1_a;
+	u8 inf_pos_0_b;
+	u8 inf_pos_1_b;
+	/* @DW5 : offset 20 */
+	u8 inf_pos_0_c;
+	u8 inf_pos_1_c;
+	u8 inf_pos_0_d;
+	u8 inf_pos_1_d;
 };
-#endif /*#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)*/
+#endif /*@#ifdef PHYSTS_3RD_TYPE_SUPPORT*/
 
 #if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
+boolean
+phydm_query_is_mu_api(struct dm_struct *phydm, u8 ppdu_idx, u8 *p_data_rate,
+		      u8 *p_gid);
+#endif
 
-void
-phydm_rx_phy_status_new_type(
-	void						*p_dm_void,
-	u8						*p_phy_status,
-	struct phydm_perpkt_info_struct			*p_pktinfo,
-	struct phydm_phyinfo_struct			*p_phy_info
-);
+#ifdef PHYSTS_3RD_TYPE_SUPPORT
+void phydm_rx_physts_3rd_type(void *dm_void, u8 *phy_sts,
+			      struct phydm_perpkt_info_struct *pktinfo,
+			      struct phydm_phyinfo_struct *phy_info);
+#endif
 
-boolean
-phydm_query_is_mu_api(
-	struct PHY_DM_STRUCT			*p_phydm,
-	u8								ppdu_idx,
-	u8								*p_data_rate,
-	u8								*p_gid
-);
-#endif
-
-void
-phydm_reset_phystatus_avg(
-	struct PHY_DM_STRUCT	*p_dm
-);
-
-void
-phydm_reset_phystatus_statistic(
-	struct PHY_DM_STRUCT	*p_dm
-);
-
-void
-phydm_reset_rssi_for_dm(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		station_id
-);
-
-void
-phydm_get_cck_rssi_table_from_reg(
-	struct PHY_DM_STRUCT	*p_dm
-);
-
-u8
-phydm_rate_to_num_ss(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			data_rate
-);
+void phydm_reset_phystatus_avg(struct dm_struct *dm);
+
+void phydm_reset_phystatus_statistic(struct dm_struct *dm);
+
+void phydm_reset_rssi_for_dm(struct dm_struct *dm, u8 station_id);
+
+void phydm_get_cck_rssi_table_from_reg(struct dm_struct *dm);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-phydm_normal_driver_rx_sniffer(
-	struct PHY_DM_STRUCT			*p_dm,
-	u8				*p_desc,
-	PRT_RFD_STATUS		p_rt_rfd_status,
-	u8				*p_drv_info,
-	u8				phy_status
-);
-#endif
-
-s32
-phydm_signal_scale_mapping(
-	struct PHY_DM_STRUCT *p_dm,
-	s32 curr_sig
-);
-
-void
-odm_phy_status_query(
-	struct PHY_DM_STRUCT					*p_dm,
-	struct phydm_phyinfo_struct			*p_phy_info,
-	u8						*p_phy_status,
-	struct phydm_perpkt_info_struct			*p_pktinfo
-);
-
-void
-phydm_rx_phy_status_init(
-	void			*p_dm_void
-);
-
-#endif /*#ifndef	__HALHWOUTSRC_H__*/
+void phydm_normal_driver_rx_sniffer(
+	struct dm_struct *dm,
+	u8 *desc,
+	PRT_RFD_STATUS rt_rfd_status,
+	u8 *drv_info,
+	u8 phy_status);
+#endif
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+s32 phydm_signal_scale_mapping(struct dm_struct *dm, s32 curr_sig);
+#endif
+
+void odm_phy_status_query(struct dm_struct *dm,
+			  struct phydm_phyinfo_struct *phy_info,
+			  u8 *phy_status_inf,
+			  struct phydm_perpkt_info_struct *pktinfo);
+
+void phydm_rx_phy_status_init(void *dm_void);
+
+#endif /*@#ifndef	__HALHWOUTSRC_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pmac_tx_setting.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pmac_tx_setting.c
new file mode 100644
index 000000000000..31695fe11a7f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pmac_tx_setting.c
@@ -0,0 +1,544 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+/*@************************************************************
+ * include files
+ ************************************************************/
+
+#include "mp_precomp.h"
+#include "phydm_precomp.h"
+
+#ifdef PHYDM_PMAC_TX_SETTING_SUPPORT
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+
+void phydm_start_cck_cont_tx_jgr3(void *dm_void,
+				  struct phydm_pmac_info *tx_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+	u8 rate = tx_info->tx_rate; /* @HW rate */
+
+	/* @if CCK block on? */
+	if (!odm_get_bb_reg(dm, R_0x1c3c, BIT(1)))
+		odm_set_bb_reg(dm, R_0x1c3c, BIT(1), 1);
+
+	/* @Turn Off All Test mode */
+	odm_set_bb_reg(dm, R_0x1ca4, 0x7, 0x0);
+
+	odm_set_bb_reg(dm, R_0x1a00, 0x3000, rate);
+	odm_set_bb_reg(dm, R_0x1a00, 0x3, 0x2); /* @transmit mode */
+	odm_set_bb_reg(dm, R_0x1a00, 0x8, 0x1); /* @turn on scramble setting */
+
+	/* @Fix rate selection issue */
+	odm_set_bb_reg(dm, R_0x1a70, 0x4000, 0x1);
+	/* @set RX weighting for path I & Q to 0 */
+	odm_set_bb_reg(dm, R_0x1a14, 0x300, 0x3);
+	/* @set loopback mode */
+	odm_set_bb_reg(dm, R_0x1c3c, 0x10, 0x1);
+
+	pmac_tx->cck_cont_tx = true;
+	pmac_tx->ofdm_cont_tx = false;
+}
+
+void phydm_stop_cck_cont_tx_jgr3(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+
+	pmac_tx->cck_cont_tx = false;
+	pmac_tx->ofdm_cont_tx = false;
+
+	odm_set_bb_reg(dm, R_0x1a00, 0x3, 0x0); /* @normal mode */
+	odm_set_bb_reg(dm, R_0x1a00, 0x8, 0x1); /* @turn on scramble setting */
+
+	/* @back to default */
+	odm_set_bb_reg(dm, R_0x1a70, 0x4000, 0x0);
+	odm_set_bb_reg(dm, R_0x1a14, 0x300, 0x0);
+	odm_set_bb_reg(dm, R_0x1c3c, 0x10, 0x0);
+	/* @BB Reset */
+	odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x0);
+	odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x1);
+}
+
+void phydm_start_ofdm_cont_tx_jgr3(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+
+	/* @1. if OFDM block on */
+	if (!odm_get_bb_reg(dm, R_0x1c3c, BIT(0)))
+		odm_set_bb_reg(dm, R_0x1c3c, BIT(0), 1);
+
+	/* @2. set CCK test mode off, set to CCK normal mode */
+	odm_set_bb_reg(dm, R_0x1a00, 0x3, 0);
+
+	/* @3. turn on scramble setting */
+	odm_set_bb_reg(dm, R_0x1a00, 0x8, 1);
+
+	/* @4. Turn On Continue Tx and turn off the other test modes. */
+	odm_set_bb_reg(dm, R_0x1ca4, 0x7, 0x1);
+
+	pmac_tx->cck_cont_tx = false;
+	pmac_tx->ofdm_cont_tx = true;
+}
+
+void phydm_stop_ofdm_cont_tx_jgr3(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+
+	pmac_tx->cck_cont_tx = false;
+	pmac_tx->ofdm_cont_tx = false;
+
+	/* @Turn Off All Test mode */
+	odm_set_bb_reg(dm, R_0x1ca4, 0x7, 0x0);
+
+	/* @Delay 10 ms */
+	ODM_delay_ms(10);
+
+	/* @BB Reset */
+	odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x0);
+	odm_set_bb_reg(dm, R_0x1d0c, 0x10000, 0x1);
+}
+
+void phydm_set_single_tone_jgr3(void *dm_void, boolean is_single_tone,
+				boolean en_pmac_tx, u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+	u8 start = RF_PATH_A, end = RF_PATH_A;
+
+	switch (path) {
+	case RF_PATH_A:
+	case RF_PATH_B:
+	case RF_PATH_C:
+	case RF_PATH_D:
+		start = path;
+		end = path;
+		break;
+	case RF_PATH_AB:
+		start = RF_PATH_A;
+		end = RF_PATH_B;
+		break;
+#if (RTL8814B_SUPPORT || RTL8198F_SUPPORT)
+	case RF_PATH_AC:
+		start = RF_PATH_A;
+		end = RF_PATH_C;
+		break;
+	case RF_PATH_AD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_BC:
+		start = RF_PATH_B;
+		end = RF_PATH_C;
+		break;
+	case RF_PATH_BD:
+		start = RF_PATH_B;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_CD:
+		start = RF_PATH_C;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_ABC:
+		start = RF_PATH_A;
+		end = RF_PATH_C;
+		break;
+	case RF_PATH_ABD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_ACD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_BCD:
+		start = RF_PATH_B;
+		end = RF_PATH_D;
+		break;
+	case RF_PATH_ABCD:
+		start = RF_PATH_A;
+		end = RF_PATH_D;
+		break;
+#endif
+	}
+
+	if (is_single_tone) {
+		pmac_tx->tx_scailing = odm_get_bb_reg(dm, R_0x81c, MASKDWORD);
+
+		if (!en_pmac_tx) {
+			phydm_start_ofdm_cont_tx_jgr3(dm);
+			/*SendPSPoll(pAdapter);*/
+		}
+
+		odm_set_bb_reg(dm, R_0x1c68, BIT(24), 0x1); /* @Disable CCA */
+
+		for (start; start <= end; start++) {
+			/* @Tx mode: RF0x00[19:16]=4'b0010 */
+			/* odm_set_rf_reg(dm, start, RF_0x0, 0xF0000, 0x2); */
+			/* @Lowest RF gain index: RF_0x0[4:0] = 0*/
+			odm_set_rf_reg(dm, start, RF_0x0, 0x1F, 0x0);
+			/* @RF LO enabled */
+			odm_set_rf_reg(dm, start, RF_0x58, BIT(1), 0x1);
+		}
+		#if (RTL8814B_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8814B) {
+			/* @Tx mode: RF0x00[19:16]=4'b0010 */
+			/* config_phydm_write_rf_syn_8814b(dm, RF_SYN0, RF_0x0,
+			 *				0xF0000, 0x2);
+			 */
+			/* @Lowest RF gain index: RF_0x0[4:0] = 0*/
+			config_phydm_write_rf_syn_8814b(dm, RF_SYN0, RF_0x0,
+							0x1F, 0x0);
+			/* @RF LO enabled */
+			config_phydm_write_rf_syn_8814b(dm, RF_SYN0, RF_0x58,
+							BIT(1), 0x1);
+		}
+		#endif
+		odm_set_bb_reg(dm, R_0x81c, 0x001FC000, 0);
+	} else {
+		for (start; start <= end; start++) {
+			/* @RF LO disabled */
+			odm_set_rf_reg(dm, start, RF_0x58, BIT(1), 0x0);
+		}
+		odm_set_bb_reg(dm, R_0x1c68, BIT(24), 0x0); /* @Enable CCA */
+
+		if (!en_pmac_tx)
+			phydm_stop_ofdm_cont_tx_jgr3(dm);
+
+		odm_set_bb_reg(dm, R_0x81c, MASKDWORD, pmac_tx->tx_scailing);
+	}
+}
+
+void phydm_stop_pmac_tx_jgr3(void *dm_void, struct phydm_pmac_info *tx_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+	u32 tmp = 0;
+
+	if (tx_info->mode == CONT_TX) {
+		odm_set_bb_reg(dm, R_0x1e70, 0xf, 2); /* TX Stop */
+		if (pmac_tx->is_cck_rate)
+			phydm_stop_cck_cont_tx_jgr3(dm);
+		else
+			phydm_stop_ofdm_cont_tx_jgr3(dm);
+	} else {
+		if (pmac_tx->is_cck_rate) {
+			tmp = odm_get_bb_reg(dm, R_0x2de4, MASKLWORD);
+			odm_set_bb_reg(dm, R_0x1e64, MASKLWORD, tmp + 50);
+		}
+		odm_set_bb_reg(dm, R_0x1e70, 0xf, 2); /* TX Stop */
+	}
+
+	if (tx_info->mode == OFDM_SINGLE_TONE_TX) {
+		/* Stop HW TX -> Stop Continuous TX -> Stop RF Setting */
+		if (pmac_tx->is_cck_rate)
+			phydm_stop_cck_cont_tx_jgr3(dm);
+		else
+			phydm_stop_ofdm_cont_tx_jgr3(dm);
+
+		phydm_set_single_tone_jgr3(dm, false, true, pmac_tx->path);
+	}
+}
+
+void phydm_set_mac_phy_txinfo_jgr3(void *dm_void,
+				   struct phydm_pmac_info *tx_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+	u32 tmp = 0;
+
+	odm_set_bb_reg(dm, R_0xa58, 0x003F8000, tx_info->tx_rate);
+
+	/* @0x900[1] ndp_sound */
+	odm_set_bb_reg(dm, R_0x900, 0x2, tx_info->ndp_sound);
+	/* @0x900[27:24] txsc [29:28] bw [31:30] m_stbc */
+	tmp = (tx_info->tx_sc) | ((tx_info->bw) << 4) |
+	      ((tx_info->m_stbc - 1) << 6);
+	odm_set_bb_reg(dm, R_0x900, 0xFF000000, tmp);
+
+	if (pmac_tx->is_ofdm_rate) {
+		odm_set_bb_reg(dm, R_0x900, 0x1, 0);
+		odm_set_bb_reg(dm, R_0x900, 0x4, 0);
+	} else if (pmac_tx->is_ht_rate) {
+		odm_set_bb_reg(dm, R_0x900, 0x1, 1);
+		odm_set_bb_reg(dm, R_0x900, 0x4, 0);
+	} else if (pmac_tx->is_vht_rate) {
+		odm_set_bb_reg(dm, R_0x900, 0x1, 0);
+		odm_set_bb_reg(dm, R_0x900, 0x4, 1);
+	}
+
+	tmp = tx_info->packet_period; /* @for TX interval */
+	odm_set_bb_reg(dm, R_0x9b8, 0xffff0000, tmp);
+}
+
+void phydm_set_sig_jgr3(void *dm_void, struct phydm_pmac_info *tx_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+	u32 tmp = 0;
+
+	if (pmac_tx->is_cck_rate)
+		return;
+
+	/* @L-SIG */
+	odm_set_bb_reg(dm, R_0x1eb4, 0xfffff, tx_info->packet_count);
+
+	tmp = BYTE_2_DWORD(0, tx_info->lsig[2], tx_info->lsig[1],
+			   tx_info->lsig[0]);
+	odm_set_bb_reg(dm, R_0x908, 0xffffff, tmp);
+#if 0
+	/* @0x924[7:0] = Data init octet */
+	tmp = tx_info->packet_pattern;
+	odm_set_bb_reg(dm, R_0x924, 0xff, tmp);
+
+	if (tx_info->packet_pattern == RANDOM_BY_PN32)
+		tmp = 0x3;
+	else
+		tmp = 0x0;
+
+	odm_set_bb_reg(dm, R_0x914, 0x60000000, tmp);
+#endif
+	if (pmac_tx->is_ht_rate) {
+	/* @HT SIG */
+		tmp = BYTE_2_DWORD(0, tx_info->ht_sig[2], tx_info->ht_sig[1],
+				   tx_info->ht_sig[0]);
+		odm_set_bb_reg(dm, R_0x90c, 0xffffff, tmp);
+		tmp = BYTE_2_DWORD(0, tx_info->ht_sig[5], tx_info->ht_sig[4],
+				   tx_info->ht_sig[3]);
+		odm_set_bb_reg(dm, R_0x910, 0xffffff, tmp);
+	} else if (pmac_tx->is_vht_rate) {
+	/* @VHT SIG A/B/serv_field/delimiter */
+		tmp = BYTE_2_DWORD(0, tx_info->vht_sig_a[2],
+				   tx_info->vht_sig_a[1],
+				   tx_info->vht_sig_a[0]);
+		odm_set_bb_reg(dm, R_0x90c, 0xffffff, tmp);
+		tmp = BYTE_2_DWORD(0, tx_info->vht_sig_a[5],
+				   tx_info->vht_sig_a[4],
+				   tx_info->vht_sig_a[3]);
+		odm_set_bb_reg(dm, R_0x910, 0xffffff, tmp);
+		tmp = BYTE_2_DWORD(tx_info->vht_sig_b[3], tx_info->vht_sig_b[2],
+				   tx_info->vht_sig_b[1],
+				   tx_info->vht_sig_b[0]);
+		odm_set_bb_reg(dm, R_0x914, 0x1FFFFFFF, tmp);
+
+		tmp = tx_info->vht_sig_b_crc;
+		odm_set_bb_reg(dm, R_0x938, 0xff00, tmp);
+
+		tmp = BYTE_2_DWORD(tx_info->vht_delimiter[3],
+				   tx_info->vht_delimiter[2],
+				   tx_info->vht_delimiter[1],
+				   tx_info->vht_delimiter[0]);
+		odm_set_bb_reg(dm, R_0x940, MASKDWORD, tmp);
+	}
+}
+
+void phydm_set_cck_preamble_hdr_jgr3(void *dm_void,
+				     struct phydm_pmac_info *tx_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+	u32 tmp = 0;
+
+	if (!pmac_tx->is_cck_rate)
+		return;
+
+	tmp = tx_info->packet_count | (tx_info->sfd << 16);
+	odm_set_bb_reg(dm, R_0x1e64, MASKDWORD, tmp);
+	tmp = tx_info->signal_field | (tx_info->service_field << 8) |
+	      (tx_info->length << 16);
+	odm_set_bb_reg(dm, R_0x1e68, MASKDWORD, tmp);
+	tmp = BYTE_2_DWORD(0, 0, tx_info->crc16[1], tx_info->crc16[0]);
+	odm_set_bb_reg(dm, R_0x1e6c, 0xffff, tmp);
+
+	if (tx_info->is_short_preamble)
+		odm_set_bb_reg(dm, R_0x1e6c, BIT(16), 0);
+	else
+		odm_set_bb_reg(dm, R_0x1e6c, BIT(16), 1);
+}
+
+void phydm_set_mode_jgr3(void *dm_void, struct phydm_pmac_info *tx_info,
+			 enum phydm_pmac_mode mode)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+
+	if (mode == CONT_TX) {
+		tx_info->packet_count = 1;
+
+		if (pmac_tx->is_cck_rate)
+			phydm_start_cck_cont_tx_jgr3(dm, tx_info);
+		else
+			phydm_start_ofdm_cont_tx_jgr3(dm);
+	} else if (mode == OFDM_SINGLE_TONE_TX) {
+		/* Continuous TX -> HW TX -> RF Setting */
+		tx_info->packet_count = 1;
+
+		if (pmac_tx->is_cck_rate)
+			phydm_start_cck_cont_tx_jgr3(dm, tx_info);
+		else
+			phydm_start_ofdm_cont_tx_jgr3(dm);
+	} else if (mode == PKTS_TX) {
+		if (pmac_tx->is_cck_rate && tx_info->packet_count == 0)
+			tx_info->packet_count = 0xffff;
+	}
+}
+
+void phydm_set_pmac_txon_jgr3(void *dm_void, struct phydm_pmac_info *tx_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+
+	odm_set_bb_reg(dm, R_0x1d08, BIT(0), 1); /* Turn on PMAC */
+
+	/* mac scramble seed setting, only in 8198F */
+	#if (RTL8198F_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8198F)
+			if ~(odm_get_bb_reg(dm, R_0x1d10, BIT(16)))
+			     odm_set_bb_reg(dm, R_0x1d10, BIT(16), 1);
+	#endif
+
+	if (pmac_tx->is_cck_rate) {
+		odm_set_bb_reg(dm, R_0x1e70, 0xf, 8); /* TX CCK ON */
+		odm_set_bb_reg(dm, R_0x1a84, BIT(31), 0);
+	} else {
+		odm_set_bb_reg(dm, R_0x1e70, 0xf, 4); /* TX Ofdm ON */
+	}
+
+	if (tx_info->mode == OFDM_SINGLE_TONE_TX)
+		phydm_set_single_tone_jgr3(dm, true, true, pmac_tx->path);
+}
+
+void phydm_set_pmac_tx_jgr3(void *dm_void, struct phydm_pmac_info *tx_info,
+			    enum rf_path mpt_rf_path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pmac_tx *pmac_tx = &dm->dm_pmac_tx_table;
+
+	pmac_tx->is_cck_rate = phydm_is_cck_rate(dm, tx_info->tx_rate);
+	pmac_tx->is_ofdm_rate = phydm_is_ofdm_rate(dm, tx_info->tx_rate);
+	pmac_tx->is_ht_rate = phydm_is_ht_rate(dm, tx_info->tx_rate);
+	pmac_tx->is_vht_rate = phydm_is_vht_rate(dm, tx_info->tx_rate);
+	pmac_tx->path = mpt_rf_path;
+
+	if (!tx_info->en_pmac_tx) {
+		phydm_stop_pmac_tx_jgr3(dm, tx_info);
+		return;
+	}
+
+	phydm_set_mode_jgr3(dm, tx_info, tx_info->mode);
+
+	if (pmac_tx->is_cck_rate)
+		phydm_set_cck_preamble_hdr_jgr3(dm, tx_info);
+	else
+		phydm_set_sig_jgr3(dm, tx_info);
+
+	phydm_set_mac_phy_txinfo_jgr3(dm, tx_info);
+	phydm_set_pmac_txon_jgr3(dm, tx_info);
+}
+
+void phydm_set_tmac_tx_jgr3(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	/* Turn on TMAC */
+	if (odm_get_bb_reg(dm, R_0x1d08, BIT(0)))
+		odm_set_bb_reg(dm, R_0x1d08, BIT(0), 0);
+
+	/* mac scramble seed setting, only in 8198F */
+	#if (RTL8198F_SUPPORT == 1)
+		if (dm->support_ic_type & ODM_RTL8198F)
+			if (odm_get_bb_reg(dm, R_0x1d10, BIT(16)))
+				odm_set_bb_reg(dm, R_0x1d10, BIT(16), 0);
+	#endif
+
+	/* Turn on TMAC CCK */
+	if ((odm_get_bb_reg(dm, R_0x1a84, BIT(31))) == 0)
+		odm_set_bb_reg(dm, R_0x1a84, BIT(31), 1);
+}
+#endif
+
+void phydm_start_cck_cont_tx(void *dm_void, struct phydm_pmac_info *tx_info)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_start_cck_cont_tx_jgr3(dm, tx_info);
+}
+
+void phydm_stop_cck_cont_tx(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_stop_cck_cont_tx_jgr3(dm);
+}
+
+void phydm_start_ofdm_cont_tx(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_start_ofdm_cont_tx_jgr3(dm);
+}
+
+void phydm_stop_ofdm_cont_tx(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_stop_ofdm_cont_tx_jgr3(dm);
+}
+
+void phydm_set_single_tone(void *dm_void, boolean is_single_tone,
+			   boolean en_pmac_tx, u8 path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_set_single_tone_jgr3(dm, is_single_tone,
+					   en_pmac_tx, path);
+}
+
+void phydm_set_pmac_tx(void *dm_void, struct phydm_pmac_info *tx_info,
+		       enum rf_path mpt_rf_path)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_set_pmac_tx_jgr3(dm, tx_info, mpt_rf_path);
+}
+
+void phydm_set_tmac_tx(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		phydm_set_tmac_tx_jgr3(dm);
+}
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pmac_tx_setting.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pmac_tx_setting.h
new file mode 100644
index 000000000000..0114eab69183
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pmac_tx_setting.h
@@ -0,0 +1,153 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
+ *
+ * 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.
+ *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
+ *****************************************************************************/
+
+#ifndef __PHYDM_PMAC_TX_SETTING_H__
+#define __PHYDM_PMAC_TX_SETTING_H__
+
+#define PMAC_TX_SETTING_VERSION "1.0"
+
+/* @1 ============================================================
+ * 1  Definition
+ * 1 ============================================================
+ */
+#define RANDOM_BY_PN32 0x12
+/* @1 ============================================================
+ * 1  structure
+ * 1 ============================================================
+ */
+struct phydm_pmac_info {
+	u8 en_pmac_tx:1; /*@ disable pmac 1: enable pmac */
+	u8 mode:3; /*@ 0: Packet TX 3:Continuous TX */
+	/* @u8 Ntx:4; */
+	u8 tx_rate; /* @should be HW rate*/
+	/* @u8 TX_RATE_HEX; */
+	u8 tx_sc;
+	/* @u8 bSGI:1; */
+	u8 is_short_preamble:1;
+	/* @u8 bSTBC:1; */
+	/* @u8 bLDPC:1; */
+	u8 ndp_sound:1;
+	u8 bw:3; /* @0:20 1:40 2:80Mhz */
+	u8 m_stbc; /* @bSTBC + 1 */
+	u16 packet_period;
+	u32 packet_count;
+	/* @u32 PacketLength; */
+	u8 packet_pattern;
+	u16 sfd;
+	u8 signal_field;
+	u8 service_field;
+	u16 length;
+	u8 crc16[2];
+	u8 lsig[3];
+	u8 ht_sig[6];
+	u8 vht_sig_a[6];
+	u8 vht_sig_b[4];
+	u8 vht_sig_b_crc;
+	u8 vht_delimiter[4];
+	/* @u8 mac_addr[6]; */
+};
+
+struct phydm_pmac_tx {
+	boolean is_cck_rate;
+	boolean is_ofdm_rate;
+	boolean is_ht_rate;
+	boolean is_vht_rate;
+	boolean cck_cont_tx;
+	boolean ofdm_cont_tx;
+	u8 path;
+	u32 tx_scailing;
+};
+
+/* @1 ============================================================
+ * 1  enumeration
+ * 1 ============================================================
+ */
+
+enum phydm_pmac_mode {
+	NONE_TEST,
+	PKTS_TX,
+	PKTS_RX,
+	CONT_TX,
+	OFDM_SINGLE_TONE_TX,
+	CCK_CARRIER_SIPPRESSION_TX
+};
+
+/* @1 ============================================================
+ * 1  function prototype
+ * 1 ============================================================
+ */
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+void phydm_start_cck_cont_tx_jgr3(void *dm_void,
+				  struct phydm_pmac_info *tx_info);
+
+void phydm_stop_cck_cont_tx_jgr3(void *dm_void);
+
+void phydm_start_ofdm_cont_tx_jgr3(void *dm_void);
+
+void phydm_stop_ofdm_cont_tx_jgr3(void *dm_void);
+
+void phydm_set_single_tone_jgr3(void *dm_void, boolean is_single_tone,
+				boolean en_pmac_tx, u8 path);
+
+void phydm_stop_pmac_tx_jgr3(void *dm_void, struct phydm_pmac_info *tx_info);
+
+void phydm_set_mac_phy_txinfo_jgr3(void *dm_void,
+				   struct phydm_pmac_info *tx_info);
+
+
+void phydm_set_sig_jgr3(void *dm_void, struct phydm_pmac_info *tx_info);
+
+void phydm_set_cck_preamble_hdr_jgr3(void *dm_void,
+				     struct phydm_pmac_info *tx_info);
+
+void phydm_set_mode_jgr3(void *dm_void, struct phydm_pmac_info *tx_info,
+			 enum phydm_pmac_mode mode);
+
+void phydm_set_pmac_txon_jgr3(void *dm_void, struct phydm_pmac_info *tx_info);
+
+void phydm_set_pmac_tx_jgr3(void *dm_void, struct phydm_pmac_info *tx_info,
+			    enum rf_path mpt_rf_path);
+
+void phydm_set_tmac_tx_jgr3(void *dm_void);
+#endif
+
+void phydm_start_cck_cont_tx(void *dm_void, struct phydm_pmac_info *tx_info);
+
+void phydm_stop_cck_cont_tx(void *dm_void);
+
+void phydm_start_ofdm_cont_tx(void *dm_void);
+
+void phydm_stop_ofdm_cont_tx(void *dm_void);
+
+void phydm_set_single_tone(void *dm_void, boolean is_single_tone,
+			   boolean en_pmac_tx, u8 path);
+
+void phydm_set_pmac_tx(void *dm_void, struct phydm_pmac_info *tx_info,
+		       enum rf_path mpt_rf_path);
+
+void phydm_set_tmac_tx(void *dm_void);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.c
index c361e32a8632..2da2e4bae5b4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,206 +9,164 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
 #ifdef PHYDM_POWER_TRAINING_SUPPORT
-void
-phydm_reset_pt_para(
-	void			*p_dm_void
-)
+void phydm_reset_pt_para(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pow_train_stuc	*p_pow_train_t = &(p_dm->pow_train_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc *pt_t = &dm->pow_train_table;
 
-	p_pow_train_t->pow_train_score = 0;
-	p_dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
-	p_dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+	pt_t->pow_train_score = 0;
 }
 
-void
-phydm_update_power_training_state(
-	void			*p_dm_void
-)
+void phydm_update_power_training_state(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pow_train_stuc	*p_pow_train_t = &(p_dm->pow_train_table);
-	struct phydm_fa_struct			*p_fa_cnt = &(p_dm->false_alm_cnt);
-	struct phydm_dig_struct		*p_dig_t = &p_dm->dm_dig_table;
-	u32	pt_score_tmp = 0;
-	u32 crc_ok_cnt;
-	u32 cca_all_cnt;
-
-
-	/*is_disable_power_training is the key to H2C to disable/enable power training*/
-	/*if is_disable_power_training == 1, it will use largest power*/
-	if (!(p_dm->support_ability & ODM_BB_PWR_TRAIN)) {
-		p_dm->is_disable_power_training = true;
-		phydm_reset_pt_para(p_dm);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc *pt_t = &dm->pow_train_table;
+	struct phydm_fa_struct *fa_cnt = &dm->false_alm_cnt;
+	struct ccx_info *ccx = &dm->dm_ccx_info;
+	u32 pt_score_tmp = ENABLE_PT_SCORE;
+	u32 crc_ok_cnt = 0;
+	u32 cca_cnt = 0;
+
+	/*@is_disable_power_training is the key to H2C to disable/enable PT*/
+	/*@if is_disable_power_training == 1, it will use largest power*/
+	if (!(dm->support_ability & ODM_BB_PWR_TRAIN) || !dm->is_linked) {
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
 		return;
 	}
 
-	PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("%s ======>\n", __FUNCTION__));
+	PHYDM_DBG(dm, DBG_PWR_TRAIN, "%s ======>\n", __func__);
 
-	if (p_pow_train_t->force_power_training_state == DISABLE_POW_TRAIN) {
-		
-		p_dm->is_disable_power_training = true;
-		phydm_reset_pt_para(p_dm);
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("Disable PT\n"));
+	if (pt_t->pt_state == DISABLE_POW_TRAIN) {
+		dm->is_disable_power_training = true;
+		phydm_reset_pt_para(dm);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Disable PT\n");
 		return;
 
-	} else if (p_pow_train_t->force_power_training_state == ENABLE_POW_TRAIN) {
-	
-		p_dm->is_disable_power_training = false;
-		phydm_reset_pt_para(p_dm);
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("Enable PT\n"));
+	} else if (pt_t->pt_state == ENABLE_POW_TRAIN) {
+		dm->is_disable_power_training = false;
+		phydm_reset_pt_para(dm);
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Enable PT\n");
 		return;
 
-	} else if (p_pow_train_t->force_power_training_state == DYNAMIC_POW_TRAIN) {
-
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("Dynamic PT\n"));
-
-		if (!p_dm->is_linked) {
-			p_dm->is_disable_power_training = true;
-			p_pow_train_t->pow_train_score = 0;
-			p_dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
-			p_dm->phy_dbg_info.num_qry_phy_status_cck = 0;
-
-			PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("PT is disabled due to no link.\n"));
-			return;
-		}
+	} else if (pt_t->pt_state == DYNAMIC_POW_TRAIN) {
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "Dynamic PT\n");
 
-		/* First connect */
-		if ((p_dm->is_linked) && (p_dig_t->is_media_connect == false)) {
-			p_pow_train_t->pow_train_score = 0;
-			p_dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
-			p_dm->phy_dbg_info.num_qry_phy_status_cck = 0;
-			PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("(PT)First Connect\n"));
+		/* @Compute score */
+		crc_ok_cnt = dm->phy_dbg_info.num_qry_phy_status_ofdm +
+			     dm->phy_dbg_info.num_qry_phy_status_cck;
+		cca_cnt = fa_cnt->cnt_cca_all;
+#if 0
+		if (crc_ok_cnt > cca_cnt) { /*invalid situation*/
+			pt_score_tmp = KEEP_PRE_PT_SCORE;
 			return;
-		}
-
-		/* Compute score */
-		crc_ok_cnt = p_dm->phy_dbg_info.num_qry_phy_status_ofdm + p_dm->phy_dbg_info.num_qry_phy_status_cck;
-		cca_all_cnt = p_fa_cnt->cnt_cca_all;
-
-		if (crc_ok_cnt < cca_all_cnt) {
-			/* crc_ok <= (2/3)*cca */
-			if ((crc_ok_cnt + (crc_ok_cnt >> 1)) <= cca_all_cnt)
-				pt_score_tmp = DISABLE_PT_SCORE;
-
-			/* crc_ok <= (4/5)*cca */
-			else if ((crc_ok_cnt + (crc_ok_cnt >> 2)) <= cca_all_cnt)
-				pt_score_tmp = KEEP_PRE_PT_SCORE;
-
-			/* crc_ok > (4/5)*cca */
-			else
-				pt_score_tmp = ENABLE_PT_SCORE;
+		} else if ((crc_ok_cnt + (crc_ok_cnt >> 1)) <= cca_cnt) {
+		/* @???crc_ok <= (2/3)*cca */
+			pt_score_tmp = DISABLE_PT_SCORE;
+			dm->is_disable_power_training = true;
+		} else if ((crc_ok_cnt + (crc_ok_cnt >> 2)) <= cca_cnt) {
+		/* @???crc_ok <= (4/5)*cca */
+			pt_score_tmp = KEEP_PRE_PT_SCORE;
 		} else {
+		/* @???crc_ok > (4/5)*cca */
 			pt_score_tmp = ENABLE_PT_SCORE;
+			dm->is_disable_power_training = false;
+		}
+#endif
+		if (ccx->nhm_ratio > 10) {
+			pt_score_tmp = DISABLE_PT_SCORE;
+			dm->is_disable_power_training = true;
+		} else if (ccx->nhm_ratio < 5) {
+			pt_score_tmp = ENABLE_PT_SCORE;
+			dm->is_disable_power_training = false;
+		} else {
+			pt_score_tmp = KEEP_PRE_PT_SCORE;
 		}
 
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("crc_ok_cnt = %d, cnt_cca_all = %d\n",
-				crc_ok_cnt, cca_all_cnt));
+		PHYDM_DBG(dm, DBG_PWR_TRAIN,
+			  "pkt_cnt{ofdm,cck,all} = {%d, %d, %d}, cnt_cca_all=%d\n",
+			  dm->phy_dbg_info.num_qry_phy_status_ofdm,
+			  dm->phy_dbg_info.num_qry_phy_status_cck,
+			  crc_ok_cnt, cca_cnt);
 
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("num_qry_phy_status_ofdm = %d, num_qry_phy_status_cck = %d\n",
-			p_dm->phy_dbg_info.num_qry_phy_status_ofdm, p_dm->phy_dbg_info.num_qry_phy_status_cck));
-		
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("pt_score_tmp = %d\n", pt_score_tmp));
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("pt_score_tmp = 0(DISABLE), 1(KEEP), 2(ENABLE)\n"));
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "pt_score_tmp=%d\n", pt_score_tmp);
 
 		/* smoothing */
-		p_pow_train_t->pow_train_score = (pt_score_tmp << 4) + (p_pow_train_t->pow_train_score >> 1) + (p_pow_train_t->pow_train_score >> 2);
-		pt_score_tmp = (p_pow_train_t->pow_train_score + 32) >> 6;
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("pow_train_score = %d, score after smoothing = %d\n",
-				p_pow_train_t->pow_train_score, pt_score_tmp));
-
-		/* mode decision */
-		if (pt_score_tmp == ENABLE_PT_SCORE) {
-			
-			p_dm->is_disable_power_training = false;
-			PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("Enable power training under dynamic.\n"));
-			
-		} else if (pt_score_tmp == DISABLE_PT_SCORE) {
-		
-			p_dm->is_disable_power_training = true;
-			PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("Disable PT due to noisy.\n"));
-		}
+		pt_t->pow_train_score = (pt_score_tmp << 4) +
+					(pt_t->pow_train_score >> 1) +
+					(pt_t->pow_train_score >> 2);
 
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("Final, score = %d, is_disable_power_training = %d\n",
-			pt_score_tmp, p_dm->is_disable_power_training));
+		pt_score_tmp = (pt_t->pow_train_score + 32) >> 6;
 
-		p_dm->phy_dbg_info.num_qry_phy_status_ofdm = 0;
-		p_dm->phy_dbg_info.num_qry_phy_status_cck = 0;
+		PHYDM_DBG(dm, DBG_PWR_TRAIN,
+			  "pow_train_score = %d, score after smoothing = %d, is_disable_PT = %d\n",
+			  pt_t->pow_train_score, pt_score_tmp,
+			  dm->is_disable_power_training);
 	} else {
-	
-		p_dm->is_disable_power_training = true;
-		phydm_reset_pt_para(p_dm);
-
-		PHYDM_DBG(p_dm, DBG_PWR_TRAIN, ("PT is disabled due to unknown pt state.\n"));
-		return;
+		PHYDM_DBG(dm, DBG_PWR_TRAIN, "[%s]warning\n", __func__);
 	}
 }
 
-void
-phydm_pow_train_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_pow_train_debug(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pow_train_stuc	*p_pow_train_t = &(p_dm->pow_train_table);
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u32		i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pow_train_stuc *pt_t = &dm->pow_train_table;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 i;
 
 	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "0: Dynamic state\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "1: Enable PT\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "2: Disable PT\n"));
-		
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{0: Auto PT, 1:enable, 2: disable}\n");
 	} else {
-
 		for (i = 0; i < 10; i++) {
-			if (input[i + 1]) {
+			if (input[i + 1])
 				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &var1[i]);
-			}
 		}
 
-		if (var1[0] == 0) {
-			p_pow_train_t->force_power_training_state = DYNAMIC_POW_TRAIN;
-			PHYDM_SNPRINTF((output + used, out_len - used, "Dynamic state\n"));
-		} else if (var1[0] == 1) {
-			p_pow_train_t->force_power_training_state = ENABLE_POW_TRAIN;
-			PHYDM_SNPRINTF((output + used, out_len - used, "Enable PT\n"));
-		} else if (var1[0] == 2) {
-			p_pow_train_t->force_power_training_state = DISABLE_POW_TRAIN;
-			PHYDM_SNPRINTF((output + used, out_len - used, "Disable PT\n"));
-		} else {
-			PHYDM_SNPRINTF((output + used, out_len - used, "Set Error\n"));
-		}		
+		if (var1[0] == 0)
+			pt_t->pt_state = DYNAMIC_POW_TRAIN;
+		else if (var1[0] == 1)
+			pt_t->pt_state = ENABLE_POW_TRAIN;
+		else if (var1[0] == 2)
+			pt_t->pt_state = DISABLE_POW_TRAIN;
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "PT state = %d\n", pt_t->pt_state);
 	}
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-
 #endif
-
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.h
index 8307890419b1..4458351703c7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pow_train.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,41 +9,51 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDM_POW_TRAIN_H__
+#define __PHYDM_POW_TRAIN_H__
 
-#ifndef	__PHYDM_POW_TRAIN_H__
-#define    __PHYDM_POW_TRAIN_H__
+#define POW_TRAIN_VERSION "1.0" /* @2017.07.0141  Dino, Add phydm_pow_train.h*/
 
-#define POW_TRAIN_VERSION	"1.0"		/* 2017.07.0141  Dino, Add phydm_pow_train.h*/
-
-
-/* 1 ============================================================
+/****************************************************************
+ * 1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
-
+ * 1 ============================================================
+ ***************************************************************/
 
 #ifdef PHYDM_POWER_TRAINING_SUPPORT
-/* 1 ============================================================
+/****************************************************************
+ * 1 ============================================================
  * 1  structure
- * 1 ============================================================ */
-
+ * 1 ============================================================
+ ***************************************************************/
 
 struct phydm_pow_train_stuc {
-
-	u8		force_power_training_state;
-	u32		pow_train_score;
+	u8 pt_state;
+	u32 pow_train_score;
 };
 
-/* 1 ============================================================
+/****************************************************************
+ * 1 ============================================================
  * 1  enumeration
- * 1 ============================================================ */
-
+ * 1 ============================================================
+ ***************************************************************/
 
-enum pow_train_state_e {
+enum pow_train_state {
 	DYNAMIC_POW_TRAIN = 0,
 	ENABLE_POW_TRAIN = 1,
 	DISABLE_POW_TRAIN = 2
@@ -54,24 +65,21 @@ enum power_training_score {
 	ENABLE_PT_SCORE = 2
 };
 
-/* 1 ============================================================
+/****************************************************************
+ * 1 ============================================================
  * 1  function prototype
- * 1 ============================================================ */
-
-void
-phydm_update_power_training_state(
-	void		*p_dm_void
-);
-
-void
-phydm_pow_train_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
+ * 1 ============================================================
+ ***************************************************************/
+
+void phydm_update_power_training_state(
+	void *dm_void);
+
+void phydm_pow_train_debug(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len);
 
 #endif
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pre_define.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pre_define.h
index 17e2285516dc..802872223d95 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pre_define.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_pre_define.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,32 +9,43 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDMPREDEFINE_H__
+#define __PHYDMPREDEFINE_H__
 
-#ifndef	__PHYDMPREDEFINE_H__
-#define    __PHYDMPREDEFINE_H__
-
-/* 1 ============================================================
+/****************************************************************
+ * 1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
+ * 1 ============================================================
+ ***************************************************************/
 
-#define PHYDM_CODE_BASE		"PHYDM_V021"
-#define PHYDM_RELEASE_DATE		"20170801"
+#define PHYDM_CODE_BASE			"PHYDM_V033"
+#define PHYDM_RELEASE_DATE		"20180906.0"
 
 /*PHYDM API status*/
-#define	PHYDM_SET_FAIL		0
-#define	PHYDM_SET_SUCCESS	1
-#define	PHYDM_SET_NO_NEED	3
+#define	PHYDM_SET_FAIL			0
+#define	PHYDM_SET_SUCCESS		1
+#define	PHYDM_SET_NO_NEED		3
 
 /*PHYDM Set/Revert*/
-#define	PHYDM_SET				1
+#define	PHYDM_SET			1
 #define	PHYDM_REVERT			2
 
-/* Max path of IC */
+/* @Max path of IC */
 /*N-IC*/
 #define MAX_PATH_NUM_8188E		1
 #define MAX_PATH_NUM_8188F		1
@@ -42,41 +54,61 @@
 #define MAX_PATH_NUM_8723D		1
 #define MAX_PATH_NUM_8703B		1
 #define MAX_PATH_NUM_8192E		2
+#define MAX_PATH_NUM_8192F		2
 #define MAX_PATH_NUM_8197F		2
 #define MAX_PATH_NUM_8198F		4
-/*AC-IC*/
+#define MAX_PATH_NUM_8197G		2
+#define MAX_PATH_NUM_8721D		1
+/*@AC-IC*/
 #define MAX_PATH_NUM_8821A		1
+#define MAX_PATH_NUM_8881A		1
 #define MAX_PATH_NUM_8821C		1
+#define MAX_PATH_NUM_8195B		1
 #define MAX_PATH_NUM_8812A		2
 #define MAX_PATH_NUM_8822B		2
+#define MAX_PATH_NUM_8822C		2
 #define MAX_PATH_NUM_8814A		4
 #define MAX_PATH_NUM_8814B		4
+#define MAX_PATH_NUM_8814C		4
+#define MAX_PATH_NUM_8195B		1
+#define MAX_PATH_NUM_8812F		2
 
-/* Max RF path */
-#define ODM_RF_PATH_MAX 2
-#define ODM_RF_PATH_MAX_JAGUAR 4
+/* @Max RF path */
+#define PHYDM_MAX_RF_PATH_N		2	/*@For old N-series IC*/
 #define PHYDM_MAX_RF_PATH		4
 
 /* number of entry */
 #if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
 	#ifdef DM_ODM_CE_MAC80211
-		/* defined in wifi.h (32+1) */
+		/* @defined in wifi.h (32+1) */
 	#else
-		#define	ASSOCIATE_ENTRY_NUM					MACID_NUM_SW_LIMIT  /* Max size of asoc_entry[].*/
+		#define	ASSOCIATE_ENTRY_NUM	MACID_NUM_SW_LIMIT  /* @Max size of asoc_entry[].*/
 	#endif
-	#define	ODM_ASSOCIATE_ENTRY_NUM				ASSOCIATE_ENTRY_NUM
+	#define	ODM_ASSOCIATE_ENTRY_NUM	ASSOCIATE_ENTRY_NUM
 #elif(DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	#define ASSOCIATE_ENTRY_NUM					NUM_STAT
-	#define	ODM_ASSOCIATE_ENTRY_NUM				(ASSOCIATE_ENTRY_NUM+1)
+	#define ASSOCIATE_ENTRY_NUM	NUM_STAT
+	#define	ODM_ASSOCIATE_ENTRY_NUM	(ASSOCIATE_ENTRY_NUM + 1)
+#elif(DM_ODM_SUPPORT_TYPE & (ODM_IOT))
+	#ifdef CONFIG_CONCURRENT_MODE
+		#define ASSOCIATE_ENTRY_NUM	NUM_STA + 2 /*@2 is for station mod*/
+	#else
+		#define ASSOCIATE_ENTRY_NUM	NUM_STA /*@8 is for max size of asoc_entry[].*/
+	#endif
+	#define	ODM_ASSOCIATE_ENTRY_NUM	ASSOCIATE_ENTRY_NUM
 #else
-	#define ODM_ASSOCIATE_ENTRY_NUM				((ASSOCIATE_ENTRY_NUM*3)+1)
+	#define ODM_ASSOCIATE_ENTRY_NUM	(((ASSOCIATE_ENTRY_NUM + 1) * 3) + 1)
 #endif
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	#define RX_SMOOTH_FACTOR	20
-#endif
+/* @-----MGN rate--------------------------------- */
 
-/* -----MGN rate--------------------------------- */
+enum PDM_RATE_TYPE {
+	PDM_1SS			= 1,	/*VHT/HT 1SS*/
+	PDM_2SS			= 2,	/*VHT/HT 2SS*/
+	PDM_3SS			= 3,	/*VHT/HT 3SS*/
+	PDM_4SS			= 4,	/*VHT/HT 4SS*/
+	PDM_CCK			= 11,	/*@B*/
+	PDM_OFDM		= 12	/*@G*/
+};
 
 enum ODM_MGN_RATE {
 	ODM_MGN_1M		= 0x02,
@@ -177,131 +209,123 @@ enum ODM_MGN_RATE {
 #define	ODM_MGN_MCS7_SG		0xc7
 #define	ODM_MGN_MCS8_SG		0xc8
 #define	ODM_MGN_MCS9_SG		0xc9
-#define	ODM_MGN_MCS10_SG		0xca
-#define	ODM_MGN_MCS11_SG		0xcb
-#define	ODM_MGN_MCS12_SG		0xcc
-#define	ODM_MGN_MCS13_SG		0xcd
-#define	ODM_MGN_MCS14_SG		0xce
-#define	ODM_MGN_MCS15_SG		0xcf
-
-/* -----DESC rate--------------------------------- */
+#define	ODM_MGN_MCS10_SG	0xca
+#define	ODM_MGN_MCS11_SG	0xcb
+#define	ODM_MGN_MCS12_SG	0xcc
+#define	ODM_MGN_MCS13_SG	0xcd
+#define	ODM_MGN_MCS14_SG	0xce
+#define	ODM_MGN_MCS15_SG	0xcf
 
-#define ODM_RATEMCS15_SG		0x1c
-#define ODM_RATEMCS32			0x20
+/* @-----DESC rate--------------------------------- */
 
+#define ODM_RATEMCS15_SG	0x1c
+#define ODM_RATEMCS32		0x20
 
 enum phydm_ctrl_info_rate {
-	ODM_RATE1M				= 0x00,
-	ODM_RATE2M				= 0x01,
-	ODM_RATE5_5M			= 0x02,
-	ODM_RATE11M			= 0x03,
+	ODM_RATE1M		= 0x00,
+	ODM_RATE2M		= 0x01,
+	ODM_RATE5_5M		= 0x02,
+	ODM_RATE11M		= 0x03,
 /* OFDM Rates, TxHT = 0 */
-	ODM_RATE6M				= 0x04,
-	ODM_RATE9M				= 0x05,
-	ODM_RATE12M			= 0x06,
-	ODM_RATE18M			= 0x07,
-	ODM_RATE24M			= 0x08,
-	ODM_RATE36M			= 0x09,
-	ODM_RATE48M			= 0x0A,
-	ODM_RATE54M			= 0x0B,
-/* MCS Rates, TxHT = 1 */
-	ODM_RATEMCS0			= 0x0C,
-	ODM_RATEMCS1			= 0x0D,
-	ODM_RATEMCS2			= 0x0E,
-	ODM_RATEMCS3			= 0x0F,
-	ODM_RATEMCS4			= 0x10,
-	ODM_RATEMCS5			= 0x11,
-	ODM_RATEMCS6			= 0x12,
-	ODM_RATEMCS7			= 0x13,
-	ODM_RATEMCS8			= 0x14,
-	ODM_RATEMCS9			= 0x15,
-	ODM_RATEMCS10			= 0x16,
-	ODM_RATEMCS11			= 0x17,
-	ODM_RATEMCS12			= 0x18,
-	ODM_RATEMCS13			= 0x19,
-	ODM_RATEMCS14			= 0x1A,
-	ODM_RATEMCS15			= 0x1B,
-	ODM_RATEMCS16			= 0x1C,
-	ODM_RATEMCS17			= 0x1D,
-	ODM_RATEMCS18			= 0x1E,
-	ODM_RATEMCS19			= 0x1F,
-	ODM_RATEMCS20			= 0x20,
-	ODM_RATEMCS21			= 0x21,
-	ODM_RATEMCS22			= 0x22,
-	ODM_RATEMCS23			= 0x23,
-	ODM_RATEMCS24			= 0x24,
-	ODM_RATEMCS25			= 0x25,
-	ODM_RATEMCS26			= 0x26,
-	ODM_RATEMCS27			= 0x27,
-	ODM_RATEMCS28			= 0x28,
-	ODM_RATEMCS29			= 0x29,
-	ODM_RATEMCS30			= 0x2A,
-	ODM_RATEMCS31			= 0x2B,
-	ODM_RATEVHTSS1MCS0		= 0x2C,
-	ODM_RATEVHTSS1MCS1		= 0x2D,
-	ODM_RATEVHTSS1MCS2		= 0x2E,
-	ODM_RATEVHTSS1MCS3		= 0x2F,
-	ODM_RATEVHTSS1MCS4		= 0x30,
-	ODM_RATEVHTSS1MCS5		= 0x31,
-	ODM_RATEVHTSS1MCS6		= 0x32,
-	ODM_RATEVHTSS1MCS7		= 0x33,
-	ODM_RATEVHTSS1MCS8		= 0x34,
-	ODM_RATEVHTSS1MCS9		= 0x35,
-	ODM_RATEVHTSS2MCS0		= 0x36,
-	ODM_RATEVHTSS2MCS1		= 0x37,
-	ODM_RATEVHTSS2MCS2		= 0x38,
-	ODM_RATEVHTSS2MCS3		= 0x39,
-	ODM_RATEVHTSS2MCS4		= 0x3A,
-	ODM_RATEVHTSS2MCS5		= 0x3B,
-	ODM_RATEVHTSS2MCS6		= 0x3C,
-	ODM_RATEVHTSS2MCS7		= 0x3D,
-	ODM_RATEVHTSS2MCS8		= 0x3E,
-	ODM_RATEVHTSS2MCS9		= 0x3F,
-	ODM_RATEVHTSS3MCS0		= 0x40,
-	ODM_RATEVHTSS3MCS1		= 0x41,
-	ODM_RATEVHTSS3MCS2		= 0x42,
-	ODM_RATEVHTSS3MCS3		= 0x43,
-	ODM_RATEVHTSS3MCS4		= 0x44,
-	ODM_RATEVHTSS3MCS5		= 0x45,
-	ODM_RATEVHTSS3MCS6		= 0x46,
-	ODM_RATEVHTSS3MCS7		= 0x47,
-	ODM_RATEVHTSS3MCS8		= 0x48,
-	ODM_RATEVHTSS3MCS9		= 0x49,
-	ODM_RATEVHTSS4MCS0		= 0x4A,
-	ODM_RATEVHTSS4MCS1		= 0x4B,
-	ODM_RATEVHTSS4MCS2		= 0x4C,
-	ODM_RATEVHTSS4MCS3		= 0x4D,
-	ODM_RATEVHTSS4MCS4		= 0x4E,
-	ODM_RATEVHTSS4MCS5		= 0x4F,
-	ODM_RATEVHTSS4MCS6		= 0x50,
-	ODM_RATEVHTSS4MCS7		= 0x51,
-	ODM_RATEVHTSS4MCS8		= 0x52,
-	ODM_RATEVHTSS4MCS9		= 0x53,
+	ODM_RATE6M		= 0x04,
+	ODM_RATE9M		= 0x05,
+	ODM_RATE12M		= 0x06,
+	ODM_RATE18M		= 0x07,
+	ODM_RATE24M		= 0x08,
+	ODM_RATE36M		= 0x09,
+	ODM_RATE48M		= 0x0A,
+	ODM_RATE54M		= 0x0B,
+/* @MCS Rates, TxHT = 1 */
+	ODM_RATEMCS0		= 0x0C,
+	ODM_RATEMCS1		= 0x0D,
+	ODM_RATEMCS2		= 0x0E,
+	ODM_RATEMCS3		= 0x0F,
+	ODM_RATEMCS4		= 0x10,
+	ODM_RATEMCS5		= 0x11,
+	ODM_RATEMCS6		= 0x12,
+	ODM_RATEMCS7		= 0x13,
+	ODM_RATEMCS8		= 0x14,
+	ODM_RATEMCS9		= 0x15,
+	ODM_RATEMCS10		= 0x16,
+	ODM_RATEMCS11		= 0x17,
+	ODM_RATEMCS12		= 0x18,
+	ODM_RATEMCS13		= 0x19,
+	ODM_RATEMCS14		= 0x1A,
+	ODM_RATEMCS15		= 0x1B,
+	ODM_RATEMCS16		= 0x1C,
+	ODM_RATEMCS17		= 0x1D,
+	ODM_RATEMCS18		= 0x1E,
+	ODM_RATEMCS19		= 0x1F,
+	ODM_RATEMCS20		= 0x20,
+	ODM_RATEMCS21		= 0x21,
+	ODM_RATEMCS22		= 0x22,
+	ODM_RATEMCS23		= 0x23,
+	ODM_RATEMCS24		= 0x24,
+	ODM_RATEMCS25		= 0x25,
+	ODM_RATEMCS26		= 0x26,
+	ODM_RATEMCS27		= 0x27,
+	ODM_RATEMCS28		= 0x28,
+	ODM_RATEMCS29		= 0x29,
+	ODM_RATEMCS30		= 0x2A,
+	ODM_RATEMCS31		= 0x2B,
+	ODM_RATEVHTSS1MCS0	= 0x2C,
+	ODM_RATEVHTSS1MCS1	= 0x2D,
+	ODM_RATEVHTSS1MCS2	= 0x2E,
+	ODM_RATEVHTSS1MCS3	= 0x2F,
+	ODM_RATEVHTSS1MCS4	= 0x30,
+	ODM_RATEVHTSS1MCS5	= 0x31,
+	ODM_RATEVHTSS1MCS6	= 0x32,
+	ODM_RATEVHTSS1MCS7	= 0x33,
+	ODM_RATEVHTSS1MCS8	= 0x34,
+	ODM_RATEVHTSS1MCS9	= 0x35,
+	ODM_RATEVHTSS2MCS0	= 0x36,
+	ODM_RATEVHTSS2MCS1	= 0x37,
+	ODM_RATEVHTSS2MCS2	= 0x38,
+	ODM_RATEVHTSS2MCS3	= 0x39,
+	ODM_RATEVHTSS2MCS4	= 0x3A,
+	ODM_RATEVHTSS2MCS5	= 0x3B,
+	ODM_RATEVHTSS2MCS6	= 0x3C,
+	ODM_RATEVHTSS2MCS7	= 0x3D,
+	ODM_RATEVHTSS2MCS8	= 0x3E,
+	ODM_RATEVHTSS2MCS9	= 0x3F,
+	ODM_RATEVHTSS3MCS0	= 0x40,
+	ODM_RATEVHTSS3MCS1	= 0x41,
+	ODM_RATEVHTSS3MCS2	= 0x42,
+	ODM_RATEVHTSS3MCS3	= 0x43,
+	ODM_RATEVHTSS3MCS4	= 0x44,
+	ODM_RATEVHTSS3MCS5	= 0x45,
+	ODM_RATEVHTSS3MCS6	= 0x46,
+	ODM_RATEVHTSS3MCS7	= 0x47,
+	ODM_RATEVHTSS3MCS8	= 0x48,
+	ODM_RATEVHTSS3MCS9	= 0x49,
+	ODM_RATEVHTSS4MCS0	= 0x4A,
+	ODM_RATEVHTSS4MCS1	= 0x4B,
+	ODM_RATEVHTSS4MCS2	= 0x4C,
+	ODM_RATEVHTSS4MCS3	= 0x4D,
+	ODM_RATEVHTSS4MCS4	= 0x4E,
+	ODM_RATEVHTSS4MCS5	= 0x4F,
+	ODM_RATEVHTSS4MCS6	= 0x50,
+	ODM_RATEVHTSS4MCS7	= 0x51,
+	ODM_RATEVHTSS4MCS8	= 0x52,
+	ODM_RATEVHTSS4MCS9	= 0x53,
 };
 
-#define	CCK_RATE_NUM		4
-#define	OFDM_RATE_NUM	8
-
-#define	LEGACY_RATE_NUM	12
-
-#define	HT_RATE_NUM		32
-#define	VHT_RATE_NUM		40
-
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
+	#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9 + 1)
 #else
-	#if (RTL8192E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEMCS15+1)
-	#elif (RTL8723B_SUPPORT == 1) || (RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEMCS7+1)
-	#elif (RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS1MCS9+1)
-	#elif (RTL8812A_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS2MCS9+1)
-	#elif (RTL8814A_SUPPORT == 1)
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS3MCS9+1)
+	#if (RTL8192E_SUPPORT || RTL8197F_SUPPORT || RTL8192F_SUPPORT)
+		#define ODM_NUM_RATE_IDX (ODM_RATEMCS15 + 1)
+	#elif (RTL8723B_SUPPORT || RTL8188E_SUPPORT || \
+	       RTL8188F_SUPPORT || RTL8721D_SUPPORT)
+		#define ODM_NUM_RATE_IDX (ODM_RATEMCS7 + 1)
+	#elif (RTL8821A_SUPPORT || RTL8881A_SUPPORT)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS1MCS9 + 1)
+	#elif (RTL8812A_SUPPORT)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS2MCS9 + 1)
+	#elif (RTL8814A_SUPPORT)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS3MCS9 + 1)
 	#else
-		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9+1)
+		#define ODM_NUM_RATE_IDX (ODM_RATEVHTSS4MCS9 + 1)
 	#endif
 #endif
 
@@ -309,21 +333,23 @@ enum phydm_ctrl_info_rate {
 	#define CONFIG_SFW_SUPPORTED
 #endif
 
-/* 1 ============================================================
+/****************************************************************
+ * 1 ============================================================
  * 1  enumeration
- * 1 ============================================================ */
-
+ * 1 ============================================================
+ ***************************************************************/
 
 /*	ODM_CMNINFO_INTERFACE */
-enum odm_interface_e {
+enum odm_interface {
 	ODM_ITRF_PCIE	=	0x1,
 	ODM_ITRF_USB	=	0x2,
 	ODM_ITRF_SDIO	=	0x4,
 	ODM_ITRF_ALL	=	0x7,
 };
 
+/*@========[Run time IC flag] ===================================*/
 
-enum phydm_ic_e {
+enum phydm_ic {
 	ODM_RTL8188E	=	BIT(0),
 	ODM_RTL8812	=	BIT(1),
 	ODM_RTL8821	=	BIT(2),
@@ -342,114 +368,173 @@ enum phydm_ic_e {
 	ODM_RTL8198F	=	BIT(15),
 	ODM_RTL8710B	=	BIT(16),
 	ODM_RTL8192F	=	BIT(17),
-	ODM_RTL8822C	=	BIT(18)
+	ODM_RTL8822C	=	BIT(18),
+	ODM_RTL8195B	=	BIT(19),
+	ODM_RTL8812F	=	BIT(20),
+	ODM_RTL8197G	=	BIT(21),
+	ODM_RTL8721D	=	BIT(22)
 };
 
-/*========[Run time IC flag] ===============================================================================]*/
-
-#define ODM_IC_N_1SS	(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8723B | ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8195A | ODM_RTL8710B)
-#define ODM_IC_N_2SS	(ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8192F)
-#define ODM_IC_N_3SS	0
-#define ODM_IC_N_4SS	(ODM_RTL8198F)
-
-#define ODM_IC_AC_1SS	(ODM_RTL8881A | ODM_RTL8821 | ODM_RTL8821C)
-#define ODM_IC_AC_2SS	(ODM_RTL8812 | ODM_RTL8822B | ODM_RTL8822C)
-#define ODM_IC_AC_3SS	0
-#define ODM_IC_AC_4SS	(ODM_RTL8814A | ODM_RTL8814B)
-
-/*====the following macro DO NOT need to update when add a new IC======= */
-#define ODM_IC_1SS	(ODM_IC_N_1SS | ODM_IC_AC_1SS)
-#define ODM_IC_2SS	(ODM_IC_N_2SS | ODM_IC_AC_2SS)
-#define ODM_IC_3SS	(ODM_IC_N_3SS | ODM_IC_AC_3SS)
-#define ODM_IC_4SS	(ODM_IC_N_4SS | ODM_IC_AC_4SS)
-
-#define PHYDM_IC_ABOVE_1SS	(ODM_IC_1SS | ODM_IC_2SS | ODM_IC_3SS | ODM_IC_4SS)
+#define ODM_IC_N_1SS		(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8723B |\
+				 ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8195A |\
+				 ODM_RTL8710B | ODM_RTL8721D)
+#define ODM_IC_N_2SS		(ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8192F)
+#define ODM_IC_N_3SS		0
+#define ODM_IC_N_4SS		0
+
+#define ODM_IC_AC_1SS		(ODM_RTL8881A | ODM_RTL8821 | ODM_RTL8821C |\
+				 ODM_RTL8195B)
+#define ODM_IC_AC_2SS		(ODM_RTL8812 | ODM_RTL8822B)
+#define ODM_IC_AC_3SS		0
+#define ODM_IC_AC_4SS		(ODM_RTL8814A)
+
+#define ODM_IC_JGR3_1SS		0
+#define ODM_IC_JGR3_2SS		(ODM_RTL8822C | ODM_RTL8812F | ODM_RTL8197G)
+#define ODM_IC_JGR3_3SS		0
+#define ODM_IC_JGR3_4SS		(ODM_RTL8198F | ODM_RTL8814B)
+
+/*@====the following macro DO NOT need to update when adding a new IC======= */
+#define ODM_IC_1SS		(ODM_IC_N_1SS | ODM_IC_AC_1SS | ODM_IC_JGR3_1SS)
+#define ODM_IC_2SS		(ODM_IC_N_2SS | ODM_IC_AC_2SS | ODM_IC_JGR3_2SS)
+#define ODM_IC_3SS		(ODM_IC_N_3SS | ODM_IC_AC_3SS | ODM_IC_JGR3_3SS)
+#define ODM_IC_4SS		(ODM_IC_N_4SS | ODM_IC_AC_4SS | ODM_IC_JGR3_4SS)
+
+#define PHYDM_IC_ABOVE_1SS	(ODM_IC_1SS | ODM_IC_2SS | ODM_IC_3SS |\
+				 ODM_IC_4SS)
 #define PHYDM_IC_ABOVE_2SS	(ODM_IC_2SS | ODM_IC_3SS | ODM_IC_4SS)
 #define PHYDM_IC_ABOVE_3SS	(ODM_IC_3SS | ODM_IC_4SS)
 #define PHYDM_IC_ABOVE_4SS	ODM_IC_4SS
 
-#define ODM_IC_11N_SERIES		(ODM_IC_N_1SS | ODM_IC_N_2SS | ODM_IC_N_3SS | ODM_IC_N_4SS)
-#define ODM_IC_11AC_SERIES		(ODM_IC_AC_1SS | ODM_IC_AC_2SS | ODM_IC_AC_3SS | ODM_IC_AC_4SS)
-/*====================================================*/
-
-#define ODM_IC_11AC_1_SERIES		(ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)
-#define ODM_IC_11AC_2_SERIES		(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)
-
-#define ODM_IC_TXBF_SUPPORT		(ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8881A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)
-
-#define ODM_IC_11N_GAIN_IDX_EDCCA		(ODM_RTL8195A | ODM_RTL8703B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8197F | ODM_RTL8710B)
-#define ODM_IC_11AC_GAIN_IDX_EDCCA		(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)
-#define ODM_IC_GAIN_IDX_EDCCA				(ODM_IC_11N_GAIN_IDX_EDCCA | ODM_IC_11AC_GAIN_IDX_EDCCA)
-
-#define ODM_IC_PHY_STATUE_NEW_TYPE		(ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B)
-
-#define PHYDM_IC_8051_SERIES		(ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8703B | ODM_RTL8188F)
-#define PHYDM_IC_3081_SERIES		(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)
-
-#define PHYDM_IC_SUPPORT_LA_MODE	(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8821C)
-#define PHYDM_IC_SUPPORT_MU_BFEE	(ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814B)
-#define PHYDM_IC_SUPPORT_MU_BFER	(ODM_RTL8822B | ODM_RTL8814B)
-
+#define ODM_IC_11N_SERIES	(ODM_IC_N_1SS | ODM_IC_N_2SS | ODM_IC_N_3SS |\
+				 ODM_IC_N_4SS)
+#define ODM_IC_11AC_SERIES	(ODM_IC_AC_1SS | ODM_IC_AC_2SS |\
+				 ODM_IC_AC_3SS | ODM_IC_AC_4SS)
+#define ODM_IC_JGR3_SERIES	(ODM_IC_JGR3_1SS | ODM_IC_JGR3_2SS |\
+				 ODM_IC_JGR3_3SS | ODM_IC_JGR3_4SS)
+/*@====================================================*/
+
+#define ODM_IC_11AC_1_SERIES	(ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8881A)
+#define ODM_IC_11AC_2_SERIES	(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C |\
+				 ODM_RTL8195B)
+
+/*@[Phy status type]*/
+#define PHYSTS_2ND_TYPE_IC	(ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8723D |\
+				 ODM_RTL8821C | ODM_RTL8710B | ODM_RTL8195B |\
+				 ODM_RTL8192F | ODM_RTL8721D)
+#define PHYSTS_3RD_TYPE_IC	(ODM_RTL8198F | ODM_RTL8814B | ODM_RTL8822C |\
+				 ODM_RTL8812F | ODM_RTL8197G)
+/*@[FW Type]*/
+#define PHYDM_IC_8051_SERIES	(ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821 |\
+				 ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8703B |\
+				 ODM_RTL8188F | ODM_RTL8192F | ODM_RTL8721D)
+#define PHYDM_IC_3081_SERIES	(ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F |\
+				 ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F |\
+				 ODM_RTL8822C | ODM_RTL8812F | ODM_RTL8814B |\
+				 ODM_RTL8197G)
+/*@[LA mode]*/
+#define PHYDM_IC_SUPPORT_LA_MODE (ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8197F |\
+				  ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8198F |\
+				  ODM_RTL8192F | ODM_RTL8822C | ODM_RTL8812F |\
+				  ODM_RTL8195B | ODM_RTL8814B | ODM_RTL8197G)
+/*@[BF]*/
+#define ODM_IC_TXBF_SUPPORT	(ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8821 |\
+				 ODM_RTL8814A | ODM_RTL8881A | ODM_RTL8822B |\
+				 ODM_RTL8197F | ODM_RTL8821C | ODM_RTL8195B |\
+				 ODM_RTL8198F | ODM_RTL8822C | ODM_RTL8812F |\
+				 ODM_RTL8814B | ODM_RTL8197G)
+#define PHYDM_IC_SUPPORT_MU_BFEE (ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8814B |\
+				  ODM_RTL8195B | ODM_RTL8198F | ODM_RTL8822C |\
+				  ODM_RTL8812F)
+#define PHYDM_IC_SUPPORT_MU_BFER (ODM_RTL8822B | ODM_RTL8814B | ODM_RTL8198F |\
+				  ODM_RTL8822C | ODM_RTL8812F)
+
+#define PHYDM_IC_SUPPORT_MU (PHYDM_IC_SUPPORT_MU_BFEE |\
+				PHYDM_IC_SUPPORT_MU_BFER)
+/*@[PHYDM API]*/
+#define CMN_API_SUPPORT_IC (ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8192F |\
+			    ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8822C |\
+			    ODM_RTL8198F | ODM_RTL8812F | ODM_RTL8814B |\
+			    ODM_RTL8197G | ODM_RTL8721D)
+
+/*@========[Compile time IC flag] ========================*/
+/*@========[AC-3/AC/N Support] ===========================*/
+
+#if (RTL8814B_SUPPORT || RTL8198F_SUPPORT || RTL8822C_SUPPORT ||\
+	RTL8812F_SUPPORT || RTL8197G_SUPPORT)
+	#define PHYDM_IC_JGR3_SERIES_SUPPORT
+	#if (RTL8814B_SUPPORT || RTL8822C_SUPPORT || RTL8812F_SUPPORT)
+		#define PHYDM_IC_JGR3_80M_SUPPORT
+	#endif
+#endif
 
-/*========[Compile time IC flag] ===============================================================================]*/
-/*========[AC/N Support] ===========================*/
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
 	#ifdef RTK_AC_SUPPORT
-	#define ODM_IC_11AC_SERIES_SUPPORT		1
+	#define ODM_IC_11AC_SERIES_SUPPORT	1
 	#else
-	#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#define ODM_IC_11AC_SERIES_SUPPORT	0
 	#endif
 
-	#define ODM_IC_11N_SERIES_SUPPORT			1
+	#define ODM_IC_11N_SERIES_SUPPORT	1
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-	#define ODM_IC_11AC_SERIES_SUPPORT		1
-	#define ODM_IC_11N_SERIES_SUPPORT			1
+	#define ODM_IC_11AC_SERIES_SUPPORT	1
+	#define ODM_IC_11N_SERIES_SUPPORT	1
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
 
+	#define ODM_IC_11AC_SERIES_SUPPORT	1
+	#define ODM_IC_11N_SERIES_SUPPORT	1
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+
 	#define ODM_IC_11AC_SERIES_SUPPORT		1
 	#define ODM_IC_11N_SERIES_SUPPORT			1
 
 #else /*ODM_CE*/
 
-	#if ((RTL8188E_SUPPORT == 1) || \
-	(RTL8723B_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8195A_SUPPORT == 1) || (RTL8703B_SUPPORT == 1) || \
-	(RTL8188F_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
-		#define ODM_IC_11N_SERIES_SUPPORT			1
-		#define ODM_IC_11AC_SERIES_SUPPORT		0
+	#if (RTL8188E_SUPPORT || RTL8723B_SUPPORT || RTL8192E_SUPPORT ||\
+	     RTL8195A_SUPPORT || RTL8703B_SUPPORT || RTL8188F_SUPPORT ||\
+	     RTL8723D_SUPPORT || RTL8197F_SUPPORT || RTL8710B_SUPPORT ||\
+	     RTL8192F_SUPPORT || RTL8721D_SUPPORT)
+		#define ODM_IC_11N_SERIES_SUPPORT	1
+		#define ODM_IC_11AC_SERIES_SUPPORT	0
 	#else
-		#define ODM_IC_11N_SERIES_SUPPORT			0
-		#define ODM_IC_11AC_SERIES_SUPPORT		1
+		#define ODM_IC_11N_SERIES_SUPPORT	0
+		#define ODM_IC_11AC_SERIES_SUPPORT	1
 	#endif
 #endif
 
-/*===IC SS Compile Flag, prepare for code size reduction==============*/
-#if ((RTL8188E_SUPPORT == 1) || (RTL8188F_SUPPORT == 1) || (RTL8723B_SUPPORT == 1) || (RTL8703B_SUPPORT == 1) ||\
-	(RTL8723D_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) ||\
-	(RTL8195A_SUPPORT == 1) || (RTL8710B_SUPPORT == 1))
-	
+/*@===IC SS Compile Flag, prepare for code size reduction==============*/
+#if (RTL8188E_SUPPORT || RTL8188F_SUPPORT || RTL8723B_SUPPORT ||\
+	RTL8703B_SUPPORT || RTL8723D_SUPPORT || RTL8881A_SUPPORT ||\
+	RTL8821A_SUPPORT || RTL8821C_SUPPORT || RTL8195A_SUPPORT ||\
+	RTL8710B_SUPPORT || RTL8195B_SUPPORT || RTL8721D_SUPPORT)
+
 	#define PHYDM_COMPILE_IC_1SS
 #endif
 
-#if ((RTL8192E_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8822B_SUPPORT == 1))
+#if (RTL8192E_SUPPORT || RTL8197F_SUPPORT || RTL8812A_SUPPORT ||\
+	RTL8822B_SUPPORT || RTL8192F_SUPPORT || RTL8822C_SUPPORT ||\
+	RTL8812F_SUPPORT || RTL8197G_SUPPORT)
 	#define PHYDM_COMPILE_IC_2SS
 #endif
 
-/*#define PHYDM_COMPILE_IC_3SS*/
+/*@#define PHYDM_COMPILE_IC_3SS*/
 
-#if ((RTL8814B_SUPPORT == 1) || (RTL8814A_SUPPORT == 1))
+#if ((RTL8814B_SUPPORT) || (RTL8814A_SUPPORT) || (RTL8198F_SUPPORT))
 	#define PHYDM_COMPILE_IC_4SS
 #endif
 
-/*==[ABOVE N-SS COMPILE FLAG]=============================*/
-#if (defined(PHYDM_COMPILE_IC_1SS) || defined(PHYDM_COMPILE_IC_2SS) || defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+/*@==[ABOVE N-SS COMPILE FLAG]=================================================*/
+#if (defined(PHYDM_COMPILE_IC_1SS) || defined(PHYDM_COMPILE_IC_2SS) ||\
+	defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
 	#define PHYDM_COMPILE_ABOVE_1SS
 #endif
 
-#if (defined(PHYDM_COMPILE_IC_2SS) || defined(PHYDM_COMPILE_IC_3SS) || defined(PHYDM_COMPILE_IC_4SS))
+#if (defined(PHYDM_COMPILE_IC_2SS) || defined(PHYDM_COMPILE_IC_3SS) ||\
+	defined(PHYDM_COMPILE_IC_4SS))
 	#define PHYDM_COMPILE_ABOVE_2SS
 #endif
 
@@ -461,241 +546,305 @@ enum phydm_ic_e {
 	#define PHYDM_COMPILE_ABOVE_4SS
 #endif
 
-/*========[New Phy-Status Support] =========================================================================]*/
-#if (RTL8824B_SUPPORT == 1)
-	#define ODM_PHY_STATUS_NEW_TYPE_SUPPORT			2
-#elif ((RTL8197F_SUPPORT == 1) || (RTL8723D_SUPPORT == 1) || (RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8710B_SUPPORT == 1) )
+/*@========[New Phy-Status Support] ========================*/
+#if (RTL8197F_SUPPORT || RTL8723D_SUPPORT || RTL8822B_SUPPORT ||\
+	RTL8821C_SUPPORT || RTL8710B_SUPPORT || RTL8195B_SUPPORT ||\
+	RTL8192F_SUPPORT || RTL8721D_SUPPORT)
 	#define ODM_PHY_STATUS_NEW_TYPE_SUPPORT			1
 #else
 	#define ODM_PHY_STATUS_NEW_TYPE_SUPPORT			0
 #endif
 
-/*==================================================================================================]*/
+#if (RTL8198F_SUPPORT) || (RTL8814B_SUPPORT) || (RTL8822C_SUPPORT) ||\
+	(RTL8812F_SUPPORT) || (RTL8197G_SUPPORT)
+	#define PHYSTS_3RD_TYPE_SUPPORT
+#endif
+
+#if (RTL8198F_SUPPORT || RTL8814B_SUPPORT || RTL8822C_SUPPORT ||\
+	RTL8812F_SUPPORT || RTL8197G_SUPPORT)
+	#define BB_RAM_SUPPORT
+#endif
 
-#if ((RTL8822B_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
+#if (RTL8821C_SUPPORT || RTL8822B_SUPPORT || RTL8822C_SUPPORT ||\
+	RTL8812F_SUPPORT || RTL8814B_SUPPORT || RTL8195B_SUPPORT ||\
+	RTL8198F_SUPPORT)
+	#define PHYDM_COMPILE_MU
+#endif
+/*@============================================================================*/
+
+#if (RTL8822B_SUPPORT || RTL8197F_SUPPORT || RTL8821C_SUPPORT ||\
+	RTL8192F_SUPPORT || RTL8195B_SUPPORT || RTL8822C_SUPPORT ||\
+	RTL8198F_SUPPORT || RTL8812F_SUPPORT || RTL8814B_SUPPORT ||\
+	RTL8197G_SUPPORT || RTL8721D_SUPPORT)
 #define PHYDM_COMMON_API_SUPPORT
 #endif
 
+
+#define	CCK_RATE_NUM		4
+#define	OFDM_RATE_NUM		8
+
+#define	LEGACY_RATE_NUM		12
+
+#define	HT_RATE_NUM_4SS		32
+#define	VHT_RATE_NUM_4SS	40
+
+#define	HT_RATE_NUM_3SS		24
+#define	VHT_RATE_NUM_3SS	30
+
+#define	HT_RATE_NUM_2SS		16
+#define	VHT_RATE_NUM_2SS	20
+
+#define	HT_RATE_NUM_1SS		8
+#define	VHT_RATE_NUM_1SS	10
+#if (defined(PHYDM_COMPILE_ABOVE_4SS))
+	#define	HT_RATE_NUM	HT_RATE_NUM_4SS
+	#define	VHT_RATE_NUM	VHT_RATE_NUM_4SS
+#elif (defined(PHYDM_COMPILE_ABOVE_3SS))
+	#define	HT_RATE_NUM	HT_RATE_NUM_3SS
+	#define	VHT_RATE_NUM	VHT_RATE_NUM_3SS
+#elif (defined(PHYDM_COMPILE_ABOVE_2SS))
+	#define	HT_RATE_NUM	HT_RATE_NUM_2SS
+	#define	VHT_RATE_NUM	VHT_RATE_NUM_2SS
+#else
+	#define	HT_RATE_NUM	HT_RATE_NUM_1SS
+	#define	VHT_RATE_NUM	VHT_RATE_NUM_1SS
+#endif
+
+#define	LOW_BW_RATE_NUM		VHT_RATE_NUM
+
+enum phydm_ic_ip {
+	PHYDM_IC_N		= 0,
+	PHYDM_IC_AC		= 1,
+	PHYDM_IC_JGR3		= 2
+};
+
+enum phydm_phy_sts_type {
+	PHYDM_PHYSTS_TYPE_1	= 1,
+	PHYDM_PHYSTS_TYPE_2	= 2,
+	PHYDM_PHYSTS_TYPE_3	= 3
+};
+
 /* ODM_CMNINFO_CUT_VER */
-enum odm_cut_version_e {
-	ODM_CUT_A		=	0,
-	ODM_CUT_B		=	1,
-	ODM_CUT_C		=	2,
-	ODM_CUT_D		=	3,
-	ODM_CUT_E		=	4,
-	ODM_CUT_F		=	5,
-	ODM_CUT_G		=	6,
-	ODM_CUT_H		=	7,
-	ODM_CUT_I		=	8,
-	ODM_CUT_J		=	9,
-	ODM_CUT_K		=	10,
-	ODM_CUT_TEST	=	15,
+enum odm_cut_version {
+	ODM_CUT_A		= 0,
+	ODM_CUT_B		= 1,
+	ODM_CUT_C		= 2,
+	ODM_CUT_D		= 3,
+	ODM_CUT_E		= 4,
+	ODM_CUT_F		= 5,
+	ODM_CUT_G		= 6,
+	ODM_CUT_H		= 7,
+	ODM_CUT_I		= 8,
+	ODM_CUT_J		= 9,
+	ODM_CUT_K		= 10,
+	ODM_CUT_TEST		= 15,
 };
 
 /* ODM_CMNINFO_FAB_VER */
-enum odm_fab_e {
-	ODM_TSMC	=	0,
-	ODM_UMC	=	1,
+enum odm_fab {
+	ODM_TSMC		= 0,
+	ODM_UMC			= 1,
 };
 
 /* ODM_CMNINFO_OP_MODE */
-enum odm_operation_mode_e {
+enum odm_operation_mode {
 	ODM_NO_LINK		= BIT(0),
-	ODM_LINK			= BIT(1),
-	ODM_SCAN			= BIT(2),
-	ODM_POWERSAVE	= BIT(3),
+	ODM_LINK		= BIT(1),
+	ODM_SCAN		= BIT(2),
+	ODM_POWERSAVE		= BIT(3),
 	ODM_AP_MODE		= BIT(4),
-	ODM_CLIENT_MODE	= BIT(5),
+	ODM_CLIENT_MODE		= BIT(5),
 	ODM_AD_HOC		= BIT(6),
-	ODM_WIFI_DIRECT	= BIT(7),
+	ODM_WIFI_DIRECT		= BIT(7),
 	ODM_WIFI_DISPLAY	= BIT(8),
 };
 
 /* ODM_CMNINFO_WM_MODE */
 #if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-enum odm_wireless_mode_e {
-	ODM_WM_UNKNOW	= 0x0,
-	ODM_WM_B			= BIT(0),
-	ODM_WM_G			= BIT(1),
-	ODM_WM_A			= BIT(2),
+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),
 };
 #else
-enum odm_wireless_mode_e {
-	ODM_WM_UNKNOWN	= 0x00,/*0x0*/
-	ODM_WM_A			= BIT(0), /* 0x1*/
-	ODM_WM_B			= BIT(1), /* 0x2*/
-	ODM_WM_G			= BIT(2),/* 0x4*/
-	ODM_WM_AUTO		= BIT(3),/* 0x8*/
-	ODM_WM_N24G		= BIT(4),/* 0x10*/
-	ODM_WM_N5G		= BIT(5),/* 0x20*/
-	ODM_WM_AC_5G		= BIT(6),/* 0x40*/
-	ODM_WM_AC_24G	= BIT(7),/* 0x80*/
-	ODM_WM_AC_ONLY	= BIT(8),/* 0x100*/
-	ODM_WM_MAX		= BIT(11)/* 0x800*/
+enum odm_wireless_mode {
+	ODM_WM_UNKNOWN		= 0x00,/*@0x0*/
+	ODM_WM_A		= BIT(0), /* @0x1*/
+	ODM_WM_B		= BIT(1), /* @0x2*/
+	ODM_WM_G		= BIT(2),/* @0x4*/
+	ODM_WM_AUTO		= BIT(3),/* @0x8*/
+	ODM_WM_N24G		= BIT(4),/* @0x10*/
+	ODM_WM_N5G		= BIT(5),/* @0x20*/
+	ODM_WM_AC_5G		= BIT(6),/* @0x40*/
+	ODM_WM_AC_24G		= BIT(7),/* @0x80*/
+	ODM_WM_AC_ONLY		= BIT(8),/* @0x100*/
+	ODM_WM_MAX		= BIT(11)/* @0x800*/
 
 };
 #endif
 
 /* ODM_CMNINFO_BAND */
-enum odm_band_type_e {
+enum odm_band_type {
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-	ODM_BAND_2_4G	= BIT(0),
+	ODM_BAND_2_4G		= BIT(0),
 	ODM_BAND_5G		= BIT(1),
 #else
-	ODM_BAND_2_4G = 0,
+	ODM_BAND_2_4G		= 0,
 	ODM_BAND_5G,
 	ODM_BAND_ON_BOTH,
 	ODM_BANDMAX
 #endif
 };
 
-
 /* ODM_CMNINFO_SEC_CHNL_OFFSET */
-enum phydm_sec_chnl_offset_e {
-
-	PHYDM_DONT_CARE	= 0,
+enum phydm_sec_chnl_offset {
+	PHYDM_DONT_CARE		= 0,
 	PHYDM_BELOW		= 1,
 	PHYDM_ABOVE		= 2
 };
 
 /* ODM_CMNINFO_SEC_MODE */
-enum odm_security_e {
-	ODM_SEC_OPEN			= 0,
+enum odm_security {
+	ODM_SEC_OPEN		= 0,
 	ODM_SEC_WEP40		= 1,
-	ODM_SEC_TKIP			= 2,
+	ODM_SEC_TKIP		= 2,
 	ODM_SEC_RESERVE		= 3,
 	ODM_SEC_AESCCMP		= 4,
 	ODM_SEC_WEP104		= 5,
-	ODM_WEP_WPA_MIXED    = 6, /* WEP + WPA */
-	ODM_SEC_SMS4			= 7,
+	ODM_WEP_WPA_MIXED	= 6, /* WEP + WPA */
+	ODM_SEC_SMS4		= 7,
 };
 
 /* ODM_CMNINFO_CHNL */
 
 /* ODM_CMNINFO_BOARD_TYPE */
-enum odm_board_type_e {
-	ODM_BOARD_DEFAULT 	= 0,	  /* The DEFAULT case. */
-	ODM_BOARD_MINICARD  = BIT(0), /* 0 = non-mini card, 1= mini card. */
-	ODM_BOARD_SLIM      = BIT(1), /* 0 = non-slim card, 1 = slim card */
-	ODM_BOARD_BT        = BIT(2), /* 0 = without BT card, 1 = with BT */
-	ODM_BOARD_EXT_PA    = BIT(3), /* 0 = no 2G ext-PA, 1 = existing 2G ext-PA */
-	ODM_BOARD_EXT_LNA   = BIT(4), /* 0 = no 2G ext-LNA, 1 = existing 2G ext-LNA */
-	ODM_BOARD_EXT_TRSW  = BIT(5), /* 0 = no ext-TRSW, 1 = existing ext-TRSW */
-	ODM_BOARD_EXT_PA_5G	= BIT(6), /* 0 = no 5G ext-PA, 1 = existing 5G ext-PA */
-	ODM_BOARD_EXT_LNA_5G = BIT(7), /* 0 = no 5G ext-LNA, 1 = existing 5G ext-LNA */
+enum odm_board_type {
+	ODM_BOARD_DEFAULT	= 0,	  /* The DEFAULT case. */
+	ODM_BOARD_MINICARD	= BIT(0), /* @0 = non-mini card, 1= mini card. */
+	ODM_BOARD_SLIM		= BIT(1), /* @0 = non-slim card, 1 = slim card */
+	ODM_BOARD_BT		= BIT(2), /* @0 = without BT card, 1 = with BT */
+	ODM_BOARD_EXT_PA	= BIT(3), /* @0 = no 2G ext-PA, 1 = existing 2G ext-PA */
+	ODM_BOARD_EXT_LNA	= BIT(4), /* @0 = no 2G ext-LNA, 1 = existing 2G ext-LNA */
+	ODM_BOARD_EXT_TRSW	= BIT(5), /* @0 = no ext-TRSW, 1 = existing ext-TRSW */
+	ODM_BOARD_EXT_PA_5G	= BIT(6), /* @0 = no 5G ext-PA, 1 = existing 5G ext-PA */
+	ODM_BOARD_EXT_LNA_5G	= BIT(7), /* @0 = no 5G ext-LNA, 1 = existing 5G ext-LNA */
 };
 
-enum odm_package_type_e {
-	ODM_PACKAGE_DEFAULT	 = 0,
-	ODM_PACKAGE_QFN68        = BIT(0),
-	ODM_PACKAGE_TFBGA90      = BIT(1),
-	ODM_PACKAGE_TFBGA79      = BIT(2),
+enum odm_package_type {
+	ODM_PACKAGE_DEFAULT	= 0,
+	ODM_PACKAGE_QFN68	= BIT(0),
+	ODM_PACKAGE_TFBGA90	= BIT(1),
+	ODM_PACKAGE_TFBGA79	= BIT(2),
 };
 
-enum odm_type_gpa_e {
-	TYPE_GPA0 = 0x0000,
-	TYPE_GPA1 = 0x0055,
-	TYPE_GPA2 = 0x00AA,
-	TYPE_GPA3 = 0x00FF,
-	TYPE_GPA4 = 0x5500,
-	TYPE_GPA5 = 0x5555,
-	TYPE_GPA6 = 0x55AA,
-	TYPE_GPA7 = 0x55FF,
-	TYPE_GPA8 = 0xAA00,
-	TYPE_GPA9 = 0xAA55,
-	TYPE_GPA10 = 0xAAAA,
-	TYPE_GPA11 = 0xAAFF,
-	TYPE_GPA12 = 0xFF00,
-	TYPE_GPA13 = 0xFF55,
-	TYPE_GPA14 = 0xFFAA,
-	TYPE_GPA15 = 0xFFFF,
+enum odm_type_gpa {
+	TYPE_GPA0		= 0x0000,
+	TYPE_GPA1		= 0x0055,
+	TYPE_GPA2		= 0x00AA,
+	TYPE_GPA3		= 0x00FF,
+	TYPE_GPA4		= 0x5500,
+	TYPE_GPA5		= 0x5555,
+	TYPE_GPA6		= 0x55AA,
+	TYPE_GPA7		= 0x55FF,
+	TYPE_GPA8		= 0xAA00,
+	TYPE_GPA9		= 0xAA55,
+	TYPE_GPA10		= 0xAAAA,
+	TYPE_GPA11		= 0xAAFF,
+	TYPE_GPA12		= 0xFF00,
+	TYPE_GPA13		= 0xFF55,
+	TYPE_GPA14		= 0xFFAA,
+	TYPE_GPA15		= 0xFFFF,
 };
 
-enum odm_type_apa_e {
-	TYPE_APA0 = 0x0000,
-	TYPE_APA1 = 0x0055,
-	TYPE_APA2 = 0x00AA,
-	TYPE_APA3 = 0x00FF,
-	TYPE_APA4 = 0x5500,
-	TYPE_APA5 = 0x5555,
-	TYPE_APA6 = 0x55AA,
-	TYPE_APA7 = 0x55FF,
-	TYPE_APA8 = 0xAA00,
-	TYPE_APA9 = 0xAA55,
-	TYPE_APA10 = 0xAAAA,
-	TYPE_APA11 = 0xAAFF,
-	TYPE_APA12 = 0xFF00,
-	TYPE_APA13 = 0xFF55,
-	TYPE_APA14 = 0xFFAA,
-	TYPE_APA15 = 0xFFFF,
+enum odm_type_apa {
+	TYPE_APA0		= 0x0000,
+	TYPE_APA1		= 0x0055,
+	TYPE_APA2		= 0x00AA,
+	TYPE_APA3		= 0x00FF,
+	TYPE_APA4		= 0x5500,
+	TYPE_APA5		= 0x5555,
+	TYPE_APA6		= 0x55AA,
+	TYPE_APA7		= 0x55FF,
+	TYPE_APA8		= 0xAA00,
+	TYPE_APA9		= 0xAA55,
+	TYPE_APA10		= 0xAAAA,
+	TYPE_APA11		= 0xAAFF,
+	TYPE_APA12		= 0xFF00,
+	TYPE_APA13		= 0xFF55,
+	TYPE_APA14		= 0xFFAA,
+	TYPE_APA15		= 0xFFFF,
 };
 
-enum odm_type_glna_e {
-	TYPE_GLNA0 = 0x0000,
-	TYPE_GLNA1 = 0x0055,
-	TYPE_GLNA2 = 0x00AA,
-	TYPE_GLNA3 = 0x00FF,
-	TYPE_GLNA4 = 0x5500,
-	TYPE_GLNA5 = 0x5555,
-	TYPE_GLNA6 = 0x55AA,
-	TYPE_GLNA7 = 0x55FF,
-	TYPE_GLNA8 = 0xAA00,
-	TYPE_GLNA9 = 0xAA55,
-	TYPE_GLNA10 = 0xAAAA,
-	TYPE_GLNA11 = 0xAAFF,
-	TYPE_GLNA12 = 0xFF00,
-	TYPE_GLNA13 = 0xFF55,
-	TYPE_GLNA14 = 0xFFAA,
-	TYPE_GLNA15 = 0xFFFF,
+enum odm_type_glna {
+	TYPE_GLNA0		= 0x0000,
+	TYPE_GLNA1		= 0x0055,
+	TYPE_GLNA2		= 0x00AA,
+	TYPE_GLNA3		= 0x00FF,
+	TYPE_GLNA4		= 0x5500,
+	TYPE_GLNA5		= 0x5555,
+	TYPE_GLNA6		= 0x55AA,
+	TYPE_GLNA7		= 0x55FF,
+	TYPE_GLNA8		= 0xAA00,
+	TYPE_GLNA9		= 0xAA55,
+	TYPE_GLNA10		= 0xAAAA,
+	TYPE_GLNA11		= 0xAAFF,
+	TYPE_GLNA12		= 0xFF00,
+	TYPE_GLNA13		= 0xFF55,
+	TYPE_GLNA14		= 0xFFAA,
+	TYPE_GLNA15		= 0xFFFF,
 };
 
-enum odm_type_alna_e {
-	TYPE_ALNA0 = 0x0000,
-	TYPE_ALNA1 = 0x0055,
-	TYPE_ALNA2 = 0x00AA,
-	TYPE_ALNA3 = 0x00FF,
-	TYPE_ALNA4 = 0x5500,
-	TYPE_ALNA5 = 0x5555,
-	TYPE_ALNA6 = 0x55AA,
-	TYPE_ALNA7 = 0x55FF,
-	TYPE_ALNA8 = 0xAA00,
-	TYPE_ALNA9 = 0xAA55,
-	TYPE_ALNA10 = 0xAAAA,
-	TYPE_ALNA11 = 0xAAFF,
-	TYPE_ALNA12 = 0xFF00,
-	TYPE_ALNA13 = 0xFF55,
-	TYPE_ALNA14 = 0xFFAA,
-	TYPE_ALNA15 = 0xFFFF,
+enum odm_type_alna {
+	TYPE_ALNA0		= 0x0000,
+	TYPE_ALNA1		= 0x0055,
+	TYPE_ALNA2		= 0x00AA,
+	TYPE_ALNA3		= 0x00FF,
+	TYPE_ALNA4		= 0x5500,
+	TYPE_ALNA5		= 0x5555,
+	TYPE_ALNA6		= 0x55AA,
+	TYPE_ALNA7		= 0x55FF,
+	TYPE_ALNA8		= 0xAA00,
+	TYPE_ALNA9		= 0xAA55,
+	TYPE_ALNA10		= 0xAAAA,
+	TYPE_ALNA11		= 0xAAFF,
+	TYPE_ALNA12		= 0xFF00,
+	TYPE_ALNA13		= 0xFF55,
+	TYPE_ALNA14		= 0xFFAA,
+	TYPE_ALNA15		= 0xFFFF,
 };
 
 #define	PAUSE_FAIL		0
-#define	PAUSE_SUCCESS	1
+#define	PAUSE_SUCCESS		1
 
-enum odm_parameter_init_e {
-	ODM_PRE_SETTING = 0,
-	ODM_POST_SETTING = 1,
+enum odm_parameter_init {
+	ODM_PRE_SETTING		= 0,
+	ODM_POST_SETTING	= 1,
 	ODM_INIT_FW_SETTING
 };
 
-
 enum phydm_pause_type {
-	PHYDM_PAUSE = 1,			/*Pause & Set new value*/
-	PHYDM_PAUSE_NO_SET = 2,	/*Pause & Stay in current value*/
-	PHYDM_RESUME = 3
+	PHYDM_PAUSE		= 1,	/*Pause & Set new value*/
+	PHYDM_PAUSE_NO_SET	= 2,	/*Pause & Stay in current value*/
+	PHYDM_RESUME		= 3
 };
 
 enum phydm_pause_level {
-	PHYDM_PAUSE_RELEASE = -1,
-	PHYDM_PAUSE_LEVEL_0 = 0,	/* Low Priority function */
-	PHYDM_PAUSE_LEVEL_1 = 1,	/* Middle Priority function */
-	PHYDM_PAUSE_LEVEL_2 = 2,	/* High priority function (ex: Check hang function) */
-	PHYDM_PAUSE_LEVEL_3 = 3,	/* Debug function (the highest priority) */
-	PHYDM_PAUSE_MAX_NUM = 4
+	PHYDM_PAUSE_RELEASE	= -1,
+	PHYDM_PAUSE_LEVEL_0	= 0,	/* @Low Priority function */
+	PHYDM_PAUSE_LEVEL_1	= 1,	/* @Middle Priority function */
+	PHYDM_PAUSE_LEVEL_2	= 2,	/* @High priority function (ex: Check hang function) */
+	PHYDM_PAUSE_LEVEL_3	= 3,	/* @Debug function (the highest priority) */
+	PHYDM_PAUSE_MAX_NUM	= 4
 };
 
+enum phydm_dis_hw_fun {
+	HW_FUN_DIS		= 0,	/*@Disable a cetain HW function & backup the original value*/
+	HW_FUN_RESUME		= 1	/*Revert */
+};
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_precomp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_precomp.h
index c8c7c5614d4a..fd0ca2256a5b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_precomp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_precomp.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,25 +9,34 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__ODM_PRECOMP_H__
+#ifndef __ODM_PRECOMP_H__
 #define __ODM_PRECOMP_H__
 
 #include "phydm_types.h"
-#include "phydm_features.h"
 #include "halrf/halrf_features.h"
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#include "Precomp.h"		/* We need to include mp_precomp.h due to batch file setting. */
+	#include "Precomp.h"		/* @We need to include mp_precomp.h due to batch file setting. */
 #else
 	#define		TEST_FALG___		1
 #endif
 
-/* 2 Config Flags and Structs - defined by each ODM type */
+/* @2 Config Flags and Structs - defined by each ODM type */
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 	#include "../8192cd_cfg.h"
@@ -34,6 +44,7 @@
 
 	#include "../8192cd.h"
 	#include "../8192cd_util.h"
+	#include "../8192cd_hw.h"
 	#ifdef _BIG_ENDIAN_
 		#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_BIG
 	#else
@@ -47,6 +58,10 @@
 	#ifdef DM_ODM_CE_MAC80211
 		#include "../wifi.h"
 		#include "rtl_phydm.h"
+	#elif defined(DM_ODM_CE_MAC80211_V2)
+		#include "../main.h"
+		#include "../hw.h"
+		#include "../fw.h"
 	#endif
 	#define __PACK
 	#define __WLAN_ATTRIB_PACK__
@@ -55,9 +70,14 @@
 	#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
 	#define __PACK
 	#define __WLAN_ATTRIB_PACK__
+#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	#include <drv_types.h>
+	#include <wifi.h>
+	#define	ODM_ENDIAN_TYPE				ODM_ENDIAN_LITTLE
+	#define __PACK
 #endif
 
-/* 2 OutSrc Header Files */
+/* @2 OutSrc Header Files */
 
 #include "phydm.h"
 #include "phydm_hwconfig.h"
@@ -67,49 +87,41 @@
 #include "phydm_regdefine11n.h"
 #include "phydm_interface.h"
 #include "phydm_reg.h"
+#include "halrf/halrf_debug.h"
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && !defined(DM_ODM_CE_MAC80211)
+#if (DM_ODM_SUPPORT_TYPE & ODM_CE) && \
+	(!defined(DM_ODM_CE_MAC80211) && !defined(DM_ODM_CE_MAC80211_V2))
 
-void
-phy_set_tx_power_limit(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8	*regulation,
-	u8	*band,
-	u8	*bandwidth,
-	u8	*rate_section,
-	u8	*rf_path,
-	u8	*channel,
-	u8	*power_limit
-);
+void phy_set_tx_power_limit(
+	struct dm_struct *dm,
+	u8 *regulation,
+	u8 *band,
+	u8 *bandwidth,
+	u8 *rate_section,
+	u8 *rf_path,
+	u8 *channel,
+	u8 *power_limit);
 
 enum hal_status
 rtw_phydm_fw_iqk(
-	struct PHY_DM_STRUCT	*p_dm,
+	struct dm_struct *dm,
 	u8 clear,
-	u8 segment
-);
+	u8 segment);
 
 enum hal_status
 rtw_phydm_cfg_phy_para(
-	struct PHY_DM_STRUCT	*p_dm,
+	struct dm_struct *dm,
 	enum phydm_halmac_param config_type,
 	u32 offset,
 	u32 data,
 	u32 mask,
 	enum rf_path e_rf_path,
-	u32 delay_time
-);
+	u32 delay_time);
 
 #endif
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
-	#define RTL8703B_SUPPORT		0
-	#define RTL8188F_SUPPORT		0
-	#define RTL8723D_SUPPORT		0
-#endif
-
-/* JJ ADD 20161014 */
-#if (DM_ODM_SUPPORT_TYPE & (ODM_CE|ODM_AP|ODM_IOT))
+/* @Judy ADD 20180125 */
+#if (DM_ODM_SUPPORT_TYPE & (ODM_AP | ODM_IOT))
 #define RTL8710B_SUPPORT		0
 #endif
 
@@ -122,8 +134,16 @@ rtw_phydm_cfg_phy_para(
 	#endif
 #endif
 
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+#define RTL8197F_SUPPORT 0	/*@Just for PHYDM API development*/
+#define	RTL8195B_SUPPORT 0	/*@Just for PHYDM API development*/
+#define	RTL8198F_SUPPORT 0	/*@Just for PHYDM API development*/
+#define	RTL8812F_SUPPORT 0	/*@Just for PHYDM API development*/
+#define	RTL8197G_SUPPORT 0	/*@Just for PHYDM API development*/
+#endif
+
 #if (RTL8188E_SUPPORT == 1)
-	#include "rtl8188e/hal8188erateadaptive.h" /* for  RA,Power training */
+	#include "rtl8188e/hal8188erateadaptive.h" /* @for  RA,Power training */
 	#include "rtl8188e/halhwimg8188e_mac.h"
 	#include "rtl8188e/halhwimg8188e_rf.h"
 	#include "rtl8188e/halhwimg8188e_bb.h"
@@ -141,19 +161,19 @@ rtw_phydm_cfg_phy_para(
 	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 		#include "halrf/rtl8188e/halrf_8188e_ap.h"
 	#endif
-#endif /* 88E END */
+#endif /* @88E END */
 
 #if (RTL8192E_SUPPORT == 1)
 
 	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		#include "halrf/rtl8192e/halrf_8192e_win.h" /*FOR_8192E_IQK*/
+		#include "halrf/rtl8192e/halrf_8192e_win.h" /*@FOR_8192E_IQK*/
 	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-		#include "halrf/rtl8192e/halrf_8192e_ap.h" /*FOR_8192E_IQK*/
+		#include "halrf/rtl8192e/halrf_8192e_ap.h" /*@FOR_8192E_IQK*/
 	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-		#include "halrf/rtl8192e/halrf_8192e_ce.h" /*FOR_8192E_IQK*/
+		#include "halrf/rtl8192e/halrf_8192e_ce.h" /*@FOR_8192E_IQK*/
 	#endif
 
-	#include "rtl8192e/phydm_rtl8192e.h" /* FOR_8192E_IQK */
+	#include "rtl8192e/phydm_rtl8192e.h" /* @FOR_8192E_IQK */
 	#include "rtl8192e/version_rtl8192e.h"
 	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 		#include "rtl8192e/halhwimg8192e_bb.h"
@@ -165,7 +185,7 @@ rtw_phydm_cfg_phy_para(
 	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
 		#include "rtl8192e_hal.h"
 	#endif
-#endif /* 92E END */
+#endif /* @92E END */
 
 #if (RTL8812A_SUPPORT == 1)
 
@@ -177,21 +197,21 @@ rtw_phydm_cfg_phy_para(
 		#include "halrf/rtl8812a/halrf_8812a_ce.h"
 	#endif
 
-	/* #include "halrf/rtl8812a/halrf_8812a.h"  */ /* FOR_8812_IQK */
+	/* @#include "halrf/rtl8812a/halrf_8812a.h"  */ /* @FOR_8812_IQK */
 	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 		#include "rtl8812a/halhwimg8812a_bb.h"
 		#include "rtl8812a/halhwimg8812a_mac.h"
 		#include "rtl8812a/halhwimg8812a_rf.h"
 		#include "rtl8812a/phydm_regconfig8812a.h"
-		#include "rtl8812a/phydm_rtl8812a.h"
 	#endif
+	#include "rtl8812a/phydm_rtl8812a.h"
 
 	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
 		#include "rtl8812a_hal.h"
 	#endif
 	#include "rtl8812a/version_rtl8812a.h"
 
-#endif /* 8812 END */
+#endif /* @8812 END */
 
 #if (RTL8814A_SUPPORT == 1)
 
@@ -212,9 +232,9 @@ rtw_phydm_cfg_phy_para(
 		#include "rtl8814a_hal.h"
 		#include "halrf/rtl8814a/halrf_iqk_8814a.h"
 	#endif
-#endif /* 8814 END */
+#endif /* @8814 END */
 
-#if (RTL8881A_SUPPORT == 1)/* FOR_8881_IQK */
+#if (RTL8881A_SUPPORT == 1)/* @FOR_8881_IQK */
 	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 		#include "halrf/rtl8821a/halrf_iqk_8821a_win.h"
 	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
@@ -222,10 +242,10 @@ rtw_phydm_cfg_phy_para(
 	#else
 		#include "halrf/rtl8821a/halrf_iqk_8821a_ap.h"
 	#endif
-	/* #include "rtl8881a/HalHWImg8881A_BB.h" */
-	/* #include "rtl8881a/HalHWImg8881A_MAC.h" */
-	/* #include "rtl8881a/HalHWImg8881A_RF.h" */
-	/* #include "rtl8881a/odm_RegConfig8881A.h" */
+	/* @#include "rtl8881a/HalHWImg8881A_BB.h" */
+	/* @#include "rtl8881a/HalHWImg8881A_MAC.h" */
+	/* @#include "rtl8881a/HalHWImg8881A_RF.h" */
+	/* @#include "rtl8881a/odm_RegConfig8881A.h" */
 #endif
 
 #if (RTL8723B_SUPPORT == 1)
@@ -258,8 +278,8 @@ rtw_phydm_cfg_phy_para(
 		#include "halrf/rtl8821a/halrf_8821a_win.h"
 	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 		#include "halrf/rtl8821a/halrf_8821a_ce.h"
-		#include "halrf/rtl8821a/halrf_iqk_8821a_ce.h"/*for IQK*/
-		#include "halrf/rtl8812a/halrf_8812a_ce.h"/*for IQK,LCK,Power-tracking*/
+		#include "halrf/rtl8821a/halrf_iqk_8821a_ce.h"/*@for IQK*/
+		#include "halrf/rtl8812a/halrf_8812a_ce.h"/*@for IQK,LCK,Power-tracking*/
 		#include "rtl8812a_hal.h"
 	#else
 	#endif
@@ -267,27 +287,8 @@ rtw_phydm_cfg_phy_para(
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
 #include "../halmac/halmac_reg2.h"
-
-#define	LDPC_HT_ENABLE_RX			BIT(0)
-#define	LDPC_HT_ENABLE_TX			BIT(1)
-#define	LDPC_HT_TEST_TX_ENABLE			BIT(2)
-#define	LDPC_HT_CAP_TX				BIT(3)
-
-#define	STBC_HT_ENABLE_RX			BIT(0)
-#define	STBC_HT_ENABLE_TX			BIT(1)
-#define	STBC_HT_TEST_TX_ENABLE			BIT(2)
-#define	STBC_HT_CAP_TX				BIT(3)
-
-
-#define	LDPC_VHT_ENABLE_RX			BIT(0)
-#define	LDPC_VHT_ENABLE_TX			BIT(1)
-#define	LDPC_VHT_TEST_TX_ENABLE			BIT(2)
-#define	LDPC_VHT_CAP_TX				BIT(3)
-
-#define	STBC_VHT_ENABLE_RX			BIT(0)
-#define	STBC_VHT_ENABLE_TX			BIT(1)
-#define	STBC_VHT_TEST_TX_ENABLE			BIT(2)
-#define	STBC_VHT_CAP_TX				BIT(3)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211_V2)
+#include "../halmac/halmac_reg2.h"
 #endif
 
 
@@ -305,9 +306,11 @@ rtw_phydm_cfg_phy_para(
 	#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 		#ifdef DM_ODM_CE_MAC80211
 			#include "../halmac/halmac_reg_8822b.h"
+		#elif defined(DM_ODM_CE_MAC80211_V2)
+			#include "../halmac/halmac_reg_8822b.h"
 		#else
-			#include <hal_data.h>		/* struct HAL_DATA_TYPE */
-			#include <rtl8822b_hal.h>	/* RX_SMOOTH_FACTOR, reg definition and etc.*/
+			#include <hal_data.h>		/* @struct HAL_DATA_TYPE */
+			#include <rtl8822b_hal.h>	/* @RX_SMOOTH_FACTOR, reg definition and etc.*/
 		#endif
 	#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 	#endif
@@ -315,6 +318,7 @@ rtw_phydm_cfg_phy_para(
 #endif
 
 #if (RTL8703B_SUPPORT == 1)
+	#include "rtl8703b/phydm_rtl8703b.h"
 	#include "rtl8703b/phydm_regconfig8703b.h"
 	#include "rtl8703b/halhwimg8703b_mac.h"
 	#include "rtl8703b/halhwimg8703b_rf.h"
@@ -333,7 +337,7 @@ rtw_phydm_cfg_phy_para(
 	#include "rtl8188f/hal8188freg.h"
 	#include "rtl8188f/phydm_rtl8188f.h"
 	#include "rtl8188f/phydm_regconfig8188f.h"
-	#include "halrf/rtl8188f/halrf_8188f.h" /* for IQK,LCK,Power-tracking */
+	#include "halrf/rtl8188f/halrf_8188f.h" /*@for IQK,LCK,Power-tracking*/
 	#include "rtl8188f/version_rtl8188f.h"
 	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
 		#include "rtl8188f_hal.h"
@@ -353,11 +357,13 @@ rtw_phydm_cfg_phy_para(
 		#include "rtl8723d/version_rtl8723d.h"
 	#endif
 	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#ifdef DM_ODM_CE_MAC80211
+		#else
 		#include "rtl8723d_hal.h"
+		#endif
 	#endif
-#endif /* 8723D End */
+#endif /* @8723D End */
 
-/* JJ ADD 20161014 */
 #if (RTL8710B_SUPPORT == 1)
 	#if (DM_ODM_SUPPORT_TYPE != ODM_AP)
 
@@ -373,7 +379,7 @@ rtw_phydm_cfg_phy_para(
 	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
 		#include "rtl8710b_hal.h"
 	#endif
-#endif /* 8710B End */
+#endif /* @8710B End */
 
 #if (RTL8197F_SUPPORT == 1)
 	#include "rtl8197f/halhwimg8197f_mac.h"
@@ -385,6 +391,7 @@ rtw_phydm_cfg_phy_para(
 	#include "rtl8197f/phydm_regconfig8197f.h"
 	#include "halrf/rtl8197f/halrf_8197f.h"
 	#include "halrf/rtl8197f/halrf_iqk_8197f.h"
+	#include "halrf/rtl8197f/halrf_dpk_8197f.h"
 #endif
 
 #if (RTL8821C_SUPPORT == 1)
@@ -396,8 +403,113 @@ rtw_phydm_cfg_phy_para(
 	#include "halrf/rtl8821c/halrf_8821c.h"
 	#include "rtl8821c/version_rtl8821c.h"
 	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#ifdef DM_ODM_CE_MAC80211
+		#include "../halmac/halmac_reg_8821c.h"
+		#else
 		#include "rtl8821c_hal.h"
+		#endif
 	#endif
 #endif
 
-#endif /* __ODM_PRECOMP_H__ */
+#if (RTL8192F_SUPPORT == 1)
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8192f_hal.h"/*need to before rf.h*/
+	#endif
+	#include "rtl8192f/halhwimg8192f_mac.h"
+	#include "rtl8192f/halhwimg8192f_rf.h"
+	#include "rtl8192f/halhwimg8192f_bb.h"
+	#include "rtl8192f/phydm_hal_api8192f.h"
+	#include "rtl8192f/version_rtl8192f.h"
+	#include "rtl8192f/phydm_rtl8192f.h"
+	#include "rtl8192f/phydm_regconfig8192f.h"
+	#include "halrf/rtl8192f/halrf_8192f.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8192f/halrf_dpk_8192f.h"
+	#endif
+#endif
+
+#if (RTL8721D_SUPPORT == 1)
+	#include "halrf/rtl8721d/halrf_8721d.h"
+	#include "rtl8721d/phydm_hal_api8721d.h"
+	#include "rtl8721d/phydm_regconfig8721d.h"
+	#include "rtl8721d/halhwimg8721d_mac.h"
+	#include "rtl8721d/halhwimg8721d_rf.h"
+	#include "rtl8721d/halhwimg8721d_bb.h"
+	#include "rtl8721d/version_rtl8721d.h"
+	#include "rtl8721d/phydm_rtl8721d.h"
+	#include "rtl8721d/hal8721dreg.h"
+	#include <hal_data.h>
+	#if 0
+	#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		#include "halrf/rtl8721d/halrf_dpk_8721d.h"
+	#endif
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+		#include "rtl8721d_hal.h"
+	#endif
+	#endif
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	#include "halrf/rtl8195b/halrf_8195b.h"
+	#include "rtl8195b/phydm_hal_api8195b.h"
+	#include "rtl8195b/phydm_regconfig8195b.h"
+	#include "rtl8195b/halhwimg8195b_mac.h"
+	#include "rtl8195b/halhwimg8195b_rf.h"
+	#include "rtl8195b/halhwimg8195b_bb.h"
+	#include "rtl8195b/version_rtl8195b.h"
+	#include <hal_data.h> /*@HAL_DATA_TYPE*/
+#endif
+
+#if (RTL8198F_SUPPORT == 1)
+	#include "rtl8198f/phydm_regconfig8198f.h"
+	#include "rtl8198f/phydm_hal_api8198f.h"
+	#include "rtl8198f/halhwimg8198f_mac.h"
+	#include "rtl8198f/halhwimg8198f_rf.h"
+	#include "rtl8198f/halhwimg8198f_bb.h"
+	#include "rtl8198f/version_rtl8198f.h"
+	#include "halrf/rtl8198f/halrf_8198f.h"
+	#include "halrf/rtl8198f/halrf_iqk_8198f.h"
+#endif
+
+#if (RTL8822C_SUPPORT)
+	#include "rtl8822c/halhwimg8822c_mac.h"
+	#include "rtl8822c/halhwimg8822c_rf.h"
+	#include "rtl8822c/halhwimg8822c_bb.h"
+	#include "rtl8822c/phydm_regconfig8822c.h"
+	#include "halrf/rtl8822c/halrf_8822c.h"
+	#include "rtl8822c/phydm_hal_api8822c.h"
+	#include "rtl8822c/version_rtl8822c.h"
+	#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+	/* @struct HAL_DATA_TYPE */
+	#include <hal_data.h>
+	/* @RX_SMOOTH_FACTOR, reg definition and etc.*/
+	#include <rtl8822c_hal.h>
+	#endif
+#endif
+#if (RTL8814B_SUPPORT == 1)
+	#include "rtl8814b/halhwimg8814b_mac.h"
+	#include "rtl8814b/halhwimg8814b_rf.h"
+	#include "rtl8814b/halhwimg8814b_bb.h"
+	#include "rtl8814b/phydm_regconfig8814b.h"
+	#include "halrf/rtl8814b/halrf_8814b.h"
+	#include "rtl8814b/phydm_hal_api8814b.h"
+	#include "rtl8814b/version_rtl8814b.h"
+#endif
+#if (RTL8812F_SUPPORT)
+	#include "rtl8812f/halhwimg8812f_mac.h"
+	#include "rtl8812f/halhwimg8812f_rf.h"
+	#include "rtl8812f/halhwimg8812f_bb.h"
+	#include "rtl8812f/phydm_regconfig8812f.h"
+	#include "halrf/rtl8812f/halrf_8812f.h"
+	#include "rtl8812f/phydm_hal_api8812f.h"
+	#include "rtl8812f/version_rtl8812f.h"
+#endif
+#if (RTL8197G_SUPPORT)
+	#include "rtl8197g/halhwimg8197g_mac.h"
+	#include "rtl8197g/halhwimg8197g_rf.h"
+	#include "rtl8197g/halhwimg8197g_bb.h"
+	#include "rtl8197g/phydm_regconfig8197g.h"
+	#include "halrf/rtl8197g/halrf_8197g.h"
+	#include "rtl8197g/phydm_hal_api8197g.h"
+	#include "rtl8197g/version_rtl8197g.h"
+#endif
+#endif /* @__ODM_PRECOMP_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.c
index 991e65b31e74..341dfe2b50b4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,727 +9,166 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 #ifdef PHYDM_PRIMARY_CCA
 
-void
-phydm_write_dynamic_cca(
-	void			*p_dm_void,
-	u8			curr_mf_state
-	
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pricca_struct	*primary_cca = &(p_dm->dm_pri_cca);
-
-	if (primary_cca->mf_state != curr_mf_state) {
-
-		if (p_dm->support_ic_type & ODM_IC_11N_SERIES) {
-			
-			if (curr_mf_state == MF_USC_LSC) {
-				odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), MF_USC_LSC);
-				odm_set_bb_reg(p_dm, 0xc84, 0xf0000000, primary_cca->cca_th_40m_bkp); /*40M OFDM MF CCA threshold*/
-			} else {
-				odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), curr_mf_state);
-				odm_set_bb_reg(p_dm, 0xc84, 0xf0000000, 0); /*40M OFDM MF CCA threshold*/
-			}
-		}
-		
-		primary_cca->mf_state = curr_mf_state;
-		PHYDM_DBG(p_dm, DBG_PRI_CCA,
-			("Set CCA at ((%s SB)), 0xc6c[8:7]=((%d))\n", ((curr_mf_state == MF_USC_LSC)?"D":((curr_mf_state == MF_LSC)?"L":"U")), curr_mf_state));
-	}
-}
-
-void
-phydm_primary_cca_reset(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pricca_struct	*primary_cca = &(p_dm->dm_pri_cca);
+void phydm_write_dynamic_cca(
+	void *dm_void,
+	u8 curr_mf_state
 
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("[PriCCA] Reset\n"));
-	primary_cca->mf_state = 0xff;
-	primary_cca->pre_bw = (enum channel_width)0xff;
-	phydm_write_dynamic_cca(p_dm, MF_USC_LSC);
-}
-
-void
-phydm_primary_cca_11n(
-	void			*p_dm_void
-)
+	)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pricca_struct	*p_primary_cca = &(p_dm->dm_pri_cca);
-	enum channel_width	curr_bw = (enum channel_width)(*(p_dm->p_band_width));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct *pri_cca = &dm->dm_pri_cca;
 
-	if (!(p_dm->support_ability & ODM_BB_PRIMARY_CCA))
+	if (pri_cca->mf_state == curr_mf_state)
 		return;
-	
-	if (!p_dm->is_linked) { /* is_linked==False */
-		PHYDM_DBG(p_dm, DBG_PRI_CCA, ("[PriCCA][No Link!!!]\n"));
 
-		if (p_primary_cca->pri_cca_is_become_linked == true) {
-			phydm_primary_cca_reset(p_dm);
-			p_primary_cca->pri_cca_is_become_linked = p_dm->is_linked;
-		}
-		return;
-		
-	} else {
-		if (p_primary_cca->pri_cca_is_become_linked == false) {
-			PHYDM_DBG(p_dm, DBG_PRI_CCA, ("[PriCCA][Linked !!!]\n"));
-			p_primary_cca->pri_cca_is_become_linked = p_dm->is_linked;
-		}
-	}
-	
-	if (curr_bw != p_primary_cca->pre_bw) {
-
-		PHYDM_DBG(p_dm, DBG_PRI_CCA, ("[Primary CCA] start ==>\n"));
-		p_primary_cca->pre_bw = curr_bw;
-
-		if (curr_bw == CHANNEL_WIDTH_40) {
-			
-			if ((*(p_dm->p_sec_ch_offset)) == SECOND_CH_AT_LSB) {/* Primary CH @ upper sideband*/
-				
-				PHYDM_DBG(p_dm, DBG_PRI_CCA, ("BW40M, Primary CH at USB\n"));
-				phydm_write_dynamic_cca(p_dm, MF_USC);
-				
-			} else {	/*Primary CH @ lower sideband*/
-				
-				PHYDM_DBG(p_dm, DBG_PRI_CCA, ("BW40M, Primary CH at LSB\n"));
-				phydm_write_dynamic_cca(p_dm, MF_LSC);
-			}
+	if (dm->support_ic_type & ODM_IC_11N_SERIES) {
+		if (curr_mf_state == MF_USC_LSC) {
+			odm_set_bb_reg(dm, R_0xc6c, 0x180, MF_USC_LSC);
+			/*@40M OFDM MF CCA threshold*/
+			odm_set_bb_reg(dm, R_0xc84, 0xf0000000,
+				       pri_cca->cca_th_40m_bkp);
 		} else {
-		
-			PHYDM_DBG(p_dm, DBG_PRI_CCA, ("Not BW40M, USB + LSB\n"));
-			phydm_primary_cca_reset(p_dm);
+			odm_set_bb_reg(dm, R_0xc6c, 0x180, curr_mf_state);
+			/*@40M OFDM MF CCA threshold*/
+			odm_set_bb_reg(dm, R_0xc84, 0xf0000000, 0);
 		}
 	}
+
+	pri_cca->mf_state = curr_mf_state;
+	PHYDM_DBG(dm, DBG_PRI_CCA, "Set CCA at ((%s SB)), 0xc6c[8:7]=((%d))\n",
+		  ((curr_mf_state == MF_USC_LSC) ? "D" :
+		  ((curr_mf_state == MF_LSC) ? "L" : "U")), curr_mf_state);
 }
 
-#if 0
-#if (RTL8188E_SUPPORT == 1)
-void
-odm_dynamic_primary_cca_8188e(
-	void			*p_dm_void
-)
+void phydm_primary_cca_reset(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct sta_info	*p_entry;
-	struct cmn_sta_info	*p_sta;
-	struct phydm_fa_struct		*false_alm_cnt = (struct phydm_fa_struct *)phydm_get_structure(p_dm, PHYDM_FALSEALMCNT);
-	struct phydm_pricca_struct		*primary_cca = &(p_dm->dm_pri_cca);
-	boolean		client_40mhz = false, client_tmp = false;      /* connected client BW */
-	boolean		is_connected = false;		/* connected or not */
-	u8	client_40mhz_pre = 0;
-	u32	counter = 0;
-	u8	delay = 1;
-	u64		cur_tx_ok_cnt;
-	u64		cur_rx_ok_cnt;
-	u8		sec_ch_offset = *(p_dm->p_sec_ch_offset);
-	u8		i;
-
-	if (!p_dm->is_linked)
-		return;
-
-	if (!(p_dm->support_ability & ODM_BB_PRIMARY_CCA))
-		return;
-
-	if (*(p_dm->p_band_width) == CHANNEL_WIDTH_20) {	/*curr bw*/
-		odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), 0);
-		return;
-	}
-
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN) || (DM_ODM_SUPPORT_TYPE == ODM_CE)
-		sec_ch_offset = sec_ch_offset % 2 + 1; /* NIC's definition is reverse to AP   1:secondary below,  2: secondary above */
-	#endif
-	
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("Second CH Offset = %d\n", sec_ch_offset));
-
-	/* 3 Check Current WLAN Traffic */
-	cur_tx_ok_cnt = p_dm->tx_tp;
-	cur_rx_ok_cnt = p_dm->rx_tp;
-
-	/* ==================Debug Message==================== */
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("TP = %llu\n", cur_tx_ok_cnt + cur_rx_ok_cnt));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("is_BW40 = %d\n", *(p_dm->p_band_width)));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("BW_LSC = %d\n", false_alm_cnt->cnt_bw_lsc));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("BW_USC = %d\n", false_alm_cnt->cnt_bw_usc));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("CCA OFDM = %d\n", false_alm_cnt->cnt_ofdm_cca));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("CCA CCK = %d\n", false_alm_cnt->cnt_cck_cca));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("OFDM FA = %d\n", false_alm_cnt->cnt_ofdm_fail));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("CCK FA = %d\n", false_alm_cnt->cnt_cck_fail));
-	/* ================================================ */
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct *pri_cca = &dm->dm_pri_cca;
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	if (ACTING_AS_AP(p_dm->adapter))   /* primary cca process only do at AP mode */
-#endif
-	{
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		PHYDM_DBG(p_dm, DBG_PRI_CCA, ("ACTING as AP mode=%d\n", ACTING_AS_AP(p_dm->adapter)));
-		/* 3 To get entry's connection and BW infomation status. */
-		for (i = 0; i < ASSOCIATE_ENTRY_NUM; i++) {
-			if (IsAPModeExist(p_dm->adapter) && GetFirstExtAdapter(p_dm->adapter) != NULL)
-				p_entry = AsocEntry_EnumStation(GetFirstExtAdapter(p_dm->adapter), i);
-			else
-				p_entry = AsocEntry_EnumStation(GetDefaultAdapter(p_dm->adapter), i);
-			if (p_entry != NULL) {
-				client_tmp = p_entry->BandWidth;   /* client BW */
-				PHYDM_DBG(p_dm, DBG_PRI_CCA, ("Client_BW=%d\n", client_tmp));
-				if (client_tmp > client_40mhz)
-					client_40mhz = client_tmp;     /* 40M/20M coexist => 40M priority is High */
-
-				if (p_entry->bAssociated) {
-					is_connected = true;  /* client is connected or not */
-					break;
-				}
-			} else
-				break;
-		}
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-		/* 3 To get entry's connection and BW infomation status. */
-
-		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-			p_sta = p_dm->p_phydm_sta_info[i];
-			if (is_sta_active(p_sta)) {
-				client_tmp = p_sta->bw_mode;
-				if (client_tmp > client_40mhz)
-					client_40mhz = client_tmp;     /* 40M/20M coexist => 40M priority is High */
-
-				is_connected = true;
-			}
-		}
-#endif
-		PHYDM_DBG(p_dm, DBG_PRI_CCA, ("is_connected=%d\n", is_connected));
-		PHYDM_DBG(p_dm, DBG_PRI_CCA, ("Is Client 40MHz=%d\n", client_40mhz));
-		/* 1 Monitor whether the interference exists or not */
-		if (primary_cca->monitor_flag == 1) {
-			if (sec_ch_offset == 1) {    /* secondary channel is below the primary channel */
-				if ((false_alm_cnt->cnt_ofdm_cca > 500) && (false_alm_cnt->cnt_bw_lsc > false_alm_cnt->cnt_bw_usc + 500)) {
-					if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1) {
-						primary_cca->intf_type = 1;
-						primary_cca->pri_cca_flag = 1;
-						odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT7, 2); /* USC MF */
-						if (primary_cca->dup_rts_flag == 1)
-							primary_cca->dup_rts_flag = 0;
-					} else {
-						primary_cca->intf_type = 2;
-						if (primary_cca->dup_rts_flag == 0)
-							primary_cca->dup_rts_flag = 1;
-					}
-
-				} else { /* interferecne disappear */
-					primary_cca->dup_rts_flag = 0;
-					primary_cca->intf_flag = 0;
-					primary_cca->intf_type = 0;
-				}
-			} else if (sec_ch_offset == 2) { /* secondary channel is above the primary channel */
-				if ((false_alm_cnt->cnt_ofdm_cca > 500) && (false_alm_cnt->cnt_bw_usc > false_alm_cnt->cnt_bw_lsc + 500)) {
-					if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1) {
-						primary_cca->intf_type = 1;
-						primary_cca->pri_cca_flag = 1;
-						odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT7, 1); /* LSC MF */
-						if (primary_cca->dup_rts_flag == 1)
-							primary_cca->dup_rts_flag = 0;
-					} else {
-						primary_cca->intf_type = 2;
-						if (primary_cca->dup_rts_flag == 0)
-							primary_cca->dup_rts_flag = 1;
-					}
-
-				} else { /* interferecne disappear */
-					primary_cca->dup_rts_flag = 0;
-					primary_cca->intf_flag = 0;
-					primary_cca->intf_type = 0;
-				}
-
-
-			}
-			primary_cca->monitor_flag = 0;
-		}
-
-		/* 1 Dynamic Primary CCA Main Function */
-		if (primary_cca->monitor_flag == 0) {
-			if (*(p_dm->p_band_width) == CHANNEL_WIDTH_40) {		/* if RFBW==40M mode which require to process primary cca */
-				/* 2 STA is NOT Connected */
-				if (!is_connected) {
-					PHYDM_DBG(p_dm, DBG_PRI_CCA, ("STA NOT Connected!!!!\n"));
-
-					if (primary_cca->pri_cca_flag == 1) {	/* reset primary cca when STA is disconnected */
-						primary_cca->pri_cca_flag = 0;
-						odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), 0);
-					}
-					if (primary_cca->dup_rts_flag == 1)		/* reset Duplicate RTS when STA is disconnected */
-						primary_cca->dup_rts_flag = 0;
-
-					if (sec_ch_offset == 1) { /* secondary channel is below the primary channel */
-						if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_lsc * 5 > false_alm_cnt->cnt_bw_usc * 9)) {
-							primary_cca->intf_flag = 1;    /* secondary channel interference is detected!!! */
-							if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
-								primary_cca->intf_type = 1;   	/* interference is shift */
-							else
-								primary_cca->intf_type = 2;   	/* interference is in-band */
-						} else {
-							primary_cca->intf_flag = 0;
-							primary_cca->intf_type = 0;
-						}
-					} else if (sec_ch_offset == 2) { /* secondary channel is above the primary channel */
-						if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_usc * 5 > false_alm_cnt->cnt_bw_lsc * 9)) {
-							primary_cca->intf_flag = 1;    /* secondary channel interference is detected!!! */
-							if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
-								primary_cca->intf_type = 1;   	/* interference is shift */
-							else
-								primary_cca->intf_type = 2;   	/* interference is in-band */
-						} else {
-							primary_cca->intf_flag = 0;
-							primary_cca->intf_type = 0;
-						}
-					}
-					PHYDM_DBG(p_dm, DBG_PRI_CCA, ("primary_cca=%d\n", primary_cca->pri_cca_flag));
-					PHYDM_DBG(p_dm, DBG_PRI_CCA, ("Intf_Type=%d\n", primary_cca->intf_type));
-				}
-				/* 2 STA is Connected */
-				else {
-					if (client_40mhz == 0)		/* 3 */ { /* client BW = 20MHz */
-						if (primary_cca->pri_cca_flag == 0) {
-							primary_cca->pri_cca_flag = 1;
-							if (sec_ch_offset == 1)
-								odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), 2);
-							else if (sec_ch_offset == 2)
-								odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), 1);
-						}
-						PHYDM_DBG(p_dm, DBG_PRI_CCA, ("STA Connected 20M!!! primary_cca=%d\n", primary_cca->pri_cca_flag));
-					} else		/* 3 */ { /* client BW = 40MHz */
-						if (primary_cca->intf_flag == 1) { /* interference is detected!! */
-							if (primary_cca->intf_type == 1) {
-								if (primary_cca->pri_cca_flag != 1) {
-									primary_cca->pri_cca_flag = 1;
-									if (sec_ch_offset == 1)
-										odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), 2);
-									else if (sec_ch_offset == 2)
-										odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), 1);
-								}
-							} else if (primary_cca->intf_type == 2) {
-								if (primary_cca->dup_rts_flag != 1)
-									primary_cca->dup_rts_flag = 1;
-							}
-						} else { /* if intf_flag==0 */
-							if ((cur_tx_ok_cnt + cur_rx_ok_cnt) < 1) { /* idle mode or TP traffic is very low */
-								if (sec_ch_offset == 1) {
-									if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_lsc * 5 > false_alm_cnt->cnt_bw_usc * 9)) {
-										primary_cca->intf_flag = 1;
-										if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
-											primary_cca->intf_type = 1;   	/* interference is shift */
-										else
-											primary_cca->intf_type = 2;   	/* interference is in-band */
-									}
-								} else if (sec_ch_offset == 2) {
-									if ((false_alm_cnt->cnt_ofdm_cca > 800) && (false_alm_cnt->cnt_bw_usc * 5 > false_alm_cnt->cnt_bw_lsc * 9)) {
-										primary_cca->intf_flag = 1;
-										if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
-											primary_cca->intf_type = 1;   	/* interference is shift */
-										else
-											primary_cca->intf_type = 2;   	/* interference is in-band */
-									}
-
-								}
-							} else { /* TP Traffic is High */
-								if (sec_ch_offset == 1) {
-									if (false_alm_cnt->cnt_bw_lsc > (false_alm_cnt->cnt_bw_usc + 500)) {
-										if (delay == 0) { /* add delay to avoid interference occurring abruptly, jump one time */
-											primary_cca->intf_flag = 1;
-											if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
-												primary_cca->intf_type = 1;   	/* interference is shift */
-											else
-												primary_cca->intf_type = 2;   	/* interference is in-band */
-											delay = 1;
-										} else
-											delay = 0;
-									}
-								} else if (sec_ch_offset == 2) {
-									if (false_alm_cnt->cnt_bw_usc > (false_alm_cnt->cnt_bw_lsc + 500)) {
-										if (delay == 0) { /* add delay to avoid interference occurring abruptly */
-											primary_cca->intf_flag = 1;
-											if (false_alm_cnt->cnt_ofdm_fail > false_alm_cnt->cnt_ofdm_cca >> 1)
-												primary_cca->intf_type = 1;   	/* interference is shift */
-											else
-												primary_cca->intf_type = 2;   	/* interference is in-band */
-											delay = 1;
-										} else
-											delay = 0;
-									}
-								}
-							}
-						}
-						PHYDM_DBG(p_dm, DBG_PRI_CCA, ("Primary CCA=%d\n", primary_cca->pri_cca_flag));
-						PHYDM_DBG(p_dm, DBG_PRI_CCA, ("Duplicate RTS=%d\n", primary_cca->dup_rts_flag));
-					}
-
-				} /* end of connected */
-			}
-		}
-		/* 1 Dynamic Primary CCA Monitor counter */
-		if ((primary_cca->pri_cca_flag == 1) || (primary_cca->dup_rts_flag == 1)) {
-			if (client_40mhz == 0) {  /* client=20M no need to monitor primary cca flag */
-				client_40mhz_pre = client_40mhz;
-				return;
-			}
-			counter++;
-			PHYDM_DBG(p_dm, DBG_PRI_CCA, ("counter=%d\n", counter));
-			if ((counter == 30) || ((client_40mhz - client_40mhz_pre) == 1)) { /* Every 60 sec to monitor one time */
-				primary_cca->monitor_flag = 1;     /* monitor flag is triggered!!!!! */
-				if (primary_cca->pri_cca_flag == 1) {
-					primary_cca->pri_cca_flag = 0;
-					odm_set_bb_reg(p_dm, 0xc6c, BIT(8) | BIT(7), 0);
-				}
-				counter = 0;
-			}
-		}
-	}
-
-	client_40mhz_pre = client_40mhz;
+	PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA] Reset\n");
+	pri_cca->mf_state = 0xff;
+	pri_cca->pre_bw = (enum channel_width)0xff;
+	phydm_write_dynamic_cca(dm, MF_USC_LSC);
 }
-#endif
-
-#if (RTL8192E_SUPPORT == 1)
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-void
-odm_dynamic_primary_cca_mp_8192e(
-	void			*p_dm_void
-)
+void phydm_primary_cca_11n(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER	*p_adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct phydm_fa_struct		*false_alm_cnt = &(p_dm->false_alm_cnt);
-	struct phydm_pricca_struct		*primary_cca = &(p_dm->dm_pri_cca);
-	u64			OFDM_CCA, OFDM_FA, bw_usc_cnt, bw_lsc_cnt;
-	u8			sec_ch_offset;
-	static u8		count_down = PRI_CCA_MONITOR_TIME;
-
-	if (!p_dm->is_linked)
-		return;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct *pri_cca = &dm->dm_pri_cca;
+	enum channel_width curr_bw = (enum channel_width)*dm->band_width;
 
-	if (!(p_dm->support_ability & ODM_BB_PRIMARY_CCA))
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
 		return;
 
-	OFDM_CCA = false_alm_cnt->cnt_ofdm_cca;
-	OFDM_FA = false_alm_cnt->cnt_ofdm_fail;
-	bw_usc_cnt = false_alm_cnt->cnt_bw_usc;
-	bw_lsc_cnt = false_alm_cnt->cnt_bw_lsc;
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: OFDM CCA=%d\n", OFDM_CCA));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: OFDM FA=%d\n", OFDM_FA));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: BW_USC=%d\n", bw_usc_cnt));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: BW_LSC=%d\n", bw_lsc_cnt));
-	sec_ch_offset = *(p_dm->p_sec_ch_offset);		/* NIC: 2: sec is below,  1: sec is above */
-
-	
-	if (IsAPModeExist(p_adapter)) {
-		phydm_write_dynamic_cca(p_dm, MF_USC_LSC);
-		return;
-	}
-
-	if (*(p_dm->p_band_width) != CHANNEL_WIDTH_40)
-		return;
-
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: Cont Down= %d\n", count_down));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: Primary_CCA_flag=%d\n", primary_cca->pri_cca_flag));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: Intf_Type=%d\n", primary_cca->intf_type));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: Intf_flag=%d\n", primary_cca->intf_flag));
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: Duplicate RTS Flag=%d\n", primary_cca->dup_rts_flag));
-
-	if (primary_cca->pri_cca_flag == 0) {
-
-		if (sec_ch_offset == SECOND_CH_AT_LSB) {  /* Primary channel is above   NOTE: duplicate CTS can remove this condition */
-
-			if ((OFDM_CCA > OFDMCCA_TH) && (bw_lsc_cnt > (bw_usc_cnt + bw_ind_bias))
-			    && (OFDM_FA > (OFDM_CCA >> 1))) {
-
-				primary_cca->intf_type = 1;
-				primary_cca->intf_flag = 1;
-				phydm_write_dynamic_cca(p_dm, MF_USC);
-				primary_cca->pri_cca_flag = 1;
-			} else if ((OFDM_CCA > OFDMCCA_TH) && (bw_lsc_cnt > (bw_usc_cnt + bw_ind_bias))
-				&& (OFDM_FA < (OFDM_CCA >> 1))) {
-
-				primary_cca->intf_type = 2;
-				primary_cca->intf_flag = 1;
-				phydm_write_dynamic_cca(p_dm, MF_USC);
-				primary_cca->pri_cca_flag = 1;
-				primary_cca->dup_rts_flag = 1;
-				p_hal_data->RTSEN = 1;
-			} else {
-
-				primary_cca->intf_type = 0;
-				primary_cca->intf_flag = 0;
-				phydm_write_dynamic_cca(p_dm, MF_USC_LSC);
-				p_hal_data->RTSEN = 0;
-				primary_cca->dup_rts_flag = 0;
-			}
-
-		} else if (sec_ch_offset == SECOND_CH_AT_USB) {
-
-			if ((OFDM_CCA > OFDMCCA_TH) && (bw_usc_cnt > (bw_lsc_cnt + bw_ind_bias))
-			    && (OFDM_FA > (OFDM_CCA >> 1))) {
-
-				primary_cca->intf_type = 1;
-				primary_cca->intf_flag = 1;
-				phydm_write_dynamic_cca(p_dm, MF_LSC);
-				primary_cca->pri_cca_flag = 1;
-			} else if ((OFDM_CCA > OFDMCCA_TH) && (bw_usc_cnt > (bw_lsc_cnt + bw_ind_bias))
-				&& (OFDM_FA < (OFDM_CCA >> 1))) {
-
-				primary_cca->intf_type = 2;
-				primary_cca->intf_flag = 1;
-				phydm_write_dynamic_cca(p_dm, MF_LSC);
-				primary_cca->pri_cca_flag = 1;
-				primary_cca->dup_rts_flag = 1;
-				p_hal_data->RTSEN = 1;
-			} else {
-
-				primary_cca->intf_type = 0;
-				primary_cca->intf_flag = 0;
-				phydm_write_dynamic_cca(p_dm, MF_USC_LSC);
-				p_hal_data->RTSEN = 0;
-				primary_cca->dup_rts_flag = 0;
-			}
+	if (!dm->is_linked) {
+		PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA][No Link!!!]\n");
 
+		if (pri_cca->pri_cca_is_become_linked) {
+			phydm_primary_cca_reset(dm);
+			pri_cca->pri_cca_is_become_linked = dm->is_linked;
 		}
-
-	} else {	/* primary_cca->pri_cca_flag==1 */
-
-		count_down--;
-		if (count_down == 0) {
-			count_down = PRI_CCA_MONITOR_TIME;
-			primary_cca->pri_cca_flag = 0;
-			phydm_write_dynamic_cca(p_dm, MF_USC_LSC);   /* default */
-			p_hal_data->RTSEN = 0;
-			primary_cca->dup_rts_flag = 0;
-			primary_cca->intf_type = 0;
-			primary_cca->intf_flag = 0;
-		}
-
-	}
-}
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-void
-odm_intf_detection(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fa_struct		*false_alm_cnt = &(p_dm->false_alm_cnt);
-	struct phydm_pricca_struct			*primary_cca = &(p_dm->dm_pri_cca);
-
-	if ((false_alm_cnt->cnt_ofdm_cca > OFDMCCA_TH)
-	    && (false_alm_cnt->cnt_bw_lsc > (false_alm_cnt->cnt_bw_usc + bw_ind_bias))) {
-
-		primary_cca->intf_flag = 1;
-		primary_cca->CH_offset = 1;  /* 1:LSC, 2:USC */
-		if (false_alm_cnt->cnt_ofdm_fail > (false_alm_cnt->cnt_ofdm_cca >> 1))
-			primary_cca->intf_type = 1;
-		else
-			primary_cca->intf_type = 2;
-	} else if ((false_alm_cnt->cnt_ofdm_cca > OFDMCCA_TH)
-		&& (false_alm_cnt->cnt_bw_usc > (false_alm_cnt->cnt_bw_lsc + bw_ind_bias))) {
-
-		primary_cca->intf_flag = 1;
-		primary_cca->CH_offset = 2;  /* 1:LSC, 2:USC */
-		if (false_alm_cnt->cnt_ofdm_fail > (false_alm_cnt->cnt_ofdm_cca >> 1))
-			primary_cca->intf_type = 1;
-		else
-			primary_cca->intf_type = 2;
-	} else {
-		primary_cca->intf_flag = 0;
-		primary_cca->intf_type = 0;
-		primary_cca->CH_offset = 0;
-	}
-
-}
-
-void
-odm_dynamic_primary_cca_ap_8192e(
-	void			*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pricca_struct		*primary_cca = &(p_dm->dm_pri_cca);
-	u8		i;
-	static u32	count_down = PRI_CCA_MONITOR_TIME;
-	u8		STA_BW = false, STA_BW_pre = false, STA_BW_TMP = false;
-	boolean		is_connected = false;
-	u8		sec_ch_offset;
-	u8		cur_mf_state;
-	struct cmn_sta_info	*p_entry;
-
-	if (!p_dm->is_linked)
 		return;
-
-	if (!(p_dm->support_ability & ODM_BB_PRIMARY_CCA))
-		return;
-
-	sec_ch_offset = *(p_dm->p_sec_ch_offset);		/* AP: 1: sec is below,  2: sec is above */
-
-	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		p_entry = p_dm->p_phydm_sta_info[i];
-		if (is_sta_active(p_entry)) {
-
-			STA_BW_TMP = p_entry->bw_mode;
-			if (STA_BW_TMP > STA_BW)
-				STA_BW = STA_BW_TMP;
-			is_connected = true;
+	} else {
+		if (!pri_cca->pri_cca_is_become_linked) {
+			PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA][Linked !!!]\n");
+			pri_cca->pri_cca_is_become_linked = dm->is_linked;
 		}
 	}
 
-	if (*(p_dm->p_band_width) == CHANNEL_WIDTH_40) {
-		
-		if (primary_cca->pri_cca_flag == 0) {
-			if (is_connected) {
-				if (STA_BW == CHANNEL_WIDTH_20) { /* 2 STA BW=20M */
-					primary_cca->pri_cca_flag = 1;
-					if (sec_ch_offset == 1) {
-						cur_mf_state = MF_USC;
-						phydm_write_dynamic_cca(p_dm, cur_mf_state);
-					} else if (sec_ch_offset == 2) {
-						cur_mf_state = MF_USC;
-						phydm_write_dynamic_cca(p_dm, cur_mf_state);
-					}
-				} else {     			/* 2  STA BW=40M */
-					if (primary_cca->intf_flag == 0)
-						odm_intf_detection(p_dm);
-					else {	/* intf_flag = 1 */
-						if (primary_cca->intf_type == 1) {
-							if (primary_cca->CH_offset == 1) {
-								cur_mf_state = MF_USC;
-								if (sec_ch_offset == 1)  /* AP,  1: primary is above  2: primary is below */
-									phydm_write_dynamic_cca(p_dm, cur_mf_state);
-							} else if (primary_cca->CH_offset == 2) {
-								cur_mf_state = MF_LSC;
-								if (sec_ch_offset == 2)
-									phydm_write_dynamic_cca(p_dm, cur_mf_state);
-							}
-						} else if (primary_cca->intf_type == 2)
-							PHYDM_DBG(p_dm, DBG_PRI_CCA, ("92E: primary_cca->intf_type = 2\n"));
-					}
-				}
-
-			} else		/* disconnected  interference detection */
-				odm_intf_detection(p_dm); /* end of disconnected */
+	if (curr_bw != pri_cca->pre_bw) {
+		PHYDM_DBG(dm, DBG_PRI_CCA, "[Primary CCA] start ==>\n");
+		pri_cca->pre_bw = curr_bw;
 
-
-		} else {	/* primary_cca->pri_cca_flag == 1 */
-
-			if (STA_BW == 0) {
-				STA_BW_pre = STA_BW;
-				return;
-			}
-
-			count_down--;
-			if ((count_down == 0) || ((STA_BW & STA_BW_pre) != 1)) {
-				count_down = PRI_CCA_MONITOR_TIME;
-				primary_cca->pri_cca_flag = 0;
-				primary_cca->intf_type = 0;
-				primary_cca->intf_flag = 0;
-				cur_mf_state = MF_USC_LSC;
-				phydm_write_dynamic_cca(p_dm, cur_mf_state); /* default */
+		if (curr_bw == CHANNEL_WIDTH_40) {
+			if (*dm->sec_ch_offset == SECOND_CH_AT_LSB) {
+			/* Primary CH @ upper sideband*/
+				PHYDM_DBG(dm, DBG_PRI_CCA,
+					  "BW40M, Primary CH at USB\n");
+				phydm_write_dynamic_cca(dm, MF_USC);
+			} else {
+			/*Primary CH @ lower sideband*/
+				PHYDM_DBG(dm, DBG_PRI_CCA,
+					  "BW40M, Primary CH at LSB\n");
+				phydm_write_dynamic_cca(dm, MF_LSC);
 			}
+		} else {
+			PHYDM_DBG(dm, DBG_PRI_CCA, "Not BW40M, USB + LSB\n");
+			phydm_primary_cca_reset(dm);
 		}
-		STA_BW_pre = STA_BW;
-
-	} else {
-		/* 2 Reset */
-		phydm_primary_cca_init(p_dm);
-		cur_mf_state = MF_USC_LSC;
-		phydm_write_dynamic_cca(p_dm, cur_mf_state);
-		count_down = PRI_CCA_MONITOR_TIME;
 	}
-
 }
-#endif
-
-
-#endif /* RTL8192E_SUPPORT == 1 */
-#endif
-
-
-#endif
 
 boolean
-odm_dynamic_primary_cca_dup_rts(
-	void			*p_dm_void
-)
+odm_dynamic_primary_cca_dup_rts(void *dm_void)
 {
-#ifdef PHYDM_PRIMARY_CCA
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pricca_struct		*primary_cca = &(p_dm->dm_pri_cca);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct *pri_cca = &dm->dm_pri_cca;
 
-	return	primary_cca->dup_rts_flag;
-#else
-	return	0;	
-#endif
+	return pri_cca->dup_rts_flag;
 }
 
-void
-phydm_primary_cca_init(
-	void			*p_dm_void
-)
+void phydm_primary_cca_init(void *dm_void)
 {
-#ifdef PHYDM_PRIMARY_CCA
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_pricca_struct		*primary_cca = &(p_dm->dm_pri_cca);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_pricca_struct *pri_cca = &dm->dm_pri_cca;
+
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
+		return;
 
-	if (!(p_dm->support_ability & ODM_BB_PRIMARY_CCA))
+	if (!(dm->support_ic_type & ODM_IC_11N_SERIES))
 		return;
 
-	PHYDM_DBG(p_dm, DBG_PRI_CCA, ("[PriCCA] Init ==>\n"));
-	#if (RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1)
-	primary_cca->dup_rts_flag = 0;
-	primary_cca->intf_flag = 0;
-	primary_cca->intf_type = 0;
-	primary_cca->monitor_flag = 0;
-	primary_cca->pri_cca_flag = 0;
-	primary_cca->ch_offset = 0;
-	#endif
-	primary_cca->mf_state = 0xff;
-	primary_cca->pre_bw = (enum channel_width)0xff;
-	
-	if (p_dm->support_ic_type & ODM_IC_11N_SERIES)
-		primary_cca->cca_th_40m_bkp = (u8)odm_get_bb_reg(p_dm, 0xc84, 0xf0000000);
+	PHYDM_DBG(dm, DBG_PRI_CCA, "[PriCCA] Init ==>\n");
+#if (RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1)
+	pri_cca->dup_rts_flag = 0;
+	pri_cca->intf_flag = 0;
+	pri_cca->intf_type = 0;
+	pri_cca->monitor_flag = 0;
+	pri_cca->pri_cca_flag = 0;
+	pri_cca->ch_offset = 0;
 #endif
+	pri_cca->mf_state = 0xff;
+	pri_cca->pre_bw = (enum channel_width)0xff;
+	pri_cca->cca_th_40m_bkp = (u8)odm_get_bb_reg(dm, R_0xc84, 0xf0000000);
 }
 
-void
-phydm_primary_cca(
-	void			*p_dm_void
-)
+void phydm_primary_cca(void *dm_void)
 {
 #ifdef PHYDM_PRIMARY_CCA
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (!(p_dm->support_ic_type & ODM_IC_11N_SERIES))
+	if (!(dm->support_ic_type & ODM_IC_11N_SERIES))
 		return;
 
-	if (!(p_dm->support_ability & ODM_BB_PRIMARY_CCA))
+	if (!(dm->support_ability & ODM_BB_PRIMARY_CCA))
 		return;
 
-	phydm_primary_cca_11n(p_dm);
+	phydm_primary_cca_11n(dm);
 
 #endif
 }
-
-
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.h
index 6d41eec81eb4..867d69fd5f3c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_primary_cca.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,48 +9,56 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDM_PRIMARYCCA_H__
-#define	__PHYDM_PRIMARYCCA_H__
+#ifndef __PHYDM_PRIMARYCCA_H__
+#define __PHYDM_PRIMARYCCA_H__
 
-#define PRIMARYCCA_VERSION	"1.0"  /*2017.03.23, Dino*/
+#ifdef PHYDM_PRIMARY_CCA
+#define PRIMARYCCA_VERSION "2.0"
 
-/*============================================================*/
-/*Definition */
-/*============================================================*/
+/*@============================================================*/
+/*@Definition */
+/*@============================================================*/
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-#define	SECOND_CH_AT_LSB	2	/*primary CH @ MSB,  SD4: HAL_PRIME_CHNL_OFFSET_UPPER*/
-#define	SECOND_CH_AT_USB	1	/*primary CH @ LSB,   SD4: HAL_PRIME_CHNL_OFFSET_LOWER*/
+#define	SECOND_CH_AT_LSB	2	/*@primary CH @ MSB,  SD4: HAL_PRIME_CHNL_OFFSET_UPPER*/
+#define	SECOND_CH_AT_USB	1	/*@primary CH @ LSB,   SD4: HAL_PRIME_CHNL_OFFSET_LOWER*/
 #elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-#define	SECOND_CH_AT_LSB	2	/*primary CH @ MSB,  SD7: HAL_PRIME_CHNL_OFFSET_UPPER*/
-#define	SECOND_CH_AT_USB	1	/*primary CH @ LSB,   SD7: HAL_PRIME_CHNL_OFFSET_LOWER*/
+#define	SECOND_CH_AT_LSB	2	/*@primary CH @ MSB,  SD7: HAL_PRIME_CHNL_OFFSET_UPPER*/
+#define	SECOND_CH_AT_USB	1	/*@primary CH @ LSB,   SD7: HAL_PRIME_CHNL_OFFSET_LOWER*/
 #else /*if (DM_ODM_SUPPORT_TYPE == ODM_AP)*/
-#define	SECOND_CH_AT_LSB	1	/*primary CH @ MSB,  SD8: HT_2NDCH_OFFSET_BELOW*/
-#define	SECOND_CH_AT_USB	2	/*primary CH @ LSB,   SD8: HT_2NDCH_OFFSET_ABOVE*/
+#define	SECOND_CH_AT_LSB	1	/*@primary CH @ MSB,  SD8: HT_2NDCH_OFFSET_BELOW*/
+#define	SECOND_CH_AT_USB	2	/*@primary CH @ LSB,   SD8: HT_2NDCH_OFFSET_ABOVE*/
 #endif
 
-#define	OFDMCCA_TH	500
+#define	OFDMCCA_TH		500
 #define	bw_ind_bias		500
 #define	PRI_CCA_MONITOR_TIME	30
 
-#ifdef PHYDM_PRIMARY_CCA
-
-/*============================================================*/
+/*@============================================================*/
 /*structure and define*/
-/*============================================================*/
-enum	primary_cca_ch_position {  /*N-series REG0xc6c[8:7]*/
-	MF_USC_LSC = 0,
-	MF_LSC = 1,
-	MF_USC = 2
+/*@============================================================*/
+enum primary_cca_ch_position { /*N-series REG0xc6c[8:7]*/
+	MF_USC_LSC	= 0,
+	MF_LSC		= 1,
+	MF_USC		= 2
 };
 
 struct phydm_pricca_struct {
-
 	#if (RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1)
 	u8	pri_cca_flag;
 	u8	intf_flag;
@@ -58,60 +67,22 @@ struct phydm_pricca_struct {
 	u8	ch_offset;
 	#endif
 	u8	dup_rts_flag;
-	u8	cca_th_40m_bkp; /*c84[31:28]*/
+	u8	cca_th_40m_bkp; /*@c84[31:28]*/
 	enum channel_width	pre_bw;
 	u8	pri_cca_is_become_linked;
 	u8	mf_state;
 };
 
-/*============================================================*/
-/*function prototype*/
-/*============================================================*/
-
-#if 0
-#if (RTL8192E_SUPPORT == 1)
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-void
-odm_dynamic_primary_cca_mp_8192e(
-	void			*p_dm_void
-);
-
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-
-void
-odm_dynamic_primary_cca_ap_8192e(
-	void			*p_dm_void
-);
-#endif
-#endif
-
-#if (RTL8188E_SUPPORT == 1)
-
-void
-odm_dynamic_primary_cca_8188e(
-	void			*p_dm_void
-);
-#endif
-#endif
-
-#endif /*#ifdef PHYDM_PRIMARY_CCA*/
-
-
-boolean
-odm_dynamic_primary_cca_dup_rts(
-	void			*p_dm_void
-);
+/*@============================================================*/
+/*@function prototype*/
+/*@============================================================*/
+void phydm_write_dynamic_cca(void *dm_void, u8 curr_mf_state);
 
-void
-phydm_primary_cca_init(
-	void			*p_dm_void
-);
+boolean odm_dynamic_primary_cca_dup_rts(void *dm_void);
 
-void
-phydm_primary_cca(
-	void			*p_dm_void
-);
+void phydm_primary_cca_init(void *dm_void);
 
+void phydm_primary_cca(void *dm_void);
+#endif /*@#ifdef PHYDM_PRIMARY_CCA*/
+#endif /*@#ifndef	__PHYDM_PRIMARYCCA_H__*/
 
-#endif /*#ifndef	__PHYDM_PRIMARYCCA_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.c
index 7ff50f2e590b..f8d70f4dce82 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,243 +9,295 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-//============================================================
-// include files
-//============================================================
+/******************************************************************************
+ * include files
+ *****************************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
 #ifdef CONFIG_PSD_TOOL
-
-u32
-phydm_get_psd_data(
-	void			*p_dm_void,
-	u32			psd_tone_idx,
-	u32			igi
-	)
+u32 phydm_get_psd_data(void *dm_void, u32 psd_tone_idx, u32 igi)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	_PHYDM_PSD_	*p_dm_psd_table = &(p_dm->dm_psd_table);
-	u32		psd_report = 0;
-	
-	odm_set_bb_reg(p_dm, p_dm_psd_table->psd_reg, 0x3ff, psd_tone_idx);
-	
-	odm_set_bb_reg(p_dm, p_dm_psd_table->psd_reg, BIT(22), 1); /*PSD trigger start*/
-	ODM_delay_us(10);
-	odm_set_bb_reg(p_dm, p_dm_psd_table->psd_reg, BIT(22), 0); /*PSD trigger stop*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct psd_info *dm_psd_table = &dm->dm_psd_table;
+	u32 psd_report = 0;
+
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		odm_set_bb_reg(dm, R_0x1e8c, 0x3ff, psd_tone_idx & 0x3ff);
+		odm_set_bb_reg(dm, R_0x1e88, BIT(27) | BIT(26),
+			       psd_tone_idx >> 10);
+		/*PSD trigger start*/
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(18), 1);
+		ODM_delay_us(10);
+		/*PSD trigger stop*/
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(18), 0);
+	} else if (dm->support_ic_type == ODM_RTL8721D) {
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, 0xfff, psd_tone_idx);
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(28), 1);
+		/*PSD trigger start*/
+		ODM_delay_us(10);
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(28), 0);
+		/*PSD trigger stop*/
+
+		psd_report = odm_get_bb_reg(dm, dm_psd_table->psd_report_reg,
+					    0xffffff);
+		psd_report = psd_report >> 5;
+	} else {
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, 0x3ff, psd_tone_idx);
+		/*PSD trigger start*/
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(22), 1);
+		ODM_delay_us(10);
+		/*PSD trigger stop*/
+		odm_set_bb_reg(dm, dm_psd_table->psd_reg, BIT(22), 0);
+	}
 
-	psd_report = odm_get_bb_reg(p_dm, p_dm_psd_table->psd_report_reg, 0xffff);
-	psd_report = odm_convert_to_db(psd_report) + igi;
+	if (dm->support_ic_type & ODM_RTL8821C) {
+		psd_report = odm_get_bb_reg(dm, dm_psd_table->psd_report_reg,
+					    0xffffff);
+		psd_report = psd_report >> 5;
+	} else if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		psd_report = odm_get_bb_reg(dm, dm_psd_table->psd_report_reg,
+					    0xffffff);
+	} else {
+		psd_report = odm_get_bb_reg(dm, dm_psd_table->psd_report_reg,
+					    0xffff);
+	}
+	psd_report = odm_convert_to_db((u64)psd_report) + igi;
 
 	return psd_report;
 }
 
-u8		psd_result_cali_tone_8821[7]= {21, 28, 33, 93, 98, 105, 127};
-u8		psd_result_cali_val_8821[7] = {67,69,71,72,71,69,67};	
+u8 psd_result_cali_tone_8821[7] = {21, 28, 33, 93, 98, 105, 127};
+u8 psd_result_cali_val_8821[7] = {67, 69, 71, 72, 71, 69, 67};
 
-void
-phydm_psd(
-	void		*p_dm_void,
-	u32		igi,
-	u16		start_point,
-	u16		stop_point
-	)
+u8 phydm_psd(void *dm_void, u32 igi, u16 start_point, u16 stop_point)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	_PHYDM_PSD_	*p_dm_psd_table = &(p_dm->dm_psd_table);
-	u32		i = 0, mod_tone_idx;
-	u32		t = 0;
-	u16		fft_max_half_bw;
-	u32		psd_igi_a_reg;
-	u32		psd_igi_b_reg;
-	u16		psd_fc_channel = p_dm_psd_table->psd_fc_channel;
-	u8		ag_rf_mode_reg = 0;
-	u8		rf_reg18_9_8 = 0;
-	u32		psd_result_tmp = 0;
-	u8		psd_result = 0;
-	u8		psd_result_cali_tone[7] = {0};
-	u8		psd_result_cali_val[7] = {0};
-	u8		noise_table_idx = 0;
-	u8		set_result;
-
-	if (p_dm->support_ic_type == ODM_RTL8821) {
-		odm_move_memory(p_dm, psd_result_cali_tone, psd_result_cali_tone_8821, 7);
-		odm_move_memory(p_dm, psd_result_cali_val, psd_result_cali_val_8821, 7);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct psd_info *dm_psd_table = &dm->dm_psd_table;
+	u32 i = 0, mod_tone_idx = 0;
+	u32 t = 0;
+	u16 fft_max_half_bw = 0;
+	u16 psd_fc_channel = dm_psd_table->psd_fc_channel;
+	u8 ag_rf_mode_reg = 0;
+	u8 is_5G = 0;
+	u32 psd_result_tmp = 0;
+	u8 psd_result = 0;
+	u8 psd_result_cali_tone[7] = {0};
+	u8 psd_result_cali_val[7] = {0};
+	u8 noise_idx = 0;
+	u8 set_result = 0;
+	u32 igi_tmp = 0x6e;
+
+	if (dm->support_ic_type == ODM_RTL8821) {
+		odm_move_memory(dm, psd_result_cali_tone,
+				psd_result_cali_tone_8821, 7);
+		odm_move_memory(dm, psd_result_cali_val,
+				psd_result_cali_val_8821, 7);
 	}
-	
-	p_dm_psd_table->psd_in_progress = 1;
-
-	/*[Stop DIG]*/
-	p_dm->support_ability &= ~(ODM_BB_DIG);
-	p_dm->support_ability &= ~(ODM_BB_FA_CNT);
 
+	dm_psd_table->psd_in_progress = 1;
 
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD Start =>\n");
 
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("PSD Start =>\n"));
-
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		psd_igi_a_reg = 0xc50;
-		psd_igi_b_reg = 0xe50;
-	} else {
-		psd_igi_a_reg = 0xc50;
-		psd_igi_b_reg = 0xc58;
+	/* @[Stop DIG]*/
+	/* @IGI target at 0dBm & make it can't CCA*/
+	if (phydm_pause_func(dm, F00_DIG, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_3, 1,
+			     &igi_tmp) == PAUSE_FAIL) {
+		return PHYDM_SET_FAIL;
 	}
-	
-	/*[back up IGI]*/
-	p_dm_psd_table->initial_gain_backup = odm_get_bb_reg(p_dm, psd_igi_a_reg, 0xff);
-	odm_set_bb_reg(p_dm, psd_igi_a_reg, 0xff, 0x6e); /*IGI target at 0dBm & make it can't CCA*/
-	odm_set_bb_reg(p_dm, psd_igi_b_reg, 0xff, 0x6e); /*IGI target at 0dBm & make it can't CCA*/
+
 	ODM_delay_us(10);
-	
-	if (phydm_stop_ic_trx(p_dm, PHYDM_SET) == PHYDM_SET_FAIL) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("STOP_TRX_FAIL\n"));
-		return;
+
+	if (phydm_stop_ic_trx(dm, PHYDM_SET) == PHYDM_SET_FAIL) {
+		phydm_pause_func(dm, F00_DIG, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_3,
+				 1, &igi_tmp);
+		return PHYDM_SET_FAIL;
 	}
 
-	/*[Set IGI]*/
-	odm_set_bb_reg(p_dm, psd_igi_a_reg, 0xff, igi);
-	odm_set_bb_reg(p_dm, psd_igi_b_reg, 0xff, igi);
-	
-	/*[Backup RF Reg]*/
-	p_dm_psd_table->rf_0x18_bkp = odm_get_rf_reg(p_dm, RF_PATH_A, 0x18, RFREGOFFSETMASK);
-	p_dm_psd_table->rf_0x18_bkp_b = odm_get_rf_reg(p_dm, RF_PATH_B, 0x18, RFREGOFFSETMASK);
+	/* @[Set IGI]*/
+	phydm_write_dig_reg(dm, (u8)igi);
+
+	/* @[Backup RF Reg]*/
+	dm_psd_table->rf_0x18_bkp = odm_get_rf_reg(dm, RF_PATH_A, RF_0x18,
+						   RFREG_MASK);
+	dm_psd_table->rf_0x18_bkp_b = odm_get_rf_reg(dm, RF_PATH_B, RF_0x18,
+						     RFREG_MASK);
 
 	if (psd_fc_channel > 14) {
-		
-		rf_reg18_9_8 = 1;
-		
-		if (36 <= psd_fc_channel && psd_fc_channel <= 64) 
-			ag_rf_mode_reg = 0x1;
-		else if (100 <= psd_fc_channel && psd_fc_channel <= 140) 
-			ag_rf_mode_reg = 0x3; 
-		else if (140 < psd_fc_channel) 
-			ag_rf_mode_reg = 0x5; 
+		is_5G = 1;
+		if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8812F)) {
+			if (psd_fc_channel < 80)
+				ag_rf_mode_reg = 0x1;
+			else if (psd_fc_channel >= 80 && psd_fc_channel <= 140)
+				ag_rf_mode_reg = 0x3;
+			else if (psd_fc_channel > 140)
+				ag_rf_mode_reg = 0x5;
+		} else if (dm->support_ic_type == ODM_RTL8721D) {
+			if (psd_fc_channel >= 36 && psd_fc_channel <= 64)
+				ag_rf_mode_reg = 0x1;
+			else if (psd_fc_channel >= 100 && psd_fc_channel <= 140)
+				ag_rf_mode_reg = 0x5;
+			else if (psd_fc_channel > 140)
+				ag_rf_mode_reg = 0x9;
+		} else {
+			if (psd_fc_channel >= 36 && psd_fc_channel <= 64)
+				ag_rf_mode_reg = 0x1;
+			else if (psd_fc_channel >= 100 && psd_fc_channel <= 140)
+				ag_rf_mode_reg = 0x3;
+			else if (psd_fc_channel > 140)
+				ag_rf_mode_reg = 0x5;
+		}
+	}
+
+	/* Set RF fc*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, 0xff, psd_fc_channel);
+	odm_set_rf_reg(dm, RF_PATH_B, RF_0x18, 0xff, psd_fc_channel);
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, 0x300, is_5G);
+	odm_set_rf_reg(dm, RF_PATH_B, RF_0x18, 0x300, is_5G);
+	if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8812F)) {
+		/* @2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, 0x3000,
+			       dm_psd_table->psd_bw_rf_reg);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x18, 0x3000,
+			       dm_psd_table->psd_bw_rf_reg);
+		/* Set RF ag fc mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, 0x70000,
+			       ag_rf_mode_reg);
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x18, 0x70000,
+			       ag_rf_mode_reg);
+	} else {
+		/* @2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		if (dm->support_ic_type == ODM_RTL8721D) {
+			odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, 0x1c00,
+				       dm_psd_table->psd_bw_rf_reg);
+		} else {
+			odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, 0xc00,
+				       dm_psd_table->psd_bw_rf_reg);
+		}
+			odm_set_rf_reg(dm, RF_PATH_B, RF_0x18, 0xc00,
+				       dm_psd_table->psd_bw_rf_reg);
+			/* Set RF ag fc mode*/
+			odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, 0xf0000,
+				       ag_rf_mode_reg);
+			odm_set_rf_reg(dm, RF_PATH_B, RF_0x18, 0xf0000,
+				       ag_rf_mode_reg);
 	}
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+		PHYDM_DBG(dm, ODM_COMP_API, "0x1d70=((0x%x))\n",
+			  odm_get_bb_reg(dm, R_0x1d70, MASKDWORD));
+	else
+		PHYDM_DBG(dm, ODM_COMP_API, "0xc50=((0x%x))\n",
+			  odm_get_bb_reg(dm, R_0xc50, MASKDWORD));
+
+	PHYDM_DBG(dm, ODM_COMP_API, "RF0x18=((0x%x))\n",
+		  odm_get_rf_reg(dm, RF_PATH_A, RF_0x18, RFREG_MASK));
+
+	/* @[Stop 3-wires]*/
+	phydm_stop_3_wire(dm, PHYDM_SET);
 
-	/* RF path-a */
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x18, 0xff, psd_fc_channel);     /* Set RF fc*/
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x18, 0x300, rf_reg18_9_8);
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x18, 0xc00, p_dm_psd_table->psd_bw_rf_reg);     /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x18, 0xf0000, ag_rf_mode_reg);     /* Set RF ag fc mode*/
-
-	/* RF path-b */
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0x18, 0xff, psd_fc_channel);     /* Set RF fc*/
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0x18, 0x300, rf_reg18_9_8);
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0x18, 0xc00, p_dm_psd_table->psd_bw_rf_reg);     /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0x18, 0xf0000, ag_rf_mode_reg);     /* Set RF ag fc mode*/
-
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("0xc50=((0x%x))\n", odm_get_bb_reg(p_dm, 0xc50, MASKDWORD)));
-	/*PHYDM_DBG(p_dm, ODM_COMP_API, ("RF0x0=((0x%x))\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x0, RFREGOFFSETMASK)));*/
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("RF0x18=((0x%x))\n", odm_get_rf_reg(p_dm, RF_PATH_A, 0x18, RFREGOFFSETMASK)));
-	
-	/*[Stop 3-wires]*/
-	phydm_stop_3_wire(p_dm, PHYDM_SET);
-	
 	ODM_delay_us(10);
 
-	if (stop_point > (p_dm_psd_table->fft_smp_point-1))
-		stop_point = (p_dm_psd_table->fft_smp_point-1);	
+	if (stop_point > (dm_psd_table->fft_smp_point - 1))
+		stop_point = (dm_psd_table->fft_smp_point - 1);
 
-	if (start_point > (p_dm_psd_table->fft_smp_point-1))
-		start_point = (p_dm_psd_table->fft_smp_point-1);
+	if (start_point > (dm_psd_table->fft_smp_point - 1))
+		start_point = (dm_psd_table->fft_smp_point - 1);
 
 	if (start_point > stop_point)
 		stop_point = start_point;
 
+	for (i = start_point; i <= stop_point; i++) {
+		fft_max_half_bw = (dm_psd_table->fft_smp_point) >> 1;
 
-	for (i = start_point; i <= stop_point; i++ ) {
-
-		fft_max_half_bw = (p_dm_psd_table->fft_smp_point)>>1;
-
-		if (i < fft_max_half_bw) {
+		if (i < fft_max_half_bw)
 			mod_tone_idx = i + fft_max_half_bw;
-		} else {
+		else
 			mod_tone_idx = i - fft_max_half_bw;
-		}
-		
-		psd_result_tmp = 0;
-		for (t = 0; t < p_dm_psd_table->sw_avg_time; t++) {
-			psd_result_tmp += phydm_get_psd_data(p_dm, mod_tone_idx, igi);
-			/**/
-		}
-		psd_result = (u8)((psd_result_tmp/p_dm_psd_table->sw_avg_time)) - p_dm_psd_table->psd_pwr_common_offset;
-
-		if( p_dm_psd_table->fft_smp_point == 128 && (p_dm_psd_table->noise_k_en)) {
-
-			if (i > psd_result_cali_tone[noise_table_idx]) {
-				noise_table_idx ++;
-			}
 
-			if (noise_table_idx > 6)
-				noise_table_idx = 6;
-
-			if (psd_result >= psd_result_cali_val[noise_table_idx])
-				psd_result = psd_result - psd_result_cali_val[noise_table_idx];
+		psd_result_tmp = 0;
+		for (t = 0; t < dm_psd_table->sw_avg_time; t++)
+			psd_result_tmp += phydm_get_psd_data(dm, mod_tone_idx,
+							     igi);
+		psd_result =
+			(u8)((psd_result_tmp / dm_psd_table->sw_avg_time)) -
+			dm_psd_table->psd_pwr_common_offset;
+
+		if (dm_psd_table->fft_smp_point == 128 &&
+		    dm_psd_table->noise_k_en) {
+			if (i > psd_result_cali_tone[noise_idx])
+				noise_idx++;
+
+			if (noise_idx > 6)
+				noise_idx = 6;
+
+			if (psd_result >= psd_result_cali_val[noise_idx])
+				psd_result = psd_result -
+					     psd_result_cali_val[noise_idx];
 			else
 				psd_result = 0;
-			
 
-			p_dm_psd_table->psd_result[i] = psd_result;
+			dm_psd_table->psd_result[i] = psd_result;
 		}
-		
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("[%d] N_cali = %d, PSD = %d\n", mod_tone_idx, psd_result_cali_val[noise_table_idx],  psd_result));
 
+		PHYDM_DBG(dm, ODM_COMP_API, "[%d] N_cali = %d, PSD = %d\n",
+			  mod_tone_idx, psd_result_cali_val[noise_idx],
+			  psd_result);
 	}
 
-	/*[Start 3-wires]*/
-	phydm_stop_3_wire(p_dm, PHYDM_REVERT);
-	
+	/*@[Start 3-wires]*/
+	phydm_stop_3_wire(dm, PHYDM_REVERT);
+
 	ODM_delay_us(10);
 
-	/*[Revert Reg]*/
-	set_result = phydm_stop_ic_trx(p_dm, PHYDM_REVERT);
-	
-	odm_set_bb_reg(p_dm, psd_igi_a_reg, 0xff, p_dm_psd_table->initial_gain_backup);
-	odm_set_bb_reg(p_dm, psd_igi_b_reg, 0xff, p_dm_psd_table->initial_gain_backup);
-	
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, p_dm_psd_table->rf_0x18_bkp);
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0x18, RFREGOFFSETMASK, p_dm_psd_table->rf_0x18_bkp_b);
-	
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("PSD finished\n\n"));
-	
-	p_dm->support_ability |= ODM_BB_DIG;
-	p_dm->support_ability |= ODM_BB_FA_CNT;
-	p_dm_psd_table->psd_in_progress = 0;
-	
+	/*@[Revert Reg]*/
+	set_result = phydm_stop_ic_trx(dm, PHYDM_REVERT);
+
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0x18, RFREG_MASK,
+		       dm_psd_table->rf_0x18_bkp);
+	odm_set_rf_reg(dm, RF_PATH_B, RF_0x18, RFREG_MASK,
+		       dm_psd_table->rf_0x18_bkp_b);
 
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD finished\n\n");
+
+	phydm_pause_func(dm, F00_DIG, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_3, 1,
+			 &igi_tmp);
+	dm_psd_table->psd_in_progress = 0;
+
+	return PHYDM_SET_SUCCESS;
 }
 
-void
-phydm_psd_para_setting(
-	void		*p_dm_void,
-	u8		sw_avg_time,
-	u8		hw_avg_time,	
-	u8		i_q_setting,
-	u16		fft_smp_point,
-	u8		ant_sel,
-	u8		psd_input,
-	u8		channel,
-	u8		noise_k_en
-	)
+void phydm_psd_para_setting(void *dm_void, u8 sw_avg_time, u8 hw_avg_time,
+			    u8 i_q_setting, u16 fft_smp_point, u8 ant_sel,
+			    u8 psd_input, u8 channel, u8 noise_k_en)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	_PHYDM_PSD_	*p_dm_psd_table = &(p_dm->dm_psd_table);
-	u8		fft_smp_point_idx = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct psd_info *dm_psd_table = &dm->dm_psd_table;
+	u8 fft_smp_point_idx = 0;
 
-	p_dm_psd_table->fft_smp_point = fft_smp_point;
+	dm_psd_table->fft_smp_point = fft_smp_point;
 
 	if (sw_avg_time == 0)
 		sw_avg_time = 1;
-	
-	p_dm_psd_table->sw_avg_time = sw_avg_time;
-	p_dm_psd_table->psd_fc_channel = channel;
-	p_dm_psd_table->noise_k_en = noise_k_en;
-		
+
+	dm_psd_table->sw_avg_time = sw_avg_time;
+	dm_psd_table->psd_fc_channel = channel;
+	dm_psd_table->noise_k_en = noise_k_en;
+
 	if (fft_smp_point == 128)
 		fft_smp_point_idx = 0;
 	else if (fft_smp_point == 256)
@@ -253,141 +306,155 @@ phydm_psd_para_setting(
 		fft_smp_point_idx = 2;
 	else if (fft_smp_point == 1024)
 		fft_smp_point_idx = 3;
-		
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		
-		odm_set_bb_reg(p_dm, 0x910, BIT(11) | BIT(10), i_q_setting);
-		odm_set_bb_reg(p_dm, 0x910, BIT(13) | BIT(12), hw_avg_time);
-		odm_set_bb_reg(p_dm, 0x910, BIT(15) | BIT(14), fft_smp_point_idx);
-		odm_set_bb_reg(p_dm, 0x910, BIT(17) | BIT(16), ant_sel);
-		odm_set_bb_reg(p_dm, 0x910, BIT(23), psd_input);
 
-	} else {
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		odm_set_bb_reg(dm, R_0x1e8c, BIT(11) | BIT(10), i_q_setting);
+		odm_set_bb_reg(dm, R_0x1e8c, BIT(13) | BIT(12), hw_avg_time);
 
+		if (fft_smp_point == 4096) {
+			odm_set_bb_reg(dm, R_0x1e88, BIT(31) | BIT(30), 0x2);
+		} else if (fft_smp_point == 2048) {
+			odm_set_bb_reg(dm, R_0x1e88, BIT(31) | BIT(30), 0x1);
+		} else {
+			odm_set_bb_reg(dm, R_0x1e88, BIT(31) | BIT(30), 0x0);
+			odm_set_bb_reg(dm, R_0x1e8c, BIT(15) | BIT(14),
+				       fft_smp_point_idx);
+		}
+		odm_set_bb_reg(dm, R_0x1e8c, BIT(17) | BIT(16), ant_sel);
+		odm_set_bb_reg(dm, R_0x1e8c, BIT(23) | BIT(22), psd_input);
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		odm_set_bb_reg(dm, R_0x910, BIT(11) | BIT(10), i_q_setting);
+		odm_set_bb_reg(dm, R_0x910, BIT(13) | BIT(12), hw_avg_time);
+		odm_set_bb_reg(dm, R_0x910, BIT(15) | BIT(14),
+			       fft_smp_point_idx);
+		odm_set_bb_reg(dm, R_0x910, BIT(17) | BIT(16), ant_sel);
+		odm_set_bb_reg(dm, R_0x910, BIT(23), psd_input);
+	} else if (dm->support_ic_type == ODM_RTL8721D) {
+		odm_set_bb_reg(dm, 0x808, BIT(19) | BIT(18), i_q_setting);
+		odm_set_bb_reg(dm, 0x808, BIT(21) | BIT(20), hw_avg_time);
+		odm_set_bb_reg(dm, 0x808, BIT(23) | BIT(22), fft_smp_point_idx);
+		odm_set_bb_reg(dm, 0x804, BIT(5) | BIT(4), ant_sel);
+		odm_set_bb_reg(dm, 0x80C, BIT(23), psd_input);
+
+#if 0
+	} else {	/*ODM_IC_11N_SERIES*/
+#endif
 	}
-
-	/*bw = (*p_dm->p_band_width); //ODM_BW20M */
-	/*channel = *(p_dm->p_channel);*/
-	
-	
-
-
+	/*@bw = (*dm->band_width); //ODM_BW20M */
+	/*@channel = *(dm->channel);*/
 }
 
-void
-phydm_psd_init(
-	void		*p_dm_void
-	)
+void phydm_psd_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	_PHYDM_PSD_	*p_dm_psd_table = &(p_dm->dm_psd_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct psd_info *dm_psd_table = &dm->dm_psd_table;
+
+	PHYDM_DBG(dm, ODM_COMP_API, "PSD para init\n");
 
-	PHYDM_DBG(p_dm, ODM_COMP_API, ("PSD para init\n"));
+	dm_psd_table->psd_in_progress = false;
 
-	p_dm_psd_table->psd_in_progress = false;
-	
-	if (p_dm->support_ic_type & ODM_IC_11AC_SERIES) {
-		
-		p_dm_psd_table->psd_reg = 0x910;
-		p_dm_psd_table->psd_report_reg = 0xF44;
+	if (dm->support_ic_type & ODM_IC_JGR3_SERIES) {
+		dm_psd_table->psd_reg = R_0x1e8c;
+		dm_psd_table->psd_report_reg = R_0x2d90;
 
+		/*@2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		dm_psd_table->psd_bw_rf_reg = 1;
+	} else if (dm->support_ic_type & ODM_IC_11AC_SERIES) {
+		dm_psd_table->psd_reg = R_0x910;
+		dm_psd_table->psd_report_reg = R_0xf44;
+
+		/*@2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
 		if (ODM_IC_11AC_2_SERIES)
-			p_dm_psd_table->psd_bw_rf_reg = 1;	/*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+			dm_psd_table->psd_bw_rf_reg = 1;
 		else
-			p_dm_psd_table->psd_bw_rf_reg = 2;	/*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
-		
+			dm_psd_table->psd_bw_rf_reg = 2;
 	} else {
-	
-		p_dm_psd_table->psd_reg = 0x808;
-		p_dm_psd_table->psd_report_reg = 0x8B4;
-		p_dm_psd_table->psd_bw_rf_reg = 2; /*2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		dm_psd_table->psd_reg = R_0x808;
+		dm_psd_table->psd_report_reg = R_0x8b4;
+		/*@2b'11: 20MHz, 2b'10: 40MHz, 2b'01: 80MHz */
+		dm_psd_table->psd_bw_rf_reg = 2;
 	}
 
-	if (p_dm->support_ic_type == ODM_RTL8812)
-		p_dm_psd_table->psd_pwr_common_offset = 0;
-	else if (p_dm->support_ic_type == ODM_RTL8821)
-		p_dm_psd_table->psd_pwr_common_offset = 0;
-	else
-		p_dm_psd_table->psd_pwr_common_offset = 0;
-	
-	phydm_psd_para_setting(p_dm, 1, 2, 3, 128, 0, 0, 7, 0);
-	/*phydm_psd(p_dm, 0x3c, 0, 127);*/			/* target at -50dBm */
-
+	dm_psd_table->psd_pwr_common_offset = 0;
 
+	phydm_psd_para_setting(dm, 1, 2, 3, 128, 0, 0, 7, 0);
+#if 0
+	/*phydm_psd(dm, 0x3c, 0, 127);*/ /* target at -50dBm */
+#endif
 }
 
-void
-phydm_psd_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_psd_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u8		i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	char help[] = "-h";
+	u32 var1[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u8 i = 0;
 
 	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "{0} {sw_avg} {hw_avg 0:3} {1:I,2:Q,3:IQ} {fft_point: 128*(1:4)} {path_sel 0~3} {0:ADC, 1:RXIQC} {CH} {noise_k}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{1} {IGI(hex)} {start_point} {stop_point}\n"));
+		#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+		if (dm->support_ic_type & ODM_IC_JGR3_SERIES)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "{0} {sw_avg} {hw_avg 0:3} {1:I,2:Q,3:IQ} {fft_point: 128*(1:4) 2048 4096}\n{path_sel 0~3} {0:ADC, 1:rxdata_fir_in, 2:rx_nbi_nf_stage2} {CH} {noise_k}\n\n");
+		else
+		#endif
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "{0} {sw_avg} {hw_avg 0:3} {1:I,2:Q,3:IQ} {fft_point: 128*(1:4)} {path_sel 0~3} {0:ADC, 1:RXIQC} {CH} {noise_k}\n");
 
-	} else {
-	
-
-		PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
-
-		if (var1[0] == 0) {
-
-			for (i = 1; i < 10; i++) {
-				if (input[i + 1]) {
-					PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
-				}
-			}
-			
-			PHYDM_SNPRINTF((output + used, out_len - used, "sw_avg_time=((%d)), hw_avg_time=((%d)), IQ=((%d)), fft=((%d)), path=((%d)), input =((%d)) ch=((%d)), noise_k=((%d))\n", 
-				var1[1], var1[2], var1[3], var1[4], var1[5], var1[6], (u8)var1[7], (u8)var1[8]));
-			phydm_psd_para_setting(p_dm, (u8)var1[1], (u8)var1[2], (u8)var1[3], (u16)var1[4], (u8)var1[5], (u8)var1[6], (u8)var1[7], (u8)var1[8]);
-			
-		} else if (var1[0] == 1) {
-
-			PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
-			PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
-			PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
-			PHYDM_SNPRINTF((output + used, out_len - used, "IGI=((0x%x)), start_point=((%d)), stop_point=((%d))\n", var1[1], var1[2], var1[3]));
-			p_dm->debug_components |= ODM_COMP_API;
-			phydm_psd(p_dm, var1[1], (u16)var1[2], (u16)var1[3]);
-			p_dm->debug_components &= (~ODM_COMP_API);
-		}
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} {IGI(hex)} {start_point} {stop_point}\n");
+		goto out;
+	}
 
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+
+	if (var1[0] == 0) {
+		for (i = 1; i < 10; i++) {
+			if (input[i + 1])
+				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL,
+					     &var1[i]);
+		}
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "sw_avg_time=((%d)), hw_avg_time=((%d)), IQ=((%d)), fft=((%d)), path=((%d)), input =((%d)) ch=((%d)), noise_k=((%d))\n",
+			 var1[1], var1[2], var1[3], var1[4], var1[5],
+			 var1[6], (u8)var1[7], (u8)var1[8]);
+		phydm_psd_para_setting(dm, (u8)var1[1], (u8)var1[2],
+				       (u8)var1[3], (u16)var1[4],
+				       (u8)var1[5], (u8)var1[6],
+				       (u8)var1[7], (u8)var1[8]);
+
+	} else if (var1[0] == 1) {
+		PHYDM_SSCANF(input[2], DCMD_HEX, &var1[1]);
+		PHYDM_SSCANF(input[3], DCMD_DECIMAL, &var1[2]);
+		PHYDM_SSCANF(input[4], DCMD_DECIMAL, &var1[3]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "IGI=((0x%x)), start_point=((%d)), stop_point=((%d))\n",
+			 var1[1], var1[2], var1[3]);
+		dm->debug_components |= ODM_COMP_API;
+		if (phydm_psd(dm, var1[1], (u16)var1[2], (u16)var1[3]) ==
+		    PHYDM_SET_FAIL)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "PSD_SET_FAIL\n");
+		dm->debug_components &= ~(ODM_COMP_API);
 	}
 
+out:
 	*_used = used;
 	*_out_len = out_len;
-	
 }
 
-u8
-phydm_get_psd_result_table(
-	void		*p_dm_void,
-	int 		index
-	)
+u8 phydm_get_psd_result_table(void *dm_void, int index)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	_PHYDM_PSD_	*p_dm_psd_table = &(p_dm->dm_psd_table);
-	u8 		temp_result = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct psd_info *dm_psd_table = &dm->dm_psd_table;
+	u8 result = 0;
 
-	if(index<128)
-		temp_result = p_dm_psd_table->psd_result[index];
+	if (index < 128)
+		result = dm_psd_table->psd_result[index];
 
-	return temp_result;
-	
+	return result;
 }
 
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.h
index 0bde88a49138..42063e79317c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_psd.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,29 +9,37 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMPSD_H__
-#define    __PHYDMPSD_H__
+#ifndef __PHYDMPSD_H__
+#define __PHYDMPSD_H__
 
-/*#define PSD_VERSION	"1.0"*/  /*2016.09.22  Dino*/
-#define PSD_VERSION	"1.1"  /*2016.10.07  Dino, Add Option for PSD Tone index Selection */
+/*@#define PSD_VERSION	"1.0"*/ /*@2016.09.22  Dino*/
+#define PSD_VERSION "1.1" /*@2016.10.07  Dino, Add Option for PSD Tone index Selection */
 
 #ifdef CONFIG_PSD_TOOL
 
 
-struct _PHYDM_PSD_ {
-
+struct psd_info {
 	u8	psd_in_progress;
 	u32	psd_reg;
 	u32	psd_report_reg;
 	u8	psd_pwr_common_offset;
 	u16	sw_avg_time;
 	u16	fft_smp_point;
-	u32	initial_gain_backup;
 	u32	rf_0x18_bkp;
 	u32	rf_0x18_bkp_b;
 	u16	psd_fc_channel;
@@ -39,55 +48,20 @@ struct _PHYDM_PSD_ {
 	u8	noise_k_en;
 };
 
-u32
-phydm_get_psd_data(
-	void			*p_dm_void,
-	u32			psd_tone_idx,
-	u32			igi
-);
+u32 phydm_get_psd_data(void *dm_void, u32 psd_tone_idx, u32 igi);
 
-void
-phydm_psd_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
+void phydm_psd_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len);
 
-void
-phydm_psd(
-	void		*p_dm_void,
-	u32		igi,
-	u16		start_point,
-	u16		stop_point
-);
+u8 phydm_psd(void *dm_void, u32 igi, u16 start_point, u16 stop_point);
 
-void
-phydm_psd_para_setting(
-	void		*p_dm_void,
-	u8		sw_avg_time,
-	u8		hw_avg_time,
-	u8		i_q_setting,
-	u16		fft_smp_point,
-	u8		ant_sel,
-	u8		psd_input,
-	u8		channel,
-	u8		noise_k_en
-);
+void phydm_psd_para_setting(void *dm_void, u8 sw_avg_time, u8 hw_avg_time,
+			    u8 i_q_setting, u16 fft_smp_point, u8 ant_sel,
+			    u8 psd_input, u8 channel, u8 noise_k_en);
 
-void
-phydm_psd_init(
-	void		*p_dm_void
-);
+void phydm_psd_init(void *dm_void);
 
-u8
-phydm_get_psd_result_table(
-	void		*p_dm_void,
-	int		index
-);
+u8 phydm_get_psd_result_table(void *dm_void, int index);
 
 #endif
 #endif
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.c
index 9b953b7d0e80..8871d2ddc160 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,980 +9,1078 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-void
-phydm_h2C_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+boolean phydm_is_vht_rate(void *dm_void, u8 rate)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			h2c_parameter[H2C_MAX_LENGTH] = {0};
-	u8			phydm_h2c_id = (u8)dm_value[0];
-	u8			i;
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-
-	PHYDM_SNPRINTF((output + used, out_len - used, "Phydm Send H2C_ID (( 0x%x))\n", phydm_h2c_id));
-	for (i = 0; i < H2C_MAX_LENGTH; i++) {
+	return ((rate & 0x7f) >= ODM_RATEVHTSS1MCS0) ? true : false;
+}
+
+boolean phydm_is_ht_rate(void *dm_void, u8 rate)
+{
+	return (((rate & 0x7f) >= ODM_RATEMCS0) &&
+		((rate & 0x7f) <= ODM_RATEMCS31)) ? true : false;
+}
+
+boolean phydm_is_ofdm_rate(void *dm_void, u8 rate)
+{
+	return (((rate & 0x7f) >= ODM_RATE6M) &&
+		((rate & 0x7f) <= ODM_RATE54M)) ? true : false;
+}
+
+boolean phydm_is_cck_rate(void *dm_void, u8 rate)
+{
+	return ((rate & 0x7f) <= ODM_RATE11M) ? true : false;
+}
+
+u8 phydm_rate_2_rate_digit(void *dm_void, u8 rate)
+{
+	u8 legacy_table[12] = {1, 2, 5, 11, 6, 9, 12, 18, 24, 36, 48, 54};
+	u8 rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8 rate_digit = 0;
+
+	if (rate_idx >= ODM_RATEVHTSS1MCS0)
+		rate_digit = (rate_idx - ODM_RATEVHTSS1MCS0) % 10;
+	else if (rate_idx >= ODM_RATEMCS0)
+		rate_digit = (rate_idx - ODM_RATEMCS0);
+	else if (rate_idx <= ODM_RATE54M)
+		rate_digit = legacy_table[rate_idx];
+
+	return rate_digit;
+}
+
+u8 phydm_rate_type_2_num_ss(void *dm_void, enum PDM_RATE_TYPE type)
+{
+	u8 num_ss = 1;
+
+	switch (type) {
+	case PDM_CCK:
+	case PDM_OFDM:
+	case PDM_1SS:
+		num_ss = 1;
+		break;
+	case PDM_2SS:
+		num_ss = 2;
+		break;
+	case PDM_3SS:
+		num_ss = 3;
+		break;
+	case PDM_4SS:
+		num_ss = 4;
+		break;
+	default:
+		break;
+	}
+
+	return num_ss;
+}
+
+u8 phydm_rate_to_num_ss(void *dm_void, u8 data_rate)
+{
+	u8 num_ss = 1;
+
+	if (data_rate <= ODM_RATE54M)
+		num_ss = 1;
+	else if (data_rate <= ODM_RATEMCS31)
+		num_ss = ((data_rate - ODM_RATEMCS0) >> 3) + 1;
+	else if (data_rate <= ODM_RATEVHTSS1MCS9)
+		num_ss = 1;
+	else if (data_rate <= ODM_RATEVHTSS2MCS9)
+		num_ss = 2;
+	else if (data_rate <= ODM_RATEVHTSS3MCS9)
+		num_ss = 3;
+	else if (data_rate <= ODM_RATEVHTSS4MCS9)
+		num_ss = 4;
+
+	return num_ss;
+}
 
+void phydm_h2C_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 dm_value[10] = {0};
+	u8 i = 0, input_idx = 0;
+	u8 h2c_parameter[H2C_MAX_LENGTH] = {0};
+	u8 phydm_h2c_id = 0;
+
+	for (i = 0; i < 8; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
+			input_idx++;
+		}
+	}
+
+	if (input_idx == 0)
+		return;
+
+	phydm_h2c_id = (u8)dm_value[0];
+
+	PDM_SNPF(out_len, used, output + used, out_len - used,
+		 "Phydm Send H2C_ID (( 0x%x))\n", phydm_h2c_id);
+
+	for (i = 0; i < H2C_MAX_LENGTH; i++) {
 		h2c_parameter[i] = (u8)dm_value[i + 1];
-		PHYDM_SNPRINTF((output + used, out_len - used, "H2C: Byte[%d] = ((0x%x))\n", i, h2c_parameter[i]));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "H2C: Byte[%d] = ((0x%x))\n", i, h2c_parameter[i]);
 	}
 
-	odm_fill_h2c_cmd(p_dm, phydm_h2c_id, H2C_MAX_LENGTH, h2c_parameter);
-	
+	odm_fill_h2c_cmd(dm, phydm_h2c_id, H2C_MAX_LENGTH, h2c_parameter);
+
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_fw_fix_rate(
-	void		*p_dm_void,
-	u8		en, 
-	u8		macid, 
-	u8		bw, 
-	u8		rate
-	
-)
+void phydm_fw_fix_rate(void *dm_void, u8 en, u8 macid, u8 bw, u8 rate)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32	reg_u32_tmp;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 reg_u32_tmp;
 
-	if (p_dm->support_ic_type & PHYDM_IC_8051_SERIES) {
-		
+	if (dm->support_ic_type & PHYDM_IC_8051_SERIES) {
 		reg_u32_tmp = (bw << 24) | (rate << 16) | (macid << 8) | en;
-		odm_set_bb_reg(p_dm, 0x4a0, MASKDWORD, reg_u32_tmp);
-			
+		odm_set_bb_reg(dm, R_0x4a0, MASKDWORD, reg_u32_tmp);
+
 	} else {
-	
 		if (en == 1)
-			reg_u32_tmp = (0x60 << 24) | (macid << 16) | (bw << 8) | rate;
+			reg_u32_tmp = BYTE_2_DWORD(0x60, macid, bw, rate);
 		else
 			reg_u32_tmp = 0x40000000;
-			
-		odm_set_bb_reg(p_dm, 0x450, MASKDWORD, reg_u32_tmp);
+		if (dm->support_ic_type & ODM_RTL8814B)
+			odm_set_bb_reg(dm, R_0x448, MASKDWORD, reg_u32_tmp);
+		else
+			odm_set_bb_reg(dm, R_0x450, MASKDWORD, reg_u32_tmp);
 	}
 	if (en == 1) {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("FW fix TX rate[id =%d], %dM, Rate(%d)=", macid, (20 << bw), rate));
-		phydm_print_rate(p_dm, rate, ODM_COMP_API);
+		PHYDM_DBG(dm, ODM_COMP_API,
+			  "FW fix TX rate[id =%d], %dM, Rate(%d)=", macid,
+			  (20 << bw), rate);
+		phydm_print_rate(dm, rate, ODM_COMP_API);
 	} else {
-		PHYDM_DBG(p_dm, ODM_COMP_API, ("Auto Rate\n"));
+		PHYDM_DBG(dm, ODM_COMP_API, "Auto Rate\n");
 	}
 }
 
-void
-phydm_ra_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void phydm_ra_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+		    u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
-	char	help[] = "-h";
-	u32	var1[5] = {0};
-	u8	i = 0;
-	u32	reg_u32_tmp;
+	char help[] = "-h";
+	u32 var[5] = {0};
+	u8 macid = 0, bw = 0, rate = 0;
+	u8 i = 0;
 
 	for (i = 0; i < 5; i++) {
 		if (input[i + 1])
-			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var1[i]);
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &var[i]);
 	}
-	
+
 	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "{1} {0:-,1:+} {ofst}: set offset\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{1} {100}: show offset\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{2} {en} {macid} {bw} {rate}: fw fix rate\n"));
-		
-	} else if (var1[0] == 1) { /*Adjust PCR offset*/
-
-		if (var1[1] == 100) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Get] RA_ofst=((%s%d))\n", 
-				((p_ra_table->RA_threshold_offset == 0) ? " " : ((p_ra_table->RA_offset_direction) ? "+" : "-")), p_ra_table->RA_threshold_offset));
-
-		} else if (var1[1] == 0) {
-			p_ra_table->RA_offset_direction = 0;
-			p_ra_table->RA_threshold_offset = (u8)var1[2];
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Set] RA_ofst=((-%d))\n", p_ra_table->RA_threshold_offset));
-		} else if (var1[1] == 1) {
-			p_ra_table->RA_offset_direction = 1;
-			p_ra_table->RA_threshold_offset = (u8)var1[2];
-			PHYDM_SNPRINTF((output + used, out_len - used, "[Set] RA_ofst=((+%d))\n", p_ra_table->RA_threshold_offset));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} {0:-,1:+} {ofst}: set offset\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} {100}: show offset\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{2} {en} {macid} {bw} {rate}: fw fix rate\n");
+
+	} else if (var[0] == 1) { /*@Adjust PCR offset*/
+
+		if (var[1] == 100) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[Get] RA_ofst=((%s%d))\n",
+				 ((ra_tab->ra_ofst_direc) ? "+" : "-"),
+				 ra_tab->ra_th_ofst);
+
+		} else if (var[1] == 0) {
+			ra_tab->ra_ofst_direc = 0;
+			ra_tab->ra_th_ofst = (u8)var[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[Set] RA_ofst=((-%d))\n", ra_tab->ra_th_ofst);
+		} else if (var[1] == 1) {
+			ra_tab->ra_ofst_direc = 1;
+			ra_tab->ra_th_ofst = (u8)var[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[Set] RA_ofst=((+%d))\n", ra_tab->ra_th_ofst);
 		}
-		
-	} else if (var1[0] == 2) { /*FW fix rate*/
-
-		PHYDM_SNPRINTF((output + used, out_len - used, 
-			"[FW fix TX Rate] {en, macid,bw,rate}={%d, %d, %d, 0x%x}", var1[1], var1[2], var1[3], var1[4]));
-		
-		phydm_fw_fix_rate(p_dm, (u8)var1[1], (u8)var1[2], (u8)var1[3], (u8)var1[4]);
-		
+
+	} else if (var[0] == 2) { /*@FW fix rate*/
+		macid = (u8)var[2];
+		bw = (u8)var[3];
+		rate = (u8)var[4];
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[FW fix TX Rate] {en, macid,bw,rate}={%d, %d, %d, 0x%x}",
+			 var[1], macid, bw, rate);
+
+		phydm_fw_fix_rate(dm, (u8)var[1], macid, bw, rate);
+
 	} else {
-		PHYDM_SNPRINTF((output + used, out_len - used, "[Set] Error\n"));
-		/**/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[Set] Error\n");
 	}
 	*_used = used;
 	*_out_len = out_len;
 }
 
-
-
-void
-odm_c2h_ra_para_report_handler(
-	void	*p_dm_void,
-	u8	*cmd_buf,
-	u8	cmd_len
-)
+void odm_c2h_ra_para_report_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-#if (defined(CONFIG_RA_DBG_CMD))
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-#endif
-
-	u8	para_idx = cmd_buf[0]; /*Retry Penalty, NH, NL*/
-#if (defined(CONFIG_RA_DBG_CMD))
-	u8	rate_type_start = cmd_buf[1];
-	u8	rate_type_length = cmd_len - 2;
-#endif
-	u8	i;
-
-
-	PHYDM_DBG(p_dm, DBG_RA, ("[ From FW C2H RA Para ]  cmd_buf[0]= (( %d ))\n", cmd_buf[0]));
-
-#if (defined(CONFIG_RA_DBG_CMD))
-	if (para_idx == RADBG_RTY_PENALTY) {
-		PHYDM_DBG(p_dm, DBG_RA, (" |rate index|   |RTY Penality index|\n"));
-
-		for (i = 0 ; i < (rate_type_length) ; i++) {
-			if (p_ra_table->is_ra_dbg_init)
-				p_ra_table->RTY_P_default[rate_type_start + i] = cmd_buf[2 + i];
-
-			p_ra_table->RTY_P[rate_type_start + i] = cmd_buf[2 + i];
-			PHYDM_DBG(p_dm, DBG_RA, ("%8d  %15d\n", (rate_type_start + i), p_ra_table->RTY_P[rate_type_start + i]));
-		}
-
-	} else	if (para_idx == RADBG_N_HIGH) {
-		/**/
-		PHYDM_DBG(p_dm, DBG_RA, (" |rate index|    |N-High|\n"));
-
-
-	} else if (para_idx == RADBG_N_LOW) {
-		PHYDM_DBG(p_dm, DBG_RA, (" |rate index|   |N-Low|\n"));
-		/**/
-	} else if (para_idx == RADBG_RATE_UP_RTY_RATIO) {
-		PHYDM_DBG(p_dm, DBG_RA, (" |rate index|   |rate Up RTY Ratio|\n"));
-
-		for (i = 0; i < (rate_type_length); i++) {
-			if (p_ra_table->is_ra_dbg_init)
-				p_ra_table->RATE_UP_RTY_RATIO_default[rate_type_start + i] = cmd_buf[2 + i];
-
-			p_ra_table->RATE_UP_RTY_RATIO[rate_type_start + i] = cmd_buf[2 + i];
-			PHYDM_DBG(p_dm, DBG_RA, ("%8d  %15d\n", (rate_type_start + i), p_ra_table->RATE_UP_RTY_RATIO[rate_type_start + i]));
-		}
-	} else	 if (para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
-		PHYDM_DBG(p_dm, DBG_RA, (" |rate index|   |rate Down RTY Ratio|\n"));
-
-		for (i = 0; i < (rate_type_length); i++) {
-			if (p_ra_table->is_ra_dbg_init)
-				p_ra_table->RATE_DOWN_RTY_RATIO_default[rate_type_start + i] = cmd_buf[2 + i];
-
-			p_ra_table->RATE_DOWN_RTY_RATIO[rate_type_start + i] = cmd_buf[2 + i];
-			PHYDM_DBG(p_dm, DBG_RA, ("%8d  %15d\n", (rate_type_start + i), p_ra_table->RATE_DOWN_RTY_RATIO[rate_type_start + i]));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 mode = cmd_buf[0]; /*Retry Penalty, NH, NL*/
+	u8 i;
+
+	PHYDM_DBG(dm, DBG_FW_TRACE, "[%s] [mode: %d]----------------------->\n",
+		  __func__, mode);
+
+	if (mode == RADBG_DEBUG_MONITOR1) {
+		if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "RSSI =",
+				  cmd_buf[1]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "rate =",
+				  cmd_buf[2] & 0x7f);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "SGI =",
+				  (cmd_buf[2] & 0x80) >> 7);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "BW =",
+				  cmd_buf[3]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "BW_max =",
+				  cmd_buf[4]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n",
+				  "multi_rate0 =", cmd_buf[5]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n",
+				  "multi_rate1 =", cmd_buf[6]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "DISRA =",
+				  cmd_buf[7]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "VHT_EN =",
+				  cmd_buf[8]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n",
+				  "SGI_support =", cmd_buf[9]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "try_ness =",
+				  cmd_buf[10]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "pre_rate =",
+				  cmd_buf[11]);
+		} else {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "RSSI =",
+				  cmd_buf[1]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %x\n", "BW =",
+				  cmd_buf[2]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "DISRA =",
+				  cmd_buf[3]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "VHT_EN =",
+				  cmd_buf[4]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n",
+				  "Hightest rate =", cmd_buf[5]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n",
+				  "Lowest rate =", cmd_buf[6]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n",
+				  "SGI_support =", cmd_buf[7]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Rate_ID =",
+				  cmd_buf[8]);
 		}
-	} else
-#endif
-		if (para_idx == RADBG_DEBUG_MONITOR1) {
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("-------------------------------\n"));
-			if (p_dm->support_ic_type & PHYDM_IC_3081_SERIES) {
-
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "RSSI =", cmd_buf[1]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "rate =", cmd_buf[2] & 0x7f));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "SGI =", (cmd_buf[2] & 0x80) >> 7));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "BW =", cmd_buf[3]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "BW_max =", cmd_buf[4]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "multi_rate0 =", cmd_buf[5]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "multi_rate1 =", cmd_buf[6]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "DISRA =",	cmd_buf[7]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "VHT_EN =", cmd_buf[8]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "SGI_support =",	cmd_buf[9]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "try_ness =", cmd_buf[10]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "pre_rate =", cmd_buf[11]));
-			} else {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "RSSI =", cmd_buf[1]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %x\n", "BW =", cmd_buf[2]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "DISRA =", cmd_buf[3]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "VHT_EN =", cmd_buf[4]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "Hightest rate =", cmd_buf[5]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "Lowest rate =", cmd_buf[6]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "SGI_support =", cmd_buf[7]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "Rate_ID =",	cmd_buf[8]));
-			}
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("-------------------------------\n"));
-		} else	 if (para_idx == RADBG_DEBUG_MONITOR2) {
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("-------------------------------\n"));
-			if (p_dm->support_ic_type & PHYDM_IC_3081_SERIES) {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "rate_id =", cmd_buf[1]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "highest_rate =", cmd_buf[2]));
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "lowest_rate =", cmd_buf[3]));
-
-				for (i = 4; i <= 11; i++)
-					PHYDM_DBG(p_dm, DBG_FW_TRACE, ("RAMASK =  0x%x\n", cmd_buf[i]));
-			} else {
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %x%x  %x%x  %x%x  %x%x\n", "RA Mask:",
-					cmd_buf[8], cmd_buf[7], cmd_buf[6], cmd_buf[5], cmd_buf[4], cmd_buf[3], cmd_buf[2], cmd_buf[1]));
-			}
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("-------------------------------\n"));
-		} else	 if (para_idx == RADBG_DEBUG_MONITOR3) {
-
-			for (i = 0; i < (cmd_len - 1); i++)
-				PHYDM_DBG(p_dm, DBG_FW_TRACE, ("content[%d] = %d\n", i, cmd_buf[1 + i]));
-		} else	 if (para_idx == RADBG_DEBUG_MONITOR4)
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  {%d.%d}\n", "RA version =", cmd_buf[1], cmd_buf[2]));
-		else if (para_idx == RADBG_DEBUG_MONITOR5) {
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "Current rate =", cmd_buf[1]));
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "Retry ratio =", cmd_buf[2]));
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  %d\n", "rate down ratio =", cmd_buf[3]));
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x\n", "highest rate =", cmd_buf[4]));
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  {0x%x 0x%x}\n", "Muti-try =", cmd_buf[5], cmd_buf[6]));
-			PHYDM_DBG(p_dm, DBG_FW_TRACE, ("%5s  0x%x%x%x%x%x\n", "RA mask =", cmd_buf[11], cmd_buf[10], cmd_buf[9], cmd_buf[8], cmd_buf[7]));
+	} else if (mode == RADBG_DEBUG_MONITOR2) {
+		if (dm->support_ic_type & PHYDM_IC_3081_SERIES) {
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "rate_id =",
+				  cmd_buf[1]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n",
+				  "highest_rate =", cmd_buf[2]);
+			PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n",
+				  "lowest_rate =", cmd_buf[3]);
+
+			for (i = 4; i <= 11; i++)
+				PHYDM_DBG(dm, DBG_FW_TRACE, "RAMASK =  0x%x\n",
+					  cmd_buf[i]);
+		} else {
+			PHYDM_DBG(dm, DBG_FW_TRACE,
+				  "%5s  %x%x  %x%x  %x%x  %x%x\n", "RA Mask:",
+				  cmd_buf[8], cmd_buf[7], cmd_buf[6],
+				  cmd_buf[5], cmd_buf[4], cmd_buf[3],
+				  cmd_buf[2], cmd_buf[1]);
 		}
+	} else if (mode == RADBG_DEBUG_MONITOR3) {
+		for (i = 0; i < (cmd_len - 1); i++)
+			PHYDM_DBG(dm, DBG_FW_TRACE, "content[%d] = %d\n", i,
+				  cmd_buf[1 + i]);
+	} else if (mode == RADBG_DEBUG_MONITOR4)
+		PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  {%d.%d}\n", "RA version =",
+			  cmd_buf[1], cmd_buf[2]);
+	else if (mode == RADBG_DEBUG_MONITOR5) {
+		PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "Current rate =",
+			  cmd_buf[1]);
+		PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "Retry ratio =",
+			  cmd_buf[2]);
+		PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  %d\n", "rate down ratio =",
+			  cmd_buf[3]);
+		PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x\n", "highest rate =",
+			  cmd_buf[4]);
+		PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  {0x%x 0x%x}\n", "Muti-try =",
+			  cmd_buf[5], cmd_buf[6]);
+		PHYDM_DBG(dm, DBG_FW_TRACE, "%5s  0x%x%x%x%x%x\n", "RA mask =",
+			  cmd_buf[11], cmd_buf[10], cmd_buf[9], cmd_buf[8],
+			  cmd_buf[7]);
+	}
+	PHYDM_DBG(dm, DBG_FW_TRACE, "-------------------------------\n");
 }
 
-void
-phydm_ra_dynamic_retry_count(
-	void	*p_dm_void
-)
+void phydm_ra_dynamic_retry_count(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (!(p_dm->support_ability & ODM_BB_DYNAMIC_ARFR))
+	if (!(dm->support_ability & ODM_BB_DYNAMIC_ARFR))
 		return;
 
-	/*PHYDM_DBG(p_dm, DBG_RA, ("p_dm->pre_b_noisy = %d\n", p_dm->pre_b_noisy ));*/
-	if (p_dm->pre_b_noisy != p_dm->noisy_decision) {
-
-		if (p_dm->noisy_decision) {
-			PHYDM_DBG(p_dm, DBG_RA, ("Noisy Env. RA fallback\n"));
-			odm_set_mac_reg(p_dm, 0x430, MASKDWORD, 0x0);
-			odm_set_mac_reg(p_dm, 0x434, MASKDWORD, 0x04030201);
+#if 0
+	/*PHYDM_DBG(dm, DBG_RA, "dm->pre_b_noisy = %d\n", dm->pre_b_noisy );*/
+#endif
+	if (dm->pre_b_noisy != dm->noisy_decision) {
+		if (dm->noisy_decision) {
+			PHYDM_DBG(dm, DBG_DYN_ARFR, "Noisy Env. RA fallback\n");
+			odm_set_mac_reg(dm, R_0x430, MASKDWORD, 0x0);
+			odm_set_mac_reg(dm, R_0x434, MASKDWORD, 0x04030201);
 		} else {
-			PHYDM_DBG(p_dm, DBG_RA, ("Clean Env. RA fallback\n"));
-			odm_set_mac_reg(p_dm, 0x430, MASKDWORD, 0x01000000);
-			odm_set_mac_reg(p_dm, 0x434, MASKDWORD, 0x06050402);
+			PHYDM_DBG(dm, DBG_DYN_ARFR, "Clean Env. RA fallback\n");
+			odm_set_mac_reg(dm, R_0x430, MASKDWORD, 0x01000000);
+			odm_set_mac_reg(dm, R_0x434, MASKDWORD, 0x06050402);
 		}
-		p_dm->pre_b_noisy = p_dm->noisy_decision;
+		dm->pre_b_noisy = dm->noisy_decision;
 	}
 }
 
-void
-phydm_print_rate(
-	void	*p_dm_void,
-	u8	rate,
-	u32	dbg_component
-)
+void phydm_print_rate(void *dm_void, u8 rate, u32 dbg_component)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		legacy_table[12] = {1, 2, 5, 11, 6, 9, 12, 18, 24, 36, 48, 54};
-	u8		rate_idx = rate & 0x7f; /*remove bit7 SGI*/
-	u8		vht_en = (rate_idx >= ODM_RATEVHTSS1MCS0) ? 1 : 0;
-	u8		b_sgi = (rate & 0x80) >> 7;
-
-	PHYDM_DBG_F(p_dm, dbg_component, ("( %s%s%s%s%d%s%s)\n",
-		((rate_idx >= ODM_RATEVHTSS1MCS0) && (rate_idx <= ODM_RATEVHTSS1MCS9)) ? "VHT 1ss  " : "",
-		((rate_idx >= ODM_RATEVHTSS2MCS0) && (rate_idx <= ODM_RATEVHTSS2MCS9)) ? "VHT 2ss " : "",
-		((rate_idx >= ODM_RATEVHTSS3MCS0) && (rate_idx <= ODM_RATEVHTSS3MCS9)) ? "VHT 3ss " : "",
-			(rate_idx >= ODM_RATEMCS0) ? "MCS " : "",
-		(vht_en) ? ((rate_idx - ODM_RATEVHTSS1MCS0) % 10) : ((rate_idx >= ODM_RATEMCS0) ? (rate_idx - ODM_RATEMCS0) : ((rate_idx <= ODM_RATE54M) ? legacy_table[rate_idx] : 0)),
-			(b_sgi) ? "-S" : "  ",
-			(rate_idx >= ODM_RATEMCS0) ? "" : "M"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	boolean vht_en = phydm_is_vht_rate(dm, rate_idx);
+	u8 b_sgi = (rate & 0x80) >> 7;
+	u8 rate_ss = phydm_rate_to_num_ss(dm, rate_idx);
+	u8 rate_digit = phydm_rate_2_rate_digit(dm, rate_idx);
+
+	PHYDM_DBG_F(dm, dbg_component, "( %s%s%s%s%s%d%s%s)\n",
+		    (vht_en && (rate_ss == 1)) ? "VHT 1ss " : "",
+		    (vht_en && (rate_ss == 2)) ? "VHT 2ss " : "",
+		    (vht_en && (rate_ss == 3)) ? "VHT 3ss " : "",
+		    (vht_en && (rate_ss == 4)) ? "VHT 4ss " : "",
+		    (rate_idx >= ODM_RATEMCS0) ? "MCS " : "",
+		    rate_digit,
+		    (b_sgi) ? "-S" : " ",
+		    (rate_idx >= ODM_RATEMCS0) ? "" : "M");
 }
 
-void
-phydm_c2h_ra_report_handler(
-	void	*p_dm_void,
-	u8   *cmd_buf,
-	u8   cmd_len
-)
+void phydm_print_rate_2_buff(void *dm_void, u8 rate, char *buf, u16 buf_size)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_		*p_ra_table = &p_dm->dm_ra_table;
-	u8	macid = cmd_buf[1];
-	u8	rate = cmd_buf[0];
-	u8	rate_idx = rate & 0x7f; /*remove bit7 SGI*/
-	u8	rate_order;
-	struct cmn_sta_info			*p_sta = p_dm->p_phydm_sta_info[macid];
-
-	if (cmd_len >=6) {
-		p_ra_table->ra_ratio[macid] = cmd_buf[6];
-		PHYDM_DBG(p_dm, DBG_RA, ("RA retry ratio: [%d]:", p_ra_table->ra_ratio[macid]));
-			/**/
-	} else if (cmd_len >= 4) {
-		if (cmd_buf[3] == 0) {
-			PHYDM_DBG(p_dm, DBG_RA, ("TX Init-rate Update[%d]:", macid));
-			/**/
-		} else if (cmd_buf[3] == 0xff) {
-			PHYDM_DBG(p_dm, DBG_RA, ("FW Level: Fix rate[%d]:", macid));
-			/**/
-		} else if (cmd_buf[3] == 1) {
-			PHYDM_DBG(p_dm, DBG_RA, ("Try Success[%d]:", macid));
-			/**/
-		} else if (cmd_buf[3] == 2) {
-			PHYDM_DBG(p_dm, DBG_RA, ("Try Fail & Try Again[%d]:", macid));
-			/**/
-		} else if (cmd_buf[3] == 3) {
-			PHYDM_DBG(p_dm, DBG_RA, ("rate Back[%d]:", macid));
-			/**/
-		} else if (cmd_buf[3] == 4) {
-			PHYDM_DBG(p_dm, DBG_RA, ("start rate by RSSI[%d]:", macid));
-			/**/
-		} else if (cmd_buf[3] == 5) {
-			PHYDM_DBG(p_dm, DBG_RA, ("Try rate[%d]:", macid));
-			/**/
-		}
-	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("Tx rate Update[%d]:", macid));
-		/**/
-	}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	boolean vht_en = phydm_is_vht_rate(dm, rate_idx);
+	u8 b_sgi = (rate & 0x80) >> 7;
+	u8 rate_ss = phydm_rate_to_num_ss(dm, rate_idx);
+	u8 rate_digit = phydm_rate_2_rate_digit(dm, rate_idx);
+
+	PHYDM_SNPRINTF(buf, buf_size, "( %s%s%s%s%d%s%s)",
+		       (vht_en && (rate_ss == 1)) ? "VHT 1ss " : "",
+		       (vht_en && (rate_ss == 2)) ? "VHT 2ss " : "",
+		       (vht_en && (rate_ss == 3)) ? "VHT 3ss " : "",
+		       (rate_idx >= ODM_RATEMCS0) ? "MCS " : "",
+		       rate_digit,
+		       (b_sgi) ? "-S" : " ",
+		       (rate_idx >= ODM_RATEMCS0) ? "" : "M");
+}
+
+void phydm_c2h_ra_report_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
+	struct cmn_sta_info *sta = NULL;
+	u8 macid = cmd_buf[1];
+	u8 rate = cmd_buf[0];
+	u8 ra_ratio = 0xff;
+	u8 curr_bw = 0xff;
+	u8 rate_idx = rate & 0x7f; /*remove bit7 SGI*/
+	u8 rate_order;
+	u8 gid_index = 0;
+	char dbg_buf[PHYDM_SNPRINT_SIZE] = {0};
+
+	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	sta = dm->phydm_sta_info[dm->phydm_macid_table[macid]];
+	#else
+	sta = dm->phydm_sta_info[macid];
+	#endif
+
+	if (cmd_len >= 7) {
+		ra_ratio = cmd_buf[5];
+		curr_bw = cmd_buf[6];
+		PHYDM_DBG(dm, DBG_RA, "[%d] PER=%d\n", macid, ra_ratio);
+	}
+
+	if (cmd_buf[3] != 0) {
+		if (cmd_buf[3] == 0xff)
+			PHYDM_DBG(dm, DBG_RA, "FW Fix Rate\n");
+		else if (cmd_buf[3] == 1)
+			PHYDM_DBG(dm, DBG_RA, "Try Success\n");
+		else if (cmd_buf[3] == 2)
+			PHYDM_DBG(dm, DBG_RA, "Try Fail & Again\n");
+		else if (cmd_buf[3] == 3)
+			PHYDM_DBG(dm, DBG_RA, "Rate Back\n");
+		else if (cmd_buf[3] == 4)
+			PHYDM_DBG(dm, DBG_RA, "Start rate by RSSI\n");
+		else if (cmd_buf[3] == 5)
+			PHYDM_DBG(dm, DBG_RA, "Try rate\n");
+	}
+	phydm_print_rate_2_buff(dm, rate, dbg_buf, PHYDM_SNPRINT_SIZE);
+	PHYDM_DBG(dm, DBG_RA, "Tx Rate=%s (%d)", dbg_buf, rate);
 
-	/*phydm_print_rate(p_dm, pre_rate_idx, DBG_RA);*/
-	/*PHYDM_DBG(p_dm, DBG_RA, (">\n",macid );*/
-	phydm_print_rate(p_dm, rate, DBG_RA);
 	if (macid >= 128) {
-		u8 gid_index = macid - 128;
-		p_ra_table->mu1_rate[gid_index] = rate;
+		gid_index = macid - 128;
+		ra_tab->mu1_rate[gid_index] = rate;
 	}
-	
-	/*p_ra_table->link_tx_rate[macid] = rate;*/
-		
-	if (is_sta_active(p_sta)) {
-		p_sta->ra_info.curr_tx_rate = rate;
-		/**/
+
+	/*@ra_tab->link_tx_rate[macid] = rate;*/
+
+	if (is_sta_active(sta)) {
+		sta->ra_info.curr_tx_rate = rate;
+		sta->ra_info.curr_tx_bw = (enum channel_width)curr_bw;
+		sta->ra_info.curr_retry_ratio = ra_ratio;
 	}
 
 	/*trigger power training*/
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
 
-	rate_order = phydm_rate_order_compute(p_dm, rate_idx);
+	rate_order = phydm_rate_order_compute(dm, rate_idx);
 
-	if ((p_dm->is_one_entry_only) ||
-		((rate_order > p_ra_table->highest_client_tx_order) && (p_ra_table->power_tracking_flag == 1))
-		) {
-		halrf_update_pwr_track(p_dm, rate_idx);
-		p_ra_table->power_tracking_flag = 0;
+	if (dm->is_one_entry_only ||
+	    (rate_order > ra_tab->highest_client_tx_order &&
+	    ra_tab->power_tracking_flag == 1)) {
+		halrf_update_pwr_track(dm, rate_idx);
+		ra_tab->power_tracking_flag = 0;
 	}
 
 #endif
 
-	/*trigger dynamic rate ID*/
-/*#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))*/	/*dino will refine here later*/
 #if 0
-	if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E))
-		phydm_update_rate_id(p_dm, rate, macid);
+	/*trigger dynamic rate ID*/
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E))
+		phydm_update_rate_id(dm, rate, macid);
 #endif
-
 }
 
-void
-odm_ra_post_action_on_assoc(
-	void	*p_dm_void
-)
+void odm_ra_post_action_on_assoc(void *dm_void)
 {
 #if 0
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
 
-	p_dm->h2c_rarpt_connect = 1;
-	phydm_rssi_monitor_check(p_dm);
-	p_dm->h2c_rarpt_connect = 0;
+	dm->h2c_rarpt_connect = 1;
+	phydm_rssi_monitor_check(dm);
+	dm->h2c_rarpt_connect = 0;
 #endif
 }
 
-void
-phydm_modify_RA_PCR_threshold(
-	void		*p_dm_void,
-	u8		RA_offset_direction,
-	u8		RA_threshold_offset
-
-)
+void phydm_modify_RA_PCR_threshold(void *dm_void, u8 ra_ofst_direc,
+				   u8 ra_th_ofst)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
 
-	p_ra_table->RA_offset_direction = RA_offset_direction;
-	p_ra_table->RA_threshold_offset = RA_threshold_offset;
-	PHYDM_DBG(p_dm, DBG_RA, ("Set RA_threshold_offset = (( %s%d ))\n", ((RA_threshold_offset == 0) ? " " : ((RA_offset_direction) ? "+" : "-")), RA_threshold_offset));
+	ra_tab->ra_ofst_direc = ra_ofst_direc;
+	ra_tab->ra_th_ofst = ra_th_ofst;
+	PHYDM_DBG(dm, DBG_RA_MASK, "Set ra_th_offset=(( %s%d ))\n",
+		  ((ra_ofst_direc) ? "+" : "-"), ra_th_ofst);
 }
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
 
-void
-odm_refresh_rate_adaptive_mask_mp(
-	void		*p_dm_void
-)
+void phydm_gen_ramask_h2c_AP(
+	void *dm_void,
+	struct rtl8192cd_priv *priv,
+	struct sta_info *entry,
+	u8 rssi_level)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_					*p_ra_table = &p_dm->dm_ra_table;
-	struct _ADAPTER				*p_adapter	 =  p_dm->adapter;
-	struct _ADAPTER				*p_target_adapter = NULL;
-	HAL_DATA_TYPE			*p_hal_data = GET_HAL_DATA(p_adapter);
-	PMGNT_INFO				p_mgnt_info = GetDefaultMgntInfo(p_adapter);
-	struct _ADAPTER			*p_loop_adapter = GetDefaultAdapter(p_adapter);
-	PMGNT_INFO					p_loop_mgnt_info = &(p_loop_adapter->MgntInfo);
-	HAL_DATA_TYPE				*p_loop_hal_data = GET_HAL_DATA(p_loop_adapter);
-	
-	u32		i;
-	struct sta_info *p_entry;
-	u8		ratr_state_new;
-
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("%s ======>\n", __func__));
-
-	if (p_adapter->bDriverStopped) {
-		PHYDM_DBG(p_dm, DBG_RA_MASK, ("driver is going to unload\n"));
-		return;
-	}
-
-	if (!p_hal_data->bUseRAMask) {
-		PHYDM_DBG(p_dm, DBG_RA_MASK, ("driver does not control rate adaptive mask\n"));
-		return;
-	}
-
-	/* if default port is connected, update RA table for default port (infrastructure mode only) */
-	/* Need to consider other ports for P2P cases*/
-
-	while(p_loop_adapter){
-
-		p_loop_mgnt_info = &(p_loop_adapter->MgntInfo);
-		p_loop_hal_data = GET_HAL_DATA(p_loop_adapter);
-	
-		if (p_loop_mgnt_info->mAssoc && (!ACTING_AS_AP(p_loop_adapter))) {
-			odm_refresh_ldpc_rts_mp(p_loop_adapter, p_dm, p_loop_mgnt_info->mMacId, p_loop_mgnt_info->IOTPeer, p_loop_hal_data->UndecoratedSmoothedPWDB);
-		/*PHYDM_DBG(p_dm, DBG_RA_MASK, ("Infrasture mode\n"));*/
-
-			ratr_state_new = phydm_rssi_lv_dec(p_dm, p_loop_hal_data->UndecoratedSmoothedPWDB, p_loop_mgnt_info->Ratr_State);
-
-			if ((p_loop_mgnt_info->Ratr_State != ratr_state_new) || (p_ra_table->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
-
-				p_ra_table->up_ramask_cnt = 0;
-				PHYDM_PRINT_ADDR(p_dm, DBG_RA_MASK, ("Target AP addr :"), p_loop_mgnt_info->Bssid);
-				PHYDM_DBG(p_dm, DBG_RA_MASK, ("Update RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n\n",
-					p_mgnt_info->Ratr_State, ratr_state_new, p_loop_hal_data->UndecoratedSmoothedPWDB));
-
-				p_loop_mgnt_info->Ratr_State = ratr_state_new;
-				p_adapter->HalFunc.UpdateHalRAMaskHandler(p_loop_adapter, p_loop_mgnt_info->mMacId, NULL, ratr_state_new);
-			} else {
-				PHYDM_DBG(p_dm, DBG_RA_MASK, ("Stay in RA level  = (( %d ))\n\n", ratr_state_new));
-				/**/
-			}
-		}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-		p_loop_adapter = GetNextExtAdapter(p_loop_adapter);
+	if (dm->support_ic_type == ODM_RTL8812) {
+		#if (RTL8812A_SUPPORT == 1)
+		UpdateHalRAMask8812(priv, entry, rssi_level);
+		#endif
+	} else if (dm->support_ic_type == ODM_RTL8188E) {
+		#if (RTL8188E_SUPPORT == 1)
+		#ifdef TXREPORT
+		add_RATid(priv, entry);
+		#endif
+		#endif
+	} else {
+		#ifdef CONFIG_WLAN_HAL
+		GET_HAL_INTERFACE(priv)->UpdateHalRAMaskHandler(priv, entry, rssi_level);
+		#endif
 	}
+}
 
-	/*  */
-	/* The following part configure AP/VWifi/IBSS rate adaptive mask. */
-	/*  */
-
-	if (p_mgnt_info->mIbss)	/* Target: AP/IBSS peer. */
-		p_target_adapter = GetDefaultAdapter(p_adapter);
-	else
-		p_target_adapter = GetFirstAPAdapter(p_adapter);
+void phydm_update_hal_ra_mask(
+	void *dm_void,
+	u32 wireless_mode,
+	u8 rf_type,
+	u8 bw,
+	u8 mimo_ps_enable,
+	u8 disable_cck_rate,
+	u32 *ratr_bitmap_msb_in,
+	u32 *ratr_bitmap_lsb_in,
+	u8 tx_rate_level)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 ratr_bitmap = *ratr_bitmap_lsb_in;
+	u32 ratr_bitmap_msb = *ratr_bitmap_msb_in;
 
-	/* if extension port (softap) is started, updaet RA table for more than one clients associate */
-	if (p_target_adapter != NULL) {
-		for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
+#if 0
+	/*PHYDM_DBG(dm, DBG_RA_MASK, "phydm_rf_type = (( %x )), rf_type = (( %x ))\n", phydm_rf_type, rf_type);*/
+#endif
+	PHYDM_DBG(dm, DBG_RA_MASK,
+		  "Platfoem original RA Mask = (( 0x %x | %x ))\n",
+		  ratr_bitmap_msb, ratr_bitmap);
 
-			p_entry = AsocEntry_EnumStation(p_target_adapter, i);
+	switch (wireless_mode) {
+	case PHYDM_WIRELESS_MODE_B: {
+		ratr_bitmap &= 0x0000000f;
+	} break;
 
-			if (is_sta_active((&GET_STA_INFO(p_entry)))) {
+	case PHYDM_WIRELESS_MODE_G: {
+		ratr_bitmap &= 0x00000ff5;
+	} break;
 
-				odm_refresh_ldpc_rts_mp(p_target_adapter, p_dm, GET_STA_INFO(p_entry).mac_id, p_entry->IOTPeer, GET_STA_INFO(p_entry).rssi_stat.rssi);
+	case PHYDM_WIRELESS_MODE_A: {
+		ratr_bitmap &= 0x00000ff0;
+	} break;
 
-				ratr_state_new = phydm_rssi_lv_dec(p_dm, GET_STA_INFO(p_entry).rssi_stat.rssi, GET_STA_INFO(p_entry).ra_info.rssi_level);
+	case PHYDM_WIRELESS_MODE_N_24G:
+	case PHYDM_WIRELESS_MODE_N_5G: {
+		if (mimo_ps_enable)
+			rf_type = RF_1T1R;
 
-				if ((GET_STA_INFO(p_entry).ra_info.rssi_level != ratr_state_new) || (p_ra_table->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+		if (rf_type == RF_1T1R) {
+			if (bw == CHANNEL_WIDTH_40)
+				ratr_bitmap &= 0x000ff015;
+			else
+				ratr_bitmap &= 0x000ff005;
+		} else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R) {
+			if (bw == CHANNEL_WIDTH_40)
+				ratr_bitmap &= 0x0ffff015;
+			else
+				ratr_bitmap &= 0x0ffff005;
+		} else { /*@3T*/
 
-					p_ra_table->up_ramask_cnt = 0;
-					PHYDM_PRINT_ADDR(p_dm, DBG_RA_MASK, ("Target AP addr :"), GET_STA_INFO(p_entry).mac_addr);
-					PHYDM_DBG(p_dm, DBG_RA_MASK, ("Update Tx RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n",
-						GET_STA_INFO(p_entry).ra_info.rssi_level, ratr_state_new,  GET_STA_INFO(p_entry).rssi_stat.rssi));
+			ratr_bitmap &= 0xfffff015;
+			ratr_bitmap_msb &= 0xf;
+		}
+	} break;
 
-					GET_STA_INFO(p_entry).ra_info.rssi_level = ratr_state_new;
-					p_adapter->HalFunc.UpdateHalRAMaskHandler(p_target_adapter, GET_STA_INFO(p_entry).mac_id, p_entry, ratr_state_new);
-				} else {
-					PHYDM_DBG(p_dm, DBG_RA_MASK, ("Stay in RA level  = (( %d ))\n\n", ratr_state_new));
-					/**/
-				}
+	case PHYDM_WIRELESS_MODE_AC_24G: {
+		if (rf_type == RF_1T1R) {
+			ratr_bitmap &= 0x003ff015;
+		} else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R) {
+			ratr_bitmap &= 0xfffff015;
+		} else { /*@3T*/
 
-			}
+			ratr_bitmap &= 0xfffff010;
+			ratr_bitmap_msb &= 0x3ff;
 		}
-	}
-}
 
-#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+		if (bw == CHANNEL_WIDTH_20) { /*@AC 20MHz not support MCS9*/
+			ratr_bitmap &= 0x7fdfffff;
+			ratr_bitmap_msb &= 0x1ff;
+		}
+	} break;
 
-void
-odm_refresh_rate_adaptive_mask_ap(
-	void	*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-	struct rtl8192cd_priv *priv = p_dm->priv;
-	struct aid_obj *aidarray;
-	u32		i;
-	struct sta_info *p_entry;
-	struct cmn_sta_info	*p_sta;
-	u8		ratr_state_new;
-
-	if (priv->up_time % 2)
-		return;
+	case PHYDM_WIRELESS_MODE_AC_5G: {
+		if (rf_type == RF_1T1R) {
+			ratr_bitmap &= 0x003ff010;
+		} else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R) {
+			ratr_bitmap &= 0xfffff010;
+		} else { /*@3T*/
 
-	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		p_entry = p_dm->p_odm_sta_info[i];
-		p_sta = p_dm->p_phydm_sta_info[i];
+			ratr_bitmap &= 0xfffff010;
+			ratr_bitmap_msb &= 0x3ff;
+		}
 
-		if (is_sta_active(p_sta)) {
+		if (bw == CHANNEL_WIDTH_20) { /*@AC 20MHz not support MCS9*/
+			ratr_bitmap &= 0x7fdfffff;
+			ratr_bitmap_msb &= 0x1ff;
+		}
+	} break;
 
-			#if defined(UNIVERSAL_REPEATER) || defined(MBSSID)
-			aidarray = container_of(p_entry, struct aid_obj, station);
-			priv = aidarray->priv;
-			#endif
+	default:
+		break;
+	}
 
-			if (!priv->pmib->dot11StationConfigEntry.autoRate)
-				continue;
+	if (wireless_mode != PHYDM_WIRELESS_MODE_B) {
+		if (tx_rate_level == 0)
+			ratr_bitmap &= 0xffffffff;
+		else if (tx_rate_level == 1)
+			ratr_bitmap &= 0xfffffff0;
+		else if (tx_rate_level == 2)
+			ratr_bitmap &= 0xffffefe0;
+		else if (tx_rate_level == 3)
+			ratr_bitmap &= 0xffffcfc0;
+		else if (tx_rate_level == 4)
+			ratr_bitmap &= 0xffff8f80;
+		else if (tx_rate_level >= 5)
+			ratr_bitmap &= 0xffff0f00;
+	}
 
-			ratr_state_new = phydm_rssi_lv_dec(p_dm, (u32)p_sta->rssi_stat.rssi, p_sta->ra_info.rssi_level);
+	if (disable_cck_rate)
+		ratr_bitmap &= 0xfffffff0;
 
-			if ((p_sta->ra_info.rssi_level != ratr_state_new) || (p_ra_table->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+	PHYDM_DBG(dm, DBG_RA_MASK,
+		  "wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x )), MimoPs_en = (( %d )), tx_rate_level= (( 0x%x ))\n",
+		  wireless_mode, rf_type, bw, mimo_ps_enable, tx_rate_level);
 
-				p_ra_table->up_ramask_cnt = 0;
-				PHYDM_PRINT_ADDR(p_dm, DBG_RA_MASK, ("Target AP addr :"), p_sta->mac_addr);
-				PHYDM_DBG(p_dm, DBG_RA_MASK, ("Update Tx RA Level: ((%x)) -> ((%x)),  RSSI = ((%d))\n", p_sta->ra_info.rssi_level, ratr_state_new, p_sta->rssi_stat.rssi));
+#if 0
+	/*PHYDM_DBG(dm, DBG_RA_MASK, "111 Phydm modified RA Mask = (( 0x %x | %x ))\n", ratr_bitmap_msb, ratr_bitmap);*/
+#endif
 
-				p_sta->ra_info.rssi_level = ratr_state_new;
-				phydm_gen_ramask_h2c_AP(p_dm, priv, p_entry, p_sta->ra_info.rssi_level);
-			} else {
-				PHYDM_DBG(p_dm, DBG_RA_MASK, ("Stay in RA level  = (( %d ))\n\n", ratr_state_new));
-				/**/
-			}
-		}
-	}
+	*ratr_bitmap_lsb_in = ratr_bitmap;
+	*ratr_bitmap_msb_in = ratr_bitmap_msb;
+	PHYDM_DBG(dm, DBG_RA_MASK,
+		  "Phydm modified RA Mask = (( 0x %x | %x ))\n",
+		  *ratr_bitmap_msb_in, *ratr_bitmap_lsb_in);
 }
+
 #endif
 
-void
-phydm_rate_adaptive_mask_init(
-	void	*p_dm_void
-)
+void phydm_rate_adaptive_mask_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_	*p_ra_t = &p_dm->dm_ra_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_t = &dm->dm_ra_table;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PMGNT_INFO		p_mgnt_info = &p_dm->adapter->MgntInfo;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_dm->adapter);
+	PADAPTER adapter = dm->adapter;
+	PMGNT_INFO mgnt_info = &(adapter->MgntInfo);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)dm->adapter));
 
-	p_mgnt_info->Ratr_State = DM_RATR_STA_INIT;
-
-	if (p_mgnt_info->DM_Type == dm_type_by_driver)
-		p_hal_data->bUseRAMask = true;
+	if (mgnt_info->DM_Type == dm_type_by_driver)
+		hal_data->bUseRAMask = true;
 	else
-		p_hal_data->bUseRAMask = false;
+		hal_data->bUseRAMask = false;
 
 #endif
 
-	p_ra_t->ldpc_thres = 35;
-	p_ra_t->up_ramask_cnt = 0;
-	p_ra_t->up_ramask_cnt_tmp = 0;
-
+	ra_t->ldpc_thres = 35;
+	ra_t->up_ramask_cnt = 0;
+	ra_t->up_ramask_cnt_tmp = 0;
 }
 
-void
-phydm_refresh_rate_adaptive_mask(
-	void	*p_dm_void
-)
+void phydm_refresh_rate_adaptive_mask(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_	*p_ra_t = &p_dm->dm_ra_table;
-
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("%s ======>\n", __func__));
-
-	if (!(p_dm->support_ability & ODM_BB_RA_MASK)) {
-		PHYDM_DBG(p_dm, DBG_RA_MASK, ("Return: Not support\n"));
-		return;
-	}
-
-	if (!p_dm->is_linked)
-		return;
-
-	p_ra_t->up_ramask_cnt++;
-	/*p_ra_t->up_ramask_cnt_tmp++;*/
-	
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-	odm_refresh_rate_adaptive_mask_mp(p_dm);
-
-#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-	odm_refresh_rate_adaptive_mask_ap(p_dm);
+/*@Will be removed*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-#else /*(DM_ODM_SUPPORT_TYPE == ODM_CE)*/
-
-	phydm_ra_mask_watchdog(p_dm);
-
-#endif
-	
+	phydm_ra_mask_watchdog(dm);
 }
 
-void
-phydm_show_sta_info(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_show_sta_info(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info		*p_sta = NULL;
-	struct ra_sta_info			*p_ra = NULL;
-	#ifdef CONFIG_BEAMFORMING
-	struct bf_cmn_info		*p_bf = NULL;
-	#endif
-	char		help[] = "-h";
-	u32		var1[10] = {0};
-	u32		used = *_used;
-	u32		out_len = *_out_len;
-	u32		i, macid_start, macid_end;
-	u8		tatal_sta_num = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = NULL;
+	struct ra_sta_info *ra = NULL;
+#ifdef CONFIG_BEAMFORMING
+	struct bf_cmn_info *bf = NULL;
+#endif
+	char help[] = "-h";
+	u32 var[10] = {0};
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 i, sta_idx_start, sta_idx_end;
+	u8 tatal_sta_num = 0;
 
-	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var1[0]);
+	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &var[0]);
 
 	if ((strcmp(input[1], help) == 0)) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "All STA: {1}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "STA[macid]: {2} {macid}\n"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "All STA: {1}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "STA[macid]: {2} {macid}\n");
 		return;
-	} else if (var1[0] == 1) {
-		macid_start = 0;
-		macid_end = ODM_ASSOCIATE_ENTRY_NUM;
-	} else if (var1[0] == 2) {
-		macid_start = var1[1];
-		macid_end = var1[1];
+	} else if (var[0] == 1) {
+		sta_idx_start = 0;
+		sta_idx_end = ODM_ASSOCIATE_ENTRY_NUM;
+	} else if (var[0] == 2) {
+		sta_idx_start = var[1];
+		sta_idx_end = var[1];
 	} else {
-		PHYDM_SNPRINTF((output + used, out_len - used, "Warning input value!\n"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Warning input value!\n");
 		return;
 	}
-		
-	for (i = macid_start; i < macid_end; i++) {
-		
-		p_sta = p_dm->p_phydm_sta_info[i];
 
+	for (i = sta_idx_start; i < sta_idx_end; i++) {
+		sta = dm->phydm_sta_info[i];
 
-		if (!is_sta_active(p_sta))
+		if (!is_sta_active(sta))
 			continue;
 
-		p_ra = &(p_sta->ra_info);
+		ra = &sta->ra_info;
 		#ifdef CONFIG_BEAMFORMING
-		p_bf = &(p_sta->bf_info);
+		bf = &sta->bf_info;
 		#endif
 
 		tatal_sta_num++;
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "==[MACID: %d]============>\n", p_sta->mac_id));
-		PHYDM_SNPRINTF((output + used, out_len - used, "AID:%d\n", p_sta->aid));
-		PHYDM_SNPRINTF((output + used, out_len - used, "ADDR:%x-%x-%x-%x-%x-%x\n", 
-		p_sta->mac_addr[5], p_sta->mac_addr[4], p_sta->mac_addr[3], p_sta->mac_addr[2], p_sta->mac_addr[1], p_sta->mac_addr[0]));
-		PHYDM_SNPRINTF((output + used, out_len - used, "DM_ctrl:0x%x\n", p_sta->dm_ctrl));
-		PHYDM_SNPRINTF((output + used, out_len - used, "BW:%d, MIMO_Type:0x%x\n", p_sta->bw_mode, p_sta->mimo_type));
-		PHYDM_SNPRINTF((output + used, out_len - used, "STBC_en:%d, LDPC_en=%d\n", p_sta->stbc_en, p_sta->ldpc_en));
-
-		/*[RSSI Info]*/
-		PHYDM_SNPRINTF((output + used, out_len - used, "RSSI{All, OFDM, CCK}={%d, %d, %d}\n", 
-			p_sta->rssi_stat.rssi, p_sta->rssi_stat.rssi_ofdm, p_sta->rssi_stat.rssi_cck));
-
-		/*[RA Info]*/
-		PHYDM_SNPRINTF((output + used, out_len - used, "Rate_ID:%d, RSSI_LV:%d, ra_bw:%d, SGI_en:%d\n", 
-			p_ra->rate_id, p_ra->rssi_level, p_ra->ra_bw_mode, p_ra->is_support_sgi));
-
-		PHYDM_SNPRINTF((output + used, out_len - used, "VHT_en:%d, Wireless_set=0x%x, sm_ps=%d\n", 
-			p_ra->is_vht_enable, p_sta->support_wireless_set, p_sta->sm_ps));
-
-		PHYDM_SNPRINTF((output + used, out_len - used, "Dis{RA, PT}={%d, %d}, TxRx:%d, Noisy:%d\n", 
-			p_ra->disable_ra, p_ra->disable_pt, p_ra->txrx_state, p_ra->is_noisy));
-		
-		PHYDM_SNPRINTF((output + used, out_len - used, "TX{Rate, BW}={%d, %d}, RTY:%d\n", 
-			p_ra->curr_tx_rate, p_ra->curr_tx_bw, p_ra->curr_retry_ratio));
-	
-		PHYDM_SNPRINTF((output + used, out_len - used, "RA_MAsk:0x%llx\n", p_ra->ramask));
-		
-		/*[TP]*/
-		PHYDM_SNPRINTF((output + used, out_len - used, "TP{TX,RX}={%d, %d}\n", 
-			p_sta->tx_moving_average_tp, p_sta->rx_moving_average_tp));
-
-		#ifdef CONFIG_BEAMFORMING
-		/*[Beamforming]*/
-		PHYDM_SNPRINTF((output + used, out_len - used, "CAP{HT,VHT}={0x%x, 0x%x}\n", 
-			p_bf->ht_beamform_cap, p_bf->vht_beamform_cap));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{p_aid,g_id}={0x%x, 0x%x}\n\n", 
-			p_bf->p_aid, p_bf->g_id));
-		#endif
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "==[sta_idx: %d][MACID: %d]============>\n", i,
+			 sta->mac_id);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "AID:%d\n", sta->aid);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "ADDR:%x-%x-%x-%x-%x-%x\n", sta->mac_addr[5],
+			 sta->mac_addr[4], sta->mac_addr[3], sta->mac_addr[2],
+			 sta->mac_addr[1], sta->mac_addr[0]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "DM_ctrl:0x%x\n", sta->dm_ctrl);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "BW:%d, MIMO_Type:0x%x\n", sta->bw_mode,
+			 sta->mimo_type);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "STBC_en:%d, LDPC_en=%d\n", sta->stbc_en,
+			 sta->ldpc_en);
+
+		/*@[RSSI Info]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "RSSI{All, OFDM, CCK}={%d, %d, %d}\n",
+			 sta->rssi_stat.rssi, sta->rssi_stat.rssi_ofdm,
+			 sta->rssi_stat.rssi_cck);
+
+		/*@[RA Info]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Rate_ID:%d, RSSI_LV:%d, ra_bw:%d, SGI_en:%d\n",
+			 ra->rate_id, ra->rssi_level, ra->ra_bw_mode,
+			 ra->is_support_sgi);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "VHT_en:%d, Wireless_set=0x%x, sm_ps=%d\n",
+			 ra->is_vht_enable, sta->support_wireless_set,
+			 sta->sm_ps);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Dis{RA, PT}={%d, %d}, TxRx:%d, Noisy:%d\n",
+			 ra->disable_ra, ra->disable_pt, ra->txrx_state,
+			 ra->is_noisy);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "TX{Rate, BW}={0x%x, %d}, RTY:%d\n", ra->curr_tx_rate,
+			 ra->curr_tx_bw, ra->curr_retry_ratio);
+
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "RA_Mask:0x%llx\n", ra->ramask);
+
+		/*@[TP]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "TP{TX,RX}={%d, %d}\n", sta->tx_moving_average_tp,
+			 sta->rx_moving_average_tp);
+
+#ifdef CONFIG_BEAMFORMING
+		/*@[Beamforming]*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "BF CAP{HT,VHT}={0x%x, 0x%x}\n", bf->ht_beamform_cap,
+			 bf->vht_beamform_cap);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "BF {p_aid,g_id}={0x%x, 0x%x}\n\n", bf->p_aid,
+			 bf->g_id);
+#endif
 	}
 
 	if (tatal_sta_num == 0) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "No Linked STA\n"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "No Linked STA\n");
 	}
-	
+
 	*_used = used;
 	*_out_len = out_len;
 }
 
-#ifdef	PHYDM_3RD_REFORM_RA_MASK
-
-u8
-phydm_get_tx_stream_num(
-	void		*p_dm_void,
-	enum 	rf_type	mimo_type
-	
-)
+u8 phydm_get_tx_stream_num(void *dm_void, enum rf_type type)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	tx_num = 1;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 tx_num = 1;
 
-	if (mimo_type == RF_1T1R || mimo_type == RF_1T2R)
+	if (type == RF_1T1R || type == RF_1T2R)
 		tx_num = 1;
-	else if (mimo_type == RF_2T2R || mimo_type == RF_2T3R  || mimo_type == RF_2T4R)
+	else if (type == RF_2T2R || type == RF_2T3R || type == RF_2T4R)
 		tx_num = 2;
-	else if (mimo_type == RF_3T3R || mimo_type == RF_3T4R)
+	else if (type == RF_3T3R || type == RF_3T4R)
 		tx_num = 3;
-	else if (mimo_type == RF_4T4R)
+	else if (type == RF_4T4R)
 		tx_num = 4;
-	else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warrning] no mimo_type is found\n"));
-	}
+	else
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] no mimo_type is found\n");
+
 	return tx_num;
 }
 
-u64
-phydm_get_bb_mod_ra_mask(
-	void		*p_dm_void,
-	u8		macid
-)
+u64 phydm_get_bb_mod_ra_mask(void *dm_void, u8 sta_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info		*p_sta = p_dm->p_phydm_sta_info[macid];
-	struct ra_sta_info			*p_ra = NULL;
-	enum channel_width		bw = 0;
-	enum wireless_set			wireless_mode = 0;
-	u8		tx_stream_num = 1;
-	u8		rssi_lv = 0;
-	u64		ra_mask_bitmap = 0;
-	
-	if (is_sta_active(p_sta)) {
-		
-		p_ra = &(p_sta->ra_info);
-		bw = p_ra->ra_bw_mode;
-		wireless_mode = p_sta->support_wireless_set;
-		tx_stream_num = phydm_get_tx_stream_num(p_dm, p_sta->mimo_type);
-		rssi_lv = p_ra->rssi_level;
-		ra_mask_bitmap = p_ra->ramask;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+	struct ra_sta_info *ra = NULL;
+	enum channel_width bw = 0;
+	enum wireless_set wrls_mode = 0;
+	u8 tx_stream_num = 1;
+	u8 rssi_lv = 0;
+	u64 ra_mask_bitmap = 0;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+		bw = ra->ra_bw_mode;
+		wrls_mode = sta->support_wireless_set;
+		tx_stream_num = phydm_get_tx_stream_num(dm, sta->mimo_type);
+		rssi_lv = ra->rssi_level;
+		ra_mask_bitmap = ra->ramask;
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warning] %s invalid sta_info\n", __func__));
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid STA\n", __func__);
 		return 0;
 	}
 
-	PHYDM_DBG(p_dm, DBG_RA, ("macid=%d ori_RA_Mask= 0x%llx\n", macid, ra_mask_bitmap));
-	PHYDM_DBG(p_dm, DBG_RA, ("wireless_mode=0x%x, tx_stream_num=%d, BW=%d, MimoPs=%d, rssi_lv=%d\n",
-		wireless_mode, tx_stream_num, bw, p_sta->sm_ps, rssi_lv));
-	
-	if (p_sta->sm_ps == SM_PS_STATIC) /*mimo_ps_enable*/
-		tx_stream_num = 1;
+	PHYDM_DBG(dm, DBG_RA, "macid=%d ori_RA_Mask= 0x%llx\n", sta->mac_id,
+		  ra_mask_bitmap);
+	PHYDM_DBG(dm, DBG_RA,
+		  "wireless_mode=0x%x, tx_ss=%d, BW=%d, MimoPs=%d, rssi_lv=%d\n",
+		  wrls_mode, tx_stream_num, bw, sta->sm_ps, rssi_lv);
 
+	if (sta->sm_ps == SM_PS_STATIC) /*@mimo_ps_enable*/
+		tx_stream_num = 1;
 
-	/*[Modify RA Mask by Wireless Mode]*/
+	/*@[Modify RA Mask by Wireless Mode]*/
 
-	if (wireless_mode == WIRELESS_CCK)								/*B mode*/
+	if (wrls_mode == WIRELESS_CCK) { /*@B mode*/
 		ra_mask_bitmap &= 0x0000000f;
-	else if (wireless_mode == WIRELESS_OFDM)							/*G mode*/
+	} else if (wrls_mode == WIRELESS_OFDM) { /*@G mode*/
 		ra_mask_bitmap &= 0x00000ff0;
-	else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM))			/*BG mode*/
+	} else if (wrls_mode == (WIRELESS_CCK | WIRELESS_OFDM)) { /*@BG mode*/
 		ra_mask_bitmap &= 0x00000ff5;
-	else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {
-																	/*N_2G*/
+	} else if (wrls_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {
+		/*N_2G*/
 		if (tx_stream_num == 1) {
 			if (bw == CHANNEL_WIDTH_40)
 				ra_mask_bitmap &= 0x000ff015;
 			else
 				ra_mask_bitmap &= 0x000ff005;
 		} else if (tx_stream_num == 2) {
-
 			if (bw == CHANNEL_WIDTH_40)
 				ra_mask_bitmap &= 0x0ffff015;
 			else
 				ra_mask_bitmap &= 0x0ffff005;
-		} else if (tx_stream_num == 3)
+		} else if (tx_stream_num == 3) {
 			ra_mask_bitmap &= 0xffffff015;
-	} else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_HT)) {		/*N_5G*/
-	
+		} else {
+			ra_mask_bitmap &= 0xffffffff015;
+		}
+	} else if (wrls_mode == (WIRELESS_OFDM | WIRELESS_HT)) { /*N_5G*/
+
 		if (tx_stream_num == 1) {
 			if (bw == CHANNEL_WIDTH_40)
 				ra_mask_bitmap &= 0x000ff030;
 			else
 				ra_mask_bitmap &= 0x000ff010;
 		} else if (tx_stream_num == 2) {
-
 			if (bw == CHANNEL_WIDTH_40)
 				ra_mask_bitmap &= 0x0ffff030;
 			else
 				ra_mask_bitmap &= 0x0ffff010;
-		} else if (tx_stream_num == 3)
+		} else if (tx_stream_num == 3) {
 			ra_mask_bitmap &= 0xffffff010;
-	} else if (wireless_mode ==  (WIRELESS_CCK |WIRELESS_OFDM | WIRELESS_VHT)) {
-																	/*AC_2G*/
+		} else {
+			ra_mask_bitmap &= 0xffffffff010;
+		}
+	} else if (wrls_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_VHT)) {
+		/*@AC_2G*/
 		if (tx_stream_num == 1)
 			ra_mask_bitmap &= 0x003ff015;
 		else if (tx_stream_num == 2)
 			ra_mask_bitmap &= 0xfffff015;
 		else if (tx_stream_num == 3)
-			ra_mask_bitmap &= 0x3fffffff010;
-		
-
-		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
-			ra_mask_bitmap &= 0x1ff7fdfffff;
+			ra_mask_bitmap &= 0x3fffffff015;
+		else /*@AC_4SS 2G*/
+			ra_mask_bitmap &= 0x000ffffffffff015;
+		if (bw == CHANNEL_WIDTH_20) {
+		/* @AC 20MHz doesn't support MCS9 except 3SS & 6SS*/
+			ra_mask_bitmap &= 0x0007ffff7fdff015;
+		} else if (bw == CHANNEL_WIDTH_80) {
+		/* @AC 80MHz doesn't support 3SS MCS6*/
+			ra_mask_bitmap &= 0x000fffbffffff015;
 		}
-	} else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_VHT)) {		/*AC_5G*/
-	
+	} else if (wrls_mode == (WIRELESS_OFDM | WIRELESS_VHT)) { /*@AC_5G*/
+
 		if (tx_stream_num == 1)
 			ra_mask_bitmap &= 0x003ff010;
 		else if (tx_stream_num == 2)
 			ra_mask_bitmap &= 0xfffff010;
-		else  if (tx_stream_num == 3)
+		else if (tx_stream_num == 3)
 			ra_mask_bitmap &= 0x3fffffff010;
-
-		if (bw == CHANNEL_WIDTH_20) /* AC 20MHz doesn't support MCS9 */
-			ra_mask_bitmap &= 0x1ff7fdfffff;
+		else /*@AC_4SS 5G*/
+			ra_mask_bitmap &= 0x000ffffffffff010;
+
+		if (bw == CHANNEL_WIDTH_20) {
+		/* @AC 20MHz doesn't support MCS9 except 3SS & 6SS*/
+			ra_mask_bitmap &= 0x0007ffff7fdff010;
+		} else if (bw == CHANNEL_WIDTH_80) {
+		/* @AC 80MHz doesn't support 3SS MCS6*/
+			ra_mask_bitmap &= 0x000fffbffffff010;
+		}
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warrning] No RA mask is found\n"));
-		/**/
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] RA mask is Not found\n");
 	}
-	
-	PHYDM_DBG(p_dm, DBG_RA, ("Mod by mode=0x%llx\n", ra_mask_bitmap));
 
-	
-	/*[Modify RA Mask by RSSI level]*/
-	if (wireless_mode != WIRELESS_CCK) {
+	PHYDM_DBG(dm, DBG_RA, "Mod by mode=0x%llx\n", ra_mask_bitmap);
 
+	/*@[Modify RA Mask by RSSI level]*/
+	if (wrls_mode != WIRELESS_CCK) {
 		if (rssi_lv == 0)
-			ra_mask_bitmap &=  0xffffffff;
+			ra_mask_bitmap &= 0xffffffffffffffff;
 		else if (rssi_lv == 1)
-			ra_mask_bitmap &=  0xfffffff0;
+			ra_mask_bitmap &= 0xfffffffffffffff0;
 		else if (rssi_lv == 2)
-			ra_mask_bitmap &=  0xffffefe0;
+			ra_mask_bitmap &= 0xffffffffffffefe0;
 		else if (rssi_lv == 3)
-			ra_mask_bitmap &=  0xffffcfc0;
+			ra_mask_bitmap &= 0xffffffffffffcfc0;
 		else if (rssi_lv == 4)
-			ra_mask_bitmap &=  0xffff8f80;
+			ra_mask_bitmap &= 0xffffffffffff8f80;
 		else if (rssi_lv >= 5)
-			ra_mask_bitmap &=  0xffff0f00;
-
+			ra_mask_bitmap &= 0xffffffffffff0f00;
 	}
-	PHYDM_DBG(p_dm, DBG_RA, ("Mod by RSSI=0x%llx\n", ra_mask_bitmap));
+	PHYDM_DBG(dm, DBG_RA, "Mod by RSSI=0x%llx\n", ra_mask_bitmap);
 
 	return ra_mask_bitmap;
 }
 
-u8
-phydm_get_rate_id(
-	void			*p_dm_void,
-	u8			macid
-)
+u8 phydm_get_rate_from_rssi_lv(void *dm_void, u8 sta_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info		*p_sta = p_dm->p_phydm_sta_info[macid];
-	struct ra_sta_info			*p_ra =NULL;
-	enum channel_width		bw = 0;
-	enum wireless_set			wireless_mode = 0;
-	u8	tx_stream_num = 1;
-	u8	rate_id_idx = PHYDM_BGN_20M_1SS;
-
-	if (is_sta_active(p_sta)) {
-		
-		p_ra = &(p_sta->ra_info);
-		bw = p_ra->ra_bw_mode;
-		wireless_mode = p_sta->support_wireless_set;
-		tx_stream_num = phydm_get_tx_stream_num(p_dm, p_sta->mimo_type);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+	struct ra_sta_info *ra = NULL;
+	enum wireless_set wrls_set = 0;
+	u8 rssi_lv = 0;
+	u8 rate_idx = 0;
+	u8 rate_ofst = 0;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+		wrls_set = sta->support_wireless_set;
+		rssi_lv = ra->rssi_level;
+	} else {
+		pr_debug("[Warning] %s: invalid STA\n", __func__);
+		return 0;
+	}
+
+	PHYDM_DBG(dm, DBG_RA, "[%s]macid=%d, wireless_set=0x%x, rssi_lv=%d\n",
+		  __func__, sta->mac_id, wrls_set, rssi_lv);
+
+	rate_ofst = (rssi_lv <= 1) ? 0 : (rssi_lv - 1);
+
+	if (wrls_set & WIRELESS_VHT) {
+		rate_idx = ODM_RATEVHTSS1MCS0 + rate_ofst;
+	} else if (wrls_set & WIRELESS_HT) {
+		rate_idx = ODM_RATEMCS0 + rate_ofst;
+	} else if (wrls_set & WIRELESS_OFDM) {
+		rate_idx = ODM_RATE6M + rate_ofst;
+	} else {
+		rate_idx = ODM_RATE1M + rate_ofst;
+
+		if (rate_idx > ODM_RATE11M)
+			rate_idx = ODM_RATE11M;
+	}
+	return rate_idx;
+}
+
+u8 phydm_get_rate_id(void *dm_void, u8 sta_idx)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+	struct ra_sta_info *ra = NULL;
+	enum channel_width bw = 0;
+	enum wireless_set wrls_mode = 0;
+	u8 tx_stream_num = 1;
+	u8 rate_id_idx = PHYDM_BGN_20M_1SS;
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+		bw = ra->ra_bw_mode;
+		wrls_mode = sta->support_wireless_set;
+		tx_stream_num = phydm_get_tx_stream_num(dm, sta->mimo_type);
 
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warning] %s: invalid sta_info\n", __func__));
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s: invalid STA\n", __func__);
 		return 0;
 	}
 
-	PHYDM_DBG(p_dm, DBG_RA, ("macid=%d, wireless_set=0x%x, tx_stream_num=%d, BW=0x%x\n",
-			macid, wireless_mode, tx_stream_num, bw));
+	PHYDM_DBG(dm, DBG_RA, "macid=%d,wireless_set=0x%x,tx_SS_num=%d,BW=%d\n",
+		  sta->mac_id, wrls_mode, tx_stream_num, bw);
 
-	if (wireless_mode == WIRELESS_CCK)								/*B mode*/
+	if (wrls_mode == WIRELESS_CCK) {
+	/*@B mode*/
 		rate_id_idx = PHYDM_B_20M;
-	else if (wireless_mode ==  WIRELESS_OFDM)						/*G mode*/
+	} else if (wrls_mode == WIRELESS_OFDM) {
+	/*@G mode*/
 		rate_id_idx = PHYDM_G;
-	else if (wireless_mode ==  (WIRELESS_CCK | WIRELESS_OFDM))			/*BG mode*/
+	} else if (wrls_mode == (WIRELESS_CCK | WIRELESS_OFDM)) {
+	/*@BG mode*/
 		rate_id_idx = PHYDM_BG;
-	else if (wireless_mode ==  (WIRELESS_OFDM | WIRELESS_HT)) {		/*GN mode*/
-	
+	} else if (wrls_mode == (WIRELESS_OFDM | WIRELESS_HT)) {
+	/*@GN mode*/
 		if (tx_stream_num == 1)
 			rate_id_idx = PHYDM_GN_N1SS;
 		else if (tx_stream_num == 2)
 			rate_id_idx = PHYDM_GN_N2SS;
 		else if (tx_stream_num == 3)
 			rate_id_idx = PHYDM_ARFR5_N_3SS;
-	} else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {	/*BGN mode*/
-	
-
+	} else if (wrls_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_HT)) {
+	 /*@BGN mode*/
 		if (bw == CHANNEL_WIDTH_40) {
-
 			if (tx_stream_num == 1)
 				rate_id_idx = PHYDM_BGN_40M_1SS;
 			else if (tx_stream_num == 2)
 				rate_id_idx = PHYDM_BGN_40M_2SS;
 			else if (tx_stream_num == 3)
 				rate_id_idx = PHYDM_ARFR5_N_3SS;
+			else if (tx_stream_num == 4)
+				rate_id_idx = PHYDM_ARFR7_N_4SS;
 
 		} else {
-
 			if (tx_stream_num == 1)
 				rate_id_idx = PHYDM_BGN_20M_1SS;
 			else if (tx_stream_num == 2)
 				rate_id_idx = PHYDM_BGN_20M_2SS;
 			else if (tx_stream_num == 3)
 				rate_id_idx = PHYDM_ARFR5_N_3SS;
+			else if (tx_stream_num == 4)
+				rate_id_idx = PHYDM_ARFR7_N_4SS;
 		}
-	} else if (wireless_mode == (WIRELESS_OFDM | WIRELESS_VHT)) {	/*AC mode*/
-	
+	} else if (wrls_mode == (WIRELESS_OFDM | WIRELESS_VHT)) {
+	/*@AC mode*/
 		if (tx_stream_num == 1)
 			rate_id_idx = PHYDM_ARFR1_AC_1SS;
 		else if (tx_stream_num == 2)
 			rate_id_idx = PHYDM_ARFR0_AC_2SS;
 		else if (tx_stream_num == 3)
 			rate_id_idx = PHYDM_ARFR4_AC_3SS;
-	} else if (wireless_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_VHT)) {	/*AC 2.4G mode*/
-	
+		else if (tx_stream_num == 4)
+			rate_id_idx = PHYDM_ARFR6_AC_4SS;
+	} else if (wrls_mode == (WIRELESS_CCK | WIRELESS_OFDM | WIRELESS_VHT)) {
+	/*@AC 2.4G mode*/
 		if (bw >= CHANNEL_WIDTH_80) {
 			if (tx_stream_num == 1)
 				rate_id_idx = PHYDM_ARFR1_AC_1SS;
@@ -989,348 +1088,393 @@ phydm_get_rate_id(
 				rate_id_idx = PHYDM_ARFR0_AC_2SS;
 			else if (tx_stream_num == 3)
 				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+			else if (tx_stream_num == 4)
+				rate_id_idx = PHYDM_ARFR6_AC_4SS;
 		} else {
-
 			if (tx_stream_num == 1)
 				rate_id_idx = PHYDM_ARFR2_AC_2G_1SS;
 			else if (tx_stream_num == 2)
 				rate_id_idx = PHYDM_ARFR3_AC_2G_2SS;
 			else if (tx_stream_num == 3)
 				rate_id_idx = PHYDM_ARFR4_AC_3SS;
+			else if (tx_stream_num == 4)
+				rate_id_idx = PHYDM_ARFR6_AC_4SS;
 		}
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warrning] No rate_id is found\n"));
+		PHYDM_DBG(dm, DBG_RA, "[Warrning] No rate_id is found\n");
 		rate_id_idx = 0;
 	}
-	
-	PHYDM_DBG(p_dm, DBG_RA, ("Rate_ID=((0x%x))\n", rate_id_idx));
+
+	PHYDM_DBG(dm, DBG_RA, "Rate_ID=((0x%x))\n", rate_id_idx);
 
 	return rate_id_idx;
 }
 
-void
-phydm_ra_h2c(
-	void	*p_dm_void,
-	u8	macid,
-	u8	dis_ra,
-	u8	dis_pt,
-	u8	no_update_bw,
-	u8	init_ra_lv,
-	u64	ra_mask
-)
+void phydm_ra_h2c(void *dm_void, u8 sta_idx, u8 dis_ra, u8 dis_pt,
+		  u8 no_update_bw, u8 init_ra_lv, u64 ra_mask)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info			*p_sta = p_dm->p_phydm_sta_info[macid];
-	struct ra_sta_info				*p_ra = NULL;
-	u8		h2c_val[H2C_MAX_LENGTH] = {0};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+	struct ra_sta_info *ra = NULL;
+	u8 h2c_val[H2C_MAX_LENGTH] = {0};
 
-	if (is_sta_active(p_sta)) {
-		p_ra = &(p_sta->ra_info);
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warning] %s invalid sta_info\n", __func__));
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid sta_info\n",
+			  __func__);
 		return;
 	}
-	
-	PHYDM_DBG(p_dm, DBG_RA, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_RA, ("MACID=%d\n", p_sta->mac_id));
 
-	if (p_dm->is_disable_power_training == true)
+	PHYDM_DBG(dm, DBG_RA, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA, "MACID=%d\n", sta->mac_id);
+
+	if (dm->is_disable_power_training)
 		dis_pt = true;
-	else if (p_dm->is_disable_power_training == false)
+	else if (!dm->is_disable_power_training)
 		dis_pt = false;
 
-	h2c_val[0] = p_sta->mac_id;
-	h2c_val[1] = (p_ra->rate_id & 0x1f) | ((init_ra_lv & 0x3) << 5) | (p_ra->is_support_sgi << 7);
-	h2c_val[2] = (u8)((p_ra->ra_bw_mode) | (((p_sta->ldpc_en) ? 1 : 0) << 2) | 
-					((no_update_bw & 0x1) << 3) | (p_ra->is_vht_enable << 4) | 
-					((dis_pt & 0x1) << 6) | ((dis_ra & 0x1) << 7));
-	
+	h2c_val[0] = sta->mac_id;
+	h2c_val[1] = (ra->rate_id & 0x1f) | ((init_ra_lv & 0x3) << 5) |
+		     (ra->is_support_sgi << 7);
+	h2c_val[2] = (u8)((ra->ra_bw_mode) | (((sta->ldpc_en) ? 1 : 0) << 2) |
+			  ((no_update_bw & 0x1) << 3) |
+			  (ra->is_vht_enable << 4) |
+			  ((dis_pt & 0x1) << 6) | ((dis_ra & 0x1) << 7));
+
 	h2c_val[3] = (u8)(ra_mask & 0xff);
 	h2c_val[4] = (u8)((ra_mask & 0xff00) >> 8);
 	h2c_val[5] = (u8)((ra_mask & 0xff0000) >> 16);
 	h2c_val[6] = (u8)((ra_mask & 0xff000000) >> 24);
 
-	PHYDM_DBG(p_dm, DBG_RA, ("PHYDM h2c[0x40]=0x%x %x %x %x %x %x %x\n",
-		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]));
+	PHYDM_DBG(dm, DBG_RA, "PHYDM h2c[0x40]=0x%x %x %x %x %x %x %x\n",
+		  h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2],
+		  h2c_val[1], h2c_val[0]);
 
-	odm_fill_h2c_cmd(p_dm, PHYDM_H2C_RA_MASK, H2C_MAX_LENGTH, h2c_val);
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_RA_MASK, H2C_MAX_LENGTH, h2c_val);
 
 	#if (defined(PHYDM_COMPILE_ABOVE_3SS))
-	if (p_dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
-		
+	if (dm->support_ic_type & (PHYDM_IC_ABOVE_3SS)) {
 		h2c_val[3] = (u8)((ra_mask >> 32) & 0x000000ff);
 		h2c_val[4] = (u8)(((ra_mask >> 32) & 0x0000ff00) >> 8);
 		h2c_val[5] = (u8)(((ra_mask >> 32) & 0x00ff0000) >> 16);
 		h2c_val[6] = (u8)(((ra_mask >> 32) & 0xff000000) >> 24);
 
-		PHYDM_DBG(p_dm, DBG_RA, ("PHYDM h2c[0x46]=0x%x %x %x %x %x %x %x\n",
-		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]));
-		
-		odm_fill_h2c_cmd(p_dm, PHYDM_RA_MASK_ABOVE_3SS, 5, h2c_val);
+		PHYDM_DBG(dm, DBG_RA, "h2c[0x46]=0x%x %x %x %x %x %x %x\n",
+			  h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3],
+			  h2c_val[2], h2c_val[1], h2c_val[0]);
+
+		odm_fill_h2c_cmd(dm, PHYDM_RA_MASK_ABOVE_3SS,
+				 H2C_MAX_LENGTH, h2c_val);
 	}
 	#endif
 }
 
-void
-phydm_ra_registed(
-	void	*p_dm_void,
-	u8	macid,
-	u8	rssi_from_assoc
-)
+void phydm_ra_registed(void *dm_void, u8 sta_idx,
+		       /*@index of sta_info array, not MACID*/
+		       u8 rssi_from_assoc)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_	*p_ra_t = &p_dm->dm_ra_table;
-	struct cmn_sta_info			*p_sta = p_dm->p_phydm_sta_info[macid];
-	struct ra_sta_info				*p_ra = NULL;
-	u8	init_ra_lv;
-	u64	ra_mask;
-
-	if (is_sta_active(p_sta)) {
-		p_ra = &(p_sta->ra_info);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+	struct ra_sta_info *ra = NULL;
+	u8 init_ra_lv = 0;
+	u64 ra_mask = 0;
+	/*@SD7 STA_idx != macid*/
+	/*@SD4,8 STA_idx == macid, */
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
+
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
+		PHYDM_DBG(dm, DBG_RA_MASK, "sta_idx=%d, macid=%d\n", sta_idx,
+			  sta->mac_id);
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warning] %s invalid sta_info\n", __func__));
+		PHYDM_DBG(dm, DBG_RA_MASK, "[Warning] %s invalid STA\n",
+			  __func__);
+		PHYDM_DBG(dm, DBG_RA_MASK, "sta_idx=%d\n", sta_idx);
 		return;
 	}
 
-	PHYDM_DBG(p_dm, DBG_RA, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_RA, ("MACID=%d\n", p_sta->mac_id));
-
-
 	#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188E)
-		phydm_get_rate_id_88e(p_dm, macid);
+	if (dm->support_ic_type == ODM_RTL8188E)
+		ra->rate_id = phydm_get_rate_id_88e(dm, sta_idx);
 	else
 	#endif
 	{
-		p_ra->rate_id = phydm_get_rate_id(p_dm, macid);
+		ra->rate_id = phydm_get_rate_id(dm, sta_idx);
 	}
-	
-	/*p_ra->is_vht_enable = (p_sta->support_wireless_set | WIRELESS_VHT) ? 1 : 0;*/
-	/*p_ra->disable_ra = 0;*/
-	/*p_ra->disable_pt = 0;*/
-	ra_mask = phydm_get_bb_mod_ra_mask(p_dm, macid);
 
+	ra_mask = phydm_get_bb_mod_ra_mask(dm, sta_idx);
+
+	PHYDM_DBG(dm, DBG_RA_MASK, "rssi_assoc=%d\n", rssi_from_assoc);
 
 	if (rssi_from_assoc > 40)
-		init_ra_lv = 3;
+		init_ra_lv = 1;
 	else if (rssi_from_assoc > 20)
 		init_ra_lv = 2;
+	else if (rssi_from_assoc > 1)
+		init_ra_lv = 3;
 	else
-		init_ra_lv = 1;
+		init_ra_lv = 0;
 
-	if (p_ra_t->record_ra_info)
-		p_ra_t->record_ra_info(p_dm, macid, p_sta, ra_mask);
+	if (ra_t->record_ra_info)
+		ra_t->record_ra_info(dm, sta_idx, sta, ra_mask);
 
 	#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188E)
-		/*Driver RA*/
-		odm_ra_update_rate_info_8188e(p_dm, macid, p_ra->rate_id, (u32)ra_mask, p_ra->is_support_sgi);
+	if (dm->support_ic_type == ODM_RTL8188E)
+		/*@Driver RA*/
+		phydm_ra_update_8188e(dm, sta_idx, ra->rate_id,
+				      (u32)ra_mask, ra->is_support_sgi);
 	else
 	#endif
 	{
-		/*FW RA*/
-		phydm_ra_h2c(p_dm, macid, p_ra->disable_ra, p_ra->disable_pt, 0, init_ra_lv, ra_mask);
+		/*@FW RA*/
+		phydm_ra_h2c(dm, sta_idx, ra->disable_ra, ra->disable_pt, 0,
+			     init_ra_lv, ra_mask);
 	}
-
-	
-
 }
 
-void
-phydm_ra_offline(
-	void	*p_dm_void,
-	u8	macid
-)
+void phydm_ra_offline(void *dm_void, u8 sta_idx)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_	*p_ra_t = &p_dm->dm_ra_table;
-	struct cmn_sta_info			*p_sta = p_dm->p_phydm_sta_info[macid];
-	struct ra_sta_info				*p_ra = NULL;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[sta_idx];
+	struct ra_sta_info *ra = NULL;
 
-	if (is_sta_active(p_sta)) {
-		p_ra = &(p_sta->ra_info);
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[Warning] %s invalid sta_info\n", __func__));
+		PHYDM_DBG(dm, DBG_RA, "[Warning] %s invalid STA\n", __func__);
 		return;
 	}
 
-	PHYDM_DBG(p_dm, DBG_RA, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_RA, ("MACID=%d\n", p_sta->mac_id));
+	PHYDM_DBG(dm, DBG_RA, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RA, "MACID=%d\n", sta->mac_id);
 
-	odm_memory_set(p_dm, &(p_ra->rate_id), 0, sizeof(struct ra_sta_info));
-	p_ra->disable_ra = 1;
-	p_ra->disable_pt = 1;
+	odm_memory_set(dm, &ra->rate_id, 0, sizeof(struct ra_sta_info));
+	ra->disable_ra = 1;
+	ra->disable_pt = 1;
 
-	if (p_ra_t->record_ra_info)
-		p_ra_t->record_ra_info(p_dm, macid, p_sta, 0);
+	if (ra_t->record_ra_info)
+		ra_t->record_ra_info(dm, sta->mac_id, sta, 0);
 
-	if (p_dm->support_ic_type != ODM_RTL8188E)
-		phydm_ra_h2c(p_dm, macid, p_ra->disable_ra, p_ra->disable_pt, 0, 0, 0);
+	if (dm->support_ic_type != ODM_RTL8188E)
+		phydm_ra_h2c(dm, sta->mac_id, 1, 1, 0, 0, 0);
 }
 
-void
-phydm_ra_mask_watchdog(
-	void	*p_dm_void
-)
+void phydm_ra_mask_watchdog(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_	*p_ra_t = &p_dm->dm_ra_table;
-	struct cmn_sta_info			*p_sta = NULL;
-	struct ra_sta_info				*p_ra = NULL;
-	u8		macid;
-	u64		ra_mask;
-	u8		rssi_lv_new;
-
-	if (!(p_dm->support_ability & ODM_BB_RA_MASK))
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info *sta = NULL;
+	struct ra_sta_info *ra = NULL;
+	u8 sta_idx;
+	u64 ra_mask;
+	u8 rssi_lv_new;
+	u8 rssi = 0;
+
+	if (!(dm->support_ability & ODM_BB_RA_MASK))
 		return;
-	
-	if (((!p_dm->is_linked)) || (p_dm->phydm_sys_up_time % 2) == 1)
+
+	if (!dm->is_linked || (dm->phydm_sys_up_time % 2) == 1)
 		return;
 
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("%s ======>\n", __func__));
-	
-	p_ra_t->up_ramask_cnt++;
+	PHYDM_DBG(dm, DBG_RA_MASK, "%s ======>\n", __func__);
 
-	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
-		
-		p_sta = p_dm->p_phydm_sta_info[macid];
-		
-		if (!is_sta_active(p_sta))
+	ra_t->up_ramask_cnt++;
+
+	for (sta_idx = 0; sta_idx < ODM_ASSOCIATE_ENTRY_NUM; sta_idx++) {
+		sta = dm->phydm_sta_info[sta_idx];
+
+		if (!is_sta_active(sta))
 			continue;
 
-		p_ra = &(p_sta->ra_info);
+		ra = &sta->ra_info;
 
-		if (p_ra->disable_ra)
+		if (ra->disable_ra)
 			continue;
 
+		PHYDM_DBG(dm, DBG_RA_MASK, "sta_idx=%d, macid=%d\n", sta_idx,
+			  sta->mac_id);
+
+		rssi = (u8)(sta->rssi_stat.rssi);
 
-		/*to be modified*/
+		/*@to be modified*/
 		#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-		if ((p_dm->support_ic_type == ODM_RTL8812) ||
-			((p_dm->support_ic_type == ODM_RTL8821) && (p_dm->cut_version == ODM_CUT_A))
+		if (dm->support_ic_type == ODM_RTL8812 ||
+			(dm->support_ic_type == ODM_RTL8821 &&
+			 dm->cut_version == ODM_CUT_A)
 			) {
-			
-			if (p_sta->rssi_stat.rssi < p_ra_t->ldpc_thres) {
-				
+			if (rssi < ra_t->ldpc_thres) {
+				/*@LDPC TX enable*/
 				#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-				set_ra_ldpc_8812(p_sta, true);		/*LDPC TX enable*/
+				set_ra_ldpc_8812(sta, true);
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+				MgntSet_TX_LDPC(sta->mac_id, true);
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+				/*to be added*/
 				#endif
-				PHYDM_DBG(p_dm, DBG_RA_MASK, ("RSSI=%d, ldpc_en =TRUE\n", p_sta->rssi_stat.rssi));
-				
-			} else if (p_sta->rssi_stat.rssi > (p_ra_t->ldpc_thres + 3)) {
+				PHYDM_DBG(dm, DBG_RA_MASK,
+					  "RSSI=%d, ldpc_en =TRUE\n", rssi);
 
+			} else if (rssi > (ra_t->ldpc_thres + 3)) {
+				/*@LDPC TX disable*/
 				#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-				set_ra_ldpc_8812(p_sta, false);	/*LDPC TX disable*/
+				set_ra_ldpc_8812(sta, false);
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+				MgntSet_TX_LDPC(sta->mac_id, false);
+				#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
+				/*to be added*/
 				#endif
-				PHYDM_DBG(p_dm, DBG_RA_MASK, ("RSSI=%d, ldpc_en =FALSE\n", p_sta->rssi_stat.rssi));
-			}	
+				PHYDM_DBG(dm, DBG_RA_MASK,
+					  "RSSI=%d, ldpc_en =FALSE\n", rssi);
+			}
 		}
 		#endif
 
-		rssi_lv_new = phydm_rssi_lv_dec(p_dm, (u32)p_sta->rssi_stat.rssi, p_ra->rssi_level);
+		rssi_lv_new = phydm_rssi_lv_dec(dm, (u32)rssi, ra->rssi_level);
 
-		if ((p_ra->rssi_level != rssi_lv_new) || 
-			(p_ra_t->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD)) {
+		if (ra->rssi_level != rssi_lv_new ||
+		    ra_t->up_ramask_cnt >= FORCED_UPDATE_RAMASK_PERIOD) {
+			PHYDM_DBG(dm, DBG_RA_MASK, "RSSI LV:((%d))->((%d))\n",
+				  ra->rssi_level, rssi_lv_new);
 
-			PHYDM_DBG(p_dm, DBG_RA_MASK, ("RSSI LV:((%d))->((%d))\n", p_ra->rssi_level, rssi_lv_new));
-			
-			p_ra->rssi_level = rssi_lv_new;
-			p_ra_t->up_ramask_cnt = 0;
-			
-			ra_mask = phydm_get_bb_mod_ra_mask(p_dm, macid);
+			ra->rssi_level = rssi_lv_new;
+			ra_t->up_ramask_cnt = 0;
 
-			if (p_ra_t->record_ra_info)
-				p_ra_t->record_ra_info(p_dm, macid, p_sta, ra_mask);
+			ra_mask = phydm_get_bb_mod_ra_mask(dm, sta_idx);
 
-			#if (RTL8188E_SUPPORT == 1) && (RATE_ADAPTIVE_SUPPORT == 1)
-			if (p_dm->support_ic_type == ODM_RTL8188E)
-				/*Driver RA*/
-				odm_ra_update_rate_info_8188e(p_dm, macid, p_ra->rate_id, (u32)ra_mask, p_ra->is_support_sgi);
+			if (ra_t->record_ra_info)
+				ra_t->record_ra_info(dm, sta_idx, sta, ra_mask);
+
+			#if (RTL8188E_SUPPORT) && (RATE_ADAPTIVE_SUPPORT)
+			if (dm->support_ic_type == ODM_RTL8188E)
+				/*@Driver RA*/
+				phydm_ra_update_8188e(dm, sta_idx, ra->rate_id,
+						      (u32)ra_mask,
+						      ra->is_support_sgi);
 			else
 			#endif
 			{
-				/*FW RA*/
-				phydm_ra_h2c(p_dm, macid, p_ra->disable_ra, p_ra->disable_pt, 1, 0, ra_mask);
+				/*@FW RA*/
+				phydm_ra_h2c(dm, sta_idx, ra->disable_ra,
+					     ra->disable_pt, 1, 0, ra_mask);
 			}
 		}
 	}
-
 }
-#endif
 
-u8
-phydm_vht_en_mapping(
-	void			*p_dm_void,
-	u32			wireless_mode
-)
+u8 phydm_vht_en_mapping(void *dm_void, u32 wireless_mode)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			vht_en_out = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 vht_en_out = 0;
 
-	if ((wireless_mode == PHYDM_WIRELESS_MODE_AC_5G) ||
-	    (wireless_mode == PHYDM_WIRELESS_MODE_AC_24G) ||
-	    (wireless_mode == PHYDM_WIRELESS_MODE_AC_ONLY)
-	   ) {
+	if (wireless_mode == PHYDM_WIRELESS_MODE_AC_5G ||
+	    wireless_mode == PHYDM_WIRELESS_MODE_AC_24G ||
+	    wireless_mode == PHYDM_WIRELESS_MODE_AC_ONLY)
 		vht_en_out = 1;
-		/**/
-	}
 
-	PHYDM_DBG(p_dm, DBG_RA, ("wireless_mode= (( 0x%x )), VHT_EN= (( %d ))\n", wireless_mode, vht_en_out));
+	PHYDM_DBG(dm, DBG_RA, "wireless_mode= (( 0x%x )), VHT_EN= (( %d ))\n",
+		  wireless_mode, vht_en_out);
 	return vht_en_out;
 }
 
-u8
-phydm_rate_id_mapping(
-	void			*p_dm_void,
-	u32			wireless_mode,
-	u8			rf_type,
-	u8			bw
-)
+u8 phydm_rftype2rateid_2g_n20(void *dm_void, u8 rf_type)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			rate_id_idx = 0;
-
-	PHYDM_DBG(p_dm, DBG_RA, ("wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x ))\n",
-			wireless_mode, rf_type, bw));
-
+	u8 rate_id_idx = 0;
+
+	if (rf_type == RF_1T1R)
+		rate_id_idx = PHYDM_BGN_20M_1SS;
+	else if (rf_type == RF_2T2R)
+		rate_id_idx = PHYDM_BGN_20M_2SS;
+	else if (rf_type == RF_3T3R)
+		rate_id_idx = PHYDM_ARFR5_N_3SS;
+	else
+		rate_id_idx = PHYDM_ARFR7_N_4SS;
+	return rate_id_idx;
+}
 
-	switch (wireless_mode) {
+u8 phydm_rftype2rateid_2g_n40(void *dm_void, u8 rf_type)
+{
+	u8 rate_id_idx = 0;
+
+	if (rf_type == RF_1T1R)
+		rate_id_idx = PHYDM_BGN_40M_1SS;
+	else if (rf_type == RF_2T2R)
+		rate_id_idx = PHYDM_BGN_40M_2SS;
+	else if (rf_type == RF_3T3R)
+		rate_id_idx = PHYDM_ARFR5_N_3SS;
+	else
+		rate_id_idx = PHYDM_ARFR7_N_4SS;
+	return rate_id_idx;
+}
 
-	case PHYDM_WIRELESS_MODE_N_24G:
-	{
+u8 phydm_rftype2rateid_5g_n(void *dm_void, u8 rf_type)
+{
+	u8 rate_id_idx = 0;
+
+	if (rf_type == RF_1T1R)
+		rate_id_idx = PHYDM_GN_N1SS;
+	else if (rf_type == RF_2T2R)
+		rate_id_idx = PHYDM_GN_N2SS;
+	else if (rf_type == RF_3T3R)
+		rate_id_idx = PHYDM_ARFR5_N_3SS;
+	else
+		rate_id_idx = PHYDM_ARFR7_N_4SS;
+	return rate_id_idx;
+}
 
-		if (bw == CHANNEL_WIDTH_40) {
+u8 phydm_rftype2rateid_ac80(void *dm_void, u8 rf_type)
+{
+	u8 rate_id_idx = 0;
+
+	if (rf_type == RF_1T1R)
+		rate_id_idx = PHYDM_ARFR1_AC_1SS;
+	else if (rf_type == RF_2T2R)
+		rate_id_idx = PHYDM_ARFR0_AC_2SS;
+	else if (rf_type == RF_3T3R)
+		rate_id_idx = PHYDM_ARFR4_AC_3SS;
+	else
+		rate_id_idx = PHYDM_ARFR6_AC_4SS;
+	return rate_id_idx;
+}
 
-			if (rf_type == RF_1T1R)
-				rate_id_idx = PHYDM_BGN_40M_1SS;
-			else if (rf_type == RF_2T2R)
-				rate_id_idx = PHYDM_BGN_40M_2SS;
-			else
-				rate_id_idx = PHYDM_ARFR5_N_3SS;
+u8 phydm_rftype2rateid_ac40(void *dm_void, u8 rf_type)
+{
+	u8 rate_id_idx = 0;
+
+	if (rf_type == RF_1T1R)
+		rate_id_idx = PHYDM_ARFR2_AC_2G_1SS;
+	else if (rf_type == RF_2T2R)
+		rate_id_idx = PHYDM_ARFR3_AC_2G_2SS;
+	else if (rf_type == RF_3T3R)
+		rate_id_idx = PHYDM_ARFR4_AC_3SS;
+	else
+		rate_id_idx = PHYDM_ARFR6_AC_4SS;
+	return rate_id_idx;
+}
 
-		} else {
+u8 phydm_rate_id_mapping(void *dm_void, u32 wireless_mode, u8 rf_type, u8 bw)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rate_id_idx = 0;
 
-			if (rf_type == RF_1T1R)
-				rate_id_idx = PHYDM_BGN_20M_1SS;
-			else if (rf_type == RF_2T2R)
-				rate_id_idx = PHYDM_BGN_20M_2SS;
-			else
-				rate_id_idx = PHYDM_ARFR5_N_3SS;
-		}
-	}
-	break;
+	PHYDM_DBG(dm, DBG_RA,
+		  "wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x ))\n",
+		  wireless_mode, rf_type, bw);
 
-	case PHYDM_WIRELESS_MODE_N_5G:
-	{
-		if (rf_type == RF_1T1R)
-			rate_id_idx = PHYDM_GN_N1SS;
-		else if (rf_type == RF_2T2R)
-			rate_id_idx = PHYDM_GN_N2SS;
+	switch (wireless_mode) {
+	case PHYDM_WIRELESS_MODE_N_24G:
+		if (bw == CHANNEL_WIDTH_40)
+			rate_id_idx = phydm_rftype2rateid_2g_n40(dm, rf_type);
 		else
-			rate_id_idx = PHYDM_ARFR5_N_3SS;
-	}
+			rate_id_idx = phydm_rftype2rateid_2g_n20(dm, rf_type);
+		break;
 
-	break;
+	case PHYDM_WIRELESS_MODE_N_5G:
+		rate_id_idx = phydm_rftype2rateid_5g_n(dm, rf_type);
+		break;
 
 	case PHYDM_WIRELESS_MODE_G:
 		rate_id_idx = PHYDM_BG;
@@ -1344,376 +1488,254 @@ phydm_rate_id_mapping(
 		rate_id_idx = PHYDM_B_20M;
 		break;
 
-
 	case PHYDM_WIRELESS_MODE_AC_5G:
 	case PHYDM_WIRELESS_MODE_AC_ONLY:
-	{
-		if (rf_type == RF_1T1R)
-			rate_id_idx = PHYDM_ARFR1_AC_1SS;
-		else if (rf_type == RF_2T2R)
-			rate_id_idx = PHYDM_ARFR0_AC_2SS;
-		else
-			rate_id_idx = PHYDM_ARFR4_AC_3SS;
-	}
-	break;
+		rate_id_idx = phydm_rftype2rateid_ac80(dm, rf_type);
+		break;
 
 	case PHYDM_WIRELESS_MODE_AC_24G:
-	{
-		/*Becareful to set "Lowest rate" while using PHYDM_ARFR4_AC_3SS in 2.4G/5G*/
-		if (bw >= CHANNEL_WIDTH_80) {
-			if (rf_type == RF_1T1R)
-				rate_id_idx = PHYDM_ARFR1_AC_1SS;
-			else if (rf_type == RF_2T2R)
-				rate_id_idx = PHYDM_ARFR0_AC_2SS;
-			else
-				rate_id_idx = PHYDM_ARFR4_AC_3SS;
-		} else {
-
-			if (rf_type == RF_1T1R)
-				rate_id_idx = PHYDM_ARFR2_AC_2G_1SS;
-			else if (rf_type == RF_2T2R)
-				rate_id_idx = PHYDM_ARFR3_AC_2G_2SS;
-			else
-				rate_id_idx = PHYDM_ARFR4_AC_3SS;
-		}
-	}
-	break;
+/*@Becareful to set "Lowest rate" while using PHYDM_ARFR4_AC_3SS in 2.4G/5G*/
+		if (bw >= CHANNEL_WIDTH_80)
+			rate_id_idx = phydm_rftype2rateid_ac80(dm, rf_type);
+		else
+			rate_id_idx = phydm_rftype2rateid_ac40(dm, rf_type);
+		break;
 
 	default:
 		rate_id_idx = 0;
 		break;
 	}
 
-	PHYDM_DBG(p_dm, DBG_RA, ("RA rate ID = (( 0x%x ))\n", rate_id_idx));
+	PHYDM_DBG(dm, DBG_RA, "RA rate ID = (( 0x%x ))\n", rate_id_idx);
 
 	return rate_id_idx;
 }
 
-void
-phydm_update_hal_ra_mask(
-	void			*p_dm_void,
-	u32			wireless_mode,
-	u8			rf_type,
-	u8			bw,
-	u8			mimo_ps_enable,
-	u8			disable_cck_rate,
-	u32			*ratr_bitmap_msb_in,
-	u32			*ratr_bitmap_lsb_in,
-	u8			tx_rate_level
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32			ratr_bitmap = *ratr_bitmap_lsb_in, ratr_bitmap_msb = *ratr_bitmap_msb_in;
-
-	/*PHYDM_DBG(p_dm, DBG_RA_MASK, ("phydm_rf_type = (( %x )), rf_type = (( %x ))\n", phydm_rf_type, rf_type));*/
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("Platfoem original RA Mask = (( 0x %x | %x ))\n", ratr_bitmap_msb, ratr_bitmap));
-
-	switch (wireless_mode) {
-
-	case PHYDM_WIRELESS_MODE_B:
-	{
-		ratr_bitmap &= 0x0000000f;
-	}
-	break;
-
-	case PHYDM_WIRELESS_MODE_G:
-	{
-		ratr_bitmap &= 0x00000ff5;
-	}
-	break;
-
-	case PHYDM_WIRELESS_MODE_A:
-	{
-		ratr_bitmap &= 0x00000ff0;
-	}
-	break;
-
-	case PHYDM_WIRELESS_MODE_N_24G:
-	case PHYDM_WIRELESS_MODE_N_5G:
-	{
-		if (mimo_ps_enable)
-			rf_type = RF_1T1R;
-
-		if (rf_type == RF_1T1R) {
-
-			if (bw == CHANNEL_WIDTH_40)
-				ratr_bitmap &= 0x000ff015;
-			else
-				ratr_bitmap &= 0x000ff005;
-		} else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R) {
-
-			if (bw == CHANNEL_WIDTH_40)
-				ratr_bitmap &= 0x0ffff015;
-			else
-				ratr_bitmap &= 0x0ffff005;
-		} else { /*3T*/
-
-			ratr_bitmap &= 0xfffff015;
-			ratr_bitmap_msb &= 0xf;
-		}
-	}
-	break;
-
-	case PHYDM_WIRELESS_MODE_AC_24G:
-	{
-		if (rf_type == RF_1T1R)
-			ratr_bitmap &= 0x003ff015;
-		else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R)
-			ratr_bitmap &= 0xfffff015;
-		else {/*3T*/
-
-			ratr_bitmap &= 0xfffff010;
-			ratr_bitmap_msb &= 0x3ff;
-		}
-
-		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
-			ratr_bitmap &= 0x7fdfffff;
-			ratr_bitmap_msb &= 0x1ff;
-		}
-	}
-	break;
-
-	case PHYDM_WIRELESS_MODE_AC_5G:
-	{
-		if (rf_type == RF_1T1R)
-			ratr_bitmap &= 0x003ff010;
-		else if (rf_type == RF_2T2R || rf_type == RF_2T4R || rf_type == RF_2T3R)
-			ratr_bitmap &= 0xfffff010;
-		else {/*3T*/
-
-			ratr_bitmap &= 0xfffff010;
-			ratr_bitmap_msb &= 0x3ff;
-		}
-
-		if (bw == CHANNEL_WIDTH_20) {/* AC 20MHz doesn't support MCS9 */
-			ratr_bitmap &= 0x7fdfffff;
-			ratr_bitmap_msb &= 0x1ff;
-		}
-	}
-	break;
-
-	default:
-		break;
-	}
-
-	if (wireless_mode != PHYDM_WIRELESS_MODE_B) {
-
-		if (tx_rate_level == 0)
-			ratr_bitmap &=  0xffffffff;
-		else if (tx_rate_level == 1)
-			ratr_bitmap &=  0xfffffff0;
-		else if (tx_rate_level == 2)
-			ratr_bitmap &=  0xffffefe0;
-		else if (tx_rate_level == 3)
-			ratr_bitmap &=  0xffffcfc0;
-		else if (tx_rate_level == 4)
-			ratr_bitmap &=  0xffff8f80;
-		else if (tx_rate_level >= 5)
-			ratr_bitmap &=  0xffff0f00;
-
-	}
-
-	if (disable_cck_rate)
-		ratr_bitmap &= 0xfffffff0;
-
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("wireless_mode= (( 0x%x )), rf_type = (( 0x%x )), BW = (( 0x%x )), MimoPs_en = (( %d )), tx_rate_level= (( 0x%x ))\n",
-		wireless_mode, rf_type, bw, mimo_ps_enable, tx_rate_level));
-
-	/*PHYDM_DBG(p_dm, DBG_RA_MASK, ("111 Phydm modified RA Mask = (( 0x %x | %x ))\n", ratr_bitmap_msb, ratr_bitmap));*/
-
-	*ratr_bitmap_lsb_in = ratr_bitmap;
-	*ratr_bitmap_msb_in = ratr_bitmap_msb;
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("Phydm modified RA Mask = (( 0x %x | %x ))\n", *ratr_bitmap_msb_in, *ratr_bitmap_lsb_in));
-
-}
-
-u8
-phydm_rssi_lv_dec(
-	void			*p_dm_void,
-	u32			rssi,
-	u8			ratr_state
-)
+u8 phydm_rssi_lv_dec(void *dm_void, u32 rssi, u8 ratr_state)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	rssi_lv_table[RA_FLOOR_TABLE_SIZE] = {20, 34, 38, 42, 46, 50, 100}; /*MCS0 ~ MCS4 , VHT1SS MCS0 ~ MCS4 , G 6M~24M*/
-	u8	new_rssi_lv = 0;
-	u8	i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	/*@MCS0 ~ MCS4 , VHT1SS MCS0 ~ MCS4 , G 6M~24M*/
+	u8 rssi_lv_t[RA_FLOOR_TABLE_SIZE] = {20, 34, 38, 42, 46, 50, 100};
+	u8 new_rssi_lv = 0;
+	u8 i;
 
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("curr RA level=(%d), Table_ori=[%d, %d, %d, %d, %d, %d]\n",
-		ratr_state, rssi_lv_table[0], rssi_lv_table[1], rssi_lv_table[2], rssi_lv_table[3], rssi_lv_table[4], rssi_lv_table[5]));
+	PHYDM_DBG(dm, DBG_RA_MASK,
+		  "curr RA level=(%d), Table_ori=[%d, %d, %d, %d, %d, %d]\n",
+		  ratr_state, rssi_lv_t[0], rssi_lv_t[1], rssi_lv_t[2],
+		  rssi_lv_t[3], rssi_lv_t[4], rssi_lv_t[5]);
 
 	for (i = 0; i < RA_FLOOR_TABLE_SIZE; i++) {
-
 		if (i >= (ratr_state))
-			rssi_lv_table[i] += RA_FLOOR_UP_GAP;
+			rssi_lv_t[i] += RA_FLOOR_UP_GAP;
 	}
 
-	PHYDM_DBG(p_dm, DBG_RA_MASK, ("RSSI=(%d), Table_mod=[%d, %d, %d, %d, %d, %d]\n",
-		rssi, rssi_lv_table[0], rssi_lv_table[1], rssi_lv_table[2], rssi_lv_table[3], rssi_lv_table[4], rssi_lv_table[5]));
+	PHYDM_DBG(dm, DBG_RA_MASK,
+		  "RSSI=(%d), Table_mod=[%d, %d, %d, %d, %d, %d]\n", rssi,
+		  rssi_lv_t[0], rssi_lv_t[1], rssi_lv_t[2], rssi_lv_t[3],
+		  rssi_lv_t[4], rssi_lv_t[5]);
 
 	for (i = 0; i < RA_FLOOR_TABLE_SIZE; i++) {
-
-		if (rssi < rssi_lv_table[i]) {
+		if (rssi < rssi_lv_t[i]) {
 			new_rssi_lv = i;
 			break;
 		}
 	}
-	return	new_rssi_lv;
+	return new_rssi_lv;
 }
 
-u8
-phydm_rate_order_compute(
-	void	*p_dm_void,
-	u8	rate_idx
-)
+u8 phydm_rate_order_compute(void *dm_void, u8 rate_idx)
 {
-	u8		rate_order = 0;
-
-	if (rate_idx >= ODM_RATEVHTSS4MCS0) {
+	u8 rate_order = 0;
 
+	if (rate_idx >= ODM_RATEVHTSS4MCS0)
 		rate_idx -= ODM_RATEVHTSS4MCS0;
-		/**/
-	} else if (rate_idx >= ODM_RATEVHTSS3MCS0) {
-
+	else if (rate_idx >= ODM_RATEVHTSS3MCS0)
 		rate_idx -= ODM_RATEVHTSS3MCS0;
-		/**/
-	} else if (rate_idx >= ODM_RATEVHTSS2MCS0) {
-
+	else if (rate_idx >= ODM_RATEVHTSS2MCS0)
 		rate_idx -= ODM_RATEVHTSS2MCS0;
-		/**/
-	} else if (rate_idx >= ODM_RATEVHTSS1MCS0) {
-
+	else if (rate_idx >= ODM_RATEVHTSS1MCS0)
 		rate_idx -= ODM_RATEVHTSS1MCS0;
-		/**/
-	} else if (rate_idx >= ODM_RATEMCS24) {
-
+	else if (rate_idx >= ODM_RATEMCS24)
 		rate_idx -= ODM_RATEMCS24;
-		/**/
-	} else if (rate_idx >= ODM_RATEMCS16) {
-
+	else if (rate_idx >= ODM_RATEMCS16)
 		rate_idx -= ODM_RATEMCS16;
-		/**/
-	} else if (rate_idx >= ODM_RATEMCS8) {
-
+	else if (rate_idx >= ODM_RATEMCS8)
 		rate_idx -= ODM_RATEMCS8;
-		/**/
-	}
 	rate_order = rate_idx;
 
 	return rate_order;
+}
 
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+u8 phydm_rate2ss(void *dm_void, u8 rate_idx)
+{
+	u8 ret = 0xff;
+	u8 i, j;
+	u8 search_idx;
+	u32 ss_mapping_tab[4][3] = {{0x00000000, 0x003ff000, 0x000ff000},
+				    {0x00000000, 0xffc00000, 0x0ff00000},
+				    {0x000003ff, 0x0000000f, 0xf0000000},
+				    {0x000ffc00, 0x00000ff0, 0x00000000} };
+	if (rate_idx < 32) {
+		search_idx = rate_idx;
+		j = 0;
+	} else if (rate_idx < 64) {
+		search_idx = rate_idx - 32;
+		j = 1;
+	} else {
+		search_idx = rate_idx - 64;
+		j = 2;
+	}
+	for (i = 0; i < 4; i++)
+		if (ss_mapping_tab[i][j] & BIT(search_idx))
+			ret = i;
+	return ret;
 }
 
-void
-phydm_ra_common_info_update(
-	void	*p_dm_void
-)
+u8 phydm_rate2plcp(void *dm_void, u8 rate_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_		*p_ra_table = &p_dm->dm_ra_table;
-	struct cmn_sta_info			*p_sta = NULL;
-	u16		macid;
-	u8		rate_order_tmp;
-	u8		cnt = 0;
-
-	p_ra_table->highest_client_tx_order = 0;
-	p_ra_table->power_tracking_flag = 1;
-
-	if (p_dm->number_linked_client != 0) {
-		for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
-
-			p_sta = p_dm->p_phydm_sta_info[macid];
-			
-			if (is_sta_active(p_sta)) {
-			
-				rate_order_tmp = phydm_rate_order_compute(p_dm, (p_sta->ra_info.curr_tx_rate & 0x7f));
-
-				if (rate_order_tmp >= (p_ra_table->highest_client_tx_order)) {
-					p_ra_table->highest_client_tx_order = rate_order_tmp;
-					p_ra_table->highest_client_tx_rate_order = macid;
-				}
+	u8 rate2ss = 0;
+	u8 ltftime = 0;
+	u8 plcptime = 0xff;
+
+	if (rate_idx < ODM_RATE6M) {
+		plcptime = 192;
+		/* @CCK PLCP = 192us (long preamble) */
+	} else if (rate_idx < ODM_RATEMCS0) {
+		plcptime = 20;
+		/* @LegOFDM PLCP = 20us */
+	} else {
+		if (rate_idx < ODM_RATEVHTSS1MCS0)
+			plcptime = 32;
+		/* @HT mode PLCP = 20us + 12us + 4us x Nss */
+		else
+			plcptime = 36;
+		/* VHT mode PLCP = 20us + 16us + 4us x Nss */
+		rate2ss = phydm_rate2ss(dm_void, rate_idx);
+		if (rate2ss != 0xff)
+			ltftime = (rate2ss + 1) * 4;
+		else
+			return 0xff;
+
+		plcptime += ltftime;
+	}
+	return plcptime;
+}
 
-				cnt++;
+u8 phydm_get_plcp(void *dm_void, u16 macid)
+{
+	u8 plcp_time = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta = NULL;
+	struct ra_sta_info *ra = NULL;
+
+	sta = dm->phydm_sta_info[macid];
+	ra = &sta->ra_info;
+	plcp_time = phydm_rate2plcp(dm, ra->curr_tx_rate);
+	return plcp_time;
+}
+#endif
 
-				if (cnt == p_dm->number_linked_client)
-					break;
-			}
+void phydm_ra_common_info_update(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
+	struct cmn_sta_info *sta = NULL;
+	u16 macid;
+	u8 rate_order_tmp;
+	u8 rate_idx = 0;
+	u8 cnt = 0;
+
+	ra_tab->highest_client_tx_order = 0;
+	ra_tab->power_tracking_flag = 1;
+
+	if (!dm->number_linked_client)
+		return;
+
+	for (macid = 0; macid < ODM_ASSOCIATE_ENTRY_NUM; macid++) {
+		sta = dm->phydm_sta_info[macid];
+
+		if (!is_sta_active(sta))
+			continue;
+
+		rate_idx = sta->ra_info.curr_tx_rate & 0x7f;
+		rate_order_tmp = phydm_rate_order_compute(dm, rate_idx);
+
+		if (rate_order_tmp >= ra_tab->highest_client_tx_order) {
+			ra_tab->highest_client_tx_order = rate_order_tmp;
+			ra_tab->highest_client_tx_rate_order = macid;
 		}
-		PHYDM_DBG(p_dm, DBG_RA, ("MACID[%d], Highest Tx order Update for power traking: %d\n", (p_ra_table->highest_client_tx_rate_order), (p_ra_table->highest_client_tx_order)));
+
+		cnt++;
+
+		if (cnt == dm->number_linked_client)
+			break;
 	}
+	PHYDM_DBG(dm, DBG_RA,
+		  "MACID[%d], Highest Tx order Update for power traking: %d\n",
+		  ra_tab->highest_client_tx_rate_order,
+		  ra_tab->highest_client_tx_order);
 }
 
-void
-phydm_ra_info_watchdog(
-	void	*p_dm_void
-)
+void phydm_ra_info_watchdog(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	phydm_ra_common_info_update(p_dm);
-	#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
-	phydm_ra_dynamic_retry_limit(p_dm);
-	#endif
-	phydm_ra_dynamic_retry_count(p_dm);
-	phydm_refresh_rate_adaptive_mask(p_dm);
+	phydm_ra_common_info_update(dm);
+	phydm_ra_dynamic_retry_count(dm);
+	phydm_ra_mask_watchdog(dm);
 
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	odm_refresh_basic_rate_mask(p_dm);
-	#endif
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+	odm_refresh_basic_rate_mask(dm);
+#endif
 }
 
-void
-phydm_ra_info_init(
-	void	*p_dm_void
-)
+void phydm_ra_info_init(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_		*p_ra_table = &p_dm->dm_ra_table;
-
-	p_ra_table->highest_client_tx_rate_order = 0;
-	p_ra_table->highest_client_tx_order = 0;
-	p_ra_table->RA_threshold_offset = 0;
-	p_ra_table->RA_offset_direction = 0;
-	
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
+
+	ra_tab->highest_client_tx_rate_order = 0;
+	ra_tab->highest_client_tx_order = 0;
+	ra_tab->ra_th_ofst = 0;
+	ra_tab->ra_ofst_direc = 0;
+
 #if (RTL8822B_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8822B) {
-		u32	ret_value;
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		u32 ret_value;
 
-		ret_value = odm_get_bb_reg(p_dm, 0x4c8, MASKBYTE2);
-		odm_set_bb_reg(p_dm, 0x4cc, MASKBYTE3, (ret_value - 1));
+		ret_value = odm_get_bb_reg(dm, R_0x4c8, MASKBYTE2);
+		odm_set_bb_reg(dm, R_0x4cc, MASKBYTE3, (ret_value - 1));
 	}
 #endif
-	
-	#ifdef CONFIG_RA_DYNAMIC_RTY_LIMIT
-	phydm_ra_dynamic_retry_limit_init(p_dm);
-	#endif
 
-	#ifdef CONFIG_RA_DYNAMIC_RATE_ID
-	phydm_ra_dynamic_rate_id_init(p_dm);
+	#if 0 /*@CONFIG_RA_DYNAMIC_RTY_LIMIT*/
+	phydm_ra_dynamic_retry_limit_init(dm);
 	#endif
 
-	#ifdef CONFIG_RA_DBG_CMD
-	odm_ra_para_adjust_init(p_dm);
+	#if 0 /*@CONFIG_RA_DYNAMIC_RATE_ID*/
+	phydm_ra_dynamic_rate_id_init(dm);
 	#endif
 
-	phydm_rate_adaptive_mask_init(p_dm);
-	
+	phydm_rate_adaptive_mask_init(dm);
 }
 
-u8
-odm_find_rts_rate(
-	void			*p_dm_void,
-	u8			tx_rate,
-	boolean		is_erp_protect
-)
+u8 odm_find_rts_rate(void *dm_void, u8 tx_rate, boolean is_erp_protect)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	rts_ini_rate = ODM_RATE6M;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 rts_ini_rate = ODM_RATE6M;
 
-	if (is_erp_protect) /* use CCK rate as RTS*/
+	if (is_erp_protect) { /* use CCK rate as RTS*/
 		rts_ini_rate = ODM_RATE1M;
-	else {
+	} else {
 		switch (tx_rate) {
+		case ODM_RATEVHTSS4MCS9:
+		case ODM_RATEVHTSS4MCS8:
+		case ODM_RATEVHTSS4MCS7:
+		case ODM_RATEVHTSS4MCS6:
+		case ODM_RATEVHTSS4MCS5:
+		case ODM_RATEVHTSS4MCS4:
+		case ODM_RATEVHTSS4MCS3:
 		case ODM_RATEVHTSS3MCS9:
 		case ODM_RATEVHTSS3MCS8:
 		case ODM_RATEVHTSS3MCS7:
@@ -1735,6 +1757,16 @@ odm_find_rts_rate(
 		case ODM_RATEVHTSS1MCS5:
 		case ODM_RATEVHTSS1MCS4:
 		case ODM_RATEVHTSS1MCS3:
+		case ODM_RATEMCS31:
+		case ODM_RATEMCS30:
+		case ODM_RATEMCS29:
+		case ODM_RATEMCS28:
+		case ODM_RATEMCS27:
+		case ODM_RATEMCS23:
+		case ODM_RATEMCS22:
+		case ODM_RATEMCS21:
+		case ODM_RATEMCS20:
+		case ODM_RATEMCS19:
 		case ODM_RATEMCS15:
 		case ODM_RATEMCS14:
 		case ODM_RATEMCS13:
@@ -1751,12 +1783,18 @@ odm_find_rts_rate(
 		case ODM_RATE24M:
 			rts_ini_rate = ODM_RATE24M;
 			break;
+		case ODM_RATEVHTSS4MCS2:
+		case ODM_RATEVHTSS4MCS1:
 		case ODM_RATEVHTSS3MCS2:
 		case ODM_RATEVHTSS3MCS1:
 		case ODM_RATEVHTSS2MCS2:
 		case ODM_RATEVHTSS2MCS1:
 		case ODM_RATEVHTSS1MCS2:
 		case ODM_RATEVHTSS1MCS1:
+		case ODM_RATEMCS26:
+		case ODM_RATEMCS25:
+		case ODM_RATEMCS18:
+		case ODM_RATEMCS17:
 		case ODM_RATEMCS10:
 		case ODM_RATEMCS9:
 		case ODM_RATEMCS2:
@@ -1765,9 +1803,12 @@ odm_find_rts_rate(
 		case ODM_RATE12M:
 			rts_ini_rate = ODM_RATE12M;
 			break;
+		case ODM_RATEVHTSS4MCS0:
 		case ODM_RATEVHTSS3MCS0:
 		case ODM_RATEVHTSS2MCS0:
 		case ODM_RATEVHTSS1MCS0:
+		case ODM_RATEMCS24:
+		case ODM_RATEMCS16:
 		case ODM_RATEMCS8:
 		case ODM_RATEMCS0:
 		case ODM_RATE9M:
@@ -1786,557 +1827,260 @@ odm_find_rts_rate(
 		}
 	}
 
-	if (*p_dm->p_band_type == ODM_BAND_5G) {
+	if (*dm->band_type == ODM_BAND_5G) {
 		if (rts_ini_rate < ODM_RATE6M)
 			rts_ini_rate = ODM_RATE6M;
 	}
 	return rts_ini_rate;
-
 }
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-void
-odm_refresh_basic_rate_mask(
-	void	*p_dm_void
-)
+void odm_refresh_basic_rate_mask(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER		*adapter	 =  p_dm->adapter;
-	static u8		stage = 0;
-	u8			cur_stage = 0;
-	OCTET_STRING	os_rate_set;
-	PMGNT_INFO		p_mgnt_info = GetDefaultMgntInfo(adapter);
-	u8			rate_set[5] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M, MGN_6M};
-
-	if (p_dm->support_ic_type != ODM_RTL8812 && p_dm->support_ic_type != ODM_RTL8821)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	static u8 stage = 0;
+	u8 cur_stage = 0;
+	OCTET_STRING os_rate_set;
+	PMGNT_INFO mgnt_info = GetDefaultMgntInfo(((PADAPTER)adapter));
+	u8 rate_set[5] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M, MGN_6M};
+
+	if (dm->support_ic_type != ODM_RTL8812 && dm->support_ic_type != ODM_RTL8821)
 		return;
 
-	if (p_dm->is_linked == false)	/* unlink Default port information */
+	if (dm->is_linked == false) /* unlink Default port information */
 		cur_stage = 0;
-	else if (p_dm->rssi_min < 40)	/* link RSSI  < 40% */
+	else if (dm->rssi_min < 40) /* @link RSSI  < 40% */
 		cur_stage = 1;
-	else if (p_dm->rssi_min > 45)	/* link RSSI > 45% */
+	else if (dm->rssi_min > 45) /* @link RSSI > 45% */
 		cur_stage = 3;
 	else
-		cur_stage = 2;					/* link  25% <= RSSI <= 30% */
+		cur_stage = 2; /* @link  25% <= RSSI <= 30% */
 
 	if (cur_stage != stage) {
 		if (cur_stage == 1) {
 			FillOctetString(os_rate_set, rate_set, 5);
-			FilterSupportRate(p_mgnt_info->mBrates, &os_rate_set, false);
-			phydm_set_hw_reg_handler_interface(p_dm, HW_VAR_BASIC_RATE, (u8 *)&os_rate_set);
+			FilterSupportRate(mgnt_info->mBrates, &os_rate_set, false);
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_BASIC_RATE, (u8 *)&os_rate_set);
 		} else if (cur_stage == 3 && (stage == 1 || stage == 2))
-			phydm_set_hw_reg_handler_interface(p_dm, HW_VAR_BASIC_RATE, (u8 *)(&p_mgnt_info->mBrates));
+			phydm_set_hw_reg_handler_interface(dm, HW_VAR_BASIC_RATE, (u8 *)(&mgnt_info->mBrates));
 	}
 
 	stage = cur_stage;
 }
 
-void
-odm_refresh_ldpc_rts_mp(
-	struct _ADAPTER			*p_adapter,
-	struct PHY_DM_STRUCT			*p_dm,
-	u8				m_mac_id,
-	u8				iot_peer,
-	s32				undecorated_smoothed_pwdb
-)
-{
-	boolean					is_ctl_ldpc = false;
-	struct _rate_adaptive_table_	*p_ra_t = &p_dm->dm_ra_table;
-
-	if (p_dm->support_ic_type != ODM_RTL8821 && p_dm->support_ic_type != ODM_RTL8812)
-		return;
-
-	if ((p_dm->support_ic_type == ODM_RTL8821) && (p_dm->cut_version == ODM_CUT_A))
-		is_ctl_ldpc = true;
-	else if (p_dm->support_ic_type == ODM_RTL8812 &&
-		 iot_peer == HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP)
-		is_ctl_ldpc = true;
-
-	if (is_ctl_ldpc) {
-		if (undecorated_smoothed_pwdb < (p_ra_t->ldpc_thres - 5))
-			MgntSet_TX_LDPC(p_adapter, m_mac_id, true);
-		else if (undecorated_smoothed_pwdb > p_ra_t->ldpc_thres)
-			MgntSet_TX_LDPC(p_adapter, m_mac_id, false);
-	}
-}
-
-void
-odm_rate_adaptive_state_ap_init(
-	void		*PADAPTER_VOID,
-	struct cmn_sta_info*p_entry
-)
-{
-	struct _ADAPTER		*adapter = (struct _ADAPTER *)PADAPTER_VOID;
-	p_entry->ra_info.rssi_level = DM_RATR_STA_INIT;
-}
-
-#elif (DM_ODM_SUPPORT_TYPE & ODM_AP)
-
-void
-phydm_gen_ramask_h2c_AP(
-	void			*p_dm_void,
-	struct rtl8192cd_priv *priv,
-	struct sta_info *p_entry,
-	u8			rssi_level
-)
-{
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (p_dm->support_ic_type == ODM_RTL8812) {
-
-		#if (RTL8812A_SUPPORT == 1)
-		UpdateHalRAMask8812(priv, p_entry, rssi_level);
-		/**/
-		#endif
-	} else if (p_dm->support_ic_type == ODM_RTL8188E) {
-
-		#if (RTL8188E_SUPPORT == 1)
-		#ifdef TXREPORT
-		add_RATid(priv, p_entry);
-		/**/
-		#endif
-		#endif
-	} else {
-		#ifdef CONFIG_WLAN_HAL
-		GET_HAL_INTERFACE(priv)->UpdateHalRAMaskHandler(priv, p_entry, rssi_level);
-		#endif
-	} 
-}
-
 #endif
 
-#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+#if 0 /*@CONFIG_RA_DYNAMIC_RTY_LIMIT*/
 
-void
-phydm_retry_limit_table_bound(
-	void	*p_dm_void,
-	u8	*retry_limit,
-	u8	offset
-)
+void phydm_retry_limit_table_bound(
+	void *dm_void,
+	u8 *retry_limit,
+	u8 offset)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_		*p_ra_table = &p_dm->dm_ra_table;
-
-	if (*retry_limit >  offset) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
 
+	if (*retry_limit > offset) {
 		*retry_limit -= offset;
 
-		if (*retry_limit < p_ra_table->retrylimit_low)
-			*retry_limit = p_ra_table->retrylimit_low;
-		else if (*retry_limit > p_ra_table->retrylimit_high)
-			*retry_limit = p_ra_table->retrylimit_high;
+		if (*retry_limit < ra_tab->retrylimit_low)
+			*retry_limit = ra_tab->retrylimit_low;
+		else if (*retry_limit > ra_tab->retrylimit_high)
+			*retry_limit = ra_tab->retrylimit_high;
 	} else
-		*retry_limit = p_ra_table->retrylimit_low;
+		*retry_limit = ra_tab->retrylimit_low;
 }
 
-void
-phydm_reset_retry_limit_table(
-	void	*p_dm_void
-)
+void phydm_reset_retry_limit_table(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_		*p_ra_table = &p_dm->dm_ra_table;
-	u8			i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_t = &dm->dm_ra_table;
+	u8 i;
 
 	u8 per_rate_retrylimit_table_20M[ODM_RATEMCS15 + 1] = {
-		1, 1, 2, 4,					/*CCK*/
-		2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
-		2, 4, 6, 8, 12, 18, 20, 22,		/*20M HT-1SS*/
-		2, 4, 6, 8, 12, 18, 20, 22		/*20M HT-2SS*/
+		1, 1, 2, 4, /*@CCK*/
+		2, 2, 4, 6, 8, 12, 16, 18, /*OFDM*/
+		2, 4, 6, 8, 12, 18, 20, 22, /*@20M HT-1SS*/
+		2, 4, 6, 8, 12, 18, 20, 22 /*@20M HT-2SS*/
 	};
 	u8 per_rate_retrylimit_table_40M[ODM_RATEMCS15 + 1] = {
-		1, 1, 2, 4,					/*CCK*/
-		2, 2, 4, 6, 8, 12, 16, 18,		/*OFDM*/
-		4, 8, 12, 16, 24, 32, 32, 32,		/*40M HT-1SS*/
-		4, 8, 12, 16, 24, 32, 32, 32		/*40M HT-2SS*/
+		1, 1, 2, 4, /*@CCK*/
+		2, 2, 4, 6, 8, 12, 16, 18, /*OFDM*/
+		4, 8, 12, 16, 24, 32, 32, 32, /*@40M HT-1SS*/
+		4, 8, 12, 16, 24, 32, 32, 32 /*@40M HT-2SS*/
 	};
 
-	memcpy(&(p_ra_table->per_rate_retrylimit_20M[0]), &(per_rate_retrylimit_table_20M[0]), ODM_NUM_RATE_IDX);
-	memcpy(&(p_ra_table->per_rate_retrylimit_40M[0]), &(per_rate_retrylimit_table_40M[0]), ODM_NUM_RATE_IDX);
+	memcpy(&ra_t->per_rate_retrylimit_20M[0],
+	       &per_rate_retrylimit_table_20M[0], ODM_NUM_RATE_IDX);
+	memcpy(&ra_t->per_rate_retrylimit_40M[0],
+	       &per_rate_retrylimit_table_40M[0], ODM_NUM_RATE_IDX);
 
 	for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
-		phydm_retry_limit_table_bound(p_dm, &(p_ra_table->per_rate_retrylimit_20M[i]), 0);
-		phydm_retry_limit_table_bound(p_dm, &(p_ra_table->per_rate_retrylimit_40M[i]), 0);
+		phydm_retry_limit_table_bound(dm,
+					      &ra_t->per_rate_retrylimit_20M[i],
+					      0);
+		phydm_retry_limit_table_bound(dm,
+					      &ra_t->per_rate_retrylimit_40M[i],
+					      0);
 	}
 }
 
-void
-phydm_ra_dynamic_retry_limit_init(
-	void	*p_dm_void
-)
+void phydm_ra_dynamic_retry_limit_init(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
 
-	p_ra_table->retry_descend_num = RA_RETRY_DESCEND_NUM;
-	p_ra_table->retrylimit_low = RA_RETRY_LIMIT_LOW;
-	p_ra_table->retrylimit_high = RA_RETRY_LIMIT_HIGH;
-
-	phydm_reset_retry_limit_table(p_dm);
+	ra_tab->retry_descend_num = RA_RETRY_DESCEND_NUM;
+	ra_tab->retrylimit_low = RA_RETRY_LIMIT_LOW;
+	ra_tab->retrylimit_high = RA_RETRY_LIMIT_HIGH;
 
+	phydm_reset_retry_limit_table(dm);
 }
 
-void
-phydm_ra_dynamic_retry_limit(
-	void	*p_dm_void
-)
+void phydm_ra_dynamic_retry_limit(
+	void *dm_void)
 {
-
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_		*p_ra_table = &p_dm->dm_ra_table;
-	u8	i, retry_offset;
-	u32	ma_rx_tp;
-
-
-	if (p_dm->pre_number_active_client == p_dm->number_active_client) {
-
-		PHYDM_DBG(p_dm, DBG_RA, (" pre_number_active_client ==  number_active_client\n"));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
+	u8 i, retry_offset;
+	u32 ma_rx_tp;
+
+	if (dm->pre_number_active_client == dm->number_active_client) {
+		PHYDM_DBG(dm, DBG_RA,
+			  "pre_number_active_client ==  number_active_client\n");
 		return;
 
 	} else {
-		if (p_dm->number_active_client == 1) {
-			phydm_reset_retry_limit_table(p_dm);
-			PHYDM_DBG(p_dm, DBG_RA, ("one client only->reset to default value\n"));
+		if (dm->number_active_client == 1) {
+			phydm_reset_retry_limit_table(dm);
+			PHYDM_DBG(dm, DBG_RA,
+				  "one client only->reset to default value\n");
 		} else {
-
-			retry_offset = p_dm->number_active_client * p_ra_table->retry_descend_num;
+			retry_offset = dm->number_active_client * ra_tab->retry_descend_num;
 
 			for (i = 0; i < ODM_NUM_RATE_IDX; i++) {
-
-				phydm_retry_limit_table_bound(p_dm, &(p_ra_table->per_rate_retrylimit_20M[i]), retry_offset);
-				phydm_retry_limit_table_bound(p_dm, &(p_ra_table->per_rate_retrylimit_40M[i]), retry_offset);
+				phydm_retry_limit_table_bound(dm,
+							      &ra_tab->per_rate_retrylimit_20M[i],
+							      retry_offset);
+				phydm_retry_limit_table_bound(dm,
+							      &ra_tab->per_rate_retrylimit_40M[i],
+							      retry_offset);
 			}
 		}
 	}
 }
 #endif
 
-#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))
-void
-phydm_ra_dynamic_rate_id_on_assoc(
-	void	*p_dm_void,
-	u8	wireless_mode,
-	u8	init_rate_id
-)
+#if 0 /*@CONFIG_RA_DYNAMIC_RATE_ID*/
+void phydm_ra_dynamic_rate_id_on_assoc(
+	void *dm_void,
+	u8 wireless_mode,
+	u8 init_rate_id)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	PHYDM_DBG(p_dm, DBG_RA, ("[ON ASSOC] rf_mode = ((0x%x)), wireless_mode = ((0x%x)), init_rate_id = ((0x%x))\n", p_dm->rf_type, wireless_mode, init_rate_id));
-
-	if ((p_dm->rf_type == RF_2T2R) || (p_dm->rf_type == RF_2T3R) || (p_dm->rf_type == RF_2T4R)) {
-
-		if ((p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) &&
-		    (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G))
-		   ) {
-			PHYDM_DBG(p_dm, DBG_RA, ("[ON ASSOC] set N-2SS ARFR5 table\n"));
-			odm_set_mac_reg(p_dm, 0x4a4, MASKDWORD, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
-			odm_set_mac_reg(p_dm, 0x4a8, MASKDWORD, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
-		} else if ((p_dm->support_ic_type & (ODM_RTL8812)) &&
-			(wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY))
-			  ) {
-			PHYDM_DBG(p_dm, DBG_RA, ("[ON ASSOC] set AC-2SS ARFR0 table\n"));
-			odm_set_mac_reg(p_dm, 0x444, MASKDWORD, 0x0fff);	/*AC-2SS, ARFR0, rate_id = 0x9*/
-			odm_set_mac_reg(p_dm, 0x448, MASKDWORD, 0xff01f000);		/*AC-2SS, ARFR0, rate_id = 0x9*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_RA,
+		  "[ON ASSOC] rf_mode = ((0x%x)), wireless_mode = ((0x%x)), init_rate_id = ((0x%x))\n",
+		  dm->rf_type, wireless_mode, init_rate_id);
+
+	if (dm->rf_type == RF_2T2R || dm->rf_type == RF_2T3R || dm->rf_type == RF_2T4R) {
+		if ((dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) &&
+		    (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G))) {
+			PHYDM_DBG(dm, DBG_RA,
+				  "[ON ASSOC] set N-2SS ARFR5 table\n");
+			odm_set_mac_reg(dm, R_0x4a4, MASKDWORD, 0xfc1ffff); /*N-2SS, ARFR5, rate_id = 0xe*/
+			odm_set_mac_reg(dm, R_0x4a8, MASKDWORD, 0x0); /*N-2SS, ARFR5, rate_id = 0xe*/
+		} else if ((dm->support_ic_type & (ODM_RTL8812)) &&
+			   (wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY))) {
+			PHYDM_DBG(dm, DBG_RA,
+				  "[ON ASSOC] set AC-2SS ARFR0 table\n");
+			odm_set_mac_reg(dm, R_0x444, MASKDWORD, 0x0fff); /*@AC-2SS, ARFR0, rate_id = 0x9*/
+			odm_set_mac_reg(dm, R_0x448, MASKDWORD, 0xff01f000); /*@AC-2SS, ARFR0, rate_id = 0x9*/
 		}
 	}
-
 }
 
-void
-phydm_ra_dynamic_rate_id_init(
-	void	*p_dm_void
-)
+void phydm_ra_dynamic_rate_id_init(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-		odm_set_mac_reg(p_dm, 0x4a4, MASKDWORD, 0xfc1ffff);	/*N-2SS, ARFR5, rate_id = 0xe*/
-		odm_set_mac_reg(p_dm, 0x4a8, MASKDWORD, 0x0);		/*N-2SS, ARFR5, rate_id = 0xe*/
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8192E)) {
+		odm_set_mac_reg(dm, R_0x4a4, MASKDWORD, 0xfc1ffff); /*N-2SS, ARFR5, rate_id = 0xe*/
+		odm_set_mac_reg(dm, R_0x4a8, MASKDWORD, 0x0); /*N-2SS, ARFR5, rate_id = 0xe*/
 
-		odm_set_mac_reg(p_dm, 0x444, MASKDWORD, 0x0fff);		/*AC-2SS, ARFR0, rate_id = 0x9*/
-		odm_set_mac_reg(p_dm, 0x448, MASKDWORD, 0xff01f000);	/*AC-2SS, ARFR0, rate_id = 0x9*/
+		odm_set_mac_reg(dm, R_0x444, MASKDWORD, 0x0fff); /*@AC-2SS, ARFR0, rate_id = 0x9*/
+		odm_set_mac_reg(dm, R_0x448, MASKDWORD, 0xff01f000); /*@AC-2SS, ARFR0, rate_id = 0x9*/
 	}
 }
 
-void
-phydm_update_rate_id(
-	void	*p_dm_void,
-	u8	rate,
-	u8	platform_macid
-)
+void phydm_update_rate_id(
+	void *dm_void,
+	u8 rate,
+	u8 platform_macid)
 {
 #if 0
 
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_		*p_ra_table = &p_dm->dm_ra_table;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct ra_table		*ra_tab = &dm->dm_ra_table;
 	u8		current_tx_ss;
 	u8		rate_idx = rate & 0x7f; /*remove bit7 SGI*/
-	u8		wireless_mode;
+	enum wireless_set wireless_set;
 	u8		phydm_macid;
-	struct sta_info	*p_entry;
-	struct cmn_sta_info	*p_sta;
-
+	struct cmn_sta_info	*sta;
 
-#if	0
+#if 0
 	if (rate_idx >= ODM_RATEVHTSS2MCS0) {
-		PHYDM_DBG(p_dm, DBG_RA, ("rate[%d]: (( VHT2SS-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEVHTSS2MCS0)));
-		/*dummy for SD4 check patch*/
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( VHT2SS-MCS%d ))\n",
+			  platform_macid, (rate_idx - ODM_RATEVHTSS2MCS0));
+		/*@dummy for SD4 check patch*/
 	} else if (rate_idx >= ODM_RATEVHTSS1MCS0) {
-		PHYDM_DBG(p_dm, DBG_RA, ("rate[%d]: (( VHT1SS-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEVHTSS1MCS0)));
-		/*dummy for SD4 check patch*/
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( VHT1SS-MCS%d ))\n",
+			  platform_macid, (rate_idx - ODM_RATEVHTSS1MCS0));
+		/*@dummy for SD4 check patch*/
 	} else if (rate_idx >= ODM_RATEMCS0) {
-		PHYDM_DBG(p_dm, DBG_RA, ("rate[%d]: (( HT-MCS%d ))\n", platform_macid, (rate_idx - ODM_RATEMCS0)));
-		/*dummy for SD4 check patch*/
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( HT-MCS%d ))\n",
+			  platform_macid, (rate_idx - ODM_RATEMCS0));
+		/*@dummy for SD4 check patch*/
 	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("rate[%d]: (( HT-MCS%d ))\n", platform_macid, rate_idx));
-		/*dummy for SD4 check patch*/
+		PHYDM_DBG(dm, DBG_RA, "rate[%d]: (( HT-MCS%d ))\n",
+			  platform_macid, rate_idx);
+		/*@dummy for SD4 check patch*/
 	}
 #endif
 
-	phydm_macid = p_dm->phydm_macid_table[platform_macid];
-	p_entry = p_dm->p_odm_sta_info[phydm_macid];
-	p_sta = p_dm->p_phydm_sta_info[phydm_macid];
-
-	if (is_sta_active(p_sta)) {
-		wireless_mode = p_entry->wireless_mode;
+	phydm_macid = dm->phydm_macid_table[platform_macid];
+	sta = dm->phydm_sta_info[phydm_macid];
 
-		if ((p_dm->rf_type  == RF_2T2R) || (p_dm->rf_type  == RF_2T3R) || (p_dm->rf_type  == RF_2T4R)) {
+	if (is_sta_active(sta)) {
+		wireless_set = sta->support_wireless_set;
 
-			if (wireless_mode & (ODM_WM_N24G | ODM_WM_N5G)) { /*N mode*/
-				if (rate_idx >= ODM_RATEMCS8 && rate_idx <= ODM_RATEMCS15) { /*2SS mode*/
+		if (dm->rf_type == RF_2T2R || dm->rf_type == RF_2T3R || dm->rf_type == RF_2T4R) {
+			if (wireless_set & WIRELESS_HT) { /*N mode*/
+				if (rate_idx >= ODM_RATEMCS8 && rate_idx <= ODM_RATEMCS15) { /*@2SS mode*/
 
-					p_sta->ra_info.rate_id  = ARFR_5_RATE_ID;
-					PHYDM_DBG(p_dm, DBG_RA, ("ARFR_5\n"));
+					sta->ra_info.rate_id  = ARFR_5_RATE_ID;
+					PHYDM_DBG(dm, DBG_RA, "ARFR_5\n");
 				}
-			} else if (wireless_mode & (ODM_WM_AC_5G | ODM_WM_AC_24G | ODM_WM_AC_ONLY)) {/*AC mode*/
-				if (rate_idx >= ODM_RATEVHTSS2MCS0 && rate_idx <= ODM_RATEVHTSS2MCS9) {/*2SS mode*/
+			} else if (wireless_set & WIRELESS_VHT) {/*@AC mode*/
+				if (rate_idx >= ODM_RATEVHTSS2MCS0 && rate_idx <= ODM_RATEVHTSS2MCS9) {/*@2SS mode*/
 
-					p_sta->ra_info.rate_id  = ARFR_0_RATE_ID;
-					PHYDM_DBG(p_dm, DBG_RA, ("ARFR_0\n"));
+					sta->ra_info.rate_id  = ARFR_0_RATE_ID;
+					PHYDM_DBG(dm, DBG_RA, "ARFR_0\n");
 				}
 			} else
-				p_sta->ra_info.rate_id  = ARFR_0_RATE_ID;
+				sta->ra_info.rate_id  = ARFR_0_RATE_ID;
 
-			PHYDM_DBG(p_dm, DBG_RA, ("UPdate_RateID[%d]: (( 0x%x ))\n", platform_macid, p_sta->ra_info.rate_id));
+			PHYDM_DBG(dm, DBG_RA, "UPdate_RateID[%d]: (( 0x%x ))\n",
+				  platform_macid, sta->ra_info.rate_id);
 		}
 	}
 #endif
 }
 
 #endif
-
-#if (defined(CONFIG_RA_DBG_CMD))
-void
-odm_ra_para_adjust_send_h2c(
-	void	*p_dm_void
-)
-{
-
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-	u8			h2c_parameter[6] = {0};
-
-	h2c_parameter[0] = RA_FIRST_MACID;
-
-	if (p_ra_table->ra_para_feedback_req) { /*h2c_parameter[5]=1 ; ask FW for all RA parameters*/
-		PHYDM_DBG(p_dm, DBG_RA, ("[H2C] Ask FW for RA parameter\n"));
-		h2c_parameter[5] |= BIT(1); /*ask FW to report RA parameters*/
-		h2c_parameter[1] = p_ra_table->para_idx; /*p_ra_table->para_idx;*/
-		p_ra_table->ra_para_feedback_req = 0;
-	} else {
-		PHYDM_DBG(p_dm, DBG_RA, ("[H2C] Send H2C to FW for modifying RA parameter\n"));
-
-		h2c_parameter[1] =  p_ra_table->para_idx;
-		h2c_parameter[2] =  p_ra_table->rate_idx;
-		/* [8 bit]*/
-		if (p_ra_table->para_idx == RADBG_RTY_PENALTY || p_ra_table->para_idx == RADBG_RATE_UP_RTY_RATIO || p_ra_table->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
-			h2c_parameter[3] = p_ra_table->value;
-			h2c_parameter[4] = 0;
-		}
-		/* [16 bit]*/
-		else {
-			h2c_parameter[3] = (u8)(((p_ra_table->value_16) & 0xf0) >> 4); /*byte1*/
-			h2c_parameter[4] = (u8)((p_ra_table->value_16) & 0x0f);	/*byte0*/
-		}
-	}
-	PHYDM_DBG(p_dm, DBG_RA, (" h2c_parameter[1] = 0x%x\n", h2c_parameter[1]));
-	PHYDM_DBG(p_dm, DBG_RA, (" h2c_parameter[2] = 0x%x\n", h2c_parameter[2]));
-	PHYDM_DBG(p_dm, DBG_RA, (" h2c_parameter[3] = 0x%x\n", h2c_parameter[3]));
-	PHYDM_DBG(p_dm, DBG_RA, (" h2c_parameter[4] = 0x%x\n", h2c_parameter[4]));
-	PHYDM_DBG(p_dm, DBG_RA, (" h2c_parameter[5] = 0x%x\n", h2c_parameter[5]));
-
-	odm_fill_h2c_cmd(p_dm, ODM_H2C_RA_PARA_ADJUST, 6, h2c_parameter);
-
-}
-
-
-void
-odm_ra_para_adjust(
-	void		*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-	u8			rate_idx = p_ra_table->rate_idx;
-	u8			value = p_ra_table->value;
-	u8			pre_value = 0xff;
-
-	if (p_ra_table->para_idx == RADBG_RTY_PENALTY) {
-		pre_value = p_ra_table->RTY_P[rate_idx];
-		p_ra_table->RTY_P[rate_idx] = value;
-		p_ra_table->RTY_P_modify_note[rate_idx] = 1;
-	} else if (p_ra_table->para_idx == RADBG_N_HIGH) {
-
-	} else if (p_ra_table->para_idx == RADBG_N_LOW) {
-
-	} else if (p_ra_table->para_idx == RADBG_RATE_UP_RTY_RATIO) {
-		pre_value = p_ra_table->RATE_UP_RTY_RATIO[rate_idx];
-		p_ra_table->RATE_UP_RTY_RATIO[rate_idx] = value;
-		p_ra_table->RATE_UP_RTY_RATIO_modify_note[rate_idx] = 1;
-	} else if (p_ra_table->para_idx == RADBG_RATE_DOWN_RTY_RATIO) {
-		pre_value = p_ra_table->RATE_DOWN_RTY_RATIO[rate_idx];
-		p_ra_table->RATE_DOWN_RTY_RATIO[rate_idx] = value;
-		p_ra_table->RATE_DOWN_RTY_RATIO_modify_note[rate_idx] = 1;
-	}
-	PHYDM_DBG(p_dm, DBG_RA, ("Change RA Papa[%d], rate[ %d ],   ((%d))  ->  ((%d))\n", p_ra_table->para_idx, rate_idx, pre_value, value));
-	odm_ra_para_adjust_send_h2c(p_dm);
-}
-
-void
-phydm_ra_print_msg(
-	void		*p_dm_void,
-	u8		*value,
-	u8		*value_default,
-	u8		*modify_note
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-	u32 i;
-
-	PHYDM_DBG(p_dm, DBG_RA, (" |rate index| |Current-value| |Default-value| |Modify?|\n"));
-	for (i = 0 ; i <= (p_ra_table->rate_length); i++) {
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-		PHYDM_DBG(p_dm, DBG_RA, ("     [ %d ]  %20d  %25d  %20s\n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  ")));
-#else
-		PHYDM_DBG(p_dm, DBG_RA, ("     [ %d ]  %10d  %14d  %14s\n", i, value[i], value_default[i], ((modify_note[i] == 1) ? "V" : " .  ")));
-#endif
-	}
-
-}
-
-void
-odm_RA_debug(
-	void		*p_dm_void,
-	u32		*const dm_value
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-
-	p_ra_table->is_ra_dbg_init = false;
-
-	if (dm_value[0] == 100) { /*1 Print RA Parameters*/
-		u8	default_pointer_value;
-		u8	*pvalue;
-		u8	*pvalue_default;
-		u8	*pmodify_note;
-
-		pvalue = pvalue_default = pmodify_note = &default_pointer_value;
-
-		PHYDM_DBG(p_dm, DBG_RA, ("\n------------------------------------------------------------------------------------\n"));
-
-		if (dm_value[1] == RADBG_RTY_PENALTY) { /* [1]*/
-			PHYDM_DBG(p_dm, DBG_RA, (" [1] RTY_PENALTY\n"));
-			pvalue		=	&(p_ra_table->RTY_P[0]);
-			pvalue_default	=	&(p_ra_table->RTY_P_default[0]);
-			pmodify_note	=	(u8 *)&(p_ra_table->RTY_P_modify_note[0]);
-		} else if (dm_value[1] == RADBG_N_HIGH)   /* [2]*/
-			PHYDM_DBG(p_dm, DBG_RA, (" [2] N_HIGH\n"));
-
-		else if (dm_value[1] == RADBG_N_LOW)   /*[3]*/
-			PHYDM_DBG(p_dm, DBG_RA, (" [3] N_LOW\n"));
-
-		else if (dm_value[1] == RADBG_RATE_UP_RTY_RATIO) { /* [8]*/
-			PHYDM_DBG(p_dm, DBG_RA, (" [8] RATE_UP_RTY_RATIO\n"));
-			pvalue		=	&(p_ra_table->RATE_UP_RTY_RATIO[0]);
-			pvalue_default	=	&(p_ra_table->RATE_UP_RTY_RATIO_default[0]);
-			pmodify_note	=	(u8 *)&(p_ra_table->RATE_UP_RTY_RATIO_modify_note[0]);
-		} else if (dm_value[1] == RADBG_RATE_DOWN_RTY_RATIO) { /* [9]*/
-			PHYDM_DBG(p_dm, DBG_RA, (" [9] RATE_DOWN_RTY_RATIO\n"));
-			pvalue		=	&(p_ra_table->RATE_DOWN_RTY_RATIO[0]);
-			pvalue_default	=	&(p_ra_table->RATE_DOWN_RTY_RATIO_default[0]);
-			pmodify_note	=	(u8 *)&(p_ra_table->RATE_DOWN_RTY_RATIO_modify_note[0]);
-		}
-
-		phydm_ra_print_msg(p_dm, pvalue, pvalue_default, pmodify_note);
-		PHYDM_DBG(p_dm, DBG_RA, ("\n------------------------------------------------------------------------------------\n\n"));
-
-	} else if (dm_value[0] == 101) {
-		p_ra_table->para_idx = (u8)dm_value[1];
-
-		p_ra_table->ra_para_feedback_req = 1;
-		odm_ra_para_adjust_send_h2c(p_dm);
-	} else {
-		p_ra_table->para_idx = (u8)dm_value[0];
-		p_ra_table->rate_idx  = (u8)dm_value[1];
-		p_ra_table->value = (u8)dm_value[2];
-
-		odm_ra_para_adjust(p_dm);
-	}
-}
-
-void
-odm_ra_para_adjust_init(
-	void		*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-	u8			i;
-	u8			ra_para_pool_u8[3] = { RADBG_RTY_PENALTY,  RADBG_RATE_UP_RTY_RATIO, RADBG_RATE_DOWN_RTY_RATIO};
-	u8			rate_size_ht_1ss = 20, rate_size_ht_2ss = 28, rate_size_ht_3ss = 36;	 /*4+8+8+8+8 =36*/
-	u8			rate_size_vht_1ss = 10, rate_size_vht_2ss = 20, rate_size_vht_3ss = 30;	 /*10 + 10 +10 =30*/
-#if 0
-	/* RTY_PENALTY		=	1,   u8 */
-	/* N_HIGH 				=	2, */
-	/* N_LOW				=	3, */
-	/* RATE_UP_TABLE		=	4, */
-	/* RATE_DOWN_TABLE	=	5, */
-	/* TRYING_NECESSARY	=	6, */
-	/* DROPING_NECESSARY =	7, */
-	/* RATE_UP_RTY_RATIO	=	8,  u8 */
-	/* RATE_DOWN_RTY_RATIO=	9,  u8 */
-	/* ALL_PARA		=	0xff */
-
-#endif
-	PHYDM_DBG(p_dm, DBG_RA, ("odm_ra_para_adjust_init\n"));
-
-/* JJ ADD 20161014 */
-	if (p_dm->support_ic_type & (ODM_RTL8188F | ODM_RTL8195A | ODM_RTL8703B | ODM_RTL8723B | ODM_RTL8188E | ODM_RTL8723D | ODM_RTL8710B))
-		p_ra_table->rate_length = rate_size_ht_1ss;
-	else if (p_dm->support_ic_type & (ODM_RTL8192E | ODM_RTL8197F))
-		p_ra_table->rate_length = rate_size_ht_2ss;
-	else if (p_dm->support_ic_type & (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8821C))
-		p_ra_table->rate_length = rate_size_ht_1ss + rate_size_vht_1ss;
-	else if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8822B))
-		p_ra_table->rate_length = rate_size_ht_2ss + rate_size_vht_2ss;
-	else if (p_dm->support_ic_type == ODM_RTL8814A)
-		p_ra_table->rate_length = rate_size_ht_3ss + rate_size_vht_3ss;
-	else
-		p_ra_table->rate_length = rate_size_ht_1ss;
-
-	p_ra_table->is_ra_dbg_init = true;
-	for (i = 0; i < 3; i++) {
-		p_ra_table->ra_para_feedback_req = 1;
-		p_ra_table->para_idx	=	ra_para_pool_u8[i];
-		odm_ra_para_adjust_send_h2c(p_dm);
-	}
-}
-
-#endif /*#if (defined(CONFIG_RA_DBG_CMD))*/
-
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.h
index ba8008b63c64..c69f6a1089c7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rainfo.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,28 +9,29 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMRAINFO_H__
-#define    __PHYDMRAINFO_H__
+#ifndef __PHYDMRAINFO_H__
+#define __PHYDMRAINFO_H__
 
-/*#define RAINFO_VERSION	"2.0"*/  /*2014.11.04*/
-/*#define RAINFO_VERSION	"3.0"*/  /*2015.01.13 Dino*/
-/*#define RAINFO_VERSION	"3.1"*/  /*2015.01.14 Dino*/
-/*#define RAINFO_VERSION	"3.3"*/  /*2015.07.29 YuChen*/
-/*#define RAINFO_VERSION	"3.4"*/  /*2015.12.15 Stanley*/
-/*#define RAINFO_VERSION	"4.0"*/  /*2016.03.24 Dino, Add more RA mask state and Phydm-lize partial ra mask function  */
-/*#define RAINFO_VERSION	"4.1"*/  /*2016.04.20 Dino, Add new function to adjust PCR RA threshold  */
-/*#define RAINFO_VERSION	"4.2"*/  /*2016.05.17 Dino, Add H2C debug cmd  */
-/*#define RAINFO_VERSION	"4.3"*/  /*2016.07.11 Dino, Fix RA hang in CCK 1M problem  */
-#define RAINFO_VERSION	"5.0"  /*2017.04.20 Dino, the 3rd PHYDM reform*/
+#define RAINFO_VERSION "8.0"
 
 #define	FORCED_UPDATE_RAMASK_PERIOD	5
 
-#define	H2C_MAX_LENGTH	7
+#define	H2C_MAX_LENGTH		7
 
 #define	RA_FLOOR_UP_GAP		3
 #define	RA_FLOOR_TABLE_SIZE	7
@@ -40,49 +42,38 @@
 #define	RA_RETRY_LIMIT_HIGH	32
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	#define		RA_FIRST_MACID	1
-#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define	RA_FIRST_MACID	0
-	#define	WIN_DEFAULT_PORT_MACID	0
-	#define	WIN_BT_PORT_MACID	2
-#else /*if (DM_ODM_SUPPORT_TYPE == ODM_CE)*/
-	#define		RA_FIRST_MACID	0
+	#define	FIRST_MACID	1
+#else
+	#define	FIRST_MACID	0
 #endif
 
-#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-#define AP_InitRateAdaptiveState		odm_rate_adaptive_state_ap_init
-#endif
-
-
-#define		DM_RATR_STA_INIT			0
-#define		DM_RATR_STA_HIGH			1
-#define		DM_RATR_STA_MIDDLE		2
-#define		DM_RATR_STA_LOW			3
-#define		DM_RATR_STA_ULTRA_LOW	4
-
-enum phydm_ra_dbg_para_e {
-	RADBG_PCR_TH_OFFSET		=	0,
-	RADBG_RTY_PENALTY		=	1,
-	RADBG_N_HIGH				=	2,
-	RADBG_N_LOW				=	3,
-	RADBG_TRATE_UP_TABLE		=	4,
-	RADBG_TRATE_DOWN_TABLE	=	5,
-	RADBG_TRYING_NECESSARY	=	6,
-	RADBG_TDROPING_NECESSARY =	7,
-	RADBG_RATE_UP_RTY_RATIO	=	8,
-	RADBG_RATE_DOWN_RTY_RATIO =	9, /* u8 */
-
-	RADBG_DEBUG_MONITOR1 = 0xc,
-	RADBG_DEBUG_MONITOR2 = 0xd,
-	RADBG_DEBUG_MONITOR3 = 0xe,
-	RADBG_DEBUG_MONITOR4 = 0xf,
-	RADBG_DEBUG_MONITOR5 = 0x10,
+/* @1 ============================================================
+ * 1 enumrate
+ * 1 ============================================================
+ */
+
+enum phydm_ra_dbg_para {
+	RADBG_PCR_TH_OFFSET	= 0,
+	RADBG_RTY_PENALTY	= 1,
+	RADBG_N_HIGH		= 2,
+	RADBG_N_LOW		= 3,
+	RADBG_TRATE_UP_TABLE	= 4,
+	RADBG_TRATE_DOWN_TABLE	= 5,
+	RADBG_TRYING_NECESSARY	= 6,
+	RADBG_TDROPING_NECESSARY = 7,
+	RADBG_RATE_UP_RTY_RATIO	= 8,
+	RADBG_RATE_DOWN_RTY_RATIO = 9, /* u8 */
+
+	RADBG_DEBUG_MONITOR1	= 0xc,
+	RADBG_DEBUG_MONITOR2	= 0xd,
+	RADBG_DEBUG_MONITOR3	= 0xe,
+	RADBG_DEBUG_MONITOR4	= 0xf,
+	RADBG_DEBUG_MONITOR5	= 0x10,
 	NUM_RA_PARA
 };
 
-enum phydm_wireless_mode_e {
-
-	PHYDM_WIRELESS_MODE_UNKNOWN = 0x00,
+enum phydm_wireless_mode {
+	PHYDM_WIRELESS_MODE_UNKNOWN	= 0x00,
 	PHYDM_WIRELESS_MODE_A		= 0x01,
 	PHYDM_WIRELESS_MODE_B		= 0x02,
 	PHYDM_WIRELESS_MODE_G		= 0x04,
@@ -96,361 +87,191 @@ enum phydm_wireless_mode_e {
 	PHYDM_WIRELESS_MODE_ALL		= 0xFFFF
 };
 
-enum phydm_rateid_idx_e {
-
+enum phydm_rateid_idx {
 	PHYDM_BGN_40M_2SS	= 0,
 	PHYDM_BGN_40M_1SS	= 1,
 	PHYDM_BGN_20M_2SS	= 2,
 	PHYDM_BGN_20M_1SS	= 3,
-	PHYDM_GN_N2SS			= 4,
-	PHYDM_GN_N1SS			= 5,
-	PHYDM_BG				= 6,
-	PHYDM_G				= 7,
-	PHYDM_B_20M			= 8,
+	PHYDM_GN_N2SS		= 4,
+	PHYDM_GN_N1SS		= 5,
+	PHYDM_BG		= 6,
+	PHYDM_G			= 7,
+	PHYDM_B_20M		= 8,
 	PHYDM_ARFR0_AC_2SS	= 9,
 	PHYDM_ARFR1_AC_1SS	= 10,
 	PHYDM_ARFR2_AC_2G_1SS	= 11,
 	PHYDM_ARFR3_AC_2G_2SS	= 12,
 	PHYDM_ARFR4_AC_3SS	= 13,
-	PHYDM_ARFR5_N_3SS		= 14
+	PHYDM_ARFR5_N_3SS	= 14,
+	PHYDM_ARFR7_N_4SS	= 15,
+	PHYDM_ARFR6_AC_4SS	= 16
+};
+
+#if (RATE_ADAPTIVE_SUPPORT == 1)/* @88E RA */
+
+struct _phydm_txstatistic_ {
+	u32	hw_total_tx;
+	u32	hw_tx_success;
+	u32	hw_tx_rty;
+	u32	hw_tx_drop;
 };
 
-#if (RATE_ADAPTIVE_SUPPORT == 1)/* 88E RA */
+/* @1 ============================================================
+ * 1  structure
+ * 1 ============================================================
+ */
 struct _odm_ra_info_ {
-	u8 rate_id;
-	u32 rate_mask;
-	u32 ra_use_rate;
-	u8 rate_sgi;
-	u8 rssi_sta_ra;
-	u8 pre_rssi_sta_ra;
-	u8 sgi_enable;
-	u8 decision_rate;
-	u8 pre_rate;
-	u8 highest_rate;
-	u8 lowest_rate;
-	u32 nsc_up;
-	u32 nsc_down;
-	u16 RTY[5];
-	u32 TOTAL;
-	u16 DROP;
-	u8 active;
-	u16 rpt_time;
-	u8 ra_waiting_counter;
-	u8 ra_pending_counter;
-	u8 ra_drop_after_down;
+	u8	rate_id;
+	u32	rate_mask;
+	u32	ra_use_rate;
+	u8	rate_sgi;
+	u8	rssi_sta_ra;
+	u8	pre_rssi_sta_ra;
+	u8	sgi_enable;
+	u8	decision_rate;
+	u8	pre_rate;
+	u8	highest_rate;
+	u8	lowest_rate;
+	u32	nsc_up;
+	u32	nsc_down;
+	u16	RTY[5];
+	u32	TOTAL;
+	u16	DROP;
+	u8	active;
+	u16	rpt_time;
+	u8	ra_waiting_counter;
+	u8	ra_pending_counter;
+	u8	ra_drop_after_down;
 #if 1 /* POWER_TRAINING_ACTIVE == 1 */ /* For compile  pass only~! */
-	u8 pt_active;  /* on or off */
-	u8 pt_try_state;  /* 0 trying state, 1 for decision state */
-	u8 pt_stage;  /* 0~6 */
-	u8 pt_stop_count; /* Stop PT counter */
-	u8 pt_pre_rate;  /* if rate change do PT */
-	u8 pt_pre_rssi; /* if RSSI change 5% do PT */
-	u8 pt_mode_ss;  /* decide whitch rate should do PT */
-	u8 ra_stage;  /* StageRA, decide how many times RA will be done between PT */
-	u8 pt_smooth_factor;
+	u8	pt_active;	/* on or off */
+	u8	pt_try_state;	/* @0 trying state, 1 for decision state */
+	u8	pt_stage;	/* @0~6 */
+	u8	pt_stop_count;	/* Stop PT counter */
+	u8	pt_pre_rate;	/* @if rate change do PT */
+	u8	pt_pre_rssi;	/* @if RSSI change 5% do PT */
+	u8	pt_mode_ss;	/* @decide whitch rate should do PT */
+	u8	ra_stage;	/* @StageRA, decide how many times RA will be done between PT */
+	u8	pt_smooth_factor;
 #endif
 #if (DM_ODM_SUPPORT_TYPE == ODM_AP) &&	((DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE))
-	u8 rate_down_counter;
-	u8 rate_up_counter;
-	u8 rate_direction;
-	u8 bounding_type;
-	u8 bounding_counter;
-	u8 bounding_learning_time;
-	u8 rate_down_start_time;
+	u8	rate_down_counter;
+	u8	rate_up_counter;
+	u8	rate_direction;
+	u8	bounding_type;
+	u8	bounding_counter;
+	u8	bounding_learning_time;
+	u8	rate_down_start_time;
 #endif
 };
 #endif
 
 
-struct _rate_adaptive_table_ {
-	u8		firstconnect;
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	boolean		PT_collision_pre;
-#endif
-
-#if (defined(CONFIG_RA_DBG_CMD))
-	boolean		is_ra_dbg_init;
-
-	u8	RTY_P[ODM_NUM_RATE_IDX];
-	u8	RTY_P_default[ODM_NUM_RATE_IDX];
-	boolean	RTY_P_modify_note[ODM_NUM_RATE_IDX];
-
-	u8	RATE_UP_RTY_RATIO[ODM_NUM_RATE_IDX];
-	u8	RATE_UP_RTY_RATIO_default[ODM_NUM_RATE_IDX];
-	boolean	RATE_UP_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
-
-	u8	RATE_DOWN_RTY_RATIO[ODM_NUM_RATE_IDX];
-	u8	RATE_DOWN_RTY_RATIO_default[ODM_NUM_RATE_IDX];
-	boolean	RATE_DOWN_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];
-
-	boolean ra_para_feedback_req;
-
-	u8   para_idx;
-	u8	rate_idx;
-	u8	value;
-	u16	value_16;
-	u8	rate_length;
-#endif
-	/*u8	link_tx_rate[ODM_ASSOCIATE_ENTRY_NUM];*/
-	u8	ra_ratio[ODM_ASSOCIATE_ENTRY_NUM];
+struct ra_table {
+	u8	firstconnect;
+	/*@u8	link_tx_rate[ODM_ASSOCIATE_ENTRY_NUM];*/
 	u8	mu1_rate[30];
 	u8	highest_client_tx_order;
 	u16	highest_client_tx_rate_order;
 	u8	power_tracking_flag;
-	u8	RA_threshold_offset;
-	u8	RA_offset_direction;
-	u8	up_ramask_cnt; /*force update_ra_mask counter*/
-	u8	up_ramask_cnt_tmp; /*Just for debug, should be removed latter*/
-
-#if (defined(CONFIG_RA_DYNAMIC_RTY_LIMIT))
+	u8	ra_th_ofst; /*RA_threshold_offset*/
+	u8	ra_ofst_direc; /*RA_offset_direction*/
+	u8	up_ramask_cnt; /*@force update_ra_mask counter*/
+	u8	up_ramask_cnt_tmp; /*@Just for debug, should be removed latter*/
+#if 0	/*@CONFIG_RA_DYNAMIC_RTY_LIMIT*/
 	u8	per_rate_retrylimit_20M[ODM_NUM_RATE_IDX];
 	u8	per_rate_retrylimit_40M[ODM_NUM_RATE_IDX];
 	u8	retry_descend_num;
 	u8	retrylimit_low;
 	u8	retrylimit_high;
 #endif
-	u8	ldpc_thres;			/* if RSSI > ldpc_thres => switch from LPDC to BCC */
-
-	void (*record_ra_info)(void *p_dm_void, u8 macid, struct cmn_sta_info *p_sta, u64 ra_mask);
+	u8	ldpc_thres; /* @if RSSI > ldpc_th => switch from LPDC to BCC */
+	void (*record_ra_info)(void *dm_void, u8 macid,
+			       struct cmn_sta_info *sta, u64 ra_mask);
 };
 
-void
-phydm_h2C_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char			*output,
-	u32		*_out_len
-);
+/* @1 ============================================================
+ * 1  Function Prototype
+ * 1 ============================================================
+ */
+boolean phydm_is_cck_rate(void *dm_void, u8 rate);
 
-#if (defined(CONFIG_RA_DBG_CMD))
+boolean phydm_is_ofdm_rate(void *dm_void, u8 rate);
 
-void
-odm_RA_debug(
-	void		*p_dm_void,
-	u32		*const dm_value
-);
+boolean phydm_is_ht_rate(void *dm_void, u8 rate);
 
-void
-odm_ra_para_adjust_init(
-	void		*p_dm_void
-);
+boolean phydm_is_vht_rate(void *dm_void, u8 rate);
 
-#endif
+u8 phydm_rate_type_2_num_ss(void *dm_void, enum PDM_RATE_TYPE type);
 
-void
-phydm_ra_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-);
-
-void
-odm_c2h_ra_para_report_handler(
-	void	*p_dm_void,
-	u8	*cmd_buf,
-	u8	cmd_len
-);
-
-void
-odm_ra_para_adjust(
-	void		*p_dm_void
-);
-
-void
-phydm_ra_dynamic_retry_count(
-	void	*p_dm_void
-);
-
-void
-phydm_ra_dynamic_retry_limit(
-	void	*p_dm_void
-);
-
-void
-phydm_print_rate(
-	void	*p_dm_void,
-	u8	rate,
-	u32	dbg_component
-);
-
-void
-phydm_c2h_ra_report_handler(
-	void	*p_dm_void,
-	u8   *cmd_buf,
-	u8   cmd_len
-);
-
-u8
-phydm_rate_order_compute(
-	void	*p_dm_void,
-	u8	rate_idx
-);
-
-void
-phydm_ra_info_watchdog(
-	void	*p_dm_void
-);
-
-void
-phydm_ra_info_init(
-	void	*p_dm_void
-);
-
-void
-phydm_modify_RA_PCR_threshold(
-	void		*p_dm_void,
-	u8		RA_offset_direction,
-	u8		RA_threshold_offset
-);
-
-u8
-phydm_vht_en_mapping(
-	void			*p_dm_void,
-	u32			wireless_mode
-);
-
-u8
-phydm_rate_id_mapping(
-	void			*p_dm_void,
-	u32			wireless_mode,
-	u8			rf_type,
-	u8			bw
-);
-
-void
-phydm_update_hal_ra_mask(
-	void			*p_dm_void,
-	u32			wireless_mode,
-	u8			rf_type,
-	u8			BW,
-	u8			mimo_ps_enable,
-	u8			disable_cck_rate,
-	u32			*ratr_bitmap_msb_in,
-	u32			*ratr_bitmap_in,
-	u8			tx_rate_level
-);
-
-void
-phydm_refresh_rate_adaptive_mask(
-	void		*p_dm_void
-);
-
-u8
-phydm_rssi_lv_dec(
-	void			*p_dm_void,
-	u32			rssi,
-	u8			ratr_state
-);
-
-void
-odm_ra_post_action_on_assoc(
-	void	*p_dm
-);
-
-u8
-odm_find_rts_rate(
-	void		*p_dm_void,
-	u8			tx_rate,
-	boolean			is_erp_protect
-);
-
-void
-phydm_show_sta_info(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
-
-#ifdef	PHYDM_3RD_REFORM_RA_MASK
-
-void
-phydm_ra_registed(
-	void	*p_dm_void,
-	u8	macid,
-	u8	rssi_from_assoc
-);
-
-void
-phydm_ra_offline(
-	void	*p_dm_void,
-	u8	macid
-);
-
-
-void
-phydm_ra_mask_watchdog(
-	void	*p_dm_void
-);
+u8 phydm_rate_to_num_ss(void *dm_void, u8 data_rate);
 
-#endif
+void phydm_h2C_debug(void *dm_void, char input[][16], u32 *_used,
+		     char *output, u32 *_out_len);
 
+void phydm_ra_debug(void *dm_void, char input[][16], u32 *_used, char *output,
+		    u32 *_out_len);
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void odm_c2h_ra_para_report_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len);
+
+void phydm_ra_dynamic_retry_count(void *dm_void);
+
+
+void phydm_print_rate(void *dm_void, u8 rate, u32 dbg_component);
+
+void phydm_print_rate_2_buff(void *dm_void, u8 rate, char *buf, u16 buf_size);
+
+void phydm_c2h_ra_report_handler(void *dm_void, u8 *cmd_buf, u8 cmd_len);
 
-void
-odm_refresh_basic_rate_mask(
-	void		*p_dm_void
-);
-
-void
-odm_update_init_rate_work_item_callback(
-	void	*p_context
-);
-
-void
-odm_refresh_ldpc_rts_mp(
-	struct _ADAPTER			*p_adapter,
-	struct PHY_DM_STRUCT			*p_dm,
-	u8				m_mac_id,
-	u8				iot_peer,
-	s32				undecorated_smoothed_pwdb
-);
-
-void
-odm_rate_adaptive_state_ap_init(
-	void			*PADAPTER_VOID,
-	struct cmn_sta_info	*p_entry
-);
-
-#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
-
-void
-phydm_gen_ramask_h2c_AP(
-	void			*p_dm_void,
-	struct rtl8192cd_priv *priv,
-	struct sta_info *p_entry,
-	u8			rssi_level
-);
-
-#endif/*#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))*/
-
-
-#if (defined(CONFIG_RA_DYNAMIC_RATE_ID))
-void
-phydm_ra_dynamic_rate_id_on_assoc(
-	void	*p_dm_void,
-	u8	wireless_mode,
-	u8	init_rate_id
-);
-
-void
-phydm_ra_dynamic_rate_id_init(
-	void	*p_dm_void
-);
-
-void
-phydm_update_rate_id(
-	void	*p_dm_void,
-	u8	rate,
-	u8	platform_macid
-);
+u8 phydm_rate_order_compute(void *dm_void, u8 rate_idx);
+
+void phydm_ra_info_watchdog(void *dm_void);
+
+void phydm_ra_info_init(void *dm_void);
+
+void phydm_modify_RA_PCR_threshold(void *dm_void, u8 ra_ofst_direc,
+				   u8 ra_th_ofst);
+
+u8 phydm_vht_en_mapping(void *dm_void, u32 wireless_mode);
+
+u8 phydm_rate_id_mapping(void *dm_void, u32 wireless_mode, u8 rf_type, u8 bw);
+#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
+void phydm_update_hal_ra_mask(
+	void *dm_void,
+	u32 wireless_mode,
+	u8 rf_type,
+	u8 BW,
+	u8 mimo_ps_enable,
+	u8 disable_cck_rate,
+	u32 *ratr_bitmap_msb_in,
+	u32 *ratr_bitmap_in,
+	u8 tx_rate_level);
+#endif
 
+#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
+u8 phydm_get_plcp(void *dm_void, u16 macid);
 #endif
 
-#endif /*#ifndef	__ODMRAINFO_H__*/
+void phydm_refresh_rate_adaptive_mask(void *dm_void);
+
+u8 phydm_rssi_lv_dec(void *dm_void, u32 rssi, u8 ratr_state);
+
+void odm_ra_post_action_on_assoc(void *dm);
+
+u8 odm_find_rts_rate(void *dm_void, u8 tx_rate, boolean is_erp_protect);
+
+void phydm_show_sta_info(void *dm_void, char input[][16], u32 *_used,
+			 char *output, u32 *_out_len);
+
+u8 phydm_get_rate_from_rssi_lv(void *dm_void, u8 sta_idx);
+
+void phydm_ra_registed(void *dm_void, u8 macid, u8 rssi_from_assoc);
+
+void phydm_ra_offline(void *dm_void, u8 macid);
+
+void phydm_ra_mask_watchdog(void *dm_void);
+
+#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
+void odm_refresh_basic_rate_mask(
+	void *dm_void);
+#endif
+#endif /*@#ifndef __PHYDMRAINFO_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_reg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_reg.h
index 9bb5dde234b5..4077a72ee46c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_reg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_reg.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,11 +9,21 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
-/* ************************************************************
+/*************************************************************
  * File Name: odm_reg.h
  *
  * Description:
@@ -20,17 +31,18 @@
  * This file is for general register definition.
  *
  *
- * ************************************************************ */
-#ifndef	__HAL_ODM_REG_H__
+ ************************************************************/
+#ifndef __HAL_ODM_REG_H__
 #define __HAL_ODM_REG_H__
 
-/*
+/*@
  * Register Definition
- *   */
+ *
+ */
 
-/* MAC REG */
-#define	ODM_BB_RESET					0x002
-#define	ODM_DUMMY						0x4fe
+/* @MAC REG */
+#define	ODM_BB_RESET				0x002
+#define	ODM_DUMMY				0x4fe
 #define	RF_T_METER_OLD				0x24
 #define	RF_T_METER_NEW				0x42
 
@@ -38,159 +50,159 @@
 #define	ODM_EDCA_VI_PARAM			0x504
 #define	ODM_EDCA_BE_PARAM			0x508
 #define	ODM_EDCA_BK_PARAM			0x50C
-#define	ODM_TXPAUSE					0x522
+#define	ODM_TXPAUSE				0x522
 
-/* LTE_COEX */
+/* @LTE_COEX */
 #define REG_LTECOEX_CTRL			0x07C0
-#define REG_LTECOEX_WRITE_DATA		0x07C4
-#define REG_LTECOEX_READ_DATA		0x07C8
-#define REG_LTECOEX_PATH_CONTROL	0x70
+#define REG_LTECOEX_WRITE_DATA			0x07C4
+#define REG_LTECOEX_READ_DATA			0x07C8
+#define REG_LTECOEX_PATH_CONTROL		0x70
 
-/* BB REG */
+/* @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_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_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_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_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_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_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_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_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_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
+#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
+#define	ODM_GAIN_SETTING			0x00
+#define	ODM_CHANNEL				0x18
 #define	ODM_RF_T_METER				0x24
 #define	ODM_RF_T_METER_92D			0x42
 #define	ODM_RF_T_METER_88E			0x42
 #define	ODM_RF_T_METER_92E			0x42
 #define	ODM_RF_T_METER_8812			0x42
-#define	REG_RF_TX_GAIN_OFFSET				0x55
+#define	REG_RF_TX_GAIN_OFFSET			0x55
 
-/* ant Detect Reg */
-#define	ODM_DPDT						0x300
+/* @ant Detect Reg */
+#define	ODM_DPDT				0x300
 
 /* PSD Init */
-#define	ODM_PSDREG					0x808
+#define	ODM_PSDREG				0x808
 
-/* 92D path Div */
-#define	PATHDIV_REG					0xB30
-#define	PATHDIV_TRI					0xBA0
+/* @92D path Div */
+#define	PATHDIV_REG				0xB30
+#define	PATHDIV_TRI				0xBA0
 
 
-/*
+/*@
  * Bitmap Definition
- *   */
+ */
 #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
 	/* TX AGC */
-	#define		REG_TX_AGC_A_CCK_11_CCK_1_JAGUAR	0xc20
-	#define		REG_TX_AGC_A_OFDM18_OFDM6_JAGUAR	0xc24
-	#define		REG_TX_AGC_A_OFDM54_OFDM24_JAGUAR	0xc28
-	#define		REG_TX_AGC_A_MCS3_MCS0_JAGUAR	0xc2c
-	#define		REG_TX_AGC_A_MCS7_MCS4_JAGUAR	0xc30
-	#define		REG_TX_AGC_A_MCS11_MCS8_JAGUAR	0xc34
-	#define		REG_TX_AGC_A_MCS15_MCS12_JAGUAR	0xc38
+	#define		REG_TX_AGC_A_CCK_11_CCK_1_JAGUAR		0xc20
+	#define		REG_TX_AGC_A_OFDM18_OFDM6_JAGUAR		0xc24
+	#define		REG_TX_AGC_A_OFDM54_OFDM24_JAGUAR		0xc28
+	#define		REG_TX_AGC_A_MCS3_MCS0_JAGUAR			0xc2c
+	#define		REG_TX_AGC_A_MCS7_MCS4_JAGUAR			0xc30
+	#define		REG_TX_AGC_A_MCS11_MCS8_JAGUAR			0xc34
+	#define		REG_TX_AGC_A_MCS15_MCS12_JAGUAR			0xc38
 	#define		REG_TX_AGC_A_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0xc3c
 	#define		REG_TX_AGC_A_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0xc40
 	#define		REG_TX_AGC_A_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0xc44
 	#define		REG_TX_AGC_A_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0xc48
 	#define		REG_TX_AGC_A_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0xc4c
 	#if defined(CONFIG_WLAN_HAL_8814AE)
-		#define		REG_TX_AGC_A_MCS19_MCS16_JAGUAR	0xcd8
-		#define		REG_TX_AGC_A_MCS23_MCS20_JAGUAR	0xcdc
+		#define		REG_TX_AGC_A_MCS19_MCS16_JAGUAR		0xcd8
+		#define		REG_TX_AGC_A_MCS23_MCS20_JAGUAR		0xcdc
 		#define		REG_TX_AGC_A_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0xce0
 		#define		REG_TX_AGC_A_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0xce4
 		#define		REG_TX_AGC_A_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0xce8
 	#endif
-	#define		REG_TX_AGC_B_CCK_11_CCK_1_JAGUAR	0xe20
-	#define		REG_TX_AGC_B_OFDM18_OFDM6_JAGUAR	0xe24
-	#define		REG_TX_AGC_B_OFDM54_OFDM24_JAGUAR	0xe28
-	#define		REG_TX_AGC_B_MCS3_MCS0_JAGUAR	0xe2c
-	#define		REG_TX_AGC_B_MCS7_MCS4_JAGUAR	0xe30
-	#define		REG_TX_AGC_B_MCS11_MCS8_JAGUAR	0xe34
-	#define		REG_TX_AGC_B_MCS15_MCS12_JAGUAR	0xe38
+	#define		REG_TX_AGC_B_CCK_11_CCK_1_JAGUAR		0xe20
+	#define		REG_TX_AGC_B_OFDM18_OFDM6_JAGUAR		0xe24
+	#define		REG_TX_AGC_B_OFDM54_OFDM24_JAGUAR		0xe28
+	#define		REG_TX_AGC_B_MCS3_MCS0_JAGUAR			0xe2c
+	#define		REG_TX_AGC_B_MCS7_MCS4_JAGUAR			0xe30
+	#define		REG_TX_AGC_B_MCS11_MCS8_JAGUAR			0xe34
+	#define		REG_TX_AGC_B_MCS15_MCS12_JAGUAR			0xe38
 	#define		REG_TX_AGC_B_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0xe3c
 	#define		REG_TX_AGC_B_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0xe40
 	#define		REG_TX_AGC_B_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0xe44
 	#define		REG_TX_AGC_B_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0xe48
 	#define		REG_TX_AGC_B_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0xe4c
 	#if defined(CONFIG_WLAN_HAL_8814AE)
-		#define		REG_TX_AGC_B_MCS19_MCS16_JAGUAR	0xed8
-		#define		REG_TX_AGC_B_MCS23_MCS20_JAGUAR	0xedc
+		#define		REG_TX_AGC_B_MCS19_MCS16_JAGUAR		0xed8
+		#define		REG_TX_AGC_B_MCS23_MCS20_JAGUAR		0xedc
 		#define		REG_TX_AGC_B_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0xee0
 		#define		REG_TX_AGC_B_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0xee4
 		#define		REG_TX_AGC_B_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0xee8
 		#define		REG_TX_AGC_C_CCK_11_CCK_1_JAGUAR	0x1820
 		#define		REG_TX_AGC_C_OFDM18_OFDM6_JAGUAR	0x1824
 		#define		REG_TX_AGC_C_OFDM54_OFDM24_JAGUAR	0x1828
-		#define		REG_TX_AGC_C_MCS3_MCS0_JAGUAR	0x182c
-		#define		REG_TX_AGC_C_MCS7_MCS4_JAGUAR	0x1830
-		#define		REG_TX_AGC_C_MCS11_MCS8_JAGUAR	0x1834
-		#define		REG_TX_AGC_C_MCS15_MCS12_JAGUAR	0x1838
+		#define		REG_TX_AGC_C_MCS3_MCS0_JAGUAR		0x182c
+		#define		REG_TX_AGC_C_MCS7_MCS4_JAGUAR		0x1830
+		#define		REG_TX_AGC_C_MCS11_MCS8_JAGUAR		0x1834
+		#define		REG_TX_AGC_C_MCS15_MCS12_JAGUAR		0x1838
 		#define		REG_TX_AGC_C_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0x183c
 		#define		REG_TX_AGC_C_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0x1840
 		#define		REG_TX_AGC_C_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0x1844
 		#define		REG_TX_AGC_C_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0x1848
 		#define		REG_TX_AGC_C_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0x184c
-		#define		REG_TX_AGC_C_MCS19_MCS16_JAGUAR	0x18d8
-		#define		REG_TX_AGC_C_MCS23_MCS20_JAGUAR	0x18dc
+		#define		REG_TX_AGC_C_MCS19_MCS16_JAGUAR		0x18d8
+		#define		REG_TX_AGC_C_MCS23_MCS20_JAGUAR		0x18dc
 		#define		REG_TX_AGC_C_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0x18e0
 		#define		REG_TX_AGC_C_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0x18e4
 		#define		REG_TX_AGC_C_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0x18e8
 		#define		REG_TX_AGC_D_CCK_11_CCK_1_JAGUAR	0x1a20
 		#define		REG_TX_AGC_D_OFDM18_OFDM6_JAGUAR	0x1a24
 		#define		REG_TX_AGC_D_OFDM54_OFDM24_JAGUAR	0x1a28
-		#define		REG_TX_AGC_D_MCS3_MCS0_JAGUAR	0x1a2c
-		#define		REG_TX_AGC_D_MCS7_MCS4_JAGUAR	0x1a30
-		#define		REG_TX_AGC_D_MCS11_MCS8_JAGUAR	0x1a34
-		#define		REG_TX_AGC_D_MCS15_MCS12_JAGUAR	0x1a38
+		#define		REG_TX_AGC_D_MCS3_MCS0_JAGUAR		0x1a2c
+		#define		REG_TX_AGC_D_MCS7_MCS4_JAGUAR		0x1a30
+		#define		REG_TX_AGC_D_MCS11_MCS8_JAGUAR		0x1a34
+		#define		REG_TX_AGC_D_MCS15_MCS12_JAGUAR		0x1a38
 		#define		REG_TX_AGC_D_NSS1_INDEX3_NSS1_INDEX0_JAGUAR	0x1a3c
 		#define		REG_TX_AGC_D_NSS1_INDEX7_NSS1_INDEX4_JAGUAR	0x1a40
 		#define		REG_TX_AGC_D_NSS2_INDEX1_NSS1_INDEX8_JAGUAR	0x1a44
 		#define		REG_TX_AGC_D_NSS2_INDEX5_NSS2_INDEX2_JAGUAR	0x1a48
 		#define		REG_TX_AGC_D_NSS2_INDEX9_NSS2_INDEX6_JAGUAR	0x1a4c
-		#define		REG_TX_AGC_D_MCS19_MCS16_JAGUAR	0x1ad8
-		#define		REG_TX_AGC_D_MCS23_MCS20_JAGUAR	0x1adc
+		#define		REG_TX_AGC_D_MCS19_MCS16_JAGUAR		0x1ad8
+		#define		REG_TX_AGC_D_MCS23_MCS20_JAGUAR		0x1adc
 		#define		REG_TX_AGC_D_NSS3_INDEX3_NSS3_INDEX0_JAGUAR	0x1ae0
 		#define		REG_TX_AGC_D_NSS3_INDEX7_NSS3_INDEX4_JAGUAR	0x1ae4
 		#define		REG_TX_AGC_D_NSS3_INDEX9_NSS3_INDEX8_JAGUAR	0x1ae8
@@ -200,25 +212,31 @@
 	#define		is_tx_agc_byte1_jaguar	0xff00
 	#define		is_tx_agc_byte2_jaguar	0xff0000
 	#define		is_tx_agc_byte3_jaguar	0xff000000
+	#if defined(CONFIG_WLAN_HAL_8198F) || defined(CONFIG_WLAN_HAL_8822CE)
+		#define REG_TX_AGC_CCK_11_CCK_1_JAGUAR3		0x3a00
+		#define REG_TX_AGC_OFDM_18_CCK_6_JAGUAR3	0x3a04
+		#define	REG_TX_AGC_OFDM_54_CCK_24_JAGUAR3	0x3a08
+		#define	REG_TX_AGC_MCS3_0_JAGUAR3		0x3a0c
+		#define	REG_TX_AGC_MCS7_4_JAGUAR3		0x3a10
+		#define	REG_TX_AGC_MCS11_8_JAGUAR3		0x3a14
+		#define	REG_TX_AGC_MCS15_12_JAGUAR3		0x3a18
+		#define	REG_TX_AGC_MCS19_16_JAGUAR3		0x3a1c
+		#define	REG_TX_AGC_MCS23_20_JAGUAR3		0x3a20
+		#define	REG_TX_AGC_MCS27_24_JAGUAR3		0x3a24
+		#define	REG_TX_AGC_MCS31_28_JAGUAR3		0x3a28
+		#define	REG_TX_AGC_VHT_Nss1_MCS3_0_JAGUAR3	0x3a2c
+		#define	REG_TX_AGC_VHT_Nss1_MCS7_4_JAGUAR3	0x3a30
+		#define	REG_TX_AGC_VHT_NSS2_MCS1_NSS1_MCS8_JAGUAR3	0x3a34
+		#define	REG_TX_AGC_VHT_Nss2_MCS5_2_JAGUAR3	0x3a38
+		#define	REG_TX_AGC_VHT_Nss2_MCS9_6_JAGUAR3	0x3a3c
+		#define	REG_TX_AGC_VHT_Nss3_MCS3_0_JAGUAR3	0x3a40
+		#define	REG_TX_AGC_VHT_Nss3_MCS7_4_JAGUAR3	0x3a44
+		#define	REG_TX_AGC_VHT_Nss4_MCS1_Nss3_MCS8_JAGUAR3	0x3a48
+		#define	REG_TX_AGC_VHT_Nss4_MCS5_2_JAGUAR3	0x3a4c
+		#define	REG_TX_AGC_VHT_Nss4_MCS9_6_JAGUAR3	0x3a50
+	#endif
 #endif
 
 #define	BIT_FA_RESET					BIT(0)
 
-#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
-	#define REG_OFDM_0_XA_TX_IQ_IMBALANCE	0xC80
-	#define REG_OFDM_0_ECCA_THRESHOLD	0xC4C
-	#define REG_FPGA0_XB_LSSI_READ_BACK	0x8A4
-	#define REG_FPGA0_TX_GAIN_STAGE		0x80C
-	#define REG_OFDM_0_XA_AGC_CORE1		0xC50
-	#define REG_OFDM_0_XB_AGC_CORE1		0xC58
-	#define REG_A_TX_SCALE_JAGUAR		0xC1C
-	#define REG_B_TX_SCALE_JAGUAR		0xE1C
-
-	#define REG_AFE_XTAL_CTRL		0x0024
-	#define REG_AFE_PLL_CTRL		0x0028
-	#define REG_MAC_PHY_CTRL		0x002C
-
-	#define RF_CHNLBW			0x18
-#endif
-
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11ac.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11ac.h
index 40a9b7fbed91..93fbe3c78a15 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11ac.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11ac.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,81 +9,102 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__ODM_REGDEFINE11AC_H__
+#ifndef __ODM_REGDEFINE11AC_H__
 #define __ODM_REGDEFINE11AC_H__
 
-/* 2 RF REG LIST */
+/* @2 RF REG LIST */
 
 
 
-/* 2 BB REG LIST
- * PAGE 8 */
-#define	ODM_REG_CCK_RPT_FORMAT_11AC	0x804
+/* @2 BB REG LIST */
+/* PAGE 8 */
+#define	ODM_REG_CCK_RPT_FORMAT_11AC		0x804
 #define	ODM_REG_BB_RX_PATH_11AC			0x808
 #define	ODM_REG_BB_TX_PATH_11AC			0x80c
-#define	ODM_REG_BB_ATC_11AC				0x860
-#define	ODM_REG_EDCCA_POWER_CAL		0x8dc
+#define	ODM_REG_BB_ATC_11AC			0x860
+#define	ODM_REG_EDCCA_POWER_CAL			0x8dc
 #define	ODM_REG_DBG_RPT_11AC			0x8fc
 /* PAGE 9 */
 #define	ODM_REG_EDCCA_DOWN_OPT			0x900
 #define	ODM_REG_ACBB_EDCCA_ENHANCE		0x944
-#define	odm_adc_trigger_jaguar2			0x95C	/*ADC sample mode*/
+#define	odm_adc_trigger_jaguar2			0x95C	/*@ADC sample mode*/
 #define	ODM_REG_OFDM_FA_RST_11AC		0x9A4
 #define	ODM_REG_CCX_PERIOD_11AC			0x990
 #define	ODM_REG_NHM_TH9_TH10_11AC		0x994
-#define	ODM_REG_CLM_11AC					0x994
-#define	ODM_REG_NHM_TH3_TO_TH0_11AC	0x998
-#define	ODM_REG_NHM_TH7_TO_TH4_11AC	0x99c
+#define	ODM_REG_CLM_11AC			0x994
+#define	ODM_REG_NHM_TH3_TO_TH0_11AC		0x998
+#define	ODM_REG_NHM_TH7_TO_TH4_11AC		0x99c
 #define	ODM_REG_NHM_TH8_11AC			0x9a0
 #define	ODM_REG_NHM_9E8_11AC			0x9e8
 #define	ODM_REG_CSI_CONTENT_VALUE		0x9b4
 /* PAGE A */
 #define	ODM_REG_CCK_CCA_11AC			0xA0A
 #define	ODM_REG_CCK_FA_RST_11AC			0xA2C
-#define	ODM_REG_CCK_FA_11AC				0xA5C
+#define	ODM_REG_CCK_FA_11AC			0xA5C
 /* PAGE B */
-#define	ODM_REG_RST_RPT_11AC				0xB58
+#define	ODM_REG_RST_RPT_11AC			0xB58
 /* PAGE C */
-#define	ODM_REG_TRMUX_11AC				0xC08
-#define	ODM_REG_IGI_A_11AC				0xC50
+#define	ODM_REG_TRMUX_11AC			0xC08
+#define	ODM_REG_IGI_A_11AC			0xC50
 /* PAGE E */
-#define	ODM_REG_IGI_B_11AC				0xE50
-#define	ODM_REG_TRMUX_11AC_B			0xE08
+#define	ODM_REG_IGI_B_11AC			0xE50
+#define	ODM_REG_ANT_11AC_B			0xE08
 /* PAGE F */
 #define	ODM_REG_CCK_CRC32_CNT_11AC		0xF04
 #define	ODM_REG_CCK_CCA_CNT_11AC		0xF08
 #define	ODM_REG_VHT_CRC32_CNT_11AC		0xF0c
 #define	ODM_REG_HT_CRC32_CNT_11AC		0xF10
-#define	ODM_REG_OFDM_CRC32_CNT_11AC	0xF14
+#define	ODM_REG_OFDM_CRC32_CNT_11AC		0xF14
 #define	ODM_REG_OFDM_FA_11AC			0xF48
-#define	ODM_REG_RPT_11AC					0xfa0
+#define	ODM_REG_OFDM_FA_TYPE1_11AC		0xFCC
+#define	ODM_REG_OFDM_FA_TYPE2_11AC		0xFD0
+#define	ODM_REG_OFDM_FA_TYPE3_11AC		0xFBC
+#define	ODM_REG_OFDM_FA_TYPE4_11AC		0xFC0
+#define	ODM_REG_OFDM_FA_TYPE5_11AC		0xFC4
+#define	ODM_REG_OFDM_FA_TYPE6_11AC		0xFC8
+#define	ODM_REG_RPT_11AC			0xfa0
 #define	ODM_REG_CLM_RESULT_11AC			0xfa4
 #define	ODM_REG_NHM_CNT_11AC			0xfa8
-#define ODM_REG_NHM_DUR_READY_11AC      0xfb4
+#define ODM_REG_NHM_DUR_READY_11AC		0xfb4
 
-#define	ODM_REG_NHM_CNT7_TO_CNT4_11AC   0xfac
-#define	ODM_REG_NHM_CNT11_TO_CNT8_11AC  0xfb0
-#define	ODM_REG_OFDM_FA_TYPE2_11AC		0xFD0
+#define	ODM_REG_NHM_CNT7_TO_CNT4_11AC		0xfac
+#define	ODM_REG_NHM_CNT11_TO_CNT8_11AC		0xfb0
 /* PAGE 18 */
-#define	ODM_REG_IGI_C_11AC				0x1850
+#define	ODM_REG_IGI_C_11AC			0x1850
 /* PAGE 1A */
-#define	ODM_REG_IGI_D_11AC				0x1A50
+#define	ODM_REG_IGI_D_11AC			0x1A50
+
+/* PAGE 1D */
+#define	ODM_REG_IGI_11AC3			0x1D70
 
-/* 2 MAC REG LIST */
-#define	ODM_REG_RESP_TX_11AC				0x6D8
+/* @2 MAC REG LIST */
+#define	ODM_REG_RESP_TX_11AC			0x6D8
 
 
 
-/* DIG Related */
-#define	ODM_BIT_IGI_11AC					0x0000007F
+/* @DIG Related */
+#define	ODM_BIT_IGI_11AC			0x0000007F
+#define	ODM_BIT_IGI_B_11AC3			0x00007F00
+#define	ODM_BIT_IGI_C_11AC3			0x007F0000
+#define	ODM_BIT_IGI_D_11AC3			0x7F000000
 #define	ODM_BIT_CCK_RPT_FORMAT_11AC		BIT(16)
 #define	ODM_BIT_BB_RX_PATH_11AC			0xF
 #define	ODM_BIT_BB_TX_PATH_11AC			0xF
-#define	ODM_BIT_BB_ATC_11AC				BIT(14)
+#define	ODM_BIT_BB_ATC_11AC			BIT(14)
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11n.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11n.h
index 5c24a27c2904..6e358670fe3d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11n.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regdefine11n.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,91 +9,101 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__ODM_REGDEFINE11N_H__
+#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
+/* @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
+/* @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_CCK_RPT_FORMAT_11N_B	0x82C
-#define	ODM_REG_RX_DEFUALT_A_11N		0x858
-#define	ODM_REG_RX_DEFUALT_B_11N		0x85A
+#define	ODM_REG_CCK_RPT_FORMAT_11N_B		0x82C
+#define	ODM_REG_RX_DEFAULT_A_11N		0x858
+#define	ODM_REG_RX_DEFAULT_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_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
+#define	ODM_REG_SC_CNT_11N			0x8C4
+#define	ODM_REG_PSD_DATA_11N			0x8B4
 #define	ODM_REG_CCX_PERIOD_11N			0x894
 #define	ODM_REG_NHM_TH9_TH10_11N		0x890
-#define	ODM_REG_CLM_11N					0x890
+#define	ODM_REG_CLM_11N				0x890
 #define	ODM_REG_NHM_TH3_TO_TH0_11N		0x898
 #define	ODM_REG_NHM_TH7_TO_TH4_11N		0x89c
-#define ODM_REG_NHM_TH8_11N				0xe28
+#define ODM_REG_NHM_TH8_11N			0xe28
 #define	ODM_REG_CLM_READY_11N			0x8b4
 #define	ODM_REG_CLM_RESULT_11N			0x8d0
-#define	ODM_REG_NHM_CNT_11N				0x8d8
+#define	ODM_REG_NHM_CNT_11N			0x8d8
 
-/* For struct _ACS_, Jeffery, 2014-12-26 */
+/* @For struct acs_info, Jeffery, 2014-12-26 */
 #define	ODM_REG_NHM_CNT7_TO_CNT4_11N		0x8dc
 #define	ODM_REG_NHM_CNT9_TO_CNT8_11N		0x8d0
-#define	ODM_REG_NHM_CNT10_TO_CNT11_11N	0x8d4
+#define	ODM_REG_NHM_CNT10_TO_CNT11_11N		0x8d4
 
 /* PAGE 9 */
 #define	ODM_REG_BB_CTRL_PAGE9_11N		0x900
-#define	ODM_REG_DBG_RPT_11N				0x908
+#define	ODM_REG_DBG_RPT_11N			0x908
 #define	ODM_REG_BB_TX_PATH_11N			0x90c
 #define	ODM_REG_ANT_MAPPING1_11N		0x914
 #define	ODM_REG_ANT_MAPPING2_11N		0x918
-#define	ODM_REG_EDCCA_DOWN_OPT_11N	0x948
+#define	ODM_REG_EDCCA_DOWN_OPT_11N		0x948
 #define	ODM_REG_RX_DFIR_MOD_97F			0x948
-#define	ODM_REG_SOML_97F					0x998
+#define	ODM_REG_SOML_97F			0x998
 
 /* PAGE A */
-#define	ODM_REG_CCK_ANTDIV_PARA1_11N	0xA00
+#define	ODM_REG_CCK_ANTDIV_PARA1_11N		0xA00
 #define	ODM_REG_CCK_ANT_SEL_11N			0xA04
-#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_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
@@ -103,60 +114,60 @@
 #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
-#define	ODM_REG_RXCK_RFMOD				0xBB0
+#define	ODM_REG_RSSI_BT_11N			0xB9C
+#define	ODM_REG_RXCK_RFMOD			0xBB0
 #define	ODM_REG_EDCCA_DCNF_97F			0xBC0
 
 /* PAGE C */
 #define	ODM_REG_OFDM_FA_HOLDC_11N		0xC00
 #define	ODM_REG_BB_RX_PATH_11N			0xC04
-#define	ODM_REG_TRMUX_11N				0xC08
+#define	ODM_REG_TRMUX_11N			0xC08
 #define	ODM_REG_OFDM_FA_RSTC_11N		0xC0C
-#define	ODM_REG_DOWNSAM_FACTOR_11N	0xC10
+#define	ODM_REG_DOWNSAM_FACTOR_11N		0xC10
 #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_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_IGI_B_11N			0xC58
 #define	ODM_REG_ANTDIV_PARA3_11N		0xC5C
-#define   ODM_REG_L1SBD_PD_CH_11N			0XC6C
-#define	ODM_REG_BB_PWR_SAV2_11N		0xC70
+#define   ODM_REG_L1SBD_PD_CH_11N		0XC6C
+#define	ODM_REG_BB_PWR_SAV2_11N			0xC70
 #define	ODM_REG_BB_AGC_SET_2_11N		0xc74
-#define	ODM_REG_RX_OFF_11N				0xC7C
+#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_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_SMALL_BANDWIDTH_11N	0xCE4
+#define	ODM_REG_SMALL_BANDWIDTH_11N		0xCE4
 #define	ODM_REG_OFDM_FA_TYPE1_11N		0xCF0
 /* PAGE D */
 #define	ODM_REG_OFDM_FA_RSTD_11N		0xD00
 #define	ODM_REG_BB_RX_ANT_11N			0xD04
-#define	ODM_REG_BB_ATC_11N				0xD2C
+#define	ODM_REG_BB_ATC_11N			0xD2C
 #define	ODM_REG_OFDM_FA_TYPE2_11N		0xDA0
 #define	ODM_REG_OFDM_FA_TYPE3_11N		0xDA4
 #define	ODM_REG_OFDM_FA_TYPE4_11N		0xDA8
-#define	ODM_REG_RPT_11N					0xDF4
+#define	ODM_REG_RPT_11N				0xDF4
 /* 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_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_TXAGC_A_MCS8_11_11N		0xE18
+#define	ODM_REG_TXAGC_A_MCS12_15_11N		0xE1C
 #define	ODM_REG_EDCCA_DCNF_11N			0xE24
-#define	ODM_REG_TAP_UPD_97F				0xE24
+#define	ODM_REG_TAP_UPD_97F			0xE24
 #define	ODM_REG_FPGA0_IQK_11N			0xE28
-#define	ODM_REG_PAGE_B1_97F				0xE28
+#define	ODM_REG_PAGE_B1_97F			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_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
@@ -165,45 +176,45 @@
 #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_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_RX2RX_11N			0xED8
+#define	ODM_REG_STANDBY_11N			0xEDC
+#define	ODM_REG_SLEEP_11N			0xEE0
 #define	ODM_REG_PMPD_ANAEN_11N			0xEEC
 /* PAGE F */
 #define	ODM_REG_PAGE_F_RST_11N			0xF14
-#define	ODM_REG_IGI_C_11N					0xF84
-#define	ODM_REG_IGI_D_11N				0xF88
-#define	ODM_REG_CCK_CRC32_ERROR_CNT_11N	0xF84
+#define	ODM_REG_IGI_C_11N			0xF84
+#define	ODM_REG_IGI_D_11N			0xF88
+#define	ODM_REG_CCK_CRC32_ERROR_CNT_11N		0xF84
 #define	ODM_REG_CCK_CRC32_OK_CNT_11N		0xF88
 #define	ODM_REG_HT_CRC32_CNT_11N		0xF90
 #define	ODM_REG_OFDM_CRC32_CNT_11N		0xF94
-#define	ODM_REG_HT_CRC32_CNT_11N_AGG	0xFB8
+#define	ODM_REG_HT_CRC32_CNT_11N_AGG		0xFB8
 
-/* 2 MAC REG LIST */
-#define	ODM_REG_BB_RST_11N				0x02
+/* @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
+#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
+/* @DIG Related */
+#define	ODM_BIT_IGI_11N				0x0000007F
 #define	ODM_BIT_CCK_RPT_FORMAT_11N		BIT(9)
 #define	ODM_BIT_BB_RX_PATH_11N			0xF
 #define	ODM_BIT_BB_TX_PATH_11N			0xF
-#define	ODM_BIT_BB_ATC_11N				BIT(11)
-
+#define	ODM_BIT_BB_ATC_11N			BIT(11)
 #endif
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regtable.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regtable.h
new file mode 100644
index 000000000000..1e4528d4d465
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_regtable.h
@@ -0,0 +1,850 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+#define R_0x0 0x0
+#define R_0x00 0x00
+#define R_0x0106 0x0106
+#define R_0x0140 0x0140
+#define R_0x0144 0x0144
+#define R_0x0148 0x0148
+#define R_0x040 0x040
+#define R_0x10 0x10
+#define R_0x100 0x100
+#define R_0x1038 0x1038
+#define R_0x103c 0x103c
+#define R_0x1040 0x1040
+#define R_0x1048 0x1048
+#define R_0x1080 0x1080
+#define R_0x14c0 0x14c0
+#define R_0x14c4 0x14c4
+#define R_0x14c8 0x14c8
+#define R_0x14cc 0x14cc
+#define R_0x1518 0x1518
+#define R_0x1684 0x1684
+#define R_0x1688 0x1688
+#define R_0x168c 0x168c
+#define R_0x1700 0x1700
+#define R_0x1704 0x1704
+#define R_0x1800 0x1800
+#define R_0x180c 0x180c
+#define R_0x1830 0x1830
+#define R_0x1834 0x1834
+#define R_0x1838 0x1838
+#define R_0x183c 0x183c
+#define R_0x1840 0x1840
+#define R_0x1844 0x1844
+#define R_0x1848 0x1848
+#define R_0x1860 0x1860
+#define R_0x1864 0x1864
+#define R_0x186c 0x186c
+#define R_0x1870 0x1870
+#define R_0x1884 0x1884
+#define R_0x188c 0x188c
+#define R_0x1894 0x1894
+#define R_0x189c 0x189c
+#define R_0x18a0 0x18a0
+#define R_0x18a4 0x18a4
+#define R_0x18a8 0x18a8
+#define R_0x18ac 0x18ac
+#define R_0x18e0 0x18e0
+#define R_0x18e8 0x18e8
+#define R_0x18ec 0x18ec
+#define R_0x18f0 0x18f0
+#define R_0x18f8 0x18f8
+#define R_0x18fc 0x18fc
+#define R_0x1900 0x1900
+#define R_0x1904 0x1904
+#define R_0x1908 0x1908
+#define R_0x1918 0x1918
+#define R_0x191c 0x191c
+#define R_0x1928 0x1928
+#define R_0x1940 0x1940
+#define R_0x1944 0x1944
+#define R_0x1950 0x1950
+#define R_0x1954 0x1954
+#define R_0x195c 0x195c
+#define R_0x1970 0x1970
+#define R_0x1984 0x1984
+#define R_0x1988 0x1988
+#define R_0x198c 0x198c
+#define R_0x1990 0x1990
+#define R_0x1991 0x1991
+#define R_0x1998 0x1998
+#define R_0x19a8 0x19a8
+#define R_0x19d4 0x19d4
+#define R_0x19d8 0x19d8
+#define R_0x19e0 0x19e0
+#define R_0x19f0 0x19f0
+#define R_0x19f8 0x19f8
+#define R_0x1a00 0x1a00
+#define R_0x1a04 0x1a04
+#define R_0x1a14 0x1a14
+#define R_0x1a20 0x1a20
+#define R_0x1a24 0x1a24
+#define R_0x1a28 0x1a28
+#define R_0x1a2c 0x1a2c
+#define R_0x1a5c 0x1a5c
+#define R_0x1a70 0x1a70
+#define R_0x1a80 0x1a80
+#define R_0x1a84 0x1a84
+#define R_0x1a8c 0x1a8c
+#define R_0x1a94 0x1a94
+#define R_0x1a98 0x1a98
+#define R_0x1a9c 0x1a9c
+#define R_0x1aa0 0x1aa0
+#define R_0x1aac 0x1aac
+#define R_0x1ab0 0x1ab0
+#define R_0x1abc 0x1abc
+#define R_0x1ac0 0x1ac0
+#define R_0x1ac8 0x1ac8
+#define R_0x1acc 0x1acc
+#define R_0x1ad0 0x1ad0
+#define R_0x1ad4 0x1ad4
+#define R_0x1b00 0x1b00
+#define R_0x1b04 0x1b04
+#define R_0x1b08 0x1b08
+#define R_0x1b0c 0x1b0c
+#define R_0x1b20 0x1b20
+#define R_0x1b2c 0x1b2c
+#define R_0x1b34 0x1b34
+#define R_0x1b38 0x1b38
+#define R_0x1b3c 0x1b3c
+#define R_0x1b40 0x1b40
+#define R_0x1b44 0x1b44
+#define R_0x1b48 0x1b48
+#define R_0x1b4c 0x1b4c
+#define R_0x1b50 0x1b50
+#define R_0x1b54 0x1b54
+#define R_0x1b58 0x1b58
+#define R_0x1b5c 0x1b5c
+#define R_0x1b60 0x1b60
+#define R_0x1b64 0x1b64
+#define R_0x1b67 0x1b67
+#define R_0x1b68 0x1b68
+#define R_0x1b6c 0x1b6c
+#define R_0x1b70 0x1b70
+#define R_0x1b74 0x1b74
+#define R_0x1b78 0x1b78
+#define R_0x1b7c 0x1b7c
+#define R_0x1b80 0x1b80
+#define R_0x1b8c 0x1b8c
+#define R_0x1b90 0x1b90
+#define R_0x1b92 0x1b92
+#define R_0x1b94 0x1b94
+#define R_0x1b98 0x1b98
+#define R_0x1b9c 0x1b9c
+#define R_0x1ba0 0x1ba0
+#define R_0x1ba4 0x1ba4
+#define R_0x1ba8 0x1ba8
+#define R_0x1bac 0x1bac
+#define R_0x1bb0 0x1bb0
+#define R_0x1bb4 0x1bb4
+#define R_0x1bb8 0x1bb8
+#define R_0x1bbc 0x1bbc
+#define R_0x1bc8 0x1bc8
+#define R_0x1bcc 0x1bcc
+#define R_0x1bd0 0x1bd0
+#define R_0x1bd4 0x1bd4
+#define R_0x1bd8 0x1bd8
+#define R_0x1bdc 0x1bdc
+#define R_0x1bf0 0x1bf0
+#define R_0x1bfc 0x1bfc
+#define R_0x1c20 0x1c20
+#define R_0x1c24 0x1c24
+#define R_0x1c28 0x1c28
+#define R_0x1c2c 0x1c2c
+#define R_0x1c30 0x1c30
+#define R_0x1c38 0x1c38
+#define R_0x1c3c 0x1c3c
+#define R_0x1c64 0x1c64
+#define R_0x1c68 0x1c68
+#define R_0x1c74 0x1c74
+#define R_0x1c78 0x1c78
+#define R_0x1c7c 0x1c7c
+#define R_0x1c80 0x1c80
+#define R_0x1c90 0x1c90
+#define R_0x1c94 0x1c94
+#define R_0x1c98 0x1c98
+#define R_0x1c9c 0x1c9c
+#define R_0x1ca0 0x1ca0
+#define R_0x1ca4 0x1ca4
+#define R_0x1cb8 0x1cb8
+#define R_0x1cd0 0x1cd0
+#define R_0x1ce4 0x1ce4
+#define R_0x1ce8 0x1ce8
+#define R_0x1cec 0x1cec
+#define R_0x1cf0 0x1cf0
+#define R_0x1cf4 0x1cf4
+#define R_0x1cf8 0x1cf8
+#define R_0x1d04 0x1d04
+#define R_0x1d08 0x1d08
+#define R_0x1d0c 0x1d0c
+#define R_0x1d10 0x1d10
+#define R_0x1d2c 0x1d2c
+#define R_0x1d30 0x1d30
+#define R_0x1d44 0x1d44
+#define R_0x1d48 0x1d48
+#define R_0x1d58 0x1d58
+#define R_0x1d60 0x1d60
+#define R_0x1d6c 0x1d6c
+#define R_0x1d70 0x1d70
+#define R_0x1d94 0x1d94
+#define R_0x1d9c 0x1d9c
+#define R_0x1da4 0x1da4
+#define R_0x1da8 0x1da8
+#define R_0x1e14 0x1e14
+#define R_0x1e18 0x1e18
+#define R_0x1e24 0x1e24
+#define R_0x1e2c 0x1e2c
+#define R_0x1e30 0x1e30
+#define R_0x1e40 0x1e40
+#define R_0x1e44 0x1e44
+#define R_0x1e48 0x1e48
+#define R_0x1e5c 0x1e5c
+#define R_0x1e60 0x1e60
+#define R_0x1e64 0x1e64
+#define R_0x1e68 0x1e68
+#define R_0x1e6c 0x1e6c
+#define R_0x1e70 0x1e70
+#define R_0x1e7c 0x1e7c
+#define R_0x1e88 0x1e88
+#define R_0x1e8c 0x1e8c
+#define R_0x1ea4 0x1ea4
+#define R_0x1eb4 0x1eb4
+#define R_0x1ee8 0x1ee8
+#define R_0x1eec 0x1eec
+#define R_0x1ef0 0x1ef0
+#define R_0x24 0x24
+#define R_0x28 0x28
+#define R_0x2c 0x2c
+#define R_0x2c04 0x2c04
+#define R_0x2c08 0x2c08
+#define R_0x2c0c 0x2c0c
+#define R_0x2c10 0x2c10
+#define R_0x2c14 0x2c14
+#define R_0x2c20 0x2c20
+#define R_0x2c2c 0x2c2c
+#define R_0x2c30 0x2c30
+#define R_0x2c34 0x2c34
+#define R_0x2d00 0x2d00
+#define R_0x2d04 0x2d04
+#define R_0x2d08 0x2d08
+#define R_0x2d0c 0x2d0c
+#define R_0x2d10 0x2d10
+#define R_0x2d20 0x2d20
+#define R_0x2d38 0x2d38
+#define R_0x2d40 0x2d40
+#define R_0x2d44 0x2d44
+#define R_0x2d48 0x2d48
+#define R_0x2d4c 0x2d4c
+#define R_0x2d88 0x2d88
+#define R_0x2d90 0x2d90
+#define R_0x2d9c 0x2d9c
+#define R_0x2db4 0x2db4
+#define R_0x2db8 0x2db8
+#define R_0x2dbc 0x2dbc
+#define R_0x2de0 0x2de0
+#define R_0x2de4 0x2de4
+#define R_0x2de8 0x2de8
+#define R_0x2e00 0x2e00
+#define R_0x2e20 0x2e20
+#define R_0x300 0x300
+#define R_0x38 0x38
+#define R_0x3a00 0x3a00
+#define R_0x3a04 0x3a04
+#define R_0x3a08 0x3a08
+#define R_0x3a0c 0x3a0c
+#define R_0x3a10 0x3a10
+#define R_0x3a14 0x3a14
+#define R_0x3a18 0x3a18
+#define R_0x3a1c 0x3a1c
+#define R_0x3a20 0x3a20
+#define R_0x3a24 0x3a24
+#define R_0x3a28 0x3a28
+#define R_0x3a2c 0x3a2c
+#define R_0x3a30 0x3a30
+#define R_0x3a34 0x3a34
+#define R_0x3a38 0x3a38
+#define R_0x3a3c 0x3a3c
+#define R_0x3a40 0x3a40
+#define R_0x3a44 0x3a44
+#define R_0x3a48 0x3a48
+#define R_0x3a4c 0x3a4c
+#define R_0x3a50 0x3a50               
+#define R_0x3a54 0x3a54
+#define R_0x3a58 0x3a58
+#define R_0x3a5c 0x3a5c
+#define R_0x3a60 0x3a60
+#define R_0x3a64 0x3a64
+#define R_0x3a68 0x3a68
+#define R_0x3a6c 0x3a6c
+#define R_0x3a70 0x3a70
+#define R_0x3a74 0x3a74
+#define R_0x3a78 0x3a78
+#define R_0x3a7c 0x3a7c
+#define R_0x3a80 0x3a80
+#define R_0x3a84 0x3a84
+#define R_0x3a88 0x3a88
+#define R_0x3a8c 0x3a8c
+#define R_0x3a90 0x3a90
+#define R_0x3a94 0x3a94
+#define R_0x3a98 0x3a98
+#define R_0x3a9c 0x3a9c
+#define R_0x3aa0 0x3aa0
+#define R_0x3aa4 0x3aa4
+#define R_0x40 0x40
+#define R_0x4000 0x4000
+#define R_0x4008 0x4008
+#define R_0x4018 0x4018
+#define R_0x401c 0x401c
+#define R_0x4028 0x4028
+#define R_0x4040 0x4040
+#define R_0x4044 0x4044
+#define R_0x4100 0x4100
+#define R_0x410c 0x410c
+#define R_0x4130 0x4130
+#define R_0x4134 0x4134
+#define R_0x4138 0x4138
+#define R_0x413c 0x413c
+#define R_0x4140 0x4140
+#define R_0x4144 0x4144
+#define R_0x4148 0x4148
+#define R_0x4160 0x4160
+#define R_0x4164 0x4164
+#define R_0x416c 0x416c
+#define R_0x419c 0x419c
+#define R_0x41a0 0x41a0
+#define R_0x41a4 0x41a4
+#define R_0x41a8 0x41a8
+#define R_0x41ac 0x41ac
+#define R_0x41e0 0x41e0
+#define R_0x41ec 0x41ec
+#define R_0x41f0 0x41f0
+#define R_0x41f8 0x41f8
+#define R_0x41fc 0x41fc
+#define R_0x42 0x42
+#define R_0x430 0x430
+#define R_0x434 0x434
+#define R_0x44 0x44
+#define R_0x444 0x444
+#define R_0x448 0x448
+#define R_0x450 0x450
+#define R_0x454 0x454
+#define R_0x49c 0x49c
+#define R_0x4a0 0x4a0
+#define R_0x4a4 0x4a4
+#define R_0x4a8 0x4a8
+#define R_0x4c 0x4c
+#define R_0x4c8 0x4c8
+#define R_0x4cc 0x4cc
+#define R_0x5000 0x5000
+#define R_0x5008 0x5008
+#define R_0x5018 0x5018
+#define R_0x501c 0x501c
+#define R_0x5028 0x5028
+#define R_0x5040 0x5040
+#define R_0x5044 0x5044
+#define R_0x5100 0x5100
+#define R_0x5108 0x5108
+#define R_0x5118 0x5118
+#define R_0x511c 0x511c
+#define R_0x5128 0x5128
+#define R_0x5140 0x5140
+#define R_0x5144 0x5144
+#define R_0x520 0x520
+#define R_0x5200 0x5200
+#define R_0x520c 0x520c
+#define R_0x522 0x522
+#define R_0x5230 0x5230
+#define R_0x5238 0x5238
+#define R_0x523c 0x523c
+#define R_0x5240 0x5240
+#define R_0x5244 0x5244
+#define R_0x5248 0x5248
+#define R_0x526c 0x526c
+#define R_0x52a0 0x52a0
+#define R_0x52a4 0x52a4
+#define R_0x52ac 0x52ac
+#define R_0x5300 0x5300
+#define R_0x530c 0x530c
+#define R_0x5330 0x5330
+#define R_0x5338 0x5338
+#define R_0x533c 0x533c
+#define R_0x5340 0x5340
+#define R_0x5344 0x5344
+#define R_0x5348 0x5348
+#define R_0x536c 0x536c
+#define R_0x53a0 0x53a0
+#define R_0x53a4 0x53a4
+#define R_0x53ac 0x53ac
+#define R_0x550 0x550
+#define R_0x551 0x551
+#define R_0x568 0x568
+#define R_0x588 0x588
+#define R_0x60 0x60
+#define R_0x604 0x604
+#define R_0x608 0x608
+#define R_0x60f 0x60f
+#define R_0x64 0x64
+#define R_0x66 0x66
+#define R_0x660 0x660
+#define R_0x668 0x668
+#define R_0x688 0x688
+#define R_0x6a0 0x6a0
+#define R_0x6d8 0x6d8
+#define R_0x6dc 0x6dc
+#define R_0x70 0x70
+#define R_0x74 0x74
+#define R_0x700 0x700
+#define R_0x764 0x764
+#define R_0x7b0 0x7b0
+#define R_0x7b4 0x7b4
+#define R_0x7c0 0x7c0
+#define R_0x7c4 0x7c4
+#define R_0x7c8 0x7c8
+#define R_0x7cc 0x7cc
+#define R_0x7f0 0x7f0
+#define R_0x7f4 0x7f4
+#define R_0x7f8 0x7f8
+#define R_0x7fc 0x7fc
+#define R_0x800 0x800
+#define R_0x804 0x804
+#define R_0x808 0x808
+#define R_0x80c 0x80c
+#define R_0x810 0x810
+#define R_0x814 0x814
+#define R_0x818 0x818
+#define R_0x81c 0x81c
+#define R_0x820 0x820
+#define R_0x824 0x824
+#define R_0x828 0x828
+#define R_0x82c 0x82c
+#define R_0x830 0x830
+#define R_0x834 0x834
+#define R_0x838 0x838
+#define R_0x83c 0x83c
+#define R_0x840 0x840
+#define R_0x844 0x840
+#define R_0x848 0x848
+#define R_0x84c 0x84c
+#define R_0x850 0x850
+#define R_0x854 0x854
+#define R_0x858 0x858
+#define R_0x85c 0x85c
+#define R_0x860 0x860
+#define R_0x864 0x864
+#define R_0x868 0x868
+#define R_0x86c 0x86c
+#define R_0x870 0x870
+#define R_0x874 0x874
+#define R_0x878 0x878
+#define R_0x87c 0x87c
+#define R_0x880 0x880
+#define R_0x884 0x884
+#define R_0x888 0x888
+#define R_0x88c 0x88c
+#define R_0x890 0x890
+#define R_0x894 0x894
+#define R_0x898 0x898
+#define R_0x89c 0x89c
+#define R_0x8a0 0x8a0
+#define R_0x8a4 0x8a4
+#define R_0x8ac 0x8ac
+#define R_0x8b4 0x8b4
+#define R_0x8c0 0x8c0
+#define R_0x8c4 0x8c4
+#define R_0x8c8 0x8c8
+#define R_0x8cc 0x8cc
+#define R_0x8d0 0x8d0
+#define R_0x8d4 0x8d4
+#define R_0x8d8 0x8d8
+#define R_0x8dc 0x8dc
+#define R_0x8f0 0x8f0
+#define R_0x8f8 0x8f8
+#define R_0x8fc 0x8fc
+#define R_0x900 0x900
+#define R_0x908 0x908
+#define R_0x90c 0x90c
+#define R_0x910 0x910
+#define R_0x914 0x914
+#define R_0x918 0x918
+#define R_0x91c 0x91c
+#define R_0x920 0x920
+#define R_0x924 0x924
+#define R_0x92c 0x92c
+#define R_0x930 0x930
+#define R_0x934 0x934
+#define R_0x938 0x938
+#define R_0x93c 0x93c
+#define R_0x940 0x940
+#define R_0x944 0x944
+#define R_0x948 0x948
+#define R_0x94c 0x94c
+#define R_0x950 0x950
+#define R_0x954 0x954
+#define R_0x958 0x958
+#define R_0x95c 0x95c
+#define R_0x960 0x960
+#define R_0x964 0x964
+#define R_0x968 0x968
+#define R_0x970 0x970
+#define R_0x974 0x974
+#define R_0x978 0x978
+#define R_0x97c 0x97c
+#define R_0x98c 0x98c
+#define R_0x990 0x990
+#define R_0x994 0x994
+#define R_0x998 0x998
+#define R_0x99c 0x99c
+#define R_0x9a0 0x9a0
+#define R_0x9a4 0x9a4
+#define R_0x9ac 0x9ac
+#define R_0x9b0 0x9b0
+#define R_0x9b4 0x9b4
+#define R_0x9b8 0x9b8
+#define R_0x9cc 0x9cc
+#define R_0x9d0 0x9d0
+#define R_0x9e4 0x9e4
+#define R_0xa0 0xa0
+#define R_0xa00 0xa00
+#define R_0xa04 0xa04
+#define R_0xa08 0xa08
+#define R_0xa0a 0xa0a
+#define R_0xa0c 0xa0c
+#define R_0xa10 0xa10
+#define R_0xa14 0xa14
+#define R_0xa20 0xa20
+#define R_0xa24 0xa24
+#define R_0xa28 0xa28
+#define R_0xa2c 0xa2c
+#define R_0xa40 0xa40
+#define R_0xa44 0xa44
+#define R_0xa48 0xa48
+#define R_0xa4c 0xa4c
+#define R_0xa50 0xa50
+#define R_0xa54 0xa54
+#define R_0xa58 0xa58
+#define R_0xa68 0xa68
+#define R_0xa70 0xa70
+#define R_0xa74 0xa74
+#define R_0xa78 0xa78
+#define R_0xa8 0xa8
+#define R_0xa80 0xa80
+#define R_0xa84 0xa84
+#define R_0xa98 0xa98
+#define R_0xa9c 0xa9c
+#define R_0xaa8 0xaa8
+#define R_0xaac 0xaac
+#define R_0xab4 0xab4
+#define R_0xabc 0xabc
+#define R_0xac8 0xac8
+#define R_0xacc 0xacc
+#define R_0xad0 0xad0
+#define R_0xb0 0xb0
+#define R_0xb00 0xb00
+#define R_0xb04 0xb04
+#define R_0xb07 0xb07
+#define R_0xb08 0xb08
+#define R_0xb0c 0xb0c
+#define R_0xb10 0xb10
+#define R_0xb14 0xb14
+#define R_0xb18 0xb18
+#define R_0xb1c 0xb1c
+#define R_0xb20 0xb20
+#define R_0xb24 0xb24
+#define R_0xb28 0xb28
+#define R_0xb2b 0xb2b
+#define R_0xb2c 0xb2c
+#define R_0xb30 0xb30
+#define R_0xb34 0xb34
+#define R_0xb38 0xb38
+#define R_0xb3c 0xb3c
+#define R_0xb40 0xb40
+#define R_0xb44 0xb44
+#define R_0xb48 0xb48
+#define R_0xb54 0xb54
+#define R_0xb58 0xb58
+#define R_0xb60 0xb60
+#define R_0xb64 0xb64
+#define R_0xb68 0xb68
+#define R_0xb6a 0xb6a
+#define R_0xb6c 0xb6c
+#define R_0xb6e 0xb6e
+#define R_0xb70 0xb70
+#define R_0xb74 0xb74
+#define R_0xb77 0xb77
+#define R_0xb78 0xb78
+#define R_0xb7c 0xb7c
+#define R_0xb80 0xb80
+#define R_0xb84 0xb84
+#define R_0xb88 0xb88
+#define R_0xb8c 0xb8c
+#define R_0xb90 0xb90
+#define R_0xb94 0xb94
+#define R_0xb98 0xb98
+#define R_0xb9b 0xb9b
+#define R_0xb9c 0xb9c
+#define R_0xba0 0xba0
+#define R_0xba4 0xba4
+#define R_0xba8 0xba8
+#define R_0xbac 0xbac
+#define R_0xbad 0xbad
+#define R_0xbc0 0xbc0
+#define R_0xbc4 0xbc4
+#define R_0xbc8 0xbc8
+#define R_0xbcc 0xbcc
+#define R_0xbd8 0xbd8
+#define R_0xbdc 0xbdc
+#define R_0xbe0 0xbe0
+#define R_0xbe4 0xbe4
+#define R_0xbe8 0xbe8
+#define R_0xbec 0xbec
+#define R_0xbf0 0xbf0
+#define R_0xbf4 0xbf4
+#define R_0xbf8 0xbf8
+#define R_0xc00 0xc00
+#define R_0xc04 0xc04
+#define R_0xc08 0xc08
+#define R_0xc0c 0xc0c
+#define R_0xc10 0xc10
+#define R_0xc14 0xc14
+#define R_0xc18 0xc18
+#define R_0xc1c 0xc1c
+#define R_0xc20 0xc20
+#define R_0xc24 0xc24
+#define R_0xc30 0xc30
+#define R_0xc38 0xc38
+#define R_0xc3c 0xc3c
+#define R_0xc40 0xc40
+#define R_0xc44 0xc44
+#define R_0xc4c 0xc4c
+#define R_0xc50 0xc50
+#define R_0xc54 0xc54
+#define R_0xc58 0xc58
+#define R_0xc5c 0xc5c
+#define R_0xc6c 0xc6c
+#define R_0xc70 0xc70
+#define R_0xc74 0xc74
+#define R_0xc78 0xc78
+#define R_0xc7c 0xc7c
+#define R_0xc80 0xc80
+#define R_0xc84 0xc84
+#define R_0xc88 0xc88
+#define R_0xc8c 0xc8c
+#define R_0xc90 0xc90
+#define R_0xc94 0xc94
+#define R_0xc9c 0xc9c
+#define R_0xca0 0xca0
+#define R_0xca4 0xca4
+#define R_0xca8 0xca8
+#define R_0xcac 0xcac
+#define R_0xcb0 0xcb0
+#define R_0xcb4 0xcb4
+#define R_0xcb8 0xcb8
+#define R_0xcbc 0xcbc
+#define R_0xcbd 0xcbd
+#define R_0xcbe 0xcbe
+#define R_0xcc4 0xcc4
+#define R_0xcc8 0xcc8
+#define R_0xccc 0xccc
+#define R_0xcd0 0xcd0
+#define R_0xcd4 0xcd4
+#define R_0xcd8 0xcd8
+#define R_0xce0 0xce0
+#define R_0xce4 0xce4
+#define R_0xce8 0xce8
+#define R_0xd00 0xd00
+#define R_0xd04 0xd04
+#define R_0xd08 0xd08
+#define R_0xd0c 0xd0c
+#define R_0xd10 0xd10
+#define R_0xd14 0xd14
+#define R_0xd2c 0xd2c
+#define R_0xd30 0xd30
+#define R_0xd40 0xd40
+#define R_0xd44 0xd44
+#define R_0xd48 0xd48
+#define R_0xd4c 0xd4c
+#define R_0xd50 0xd50
+#define R_0xd54 0xd54
+#define R_0xd5c 0xd5c
+#define R_0xd6c 0xd6c
+#define R_0xd7c 0xd7c
+#define R_0xd80 0xd80
+#define R_0xd84 0xd84
+#define R_0xd8c 0xd8c
+#define R_0xd90 0xd90
+#define R_0xd94 0xd94
+#define R_0xdac 0xdac
+#define R_0xdb0 0xdb0
+#define R_0xdb4 0xdb4
+#define R_0xdb8 0xdb8
+#define R_0xdbc 0xdbc
+#define R_0xdcc 0xdcc
+#define R_0xdd0 0xdd0
+#define R_0xdd4 0xdd4
+#define R_0xdd8 0xdd8
+#define R_0xde0 0xde0
+#define R_0xdec 0xdec
+#define R_0xdf4 0xdf4
+#define R_0xe00 0xe00
+#define R_0xe04 0xe04
+#define R_0xe08 0xe08
+#define R_0xe10 0xe10
+#define R_0xe14 0xe14
+#define R_0xe18 0xe18
+#define R_0xe1c 0xe1c
+#define R_0xe20 0xe20
+#define R_0xe24 0xe24
+#define R_0xe28 0xe28
+#define R_0xe30 0xe30
+#define R_0xe34 0xe34
+#define R_0xe38 0xe38
+#define R_0xe3c 0xe3c
+#define R_0xe40 0xe40
+#define R_0xe44 0xe44
+#define R_0xe48 0xe48
+#define R_0xe4c 0xe4c
+#define R_0xe50 0xe50
+#define R_0xe54 0xe54
+#define R_0xe5c 0xe5c
+#define R_0xe64 0xe64
+#define R_0xe6c 0xe6c
+#define R_0xe70 0xe70
+#define R_0xe74 0xe74
+#define R_0xe78 0xe78
+#define R_0xe7c 0xe7c
+#define R_0xe80 0xe80
+#define R_0xe84 0xe84
+#define R_0xe88 0xe88
+#define R_0xe8c 0xe8c
+#define R_0xe90 0xe90
+#define R_0xe94 0xe94
+#define R_0xe98 0xe98
+#define R_0xe9c 0xe9c
+#define R_0xea0 0xea0
+#define R_0xea4 0xea4
+#define R_0xea8 0xea8
+#define R_0xeac 0xeac
+#define R_0xeb0 0xeb0
+#define R_0xeb4 0xeb4
+#define R_0xeb8 0xeb8
+#define R_0xebc 0xebc
+#define R_0xec0 0xec0
+#define R_0xec4 0xec4
+#define R_0xec8 0xec8
+#define R_0xecc 0xecc
+#define R_0xed0 0xed0
+#define R_0xed4 0xed4
+#define R_0xed8 0xed8
+#define R_0xedc 0xedc
+#define R_0xee0 0xee0
+#define R_0xee8 0xee8
+#define R_0xeec 0xeec
+#define R_0xf0 0xf0
+#define R_0xf00 0xf00
+#define R_0xf04 0xf04
+#define R_0xf08 0xf08
+#define R_0xf0c 0xf0c
+#define R_0xf10 0xf10
+#define R_0xf14 0xf14
+#define R_0xf20 0xf20
+#define R_0xf2c 0xf2c
+#define R_0xf30 0xf30
+#define R_0xf34 0xf34
+#define R_0xf4 0xf4
+#define R_0xf44 0xf44
+#define R_0xf48 0xf48
+#define R_0xf4c 0xf4c
+#define R_0xf50 0xf50
+#define R_0xf54 0xf54
+#define R_0xf58 0xf58
+#define R_0xf5c 0xf5c
+#define R_0xf70 0xf70
+#define R_0xf74 0xf74
+#define R_0xf80 0xf80
+#define R_0xf84 0xf84
+#define R_0xf87 0xf87
+#define R_0xf88 0xf88
+#define R_0xf8c 0xf8c
+#define R_0xf90 0xf90
+#define R_0xf94 0xf94
+#define R_0xf98 0xf98
+#define R_0xfa0 0xfa0
+#define R_0xfa4 0xfa4
+#define R_0xfa8 0xfa8
+#define R_0xfac 0xfac
+#define R_0xfb0 0xfb0
+#define R_0xfb4 0xfb4
+#define R_0xfb8 0xfb8
+#define R_0xfbc 0xfbc
+#define R_0xfc0 0xfc0
+#define R_0xfc4 0xfc4
+#define R_0xfc8 0xfc8
+#define R_0xfcc 0xfcc
+#define R_0xfd0 0xfd0
+#define R_0xff0 0xff0
+#define RF_0x0 0x0
+#define RF_0x00 0x00
+#define RF_0x08 0x08
+#define RF_0x0c 0x0c
+#define RF_0x0d 0x0d
+#define RF_0x1 0x1
+#define RF_0x18 0x18
+#define RF_0x1a 0x1a
+#define RF_0x1bf0 0x1bf0
+#define RF_0x2 0x2
+#define RF_0x3 0x3
+#define RF_0x30 0x30
+#define RF_0x31 0x31
+#define RF_0x32 0x32
+#define RF_0x33 0x33
+#define RF_0x35 0x35
+#define RF_0x3e 0x3e
+#define RF_0x3f 0x3f
+#define RF_0x4 0x4
+#define RF_0x42 0x42
+#define RF_0x43 0x43
+#define RF_0x51 0x51
+#define RF_0x52 0x52
+#define RF_0x54 0x54
+#define RF_0x55 0x55
+#define RF_0x56 0x56
+#define RF_0x58 0x58
+#define RF_0x5c 0x5c
+#define RF_0x61 0x61
+#define RF_0x63 0x63
+#define RF_0x64 0x64
+#define RF_0x65 0x65
+#define RF_0x66 0x66
+#define RF_0x67 0x67
+#define RF_0x75 0x75
+#define RF_0x76 0x76
+#define RF_0x78 0x78
+#define RF_0x7f 0x7f
+#define RF_0x8 0x8
+#define RF_0x80 0x80
+#define RF_0x81 0x81
+#define RF_0x86 0x86
+#define RF_0x87 0x87
+#define RF_0x8a 0x8a
+#define RF_0x8d 0x8d
+#define RF_0x8f 0x8f
+#define RF_0xa9 0xa9
+#define RF_0xae 0xae
+#define RF_0xb0 0xb0
+#define RF_0xb3 0xb3
+#define RF_0xb4 0xb4
+#define RF_0xb8 0xb8
+#define RF_0xbc 0xbc
+#define RF_0xbe 0xbe
+#define RF_0xc4 0xc4
+#define RF_0xc9 0xc9
+#define RF_0xca 0xca
+#define RF_0xcc 0xcc
+#define RF_0xd 0xd
+#define RF_0xdd 0xdd
+#define RF_0xde 0xde
+#define RF_0xdf 0xdf
+#define RF_0xed 0xed
+#define RF_0xee 0xee
+#define RF_0xef 0xef
+#define RF_0xf5 0xf5
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.c
index 1a1f6b01751a..6d59135fb1a4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,452 +9,163 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*@************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
- 
+
 #ifdef PHYDM_SUPPORT_RSSI_MONITOR
 
-#ifdef PHYDM_3RD_REFORM_RSSI_MONOTOR
-void
-phydm_rssi_monitor_h2c(
-	void	*p_dm_void,
-	u8	macid
-)
+void phydm_rssi_monitor_h2c(void *dm_void, u8 macid)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_	*p_ra_t = &p_dm->dm_ra_table;
-	struct cmn_sta_info			*p_sta = p_dm->p_phydm_sta_info[macid];
-	struct ra_sta_info				*p_ra = NULL;
-	u8		h2c_val[H2C_MAX_LENGTH] = {0};
-	u8		stbc_en, ldpc_en;
-	u8		bf_en = 0;
-	u8		is_rx, is_tx;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_t = &dm->dm_ra_table;
+	struct cmn_sta_info *sta = dm->phydm_sta_info[macid];
+	struct ra_sta_info *ra = NULL;
+	#ifdef CONFIG_BEAMFORMING
+	struct bf_cmn_info *bf = NULL;
+	#endif
+	u8 h2c[H2C_MAX_LENGTH] = {0};
+	u8 stbc_en, ldpc_en;
+	u8 bf_en = 0;
+	u8 is_rx, is_tx;
 
-	if (is_sta_active(p_sta)) {
-		p_ra = &(p_sta->ra_info);
+	if (is_sta_active(sta)) {
+		ra = &sta->ra_info;
 	} else {
-		PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("[Warning] %s invalid sta_info\n", __func__));
+		PHYDM_DBG(dm, DBG_RSSI_MNTR, "[Warning] %s\n", __func__);
 		return;
 	}
-	
-	PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("%s ======>\n", __func__));
-	PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("MACID=%d\n", p_sta->mac_id));
 
-	is_rx = (p_ra->txrx_state == RX_STATE) ? 1 : 0;
-	is_tx = (p_ra->txrx_state == TX_STATE) ? 1 : 0;
-	stbc_en = (p_sta->stbc_en) ? 1 : 0;
-	ldpc_en = (p_sta->ldpc_en) ? 1 : 0;
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "MACID=%d\n", sta->mac_id);
+
+	is_rx = (ra->txrx_state == RX_STATE) ? 1 : 0;
+	is_tx = (ra->txrx_state == TX_STATE) ? 1 : 0;
+	stbc_en = (sta->stbc_en) ? 1 : 0;
+	ldpc_en = (sta->ldpc_en) ? 1 : 0;
 
 	#ifdef CONFIG_BEAMFORMING
-	if ((p_sta->bf_info.ht_beamform_cap & BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
-		(p_sta->bf_info.vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) {
+	bf = &sta->bf_info;
+
+	if ((bf->ht_beamform_cap & BEAMFORMING_HT_BEAMFORMEE_ENABLE) ||
+	    (bf->vht_beamform_cap & BEAMFORMING_VHT_BEAMFORMEE_ENABLE))
 		bf_en = 1;
-	}
 	#endif
 
-	if (p_ra_t->RA_threshold_offset != 0) {
-		PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("RA_th_ofst = (( %s%d ))\n",
-			((p_ra_t->RA_offset_direction) ? "+" : "-"), p_ra_t->RA_threshold_offset));
-	}
-
-	h2c_val[0] = p_sta->mac_id;
-	h2c_val[1] = 0;
-	h2c_val[2] = p_sta->rssi_stat.rssi;
-	h2c_val[3] = is_rx | (stbc_en << 1) | ((p_dm->noisy_decision & 0x1) << 2) |  (bf_en << 6);
-	h2c_val[4] = (p_ra_t->RA_threshold_offset & 0x7f) | ((p_ra_t->RA_offset_direction & 0x1) << 7);
-	h2c_val[5] = 0;
-	h2c_val[6] = 0;
-
-	PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("PHYDM h2c[0x42]=0x%x %x %x %x %x %x %x\n",
-		h2c_val[6], h2c_val[5], h2c_val[4], h2c_val[3], h2c_val[2], h2c_val[1], h2c_val[0]));
-
-	#if (RTL8188E_SUPPORT == 1)
-	if (p_dm->support_ic_type == ODM_RTL8188E)
-		odm_ra_set_rssi_8188e(p_dm, (u8)(p_sta->mac_id & 0xFF), p_sta->rssi_stat.rssi & 0x7F);
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "RA_th_ofst=(( %s%d ))\n",
+		  ((ra_t->ra_ofst_direc) ? "+" : "-"), ra_t->ra_th_ofst);
+
+	h2c[0] = sta->mac_id;
+	h2c[1] = 0;
+	h2c[2] = sta->rssi_stat.rssi;
+	h2c[3] = is_rx | (stbc_en << 1) |
+		     ((dm->noisy_decision & 0x1) << 2) | (bf_en << 6);
+	h2c[4] = (ra_t->ra_th_ofst & 0x7f) |
+		     ((ra_t->ra_ofst_direc & 0x1) << 7);
+	h2c[5] = 0;
+	h2c[6] = 0;
+
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "PHYDM h2c[0x42]=0x%x %x %x %x %x %x %x\n",
+		  h2c[6], h2c[5], h2c[4], h2c[3], h2c[2], h2c[1], h2c[0]);
+
+	#if (RTL8188E_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8188E)
+		odm_ra_set_rssi_8188e(dm, sta->mac_id, sta->rssi_stat.rssi);
 	else
-	#endif 
+	#endif
 	{
-		odm_fill_h2c_cmd(p_dm, ODM_H2C_RSSI_REPORT, H2C_MAX_LENGTH, h2c_val);
+		odm_fill_h2c_cmd(dm, ODM_H2C_RSSI_REPORT, H2C_MAX_LENGTH, h2c);
 	}
 }
 
-void
-phydm_calculate_rssi_min_max(
-	void		*p_dm_void
-)
+void phydm_calculate_rssi_min_max(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct cmn_sta_info		*p_sta;
-	s8	rssi_max_tmp = 0, rssi_min_tmp = 100;
-	u8	i;
-	u8	sta_cnt = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct cmn_sta_info *sta;
+	s8 rssi_max_tmp = 0, rssi_min_tmp = 100;
+	u8 i;
+	u8 sta_cnt = 0;
 
-	if (!p_dm->is_linked)
+	if (!dm->is_linked)
 		return;
 
-	PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("%s ======>\n", __func__));
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
 
 	for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-		p_sta = p_dm->p_phydm_sta_info[i];
-		if (is_sta_active(p_sta)) {
-
+		sta = dm->phydm_sta_info[i];
+		if (is_sta_active(sta)) {
 			sta_cnt++;
 
-			if (p_sta->rssi_stat.rssi < rssi_min_tmp)
-				rssi_min_tmp = p_sta->rssi_stat.rssi;
-
-			if (p_sta->rssi_stat.rssi > rssi_max_tmp)
-				rssi_max_tmp = p_sta->rssi_stat.rssi;
-
-			/*[Send RSSI to FW]*/
-			if (p_sta->ra_info.disable_ra == false)
-				phydm_rssi_monitor_h2c(p_dm, i);
-
-			if (sta_cnt == p_dm->number_linked_client)
-				break;
-		}
-	}
-
-	p_dm->rssi_max = (u8)rssi_max_tmp;
-	p_dm->rssi_min = (u8)rssi_min_tmp;
-
-}
-#endif
-
-
-#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-
-s32
-phydm_find_minimum_rssi(
-	struct PHY_DM_STRUCT	*p_dm,
-	struct _ADAPTER			*p_adapter,
-	boolean					*p_is_link_temp
-
-)
-{
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	PMGNT_INFO		p_mgnt_info = &(p_adapter->MgntInfo);
-	boolean			act_as_ap = ACTING_AS_AP(p_adapter);
-
-	/* 1.Determine the minimum RSSI */
-	if ((!p_mgnt_info->bMediaConnect) ||
-	    (act_as_ap && (p_hal_data->EntryMinUndecoratedSmoothedPWDB == 0))) {/* We should check AP mode and Entry info.into consideration, revised by Roger, 2013.10.18*/
-
-		p_hal_data->MinUndecoratedPWDBForDM = 0;
-		*p_is_link_temp = false;
-
-	} else
-		*p_is_link_temp = true;
-
-
-	if (p_mgnt_info->bMediaConnect) {	/* Default port*/
-
-		if (act_as_ap || p_mgnt_info->mIbss) {
-			p_hal_data->MinUndecoratedPWDBForDM = p_hal_data->EntryMinUndecoratedSmoothedPWDB;
-			/**/
-		} else {
-			p_hal_data->MinUndecoratedPWDBForDM = p_hal_data->UndecoratedSmoothedPWDB;
-			/**/
-		}
-	} else { /* associated entry pwdb*/
-		p_hal_data->MinUndecoratedPWDBForDM = p_hal_data->EntryMinUndecoratedSmoothedPWDB;
-		/**/
-	}
-
-	return p_hal_data->MinUndecoratedPWDBForDM;
-}
-
-void
-odm_rssi_monitor_check_mp(
-	void	*p_dm_void
-)
-{
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_			*p_ra_table = &p_dm->dm_ra_table;
-	u8			h2c_parameter[H2C_0X42_LENGTH] = {0};
-	u32			i;
-	boolean			is_ext_ra_info = true;
-	u8			cmdlen = H2C_0X42_LENGTH;
-	u8			tx_bf_en = 0, stbc_en = 0;
-
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct sta_info		*p_entry = NULL;
-	s32			tmp_entry_max_pwdb = 0, tmp_entry_min_pwdb = 0xff;
-	PMGNT_INFO		p_mgnt_info = &adapter->MgntInfo;
-	PMGNT_INFO		p_default_mgnt_info = &adapter->MgntInfo;
-	u64			cur_tx_ok_cnt = 0, cur_rx_ok_cnt = 0;
-#if (BEAMFORMING_SUPPORT == 1)
-#ifndef BEAMFORMING_VERSION_1
-	enum beamforming_cap beamform_cap = BEAMFORMING_CAP_NONE;
-#endif
-#endif
-	struct _ADAPTER	*p_loop_adapter = GetDefaultAdapter(adapter);
-
-	if (p_dm->support_ic_type == ODM_RTL8188E) {
-		is_ext_ra_info = false;
-		cmdlen = 3;
-	}
-
-	while (p_loop_adapter) {
-
-		if (p_loop_adapter != NULL) {
-			p_mgnt_info = &p_loop_adapter->MgntInfo;
-			cur_tx_ok_cnt = p_loop_adapter->TxStats.NumTxBytesUnicast - p_mgnt_info->lastTxOkCnt;
-			cur_rx_ok_cnt = p_loop_adapter->RxStats.NumRxBytesUnicast - p_mgnt_info->lastRxOkCnt;
-			p_mgnt_info->lastTxOkCnt = cur_tx_ok_cnt;
-			p_mgnt_info->lastRxOkCnt = cur_rx_ok_cnt;
-		}
-
-		for (i = 0; i < ASSOCIATE_ENTRY_NUM; i++) {
-
-			if (IsAPModeExist(p_loop_adapter)) {
-				if (GetFirstExtAdapter(p_loop_adapter) != NULL &&
-				    GetFirstExtAdapter(p_loop_adapter) == p_loop_adapter)
-				p_entry = AsocEntry_EnumStation(p_loop_adapter, i);
-				else if (GetFirstGOPort(p_loop_adapter) != NULL &&
-					 IsFirstGoAdapter(p_loop_adapter))
-				p_entry = AsocEntry_EnumStation(p_loop_adapter, i);
-			} else {
-				if (GetDefaultAdapter(p_loop_adapter) == p_loop_adapter)
-					p_entry = AsocEntry_EnumStation(p_loop_adapter, i);
+			if (sta->rssi_stat.rssi < rssi_min_tmp) {
+				rssi_min_tmp = sta->rssi_stat.rssi;
+				dm->rssi_min_macid = i;
 			}
 
-			if (p_entry != NULL) {
-				if (p_entry->bAssociated) {
-
-					RT_DISP_ADDR(FDM, DM_PWDB, ("p_entry->mac_addr ="), GET_STA_INFO(p_entry).mac_addr);
-					RT_DISP(FDM, DM_PWDB, ("p_entry->rssi = 0x%x(%d)\n",
-						GET_STA_INFO(p_entry).rssi_stat.rssi, GET_STA_INFO(p_entry).rssi_stat.rssi));
-
-					/* 2 BF_en */
-#if (BEAMFORMING_SUPPORT == 1)
-#ifndef BEAMFORMING_VERSION_1
-					beamform_cap = phydm_beamforming_get_entry_beam_cap_by_mac_id(p_dm, GET_STA_INFO(p_entry).mac_id);
-					if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
-						tx_bf_en = 1;
-#else
-					if (Beamform_GetSupportBeamformerCap(GetDefaultAdapter(adapter), p_entry))
-						tx_bf_en = 1;
-#endif
-#endif
-					/* 2 STBC_en */
-					if ((IS_WIRELESS_MODE_AC(adapter) && TEST_FLAG(p_entry->VHTInfo.STBC, STBC_VHT_ENABLE_TX)) ||
-						TEST_FLAG(p_entry->HTInfo.STBC, STBC_HT_ENABLE_TX))
-						stbc_en = 1;
-
-					if (GET_STA_INFO(p_entry).rssi_stat.rssi < tmp_entry_min_pwdb)
-						tmp_entry_min_pwdb = GET_STA_INFO(p_entry).rssi_stat.rssi;
-					if (GET_STA_INFO(p_entry).rssi_stat.rssi > tmp_entry_max_pwdb)
-						tmp_entry_max_pwdb = GET_STA_INFO(p_entry).rssi_stat.rssi;
-
-					h2c_parameter[4] = (p_ra_table->RA_threshold_offset & 0x7f) | (p_ra_table->RA_offset_direction << 7);
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("RA_threshold_offset = (( %s%d ))\n", ((p_ra_table->RA_threshold_offset == 0) ? " " : ((p_ra_table->RA_offset_direction) ? "+" : "-")), p_ra_table->RA_threshold_offset));
-
-					if (is_ext_ra_info) {
-						if (cur_rx_ok_cnt > (cur_tx_ok_cnt * 6))
-							h2c_parameter[3] |= RAINFO_BE_RX_STATE;
-
-						if (tx_bf_en)
-							h2c_parameter[3] |= RAINFO_BF_STATE;
-						else {
-							if (stbc_en)
-								h2c_parameter[3] |= RAINFO_STBC_STATE;
-						}
-
-						if (p_dm->noisy_decision)
-							h2c_parameter[3] |= RAINFO_NOISY_STATE;
-						else
-							h2c_parameter[3] &= (~RAINFO_NOISY_STATE);
-
-						if (p_dm->h2c_rarpt_connect) {
-							h2c_parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
-							PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("h2c_rarpt_connect = (( %d ))\n", p_dm->h2c_rarpt_connect));
-						}
-
-					}
-
-					h2c_parameter[2] = (u8)(GET_STA_INFO(p_entry).rssi_stat.rssi & 0xFF);
-					/* h2c_parameter[1] = 0x20;*/ /* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1 */
-					h2c_parameter[0] = (GET_STA_INFO(p_entry).mac_id);
-
-					odm_fill_h2c_cmd(p_dm, ODM_H2C_RSSI_REPORT, cmdlen, h2c_parameter);
-				}
-			} else
-				break;
-		}
-
-		p_loop_adapter = GetNextExtAdapter(p_loop_adapter);
-	}
-
-
-	/*Default port*/
-	if (tmp_entry_max_pwdb != 0) {	/* If associated entry is found */
-		p_hal_data->EntryMaxUndecoratedSmoothedPWDB = tmp_entry_max_pwdb;
-		RT_DISP(FDM, DM_PWDB, ("EntryMaxPWDB = 0x%x(%d)\n",	tmp_entry_max_pwdb, tmp_entry_max_pwdb));
-	} else
-		p_hal_data->EntryMaxUndecoratedSmoothedPWDB = 0;
-
-	if (tmp_entry_min_pwdb != 0xff) { /* If associated entry is found */
-		p_hal_data->EntryMinUndecoratedSmoothedPWDB = tmp_entry_min_pwdb;
-		RT_DISP(FDM, DM_PWDB, ("EntryMinPWDB = 0x%x(%d)\n", tmp_entry_min_pwdb, tmp_entry_min_pwdb));
-
-	} else
-		p_hal_data->EntryMinUndecoratedSmoothedPWDB = 0;
-
-	/* Default porti sent RSSI to FW */
-	if (p_hal_data->bUseRAMask) {
-		PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("1 RA First Link, RSSI[%d] = ((%d)) , ra_rpt_linked = ((%d))\n",
-			WIN_DEFAULT_PORT_MACID, p_hal_data->UndecoratedSmoothedPWDB, p_hal_data->ra_rpt_linked));
-		if (p_hal_data->UndecoratedSmoothedPWDB > 0) {
-
-			PRT_HIGH_THROUGHPUT			p_ht_info = GET_HT_INFO(p_default_mgnt_info);
-			PRT_VERY_HIGH_THROUGHPUT	p_vht_info = GET_VHT_INFO(p_default_mgnt_info);
-
-			/* BF_en*/
-#if (BEAMFORMING_SUPPORT == 1)
-#ifndef BEAMFORMING_VERSION_1
-			beamform_cap = phydm_beamforming_get_entry_beam_cap_by_mac_id(p_dm, p_default_mgnt_info->m_mac_id);
-
-			if (beamform_cap & (BEAMFORMER_CAP_HT_EXPLICIT | BEAMFORMER_CAP_VHT_SU))
-				tx_bf_en = 1;
-#else
-			if (Beamform_GetSupportBeamformerCap(GetDefaultAdapter(adapter), NULL))
-				tx_bf_en = 1;
-#endif
-#endif
-
-			/* STBC_en*/
-			if ((IS_WIRELESS_MODE_AC(adapter) && TEST_FLAG(p_vht_info->VhtCurStbc, STBC_VHT_ENABLE_TX)) ||
-			    TEST_FLAG(p_ht_info->HtCurStbc, STBC_HT_ENABLE_TX))
-				stbc_en = 1;
-
-			h2c_parameter[4] = (p_ra_table->RA_threshold_offset & 0x7f) | (p_ra_table->RA_offset_direction << 7);
-			PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("RA_threshold_offset = (( %s%d ))\n", ((p_ra_table->RA_threshold_offset == 0) ? " " : ((p_ra_table->RA_offset_direction) ? "+" : "-")), p_ra_table->RA_threshold_offset));
-
-			if (is_ext_ra_info) {
-				if (tx_bf_en)
-					h2c_parameter[3] |= RAINFO_BF_STATE;
-				else {
-					if (stbc_en)
-						h2c_parameter[3] |= RAINFO_STBC_STATE;
-				}
-
-				if (p_dm->h2c_rarpt_connect) {
-					h2c_parameter[3] |= RAINFO_INIT_RSSI_RATE_STATE;
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("h2c_rarpt_connect = (( %d ))\n", p_dm->h2c_rarpt_connect));
-				}
-
-
-				if (p_dm->noisy_decision == 1) {
-					h2c_parameter[3] |= RAINFO_NOISY_STATE;
-					PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("[RSSIMonitorCheckMP] Send H2C to FW\n"));
-				} else
-					h2c_parameter[3] &= (~RAINFO_NOISY_STATE);
-
-				PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("[RSSIMonitorCheckMP] h2c_parameter=%x\n", h2c_parameter[3]));
+			if (sta->rssi_stat.rssi > rssi_max_tmp) {
+				rssi_max_tmp = sta->rssi_stat.rssi;
+				dm->rssi_max_macid = i;
 			}
 
-			h2c_parameter[2] = (u8)(p_hal_data->UndecoratedSmoothedPWDB & 0xFF);
-			/*h2c_parameter[1] = 0x20;*/	/* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1*/
-			h2c_parameter[0] = WIN_DEFAULT_PORT_MACID;		/* fw v12 cmdid 5:use max macid ,for nic ,default macid is 0 ,max macid is 1*/
-
-			odm_fill_h2c_cmd(p_dm, ODM_H2C_RSSI_REPORT, cmdlen, h2c_parameter);
-		}
-	
-	} else
-		PlatformEFIOWrite1Byte(adapter, 0x4fe, (u8)p_hal_data->UndecoratedSmoothedPWDB);
-
-	{
-		struct _ADAPTER *p_loop_adapter = GetDefaultAdapter(adapter);
-		boolean		default_pointer_value, *p_is_link_temp = &default_pointer_value;
-		s32	global_rssi_min = 0xFF, local_rssi_min;
-		boolean		is_link = false;
-
-		while (p_loop_adapter) {
-			local_rssi_min = phydm_find_minimum_rssi(p_dm, p_loop_adapter, p_is_link_temp);
-			/* dbg_print("p_hal_data->is_linked=%d, local_rssi_min=%d\n", p_hal_data->is_linked, local_rssi_min); */
-
-			if (*p_is_link_temp)
-				is_link = true;
+			/*@[Send RSSI to FW]*/
+			if (!sta->ra_info.disable_ra)
+				phydm_rssi_monitor_h2c(dm, i);
 
-			if ((local_rssi_min < global_rssi_min) && (*p_is_link_temp))
-				global_rssi_min = local_rssi_min;
-
-			p_loop_adapter = GetNextExtAdapter(p_loop_adapter);
+			if (sta_cnt == dm->number_linked_client)
+				break;
 		}
-
-		p_hal_data->bLinked = is_link;
-
-		p_dm->is_linked = is_link;
-		p_dm->rssi_min = (u8)((is_link) ? global_rssi_min : 0);
-
 	}
+	dm->pre_rssi_min = dm->rssi_min;
 
-
+	dm->rssi_max = (u8)rssi_max_tmp;
+	dm->rssi_min = (u8)rssi_min_tmp;
 }
 
-#endif
-
-void
-phydm_rssi_monitor_check(
-	void		*p_dm_void
-)
+void phydm_rssi_monitor_check(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (!(p_dm->support_ability & ODM_BB_RSSI_MONITOR))
+	if (!(dm->support_ability & ODM_BB_RSSI_MONITOR))
 		return;
 
-	if ((p_dm->phydm_sys_up_time % 2) == 1) /*for AP watchdog period = 1 sec*/
+	/*@for AP watchdog period = 1 sec*/
+	if ((dm->phydm_sys_up_time % 2) == 1)
 		return;
 
-	PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("%s ======>\n", __func__));
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "%s ======>\n", __func__);
 
-#ifdef PHYDM_3RD_REFORM_RSSI_MONOTOR
-	phydm_calculate_rssi_min_max(p_dm);
-#else
-	#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	odm_rssi_monitor_check_mp(p_dm);
-	#endif
-#endif
-
-	PHYDM_DBG(p_dm, DBG_RSSI_MNTR, ("RSSI {max, min} = {%d, %d}\n",
-		p_dm->rssi_max, p_dm->rssi_min));
+	phydm_calculate_rssi_min_max(dm);
 
+	PHYDM_DBG(dm, DBG_RSSI_MNTR, "RSSI {max, min} = {%d, %d}\n",
+		  dm->rssi_max, dm->rssi_min);
 }
 
-void
-phydm_rssi_monitor_init(
-	void		*p_dm_void
-)
+void phydm_rssi_monitor_init(void *dm_void)
 {
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
 
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _rate_adaptive_table_	*p_ra_table = &p_dm->dm_ra_table;
-#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
-	struct _ADAPTER		*adapter = p_dm->adapter;
-	HAL_DATA_TYPE		*p_hal_data = GET_HAL_DATA(adapter);
-
-	p_ra_table->PT_collision_pre = true;	/*used in odm_dynamic_arfb_select(WIN only)*/
-
-	p_hal_data->UndecoratedSmoothedPWDB = -1;
-	p_hal_data->ra_rpt_linked = false;
-#endif
-
-	p_ra_table->firstconnect = false;
-	p_dm->rssi_max = 0;
-	p_dm->rssi_min = 0;
-
+	ra_tab->firstconnect = false;
+	dm->pre_rssi_min = 0;
+	dm->rssi_max = 0;
+	dm->rssi_min = 0;
 }
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.h
index 9aef3cc6f1b9..e7d7d2a48c72 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_rssi_monitor.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,58 +9,48 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
+#ifndef __PHYDM_RSSI_MONITOR_H__
+#define __PHYDM_RSSI_MONITOR_H__
 
-#ifndef	__PHYDM_RSSI_MONITOR_H__
-#define    __PHYDM_RSSI_MONITOR_H__
+#define RSSI_MONITOR_VERSION "2.0"
 
-#define RSSI_MONITOR_VERSION	"1.0"		/* 2017.05.011  Dino, Add phydm_rssi_monitor.h*/
-
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  Definition
- * 1 ============================================================ */
-
-#define	H2C_0X42_LENGTH	5
+ * 1 ============================================================
+ */
 
-#define RAINFO_BE_RX_STATE				BIT(0)	/* 1:RX*/ /* ULDL */
-#define RAINFO_STBC_STATE				BIT(1)
-#define RAINFO_NOISY_STATE 			BIT(2)	/* set by Noisy_Detection */
-/*#define RAINFO_SHURTCUT_STATE			BIT(3)*/
-/*#define RAINFO_SHURTCUT_FLAG			BIT(4)*/
-#define RAINFO_INIT_RSSI_RATE_STATE	BIT(5)
-#define RAINFO_BF_STATE				BIT(6)
-#define RAINFO_BE_TX_STATE 			BIT(7)	/* 1:TX */
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  structure
- * 1 ============================================================ */
-
-
+ * 1 ============================================================
+ */
 
-
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  enumeration
- * 1 ============================================================ */
-
-
+ * 1 ============================================================
+ */
 
-/* 1 ============================================================
+/* @1 ============================================================
  * 1  function prototype
- * 1 ============================================================ */
+ * 1 ============================================================
+ */
 
-void
-phydm_rssi_monitor_check(
-	void		*p_dm_void
-);
+void phydm_rssi_monitor_check(void *dm_void);
 
-void
-phydm_rssi_monitor_init(
-	void		*p_dm_void
-);
+void phydm_rssi_monitor_init(void *dm_void);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.c
index ec8a9a870785..5ed1bb7c3157 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,9 +9,19 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
 /* ************************************************************
@@ -20,286 +31,305 @@
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-/* ******************************************************
+/*******************************************************
  * when antenna test utility is on or some testing need to disable antenna diversity
  * call this function to disable all ODM related mechanisms which will switch antenna.
- * ****************************************************** */
+ ******************************************************/
 #if (defined(CONFIG_SMART_ANTENNA))
+
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+#if (RTL8198F_SUPPORT == 1)
+void phydm_smt_ant_init_98f(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 val = 0;
+
+	#if 0
+	odm_set_bb_reg(dm, R_0x1da4, 0x3c, 4); /*6.25*4 = 25ms*/
+	odm_set_bb_reg(dm, R_0x1da4, BIT(6), 1);
+	odm_set_bb_reg(dm, R_0x1da4, BIT(7), 1);
+	#endif
+}
+#endif
+#endif
+
 #if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
-void
-phydm_cumitek_smt_ant_mapping_table_8822b(
-	void		*p_dm_void,
-	u8		*table_path_a,
-	u8		*table_path_b
-)
+void phydm_cumitek_smt_ant_mapping_table_8822b(
+	void *dm_void,
+	u8 *table_path_a,
+	u8 *table_path_b)
 {
-	struct	PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32		path_a_0to3_idx = 0;
-	u32		path_b_0to3_idx = 0;
-	u32		path_a_4to7_idx = 0;
-	u32		path_b_4to7_idx = 0;
-	
-	path_a_0to3_idx = ((table_path_a[3] & 0xf) << 24) | ((table_path_a[2] & 0xf) << 16) 
-						| ((table_path_a[1] & 0xf) << 8) | (table_path_a[0] & 0xf);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 path_a_0to3_idx = 0;
+	u32 path_b_0to3_idx = 0;
+	u32 path_a_4to7_idx = 0;
+	u32 path_b_4to7_idx = 0;
 
-	path_b_0to3_idx = ((table_path_b[3] & 0xf) << 28) | ((table_path_b[2] & 0xf) << 20) 
-						| ((table_path_b[1] & 0xf) << 12) | ((table_path_b[0] & 0xf) << 4);
+	path_a_0to3_idx = ((table_path_a[3] & 0xf) << 24) | ((table_path_a[2] & 0xf) << 16) | ((table_path_a[1] & 0xf) << 8) | (table_path_a[0] & 0xf);
 
-	path_a_4to7_idx = ((table_path_a[7] & 0xf) << 24) | ((table_path_a[6] & 0xf) << 16) 
-						| ((table_path_a[5] & 0xf) << 8) | (table_path_a[4] & 0xf);
+	path_b_0to3_idx = ((table_path_b[3] & 0xf) << 28) | ((table_path_b[2] & 0xf) << 20) | ((table_path_b[1] & 0xf) << 12) | ((table_path_b[0] & 0xf) << 4);
 
-	path_b_4to7_idx = ((table_path_b[7] & 0xf) << 28) | ((table_path_b[6] & 0xf) << 20) 
-						| ((table_path_b[5] & 0xf) << 12) | ((table_path_b[4] & 0xf) << 4);
+	path_a_4to7_idx = ((table_path_a[7] & 0xf) << 24) | ((table_path_a[6] & 0xf) << 16) | ((table_path_a[5] & 0xf) << 8) | (table_path_a[4] & 0xf);
 
+	path_b_4to7_idx = ((table_path_b[7] & 0xf) << 28) | ((table_path_b[6] & 0xf) << 20) | ((table_path_b[5] & 0xf) << 12) | ((table_path_b[4] & 0xf) << 4);
 
-	/*PHYDM_DBG(p_dm, DBG_SMT_ANT, ("mapping table{A, B} = {0x%x, 0x%x}\n", path_a_0to3_idx, path_b_0to3_idx));*/
+#if 0
+	/*PHYDM_DBG(dm, DBG_SMT_ANT, "mapping table{A, B} = {0x%x, 0x%x}\n", path_a_0to3_idx, path_b_0to3_idx);*/
+#endif
 
 	/*pathA*/
-	odm_set_bb_reg(p_dm, 0xca4, MASKDWORD, path_a_0to3_idx); /*ant map 1*/
-	odm_set_bb_reg(p_dm, 0xca8, MASKDWORD, path_a_4to7_idx); /*ant map 2*/
+	odm_set_bb_reg(dm, R_0xca4, MASKDWORD, path_a_0to3_idx); /*@ant map 1*/
+	odm_set_bb_reg(dm, R_0xca8, MASKDWORD, path_a_4to7_idx); /*@ant map 2*/
 
 	/*pathB*/
-	odm_set_bb_reg(p_dm, 0xea4, MASKDWORD, path_b_0to3_idx); /*ant map 1*/
-	odm_set_bb_reg(p_dm, 0xea8, MASKDWORD, path_b_4to7_idx); /*ant map 2*/
-
+	odm_set_bb_reg(dm, R_0xea4, MASKDWORD, path_b_0to3_idx); /*@ant map 1*/
+	odm_set_bb_reg(dm, R_0xea8, MASKDWORD, path_b_4to7_idx); /*@ant map 2*/
 }
 
-
-void
-phydm_cumitek_smt_ant_init_8822b(
-	void		*p_dm_void
-)
+void phydm_cumitek_smt_ant_init_8822b(
+	void *dm_void)
 {
-	struct	PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	smt_ant				*p_smtant_table = &(p_dm->smtant_table);
-	struct	smt_ant_cumitek		*p_cumi_smtant_table = &(p_dm->smtant_table.cumi_smtant_table);
-	u32		value32;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
+	struct smt_ant_cumitek *cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32 value32;
 
-	PHYDM_DBG(p_dm, DBG_SMT_ANT, ("[8822B Cumitek SmtAnt Int]\n"));
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[8822B Cumitek SmtAnt Int]\n");
+
+	/*@========= MAC GPIO setting =================================*/
 
-	/*========= MAC GPIO setting =================================*/
-	
 	/* Pin, pin_name, RFE_CTRL_NUM*/
-	
-	/* A0, 55, 5G_TRSW, 3*/
-	/* A1, 52, 5G_TRSW, 0*/
-	/* A2, 25, 5G_TRSW, 8*/
-	
-	/* B0, 16, 5G_TRSW, 4*/
-	/* B1, 13, 5G_TRSW, 11*/
-	/* B2, 24, 5G_TRSW, 9*/
 
-	/*for RFE_CTRL 8 & 9*/
-	odm_set_mac_reg(p_dm, 0x4c, BIT(24) | BIT(23), 2);
-	odm_set_mac_reg(p_dm, 0x44, BIT(27) | BIT(26), 0);
+	/* @A0, 55, 5G_TRSW, 3*/
+	/* @A1, 52, 5G_TRSW, 0*/
+	/* @A2, 25, 5G_TRSW, 8*/
 
-	/*for RFE_CTRL 0*/
-	odm_set_mac_reg(p_dm, 0x4c, BIT(25), 0);
-	odm_set_mac_reg(p_dm, 0x64, BIT(29), 1);
+	/* @B0, 16, 5G_TRSW, 4*/
+	/* @B1, 13, 5G_TRSW, 11*/
+	/* @B2, 24, 5G_TRSW, 9*/
 
-	/*for RFE_CTRL 2 & 3*/
-	odm_set_mac_reg(p_dm, 0x4c, BIT(26), 0);
-	odm_set_mac_reg(p_dm, 0x64, BIT(28), 1);
+	/*@for RFE_CTRL 8 & 9*/
+	odm_set_mac_reg(dm, R_0x4c, BIT(24) | BIT(23), 2);
+	odm_set_mac_reg(dm, R_0x44, BIT(27) | BIT(26), 0);
 
-	/*for RFE_CTRL 11*/
-	odm_set_mac_reg(p_dm, 0x40, BIT(3), 1);
+	/*@for RFE_CTRL 0*/
+	odm_set_mac_reg(dm, R_0x4c, BIT(25), 0);
+	odm_set_mac_reg(dm, R_0x64, BIT(29), 1);
 
+	/*@for RFE_CTRL 2 & 3*/
+	odm_set_mac_reg(dm, R_0x4c, BIT(26), 0);
+	odm_set_mac_reg(dm, R_0x64, BIT(28), 1);
 
-	/*0x604[25]=1 : 2bit mode for pathA&B&C&D*/
-	/*0x604[25]=0 : 3bit mode for pathA&B*/
-	p_smtant_table->tx_desc_mode = 0;
-	odm_set_mac_reg(p_dm, 0x604, BIT(25), (u32)p_smtant_table->tx_desc_mode);
+	/*@for RFE_CTRL 11*/
+	odm_set_mac_reg(dm, R_0x40, BIT(3), 1);
 
-	/*========= BB RFE setting =================================*/
-	#if 0
+	/*@0x604[25]=1 : 2bit mode for pathA&B&C&D*/
+	/*@0x604[25]=0 : 3bit mode for pathA&B*/
+	smtant_table->tx_desc_mode = 0;
+	odm_set_mac_reg(dm, R_0x604, BIT(25), (u32)smtant_table->tx_desc_mode);
+
+	/*@========= BB RFE setting =================================*/
+#if 0
 	/*path A*/
-	odm_set_bb_reg(p_dm, 0x1990, BIT(3), 0);		/*RFE_CTRL_3*/ /*A_0*/
-	odm_set_bb_reg(p_dm, 0xcbc, BIT(3), 0);		/*inv*/
-	odm_set_bb_reg(p_dm, 0xcb0, 0xf000, 8);
-
-	odm_set_bb_reg(p_dm, 0x1990, BIT(1), 0);		/*RFE_CTRL_0*/ /*A_1*/
-	odm_set_bb_reg(p_dm, 0xcbc, BIT(0), 0);		/*inv*/
-	odm_set_bb_reg(p_dm, 0xcb0, 0xf, 0x9);
-	
-	odm_set_bb_reg(p_dm, 0x1990, BIT(8), 0);		/*RFE_CTRL_8*/ /*A_2*/
-	odm_set_bb_reg(p_dm, 0xcbc, BIT(8), 0);		/*inv*/
-	odm_set_bb_reg(p_dm, 0xcb4, 0xf, 0xa);
-	
+	odm_set_bb_reg(dm, R_0x1990, BIT(3), 0);		/*RFE_CTRL_3*/ /*A_0*/
+	odm_set_bb_reg(dm, R_0xcbc, BIT(3), 0);		/*@inv*/
+	odm_set_bb_reg(dm, R_0xcb0, 0xf000, 8);
+
+	odm_set_bb_reg(dm, R_0x1990, BIT(0), 0);		/*RFE_CTRL_0*/ /*A_1*/
+	odm_set_bb_reg(dm, R_0xcbc, BIT(0), 0);		/*@inv*/
+	odm_set_bb_reg(dm, R_0xcb0, 0xf, 0x9);
+
+	odm_set_bb_reg(dm, R_0x1990, BIT(8), 0);		/*RFE_CTRL_8*/ /*A_2*/
+	odm_set_bb_reg(dm, R_0xcbc, BIT(8), 0);		/*@inv*/
+	odm_set_bb_reg(dm, R_0xcb4, 0xf, 0xa);
+
 
 	/*path B*/
-	odm_set_bb_reg(p_dm, 0x1990, BIT(4), 1);		/*RFE_CTRL_4*/	/*B_0*/
-	odm_set_bb_reg(p_dm, 0xdbc, BIT(4), 0);		/*inv*/
-	odm_set_bb_reg(p_dm, 0xdb0, 0xf0000, 0xb);
-	
-	odm_set_bb_reg(p_dm, 0x1990, BIT(11), 1);	/*RFE_CTRL_11*/	/*B_1*/
-	odm_set_bb_reg(p_dm, 0xdbc, BIT(11), 0);		/*inv*/
-	odm_set_bb_reg(p_dm, 0xdb4, 0xf000, 0xc);
-	
-	odm_set_bb_reg(p_dm, 0x1990, BIT(9), 1);		/*RFE_CTRL_9*/	/*B_2*/
-	odm_set_bb_reg(p_dm, 0xdbc, BIT(9), 0);		/*inv*/
-	odm_set_bb_reg(p_dm, 0xdb4, 0xf0, 0xd);
-	#endif
-	/*========= BB SmtAnt setting =================================*/
-	odm_set_mac_reg(p_dm, 0x668, BIT(3), 1);
-	odm_set_bb_reg(p_dm, 0x804, BIT(4), 0); /*lathch antsel*/
-	odm_set_bb_reg(p_dm, 0x818, 0xf00000, 0); /*keep tx by rx*/
-	odm_set_bb_reg(p_dm, 0x900, BIT(19), 0); /*fast train*/
-	odm_set_bb_reg(p_dm, 0x900, BIT(18), 1); /*1: by TXDESC*/
+	odm_set_bb_reg(dm, R_0x1990, BIT(4), 1);		/*RFE_CTRL_4*/	/*B_0*/
+	odm_set_bb_reg(dm, R_0xdbc, BIT(4), 0);		/*@inv*/
+	odm_set_bb_reg(dm, R_0xdb0, 0xf0000, 0xb);
+
+	odm_set_bb_reg(dm, R_0x1990, BIT(11), 1);	/*RFE_CTRL_11*/	/*B_1*/
+	odm_set_bb_reg(dm, R_0xdbc, BIT(11), 0);		/*@inv*/
+	odm_set_bb_reg(dm, R_0xdb4, 0xf000, 0xc);
+
+	odm_set_bb_reg(dm, R_0x1990, BIT(9), 1);		/*RFE_CTRL_9*/	/*B_2*/
+	odm_set_bb_reg(dm, R_0xdbc, BIT(9), 0);		/*@inv*/
+	odm_set_bb_reg(dm, R_0xdb4, 0xf0, 0xd);
+#endif
+	/*@========= BB SmtAnt setting =================================*/
+	odm_set_mac_reg(dm, R_0x6d8, BIT(22) | BIT(21), 2); /*resp tx by register*/
+	odm_set_mac_reg(dm, R_0x668, BIT(3), 1);
+	odm_set_bb_reg(dm, R_0x804, BIT(4), 0); /*@lathch antsel*/
+	odm_set_bb_reg(dm, R_0x818, 0xf00000, 0); /*@keep tx by rx*/
+	odm_set_bb_reg(dm, R_0x900, BIT(19), 0); /*@fast train*/
+	odm_set_bb_reg(dm, R_0x900, BIT(18), 1); /*@1: by TXDESC*/
 
 	/*pathA*/
-	odm_set_bb_reg(p_dm, 0xca4, MASKDWORD, 0x03020100); /*ant map 1*/
-	odm_set_bb_reg(p_dm, 0xca8, MASKDWORD, 0x07060504); /*ant map 2*/
-	odm_set_bb_reg(p_dm, 0xcac, BIT(9), 0); /*keep antsel map by GNT_BT*/
+	odm_set_bb_reg(dm, R_0xca4, MASKDWORD, 0x03020100); /*@ant map 1*/
+	odm_set_bb_reg(dm, R_0xca8, MASKDWORD, 0x07060504); /*@ant map 2*/
+	odm_set_bb_reg(dm, R_0xcac, BIT(9), 0); /*@keep antsel map by GNT_BT*/
 
 	/*pathB*/
-	odm_set_bb_reg(p_dm, 0xea4, MASKDWORD, 0x30201000); /*ant map 1*/
-	odm_set_bb_reg(p_dm, 0xea8, MASKDWORD, 0x70605040); /*ant map 2*/
-	odm_set_bb_reg(p_dm, 0xeac, BIT(9), 0); /*keep antsel map by GNT_BT*/
+	odm_set_bb_reg(dm, R_0xea4, MASKDWORD, 0x30201000); /*@ant map 1*/
+	odm_set_bb_reg(dm, R_0xea8, MASKDWORD, 0x70605040); /*@ant map 2*/
+	odm_set_bb_reg(dm, R_0xeac, BIT(9), 0); /*@keep antsel map by GNT_BT*/
 }
 
-void
-phydm_cumitek_smt_ant_init_8197f(
-	void		*p_dm_void
-)
+void phydm_cumitek_smt_ant_init_8197f(
+	void *dm_void)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	smt_ant			*p_smtant_table = &(p_dm->smtant_table);
-	struct	smt_ant_cumitek	*p_cumi_smtant_table = &(p_dm->smtant_table.cumi_smtant_table);
-	u32		value32;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
+	struct smt_ant_cumitek *cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32 value32;
 
-	PHYDM_DBG(p_dm, DBG_SMT_ANT, ("[8197F Cumitek SmtAnt Int]\n"));
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[8197F Cumitek SmtAnt Int]\n");
 
-	/*GPIO setting*/
+	/*@GPIO setting*/
+}
 
+void phydm_cumitek_smt_ant_init_8192f(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
+	struct smt_ant_cumitek *cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32 value32;
+	PHYDM_DBG(dm, DBG_SMT_ANT, "[8192F Cumitek SmtAnt Int]\n");
 
+	/*@GPIO setting*/
 }
 
-void
-phydm_cumitek_smt_tx_ant_update(
-	void		*p_dm_void,
-	u8		tx_ant_idx_path_a,
-	u8		tx_ant_idx_path_b,
-	u32		mac_id
-)
+void phydm_cumitek_smt_tx_ant_update(
+	void *dm_void,
+	u8 tx_ant_idx_path_a,
+	u8 tx_ant_idx_path_b,
+	u32 mac_id)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	smt_ant			*p_smtant_table = &(p_dm->smtant_table);
-	struct	smt_ant_cumitek	*p_cumi_smtant_table = &(p_dm->smtant_table.cumi_smtant_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
+	struct smt_ant_cumitek *cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Cumitek] Set TX-ANT[%d] = (( A:0x%x ,  B:0x%x ))\n",
-		mac_id, tx_ant_idx_path_a, tx_ant_idx_path_b));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[Cumitek] Set TX-ANT[%d] = (( A:0x%x ,  B:0x%x ))\n", mac_id,
+		  tx_ant_idx_path_a, tx_ant_idx_path_b);
 
 	/*path-A*/
-	p_cumi_smtant_table->tx_ant_idx[0][mac_id] = tx_ant_idx_path_a; /*fill this value into TXDESC*/
-	
-	/*path-B*/	
-	p_cumi_smtant_table->tx_ant_idx[1][mac_id] = tx_ant_idx_path_b; /*fill this value into TXDESC*/
+	cumi_smtant_table->tx_ant_idx[0][mac_id] = tx_ant_idx_path_a; /*@fill this value into TXDESC*/
+
+	/*path-B*/
+	cumi_smtant_table->tx_ant_idx[1][mac_id] = tx_ant_idx_path_b; /*@fill this value into TXDESC*/
 }
 
-void
-phydm_cumitek_smt_rx_default_ant_update(
-	void		*p_dm_void,
-	u8		rx_ant_idx_path_a,
-	u8		rx_ant_idx_path_b
-)
+void phydm_cumitek_smt_rx_default_ant_update(
+	void *dm_void,
+	u8 rx_ant_idx_path_a,
+	u8 rx_ant_idx_path_b)
 {
-	struct	PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	smt_ant			*p_smtant_table = &(p_dm->smtant_table);
-	struct	smt_ant_cumitek	*p_cumi_smtant_table = &(p_dm->smtant_table.cumi_smtant_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
+	struct smt_ant_cumitek *cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Cumitek] Set RX-ANT = (( A:0x%x, B:0x%x ))\n",
-		rx_ant_idx_path_a, rx_ant_idx_path_b));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[Cumitek] Set RX-ANT = (( A:0x%x, B:0x%x ))\n",
+		  rx_ant_idx_path_a, rx_ant_idx_path_b);
 
 	/*path-A*/
-	if (p_cumi_smtant_table->rx_default_ant_idx[0] != rx_ant_idx_path_a) {
-		
+	if (cumi_smtant_table->rx_default_ant_idx[0] != rx_ant_idx_path_a) {
 		#if (RTL8822B_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8822B) {
-			
-			odm_set_bb_reg(p_dm, 0xc08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_a); /*default RX antenna*/
-			odm_set_mac_reg(p_dm, 0x6d8, BIT(2) | BIT(1) | BIT(0), rx_ant_idx_path_a); /*default response TX antenna*/
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			odm_set_bb_reg(dm, R_0xc08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_a); /*@default RX antenna*/
+			odm_set_mac_reg(dm, R_0x6d8, BIT(2) | BIT(1) | BIT(0), rx_ant_idx_path_a); /*@default response TX antenna*/
 		}
 		#endif
-		
-		#if (RTL8197F_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8197F) {
 
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
 		}
 		#endif
 
-		p_cumi_smtant_table->rx_default_ant_idx[0] = rx_ant_idx_path_a;
+		/*@jj add 20170822*/
+		#if (RTL8192F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8192F) {
+		}
+		#endif
+		cumi_smtant_table->rx_default_ant_idx[0] = rx_ant_idx_path_a;
 	}
 
 	/*path-B*/
-	if (p_cumi_smtant_table->rx_default_ant_idx[1] != rx_ant_idx_path_b) {
-		
+	if (cumi_smtant_table->rx_default_ant_idx[1] != rx_ant_idx_path_b) {
 		#if (RTL8822B_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8822B) {
-			
-			odm_set_bb_reg(p_dm, 0xe08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_b); /*default antenna*/
-			odm_set_mac_reg(p_dm, 0x6d8, BIT(5) | BIT(4) | BIT(3), rx_ant_idx_path_b); /*default response TX antenna*/
+		if (dm->support_ic_type == ODM_RTL8822B) {
+			odm_set_bb_reg(dm, R_0xe08, BIT(21) | BIT(20) | BIT(19), rx_ant_idx_path_b); /*@default antenna*/
+			odm_set_mac_reg(dm, R_0x6d8, BIT(5) | BIT(4) | BIT(3), rx_ant_idx_path_b); /*@default response TX antenna*/
 		}
 		#endif
-		
-		#if (RTL8197F_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8197F) {
 
+		#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F) {
 		}
 		#endif
 
-		p_cumi_smtant_table->rx_default_ant_idx[1] = rx_ant_idx_path_b;
+		/*@jj add 20170822*/
+		#if (RTL8192F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8192F) {
+		}
+		#endif
+		cumi_smtant_table->rx_default_ant_idx[1] = rx_ant_idx_path_b;
 	}
-	
 }
 
-void
-phydm_cumitek_smt_ant_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_cumitek_smt_ant_debug(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	smt_ant			*p_smtant_table = &(p_dm->smtant_table);
-	struct	smt_ant_cumitek	*p_cumi_smtant_table = &(p_dm->smtant_table.cumi_smtant_table);
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-	char			help[] = "-h";
-	u32			dm_value[10] = {0};
-	u8			i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
+	struct smt_ant_cumitek *cumi_smtant_table = &dm->smtant_table.cumi_smtant_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	char help[] = "-h";
+	u32 dm_value[10] = {0};
+	u8 i;
 
 	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &dm_value[0]);
 
 	if (strcmp(input[1], help) == 0) {
-		PHYDM_SNPRINTF((output + used, out_len - used, "{1} {PathA rx_ant_idx} {pathB rx_ant_idx}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{2} {PathA tx_ant_idx} {pathB tx_ant_idx} {macid}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{3} {PathA mapping table} {PathB mapping table}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, "{4} {txdesc_mode 0:3bit, 1:2bit}\n"));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{1} {PathA rx_ant_idx} {pathB rx_ant_idx}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{2} {PathA tx_ant_idx} {pathB tx_ant_idx} {macid}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{3} {PathA mapping table} {PathB mapping table}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "{4} {txdesc_mode 0:3bit, 1:2bit}\n");
+
+	} else if (dm_value[0] == 1) { /*@fix rx_idle pattern*/
 
-	} else if (dm_value[0] == 1) { /*fix rx_idle pattern*/
-	
 		PHYDM_SSCANF(input[2], DCMD_DECIMAL, &dm_value[1]);
 		PHYDM_SSCANF(input[3], DCMD_DECIMAL, &dm_value[2]);
 
-		phydm_cumitek_smt_rx_default_ant_update(p_dm, (u8)dm_value[1], (u8)dm_value[2]);
-		PHYDM_SNPRINTF((output + used, out_len - used, "RX Ant{A, B}={%d, %d}\n", dm_value[1], dm_value[2]));
-		
-	} else if (dm_value[0] == 2) { /*fix tx pattern*/ 
+		phydm_cumitek_smt_rx_default_ant_update(dm, (u8)dm_value[1], (u8)dm_value[2]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "RX Ant{A, B}={%d, %d}\n", dm_value[1], dm_value[2]);
 
+	} else if (dm_value[0] == 2) { /*@fix tx pattern*/
 
 		for (i = 1; i < 4; i++) {
 			if (input[i + 1])
 				PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
 		}
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "STA[%d] TX Ant{A, B}={%d, %d}\n",dm_value[3], dm_value[1], dm_value[2]));
-		phydm_cumitek_smt_tx_ant_update(p_dm, (u8)dm_value[1], (u8)dm_value[2], (u8)dm_value[3]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "STA[%d] TX Ant{A, B}={%d, %d}\n", dm_value[3],
+			 dm_value[1], dm_value[2]);
+		phydm_cumitek_smt_tx_ant_update(dm, (u8)dm_value[1], (u8)dm_value[2], (u8)dm_value[3]);
 
 	} else if (dm_value[0] == 3) {
-
 		u8 table_path_a[8] = {0};
 		u8 table_path_b[8] = {0};
 
@@ -308,23 +338,31 @@ phydm_cumitek_smt_ant_debug(
 				PHYDM_SSCANF(input[i + 1], DCMD_HEX, &dm_value[i]);
 		}
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "Set Path-AB mapping table={%d, %d}\n", dm_value[1], dm_value[2]));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Set Path-AB mapping table={%d, %d}\n", dm_value[1],
+			 dm_value[2]);
 
-		for (i = 0; i <8; i++) {
+		for (i = 0; i < 8; i++) {
 			table_path_a[i] = (u8)((dm_value[1] >> (4 * i)) & 0xf);
 			table_path_b[i] = (u8)((dm_value[2] >> (4 * i)) & 0xf);
 		}
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "Ant_Table_A[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n", 
-			table_path_a[7], table_path_a[6], table_path_a[5], table_path_a[4], table_path_a[3], table_path_a[2], table_path_a[1], table_path_a[0]));
-		PHYDM_SNPRINTF((output + used, out_len - used, "Ant_Table_B[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n", 
-			table_path_b[7], table_path_b[6], table_path_b[5], table_path_b[4], table_path_b[3], table_path_b[2], table_path_b[1], table_path_b[0]));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Ant_Table_A[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n",
+			 table_path_a[7], table_path_a[6], table_path_a[5],
+			 table_path_a[4], table_path_a[3], table_path_a[2],
+			 table_path_a[1], table_path_a[0]);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "Ant_Table_B[7:0]={0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x}\n",
+			 table_path_b[7], table_path_b[6], table_path_b[5],
+			 table_path_b[4], table_path_b[3], table_path_b[2],
+			 table_path_b[1], table_path_b[0]);
 
-		phydm_cumitek_smt_ant_mapping_table_8822b(p_dm, &(table_path_a[0]), &(table_path_b[0]));
-	}else if (dm_value[0] == 4) {
+		phydm_cumitek_smt_ant_mapping_table_8822b(dm, &table_path_a[0], &table_path_b[0]);
 
-		p_smtant_table->tx_desc_mode = (u8)dm_value[1];
-		odm_set_mac_reg(p_dm, 0x604, BIT(25), (u32)p_smtant_table->tx_desc_mode);
+	} else if (dm_value[0] == 4) {
+		smtant_table->tx_desc_mode = (u8)dm_value[1];
+		odm_set_mac_reg(dm, R_0x604, BIT(25), (u32)smtant_table->tx_desc_mode);
 	}
 	*_used = used;
 	*_out_len = out_len;
@@ -336,248 +374,240 @@ phydm_cumitek_smt_ant_debug(
 #ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
 
 #if (RTL8822B_SUPPORT == 1)
-void
-phydm_hl_smart_ant_type2_init_8822b(
-	void		*p_dm_void
-)
+void phydm_hl_smart_ant_type2_init_8822b(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo	*pdm_sat_table = &(p_dm->dm_sat_table);
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-	u8	j;
-	u8	rfu_codeword_table_init_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] = {
-			{1, 1},/*0*/
-			{1, 2},
-			{2, 1},
-			{2, 2},
-			{4, 0},
-			{5, 0},
-			{6, 0},
-			{7, 0},
-			{8, 0},/*8*/
-			{9, 0},
-			{0xa, 0},
-			{0xb, 0},
-			{0xc, 0},
-			{0xd, 0},
-			{0xe, 0},
-			{0xf, 0}
-		}; 
-	u8	rfu_codeword_table_init_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] ={
-		#if 1
-			{9, 1},/*0*/
-			{9, 9},
-			{1, 9},
-			{9, 6},
-			{2, 1},
-			{2, 9},
-			{9, 2},
-			{2, 2},/*8*/
-			{6, 1},
-			{6, 9},
-			{2, 9},
-			{2, 2},
-			{6, 2},
-			{6, 6},
-			{2, 6},
-			{1, 1}
-		#else
-			{1, 1},/*0*/
-			{9, 1},
-			{9, 9},
-			{1, 9},
-			{1, 2},
-			{9, 2},
-			{9, 6},
-			{1, 6},
-			{2, 1},/*8*/
-			{6, 1},
-			{6, 9},
-			{2, 9},
-			{2, 2},
-			{6, 2},
-			{6, 6},
-			{2, 6}
-		#endif
-		}; 		
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u8 j;
+	u8 rfu_codeword_table_init_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] = {
+		{1, 1}, /*@0*/
+		{1, 2},
+		{2, 1},
+		{2, 2},
+		{4, 0},
+		{5, 0},
+		{6, 0},
+		{7, 0},
+		{8, 0}, /*@8*/
+		{9, 0},
+		{0xa, 0},
+		{0xb, 0},
+		{0xc, 0},
+		{0xd, 0},
+		{0xe, 0},
+		{0xf, 0}};
+	u8 rfu_codeword_table_init_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B] = {
+#if 1
+		{9, 1}, /*@0*/
+		{9, 9},
+		{1, 9},
+		{9, 6},
+		{2, 1},
+		{2, 9},
+		{9, 2},
+		{2, 2}, /*@8*/
+		{6, 1},
+		{6, 9},
+		{2, 9},
+		{2, 2},
+		{6, 2},
+		{6, 6},
+		{2, 6},
+		{1, 1}
+#else
+		{1, 1}, /*@0*/
+		{9, 1},
+		{9, 9},
+		{1, 9},
+		{1, 2},
+		{9, 2},
+		{9, 6},
+		{1, 6},
+		{2, 1}, /*@8*/
+		{6, 1},
+		{6, 9},
+		{2, 9},
+		{2, 2},
+		{6, 2},
+		{6, 6},
+		{2, 6}
+#endif
+	};
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***RTK 8822B SmartAnt_Init: Hong-Bo SmrtAnt Type2]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***RTK 8822B SmartAnt_Init: Hong-Bo SmrtAnt Type2]\n");
 
-	/* ---------------------------------------- */
-	/* GPIO 0-1 for Beam control */
+	/* @---------------------------------------- */
+	/* @GPIO 0-1 for Beam control */
 	/* reg0x66[2:0]=0 */
 	/* reg0x44[25:24] = 0 */
 	/* reg0x44[23:16]  enable_output for P_GPIO[7:0] */
 	/* reg0x44[15:8]  output_value for P_GPIO[7:0] */
 	/* reg0x40[1:0] = 0  GPIO function */
-	/* ------------------------------------------ */
-
-	odm_move_memory(p_dm, pdm_sat_table->rfu_codeword_table_2g, rfu_codeword_table_init_2g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
-	odm_move_memory(p_dm, pdm_sat_table->rfu_codeword_table_5g, rfu_codeword_table_init_5g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
-
-	/*GPIO setting*/
-	odm_set_mac_reg(p_dm, 0x64, (BIT(18) | BIT(17) | BIT(16)), 0);
-	odm_set_mac_reg(p_dm, 0x44, BIT(25) | BIT(24), 0);	/*config P_GPIO[3:2] to data port*/
-	odm_set_mac_reg(p_dm, 0x44, BIT(17) | BIT(16), 0x3);	/*enable_output for P_GPIO[3:2]*/
-	/*odm_set_mac_reg(p_dm, 0x44, BIT(9)|BIT(8), 0);*/ /*P_GPIO[3:2] output value*/
-	odm_set_mac_reg(p_dm, 0x40, BIT(1) | BIT(0), 0);		/*GPIO function*/
-
-	/*Hong_lin smart antenna HW setting*/
-	pdm_sat_table->rfu_protocol_type = 2;
-	pdm_sat_table->rfu_protocol_delay_time = 45;
-	
-	pdm_sat_table->rfu_codeword_total_bit_num  = 16;/*max=32bit*/
-	pdm_sat_table->rfu_each_ant_bit_num = 4;
-	
-	pdm_sat_table->total_beam_set_num = 4;
-	pdm_sat_table->total_beam_set_num_2g = 4;
-	pdm_sat_table->total_beam_set_num_5g = 8;
+	/* @------------------------------------------ */
 
-#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
-	pdm_sat_table->latch_time = 100; /*mu sec*/
-#elif DEV_BUS_TYPE == RT_USB_INTERFACE
-	pdm_sat_table->latch_time = 100; /*mu sec*/
+	odm_move_memory(dm, sat_tab->rfu_codeword_table_2g, rfu_codeword_table_init_2g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
+	odm_move_memory(dm, sat_tab->rfu_codeword_table_5g, rfu_codeword_table_init_5g, (SUPPORT_BEAM_SET_PATTERN_NUM * MAX_PATH_NUM_8822B));
+
+	/*@GPIO setting*/
+	odm_set_mac_reg(dm, R_0x64, (BIT(18) | BIT(17) | BIT(16)), 0);
+	odm_set_mac_reg(dm, R_0x44, BIT(25) | BIT(24), 0); /*@config P_GPIO[3:2] to data port*/
+	odm_set_mac_reg(dm, R_0x44, BIT(17) | BIT(16), 0x3); /*@enable_output for P_GPIO[3:2]*/
+#if 0
+	/*odm_set_mac_reg(dm, R_0x44, BIT(9)|BIT(8), 0);*/ /*P_GPIO[3:2] output value*/
 #endif
-	pdm_sat_table->pkt_skip_statistic_en = 0;
+	odm_set_mac_reg(dm, R_0x40, BIT(1) | BIT(0), 0); /*@GPIO function*/
 
-	pdm_sat_table->ant_num = 2;
-	pdm_sat_table->ant_num_total = MAX_PATH_NUM_8822B;
-	pdm_sat_table->first_train_ant = MAIN_ANT;
+	/*@Hong_lin smart antenna HW setting*/
+	sat_tab->rfu_protocol_type = 2;
+	sat_tab->rfu_protocol_delay_time = 45;
 
+	sat_tab->rfu_codeword_total_bit_num = 16; /*@max=32bit*/
+	sat_tab->rfu_each_ant_bit_num = 4;
 
+	sat_tab->total_beam_set_num = 4;
+	sat_tab->total_beam_set_num_2g = 4;
+	sat_tab->total_beam_set_num_5g = 8;
 
-	pdm_sat_table->fix_beam_pattern_en  = 0;
-	pdm_sat_table->decision_holding_period = 0;
+#if DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	if (dm->support_interface == ODM_ITRF_SDIO)
+		sat_tab->latch_time = 100; /*@mu sec*/
+#endif
+#if DEV_BUS_TYPE == RT_USB_INTERFACE
+	if (dm->support_interface == ODM_ITRF_USB)
+		sat_tab->latch_time = 100; /*@mu sec*/
+#endif
+	sat_tab->pkt_skip_statistic_en = 0;
+
+	sat_tab->ant_num = 2;
+	sat_tab->ant_num_total = MAX_PATH_NUM_8822B;
+	sat_tab->first_train_ant = MAIN_ANT;
+
+	sat_tab->fix_beam_pattern_en = 0;
+	sat_tab->decision_holding_period = 0;
 
-	/*beam training setting*/
-	pdm_sat_table->pkt_counter = 0;
-	pdm_sat_table->per_beam_training_pkt_num = 10;
+	/*@beam training setting*/
+	sat_tab->pkt_counter = 0;
+	sat_tab->per_beam_training_pkt_num = 10;
 
 	/*set default beam*/
-	pdm_sat_table->fast_training_beam_num = 0;
-	pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
+	sat_tab->fast_training_beam_num = 0;
+	sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
 
 	for (j = 0; j < SUPPORT_BEAM_SET_PATTERN_NUM; j++) {
-		
-		pdm_sat_table->beam_set_avg_rssi_pre[j] = 0;
-		pdm_sat_table->beam_set_train_val_diff[j] = 0;
-		pdm_sat_table->beam_set_train_cnt[j] = 0;
+		sat_tab->beam_set_avg_rssi_pre[j] = 0;
+		sat_tab->beam_set_train_val_diff[j] = 0;
+		sat_tab->beam_set_train_cnt[j] = 0;
 	}
-	phydm_set_rfu_beam_pattern_type2(p_dm);
-	p_dm_fat_table->fat_state = FAT_BEFORE_LINK_STATE;
-	
+	phydm_set_rfu_beam_pattern_type2(dm);
+	fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
 }
 #endif
 
-
-u32
-phydm_construct_hb_rfu_codeword_type2(
-	void		*p_dm_void,
-	u32		beam_set_idx
-)
+u32 phydm_construct_hb_rfu_codeword_type2(
+	void *dm_void,
+	u32 beam_set_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo		*pdm_sat_table = &(p_dm->dm_sat_table);
-	u32		sync_codeword = 0x7f;
-	u32		codeword = 0;
-	u32		data_tmp = 0;
-	u32		i;
-
-	for (i = 0; i < pdm_sat_table->ant_num_total; i++) {
-
-		if (*p_dm->p_band_type == ODM_BAND_5G)
-			data_tmp = pdm_sat_table->rfu_codeword_table_5g[beam_set_idx][i];
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u32 sync_codeword = 0x7f;
+	u32 codeword = 0;
+	u32 data_tmp = 0;
+	u32 i;
+
+	for (i = 0; i < sat_tab->ant_num_total; i++) {
+		if (*dm->band_type == ODM_BAND_5G)
+			data_tmp = sat_tab->rfu_codeword_table_5g[beam_set_idx][i];
 		else
-			data_tmp = pdm_sat_table->rfu_codeword_table_2g[beam_set_idx][i];
-			
-		codeword |= (data_tmp << (i * pdm_sat_table->rfu_each_ant_bit_num));
+			data_tmp = sat_tab->rfu_codeword_table_2g[beam_set_idx][i];
+
+		codeword |= (data_tmp << (i * sat_tab->rfu_each_ant_bit_num));
 	}
 
-	codeword = (codeword<<8) | sync_codeword;
-	
+	codeword = (codeword << 8) | sync_codeword;
+
 	return codeword;
 }
 
-void
-phydm_update_beam_pattern_type2(
-	void		*p_dm_void,
-	u32		codeword,
-	u32		codeword_length
-)
+void phydm_update_beam_pattern_type2(
+	void *dm_void,
+	u32 codeword,
+	u32 codeword_length)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
-	u8			i;
-	boolean			beam_ctrl_signal;
-	u32			one = 0x1;
-	u32			reg44_tmp_p, reg44_tmp_n, reg44_ori;
-	u8			devide_num = 4;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u8 i;
+	boolean beam_ctrl_signal;
+	u32 one = 0x1;
+	u32 reg44_tmp_p, reg44_tmp_n, reg44_ori;
+	u8 devide_num = 4;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Set codeword = ((0x%x))\n", codeword));
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Set codeword = ((0x%x))\n", codeword);
 
-	reg44_ori = odm_get_mac_reg(p_dm, 0x44, MASKDWORD);
+	reg44_ori = odm_get_mac_reg(dm, R_0x44, MASKDWORD);
 	reg44_tmp_p = reg44_ori;
-	/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44_ori =0x%x\n", reg44_ori));*/
+#if 0
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_ori =0x%x\n", reg44_ori);*/
+#endif
 
-	/*devide_num = (pdm_sat_table->rfu_protocol_type == 2) ? 8 : 4;*/
+	/*@devide_num = (sat_tab->rfu_protocol_type == 2) ? 8 : 4;*/
 
 	for (i = 0; i <= (codeword_length - 1); i++) {
 		beam_ctrl_signal = (boolean)((codeword & BIT(i)) >> i);
-		
+
 		#if 1
-		if (p_dm->debug_components & DBG_ANT_DIV) {
-
-			if (i == (codeword_length - 1)) {
-				dbg_print("%d ]\n", beam_ctrl_signal);
-				/**/
-			} else if (i == 0) {
-				dbg_print("Start sending codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
-				/**/
-			} else if ((i % devide_num) == (devide_num-1)) {
-				dbg_print("%d  |  ", beam_ctrl_signal);
-				/**/
-			} else {
-				dbg_print("%d ", beam_ctrl_signal);
-				/**/
-			}
+		if (dm->debug_components & DBG_ANT_DIV) {
+			if (i == (codeword_length - 1))
+				pr_debug("%d ]\n", beam_ctrl_signal);
+			else if (i == 0)
+				pr_debug("Start sending codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
+			else if ((i % devide_num) == (devide_num - 1))
+				pr_debug("%d  |  ", beam_ctrl_signal);
+			else
+				pr_debug("%d ", beam_ctrl_signal);
 		}
 		#endif
-		
-		if (p_dm->support_ic_type == ODM_RTL8821) {
+
+		if (dm->support_ic_type == ODM_RTL8821) {
 			#if (RTL8821A_SUPPORT == 1)
-			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*clean bit 10 & 11*/
+			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*@clean bit 10 & 11*/
 			reg44_tmp_p |= ((1 << 11) | (beam_ctrl_signal << 10));
 			reg44_tmp_n = reg44_ori & (~(BIT(11) | BIT(10)));
 
-			/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n));*/
-			odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_p);
-			odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_n);
+#if 0
+			/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n);*/
+#endif
+			odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_p);
+			odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_n);
 			#endif
 		}
 		#if (RTL8822B_SUPPORT == 1)
-		else if (p_dm->support_ic_type == ODM_RTL8822B) {
+		else if (dm->support_ic_type == ODM_RTL8822B) {
+			if (sat_tab->rfu_protocol_type == 2) {
+				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*@clean bit 8*/
+				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*@get new clk high/low, exclusive-or*/
 
-			if (pdm_sat_table->rfu_protocol_type == 2) {
+				reg44_tmp_p |= (beam_ctrl_signal << 8);
 
-				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*clean bit 8*/
-				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*get new clk high/low, exclusive-or*/
+				odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_p);
+				ODM_delay_us(sat_tab->rfu_protocol_delay_time);
+#if 0
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal);*/
+#endif
 
-	
-				reg44_tmp_p |= (beam_ctrl_signal << 8);
-				
-				odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_p);
-				ODM_delay_us(pdm_sat_table->rfu_protocol_delay_time);
-				/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal));*/
-				
 			} else {
-				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*clean bit 9 & 8*/
+				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*@clean bit 9 & 8*/
 				reg44_tmp_p |= ((1 << 9) | (beam_ctrl_signal << 8));
 				reg44_tmp_n = reg44_ori & (~(BIT(9) | BIT(8)));
 
-				/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n)); */
-				odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_p);
+#if 0
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n); */
+#endif
+				odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_p);
 				ODM_delay_us(10);
-				odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_n);
+				odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_n);
 				ODM_delay_us(10);
 			}
 		}
@@ -585,50 +615,52 @@ phydm_update_beam_pattern_type2(
 	}
 }
 
-void
-phydm_update_rx_idle_beam_type2(
-	void		*p_dm_void
-)
+void phydm_update_rx_idle_beam_type2(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct smt_ant_honbo	*pdm_sat_table = &(p_dm->dm_sat_table);
-	u32			i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u32 i;
 
-	pdm_sat_table->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(p_dm, pdm_sat_table->rx_idle_beam_set_idx);
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-Beam ] BeamSet idx = ((%d))\n", pdm_sat_table->rx_idle_beam_set_idx));
+	sat_tab->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(dm, sat_tab->rx_idle_beam_set_idx);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ Update Rx-Idle-Beam ] BeamSet idx = ((%d))\n",
+		  sat_tab->rx_idle_beam_set_idx);
 
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	phydm_update_beam_pattern_type2(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
-#else
-	odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_workitem);
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#endif
+#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+		odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+#if 0
 	/*odm_stall_execution(1);*/
+#endif
 #endif
 
-	pdm_sat_table->pre_codeword = pdm_sat_table->update_beam_codeword;
+	sat_tab->pre_codeword = sat_tab->update_beam_codeword;
 }
 
-
-void
-phydm_hl_smart_ant_debug_type2(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
+void phydm_hl_smt_ant_dbg_type2(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len
 )
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-	u32			one = 0x1;
-	u32			codeword_length = pdm_sat_table->rfu_codeword_total_bit_num;
-	u32			beam_ctrl_signal, i;
-	u8			devide_num = 4;
-	char			help[] = "-h";
-	u32			dm_value[10] = {0};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 one = 0x1;
+	u32 codeword_length = sat_tab->rfu_codeword_total_bit_num;
+	u32 beam_ctrl_signal, i;
+	u8 devide_num = 4;
+	char help[] = "-h";
+	u32 dm_value[10] = {0};
 
 	PHYDM_SSCANF(input[1], DCMD_DECIMAL, &dm_value[0]);
 	PHYDM_SSCANF(input[2], DCMD_DECIMAL, &dm_value[1]);
@@ -636,295 +668,350 @@ phydm_hl_smart_ant_debug_type2(
 	PHYDM_SSCANF(input[4], DCMD_DECIMAL, &dm_value[3]);
 	PHYDM_SSCANF(input[5], DCMD_DECIMAL, &dm_value[4]);
 
-
 	if (strcmp(input[1], help) == 0) {
-		PHYDM_SNPRINTF((output + used, out_len - used, " 1 {fix_en} {codeword(Hex)}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, " 3 {Fix_training_num_en} {Per_beam_training_pkt_num} {Decision_holding_period}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, " 5 {0:show, 1:2G, 2:5G} {beam_num} {idxA(Hex)} {idxB(Hex)}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, " 7 {0:show, 1:2G, 2:5G} {total_beam_set_num}\n"));
-		PHYDM_SNPRINTF((output + used, out_len - used, " 8 {0:show, 1:set} {RFU delay time(us)}\n"));
-
-	} else if (dm_value[0] == 1) { /*fix beam pattern*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 " 1 {fix_en} {codeword(Hex)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 " 3 {Fix_training_num_en} {Per_beam_training_pkt_num} {Decision_holding_period}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 " 5 {0:show, 1:2G, 2:5G} {beam_num} {idxA(Hex)} {idxB(Hex)}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 " 7 {0:show, 1:2G, 2:5G} {total_beam_set_num}\n");
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 " 8 {0:show, 1:set} {RFU delay time(us)}\n");
+
+	} else if (dm_value[0] == 1) { /*@fix beam pattern*/
+
+		sat_tab->fix_beam_pattern_en = dm_value[1];
+
+		if (sat_tab->fix_beam_pattern_en == 1) {
+			PHYDM_SSCANF(input[3], DCMD_HEX, &dm_value[2]);
+			sat_tab->fix_beam_pattern_codeword = dm_value[2];
 
-		pdm_sat_table->fix_beam_pattern_en = dm_value[1];
+			if (sat_tab->fix_beam_pattern_codeword > (one << codeword_length)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
+					  sat_tab->fix_beam_pattern_codeword,
+					  codeword_length);
 
-		if (pdm_sat_table->fix_beam_pattern_en == 1) {
+				(sat_tab->fix_beam_pattern_codeword) &= 0xffffff;
 
-			PHYDM_SSCANF(input[3], DCMD_HEX, &dm_value[2]);
-			pdm_sat_table->fix_beam_pattern_codeword = dm_value[2];
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[ SmartAnt ] Auto modify to (0x%x)\n",
+					  sat_tab->fix_beam_pattern_codeword);
+			}
 
-			if (pdm_sat_table->fix_beam_pattern_codeword  > (one << codeword_length)) {
+			sat_tab->update_beam_codeword = sat_tab->fix_beam_pattern_codeword;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
-					pdm_sat_table->fix_beam_pattern_codeword, codeword_length));
-				
-				(pdm_sat_table->fix_beam_pattern_codeword) &= 0xffffff;
-				
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Auto modify to (0x%x)\n", pdm_sat_table->fix_beam_pattern_codeword));
-			}
+			/*@---------------------------------------------------------*/
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Fix Beam Pattern\n");
 
-			pdm_sat_table->update_beam_codeword = pdm_sat_table->fix_beam_pattern_codeword;
+			/*@devide_num = (sat_tab->rfu_protocol_type == 2) ? 8 : 4;*/
 
-			/*---------------------------------------------------------*/
-			PHYDM_SNPRINTF((output + used, out_len - used, "Fix Beam Pattern\n"));
-			
-			/*devide_num = (pdm_sat_table->rfu_protocol_type == 2) ? 8 : 4;*/
-			
 			for (i = 0; i <= (codeword_length - 1); i++) {
-				beam_ctrl_signal = (boolean)((pdm_sat_table->update_beam_codeword & BIT(i)) >> i);
-
-				if (i == (codeword_length - 1)) {
-					PHYDM_SNPRINTF((output + used, out_len - used, "%d]\n", beam_ctrl_signal));
-					/**/
-				} else if (i == 0) {
-					PHYDM_SNPRINTF((output + used, out_len - used, "Send Codeword[1:%d] to RFU -> [%d", pdm_sat_table->rfu_codeword_total_bit_num, beam_ctrl_signal));
-					/**/
-				} else if ((i % devide_num) == (devide_num-1)) {
-					PHYDM_SNPRINTF((output + used, out_len - used, "%d|", beam_ctrl_signal));
-					/**/
-				} else {
-					PHYDM_SNPRINTF((output + used, out_len - used, "%d", beam_ctrl_signal));
-					/**/
-				}
+				beam_ctrl_signal = (boolean)((sat_tab->update_beam_codeword & BIT(i)) >> i);
+
+				if (i == (codeword_length - 1))
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used,
+						 "%d]\n",
+						 beam_ctrl_signal);
+				else if (i == 0)
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used,
+						 "Send Codeword[1:%d] to RFU -> [%d",
+						 sat_tab->rfu_codeword_total_bit_num,
+						 beam_ctrl_signal);
+				else if ((i % devide_num) == (devide_num - 1))
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used, "%d|",
+						 beam_ctrl_signal);
+				else
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used, "%d",
+						 beam_ctrl_signal);
 			}
-			/*---------------------------------------------------------*/
-
+/*@---------------------------------------------------------*/
 
-			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-			phydm_update_beam_pattern_type2(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
-			#else
-			odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_workitem);
+#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			if (dm->support_interface == ODM_ITRF_PCIE)
+				phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#endif
+#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+			if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+			odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+#if 0
 			/*odm_stall_execution(1);*/
-			#endif
-		} else if (pdm_sat_table->fix_beam_pattern_en == 0)
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Smart Antenna: Enable\n"));
+#endif
+#endif
+		} else if (sat_tab->fix_beam_pattern_en == 0)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] Smart Antenna: Enable\n");
 
 	} else if (dm_value[0] == 2) { /*set latch time*/
 
-		pdm_sat_table->latch_time = dm_value[1];
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ]  latch_time =0x%x\n", pdm_sat_table->latch_time));
+		sat_tab->latch_time = dm_value[1];
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ]  latch_time =0x%x\n",
+			  sat_tab->latch_time);
 	} else if (dm_value[0] == 3) {
+		sat_tab->fix_training_num_en = dm_value[1];
 
-		pdm_sat_table->fix_training_num_en = dm_value[1];
-
-		if (pdm_sat_table->fix_training_num_en == 1) {
-			pdm_sat_table->per_beam_training_pkt_num = (u8)dm_value[2];
-			pdm_sat_table->decision_holding_period = (u8)dm_value[3];
+		if (sat_tab->fix_training_num_en == 1) {
+			sat_tab->per_beam_training_pkt_num = (u8)dm_value[2];
+			sat_tab->decision_holding_period = (u8)dm_value[3];
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
-				pdm_sat_table->fix_training_num_en, pdm_sat_table->per_beam_training_pkt_num, pdm_sat_table->decision_holding_period));
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[SmtAnt] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
+				 sat_tab->fix_training_num_en,
+				 sat_tab->per_beam_training_pkt_num,
+				 sat_tab->decision_holding_period);
 
-		} else if (pdm_sat_table->fix_training_num_en == 0) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n"));
-			/**/
+		} else if (sat_tab->fix_training_num_en == 0) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n");
 		}
 	} else if (dm_value[0] == 4) {
 		#if 0
 		if (dm_value[1] == 1) {
-			pdm_sat_table->ant_num = 1;
-			pdm_sat_table->first_train_ant = MAIN_ANT;
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = MAIN_ANT;
 
 		} else if (dm_value[1] == 2) {
-			pdm_sat_table->ant_num = 1;
-			pdm_sat_table->first_train_ant = AUX_ANT;
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = AUX_ANT;
 
 		} else if (dm_value[1] == 3) {
-			pdm_sat_table->ant_num = 2;
-			pdm_sat_table->first_train_ant = MAIN_ANT;
+			sat_tab->ant_num = 2;
+			sat_tab->first_train_ant = MAIN_ANT;
 		}
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
-			pdm_sat_table->ant_num, (pdm_sat_table->first_train_ant - 1)));
+		PDM_SNPF((output + used, out_len - used,
+			 "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
+			 sat_tab->ant_num, (sat_tab->first_train_ant - 1)));
 		#endif
-	} else if (dm_value[0] == 5) {	/*set beam set table*/
+	} else if (dm_value[0] == 5) { /*set beam set table*/
 
 		PHYDM_SSCANF(input[4], DCMD_HEX, &dm_value[3]);
 		PHYDM_SSCANF(input[5], DCMD_HEX, &dm_value[4]);
 
-		if (dm_value[1] == 1) { /*2G*/
+		if (dm_value[1] == 1) { /*@2G*/
 			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
-				pdm_sat_table->rfu_codeword_table_2g[dm_value[2] ][0] = (u8)dm_value[3];
-				pdm_sat_table->rfu_codeword_table_2g[dm_value[2] ][1] = (u8)dm_value[4];
-				PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] Set 2G Table[%d] = [A:0x%x, B:0x%x]\n",dm_value[2], dm_value[3], dm_value[4]));
+				sat_tab->rfu_codeword_table_2g[dm_value[2]][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_2g[dm_value[2]][1] = (u8)dm_value[4];
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "[SmtAnt] Set 2G Table[%d] = [A:0x%x, B:0x%x]\n",
+					 dm_value[2], dm_value[3], dm_value[4]);
 			}
-			
-		} else if (dm_value[1] == 2) { /*5G*/
+
+		} else if (dm_value[1] == 2) { /*@5G*/
 			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
-				pdm_sat_table->rfu_codeword_table_5g[dm_value[2] ][0] = (u8)dm_value[3];
-				pdm_sat_table->rfu_codeword_table_5g[dm_value[2] ][1] = (u8)dm_value[4];
-				PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",dm_value[2], dm_value[3], dm_value[4]));
+				sat_tab->rfu_codeword_table_5g[dm_value[2]][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_5g[dm_value[2]][1] = (u8)dm_value[4];
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					 dm_value[2], dm_value[3], dm_value[4]);
 			}
-		} else  if (dm_value[1] == 0) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] 2G Beam Table==============>\n"));
-			for (i = 0; i < pdm_sat_table->total_beam_set_num_2g; i++) {
-				PHYDM_SNPRINTF((output + used, out_len - used, "2G Table[%d] = [A:0x%x, B:0x%x]\n",
-					i, pdm_sat_table->rfu_codeword_table_2g[i][0], pdm_sat_table->rfu_codeword_table_2g[i][1]));
+		} else if (dm_value[1] == 0) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[SmtAnt] 2G Beam Table==============>\n");
+			for (i = 0; i < sat_tab->total_beam_set_num_2g; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "2G Table[%d] = [A:0x%x, B:0x%x]\n", i,
+					 sat_tab->rfu_codeword_table_2g[i][0],
+					 sat_tab->rfu_codeword_table_2g[i][1]);
 			}
-			PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] 5G Beam Table==============>\n"));
-			for (i = 0; i < pdm_sat_table->total_beam_set_num_5g; i++) {
-				PHYDM_SNPRINTF((output + used, out_len - used, "5G Table[%d] = [A:0x%x, B:0x%x]\n",
-					i, pdm_sat_table->rfu_codeword_table_5g[i][0], pdm_sat_table->rfu_codeword_table_5g[i][1]));
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[SmtAnt] 5G Beam Table==============>\n");
+			for (i = 0; i < sat_tab->total_beam_set_num_5g; i++) {
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "5G Table[%d] = [A:0x%x, B:0x%x]\n", i,
+					 sat_tab->rfu_codeword_table_5g[i][0],
+					 sat_tab->rfu_codeword_table_5g[i][1]);
 			}
 		}
 
 	} else if (dm_value[0] == 6) {
-		#if 0
+#if 0
 		if (dm_value[1] == 0) {
 			if (dm_value[2] < SUPPORT_BEAM_SET_PATTERN_NUM) {
-				pdm_sat_table->rfu_codeword_table_5g[dm_value[2] ][0] = (u8)dm_value[3];
-				pdm_sat_table->rfu_codeword_table_5g[dm_value[2] ][1] = (u8)dm_value[4];
-				PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",dm_value[2], dm_value[3], dm_value[4]));
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][0] = (u8)dm_value[3];
+				sat_tab->rfu_codeword_table_5g[dm_value[2] ][1] = (u8)dm_value[4];
+				PDM_SNPF((output + used, out_len - used,
+					 "[SmtAnt] Set5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					 dm_value[2], dm_value[3],
+					 dm_value[4]));
 			}
 		} else {
-			for (i = 0; i < pdm_sat_table->total_beam_set_num_5g; i++) {
-				PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] Read 5G Table[%d] = [A:0x%x, B:0x%x]\n",
-					i, pdm_sat_table->rfu_codeword_table_5g[i][0], pdm_sat_table->rfu_codeword_table_5g[i][1]));
+			for (i = 0; i < sat_tab->total_beam_set_num_5g; i++) {
+				PDM_SNPF((output + used, out_len - used,
+					 "[SmtAnt] Read 5G Table[%d] = [A:0x%x, B:0x%x]\n",
+					 i,
+					 sat_tab->rfu_codeword_table_5g[i][0],
+					 sat_tab->rfu_codeword_table_5g[i][1]));
 			}
 		}
-		#endif
+#endif
 	} else if (dm_value[0] == 7) {
-
 		if (dm_value[1] == 1) {
-
-			pdm_sat_table->total_beam_set_num_2g = (u8)(dm_value[2]);
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] total_beam_set_num_2g = ((%d))\n", pdm_sat_table->total_beam_set_num_2g));
+			sat_tab->total_beam_set_num_2g = (u8)(dm_value[2]);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] total_beam_set_num_2g = ((%d))\n",
+				 sat_tab->total_beam_set_num_2g);
 
 		} else if (dm_value[1] == 2) {
-
-			pdm_sat_table->total_beam_set_num_5g = (u8)(dm_value[2]);
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] total_beam_set_num_5g = ((%d))\n", pdm_sat_table->total_beam_set_num_5g));
+			sat_tab->total_beam_set_num_5g = (u8)(dm_value[2]);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] total_beam_set_num_5g = ((%d))\n",
+				 sat_tab->total_beam_set_num_5g);
 		} else if (dm_value[1] == 0) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Show total_beam_set_num{2g,5g} = {%d,%d}\n", 
-				pdm_sat_table->total_beam_set_num_2g, pdm_sat_table->total_beam_set_num_5g));
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] Show total_beam_set_num{2g,5g} = {%d,%d}\n",
+				 sat_tab->total_beam_set_num_2g,
+				 sat_tab->total_beam_set_num_5g);
 		}
 
 	} else if (dm_value[0] == 8) {
-
-			if (dm_value[1] == 1) {
-				pdm_sat_table->rfu_protocol_delay_time = (u16)(dm_value[2]);
-				PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] Set rfu_protocol_delay_time = ((%d))\n", pdm_sat_table->rfu_protocol_delay_time));
-			} else if (dm_value[1] == 0) {
-				PHYDM_SNPRINTF((output + used, out_len - used, "[SmtAnt] Read rfu_protocol_delay_time = ((%d))\n", pdm_sat_table->rfu_protocol_delay_time));
-			}
+		if (dm_value[1] == 1) {
+			sat_tab->rfu_protocol_delay_time = (u16)(dm_value[2]);
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[SmtAnt] Set rfu_protocol_delay_time = ((%d))\n",
+				 sat_tab->rfu_protocol_delay_time);
+		} else if (dm_value[1] == 0) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[SmtAnt] Read rfu_protocol_delay_time = ((%d))\n",
+				 sat_tab->rfu_protocol_delay_time);
+		}
 	}
 
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_set_rfu_beam_pattern_type2(
-	void		*p_dm_void
-)
+void phydm_set_rfu_beam_pattern_type2(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo	*pdm_sat_table = &(p_dm->dm_sat_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
 
-	if (p_dm->ant_div_type != HL_SW_SMART_ANT_TYPE2)
+	if (dm->ant_div_type != HL_SW_SMART_ANT_TYPE2)
 		return;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Training beam_set index = (( 0x%x ))\n", pdm_sat_table->fast_training_beam_num));
-	pdm_sat_table->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(p_dm, pdm_sat_table->fast_training_beam_num);
+	PHYDM_DBG(dm, DBG_ANT_DIV, "Training beam_set index = (( 0x%x ))\n",
+		  sat_tab->fast_training_beam_num);
+	sat_tab->update_beam_codeword = phydm_construct_hb_rfu_codeword_type2(dm, sat_tab->fast_training_beam_num);
 
 	#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	phydm_update_beam_pattern_type2(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
-	#else
-	odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_workitem);
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+	#endif
+	#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+		odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+#if 0
 	/*odm_stall_execution(1);*/
+#endif
 	#endif
 }
 
-void
-phydm_fast_ant_training_hl_smart_antenna_type2(
-	void		*p_dm_void
-)
+void phydm_fast_ant_training_hl_smart_antenna_type2(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo	*pdm_sat_table = &(p_dm->dm_sat_table);
-	struct phydm_fat_struct		*p_dm_fat_table	 = &(p_dm->dm_fat_table);
-	struct _sw_antenna_switch_				*p_dm_swat_table = &p_dm->dm_swat_table;
-	u32		codeword = 0;
-	u8		i = 0, j=0;
-	u8		avg_rssi_tmp;
-	u8		avg_rssi_tmp_ma;
-	u8		max_beam_ant_rssi = 0;
-	u8		rssi_target_beam = 0, target_beam_max_rssi = 0;
-	u8		evm1ss_target_beam = 0, evm2ss_target_beam = 0;
-	u32		target_beam_max_evm1ss = 0, target_beam_max_evm2ss = 0;
-	u32		beam_tmp;
-	u8		per_beam_val_diff_tmp = 0, training_pkt_num_offset;
-	u32		avg_evm2ss[2] = {0}, avg_evm2ss_sum = 0;
-	u32		avg_evm1ss = 0;
-	u32		beam_path_evm_2ss_cnt_all = 0; /*sum of all 2SS-pattern cnt*/
-	u32		beam_path_evm_1ss_cnt_all = 0; /*sum of all 1SS-pattern cnt*/
-	u8		decision_type;
-
-	if (!p_dm->is_linked) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[No Link!!!]\n"));
-
-		if (p_dm_fat_table->is_become_linked == true) {
-
-			pdm_sat_table->decision_holding_period = 0;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Link->no Link\n"));
-			p_dm_fat_table->fat_state = FAT_BEFORE_LINK_STATE;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("change to (( %d )) FAT_state\n", p_dm_fat_table->fat_state));
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct sw_antenna_switch *dm_swat_table = &dm->dm_swat_table;
+	u32 codeword = 0;
+	u8 i = 0, j = 0;
+	u8 avg_rssi_tmp;
+	u8 avg_rssi_tmp_ma;
+	u8 max_beam_ant_rssi = 0;
+	u8 rssi_target_beam = 0, target_beam_max_rssi = 0;
+	u8 evm1ss_target_beam = 0, evm2ss_target_beam = 0;
+	u32 target_beam_max_evm1ss = 0, target_beam_max_evm2ss = 0;
+	u32 beam_tmp;
+	u8 per_beam_val_diff_tmp = 0, training_pkt_num_offset;
+	u32 avg_evm2ss[2] = {0}, avg_evm2ss_sum = 0;
+	u32 avg_evm1ss = 0;
+	u32 beam_path_evm_2ss_cnt_all = 0; /*sum of all 2SS-pattern cnt*/
+	u32 beam_path_evm_1ss_cnt_all = 0; /*sum of all 1SS-pattern cnt*/
+	u8 decision_type;
+
+	if (!dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			sat_tab->decision_holding_period = 0;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Link->no Link\n");
+			fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "change to (( %d )) FAT_state\n",
+				  fat_tab->fat_state);
+			fat_tab->is_become_linked = dm->is_linked;
 		}
 		return;
 
 	} else {
-		if (p_dm_fat_table->is_become_linked == false) {
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Linked !!!]\n"));
+			fat_tab->fat_state = FAT_PREPARE_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "change to (( %d )) FAT_state\n",
+				  fat_tab->fat_state);
 
-			p_dm_fat_table->fat_state = FAT_PREPARE_STATE;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("change to (( %d )) FAT_state\n", p_dm_fat_table->fat_state));
+			/*sat_tab->fast_training_beam_num = 0;*/
+			/*phydm_set_rfu_beam_pattern_type2(dm);*/
 
-			/*pdm_sat_table->fast_training_beam_num = 0;*/
-			/*phydm_set_rfu_beam_pattern_type2(p_dm);*/
-
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+			fat_tab->is_become_linked = dm->is_linked;
 		}
 	}
 
+#if 0
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "HL Smart ant Training: state (( %d ))\n", fat_tab->fat_state);*/
+#endif
 
-	/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("HL Smart ant Training: state (( %d ))\n", p_dm_fat_table->fat_state));*/
-
-	/* [DECISION STATE] */
-	/*=======================================================================================*/
-	if (p_dm_fat_table->fat_state == FAT_DECISION_STATE) {
-
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 3. In Decision state]\n"));
-
-		/*compute target beam in each antenna*/
+	/* @[DECISION STATE] */
+	/*@=======================================================================================*/
+	if (fat_tab->fat_state == FAT_DECISION_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 3. In Decision state]\n");
 
-		for (j = 0; j < (pdm_sat_table->total_beam_set_num); j++) {
+		/*@compute target beam in each antenna*/
 
-			/*[Decision1: RSSI]-------------------------------------------------------------------*/
-			if (pdm_sat_table->statistic_pkt_cnt[j] == 0) {	/*if new RSSI = 0 -> MA_RSSI-=2*/
-				avg_rssi_tmp = pdm_sat_table->beam_set_avg_rssi_pre[j];
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			/*@[Decision1: RSSI]-------------------------------------------------------------------*/
+			if (sat_tab->statistic_pkt_cnt[j] == 0) { /*@if new RSSI = 0 -> MA_RSSI-=2*/
+				avg_rssi_tmp = sat_tab->beam_set_avg_rssi_pre[j];
 				avg_rssi_tmp = (avg_rssi_tmp >= 2) ? (avg_rssi_tmp - 2) : avg_rssi_tmp;
 				avg_rssi_tmp_ma = avg_rssi_tmp;
 			} else {
-				avg_rssi_tmp = (u8)((pdm_sat_table->beam_set_rssi_avg_sum[j]) / (pdm_sat_table->statistic_pkt_cnt[j]));
-				avg_rssi_tmp_ma = (avg_rssi_tmp + pdm_sat_table->beam_set_avg_rssi_pre[j]) >> 1;
+				avg_rssi_tmp = (u8)((sat_tab->beam_set_rssi_avg_sum[j]) / (sat_tab->statistic_pkt_cnt[j]));
+				avg_rssi_tmp_ma = (avg_rssi_tmp + sat_tab->beam_set_avg_rssi_pre[j]) >> 1;
 			}
 
-			pdm_sat_table->beam_set_avg_rssi_pre[j] = avg_rssi_tmp;
+			sat_tab->beam_set_avg_rssi_pre[j] = avg_rssi_tmp;
 
 			if (avg_rssi_tmp > target_beam_max_rssi) {
 				rssi_target_beam = j;
 				target_beam_max_rssi = avg_rssi_tmp;
 			}
 
-			/*[Decision2: EVM 2ss]-------------------------------------------------------------------*/
-			if (pdm_sat_table->beam_path_evm_2ss_cnt[j] != 0) {
-				avg_evm2ss[0] =  pdm_sat_table->beam_path_evm_2ss_sum[j][0] / pdm_sat_table->beam_path_evm_2ss_cnt[j];
-				avg_evm2ss[1] =  pdm_sat_table->beam_path_evm_2ss_sum[j][1] / pdm_sat_table->beam_path_evm_2ss_cnt[j];
+			/*@[Decision2: EVM 2ss]-------------------------------------------------------------------*/
+			if (sat_tab->beam_path_evm_2ss_cnt[j] != 0) {
+				avg_evm2ss[0] = sat_tab->beam_path_evm_2ss_sum[j][0] / sat_tab->beam_path_evm_2ss_cnt[j];
+				avg_evm2ss[1] = sat_tab->beam_path_evm_2ss_sum[j][1] / sat_tab->beam_path_evm_2ss_cnt[j];
 				avg_evm2ss_sum = avg_evm2ss[0] + avg_evm2ss[1];
-				beam_path_evm_2ss_cnt_all += pdm_sat_table->beam_path_evm_2ss_cnt[j];
+				beam_path_evm_2ss_cnt_all += sat_tab->beam_path_evm_2ss_cnt[j];
 
-				pdm_sat_table->beam_set_avg_evm_2ss_pre[j] = (u8)avg_evm2ss_sum;
+				sat_tab->beam_set_avg_evm_2ss_pre[j] = (u8)avg_evm2ss_sum;
 			}
 
 			if (avg_evm2ss_sum > target_beam_max_evm2ss) {
@@ -932,578 +1019,590 @@ phydm_fast_ant_training_hl_smart_antenna_type2(
 				target_beam_max_evm2ss = avg_evm2ss_sum;
 			}
 
-			/*[Decision3: EVM 1ss]-------------------------------------------------------------------*/
-			if (pdm_sat_table->beam_path_evm_1ss_cnt[j] != 0) {
-				avg_evm1ss =  pdm_sat_table->beam_path_evm_1ss_sum[j] / pdm_sat_table->beam_path_evm_1ss_cnt[j];
-				beam_path_evm_1ss_cnt_all += pdm_sat_table->beam_path_evm_1ss_cnt[j];
+			/*@[Decision3: EVM 1ss]-------------------------------------------------------------------*/
+			if (sat_tab->beam_path_evm_1ss_cnt[j] != 0) {
+				avg_evm1ss = sat_tab->beam_path_evm_1ss_sum[j] / sat_tab->beam_path_evm_1ss_cnt[j];
+				beam_path_evm_1ss_cnt_all += sat_tab->beam_path_evm_1ss_cnt[j];
 
-				pdm_sat_table->beam_set_avg_evm_1ss_pre[j] = (u8)avg_evm1ss;
+				sat_tab->beam_set_avg_evm_1ss_pre[j] = (u8)avg_evm1ss;
 			}
-				
+
 			if (avg_evm1ss > target_beam_max_evm1ss) {
 				evm1ss_target_beam = j;
 				target_beam_max_evm1ss = avg_evm1ss;
 			}
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Beam[%d] Pkt_cnt=(( %d )), avg{MA,rssi}={%d, %d}, EVM1={%d}, EVM2={%d, %d, %d}\n",
-				j, pdm_sat_table->statistic_pkt_cnt[j], avg_rssi_tmp_ma, avg_rssi_tmp, avg_evm1ss, avg_evm2ss[0], avg_evm2ss[1], avg_evm2ss_sum));
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Beam[%d] Pkt_cnt=(( %d )), avg{MA,rssi}={%d, %d}, EVM1={%d}, EVM2={%d, %d, %d}\n",
+				  j, sat_tab->statistic_pkt_cnt[j],
+				  avg_rssi_tmp_ma, avg_rssi_tmp, avg_evm1ss,
+				  avg_evm2ss[0], avg_evm2ss[1], avg_evm2ss_sum);
 
 			/*reset counter value*/
-			pdm_sat_table->beam_set_rssi_avg_sum[j] = 0;
-			pdm_sat_table->beam_path_rssi_sum[j][0] = 0;
-			pdm_sat_table->beam_path_rssi_sum[j][1] = 0;
-			pdm_sat_table->statistic_pkt_cnt[j] = 0;
-			
-			pdm_sat_table->beam_path_evm_2ss_sum[j][0] = 0;
-			pdm_sat_table->beam_path_evm_2ss_sum[j][1] = 0;
-			pdm_sat_table->beam_path_evm_2ss_cnt[j] = 0;
-			
-			pdm_sat_table->beam_path_evm_1ss_sum[j] = 0;
-			pdm_sat_table->beam_path_evm_1ss_cnt[j] = 0;
+			sat_tab->beam_set_rssi_avg_sum[j] = 0;
+			sat_tab->beam_path_rssi_sum[j][0] = 0;
+			sat_tab->beam_path_rssi_sum[j][1] = 0;
+			sat_tab->statistic_pkt_cnt[j] = 0;
+
+			sat_tab->beam_path_evm_2ss_sum[j][0] = 0;
+			sat_tab->beam_path_evm_2ss_sum[j][1] = 0;
+			sat_tab->beam_path_evm_2ss_cnt[j] = 0;
+
+			sat_tab->beam_path_evm_1ss_sum[j] = 0;
+			sat_tab->beam_path_evm_1ss_cnt[j] = 0;
 		}
-		
-		/*[Joint Decision]-------------------------------------------------------------------*/
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("--->1.[RSSI]      Target Beam(( %d )) RSSI_max=((%d))\n", rssi_target_beam, target_beam_max_rssi));
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("--->2.[Evm2SS] Target Beam(( %d )) EVM2SS_max=((%d))\n", evm2ss_target_beam, target_beam_max_evm2ss));
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("--->3.[Evm1SS] Target Beam(( %d )) EVM1SS_max=((%d))\n", evm1ss_target_beam, target_beam_max_evm1ss));
+
+		/*@[Joint Decision]-------------------------------------------------------------------*/
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "--->1.[RSSI]      Target Beam(( %d )) RSSI_max=((%d))\n",
+			  rssi_target_beam, target_beam_max_rssi);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "--->2.[Evm2SS] Target Beam(( %d )) EVM2SS_max=((%d))\n",
+			  evm2ss_target_beam, target_beam_max_evm2ss);
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "--->3.[Evm1SS] Target Beam(( %d )) EVM1SS_max=((%d))\n",
+			  evm1ss_target_beam, target_beam_max_evm1ss);
 
 		if (target_beam_max_rssi <= 10) {
-			pdm_sat_table->rx_idle_beam_set_idx = rssi_target_beam;
+			sat_tab->rx_idle_beam_set_idx = rssi_target_beam;
 			decision_type = 1;
 		} else {
 			if (beam_path_evm_2ss_cnt_all != 0) {
-				pdm_sat_table->rx_idle_beam_set_idx = evm2ss_target_beam;
+				sat_tab->rx_idle_beam_set_idx = evm2ss_target_beam;
 				decision_type = 2;
 			} else if (beam_path_evm_1ss_cnt_all != 0) {
-				pdm_sat_table->rx_idle_beam_set_idx = evm1ss_target_beam;
+				sat_tab->rx_idle_beam_set_idx = evm1ss_target_beam;
 				decision_type = 3;
 			} else {
-				pdm_sat_table->rx_idle_beam_set_idx = rssi_target_beam;
+				sat_tab->rx_idle_beam_set_idx = rssi_target_beam;
 				decision_type = 1;
 			}
 		}
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("---> Decision_type=((%d)), Final Target Beam(( %d ))\n", decision_type, pdm_sat_table->rx_idle_beam_set_idx));
-
-		/*Calculate packet counter offset*/
-		for (j = 0; j < (pdm_sat_table->total_beam_set_num); j++) {
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "---> Decision_type=((%d)), Final Target Beam(( %d ))\n",
+			  decision_type, sat_tab->rx_idle_beam_set_idx);
 
+		/*@Calculate packet counter offset*/
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
 			if (decision_type == 1) {
-				per_beam_val_diff_tmp = target_beam_max_rssi - pdm_sat_table->beam_set_avg_rssi_pre[j];
-				
+				per_beam_val_diff_tmp = target_beam_max_rssi - sat_tab->beam_set_avg_rssi_pre[j];
+
 			} else if (decision_type == 2) {
-				per_beam_val_diff_tmp = ((u8)target_beam_max_evm2ss - pdm_sat_table->beam_set_avg_evm_2ss_pre[j]) >> 1;
+				per_beam_val_diff_tmp = ((u8)target_beam_max_evm2ss - sat_tab->beam_set_avg_evm_2ss_pre[j]) >> 1;
 			} else if (decision_type == 3) {
-				per_beam_val_diff_tmp = (u8)target_beam_max_evm1ss - pdm_sat_table->beam_set_avg_evm_1ss_pre[j];
+				per_beam_val_diff_tmp = (u8)target_beam_max_evm1ss - sat_tab->beam_set_avg_evm_1ss_pre[j];
 			}
-			pdm_sat_table->beam_set_train_val_diff[j] = per_beam_val_diff_tmp;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Beam_Set[%d]: diff= ((%d))\n", j, per_beam_val_diff_tmp));
+			sat_tab->beam_set_train_val_diff[j] = per_beam_val_diff_tmp;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Beam_Set[%d]: diff= ((%d))\n", j,
+				  per_beam_val_diff_tmp);
 		}
 
 		/*set beam in each antenna*/
-		phydm_update_rx_idle_beam_type2(p_dm);
-		p_dm_fat_table->fat_state = FAT_PREPARE_STATE;
-
+		phydm_update_rx_idle_beam_type2(dm);
+		fat_tab->fat_state = FAT_PREPARE_STATE;
 	}
-	/* [TRAINING STATE] */
-	else if (p_dm_fat_table->fat_state == FAT_TRAINING_STATE) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2. In Training state]\n"));
+	/* @[TRAINING STATE] */
+	else if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2. In Training state]\n");
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("curr_beam_idx = (( %d )), pre_beam_idx = (( %d ))\n",
-			pdm_sat_table->fast_training_beam_num, pdm_sat_table->pre_fast_training_beam_num));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "curr_beam_idx = (( %d )), pre_beam_idx = (( %d ))\n",
+			  sat_tab->fast_training_beam_num,
+			  sat_tab->pre_fast_training_beam_num);
 
-		if (pdm_sat_table->fast_training_beam_num > pdm_sat_table->pre_fast_training_beam_num)
+		if (sat_tab->fast_training_beam_num > sat_tab->pre_fast_training_beam_num)
 
-			pdm_sat_table->force_update_beam_en = 0;
+			sat_tab->force_update_beam_en = 0;
 
 		else {
+			sat_tab->force_update_beam_en = 1;
 
-			pdm_sat_table->force_update_beam_en = 1;
-
-			pdm_sat_table->pkt_counter = 0;
-			beam_tmp = pdm_sat_table->fast_training_beam_num;
-			if (pdm_sat_table->fast_training_beam_num >= ((u32)pdm_sat_table->total_beam_set_num - 1)) {
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n", pdm_sat_table->fast_training_beam_num));
-				p_dm_fat_table->fat_state = FAT_DECISION_STATE;
-				phydm_fast_ant_training_hl_smart_antenna_type2(p_dm);
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+			if (sat_tab->fast_training_beam_num >= ((u32)sat_tab->total_beam_set_num - 1)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n",
+					  sat_tab->fast_training_beam_num);
+				fat_tab->fat_state = FAT_DECISION_STATE;
+				phydm_fast_ant_training_hl_smart_antenna_type2(dm);
 
 			} else {
-				pdm_sat_table->fast_training_beam_num++;
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, pdm_sat_table->fast_training_beam_num));
-				phydm_set_rfu_beam_pattern_type2(p_dm);
-				p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
-
+				sat_tab->fast_training_beam_num++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n",
+					  beam_tmp,
+					  sat_tab->fast_training_beam_num);
+				phydm_set_rfu_beam_pattern_type2(dm);
+				fat_tab->fat_state = FAT_TRAINING_STATE;
 			}
 		}
-		pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Update Pre_Beam =(( %d ))\n", pdm_sat_table->pre_fast_training_beam_num));
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		PHYDM_DBG(dm, DBG_ANT_DIV, "Update Pre_Beam =(( %d ))\n",
+			  sat_tab->pre_fast_training_beam_num);
 	}
-	/*  [Prepare state] */
-	/*=======================================================================================*/
-	else if (p_dm_fat_table->fat_state == FAT_PREPARE_STATE) {
-
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\n\n[ 1. In Prepare state]\n"));
-
-		if (p_dm->pre_traffic_load == (p_dm->traffic_load)) {
-			if (pdm_sat_table->decision_holding_period != 0) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Holding_period = (( %d )), return!!!\n", pdm_sat_table->decision_holding_period));
-				pdm_sat_table->decision_holding_period--;
+	/*  @[Prepare state] */
+	/*@=======================================================================================*/
+	else if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n\n[ 1. In Prepare state]\n");
+
+		if (dm->pre_traffic_load == dm->traffic_load) {
+			if (sat_tab->decision_holding_period != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Holding_period = (( %d )), return!!!\n",
+					  sat_tab->decision_holding_period);
+				sat_tab->decision_holding_period--;
 				return;
 			}
 		}
 
 		/* Set training packet number*/
-		if (pdm_sat_table->fix_training_num_en == 0) {
-
-			switch (p_dm->traffic_load) {
-
+		if (sat_tab->fix_training_num_en == 0) {
+			switch (dm->traffic_load) {
 			case TRAFFIC_HIGH:
-				pdm_sat_table->per_beam_training_pkt_num = 8;
-				pdm_sat_table->decision_holding_period = 2;
+				sat_tab->per_beam_training_pkt_num = 8;
+				sat_tab->decision_holding_period = 2;
 				break;
 			case TRAFFIC_MID:
-				pdm_sat_table->per_beam_training_pkt_num = 6;
-				pdm_sat_table->decision_holding_period = 3;
+				sat_tab->per_beam_training_pkt_num = 6;
+				sat_tab->decision_holding_period = 3;
 				break;
 			case TRAFFIC_LOW:
-				pdm_sat_table->per_beam_training_pkt_num = 3; /*ping 60000*/
-				pdm_sat_table->decision_holding_period = 4;
+				sat_tab->per_beam_training_pkt_num = 3; /*ping 60000*/
+				sat_tab->decision_holding_period = 4;
 				break;
 			case TRAFFIC_ULTRA_LOW:
-				pdm_sat_table->per_beam_training_pkt_num = 1;
-				pdm_sat_table->decision_holding_period = 6;
+				sat_tab->per_beam_training_pkt_num = 1;
+				sat_tab->decision_holding_period = 6;
 				break;
 			default:
 				break;
 			}
 		}
-		
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("TrafficLoad = (( %d )), Fix_beam = (( %d )), per_beam_training_pkt_num = (( %d )), decision_holding_period = ((%d))\n",
-			p_dm->traffic_load, pdm_sat_table->fix_training_num_en, pdm_sat_table->per_beam_training_pkt_num, pdm_sat_table->decision_holding_period));
-
-		/*Beam_set number*/
-		if (*p_dm->p_band_type == ODM_BAND_5G) {
-			pdm_sat_table->total_beam_set_num = pdm_sat_table->total_beam_set_num_5g;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("5G beam_set num = ((%d))\n", pdm_sat_table->total_beam_set_num));
+
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "TrafficLoad = (( %d )), Fix_beam = (( %d )), per_beam_training_pkt_num = (( %d )), decision_holding_period = ((%d))\n",
+			  dm->traffic_load, sat_tab->fix_training_num_en,
+			  sat_tab->per_beam_training_pkt_num,
+			  sat_tab->decision_holding_period);
+
+		/*@Beam_set number*/
+		if (*dm->band_type == ODM_BAND_5G) {
+			sat_tab->total_beam_set_num = sat_tab->total_beam_set_num_5g;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "5G beam_set num = ((%d))\n",
+				  sat_tab->total_beam_set_num);
 		} else {
-			pdm_sat_table->total_beam_set_num = pdm_sat_table->total_beam_set_num_2g;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("2G beam_set num = ((%d))\n", pdm_sat_table->total_beam_set_num));
+			sat_tab->total_beam_set_num = sat_tab->total_beam_set_num_2g;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "2G beam_set num = ((%d))\n",
+				  sat_tab->total_beam_set_num);
 		}
 
-		for (j = 0; j < (pdm_sat_table->total_beam_set_num); j++) {
-
-			training_pkt_num_offset = pdm_sat_table->beam_set_train_val_diff[j];
+		for (j = 0; j < (sat_tab->total_beam_set_num); j++) {
+			training_pkt_num_offset = sat_tab->beam_set_train_val_diff[j];
 
-			if ((pdm_sat_table->per_beam_training_pkt_num) > training_pkt_num_offset)
-				pdm_sat_table->beam_set_train_cnt[j] = pdm_sat_table->per_beam_training_pkt_num - training_pkt_num_offset;
+			if (sat_tab->per_beam_training_pkt_num > training_pkt_num_offset)
+				sat_tab->beam_set_train_cnt[j] = sat_tab->per_beam_training_pkt_num - training_pkt_num_offset;
 			else
-				pdm_sat_table->beam_set_train_cnt[j] = 1;
+				sat_tab->beam_set_train_cnt[j] = 1;
 
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Beam_Set[ %d ] training_pkt_offset = ((%d)), training_pkt_num = ((%d))\n",
-				j, pdm_sat_table->beam_set_train_val_diff[j], pdm_sat_table->beam_set_train_cnt[j]));
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Beam_Set[ %d ] training_pkt_offset = ((%d)), training_pkt_num = ((%d))\n",
+				  j, sat_tab->beam_set_train_val_diff[j],
+				  sat_tab->beam_set_train_cnt[j]);
 		}
-		
-		pdm_sat_table->pre_beacon_counter = pdm_sat_table->beacon_counter;
-		pdm_sat_table->update_beam_idx = 0;
-		pdm_sat_table->pkt_counter = 0;
-		
-		pdm_sat_table->fast_training_beam_num = 0;
-		phydm_set_rfu_beam_pattern_type2(p_dm);
-		pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-		p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
-	}
 
+		sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+		sat_tab->update_beam_idx = 0;
+		sat_tab->pkt_counter = 0;
+
+		sat_tab->fast_training_beam_num = 0;
+		phydm_set_rfu_beam_pattern_type2(dm);
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		fat_tab->fat_state = FAT_TRAINING_STATE;
+	}
 }
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-void
-phydm_beam_switch_workitem_callback(
-	void	*p_context
-)
+void phydm_beam_switch_workitem_callback(
+	void *context)
 {
-	struct _ADAPTER		*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
 
 #if DEV_BUS_TYPE != RT_PCI_INTERFACE
-	pdm_sat_table->pkt_skip_statistic_en = 1;
+	sat_tab->pkt_skip_statistic_en = 1;
 #endif
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n", pdm_sat_table->pkt_skip_statistic_en));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n",
+		  sat_tab->pkt_skip_statistic_en);
 
-	phydm_update_beam_pattern_type2(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
+	phydm_update_beam_pattern_type2(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
 
 #if DEV_BUS_TYPE != RT_PCI_INTERFACE
-	/*odm_stall_execution(pdm_sat_table->latch_time);*/
-	pdm_sat_table->pkt_skip_statistic_en = 0;
+#if 0
+	/*odm_stall_execution(sat_tab->latch_time);*/
+#endif
+	sat_tab->pkt_skip_statistic_en = 0;
 #endif
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n", pdm_sat_table->pkt_skip_statistic_en, pdm_sat_table->latch_time));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n",
+		  sat_tab->pkt_skip_statistic_en, sat_tab->latch_time);
 }
 
-void
-phydm_beam_decision_workitem_callback(
-	void	*p_context
-)
+void phydm_beam_decision_workitem_callback(
+	void *context)
 {
-	struct _ADAPTER		*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Beam decision Workitem Callback\n"));
-	phydm_fast_ant_training_hl_smart_antenna_type2(p_dm);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ SmartAnt ] Beam decision Workitem Callback\n");
+	phydm_fast_ant_training_hl_smart_antenna_type2(dm);
 }
 #endif
 
-void
-phydm_process_rssi_for_hb_smtant_type2(
-	void		*p_dm_void,
-	void		*p_phy_info_void,
-	void		*p_pkt_info_void,
-	u8		rssi_avg	
-)
+void phydm_process_rssi_for_hb_smtant_type2(
+	void *dm_void,
+	void *phy_info_void,
+	void *pkt_info_void,
+	u8 rssi_avg)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_phyinfo_struct			*p_phy_info = (struct phydm_phyinfo_struct *)p_phy_info_void;
-	struct phydm_perpkt_info_struct				*p_pktinfo = (struct phydm_perpkt_info_struct *)p_pkt_info_void;
-	struct phydm_fat_struct		*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct smt_ant_honbo	*pdm_sat_table = &(p_dm->dm_sat_table);
-	u8		train_pkt_number;
-	u32		beam_tmp;
-	u8		is_cck_rate;
-	u8		rx_power_ant0 = p_phy_info->rx_mimo_signal_strength[0];
-	u8		rx_power_ant1 = p_phy_info->rx_mimo_signal_strength[1];
-	u8		rx_evm_ant0 = p_phy_info->rx_mimo_evm_dbm[0];
-	u8		rx_evm_ant1 = p_phy_info->rx_mimo_evm_dbm[1];
-	u8		rate_ss = phydm_rate_to_num_ss(p_dm, p_pktinfo->data_rate);
-
-	is_cck_rate = (p_pktinfo->data_rate <= ODM_RATE11M) ? true : false;
-
-
-	/*[Beacon]*/
-	if (p_pktinfo->is_packet_beacon) {
-
-		pdm_sat_table->beacon_counter++;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("MatchBSSID_beacon_counter = ((%d))\n", pdm_sat_table->beacon_counter));
-
-		if (pdm_sat_table->beacon_counter >= pdm_sat_table->pre_beacon_counter + 2) {
-
-			pdm_sat_table->update_beam_idx++;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
-				pdm_sat_table->pre_beacon_counter, pdm_sat_table->pkt_counter, pdm_sat_table->update_beam_idx));
-			
-			pdm_sat_table->pre_beacon_counter = pdm_sat_table->beacon_counter;
-			pdm_sat_table->pkt_counter = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_phyinfo_struct *phy_info = (struct phydm_phyinfo_struct *)phy_info_void;
+	struct phydm_perpkt_info_struct *pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u8 train_pkt_number;
+	u32 beam_tmp;
+	u8 rx_power_ant0 = phy_info->rx_mimo_signal_strength[0];
+	u8 rx_power_ant1 = phy_info->rx_mimo_signal_strength[1];
+	u8 rx_evm_ant0 = phy_info->rx_mimo_evm_dbm[0];
+	u8 rx_evm_ant1 = phy_info->rx_mimo_evm_dbm[1];
+
+	/*@[Beacon]*/
+	if (pktinfo->is_packet_beacon) {
+		sat_tab->beacon_counter++;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "MatchBSSID_beacon_counter = ((%d))\n",
+			  sat_tab->beacon_counter);
+
+		if (sat_tab->beacon_counter >= sat_tab->pre_beacon_counter + 2) {
+			sat_tab->update_beam_idx++;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "pre_beacon_counter = ((%d)), pkt_counter = ((%d)), update_beam_idx = ((%d))\n",
+				  sat_tab->pre_beacon_counter,
+				  sat_tab->pkt_counter,
+				  sat_tab->update_beam_idx);
+
+			sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+			sat_tab->pkt_counter = 0;
 		}
 	}
-	/*[data]*/
-	else if (p_pktinfo->is_packet_to_self) {
-
-		if (pdm_sat_table->pkt_skip_statistic_en == 0) {
-
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("ID[%d] pkt_cnt=((%d)): Beam_set = ((%d)), RSSI{A,B,avg} = {%d, %d, %d}\n",
-				p_pktinfo->station_id, pdm_sat_table->pkt_counter,  pdm_sat_table->fast_training_beam_num, rx_power_ant0, rx_power_ant1, rssi_avg));
-
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Rate_ss = ((%d)), EVM{A,B} = {%d, %d}, RX Rate =", rate_ss,  rx_evm_ant0, rx_evm_ant1));
-			phydm_print_rate(p_dm, p_dm->rx_rate, DBG_ANT_DIV);
+	/*@[data]*/
+	else if (pktinfo->is_packet_to_self) {
+		if (sat_tab->pkt_skip_statistic_en == 0) {
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "ID[%d] pkt_cnt=((%d)): Beam_set = ((%d)), RSSI{A,B,avg} = {%d, %d, %d}\n",
+				  pktinfo->station_id, sat_tab->pkt_counter,
+				  sat_tab->fast_training_beam_num,
+				  rx_power_ant0, rx_power_ant1, rssi_avg);
+
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Rate_ss = ((%d)), EVM{A,B} = {%d, %d}, RX Rate =",
+				  pktinfo->rate_ss, rx_evm_ant0, rx_evm_ant1);
+			phydm_print_rate(dm, dm->rx_rate, DBG_ANT_DIV);
+
+			if (sat_tab->pkt_counter >= 1) /*packet skip count*/
+			{
+				sat_tab->beam_set_rssi_avg_sum[sat_tab->fast_training_beam_num] += rssi_avg;
+				sat_tab->statistic_pkt_cnt[sat_tab->fast_training_beam_num]++;
 
+				sat_tab->beam_path_rssi_sum[sat_tab->fast_training_beam_num][0] += rx_power_ant0;
+				sat_tab->beam_path_rssi_sum[sat_tab->fast_training_beam_num][1] += rx_power_ant1;
 
-			if (pdm_sat_table->pkt_counter >= 1)  /*packet skip count*/
-			{
-				pdm_sat_table->beam_set_rssi_avg_sum[pdm_sat_table->fast_training_beam_num] += rssi_avg;
-				pdm_sat_table->statistic_pkt_cnt[pdm_sat_table->fast_training_beam_num]++;
-				
-				pdm_sat_table->beam_path_rssi_sum[pdm_sat_table->fast_training_beam_num][0] += rx_power_ant0;
-				pdm_sat_table->beam_path_rssi_sum[pdm_sat_table->fast_training_beam_num][1] += rx_power_ant1;
-
-				if (rate_ss == 2) {
-					pdm_sat_table->beam_path_evm_2ss_sum[pdm_sat_table->fast_training_beam_num][0] += rx_evm_ant0;
-					pdm_sat_table->beam_path_evm_2ss_sum[pdm_sat_table->fast_training_beam_num][1] += rx_evm_ant1;
-					pdm_sat_table->beam_path_evm_2ss_cnt[pdm_sat_table->fast_training_beam_num]++;
+				if (pktinfo->rate_ss == 2) {
+					sat_tab->beam_path_evm_2ss_sum[sat_tab->fast_training_beam_num][0] += rx_evm_ant0;
+					sat_tab->beam_path_evm_2ss_sum[sat_tab->fast_training_beam_num][1] += rx_evm_ant1;
+					sat_tab->beam_path_evm_2ss_cnt[sat_tab->fast_training_beam_num]++;
 				} else {
-					pdm_sat_table->beam_path_evm_1ss_sum[pdm_sat_table->fast_training_beam_num] += rx_evm_ant0;
-					pdm_sat_table->beam_path_evm_1ss_cnt[pdm_sat_table->fast_training_beam_num]++;
+					sat_tab->beam_path_evm_1ss_sum[sat_tab->fast_training_beam_num] += rx_evm_ant0;
+					sat_tab->beam_path_evm_1ss_cnt[sat_tab->fast_training_beam_num]++;
 				}
 			}
-			
-			pdm_sat_table->pkt_counter++;
 
-			train_pkt_number = pdm_sat_table->beam_set_train_cnt[pdm_sat_table->fast_training_beam_num];
+			sat_tab->pkt_counter++;
+
+			train_pkt_number = sat_tab->beam_set_train_cnt[sat_tab->fast_training_beam_num];
 
-			if (pdm_sat_table->pkt_counter >= train_pkt_number) {
+			if (sat_tab->pkt_counter >= train_pkt_number) {
+				sat_tab->update_beam_idx++;
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "pre_beacon_counter = ((%d)), Update_new_beam = ((%d))\n",
+					  sat_tab->pre_beacon_counter,
+					  sat_tab->update_beam_idx);
 
-				pdm_sat_table->update_beam_idx++;
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("pre_beacon_counter = ((%d)), Update_new_beam = ((%d))\n",
-					pdm_sat_table->pre_beacon_counter, pdm_sat_table->update_beam_idx));
-				
-				pdm_sat_table->pre_beacon_counter = pdm_sat_table->beacon_counter;
-				pdm_sat_table->pkt_counter = 0;
+				sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+				sat_tab->pkt_counter = 0;
 			}
 		}
 	}
 
-	if (pdm_sat_table->update_beam_idx > 0) {
-		
-		pdm_sat_table->update_beam_idx = 0;
+	if (sat_tab->update_beam_idx > 0) {
+		sat_tab->update_beam_idx = 0;
 
-		if (pdm_sat_table->fast_training_beam_num >= ((u32)pdm_sat_table->total_beam_set_num - 1)) {
-
-			p_dm_fat_table->fat_state = FAT_DECISION_STATE;
+		if (sat_tab->fast_training_beam_num >= ((u32)sat_tab->total_beam_set_num - 1)) {
+			fat_tab->fat_state = FAT_DECISION_STATE;
 
 			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-			phydm_fast_ant_training_hl_smart_antenna_type2(p_dm); /*go to make decision*/
-			#else
-			odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_decision_workitem);
+			if (dm->support_interface == ODM_ITRF_PCIE)
+				phydm_fast_ant_training_hl_smart_antenna_type2(dm); /*@go to make decision*/
+			#endif
+			#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+			if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+				odm_schedule_work_item(&sat_tab->hl_smart_antenna_decision_workitem);
 			#endif
-
 
 		} else {
-			beam_tmp = pdm_sat_table->fast_training_beam_num;
-			pdm_sat_table->fast_training_beam_num++;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Update Beam_num (( %d )) -> (( %d ))\n", beam_tmp, pdm_sat_table->fast_training_beam_num));
-			phydm_set_rfu_beam_pattern_type2(p_dm);
-			pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-
-			p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
+			beam_tmp = sat_tab->fast_training_beam_num;
+			sat_tab->fast_training_beam_num++;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "Update Beam_num (( %d )) -> (( %d ))\n",
+				  beam_tmp, sat_tab->fast_training_beam_num);
+			phydm_set_rfu_beam_pattern_type2(dm);
+			sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+
+			fat_tab->fat_state = FAT_TRAINING_STATE;
 		}
 	}
-	
 }
 #endif
 
 #if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
 
-void
-phydm_hl_smart_ant_type1_init_8821a(
-	void		*p_dm_void
-)
+void phydm_hl_smart_ant_type1_init_8821a(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	u32			value32;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	u32 value32;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("***8821A SmartAnt_Init => ant_div_type=[Hong-Lin Smart ant Type1]\n"));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "***8821A SmartAnt_Init => ant_div_type=[Hong-Lin Smart ant Type1]\n");
 
 #if 0
-	/* ---------------------------------------- */
-	/* GPIO 2-3 for Beam control */
+	/* @---------------------------------------- */
+	/* @GPIO 2-3 for Beam control */
 	/* reg0x66[2]=0 */
 	/* reg0x44[27:26] = 0 */
 	/* reg0x44[23:16]  enable_output for P_GPIO[7:0] */
 	/* reg0x44[15:8]  output_value for P_GPIO[7:0] */
 	/* reg0x40[1:0] = 0  GPIO function */
-	/* ------------------------------------------ */
+	/* @------------------------------------------ */
 #endif
 
-	/*GPIO setting*/
-	odm_set_mac_reg(p_dm, 0x64, BIT(18), 0);
-	odm_set_mac_reg(p_dm, 0x44, BIT(27) | BIT(26), 0);
-	odm_set_mac_reg(p_dm, 0x44, BIT(19) | BIT(18), 0x3);	/*enable_output for P_GPIO[3:2]*/
-	/*odm_set_mac_reg(p_dm, 0x44, BIT(11)|BIT(10), 0);*/ /*output value*/
-	odm_set_mac_reg(p_dm, 0x40, BIT(1) | BIT(0), 0);		/*GPIO function*/
+	/*@GPIO setting*/
+	odm_set_mac_reg(dm, R_0x64, BIT(18), 0);
+	odm_set_mac_reg(dm, R_0x44, BIT(27) | BIT(26), 0);
+	odm_set_mac_reg(dm, R_0x44, BIT(19) | BIT(18), 0x3); /*@enable_output for P_GPIO[3:2]*/
+#if 0
+	/*odm_set_mac_reg(dm, R_0x44, BIT(11)|BIT(10), 0);*/ /*output value*/
+#endif
+	odm_set_mac_reg(dm, R_0x40, BIT(1) | BIT(0), 0); /*@GPIO function*/
 
-	/*Hong_lin smart antenna HW setting*/
-	pdm_sat_table->rfu_codeword_total_bit_num  = 24;/*max=32*/
-	pdm_sat_table->rfu_each_ant_bit_num = 4;
-	pdm_sat_table->beam_patten_num_each_ant = 4;
+	/*@Hong_lin smart antenna HW setting*/
+	sat_tab->rfu_codeword_total_bit_num = 24; /*@max=32*/
+	sat_tab->rfu_each_ant_bit_num = 4;
+	sat_tab->beam_patten_num_each_ant = 4;
 
 #if DEV_BUS_TYPE == RT_SDIO_INTERFACE
-	pdm_sat_table->latch_time = 100; /*mu sec*/
+	sat_tab->latch_time = 100; /*@mu sec*/
 #elif DEV_BUS_TYPE == RT_USB_INTERFACE
-	pdm_sat_table->latch_time = 100; /*mu sec*/
+	sat_tab->latch_time = 100; /*@mu sec*/
 #endif
-	pdm_sat_table->pkt_skip_statistic_en = 0;
+	sat_tab->pkt_skip_statistic_en = 0;
 
-	pdm_sat_table->ant_num = 1;/*max=8*/
-	pdm_sat_table->ant_num_total = NUM_ANTENNA_8821A;
-	pdm_sat_table->first_train_ant = MAIN_ANT;
+	sat_tab->ant_num = 1; /*@max=8*/
+	sat_tab->ant_num_total = NUM_ANTENNA_8821A;
+	sat_tab->first_train_ant = MAIN_ANT;
 
-	pdm_sat_table->rfu_codeword_table[0] = 0x0;
-	pdm_sat_table->rfu_codeword_table[1] = 0x4;
-	pdm_sat_table->rfu_codeword_table[2] = 0x8;
-	pdm_sat_table->rfu_codeword_table[3] = 0xc;
+	sat_tab->rfu_codeword_table[0] = 0x0;
+	sat_tab->rfu_codeword_table[1] = 0x4;
+	sat_tab->rfu_codeword_table[2] = 0x8;
+	sat_tab->rfu_codeword_table[3] = 0xc;
 
-	pdm_sat_table->rfu_codeword_table_5g[0] = 0x1;
-	pdm_sat_table->rfu_codeword_table_5g[1] = 0x2;
-	pdm_sat_table->rfu_codeword_table_5g[2] = 0x4;
-	pdm_sat_table->rfu_codeword_table_5g[3] = 0x8;
+	sat_tab->rfu_codeword_table_5g[0] = 0x1;
+	sat_tab->rfu_codeword_table_5g[1] = 0x2;
+	sat_tab->rfu_codeword_table_5g[2] = 0x4;
+	sat_tab->rfu_codeword_table_5g[3] = 0x8;
 
-	pdm_sat_table->fix_beam_pattern_en  = 0;
-	pdm_sat_table->decision_holding_period = 0;
+	sat_tab->fix_beam_pattern_en = 0;
+	sat_tab->decision_holding_period = 0;
 
-	/*beam training setting*/
-	pdm_sat_table->pkt_counter = 0;
-	pdm_sat_table->per_beam_training_pkt_num = 10;
+	/*@beam training setting*/
+	sat_tab->pkt_counter = 0;
+	sat_tab->per_beam_training_pkt_num = 10;
 
 	/*set default beam*/
-	pdm_sat_table->fast_training_beam_num = 0;
-	pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-	phydm_set_all_ant_same_beam_num(p_dm);
+	sat_tab->fast_training_beam_num = 0;
+	sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+	phydm_set_all_ant_same_beam_num(dm);
 
-	p_dm_fat_table->fat_state = FAT_BEFORE_LINK_STATE;
+	fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
 
-	odm_set_bb_reg(p_dm, 0xCA4, MASKDWORD, 0x01000100);
-	odm_set_bb_reg(p_dm, 0xCA8, MASKDWORD, 0x01000100);
+	odm_set_bb_reg(dm, R_0xca4, MASKDWORD, 0x01000100);
+	odm_set_bb_reg(dm, R_0xca8, MASKDWORD, 0x01000100);
 
-	/*[BB] FAT setting*/
-	odm_set_bb_reg(p_dm, 0xc08, BIT(18) | BIT(17) | BIT(16), pdm_sat_table->ant_num);
-	odm_set_bb_reg(p_dm, 0xc08, BIT(31), 0); /*increase ant num every FAT period 0:+1, 1+2*/
-	odm_set_bb_reg(p_dm, 0x8c4, BIT(2) | BIT(1), 1); /*change cca antenna timming threshold if no CCA occurred: 0:200ms / 1:100ms / 2:no use / 3: 300*/
-	odm_set_bb_reg(p_dm, 0x8c4, BIT(0), 1); /*FAT_watchdog_en*/
+	/*@[BB] FAT setting*/
+	odm_set_bb_reg(dm, R_0xc08, BIT(18) | BIT(17) | BIT(16), sat_tab->ant_num);
+	odm_set_bb_reg(dm, R_0xc08, BIT(31), 0); /*@increase ant num every FAT period 0:+1, 1+2*/
+	odm_set_bb_reg(dm, R_0x8c4, BIT(2) | BIT(1), 1); /*@change cca antenna timming threshold if no CCA occurred: 0:200ms / 1:100ms / 2:no use / 3: 300*/
+	odm_set_bb_reg(dm, R_0x8c4, BIT(0), 1); /*@FAT_watchdog_en*/
 
-	value32 = odm_get_mac_reg(p_dm,  0x7B4, MASKDWORD);
-	odm_set_mac_reg(p_dm, 0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17)));	/*Reg7B4[16]=1 enable antenna training */
+	value32 = odm_get_mac_reg(dm, R_0x7b4, MASKDWORD);
+	odm_set_mac_reg(dm, R_0x7b4, MASKDWORD, value32 | (BIT(16) | BIT(17))); /*Reg7B4[16]=1 enable antenna training */
 	/*Reg7B4[17]=1 enable  match MAC addr*/
-	odm_set_mac_reg(p_dm, 0x7b4, 0xFFFF, 0);/*Match MAC ADDR*/
-	odm_set_mac_reg(p_dm, 0x7b0, MASKDWORD, 0);
-
+	odm_set_mac_reg(dm, R_0x7b4, 0xFFFF, 0); /*@Match MAC ADDR*/
+	odm_set_mac_reg(dm, R_0x7b0, MASKDWORD, 0);
 }
 
-u32
-phydm_construct_hl_beam_codeword(
-	void		*p_dm_void,
-	u32		*beam_pattern_idx,
-	u32		ant_num
-)
+u32 phydm_construct_hl_beam_codeword(
+	void *dm_void,
+	u32 *beam_pattern_idx,
+	u32 ant_num)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo		*pdm_sat_table = &(p_dm->dm_sat_table);
-	u32		codeword = 0;
-	u32		data_tmp;
-	u32		i;
-	u32		break_counter = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u32 codeword = 0;
+	u32 data_tmp;
+	u32 i;
+	u32 break_counter = 0;
 
 	if (ant_num < 8) {
-		for (i = 0; i < (pdm_sat_table->ant_num_total); i++) {
-			/*PHYDM_DBG(p_dm,DBG_ANT_DIV, ("beam_pattern_num[%x] = %x\n",i,beam_pattern_num[i] ));*/
-			if ((i < (pdm_sat_table->first_train_ant - 1)) || (break_counter >= (pdm_sat_table->ant_num))) {
+		for (i = 0; i < (sat_tab->ant_num_total); i++) {
+#if 0
+			/*PHYDM_DBG(dm,DBG_ANT_DIV, "beam_pattern_num[%x] = %x\n",i,beam_pattern_num[i] );*/
+#endif
+			if ((i < (sat_tab->first_train_ant - 1)) || break_counter >= sat_tab->ant_num) {
 				data_tmp = 0;
-				/**/
 			} else {
-
 				break_counter++;
 
 				if (beam_pattern_idx[i] == 0) {
-
-					if (*p_dm->p_band_type == ODM_BAND_5G)
-						data_tmp = pdm_sat_table->rfu_codeword_table_5g[0];
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[0];
 					else
-						data_tmp = pdm_sat_table->rfu_codeword_table[0];
+						data_tmp = sat_tab->rfu_codeword_table[0];
 
 				} else if (beam_pattern_idx[i] == 1) {
-
-
-					if (*p_dm->p_band_type == ODM_BAND_5G)
-						data_tmp = pdm_sat_table->rfu_codeword_table_5g[1];
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[1];
 					else
-						data_tmp = pdm_sat_table->rfu_codeword_table[1];
+						data_tmp = sat_tab->rfu_codeword_table[1];
 
 				} else if (beam_pattern_idx[i] == 2) {
-
-					if (*p_dm->p_band_type == ODM_BAND_5G)
-						data_tmp = pdm_sat_table->rfu_codeword_table_5g[2];
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[2];
 					else
-						data_tmp = pdm_sat_table->rfu_codeword_table[2];
+						data_tmp = sat_tab->rfu_codeword_table[2];
 
 				} else if (beam_pattern_idx[i] == 3) {
-
-					if (*p_dm->p_band_type == ODM_BAND_5G)
-						data_tmp = pdm_sat_table->rfu_codeword_table_5g[3];
+					if (*dm->band_type == ODM_BAND_5G)
+						data_tmp = sat_tab->rfu_codeword_table_5g[3];
 					else
-						data_tmp = pdm_sat_table->rfu_codeword_table[3];
+						data_tmp = sat_tab->rfu_codeword_table[3];
 				}
 			}
 
-
 			codeword |= (data_tmp << (i * 4));
-
 		}
 	}
 
 	return codeword;
 }
 
-void
-phydm_update_beam_pattern(
-	void		*p_dm_void,
-	u32		codeword,
-	u32		codeword_length
-)
+void phydm_update_beam_pattern(
+	void *dm_void,
+	u32 codeword,
+	u32 codeword_length)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
-	u8			i;
-	boolean			beam_ctrl_signal;
-	u32			one = 0x1;
-	u32			reg44_tmp_p, reg44_tmp_n, reg44_ori;
-	u8			devide_num = 4;
-
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Set Beam Pattern =0x%x\n", codeword));
-
-	reg44_ori = odm_get_mac_reg(p_dm, 0x44, MASKDWORD);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u8 i;
+	boolean beam_ctrl_signal;
+	u32 one = 0x1;
+	u32 reg44_tmp_p, reg44_tmp_n, reg44_ori;
+	u8 devide_num = 4;
+
+	PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ] Set Beam Pattern =0x%x\n",
+		  codeword);
+
+	reg44_ori = odm_get_mac_reg(dm, R_0x44, MASKDWORD);
 	reg44_tmp_p = reg44_ori;
-	/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44_ori =0x%x\n", reg44_ori));*/
+#if 0
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_ori =0x%x\n", reg44_ori);*/
+#endif
 
-	devide_num = (pdm_sat_table->rfu_protocol_type == 2) ? 6 : 4;
+	devide_num = (sat_tab->rfu_protocol_type == 2) ? 6 : 4;
 
 	for (i = 0; i <= (codeword_length - 1); i++) {
 		beam_ctrl_signal = (boolean)((codeword & BIT(i)) >> i);
 
-		if (p_dm->debug_components & DBG_ANT_DIV) {
-
-			if (i == (codeword_length - 1)) {
-				dbg_print("%d ]\n", beam_ctrl_signal);
-				/**/
-			} else if (i == 0) {
-				dbg_print("Send codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
-				/**/
-			} else if ((i % devide_num) == (devide_num-1)) {
-				dbg_print("%d  |  ", beam_ctrl_signal);
-				/**/
-			} else {
-				dbg_print("%d ", beam_ctrl_signal);
-				/**/
-			}
+		if (dm->debug_components & DBG_ANT_DIV) {
+			if (i == (codeword_length - 1))
+				pr_debug("%d ]\n", beam_ctrl_signal);
+			else if (i == 0)
+				pr_debug("Send codeword[1:%d] ---> [ %d ", codeword_length, beam_ctrl_signal);
+			else if ((i % devide_num) == (devide_num - 1))
+				pr_debug("%d  |  ", beam_ctrl_signal);
+			else
+				pr_debug("%d ", beam_ctrl_signal);
 		}
 
-		if (p_dm->support_ic_type == ODM_RTL8821) {
+		if (dm->support_ic_type == ODM_RTL8821) {
 			#if (RTL8821A_SUPPORT == 1)
-			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*clean bit 10 & 11*/
+			reg44_tmp_p = reg44_ori & (~(BIT(11) | BIT(10))); /*@clean bit 10 & 11*/
 			reg44_tmp_p |= ((1 << 11) | (beam_ctrl_signal << 10));
 			reg44_tmp_n = reg44_ori & (~(BIT(11) | BIT(10)));
 
-			/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n));*/
-			odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_p);
-			odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_n);
+#if 0
+			/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n);*/
+#endif
+			odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_p);
+			odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_n);
 			#endif
 		}
 		#if (RTL8822B_SUPPORT == 1)
-		else if (p_dm->support_ic_type == ODM_RTL8822B) {
-
-			if (pdm_sat_table->rfu_protocol_type == 2) {
-
-				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*clean bit 8*/
-				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*get new clk high/low, exclusive-or*/
+		else if (dm->support_ic_type == ODM_RTL8822B) {
+			if (sat_tab->rfu_protocol_type == 2) {
+				reg44_tmp_p = reg44_tmp_p & ~(BIT(8)); /*@clean bit 8*/
+				reg44_tmp_p = reg44_tmp_p ^ BIT(9); /*@get new clk high/low, exclusive-or*/
 
-	
 				reg44_tmp_p |= (beam_ctrl_signal << 8);
-				
-				odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_p);
+
+				odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_p);
 				ODM_delay_us(10);
-				/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal));*/
-				
+#if 0
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44 =(( 0x%x )), reg44[9:8] = ((%x)), beam_ctrl_signal =((%x))\n", reg44_tmp_p, ((reg44_tmp_p & 0x300)>>8), beam_ctrl_signal);*/
+#endif
+
 			} else {
-				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*clean bit 9 & 8*/
+				reg44_tmp_p = reg44_ori & (~(BIT(9) | BIT(8))); /*@clean bit 9 & 8*/
 				reg44_tmp_p |= ((1 << 9) | (beam_ctrl_signal << 8));
 				reg44_tmp_n = reg44_ori & (~(BIT(9) | BIT(8)));
 
-				/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n)); */
-				odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_p);
+#if 0
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "reg44_tmp_p =(( 0x%x )), reg44_tmp_n = (( 0x%x ))\n", reg44_tmp_p, reg44_tmp_n); */
+#endif
+				odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_p);
 				ODM_delay_us(10);
-				odm_set_mac_reg(p_dm, 0x44, MASKDWORD, reg44_tmp_n);
+				odm_set_mac_reg(dm, R_0x44, MASKDWORD, reg44_tmp_n);
 				ODM_delay_us(10);
 			}
 		}
@@ -1511,301 +1610,335 @@ phydm_update_beam_pattern(
 	}
 }
 
-void
-phydm_update_rx_idle_beam(
-	void		*p_dm_void
-)
+void phydm_update_rx_idle_beam(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct phydm_fat_struct			*p_dm_fat_table = &p_dm->dm_fat_table;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
-	u32			i;
-
-	pdm_sat_table->update_beam_codeword = phydm_construct_hl_beam_codeword(p_dm, &(pdm_sat_table->rx_idle_beam[0]), pdm_sat_table->ant_num);
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Set target beam_pattern codeword = (( 0x%x ))\n", pdm_sat_table->update_beam_codeword));
-
-	for (i = 0; i < (pdm_sat_table->ant_num); i++) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ Update Rx-Idle-Beam ] RxIdleBeam[%d] =%d\n", i, pdm_sat_table->rx_idle_beam[i]));
-		/**/
-	}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u32 i;
+
+	sat_tab->update_beam_codeword = phydm_construct_hl_beam_codeword(dm,
+									 &sat_tab->rx_idle_beam[0],
+									 sat_tab->ant_num);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "Set target beam_pattern codeword = (( 0x%x ))\n",
+		  sat_tab->update_beam_codeword);
+
+	for (i = 0; i < (sat_tab->ant_num); i++)
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[ Update Rx-Idle-Beam ] RxIdleBeam[%d] =%d\n", i,
+			  sat_tab->rx_idle_beam[i]);
 
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	phydm_update_beam_pattern(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
-#else
-	odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_workitem);
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#endif
+#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+		odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+#if 0
 	/*odm_stall_execution(1);*/
+#endif
 #endif
 
-	pdm_sat_table->pre_codeword = pdm_sat_table->update_beam_codeword;
+	sat_tab->pre_codeword = sat_tab->update_beam_codeword;
 }
 
-void
-phydm_hl_smart_ant_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-)
+void phydm_hl_smart_ant_debug(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
-	u32			used = *_used;
-	u32			out_len = *_out_len;
-	u32			one = 0x1;
-	u32			codeword_length = pdm_sat_table->rfu_codeword_total_bit_num;
-	u32			beam_ctrl_signal, i;
-	u8			devide_num = 4;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	u32 used = *_used;
+	u32 out_len = *_out_len;
+	u32 one = 0x1;
+	u32 codeword_length = sat_tab->rfu_codeword_total_bit_num;
+	u32 beam_ctrl_signal, i;
+	u8 devide_num = 4;
 
-	if (dm_value[0] == 1) { /*fix beam pattern*/
+	if (dm_value[0] == 1) { /*@fix beam pattern*/
 
-		pdm_sat_table->fix_beam_pattern_en = dm_value[1];
+		sat_tab->fix_beam_pattern_en = dm_value[1];
 
-		if (pdm_sat_table->fix_beam_pattern_en == 1) {
+		if (sat_tab->fix_beam_pattern_en == 1) {
+			sat_tab->fix_beam_pattern_codeword = dm_value[2];
 
-			pdm_sat_table->fix_beam_pattern_codeword = dm_value[2];
+			if (sat_tab->fix_beam_pattern_codeword > (one << codeword_length)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
+					  sat_tab->fix_beam_pattern_codeword,
+					  codeword_length);
 
-			if (pdm_sat_table->fix_beam_pattern_codeword  > (one << codeword_length)) {
+				(sat_tab->fix_beam_pattern_codeword) &= 0xffffff;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Codeword overflow, Current codeword is ((0x%x)), and should be less than ((%d))bit\n",
-					pdm_sat_table->fix_beam_pattern_codeword, codeword_length));
-				
-				(pdm_sat_table->fix_beam_pattern_codeword) &= 0xffffff;
-				
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Auto modify to (0x%x)\n", pdm_sat_table->fix_beam_pattern_codeword));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[ SmartAnt ] Auto modify to (0x%x)\n",
+					  sat_tab->fix_beam_pattern_codeword);
 			}
 
-			pdm_sat_table->update_beam_codeword = pdm_sat_table->fix_beam_pattern_codeword;
+			sat_tab->update_beam_codeword = sat_tab->fix_beam_pattern_codeword;
+
+			/*@---------------------------------------------------------*/
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "Fix Beam Pattern\n");
+
+			devide_num = (sat_tab->rfu_protocol_type == 2) ? 6 : 4;
 
-			/*---------------------------------------------------------*/
-			PHYDM_SNPRINTF((output + used, out_len - used, "Fix Beam Pattern\n"));
-			
-			devide_num = (pdm_sat_table->rfu_protocol_type == 2) ? 6 : 4;
-			
 			for (i = 0; i <= (codeword_length - 1); i++) {
-				beam_ctrl_signal = (boolean)((pdm_sat_table->update_beam_codeword & BIT(i)) >> i);
-
-				if (i == (codeword_length - 1)) {
-					PHYDM_SNPRINTF((output + used, out_len - used, "%d]\n", beam_ctrl_signal));
-					/**/
-				} else if (i == 0) {
-					PHYDM_SNPRINTF((output + used, out_len - used, "Send Codeword[1:24] to RFU -> [%d", beam_ctrl_signal));
-					/**/
-				} else if ((i % devide_num) == (devide_num-1)) {
-					PHYDM_SNPRINTF((output + used, out_len - used, "%d|", beam_ctrl_signal));
-					/**/
-				} else {
-					PHYDM_SNPRINTF((output + used, out_len - used, "%d", beam_ctrl_signal));
-					/**/
-				}
+				beam_ctrl_signal = (boolean)((sat_tab->update_beam_codeword & BIT(i)) >> i);
+
+				if (i == (codeword_length - 1))
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used,
+						 "%d]\n",
+						 beam_ctrl_signal);
+				else if (i == 0)
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used,
+						 "Send Codeword[1:24] to RFU -> [%d",
+						 beam_ctrl_signal);
+				else if ((i % devide_num) == (devide_num - 1))
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used, "%d|",
+						 beam_ctrl_signal);
+				else
+					PDM_SNPF(out_len, used,
+						 output + used,
+						 out_len - used, "%d",
+						 beam_ctrl_signal);
 			}
-			/*---------------------------------------------------------*/
+/*@---------------------------------------------------------*/
 
-
-#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-			phydm_update_beam_pattern(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
-#else
-			odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_workitem);
+			#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+			if (dm->support_interface == ODM_ITRF_PCIE)
+				phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+			#endif
+			#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+			if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+				odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+#if 0
 			/*odm_stall_execution(1);*/
 #endif
-		} else if (pdm_sat_table->fix_beam_pattern_en == 0)
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Smart Antenna: Enable\n"));
+			#endif
+		} else if (sat_tab->fix_beam_pattern_en == 0)
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] Smart Antenna: Enable\n");
 
 	} else if (dm_value[0] == 2) { /*set latch time*/
 
-		pdm_sat_table->latch_time = dm_value[1];
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ]  latch_time =0x%x\n", pdm_sat_table->latch_time));
+		sat_tab->latch_time = dm_value[1];
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ SmartAnt ]  latch_time =0x%x\n",
+			  sat_tab->latch_time);
 	} else if (dm_value[0] == 3) {
+		sat_tab->fix_training_num_en = dm_value[1];
 
-		pdm_sat_table->fix_training_num_en = dm_value[1];
-
-		if (pdm_sat_table->fix_training_num_en == 1) {
-			pdm_sat_table->per_beam_training_pkt_num = (u8)dm_value[2];
-			pdm_sat_table->decision_holding_period = (u8)dm_value[3];
+		if (sat_tab->fix_training_num_en == 1) {
+			sat_tab->per_beam_training_pkt_num = (u8)dm_value[2];
+			sat_tab->decision_holding_period = (u8)dm_value[3];
 
-			PHYDM_SNPRINTF((output + used, out_len - used, "[SmartAnt][Dbg] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
-				pdm_sat_table->fix_training_num_en, pdm_sat_table->per_beam_training_pkt_num, pdm_sat_table->decision_holding_period));
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[SmartAnt][Dbg] Fix_train_en = (( %d )), train_pkt_num = (( %d )), holding_period = (( %d )),\n",
+				 sat_tab->fix_training_num_en,
+				 sat_tab->per_beam_training_pkt_num,
+				 sat_tab->decision_holding_period);
 
-		} else if (pdm_sat_table->fix_training_num_en == 0) {
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n"));
-			/**/
+		} else if (sat_tab->fix_training_num_en == 0) {
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ]  AUTO per_beam_training_pkt_num\n");
 		}
 	} else if (dm_value[0] == 4) {
-
 		if (dm_value[1] == 1) {
-			pdm_sat_table->ant_num = 1;
-			pdm_sat_table->first_train_ant = MAIN_ANT;
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = MAIN_ANT;
 
 		} else if (dm_value[1] == 2) {
-			pdm_sat_table->ant_num = 1;
-			pdm_sat_table->first_train_ant = AUX_ANT;
+			sat_tab->ant_num = 1;
+			sat_tab->first_train_ant = AUX_ANT;
 
 		} else if (dm_value[1] == 3) {
-			pdm_sat_table->ant_num = 2;
-			pdm_sat_table->first_train_ant = MAIN_ANT;
+			sat_tab->ant_num = 2;
+			sat_tab->first_train_ant = MAIN_ANT;
 		}
 
-		PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
-			pdm_sat_table->ant_num, (pdm_sat_table->first_train_ant - 1)));
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "[ SmartAnt ]  Set ant Num = (( %d )), first_train_ant = (( %d ))\n",
+			 sat_tab->ant_num, (sat_tab->first_train_ant - 1));
 	} else if (dm_value[0] == 5) {
-
 		if (dm_value[1] <= 3) {
-			pdm_sat_table->rfu_codeword_table[dm_value[1]] = dm_value[2];
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Set Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
-					dm_value[1], dm_value[2]));
+			sat_tab->rfu_codeword_table[dm_value[1]] = dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] Set Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+				 dm_value[1], dm_value[2]);
 		} else {
 			for (i = 0; i < 4; i++) {
-				PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Show Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
-					i, pdm_sat_table->rfu_codeword_table[i]));
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "[ SmartAnt ] Show Beam_2G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					 i, sat_tab->rfu_codeword_table[i]);
 			}
 		}
 	} else if (dm_value[0] == 6) {
-
 		if (dm_value[1] <= 3) {
-			pdm_sat_table->rfu_codeword_table_5g[dm_value[1]] = dm_value[2];
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Set Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
-					dm_value[1], dm_value[2]));
+			sat_tab->rfu_codeword_table_5g[dm_value[1]] = dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] Set Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+				 dm_value[1], dm_value[2]);
 		} else {
 			for (i = 0; i < 4; i++) {
-				PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Show Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
-					i, pdm_sat_table->rfu_codeword_table_5g[i]));
+				PDM_SNPF(out_len, used, output + used,
+					 out_len - used,
+					 "[ SmartAnt ] Show Beam_5G: (( %d )), RFU codeword table = (( 0x%x ))\n",
+					 i, sat_tab->rfu_codeword_table_5g[i]);
 			}
 		}
 	} else if (dm_value[0] == 7) {
-
 		if (dm_value[1] <= 4) {
-
-			pdm_sat_table->beam_patten_num_each_ant = dm_value[1];
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Set Beam number = (( %d ))\n",
-				pdm_sat_table->beam_patten_num_each_ant));
+			sat_tab->beam_patten_num_each_ant = dm_value[1];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] Set Beam number = (( %d ))\n",
+				 sat_tab->beam_patten_num_each_ant);
 		} else {
-
-			PHYDM_SNPRINTF((output + used, out_len - used, "[ SmartAnt ] Show Beam number = (( %d ))\n",
-				pdm_sat_table->beam_patten_num_each_ant));
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "[ SmartAnt ] Show Beam number = (( %d ))\n",
+				 sat_tab->beam_patten_num_each_ant);
 		}
 	}
 	*_used = used;
 	*_out_len = out_len;
 }
 
-
-void
-phydm_set_all_ant_same_beam_num(
-	void		*p_dm_void
-)
+void phydm_set_all_ant_same_beam_num(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
 
-	if (p_dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) { /*2ant for 8821A*/
+	if (dm->ant_div_type == HL_SW_SMART_ANT_TYPE1) { /*@2ant for 8821A*/
 
-		pdm_sat_table->rx_idle_beam[0] = pdm_sat_table->fast_training_beam_num;
-		pdm_sat_table->rx_idle_beam[1] = pdm_sat_table->fast_training_beam_num;
+		sat_tab->rx_idle_beam[0] = sat_tab->fast_training_beam_num;
+		sat_tab->rx_idle_beam[1] = sat_tab->fast_training_beam_num;
 	}
 
-	pdm_sat_table->update_beam_codeword = phydm_construct_hl_beam_codeword(p_dm, &(pdm_sat_table->rx_idle_beam[0]), pdm_sat_table->ant_num);
+	sat_tab->update_beam_codeword = phydm_construct_hl_beam_codeword(dm,
+									 &sat_tab->rx_idle_beam[0],
+									 sat_tab->ant_num);
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Set all ant beam_pattern: codeword = (( 0x%x ))\n", pdm_sat_table->update_beam_codeword));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ SmartAnt ] Set all ant beam_pattern: codeword = (( 0x%x ))\n",
+		  sat_tab->update_beam_codeword);
 
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	phydm_update_beam_pattern(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
-#else
-	odm_schedule_work_item(&pdm_sat_table->hl_smart_antenna_workitem);
-	/*odm_stall_execution(1);*/
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
+#endif
+#if DEV_BUS_TYPE == RT_USB_INTERFACE || DEV_BUS_TYPE == RT_SDIO_INTERFACE
+	if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO)
+		odm_schedule_work_item(&sat_tab->hl_smart_antenna_workitem);
+/*odm_stall_execution(1);*/
 #endif
 }
 
-void
-odm_fast_ant_training_hl_smart_antenna_type1(
-	void		*p_dm_void
-)
+void odm_fast_ant_training_hl_smart_antenna_type1(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct smt_ant_honbo		*pdm_sat_table = &(p_dm->dm_sat_table);
-	struct phydm_fat_struct		*p_dm_fat_table	 = &(p_dm->dm_fat_table);
-	struct _sw_antenna_switch_		*p_dm_swat_table = &p_dm->dm_swat_table;
-	u32		codeword = 0, i, j;
-	u32		target_ant;
-	u32		avg_rssi_tmp, avg_rssi_tmp_ma;
-	u32		target_ant_beam_max_rssi[SUPPORT_RF_PATH_NUM] = {0};
-	u32		max_beam_ant_rssi = 0;
-	u32		target_ant_beam[SUPPORT_RF_PATH_NUM] = {0};
-	u32		beam_tmp;
-	u8		next_ant;
-	u32		rssi_sorting_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
-	u32		rank_idx_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
-	u32		rank_idx_out[SUPPORT_BEAM_PATTERN_NUM] = {0};
-	u8		per_beam_rssi_diff_tmp = 0, training_pkt_num_offset;
-	u32		break_counter = 0;
-	u32		used_ant;
-
-
-	if (!p_dm->is_linked) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[No Link!!!]\n"));
-
-		if (p_dm_fat_table->is_become_linked == true) {
-
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Link->no Link\n"));
-			p_dm_fat_table->fat_state = FAT_BEFORE_LINK_STATE;
-			odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("change to (( %d )) FAT_state\n", p_dm_fat_table->fat_state));
-
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
+	struct phydm_fat_struct *fat_tab = &dm->dm_fat_table;
+	struct sw_antenna_switch *dm_swat_table = &dm->dm_swat_table;
+	u32 codeword = 0, i, j;
+	u32 target_ant;
+	u32 avg_rssi_tmp, avg_rssi_tmp_ma;
+	u32 target_ant_beam_max_rssi[SUPPORT_RF_PATH_NUM] = {0};
+	u32 max_beam_ant_rssi = 0;
+	u32 target_ant_beam[SUPPORT_RF_PATH_NUM] = {0};
+	u32 beam_tmp;
+	u8 next_ant;
+	u32 rssi_sorting_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u32 rank_idx_seq[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u32 rank_idx_out[SUPPORT_BEAM_PATTERN_NUM] = {0};
+	u8 per_beam_rssi_diff_tmp = 0, training_pkt_num_offset;
+	u32 break_counter = 0;
+	u32 used_ant;
+
+	if (!dm->is_linked) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[No Link!!!]\n");
+
+		if (fat_tab->is_become_linked == true) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Link->no Link\n");
+			fat_tab->fat_state = FAT_BEFORE_LINK_STATE;
+			odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "change to (( %d )) FAT_state\n",
+				  fat_tab->fat_state);
+
+			fat_tab->is_become_linked = dm->is_linked;
 		}
 		return;
 
 	} else {
-		if (p_dm_fat_table->is_become_linked == false) {
-
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Linked !!!]\n"));
+		if (fat_tab->is_become_linked == false) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Linked !!!]\n");
 
-			p_dm_fat_table->fat_state = FAT_PREPARE_STATE;
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("change to (( %d )) FAT_state\n", p_dm_fat_table->fat_state));
+			fat_tab->fat_state = FAT_PREPARE_STATE;
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "change to (( %d )) FAT_state\n",
+				  fat_tab->fat_state);
 
-			/*pdm_sat_table->fast_training_beam_num = 0;*/
-			/*phydm_set_all_ant_same_beam_num(p_dm);*/
+#if 0
+			/*sat_tab->fast_training_beam_num = 0;*/
+			/*phydm_set_all_ant_same_beam_num(dm);*/
+#endif
 
-			p_dm_fat_table->is_become_linked = p_dm->is_linked;
+			fat_tab->is_become_linked = dm->is_linked;
 		}
 	}
 
-	if (*(p_dm_fat_table->p_force_tx_ant_by_desc) == false) {
-		if (p_dm->is_one_entry_only == true)
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_REG);
+	if (!(*fat_tab->p_force_tx_by_desc)) {
+		if (dm->is_one_entry_only == true)
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_REG);
 		else
-			odm_tx_by_tx_desc_or_reg(p_dm, TX_BY_DESC);
+			odm_tx_by_tx_desc_or_reg(dm, TX_BY_DESC);
 	}
 
-	/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("HL Smart ant Training: state (( %d ))\n", p_dm_fat_table->fat_state));*/
-
-	/* [DECISION STATE] */
-	/*=======================================================================================*/
-	if (p_dm_fat_table->fat_state == FAT_DECISION_STATE) {
+#if 0
+	/*PHYDM_DBG(dm, DBG_ANT_DIV, "HL Smart ant Training: state (( %d ))\n", fat_tab->fat_state);*/
+#endif
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 3. In Decision state]\n"));
-		phydm_fast_training_enable(p_dm, FAT_OFF);
+	/* @[DECISION STATE] */
+	/*@=======================================================================================*/
+	if (fat_tab->fat_state == FAT_DECISION_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 3. In Decision state]\n");
+		phydm_fast_training_enable(dm, FAT_OFF);
 
 		break_counter = 0;
-		/*compute target beam in each antenna*/
-		for (i = (pdm_sat_table->first_train_ant - 1); i < pdm_sat_table->ant_num_total; i++) {
-			for (j = 0; j < (pdm_sat_table->beam_patten_num_each_ant); j++) {
-
-				if (pdm_sat_table->pkt_rssi_cnt[i][j] == 0) {
-					avg_rssi_tmp = pdm_sat_table->pkt_rssi_pre[i][j];
+		/*@compute target beam in each antenna*/
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				if (sat_tab->pkt_rssi_cnt[i][j] == 0) {
+					avg_rssi_tmp = sat_tab->pkt_rssi_pre[i][j];
 					avg_rssi_tmp = (avg_rssi_tmp >= 2) ? (avg_rssi_tmp - 2) : avg_rssi_tmp;
 					avg_rssi_tmp_ma = avg_rssi_tmp;
 				} else {
-					avg_rssi_tmp = (pdm_sat_table->pkt_rssi_sum[i][j]) / (pdm_sat_table->pkt_rssi_cnt[i][j]);
-					avg_rssi_tmp_ma = (avg_rssi_tmp + pdm_sat_table->pkt_rssi_pre[i][j]) >> 1;
+					avg_rssi_tmp = (sat_tab->pkt_rssi_sum[i][j]) / (sat_tab->pkt_rssi_cnt[i][j]);
+					avg_rssi_tmp_ma = (avg_rssi_tmp + sat_tab->pkt_rssi_pre[i][j]) >> 1;
 				}
 
 				rssi_sorting_seq[j] = avg_rssi_tmp;
-				pdm_sat_table->pkt_rssi_pre[i][j] = avg_rssi_tmp;
+				sat_tab->pkt_rssi_pre[i][j] = avg_rssi_tmp;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("ant[%d], Beam[%d]: pkt_cnt=(( %d )), avg_rssi_MA=(( %d )), avg_rssi=(( %d ))\n",
-					i, j, pdm_sat_table->pkt_rssi_cnt[i][j], avg_rssi_tmp_ma, avg_rssi_tmp));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "ant[%d], Beam[%d]: pkt_cnt=(( %d )), avg_rssi_MA=(( %d )), avg_rssi=(( %d ))\n",
+					  i, j, sat_tab->pkt_rssi_cnt[i][j],
+					  avg_rssi_tmp_ma, avg_rssi_tmp);
 
 				if (avg_rssi_tmp > target_ant_beam_max_rssi[i]) {
 					target_ant_beam[i] = j;
@@ -1813,51 +1946,56 @@ odm_fast_ant_training_hl_smart_antenna_type1(
 				}
 
 				/*reset counter value*/
-				pdm_sat_table->pkt_rssi_sum[i][j] = 0;
-				pdm_sat_table->pkt_rssi_cnt[i][j] = 0;
-
+				sat_tab->pkt_rssi_sum[i][j] = 0;
+				sat_tab->pkt_rssi_cnt[i][j] = 0;
 			}
-			pdm_sat_table->rx_idle_beam[i] = target_ant_beam[i];
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("---------> Target of ant[%d]: Beam_num-(( %d )) RSSI= ((%d))\n",
-				i,  target_ant_beam[i], target_ant_beam_max_rssi[i]));
+			sat_tab->rx_idle_beam[i] = target_ant_beam[i];
+			PHYDM_DBG(dm, DBG_ANT_DIV,
+				  "---------> Target of ant[%d]: Beam_num-(( %d )) RSSI= ((%d))\n",
+				  i, target_ant_beam[i],
+				  target_ant_beam_max_rssi[i]);
 
+#if 0
 			/*sorting*/
-			/*
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Pre]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]));
+			/*@
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Pre]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]);
 			*/
 
-			/*phydm_seq_sorting(p_dm, &rssi_sorting_seq[0], &rank_idx_seq[0], &rank_idx_out[0], SUPPORT_BEAM_PATTERN_NUM);*/
+			/*phydm_seq_sorting(dm, &rssi_sorting_seq[0], &rank_idx_seq[0], &rank_idx_out[0], SUPPORT_BEAM_PATTERN_NUM);*/
 
-			/*
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Post]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]));
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Post]rank_idx_seq = [%d, %d, %d, %d]\n", rank_idx_seq[0], rank_idx_seq[1], rank_idx_seq[2], rank_idx_seq[3]));
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Post]rank_idx_out = [%d, %d, %d, %d]\n", rank_idx_out[0], rank_idx_out[1], rank_idx_out[2], rank_idx_out[3]));
+			/*@
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rssi_sorting_seq = [%d, %d, %d, %d]\n", rssi_sorting_seq[0], rssi_sorting_seq[1], rssi_sorting_seq[2], rssi_sorting_seq[3]);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rank_idx_seq = [%d, %d, %d, %d]\n", rank_idx_seq[0], rank_idx_seq[1], rank_idx_seq[2], rank_idx_seq[3]);
+			PHYDM_DBG(dm, DBG_ANT_DIV, "[Post]rank_idx_out = [%d, %d, %d, %d]\n", rank_idx_out[0], rank_idx_out[1], rank_idx_out[2], rank_idx_out[3]);
 			*/
+#endif
 
 			if (target_ant_beam_max_rssi[i] > max_beam_ant_rssi) {
 				target_ant = i;
 				max_beam_ant_rssi = target_ant_beam_max_rssi[i];
-				/*PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Target of ant = (( %d )) max_beam_ant_rssi = (( %d ))\n",
-					target_ant,  max_beam_ant_rssi));*/
+#if
+				/*PHYDM_DBG(dm, DBG_ANT_DIV, "Target of ant = (( %d )) max_beam_ant_rssi = (( %d ))\n",
+					target_ant,  max_beam_ant_rssi);*/
+#endif
 			}
 			break_counter++;
-			if (break_counter >= (pdm_sat_table->ant_num))
+			if (break_counter >= sat_tab->ant_num)
 				break;
 		}
 
 #ifdef CONFIG_FAT_PATCH
 		break_counter = 0;
-		for (i = (pdm_sat_table->first_train_ant - 1); i < pdm_sat_table->ant_num_total; i++) {
-			for (j = 0; j < (pdm_sat_table->beam_patten_num_each_ant); j++) {
-
-				per_beam_rssi_diff_tmp = (u8)(max_beam_ant_rssi - pdm_sat_table->pkt_rssi_pre[i][j]);
-				pdm_sat_table->beam_train_rssi_diff[i][j] = per_beam_rssi_diff_tmp;
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("ant[%d], Beam[%d]: RSSI_diff= ((%d))\n",
-						i,  j, per_beam_rssi_diff_tmp));
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				per_beam_rssi_diff_tmp = (u8)(max_beam_ant_rssi - sat_tab->pkt_rssi_pre[i][j]);
+				sat_tab->beam_train_rssi_diff[i][j] = per_beam_rssi_diff_tmp;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "ant[%d], Beam[%d]: RSSI_diff= ((%d))\n",
+					  i, j, per_beam_rssi_diff_tmp);
 			}
 			break_counter++;
-			if (break_counter >= (pdm_sat_table->ant_num))
+			if (break_counter >= sat_tab->ant_num)
 				break;
 		}
 #endif
@@ -1867,288 +2005,274 @@ odm_fast_ant_training_hl_smart_antenna_type1(
 		else if (target_ant == 1)
 			target_ant = AUX_ANT;
 
-		if (pdm_sat_table->ant_num > 1) {
-			/* [ update RX ant ]*/
-			odm_update_rx_idle_ant(p_dm, (u8)target_ant);
+		if (sat_tab->ant_num > 1) {
+			/* @[ update RX ant ]*/
+			odm_update_rx_idle_ant(dm, (u8)target_ant);
 
-			/* [ update TX ant ]*/
-			odm_update_tx_ant(p_dm, (u8)target_ant, (p_dm_fat_table->train_idx));
+			/* @[ update TX ant ]*/
+			odm_update_tx_ant(dm, (u8)target_ant, (fat_tab->train_idx));
 		}
 
 		/*set beam in each antenna*/
-		phydm_update_rx_idle_beam(p_dm);
+		phydm_update_rx_idle_beam(dm);
 
-		odm_ant_div_on_off(p_dm, ANTDIV_ON);
-		p_dm_fat_table->fat_state = FAT_PREPARE_STATE;
+		odm_ant_div_on_off(dm, ANTDIV_ON, ANT_PATH_A);
+		fat_tab->fat_state = FAT_PREPARE_STATE;
 		return;
-
 	}
-	/* [TRAINING STATE] */
-	else if (p_dm_fat_table->fat_state == FAT_TRAINING_STATE) {
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ 2. In Training state]\n"));
+	/* @[TRAINING STATE] */
+	else if (fat_tab->fat_state == FAT_TRAINING_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "[ 2. In Training state]\n");
 
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("fat_beam_n = (( %d )), pre_fat_beam_n = (( %d ))\n",
-			pdm_sat_table->fast_training_beam_num, pdm_sat_table->pre_fast_training_beam_num));
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "fat_beam_n = (( %d )), pre_fat_beam_n = (( %d ))\n",
+			  sat_tab->fast_training_beam_num,
+			  sat_tab->pre_fast_training_beam_num);
 
-		if (pdm_sat_table->fast_training_beam_num > pdm_sat_table->pre_fast_training_beam_num)
+		if (sat_tab->fast_training_beam_num > sat_tab->pre_fast_training_beam_num)
 
-			pdm_sat_table->force_update_beam_en = 0;
+			sat_tab->force_update_beam_en = 0;
 
 		else {
+			sat_tab->force_update_beam_en = 1;
 
-			pdm_sat_table->force_update_beam_en = 1;
-
-			pdm_sat_table->pkt_counter = 0;
-			beam_tmp = pdm_sat_table->fast_training_beam_num;
-			if (pdm_sat_table->fast_training_beam_num >= (pdm_sat_table->beam_patten_num_each_ant - 1)) {
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n", pdm_sat_table->fast_training_beam_num));
-				p_dm_fat_table->fat_state = FAT_DECISION_STATE;
-				odm_fast_ant_training_hl_smart_antenna_type1(p_dm);
+			sat_tab->pkt_counter = 0;
+			beam_tmp = sat_tab->fast_training_beam_num;
+			if (sat_tab->fast_training_beam_num >= (sat_tab->beam_patten_num_each_ant - 1)) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[Timeout Update]  Beam_num (( %d )) -> (( decision ))\n",
+					  sat_tab->fast_training_beam_num);
+				fat_tab->fat_state = FAT_DECISION_STATE;
+				odm_fast_ant_training_hl_smart_antenna_type1(dm);
 
 			} else {
-				pdm_sat_table->fast_training_beam_num++;
-
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n", beam_tmp, pdm_sat_table->fast_training_beam_num));
-				phydm_set_all_ant_same_beam_num(p_dm);
-				p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
-
+				sat_tab->fast_training_beam_num++;
+
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "[Timeout Update]  Beam_num (( %d )) -> (( %d ))\n",
+					  beam_tmp,
+					  sat_tab->fast_training_beam_num);
+				phydm_set_all_ant_same_beam_num(dm);
+				fat_tab->fat_state = FAT_TRAINING_STATE;
 			}
 		}
-		pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[prepare state] Update Pre_Beam =(( %d ))\n", pdm_sat_table->pre_fast_training_beam_num));
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "[prepare state] Update Pre_Beam =(( %d ))\n",
+			  sat_tab->pre_fast_training_beam_num);
 	}
-	/*  [Prepare state] */
-	/*=======================================================================================*/
-	else if (p_dm_fat_table->fat_state == FAT_PREPARE_STATE) {
-
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("\n\n[ 1. In Prepare state]\n"));
-
-		if (p_dm->pre_traffic_load == (p_dm->traffic_load)) {
-			if (pdm_sat_table->decision_holding_period != 0) {
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Holding_period = (( %d )), return!!!\n", pdm_sat_table->decision_holding_period));
-				pdm_sat_table->decision_holding_period--;
+	/*  @[Prepare state] */
+	/*@=======================================================================================*/
+	else if (fat_tab->fat_state == FAT_PREPARE_STATE) {
+		PHYDM_DBG(dm, DBG_ANT_DIV, "\n\n[ 1. In Prepare state]\n");
+
+		if (dm->pre_traffic_load == dm->traffic_load) {
+			if (sat_tab->decision_holding_period != 0) {
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "Holding_period = (( %d )), return!!!\n",
+					  sat_tab->decision_holding_period);
+				sat_tab->decision_holding_period--;
 				return;
 			}
 		}
 
-
 		/* Set training packet number*/
-		if (pdm_sat_table->fix_training_num_en == 0) {
-
-			switch (p_dm->traffic_load) {
-
+		if (sat_tab->fix_training_num_en == 0) {
+			switch (dm->traffic_load) {
 			case TRAFFIC_HIGH:
-				pdm_sat_table->per_beam_training_pkt_num = 8;
-				pdm_sat_table->decision_holding_period = 2;
+				sat_tab->per_beam_training_pkt_num = 8;
+				sat_tab->decision_holding_period = 2;
 				break;
 			case TRAFFIC_MID:
-				pdm_sat_table->per_beam_training_pkt_num = 6;
-				pdm_sat_table->decision_holding_period = 3;
+				sat_tab->per_beam_training_pkt_num = 6;
+				sat_tab->decision_holding_period = 3;
 				break;
 			case TRAFFIC_LOW:
-				pdm_sat_table->per_beam_training_pkt_num = 3; /*ping 60000*/
-				pdm_sat_table->decision_holding_period = 4;
+				sat_tab->per_beam_training_pkt_num = 3; /*ping 60000*/
+				sat_tab->decision_holding_period = 4;
 				break;
 			case TRAFFIC_ULTRA_LOW:
-				pdm_sat_table->per_beam_training_pkt_num = 1;
-				pdm_sat_table->decision_holding_period = 6;
+				sat_tab->per_beam_training_pkt_num = 1;
+				sat_tab->decision_holding_period = 6;
 				break;
 			default:
 				break;
 			}
 		}
-		PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Fix_training_en = (( %d )), training_pkt_num_base = (( %d )), holding_period = ((%d))\n",
-			pdm_sat_table->fix_training_num_en, pdm_sat_table->per_beam_training_pkt_num, pdm_sat_table->decision_holding_period));
-
+		PHYDM_DBG(dm, DBG_ANT_DIV,
+			  "Fix_training_en = (( %d )), training_pkt_num_base = (( %d )), holding_period = ((%d))\n",
+			  sat_tab->fix_training_num_en,
+			  sat_tab->per_beam_training_pkt_num,
+			  sat_tab->decision_holding_period);
 
 #ifdef CONFIG_FAT_PATCH
 		break_counter = 0;
-		for (i = (pdm_sat_table->first_train_ant - 1); i < pdm_sat_table->ant_num_total; i++) {
-			for (j = 0; j < (pdm_sat_table->beam_patten_num_each_ant); j++) {
-
-				per_beam_rssi_diff_tmp = pdm_sat_table->beam_train_rssi_diff[i][j];
+		for (i = (sat_tab->first_train_ant - 1); i < sat_tab->ant_num_total; i++) {
+			for (j = 0; j < (sat_tab->beam_patten_num_each_ant); j++) {
+				per_beam_rssi_diff_tmp = sat_tab->beam_train_rssi_diff[i][j];
 				training_pkt_num_offset = per_beam_rssi_diff_tmp;
 
-				if ((pdm_sat_table->per_beam_training_pkt_num) > training_pkt_num_offset)
-					pdm_sat_table->beam_train_cnt[i][j] = pdm_sat_table->per_beam_training_pkt_num - training_pkt_num_offset;
+				if (sat_tab->per_beam_training_pkt_num > training_pkt_num_offset)
+					sat_tab->beam_train_cnt[i][j] = sat_tab->per_beam_training_pkt_num - training_pkt_num_offset;
 				else
-					pdm_sat_table->beam_train_cnt[i][j] = 1;
-
+					sat_tab->beam_train_cnt[i][j] = 1;
 
-				PHYDM_DBG(p_dm, DBG_ANT_DIV, ("ant[%d]: Beam_num-(( %d ))  training_pkt_num = ((%d))\n",
-					i,  j, pdm_sat_table->beam_train_cnt[i][j]));
+				PHYDM_DBG(dm, DBG_ANT_DIV,
+					  "ant[%d]: Beam_num-(( %d ))  training_pkt_num = ((%d))\n",
+					  i, j, sat_tab->beam_train_cnt[i][j]);
 			}
 			break_counter++;
-			if (break_counter >= (pdm_sat_table->ant_num))
+			if (break_counter >= sat_tab->ant_num)
 				break;
 		}
 
+		phydm_fast_training_enable(dm, FAT_OFF);
+		sat_tab->pre_beacon_counter = sat_tab->beacon_counter;
+		sat_tab->update_beam_idx = 0;
 
-		phydm_fast_training_enable(p_dm, FAT_OFF);
-		pdm_sat_table->pre_beacon_counter = pdm_sat_table->beacon_counter;
-		pdm_sat_table->update_beam_idx = 0;
-
-		if (*p_dm->p_band_type == ODM_BAND_5G) {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Set 5G ant\n"));
-			/*used_ant = (pdm_sat_table->first_train_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;*/
-			used_ant = pdm_sat_table->first_train_ant;
+		if (*dm->band_type == ODM_BAND_5G) {
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Set 5G ant\n");
+			/*used_ant = (sat_tab->first_train_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;*/
+			used_ant = sat_tab->first_train_ant;
 		} else {
-			PHYDM_DBG(p_dm, DBG_ANT_DIV, ("Set 2.4G ant\n"));
-			used_ant = pdm_sat_table->first_train_ant;
+			PHYDM_DBG(dm, DBG_ANT_DIV, "Set 2.4G ant\n");
+			used_ant = sat_tab->first_train_ant;
 		}
 
-		odm_update_rx_idle_ant(p_dm, (u8)used_ant);
+		odm_update_rx_idle_ant(dm, (u8)used_ant);
 
 #else
 		/* Set training MAC addr. of target */
-		odm_set_next_mac_addr_target(p_dm);
-		phydm_fast_training_enable(p_dm, FAT_ON);
+		odm_set_next_mac_addr_target(dm);
+		phydm_fast_training_enable(dm, FAT_ON);
 #endif
 
-		odm_ant_div_on_off(p_dm, ANTDIV_OFF);
-		pdm_sat_table->pkt_counter = 0;
-		pdm_sat_table->fast_training_beam_num = 0;
-		phydm_set_all_ant_same_beam_num(p_dm);
-		pdm_sat_table->pre_fast_training_beam_num = pdm_sat_table->fast_training_beam_num;
-		p_dm_fat_table->fat_state = FAT_TRAINING_STATE;
+		odm_ant_div_on_off(dm, ANTDIV_OFF, ANT_PATH_A);
+		sat_tab->pkt_counter = 0;
+		sat_tab->fast_training_beam_num = 0;
+		phydm_set_all_ant_same_beam_num(dm);
+		sat_tab->pre_fast_training_beam_num = sat_tab->fast_training_beam_num;
+		fat_tab->fat_state = FAT_TRAINING_STATE;
 	}
-
 }
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-void
-phydm_beam_switch_workitem_callback(
-	void	*p_context
-)
+void phydm_beam_switch_workitem_callback(
+	void *context)
 {
-	struct _ADAPTER		*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
-	struct smt_ant_honbo			*pdm_sat_table = &(p_dm->dm_sat_table);
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	struct smt_ant_honbo *sat_tab = &dm->dm_sat_table;
 
 #if DEV_BUS_TYPE != RT_PCI_INTERFACE
-	pdm_sat_table->pkt_skip_statistic_en = 1;
+	sat_tab->pkt_skip_statistic_en = 1;
 #endif
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n", pdm_sat_table->pkt_skip_statistic_en));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ SmartAnt ] Beam Switch Workitem Callback, pkt_skip_statistic_en = (( %d ))\n",
+		  sat_tab->pkt_skip_statistic_en);
 
-	phydm_update_beam_pattern(p_dm, pdm_sat_table->update_beam_codeword, pdm_sat_table->rfu_codeword_total_bit_num);
+	phydm_update_beam_pattern(dm, sat_tab->update_beam_codeword, sat_tab->rfu_codeword_total_bit_num);
 
 #if DEV_BUS_TYPE != RT_PCI_INTERFACE
-	/*odm_stall_execution(pdm_sat_table->latch_time);*/
-	pdm_sat_table->pkt_skip_statistic_en = 0;
+#if 0
+	/*odm_stall_execution(sat_tab->latch_time);*/
+#endif
+	sat_tab->pkt_skip_statistic_en = 0;
 #endif
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n", pdm_sat_table->pkt_skip_statistic_en, pdm_sat_table->latch_time));
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "pkt_skip_statistic_en = (( %d )), latch_time = (( %d ))\n",
+		  sat_tab->pkt_skip_statistic_en, sat_tab->latch_time);
 }
 
-void
-phydm_beam_decision_workitem_callback(
-	void	*p_context
-)
+void phydm_beam_decision_workitem_callback(
+	void *context)
 {
-	struct _ADAPTER		*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 
-	PHYDM_DBG(p_dm, DBG_ANT_DIV, ("[ SmartAnt ] Beam decision Workitem Callback\n"));
-	odm_fast_ant_training_hl_smart_antenna_type1(p_dm);
+	PHYDM_DBG(dm, DBG_ANT_DIV,
+		  "[ SmartAnt ] Beam decision Workitem Callback\n");
+	odm_fast_ant_training_hl_smart_antenna_type1(dm);
 }
 #endif
 
+#endif /*@#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1*/
 
-#endif /*#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1*/
+#endif /*@#ifdef CONFIG_HL_SMART_ANTENNA*/
 
+void phydm_smt_ant_config(
+	void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
 
-#endif/*#ifdef CONFIG_HL_SMART_ANTENNA*/
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
 
+	dm->support_ability |= ODM_BB_SMT_ANT;
+	smtant_table->smt_ant_vendor = SMTANT_CUMITEK;
+	smtant_table->smt_ant_type = 1;
+#if (RTL8822B_SUPPORT == 1)
+	dm->rfe_type = SMTANT_TMP_RFE_TYPE;
+#endif
+#elif (defined(CONFIG_HL_SMART_ANTENNA))
 
+	dm->support_ability |= ODM_BB_SMT_ANT;
+	smtant_table->smt_ant_vendor = SMTANT_HON_BO;
 
-void
-phydm_smt_ant_config(
-	void		*p_dm_void
-)
-{
-	struct	PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	smt_ant				*p_smtant_table = &(p_dm->smtant_table);
-
-	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
-	
-		p_dm->support_ability |= ODM_BB_SMT_ANT;
-		p_smtant_table->smt_ant_vendor = SMTANT_CUMITEK;
-		p_smtant_table->smt_ant_type = 1;
-		#if (RTL8822B_SUPPORT == 1)
-		p_dm->rfe_type = SMTANT_TMP_RFE_TYPE;
-		#endif
-	#elif (defined(CONFIG_HL_SMART_ANTENNA))
-	
-		p_dm->support_ability |= ODM_BB_SMT_ANT;
-		p_smtant_table->smt_ant_vendor = SMTANT_HON_BO;
-		
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-		p_smtant_table->smt_ant_type = 1;
-		#endif
-		
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-		p_smtant_table->smt_ant_type = 2;
-		#endif
-	#endif
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+	smtant_table->smt_ant_type = 1;
+#endif
 
-	PHYDM_DBG(p_dm, DBG_SMT_ANT, ("[SmtAnt Config] Vendor=((%d)), Smt_ant_type =((%d))\n",
-		p_smtant_table->smt_ant_vendor, p_smtant_table->smt_ant_type));
-}
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+	smtant_table->smt_ant_type = 2;
+#endif
 #endif
 
+	PHYDM_DBG(dm, DBG_SMT_ANT,
+		  "[SmtAnt Config] Vendor=((%d)), Smt_ant_type =((%d))\n",
+		  smtant_table->smt_ant_vendor, smtant_table->smt_ant_type);
+}
 
-void
-phydm_smt_ant_init(
-	void		*p_dm_void
-)
+void phydm_smt_ant_init(void *dm_void)
 {
-#if (defined(CONFIG_SMART_ANTENNA))
-	struct	PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct	smt_ant				*p_smtant_table = &(p_dm->smtant_table);
-	
-	phydm_smt_ant_config(p_dm);
-	
-
-	if (p_smtant_table->smt_ant_vendor == SMTANT_CUMITEK) {
-		
-		#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
-		#if (RTL8822B_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8822B) {
-			phydm_cumitek_smt_ant_init_8822b(p_dm);
-			/**/
-		}
-		#endif
-		
-		#if (RTL8197F_SUPPORT == 1)
-		if (p_dm->support_ic_type == ODM_RTL8197F) {
-			phydm_cumitek_smt_ant_init_8197f(p_dm);
-			/**/
-		}
-		#endif
-		#endif /*#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))*/
-		
-	} else if (p_smtant_table->smt_ant_vendor == SMTANT_HON_BO) {
-
-		#if (defined(CONFIG_HL_SMART_ANTENNA))
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-		if (p_dm->support_ic_type == ODM_RTL8821) {
-			phydm_hl_smart_ant_type1_init_8821a(p_dm);
-			/**/
-		}
-		#endif
-		
-		#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-		if (p_dm->support_ic_type == ODM_RTL8822B) {
-			phydm_hl_smart_ant_type2_init_8822b(p_dm);
-			/**/
-		}
-		#endif
-		#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
-	}
-#endif	
-}
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct smt_ant *smtant_table = &dm->smtant_table;
+
+	phydm_smt_ant_config(dm);
 
+	if (smtant_table->smt_ant_vendor == SMTANT_CUMITEK) {
+#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
+#if (RTL8822B_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_cumitek_smt_ant_init_8822b(dm);
+#endif
 
+#if (RTL8197F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8197F)
+			phydm_cumitek_smt_ant_init_8197f(dm);
+#endif
+/*@jj add 20170822*/
+#if (RTL8192F_SUPPORT == 1)
+		if (dm->support_ic_type == ODM_RTL8192F)
+			phydm_cumitek_smt_ant_init_8192f(dm);
+#endif
+#endif /*@#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))*/
+
+	} else if (smtant_table->smt_ant_vendor == SMTANT_HON_BO) {
+#if (defined(CONFIG_HL_SMART_ANTENNA))
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
+		if (dm->support_ic_type == ODM_RTL8821)
+			phydm_hl_smart_ant_type1_init_8821a(dm);
+#endif
+
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_hl_smart_ant_type2_init_8822b(dm);
+#endif
+#endif /*@#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+	}
+}
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.h
index 98f6717d4d81..60db8c33af58 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_smt_ant.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,17 +9,27 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-#ifndef	__PHYDMSMTANT_H__
-#define    __PHYDMSMTANT_H__
+#ifndef __PHYDMSMTANT_H__
+#define __PHYDMSMTANT_H__
 
-/*#define SMT_ANT_VERSION	"1.1"*/ /*2017.03.13*/
-/*#define SMT_ANT_VERSION	"1.2"*/ /*2017.03.28*/
-#define SMT_ANT_VERSION	"2.0" /* Add Cumitek SmtAnt 2017.05.25*/
+/*@#define SMT_ANT_VERSION	"1.1"*/ /*@2017.03.13*/
+/*@#define SMT_ANT_VERSION	"1.2"*/ /*@2017.03.28*/
+#define SMT_ANT_VERSION "2.0" /* @Add Cumitek SmtAnt 2017.05.25*/
 
 #define	SMTANT_RTK		1
 #define	SMTANT_HON_BO	2
@@ -26,11 +37,10 @@
 
 #if (defined(CONFIG_SMART_ANTENNA))
 
-
 #if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
 struct smt_ant_cumitek {
-	u8	tx_ant_idx[2][ODM_ASSOCIATE_ENTRY_NUM]; /*[pathA~B] [MACID 0~128]*/
-	u8	rx_default_ant_idx[2]; /*[pathA~B]*/
+	u8	tx_ant_idx[2][ODM_ASSOCIATE_ENTRY_NUM]; /*@[pathA~B] [MACID 0~128]*/
+	u8	rx_default_ant_idx[2]; /*@[pathA~B]*/
 };
 #endif
 
@@ -44,34 +54,34 @@ struct smt_ant_honbo {
 	u32	update_beam_codeword;
 	u32	ant_num; /*number of "used" smart beam antenna*/
 	u32	ant_num_total;/*number of "total" smart beam antenna*/
-	u32	first_train_ant; /*decide witch antenna to train first*/
+	u32	first_train_ant; /*@decide witch antenna to train first*/
 
 	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
-	u32	pkt_rssi_pre[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];/*rssi of each path with a certain beam pattern*/
+	u32	pkt_rssi_pre[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];/*@rssi of each path with a certain beam pattern*/
 	u8	beam_train_rssi_diff[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
 	u8	beam_train_cnt[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
-	u32	rfu_codeword_table[4]; /*2G beam truth table*/
-	u32	rfu_codeword_table_5g[4]; /*5G beam truth table*/
-	u32	beam_patten_num_each_ant;/*number of  beam can be switched in each antenna*/
+	u32	rfu_codeword_table[4]; /*@2G beam truth table*/
+	u32	rfu_codeword_table_5g[4]; /*@5G beam truth table*/
+	u32	beam_patten_num_each_ant;/*@number of  beam can be switched in each antenna*/
 	u32	rx_idle_beam[SUPPORT_RF_PATH_NUM];
 	u32	pkt_rssi_sum[8][SUPPORT_BEAM_PATTERN_NUM];
 	u32	pkt_rssi_cnt[8][SUPPORT_BEAM_PATTERN_NUM];
 	#endif
-	
-	u32	fast_training_beam_num;/*current training beam_set index*/
+
+	u32	fast_training_beam_num;/*@current training beam_set index*/
 	u32	pre_fast_training_beam_num;/*pre training beam_set index*/
-	u32	rfu_codeword_total_bit_num; /* total bit number of RFU protocol*/
-	u32	rfu_each_ant_bit_num; /* bit number of RFU protocol for each ant*/
+	u32	rfu_codeword_total_bit_num; /* @total bit number of RFU protocol*/
+	u32	rfu_each_ant_bit_num; /* @bit number of RFU protocol for each ant*/
 	u8	per_beam_training_pkt_num;
 	u8	decision_holding_period;
-	
-	
+
+
 	u32	pre_codeword;
 	boolean	force_update_beam_en;
 	u32	beacon_counter;
 	u32	pre_beacon_counter;
-	u8	pkt_counter;		/*packet number that each beam-set should be colected in training state*/
-	u8	update_beam_idx;	/*the index announce that the beam can be updated*/
+	u8	pkt_counter;		/*@packet number that each beam-set should be colected in training state*/
+	u8	update_beam_idx;	/*@the index announce that the beam can be updated*/
 	u8	rfu_protocol_type;
 	u16	rfu_protocol_delay_time;
 
@@ -82,158 +92,120 @@ struct smt_ant_honbo {
 
 
 	#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-	u8	beam_set_avg_rssi_pre[SUPPORT_BEAM_SET_PATTERN_NUM];		/*avg pre_rssi of each beam set*/
-	u8	beam_set_train_val_diff[SUPPORT_BEAM_SET_PATTERN_NUM];	/*rssi of a beam pattern set, ex: a set = {ant1_beam=1, ant2_beam=3}*/
-	u8	beam_set_train_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];			/*training pkt num of each beam set*/
-	u32	beam_set_rssi_avg_sum[SUPPORT_BEAM_SET_PATTERN_NUM];			/*RSSI_sum of avg(pathA,pathB) for each beam-set)*/
-	u32	beam_path_rssi_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*RSSI_sum of each path for each beam-set)*/
-
-	u8	beam_set_avg_evm_2ss_pre[SUPPORT_BEAM_SET_PATTERN_NUM];	
-	u32	beam_path_evm_2ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*2SS evm_sum of each path for each beam-set)*/
+	u8	beam_set_avg_rssi_pre[SUPPORT_BEAM_SET_PATTERN_NUM];		/*@avg pre_rssi of each beam set*/
+	u8	beam_set_train_val_diff[SUPPORT_BEAM_SET_PATTERN_NUM];	/*@rssi of a beam pattern set, ex: a set = {ant1_beam=1, ant2_beam=3}*/
+	u8	beam_set_train_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];			/*@training pkt num of each beam set*/
+	u32	beam_set_rssi_avg_sum[SUPPORT_BEAM_SET_PATTERN_NUM];			/*@RSSI_sum of avg(pathA,pathB) for each beam-set)*/
+	u32	beam_path_rssi_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*@RSSI_sum of each path for each beam-set)*/
+
+	u8	beam_set_avg_evm_2ss_pre[SUPPORT_BEAM_SET_PATTERN_NUM];
+	u32	beam_path_evm_2ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*@2SS evm_sum of each path for each beam-set)*/
 	u32	beam_path_evm_2ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
 
 	u8	beam_set_avg_evm_1ss_pre[SUPPORT_BEAM_SET_PATTERN_NUM];
-	u32	beam_path_evm_1ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM];/*1SS evm_sum of each path for each beam-set)*/
+	u32	beam_path_evm_1ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM];/*@1SS evm_sum of each path for each beam-set)*/
 	u32	beam_path_evm_1ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
-	
-	u32	statistic_pkt_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];				/*statistic_pkt_cnt for SmtAnt make decision*/
-	
-	u8	total_beam_set_num;	/*number of  beam set can be switched*/
-	u8	total_beam_set_num_2g;/*number of  beam set can be switched in 2G*/
-	u8	total_beam_set_num_5g;/*number of  beam set can be switched in 5G*/
-
-	u8	rfu_codeword_table_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*2G beam truth table*/
-	u8	rfu_codeword_table_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*5G beam truth table*/
+
+	u32	statistic_pkt_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];				/*@statistic_pkt_cnt for SmtAnt make decision*/
+
+	u8	total_beam_set_num;	/*@number of  beam set can be switched*/
+	u8	total_beam_set_num_2g;/*@number of  beam set can be switched in 2G*/
+	u8	total_beam_set_num_5g;/*@number of  beam set can be switched in 5G*/
+
+	u8	rfu_codeword_table_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*@2G beam truth table*/
+	u8	rfu_codeword_table_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*@5G beam truth table*/
 	u8	rx_idle_beam_set_idx;	/*the filanl decsion result*/
 	#endif
-	
+
 
 };
-#endif /*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+#endif /*@#if (defined(CONFIG_HL_SMART_ANTENNA))*/
 
 struct smt_ant {
 	u8	smt_ant_vendor;
 	u8	smt_ant_type;
-	u8	tx_desc_mode; /*0:3 bit mode, 1:2 bit mode*/
+	u8	tx_desc_mode; /*@0:3 bit mode, 1:2 bit mode*/
 	#if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
 	struct	smt_ant_cumitek	cumi_smtant_table;
 	#endif
 };
 
 #if (defined(CONFIG_CUMITEK_SMART_ANTENNA))
-void
-phydm_cumitek_smt_tx_ant_update(
-	void		*p_dm_void,
-	u8		tx_ant_idx_path_a,
-	u8		tx_ant_idx_path_b,
-	u32		mac_id
-);
-
-void
-phydm_cumitek_smt_rx_default_ant_update(
-	void		*p_dm_void,
-	u8		rx_ant_idx_path_a,
-	u8		rx_ant_idx_path_b
-);
-
-void
-phydm_cumitek_smt_ant_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
+void phydm_cumitek_smt_tx_ant_update(
+	void *dm_void,
+	u8 tx_ant_idx_path_a,
+	u8 tx_ant_idx_path_b,
+	u32 mac_id);
+
+void phydm_cumitek_smt_rx_default_ant_update(
+	void *dm_void,
+	u8 rx_ant_idx_path_a,
+	u8 rx_ant_idx_path_b);
+
+void phydm_cumitek_smt_ant_debug(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len);
 
 #endif
 
-
 #if (defined(CONFIG_HL_SMART_ANTENNA))
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-phydm_beam_switch_workitem_callback(
-	void	*p_context
-);
+void phydm_beam_switch_workitem_callback(
+	void *context);
+
+void phydm_beam_decision_workitem_callback(
+	void *context);
+#endif /*@#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
 
-void
-phydm_beam_decision_workitem_callback(
-	void	*p_context
-);
-#endif /*#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)*/
+#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
+void phydm_hl_smart_ant_type2_init_8822b(
+	void *dm_void);
 
+void phydm_update_beam_pattern_type2(
+	void *dm_void,
+	u32 codeword,
+	u32 codeword_length);
 
+void phydm_set_rfu_beam_pattern_type2(
+	void *dm_void);
 
-#ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
-void
-phydm_hl_smart_ant_type2_init_8822b(
-	void		*p_dm_void
-);
-
-void
-phydm_update_beam_pattern_type2(
-	void		*p_dm_void,
-	u32		codeword,
-	u32		codeword_length
-);
-
-void
-phydm_set_rfu_beam_pattern_type2(
-	void		*p_dm_void
-);
-
-void
-phydm_hl_smart_ant_debug_type2(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
-
-void
-phydm_process_rssi_for_hb_smtant_type2(
-	void		*p_dm_void,
-	void		*p_phy_info_void,
-	void		*p_pkt_info_void,
-	u8		rssi_avg	
-);
-
-#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE2))*/
+void phydm_hl_smt_ant_dbg_type2(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len);
 
+void phydm_process_rssi_for_hb_smtant_type2(
+	void *dm_void,
+	void *phy_info_void,
+	void *pkt_info_void,
+	u8 rssi_avg);
 
-#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
+#endif /*@#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE2))*/
 
-void
-phydm_update_beam_pattern(
-	void		*p_dm_void,
-	u32		codeword,
-	u32		codeword_length
-);
-
-void
-phydm_set_all_ant_same_beam_num(
-	void		*p_dm_void
-);
-
-void
-phydm_hl_smart_ant_debug(
-	void		*p_dm_void,
-	char		input[][16],
-	u32		*_used,
-	char		*output,
-	u32		*_out_len,
-	u32		input_num
-);
-
-#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))*/
-#endif/*#if (defined(CONFIG_HL_SMART_ANTENNA))*/
-#endif/*#if (defined(CONFIG_SMART_ANTENNA))*/
-
-void
-phydm_smt_ant_init(
-	void		*p_dm_void
-);
+#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
 
+void phydm_update_beam_pattern(
+	void *dm_void,
+	u32 codeword,
+	u32 codeword_length);
+
+void phydm_set_all_ant_same_beam_num(
+	void *dm_void);
+
+void phydm_hl_smart_ant_debug(
+	void *dm_void,
+	char input[][16],
+	u32 *_used,
+	char *output,
+	u32 *_out_len);
+
+#endif /*@#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))*/
+#endif /*@#if (defined(CONFIG_HL_SMART_ANTENNA))*/
+void phydm_smt_ant_init(void *dm_void);
+#endif /*@#if (defined(CONFIG_SMART_ANTENNA))*/
 #endif
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.c
index 9c312a94477e..41b5af9922da 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,522 +9,1104 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 
-/* ************************************************************
+/*************************************************************
  * include files
- * ************************************************************ */
+ ************************************************************/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
-void
-phydm_dynamicsoftmletting(
-	struct PHY_DM_STRUCT		*p_dm
-)
-{
+#ifdef CONFIG_ADAPTIVE_SOML
 
+void phydm_dynamicsoftmletting(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u32 ret_val;
 
 #if (RTL8822B_SUPPORT == 1)
-	if (*(p_dm->p_mp_mode) == false) {
-		if (p_dm->support_ic_type & ODM_RTL8822B) {
-
-			if ((!p_dm->is_linked)|(p_dm->iot_table.is_linked_cmw500))
+	if (!*dm->mp_mode) {
+		if (dm->support_ic_type & ODM_RTL8822B) {
+			if (!dm->is_linked | dm->iot_table.is_linked_cmw500)
 				return;
 
-			if (true == p_dm->bsomlenabled) {
-				PHYDM_DBG(p_dm, ODM_COMP_API, ("PHYDM_DynamicSoftMLSetting(): SoML has been enable, skip dynamic SoML switch\n"));
-				return; 		
+			if (dm->bsomlenabled) {
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "PHYDM_DynamicSoftMLSetting(): SoML has been enable, skip dynamic SoML switch\n");
+				return;
 			}
 
-			ret_val = odm_get_bb_reg(p_dm, 0xf8c, MASKBYTE0);
-			PHYDM_DBG(p_dm, ODM_COMP_API, ("PHYDM_DynamicSoftMLSetting(): Read 0xF8C = 0x%08X\n", ret_val));
+			ret_val = odm_get_bb_reg(dm, R_0xf8c, MASKBYTE0);
+			PHYDM_DBG(dm, ODM_COMP_API,
+				  "PHYDM_DynamicSoftMLSetting(): Read 0xF8C = 0x%08X\n",
+				  ret_val);
 
 			if (ret_val < 0x16) {
-				PHYDM_DBG(p_dm, ODM_COMP_API, ("PHYDM_DynamicSoftMLSetting(): 0xF8C(== 0x%08X) < 0x16, enable SoML\n", ret_val));
-				phydm_somlrxhp_setting(p_dm, true);
-				/*odm_set_bb_reg(p_dm, 0x19a8, MASKDWORD, 0xc10a0000);*/
-				p_dm->bsomlenabled = true;
+				PHYDM_DBG(dm, ODM_COMP_API,
+					  "PHYDM_DynamicSoftMLSetting(): 0xF8C(== 0x%08X) < 0x16, enable SoML\n",
+					  ret_val);
+				phydm_somlrxhp_setting(dm, true);
+#if 0
+			/*odm_set_bb_reg(dm, R_0x19a8, MASKDWORD, 0xc10a0000);*/
+#endif
+				dm->bsomlenabled = true;
 			}
 		}
 	}
 #endif
-
 }
 
-#ifdef CONFIG_ADAPTIVE_SOML
-void
-phydm_soml_on_off(
-	void		*p_dm_void,
-	u8		swch
-)
+void phydm_soml_on_off(void *dm_void, u8 swch)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml	*p_dm_soml_table = &(p_dm->dm_soml_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
 
 	if (swch == SOML_ON) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "(( Turn on )) SOML\n");
 
-		PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("(( Turn on )) SOML\n"));
-
-		if (p_dm->support_ic_type == ODM_RTL8822B)
-			phydm_somlrxhp_setting(p_dm, true);
-		else if (p_dm->support_ic_type == ODM_RTL8197F)
-			odm_set_bb_reg(p_dm, 0x998, BIT(6), swch);
+		if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+			odm_set_bb_reg(dm, R_0x998, BIT(6), swch);
+#if (RTL8822B_SUPPORT == 1)
+		else if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_somlrxhp_setting(dm, true);
+#endif
 
 	} else if (swch == SOML_OFF) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "(( Turn off )) SOML\n");
 
-		PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("(( Turn off )) SOML\n"));
-
-		if (p_dm->support_ic_type == ODM_RTL8822B)
-			phydm_somlrxhp_setting(p_dm, false);
-		else if (p_dm->support_ic_type == ODM_RTL8197F)
-			odm_set_bb_reg(p_dm, 0x998, BIT(6), swch);
+		if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+			odm_set_bb_reg(dm, R_0x998, BIT(6), swch);
+#if (RTL8822B_SUPPORT == 1)
+		else if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_somlrxhp_setting(dm, false);
+#endif
 	}
-	p_dm_soml_table->soml_on_off = swch;
+	soml_tab->soml_on_off = swch;
 }
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-phydm_adaptive_soml_callback(
-	struct timer_list		*p_timer
-)
-{
-	struct _ADAPTER		*adapter = (struct _ADAPTER *)p_timer->Adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &(p_hal_data->DM_OutSrc);
-	struct adaptive_soml	*p_dm_soml_table = &(p_dm->dm_soml_table);
-
-#if DEV_BUS_TYPE == RT_PCI_INTERFACE
-#if USE_WORKITEM
-	odm_schedule_work_item(&(p_dm_soml_table->phydm_adaptive_soml_workitem));
-#else
+void phydm_adaptive_soml_callback(struct phydm_timer_list *timer)
+{
+	void *adapter = (void *)timer->Adapter;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+
+	#if DEV_BUS_TYPE == RT_PCI_INTERFACE
+	#if USE_WORKITEM
+	odm_schedule_work_item(&soml_tab->phydm_adaptive_soml_workitem);
+	#else
 	{
-		/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_callback\n");*/
-		phydm_adsl(p_dm);
+#if 0
+		/*@dbg_print("%s\n",__func__);*/
+#endif
+		phydm_adsl(dm);
 	}
+	#endif
+	#else
+	odm_schedule_work_item(&soml_tab->phydm_adaptive_soml_workitem);
+	#endif
+}
+
+void phydm_adaptive_soml_workitem_callback(void *context)
+{
+#ifdef CONFIG_ADAPTIVE_SOML
+	void *adapter = (void *)context;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+
+#if 0
+	/*@dbg_print("%s\n",__func__);*/
 #endif
-#else
-	odm_schedule_work_item(&(p_dm_soml_table->phydm_adaptive_soml_workitem));
+	phydm_adsl(dm);
 #endif
 }
 
-void
-phydm_adaptive_soml_workitem_callback(
-	void		*p_context
-)
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void phydm_adaptive_soml_callback(void *dm_void)
 {
-#ifdef CONFIG_ADAPTIVE_SOML
-	struct _ADAPTER		*p_adapter = (struct _ADAPTER *)p_context;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(p_adapter);
-	struct PHY_DM_STRUCT		*p_dm = &(p_hal_data->DM_OutSrc);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *padapter = dm->adapter;
+
+	if (*dm->is_net_closed == true)
+		return;
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		phydm_adsl(dm);
+	else {
+		/* @Can't do I/O in timer callback*/
+		phydm_run_in_thread_cmd(dm,
+					phydm_adaptive_soml_workitem_callback,
+					dm);
+	}
+}
+
+void phydm_adaptive_soml_workitem_callback(void *context)
+{
+	struct dm_struct *dm = (void *)context;
 
-	/*dbg_print("phydm_adaptive_soml-phydm_adaptive_soml_workitem_callback\n");*/
-	phydm_adsl(p_dm);
+#if 0
+	/*@dbg_print("%s\n",__func__);*/
 #endif
+	phydm_adsl(dm);
 }
 
 #else
+void phydm_adaptive_soml_callback(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-void
-phydm_adaptive_soml_callback(
-	void		*p_dm_void
-)
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "******SOML_Callback******\n");
+	phydm_adsl(dm);
+}
+#endif
+
+void phydm_rx_rate_for_soml(void *dm_void, void *pkt_info_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	u8 data_rate;
+
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	data_rate = (pktinfo->data_rate & 0x7f);
+
+	if (pktinfo->data_rate >= ODM_RATEMCS0 &&
+	    pktinfo->data_rate <= ODM_RATEMCS31)
+		soml_tab->ht_cnt[data_rate - ODM_RATEMCS0]++;
+	else if ((pktinfo->data_rate >= ODM_RATEVHTSS1MCS0) &&
+		 (pktinfo->data_rate <= ODM_RATEVHTSS4MCS9))
+		soml_tab->vht_cnt[data_rate - ODM_RATEVHTSS1MCS0]++;
+}
 
-	PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("******SOML_Callback******\n"));
-	phydm_adsl(p_dm);
+void phydm_rx_qam_for_soml(void *dm_void, void *pkt_info_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	struct phydm_perpkt_info_struct *pktinfo = NULL;
+	u8 date_rate;
+
+	pktinfo = (struct phydm_perpkt_info_struct *)pkt_info_void;
+	date_rate = (pktinfo->data_rate & 0x7f);
+	if (soml_tab->soml_state_cnt < (soml_tab->soml_train_num << 1)) {
+		if (soml_tab->soml_on_off == SOML_ON) {
+			return;
+		} else if (soml_tab->soml_on_off == SOML_OFF) {
+			if (date_rate >= ODM_RATEMCS8 &&
+			    date_rate <= ODM_RATEMCS10)
+				soml_tab->num_ht_qam[BPSK_QPSK]++;
+
+			else if ((date_rate >= ODM_RATEMCS11) &&
+				 (date_rate <= ODM_RATEMCS12))
+				soml_tab->num_ht_qam[QAM16]++;
+
+			else if ((date_rate >= ODM_RATEMCS13) &&
+				 (date_rate <= ODM_RATEMCS15))
+				soml_tab->num_ht_qam[QAM64]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS0) &&
+				 (date_rate <= ODM_RATEVHTSS2MCS2))
+				soml_tab->num_vht_qam[BPSK_QPSK]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS3) &&
+				 (date_rate <= ODM_RATEVHTSS2MCS4))
+				soml_tab->num_vht_qam[QAM16]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS5) &&
+				 (date_rate <= ODM_RATEVHTSS2MCS5))
+				soml_tab->num_vht_qam[QAM64]++;
+
+			else if ((date_rate >= ODM_RATEVHTSS2MCS8) &&
+				 (date_rate <= ODM_RATEVHTSS2MCS9))
+				soml_tab->num_vht_qam[QAM256]++;
+		}
+	}
+}
 
+void phydm_soml_reset_rx_rate(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 order;
+
+	for (order = 0; order < HT_RATE_IDX; order++) {
+		soml_tab->ht_cnt[order] = 0;
+		soml_tab->pre_ht_cnt[order] = 0;
+	}
+
+	for (order = 0; order < VHT_RATE_IDX; order++) {
+		soml_tab->vht_cnt[order] = 0;
+		soml_tab->pre_vht_cnt[order] = 0;
+	}
 }
 
-#endif
+void phydm_soml_reset_qam(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 order;
 
+	for (order = 0; order < HT_ORDER_TYPE; order++)
+		soml_tab->num_ht_qam[order] = 0;
 
+	for (order = 0; order < VHT_ORDER_TYPE; order++)
+		soml_tab->num_vht_qam[order] = 0;
+}
 
+void phydm_soml_cfo_process(void *dm_void, s32 *diff_a, s32 *diff_b)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 value32, value32_1, value32_2, value32_3;
+	s32 cfo_acq_a, cfo_acq_b, cfo_end_a, cfo_end_b;
+
+	value32 = odm_get_bb_reg(dm, R_0xd10, MASKDWORD);
+	value32_1 = odm_get_bb_reg(dm, R_0xd14, MASKDWORD);
+	value32_2 = odm_get_bb_reg(dm, R_0xd50, MASKDWORD);
+	value32_3 = odm_get_bb_reg(dm, R_0xd54, MASKDWORD);
+
+	cfo_acq_a = (s32)((value32 & 0x1fff0000) >> 16);
+	cfo_end_a = (s32)((value32_1 & 0x1fff0000) >> 16);
+	cfo_acq_b = (s32)((value32_2 & 0x1fff0000) >> 16);
+	cfo_end_b = (s32)((value32_3 & 0x1fff0000) >> 16);
+
+	*diff_a = ((cfo_acq_a >= cfo_end_a) ? (cfo_acq_a - cfo_end_a) :
+		  (cfo_end_a - cfo_acq_a));
+	*diff_b = ((cfo_acq_b >= cfo_end_b) ? (cfo_acq_b - cfo_end_b) :
+		  (cfo_end_b - cfo_acq_b));
+
+	*diff_a = ((*diff_a * 312) + (*diff_a >> 1)) >> 12; /* @312.5/2^12 */
+	*diff_b = ((*diff_b * 312) + (*diff_b >> 1)) >> 12; /* @312.5/2^12 */
+}
 
-void
-phydm_soml_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char		*output,
-	u32		*_out_len
-)
+void phydm_soml_debug(void *dm_void, char input[][16], u32 *_used,
+		      char *output, u32 *_out_len)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml	*p_dm_soml_table = &(p_dm->dm_soml_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
 	u32 used = *_used;
 	u32 out_len = *_out_len;
+	u32 dm_value[10] = {0};
+	u8 i = 0, input_idx = 0;
+
+	for (i = 0; i < 5; i++) {
+		if (input[i + 1]) {
+			PHYDM_SSCANF(input[i + 1], DCMD_DECIMAL, &dm_value[i]);
+			input_idx++;
+		}
+	}
+
+	if (input_idx == 0)
+		return;
 
 	if (dm_value[0] == 1) { /*Turn on/off SOML*/
-		p_dm_soml_table->soml_select = (u8)dm_value[1];
+		soml_tab->soml_select = (u8)dm_value[1];
 
 	} else if (dm_value[0] == 2) { /*training number for SOML*/
 
-		p_dm_soml_table->soml_train_num = (u8)dm_value[1];
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_train_num = ((%d))\n", p_dm_soml_table->soml_train_num));
+		soml_tab->soml_train_num = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_train_num = ((%d))\n",
+			 soml_tab->soml_train_num);
 	} else if (dm_value[0] == 3) { /*training interval for SOML*/
 
-		p_dm_soml_table->soml_intvl = (u8)dm_value[1];
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_intvl = ((%d))\n", p_dm_soml_table->soml_intvl));
-	} else if (dm_value[0] == 4) { /*function period for SOML*/
-
-		p_dm_soml_table->soml_period = (u8)dm_value[1];
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_period = ((%d))\n", p_dm_soml_table->soml_period));
-	} else if (dm_value[0] == 5) { /*delay_time for SOML*/
-
-		p_dm_soml_table->soml_delay_time = (u8)dm_value[1];
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_delay_time = ((%d))\n", p_dm_soml_table->soml_delay_time));
-	} else if (dm_value[0] == 100) { /*show parameters*/
-
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_train_num = ((%d))\n", p_dm_soml_table->soml_train_num));
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_intvl = ((%d))\n", p_dm_soml_table->soml_intvl));
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_period = ((%d))\n", p_dm_soml_table->soml_period));
-		PHYDM_SNPRINTF((output + used, out_len - used, "soml_delay_time = ((%d))\n", p_dm_soml_table->soml_delay_time));
+		soml_tab->soml_intvl = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_intvl = ((%d))\n", soml_tab->soml_intvl);
+	} else if (dm_value[0] == 4) { /*@function period for SOML*/
+
+		soml_tab->soml_period = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_period = ((%d))\n", soml_tab->soml_period);
+	} else if (dm_value[0] == 5) { /*@delay_time for SOML*/
+
+		soml_tab->soml_delay_time = (u8)dm_value[1];
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_delay_time = ((%d))\n",
+			 soml_tab->soml_delay_time);
+	} else if (dm_value[0] == 6) { /* @for SOML Rx QAM distribution th*/
+		if (dm_value[1] == 256) {
+			soml_tab->qam256_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "qam256_dist_th = ((%d))\n",
+				 soml_tab->qam256_dist_th);
+		} else if (dm_value[1] == 64) {
+			soml_tab->qam64_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "qam64_dist_th = ((%d))\n",
+				 soml_tab->qam64_dist_th);
+		} else if (dm_value[1] == 16) {
+			soml_tab->qam16_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "qam16_dist_th = ((%d))\n",
+				 soml_tab->qam16_dist_th);
+		} else if (dm_value[1] == 4) {
+			soml_tab->bpsk_qpsk_dist_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "bpsk_qpsk_dist_th = ((%d))\n",
+				 soml_tab->bpsk_qpsk_dist_th);
+		}
+	} else if (dm_value[0] == 7) { /* @for SOML cfo th*/
+		if (dm_value[1] == 256) {
+			soml_tab->cfo_qam256_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "cfo_qam256_th = ((%d KHz))\n",
+				 soml_tab->cfo_qam256_th);
+		} else if (dm_value[1] == 64) {
+			soml_tab->cfo_qam64_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "cfo_qam64_th = ((%d KHz))\n",
+				 soml_tab->cfo_qam64_th);
+		} else if (dm_value[1] == 16) {
+			soml_tab->cfo_qam16_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "cfo_qam16_th = ((%d KHz))\n",
+				 soml_tab->cfo_qam16_th);
+		} else if (dm_value[1] == 4) {
+			soml_tab->cfo_qpsk_th = (u8)dm_value[2];
+			PDM_SNPF(out_len, used, output + used, out_len - used,
+				 "cfo_qpsk_th = ((%d KHz))\n",
+				 soml_tab->cfo_qpsk_th);
+		}
+	} else if (dm_value[0] == 100) {
+		/*show parameters*/
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_select = ((%d))\n", soml_tab->soml_select);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_train_num = ((%d))\n",
+			 soml_tab->soml_train_num);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_intvl = ((%d))\n", soml_tab->soml_intvl);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_period = ((%d))\n", soml_tab->soml_period);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "soml_delay_time = ((%d))\n\n",
+			 soml_tab->soml_delay_time);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "qam256_dist_th = ((%d)),  qam64_dist_th = ((%d)), ",
+			 soml_tab->qam256_dist_th,
+			 soml_tab->qam64_dist_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "qam16_dist_th = ((%d)),  bpsk_qpsk_dist_th = ((%d))\n",
+			 soml_tab->qam16_dist_th,
+			 soml_tab->bpsk_qpsk_dist_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "cfo_qam256_th = ((%d KHz)),  cfo_qam64_th = ((%d KHz)), ",
+			 soml_tab->cfo_qam256_th,
+			 soml_tab->cfo_qam64_th);
+		PDM_SNPF(out_len, used, output + used, out_len - used,
+			 "cfo_qam16_th = ((%d KHz)),  cfo_qpsk_th  = ((%d KHz))\n",
+			 soml_tab->cfo_qam16_th,
+			 soml_tab->cfo_qpsk_th);
 	}
 	*_used = used;
 	*_out_len = out_len;
 }
 
-void
-phydm_soml_statistics(
-	void		*p_dm_void,
-	u8		on_off_state
+void phydm_soml_stats_ht_on(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 i, mcs0;
+	u16 num_bytes_diff, num_rate_diff;
+
+	mcs0 = ODM_RATEMCS0;
+	for (i = mcs0; i <= ODM_RATEMCS15; i++) {
+		num_rate_diff = soml_tab->ht_cnt[i - mcs0] -
+				soml_tab->pre_ht_cnt[i - mcs0];
+		soml_tab->ht_cnt_on[i - mcs0] += num_rate_diff;
+		soml_tab->pre_ht_cnt[i - mcs0] = soml_tab->ht_cnt[i - mcs0];
+		num_bytes_diff = soml_tab->ht_byte[i - mcs0] -
+				 soml_tab->pre_ht_byte[i - mcs0];
+		soml_tab->ht_byte_on[i - mcs0] += num_bytes_diff;
+		soml_tab->pre_ht_byte[i - mcs0] = soml_tab->ht_byte[i - mcs0];
+	}
+}
+
+void phydm_soml_stats_ht_off(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 i, mcs0;
+	u16 num_bytes_diff, num_rate_diff;
+
+	mcs0 = ODM_RATEMCS0;
+	for (i = mcs0; i <= ODM_RATEMCS15; i++) {
+		num_rate_diff = soml_tab->ht_cnt[i - mcs0] -
+				soml_tab->pre_ht_cnt[i - mcs0];
+		soml_tab->ht_cnt_off[i - mcs0] += num_rate_diff;
+		soml_tab->pre_ht_cnt[i - mcs0] = soml_tab->ht_cnt[i - mcs0];
+		num_bytes_diff = soml_tab->ht_byte[i - mcs0] -
+				 soml_tab->pre_ht_byte[i - mcs0];
+		soml_tab->ht_byte_off[i - mcs0] += num_bytes_diff;
+		soml_tab->pre_ht_byte[i - mcs0] = soml_tab->ht_byte[i - mcs0];
+	}
+}
 
-)
+void phydm_soml_stats_vht_on(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml	*p_dm_soml_table = &(p_dm->dm_soml_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 j, vht0;
+	u16 num_bytes_diff, num_rate_diff;
+
+	vht0 = ODM_RATEVHTSS1MCS0;
+	for (j = vht0; j <= ODM_RATEVHTSS2MCS9; j++) {
+		num_rate_diff = soml_tab->vht_cnt[j - vht0] -
+				soml_tab->pre_vht_cnt[j - vht0];
+		soml_tab->vht_cnt_on[j - vht0] += num_rate_diff;
+		soml_tab->pre_vht_cnt[j - vht0] = soml_tab->vht_cnt[j - vht0];
+		num_bytes_diff = soml_tab->vht_byte[j - vht0] -
+				 soml_tab->pre_vht_byte[j - vht0];
+		soml_tab->vht_byte_on[j - vht0] += num_bytes_diff;
+		soml_tab->pre_vht_byte[j - vht0] = soml_tab->vht_byte[j - vht0];
+	}
+}
 
-	u8	i;
-	u32	num_bytes_diff;
+void phydm_soml_stats_vht_off(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 j, vht0;
+	u16 num_bytes_diff, num_rate_diff;
+
+	vht0 = ODM_RATEVHTSS1MCS0;
+	for (j = vht0; j <= ODM_RATEVHTSS2MCS9; j++) {
+		num_rate_diff = soml_tab->vht_cnt[j - vht0] -
+				soml_tab->pre_vht_cnt[j - vht0];
+		soml_tab->vht_cnt_off[j - vht0] += num_rate_diff;
+		soml_tab->pre_vht_cnt[j - vht0] = soml_tab->vht_cnt[j - vht0];
+		num_bytes_diff = soml_tab->vht_byte[j - vht0] -
+				 soml_tab->pre_vht_byte[j - vht0];
+		soml_tab->vht_byte_off[j - vht0] += num_bytes_diff;
+		soml_tab->pre_vht_byte[j - vht0] = soml_tab->vht_byte[j - vht0];
+	}
+}
 
-	if (p_dm->support_ic_type == ODM_RTL8197F) {
-		if (on_off_state == SOML_ON) {
-			for (i = 0; i < HT_RATE_IDX; i++) {
-				num_bytes_diff = p_dm_soml_table->num_ht_bytes[i] - p_dm_soml_table->pre_num_ht_bytes[i];
-				p_dm_soml_table->num_ht_bytes_on[i] += num_bytes_diff;
-				p_dm_soml_table->pre_num_ht_bytes[i] = p_dm_soml_table->num_ht_bytes[i];
-			}
-		} else if (on_off_state == SOML_OFF) {
-			for (i = 0; i < HT_RATE_IDX; i++) {
-				num_bytes_diff = p_dm_soml_table->num_ht_bytes[i] - p_dm_soml_table->pre_num_ht_bytes[i];
-				p_dm_soml_table->num_ht_bytes_off[i] += num_bytes_diff;
-				p_dm_soml_table->pre_num_ht_bytes[i] = p_dm_soml_table->num_ht_bytes[i];
-			}
-		}
-	} else if (p_dm->support_ic_type == ODM_RTL8822B) {
-		if (on_off_state == SOML_ON) {
-			for (i = 0; i < VHT_RATE_IDX; i++) {
-				num_bytes_diff = p_dm_soml_table->num_vht_bytes[i] - p_dm_soml_table->pre_num_vht_bytes[i];
-				p_dm_soml_table->num_vht_bytes_on[i] += num_bytes_diff;
-				p_dm_soml_table->pre_num_vht_bytes[i] = p_dm_soml_table->num_vht_bytes[i];
-			}
-		} else if (on_off_state == SOML_OFF) {
-			for (i = 0; i < VHT_RATE_IDX; i++) {
-				num_bytes_diff = p_dm_soml_table->num_vht_bytes[i] - p_dm_soml_table->pre_num_vht_bytes[i];
-				p_dm_soml_table->num_vht_bytes_off[i] += num_bytes_diff;
-				p_dm_soml_table->pre_num_vht_bytes[i] = p_dm_soml_table->num_vht_bytes[i];
-			}
-		}
+void phydm_soml_statistics(void *dm_void, u8 on_off_state)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+
+	if (on_off_state == SOML_ON) {
+		if (*dm->channel <= 14)
+			phydm_soml_stats_ht_on(dm);
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_soml_stats_vht_on(dm);
+	} else if (on_off_state == SOML_OFF) {
+		if (*dm->channel <= 14)
+			phydm_soml_stats_ht_off(dm);
+		if (dm->support_ic_type == ODM_RTL8822B)
+			phydm_soml_stats_vht_off(dm);
 	}
 }
 
-void
-phydm_adsl(
-	void		*p_dm_void
-)
+void phydm_adsl_init_state(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml		*p_dm_soml_table = &(p_dm->dm_soml_table);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+
+	u8 next_on_off;
+	u16 ht_reset[HT_RATE_IDX] = {0}, vht_reset[VHT_RATE_IDX] = {0};
+	u8 size = sizeof(ht_reset[0]);
+
+	phydm_soml_reset_rx_rate(dm);
+	odm_move_memory(dm, soml_tab->ht_byte, ht_reset,
+			HT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->ht_byte_on, ht_reset,
+			HT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->ht_byte_off, ht_reset,
+			HT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->vht_byte, vht_reset,
+			VHT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->vht_byte_on, vht_reset,
+			VHT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->vht_byte_off, vht_reset,
+			VHT_RATE_IDX * size);
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		soml_tab->cfo_cnt++;
+		phydm_soml_cfo_process(dm,
+				       &soml_tab->cfo_diff_a,
+				       &soml_tab->cfo_diff_b);
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n",
+			  soml_tab->cfo_cnt, soml_tab->cfo_diff_a,
+			  soml_tab->cfo_diff_b);
+		soml_tab->cfo_diff_sum_a += soml_tab->cfo_diff_a;
+		soml_tab->cfo_diff_sum_b += soml_tab->cfo_diff_b;
+	}
 
-	u8	i;
-	u8	next_on_off;
-	u8	rate_num = 1, rate_ss_shift = 0;
-	u32	byte_total_on = 0, byte_total_off = 0;
-	u32	ht_reset[HT_RATE_IDX] = {0}, vht_reset[VHT_RATE_IDX] = {0};
-	u8	size = sizeof(ht_reset[0]);
+	soml_tab->is_soml_method_enable = 1;
+	soml_tab->soml_state_cnt++;
+	next_on_off = (soml_tab->soml_on_off == SOML_ON) ? SOML_ON : SOML_OFF;
+	phydm_soml_on_off(dm, next_on_off);
+	odm_set_timer(dm, &soml_tab->phydm_adaptive_soml_timer,
+		      soml_tab->soml_delay_time); /*@ms*/
+}
 
-	if (p_dm->support_ic_type & ODM_IC_4SS)
+void phydm_adsl_odd_state(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u16 ht_reset[HT_RATE_IDX] = {0}, vht_reset[VHT_RATE_IDX] = {0};
+	u8 size = sizeof(ht_reset[0]);
+
+	soml_tab->soml_state_cnt++;
+	odm_move_memory(dm, soml_tab->pre_ht_cnt, soml_tab->ht_cnt,
+			HT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->pre_vht_cnt, soml_tab->vht_cnt,
+			VHT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->pre_ht_byte, soml_tab->ht_byte,
+			HT_RATE_IDX * size);
+	odm_move_memory(dm, soml_tab->pre_vht_byte, soml_tab->vht_byte,
+			VHT_RATE_IDX * size);
+
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		soml_tab->cfo_cnt++;
+		phydm_soml_cfo_process(dm,
+				       &soml_tab->cfo_diff_a,
+				       &soml_tab->cfo_diff_b);
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n",
+			  soml_tab->cfo_cnt, soml_tab->cfo_diff_a,
+			  soml_tab->cfo_diff_b);
+		soml_tab->cfo_diff_sum_a += soml_tab->cfo_diff_a;
+		soml_tab->cfo_diff_sum_b += soml_tab->cfo_diff_b;
+	}
+	odm_set_timer(dm, &soml_tab->phydm_adaptive_soml_timer,
+		      soml_tab->soml_intvl); /*@ms*/
+}
+
+void phydm_adsl_even_state(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 next_on_off;
+
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		soml_tab->cfo_cnt++;
+		phydm_soml_cfo_process(dm,
+				       &soml_tab->cfo_diff_a,
+				       &soml_tab->cfo_diff_b);
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ (%d) cfo_diff_a = %d KHz; cfo_diff_b = %d KHz ]\n",
+			  soml_tab->cfo_cnt, soml_tab->cfo_diff_a,
+			  soml_tab->cfo_diff_b);
+		soml_tab->cfo_diff_sum_a += soml_tab->cfo_diff_a;
+		soml_tab->cfo_diff_sum_b += soml_tab->cfo_diff_b;
+	}
+	soml_tab->soml_state_cnt++;
+	phydm_soml_statistics(dm, soml_tab->soml_on_off);
+	next_on_off = (soml_tab->soml_on_off == SOML_ON) ? SOML_OFF : SOML_ON;
+	phydm_soml_on_off(dm, next_on_off);
+	odm_set_timer(dm, &soml_tab->phydm_adaptive_soml_timer,
+		      soml_tab->soml_delay_time); /*@ms*/
+}
+
+void phydm_adsl_decision_state(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	u8 i;
+	u8 next_on_off, mcs0 = ODM_RATEMCS0, vht0 = ODM_RATEVHTSS1MCS0;
+	u8 rate_num = 1, rate_ss_shift = 0;
+	u16 num_total_qam = 0;
+	u32 ht_total_cnt_on = 0, ht_total_cnt_off = 0;
+	u32 total_ht_rate_on = 0, total_ht_rate_off = 0;
+	u32 vht_total_cnt_on = 0, vht_total_cnt_off = 0;
+	u32 total_vht_rate_on = 0, total_vht_rate_off = 0;
+	u32 rate_per_pkt_on = 0, rate_per_pkt_off = 0;
+	s32 cfo_diff_avg_a, cfo_diff_avg_b;
+	u16 vht_phy_rate_table[] = {
+		/*@20M*/
+		6, 13, 19, 26, 39, 52, 58, 65, 78, 90, /*@1SS MCS0~9*/
+		13, 26, 39, 52, 78, 104, 117, 130, 156, 180 /*@2SSMCS0~9*/
+	};
+
+	if (dm->support_ic_type & ODM_IC_4SS)
 		rate_num = 4;
-	else if (p_dm->support_ic_type & ODM_IC_3SS)
+	else if (dm->support_ic_type & ODM_IC_3SS)
 		rate_num = 3;
-	else if (p_dm->support_ic_type & ODM_IC_2SS)
+	else if (dm->support_ic_type & ODM_IC_2SS)
 		rate_num = 2;
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[Decisoin state ]\n");
+	phydm_soml_statistics(dm, soml_tab->soml_on_off);
+	if (*dm->channel <= 14) {
+		/* @[Search 1st and 2nd rate by counter] */
+		for (i = 0; i < rate_num; i++) {
+			rate_ss_shift = (i << 3);
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "*ht_cnt_on  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+				  (rate_ss_shift), (rate_ss_shift + 7),
+				  soml_tab->ht_cnt_on[rate_ss_shift + 0],
+				  soml_tab->ht_cnt_on[rate_ss_shift + 1],
+				  soml_tab->ht_cnt_on[rate_ss_shift + 2],
+				  soml_tab->ht_cnt_on[rate_ss_shift + 3],
+				  soml_tab->ht_cnt_on[rate_ss_shift + 4],
+				  soml_tab->ht_cnt_on[rate_ss_shift + 5],
+				  soml_tab->ht_cnt_on[rate_ss_shift + 6],
+				  soml_tab->ht_cnt_on[rate_ss_shift + 7]);
+		}
 
-	if ((p_dm->support_ic_type & ODM_ADAPTIVE_SOML_SUPPORT_IC)) {
-		if (p_dm->number_active_client == 1) {
-			PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("rssi_min =%d\n", p_dm->rssi_min));
-			if ((p_dm->rssi_min >= SOML_RSSI_TH_HIGH) || (p_dm_soml_table->is_soml_method_enable == 1)) {
-
-				PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("> TH_H || is_soml_method_enable==1\n"));
-
-				if (p_dm->rssi_min >= SOML_RSSI_TH_LOW) {
-					PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("> TH_L, soml_state_cnt =((%d))\n", p_dm_soml_table->soml_state_cnt));
-					/*Traning state: 0(alt) 1(ori) 2(alt) 3(ori)============================================================*/
-					if (p_dm_soml_table->soml_state_cnt < ((p_dm_soml_table->soml_train_num)<<1)) {
-
-						if (p_dm_soml_table->soml_state_cnt == 0) {
-
-							if (p_dm->support_ic_type == ODM_RTL8197F) {
-
-								odm_move_memory(p_dm, p_dm_soml_table->num_ht_bytes, ht_reset, HT_RATE_IDX*size);
-								odm_move_memory(p_dm, p_dm_soml_table->num_ht_bytes_on, ht_reset, HT_RATE_IDX*size);
-								odm_move_memory(p_dm, p_dm_soml_table->num_ht_bytes_off, ht_reset, HT_RATE_IDX*size);
-							} else if (p_dm->support_ic_type == ODM_RTL8822B) {
-
-								odm_move_memory(p_dm, p_dm_soml_table->num_vht_bytes, vht_reset, VHT_RATE_IDX*size);
-								odm_move_memory(p_dm, p_dm_soml_table->num_vht_bytes_on, vht_reset, VHT_RATE_IDX*size);
-								odm_move_memory(p_dm, p_dm_soml_table->num_vht_bytes_off, vht_reset, VHT_RATE_IDX*size);
-							}
-
-							p_dm_soml_table->is_soml_method_enable = 1;
-							p_dm_soml_table->soml_state_cnt++;
-							next_on_off = (p_dm_soml_table->soml_on_off == SOML_ON) ? SOML_ON : SOML_OFF;
-							phydm_soml_on_off(p_dm, next_on_off);
-							odm_set_timer(p_dm, &p_dm_soml_table->phydm_adaptive_soml_timer, p_dm_soml_table->soml_delay_time); /*ms*/
-						} else if ((p_dm_soml_table->soml_state_cnt % 2) != 0) {
-
-							p_dm_soml_table->soml_state_cnt++;
-							if (p_dm->support_ic_type == ODM_RTL8197F)
-								odm_move_memory(p_dm, p_dm_soml_table->pre_num_ht_bytes, p_dm_soml_table->num_ht_bytes, HT_RATE_IDX*size);
-							else if (p_dm->support_ic_type == ODM_RTL8822B)
-								odm_move_memory(p_dm, p_dm_soml_table->pre_num_vht_bytes, p_dm_soml_table->num_vht_bytes, VHT_RATE_IDX*size);
-							odm_set_timer(p_dm, &p_dm_soml_table->phydm_adaptive_soml_timer, p_dm_soml_table->soml_intvl); /*ms*/
-						} else if ((p_dm_soml_table->soml_state_cnt % 2) == 0) {
-
-							p_dm_soml_table->soml_state_cnt++;
-							phydm_soml_statistics(p_dm, p_dm_soml_table->soml_on_off);
-							next_on_off = (p_dm_soml_table->soml_on_off == SOML_ON) ? SOML_OFF : SOML_ON;
-							phydm_soml_on_off(p_dm, next_on_off);
-							odm_set_timer(p_dm, &p_dm_soml_table->phydm_adaptive_soml_timer, p_dm_soml_table->soml_delay_time); /*ms*/
-						}
-					}
-					/*Decision state: ==============================================================*/
-					else {
-
-						p_dm_soml_table->soml_state_cnt = 0;
-						phydm_soml_statistics(p_dm, p_dm_soml_table->soml_on_off);
-
-						/* [Search 1st and 2ed rate by counter] */
-						if (p_dm->support_ic_type == ODM_RTL8197F) {
-
-							for (i = 0; i < rate_num; i++) {
-								rate_ss_shift = (i << 3);
-								PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("*num_ht_bytes_on  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
-									(rate_ss_shift), (rate_ss_shift+7),
-									p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 0], p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 1],
-									p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 2], p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 3],
-									p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 4], p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 5],
-									p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 6], p_dm_soml_table->num_ht_bytes_on[rate_ss_shift + 7]));
-							}
-
-							for (i = 0; i < rate_num; i++) {
-								rate_ss_shift = (i << 3);
-								PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("*num_ht_bytes_off  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
-									(rate_ss_shift), (rate_ss_shift+7),
-									p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 0], p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 1],
-									p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 2], p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 3],
-									p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 4], p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 5],
-									p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 6], p_dm_soml_table->num_ht_bytes_off[rate_ss_shift + 7]));
-							}
-
-							for (i = 0; i < HT_RATE_IDX; i++) {
-
-								byte_total_on += p_dm_soml_table->num_vht_bytes_on[i];
-								byte_total_off += p_dm_soml_table->num_vht_bytes_off[i];
-							}
-
-						} else if (p_dm->support_ic_type == ODM_RTL8822B) {
-
-							for (i = 0; i < rate_num; i++) {
-								rate_ss_shift = 10 * i;
-								PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("* num_vht_bytes_on  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
-									(i + 1),
-									p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 0], p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 1],
-									p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 2], p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 3],
-									p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 4], p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 5],
-									p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 6], p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 7],
-									p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 8], p_dm_soml_table->num_vht_bytes_on[rate_ss_shift + 9]));
-							}
-
-							for (i = 0; i < rate_num; i++) {
-								rate_ss_shift = 10 * i;
-								PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("* num_vht_bytes_off  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d}\n",
-									(i + 1),
-									p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 0], p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 1],
-									p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 2], p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 3],
-									p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 4], p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 5],
-									p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 6], p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 7],
-									p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 8], p_dm_soml_table->num_vht_bytes_off[rate_ss_shift + 9]));
-							}
-							for (i = 0; i < VHT_RATE_IDX; i++) {
-								byte_total_on += p_dm_soml_table->num_vht_bytes_on[i];
-								byte_total_off += p_dm_soml_table->num_vht_bytes_off[i];
-							}
-						}
-
-						/* [Decision] */
-						PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[  byte_total_on = %d ; byte_total_off = %d ]\n", byte_total_on, byte_total_off));
-						PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[Decisoin state ]\n"));
-						if (byte_total_on > byte_total_off) {
-							next_on_off = SOML_ON;
-							PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[ byte_total_on > byte_total_off ==> SOML_ON ]\n"));
-						} else if (byte_total_on < byte_total_off) {
-							next_on_off = SOML_OFF;
-							PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[ byte_total_on < byte_total_off ==> SOML_OFF ]\n"));
-						} else {
-							PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[ stay at soml_last_state ]\n"));
-							next_on_off = p_dm_soml_table->soml_last_state;
-						}
-
-						PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[ Final decisoin ] : "));
-						phydm_soml_on_off(p_dm, next_on_off);
-						p_dm_soml_table->soml_last_state = next_on_off;
-					}
-				} else { /* RSSI< = SOML_RSSI_TH_LOW */
-					PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[ <TH_L: escape from > TH_L ]\n"));
-					phydm_adaptive_soml_reset(p_dm);
-					phydm_soml_on_off(p_dm, SOML_ON);
-				}
-			} else {
-				PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[escape from > TH_H || is_soml_method_enable==1]\n"));
-				phydm_adaptive_soml_reset(p_dm);
-				phydm_soml_on_off(p_dm, SOML_ON);
-			}
+		for (i = 0; i < rate_num; i++) {
+			rate_ss_shift = (i << 3);
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "*ht_byte_off  HT MCS[%d :%d ] = {%d, %d, %d, %d, %d, %d, %d, %d}\n",
+				  (rate_ss_shift), (rate_ss_shift + 7),
+				  soml_tab->ht_cnt_off[rate_ss_shift + 0],
+				  soml_tab->ht_cnt_off[rate_ss_shift + 1],
+				  soml_tab->ht_cnt_off[rate_ss_shift + 2],
+				  soml_tab->ht_cnt_off[rate_ss_shift + 3],
+				  soml_tab->ht_cnt_off[rate_ss_shift + 4],
+				  soml_tab->ht_cnt_off[rate_ss_shift + 5],
+				  soml_tab->ht_cnt_off[rate_ss_shift + 6],
+				  soml_tab->ht_cnt_off[rate_ss_shift + 7]);
+		}
+
+		for (i = ODM_RATEMCS8; i <= ODM_RATEMCS15; i++) {
+			ht_total_cnt_on += soml_tab->ht_cnt_on[i - mcs0];
+			ht_total_cnt_off += soml_tab->ht_cnt_off[i - mcs0];
+			total_ht_rate_on += (soml_tab->ht_cnt_on[i - mcs0] *
+					    (phy_rate_table[i] >> 1));
+			total_ht_rate_off += (soml_tab->ht_cnt_off[i - mcs0] *
+					     (phy_rate_table[i] >> 1));
+		}
+		total_ht_rate_on = total_ht_rate_on << 3;
+		total_ht_rate_off = total_ht_rate_off << 3;
+		rate_per_pkt_on = (ht_total_cnt_on != 0) ?
+				  (total_ht_rate_on / ht_total_cnt_on) : 0;
+		rate_per_pkt_off = (ht_total_cnt_off != 0) ?
+				   (total_ht_rate_off / ht_total_cnt_off) : 0;
+	}
+
+	if (dm->support_ic_type == ODM_RTL8822B) {
+		cfo_diff_avg_a = soml_tab->cfo_diff_sum_a / soml_tab->cfo_cnt;
+		cfo_diff_avg_b = soml_tab->cfo_diff_sum_b / soml_tab->cfo_cnt;
+		soml_tab->cfo_diff_avg_a = (soml_tab->cfo_cnt != 0) ?
+					   cfo_diff_avg_a : 0;
+		soml_tab->cfo_diff_avg_b = (soml_tab->cfo_cnt != 0) ?
+					   cfo_diff_avg_b : 0;
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ cfo_diff_avg_a = %d KHz; cfo_diff_avg_b = %d KHz]\n",
+			  soml_tab->cfo_diff_avg_a,
+			  soml_tab->cfo_diff_avg_b);
+		for (i = 0; i < VHT_ORDER_TYPE; i++)
+			num_total_qam += soml_tab->num_vht_qam[i];
+
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ ((2SS)) BPSK_QPSK_count = %d ; 16QAM_count = %d ; 64QAM_count = %d ; 256QAM_count = %d ; num_total_qam = %d]\n",
+			  soml_tab->num_vht_qam[BPSK_QPSK],
+			  soml_tab->num_vht_qam[QAM16],
+			  soml_tab->num_vht_qam[QAM64],
+			  soml_tab->num_vht_qam[QAM256],
+			  num_total_qam);
+		if (((soml_tab->num_vht_qam[QAM256] * 100) >
+		    (num_total_qam * soml_tab->qam256_dist_th)) &&
+		    cfo_diff_avg_a > soml_tab->cfo_qam256_th &&
+		    cfo_diff_avg_b > soml_tab->cfo_qam256_th) {
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "[  QAM256_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n",
+				  soml_tab->qam256_dist_th,
+				  soml_tab->cfo_qam256_th);
+			PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+			phydm_soml_on_off(dm, SOML_OFF);
+			return;
+		} else if (((soml_tab->num_vht_qam[QAM64] * 100) >
+			   (num_total_qam * soml_tab->qam64_dist_th)) &&
+			   (cfo_diff_avg_a > soml_tab->cfo_qam64_th) &&
+			   (cfo_diff_avg_b > soml_tab->cfo_qam64_th)) {
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "[  QAM64_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n",
+				  soml_tab->qam64_dist_th,
+				  soml_tab->cfo_qam64_th);
+			PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+			phydm_soml_on_off(dm, SOML_OFF);
+			return;
+		} else if (((soml_tab->num_vht_qam[QAM16] * 100) >
+			   (num_total_qam * soml_tab->qam16_dist_th)) &&
+			   (cfo_diff_avg_a > soml_tab->cfo_qam16_th) &&
+			   (cfo_diff_avg_b > soml_tab->cfo_qam16_th)) {
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "[  QAM16_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n",
+				  soml_tab->qam16_dist_th,
+				  soml_tab->cfo_qam16_th);
+			PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+			phydm_soml_on_off(dm, SOML_OFF);
+			return;
+		} else if (((soml_tab->num_vht_qam[BPSK_QPSK] * 100) >
+			   (num_total_qam * soml_tab->bpsk_qpsk_dist_th)) &&
+			   (cfo_diff_avg_a > soml_tab->cfo_qpsk_th) &&
+			   (cfo_diff_avg_b > soml_tab->cfo_qpsk_th)) {
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "[  BPSK_QPSK_ratio > %d ; cfo_diff_avg_a > %d KHz ==> SOML_OFF]\n",
+				  soml_tab->bpsk_qpsk_dist_th,
+				  soml_tab->cfo_qpsk_th);
+			PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+			phydm_soml_on_off(dm, SOML_OFF);
+			return;
+		}
+
+		for (i = 0; i < rate_num; i++) {
+			rate_ss_shift = 10 * i;
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "[  vht_cnt_on  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d} ]\n",
+				  (i + 1),
+				  soml_tab->vht_cnt_on[rate_ss_shift + 0],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 1],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 2],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 3],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 4],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 5],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 6],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 7],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 8],
+				  soml_tab->vht_cnt_on[rate_ss_shift + 9]);
+		}
+
+		for (i = 0; i < rate_num; i++) {
+			rate_ss_shift = 10 * i;
+			PHYDM_DBG(dm, DBG_ADPTV_SOML,
+				  "[  vht_cnt_off  VHT-%d ss MCS[0:9] = {%d, %d, %d, %d, %d, %d, %d, %d, %d, %d} ]\n",
+				  (i + 1),
+				  soml_tab->vht_cnt_off[rate_ss_shift + 0],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 1],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 2],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 3],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 4],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 5],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 6],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 7],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 8],
+				  soml_tab->vht_cnt_off[rate_ss_shift + 9]);
+		}
+
+		for (i = ODM_RATEVHTSS2MCS0; i <= ODM_RATEVHTSS2MCS9; i++) {
+			vht_total_cnt_on += soml_tab->vht_cnt_on[i - vht0];
+			vht_total_cnt_off += soml_tab->vht_cnt_off[i - vht0];
+			total_vht_rate_on += (soml_tab->vht_cnt_on[i - vht0] *
+					     (vht_phy_rate_table[i - vht0] >> 1
+					     ));
+			total_vht_rate_off += (soml_tab->vht_cnt_off[i - vht0] *
+					      (vht_phy_rate_table[i - vht0] >> 1
+					      ));
+		}
+		total_vht_rate_on = total_vht_rate_on << 3;
+		total_vht_rate_off = total_vht_rate_off << 3;
+		rate_per_pkt_on = (vht_total_cnt_on != 0) ?
+				  (total_vht_rate_on / vht_total_cnt_on) : 0;
+		rate_per_pkt_off = (vht_total_cnt_off != 0) ?
+				   (total_vht_rate_off / vht_total_cnt_off) : 0;
+	}
+
+	/* @[Decision] */
+	PHYDM_DBG(dm, DBG_ADPTV_SOML,
+		  "[  rate_per_pkt_on = %d ; rate_per_pkt_off = %d ]\n",
+		  rate_per_pkt_on, rate_per_pkt_off);
+	if (rate_per_pkt_on > rate_per_pkt_off) {
+		next_on_off = SOML_ON;
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ rate_per_pkt_on > rate_per_pkt_off ==> SOML_ON ]\n");
+	} else if (rate_per_pkt_on < rate_per_pkt_off) {
+		next_on_off = SOML_OFF;
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ rate_per_pkt_on < rate_per_pkt_off ==> SOML_OFF ]\n");
+	} else {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ stay at soml_last_state ]\n");
+		next_on_off = soml_tab->soml_last_state;
+	}
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Final decisoin ] : ");
+	phydm_soml_on_off(dm, next_on_off);
+	soml_tab->soml_last_state = next_on_off;
+}
+
+void phydm_adsl(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+
+	if (dm->support_ic_type & PHYDM_ADAPTIVE_SOML_IC) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "soml_state_cnt =((%d))\n",
+			  soml_tab->soml_state_cnt);
+		/*Traning state: 0(alt) 1(ori) 2(alt) 3(ori)===============*/
+		if (soml_tab->soml_state_cnt <
+		    (soml_tab->soml_train_num << 1)) {
+			if (soml_tab->soml_state_cnt == 0)
+				phydm_adsl_init_state(dm);
+			else if ((soml_tab->soml_state_cnt % 2) != 0)
+				phydm_adsl_odd_state(dm);
+			else if ((soml_tab->soml_state_cnt % 2) == 0)
+				phydm_adsl_even_state(dm);
 		} else {
-			PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[multi-Client]\n"));
-			phydm_adaptive_soml_reset(p_dm);
-			phydm_soml_on_off(p_dm, SOML_ON);
+			phydm_adsl_decision_state(dm);
 		}
 	}
 }
 
-void
-phydm_adaptive_soml_reset(
-	void		*p_dm_void
-)
+void phydm_adaptive_soml_reset(void *dm_void)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml	*p_dm_soml_table = &p_dm->dm_soml_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
 
-	p_dm_soml_table->soml_state_cnt = 0;
-	p_dm_soml_table->is_soml_method_enable = 0;
-	p_dm_soml_table->soml_counter = 0;
+	soml_tab->soml_state_cnt = 0;
+	soml_tab->is_soml_method_enable = 0;
+	soml_tab->soml_counter = 0;
 }
 
-#endif /* end of CONFIG_ADAPTIVE_SOML*/
+void phydm_set_adsl_val(void *dm_void, u32 *val_buf, u8 val_len)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	if (val_len != 1) {
+		PHYDM_DBG(dm, ODM_COMP_API, "[Error][ADSL]Need val_len=1\n");
+		return;
+	}
 
-void
-phydm_adaptive_soml_timers(
-	void		*p_dm_void,
-	u8		state
-)
+	phydm_soml_on_off(dm, (u8)val_buf[1]);
+}
+
+void phydm_soml_bytes_acq(void *dm_void, u8 rate_id, u32 length)
 {
-#ifdef CONFIG_ADAPTIVE_SOML
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml	*p_dm_soml_table = &p_dm->dm_soml_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+
+	if (rate_id >= ODM_RATEMCS0 && rate_id <= ODM_RATEMCS31)
+		soml_tab->ht_byte[rate_id - ODM_RATEMCS0] += (u16)length;
+	else if (rate_id >= ODM_RATEVHTSS1MCS0 && rate_id <= ODM_RATEVHTSS4MCS9)
+		soml_tab->vht_byte[rate_id - ODM_RATEVHTSS1MCS0] += (u16)length;
+
+}
+
+#if defined(CONFIG_RTL_TRIBAND_SUPPORT) && defined(CONFIG_USB_HCI)
+#define INIT_TIMER_EVENT_ENTRY(_entry, _func, _data) \
+	do { \
+		_rtw_init_listhead(&(_entry)->list); \
+		(_entry)->data = (_data); \
+		(_entry)->function = (_func); \
+	} while (0)
+
+static void pre_phydm_adaptive_soml_callback(unsigned long task_dm)
+{
+	struct dm_struct *dm = (struct dm_struct *)task_dm;
+	struct rtl8192cd_priv *priv = dm->priv;
+	struct priv_shared_info *pshare = priv->pshare;
+
+	if (pshare->bDriverStopped || pshare->bSurpriseRemoved) {
+		printk("[%s] bDriverStopped(%d) OR bSurpriseRemoved(%d)\n",
+		       __FUNCTION__, pshare->bDriverStopped,
+		       pshare->bSurpriseRemoved);
+		return;
+	}
+
+	rtw_enqueue_timer_event(priv, &pshare->adaptive_soml_event,
+				ENQUEUE_TO_TAIL);
+}
+
+void phydm_adaptive_soml_timers_usb(void *dm_void, u8 state)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+	struct rtl8192cd_priv *priv = dm->priv;
 
 	if (state == INIT_SOML_TIMMER) {
-		odm_initialize_timer(p_dm, &p_dm_soml_table->phydm_adaptive_soml_timer,
-			(void *)phydm_adaptive_soml_callback, NULL, "phydm_adaptive_soml_timer");
+		init_timer(&soml_tab->phydm_adaptive_soml_timer);
+		soml_tab->phydm_adaptive_soml_timer.data = (unsigned long)dm;
+		soml_tab->phydm_adaptive_soml_timer.function = pre_phydm_adaptive_soml_callback;
+		INIT_TIMER_EVENT_ENTRY(&priv->pshare->adaptive_soml_event,
+				       phydm_adaptive_soml_callback,
+				       (unsigned long)dm);
 	} else if (state == CANCEL_SOML_TIMMER) {
-		odm_cancel_timer(p_dm, &p_dm_soml_table->phydm_adaptive_soml_timer);
+		odm_cancel_timer(dm, &soml_tab->phydm_adaptive_soml_timer);
 	} else if (state == RELEASE_SOML_TIMMER) {
-		odm_release_timer(p_dm, &p_dm_soml_table->phydm_adaptive_soml_timer);
+		odm_release_timer(dm, &soml_tab->phydm_adaptive_soml_timer);
 	}
-#endif
 }
+#endif /* defined(CONFIG_RTL_TRIBAND_SUPPORT) && defined(CONFIG_USB_HCI) */
 
-void
-phydm_adaptive_soml_init(
-	void		*p_dm_void
-)
+void phydm_adaptive_soml_timers(void *dm_void, u8 state)
 {
-#ifdef CONFIG_ADAPTIVE_SOML
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml	*p_dm_soml_table = &p_dm->dm_soml_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
 
-	if (!(p_dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
-		PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[Return]   Not Support Adaptive SOML\n"));
-		return;
+#if defined(CONFIG_RTL_TRIBAND_SUPPORT) && defined(CONFIG_USB_HCI)
+	struct rtl8192cd_priv *priv = dm->priv;
+
+	if (priv->hci_type == RTL_HCI_USB) {
+		phydm_adaptive_soml_timers_usb(dm_void, state);
+	} else
+#endif /* defined(CONFIG_RTL_TRIBAND_SUPPORT) && defined(CONFIG_USB_HCI) */
+	{
+	if (state == INIT_SOML_TIMMER) {
+		odm_initialize_timer(dm, &soml_tab->phydm_adaptive_soml_timer,
+				     (void *)phydm_adaptive_soml_callback, NULL,
+				     "phydm_adaptive_soml_timer");
+	} else if (state == CANCEL_SOML_TIMMER) {
+		odm_cancel_timer(dm, &soml_tab->phydm_adaptive_soml_timer);
+	} else if (state == RELEASE_SOML_TIMMER) {
+		odm_release_timer(dm, &soml_tab->phydm_adaptive_soml_timer);
+	}
 	}
-	PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("phydm_adaptive_soml_init\n"));
+}
 
-	p_dm_soml_table->soml_state_cnt = 0;
-	p_dm_soml_table->soml_delay_time = 40;
-	p_dm_soml_table->soml_intvl = 150;
-	p_dm_soml_table->soml_train_num = 4;
-	p_dm_soml_table->is_soml_method_enable = 0;
-	p_dm_soml_table->soml_counter = 0;
-	p_dm_soml_table->soml_period = 4;
-	p_dm_soml_table->soml_select = 0;
+void phydm_adaptive_soml_init(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+#if 0
+	if (!(dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[Return]   Not Support Adaptive SOML\n");
+		return;
+	}
 #endif
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "%s\n", __func__);
+
+	soml_tab->soml_state_cnt = 0;
+	soml_tab->soml_delay_time = 40;
+	soml_tab->soml_intvl = 150;
+	soml_tab->soml_train_num = 4;
+	soml_tab->is_soml_method_enable = 0;
+	soml_tab->soml_counter = 0;
+#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
+	soml_tab->soml_period = 1;
+#else
+	soml_tab->soml_period = 4;
+#endif
+	soml_tab->soml_select = 0;
+	soml_tab->cfo_cnt = 0;
+	soml_tab->cfo_diff_sum_a = 0;
+	soml_tab->cfo_diff_sum_b = 0;
+
+	soml_tab->cfo_qpsk_th = 94;
+	soml_tab->cfo_qam16_th = 38;
+	soml_tab->cfo_qam64_th = 17;
+	soml_tab->cfo_qam256_th = 7;
+
+	soml_tab->bpsk_qpsk_dist_th = 20;
+	soml_tab->qam16_dist_th = 20;
+	soml_tab->qam64_dist_th = 20;
+	soml_tab->qam256_dist_th = 20;
+
+	if (dm->support_ic_type & (ODM_RTL8197F | ODM_RTL8192F))
+		odm_set_bb_reg(dm, 0x988, BIT(25), 1);
 }
 
-void
-phydm_adaptive_soml(
-	void		*p_dm_void
-)
+void phydm_adaptive_soml(void *dm_void)
 {
-#ifdef CONFIG_ADAPTIVE_SOML
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct adaptive_soml	*p_dm_soml_table = &p_dm->dm_soml_table;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
 
-	if (!(p_dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
-		PHYDM_DBG(p_dm, DBG_ADPTV_SOML,
-			("[Return!!!]   Not Support Adaptive SOML Function\n"));
+	if (!(dm->support_ability & ODM_BB_ADAPTIVE_SOML)) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[Return!!!] Not Support Adaptive SOML Function\n");
 		return;
 	}
 
-	if (p_dm_soml_table->soml_counter <  p_dm_soml_table->soml_period) {
-		p_dm_soml_table->soml_counter++;
+	if (dm->pause_ability & ODM_BB_ADAPTIVE_SOML) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "Return: Pause ADSL in LV=%d\n",
+			  dm->pause_lv_table.lv_adsl);
 		return;
 	}
-	p_dm_soml_table->soml_counter = 0;
 
-
-	if (p_dm_soml_table->soml_select == 0) {
-		PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[Adaptive SOML Training !!!]\n"));
-	} else if (p_dm_soml_table->soml_select == 1) {
-		PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[Turn on SOML !!!] Exit from Adaptive SOML Training\n"));
-		phydm_soml_on_off(p_dm, SOML_ON);
+	if (soml_tab->soml_counter < soml_tab->soml_period) {
+		soml_tab->soml_counter++;
+		return;
+	}
+	soml_tab->soml_counter = 0;
+	soml_tab->soml_state_cnt = 0;
+	soml_tab->cfo_cnt = 0;
+	soml_tab->cfo_diff_sum_a = 0;
+	soml_tab->cfo_diff_sum_b = 0;
+
+	phydm_soml_reset_qam(dm);
+
+	if (soml_tab->soml_select == 0) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML,
+			  "[ Adaptive SOML Training !!!]\n");
+	} else if (soml_tab->soml_select == 1) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Stop Adaptive SOML !!!]\n");
+		phydm_soml_on_off(dm, SOML_ON);
 		return;
-	} else if (p_dm_soml_table->soml_select == 2) {
-		PHYDM_DBG(p_dm, DBG_ADPTV_SOML, ("[Turn off SOML !!!] Exit from Adaptive SOML Training\n"));
-		phydm_soml_on_off(p_dm, SOML_OFF);
+	} else if (soml_tab->soml_select == 2) {
+		PHYDM_DBG(dm, DBG_ADPTV_SOML, "[ Stop Adaptive SOML !!!]\n");
+		phydm_soml_on_off(dm, SOML_OFF);
 		return;
 	}
 
-	phydm_adsl(p_dm);
+	if (dm->support_ic_type & PHYDM_ADAPTIVE_SOML_IC)
+		phydm_adsl(dm);
+}
 
-#endif
+void phydm_enable_adaptive_soml(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[%s]\n", __func__);
+	dm->support_ability |= ODM_BB_ADAPTIVE_SOML;
+	phydm_soml_on_off(dm, SOML_ON);
+}
+
+void phydm_stop_adaptive_soml(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+
+	PHYDM_DBG(dm, DBG_ADPTV_SOML, "[%s]\n", __func__);
+	dm->support_ability &= ~ODM_BB_ADAPTIVE_SOML;
+	phydm_soml_on_off(dm, SOML_ON);
 }
 
-void
-phydm_init_soft_ml_setting(
-	void		*p_dm_void
-)
+void phydm_adaptive_soml_para_set(void *dm_void, u8 train_num, u8 intvl,
+				  u8 period, u8 delay_time)
 {
-	struct PHY_DM_STRUCT		*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct adaptive_soml *soml_tab = &dm->dm_soml_table;
+
+	soml_tab->soml_train_num = train_num;
+	soml_tab->soml_intvl = intvl;
+	soml_tab->soml_period = period;
+	soml_tab->soml_delay_time = delay_time;
+}
+#endif /* @end of CONFIG_ADAPTIVE_SOML*/
+
+void phydm_init_soft_ml_setting(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 soml_mask = BIT(31) | BIT(30) | BIT(29) | BIT(28);
+
 #if (RTL8822B_SUPPORT == 1)
-	if (*(p_dm->p_mp_mode) == false) {
-		if (p_dm->support_ic_type & ODM_RTL8822B)
-			/*odm_set_bb_reg(p_dm, 0x19a8, MASKDWORD, 0xd10a0000);*/
-			phydm_somlrxhp_setting(p_dm, true);
-			p_dm->bsomlenabled = true;
+	if (!*dm->mp_mode) {
+		if (dm->support_ic_type & ODM_RTL8822B) {
+#if 0
+			/*odm_set_bb_reg(dm, R_0x19a8, MASKDWORD, 0xd10a0000);*/
+#endif
+			phydm_somlrxhp_setting(dm, true);
+			dm->bsomlenabled = true;
+		}
 	}
 #endif
 #if (RTL8821C_SUPPORT == 1)
-	if (*(p_dm->p_mp_mode) == false) {
-		if (p_dm->support_ic_type & ODM_RTL8821C)
-			odm_set_bb_reg(p_dm, 0x19a8, BIT(31)|BIT(30)|BIT(29)|BIT(28), 0xd);
+	if (!*dm->mp_mode) {
+		if (dm->support_ic_type & ODM_RTL8821C)
+			odm_set_bb_reg(dm, R_0x19a8, soml_mask, 0xd);
+	}
+#endif
+#if (RTL8195B_SUPPORT == 1)
+	if (!*dm->mp_mode) {
+		if (dm->support_ic_type & ODM_RTL8195B)
+			odm_set_bb_reg(dm, R_0x19a8, soml_mask, 0xd);
 	}
 #endif
 }
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.h
index da86bd493a30..f411ea3e9a08 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_soml.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,34 +9,64 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
-#ifndef	__PHYDMSOML_H__
-#define    __PHYDMSOML_H__
+#ifndef __PHYDMSOML_H__
+#define __PHYDMSOML_H__
 
-#define ADAPTIVE_SOML_VERSION	"1.0"
+/*@#define ADAPTIVE_SOML_VERSION	"1.0" Byte counter version*/
+#define ADAPTIVE_SOML_VERSION "2.0" /*@add avg. phy rate decision 20180126*/
 
-#define ODM_ADAPTIVE_SOML_SUPPORT_IC	(ODM_RTL8822B | ODM_RTL8197F)
+#define PHYDM_ADAPTIVE_SOML_IC	(ODM_RTL8822B | ODM_RTL8197F | ODM_RTL8192F)
+/*@jj add 20170822*/
 
 #define INIT_SOML_TIMMER			0
-#define CANCEL_SOML_TIMMER		1
+#define CANCEL_SOML_TIMMER			1
 #define RELEASE_SOML_TIMMER		2
 
 #define SOML_RSSI_TH_HIGH	25
 #define SOML_RSSI_TH_LOW	20
 
-#define HT_RATE_IDX			32
-#define VHT_RATE_IDX		40
+#define HT_RATE_IDX			16
+#define VHT_RATE_IDX		20
+
+#define HT_ORDER_TYPE		3
+#define VHT_ORDER_TYPE		4
+
+#if 0
+#define CFO_QPSK_TH			20
+#define CFO_QAM16_TH		20
+#define CFO_QAM64_TH		20
+#define CFO_QAM256_TH		20
+
+#define BPSK_QPSK_DIST		20
+#define QAM16_DIST			30
+#define QAM64_DIST			30
+#define QAM256_DIST			20
+#endif
+#define HT_TYPE		1
+#define VHT_TYPE		2
 
 #define SOML_ON		1
-#define SOML_OFF	0
+#define SOML_OFF		0
 
 #ifdef CONFIG_ADAPTIVE_SOML
 
 struct adaptive_soml {
-	boolean		is_soml_method_enable;
+	u8			rvrt_val;
+	boolean			is_soml_method_enable;
 	u8			soml_on_off;
 	u8			soml_state_cnt;
 	u8			soml_delay_time;
@@ -45,104 +76,111 @@ struct adaptive_soml {
 	u8			soml_period;
 	u8			soml_select;
 	u8			soml_last_state;
-	u32			num_ht_bytes[HT_RATE_IDX];
-	u32			pre_num_ht_bytes[HT_RATE_IDX];
-	u32			num_ht_bytes_on[HT_RATE_IDX];
-	u32			num_ht_bytes_off[HT_RATE_IDX];
-	#if	ODM_IC_11AC_SERIES_SUPPORT
-	u32			num_vht_bytes[VHT_RATE_IDX];
-	u32			pre_num_vht_bytes[VHT_RATE_IDX];
-	u32			num_vht_bytes_on[VHT_RATE_IDX];
-	u32			num_vht_bytes_off[VHT_RATE_IDX];
-	#endif
+	u8			cfo_qpsk_th;
+	u8			cfo_qam16_th;
+	u8			cfo_qam64_th;
+	u8			cfo_qam256_th;
+	u8			bpsk_qpsk_dist_th;
+	u8			qam16_dist_th;
+	u8			qam64_dist_th;
+	u8			qam256_dist_th;
+	u8			cfo_cnt;
+	s32			cfo_diff_a;
+	s32			cfo_diff_b;
+	s32			cfo_diff_sum_a;
+	s32			cfo_diff_sum_b;
+	s32			cfo_diff_avg_a;
+	s32			cfo_diff_avg_b;
+	u16			ht_cnt[HT_RATE_IDX];
+	u16			pre_ht_cnt[HT_RATE_IDX];
+	u16			ht_cnt_on[HT_RATE_IDX];
+	u16			ht_cnt_off[HT_RATE_IDX];
+
+	u16			vht_cnt[VHT_RATE_IDX];
+	u16			pre_vht_cnt[VHT_RATE_IDX];
+	u16			vht_cnt_on[VHT_RATE_IDX];
+	u16			vht_cnt_off[VHT_RATE_IDX];
+
+	u16			num_ht_qam[HT_ORDER_TYPE];
+	u16			ht_byte[HT_RATE_IDX];
+	u16			pre_ht_byte[HT_RATE_IDX];
+	u16			ht_byte_on[HT_RATE_IDX];
+	u16			ht_byte_off[HT_RATE_IDX];
+	u16			num_vht_qam[VHT_ORDER_TYPE];
+	u16			vht_byte[VHT_RATE_IDX];
+	u16			pre_vht_byte[VHT_RATE_IDX];
+	u16			vht_byte_on[VHT_RATE_IDX];
+	u16			vht_byte_off[VHT_RATE_IDX];
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 #if USE_WORKITEM
 	RT_WORK_ITEM	phydm_adaptive_soml_workitem;
 #endif
 #endif
-	struct timer_list		phydm_adaptive_soml_timer;
+	struct phydm_timer_list		phydm_adaptive_soml_timer;
 
 };
 
-void
-phydm_dynamicsoftmletting(
-	struct PHY_DM_STRUCT		*p_dm
-);
+enum qam_order {
+	BPSK_QPSK	= 0,
+	QAM16		= 1,
+	QAM64		= 2,
+	QAM256		= 3
+};
 
-void
-phydm_soml_on_off(
-	void		*p_dm_void,
-	u8		swch
-);
+void phydm_dynamicsoftmletting(void *dm_void);
+
+void phydm_soml_on_off(void *dm_void, u8 swch);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-phydm_adaptive_soml_callback(
-	struct timer_list		*p_timer
-);
+void phydm_adaptive_soml_callback(struct phydm_timer_list *timer);
 
-void
-phydm_adaptive_soml_workitem_callback(
-	void		*p_context
-);
+void phydm_adaptive_soml_workitem_callback(void *context);
 
-#else
+#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
+void phydm_adaptive_soml_callback(void *dm_void);
 
-void
-phydm_adaptive_soml_callback(
-	void		*p_dm_void
-);
+void phydm_adaptive_soml_workitem_callback(void *context);
 
+#else
+void phydm_adaptive_soml_callback(void *dm_void);
 #endif
 
-void
-phydm_soml_debug(
-	void		*p_dm_void,
-	u32		*const dm_value,
-	u32		*_used,
-	char			*output,
-	u32		*_out_len
-);
+void phydm_rx_rate_for_soml(void *dm_void, void *pkt_info_void);
 
-void
-phydm_soml_statistics(
-	void		*p_dm_void,
-	u8		on_off_state
+void phydm_rx_qam_for_soml(void *dm_void, void *pkt_info_void);
 
-);
+void phydm_soml_reset_rx_rate(void *dm_void);
 
-void
-phydm_adsl(
-	void		*p_dm_void
-);
+void phydm_soml_reset_qam(void *dm_void);
 
-void
-phydm_adaptive_soml_reset(
-	void		*p_dm_void
-);
+void phydm_soml_cfo_process(void *dm_void, s32 *diff_a, s32 *diff_b);
 
-#endif
+void phydm_soml_debug(void *dm_void, char input[][16], u32 *_used,
+		      char *output, u32 *_out_len);
+
+void phydm_soml_statistics(void *dm_void, u8 on_off_state);
+
+void phydm_adsl(void *dm_void);
+
+void phydm_adaptive_soml_reset(void *dm_void);
 
-void
-phydm_adaptive_soml_timers(
-	void		*p_dm_void,
-	u8		state
-);
+void phydm_set_adsl_val(void *dm_void, u32 *val_buf, u8 val_len);
 
-void
-phydm_adaptive_soml_init(
-	void		*p_dm_void
-);
+void phydm_soml_bytes_acq(void *dm_void, u8 rate_id, u32 length);
 
-void
-phydm_adaptive_soml(
-	void		*p_dm_void
-);
+void phydm_adaptive_soml_timers(void *dm_void, u8 state);
 
-void
-phydm_init_soft_ml_setting(
-	void		*p_dm_void
-);
+void phydm_adaptive_soml_init(void *dm_void);
 
-#endif /*#ifndef	__PHYDMSOML_H__*/
+void phydm_adaptive_soml(void *dm_void);
+
+void phydm_enable_adaptive_soml(void *dm_void);
+
+void phydm_stop_adaptive_soml(void *dm_void);
+
+void phydm_adaptive_soml_para_set(void *dm_void, u8 train_num, u8 intvl,
+				  u8 period, u8 delay_time);
+#endif
+void phydm_init_soft_ml_setting(void *dm_void);
+#endif /*@#ifndef	__PHYDMSOML_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_types.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_types.h
index 2565cf37921e..533c0956a126 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_types.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/phydm_types.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,51 +9,73 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #ifndef __ODM_TYPES_H__
 #define __ODM_TYPES_H__
 
-
 /*Define Different SW team support*/
 #define	ODM_AP			0x01	/*BIT(0)*/
 #define	ODM_CE			0x04	/*BIT(2)*/
 #define	ODM_WIN		0x08	/*BIT(3)*/
-#define	ODM_ADSL		0x10	/*BIT(4)*/		/*already combine with ODM_AP, and is nouse now*/
+#define	ODM_ADSL		0x10
+/*BIT(4)*/		/*already combine with ODM_AP, and is nouse now*/
 #define	ODM_IOT		0x20	/*BIT(5)*/
 
 /*For FW API*/
 #define	__iram_odm_func__
+#define	__odm_func__
+#define	__odm_func_aon__
 
 /*Deifne HW endian support*/
 #define	ODM_ENDIAN_BIG	0
 #define	ODM_ENDIAN_LITTLE	1
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define GET_PDM_ODM(__padapter)	((struct PHY_DM_STRUCT*)(&((GET_HAL_DATA(__padapter))->DM_OutSrc)))
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&(GET_HAL_DATA(__padapter))->DM_OutSrc))
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#define GET_PDM_ODM(__padapter)	((struct PHY_DM_STRUCT*)(&((GET_HAL_DATA(__padapter))->odmpriv)))
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct *)(&(GET_HAL_DATA(__padapter))->odmpriv))
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
-	#define GET_PDM_ODM(__padapter)	((struct PHY_DM_STRUCT*)(&(__padapter->pshare->_dmODM)))
+	#define GET_PDM_ODM(__padapter)	((struct dm_struct*)(&__padapter->pshare->_dmODM))
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
-	#define	RT_PCI_INTERFACE				1
-	#define	RT_USB_INTERFACE				2
-	#define	RT_SDIO_INTERFACE				3
+	#if defined(CONFIG_RTL_TRIBAND_SUPPORT) && defined(CONFIG_USB_HCI)
+	/* enable PCI & USB HCI at the same time */
+  	#define RT_PCI_USB_INTERFACE			1
+  	#define	RT_PCI_INTERFACE			RT_PCI_USB_INTERFACE
+	#define RT_USB_INTERFACE			RT_PCI_USB_INTERFACE
+	#define	RT_SDIO_INTERFACE			3
+  	#else
+	#define	RT_PCI_INTERFACE			1
+	#define	RT_USB_INTERFACE			2
+	#define	RT_SDIO_INTERFACE			3
+	#endif
 #endif
 
 enum hal_status {
 	HAL_STATUS_SUCCESS,
 	HAL_STATUS_FAILURE,
-	/*RT_STATUS_PENDING,
+#if 0
+	RT_STATUS_PENDING,
 	RT_STATUS_RESOURCE,
 	RT_STATUS_INVALID_CONTEXT,
 	RT_STATUS_INVALID_PARAMETER,
 	RT_STATUS_NOT_SUPPORT,
-	RT_STATUS_OS_API_FAILED,*/
+	RT_STATUS_OS_API_FAILED,
+#endif
 };
 
 #if (DM_ODM_SUPPORT_TYPE != ODM_WIN)
@@ -60,8 +83,8 @@ enum hal_status {
 #define		VISTA_USB_RX_REVISE			0
 
 /*
- * Declare for ODM spin lock defintion temporarily fro compile pass.
- *   */
+ * Declare for ODM spin lock definition temporarily fro compile pass.
+ */
 enum rt_spinlock_type {
 	RT_TX_SPINLOCK = 1,
 	RT_RX_SPINLOCK = 2,
@@ -73,16 +96,19 @@ enum rt_spinlock_type {
 	RT_CHNLOP_SPINLOCK = 9,
 	RT_RF_OPERATE_SPINLOCK = 10,
 	RT_INITIAL_SPINLOCK = 11,
-	RT_RF_STATE_SPINLOCK = 12, /* For RF state. Added by Bruce, 2007-10-30. */
+	RT_RF_STATE_SPINLOCK = 12,
+	/* For RF state. Added by Bruce, 2007-10-30. */
 #if VISTA_USB_RX_REVISE
 	RT_USBRX_CONTEXT_SPINLOCK = 13,
-	RT_USBRX_POSTPROC_SPINLOCK = 14, /* protect data of adapter->IndicateW/ IndicateR */
+	RT_USBRX_POSTPROC_SPINLOCK = 14,
+	/* protect data of adapter->IndicateW/ IndicateR */
 #endif
 	/* Shall we define Ndis 6.2 SpinLock Here ? */
 	RT_PORT_SPINLOCK = 16,
 	RT_VNIC_SPINLOCK = 17,
 	RT_HVL_SPINLOCK = 18,
-	RT_H2C_SPINLOCK = 20, /* For H2C cmd. Added by tynli. 2009.11.09. */
+	RT_H2C_SPINLOCK = 20,
+	/* For H2C cmd. Added by tynli. 2009.11.09. */
 
 	rt_bt_data_spinlock = 25,
 
@@ -131,15 +157,19 @@ enum rt_spinlock_type {
 	#define	u64		u8Byte
 	#define	s64		s8Byte
 
-	#define	timer_list	_RT_TIMER
-	
+	#define	phydm_timer_list	_RT_TIMER
+
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
 	#include "../typedef.h"
 
 	#ifdef CONFIG_PCI_HCI
+	#if defined(CONFIG_RTL_TRIBAND_SUPPORT) && defined(CONFIG_USB_HCI)
+		#define DEV_BUS_TYPE		RT_PCI_USB_INTERFACE
+	#else
 		#define DEV_BUS_TYPE		RT_PCI_INTERFACE
 	#endif
+	#endif
 
 	#if (defined(TESTCHIP_SUPPORT))
 		#define	PHYDM_TESTCHIP_SUPPORT 1
@@ -150,6 +180,8 @@ enum rt_spinlock_type {
 	#define	sta_info stat_info
 	#define	boolean	bool
 
+	#define	phydm_timer_list	timer_list
+
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
 
 	#include <asm/byteorder.h>
@@ -171,21 +203,6 @@ enum rt_spinlock_type {
 	#define	RTL8881A_SUPPORT	0
 	#define	PHYDM_TESTCHIP_SUPPORT 0
 
-	/* support list */
-	#define RTL8188E_SUPPORT				0
-	#define RTL8812A_SUPPORT				0
-	#define RTL8821A_SUPPORT				0
-	#define RTL8723B_SUPPORT				0
-	#define RTL8723D_SUPPORT				0
-	#define RTL8192E_SUPPORT				0
-	#define RTL8814A_SUPPORT				0
-	#define RTL8195A_SUPPORT				0
-	#define RTL8197F_SUPPORT				0
-	#define RTL8703B_SUPPORT				0
-	#define RTL8188F_SUPPORT				0
-	#define RTL8822B_SUPPORT				1
-	#define RTL8821B_SUPPORT				0
-	#define RTL8821C_SUPPORT				0
 
 	#define RATE_ADAPTIVE_SUPPORT			0
 	#define POWER_TRAINING_ACTIVE			0
@@ -193,6 +210,8 @@ enum rt_spinlock_type {
 	#define sta_info	rtl_sta_info
 	#define	boolean		bool
 
+	#define	phydm_timer_list	timer_list
+
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 	#include <drv_types.h>
 
@@ -209,15 +228,15 @@ enum rt_spinlock_type {
 
 	#if defined(CONFIG_LITTLE_ENDIAN)
 		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_LITTLE
-	#elif defined (CONFIG_BIG_ENDIAN)
+	#elif defined(CONFIG_BIG_ENDIAN)
 		#define	ODM_ENDIAN_TYPE			ODM_ENDIAN_BIG
 	#endif
 
 	#define	boolean	bool
 
-	#define SET_TX_DESC_ANTSEL_A_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+8, 24, 1, __value)
-	#define SET_TX_DESC_ANTSEL_B_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+8, 25, 1, __value)
-	#define SET_TX_DESC_ANTSEL_C_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc+28, 29, 1, __value)
+	#define SET_TX_DESC_ANTSEL_A_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc + 8, 24, 1, __value)
+	#define SET_TX_DESC_ANTSEL_B_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc + 8, 25, 1, __value)
+	#define SET_TX_DESC_ANTSEL_C_88E(__ptx_desc, __value) SET_BITS_TO_LE_4BYTE(__ptx_desc + 28, 29, 1, __value)
 
 	/* define useless flag to avoid compile warning */
 	#define	USE_WORKITEM 0
@@ -230,9 +249,57 @@ enum rt_spinlock_type {
 	#else
 		#define	PHYDM_TESTCHIP_SUPPORT 0
 	#endif
+
+	#define	phydm_timer_list	rtw_timer_list
+
+#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
+	#define	boolean	bool
+	#define true	_TRUE
+	#define false	_FALSE
+
+	// for power limit table
+	enum odm_pw_lmt_regulation_type {
+		PW_LMT_REGU_NULL = 0,
+		PW_LMT_REGU_FCC = 1,
+		PW_LMT_REGU_ETSI = 2,
+		PW_LMT_REGU_MKK = 3,
+		PW_LMT_REGU_WW13 = 4
+	};
+
+	enum odm_pw_lmt_band_type {
+		PW_LMT_BAND_NULL = 0,
+		PW_LMT_BAND_2_4G = 1,
+		PW_LMT_BAND_5G = 2
+	};
+
+	enum odm_pw_lmt_bandwidth_type {
+		PW_LMT_BW_NULL = 0,
+		PW_LMT_BW_20M = 1,
+		PW_LMT_BW_40M = 2,
+		PW_LMT_BW_80M = 3
+	};
+
+	enum odm_pw_lmt_ratesection_type {
+		PW_LMT_RS_NULL = 0,
+		PW_LMT_RS_CCK = 1,
+		PW_LMT_RS_OFDM = 2,
+		PW_LMT_RS_HT = 3,
+		PW_LMT_RS_VHT = 4
+	};
+
+	enum odm_pw_lmt_rfpath_type {
+		PW_LMT_PH_NULL = 0,
+		PW_LMT_PH_1T = 1,
+		PW_LMT_PH_2T = 2,
+		PW_LMT_PH_3T = 3,
+		PW_LMT_PH_4T = 4
+	};
+
+	#define	phydm_timer_list	timer_list
+
 #endif
 
-#define READ_NEXT_PAIR(v1, v2, i) do { if (i+2 >= array_len) break; i += 2; v1 = array[i]; v2 = array[i+1]; } while (0)
+#define READ_NEXT_PAIR(v1, v2, i) do { if (i + 2 >= array_len) break; i += 2; v1 = array[i]; v2 = array[i + 1]; } while (0)
 #define COND_ELSE  2
 #define COND_ENDIF 3
 
@@ -243,18 +310,22 @@ enum rt_spinlock_type {
 #define	MASKHWORD		0xffff0000
 #define	MASKLWORD		0x0000ffff
 #define	MASKDWORD		0xffffffff
+
 #define	MASK7BITS		0x7f
 #define	MASK12BITS		0xfff
 #define	MASKH4BITS		0xf0000000
 #define	MASK20BITS		0xfffff
+#define	MASK24BITS		0xffffff
 #define	MASKOFDM_D		0xffc00000
 #define	MASKCCK			0x3f3f3f3f
-#define RFREGOFFSETMASK	0xfffff
+
+#define RFREGOFFSETMASK		0xfffff
+#define RFREG_MASK		0xfffff
+
 #define MASKH3BYTES		0xffffff00
 #define MASKL3BYTES		0x00ffffff
-#define MASKBYTE2HIGHNIBBLE		0x00f00000
-#define MASKBYTE3LOWNIBBLE		0x0f000000
-#define	MASKL3BYTES			0x00ffffff
-#define RFREGOFFSETMASK	0xfffff
+#define MASKBYTE2HIGHNIBBLE	0x00f00000
+#define MASKBYTE3LOWNIBBLE	0x0f000000
+#define	MASKL3BYTES		0x00ffffff
 
 #endif /* __ODM_TYPES_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/hal8723dreg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/hal8723dreg.h
index 11e8a6470f1b..487e5f5c4e20 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/hal8723dreg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/hal8723dreg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -32,306 +33,306 @@
 #ifndef __INC_HAL8723DREG_H
 #define __INC_HAL8723DREG_H
 
-
-
-/* ************************************************************
+/*************************************************************
  *
- * ************************************************************ */
+ ************************************************************/
 
 /* -----------------------------------------------------
  *
  *	0x0000h ~ 0x00FFh	System Configuration
  *
- * ----------------------------------------------------- */
-#define REG_SYS_ISO_CTRL_8723D			0x0000	/* 2 Byte */
-#define REG_SYS_FUNC_EN_8723D			0x0002	/* 2 Byte */
-#define REG_SYS_PW_CTRL_8723D			0x0004	/* 4 Byte */
-#define REG_SYS_CLKR_8723D				0x0008	/* 2 Byte */
-#define REG_SYS_EEPROM_CTRL_8723D		0x000A	/* 2 Byte */
-#define REG_EE_VPD_8723D				0x000C	/* 2 Byte */
-#define REG_SYS_SWR_CTRL1_8723D			0x0010	/* 1 Byte */
-#define REG_SYS_SWR_CTRL2_8723D			0x0014	/* 1 Byte */
-#define REG_SYS_SWR_CTRL3_8723D			0x0018	/* 4 Byte */
-#define REG_RSV_CTRL_8723D				0x001C	/* 3 Byte */
-#define REG_RF_CTRL_8723D				0x001F	/* 1 Byte */
-#define REG_AFE_CTRL1_8723D				0x0024	/* 4 Byte */
-#define REG_AFE_CTRL2_8723D				0x0028	/* 4 Byte */
-#define REG_AFE_CTRL3_8723D				0x002c	/* 4 Byte */
-#define REG_EFUSE_CTRL_8723D			0x0030
-#define REG_LDO_EFUSE_CTRL_8723D		0x0034
-#define REG_PWR_DATA_8723D				0x0038
-#define REG_CAL_TIMER_8723D				0x003C
-#define REG_ACLK_MON_8723D				0x003E
-#define REG_GPIO_MUXCFG_8723D			0x0040
-#define REG_GPIO_IO_SEL_8723D			0x0042
-#define REG_MAC_PINMUX_CFG_8723D		0x0043 /* ?????? */
-#define REG_GPIO_PIN_CTRL_8723D			0x0044
-#define REG_GPIO_INTM_8723D				0x0048
-#define BIT_REG_LED_CFG_8723D			0x004C
-#define REG_LEDCFG2_8723D				0x004E /* ?????? */
-#define REG_FSIMR_8723D					0x0050
-#define REG_FSISR_8723D					0x0054
-#define REG_HSIMR_8723D					0x0058
-#define REG_HSISR_8723D					0x005c
-#define REG_GPIO_EXT_CTRL_8723D			0x0060
-#define REG_MULTI_FUNC_CTRL_8723D		0x0068
-#define REG_GPIO_STATUS_8723D			0x006C
-#define REG_SDIO_CTRL_8723D				0x0070
-#define REG_HCI_OPT_CTRL_8723D			0x0074
-#define REG_AFE_CTRL4_8723D				0x0078
-#define REG_LDO_SWR_CTRL_8723D			0x007C
-#define REG_8051FW_CTRL_8723D			0x0080
-#define REG_FW_DBG_STATUS_8723D			0x0088
-#define REG_FW_DBG_CTRL_8723D			0x008F
-#define REG_WLLPS_CTRL_8723D			0x0090
-#define REG_HIMR0_8723D					0x00B0
-#define REG_HISR0_8723D					0x00B4
-#define REG_HIMR1_8723D					0x00B8
-#define REG_HISR1_8723D					0x00BC
-#define REG_PMC_DBG_CTRL2_8723D         0x00CC
-#define	REG_EFUSE_BURN_GNT_8723D		0x00CF
-#define REG_XTAL_AAC_8723D				0x00EC
-#define REG_SYS_CFG1_8723D				0x00F0
-#define REG_SYS_CFG2_8723D				0x00FC
-#define REG_ROM_VERSION					0x00FD
+ * -----------------------------------------------------
+ */
+#define REG_SYS_ISO_CTRL_8723D 0x0000 /* 2 Byte */
+#define REG_SYS_FUNC_EN_8723D 0x0002 /* 2 Byte */
+#define REG_SYS_PW_CTRL_8723D 0x0004 /* 4 Byte */
+#define REG_SYS_CLKR_8723D 0x0008 /* 2 Byte */
+#define REG_SYS_EEPROM_CTRL_8723D 0x000A /* 2 Byte */
+#define REG_EE_VPD_8723D 0x000C /* 2 Byte */
+#define REG_SYS_SWR_CTRL1_8723D 0x0010 /* 1 Byte */
+#define REG_SYS_SWR_CTRL2_8723D 0x0014 /* 1 Byte */
+#define REG_SYS_SWR_CTRL3_8723D 0x0018 /* 4 Byte */
+#define REG_RSV_CTRL_8723D 0x001C /* 3 Byte */
+#define REG_RF_CTRL_8723D 0x001F /* 1 Byte */
+#define REG_AFE_CTRL1_8723D 0x0024 /* 4 Byte */
+#define REG_AFE_CTRL2_8723D 0x0028 /* 4 Byte */
+#define REG_AFE_CTRL3_8723D 0x002c /* 4 Byte */
+#define REG_EFUSE_CTRL_8723D 0x0030
+#define REG_LDO_EFUSE_CTRL_8723D 0x0034
+#define REG_PWR_DATA_8723D 0x0038
+#define REG_CAL_TIMER_8723D 0x003C
+#define REG_ACLK_MON_8723D 0x003E
+#define REG_GPIO_MUXCFG_8723D 0x0040
+#define REG_GPIO_IO_SEL_8723D 0x0042
+#define REG_MAC_PINMUX_CFG_8723D 0x0043 /* ?????? */
+#define REG_GPIO_PIN_CTRL_8723D 0x0044
+#define REG_GPIO_INTM_8723D 0x0048
+#define BIT_REG_LED_CFG_8723D 0x004C
+#define REG_LEDCFG2_8723D 0x004E /* ?????? */
+#define REG_FSIMR_8723D 0x0050
+#define REG_FSISR_8723D 0x0054
+#define REG_HSIMR_8723D 0x0058
+#define REG_HSISR_8723D 0x005c
+#define REG_GPIO_EXT_CTRL_8723D 0x0060
+#define REG_MULTI_FUNC_CTRL_8723D 0x0068
+#define REG_GPIO_STATUS_8723D 0x006C
+#define REG_SDIO_CTRL_8723D 0x0070
+#define REG_HCI_OPT_CTRL_8723D 0x0074
+#define REG_AFE_CTRL4_8723D 0x0078
+#define REG_LDO_SWR_CTRL_8723D 0x007C
+#define REG_8051FW_CTRL_8723D 0x0080
+#define REG_FW_DBG_STATUS_8723D 0x0088
+#define REG_FW_DBG_CTRL_8723D 0x008F
+#define REG_WLLPS_CTRL_8723D 0x0090
+#define REG_HIMR0_8723D 0x00B0
+#define REG_HISR0_8723D 0x00B4
+#define REG_HIMR1_8723D 0x00B8
+#define REG_HISR1_8723D 0x00BC
+#define REG_PMC_DBG_CTRL2_8723D 0x00CC
+#define REG_EFUSE_BURN_GNT_8723D 0x00CF
+#define REG_XTAL_AAC_8723D 0x00EC
+#define REG_SYS_CFG1_8723D 0x00F0
+#define REG_SYS_CFG2_8723D 0x00FC
+#define REG_ROM_VERSION 0x00FD
 
 /* -----------------------------------------------------
  *
  *	0x0100h ~ 0x01FFh	MACTOP General Configuration
  *
- * ----------------------------------------------------- */
-#define REG_CR_8723D					0x0100
-#define REG_PBP_8723D					0x0104 /* ?????? */
-#define REG_PKT_BUFF_ACCESS_CTRL_8723D	0x0106 /* ?????? */
-#define REG_TRXDMA_CTRL_8723D			0x010C
-#define REG_TRXFF_BNDY_8723D			0x0114
-#define REG_RXFF_PTR_8723D				0x011C
-#define REG_CPWM_8723D					0x012C
-#define REG_FWIMR_8723D					0x0130
-#define REG_FWISR_8723D					0x0134
-#define REG_FTIMR_8723D					0x0138
-#define REG_PKTBUF_DBG_CTRL_8723D		0x0140
-#define REG_RXPKTBUF_CTRL_8723D			0x0142 /* ?????? */
-#define REG_PKTBUF_DBG_DATA_L_8723D		0x0144
-#define REG_PKTBUF_DBG_DATA_H_8723D		0x0148
-
-#define REG_TC0_CTRL_8723D				0x0150
-#define REG_TC1_CTRL_8723D				0x0154
-#define REG_TC2_CTRL_8723D				0x0158
-#define REG_TC3_CTRL_8723D				0x015C
-#define REG_TC4_CTRL_8723D				0x0160
-#define REG_TCUNIT_BASE_8723D			0x0164
-#define REG_RSVD3_8723D				0x0168 /* ????? */
-
-#define REG_C2HEVT_MSG_NORMAL_8723D		0x01A0 /* ?????? */
-#define REG_C2HEVT_CMD_SEQ_88XX			0x01A1 /* ?????? */
-#define reg_c2h_evt_cmd_content_88xx		0x01A2 /* ?????? */
-#define REG_C2HEVT_CMD_LEN_88XX			0x01AE /* ?????? */
-#define REG_C2HEVT_CLEAR_8723D			0x01AF /* ?????? */
-#define REG_MCUTST_1_8723D				0x01C0
-#define REG_MCUTST_2_8723D				0x01C4
-#define REG_MCUTST_WOWLAN_8723D			0x01C7 /* ?????? */
-#define REG_FMETHR_8723D				0x01C8
-#define REG_HMETFR_8723D				0x01CC
-#define REG_HMEBOX_0_8723D				0x01D0
-#define REG_HMEBOX_1_8723D				0x01D4
-#define REG_HMEBOX_2_8723D				0x01D8
-#define REG_HMEBOX_3_8723D				0x01DC
-#define REG_LLT_INIT_8723D				0x01E0
-#define REG_HMEBOX_EXT0_8723D			0x01F0 /* ?????? */
-#define REG_HMEBOX_EXT1_8723D			0x01F4 /* ?????? */
-#define REG_HMEBOX_EXT2_8723D			0x01F8 /* ?????? */
-#define REG_HMEBOX_EXT3_8723D			0x01FC /* ?????? */
+ * -----------------------------------------------------
+ */
+#define REG_CR_8723D 0x0100
+#define REG_PBP_8723D 0x0104 /* ?????? */
+#define REG_PKT_BUFF_ACCESS_CTRL_8723D 0x0106 /* ?????? */
+#define REG_TRXDMA_CTRL_8723D 0x010C
+#define REG_TRXFF_BNDY_8723D 0x0114
+#define REG_RXFF_PTR_8723D 0x011C
+#define REG_CPWM_8723D 0x012C
+#define REG_FWIMR_8723D 0x0130
+#define REG_FWISR_8723D 0x0134
+#define REG_FTIMR_8723D 0x0138
+#define REG_PKTBUF_DBG_CTRL_8723D 0x0140
+#define REG_RXPKTBUF_CTRL_8723D 0x0142 /* ?????? */
+#define REG_PKTBUF_DBG_DATA_L_8723D 0x0144
+#define REG_PKTBUF_DBG_DATA_H_8723D 0x0148
+
+#define REG_TC0_CTRL_8723D 0x0150
+#define REG_TC1_CTRL_8723D 0x0154
+#define REG_TC2_CTRL_8723D 0x0158
+#define REG_TC3_CTRL_8723D 0x015C
+#define REG_TC4_CTRL_8723D 0x0160
+#define REG_TCUNIT_BASE_8723D 0x0164
+#define REG_RSVD3_8723D 0x0168 /* ????? */
+
+#define REG_C2HEVT_MSG_NORMAL_8723D 0x01A0 /* ?????? */
+#define REG_C2HEVT_CMD_SEQ_88XX 0x01A1 /* ?????? */
+#define reg_c2h_evt_cmd_content_88xx 0x01A2 /* ?????? */
+#define REG_C2HEVT_CMD_LEN_88XX 0x01AE /* ?????? */
+#define REG_C2HEVT_CLEAR_8723D 0x01AF /* ?????? */
+#define REG_MCUTST_1_8723D 0x01C0
+#define REG_MCUTST_2_8723D 0x01C4
+#define REG_MCUTST_WOWLAN_8723D 0x01C7 /* ?????? */
+#define REG_FMETHR_8723D 0x01C8
+#define REG_HMETFR_8723D 0x01CC
+#define REG_HMEBOX_0_8723D 0x01D0
+#define REG_HMEBOX_1_8723D 0x01D4
+#define REG_HMEBOX_2_8723D 0x01D8
+#define REG_HMEBOX_3_8723D 0x01DC
+#define REG_LLT_INIT_8723D 0x01E0
+#define REG_HMEBOX_EXT0_8723D 0x01F0 /* ?????? */
+#define REG_HMEBOX_EXT1_8723D 0x01F4 /* ?????? */
+#define REG_HMEBOX_EXT2_8723D 0x01F8 /* ?????? */
+#define REG_HMEBOX_EXT3_8723D 0x01FC /* ?????? */
 
 /* -----------------------------------------------------
  *
  *	0x0200h ~ 0x027Fh	TXDMA Configuration
  *
- * ----------------------------------------------------- */
-#define REG_RQPN_8723D					0x0200
-#define REG_FIFOPAGE_8723D				0x0204
-#define REG_TDECTRL_8723D			0x0208
-#define REG_TXDMA_OFFSET_CHK_8723D		0x020C
-#define REG_TXDMA_STATUS_8723D			0x0210
-#define REG_RQPN_NPQ_8723D				0x0214
-#define REG_AUTO_LLT_8723D				0x0224
-#define REG_DWBCN1_CTRL_8723D			0x0228
-
+ * -----------------------------------------------------
+ */
+#define REG_RQPN_8723D 0x0200
+#define REG_FIFOPAGE_8723D 0x0204
+#define REG_TDECTRL_8723D 0x0208
+#define REG_TXDMA_OFFSET_CHK_8723D 0x020C
+#define REG_TXDMA_STATUS_8723D 0x0210
+#define REG_RQPN_NPQ_8723D 0x0214
+#define REG_AUTO_LLT_8723D 0x0224
+#define REG_DWBCN1_CTRL_8723D 0x0228
 
 /* -----------------------------------------------------
  *
  *	0x0280h ~ 0x02FFh	RXDMA Configuration
  *
- * ----------------------------------------------------- */
-#define REG_RXDMA_AGG_PG_TH_8723D		0x0280
-#define REG_RXPKT_NUM_8723D				0x0284 /* The number of packets in RXPKTBUF. */
-#define REG_RXDMA_CONTROL_8723D			0x0286 /* ?????? Control the RX DMA. */
-#define REG_RXDMA_STATUS_8723D			0x0288
-#define REG_RXDMA_PRO_8723D				0x0290 /* ?????? */
-#define REG_EARLY_MODE_CONTROL_8723D	0x02BC /* ?????? */
-#define REG_RSVD5_8723D					0x02F0 /* ?????? */
-
+ * -----------------------------------------------------
+ */
+#define REG_RXDMA_AGG_PG_TH_8723D 0x0280
+#define REG_RXPKT_NUM_8723D 0x0284 /* The number of packets in RXPKTBUF. */
+#define REG_RXDMA_CONTROL_8723D 0x0286 /* ?????? Control the RX DMA. */
+#define REG_RXDMA_STATUS_8723D 0x0288
+#define REG_RXDMA_PRO_8723D 0x0290 /* ?????? */
+#define REG_EARLY_MODE_CONTROL_8723D 0x02BC /* ?????? */
+#define REG_RSVD5_8723D 0x02F0 /* ?????? */
 
 /* -----------------------------------------------------
  *
  *	0x0300h ~ 0x03FFh	PCIe
  *
- * ----------------------------------------------------- */
-#define	REG_PCIE_CTRL_REG_8723D			0x0300
-#define	REG_INT_MIG_8723D				0x0304	/* Interrupt Migration */
-#define	REG_BCNQ_TXBD_DESA_8723D		0x0308	/* TX Beacon Descriptor Address */
-#define	REG_MGQ_TXBD_DESA_8723D			0x0310	/* TX Manage Queue Descriptor Address */
-#define	REG_VOQ_TXBD_DESA_8723D			0x0318	/* TX VO Queue Descriptor Address */
-#define	REG_VIQ_TXBD_DESA_8723D			0x0320	/* TX VI Queue Descriptor Address */
-#define	REG_BEQ_TXBD_DESA_8723D			0x0328	/* TX BE Queue Descriptor Address */
-#define	REG_BKQ_TXBD_DESA_8723D			0x0330	/* TX BK Queue Descriptor Address */
-#define	REG_RXQ_RXBD_DESA_8723D			0x0338	/* RX Queue	Descriptor Address */
-#define REG_HI0Q_TXBD_DESA_8723D		0x0340
-#define REG_HI1Q_TXBD_DESA_8723D		0x0348
-#define REG_HI2Q_TXBD_DESA_8723D		0x0350
-#define REG_HI3Q_TXBD_DESA_8723D		0x0358
-#define REG_HI4Q_TXBD_DESA_8723D		0x0360
-#define REG_HI5Q_TXBD_DESA_8723D		0x0368
-#define REG_HI6Q_TXBD_DESA_8723D		0x0370
-#define REG_HI7Q_TXBD_DESA_8723D		0x0378
-#define	REG_MGQ_TXBD_NUM_8723D			0x0380
-#define	REG_RX_RXBD_NUM_8723D			0x0382
-#define	REG_VOQ_TXBD_NUM_8723D			0x0384
-#define	REG_VIQ_TXBD_NUM_8723D			0x0386
-#define	REG_BEQ_TXBD_NUM_8723D			0x0388
-#define	REG_BKQ_TXBD_NUM_8723D			0x038A
-#define	REG_HI0Q_TXBD_NUM_8723D			0x038C
-#define	REG_HI1Q_TXBD_NUM_8723D			0x038E
-#define	REG_HI2Q_TXBD_NUM_8723D			0x0390
-#define	REG_HI3Q_TXBD_NUM_8723D			0x0392
-#define	REG_HI4Q_TXBD_NUM_8723D			0x0394
-#define	REG_HI5Q_TXBD_NUM_8723D			0x0396
-#define	REG_HI6Q_TXBD_NUM_8723D			0x0398
-#define	REG_HI7Q_TXBD_NUM_8723D			0x039A
-#define	REG_TSFTIMER_HCI_8723D			0x039C
+ * -----------------------------------------------------
+ */
+#define REG_PCIE_CTRL_REG_8723D 0x0300
+#define REG_INT_MIG_8723D 0x0304 /* Interrupt Migration */
+#define REG_BCNQ_TXBD_DESA_8723D 0x0308 /* TX Beacon Descriptor Address */
+#define REG_MGQ_TXBD_DESA_8723D 0x0310 /* TX Manage Queue Descriptor Address */
+#define REG_VOQ_TXBD_DESA_8723D 0x0318 /* TX VO Queue Descriptor Address */
+#define REG_VIQ_TXBD_DESA_8723D 0x0320 /* TX VI Queue Descriptor Address */
+#define REG_BEQ_TXBD_DESA_8723D 0x0328 /* TX BE Queue Descriptor Address */
+#define REG_BKQ_TXBD_DESA_8723D 0x0330 /* TX BK Queue Descriptor Address */
+#define REG_RXQ_RXBD_DESA_8723D 0x0338 /* RX Queue	Descriptor Address */
+#define REG_HI0Q_TXBD_DESA_8723D 0x0340
+#define REG_HI1Q_TXBD_DESA_8723D 0x0348
+#define REG_HI2Q_TXBD_DESA_8723D 0x0350
+#define REG_HI3Q_TXBD_DESA_8723D 0x0358
+#define REG_HI4Q_TXBD_DESA_8723D 0x0360
+#define REG_HI5Q_TXBD_DESA_8723D 0x0368
+#define REG_HI6Q_TXBD_DESA_8723D 0x0370
+#define REG_HI7Q_TXBD_DESA_8723D 0x0378
+#define REG_MGQ_TXBD_NUM_8723D 0x0380
+#define REG_RX_RXBD_NUM_8723D 0x0382
+#define REG_VOQ_TXBD_NUM_8723D 0x0384
+#define REG_VIQ_TXBD_NUM_8723D 0x0386
+#define REG_BEQ_TXBD_NUM_8723D 0x0388
+#define REG_BKQ_TXBD_NUM_8723D 0x038A
+#define REG_HI0Q_TXBD_NUM_8723D 0x038C
+#define REG_HI1Q_TXBD_NUM_8723D 0x038E
+#define REG_HI2Q_TXBD_NUM_8723D 0x0390
+#define REG_HI3Q_TXBD_NUM_8723D 0x0392
+#define REG_HI4Q_TXBD_NUM_8723D 0x0394
+#define REG_HI5Q_TXBD_NUM_8723D 0x0396
+#define REG_HI6Q_TXBD_NUM_8723D 0x0398
+#define REG_HI7Q_TXBD_NUM_8723D 0x039A
+#define REG_TSFTIMER_HCI_8723D 0x039C
 
 /* Read Write Point */
-#define	REG_VOQ_TXBD_IDX_8723D			0x03A0
-#define	REG_VIQ_TXBD_IDX_8723D			0x03A4
-#define	REG_BEQ_TXBD_IDX_8723D			0x03A8
-#define	REG_BKQ_TXBD_IDX_8723D			0x03AC
-#define	REG_MGQ_TXBD_IDX_8723D			0x03B0
-#define	REG_RXQ_TXBD_IDX_8723D			0x03B4
-#define	REG_HI0Q_TXBD_IDX_8723D			0x03B8
-#define	REG_HI1Q_TXBD_IDX_8723D			0x03BC
-#define	REG_HI2Q_TXBD_IDX_8723D			0x03C0
-#define	REG_HI3Q_TXBD_IDX_8723D			0x03C4
-#define	REG_HI4Q_TXBD_IDX_8723D			0x03C8
-#define	REG_HI5Q_TXBD_IDX_8723D			0x03CC
-#define	REG_HI6Q_TXBD_IDX_8723D			0x03D0
-#define	REG_HI7Q_TXBD_IDX_8723D			0x03D4
-
-#define	REG_PCIE_HCPWM_8723DE			0x03D8 /* ?????? */
-#define	REG_PCIE_HRPWM_8723DE			0x03DC	/* PCIe RPWM */ /* ?????? */
-#define	REG_DBI_WDATA_V1_8723D			0x03E8
-#define	REG_DBI_RDATA_V1_8723D			0x03EC
-#define	REG_DBI_FLAG_V1_8723D			0x03F0
-#define REG_MDIO_V1_8723D				0x03F4
-#define REG_PCIE_MIX_CFG_8723D			0x03F8
-#define REG_HCI_MIX_CFG_8723D			0x03FC
+#define REG_VOQ_TXBD_IDX_8723D 0x03A0
+#define REG_VIQ_TXBD_IDX_8723D 0x03A4
+#define REG_BEQ_TXBD_IDX_8723D 0x03A8
+#define REG_BKQ_TXBD_IDX_8723D 0x03AC
+#define REG_MGQ_TXBD_IDX_8723D 0x03B0
+#define REG_RXQ_TXBD_IDX_8723D 0x03B4
+#define REG_HI0Q_TXBD_IDX_8723D 0x03B8
+#define REG_HI1Q_TXBD_IDX_8723D 0x03BC
+#define REG_HI2Q_TXBD_IDX_8723D 0x03C0
+#define REG_HI3Q_TXBD_IDX_8723D 0x03C4
+#define REG_HI4Q_TXBD_IDX_8723D 0x03C8
+#define REG_HI5Q_TXBD_IDX_8723D 0x03CC
+#define REG_HI6Q_TXBD_IDX_8723D 0x03D0
+#define REG_HI7Q_TXBD_IDX_8723D 0x03D4
+
+#define REG_PCIE_HCPWM_8723DE 0x03D8 /* ?????? */
+#define REG_PCIE_HRPWM_8723DE 0x03DC /* PCIe RPWM */ /* ?????? */
+#define REG_DBI_WDATA_V1_8723D 0x03E8
+#define REG_DBI_RDATA_V1_8723D 0x03EC
+#define REG_DBI_FLAG_V1_8723D 0x03F0
+#define REG_MDIO_V1_8723D 0x03F4
+#define REG_PCIE_MIX_CFG_8723D 0x03F8
+#define REG_HCI_MIX_CFG_8723D 0x03FC
 
 /* -----------------------------------------------------
  *
  *	0x0400h ~ 0x047Fh	Protocol Configuration
  *
- * ----------------------------------------------------- */
-#define REG_TXPKT_EMPTY_8723D				0x041A
-#define REG_PTCL_POLL_MGN_8723D				0x041F
-#define REG_FWHW_TXQ_CTRL_8723D				0x0420
-#define REG_HWSEQ_CTRL_8723D				0x0423
-#define REG_BCNQ_BDNY_8723D					0x0424
-#define REG_MGQ_BDNY_8723D					0x0425
-#define REG_LIFETIME_EN_8723D				0x0426
-#define REG_FW_FREE_TAIL_8723D				0x0427
-#define REG_SPEC_SIFS_8723D					0x0428
-#define REG_RETRY_LIMIT_8723D				0x042A
-#define REG_TXBF_CTRL_8723D					0x042C
-#define REG_DARFRC_8723D					0x0430
-#define REG_RARFRC_8723D					0x0438
-#define REG_RRSR_8723D						0x0440
-#define REG_ARFR0_8723D						0x0444
-#define REG_ARFR1_8723D						0x044C
-#define REG_CCK_CHECK_8723D					0x0454
-#define REG_BCNQ2_BDNY_8723D				0x0455
-#define REG_AMPDU_MAX_TIME_8723D			0x0456
-#define REG_BCNQ1_BDNY_8723D				0x0457
-#define REG_AMPDU_MAX_LENGTH_8723D			0x0458
-#define REG_WMAC_LBK_BUF_HD_8723D			0x045D
-#define REG_NDPA_OPT_CTRL_8723D				0x045F
-#define REG_FAST_EDCA_CTRL_8723D			0x0460
-#define REG_RD_RESP_PKT_TH_8723D			0x0463
-#define REG_DATA_SC_8723D					0x0483
-#define REG_TXRPT_START_OFFSET				0x04AC
-#define REG_POWER_STAGE1_8723D				0x04B4
-#define REG_PTCL_SDF_STATUS_8723D			0x04BB
-#define REG_SW_AMPDU_BURST_MODE_CTRL_8723D	0x04BC
-#define REG_EVTQ_BNDY_8723D					0x04BF
-#define REG_PKT_LIFE_TIME_8723D				0x04C0
-#define REG_PKT_BE_BK_LIFE_TIME_8723D		0x04C2 /* ?????? */
-
-#define REG_STBC_SETTING_8723D				0x04C4
-#define REG_HT_SINGLE_AMPDU_8723D			0x04C7
-#define REG_PROT_MODE_CTRL_8723D			0x04C8
-#define REG_MAX_AGGR_NUM_8723D				0x04CA
-#define REG_RTS_MAX_AGGR_NUM_8723D			0x04CB
-#define REG_BAR_MODE_CTRL_8723D				0x04CC
-#define REG_RA_TRY_RATE_AGG_LMT_8723D		0x04CF
-#define REG_MACID_SLEEP2_8723D				0x04D0
-#define REG_PTCL_HWSSN0_8723D				0x04D8
-#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8723D	0x045D /* ?????? */
-
+ * -----------------------------------------------------
+ */
+#define REG_TXPKT_EMPTY_8723D 0x041A
+#define REG_PTCL_POLL_MGN_8723D 0x041F
+#define REG_FWHW_TXQ_CTRL_8723D 0x0420
+#define REG_HWSEQ_CTRL_8723D 0x0423
+#define REG_BCNQ_BDNY_8723D 0x0424
+#define REG_MGQ_BDNY_8723D 0x0425
+#define REG_LIFETIME_EN_8723D 0x0426
+#define REG_FW_FREE_TAIL_8723D 0x0427
+#define REG_SPEC_SIFS_8723D 0x0428
+#define REG_RETRY_LIMIT_8723D 0x042A
+#define REG_TXBF_CTRL_8723D 0x042C
+#define REG_DARFRC_8723D 0x0430
+#define REG_RARFRC_8723D 0x0438
+#define REG_RRSR_8723D 0x0440
+#define REG_ARFR0_8723D 0x0444
+#define REG_ARFR1_8723D 0x044C
+#define REG_CCK_CHECK_8723D 0x0454
+#define REG_BCNQ2_BDNY_8723D 0x0455
+#define REG_AMPDU_MAX_TIME_8723D 0x0456
+#define REG_BCNQ1_BDNY_8723D 0x0457
+#define REG_AMPDU_MAX_LENGTH_8723D 0x0458
+#define REG_WMAC_LBK_BUF_HD_8723D 0x045D
+#define REG_NDPA_OPT_CTRL_8723D 0x045F
+#define REG_FAST_EDCA_CTRL_8723D 0x0460
+#define REG_RD_RESP_PKT_TH_8723D 0x0463
+#define REG_DATA_SC_8723D 0x0483
+#define REG_TXRPT_START_OFFSET 0x04AC
+#define REG_POWER_STAGE1_8723D 0x04B4
+#define REG_PTCL_SDF_STATUS_8723D 0x04BB
+#define REG_SW_AMPDU_BURST_MODE_CTRL_8723D 0x04BC
+#define REG_EVTQ_BNDY_8723D 0x04BF
+#define REG_PKT_LIFE_TIME_8723D 0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8723D 0x04C2 /* ?????? */
+
+#define REG_STBC_SETTING_8723D 0x04C4
+#define REG_HT_SINGLE_AMPDU_8723D 0x04C7
+#define REG_PROT_MODE_CTRL_8723D 0x04C8
+#define REG_MAX_AGGR_NUM_8723D 0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8723D 0x04CB
+#define REG_BAR_MODE_CTRL_8723D 0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8723D 0x04CF
+#define REG_MACID_SLEEP2_8723D 0x04D0
+#define REG_PTCL_HWSSN0_8723D 0x04D8
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8723D 0x045D /* ?????? */
 
 /************* 0x1480~0x14A7 is for NAN ***************/
 /* Own Master Rank, 8Bytes */
-#define	REG_NAN_INTERFACE_ADDR_8723D		0x2480	/* 6 bytes */
-#define	REG_NAN_RANDOM_FACTOR_8723D			0x2486	/* 1 byte */
-#define	REG_NAN_MASTER_PREF_8723D			0x2487	/* 1 byte */
+#define REG_NAN_INTERFACE_ADDR_8723D 0x2480 /* 6 bytes */
+#define REG_NAN_RANDOM_FACTOR_8723D 0x2486 /* 1 byte */
+#define REG_NAN_MASTER_PREF_8723D 0x2487 /* 1 byte */
 
 /* 0x5dc[25:24] NAN role */
 
 /* Current Anchor Master Record */
-#define	REG_NAN_CAMR_L_8723D				0x2488	/* 4 bytes */
-#define	REG_NAN_CAMR_H_8723D				0x248C	/* 4 byte
- * #define REG_HOP_CNT_8723D					0x05DC */
-#define	REG_NAN_CAMR_AMBTT_8723D			0x2490	/* 4 bytes */
+#define REG_NAN_CAMR_L_8723D 0x2488 /* 4 bytes */
+#define REG_NAN_CAMR_H_8723D 0x248C /* 4 byte */
+#define REG_NAN_CAMR_AMBTT_8723D 0x2490 /* 4 bytes */
 
 /* Last Anchor Master Record */
-#define	REG_NAN_LAMR_L_8723D				0x2494	/* 4 bytes */
-#define	REG_NAN_LAMR_H_8723D				0x2498	/* 4 byte */
-#define	REG_NAN_LAMR_AMBTT_8723D			0x249C	/* 4 bytes */
+#define REG_NAN_LAMR_L_8723D 0x2494 /* 4 bytes */
+#define REG_NAN_LAMR_H_8723D 0x2498 /* 4 byte */
+#define REG_NAN_LAMR_AMBTT_8723D 0x249C /* 4 bytes */
 
 /* TSF Synced:bit 0
- * Anchor Master: bit 7 */
-#define REG_NAN_STATUS_8723D				0x24A0	/* BIT0
- ***************************************************/
-
+ * Anchor Master: bit 7
+ */
+#define REG_NAN_STATUS_8723D 0x24A0 /* BIT0 */
 
 /* -----------------------------------------------------
  *
  *	0x0500h ~ 0x05FFh	EDCA Configuration
  *
  * -----------------------------------------------------
- * gogogo */
-#define REG_EDCA_VO_PARAM_8723D			0x0500
-#define REG_EDCA_VI_PARAM_8723D			0x0504
-#define REG_EDCA_BE_PARAM_8723D			0x0508
-#define REG_EDCA_BK_PARAM_8723D			0x050C
-#define REG_BCNTCFG_8723D				0x0510
-#define REG_PIFS_8723D					0x0512
-#define REG_RDG_PIFS_8723D				0x0513
-#define REG_SIFS_CTX_8723D				0x0514
-#define REG_SIFS_TRX_8723D				0x0516
-#define REG_AGGR_BREAK_TIME_8723D		0x051A
-#define REG_SLOT_8723D					0x051B
-#define REG_TX_PTCL_CTRL_8723D			0x0520
-#define REG_TXPAUSE_8723D				0x0522
-#define REG_DIS_TXREQ_CLR_8723D			0x0523
-#define REG_RD_CTRL_8723D				0x0524
+ * gogogo
+ */
+#define REG_EDCA_VO_PARAM_8723D 0x0500
+#define REG_EDCA_VI_PARAM_8723D 0x0504
+#define REG_EDCA_BE_PARAM_8723D 0x0508
+#define REG_EDCA_BK_PARAM_8723D 0x050C
+#define REG_BCNTCFG_8723D 0x0510
+#define REG_PIFS_8723D 0x0512
+#define REG_RDG_PIFS_8723D 0x0513
+#define REG_SIFS_CTX_8723D 0x0514
+#define REG_SIFS_TRX_8723D 0x0516
+#define REG_AGGR_BREAK_TIME_8723D 0x051A
+#define REG_SLOT_8723D 0x051B
+#define REG_TX_PTCL_CTRL_8723D 0x0520
+#define REG_TXPAUSE_8723D 0x0522
+#define REG_DIS_TXREQ_CLR_8723D 0x0523
+#define REG_RD_CTRL_8723D 0x0524
 /*
  * Format for offset 540h-542h:
  *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
@@ -346,213 +347,216 @@
  * TBTT
  * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
  * Described by Designer Tim and Bruce, 2011-01-14.
- *   */
-#define REG_TBTT_PROHIBIT_8723D			0x0540
-#define REG_RD_NAV_NXT_8723D			0x0544
-#define REG_NAV_PROT_LEN_8723D			0x0546
-#define REG_BCN_CTRL_8723D				0x0550
-#define REG_EDCA_BCNCTRL1_IOREG_8723D	0x0551
-#define REG_MBID_NUM_8723D				0x0552
-#define REG_DUAL_TSF_RST_8723D			0x0553
-#define REG_BCN_INTERVAL_8723D			0x0554
-#define REG_DRVERLYINT_8723D			0x0558
-#define REG_BCNDMATIM_8723D				0x0559
-#define REG_ATIMWND_8723D				0x055A
-#define REG_USTIME_TSF_8723D			0x055C
-#define REG_BCN_MAX_ERR_8723D			0x055D
-#define REG_RXTSF_OFFSET_CCK_8723D		0x055E
-#define REG_RXTSF_OFFSET_OFDM_8723D		0x055F
-#define REG_TSFTR_8723D					0x0560
-#define REG_CTWND_8723D					0x0572
-#define REG_SECONDARY_CCA_CTRL_8723D	0x0577 /* ?????? */
-#define	REG_TSFTR2_8723D				0x0578
-#define REG_PSTIMER_8723D				0x0580
-#define REG_TIMER0_8723D				0x0584
-#define REG_TIMER1_8723D				0x0588
-#define	REG_SCH_MULTI_BCN_8723D			0x05B2
-#define REG_SCH_CURRENT_BCN_8723D		0x05B3
-#define REG_ACMHWCTRL_8723D				0x05C0
-#define REG_SCH_SDFX_EARLY_8723D		0x05CF
-#define REG_SCH_PORT2_EARLY_8723D		0x05D0
-#define REG_SCH_TSFT_DIFF_8723D			0x05D2
-#define REG_EDCA_BCNCTRL2_IOREG_8723D	0x05D4
-#define REG_EDCA_DRVERLYINT1_IOREG_8723D	0x05D4
-#define REG_EDCA_BCNSPACE3_IOREG_8723D	0x05D8
-#define REG_EDCA_BCNSPACE4_IOREG_8723D	0x05DA
-#define REG_HOP_CNT_8723D				0x05DC
-#define REG_SCH_M_DW_8723D				0x05DD
-#define REG_SCH_M_SLOT_8723D			0x05DE
-#define REG_SCH_EARLY_DWEND_8723D		0x05DF
-#define REG_SCH_TXCMD_8723D				0x05F8
+ *
+ */
+#define REG_TBTT_PROHIBIT_8723D 0x0540
+#define REG_RD_NAV_NXT_8723D 0x0544
+#define REG_NAV_PROT_LEN_8723D 0x0546
+#define REG_BCN_CTRL_8723D 0x0550
+#define REG_EDCA_BCNCTRL1_IOREG_8723D 0x0551
+#define REG_MBID_NUM_8723D 0x0552
+#define REG_DUAL_TSF_RST_8723D 0x0553
+#define REG_BCN_INTERVAL_8723D 0x0554
+#define REG_DRVERLYINT_8723D 0x0558
+#define REG_BCNDMATIM_8723D 0x0559
+#define REG_ATIMWND_8723D 0x055A
+#define REG_USTIME_TSF_8723D 0x055C
+#define REG_BCN_MAX_ERR_8723D 0x055D
+#define REG_RXTSF_OFFSET_CCK_8723D 0x055E
+#define REG_RXTSF_OFFSET_OFDM_8723D 0x055F
+#define REG_TSFTR_8723D 0x0560
+#define REG_CTWND_8723D 0x0572
+#define REG_SECONDARY_CCA_CTRL_8723D 0x0577 /* ?????? */
+#define REG_TSFTR2_8723D 0x0578
+#define REG_PSTIMER_8723D 0x0580
+#define REG_TIMER0_8723D 0x0584
+#define REG_TIMER1_8723D 0x0588
+#define REG_SCH_MULTI_BCN_8723D 0x05B2
+#define REG_SCH_CURRENT_BCN_8723D 0x05B3
+#define REG_ACMHWCTRL_8723D 0x05C0
+#define REG_SCH_SDFX_EARLY_8723D 0x05CF
+#define REG_SCH_PORT2_EARLY_8723D 0x05D0
+#define REG_SCH_TSFT_DIFF_8723D 0x05D2
+#define REG_EDCA_BCNCTRL2_IOREG_8723D 0x05D4
+#define REG_EDCA_DRVERLYINT1_IOREG_8723D 0x05D4
+#define REG_EDCA_BCNSPACE3_IOREG_8723D 0x05D8
+#define REG_EDCA_BCNSPACE4_IOREG_8723D 0x05DA
+#define REG_HOP_CNT_8723D 0x05DC
+#define REG_SCH_M_DW_8723D 0x05DD
+#define REG_SCH_M_SLOT_8723D 0x05DE
+#define REG_SCH_EARLY_DWEND_8723D 0x05DF
+#define REG_SCH_TXCMD_8723D 0x05F8
 
 /* -----------------------------------------------------
  *
  *	0x0600h ~ 0x07FFh	WMAC Configuration
  *
  * -----------------------------------------------------
- * gogogo */
-#define REG_MAC_CR_8723D				0x0600
-#define REG_TCR_8723D					0x0604
-#define REG_RCR_8723D					0x0608
-#define REG_RX_PKT_LIMIT_8723D			0x060C
-#define REG_RX_DLK_TIME_8723D			0x060D
-#define REG_RX_DRVINFO_SZ_8723D			0x060F
-
-#define REG_MACID_8723D					0x0610
-#define REG_BSSID_8723D					0x0618
-#define REG_MAR_8723D					0x0620
-#define REG_MBIDCAMCFG_8723D			0x0628
-
-#define REG_USTIME_EDCA_8723D			0x0638
-#define REG_MAC_SPEC_SIFS_8723D			0x063A
-#define REG_RESP_SIFP_CCK_8723D			0x063C
-#define REG_RESP_SIFS_OFDM_8723D		0x063E
-#define REG_ACKTO_8723D					0x0640
-#define REG_CTS2TO_8723D				0x0641
-#define REG_EIFS_8723D					0x0642
-
-#define REG_NAV_UPPER_8723D				0x0652	/* ?????? */
-#define REG_TRXPTCL_CTL_8723D			0x0668
+ * gogogo
+ */
+#define REG_MAC_CR_8723D 0x0600
+#define REG_TCR_8723D 0x0604
+#define REG_RCR_8723D 0x0608
+#define REG_RX_PKT_LIMIT_8723D 0x060C
+#define REG_RX_DLK_TIME_8723D 0x060D
+#define REG_RX_DRVINFO_SZ_8723D 0x060F
+
+#define REG_MACID_8723D 0x0610
+#define REG_BSSID_8723D 0x0618
+#define REG_MAR_8723D 0x0620
+#define REG_MBIDCAMCFG_8723D 0x0628
+
+#define REG_USTIME_EDCA_8723D 0x0638
+#define REG_MAC_SPEC_SIFS_8723D 0x063A
+#define REG_RESP_SIFP_CCK_8723D 0x063C
+#define REG_RESP_SIFS_OFDM_8723D 0x063E
+#define REG_ACKTO_8723D 0x0640
+#define REG_CTS2TO_8723D 0x0641
+#define REG_EIFS_8723D 0x0642
+
+#define REG_NAV_UPPER_8723D 0x0652 /* ?????? */
+#define REG_TRXPTCL_CTL_8723D 0x0668
 
 /* security */
-#define REG_CAMCMD_8723D				0x0670
-#define REG_CAMWRITE_8723D				0x0674
-#define REG_CAMREAD_8723D				0x0678
-#define REG_CAMDBG_8723D				0x067C
-#define REG_SECCFG_8723D				0x0680
+#define REG_CAMCMD_8723D 0x0670
+#define REG_CAMWRITE_8723D 0x0674
+#define REG_CAMREAD_8723D 0x0678
+#define REG_CAMDBG_8723D 0x067C
+#define REG_SECCFG_8723D 0x0680
 
 /* Power */
-#define REG_WOW_CTRL_8723D				0x0690
-#define REG_PS_RX_INFO_8723D			0x0692
-#define REG_UAPSD_TID_8723D				0x0693
-#define REG_WKFMCAM_NUM_8723D			0x0698
-#define REG_RXFLTMAP0_8723D				0x06A0
-#define REG_RXFLTMAP1_8723D				0x06A2
-#define REG_RXFLTMAP2_8723D				0x06A4
-#define REG_BCN_PSR_RPT_8723D			0x06A8
-#define REG_BT_COEX_TABLE_8723D			0x06C0
-#define REG_ASSOCIATED_BFMER0_INFO_8723D	0x06E4
-#define REG_ASSOCIATED_BFMER1_INFO_8723D	0x06EC
-#define REG_CSI_RPT_PARAM_BW20_8723D	0x06F4
-#define REG_CSI_RPT_PARAM_BW40_8723D	0x06F8
-#define REG_CSI_RPT_PARAM_BW80_8723D	0x06FC
+#define REG_WOW_CTRL_8723D 0x0690
+#define REG_PS_RX_INFO_8723D 0x0692
+#define REG_UAPSD_TID_8723D 0x0693
+#define REG_WKFMCAM_NUM_8723D 0x0698
+#define REG_RXFLTMAP0_8723D 0x06A0
+#define REG_RXFLTMAP1_8723D 0x06A2
+#define REG_RXFLTMAP2_8723D 0x06A4
+#define REG_BCN_PSR_RPT_8723D 0x06A8
+#define REG_BT_COEX_TABLE_8723D 0x06C0
+#define REG_ASSOCIATED_BFMER0_INFO_8723D 0x06E4
+#define REG_ASSOCIATED_BFMER1_INFO_8723D 0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8723D 0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8723D 0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8723D 0x06FC
 
 /* Hardware Port 2 */
-#define REG_MACID1_8723D				0x0700
-#define REG_BSSID1_8723D				0x0708
-#define REG_ASSOCIATED_BFMEE_SEL_8723D	0x0714
-#define REG_SND_PTCL_CTRL_8723D			0x0718
+#define REG_MACID1_8723D 0x0700
+#define REG_BSSID1_8723D 0x0708
+#define REG_ASSOCIATED_BFMEE_SEL_8723D 0x0714
+#define REG_SND_PTCL_CTRL_8723D 0x0718
 
 /* -----------------------------------------------------
  *
  *	Redifine 8192C register definition for compatibility
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 
 /* TODO: use these definition when using REG_xxx naming rule.
- * NOTE: DO NOT Remove these definition. Use later. */
-#define	EFUSE_CTRL_8723D					REG_EFUSE_CTRL_8723D		/* E-Fuse Control. */
-#define	EFUSE_TEST_8723D					REG_LDO_EFUSE_CTRL_8723D		/* E-Fuse Test. */
-#define	MSR_8723D							(REG_CR_8723D + 2)		/* Media status register */
-#define	ISR_8723D							REG_HISR0_8723D
-#define	TSFR_8723D							REG_TSFTR_8723D			/* Timing Sync Function Timer Register. */
+ * NOTE: DO NOT Remove these definition. Use later.
+ */
+#define EFUSE_CTRL_8723D REG_EFUSE_CTRL_8723D /* E-Fuse Control. */
+#define EFUSE_TEST_8723D REG_LDO_EFUSE_CTRL_8723D /* E-Fuse Test. */
+#define MSR_8723D (REG_CR_8723D + 2) /* Media status register */
+#define ISR_8723D REG_HISR0_8723D
+#define TSFR_8723D REG_TSFTR_8723D /* Timing Sync Function Timer Register. */
 
 /* Redifine MACID register, to compatible prior ICs. */
-#define	IDR0_8723D							REG_MACID_8723D			/* MAC ID Register, Offset 0x0050-0x0053 */
-#define	IDR4_8723D							(REG_MACID_8723D + 4)	/* MAC ID Register, Offset 0x0054-0x0055 */
-
+#define IDR0_8723D REG_MACID_8723D /* MAC ID Register, Offset 0x0050-0x0053 */
+#define IDR4_8723D (REG_MACID_8723D + 4) /* MAC ID Register, Offset 0x0054-0x0055 */
 
 /*
  * 9. security Control Registers	(Offset: )
- *   */
-#define	RWCAM_8723D						REG_CAMCMD_8723D		/* 8190 data Sheet is called CAMcmd */
-#define	WCAMI_8723D						REG_CAMWRITE_8723D		/* Software write CAM input content */
-#define	RCAMO_8723D						REG_CAMREAD_8723D		/* Software read/write CAM config */
-#define	CAMDBG_8723D						REG_CAMDBG_8723D
-#define	SECR_8723D							REG_SECCFG_8723D		/* security Configuration Register */
-
+ *
+ */
+#define RWCAM_8723D REG_CAMCMD_8723D /* 8190 data Sheet is called CAMcmd */
+#define WCAMI_8723D REG_CAMWRITE_8723D /* Software write CAM input content */
+#define RCAMO_8723D REG_CAMREAD_8723D /* Software read/write CAM config */
+#define CAMDBG_8723D REG_CAMDBG_8723D
+#define SECR_8723D REG_SECCFG_8723D /* security Configuration Register */
 
 /* ----------------------------------------------------------------------------
  * 8195 IMR/ISR bits						(offset 0xB0,  8bits)
- * ---------------------------------------------------------------------------- */
-#define	IMR_DISABLED_8723D					0
+ * ----------------------------------------------------------------------------
+ */
+#define IMR_DISABLED_8723D 0
 /* IMR DW0(0x00B0-00B3) Bit 0-31 */
-#define	IMR_TIMER2_8723D					BIT(31)		/* Timeout interrupt 2 */
-#define	IMR_TIMER1_8723D					BIT(30)		/* Timeout interrupt 1 */
-#define	IMR_PSTIMEOUT_8723D				BIT(29)		/* Power Save Time Out Interrupt */
-#define	IMR_GTINT4_8723D					BIT(28)		/* When GTIMER4 expires, this bit is set to 1 */
-#define	IMR_GTINT3_8723D					BIT(27)		/* When GTIMER3 expires, this bit is set to 1 */
-#define	IMR_TXBCN0ERR_8723D				BIT(26)		/* Transmit Beacon0 Error */
-#define	IMR_TXBCN0OK_8723D				BIT(25)		/* Transmit Beacon0 OK */
-#define	IMR_TSF_BIT32_TOGGLE_8723D		BIT(24)		/* TSF Timer BIT32 toggle indication interrupt */
-#define	IMR_BCNDMAINT0_8723D				BIT(20)		/* Beacon DMA Interrupt 0 */
-#define	IMR_BCNDERR0_8723D				BIT(16)		/* Beacon Queue DMA OK0 */
-#define	IMR_HSISR_IND_ON_INT_8723D		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
-#define	IMR_BCNDMAINT_E_8723D			BIT(14)		/* Beacon DMA Interrupt Extension for Win7 */
-#define	IMR_ATIMEND_8723D				BIT(12)		/* CTWidnow End or ATIM Window End */
-#define	IMR_C2HCMD_8723D					BIT(10)		/* CPU to Host Command INT status, Write 1 clear */
-#define	IMR_CPWM2_8723D					BIT(9)			/* CPU power mode exchange INT status, Write 1 clear */
-#define	IMR_CPWM_8723D					BIT(8)			/* CPU power mode exchange INT status, Write 1 clear */
-#define	IMR_HIGHDOK_8723D				BIT(7)			/* High Queue DMA OK */
-#define	IMR_MGNTDOK_8723D				BIT(6)			/* Management Queue DMA OK */
-#define	IMR_BKDOK_8723D					BIT(5)			/* AC_BK DMA OK */
-#define	IMR_BEDOK_8723D					BIT(4)			/* AC_BE DMA OK */
-#define	IMR_VIDOK_8723D					BIT(3)			/* AC_VI DMA OK */
-#define	IMR_VODOK_8723D					BIT(2)			/* AC_VO DMA OK */
-#define	IMR_RDU_8723D					BIT(1)			/* Rx Descriptor Unavailable */
-#define	IMR_ROK_8723D					BIT(0)			/* Receive DMA OK */
+#define IMR_TIMER2_8723D BIT(31) /* Timeout interrupt 2 */
+#define IMR_TIMER1_8723D BIT(30) /* Timeout interrupt 1 */
+#define IMR_PSTIMEOUT_8723D BIT(29) /* Power Save Time Out Interrupt */
+#define IMR_GTINT4_8723D BIT(28) /* When GTIMER4 expires, this bit is set to 1 */
+#define IMR_GTINT3_8723D BIT(27) /* When GTIMER3 expires, this bit is set to 1 */
+#define IMR_TXBCN0ERR_8723D BIT(26) /* Transmit Beacon0 Error */
+#define IMR_TXBCN0OK_8723D BIT(25) /* Transmit Beacon0 OK */
+#define IMR_TSF_BIT32_TOGGLE_8723D BIT(24) /* TSF Timer BIT32 toggle indication interrupt */
+#define IMR_BCNDMAINT0_8723D BIT(20) /* Beacon DMA Interrupt 0 */
+#define IMR_BCNDERR0_8723D BIT(16) /* Beacon Queue DMA OK0 */
+#define IMR_HSISR_IND_ON_INT_8723D BIT(15) /* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define IMR_BCNDMAINT_E_8723D BIT(14) /* Beacon DMA Interrupt Extension for Win7 */
+#define IMR_ATIMEND_8723D BIT(12) /* CTWidnow End or ATIM Window End */
+#define IMR_C2HCMD_8723D BIT(10) /* CPU to Host Command INT status, Write 1 clear */
+#define IMR_CPWM2_8723D BIT(9) /* CPU power mode exchange INT status, Write 1 clear */
+#define IMR_CPWM_8723D BIT(8) /* CPU power mode exchange INT status, Write 1 clear */
+#define IMR_HIGHDOK_8723D BIT(7) /* High Queue DMA OK */
+#define IMR_MGNTDOK_8723D BIT(6) /* Management Queue DMA OK */
+#define IMR_BKDOK_8723D BIT(5) /* AC_BK DMA OK */
+#define IMR_BEDOK_8723D BIT(4) /* AC_BE DMA OK */
+#define IMR_VIDOK_8723D BIT(3) /* AC_VI DMA OK */
+#define IMR_VODOK_8723D BIT(2) /* AC_VO DMA OK */
+#define IMR_RDU_8723D BIT(1) /* Rx Descriptor Unavailable */
+#define IMR_ROK_8723D BIT(0) /* Receive DMA OK */
 
 /* IMR DW1(0x00B4-00B7) Bit 0-31 */
-#define	IMR_BCNDMAINT7_8723D				BIT(27)		/* Beacon DMA Interrupt 7 */
-#define	IMR_BCNDMAINT6_8723D				BIT(26)		/* Beacon DMA Interrupt 6 */
-#define	IMR_BCNDMAINT5_8723D				BIT(25)		/* Beacon DMA Interrupt 5 */
-#define	IMR_BCNDMAINT4_8723D				BIT(24)		/* Beacon DMA Interrupt 4 */
-#define	IMR_BCNDMAINT3_8723D				BIT(23)		/* Beacon DMA Interrupt 3 */
-#define	IMR_BCNDMAINT2_8723D				BIT(22)		/* Beacon DMA Interrupt 2 */
-#define	IMR_BCNDMAINT1_8723D				BIT(21)		/* Beacon DMA Interrupt 1 */
-#define	IMR_BCNDOK7_8723D					BIT(20)		/* Beacon Queue DMA OK Interrup 7 */
-#define	IMR_BCNDOK6_8723D					BIT(19)		/* Beacon Queue DMA OK Interrup 6 */
-#define	IMR_BCNDOK5_8723D					BIT(18)		/* Beacon Queue DMA OK Interrup 5 */
-#define	IMR_BCNDOK4_8723D					BIT(17)		/* Beacon Queue DMA OK Interrup 4 */
-#define	IMR_BCNDOK3_8723D					BIT(16)		/* Beacon Queue DMA OK Interrup 3 */
-#define	IMR_BCNDOK2_8723D					BIT(15)		/* Beacon Queue DMA OK Interrup 2 */
-#define	IMR_BCNDOK1_8723D					BIT(14)		/* Beacon Queue DMA OK Interrup 1 */
-#define	IMR_ATIMEND_E_8723D				BIT(13)		/* ATIM Window End Extension for Win7 */
-#define	IMR_TXERR_8723D					BIT(11)		/* Tx Error Flag Interrupt status, write 1 clear. */
-#define	IMR_RXERR_8723D					BIT(10)		/* Rx Error Flag INT status, Write 1 clear */
-#define	IMR_TXFOVW_8723D					BIT(9)			/* Transmit FIFO Overflow */
-#define	IMR_RXFOVW_8723D					BIT(8)			/* Receive FIFO Overflow */
-
-
-
-#define	IMR_MCUERR_8723D						BIT(28)		/* Beacon DMA Interrupt 7 */
-
+#define IMR_BCNDMAINT7_8723D BIT(27) /* Beacon DMA Interrupt 7 */
+#define IMR_BCNDMAINT6_8723D BIT(26) /* Beacon DMA Interrupt 6 */
+#define IMR_BCNDMAINT5_8723D BIT(25) /* Beacon DMA Interrupt 5 */
+#define IMR_BCNDMAINT4_8723D BIT(24) /* Beacon DMA Interrupt 4 */
+#define IMR_BCNDMAINT3_8723D BIT(23) /* Beacon DMA Interrupt 3 */
+#define IMR_BCNDMAINT2_8723D BIT(22) /* Beacon DMA Interrupt 2 */
+#define IMR_BCNDMAINT1_8723D BIT(21) /* Beacon DMA Interrupt 1 */
+#define IMR_BCNDOK7_8723D BIT(20) /* Beacon Queue DMA OK Interrupt 7 */
+#define IMR_BCNDOK6_8723D BIT(19) /* Beacon Queue DMA OK Interrupt 6 */
+#define IMR_BCNDOK5_8723D BIT(18) /* Beacon Queue DMA OK Interrupt 5 */
+#define IMR_BCNDOK4_8723D BIT(17) /* Beacon Queue DMA OK Interrupt 4 */
+#define IMR_BCNDOK3_8723D BIT(16) /* Beacon Queue DMA OK Interrupt 3 */
+#define IMR_BCNDOK2_8723D BIT(15) /* Beacon Queue DMA OK Interrupt 2 */
+#define IMR_BCNDOK1_8723D BIT(14) /* Beacon Queue DMA OK Interrupt 1 */
+#define IMR_ATIMEND_E_8723D BIT(13) /* ATIM Window End Extension for Win7 */
+#define IMR_TXERR_8723D BIT(11) /* Tx Error Flag Interrupt status, write 1 clear. */
+#define IMR_RXERR_8723D BIT(10) /* Rx Error Flag INT status, Write 1 clear */
+#define IMR_TXFOVW_8723D BIT(9) /* Transmit FIFO Overflow */
+#define IMR_RXFOVW_8723D BIT(8) /* Receive FIFO Overflow */
+
+#define IMR_MCUERR_8723D BIT(28) /* Beacon DMA Interrupt 7 */
 
 /*===================================================================
-=====================================================================
-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!!!!!!
-=====================================================================
-=====================================================================*/
+ *=====================================================================
+ *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)
-*/
+ * 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)
+ */
 /* ----------------------------------------------------------------------------
  *		 8195 (TXPAUSE) transmission pause	(Offset 0x522, 8 bits)
  * ----------------------------------------------------------------------------
- *
+ */
+#if 0
 #define		StopBecon			BIT(6)
 #define		StopHigh				BIT(5)
 #define		StopMgt				BIT(4)
@@ -560,8 +564,7 @@ Current IOREG MAP
 #define		StopVI				BIT(2)
 #define		StopBE				BIT(1)
 #define		StopBK				BIT(0)
-*/
-
+#endif
 
 
 /* ****************************************************************************
@@ -571,372 +574,375 @@ Current IOREG MAP
  *
  *	0x0000h ~ 0x00FFh	System Configuration
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 #if 0
 	/* 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_EV12V						BIT(15)
+#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_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)
+#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)
+#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 ANAD16V_EN BIT(0)
+#define ANA8M BIT(1)
+#define MACSLP BIT(4)
+#define LOADER_CLK_EN BIT(5)
 
 
 	/* 2 9346CR */
 
-	#define		BOOT_FROM_EEPROM		BIT(4)
-	#define		EEPROM_EN				BIT(5)
+#define BOOT_FROM_EEPROM BIT(4)
+#define EEPROM_EN BIT(5)
 
 
 	/* 2 RF_CTRL */
-	#define RF_EN						BIT(0)
-	#define RF_RSTB					BIT(1)
-	#define RF_SDMRSTB				BIT(2)
+#define RF_EN BIT(0)
+#define RF_RSTB BIT(1)
+#define RF_SDMRSTB BIT(2)
 
 	/* 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)
+#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 EFUSE_TEST (For RTL8723 partially) */
-	#define EF_TRPT						BIT(7)
-	#define EF_CELL_SEL						(BIT(8) | BIT(9)) /*  00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2 */
-	#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 EF_TRPT BIT(7)
+#define EF_CELL_SEL (BIT(8) | BIT(9))  /*  00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2 */
+#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
 
 
 	/* 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 RAM_DL_SEL					BIT(7)
-	#define ROM_DLEN						BIT(19)
-	#define CPRST							BIT(23)
+#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 RAM_DL_SEL BIT(7)
+#define ROM_DLEN BIT(19)
+#define CPRST BIT(23)
 
 
 
 	/* 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)	/*  RTL ID */
-	#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
+#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)	 /*  RTL ID */
+#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
 
 #endif
 /* -----------------------------------------------------
  *
  *	0x0100h ~ 0x01FFh	MACTOP General Configuration
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 #if 0
 
 	/* 2 Function Enable Registers */
 	/* 2 CR 0x0100-0x0103 */
 
-
-	#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 CALTMR_EN					BIT(10)	/*  32k CAL TMR enable */
+#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 CALTMR_EN BIT(10)	 /*  32k CAL TMR enable */
 
 	/*  Network type */
-	#define _NETTYPE(x)					(((x) & 0x3) << 16)
-	#define MASK_NETTYPE					0x30000
-	#define NT_NO_LINK					0x0
-	#define NT_LINK_AD_HOC				0x1
-	#define NT_LINK_AP						0x2
-	#define NT_AS_AP						0x3
+#define _NETTYPE(x) (((x) & 0x3) << 16)
+#define MASK_NETTYPE 0x30000
+#define NT_NO_LINK 0x0
+#define NT_LINK_AD_HOC 0x1
+#define NT_LINK_AP 0x2
+#define NT_AS_AP 0x3
 
 
 	/* 2 PBP - Page Size Register 0x0104 */
-	#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 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
+#define PBP_64 0x0
+#define PBP_128 0x1
+#define PBP_256 0x2
+#define PBP_512 0x3
+#define PBP_1024 0x4
 
 
 	/* 2 TX/RXDMA 0x010C */
-	#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)
+#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 _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
+#define QUEUE_LOW 1
+#define QUEUE_NORMAL 2
+#define QUEUE_HIGH 3
 
 
 	/* 2 REG_C2HEVT_CLEAR 0x01AF */
-	#define	C2H_EVT_HOST_CLOSE			0x00	/*  Set by driver and notify FW that the driver has read the C2H command message */
-	#define	C2H_EVT_FW_CLOSE			0xFF		/*  Set by FW indicating that FW had set the C2H command message and it's not yet read by driver. */
+#define C2H_EVT_HOST_CLOSE 0x00	 /*  Set by driver and notify FW that the driver has read the C2H command message */
+#define C2H_EVT_FW_CLOSE 0xFF		 /*  Set by FW indicating that FW had set the C2H command message and it's not yet read by driver. */
 
 
 
 	/* 2 LLT_INIT 0x01E0 */
-	#define _LLT_NO_ACTIVE					0x0
-	#define _LLT_WRITE_ACCESS				0x1
-	#define _LLT_READ_ACCESS				0x2
+#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)
+#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)
 
 #endif
 /* -----------------------------------------------------
  *
  *	0x0200h ~ 0x027Fh	TXDMA Configuration
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 #if 0
 	/* 2 TDECTL 0x0208 */
-	#define BLK_DESC_NUM_SHIFT			4
-	#define BLK_DESC_NUM_MASK			0xF
+#define BLK_DESC_NUM_SHIFT 4
+#define BLK_DESC_NUM_MASK 0xF
 
 
 	/* 2 TXDMA_OFFSET_CHK 0x020C */
-	#define DROP_DATA_EN				BIT(9)
+#define DROP_DATA_EN BIT(9)
 #endif
 /* -----------------------------------------------------
  *
  *	0x0280h ~ 0x028Bh	RX DMA Configuration
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 #if 0
 	/* 2 REG_RXDMA_CONTROL, 0x0286h */
 
 	/*  Write only. When this bit is set, RXDMA will decrease RX PKT counter by one. Before */
 	/*  this bit is polled, FW shall update RXFF_RD_PTR first. This register is write pulse and auto clear. */
-	#define	RXPKT_RELEASE_POLL			BIT(0)
+#define RXPKT_RELEASE_POLL BIT(0)
 	/*  Read only. When RXMA finishes on-going DMA operation, RXMDA will report idle state in */
 	/*  this bit. FW can start releasing packets after RXDMA entering idle mode. */
-	#define	RXDMA_IDLE					BIT(1)
+#define RXDMA_IDLE BIT(1)
 	/*  When this bit is set, RXDMA will enter this mode after on-going RXDMA packet to host */
 	/*  completed, and stop DMA packet to host. RXDMA will then report Default: 0; */
-	#define	RW_RELEASE_EN				BIT(2)
+#define RW_RELEASE_EN BIT(2)
 #endif
 /* -----------------------------------------------------
  *
  *	0x0400h ~ 0x047Fh	Protocol Configuration
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 #if 0
 	/* 2 FWHW_TXQ_CTRL 0x0420 */
-	#define EN_AMPDU_RTY_NEW			BIT(7)
+#define EN_AMPDU_RTY_NEW BIT(7)
 
 
 	/* 2 REG_LIFECTRL_CTRL 0x0426 */
-	#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_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. */
+#define HAL92C_MSDU_LIFE_TIME_UNIT 128		 /*  in us, said by Tim. */
 
 
 	/* 2 SPEC SIFS 0x0428 */
-	#define _SPEC_SIFS_CCK(x)				((x) & 0xFF)
-	#define _SPEC_SIFS_OFDM(x)				(((x) & 0xFF) << 8)
+#define _SPEC_SIFS_CCK(x) ((x) & 0xFF)
+#define _SPEC_SIFS_OFDM(x) (((x) & 0xFF) << 8)
 
 	/* 2 RL 0x042A */
-	#define	RETRY_LIMIT_SHORT_SHIFT		8
-	#define	RETRY_LIMIT_LONG_SHIFT		0
+#define RETRY_LIMIT_SHORT_SHIFT 8
+#define RETRY_LIMIT_LONG_SHIFT 0
 
-	#define _LRL(x)							((x) & 0x3F)
-	#define _SRL(x)							(((x) & 0x3F) << 8)
+#define _LRL(x) ((x) & 0x3F)
+#define _SRL(x) (((x) & 0x3F) << 8)
 #endif
 
 /* -----------------------------------------------------
  *
  *	0x0500h ~ 0x05FFh	EDCA Configuration
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 #if 0
 	/* 2 EDCA setting 0x050C */
-	#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
+#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 BCN_CTRL 0x0550 */
-	#define EN_TXBCN_RPT						BIT(2)
-	#define EN_BCN_FUNCTION					BIT(3)
+#define EN_TXBCN_RPT BIT(2)
+#define EN_BCN_FUNCTION BIT(3)
 
 	/* 2 TxPause 0x0522 */
-	#define STOP_BCNQ						BIT(6)
+#define STOP_BCNQ BIT(6)
 #endif
 
-
 /* 2 ACMHWCTRL 0x05C0 */
-#define	acm_hw_hw_en_8723d				BIT(0)
-#define	acm_hw_voq_en_8723d				BIT(1)
-#define	acm_hw_viq_en_8723d				BIT(2)
-#define	acm_hw_beq_en_8723d				BIT(3)
-#define	acm_hw_voq_status_8723d			BIT(5)
-#define	acm_hw_viq_status_8723d			BIT(6)
-#define	acm_hw_beq_status_8723d			BIT(7)
-
-
+#define acm_hw_hw_en_8723d BIT(0)
+#define acm_hw_voq_en_8723d BIT(1)
+#define acm_hw_viq_en_8723d BIT(2)
+#define acm_hw_beq_en_8723d BIT(3)
+#define acm_hw_voq_status_8723d BIT(5)
+#define acm_hw_viq_status_8723d BIT(6)
+#define acm_hw_beq_status_8723d BIT(7)
 
 /* -----------------------------------------------------
  *
  *	0x0600h ~ 0x07FFh	WMAC Configuration
  *
- * ----------------------------------------------------- */
+ * -----------------------------------------------------
+ */
 #if 0
 
 	/* 2 TCR 0x0604 */
-	#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)
+#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)
 #endif
 
 /* ----------------------------------------------------------------------------
  * 8195 (RCR) Receive Configuration Register	(Offset 0x608, 32 bits)
- * ---------------------------------------------------------------------------- */
+ * ----------------------------------------------------------------------------
+ */
 #if 0
-	#define	RCR_APPFCS					BIT(31)		/*  WMAC append FCS after pauload */
-	#define	RCR_APP_MIC					BIT(30)		/*  MACRX will retain the MIC at the bottom of the packet. */
-	#define	RCR_APP_ICV					BIT(29)       /*  MACRX will retain the ICV at the bottom of the packet. */
-	#define	RCR_APP_PHYST_RXFF			BIT(28)       /*  HY status is appended before RX packet in RXFF */
-	#define	RCR_APP_BA_SSN				BIT(27)		/*  SSN of previous TXBA is appended as after original RXDESC as the 4-th DW of RXDESC. */
-	#define	RCR_RSVD_BIT(26)				BIT26		/*  Reserved */
+#define RCR_APPFCS BIT(31)		 /*  WMAC append FCS after pauload */
+#define RCR_APP_MIC BIT(30)		 /*  MACRX will retain the MIC at the bottom of the packet. */
+#define RCR_APP_ICV BIT(29)        /*  MACRX will retain the ICV at the bottom of the packet. */
+#define RCR_APP_PHYST_RXFF BIT(28)        /*  HY status is appended before RX packet in RXFF */
+#define RCR_APP_BA_SSN BIT(27)		 /*  SSN of previous TXBA is appended as after original RXDESC as the 4-th DW of RXDESC. */
+#define RCR_RSVD_BIT(26) BIT26		 /*  Reserved */
 #endif
-#define	RCR_TCPOFLD_EN				BIT(25)		/* Enable TCP checksum offload */
+#define RCR_TCPOFLD_EN BIT(25) /* Enable TCP checksum offload */
 #if 0
-	#define	RCR_ENMBID					BIT(24)		/*  Enable Multiple BssId. Only response ACK to the packets whose DID(A1) matching to the addresses in the MBSSID CAM Entries. */
-	#define	RCR_LSIGEN					BIT(23)		/*  Enable LSIG TXOP Protection function. Search KEYCAM for each rx packet to check if LSIGEN bit is set. */
-	#define	RCR_MFBEN					BIT(22)		/*  Enable immediate MCS Feedback function. When Rx packet with MRQ = 1'b1, then search KEYCAM to find sender's MCS Feedback function and send response. */
+#define RCR_ENMBID BIT(24)		 /*  Enable Multiple BssId. Only response ACK to the packets whose DID(A1) matching to the addresses in the MBSSID CAM Entries. */
+#define RCR_LSIGEN BIT(23)		 /*  Enable LSIG TXOP Protection function. Search KEYCAM for each rx packet to check if LSIGEN bit is set. */
+#define RCR_MFBEN BIT(22)		 /*  Enable immediate MCS Feedback function. When Rx packet with MRQ = 1'b1, then search KEYCAM to find sender's MCS Feedback function and send response. */
 #endif
 
-
 #endif /*  #ifndef __INC_HAL8723DREG_H */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.c
index 58b88f252f03..83ac7da91de5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -20,54 +21,58 @@
 #if (RTL8723D_SUPPORT == 1)
 static boolean
 check_positive(
-	struct PHY_DM_STRUCT *p_dm,
+	struct dm_struct *dm,
 	const u32	condition1,
 	const u32	condition2,
 	const u32	condition3,
 	const u32	condition4
 )
 {
-	u8	_board_type = ((p_dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
-			((p_dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
-			((p_dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
-			((p_dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
-			((p_dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
-			((p_dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
-			((p_dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
+	u8	_board_type = ((dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
+			((dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
+			((dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
+			((dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
+			((dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
+			((dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
+			((dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
 
 	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
 
-	u8	cut_version_for_para = (p_dm->cut_version ==  ODM_CUT_A) ? 15 : p_dm->cut_version;
-	u8	pkg_type_for_para = (p_dm->package_type == 0) ? 15 : p_dm->package_type;
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
 
 	u32	driver1 = cut_version_for_para << 24 |
-			(p_dm->support_interface & 0xF0) << 16 |
-			p_dm->support_platform << 16 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
 			pkg_type_for_para << 12 |
-			(p_dm->support_interface & 0x0F) << 8  |
+			(dm->support_interface & 0x0F) << 8  |
 			_board_type;
 
-	u32	driver2 = (p_dm->type_glna & 0xFF) <<  0 |
-			(p_dm->type_gpa & 0xFF)  <<  8 |
-			(p_dm->type_alna & 0xFF) << 16 |
-			(p_dm->type_apa & 0xFF)  << 24;
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
 
 	u32	driver3 = 0;
 
-	u32	driver4 = (p_dm->type_glna & 0xFF00) >>  8 |
-			(p_dm->type_gpa & 0xFF00) |
-			(p_dm->type_alna & 0xFF00) << 8 |
-			(p_dm->type_apa & 0xFF00)  << 16;
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> %s (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n",
+		  __func__, cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> %s (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n",
+		  __func__, driver1, driver2, driver3, driver4);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("	(Platform, Interface) = (0x%X, 0x%X)\n", p_dm->support_platform, p_dm->support_interface));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("	(Board, Package) = (0x%X, 0x%X)\n", p_dm->board_type, p_dm->package_type));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "	(Platform, Interface) = (0x%X, 0x%X)\n",
+		  dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "	(Board, Package) = (0x%X, 0x%X)\n", dm->board_type,
+		  dm->package_type);
 
 
 	/*============== value Defined Check ===============*/
@@ -108,7 +113,7 @@ check_positive(
 }
 static boolean
 check_negative(
-	struct PHY_DM_STRUCT *p_dm,
+	struct dm_struct *dm,
 	const u32	condition1,
 	const u32	condition2
 )
@@ -511,19 +516,17 @@ u32 array_mp_8723d_agc_tab[] = {
 };
 
 void
-odm_read_and_config_mp_8723d_agc_tab(
-	struct	PHY_DM_STRUCT *p_dm
-)
+odm_read_and_config_mp_8723d_agc_tab(struct dm_struct *dm)
 {
 	u32	i = 0;
 	u8	c_cond;
 	boolean	is_matched = true, is_skipped = false;
-	u32	array_len = sizeof(array_mp_8723d_agc_tab)/sizeof(u32);
+	u32	array_len = sizeof(array_mp_8723d_agc_tab) / sizeof(u32);
 	u32	*array = array_mp_8723d_agc_tab;
 
 	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_read_and_config_mp_8723d_agc_tab\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
 
 	while ((i + 1) < array_len) {
 		v1 = array[i];
@@ -531,22 +534,22 @@ odm_read_and_config_mp_8723d_agc_tab(
 
 		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
 			if (v1 & BIT(31)) {/* positive condition*/
-				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				c_cond  = (u8)((v1 & (BIT(29) | BIT(28))) >> 28);
 				if (c_cond == COND_ENDIF) {/*end*/
 					is_matched = true;
 					is_skipped = false;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ENDIF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
 				} else if (c_cond == COND_ELSE) { /*else*/
-					is_matched = is_skipped?false:true;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ELSE\n"));
+					is_matched = is_skipped ? false : true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
 				} else {/*if , else if*/
 					pre_v1 = v1;
 					pre_v2 = v2;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("IF or ELSE IF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
 				}
 			} else if (v1 & BIT(30)) { /*negative condition*/
 				if (is_skipped == false) {
-					if (check_positive(p_dm, pre_v1, pre_v2, v1, v2)) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
 						is_matched = true;
 						is_skipped = true;
 					} else {
@@ -558,7 +561,7 @@ odm_read_and_config_mp_8723d_agc_tab(
 			}
 		} else {
 			if (is_matched)
-				odm_config_bb_agc_8723d(p_dm, v1, MASKDWORD, v2);
+				odm_config_bb_agc_8723d(dm, v1, MASKDWORD, v2);
 		}
 		i = i + 2;
 	}
@@ -567,7 +570,7 @@ odm_read_and_config_mp_8723d_agc_tab(
 u32
 odm_get_version_mp_8723d_agc_tab(void)
 {
-		return 36;
+		return 37;
 }
 
 /******************************************************************************
@@ -802,19 +805,17 @@ u32 array_mp_8723d_phy_reg[] = {
 };
 
 void
-odm_read_and_config_mp_8723d_phy_reg(
-	struct	PHY_DM_STRUCT *p_dm
-)
+odm_read_and_config_mp_8723d_phy_reg(struct dm_struct *dm)
 {
 	u32	i = 0;
 	u8	c_cond;
 	boolean	is_matched = true, is_skipped = false;
-	u32	array_len = sizeof(array_mp_8723d_phy_reg)/sizeof(u32);
+	u32	array_len = sizeof(array_mp_8723d_phy_reg) / sizeof(u32);
 	u32	*array = array_mp_8723d_phy_reg;
 
 	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_read_and_config_mp_8723d_phy_reg\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
 
 	while ((i + 1) < array_len) {
 		v1 = array[i];
@@ -822,22 +823,22 @@ odm_read_and_config_mp_8723d_phy_reg(
 
 		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
 			if (v1 & BIT(31)) {/* positive condition*/
-				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				c_cond  = (u8)((v1 & (BIT(29) | BIT(28))) >> 28);
 				if (c_cond == COND_ENDIF) {/*end*/
 					is_matched = true;
 					is_skipped = false;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ENDIF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
 				} else if (c_cond == COND_ELSE) { /*else*/
-					is_matched = is_skipped?false:true;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ELSE\n"));
+					is_matched = is_skipped ? false : true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
 				} else {/*if , else if*/
 					pre_v1 = v1;
 					pre_v2 = v2;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("IF or ELSE IF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
 				}
 			} else if (v1 & BIT(30)) { /*negative condition*/
 				if (is_skipped == false) {
-					if (check_positive(p_dm, pre_v1, pre_v2, v1, v2)) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
 						is_matched = true;
 						is_skipped = true;
 					} else {
@@ -849,7 +850,7 @@ odm_read_and_config_mp_8723d_phy_reg(
 			}
 		} else {
 			if (is_matched)
-				odm_config_bb_phy_8723d(p_dm, v1, MASKDWORD, v2);
+				odm_config_bb_phy_8723d(dm, v1, MASKDWORD, v2);
 		}
 		i = i + 2;
 	}
@@ -858,7 +859,7 @@ odm_read_and_config_mp_8723d_phy_reg(
 u32
 odm_get_version_mp_8723d_phy_reg(void)
 {
-		return 36;
+		return 37;
 }
 
 /******************************************************************************
@@ -875,40 +876,38 @@ u32 array_mp_8723d_phy_reg_pg[] = {
 };
 
 void
-odm_read_and_config_mp_8723d_phy_reg_pg(
-	struct PHY_DM_STRUCT	*p_dm
-)
+odm_read_and_config_mp_8723d_phy_reg_pg(struct dm_struct *dm)
 {
 	u32	i = 0;
-	u32	array_len = sizeof(array_mp_8723d_phy_reg_pg)/sizeof(u32);
+	u32	array_len = sizeof(array_mp_8723d_phy_reg_pg) / sizeof(u32);
 	u32	*array = array_mp_8723d_phy_reg_pg;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER	*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 
-	PlatformZeroMemory(p_hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
-	p_hal_data->nLinesReadPwrByRate = array_len/6;
+	PlatformZeroMemory(hal_data->BufOfLinesPwrByRate, MAX_LINES_HWCONFIG_TXT * MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrByRate = array_len / 6;
 #endif
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_read_and_config_mp_8723d_phy_reg_pg\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
 
-	p_dm->phy_reg_pg_version = 1;
-	p_dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
+	dm->phy_reg_pg_version = 1;
+	dm->phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
 
 	for (i = 0; i < array_len; i += 6) {
 		u32	v1 = array[i];
-		u32	v2 = array[i+1];
-		u32	v3 = array[i+2];
-		u32	v4 = array[i+3];
-		u32	v5 = array[i+4];
-		u32	v6 = array[i+5];
+		u32	v2 = array[i + 1];
+		u32	v3 = array[i + 2];
+		u32	v4 = array[i + 3];
+		u32	v5 = array[i + 4];
+		u32	v6 = array[i + 5];
 
-		odm_config_bb_phy_reg_pg_8723d(p_dm, v1, v2, v3, v4, v5, v6);
+		odm_config_bb_phy_reg_pg_8723d(dm, v1, v2, v3, v4, v5, v6);
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	rsprintf((char *)p_hal_data->BufOfLinesPwrByRate[i/6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
-		(v1 == 0?"2.4G":"  5G"), (v2 == 0?"A":"B"), (v3 == 0?"1Tx":"2Tx"), v4, v5, v6);
+	rsprintf((char *)hal_data->BufOfLinesPwrByRate[i / 6], 100, "%s, %s, %s, 0x%X, 0x%08X, 0x%08X,",
+		(v1 == 0 ? "2.4G" : "  5G"), (v2 == 0 ? "A" : "B"), (v3 == 0 ? "1Tx" : "2Tx"), v4, v5, v6);
 #endif
 	}
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.h
index 44aea06f7c0c..2ee8f1d7370a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_bb.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -24,29 +25,26 @@
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_agc_tab(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
-u32	odm_get_version_mp_8723d_agc_tab(void);
+odm_read_and_config_mp_8723d_agc_tab( /* tc: Test Chip, mp: mp Chip*/
+				     struct dm_struct *dm);
+u32 odm_get_version_mp_8723d_agc_tab(void);
 
 /******************************************************************************
 *                           phy_reg.TXT
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_phy_reg(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
-u32	odm_get_version_mp_8723d_phy_reg(void);
+odm_read_and_config_mp_8723d_phy_reg( /* tc: Test Chip, mp: mp Chip*/
+				     struct dm_struct *dm);
+u32 odm_get_version_mp_8723d_phy_reg(void);
 
 /******************************************************************************
 *                           phy_reg_pg.TXT
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_phy_reg_pg(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
+odm_read_and_config_mp_8723d_phy_reg_pg( /* tc: Test Chip, mp: mp Chip*/
+					struct dm_struct *dm);
 u32	odm_get_version_mp_8723d_phy_reg_pg(void);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.c
index db42972ba955..4853fe82e9dd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -20,54 +21,58 @@
 #if (RTL8723D_SUPPORT == 1)
 static boolean
 check_positive(
-	struct PHY_DM_STRUCT *p_dm,
+	struct dm_struct *dm,
 	const u32	condition1,
 	const u32	condition2,
 	const u32	condition3,
 	const u32	condition4
 )
 {
-	u8	_board_type = ((p_dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
-			((p_dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
-			((p_dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
-			((p_dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
-			((p_dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
-			((p_dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
-			((p_dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
+	u8	_board_type = ((dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
+			((dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
+			((dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
+			((dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
+			((dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
+			((dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
+			((dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
 
 	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
 
-	u8	cut_version_for_para = (p_dm->cut_version ==  ODM_CUT_A) ? 15 : p_dm->cut_version;
-	u8	pkg_type_for_para = (p_dm->package_type == 0) ? 15 : p_dm->package_type;
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
 
 	u32	driver1 = cut_version_for_para << 24 |
-			(p_dm->support_interface & 0xF0) << 16 |
-			p_dm->support_platform << 16 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
 			pkg_type_for_para << 12 |
-			(p_dm->support_interface & 0x0F) << 8  |
+			(dm->support_interface & 0x0F) << 8  |
 			_board_type;
 
-	u32	driver2 = (p_dm->type_glna & 0xFF) <<  0 |
-			(p_dm->type_gpa & 0xFF)  <<  8 |
-			(p_dm->type_alna & 0xFF) << 16 |
-			(p_dm->type_apa & 0xFF)  << 24;
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
 
 	u32	driver3 = 0;
 
-	u32	driver4 = (p_dm->type_glna & 0xFF00) >>  8 |
-			(p_dm->type_gpa & 0xFF00) |
-			(p_dm->type_alna & 0xFF00) << 8 |
-			(p_dm->type_apa & 0xFF00)  << 16;
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> %s (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n",
+		  __func__, cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> %s (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n",
+		  __func__, driver1, driver2, driver3, driver4);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("	(Platform, Interface) = (0x%X, 0x%X)\n", p_dm->support_platform, p_dm->support_interface));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("	(Board, Package) = (0x%X, 0x%X)\n", p_dm->board_type, p_dm->package_type));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "	(Platform, Interface) = (0x%X, 0x%X)\n",
+		  dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "	(Board, Package) = (0x%X, 0x%X)\n", dm->board_type,
+		  dm->package_type);
 
 
 	/*============== value Defined Check ===============*/
@@ -108,7 +113,7 @@ check_positive(
 }
 static boolean
 check_negative(
-	struct PHY_DM_STRUCT *p_dm,
+	struct dm_struct *dm,
 	const u32	condition1,
 	const u32	condition2
 )
@@ -238,19 +243,17 @@ u32 array_mp_8723d_mac_reg[] = {
 };
 
 void
-odm_read_and_config_mp_8723d_mac_reg(
-	struct	PHY_DM_STRUCT *p_dm
-)
+odm_read_and_config_mp_8723d_mac_reg(struct dm_struct *dm)
 {
 	u32	i = 0;
 	u8	c_cond;
 	boolean	is_matched = true, is_skipped = false;
-	u32	array_len = sizeof(array_mp_8723d_mac_reg)/sizeof(u32);
+	u32	array_len = sizeof(array_mp_8723d_mac_reg) / sizeof(u32);
 	u32	*array = array_mp_8723d_mac_reg;
 
 	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_read_and_config_mp_8723d_mac_reg\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
 
 	while ((i + 1) < array_len) {
 		v1 = array[i];
@@ -258,22 +261,22 @@ odm_read_and_config_mp_8723d_mac_reg(
 
 		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
 			if (v1 & BIT(31)) {/* positive condition*/
-				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				c_cond  = (u8)((v1 & (BIT(29) | BIT(28))) >> 28);
 				if (c_cond == COND_ENDIF) {/*end*/
 					is_matched = true;
 					is_skipped = false;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ENDIF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
 				} else if (c_cond == COND_ELSE) { /*else*/
-					is_matched = is_skipped?false:true;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ELSE\n"));
+					is_matched = is_skipped ? false : true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
 				} else {/*if , else if*/
 					pre_v1 = v1;
 					pre_v2 = v2;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("IF or ELSE IF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
 				}
 			} else if (v1 & BIT(30)) { /*negative condition*/
 				if (is_skipped == false) {
-					if (check_positive(p_dm, pre_v1, pre_v2, v1, v2)) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
 						is_matched = true;
 						is_skipped = true;
 					} else {
@@ -285,7 +288,7 @@ odm_read_and_config_mp_8723d_mac_reg(
 			}
 		} else {
 			if (is_matched)
-				odm_config_mac_8723d(p_dm, v1, (u8)v2);
+				odm_config_mac_8723d(dm, v1, (u8)v2);
 		}
 		i = i + 2;
 	}
@@ -294,7 +297,7 @@ odm_read_and_config_mp_8723d_mac_reg(
 u32
 odm_get_version_mp_8723d_mac_reg(void)
 {
-		return 36;
+		return 37;
 }
 
 #endif /* end of HWIMG_SUPPORT*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.h
index 99236a7c8994..eae2f9088859 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_mac.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -24,10 +25,9 @@
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_mac_reg(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
-u32	odm_get_version_mp_8723d_mac_reg(void);
+odm_read_and_config_mp_8723d_mac_reg( /* tc: Test Chip, mp: mp Chip*/
+				     struct dm_struct *dm);
+u32 odm_get_version_mp_8723d_mac_reg(void);
 
 #endif
 #endif /* end of HWIMG_SUPPORT*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.c
index 34f53978db85..8f237acf29e4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -20,54 +21,58 @@
 #if (RTL8723D_SUPPORT == 1)
 static boolean
 check_positive(
-	struct PHY_DM_STRUCT *p_dm,
+	struct dm_struct *dm,
 	const u32	condition1,
 	const u32	condition2,
 	const u32	condition3,
 	const u32	condition4
 )
 {
-	u8	_board_type = ((p_dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
-			((p_dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
-			((p_dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
-			((p_dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
-			((p_dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
-			((p_dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
-			((p_dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
+	u8	_board_type = ((dm->board_type & BIT(4)) >> 4) << 0 | /* _GLNA*/
+			((dm->board_type & BIT(3)) >> 3) << 1 | /* _GPA*/
+			((dm->board_type & BIT(7)) >> 7) << 2 | /* _ALNA*/
+			((dm->board_type & BIT(6)) >> 6) << 3 | /* _APA */
+			((dm->board_type & BIT(2)) >> 2) << 4 | /* _BT*/
+			((dm->board_type & BIT(1)) >> 1) << 5 | /* _NGFF*/
+			((dm->board_type & BIT(5)) >> 5) << 6;  /* _TRSWT*/
 
 	u32	cond1 = condition1, cond2 = condition2, cond3 = condition3, cond4 = condition4;
 
-	u8	cut_version_for_para = (p_dm->cut_version ==  ODM_CUT_A) ? 15 : p_dm->cut_version;
-	u8	pkg_type_for_para = (p_dm->package_type == 0) ? 15 : p_dm->package_type;
+	u8	cut_version_for_para = (dm->cut_version ==  ODM_CUT_A) ? 15 : dm->cut_version;
+	u8	pkg_type_for_para = (dm->package_type == 0) ? 15 : dm->package_type;
 
 	u32	driver1 = cut_version_for_para << 24 |
-			(p_dm->support_interface & 0xF0) << 16 |
-			p_dm->support_platform << 16 |
+			(dm->support_interface & 0xF0) << 16 |
+			dm->support_platform << 16 |
 			pkg_type_for_para << 12 |
-			(p_dm->support_interface & 0x0F) << 8  |
+			(dm->support_interface & 0x0F) << 8  |
 			_board_type;
 
-	u32	driver2 = (p_dm->type_glna & 0xFF) <<  0 |
-			(p_dm->type_gpa & 0xFF)  <<  8 |
-			(p_dm->type_alna & 0xFF) << 16 |
-			(p_dm->type_apa & 0xFF)  << 24;
+	u32	driver2 = (dm->type_glna & 0xFF) <<  0 |
+			(dm->type_gpa & 0xFF)  <<  8 |
+			(dm->type_alna & 0xFF) << 16 |
+			(dm->type_apa & 0xFF)  << 24;
 
 	u32	driver3 = 0;
 
-	u32	driver4 = (p_dm->type_glna & 0xFF00) >>  8 |
-			(p_dm->type_gpa & 0xFF00) |
-			(p_dm->type_alna & 0xFF00) << 8 |
-			(p_dm->type_apa & 0xFF00)  << 16;
+	u32	driver4 = (dm->type_glna & 0xFF00) >>  8 |
+			(dm->type_gpa & 0xFF00) |
+			(dm->type_alna & 0xFF00) << 8 |
+			(dm->type_apa & 0xFF00)  << 16;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("===> check_positive (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n", cond1, cond2, cond3, cond4));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("===> check_positive (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n", driver1, driver2, driver3, driver4));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> %s (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n",
+		  __func__, cond1, cond2, cond3, cond4);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> %s (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n",
+		  __func__, driver1, driver2, driver3, driver4);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("	(Platform, Interface) = (0x%X, 0x%X)\n", p_dm->support_platform, p_dm->support_interface));
-	PHYDM_DBG(p_dm, ODM_COMP_INIT,
-	("	(Board, Package) = (0x%X, 0x%X)\n", p_dm->board_type, p_dm->package_type));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "	(Platform, Interface) = (0x%X, 0x%X)\n",
+		  dm->support_platform, dm->support_interface);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "	(Board, Package) = (0x%X, 0x%X)\n", dm->board_type,
+		  dm->package_type);
 
 
 	/*============== value Defined Check ===============*/
@@ -108,7 +113,7 @@ check_positive(
 }
 static boolean
 check_negative(
-	struct PHY_DM_STRUCT *p_dm,
+	struct dm_struct *dm,
 	const u32	condition1,
 	const u32	condition2
 )
@@ -121,7 +126,7 @@ check_negative(
 ******************************************************************************/
 
 u32 array_mp_8723d_radioa[] = {
-		0x050, 0x0001B000,
+		0x050, 0x0001C000,
 		0x049, 0x0004AA00,
 		0x000, 0x00010000,
 		0x0B1, 0x00054573,
@@ -146,13 +151,13 @@ u32 array_mp_8723d_radioa[] = {
 		0x092, 0x00082AAC,
 		0x0EF, 0x00000400,
 		0x030, 0x000008CA,
-		0x030, 0x000018CF,
+		0x030, 0x000018CA,
 		0x030, 0x000028CA,
 		0x030, 0x000038CA,
 		0x0EF, 0x00000000,
 		0x0EE, 0x00000400,
 		0x030, 0x000008CA,
-		0x030, 0x000018CF,
+		0x030, 0x000018CA,
 		0x030, 0x000028CA,
 		0x030, 0x000038CA,
 		0x0EE, 0x00000000,
@@ -304,19 +309,17 @@ u32 array_mp_8723d_radioa[] = {
 };
 
 void
-odm_read_and_config_mp_8723d_radioa(
-	struct	PHY_DM_STRUCT *p_dm
-)
+odm_read_and_config_mp_8723d_radioa(struct dm_struct *dm)
 {
 	u32	i = 0;
 	u8	c_cond;
 	boolean	is_matched = true, is_skipped = false;
-	u32	array_len = sizeof(array_mp_8723d_radioa)/sizeof(u32);
+	u32	array_len = sizeof(array_mp_8723d_radioa) / sizeof(u32);
 	u32	*array = array_mp_8723d_radioa;
 
 	u32	v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_read_and_config_mp_8723d_radioa\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
 
 	while ((i + 1) < array_len) {
 		v1 = array[i];
@@ -324,22 +327,22 @@ odm_read_and_config_mp_8723d_radioa(
 
 		if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
 			if (v1 & BIT(31)) {/* positive condition*/
-				c_cond  = (u8)((v1 & (BIT(29)|BIT(28))) >> 28);
+				c_cond  = (u8)((v1 & (BIT(29) | BIT(28))) >> 28);
 				if (c_cond == COND_ENDIF) {/*end*/
 					is_matched = true;
 					is_skipped = false;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ENDIF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
 				} else if (c_cond == COND_ELSE) { /*else*/
-					is_matched = is_skipped?false:true;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("ELSE\n"));
+					is_matched = is_skipped ? false : true;
+					PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
 				} else {/*if , else if*/
 					pre_v1 = v1;
 					pre_v2 = v2;
-					PHYDM_DBG(p_dm, ODM_COMP_INIT, ("IF or ELSE IF\n"));
+					PHYDM_DBG(dm, ODM_COMP_INIT, "IF or ELSE IF\n");
 				}
 			} else if (v1 & BIT(30)) { /*negative condition*/
 				if (is_skipped == false) {
-					if (check_positive(p_dm, pre_v1, pre_v2, v1, v2)) {
+					if (check_positive(dm, pre_v1, pre_v2, v1, v2)) {
 						is_matched = true;
 						is_skipped = true;
 					} else {
@@ -351,7 +354,7 @@ odm_read_and_config_mp_8723d_radioa(
 			}
 		} else {
 			if (is_matched)
-				odm_config_rf_radio_a_8723d(p_dm, v1, v2);
+				odm_config_rf_radio_a_8723d(dm, v1, v2);
 		}
 		i = i + 2;
 	}
@@ -360,7 +363,7 @@ odm_read_and_config_mp_8723d_radioa(
 u32
 odm_get_version_mp_8723d_radioa(void)
 {
-		return 36;
+		return 37;
 }
 
 /******************************************************************************
@@ -399,30 +402,28 @@ u8 g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_pcie_8723d[] = {0, 0, 1, 1
 #endif
 
 void
-odm_read_and_config_mp_8723d_txpowertrack_pcie(
-	struct PHY_DM_STRUCT	 *p_dm
-)
+odm_read_and_config_mp_8723d_txpowertrack_pcie(struct dm_struct *dm)
 {
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	struct odm_rf_calibration_structure  *p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_rf_calibration_struct  *cali_info = &(dm->rf_calibrate_info);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> ODM_ReadAndConfig_MP_mp_8723d\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8723d\n");
 
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE);
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_pcie_8723d, DELTA_SWINGIDX_SIZE * 3);
 #endif
 }
 
@@ -462,30 +463,28 @@ u8 g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_sdio_8723d[] = {0, 0, 1, 1
 #endif
 
 void
-odm_read_and_config_mp_8723d_txpowertrack_sdio(
-	struct PHY_DM_STRUCT	 *p_dm
-)
+odm_read_and_config_mp_8723d_txpowertrack_sdio(struct dm_struct *dm)
 {
 #if DEV_BUS_TYPE == RT_SDIO_INTERFACE
-	struct odm_rf_calibration_structure  *p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_rf_calibration_struct  *cali_info = &(dm->rf_calibrate_info);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> ODM_ReadAndConfig_MP_mp_8723d\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8723d\n");
 
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE);
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_sdio_8723d, DELTA_SWINGIDX_SIZE * 3);
 #endif
 }
 
@@ -525,30 +524,28 @@ u8 g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_usb_8723d[] = {0, 0, 1, 1,
 #endif
 
 void
-odm_read_and_config_mp_8723d_txpowertrack_usb(
-	struct PHY_DM_STRUCT	 *p_dm
-)
+odm_read_and_config_mp_8723d_txpowertrack_usb(struct dm_struct *dm)
 {
 #if DEV_BUS_TYPE == RT_USB_INTERFACE
-	struct odm_rf_calibration_structure  *p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_rf_calibration_struct  *cali_info = &(dm->rf_calibrate_info);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> ODM_ReadAndConfig_MP_mp_8723d\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8723d\n");
 
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p, g_delta_swing_table_idx_mp_2ga_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n, g_delta_swing_table_idx_mp_2ga_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p, g_delta_swing_table_idx_mp_2gb_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n, g_delta_swing_table_idx_mp_2gb_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p, g_delta_swing_table_idx_mp_2g_cck_a_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n, g_delta_swing_table_idx_mp_2g_cck_a_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p, g_delta_swing_table_idx_mp_2g_cck_b_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n, g_delta_swing_table_idx_mp_2g_cck_b_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE);
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE*3);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE*3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p, g_delta_swing_table_idx_mp_5ga_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n, g_delta_swing_table_idx_mp_5ga_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p, g_delta_swing_table_idx_mp_5gb_p_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE * 3);
+	odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n, g_delta_swing_table_idx_mp_5gb_n_txpowertrack_usb_8723d, DELTA_SWINGIDX_SIZE * 3);
 #endif
 }
 
@@ -1124,55 +1121,52 @@ const char *array_mp_8723d_txpwr_lmt[] = {
 };
 
 void
-odm_read_and_config_mp_8723d_txpwr_lmt(
-	struct PHY_DM_STRUCT	*p_dm
-)
+odm_read_and_config_mp_8723d_txpwr_lmt(struct dm_struct *dm)
 {
 	u32	i = 0;
 #if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
-	u32	array_len = sizeof(array_mp_8723d_txpwr_lmt)/sizeof(u8);
+	u32	array_len = sizeof(array_mp_8723d_txpwr_lmt) / sizeof(u8);
 	u8	*array = (u8 *)array_mp_8723d_txpwr_lmt;
 #else
-	u32	array_len = sizeof(array_mp_8723d_txpwr_lmt)/sizeof(u8 *);
+	u32	array_len = sizeof(array_mp_8723d_txpwr_lmt) / sizeof(u8 *);
 	u8	**array = (u8 **)array_mp_8723d_txpwr_lmt;
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER	*adapter = p_dm->adapter;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
+	void	*adapter = dm->adapter;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(((PADAPTER)adapter));
 
-	PlatformZeroMemory(p_hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT*MAX_BYTES_LINE_HWCONFIG_TXT);
-	p_hal_data->nLinesReadPwrLmt = array_len/7;
+	PlatformZeroMemory(hal_data->BufOfLinesPwrLmt, MAX_LINES_HWCONFIG_TXT * MAX_BYTES_LINE_HWCONFIG_TXT);
+	hal_data->nLinesReadPwrLmt = array_len / 7;
 #endif
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_read_and_config_mp_8723d_txpwr_lmt\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
 
 	for (i = 0; i < array_len; i += 7) {
 #if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
 		u8	regulation = array[i];
-		u8	band = array[i+1];
-		u8	bandwidth = array[i+2];
-		u8	rate = array[i+3];
-		u8	rf_path = array[i+4];
-		u8	chnl = array[i+5];
-		u8	val = array[i+6];
+		u8	band = array[i + 1];
+		u8	bandwidth = array[i + 2];
+		u8	rate = array[i + 3];
+		u8	rf_path = array[i + 4];
+		u8	chnl = array[i + 5];
+		u8	val = array[i + 6];
 #else
 		u8	*regulation = array[i];
-		u8	*band = array[i+1];
-		u8	*bandwidth = array[i+2];
-		u8	*rate = array[i+3];
-		u8	*rf_path = array[i+4];
-		u8	*chnl = array[i+5];
-		u8	*val = array[i+6];
+		u8	*band = array[i + 1];
+		u8	*bandwidth = array[i + 2];
+		u8	*rate = array[i + 3];
+		u8	*rf_path = array[i + 4];
+		u8	*chnl = array[i + 5];
+		u8	*val = array[i + 6];
 #endif
 
-		odm_config_bb_txpwr_lmt_8723d(p_dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
+		odm_config_bb_txpwr_lmt_8723d(dm, regulation, band, bandwidth, rate, rf_path, chnl, val);
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-		rsprintf((char *)p_hal_data->BufOfLinesPwrLmt[i/7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
+		rsprintf((char *)hal_data->BufOfLinesPwrLmt[i / 7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
 		regulation, band, bandwidth, rate, rf_path, chnl, val);
 #endif
 	}
-
 }
 
 /******************************************************************************
@@ -1183,17 +1177,15 @@ s8 g_delta_swing_table_xtal_mp_n_txxtaltrack_8723d[]    = {0, 0, 0, 0, 0, 0, 0,
 s8 g_delta_swing_table_xtal_mp_p_txxtaltrack_8723d[]    = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -10, -12, -14, -16, -16, -16, -16, -16, -16, -16, -16, -16, -16, -16};
 
 void
-odm_read_and_config_mp_8723d_txxtaltrack(
-	struct	PHY_DM_STRUCT *p_dm
-)
+odm_read_and_config_mp_8723d_txxtaltrack(struct dm_struct *dm)
 {
-	struct odm_rf_calibration_structure	*p_rf_calibrate_info = &(p_dm->rf_calibrate_info);
+	struct dm_rf_calibration_struct	*cali_info = &(dm->rf_calibrate_info);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> ODM_ReadAndConfig_MP_mp_8723d\n"));
+	PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8723d\n");
 
 
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_xtal_p, g_delta_swing_table_xtal_mp_p_txxtaltrack_8723d, DELTA_SWINGIDX_SIZE);
-	odm_move_memory(p_dm, p_rf_calibrate_info->delta_swing_table_xtal_n, g_delta_swing_table_xtal_mp_n_txxtaltrack_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_xtal_p, g_delta_swing_table_xtal_mp_p_txxtaltrack_8723d, DELTA_SWINGIDX_SIZE);
+	odm_move_memory(dm, cali_info->delta_swing_table_xtal_n, g_delta_swing_table_xtal_mp_n_txxtaltrack_8723d, DELTA_SWINGIDX_SIZE);
 }
 
 #endif /* end of HWIMG_SUPPORT*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.h
index b97529bde8f8..022ab8a11759 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/halhwimg8723d_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -24,19 +25,17 @@
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_radioa(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
-u32	odm_get_version_mp_8723d_radioa(void);
+odm_read_and_config_mp_8723d_radioa( /* tc: Test Chip, mp: mp Chip*/
+				    struct dm_struct *dm);
+u32 odm_get_version_mp_8723d_radioa(void);
 
 /******************************************************************************
 *                           txpowertrack_pcie.TXT
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_txpowertrack_pcie(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
+odm_read_and_config_mp_8723d_txpowertrack_pcie( /* tc: Test Chip, mp: mp Chip*/
+					       struct dm_struct *dm);
 u32	odm_get_version_mp_8723d_txpowertrack_pcie(void);
 
 /******************************************************************************
@@ -44,9 +43,8 @@ u32	odm_get_version_mp_8723d_txpowertrack_pcie(void);
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_txpowertrack_sdio(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
+odm_read_and_config_mp_8723d_txpowertrack_sdio( /* tc: Test Chip, mp: mp Chip*/
+					       struct dm_struct *dm);
 u32	odm_get_version_mp_8723d_txpowertrack_sdio(void);
 
 /******************************************************************************
@@ -54,9 +52,8 @@ u32	odm_get_version_mp_8723d_txpowertrack_sdio(void);
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_txpowertrack_usb(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
+odm_read_and_config_mp_8723d_txpowertrack_usb( /* tc: Test Chip, mp: mp Chip*/
+					      struct dm_struct *dm);
 u32	odm_get_version_mp_8723d_txpowertrack_usb(void);
 
 /******************************************************************************
@@ -64,9 +61,8 @@ u32	odm_get_version_mp_8723d_txpowertrack_usb(void);
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_txpwr_lmt(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
+odm_read_and_config_mp_8723d_txpwr_lmt( /* tc: Test Chip, mp: mp Chip*/
+				       struct dm_struct *dm);
 u32	odm_get_version_mp_8723d_txpwr_lmt(void);
 
 /******************************************************************************
@@ -74,9 +70,8 @@ u32	odm_get_version_mp_8723d_txpwr_lmt(void);
 ******************************************************************************/
 
 void
-odm_read_and_config_mp_8723d_txxtaltrack(/* tc: Test Chip, mp: mp Chip*/
-	struct	PHY_DM_STRUCT *p_dm
-);
+odm_read_and_config_mp_8723d_txxtaltrack( /* tc: Test Chip, mp: mp Chip*/
+					 struct dm_struct *dm);
 u32	odm_get_version_mp_8723d_txxtaltrack(void);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.c
index 0587e60feffe..ecbf382b7c1b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -18,14 +19,8 @@
 
 #if (RTL8723D_SUPPORT == 1)
 
-void
-odm_config_rf_reg_8723d(
-	struct PHY_DM_STRUCT				*p_dm,
-	u32					addr,
-	u32					data,
-	enum rf_path     RF_PATH,
-	u32				    reg_addr
-)
+void odm_config_rf_reg_8723d(struct dm_struct *dm, u32 addr, u32 data,
+			     enum rf_path RF_PATH, u32 reg_addr)
 {
 	if (addr == 0xfe || addr == 0xffe) {
 #ifdef CONFIG_LONG_DELAY_ISSUE
@@ -34,80 +29,58 @@ odm_config_rf_reg_8723d(
 		ODM_delay_ms(50);
 #endif
 	} else {
-		odm_set_rf_reg(p_dm, RF_PATH, reg_addr, RFREGOFFSETMASK, data);
+		odm_set_rf_reg(dm, RF_PATH, reg_addr, RFREGOFFSETMASK, data);
 		/* Add 1us delay between BB/RF register setting. */
 		ODM_delay_us(1);
 	}
 }
 
-
-void
-odm_config_rf_radio_a_8723d(
-	struct PHY_DM_STRUCT				*p_dm,
-	u32					addr,
-	u32					data
-)
+void odm_config_rf_radio_a_8723d(struct dm_struct *dm, u32 addr, u32 data)
 {
-	u32  content = 0x1000; /* RF_Content: radioa_txt */
-	u32	maskfor_phy_set = (u32)(content & 0xE000);
+	u32 content = 0x1000; /* RF_Content: radioa_txt */
+	u32 maskfor_phy_set = (u32)(content & 0xE000);
 
-	odm_config_rf_reg_8723d(p_dm, addr, data, RF_PATH_A, addr | maskfor_phy_set);
+	odm_config_rf_reg_8723d(dm, addr, data, RF_PATH_A, addr | maskfor_phy_set);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_config_rf_with_header_file: [RadioA] %08X %08X\n", addr, data));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> odm_config_rf_with_header_file: [RadioA] %08X %08X\n",
+		  addr, data);
 }
 
-void
-odm_config_rf_radio_b_8723d(
-	struct PHY_DM_STRUCT				*p_dm,
-	u32					addr,
-	u32					data
-)
+void odm_config_rf_radio_b_8723d(struct dm_struct *dm, u32 addr, u32 data)
 {
-	u32  content = 0x1001; /* RF_Content: radiob_txt */
-	u32	maskfor_phy_set = (u32)(content & 0xE000);
-
-	odm_config_rf_reg_8723d(p_dm, addr, data, RF_PATH_B, addr | maskfor_phy_set);
+	u32 content = 0x1001; /* RF_Content: radiob_txt */
+	u32 maskfor_phy_set = (u32)(content & 0xE000);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_config_rf_with_header_file: [RadioB] %08X %08X\n", addr, data));
+	odm_config_rf_reg_8723d(dm, addr, data, RF_PATH_B, addr | maskfor_phy_set);
 
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> odm_config_rf_with_header_file: [RadioB] %08X %08X\n",
+		  addr, data);
 }
 
-void
-odm_config_mac_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		addr,
-	u8		data
-)
+void odm_config_mac_8723d(struct dm_struct *dm, u32 addr, u8 data)
 {
-	odm_write_1byte(p_dm, addr, data);
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_config_mac_with_header_file: [MAC_REG] %08X %08X\n", addr, data));
+	odm_write_1byte(dm, addr, data);
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> odm_config_mac_with_header_file: [MAC_REG] %08X %08X\n",
+		  addr, data);
 }
 
-void
-odm_config_bb_agc_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		addr,
-	u32		bitmask,
-	u32		data
-)
+void odm_config_bb_agc_8723d(struct dm_struct *dm, u32 addr, u32 bitmask,
+			     u32 data)
 {
-	odm_set_bb_reg(p_dm, addr, bitmask, data);
+	odm_set_bb_reg(dm, addr, bitmask, data);
 	/* Add 1us delay between BB/RF register setting. */
 	ODM_delay_us(1);
 
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_config_bb_with_header_file: [AGC_TAB] %08X %08X\n", addr, data));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> odm_config_bb_with_header_file: [AGC_TAB] %08X %08X\n",
+		  addr, data);
 }
 
-void
-odm_config_bb_phy_reg_pg_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		band,
-	u32		rf_path,
-	u32		tx_num,
-	u32		addr,
-	u32		bitmask,
-	u32		data
-)
+void odm_config_bb_phy_reg_pg_8723d(struct dm_struct *dm, u32 band, u32 rf_path,
+				    u32 tx_num, u32 addr, u32 bitmask, u32 data)
 {
 	if (addr == 0xfe || addr == 0xffe)
 #ifdef CONFIG_LONG_DELAY_ISSUE
@@ -115,23 +88,20 @@ odm_config_bb_phy_reg_pg_8723d(
 #else
 		ODM_delay_ms(50);
 #endif
-	else {
 #if (DM_ODM_SUPPORT_TYPE & ODM_CE)
-		phy_store_tx_power_by_rate(p_dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
+	else
+		phy_store_tx_power_by_rate(dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-		PHY_StoreTxPowerByRate(p_dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
+	else
+		PHY_StoreTxPowerByRate(dm->adapter, band, rf_path, tx_num, addr, bitmask, data);
 #endif
-	}
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_config_bb_with_header_file: [PHY_REG] %08X %08X %08X\n", addr, bitmask, data));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> odm_config_bb_with_header_file: [PHY_REG] %08X %08X %08X\n",
+		  addr, bitmask, data);
 }
 
-void
-odm_config_bb_phy_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		addr,
-	u32		bitmask,
-	u32		data
-)
+void odm_config_bb_phy_8723d(struct dm_struct *dm, u32 addr, u32 bitmask,
+			     u32 data)
 {
 	/*dbg_print("odm_config_bb_phy_8723d(), addr = 0x%x, data = 0x%x\n", addr, data);*/
 	if (addr == 0xfe)
@@ -151,31 +121,25 @@ odm_config_bb_phy_8723d(
 	else if (addr == 0xf9)
 		ODM_delay_us(1);
 	else
-		odm_set_bb_reg(p_dm, addr, bitmask, data);
+		odm_set_bb_reg(dm, addr, bitmask, data);
 
 	/* Add 1us delay between BB/RF register setting. */
 	ODM_delay_us(1);
-	PHYDM_DBG(p_dm, ODM_COMP_INIT, ("===> odm_config_bb_with_header_file: [PHY_REG] %08X %08X\n", addr, data));
+	PHYDM_DBG(dm, ODM_COMP_INIT,
+		  "===> odm_config_bb_with_header_file: [PHY_REG] %08X %08X\n",
+		  addr, data);
 }
 
-void
-odm_config_bb_txpwr_lmt_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8		*regulation,
-	u8		*band,
-	u8		*bandwidth,
-	u8		*rate_section,
-	u8		*rf_path,
-	u8	*channel,
-	u8		*power_limit
-)
+void odm_config_bb_txpwr_lmt_8723d(struct dm_struct *dm, u8 *regulation,
+				   u8 *band, u8 *bandwidth, u8 *rate_section,
+				   u8 *rf_path, u8 *channel, u8 *power_limit)
 {
 #if (DM_ODM_SUPPORT_TYPE & ODM_CE)
-	phy_set_tx_power_limit(p_dm, regulation, band,
-		       bandwidth, rate_section, rf_path, channel, power_limit);
+	phy_set_tx_power_limit(dm, regulation, band,
+			       bandwidth, rate_section, rf_path, channel, power_limit);
 #elif (DM_ODM_SUPPORT_TYPE & ODM_WIN)
-	PHY_SetTxPowerLimit(p_dm, regulation, band,
-		       bandwidth, rate_section, rf_path, channel, power_limit);
+	PHY_SetTxPowerLimit(dm, regulation, band,
+			    bandwidth, rate_section, rf_path, channel, power_limit);
 #endif
 }
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.h
index a0874c4f1c44..719852f7ea85 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_regconfig8723d.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -17,75 +18,28 @@
 
 #if (RTL8723D_SUPPORT == 1)
 
-void
-odm_config_rf_reg_8723d(
-	struct PHY_DM_STRUCT				*p_dm,
-	u32					addr,
-	u32					data,
-	enum rf_path     RF_PATH,
-	u32				    reg_addr
-);
+void odm_config_rf_reg_8723d(struct dm_struct *dm, u32 addr, u32 data,
+			     enum rf_path RF_PATH, u32 reg_addr);
 
-void
-odm_config_rf_radio_a_8723d(
-	struct PHY_DM_STRUCT				*p_dm,
-	u32					addr,
-	u32					data
-);
+void odm_config_rf_radio_a_8723d(struct dm_struct *dm, u32 addr, u32 data);
 
-void
-odm_config_rf_radio_b_8723d(
-	struct PHY_DM_STRUCT				*p_dm,
-	u32					addr,
-	u32					data
-);
+void odm_config_rf_radio_b_8723d(struct dm_struct *dm, u32 addr, u32 data);
 
-void
-odm_config_mac_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		addr,
-	u8		data
-);
+void odm_config_mac_8723d(struct dm_struct *dm, u32 addr, u8 data);
 
-void
-odm_config_bb_agc_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		addr,
-	u32		bitmask,
-	u32		data
-);
+void odm_config_bb_agc_8723d(struct dm_struct *dm, u32 addr, u32 bitmask,
+			     u32 data);
 
-void
-odm_config_bb_phy_reg_pg_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		band,
-	u32		rf_path,
-	u32		tx_num,
-	u32		addr,
-	u32		bitmask,
-	u32		data
-);
+void odm_config_bb_phy_reg_pg_8723d(struct dm_struct *dm, u32 band, u32 rf_path,
+				    u32 tx_num, u32 addr, u32 bitmask,
+				    u32 data);
 
-void
-odm_config_bb_phy_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u32		addr,
-	u32		bitmask,
-	u32		data
-);
-
-void
-odm_config_bb_txpwr_lmt_8723d(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8	*regulation,
-	u8	*band,
-	u8	*bandwidth,
-	u8	*rate_section,
-	u8	*rf_path,
-	u8	*channel,
-	u8	*power_limit
-);
+void odm_config_bb_phy_8723d(struct dm_struct *dm, u32 addr, u32 bitmask,
+			     u32 data);
 
+void odm_config_bb_txpwr_lmt_8723d(struct dm_struct *dm, u8 *regulation,
+				   u8 *band, u8 *bandwidth, u8 *rate_section,
+				   u8 *rf_path, u8 *channel, u8 *power_limit);
 
 #endif
 #endif /* end of SUPPORT */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.c
index fc4e42eaab9b..cd511f6b981c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -13,25 +14,21 @@
  *
  *****************************************************************************/
 
-/*============================================================
- include files
-============================================================*/
+/* ============================================================
+ *  include files
+ * ============================================================
+ */
 
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
 #if (RTL8723D_SUPPORT == 1)
 
-s8
-odm_cckrssi_8723d(
-	u8	lna_idx,
-	u8	vga_idx
-)
+s8 phydm_cckrssi_8723d(struct dm_struct *dm, u8 lna_idx, u8 vga_idx)
 {
-	s8	rx_pwr_all = 0x00;
+	s8 rx_pwr_all = 0x00;
 
 	switch (lna_idx) {
-
 	case 0xf:
 		rx_pwr_all = -46 - (2 * vga_idx);
 		break;
@@ -49,7 +46,6 @@ odm_cckrssi_8723d(
 	}
 
 	return rx_pwr_all;
-
 }
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.h
index 6c8eeddd881b..4c484451b8c9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/phydm_rtl8723d.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -12,16 +13,12 @@
  * more details.
  *
  *****************************************************************************/
-#ifndef	__ODM_RTL8723D_H__
+#ifndef __ODM_RTL8723D_H__
 #define __ODM_RTL8723D_H__
 
 #if (RTL8723D_SUPPORT == 1)
 
-s8
-odm_cckrssi_8723d(
-	u8	lna_idx,
-	u8	vga_idx
-);
+s8 phydm_cckrssi_8723d(struct dm_struct *dm, u8 lna_idx, u8 vga_idx);
 
 #endif
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/version_rtl8723d.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/version_rtl8723d.h
index bde7025c93bc..e7b42e454265 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/version_rtl8723d.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/rtl8723d/version_rtl8723d.h
@@ -1,5 +1,5 @@
 /* SPDX-License-Identifier: GPL-2.0 */
 /*RTL8723D PHY Parameters*/
-#define	RELEASE_DATE_8723D		20170824
+#define	RELEASE_DATE_8723D		20180130
 #define	COMMIT_BY_8723D			"BB_Jessica"
-#define	RELEASE_VERSION_8723D	36
+#define	RELEASE_VERSION_8723D	37
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/sd4_phydm_2_kernel.mk b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/sd4_phydm_2_kernel.mk
new file mode 100644
index 000000000000..324d0ee12cad
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/sd4_phydm_2_kernel.mk
@@ -0,0 +1,189 @@
+# SPDX-License-Identifier: GPL-2.0
+EXTRA_CFLAGS += -I$(src)/hal/phydm
+
+_PHYDM_FILES := hal/phydm/phydm_debug.o	\
+								hal/phydm/phydm_interface.o\
+								hal/phydm/phydm_phystatus.o\
+								hal/phydm/phydm_hwconfig.o\
+								hal/phydm/phydm.o\
+								hal/phydm/phydm_dig.o\
+								hal/phydm/phydm_rainfo.o\
+								hal/phydm/phydm_adaptivity.o\
+								hal/phydm/phydm_cfotracking.o\
+								hal/phydm/phydm_noisemonitor.o\
+								hal/phydm/phydm_beamforming.o\
+								hal/phydm/phydm_dfs.o\
+								hal/phydm/txbf/halcomtxbf.o\
+								hal/phydm/txbf/haltxbfinterface.o\
+								hal/phydm/txbf/phydm_hal_txbf_api.o\
+								hal/phydm/phydm_ccx.o\
+								hal/phydm/phydm_cck_pd.o\
+								hal/phydm/phydm_rssi_monitor.o\
+								hal/phydm/phydm_math_lib.o\
+								hal/phydm/phydm_api.o\
+								hal/phydm/halrf/halrf.o\
+								hal/phydm/halrf/halrf_debug.o\
+								hal/phydm/halrf/halphyrf_ce.o\
+								hal/phydm/halrf/halrf_powertracking_ce.o\
+								hal/phydm/halrf/halrf_powertracking.o\
+								hal/phydm/halrf/halrf_kfree.o
+
+ifeq ($(CONFIG_RTL8188E), y)
+RTL871X = rtl8188e
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8188e_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8188e_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8188e_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8188e_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8188e.o\
+								hal/phydm/$(RTL871X)/hal8188erateadaptive.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8188e.o
+endif
+
+ifeq ($(CONFIG_RTL8192E), y)
+RTL871X = rtl8192e
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8192e_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8192e_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8192e_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8192e_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8192e.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8192e.o
+endif
+
+
+ifeq ($(CONFIG_RTL8812A), y)
+RTL871X = rtl8812a
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8812a_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8812a_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8812a_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8812a_ce.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8812a.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8812a.o\
+								hal/phydm/txbf/haltxbfjaguar.o
+endif
+
+ifeq ($(CONFIG_RTL8821A), y)
+RTL871X = rtl8821a
+_PHYDM_FILES += hal/phydm/rtl8821a/halhwimg8821a_mac.o\
+								hal/phydm/rtl8821a/halhwimg8821a_bb.o\
+								hal/phydm/rtl8821a/halhwimg8821a_rf.o\
+								hal/phydm/halrf/rtl8812a/halrf_8812a_ce.o\
+								hal/phydm/halrf/rtl8821a/halrf_8821a_ce.o\
+								hal/phydm/rtl8821a/phydm_regconfig8821a.o\
+								hal/phydm/rtl8821a/phydm_rtl8821a.o\
+								hal/phydm/halrf/rtl8821a/halrf_iqk_8821a_ce.o\
+								hal/phydm/txbf/haltxbfjaguar.o
+endif
+
+
+ifeq ($(CONFIG_RTL8723B), y)
+RTL871X = rtl8723b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8723b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_rf.o\
+								hal/phydm/$(RTL871X)/halhwimg8723b_mp.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8723b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8723b_ce.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8723b.o
+endif
+
+
+ifeq ($(CONFIG_RTL8814A), y)
+RTL871X = rtl8814a
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8814a_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8814a_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8814a_rf.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8814a.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8814a.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8814a_ce.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8814a.o\
+								hal/phydm/txbf/haltxbf8814a.o
+endif
+
+
+ifeq ($(CONFIG_RTL8723C), y)
+RTL871X = rtl8703b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8703b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8703b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8703b_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8703b.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8703b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8703b.o
+endif
+
+ifeq ($(CONFIG_RTL8723D), y)
+RTL871X = rtl8723d
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8723d_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8723d_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8723d_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8723d.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8723d.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8723d.o
+endif
+
+
+ifeq ($(CONFIG_RTL8710B), y)
+RTL871X = rtl8710b
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8710b_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8710b_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8710b_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8710b.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8710b.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8710b.o
+endif
+
+
+ifeq ($(CONFIG_RTL8188F), y)
+RTL871X = rtl8188f
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8188f_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8188f_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8188f_rf.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8188f.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8188f.o \
+								hal/phydm/$(RTL871X)/phydm_rtl8188f.o
+endif
+
+ifeq ($(CONFIG_RTL8822B), y)
+RTL871X = rtl8822b
+_PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8822b_bb.o \
+								hal/phydm/$(RTL871X)/halhwimg8822b_mac.o \
+								hal/phydm/$(RTL871X)/halhwimg8822b_rf.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_8822b.o \
+								hal/phydm/$(RTL871X)/phydm_hal_api8822b.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8822b.o \
+								hal/phydm/halrf/$(RTL871X)/halrf_rfk_init_8822b.o \
+								hal/phydm/$(RTL871X)/phydm_regconfig8822b.o \
+								hal/phydm/$(RTL871X)/phydm_rtl8822b.o
+
+_PHYDM_FILES +=	hal/phydm/txbf/haltxbf8822b.o
+endif
+
+
+ifeq ($(CONFIG_RTL8821C), y)
+RTL871X = rtl8821c
+_PHYDM_FILES +=	hal/phydm/$(RTL871X)/halhwimg8821c_bb.o \
+								hal/phydm/$(RTL871X)/halhwimg8821c_mac.o \
+								hal/phydm/$(RTL871X)/halhwimg8821c_rf.o \
+								hal/phydm/$(RTL871X)/phydm_hal_api8821c.o \
+								hal/phydm/$(RTL871X)/phydm_regconfig8821c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8821c.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_iqk_8821c.o
+endif
+ifeq ($(CONFIG_RTL8192F), y)
+RTL871X = rtl8192f
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8192f_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8192f_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8192f_rf.o\
+								hal/phydm/$(RTL871X)/phydm_hal_api8192f.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8192f.o\
+								hal/phydm/$(RTL871X)/phydm_rtl8192f.o\
+								hal/phydm/halrf/$(RTL871X)/halrf_8192f.o
+endif
+
+ifeq ($(CONFIG_RTL8198F), y)
+RTL871X = rtl8198f
+_PHYDM_FILES += hal/phydm/$(RTL871X)/halhwimg8198f_bb.o\
+								hal/phydm/$(RTL871X)/halhwimg8198f_mac.o\
+								hal/phydm/$(RTL871X)/halhwimg8198f_rf.o\
+								hal/phydm/$(RTL871X)/phydm_hal_api8198f.o\
+								hal/phydm/$(RTL871X)/phydm_regconfig8198f.o
+endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.c
index f0e3164a2fb4..41c6b9fb9fdc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -12,478 +13,437 @@
  * more details.
  *
  *****************************************************************************/
-/* ************************************************************
+/*@************************************************************
  * Description:
  *
  * This file is for TXBF mechanism
  *
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
-#if (BEAMFORMING_SUPPORT == 1)
-/*Beamforming halcomtxbf API create by YuChen 2015/05*/
+#ifdef PHYDM_BEAMFORMING_SUPPORT
+/*@Beamforming halcomtxbf API create by YuChen 2015/05*/
 
-void
-hal_com_txbf_beamform_init(
-	void			*p_dm_void
-)
+void hal_com_txbf_beamform_init(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	boolean		is_iqgen_setting_ok = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	boolean is_iqgen_setting_ok = false;
 
-	if (p_dm->support_ic_type & ODM_RTL8814A) {
-		is_iqgen_setting_ok = phydm_beamforming_set_iqgen_8814A(p_dm);
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] is_iqgen_setting_ok = %d\n", __func__, is_iqgen_setting_ok));
+	if (dm->support_ic_type & ODM_RTL8814A) {
+		is_iqgen_setting_ok = phydm_beamforming_set_iqgen_8814A(dm);
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] is_iqgen_setting_ok = %d\n",
+			  __func__, is_iqgen_setting_ok);
 	}
 }
 
-/*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
-void
-hal_com_txbf_config_gtab(
-	void			*p_dm_void
-)
+/*Only used for MU BFer Entry when get GID management frame (self as MU STA)*/
+void hal_com_txbf_config_gtab(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (p_dm->support_ic_type & ODM_RTL8822B)
-		hal_txbf_8822b_config_gtab(p_dm);
+	if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_config_gtab(dm);
 }
 
-void
-phydm_beamform_set_sounding_enter(
-	void			*p_dm_void
-)
+void phydm_beamform_set_sounding_enter(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_enter_work_item)) == false)
-		odm_schedule_work_item(&(p_txbf_info->txbf_enter_work_item));
+	if (!odm_is_work_item_scheduled(&p_txbf_info->txbf_enter_work_item))
+		odm_schedule_work_item(&p_txbf_info->txbf_enter_work_item);
 #else
-	hal_com_txbf_enter_work_item_callback(p_dm);
+	hal_com_txbf_enter_work_item_callback(dm);
 #endif
 }
 
-void
-phydm_beamform_set_sounding_leave(
-	void			*p_dm_void
-)
+void phydm_beamform_set_sounding_leave(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_leave_work_item)) == false)
-		odm_schedule_work_item(&(p_txbf_info->txbf_leave_work_item));
+	if (!odm_is_work_item_scheduled(&p_txbf_info->txbf_leave_work_item))
+		odm_schedule_work_item(&p_txbf_info->txbf_leave_work_item);
 #else
-	hal_com_txbf_leave_work_item_callback(p_dm);
+	hal_com_txbf_leave_work_item_callback(dm);
 #endif
 }
 
-void
-phydm_beamform_set_sounding_rate(
-	void			*p_dm_void
-)
+void phydm_beamform_set_sounding_rate(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_rate_work_item)) == false)
-		odm_schedule_work_item(&(p_txbf_info->txbf_rate_work_item));
+	if (!odm_is_work_item_scheduled(&p_txbf_info->txbf_rate_work_item))
+		odm_schedule_work_item(&p_txbf_info->txbf_rate_work_item);
 #else
-	hal_com_txbf_rate_work_item_callback(p_dm);
+	hal_com_txbf_rate_work_item_callback(dm);
 #endif
 }
 
-void
-phydm_beamform_set_sounding_status(
-	void			*p_dm_void
-)
+void phydm_beamform_set_sounding_status(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_status_work_item)) == false)
-		odm_schedule_work_item(&(p_txbf_info->txbf_status_work_item));
+	if (!odm_is_work_item_scheduled(&p_txbf_info->txbf_status_work_item))
+		odm_schedule_work_item(&p_txbf_info->txbf_status_work_item);
 #else
-	hal_com_txbf_status_work_item_callback(p_dm);
+	hal_com_txbf_status_work_item_callback(dm);
 #endif
 }
 
-void
-phydm_beamform_set_sounding_fw_ndpa(
-	void			*p_dm_void
-)
+void phydm_beamform_set_sounding_fw_ndpa(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	if (*p_dm->p_is_fw_dw_rsvd_page_in_progress)
-		odm_set_timer(p_dm, &(p_txbf_info->txbf_fw_ndpa_timer), 5);
+	if (*dm->is_fw_dw_rsvd_page_in_progress)
+		odm_set_timer(dm, &p_txbf_info->txbf_fw_ndpa_timer, 5);
 	else
-		odm_schedule_work_item(&(p_txbf_info->txbf_fw_ndpa_work_item));
+		odm_schedule_work_item(&p_txbf_info->txbf_fw_ndpa_work_item);
 #else
-	hal_com_txbf_fw_ndpa_work_item_callback(p_dm);
+	hal_com_txbf_fw_ndpa_work_item_callback(dm);
 #endif
 }
 
-void
-phydm_beamform_set_sounding_clk(
-	void			*p_dm_void
-)
+void phydm_beamform_set_sounding_clk(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_clk_work_item)) == false)
-		odm_schedule_work_item(&(p_txbf_info->txbf_clk_work_item));
+	if (!odm_is_work_item_scheduled(&p_txbf_info->txbf_clk_work_item))
+		odm_schedule_work_item(&p_txbf_info->txbf_clk_work_item);
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	struct _ADAPTER	*padapter = p_dm->adapter;
-
-	rtw_run_in_thread_cmd(padapter, hal_com_txbf_clk_work_item_callback, p_dm);
+	phydm_run_in_thread_cmd(dm, hal_com_txbf_clk_work_item_callback, dm);
 #else
-	hal_com_txbf_clk_work_item_callback(p_dm);
+	hal_com_txbf_clk_work_item_callback(dm);
 #endif
 }
 
-void
-phydm_beamform_set_reset_tx_path(
-	void			*p_dm_void
-)
+void phydm_beamform_set_reset_tx_path(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
+	struct _RT_WORK_ITEM *pwi = &p_txbf_info->txbf_reset_tx_path_work_item;
 
-	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_reset_tx_path_work_item)) == false)
-		odm_schedule_work_item(&(p_txbf_info->txbf_reset_tx_path_work_item));
+	if (!odm_is_work_item_scheduled(pwi))
+		odm_schedule_work_item(pwi);
 #else
-	hal_com_txbf_reset_tx_path_work_item_callback(p_dm);
+	hal_com_txbf_reset_tx_path_work_item_callback(dm);
 #endif
 }
 
-void
-phydm_beamform_set_get_tx_rate(
-	void			*p_dm_void
-)
+void phydm_beamform_set_get_tx_rate(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
+	struct _RT_WORK_ITEM *pwi = &p_txbf_info->txbf_get_tx_rate_work_item;
 
-	if (odm_is_work_item_scheduled(&(p_txbf_info->txbf_get_tx_rate_work_item)) == false)
-		odm_schedule_work_item(&(p_txbf_info->txbf_get_tx_rate_work_item));
+	if (!odm_is_work_item_scheduled(pwi))
+		odm_schedule_work_item(pwi);
 #else
-	hal_com_txbf_get_tx_rate_work_item_callback(p_dm);
+	hal_com_txbf_get_tx_rate_work_item_callback(dm);
 #endif
 }
 
-void
-hal_com_txbf_enter_work_item_callback(
+void hal_com_txbf_enter_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
-	u8			idx = p_txbf_info->txbf_idx;
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
-
-	if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
-		hal_txbf_jaguar_enter(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8192E)
-		hal_txbf_8192e_enter(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8814A)
-		hal_txbf_8814a_enter(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8822B)
-		hal_txbf_8822b_enter(p_dm, idx);
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8 idx = p_txbf_info->txbf_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_enter(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_enter(dm, idx);
 }
 
-void
-hal_com_txbf_leave_work_item_callback(
+void hal_com_txbf_leave_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	u8			idx = p_txbf_info->txbf_idx;
+	u8 idx = p_txbf_info->txbf_idx;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
-		hal_txbf_jaguar_leave(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8192E)
-		hal_txbf_8192e_leave(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8814A)
-		hal_txbf_8814a_leave(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8822B)
-		hal_txbf_8822b_leave(p_dm, idx);
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_leave(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_leave(dm, idx);
 }
 
-
-void
-hal_com_txbf_fw_ndpa_work_item_callback(
+void hal_com_txbf_fw_ndpa_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
-	u8	idx = p_txbf_info->ndpa_idx;
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
-
-	if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
-		hal_txbf_jaguar_fw_txbf(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8192E)
-		hal_txbf_8192e_fw_tx_bf(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8814A)
-		hal_txbf_8814a_fw_txbf(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8822B)
-		hal_txbf_8822b_fw_txbf(p_dm, idx);
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8 idx = p_txbf_info->ndpa_idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_fw_txbf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_fw_tx_bf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_fw_txbf(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_fw_txbf(dm, idx);
 }
 
-void
-hal_com_txbf_clk_work_item_callback(
+void hal_com_txbf_clk_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	if (p_dm->support_ic_type & ODM_RTL8812)
-		hal_txbf_jaguar_clk_8812a(p_dm);
+	if (dm->support_ic_type & ODM_RTL8812)
+		hal_txbf_jaguar_clk_8812a(dm);
 }
 
-
-
-void
-hal_com_txbf_rate_work_item_callback(
+void hal_com_txbf_rate_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
-	u8			BW = p_txbf_info->BW;
-	u8			rate = p_txbf_info->rate;
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
-
-	if (p_dm->support_ic_type & ODM_RTL8812)
-		hal_txbf_8812a_set_ndpa_rate(p_dm, BW, rate);
-	else if (p_dm->support_ic_type & ODM_RTL8192E)
-		hal_txbf_8192e_set_ndpa_rate(p_dm, BW, rate);
-	else if (p_dm->support_ic_type & ODM_RTL8814A)
-		hal_txbf_8814a_set_ndpa_rate(p_dm, BW, rate);
-
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
+	u8 BW = p_txbf_info->BW;
+	u8 rate = p_txbf_info->rate;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (dm->support_ic_type & ODM_RTL8812)
+		hal_txbf_8812a_set_ndpa_rate(dm, BW, rate);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_set_ndpa_rate(dm, BW, rate);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_set_ndpa_rate(dm, BW, rate);
 }
 
-
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-hal_com_txbf_fw_ndpa_timer_callback(
-	struct timer_list		*p_timer
-)
+void hal_com_txbf_fw_ndpa_timer_callback(
+	struct phydm_timer_list *timer)
 {
+	void *adapter = (void *)timer->Adapter;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 
-	struct _ADAPTER		*adapter = (struct _ADAPTER *)p_timer->Adapter;
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
-
-	if (*p_dm->p_is_fw_dw_rsvd_page_in_progress)
-		odm_set_timer(p_dm, &(p_txbf_info->txbf_fw_ndpa_timer), 5);
+	if (*dm->is_fw_dw_rsvd_page_in_progress)
+		odm_set_timer(dm, &(p_txbf_info->txbf_fw_ndpa_timer), 5);
 	else
 		odm_schedule_work_item(&(p_txbf_info->txbf_fw_ndpa_work_item));
 }
 #endif
 
-
-void
-hal_com_txbf_status_work_item_callback(
+void hal_com_txbf_status_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	u8			idx = p_txbf_info->txbf_idx;
+	u8 idx = p_txbf_info->txbf_idx;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	if (p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
-		hal_txbf_jaguar_status(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8192E)
-		hal_txbf_8192e_status(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8814A)
-		hal_txbf_8814a_status(p_dm, idx);
-	else if (p_dm->support_ic_type & ODM_RTL8822B)
-		hal_txbf_8822b_status(p_dm, idx);
+	if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))
+		hal_txbf_jaguar_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8192E)
+		hal_txbf_8192e_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_status(dm, idx);
+	else if (dm->support_ic_type & ODM_RTL8822B)
+		hal_txbf_8822b_status(dm, idx);
 }
 
-void
-hal_com_txbf_reset_tx_path_work_item_callback(
+void hal_com_txbf_reset_tx_path_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
-
-	u8			idx = p_txbf_info->txbf_idx;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		hal_txbf_8814a_reset_tx_path(p_dm, idx);
+	u8 idx = p_txbf_info->txbf_idx;
 
+	if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_reset_tx_path(dm, idx);
 }
 
-void
-hal_com_txbf_get_tx_rate_work_item_callback(
+void hal_com_txbf_get_tx_rate_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-)
+	)
 {
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	PHAL_DATA_TYPE	p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
 #else
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #endif
 
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		hal_txbf_8814a_get_tx_rate(p_dm);
+	if (dm->support_ic_type & ODM_RTL8814A)
+		hal_txbf_8814a_get_tx_rate(dm);
 }
 
-
 boolean
 hal_com_txbf_set(
-	void			*p_dm_void,
-	u8			set_type,
-	void			*p_in_buf
-)
+	void *dm_void,
+	u8 set_type,
+	void *p_in_buf)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			*p_u1_tmp = (u8 *)p_in_buf;
-	struct _HAL_TXBF_INFO	*p_txbf_info = &p_dm->beamforming_info.txbf_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 *p_u1_tmp = (u8 *)p_in_buf;
+	struct _HAL_TXBF_INFO *p_txbf_info = &dm->beamforming_info.txbf_info;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] set_type = 0x%X\n", __func__, set_type));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] set_type = 0x%X\n", __func__, set_type);
 
 	switch (set_type) {
 	case TXBF_SET_SOUNDING_ENTER:
 		p_txbf_info->txbf_idx = *p_u1_tmp;
-		phydm_beamform_set_sounding_enter(p_dm);
+		phydm_beamform_set_sounding_enter(dm);
 		break;
 
 	case TXBF_SET_SOUNDING_LEAVE:
 		p_txbf_info->txbf_idx = *p_u1_tmp;
-		phydm_beamform_set_sounding_leave(p_dm);
+		phydm_beamform_set_sounding_leave(dm);
 		break;
 
 	case TXBF_SET_SOUNDING_RATE:
 		p_txbf_info->BW = p_u1_tmp[0];
 		p_txbf_info->rate = p_u1_tmp[1];
-		phydm_beamform_set_sounding_rate(p_dm);
+		phydm_beamform_set_sounding_rate(dm);
 		break;
 
 	case TXBF_SET_SOUNDING_STATUS:
 		p_txbf_info->txbf_idx = *p_u1_tmp;
-		phydm_beamform_set_sounding_status(p_dm);
+		phydm_beamform_set_sounding_status(dm);
 		break;
 
 	case TXBF_SET_SOUNDING_FW_NDPA:
 		p_txbf_info->ndpa_idx = *p_u1_tmp;
-		phydm_beamform_set_sounding_fw_ndpa(p_dm);
+		phydm_beamform_set_sounding_fw_ndpa(dm);
 		break;
 
 	case TXBF_SET_SOUNDING_CLK:
-		phydm_beamform_set_sounding_clk(p_dm);
+		phydm_beamform_set_sounding_clk(dm);
 		break;
 
 	case TXBF_SET_TX_PATH_RESET:
 		p_txbf_info->txbf_idx = *p_u1_tmp;
-		phydm_beamform_set_reset_tx_path(p_dm);
+		phydm_beamform_set_reset_tx_path(dm);
 		break;
 
 	case TXBF_SET_GET_TX_RATE:
-		phydm_beamform_set_get_tx_rate(p_dm);
+		phydm_beamform_set_get_tx_rate(dm);
 		break;
-
 	}
 
 	return true;
@@ -492,52 +452,62 @@ hal_com_txbf_set(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 boolean
 hal_com_txbf_get(
-	struct _ADAPTER		*adapter,
-	u8			get_type,
-	void			*p_out_buf
-)
+	void *adapter,
+	u8 get_type,
+	void *p_out_buf)
 {
-	PHAL_DATA_TYPE		p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT			*p_dm = &p_hal_data->DM_OutSrc;
-	boolean			*p_boolean = (boolean *)p_out_buf;
+	PHAL_DATA_TYPE hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	boolean *p_boolean = (boolean *)p_out_buf;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	if (get_type == TXBF_GET_EXPLICIT_BEAMFORMEE) {
 		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(adapter))
 			*p_boolean = false;
-		else if (/*IS_HARDWARE_TYPE_8822B(adapter)	||*/
-			IS_HARDWARE_TYPE_8821B(adapter)	||
-			IS_HARDWARE_TYPE_8192E(adapter)	||
-			IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter))
+		else if (/*@IS_HARDWARE_TYPE_8822B(adapter)	||*/
+			 IS_HARDWARE_TYPE_8821B(adapter) ||
+			 IS_HARDWARE_TYPE_8192E(adapter) ||
+			 IS_HARDWARE_TYPE_8192F(adapter) ||
+			 IS_HARDWARE_TYPE_JAGUAR(adapter) ||
+			 IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter) ||
+			 IS_HARDWARE_TYPE_JAGUAR3(adapter))
 			*p_boolean = true;
 		else
 			*p_boolean = false;
 	} else if (get_type == TXBF_GET_EXPLICIT_BEAMFORMER) {
 		if (IS_HARDWARE_TYPE_OLDER_THAN_8812A(adapter))
 			*p_boolean = false;
-		else	if (/*IS_HARDWARE_TYPE_8822B(adapter)	||*/
-			IS_HARDWARE_TYPE_8821B(adapter)	||
-			IS_HARDWARE_TYPE_8192E(adapter)	||
-			IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter)) {
-			if (p_hal_data->RF_Type == RF_2T2R || p_hal_data->RF_Type == RF_3T3R)
+		else if (/*@IS_HARDWARE_TYPE_8822B(adapter)	||*/
+			 IS_HARDWARE_TYPE_8821B(adapter) ||
+			 IS_HARDWARE_TYPE_8192E(adapter) ||
+			 IS_HARDWARE_TYPE_8192F(adapter) ||
+			 IS_HARDWARE_TYPE_JAGUAR(adapter) ||
+			 IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(adapter) ||
+			 IS_HARDWARE_TYPE_JAGUAR3(adapter)) {
+			if (hal_data->RF_Type == RF_2T2R ||
+			    hal_data->RF_Type == RF_3T3R ||
+			    hal_data->RF_Type == RF_4T4R)
 				*p_boolean = true;
 			else
 				*p_boolean = false;
 		} else
 			*p_boolean = false;
 	} else if (get_type == TXBF_GET_MU_MIMO_STA) {
-#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1))
-		if (IS_HARDWARE_TYPE_8822B(adapter) || IS_HARDWARE_TYPE_8821C(adapter))
+#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) ||\
+	(RTL8822C_SUPPORT == 1))
+		if (IS_HARDWARE_TYPE_8822B(adapter) ||
+		    IS_HARDWARE_TYPE_8821C(adapter) ||
+		    IS_HARDWARE_TYPE_JAGUAR3(adapter))
 			*p_boolean = true;
 		else
 #endif
 			*p_boolean = false;
 
-
 	} else if (get_type == TXBF_GET_MU_MIMO_AP) {
-#if (RTL8822B_SUPPORT == 1)
-		if (IS_HARDWARE_TYPE_8822B(adapter))
+#if ((RTL8822B_SUPPORT == 1) || (RTL8822C_SUPPORT == 1))
+		if (IS_HARDWARE_TYPE_8822B(adapter) ||
+		    IS_HARDWARE_TYPE_JAGUAR3(adapter))
 			*p_boolean = true;
 		else
 #endif
@@ -548,5 +518,4 @@ hal_com_txbf_get(
 }
 #endif
 
-
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.h
index 0d95b69908e2..8018f7b20bdc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/halcomtxbf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,28 +9,38 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #ifndef __HAL_COM_TXBF_H__
 #define __HAL_COM_TXBF_H__
 
-/*
+#if 0
 typedef	bool
 (*TXBF_GET)(
-	void*			p_adapter,
+	void*			adapter,
 	u8			get_type,
 	void*			p_out_buf
 	);
 
 typedef	bool
 (*TXBF_SET)(
-	void*			p_adapter,
+	void*			adapter,
 	u8			set_type,
 	void*			p_in_buf
 	);
-*/
+#endif
 
 enum txbf_set_type {
 	TXBF_SET_SOUNDING_ENTER,
@@ -42,7 +53,6 @@ enum txbf_set_type {
 	TXBF_SET_GET_TX_RATE
 };
 
-
 enum txbf_get_type {
 	TXBF_GET_EXPLICIT_BEAMFORMEE,
 	TXBF_GET_EXPLICIT_BEAMFORMER,
@@ -50,144 +60,125 @@ enum txbf_get_type {
 	TXBF_GET_MU_MIMO_AP
 };
 
-
-
-/* 2 HAL TXBF related */
+/* @2 HAL TXBF related */
 struct _HAL_TXBF_INFO {
-	u8				txbf_idx;
-	u8				ndpa_idx;
-	u8				BW;
-	u8				rate;
+	u8 txbf_idx;
+	u8 ndpa_idx;
+	u8 BW;
+	u8 rate;
 
-	struct timer_list			txbf_fw_ndpa_timer;
+	struct phydm_timer_list txbf_fw_ndpa_timer;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	RT_WORK_ITEM		txbf_enter_work_item;
-	RT_WORK_ITEM		txbf_leave_work_item;
-	RT_WORK_ITEM		txbf_fw_ndpa_work_item;
-	RT_WORK_ITEM		txbf_clk_work_item;
-	RT_WORK_ITEM		txbf_status_work_item;
-	RT_WORK_ITEM		txbf_rate_work_item;
-	RT_WORK_ITEM		txbf_reset_tx_path_work_item;
-	RT_WORK_ITEM		txbf_get_tx_rate_work_item;
+	RT_WORK_ITEM txbf_enter_work_item;
+	RT_WORK_ITEM txbf_leave_work_item;
+	RT_WORK_ITEM txbf_fw_ndpa_work_item;
+	RT_WORK_ITEM txbf_clk_work_item;
+	RT_WORK_ITEM txbf_status_work_item;
+	RT_WORK_ITEM txbf_rate_work_item;
+	RT_WORK_ITEM txbf_reset_tx_path_work_item;
+	RT_WORK_ITEM txbf_get_tx_rate_work_item;
 #endif
-
 };
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
-void
-hal_com_txbf_beamform_init(
-	void			*p_dm_void
-);
+void hal_com_txbf_beamform_init(
+	void *dm_void);
 
-void
-hal_com_txbf_config_gtab(
-	void			*p_dm_void
-);
+void hal_com_txbf_config_gtab(
+	void *dm_void);
 
-void
-hal_com_txbf_enter_work_item_callback(
+void hal_com_txbf_enter_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
-void
-hal_com_txbf_leave_work_item_callback(
+void hal_com_txbf_leave_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
-void
-hal_com_txbf_fw_ndpa_work_item_callback(
+void hal_com_txbf_fw_ndpa_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
-void
-hal_com_txbf_clk_work_item_callback(
+void hal_com_txbf_clk_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
-void
-hal_com_txbf_reset_tx_path_work_item_callback(
+void hal_com_txbf_reset_tx_path_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
-void
-hal_com_txbf_get_tx_rate_work_item_callback(
+void hal_com_txbf_get_tx_rate_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
-void
-hal_com_txbf_rate_work_item_callback(
+void hal_com_txbf_rate_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
-void
-hal_com_txbf_fw_ndpa_timer_callback(
-	struct timer_list		*p_timer
-);
+void hal_com_txbf_fw_ndpa_timer_callback(
+	struct phydm_timer_list *timer);
 
-void
-hal_com_txbf_status_work_item_callback(
+void hal_com_txbf_status_work_item_callback(
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	struct _ADAPTER		*adapter
+	void *adapter
 #else
-	void			*p_dm_void
+	void *dm_void
 #endif
-);
+	);
 
 boolean
 hal_com_txbf_set(
-	void			*p_dm_void,
-	u8			set_type,
-	void			*p_in_buf
-);
+	void *dm_void,
+	u8 set_type,
+	void *p_in_buf);
 
 boolean
 hal_com_txbf_get(
-	struct _ADAPTER		*adapter,
-	u8			get_type,
-	void			*p_out_buf
-);
+	void *adapter,
+	u8 get_type,
+	void *p_out_buf);
 
 #else
-#define hal_com_txbf_beamform_init(p_dm_void)					NULL
-#define hal_com_txbf_config_gtab(p_dm_void)				NULL
-#define hal_com_txbf_enter_work_item_callback(_adapter)		NULL
-#define hal_com_txbf_leave_work_item_callback(_adapter)		NULL
-#define hal_com_txbf_fw_ndpa_work_item_callback(_adapter)		NULL
-#define hal_com_txbf_clk_work_item_callback(_adapter)			NULL
-#define hal_com_txbf_rate_work_item_callback(_adapter)		NULL
-#define hal_com_txbf_fw_ndpa_timer_callback(_adapter)		NULL
-#define hal_com_txbf_status_work_item_callback(_adapter)		NULL
+#define hal_com_txbf_beamform_init(dm_void) NULL
+#define hal_com_txbf_config_gtab(dm_void) NULL
+#define hal_com_txbf_enter_work_item_callback(_adapter) NULL
+#define hal_com_txbf_leave_work_item_callback(_adapter) NULL
+#define hal_com_txbf_fw_ndpa_work_item_callback(_adapter) NULL
+#define hal_com_txbf_clk_work_item_callback(_adapter) NULL
+#define hal_com_txbf_rate_work_item_callback(_adapter) NULL
+#define hal_com_txbf_fw_ndpa_timer_callback(_adapter) NULL
+#define hal_com_txbf_status_work_item_callback(_adapter) NULL
 #define hal_com_txbf_get(_adapter, _get_type, _pout_buf)
 
 #endif
 
-#endif	/*  #ifndef __HAL_COM_TXBF_H__ */
+#endif /*  @#ifndef __HAL_COM_TXBF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.c
index e82a99b8713e..b6a63930bfa0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -12,104 +13,95 @@
  * more details.
  *
  *****************************************************************************/
-/* ************************************************************
+/*************************************************************
  * Description:
  *
  * This file is for 8192E TXBF mechanism
  *
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (RTL8192E_SUPPORT == 1)
 
-void
-hal_txbf_8192e_set_ndpa_rate(
-	void			*p_dm_void,
-	u8	BW,
-	u8	rate
-)
+void hal_txbf_8192e_set_ndpa_rate(
+	void *dm_void,
+	u8 BW,
+	u8 rate)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	odm_write_1byte(p_dm, REG_NDPA_OPT_CTRL_8192E, (rate << 2 | BW));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8192E, (rate << 2 | BW));
 }
 
-void
-hal_txbf_8192e_rf_mode(
-	void			*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info
-)
+void hal_txbf_8192e_rf_mode(
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	if (p_dm->rf_type == RF_1T1R)
+	if (dm->rf_type == RF_1T1R)
 		return;
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
-	odm_set_rf_reg(p_dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
 
-	if (p_beam_info->beamformee_su_cnt > 0) {
+	if (beam_info->beamformee_su_cnt > 0) {
 		/*Path_A*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*Select RX mode  0x30=0x18000*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x30, 0xfffff, 0x18000); /*Select RX mode  0x30=0x18000*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x31, 0xfffff, 0x0000f); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x32, 0xfffff, 0x77fc2); /*@Enable TXIQGEN in RX mode*/
 		/*Path_B*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0x77fc2);	/*Enable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x30, 0xfffff, 0x18000); /*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x31, 0xfffff, 0x0000f); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x32, 0xfffff, 0x77fc2); /*@Enable TXIQGEN in RX mode*/
 	} else {
 		/*Path_A*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x30, 0xfffff, 0x18000); /*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x31, 0xfffff, 0x0000f); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x32, 0xfffff, 0x77f82); /*@Disable TXIQGEN in RX mode*/
 		/*Path_B*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0xfffff, 0x18000);	/*Select RX mode*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x0000f);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0x77f82);	/*Disable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x30, 0xfffff, 0x18000); /*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x31, 0xfffff, 0x0000f); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x32, 0xfffff, 0x77f82); /*@Disable TXIQGEN in RX mode*/
 	}
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
-	odm_set_rf_reg(p_dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_WE_LUT, 0x80000, 0x0); /*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_WE_LUT, 0x80000, 0x0); /*RF mode table write disable*/
 
-	if (p_beam_info->beamformee_su_cnt > 0) {
-		odm_set_bb_reg(p_dm, 0x90c, MASKDWORD, 0x83321333);
-		odm_set_bb_reg(p_dm, 0xa04, MASKBYTE3, 0xc1);
+	if (beam_info->beamformee_su_cnt > 0) {
+		odm_set_bb_reg(dm, R_0x90c, MASKDWORD, 0x83321333);
+		odm_set_bb_reg(dm, R_0xa04, MASKBYTE3, 0xc1);
 	} else
-		odm_set_bb_reg(p_dm, 0x90c, MASKDWORD, 0x81121313);
+		odm_set_bb_reg(dm, R_0x90c, MASKDWORD, 0x81121313);
 }
 
-
-
-void
-hal_txbf_8192e_fw_txbf_cmd(
-	void			*p_dm_void
-)
+void hal_txbf_8192e_fw_txbf_cmd(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	idx, period0 = 0, period1 = 0;
-	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
-	u8	u1_tx_bf_parm[3] = {0};
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 idx, period0 = 0, period1 = 0;
+	u8 PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8 u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		if (p_beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+		if (beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
 			if (idx == 0) {
-				if (p_beam_info->beamformee_entry[idx].is_sound)
+				if (beam_info->beamformee_entry[idx].is_sound)
 					PageNum0 = 0xFE;
 				else
 					PageNum0 = 0xFF; /* stop sounding */
-				period0 = (u8)(p_beam_info->beamformee_entry[idx].sound_period);
+				period0 = (u8)(beam_info->beamformee_entry[idx].sound_period);
 			} else if (idx == 1) {
-				if (p_beam_info->beamformee_entry[idx].is_sound)
+				if (beam_info->beamformee_entry[idx].is_sound)
 					PageNum1 = 0xFE;
 				else
 					PageNum1 = 0xFF; /* stop sounding */
-				period1 = (u8)(p_beam_info->beamformee_entry[idx].sound_period);
+				period1 = (u8)(beam_info->beamformee_entry[idx].sound_period);
 			}
 		}
 	}
@@ -117,242 +109,235 @@ hal_txbf_8192e_fw_txbf_cmd(
 	u1_tx_bf_parm[0] = PageNum0;
 	u1_tx_bf_parm[1] = PageNum1;
 	u1_tx_bf_parm[2] = (period1 << 4) | period0;
-	odm_fill_h2c_cmd(p_dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
 
-	PHYDM_DBG(p_dm, DBG_TXBF,
-		("[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n", __func__, PageNum0, period0, PageNum1, period1));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n",
+		  __func__, PageNum0, period0, PageNum1, period1);
 }
 
-
-void
-hal_txbf_8192e_download_ndpa(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8192e_download_ndpa(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			u1b_tmp = 0, tmp_reg422 = 0, head_page;
-	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
-	boolean			is_send_beacon = false;
-	u8			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;
-	/*default reseved 1 page for the IC type which is undefined.*/
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 u1b_tmp = 0, tmp_reg422 = 0, head_page;
+	u8 bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	boolean is_send_beacon = false;
+	u8 tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;
+	/*@default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *p_beam_entry = beam_info->beamformee_entry + idx;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*p_dm->p_is_fw_dw_rsvd_page_in_progress = true;
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
 #endif
 	if (idx == 0)
 		head_page = 0xFE;
 	else
 		head_page = 0xFE;
 
-	phydm_get_hal_def_var_handler_interface(p_dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
 
 	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1b_tmp = odm_read_1byte(p_dm, REG_CR_8192E+1);
-	odm_write_1byte(p_dm,  REG_CR_8192E+1, (u1b_tmp | BIT(0)));
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8192E + 1);
+	odm_write_1byte(dm, REG_CR_8192E + 1, (u1b_tmp | BIT(0)));
 
 	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmp_reg422 = odm_read_1byte(p_dm, REG_FWHW_TXQ_CTRL_8192E+2);
-	odm_write_1byte(p_dm, REG_FWHW_TXQ_CTRL_8192E+2,  tmp_reg422 & (~BIT(6)));
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8192E + 2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8192E + 2, tmp_reg422 & (~BIT(6)));
 
 	if (tmp_reg422 & BIT(6)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s There is an adapter is sending beacon.\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "%s There is an adapter is sending beacon.\n",
+			  __func__);
 		is_send_beacon = true;
 	}
 
 	/*TDECTRL[15:8] 0x209[7:0] = 0xFE/0xFD	NDPA Head for TXDMA*/
-	odm_write_1byte(p_dm, REG_DWBCN0_CTRL_8192E+1, head_page);
+	odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E + 1, head_page);
 
 	do {
-		/*Clear beacon valid check bit.*/
-		bcn_valid_reg = odm_read_1byte(p_dm, REG_DWBCN0_CTRL_8192E+2);
-		odm_write_1byte(p_dm, REG_DWBCN0_CTRL_8192E+2, (bcn_valid_reg | BIT(0)));
+		/*@Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E + 2);
+		odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E + 2, (bcn_valid_reg | BIT(0)));
 
-		/* download NDPA rsvd page. */
-		beamforming_send_ht_ndpa_packet(p_dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+		/* @download NDPA rsvd page. */
+		beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
 
 #if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
-		u1b_tmp = odm_read_1byte(p_dm, REG_MGQ_TXBD_NUM_8192E+3);
-		count = 0;
-		while ((count < 20) && (u1b_tmp & BIT(4))) {
-			count++;
-			ODM_delay_us(10);
-			u1b_tmp = odm_read_1byte(p_dm, REG_MGQ_TXBD_NUM_8192E+3);
+		if (dm->support_interface == ODM_ITRF_PCIE) {
+			u1b_tmp = odm_read_1byte(dm, REG_MGQ_TXBD_NUM_8192E + 3);
+			count = 0;
+			while ((count < 20) && (u1b_tmp & BIT(4))) {
+				count++;
+				ODM_delay_us(10);
+				u1b_tmp = odm_read_1byte(dm, REG_MGQ_TXBD_NUM_8192E + 3);
+			}
+			odm_write_1byte(dm, REG_MGQ_TXBD_NUM_8192E + 3, u1b_tmp | BIT(4));
 		}
-		odm_write_1byte(p_dm, REG_MGQ_TXBD_NUM_8192E+3, u1b_tmp | BIT(4));
 #endif
 
-		/*check rsvd page download OK.*/
-		bcn_valid_reg = odm_read_1byte(p_dm, REG_DWBCN0_CTRL_8192E+2);
+		/*@check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E + 2);
 		count = 0;
 		while (!(bcn_valid_reg & BIT(0)) && count < 20) {
 			count++;
 			ODM_delay_us(10);
-			bcn_valid_reg = odm_read_1byte(p_dm, REG_DWBCN0_CTRL_8192E+2);
+			bcn_valid_reg = odm_read_1byte(dm, REG_DWBCN0_CTRL_8192E + 2);
 		}
 		dl_bcn_count++;
 	} while (!(bcn_valid_reg & BIT(0)) && dl_bcn_count < 5);
 
 	if (!(bcn_valid_reg & BIT(0)))
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s Download RSVD page failed!\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n",
+			  __func__);
 
 	/*TDECTRL[15:8] 0x209[7:0] = 0xF9	Beacon Head for TXDMA*/
-	odm_write_1byte(p_dm, REG_DWBCN0_CTRL_8192E+1, tx_page_bndy);
+	odm_write_1byte(dm, REG_DWBCN0_CTRL_8192E + 1, tx_page_bndy);
 
 	/*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*/
+	/*@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.*/
+	/*@2010.06.23. Added by tynli.*/
 	if (is_send_beacon)
-		odm_write_1byte(p_dm, REG_FWHW_TXQ_CTRL_8192E+2, tmp_reg422);
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8192E + 2, tmp_reg422);
 
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1b_tmp = odm_read_1byte(p_dm, REG_CR_8192E+1);
-	odm_write_1byte(p_dm, REG_CR_8192E+1, (u1b_tmp & (~BIT(0))));
+	/*@Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*@Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8192E + 1);
+	odm_write_1byte(dm, REG_CR_8192E + 1, (u1b_tmp & (~BIT(0))));
 
 	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*p_dm->p_is_fw_dw_rsvd_page_in_progress = false;
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
 #endif
 }
 
-
-void
-hal_txbf_8192e_enter(
-	void			*p_dm_void,
-	u8				bfer_bfee_idx
-)
+void hal_txbf_8192e_enter(
+	void *dm_void,
+	u8 bfer_bfee_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8					i = 0;
-	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
-	u8					bfee_idx = (bfer_bfee_idx & 0xF);
-	u32					csi_param;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
-	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
-	u16					sta_id = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	u8 bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8 bfee_idx = (bfer_bfee_idx & 0xF);
+	u32 csi_param;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY beamformer_entry;
+	u16 sta_id = 0;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	hal_txbf_8192e_rf_mode(p_dm, p_beamforming_info);
+	hal_txbf_8192e_rf_mode(dm, beamforming_info);
 
-	if (p_dm->rf_type == RF_2T2R)
-		odm_write_4byte(p_dm, 0xd80, 0x00000000);		/*nc =2*/
+	if (dm->rf_type == RF_2T2R)
+		odm_write_4byte(dm, 0xd80, 0x00000000); /*nc =2*/
 
-	if ((p_beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
-		beamformer_entry = p_beamforming_info->beamformer_entry[bfer_idx];
+	if (beamforming_info->beamformer_su_cnt > 0 && bfer_idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
 
 		/*Sounding protocol control*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8192E, 0xCB);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E, 0xCB);
 
-		/*MAC address/Partial AID of Beamformer*/
+		/*@MAC address/Partial AID of Beamformer*/
 		if (bfer_idx == 0) {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_ASSOCIATED_BFMER0_INFO_8192E+i), beamformer_entry.mac_addr[i]);
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8192E + i), beamformer_entry.mac_addr[i]);
 		} else {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_ASSOCIATED_BFMER1_INFO_8192E+i), beamformer_entry.mac_addr[i]);
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8192E + i), beamformer_entry.mac_addr[i]);
 		}
 
-		/*CSI report parameters of Beamformer Default use nc = 2*/
+		/*@CSI report parameters of Beamformer Default use nc = 2*/
 		csi_param = 0x03090309;
 
-		odm_write_4byte(p_dm, REG_CSI_RPT_PARAM_BW20_8192E, csi_param);
-		odm_write_4byte(p_dm, REG_CSI_RPT_PARAM_BW40_8192E, csi_param);
-		odm_write_4byte(p_dm, REG_CSI_RPT_PARAM_BW80_8192E, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW20_8192E, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW40_8192E, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW80_8192E, csi_param);
 
 		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8192E+3, 0x50);
-
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E + 3, 0x50);
 	}
 
-	if ((p_beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
-		beamformee_entry = p_beamforming_info->beamformee_entry[bfee_idx];
+	if (beamforming_info->beamformee_su_cnt > 0 && bfee_idx < BEAMFORMEE_ENTRY_NUM) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
 
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
 			sta_id = beamformee_entry.mac_id;
 		else
 			sta_id = beamformee_entry.p_aid;
 
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s], sta_id=0x%X\n", __func__, sta_id));
+		PHYDM_DBG(dm, DBG_TXBF, "[%s], sta_id=0x%X\n", __func__,
+			  sta_id);
 
 		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
 		if (bfee_idx == 0) {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8192E, sta_id);
-			odm_write_1byte(p_dm, REG_TXBF_CTRL_8192E+3, odm_read_1byte(p_dm, REG_TXBF_CTRL_8192E+3) | BIT(4) | BIT(6) | BIT(7));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8192E, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8192E + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8192E + 3) | BIT(4) | BIT(6) | BIT(7));
 		} else
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8192E+2, sta_id | BIT(12) | BIT(14) | BIT(15));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8192E + 2, sta_id | BIT(12) | BIT(14) | BIT(15));
 
-		/*CSI report parameters of Beamformee*/
+		/*@CSI report parameters of Beamformee*/
 		if (bfee_idx == 0) {
-			/*Get BIT24 & BIT25*/
-			u8 tmp = odm_read_1byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8192E+3) & 0x3;
+			/*@Get BIT24 & BIT25*/
+			u8 tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E + 3) & 0x3;
 
-			odm_write_1byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8192E+3, tmp | 0x60);
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8192E, sta_id | BIT(9));
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E, sta_id | BIT(9));
 		} else {
 			/*Set BIT25*/
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, sta_id | 0xE200);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E + 2, sta_id | 0xE200);
 		}
-		phydm_beamforming_notify(p_dm);
-
+		phydm_beamforming_notify(dm);
 	}
 }
 
-
-void
-hal_txbf_8192e_leave(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8192e_leave(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
-	hal_txbf_8192e_rf_mode(p_dm, p_beam_info);
+	hal_txbf_8192e_rf_mode(dm, beam_info);
 
-	/*	Clear P_AID of Beamformee
+	/*	@Clear P_AID of Beamformee
 	*	Clear MAC addresss of Beamformer
 	*	Clear Associated Bfmee Sel
 	*/
-	if (p_beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8192E, 0xC8);
+	if (beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8192E, 0xC8);
 
 	if (idx == 0) {
-		odm_write_2byte(p_dm, REG_TXBF_CTRL_8192E, 0);
-		odm_write_4byte(p_dm, REG_ASSOCIATED_BFMER0_INFO_8192E, 0);
-		odm_write_2byte(p_dm, REG_ASSOCIATED_BFMER0_INFO_8192E+4, 0);
-		odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8192E, 0);
+		odm_write_2byte(dm, REG_TXBF_CTRL_8192E, 0);
+		odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8192E, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8192E + 4, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E, 0);
 	} else {
-		odm_write_2byte(p_dm, REG_TXBF_CTRL_8192E+2, odm_read_1byte(p_dm, REG_TXBF_CTRL_8192E+2) & 0xF000);
-		odm_write_4byte(p_dm, REG_ASSOCIATED_BFMER1_INFO_8192E, 0);
-		odm_write_2byte(p_dm, REG_ASSOCIATED_BFMER1_INFO_8192E+4, 0);
-		odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2, odm_read_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8192E+2) & 0x60);
+		odm_write_2byte(dm, REG_TXBF_CTRL_8192E + 2, odm_read_1byte(dm, REG_TXBF_CTRL_8192E + 2) & 0xF000);
+		odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8192E, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8192E + 4, 0);
+		odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E + 2, odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8192E + 2) & 0x60);
 	}
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] idx %d\n", __func__, idx));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] idx %d\n", __func__, idx);
 }
 
-
-void
-hal_txbf_8192e_status(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8192e_status(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u16					beam_ctrl_val;
-	u32					beam_ctrl_reg;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info =  &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	beamform_entry = p_beam_info->beamformee_entry[idx];
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 beam_ctrl_val;
+	u32 beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY beamform_entry = beam_info->beamformee_entry[idx];
 
-	if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
 		beam_ctrl_val = beamform_entry.mac_id;
 	else
 		beam_ctrl_val = beamform_entry.p_aid;
@@ -360,11 +345,11 @@ hal_txbf_8192e_status(
 	if (idx == 0)
 		beam_ctrl_reg = REG_TXBF_CTRL_8192E;
 	else {
-		beam_ctrl_reg = REG_TXBF_CTRL_8192E+2;
+		beam_ctrl_reg = REG_TXBF_CTRL_8192E + 2;
 		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
 	}
 
-	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (p_beam_info->apply_v_matrix == true)) {
+	if (beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED && beam_info->apply_v_matrix == true) {
 		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
 			beam_ctrl_val |= BIT(9);
 		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
@@ -372,30 +357,29 @@ hal_txbf_8192e_status(
 	} else
 		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
 
-	odm_write_2byte(p_dm, beam_ctrl_reg, beam_ctrl_val);
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] idx %d beam_ctrl_reg %x beam_ctrl_val %x\n", __func__, idx, beam_ctrl_reg, beam_ctrl_val));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] idx %d beam_ctrl_reg %x beam_ctrl_val %x\n", __func__,
+		  idx, beam_ctrl_reg, beam_ctrl_val);
 }
 
-
-void
-hal_txbf_8192e_fw_tx_bf(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8192e_fw_tx_bf(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *p_beam_entry = beam_info->beamformee_entry + idx;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		hal_txbf_8192e_download_ndpa(p_dm, idx);
+		hal_txbf_8192e_download_ndpa(dm, idx);
 
-	hal_txbf_8192e_fw_txbf_cmd(p_dm);
+	hal_txbf_8192e_fw_txbf_cmd(dm);
 }
 
-#endif	/* #if (RTL8192E_SUPPORT == 1)*/
+#endif /* @#if (RTL8192E_SUPPORT == 1)*/
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.h
index 636e0d558c57..dc7a8c0e5398 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8192e.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,66 +9,63 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #ifndef __HAL_TXBF_8192E_H__
 #define __HAL_TXBF_8192E_H__
 
 #if (RTL8192E_SUPPORT == 1)
-#if (BEAMFORMING_SUPPORT == 1)
-
-void
-hal_txbf_8192e_set_ndpa_rate(
-	void			*p_dm_void,
-	u8	BW,
-	u8	rate
-);
-
-void
-hal_txbf_8192e_enter(
-	void			*p_dm_void,
-	u8				idx
-);
-
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
-void
-hal_txbf_8192e_leave(
-	void			*p_dm_void,
-	u8				idx
-);
+void hal_txbf_8192e_set_ndpa_rate(
+	void *dm_void,
+	u8 BW,
+	u8 rate);
 
+void hal_txbf_8192e_enter(
+	void *dm_void,
+	u8 idx);
 
-void
-hal_txbf_8192e_status(
-	void			*p_dm_void,
-	u8				idx
-);
+void hal_txbf_8192e_leave(
+	void *dm_void,
+	u8 idx);
 
+void hal_txbf_8192e_status(
+	void *dm_void,
+	u8 idx);
 
-void
-hal_txbf_8192e_fw_tx_bf(
-	void			*p_dm_void,
-	u8				idx
-);
+void hal_txbf_8192e_fw_tx_bf(
+	void *dm_void,
+	u8 idx);
 #else
 
-#define hal_txbf_8192e_set_ndpa_rate(p_dm_void, BW, rate)
-#define hal_txbf_8192e_enter(p_dm_void, idx)
-#define hal_txbf_8192e_leave(p_dm_void, idx)
-#define hal_txbf_8192e_status(p_dm_void, idx)
-#define hal_txbf_8192e_fw_tx_bf(p_dm_void, idx)
+#define hal_txbf_8192e_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8192e_enter(dm_void, idx)
+#define hal_txbf_8192e_leave(dm_void, idx)
+#define hal_txbf_8192e_status(dm_void, idx)
+#define hal_txbf_8192e_fw_tx_bf(dm_void, idx)
 
 #endif
 
 #else
 
-#define hal_txbf_8192e_set_ndpa_rate(p_dm_void, BW, rate)
-#define hal_txbf_8192e_enter(p_dm_void, idx)
-#define hal_txbf_8192e_leave(p_dm_void, idx)
-#define hal_txbf_8192e_status(p_dm_void, idx)
-#define hal_txbf_8192e_fw_tx_bf(p_dm_void, idx)
+#define hal_txbf_8192e_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8192e_enter(dm_void, idx)
+#define hal_txbf_8192e_leave(dm_void, idx)
+#define hal_txbf_8192e_status(dm_void, idx)
+#define hal_txbf_8192e_fw_tx_bf(dm_void, idx)
 
 #endif
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.c
index 9cfb0150e0ec..79cc536fc971 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -22,75 +23,64 @@
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (RTL8814A_SUPPORT == 1)
 
 boolean
-phydm_beamforming_set_iqgen_8814A(
-	void			*p_dm_void
-)
+phydm_beamforming_set_iqgen_8814A(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u8 i = 0;
 	u16 counter = 0;
 	u32 rf_mode[4];
 
-	for (i = RF_PATH_A ; i < MAX_RF_PATH ; i++)
-		odm_set_rf_reg(p_dm, i, RF_WE_LUT, 0x80000, 0x1);	/*RF mode table write enable*/
+	for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
+		odm_set_rf_reg(dm, i, RF_WE_LUT, 0x80000, 0x1); /*RF mode table write enable*/
 
 	while (1) {
 		counter++;
 		for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
-			odm_set_rf_reg(p_dm, i, RF_RCK_OS, 0xfffff, 0x18000);	/*Select Rx mode*/
+			odm_set_rf_reg(dm, i, RF_RCK_OS, 0xfffff, 0x18000); /*Select Rx mode*/
 
 		ODM_delay_us(2);
 
 		for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
-			rf_mode[i] = odm_get_rf_reg(p_dm, i, RF_RCK_OS, 0xfffff);
+			rf_mode[i] = odm_get_rf_reg(dm, i, RF_RCK_OS, 0xfffff);
 
-		if ((rf_mode[0] == 0x18000) && (rf_mode[1] == 0x18000) && (rf_mode[2] == 0x18000) && (rf_mode[3] == 0x18000))
+		if (rf_mode[0] == 0x18000 && rf_mode[1] == 0x18000 && rf_mode[2] == 0x18000 && rf_mode[3] == 0x18000)
 			break;
 		else if (counter == 100) {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("iqgen setting fail:8814A\n"));
+			PHYDM_DBG(dm, DBG_TXBF, "iqgen setting fail:8814A\n");
 			return false;
 		}
 	}
 
-	for (i = RF_PATH_A ; i < MAX_RF_PATH ; i++) {
-		odm_set_rf_reg(p_dm, i, RF_TXPA_G1, 0xfffff, 0xBE77F); /*Set Table data*/
-		odm_set_rf_reg(p_dm, i, RF_TXPA_G2, 0xfffff, 0x226BF); /*Enable TXIQGEN in Rx mode*/
+	for (i = RF_PATH_A; i < MAX_RF_PATH; i++) {
+		odm_set_rf_reg(dm, i, RF_TXPA_G1, 0xfffff, 0xBE77F); /*Set Table data*/
+		odm_set_rf_reg(dm, i, RF_TXPA_G2, 0xfffff, 0x226BF); /*@Enable TXIQGEN in Rx mode*/
 	}
-	odm_set_rf_reg(p_dm, RF_PATH_A, RF_TXPA_G2, 0xfffff, 0xE26BF); /*Enable TXIQGEN in Rx mode*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_TXPA_G2, 0xfffff, 0xE26BF); /*@Enable TXIQGEN in Rx mode*/
 
 	for (i = RF_PATH_A; i < MAX_RF_PATH; i++)
-		odm_set_rf_reg(p_dm, i, RF_WE_LUT, 0x80000, 0x0);	/*RF mode table write disable*/
+		odm_set_rf_reg(dm, i, RF_WE_LUT, 0x80000, 0x0); /*RF mode table write disable*/
 
 	return true;
-
 }
 
-
-
-void
-hal_txbf_8814a_set_ndpa_rate(
-	void			*p_dm_void,
-	u8	BW,
-	u8	rate
-)
+void hal_txbf_8814a_set_ndpa_rate(void *dm_void, u8 BW, u8 rate)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	odm_write_1byte(p_dm, REG_NDPA_OPT_CTRL_8814A, BW);
-	odm_write_1byte(p_dm, REG_NDPA_RATE_8814A, (u8) rate);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8814A, BW);
+	odm_write_1byte(dm, REG_NDPA_RATE_8814A, (u8)rate);
 }
 #if 0
-#define PHYDM_MEMORY_MAP_BUF_READ	0x8000
-#define PHYDM_CTRL_INFO_PAGE			0x660
+#define PHYDM_MEMORY_MAP_BUF_READ 0x8000
+#define PHYDM_CTRL_INFO_PAGE 0x660
 
 void
 phydm_data_rate_8814a(
-	struct PHY_DM_STRUCT			*p_dm,
+	struct dm_struct			*dm,
 	u8				mac_id,
 	u32				*data,
 	u8				data_len
@@ -99,89 +89,83 @@ phydm_data_rate_8814a(
 	u8	i = 0;
 	u16	x_read_data_addr = 0;
 
-	odm_write_2byte(p_dm, REG_PKTBUF_DBG_CTRL_8814A, PHYDM_CTRL_INFO_PAGE);
-	x_read_data_addr = PHYDM_MEMORY_MAP_BUF_READ + mac_id * 32; /*Ctrl Info: 32Bytes for each macid(n)*/
+	odm_write_2byte(dm, REG_PKTBUF_DBG_CTRL_8814A, PHYDM_CTRL_INFO_PAGE);
+	x_read_data_addr = PHYDM_MEMORY_MAP_BUF_READ + mac_id * 32; /*@Ctrl Info: 32Bytes for each macid(n)*/
 
-	if ((x_read_data_addr < PHYDM_MEMORY_MAP_BUF_READ) || (x_read_data_addr > 0x8FFF)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("x_read_data_addr(0x%x) is not correct!\n", x_read_data_addr));
+	if (x_read_data_addr < PHYDM_MEMORY_MAP_BUF_READ || x_read_data_addr > 0x8FFF) {
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "x_read_data_addr(0x%x) is not correct!\n",
+			  x_read_data_addr);
 		return;
 	}
 
 	/* Read data */
 	for (i = 0; i < data_len; i++)
-		*(data + i) = odm_read_2byte(p_dm, x_read_data_addr + i);
-
+		*(data + i) = odm_read_2byte(dm, x_read_data_addr + i);
 }
 #endif
 
-void
-hal_txbf_8814a_get_tx_rate(
-	void			*p_dm_void
-)
+void hal_txbf_8814a_get_tx_rate(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry;
-	struct _rate_adaptive_table_	*p_ra_table = &p_dm->dm_ra_table;
-	struct cmn_sta_info			*p_sta = NULL;
-	u8	data_rate = 0xFF;
-	u8	macid = 0;
-
-	p_entry = &(p_beam_info->beamformee_entry[p_beam_info->beamformee_cur_idx]);
-	macid = (u8)p_entry->mac_id;
-
-	p_sta = p_dm->p_phydm_sta_info[macid];
-	
-	if (is_sta_active(p_sta)) {
-		
-		data_rate = (p_sta->ra_info.curr_tx_rate) & 0x7f;	/*Bit7 indicates SGI*/
-		p_beam_info->tx_bf_data_rate = data_rate;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *entry;
+	struct ra_table *ra_tab = &dm->dm_ra_table;
+	struct cmn_sta_info *sta = NULL;
+	u8 data_rate = 0xFF;
+	u8 macid = 0;
+
+	entry = &(beam_info->beamformee_entry[beam_info->beamformee_cur_idx]);
+	macid = (u8)entry->mac_id;
+
+	sta = dm->phydm_sta_info[macid];
+
+	if (is_sta_active(sta)) {
+		data_rate = (sta->ra_info.curr_tx_rate) & 0x7f; /*@Bit7 indicates SGI*/
+		beam_info->tx_bf_data_rate = data_rate;
 	}
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] p_dm->tx_bf_data_rate = 0x%x\n", __func__, p_beam_info->tx_bf_data_rate));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] dm->tx_bf_data_rate = 0x%x\n", __func__,
+		  beam_info->tx_bf_data_rate);
 }
 
-void
-hal_txbf_8814a_reset_tx_path(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8814a_reset_tx_path(void *dm_void, u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 #if DEV_BUS_TYPE == RT_USB_INTERFACE
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
-	u8	nr_index = 0, tx_ss = 0;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
+	u8 nr_index = 0, tx_ss = 0;
 
 	if (idx < BEAMFORMEE_ENTRY_NUM)
-		beamformee_entry = p_beamforming_info->beamformee_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
 	else
 		return;
 
-	if ((p_beamforming_info->last_usb_hub) != (*p_dm->hub_usb_mode)) {
-		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(p_dm), beamformee_entry.comp_steering_num_of_bfer);
+	if (beamforming_info->last_usb_hub != (*dm->hub_usb_mode)) {
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), beamformee_entry.comp_steering_num_of_bfer);
 
-		if (*p_dm->hub_usb_mode == 2) {
-			if (p_dm->rf_type == RF_4T4R)
+		if (*dm->hub_usb_mode == 2) {
+			if (dm->rf_type == RF_4T4R)
 				tx_ss = 0xf;
-			else if (p_dm->rf_type == RF_3T3R)
+			else if (dm->rf_type == RF_3T3R)
 				tx_ss = 0xe;
 			else
 				tx_ss = 0x6;
-		} else if (*p_dm->hub_usb_mode == 1)	/*USB 2.0 always 2Tx*/
+		} else if (*dm->hub_usb_mode == 1) /*USB 2.0 always 2Tx*/
 			tx_ss = 0x6;
 		else
 			tx_ss = 0x6;
 
 		if (tx_ss == 0xf) {
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
 		} else if (tx_ss == 0xe) {
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
 		} else if (tx_ss == 0x6) {
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
 		}
 
 		if (idx == 0) {
@@ -189,169 +173,159 @@ hal_txbf_8814a_reset_tx_path(
 			case 0:
 				break;
 
-			case 1:			/*Nsts = 2	BC*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+			case 1: /*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366); /*tx2path, BC*/
 				break;
 
-			case 2:			/*Nsts = 3	BCD*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+			case 2: /*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee); /*tx3path, BCD*/
 				break;
 
-			default:			/*nr>3, same as Case 3*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+			default: /*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff); /*tx4path, ABCD*/
 				break;
 			}
-		} else	{
+		} else {
 			switch (nr_index) {
 			case 0:
 				break;
 
-			case 1:			/*Nsts = 2	BC*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+			case 1: /*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366); /*tx2path, BC*/
 				break;
 
-			case 2:			/*Nsts = 3	BCD*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+			case 2: /*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee); /*tx3path, BCD*/
 				break;
 
-			default:			/*nr>3, same as Case 3*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+			default: /*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff); /*tx4path, ABCD*/
 				break;
 			}
 		}
 
-		p_beamforming_info->last_usb_hub = *p_dm->hub_usb_mode;
+		beamforming_info->last_usb_hub = *dm->hub_usb_mode;
 	} else
 		return;
 #endif
 }
 
-
-u8
-hal_txbf_8814a_get_ntx(
-	void			*p_dm_void
-)
+u8 hal_txbf_8814a_get_ntx(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		ntx = 0, tx_ss = 3;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 ntx = 0, tx_ss = 3;
 
 #if DEV_BUS_TYPE == RT_USB_INTERFACE
-	tx_ss = *p_dm->hub_usb_mode;
+	tx_ss = *dm->hub_usb_mode;
 #endif
 	if (tx_ss == 3 || tx_ss == 2) {
-		if (p_dm->rf_type == RF_4T4R)
+		if (dm->rf_type == RF_4T4R)
 			ntx = 3;
-		else if (p_dm->rf_type == RF_3T3R)
+		else if (dm->rf_type == RF_3T3R)
 			ntx = 2;
 		else
 			ntx = 1;
-	} else if (tx_ss == 1)	/*USB 2.0 always 2Tx*/
+	} else if (tx_ss == 1) /*USB 2.0 always 2Tx*/
 		ntx = 1;
 	else
 		ntx = 1;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ntx = %d\n", __func__, ntx));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ntx = %d\n", __func__, ntx);
 	return ntx;
 }
 
-u8
-hal_txbf_8814a_get_nrx(
-	void			*p_dm_void
-)
+u8 hal_txbf_8814a_get_nrx(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			nrx = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 nrx = 0;
 
-	if (p_dm->rf_type == RF_4T4R)
+	if (dm->rf_type == RF_4T4R)
 		nrx = 3;
-	else if (p_dm->rf_type == RF_3T3R)
+	else if (dm->rf_type == RF_3T3R)
 		nrx = 2;
-	else if (p_dm->rf_type == RF_2T2R)
+	else if (dm->rf_type == RF_2T2R)
 		nrx = 1;
-	else if (p_dm->rf_type == RF_2T3R)
+	else if (dm->rf_type == RF_2T3R)
 		nrx = 2;
-	else if (p_dm->rf_type == RF_2T4R)
+	else if (dm->rf_type == RF_2T4R)
 		nrx = 3;
-	else if (p_dm->rf_type == RF_1T1R)
+	else if (dm->rf_type == RF_1T1R)
 		nrx = 0;
-	else if (p_dm->rf_type == RF_1T2R)
+	else if (dm->rf_type == RF_1T2R)
 		nrx = 1;
 	else
 		nrx = 0;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] nrx = %d\n", __func__, nrx));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] nrx = %d\n", __func__, nrx);
 	return nrx;
 }
 
-void
-hal_txbf_8814a_rf_mode(
-	void			*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info,
-	u8					idx
-)
+void hal_txbf_8814a_rf_mode(void *dm_void,
+			    struct _RT_BEAMFORMING_INFO *beamforming_info,
+			    u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8				nr_index = 0;
-	u8				tx_ss = 3;		/*default use 3 Tx*/
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 nr_index = 0;
+	u8 tx_ss = 3; /*@default use 3 Tx*/
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
 
 	if (idx < BEAMFORMEE_ENTRY_NUM)
-		beamformee_entry = p_beamforming_info->beamformee_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
 	else
 		return;
 
-	nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(p_dm), beamformee_entry.comp_steering_num_of_bfer);
+	nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), beamformee_entry.comp_steering_num_of_bfer);
 
-	if (p_dm->rf_type == RF_1T1R)
+	if (dm->rf_type == RF_1T1R)
 		return;
 
-	if (p_beamforming_info->beamformee_su_cnt > 0) {
+	if (beamforming_info->beamformee_su_cnt > 0) {
 #if DEV_BUS_TYPE == RT_USB_INTERFACE
-		p_beamforming_info->last_usb_hub = *p_dm->hub_usb_mode;
-		tx_ss = *p_dm->hub_usb_mode;
+		beamforming_info->last_usb_hub = *dm->hub_usb_mode;
+		tx_ss = *dm->hub_usb_mode;
 #endif
 		if (tx_ss == 3 || tx_ss == 2) {
-			if (p_dm->rf_type == RF_4T4R)
+			if (dm->rf_type == RF_4T4R)
 				tx_ss = 0xf;
-			else if (p_dm->rf_type == RF_3T3R)
+			else if (dm->rf_type == RF_3T3R)
 				tx_ss = 0xe;
 			else
 				tx_ss = 0x6;
-		} else if (tx_ss == 1)	/*USB 2.0 always 2Tx*/
+		} else if (tx_ss == 1) /*USB 2.0 always 2Tx*/
 			tx_ss = 0x6;
 		else
 			tx_ss = 0x6;
 
 		if (tx_ss == 0xf) {
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93f);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKDWORD, 0x93f93f0);
 		} else if (tx_ss == 0xe) {
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x93e);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e93e0);
 		} else if (tx_ss == 0x6) {
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x936);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKLWORD, 0x9360);
 		}
 
-		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT(28) | BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT30, 0x1);			/*if Nsts > Nc don't apply V matrix*/
+		/*@for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT(28) | BIT29, 0x2); /*@enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, BIT30, 0x1); /*@if Nsts > Nc don't apply V matrix*/
 
 		if (idx == 0) {
 			switch (nr_index) {
 			case 0:
 				break;
 
-			case 1:			/*Nsts = 2	BC*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+			case 1: /*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366); /*tx2path, BC*/
 				break;
 
-			case 2:			/*Nsts = 3	BCD*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+			case 2: /*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee); /*tx3path, BCD*/
 				break;
 
-			default:			/*nr>3, same as Case 3*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+			default: /*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff); /*tx4path, ABCD*/
 
 				break;
 			}
@@ -360,132 +334,135 @@ hal_txbf_8814a_rf_mode(
 			case 0:
 				break;
 
-			case 1:			/*Nsts = 2	BC*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366);		/*tx2path, BC*/
+			case 1: /*Nsts = 2	BC*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x9366); /*tx2path, BC*/
 				break;
 
-			case 2:			/*Nsts = 3	BCD*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee);	/*tx3path, BCD*/
+			case 2: /*Nsts = 3	BCD*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93e93ee); /*tx3path, BCD*/
 				break;
 
-			default:			/*nr>3, same as Case 3*/
-				odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff);	/*tx4path, ABCD*/
+			default: /*nr>3, same as Case 3*/
+				odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8814A, MASKBYTE3LOWNIBBLE | MASKL3BYTES, 0x93f93ff); /*tx4path, ABCD*/
 				break;
 			}
 		}
 	}
 
-	if ((p_beamforming_info->beamformee_su_cnt == 0) && (p_beamforming_info->beamformer_su_cnt == 0)) {
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x932);	/*set tx_path selection for 8814a BFer bug refine*/
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e9360);
+	if (beamforming_info->beamformee_su_cnt == 0 && beamforming_info->beamformer_su_cnt == 0) {
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8814A, MASKBYTE3 | MASKBYTE2HIGHNIBBLE, 0x932); /*set tx_path selection for 8814a BFer bug refine*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8814A, MASKDWORD, 0x93e9360);
 	}
 }
 #if 0
 void
 hal_txbf_8814a_download_ndpa(
-	void			*p_dm_void,
+	void			*dm_void,
 	u8				idx
 )
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
 	u8			u1b_tmp = 0, tmp_reg422 = 0;
 	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
 	u16			head_page = 0x7FE;
 	boolean			is_send_beacon = false;
-	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*@default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
+	void		*adapter = dm->adapter;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*p_dm->p_is_fw_dw_rsvd_page_in_progress = true;
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
 #endif
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	phydm_get_hal_def_var_handler_interface(p_dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
 
 	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1b_tmp = odm_read_1byte(p_dm, REG_CR_8814A + 1);
-	odm_write_1byte(p_dm,  REG_CR_8814A + 1, (u1b_tmp | BIT(0)));
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8814A + 1);
+	odm_write_1byte(dm,  REG_CR_8814A + 1, (u1b_tmp | BIT(0)));
 
 
 	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmp_reg422 = odm_read_1byte(p_dm, REG_FWHW_TXQ_CTRL_8814A + 2);
-	odm_write_1byte(p_dm, REG_FWHW_TXQ_CTRL_8814A + 2,  tmp_reg422 & (~BIT(6)));
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2,  tmp_reg422 & (~BIT(6)));
 
 	if (tmp_reg422 & BIT(6)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: There is an adapter is sending beacon.\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "%s: There is an adapter is sending beacon.\n",
+			  __func__);
 		is_send_beacon = true;
 	}
 
-	/*0x204[11:0]	Beacon Head for TXDMA*/
-	odm_write_2byte(p_dm, REG_FIFOPAGE_CTRL_2_8814A, head_page);
+	/*@0x204[11:0]	Beacon Head for TXDMA*/
+	odm_write_2byte(dm, REG_FIFOPAGE_CTRL_2_8814A, head_page);
 
 	do {
-		/*Clear beacon valid check bit.*/
-		bcn_valid_reg = odm_read_1byte(p_dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
-		odm_write_1byte(p_dm, REG_FIFOPAGE_CTRL_2_8814A + 1, (bcn_valid_reg | BIT(7)));
+		/*@Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		odm_write_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1, (bcn_valid_reg | BIT(7)));
 
-		/*download NDPA rsvd page.*/
+		/*@download NDPA rsvd page.*/
 		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
-			beamforming_send_vht_ndpa_packet(p_dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
 		else
-			beamforming_send_ht_ndpa_packet(p_dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
 
-		/*check rsvd page download OK.*/
-		bcn_valid_reg = odm_read_1byte(p_dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
+		/*@check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 1);
 		count = 0;
 		while (!(bcn_valid_reg & BIT(7)) && count < 20) {
 			count++;
 			ODM_delay_ms(10);
-			bcn_valid_reg = odm_read_1byte(p_dm, REG_FIFOPAGE_CTRL_2_8814A + 2);
+			bcn_valid_reg = odm_read_1byte(dm, REG_FIFOPAGE_CTRL_2_8814A + 2);
 		}
 		dl_bcn_count++;
 	} while (!(bcn_valid_reg & BIT(7)) && dl_bcn_count < 5);
 
 	if (!(bcn_valid_reg & BIT(7)))
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s Download RSVD page failed!\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n",
+			  __func__);
 
-	/*0x204[11:0]	Beacon Head for TXDMA*/
-	odm_write_2byte(p_dm, REG_FIFOPAGE_CTRL_2_8814A, tx_page_bndy);
+	/*@0x204[11:0]	Beacon Head for TXDMA*/
+	odm_write_2byte(dm, REG_FIFOPAGE_CTRL_2_8814A, tx_page_bndy);
 
 	/*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*/
+	/*@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.*/
+	/*@2010.06.23. Added by tynli.*/
 	if (is_send_beacon)
-		odm_write_1byte(p_dm, REG_FWHW_TXQ_CTRL_8814A + 2, tmp_reg422);
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8814A + 2, tmp_reg422);
 
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1b_tmp = odm_read_1byte(p_dm, REG_CR_8814A + 1);
-	odm_write_1byte(p_dm, REG_CR_8814A + 1, (u1b_tmp & (~BIT(0))));
+	/*@Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*@Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8814A + 1);
+	odm_write_1byte(dm, REG_CR_8814A + 1, (u1b_tmp & (~BIT(0))));
 
 	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*p_dm->p_is_fw_dw_rsvd_page_in_progress = false;
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
 #endif
 }
 
 void
 hal_txbf_8814a_fw_txbf_cmd(
-	void			*p_dm_void
+	void			*dm_void
 )
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
 	u8	idx, period = 0;
 	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
 	u8	u1_tx_bf_parm[3] = {0};
-	struct _RT_BEAMFORMING_INFO *p_beam_info = &p_dm->beamforming_info;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		if (p_beam_info->beamformee_entry[idx].is_used && p_beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (p_beam_info->beamformee_entry[idx].is_sound) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beam_info->beamformee_entry[idx].is_sound) {
 				PageNum0 = 0xFE;
 				PageNum1 = 0x07;
-				period = (u8)(p_beam_info->beamformee_entry[idx].sound_period);
+				period = (u8)(beam_info->beamformee_entry[idx].sound_period);
 			} else if (PageNum0 == 0xFF) {
 				PageNum0 = 0xFF; /*stop sounding*/
 				PageNum1 = 0x0F;
@@ -496,52 +473,50 @@ hal_txbf_8814a_fw_txbf_cmd(
 	u1_tx_bf_parm[0] = PageNum0;
 	u1_tx_bf_parm[1] = PageNum1;
 	u1_tx_bf_parm[2] = period;
-	odm_fill_h2c_cmd(p_dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
 
-	PHYDM_DBG(p_dm, DBG_TXBF,
-		("[%s] PageNum0 = %d, PageNum1 = %d period = %d\n", __func__, PageNum0, PageNum1, period));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] PageNum0 = %d, PageNum1 = %d period = %d\n", __func__,
+		  PageNum0, PageNum1, period);
 }
 #endif
-void
-hal_txbf_8814a_enter(
-	void			*p_dm_void,
-	u8				bfer_bfee_idx
-)
+void hal_txbf_8814a_enter(void *dm_void, u8 bfer_bfee_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8					i = 0;
-	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
-	u8					bfee_idx = (bfer_bfee_idx & 0xF);
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
-	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
-	u16					sta_id = 0, csi_param = 0;
-	u8					nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] bfer_idx=%d, bfee_idx=%d\n", __func__, bfer_idx, bfee_idx));
-	odm_set_mac_reg(p_dm, REG_SND_PTCL_CTRL_8814A, MASKBYTE1 | MASKBYTE2, 0x0202);
-
-	if ((p_beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
-		beamformer_entry = p_beamforming_info->beamformer_entry[bfer_idx];
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	u8 bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8 bfee_idx = (bfer_bfee_idx & 0xF);
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY beamformer_entry;
+	u16 sta_id = 0, csi_param = 0;
+	u8 nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] bfer_idx=%d, bfee_idx=%d\n", __func__,
+		  bfer_idx, bfee_idx);
+	odm_set_mac_reg(dm, REG_SND_PTCL_CTRL_8814A, MASKBYTE1 | MASKBYTE2, 0x0202);
+
+	if (beamforming_info->beamformer_su_cnt > 0 && bfer_idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
 		/*Sounding protocol control*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8814A, 0xDB);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A, 0xDB);
 
-		/*MAC address/Partial AID of Beamformer*/
+		/*@MAC address/Partial AID of Beamformer*/
 		if (bfer_idx == 0) {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_ASSOCIATED_BFMER0_INFO_8814A + i), beamformer_entry.mac_addr[i]);
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8814A + i), beamformer_entry.mac_addr[i]);
 		} else {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_ASSOCIATED_BFMER1_INFO_8814A + i), beamformer_entry.mac_addr[i]);
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8814A + i), beamformer_entry.mac_addr[i]);
 		}
 
-		/*CSI report parameters of Beamformer*/
-		nc_index = hal_txbf_8814a_get_nrx(p_dm);	/*for 8814A nrx = 3(4 ant), min=0(1 ant)*/
-		nr_index = beamformer_entry.num_of_sounding_dim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+		/*@CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8814a_get_nrx(dm); /*@for 8814A nrx = 3(4 ant), min=0(1 ant)*/
+		nr_index = beamformer_entry.num_of_sounding_dim; /*@0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
 
 		grouping = 0;
 
-		/*for ac = 1, for n = 3*/
+		/*@for ac = 1, for n = 3*/
 		if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU)
 			codebookinfo = 1;
 		else if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
@@ -552,118 +527,108 @@ hal_txbf_8814a_enter(
 		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
 
 		if (bfer_idx == 0)
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW20_8814A, csi_param);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A, csi_param);
 		else
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, csi_param);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, csi_param);
 		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8814A + 3, 0x40);
-
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A + 3, 0x40);
 	}
 
-	if ((p_beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
-		beamformee_entry = p_beamforming_info->beamformee_entry[bfee_idx];
+	if (beamforming_info->beamformee_su_cnt > 0 && bfee_idx < BEAMFORMEE_ENTRY_NUM) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
 
-		hal_txbf_8814a_rf_mode(p_dm, p_beamforming_info, bfee_idx);
+		hal_txbf_8814a_rf_mode(dm, beamforming_info, bfee_idx);
 
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
 			sta_id = beamformee_entry.mac_id;
 		else
 			sta_id = beamformee_entry.p_aid;
 
 		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
 		if (bfee_idx == 0) {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8814A, sta_id);
-			odm_write_1byte(p_dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(p_dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
 		} else
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8814A + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
 
-		/*CSI report parameters of Beamformee*/
+		/*@CSI report parameters of Beamformee*/
 		if (bfee_idx == 0) {
-			/*Get BIT24 & BIT25*/
-			u8	tmp = odm_read_1byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3) & 0x3;
+			/*@Get BIT24 & BIT25*/
+			u8 tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3) & 0x3;
 
-			odm_write_1byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3, tmp | 0x60);
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8814A, sta_id | BIT(9));
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A, sta_id | BIT(9));
 		} else
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, sta_id | 0xE200);	/*Set BIT25*/
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, sta_id | 0xE200); /*Set BIT25*/
 
-		phydm_beamforming_notify(p_dm);
+		phydm_beamforming_notify(dm);
 	}
-
 }
 
-
-void
-hal_txbf_8814a_leave(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8814a_leave(void *dm_void, u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
 
 	if (idx < BEAMFORMER_ENTRY_NUM) {
-		beamformer_entry = p_beamforming_info->beamformer_entry[idx];
-		beamformee_entry = p_beamforming_info->beamformee_entry[idx];
+		beamformer_entry = beamforming_info->beamformer_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
 	} else
 		return;
 
-	/*Clear P_AID of Beamformee*/
-	/*Clear MAC address of Beamformer*/
-	/*Clear Associated Bfmee Sel*/
+	/*@Clear P_AID of Beamformee*/
+	/*@Clear MAC address of Beamformer*/
+	/*@Clear Associated Bfmee Sel*/
 
 	if (beamformer_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8814A, 0xD8);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8814A, 0xD8);
 		if (idx == 0) {
-			odm_write_4byte(p_dm, REG_ASSOCIATED_BFMER0_INFO_8814A, 0);
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMER0_INFO_8814A + 4, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW20_8814A, 0);
+			odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8814A, 0);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8814A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A, 0);
 		} else {
-			odm_write_4byte(p_dm, REG_ASSOCIATED_BFMER1_INFO_8814A, 0);
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMER1_INFO_8814A + 4, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, 0);
+			odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8814A, 0);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8814A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8814A + 2, 0);
 		}
 	}
 
 	if (beamformee_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
-		hal_txbf_8814a_rf_mode(p_dm, p_beamforming_info, idx);
+		hal_txbf_8814a_rf_mode(dm, beamforming_info, idx);
 		if (idx == 0) {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8814A, 0x0);
-			odm_write_1byte(p_dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(p_dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8814A, 0);
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A, 0x0);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8814A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8814A + 3) | BIT(4) | BIT(6) | BIT(7));
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A, 0);
 		} else {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8814A + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8814A + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
 
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, odm_read_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2) & 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2, odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8814A + 2) & 0x60);
 		}
 	}
 }
 
-void
-hal_txbf_8814a_status(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8814a_status(void *dm_void, u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u16					beam_ctrl_val, tmp_val;
-	u32					beam_ctrl_reg;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	beamform_entry;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 beam_ctrl_val, tmp_val;
+	u32 beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY beamform_entry;
 
 	if (idx < BEAMFORMEE_ENTRY_NUM)
-		beamform_entry = p_beamforming_info->beamformee_entry[idx];
+		beamform_entry = beamforming_info->beamformee_entry[idx];
 	else
 		return;
 
-	if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
 		beam_ctrl_val = beamform_entry.mac_id;
 	else
 		beam_ctrl_val = beamform_entry.p_aid;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, beamform_entry.beamform_entry_state = %d", __func__, beamform_entry.beamform_entry_state));
+	PHYDM_DBG(dm, DBG_TXBF, "@%s, beamform_entry.beamform_entry_state = %d",
+		  __func__, beamform_entry.beamform_entry_state);
 
 	if (idx == 0)
 		beam_ctrl_reg = REG_TXBF_CTRL_8814A;
@@ -672,7 +637,7 @@ hal_txbf_8814a_status(
 		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
 	}
 
-	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (p_beamforming_info->apply_v_matrix == true)) {
+	if (beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED && beamforming_info->apply_v_matrix == true) {
 		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
 			beam_ctrl_val |= BIT(9);
 		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
@@ -680,41 +645,32 @@ hal_txbf_8814a_status(
 		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_80)
 			beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
 	} else {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, Don't apply Vmatrix",  __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, Don't apply Vmatrix", __func__);
 		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
 	}
 
-	odm_write_2byte(p_dm, beam_ctrl_reg, beam_ctrl_val);
-	/*disable NDP packet use beamforming */
-	tmp_val = odm_read_2byte(p_dm, REG_TXBF_CTRL_8814A);
-	odm_write_2byte(p_dm, REG_TXBF_CTRL_8814A, tmp_val | BIT(15));
-
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+	/*@disable NDP packet use beamforming */
+	tmp_val = odm_read_2byte(dm, REG_TXBF_CTRL_8814A);
+	odm_write_2byte(dm, REG_TXBF_CTRL_8814A, tmp_val | BIT(15));
 }
 
-
-
-
-
-void
-hal_txbf_8814a_fw_txbf(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8814a_fw_txbf(void *dm_void, u8 idx)
 {
 #if 0
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO	*beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		hal_txbf_8814a_download_ndpa(p_dm, idx);
+		hal_txbf_8814a_download_ndpa(dm, idx);
 
-	hal_txbf_8814a_fw_txbf_cmd(p_dm);
+	hal_txbf_8814a_fw_txbf_cmd(dm);
 #endif
 }
 
-#endif	/* (RTL8814A_SUPPORT == 1)*/
+#endif /* @(RTL8814A_SUPPORT == 1)*/
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.h
index b070564af2d6..9863d770db4f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8814a.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,96 +9,70 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #ifndef __HAL_TXBF_8814A_H__
 #define __HAL_TXBF_8814A_H__
 
 #if (RTL8814A_SUPPORT == 1)
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
 boolean
-phydm_beamforming_set_iqgen_8814A(
-	void			*p_dm_void
-);
-
-void
-hal_txbf_8814a_set_ndpa_rate(
-	void			*p_dm_void,
-	u8	BW,
-	u8	rate
-);
-
-u8
-hal_txbf_8814a_get_ntx(
-	void			*p_dm_void
-);
-
-void
-hal_txbf_8814a_enter(
-	void			*p_dm_void,
-	u8				idx
-);
-
-
-void
-hal_txbf_8814a_leave(
-	void			*p_dm_void,
-	u8				idx
-);
-
-
-void
-hal_txbf_8814a_status(
-	void			*p_dm_void,
-	u8				idx
-);
-
-void
-hal_txbf_8814a_reset_tx_path(
-	void			*p_dm_void,
-	u8				idx
-);
-
-
-void
-hal_txbf_8814a_get_tx_rate(
-	void			*p_dm_void
-);
-
-void
-hal_txbf_8814a_fw_txbf(
-	void			*p_dm_void,
-	u8				idx
-);
+phydm_beamforming_set_iqgen_8814A(void *dm_void);
+
+void hal_txbf_8814a_set_ndpa_rate(void *dm_void, u8 BW, u8 rate);
+
+u8 hal_txbf_8814a_get_ntx(void *dm_void);
+
+void hal_txbf_8814a_enter(void *dm_void, u8 idx);
+
+void hal_txbf_8814a_leave(void *dm_void, u8 idx);
+
+void hal_txbf_8814a_status(void *dm_void, u8 idx);
+
+void hal_txbf_8814a_reset_tx_path(void *dm_void, u8 idx);
+
+void hal_txbf_8814a_get_tx_rate(void *dm_void);
+
+void hal_txbf_8814a_fw_txbf(void *dm_void, u8 idx);
 
 #else
 
-#define hal_txbf_8814a_set_ndpa_rate(p_dm_void,	BW,	rate)
-#define hal_txbf_8814a_get_ntx(p_dm_void) 0
-#define hal_txbf_8814a_enter(p_dm_void, idx)
-#define hal_txbf_8814a_leave(p_dm_void, idx)
-#define hal_txbf_8814a_status(p_dm_void, idx)
-#define hal_txbf_8814a_reset_tx_path(p_dm_void,	idx)
-#define hal_txbf_8814a_get_tx_rate(p_dm_void)
-#define hal_txbf_8814a_fw_txbf(p_dm_void,	idx)
-#define phydm_beamforming_set_iqgen_8814A(p_dm_void)	0
+#define hal_txbf_8814a_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8814a_get_ntx(dm_void) 0
+#define hal_txbf_8814a_enter(dm_void, idx)
+#define hal_txbf_8814a_leave(dm_void, idx)
+#define hal_txbf_8814a_status(dm_void, idx)
+#define hal_txbf_8814a_reset_tx_path(dm_void, idx)
+#define hal_txbf_8814a_get_tx_rate(dm_void)
+#define hal_txbf_8814a_fw_txbf(dm_void, idx)
+#define phydm_beamforming_set_iqgen_8814A(dm_void) 0
 
 #endif
 
 #else
 
-#define hal_txbf_8814a_set_ndpa_rate(p_dm_void,	BW,	rate)
-#define hal_txbf_8814a_get_ntx(p_dm_void) 0
-#define hal_txbf_8814a_enter(p_dm_void, idx)
-#define hal_txbf_8814a_leave(p_dm_void, idx)
-#define hal_txbf_8814a_status(p_dm_void, idx)
-#define hal_txbf_8814a_reset_tx_path(p_dm_void,	idx)
-#define hal_txbf_8814a_get_tx_rate(p_dm_void)
-#define hal_txbf_8814a_fw_txbf(p_dm_void,	idx)
-#define phydm_beamforming_set_iqgen_8814A(p_dm_void)	0
+#define hal_txbf_8814a_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_8814a_get_ntx(dm_void) 0
+#define hal_txbf_8814a_enter(dm_void, idx)
+#define hal_txbf_8814a_leave(dm_void, idx)
+#define hal_txbf_8814a_status(dm_void, idx)
+#define hal_txbf_8814a_reset_tx_path(dm_void, idx)
+#define hal_txbf_8814a_get_tx_rate(dm_void)
+#define hal_txbf_8814a_fw_txbf(dm_void, idx)
+#define phydm_beamforming_set_iqgen_8814A(dm_void) 0
 #endif
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.c
index e7d75a45b484..1924e0f15a6c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -12,163 +13,154 @@
  * more details.
  *
  *****************************************************************************/
-/*============================================================*/
-/* Description:                                              */
-/*                                                           */
+/*@============================================================*/
+/* @Description:                                              */
+/*                                                           @*/
 /* This file is for 8814A TXBF mechanism                     */
-/*                                                           */
-/*============================================================*/
+/*                                                           @*/
+/*@============================================================*/
 
 #include "mp_precomp.h"
 #include "phydm_precomp.h"
 
 #if (RTL8822B_SUPPORT == 1)
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
-u8
-hal_txbf_8822b_get_ntx(
-	void			*p_dm_void
-)
+u8 hal_txbf_8822b_get_ntx(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			ntx = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 ntx = 0;
 
 #if DEV_BUS_TYPE == RT_USB_INTERFACE
-	if (p_dm->support_interface == ODM_ITRF_USB) {
-		if (*p_dm->hub_usb_mode == 2) {/*USB3.0*/
-			if (p_dm->rf_type == RF_4T4R)
+	if (dm->support_interface == ODM_ITRF_USB) {
+		if (*dm->hub_usb_mode == 2) { /*USB3.0*/
+			if (dm->rf_type == RF_4T4R)
 				ntx = 3;
-			else if (p_dm->rf_type == RF_3T3R)
+			else if (dm->rf_type == RF_3T3R)
 				ntx = 2;
 			else
 				ntx = 1;
-		} else if (*p_dm->hub_usb_mode == 1)	/*USB 2.0 always 2Tx*/
+		} else if (*dm->hub_usb_mode == 1) /*USB 2.0 always 2Tx*/
 			ntx = 1;
 		else
 			ntx = 1;
 	} else
 #endif
 	{
-		if (p_dm->rf_type == RF_4T4R)
+		if (dm->rf_type == RF_4T4R)
 			ntx = 3;
-		else if (p_dm->rf_type == RF_3T3R)
+		else if (dm->rf_type == RF_3T3R)
 			ntx = 2;
 		else
 			ntx = 1;
 	}
 
 	return ntx;
-
 }
 
-u8
-hal_txbf_8822b_get_nrx(
-	void			*p_dm_void
-)
+u8 hal_txbf_8822b_get_nrx(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			nrx = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 nrx = 0;
 
-	if (p_dm->rf_type == RF_4T4R)
+	if (dm->rf_type == RF_4T4R)
 		nrx = 3;
-	else if (p_dm->rf_type == RF_3T3R)
+	else if (dm->rf_type == RF_3T3R)
 		nrx = 2;
-	else if (p_dm->rf_type == RF_2T2R)
+	else if (dm->rf_type == RF_2T2R)
 		nrx = 1;
-	else if (p_dm->rf_type == RF_2T3R)
+	else if (dm->rf_type == RF_2T3R)
 		nrx = 2;
-	else if (p_dm->rf_type == RF_2T4R)
+	else if (dm->rf_type == RF_2T4R)
 		nrx = 3;
-	else if (p_dm->rf_type == RF_1T1R)
+	else if (dm->rf_type == RF_1T1R)
 		nrx = 0;
-	else if (p_dm->rf_type == RF_1T2R)
+	else if (dm->rf_type == RF_1T2R)
 		nrx = 1;
 	else
 		nrx = 0;
 
 	return nrx;
-
 }
 
 /***************SU & MU BFee Entry********************/
-void
-hal_txbf_8822b_rf_mode(
-	void			*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info,
-	u8					idx
-)
+void hal_txbf_8822b_rf_mode(
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beamforming_info,
+	u8 idx)
 {
 #if 0
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
 	u8				i, nr_index = 0;
 	boolean				is_self_beamformer = false;
 	boolean				is_self_beamformee = false;
 	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
 
 	if (idx < BEAMFORMEE_ENTRY_NUM)
-		beamformee_entry = p_beamforming_info->beamformee_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
 	else
 		return;
 
-	if (p_dm->rf_type == RF_1T1R)
+	if (dm->rf_type == RF_1T1R)
 		return;
 
 	for (i = RF_PATH_A; i < RF_PATH_B; i++) {
-		odm_set_rf_reg(p_dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x1);
+		odm_set_rf_reg(dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x1);
 		/*RF mode table write enable*/
 	}
 
-	if ((p_beamforming_info->beamformee_su_cnt > 0) || (p_beamforming_info->beamformee_mu_cnt > 0)) {
+	if (beamforming_info->beamformee_su_cnt > 0 || beamforming_info->beamformee_mu_cnt > 0) {
 		for (i = RF_PATH_A; i < RF_PATH_B; i++) {
-			odm_set_rf_reg(p_dm, (enum rf_path)i, rf_mode_table_addr, 0xfffff, 0x18000);
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_addr, 0xfffff, 0x18000);
 			/*Select RX mode*/
-			odm_set_rf_reg(p_dm, (enum rf_path)i, rf_mode_table_data0, 0xfffff, 0xBE77F);
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_data0, 0xfffff, 0xBE77F);
 			/*Set Table data*/
-			odm_set_rf_reg(p_dm, (enum rf_path)i, rf_mode_table_data1, 0xfffff, 0x226BF);
-			/*Enable TXIQGEN in RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, rf_mode_table_data1, 0xfffff, 0x226BF);
+			/*@Enable TXIQGEN in RX mode*/
 		}
-		odm_set_rf_reg(p_dm, RF_PATH_A, rf_mode_table_data1, 0xfffff, 0xE26BF);
-		/*Enable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, rf_mode_table_data1, 0xfffff, 0xE26BF);
+		/*@Enable TXIQGEN in RX mode*/
 	}
 
 	for (i = RF_PATH_A; i < RF_PATH_B; i++) {
-		odm_set_rf_reg(p_dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x0);
+		odm_set_rf_reg(dm, (enum rf_path)i, rf_welut_jaguar, 0x80000, 0x0);
 		/*RF mode table write disable*/
 	}
 
-	if (p_beamforming_info->beamformee_su_cnt > 0) {
-
-		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2);			/*enable BB TxBF ant mapping register*/
+	if (beamforming_info->beamformee_su_cnt > 0) {
+		/*@for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2);			/*@enable BB TxBF ant mapping register*/
 
 		if (idx == 0) {
 			/*Nsts = 2	AB*/
-			odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF0_8822B, 0xffff, 0x0433);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
-			/*odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430);*/
-
-		} else {/*IDX =1*/
-			odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
-			odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
-			/*odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430;*/
+			odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF0_8822B, 0xffff, 0x0433);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+			/*odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430);*/
+
+		} else {/*@IDX =1*/
+			odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+			odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+			/*odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2, MASKLWORD, 0x430;*/
 		}
 	} else {
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*1SS by path-A*/
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*2SS by path-A,B*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*@1SS by path-A*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*@2SS by path-A,B*/
 	}
 
-	if (p_beamforming_info->beamformee_mu_cnt > 0) {
-		/*MU STAs share the common setting*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1);
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+	if (beamforming_info->beamformee_mu_cnt > 0) {
+		/*@MU STAs share the common setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1);
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
 	}
 #endif
 }
 #if 0
 void
 hal_txbf_8822b_download_ndpa(
-	struct _ADAPTER			*adapter,
+	void			*adapter,
 	u8				idx
 )
 {
@@ -176,13 +168,13 @@ hal_txbf_8822b_download_ndpa(
 	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
 	u16			head_page = 0x7FE;
 	boolean			is_send_beacon = false;
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*default reseved 1 page for the IC type which is undefined.*/
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = GET_BEAMFORM_INFO(adapter);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
+	HAL_DATA_TYPE	*hal_data = GET_HAL_DATA(adapter);
+	u16			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8814A; /*@default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
 
-	p_hal_data->is_fw_dw_rsvd_page_in_progress = true;
-	phydm_get_hal_def_var_handler_interface(p_dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
+	hal_data->is_fw_dw_rsvd_page_in_progress = true;
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u16 *)&tx_page_bndy);
 
 	/*Set REG_CR bit 8. DMA beacon by SW.*/
 	u1b_tmp = platform_efio_read_1byte(adapter, REG_CR_8814A + 1);
@@ -198,21 +190,21 @@ hal_txbf_8822b_download_ndpa(
 		is_send_beacon = true;
 	}
 
-	/*0x204[11:0]	Beacon Head for TXDMA*/
+	/*@0x204[11:0]	Beacon Head for TXDMA*/
 	platform_efio_write_2byte(adapter, REG_FIFOPAGE_CTRL_2_8814A, head_page);
 
 	do {
-		/*Clear beacon valid check bit.*/
+		/*@Clear beacon valid check bit.*/
 		bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
 		platform_efio_write_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1, (bcn_valid_reg | BIT(7)));
 
-		/*download NDPA rsvd page.*/
+		/*@download NDPA rsvd page.*/
 		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
-			beamforming_send_vht_ndpa_packet(p_dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->AID, p_beam_entry->sound_bw, BEACON_QUEUE);
 		else
-			beamforming_send_ht_ndpa_packet(p_dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
 
-		/*check rsvd page download OK.*/
+		/*@check rsvd page download OK.*/
 		bcn_valid_reg = platform_efio_read_1byte(adapter, REG_FIFOPAGE_CTRL_2_8814A + 1);
 		count = 0;
 		while (!(bcn_valid_reg & BIT(7)) && count < 20) {
@@ -226,45 +218,45 @@ hal_txbf_8822b_download_ndpa(
 	if (!(bcn_valid_reg & BIT(0)))
 		RT_DISP(FBEAM, FBEAM_ERROR, ("%s Download RSVD page failed!\n", __func__));
 
-	/*0x204[11:0]	Beacon Head for TXDMA*/
+	/*@0x204[11:0]	Beacon Head for TXDMA*/
 	platform_efio_write_2byte(adapter, REG_FIFOPAGE_CTRL_2_8814A, tx_page_bndy);
 
 	/*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*/
+	/*@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.*/
+	/*@2010.06.23. Added by tynli.*/
 	if (is_send_beacon)
 		platform_efio_write_1byte(adapter, REG_FWHW_TXQ_CTRL_8814A + 2, tmp_reg422);
 
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	/*@Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*@Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
 	u1b_tmp = platform_efio_read_1byte(adapter, REG_CR_8814A + 1);
 	platform_efio_write_1byte(adapter, REG_CR_8814A + 1, (u1b_tmp & (~BIT(0))));
 
 	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
 
-	p_hal_data->is_fw_dw_rsvd_page_in_progress = false;
+	hal_data->is_fw_dw_rsvd_page_in_progress = false;
 }
 
 void
 hal_txbf_8822b_fw_txbf_cmd(
-	struct _ADAPTER	*adapter
+	void	*adapter
 )
 {
 	u8	idx, period = 0;
 	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
 	u8	u1_tx_bf_parm[3] = {0};
 
-	PMGNT_INFO				p_mgnt_info = &(adapter->MgntInfo);
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = GET_BEAMFORM_INFO(adapter);
+	PMGNT_INFO				mgnt_info = &(adapter->MgntInfo);
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
 
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		if (p_beam_info->beamformee_entry[idx].is_used && p_beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (p_beam_info->beamformee_entry[idx].is_sound) {
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beam_info->beamformee_entry[idx].is_sound) {
 				PageNum0 = 0xFE;
 				PageNum1 = 0x07;
-				period = (u8)(p_beam_info->beamformee_entry[idx].sound_period);
+				period = (u8)(beam_info->beamformee_entry[idx].sound_period);
 			} else if (PageNum0 == 0xFF) {
 				PageNum0 = 0xFF; /*stop sounding*/
 				PageNum1 = 0x0F;
@@ -284,108 +276,107 @@ hal_txbf_8822b_fw_txbf_cmd(
 #if 0
 void
 hal_txbf_8822b_init(
-	void			*p_dm_void
+	void			*dm_void
 )
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct	*dm = (struct dm_struct *)dm_void;
 	u8		u1b_tmp;
-	struct _RT_BEAMFORMING_INFO		*p_beamforming_info = &p_dm->beamforming_info;
-	struct _ADAPTER				*adapter = p_dm->adapter;
+	struct _RT_BEAMFORMING_INFO		*beamforming_info = &dm->beamforming_info;
+	void				*adapter = dm->adapter;
 
-	odm_set_bb_reg(p_dm, 0x14c0, BIT(16), 1); /*Enable P1 aggr new packet according to P0 transfer time*/
-	odm_set_bb_reg(p_dm, 0x14c0, BIT(15) | BIT14 | BIT13 | BIT12, 10); /*MU Retry Limit*/
-	odm_set_bb_reg(p_dm, 0x14c0, BIT(7), 0); /*Disable Tx MU-MIMO until sounding done*/
-	odm_set_bb_reg(p_dm, 0x14c0, 0x3F, 0); /* Clear validity of MU STAs */
-	odm_write_1byte(p_dm, 0x167c, 0x70); /*MU-MIMO Option as default value*/
-	odm_write_2byte(p_dm, 0x1680, 0); /*MU-MIMO Control as default value*/
+	odm_set_bb_reg(dm, R_0x14c0, BIT(16), 1); /*@Enable P1 aggr new packet according to P0 transfer time*/
+	odm_set_bb_reg(dm, R_0x14c0, BIT(15) | BIT14 | BIT13 | BIT12, 10); /*@MU Retry Limit*/
+	odm_set_bb_reg(dm, R_0x14c0, BIT(7), 0); /*@Disable Tx MU-MIMO until sounding done*/
+	odm_set_bb_reg(dm, R_0x14c0, 0x3F, 0); /* @Clear validity of MU STAs */
+	odm_write_1byte(dm, 0x167c, 0x70); /*@MU-MIMO Option as default value*/
+	odm_write_2byte(dm, 0x1680, 0); /*@MU-MIMO Control as default value*/
 
 	/* Set MU NDPA rate & BW source */
-	/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
-	u1b_tmp = odm_read_1byte(p_dm, 0x42C);
-	odm_write_1byte(p_dm, REG_TXBF_CTRL_8822B, (u1b_tmp | BIT(6)));
-	/* 0x45F[7:0] = 0x10 (rate=OFDM_6M, BW20) */
-	odm_write_1byte(p_dm, REG_NDPA_OPT_CTRL_8822B, 0x10);
+	/* @0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+	u1b_tmp = odm_read_1byte(dm, 0x42C);
+	odm_write_1byte(dm, REG_TXBF_CTRL_8822B, (u1b_tmp | BIT(6)));
+	/* @0x45F[7:0] = 0x10 (rate=OFDM_6M, BW20) */
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8822B, 0x10);
 
 	/*Temp Settings*/
-	odm_set_bb_reg(p_dm, 0x6DC, 0x3F000000, 4); /*STA2's CSI rate is fixed at 6M*/
-	odm_set_bb_reg(p_dm, 0x1C94, MASKDWORD, 0xAFFFAFFF); /*Grouping bitmap parameters*/
+	odm_set_bb_reg(dm, R_0x6dc, 0x3F000000, 4); /*STA2's CSI rate is fixed at 6M*/
+	odm_set_bb_reg(dm, R_0x1c94, MASKDWORD, 0xAFFFAFFF); /*@Grouping bitmap parameters*/
 
-	/* Init HW variable */
-	p_beamforming_info->reg_mu_tx_ctrl = odm_read_4byte(p_dm, 0x14c0);
+	/* @Init HW variable */
+	beamforming_info->reg_mu_tx_ctrl = odm_read_4byte(dm, 0x14c0);
 
-	if (p_dm->rf_type == RF_2T2R) { /*2T2R*/
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s: rf_type is 2T2R\n", __func__));
-		config_phydm_trx_mode_8822b(p_dm, (enum bb_path)3, (enum bb_path)3, true);/*Tx2path*/
+	if (dm->rf_type == RF_2T2R) { /*@2T2R*/
+		PHYDM_DBG(dm, DBG_TXBF, "%s: rf_type is 2T2R\n", __func__);
+		config_phydm_trx_mode_8822b(dm, (enum bb_path)3, (enum bb_path)3, true);/*Tx2path*/
 	}
 
 #if (OMNIPEEK_SNIFFER_ENABLED == 1)
-	/* Config HW to receive packet on the user position from registry for sniffer mode. */
-	/* odm_set_bb_reg(p_dm, 0xB00, BIT(9), 1);*/ /* For A-cut only. RegB00[9] = 1 (enable PMAC Rx) */
-	odm_set_bb_reg(p_dm, 0xB54, BIT(30), 1); /* RegB54[30] = 1 (force user position) */
-	odm_set_bb_reg(p_dm, 0xB54, (BIT(29) | BIT28), adapter->MgntInfo.sniff_user_position); /* RegB54[29:28] = user position (0~3) */
-	PHYDM_DBG(p_dm, DBG_TXBF, ("Set adapter->MgntInfo.sniff_user_position=%#X\n", adapter->MgntInfo.sniff_user_position));
+	/* @Config HW to receive packet on the user position from registry for sniffer mode. */
+	/* odm_set_bb_reg(dm, R_0xb00, BIT(9), 1);*/ /* For A-cut only. RegB00[9] = 1 (enable PMAC Rx) */
+	odm_set_bb_reg(dm, R_0xb54, BIT(30), 1); /* RegB54[30] = 1 (force user position) */
+	odm_set_bb_reg(dm, R_0xb54, (BIT(29) | BIT28), adapter->MgntInfo.sniff_user_position); /* RegB54[29:28] = user position (0~3) */
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "Set adapter->MgntInfo.sniff_user_position=%#X\n",
+		  adapter->MgntInfo.sniff_user_position);
 #endif
 }
 #endif
 
-void
-hal_txbf_8822b_enter(
-	void			*p_dm_void,
-	u8				bfer_bfee_idx
-)
+void hal_txbf_8822b_enter(
+	void *dm_void,
+	u8 bfer_bfee_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8					i = 0;
-	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
-	u8					bfee_idx = (bfer_bfee_idx & 0xF);
-	u16					csi_param = 0;
-	struct _RT_BEAMFORMING_INFO		*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamformee_entry;
-	struct _RT_BEAMFORMER_ENTRY	*p_beamformer_entry;
-	u16					value16, sta_id = 0;
-	u8					nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
-	u32					gid_valid, user_position_l, user_position_h;
-	u32					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
-	u8					u1b_tmp;
-	u32					u4b_tmp;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	u8 bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8 bfee_idx = (bfer_bfee_idx & 0xF);
+	u16 csi_param = 0;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *p_beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY *beamformer_entry;
+	u16 value16, sta_id = 0;
+	u8 nc_index = 0, nr_index = 0, grouping = 0, codebookinfo = 0, coefficientsize = 0;
+	u32 gid_valid, user_position_l, user_position_h;
+	u32 mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
+	u8 u1b_tmp;
+	u32 u4b_tmp;
 
 	RT_DISP(FBEAM, FBEAM_FUN, ("%s: bfer_bfee_idx=%d, bfer_idx=%d, bfee_idx=%d\n", __func__, bfer_bfee_idx, bfer_idx, bfee_idx));
 
 	/*************SU BFer Entry Init*************/
-	if ((p_beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
-		p_beamformer_entry = &p_beamforming_info->beamformer_entry[bfer_idx];
-		p_beamformer_entry->is_mu_ap = false;
+	if (beamforming_info->beamformer_su_cnt > 0 && bfer_idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = &beamforming_info->beamformer_entry[bfer_idx];
+		beamformer_entry->is_mu_ap = false;
 		/*Sounding protocol control*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
-
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
 
 		for (i = 0; i < MAX_BEAMFORMER_SU; i++) {
-			if ((p_beamforming_info->beamformer_su_reg_maping & BIT(i)) == 0) {
-				p_beamforming_info->beamformer_su_reg_maping |= BIT(i);
-				p_beamformer_entry->su_reg_index = i;
+			if ((beamforming_info->beamformer_su_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformer_su_reg_maping |= BIT(i);
+				beamformer_entry->su_reg_index = i;
 				break;
 			}
 		}
 
-		/*MAC address/Partial AID of Beamformer*/
-		if (p_beamformer_entry->su_reg_index == 0) {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), p_beamformer_entry->mac_addr[i]);
+		/*@MAC address/Partial AID of Beamformer*/
+		if (beamformer_entry->su_reg_index == 0) {
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), beamformer_entry->mac_addr[i]);
 		} else {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_ASSOCIATED_BFMER1_INFO_8822B + i), p_beamformer_entry->mac_addr[i]);
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_ASSOCIATED_BFMER1_INFO_8822B + i), beamformer_entry->mac_addr[i]);
 		}
 
-		/*CSI report parameters of Beamformer*/
-		nc_index = hal_txbf_8822b_get_nrx(p_dm);	/*for 8814A nrx = 3(4 ant), min=0(1 ant)*/
-		nr_index = p_beamformer_entry->num_of_sounding_dim;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+		/*@CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8822b_get_nrx(dm); /*@for 8814A nrx = 3(4 ant), min=0(1 ant)*/
+		nr_index = beamformer_entry->num_of_sounding_dim; /*@0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
 
 		grouping = 0;
 
-		/*for ac = 1, for n = 3*/
-		if (p_beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU)
+		/*@for ac = 1, for n = 3*/
+		if (beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU)
 			codebookinfo = 1;
-		else if (p_beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
+		else if (beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
 			codebookinfo = 3;
 
 		coefficientsize = 3;
@@ -393,28 +384,27 @@ hal_txbf_8822b_enter(
 		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
 
 		if (bfer_idx == 0)
-			odm_write_2byte(p_dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, csi_param);
+			odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, csi_param);
 		else
-			odm_write_2byte(p_dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, csi_param);
+			odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, csi_param);
 		/*ndp_rx_standby_timer, 8814 need > 0x56, suggest from Dvaid*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8822B + 3, 0x70);
-
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B + 3, 0x70);
 	}
 
 	/*************SU BFee Entry Init*************/
-	if ((p_beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
-		p_beamformee_entry = &p_beamforming_info->beamformee_entry[bfee_idx];
+	if (beamforming_info->beamformee_su_cnt > 0 && bfee_idx < BEAMFORMEE_ENTRY_NUM) {
+		p_beamformee_entry = &beamforming_info->beamformee_entry[bfee_idx];
 		p_beamformee_entry->is_mu_sta = false;
-		hal_txbf_8822b_rf_mode(p_dm, p_beamforming_info, bfee_idx);
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, bfee_idx);
 
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
 			sta_id = p_beamformee_entry->mac_id;
 		else
 			sta_id = p_beamformee_entry->p_aid;
 
 		for (i = 0; i < MAX_BEAMFORMEE_SU; i++) {
-			if ((p_beamforming_info->beamformee_su_reg_maping & BIT(i)) == 0) {
-				p_beamforming_info->beamformee_su_reg_maping |= BIT(i);
+			if ((beamforming_info->beamformee_su_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformee_su_reg_maping |= BIT(i);
 				p_beamformee_entry->su_reg_index = i;
 				break;
 			}
@@ -422,83 +412,82 @@ hal_txbf_8822b_enter(
 
 		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
 		if (p_beamformee_entry->su_reg_index == 0) {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8822B, sta_id);
-			odm_write_1byte(p_dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(p_dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8822B, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
 		} else
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8822B + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8822B + 2, sta_id | BIT(14) | BIT(15) | BIT(12));
 
-		/*CSI report parameters of Beamformee*/
+		/*@CSI report parameters of Beamformee*/
 		if (p_beamformee_entry->su_reg_index == 0) {
-			/*Get BIT24 & BIT25*/
-			u8	tmp = odm_read_1byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3) & 0x3;
+			/*@Get BIT24 & BIT25*/
+			u8 tmp = odm_read_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3) & 0x3;
 
-			odm_write_1byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3, tmp | 0x60);
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8822B, sta_id | BIT(9));
+			odm_write_1byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B, sta_id | BIT(9));
 		} else
-			odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2, sta_id | 0xE200);	/*Set BIT25*/
+			odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2, sta_id | 0xE200); /*Set BIT25*/
 
-		phydm_beamforming_notify(p_dm);
+		phydm_beamforming_notify(dm);
 	}
 
 	/*************MU BFer Entry Init*************/
-	if ((p_beamforming_info->beamformer_mu_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
-		p_beamformer_entry = &p_beamforming_info->beamformer_entry[bfer_idx];
-		p_beamforming_info->mu_ap_index = bfer_idx;
-		p_beamformer_entry->is_mu_ap = true;
+	if (beamforming_info->beamformer_mu_cnt > 0 && bfer_idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = &beamforming_info->beamformer_entry[bfer_idx];
+		beamforming_info->mu_ap_index = bfer_idx;
+		beamformer_entry->is_mu_ap = true;
 		for (i = 0; i < 8; i++)
-			p_beamformer_entry->gid_valid[i] = 0;
+			beamformer_entry->gid_valid[i] = 0;
 		for (i = 0; i < 16; i++)
-			p_beamformer_entry->user_position[i] = 0;
+			beamformer_entry->user_position[i] = 0;
 
 		/*Sounding protocol control*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
 
-		/* MAC address */
-		for (i = 0; i < 6 ; i++)
-			odm_write_1byte(p_dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), p_beamformer_entry->mac_addr[i]);
+		/* @MAC address */
+		for (i = 0; i < 6; i++)
+			odm_write_1byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + i), beamformer_entry->mac_addr[i]);
 
 		/* Set partial AID */
-		odm_write_2byte(p_dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + 6), p_beamformer_entry->p_aid);
+		odm_write_2byte(dm, (REG_ASSOCIATED_BFMER0_INFO_8822B + 6), beamformer_entry->p_aid);
 
-		/* Fill our AID to 0x1680[11:0] and [13:12] = 2b'00, BF report segment select to 3895 bytes*/
-		u1b_tmp = odm_read_1byte(p_dm, 0x1680);
-		u1b_tmp = (p_beamformer_entry->p_aid) & 0xFFF;
-		odm_write_1byte(p_dm, 0x1680, u1b_tmp);
+		/* @Fill our AID to 0x1680[11:0] and [13:12] = 2b'00, BF report segment select to 3895 bytes*/
+		u1b_tmp = odm_read_1byte(dm, 0x1680);
+		u1b_tmp = (beamformer_entry->p_aid) & 0xFFF;
+		odm_write_1byte(dm, 0x1680, u1b_tmp);
 
 		/* Set 80us for leaving ndp_rx_standby_state */
-		odm_write_1byte(p_dm, 0x71B, 0x50);
+		odm_write_1byte(dm, 0x71B, 0x50);
 
 		/* Set 0x6A0[14] = 1 to accept action_no_ack */
-		u1b_tmp = odm_read_1byte(p_dm, REG_RXFLTMAP0_8822B + 1);
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP0_8822B + 1);
 		u1b_tmp |= 0x40;
-		odm_write_1byte(p_dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
+		odm_write_1byte(dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
 		/* Set 0x6A2[5:4] = 1 to NDPA and BF report poll */
-		u1b_tmp = odm_read_1byte(p_dm, REG_RXFLTMAP1_8822B);
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP1_8822B);
 		u1b_tmp |= 0x30;
-		odm_write_1byte(p_dm, REG_RXFLTMAP1_8822B, u1b_tmp);
+		odm_write_1byte(dm, REG_RXFLTMAP1_8822B, u1b_tmp);
 
-		/*CSI report parameters of Beamformer*/
-		nc_index = hal_txbf_8822b_get_nrx(p_dm);	/* Depend on RF type */
-		nr_index = 1;	/*0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
+		/*@CSI report parameters of Beamformer*/
+		nc_index = hal_txbf_8822b_get_nrx(dm); /* @Depend on RF type */
+		nr_index = 1; /*@0x718[7] = 1 use Nsts, 0x718[7] = 0 use reg setting. as Bfee, we use Nsts, so nr_index don't care*/
 		grouping = 0; /*no grouping*/
-		codebookinfo = 1; /*7 bit for psi, 9 bit for phi*/
+		codebookinfo = 1; /*@7 bit for psi, 9 bit for phi*/
 		coefficientsize = 0; /*This is nothing really matter*/
 		csi_param = (u16)((coefficientsize << 10) | (codebookinfo << 8) | (grouping << 6) | (nr_index << 3) | (nc_index));
-		odm_write_2byte(p_dm, 0x6F4, csi_param);
-
-		/*for B-cut*/
-		odm_set_bb_reg(p_dm, 0x6A0, BIT(20), 0);
-		odm_set_bb_reg(p_dm, 0x688, BIT(20), 0);
+		odm_write_2byte(dm, 0x6F4, csi_param);
 
+		/*@for B-cut*/
+		odm_set_bb_reg(dm, R_0x6a0, BIT(20), 0);
+		odm_set_bb_reg(dm, R_0x688, BIT(20), 0);
 	}
 
 	/*************MU BFee Entry Init*************/
-	if ((p_beamforming_info->beamformee_mu_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
-		p_beamformee_entry = &p_beamforming_info->beamformee_entry[bfee_idx];
+	if (beamforming_info->beamformee_mu_cnt > 0 && bfee_idx < BEAMFORMEE_ENTRY_NUM) {
+		p_beamformee_entry = &beamforming_info->beamformee_entry[bfee_idx];
 		p_beamformee_entry->is_mu_sta = true;
 		for (i = 0; i < MAX_BEAMFORMEE_MU; i++) {
-			if ((p_beamforming_info->beamformee_mu_reg_maping & BIT(i)) == 0) {
-				p_beamforming_info->beamformee_mu_reg_maping |= BIT(i);
+			if ((beamforming_info->beamformee_mu_reg_maping & BIT(i)) == 0) {
+				beamforming_info->beamformee_mu_reg_maping |= BIT(i);
 				p_beamformee_entry->mu_reg_index = i;
 				break;
 			}
@@ -561,173 +550,170 @@ hal_txbf_8822b_enter(
 		}
 
 		/*Sounding protocol control*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xDB);
 
 		/*select MU STA table*/
-		p_beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
-		p_beamforming_info->reg_mu_tx_ctrl |= (p_beamformee_entry->mu_reg_index << 8) & (BIT(8) | BIT(9) | BIT(10));
-		odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
+		beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+		beamforming_info->reg_mu_tx_ctrl |= (p_beamformee_entry->mu_reg_index << 8) & (BIT(8) | BIT(9) | BIT(10));
+		odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
 
-		odm_set_bb_reg(p_dm, 0x14c4, MASKDWORD, 0); /*Reset gid_valid table*/
-		odm_set_bb_reg(p_dm, 0x14c8, MASKDWORD, user_position_l);
-		odm_set_bb_reg(p_dm, 0x14cc, MASKDWORD, user_position_h);
+		odm_set_bb_reg(dm, R_0x14c4, MASKDWORD, 0); /*Reset gid_valid table*/
+		odm_set_bb_reg(dm, R_0x14c8, MASKDWORD, user_position_l);
+		odm_set_bb_reg(dm, R_0x14cc, MASKDWORD, user_position_h);
 
 		/*set validity of MU STAs*/
-		p_beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
-		p_beamforming_info->reg_mu_tx_ctrl |= p_beamforming_info->beamformee_mu_reg_maping & 0x3F;
-		odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
-
-		PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, reg_mu_tx_ctrl = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
-			__func__, p_beamforming_info->reg_mu_tx_ctrl, user_position_l, user_position_h));
-
-		value16 = odm_read_2byte(p_dm, mu_reg[p_beamformee_entry->mu_reg_index]);
-		value16 &= 0xFE00; /*Clear PAID*/
-		value16 |= BIT(9); /*Enable MU BFee*/
+		beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+		beamforming_info->reg_mu_tx_ctrl |= beamforming_info->beamformee_mu_reg_maping & 0x3F;
+		odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "@%s, reg_mu_tx_ctrl = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+			  __func__, beamforming_info->reg_mu_tx_ctrl,
+			  user_position_l, user_position_h);
+
+		value16 = odm_read_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index]);
+		value16 &= 0xFE00; /*@Clear PAID*/
+		value16 |= BIT(9); /*@Enable MU BFee*/
 		value16 |= p_beamformee_entry->p_aid;
-		odm_write_2byte(p_dm, mu_reg[p_beamformee_entry->mu_reg_index], value16);
+		odm_write_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index], value16);
 
-		/* 0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
-		u1b_tmp = odm_read_1byte(p_dm, REG_TXBF_CTRL_8822B + 3);
+		/* @0x42C[30] = 1 (0: from Tx desc, 1: from 0x45F) */
+		u1b_tmp = odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3);
 		u1b_tmp |= 0xD0; /* Set bit 28, 30, 31 to 3b'111*/
-		odm_write_1byte(p_dm, REG_TXBF_CTRL_8822B + 3, u1b_tmp);
+		odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, u1b_tmp);
 		/* Set NDPA to 6M*/
-		odm_write_1byte(p_dm, REG_NDPA_RATE_8822B, 0x4);
+		odm_write_1byte(dm, REG_NDPA_RATE_8822B, 0x4);
 
-		u1b_tmp = odm_read_1byte(p_dm, REG_NDPA_OPT_CTRL_8822B);
-		u1b_tmp &= 0xFC; /* Clear bit 0, 1*/
-		odm_write_1byte(p_dm, REG_NDPA_OPT_CTRL_8822B, u1b_tmp);
+		u1b_tmp = odm_read_1byte(dm, REG_NDPA_OPT_CTRL_8822B);
+		u1b_tmp &= 0xFC; /* @Clear bit 0, 1*/
+		odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8822B, u1b_tmp);
 
-		u4b_tmp = odm_read_4byte(p_dm, REG_SND_PTCL_CTRL_8822B);
+		u4b_tmp = odm_read_4byte(dm, REG_SND_PTCL_CTRL_8822B);
 		u4b_tmp = ((u4b_tmp & 0xFF0000FF) | 0x020200); /* Set [23:8] to 0x0202*/
-		odm_write_4byte(p_dm, REG_SND_PTCL_CTRL_8822B, u4b_tmp);
+		odm_write_4byte(dm, REG_SND_PTCL_CTRL_8822B, u4b_tmp);
 
 		/* Set 0x6A0[14] = 1 to accept action_no_ack */
-		u1b_tmp = odm_read_1byte(p_dm, REG_RXFLTMAP0_8822B + 1);
+		u1b_tmp = odm_read_1byte(dm, REG_RXFLTMAP0_8822B + 1);
 		u1b_tmp |= 0x40;
-		odm_write_1byte(p_dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
-		/* End of MAC registers setting */
+		odm_write_1byte(dm, REG_RXFLTMAP0_8822B + 1, u1b_tmp);
+		/* @End of MAC registers setting */
 
-		hal_txbf_8822b_rf_mode(p_dm, p_beamforming_info, bfee_idx);
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, bfee_idx);
 #if (SUPPORT_MU_BF == 1)
 		/*Special for plugfest*/
 		delay_ms(50); /* wait for 4-way handshake ending*/
-		send_sw_vht_gid_mgnt_frame(p_dm, p_beamformee_entry->mac_addr, bfee_idx);
+		send_sw_vht_gid_mgnt_frame(dm, p_beamformee_entry->mac_addr, bfee_idx);
 #endif
 
-		phydm_beamforming_notify(p_dm);
+		phydm_beamforming_notify(dm);
 #if 1
 		{
 			u32 ctrl_info_offset, index;
 			/*Set Ctrl Info*/
-			odm_write_2byte(p_dm, 0x140, 0x660);
+			odm_write_2byte(dm, 0x140, 0x660);
 			ctrl_info_offset = 0x8000 + 32 * p_beamformee_entry->mac_id;
 			/*Reset Ctrl Info*/
 			for (index = 0; index < 8; index++)
-				odm_write_4byte(p_dm, ctrl_info_offset + index * 4, 0);
+				odm_write_4byte(dm, ctrl_info_offset + index * 4, 0);
 
-			odm_write_4byte(p_dm, ctrl_info_offset, (p_beamformee_entry->mu_reg_index + 1) << 16);
-			odm_write_1byte(p_dm, 0x81, 0x80); /*RPTBUF ready*/
+			odm_write_4byte(dm, ctrl_info_offset, (p_beamformee_entry->mu_reg_index + 1) << 16);
+			odm_write_1byte(dm, 0x81, 0x80); /*RPTBUF ready*/
 
-			PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, mac_id = %d, ctrl_info_offset = 0x%x, mu_reg_index = %x\n",
-				__func__, p_beamformee_entry->mac_id, ctrl_info_offset, p_beamformee_entry->mu_reg_index));
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "@%s, mac_id = %d, ctrl_info_offset = 0x%x, mu_reg_index = %x\n",
+				  __func__, p_beamformee_entry->mac_id,
+				  ctrl_info_offset,
+				  p_beamformee_entry->mu_reg_index);
 		}
 #endif
 	}
-
 }
 
-
-void
-hal_txbf_8822b_leave(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8822b_leave(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMER_ENTRY	*p_beamformer_entry;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamformee_entry;
-	u32					mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY *beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY *p_beamformee_entry;
+	u32 mu_reg[6] = {0x1684, 0x1686, 0x1688, 0x168a, 0x168c, 0x168e};
 
 	if (idx < BEAMFORMER_ENTRY_NUM) {
-		p_beamformer_entry = &p_beamforming_info->beamformer_entry[idx];
-		p_beamformee_entry = &p_beamforming_info->beamformee_entry[idx];
+		beamformer_entry = &beamforming_info->beamformer_entry[idx];
+		p_beamformee_entry = &beamforming_info->beamformee_entry[idx];
 	} else
 		return;
 
-	/*Clear P_AID of Beamformee*/
-	/*Clear MAC address of Beamformer*/
-	/*Clear Associated Bfmee Sel*/
-
-	if (p_beamformer_entry->beamform_entry_cap == BEAMFORMING_CAP_NONE) {
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8822B, 0xD8);
-		if (p_beamformer_entry->is_mu_ap == 0) { /*SU BFer */
-			if (p_beamformer_entry->su_reg_index == 0) {
-				odm_write_4byte(p_dm, REG_ASSOCIATED_BFMER0_INFO_8822B, 0);
-				odm_write_2byte(p_dm, REG_ASSOCIATED_BFMER0_INFO_8822B + 4, 0);
-				odm_write_2byte(p_dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, 0);
+	/*@Clear P_AID of Beamformee*/
+	/*@Clear MAC address of Beamformer*/
+	/*@Clear Associated Bfmee Sel*/
+
+	if (beamformer_entry->beamform_entry_cap == BEAMFORMING_CAP_NONE) {
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8822B, 0xD8);
+		if (beamformer_entry->is_mu_ap == 0) { /*SU BFer */
+			if (beamformer_entry->su_reg_index == 0) {
+				odm_write_4byte(dm, REG_ASSOCIATED_BFMER0_INFO_8822B, 0);
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMER0_INFO_8822B + 4, 0);
+				odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B, 0);
 			} else {
-				odm_write_4byte(p_dm, REG_ASSOCIATED_BFMER1_INFO_8822B, 0);
-				odm_write_2byte(p_dm, REG_ASSOCIATED_BFMER1_INFO_8822B + 4, 0);
-				odm_write_2byte(p_dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, 0);
+				odm_write_4byte(dm, REG_ASSOCIATED_BFMER1_INFO_8822B, 0);
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMER1_INFO_8822B + 4, 0);
+				odm_write_2byte(dm, REG_TX_CSI_RPT_PARAM_BW20_8822B + 2, 0);
 			}
-			p_beamforming_info->beamformer_su_reg_maping &= ~(BIT(p_beamformer_entry->su_reg_index));
-			p_beamformer_entry->su_reg_index = 0xFF;
-		} else { /*MU BFer */
+			beamforming_info->beamformer_su_reg_maping &= ~(BIT(beamformer_entry->su_reg_index));
+			beamformer_entry->su_reg_index = 0xFF;
+		} else { /*@MU BFer */
 			/*set validity of MU STA0 and MU STA1*/
-			p_beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
-			odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
+			beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
 
-			odm_memory_set(p_dm, p_beamformer_entry->gid_valid, 0, 8);
-			odm_memory_set(p_dm, p_beamformer_entry->user_position, 0, 16);
-			p_beamformer_entry->is_mu_ap = false;
+			odm_memory_set(dm, beamformer_entry->gid_valid, 0, 8);
+			odm_memory_set(dm, beamformer_entry->user_position, 0, 16);
+			beamformer_entry->is_mu_ap = false;
 		}
 	}
 
 	if (p_beamformee_entry->beamform_entry_cap == BEAMFORMING_CAP_NONE) {
-		hal_txbf_8822b_rf_mode(p_dm, p_beamforming_info, idx);
+		hal_txbf_8822b_rf_mode(dm, beamforming_info, idx);
 		if (p_beamformee_entry->is_mu_sta == 0) { /*SU BFee*/
 			if (p_beamformee_entry->su_reg_index == 0) {
-				odm_write_2byte(p_dm, REG_TXBF_CTRL_8822B, 0x0);
-				odm_write_1byte(p_dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(p_dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
-				odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8822B, 0);
+				odm_write_2byte(dm, REG_TXBF_CTRL_8822B, 0x0);
+				odm_write_1byte(dm, REG_TXBF_CTRL_8822B + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8822B + 3) | BIT(4) | BIT(6) | BIT(7));
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B, 0);
 			} else {
-				odm_write_2byte(p_dm, REG_TXBF_CTRL_8822B + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
+				odm_write_2byte(dm, REG_TXBF_CTRL_8822B + 2, 0x0 | BIT(14) | BIT(15) | BIT(12));
 
-				odm_write_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2,
-					odm_read_2byte(p_dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2) & 0x60);
+				odm_write_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2,
+						odm_read_2byte(dm, REG_ASSOCIATED_BFMEE_SEL_8822B + 2) & 0x60);
 			}
-			p_beamforming_info->beamformee_su_reg_maping &= ~(BIT(p_beamformee_entry->su_reg_index));
+			beamforming_info->beamformee_su_reg_maping &= ~(BIT(p_beamformee_entry->su_reg_index));
 			p_beamformee_entry->su_reg_index = 0xFF;
-		} else { /*MU BFee */
-			/*Disable sending NDPA & BF-rpt-poll to this BFee*/
-			odm_write_2byte(p_dm, mu_reg[p_beamformee_entry->mu_reg_index], 0);
+		} else { /*@MU BFee */
+			/*@Disable sending NDPA & BF-rpt-poll to this BFee*/
+			odm_write_2byte(dm, mu_reg[p_beamformee_entry->mu_reg_index], 0);
 			/*set validity of MU STA*/
-			p_beamforming_info->reg_mu_tx_ctrl &= ~(BIT(p_beamformee_entry->mu_reg_index));
-			odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
-
+			beamforming_info->reg_mu_tx_ctrl &= ~(BIT(p_beamformee_entry->mu_reg_index));
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
 
 			p_beamformee_entry->is_mu_sta = false;
-			p_beamforming_info->beamformee_mu_reg_maping &= ~(BIT(p_beamformee_entry->mu_reg_index));
+			beamforming_info->beamformee_mu_reg_maping &= ~(BIT(p_beamformee_entry->mu_reg_index));
 			p_beamformee_entry->mu_reg_index = 0xFF;
 		}
 	}
 }
 
-
 /***********SU & MU BFee Entry Only when souding done****************/
-void
-hal_txbf_8822b_status(
-	void			*p_dm_void,
-	u8				beamform_idx
-)
+void hal_txbf_8822b_status(
+	void *dm_void,
+	u8 beamform_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u16					beam_ctrl_val, tmp_val;
-	u32					beam_ctrl_reg;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry;
-	boolean	is_mu_sounding = p_beamforming_info->is_mu_sounding, is_bitmap_ready = false;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 beam_ctrl_val, tmp_val;
+	u32 beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry;
+	boolean is_mu_sounding = beamforming_info->is_mu_sounding, is_bitmap_ready = false;
 	u16 bitmap;
 	u8 idx, gid, i;
 	u8 id1, id0;
@@ -736,82 +722,92 @@ hal_txbf_8822b_status(
 	boolean is_sounding_success[6] = {false};
 
 	if (beamform_idx < BEAMFORMEE_ENTRY_NUM)
-		p_beamform_entry = &p_beamforming_info->beamformee_entry[beamform_idx];
+		beamform_entry = &beamforming_info->beamformee_entry[beamform_idx];
 	else
 		return;
 
 	/*SU sounding done */
 	if (is_mu_sounding == false) {
-
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
-			beam_ctrl_val = p_beamform_entry->mac_id;
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
+			beam_ctrl_val = beamform_entry->mac_id;
 		else
-			beam_ctrl_val = p_beamform_entry->p_aid;
+			beam_ctrl_val = beamform_entry->p_aid;
 
-		PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, beamform_entry.beamform_entry_state = %d", __func__, p_beamform_entry->beamform_entry_state));
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "@%s, beamform_entry.beamform_entry_state = %d",
+			  __func__, beamform_entry->beamform_entry_state);
 
-		if (p_beamform_entry->su_reg_index == 0)
+		if (beamform_entry->su_reg_index == 0)
 			beam_ctrl_reg = REG_TXBF_CTRL_8822B;
 		else {
 			beam_ctrl_reg = REG_TXBF_CTRL_8822B + 2;
 			beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
 		}
 
-		if (p_beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
-			if (p_beamform_entry->sound_bw == CHANNEL_WIDTH_20)
+		if (beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+			if (beamform_entry->sound_bw == CHANNEL_WIDTH_20)
 				beam_ctrl_val |= BIT(9);
-			else if (p_beamform_entry->sound_bw == CHANNEL_WIDTH_40)
+			else if (beamform_entry->sound_bw == CHANNEL_WIDTH_40)
 				beam_ctrl_val |= (BIT(9) | BIT(10));
-			else if (p_beamform_entry->sound_bw == CHANNEL_WIDTH_80)
+			else if (beamform_entry->sound_bw == CHANNEL_WIDTH_80)
 				beam_ctrl_val |= (BIT(9) | BIT(10) | BIT(11));
 		} else {
-			PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, Don't apply Vmatrix",  __func__));
+			PHYDM_DBG(dm, DBG_TXBF, "@%s, Don't apply Vmatrix",
+				  __func__);
 			beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
 		}
 
-		odm_write_2byte(p_dm, beam_ctrl_reg, beam_ctrl_val);
-		/*disable NDP packet use beamforming */
-		tmp_val = odm_read_2byte(p_dm, REG_TXBF_CTRL_8822B);
-		odm_write_2byte(p_dm, REG_TXBF_CTRL_8822B, tmp_val | BIT(15));
+		odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
+		/*@disable NDP packet use beamforming */
+		tmp_val = odm_read_2byte(dm, REG_TXBF_CTRL_8822B);
+		odm_write_2byte(dm, REG_TXBF_CTRL_8822B, tmp_val | BIT(15));
 	} else {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, MU Sounding Done\n",  __func__));
-		/*MU sounding done */
-		if (1) { /* (p_beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) { */
-			PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, BEAMFORMING_ENTRY_STATE_PROGRESSED\n",  __func__));
-
-			value32 = odm_get_bb_reg(p_dm, 0x1684, MASKDWORD);
+		PHYDM_DBG(dm, DBG_TXBF, "@%s, MU Sounding Done\n", __func__);
+		/*@MU sounding done */
+		if (1) { /* @(beamform_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) { */
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "@%s, BEAMFORMING_ENTRY_STATE_PROGRESSED\n",
+				  __func__);
+
+			value32 = odm_get_bb_reg(dm, R_0x1684, MASKDWORD);
 			is_sounding_success[0] = (value32 & BIT(10)) ? 1 : 0;
 			is_sounding_success[1] = (value32 & BIT(26)) ? 1 : 0;
-			value32 = odm_get_bb_reg(p_dm, 0x1688, MASKDWORD);
+			value32 = odm_get_bb_reg(dm, R_0x1688, MASKDWORD);
 			is_sounding_success[2] = (value32 & BIT(10)) ? 1 : 0;
 			is_sounding_success[3] = (value32 & BIT(26)) ? 1 : 0;
-			value32 = odm_get_bb_reg(p_dm, 0x168C, MASKDWORD);
+			value32 = odm_get_bb_reg(dm, R_0x168c, MASKDWORD);
 			is_sounding_success[4] = (value32 & BIT(10)) ? 1 : 0;
 			is_sounding_success[5] = (value32 & BIT(26)) ? 1 : 0;
 
-			PHYDM_DBG(p_dm, DBG_TXBF, ("@%s, is_sounding_success STA1:%d,  STA2:%d, STA3:%d, STA4:%d, STA5:%d, STA6:%d\n",
-				__func__, is_sounding_success[0], is_sounding_success[1], is_sounding_success[2], is_sounding_success[3], is_sounding_success[4], is_sounding_success[5]));
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "@%s, is_sounding_success STA1:%d,  STA2:%d, STA3:%d, STA4:%d, STA5:%d, STA6:%d\n",
+				  __func__, is_sounding_success[0],
+				  is_sounding_success[1],
+				  is_sounding_success[2],
+				  is_sounding_success[3],
+				  is_sounding_success[4],
+				  is_sounding_success[5]);
 
-			value32 = odm_get_bb_reg(p_dm, 0xF4C, 0xFFFF0000);
-			/* odm_set_bb_reg(p_dm, 0x19E0, MASKHWORD, 0xFFFF);Let MAC ignore bitmap */
+			value32 = odm_get_bb_reg(dm, R_0xf4c, 0xFFFF0000);
+			/* odm_set_bb_reg(dm, R_0x19e0, MASKHWORD, 0xFFFF);Let MAC ignore bitmap */
 
 			is_bitmap_ready = (boolean)((value32 & BIT(15)) >> 15);
 			bitmap = (u16)(value32 & 0x3FFF);
 
 			for (idx = 0; idx < 15; idx++) {
-				if (idx < 5) {/*bit0~4*/
+				if (idx < 5) { /*@bit0~4*/
 					id0 = 0;
 					id1 = (u8)(idx + 1);
-				} else if (idx < 9) { /*bit5~8*/
+				} else if (idx < 9) { /*@bit5~8*/
 					id0 = 1;
 					id1 = (u8)(idx - 3);
-				} else if (idx < 12) { /*bit9~11*/
+				} else if (idx < 12) { /*@bit9~11*/
 					id0 = 2;
 					id1 = (u8)(idx - 6);
-				} else if (idx < 14) { /*bit12~13*/
+				} else if (idx < 14) { /*@bit12~13*/
 					id0 = 3;
 					id1 = (u8)(idx - 8);
-				} else { /*bit14*/
+				} else { /*@bit14*/
 					id0 = 4;
 					id1 = (u8)(idx - 9);
 				}
@@ -837,108 +833,105 @@ hal_txbf_8822b_status(
 			}
 
 			for (i = 0; i < BEAMFORMEE_ENTRY_NUM; i++) {
-				p_beamform_entry = &p_beamforming_info->beamformee_entry[i];
-				if ((p_beamform_entry->is_mu_sta) && (p_beamform_entry->mu_reg_index < 6)) {
-					value32 = gid_valid[p_beamform_entry->mu_reg_index];
+				beamform_entry = &beamforming_info->beamformee_entry[i];
+				if (beamform_entry->is_mu_sta && beamform_entry->mu_reg_index < 6) {
+					value32 = gid_valid[beamform_entry->mu_reg_index];
 					for (idx = 0; idx < 4; idx++) {
-						p_beamform_entry->gid_valid[idx] = (u8)(value32 & 0xFF);
+						beamform_entry->gid_valid[idx] = (u8)(value32 & 0xFF);
 						value32 = (value32 >> 8);
 					}
 				}
 			}
 
 			for (idx = 0; idx < 6; idx++) {
-				p_beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
-				p_beamforming_info->reg_mu_tx_ctrl |= ((idx << 8) & (BIT(8) | BIT(9) | BIT(10)));
-				odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
-				odm_set_mac_reg(p_dm, 0x14C4, MASKDWORD, gid_valid[idx]); /*set MU STA gid valid table*/
+				beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+				beamforming_info->reg_mu_tx_ctrl |= ((idx << 8) & (BIT(8) | BIT(9) | BIT(10)));
+				odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+				odm_set_mac_reg(dm, R_0x14c4, MASKDWORD, gid_valid[idx]); /*set MU STA gid valid table*/
 			}
 
-			/*Enable TxMU PPDU*/
-			if (p_beamforming_info->dbg_disable_mu_tx == false)
-				p_beamforming_info->reg_mu_tx_ctrl |= BIT(7);
+			/*@Enable TxMU PPDU*/
+			if (beamforming_info->dbg_disable_mu_tx == false)
+				beamforming_info->reg_mu_tx_ctrl |= BIT(7);
 			else
-				p_beamforming_info->reg_mu_tx_ctrl &= ~BIT(7);
-			odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
+				beamforming_info->reg_mu_tx_ctrl &= ~BIT(7);
+			odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
 		}
 	}
 }
 
 /*Only used for MU BFer Entry when get GID management frame (self is as MU STA)*/
-void
-hal_txbf_8822b_config_gtab(
-	void			*p_dm_void
-)
+void hal_txbf_8822b_config_gtab(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMER_ENTRY	*p_beamformer_entry = NULL;
-	u32		gid_valid = 0, user_position_l = 0, user_position_h = 0, i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY *beamformer_entry = NULL;
+	u32 gid_valid = 0, user_position_l = 0, user_position_h = 0, i;
 
-	if (p_beamforming_info->mu_ap_index < BEAMFORMER_ENTRY_NUM)
-		p_beamformer_entry = &p_beamforming_info->beamformer_entry[p_beamforming_info->mu_ap_index];
+	if (beamforming_info->mu_ap_index < BEAMFORMER_ENTRY_NUM)
+		beamformer_entry = &beamforming_info->beamformer_entry[beamforming_info->mu_ap_index];
 	else
 		return;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s==>\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "%s==>\n", __func__);
 
-	/*For GID 0~31*/
+	/*@For GID 0~31*/
 	for (i = 0; i < 4; i++)
-		gid_valid |= (p_beamformer_entry->gid_valid[i] << (i << 3));
+		gid_valid |= (beamformer_entry->gid_valid[i] << (i << 3));
 	for (i = 0; i < 8; i++) {
 		if (i < 4)
-			user_position_l |= (p_beamformer_entry->user_position[i] << (i << 3));
+			user_position_l |= (beamformer_entry->user_position[i] << (i << 3));
 		else
-			user_position_h |= (p_beamformer_entry->user_position[i] << ((i - 4) << 3));
+			user_position_h |= (beamformer_entry->user_position[i] << ((i - 4) << 3));
 	}
 	/*select MU STA0 table*/
-	p_beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
-	odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
-	odm_set_bb_reg(p_dm, 0x14c4, MASKDWORD, gid_valid);
-	odm_set_bb_reg(p_dm, 0x14c8, MASKDWORD, user_position_l);
-	odm_set_bb_reg(p_dm, 0x14cc, MASKDWORD, user_position_h);
+	beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+	odm_set_bb_reg(dm, R_0x14c4, MASKDWORD, gid_valid);
+	odm_set_bb_reg(dm, R_0x14c8, MASKDWORD, user_position_l);
+	odm_set_bb_reg(dm, R_0x14cc, MASKDWORD, user_position_h);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s: STA0: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
-			__func__, gid_valid, user_position_l, user_position_h));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "%s: STA0: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+		  __func__, gid_valid, user_position_l, user_position_h);
 
 	gid_valid = 0;
 	user_position_l = 0;
 	user_position_h = 0;
 
-	/*For GID 32~64*/
+	/*@For GID 32~64*/
 	for (i = 4; i < 8; i++)
-		gid_valid |= (p_beamformer_entry->gid_valid[i] << ((i - 4) << 3));
+		gid_valid |= (beamformer_entry->gid_valid[i] << ((i - 4) << 3));
 	for (i = 8; i < 16; i++) {
 		if (i < 4)
-			user_position_l |= (p_beamformer_entry->user_position[i] << ((i - 8) << 3));
+			user_position_l |= (beamformer_entry->user_position[i] << ((i - 8) << 3));
 		else
-			user_position_h |= (p_beamformer_entry->user_position[i] << ((i - 12) << 3));
+			user_position_h |= (beamformer_entry->user_position[i] << ((i - 12) << 3));
 	}
 	/*select MU STA1 table*/
-	p_beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
-	p_beamforming_info->reg_mu_tx_ctrl |= BIT(8);
-	odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
-	odm_set_bb_reg(p_dm, 0x14c4, MASKDWORD, gid_valid);
-	odm_set_bb_reg(p_dm, 0x14c8, MASKDWORD, user_position_l);
-	odm_set_bb_reg(p_dm, 0x14cc, MASKDWORD, user_position_h);
+	beamforming_info->reg_mu_tx_ctrl &= ~(BIT(8) | BIT(9) | BIT(10));
+	beamforming_info->reg_mu_tx_ctrl |= BIT(8);
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
+	odm_set_bb_reg(dm, R_0x14c4, MASKDWORD, gid_valid);
+	odm_set_bb_reg(dm, R_0x14c8, MASKDWORD, user_position_l);
+	odm_set_bb_reg(dm, R_0x14cc, MASKDWORD, user_position_h);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("%s: STA1: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
-			__func__, gid_valid, user_position_l, user_position_h));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "%s: STA1: gid_valid = 0x%x, user_position_l = 0x%x, user_position_h = 0x%x\n",
+		  __func__, gid_valid, user_position_l, user_position_h);
 
 	/* Set validity of MU STA0 and MU STA1*/
-	p_beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
-	p_beamforming_info->reg_mu_tx_ctrl |= 0x3; /* STA0, STA1*/
-	odm_write_4byte(p_dm, 0x14c0, p_beamforming_info->reg_mu_tx_ctrl);
-
+	beamforming_info->reg_mu_tx_ctrl &= 0xFFFFFFC0;
+	beamforming_info->reg_mu_tx_ctrl |= 0x3; /* STA0, STA1*/
+	odm_write_4byte(dm, 0x14c0, beamforming_info->reg_mu_tx_ctrl);
 }
 
-
-
 #if 0
 /*This function translate the bitmap to GTAB*/
 void
 haltxbf8822b_gtab_translation(
-	struct PHY_DM_STRUCT			*p_dm
+	struct dm_struct			*dm
 )
 {
 	u8 idx, gid;
@@ -948,19 +941,19 @@ haltxbf8822b_gtab_translation(
 	u32 user_position_msb[6] = {0};
 
 	for (idx = 0; idx < 15; idx++) {
-		if (idx < 5) {/*bit0~4*/
+		if (idx < 5) {/*@bit0~4*/
 			id0 = 0;
 			id1 = (u8)(idx + 1);
-		} else if (idx < 9) { /*bit5~8*/
+		} else if (idx < 9) { /*@bit5~8*/
 			id0 = 1;
 			id1 = (u8)(idx - 3);
-		} else if (idx < 12) { /*bit9~11*/
+		} else if (idx < 12) { /*@bit9~11*/
 			id0 = 2;
 			id1 = (u8)(idx - 6);
-		} else if (idx < 14) { /*bit12~13*/
+		} else if (idx < 14) { /*@bit12~13*/
 			id0 = 3;
 			id1 = (u8)(idx - 8);
-		} else { /*bit14*/
+		} else { /*@bit14*/
 			id0 = 4;
 			id1 = (u8)(idx - 9);
 		}
@@ -988,26 +981,23 @@ haltxbf8822b_gtab_translation(
 			user_position_msb[id0] |= (1 << ((gid - 16) << 1));
 			/*user_position_msb[id1] |= (0 << ((gid - 16) << 1));*/
 		}
-
 	}
 
 
 	for (idx = 0; idx < 6; idx++) {
-		/*dbg_print("gid_valid[%d] = 0x%x\n", idx, gid_valid[idx]);
+		/*@dbg_print("gid_valid[%d] = 0x%x\n", idx, gid_valid[idx]);
 		dbg_print("user_position[%d] = 0x%x   %x\n", idx, user_position_msb[idx], user_position_lsb[idx]);*/
 	}
 }
 #endif
 
-void
-hal_txbf_8822b_fw_txbf(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_8822b_fw_txbf(
+	void *dm_void,
+	u8 idx)
 {
 #if 0
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = GET_BEAMFORM_INFO(adapter);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
+	struct _RT_BEAMFORMING_INFO	*beam_info = GET_BEAMFORM_INFO(adapter);
+	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = beam_info->beamformee_entry + idx;
 
 	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
 		hal_txbf_8822b_download_ndpa(adapter, idx);
@@ -1020,93 +1010,79 @@ hal_txbf_8822b_fw_txbf(
 
 #if (defined(CONFIG_BB_TXBF_API))
 /*this function is only used for BFer*/
-void
-phydm_8822btxbf_rfmode(
-	void		*p_dm_void,
-	u8	su_bfee_cnt,
-	u8	mu_bfee_cnt
-)
+void phydm_8822btxbf_rfmode(void *dm_void, u8 su_bfee_cnt, u8 mu_bfee_cnt)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		i;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i;
 
-	if (p_dm->rf_type == RF_1T1R)
+	if (dm->rf_type == RF_1T1R)
 		return;
 
-	if ((su_bfee_cnt > 0) || (mu_bfee_cnt > 0)) {
+	if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
 		for (i = RF_PATH_A; i <= RF_PATH_B; i++) {
-			odm_set_rf_reg(p_dm, (enum rf_path)i, 0xEF, BIT(19), 0x1); /*RF mode table write enable*/
-			odm_set_rf_reg(p_dm, (enum rf_path)i, 0x33, 0xF, 3); /*Select RX mode*/
-			odm_set_rf_reg(p_dm, (enum rf_path)i, 0x3E, 0xfffff, 0x00036); /*Set Table data*/
-			odm_set_rf_reg(p_dm, (enum rf_path)i, 0x3F, 0xfffff, 0x5AFCE); /*Set Table data*/
-			odm_set_rf_reg(p_dm, (enum rf_path)i, 0xEF, BIT(19), 0x0); /*RF mode table write disable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef, BIT(19), 0x1); /*RF mode table write enable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33, 0xF, 3); /*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3e, 0xfffff, 0x00036); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f, 0xfffff, 0x5AFCE); /*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef, BIT(19), 0x0); /*RF mode table write disable*/
 		}
 	}
 
-	odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(30), 1);			/*if Nsts > Nc, don't apply V matrix*/
+	odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(30), 1); /*@if Nsts > Nc, don't apply V matrix*/
 
 	if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
-		/*for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2);	/*enable BB TxBF ant mapping register*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1);			/*ignore user since 8822B only 2Tx*/
-		
+		/*@for 8814 19ac(idx 1), 19b4(idx 0), different Tx ant setting*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x2); /*@enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 1); /*@ignore user since 8822B only 2Tx*/
 
 		/*Nsts = 2	AB*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, 0xffff, 0x0433);
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x043);
 
 	} else {
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x0);	/*enable BB TxBF ant mapping register*/
-		odm_set_bb_reg(p_dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 0);			/*ignore user since 8822B only 2Tx*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(28) | BIT29, 0x0); /*@enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, REG_BB_TXBF_ANT_SET_BF1_8822B, BIT(31), 0); /*@ignore user since 8822B only 2Tx*/
 
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*1SS by path-A*/
-		odm_set_bb_reg(p_dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*2SS by path-A,B*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_1_8822B, 0xfff00000, 0x1); /*@1SS by path-A*/
+		odm_set_bb_reg(dm, REG_BB_TX_PATH_SEL_2_8822B, MASKLWORD, 0x430); /*@2SS by path-A,B*/
 	}
-
 }
 
-
 /*this function is for BFer bug workaround*/
-void
-phydm_8822b_sutxbfer_workaroud(
-	void		*p_dm_void,
-	boolean	enable_su_bfer,
-	u8	nc,
-	u8	nr,
-	u8	ng,
-	u8	CB,
-	u8	BW,
-	boolean	is_vht
-)
+void phydm_8822b_sutxbfer_workaroud(void *dm_void, boolean enable_su_bfer,
+				    u8 nc, u8 nr, u8 ng, u8 CB, u8 BW,
+				    boolean is_vht)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	if (enable_su_bfer) {
-		odm_set_bb_reg(p_dm, 0x19f8, BIT(22) | BIT(21) | BIT(20), 0x1);
-		odm_set_bb_reg(p_dm, 0x19f8, BIT(25) | BIT(24) | BIT(23), 0x0);
-		odm_set_bb_reg(p_dm, 0x19f8, BIT(16), 0x1);
+		odm_set_bb_reg(dm, R_0x19f8, BIT(22) | BIT(21) | BIT(20), 0x1);
+		odm_set_bb_reg(dm, R_0x19f8, BIT(25) | BIT(24) | BIT(23), 0x0);
+		odm_set_bb_reg(dm, R_0x19f8, BIT(16), 0x1);
 
 		if (is_vht)
-			odm_set_bb_reg(p_dm, 0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x1f);
+			odm_set_bb_reg(dm, R_0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x1f);
 		else
-			odm_set_bb_reg(p_dm, 0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x22);
+			odm_set_bb_reg(dm, R_0x19f0, BIT(5) | BIT(4) | BIT(3) | BIT(2) | BIT(1) | BIT(0), 0x22);
 
-		odm_set_bb_reg(p_dm, 0x19f0, BIT(7) | BIT(6), nc);
-		odm_set_bb_reg(p_dm, 0x19f0, BIT(9) | BIT(8), nr);
-		odm_set_bb_reg(p_dm, 0x19f0, BIT(11) | BIT(10), ng);
-		odm_set_bb_reg(p_dm, 0x19f0, BIT(13) | BIT(12), CB);
-
-		odm_set_bb_reg(p_dm, 0xb58, BIT(3) | BIT(2), BW);
-		odm_set_bb_reg(p_dm, 0xb58, BIT(7) | BIT(6) | BIT(5) | BIT(4), 0x0);
-		odm_set_bb_reg(p_dm, 0xb58, BIT(9) | BIT(8), BW);
-		odm_set_bb_reg(p_dm, 0xb58, BIT(13) | BIT(12) | BIT(11) | BIT(10), 0x0);
-	} else
-		odm_set_bb_reg(p_dm, 0x19f8, BIT(16), 0x0);
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] enable_su_bfer = %d, is_vht = %d\n", __func__, enable_su_bfer, is_vht));
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] nc = %d, nr = %d, ng = %d, CB = %d, BW = %d\n", __func__, nc, nr, ng, CB, BW));
+		odm_set_bb_reg(dm, R_0x19f0, BIT(7) | BIT(6), nc);
+		odm_set_bb_reg(dm, R_0x19f0, BIT(9) | BIT(8), nr);
+		odm_set_bb_reg(dm, R_0x19f0, BIT(11) | BIT(10), ng);
+		odm_set_bb_reg(dm, R_0x19f0, BIT(13) | BIT(12), CB);
 
+		odm_set_bb_reg(dm, R_0xb58, BIT(3) | BIT(2), BW);
+		odm_set_bb_reg(dm, R_0xb58, BIT(7) | BIT(6) | BIT(5) | BIT(4), 0x0);
+		odm_set_bb_reg(dm, R_0xb58, BIT(9) | BIT(8), BW);
+		odm_set_bb_reg(dm, R_0xb58, BIT(13) | BIT(12) | BIT(11) | BIT(10), 0x0);
+	} else {
+		odm_set_bb_reg(dm, R_0x19f8, BIT(16), 0x0);
+	}
 
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] enable_su_bfer = %d, is_vht = %d\n",
+		  __func__, enable_su_bfer, is_vht);
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] nc = %d, nr = %d, ng = %d, CB = %d, BW = %d\n",
+		  __func__, nc, nr, ng, CB, BW);
 }
 #endif
-#endif	/* (RTL8822B_SUPPORT == 1)*/
+#endif /* @(RTL8822B_SUPPORT == 1)*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.h
index 2ff19bd665d7..e331ed8f7388 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbf8822b.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,86 +9,71 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #ifndef __HAL_TXBF_8822B_H__
 #define __HAL_TXBF_8822B_H__
 
 #if (RTL8822B_SUPPORT == 1)
-#if (BEAMFORMING_SUPPORT == 1)
-
-void
-hal_txbf_8822b_enter(
-	void			*p_dm_void,
-	u8				idx
-);
-
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
-void
-hal_txbf_8822b_leave(
-	void			*p_dm_void,
-	u8				idx
-);
+void hal_txbf_8822b_enter(
+	void *dm_void,
+	u8 idx);
 
+void hal_txbf_8822b_leave(
+	void *dm_void,
+	u8 idx);
 
-void
-hal_txbf_8822b_status(
-	void			*p_dm_void,
-	u8				beamform_idx
-);
+void hal_txbf_8822b_status(
+	void *dm_void,
+	u8 beamform_idx);
 
-void
-hal_txbf_8822b_config_gtab(
-	void			*p_dm_void
-);
+void hal_txbf_8822b_config_gtab(
+	void *dm_void);
 
-void
-hal_txbf_8822b_fw_txbf(
-	void			*p_dm_void,
-	u8				idx
-);
+void hal_txbf_8822b_fw_txbf(
+	void *dm_void,
+	u8 idx);
 #else
-#define hal_txbf_8822b_enter(p_dm_void, idx)
-#define hal_txbf_8822b_leave(p_dm_void, idx)
-#define hal_txbf_8822b_status(p_dm_void, idx)
-#define hal_txbf_8822b_fw_txbf(p_dm_void, idx)
-#define hal_txbf_8822b_config_gtab(p_dm_void)
+#define hal_txbf_8822b_enter(dm_void, idx)
+#define hal_txbf_8822b_leave(dm_void, idx)
+#define hal_txbf_8822b_status(dm_void, idx)
+#define hal_txbf_8822b_fw_txbf(dm_void, idx)
+#define hal_txbf_8822b_config_gtab(dm_void)
 
 #endif
 
 #if (defined(CONFIG_BB_TXBF_API))
-void
-phydm_8822btxbf_rfmode(
-	void		*p_dm_void,
-	u8	su_bfee_cnt,
-	u8	mu_bfee_cnt
-);
+void phydm_8822btxbf_rfmode(void *dm_void, u8 su_bfee_cnt, u8 mu_bfee_cnt);
 
-void
-phydm_8822b_sutxbfer_workaroud(
-	void		*p_dm_void,
-	boolean	enable_su_bfer,
-	u8	nc,
-	u8	nr,
-	u8	ng,
-	u8	CB,
-	u8	BW,
-	boolean	is_vht
-);
+void phydm_8822b_sutxbfer_workaroud(void *dm_void, boolean enable_su_bfer,
+				    u8 nc, u8 nr, u8 ng, u8 CB, u8 BW,
+				    boolean is_vht);
 
 #else
-#define phydm_8822btxbf_rfmode(p_dm_void, su_bfee_cnt, mu_bfee_cnt)
-#define phydm_8822b_sutxbfer_workaroud(p_dm_void, enable_su_bfer, nc, nr, ng, CB, BW, is_vht)
+#define phydm_8822btxbf_rfmode(dm_void, su_bfee_cnt, mu_bfee_cnt)
+#define phydm_8822b_sutxbfer_workaroud(dm_void, enable_su_bfer, nc, nr, ng, CB, BW, is_vht)
 #endif
 
 #else
-#define hal_txbf_8822b_enter(p_dm_void, idx)
-#define hal_txbf_8822b_leave(p_dm_void, idx)
-#define hal_txbf_8822b_status(p_dm_void, idx)
-#define hal_txbf_8822b_fw_txbf(p_dm_void, idx)
-#define hal_txbf_8822b_config_gtab(p_dm_void)
+#define hal_txbf_8822b_enter(dm_void, idx)
+#define hal_txbf_8822b_leave(dm_void, idx)
+#define hal_txbf_8822b_status(dm_void, idx)
+#define hal_txbf_8822b_fw_txbf(dm_void, idx)
+#define hal_txbf_8822b_config_gtab(dm_void)
 
 #endif
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.c
index ebccedcfb593..482265408746 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -12,148 +13,149 @@
  * more details.
  *
  *****************************************************************************/
-/* ************************************************************
+/*************************************************************
  * Description:
  *
  * This file is for TXBF interface mechanism
  *
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-void
-beamforming_gid_paid(
-	struct _ADAPTER	*adapter,
-	PRT_TCB		p_tcb
-)
+void beamforming_gid_paid(
+	void *adapter,
+	PRT_TCB tcb)
 {
-	u8		RA[6] = {0};
-	u8		*p_header = GET_FRAME_OF_FIRST_FRAG(adapter, p_tcb);
-	HAL_DATA_TYPE			*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT				*p_dm = &p_hal_data->DM_OutSrc;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
+	u8 RA[6] = {0};
+	u8 *p_header = GET_FRAME_OF_FIRST_FRAG(adapter, tcb);
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
 
-	if (adapter->HardwareType < HARDWARE_TYPE_RTL8192EE)
+	if (((PADAPTER)adapter)->HardwareType < HARDWARE_TYPE_RTL8192EE)
 		return;
-	else if (IS_WIRELESS_MODE_N(adapter) == false)
+	else if (IS_WIRELESS_MODE_N((PADAPTER)adapter) == false)
 		return;
 
 #if (SUPPORT_MU_BF == 1)
-	if (p_tcb->tx_bf_pkt_type == RT_BF_PKT_TYPE_BROADCAST_NDPA) { /* MU NDPA */
+	if (tcb->tx_bf_pkt_type == RT_BF_PKT_TYPE_BROADCAST_NDPA) { /* @MU NDPA */
 #else
 	if (0) {
 #endif
-		/* Fill G_ID and P_AID */
-		p_tcb->G_ID = 63;
-		if (p_beam_info->first_mu_bfee_index < BEAMFORMEE_ENTRY_NUM) {
-			p_tcb->P_AID = p_beam_info->beamformee_entry[p_beam_info->first_mu_bfee_index].p_aid;
-			RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, p_tcb->G_ID, p_tcb->P_AID));
+		/* @Fill G_ID and P_AID */
+		tcb->G_ID = 63;
+		if (beam_info->first_mu_bfee_index < BEAMFORMEE_ENTRY_NUM) {
+			tcb->P_AID = beam_info->beamformee_entry[beam_info->first_mu_bfee_index].p_aid;
+			RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, tcb->G_ID, tcb->P_AID));
 		}
 	} else {
 		GET_80211_HDR_ADDRESS1(p_header, &RA);
 
 		/* VHT SU PPDU carrying one or more group addressed MPDUs or */
 		/* Transmitting a VHT NDP intended for multiple recipients */
-		if (MacAddr_isBcst(RA) || MacAddr_isMulticast(RA)	|| p_tcb->macId == MAC_ID_STATIC_FOR_BROADCAST_MULTICAST) {
-			p_tcb->G_ID = 63;
-			p_tcb->P_AID = 0;
+		if (MacAddr_isBcst(RA) || MacAddr_isMulticast(RA) || tcb->macId == MAC_ID_STATIC_FOR_BROADCAST_MULTICAST) {
+			tcb->G_ID = 63;
+			tcb->P_AID = 0;
 		} else if (ACTING_AS_AP(adapter)) {
-			u16	AID = (u16)(MacIdGetOwnerAssociatedClientAID(adapter, p_tcb->macId) & 0x1ff);		/*AID[0:8]*/
+			u16 AID = (u16)(MacIdGetOwnerAssociatedClientAID(adapter, tcb->macId) & 0x1ff); /*@AID[0:8]*/
 
-			/*RT_DISP(FBEAM, FBEAM_FUN, ("@%s  p_tcb->mac_id=0x%X, AID=0x%X\n", __func__, p_tcb->mac_id, AID));*/
-			p_tcb->G_ID = 63;
+			/*RT_DISP(FBEAM, FBEAM_FUN, ("@%s  tcb->mac_id=0x%X, AID=0x%X\n", __func__, tcb->mac_id, AID));*/
+			tcb->G_ID = 63;
 
-			if (AID == 0)		/*A PPDU sent by an AP to a non associated STA*/
-				p_tcb->P_AID = 0;
-			else {				/*Sent by an AP and addressed to a STA associated with that AP*/
-				u16	BSSID = 0;
+			if (AID == 0) /*@A PPDU sent by an AP to a non associated STA*/
+				tcb->P_AID = 0;
+			else { /*Sent by an AP and addressed to a STA associated with that AP*/
+				u16 BSSID = 0;
 				GET_80211_HDR_ADDRESS2(p_header, &RA);
-				BSSID = ((RA[5] & 0xf0) >> 4) ^ (RA[5] & 0xf);	/*BSSID[44:47] xor BSSID[40:43]*/
-				p_tcb->P_AID = (AID + BSSID * 32) & 0x1ff;		/*(dec(A) + dec(B)*32) mod 512*/
+				BSSID = ((RA[5] & 0xf0) >> 4) ^ (RA[5] & 0xf); /*@BSSID[44:47] xor BSSID[40:43]*/
+				tcb->P_AID = (AID + BSSID * 32) & 0x1ff; /*@(dec(A) + dec(B)*32) mod 512*/
 			}
-		} else if (ACTING_AS_IBSS(adapter)) {
-			p_tcb->G_ID = 63;
+		} else if (ACTING_AS_IBSS(((PADAPTER)adapter))) {
+			tcb->G_ID = 63;
 			/*P_AID for infrasturcture mode; MACID for ad-hoc mode. */
-			p_tcb->P_AID = p_tcb->macId;
-		} else if (MgntLinkStatusQuery(adapter)) {				/*Addressed to AP*/
-			p_tcb->G_ID = 0;
+			tcb->P_AID = tcb->macId;
+		} else if (MgntLinkStatusQuery(adapter)) { /*@Addressed to AP*/
+			tcb->G_ID = 0;
 			GET_80211_HDR_ADDRESS1(p_header, &RA);
-			p_tcb->P_AID =  RA[5];							/*RA[39:47]*/
-			p_tcb->P_AID = (p_tcb->P_AID << 1) | (RA[4] >> 7);
+			tcb->P_AID = RA[5]; /*RA[39:47]*/
+			tcb->P_AID = (tcb->P_AID << 1) | (RA[4] >> 7);
 		} else {
-			p_tcb->G_ID = 63;
-			p_tcb->P_AID = 0;
+			tcb->G_ID = 63;
+			tcb->P_AID = 0;
 		}
-		/*RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, p_tcb->G_ID, p_tcb->P_AID));*/
+		/*RT_DISP(FBEAM, FBEAM_FUN, ("[David]@%s End, G_ID=0x%X, P_AID=0x%X\n", __func__, tcb->G_ID, tcb->P_AID));*/
 	}
 }
 
-
 enum rt_status
 beamforming_get_report_frame(
-	struct _ADAPTER		*adapter,
-	PRT_RFD			p_rfd,
-	POCTET_STRING	p_pdu_os
-)
+	void *adapter,
+	PRT_RFD rfd,
+	POCTET_STRING p_pdu_os)
 {
-	HAL_DATA_TYPE				*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT					*p_dm = &p_hal_data->DM_OutSrc;
-	struct _RT_BEAMFORMEE_ENTRY		*p_beamform_entry = NULL;
-	u8						*p_mimo_ctrl_field, p_csi_matrix;
-	u8						idx, nc, nr, CH_W;
-	u16						csi_matrix_len = 0;
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA((PADAPTER)adapter);
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = NULL;
+	u8 *p_mimo_ctrl_field, p_csi_matrix;
+	u8 idx, nc, nr, CH_W;
+	u16 csi_matrix_len = 0;
 
-	ACT_PKT_TYPE				pkt_type = ACT_PKT_TYPE_UNKNOWN;
+	ACT_PKT_TYPE pkt_type = ACT_PKT_TYPE_UNKNOWN;
 
-	/* Memory comparison to see if CSI report is the same with previous one */
-	p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, Frame_Addr2(*p_pdu_os), &idx);
+	/* @Memory comparison to see if CSI report is the same with previous one */
+	beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, Frame_Addr2(*p_pdu_os), &idx);
 
-	if (p_beamform_entry == NULL) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("beamforming_get_report_frame: Cannot find entry by addr\n"));
+	if (beamform_entry == NULL) {
+		PHYDM_DBG(dm, DBG_TXBF, "%s: Cannot find entry by addr\n",
+			  __func__);
 		return RT_STATUS_FAILURE;
 	}
 
 	pkt_type = PacketGetActionFrameType(p_pdu_os);
 
-	/* -@ Modified by David */
+	/* @-@ Modified by David */
 	if (pkt_type == ACT_PKT_VHT_COMPRESSED_BEAMFORMING) {
 		p_mimo_ctrl_field = p_pdu_os->Octet + 26;
 		nc = ((*p_mimo_ctrl_field) & 0x7) + 1;
 		nr = (((*p_mimo_ctrl_field) & 0x38) >> 3) + 1;
 		CH_W = (((*p_mimo_ctrl_field) & 0xC0) >> 6);
 		/*p_csi_matrix = p_mimo_ctrl_field + 3 + nc;*/ /* 24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(nc=2) */
-		csi_matrix_len = p_pdu_os->Length  - 26 - 3 - nc;
+		csi_matrix_len = p_pdu_os->Length - 26 - 3 - nc;
 	} else if (pkt_type == ACT_PKT_HT_COMPRESSED_BEAMFORMING) {
 		p_mimo_ctrl_field = p_pdu_os->Octet + 26;
 		nc = ((*p_mimo_ctrl_field) & 0x3) + 1;
 		nr = (((*p_mimo_ctrl_field) & 0xC) >> 2) + 1;
 		CH_W = (((*p_mimo_ctrl_field) & 0x10) >> 4);
-		/*p_csi_matrix = p_mimo_ctrl_field + 6 + nr;*/	/* 24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(nc=2) */
-		csi_matrix_len = p_pdu_os->Length  - 26 - 6 - nr;
+		/*p_csi_matrix = p_mimo_ctrl_field + 6 + nr;*/ /* 24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField) +SNR(nc=2) */
+		csi_matrix_len = p_pdu_os->Length - 26 - 6 - nr;
 	} else
 		return RT_STATUS_SUCCESS;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] idx=%d, pkt type=%d, nc=%d, nr=%d, CH_W=%d\n", __func__, idx, pkt_type, nc, nr, CH_W));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] idx=%d, pkt type=%d, nc=%d, nr=%d, CH_W=%d\n", __func__,
+		  idx, pkt_type, nc, nr, CH_W);
 
 	return RT_STATUS_SUCCESS;
 }
 
-
-void
-construct_ht_ndpa_packet(
-	struct _ADAPTER		*adapter,
-	u8			*RA,
-	u8			*buffer,
-	u32			*p_length,
-	enum channel_width	BW
-)
+void construct_ht_ndpa_packet(
+	// 2017/11 MH PHYDM compile. But why need to use windows maco?
+	// For all linux code, it should be useless?
+	//void				*adapter = dm->adapter;
+	ADAPTER * adapter,
+	//void		*adapter,
+	u8 *RA,
+	u8 *buffer,
+	u32 *p_length,
+	enum channel_width BW)
 {
-	u16					duration = 0;
-	PMGNT_INFO				p_mgnt_info = &(adapter->MgntInfo);
-	OCTET_STRING			p_ndpa_frame, action_content;
-	u8					action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u16 duration = 0;
+	PMGNT_INFO mgnt_info = &(((PADAPTER)adapter)->MgntInfo);
+	//PMGNT_INFO				mgnt_info = &((MGNT_INFO)(((PADAPTER)adapter)->MgntInfo));
+	OCTET_STRING p_ndpa_frame, action_content;
+	u8 action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
 
 	PlatformZeroMemory(buffer, 32);
 
@@ -163,8 +165,8 @@ construct_ht_ndpa_packet(
 	SET_80211_HDR_TYPE_AND_SUBTYPE(buffer, Type_Action_No_Ack);
 
 	SET_80211_HDR_ADDRESS1(buffer, RA);
-	SET_80211_HDR_ADDRESS2(buffer, adapter->CurrentAddress);
-	SET_80211_HDR_ADDRESS3(buffer, p_mgnt_info->Bssid);
+	SET_80211_HDR_ADDRESS2(buffer, ((PADAPTER)adapter)->CurrentAddress);
+	SET_80211_HDR_ADDRESS3(buffer, ((PMGNT_INFO)mgnt_info)->Bssid);
 
 	duration = 2 * a_SifsTime + 40;
 
@@ -175,7 +177,7 @@ construct_ht_ndpa_packet(
 
 	SET_80211_HDR_DURATION(buffer, duration);
 
-	/* HT control field */
+	/* @HT control field */
 	SET_HT_CTRL_CSI_STEERING(buffer + sMacHdrLng, 3);
 	SET_HT_CTRL_NDP_ANNOUNCEMENT(buffer + sMacHdrLng, 1);
 
@@ -187,40 +189,37 @@ construct_ht_ndpa_packet(
 	*p_length = 32;
 }
 
-
-
-
 boolean
 send_fw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	PRT_TCB				p_tcb;
-	PRT_TX_LOCAL_BUFFER	p_buf;
-	boolean				ret = true;
-	u32					buf_len;
-	u8					*buf_addr;
-	u8					desc_len = 0, idx = 0, ndp_tx_rate;
-	struct _ADAPTER				*p_def_adapter = GetDefaultAdapter(adapter);
-	HAL_DATA_TYPE			*p_hal_data = GET_HAL_DATA(adapter);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
-
-	if (p_beamform_entry == NULL)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u32 buf_len;
+	u8 *buf_addr;
+	u8 desc_len = 0, idx = 0, ndp_tx_rate;
+	void *p_def_adapter = GetDefaultAdapter(((PADAPTER)adapter));
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beamform_entry == NULL)
 		return false;
 
-	ndp_tx_rate = beamforming_get_htndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetFWBuffer(p_def_adapter, &p_tcb, &p_buf)) {
+	if (MgntGetFWBuffer(p_def_adapter, &tcb, &p_buf)) {
 #if (DEV_BUS_TYPE != RT_PCI_INTERFACE)
-		desc_len = adapter->HWDescHeadLength - p_hal_data->USBALLDummyLength;
+		desc_len = ((PADAPTER)adapter)->HWDescHeadLength - hal_data->USBALLDummyLength;
 #endif
 		buf_addr = p_buf->Buffer.VirtualAddress + desc_len;
 
@@ -229,107 +228,105 @@ send_fw_ht_ndpa_packet(
 			RA,
 			buf_addr,
 			&buf_len,
-			BW
-		);
+			BW);
 
-		p_tcb->PacketLength = buf_len + desc_len;
+		tcb->PacketLength = buf_len + desc_len;
 
-		p_tcb->bTxEnableSwCalcDur = true;
+		tcb->bTxEnableSwCalcDur = true;
 
-		p_tcb->BWOfPacket = BW;
+		tcb->BWOfPacket = BW;
 
-		if (ACTING_AS_IBSS(adapter) || ACTING_AS_AP(adapter))
-			p_tcb->G_ID = 63;
+		if (ACTING_AS_IBSS(((PADAPTER)adapter)) || ACTING_AS_AP(((PADAPTER)adapter)))
+			tcb->G_ID = 63;
 
-		p_tcb->P_AID = p_beamform_entry->p_aid;
-		p_tcb->DataRate = ndp_tx_rate;	/*rate of NDP decide by nr*/
+		tcb->P_AID = beamform_entry->p_aid;
+		tcb->DataRate = ndp_tx_rate; /*rate of NDP decide by nr*/
 
-		adapter->HalFunc.CmdSendPacketHandler(adapter, p_tcb, p_buf, p_tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
+		((PADAPTER)adapter)->HalFunc.CmdSendPacketHandler(((PADAPTER)adapter), tcb, p_buf, tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
 }
 
-
 boolean
 send_sw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	PRT_TCB					p_tcb;
-	PRT_TX_LOCAL_BUFFER		p_buf;
-	boolean					ret = true;
-	u8					idx = 0, ndp_tx_rate = 0;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u8 idx = 0, ndp_tx_rate = 0;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	ndp_tx_rate = beamforming_get_htndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetBuffer(adapter, &p_tcb, &p_buf)) {
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
 		construct_ht_ndpa_packet(
 			adapter,
 			RA,
 			p_buf->Buffer.VirtualAddress,
-			&p_tcb->PacketLength,
-			BW
-		);
+			&tcb->PacketLength,
+			BW);
 
-		p_tcb->bTxEnableSwCalcDur = true;
+		tcb->bTxEnableSwCalcDur = true;
 
-		p_tcb->BWOfPacket = BW;
+		tcb->BWOfPacket = BW;
 
-		MgntSendPacket(adapter, p_tcb, p_buf, p_tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
 }
 
-
-
-void
-construct_vht_ndpa_packet(
-	struct PHY_DM_STRUCT	*p_dm,
-	u8			*RA,
-	u16			AID,
-	u8			*buffer,
-	u32			*p_length,
-	enum channel_width	BW
-)
+void construct_vht_ndpa_packet(
+	struct dm_struct *dm,
+	u8 *RA,
+	u16 AID,
+	u8 *buffer,
+	u32 *p_length,
+	enum channel_width BW)
 {
-	u16					duration = 0;
-	u8					sequence = 0;
-	u8					*p_ndpa_frame = buffer;
-	struct _RT_NDPA_STA_INFO		sta_info;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	u8	idx = 0;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-	/* Frame control. */
+	u16 duration = 0;
+	u8 sequence = 0;
+	u8 *p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO sta_info;
+	// 2017/11 MH PHYDM compile. But why need to use windows maco?
+	// For all linux code, it should be useless?
+	//void				*adapter = dm->adapter;
+	ADAPTER * adapter = (PADAPTER)(dm->adapter);
+	u8 idx = 0;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	/* @Frame control. */
 	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
 	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
 
 	SET_80211_HDR_ADDRESS1(p_ndpa_frame, RA);
-	SET_80211_HDR_ADDRESS2(p_ndpa_frame, p_beamform_entry->my_mac_addr);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, beamform_entry->my_mac_addr);
 
+	// 2017/11 MH PHYDM compile. But why need to use windows maco?
+	// For all linux code, it should be useless?
 	duration = 2 * a_SifsTime + 44;
 
 	if (BW == CHANNEL_WIDTH_80)
@@ -341,178 +338,174 @@ construct_vht_ndpa_packet(
 
 	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
 
-	sequence = *(p_dm->p_sounding_seq) << 2;
-	odm_move_memory(p_dm, p_ndpa_frame + 16, &sequence, 1);
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
 
-	if (phydm_acting_determine(p_dm, phydm_acting_as_ibss) || phydm_acting_determine(p_dm, phydm_acting_as_ap) == false)
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss) || phydm_acting_determine(dm, phydm_acting_as_ap) == false)
 		AID = 0;
 
 	sta_info.aid = AID;
 	sta_info.feedback_type = 0;
 	sta_info.nc_index = 0;
 
-	odm_move_memory(p_dm, p_ndpa_frame + 17, (u8 *)&sta_info, 2);
+	odm_move_memory(dm, p_ndpa_frame + 17, (u8 *)&sta_info, 2);
 
 	*p_length = 19;
 }
 
-
 boolean
 send_fw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	PRT_TCB					p_tcb;
-	PRT_TX_LOCAL_BUFFER		p_buf;
-	boolean					ret = true;
-	u32					buf_len;
-	u8					*buf_addr;
-	u8					desc_len = 0, idx = 0, ndp_tx_rate = 0;
-	struct _ADAPTER				*p_def_adapter = GetDefaultAdapter(adapter);
-	HAL_DATA_TYPE			*p_hal_data = GET_HAL_DATA(adapter);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
-
-	if (p_beamform_entry == NULL)
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u32 buf_len;
+	u8 *buf_addr;
+	u8 desc_len = 0, idx = 0, ndp_tx_rate = 0;
+	void *p_def_adapter = GetDefaultAdapter(((PADAPTER)adapter));
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
+
+	if (beamform_entry == NULL)
 		return false;
 
-	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetFWBuffer(p_def_adapter, &p_tcb, &p_buf)) {
+	if (MgntGetFWBuffer(p_def_adapter, &tcb, &p_buf)) {
 #if (DEV_BUS_TYPE != RT_PCI_INTERFACE)
-		desc_len = adapter->HWDescHeadLength - p_hal_data->USBALLDummyLength;
+		desc_len = ((PADAPTER)adapter)->HWDescHeadLength - hal_data->USBALLDummyLength;
 #endif
 		buf_addr = p_buf->Buffer.VirtualAddress + desc_len;
 
 		construct_vht_ndpa_packet(
-			p_dm,
+			dm,
 			RA,
 			AID,
 			buf_addr,
 			&buf_len,
-			BW
-		);
+			BW);
 
-		p_tcb->PacketLength = buf_len + desc_len;
+		tcb->PacketLength = buf_len + desc_len;
 
-		p_tcb->bTxEnableSwCalcDur = true;
+		tcb->bTxEnableSwCalcDur = true;
 
-		p_tcb->BWOfPacket = BW;
+		tcb->BWOfPacket = BW;
 
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ibss) || phydm_acting_determine(p_dm, phydm_acting_as_ap))
-			p_tcb->G_ID = 63;
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss) || phydm_acting_determine(dm, phydm_acting_as_ap))
+			tcb->G_ID = 63;
 
-		p_tcb->P_AID = p_beamform_entry->p_aid;
-		p_tcb->DataRate = ndp_tx_rate;	/*decide by nr*/
+		tcb->P_AID = beamform_entry->p_aid;
+		tcb->DataRate = ndp_tx_rate; /*@decide by nr*/
 
-		adapter->HalFunc.CmdSendPacketHandler(adapter, p_tcb, p_buf, p_tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
+		((PADAPTER)adapter)->HalFunc.CmdSendPacketHandler(adapter, tcb, p_buf, tcb->PacketLength, DESC_PACKET_TYPE_NORMAL, false);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] End, ret=%d\n", __func__, ret));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] End, ret=%d\n", __func__, ret);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
 }
 
-
-
 boolean
 send_sw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	PRT_TCB					p_tcb;
-	PRT_TX_LOCAL_BUFFER		p_buf;
-	boolean					ret = true;
-	u8					idx = 0, ndp_tx_rate = 0;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-
-	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	void *adapter = dm->adapter;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u8 idx = 0, ndp_tx_rate = 0;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetBuffer(adapter, &p_tcb, &p_buf)) {
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
 		construct_vht_ndpa_packet(
-			p_dm,
+			dm,
 			RA,
 			AID,
 			p_buf->Buffer.VirtualAddress,
-			&p_tcb->PacketLength,
-			BW
-		);
+			&tcb->PacketLength,
+			BW);
 
-		p_tcb->bTxEnableSwCalcDur = true;
-		p_tcb->BWOfPacket = BW;
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
 
 		/*rate of NDP decide by nr*/
-		MgntSendPacket(adapter, p_tcb, p_buf, p_tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
 }
 
 #ifdef SUPPORT_MU_BF
 #if (SUPPORT_MU_BF == 1)
-/*
+/*@
  * Description: On VHT GID management frame by an MU beamformee.
  *
  * 2015.05.20. Created by tynli.
  */
 enum rt_status
 beamforming_get_vht_gid_mgnt_frame(
-	struct _ADAPTER		*adapter,
-	PRT_RFD			p_rfd,
-	POCTET_STRING	p_pdu_os
-)
+	void *adapter,
+	PRT_RFD rfd,
+	POCTET_STRING p_pdu_os)
 {
-	HAL_DATA_TYPE	*p_hal_data = GET_HAL_DATA(adapter);
-	struct PHY_DM_STRUCT		*p_dm = &p_hal_data->DM_OutSrc;
-	enum rt_status		rt_status = RT_STATUS_SUCCESS;
-	u8			*p_buffer = NULL;
-	u8			*p_raddr = NULL;
-	u8			mem_status[8] = {0}, user_pos[16] = {0};
-	u8			idx;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMER_ENTRY	*p_beamform_entry = &p_beam_info->beamformer_entry[p_beam_info->mu_ap_index];
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] On VHT GID mgnt frame!\n", __func__));
-
-	/* Check length*/
+	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
+	struct dm_struct *dm = &hal_data->DM_OutSrc;
+	enum rt_status rt_status = RT_STATUS_SUCCESS;
+	u8 *p_buffer = NULL;
+	u8 *p_raddr = NULL;
+	u8 mem_status[8] = {0}, user_pos[16] = {0};
+	u8 idx;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMER_ENTRY *beamform_entry = &beam_info->beamformer_entry[beam_info->mu_ap_index];
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] On VHT GID mgnt frame!\n", __func__);
+
+	/* @Check length*/
 	if (p_pdu_os->length < (FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY + 16)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("beamforming_get_vht_gid_mgnt_frame(): Invalid length (%d)\n", p_pdu_os->length));
+		PHYDM_DBG(dm, DBG_TXBF, "%s: Invalid length (%d)\n", __func__,
+			  p_pdu_os->length);
 		return RT_STATUS_INVALID_LENGTH;
 	}
 
-	/* Check RA*/
+	/* @Check RA*/
 	p_raddr = (u8 *)(p_pdu_os->Octet) + 4;
 	if (!eq_mac_addr(p_raddr, adapter->CurrentAddress)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("beamforming_get_vht_gid_mgnt_frame(): Drop because of RA error.\n"));
+		PHYDM_DBG(dm, DBG_TXBF, "%s: Drop because of RA error.\n",
+			  __func__);
 		return RT_STATUS_PKT_DROP;
 	}
 
@@ -522,7 +515,7 @@ beamforming_get_vht_gid_mgnt_frame(
 	p_buffer = p_pdu_os->Octet + FRAME_OFFSET_VHT_GID_MGNT_MEMBERSHIP_STATUS_ARRAY;
 	for (idx = 0; idx < 8; idx++) {
 		mem_status[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(p_buffer + idx);
-		p_beamform_entry->gid_valid[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(p_buffer + idx);
+		beamform_entry->gid_valid[idx] = GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS(p_buffer + idx);
 	}
 
 	RT_DISP_DATA(FBEAM, FBEAM_DATA, "mem_status: ", mem_status, 8);
@@ -531,37 +524,37 @@ beamforming_get_vht_gid_mgnt_frame(
 	p_buffer = p_pdu_os->Octet + FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY;
 	for (idx = 0; idx < 16; idx++) {
 		user_pos[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(p_buffer + idx);
-		p_beamform_entry->user_position[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(p_buffer + idx);
+		beamform_entry->user_position[idx] = GET_VHT_GID_MGNT_INFO_USER_POSITION(p_buffer + idx);
 	}
 
 	RT_DISP_DATA(FBEAM, FBEAM_DATA, "user_pos: ", user_pos, 16);
 
-	/* Group ID detail printed*/
+	/* @Group ID detail printed*/
 	{
-		u8	i, j;
-		u8	tmp_val;
-		u16	tmp_val2;
+		u8 i, j;
+		u8 tmp_val;
+		u16 tmp_val2;
 
 		for (i = 0; i < 8; i++) {
 			tmp_val = mem_status[i];
 			tmp_val2 = ((user_pos[i * 2 + 1] << 8) & 0xFF00) + (user_pos[i * 2] & 0xFF);
 			for (j = 0; j < 8; j++) {
 				if ((tmp_val >> j) & BIT(0)) {
-					PHYDM_DBG(p_dm, DBG_TXBF, ("Use Group ID (%d), User Position (%d)\n",
-						(i * 8 + j), (tmp_val2 >> 2 * j) & 0x3));
+					PHYDM_DBG(dm, DBG_TXBF, "Use Group ID (%d), User Position (%d)\n",
+						  (i * 8 + j), (tmp_val2 >> 2 * j) & 0x3);
 				}
 			}
 		}
 	}
 
-	/* Indicate GID frame to IHV service. */
+	/* @Indicate GID frame to IHV service. */
 	{
-		u8	indibuffer[24] = {0};
-		u8	indioffset = 0;
+		u8 indibuffer[24] = {0};
+		u8 indioffset = 0;
 
-		PlatformMoveMemory(indibuffer + indioffset, p_beamform_entry->gid_valid, 8);
+		PlatformMoveMemory(indibuffer + indioffset, beamform_entry->gid_valid, 8);
 		indioffset += 8;
-		PlatformMoveMemory(indibuffer + indioffset, p_beamform_entry->user_position, 16);
+		PlatformMoveMemory(indibuffer + indioffset, beamform_entry->user_position, 16);
 		indioffset += 16;
 
 		PlatformIndicateCustomStatus(
@@ -572,30 +565,29 @@ beamforming_get_vht_gid_mgnt_frame(
 			indioffset);
 	}
 
-	/* Config HW GID table */
-	hal_com_txbf_config_gtab(p_dm);
+	/* @Config HW GID table */
+	hal_com_txbf_config_gtab(dm);
 
 	return rt_status;
 }
 
-/*
+/*@
  * Description: Construct VHT Group ID (GID) management frame.
  *
  * 2015.05.20. Created by tynli.
  */
-void
-construct_vht_gid_mgnt_frame(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			*RA,
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry,
-	u8			*buffer,
-	u32			*p_length
-
-)
+void construct_vht_gid_mgnt_frame(
+	struct dm_struct *dm,
+	u8 *RA,
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry,
+	u8 *buffer,
+	u32 *p_length
+
+	)
 {
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
-	OCTET_STRING		os_ftm_frame, tmp;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	void *adapter = beam_info->source_adapter;
+	OCTET_STRING os_ftm_frame, tmp;
 
 	FillOctetString(os_ftm_frame, buffer, 0);
 	*p_length = 0;
@@ -607,12 +599,12 @@ construct_vht_gid_mgnt_frame(
 		ACT_VHT_GROUPID_MANAGEMENT,
 		&os_ftm_frame);
 
-	/* Membership status array*/
-	FillOctetString(tmp, p_beamform_entry->gid_valid, 8);
+	/* @Membership status array*/
+	FillOctetString(tmp, beamform_entry->gid_valid, 8);
 	PacketAppendData(&os_ftm_frame, tmp);
 
 	/* User Position array*/
-	FillOctetString(tmp, p_beamform_entry->user_position, 16);
+	FillOctetString(tmp, beamform_entry->user_position, 16);
 	PacketAppendData(&os_ftm_frame, tmp);
 
 	*p_length = os_ftm_frame.length;
@@ -622,70 +614,65 @@ construct_vht_gid_mgnt_frame(
 
 boolean
 send_sw_vht_gid_mgnt_frame(
-	void			*p_dm_void,
-	u8			*RA,
-	u8			idx
-)
+	void *dm_void,
+	u8 *RA,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	PRT_TCB					p_tcb;
-	PRT_TX_LOCAL_BUFFER		p_buf;
-	boolean					ret = true;
-	u8					data_rate = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = &p_beam_info->beamformee_entry[idx];
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u8 data_rate = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = &beam_info->beamformee_entry[idx];
+	void *adapter = beam_info->source_adapter;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetBuffer(adapter, &p_tcb, &p_buf)) {
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
 		construct_vht_gid_mgnt_frame(
-			p_dm,
+			dm,
 			RA,
-			p_beamform_entry,
+			beamform_entry,
 			p_buf->Buffer.VirtualAddress,
-			&p_tcb->PacketLength
-		);
+			&tcb->PacketLength);
 
-		p_tcb->bw_of_packet = CHANNEL_WIDTH_20;
+		tcb->bw_of_packet = CHANNEL_WIDTH_20;
 		data_rate = MGN_6M;
-		MgntSendPacket(adapter, p_tcb, p_buf, p_tcb->PacketLength, NORMAL_QUEUE, data_rate);
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, data_rate);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
 }
 
-
-/*
+/*@
  * Description: Construct VHT beamforming report poll.
  *
  * 2015.05.20. Created by tynli.
  */
-void
-construct_vht_bf_report_poll(
-	struct PHY_DM_STRUCT		*p_dm,
-	u8			*RA,
-	u8			*buffer,
-	u32			*p_length
-)
+void construct_vht_bf_report_poll(
+	struct dm_struct *dm,
+	u8 *RA,
+	u8 *buffer,
+	u32 *p_length)
 {
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
-	u8			*p_bf_rpt_poll = buffer;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	void *adapter = beam_info->source_adapter;
+	u8 *p_bf_rpt_poll = buffer;
 
-	/* Frame control*/
+	/* @Frame control*/
 	SET_80211_HDR_FRAME_CONTROL(p_bf_rpt_poll, 0);
 	SET_80211_HDR_TYPE_AND_SUBTYPE(p_bf_rpt_poll, Type_Beamforming_Report_Poll);
 
-	/* duration*/
+	/* @duration*/
 	SET_80211_HDR_DURATION(p_bf_rpt_poll, 100);
 
 	/* RA*/
@@ -694,111 +681,105 @@ construct_vht_bf_report_poll(
 	/* TA*/
 	SET_VHT_BF_REPORT_POLL_TA(p_bf_rpt_poll, adapter->CurrentAddress);
 
-	/* Feedback Segment Retransmission Bitmap*/
+	/* @Feedback Segment Retransmission Bitmap*/
 	SET_VHT_BF_REPORT_POLL_FEEDBACK_SEG_RETRAN_BITMAP(p_bf_rpt_poll, 0xFF);
 
 	*p_length = 17;
 
 	RT_DISP_DATA(FBEAM, FBEAM_DATA, "construct_vht_bf_report_poll():\n", buffer, *p_length);
-
 }
 
 boolean
 send_sw_vht_bf_report_poll(
-	void			*p_dm_void,
-	u8			*RA,
-	boolean			is_final_poll
-)
+	void *dm_void,
+	u8 *RA,
+	boolean is_final_poll)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	PRT_TCB					p_tcb;
-	PRT_TX_LOCAL_BUFFER		p_buf;
-	boolean					ret = true;
-	u8					idx = 0, data_rate = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u8 idx = 0, data_rate = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	void *adapter = beam_info->source_adapter;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetBuffer(adapter, &p_tcb, &p_buf)) {
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
 		construct_vht_bf_report_poll(
-			p_dm,
+			dm,
 			RA,
 			p_buf->Buffer.VirtualAddress,
-			&p_tcb->PacketLength
-		);
+			&tcb->PacketLength);
 
-		p_tcb->bTxEnableSwCalcDur = true; /* <tynli_note> need?*/
-		p_tcb->BWOfPacket = CHANNEL_WIDTH_20;
+		tcb->bTxEnableSwCalcDur = true; /* @<tynli_note> need?*/
+		tcb->BWOfPacket = CHANNEL_WIDTH_20;
 
 		if (is_final_poll)
-			p_tcb->TxBFPktType = RT_BF_PKT_TYPE_FINAL_BF_REPORT_POLL;
+			tcb->TxBFPktType = RT_BF_PKT_TYPE_FINAL_BF_REPORT_POLL;
 		else
-			p_tcb->TxBFPktType = RT_BF_PKT_TYPE_BF_REPORT_POLL;
+			tcb->TxBFPktType = RT_BF_PKT_TYPE_BF_REPORT_POLL;
 
-		data_rate = MGN_6M;	/* Legacy OFDM rate*/
-		MgntSendPacket(adapter, p_tcb, p_buf, p_tcb->PacketLength, NORMAL_QUEUE, data_rate);
+		data_rate = MGN_6M; /* @Legacy OFDM rate*/
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, data_rate);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "send_sw_vht_bf_report_poll():\n", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "send_sw_vht_bf_report_poll:\n",
+		p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
-
 }
 
-
-/*
+/*@
  * Description: Construct VHT MU NDPA packet.
  *	<Note> We should combine this function with construct_vht_ndpa_packet() in the future.
  *
  * 2015.05.21. Created by tynli.
  */
-void
-construct_vht_mu_ndpa_packet(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum channel_width	BW,
-	u8			*buffer,
-	u32			*p_length
-)
+void construct_vht_mu_ndpa_packet(
+	struct dm_struct *dm,
+	enum channel_width BW,
+	u8 *buffer,
+	u32 *p_length)
 {
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
-	u16					duration = 0;
-	u8					sequence = 0;
-	u8					*p_ndpa_frame = buffer;
-	struct _RT_NDPA_STA_INFO		sta_info;
-	u8					idx;
-	u8					dest_addr[6] = {0};
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry = NULL;
-
-	/* Fill the first MU BFee entry (STA1) MAC addr to destination address then
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	void *adapter = beam_info->source_adapter;
+	u16 duration = 0;
+	u8 sequence = 0;
+	u8 *p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO sta_info;
+	u8 idx;
+	u8 dest_addr[6] = {0};
+	struct _RT_BEAMFORMEE_ENTRY *entry = NULL;
+
+	/* @Fill the first MU BFee entry (STA1) MAC addr to destination address then
 	     HW will change A1 to broadcast addr. 2015.05.28. Suggested by SD1 Chunchu. */
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		p_entry = &(p_beam_info->beamformee_entry[idx]);
-		if (p_entry->is_mu_sta) {
-			cp_mac_addr(dest_addr, p_entry->mac_addr);
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			cp_mac_addr(dest_addr, entry->mac_addr);
 			break;
 		}
 	}
-	if (p_entry == NULL)
+	if (entry == NULL)
 		return;
 
-	/* Frame control.*/
+	/* @Frame control.*/
 	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
 	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
 
 	SET_80211_HDR_ADDRESS1(p_ndpa_frame, dest_addr);
-	SET_80211_HDR_ADDRESS2(p_ndpa_frame, p_entry->my_mac_addr);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, entry->my_mac_addr);
 
-	/*--------------------------------------------*/
-	/* <Note> Need to modify "duration" to MU consideration. */
+	/*@--------------------------------------------*/
+	/* @<Note> Need to modify "duration" to MU consideration. */
 	duration = 2 * a_SifsTime + 44;
 
 	if (BW == CHANNEL_WIDTH_80)
@@ -807,122 +788,118 @@ construct_vht_mu_ndpa_packet(
 		duration += 87;
 	else
 		duration += 180;
-	/*--------------------------------------------*/
+	/*@--------------------------------------------*/
 
 	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
 
-	sequence = *(p_dm->p_sounding_seq) << 2;
-	odm_move_memory(p_dm, p_ndpa_frame + 16, &sequence, 1);
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
 
 	*p_length = 17;
 
-	/* Construct STA info. for multiple STAs*/
+	/* @Construct STA info. for multiple STAs*/
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		p_entry = &(p_beam_info->beamformee_entry[idx]);
-		if (p_entry->is_mu_sta) {
-			sta_info.aid = p_entry->AID;
-			sta_info.feedback_type = 1; /* 1'b1: MU*/
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
+			sta_info.aid = entry->AID;
+			sta_info.feedback_type = 1; /* @1'b1: MU*/
 			sta_info.nc_index = 0;
 
-			PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Get beamformee_entry idx(%d), AID =%d\n", __func__, idx, p_entry->AID));
+			PHYDM_DBG(dm, DBG_TXBF,
+				  "[%s] Get beamformee_entry idx(%d), AID =%d\n",
+				  __func__, idx, entry->AID);
 
-			odm_move_memory(p_dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
+			odm_move_memory(dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
 			*p_length += 2;
 		}
 	}
-
 }
 
 boolean
 send_sw_vht_mu_ndpa_packet(
-	void			*p_dm_void,
-	enum channel_width	BW
-)
+	void *dm_void,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	PRT_TCB					p_tcb;
-	PRT_TX_LOCAL_BUFFER		p_buf;
-	boolean					ret = true;
-	u8					ndp_tx_rate = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u8 ndp_tx_rate = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	void *adapter = beam_info->source_adapter;
 
 	ndp_tx_rate = MGN_VHT2SS_MCS0;
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetBuffer(adapter, &p_tcb, &p_buf)) {
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
 		construct_vht_mu_ndpa_packet(
-			p_dm,
+			dm,
 			BW,
 			p_buf->Buffer.VirtualAddress,
-			&p_tcb->PacketLength
-		);
+			&tcb->PacketLength);
 
-		p_tcb->bTxEnableSwCalcDur = true;
-		p_tcb->BWOfPacket = BW;
-		p_tcb->TxBFPktType = RT_BF_PKT_TYPE_BROADCAST_NDPA;
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+		tcb->TxBFPktType = RT_BF_PKT_TYPE_BROADCAST_NDPA;
 
 		/*rate of NDP decide by nr*/
-		MgntSendPacket(adapter, p_tcb, p_buf, p_tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
 }
 
-
-void
-dbg_construct_vht_mundpa_packet(
-	struct PHY_DM_STRUCT		*p_dm,
-	enum channel_width	BW,
-	u8			*buffer,
-	u32			*p_length
-)
+void dbg_construct_vht_mundpa_packet(
+	struct dm_struct *dm,
+	enum channel_width BW,
+	u8 *buffer,
+	u32 *p_length)
 {
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
-	u16					duration = 0;
-	u8					sequence = 0;
-	u8					*p_ndpa_frame = buffer;
-	struct _RT_NDPA_STA_INFO		sta_info;
-	u8					idx;
-	u8					dest_addr[6] = {0};
-	struct _RT_BEAMFORMEE_ENTRY	*p_entry = NULL;
-
-	boolean	is_STA1 = false;
-
-
-	/* Fill the first MU BFee entry (STA1) MAC addr to destination address then
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	void *adapter = beam_info->source_adapter;
+	u16 duration = 0;
+	u8 sequence = 0;
+	u8 *p_ndpa_frame = buffer;
+	struct _RT_NDPA_STA_INFO sta_info;
+	u8 idx;
+	u8 dest_addr[6] = {0};
+	struct _RT_BEAMFORMEE_ENTRY *entry = NULL;
+
+	boolean is_STA1 = false;
+
+	/* @Fill the first MU BFee entry (STA1) MAC addr to destination address then
 	     HW will change A1 to broadcast addr. 2015.05.28. Suggested by SD1 Chunchu. */
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		p_entry = &(p_beam_info->beamformee_entry[idx]);
-		if (p_entry->is_mu_sta) {
+		entry = &(beam_info->beamformee_entry[idx]);
+		if (entry->is_mu_sta) {
 			if (is_STA1 == false) {
 				is_STA1 = true;
 				continue;
 			} else {
-				cp_mac_addr(dest_addr, p_entry->mac_addr);
+				cp_mac_addr(dest_addr, entry->mac_addr);
 				break;
 			}
 		}
 	}
 
-	/* Frame control.*/
+	/* @Frame control.*/
 	SET_80211_HDR_FRAME_CONTROL(p_ndpa_frame, 0);
 	SET_80211_HDR_TYPE_AND_SUBTYPE(p_ndpa_frame, Type_NDPA);
 
 	SET_80211_HDR_ADDRESS1(p_ndpa_frame, dest_addr);
-	SET_80211_HDR_ADDRESS2(p_ndpa_frame, p_dm->CurrentAddress);
+	SET_80211_HDR_ADDRESS2(p_ndpa_frame, dm->CurrentAddress);
 
-	/*--------------------------------------------*/
-	/* <Note> Need to modify "duration" to MU consideration. */
+	/*@--------------------------------------------*/
+	/* @<Note> Need to modify "duration" to MU consideration. */
 	duration = 2 * a_SifsTime + 44;
 
 	if (BW == CHANNEL_WIDTH_80)
@@ -931,135 +908,127 @@ dbg_construct_vht_mundpa_packet(
 		duration += 87;
 	else
 		duration += 180;
-	/*--------------------------------------------*/
+	/*@--------------------------------------------*/
 
 	SET_80211_HDR_DURATION(p_ndpa_frame, duration);
 
-	sequence = *(p_dm->p_sounding_seq) << 2;
-	odm_move_memory(p_dm, p_ndpa_frame + 16, &sequence, 1);
+	sequence = *(dm->sounding_seq) << 2;
+	odm_move_memory(dm, p_ndpa_frame + 16, &sequence, 1);
 
 	*p_length = 17;
 
 	/*STA2's STA Info*/
-	sta_info.aid = p_entry->aid;
-	sta_info.feedback_type = 1; /* 1'b1: MU */
+	sta_info.aid = entry->aid;
+	sta_info.feedback_type = 1; /* @1'b1: MU */
 	sta_info.nc_index = 0;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Get beamformee_entry idx(%d), AID =%d\n", __func__, idx, p_entry->aid));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Get beamformee_entry idx(%d), AID =%d\n",
+		  __func__, idx, entry->aid);
 
-	odm_move_memory(p_dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
+	odm_move_memory(dm, p_ndpa_frame + (*p_length), (u8 *)&sta_info, 2);
 	*p_length += 2;
-
 }
 
 boolean
 dbg_send_sw_vht_mundpa_packet(
-	void			*p_dm_void,
-	enum channel_width	BW
-)
+	void *dm_void,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	PRT_TCB					p_tcb;
-	PRT_TX_LOCAL_BUFFER		p_buf;
-	boolean					ret = true;
-	u8					ndp_tx_rate = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _ADAPTER				*adapter = p_beam_info->source_adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	PRT_TCB tcb;
+	PRT_TX_LOCAL_BUFFER p_buf;
+	boolean ret = true;
+	u8 ndp_tx_rate = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	void *adapter = beam_info->source_adapter;
 
 	ndp_tx_rate = MGN_VHT2SS_MCS0;
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 
 	PlatformAcquireSpinLock(adapter, RT_TX_SPINLOCK);
 
-	if (MgntGetBuffer(adapter, &p_tcb, &p_buf)) {
+	if (MgntGetBuffer(adapter, &tcb, &p_buf)) {
 		dbg_construct_vht_mundpa_packet(
-			p_dm,
+			dm,
 			BW,
 			p_buf->Buffer.VirtualAddress,
-			&p_tcb->PacketLength
-		);
+			&tcb->PacketLength);
 
-		p_tcb->bTxEnableSwCalcDur = true;
-		p_tcb->BWOfPacket = BW;
-		p_tcb->TxBFPktType = RT_BF_PKT_TYPE_UNICAST_NDPA;
+		tcb->bTxEnableSwCalcDur = true;
+		tcb->BWOfPacket = BW;
+		tcb->TxBFPktType = RT_BF_PKT_TYPE_UNICAST_NDPA;
 
 		/*rate of NDP decide by nr*/
-		MgntSendPacket(adapter, p_tcb, p_buf, p_tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
+		MgntSendPacket(adapter, tcb, p_buf, tcb->PacketLength, NORMAL_QUEUE, ndp_tx_rate);
 	} else
 		ret = false;
 
 	PlatformReleaseSpinLock(adapter, RT_TX_SPINLOCK);
 
 	if (ret)
-		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, p_tcb->PacketLength);
+		RT_DISP_DATA(FBEAM, FBEAM_DATA, "", p_buf->Buffer.VirtualAddress, tcb->PacketLength);
 
 	return ret;
 }
 
-
-#endif	/*#if (SUPPORT_MU_BF == 1)*/
-#endif	/*#ifdef SUPPORT_MU_BF*/
-
+#endif /*@#if (SUPPORT_MU_BF == 1)*/
+#endif /*@#ifdef SUPPORT_MU_BF*/
 
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 
-u32
-beamforming_get_report_frame(
-	void			*p_dm_void,
-	union recv_frame *precv_frame
-)
+u32 beamforming_get_report_frame(
+	void *dm_void,
+	union recv_frame *precv_frame)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u32					ret = _SUCCESS;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = NULL;
-	u8					*pframe = precv_frame->u.hdr.rx_data;
-	u32					frame_len = precv_frame->u.hdr.len;
-	u8					*TA;
-	u8					idx, offset;
-
-
-	/*Memory comparison to see if CSI report is the same with previous one*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u32 ret = _SUCCESS;
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = NULL;
+	u8 *pframe = precv_frame->u.hdr.rx_data;
+	u32 frame_len = precv_frame->u.hdr.len;
+	u8 *TA;
+	u8 idx, offset;
+
+	/*@Memory comparison to see if CSI report is the same with previous one*/
 	TA = get_addr2_ptr(pframe);
-	p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, TA, &idx);
-	if (p_beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
-		offset = 31;		/*24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
-	else if (p_beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
-		offset = 34;		/*24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
+	beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, TA, &idx);
+	if (beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
+		offset = 31; /*@24+(1+1+3)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
+	else if (beamform_entry->beamform_entry_cap & BEAMFORMER_CAP_HT_EXPLICIT)
+		offset = 34; /*@24+(1+1+6)+2  MAC header+(Category+ActionCode+MIMOControlField)+SNR(nc=2)*/
 	else
 		return ret;
 
-
 	return ret;
 }
 
-
 boolean
 send_fw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8	action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	u8	a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER *adapter = dm->adapter;
+	struct xmit_frame *pmgntframe;
+	struct pkt_attrib *pattrib;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8 action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8 *pframe;
+	u16 *fctrl;
+	u16 duration = 0;
+	u8 a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
 
 	if (pmgntframe == NULL) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s, alloc mgnt frame fail\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n",
+			  __func__);
 		return false;
 	}
 
@@ -1068,8 +1037,9 @@ send_fw_ht_ndpa_packet(
 	update_mgntframe_attrib(adapter, pattrib);
 
 	pattrib->qsel = QSLT_BEACON;
-	ndp_tx_rate = beamforming_get_htndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 	pattrib->rate = ndp_tx_rate;
 	pattrib->bwmode = BW;
 	pattrib->order = 1;
@@ -1088,7 +1058,7 @@ send_fw_ht_ndpa_packet(
 	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
 
 	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, p_beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
@@ -1105,7 +1075,7 @@ send_fw_ht_ndpa_packet(
 
 	set_duration(pframe, duration);
 
-	/* HT control field */
+	/* @HT control field */
 	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
 	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
 
@@ -1120,36 +1090,35 @@ send_fw_ht_ndpa_packet(
 	return true;
 }
 
-
 boolean
 send_sw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	u8	action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	u8	a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-
-	ndp_tx_rate = beamforming_get_htndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER *adapter = dm->adapter;
+	struct xmit_frame *pmgntframe;
+	struct pkt_attrib *pattrib;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8 action_hdr[4] = {ACT_CAT_VENDOR, 0x00, 0xe0, 0x4c};
+	u8 *pframe;
+	u16 *fctrl;
+	u16 duration = 0;
+	u8 a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_htndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
 
 	if (pmgntframe == NULL) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s, alloc mgnt frame fail\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n",
+			  __func__);
 		return false;
 	}
 
@@ -1175,7 +1144,7 @@ send_sw_ht_ndpa_packet(
 	set_frame_sub_type(pframe, WIFI_ACTION_NOACK);
 
 	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, p_beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
 	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
 
 	if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
@@ -1192,7 +1161,7 @@ send_sw_ht_ndpa_packet(
 
 	set_duration(pframe, duration);
 
-	/*HT control field*/
+	/*@HT control field*/
 	SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
 	SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
 
@@ -1207,36 +1176,35 @@ send_sw_ht_ndpa_packet(
 	return true;
 }
 
-
 boolean
 send_fw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	u8	sequence = 0, a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-	struct _RT_NDPA_STA_INFO	sta_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER *adapter = dm->adapter;
+	struct xmit_frame *pmgntframe;
+	struct pkt_attrib *pattrib;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	u8 *pframe;
+	u16 *fctrl;
+	u16 duration = 0;
+	u8 sequence = 0, a_sifs_time = 0, ndp_tx_rate = 0, idx = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+	struct _RT_NDPA_STA_INFO sta_info;
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
 
 	if (pmgntframe == NULL) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s, alloc mgnt frame fail\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n",
+			  __func__);
 		return false;
 	}
 
@@ -1246,8 +1214,9 @@ send_fw_vht_ndpa_packet(
 	update_mgntframe_attrib(adapter, pattrib);
 
 	pattrib->qsel = QSLT_BEACON;
-	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 	pattrib->rate = ndp_tx_rate;
 	pattrib->bwmode = BW;
 	pattrib->subtype = WIFI_NDPA;
@@ -1264,7 +1233,7 @@ send_fw_vht_ndpa_packet(
 	set_frame_sub_type(pframe, WIFI_NDPA);
 
 	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, p_beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
 
 	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
 		a_sifs_time = 16;
@@ -1282,11 +1251,11 @@ send_fw_vht_ndpa_packet(
 
 	set_duration(pframe, duration);
 
-	sequence = p_beam_info->sounding_sequence << 2;
-	if (p_beam_info->sounding_sequence >= 0x3f)
-		p_beam_info->sounding_sequence = 0;
+	sequence = beam_info->sounding_sequence << 2;
+	if (beam_info->sounding_sequence >= 0x3f)
+		beam_info->sounding_sequence = 0;
 	else
-		p_beam_info->sounding_sequence++;
+		beam_info->sounding_sequence++;
 
 	_rtw_memcpy(pframe + 16, &sequence, 1);
 
@@ -1308,40 +1277,39 @@ send_fw_vht_ndpa_packet(
 	return true;
 }
 
-
-
 boolean
 send_sw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-)
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW)
 {
-	struct PHY_DM_STRUCT				*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _ADAPTER				*adapter = p_dm->adapter;
-	struct xmit_frame		*pmgntframe;
-	struct pkt_attrib		*pattrib;
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	struct xmit_priv		*pxmitpriv = &(adapter->xmitpriv);
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	struct mlme_priv		*pmlmepriv = &(adapter->mlmepriv);
-	struct _RT_NDPA_STA_INFO	ndpa_sta_info;
-	u8	ndp_tx_rate = 0, sequence = 0, a_sifs_time = 0, idx = 0;
-	u8	*pframe;
-	u16	*fctrl;
-	u16	duration = 0;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &(p_dm->beamforming_info);
-	struct _RT_BEAMFORMEE_ENTRY	*p_beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(p_dm, RA, &idx);
-
-	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(p_dm, p_beamform_entry->comp_steering_num_of_bfer);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndp_tx_rate =%d\n", __func__, ndp_tx_rate));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _ADAPTER *adapter = dm->adapter;
+	struct xmit_frame *pmgntframe;
+	struct pkt_attrib *pattrib;
+	struct rtw_ieee80211_hdr *pwlanhdr;
+	struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
+	struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
+	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
+	struct _RT_NDPA_STA_INFO ndpa_sta_info;
+	u8 ndp_tx_rate = 0, sequence = 0, a_sifs_time = 0, idx = 0;
+	u8 *pframe;
+	u16 *fctrl;
+	u16 duration = 0;
+	struct _RT_BEAMFORMING_INFO *beam_info = &(dm->beamforming_info);
+	struct _RT_BEAMFORMEE_ENTRY *beamform_entry = phydm_beamforming_get_bfee_entry_by_addr(dm, RA, &idx);
+
+	ndp_tx_rate = beamforming_get_vht_ndp_tx_rate(dm, beamform_entry->comp_steering_num_of_bfer);
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndp_tx_rate =%d\n", __func__,
+		  ndp_tx_rate);
 
 	pmgntframe = alloc_mgtxmitframe(pxmitpriv);
 
 	if (pmgntframe == NULL) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s, alloc mgnt frame fail\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s, alloc mgnt frame fail\n",
+			  __func__);
 		return false;
 	}
 
@@ -1366,7 +1334,7 @@ send_sw_vht_ndpa_packet(
 	set_frame_sub_type(pframe, WIFI_NDPA);
 
 	_rtw_memcpy(pwlanhdr->addr1, RA, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, p_beamform_entry->my_mac_addr, ETH_ALEN);
+	_rtw_memcpy(pwlanhdr->addr2, beamform_entry->my_mac_addr, ETH_ALEN);
 
 	if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
 		a_sifs_time = 16;
@@ -1384,11 +1352,11 @@ send_sw_vht_ndpa_packet(
 
 	set_duration(pframe, duration);
 
-	sequence = p_beam_info->sounding_sequence << 2;
-	if (p_beam_info->sounding_sequence >= 0x3f)
-		p_beam_info->sounding_sequence = 0;
+	sequence = beam_info->sounding_sequence << 2;
+	if (beam_info->sounding_sequence >= 0x3f)
+		beam_info->sounding_sequence = 0;
 	else
-		p_beam_info->sounding_sequence++;
+		beam_info->sounding_sequence++;
 
 	_rtw_memcpy(pframe + 16, &sequence, 1);
 	if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE))
@@ -1405,45 +1373,43 @@ send_sw_vht_ndpa_packet(
 	pattrib->last_txcmdsz = pattrib->pktlen;
 
 	dump_mgntframe(adapter, pmgntframe);
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] [%d]\n", __func__, __LINE__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] [%d]\n", __func__, __LINE__);
 
 	return true;
 }
 
-
 #endif
 
-
-void
-beamforming_get_ndpa_frame(
-	void			*p_dm_void,
+void beamforming_get_ndpa_frame(
+	void *dm_void,
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	OCTET_STRING	pdu_os
+	OCTET_STRING pdu_os
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 	union recv_frame *precv_frame
 #endif
-)
+	)
 {
-	struct PHY_DM_STRUCT					*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8						*TA ;
-	u8						idx, sequence;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 *TA;
+	u8 idx, sequence;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	u8						*p_ndpa_frame = pdu_os.Octet;
+	u8 *p_ndpa_frame = pdu_os.Octet;
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	u8						*p_ndpa_frame = precv_frame->u.hdr.rx_data;
+	u8 *p_ndpa_frame = precv_frame->u.hdr.rx_data;
 #endif
-	struct _RT_BEAMFORMER_ENTRY		*p_beamformer_entry = NULL;		/*Modified By Jeffery @2014-10-29*/
-
+	struct _RT_BEAMFORMER_ENTRY *beamformer_entry = NULL; /*@Modified By Jeffery @2014-10-29*/
 
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	RT_DISP_DATA(FBEAM, FBEAM_DATA, "beamforming_get_ndpa_frame\n", pdu_os.Octet, pdu_os.Length);
+	RT_DISP_DATA(FBEAM, FBEAM_DATA, "beamforming_get_ndpa_frame\n",
+	pdu_os.Octet, pdu_os.Length);
 	if (IsCtrlNDPA(p_ndpa_frame) == false)
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 	if (get_frame_sub_type(p_ndpa_frame) != WIFI_NDPA)
 #endif
 		return;
-	else if (!(p_dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] not 8812 or 8821A, return\n", __func__));
+	else if (!(dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821))) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] not 8812 or 8821A, return\n",
+			  __func__);
 		return;
 	}
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
@@ -1454,57 +1420,66 @@ beamforming_get_ndpa_frame(
 	/*Remove signaling TA. */
 	TA[0] = TA[0] & 0xFE;
 
-	p_beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(p_dm, TA, &idx);		/* Modified By Jeffery @2014-10-29 */
+	beamformer_entry = phydm_beamforming_get_bfer_entry_by_addr(dm, TA, &idx); /* @Modified By Jeffery @2014-10-29 */
 
-	/*Break options for Clock Reset*/
-	if (p_beamformer_entry == NULL)
+	/*@Break options for Clock Reset*/
+	if (beamformer_entry == NULL)
 		return;
-	else if (!(p_beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU))
+	else if (!(beamformer_entry->beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU))
 		return;
-	/*log_success: As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is NO LONGER needed !2015-04-10, Jeffery*/
-	/*clock_reset_times: While BFer entry always doesn't receive our CSI, clock will reset again and again.So clock_reset_times is limited to 5 times.2015-04-13, Jeffery*/
-	else if ((p_beamformer_entry->log_success == 1) || (p_beamformer_entry->clock_reset_times == 5)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, log_success=%d, clock_reset_times=%d, clock reset is no longer needed.\n",
-			__func__, p_beamformer_entry->log_seq, p_beamformer_entry->pre_log_seq, p_beamformer_entry->log_retry_cnt, p_beamformer_entry->log_success, p_beamformer_entry->clock_reset_times));
+	/*@log_success: As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is NO LONGER needed !2015-04-10, Jeffery*/
+	/*@clock_reset_times: While BFer entry always doesn't receive our CSI, clock will reset again and again.So clock_reset_times is limited to 5 times.2015-04-13, Jeffery*/
+	else if ((beamformer_entry->log_success == 1) || (beamformer_entry->clock_reset_times == 5)) {
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "[%s] log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, log_success=%d, clock_reset_times=%d, clock reset is no longer needed.\n",
+			  __func__, beamformer_entry->log_seq,
+			  beamformer_entry->pre_log_seq,
+			  beamformer_entry->log_retry_cnt,
+			  beamformer_entry->log_success,
+			  beamformer_entry->clock_reset_times);
 
 		return;
 	}
 
 	sequence = (p_ndpa_frame[16]) >> 2;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start, sequence=%d, log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, clock_reset_times=%d, log_success=%d\n",
-		__func__, sequence, p_beamformer_entry->log_seq, p_beamformer_entry->pre_log_seq, p_beamformer_entry->log_retry_cnt, p_beamformer_entry->clock_reset_times, p_beamformer_entry->log_success));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] Start, sequence=%d, log_seq=%d, pre_log_seq=%d, log_retry_cnt=%d, clock_reset_times=%d, log_success=%d\n",
+		  __func__, sequence, beamformer_entry->log_seq,
+		  beamformer_entry->pre_log_seq,
+		  beamformer_entry->log_retry_cnt,
+		  beamformer_entry->clock_reset_times,
+		  beamformer_entry->log_success);
 
-	if ((p_beamformer_entry->log_seq != 0) && (p_beamformer_entry->pre_log_seq != 0)) {
+	if (beamformer_entry->log_seq != 0 && beamformer_entry->pre_log_seq != 0) {
 		/*Success condition*/
-		if ((p_beamformer_entry->log_seq != sequence) && (p_beamformer_entry->pre_log_seq != p_beamformer_entry->log_seq)) {
-			/* break option for clcok reset, 2015-03-30, Jeffery */
-			p_beamformer_entry->log_retry_cnt = 0;
-			/*As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is no longer needed.*/
+		if (beamformer_entry->log_seq != sequence && beamformer_entry->pre_log_seq != beamformer_entry->log_seq) {
+			/* @break option for clcok reset, 2015-03-30, Jeffery */
+			beamformer_entry->log_retry_cnt = 0;
+			/*@As long as 8812A receive NDPA and feedback CSI succeed once, clock reset is no longer needed.*/
 			/*That is, log_success is NOT needed to be reset to zero, 2015-04-13, Jeffery*/
-			p_beamformer_entry->log_success = 1;
+			beamformer_entry->log_success = 1;
 
-		} else {/*Fail condition*/
+		} else { /*@Fail condition*/
 
-			if (p_beamformer_entry->log_retry_cnt == 5) {
-				p_beamformer_entry->clock_reset_times++;
-				p_beamformer_entry->log_retry_cnt = 0;
+			if (beamformer_entry->log_retry_cnt == 5) {
+				beamformer_entry->clock_reset_times++;
+				beamformer_entry->log_retry_cnt = 0;
 
-				PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Clock Reset!!! clock_reset_times=%d\n",
-					__func__, p_beamformer_entry->clock_reset_times));
-				hal_com_txbf_set(p_dm, TXBF_SET_SOUNDING_CLK, NULL);
+				PHYDM_DBG(dm, DBG_TXBF,
+					  "[%s] Clock Reset!!! clock_reset_times=%d\n",
+					  __func__,
+					  beamformer_entry->clock_reset_times);
+				hal_com_txbf_set(dm, TXBF_SET_SOUNDING_CLK, NULL);
 
 			} else
-				p_beamformer_entry->log_retry_cnt++;
+				beamformer_entry->log_retry_cnt++;
 		}
 	}
 
 	/*Update log_seq & pre_log_seq*/
-	p_beamformer_entry->pre_log_seq = p_beamformer_entry->log_seq;
-	p_beamformer_entry->log_seq = sequence;
-
+	beamformer_entry->pre_log_seq = beamformer_entry->log_seq;
+	beamformer_entry->log_seq = sequence;
 }
 
-
-
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.h
index 795cfc8b5f81..28ba104746fe 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfinterface.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,172 +9,160 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #ifndef __HAL_TXBF_INTERFACE_H__
 #define __HAL_TXBF_INTERFACE_H__
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 
-#define a_SifsTime					((IS_WIRELESS_MODE_5G(adapter)|| IS_WIRELESS_MODE_N_24G(adapter))? 16 : 10)
+#define a_SifsTime ((IS_WIRELESS_MODE_5G(adapter) || IS_WIRELESS_MODE_N_24G(adapter)) ? 16 : 10)
 
-void
-beamforming_gid_paid(
-	struct _ADAPTER	*adapter,
-	PRT_TCB		p_tcb
-);
+void beamforming_gid_paid(
+	void *adapter,
+	PRT_TCB tcb);
 
 enum rt_status
 beamforming_get_report_frame(
-	struct _ADAPTER		*adapter,
-	PRT_RFD			p_rfd,
-	POCTET_STRING	p_pdu_os
-);
+	void *adapter,
+	PRT_RFD rfd,
+	POCTET_STRING p_pdu_os);
 
-void
-beamforming_get_ndpa_frame(
-	void			*p_dm_void,
-	OCTET_STRING	pdu_os
-);
+void beamforming_get_ndpa_frame(
+	void *dm_void,
+	OCTET_STRING pdu_os);
 
 boolean
 send_fw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW);
 
 boolean
 send_fw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW);
 
 boolean
 send_sw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW);
 
 boolean
 send_sw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW);
 
 #if (SUPPORT_MU_BF == 1)
 enum rt_status
 beamforming_get_vht_gid_mgnt_frame(
-	struct _ADAPTER		*adapter,
-	PRT_RFD			p_rfd,
-	POCTET_STRING	p_pdu_os
-);
+	void *adapter,
+	PRT_RFD rfd,
+	POCTET_STRING p_pdu_os);
 
 boolean
 send_sw_vht_gid_mgnt_frame(
-	void			*p_dm_void,
-	u8			*RA,
-	u8			idx
-);
+	void *dm_void,
+	u8 *RA,
+	u8 idx);
 
 boolean
 send_sw_vht_bf_report_poll(
-	void			*p_dm_void,
-	u8			*RA,
-	boolean			is_final_poll
-);
+	void *dm_void,
+	u8 *RA,
+	boolean is_final_poll);
 
 boolean
 send_sw_vht_mu_ndpa_packet(
-	void			*p_dm_void,
-	enum channel_width	BW
-);
+	void *dm_void,
+	enum channel_width BW);
 #else
-#define beamforming_get_vht_gid_mgnt_frame(adapter, p_rfd, p_pdu_os) RT_STATUS_FAILURE
-#define send_sw_vht_gid_mgnt_frame(p_dm_void, RA)
-#define send_sw_vht_bf_report_poll(p_dm_void, RA, is_final_poll)
-#define send_sw_vht_mu_ndpa_packet(p_dm_void, BW)
+#define beamforming_get_vht_gid_mgnt_frame(adapter, rfd, p_pdu_os) RT_STATUS_FAILURE
+#define send_sw_vht_gid_mgnt_frame(dm_void, RA)
+#define send_sw_vht_bf_report_poll(dm_void, RA, is_final_poll)
+#define send_sw_vht_mu_ndpa_packet(dm_void, BW)
 #endif
 
-
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 
-u32
-beamforming_get_report_frame(
-	void			*p_dm_void,
-	union recv_frame *precv_frame
-);
+u32 beamforming_get_report_frame(
+	void *dm_void,
+	union recv_frame *precv_frame);
 
 boolean
 send_fw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW);
 
 boolean
 send_sw_ht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	enum channel_width BW);
 
 boolean
 send_fw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW);
 
 boolean
 send_sw_vht_ndpa_packet(
-	void			*p_dm_void,
-	u8			*RA,
-	u16			AID,
-	enum channel_width	BW
-);
+	void *dm_void,
+	u8 *RA,
+	u16 AID,
+	enum channel_width BW);
 #endif
 
-void
-beamforming_get_ndpa_frame(
-	void			*p_dm_void,
+void beamforming_get_ndpa_frame(
+	void *dm_void,
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	OCTET_STRING	pdu_os
+	OCTET_STRING pdu_os
 #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
 	union recv_frame *precv_frame
 #endif
-);
+	);
 
 boolean
 dbg_send_sw_vht_mundpa_packet(
-	void			*p_dm_void,
-	enum channel_width	BW
-);
+	void *dm_void,
+	enum channel_width BW);
 
 #else
-#define beamforming_get_ndpa_frame(p_dm, _pdu_os)
+#define beamforming_get_ndpa_frame(dm, _pdu_os)
 #if (DM_ODM_SUPPORT_TYPE == ODM_CE)
-	#define beamforming_get_report_frame(adapter, precv_frame)		RT_STATUS_FAILURE
+#define beamforming_get_report_frame(adapter, precv_frame) RT_STATUS_FAILURE
 #elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	#define beamforming_get_report_frame(adapter, p_rfd, p_pdu_os)		RT_STATUS_FAILURE
-	#define beamforming_get_vht_gid_mgnt_frame(adapter, p_rfd, p_pdu_os) RT_STATUS_FAILURE
+#define beamforming_get_report_frame(adapter, rfd, p_pdu_os) RT_STATUS_FAILURE
+#define beamforming_get_vht_gid_mgnt_frame(adapter, rfd, p_pdu_os) RT_STATUS_FAILURE
 #endif
-#define send_fw_ht_ndpa_packet(p_dm_void, RA, BW)
-#define send_sw_ht_ndpa_packet(p_dm_void, RA, BW)
-#define send_fw_vht_ndpa_packet(p_dm_void, RA, AID, BW)
-#define send_sw_vht_ndpa_packet(p_dm_void, RA,	AID, BW)
-#define send_sw_vht_gid_mgnt_frame(p_dm_void, RA, idx)
-#define send_sw_vht_bf_report_poll(p_dm_void, RA, is_final_poll)
-#define send_sw_vht_mu_ndpa_packet(p_dm_void, BW)
+#define send_fw_ht_ndpa_packet(dm_void, RA, BW)
+#define send_sw_ht_ndpa_packet(dm_void, RA, BW)
+#define send_fw_vht_ndpa_packet(dm_void, RA, AID, BW)
+#define send_sw_vht_ndpa_packet(dm_void, RA, AID, BW)
+#define send_sw_vht_gid_mgnt_frame(dm_void, RA, idx)
+#define send_sw_vht_bf_report_poll(dm_void, RA, is_final_poll)
+#define send_sw_vht_mu_ndpa_packet(dm_void, BW)
 #endif
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.c
index 038683739b50..79a821564ba0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -12,193 +13,183 @@
  * more details.
  *
  *****************************************************************************/
-/* ************************************************************
+/*************************************************************
  * Description:
  *
  * This file is for 8812/8821/8811 TXBF mechanism
  *
- * ************************************************************ */
+ ************************************************************/
 #include "mp_precomp.h"
 #include "../phydm_precomp.h"
 
-#if (BEAMFORMING_SUPPORT == 1)
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 #if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-void
-hal_txbf_8812a_set_ndpa_rate(
-	void			*p_dm_void,
-	u8	BW,
-	u8	rate
-)
+void hal_txbf_8812a_set_ndpa_rate(
+	void *dm_void,
+	u8 BW,
+	u8 rate)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-
-	odm_write_1byte(p_dm, REG_NDPA_OPT_CTRL_8812A, (rate << 2 | BW));
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+	odm_write_1byte(dm, REG_NDPA_OPT_CTRL_8812A, (rate << 2 | BW));
 }
 
-void
-hal_txbf_jaguar_rf_mode(
-	void			*p_dm_void,
-	struct _RT_BEAMFORMING_INFO	*p_beam_info
-)
+void hal_txbf_jaguar_rf_mode(
+	void *dm_void,
+	struct _RT_BEAMFORMING_INFO *beam_info)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
-	if (p_dm->rf_type == RF_1T1R)
+	if (dm->rf_type == RF_1T1R)
 		return;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] set TxIQGen\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] set TxIQGen\n", __func__);
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x1);	/*RF mode table write enable*/
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x1);	/*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, 0x80000, 0x1); /*RF mode table write enable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_0xef, 0x80000, 0x1); /*RF mode table write enable*/
 
-	if (p_beam_info->beamformee_su_cnt > 0) {
+	if (beam_info->beamformee_su_cnt > 0) {
 		/* Paath_A */
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0x78000, 0x3);		/*Select RX mode*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x30, 0x78000, 0x3); /*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x31, 0xfffff, 0x3F7FF); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x32, 0xfffff, 0xE26BF); /*@Enable TXIQGEN in RX mode*/
 		/* Path_B */
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0x78000, 0x3);		/*Select RX mode*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0xE26BF);	/*Enable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x30, 0x78000, 0x3); /*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x31, 0xfffff, 0x3F7FF); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x32, 0xfffff, 0xE26BF); /*@Enable TXIQGEN in RX mode*/
 	} else {
 		/* Paath_A */
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x30, 0x78000, 0x3);		/*Select RX mode*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_A, 0x32, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x30, 0x78000, 0x3); /*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x31, 0xfffff, 0x3F7FF); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_A, RF_0x32, 0xfffff, 0xC26BF); /*@Disable TXIQGEN in RX mode*/
 		/* Path_B */
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x30, 0x78000, 0x3);		/*Select RX mode*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x31, 0xfffff, 0x3F7FF);	/*Set Table data*/
-		odm_set_rf_reg(p_dm, RF_PATH_B, 0x32, 0xfffff, 0xC26BF);	/*Disable TXIQGEN in RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x30, 0x78000, 0x3); /*Select RX mode*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x31, 0xfffff, 0x3F7FF); /*Set Table data*/
+		odm_set_rf_reg(dm, RF_PATH_B, RF_0x32, 0xfffff, 0xC26BF); /*@Disable TXIQGEN in RX mode*/
 	}
 
-	odm_set_rf_reg(p_dm, RF_PATH_A, 0xef, 0x80000, 0x0);	/*RF mode table write disable*/
-	odm_set_rf_reg(p_dm, RF_PATH_B, 0xef, 0x80000, 0x0);	/*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_A, RF_0xef, 0x80000, 0x0); /*RF mode table write disable*/
+	odm_set_rf_reg(dm, RF_PATH_B, RF_0xef, 0x80000, 0x0); /*RF mode table write disable*/
 
-	if (p_beam_info->beamformee_su_cnt > 0)
-		odm_set_bb_reg(p_dm, 0x80c, MASKBYTE1, 0x33);
+	if (beam_info->beamformee_su_cnt > 0)
+		odm_set_bb_reg(dm, R_0x80c, MASKBYTE1, 0x33);
 	else
-		odm_set_bb_reg(p_dm, 0x80c, MASKBYTE1, 0x11);
+		odm_set_bb_reg(dm, R_0x80c, MASKBYTE1, 0x11);
 }
 
-
-void
-hal_txbf_jaguar_download_ndpa(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_jaguar_download_ndpa(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8			u1b_tmp = 0, tmp_reg422 = 0, head_page;
-	u8			bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
-	boolean			is_send_beacon = false;
-	u8			tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812;	/*default reseved 1 page for the IC type which is undefined.*/
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
-	struct _ADAPTER		*adapter = p_dm->adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 u1b_tmp = 0, tmp_reg422 = 0, head_page;
+	u8 bcn_valid_reg = 0, count = 0, dl_bcn_count = 0;
+	boolean is_send_beacon = false;
+	u8 tx_page_bndy = LAST_ENTRY_OF_TX_PKT_BUFFER_8812; /*@default reseved 1 page for the IC type which is undefined.*/
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *p_beam_entry = beam_info->beamformee_entry + idx;
+	void *adapter = dm->adapter;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*p_dm->p_is_fw_dw_rsvd_page_in_progress = true;
+	*dm->is_fw_dw_rsvd_page_in_progress = true;
 #endif
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	if (idx == 0)
 		head_page = 0xFE;
 	else
 		head_page = 0xFE;
 
-	phydm_get_hal_def_var_handler_interface(p_dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
+	phydm_get_hal_def_var_handler_interface(dm, HAL_DEF_TX_PAGE_BOUNDARY, (u8 *)&tx_page_bndy);
 
 	/*Set REG_CR bit 8. DMA beacon by SW.*/
-	u1b_tmp = odm_read_1byte(p_dm, REG_CR_8812A + 1);
-	odm_write_1byte(p_dm,  REG_CR_8812A + 1, (u1b_tmp | BIT(0)));
-
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8812A + 1);
+	odm_write_1byte(dm, REG_CR_8812A + 1, (u1b_tmp | BIT(0)));
 
 	/*Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame.*/
-	tmp_reg422 = odm_read_1byte(p_dm, REG_FWHW_TXQ_CTRL_8812A + 2);
-	odm_write_1byte(p_dm, REG_FWHW_TXQ_CTRL_8812A + 2,  tmp_reg422 & (~BIT(6)));
+	tmp_reg422 = odm_read_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2);
+	odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2, tmp_reg422 & (~BIT(6)));
 
 	if (tmp_reg422 & BIT(6)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("SetBeamformDownloadNDPA_8812(): There is an adapter is sending beacon.\n"));
+		PHYDM_DBG(dm, DBG_TXBF,
+			  "SetBeamformDownloadNDPA_8812(): There is an adapter is sending beacon.\n");
 		is_send_beacon = true;
 	}
 
 	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
-	odm_write_1byte(p_dm, REG_TDECTRL_8812A + 1, head_page);
+	odm_write_1byte(dm, REG_TDECTRL_8812A + 1, head_page);
 
 	do {
-		/*Clear beacon valid check bit.*/
-		bcn_valid_reg = odm_read_1byte(p_dm, REG_TDECTRL_8812A + 2);
-		odm_write_1byte(p_dm, REG_TDECTRL_8812A + 2, (bcn_valid_reg | BIT(0)));
+		/*@Clear beacon valid check bit.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
+		odm_write_1byte(dm, REG_TDECTRL_8812A + 2, (bcn_valid_reg | BIT(0)));
 
-		/*download NDPA rsvd page.*/
+		/*@download NDPA rsvd page.*/
 		if (p_beam_entry->beamform_entry_cap & BEAMFORMER_CAP_VHT_SU)
-			beamforming_send_vht_ndpa_packet(p_dm, p_beam_entry->mac_addr, p_beam_entry->aid, p_beam_entry->sound_bw, BEACON_QUEUE);
+			beamforming_send_vht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->aid, p_beam_entry->sound_bw, BEACON_QUEUE);
 		else
-			beamforming_send_ht_ndpa_packet(p_dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
+			beamforming_send_ht_ndpa_packet(dm, p_beam_entry->mac_addr, p_beam_entry->sound_bw, BEACON_QUEUE);
 
-		/*check rsvd page download OK.*/
-		bcn_valid_reg = odm_read_1byte(p_dm, REG_TDECTRL_8812A + 2);
+		/*@check rsvd page download OK.*/
+		bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
 		count = 0;
 		while (!(bcn_valid_reg & BIT(0)) && count < 20) {
 			count++;
 			ODM_delay_ms(10);
-			bcn_valid_reg = odm_read_1byte(p_dm, REG_TDECTRL_8812A + 2);
+			bcn_valid_reg = odm_read_1byte(dm, REG_TDECTRL_8812A + 2);
 		}
 		dl_bcn_count++;
 	} while (!(bcn_valid_reg & BIT(0)) && dl_bcn_count < 5);
 
 	if (!(bcn_valid_reg & BIT(0)))
-		PHYDM_DBG(p_dm, DBG_TXBF, ("%s Download RSVD page failed!\n", __func__));
+		PHYDM_DBG(dm, DBG_TXBF, "%s Download RSVD page failed!\n",
+			  __func__);
 
 	/*TDECTRL[15:8] 0x209[7:0] = 0xF6	Beacon Head for TXDMA*/
-	odm_write_1byte(p_dm, REG_TDECTRL_8812A + 1, tx_page_bndy);
+	odm_write_1byte(dm, REG_TDECTRL_8812A + 1, tx_page_bndy);
 
 	/*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*/
+	/*@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.*/
+	/*@2010.06.23. Added by tynli.*/
 	if (is_send_beacon)
-		odm_write_1byte(p_dm, REG_FWHW_TXQ_CTRL_8812A + 2, tmp_reg422);
+		odm_write_1byte(dm, REG_FWHW_TXQ_CTRL_8812A + 2, tmp_reg422);
 
-	/*Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
-	/*Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
-	u1b_tmp = odm_read_1byte(p_dm, REG_CR_8812A + 1);
-	odm_write_1byte(p_dm, REG_CR_8812A + 1, (u1b_tmp & (~BIT(0))));
+	/*@Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli.*/
+	/*@Clear CR[8] or beacon packet will not be send to TxBuf anymore.*/
+	u1b_tmp = odm_read_1byte(dm, REG_CR_8812A + 1);
+	odm_write_1byte(dm, REG_CR_8812A + 1, (u1b_tmp & (~BIT(0))));
 
 	p_beam_entry->beamform_entry_state = BEAMFORMING_ENTRY_STATE_PROGRESSED;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	*p_dm->p_is_fw_dw_rsvd_page_in_progress = false;
+	*dm->is_fw_dw_rsvd_page_in_progress = false;
 #endif
 }
 
-
-void
-hal_txbf_jaguar_fw_txbf_cmd(
-	void			*p_dm_void
-)
+void hal_txbf_jaguar_fw_txbf_cmd(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8	idx, period0 = 0, period1 = 0;
-	u8	PageNum0 = 0xFF, PageNum1 = 0xFF;
-	u8	u1_tx_bf_parm[3] = {0};
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 idx, period0 = 0, period1 = 0;
+	u8 PageNum0 = 0xFF, PageNum1 = 0xFF;
+	u8 u1_tx_bf_parm[3] = {0};
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
 	for (idx = 0; idx < BEAMFORMEE_ENTRY_NUM; idx++) {
-		/*Modified by David*/
-		if (p_beam_info->beamformee_entry[idx].is_used && p_beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
+		/*@Modified by David*/
+		if (beam_info->beamformee_entry[idx].is_used && beam_info->beamformee_entry[idx].beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) {
 			if (idx == 0) {
-				if (p_beam_info->beamformee_entry[idx].is_sound)
+				if (beam_info->beamformee_entry[idx].is_sound)
 					PageNum0 = 0xFE;
 				else
 					PageNum0 = 0xFF; /*stop sounding*/
-				period0 = (u8)(p_beam_info->beamformee_entry[idx].sound_period);
+				period0 = (u8)(beam_info->beamformee_entry[idx].sound_period);
 			} else if (idx == 1) {
-				if (p_beam_info->beamformee_entry[idx].is_sound)
+				if (beam_info->beamformee_entry[idx].is_sound)
 					PageNum1 = 0xFE;
 				else
 					PageNum1 = 0xFF; /*stop sounding*/
-				period1 = (u8)(p_beam_info->beamformee_entry[idx].sound_period);
+				period1 = (u8)(beam_info->beamformee_entry[idx].sound_period);
 			}
 		}
 	}
@@ -206,177 +197,167 @@ hal_txbf_jaguar_fw_txbf_cmd(
 	u1_tx_bf_parm[0] = PageNum0;
 	u1_tx_bf_parm[1] = PageNum1;
 	u1_tx_bf_parm[2] = (period1 << 4) | period0;
-	odm_fill_h2c_cmd(p_dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
+	odm_fill_h2c_cmd(dm, PHYDM_H2C_TXBF, 3, u1_tx_bf_parm);
 
-	PHYDM_DBG(p_dm, DBG_TXBF,
-		("[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n", __func__, PageNum0, period0, PageNum1, period1));
+	PHYDM_DBG(dm, DBG_TXBF,
+		  "[%s] PageNum0 = %d period0 = %d, PageNum1 = %d period1 %d\n",
+		  __func__, PageNum0, period0, PageNum1, period1);
 }
 
-
-void
-hal_txbf_jaguar_enter(
-	void			*p_dm_void,
-	u8				bfer_bfee_idx
-)
+void hal_txbf_jaguar_enter(
+	void *dm_void,
+	u8 bfer_bfee_idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8					i = 0;
-	u8					bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
-	u8					bfee_idx = (bfer_bfee_idx & 0xF);
-	u32					csi_param;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
-	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
-	u16					sta_id = 0;
-
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]Start!\n", __func__));
-
-	hal_txbf_jaguar_rf_mode(p_dm, p_beamforming_info);
-
-	if (p_dm->rf_type == RF_2T2R)
-		odm_set_bb_reg(p_dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x00000000);	/*nc =2*/
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i = 0;
+	u8 bfer_idx = (bfer_bfee_idx & 0xF0) >> 4;
+	u8 bfee_idx = (bfer_bfee_idx & 0xF);
+	u32 csi_param;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
+	struct _RT_BEAMFORMER_ENTRY beamformer_entry;
+	u16 sta_id = 0;
+
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]Start!\n", __func__);
+
+	hal_txbf_jaguar_rf_mode(dm, beamforming_info);
+
+	if (dm->rf_type == RF_2T2R)
+		odm_set_bb_reg(dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x00000000); /*nc =2*/
 	else
-		odm_set_bb_reg(p_dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x01081008);	/*nc =1*/
+		odm_set_bb_reg(dm, ODM_REG_CSI_CONTENT_VALUE, MASKDWORD, 0x01081008); /*nc =1*/
 
-	if ((p_beamforming_info->beamformer_su_cnt > 0) && (bfer_idx < BEAMFORMER_ENTRY_NUM)) {
-		beamformer_entry = p_beamforming_info->beamformer_entry[bfer_idx];
+	if (beamforming_info->beamformer_su_cnt > 0 && bfer_idx < BEAMFORMER_ENTRY_NUM) {
+		beamformer_entry = beamforming_info->beamformer_entry[bfer_idx];
 
 		/*Sounding protocol control*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
 
-		/*MAC address/Partial AID of Beamformer*/
+		/*@MAC address/Partial AID of Beamformer*/
 		if (bfer_idx == 0) {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_BFMER0_INFO_8812A + i), beamformer_entry.mac_addr[i]);
-			/*CSI report use legacy ofdm so don't need to fill P_AID. */
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_BFMER0_INFO_8812A + i), beamformer_entry.mac_addr[i]);
+			/*@CSI report use legacy ofdm so don't need to fill P_AID. */
 			/*platform_efio_write_2byte(adapter, REG_BFMER0_INFO_8812A+6, beamform_entry.P_AID); */
 		} else {
-			for (i = 0; i < 6 ; i++)
-				odm_write_1byte(p_dm, (REG_BFMER1_INFO_8812A + i), beamformer_entry.mac_addr[i]);
-			/*CSI report use legacy ofdm so don't need to fill P_AID.*/
+			for (i = 0; i < 6; i++)
+				odm_write_1byte(dm, (REG_BFMER1_INFO_8812A + i), beamformer_entry.mac_addr[i]);
+			/*@CSI report use legacy ofdm so don't need to fill P_AID.*/
 			/*platform_efio_write_2byte(adapter, REG_BFMER1_INFO_8812A+6, beamform_entry.P_AID);*/
 		}
 
-		/*CSI report parameters of Beamformee*/
+		/*@CSI report parameters of Beamformee*/
 		if (beamformer_entry.beamform_entry_cap & BEAMFORMEE_CAP_VHT_SU) {
-			if (p_dm->rf_type == RF_2T2R)
+			if (dm->rf_type == RF_2T2R)
 				csi_param = 0x01090109;
 			else
 				csi_param = 0x01080108;
 		} else {
-			if (p_dm->rf_type == RF_2T2R)
+			if (dm->rf_type == RF_2T2R)
 				csi_param = 0x03090309;
 			else
 				csi_param = 0x03080308;
 		}
 
-		odm_write_4byte(p_dm, REG_CSI_RPT_PARAM_BW20_8812A, csi_param);
-		odm_write_4byte(p_dm, REG_CSI_RPT_PARAM_BW40_8812A, csi_param);
-		odm_write_4byte(p_dm, REG_CSI_RPT_PARAM_BW80_8812A, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, csi_param);
+		odm_write_4byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, csi_param);
 
 		/*Timeout value for MAC to leave NDP_RX_standby_state (60 us, Test chip) (80 us,  MP chip)*/
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8812A + 3, 0x50);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A + 3, 0x50);
 	}
 
+	if (beamforming_info->beamformee_su_cnt > 0 && bfee_idx < BEAMFORMEE_ENTRY_NUM) {
+		beamformee_entry = beamforming_info->beamformee_entry[bfee_idx];
 
-	if ((p_beamforming_info->beamformee_su_cnt > 0) && (bfee_idx < BEAMFORMEE_ENTRY_NUM)) {
-		beamformee_entry = p_beamforming_info->beamformee_entry[bfee_idx];
-
-		if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
+		if (phydm_acting_determine(dm, phydm_acting_as_ibss))
 			sta_id = beamformee_entry.mac_id;
 		else
 			sta_id = beamformee_entry.p_aid;
 
 		/*P_AID of Beamformee & enable NDPA transmission & enable NDPA interrupt*/
 		if (bfee_idx == 0) {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8812A, sta_id);
-			odm_write_1byte(p_dm, REG_TXBF_CTRL_8812A + 3, odm_read_1byte(p_dm, REG_TXBF_CTRL_8812A + 3) | BIT(4) | BIT(6) | BIT(7));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A, sta_id);
+			odm_write_1byte(dm, REG_TXBF_CTRL_8812A + 3, odm_read_1byte(dm, REG_TXBF_CTRL_8812A + 3) | BIT(4) | BIT(6) | BIT(7));
 		} else
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8812A + 2, sta_id | BIT(12) | BIT(14) | BIT(15));
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A + 2, sta_id | BIT(12) | BIT(14) | BIT(15));
 
-		/*CSI report parameters of Beamformee*/
+		/*@CSI report parameters of Beamformee*/
 		if (bfee_idx == 0) {
-			/*Get BIT24 & BIT25*/
-			u8	tmp = odm_read_1byte(p_dm, REG_BFMEE_SEL_8812A + 3) & 0x3;
+			/*@Get BIT24 & BIT25*/
+			u8 tmp = odm_read_1byte(dm, REG_BFMEE_SEL_8812A + 3) & 0x3;
 
-			odm_write_1byte(p_dm, REG_BFMEE_SEL_8812A + 3, tmp | 0x60);
-			odm_write_2byte(p_dm, REG_BFMEE_SEL_8812A, sta_id | BIT(9));
+			odm_write_1byte(dm, REG_BFMEE_SEL_8812A + 3, tmp | 0x60);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A, sta_id | BIT(9));
 		} else {
 			/*Set BIT25*/
-			odm_write_2byte(p_dm, REG_BFMEE_SEL_8812A + 2, sta_id | 0xE200);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A + 2, sta_id | 0xE200);
 		}
-		phydm_beamforming_notify(p_dm);
+		phydm_beamforming_notify(dm);
 	}
 }
 
-
-void
-hal_txbf_jaguar_leave(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_jaguar_leave(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beamforming_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMER_ENTRY	beamformer_entry;
-	struct _RT_BEAMFORMEE_ENTRY	beamformee_entry;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beamforming_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMER_ENTRY beamformer_entry;
+	struct _RT_BEAMFORMEE_ENTRY beamformee_entry;
 
 	if (idx < BEAMFORMER_ENTRY_NUM) {
-		beamformer_entry = p_beamforming_info->beamformer_entry[idx];
-		beamformee_entry = p_beamforming_info->beamformee_entry[idx];
+		beamformer_entry = beamforming_info->beamformer_entry[idx];
+		beamformee_entry = beamforming_info->beamformee_entry[idx];
 	} else
 		return;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s]Start!, IDx = %d\n", __func__, idx));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s]Start!, IDx = %d\n", __func__, idx);
 
-	/*Clear P_AID of Beamformee*/
-	/*Clear MAC address of Beamformer*/
-	/*Clear Associated Bfmee Sel*/
+	/*@Clear P_AID of Beamformee*/
+	/*@Clear MAC address of Beamformer*/
+	/*@Clear Associated Bfmee Sel*/
 
 	if (beamformer_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
 		if (idx == 0) {
-			odm_write_4byte(p_dm, REG_BFMER0_INFO_8812A, 0);
-			odm_write_2byte(p_dm, REG_BFMER0_INFO_8812A + 4, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
+			odm_write_4byte(dm, REG_BFMER0_INFO_8812A, 0);
+			odm_write_2byte(dm, REG_BFMER0_INFO_8812A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
 		} else {
-			odm_write_4byte(p_dm, REG_BFMER1_INFO_8812A, 0);
-			odm_write_2byte(p_dm, REG_BFMER1_INFO_8812A + 4, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
-			odm_write_2byte(p_dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
+			odm_write_4byte(dm, REG_BFMER1_INFO_8812A, 0);
+			odm_write_2byte(dm, REG_BFMER1_INFO_8812A + 4, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW20_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW40_8812A, 0);
+			odm_write_2byte(dm, REG_CSI_RPT_PARAM_BW80_8812A, 0);
 		}
 	}
 
 	if (beamformee_entry.beamform_entry_cap == BEAMFORMING_CAP_NONE) {
-		hal_txbf_jaguar_rf_mode(p_dm, p_beamforming_info);
+		hal_txbf_jaguar_rf_mode(dm, beamforming_info);
 		if (idx == 0) {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8812A, 0x0);
-			odm_write_2byte(p_dm, REG_BFMEE_SEL_8812A, 0);
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A, 0x0);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A, 0);
 		} else {
-			odm_write_2byte(p_dm, REG_TXBF_CTRL_8812A + 2, odm_read_2byte(p_dm, REG_TXBF_CTRL_8812A + 2) & 0xF000);
-			odm_write_2byte(p_dm, REG_BFMEE_SEL_8812A + 2, odm_read_2byte(p_dm, REG_BFMEE_SEL_8812A + 2) & 0x60);
+			odm_write_2byte(dm, REG_TXBF_CTRL_8812A + 2, odm_read_2byte(dm, REG_TXBF_CTRL_8812A + 2) & 0xF000);
+			odm_write_2byte(dm, REG_BFMEE_SEL_8812A + 2, odm_read_2byte(dm, REG_BFMEE_SEL_8812A + 2) & 0x60);
 		}
 	}
-
 }
 
-
-void
-hal_txbf_jaguar_status(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_jaguar_status(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u16					beam_ctrl_val;
-	u32					beam_ctrl_reg;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	beamform_entry = p_beam_info->beamformee_entry[idx];
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 beam_ctrl_val;
+	u32 beam_ctrl_reg;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY beamform_entry = beam_info->beamformee_entry[idx];
 
-	if (phydm_acting_determine(p_dm, phydm_acting_as_ibss))
+	if (phydm_acting_determine(dm, phydm_acting_as_ibss))
 		beam_ctrl_val = beamform_entry.mac_id;
 	else
 		beam_ctrl_val = beamform_entry.p_aid;
@@ -388,7 +369,7 @@ hal_txbf_jaguar_status(
 		beam_ctrl_val |= BIT(12) | BIT(14) | BIT(15);
 	}
 
-	if ((beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED) && (p_beam_info->apply_v_matrix == true)) {
+	if (beamform_entry.beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSED && beam_info->apply_v_matrix == true) {
 		if (beamform_entry.sound_bw == CHANNEL_WIDTH_20)
 			beam_ctrl_val |= BIT(9);
 		else if (beamform_entry.sound_bw == CHANNEL_WIDTH_40)
@@ -398,77 +379,70 @@ hal_txbf_jaguar_status(
 	} else
 		beam_ctrl_val &= ~(BIT(9) | BIT(10) | BIT(11));
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] beam_ctrl_val = 0x%x!\n", __func__, beam_ctrl_val));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] beam_ctrl_val = 0x%x!\n", __func__,
+		  beam_ctrl_val);
 
-	odm_write_2byte(p_dm, beam_ctrl_reg, beam_ctrl_val);
+	odm_write_2byte(dm, beam_ctrl_reg, beam_ctrl_val);
 }
 
-
-
-void
-hal_txbf_jaguar_fw_txbf(
-	void			*p_dm_void,
-	u8				idx
-)
+void hal_txbf_jaguar_fw_txbf(
+	void *dm_void,
+	u8 idx)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
-	struct _RT_BEAMFORMEE_ENTRY	*p_beam_entry = p_beam_info->beamformee_entry + idx;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
+	struct _RT_BEAMFORMEE_ENTRY *p_beam_entry = beam_info->beamformee_entry + idx;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
 	if (p_beam_entry->beamform_entry_state == BEAMFORMING_ENTRY_STATE_PROGRESSING)
-		hal_txbf_jaguar_download_ndpa(p_dm, idx);
+		hal_txbf_jaguar_download_ndpa(dm, idx);
 
-	hal_txbf_jaguar_fw_txbf_cmd(p_dm);
+	hal_txbf_jaguar_fw_txbf_cmd(dm);
 }
 
-
-void
-hal_txbf_jaguar_patch(
-	void			*p_dm_void,
-	u8				operation
-)
+void hal_txbf_jaguar_patch(
+	void *dm_void,
+	u8 operation)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	struct _RT_BEAMFORMING_INFO	*p_beam_info = &p_dm->beamforming_info;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	struct _RT_BEAMFORMING_INFO *beam_info = &dm->beamforming_info;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	if (p_beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
+	if (beam_info->beamform_cap == BEAMFORMING_CAP_NONE)
 		return;
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
 	if (operation == SCAN_OPT_BACKUP_BAND0)
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xC8);
 	else if (operation == SCAN_OPT_RESTORE)
-		odm_write_1byte(p_dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
+		odm_write_1byte(dm, REG_SND_PTCL_CTRL_8812A, 0xCB);
 #endif
 }
 
-void
-hal_txbf_jaguar_clk_8812a(
-	void			*p_dm_void
-)
+void hal_txbf_jaguar_clk_8812a(
+	void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u16	u2btmp;
-	u8	count = 0, u1btmp;
-	struct _ADAPTER	*adapter = p_dm->adapter;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u16 u2btmp;
+	u8 count = 0, u1btmp;
+	void *adapter = dm->adapter;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] Start!\n", __func__));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] Start!\n", __func__);
 
-	if (*(p_dm->p_is_scan_in_process)) {
-		PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] return by Scan\n", __func__));
+	if (*dm->is_scan_in_process) {
+		PHYDM_DBG(dm, DBG_TXBF, "[%s] return by Scan\n", __func__);
 		return;
 	}
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
 	/*Stop PCIe TxDMA*/
-	odm_write_1byte(p_dm, REG_PCIE_CTRL_REG_8812A + 1, 0xFE);
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		odm_write_1byte(dm, REG_PCIE_CTRL_REG_8812A + 1, 0xFE);
 #endif
 
-	/*Stop Usb TxDMA*/
+/*Stop Usb TxDMA*/
 #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
-	RT_DISABLE_FUNC(adapter, DF_TX_BIT);
+	RT_DISABLE_FUNC((PADAPTER)adapter, DF_TX_BIT);
 	PlatformReturnAllPendingTxPackets(adapter);
 #else
 	rtw_write_port_cancel(adapter);
@@ -476,7 +450,7 @@ hal_txbf_jaguar_clk_8812a(
 
 	/*Wait TXFF empty*/
 	for (count = 0; count < 100; count++) {
-		u2btmp = odm_read_2byte(p_dm, REG_TXPKT_EMPTY_8812A);
+		u2btmp = odm_read_2byte(dm, REG_TXPKT_EMPTY_8812A);
 		u2btmp = u2btmp & 0xfff;
 		if (u2btmp != 0xfff) {
 			ODM_delay_ms(10);
@@ -486,55 +460,52 @@ hal_txbf_jaguar_clk_8812a(
 	}
 
 	/*TX pause*/
-	odm_write_1byte(p_dm, REG_TXPAUSE_8812A, 0xFF);
+	odm_write_1byte(dm, REG_TXPAUSE_8812A, 0xFF);
 
 	/*Wait TX state Machine OK*/
 	for (count = 0; count < 100; count++) {
-		if (odm_read_4byte(p_dm, REG_SCH_TXCMD_8812A) != 0)
+		if (odm_read_4byte(dm, REG_SCH_TXCMD_8812A) != 0)
 			continue;
 		else
 			break;
 	}
 
-
 	/*Stop RX DMA path*/
-	u1btmp = odm_read_1byte(p_dm, REG_RXDMA_CONTROL_8812A);
-	odm_write_1byte(p_dm, REG_RXDMA_CONTROL_8812A, u1btmp | BIT(2));
+	u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+	odm_write_1byte(dm, REG_RXDMA_CONTROL_8812A, u1btmp | BIT(2));
 
 	for (count = 0; count < 100; count++) {
-		u1btmp = odm_read_1byte(p_dm, REG_RXDMA_CONTROL_8812A);
+		u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
 		if (u1btmp & BIT(1))
 			break;
 		else
 			ODM_delay_ms(10);
 	}
 
-	/*Disable clock*/
-	odm_write_1byte(p_dm, REG_SYS_CLKR_8812A + 1, 0xf0);
-	/*Disable 320M*/
-	odm_write_1byte(p_dm, REG_AFE_PLL_CTRL_8812A + 3, 0x8);
-	/*Enable 320M*/
-	odm_write_1byte(p_dm, REG_AFE_PLL_CTRL_8812A + 3, 0xa);
-	/*Enable clock*/
-	odm_write_1byte(p_dm, REG_SYS_CLKR_8812A + 1, 0xfc);
-
+	/*@Disable clock*/
+	odm_write_1byte(dm, REG_SYS_CLKR_8812A + 1, 0xf0);
+	/*@Disable 320M*/
+	odm_write_1byte(dm, REG_AFE_PLL_CTRL_8812A + 3, 0x8);
+	/*@Enable 320M*/
+	odm_write_1byte(dm, REG_AFE_PLL_CTRL_8812A + 3, 0xa);
+	/*@Enable clock*/
+	odm_write_1byte(dm, REG_SYS_CLKR_8812A + 1, 0xfc);
 
 	/*Release Tx pause*/
-	odm_write_1byte(p_dm, REG_TXPAUSE_8812A, 0);
+	odm_write_1byte(dm, REG_TXPAUSE_8812A, 0);
 
-	/*Enable RX DMA path*/
-	u1btmp = odm_read_1byte(p_dm, REG_RXDMA_CONTROL_8812A);
-	odm_write_1byte(p_dm, REG_RXDMA_CONTROL_8812A, u1btmp & (~BIT(2)));
+	/*@Enable RX DMA path*/
+	u1btmp = odm_read_1byte(dm, REG_RXDMA_CONTROL_8812A);
+	odm_write_1byte(dm, REG_RXDMA_CONTROL_8812A, u1btmp & (~BIT(2)));
 #if DEV_BUS_TYPE == RT_PCI_INTERFACE
-	/*Enable PCIe TxDMA*/
-	odm_write_1byte(p_dm, REG_PCIE_CTRL_REG_8812A + 1, 0);
+	/*@Enable PCIe TxDMA*/
+	if (dm->support_interface == ODM_ITRF_PCIE)
+		odm_write_1byte(dm, REG_PCIE_CTRL_REG_8812A + 1, 0);
 #endif
 	/*Start Usb TxDMA*/
-	RT_ENABLE_FUNC(adapter, DF_TX_BIT);
+	RT_ENABLE_FUNC((PADAPTER)adapter, DF_TX_BIT);
 }
 
 #endif
 
-
-
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.h
index 4b1b32099f85..9e5e09e1f345 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/haltxbfjaguar.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,81 +9,71 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
 #ifndef __HAL_TXBF_JAGUAR_H__
 #define __HAL_TXBF_JAGUAR_H__
 #if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
-#if (BEAMFORMING_SUPPORT == 1)
-
-void
-hal_txbf_8812a_set_ndpa_rate(
-	void			*p_dm_void,
-	u8	BW,
-	u8	rate
-);
-
-
-void
-hal_txbf_jaguar_enter(
-	void			*p_dm_void,
-	u8				idx
-);
-
-
-void
-hal_txbf_jaguar_leave(
-	void			*p_dm_void,
-	u8				idx
-);
-
+#ifdef PHYDM_BEAMFORMING_SUPPORT
 
-void
-hal_txbf_jaguar_status(
-	void			*p_dm_void,
-	u8				idx
-);
+void hal_txbf_8812a_set_ndpa_rate(
+	void *dm_void,
+	u8 BW,
+	u8 rate);
 
+void hal_txbf_jaguar_enter(
+	void *dm_void,
+	u8 idx);
 
-void
-hal_txbf_jaguar_fw_txbf(
-	void			*p_dm_void,
-	u8				idx
-);
+void hal_txbf_jaguar_leave(
+	void *dm_void,
+	u8 idx);
 
+void hal_txbf_jaguar_status(
+	void *dm_void,
+	u8 idx);
 
-void
-hal_txbf_jaguar_patch(
-	void			*p_dm_void,
-	u8				operation
-);
+void hal_txbf_jaguar_fw_txbf(
+	void *dm_void,
+	u8 idx);
 
+void hal_txbf_jaguar_patch(
+	void *dm_void,
+	u8 operation);
 
-void
-hal_txbf_jaguar_clk_8812a(
-	void			*p_dm_void
-);
+void hal_txbf_jaguar_clk_8812a(
+	void *dm_void);
 #else
 
-#define hal_txbf_8812a_set_ndpa_rate(p_dm_void,	BW,	rate)
-#define hal_txbf_jaguar_enter(p_dm_void, idx)
-#define hal_txbf_jaguar_leave(p_dm_void, idx)
-#define hal_txbf_jaguar_status(p_dm_void, idx)
-#define hal_txbf_jaguar_fw_txbf(p_dm_void,	idx)
-#define hal_txbf_jaguar_patch(p_dm_void, operation)
-#define hal_txbf_jaguar_clk_8812a(p_dm_void)
+#define hal_txbf_8812a_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_jaguar_enter(dm_void, idx)
+#define hal_txbf_jaguar_leave(dm_void, idx)
+#define hal_txbf_jaguar_status(dm_void, idx)
+#define hal_txbf_jaguar_fw_txbf(dm_void, idx)
+#define hal_txbf_jaguar_patch(dm_void, operation)
+#define hal_txbf_jaguar_clk_8812a(dm_void)
 #endif
 #else
 
-#define hal_txbf_8812a_set_ndpa_rate(p_dm_void,	BW,	rate)
-#define hal_txbf_jaguar_enter(p_dm_void, idx)
-#define hal_txbf_jaguar_leave(p_dm_void, idx)
-#define hal_txbf_jaguar_status(p_dm_void, idx)
-#define hal_txbf_jaguar_fw_txbf(p_dm_void,	idx)
-#define hal_txbf_jaguar_patch(p_dm_void, operation)
-#define hal_txbf_jaguar_clk_8812a(p_dm_void)
+#define hal_txbf_8812a_set_ndpa_rate(dm_void, BW, rate)
+#define hal_txbf_jaguar_enter(dm_void, idx)
+#define hal_txbf_jaguar_leave(dm_void, idx)
+#define hal_txbf_jaguar_status(dm_void, idx)
+#define hal_txbf_jaguar_fw_txbf(dm_void, idx)
+#define hal_txbf_jaguar_patch(dm_void, operation)
+#define hal_txbf_jaguar_clk_8812a(dm_void)
 #endif
 
-#endif	/*  #ifndef __HAL_TXBF_JAGUAR_H__ */
+#endif /*  @#ifndef __HAL_TXBF_JAGUAR_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.c
index 2fb3f0a6c95b..461e6b13b0e8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -17,75 +18,67 @@
 #include "phydm_precomp.h"
 
 #if (defined(CONFIG_BB_TXBF_API))
-#if (RTL8822B_SUPPORT == 1)
-/*Add by YuChen for 8822B MU-MIMO API*/
+#if (RTL8822B_SUPPORT == 1 || RTL8192F_SUPPORT == 1 ||\
+	RTL8822C_SUPPORT == 1 || RTL8198F_SUPPORT == 1 || RTL8814B_SUPPORT == 1)
+/*@Add by YuChen for 8822B MU-MIMO API*/
 
 /*this function is only used for BFer*/
-u8
-phydm_get_ndpa_rate(
-	void		*p_dm_void
-)
+u8 phydm_get_ndpa_rate(void *dm_void)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
-	u8		ndpa_rate = ODM_RATE6M;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 ndpa_rate = ODM_RATE6M;
 
-	if (p_dm->rssi_min >= 30)	/*link RSSI > 30%*/
+	if (dm->rssi_min >= 30) /*@link RSSI > 30%*/
 		ndpa_rate = ODM_RATE24M;
-	else if (p_dm->rssi_min <= 25)
+	else if (dm->rssi_min <= 25)
 		ndpa_rate = ODM_RATE6M;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] ndpa_rate = 0x%x\n", __func__, ndpa_rate));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] ndpa_rate = 0x%x\n", __func__, ndpa_rate);
 
 	return ndpa_rate;
-
 }
 
 /*this function is only used for BFer*/
-u8
-phydm_get_beamforming_sounding_info(
-	void		*p_dm_void,
-	u16	*troughput,
-	u8	total_bfee_num,
-	u8	*tx_rate
-)
+u8 phydm_get_beamforming_sounding_info(void *dm_void, u16 *throughput,
+				       u8 total_bfee_num, u8 *tx_rate)
 {
-	u8	idx = 0;
-	u8	soundingdecision = 0xff;
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u8 idx = 0;
+	u8 snddecision = 0xff;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	for (idx = 0; idx < total_bfee_num; idx++) {
-		if (p_dm->support_ic_type & (ODM_RTL8814A)) {
-			if (((tx_rate[idx] >= ODM_RATEVHTSS3MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS3MCS9)))
-				soundingdecision = soundingdecision & ~(1 << idx);
-		} else if (p_dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8822C | ODM_RTL8812)) {
-			if (((tx_rate[idx] >= ODM_RATEVHTSS2MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS2MCS9)))
-				soundingdecision = soundingdecision & ~(1 << idx);
-		} else if (p_dm->support_ic_type & (ODM_RTL8814B)) {
-			if (((tx_rate[idx] >= ODM_RATEVHTSS4MCS7) && (tx_rate[idx] <= ODM_RATEVHTSS4MCS9)))
-				soundingdecision = soundingdecision & ~(1 << idx);
+		if (dm->support_ic_type & (ODM_RTL8814A)) {
+			if ((tx_rate[idx] >= ODM_RATEVHTSS3MCS7 &&
+			     tx_rate[idx] <= ODM_RATEVHTSS3MCS9))
+				snddecision = snddecision & ~(1 << idx);
+		} else if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8822C |
+			   ODM_RTL8812 | ODM_RTL8192F)) {
+			if ((tx_rate[idx] >= ODM_RATEVHTSS2MCS7 &&
+			     tx_rate[idx] <= ODM_RATEVHTSS2MCS9))
+				snddecision = snddecision & ~(1 << idx);
+		} else if (dm->support_ic_type & (ODM_RTL8814B)) {
+			if ((tx_rate[idx] >= ODM_RATEVHTSS4MCS7 &&
+			     tx_rate[idx] <= ODM_RATEVHTSS4MCS9))
+				snddecision = snddecision & ~(1 << idx);
 		}
 	}
 
 	for (idx = 0; idx < total_bfee_num; idx++) {
-		if (troughput[idx] <= 10)
-			soundingdecision = soundingdecision & ~(1 << idx);
+		if (throughput[idx] <= 10)
+			snddecision = snddecision & ~(1 << idx);
 	}
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] soundingdecision = 0x%x\n", __func__, soundingdecision));
-
-	return soundingdecision;
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] soundingdecision = 0x%x\n", __func__,
+		  snddecision);
 
+	return snddecision;
 }
 
 /*this function is only used for BFer*/
-u8
-phydm_get_mu_bfee_snding_decision(
-	void		*p_dm_void,
-	u16	throughput
-)
+u8 phydm_get_mu_bfee_snding_decision(void *dm_void, u16 throughput)
 {
-	u8	snding_score = 0;
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	u8 snding_score = 0;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
 	/*throughput unit is Mbps*/
 	if (throughput >= 500)
@@ -111,31 +104,26 @@ phydm_get_mu_bfee_snding_decision(
 	else
 		snding_score = 0;
 
-	PHYDM_DBG(p_dm, DBG_TXBF, ("[%s] snding_score = 0x%x\n", __func__, snding_score));
+	PHYDM_DBG(dm, DBG_TXBF, "[%s] snding_score = 0x%x\n", __func__,
+		  snding_score);
 
 	return snding_score;
-
 }
 
-
 #endif
 #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
-u8
-beamforming_get_htndp_tx_rate(
-	void	*p_dm_void,
-	u8	comp_steering_num_of_bfer
-)
+u8 beamforming_get_htndp_tx_rate(void *dm_void, u8 bfer_str_num)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u8 nr_index = 0;
 	u8 ndp_tx_rate;
-	/*Find nr*/
+/*@Find nr*/
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(p_dm), comp_steering_num_of_bfer);
+	if (dm->support_ic_type & ODM_RTL8814A)
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), bfer_str_num);
 	else
 #endif
-		nr_index = tx_bf_nr(1, comp_steering_num_of_bfer);
+		nr_index = tx_bf_nr(1, bfer_str_num);
 
 	switch (nr_index) {
 	case 1:
@@ -156,25 +144,20 @@ beamforming_get_htndp_tx_rate(
 	}
 
 	return ndp_tx_rate;
-
 }
 
-u8
-beamforming_get_vht_ndp_tx_rate(
-	void	*p_dm_void,
-	u8	comp_steering_num_of_bfer
-)
+u8 beamforming_get_vht_ndp_tx_rate(void *dm_void, u8 bfer_str_num)
 {
-	struct PHY_DM_STRUCT	*p_dm = (struct PHY_DM_STRUCT *)p_dm_void;
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 	u8 nr_index = 0;
 	u8 ndp_tx_rate;
-	/*Find nr*/
+/*@Find nr*/
 #if (RTL8814A_SUPPORT == 1)
-	if (p_dm->support_ic_type & ODM_RTL8814A)
-		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(p_dm), comp_steering_num_of_bfer);
+	if (dm->support_ic_type & ODM_RTL8814A)
+		nr_index = tx_bf_nr(hal_txbf_8814a_get_ntx(dm), bfer_str_num);
 	else
 #endif
-		nr_index = tx_bf_nr(1, comp_steering_num_of_bfer);
+		nr_index = tx_bf_nr(1, bfer_str_num);
 
 	switch (nr_index) {
 	case 1:
@@ -195,8 +178,249 @@ beamforming_get_vht_ndp_tx_rate(
 	}
 
 	return ndp_tx_rate;
-
 }
 #endif
+#ifdef PHYDM_IC_JGR3_SERIES_SUPPORT
+/*this function is only used for BFer*/
+void phydm_txbf_rfmode(void *dm_void, u8 su_bfee_cnt, u8 mu_bfee_cnt)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+#if (RTL8822C_SUPPORT == 1)
+	if (dm->support_ic_type == ODM_RTL8822C) {
+		if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+			for (i = RF_PATH_A; i <= RF_PATH_B; i++) {
+				/*RF mode table write enable*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef,
+					       BIT(19), 0x1);
+				/*Select RX mode*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33,
+					       0xF, 3);
+				/*Set Table data*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3e,
+					       0x3, 0x2);
+				/*Set Table data*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f,
+					       0xfffff, 0x61AFF);
+				/*RF mode table write disable*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef,
+					       BIT(19), 0x0);
+			}
+		}
+		/*@if Nsts > Nc, don't apply V matrix*/
+		odm_set_bb_reg(dm, R_0x1e24, BIT(11), 1);
+
+		if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+			/*@enable BB TxBF ant mapping register*/
+			odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x2);
+			odm_set_bb_reg(dm, R_0x1e24, BIT(30), 1);
+
+			/* logic mapping */
+			/* TX BF logic map and TX path en for Nsts = 1~2 */
+			odm_set_bb_reg(dm, R_0x820, 0xffff0000, 0x33);
+			odm_set_bb_reg(dm, R_0x1e30, 0xffff, 0x404);
+		} else {
+			/*@Disable BB TxBF ant mapping register*/
+			odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x0);
+			odm_set_bb_reg(dm, R_0x1e24, BIT(31), 0);
+			/*@1SS~2ss A, AB*/
+			odm_set_bb_reg(dm, R_0x820, 0xff, 0x31);
+			odm_set_bb_reg(dm, R_0x1e2c, 0xffff, 0x400);
+		}
+	}
+#endif
+#if (RTL8814B_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8814B) {
+		if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+			for (i = RF_PATH_A; i <= RF_PATH_D; i++) {
+				/*RF mode table write enable*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef,
+					       BIT(19), 0x1);
+				/*Select RX mode*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33,
+					       0xF, 2);
+				/*Set Table data*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3e,
+					       0xfffff, 0x3fc);
+				/*Set Table data*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f,
+					       0xfffff, 0x280f7);
+				/*Select RX mode*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33,
+					       0xF, 3);
+				/*Set Table data*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3e,
+					       0xfffff, 0x365);
+				/*Set Table data*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f,
+					       0xfffff, 0xafcf7);
+				/*RF mode table write disable*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef,
+					       BIT(19), 0x0);
+			}
+		}
+		/*@if Nsts > Nc, don't apply V matrix*/
+		odm_set_bb_reg(dm, R_0x1e24, BIT(11), 1);
+
+		if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+			/*@enable BB TxBF ant mapping register*/
+			odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x2);
+			odm_set_bb_reg(dm, R_0x1e24, BIT(30), 1);
+
+			/* logic mapping */
+			/* TX BF logic map and TX path en for Nsts = 1~4 */
+			odm_set_bb_reg(dm, R_0x820, 0xffff0000, 0xff55);
+			/*verification path-AC*/
+			odm_set_bb_reg(dm, R_0x1e30, 0xffffffff, 0xe4e41010);
+		} else {
+			/*@Disable BB TxBF ant mapping register*/
+			odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x0);
+			odm_set_bb_reg(dm, R_0x1e24, BIT(31), 0);
+			/*@1SS~4ss A, AB, ABC, ABCD*/
+			odm_set_bb_reg(dm, R_0x820, 0xffff, 0xf731);
+			odm_set_bb_reg(dm, R_0x1e2c, 0xffffffff, 0xe4240400);
+		}
+	}
+#endif
+#if (RTL8198F_SUPPORT)
+	if (dm->support_ic_type == ODM_RTL8198F) {
+		if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+			for (i = RF_PATH_A; i <= RF_PATH_D; i++) {
+				/*RF mode table write enable*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef,
+					       BIT(19), 0x1);
+				/*Select RX mode*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x30,
+					       0xfffff, 0x18000);
+				/*Set Table data*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x31,
+					       0xfffff, 0x4f);
+				/*Select RX mode*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0x32,
+					       0xfffff, 0x71fc0);
+				/*RF mode table write disable*/
+				odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef,
+					       BIT(19), 0x0);
+			}
+		}
+		/*@if Nsts > Nc, don't apply V matrix*/
+		odm_set_bb_reg(dm, R_0x1e24, BIT(11), 1);
+
+		if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+			/*@enable BB TxBF ant mapping register*/
+			odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x2);
+			odm_set_bb_reg(dm, R_0x1e24, BIT(30), 1);
+
+			/* logic mapping */
+			/* TX BF logic map and TX path en for Nsts = 1~4 */
+			odm_set_bb_reg(dm, R_0x820, 0xffff0000, 0xffff);
+			odm_set_bb_reg(dm, R_0x1e30, 0xffffffff, 0xe4e4e4e4);
+		} else {
+			/*@Disable BB TxBF ant mapping register*/
+			odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x0);
+			odm_set_bb_reg(dm, R_0x1e24, BIT(31), 0);
+			/*@1SS~4ss A, AB, ABC, ABCD*/
+			odm_set_bb_reg(dm, R_0x820, 0xffff, 0xf731);
+			odm_set_bb_reg(dm, R_0x1e2c, 0xffffffff, 0xe4240400);
+		}
+	}
+#endif
+}
+
+void phydm_txbf_avoid_hang(void *dm_void)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
 
+	/* avoid CCK CCA hang when the BF mode */
+	odm_set_bb_reg(dm, R_0x1e6c, 0x100000, 0x1);
+}
+
+#if (RTL8814B_SUPPORT == 1)
+void phydm_txbf_80p80_rfmode(void *dm_void, u8 su_bfee_cnt, u8 mu_bfee_cnt)
+{
+	struct dm_struct *dm = (struct dm_struct *)dm_void;
+	u8 i;
+
+	if (dm->rf_type == RF_1T1R)
+		return;
+
+	if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+		for (i = RF_PATH_A; i <= RF_PATH_D; i += 3) {
+			/*RF mode table write enable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef, BIT(19),
+				       0x1);
+			/*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33, 0xF, 2);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3e, 0xfffff,
+				       0x3fc);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f, 0xfffff,
+				       0x280f7);
+			/*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33, 0xF, 3);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3e, 0xfffff,
+				       0x365);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f, 0xfffff,
+				       0xafcf7);
+			/*RF mode table write disable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef, BIT(19),
+				       0x0);
+		}
+		for (i = RF_PATH_B; i <= RF_PATH_C; i++) {
+			/*RF mode table write enable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef, BIT(19),
+				       0x1);
+			/*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33, 0xF, 2);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f, 0xfffff,
+				       0x280c7);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f, 0xfffff,
+				       0x280c7);
+			/*Select RX mode*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x33, 0xF, 3);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3e, 0xfffff,
+				       0x365);
+			/*Set Table data*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0x3f, 0xfffff,
+				       0xafcc7);
+			/*RF mode table write disable*/
+			odm_set_rf_reg(dm, (enum rf_path)i, RF_0xef, BIT(19),
+				       0x0);
+		}
+	}
+	/*@if Nsts > Nc, don't apply V matrix*/
+	odm_set_bb_reg(dm, R_0x1e24, BIT(11), 1);
+
+	if (su_bfee_cnt > 0 || mu_bfee_cnt > 0) {
+		/*@enable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x2);
+		odm_set_bb_reg(dm, R_0x1e24, BIT(30), 1);
+
+		/* logic mapping */
+		/* TX BF logic map and TX path en for Nsts = 1~2 */
+		odm_set_bb_reg(dm, R_0x820, 0xff0000, 0x33); /*seg0*/
+		odm_set_bb_reg(dm, R_0x824, 0xff00, 0xcc); /*seg1*/
+		odm_set_bb_reg(dm, R_0x1e30, 0xffff, 0xe4e4);
+
+	} else {
+		/*@Disable BB TxBF ant mapping register*/
+		odm_set_bb_reg(dm, R_0x1e24, BIT(28) | BIT29, 0x0);
+		odm_set_bb_reg(dm, R_0x1e24, BIT(31), 0);
+		/*@1SS~2ss A, AB*/
+		odm_set_bb_reg(dm, R_0x820, 0xff, 0x31); /*seg0*/
+		odm_set_bb_reg(dm, R_0x824, 0xff, 0xc8); /*seg1*/
+		odm_set_bb_reg(dm, R_0x1e2c, 0xffff, 0xe420);
+	}
+}
 #endif
+#endif /*PHYSTS_3RD_TYPE_IC*/
+#endif /*CONFIG_BB_TXBF_API*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.h
index 96809e83d5b5..15b11ce8b549 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/phydm/txbf/phydm_hal_txbf_api.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2011 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017  Realtek Corporation.
  *
  * 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
@@ -8,58 +9,67 @@
  *
  * 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
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  * more details.
  *
+ * The full GNU General Public License is included in this distribution in the
+ * file called LICENSE.
+ *
+ * Contact Information:
+ * wlanfae <wlanfae@realtek.com>
+ * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
+ * Hsinchu 300, Taiwan.
+ *
+ * Larry Finger <Larry.Finger@lwfinger.net>
+ *
  *****************************************************************************/
-#ifndef	__PHYDM_HAL_TXBF_API_H__
+#ifndef __PHYDM_HAL_TXBF_API_H__
 #define __PHYDM_HAL_TXBF_API_H__
 
 #if (defined(CONFIG_BB_TXBF_API))
 
 #if (DM_ODM_SUPPORT_TYPE != ODM_AP)
+#if defined(DM_ODM_CE_MAC80211)
+#define tx_bf_nr(a, b) ({	\
+	u8 __tx_bf_nr_a = (a);	\
+	u8 __tx_bf_nr_b = (b);	\
+	((__tx_bf_nr_a > __tx_bf_nr_b) ? (__tx_bf_nr_b) : (__tx_bf_nr_a)); })
+#else
 #define tx_bf_nr(a, b) ((a > b) ? (b) : (a))
+#endif
 
-u8
-beamforming_get_htndp_tx_rate(
-	void	*p_dm_void,
-	u8	comp_steering_num_of_bfer
-);
+u8 beamforming_get_htndp_tx_rate(void *dm_void, u8 bfer_str_num);
 
-u8
-beamforming_get_vht_ndp_tx_rate(
-	void	*p_dm_void,
-	u8	comp_steering_num_of_bfer
-);
+u8 beamforming_get_vht_ndp_tx_rate(void *dm_void, u8 bfer_str_num);
 
 #endif
 
-#if (RTL8822B_SUPPORT == 1)
-u8
-phydm_get_beamforming_sounding_info(
-	void		*p_dm_void,
-	u16	*troughput,
-	u8	total_bfee_num,
-	u8	*tx_rate
-);
+#if (RTL8822B_SUPPORT == 1 || RTL8822C_SUPPORT == 1 || RTL8192F_SUPPORT == 1 ||\
+	RTL8814B_SUPPORT == 1 || RTL8198F_SUPPORT == 1)
+u8 phydm_get_beamforming_sounding_info(void *dm_void, u16 *throughput,
+				       u8 total_bfee_num, u8 *tx_rate);
 
-u8
-phydm_get_ndpa_rate(
-	void		*p_dm_void
-);
+u8 phydm_get_ndpa_rate(void *dm_void);
 
-u8
-phydm_get_mu_bfee_snding_decision(
-	void		*p_dm_void,
-	u16	throughput
-);
+u8 phydm_get_mu_bfee_snding_decision(void *dm_void, u16 throughput);
 
 #else
-#define phydm_get_beamforming_sounding_info(p_dm_void, troughput, total_bfee_num, tx_rate)
-#define phydm_get_ndpa_rate(p_dm_void)
-#define phydm_get_mu_bfee_snding_decision(p_dm_void, troughput)
+#define phydm_get_beamforming_sounding_info(dm, tp, bfee_num, rate) 0
+#define phydm_get_ndpa_rate(dm)
+#define phydm_get_mu_bfee_snding_decision(dm, tp)
 
 #endif
+#ifdef PHYSTS_3RD_TYPE_IC
+/*this function is only used for BFer*/
+void phydm_txbf_rfmode(void *dm_void, u8 su_bfee_cnt, u8 mu_bfee_cnt);
+
+void phydm_txbf_avoid_hang(void *dm_void);
+
+#if (RTL8814B_SUPPORT == 1)
+void phydm_txbf_80p80_rfmode(void *dm_void, u8 su_bfee_cnt, u8 mu_bfee_cnt);
+#endif
+
+#endif /*PHYSTS_3RD_TYPE_IC*/
 
 #endif
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/Hal8723DPwrSeq.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/Hal8723DPwrSeq.c
index 8e99a0b5cb49..1f8e41f9806d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/Hal8723DPwrSeq.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/Hal8723DPwrSeq.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) Semiconductor - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.c
index 54d5b4d21a1e..1f3027e658d8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
 *
 * Copyright(c) 2012 - 2017 Realtek Corporation.
@@ -22,21 +23,21 @@
 #if (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))
 
 u8 array_mp_8723d_fw_ap[] = {
-0xD1, 0x23, 0x20, 0x00, 0x27, 0x00, 0x00, 0x00,
-0x09, 0x15, 0x17, 0x38, 0xAE, 0x5D, 0x02, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xD1, 0x23, 0x20, 0x00, 0x2F, 0x00, 0x00, 0x00,
+0x12, 0x10, 0x17, 0x09, 0xBC, 0x60, 0x02, 0x00,
+0xBE, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x02, 0x85, 0xA9, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xB8, 0xA5, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xB8, 0xE8, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC5, 0x63, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xC9, 0x8F, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xBE, 0xAA, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xBB, 0x8E, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC5, 0x0D, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xC8, 0xE1, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xBD, 0xB9, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xC9, 0x39, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
@@ -238,500 +239,254 @@ u8 array_mp_8723d_fw_ap[] = {
 0x74, 0x01, 0x93, 0x70, 0x0D, 0xA3, 0xA3, 0x93,
 0xF8, 0x74, 0x01, 0x93, 0xF5, 0x82, 0x88, 0x83,
 0xE4, 0x73, 0x74, 0x02, 0x93, 0x68, 0x60, 0xEF,
-0xA3, 0xA3, 0xA3, 0x80, 0xDF, 0x41, 0x96, 0xCA,
-0x00, 0x41, 0x96, 0xCF, 0x00, 0x44, 0x96, 0x95,
-0x41, 0x4E, 0x59, 0x00, 0x44, 0x96, 0x91, 0x61,
-0x6E, 0x79, 0x00, 0x41, 0x96, 0xD2, 0x00, 0x00,
-0xBF, 0x01, 0xC1, 0x7F, 0x8A, 0x4D, 0x90, 0x96,
-0xC9, 0xEF, 0xF0, 0x7F, 0x02, 0xB1, 0x27, 0x90,
-0x86, 0xAF, 0xE0, 0xFF, 0x90, 0x96, 0xC9, 0xE0,
+0xA3, 0xA3, 0xA3, 0x80, 0xDF, 0x41, 0x97, 0x06,
+0x00, 0x41, 0x97, 0x0B, 0x00, 0x44, 0x96, 0xC7,
+0x41, 0x4E, 0x59, 0x00, 0x44, 0x96, 0xC3, 0x61,
+0x6E, 0x79, 0x00, 0x41, 0x97, 0x0E, 0x00, 0x00,
+0xA7, 0x60, 0xC4, 0x9F, 0x8F, 0x15, 0x90, 0x97,
+0x05, 0xEF, 0xF0, 0x7F, 0x02, 0xB1, 0x27, 0x90,
+0x86, 0xAF, 0xE0, 0xFF, 0x90, 0x97, 0x05, 0xE0,
 0xFE, 0xEF, 0x4E, 0x90, 0x86, 0xAF, 0xF0, 0x22,
 0x90, 0x02, 0x09, 0xE0, 0xFD, 0x12, 0x02, 0x06,
 0xFE, 0xAF, 0x05, 0xED, 0x2E, 0x90, 0x86, 0xB4,
-0xF0, 0x12, 0x98, 0xAC, 0xFF, 0xED, 0x2F, 0x90,
-0x86, 0xB5, 0xF1, 0xE9, 0xFF, 0xED, 0x2F, 0x90,
-0x86, 0xB6, 0xF1, 0xF3, 0xFF, 0xED, 0x2F, 0x90,
-0x86, 0xB7, 0xF1, 0xFD, 0xFF, 0xED, 0x2F, 0x90,
-0x86, 0xB8, 0xF1, 0x29, 0xFF, 0xED, 0x2F, 0x90,
-0x86, 0xB9, 0x12, 0xA7, 0xD8, 0xFF, 0xAE, 0x05,
-0xED, 0x2F, 0x90, 0x86, 0xBA, 0xF0, 0x22, 0x4E,
-0xFF, 0xF0, 0x90, 0x00, 0x05, 0x02, 0x02, 0x1F,
-0x12, 0x9F, 0xE9, 0x12, 0x8A, 0xC6, 0xFF, 0x54,
-0x7F, 0x90, 0x88, 0x36, 0xF0, 0xEF, 0x12, 0x8F,
-0xF1, 0xA3, 0xF0, 0x12, 0x98, 0xAC, 0xFD, 0x54,
-0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x88, 0x34,
-0xE0, 0x54, 0xF0, 0x4F, 0xF1, 0xF3, 0xFC, 0x54,
-0x01, 0x25, 0xE0, 0xFF, 0x90, 0x88, 0x31, 0xE0,
-0x54, 0xFD, 0x4F, 0xF0, 0xEC, 0x54, 0x04, 0xC3,
-0x13, 0xFF, 0x90, 0x88, 0x33, 0xE0, 0x54, 0xFD,
-0x4F, 0xF0, 0xED, 0x54, 0x0F, 0xC4, 0x54, 0xF0,
-0xFF, 0xA3, 0xE0, 0x54, 0x0F, 0xF1, 0xE8, 0x90,
-0x88, 0x35, 0xF1, 0xFD, 0xFD, 0x90, 0x8A, 0x89,
-0x12, 0x8B, 0x46, 0x7F, 0x02, 0x12, 0x04, 0x7E,
-0x90, 0x94, 0xB6, 0xD1, 0x6D, 0xF1, 0x2A, 0xFF,
-0x54, 0x01, 0xFE, 0x90, 0x88, 0x9B, 0x12, 0xDC,
-0xB2, 0xF1, 0x28, 0xFE, 0x12, 0xDD, 0x47, 0x90,
-0x88, 0x9B, 0x12, 0xDD, 0x74, 0xF1, 0x27, 0x12,
-0xDD, 0x3D, 0x90, 0x88, 0x9B, 0x12, 0xDD, 0x6B,
-0xF1, 0x27, 0x54, 0x40, 0xFE, 0xEF, 0x54, 0xBF,
-0x4E, 0x90, 0x88, 0x9B, 0xF0, 0x12, 0x5C, 0x5F,
-0x90, 0x88, 0x36, 0xE0, 0xB4, 0x01, 0x07, 0x90,
-0x88, 0x33, 0xE0, 0x54, 0xFB, 0xF0, 0x12, 0xBD,
-0xBC, 0xF0, 0x90, 0x88, 0x36, 0x12, 0xDC, 0xEB,
-0x12, 0xA7, 0xE7, 0x90, 0x01, 0xBE, 0xF0, 0x22,
-0x4F, 0xF0, 0x90, 0x00, 0x02, 0x02, 0x02, 0x1F,
-0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00, 0x03, 0x02,
-0x02, 0x1F, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00,
-0x04, 0x02, 0x02, 0x1F, 0x12, 0x9F, 0xE9, 0x90,
-0x93, 0x4C, 0xE0, 0x70, 0x0F, 0x51, 0xC6, 0x13,
-0x13, 0x54, 0x3F, 0x30, 0xE0, 0x06, 0x90, 0x93,
-0x52, 0x74, 0x01, 0xF0, 0x90, 0x93, 0x4E, 0xE0,
-0x70, 0x0F, 0x51, 0xC6, 0xC4, 0x54, 0x0F, 0xFF,
-0xBF, 0x05, 0x06, 0x90, 0x93, 0x53, 0x74, 0x01,
-0xF0, 0x12, 0x98, 0xA6, 0xFF, 0x90, 0x94, 0xBA,
-0xF0, 0x12, 0x02, 0x06, 0xC3, 0x13, 0x30, 0xE0,
-0x0F, 0x90, 0x94, 0xB6, 0x12, 0x86, 0x6D, 0x12,
-0x87, 0xEA, 0x90, 0x94, 0xBB, 0xF0, 0x80, 0x05,
-0x90, 0x94, 0xBB, 0xEF, 0xF0, 0x90, 0x94, 0xBA,
-0xE0, 0x90, 0x94, 0xB9, 0xF0, 0x90, 0x94, 0xBB,
-0xE0, 0xFE, 0x90, 0x94, 0xB9, 0xE0, 0xFF, 0xD3,
-0x9E, 0x50, 0x36, 0x51, 0xC6, 0x54, 0x01, 0xFD,
-0x12, 0x6E, 0x71, 0x90, 0x94, 0xB9, 0xE0, 0xFF,
-0x12, 0x78, 0x4A, 0xEF, 0x90, 0x94, 0xB9, 0x70,
-0x06, 0xE0, 0xFF, 0xF1, 0xF8, 0x80, 0x05, 0xE0,
-0xFF, 0x12, 0xB8, 0x14, 0x90, 0x93, 0x53, 0xE0,
-0x60, 0x07, 0x90, 0x94, 0xB9, 0xE0, 0xFF, 0xF1,
-0xF8, 0x90, 0x94, 0xB9, 0xE0, 0x04, 0xF0, 0x80,
-0xBC, 0x90, 0x05, 0x5E, 0xE4, 0xF0, 0x90, 0x94,
-0xBA, 0xE0, 0x70, 0x17, 0xFF, 0x12, 0x78, 0x4A,
-0xEF, 0x70, 0x10, 0x11, 0xCA, 0x90, 0x8A, 0xED,
-0x11, 0xCD, 0x12, 0xDD, 0xA3, 0x54, 0xBF, 0xF0,
-0x54, 0x7F, 0xF0, 0x22, 0xE4, 0xFD, 0xFF, 0x12,
-0x04, 0x7E, 0x90, 0x86, 0x0C, 0xE0, 0xFE, 0xA3,
-0xE0, 0xAA, 0x06, 0xF9, 0x02, 0x04, 0x7A, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96,
-0xD0, 0xED, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0xFE,
-0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
-0x41, 0x48, 0xEE, 0xF1, 0xF1, 0x30, 0xE0, 0x02,
-0x41, 0x48, 0x90, 0x88, 0x39, 0xE0, 0xFE, 0x6F,
-0x70, 0x02, 0x41, 0x48, 0xEF, 0x70, 0x02, 0x21,
-0xA4, 0x24, 0xFE, 0x70, 0x02, 0x21, 0xE9, 0x24,
-0xFE, 0x60, 0x4F, 0x24, 0xFC, 0x70, 0x02, 0x41,
-0x2E, 0x24, 0xFC, 0x60, 0x02, 0x41, 0x41, 0xEE,
-0xB4, 0x0E, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88,
-0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x78,
-0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03,
-0x12, 0x71, 0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4,
-0x04, 0x11, 0x90, 0x96, 0xD0, 0xE0, 0xFF, 0x60,
-0x05, 0x12, 0x67, 0x80, 0x80, 0x05, 0x90, 0x8A,
-0xED, 0x11, 0xCD, 0x90, 0x88, 0x39, 0xE0, 0x64,
-0x08, 0x60, 0x02, 0x41, 0x41, 0x12, 0x7B, 0xCC,
-0x41, 0x41, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x05,
-0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90, 0x88, 0x39,
-0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24, 0x90,
-0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B, 0x90, 0x86,
-0x00, 0x11, 0xCD, 0xBF, 0x01, 0x03, 0x12, 0x71,
-0x5F, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x0C, 0x60,
-0x02, 0x41, 0x41, 0x90, 0x86, 0x00, 0x11, 0xCD,
-0xEF, 0x64, 0x01, 0x60, 0x02, 0x41, 0x41, 0x12,
-0x68, 0xC2, 0x41, 0x41, 0x90, 0x88, 0x39, 0xE0,
-0xB4, 0x0E, 0x0B, 0x90, 0x86, 0x00, 0x11, 0xCD,
-0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88,
-0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24,
-0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0B, 0x90,
-0x86, 0x00, 0x11, 0xCD, 0xBF, 0x01, 0x03, 0x12,
-0x68, 0xC2, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x04,
-0x70, 0x67, 0x90, 0x86, 0x02, 0x11, 0xCD, 0xEF,
-0x64, 0x01, 0x70, 0x5D, 0x12, 0x73, 0x5A, 0x80,
-0x58, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B,
-0x90, 0x86, 0x00, 0x11, 0xCD, 0xBF, 0x01, 0x03,
-0x12, 0x71, 0x5F, 0x90, 0x88, 0x39, 0xE0, 0xB4,
-0x06, 0x03, 0x12, 0x71, 0x24, 0x90, 0x88, 0x39,
-0xE0, 0xB4, 0x0C, 0x0B, 0x90, 0x86, 0x00, 0x11,
-0xCD, 0xBF, 0x01, 0x03, 0x12, 0x68, 0xC2, 0x90,
-0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12,
-0x78, 0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x04,
-0x18, 0x12, 0x7A, 0x49, 0x80, 0x13, 0x90, 0x88,
-0x39, 0xE0, 0xB4, 0x0C, 0x0C, 0x90, 0x88, 0x32,
-0x12, 0xAF, 0x0F, 0x30, 0xE0, 0x03, 0x12, 0x79,
-0xD4, 0x90, 0x88, 0x39, 0x12, 0xDC, 0xEB, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4, 0xFB, 0xFA,
-0xFD, 0x7F, 0x01, 0x12, 0x85, 0x4E, 0x90, 0x95,
-0x38, 0xEF, 0xF0, 0x60, 0xF0, 0x90, 0x86, 0xAF,
-0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0, 0x60, 0xE5,
-0xC2, 0xAF, 0xEF, 0x30, 0xE0, 0x0F, 0x90, 0x86,
-0xAF, 0xE0, 0x54, 0xFE, 0xF0, 0xE4, 0xFF, 0x12,
-0xB5, 0xE7, 0x12, 0xC7, 0xB4, 0x51, 0xBE, 0xE0,
-0x30, 0xE1, 0x08, 0x54, 0xFD, 0xF0, 0x90, 0x86,
-0x08, 0x11, 0xCD, 0x51, 0xBE, 0xE0, 0x30, 0xE2,
-0x08, 0x54, 0xFB, 0xF0, 0x90, 0x86, 0x0A, 0x11,
-0xCD, 0x51, 0xBE, 0xE0, 0xFF, 0x30, 0xE5, 0x0C,
-0x54, 0xDF, 0xF0, 0x12, 0xD4, 0x43, 0xBF, 0x01,
-0x03, 0x12, 0xD4, 0xE8, 0x51, 0xBE, 0xE0, 0x30,
-0xE6, 0x08, 0x54, 0xBF, 0xF0, 0x90, 0x8A, 0x7D,
-0x11, 0xCD, 0xD2, 0xAF, 0x80, 0x9F, 0xD2, 0xAF,
-0xC2, 0xAF, 0x90, 0x86, 0xAF, 0x22, 0x90, 0x94,
-0xB6, 0x12, 0x86, 0x6D, 0x02, 0x02, 0x06, 0x90,
-0x93, 0x29, 0xE0, 0x30, 0xE0, 0x5D, 0xC4, 0x54,
-0x0F, 0x20, 0xE0, 0x1D, 0x12, 0xDD, 0x50, 0x12,
-0xA7, 0x92, 0x90, 0x8A, 0xF9, 0x71, 0x46, 0x11,
-0xC4, 0x12, 0xDD, 0x04, 0x30, 0xE0, 0x07, 0x90,
-0x8A, 0x89, 0x71, 0x46, 0xF1, 0xE6, 0x02, 0xAD,
-0x94, 0x90, 0x93, 0x29, 0xE0, 0xC4, 0x54, 0x0F,
-0x30, 0xE0, 0x30, 0xE4, 0x90, 0x92, 0x20, 0xF0,
-0x90, 0x93, 0x2C, 0x12, 0xA7, 0x92, 0x90, 0x93,
-0x29, 0xE0, 0x54, 0xEF, 0xF0, 0xE0, 0xC3, 0x13,
-0x30, 0xE0, 0x0C, 0x90, 0x8A, 0x89, 0x71, 0x46,
-0x7D, 0x04, 0x7F, 0x01, 0x02, 0x04, 0x7E, 0x90,
-0x8A, 0xF9, 0x71, 0x46, 0x7D, 0x31, 0x12, 0xD2,
-0x82, 0x11, 0xCD, 0x22, 0x90, 0x8A, 0x77, 0xE0,
-0xFE, 0xA3, 0xE0, 0xFF, 0xF5, 0x82, 0x8E, 0x83,
-0x12, 0x04, 0x7E, 0x90, 0x8A, 0x79, 0xE0, 0xFE,
-0xA3, 0xE0, 0xF5, 0x82, 0x8E, 0x83, 0x22, 0x90,
-0x8A, 0xD9, 0x71, 0x46, 0x7F, 0x01, 0x12, 0x04,
-0x7E, 0x90, 0x88, 0xA1, 0xF1, 0xF0, 0x30, 0xE0,
-0x04, 0x7F, 0x03, 0x80, 0x02, 0x7F, 0x01, 0x12,
-0x71, 0x9A, 0xE4, 0x90, 0x88, 0xAF, 0xF0, 0xA3,
-0x12, 0xD4, 0x1D, 0x30, 0xE0, 0x09, 0x90, 0x8A,
-0xF9, 0x71, 0x46, 0x7D, 0x0E, 0x80, 0x32, 0x90,
-0x88, 0x9D, 0xE0, 0xC4, 0x54, 0x0F, 0x30, 0xE0,
-0x15, 0x12, 0xDD, 0x59, 0x20, 0xE0, 0x06, 0x12,
-0xA6, 0xF9, 0x12, 0xDD, 0x85, 0x90, 0x8A, 0xF9,
-0x71, 0x46, 0x7D, 0x0F, 0x80, 0x13, 0x90, 0x88,
-0x36, 0xE0, 0x60, 0x12, 0x12, 0xA6, 0xF9, 0x12,
-0xDD, 0x85, 0x90, 0x8A, 0xF9, 0x71, 0x46, 0x7D,
-0x10, 0x7F, 0x6F, 0x12, 0x04, 0x7E, 0x90, 0x88,
-0xA0, 0xE0, 0x30, 0xE0, 0x08, 0x90, 0x8A, 0xF9,
-0x71, 0x46, 0x12, 0xA9, 0x17, 0xF1, 0xED, 0x30,
-0xE0, 0x0A, 0x90, 0x8A, 0x97, 0x71, 0x46, 0xE4,
-0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA1, 0xE0,
-0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x0E, 0x90, 0x06,
-0xCD, 0xE0, 0x54, 0xEF, 0xF0, 0x90, 0x06, 0xCF,
-0xE0, 0x54, 0xEF, 0xF0, 0x12, 0xBE, 0x34, 0x30,
-0xE0, 0x1C, 0xEF, 0x13, 0x13, 0x54, 0x3F, 0x30,
-0xE0, 0x14, 0xEE, 0x44, 0x08, 0xF0, 0xA3, 0xE0,
-0xC3, 0x13, 0x54, 0x7F, 0xFF, 0x90, 0x8A, 0xD1,
-0x12, 0x9E, 0x75, 0x12, 0x04, 0x7E, 0x90, 0x05,
-0x63, 0xE0, 0x90, 0x96, 0xB7, 0xF0, 0x90, 0x05,
-0x62, 0xE0, 0x90, 0x96, 0xB6, 0xF0, 0x90, 0x05,
-0x61, 0xE0, 0x90, 0x96, 0xB5, 0xF0, 0x90, 0x05,
-0x60, 0xE0, 0x90, 0x96, 0xB4, 0xF0, 0xD1, 0xD0,
-0x12, 0xD4, 0x27, 0x90, 0x96, 0xB4, 0xD1, 0xD1,
+0xF1, 0x86, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB5,
+0xF1, 0x25, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB6,
+0xF1, 0x75, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB7,
+0xF1, 0x7F, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB8,
+0xF1, 0xA6, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB9,
+0xF1, 0x9F, 0xFF, 0xAE, 0x05, 0xED, 0x2F, 0x90,
+0x86, 0xBA, 0xF0, 0x22, 0x4F, 0xF0, 0x90, 0x00,
+0x02, 0x02, 0x02, 0x1F, 0x12, 0x02, 0x06, 0xFE,
+0xF1, 0x26, 0xFF, 0x74, 0xD6, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x8D, 0xF1, 0x72, 0xFF, 0xF1, 0x69,
+0xF1, 0x7C, 0xFF, 0x74, 0x15, 0x2E, 0xF1, 0xAD,
+0xEF, 0xF0, 0xF1, 0x69, 0xF5, 0x83, 0xE0, 0x30,
+0xE5, 0x16, 0x75, 0xF0, 0x12, 0xEE, 0xF1, 0xBA,
+0x13, 0x13, 0x54, 0x03, 0xFB, 0xAF, 0x06, 0x74,
+0xD6, 0x2E, 0xF1, 0xC6, 0xFD, 0x12, 0x6B, 0xFD,
+0x22, 0x74, 0xC6, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0x8D, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00,
+0x03, 0x02, 0x02, 0x1F, 0xF5, 0x83, 0xEF, 0xF0,
+0x90, 0x00, 0x04, 0x02, 0x02, 0x1F, 0xF0, 0x90,
+0x00, 0x01, 0x02, 0x02, 0x1F, 0x12, 0x02, 0x06,
+0x90, 0x93, 0x26, 0xF1, 0x86, 0x90, 0x93, 0x27,
+0xF1, 0x25, 0x90, 0x93, 0x28, 0xF0, 0x22, 0xF0,
+0x90, 0x00, 0x06, 0x02, 0x02, 0x1F, 0xF0, 0x90,
+0x00, 0x05, 0x02, 0x02, 0x1F, 0xF5, 0x82, 0xE4,
+0x34, 0x96, 0xF5, 0x83, 0x22, 0xFF, 0x75, 0xF0,
+0x12, 0xED, 0x90, 0x89, 0x52, 0x12, 0x04, 0x6E,
+0xE0, 0x22, 0x74, 0xD6, 0x25, 0x62, 0xF5, 0x82,
+0xE4, 0x34, 0x8D, 0xF5, 0x83, 0xE0, 0x22, 0x12,
+0x02, 0x06, 0xFF, 0xF1, 0x87, 0x90, 0x94, 0xBD,
+0xF1, 0x25, 0x90, 0x94, 0xBE, 0xF1, 0x75, 0x90,
+0x94, 0xBF, 0xF1, 0x7F, 0x90, 0x94, 0xC0, 0xF1,
+0xA6, 0x90, 0x94, 0xC1, 0xF1, 0x9F, 0x90, 0x94,
+0xC2, 0xF0, 0xEF, 0x24, 0xF9, 0x60, 0x40, 0x14,
+0x70, 0x03, 0x02, 0x88, 0x8C, 0x14, 0x70, 0x02,
+0x01, 0x8F, 0x24, 0xFD, 0x70, 0x02, 0x01, 0xCE,
+0x24, 0x06, 0x60, 0x02, 0x01, 0xDE, 0x90, 0x94,
+0xBD, 0xE0, 0x90, 0x88, 0xE1, 0xF0, 0x90, 0x94,
+0xBE, 0xE0, 0x90, 0x88, 0xE2, 0xF0, 0x90, 0x94,
+0xBF, 0xE0, 0x90, 0x88, 0xE3, 0xF0, 0x90, 0x94,
+0xC0, 0xE0, 0x90, 0x88, 0xE4, 0xF0, 0x90, 0x94,
+0xC1, 0xE0, 0x90, 0x88, 0xE5, 0xF0, 0x22, 0x90,
+0x94, 0xBD, 0xE0, 0x90, 0x94, 0xAE, 0xF0, 0x90,
+0x94, 0xC0, 0x31, 0x01, 0x78, 0x10, 0x12, 0x03,
+0xFE, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0xA3, 0x31, 0x01, 0x78, 0x18, 0x12, 0x03,
+0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x86, 0x54, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x94, 0xBF, 0x31,
+0x01, 0x78, 0x08, 0x12, 0x03, 0xFE, 0xD0, 0x03,
+0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86,
+0x54, 0x11, 0xF6, 0x12, 0x86, 0x54, 0x90, 0x94,
+0xA4, 0x02, 0x04, 0x31, 0x02, 0x9F, 0x14, 0x90,
+0x94, 0xB0, 0xE0, 0x44, 0x01, 0xFF, 0xF0, 0x90,
+0x94, 0xBD, 0xE0, 0x54, 0x7F, 0x25, 0xE0, 0xFE,
+0xEF, 0x54, 0x01, 0x4E, 0x90, 0x94, 0xB0, 0xF0,
+0xE0, 0xFF, 0xC3, 0x13, 0x54, 0x7F, 0xC3, 0x94,
+0x1E, 0x50, 0x06, 0xEF, 0x54, 0x01, 0x44, 0x3C,
+0xF0, 0x90, 0x94, 0xB0, 0xE0, 0xFF, 0xC3, 0x13,
+0x54, 0x7F, 0xD3, 0x94, 0x50, 0x40, 0x2E, 0xEF,
+0x54, 0x01, 0x44, 0xA0, 0xF0, 0x22, 0x90, 0x94,
+0xBD, 0xE0, 0x54, 0x01, 0xFF, 0x90, 0x94, 0xB7,
+0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x22, 0x7E, 0x01,
+0x7F, 0xFF, 0xAD, 0x06, 0x12, 0xA0, 0xCC, 0x90,
+0x8A, 0xCF, 0xE0, 0xF8, 0xA3, 0xE0, 0xF5, 0x82,
+0x88, 0x83, 0x12, 0x04, 0x7E, 0x22, 0xA8, 0x04,
+0xA9, 0x05, 0xAA, 0x06, 0xAB, 0x07, 0x90, 0x94,
+0xBE, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0x22,
+0x90, 0x94, 0xB9, 0xE0, 0x04, 0xF0, 0x90, 0x8A,
+0xD9, 0x51, 0x5F, 0x7F, 0x01, 0x12, 0x04, 0x7E,
+0x90, 0x88, 0xA1, 0xB1, 0x34, 0x30, 0xE0, 0x04,
+0x7F, 0x03, 0x80, 0x02, 0x7F, 0x01, 0x12, 0x71,
+0x9A, 0xE4, 0x90, 0x88, 0xAF, 0xF0, 0xA3, 0xF1,
+0xF8, 0x30, 0xE0, 0x09, 0x90, 0x8A, 0xF9, 0x51,
+0x5F, 0x7D, 0x0E, 0x80, 0x2B, 0xF1, 0xE4, 0x30,
+0xE0, 0x14, 0x12, 0xE0, 0x99, 0x20, 0xE0, 0x05,
+0x12, 0xA7, 0x27, 0xF1, 0xDD, 0x90, 0x8A, 0xF9,
+0x51, 0x5F, 0x7D, 0x0F, 0x80, 0x12, 0x90, 0x88,
+0x36, 0xE0, 0x60, 0x11, 0x12, 0xA7, 0x27, 0xF1,
+0xDD, 0x90, 0x8A, 0xF9, 0x51, 0x5F, 0x7D, 0x10,
+0x7F, 0x6F, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA0,
+0xE0, 0x30, 0xE0, 0x08, 0x90, 0x8A, 0xF9, 0x51,
+0x5F, 0x12, 0x97, 0xF1, 0x90, 0x88, 0xA0, 0xB1,
+0x34, 0x30, 0xE0, 0x0A, 0x90, 0x8A, 0x97, 0x51,
+0x5F, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88,
+0xA1, 0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x0E,
+0x90, 0x06, 0xCD, 0xE0, 0x54, 0xEF, 0xF0, 0x90,
+0x06, 0xCF, 0xE0, 0x54, 0xEF, 0xF0, 0x12, 0xDB,
+0xDC, 0x30, 0xE0, 0x1C, 0xEF, 0x13, 0x13, 0x54,
+0x3F, 0x30, 0xE0, 0x14, 0xEE, 0x44, 0x08, 0xF0,
+0xA3, 0xE0, 0xC3, 0x13, 0x54, 0x7F, 0xFF, 0x90,
+0x8A, 0xD1, 0x12, 0xA5, 0xDE, 0x12, 0x04, 0x7E,
+0x90, 0x05, 0x63, 0xE0, 0x90, 0x96, 0xDB, 0xF0,
+0x90, 0x05, 0x62, 0xE0, 0x90, 0x96, 0xDA, 0xF0,
+0x90, 0x05, 0x61, 0xE0, 0x90, 0x96, 0xD9, 0xF0,
+0x90, 0x05, 0x60, 0xE0, 0x90, 0x96, 0xD8, 0xF0,
+0xA3, 0x31, 0x01, 0x12, 0xE0, 0x70, 0x90, 0x96,
+0xD8, 0x31, 0x01, 0x12, 0x86, 0x54, 0xC0, 0x04,
+0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x96,
+0xDA, 0x31, 0x01, 0x78, 0x10, 0x12, 0x03, 0xFE,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
 0x12, 0x86, 0x54, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x96, 0xB6, 0xD1, 0xD1,
-0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x54,
-0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0xD1, 0xD0, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0,
+0x06, 0xC0, 0x07, 0xA3, 0x31, 0x01, 0x78, 0x18,
+0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0x12, 0x86, 0x54, 0x90, 0x94,
+0xB1, 0x12, 0x04, 0x31, 0x12, 0xDC, 0xB4, 0x90,
+0x96, 0xDC, 0xF0, 0x7B, 0x01, 0x7A, 0x96, 0x79,
+0xDC, 0x90, 0x8A, 0xCF, 0x51, 0x5F, 0x7D, 0x01,
+0x7F, 0x42, 0x02, 0x04, 0x7E, 0x90, 0x8A, 0x77,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xF5, 0x82, 0x8E,
+0x83, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0x79, 0xE0,
+0xFE, 0xA3, 0xE0, 0xF5, 0x82, 0x8E, 0x83, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x94, 0xBD, 0x74, 0x02, 0xF0, 0x90, 0x88, 0xC2,
+0xE0, 0x44, 0x10, 0xF0, 0x90, 0x88, 0xAF, 0xE0,
+0x60, 0x02, 0x61, 0xFA, 0x90, 0x8A, 0xD9, 0x51,
+0x5F, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88,
+0xA1, 0xE0, 0x30, 0xE0, 0x04, 0x7F, 0x01, 0x80,
+0x36, 0x90, 0x88, 0x9D, 0xF1, 0xEF, 0x30, 0xE0,
+0x04, 0x7F, 0x0D, 0x80, 0x2A, 0x90, 0x88, 0xA0,
+0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x10,
+0xEF, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x04,
+0x7F, 0x09, 0x80, 0x13, 0x7F, 0x03, 0x80, 0x0F,
+0x90, 0x88, 0xA0, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
+0x04, 0x7F, 0x03, 0x80, 0x02, 0x7F, 0x09, 0x12,
+0x71, 0x9A, 0x90, 0x88, 0xAF, 0x74, 0x01, 0xF1,
+0xF8, 0x30, 0xE0, 0x05, 0x12, 0xA4, 0x85, 0x80,
+0x3B, 0xF1, 0xE4, 0x30, 0xE0, 0x36, 0x90, 0x88,
+0xA3, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x88, 0x9C,
+0xE0, 0x60, 0x0B, 0x90, 0x8A, 0xB9, 0x51, 0x5F,
+0x7D, 0x01, 0x7F, 0x04, 0x80, 0x11, 0x12, 0xA4,
+0x85, 0xB1, 0x31, 0x90, 0x8A, 0xB9, 0x20, 0xE0,
+0x0B, 0x51, 0x5F, 0x7D, 0x01, 0x7F, 0x0C, 0x12,
+0x04, 0x7E, 0x80, 0x08, 0x51, 0x5F, 0x12, 0xAF,
+0x89, 0x12, 0xBC, 0x87, 0x90, 0x88, 0x9C, 0xE0,
+0x60, 0x06, 0x7B, 0x04, 0x7D, 0x6F, 0x80, 0x03,
+0xE4, 0xFB, 0xFD, 0x7F, 0xFF, 0x12, 0xA4, 0x8A,
+0x90, 0x88, 0xA0, 0xB1, 0x34, 0x30, 0xE0, 0x0A,
+0x90, 0x8A, 0x97, 0x51, 0x5F, 0x7F, 0x01, 0x12,
+0x04, 0x7E, 0x90, 0x88, 0xA1, 0xE0, 0xC3, 0x13,
+0x30, 0xE0, 0x0E, 0x90, 0x06, 0xCD, 0xE0, 0x44,
+0x10, 0xF0, 0x90, 0x06, 0xCF, 0xE0, 0x44, 0x10,
+0xF0, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x94, 0xC1,
+0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x94, 0xC0,
+0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x94, 0xBF,
+0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x94, 0xBE,
+0xF0, 0xA3, 0x31, 0x01, 0x78, 0x08, 0x12, 0x03,
+0xFE, 0x11, 0xF6, 0x12, 0x86, 0x54, 0xC0, 0x04,
+0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x94,
+0xC0, 0x31, 0x01, 0x78, 0x10, 0x12, 0x03, 0xFE,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0x12, 0x86, 0x54, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
+0x06, 0xC0, 0x07, 0xA3, 0x31, 0x01, 0x78, 0x18,
+0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0x12, 0x86, 0x54, 0xA3, 0x12,
+0x04, 0x31, 0x90, 0x88, 0xA1, 0x12, 0xAD, 0x2E,
+0x30, 0xE0, 0x2F, 0x90, 0x94, 0xB1, 0x12, 0x04,
+0xB8, 0x90, 0x94, 0xC2, 0x12, 0xD7, 0x77, 0x40,
+0x21, 0x90, 0x94, 0xB1, 0x12, 0x86, 0x61, 0x90,
+0x94, 0xC2, 0x12, 0x04, 0xB8, 0x12, 0x86, 0x39,
+0xE4, 0xFB, 0x7A, 0x78, 0xF9, 0xF8, 0xC3, 0x12,
+0x03, 0xDA, 0x50, 0x06, 0x90, 0x94, 0xB6, 0xE0,
+0x04, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
+0x88, 0xB8, 0xE0, 0x30, 0xE0, 0x05, 0x90, 0x8A,
+0x8F, 0x80, 0x03, 0x90, 0x8A, 0x87, 0xD1, 0xAD,
+0x90, 0x88, 0xE6, 0xE0, 0x30, 0xE0, 0x04, 0xA3,
+0xE0, 0x04, 0xF0, 0x90, 0x88, 0xE7, 0xE0, 0x64,
+0x08, 0x70, 0x21, 0x90, 0x88, 0xE6, 0xE0, 0x30,
+0xE0, 0x15, 0x12, 0xC2, 0xF4, 0xF0, 0xE4, 0xFD,
+0x12, 0x76, 0xF7, 0x90, 0x88, 0xE6, 0xE0, 0x54,
+0xFE, 0xF0, 0xE4, 0xA3, 0xF0, 0x80, 0x05, 0xE4,
+0x90, 0x88, 0xE7, 0xF0, 0xF1, 0xEC, 0x30, 0xE0,
+0x13, 0x90, 0x88, 0xE8, 0xE0, 0x04, 0xF0, 0xE0,
+0xB4, 0x14, 0x09, 0x90, 0x04, 0x9C, 0xE4, 0xF0,
+0x90, 0x88, 0xE8, 0xF0, 0x90, 0x88, 0x36, 0xE0,
+0x70, 0x02, 0x81, 0xE9, 0x90, 0x88, 0x4D, 0xE0,
+0x04, 0xF0, 0x90, 0x05, 0x61, 0x31, 0x01, 0x12,
+0xE0, 0x70, 0x90, 0x05, 0x60, 0x31, 0x01, 0x12,
+0x86, 0x54, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x05, 0x62, 0x31, 0x01, 0x78,
+0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x54, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3,
+0x31, 0x01, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0,
 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x86, 0x54, 0x90, 0x94, 0xB0, 0x02, 0x04, 0x31,
-0x90, 0x94, 0xB6, 0xEF, 0xF0, 0xD1, 0xC9, 0x7F,
-0xF4, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
-0x08, 0x90, 0x94, 0xFD, 0xE0, 0x90, 0x94, 0xFF,
-0xF0, 0xD1, 0xC9, 0x7F, 0xF5, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x94, 0xFD,
-0xE0, 0x90, 0x95, 0x00, 0xF0, 0xD1, 0xC9, 0x7F,
-0xF6, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
-0x08, 0x90, 0x94, 0xFD, 0xE0, 0x90, 0x95, 0x01,
-0xF0, 0xD1, 0xC9, 0x7F, 0xF7, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x94, 0xFD,
-0xE0, 0x90, 0x95, 0x02, 0xF0, 0xD1, 0xC9, 0x7F,
-0xF8, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
-0x08, 0x90, 0x94, 0xFD, 0xE0, 0x90, 0x95, 0x03,
-0xF0, 0xD1, 0xC9, 0x12, 0xDD, 0x9C, 0xBF, 0x01,
-0x08, 0x90, 0x94, 0xFD, 0xE0, 0x90, 0x95, 0x04,
-0xF0, 0xD1, 0xC9, 0x12, 0xDC, 0xC1, 0x70, 0x53,
-0x90, 0x94, 0xFD, 0xE0, 0x90, 0x95, 0x05, 0xF0,
-0x54, 0x07, 0x60, 0x08, 0x90, 0x94, 0xFD, 0xE0,
-0x54, 0xE0, 0x70, 0x3F, 0x7B, 0x01, 0x7A, 0x94,
-0x79, 0xFE, 0x7F, 0xFA, 0x12, 0xDC, 0xC3, 0x70,
-0x32, 0x90, 0x94, 0xFD, 0xE0, 0xFC, 0x54, 0x07,
-0x70, 0x12, 0x90, 0x95, 0x05, 0xE0, 0xFE, 0x90,
-0x94, 0xFE, 0xE0, 0x54, 0x07, 0xFD, 0xEE, 0x4D,
-0x90, 0x95, 0x05, 0xF0, 0xEC, 0x54, 0xE0, 0x70,
-0x12, 0x90, 0x95, 0x05, 0xE0, 0xFF, 0x90, 0x94,
-0xFE, 0xE0, 0x54, 0xE0, 0xFE, 0xEF, 0x4E, 0x90,
-0x95, 0x05, 0xF0, 0xD1, 0xC9, 0x7F, 0xFD, 0x12,
-0xDC, 0xC3, 0x70, 0x47, 0x90, 0x94, 0xFD, 0xE0,
-0xFE, 0x54, 0xCC, 0x90, 0x95, 0x06, 0xF0, 0xEE,
-0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90, 0x94, 0xFD,
-0xE0, 0x54, 0xC0, 0x70, 0x2E, 0xEF, 0x70, 0x12,
-0x90, 0x95, 0x06, 0xE0, 0xFF, 0x90, 0x94, 0xFD,
-0xE0, 0x54, 0x03, 0x12, 0xDD, 0x94, 0x90, 0x95,
-0x06, 0xF0, 0x90, 0x94, 0xFD, 0xE0, 0xFF, 0x54,
-0xC0, 0x70, 0x10, 0x90, 0x95, 0x06, 0xE0, 0xFE,
-0xEF, 0x54, 0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF,
-0xEE, 0x4F, 0xF0, 0xD1, 0xC9, 0x7F, 0xF0, 0x7E,
-0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
-0x94, 0xFD, 0xE0, 0x90, 0x95, 0x07, 0xF0, 0xD1,
-0xC9, 0x7F, 0xF1, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
-0xBF, 0x01, 0x08, 0x90, 0x94, 0xFD, 0xE0, 0x90,
-0x95, 0x08, 0xF0, 0xD1, 0xC9, 0x7F, 0xF2, 0x7E,
-0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
-0x94, 0xFD, 0xE0, 0x90, 0x95, 0x09, 0xF0, 0xD1,
-0xC9, 0x7F, 0xF3, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
-0xBF, 0x01, 0x08, 0x90, 0x94, 0xFD, 0xE0, 0x90,
-0x95, 0x0A, 0xF0, 0xD1, 0xC9, 0x7F, 0xFC, 0x7E,
-0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
-0x94, 0xFD, 0xE0, 0x90, 0x95, 0x0B, 0xF0, 0x90,
-0x94, 0xB7, 0x74, 0x19, 0xF0, 0x90, 0x94, 0xD9,
-0x74, 0x08, 0xF0, 0x90, 0x94, 0xFF, 0xE0, 0x90,
-0x94, 0xB9, 0xF0, 0x90, 0x95, 0x00, 0xE0, 0x90,
-0x94, 0xBA, 0xF0, 0x90, 0x95, 0x01, 0xE0, 0x90,
-0x94, 0xBB, 0xF0, 0x90, 0x95, 0x02, 0xE0, 0x90,
-0x94, 0xBC, 0xF0, 0x90, 0x95, 0x03, 0xE0, 0x90,
-0x94, 0xBD, 0xF0, 0x90, 0x95, 0x04, 0xE0, 0x90,
-0x94, 0xBE, 0xF0, 0x90, 0x95, 0x05, 0xE0, 0x90,
-0x94, 0xBF, 0xF0, 0x90, 0x95, 0x06, 0xE0, 0x90,
-0x94, 0xC0, 0xF0, 0x90, 0x94, 0xDA, 0x74, 0x1A,
-0xF0, 0x90, 0x94, 0xFC, 0x74, 0x05, 0xF0, 0x90,
-0x95, 0x07, 0xE0, 0x90, 0x94, 0xDC, 0xF0, 0x90,
-0x95, 0x08, 0xE0, 0x90, 0x94, 0xDD, 0xF0, 0x90,
-0x95, 0x09, 0xE0, 0x90, 0x94, 0xDE, 0xF0, 0x90,
-0x95, 0x0A, 0xE0, 0x90, 0x94, 0xDF, 0xF0, 0x90,
-0x95, 0x0B, 0xE0, 0x90, 0x94, 0xE0, 0xF0, 0x90,
-0x94, 0xB6, 0xE0, 0xB4, 0x01, 0x19, 0x7B, 0x01,
-0x7A, 0x94, 0x79, 0xB7, 0x12, 0xA4, 0x3F, 0x12,
-0x04, 0x7E, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0xDA,
-0x71, 0x34, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0x75,
-0x45, 0x01, 0x75, 0x46, 0x94, 0x75, 0x47, 0xB7,
-0x75, 0x48, 0x0A, 0x7B, 0x01, 0x7A, 0x01, 0x79,
-0xA0, 0x12, 0x69, 0xF5, 0x75, 0x45, 0x01, 0x75,
-0x46, 0x94, 0x75, 0x47, 0xDC, 0x75, 0x48, 0x05,
-0x7B, 0x01, 0x7A, 0x01, 0x79, 0xAA, 0x02, 0x69,
-0xF5, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0xFD, 0x22,
-0xA3, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0x22,
-0x7E, 0x00, 0x7F, 0x62, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x88, 0x79, 0x31, 0x12, 0x04, 0x80, 0xE4,
-0x90, 0x94, 0xA1, 0xF0, 0x90, 0x88, 0x35, 0x74,
-0x02, 0xF0, 0x90, 0x88, 0x3C, 0x14, 0xF0, 0xA3,
-0xF0, 0xA3, 0x74, 0x50, 0xF0, 0x90, 0x88, 0x42,
-0xE4, 0xF0, 0xA3, 0x74, 0x02, 0xF0, 0x90, 0x88,
-0x4E, 0x74, 0x10, 0xF0, 0xA3, 0x74, 0x50, 0xF0,
-0x12, 0xDB, 0xED, 0x90, 0x8A, 0x89, 0x71, 0x46,
-0x12, 0xA9, 0x17, 0x90, 0x8A, 0x89, 0x71, 0x46,
-0x7D, 0x0C, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x90,
-0x8A, 0x89, 0x71, 0x46, 0xF1, 0xE6, 0x90, 0x86,
-0xB3, 0xE0, 0xFF, 0xB4, 0x01, 0x08, 0x90, 0x88,
-0x41, 0x74, 0xDD, 0xF0, 0x80, 0x18, 0xEF, 0xB4,
-0x03, 0x0F, 0x90, 0x88, 0x41, 0x74, 0xF4, 0xF0,
-0x90, 0x00, 0x92, 0xE0, 0x54, 0x7F, 0xF0, 0x80,
-0x05, 0xE4, 0x90, 0x88, 0x41, 0xF0, 0x90, 0x00,
-0x79, 0xE0, 0x54, 0x03, 0xFF, 0xBF, 0x02, 0x0D,
-0x90, 0x00, 0x28, 0xE0, 0x30, 0xE2, 0x06, 0x90,
-0x88, 0x53, 0x74, 0x02, 0xF0, 0x90, 0x88, 0x93,
-0x74, 0x02, 0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3,
-0xE0, 0x54, 0x01, 0x44, 0x28, 0xF0, 0xA3, 0x74,
-0x07, 0xF0, 0x7E, 0x00, 0x7F, 0x18, 0x7D, 0x00,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x31, 0x12, 0x04,
-0x80, 0x90, 0x8A, 0xA3, 0x71, 0x46, 0x7F, 0x01,
-0x12, 0x04, 0x7E, 0x7E, 0x00, 0x7F, 0x02, 0x7D,
-0x00, 0x7B, 0x01, 0x7A, 0x88, 0x79, 0x9A, 0x12,
-0x04, 0x80, 0x90, 0x06, 0x04, 0xE0, 0x54, 0x7F,
-0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x54, 0xF8, 0xF0,
-0x90, 0x05, 0x22, 0xE4, 0xF0, 0x90, 0x88, 0x9C,
-0xF0, 0x22, 0x90, 0x93, 0x29, 0xE0, 0x30, 0xE0,
-0x1C, 0x90, 0x01, 0x57, 0xE4, 0xF0, 0x90, 0x8A,
-0xF9, 0x71, 0x46, 0x11, 0xC4, 0x12, 0xDD, 0x04,
-0x30, 0xE0, 0x07, 0x90, 0x8A, 0x89, 0x71, 0x46,
-0xF1, 0xE6, 0x12, 0xAD, 0x94, 0x22, 0x7D, 0x0C,
-0x7F, 0x01, 0x02, 0x04, 0x7E, 0x90, 0x88, 0xA0,
-0xE0, 0xC4, 0x13, 0x13, 0x13, 0x54, 0x01, 0x22,
-0x7D, 0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x96, 0xC1, 0xEF, 0xF0, 0xA3, 0xED,
-0xF0, 0x90, 0x8A, 0xF9, 0x12, 0x8B, 0x46, 0x7D,
-0x44, 0x7F, 0x6F, 0x12, 0x04, 0x7E, 0x90, 0x8A,
-0xFD, 0x12, 0x88, 0xCD, 0x90, 0x96, 0xC2, 0xE0,
-0x90, 0x96, 0xC1, 0xB4, 0x01, 0x09, 0xE0, 0x11,
-0x48, 0xE0, 0x44, 0x04, 0xF0, 0x80, 0x07, 0xE0,
-0x11, 0x48, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x8A,
-0xF9, 0x12, 0x8B, 0x46, 0x12, 0xA9, 0x17, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0xE0, 0xFD, 0xE5, 0x0E,
-0xC4, 0x54, 0xF0, 0x24, 0x05, 0xF5, 0x82, 0xE4,
-0x34, 0x81, 0xF5, 0x83, 0x22, 0x8D, 0x0E, 0xEF,
-0x30, 0xE6, 0x1E, 0x11, 0xDC, 0x11, 0x44, 0xE0,
-0x54, 0x03, 0x90, 0x92, 0x80, 0xF0, 0xE4, 0xFB,
-0xAF, 0x0E, 0x12, 0x75, 0x80, 0x11, 0xCF, 0xE0,
-0x90, 0x92, 0x5E, 0xF0, 0xA3, 0x74, 0x01, 0x80,
-0x4D, 0x11, 0xEB, 0x04, 0xF0, 0x11, 0xEB, 0x64,
-0x02, 0x70, 0x1B, 0x74, 0x1E, 0x25, 0x0E, 0x31,
-0xB5, 0xE0, 0xFD, 0xF4, 0x60, 0x02, 0x80, 0x04,
-0x11, 0xDC, 0xE0, 0xFD, 0x11, 0x46, 0xF1, 0xEA,
-0x11, 0xDC, 0x91, 0xBE, 0x80, 0x28, 0x11, 0xEB,
-0xD3, 0x94, 0x03, 0x40, 0x17, 0x90, 0x8A, 0xB3,
-0x12, 0x8B, 0x46, 0xAF, 0x0E, 0x12, 0x04, 0x7E,
-0x11, 0xCF, 0xE0, 0x90, 0x92, 0x5E, 0xF0, 0xA3,
-0x74, 0x03, 0x80, 0x0A, 0x11, 0xDC, 0x11, 0x44,
-0xF1, 0xEA, 0x11, 0xDC, 0x91, 0xBE, 0xF0, 0xAB,
-0x0E, 0xE4, 0xFD, 0xFF, 0x02, 0x6F, 0x75, 0x74,
-0xB6, 0x25, 0x0E, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
-0xF5, 0x83, 0xE4, 0xF0, 0xE5, 0x0E, 0xC4, 0x54,
-0xF0, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x81,
-0xF5, 0x83, 0x22, 0x74, 0xB6, 0x25, 0x0E, 0xF5,
-0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83, 0xE0, 0x22,
-0x8F, 0x70, 0x8D, 0x71, 0xEF, 0x11, 0xDE, 0xE0,
-0xFD, 0x54, 0x7F, 0xF5, 0x72, 0xED, 0x54, 0x80,
-0xF5, 0x73, 0xF1, 0xBB, 0xF5, 0x75, 0x75, 0xF0,
-0x12, 0xEF, 0x91, 0xEE, 0xC4, 0x54, 0x03, 0xF5,
-0x76, 0x31, 0xB1, 0x74, 0xFF, 0xF0, 0x31, 0xBD,
-0xE5, 0x73, 0x4D, 0xFF, 0x91, 0xDD, 0xEF, 0xF0,
-0xE5, 0x70, 0x11, 0x48, 0xE0, 0x54, 0x03, 0xF5,
-0x74, 0x74, 0x46, 0x25, 0x70, 0x12, 0xC7, 0x79,
-0xE5, 0x74, 0xF0, 0xE5, 0x72, 0x65, 0x75, 0x70,
-0x22, 0x75, 0xF0, 0x12, 0xE5, 0x70, 0xF1, 0xB3,
-0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x0B, 0xE5,
-0x73, 0x70, 0x07, 0xE5, 0x72, 0x44, 0x80, 0xFD,
-0x80, 0x4A, 0x31, 0xBD, 0x7D, 0x07, 0xAF, 0x70,
-0x02, 0xB7, 0x4E, 0xE5, 0x72, 0xC3, 0x95, 0x75,
-0x50, 0x34, 0xAB, 0x70, 0xAD, 0x75, 0xAF, 0x72,
-0x12, 0x72, 0x7F, 0xAD, 0x07, 0xE5, 0x72, 0xC3,
-0x94, 0x0C, 0x40, 0x28, 0x75, 0xF0, 0x12, 0xE5,
-0x70, 0xF1, 0xB3, 0xFE, 0xC4, 0x13, 0x54, 0x07,
-0x30, 0xE0, 0x19, 0xE5, 0x71, 0x60, 0x15, 0xE5,
-0x73, 0x70, 0x11, 0xE5, 0x72, 0x44, 0x80, 0xFD,
-0x31, 0xB1, 0xEF, 0xF0, 0x80, 0x06, 0x91, 0xDD,
-0xE5, 0x75, 0xF0, 0xFD, 0x90, 0x92, 0x80, 0xE5,
-0x74, 0xF0, 0xAB, 0x71, 0xAF, 0x70, 0x02, 0x75,
-0x80, 0x74, 0x1E, 0x25, 0x70, 0xF5, 0x82, 0xE4,
-0x34, 0x96, 0xF5, 0x83, 0x22, 0xE5, 0x72, 0x25,
-0xE0, 0x24, 0x75, 0xF5, 0x82, 0xE4, 0x34, 0x81,
-0xF5, 0x83, 0xE4, 0x93, 0xFE, 0x74, 0x01, 0x93,
-0xFF, 0xE5, 0x70, 0x25, 0xE0, 0x24, 0x75, 0xF5,
-0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83, 0xEE, 0xF0,
-0xA3, 0xEF, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x7B, 0x12, 0xDD,
-0x62, 0x12, 0xD1, 0x46, 0x90, 0x96, 0x86, 0xF0,
-0xE4, 0x90, 0x96, 0x83, 0xF0, 0x90, 0x96, 0x7B,
-0x12, 0xAD, 0x9F, 0x90, 0x96, 0x7E, 0xF0, 0xEF,
-0x54, 0x07, 0x90, 0x96, 0x80, 0xF0, 0x90, 0x96,
-0x7B, 0xE0, 0x71, 0xEF, 0xE0, 0x90, 0x96, 0x81,
-0xF0, 0xF1, 0xBB, 0x54, 0x7F, 0x90, 0x96, 0x84,
-0xF0, 0x90, 0x96, 0x7B, 0xE0, 0xF1, 0xC7, 0xE0,
-0x90, 0x96, 0x85, 0xF0, 0xED, 0x54, 0x7F, 0x90,
-0x96, 0x7F, 0xF0, 0xEB, 0x70, 0x20, 0x90, 0x89,
-0x3D, 0x91, 0xB6, 0xFF, 0x12, 0xDC, 0xF8, 0xFD,
-0x90, 0x89, 0x40, 0x91, 0xC7, 0x2D, 0xFF, 0xE4,
-0x35, 0xF0, 0xC3, 0x13, 0xFE, 0xEF, 0x13, 0xFF,
-0x90, 0x96, 0x7B, 0xE0, 0x31, 0xD3, 0x90, 0x96,
-0x84, 0xE0, 0xFF, 0x90, 0x96, 0x7F, 0xE0, 0xFE,
-0xD3, 0x9F, 0x40, 0x0C, 0x90, 0x96, 0x7C, 0xE0,
-0x54, 0x80, 0xFD, 0xEF, 0x4D, 0xF0, 0x80, 0x0F,
-0x90, 0x96, 0x85, 0xE0, 0xFF, 0xEE, 0xC3, 0x9F,
-0x50, 0x05, 0x90, 0x96, 0x7C, 0xEF, 0xF0, 0x90,
-0x96, 0x7C, 0xE0, 0xFE, 0x54, 0x7F, 0x90, 0x96,
-0x7F, 0xF0, 0xEE, 0x54, 0x80, 0x90, 0x96, 0x82,
-0xF0, 0x90, 0x96, 0x7D, 0xE0, 0x70, 0x24, 0xA3,
-0x91, 0xD2, 0xC0, 0x83, 0xC0, 0x82, 0xE0, 0xFF,
-0x90, 0x96, 0x80, 0x71, 0x3F, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0xD0, 0x82, 0xD0,
-0x83, 0xF0, 0x90, 0x96, 0x81, 0xE0, 0x54, 0x7F,
-0xF0, 0x80, 0x40, 0x90, 0x96, 0x7E, 0x91, 0xD2,
-0xC0, 0x83, 0xC0, 0x82, 0xE0, 0xFF, 0x90, 0x96,
-0x80, 0x71, 0x3F, 0x80, 0x02, 0xC3, 0x33, 0xD8,
-0xFC, 0x4F, 0xD0, 0x82, 0xD0, 0x83, 0xF0, 0x90,
-0x96, 0x7B, 0xE0, 0x71, 0xEF, 0xE0, 0x54, 0x07,
-0xFF, 0x90, 0x96, 0x81, 0xF0, 0x90, 0x89, 0x46,
-0x91, 0xB6, 0xF5, 0x82, 0x91, 0xCC, 0x33, 0x33,
-0x33, 0x54, 0xF8, 0x4F, 0x90, 0x96, 0x81, 0xF0,
-0x44, 0x80, 0xF0, 0x90, 0x96, 0x7C, 0x91, 0xAE,
-0x11, 0xDE, 0xEF, 0xF0, 0xEE, 0x70, 0x05, 0x90,
-0x01, 0xC8, 0xEF, 0xF0, 0x90, 0x96, 0x81, 0x91,
-0xAE, 0x71, 0xEF, 0xEF, 0xF0, 0xEE, 0x11, 0x48,
-0xE0, 0x54, 0xFC, 0xFF, 0x90, 0x96, 0x86, 0xE0,
-0x54, 0x03, 0x4F, 0xFE, 0x90, 0x96, 0x7B, 0xE0,
-0xFF, 0x11, 0x48, 0xEE, 0xF0, 0x7D, 0x01, 0x12,
-0x61, 0xF7, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7F,
-0x61, 0x12, 0x7B, 0x41, 0x90, 0x96, 0xC5, 0xE0,
-0xFE, 0x74, 0x01, 0xA8, 0x06, 0x08, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96,
-0xC6, 0xED, 0xF0, 0x90, 0x96, 0xC5, 0xEF, 0xF0,
-0xD3, 0x94, 0x07, 0x50, 0x42, 0x7F, 0x47, 0x71,
-0x39, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4,
-0x5F, 0xFD, 0x7F, 0x47, 0x12, 0x7B, 0x2E, 0x7F,
-0x46, 0x71, 0x39, 0x80, 0x02, 0xC3, 0x33, 0xD8,
-0xFC, 0x4F, 0xFD, 0x7F, 0x46, 0x91, 0xA6, 0x60,
-0x0D, 0x7F, 0x45, 0x71, 0x39, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0x4F, 0x80, 0x0C, 0x7F, 0x45,
-0x71, 0x39, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xF4, 0x5F, 0xFD, 0x7F, 0x45, 0x80, 0x46, 0x90,
-0x96, 0xC5, 0xE0, 0x24, 0xF8, 0xF0, 0x7F, 0x63,
-0x71, 0x39, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xF4, 0x5F, 0xFD, 0x7F, 0x63, 0x12, 0x7B, 0x2E,
-0x7F, 0x62, 0x71, 0x39, 0x80, 0x02, 0xC3, 0x33,
-0xD8, 0xFC, 0x4F, 0xFD, 0x7F, 0x62, 0x91, 0xA6,
-0x60, 0x0E, 0x71, 0x37, 0x80, 0x02, 0xC3, 0x33,
-0xD8, 0xFC, 0x4F, 0xFD, 0x7F, 0x61, 0x80, 0x0D,
-0x71, 0x37, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xF4, 0x5F, 0xFD, 0x7F, 0x61, 0x12, 0x7B, 0x2E,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE5, 0x62, 0xC4,
-0x54, 0xF0, 0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34,
-0x81, 0xF5, 0x83, 0x22, 0xAD, 0x07, 0x90, 0x93,
-0x59, 0xE0, 0x75, 0xF0, 0x20, 0xA4, 0xFF, 0x90,
-0x96, 0x99, 0xE5, 0xF0, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x93, 0x5A, 0xE0, 0x75, 0xF0, 0x08, 0xA4,
-0xAE, 0xF0, 0x90, 0x96, 0x9B, 0xF0, 0xEE, 0xA3,
-0xF0, 0x91, 0x9E, 0x90, 0x96, 0x9D, 0xF0, 0xEE,
-0xA3, 0xF0, 0xED, 0x64, 0x01, 0x60, 0x67, 0x90,
-0x93, 0x57, 0xE0, 0xFE, 0x12, 0x8F, 0xF1, 0x30,
-0xE0, 0x5C, 0xEE, 0x12, 0xA6, 0xA1, 0x20, 0xE0,
-0x02, 0x7D, 0x01, 0x91, 0x97, 0xFE, 0x54, 0x0F,
-0xFF, 0xEE, 0xC4, 0x13, 0x13, 0x54, 0x01, 0xFD,
-0x91, 0x97, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0,
-0x25, 0xA3, 0xE0, 0x30, 0xE0, 0x10, 0x90, 0x96,
-0x9E, 0xE0, 0x90, 0x92, 0x20, 0xF0, 0x90, 0x96,
-0x9D, 0x12, 0xBD, 0xC6, 0x80, 0x10, 0x91, 0x9E,
-0xFF, 0x12, 0x7C, 0x6A, 0x12, 0xA6, 0x9C, 0x20,
-0xE0, 0x02, 0x7D, 0x01, 0x71, 0x47, 0x90, 0x93,
-0x57, 0xE0, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x0E,
-0x90, 0x96, 0x9C, 0xE0, 0x90, 0x92, 0x20, 0xF0,
-0x90, 0x96, 0x9B, 0x12, 0xBD, 0xC6, 0x22, 0x71,
-0x47, 0x90, 0x93, 0x57, 0xE0, 0x22, 0x90, 0x96,
-0x99, 0xE0, 0xFE, 0xA3, 0xE0, 0x22, 0x12, 0x7B,
-0x2E, 0x90, 0x96, 0xC6, 0xE0, 0x22, 0xE0, 0xFF,
-0x90, 0x96, 0x7B, 0xE0, 0xFE, 0x22, 0x12, 0x86,
-0x6D, 0x90, 0x96, 0x7F, 0xE0, 0x22, 0xE0, 0x90,
-0x92, 0x5E, 0xF0, 0xA3, 0x74, 0x02, 0x22, 0x12,
-0x86, 0x6D, 0x8F, 0x82, 0x75, 0x83, 0x00, 0x02,
-0x02, 0x1F, 0xE0, 0x24, 0x6F, 0xF5, 0x82, 0xE4,
-0x34, 0x8D, 0xF5, 0x83, 0x22, 0x74, 0xC6, 0x25,
-0x70, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
-0x22, 0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90, 0x89,
-0x52, 0x12, 0x04, 0x6E, 0xE0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x7F, 0x8F, 0x12,
-0x7B, 0x41, 0xEF, 0x20, 0xE6, 0x02, 0xC1, 0x1B,
-0x90, 0x00, 0x8C, 0xE0, 0x90, 0x96, 0xBB, 0xF0,
-0x7F, 0x8D, 0x12, 0x7B, 0x41, 0x90, 0x96, 0xBC,
-0xEF, 0xF0, 0x90, 0x00, 0x8E, 0xE0, 0x90, 0x96,
-0xBD, 0xF0, 0x90, 0x96, 0xBC, 0xE0, 0x24, 0xFC,
-0x60, 0x10, 0x24, 0x03, 0x60, 0x02, 0xC1, 0x0B,
-0x90, 0x96, 0xBB, 0xE0, 0xFF, 0x12, 0xCF, 0xF0,
-0xC1, 0x0B, 0x90, 0x96, 0xBB, 0xE0, 0x24, 0xD6,
-0x12, 0xC6, 0x43, 0xFB, 0xE4, 0xFD, 0xFF, 0xD1,
-0x4D, 0x75, 0xF0, 0x12, 0x91, 0xEE, 0x13, 0x13,
-0x54, 0x03, 0xFB, 0x0D, 0xE4, 0xFF, 0xD1, 0x4D,
-0x75, 0xF0, 0x12, 0x91, 0xEE, 0x12, 0x8F, 0xF1,
-0xFB, 0x0D, 0xE4, 0xFF, 0xD1, 0x4D, 0x75, 0xF0,
-0x12, 0x91, 0xEE, 0xC4, 0x54, 0x03, 0xFB, 0x0D,
-0xE4, 0xFF, 0xD1, 0x4D, 0x75, 0xF0, 0x12, 0xF1,
-0xBF, 0xFB, 0xE4, 0xFD, 0x0F, 0xD1, 0x4D, 0xF1,
-0xC7, 0xD1, 0x4A, 0x75, 0xF0, 0x12, 0xF1, 0xB3,
-0xC4, 0x13, 0x54, 0x01, 0xFB, 0x0D, 0x7F, 0x01,
-0xD1, 0x4D, 0x75, 0xF0, 0x12, 0xF1, 0xB3, 0x54,
-0x1F, 0xD1, 0x4B, 0xF1, 0xDC, 0xE0, 0xFB, 0xE4,
-0xFD, 0x0F, 0xD1, 0x4D, 0x75, 0xF0, 0x08, 0xA4,
+0x86, 0x54, 0x90, 0x88, 0x81, 0x12, 0x04, 0x31,
+0x90, 0x88, 0x32, 0xE0, 0x54, 0x7F, 0xF0, 0xA3,
+0xE0, 0x30, 0xE0, 0x0F, 0x12, 0xAF, 0xA9, 0x90,
+0x92, 0x98, 0x74, 0x05, 0xF0, 0x12, 0x6E, 0x2F,
+0x12, 0xD7, 0x7E, 0x90, 0x88, 0x32, 0x12, 0xAE,
+0x23, 0x30, 0xE0, 0x0D, 0x90, 0x01, 0x3B, 0xE0,
+0x30, 0xE4, 0x06, 0x12, 0xAD, 0xB2, 0x12, 0xE0,
+0xAB, 0x12, 0xBB, 0x9F, 0xBF, 0x03, 0x14, 0x90,
+0x93, 0x4B, 0xE0, 0xB4, 0x01, 0x0D, 0x90, 0x01,
+0xB8, 0xE0, 0x04, 0xF0, 0x90, 0x05, 0x21, 0xE0,
+0x44, 0x80, 0xF0, 0x90, 0x8A, 0xE5, 0x51, 0x5F,
+0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x93, 0x2A,
+0xE0, 0x30, 0xE0, 0x04, 0xF1, 0x8E, 0xF1, 0xC7,
+0x90, 0x86, 0xB3, 0xE0, 0xB4, 0x01, 0x11, 0x12,
+0xAD, 0x35, 0x20, 0xE0, 0x0B, 0xEF, 0xC4, 0x13,
+0x54, 0x07, 0x30, 0xE0, 0x03, 0x12, 0xE0, 0x0C,
+0x22, 0x90, 0x94, 0xAF, 0xE0, 0xC4, 0x13, 0x13,
+0x13, 0x54, 0x01, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x7F, 0x8F, 0x12, 0x7B, 0x41,
+0xEF, 0x20, 0xE6, 0x02, 0xC1, 0x6B, 0x90, 0x00,
+0x8C, 0xE0, 0x90, 0x96, 0xF5, 0xF0, 0x7F, 0x8D,
+0x12, 0x7B, 0x41, 0x90, 0x96, 0xF6, 0xEF, 0xF0,
+0x90, 0x00, 0x8E, 0xE0, 0x90, 0x96, 0xF7, 0xF0,
+0x90, 0x96, 0xF6, 0xE0, 0x24, 0xFC, 0x60, 0x10,
+0x24, 0x03, 0x60, 0x02, 0xC1, 0x5B, 0x90, 0x96,
+0xF5, 0xE0, 0xFF, 0x12, 0xD5, 0x8E, 0xC1, 0x5B,
+0x90, 0x96, 0xF5, 0xE0, 0x24, 0xD6, 0x12, 0x87,
+0xC6, 0xFB, 0xE4, 0xFD, 0xFF, 0xD1, 0x9D, 0x75,
+0xF0, 0x12, 0x12, 0x87, 0xBA, 0x13, 0x13, 0x54,
+0x03, 0xFB, 0x0D, 0xE4, 0xFF, 0xD1, 0x9D, 0x75,
+0xF0, 0x12, 0x90, 0x89, 0x52, 0x12, 0x04, 0x6E,
+0xB1, 0x34, 0xFB, 0x0D, 0xE4, 0xFF, 0xD1, 0x9D,
+0x75, 0xF0, 0x12, 0x12, 0x87, 0xBA, 0xC4, 0x54,
+0x03, 0xFB, 0x0D, 0xE4, 0xFF, 0xD1, 0x9D, 0x75,
+0xF0, 0x12, 0x12, 0xCE, 0x70, 0xFB, 0xE4, 0xFD,
+0x0F, 0xD1, 0x9D, 0x12, 0xCE, 0x9F, 0xD1, 0x9A,
+0x75, 0xF0, 0x12, 0x12, 0xB6, 0x6C, 0xC4, 0x13,
+0x54, 0x01, 0xFB, 0x0D, 0x7F, 0x01, 0xD1, 0x9D,
+0x75, 0xF0, 0x12, 0x12, 0xB6, 0x6C, 0x54, 0x1F,
+0xD1, 0x9B, 0x12, 0xCC, 0xD1, 0xE0, 0xFB, 0xE4,
+0xFD, 0x0F, 0xD1, 0x9D, 0x75, 0xF0, 0x08, 0xA4,
 0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xD1,
-0x48, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x02, 0xF5,
-0x82, 0xE4, 0x34, 0x82, 0xD1, 0x48, 0x75, 0xF0,
+0x98, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x02, 0xF5,
+0x82, 0xE4, 0x34, 0x82, 0xD1, 0x98, 0x75, 0xF0,
 0x08, 0xA4, 0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34,
-0x82, 0xD1, 0x48, 0x75, 0xF0, 0x08, 0xA4, 0x24,
+0x82, 0xD1, 0x98, 0x75, 0xF0, 0x08, 0xA4, 0x24,
 0x04, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83,
-0xE0, 0xFB, 0xE4, 0xFD, 0x0F, 0xD1, 0x4D, 0x75,
+0xE0, 0xFB, 0xE4, 0xFD, 0x0F, 0xD1, 0x9D, 0x75,
 0xF0, 0x08, 0xA4, 0x24, 0x05, 0xF5, 0x82, 0xE4,
-0x34, 0x82, 0xD1, 0x48, 0x75, 0xF0, 0x08, 0xA4,
+0x34, 0x82, 0xD1, 0x98, 0x75, 0xF0, 0x08, 0xA4,
 0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xD1,
-0x48, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x07, 0xF5,
+0x98, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x07, 0xF5,
 0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0xE0, 0xFB,
-0x0D, 0xD1, 0x20, 0x7F, 0x8F, 0x12, 0x7B, 0x41,
+0x0D, 0xD1, 0x70, 0x7F, 0x8F, 0x12, 0x7B, 0x41,
 0xEF, 0x30, 0xE0, 0x07, 0xE4, 0xFD, 0x7F, 0x8D,
 0x12, 0x7B, 0x2E, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
 0xEF, 0x70, 0x04, 0x74, 0xF0, 0x80, 0x16, 0xEF,
@@ -739,2315 +494,2659 @@ u8 array_mp_8723d_fw_ap[] = {
 0xB4, 0x02, 0x04, 0x74, 0xF8, 0x80, 0x06, 0xEF,
 0xB4, 0x03, 0x0C, 0x74, 0xFC, 0x2D, 0xF5, 0x82,
 0xE4, 0x34, 0x02, 0xF5, 0x83, 0xEB, 0xF0, 0x22,
-0xF5, 0x83, 0xE0, 0xFB, 0x0D, 0xD1, 0x20, 0x90,
-0x96, 0xBB, 0xE0, 0x22, 0x90, 0x96, 0x87, 0x12,
-0x86, 0x76, 0x90, 0x96, 0x87, 0x12, 0x8A, 0xC9,
-0x54, 0x7F, 0xFD, 0x12, 0x98, 0xAC, 0xFE, 0x54,
-0x1F, 0x90, 0x96, 0x8B, 0xF0, 0xEE, 0x54, 0x80,
-0x12, 0x8F, 0xF1, 0x90, 0x96, 0x8A, 0x12, 0x87,
-0xE9, 0xFE, 0x54, 0x03, 0xFC, 0xEE, 0x54, 0x30,
-0xC4, 0x54, 0x0F, 0x90, 0x96, 0x8D, 0x12, 0x87,
-0xE9, 0xFE, 0x54, 0x40, 0xC4, 0x13, 0x13, 0x54,
-0x03, 0x90, 0x96, 0x8C, 0xF0, 0xEE, 0x54, 0x80,
-0x12, 0x8F, 0xF1, 0xFF, 0x12, 0x87, 0xEA, 0xFB,
-0x54, 0x08, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x90,
-0x96, 0x8F, 0xF0, 0xFA, 0xEB, 0x54, 0x04, 0x13,
-0x13, 0x54, 0x3F, 0xA3, 0xF0, 0xEF, 0x54, 0x01,
-0xC4, 0x33, 0x33, 0x33, 0x54, 0x80, 0x91, 0xE9,
-0x54, 0x7F, 0x4F, 0xF0, 0x90, 0x96, 0x8C, 0xE0,
-0x54, 0x01, 0xC4, 0x33, 0x33, 0x54, 0xC0, 0x91,
-0xE9, 0x54, 0xBF, 0x4F, 0xF0, 0xEA, 0x70, 0x0D,
-0xEC, 0x54, 0x03, 0x25, 0xE0, 0x25, 0xE0, 0x91,
-0xE9, 0x54, 0xF3, 0x4F, 0xF0, 0x90, 0x96, 0x8B,
-0xE0, 0x54, 0x1F, 0xF1, 0xAE, 0x54, 0xE0, 0x4F,
-0xF0, 0xEC, 0x54, 0x03, 0x91, 0xE9, 0x54, 0xFC,
-0x4F, 0xF0, 0x90, 0x96, 0x8A, 0xE0, 0x54, 0x01,
-0xC4, 0x33, 0x54, 0xE0, 0xF1, 0xAE, 0x54, 0xDF,
-0x4F, 0xF0, 0x90, 0x96, 0x8D, 0xE0, 0x54, 0x03,
-0xC4, 0x54, 0xF0, 0x91, 0xE9, 0x54, 0xCF, 0x4F,
-0xF1, 0xD0, 0xE0, 0x54, 0xFB, 0xF1, 0xD0, 0xC0,
-0x83, 0xC0, 0x82, 0xE0, 0xFF, 0x90, 0x96, 0x90,
-0xE0, 0x12, 0xDD, 0x94, 0xD0, 0x82, 0xD0, 0x83,
-0xF0, 0x90, 0x93, 0x52, 0xE0, 0x60, 0x35, 0x90,
-0x96, 0x87, 0x12, 0x86, 0x6D, 0xE9, 0x24, 0x03,
-0xF9, 0xE4, 0x3A, 0xFA, 0x12, 0x02, 0x06, 0x54,
-0x1F, 0x12, 0x02, 0x4C, 0x90, 0x96, 0x8E, 0x74,
-0x01, 0xF0, 0x90, 0x96, 0x8E, 0xE0, 0xFF, 0xC3,
-0x94, 0x04, 0x50, 0x10, 0xEF, 0x12, 0xDC, 0xCC,
-0xE4, 0x12, 0x02, 0x5E, 0x90, 0x96, 0x8E, 0xE0,
-0x04, 0xF0, 0x80, 0xE6, 0x90, 0x93, 0x50, 0xE0,
-0x54, 0x07, 0xFF, 0xBF, 0x05, 0x0A, 0xEC, 0xB4,
-0x01, 0x06, 0x90, 0x93, 0x55, 0x74, 0x01, 0xF0,
-0xE4, 0x90, 0x96, 0x8E, 0xF0, 0x90, 0x96, 0x8E,
-0xE0, 0xFC, 0x12, 0xDC, 0xCC, 0x12, 0x02, 0x1F,
-0xFF, 0xED, 0xF1, 0xDC, 0x12, 0xB5, 0xDC, 0xEF,
-0xF0, 0x90, 0x96, 0x8E, 0xE0, 0x04, 0xF0, 0xE0,
-0xB4, 0x04, 0xE2, 0xAF, 0x05, 0x90, 0x8A, 0xFF,
-0x12, 0x9E, 0x75, 0x02, 0x04, 0x7E, 0xFF, 0x75,
-0xF0, 0x12, 0xED, 0x90, 0x89, 0x51, 0x12, 0x04,
-0x6E, 0xE0, 0x22, 0x75, 0xF0, 0x12, 0xEF, 0x90,
-0x89, 0x4F, 0x12, 0x04, 0x6E, 0xE0, 0x22, 0x75,
-0xF0, 0x12, 0x90, 0x89, 0x50, 0x02, 0x04, 0x6E,
-0xF0, 0x74, 0xC6, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
-0x8D, 0xF5, 0x83, 0x22, 0x75, 0xF0, 0x08, 0xA4,
-0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5,
-0x83, 0x22, 0xE0, 0x54, 0x03, 0x90, 0x92, 0x80,
-0xF0, 0x7B, 0x01, 0xAF, 0x0E, 0x02, 0x75, 0x80,
-0x81, 0xF6, 0x12, 0x9F, 0xE9, 0x12, 0x02, 0x06,
-0x30, 0xE0, 0x13, 0x71, 0x7B, 0x90, 0x86, 0xB3,
-0xE0, 0x64, 0x01, 0x70, 0x28, 0x90, 0xFE, 0x10,
-0xE0, 0x44, 0x04, 0xF0, 0x80, 0x1F, 0x90, 0x93,
-0x25, 0xE0, 0x60, 0x16, 0x7D, 0x10, 0xE4, 0xFF,
-0x12, 0x7C, 0x3B, 0x90, 0x01, 0x3C, 0xE0, 0x30,
-0xE4, 0x03, 0x74, 0x10, 0xF0, 0x90, 0x01, 0x63,
-0xE4, 0xF0, 0x12, 0xD4, 0xC5, 0x11, 0xA6, 0x90,
-0x93, 0x04, 0x12, 0x87, 0xE9, 0x90, 0x93, 0x05,
-0xF0, 0x90, 0x93, 0x04, 0xE0, 0x54, 0x01, 0x90,
-0x93, 0x11, 0xF0, 0x90, 0x93, 0x04, 0xE0, 0x54,
-0x02, 0x90, 0x93, 0x12, 0xF0, 0x90, 0x93, 0x04,
-0xE0, 0x54, 0x04, 0x90, 0x93, 0x13, 0xF0, 0x90,
-0x93, 0x04, 0xE0, 0x54, 0x08, 0x90, 0x93, 0x14,
-0xF0, 0x90, 0x93, 0x04, 0xE0, 0x54, 0x10, 0x90,
-0x93, 0x15, 0xF0, 0x90, 0x93, 0x05, 0xE0, 0x54,
-0x01, 0x90, 0x93, 0x16, 0xF0, 0x90, 0x93, 0x05,
-0xE0, 0x54, 0x02, 0x90, 0x93, 0x17, 0xF0, 0x90,
-0x93, 0x05, 0xE0, 0x54, 0x04, 0x90, 0x93, 0x18,
-0xF0, 0x90, 0x93, 0x05, 0xE0, 0x54, 0x08, 0x90,
-0x93, 0x19, 0xF0, 0x90, 0x93, 0x05, 0xE0, 0x54,
-0x10, 0x90, 0x93, 0x1A, 0xF0, 0x22, 0x90, 0x94,
-0xB6, 0x12, 0x86, 0x6D, 0x90, 0x00, 0x01, 0x02,
-0x02, 0x1F, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0xF1, 0xE9, 0x12, 0xDD, 0x7D, 0x90, 0x88,
-0x9D, 0x12, 0xDC, 0xB2, 0xF0, 0xFC, 0x12, 0x02,
-0x06, 0xFD, 0x54, 0x04, 0x13, 0x13, 0x54, 0x3F,
-0xFF, 0x90, 0x94, 0xA2, 0xE0, 0x54, 0xFE, 0x4F,
-0xF0, 0xED, 0x54, 0x08, 0xFF, 0xEC, 0x54, 0xF7,
-0x4F, 0xFF, 0x90, 0x88, 0x9D, 0xF0, 0x12, 0x02,
-0x06, 0x12, 0xDD, 0x3D, 0x90, 0x88, 0x9D, 0x12,
-0xDD, 0x6B, 0x4E, 0x12, 0xA7, 0xA7, 0x54, 0x40,
-0xFD, 0xEF, 0x54, 0xBF, 0x4D, 0xFF, 0x90, 0x88,
-0x9D, 0xF0, 0xEE, 0x54, 0x80, 0xFE, 0xEF, 0x54,
-0x7F, 0x4E, 0xF0, 0x90, 0x94, 0xB6, 0x12, 0x86,
-0x6D, 0xE9, 0x24, 0x01, 0xF9, 0xE4, 0x3A, 0x8B,
+0xF5, 0x83, 0xE0, 0xFB, 0x0D, 0xD1, 0x70, 0x90,
+0x96, 0xF5, 0xE0, 0x22, 0xE4, 0xFD, 0xFF, 0x12,
+0x04, 0x7E, 0x90, 0x86, 0x0C, 0xE0, 0xFE, 0xA3,
+0xE0, 0xAA, 0x06, 0xF9, 0x02, 0x04, 0x7A, 0x90,
+0x93, 0x2A, 0xE0, 0x30, 0xE0, 0x56, 0xC4, 0x54,
+0x0F, 0x20, 0xE0, 0x17, 0xF1, 0x8E, 0x90, 0x8A,
+0xF9, 0x51, 0x5F, 0xD1, 0xA4, 0xF1, 0xD6, 0x30,
+0xE0, 0x07, 0x90, 0x8A, 0x89, 0x51, 0x5F, 0xF1,
+0xCF, 0xE1, 0xC7, 0x90, 0x93, 0x2A, 0xE0, 0xC4,
+0x54, 0x0F, 0x30, 0xE0, 0x2F, 0xE4, 0x90, 0x92,
+0x20, 0xF0, 0x90, 0x93, 0x2D, 0xF1, 0x96, 0x90,
+0x93, 0x2A, 0xE0, 0x54, 0xEF, 0xF0, 0xE0, 0xC3,
+0x13, 0x30, 0xE0, 0x0C, 0x90, 0x8A, 0x89, 0x51,
+0x5F, 0x7D, 0x04, 0x7F, 0x01, 0x02, 0x04, 0x7E,
+0x90, 0x8A, 0xF9, 0x51, 0x5F, 0x7D, 0x31, 0x12,
+0xDB, 0x70, 0xD1, 0xAD, 0x22, 0xE4, 0xFB, 0xFA,
+0xFD, 0x7F, 0x01, 0x12, 0x85, 0x4E, 0x90, 0x95,
+0x3F, 0xEF, 0xF0, 0x60, 0xF0, 0x90, 0x86, 0xAF,
+0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0, 0x60, 0xE5,
+0xC2, 0xAF, 0xEF, 0x30, 0xE0, 0x0F, 0x90, 0x86,
+0xAF, 0xE0, 0x54, 0xFE, 0xF0, 0xE4, 0xFF, 0x12,
+0xB9, 0xAD, 0x12, 0xCE, 0xE5, 0xF1, 0x86, 0xE0,
+0x30, 0xE1, 0x08, 0x54, 0xFD, 0xF0, 0x90, 0x86,
+0x08, 0xD1, 0xAD, 0xF1, 0x86, 0xE0, 0x30, 0xE2,
+0x08, 0x54, 0xFB, 0xF0, 0x90, 0x86, 0x0A, 0xD1,
+0xAD, 0xF1, 0x86, 0xE0, 0xFF, 0x30, 0xE5, 0x0C,
+0x54, 0xDF, 0xF0, 0x12, 0xC4, 0x32, 0xBF, 0x01,
+0x03, 0x12, 0x98, 0xC2, 0xF1, 0x86, 0xE0, 0x30,
+0xE6, 0x08, 0x54, 0xBF, 0xF0, 0x90, 0x8A, 0x7D,
+0xD1, 0xAD, 0xD2, 0xAF, 0x80, 0x9F, 0xD2, 0xAF,
+0xC2, 0xAF, 0x90, 0x86, 0xAF, 0x22, 0xE4, 0x90,
+0x92, 0x20, 0xF0, 0x90, 0x93, 0x2C, 0xE0, 0x90,
+0x92, 0x21, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54,
+0x7E, 0x01, 0x02, 0x66, 0x33, 0x90, 0x93, 0x2A,
+0xE0, 0x30, 0xE0, 0x1A, 0x90, 0x01, 0x57, 0xE4,
+0xF0, 0x90, 0x8A, 0xF9, 0x51, 0x5F, 0xD1, 0xA4,
+0xF1, 0xD6, 0x30, 0xE0, 0x07, 0x90, 0x8A, 0x89,
+0x51, 0x5F, 0xF1, 0xCF, 0xF1, 0xC7, 0x22, 0x90,
+0x93, 0x2A, 0xE0, 0x44, 0x10, 0xF0, 0x22, 0x7D,
+0x0C, 0x7F, 0x01, 0x02, 0x04, 0x7E, 0x90, 0x93,
+0x2A, 0xE0, 0xC3, 0x13, 0x22, 0x8C, 0x83, 0xE4,
+0xFD, 0x02, 0x04, 0x7E, 0x90, 0x88, 0x9D, 0xE0,
+0xC4, 0x54, 0x0F, 0x22, 0x90, 0x88, 0xA1, 0xE0,
+0xC4, 0x13, 0x13, 0x54, 0x03, 0x22, 0xA1, 0x3C,
+0xF0, 0x90, 0x88, 0x9D, 0xE0, 0xC4, 0x13, 0x54,
+0x07, 0x22, 0x90, 0x94, 0xBD, 0x12, 0x86, 0x76,
+0x90, 0x93, 0x4D, 0xE0, 0x70, 0x12, 0x11, 0xD3,
+0x12, 0x02, 0x06, 0x13, 0x13, 0x54, 0x3F, 0x30,
+0xE0, 0x06, 0x90, 0x93, 0x53, 0x74, 0x01, 0xF0,
+0x90, 0x93, 0x4F, 0xE0, 0x70, 0x12, 0x11, 0xD3,
+0x12, 0x02, 0x06, 0xC4, 0x54, 0x0F, 0xFF, 0xBF,
+0x05, 0x06, 0x90, 0x93, 0x54, 0x74, 0x01, 0xF0,
+0x11, 0xD3, 0x12, 0x87, 0x87, 0xFF, 0x90, 0x94,
+0xC1, 0xF0, 0x12, 0x02, 0x06, 0xC3, 0x13, 0x30,
+0xE0, 0x0B, 0x11, 0xD3, 0x12, 0x87, 0x26, 0x90,
+0x94, 0xC2, 0xF0, 0x80, 0x05, 0x90, 0x94, 0xC2,
+0xEF, 0xF0, 0x90, 0x94, 0xC1, 0xE0, 0x90, 0x94,
+0xC0, 0xF0, 0x90, 0x94, 0xC2, 0xE0, 0xFE, 0x90,
+0x94, 0xC0, 0xE0, 0xFF, 0xD3, 0x9E, 0x50, 0x38,
+0x11, 0xD3, 0x12, 0x02, 0x06, 0x54, 0x01, 0xFD,
+0x12, 0x6E, 0x71, 0x90, 0x94, 0xC0, 0xE0, 0xFF,
+0x12, 0x78, 0x4A, 0xEF, 0x90, 0x94, 0xC0, 0x70,
+0x06, 0xE0, 0xFF, 0x71, 0x8F, 0x80, 0x04, 0xE0,
+0xFF, 0xF1, 0xA8, 0x90, 0x93, 0x54, 0xE0, 0x60,
+0x07, 0x90, 0x94, 0xC0, 0xE0, 0xFF, 0x71, 0x8F,
+0x90, 0x94, 0xC0, 0xE0, 0x04, 0xF0, 0x80, 0xBA,
+0x90, 0x05, 0x5E, 0xE4, 0xF0, 0x90, 0x94, 0xC1,
+0xE0, 0x70, 0x19, 0xFF, 0x12, 0x78, 0x4A, 0xEF,
+0x70, 0x12, 0x12, 0x8E, 0xAA, 0x90, 0x8A, 0xED,
+0x12, 0x8E, 0xAD, 0x12, 0xE0, 0xB2, 0x54, 0xBF,
+0xF0, 0x54, 0x7F, 0xF0, 0x22, 0x90, 0x94, 0xBD,
+0x12, 0x86, 0x76, 0x90, 0x94, 0xBD, 0x02, 0x86,
+0x6D, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x11, 0xCD, 0x12, 0x02, 0x06, 0xFF, 0x54, 0x01,
+0xFE, 0x90, 0x88, 0x9D, 0x12, 0xE0, 0x7E, 0xF0,
+0xFC, 0x12, 0x02, 0x06, 0xFD, 0x54, 0x04, 0x13,
+0x13, 0x54, 0x3F, 0xFF, 0x90, 0x94, 0xA3, 0xE0,
+0x54, 0xFE, 0x4F, 0xF0, 0xED, 0x54, 0x08, 0xFF,
+0xEC, 0x54, 0xF7, 0x4F, 0xFF, 0x90, 0x88, 0x9D,
+0xF0, 0x12, 0x02, 0x06, 0xFE, 0x54, 0x10, 0xFD,
+0xEF, 0x54, 0xEF, 0x71, 0xEA, 0x54, 0x20, 0xFE,
+0xEF, 0x54, 0xDF, 0x4E, 0x12, 0xA8, 0xB3, 0x54,
+0x40, 0xFD, 0xEF, 0x54, 0xBF, 0x71, 0xEA, 0x54,
+0x80, 0xFE, 0xEF, 0x54, 0x7F, 0x4E, 0xF0, 0x11,
+0xD3, 0xE9, 0x24, 0x01, 0xF9, 0xE4, 0x3A, 0x8B,
 0x45, 0xF5, 0x46, 0x89, 0x47, 0x75, 0x48, 0x04,
 0x7B, 0x01, 0x7A, 0x88, 0x79, 0x9E, 0x12, 0x69,
-0xF5, 0x90, 0x94, 0xB6, 0x12, 0x86, 0x6D, 0x12,
-0x87, 0xEA, 0xFF, 0x54, 0x03, 0x90, 0x88, 0x9F,
-0xF0, 0xEF, 0x54, 0x04, 0x13, 0x13, 0x54, 0x01,
-0x25, 0xE0, 0x25, 0xE0, 0xFF, 0x90, 0x94, 0xAE,
-0xE0, 0x54, 0xFB, 0x4F, 0xF0, 0x12, 0x02, 0x06,
-0x20, 0xE0, 0x02, 0x41, 0xB0, 0x90, 0x05, 0x54,
+0xF5, 0x11, 0xD3, 0x12, 0x87, 0x26, 0xFF, 0x54,
+0x03, 0x90, 0x88, 0x9F, 0xF0, 0xEF, 0x54, 0x04,
+0x13, 0x13, 0x54, 0x01, 0x25, 0xE0, 0x25, 0xE0,
+0xFF, 0x90, 0x94, 0xAF, 0xE0, 0x54, 0xFB, 0x4F,
+0xFF, 0x12, 0x87, 0x25, 0xFE, 0x54, 0x08, 0x13,
+0x13, 0x13, 0x54, 0x01, 0xC4, 0x33, 0x33, 0x33,
+0x54, 0x80, 0xFD, 0xEF, 0x54, 0x7F, 0x4D, 0x90,
+0x94, 0xAF, 0xF0, 0x11, 0xD3, 0x12, 0x02, 0x06,
+0x20, 0xE0, 0x02, 0x41, 0xE7, 0x90, 0x05, 0x54,
 0xE0, 0x90, 0x88, 0xAE, 0xF0, 0xE0, 0xC3, 0x13,
 0x90, 0x88, 0xAD, 0xF0, 0x90, 0x88, 0xA0, 0xE0,
-0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x14, 0x11, 0xAC,
-0x90, 0x88, 0x9E, 0xF0, 0x24, 0x0A, 0x90, 0x88,
-0xCF, 0x12, 0x87, 0xE9, 0x90, 0x88, 0x9F, 0xF0,
-0x80, 0x28, 0x11, 0xAC, 0xFF, 0xC3, 0x94, 0x2A,
-0x50, 0x14, 0xEF, 0xC3, 0x94, 0x03, 0x50, 0x07,
-0x90, 0x88, 0x9E, 0x74, 0x03, 0x80, 0x0C, 0x11,
-0xA6, 0x90, 0x88, 0x9E, 0x80, 0x05, 0x90, 0x88,
-0x9E, 0x74, 0x2A, 0xF0, 0x24, 0x0A, 0x90, 0x88,
-0xCF, 0xF0, 0xB1, 0xBD, 0x30, 0xE0, 0x3D, 0x90,
-0x88, 0x9E, 0xE0, 0x75, 0xF0, 0x03, 0x84, 0x90,
-0x88, 0xA6, 0xF0, 0xE0, 0xC3, 0x13, 0xA3, 0xF0,
-0x90, 0x88, 0x9F, 0xE0, 0x75, 0xF0, 0x03, 0x84,
-0x90, 0x88, 0xA8, 0xF0, 0x90, 0x88, 0x9E, 0xE0,
-0xC3, 0x13, 0x90, 0x88, 0xA9, 0xF0, 0x90, 0x88,
-0x9F, 0xE0, 0xC3, 0x13, 0x90, 0x88, 0xAA, 0xF0,
-0x90, 0x01, 0x3E, 0x74, 0x08, 0xF0, 0xFD, 0x7F,
-0x02, 0x12, 0x7C, 0x05, 0xE4, 0x90, 0x88, 0xDD,
-0xF0, 0x90, 0x88, 0x9D, 0xE0, 0xC4, 0x54, 0x0F,
-0x30, 0xE0, 0x18, 0x12, 0xDD, 0x59, 0x30, 0xE0,
-0x0D, 0x90, 0x8A, 0x89, 0x12, 0x8B, 0x46, 0x7D,
-0x04, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x71, 0x3A,
-0x74, 0x11, 0xF0, 0x90, 0x94, 0xA2, 0xE0, 0x30,
-0xE0, 0x31, 0x90, 0x94, 0xAB, 0x74, 0x01, 0xF0,
-0xE4, 0xA3, 0xF0, 0x90, 0x06, 0xC7, 0xE0, 0xFE,
-0x90, 0x06, 0xC6, 0x71, 0x42, 0xFE, 0xE4, 0xFD,
-0x78, 0x10, 0x12, 0xD4, 0x29, 0x90, 0x06, 0xC5,
-0xE0, 0xFE, 0x90, 0x06, 0xC4, 0x71, 0x42, 0xFE,
-0xE4, 0xFD, 0x12, 0x86, 0x54, 0x90, 0x94, 0xA7,
-0x12, 0x04, 0x31, 0x90, 0x94, 0xAE, 0xE0, 0x13,
-0x13, 0x54, 0x3F, 0x30, 0xE0, 0x13, 0xA3, 0xE0,
-0x20, 0xE0, 0x07, 0x54, 0x01, 0x44, 0x64, 0xF0,
-0x80, 0x07, 0x90, 0x94, 0xAF, 0xE0, 0x54, 0xFE,
-0xF0, 0x90, 0x05, 0x58, 0x74, 0x02, 0xF0, 0x90,
-0x88, 0xA5, 0xE0, 0xB4, 0x01, 0x08, 0x90, 0x88,
-0xB0, 0x74, 0x01, 0xF0, 0x80, 0x2B, 0x90, 0x88,
-0xA5, 0xE0, 0xB4, 0x04, 0x08, 0x90, 0x88, 0xB0,
-0x74, 0x04, 0xF0, 0x80, 0x1C, 0x90, 0x88, 0xA5,
-0xE0, 0xB4, 0x06, 0x08, 0x90, 0x88, 0xB0, 0x74,
-0x02, 0xF0, 0x80, 0x0D, 0x90, 0x88, 0xA5, 0xE0,
-0xB4, 0x07, 0x06, 0x90, 0x88, 0xB0, 0x74, 0x05,
-0xF0, 0xE4, 0x90, 0x88, 0xA5, 0xF0, 0x80, 0x3F,
-0x90, 0x8A, 0xF1, 0x12, 0x88, 0xCD, 0x90, 0x89,
-0x04, 0xE0, 0x90, 0x00, 0x40, 0x30, 0xE0, 0x08,
-0xE0, 0x54, 0x0F, 0x44, 0xA0, 0xF0, 0x80, 0x06,
-0xE0, 0x54, 0x0F, 0x44, 0x20, 0xF0, 0x90, 0x94,
-0xB6, 0x12, 0x86, 0x6D, 0x12, 0x87, 0xF4, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x04, 0x7F,
-0x03, 0x80, 0x02, 0x7F, 0x01, 0x12, 0x71, 0x9A,
-0x71, 0x4B, 0x71, 0x3A, 0x74, 0x43, 0xF0, 0x90,
-0x88, 0xA3, 0xE0, 0x54, 0xDF, 0xF0, 0xE4, 0x90,
-0x88, 0xAF, 0xF0, 0x12, 0x8F, 0xED, 0x30, 0xE0,
-0x09, 0x90, 0x88, 0xD0, 0xE0, 0x44, 0x02, 0xF0,
-0x80, 0x12, 0x90, 0x8A, 0x97, 0x12, 0x8B, 0x46,
-0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xD0,
-0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x8A, 0xD9, 0x12,
-0x8B, 0x46, 0x7F, 0x03, 0x12, 0x04, 0x7E, 0x90,
-0x88, 0x9D, 0xE0, 0x20, 0xE0, 0x07, 0x90, 0x88,
-0xA1, 0xE0, 0x54, 0xBF, 0xF0, 0xD0, 0xD0, 0x92,
+0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x0F, 0x12, 0x87,
+0x87, 0x90, 0x88, 0x9E, 0x71, 0xE2, 0x90, 0x88,
+0x9F, 0xEE, 0xF0, 0x80, 0x25, 0x12, 0x87, 0x87,
+0xFF, 0xC3, 0x94, 0x2A, 0x50, 0x15, 0xEF, 0xC3,
+0x94, 0x03, 0x50, 0x07, 0x90, 0x88, 0x9E, 0x74,
+0x03, 0x80, 0x0D, 0x12, 0x87, 0x87, 0x90, 0x88,
+0x9E, 0x80, 0x05, 0x90, 0x88, 0x9E, 0x74, 0x2A,
+0x71, 0xE2, 0x12, 0x8F, 0xEC, 0x30, 0xE0, 0x3D,
+0x90, 0x88, 0x9E, 0xE0, 0x75, 0xF0, 0x03, 0x84,
+0x90, 0x88, 0xA6, 0xF0, 0xE0, 0xC3, 0x13, 0xA3,
+0xF0, 0x90, 0x88, 0x9F, 0xE0, 0x75, 0xF0, 0x03,
+0x84, 0x90, 0x88, 0xA8, 0xF0, 0x90, 0x88, 0x9E,
+0xE0, 0xC3, 0x13, 0x90, 0x88, 0xA9, 0xF0, 0x90,
+0x88, 0x9F, 0xE0, 0xC3, 0x13, 0x90, 0x88, 0xAA,
+0xF0, 0x90, 0x01, 0x3E, 0x74, 0x08, 0xF0, 0xFD,
+0x7F, 0x02, 0x12, 0x7C, 0x05, 0xE4, 0x90, 0x88,
+0xDD, 0xF0, 0x12, 0x8F, 0xE4, 0x30, 0xE0, 0x18,
+0x12, 0xE0, 0x99, 0x30, 0xE0, 0x0D, 0x90, 0x8A,
+0x89, 0x12, 0x8A, 0x5F, 0x7D, 0x04, 0x7F, 0x02,
+0x12, 0x04, 0x7E, 0x71, 0xDA, 0x74, 0x11, 0xF0,
+0x90, 0x94, 0xA3, 0xE0, 0x30, 0xE0, 0x33, 0x90,
+0x94, 0xAC, 0x74, 0x01, 0xF0, 0xE4, 0xA3, 0xF0,
+0x90, 0x06, 0xC7, 0xE0, 0xFE, 0x90, 0x06, 0xC6,
+0x12, 0x9E, 0xF1, 0xFE, 0xE4, 0xFD, 0x78, 0x10,
+0x12, 0xE0, 0x72, 0x90, 0x06, 0xC5, 0xE0, 0xFE,
+0x90, 0x06, 0xC4, 0x12, 0x9E, 0xF1, 0xFE, 0xE4,
+0xFD, 0x12, 0x86, 0x54, 0x90, 0x94, 0xA8, 0x12,
+0x04, 0x31, 0x90, 0x94, 0xAF, 0xE0, 0x13, 0x13,
+0x54, 0x3F, 0x30, 0xE0, 0x13, 0xA3, 0xE0, 0x20,
+0xE0, 0x07, 0x54, 0x01, 0x44, 0x64, 0xF0, 0x80,
+0x07, 0x90, 0x94, 0xB0, 0xE0, 0x54, 0xFE, 0xF0,
+0x90, 0x05, 0x58, 0x74, 0x02, 0xF0, 0x90, 0x88,
+0xA5, 0xE0, 0xB4, 0x01, 0x08, 0x90, 0x88, 0xB0,
+0x74, 0x01, 0xF0, 0x80, 0x2B, 0x90, 0x88, 0xA5,
+0xE0, 0xB4, 0x04, 0x08, 0x90, 0x88, 0xB0, 0x74,
+0x04, 0xF0, 0x80, 0x1C, 0x90, 0x88, 0xA5, 0xE0,
+0xB4, 0x06, 0x08, 0x90, 0x88, 0xB0, 0x74, 0x02,
+0xF0, 0x80, 0x0D, 0x90, 0x88, 0xA5, 0xE0, 0xB4,
+0x07, 0x06, 0x90, 0x88, 0xB0, 0x74, 0x05, 0xF0,
+0xE4, 0x90, 0x88, 0xA5, 0xF0, 0x80, 0x3C, 0x90,
+0x8A, 0xF1, 0x12, 0x8E, 0xAD, 0x90, 0x89, 0x04,
+0xE0, 0x90, 0x00, 0x40, 0x30, 0xE0, 0x08, 0xE0,
+0x54, 0x0F, 0x44, 0xA0, 0xF0, 0x80, 0x06, 0xE0,
+0x54, 0x0F, 0x44, 0x20, 0xF0, 0x11, 0xD3, 0x12,
+0x87, 0x76, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x30,
+0xE0, 0x04, 0x7F, 0x03, 0x80, 0x02, 0x7F, 0x01,
+0x12, 0x71, 0x9A, 0x12, 0xA4, 0x85, 0x71, 0xDA,
+0x74, 0x43, 0xF0, 0x90, 0x88, 0xA3, 0xE0, 0x54,
+0xDF, 0xF0, 0xE4, 0x90, 0x88, 0xAF, 0xF0, 0x90,
+0x88, 0xA0, 0x12, 0x8D, 0x34, 0x30, 0xE0, 0x09,
+0x90, 0x88, 0xD0, 0xE0, 0x44, 0x02, 0xF0, 0x80,
+0x12, 0x90, 0x8A, 0x97, 0x12, 0x8A, 0x5F, 0x7F,
+0x01, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xD0, 0xE0,
+0x54, 0xFD, 0xF0, 0x90, 0x8A, 0xD9, 0x12, 0x8A,
+0x5F, 0x7F, 0x03, 0x12, 0x04, 0x7E, 0x12, 0x8D,
+0x31, 0x30, 0xE0, 0x0E, 0x90, 0x01, 0x36, 0x74,
+0x20, 0xF0, 0xFD, 0x7F, 0x02, 0x12, 0x7C, 0x74,
+0x80, 0x07, 0x7D, 0x20, 0x7F, 0x02, 0x12, 0x7C,
+0x7E, 0x12, 0xDB, 0x01, 0x90, 0x88, 0x9D, 0xE0,
+0x20, 0xE0, 0x07, 0x90, 0x88, 0xA1, 0xE0, 0x54,
+0xBF, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7D,
+0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x96, 0xFB, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
+0x90, 0x8A, 0xF9, 0x12, 0x8A, 0x5F, 0x7D, 0x44,
+0x7F, 0x6F, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0xFD,
+0x12, 0x8E, 0xAD, 0x90, 0x96, 0xFC, 0xE0, 0x90,
+0x96, 0xFB, 0xB4, 0x01, 0x09, 0xE0, 0x71, 0xF4,
+0xE0, 0x44, 0x04, 0xF0, 0x80, 0x07, 0xE0, 0x71,
+0xF4, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x8A, 0xF9,
+0x12, 0x8A, 0x5F, 0xF1, 0xF1, 0xD0, 0xD0, 0x92,
 0xAF, 0x22, 0x90, 0x05, 0x00, 0x74, 0x1C, 0xF0,
-0xA3, 0x22, 0xE0, 0x7C, 0x00, 0x24, 0x00, 0xFF,
-0xEC, 0x3E, 0x22, 0xE4, 0xFB, 0xFD, 0x7F, 0xFF,
-0xEB, 0xB4, 0x57, 0x04, 0x71, 0x70, 0x80, 0x0E,
-0xEF, 0x70, 0x07, 0x90, 0x93, 0x5D, 0xE0, 0x4D,
-0x80, 0x04, 0xF1, 0xBF, 0x71, 0x70, 0x90, 0x05,
-0x22, 0xF0, 0x90, 0x93, 0x01, 0xEB, 0xF0, 0x22,
-0x90, 0x93, 0x5E, 0xE0, 0xFF, 0x90, 0x93, 0x5D,
-0xE0, 0x4F, 0x22, 0x90, 0x01, 0x17, 0xE0, 0xFE,
-0x90, 0x01, 0x16, 0x71, 0x42, 0x90, 0x88, 0x27,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x02, 0x86, 0xE0,
-0x44, 0x04, 0xF0, 0x90, 0x93, 0x03, 0xE0, 0x44,
-0x01, 0xF0, 0x7D, 0x08, 0xE4, 0xFF, 0x12, 0x7C,
-0x74, 0x90, 0x05, 0x52, 0xE0, 0x54, 0x07, 0x04,
-0x90, 0x93, 0x0E, 0x12, 0xA7, 0xAE, 0x90, 0x04,
-0x22, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0x12, 0x02,
-0x06, 0x90, 0x94, 0xD9, 0xF0, 0x11, 0xAC, 0x90,
-0x94, 0xDA, 0xF0, 0x60, 0x0D, 0xB1, 0x3C, 0xF1,
-0xD7, 0x90, 0x94, 0xDA, 0xB1, 0x3C, 0x7B, 0x57,
-0x71, 0x50, 0x90, 0x94, 0xB6, 0x74, 0x20, 0xF0,
-0x90, 0x94, 0xD8, 0x74, 0x03, 0xF0, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x94, 0xB8, 0xF0, 0x90, 0x93,
-0x5D, 0xE0, 0x90, 0x94, 0xB9, 0xF0, 0x90, 0x93,
-0x5E, 0xE0, 0x90, 0x94, 0xBA, 0x71, 0xFF, 0x12,
-0x8B, 0x34, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0xF0,
-0x7B, 0x01, 0x7A, 0x94, 0x79, 0xB6, 0x22, 0x91,
-0x00, 0x7F, 0xEF, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
-0xBF, 0x01, 0x06, 0x90, 0x94, 0xB6, 0xE0, 0xA3,
-0xF0, 0x91, 0x00, 0x7F, 0xEE, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x94, 0xB6,
-0xE0, 0x90, 0x94, 0xB8, 0xF0, 0x91, 0x00, 0x7F,
-0xED, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
-0x08, 0x90, 0x94, 0xB6, 0xE0, 0x90, 0x94, 0xB9,
-0xF0, 0x91, 0x00, 0x7F, 0xEC, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x94, 0xB6,
-0xE0, 0x90, 0x94, 0xBA, 0xF0, 0x91, 0x00, 0x7F,
-0xEB, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
-0x08, 0x90, 0x94, 0xB6, 0xE0, 0x90, 0x94, 0xBB,
-0xF0, 0x90, 0x94, 0xB7, 0xE0, 0xFF, 0xA3, 0xE0,
-0xFD, 0xA3, 0xE0, 0xFB, 0xA3, 0xE0, 0x90, 0x94,
-0xBF, 0xF0, 0x90, 0x94, 0xBB, 0xE0, 0x90, 0x94,
-0xC0, 0xF0, 0x90, 0x94, 0xC1, 0x74, 0x12, 0xF0,
-0x90, 0x94, 0xE3, 0x74, 0x05, 0xF0, 0x90, 0x94,
-0xC3, 0x12, 0xDD, 0x62, 0x90, 0x94, 0xBF, 0xE0,
-0x90, 0x94, 0xC6, 0xF0, 0x90, 0x94, 0xC0, 0xE0,
-0x90, 0x94, 0xC7, 0xF0, 0x7B, 0x01, 0x7A, 0x94,
-0x79, 0xC1, 0x12, 0x8B, 0x34, 0x7F, 0x04, 0x02,
-0x04, 0x7E, 0x7E, 0x00, 0x7F, 0x0B, 0x7D, 0x00,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x4C, 0x12, 0x04,
-0x80, 0x91, 0x00, 0x12, 0xDD, 0x9C, 0xBF, 0x01,
-0x1C, 0x90, 0x94, 0xB6, 0xE0, 0xFE, 0x54, 0x01,
-0x90, 0x93, 0x4C, 0xF0, 0xEE, 0x54, 0x04, 0x90,
-0x93, 0x4E, 0xF0, 0x90, 0x94, 0xB6, 0xE0, 0x54,
-0x08, 0x90, 0x93, 0x4D, 0xF0, 0x91, 0x00, 0x12,
-0xDC, 0xC1, 0x70, 0x35, 0x90, 0x94, 0xB6, 0xE0,
-0x54, 0x07, 0x70, 0x15, 0x7B, 0x01, 0x7A, 0x94,
-0x79, 0xB7, 0x7F, 0xFA, 0x7E, 0x01, 0x12, 0x5F,
-0xA6, 0xBF, 0x01, 0x0F, 0x90, 0x94, 0xB7, 0x80,
-0x03, 0x90, 0x94, 0xB6, 0xE0, 0x54, 0x07, 0x90,
-0x93, 0x50, 0xF0, 0x90, 0x94, 0xB6, 0xE0, 0x54,
-0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90, 0x93, 0x4F,
-0xF0, 0x91, 0x00, 0x7F, 0xFD, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x0E, 0x90, 0x94, 0xB6,
-0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F, 0x90,
-0x93, 0x51, 0xF0, 0x22, 0xE0, 0xFF, 0x90, 0x94,
-0xD9, 0xE0, 0xFD, 0x22, 0xE4, 0x90, 0x96, 0xB8,
-0xF0, 0xA3, 0xF0, 0x90, 0x05, 0x22, 0xE0, 0x90,
-0x96, 0xBA, 0xF0, 0x7B, 0x47, 0xD1, 0x5A, 0x90,
-0x05, 0xF8, 0xE0, 0x70, 0x1A, 0xA3, 0xE0, 0x70,
-0x16, 0xA3, 0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70,
-0x0E, 0x90, 0x96, 0xBA, 0xE0, 0xFD, 0x7B, 0x48,
-0xE4, 0xFF, 0x71, 0x50, 0x7F, 0x01, 0x22, 0xB1,
-0xBD, 0x30, 0xE0, 0x19, 0xD3, 0x90, 0x96, 0xB9,
-0xE0, 0x94, 0x03, 0x90, 0x96, 0xB8, 0xE0, 0x94,
-0x00, 0x40, 0x06, 0xD1, 0x60, 0x7B, 0x5A, 0x80,
-0x17, 0x7F, 0x01, 0x80, 0x1C, 0xD3, 0x90, 0x96,
-0xB9, 0xE0, 0x94, 0xE8, 0x90, 0x96, 0xB8, 0xE0,
-0x94, 0x03, 0x40, 0x0B, 0xD1, 0x60, 0x7B, 0x5B,
-0xE4, 0xFF, 0x71, 0x50, 0x7F, 0x00, 0x22, 0x7F,
-0x32, 0x7E, 0x00, 0x12, 0x7C, 0x6A, 0x90, 0x96,
-0xB8, 0xF1, 0xEF, 0x80, 0x9A, 0x90, 0x88, 0xA1,
-0xE0, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96,
-0x9F, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x86,
-0xB1, 0xE0, 0x04, 0xF0, 0x90, 0x88, 0x9D, 0xE0,
-0x30, 0xE0, 0x07, 0x90, 0x05, 0x10, 0xE4, 0xF0,
-0xA3, 0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x34,
-0x90, 0x05, 0x22, 0xE0, 0x90, 0x96, 0xA3, 0xF0,
-0x7B, 0x26, 0xD1, 0x5A, 0x90, 0x8A, 0xFD, 0x12,
-0x88, 0xCD, 0xEF, 0x64, 0x01, 0x70, 0x02, 0x80,
-0x05, 0xB1, 0xBD, 0x30, 0xE0, 0x04, 0xD1, 0x7F,
-0xEE, 0xF0, 0x90, 0x96, 0xA3, 0xE0, 0xFD, 0x7B,
-0x27, 0xE4, 0xFF, 0x71, 0x50, 0xD1, 0x6D, 0x12,
-0x04, 0x7E, 0x80, 0x09, 0xD1, 0x6D, 0x12, 0x04,
-0x7E, 0xD1, 0x7F, 0xEE, 0xF0, 0x90, 0x88, 0x9D,
-0xE0, 0x30, 0xE0, 0x19, 0xB1, 0xBD, 0x30, 0xE0,
-0x14, 0x90, 0x05, 0x22, 0xE0, 0x54, 0x6F, 0xFF,
-0x90, 0x8A, 0xF9, 0x12, 0xA7, 0x01, 0x8C, 0x83,
-0x7D, 0x28, 0x12, 0x04, 0x7E, 0x90, 0x04, 0x1F,
-0x74, 0x20, 0xF0, 0x7F, 0x01, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x7D, 0xFF, 0xE4, 0xFF, 0x61, 0x50,
-0x90, 0x01, 0xC0, 0xE0, 0x44, 0x20, 0xF0, 0x90,
-0x96, 0xBA, 0xE0, 0xFD, 0x22, 0x90, 0x96, 0x9F,
-0xE0, 0xFF, 0x90, 0x8A, 0xC7, 0xE0, 0xFC, 0xA3,
-0xE0, 0xFD, 0xF5, 0x82, 0x8C, 0x83, 0x22, 0x90,
-0x86, 0xB6, 0xE0, 0xFF, 0x90, 0x96, 0xA0, 0xE0,
-0xFB, 0x90, 0x92, 0x13, 0x74, 0x0A, 0xF0, 0x7D,
-0x01, 0x12, 0x66, 0xDB, 0x90, 0x96, 0xA1, 0xEE,
-0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x96,
-0x9F, 0xE0, 0xFF, 0x90, 0x8A, 0x95, 0xE0, 0xFA,
-0xA3, 0xE0, 0xFB, 0xF5, 0x82, 0x8A, 0x83, 0x12,
-0x04, 0x7E, 0x90, 0x96, 0xA1, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0x90, 0x8A, 0x9B, 0xE0, 0xFC, 0xA3,
-0xE0, 0xFD, 0xF5, 0x82, 0x8C, 0x83, 0x12, 0x04,
-0x7E, 0x90, 0x96, 0xA1, 0xA3, 0xE0, 0xFF, 0x24,
-0x12, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0x54, 0x01, 0xFE, 0x90, 0x96, 0xA0, 0xE0,
-0x25, 0xE0, 0x25, 0xE0, 0x44, 0x02, 0x4E, 0xFE,
-0x74, 0x12, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
-0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x96, 0xA9, 0xED, 0xF0, 0xA3,
-0xEB, 0xF0, 0x90, 0x96, 0xA8, 0xEF, 0xF0, 0xE4,
-0xFD, 0xFC, 0x12, 0xD1, 0x46, 0x90, 0x96, 0xAB,
-0xF0, 0x12, 0x7B, 0x07, 0x7C, 0x00, 0xAD, 0x07,
-0x90, 0x96, 0xA8, 0xE0, 0x90, 0x04, 0x25, 0xF0,
-0x90, 0x96, 0xA9, 0xE0, 0x60, 0x06, 0xF1, 0xB4,
-0xE0, 0x44, 0x80, 0xF0, 0xAF, 0x05, 0x74, 0x20,
+0xA3, 0x22, 0xF0, 0x24, 0x0A, 0x90, 0x88, 0xCF,
+0xF0, 0x22, 0x4D, 0xFF, 0x90, 0x88, 0x9D, 0xF0,
+0xEE, 0x22, 0xE5, 0x62, 0xC4, 0x54, 0xF0, 0x24,
+0x05, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
+0x22, 0x8D, 0x0E, 0xEF, 0x30, 0xE6, 0x19, 0xE5,
+0x0E, 0x91, 0xDD, 0xE0, 0xFD, 0xE5, 0x0E, 0x71,
+0xF4, 0xF1, 0x99, 0xE4, 0xFB, 0xAF, 0x0E, 0x12,
+0x75, 0x80, 0x91, 0xD1, 0xE4, 0xF0, 0x80, 0x4E,
+0x91, 0xD1, 0xE0, 0x04, 0xF0, 0x91, 0xD1, 0xE0,
+0x64, 0x02, 0x70, 0x16, 0x74, 0x26, 0x25, 0x0E,
+0x12, 0xCE, 0x5C, 0xE0, 0xFD, 0xF4, 0x60, 0x02,
+0x80, 0x27, 0xE5, 0x0E, 0x91, 0xDD, 0xE0, 0xFD,
+0x80, 0x1F, 0x91, 0xD1, 0xE0, 0xD3, 0x94, 0x03,
+0x40, 0x11, 0x90, 0x8A, 0xB3, 0x12, 0x8A, 0x5F,
+0xAF, 0x0E, 0x12, 0x04, 0x7E, 0x91, 0xD1, 0xE4,
+0xF0, 0x80, 0x13, 0xE5, 0x0E, 0x91, 0xDD, 0xE0,
+0xFD, 0xE5, 0x0E, 0x71, 0xF4, 0xF1, 0x99, 0x7B,
+0x01, 0xAF, 0x0E, 0x12, 0x75, 0x80, 0xE5, 0x0E,
+0x91, 0xDD, 0xE0, 0xFD, 0x90, 0x96, 0x3E, 0x74,
+0x05, 0xF0, 0xE4, 0xFB, 0xAF, 0x0E, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x41,
+0xED, 0xF0, 0xA3, 0xEF, 0xF0, 0xA3, 0xEB, 0xF0,
+0x90, 0x96, 0x3E, 0xE0, 0x90, 0x96, 0x44, 0xF0,
+0xE4, 0xA3, 0xF0, 0xEF, 0x12, 0xCE, 0xA8, 0xF5,
+0x83, 0xA3, 0xE0, 0x90, 0x96, 0x46, 0xF0, 0x74,
+0x46, 0x2F, 0x12, 0xCE, 0x64, 0xE0, 0x90, 0x96,
+0x47, 0xF0, 0x90, 0x96, 0x3F, 0x74, 0x0C, 0xF0,
+0x90, 0x96, 0x61, 0x74, 0x07, 0xF0, 0x7B, 0x01,
+0x7A, 0x96, 0x79, 0x3F, 0x12, 0x8A, 0x4D, 0x7F,
+0x04, 0x12, 0x04, 0x7E, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x74, 0xB6, 0x25, 0x0E, 0xF5, 0x82, 0xE4,
+0x34, 0x8E, 0xF5, 0x83, 0x22, 0xC4, 0x54, 0xF0,
+0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
+0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x96, 0xB7, 0x12, 0xE0, 0xA2, 0x12,
+0xD7, 0x92, 0x90, 0x96, 0xC2, 0xF0, 0xE4, 0x90,
+0x96, 0xBF, 0xF0, 0x90, 0x96, 0xB7, 0x12, 0xAD,
+0x38, 0x90, 0x96, 0xBA, 0xF0, 0xEF, 0x54, 0x07,
+0x90, 0x96, 0xBC, 0xD1, 0xEE, 0xE0, 0x90, 0x96,
+0xBD, 0xF0, 0x12, 0xCE, 0x6C, 0x54, 0x7F, 0x90,
+0x96, 0xC0, 0xF0, 0x90, 0x96, 0xB7, 0xE0, 0x12,
+0xCE, 0x9F, 0xE0, 0x90, 0x96, 0xC1, 0xF0, 0xED,
+0x54, 0x7F, 0x90, 0x96, 0xBB, 0xF0, 0xEB, 0x70,
+0x21, 0x90, 0x89, 0x3D, 0xF1, 0xC4, 0xFF, 0x12,
+0xD7, 0x86, 0xFD, 0x90, 0x89, 0x40, 0xF1, 0xCC,
+0x2D, 0xFF, 0xE4, 0x35, 0xF0, 0xC3, 0x13, 0xFE,
+0xEF, 0x13, 0xFF, 0x90, 0x96, 0xB7, 0xE0, 0x12,
+0xCE, 0x8E, 0x90, 0x96, 0xC0, 0xE0, 0xFF, 0x90,
+0x96, 0xBB, 0xE0, 0xFE, 0xD3, 0x9F, 0x40, 0x0C,
+0x90, 0x96, 0xB8, 0xE0, 0x54, 0x80, 0xFD, 0xEF,
+0x4D, 0xF0, 0x80, 0x0F, 0x90, 0x96, 0xC1, 0xE0,
+0xFF, 0xEE, 0xC3, 0x9F, 0x50, 0x05, 0x90, 0x96,
+0xB8, 0xEF, 0xF0, 0x90, 0x96, 0xB8, 0xE0, 0xFE,
+0x54, 0x7F, 0x90, 0x96, 0xBB, 0xF0, 0xEE, 0x54,
+0x80, 0x90, 0x96, 0xBE, 0xF0, 0x90, 0x96, 0xB9,
+0xE0, 0x70, 0x24, 0xA3, 0xF1, 0xD7, 0xC0, 0x83,
+0xC0, 0x82, 0xE0, 0xFF, 0x90, 0x96, 0xBC, 0xD1,
+0x3C, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4,
+0x5F, 0xD0, 0x82, 0xD0, 0x83, 0xF0, 0x90, 0x96,
+0xBD, 0xE0, 0x54, 0x7F, 0xF0, 0x80, 0x3B, 0x90,
+0x96, 0xBA, 0xF1, 0xD7, 0xC0, 0x83, 0xC0, 0x82,
+0xE0, 0xFF, 0x90, 0x96, 0xBC, 0xD1, 0x3C, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0xD0, 0x82,
+0xD0, 0x83, 0xD1, 0xEE, 0xE0, 0x54, 0x07, 0xFF,
+0x90, 0x96, 0xBD, 0xF0, 0x90, 0x89, 0x46, 0xF1,
+0xC4, 0xF5, 0x82, 0xF1, 0xD1, 0x33, 0x33, 0x33,
+0x54, 0xF8, 0x4F, 0x90, 0x96, 0xBD, 0xF0, 0x44,
+0x80, 0xF0, 0x90, 0x96, 0xB8, 0xF1, 0xBC, 0x91,
+0xDD, 0xEF, 0xF0, 0xEE, 0x70, 0x05, 0x90, 0x01,
+0xC8, 0xEF, 0xF0, 0x90, 0x96, 0xBD, 0xF1, 0xBC,
+0xD1, 0xF3, 0xEF, 0xF0, 0xEE, 0x71, 0xF4, 0xE0,
+0x54, 0xFC, 0xFF, 0x90, 0x96, 0xC2, 0xE0, 0x54,
+0x03, 0x4F, 0xFE, 0x90, 0x96, 0xB7, 0xE0, 0xFF,
+0x71, 0xF4, 0xEE, 0xF0, 0x7D, 0x01, 0x12, 0x61,
+0xF7, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0x7B,
+0x41, 0x90, 0x96, 0xFF, 0xE0, 0xFE, 0x74, 0x01,
+0xA8, 0x06, 0x08, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x00, 0xED, 0xF0,
+0x90, 0x96, 0xFF, 0xEF, 0xF0, 0xD3, 0x94, 0x07,
+0x50, 0x42, 0x7F, 0x47, 0xD1, 0x36, 0x80, 0x02,
+0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0xFD, 0x7F,
+0x47, 0x12, 0x7B, 0x2E, 0x7F, 0x46, 0xD1, 0x36,
+0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0xFD,
+0x7F, 0x46, 0xF1, 0xB4, 0x60, 0x0D, 0x7F, 0x45,
+0xD1, 0x36, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
+0x4F, 0x80, 0x0C, 0x7F, 0x45, 0xD1, 0x36, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0xFD,
+0x7F, 0x45, 0x80, 0x4A, 0x90, 0x96, 0xFF, 0xE0,
+0x24, 0xF8, 0xF0, 0x7F, 0x63, 0xD1, 0x36, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0xFD,
+0x7F, 0x63, 0x12, 0x7B, 0x2E, 0x7F, 0x62, 0xD1,
+0x36, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F,
+0xFD, 0x7F, 0x62, 0xF1, 0xB4, 0x60, 0x10, 0x7F,
+0x61, 0xD1, 0x36, 0x80, 0x02, 0xC3, 0x33, 0xD8,
+0xFC, 0x4F, 0xFD, 0x7F, 0x61, 0x80, 0x0F, 0x7F,
+0x61, 0xD1, 0x36, 0x80, 0x02, 0xC3, 0x33, 0xD8,
+0xFC, 0xF4, 0x5F, 0xFD, 0x7F, 0x61, 0x12, 0x7B,
+0x2E, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90,
+0x96, 0xB7, 0xE0, 0xC4, 0x54, 0xF0, 0x24, 0x01,
+0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22,
+0xAD, 0x07, 0x90, 0x93, 0x5A, 0xE0, 0x75, 0xF0,
+0x20, 0xA4, 0xFF, 0x90, 0x96, 0xD2, 0xE5, 0xF0,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x93, 0x5B, 0xE0,
+0x75, 0xF0, 0x08, 0xA4, 0xAE, 0xF0, 0x90, 0x96,
+0xD4, 0xF0, 0xEE, 0xA3, 0xF0, 0xF1, 0xAC, 0x90,
+0x96, 0xD6, 0xF0, 0xEE, 0xA3, 0xF0, 0xED, 0x64,
+0x01, 0x60, 0x65, 0x90, 0x93, 0x58, 0xE0, 0xFE,
+0x12, 0x8D, 0x35, 0x30, 0xE0, 0x5A, 0xEE, 0x12,
+0xA8, 0x64, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0xF1,
+0xA1, 0xFE, 0x54, 0x0F, 0xFF, 0xEE, 0xC4, 0x13,
+0x13, 0x54, 0x01, 0xFD, 0xF1, 0xA1, 0xC4, 0x13,
+0x54, 0x07, 0x30, 0xE0, 0x24, 0xA3, 0xE0, 0x30,
+0xE0, 0x0F, 0x90, 0x96, 0xD7, 0xE0, 0x90, 0x92,
+0x20, 0xF0, 0x90, 0x96, 0xD6, 0xF1, 0xE2, 0x80,
+0x10, 0xF1, 0xAC, 0xFF, 0x12, 0x7C, 0x6A, 0x12,
+0xA8, 0x5F, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0xD1,
+0x44, 0x90, 0x93, 0x58, 0xE0, 0xC4, 0x54, 0x0F,
+0x30, 0xE0, 0x0D, 0x90, 0x96, 0xD5, 0xE0, 0x90,
+0x92, 0x20, 0xF0, 0x90, 0x96, 0xD4, 0xF1, 0xE2,
+0x22, 0xE0, 0x54, 0x03, 0x90, 0x92, 0x80, 0xF0,
+0x22, 0xD1, 0x44, 0x90, 0x93, 0x58, 0xE0, 0x22,
+0xE4, 0xFD, 0x61, 0x91, 0x90, 0x96, 0xD2, 0xE0,
+0xFE, 0xA3, 0xE0, 0x22, 0x12, 0x7B, 0x2E, 0x90,
+0x97, 0x00, 0xE0, 0x22, 0xE0, 0xFF, 0x90, 0x96,
+0xB7, 0xE0, 0xFE, 0x22, 0x12, 0x86, 0x6D, 0x90,
+0x96, 0xBB, 0xE0, 0x22, 0x12, 0x86, 0x6D, 0x8F,
+0x82, 0x75, 0x83, 0x00, 0x02, 0x02, 0x1F, 0xE0,
+0x24, 0x6F, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5,
+0x83, 0x22, 0xE0, 0x90, 0x92, 0x21, 0xF0, 0xE4,
+0xFB, 0xFD, 0x7F, 0x58, 0x7E, 0x01, 0x02, 0x66,
+0x33, 0xE4, 0xFD, 0xFF, 0x02, 0x04, 0x7E, 0x12,
+0xB3, 0xFD, 0x30, 0xE0, 0x14, 0x12, 0x9E, 0xAF,
+0x90, 0x86, 0xB3, 0xE0, 0x64, 0x01, 0x70, 0x27,
+0x90, 0xFE, 0x10, 0xE0, 0x44, 0x04, 0xF0, 0x80,
+0x1E, 0x90, 0x93, 0x26, 0xE0, 0x60, 0x16, 0x7D,
+0x10, 0xE4, 0xFF, 0x12, 0x7C, 0x3B, 0x90, 0x01,
+0x3C, 0xE0, 0x30, 0xE4, 0x03, 0x74, 0x10, 0xF0,
+0x90, 0x01, 0x63, 0xE4, 0xF0, 0x11, 0xA4, 0x12,
+0x90, 0xD3, 0x12, 0x87, 0x87, 0x90, 0x93, 0x04,
+0x12, 0x87, 0x25, 0x90, 0x93, 0x05, 0xF0, 0x90,
+0x93, 0x04, 0xE0, 0x54, 0x01, 0x90, 0x93, 0x12,
+0xF0, 0x90, 0x93, 0x04, 0xE0, 0x54, 0x02, 0x90,
+0x93, 0x13, 0xF0, 0x90, 0x93, 0x04, 0xE0, 0x54,
+0x04, 0x90, 0x93, 0x14, 0xF0, 0x90, 0x93, 0x04,
+0xE0, 0x54, 0x08, 0x90, 0x93, 0x15, 0xF0, 0x90,
+0x93, 0x04, 0xE0, 0x54, 0x10, 0x90, 0x93, 0x16,
+0xF0, 0x90, 0x93, 0x05, 0xE0, 0x54, 0x01, 0x90,
+0x93, 0x17, 0xF0, 0x90, 0x93, 0x05, 0xE0, 0x54,
+0x02, 0x90, 0x93, 0x18, 0xF0, 0x90, 0x93, 0x05,
+0xE0, 0x54, 0x04, 0x90, 0x93, 0x19, 0xF0, 0x90,
+0x93, 0x05, 0xE0, 0x54, 0x08, 0x90, 0x93, 0x1A,
+0xF0, 0x90, 0x93, 0x05, 0xE0, 0x54, 0x10, 0x90,
+0x93, 0x1B, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x93, 0x03, 0xE0, 0xFE,
+0xEE, 0x54, 0xFE, 0xF0, 0xF1, 0xBF, 0xE4, 0x90,
+0x93, 0x10, 0xF0, 0xA3, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x93, 0x21, 0xE0, 0x90, 0x95,
+0xA3, 0xF0, 0x90, 0x93, 0x22, 0xE0, 0x90, 0x95,
+0xA4, 0xF0, 0x90, 0x93, 0x23, 0xE0, 0x90, 0x95,
+0xA5, 0xF0, 0x90, 0x93, 0x24, 0xE0, 0x90, 0x95,
+0xA6, 0xF0, 0x90, 0x93, 0x25, 0xE0, 0x90, 0x95,
+0xA7, 0xF0, 0x90, 0x93, 0x12, 0xE0, 0x90, 0x95,
+0xA8, 0xF0, 0x90, 0x93, 0x13, 0xE0, 0x90, 0x95,
+0xA9, 0xF0, 0x90, 0x93, 0x14, 0xE0, 0x90, 0x95,
+0xAA, 0xF0, 0x90, 0x93, 0x15, 0xE0, 0x90, 0x95,
+0xAB, 0xF0, 0x90, 0x93, 0x16, 0xE0, 0x90, 0x95,
+0xAC, 0xF0, 0x90, 0x93, 0x17, 0xE0, 0x90, 0x95,
+0xAD, 0xF0, 0x90, 0x93, 0x18, 0xE0, 0x90, 0x95,
+0xAE, 0xF0, 0x90, 0x93, 0x19, 0xE0, 0x90, 0x95,
+0xAF, 0xF0, 0x90, 0x93, 0x1A, 0xE0, 0x90, 0x95,
+0xB0, 0xF0, 0x90, 0x93, 0x1B, 0xE0, 0x90, 0x95,
+0xB1, 0xF0, 0xD1, 0x27, 0x90, 0x95, 0x4B, 0xF0,
+0xB1, 0xBF, 0x50, 0x09, 0xB1, 0xFD, 0x74, 0x01,
+0xF0, 0xB1, 0xB8, 0x80, 0xF3, 0x90, 0x93, 0x03,
+0xE0, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x12,
+0x90, 0x01, 0x02, 0xE0, 0x54, 0x0C, 0xFF, 0xBF,
+0x08, 0x08, 0x90, 0x95, 0xC1, 0x74, 0x01, 0xF0,
+0x80, 0x05, 0xE4, 0x90, 0x95, 0xC1, 0xF0, 0x90,
+0x01, 0x1F, 0xE0, 0xFE, 0x90, 0x01, 0x1E, 0xD1,
+0xF1, 0x90, 0x95, 0x40, 0xF0, 0xA3, 0xD1, 0x64,
+0xB1, 0xBF, 0x50, 0x4A, 0xB1, 0xE5, 0x90, 0x95,
+0x4B, 0xE0, 0xFE, 0x24, 0xB2, 0xF5, 0x82, 0xE4,
+0x34, 0x95, 0xD1, 0x08, 0xE0, 0x24, 0x4D, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFF,
+0x74, 0x4D, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xD1, 0x08, 0xE0, 0x24, 0x4E, 0xF9, 0xE4, 0x34,
+0xFC, 0xFA, 0x7B, 0x01, 0xEE, 0xD1, 0x8B, 0x12,
+0x86, 0x76, 0xD1, 0x0C, 0xE0, 0x24, 0x38, 0xF9,
+0xE4, 0x34, 0xFC, 0xFA, 0xEE, 0xD1, 0x7D, 0x12,
+0x86, 0x76, 0xB1, 0xB8, 0x80, 0xB2, 0x90, 0x02,
+0x87, 0xE0, 0x70, 0x02, 0xA1, 0x98, 0x90, 0x93,
+0x03, 0xE0, 0x20, 0xE0, 0x02, 0xA1, 0x98, 0xE4,
+0x90, 0x95, 0xBC, 0xD1, 0x2F, 0x90, 0x95, 0x40,
+0xE0, 0xFF, 0xA3, 0xE0, 0xA3, 0xCF, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x95, 0x42, 0xE0, 0xFC, 0xA3,
+0xE0, 0xFD, 0xEC, 0x90, 0xFD, 0x11, 0xF0, 0x74,
+0x01, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5,
+0x83, 0xE0, 0xFE, 0x74, 0x00, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x7A, 0x00,
+0x24, 0x00, 0xFF, 0xEA, 0x3E, 0x54, 0x3F, 0x90,
+0x95, 0x44, 0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x02,
+0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83,
+0xE0, 0x54, 0x0F, 0x33, 0x33, 0x33, 0x54, 0xF8,
+0x90, 0x95, 0x47, 0xF0, 0xFC, 0x74, 0x07, 0x2D,
+0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0,
+0x54, 0xC0, 0x90, 0x95, 0x49, 0xF0, 0xEC, 0x24,
+0x18, 0x90, 0x95, 0x46, 0xF0, 0xFD, 0x90, 0x95,
+0x42, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xB1, 0x9D,
+0xEF, 0x54, 0xFC, 0x90, 0x95, 0x48, 0xF0, 0x90,
+0x95, 0x47, 0xE0, 0x24, 0x18, 0xFF, 0xE4, 0x33,
+0x90, 0x95, 0x44, 0x8F, 0xF0, 0x12, 0x02, 0xE7,
+0x90, 0x95, 0x44, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0x12, 0xDD, 0x2C, 0x90, 0x95, 0x40, 0xEE, 0x8F,
+0xF0, 0x12, 0x02, 0xE7, 0x90, 0x88, 0x27, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x95, 0x40, 0xF1,
+0xD1, 0x40, 0x1B, 0x90, 0x88, 0x28, 0xE0, 0x24,
+0x01, 0xFF, 0x90, 0x88, 0x27, 0xE0, 0x34, 0x00,
+0xFE, 0xC3, 0xED, 0x9F, 0xFF, 0xEC, 0x9E, 0x90,
+0x95, 0x40, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x95,
+0x48, 0xE0, 0x24, 0xC0, 0x60, 0x02, 0x81, 0x9B,
+0xB1, 0xAC, 0xE0, 0x24, 0x18, 0xB1, 0x9C, 0xEF,
+0x60, 0x02, 0x81, 0x91, 0xB1, 0xAC, 0xE0, 0x24,
+0x19, 0xB1, 0x9C, 0x90, 0x95, 0x61, 0xD1, 0x6C,
+0x90, 0x95, 0x61, 0xE0, 0xFF, 0x90, 0x95, 0x4A,
+0xE0, 0xFD, 0xC3, 0x9F, 0x50, 0x16, 0xB1, 0xAC,
+0xE0, 0x24, 0x1A, 0xB1, 0x99, 0x90, 0x95, 0x4A,
+0xE0, 0x24, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xB1, 0xDA, 0x80, 0xDC, 0x90, 0x95, 0x61, 0xE0,
+0x70, 0x02, 0x61, 0xC3, 0xE4, 0x90, 0x95, 0x4B,
+0xF0, 0xB1, 0xBF, 0x40, 0x02, 0x61, 0xAB, 0xB1,
+0xE5, 0x90, 0x95, 0x4B, 0xE0, 0xFF, 0x24, 0x4D,
+0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0xE0,
+0xFE, 0x90, 0x95, 0x61, 0xE0, 0xFD, 0xEE, 0x6D,
+0x70, 0x1D, 0xEF, 0xD1, 0x8B, 0x12, 0x86, 0x6D,
+0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01, 0xD1, 0x17,
+0xED, 0xF0, 0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03,
+0xD1, 0x39, 0xEF, 0x60, 0x02, 0x80, 0x47, 0x90,
+0x95, 0x61, 0xE0, 0x64, 0x03, 0x70, 0x4E, 0xD1,
+0x17, 0x74, 0x03, 0xF0, 0x7A, 0x96, 0x79, 0xC7,
+0xD1, 0x39, 0xEF, 0x70, 0x0E, 0xD1, 0x17, 0x74,
+0x03, 0xF0, 0x7A, 0x96, 0x79, 0xC3, 0xD1, 0x39,
+0xEF, 0x60, 0x2A, 0x90, 0x95, 0x4B, 0xE0, 0xFF,
+0x24, 0xAD, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5,
+0x83, 0xE0, 0x60, 0x02, 0x80, 0x0B, 0x90, 0x95,
+0x4B, 0xE0, 0xFF, 0x24, 0xA8, 0xD1, 0x74, 0x60,
+0x05, 0x74, 0xBC, 0x2F, 0x80, 0x15, 0xB1, 0xCC,
+0x74, 0x01, 0xF0, 0x80, 0x12, 0x90, 0x95, 0x4B,
+0xE0, 0x24, 0xBC, 0x80, 0x06, 0x90, 0x95, 0x4B,
+0xE0, 0x24, 0xBC, 0xB1, 0xD2, 0xE4, 0xF0, 0xB1,
+0xB8, 0x61, 0x09, 0x90, 0x95, 0xBC, 0xE0, 0x70,
+0x4F, 0xA3, 0xE0, 0x70, 0x4B, 0xA3, 0xE0, 0x70,
+0x47, 0xA3, 0xE0, 0x70, 0x43, 0xA3, 0xE0, 0x70,
+0x3F, 0x81, 0x91, 0xE4, 0x90, 0x95, 0x4B, 0xF0,
+0xB1, 0xBF, 0x50, 0x1C, 0x74, 0xA8, 0x2E, 0xD1,
+0x74, 0x60, 0x09, 0x74, 0xBC, 0x2E, 0xB1, 0xD2,
+0xE4, 0xF0, 0x80, 0x08, 0x74, 0xBC, 0x2E, 0xB1,
+0xD2, 0x74, 0x01, 0xF0, 0xB1, 0xB8, 0x80, 0xE0,
+0x90, 0x95, 0xBC, 0xE0, 0x70, 0x12, 0xA3, 0xE0,
+0x70, 0x0E, 0xA3, 0xE0, 0x70, 0x0A, 0xA3, 0xE0,
+0x70, 0x06, 0xA3, 0xE0, 0x70, 0x02, 0x81, 0x91,
+0xE4, 0x90, 0x95, 0x4B, 0xF0, 0xB1, 0xBF, 0x40,
+0x02, 0x81, 0x91, 0xB1, 0xE5, 0xB1, 0xCC, 0xE0,
+0x60, 0x7B, 0x90, 0x93, 0x2A, 0xE0, 0x30, 0xE0,
+0x06, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x6E, 0xE4,
+0xFF, 0xFE, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x10,
+0xD3, 0xEF, 0x94, 0xE8, 0xEE, 0x94, 0x03, 0x50,
+0x07, 0x0F, 0xBF, 0x00, 0x01, 0x0E, 0x80, 0xEA,
+0x90, 0x04, 0x1D, 0xE0, 0x70, 0x4F, 0x90, 0x95,
+0x4B, 0xE0, 0x24, 0xA3, 0xF5, 0x82, 0xE4, 0x34,
+0x95, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x92, 0x13,
+0x74, 0x06, 0xF0, 0x7B, 0x08, 0x7D, 0x01, 0x12,
+0x66, 0xDB, 0x90, 0x95, 0x44, 0xEE, 0xF0, 0xA3,
+0xD1, 0x6C, 0xB1, 0xF4, 0x50, 0x1D, 0xB1, 0xAC,
+0xE0, 0x24, 0x0A, 0xB1, 0x99, 0x90, 0x95, 0x44,
+0xA3, 0xE0, 0xFE, 0x90, 0x95, 0x4A, 0xE0, 0x2E,
+0x24, 0x2C, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xB1,
+0xDA, 0x80, 0xDF, 0x90, 0x04, 0x1F, 0x74, 0x20,
+0xF0, 0x90, 0x06, 0x35, 0xF0, 0xB1, 0xB8, 0x81,
+0x05, 0xD1, 0x99, 0x90, 0x06, 0x36, 0x74, 0xDD,
+0xF0, 0x21, 0xCE, 0x90, 0x95, 0x49, 0xE0, 0x60,
+0x02, 0xA1, 0x94, 0xB1, 0xAC, 0xE0, 0x24, 0x16,
+0xB1, 0x9C, 0x90, 0x06, 0x34, 0xEF, 0xF0, 0xB1,
+0xAC, 0xE0, 0x24, 0x17, 0xB1, 0x9C, 0x90, 0x06,
+0x37, 0xD1, 0x64, 0xB1, 0xBF, 0x50, 0x37, 0xB1,
+0xE5, 0xE4, 0x90, 0x95, 0x4A, 0xF0, 0xB1, 0xF4,
+0x50, 0x28, 0xB1, 0xAC, 0xE0, 0x24, 0x04, 0x2D,
+0xB1, 0x9C, 0x90, 0x95, 0x4B, 0xE0, 0xFE, 0xD1,
+0x7D, 0x12, 0x86, 0x6D, 0x90, 0x95, 0x4A, 0xE0,
+0xF5, 0x82, 0x12, 0x97, 0xD1, 0x6F, 0x60, 0x06,
+0xB1, 0xFD, 0xE4, 0xF0, 0x80, 0x04, 0xB1, 0xDE,
+0x80, 0xD4, 0xB1, 0xB8, 0x80, 0xC5, 0x90, 0x95,
+0xB7, 0xE0, 0x64, 0x01, 0x60, 0x17, 0xA3, 0xE0,
+0x64, 0x01, 0x60, 0x11, 0xA3, 0xE0, 0x64, 0x01,
+0x60, 0x0B, 0xA3, 0xE0, 0x64, 0x01, 0x60, 0x05,
+0xA3, 0xE0, 0xB4, 0x01, 0x06, 0x90, 0x95, 0x4C,
+0x74, 0x01, 0xF0, 0x90, 0x93, 0x03, 0xE0, 0xFF,
+0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x43, 0x90,
+0x01, 0x02, 0xE0, 0x54, 0x0C, 0x64, 0x08, 0x70,
+0x2C, 0x90, 0x95, 0x4A, 0xF0, 0xB1, 0xF4, 0x50,
+0x24, 0xB1, 0xAC, 0xE0, 0x24, 0x04, 0xB1, 0x99,
+0x90, 0x95, 0x4A, 0xE0, 0xFE, 0xE4, 0x2E, 0xF5,
+0x82, 0xE4, 0x34, 0x07, 0xF5, 0x83, 0xE0, 0x6F,
+0x60, 0x07, 0xE4, 0x90, 0x95, 0xC1, 0xF0, 0x80,
+0x04, 0xB1, 0xDE, 0x80, 0xD8, 0x90, 0x95, 0xC1,
+0xE0, 0xB4, 0x01, 0x06, 0x90, 0x95, 0x4C, 0x74,
+0x01, 0xF0, 0x90, 0x95, 0x4C, 0xE0, 0xB4, 0x01,
+0x10, 0x11, 0xA4, 0x90, 0x93, 0x0D, 0xE0, 0x44,
+0x01, 0xF0, 0xF1, 0xC6, 0x12, 0xBF, 0x4B, 0x21,
+0xCE, 0xD1, 0x27, 0x90, 0x95, 0x4B, 0xF0, 0xB1,
+0xBF, 0x50, 0x09, 0xB1, 0xFD, 0x74, 0x01, 0xF0,
+0xB1, 0xB8, 0x80, 0xF3, 0xD1, 0x99, 0x21, 0xCE,
+0x22, 0xFC, 0xED, 0x2C, 0xFD, 0x90, 0x8A, 0xE9,
+0xE0, 0xFA, 0xA3, 0xE0, 0xFB, 0xF5, 0x82, 0x8A,
+0x83, 0x02, 0x04, 0x7E, 0x90, 0x95, 0x42, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x95, 0x46, 0x22,
+0x90, 0x95, 0x4B, 0xE0, 0x04, 0xF0, 0x22, 0x90,
+0x93, 0x0F, 0xE0, 0xFF, 0x90, 0x95, 0x4B, 0xE0,
+0xFE, 0xC3, 0x9F, 0x22, 0x90, 0x95, 0x4B, 0xE0,
+0x24, 0xBC, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5,
+0x83, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x95,
+0x4A, 0xE0, 0x04, 0xF0, 0x22, 0x74, 0xA3, 0x2E,
+0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0xE0,
+0xFF, 0x02, 0x7B, 0x07, 0x90, 0x95, 0x4A, 0xE0,
+0xFD, 0xC3, 0x94, 0x06, 0x22, 0x74, 0xB7, 0x2E,
+0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0x22,
+0xF5, 0x83, 0xEF, 0xF0, 0x74, 0xB2, 0x2E, 0xF5,
+0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0x22, 0x7B,
+0x01, 0x7A, 0x95, 0x79, 0x62, 0x90, 0x95, 0xC5,
+0x12, 0x86, 0x76, 0x90, 0x95, 0xC8, 0x22, 0xE4,
+0x90, 0x95, 0x4C, 0xF0, 0x90, 0x95, 0xB7, 0xF0,
+0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
+0x22, 0x90, 0x95, 0xC2, 0x12, 0x86, 0x76, 0xE4,
+0xFF, 0x90, 0x95, 0xC8, 0xE0, 0xFE, 0xEF, 0xC3,
+0x9E, 0x50, 0x16, 0x90, 0x95, 0xC5, 0x12, 0x97,
+0xCC, 0xFE, 0x90, 0x95, 0xC2, 0x12, 0x97, 0xCC,
+0x6E, 0x60, 0x03, 0x7F, 0x00, 0x22, 0x0F, 0x80,
+0xE0, 0x7F, 0x01, 0x22, 0xEF, 0xF0, 0xE4, 0x90,
+0x95, 0x4B, 0xF0, 0x22, 0xEF, 0xF0, 0xE4, 0x90,
+0x95, 0x4A, 0xF0, 0x22, 0xF5, 0x82, 0xE4, 0x34,
+0x95, 0xF5, 0x83, 0xE0, 0x22, 0x75, 0xF0, 0x03,
+0xA4, 0x24, 0x94, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xF5, 0x83, 0x22, 0x75, 0xF0, 0x03, 0xA4, 0x24,
+0x52, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83,
+0x22, 0x90, 0x95, 0x40, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x90, 0x02, 0x84, 0xEF, 0xF0, 0xEE, 0xA3,
+0xF0, 0xA3, 0xE0, 0x44, 0x01, 0xF0, 0x22, 0x90,
+0x01, 0x17, 0xE0, 0xFE, 0x90, 0x01, 0x16, 0xD1,
+0xF1, 0x90, 0x88, 0x27, 0xF0, 0xA3, 0xEF, 0xF0,
+0x90, 0x02, 0x86, 0xE0, 0x44, 0x04, 0xF0, 0x90,
+0x93, 0x03, 0xE0, 0x44, 0x01, 0xF0, 0x7D, 0x08,
+0xE4, 0xFF, 0x12, 0x7C, 0x74, 0x90, 0x05, 0x52,
+0xE0, 0x54, 0x07, 0x04, 0x90, 0x93, 0x0F, 0xF1,
+0xB2, 0x90, 0x04, 0x22, 0xE0, 0x54, 0xEF, 0xF0,
+0x22, 0x90, 0x00, 0xAB, 0xE0, 0xFE, 0x90, 0x00,
+0xAA, 0xE0, 0x7C, 0x00, 0x24, 0x00, 0xFF, 0xEC,
+0x3E, 0x22, 0xD1, 0xE9, 0x54, 0x7F, 0x90, 0x94,
+0xBB, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x00, 0xAB,
+0xE0, 0x44, 0x80, 0xF0, 0x90, 0x00, 0xAA, 0xE0,
+0x44, 0x02, 0xF0, 0x22, 0x90, 0x94, 0xC3, 0x74,
+0x27, 0xF0, 0x90, 0x94, 0xE5, 0x74, 0x08, 0xF0,
+0x90, 0x94, 0xC5, 0xF0, 0xE4, 0xD1, 0x32, 0x90,
+0x94, 0xB5, 0xE0, 0x90, 0x94, 0xC9, 0xF0, 0x90,
+0x94, 0xB6, 0xE0, 0x90, 0x94, 0xCA, 0xF0, 0x90,
+0x94, 0xB9, 0xE0, 0x90, 0x94, 0xCB, 0xF0, 0x90,
+0x94, 0xBA, 0xE0, 0x90, 0x94, 0xCC, 0xF0, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0xC3, 0xF1, 0xDB, 0x02,
+0x04, 0x7E, 0xF1, 0xB9, 0x12, 0x7B, 0xDB, 0x90,
+0x8A, 0xC5, 0x12, 0x8E, 0xAD, 0x12, 0xCB, 0xD1,
+0xD1, 0xFA, 0x12, 0xDA, 0x26, 0x12, 0xD9, 0x81,
+0xF1, 0x95, 0x90, 0x8A, 0x73, 0x12, 0x8E, 0xAD,
+0x90, 0x00, 0x6A, 0xE0, 0x30, 0xE2, 0x14, 0x90,
+0x92, 0x20, 0x74, 0x01, 0xF0, 0xA3, 0x74, 0xF4,
+0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x68, 0x7E, 0x01,
+0x12, 0x66, 0x33, 0x12, 0xD7, 0xD2, 0x90, 0x93,
+0x4B, 0x74, 0x01, 0xF0, 0x22, 0x90, 0x93, 0x03,
+0xE0, 0x54, 0xFE, 0xF1, 0xB2, 0x90, 0x93, 0x0A,
+0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x93, 0x0E,
+0xF0, 0x90, 0x93, 0x26, 0xF0, 0xA3, 0xF0, 0xA3,
+0xF0, 0x22, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0,
+0x22, 0xE4, 0xFD, 0xFF, 0x02, 0x6E, 0x71, 0x7D,
+0x08, 0xE4, 0xFF, 0x02, 0x7C, 0x7E, 0x90, 0x01,
+0xC7, 0x74, 0x66, 0xF0, 0xE4, 0xFF, 0x22, 0xF5,
+0x83, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xD3, 0x9F,
+0xEC, 0x9E, 0x22, 0x90, 0x8A, 0x77, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0xF5, 0x82, 0x8E, 0x83, 0x22,
+0x12, 0x90, 0xCD, 0x12, 0xA0, 0x02, 0x7A, 0x93,
+0x79, 0x1C, 0x02, 0x69, 0xF5, 0x12, 0x90, 0xCD,
+0x12, 0xA0, 0x02, 0x7A, 0x93, 0x79, 0x21, 0x02,
+0x69, 0xF5, 0x8B, 0x45, 0x8A, 0x46, 0x89, 0x47,
+0x75, 0x48, 0x05, 0x7B, 0x01, 0x22, 0x12, 0x02,
+0x06, 0xFF, 0x90, 0x93, 0x29, 0xF0, 0xBF, 0x01,
+0x07, 0x11, 0x21, 0xE4, 0x90, 0x93, 0x29, 0xF0,
+0x22, 0x11, 0xCC, 0x7F, 0xEF, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x06, 0x90, 0x94, 0xBD,
+0xE0, 0xA3, 0xF0, 0x11, 0xCC, 0x7F, 0xEE, 0x7E,
+0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
+0x94, 0xBD, 0xE0, 0x90, 0x94, 0xBF, 0xF0, 0x11,
+0xCC, 0x7F, 0xED, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x08, 0x90, 0x94, 0xBD, 0xE0, 0x90,
+0x94, 0xC0, 0xF0, 0x11, 0xCC, 0x7F, 0xEC, 0x7E,
+0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
+0x94, 0xBD, 0xE0, 0x90, 0x94, 0xC1, 0xF0, 0x11,
+0xCC, 0x7F, 0xEB, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x08, 0x90, 0x94, 0xBD, 0xE0, 0x90,
+0x94, 0xC2, 0xF0, 0x90, 0x94, 0xBE, 0xE0, 0xFF,
+0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFB, 0xA3, 0xE0,
+0x90, 0x94, 0xC6, 0xF0, 0x90, 0x94, 0xC2, 0xE0,
+0x90, 0x94, 0xC7, 0xF0, 0x90, 0x94, 0xC8, 0x74,
+0x12, 0xF0, 0x90, 0x94, 0xEA, 0x74, 0x05, 0xF0,
+0x90, 0x94, 0xCA, 0x12, 0xE0, 0xA2, 0x90, 0x94,
+0xC6, 0xE0, 0x90, 0x94, 0xCD, 0xF0, 0x90, 0x94,
+0xC7, 0xE0, 0x90, 0x94, 0xCE, 0xF0, 0x7B, 0x01,
+0x7A, 0x94, 0x79, 0xC8, 0x12, 0x8A, 0x4D, 0x7F,
+0x04, 0x02, 0x04, 0x7E, 0x7B, 0x01, 0x7A, 0x94,
+0x79, 0xBD, 0x22, 0x7E, 0x00, 0x7F, 0x0B, 0x7D,
+0x00, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x4D, 0x12,
+0x04, 0x80, 0x11, 0xCC, 0x91, 0x18, 0xBF, 0x01,
+0x1C, 0x90, 0x94, 0xBD, 0xE0, 0xFE, 0x54, 0x01,
+0x90, 0x93, 0x4D, 0xF0, 0xEE, 0x54, 0x04, 0x90,
+0x93, 0x4F, 0xF0, 0x90, 0x94, 0xBD, 0xE0, 0x54,
+0x08, 0x90, 0x93, 0x4E, 0xF0, 0x11, 0xCC, 0x31,
+0x5B, 0x70, 0x35, 0x90, 0x94, 0xBD, 0xE0, 0x54,
+0x07, 0x70, 0x15, 0x7B, 0x01, 0x7A, 0x94, 0x79,
+0xBE, 0x7F, 0xFA, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x0F, 0x90, 0x94, 0xBE, 0x80, 0x03,
+0x90, 0x94, 0xBD, 0xE0, 0x54, 0x07, 0x90, 0x93,
+0x51, 0xF0, 0x90, 0x94, 0xBD, 0xE0, 0x54, 0xE0,
+0xC4, 0x13, 0x54, 0x07, 0x90, 0x93, 0x50, 0xF0,
+0x11, 0xCC, 0x7F, 0xFD, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x0E, 0x90, 0x94, 0xBD, 0xE0,
+0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F, 0x90, 0x93,
+0x52, 0xF0, 0x22, 0x7F, 0xFB, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xEF, 0x64, 0x01, 0x22, 0x90, 0x94,
+0xBD, 0xEF, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0x04, 0x7F, 0xF4, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0, 0x90,
+0x95, 0x06, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0x04, 0x7F, 0xF5, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0, 0x90,
+0x95, 0x07, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0x04, 0x7F, 0xF6, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0, 0x90,
+0x95, 0x08, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0x04, 0x7F, 0xF7, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0, 0x90,
+0x95, 0x09, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0x04, 0x7F, 0xF8, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0, 0x90,
+0x95, 0x0A, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0x04, 0x91, 0x18, 0xBF, 0x01, 0x08, 0x90, 0x95,
+0x04, 0xE0, 0x90, 0x95, 0x0B, 0xF0, 0x7B, 0x01,
+0x7A, 0x95, 0x79, 0x04, 0x31, 0x5B, 0x70, 0x52,
+0x90, 0x95, 0x04, 0xE0, 0x90, 0x95, 0x0C, 0xF0,
+0x54, 0x07, 0x60, 0x08, 0x90, 0x95, 0x04, 0xE0,
+0x54, 0xE0, 0x70, 0x3E, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x05, 0x7F, 0xFA, 0x31, 0x5D, 0x70, 0x32,
+0x90, 0x95, 0x04, 0xE0, 0xFC, 0x54, 0x07, 0x70,
+0x12, 0x90, 0x95, 0x0C, 0xE0, 0xFE, 0x90, 0x95,
+0x05, 0xE0, 0x54, 0x07, 0xFD, 0xEE, 0x4D, 0x90,
+0x95, 0x0C, 0xF0, 0xEC, 0x54, 0xE0, 0x70, 0x12,
+0x90, 0x95, 0x0C, 0xE0, 0xFF, 0x90, 0x95, 0x05,
+0xE0, 0x54, 0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x95,
+0x0C, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x04,
+0x7F, 0xFD, 0x31, 0x5D, 0x70, 0x46, 0x90, 0x95,
+0x04, 0xE0, 0xFE, 0x54, 0xCC, 0x90, 0x95, 0x0D,
+0xF0, 0xEE, 0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90,
+0x95, 0x04, 0xE0, 0x54, 0xC0, 0x70, 0x2D, 0xEF,
+0x70, 0x11, 0x90, 0x95, 0x0D, 0xE0, 0xFF, 0x90,
+0x95, 0x04, 0xE0, 0x54, 0x03, 0xF1, 0xE3, 0x90,
+0x95, 0x0D, 0xF0, 0x90, 0x95, 0x04, 0xE0, 0xFF,
+0x54, 0xC0, 0x70, 0x10, 0x90, 0x95, 0x0D, 0xE0,
+0xFE, 0xEF, 0x54, 0x30, 0x25, 0xE0, 0x25, 0xE0,
+0xFF, 0xEE, 0x4F, 0xF0, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x04, 0x7F, 0xF0, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0,
+0x90, 0x95, 0x0E, 0xF0, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x04, 0x7F, 0xF1, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0,
+0x90, 0x95, 0x0F, 0xF0, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x04, 0x7F, 0xF2, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0,
+0x90, 0x95, 0x10, 0xF0, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x04, 0x7F, 0xF3, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0,
+0x90, 0x95, 0x11, 0xF0, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x04, 0x7F, 0xFC, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x04, 0xE0,
+0x90, 0x95, 0x12, 0xF0, 0x90, 0x94, 0xBE, 0x74,
+0x19, 0xF0, 0x90, 0x94, 0xE0, 0x74, 0x08, 0xF0,
+0x90, 0x95, 0x06, 0xE0, 0x90, 0x94, 0xC0, 0xF0,
+0x90, 0x95, 0x07, 0xE0, 0x90, 0x94, 0xC1, 0xF0,
+0x90, 0x95, 0x08, 0xE0, 0x90, 0x94, 0xC2, 0xF0,
+0x90, 0x95, 0x09, 0xE0, 0x90, 0x94, 0xC3, 0xF0,
+0x90, 0x95, 0x0A, 0xE0, 0x90, 0x94, 0xC4, 0xF0,
+0x90, 0x95, 0x0B, 0xE0, 0x90, 0x94, 0xC5, 0xF0,
+0x90, 0x95, 0x0C, 0xE0, 0x90, 0x94, 0xC6, 0xF0,
+0x90, 0x95, 0x0D, 0xE0, 0x90, 0x94, 0xC7, 0xF0,
+0x90, 0x94, 0xE1, 0x74, 0x1A, 0xF0, 0x90, 0x95,
+0x03, 0x74, 0x05, 0xF0, 0x90, 0x95, 0x0E, 0xE0,
+0x90, 0x94, 0xE3, 0xF0, 0x90, 0x95, 0x0F, 0xE0,
+0x90, 0x94, 0xE4, 0xF0, 0x90, 0x95, 0x10, 0xE0,
+0x90, 0x94, 0xE5, 0xF0, 0x90, 0x95, 0x11, 0xE0,
+0x90, 0x94, 0xE6, 0xF0, 0x90, 0x95, 0x12, 0xE0,
+0x90, 0x94, 0xE7, 0xF0, 0x90, 0x00, 0x35, 0xE0,
+0x54, 0xFC, 0x44, 0x01, 0xF0, 0x7B, 0x01, 0x7A,
+0x95, 0x79, 0x04, 0x7F, 0x6F, 0x7E, 0x00, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x04,
+0xE0, 0x90, 0x95, 0x13, 0xF0, 0x90, 0x00, 0x35,
+0xE0, 0x54, 0xFC, 0xF0, 0x90, 0x94, 0xBD, 0xE0,
+0xB4, 0x01, 0x1A, 0x7B, 0x01, 0x7A, 0x94, 0x79,
+0xBE, 0x12, 0x9F, 0xDB, 0x12, 0x04, 0x7E, 0x7B,
+0x01, 0x7A, 0x94, 0x79, 0xE1, 0x12, 0x8A, 0x4D,
+0x7F, 0x04, 0x02, 0x04, 0x7E, 0x75, 0x45, 0x01,
+0x75, 0x46, 0x94, 0x75, 0x47, 0xBE, 0x75, 0x48,
+0x0A, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xA0, 0x12,
+0x69, 0xF5, 0x75, 0x45, 0x01, 0x75, 0x46, 0x94,
+0x75, 0x47, 0xE3, 0x75, 0x48, 0x05, 0x7B, 0x01,
+0x7A, 0x01, 0x79, 0xAA, 0x12, 0x69, 0xF5, 0x90,
+0x95, 0x13, 0xE0, 0x90, 0x01, 0xA1, 0xF0, 0x22,
+0x7F, 0xF9, 0x7E, 0x01, 0x02, 0x5F, 0xA6, 0x12,
+0x02, 0x06, 0x90, 0x94, 0xE0, 0x12, 0x87, 0x86,
+0x90, 0x94, 0xE1, 0xF0, 0x60, 0x0D, 0x91, 0x7D,
+0xF1, 0x36, 0x90, 0x94, 0xE1, 0x91, 0x7D, 0x7B,
+0x57, 0x91, 0x8A, 0x90, 0x88, 0x9D, 0xE0, 0x30,
+0xE0, 0x0D, 0x12, 0x8D, 0x31, 0x30, 0xE0, 0x07,
+0x90, 0x06, 0x0A, 0xE0, 0x44, 0x07, 0xF0, 0x90,
+0x94, 0xBD, 0x74, 0x20, 0xF0, 0x90, 0x94, 0xDF,
+0x74, 0x03, 0xF0, 0x90, 0x05, 0x22, 0xE0, 0x90,
+0x94, 0xBF, 0xF0, 0x90, 0x93, 0x5E, 0xE0, 0x90,
+0x94, 0xC0, 0xF0, 0x90, 0x93, 0x5F, 0xE0, 0x90,
+0x94, 0xC1, 0xF0, 0x11, 0xCC, 0x12, 0x8A, 0x4D,
+0x7F, 0x04, 0x02, 0x04, 0x7E, 0xE0, 0xFF, 0x90,
+0x94, 0xE0, 0xE0, 0xFD, 0x22, 0xE4, 0xFB, 0xFD,
+0x7F, 0xFF, 0xEB, 0xB4, 0x57, 0x04, 0x91, 0xAA,
+0x80, 0x0E, 0xEF, 0x70, 0x07, 0x90, 0x93, 0x5E,
+0xE0, 0x4D, 0x80, 0x04, 0xF1, 0x4E, 0x91, 0xAA,
+0x90, 0x05, 0x22, 0xF0, 0x90, 0x93, 0x01, 0xEB,
+0xF0, 0x22, 0x90, 0x93, 0x5F, 0xE0, 0xFF, 0x90,
+0x93, 0x5E, 0xE0, 0x4F, 0x22, 0xE4, 0x90, 0x96,
+0xF2, 0xF0, 0xA3, 0xF0, 0x90, 0x05, 0x22, 0xE0,
+0x90, 0x96, 0xF4, 0xF0, 0x7B, 0x47, 0xB1, 0x3C,
+0x90, 0x05, 0xF8, 0xE0, 0x70, 0x1A, 0xA3, 0xE0,
+0x70, 0x16, 0xA3, 0xE0, 0x70, 0x12, 0xA3, 0xE0,
+0x70, 0x0E, 0x90, 0x96, 0xF4, 0xE0, 0xFD, 0x7B,
+0x48, 0xE4, 0xFF, 0x91, 0x8A, 0x7F, 0x01, 0x22,
+0x12, 0x8F, 0xEC, 0x30, 0xE0, 0x19, 0xD3, 0x90,
+0x96, 0xF3, 0xE0, 0x94, 0x03, 0x90, 0x96, 0xF2,
+0xE0, 0x94, 0x00, 0x40, 0x06, 0xB1, 0x2F, 0x7B,
+0x5A, 0x80, 0x17, 0x7F, 0x01, 0x80, 0x1C, 0xD3,
+0x90, 0x96, 0xF3, 0xE0, 0x94, 0xE8, 0x90, 0x96,
+0xF2, 0xE0, 0x94, 0x03, 0x40, 0x0B, 0xB1, 0x2F,
+0x7B, 0x5B, 0xE4, 0xFF, 0x91, 0x8A, 0x7F, 0x00,
+0x22, 0x7F, 0x32, 0x7E, 0x00, 0x12, 0x7C, 0x6A,
+0x90, 0x96, 0xF2, 0xF1, 0xDC, 0x80, 0x99, 0x90,
+0x01, 0xC0, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x96,
+0xF4, 0xE0, 0xFD, 0x22, 0x7D, 0xFF, 0xE4, 0xFF,
+0x81, 0x8A, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x96, 0xDD, 0xEF, 0xF0, 0xA3, 0xED,
+0xF0, 0x90, 0x86, 0xB1, 0xE0, 0x04, 0xF0, 0x90,
+0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x07, 0x90, 0x05,
+0x10, 0xE4, 0xF0, 0xA3, 0xF0, 0x90, 0x04, 0x1D,
+0xE0, 0x60, 0x35, 0x90, 0x05, 0x22, 0xE0, 0x90,
+0x96, 0xE1, 0xF0, 0x7B, 0x26, 0xB1, 0x3C, 0x90,
+0x8A, 0xFD, 0x12, 0x8E, 0xAD, 0xEF, 0x64, 0x01,
+0x70, 0x02, 0x80, 0x06, 0x12, 0x8F, 0xEC, 0x30,
+0xE0, 0x04, 0xB1, 0xE8, 0xEE, 0xF0, 0x90, 0x96,
+0xE1, 0xE0, 0xFD, 0x7B, 0x27, 0xE4, 0xFF, 0x91,
+0x8A, 0xB1, 0xD6, 0x12, 0x04, 0x7E, 0x80, 0x09,
+0xB1, 0xD6, 0x12, 0x04, 0x7E, 0xB1, 0xE8, 0xEE,
+0xF0, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x19,
+0x12, 0x8F, 0xEC, 0x30, 0xE0, 0x13, 0x90, 0x05,
+0x22, 0xE0, 0x54, 0x6F, 0xFF, 0x90, 0x8A, 0xF9,
+0xF1, 0x2F, 0x8C, 0x83, 0x7D, 0x28, 0x12, 0x04,
+0x7E, 0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0, 0x7F,
+0x01, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x96,
+0xDD, 0xE0, 0xFF, 0x90, 0x8A, 0xC7, 0xE0, 0xFC,
+0xA3, 0xE0, 0xFD, 0xF5, 0x82, 0x8C, 0x83, 0x22,
+0x90, 0x86, 0xB6, 0xE0, 0xFF, 0x90, 0x96, 0xDE,
+0xE0, 0xFB, 0x90, 0x92, 0x13, 0x74, 0x0A, 0xF0,
+0x7D, 0x01, 0x12, 0x66, 0xDB, 0x90, 0x96, 0xDF,
+0xEE, 0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD, 0x90,
+0x96, 0xDD, 0xE0, 0xFF, 0x90, 0x8A, 0x95, 0xE0,
+0xFA, 0xA3, 0xE0, 0xFB, 0xF5, 0x82, 0x8A, 0x83,
+0x12, 0x04, 0x7E, 0x90, 0x96, 0xDF, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0x90, 0x8A, 0x9B, 0xE0, 0xFC,
+0xA3, 0xE0, 0xFD, 0xF5, 0x82, 0x8C, 0x83, 0x12,
+0x04, 0x7E, 0x90, 0x96, 0xDF, 0xA3, 0xE0, 0xFF,
+0x24, 0x12, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0x54, 0x01, 0xFE, 0x90, 0x96, 0xDE,
+0xE0, 0x25, 0xE0, 0x25, 0xE0, 0x44, 0x02, 0x4E,
+0xFE, 0x74, 0x12, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x96, 0xE7, 0xED, 0xF0,
+0xA3, 0xEB, 0xF0, 0x90, 0x96, 0xE6, 0xEF, 0xF0,
+0xE4, 0xFD, 0xFC, 0x12, 0xD7, 0x92, 0x90, 0x96,
+0xE9, 0xF0, 0x12, 0x7B, 0x07, 0x7C, 0x00, 0xAD,
+0x07, 0x90, 0x96, 0xE6, 0xE0, 0x90, 0x04, 0x25,
+0xF0, 0x90, 0x96, 0xE7, 0xE0, 0x60, 0x05, 0xF1,
+0x1B, 0x44, 0x80, 0xF0, 0xAF, 0x05, 0x74, 0x20,
 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0x54, 0xC0, 0xF0, 0xF1, 0xB4, 0xE0, 0x54,
-0xC0, 0xF0, 0x90, 0x96, 0xAB, 0xE0, 0xFF, 0xAE,
-0x05, 0x74, 0x18, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00, 0x8B,
-0xE0, 0xD3, 0x94, 0x03, 0x74, 0x10, 0x2E, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x74, 0x04,
-0xF0, 0xAF, 0x05, 0xD1, 0xE8, 0xE0, 0x54, 0x01,
-0xFE, 0x90, 0x96, 0xAA, 0xE0, 0x25, 0xE0, 0x25,
-0xE0, 0xFB, 0xEE, 0x44, 0x02, 0x4B, 0xD1, 0xE7,
-0xEE, 0xF0, 0x74, 0x11, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0x74, 0xFF, 0xF0, 0x74,
-0x29, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xE0, 0x54, 0xF7, 0xF0, 0x74, 0x0D, 0x2D,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
-0x44, 0x80, 0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x74, 0x21, 0x2F, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0xEF,
-0xB4, 0xFF, 0x06, 0x90, 0x93, 0x5E, 0xED, 0xF0,
-0x22, 0xEF, 0xF4, 0xFE, 0x90, 0x93, 0x5E, 0xE0,
-0x5E, 0xFE, 0xED, 0x5F, 0x4E, 0xF0, 0x22, 0xEF,
-0xB4, 0xFF, 0x06, 0x90, 0x93, 0x5D, 0xED, 0xF0,
-0x22, 0xEF, 0xF4, 0xFE, 0x90, 0x93, 0x5D, 0x80,
-0xE6, 0x90, 0x94, 0xB6, 0x02, 0x86, 0x76, 0xE4,
-0x75, 0xF0, 0x01, 0x02, 0x02, 0xE7, 0xF1, 0xE9,
-0x12, 0xA0, 0x02, 0x7A, 0x93, 0x79, 0x1B, 0x02,
-0x69, 0xF5, 0x90, 0x94, 0xB6, 0x12, 0x86, 0x6D,
-0x8B, 0x45, 0x8A, 0x46, 0x89, 0x47, 0x75, 0x48,
-0x05, 0x7B, 0x01, 0x22, 0x12, 0x9F, 0xE9, 0x11,
-0x02, 0x7A, 0x93, 0x79, 0x20, 0x02, 0x69, 0xF5,
-0x90, 0x96, 0xA5, 0x12, 0x86, 0x76, 0x90, 0x96,
-0xA4, 0xEF, 0xF0, 0x12, 0x86, 0x7F, 0xA0, 0xB3,
-0x00, 0xA0, 0xBC, 0x01, 0xA0, 0xC5, 0x06, 0xA0,
-0xD9, 0x08, 0xA0, 0xE2, 0x09, 0xA0, 0xEB, 0x0A,
-0xA0, 0xF3, 0x12, 0xA0, 0xFB, 0x13, 0xA1, 0x03,
-0x14, 0xA1, 0x0C, 0x1E, 0xA1, 0x15, 0x20, 0xA1,
-0x1E, 0x25, 0xA1, 0x27, 0x26, 0xA1, 0x30, 0x29,
-0xA1, 0x38, 0x2A, 0xA1, 0x41, 0x40, 0xA1, 0x4C,
-0x42, 0xA1, 0x5A, 0x43, 0xA1, 0x63, 0x44, 0xA2,
-0x2C, 0x47, 0xA1, 0x6C, 0x49, 0xA1, 0x74, 0x60,
-0xA1, 0x7D, 0x61, 0xA1, 0x86, 0x62, 0xA1, 0x8F,
-0x63, 0xA1, 0x98, 0x64, 0xA1, 0xA1, 0x65, 0xA1,
-0xAA, 0x66, 0xA1, 0xB3, 0x67, 0xA1, 0xBC, 0x68,
-0xA1, 0xC5, 0x69, 0xA1, 0xCD, 0x6B, 0xA1, 0xD6,
-0x6C, 0xA1, 0xDF, 0x6D, 0xA1, 0xE8, 0x6E, 0xA1,
-0xF1, 0x6F, 0xA1, 0xFA, 0x70, 0xA2, 0x03, 0xC2,
-0xA2, 0x0B, 0xC3, 0xA2, 0x14, 0xC4, 0xA0, 0xCD,
-0xC6, 0xA0, 0xCD, 0xC7, 0xA0, 0xCD, 0xC8, 0x00,
-0x00, 0xA2, 0x1D, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0x02, 0x86, 0xE0, 0x90, 0x96, 0xA5, 0x12,
-0x86, 0x6D, 0x02, 0x88, 0x04, 0x90, 0x96, 0xA5,
-0x12, 0x86, 0x6D, 0x61, 0xAD, 0x90, 0x96, 0xA4,
-0xE0, 0xFF, 0xA3, 0x12, 0x86, 0x6D, 0x02, 0xBF,
-0xBF, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02,
-0x97, 0xFA, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D,
-0x02, 0x9F, 0xF6, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0x01, 0x14, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0xE1, 0xEF, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0xC1, 0x27, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0x02, 0xA8, 0x03, 0x90, 0x96, 0xA5, 0x12,
-0x86, 0x6D, 0x02, 0x9B, 0xB6, 0x90, 0x96, 0xA5,
-0x12, 0x86, 0x6D, 0x02, 0x87, 0x30, 0x90, 0x96,
-0xA5, 0x12, 0x86, 0x6D, 0x02, 0xA8, 0x12, 0x90,
-0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02, 0xA8, 0x55,
-0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x81, 0x9B,
-0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02, 0xB0,
-0x18, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x90,
-0x8A, 0xA5, 0x80, 0x09, 0x90, 0x96, 0xA5, 0x12,
-0x86, 0x6D, 0x90, 0x8A, 0xB5, 0x91, 0x42, 0x02,
-0x04, 0x7E, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D,
-0x02, 0x25, 0xEC, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0x02, 0x5B, 0xF3, 0x90, 0x96, 0xA5, 0x12,
-0x86, 0x6D, 0xE1, 0xDF, 0x90, 0x96, 0xA5, 0x12,
-0x86, 0x6D, 0x02, 0x98, 0xB2, 0x90, 0x96, 0xA5,
-0x12, 0x86, 0x6D, 0x02, 0x77, 0x4F, 0x90, 0x96,
-0xA5, 0x12, 0x86, 0x6D, 0x02, 0x7C, 0x60, 0x90,
-0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02, 0x7A, 0xC6,
-0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02, 0x5D,
-0x36, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02,
-0x7B, 0xE9, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D,
-0x02, 0x70, 0x33, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0x02, 0x48, 0xC9, 0x90, 0x96, 0xA5, 0x12,
-0x86, 0x6D, 0x02, 0x79, 0xF3, 0x90, 0x96, 0xA5,
-0x12, 0x86, 0x6D, 0x80, 0x60, 0x90, 0x96, 0xA5,
-0x12, 0x86, 0x6D, 0x02, 0x51, 0x7B, 0x90, 0x96,
-0xA5, 0x12, 0x86, 0x6D, 0x02, 0x79, 0x30, 0x90,
-0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02, 0x57, 0xF2,
-0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02, 0x74,
-0x8D, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D, 0x02,
-0x78, 0x9A, 0x90, 0x96, 0xA5, 0x12, 0x86, 0x6D,
-0x02, 0x5E, 0x0B, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0x81, 0x7C, 0x90, 0x96, 0xA5, 0x12, 0x86,
-0x6D, 0x02, 0xB7, 0xE9, 0x90, 0x96, 0xA5, 0x12,
-0x86, 0x6D, 0x02, 0xB7, 0xFF, 0x90, 0x01, 0xC0,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x96, 0xA4, 0xE0,
-0x90, 0x01, 0xC2, 0xF0, 0x22, 0x12, 0x02, 0x06,
-0xFF, 0x12, 0x98, 0xAC, 0x90, 0x94, 0xB8, 0x12,
-0x87, 0xE9, 0x90, 0x94, 0xB9, 0x12, 0x87, 0xF3,
-0x90, 0x94, 0xBA, 0x12, 0x87, 0xFD, 0x90, 0x94,
-0xBB, 0x12, 0x87, 0x29, 0x90, 0x94, 0xBC, 0xF1,
-0xD8, 0x90, 0x94, 0xBD, 0xF0, 0xEF, 0x12, 0x86,
-0x7F, 0xA2, 0x7B, 0x00, 0xA2, 0x87, 0x01, 0xA2,
-0x8E, 0x02, 0xA2, 0x96, 0x03, 0xA2, 0x9E, 0x04,
-0xA2, 0xA5, 0x05, 0xA2, 0xAE, 0x06, 0xA2, 0xD7,
-0x07, 0xA3, 0x35, 0x08, 0xA3, 0x37, 0x09, 0x00,
-0x00, 0xA3, 0x76, 0x90, 0x94, 0xB6, 0x74, 0x02,
-0xF0, 0xA3, 0x74, 0x29, 0xF0, 0x61, 0x7C, 0x71,
-0xA5, 0x74, 0x2A, 0xF0, 0x61, 0x7C, 0x71, 0x97,
-0xA3, 0x74, 0x31, 0xF0, 0x61, 0x7C, 0x71, 0x97,
-0xA3, 0x74, 0x32, 0xF0, 0x61, 0x7C, 0x71, 0xA5,
-0x74, 0x33, 0xF0, 0x61, 0x7C, 0x71, 0x9E, 0x90,
-0x8A, 0x83, 0x91, 0x42, 0x61, 0x93, 0x90, 0x94,
-0xB8, 0xE0, 0x90, 0x88, 0xE1, 0xF0, 0x90, 0x94,
-0xB9, 0xE0, 0x90, 0x88, 0xE2, 0xF0, 0x90, 0x94,
-0xBA, 0xE0, 0x90, 0x88, 0xE3, 0xF0, 0x90, 0x94,
-0xBB, 0xE0, 0x90, 0x88, 0xE4, 0xF0, 0x90, 0x94,
-0xBC, 0xE0, 0x90, 0x88, 0xE5, 0xF0, 0x22, 0x90,
-0x94, 0xB8, 0xE0, 0x90, 0x94, 0xAD, 0xF0, 0x90,
-0x94, 0xBB, 0x12, 0x8E, 0xD1, 0x78, 0x10, 0x12,
-0x03, 0xFE, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x12, 0x8E, 0xD0, 0x78, 0x18, 0x12,
-0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0x12, 0x86, 0x54, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x94, 0xBA,
-0x12, 0x8E, 0xD1, 0x78, 0x08, 0x12, 0x03, 0xFE,
-0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
-0x12, 0x86, 0x54, 0x12, 0xD4, 0x2C, 0x90, 0x94,
-0xB9, 0x12, 0x8E, 0xD1, 0x12, 0x86, 0x54, 0x90,
-0x94, 0xA3, 0x02, 0x04, 0x31, 0x81, 0x4C, 0x90,
-0x94, 0xAF, 0xE0, 0x44, 0x01, 0xFF, 0xF0, 0x90,
-0x94, 0xB8, 0xE0, 0x54, 0x7F, 0x25, 0xE0, 0xFE,
-0xEF, 0x54, 0x01, 0x4E, 0x90, 0x94, 0xAF, 0xF0,
-0xE0, 0xFF, 0xC3, 0x13, 0x54, 0x7F, 0xC3, 0x94,
-0x1E, 0x50, 0x06, 0xEF, 0x54, 0x01, 0x44, 0x3C,
-0xF0, 0x90, 0x94, 0xAF, 0xE0, 0xFF, 0xC3, 0x13,
-0x54, 0x7F, 0xD3, 0x94, 0x50, 0x40, 0x27, 0xEF,
-0x54, 0x01, 0x44, 0xA0, 0xF0, 0x22, 0x71, 0x97,
-0xA3, 0x74, 0xFF, 0xF0, 0x90, 0x94, 0xB7, 0xE0,
-0xFF, 0x90, 0x94, 0xB6, 0xE0, 0xFD, 0x71, 0x9E,
-0x90, 0x8A, 0xCF, 0xE0, 0xF8, 0xA3, 0xE0, 0xF5,
-0x82, 0x88, 0x83, 0x12, 0x04, 0x7E, 0x22, 0x90,
-0x94, 0xB6, 0x74, 0x01, 0xF0, 0x22, 0x7B, 0x01,
-0x7A, 0x94, 0x79, 0xB8, 0x22, 0x90, 0x94, 0xB6,
-0x74, 0x06, 0xF0, 0xA3, 0x22, 0x12, 0x02, 0x06,
-0x64, 0x01, 0x60, 0x02, 0x81, 0x3E, 0x90, 0x94,
-0xFD, 0xF0, 0x90, 0x94, 0xFD, 0xE0, 0xFF, 0xC3,
-0x94, 0x10, 0x50, 0x28, 0xEF, 0x12, 0xC0, 0xD5,
-0x7A, 0x94, 0x79, 0xFC, 0x12, 0x5F, 0xA6, 0xBF,
-0x01, 0x12, 0x90, 0x94, 0xFC, 0xE0, 0xFF, 0xA3,
-0xE0, 0x24, 0xFE, 0xF5, 0x82, 0xE4, 0x34, 0x94,
-0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x94, 0xFD, 0xE0,
-0x04, 0xF0, 0x80, 0xCE, 0x75, 0x45, 0x01, 0x75,
-0x46, 0x94, 0x75, 0x47, 0xFE, 0x75, 0x48, 0x08,
-0x71, 0x9E, 0x12, 0x69, 0xF5, 0x90, 0x94, 0xB6,
-0x74, 0x24, 0xF0, 0x90, 0x94, 0xD8, 0x74, 0x08,
-0xF0, 0x75, 0x45, 0x01, 0x75, 0x46, 0x95, 0x75,
-0x47, 0x06, 0xF5, 0x48, 0x7B, 0x01, 0x7A, 0x94,
-0x79, 0xDB, 0x12, 0x69, 0xF5, 0x90, 0x94, 0xD9,
-0x74, 0x25, 0xF0, 0x90, 0x94, 0xFB, 0x74, 0x08,
-0x12, 0x9B, 0xFF, 0x91, 0x3F, 0x12, 0x04, 0x7E,
-0x7B, 0x01, 0x7A, 0x94, 0x79, 0xD9, 0x12, 0x8B,
-0x34, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x22, 0x90,
-0x8A, 0x77, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xF5,
-0x82, 0x8E, 0x83, 0x22, 0x90, 0x94, 0xBE, 0x74,
-0x27, 0xF0, 0x90, 0x94, 0xE0, 0x74, 0x06, 0xF0,
-0x90, 0x94, 0xC0, 0x74, 0x08, 0xF0, 0xE4, 0x91,
-0x94, 0x90, 0x94, 0xB4, 0xE0, 0x90, 0x94, 0xC4,
-0xF0, 0x90, 0x94, 0xB5, 0xE0, 0x90, 0x94, 0xC5,
-0xF0, 0x7B, 0x01, 0x7A, 0x94, 0x79, 0xBE, 0x91,
-0x3F, 0x02, 0x04, 0x7E, 0x12, 0x02, 0x06, 0x90,
-0x93, 0x4A, 0xF0, 0x70, 0x03, 0xF1, 0xD1, 0xF0,
-0x22, 0xE4, 0x90, 0x95, 0x45, 0xF0, 0x90, 0x95,
-0xB0, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
-0xA3, 0xF0, 0x22, 0x12, 0x02, 0x06, 0x54, 0x01,
-0xFF, 0x90, 0x93, 0x31, 0xE0, 0x54, 0xFE, 0x4F,
-0xF0, 0x30, 0xE0, 0x03, 0xE4, 0x91, 0x94, 0x22,
-0x90, 0x93, 0x03, 0xE0, 0x54, 0xFE, 0xF1, 0xAE,
-0x90, 0x93, 0x0A, 0x91, 0x93, 0x90, 0x93, 0x25,
-0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0xF1, 0xA1,
-0x12, 0x7B, 0xDB, 0x90, 0x8A, 0xC5, 0x12, 0x88,
-0xCD, 0x12, 0xB0, 0xE3, 0x12, 0x8E, 0xD8, 0xB1,
-0x06, 0x91, 0xB0, 0x90, 0x8A, 0x73, 0x12, 0x88,
-0xCD, 0x90, 0x00, 0x6A, 0xE0, 0x30, 0xE2, 0x14,
-0x90, 0x92, 0x20, 0x74, 0x01, 0xF0, 0xA3, 0x74,
-0xF4, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x68, 0x7E,
-0x01, 0x12, 0x66, 0x33, 0x12, 0xD0, 0x45, 0x90,
-0x93, 0x4A, 0x74, 0x01, 0xF0, 0x22, 0x90, 0x93,
-0x29, 0xE0, 0x54, 0xFE, 0xF0, 0x54, 0xFD, 0xF0,
-0x54, 0xEF, 0xF0, 0x44, 0x08, 0xF0, 0x90, 0x86,
-0xB3, 0xE0, 0xFF, 0x64, 0x02, 0x70, 0x29, 0xB1,
-0xA7, 0x30, 0xE0, 0x02, 0x7E, 0x01, 0x90, 0x93,
-0x2F, 0xB1, 0xA5, 0x30, 0xE1, 0x02, 0x7E, 0x01,
-0x90, 0x93, 0x2D, 0xB1, 0xA5, 0x30, 0xE2, 0x02,
-0x7E, 0x01, 0x90, 0x93, 0x2E, 0xEE, 0xF0, 0x90,
-0xFD, 0x80, 0xE0, 0x90, 0x02, 0xFB, 0xF0, 0x22,
-0xEF, 0x64, 0x01, 0x70, 0x1D, 0xB1, 0x9E, 0x30,
-0xE0, 0x02, 0x7F, 0x01, 0x90, 0x93, 0x2F, 0xB1,
-0x9C, 0x30, 0xE1, 0x02, 0x7F, 0x01, 0x90, 0x93,
-0x2D, 0xB1, 0x9C, 0x30, 0xE2, 0x02, 0x7F, 0x01,
-0x80, 0x23, 0x90, 0x86, 0xB3, 0xE0, 0x64, 0x03,
-0x70, 0x20, 0xB1, 0x95, 0x30, 0xE0, 0x02, 0x7F,
-0x01, 0x90, 0x93, 0x2F, 0xB1, 0x93, 0x30, 0xE1,
-0x02, 0x7F, 0x01, 0x90, 0x93, 0x2D, 0xB1, 0x93,
-0x30, 0xE2, 0x02, 0x7F, 0x01, 0x90, 0x93, 0x2E,
-0xEF, 0xF0, 0x22, 0xEF, 0xF0, 0x90, 0xFD, 0x78,
-0xE0, 0x7F, 0x00, 0x22, 0xEF, 0xF0, 0x90, 0xFD,
-0x70, 0xE0, 0x7F, 0x00, 0x22, 0xEE, 0xF0, 0x90,
-0xFD, 0x80, 0xE0, 0x7E, 0x00, 0x22, 0x7E, 0x00,
-0x7F, 0x33, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x88,
-0x79, 0x9D, 0x12, 0x04, 0x80, 0x90, 0x88, 0x9E,
-0x74, 0x0B, 0xF0, 0xA3, 0x74, 0x08, 0xF0, 0x7E,
-0x00, 0x7F, 0x14, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
-0x94, 0x79, 0xA2, 0x12, 0x04, 0x80, 0x90, 0x86,
-0xB3, 0xE0, 0xFC, 0x64, 0x02, 0x70, 0x19, 0xB1,
-0xA7, 0x30, 0xE2, 0x02, 0x7E, 0x01, 0xEE, 0x54,
-0x01, 0xC4, 0x33, 0x33, 0x54, 0xC0, 0xFE, 0x90,
-0x88, 0xA0, 0xE0, 0x54, 0xBF, 0x4E, 0xF0, 0x22,
-0xEC, 0x64, 0x01, 0x70, 0x09, 0xB1, 0x9E, 0x30,
-0xE2, 0x02, 0x7F, 0x01, 0x80, 0x0F, 0x90, 0x86,
-0xB3, 0xE0, 0x64, 0x03, 0x70, 0x18, 0xB1, 0x95,
-0x30, 0xE2, 0x02, 0x7F, 0x01, 0xEF, 0x54, 0x01,
-0xC4, 0x33, 0x33, 0x54, 0xC0, 0xFF, 0x90, 0x88,
-0xA0, 0xE0, 0x54, 0xBF, 0x4F, 0xF0, 0x22, 0x12,
-0x02, 0x06, 0xFF, 0x54, 0x80, 0xFE, 0x90, 0x93,
-0x57, 0xE0, 0x54, 0x7F, 0x4E, 0xFE, 0xF0, 0xEF,
-0x54, 0x40, 0xFF, 0xEE, 0x54, 0xBF, 0x4F, 0xF1,
-0xA7, 0x54, 0x20, 0xFD, 0xEF, 0x54, 0xDF, 0x4D,
-0xFF, 0x90, 0x93, 0x57, 0xF0, 0xEE, 0x54, 0x10,
-0xFE, 0xEF, 0x54, 0xEF, 0x4E, 0xFF, 0xF0, 0x12,
-0x02, 0x06, 0x54, 0x0F, 0xFE, 0xEF, 0x54, 0xF0,
-0x4E, 0x90, 0x93, 0x57, 0xF0, 0x12, 0x98, 0xAC,
-0xFF, 0x54, 0x7F, 0x90, 0x93, 0x59, 0xF0, 0xEF,
-0x54, 0x80, 0x12, 0x8F, 0xF1, 0xFF, 0x90, 0x93,
-0x58, 0xE0, 0x54, 0xFE, 0x12, 0x87, 0xE8, 0x90,
-0x93, 0x5A, 0x12, 0x87, 0xF3, 0x54, 0x01, 0x25,
-0xE0, 0xFF, 0x90, 0x93, 0x58, 0xE0, 0x54, 0xFD,
-0x4F, 0xF0, 0xD1, 0x9C, 0x20, 0xE0, 0x02, 0x7D,
-0x01, 0x02, 0x93, 0x47, 0x90, 0x93, 0x57, 0xE0,
-0xFE, 0x54, 0x0F, 0xFF, 0xEE, 0xC4, 0x13, 0x13,
-0x54, 0x03, 0x7D, 0x00, 0x22, 0x90, 0x93, 0x57,
-0xE0, 0xFF, 0x12, 0x8F, 0xF1, 0x30, 0xE0, 0x1B,
-0xEF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x03, 0x12,
-0xD0, 0x62, 0x90, 0x93, 0x58, 0xE0, 0x30, 0xE0,
-0x0A, 0xD1, 0x9C, 0x20, 0xE0, 0x02, 0x7D, 0x01,
-0x12, 0x93, 0x47, 0x22, 0x90, 0x88, 0x36, 0xE0,
-0x60, 0x14, 0x90, 0x06, 0x92, 0xE0, 0x30, 0xE1,
-0x08, 0x90, 0x8B, 0x01, 0x12, 0x88, 0xCD, 0x80,
-0x05, 0x12, 0xDD, 0xA3, 0xD1, 0xF0, 0x80, 0xBD,
-0xD1, 0xF9, 0x8C, 0x83, 0x7D, 0x01, 0x02, 0x04,
-0x7E, 0x90, 0x88, 0x38, 0xE0, 0xFF, 0x90, 0x8A,
-0xB9, 0xE0, 0xFC, 0xA3, 0xE0, 0xF5, 0x82, 0x22,
-0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xBF, 0x01, 0x0F,
-0x90, 0x88, 0x36, 0xE0, 0x60, 0x09, 0xF1, 0x20,
-0xF0, 0x54, 0x07, 0x70, 0x02, 0xD1, 0xF0, 0x22,
-0x90, 0x88, 0x3A, 0xE0, 0x54, 0xFE, 0x22, 0xE4,
-0xF5, 0x77, 0x90, 0x06, 0xA9, 0xE0, 0xF5, 0x77,
-0x54, 0xC0, 0x70, 0x12, 0xF1, 0x20, 0xF0, 0x54,
-0xFD, 0xF0, 0xD1, 0xF0, 0x90, 0x88, 0x39, 0xE0,
-0x60, 0x46, 0xF1, 0xB5, 0xF0, 0x22, 0xE5, 0x77,
-0x30, 0xE6, 0x21, 0x90, 0x88, 0x36, 0xE0, 0x64,
-0x01, 0x70, 0x1C, 0x90, 0x88, 0x3A, 0xE0, 0x44,
-0x01, 0xF1, 0xE7, 0x64, 0x02, 0x60, 0x08, 0x90,
-0x8A, 0xE1, 0x12, 0x88, 0xCD, 0x80, 0x08, 0x12,
-0xDB, 0xAA, 0x80, 0x03, 0xF1, 0x20, 0xF0, 0xE5,
-0x77, 0x90, 0x88, 0x3A, 0x30, 0xE7, 0x0D, 0xE0,
-0x44, 0x02, 0xF1, 0x89, 0x90, 0x88, 0x31, 0xE0,
-0x44, 0x04, 0xF0, 0x22, 0xE0, 0x54, 0xFD, 0xF0,
-0x22, 0xF0, 0xE4, 0x90, 0x92, 0x20, 0xF0, 0x90,
-0x88, 0x94, 0xE0, 0x90, 0x92, 0x21, 0xF0, 0xE4,
-0xFB, 0xFD, 0x7F, 0x54, 0x7E, 0x01, 0x02, 0x66,
-0x33, 0xE4, 0xFD, 0xFF, 0x02, 0x6E, 0x71, 0xFF,
-0xF0, 0x12, 0x02, 0x06, 0xFE, 0x22, 0xF0, 0xE4,
-0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x00, 0x02,
-0xE0, 0x44, 0x01, 0x22, 0x90, 0x88, 0x39, 0xE0,
-0xB4, 0x04, 0x03, 0xF1, 0xB5, 0xF0, 0x90, 0x88,
-0x9D, 0xE0, 0x20, 0xE0, 0x03, 0x12, 0xBB, 0x1C,
-0x22, 0x90, 0x05, 0x21, 0xE0, 0x54, 0x7F, 0x22,
-0xF0, 0x90, 0x00, 0x06, 0x02, 0x02, 0x1F, 0x12,
-0x02, 0x06, 0x90, 0x96, 0x0C, 0xF0, 0x22, 0xF0,
-0x90, 0x88, 0x34, 0xE0, 0x54, 0x0F, 0x22, 0x12,
-0x02, 0x06, 0xFF, 0x90, 0x93, 0x28, 0xF0, 0xBF,
-0x01, 0x08, 0x12, 0x9C, 0x07, 0xE4, 0x90, 0x93,
-0x28, 0xF0, 0x22, 0x12, 0x02, 0x06, 0x54, 0x01,
-0xFF, 0x90, 0x93, 0x5C, 0xE0, 0x54, 0xFE, 0x4F,
-0xF0, 0x22, 0x12, 0x02, 0x06, 0x90, 0x88, 0x9C,
-0xF0, 0x60, 0x39, 0xA3, 0xE0, 0x20, 0xE0, 0x34,
-0x90, 0x8A, 0xB9, 0x12, 0x8B, 0x46, 0xE4, 0xFD,
-0x7F, 0x04, 0x12, 0x04, 0x7E, 0x90, 0x88, 0x9B,
-0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x1D, 0xEF,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x20, 0xE0, 0x14,
-0x90, 0x88, 0x9B, 0xE0, 0x13, 0x13, 0x54, 0x3F,
-0x30, 0xE0, 0x04, 0x7F, 0x0D, 0x80, 0x02, 0x7F,
-0x09, 0x12, 0x71, 0x9A, 0x22, 0x12, 0x9F, 0xE9,
-0x12, 0xDD, 0x7D, 0x90, 0x93, 0x29, 0x12, 0xDC,
-0xB2, 0x12, 0xA7, 0xA7, 0x12, 0xDD, 0x47, 0x90,
-0x93, 0x29, 0x12, 0xDD, 0x74, 0x4E, 0xF0, 0x90,
-0x05, 0x52, 0xE0, 0x54, 0x07, 0x90, 0x94, 0xB6,
-0x60, 0x13, 0x12, 0x98, 0xA9, 0xFD, 0x90, 0x05,
-0x56, 0xE0, 0xC3, 0x9D, 0x90, 0x93, 0x2B, 0xF0,
-0xA3, 0xED, 0xF0, 0x80, 0x23, 0x12, 0x98, 0xA9,
-0xFB, 0xFF, 0x90, 0x05, 0x54, 0xE0, 0xC3, 0x9F,
-0xFF, 0xE4, 0x94, 0x00, 0xFE, 0x7C, 0x00, 0x7D,
-0x05, 0x12, 0x02, 0x92, 0x90, 0x93, 0x2B, 0xEF,
-0xF0, 0xEB, 0x75, 0xF0, 0x05, 0x84, 0xA3, 0xF0,
-0x12, 0x8A, 0xC6, 0x20, 0xE0, 0x12, 0x12, 0x88,
-0xCA, 0x90, 0x8A, 0xF9, 0x12, 0x8B, 0x46, 0x31,
-0x17, 0x90, 0x01, 0x57, 0xE4, 0xF0, 0x80, 0x0B,
-0x90, 0x8A, 0x89, 0x12, 0x8B, 0x46, 0x12, 0x8F,
-0xE6, 0xB1, 0x94, 0xB1, 0x9C, 0x20, 0xE0, 0x04,
-0xEF, 0x44, 0x20, 0xF0, 0x12, 0xDD, 0x04, 0x30,
-0xE0, 0x1D, 0x90, 0x88, 0x36, 0x74, 0x01, 0xF0,
-0xE4, 0x90, 0x88, 0x38, 0xF0, 0x90, 0x88, 0x32,
-0xE0, 0x44, 0x04, 0x31, 0x67, 0xFB, 0x90, 0x92,
-0x98, 0x74, 0x06, 0xF0, 0x02, 0x6E, 0x2F, 0xE4,
-0x90, 0x88, 0x36, 0xF0, 0x90, 0x88, 0x38, 0x74,
-0x0C, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0x54, 0xFE,
-0xF0, 0xA3, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0xE4,
-0xFD, 0xFF, 0x02, 0x04, 0x7E, 0x12, 0xD0, 0xB2,
-0x90, 0x95, 0xE8, 0xEF, 0xF0, 0x90, 0x8A, 0x89,
-0x30, 0xE0, 0x13, 0x12, 0x8B, 0x46, 0x7D, 0x01,
-0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88, 0x33,
-0xE0, 0x44, 0x04, 0xF0, 0x80, 0x05, 0x12, 0x8B,
-0x46, 0x31, 0x17, 0x90, 0x95, 0xE8, 0xE0, 0x30,
-0xE6, 0x11, 0x90, 0x01, 0x2F, 0xE0, 0x30, 0xE7,
-0x04, 0xE4, 0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F,
-0x74, 0x80, 0xF0, 0x31, 0x68, 0xFB, 0x90, 0x92,
-0x98, 0x74, 0x02, 0xF0, 0x02, 0x6E, 0x2F, 0xF0,
-0x90, 0x88, 0x48, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD,
-0x90, 0x88, 0x4F, 0xE0, 0x22, 0x90, 0x88, 0x85,
-0x12, 0x04, 0xB8, 0xC0, 0x06, 0xC0, 0x07, 0x90,
-0x94, 0xA0, 0xE0, 0x24, 0x46, 0xFF, 0x90, 0x94,
-0x9F, 0xE0, 0x34, 0x00, 0xAB, 0x07, 0xFA, 0xE4,
-0xF9, 0xF8, 0xD0, 0x07, 0xD0, 0x06, 0x12, 0x86,
-0x39, 0x90, 0x88, 0x85, 0x71, 0x92, 0xEF, 0x24,
-0x46, 0xFF, 0xE4, 0x3E, 0xFE, 0xE4, 0x3D, 0xFD,
-0xE4, 0x3C, 0xFC, 0x90, 0x88, 0x89, 0x71, 0x92,
-0x90, 0x88, 0x85, 0x12, 0x86, 0x61, 0xC3, 0x12,
-0x03, 0xDA, 0x50, 0x02, 0x41, 0x77, 0x90, 0x88,
-0x89, 0x12, 0x86, 0x61, 0x90, 0x88, 0x85, 0x12,
-0x04, 0xB8, 0x12, 0x86, 0x39, 0x90, 0x95, 0xC8,
-0x12, 0x04, 0x31, 0x90, 0x88, 0x31, 0xE0, 0x30,
-0xE0, 0x34, 0x90, 0x88, 0x53, 0xE0, 0x24, 0x04,
-0xFF, 0xE4, 0x33, 0xFE, 0xEF, 0x78, 0x03, 0xC3,
-0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24, 0x50,
-0xFF, 0xE4, 0x3E, 0xFE, 0x90, 0x88, 0x4E, 0xE0,
-0xFD, 0xC3, 0xEF, 0x9D, 0xFB, 0xEE, 0x94, 0x00,
-0xFA, 0x71, 0x81, 0x78, 0x07, 0x12, 0x03, 0xEB,
-0xEB, 0x2F, 0xFF, 0xEA, 0x80, 0x22, 0x90, 0x88,
-0x33, 0xF1, 0x0F, 0x30, 0xE0, 0x02, 0x61, 0x71,
-0x71, 0x81, 0x78, 0x07, 0x12, 0x03, 0xEB, 0x90,
-0x88, 0x4E, 0xE0, 0xFD, 0xC3, 0x74, 0x60, 0x9D,
-0xCD, 0xE4, 0x94, 0x00, 0xCD, 0x2F, 0xFF, 0xED,
-0x3E, 0x90, 0x95, 0xC4, 0xF0, 0xA3, 0xEF, 0xF0,
-0xC3, 0x90, 0x95, 0xC5, 0xE0, 0x94, 0xA0, 0x90,
-0x95, 0xC4, 0xE0, 0x94, 0x00, 0x50, 0x30, 0xA3,
-0xE0, 0xFB, 0x24, 0x5F, 0x71, 0x8A, 0xE0, 0x04,
-0xF0, 0x71, 0x81, 0xEF, 0x54, 0x7F, 0xFF, 0x74,
-0xFF, 0x2B, 0x71, 0x79, 0xE0, 0xFE, 0xEF, 0xC3,
-0x9E, 0x50, 0x09, 0x90, 0x95, 0xC4, 0xA3, 0xE0,
-0x71, 0x77, 0xEF, 0xF0, 0x90, 0x88, 0x4C, 0xE0,
-0x04, 0xF0, 0xE0, 0x90, 0x00, 0xFE, 0xF0, 0x90,
-0x88, 0x4C, 0xE0, 0xFF, 0xD3, 0x90, 0x88, 0x90,
-0xE0, 0x9F, 0x90, 0x88, 0x8F, 0xE0, 0x94, 0x00,
-0x40, 0x02, 0x61, 0x71, 0xE4, 0xFF, 0xFE, 0x71,
-0x87, 0xE0, 0x2F, 0xFF, 0x90, 0x88, 0x91, 0xE0,
-0xFD, 0xEF, 0xD3, 0x9D, 0x40, 0x07, 0x90, 0x95,
-0xC6, 0xEE, 0xF0, 0x80, 0x05, 0x0E, 0xEE, 0xB4,
-0xA0, 0xE5, 0x71, 0x9B, 0x40, 0x02, 0x80, 0x15,
-0x90, 0x95, 0xC6, 0xE0, 0x04, 0xFE, 0xEE, 0xC3,
-0x94, 0xA0, 0x50, 0x13, 0x71, 0x87, 0xE0, 0x2F,
-0xFF, 0x71, 0x9B, 0x40, 0x07, 0x90, 0x95, 0xC7,
-0xEE, 0xF0, 0x80, 0x03, 0x0E, 0x80, 0xE7, 0x90,
-0x05, 0x5E, 0xE0, 0xFF, 0x71, 0x72, 0xE0, 0xFD,
-0xEF, 0xC3, 0x9D, 0x40, 0x11, 0xEF, 0x9D, 0x90,
-0x05, 0x5E, 0xF0, 0x90, 0x88, 0x51, 0xEE, 0xF0,
-0x90, 0x95, 0xC7, 0xE0, 0x80, 0x18, 0x71, 0x72,
-0xE0, 0xFD, 0xC3, 0x74, 0x80, 0x9D, 0x2F, 0x90,
-0x05, 0x5E, 0xF0, 0xEE, 0x04, 0x90, 0x88, 0x51,
-0xF0, 0x90, 0x95, 0xC7, 0xE0, 0x04, 0x90, 0x88,
-0x52, 0xF0, 0x90, 0x88, 0x51, 0xE0, 0xFF, 0xC3,
-0x94, 0x50, 0x40, 0x0A, 0xEF, 0x24, 0xB0, 0x90,
-0x88, 0x49, 0xF0, 0xE4, 0x80, 0x0E, 0xE4, 0x90,
-0x88, 0x49, 0xF0, 0x90, 0x88, 0x51, 0xE0, 0xFF,
-0xC3, 0x74, 0x50, 0x9F, 0x90, 0x88, 0x48, 0xF0,
-0x90, 0x88, 0x51, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3,
-0x9F, 0x90, 0x88, 0x4F, 0xF0, 0x90, 0x88, 0x31,
-0xE0, 0x90, 0x88, 0x8E, 0xE0, 0x24, 0x08, 0xFF,
-0x90, 0x88, 0x4F, 0xE0, 0x2F, 0xF0, 0x90, 0x88,
-0x4F, 0xE0, 0xC3, 0x94, 0x50, 0x50, 0x03, 0x74,
-0x50, 0xF0, 0x90, 0x88, 0x4F, 0xE0, 0x24, 0x10,
-0x31, 0x67, 0xFB, 0x12, 0xDC, 0x43, 0x90, 0x8A,
-0xA3, 0x12, 0x8B, 0x46, 0xE4, 0xFF, 0x12, 0x04,
-0x7E, 0x22, 0x90, 0x95, 0xC6, 0xE0, 0xFE, 0x24,
-0xFF, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
-0x22, 0x90, 0x95, 0xC8, 0x02, 0x04, 0xB8, 0x74,
-0x5F, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5,
-0x83, 0x22, 0x12, 0x04, 0x31, 0x90, 0x88, 0x89,
-0x02, 0x04, 0xB8, 0x90, 0x88, 0x91, 0xE0, 0xFD,
-0xC3, 0x90, 0x88, 0x90, 0xE0, 0x9D, 0xFD, 0x90,
-0x88, 0x8F, 0xE0, 0x94, 0x00, 0xFC, 0xEF, 0xD3,
-0x9D, 0xE4, 0x9C, 0x22, 0xE4, 0xFE, 0x71, 0x87,
-0xE4, 0xF0, 0x74, 0xFF, 0x2E, 0x71, 0x79, 0x74,
-0xFF, 0xF0, 0x0E, 0xEE, 0xB4, 0xA0, 0xEF, 0xE4,
-0x90, 0x88, 0x4D, 0xF0, 0x90, 0x88, 0x4C, 0xF0,
-0x90, 0x88, 0x50, 0xF0, 0xEF, 0xB4, 0x01, 0x07,
-0xA3, 0x74, 0xA0, 0xF0, 0xE4, 0xA3, 0xF0, 0x22,
-0x90, 0x88, 0xB8, 0xE0, 0x30, 0xE0, 0x05, 0x90,
-0x8A, 0x8F, 0x80, 0x03, 0x90, 0x8A, 0x87, 0x12,
-0x88, 0xCD, 0x90, 0x88, 0xE6, 0xE0, 0x30, 0xE0,
-0x04, 0xA3, 0xE0, 0x04, 0xF0, 0x90, 0x88, 0xE7,
-0xE0, 0x64, 0x08, 0x70, 0x21, 0x90, 0x88, 0xE6,
-0xE0, 0x30, 0xE0, 0x15, 0x12, 0xB4, 0x08, 0xF0,
-0xE4, 0xFD, 0x12, 0x76, 0xF7, 0x90, 0x88, 0xE6,
-0xE0, 0x54, 0xFE, 0xF0, 0xE4, 0xA3, 0xF0, 0x80,
-0x05, 0xE4, 0x90, 0x88, 0xE7, 0xF0, 0x12, 0x9D,
-0xBD, 0x30, 0xE0, 0x13, 0x90, 0x88, 0xE8, 0xE0,
-0x04, 0xF0, 0xE0, 0xB4, 0x14, 0x09, 0x90, 0x04,
-0x9C, 0xE4, 0xF0, 0x90, 0x88, 0xE8, 0xF0, 0x90,
-0x88, 0x36, 0xE0, 0x70, 0x02, 0x81, 0xD1, 0x90,
-0x88, 0x4D, 0xE0, 0x04, 0xF0, 0x90, 0x05, 0x61,
-0x12, 0x8E, 0xD1, 0x12, 0xD4, 0x27, 0x90, 0x05,
-0x60, 0x12, 0x8E, 0xD1, 0x12, 0x86, 0x54, 0xC0,
-0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90,
-0x05, 0x62, 0x12, 0x8E, 0xD1, 0x78, 0x10, 0x12,
-0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0x12, 0x86, 0x54, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x12, 0x8E, 0xD0,
-0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x54,
-0x90, 0x88, 0x81, 0x12, 0x04, 0x31, 0x90, 0x88,
-0x32, 0xE0, 0x54, 0x7F, 0xF0, 0xA3, 0xE0, 0x30,
-0xE0, 0x0F, 0x31, 0x68, 0xFB, 0x90, 0x92, 0x98,
-0x74, 0x05, 0xF0, 0x12, 0x6E, 0x2F, 0x12, 0xDD,
-0x8C, 0x90, 0x88, 0x32, 0xB1, 0x26, 0x30, 0xE0,
-0x10, 0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4, 0x09,
-0x7D, 0x02, 0x7F, 0x02, 0x12, 0x7C, 0x7E, 0xF1,
-0xD9, 0x12, 0xB9, 0xB3, 0xFF, 0xBF, 0x03, 0x14,
-0x90, 0x93, 0x4A, 0xE0, 0xB4, 0x01, 0x0D, 0x90,
-0x01, 0xB8, 0xE0, 0x04, 0xF0, 0x90, 0x05, 0x21,
-0xE0, 0x44, 0x80, 0xF0, 0x90, 0x8A, 0xE5, 0x12,
-0x8B, 0x46, 0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90,
-0x93, 0x29, 0xE0, 0x30, 0xE0, 0x08, 0x12, 0xDD,
-0x50, 0x12, 0xA7, 0x92, 0xB1, 0x94, 0x90, 0x86,
-0xB3, 0xE0, 0xB4, 0x01, 0x10, 0xB1, 0x9C, 0x20,
-0xE0, 0x0B, 0xEF, 0xC4, 0x13, 0x54, 0x07, 0x30,
-0xE0, 0x03, 0x12, 0xDC, 0x57, 0x22, 0xE4, 0x90,
-0x92, 0x20, 0xF0, 0x90, 0x88, 0x3E, 0xE0, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x22, 0xE4, 0xF5, 0x77,
-0x90, 0x88, 0x36, 0xE0, 0x60, 0x53, 0xF1, 0x92,
-0x70, 0x4F, 0xF1, 0xF0, 0x75, 0x77, 0x01, 0xE5,
-0x77, 0x60, 0x46, 0x90, 0x88, 0x39, 0xE0, 0x20,
-0xE2, 0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x8B, 0x46,
-0x7D, 0x01, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xF1,
-0xE8, 0x90, 0x88, 0x3F, 0xE0, 0x60, 0x04, 0x64,
-0x01, 0x70, 0x10, 0xB1, 0x1E, 0xFF, 0xA3, 0xE0,
-0x2F, 0x12, 0xA7, 0x93, 0xB1, 0x23, 0xFF, 0xA3,
-0xE0, 0x80, 0x0C, 0xB1, 0x1E, 0xB1, 0x8A, 0x2F,
-0x12, 0xA7, 0x93, 0xB1, 0x23, 0xB1, 0x8A, 0x2F,
-0x33, 0x33, 0x33, 0x54, 0xF8, 0x90, 0x88, 0x4F,
-0xF0, 0x22, 0xFF, 0xA3, 0xE0, 0x75, 0xF0, 0x03,
-0xA4, 0x24, 0xFE, 0x22, 0x90, 0x93, 0x29, 0xE0,
-0x44, 0x10, 0xF0, 0x22, 0x90, 0x93, 0x29, 0xE0,
-0xFF, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x22, 0xE4,
-0x90, 0x95, 0xC3, 0xF0, 0xF1, 0x93, 0x60, 0x02,
-0xC1, 0xF2, 0x90, 0x88, 0x36, 0xE0, 0x70, 0x02,
-0xC1, 0xF2, 0x90, 0x88, 0x9D, 0xE0, 0x20, 0xE0,
-0x2F, 0x90, 0x06, 0xA9, 0xE0, 0x54, 0xC0, 0x70,
-0x27, 0x90, 0x88, 0x9C, 0xE0, 0x70, 0x21, 0x90,
-0x04, 0x1A, 0xE0, 0xF4, 0x70, 0x1A, 0xA3, 0xE0,
-0x54, 0x07, 0xFF, 0xBF, 0x07, 0x12, 0x90, 0x06,
-0x62, 0xE0, 0x54, 0x03, 0x70, 0x0A, 0x90, 0x88,
-0x39, 0xE0, 0xB4, 0x04, 0x03, 0x12, 0xC3, 0x62,
-0x90, 0x05, 0x63, 0xE0, 0x90, 0x88, 0x85, 0xF0,
-0x90, 0x05, 0x62, 0xE0, 0x90, 0x88, 0x86, 0xF0,
-0x90, 0x05, 0x61, 0xE0, 0x90, 0x88, 0x87, 0xF0,
-0x90, 0x05, 0x60, 0xE0, 0x90, 0x88, 0x88, 0xF0,
-0x90, 0x07, 0xF1, 0xE0, 0x90, 0x94, 0x9F, 0xF0,
-0x90, 0x07, 0xF0, 0xE0, 0x90, 0x94, 0xA0, 0xF0,
-0x12, 0xBA, 0x2E, 0xF0, 0x90, 0x88, 0x3A, 0xE0,
-0x54, 0xEC, 0xF0, 0xD1, 0xFB, 0x24, 0xFD, 0x50,
-0x02, 0x80, 0x03, 0x12, 0xA7, 0x27, 0xD1, 0xFB,
-0x64, 0x01, 0x70, 0x3A, 0x90, 0x06, 0xAB, 0xE0,
-0x90, 0x88, 0x3D, 0xF0, 0x90, 0x06, 0xA9, 0xE0,
-0x30, 0xE5, 0x06, 0xA3, 0xE0, 0x90, 0x95, 0xC3,
-0xF0, 0x90, 0x95, 0xC3, 0xE0, 0xFF, 0x60, 0x02,
-0x80, 0x05, 0x90, 0x88, 0x3C, 0xE0, 0xFF, 0x90,
-0x88, 0x3C, 0xEF, 0xF0, 0xA3, 0xE0, 0xFF, 0x70,
-0x08, 0x90, 0x88, 0x3C, 0xE0, 0xFE, 0xFF, 0x80,
-0x00, 0x90, 0x88, 0x3D, 0xEF, 0xF0, 0x31, 0x75,
-0xE4, 0x90, 0x88, 0x3F, 0xF0, 0xA3, 0xF0, 0x90,
-0x88, 0x32, 0xB1, 0x9F, 0x30, 0xE0, 0x64, 0xEF,
-0xC4, 0x13, 0x13, 0x54, 0x03, 0x20, 0xE0, 0x27,
-0xD1, 0xF3, 0x6F, 0x70, 0x56, 0xEF, 0x60, 0x53,
-0x90, 0x88, 0x32, 0xE0, 0x44, 0x40, 0xF0, 0xF1,
-0xE0, 0xF1, 0x04, 0x12, 0x7C, 0x05, 0xF1, 0xD9,
-0x7D, 0x02, 0x7F, 0x02, 0x12, 0x7C, 0x7E, 0x90,
-0x88, 0x3D, 0xE0, 0x14, 0xF0, 0x80, 0x34, 0x90,
-0x88, 0x34, 0xE0, 0xC4, 0x54, 0x0F, 0x64, 0x01,
-0x70, 0x29, 0xD1, 0xF3, 0xFE, 0x6F, 0x60, 0x23,
-0x90, 0x05, 0x73, 0xE0, 0xFF, 0xEE, 0x6F, 0x60,
-0x1A, 0x90, 0x88, 0x32, 0xF1, 0x0F, 0x30, 0xE0,
-0x12, 0xEF, 0x54, 0xBF, 0xF1, 0x04, 0x12, 0x7C,
-0x3B, 0x7D, 0x01, 0x7F, 0x02, 0x12, 0x7C, 0x74,
-0x12, 0xBA, 0xC4, 0x90, 0x88, 0x32, 0xE0, 0x44,
-0x04, 0xF0, 0x22, 0x90, 0x88, 0x3C, 0xE0, 0xFF,
-0xA3, 0xE0, 0x22, 0x90, 0x88, 0x34, 0xE0, 0xFF,
-0xC4, 0x54, 0x0F, 0x22, 0xF0, 0x90, 0x01, 0x3F,
-0x74, 0x10, 0xF0, 0xFD, 0x7F, 0x03, 0x22, 0xE0,
-0xFF, 0x13, 0x13, 0x54, 0x3F, 0x22, 0x90, 0x88,
-0x32, 0xB1, 0x9F, 0x30, 0xE0, 0x10, 0xEF, 0xC4,
-0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x07, 0x7D,
-0x02, 0x7F, 0x02, 0x12, 0x7C, 0x7E, 0x90, 0x88,
-0x31, 0xF1, 0x0F, 0x30, 0xE0, 0x08, 0xEF, 0x12,
-0xBA, 0xEB, 0x70, 0x4D, 0x80, 0x48, 0x90, 0x88,
-0x3F, 0xE0, 0x04, 0xF0, 0x90, 0x88, 0x3A, 0xE0,
-0x54, 0xEF, 0xF0, 0x12, 0xDC, 0x4C, 0x9F, 0x40,
-0x35, 0xF1, 0x92, 0x70, 0x34, 0x12, 0xA7, 0xE8,
-0x70, 0x08, 0x90, 0x8A, 0xF5, 0x12, 0x88, 0xCD,
-0x80, 0x28, 0x90, 0x8A, 0xF5, 0x12, 0x88, 0xCD,
-0x90, 0x88, 0x40, 0xE0, 0x04, 0xF0, 0xE0, 0xD3,
-0x94, 0x02, 0x40, 0x09, 0xF1, 0x8A, 0xE4, 0x90,
-0x88, 0x40, 0xF0, 0x80, 0x03, 0x12, 0xDB, 0xAA,
-0xE4, 0x90, 0x88, 0x3F, 0xF0, 0x22, 0x12, 0xA6,
-0xF0, 0x22, 0x90, 0x88, 0x32, 0xE0, 0x54, 0xFB,
-0xF0, 0x22, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xEF,
-0x64, 0x01, 0x22, 0xE4, 0x90, 0x95, 0xE8, 0xF0,
-0x90, 0x88, 0x36, 0xE0, 0x60, 0x32, 0xF1, 0x92,
-0x70, 0x2E, 0xF1, 0xE0, 0xF0, 0xF1, 0xF0, 0x90,
-0x95, 0xE8, 0x74, 0x01, 0xF0, 0xE4, 0x90, 0x88,
-0x3D, 0xF0, 0x04, 0x60, 0x1B, 0x90, 0x88, 0x39,
-0xE0, 0x20, 0xE2, 0x0D, 0x90, 0x8A, 0xB9, 0x12,
-0x8B, 0x46, 0x7D, 0x01, 0x7F, 0x04, 0x12, 0x04,
-0x7E, 0xF1, 0xE8, 0xB1, 0x1E, 0x12, 0xA7, 0x93,
-0x22, 0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0x7E,
-0x90, 0x88, 0x3C, 0xE0, 0x90, 0x05, 0x73, 0x22,
-0x90, 0x88, 0x3A, 0xE0, 0x44, 0x10, 0xF0, 0x22,
-0x90, 0x05, 0x63, 0xE0, 0x90, 0x88, 0x89, 0xF0,
-0x90, 0x05, 0x62, 0xE0, 0x90, 0x88, 0x8A, 0xF0,
-0x90, 0x05, 0x61, 0xE0, 0x90, 0x88, 0x8B, 0xF0,
-0x90, 0x05, 0x60, 0xE0, 0x90, 0x88, 0x8C, 0xF0,
-0x90, 0x88, 0x32, 0xE0, 0x44, 0x80, 0xF0, 0x22,
-0x90, 0x93, 0x31, 0xE0, 0x20, 0xE0, 0x02, 0x01,
-0xD9, 0xE4, 0x90, 0x94, 0xB6, 0xF0, 0x11, 0xDA,
-0x40, 0x02, 0x01, 0xD9, 0x31, 0x73, 0x80, 0x05,
-0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF,
-0x90, 0x93, 0x32, 0xE0, 0xFD, 0xEF, 0x5D, 0x60,
-0x02, 0x01, 0xD1, 0x12, 0x02, 0x06, 0xFF, 0x30,
-0xE0, 0x1A, 0x90, 0x93, 0x33, 0xE0, 0xFE, 0x90,
-0x94, 0xB6, 0xE0, 0xFD, 0x74, 0x01, 0xA8, 0x05,
-0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4E,
-0x90, 0x93, 0x33, 0xF0, 0xEF, 0xC3, 0x13, 0x30,
-0xE0, 0x16, 0x90, 0x93, 0x34, 0xE0, 0xFF, 0x90,
-0x94, 0xB6, 0x12, 0x93, 0x3F, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93, 0x34, 0xF0,
-0x12, 0x98, 0xAC, 0xFF, 0x90, 0x94, 0xB6, 0xE0,
-0xFE, 0x24, 0x35, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xEF, 0x12, 0x87, 0xE9, 0xFF, 0x74,
-0x3A, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0x12,
-0x87, 0xF0, 0xFF, 0x74, 0x3F, 0x2E, 0xF5, 0x82,
-0xE4, 0x34, 0x93, 0x12, 0x87, 0xFA, 0xFF, 0x74,
-0x44, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5,
-0x83, 0xEF, 0xF0, 0x90, 0x93, 0x32, 0xE0, 0xFF,
-0x74, 0x01, 0xA8, 0x06, 0x08, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93, 0x32, 0xF0,
-0x22, 0x90, 0x94, 0xB6, 0xE0, 0x04, 0xF0, 0x01,
-0x26, 0x22, 0x90, 0x94, 0xB6, 0xE0, 0xFF, 0xC3,
-0x94, 0x05, 0x22, 0x7B, 0x00, 0x7A, 0x00, 0x79,
-0x00, 0x90, 0x89, 0x2E, 0x12, 0x86, 0x76, 0x7B,
-0xFF, 0x7A, 0x80, 0x79, 0x80, 0x90, 0x89, 0x31,
-0x12, 0x86, 0x76, 0x7A, 0x80, 0x79, 0xBF, 0x90,
-0x89, 0x34, 0x12, 0x86, 0x76, 0x7A, 0x81, 0x79,
-0x61, 0x90, 0x89, 0x3A, 0x12, 0x86, 0x76, 0x7A,
-0x81, 0x79, 0x75, 0x90, 0x89, 0x3D, 0x12, 0x86,
-0x76, 0x7A, 0x81, 0x79, 0x9D, 0x90, 0x89, 0x40,
-0x12, 0x86, 0x76, 0x31, 0x66, 0x7A, 0x81, 0x79,
-0xD9, 0x90, 0x89, 0x49, 0x12, 0x86, 0x76, 0x7A,
-0x82, 0x79, 0x01, 0x90, 0x89, 0x4C, 0x12, 0x86,
-0x76, 0xE4, 0x90, 0x96, 0x1D, 0xF0, 0x90, 0x96,
-0x0C, 0xF0, 0x90, 0x94, 0xB6, 0xF0, 0x11, 0xDA,
-0x50, 0x0F, 0x74, 0x2E, 0x2F, 0x31, 0x5E, 0xE4,
-0xF0, 0x90, 0x94, 0xB6, 0xE0, 0x04, 0xF0, 0x80,
-0xED, 0x22, 0x74, 0x2E, 0x25, 0x62, 0xF5, 0x82,
-0xE4, 0x34, 0x96, 0xF5, 0x83, 0x22, 0x7A, 0x81,
-0x79, 0xB1, 0x90, 0x89, 0x46, 0x02, 0x86, 0x76,
-0x54, 0x07, 0xFF, 0x74, 0x01, 0x7E, 0x00, 0xA8,
-0x07, 0x08, 0x22, 0xE4, 0x90, 0x95, 0x11, 0xF0,
-0x12, 0xD0, 0xF7, 0xF1, 0xB5, 0xE4, 0xFF, 0x71,
-0xB1, 0x90, 0x93, 0x31, 0xE0, 0x20, 0xE0, 0x02,
-0x41, 0x6D, 0x90, 0x00, 0x02, 0xE0, 0x44, 0x02,
-0xF0, 0xE4, 0x90, 0x95, 0x12, 0xF0, 0x90, 0x95,
-0x12, 0xE0, 0xFF, 0xC3, 0x94, 0x05, 0x50, 0x2B,
-0x31, 0x73, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
-0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x34, 0xE0,
-0xFD, 0xEF, 0x5D, 0x60, 0x0E, 0x90, 0x95, 0x12,
-0x91, 0x38, 0x90, 0x95, 0x12, 0x91, 0x58, 0x44,
-0x40, 0x91, 0x00, 0x90, 0x95, 0x12, 0xE0, 0x04,
-0xF0, 0x80, 0xCB, 0x90, 0x07, 0xC7, 0xE4, 0xF0,
-0x90, 0x07, 0xC6, 0xF0, 0x90, 0x07, 0xC5, 0x74,
-0x77, 0xF0, 0x90, 0x07, 0xC4, 0xE4, 0xF0, 0x90,
-0x07, 0xC0, 0x74, 0x38, 0xF0, 0xA3, 0xE4, 0xF0,
-0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0x74, 0xC0, 0xF0,
-0x90, 0x02, 0x26, 0xE0, 0x44, 0x01, 0xF0, 0xE0,
-0x90, 0x95, 0x13, 0xF0, 0x90, 0x95, 0x13, 0xE0,
-0x30, 0xE0, 0x18, 0x90, 0x95, 0x11, 0xE0, 0x04,
-0xF1, 0xAD, 0x90, 0x02, 0x26, 0xE0, 0x90, 0x95,
-0x13, 0xF0, 0x90, 0x95, 0x11, 0xE0, 0xD3, 0x94,
-0xFA, 0x40, 0xE1, 0x90, 0x02, 0x03, 0x74, 0x80,
-0xF0, 0x90, 0x04, 0x24, 0xE0, 0x90, 0x95, 0x14,
-0xF0, 0x90, 0x04, 0x22, 0xE0, 0x44, 0x10, 0xF0,
-0x90, 0x02, 0x00, 0xE0, 0x90, 0x95, 0x13, 0xF0,
-0x90, 0x02, 0x01, 0x51, 0x7D, 0x90, 0x02, 0x02,
-0x51, 0x7D, 0x90, 0x02, 0x14, 0x51, 0x7D, 0xE0,
-0x04, 0xF0, 0xE0, 0x90, 0x04, 0x24, 0xF0, 0x12,
-0x9B, 0xAE, 0x90, 0x95, 0x14, 0xE0, 0x90, 0x04,
-0x24, 0xF0, 0x90, 0xFD, 0x09, 0x74, 0xFF, 0xF0,
-0x90, 0xFD, 0x08, 0xE4, 0xF0, 0x91, 0x08, 0xF0,
-0xE4, 0xFD, 0x12, 0x76, 0xF7, 0x90, 0x88, 0x32,
-0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xE0, 0xFF, 0x90,
-0x95, 0x13, 0xE0, 0x2F, 0xF0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x51, 0x96, 0x31,
-0x7B, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x75, 0x61,
-0x14, 0x90, 0x88, 0x32, 0xE0, 0x44, 0x10, 0xF0,
-0x91, 0x08, 0xF0, 0x7D, 0x01, 0x12, 0x76, 0xF7,
-0x90, 0x88, 0x41, 0xE0, 0x90, 0x00, 0x93, 0xF0,
-0x90, 0x88, 0x37, 0xE0, 0x60, 0x12, 0x90, 0x01,
-0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74, 0x10, 0xF0,
-0x80, 0x06, 0x90, 0x01, 0x2F, 0x74, 0x90, 0xF0,
-0x90, 0x93, 0x31, 0xE0, 0x30, 0xE0, 0x5E, 0x90,
-0xFD, 0x09, 0xE4, 0xF0, 0x90, 0xFD, 0x08, 0xF0,
-0x90, 0x0E, 0x4B, 0xE0, 0x54, 0xFC, 0xF0, 0xE4,
-0x90, 0x95, 0x11, 0xF0, 0x90, 0x95, 0x11, 0xE0,
-0xFF, 0xC3, 0x94, 0x05, 0x50, 0x2B, 0x31, 0x73,
+0xE0, 0x54, 0xC0, 0xF0, 0xF1, 0x1B, 0x54, 0xC0,
+0xF0, 0x90, 0x96, 0xE9, 0xE0, 0xFF, 0xAE, 0x05,
+0x74, 0x18, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00, 0x8B, 0xE0,
+0xD3, 0x94, 0x03, 0x74, 0x10, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x74, 0x04, 0xF0,
+0xAF, 0x05, 0xD1, 0x51, 0xE0, 0x54, 0x01, 0xFE,
+0x90, 0x96, 0xE8, 0xE0, 0x25, 0xE0, 0x25, 0xE0,
+0xFB, 0xEE, 0x44, 0x02, 0x4B, 0xD1, 0x50, 0xEE,
+0xF0, 0x74, 0x11, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0x74, 0xFF, 0xF0, 0x74, 0x29,
+0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xE0, 0x54, 0xF7, 0xF0, 0x74, 0x0D, 0x2D, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x44,
+0x80, 0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x74, 0x21, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22, 0x90,
+0x88, 0x38, 0xE0, 0xFF, 0x90, 0x8A, 0xB9, 0xE0,
+0xFC, 0xA3, 0xE0, 0xF5, 0x82, 0x22, 0xEF, 0xB4,
+0xFF, 0x06, 0x90, 0x93, 0x5E, 0xED, 0xF0, 0x22,
+0xEF, 0xF4, 0xFE, 0x90, 0x93, 0x5E, 0xE0, 0x5E,
+0xFE, 0xED, 0x5F, 0x4E, 0xF0, 0x22, 0xEF, 0xB4,
+0xFF, 0x06, 0x90, 0x93, 0x5F, 0xED, 0xF0, 0x22,
+0xEF, 0xF4, 0xFE, 0x90, 0x93, 0x5F, 0x80, 0xE6,
+0x90, 0x00, 0x80, 0xE0, 0x44, 0x80, 0xF0, 0x12,
+0xC7, 0x9B, 0x12, 0xD8, 0x19, 0x12, 0x7B, 0x79,
+0x12, 0xBE, 0x73, 0x12, 0xC0, 0x04, 0x7F, 0x01,
+0x12, 0x84, 0x15, 0x90, 0x93, 0x4A, 0x74, 0x02,
+0xF0, 0xFF, 0x12, 0x84, 0x15, 0x90, 0x93, 0x4A,
+0xE0, 0x04, 0xF0, 0x12, 0xC3, 0xCE, 0x12, 0x9F,
+0x52, 0x90, 0x00, 0x80, 0xE0, 0x44, 0x40, 0xF0,
+0x75, 0x20, 0xFF, 0x12, 0x7C, 0x97, 0x53, 0xA8,
+0xFE, 0x90, 0x01, 0xA0, 0xE0, 0xB4, 0xFD, 0x04,
+0xE4, 0xFF, 0x31, 0x66, 0x12, 0xBE, 0xE2, 0x90,
+0x00, 0x81, 0xE0, 0x44, 0x04, 0xF0, 0x12, 0xC7,
+0x91, 0x11, 0xD3, 0x12, 0x9F, 0x0C, 0xA3, 0xE0,
+0x44, 0x80, 0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x44,
+0x10, 0xF0, 0x90, 0x07, 0xDB, 0xE0, 0x44, 0x80,
+0xF0, 0x90, 0x06, 0x0D, 0x74, 0xFF, 0xF0, 0xE4,
+0xFF, 0x02, 0x84, 0x9E, 0xE4, 0x75, 0xF0, 0x01,
+0x02, 0x02, 0xE7, 0x25, 0xE0, 0x25, 0xE0, 0xFE,
+0xEF, 0x4E, 0x22, 0x12, 0x02, 0x06, 0xFF, 0x54,
+0x80, 0xFE, 0x90, 0x93, 0x58, 0xE0, 0x54, 0x7F,
+0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x40, 0xFF, 0xEE,
+0x54, 0xBF, 0x4F, 0x11, 0xB3, 0x54, 0x20, 0xFD,
+0xEF, 0x54, 0xDF, 0x4D, 0xFF, 0x90, 0x93, 0x58,
+0xF0, 0xEE, 0x54, 0x10, 0xFE, 0xEF, 0x54, 0xEF,
+0x4E, 0xFF, 0xF0, 0x12, 0x02, 0x06, 0x54, 0x0F,
+0xFE, 0xEF, 0x54, 0xF0, 0x4E, 0x90, 0x93, 0x58,
+0x12, 0x87, 0x86, 0xFF, 0x54, 0x7F, 0x90, 0x93,
+0x5A, 0xF0, 0xEF, 0x54, 0x80, 0x12, 0x8D, 0x35,
+0xFF, 0x90, 0x93, 0x59, 0xE0, 0x54, 0xFE, 0x12,
+0x87, 0x24, 0x90, 0x93, 0x5B, 0x12, 0x87, 0x75,
+0x54, 0x01, 0x25, 0xE0, 0xFF, 0x90, 0x93, 0x59,
+0xE0, 0x54, 0xFD, 0x4F, 0xF0, 0x11, 0x5F, 0x20,
+0xE0, 0x02, 0x7D, 0x01, 0x02, 0x96, 0x44, 0x90,
+0x93, 0x58, 0xE0, 0xFE, 0x54, 0x0F, 0xFF, 0xEE,
+0xC4, 0x13, 0x13, 0x54, 0x03, 0x7D, 0x00, 0x22,
+0x90, 0x93, 0x58, 0xE0, 0xFF, 0x12, 0x8D, 0x35,
+0x30, 0xE0, 0x1B, 0xEF, 0xC4, 0x54, 0x0F, 0x30,
+0xE0, 0x03, 0x12, 0xD7, 0xEF, 0x90, 0x93, 0x59,
+0xE0, 0x30, 0xE0, 0x0A, 0x11, 0x5F, 0x20, 0xE0,
+0x02, 0x7D, 0x01, 0x12, 0x96, 0x44, 0x22, 0x90,
+0x88, 0x36, 0xE0, 0x60, 0x14, 0x90, 0x06, 0x92,
+0xE0, 0x30, 0xE1, 0x08, 0x90, 0x8B, 0x01, 0x12,
+0x8E, 0xAD, 0x80, 0x05, 0x12, 0xE0, 0xB2, 0xD1,
+0x85, 0x80, 0xBD, 0xFF, 0xF0, 0x12, 0x02, 0x06,
+0xFE, 0x22, 0x12, 0xB3, 0xFD, 0xFF, 0x54, 0x01,
+0xFE, 0x90, 0x93, 0x2A, 0x12, 0xE0, 0x7E, 0x11,
+0xB3, 0x54, 0x04, 0xFD, 0xEF, 0x54, 0xFB, 0x4D,
+0xFF, 0x90, 0x93, 0x2A, 0xF0, 0xEE, 0x54, 0x08,
+0xFE, 0xEF, 0x54, 0xF7, 0x4E, 0xF0, 0x90, 0x05,
+0x52, 0xE0, 0x54, 0x07, 0x90, 0x94, 0xBD, 0x60,
+0x16, 0x12, 0x86, 0x6D, 0x12, 0x87, 0x87, 0xFD,
+0x90, 0x05, 0x56, 0xE0, 0xC3, 0x9D, 0x90, 0x93,
+0x2C, 0xF0, 0xA3, 0xED, 0xF0, 0x80, 0x26, 0x12,
+0x86, 0x6D, 0x12, 0x87, 0x87, 0xFB, 0xFF, 0x90,
+0x05, 0x54, 0xE0, 0xC3, 0x9F, 0xFF, 0xE4, 0x94,
+0x00, 0xFE, 0x7C, 0x00, 0x7D, 0x05, 0x12, 0x02,
+0x92, 0x90, 0x93, 0x2C, 0xEF, 0xF0, 0xEB, 0x75,
+0xF0, 0x05, 0x84, 0xA3, 0xF0, 0x12, 0x90, 0xD3,
+0x12, 0x02, 0x06, 0x20, 0xE0, 0x13, 0x12, 0x8E,
+0xAA, 0x90, 0x8A, 0xF9, 0x12, 0x8A, 0x5F, 0x12,
+0x97, 0xF1, 0x90, 0x01, 0x57, 0xE4, 0xF0, 0x80,
+0x0C, 0x90, 0x8A, 0x89, 0x12, 0x8A, 0x5F, 0x12,
+0x8F, 0xCF, 0x12, 0x8F, 0xC7, 0xB1, 0x35, 0x20,
+0xE0, 0x04, 0xEF, 0x44, 0x20, 0xF0, 0x12, 0x8F,
+0xD6, 0x30, 0xE0, 0x18, 0x90, 0x88, 0x36, 0x74,
+0x01, 0xF0, 0xE4, 0x90, 0x88, 0x38, 0xF0, 0x31,
+0x8C, 0xF1, 0xA9, 0x90, 0x92, 0x98, 0x74, 0x06,
+0xF0, 0x02, 0x6E, 0x2F, 0xE4, 0x90, 0x88, 0x36,
+0xF0, 0x90, 0x88, 0x38, 0x74, 0x0C, 0xF0, 0x90,
+0x88, 0x31, 0xE0, 0x54, 0xFE, 0xF0, 0xA3, 0xE0,
+0x54, 0xFB, 0xF0, 0x22, 0x90, 0x88, 0x32, 0xE0,
+0x44, 0x04, 0xF0, 0x22, 0xE4, 0x90, 0x95, 0xCB,
+0xF0, 0xB1, 0xBA, 0x60, 0x02, 0x41, 0xD3, 0x90,
+0x88, 0x36, 0xE0, 0x70, 0x02, 0x41, 0xD3, 0x90,
+0x88, 0x9D, 0xE0, 0x20, 0xE0, 0x2F, 0x90, 0x06,
+0xA9, 0xE0, 0x54, 0xC0, 0x70, 0x27, 0x90, 0x88,
+0x9C, 0xE0, 0x70, 0x21, 0x90, 0x04, 0x1A, 0xE0,
+0xF4, 0x70, 0x1A, 0xA3, 0xE0, 0x54, 0x07, 0xFF,
+0xBF, 0x07, 0x12, 0x90, 0x06, 0x62, 0xE0, 0x54,
+0x03, 0x70, 0x0A, 0x90, 0x88, 0x39, 0xE0, 0xB4,
+0x04, 0x03, 0x12, 0xC6, 0x76, 0x90, 0x05, 0x63,
+0xE0, 0x90, 0x88, 0x85, 0xF0, 0x90, 0x05, 0x62,
+0xE0, 0x90, 0x88, 0x86, 0xF0, 0x90, 0x05, 0x61,
+0xE0, 0x90, 0x88, 0x87, 0xF0, 0x90, 0x05, 0x60,
+0xE0, 0x90, 0x88, 0x88, 0xF0, 0x90, 0x07, 0xF1,
+0xE0, 0x90, 0x94, 0xA0, 0xF0, 0x90, 0x07, 0xF0,
+0xE0, 0x90, 0x94, 0xA1, 0xF0, 0xF1, 0x90, 0x90,
+0x88, 0x3A, 0xE0, 0x54, 0xEC, 0xF0, 0x51, 0xDC,
+0x24, 0xFD, 0x50, 0x02, 0x80, 0x02, 0xD1, 0xAD,
+0x51, 0xDC, 0x64, 0x01, 0x70, 0x3A, 0x90, 0x06,
+0xAB, 0xE0, 0x90, 0x88, 0x3D, 0xF0, 0x90, 0x06,
+0xA9, 0xE0, 0x30, 0xE5, 0x06, 0xA3, 0xE0, 0x90,
+0x95, 0xCB, 0xF0, 0x90, 0x95, 0xCB, 0xE0, 0xFF,
+0x60, 0x02, 0x80, 0x05, 0x90, 0x88, 0x3C, 0xE0,
+0xFF, 0x90, 0x88, 0x3C, 0xEF, 0xF0, 0xA3, 0xE0,
+0xFF, 0x70, 0x08, 0x90, 0x88, 0x3C, 0xE0, 0xFE,
+0xFF, 0x80, 0x00, 0x90, 0x88, 0x3D, 0xEF, 0xF0,
+0x51, 0xF0, 0xE4, 0x90, 0x88, 0x3F, 0xF0, 0xA3,
+0xF0, 0x90, 0x88, 0x32, 0xB1, 0x38, 0x30, 0xE0,
+0x60, 0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x20,
+0xE0, 0x23, 0x51, 0xD4, 0x6F, 0x70, 0x52, 0xEF,
+0x60, 0x4F, 0x90, 0x88, 0x32, 0xE0, 0x44, 0x40,
+0xF0, 0xD1, 0x75, 0x51, 0xE5, 0x12, 0x7C, 0x05,
+0x12, 0xE0, 0xAB, 0xB1, 0xB2, 0x90, 0x88, 0x3D,
+0xE0, 0x14, 0xF0, 0x80, 0x34, 0x90, 0x88, 0x34,
+0xE0, 0xC4, 0x54, 0x0F, 0x64, 0x01, 0x70, 0x29,
+0x51, 0xD4, 0xFE, 0x6F, 0x60, 0x23, 0x90, 0x05,
+0x73, 0xE0, 0xFF, 0xEE, 0x6F, 0x60, 0x1A, 0x90,
+0x88, 0x32, 0xB1, 0x2E, 0x30, 0xE0, 0x12, 0xEF,
+0x54, 0xBF, 0x51, 0xE5, 0x12, 0x7C, 0x3B, 0x7D,
+0x01, 0x7F, 0x02, 0x12, 0x7C, 0x74, 0x12, 0xBD,
+0x49, 0x31, 0x8C, 0x22, 0x90, 0x88, 0x3C, 0xE0,
+0xFF, 0xA3, 0xE0, 0x22, 0x90, 0x88, 0x34, 0xE0,
+0xFF, 0xC4, 0x54, 0x0F, 0x22, 0xF0, 0x90, 0x01,
+0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F, 0x03, 0x22,
+0x90, 0x88, 0x85, 0x12, 0x04, 0xB8, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x94, 0xA1, 0xE0, 0x24, 0x46,
+0xFF, 0x90, 0x94, 0xA0, 0xE0, 0x34, 0x00, 0xAB,
+0x07, 0xFA, 0xE4, 0xF9, 0xF8, 0xD0, 0x07, 0xD0,
+0x06, 0x12, 0x86, 0x39, 0x90, 0x88, 0x85, 0xB1,
+0x01, 0xEF, 0x24, 0x46, 0xFF, 0xE4, 0x3E, 0xFE,
+0xE4, 0x3D, 0xFD, 0xE4, 0x3C, 0xFC, 0x90, 0x88,
+0x89, 0xB1, 0x01, 0x90, 0x88, 0x85, 0x12, 0x86,
+0x61, 0xC3, 0x12, 0x03, 0xDA, 0x50, 0x02, 0x61,
+0xEC, 0x90, 0x88, 0x89, 0x12, 0x86, 0x61, 0x90,
+0x88, 0x85, 0x12, 0x04, 0xB8, 0x12, 0x86, 0x39,
+0x90, 0x95, 0xD0, 0x12, 0x04, 0x31, 0x90, 0x88,
+0x31, 0xE0, 0x30, 0xE0, 0x2F, 0x90, 0x88, 0x53,
+0xE0, 0x24, 0x04, 0xFF, 0xE4, 0x33, 0xFE, 0xEF,
+0x78, 0x03, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
+0xF9, 0x24, 0x50, 0xFF, 0xE4, 0x3E, 0xFE, 0x90,
+0x88, 0x4E, 0xE0, 0xFD, 0xC3, 0xEF, 0x9D, 0xFB,
+0xEE, 0x94, 0x00, 0xFA, 0xB1, 0x0A, 0xEB, 0x2F,
+0xFF, 0xEA, 0x80, 0x1D, 0x90, 0x88, 0x33, 0xB1,
+0x2E, 0x30, 0xE0, 0x02, 0x81, 0xE6, 0xB1, 0x0A,
+0x90, 0x88, 0x4E, 0xE0, 0xFD, 0xC3, 0x74, 0x60,
+0x9D, 0xCD, 0xE4, 0x94, 0x00, 0xCD, 0x2F, 0xFF,
+0xED, 0x3E, 0x90, 0x95, 0xCC, 0xF0, 0xA3, 0xEF,
+0xF0, 0xC3, 0x90, 0x95, 0xCD, 0xE0, 0x94, 0xA0,
+0x90, 0x95, 0xCC, 0xE0, 0x94, 0x00, 0x50, 0x34,
+0xA3, 0xE0, 0xFB, 0x24, 0x60, 0x91, 0xF9, 0xE0,
+0x04, 0xF0, 0x90, 0x95, 0xD0, 0x12, 0x04, 0xB8,
+0xEF, 0x54, 0x7F, 0xFF, 0x74, 0x00, 0x2B, 0x91,
+0xEE, 0xE0, 0xFE, 0xEF, 0xC3, 0x9E, 0x50, 0x09,
+0x90, 0x95, 0xCC, 0xA3, 0xE0, 0x91, 0xEC, 0xEF,
+0xF0, 0x90, 0x88, 0x4C, 0xE0, 0x04, 0xF0, 0xE0,
+0x90, 0x00, 0xFE, 0xF0, 0x90, 0x88, 0x4C, 0xE0,
+0xFF, 0xD3, 0x90, 0x88, 0x90, 0xE0, 0x9F, 0x90,
+0x88, 0x8F, 0xE0, 0x94, 0x00, 0x40, 0x02, 0x81,
+0xE6, 0xE4, 0xFF, 0xFE, 0x91, 0xF6, 0xE0, 0x2F,
+0xFF, 0x90, 0x88, 0x91, 0xE0, 0xFD, 0xEF, 0xD3,
+0x9D, 0x40, 0x07, 0x90, 0x95, 0xCE, 0xEE, 0xF0,
+0x80, 0x05, 0x0E, 0xEE, 0xB4, 0xA0, 0xE5, 0xB1,
+0x15, 0x40, 0x02, 0x80, 0x15, 0x90, 0x95, 0xCE,
+0xE0, 0x04, 0xFE, 0xEE, 0xC3, 0x94, 0xA0, 0x50,
+0x13, 0x91, 0xF6, 0xE0, 0x2F, 0xFF, 0xB1, 0x15,
+0x40, 0x07, 0x90, 0x95, 0xCF, 0xEE, 0xF0, 0x80,
+0x03, 0x0E, 0x80, 0xE7, 0x90, 0x05, 0x5E, 0xE0,
+0xFF, 0x91, 0xE7, 0xE0, 0xFD, 0xEF, 0xC3, 0x9D,
+0x40, 0x11, 0xEF, 0x9D, 0x90, 0x05, 0x5E, 0xF0,
+0x90, 0x88, 0x51, 0xEE, 0xF0, 0x90, 0x95, 0xCF,
+0xE0, 0x80, 0x18, 0x91, 0xE7, 0xE0, 0xFD, 0xC3,
+0x74, 0x80, 0x9D, 0x2F, 0x90, 0x05, 0x5E, 0xF0,
+0xEE, 0x04, 0x90, 0x88, 0x51, 0xF0, 0x90, 0x95,
+0xCF, 0xE0, 0x04, 0x90, 0x88, 0x52, 0xF0, 0x90,
+0x88, 0x51, 0xE0, 0xFF, 0xC3, 0x94, 0x50, 0x40,
+0x0A, 0xEF, 0x24, 0xB0, 0x90, 0x88, 0x49, 0xF0,
+0xE4, 0x80, 0x0E, 0xE4, 0x90, 0x88, 0x49, 0xF0,
+0x90, 0x88, 0x51, 0xE0, 0xFF, 0xC3, 0x74, 0x50,
+0x9F, 0x90, 0x88, 0x48, 0xF0, 0x90, 0x88, 0x51,
+0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x88,
+0x4F, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0x90, 0x88,
+0x8E, 0xE0, 0x24, 0x08, 0xFF, 0x90, 0x88, 0x4F,
+0xE0, 0x2F, 0xF0, 0x90, 0x88, 0x4F, 0xE0, 0xC3,
+0x94, 0x50, 0x50, 0x03, 0x74, 0x50, 0xF0, 0x90,
+0x88, 0x4F, 0xE0, 0x24, 0x10, 0xF0, 0xF1, 0xA9,
+0x12, 0xDF, 0xC9, 0x90, 0x8A, 0xA3, 0x12, 0x8A,
+0x5F, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x22, 0x90,
+0x95, 0xCE, 0xE0, 0xFE, 0x24, 0x00, 0xF5, 0x82,
+0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22, 0x74, 0x60,
+0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
+0x22, 0x12, 0x04, 0x31, 0x90, 0x88, 0x89, 0x02,
+0x04, 0xB8, 0x90, 0x95, 0xD0, 0x12, 0x04, 0xB8,
+0x78, 0x07, 0x02, 0x03, 0xEB, 0x90, 0x88, 0x91,
+0xE0, 0xFD, 0xC3, 0x90, 0x88, 0x90, 0xE0, 0x9D,
+0xFD, 0x90, 0x88, 0x8F, 0xE0, 0x94, 0x00, 0xFC,
+0xEF, 0xD3, 0x9D, 0xE4, 0x9C, 0x22, 0xE0, 0xFF,
+0x13, 0x13, 0x54, 0x3F, 0x22, 0x90, 0x93, 0x2A,
+0xE0, 0xFF, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x22,
+0x90, 0x88, 0x32, 0xB1, 0x38, 0x30, 0xE0, 0x0B,
+0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0,
+0x02, 0xB1, 0xB2, 0x90, 0x88, 0x31, 0xB1, 0x2E,
+0x30, 0xE0, 0x07, 0xEF, 0xF1, 0x9C, 0x70, 0x49,
+0x80, 0x45, 0x90, 0x88, 0x3F, 0xE0, 0x04, 0xF0,
+0x90, 0x88, 0x3A, 0xE0, 0x54, 0xEF, 0xF0, 0x12,
+0xDF, 0xD2, 0x40, 0x33, 0xB1, 0xB9, 0x70, 0x31,
+0xF1, 0x56, 0x70, 0x08, 0x90, 0x8A, 0xF5, 0x12,
+0x8E, 0xAD, 0x80, 0x26, 0x90, 0x8A, 0xF5, 0x12,
+0x8E, 0xAD, 0x90, 0x88, 0x40, 0xE0, 0x04, 0xF0,
+0xE0, 0xD3, 0x94, 0x02, 0x40, 0x09, 0xB1, 0xAA,
+0xE4, 0x90, 0x88, 0x40, 0xF0, 0x80, 0x02, 0xF1,
+0x17, 0xE4, 0x90, 0x88, 0x3F, 0xF0, 0x22, 0xD1,
+0x85, 0x22, 0x90, 0x88, 0x32, 0xE0, 0x54, 0xFB,
+0xF0, 0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C,
+0x7E, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xEF, 0x64,
+0x01, 0x22, 0xE4, 0xF5, 0x77, 0x90, 0x88, 0x36,
+0xE0, 0x60, 0x4F, 0xB1, 0xB9, 0x70, 0x4B, 0x12,
+0xE0, 0x48, 0x75, 0x77, 0x01, 0xE5, 0x77, 0x60,
+0x41, 0x90, 0x88, 0x39, 0xE0, 0x20, 0xE2, 0x08,
+0x90, 0x8A, 0xB9, 0x12, 0x8A, 0x5F, 0xD1, 0x6E,
+0xD1, 0x7D, 0x90, 0x88, 0x3F, 0xE0, 0x60, 0x04,
+0x64, 0x01, 0x70, 0x10, 0xD1, 0x1B, 0xFF, 0xA3,
+0xE0, 0x2F, 0x12, 0x8F, 0x97, 0xD1, 0x20, 0xFF,
+0xA3, 0xE0, 0x80, 0x0C, 0xD1, 0x1B, 0xD1, 0x2A,
+0x2F, 0x12, 0x8F, 0x97, 0xD1, 0x20, 0xD1, 0x2A,
+0x2F, 0x33, 0x33, 0x33, 0x54, 0xF8, 0x90, 0x88,
+0x4F, 0xF0, 0x22, 0xE4, 0x90, 0x92, 0x20, 0xF0,
+0x90, 0x88, 0x3E, 0xE0, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x22, 0xFF, 0xA3, 0xE0, 0x75, 0xF0, 0x03,
+0xA4, 0x24, 0xFE, 0x22, 0xE4, 0x90, 0x95, 0xF0,
+0xF0, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x2E, 0xB1,
+0xB9, 0x70, 0x2A, 0xD1, 0x75, 0xF0, 0x12, 0xE0,
+0x48, 0x90, 0x95, 0xF0, 0x74, 0x01, 0xF0, 0xE4,
+0x90, 0x88, 0x3D, 0xF0, 0x04, 0x60, 0x16, 0x90,
+0x88, 0x39, 0xE0, 0x20, 0xE2, 0x08, 0x90, 0x8A,
+0xB9, 0x12, 0x8A, 0x5F, 0xD1, 0x6E, 0xD1, 0x7D,
+0xD1, 0x1B, 0x12, 0x8F, 0x97, 0x22, 0x7D, 0x01,
+0x7F, 0x04, 0x02, 0x04, 0x7E, 0x90, 0x88, 0x3C,
+0xE0, 0x90, 0x05, 0x73, 0x22, 0x90, 0x88, 0x3A,
+0xE0, 0x44, 0x10, 0xF0, 0x22, 0x12, 0xA7, 0x27,
+0x8C, 0x83, 0x7D, 0x01, 0x02, 0x04, 0x7E, 0xB1,
+0xB9, 0x70, 0x19, 0x90, 0x88, 0x36, 0xE0, 0x60,
+0x13, 0x90, 0x88, 0x3A, 0xE0, 0x20, 0xE4, 0x0C,
+0xF1, 0x90, 0x90, 0x88, 0x31, 0xE0, 0xF1, 0x9C,
+0x70, 0x02, 0xD1, 0x85, 0x22, 0xE4, 0xF5, 0x77,
+0x90, 0x06, 0xA9, 0xE0, 0xF5, 0x77, 0x54, 0xC0,
+0x70, 0x10, 0x90, 0x88, 0x3A, 0x12, 0xB7, 0xBC,
+0xD1, 0x85, 0x90, 0x88, 0x39, 0xE0, 0x60, 0x4E,
+0xE1, 0xCA, 0xE5, 0x77, 0x30, 0xE6, 0x27, 0x90,
+0x88, 0x36, 0xE0, 0x64, 0x01, 0x70, 0x22, 0x90,
+0x88, 0x3A, 0xE0, 0x44, 0x01, 0xF1, 0x55, 0x64,
+0x02, 0x60, 0x0F, 0x90, 0x88, 0x9D, 0xE0, 0x20,
+0xE0, 0x0F, 0x90, 0x8A, 0xE1, 0x12, 0x8E, 0xAD,
+0x80, 0x07, 0xF1, 0x17, 0x80, 0x03, 0x12, 0xBD,
+0x50, 0xE5, 0x77, 0x90, 0x88, 0x3A, 0x30, 0xE7,
+0x11, 0xE0, 0x44, 0x02, 0xF0, 0xF1, 0xEB, 0x12,
+0x8F, 0x96, 0x90, 0x88, 0x31, 0xE0, 0x44, 0x04,
+0xF0, 0x22, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90,
+0x94, 0xA2, 0x74, 0x01, 0xF0, 0x90, 0x06, 0x92,
+0x04, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x04, 0xF0,
+0x90, 0x88, 0x31, 0xE0, 0x44, 0x08, 0xF0, 0x90,
+0x88, 0x39, 0xE0, 0x64, 0x0C, 0x60, 0x11, 0x90,
+0x8A, 0xB9, 0x12, 0x8A, 0x5F, 0xF1, 0x89, 0x90,
+0x8A, 0xF9, 0x12, 0x8A, 0x5F, 0x12, 0x97, 0xF1,
+0x90, 0x8A, 0xAF, 0x12, 0x8A, 0x5F, 0x7D, 0x08,
+0xE4, 0xFF, 0x02, 0x04, 0x7E, 0xF0, 0x90, 0x88,
+0x34, 0xE0, 0x54, 0x0F, 0x22, 0x90, 0x88, 0x36,
+0xE0, 0x64, 0x01, 0x70, 0x23, 0xF1, 0x56, 0x60,
+0x11, 0x90, 0x8A, 0xB9, 0x12, 0x8A, 0x5F, 0xF1,
+0x89, 0x90, 0x8B, 0x01, 0x12, 0xBC, 0x6E, 0x02,
+0x04, 0x7A, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x08,
+0x90, 0x8A, 0xB9, 0x12, 0x8A, 0x5F, 0xD1, 0x6E,
+0x22, 0xE4, 0xFD, 0x7F, 0x0C, 0x02, 0x04, 0x7E,
+0x90, 0x01, 0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C,
+0x74, 0x02, 0xF0, 0x22, 0x54, 0xFB, 0xF0, 0x90,
+0x88, 0x3A, 0xE0, 0x54, 0xFD, 0xF0, 0x54, 0x07,
+0x22, 0x90, 0x88, 0x48, 0xE0, 0xFF, 0xA3, 0xE0,
+0xFD, 0x90, 0x88, 0x4F, 0xE0, 0xFB, 0x22, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x04, 0x02, 0xF1, 0xCA,
+0x90, 0x88, 0x9D, 0xE0, 0x20, 0xE0, 0x02, 0xF1,
+0x5D, 0x22, 0x90, 0x00, 0x02, 0xE0, 0x44, 0x01,
+0xF0, 0x22, 0xB1, 0xB9, 0x70, 0x14, 0x90, 0x88,
+0x36, 0xE0, 0x60, 0x0E, 0x90, 0x88, 0x3A, 0xE0,
+0x20, 0xE4, 0x07, 0xF1, 0x90, 0xF1, 0xEB, 0x12,
+0x8F, 0x96, 0x22, 0xE4, 0x90, 0x92, 0x20, 0xF0,
+0x90, 0x88, 0x94, 0x22, 0x12, 0x02, 0x06, 0x54,
+0x01, 0xFF, 0x90, 0x93, 0x5D, 0xE0, 0x54, 0xFE,
+0x4F, 0xF0, 0x22, 0x90, 0x96, 0xE3, 0x12, 0x86,
+0x76, 0x90, 0x96, 0xE2, 0xEF, 0xF0, 0x12, 0x86,
+0x7F, 0xB0, 0x96, 0x00, 0xB0, 0x9F, 0x01, 0xB0,
+0xA8, 0x06, 0xB0, 0xBB, 0x08, 0xB0, 0xC4, 0x09,
+0xB0, 0xCD, 0x0A, 0xB0, 0xD6, 0x12, 0xB0, 0xDF,
+0x13, 0xB0, 0xE8, 0x14, 0xB0, 0xF1, 0x1E, 0xB0,
+0xFA, 0x20, 0xB1, 0x02, 0x25, 0xB1, 0x0A, 0x26,
+0xB1, 0x13, 0x29, 0xB1, 0x1C, 0x2A, 0xB1, 0x24,
+0x40, 0xB1, 0x2F, 0x42, 0xB1, 0x3E, 0x43, 0xB1,
+0x47, 0x44, 0xB2, 0x11, 0x47, 0xB1, 0x50, 0x49,
+0xB1, 0x58, 0x60, 0xB1, 0x61, 0x61, 0xB1, 0x6A,
+0x62, 0xB1, 0x73, 0x63, 0xB1, 0x7C, 0x64, 0xB1,
+0x85, 0x65, 0xB1, 0x8E, 0x66, 0xB1, 0x97, 0x67,
+0xB1, 0xA0, 0x68, 0xB1, 0xA9, 0x69, 0xB1, 0xB2,
+0x6B, 0xB1, 0xBB, 0x6C, 0xB1, 0xC4, 0x6D, 0xB1,
+0xCD, 0x6E, 0xB1, 0xD6, 0x6F, 0xB1, 0xDF, 0x70,
+0xB1, 0xE8, 0xC2, 0xB1, 0xF0, 0xC3, 0xB1, 0xF9,
+0xC4, 0xB0, 0xB0, 0xC6, 0xB0, 0xB0, 0xC7, 0xB0,
+0xB0, 0xC8, 0x00, 0x00, 0xB2, 0x02, 0x90, 0x96,
+0xE3, 0x12, 0x86, 0x6D, 0x02, 0x86, 0xE0, 0x90,
+0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0x90, 0x02,
+0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x41, 0x1E,
+0x90, 0x96, 0xE2, 0xE0, 0xFF, 0xA3, 0x12, 0x86,
+0x6D, 0x61, 0x4B, 0x90, 0x96, 0xE3, 0x12, 0x86,
+0x6D, 0x02, 0x97, 0xF7, 0x90, 0x96, 0xE3, 0x12,
+0x86, 0x6D, 0x02, 0x9F, 0xE8, 0x90, 0x96, 0xE3,
+0x12, 0x86, 0x6D, 0x02, 0x9F, 0xF5, 0x90, 0x96,
+0xE3, 0x12, 0x86, 0x6D, 0x02, 0xA0, 0x0E, 0x90,
+0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0xA7, 0xEB,
+0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0xAF,
+0xF4, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02,
+0xA4, 0x1F, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D,
+0x41, 0xB5, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D,
+0xE1, 0xED, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D,
+0x02, 0xA8, 0xBA, 0x90, 0x96, 0xE3, 0x12, 0x86,
+0x6D, 0x02, 0xB8, 0x30, 0x90, 0x96, 0xE3, 0x12,
+0x86, 0x6D, 0x81, 0x6A, 0x90, 0x96, 0xE3, 0x12,
+0x86, 0x6D, 0x90, 0x8A, 0xA5, 0x80, 0x09, 0x90,
+0x96, 0xE3, 0x12, 0x86, 0x6D, 0x90, 0x8A, 0xB5,
+0x12, 0x9F, 0xDE, 0x02, 0x04, 0x7E, 0x90, 0x96,
+0xE3, 0x12, 0x86, 0x6D, 0x02, 0x25, 0xEC, 0x90,
+0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0x5B, 0xF3,
+0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0xE1, 0xB4,
+0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0x90,
+0xD9, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02,
+0x77, 0x4F, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D,
+0x02, 0x7C, 0x60, 0x90, 0x96, 0xE3, 0x12, 0x86,
+0x6D, 0x02, 0x7A, 0xC6, 0x90, 0x96, 0xE3, 0x12,
+0x86, 0x6D, 0x02, 0x5D, 0x36, 0x90, 0x96, 0xE3,
+0x12, 0x86, 0x6D, 0x02, 0x7B, 0xE9, 0x90, 0x96,
+0xE3, 0x12, 0x86, 0x6D, 0x02, 0x70, 0x33, 0x90,
+0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0x48, 0xC9,
+0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0x79,
+0xF3, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02,
+0x87, 0xCF, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D,
+0x02, 0x51, 0x7B, 0x90, 0x96, 0xE3, 0x12, 0x86,
+0x6D, 0x02, 0x79, 0x30, 0x90, 0x96, 0xE3, 0x12,
+0x86, 0x6D, 0x02, 0x57, 0xF2, 0x90, 0x96, 0xE3,
+0x12, 0x86, 0x6D, 0x02, 0x74, 0x8D, 0x90, 0x96,
+0xE3, 0x12, 0x86, 0x6D, 0x02, 0x78, 0x9A, 0x90,
+0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0x5E, 0x0B,
+0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x80, 0x22,
+0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02, 0xB8,
+0x46, 0x90, 0x96, 0xE3, 0x12, 0x86, 0x6D, 0x02,
+0x87, 0x8D, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x01,
+0xF0, 0x90, 0x96, 0xE2, 0xE0, 0x90, 0x01, 0xC2,
+0xF0, 0x22, 0x12, 0x02, 0x06, 0x90, 0x93, 0x4B,
+0xF0, 0x70, 0x02, 0xF1, 0xC4, 0x22, 0x12, 0x02,
+0x06, 0x64, 0x01, 0x60, 0x02, 0x41, 0xB4, 0x90,
+0x95, 0x04, 0xF0, 0x90, 0x95, 0x04, 0xE0, 0xFF,
+0xC3, 0x94, 0x10, 0x50, 0x27, 0xEF, 0x91, 0x06,
+0x7A, 0x95, 0x79, 0x03, 0x12, 0x5F, 0xA6, 0xBF,
+0x01, 0x12, 0x90, 0x95, 0x03, 0xE0, 0xFF, 0xA3,
+0xE0, 0x24, 0x05, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x95, 0x04, 0xE0,
+0x04, 0xF0, 0x80, 0xCF, 0x75, 0x45, 0x01, 0x75,
+0x46, 0x95, 0x75, 0x47, 0x05, 0x75, 0x48, 0x08,
+0x7B, 0x01, 0x7A, 0x94, 0x79, 0xBF, 0x12, 0x69,
+0xF5, 0x90, 0x94, 0xBD, 0x74, 0x24, 0xF0, 0x90,
+0x94, 0xDF, 0x74, 0x08, 0xF0, 0x75, 0x45, 0x01,
+0x75, 0x46, 0x95, 0x75, 0x47, 0x0D, 0xF5, 0x48,
+0x7B, 0x01, 0x7A, 0x94, 0x79, 0xE2, 0x12, 0x69,
+0xF5, 0x90, 0x94, 0xE0, 0x74, 0x25, 0xF0, 0x90,
+0x95, 0x02, 0x74, 0x08, 0xF0, 0x12, 0xA0, 0xCC,
+0x12, 0x9F, 0xDB, 0x12, 0x04, 0x7E, 0x7B, 0x01,
+0x7A, 0x94, 0x79, 0xE0, 0x12, 0x8A, 0x4D, 0x7F,
+0x04, 0x12, 0x04, 0x7E, 0x22, 0x71, 0xFD, 0xFF,
+0x54, 0x7F, 0x90, 0x88, 0x36, 0xF0, 0xEF, 0x12,
+0x8D, 0x35, 0xA3, 0x12, 0x87, 0x86, 0xFD, 0x54,
+0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x88, 0x34,
+0xE0, 0x54, 0xF0, 0x4F, 0x12, 0x87, 0x75, 0xFC,
+0x54, 0x01, 0x25, 0xE0, 0xFF, 0x90, 0x88, 0x31,
+0xE0, 0x54, 0xFD, 0x4F, 0xF0, 0xEC, 0x54, 0x04,
+0xC3, 0x13, 0xFF, 0x90, 0x88, 0x33, 0xE0, 0x54,
+0xFD, 0x4F, 0xF0, 0xED, 0x54, 0x0F, 0xC4, 0x54,
+0xF0, 0xFF, 0xA3, 0xE0, 0x54, 0x0F, 0x12, 0x87,
+0x24, 0x90, 0x88, 0x35, 0x12, 0x87, 0x7F, 0xFD,
+0x90, 0x8A, 0x89, 0x12, 0x8A, 0x5F, 0x7F, 0x02,
+0x12, 0x04, 0x7E, 0x90, 0x88, 0x9B, 0xF1, 0xBC,
+0x54, 0xFB, 0xF0, 0x54, 0xF7, 0xF0, 0x54, 0xEF,
+0xF0, 0x54, 0xDF, 0xF0, 0x54, 0xBF, 0xF0, 0x12,
+0x90, 0xD3, 0x12, 0x5C, 0x5F, 0x90, 0x88, 0x36,
+0xE0, 0xB4, 0x01, 0x07, 0x90, 0x88, 0x33, 0xE0,
+0x54, 0xFB, 0xF0, 0xF1, 0xD6, 0xF0, 0x90, 0x88,
+0x36, 0xF1, 0xE0, 0x12, 0xAF, 0x55, 0x90, 0x01,
+0xBE, 0xF0, 0x22, 0x71, 0xFD, 0x64, 0x01, 0x60,
+0x02, 0x61, 0xD8, 0xEF, 0x24, 0x39, 0x60, 0x12,
+0x14, 0x60, 0x19, 0x24, 0x02, 0x70, 0x1F, 0xE4,
+0x90, 0x94, 0xC3, 0xF0, 0xA3, 0x74, 0x06, 0xF0,
+0x80, 0x14, 0x90, 0x94, 0xC3, 0x74, 0x06, 0xF0,
+0xA3, 0xF0, 0x80, 0x0A, 0x90, 0x94, 0xC3, 0x74,
+0x0C, 0xF0, 0xA3, 0x74, 0x04, 0xF0, 0x71, 0xEC,
+0x71, 0xD9, 0x40, 0x1B, 0x90, 0x94, 0xC1, 0xE0,
+0x91, 0x06, 0x7A, 0x94, 0x79, 0xC0, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x07, 0x90, 0x94, 0xC0, 0xE0,
+0xF4, 0x70, 0x3D, 0x71, 0xE1, 0x80, 0xE1, 0x71,
+0xEC, 0x71, 0xD9, 0x40, 0x33, 0x90, 0x94, 0xC1,
+0xE0, 0xFD, 0x7C, 0x00, 0x24, 0xA8, 0xFF, 0xEC,
+0x34, 0x01, 0xFE, 0xED, 0x24, 0x01, 0xFD, 0xEC,
+0x33, 0xFC, 0x90, 0x94, 0xC3, 0xE0, 0xFB, 0xC3,
+0xED, 0x9B, 0xFD, 0xEC, 0x94, 0x00, 0xFC, 0x12,
+0x90, 0xD3, 0x8D, 0x82, 0x8C, 0x83, 0x12, 0x02,
+0x1F, 0xFD, 0x91, 0x10, 0x71, 0xE1, 0x80, 0xC9,
+0x22, 0x90, 0x94, 0xC2, 0xE0, 0xD3, 0x94, 0x00,
+0x22, 0x90, 0x94, 0xC1, 0xE0, 0x04, 0xF0, 0xA3,
+0xE0, 0x14, 0xF0, 0x22, 0x90, 0x94, 0xC3, 0xE0,
+0x90, 0x94, 0xC1, 0xF0, 0x90, 0x94, 0xC4, 0xE0,
+0x90, 0x94, 0xC2, 0xF0, 0x22, 0x90, 0x94, 0xBD,
+0x12, 0x86, 0x76, 0x02, 0x02, 0x06, 0x24, 0xA8,
+0xFF, 0xE4, 0x34, 0x01, 0xFE, 0x7B, 0x01, 0x22,
+0xE4, 0x90, 0x94, 0xC5, 0xF0, 0x90, 0x00, 0x37,
+0xE0, 0x44, 0x80, 0xF0, 0x90, 0x00, 0xCF, 0x74,
+0x69, 0xF0, 0xEF, 0x90, 0x00, 0x31, 0xF0, 0xEE,
+0x54, 0x03, 0xFF, 0xA3, 0xE0, 0x54, 0xFC, 0x4F,
+0xF0, 0x90, 0x00, 0x30, 0xED, 0xF0, 0x90, 0x00,
+0x33, 0xE0, 0x44, 0x80, 0xF0, 0x90, 0x00, 0x33,
+0xE0, 0x30, 0xE7, 0x09, 0x91, 0x62, 0x50, 0x05,
+0xE0, 0x04, 0xF0, 0x80, 0xF0, 0x90, 0x00, 0xCF,
+0xE4, 0xF0, 0x90, 0x00, 0x37, 0xE0, 0x54, 0x7F,
+0xF0, 0x91, 0x62, 0x7F, 0x00, 0x50, 0x02, 0x7F,
+0x01, 0x22, 0x90, 0x94, 0xC5, 0xE0, 0xC3, 0x94,
+0x64, 0x22, 0x90, 0x93, 0x32, 0xE0, 0x20, 0xE0,
+0x02, 0xA1, 0x2B, 0xE4, 0x90, 0x94, 0xBD, 0xF0,
+0xF1, 0xCC, 0x40, 0x02, 0xA1, 0x2B, 0xF1, 0x96,
 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
 0xF9, 0xFF, 0x90, 0x93, 0x33, 0xE0, 0xFD, 0xEF,
-0x5D, 0x60, 0x0E, 0x90, 0x95, 0x11, 0x91, 0x38,
-0x90, 0x95, 0x11, 0x91, 0x58, 0x44, 0x20, 0x91,
-0x00, 0x90, 0x95, 0x11, 0xE0, 0x04, 0xF0, 0x80,
-0xCB, 0x90, 0x00, 0x92, 0xE0, 0x54, 0xFE, 0xF0,
-0xE0, 0x44, 0x08, 0xF0, 0x90, 0x00, 0x02, 0xE0,
-0x54, 0xFD, 0xF0, 0x80, 0x07, 0x90, 0x00, 0x92,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x00, 0x08, 0xE0,
-0x44, 0x10, 0xF0, 0x7F, 0x01, 0x71, 0xB1, 0x90,
-0x00, 0x90, 0xE0, 0x44, 0x01, 0xF0, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C,
-0x6A, 0x90, 0x96, 0xBE, 0xEF, 0x12, 0xA7, 0xAE,
-0x90, 0x01, 0x09, 0xE0, 0x7F, 0x00, 0x30, 0xE7,
-0x02, 0x7F, 0x01, 0x90, 0x96, 0xBE, 0xE0, 0x6F,
-0x60, 0x35, 0xC3, 0x90, 0x96, 0xC0, 0xE0, 0x94,
-0x88, 0x90, 0x96, 0xBF, 0xE0, 0x94, 0x13, 0x40,
-0x08, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x10, 0xF0,
-0x22, 0x90, 0x96, 0xBF, 0x12, 0x9F, 0xEF, 0x91,
-0x01, 0xD3, 0x90, 0x96, 0xC0, 0xE0, 0x94, 0x32,
-0x90, 0x96, 0xBF, 0xE0, 0x94, 0x00, 0x40, 0xC0,
-0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE0, 0xB9, 0x22,
-0xF0, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C, 0x6A,
-0x90, 0x88, 0xA0, 0xE0, 0xC4, 0x13, 0x13, 0x54,
-0x01, 0xFF, 0x90, 0x88, 0xE0, 0xE0, 0xFB, 0x90,
-0x88, 0xDF, 0xE0, 0x90, 0x92, 0x90, 0x22, 0x90,
-0x88, 0x39, 0xE0, 0xFF, 0x60, 0x03, 0xB4, 0x08,
-0x0E, 0x12, 0xDB, 0x52, 0xBF, 0x01, 0x08, 0x51,
-0x86, 0x90, 0x01, 0xE5, 0xE0, 0x04, 0xF0, 0x22,
-0xE0, 0xFF, 0x24, 0x3F, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB0, 0xF0,
-0x74, 0x44, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB1, 0xF0, 0x22,
-0xE0, 0xFF, 0x24, 0x35, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB2, 0xF0,
-0x74, 0x3A, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB3, 0xF0, 0xE0,
-0x22, 0xE4, 0x90, 0x94, 0xB6, 0xF0, 0xA3, 0xF0,
-0x12, 0xD0, 0xA5, 0xEF, 0x64, 0x01, 0x60, 0x3C,
-0xC3, 0x90, 0x94, 0xB7, 0xE0, 0x94, 0x88, 0x90,
-0x94, 0xB6, 0xE0, 0x94, 0x13, 0x40, 0x0F, 0x90,
-0x01, 0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x01,
-0xC7, 0x74, 0xFD, 0xF0, 0x80, 0x1E, 0x90, 0x94,
-0xB6, 0x12, 0x9F, 0xEF, 0x91, 0x01, 0xD3, 0x90,
-0x94, 0xB7, 0xE0, 0x94, 0x32, 0x90, 0x94, 0xB6,
-0xE0, 0x94, 0x00, 0x40, 0xC3, 0x90, 0x01, 0xC6,
-0xE0, 0x30, 0xE3, 0xBC, 0x90, 0x01, 0xC7, 0x74,
-0xFE, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0x5D, 0x60, 0x02, 0xA1, 0x23, 0x12, 0x02, 0x06,
+0xFF, 0x30, 0xE0, 0x1A, 0x90, 0x93, 0x34, 0xE0,
+0xFE, 0x90, 0x94, 0xBD, 0xE0, 0xFD, 0x74, 0x01,
+0xA8, 0x05, 0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8,
+0xFC, 0x4E, 0x90, 0x93, 0x34, 0xF0, 0xEF, 0xC3,
+0x13, 0x30, 0xE0, 0x16, 0x90, 0x93, 0x35, 0xE0,
+0xFF, 0x90, 0x94, 0xBD, 0x12, 0x96, 0x3C, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93,
+0x35, 0xF0, 0x12, 0x87, 0x87, 0xFF, 0x90, 0x94,
+0xBD, 0xE0, 0xFE, 0x24, 0x36, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xEF, 0x12, 0x87, 0x25,
+0xFF, 0x74, 0x3B, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0x12, 0x87, 0x72, 0xFF, 0x74, 0x40, 0x2E,
+0xF5, 0x82, 0xE4, 0x34, 0x93, 0x12, 0x87, 0x7C,
+0xFF, 0x74, 0x45, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x93, 0x33,
+0xE0, 0xFF, 0x74, 0x01, 0xA8, 0x06, 0x08, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93,
+0x33, 0xF0, 0x22, 0x90, 0x94, 0xBD, 0xE0, 0x04,
+0xF0, 0x81, 0x78, 0x22, 0x90, 0x96, 0xCB, 0x91,
+0x00, 0x54, 0x7F, 0xFD, 0x12, 0x87, 0x87, 0x54,
+0x1F, 0xD1, 0x67, 0x54, 0xE0, 0x4F, 0x12, 0x87,
+0x86, 0xFE, 0x54, 0x60, 0xC4, 0x13, 0x54, 0x07,
+0x90, 0x96, 0xCE, 0xF0, 0xEE, 0x54, 0x80, 0x12,
+0x8D, 0x35, 0xC4, 0x33, 0x54, 0xE0, 0xD1, 0x67,
+0x54, 0xDF, 0x12, 0x87, 0x24, 0xFE, 0x54, 0x03,
+0xFC, 0xEE, 0x54, 0x30, 0xC4, 0x54, 0x03, 0xC4,
+0x54, 0xF0, 0x12, 0x87, 0xB5, 0x54, 0xCF, 0x12,
+0x87, 0x24, 0x54, 0x40, 0xC4, 0x13, 0x13, 0xD1,
+0x85, 0x12, 0x87, 0xB5, 0x54, 0xBF, 0x12, 0x87,
+0x24, 0x54, 0x80, 0x12, 0x8D, 0x35, 0xC4, 0x33,
+0x33, 0x33, 0x54, 0x80, 0x12, 0x87, 0xB5, 0x54,
+0x7F, 0x12, 0x87, 0x24, 0xFE, 0x54, 0x08, 0x13,
+0x13, 0x13, 0x54, 0x1F, 0x90, 0x96, 0xD0, 0xF0,
+0xFB, 0xEE, 0x54, 0x04, 0x13, 0x13, 0x54, 0x3F,
+0xA3, 0xF0, 0xEC, 0x54, 0x03, 0x12, 0x87, 0xB5,
+0x54, 0xFC, 0x4F, 0xF0, 0xEB, 0x70, 0x0E, 0xEC,
+0x54, 0x03, 0x25, 0xE0, 0x25, 0xE0, 0x12, 0x87,
+0xB5, 0x54, 0xF3, 0x4F, 0xF0, 0xD1, 0x5E, 0xF5,
+0x83, 0xE0, 0x54, 0xFB, 0xF0, 0xD1, 0x5E, 0xF5,
+0x83, 0xC0, 0x83, 0xC0, 0x82, 0xE0, 0xFF, 0x90,
+0x96, 0xD1, 0xE0, 0x12, 0xA7, 0xE3, 0xD0, 0x82,
+0xD0, 0x83, 0xF0, 0x90, 0x93, 0x53, 0xE0, 0x60,
+0x34, 0x90, 0x96, 0xCB, 0x12, 0x86, 0x6D, 0xE9,
+0x24, 0x03, 0xF9, 0xE4, 0x3A, 0xFA, 0x12, 0x02,
+0x06, 0x54, 0x1F, 0x12, 0x02, 0x4C, 0x90, 0x96,
+0xCF, 0x74, 0x01, 0xF0, 0x90, 0x96, 0xCF, 0xE0,
+0xFF, 0xC3, 0x94, 0x04, 0x50, 0x0F, 0xEF, 0xD1,
+0x74, 0xE4, 0x12, 0x02, 0x5E, 0x90, 0x96, 0xCF,
+0xE0, 0x04, 0xF0, 0x80, 0xE7, 0x90, 0x93, 0x51,
+0xE0, 0x54, 0x07, 0xFF, 0xBF, 0x05, 0x0A, 0xEC,
+0xB4, 0x01, 0x06, 0x90, 0x93, 0x56, 0x74, 0x01,
+0xF0, 0xE4, 0x90, 0x96, 0xCF, 0xF0, 0x90, 0x96,
+0xCF, 0xE0, 0xFC, 0xD1, 0x74, 0x12, 0x02, 0x1F,
+0xFF, 0xED, 0x12, 0xCC, 0xD1, 0xD1, 0x90, 0xEF,
+0xF0, 0x90, 0x96, 0xCF, 0xE0, 0x04, 0xF0, 0xE0,
+0xB4, 0x04, 0xE3, 0xAF, 0x05, 0x90, 0x8A, 0xFF,
+0x12, 0xA5, 0xDE, 0x02, 0x04, 0x7E, 0x74, 0xC6,
+0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0x22, 0xFF,
+0x75, 0xF0, 0x12, 0xED, 0x90, 0x89, 0x51, 0x12,
+0x04, 0x6E, 0xE0, 0x22, 0x24, 0x03, 0xFF, 0xE4,
+0x33, 0xFE, 0x90, 0x96, 0xCB, 0x12, 0x86, 0x6D,
+0x8F, 0x82, 0x8E, 0x83, 0x22, 0x54, 0x01, 0xC4,
+0x33, 0x33, 0x54, 0xC0, 0x22, 0x12, 0x04, 0x6E,
+0xE5, 0x82, 0x2C, 0xF5, 0x82, 0xE4, 0x35, 0x83,
+0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
 0xC0, 0xD0, 0x90, 0x01, 0xCC, 0xE0, 0x54, 0x0F,
-0xFD, 0xED, 0x70, 0x02, 0xA1, 0xB5, 0x90, 0x87,
+0xFD, 0xED, 0x70, 0x02, 0xE1, 0x85, 0x90, 0x87,
 0x0B, 0xE0, 0xFF, 0x70, 0x06, 0xA3, 0xE0, 0x64,
 0x09, 0x60, 0x0A, 0xEF, 0x14, 0xFF, 0x90, 0x87,
 0x0C, 0xE0, 0xB5, 0x07, 0x04, 0x7F, 0x01, 0x80,
 0x02, 0x7F, 0x00, 0xEF, 0x60, 0x09, 0x90, 0x01,
-0xC1, 0xE0, 0x44, 0x01, 0xF0, 0xA1, 0xB5, 0x90,
-0x96, 0xCA, 0xE0, 0x31, 0x72, 0x80, 0x05, 0xC3,
+0xC1, 0xE0, 0x44, 0x01, 0xF0, 0xE1, 0x85, 0x90,
+0x97, 0x06, 0xE0, 0xF1, 0x95, 0x80, 0x05, 0xC3,
 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xED,
-0xFB, 0xEF, 0x5B, 0x60, 0x7B, 0xE4, 0xFC, 0xB1,
-0xBB, 0xA4, 0xFF, 0xEC, 0x7A, 0x00, 0x2F, 0xFF,
-0xEA, 0x35, 0xF0, 0xFE, 0x74, 0xD0, 0xB1, 0xCE,
+0xFB, 0xEF, 0x5B, 0x60, 0x7B, 0xE4, 0xFC, 0xF1,
+0x8B, 0xA4, 0xFF, 0xEC, 0x7A, 0x00, 0x2F, 0xFF,
+0xEA, 0x35, 0xF0, 0xFE, 0x74, 0xD0, 0xF1, 0xA9,
 0x90, 0x87, 0x0C, 0xE0, 0xF9, 0x75, 0xF0, 0x08,
-0x90, 0x86, 0xBB, 0xB1, 0xD9, 0xEF, 0xB1, 0xBA,
+0x90, 0x86, 0xBB, 0xD1, 0x8D, 0xEF, 0xF1, 0x8A,
 0xA4, 0xFF, 0xEC, 0x2F, 0xFF, 0xEA, 0x35, 0xF0,
-0xFE, 0x74, 0xF0, 0xB1, 0xCE, 0x75, 0xF0, 0x08,
-0xE9, 0x90, 0x86, 0xBF, 0xB1, 0xD9, 0xEF, 0xF0,
-0x0C, 0xEC, 0xB4, 0x04, 0xC2, 0xB1, 0xC3, 0x80,
+0xFE, 0x74, 0xF0, 0xF1, 0xA9, 0x75, 0xF0, 0x08,
+0xE9, 0x90, 0x86, 0xBF, 0xD1, 0x8D, 0xEF, 0xF0,
+0x0C, 0xEC, 0xB4, 0x04, 0xC2, 0xF1, 0x9E, 0x80,
 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5D, 0xFD,
-0xB1, 0xC3, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0x90, 0x01, 0xCC, 0xF0, 0x90, 0x96, 0xCA, 0xE0,
+0xF1, 0x9E, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
+0x90, 0x01, 0xCC, 0xF0, 0x90, 0x97, 0x06, 0xE0,
 0x04, 0xF0, 0xE0, 0x54, 0x03, 0xF0, 0x90, 0x87,
 0x0C, 0xE0, 0x04, 0xF0, 0xE0, 0x7F, 0x00, 0xB4,
-0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x70, 0x02, 0x81,
-0xD9, 0xE4, 0x90, 0x87, 0x0C, 0xF0, 0x81, 0xD9,
+0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x70, 0x02, 0xC1,
+0xA9, 0xE4, 0x90, 0x87, 0x0C, 0xF0, 0xC1, 0xA9,
 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x02, 0xF0, 0x90,
-0x96, 0xCA, 0xE0, 0x44, 0x80, 0x90, 0x00, 0x8A,
-0xB1, 0xBA, 0x90, 0x01, 0xD0, 0x12, 0x04, 0x6E,
+0x97, 0x06, 0xE0, 0x44, 0x80, 0x90, 0x00, 0x8A,
+0xF1, 0x8A, 0x90, 0x01, 0xD0, 0x12, 0x04, 0x6E,
 0xE0, 0x90, 0x01, 0xC3, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xF0, 0x90, 0x96, 0xCA, 0xE0, 0x75,
-0xF0, 0x04, 0x22, 0x90, 0x96, 0xCA, 0xE0, 0xFF,
-0x74, 0x01, 0xA8, 0x07, 0x08, 0x22, 0x2F, 0xF5,
-0x82, 0x74, 0x01, 0x3E, 0xF5, 0x83, 0xE0, 0xFF,
-0x22, 0x12, 0x04, 0x6E, 0xE5, 0x82, 0x2C, 0xF5,
-0x82, 0xE4, 0x35, 0x83, 0xF5, 0x83, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96,
-0x56, 0xEF, 0xF0, 0x90, 0x88, 0x2B, 0xE0, 0x90,
-0x96, 0x68, 0xF0, 0xE4, 0x90, 0x96, 0x57, 0xF0,
-0x90, 0x96, 0x68, 0xE0, 0xFE, 0x90, 0x96, 0x57,
-0xE0, 0xFF, 0xC3, 0x9E, 0x50, 0x2B, 0xE0, 0xFE,
-0xF1, 0x06, 0xE4, 0xF0, 0xEE, 0xF1, 0x3D, 0xE0,
-0x30, 0xE7, 0x0A, 0x75, 0xF0, 0x12, 0xEF, 0xF1,
-0x10, 0xE4, 0xF0, 0x80, 0x0C, 0x12, 0x7C, 0x8F,
-0x90, 0x96, 0x57, 0xE0, 0xF1, 0x06, 0x74, 0x01,
-0xF0, 0x90, 0x96, 0x57, 0xE0, 0x04, 0xF0, 0x80,
-0xC7, 0x7F, 0x0C, 0x7E, 0x00, 0x12, 0x7C, 0x6A,
-0xE4, 0x90, 0x96, 0x57, 0xF0, 0x90, 0x96, 0x68,
-0xE0, 0xFF, 0x90, 0x96, 0x57, 0xE0, 0xFE, 0xC3,
-0x9F, 0x40, 0x02, 0xE1, 0x01, 0x74, 0x58, 0x2E,
-0xF1, 0x08, 0xE0, 0x70, 0x02, 0xC1, 0xF9, 0xEE,
-0xC4, 0x54, 0xF0, 0x24, 0x06, 0xF5, 0x82, 0xE4,
-0x34, 0x81, 0xF5, 0x83, 0xE0, 0xFD, 0xEE, 0xC4,
-0x54, 0xF0, 0x24, 0x07, 0xF5, 0x82, 0xE4, 0x34,
-0x81, 0xF5, 0x83, 0xF1, 0x16, 0xFC, 0x75, 0xF0,
-0x12, 0x90, 0x89, 0x53, 0xF1, 0x1F, 0xEC, 0xC4,
-0x54, 0xF0, 0x24, 0x0A, 0xF5, 0x82, 0xE4, 0x34,
-0x81, 0xF5, 0x83, 0xE0, 0xFD, 0xEC, 0xF1, 0x28,
-0xF1, 0x16, 0x75, 0xF0, 0x12, 0x90, 0x89, 0x57,
-0xF1, 0x1F, 0x7F, 0x01, 0x90, 0x96, 0x57, 0xE0,
-0xFE, 0xF1, 0x28, 0xE5, 0x82, 0x2F, 0xB1, 0xDF,
-0xE0, 0xFD, 0x75, 0xF0, 0x12, 0xEE, 0x90, 0x89,
-0x57, 0x12, 0x04, 0x6E, 0x75, 0xF0, 0x02, 0xEF,
-0xF1, 0x35, 0xED, 0xF0, 0x0F, 0xEF, 0xB4, 0x05,
-0xDB, 0x90, 0x96, 0x57, 0xE0, 0xFF, 0xC4, 0x54,
-0xF0, 0x24, 0x09, 0xF5, 0x82, 0xE4, 0x34, 0x81,
-0xF5, 0x83, 0xE0, 0xFE, 0xF1, 0x9F, 0xEE, 0xF0,
-0x90, 0x96, 0x57, 0xE0, 0xFF, 0x90, 0x96, 0x56,
-0xE0, 0xFD, 0x12, 0x61, 0xF7, 0x90, 0x96, 0x57,
-0xE0, 0x75, 0xF0, 0x12, 0xF1, 0x10, 0x74, 0x01,
-0xF0, 0x90, 0x96, 0x57, 0xE0, 0x04, 0xF0, 0xC1,
-0x45, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x24, 0x58,
-0xF5, 0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83, 0x22,
-0x90, 0x89, 0x56, 0x02, 0x04, 0x6E, 0xE0, 0xFE,
-0xED, 0xFF, 0x90, 0x96, 0x57, 0xE0, 0x22, 0x12,
-0x04, 0x6E, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22,
-0xC4, 0x54, 0xF0, 0x24, 0x0B, 0xF5, 0x82, 0xE4,
-0x34, 0x81, 0xF5, 0x83, 0x22, 0x12, 0x04, 0x6E,
-0xE4, 0xF0, 0xA3, 0x22, 0xEF, 0xC4, 0x54, 0xF0,
-0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
-0x83, 0x22, 0x7D, 0x07, 0xAF, 0x62, 0xED, 0x30,
-0xE0, 0x1E, 0x75, 0xF0, 0x12, 0xEF, 0x90, 0x89,
-0x57, 0xF1, 0x93, 0x90, 0x89, 0x59, 0xF1, 0x93,
-0x90, 0x89, 0x5B, 0xF1, 0x93, 0x90, 0x89, 0x5D,
-0xF1, 0x93, 0x90, 0x89, 0x5F, 0xF1, 0x35, 0xF0,
-0xED, 0x30, 0xE1, 0x0A, 0x75, 0xF0, 0x12, 0xEF,
-0x90, 0x89, 0x53, 0xF1, 0x35, 0xF0, 0xED, 0x30,
-0xE2, 0x04, 0xF1, 0x9F, 0xE4, 0xF0, 0xF1, 0x3C,
-0xE0, 0x54, 0xBF, 0x44, 0x80, 0xFE, 0xF1, 0x3C,
-0xEE, 0xF0, 0x22, 0x12, 0x04, 0x6E, 0xE4, 0xF0,
-0xA3, 0xF0, 0x75, 0xF0, 0x12, 0xEF, 0x22, 0x75,
-0xF0, 0x12, 0xEF, 0x90, 0x89, 0x55, 0x02, 0x04,
-0x6E, 0xE4, 0xFF, 0xA1, 0xE7, 0xF0, 0x7F, 0x0A,
-0x7E, 0x00, 0x02, 0x7C, 0x6A, 0x90, 0x00, 0x08,
-0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xF1, 0xB5, 0x12,
-0x76, 0x6D, 0x12, 0x75, 0xE0, 0x12, 0xC0, 0xDF,
-0x12, 0xC1, 0x18, 0x75, 0x21, 0x80, 0xE4, 0xF5,
-0x22, 0xF5, 0x23, 0x75, 0x24, 0x80, 0x90, 0x00,
-0x50, 0xE5, 0x21, 0xF0, 0xA3, 0xE5, 0x22, 0xF0,
-0xA3, 0xE5, 0x23, 0xF0, 0xA3, 0xE5, 0x24, 0xF0,
-0x22, 0x12, 0x02, 0x06, 0xFF, 0x90, 0x93, 0x4B,
-0xF0, 0xBF, 0x01, 0x0A, 0x7F, 0x01, 0x12, 0x8C,
-0x78, 0xE4, 0x90, 0x93, 0x4B, 0xF0, 0x22, 0x12,
-0x02, 0x06, 0x90, 0x93, 0x25, 0xF0, 0x12, 0x98,
-0xAC, 0x90, 0x93, 0x26, 0x12, 0x87, 0xE9, 0x90,
-0x93, 0x27, 0xF0, 0x22, 0xE4, 0xFD, 0x02, 0x8F,
-0xFA, 0x90, 0x95, 0xC3, 0xEF, 0xF0, 0x90, 0x04,
-0x7E, 0xE0, 0xFF, 0xA3, 0xE0, 0x90, 0x95, 0xE7,
-0xF0, 0xE0, 0xFE, 0x6F, 0x60, 0x72, 0x90, 0x95,
-0xC4, 0x74, 0x03, 0xF0, 0x90, 0x95, 0xE6, 0x74,
-0x08, 0xF0, 0xEE, 0x04, 0x54, 0x0F, 0xFF, 0xE4,
-0xFE, 0xEF, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x00,
-0xF5, 0x82, 0xE4, 0x34, 0x80, 0xF5, 0x83, 0xE5,
-0x82, 0x2E, 0x12, 0xB5, 0xDF, 0xE0, 0xFD, 0x74,
-0xC6, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5,
-0x83, 0xED, 0xF0, 0x0E, 0xEE, 0xB4, 0x08, 0xD9,
-0x7B, 0x01, 0x7A, 0x95, 0x79, 0xC4, 0x12, 0xA4,
-0x3F, 0x12, 0x04, 0x7E, 0x90, 0x95, 0xE7, 0xE0,
-0x04, 0x54, 0x0F, 0xFF, 0xF0, 0xBF, 0x0F, 0x02,
-0xE4, 0xF0, 0x90, 0x95, 0xE7, 0xE0, 0x90, 0x04,
-0x7F, 0xF0, 0x90, 0x95, 0xC3, 0xE0, 0x70, 0x05,
-0x90, 0x8A, 0xE5, 0x80, 0x03, 0x90, 0x8A, 0x79,
-0x12, 0x8B, 0x46, 0x7F, 0x04, 0x12, 0x04, 0x7E,
-0x22, 0xE4, 0xFF, 0x01, 0x19, 0xC0, 0xE0, 0xC0,
-0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
-0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
-0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0xA5, 0xF0,
-0x74, 0xB8, 0xA3, 0xF0, 0x12, 0x64, 0x7F, 0xE5,
-0x30, 0x30, 0xE1, 0x02, 0x51, 0xCB, 0xE5, 0x2D,
-0x30, 0xE1, 0x02, 0x11, 0xA1, 0xE5, 0x2D, 0x30,
-0xE3, 0x02, 0x71, 0x09, 0xE5, 0x2D, 0x30, 0xE4,
-0x02, 0x51, 0xF8, 0xE5, 0x2D, 0x30, 0xE5, 0x02,
-0x71, 0x52, 0xE5, 0x2F, 0x30, 0xE0, 0x02, 0x31,
-0xBA, 0xE5, 0x2F, 0x30, 0xE1, 0x03, 0x12, 0xAB,
-0xE0, 0xE5, 0x2F, 0x30, 0xE2, 0x02, 0x51, 0xDF,
-0xE5, 0x2F, 0x30, 0xE3, 0x02, 0x31, 0x82, 0xE5,
-0x2F, 0x30, 0xE4, 0x02, 0x51, 0x0D, 0xE5, 0x2F,
-0x30, 0xE5, 0x02, 0x31, 0xD3, 0xE5, 0x2F, 0x30,
-0xE6, 0x03, 0x12, 0xA7, 0x08, 0xE5, 0x2F, 0x30,
-0xE7, 0x02, 0x31, 0x9A, 0xE5, 0x30, 0x30, 0xE0,
-0x02, 0x31, 0x70, 0xE5, 0x30, 0x30, 0xE4, 0x03,
-0x12, 0xB7, 0xA9, 0xE5, 0x30, 0x30, 0xE5, 0x02,
-0x31, 0x68, 0x74, 0xA5, 0x04, 0x90, 0x01, 0xC4,
-0xF0, 0x74, 0xB8, 0xA3, 0xF0, 0xD0, 0x07, 0xD0,
-0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0,
-0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32,
-0x90, 0x8A, 0xDF, 0x31, 0xF4, 0x02, 0x04, 0x7A,
-0x31, 0xB3, 0xFF, 0xBF, 0x03, 0x0B, 0x90, 0x93,
-0x4A, 0xE0, 0xB4, 0x01, 0x04, 0x12, 0xA7, 0xD1,
-0xF0, 0x22, 0x12, 0xAF, 0x92, 0x70, 0x12, 0x90,
-0x88, 0x36, 0xE0, 0x60, 0x0C, 0x90, 0x88, 0x3A,
-0xE0, 0x20, 0xE4, 0x05, 0x51, 0x2E, 0x12, 0xA7,
-0x89, 0x22, 0xE4, 0xF5, 0x77, 0xF5, 0x78, 0xF5,
-0x79, 0x31, 0xB3, 0xFF, 0xBF, 0x03, 0x0B, 0x90,
-0x93, 0x4A, 0xE0, 0xB4, 0x01, 0x04, 0x12, 0xA7,
-0xD1, 0xF0, 0x22, 0x90, 0x01, 0x02, 0xE0, 0x54,
-0x03, 0x22, 0x12, 0xAD, 0x2D, 0xE4, 0xFF, 0x51,
-0x39, 0x90, 0x93, 0x03, 0xE0, 0x30, 0xE0, 0x02,
-0x51, 0x76, 0x90, 0x8B, 0x07, 0x12, 0x88, 0xCD,
-0x02, 0x8F, 0xC2, 0xE4, 0xFF, 0x12, 0x78, 0x4A,
-0xBF, 0x01, 0x18, 0x90, 0x88, 0x36, 0xE0, 0x60,
-0x12, 0x12, 0xA7, 0xE8, 0x64, 0x02, 0x60, 0x08,
-0x90, 0x8A, 0xE1, 0x31, 0xF4, 0x02, 0x04, 0x7A,
-0x12, 0x73, 0x8F, 0x22, 0xE0, 0xFE, 0xA3, 0xE0,
-0xAA, 0x06, 0xF9, 0x22, 0x12, 0xAF, 0x9B, 0x51,
-0xC4, 0x7F, 0x01, 0x51, 0x39, 0x90, 0x8B, 0x07,
-0x31, 0xF4, 0x02, 0x04, 0x7A, 0x12, 0xAF, 0x92,
-0x70, 0x1B, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x15,
-0x90, 0x88, 0x3A, 0xE0, 0x20, 0xE4, 0x0E, 0x51,
-0x2E, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0x51, 0xEB,
-0x70, 0x03, 0x12, 0xA6, 0xF0, 0x22, 0x90, 0x01,
-0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x02,
+0xAF, 0x22, 0xF0, 0x90, 0x97, 0x06, 0xE0, 0x75,
+0xF0, 0x04, 0x22, 0x54, 0x07, 0xFF, 0x74, 0x01,
+0x7E, 0x00, 0xA8, 0x07, 0x08, 0x22, 0x90, 0x97,
+0x06, 0xE0, 0xFF, 0x74, 0x01, 0xA8, 0x07, 0x08,
+0x22, 0x2F, 0xF5, 0x82, 0x74, 0x01, 0x3E, 0xF5,
+0x83, 0xE0, 0xFF, 0x22, 0x12, 0x02, 0x06, 0x90,
+0x96, 0x14, 0xF0, 0x22, 0xE0, 0x54, 0xFE, 0xF0,
+0x54, 0xFD, 0xF0, 0x22, 0x90, 0x05, 0x21, 0xE0,
+0x54, 0x7F, 0xF0, 0x22, 0x90, 0x94, 0xBD, 0xE0,
+0xFF, 0xC3, 0x94, 0x05, 0x22, 0xF0, 0x90, 0x01,
+0xB9, 0x74, 0x01, 0xF0, 0x90, 0x01, 0xB8, 0x22,
+0xE0, 0x90, 0x01, 0xBA, 0xF0, 0x90, 0x88, 0x38,
+0xE0, 0x90, 0x01, 0xBB, 0x22, 0x12, 0x02, 0x06,
+0x90, 0x88, 0x9C, 0xF0, 0x60, 0x39, 0xA3, 0xE0,
+0x20, 0xE0, 0x34, 0x90, 0x8A, 0xB9, 0x12, 0x8A,
+0x5F, 0xE4, 0xFD, 0x7F, 0x04, 0x12, 0x04, 0x7E,
+0x90, 0x88, 0x9B, 0xE0, 0xFF, 0xC3, 0x13, 0x30,
+0xE0, 0x1D, 0xEF, 0x13, 0x13, 0x13, 0x54, 0x1F,
+0x20, 0xE0, 0x14, 0x90, 0x88, 0x9B, 0xE0, 0x13,
+0x13, 0x54, 0x3F, 0x30, 0xE0, 0x04, 0x7F, 0x0D,
+0x80, 0x02, 0x7F, 0x09, 0x12, 0x71, 0x9A, 0x22,
+0x12, 0x02, 0x06, 0x54, 0x01, 0xFF, 0x90, 0x93,
+0x32, 0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x30, 0xE0,
+0x04, 0xE4, 0x12, 0x9E, 0x32, 0x22, 0x12, 0x02,
+0x06, 0xFF, 0x90, 0x93, 0x4C, 0xF0, 0xBF, 0x01,
+0x0A, 0x7F, 0x01, 0x12, 0xA1, 0x66, 0xE4, 0x90,
+0x93, 0x4C, 0xF0, 0x22, 0x90, 0x95, 0xCB, 0xEF,
+0xF0, 0x90, 0x04, 0x7E, 0xE0, 0xFF, 0xA3, 0xE0,
+0x90, 0x95, 0xEF, 0xF0, 0xE0, 0xFE, 0x6F, 0x60,
+0x72, 0x90, 0x95, 0xCC, 0x74, 0x03, 0xF0, 0x90,
+0x95, 0xEE, 0x74, 0x08, 0xF0, 0xEE, 0x04, 0x54,
+0x0F, 0xFF, 0xE4, 0xFE, 0xEF, 0x75, 0xF0, 0x08,
+0xA4, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x80,
+0xF5, 0x83, 0xE5, 0x82, 0x2E, 0x12, 0xB6, 0x93,
+0xE0, 0xFD, 0x74, 0xCE, 0x2E, 0xF5, 0x82, 0xE4,
+0x34, 0x95, 0xF5, 0x83, 0xED, 0xF0, 0x0E, 0xEE,
+0xB4, 0x08, 0xD9, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0xCC, 0x12, 0x9F, 0xDB, 0x12, 0x04, 0x7E, 0x90,
+0x95, 0xEF, 0xE0, 0x04, 0x54, 0x0F, 0xFF, 0xF0,
+0xBF, 0x0F, 0x02, 0xE4, 0xF0, 0x90, 0x95, 0xEF,
+0xE0, 0x90, 0x04, 0x7F, 0xF0, 0x90, 0x95, 0xCB,
+0xE0, 0x70, 0x05, 0x90, 0x8A, 0xE5, 0x80, 0x03,
+0x90, 0x8A, 0x79, 0x12, 0x8A, 0x5F, 0x7F, 0x04,
+0x12, 0x04, 0x7E, 0x22, 0xE4, 0xFF, 0x01, 0x5C,
+0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82,
+0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0,
+0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0,
+0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4,
+0x74, 0xE8, 0xF0, 0x74, 0xB8, 0xA3, 0xF0, 0x12,
+0x64, 0x7F, 0xE5, 0x30, 0x30, 0xE1, 0x02, 0xB1,
+0x58, 0xE5, 0x2D, 0x30, 0xE1, 0x02, 0x11, 0xE4,
+0xE5, 0x2D, 0x30, 0xE3, 0x02, 0x71, 0xD8, 0xE5,
+0x2D, 0x30, 0xE4, 0x02, 0xB1, 0x6C, 0xE5, 0x2D,
+0x30, 0xE5, 0x02, 0xB1, 0x7D, 0xE5, 0x2F, 0x30,
+0xE0, 0x02, 0x71, 0xBF, 0xE5, 0x2F, 0x30, 0xE1,
+0x03, 0x12, 0x8B, 0xFF, 0xE5, 0x2F, 0x30, 0xE2,
+0x02, 0x71, 0xFB, 0xE5, 0x2F, 0x30, 0xE3, 0x03,
+0x12, 0xAF, 0xD2, 0xE5, 0x2F, 0x30, 0xE4, 0x03,
+0x12, 0xAE, 0x8F, 0xE5, 0x2F, 0x30, 0xE5, 0x02,
+0x91, 0x39, 0xE5, 0x2F, 0x30, 0xE6, 0x02, 0x71,
+0xA7, 0xE5, 0x2F, 0x30, 0xE7, 0x02, 0x71, 0x88,
+0xE5, 0x30, 0x30, 0xE0, 0x02, 0x71, 0x78, 0xE5,
+0x30, 0x30, 0xE4, 0x02, 0x31, 0xAB, 0xE5, 0x30,
+0x30, 0xE5, 0x02, 0x71, 0x66, 0x74, 0xE8, 0x04,
+0x90, 0x01, 0xC4, 0xF0, 0x74, 0xB8, 0xA3, 0xF0,
+0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
+0xD0, 0xE0, 0x32, 0xE4, 0xFF, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x85, 0xEF,
+0xF0, 0x90, 0x88, 0x2B, 0xE0, 0x90, 0x96, 0x97,
+0xF0, 0xE4, 0x90, 0x96, 0x86, 0xF0, 0x90, 0x96,
+0x97, 0xE0, 0xFE, 0x90, 0x96, 0x86, 0xE0, 0xFF,
+0xC3, 0x9E, 0x50, 0x2B, 0xE0, 0xFE, 0x51, 0xCD,
+0xE4, 0xF0, 0xEE, 0x71, 0x59, 0xE0, 0x30, 0xE7,
+0x0A, 0x75, 0xF0, 0x12, 0xEF, 0x51, 0xD7, 0xE4,
+0xF0, 0x80, 0x0C, 0x12, 0x7C, 0x8F, 0x90, 0x96,
+0x86, 0xE0, 0x51, 0xCD, 0x74, 0x01, 0xF0, 0x90,
+0x96, 0x86, 0xE0, 0x04, 0xF0, 0x80, 0xC7, 0x7F,
+0x0C, 0x7E, 0x00, 0x12, 0x7C, 0x6A, 0xE4, 0x90,
+0x96, 0x86, 0xF0, 0x90, 0x96, 0x97, 0xE0, 0xFF,
+0x90, 0x96, 0x86, 0xE0, 0xFE, 0xC3, 0x9F, 0x40,
+0x02, 0x41, 0xC8, 0x74, 0x87, 0x2E, 0x51, 0xCF,
+0xE0, 0x70, 0x02, 0x41, 0xC0, 0xEE, 0xC4, 0x54,
+0xF0, 0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34, 0x81,
+0xF5, 0x83, 0xE0, 0xFD, 0xEE, 0xC4, 0x54, 0xF0,
+0x24, 0x07, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
+0x83, 0x51, 0xDD, 0xFC, 0x75, 0xF0, 0x12, 0x90,
+0x89, 0x53, 0x51, 0xE6, 0xEC, 0xC4, 0x54, 0xF0,
+0x24, 0x0A, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
+0x83, 0xE0, 0xFD, 0xEC, 0x51, 0xEF, 0x51, 0xDD,
+0x75, 0xF0, 0x12, 0x90, 0x89, 0x57, 0x51, 0xE6,
+0x7F, 0x01, 0x90, 0x96, 0x86, 0xE0, 0xFE, 0x51,
+0xEF, 0xE5, 0x82, 0x2F, 0x12, 0xB6, 0x93, 0xE0,
+0xFD, 0x75, 0xF0, 0x12, 0xEE, 0x90, 0x89, 0x57,
+0x12, 0x04, 0x6E, 0x75, 0xF0, 0x02, 0xEF, 0x51,
+0xFC, 0xED, 0xF0, 0x0F, 0xEF, 0xB4, 0x05, 0xDA,
+0x90, 0x96, 0x86, 0xE0, 0xFF, 0xC4, 0x54, 0xF0,
+0x24, 0x09, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
+0x83, 0xE0, 0xFE, 0x71, 0x6E, 0xEE, 0xF0, 0x90,
+0x96, 0x86, 0xE0, 0xFF, 0x90, 0x96, 0x85, 0xE0,
+0xFD, 0x12, 0x61, 0xF7, 0x90, 0x96, 0x86, 0xE0,
+0x75, 0xF0, 0x12, 0x51, 0xD7, 0x74, 0x01, 0xF0,
+0x90, 0x96, 0x86, 0xE0, 0x04, 0xF0, 0x41, 0x0B,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x24, 0x87, 0xF5,
+0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83, 0x22, 0x90,
+0x89, 0x56, 0x02, 0x04, 0x6E, 0xE0, 0xFE, 0xED,
+0xFF, 0x90, 0x96, 0x86, 0xE0, 0x22, 0x12, 0x04,
+0x6E, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xC4,
+0x54, 0xF0, 0x24, 0x0B, 0xF5, 0x82, 0xE4, 0x34,
+0x81, 0xF5, 0x83, 0x22, 0x12, 0x04, 0x6E, 0xE4,
+0xF0, 0xA3, 0x22, 0x7D, 0x07, 0xAF, 0x62, 0xED,
+0x30, 0xE0, 0x1E, 0x75, 0xF0, 0x12, 0xEF, 0x90,
+0x89, 0x57, 0x71, 0x4C, 0x90, 0x89, 0x59, 0x71,
+0x4C, 0x90, 0x89, 0x5B, 0x71, 0x4C, 0x90, 0x89,
+0x5D, 0x71, 0x4C, 0x90, 0x89, 0x5F, 0x51, 0xFC,
+0xF0, 0xED, 0x30, 0xE1, 0x0A, 0x75, 0xF0, 0x12,
+0xEF, 0x90, 0x89, 0x53, 0x51, 0xFC, 0xF0, 0xED,
+0x30, 0xE2, 0x04, 0x71, 0x6E, 0xE4, 0xF0, 0x71,
+0x58, 0xE0, 0x54, 0xBF, 0x44, 0x80, 0xFE, 0x71,
+0x58, 0xEE, 0xF0, 0x22, 0x12, 0x04, 0x6E, 0xE4,
+0xF0, 0xA3, 0xF0, 0x75, 0xF0, 0x12, 0xEF, 0x22,
+0xEF, 0xC4, 0x54, 0xF0, 0x24, 0x03, 0xF5, 0x82,
+0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x90, 0x8A,
+0xDF, 0x91, 0x6E, 0x02, 0x04, 0x7A, 0x75, 0xF0,
+0x12, 0xEF, 0x90, 0x89, 0x55, 0x02, 0x04, 0x6E,
+0x71, 0x9F, 0xBF, 0x03, 0x0A, 0x90, 0x93, 0x4B,
+0xE0, 0xB4, 0x01, 0x03, 0x12, 0xB7, 0xC4, 0x22,
+0xE4, 0xF5, 0x77, 0xF5, 0x78, 0xF5, 0x79, 0x71,
+0x9F, 0xBF, 0x03, 0x0A, 0x90, 0x93, 0x4B, 0xE0,
+0xB4, 0x01, 0x03, 0x12, 0xB7, 0xC4, 0x22, 0x90,
+0x01, 0x02, 0xE0, 0x54, 0x03, 0xFF, 0x22, 0xE4,
+0xFF, 0x12, 0x78, 0x4A, 0xBF, 0x01, 0x0F, 0x90,
+0x88, 0x36, 0xE0, 0x60, 0x09, 0xB1, 0x50, 0x54,
+0x07, 0x70, 0x03, 0x12, 0xAE, 0x85, 0x22, 0x12,
+0xAD, 0xC2, 0xE4, 0xFF, 0x91, 0xB7, 0x90, 0x93,
+0x03, 0xE0, 0x30, 0xE0, 0x02, 0x91, 0xF4, 0x90,
+0x8B, 0x07, 0x12, 0x8E, 0xAD, 0x02, 0x8F, 0xA5,
+0x90, 0x93, 0x03, 0xE0, 0x30, 0xE0, 0x0B, 0x90,
+0x8A, 0xE5, 0x12, 0x8A, 0x5F, 0x7F, 0x20, 0x12,
+0x04, 0x7E, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0,
+0x09, 0x90, 0x94, 0xB7, 0xE0, 0x20, 0xE0, 0x02,
+0xB1, 0x42, 0x22, 0x90, 0x88, 0x39, 0xE0, 0x64,
+0x02, 0x60, 0x29, 0x90, 0x88, 0x9D, 0xE0, 0x30,
+0xE0, 0x0B, 0x90, 0x94, 0xAF, 0xE0, 0xFF, 0x12,
+0x8D, 0x35, 0x20, 0xE0, 0x03, 0x12, 0xA9, 0x94,
+0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x0D, 0x90,
+0x94, 0xAF, 0xE0, 0xFF, 0x12, 0x8D, 0x35, 0x30,
+0xE0, 0x02, 0x91, 0x2D, 0x22, 0x90, 0x06, 0xA9,
+0xE0, 0xF5, 0x77, 0x30, 0xE6, 0x02, 0x91, 0x87,
+0x22, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x0D,
+0x90, 0x94, 0xAF, 0xE0, 0xFF, 0x12, 0x8D, 0x35,
+0x30, 0xE0, 0x02, 0x80, 0x3A, 0xE4, 0xFF, 0x12,
+0x78, 0x4A, 0xBF, 0x01, 0x18, 0x90, 0x88, 0x36,
+0xE0, 0x60, 0x12, 0x12, 0xAF, 0x56, 0x64, 0x02,
+0x60, 0x08, 0x90, 0x8A, 0xE1, 0x91, 0x6E, 0x02,
+0x04, 0x7A, 0x12, 0x73, 0x8F, 0x22, 0xE0, 0xFE,
+0xA3, 0xE0, 0xAA, 0x06, 0xF9, 0x22, 0x12, 0xAE,
+0x34, 0xB1, 0x49, 0x7F, 0x01, 0x91, 0xB7, 0x90,
+0x8B, 0x07, 0x91, 0x6E, 0x02, 0x04, 0x7A, 0x90,
+0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x28, 0x12, 0x8D,
+0x31, 0x30, 0xE0, 0x22, 0x90, 0x88, 0xAF, 0xE0,
+0xFF, 0x70, 0x0A, 0xEF, 0x70, 0x18, 0x90, 0x88,
+0xA0, 0xE0, 0x30, 0xE0, 0x11, 0x90, 0x06, 0x04,
+0xE0, 0x44, 0x40, 0xF0, 0xE0, 0x44, 0x80, 0xF0,
+0x90, 0x8A, 0xE1, 0x12, 0x8E, 0xAD, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88,
+0x33, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x28, 0x90,
+0x96, 0x62, 0x74, 0x1E, 0xF0, 0x90, 0x96, 0x84,
+0x74, 0x01, 0xF0, 0x90, 0x96, 0x64, 0xEF, 0xF0,
+0x7B, 0x01, 0x7A, 0x96, 0x79, 0x62, 0x12, 0x9F,
+0xDB, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0xE5, 0x12,
+0x8A, 0x5F, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93, 0x0F, 0xE0,
+0xFD, 0x7C, 0x00, 0xA3, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x12, 0x02, 0x92, 0xED, 0x4C, 0x70, 0x05,
+0x90, 0x93, 0x1C, 0x80, 0x2A, 0xED, 0x64, 0x01,
+0x4C, 0x70, 0x05, 0x90, 0x93, 0x1D, 0x80, 0x1F,
+0xED, 0x64, 0x02, 0x4C, 0x70, 0x05, 0x90, 0x93,
+0x1E, 0x80, 0x14, 0xED, 0x64, 0x03, 0x4C, 0x70,
+0x05, 0x90, 0x93, 0x1F, 0x80, 0x09, 0xED, 0x64,
+0x04, 0x4C, 0x70, 0x0D, 0x90, 0x93, 0x20, 0xE0,
+0xFF, 0xB1, 0x62, 0x90, 0x93, 0x10, 0x12, 0xA7,
+0xDC, 0x22, 0x90, 0x94, 0xB8, 0xE0, 0x04, 0xF0,
+0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C, 0x74,
+0x90, 0x88, 0x3A, 0xE0, 0x54, 0xFE, 0xF0, 0x22,
+0x90, 0x88, 0x36, 0xE0, 0x60, 0x03, 0x12, 0xAF,
+0xB7, 0x22, 0x90, 0x04, 0x24, 0xEF, 0xF0, 0x90,
+0x04, 0x57, 0xF0, 0x22, 0x90, 0x8A, 0x75, 0x12,
+0x8E, 0xAD, 0x90, 0x8A, 0xE5, 0x12, 0x8A, 0x5F,
+0x7F, 0x02, 0x02, 0x04, 0x7E, 0x90, 0x01, 0xCF,
+0xE0, 0x90, 0x95, 0xCB, 0xF0, 0xE0, 0xFF, 0x30,
+0xE0, 0x07, 0x90, 0x01, 0xCF, 0xE0, 0x54, 0xFE,
+0xF0, 0xEF, 0x30, 0xE5, 0x23, 0x90, 0x01, 0xCF,
+0xE0, 0x54, 0xDF, 0xF0, 0x90, 0x01, 0x34, 0x74,
+0x20, 0xF0, 0xE4, 0xF5, 0xA8, 0xF5, 0xE8, 0x12,
+0x76, 0x6D, 0x90, 0x00, 0x03, 0xE0, 0x54, 0xFB,
+0xFD, 0x7F, 0x03, 0x12, 0x7B, 0x2E, 0x80, 0xFE,
+0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0,
+0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00,
+0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04,
+0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01,
+0xC4, 0x74, 0xB9, 0xF0, 0x74, 0xBD, 0xA3, 0xF0,
+0x12, 0x75, 0x50, 0xE5, 0x3D, 0x30, 0xE0, 0x02,
+0xF1, 0xE0, 0xE5, 0x3D, 0x30, 0xE1, 0x03, 0x12,
+0xC9, 0xC0, 0xE5, 0x3D, 0x30, 0xE2, 0x03, 0x12,
+0xA8, 0x97, 0xE5, 0x3D, 0x30, 0xE4, 0x02, 0xF1,
+0x34, 0xE5, 0x3E, 0x30, 0xE0, 0x03, 0x12, 0xC9,
+0xDE, 0xE5, 0x3E, 0x30, 0xE3, 0x02, 0xD1, 0x73,
+0xE5, 0x3F, 0x30, 0xE2, 0x0A, 0x12, 0xCA, 0x7A,
+0x90, 0x07, 0x8F, 0xE0, 0x44, 0x10, 0xF0, 0xE5,
+0x40, 0x30, 0xE1, 0x0B, 0x90, 0x8A, 0xE5, 0x12,
+0x8A, 0x5F, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xE5,
+0x40, 0x30, 0xE4, 0x02, 0x91, 0x76, 0xE5, 0x40,
+0x30, 0xE5, 0x03, 0x12, 0xCA, 0xBF, 0xE5, 0x40,
+0x30, 0xE6, 0x03, 0x12, 0xCB, 0x25, 0xE5, 0x40,
+0x30, 0xE7, 0x02, 0xF1, 0x9C, 0x74, 0xB9, 0x04,
+0x90, 0x01, 0xC4, 0xF0, 0x74, 0xBD, 0xA3, 0xF0,
+0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
+0xD0, 0xE0, 0x32, 0x90, 0x01, 0x8C, 0xE4, 0xF0,
+0xA3, 0xF0, 0xA3, 0x74, 0x71, 0xF0, 0xA3, 0x74,
+0x02, 0xF0, 0x90, 0x01, 0x95, 0xE0, 0x54, 0xF0,
+0x44, 0x07, 0xF0, 0x90, 0x01, 0x98, 0x74, 0x7F,
+0xF0, 0x90, 0x01, 0x01, 0xE0, 0x54, 0xFB, 0xF0,
+0xE0, 0x44, 0x04, 0xF0, 0x22, 0x12, 0x9E, 0xE9,
+0x54, 0x7F, 0x90, 0x95, 0xC9, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0x94, 0xBC, 0xE0, 0x54, 0x02, 0xFF,
+0x90, 0x95, 0xCA, 0xE0, 0x54, 0x02, 0xFD, 0xED,
+0x6F, 0x30, 0xE1, 0x04, 0xD1, 0x73, 0xD1, 0xE2,
+0x90, 0x95, 0xCA, 0xE0, 0x20, 0xE1, 0x0B, 0x90,
+0x94, 0xBC, 0xE0, 0x20, 0xE1, 0x04, 0xD1, 0x73,
+0xD1, 0xE2, 0x90, 0x95, 0xC9, 0xE0, 0xFF, 0xA3,
+0xE0, 0x90, 0x94, 0xBB, 0xCF, 0xF0, 0xA3, 0xEF,
+0xF0, 0x22, 0xE4, 0x90, 0x97, 0x01, 0xF0, 0xA3,
+0xF0, 0x12, 0xD8, 0x26, 0xEF, 0x64, 0x01, 0x60,
+0x3C, 0xC3, 0x90, 0x97, 0x02, 0xE0, 0x94, 0x88,
+0x90, 0x97, 0x01, 0xE0, 0x94, 0x13, 0x40, 0x0F,
+0x90, 0x01, 0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90,
+0x01, 0xC7, 0x74, 0xFD, 0xF0, 0x80, 0x1E, 0x90,
+0x97, 0x01, 0x12, 0xA7, 0xDC, 0xF1, 0xE2, 0xD3,
+0x90, 0x97, 0x02, 0xE0, 0x94, 0x32, 0x90, 0x97,
+0x01, 0xE0, 0x94, 0x00, 0x40, 0xC3, 0x90, 0x01,
+0xC6, 0xE0, 0x30, 0xE3, 0xBC, 0x90, 0x01, 0xC7,
+0x74, 0xFE, 0xF0, 0x22, 0x90, 0x88, 0x9D, 0xE0,
+0x30, 0xE0, 0x0D, 0xF1, 0x86, 0x30, 0xE0, 0x08,
+0x90, 0x8A, 0xBB, 0x12, 0x8A, 0x5F, 0xF1, 0x8F,
+0x12, 0x9F, 0xC6, 0x90, 0x97, 0x0A, 0xEF, 0xF0,
+0x90, 0x86, 0xB3, 0xE0, 0xB4, 0x02, 0x12, 0x90,
+0x97, 0x0A, 0xE0, 0xFF, 0x64, 0x01, 0x60, 0x25,
+0x90, 0x01, 0x4D, 0xE0, 0x64, 0x80, 0xF0, 0x80,
+0x19, 0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x7F,
+0x64, 0x7E, 0x00, 0x12, 0x7C, 0x6A, 0x90, 0x06,
+0x90, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x97, 0x0A,
+0xE0, 0xFF, 0x12, 0x97, 0x00, 0x22, 0x90, 0x88,
+0xA1, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x22, 0xE4,
+0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xC2, 0xE0,
+0x54, 0xEF, 0xF0, 0x22, 0x90, 0x88, 0xB8, 0xE0,
+0x30, 0xE0, 0x05, 0x90, 0x8A, 0xEB, 0x80, 0x27,
+0x90, 0x94, 0xAF, 0x12, 0xAE, 0x23, 0x30, 0xE0,
+0x1B, 0x90, 0x88, 0xC2, 0xE0, 0xC4, 0x54, 0x0F,
+0x20, 0xE0, 0x08, 0x90, 0x8A, 0xBB, 0x12, 0x8A,
+0x5F, 0xF1, 0x8F, 0x90, 0x94, 0xAF, 0xE0, 0x54,
+0xF7, 0xF0, 0x80, 0x06, 0x90, 0x8A, 0x99, 0x12,
+0x8E, 0xAD, 0x90, 0x88, 0xF0, 0xE0, 0x30, 0xE0,
+0x06, 0x90, 0x8A, 0xE7, 0x12, 0x8E, 0xAD, 0x22,
+0x22, 0xF0, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C,
+0x6A, 0x90, 0x95, 0x40, 0x02, 0x86, 0x6D, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0xE4, 0x90, 0x86, 0xAF,
+0x12, 0x9E, 0x31, 0x90, 0x93, 0x01, 0xF0, 0x90,
+0x93, 0x5E, 0xF0, 0xA3, 0xF0, 0x22, 0x75, 0x21,
+0x80, 0xE4, 0xF5, 0x22, 0xF5, 0x23, 0x75, 0x24,
+0x80, 0x90, 0x00, 0x50, 0xE5, 0x21, 0xF0, 0xA3,
+0xE5, 0x22, 0xF0, 0xA3, 0xE5, 0x23, 0xF0, 0xA3,
+0xE5, 0x24, 0xF0, 0x22, 0x11, 0x42, 0x12, 0x76,
+0x6D, 0x12, 0x75, 0xE0, 0x91, 0x66, 0x91, 0x07,
+0x80, 0xD4, 0x90, 0x00, 0x08, 0xE0, 0x54, 0xEF,
+0xF0, 0x22, 0xE4, 0x90, 0x95, 0x18, 0xF0, 0x71,
+0xE8, 0x11, 0x42, 0xE4, 0xFF, 0x71, 0x4C, 0x90,
+0x93, 0x32, 0xE0, 0x20, 0xE0, 0x02, 0x21, 0x3D,
+0x90, 0x00, 0x02, 0xE0, 0x44, 0x02, 0xF0, 0xE4,
+0x90, 0x95, 0x19, 0xF0, 0x90, 0x95, 0x19, 0xE0,
+0xFF, 0xC3, 0x94, 0x05, 0x50, 0x2D, 0x12, 0xB7,
+0x96, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
+0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x35, 0xE0, 0xFD,
+0xEF, 0x5D, 0x60, 0x0F, 0x90, 0x95, 0x19, 0x71,
+0x0B, 0x90, 0x95, 0x19, 0x71, 0x2B, 0x44, 0x40,
+0x12, 0xBF, 0xE1, 0x90, 0x95, 0x19, 0xE0, 0x04,
+0xF0, 0x80, 0xC9, 0x90, 0x07, 0xC7, 0xE4, 0xF0,
+0x90, 0x07, 0xC6, 0xF0, 0x90, 0x07, 0xC5, 0x74,
+0x77, 0xF0, 0x90, 0x07, 0xC4, 0xE4, 0xF0, 0x90,
+0x07, 0xC0, 0x74, 0x38, 0xF0, 0xA3, 0xE4, 0xF0,
+0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0x74, 0xC0, 0xF0,
+0x90, 0x02, 0x26, 0xE0, 0x44, 0x01, 0xF0, 0xE0,
+0x90, 0x95, 0x1A, 0xF0, 0x90, 0x95, 0x1A, 0xE0,
+0x30, 0xE0, 0x18, 0x90, 0x95, 0x18, 0xE0, 0x04,
+0x71, 0x9C, 0x90, 0x02, 0x26, 0xE0, 0x90, 0x95,
+0x1A, 0xF0, 0x90, 0x95, 0x18, 0xE0, 0xD3, 0x94,
+0xFA, 0x40, 0xE1, 0x90, 0x02, 0x03, 0x74, 0x80,
+0xF0, 0x90, 0x04, 0x24, 0xE0, 0x90, 0x95, 0x1B,
+0xF0, 0x90, 0x04, 0x22, 0xE0, 0x44, 0x10, 0xF0,
+0x90, 0x02, 0x00, 0xE0, 0x90, 0x95, 0x1A, 0xF0,
+0x90, 0x02, 0x01, 0x31, 0x4D, 0x90, 0x02, 0x02,
+0x31, 0x4D, 0x90, 0x02, 0x14, 0x31, 0x4D, 0xE0,
+0x04, 0xF0, 0xE0, 0x90, 0x04, 0x24, 0xF0, 0x12,
+0x9E, 0xE1, 0x90, 0x95, 0x1B, 0xE0, 0x90, 0x04,
+0x24, 0xF0, 0x90, 0xFD, 0x09, 0x74, 0xFF, 0xF0,
+0x90, 0xFD, 0x08, 0xE4, 0xF0, 0x51, 0xF4, 0xF0,
+0xE4, 0xFD, 0x12, 0x76, 0xF7, 0x90, 0x88, 0x32,
+0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xE0, 0xFF, 0x90,
+0x95, 0x1A, 0xE0, 0x2F, 0xF0, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x31, 0xD0, 0x11,
+0x4A, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x88,
+0x39, 0xE0, 0xFF, 0x60, 0x03, 0xB4, 0x08, 0x0D,
+0x31, 0x7E, 0xBF, 0x01, 0x08, 0x31, 0x56, 0x90,
+0x01, 0xE5, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x02,
+0x87, 0xE0, 0x60, 0x02, 0x80, 0x08, 0x90, 0x01,
+0x00, 0xE0, 0x64, 0x3F, 0x60, 0x05, 0x75, 0x61,
+0x01, 0x80, 0x2E, 0x90, 0x02, 0x96, 0xE0, 0x60,
+0x05, 0x75, 0x61, 0x10, 0x80, 0x23, 0x90, 0x02,
+0x86, 0xE0, 0x20, 0xE1, 0x02, 0x80, 0x07, 0x90,
+0x02, 0x86, 0xE0, 0x30, 0xE3, 0x05, 0x75, 0x61,
+0x04, 0x80, 0x0E, 0x90, 0x88, 0xE6, 0xE0, 0x30,
+0xE0, 0x05, 0x75, 0x61, 0x20, 0x80, 0x02, 0x61,
+0xA4, 0x90, 0x01, 0xB9, 0x74, 0x08, 0xF0, 0x90,
+0x01, 0xB8, 0xE5, 0x61, 0xF0, 0x7F, 0x00, 0x22,
+0x75, 0x61, 0x14, 0x90, 0x88, 0x32, 0xE0, 0x44,
+0x10, 0xF0, 0x51, 0xF4, 0xF0, 0x7D, 0x01, 0x12,
+0x76, 0xF7, 0x90, 0x00, 0x06, 0xE0, 0x44, 0x40,
+0xF0, 0x90, 0x88, 0x41, 0xE0, 0x90, 0x00, 0x93,
+0xF0, 0x90, 0x88, 0x37, 0xE0, 0x60, 0x12, 0x90,
+0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74, 0x10,
+0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F, 0x74, 0x90,
+0xF0, 0x90, 0x93, 0x32, 0xE0, 0x30, 0xE0, 0x60,
+0x90, 0xFD, 0x09, 0xE4, 0xF0, 0x90, 0xFD, 0x08,
+0xF0, 0x90, 0x0E, 0x4B, 0xE0, 0x54, 0xFC, 0xF0,
+0xE4, 0x90, 0x95, 0x18, 0xF0, 0x90, 0x95, 0x18,
+0xE0, 0xFF, 0xC3, 0x94, 0x05, 0x50, 0x2D, 0x12,
+0xB7, 0x96, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x34, 0xE0,
+0xFD, 0xEF, 0x5D, 0x60, 0x0F, 0x90, 0x95, 0x18,
+0x71, 0x0B, 0x90, 0x95, 0x18, 0x71, 0x2B, 0x44,
+0x20, 0x12, 0xBF, 0xE1, 0x90, 0x95, 0x18, 0xE0,
+0x04, 0xF0, 0x80, 0xC9, 0x90, 0x00, 0x92, 0xE0,
+0x54, 0xFE, 0xF0, 0xE0, 0x44, 0x08, 0xF0, 0x90,
+0x00, 0x02, 0xE0, 0x54, 0xFD, 0xF0, 0x80, 0x07,
+0x90, 0x00, 0x92, 0xE0, 0x44, 0x01, 0xF0, 0x90,
+0x00, 0x08, 0xE0, 0x44, 0x10, 0xF0, 0x7F, 0x01,
+0x71, 0x4C, 0x90, 0x00, 0x90, 0xE0, 0x44, 0x01,
+0xF0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x14, 0x7E,
+0x00, 0x02, 0x7C, 0x6A, 0x90, 0x88, 0xA0, 0xE0,
+0xC4, 0x13, 0x13, 0x54, 0x01, 0xFF, 0x90, 0x88,
+0xE0, 0xE0, 0xFB, 0x90, 0x88, 0xDF, 0xE0, 0x90,
+0x92, 0x90, 0x22, 0xE0, 0xFF, 0x24, 0x40, 0xF5,
+0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90,
+0x01, 0xB0, 0xF0, 0x74, 0x45, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01,
+0xB1, 0xF0, 0x22, 0xE0, 0xFF, 0x24, 0x36, 0xF5,
+0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90,
+0x01, 0xB2, 0xF0, 0x74, 0x3B, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01,
+0xB3, 0xF0, 0xE0, 0x22, 0x90, 0x96, 0xF8, 0xEF,
+0x12, 0x9F, 0xB2, 0x90, 0x01, 0x09, 0xE0, 0x7F,
+0x00, 0x30, 0xE7, 0x02, 0x7F, 0x01, 0x90, 0x96,
+0xF8, 0xE0, 0x6F, 0x60, 0x36, 0xC3, 0x90, 0x96,
+0xFA, 0xE0, 0x94, 0x88, 0x90, 0x96, 0xF9, 0xE0,
+0x94, 0x13, 0x40, 0x08, 0x90, 0x01, 0xC0, 0xE0,
+0x44, 0x10, 0xF0, 0x22, 0x90, 0x96, 0xF9, 0x12,
+0xA7, 0xDC, 0x12, 0xBF, 0xE2, 0xD3, 0x90, 0x96,
+0xFA, 0xE0, 0x94, 0x32, 0x90, 0x96, 0xF9, 0xE0,
+0x94, 0x00, 0x40, 0xBF, 0x90, 0x01, 0xC6, 0xE0,
+0x30, 0xE0, 0xB8, 0x22, 0xF0, 0x7F, 0x0A, 0x7E,
+0x00, 0x02, 0x7C, 0x6A, 0x90, 0x01, 0xB8, 0xE4,
+0xF0, 0x7F, 0x01, 0x22, 0x90, 0x88, 0x31, 0xE0,
+0x30, 0xE0, 0x02, 0x31, 0x66, 0x22, 0x90, 0x01,
+0x9A, 0xE0, 0x54, 0xC0, 0x44, 0x0B, 0x71, 0x9C,
+0x90, 0x01, 0x98, 0xE0, 0x54, 0xC0, 0x7F, 0x00,
+0xB4, 0x40, 0x02, 0x7F, 0x01, 0x22, 0x12, 0x7B,
+0x1B, 0x90, 0x86, 0xB3, 0xEF, 0xF0, 0x11, 0x34,
+0x90, 0x01, 0x64, 0x74, 0x01, 0xF0, 0x90, 0x04,
+0x23, 0xE0, 0x44, 0x80, 0xF0, 0x02, 0x67, 0xD2,
+0x90, 0x01, 0xC4, 0x74, 0xE8, 0xF0, 0x74, 0xC3,
+0xA3, 0xF0, 0x7F, 0x90, 0x12, 0x7B, 0x41, 0xEF,
+0x20, 0xE0, 0xF7, 0x74, 0xE8, 0x04, 0x90, 0x01,
+0xC4, 0xF0, 0x74, 0xC3, 0xA3, 0xF0, 0x22, 0x75,
+0x39, 0x07, 0x43, 0x39, 0x10, 0x75, 0x3A, 0x01,
+0x43, 0x3A, 0x08, 0x75, 0x3B, 0x03, 0x75, 0x3C,
+0x62, 0x43, 0x3C, 0x80, 0x43, 0x3B, 0x04, 0x90,
+0x01, 0x38, 0xE5, 0x39, 0xF0, 0xA3, 0xE5, 0x3A,
+0xF0, 0xA3, 0xE5, 0x3B, 0xF0, 0xA3, 0xE5, 0x3C,
+0xF0, 0x22, 0xE4, 0x90, 0x97, 0x03, 0xF0, 0xA3,
+0xF0, 0x90, 0x02, 0x86, 0xE0, 0x20, 0xE1, 0x23,
+0xC3, 0x90, 0x97, 0x04, 0xE0, 0x94, 0xD0, 0x90,
+0x97, 0x03, 0xE0, 0x94, 0x07, 0x40, 0x0A, 0x90,
+0x01, 0xC1, 0xE0, 0x44, 0x04, 0xF0, 0x7F, 0x00,
+0x22, 0x90, 0x97, 0x03, 0x12, 0xA7, 0xDC, 0x71,
+0x9D, 0x80, 0xD6, 0x7F, 0x01, 0x22, 0x75, 0x29,
+0x12, 0xE4, 0xF5, 0x2A, 0x75, 0x2B, 0x87, 0x75,
+0x2C, 0x33, 0xF5, 0x31, 0xF5, 0x32, 0xF5, 0x33,
+0xF5, 0x34, 0x90, 0x01, 0x30, 0xE5, 0x29, 0xF0,
+0xA3, 0xE5, 0x2A, 0xF0, 0xA3, 0xE5, 0x2B, 0xF0,
+0xA3, 0xE5, 0x2C, 0xF0, 0x90, 0x01, 0x20, 0xE5,
+0x31, 0xF0, 0xA3, 0xE5, 0x32, 0xF0, 0xA3, 0xE5,
+0x33, 0xF0, 0xA3, 0xE5, 0x34, 0xF0, 0x22, 0xE4,
+0x90, 0x95, 0x15, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
+0x90, 0x95, 0x15, 0xE0, 0x64, 0x01, 0xF0, 0x90,
+0x93, 0x56, 0xE0, 0x70, 0x18, 0x90, 0x93, 0x53,
+0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E, 0x90,
+0x95, 0x15, 0xE0, 0x24, 0x9F, 0x90, 0x01, 0xC4,
+0xF0, 0x74, 0xC4, 0xA3, 0xF0, 0x12, 0x7C, 0x54,
+0xBF, 0x01, 0x03, 0x12, 0x54, 0x9F, 0x90, 0x88,
+0x36, 0xE0, 0x60, 0x0F, 0x90, 0x88, 0x39, 0xE0,
+0xFF, 0x90, 0x88, 0x38, 0xE0, 0x6F, 0x60, 0x03,
+0x12, 0xAE, 0x85, 0xC2, 0xAF, 0xD1, 0x7E, 0xBF,
+0x01, 0x02, 0x71, 0xAC, 0xD2, 0xAF, 0xB1, 0x00,
+0x12, 0x8F, 0xF6, 0x12, 0x83, 0x4D, 0x80, 0xA8,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x93, 0x53, 0xE0, 0x60, 0x24, 0x7F, 0x54, 0x7E,
+0x09, 0x12, 0x70, 0x70, 0xB1, 0xAC, 0x12, 0x04,
+0xB8, 0xEF, 0x44, 0xFE, 0xFF, 0xEE, 0x44, 0x03,
+0xFE, 0xED, 0x44, 0x04, 0xFD, 0xEC, 0xB1, 0xAC,
+0xB1, 0xB6, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x70,
+0xAD, 0x90, 0x93, 0x4E, 0xE0, 0x70, 0x29, 0x90,
+0x07, 0xCC, 0xE0, 0x30, 0xE0, 0x22, 0xE4, 0xF0,
+0x90, 0x95, 0x1C, 0x74, 0x22, 0xF0, 0x90, 0x95,
+0x3E, 0x74, 0x01, 0xF0, 0x90, 0x95, 0x1E, 0x74,
+0x03, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x1C,
+0x12, 0x8A, 0x4D, 0x7F, 0x04, 0x12, 0x04, 0x7E,
+0x90, 0x93, 0x56, 0xE0, 0xFF, 0x70, 0x0A, 0x90,
+0x93, 0x53, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x60,
+0x15, 0x90, 0x00, 0x1F, 0xE0, 0x54, 0xF0, 0xF0,
+0x90, 0x01, 0xC5, 0x74, 0xEA, 0xF0, 0xA3, 0x74,
+0xEF, 0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0xEF, 0x60,
+0x06, 0x90, 0x01, 0xC4, 0x74, 0x07, 0xF0, 0x90,
+0x93, 0x53, 0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4,
+0x74, 0x01, 0xF0, 0x90, 0x93, 0x54, 0xE0, 0x60,
+0x06, 0x90, 0x01, 0xC4, 0x74, 0x02, 0xF0, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x95, 0x18, 0x12,
+0x04, 0x31, 0x90, 0x95, 0x18, 0x22, 0x12, 0x04,
+0xB8, 0x90, 0x92, 0x18, 0x02, 0x04, 0x31, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD1, 0x69,
+0x90, 0x96, 0xEA, 0x12, 0x04, 0x31, 0x90, 0x96,
+0xEA, 0xB1, 0xB6, 0xB1, 0xF6, 0x90, 0x01, 0x01,
+0xE0, 0x44, 0x02, 0xF0, 0x90, 0x01, 0x00, 0x74,
+0xFF, 0xF0, 0x90, 0x06, 0xB7, 0x74, 0x09, 0xF0,
+0x90, 0x06, 0xB4, 0x74, 0x86, 0xF0, 0x12, 0xAF,
+0xCA, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7F, 0x30,
+0x7E, 0x08, 0x02, 0x70, 0xAD, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0xD1, 0x69, 0x90, 0x96,
+0xEE, 0x12, 0x04, 0x31, 0x90, 0x96, 0xEE, 0xB1,
+0xB6, 0xB1, 0xF6, 0x90, 0x8A, 0xFD, 0x12, 0x8E,
+0xAD, 0x90, 0x06, 0xB7, 0x74, 0x11, 0xF0, 0x7F,
+0x03, 0x7E, 0x00, 0x12, 0x7C, 0x6A, 0x90, 0x06,
+0xB4, 0xE0, 0x54, 0x0F, 0x70, 0xF1, 0x90, 0x07,
+0xD5, 0xE0, 0x44, 0x80, 0xF0, 0x7F, 0x0A, 0x80,
+0x09, 0x90, 0x06, 0x62, 0xE0, 0x30, 0xE0, 0x09,
+0x7F, 0x01, 0x7E, 0x00, 0x12, 0x7C, 0x6A, 0x80,
+0xF0, 0xD1, 0x76, 0x90, 0x01, 0x00, 0x74, 0x3F,
+0xF0, 0xA3, 0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x05,
+0x53, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x07, 0xD5,
+0xE0, 0x54, 0x7F, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70, 0x70,
+0xED, 0x44, 0x80, 0xFD, 0xEC, 0x22, 0x90, 0x00,
+0x02, 0xE0, 0x54, 0xFE, 0xF0, 0x22, 0x7D, 0x02,
+0x90, 0x01, 0xC4, 0x74, 0x7E, 0xF0, 0x74, 0xC6,
+0xA3, 0xF0, 0x90, 0x93, 0x4A, 0xE0, 0xFF, 0xED,
+0xC3, 0x9F, 0x50, 0x18, 0xED, 0x25, 0xE0, 0x24,
+0x81, 0xF8, 0xE6, 0x30, 0xE4, 0x0B, 0x90, 0x01,
+0xB8, 0x74, 0x08, 0xF0, 0xA3, 0xF0, 0x7F, 0x00,
+0x22, 0x0D, 0x80, 0xDE, 0x74, 0x7E, 0x04, 0x90,
+0x01, 0xC4, 0xF0, 0x74, 0xC6, 0xA3, 0xF0, 0x7F,
+0x01, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x96, 0x98, 0xEE, 0xF0, 0xA3, 0xEF,
+0xF0, 0x12, 0x70, 0x70, 0x90, 0x96, 0xA2, 0x12,
+0x04, 0x31, 0x90, 0x96, 0x9A, 0x12, 0x04, 0xB8,
+0x12, 0x03, 0xCD, 0x90, 0x96, 0xA2, 0x12, 0x86,
+0x61, 0x12, 0x86, 0x47, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x96, 0x9A, 0x12,
+0x04, 0xB8, 0x90, 0x96, 0x9E, 0x12, 0x86, 0x61,
+0x12, 0x86, 0x47, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
+0x01, 0xD0, 0x00, 0x12, 0x86, 0x54, 0x90, 0x96,
+0xA6, 0x12, 0x04, 0x31, 0x90, 0x96, 0xA6, 0xB1,
+0xB6, 0x90, 0x96, 0x98, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x12, 0x70, 0xAD, 0xD0, 0xD0, 0x92, 0xAF,
 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x88, 0x33, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
-0x28, 0x90, 0x96, 0x33, 0x74, 0x1E, 0xF0, 0x90,
-0x96, 0x55, 0x74, 0x01, 0xF0, 0x90, 0x96, 0x35,
-0xEF, 0xF0, 0x7B, 0x01, 0x7A, 0x96, 0x79, 0x33,
-0x12, 0xA4, 0x3F, 0x12, 0x04, 0x7E, 0x90, 0x8A,
-0xE5, 0x12, 0x8B, 0x46, 0x7F, 0x04, 0x12, 0x04,
-0x7E, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93,
-0x0E, 0xE0, 0xFD, 0x7C, 0x00, 0xA3, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x12, 0x02, 0x92, 0xED, 0x4C,
-0x70, 0x05, 0x90, 0x93, 0x1B, 0x80, 0x2A, 0xED,
-0x64, 0x01, 0x4C, 0x70, 0x05, 0x90, 0x93, 0x1C,
-0x80, 0x1F, 0xED, 0x64, 0x02, 0x4C, 0x70, 0x05,
-0x90, 0x93, 0x1D, 0x80, 0x14, 0xED, 0x64, 0x03,
-0x4C, 0x70, 0x05, 0x90, 0x93, 0x1E, 0x80, 0x09,
-0xED, 0x64, 0x04, 0x4C, 0x70, 0x0D, 0x90, 0x93,
-0x1F, 0xE0, 0xFF, 0x51, 0xD5, 0x90, 0x93, 0x0F,
-0x12, 0x9F, 0xEF, 0x22, 0x7D, 0x02, 0x7F, 0x02,
-0x02, 0x7C, 0x74, 0x90, 0x88, 0x36, 0xE0, 0x60,
-0x03, 0x12, 0xA7, 0xBC, 0x22, 0x90, 0x04, 0x24,
-0xEF, 0xF0, 0x90, 0x04, 0x57, 0xF0, 0x22, 0x90,
-0x88, 0x39, 0xE0, 0x64, 0x02, 0x60, 0x03, 0x12,
-0xAD, 0xA7, 0x22, 0x54, 0xFB, 0xF0, 0x90, 0x88,
-0x3A, 0xE0, 0x54, 0xFD, 0xF0, 0x54, 0x07, 0x22,
-0x90, 0x8A, 0x75, 0x12, 0x88, 0xCD, 0x90, 0x8A,
-0xE5, 0x12, 0x8B, 0x46, 0x7F, 0x02, 0x02, 0x04,
-0x7E, 0x90, 0x93, 0x03, 0xE0, 0x30, 0xE0, 0x0B,
-0x90, 0x8A, 0xE5, 0x12, 0x8B, 0x46, 0x7F, 0x20,
-0x12, 0x04, 0x7E, 0x22, 0x90, 0x88, 0x36, 0xE0,
-0x64, 0x01, 0x70, 0x2D, 0x12, 0xA7, 0xE8, 0x60,
-0x15, 0x90, 0x8A, 0xB9, 0x12, 0x8B, 0x46, 0xE4,
-0xFD, 0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x90, 0x8B,
-0x01, 0x31, 0xF4, 0x02, 0x04, 0x7A, 0x90, 0x88,
-0x39, 0xE0, 0x70, 0x0D, 0x90, 0x8A, 0xB9, 0x12,
-0x8B, 0x46, 0x7D, 0x01, 0x7F, 0x04, 0x12, 0x04,
-0x7E, 0x22, 0x90, 0x01, 0xCF, 0xE0, 0x90, 0x95,
-0xC3, 0xF0, 0xE0, 0xFF, 0x30, 0xE0, 0x07, 0x90,
-0x01, 0xCF, 0xE0, 0x54, 0xFE, 0xF0, 0xEF, 0x30,
-0xE5, 0x23, 0x90, 0x01, 0xCF, 0xE0, 0x54, 0xDF,
-0xF0, 0x90, 0x01, 0x34, 0x74, 0x20, 0xF0, 0xE4,
-0xF5, 0xA8, 0xF5, 0xE8, 0x12, 0x76, 0x6D, 0x90,
-0x00, 0x03, 0xE0, 0x54, 0xFB, 0xFD, 0x7F, 0x03,
-0x12, 0x7B, 0x2E, 0x80, 0xFE, 0x22, 0xC0, 0xE0,
-0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0,
-0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0,
-0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x8E,
-0xF0, 0x74, 0xBB, 0xA3, 0xF0, 0x12, 0x75, 0x50,
-0xE5, 0x3D, 0x30, 0xE0, 0x02, 0xB1, 0xD5, 0xE5,
-0x3D, 0x30, 0xE1, 0x02, 0xD1, 0x3E, 0xE5, 0x3D,
-0x30, 0xE2, 0x03, 0x12, 0xA6, 0xD4, 0xE5, 0x3D,
-0x30, 0xE4, 0x02, 0x91, 0x64, 0xE5, 0x3E, 0x30,
-0xE0, 0x03, 0x12, 0xA9, 0x1D, 0xE5, 0x3E, 0x30,
-0xE3, 0x02, 0x91, 0x44, 0xE5, 0x3F, 0x30, 0xE2,
-0x09, 0xD1, 0x65, 0x90, 0x07, 0x8F, 0xE0, 0x44,
-0x10, 0xF0, 0xE5, 0x40, 0x30, 0xE1, 0x0B, 0x90,
-0x8A, 0xE5, 0x12, 0x8B, 0x46, 0x7F, 0x04, 0x12,
-0x04, 0x7E, 0xE5, 0x40, 0x30, 0xE4, 0x02, 0x31,
-0xFC, 0xE5, 0x40, 0x30, 0xE5, 0x02, 0xB1, 0x57,
-0xE5, 0x40, 0x30, 0xE6, 0x02, 0xB1, 0x06, 0xE5,
-0x40, 0x30, 0xE7, 0x02, 0x91, 0xB5, 0x74, 0x8E,
-0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xBB, 0xA3,
-0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0,
-0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
-0xF0, 0xD0, 0xE0, 0x32, 0x90, 0x01, 0x8C, 0xE4,
-0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x71, 0xF0, 0xA3,
-0x74, 0x02, 0xF0, 0x90, 0x01, 0x95, 0xE0, 0x54,
-0xF0, 0x44, 0x07, 0xF0, 0x90, 0x01, 0x01, 0xE0,
-0x44, 0x04, 0xF0, 0x22, 0x90, 0x88, 0x9D, 0xE0,
-0x30, 0xE0, 0x0D, 0xB1, 0xDF, 0x30, 0xE0, 0x08,
-0x90, 0x8A, 0xBB, 0x12, 0x8B, 0x46, 0x91, 0xF9,
-0xB1, 0xD6, 0x90, 0x96, 0xCE, 0xEF, 0xF0, 0x90,
-0x86, 0xB3, 0xE0, 0xB4, 0x02, 0x12, 0x90, 0x96,
-0xCE, 0xE0, 0xFF, 0x64, 0x01, 0x60, 0x25, 0x90,
-0x01, 0x4D, 0xE0, 0x64, 0x80, 0xF0, 0x80, 0x19,
-0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x7F, 0x64,
-0x7E, 0x00, 0x12, 0x7C, 0x6A, 0x90, 0x06, 0x90,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x96, 0xCE, 0xE0,
-0xFF, 0x12, 0x93, 0xFC, 0x22, 0x90, 0x88, 0xB8,
-0xE0, 0x30, 0xE0, 0x05, 0x90, 0x8A, 0xEB, 0x80,
-0x27, 0x90, 0x94, 0xAE, 0x12, 0xAD, 0x26, 0x30,
-0xE0, 0x1B, 0x90, 0x88, 0xC2, 0xE0, 0xC4, 0x54,
-0x0F, 0x20, 0xE0, 0x08, 0x90, 0x8A, 0xBB, 0x12,
-0x8B, 0x46, 0x91, 0xF9, 0x90, 0x94, 0xAE, 0xE0,
-0x54, 0xF7, 0xF0, 0x80, 0x06, 0x90, 0x8A, 0x99,
-0x12, 0x88, 0xCD, 0x90, 0x88, 0xF0, 0xE0, 0x30,
-0xE0, 0x06, 0x90, 0x8A, 0xE7, 0x12, 0x88, 0xCD,
-0x22, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88,
-0xC2, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0x90, 0x88,
-0x31, 0xE0, 0xFF, 0x12, 0x8F, 0xF1, 0x30, 0xE0,
-0x1E, 0xEF, 0x54, 0x7F, 0xB1, 0xB2, 0x30, 0xE1,
-0x06, 0xE0, 0x44, 0x02, 0xF0, 0x80, 0x07, 0xE0,
-0x54, 0xFD, 0xB1, 0xBB, 0x04, 0xF0, 0x90, 0x88,
-0x36, 0xE0, 0x60, 0x03, 0x12, 0xA6, 0xF0, 0x12,
-0x9D, 0xBD, 0x30, 0xE0, 0x21, 0x90, 0x88, 0xA4,
+0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x10, 0x90,
+0x88, 0xA3, 0xE0, 0xC4, 0x13, 0x54, 0x07, 0x30,
+0xE0, 0x20, 0x75, 0x10, 0x10, 0x80, 0x3F, 0x12,
+0x7A, 0x65, 0xEF, 0x64, 0x01, 0x60, 0x05, 0x75,
+0x10, 0x01, 0x80, 0x32, 0x90, 0x88, 0x31, 0x12,
+0xAE, 0x23, 0x30, 0xE0, 0x05, 0x75, 0x10, 0x02,
+0x80, 0x24, 0x90, 0x88, 0x38, 0xE0, 0xD3, 0x94,
+0x04, 0x40, 0x05, 0x75, 0x10, 0x08, 0x80, 0x16,
+0x90, 0x93, 0x2A, 0xE0, 0x30, 0xE0, 0x0B, 0xC4,
+0x54, 0x0F, 0x30, 0xE0, 0x05, 0x75, 0x10, 0x11,
+0x80, 0x04, 0x71, 0xA4, 0x80, 0x0E, 0x90, 0x01,
+0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8, 0xE5,
+0x10, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x01, 0xE4, 0x74, 0x2F, 0xF0, 0xA3,
+0xE4, 0xF0, 0x22, 0x90, 0x8A, 0x79, 0x74, 0x86,
+0xF0, 0xA3, 0x74, 0xC6, 0xF0, 0x90, 0x8A, 0xE5,
+0x74, 0xC8, 0xF0, 0xA3, 0x74, 0xD2, 0xF0, 0x90,
+0x8B, 0x03, 0x74, 0xB0, 0xF0, 0xA3, 0x74, 0x03,
+0xF0, 0x90, 0x8A, 0xB9, 0x74, 0xDE, 0xF0, 0xA3,
+0x74, 0x0B, 0xF0, 0x90, 0x8A, 0xD5, 0x74, 0x94,
+0xF0, 0xA3, 0x74, 0xEA, 0xF0, 0x90, 0x8A, 0xFB,
+0x74, 0x94, 0xF0, 0xA3, 0x74, 0x01, 0xF0, 0x90,
+0x8A, 0xA5, 0x74, 0xB5, 0xF0, 0xA3, 0x74, 0x2C,
+0xF0, 0x90, 0x8A, 0xB5, 0x74, 0x87, 0xF0, 0xA3,
+0x74, 0x2C, 0xF0, 0x90, 0x8A, 0x75, 0x74, 0xB6,
+0xF0, 0xA3, 0x74, 0x9B, 0xF0, 0x90, 0x8A, 0xC1,
+0x74, 0x89, 0xF0, 0xA3, 0x74, 0x08, 0xF0, 0x90,
+0x8A, 0xC3, 0x74, 0xD7, 0xF0, 0xA3, 0x74, 0xA2,
+0xF0, 0x90, 0x8A, 0xF3, 0x74, 0xD8, 0xF0, 0xA3,
+0x74, 0x33, 0xF0, 0x90, 0x8A, 0x85, 0x74, 0xDB,
+0xF0, 0xA3, 0x74, 0x1F, 0xF0, 0x90, 0x8A, 0x99,
+0x74, 0xDB, 0xF0, 0xA3, 0x74, 0xE6, 0xF0, 0x90,
+0x86, 0x04, 0x74, 0xDB, 0xF0, 0xA3, 0x74, 0x79,
+0xF0, 0x90, 0x8A, 0xA9, 0x74, 0xD8, 0xF0, 0xA3,
+0x74, 0x3F, 0xF0, 0x90, 0x8B, 0x07, 0x74, 0xD8,
+0xF0, 0xA3, 0x74, 0x64, 0xF0, 0x90, 0x8A, 0xAD,
+0x74, 0xD9, 0xF0, 0xA3, 0x74, 0x0E, 0xF0, 0x90,
+0x8A, 0xBB, 0x74, 0x8A, 0xF0, 0xA3, 0x74, 0x68,
+0xF0, 0x90, 0x86, 0x0C, 0x74, 0xC5, 0xF0, 0xA3,
+0x74, 0xBF, 0xF0, 0x90, 0x8A, 0xEF, 0x74, 0xC5,
+0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0x90, 0x86, 0x00,
+0x74, 0xC7, 0xF0, 0xA3, 0x74, 0x21, 0xF0, 0x90,
+0x86, 0x02, 0x74, 0xDD, 0xF0, 0xA3, 0x74, 0x4E,
+0xF0, 0x90, 0x8A, 0xFD, 0x74, 0xA4, 0xF0, 0xA3,
+0x74, 0xB5, 0xF0, 0x90, 0x8A, 0xF9, 0x74, 0xCB,
+0xF0, 0xA3, 0x74, 0x77, 0xF0, 0x90, 0x8A, 0xDB,
+0x74, 0xCE, 0xF0, 0xA3, 0x74, 0xB2, 0xF0, 0x90,
+0x8A, 0xAF, 0x74, 0xA5, 0xF0, 0xA3, 0x74, 0x42,
+0xF0, 0x90, 0x8A, 0xD3, 0x74, 0xD6, 0xF0, 0xA3,
+0x74, 0x2A, 0xF0, 0x90, 0x8A, 0xF5, 0x74, 0xDF,
+0xF0, 0xA3, 0x74, 0x8A, 0xF0, 0x90, 0x8A, 0xA3,
+0x74, 0xDF, 0xF0, 0xA3, 0x74, 0xDE, 0xF0, 0x90,
+0x86, 0x06, 0x74, 0xA6, 0xF0, 0xA3, 0x74, 0x5C,
+0xF0, 0x22, 0x8F, 0x0D, 0x7F, 0x02, 0x12, 0x85,
+0x27, 0x90, 0x86, 0xAF, 0xE0, 0x45, 0x0D, 0xF0,
+0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0,
+0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00,
+0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04,
+0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01,
+0xC4, 0x74, 0xE1, 0xF0, 0x74, 0xC8, 0xA3, 0xF0,
+0x12, 0x6C, 0xD6, 0xE5, 0x25, 0x30, 0xE7, 0x03,
+0x12, 0xBE, 0x9D, 0x74, 0xE1, 0x04, 0x90, 0x01,
+0xC4, 0xF0, 0x74, 0xC8, 0xA3, 0xF0, 0xD0, 0x07,
+0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03,
+0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0,
+0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0,
+0x32, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0,
+0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00,
+0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04,
+0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01,
+0xC4, 0x74, 0x39, 0xF0, 0x74, 0xC9, 0xA3, 0xF0,
+0x90, 0x8A, 0x9D, 0x12, 0x8E, 0xAD, 0x53, 0x91,
+0xBF, 0x74, 0x39, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xC9, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
+0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
+0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0xC0,
+0xE0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
+0xD0, 0x00, 0xC0, 0x05, 0xC0, 0x07, 0x7D, 0x8F,
+0x90, 0x01, 0xC4, 0xED, 0xF0, 0x74, 0xC9, 0xFF,
+0xA3, 0xF0, 0xED, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0xA3, 0xEF, 0xF0, 0xD0, 0x07, 0xD0, 0x05, 0xD0,
+0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xE0, 0x32,
+0x90, 0x88, 0x36, 0xE0, 0x60, 0x15, 0x90, 0x88,
+0x9D, 0xE0, 0x30, 0xE0, 0x0B, 0x90, 0x94, 0xAF,
+0xE0, 0xFF, 0x12, 0x8D, 0x35, 0x20, 0xE0, 0x03,
+0x12, 0xAD, 0x40, 0x02, 0x8E, 0xB7, 0x51, 0x35,
+0x90, 0x95, 0xF0, 0xEF, 0xF0, 0x20, 0xE0, 0x06,
+0x90, 0x01, 0x3D, 0x74, 0x01, 0xF0, 0x90, 0x95,
+0xF0, 0xE0, 0x90, 0x8A, 0x89, 0x30, 0xE0, 0x13,
+0x12, 0x8A, 0x5F, 0x7D, 0x01, 0xE4, 0xFF, 0x12,
+0x04, 0x7E, 0x90, 0x88, 0x33, 0xE0, 0x44, 0x04,
+0xF0, 0x80, 0x06, 0x12, 0x8A, 0x5F, 0x12, 0x97,
+0xF1, 0x90, 0x95, 0xF0, 0xE0, 0x30, 0xE6, 0x11,
+0x90, 0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x04, 0xE4,
+0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F, 0x74, 0x80,
+0xF0, 0x12, 0xAF, 0xA9, 0x90, 0x92, 0x98, 0x74,
+0x02, 0xF0, 0x02, 0x6E, 0x2F, 0xE4, 0x90, 0x95,
+0xF2, 0xF0, 0xA3, 0xF0, 0x7F, 0x83, 0x12, 0x7B,
+0x41, 0x90, 0x95, 0xF1, 0xEF, 0xF0, 0x7F, 0x83,
+0x12, 0x7B, 0x41, 0xAE, 0x07, 0x90, 0x95, 0xF1,
+0xE0, 0xFF, 0xB5, 0x06, 0x01, 0x22, 0xC3, 0x90,
+0x95, 0xF3, 0xE0, 0x94, 0x64, 0x90, 0x95, 0xF2,
+0xE0, 0x94, 0x00, 0x40, 0x0D, 0x90, 0x01, 0xC0,
+0xE0, 0x44, 0x40, 0xF0, 0x90, 0x95, 0xF1, 0xE0,
+0xFF, 0x22, 0x90, 0x95, 0xF2, 0x12, 0xA7, 0xDC,
+0x80, 0xC2, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x88, 0xF0, 0xE0, 0x30, 0xE0, 0x32,
+0x90, 0x88, 0xF7, 0xE0, 0xB4, 0x01, 0x1B, 0xA3,
+0xE0, 0xB4, 0x01, 0x26, 0x74, 0x02, 0xF0, 0x90,
+0x88, 0xFE, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90,
+0x8A, 0x7F, 0x12, 0xA5, 0xDE, 0x12, 0x04, 0x7E,
+0x80, 0x10, 0x90, 0x88, 0xF7, 0xE0, 0xB4, 0x02,
+0x09, 0x74, 0x03, 0xF0, 0x90, 0x8A, 0xE7, 0x12,
+0x8E, 0xAD, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
+0x94, 0xA2, 0xE0, 0xB4, 0x01, 0x15, 0xE4, 0xF0,
+0x90, 0x01, 0x5B, 0xF0, 0x90, 0x92, 0x20, 0xF0,
+0x90, 0x88, 0x95, 0xE0, 0xC3, 0x13, 0x54, 0x7F,
+0x12, 0x97, 0xE3, 0x90, 0x88, 0x31, 0xE0, 0xFF,
+0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x33,
+0xEF, 0x54, 0xBF, 0x71, 0x1C, 0x30, 0xE0, 0x06,
+0xE0, 0x44, 0x01, 0xF0, 0x80, 0x09, 0xE0, 0x54,
+0xFE, 0x12, 0xB7, 0xD5, 0x74, 0x04, 0xF0, 0x90,
+0x88, 0xA3, 0xE0, 0xFF, 0xC4, 0x13, 0x54, 0x07,
+0x30, 0xE0, 0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x8A,
+0x5F, 0x7D, 0x01, 0x7F, 0x0C, 0x02, 0x04, 0x7E,
+0x12, 0xAE, 0x85, 0x22, 0xF0, 0x90, 0x04, 0xE0,
+0xE0, 0x90, 0x88, 0x32, 0x22, 0x90, 0x88, 0x31,
+0xE0, 0xFF, 0x12, 0x8D, 0x35, 0x30, 0xE0, 0x1F,
+0xEF, 0x54, 0x7F, 0x71, 0x1C, 0x30, 0xE1, 0x06,
+0xE0, 0x44, 0x02, 0xF0, 0x80, 0x08, 0xE0, 0x54,
+0xFD, 0x12, 0xB7, 0xD5, 0x04, 0xF0, 0x90, 0x88,
+0x36, 0xE0, 0x60, 0x03, 0x12, 0xAE, 0x85, 0x12,
+0x8F, 0xEC, 0x30, 0xE0, 0x21, 0x90, 0x88, 0xA4,
 0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x17, 0xEF,
 0x54, 0xFD, 0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x90,
 0x88, 0xA4, 0x30, 0xE1, 0x05, 0xE0, 0x44, 0x04,
 0xF0, 0x22, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0x90,
-0x94, 0xA1, 0xE0, 0xB4, 0x01, 0x14, 0xE4, 0xF0,
-0x90, 0x01, 0x5B, 0xF0, 0x90, 0x92, 0x20, 0xF0,
-0x90, 0x88, 0x95, 0xE0, 0xC3, 0x13, 0x54, 0x7F,
-0xB1, 0xC7, 0x90, 0x88, 0x31, 0xE0, 0xFF, 0xC4,
-0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x32, 0xEF,
-0x54, 0xBF, 0xB1, 0xB2, 0x30, 0xE0, 0x06, 0xE0,
-0x44, 0x01, 0xF0, 0x80, 0x08, 0xE0, 0x54, 0xFE,
-0xB1, 0xBB, 0x74, 0x04, 0xF0, 0x90, 0x88, 0xA3,
-0xE0, 0xFF, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0,
-0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x8B, 0x46, 0x7D,
-0x01, 0x7F, 0x0C, 0x02, 0x04, 0x7E, 0x12, 0xA6,
-0xF0, 0x22, 0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x90,
-0x88, 0x32, 0x22, 0xF0, 0x90, 0x01, 0xB9, 0x74,
-0x01, 0xF0, 0x90, 0x01, 0xB8, 0x22, 0xE0, 0x90,
-0x92, 0x21, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x58,
-0x7E, 0x01, 0x02, 0x66, 0x33, 0x22, 0x90, 0x01,
-0xC7, 0x74, 0x66, 0xF0, 0xE4, 0xFF, 0x22, 0x90,
-0x88, 0xA1, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x22,
-0xEF, 0x64, 0x39, 0x70, 0x46, 0x90, 0x88, 0x9D,
-0xE0, 0x30, 0xE0, 0x3F, 0xB1, 0xDF, 0x30, 0xE0,
-0x3A, 0x90, 0x88, 0xC2, 0xE0, 0xFF, 0xC4, 0x54,
-0x0F, 0x30, 0xE0, 0x2F, 0x90, 0x94, 0xB4, 0xE0,
-0x04, 0xF0, 0xD1, 0x34, 0x30, 0xE0, 0x1C, 0xEE,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x13,
-0x90, 0x01, 0x63, 0xE4, 0xF0, 0x90, 0x01, 0x3C,
-0x74, 0x10, 0xF0, 0xEF, 0x54, 0xEF, 0x90, 0x88,
-0xC2, 0xF0, 0x22, 0x90, 0x88, 0xB0, 0xE0, 0x70,
-0x02, 0x91, 0xFE, 0x22, 0x90, 0x94, 0xAE, 0xE0,
-0xFE, 0x13, 0x13, 0x54, 0x3F, 0x22, 0x90, 0x88,
-0x36, 0xE0, 0x60, 0x03, 0x12, 0xAF, 0x16, 0x02,
-0x8A, 0xCF, 0x90, 0x00, 0xAB, 0xE0, 0xFE, 0x90,
-0x00, 0xAA, 0x12, 0x9B, 0x42, 0x54, 0x7F, 0x90,
-0x95, 0xC1, 0xF0, 0xA3, 0xEF, 0xF0, 0xE0, 0x30,
-0xE1, 0x02, 0x91, 0x44, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88, 0xF0, 0xE0,
-0x30, 0xE0, 0x32, 0x90, 0x88, 0xF7, 0xE0, 0xB4,
-0x01, 0x1B, 0xA3, 0xE0, 0xB4, 0x01, 0x26, 0x74,
-0x02, 0xF0, 0x90, 0x88, 0xFE, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0x90, 0x8A, 0x7F, 0x12, 0x9E, 0x75,
-0x12, 0x04, 0x7E, 0x80, 0x10, 0x90, 0x88, 0xF7,
-0xE0, 0xB4, 0x02, 0x09, 0x74, 0x03, 0xF0, 0x90,
-0x8A, 0xE7, 0x12, 0x88, 0xCD, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83,
-0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0,
-0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0,
-0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90,
-0x01, 0xC4, 0x74, 0xAA, 0xF0, 0x74, 0xBE, 0xA3,
-0xF0, 0x12, 0x6C, 0xD6, 0xE5, 0x25, 0x30, 0xE7,
-0x02, 0xD1, 0x4A, 0x74, 0xAA, 0x04, 0x90, 0x01,
-0xC4, 0xF0, 0x74, 0xBE, 0xA3, 0xF0, 0xD0, 0x07,
-0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0,
-0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0,
-0x32, 0x90, 0x00, 0x80, 0xE0, 0x44, 0x80, 0xF0,
-0x12, 0xC3, 0xD1, 0xF1, 0x85, 0x12, 0x7B, 0x79,
-0x91, 0x44, 0xF1, 0x92, 0x7F, 0x01, 0x12, 0x84,
-0x15, 0x90, 0x93, 0x49, 0x74, 0x02, 0xF0, 0xFF,
-0x12, 0x84, 0x15, 0x90, 0x93, 0x49, 0xE0, 0x04,
-0xF0, 0xF1, 0xA4, 0x12, 0xA4, 0xC6, 0x90, 0x00,
-0x80, 0xE0, 0x44, 0x40, 0xF0, 0x75, 0x20, 0xFF,
-0x12, 0x7C, 0x97, 0x90, 0x01, 0xA0, 0xE0, 0xB4,
-0xFD, 0x05, 0xE4, 0xFF, 0x12, 0x8C, 0x78, 0x12,
-0xB4, 0x79, 0x90, 0x00, 0x81, 0xE0, 0x44, 0x04,
-0xF0, 0xF1, 0x7B, 0x12, 0x9C, 0xB2, 0x90, 0x00,
-0xAA, 0xE0, 0x44, 0x02, 0xF0, 0xA3, 0xE0, 0x44,
-0x80, 0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x44, 0x10,
-0xF0, 0x90, 0x07, 0xDB, 0xE0, 0x44, 0x80, 0xF0,
-0x90, 0x06, 0x0D, 0x74, 0xFF, 0xF0, 0xE4, 0xFF,
-0x02, 0x84, 0x9E, 0x90, 0x01, 0xE4, 0x74, 0x27,
-0xF0, 0xA3, 0xE4, 0xF0, 0x22, 0x90, 0x01, 0x94,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x01, 0xC7, 0xE4,
-0xF0, 0x22, 0xE4, 0x90, 0x86, 0xAF, 0x12, 0xA4,
-0x93, 0x90, 0x93, 0x01, 0xF0, 0x90, 0x93, 0x5D,
-0xF0, 0xA3, 0xF0, 0x22, 0x12, 0x7B, 0x1B, 0x90,
-0x86, 0xB3, 0xEF, 0xF0, 0x12, 0xB7, 0xBD, 0x90,
-0x01, 0x64, 0x74, 0x01, 0xF0, 0x90, 0x04, 0x23,
-0xE0, 0x44, 0x80, 0xF0, 0x02, 0x67, 0xD2, 0x12,
-0x9F, 0xE9, 0x12, 0x02, 0x06, 0x64, 0x01, 0x60,
-0x03, 0x02, 0xC0, 0x56, 0xEF, 0x24, 0x39, 0x60,
-0x12, 0x14, 0x60, 0x19, 0x24, 0x02, 0x70, 0x1F,
-0xE4, 0x90, 0x94, 0xBC, 0xF0, 0xA3, 0x74, 0x06,
-0xF0, 0x80, 0x14, 0x90, 0x94, 0xBC, 0x74, 0x06,
-0xF0, 0xA3, 0xF0, 0x80, 0x0A, 0x90, 0x94, 0xBC,
-0x74, 0x0C, 0xF0, 0xA3, 0x74, 0x04, 0xF0, 0x12,
-0xC0, 0x6A, 0x12, 0xC0, 0x57, 0x40, 0x1B, 0x90,
-0x94, 0xBA, 0xE0, 0x11, 0xD5, 0x7A, 0x94, 0x79,
-0xB9, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x07, 0x90,
-0x94, 0xB9, 0xE0, 0xF4, 0x70, 0x40, 0x11, 0x5F,
-0x80, 0xE0, 0x11, 0x6A, 0x11, 0x57, 0x40, 0x36,
-0x90, 0x94, 0xBA, 0xE0, 0xFD, 0x7C, 0x00, 0x24,
-0xA8, 0xFF, 0xEC, 0x34, 0x01, 0xFE, 0xED, 0x24,
-0x01, 0xFD, 0xEC, 0x33, 0xFC, 0x90, 0x94, 0xBC,
-0xE0, 0xFB, 0xC3, 0xED, 0x9B, 0xFD, 0xEC, 0x94,
-0x00, 0xFC, 0x90, 0x94, 0xB6, 0x12, 0x86, 0x6D,
-0x8D, 0x82, 0x8C, 0x83, 0x12, 0x02, 0x1F, 0xFD,
-0x11, 0x7B, 0x11, 0x5F, 0x80, 0xC6, 0x22, 0x90,
-0x94, 0xBB, 0xE0, 0xD3, 0x94, 0x00, 0x22, 0x90,
-0x94, 0xBA, 0xE0, 0x04, 0xF0, 0xA3, 0xE0, 0x14,
-0xF0, 0x22, 0x90, 0x94, 0xBC, 0xE0, 0x90, 0x94,
-0xBA, 0xF0, 0x90, 0x94, 0xBD, 0xE0, 0x90, 0x94,
-0xBB, 0xF0, 0x22, 0xE4, 0x90, 0x94, 0xBE, 0xF0,
-0x90, 0x00, 0x37, 0xE0, 0x44, 0x80, 0xF0, 0x90,
-0x00, 0xCF, 0x74, 0x69, 0xF0, 0xEF, 0x90, 0x00,
-0x31, 0xF0, 0xEE, 0x54, 0x03, 0xFF, 0xA3, 0xE0,
-0x54, 0xFC, 0x4F, 0xF0, 0x90, 0x00, 0x30, 0xED,
-0xF0, 0x90, 0x00, 0x33, 0xE0, 0x44, 0x80, 0xF0,
-0x90, 0x00, 0x33, 0xE0, 0x30, 0xE7, 0x09, 0x11,
-0xCD, 0x50, 0x05, 0xE0, 0x04, 0xF0, 0x80, 0xF0,
-0x90, 0x00, 0xCF, 0xE4, 0xF0, 0x90, 0x00, 0x37,
-0xE0, 0x54, 0x7F, 0xF0, 0x11, 0xCD, 0x7F, 0x00,
-0x50, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x94, 0xBE,
-0xE0, 0xC3, 0x94, 0x64, 0x22, 0x24, 0xA8, 0xFF,
-0xE4, 0x34, 0x01, 0xFE, 0x7B, 0x01, 0x22, 0x75,
-0x29, 0x12, 0xE4, 0xF5, 0x2A, 0x75, 0x2B, 0x87,
-0x75, 0x2C, 0x33, 0xF5, 0x31, 0xF5, 0x32, 0xF5,
-0x33, 0xF5, 0x34, 0x90, 0x01, 0x30, 0xE5, 0x29,
-0xF0, 0xA3, 0xE5, 0x2A, 0xF0, 0xA3, 0xE5, 0x2B,
-0xF0, 0xA3, 0xE5, 0x2C, 0xF0, 0x90, 0x01, 0x20,
-0xE5, 0x31, 0xF0, 0xA3, 0xE5, 0x32, 0xF0, 0xA3,
-0xE5, 0x33, 0xF0, 0xA3, 0xE5, 0x34, 0xF0, 0x22,
-0x75, 0x39, 0x07, 0x43, 0x39, 0x10, 0x75, 0x3A,
-0x01, 0x43, 0x3A, 0x08, 0x75, 0x3B, 0x03, 0x75,
-0x3C, 0x62, 0x43, 0x3C, 0x80, 0x43, 0x3B, 0x04,
-0x90, 0x01, 0x38, 0xE5, 0x39, 0xF0, 0xA3, 0xE5,
-0x3A, 0xF0, 0xA3, 0xE5, 0x3B, 0xF0, 0xA3, 0xE5,
-0x3C, 0xF0, 0x22, 0x7D, 0x02, 0x90, 0x01, 0xC4,
-0x74, 0x43, 0xF0, 0x74, 0xC1, 0xA3, 0xF0, 0x90,
-0x93, 0x49, 0xE0, 0xFF, 0xED, 0xC3, 0x9F, 0x50,
-0x18, 0xED, 0x25, 0xE0, 0x24, 0x81, 0xF8, 0xE6,
-0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8, 0x74, 0x08,
-0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22, 0x0D, 0x80,
-0xDE, 0x74, 0x43, 0x04, 0x90, 0x01, 0xC4, 0xF0,
-0x74, 0xC1, 0xA3, 0xF0, 0x7F, 0x01, 0x22, 0xE4,
-0x90, 0x95, 0x0E, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
-0x90, 0x95, 0x0E, 0xE0, 0x64, 0x01, 0xF0, 0x90,
-0x93, 0x55, 0xE0, 0x70, 0x18, 0x90, 0x93, 0x52,
-0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E, 0x90,
-0x95, 0x0E, 0xE0, 0x24, 0x7F, 0x90, 0x01, 0xC4,
-0xF0, 0x74, 0xC1, 0xA3, 0xF0, 0x12, 0x7C, 0x54,
-0xBF, 0x01, 0x03, 0x12, 0x54, 0x9F, 0x90, 0x88,
-0x36, 0xE0, 0x60, 0x0F, 0x90, 0x88, 0x39, 0xE0,
-0xFF, 0x90, 0x88, 0x38, 0xE0, 0x6F, 0x60, 0x03,
-0x12, 0xA6, 0xF0, 0xC2, 0xAF, 0x31, 0x43, 0xBF,
-0x01, 0x02, 0x51, 0x9F, 0xD2, 0xAF, 0x31, 0xE0,
-0x12, 0x97, 0xF8, 0x12, 0x83, 0x4D, 0x80, 0xA8,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x93, 0x52, 0xE0, 0x60, 0x24, 0x7F, 0x54, 0x7E,
-0x09, 0x12, 0x70, 0x70, 0x51, 0x8C, 0x12, 0x04,
-0xB8, 0xEF, 0x44, 0xFE, 0xFF, 0xEE, 0x44, 0x03,
-0xFE, 0xED, 0x44, 0x04, 0xFD, 0xEC, 0x51, 0x8C,
-0x51, 0x96, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x70,
-0xAD, 0x90, 0x93, 0x4D, 0xE0, 0x70, 0x29, 0x90,
-0x07, 0xCC, 0xE0, 0x30, 0xE0, 0x22, 0xE4, 0xF0,
-0x90, 0x95, 0x15, 0x74, 0x22, 0xF0, 0x90, 0x95,
-0x37, 0x74, 0x01, 0xF0, 0x90, 0x95, 0x17, 0x74,
-0x03, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x15,
-0x12, 0x8B, 0x34, 0x7F, 0x04, 0x12, 0x04, 0x7E,
-0x90, 0x93, 0x55, 0xE0, 0xFF, 0x70, 0x0A, 0x90,
-0x93, 0x52, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x60,
-0x15, 0x90, 0x00, 0x1F, 0xE0, 0x54, 0xF0, 0xF0,
-0x90, 0x01, 0xC5, 0x74, 0xEA, 0xF0, 0xA3, 0x74,
-0xEF, 0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0xEF, 0x60,
-0x06, 0x90, 0x01, 0xC4, 0x74, 0x07, 0xF0, 0x90,
-0x93, 0x52, 0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4,
-0x74, 0x01, 0xF0, 0x90, 0x93, 0x53, 0xE0, 0x60,
-0x06, 0x90, 0x01, 0xC4, 0x74, 0x02, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x95, 0x11, 0x12,
-0x04, 0x31, 0x90, 0x95, 0x11, 0x22, 0x12, 0x04,
-0xB8, 0x90, 0x92, 0x18, 0x02, 0x04, 0x31, 0x90,
-0x88, 0x31, 0xE0, 0x30, 0xE0, 0x03, 0x12, 0xB4,
-0x1F, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x71, 0x55, 0x90, 0x96, 0xAC, 0x12, 0x04,
-0x31, 0x90, 0x96, 0xAC, 0x51, 0x96, 0x51, 0xE2,
-0x90, 0x01, 0x01, 0xE0, 0x44, 0x02, 0xF0, 0x90,
-0x01, 0x00, 0x74, 0xFF, 0xF0, 0x90, 0x06, 0xB7,
-0x74, 0x09, 0xF0, 0x90, 0x06, 0xB4, 0x74, 0x86,
-0xF0, 0x12, 0xA7, 0xB5, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x7F, 0x30, 0x7E, 0x08, 0x02, 0x70,
-0xAD, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x71, 0x55, 0x90, 0x96, 0xB0, 0x12, 0x04, 0x31,
-0x90, 0x96, 0xB0, 0x51, 0x96, 0x51, 0xE2, 0x90,
-0x8A, 0xFD, 0x12, 0x88, 0xCD, 0x90, 0x06, 0xB7,
-0x74, 0x11, 0xF0, 0x7F, 0x03, 0x7E, 0x00, 0x12,
-0x7C, 0x6A, 0x90, 0x06, 0xB4, 0xE0, 0x54, 0x0F,
-0x70, 0xF1, 0x90, 0x07, 0xD5, 0xE0, 0x44, 0x80,
-0xF0, 0x7F, 0x0A, 0x80, 0x09, 0x90, 0x06, 0x62,
-0xE0, 0x30, 0xE0, 0x09, 0x7F, 0x01, 0x7E, 0x00,
-0x12, 0x7C, 0x6A, 0x80, 0xF0, 0x71, 0x62, 0x90,
-0x01, 0x00, 0x74, 0x3F, 0xF0, 0xA3, 0xE0, 0x54,
-0xFD, 0xF0, 0x90, 0x05, 0x53, 0xE0, 0x44, 0x20,
-0xF0, 0x90, 0x07, 0xD5, 0xE0, 0x54, 0x7F, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7F, 0x30, 0x7E,
-0x08, 0x12, 0x70, 0x70, 0xED, 0x44, 0x80, 0xFD,
-0xEC, 0x22, 0x90, 0x00, 0x02, 0xE0, 0x54, 0xFE,
-0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x96, 0x69, 0xEE, 0xF0, 0xA3, 0xEF,
-0xF0, 0x12, 0x70, 0x70, 0x90, 0x96, 0x73, 0x12,
-0x04, 0x31, 0x90, 0x96, 0x6B, 0x12, 0x04, 0xB8,
-0x12, 0x03, 0xCD, 0x90, 0x96, 0x73, 0x12, 0x86,
-0x61, 0x12, 0x86, 0x47, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x96, 0x6B, 0x12,
-0x04, 0xB8, 0x90, 0x96, 0x6F, 0x12, 0x86, 0x61,
-0x12, 0x86, 0x47, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x86, 0x54, 0x90, 0x96,
-0x77, 0x12, 0x04, 0x31, 0x90, 0x96, 0x77, 0x51,
-0x96, 0x90, 0x96, 0x69, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x12, 0x70, 0xAD, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x90, 0x8A, 0x79, 0x74, 0x86, 0xF0, 0xA3,
-0x74, 0xC6, 0xF0, 0x90, 0x8A, 0xE5, 0x74, 0xC4,
-0xF0, 0xA3, 0x74, 0xFE, 0xF0, 0x90, 0x8B, 0x03,
-0x74, 0xA0, 0xF0, 0xA3, 0x74, 0x20, 0xF0, 0x90,
-0x8A, 0xB9, 0x74, 0x88, 0xF0, 0xA3, 0x74, 0xD7,
-0xF0, 0x90, 0x8A, 0xD5, 0x74, 0x91, 0xF0, 0xA3,
-0x74, 0xE4, 0xF0, 0x90, 0x8A, 0xFB, 0x74, 0x90,
-0xF0, 0xA3, 0x74, 0x55, 0xF0, 0x90, 0x8A, 0xA5,
-0x74, 0x96, 0xF0, 0xA3, 0x74, 0x54, 0xF0, 0x90,
-0x8A, 0xB5, 0x74, 0xC5, 0xF0, 0xA3, 0x74, 0xEE,
-0xF0, 0x90, 0x8A, 0x75, 0x74, 0xB4, 0xF0, 0xA3,
-0x74, 0xCB, 0xF0, 0x90, 0x8A, 0xC1, 0x74, 0x8B,
-0xF0, 0xA3, 0x74, 0x4F, 0xF0, 0x90, 0x8A, 0xC3,
-0x74, 0xD1, 0xF0, 0xA3, 0x74, 0x16, 0xF0, 0x90,
-0x8A, 0xF3, 0x74, 0xD1, 0xF0, 0xA3, 0x74, 0x56,
-0xF0, 0x90, 0x8A, 0x85, 0x74, 0xD2, 0xF0, 0xA3,
-0x74, 0x31, 0xF0, 0x90, 0x86, 0x04, 0x74, 0xBD,
-0xF0, 0xA3, 0x74, 0xE8, 0xF0, 0x90, 0x8A, 0xA9,
-0x74, 0xD1, 0xF0, 0xA3, 0x74, 0x62, 0xF0, 0x90,
-0x8B, 0x07, 0x74, 0xD1, 0xF0, 0xA3, 0x74, 0x87,
-0xF0, 0x90, 0x8A, 0xAD, 0x74, 0xA5, 0xF0, 0xA3,
-0x74, 0xAE, 0xF0, 0x90, 0x8A, 0xBB, 0x74, 0xD2,
-0xF0, 0xA3, 0x74, 0x8B, 0xF0, 0x90, 0x86, 0x0C,
-0x74, 0xC2, 0xF0, 0xA3, 0x74, 0xAA, 0xF0, 0x90,
-0x8A, 0xEF, 0x74, 0xC2, 0xF0, 0xA3, 0x74, 0xE9,
-0xF0, 0x90, 0x86, 0x00, 0x74, 0xDA, 0xF0, 0xA3,
-0x74, 0x1C, 0xF0, 0x90, 0x86, 0x02, 0x74, 0xDA,
-0xF0, 0xA3, 0x74, 0x91, 0xF0, 0x90, 0x8A, 0xFD,
-0x74, 0x9D, 0xF0, 0xA3, 0x74, 0x44, 0xF0, 0x90,
-0x8A, 0xF9, 0x74, 0xC5, 0xF0, 0xA3, 0x74, 0x94,
-0xF0, 0x90, 0x8A, 0xDB, 0x74, 0xC7, 0xF0, 0xA3,
-0x74, 0x81, 0xF0, 0x90, 0x8A, 0xAF, 0x74, 0x9D,
-0xF0, 0xA3, 0x74, 0xC7, 0xF0, 0x90, 0x8A, 0xD3,
-0x74, 0xCE, 0xF0, 0xA3, 0x74, 0xD6, 0xF0, 0x90,
-0x8A, 0xF5, 0x74, 0xDC, 0xF0, 0xA3, 0x74, 0x03,
-0xF0, 0x90, 0x8A, 0xA3, 0x74, 0xAB, 0xF0, 0xA3,
-0x74, 0xB4, 0xF0, 0x90, 0x86, 0x06, 0x74, 0x9E,
-0xF0, 0xA3, 0x74, 0xF3, 0xF0, 0x22, 0x8F, 0x0D,
-0x7F, 0x02, 0x12, 0x85, 0x27, 0x90, 0x86, 0xAF,
-0xE0, 0x45, 0x0D, 0xF0, 0x22, 0xC0, 0xE0, 0xC0,
-0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
-0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
-0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x0D, 0xF0,
-0x74, 0xC5, 0xA3, 0xF0, 0x90, 0x8A, 0x9D, 0x12,
-0x88, 0xCD, 0x53, 0x91, 0xBF, 0x74, 0x0D, 0x04,
-0x90, 0x01, 0xC4, 0xF0, 0x74, 0xC5, 0xA3, 0xF0,
-0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
-0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
-0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
-0xD0, 0xE0, 0x32, 0xC0, 0xE0, 0xC0, 0x83, 0xC0,
-0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x05,
-0xC0, 0x07, 0x7D, 0x63, 0x90, 0x01, 0xC4, 0xED,
-0xF0, 0x74, 0xC5, 0xFF, 0xA3, 0xF0, 0xED, 0x04,
-0x90, 0x01, 0xC4, 0xF0, 0xA3, 0xEF, 0xF0, 0xD0,
-0x07, 0xD0, 0x05, 0xD0, 0xD0, 0xD0, 0x82, 0xD0,
-0x83, 0xD0, 0xE0, 0x32, 0x90, 0x96, 0xCB, 0xED,
-0xF0, 0x64, 0x01, 0x60, 0x27, 0xE0, 0xFE, 0x64,
-0x02, 0x60, 0x21, 0xEE, 0x64, 0x29, 0x60, 0x1C,
-0xEE, 0x64, 0x2A, 0x60, 0x17, 0xEE, 0x64, 0x36,
-0x60, 0x12, 0xEE, 0xB4, 0x37, 0x02, 0x80, 0x0C,
-0xAD, 0x07, 0x7F, 0xFF, 0x12, 0x9F, 0xBF, 0x90,
-0x93, 0x5E, 0xE0, 0xFF, 0x90, 0x93, 0x5D, 0xE0,
-0x4F, 0x90, 0x05, 0x22, 0xF0, 0x90, 0x96, 0xCB,
-0xE0, 0x90, 0x93, 0x01, 0xF0, 0x22, 0xE6, 0xFD,
-0xAF, 0x62, 0xEF, 0x12, 0x93, 0xEF, 0xE0, 0x54,
-0xF8, 0xF5, 0x70, 0xED, 0x42, 0x70, 0xEF, 0x12,
-0x93, 0xEF, 0xE5, 0x70, 0xF0, 0x22, 0x12, 0x02,
-0x06, 0xFE, 0x12, 0x87, 0xEA, 0xFF, 0x74, 0xD6,
-0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0x12, 0x87,
-0xF0, 0xFF, 0x74, 0xC6, 0x2E, 0xF5, 0x82, 0xE4,
-0x34, 0x8D, 0x12, 0x87, 0xFA, 0xFF, 0x74, 0x0D,
-0x2E, 0xD1, 0x37, 0xEF, 0xF0, 0x74, 0xC6, 0x2E,
-0x12, 0x97, 0xD4, 0xE0, 0x30, 0xE5, 0x17, 0x75,
-0xF0, 0x12, 0xEE, 0x12, 0x94, 0xEE, 0x13, 0x13,
-0x54, 0x03, 0xFB, 0xAF, 0x06, 0x74, 0xD6, 0x2E,
-0xD1, 0x43, 0xFD, 0x12, 0x6B, 0xFD, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83, 0x22, 0x74,
-0xD6, 0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8D,
-0xF5, 0x83, 0xE0, 0x22, 0xE4, 0xF5, 0x75, 0xEF,
-0x14, 0xF5, 0x74, 0xED, 0xFF, 0xE5, 0x74, 0xF5,
-0x82, 0x33, 0x95, 0xE0, 0xF5, 0x83, 0xC3, 0xE5,
-0x82, 0x9F, 0x74, 0x80, 0xF8, 0x65, 0x83, 0x98,
-0x40, 0x52, 0xE5, 0x74, 0x78, 0x03, 0xA2, 0xE7,
-0x13, 0xD8, 0xFB, 0xFF, 0x33, 0x95, 0xE0, 0xFE,
-0xEB, 0x12, 0x97, 0xDC, 0xE5, 0x82, 0x2F, 0xF5,
-0x82, 0xE5, 0x83, 0x3E, 0xF5, 0x83, 0xE0, 0xF5,
-0x82, 0x75, 0x83, 0x00, 0xE5, 0x74, 0x12, 0xB1,
-0x70, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
-0xD8, 0xF9, 0xFF, 0xEE, 0x55, 0x83, 0xFE, 0xEF,
-0x55, 0x82, 0x4E, 0x60, 0x13, 0x85, 0x74, 0x76,
-0x05, 0x75, 0x90, 0x95, 0x4C, 0xE0, 0x65, 0x75,
-0x60, 0x0A, 0xE5, 0x76, 0xD3, 0x9D, 0x40, 0x04,
-0x15, 0x74, 0x80, 0x97, 0xAF, 0x76, 0x22, 0xAA,
-0x07, 0xA9, 0x05, 0xEA, 0x12, 0x90, 0xDE, 0xE0,
+0x97, 0x07, 0xED, 0xF0, 0x64, 0x01, 0x60, 0x27,
+0xE0, 0xFE, 0x64, 0x02, 0x60, 0x21, 0xEE, 0x64,
+0x29, 0x60, 0x1C, 0xEE, 0x64, 0x2A, 0x60, 0x17,
+0xEE, 0x64, 0x36, 0x60, 0x12, 0xEE, 0xB4, 0x37,
+0x02, 0x80, 0x0C, 0xAD, 0x07, 0x7F, 0xFF, 0x12,
+0xA7, 0x4E, 0x90, 0x93, 0x5F, 0xE0, 0xFF, 0x90,
+0x93, 0x5E, 0xE0, 0x4F, 0x90, 0x05, 0x22, 0xF0,
+0x90, 0x97, 0x07, 0xE0, 0x90, 0x93, 0x01, 0xF0,
+0x22, 0xE6, 0xFD, 0xAF, 0x62, 0xEF, 0x12, 0x96,
+0xF3, 0xE0, 0x54, 0xF8, 0xF5, 0x70, 0xED, 0x42,
+0x70, 0xEF, 0x12, 0x96, 0xF3, 0xE5, 0x70, 0xF0,
+0x22, 0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00, 0x90,
+0x89, 0x2E, 0x12, 0x86, 0x76, 0x7B, 0xFF, 0x7A,
+0x80, 0x79, 0x80, 0x90, 0x89, 0x31, 0x12, 0x86,
+0x76, 0x7A, 0x80, 0x79, 0xBF, 0x90, 0x89, 0x34,
+0x12, 0x86, 0x76, 0x7A, 0x81, 0x79, 0x61, 0x90,
+0x89, 0x3A, 0x12, 0x86, 0x76, 0x7A, 0x81, 0x79,
+0x75, 0x90, 0x89, 0x3D, 0x12, 0x86, 0x76, 0x7A,
+0x81, 0x79, 0x9D, 0x90, 0x89, 0x40, 0x12, 0x86,
+0x76, 0x91, 0x49, 0x7A, 0x81, 0x79, 0xD9, 0x90,
+0x89, 0x49, 0x12, 0x86, 0x76, 0x7A, 0x82, 0x79,
+0x01, 0x90, 0x89, 0x4C, 0x12, 0x86, 0x76, 0xE4,
+0x90, 0x96, 0x25, 0xF0, 0x90, 0x96, 0x14, 0xF0,
+0x90, 0x94, 0xBD, 0xF0, 0x12, 0xB7, 0xCC, 0x50,
+0x0F, 0x74, 0x36, 0x2F, 0x91, 0x57, 0xE4, 0xF0,
+0x90, 0x94, 0xBD, 0xE0, 0x04, 0xF0, 0x80, 0xEC,
+0x22, 0x7A, 0x81, 0x79, 0xB1, 0x90, 0x89, 0x46,
+0x02, 0x86, 0x76, 0x74, 0x36, 0x25, 0x62, 0xF5,
+0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83, 0x22, 0xE4,
+0xF5, 0x75, 0xEF, 0x14, 0xF5, 0x74, 0xED, 0xFF,
+0xE5, 0x74, 0xF5, 0x82, 0x33, 0x95, 0xE0, 0xF5,
+0x83, 0xC3, 0xE5, 0x82, 0x9F, 0x74, 0x80, 0xF8,
+0x65, 0x83, 0x98, 0x40, 0x51, 0xE5, 0x74, 0x78,
+0x03, 0xA2, 0xE7, 0x13, 0xD8, 0xFB, 0xFF, 0x33,
+0x95, 0xE0, 0xFE, 0xEB, 0x91, 0xD1, 0xE5, 0x82,
+0x2F, 0xF5, 0x82, 0xE5, 0x83, 0x3E, 0xF5, 0x83,
+0xE0, 0xF5, 0x82, 0x75, 0x83, 0x00, 0xE5, 0x74,
+0x12, 0xB7, 0x93, 0x80, 0x05, 0xC3, 0x33, 0xCE,
+0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEE, 0x55, 0x83,
+0xFE, 0xEF, 0x55, 0x82, 0x4E, 0x60, 0x13, 0x85,
+0x74, 0x76, 0x05, 0x75, 0x90, 0x95, 0x53, 0xE0,
+0x65, 0x75, 0x60, 0x0A, 0xE5, 0x76, 0xD3, 0x9D,
+0x40, 0x04, 0x15, 0x74, 0x80, 0x98, 0xAF, 0x76,
+0x22, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x00, 0xF5,
+0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0x22, 0xAA,
+0x07, 0xA9, 0x05, 0xEA, 0x12, 0x94, 0xDD, 0xE0,
 0xF5, 0x70, 0x54, 0x7F, 0xF5, 0x72, 0x75, 0xF0,
-0x12, 0xEA, 0x12, 0x97, 0xCA, 0xE0, 0x90, 0x95,
-0x48, 0xF0, 0x75, 0xF0, 0x12, 0xEA, 0x12, 0x97,
-0xBF, 0xFF, 0xEA, 0x12, 0x90, 0x48, 0xE0, 0x54,
-0x03, 0xF5, 0x71, 0xE5, 0x72, 0x90, 0x81, 0x9D,
-0x93, 0xFD, 0xEA, 0x25, 0xE0, 0x24, 0x75, 0xF5,
-0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83, 0xE4, 0xF0,
-0xA3, 0xED, 0xF0, 0x75, 0xF0, 0x12, 0xEA, 0x12,
-0x94, 0xEE, 0xFE, 0xC4, 0x54, 0x03, 0x90, 0x95,
-0x47, 0xF0, 0x74, 0xC6, 0x2A, 0x12, 0x94, 0xE1,
-0xE5, 0x72, 0xF0, 0x74, 0x46, 0x2A, 0xF1, 0x79,
-0xE5, 0x71, 0xF0, 0xE5, 0x72, 0xD3, 0x9F, 0x40,
-0x04, 0x8F, 0x72, 0x8F, 0x70, 0x89, 0x73, 0xE4,
-0xFF, 0xEF, 0xC3, 0x95, 0x73, 0x50, 0x33, 0xE5,
-0x70, 0x30, 0xE7, 0x09, 0x85, 0x72, 0x70, 0x19,
-0xE9, 0x70, 0x24, 0x80, 0x25, 0x90, 0x95, 0x48,
-0xE0, 0xFD, 0xE5, 0x72, 0xD3, 0x9D, 0x40, 0x0F,
-0xAB, 0x02, 0x90, 0x95, 0x4C, 0xE9, 0xF0, 0xAF,
-0x72, 0xD1, 0x4C, 0x8F, 0x70, 0x80, 0x0B, 0x90,
-0x95, 0x48, 0xE0, 0xF5, 0x70, 0x80, 0x03, 0x0F,
-0x80, 0xC7, 0xAF, 0x02, 0x90, 0x92, 0x80, 0xE5,
-0x71, 0xF0, 0xE4, 0xFB, 0xAD, 0x70, 0x02, 0x75,
-0x80, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
-0x22, 0xEF, 0x64, 0x13, 0x60, 0x04, 0xEF, 0xB4,
-0x0B, 0x05, 0x90, 0x88, 0xE3, 0x80, 0x1F, 0xEF,
-0x64, 0x12, 0x60, 0x04, 0xEF, 0xB4, 0x0A, 0x05,
-0x90, 0x88, 0xE4, 0x80, 0x11, 0xEF, 0x64, 0x11,
-0x60, 0x04, 0xEF, 0xB4, 0x09, 0x05, 0x90, 0x88,
-0xE5, 0x80, 0x03, 0x90, 0x88, 0xE2, 0xE0, 0xF5,
-0x0F, 0xAF, 0x0F, 0x22, 0x90, 0x04, 0x85, 0xE0,
-0xF5, 0x6B, 0x90, 0x96, 0x1D, 0xE0, 0x04, 0xF0,
-0xE4, 0xF5, 0x62, 0x90, 0x88, 0x2B, 0xE0, 0xFF,
-0xE5, 0x62, 0xC3, 0x9F, 0x40, 0x03, 0x02, 0xCE,
-0x36, 0xE5, 0x62, 0x12, 0x90, 0xDE, 0xE0, 0xF5,
-0x6D, 0x12, 0xDD, 0x33, 0xF5, 0x83, 0xE0, 0x65,
-0x6D, 0x60, 0x18, 0x90, 0x92, 0x5E, 0xE5, 0x6D,
-0xF0, 0xE4, 0xA3, 0xF0, 0xAB, 0x62, 0xFD, 0xFF,
-0x12, 0x6F, 0x75, 0x12, 0xDD, 0x33, 0xF5, 0x83,
-0xE5, 0x6D, 0xF0, 0x90, 0x04, 0xA0, 0xE0, 0x64,
-0x01, 0x70, 0x50, 0xA3, 0xE0, 0x65, 0x62, 0x70,
-0x4A, 0xA3, 0xE0, 0xF5, 0x63, 0xA3, 0xE0, 0x90,
-0x95, 0x44, 0xF0, 0xE5, 0x62, 0x12, 0x90, 0xDE,
-0xE0, 0x65, 0x63, 0x70, 0x02, 0xC1, 0x31, 0xE5,
-0x62, 0x12, 0x90, 0xDE, 0xE5, 0x63, 0xF0, 0xE5,
-0x62, 0x12, 0x90, 0x48, 0xE0, 0x54, 0xFC, 0xFF,
-0x90, 0x95, 0x44, 0xE0, 0x54, 0x03, 0x4F, 0xFF,
-0xE5, 0x62, 0x12, 0x90, 0x48, 0xEF, 0xF0, 0x90,
-0x92, 0x5E, 0xE5, 0x63, 0xF0, 0xA3, 0x74, 0xFF,
-0xF0, 0xAB, 0x62, 0xE4, 0xFD, 0xFF, 0x12, 0x6F,
-0x75, 0xC1, 0x31, 0x75, 0xF0, 0x12, 0xE5, 0x62,
-0x12, 0xB7, 0xA3, 0xE0, 0xFF, 0x90, 0x95, 0x3C,
-0xE4, 0xF0, 0xA3, 0xEF, 0xF0, 0x75, 0xF0, 0x12,
-0xE5, 0x62, 0x90, 0x89, 0x53, 0x12, 0x04, 0x6E,
-0xE0, 0xF5, 0x68, 0xA3, 0xE0, 0xF5, 0x69, 0xE5,
-0x62, 0x75, 0xF0, 0x12, 0xA4, 0x24, 0x57, 0xF9,
-0x74, 0x89, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x90,
-0x95, 0x39, 0x12, 0x86, 0x76, 0xD1, 0x94, 0xFF,
-0x12, 0x03, 0x13, 0x2F, 0xFF, 0xD1, 0x9A, 0x2F,
-0xFF, 0xD1, 0x83, 0x2F, 0xFF, 0xD1, 0x7A, 0x2F,
-0xF5, 0x6C, 0xE5, 0x62, 0x12, 0x90, 0xDE, 0xE0,
-0xF5, 0x63, 0x54, 0x80, 0xF5, 0x65, 0xE5, 0x63,
-0x54, 0x7F, 0xF5, 0x64, 0x75, 0xF0, 0x12, 0xE5,
-0x62, 0x12, 0xB7, 0x10, 0xE0, 0x64, 0x01, 0x60,
-0x02, 0x41, 0x12, 0xD1, 0x37, 0xD1, 0x94, 0xFF,
-0xAE, 0xF0, 0x12, 0x03, 0x13, 0x2F, 0xFF, 0xE5,
-0xF0, 0x3E, 0xFE, 0xD1, 0x9A, 0x2F, 0xFF, 0xEE,
-0xD1, 0x80, 0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xFE,
-0xD1, 0x7A, 0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0x90,
-0x95, 0x3E, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x03,
-0x13, 0xFF, 0xC3, 0x90, 0x95, 0x3F, 0xE0, 0x9F,
-0xFE, 0x90, 0x95, 0x3E, 0xE0, 0x95, 0xF0, 0x90,
-0x95, 0x40, 0xF0, 0xA3, 0xCE, 0xF0, 0xD1, 0x83,
-0xFD, 0xAC, 0xF0, 0x25, 0xE0, 0xFF, 0xEC, 0x33,
-0xFE, 0xEF, 0x2D, 0xFD, 0xEE, 0x3C, 0xFC, 0xD1,
-0x9A, 0x25, 0xE0, 0xFF, 0xE5, 0xF0, 0x33, 0xFE,
-0xD1, 0x94, 0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xCF,
-0x2D, 0xFD, 0xEF, 0x3C, 0xFC, 0xD1, 0x37, 0xD1,
-0x7A, 0xAE, 0xF0, 0x78, 0x02, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0x2D, 0xFF, 0xEC, 0x3E,
-0x90, 0x95, 0x42, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
-0x95, 0x3C, 0xD1, 0xC5, 0xF1, 0xB8, 0x34, 0x8E,
-0xD1, 0x89, 0x9E, 0x50, 0x07, 0x90, 0x95, 0x3C,
-0xD1, 0xAB, 0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF,
-0xE5, 0x62, 0xF1, 0xB8, 0x34, 0x8E, 0x12, 0x91,
-0xDC, 0x90, 0x95, 0x3E, 0xD1, 0xC5, 0xF1, 0xC0,
-0x34, 0x8E, 0xD1, 0x89, 0x9E, 0x50, 0x07, 0x90,
-0x95, 0x3E, 0xD1, 0xAB, 0x80, 0x04, 0x7E, 0xFF,
-0x7F, 0xFF, 0xE5, 0x62, 0xF1, 0xC0, 0x34, 0x8E,
-0x12, 0x91, 0xDC, 0x90, 0x95, 0x42, 0xD1, 0xC5,
-0xF1, 0xC8, 0x34, 0x8E, 0xD1, 0x89, 0x9E, 0x50,
-0x07, 0x90, 0x95, 0x42, 0xD1, 0xAB, 0x80, 0x04,
-0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x62, 0xF1, 0xC8,
-0x34, 0x8E, 0x12, 0x91, 0xDC, 0xC3, 0x74, 0xFF,
-0x95, 0x69, 0xFF, 0x74, 0xFF, 0x95, 0x68, 0xFE,
-0x12, 0xDD, 0x29, 0x34, 0x8E, 0xD1, 0x89, 0x9E,
-0x50, 0x0A, 0xE5, 0x69, 0x2D, 0xFF, 0xE5, 0x68,
-0x3C, 0xFE, 0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF,
-0x12, 0xDD, 0x29, 0x34, 0x8E, 0x12, 0x91, 0xDC,
-0xF1, 0xD8, 0xFB, 0xC3, 0x74, 0xFF, 0x9B, 0xFF,
-0x74, 0xFF, 0x9E, 0xFE, 0x74, 0xFF, 0x94, 0x00,
-0xFD, 0x74, 0xFF, 0x94, 0x00, 0xFC, 0x90, 0x8D,
-0x71, 0xF1, 0xE9, 0x50, 0x11, 0xF1, 0xD8, 0xFF,
-0xE4, 0xFC, 0xFD, 0x90, 0x8D, 0x71, 0x12, 0x86,
-0x61, 0x12, 0x86, 0x2C, 0x80, 0x06, 0x74, 0xFF,
-0xFF, 0xFE, 0xFD, 0xFC, 0x90, 0x8D, 0x71, 0x12,
-0x04, 0x31, 0xAF, 0x62, 0x12, 0x78, 0x4A, 0xEF,
-0x70, 0x02, 0xC1, 0x31, 0x75, 0xF0, 0x12, 0xE5,
-0x62, 0x12, 0x94, 0xEE, 0x12, 0x8F, 0xF1, 0x30,
-0xE0, 0x02, 0xC1, 0x31, 0xE5, 0x62, 0x13, 0x13,
-0x13, 0x54, 0x1F, 0x12, 0x94, 0xD3, 0xE0, 0xFD,
-0x7C, 0x00, 0xE5, 0x62, 0x12, 0xB1, 0x70, 0x80,
-0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
-0xFF, 0xEE, 0x5C, 0xFE, 0xEF, 0x5D, 0x4E, 0x60,
-0x02, 0xC1, 0x31, 0xE5, 0x69, 0x45, 0x68, 0x70,
-0x0C, 0x90, 0x95, 0x3C, 0xE0, 0x70, 0x02, 0xA3,
-0xE0, 0x70, 0x02, 0xC1, 0x31, 0x90, 0x96, 0x0B,
-0xE0, 0x60, 0x11, 0x75, 0x6E, 0x0A, 0xD1, 0xB7,
-0xE4, 0x93, 0xC3, 0x13, 0x74, 0x01, 0x93, 0x13,
-0xF5, 0x6F, 0x80, 0x0A, 0x7B, 0xFF, 0x12, 0xB1,
-0x66, 0xE4, 0xF5, 0x6E, 0xF5, 0x6F, 0x75, 0xF0,
-0x12, 0xE5, 0x62, 0x12, 0x97, 0xBF, 0xFF, 0xE5,
-0x64, 0xD3, 0x9F, 0x40, 0x08, 0x8F, 0x64, 0xE5,
-0x64, 0x45, 0x65, 0xF5, 0x63, 0xD1, 0x3D, 0xE0,
-0xC3, 0x94, 0x05, 0x40, 0x02, 0x81, 0x21, 0xE5,
-0x64, 0x90, 0x81, 0x61, 0x93, 0xF5, 0x6A, 0xFD,
-0xAF, 0x64, 0x12, 0x60, 0x6F, 0x8F, 0x6A, 0xE5,
-0x65, 0x60, 0x04, 0x05, 0x6A, 0x05, 0x6A, 0xE5,
-0x64, 0xC3, 0x94, 0x0C, 0x40, 0x1D, 0x74, 0x0D,
-0x25, 0x62, 0x12, 0xC6, 0x37, 0xE0, 0xFF, 0x54,
-0x7F, 0xFE, 0xEF, 0x30, 0xE7, 0x06, 0xE5, 0x6A,
-0x2E, 0xFF, 0x80, 0x05, 0xC3, 0xE5, 0x6A, 0x9E,
-0xFF, 0x8F, 0x6A, 0xE5, 0x6A, 0xD3, 0x94, 0x1A,
-0xAF, 0x6A, 0x40, 0x02, 0x7F, 0x1A, 0x8F, 0x6A,
-0xE5, 0x63, 0x90, 0x81, 0xD9, 0x93, 0xFF, 0xD3,
-0x90, 0x95, 0x3D, 0xE0, 0x9F, 0x90, 0x95, 0x3C,
-0xE0, 0x94, 0x00, 0x40, 0x02, 0x61, 0xDA, 0xC3,
-0xE5, 0x69, 0x94, 0x0A, 0xE5, 0x68, 0x94, 0x00,
-0x50, 0x7A, 0x12, 0xB1, 0x5A, 0xE0, 0xC3, 0x94,
-0x01, 0x40, 0x06, 0x12, 0xB1, 0x5A, 0xE0, 0x14,
-0xF0, 0xD1, 0x37, 0xD1, 0x7A, 0xFF, 0x90, 0x95,
-0x3D, 0xE0, 0x2F, 0xFF, 0x90, 0x95, 0x3C, 0xE0,
-0xD1, 0x80, 0x2F, 0xFD, 0xEE, 0x35, 0xF0, 0xFC,
-0xE5, 0x68, 0xC3, 0x13, 0xFE, 0xE5, 0x69, 0x13,
-0xFF, 0xD3, 0xED, 0x9F, 0xEC, 0x9E, 0x40, 0x0E,
-0xE5, 0x62, 0x94, 0x05, 0x50, 0x06, 0x12, 0xB1,
-0x5A, 0x74, 0x02, 0xF0, 0x61, 0xDA, 0xD1, 0x37,
+0x12, 0xEA, 0xD1, 0xA2, 0xE0, 0x90, 0x95, 0x4F,
+0xF0, 0x75, 0xF0, 0x12, 0xEA, 0xD1, 0x70, 0xFF,
+0xEA, 0x12, 0x93, 0xF4, 0xE0, 0x54, 0x03, 0xF5,
+0x71, 0xE5, 0x72, 0x90, 0x81, 0x9D, 0x93, 0xFD,
+0xEA, 0xD1, 0xA8, 0xF5, 0x83, 0xE4, 0xF0, 0xA3,
+0xED, 0xF0, 0x75, 0xF0, 0x12, 0xEA, 0x12, 0x87,
+0xBA, 0xFE, 0xC4, 0x54, 0x03, 0x90, 0x95, 0x4E,
+0xF0, 0x74, 0xC6, 0x2A, 0xB1, 0x93, 0xE5, 0x72,
+0xF0, 0x74, 0x46, 0x2A, 0xD1, 0x64, 0xE5, 0x71,
+0xF0, 0xE5, 0x72, 0xD3, 0x9F, 0x40, 0x04, 0x8F,
+0x72, 0x8F, 0x70, 0x89, 0x73, 0xE4, 0xFF, 0xEF,
+0xC3, 0x95, 0x73, 0x50, 0x33, 0xE5, 0x70, 0x30,
+0xE7, 0x09, 0x85, 0x72, 0x70, 0x19, 0xE9, 0x70,
+0x24, 0x80, 0x25, 0x90, 0x95, 0x4F, 0xE0, 0xFD,
+0xE5, 0x72, 0xD3, 0x9D, 0x40, 0x0F, 0xAB, 0x02,
+0x90, 0x95, 0x53, 0xE9, 0xF0, 0xAF, 0x72, 0x91,
+0x5F, 0x8F, 0x70, 0x80, 0x0B, 0x90, 0x95, 0x4F,
+0xE0, 0xF5, 0x70, 0x80, 0x03, 0x0F, 0x80, 0xC7,
+0xAF, 0x02, 0x90, 0x92, 0x80, 0xE5, 0x71, 0xF0,
+0xE4, 0xFB, 0xAD, 0x70, 0x02, 0x75, 0x80, 0x74,
+0xC6, 0x25, 0x70, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
+0xF5, 0x83, 0x22, 0x8F, 0x70, 0x8D, 0x71, 0xEF,
+0x12, 0x94, 0xDD, 0xE0, 0xFD, 0x54, 0x7F, 0xF5,
+0x72, 0xED, 0x54, 0x80, 0xF5, 0x73, 0xD1, 0x6C,
+0xF5, 0x75, 0x75, 0xF0, 0x12, 0xEF, 0x12, 0x87,
+0xBA, 0xC4, 0x54, 0x03, 0xF5, 0x76, 0xD1, 0x58,
+0x74, 0xFF, 0xF0, 0xD1, 0x78, 0xE5, 0x73, 0x4D,
+0xFF, 0xB1, 0x8F, 0xEF, 0xF0, 0xE5, 0x70, 0x12,
+0x93, 0xF4, 0xE0, 0x54, 0x03, 0xF5, 0x74, 0x74,
+0x46, 0x25, 0x70, 0xD1, 0x64, 0xE5, 0x74, 0xF0,
+0xE5, 0x72, 0x65, 0x75, 0x70, 0x23, 0x75, 0xF0,
+0x12, 0xE5, 0x70, 0x12, 0xB6, 0x6C, 0xC4, 0x13,
+0x54, 0x07, 0x30, 0xE0, 0x0B, 0xE5, 0x73, 0x70,
+0x07, 0xE5, 0x72, 0x44, 0x80, 0xFD, 0x80, 0x4B,
+0xD1, 0x78, 0x7D, 0x07, 0xAF, 0x70, 0x02, 0xBB,
+0x07, 0xE5, 0x72, 0xC3, 0x95, 0x75, 0x50, 0x35,
+0xAB, 0x70, 0xAD, 0x75, 0xAF, 0x72, 0x12, 0x72,
+0x7F, 0xAD, 0x07, 0xE5, 0x72, 0xC3, 0x94, 0x0C,
+0x40, 0x29, 0x75, 0xF0, 0x12, 0xE5, 0x70, 0x12,
+0xB6, 0x6C, 0xFE, 0xC4, 0x13, 0x54, 0x07, 0x30,
+0xE0, 0x19, 0xE5, 0x71, 0x60, 0x15, 0xE5, 0x73,
+0x70, 0x11, 0xE5, 0x72, 0x44, 0x80, 0xFD, 0xD1,
+0x58, 0xEF, 0xF0, 0x80, 0x06, 0xB1, 0x8F, 0xE5,
+0x75, 0xF0, 0xFD, 0x90, 0x92, 0x80, 0xE5, 0x74,
+0xF0, 0xAB, 0x71, 0xAF, 0x70, 0x02, 0x75, 0x80,
+0x74, 0x26, 0x25, 0x70, 0xF5, 0x82, 0xE4, 0x34,
+0x96, 0xF5, 0x83, 0x22, 0xF5, 0x82, 0xE4, 0x34,
+0x8E, 0xF5, 0x83, 0x22, 0x75, 0xF0, 0x12, 0xEF,
+0x90, 0x89, 0x4F, 0x12, 0x04, 0x6E, 0xE0, 0x22,
+0xE5, 0x72, 0x25, 0xE0, 0x24, 0x75, 0xF5, 0x82,
+0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE4, 0x93, 0xFE,
+0x74, 0x01, 0x93, 0xFF, 0xE5, 0x70, 0x25, 0xE0,
+0x24, 0x75, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5,
+0x83, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x75,
+0xF0, 0x12, 0x90, 0x89, 0x50, 0x02, 0x04, 0x6E,
+0x25, 0xE0, 0x24, 0x75, 0xF5, 0x82, 0xE4, 0x34,
+0x8D, 0x22, 0xEF, 0x64, 0x13, 0x60, 0x04, 0xEF,
+0xB4, 0x0B, 0x05, 0x90, 0x88, 0xE3, 0x80, 0x1F,
+0xEF, 0x64, 0x12, 0x60, 0x04, 0xEF, 0xB4, 0x0A,
+0x05, 0x90, 0x88, 0xE4, 0x80, 0x11, 0xEF, 0x64,
+0x11, 0x60, 0x04, 0xEF, 0xB4, 0x09, 0x05, 0x90,
+0x88, 0xE5, 0x80, 0x03, 0x90, 0x88, 0xE2, 0xE0,
+0xF5, 0x0F, 0xAF, 0x0F, 0x22, 0x90, 0x04, 0x85,
+0xE0, 0xF5, 0x6B, 0x90, 0x96, 0x25, 0xE0, 0x04,
+0xF0, 0xE4, 0xF5, 0x62, 0x90, 0x88, 0x2B, 0xE0,
+0xFF, 0xE5, 0x62, 0xC3, 0x9F, 0x40, 0x03, 0x02,
+0xD5, 0x50, 0xE5, 0x62, 0x12, 0x94, 0xDD, 0xE0,
+0xF5, 0x6D, 0x12, 0xE0, 0x8D, 0xE0, 0x65, 0x6D,
+0x60, 0x15, 0x90, 0x96, 0x3E, 0x74, 0x06, 0xF0,
+0xE4, 0xFB, 0xAD, 0x6D, 0xAF, 0x62, 0x12, 0x94,
+0x7E, 0x12, 0xE0, 0x8D, 0xE5, 0x6D, 0xF0, 0x90,
+0x04, 0xA0, 0xE0, 0x64, 0x01, 0x70, 0x4B, 0xA3,
+0xE0, 0x65, 0x62, 0x70, 0x45, 0xA3, 0xE0, 0xF5,
+0x63, 0xA3, 0xE0, 0x90, 0x95, 0x4B, 0xF0, 0xE5,
+0x62, 0x12, 0x94, 0xDD, 0xE0, 0x65, 0x63, 0x70,
+0x03, 0x02, 0xD5, 0x4B, 0xE5, 0x62, 0x12, 0x94,
+0xDD, 0xE5, 0x63, 0xF0, 0x12, 0x93, 0xF2, 0xE0,
+0x54, 0xFC, 0xFF, 0x90, 0x95, 0x4B, 0xE0, 0x54,
+0x03, 0x4F, 0xFF, 0x12, 0x93, 0xF2, 0xEF, 0xF0,
+0x90, 0x96, 0x3E, 0x74, 0x07, 0xF0, 0xE4, 0xFB,
+0xAD, 0x63, 0xAF, 0x62, 0x12, 0x94, 0x7E, 0x02,
+0xD5, 0x4B, 0x75, 0xF0, 0x12, 0xE5, 0x62, 0x12,
+0xBB, 0x72, 0xE0, 0xFF, 0x90, 0x95, 0x43, 0xE4,
+0xF0, 0xA3, 0xEF, 0xF0, 0x75, 0xF0, 0x12, 0xE5,
+0x62, 0x90, 0x89, 0x53, 0x12, 0x04, 0x6E, 0xE0,
+0xF5, 0x68, 0xA3, 0xE0, 0xF5, 0x69, 0xE5, 0x62,
+0x75, 0xF0, 0x12, 0xA4, 0x24, 0x57, 0xF9, 0x74,
+0x89, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x90, 0x95,
+0x40, 0x12, 0x86, 0x76, 0x12, 0xD7, 0x71, 0xFF,
+0x12, 0x03, 0x13, 0x2F, 0xFF, 0x12, 0xD7, 0x05,
+0x2F, 0xFF, 0x12, 0xD5, 0xEC, 0x2F, 0xFF, 0x12,
+0xD5, 0xE3, 0x2F, 0xF5, 0x6C, 0xE5, 0x62, 0x12,
+0x94, 0xDD, 0xE0, 0xF5, 0x63, 0x54, 0x80, 0xF5,
+0x65, 0xE5, 0x63, 0x54, 0x7F, 0xF5, 0x64, 0x75,
+0xF0, 0x12, 0xE5, 0x62, 0x12, 0xBA, 0xD7, 0xE0,
+0x64, 0x01, 0x60, 0x03, 0x02, 0xD1, 0x35, 0x12,
+0xBF, 0xE9, 0x12, 0xD7, 0x71, 0xFF, 0xAE, 0xF0,
+0x12, 0x03, 0x13, 0x2F, 0xFF, 0xE5, 0xF0, 0x3E,
+0xFE, 0xF1, 0x05, 0x2F, 0xFF, 0xEE, 0xB1, 0xE9,
+0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xFE, 0xB1, 0xE3,
+0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0x90, 0x95, 0x45,
+0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x03, 0x13, 0xFF,
+0xC3, 0x90, 0x95, 0x46, 0xE0, 0x9F, 0xFE, 0x90,
+0x95, 0x45, 0xE0, 0x95, 0xF0, 0x90, 0x95, 0x47,
+0xF0, 0xA3, 0xCE, 0xF0, 0xB1, 0xEC, 0xFD, 0xAC,
+0xF0, 0x25, 0xE0, 0xFF, 0xEC, 0x33, 0xFE, 0xEF,
+0x2D, 0xFD, 0xEE, 0x3C, 0xFC, 0xF1, 0x05, 0x25,
+0xE0, 0xFF, 0xE5, 0xF0, 0x33, 0xFE, 0xF1, 0x71,
+0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xCF, 0x2D, 0xFD,
+0xEF, 0x3C, 0xFC, 0x12, 0xBF, 0xE9, 0xB1, 0xE3,
+0xAE, 0xF0, 0x78, 0x02, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0x2D, 0xFF, 0xEC, 0x3E, 0x90,
+0x95, 0x49, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x95,
+0x43, 0xD1, 0x17, 0xF1, 0x19, 0x12, 0x9F, 0xCF,
+0x50, 0x07, 0x90, 0x95, 0x43, 0xB1, 0xFD, 0x80,
+0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x62, 0x25,
+0xE0, 0xF1, 0x19, 0x12, 0xCE, 0x97, 0x90, 0x95,
+0x45, 0xD1, 0x17, 0xF1, 0x21, 0x12, 0x9F, 0xCF,
+0x50, 0x07, 0x90, 0x95, 0x45, 0xB1, 0xFD, 0x80,
+0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x62, 0x25,
+0xE0, 0xF1, 0x21, 0x12, 0xCE, 0x97, 0x90, 0x95,
+0x49, 0xD1, 0x17, 0xF1, 0x29, 0x12, 0x9F, 0xCF,
+0x50, 0x07, 0x90, 0x95, 0x49, 0xB1, 0xFD, 0x80,
+0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x62, 0x25,
+0xE0, 0xF1, 0x29, 0x12, 0xCE, 0x97, 0xC3, 0x74,
+0xFF, 0x95, 0x69, 0xFF, 0x74, 0xFF, 0x95, 0x68,
+0xFE, 0xF1, 0x65, 0x12, 0x9F, 0xCF, 0x50, 0x0A,
+0xE5, 0x69, 0x2D, 0xFF, 0xE5, 0x68, 0x3C, 0xFE,
+0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xF1, 0x65,
+0x12, 0xCE, 0x97, 0xF1, 0x39, 0xFB, 0xC3, 0x74,
+0xFF, 0x9B, 0xFF, 0x74, 0xFF, 0x9E, 0xFE, 0x74,
+0xFF, 0x94, 0x00, 0xFD, 0x74, 0xFF, 0x94, 0x00,
+0xFC, 0x90, 0x8D, 0x71, 0xF1, 0x77, 0x50, 0x11,
+0xF1, 0x39, 0xFF, 0xE4, 0xFC, 0xFD, 0x90, 0x8D,
+0x71, 0x12, 0x86, 0x61, 0x12, 0x86, 0x2C, 0x80,
+0x06, 0x74, 0xFF, 0xFF, 0xFE, 0xFD, 0xFC, 0x90,
+0x8D, 0x71, 0x12, 0x04, 0x31, 0xAF, 0x62, 0x12,
+0x78, 0x4A, 0xEF, 0x70, 0x02, 0xA1, 0x4B, 0x75,
+0xF0, 0x12, 0xE5, 0x62, 0x90, 0x89, 0x52, 0x12,
+0x04, 0x6E, 0x12, 0x8D, 0x34, 0x30, 0xE0, 0x02,
+0xA1, 0x4B, 0xE5, 0x62, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x12, 0x97, 0xD8, 0xE0, 0xFD, 0x7C, 0x00,
+0xE5, 0x62, 0x12, 0xB7, 0x93, 0x80, 0x05, 0xC3,
+0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEE,
+0x5C, 0xFE, 0xEF, 0x5D, 0x4E, 0x60, 0x02, 0xA1,
+0x4B, 0xE5, 0x69, 0x45, 0x68, 0x70, 0x0C, 0x90,
+0x95, 0x43, 0xE0, 0x70, 0x02, 0xA3, 0xE0, 0x70,
+0x02, 0xA1, 0x4B, 0x90, 0x96, 0x13, 0xE0, 0x60,
+0x11, 0x75, 0x6E, 0x0A, 0xD1, 0x09, 0xE4, 0x93,
+0xC3, 0x13, 0x74, 0x01, 0x93, 0x13, 0xF5, 0x6F,
+0x80, 0x0A, 0x7B, 0xFF, 0x12, 0xCC, 0x49, 0xE4,
+0xF5, 0x6E, 0xF5, 0x6F, 0x75, 0xF0, 0x12, 0xE5,
+0x62, 0x12, 0xCE, 0x70, 0xFF, 0xE5, 0x64, 0xD3,
+0x9F, 0x40, 0x08, 0x8F, 0x64, 0xE5, 0x64, 0x45,
+0x65, 0xF5, 0x63, 0xB1, 0x51, 0xE0, 0xC3, 0x94,
+0x05, 0x40, 0x02, 0x61, 0x49, 0xE5, 0x64, 0x90,
+0x81, 0x61, 0x93, 0xF5, 0x6A, 0xFD, 0xAF, 0x64,
+0x12, 0x60, 0x6F, 0x8F, 0x6A, 0xE5, 0x65, 0x60,
+0x04, 0x05, 0x6A, 0x05, 0x6A, 0xE5, 0x64, 0xC3,
+0x94, 0x0C, 0x40, 0x1D, 0x74, 0x15, 0x25, 0x62,
+0x12, 0x87, 0xAD, 0xE0, 0xFF, 0x54, 0x7F, 0xFE,
+0xEF, 0x30, 0xE7, 0x06, 0xE5, 0x6A, 0x2E, 0xFF,
+0x80, 0x05, 0xC3, 0xE5, 0x6A, 0x9E, 0xFF, 0x8F,
+0x6A, 0xE5, 0x6A, 0xD3, 0x94, 0x1A, 0xAF, 0x6A,
+0x40, 0x02, 0x7F, 0x1A, 0x8F, 0x6A, 0xE5, 0x63,
+0x90, 0x81, 0xD9, 0x93, 0xFF, 0xD3, 0x90, 0x95,
+0x44, 0xE0, 0x9F, 0x90, 0x95, 0x43, 0xE0, 0x94,
+0x00, 0x40, 0x02, 0x61, 0x02, 0xC3, 0xE5, 0x69,
+0x94, 0x0A, 0xE5, 0x68, 0x94, 0x00, 0x50, 0x7C,
+0x12, 0xCC, 0x53, 0xE0, 0xC3, 0x94, 0x01, 0x40,
+0x06, 0x12, 0xCC, 0x53, 0xE0, 0x14, 0xF0, 0x12,
+0xBF, 0xE9, 0xB1, 0xE3, 0xFF, 0x90, 0x95, 0x44,
+0xE0, 0x2F, 0xFF, 0x90, 0x95, 0x43, 0xE0, 0xB1,
+0xE9, 0x2F, 0xFD, 0xEE, 0x35, 0xF0, 0xFC, 0xE5,
+0x68, 0xC3, 0x13, 0xFE, 0xE5, 0x69, 0x13, 0xFF,
+0xD3, 0xED, 0x9F, 0xEC, 0x9E, 0x40, 0x0E, 0xE5,
+0x62, 0x94, 0x05, 0x50, 0x06, 0x12, 0xCC, 0x53,
+0x74, 0x02, 0xF0, 0x61, 0x02, 0x12, 0xBF, 0xE9,
 0x12, 0x03, 0x13, 0x65, 0x6C, 0x70, 0x02, 0xE5,
 0xF0, 0x70, 0x25, 0xE5, 0x62, 0xC3, 0x94, 0x05,
-0x50, 0x12, 0x12, 0xB1, 0x5A, 0xE0, 0xD3, 0x94,
+0x50, 0x12, 0x12, 0xCC, 0x53, 0xE0, 0xD3, 0x94,
 0x00, 0x40, 0x09, 0x7D, 0x06, 0xAF, 0x62, 0x12,
-0xB7, 0x4E, 0xC1, 0x31, 0xE4, 0xFD, 0xAF, 0x62,
-0x12, 0x90, 0xF8, 0x12, 0xB7, 0x4A, 0xC1, 0x16,
-0xF1, 0xAA, 0xC1, 0x16, 0x12, 0xB1, 0x5A, 0xE4,
+0xBB, 0x07, 0xA1, 0x4B, 0xE4, 0xFD, 0xAF, 0x62,
+0x12, 0xCD, 0x9B, 0x12, 0xBB, 0x03, 0xA1, 0x30,
+0xF1, 0x0B, 0xA1, 0x30, 0x12, 0xCC, 0x53, 0xE4,
 0xF0, 0x90, 0x91, 0x6C, 0x74, 0x02, 0xF0, 0xAB,
 0x6A, 0xAD, 0x62, 0xAF, 0x69, 0xAE, 0x68, 0x12,
-0x41, 0x9C, 0x8E, 0x66, 0x8F, 0x67, 0xD1, 0xB7,
+0x41, 0x9C, 0x8E, 0x66, 0x8F, 0x67, 0xD1, 0x09,
 0xC3, 0x74, 0x01, 0x93, 0x95, 0x6F, 0xFF, 0xE4,
 0x93, 0x94, 0x00, 0xFE, 0xD3, 0xE5, 0x67, 0x9F,
-0xE5, 0x66, 0x9E, 0x40, 0x0D, 0xD1, 0x55, 0xE4,
-0xF0, 0x7D, 0x01, 0xAF, 0x62, 0x12, 0x90, 0xF8,
-0xC1, 0x16, 0xF1, 0xD0, 0xC3, 0xE5, 0x67, 0x9F,
-0xE5, 0x66, 0x94, 0x00, 0x50, 0x0D, 0xD1, 0x55,
-0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x62, 0x12, 0xC6,
-0xBF, 0xC1, 0x16, 0x12, 0xB7, 0x4A, 0xD1, 0x55,
+0xE5, 0x66, 0x9E, 0x40, 0x0D, 0xB1, 0x69, 0xE4,
+0xF0, 0x7D, 0x01, 0xAF, 0x62, 0x12, 0xCD, 0x9B,
+0xA1, 0x30, 0xF1, 0x31, 0xC3, 0xE5, 0x67, 0x9F,
+0xE5, 0x66, 0x94, 0x00, 0x50, 0x0D, 0xB1, 0x69,
+0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x62, 0x12, 0xCC,
+0xDF, 0xA1, 0x30, 0x12, 0xBB, 0x03, 0xB1, 0x69,
 0xE0, 0x04, 0xF0, 0xE5, 0x64, 0x90, 0x81, 0xED,
-0x93, 0x25, 0x6E, 0xFF, 0xE4, 0x33, 0xFE, 0xD1,
-0x55, 0xE0, 0xC3, 0x9F, 0xEE, 0xD1, 0xA4, 0x50,
-0x02, 0xC1, 0x16, 0xD1, 0x55, 0xE4, 0xF0, 0xF1,
-0xD0, 0xD1, 0xB7, 0x74, 0x01, 0x93, 0x2F, 0xFF,
+0x93, 0x25, 0x6E, 0xFF, 0xE4, 0x33, 0xFE, 0xB1,
+0x69, 0xE0, 0xC3, 0x9F, 0xEE, 0xB1, 0xF6, 0x50,
+0x02, 0xA1, 0x30, 0xB1, 0x69, 0xE4, 0xF0, 0xF1,
+0x31, 0xD1, 0x09, 0x74, 0x01, 0x93, 0x2F, 0xFF,
 0xE4, 0x93, 0x34, 0x00, 0xC3, 0x13, 0xFE, 0xEF,
-0x13, 0xFF, 0xE5, 0x62, 0x12, 0x91, 0xD3, 0xC1,
-0x16, 0xD1, 0x3D, 0xE0, 0x64, 0x05, 0x60, 0x02,
-0x81, 0xF2, 0x90, 0x04, 0xA0, 0xE0, 0x64, 0x02,
-0x70, 0x10, 0xD1, 0x61, 0xE4, 0xF0, 0x90, 0x04,
-0xA1, 0xE0, 0x78, 0x88, 0xF6, 0x12, 0xC5, 0xD6,
-0xC1, 0x2A, 0xAD, 0x64, 0xAF, 0x62, 0x12, 0x72,
-0xEE, 0x12, 0xDD, 0x1F, 0xF5, 0x83, 0xEF, 0xF0,
-0x12, 0x93, 0xED, 0xE0, 0x54, 0x07, 0x78, 0x88,
-0xF6, 0x12, 0xC6, 0x3F, 0xFF, 0xC3, 0x94, 0x30,
-0x40, 0x1F, 0x75, 0xF0, 0x12, 0xE5, 0x62, 0x12,
-0x94, 0xEE, 0xFE, 0xC4, 0x13, 0x13, 0x54, 0x03,
-0x20, 0xE0, 0x0E, 0x12, 0xDD, 0x1F, 0xF5, 0x83,
-0xE0, 0x60, 0x06, 0x90, 0x96, 0x0B, 0xE0, 0x60,
-0x0A, 0xE4, 0x78, 0x88, 0xF6, 0xD1, 0x61, 0xE4,
-0xF0, 0x80, 0x5D, 0x12, 0xDD, 0x15, 0xF5, 0x83,
-0xE0, 0xFE, 0x24, 0x05, 0xFD, 0xE4, 0x33, 0xFC,
-0xEF, 0xD1, 0xA1, 0x50, 0x1F, 0x12, 0xC6, 0x3F,
-0x24, 0x05, 0xFD, 0xE4, 0x33, 0xFC, 0xEE, 0xD1,
-0xA1, 0x50, 0x11, 0x12, 0xDD, 0x0B, 0xF5, 0x83,
-0xE0, 0xB5, 0x64, 0x08, 0xD1, 0x6E, 0xE0, 0xC3,
-0x94, 0x0A, 0x40, 0x27, 0x78, 0x88, 0xE6, 0xFF,
-0x70, 0x04, 0x76, 0x01, 0x80, 0x0C, 0xEF, 0x78,
-0x88, 0xB4, 0x01, 0x04, 0x76, 0x03, 0x80, 0x02,
-0x76, 0x05, 0xD1, 0x6E, 0xE4, 0xF0, 0x12, 0xC6,
-0x3F, 0xFF, 0x12, 0xDD, 0x15, 0xF5, 0x83, 0xEF,
-0xF0, 0x80, 0x05, 0xD1, 0x61, 0xE0, 0x04, 0xF0,
-0x12, 0xDD, 0x0B, 0xF5, 0x83, 0xE5, 0x64, 0xF0,
-0xC1, 0x11, 0xD1, 0x3D, 0xE0, 0x64, 0x06, 0x60,
-0x02, 0xC1, 0x16, 0xF5, 0x66, 0xF5, 0x67, 0x12,
-0x93, 0xED, 0xE0, 0x54, 0x07, 0x78, 0x88, 0xF6,
-0xD3, 0xE5, 0x69, 0x94, 0xE8, 0xE5, 0x68, 0x94,
-0x03, 0x40, 0x06, 0x78, 0x86, 0x76, 0x05, 0x80,
-0x15, 0xD3, 0xE5, 0x69, 0x94, 0xFA, 0xE5, 0x68,
-0x94, 0x00, 0x40, 0x06, 0x78, 0x86, 0x76, 0x02,
-0x80, 0x04, 0xE4, 0x78, 0x86, 0xF6, 0xE5, 0x69,
-0xAE, 0x68, 0x78, 0x86, 0x86, 0x00, 0x08, 0x80,
-0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9,
-0xFF, 0x90, 0x82, 0x06, 0xE4, 0xF1, 0xB1, 0x90,
-0x95, 0x45, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4,
-0x78, 0x87, 0xF6, 0xD1, 0x37, 0x78, 0x87, 0xE6,
-0xFD, 0x12, 0xDC, 0xF8, 0xAE, 0xF0, 0x78, 0x86,
-0x86, 0x00, 0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13,
-0xCE, 0x13, 0xD8, 0xF9, 0xFF, 0xED, 0x90, 0x82,
-0x01, 0xF1, 0xB1, 0xEF, 0x25, 0x67, 0xF5, 0x67,
-0xEE, 0x35, 0x66, 0xF5, 0x66, 0xC3, 0x90, 0x95,
-0x46, 0xE0, 0x95, 0x67, 0x90, 0x95, 0x45, 0xE0,
-0x95, 0x66, 0x40, 0x07, 0x78, 0x87, 0x06, 0xE6,
-0xB4, 0x05, 0xC0, 0x78, 0x87, 0xE6, 0xC3, 0x13,
-0xF6, 0xFD, 0x08, 0xE6, 0x24, 0x01, 0xFF, 0xE4,
-0x33, 0xA2, 0xE7, 0x13, 0xEF, 0x13, 0x08, 0xF6,
-0xD3, 0x9D, 0x40, 0x07, 0xE6, 0x79, 0x87, 0x97,
-0xF6, 0x80, 0x04, 0xE4, 0x78, 0x89, 0xF6, 0xD1,
-0x49, 0xE0, 0xC3, 0x13, 0xFF, 0x78, 0x89, 0xE6,
-0xC4, 0x33, 0x54, 0xE0, 0x2F, 0xFF, 0xD1, 0x49,
-0xEF, 0xF0, 0xD1, 0x49, 0xE0, 0xC3, 0x94, 0xC0,
-0x40, 0x05, 0xD1, 0x49, 0x74, 0xC0, 0xF0, 0xD1,
-0x49, 0xE0, 0x24, 0x1F, 0xFF, 0xE4, 0x33, 0xFE,
-0xEF, 0x78, 0x06, 0xCE, 0xA2, 0xE7, 0x13, 0xCE,
-0x13, 0xD8, 0xF8, 0x78, 0x89, 0xF6, 0xE6, 0x25,
-0xE0, 0xF6, 0x70, 0x03, 0xFF, 0x80, 0x05, 0x78,
-0x89, 0xE6, 0x14, 0xFF, 0x78, 0x88, 0xA6, 0x07,
-0xD3, 0x90, 0x95, 0x3D, 0xE0, 0x94, 0x03, 0x90,
-0x95, 0x3C, 0xE0, 0x94, 0x00, 0x40, 0x02, 0xE4,
-0xF6, 0x78, 0x88, 0x12, 0xC5, 0xD6, 0xD1, 0x3D,
-0xE0, 0xFF, 0xD3, 0x94, 0x05, 0x50, 0x05, 0xEF,
-0x04, 0xFF, 0x80, 0x02, 0x7F, 0x00, 0xD1, 0x3D,
-0xEF, 0xF0, 0xE4, 0xF5, 0x66, 0xF5, 0x67, 0xF1,
-0xAA, 0x05, 0x62, 0x02, 0xC7, 0xC3, 0x22, 0x90,
-0x95, 0x39, 0x02, 0x86, 0x6D, 0x74, 0x76, 0x25,
+0x13, 0xFF, 0xE5, 0x62, 0x12, 0xCE, 0x8E, 0xA1,
+0x30, 0xB1, 0x51, 0xE0, 0x64, 0x05, 0x60, 0x02,
+0x81, 0x0A, 0x90, 0x04, 0xA0, 0xE0, 0x64, 0x02,
+0x70, 0x10, 0xB1, 0x75, 0xE4, 0xF0, 0x90, 0x04,
+0xA1, 0xE0, 0x78, 0x88, 0xF6, 0x12, 0xCB, 0xB9,
+0xA1, 0x44, 0xAD, 0x64, 0xAF, 0x62, 0x12, 0x72,
+0xEE, 0xF1, 0x59, 0xEF, 0xF0, 0xE5, 0x62, 0x12,
+0x96, 0xF3, 0xE0, 0x54, 0x07, 0x78, 0x88, 0xF6,
+0x12, 0x87, 0xC2, 0xFF, 0xC3, 0x94, 0x30, 0x40,
+0x1C, 0x75, 0xF0, 0x12, 0xE5, 0x62, 0x12, 0x87,
+0xBA, 0xFE, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x20,
+0xE0, 0x0B, 0xF1, 0x59, 0xE0, 0x60, 0x06, 0x90,
+0x96, 0x13, 0xE0, 0x60, 0x0A, 0xE4, 0x78, 0x88,
+0xF6, 0xB1, 0x75, 0xE4, 0xF0, 0x80, 0x54, 0xF1,
+0x4D, 0xE0, 0xFE, 0x24, 0x05, 0xFD, 0xE4, 0x33,
+0xFC, 0xEF, 0xB1, 0xF3, 0x50, 0x1C, 0x12, 0x87,
+0xC2, 0x24, 0x05, 0xFD, 0xE4, 0x33, 0xFC, 0xEE,
+0xB1, 0xF3, 0x50, 0x0E, 0xF1, 0x41, 0xE0, 0xB5,
+0x64, 0x08, 0xB1, 0x82, 0xE0, 0xC3, 0x94, 0x0A,
+0x40, 0x24, 0x78, 0x88, 0xE6, 0xFF, 0x70, 0x04,
+0x76, 0x01, 0x80, 0x0C, 0xEF, 0x78, 0x88, 0xB4,
+0x01, 0x04, 0x76, 0x03, 0x80, 0x02, 0x76, 0x05,
+0xB1, 0x82, 0xE4, 0xF0, 0x12, 0x87, 0xC2, 0xFF,
+0xF1, 0x4D, 0xEF, 0xF0, 0x80, 0x05, 0xB1, 0x75,
+0xE0, 0x04, 0xF0, 0xF1, 0x41, 0xE5, 0x64, 0xF0,
+0xA1, 0x2B, 0xB1, 0x51, 0xE0, 0x64, 0x06, 0x60,
+0x02, 0xA1, 0x30, 0xF5, 0x66, 0xF5, 0x67, 0xE5,
+0x62, 0x12, 0x96, 0xF3, 0xE0, 0x54, 0x07, 0x78,
+0x88, 0xF6, 0xD3, 0xE5, 0x69, 0x94, 0xE8, 0xE5,
+0x68, 0x94, 0x03, 0x40, 0x06, 0x78, 0x86, 0x76,
+0x05, 0x80, 0x15, 0xD3, 0xE5, 0x69, 0x94, 0xFA,
+0xE5, 0x68, 0x94, 0x00, 0x40, 0x06, 0x78, 0x86,
+0x76, 0x02, 0x80, 0x04, 0xE4, 0x78, 0x86, 0xF6,
+0xE5, 0x69, 0xAE, 0x68, 0x78, 0x86, 0x86, 0x00,
+0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
+0xD8, 0xF9, 0xFF, 0x90, 0x82, 0x06, 0xE4, 0xF1,
+0x12, 0x90, 0x95, 0x4C, 0xEE, 0xF0, 0xA3, 0xEF,
+0xF0, 0xE4, 0x78, 0x87, 0xF6, 0x12, 0xBF, 0xE9,
+0x78, 0x87, 0xE6, 0xFD, 0xF1, 0x86, 0xAE, 0xF0,
+0x78, 0x86, 0x86, 0x00, 0x08, 0x80, 0x05, 0xCE,
+0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xFF, 0xED,
+0x90, 0x82, 0x01, 0xF1, 0x12, 0xEF, 0x25, 0x67,
+0xF5, 0x67, 0xEE, 0x35, 0x66, 0xF5, 0x66, 0xC3,
+0x90, 0x95, 0x4D, 0xE0, 0x95, 0x67, 0x90, 0x95,
+0x4C, 0xE0, 0x95, 0x66, 0x40, 0x07, 0x78, 0x87,
+0x06, 0xE6, 0xB4, 0x05, 0xC0, 0x78, 0x87, 0xE6,
+0xC3, 0x13, 0xF6, 0xFD, 0x08, 0xE6, 0x24, 0x01,
+0xFF, 0xE4, 0x33, 0xA2, 0xE7, 0x13, 0xEF, 0x13,
+0x08, 0xF6, 0xD3, 0x9D, 0x40, 0x07, 0xE6, 0x79,
+0x87, 0x97, 0xF6, 0x80, 0x04, 0xE4, 0x78, 0x89,
+0xF6, 0xB1, 0x5D, 0xE0, 0xC3, 0x13, 0xFF, 0x78,
+0x89, 0xE6, 0xC4, 0x33, 0x54, 0xE0, 0x2F, 0xFF,
+0xB1, 0x5D, 0xEF, 0xF0, 0xB1, 0x5D, 0xE0, 0xC3,
+0x94, 0xC0, 0x40, 0x05, 0xB1, 0x5D, 0x74, 0xC0,
+0xF0, 0xB1, 0x5D, 0xE0, 0x24, 0x1F, 0xFF, 0xE4,
+0x33, 0xFE, 0xEF, 0x78, 0x06, 0xCE, 0xA2, 0xE7,
+0x13, 0xCE, 0x13, 0xD8, 0xF8, 0x78, 0x89, 0xF6,
+0xE6, 0x25, 0xE0, 0xF6, 0x70, 0x03, 0xFF, 0x80,
+0x05, 0x78, 0x89, 0xE6, 0x14, 0xFF, 0x78, 0x88,
+0xA6, 0x07, 0xD3, 0x90, 0x95, 0x44, 0xE0, 0x94,
+0x03, 0x90, 0x95, 0x43, 0xE0, 0x94, 0x00, 0x40,
+0x02, 0xE4, 0xF6, 0x78, 0x88, 0x12, 0xCB, 0xB9,
+0xB1, 0x51, 0xE0, 0xFF, 0xD3, 0x94, 0x05, 0x50,
+0x05, 0xEF, 0x04, 0xFF, 0x80, 0x02, 0x7F, 0x00,
+0xB1, 0x51, 0xEF, 0xF0, 0xE4, 0xF5, 0x66, 0xF5,
+0x67, 0xF1, 0x0B, 0x05, 0x62, 0x02, 0xCE, 0xF4,
+0x22, 0x74, 0x76, 0x25, 0x62, 0xF5, 0x82, 0xE4,
+0x34, 0x8E, 0xF5, 0x83, 0x22, 0x74, 0x4F, 0x25,
+0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83,
+0x22, 0x74, 0xA6, 0x25, 0x62, 0xF5, 0x82, 0xE4,
+0x34, 0x8D, 0xF5, 0x83, 0x22, 0x74, 0x76, 0x25,
 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
-0x22, 0x74, 0x4F, 0x25, 0x62, 0xF5, 0x82, 0xE4,
-0x34, 0x8D, 0xF5, 0x83, 0x22, 0x74, 0xA6, 0x25,
+0xE4, 0xF0, 0x74, 0xF6, 0x25, 0x62, 0xF5, 0x82,
+0xE4, 0x34, 0x8D, 0xF5, 0x83, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0xFD,
+0xEF, 0xF0, 0x90, 0x00, 0x8F, 0xE0, 0x30, 0xE6,
+0x3D, 0x90, 0x00, 0x8D, 0xE0, 0x64, 0x01, 0x70,
+0x35, 0x90, 0x96, 0xFE, 0xF0, 0x90, 0x96, 0xFE,
+0xE0, 0xFD, 0x90, 0x96, 0xFD, 0xE0, 0x12, 0x94,
+0xDD, 0xE5, 0x82, 0x2D, 0x12, 0xB6, 0x93, 0xE0,
+0xFB, 0xE4, 0xFF, 0x12, 0x8E, 0x70, 0x90, 0x96,
+0xFE, 0xE0, 0x04, 0xF0, 0xE0, 0xC3, 0x94, 0x10,
+0x40, 0xDB, 0x90, 0x00, 0x8F, 0xE0, 0x30, 0xE0,
+0x05, 0x90, 0x00, 0x8D, 0xE4, 0xF0, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x00, 0x08, 0x02, 0x03,
+0x3E, 0x35, 0xF0, 0xFE, 0x90, 0x00, 0x06, 0x02,
+0x03, 0x3E, 0xE0, 0xD3, 0x9D, 0xEC, 0x64, 0x80,
+0xF8, 0x74, 0x80, 0x98, 0x22, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0xED, 0x2F, 0xFF, 0xEC, 0x3E, 0xFE,
+0x22, 0xE5, 0x64, 0x25, 0xE0, 0x24, 0x75, 0xF5,
+0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0xC3, 0x74, 0xFF, 0x9F,
+0xFF, 0x74, 0xFF, 0x9E, 0xFE, 0xE5, 0x62, 0x25,
+0xE0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0xF1, 0x92, 0x90, 0x97, 0x0D, 0xF0, 0x90,
+0x88, 0x32, 0x12, 0x8D, 0x34, 0x30, 0xE0, 0x02,
+0xC1, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0x30, 0xE0,
+0x1F, 0x90, 0x88, 0x53, 0xE0, 0x24, 0x04, 0x33,
+0x33, 0x33, 0x54, 0xF8, 0x90, 0x88, 0x4B, 0xF0,
+0x90, 0x88, 0x53, 0xE0, 0x04, 0x33, 0x33, 0x33,
+0x54, 0xF8, 0x90, 0x88, 0x4A, 0xF0, 0x80, 0x10,
+0x90, 0x88, 0x4B, 0x74, 0x10, 0xF0, 0x90, 0x88,
+0x4A, 0x74, 0x08, 0xF0, 0x74, 0x10, 0x2B, 0xFB,
+0x90, 0x88, 0x4A, 0xE0, 0xFE, 0x90, 0x88, 0x49,
+0xE0, 0xD3, 0x9E, 0x50, 0x0E, 0x90, 0x88, 0x3E,
+0xEB, 0xF0, 0x90, 0x88, 0x4B, 0xE0, 0xC3, 0x9D,
+0x2F, 0x80, 0x11, 0xC3, 0xED, 0x9E, 0x2B, 0x90,
+0x88, 0x3E, 0xF0, 0x90, 0x88, 0x4A, 0xE0, 0xFF,
+0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x88, 0x4E, 0xF0,
+0x90, 0x88, 0x4B, 0xD1, 0xFC, 0x90, 0x88, 0x4E,
+0xB1, 0xF2, 0x40, 0x04, 0xEF, 0x24, 0x50, 0xF0,
+0x90, 0x88, 0x4E, 0xD1, 0xFC, 0x90, 0x88, 0x3E,
+0xB1, 0xF2, 0x40, 0x04, 0xEF, 0x24, 0x50, 0xF0,
+0x90, 0x88, 0x4E, 0x12, 0xAE, 0x23, 0xFF, 0x7E,
+0x00, 0x90, 0x88, 0x42, 0xEE, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0x05, 0x58, 0xF0, 0x90, 0x88, 0x4E,
+0xE0, 0x54, 0x07, 0xFF, 0x90, 0x05, 0xB1, 0xE0,
+0x54, 0xF8, 0x4F, 0xF0, 0xF1, 0x7E, 0x80, 0x07,
+0x90, 0x88, 0x33, 0xE0, 0x44, 0x01, 0xF0, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0xE0, 0xFF, 0x24, 0x50,
+0xFD, 0xE4, 0x33, 0xFC, 0x22, 0x90, 0x00, 0x04,
+0x02, 0x03, 0x3E, 0x7D, 0x01, 0xAF, 0x62, 0x02,
+0x61, 0xF7, 0x93, 0xFD, 0x7C, 0x00, 0x02, 0x02,
+0x80, 0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
+0x22, 0x24, 0x26, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
+0x22, 0x24, 0x56, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
+0x22, 0xE5, 0x64, 0x90, 0x81, 0x9D, 0x93, 0xFF,
+0x22, 0x90, 0x95, 0x47, 0xE0, 0xFE, 0xA3, 0xE0,
+0x22, 0x74, 0xA6, 0x25, 0x62, 0xF5, 0x82, 0xE4,
+0x34, 0x8E, 0xF5, 0x83, 0x22, 0x74, 0x5F, 0x25,
+0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83,
+0x22, 0x74, 0xE6, 0x25, 0x62, 0xF5, 0x82, 0xE4,
+0x34, 0x8D, 0xF5, 0x83, 0x22, 0xE5, 0x62, 0x25,
+0xE0, 0x24, 0x86, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
+0x22, 0x90, 0x00, 0x02, 0x02, 0x03, 0x3E, 0x12,
+0x86, 0x61, 0xD3, 0x02, 0x03, 0xDA, 0x90, 0x88,
+0x33, 0xE0, 0x54, 0xFE, 0xF0, 0x22, 0x75, 0xF0,
+0x02, 0xA4, 0xF5, 0x82, 0x85, 0xF0, 0x83, 0x02,
+0x03, 0x3E, 0x90, 0x86, 0xAD, 0xA3, 0xE0, 0x24,
+0x7F, 0xF5, 0x82, 0xE4, 0x34, 0x84, 0xF5, 0x83,
+0xE0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0xF1, 0x92, 0x90, 0x97, 0x08, 0xF0, 0xED,
+0x90, 0x00, 0x73, 0x70, 0x0D, 0xE0, 0x44, 0x04,
+0xF0, 0x90, 0x00, 0x67, 0xE0, 0x44, 0x80, 0xF0,
+0x80, 0x0B, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x00,
+0x67, 0xE0, 0x54, 0x7F, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x93, 0x58, 0xE0, 0x54, 0x7F,
+0xF0, 0x54, 0xBF, 0xF0, 0x54, 0xDF, 0xF0, 0x54,
+0xF0, 0xF0, 0xE4, 0x90, 0x93, 0x5A, 0xF0, 0x90,
+0x93, 0x58, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0x90,
+0x95, 0xF2, 0xF0, 0x90, 0x95, 0xF0, 0x74, 0x14,
+0xF0, 0x90, 0x96, 0x12, 0x74, 0x01, 0xF0, 0xFB,
+0x7A, 0x95, 0x79, 0xF0, 0x12, 0x8A, 0x4D, 0x7F,
+0x04, 0x12, 0x04, 0x7E, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x01, 0x94, 0xE0, 0x44, 0x01, 0xF0,
+0x90, 0x01, 0xC7, 0xE4, 0xF0, 0x22, 0x90, 0x01,
+0x95, 0xE0, 0x7F, 0x00, 0x30, 0xE4, 0x02, 0x7F,
+0x01, 0x22, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
+0x88, 0xB8, 0xE0, 0x54, 0xFE, 0xF0, 0x54, 0xE1,
+0xF0, 0x90, 0x88, 0xBD, 0xE0, 0xFF, 0x12, 0x71,
+0x9A, 0x90, 0x88, 0x36, 0xE0, 0x70, 0x0C, 0x12,
+0x8E, 0xAA, 0x90, 0x8A, 0xF9, 0x12, 0x8A, 0x5F,
+0x12, 0x97, 0xF1, 0x22, 0x90, 0x88, 0x9D, 0xE0,
+0x30, 0xE0, 0x5E, 0x90, 0x94, 0xA3, 0xE0, 0x30,
+0xE0, 0x3D, 0x90, 0x94, 0xAE, 0xE0, 0xFF, 0x90,
+0x94, 0xAD, 0xE0, 0xC3, 0x9F, 0x40, 0x24, 0x11,
+0xCC, 0x90, 0x06, 0xC4, 0x11, 0xCA, 0x78, 0x08,
+0x12, 0x03, 0xEB, 0x90, 0x06, 0xC5, 0x11, 0xCA,
+0x78, 0x10, 0x12, 0x03, 0xEB, 0x90, 0x06, 0xC6,
+0x11, 0xCA, 0x11, 0xD2, 0xE4, 0x90, 0x94, 0xAD,
+0xF0, 0x80, 0x1B, 0x11, 0xDD, 0x11, 0xD2, 0x90,
+0x94, 0xAD, 0xE0, 0x04, 0xF0, 0x80, 0x0F, 0x90,
+0x94, 0xAC, 0xE0, 0x60, 0x09, 0x11, 0xDD, 0x11,
+0xD2, 0xE4, 0x90, 0x94, 0xAC, 0xF0, 0x90, 0x8A,
+0xBB, 0x12, 0x8A, 0x5F, 0xE4, 0xFF, 0x12, 0x04,
+0x7E, 0x22, 0xEF, 0xF0, 0x90, 0x94, 0xA4, 0x02,
+0x04, 0xB8, 0x78, 0x18, 0x12, 0x03, 0xEB, 0x90,
+0x06, 0xC7, 0xEF, 0xF0, 0x22, 0x90, 0x94, 0xA8,
+0x12, 0x04, 0xB8, 0x90, 0x06, 0xC4, 0xEF, 0xF0,
+0x90, 0x94, 0xA8, 0x12, 0x04, 0xB8, 0x78, 0x08,
+0x12, 0x03, 0xEB, 0x90, 0x06, 0xC5, 0xEF, 0xF0,
+0x90, 0x94, 0xA8, 0x12, 0x04, 0xB8, 0x78, 0x10,
+0x12, 0x03, 0xEB, 0x90, 0x06, 0xC6, 0xEF, 0xF0,
+0x90, 0x94, 0xA8, 0x02, 0x04, 0xB8, 0x7E, 0x00,
+0x7F, 0x33, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x88,
+0x79, 0x9D, 0x12, 0x04, 0x80, 0x90, 0x88, 0x9E,
+0x74, 0x0B, 0xF0, 0xA3, 0x74, 0x08, 0x51, 0x1C,
+0x7A, 0x94, 0x79, 0xA3, 0x12, 0x04, 0x80, 0x90,
+0x86, 0xB3, 0xE0, 0xFC, 0x64, 0x02, 0x70, 0x15,
+0x51, 0x15, 0x30, 0xE2, 0x02, 0x7E, 0x01, 0xEE,
+0x12, 0xB6, 0x85, 0xFE, 0x90, 0x88, 0xA0, 0xE0,
+0x54, 0xBF, 0x4E, 0xF0, 0x22, 0xEC, 0x64, 0x01,
+0x70, 0x09, 0x51, 0x0C, 0x30, 0xE2, 0x02, 0x7F,
+0x01, 0x80, 0x0F, 0x90, 0x86, 0xB3, 0xE0, 0x64,
+0x03, 0x70, 0x14, 0x31, 0x7A, 0x30, 0xE2, 0x02,
+0x7F, 0x01, 0xEF, 0x12, 0xB6, 0x85, 0xFF, 0x90,
+0x88, 0xA0, 0xE0, 0x54, 0xBF, 0x4F, 0xF0, 0x22,
+0xEF, 0xF0, 0x90, 0xFD, 0x78, 0xE0, 0x7F, 0x00,
+0x22, 0x90, 0x93, 0x2A, 0x12, 0xB7, 0xBC, 0x54,
+0xEF, 0xF0, 0x44, 0x08, 0xF0, 0x90, 0x86, 0xB3,
+0xE0, 0xFF, 0x64, 0x02, 0x70, 0x29, 0x51, 0x15,
+0x30, 0xE0, 0x02, 0x7E, 0x01, 0x90, 0x93, 0x30,
+0x51, 0x13, 0x30, 0xE1, 0x02, 0x7E, 0x01, 0x90,
+0x93, 0x2E, 0x51, 0x13, 0x30, 0xE2, 0x02, 0x7E,
+0x01, 0x90, 0x93, 0x2F, 0xEE, 0xF0, 0x90, 0xFD,
+0x80, 0xE0, 0x90, 0x02, 0xFB, 0xF0, 0x22, 0xEF,
+0x64, 0x01, 0x70, 0x1D, 0x51, 0x0C, 0x30, 0xE0,
+0x02, 0x7F, 0x01, 0x90, 0x93, 0x30, 0x51, 0x0A,
+0x30, 0xE1, 0x02, 0x7F, 0x01, 0x90, 0x93, 0x2E,
+0x51, 0x0A, 0x30, 0xE2, 0x02, 0x7F, 0x01, 0x80,
+0x23, 0x90, 0x86, 0xB3, 0xE0, 0x64, 0x03, 0x70,
+0x20, 0x31, 0x7A, 0x30, 0xE0, 0x02, 0x7F, 0x01,
+0x90, 0x93, 0x30, 0x31, 0x78, 0x30, 0xE1, 0x02,
+0x7F, 0x01, 0x90, 0x93, 0x2E, 0x31, 0x78, 0x30,
+0xE2, 0x02, 0x7F, 0x01, 0x90, 0x93, 0x2F, 0xEF,
+0xF0, 0x22, 0xEF, 0xF0, 0x90, 0xFD, 0x70, 0xE0,
+0x7F, 0x00, 0x22, 0xEE, 0xF0, 0x90, 0xFD, 0x80,
+0xE0, 0x7E, 0x00, 0x22, 0xF0, 0x7E, 0x00, 0x7F,
+0x18, 0x7D, 0x00, 0x7B, 0x01, 0x22, 0x7E, 0x00,
+0x7F, 0x62, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x88,
+0x79, 0x31, 0x12, 0x04, 0x80, 0xE4, 0x90, 0x94,
+0xA2, 0xF0, 0x90, 0x88, 0x35, 0x74, 0x02, 0xF0,
+0x90, 0x88, 0x3C, 0x14, 0xF0, 0xA3, 0xF0, 0xA3,
+0x74, 0x50, 0xF0, 0x90, 0x88, 0x42, 0xE4, 0xF0,
+0xA3, 0x74, 0x02, 0xF0, 0x90, 0x88, 0x4E, 0x74,
+0x10, 0xF0, 0xA3, 0x74, 0x50, 0xF0, 0x71, 0x09,
+0x90, 0x8A, 0x89, 0x12, 0x8A, 0x5F, 0x12, 0x97,
+0xF1, 0x90, 0x8A, 0x89, 0x12, 0x8A, 0x5F, 0x7D,
+0x0C, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x90, 0x8A,
+0x89, 0x12, 0x8A, 0x5F, 0x12, 0x8F, 0xCF, 0x90,
+0x86, 0xB3, 0xE0, 0xFF, 0xB4, 0x01, 0x08, 0x90,
+0x88, 0x41, 0x74, 0xDD, 0xF0, 0x80, 0x11, 0xEF,
+0xB4, 0x03, 0x08, 0x90, 0x88, 0x41, 0x74, 0x14,
+0xF0, 0x80, 0x05, 0xE4, 0x90, 0x88, 0x41, 0xF0,
+0x90, 0x00, 0x79, 0xE0, 0x54, 0x03, 0xFF, 0xBF,
+0x02, 0x0D, 0x90, 0x00, 0x28, 0xE0, 0x30, 0xE2,
+0x06, 0x90, 0x88, 0x53, 0x74, 0x02, 0xF0, 0x90,
+0x88, 0x93, 0x74, 0x02, 0xF0, 0xA3, 0x74, 0x0F,
+0xF0, 0xA3, 0xE0, 0x54, 0x01, 0x44, 0x28, 0xF0,
+0xA3, 0x74, 0x07, 0x51, 0x1C, 0x7A, 0x93, 0x79,
+0x32, 0x12, 0x04, 0x80, 0x90, 0x8A, 0xA3, 0x12,
+0x8A, 0x5F, 0x7F, 0x01, 0x12, 0x04, 0x7E, 0x7E,
+0x00, 0x7F, 0x02, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
+0x88, 0x79, 0x9A, 0x12, 0x04, 0x80, 0x71, 0x01,
+0x90, 0x06, 0x0A, 0xE0, 0x54, 0xF8, 0xF0, 0x90,
+0x05, 0x22, 0xE4, 0xF0, 0x90, 0x88, 0x9C, 0xF0,
+0x22, 0x90, 0x06, 0x04, 0xE0, 0x54, 0x7F, 0xF0,
+0x22, 0x90, 0x88, 0x8D, 0x74, 0x18, 0xF0, 0xA3,
+0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x64, 0xF0,
+0xA3, 0x74, 0x05, 0xF0, 0xA3, 0xF0, 0x22, 0x90,
+0x97, 0x09, 0xEF, 0xF0, 0x90, 0x88, 0xB8, 0xE0,
+0x44, 0x01, 0xF0, 0x90, 0x8A, 0xF9, 0x12, 0x8A,
+0x5F, 0x7D, 0x11, 0x71, 0x70, 0x12, 0x8E, 0xAD,
+0x90, 0x07, 0x78, 0xE0, 0x90, 0x88, 0xBD, 0xF0,
+0x90, 0x97, 0x09, 0xE0, 0xFD, 0x70, 0x02, 0x80,
+0x1C, 0xED, 0xB4, 0x01, 0x06, 0x71, 0x69, 0x44,
+0x20, 0xF0, 0x22, 0x90, 0x97, 0x09, 0xE0, 0xFD,
+0xB4, 0x02, 0x06, 0x71, 0x69, 0x44, 0x60, 0xF0,
+0x22, 0xED, 0xB4, 0x03, 0x03, 0x71, 0x69, 0xF0,
+0x22, 0x90, 0x88, 0xB8, 0xE0, 0x54, 0x1F, 0x22,
+0x7F, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0xEF,
+0x22, 0xEF, 0x64, 0x39, 0x70, 0x5D, 0x90, 0x01,
+0x63, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x10, 0xF0,
+0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x4C, 0x12,
+0xBF, 0x86, 0x30, 0xE0, 0x46, 0x90, 0x88, 0xC2,
+0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x3B,
+0x90, 0x94, 0xB5, 0xE0, 0x04, 0xF0, 0x71, 0xDC,
+0x30, 0xE0, 0x11, 0xEE, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x30, 0xE0, 0x08, 0xEF, 0x54, 0xEF, 0x90,
+0x88, 0xC2, 0xF0, 0x22, 0x90, 0x88, 0xB0, 0xE0,
+0x70, 0x19, 0x12, 0xBF, 0x94, 0x90, 0x88, 0x9D,
+0xE0, 0x30, 0xE0, 0x0F, 0x12, 0xBF, 0x86, 0x30,
+0xE0, 0x09, 0x90, 0x8A, 0xBB, 0x12, 0x8A, 0x5F,
+0x12, 0xBF, 0x8F, 0x22, 0x90, 0x94, 0xAF, 0xE0,
+0xFE, 0x13, 0x13, 0x54, 0x3F, 0x22, 0x90, 0x88,
+0x9D, 0xE0, 0x20, 0xE0, 0x02, 0x81, 0xAB, 0x90,
+0x8A, 0xB1, 0x12, 0x8E, 0xAD, 0x90, 0x88, 0xB0,
+0xE0, 0xFF, 0xB4, 0x01, 0x02, 0x80, 0x22, 0x90,
+0x88, 0xB0, 0xE0, 0xFF, 0xB4, 0x02, 0x05, 0x90,
+0x8A, 0xC1, 0x80, 0x18, 0x90, 0x88, 0xB0, 0xE0,
+0xFF, 0xB4, 0x03, 0x05, 0x90, 0x8A, 0xBB, 0x80,
+0x0B, 0x90, 0x88, 0xB0, 0xE0, 0xFF, 0xB4, 0x04,
+0x09, 0x90, 0x8A, 0xBD, 0x12, 0xA5, 0xDE, 0x02,
+0x04, 0x7E, 0x90, 0x88, 0xB0, 0xE0, 0xFF, 0x64,
+0x05, 0x70, 0x78, 0x90, 0x94, 0xB7, 0xE0, 0x20,
+0xE0, 0x66, 0x90, 0x88, 0x9D, 0xE0, 0xFE, 0xC4,
+0x54, 0x0F, 0x20, 0xE0, 0x0A, 0xEE, 0xC4, 0x13,
+0x54, 0x07, 0x30, 0xE0, 0x02, 0x80, 0x51, 0x91,
+0xB4, 0x70, 0x0E, 0x90, 0x01, 0x34, 0x74, 0x08,
+0xF0, 0xFD, 0xE4, 0xFF, 0x12, 0x7C, 0x74, 0x80,
+0x16, 0x90, 0x94, 0xB8, 0xE0, 0x60, 0x2B, 0x91,
+0xB4, 0xC3, 0x94, 0x05, 0x50, 0x24, 0xE4, 0xA3,
+0xF0, 0x90, 0x94, 0xBA, 0xE0, 0x04, 0xF0, 0x90,
+0x8A, 0xD1, 0x12, 0x8A, 0x5F, 0x7F, 0x05, 0x91,
+0xAC, 0xFF, 0xC3, 0x13, 0xFE, 0xEF, 0x54, 0x01,
+0xFF, 0xEE, 0x04, 0x54, 0x7F, 0x25, 0xE0, 0x4F,
+0xF0, 0x22, 0x12, 0x9F, 0xBF, 0x90, 0x01, 0x34,
+0x74, 0x08, 0xF0, 0x90, 0x88, 0xB0, 0xE0, 0xFF,
+0x90, 0x8A, 0xC1, 0x12, 0xA5, 0xDE, 0x91, 0xAC,
+0x54, 0x01, 0xF0, 0x22, 0x12, 0x04, 0x7E, 0x90,
+0x94, 0xB7, 0xE0, 0x22, 0x90, 0x94, 0xB7, 0xE0,
+0xC3, 0x13, 0x54, 0x7F, 0x22, 0x90, 0x96, 0xB1,
+0x12, 0x86, 0x76, 0x90, 0x96, 0xAD, 0x12, 0x86,
+0x6D, 0x90, 0x96, 0xB4, 0x12, 0x86, 0x76, 0x90,
+0x96, 0xB0, 0xE0, 0x24, 0xFF, 0xFF, 0xE4, 0x34,
+0xFF, 0xFE, 0x90, 0x96, 0xB2, 0x8F, 0xF0, 0x12,
+0x02, 0xE7, 0x90, 0x96, 0xB5, 0xEE, 0x8F, 0xF0,
+0x12, 0x02, 0xE7, 0x90, 0x96, 0xB0, 0xE0, 0xD3,
+0x94, 0x00, 0x40, 0x2E, 0x90, 0x96, 0xB4, 0x12,
+0x86, 0x6D, 0x12, 0x02, 0x06, 0xFF, 0x90, 0x96,
+0xB1, 0x12, 0x86, 0x6D, 0x12, 0x02, 0x06, 0xFE,
+0x6F, 0x60, 0x05, 0xC3, 0xEE, 0x9F, 0xFF, 0x22,
+0x90, 0x96, 0xB2, 0xB1, 0x25, 0x90, 0x96, 0xB5,
+0xB1, 0x25, 0x90, 0x96, 0xB0, 0xE0, 0x14, 0xF0,
+0x80, 0xC9, 0x7F, 0x00, 0x22, 0x74, 0xFF, 0xF5,
+0xF0, 0x02, 0x02, 0xE7, 0x7D, 0x07, 0xEF, 0x5D,
+0xC3, 0x60, 0x0A, 0xB1, 0x41, 0x24, 0x08, 0xFF,
+0xE4, 0x3E, 0xFE, 0x80, 0x03, 0xB1, 0x41, 0xFF,
+0x22, 0x74, 0xFF, 0x9D, 0xFD, 0x74, 0xFF, 0x94,
+0x00, 0x5E, 0xFE, 0xED, 0x5F, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88, 0x9D,
+0xE0, 0x30, 0xE0, 0x1E, 0x90, 0x88, 0xAF, 0xE0,
+0x60, 0x05, 0x75, 0x11, 0x40, 0xA1, 0xF8, 0x90,
+0x88, 0x38, 0xE0, 0xD3, 0x94, 0x00, 0x40, 0x02,
+0x80, 0x2D, 0x90, 0x88, 0x9C, 0xE0, 0x60, 0x7B,
+0x80, 0x55, 0x12, 0x7A, 0x65, 0xEF, 0x64, 0x01,
+0x60, 0x05, 0x75, 0x11, 0x01, 0x80, 0x71, 0x90,
+0x88, 0x3A, 0xE0, 0xFF, 0x54, 0x03, 0x60, 0x05,
+0x75, 0x11, 0x02, 0x80, 0x63, 0x90, 0x88, 0x38,
+0xE0, 0xFE, 0xE4, 0xC3, 0x9E, 0x50, 0x05, 0x75,
+0x11, 0x04, 0x80, 0x54, 0xEF, 0x30, 0xE2, 0x05,
+0x75, 0x11, 0x08, 0x80, 0x4B, 0x90, 0x88, 0x3A,
+0xE0, 0x30, 0xE4, 0x05, 0x75, 0x11, 0x10, 0x80,
+0x3F, 0x90, 0x88, 0x32, 0xE0, 0x13, 0x13, 0x54,
+0x3F, 0x20, 0xE0, 0x05, 0x75, 0x11, 0x20, 0x80,
+0x2F, 0x90, 0x88, 0x9C, 0xE0, 0x60, 0x05, 0x75,
+0x11, 0x80, 0x80, 0x24, 0x90, 0x06, 0x62, 0xE0,
+0x30, 0xE1, 0x05, 0x75, 0x11, 0x11, 0x80, 0x18,
+0x90, 0x06, 0x62, 0xE0, 0x30, 0xE0, 0x0C, 0xE0,
+0x54, 0xFC, 0xFF, 0xBF, 0x80, 0x05, 0x75, 0x11,
+0x12, 0x80, 0x05, 0x12, 0xC3, 0xA4, 0x80, 0x0E,
+0x90, 0x01, 0xB9, 0x74, 0x04, 0xF0, 0x90, 0x01,
+0xB8, 0xE5, 0x11, 0xF0, 0x7F, 0x00, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x97, 0x0C, 0xED, 0xF0, 0x90,
+0x88, 0x31, 0xE0, 0xFE, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x30, 0xE0, 0x02, 0xE1, 0x85, 0xEE, 0x12,
+0x8D, 0x35, 0x30, 0xE0, 0x02, 0xE1, 0x85, 0x90,
+0x88, 0x39, 0xE0, 0xFE, 0x6F, 0x70, 0x02, 0xE1,
+0x85, 0xEF, 0x70, 0x02, 0xC1, 0xDC, 0x24, 0xFE,
+0x70, 0x02, 0xE1, 0x24, 0x24, 0xFE, 0x60, 0x50,
+0x24, 0xFC, 0x70, 0x02, 0xE1, 0x6B, 0x24, 0xFC,
+0x60, 0x02, 0xE1, 0x7E, 0xEE, 0xB4, 0x0E, 0x03,
+0x12, 0x71, 0x5F, 0x90, 0x88, 0x39, 0xE0, 0x70,
+0x05, 0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90, 0x88,
+0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24,
+0x90, 0x88, 0x39, 0xE0, 0xB4, 0x04, 0x12, 0x90,
+0x97, 0x0C, 0xE0, 0xFF, 0x60, 0x05, 0x12, 0x67,
+0x80, 0x80, 0x06, 0x90, 0x8A, 0xED, 0x12, 0x8E,
+0xAD, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x08, 0x60,
+0x02, 0xE1, 0x7E, 0x12, 0x7B, 0xCC, 0xE1, 0x7E,
+0x90, 0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01,
+0x12, 0x78, 0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4,
+0x06, 0x03, 0x12, 0x71, 0x24, 0x90, 0x88, 0x39,
+0xE0, 0xB4, 0x0E, 0x0C, 0x90, 0x86, 0x00, 0x12,
+0x8E, 0xAD, 0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F,
+0x90, 0x88, 0x39, 0xE0, 0x64, 0x0C, 0x60, 0x02,
+0xE1, 0x7E, 0x90, 0x86, 0x00, 0x12, 0x8E, 0xAD,
+0xEF, 0x64, 0x01, 0x60, 0x02, 0xE1, 0x7E, 0x12,
+0x68, 0xC2, 0xE1, 0x7E, 0x90, 0x88, 0x39, 0xE0,
+0xB4, 0x0E, 0x0C, 0x90, 0x86, 0x00, 0x12, 0x8E,
+0xAD, 0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71,
+0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0C,
+0x90, 0x86, 0x00, 0x12, 0x8E, 0xAD, 0xBF, 0x01,
+0x03, 0x12, 0x68, 0xC2, 0x90, 0x88, 0x39, 0xE0,
+0x64, 0x04, 0x70, 0x6A, 0x90, 0x86, 0x02, 0x12,
+0x8E, 0xAD, 0xEF, 0x64, 0x01, 0x70, 0x5F, 0x12,
+0x73, 0x5A, 0x80, 0x5A, 0x90, 0x88, 0x39, 0xE0,
+0xB4, 0x0E, 0x0C, 0x90, 0x86, 0x00, 0x12, 0x8E,
+0xAD, 0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71,
+0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0C,
+0x90, 0x86, 0x00, 0x12, 0x8E, 0xAD, 0xBF, 0x01,
+0x03, 0x12, 0x68, 0xC2, 0x90, 0x88, 0x39, 0xE0,
+0x70, 0x05, 0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x04, 0x18, 0x12, 0x7A,
+0x49, 0x80, 0x13, 0x90, 0x88, 0x39, 0xE0, 0xB4,
+0x0C, 0x0C, 0x90, 0x88, 0x32, 0x12, 0xAD, 0x2E,
+0x30, 0xE0, 0x03, 0x12, 0x79, 0xD4, 0x90, 0x88,
+0x39, 0x12, 0xB7, 0xE0, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xF1, 0xD2, 0x40, 0x3A, 0x90, 0x88,
+0x50, 0xE0, 0x04, 0xF0, 0x90, 0x88, 0x92, 0xE0,
+0xFF, 0x90, 0x88, 0x50, 0xE0, 0xD3, 0x9F, 0x50,
+0x27, 0x90, 0x88, 0x48, 0xE0, 0x24, 0x08, 0xF0,
+0x90, 0x88, 0x3F, 0x12, 0xAE, 0x2C, 0x33, 0x33,
+0x33, 0x54, 0xF8, 0xFF, 0x90, 0x88, 0x3E, 0xE0,
+0x2F, 0x90, 0x88, 0x4F, 0xF0, 0xFB, 0x90, 0x88,
+0x48, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0xF1, 0xC9,
+0x22, 0x90, 0x92, 0x98, 0x74, 0x03, 0xF0, 0x02,
+0x6E, 0x2F, 0x90, 0x88, 0x93, 0xE0, 0xFF, 0x90,
+0x88, 0x3F, 0xE0, 0xD3, 0x9F, 0x22, 0xE4, 0xFE,
+0x12, 0xAC, 0xF6, 0xE4, 0xF0, 0x74, 0x00, 0x2E,
+0x12, 0xAC, 0xEE, 0x74, 0xFF, 0xF0, 0x0E, 0xEE,
+0xB4, 0xA0, 0xED, 0xE4, 0x90, 0x88, 0x4D, 0xF0,
+0x90, 0x88, 0x4C, 0xF0, 0x90, 0x88, 0x50, 0xF0,
+0xEF, 0xB4, 0x01, 0x07, 0xA3, 0x74, 0xA0, 0xF0,
+0xE4, 0xA3, 0xF0, 0x22, 0x90, 0x93, 0x2A, 0xE0,
+0x30, 0xE0, 0x34, 0xC4, 0x13, 0x54, 0x07, 0x30,
+0xE0, 0x2D, 0x90, 0x97, 0x0E, 0xE0, 0x04, 0xF0,
+0xE0, 0xD3, 0x94, 0xC8, 0x40, 0x21, 0x90, 0x93,
+0x2A, 0xE0, 0x54, 0xDF, 0xF0, 0xE4, 0x90, 0x97,
+0x0E, 0xF0, 0x90, 0x93, 0x2A, 0xE0, 0x13, 0x30,
+0xE0, 0x0D, 0x90, 0x88, 0x31, 0xE0, 0x44, 0x01,
+0xF0, 0x90, 0x88, 0x41, 0x74, 0xD0, 0xF0, 0x22,
+0x90, 0x05, 0x63, 0xE0, 0x90, 0x88, 0x89, 0xF0,
+0x90, 0x05, 0x62, 0xE0, 0x90, 0x88, 0x8A, 0xF0,
+0x90, 0x05, 0x61, 0xE0, 0x90, 0x88, 0x8B, 0xF0,
+0x90, 0x05, 0x60, 0xE0, 0x90, 0x88, 0x8C, 0xF0,
+0x90, 0x88, 0x32, 0xE0, 0x44, 0x80, 0xF0, 0x22,
+0x78, 0x08, 0x12, 0x03, 0xFE, 0xA8, 0x04, 0xA9,
+0x05, 0xAA, 0x06, 0xAB, 0x07, 0x22, 0xE0, 0x54,
+0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x02, 0xFF,
+0xEE, 0x54, 0xFD, 0x4F, 0x22, 0x74, 0xB6, 0x25,
 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83,
-0x22, 0x74, 0x76, 0x25, 0x62, 0xF5, 0x82, 0xE4,
-0x34, 0x8E, 0xF5, 0x83, 0xE4, 0xF0, 0x74, 0xF6,
-0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5,
-0x83, 0x22, 0x90, 0x00, 0x08, 0x02, 0x03, 0x3E,
-0x35, 0xF0, 0xFE, 0x90, 0x00, 0x06, 0x02, 0x03,
-0x3E, 0xF5, 0x83, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD,
-0xD3, 0x9F, 0xEC, 0x22, 0x90, 0x00, 0x02, 0x02,
-0x03, 0x3E, 0x90, 0x00, 0x04, 0x02, 0x03, 0x3E,
-0xE0, 0xD3, 0x9D, 0xEC, 0x64, 0x80, 0xF8, 0x74,
-0x80, 0x98, 0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0xED, 0x2F, 0xFF, 0xEC, 0x3E, 0xFE, 0x22, 0xE5,
-0x64, 0x25, 0xE0, 0x24, 0x75, 0xF5, 0x82, 0xE4,
-0x34, 0x81, 0xF5, 0x83, 0x22, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0xC3, 0x74, 0xFF, 0x9F, 0xFF, 0x74,
-0xFF, 0x9E, 0xFE, 0xE5, 0x62, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0xD1, 0x46,
-0x90, 0x96, 0xD1, 0xF0, 0x90, 0x88, 0x32, 0x12,
-0x8F, 0xF0, 0x30, 0xE0, 0x02, 0xE1, 0x9E, 0x90,
-0x88, 0x31, 0xE0, 0x30, 0xE0, 0x1F, 0x90, 0x88,
-0x53, 0xE0, 0x24, 0x04, 0x33, 0x33, 0x33, 0x54,
-0xF8, 0x90, 0x88, 0x4B, 0xF0, 0x90, 0x88, 0x53,
-0xE0, 0x04, 0x33, 0x33, 0x33, 0x54, 0xF8, 0x90,
-0x88, 0x4A, 0xF0, 0x80, 0x10, 0x90, 0x88, 0x4B,
-0x74, 0x10, 0xF0, 0x90, 0x88, 0x4A, 0x74, 0x08,
-0xF0, 0x74, 0x10, 0x2B, 0xFB, 0x90, 0x88, 0x4A,
-0xE0, 0xFE, 0x90, 0x88, 0x49, 0xE0, 0xD3, 0x9E,
-0x50, 0x0E, 0x90, 0x88, 0x3E, 0xEB, 0xF0, 0x90,
-0x88, 0x4B, 0xE0, 0xC3, 0x9D, 0x2F, 0x80, 0x11,
-0xC3, 0xED, 0x9E, 0x2B, 0x90, 0x88, 0x3E, 0xF0,
-0x90, 0x88, 0x4A, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3,
-0x9F, 0x90, 0x88, 0x4E, 0xF0, 0x90, 0x88, 0x4B,
-0xF1, 0xE0, 0x90, 0x88, 0x4E, 0xD1, 0xA0, 0x40,
-0x04, 0xEF, 0x24, 0x50, 0xF0, 0x90, 0x88, 0x4E,
-0xF1, 0xE0, 0x90, 0x88, 0x3E, 0xD1, 0xA0, 0x40,
-0x04, 0xEF, 0x24, 0x50, 0xF0, 0x90, 0x88, 0x4E,
-0x12, 0xAD, 0x26, 0xFF, 0x7E, 0x00, 0x90, 0x88,
-0x42, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x05,
-0x58, 0xF0, 0x90, 0x88, 0x4E, 0xE0, 0x54, 0x07,
-0xFF, 0x90, 0x05, 0xB1, 0xE0, 0x54, 0xF8, 0x4F,
-0xF0, 0x12, 0xDD, 0x8C, 0x80, 0x07, 0x90, 0x88,
-0x33, 0xE0, 0x44, 0x01, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x7D, 0x01, 0xAF, 0x62, 0x02, 0x61,
-0xF7, 0x93, 0xFD, 0x7C, 0x00, 0x02, 0x02, 0x80,
-0x25, 0xE0, 0x24, 0x06, 0xF5, 0x82, 0xE4, 0x22,
-0x25, 0xE0, 0x24, 0x26, 0xF5, 0x82, 0xE4, 0x22,
-0x25, 0xE0, 0x24, 0x56, 0xF5, 0x82, 0xE4, 0x22,
-0xE5, 0x64, 0x90, 0x81, 0x9D, 0x93, 0xFF, 0x22,
-0x90, 0x95, 0x40, 0xE0, 0xFE, 0xA3, 0xE0, 0x22,
-0xE0, 0xFF, 0x24, 0x50, 0xFD, 0xE4, 0x33, 0xFC,
-0x22, 0x12, 0x86, 0x61, 0xD3, 0x02, 0x03, 0xDA,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x96, 0xC3, 0xEF, 0xF0, 0x90, 0x00, 0x8F, 0xE0,
-0x30, 0xE6, 0x3D, 0x90, 0x00, 0x8D, 0xE0, 0x64,
-0x01, 0x70, 0x35, 0x90, 0x96, 0xC4, 0xF0, 0x90,
-0x96, 0xC4, 0xE0, 0xFD, 0x90, 0x96, 0xC3, 0xE0,
-0x12, 0x90, 0xDE, 0xE5, 0x82, 0x2D, 0x12, 0xB5,
-0xDF, 0xE0, 0xFB, 0xE4, 0xFF, 0x12, 0x96, 0x20,
-0x90, 0x96, 0xC4, 0xE0, 0x04, 0xF0, 0xE0, 0xC3,
-0x94, 0x10, 0x40, 0xDB, 0x90, 0x00, 0x8F, 0xE0,
-0x30, 0xE0, 0x05, 0x90, 0x00, 0x8D, 0xE4, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93, 0x57,
-0xE0, 0x54, 0x7F, 0xF0, 0x54, 0xBF, 0xF0, 0x54,
-0xDF, 0xF0, 0x54, 0xF0, 0xF0, 0xE4, 0x90, 0x93,
-0x59, 0xF0, 0x90, 0x93, 0x57, 0xE0, 0x54, 0xEF,
-0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0xE4, 0x90, 0x95, 0xEA, 0xF0, 0x90, 0x95,
-0xE8, 0x74, 0x14, 0xF0, 0x90, 0x96, 0x0A, 0x74,
-0x01, 0xF0, 0xFB, 0x7A, 0x95, 0x79, 0xE8, 0x12,
-0x8B, 0x34, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x01, 0x9A, 0xE0,
-0x54, 0xC0, 0x44, 0x0B, 0x12, 0xB7, 0xAD, 0x90,
-0x01, 0x98, 0xE0, 0x54, 0xC0, 0x7F, 0x00, 0xB4,
-0x40, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x01, 0x95,
-0xE0, 0x7F, 0x00, 0x30, 0xE4, 0x02, 0x7F, 0x01,
-0x22, 0x22, 0xE4, 0x90, 0x95, 0xEA, 0xF0, 0xA3,
-0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x41, 0x90, 0x95,
-0xE9, 0xEF, 0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x41,
-0xAE, 0x07, 0x90, 0x95, 0xE9, 0xE0, 0xFF, 0xB5,
-0x06, 0x01, 0x22, 0xC3, 0x90, 0x95, 0xEB, 0xE0,
-0x94, 0x64, 0x90, 0x95, 0xEA, 0xE0, 0x94, 0x00,
-0x40, 0x0D, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x40,
-0xF0, 0x90, 0x95, 0xE9, 0xE0, 0xFF, 0x22, 0x90,
-0x95, 0xEA, 0x12, 0x9F, 0xEF, 0x80, 0xC2, 0x90,
-0x01, 0xC4, 0x74, 0xF7, 0xF0, 0x74, 0xD0, 0xA3,
-0xF0, 0x7F, 0x90, 0x12, 0x7B, 0x41, 0xEF, 0x20,
-0xE0, 0xF7, 0x74, 0xF7, 0x04, 0x90, 0x01, 0xC4,
-0xF0, 0x74, 0xD0, 0xA3, 0xF0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x31, 0x46, 0x90,
-0x96, 0xCC, 0xF0, 0xED, 0x90, 0x00, 0x73, 0x70,
-0x0D, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x00, 0x67,
-0xE0, 0x44, 0x80, 0xF0, 0x80, 0x0B, 0xE0, 0x54,
-0xFB, 0xF0, 0x90, 0x00, 0x67, 0xE0, 0x54, 0x7F,
-0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x86,
-0xAD, 0xA3, 0xE0, 0x24, 0x7F, 0xF5, 0x82, 0xE4,
-0x34, 0x84, 0xF5, 0x83, 0xE0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x90, 0x88, 0xB8, 0xE0, 0x54, 0xFE,
-0xF0, 0x54, 0xE1, 0xF0, 0x90, 0x88, 0xBD, 0xE0,
-0xFF, 0x12, 0x71, 0x9A, 0x90, 0x88, 0x36, 0xE0,
-0x70, 0x0C, 0x12, 0x88, 0xCA, 0x90, 0x8A, 0xF9,
-0x12, 0x8B, 0x46, 0x12, 0xA9, 0x17, 0x22, 0x90,
-0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x5E, 0x90, 0x94,
-0xA2, 0xE0, 0x30, 0xE0, 0x3D, 0x90, 0x94, 0xAD,
-0xE0, 0xFF, 0x90, 0x94, 0xAC, 0xE0, 0xC3, 0x9F,
-0x40, 0x24, 0x31, 0xEF, 0x90, 0x06, 0xC4, 0x31,
-0xED, 0x78, 0x08, 0x12, 0x03, 0xEB, 0x90, 0x06,
-0xC5, 0x31, 0xED, 0x78, 0x10, 0x12, 0x03, 0xEB,
-0x90, 0x06, 0xC6, 0x31, 0xED, 0x31, 0xF5, 0xE4,
-0x90, 0x94, 0xAC, 0xF0, 0x80, 0x1B, 0x51, 0x00,
-0x31, 0xF5, 0x90, 0x94, 0xAC, 0xE0, 0x04, 0xF0,
-0x80, 0x0F, 0x90, 0x94, 0xAB, 0xE0, 0x60, 0x09,
-0x51, 0x00, 0x31, 0xF5, 0xE4, 0x90, 0x94, 0xAB,
-0xF0, 0x90, 0x8A, 0xBB, 0x12, 0x8B, 0x46, 0xE4,
-0xFF, 0x12, 0x04, 0x7E, 0x22, 0xEF, 0xF0, 0x90,
-0x94, 0xA3, 0x02, 0x04, 0xB8, 0x78, 0x18, 0x12,
-0x03, 0xEB, 0x90, 0x06, 0xC7, 0xEF, 0xF0, 0x22,
-0x90, 0x94, 0xA7, 0x12, 0x04, 0xB8, 0x90, 0x06,
-0xC4, 0xEF, 0xF0, 0x90, 0x94, 0xA7, 0x12, 0x04,
-0xB8, 0x78, 0x08, 0x12, 0x03, 0xEB, 0x90, 0x06,
-0xC5, 0xEF, 0xF0, 0x90, 0x94, 0xA7, 0x12, 0x04,
-0xB8, 0x78, 0x10, 0x12, 0x03, 0xEB, 0x90, 0x06,
-0xC6, 0xEF, 0xF0, 0x90, 0x94, 0xA7, 0x02, 0x04,
-0xB8, 0x90, 0x96, 0xCD, 0xEF, 0xF0, 0x90, 0x88,
-0xB8, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x8A, 0xF9,
-0x12, 0x8B, 0x46, 0x7D, 0x11, 0x51, 0x82, 0x12,
-0x88, 0xCD, 0x90, 0x07, 0x78, 0xE0, 0x90, 0x88,
-0xBD, 0xF0, 0x90, 0x96, 0xCD, 0xE0, 0xFD, 0x70,
-0x02, 0x80, 0x1C, 0xED, 0xB4, 0x01, 0x06, 0x51,
-0x7B, 0x44, 0x20, 0xF0, 0x22, 0x90, 0x96, 0xCD,
-0xE0, 0xFD, 0xB4, 0x02, 0x06, 0x51, 0x7B, 0x44,
-0x60, 0xF0, 0x22, 0xED, 0xB4, 0x03, 0x03, 0x51,
-0x7B, 0xF0, 0x22, 0x90, 0x88, 0xB8, 0xE0, 0x54,
-0x1F, 0x22, 0x7F, 0xFF, 0x12, 0x04, 0x7E, 0x90,
-0x8A, 0xEF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x94, 0xB6, 0x74, 0x02, 0xF0,
-0x90, 0x88, 0xC2, 0xE0, 0x44, 0x10, 0xF0, 0x90,
-0x88, 0xAF, 0xE0, 0x60, 0x02, 0x81, 0x18, 0x90,
-0x8A, 0xD9, 0x12, 0x8B, 0x46, 0xE4, 0xFF, 0x12,
-0x04, 0x7E, 0x90, 0x88, 0xA1, 0xE0, 0x30, 0xE0,
-0x04, 0x7F, 0x01, 0x80, 0x37, 0x90, 0x88, 0x9D,
-0x12, 0x9D, 0xC0, 0x30, 0xE0, 0x04, 0x7F, 0x0D,
-0x80, 0x2A, 0x90, 0x88, 0xA0, 0xE0, 0xFF, 0xC4,
-0x54, 0x0F, 0x30, 0xE0, 0x10, 0xEF, 0x13, 0x13,
-0x54, 0x3F, 0x30, 0xE0, 0x04, 0x7F, 0x09, 0x80,
-0x13, 0x7F, 0x03, 0x80, 0x0F, 0x90, 0x88, 0xA0,
-0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x04, 0x7F, 0x03,
-0x80, 0x02, 0x7F, 0x09, 0x12, 0x71, 0x9A, 0x90,
-0x88, 0xAF, 0x74, 0x01, 0x91, 0x1D, 0x30, 0xE0,
-0x05, 0x12, 0x9B, 0x4B, 0x80, 0x33, 0x90, 0x88,
-0x9D, 0xE0, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x29,
-0x90, 0x88, 0xA3, 0xE0, 0x44, 0x20, 0xF0, 0x90,
-0x88, 0x9C, 0xE0, 0x60, 0x0C, 0x90, 0x8A, 0xB9,
-0x12, 0x8B, 0x46, 0x7D, 0x01, 0x7F, 0x04, 0x80,
-0x0D, 0x12, 0x9B, 0x4B, 0x90, 0x8A, 0xB9, 0x12,
-0x8B, 0x46, 0x7D, 0x01, 0x7F, 0x0C, 0x12, 0x04,
-0x7E, 0x90, 0x88, 0x9C, 0xE0, 0x60, 0x06, 0x7B,
-0x04, 0x7D, 0x6F, 0x80, 0x03, 0xE4, 0xFB, 0xFD,
-0x7F, 0xFF, 0x12, 0x9B, 0x50, 0x12, 0x8F, 0xED,
-0x30, 0xE0, 0x0B, 0x90, 0x8A, 0x97, 0x12, 0x8B,
-0x46, 0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x88,
-0xA1, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x0E, 0x90,
-0x06, 0xCD, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x06,
-0xCF, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x05, 0x63,
-0xE0, 0x90, 0x94, 0xBA, 0xF0, 0x90, 0x05, 0x62,
-0xE0, 0x90, 0x94, 0xB9, 0xF0, 0x90, 0x05, 0x61,
-0xE0, 0x90, 0x94, 0xB8, 0xF0, 0x90, 0x05, 0x60,
-0xE0, 0x90, 0x94, 0xB7, 0xF0, 0x12, 0x8E, 0xD0,
-0x91, 0x27, 0x90, 0x94, 0xB7, 0x12, 0x8E, 0xD1,
-0x12, 0x86, 0x54, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x94, 0xB9, 0x12, 0x8E,
-0xD1, 0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86,
-0x54, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x12, 0x8E, 0xD0, 0x78, 0x18, 0x12, 0x03,
-0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0x86, 0x54, 0xA3, 0x12, 0x04, 0x31,
-0x90, 0x88, 0xA1, 0x12, 0xAF, 0x0F, 0x30, 0xE0,
-0x2F, 0x90, 0x94, 0xB0, 0x12, 0x04, 0xB8, 0x90,
-0x94, 0xBB, 0x12, 0xCF, 0xE9, 0x40, 0x21, 0x90,
-0x94, 0xB0, 0x12, 0x86, 0x61, 0x90, 0x94, 0xBB,
-0x12, 0x04, 0xB8, 0x12, 0x86, 0x39, 0xE4, 0xFB,
-0x7A, 0x78, 0xF9, 0xF8, 0xC3, 0x12, 0x03, 0xDA,
-0x50, 0x06, 0x90, 0x94, 0xB5, 0xE0, 0x04, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90, 0x88,
-0x9D, 0xE0, 0xC4, 0x13, 0x54, 0x07, 0x22, 0x78,
-0x08, 0x12, 0x03, 0xFE, 0xA8, 0x04, 0xA9, 0x05,
-0xAA, 0x06, 0xAB, 0x07, 0x22, 0x90, 0x02, 0x84,
-0xEF, 0xF0, 0xEE, 0xA3, 0xF0, 0xA3, 0xE0, 0x44,
-0x01, 0xF0, 0x22, 0xE4, 0x90, 0x96, 0xC7, 0xF0,
-0xA3, 0xF0, 0x90, 0x02, 0x86, 0xE0, 0x20, 0xE1,
-0x24, 0xC3, 0x90, 0x96, 0xC8, 0xE0, 0x94, 0xD0,
-0x90, 0x96, 0xC7, 0xE0, 0x94, 0x07, 0x40, 0x0A,
-0x90, 0x01, 0xC1, 0xE0, 0x44, 0x04, 0xF0, 0x7F,
-0x00, 0x22, 0x90, 0x96, 0xC7, 0x12, 0x9F, 0xEF,
-0x12, 0xB7, 0xAE, 0x80, 0xD5, 0x7F, 0x01, 0x22,
-0x7D, 0x07, 0xEF, 0x5D, 0xC3, 0x60, 0x0A, 0x91,
-0x8D, 0x24, 0x08, 0xFF, 0xE4, 0x3E, 0xFE, 0x80,
-0x03, 0x91, 0x8D, 0xFF, 0x22, 0x74, 0xFF, 0x9D,
-0xFD, 0x74, 0xFF, 0x94, 0x00, 0x5E, 0xFE, 0xED,
-0x5F, 0x22, 0x90, 0x95, 0xBA, 0x12, 0x86, 0x76,
-0xE4, 0xFF, 0x90, 0x95, 0xC0, 0xE0, 0xFE, 0xEF,
-0xC3, 0x9E, 0x50, 0x16, 0x90, 0x95, 0xBD, 0x12,
-0x94, 0xC7, 0xFE, 0x90, 0x95, 0xBA, 0x12, 0x94,
-0xC7, 0x6E, 0x60, 0x03, 0x7F, 0x00, 0x22, 0x0F,
-0x80, 0xE0, 0x7F, 0x01, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x93, 0x03, 0xE0,
-0xFE, 0xEE, 0x54, 0xFE, 0xF0, 0x7D, 0x08, 0xE4,
-0xFF, 0x12, 0x7C, 0x7E, 0xE4, 0x90, 0x93, 0x0F,
-0xF0, 0xA3, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x90, 0x93, 0x20, 0xE0, 0x90, 0x95, 0x9C, 0xF0,
-0x90, 0x93, 0x21, 0xE0, 0x90, 0x95, 0x9D, 0xF0,
-0x90, 0x93, 0x22, 0xE0, 0x90, 0x95, 0x9E, 0xF0,
-0x90, 0x93, 0x23, 0xE0, 0x90, 0x95, 0x9F, 0xF0,
-0x90, 0x93, 0x24, 0xE0, 0x90, 0x95, 0xA0, 0xF0,
-0x90, 0x93, 0x11, 0xE0, 0x90, 0x95, 0xA1, 0xF0,
-0x90, 0x93, 0x12, 0xE0, 0x90, 0x95, 0xA2, 0xF0,
-0x90, 0x93, 0x13, 0xE0, 0x90, 0x95, 0xA3, 0xF0,
-0x90, 0x93, 0x14, 0xE0, 0x90, 0x95, 0xA4, 0xF0,
-0x90, 0x93, 0x15, 0xE0, 0x90, 0x95, 0xA5, 0xF0,
-0x90, 0x93, 0x16, 0xE0, 0x90, 0x95, 0xA6, 0xF0,
-0x90, 0x93, 0x17, 0xE0, 0x90, 0x95, 0xA7, 0xF0,
-0x90, 0x93, 0x18, 0xE0, 0x90, 0x95, 0xA8, 0xF0,
-0x90, 0x93, 0x19, 0xE0, 0x90, 0x95, 0xA9, 0xF0,
-0x90, 0x93, 0x1A, 0xE0, 0x90, 0x95, 0xAA, 0xF0,
-0x12, 0xA4, 0x89, 0x90, 0x95, 0x44, 0xF0, 0x12,
-0xD9, 0xA5, 0x50, 0x0B, 0x12, 0xD9, 0xDF, 0x74,
-0x01, 0xF0, 0x12, 0xD9, 0x91, 0x80, 0xF0, 0x90,
-0x01, 0x1F, 0xE0, 0xFE, 0x90, 0x01, 0x1E, 0x12,
-0x9B, 0x42, 0x90, 0x95, 0x39, 0xF0, 0xA3, 0x12,
-0xD9, 0xF5, 0x12, 0xD9, 0xA5, 0x50, 0x51, 0x12,
-0xD9, 0xC0, 0x90, 0x95, 0x44, 0xE0, 0xFE, 0x24,
-0xAB, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0x12, 0xDC,
-0xA3, 0xE0, 0x24, 0x4D, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xE0, 0xFF, 0x74, 0x46, 0x2E,
-0xF5, 0x82, 0xE4, 0x34, 0x95, 0x12, 0xDC, 0xA3,
-0xE0, 0x24, 0x4E, 0xF9, 0xE4, 0x34, 0xFC, 0xFA,
-0x7B, 0x01, 0xEE, 0x12, 0xDC, 0xDD, 0x12, 0x86,
-0x76, 0x12, 0xDC, 0xA7, 0xE0, 0x24, 0x38, 0xF9,
-0xE4, 0x34, 0xFC, 0xFA, 0xEE, 0x12, 0xDA, 0x0E,
-0x12, 0x86, 0x76, 0x12, 0xD9, 0x91, 0x80, 0xAA,
-0x90, 0x02, 0x87, 0xE0, 0x70, 0x03, 0x02, 0xD9,
-0x7D, 0x90, 0x93, 0x03, 0xE0, 0x20, 0xE0, 0x03,
-0x02, 0xD9, 0x7D, 0xE4, 0x90, 0x95, 0xB5, 0x12,
-0xA4, 0x91, 0x90, 0x95, 0x39, 0xE0, 0xFF, 0xA3,
-0xE0, 0xA3, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
-0x95, 0x3B, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xEC,
-0x90, 0xFD, 0x11, 0xF0, 0x74, 0x01, 0x2D, 0xF5,
-0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0xFE,
-0x74, 0x00, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB,
-0xF5, 0x83, 0xE0, 0x7A, 0x00, 0x24, 0x00, 0xFF,
-0xEA, 0x3E, 0x54, 0x3F, 0x90, 0x95, 0x3D, 0xF0,
-0xA3, 0xEF, 0xF0, 0x74, 0x02, 0x2D, 0xF5, 0x82,
-0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x54, 0x0F,
-0x33, 0x33, 0x33, 0x54, 0xF8, 0x90, 0x95, 0x40,
-0xF0, 0xFC, 0x74, 0x07, 0x2D, 0xF5, 0x82, 0xE4,
-0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x54, 0xC0, 0x90,
-0x95, 0x42, 0xF0, 0xEC, 0x24, 0x18, 0x90, 0x95,
-0x3F, 0xF0, 0xFD, 0x90, 0x95, 0x3B, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x12, 0xD9, 0x82, 0xEF, 0x54,
-0xFC, 0x90, 0x95, 0x41, 0xF0, 0x90, 0x95, 0x40,
-0xE0, 0x24, 0x18, 0xFF, 0xE4, 0x33, 0x90, 0x95,
-0x3D, 0x8F, 0xF0, 0x12, 0x02, 0xE7, 0x90, 0x95,
-0x3D, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x91, 0x78,
-0x90, 0x95, 0x39, 0xEE, 0x8F, 0xF0, 0x12, 0x02,
-0xE7, 0x90, 0x88, 0x27, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x90, 0x95, 0x39, 0x12, 0xCE, 0x8B, 0x9E,
-0x40, 0x1B, 0x90, 0x88, 0x28, 0xE0, 0x24, 0x01,
-0xFF, 0x90, 0x88, 0x27, 0xE0, 0x34, 0x00, 0xFE,
-0xC3, 0xED, 0x9F, 0xFF, 0xEC, 0x9E, 0x90, 0x95,
-0x39, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x95, 0x41,
-0xE0, 0x24, 0xC0, 0x60, 0x03, 0x02, 0xD8, 0xC8,
-0x12, 0xD9, 0x98, 0x24, 0x18, 0x12, 0xD9, 0x81,
-0xEF, 0x60, 0x03, 0x02, 0xD8, 0xBA, 0x12, 0xD9,
-0x98, 0x24, 0x19, 0x12, 0xD9, 0x81, 0x90, 0x95,
-0x5A, 0x12, 0xD9, 0xFD, 0x90, 0x95, 0x5A, 0xE0,
-0xFF, 0x12, 0xD9, 0xCF, 0x9F, 0x50, 0x18, 0x12,
-0xD9, 0x98, 0x24, 0x1A, 0x12, 0xD9, 0x7E, 0x90,
-0x95, 0x43, 0xE0, 0x24, 0x5B, 0xF5, 0x82, 0xE4,
-0x34, 0x95, 0x12, 0xD9, 0xEA, 0x80, 0xDD, 0x90,
-0x95, 0x5A, 0xE0, 0x70, 0x02, 0xE1, 0xE9, 0xE4,
-0x90, 0x95, 0x44, 0xF0, 0x12, 0xD9, 0xA5, 0x40,
-0x02, 0xE1, 0xD0, 0x12, 0xD9, 0xC0, 0x90, 0x95,
-0x44, 0xE0, 0xFF, 0x24, 0x46, 0xF5, 0x82, 0xE4,
-0x34, 0x95, 0xF5, 0x83, 0xE0, 0xFE, 0x90, 0x95,
-0x5A, 0xE0, 0xFD, 0xEE, 0x6D, 0x70, 0x1F, 0xEF,
-0x12, 0xDC, 0xDD, 0x12, 0x86, 0x6D, 0xC0, 0x03,
-0xC0, 0x02, 0xC0, 0x01, 0x12, 0xDC, 0x93, 0xED,
-0xF0, 0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03, 0x91,
-0x9A, 0xEF, 0x60, 0x02, 0x80, 0x4A, 0x90, 0x95,
-0x5A, 0xE0, 0x64, 0x03, 0x70, 0x52, 0x12, 0xDC,
-0x93, 0x74, 0x03, 0xF0, 0x7A, 0x96, 0x79, 0x95,
-0x91, 0x9A, 0xEF, 0x70, 0x0F, 0x12, 0xDC, 0x93,
-0x74, 0x03, 0xF0, 0x7A, 0x96, 0x79, 0x91, 0x91,
-0x9A, 0xEF, 0x60, 0x2C, 0x90, 0x95, 0x44, 0xE0,
-0xFF, 0x24, 0xA6, 0xF5, 0x82, 0xE4, 0x34, 0x95,
-0xF5, 0x83, 0xE0, 0x60, 0x02, 0x80, 0x0C, 0x90,
-0x95, 0x44, 0xE0, 0xFF, 0x24, 0xA1, 0x12, 0xDA,
-0x05, 0x60, 0x05, 0x74, 0xB5, 0x2F, 0x80, 0x16,
-0x12, 0xD9, 0xB2, 0x74, 0x01, 0xF0, 0x80, 0x13,
-0x90, 0x95, 0x44, 0xE0, 0x24, 0xB5, 0x80, 0x06,
-0x90, 0x95, 0x44, 0xE0, 0x24, 0xB5, 0x12, 0xD9,
-0xB8, 0xE4, 0xF0, 0x12, 0xD9, 0x91, 0xE1, 0x24,
-0x90, 0x95, 0xB5, 0xE0, 0x70, 0x52, 0xA3, 0xE0,
-0x70, 0x4E, 0xA3, 0xE0, 0x70, 0x4A, 0xA3, 0xE0,
-0x70, 0x46, 0xA3, 0xE0, 0x70, 0x42, 0x02, 0xD8,
-0xBA, 0xE4, 0x90, 0x95, 0x44, 0xF0, 0x12, 0xD9,
-0xA5, 0x50, 0x1D, 0x74, 0xA1, 0x2E, 0x12, 0xDA,
-0x05, 0x60, 0x09, 0x74, 0xB5, 0x2E, 0x31, 0xB8,
-0xE4, 0xF0, 0x80, 0x08, 0x74, 0xB5, 0x2E, 0x31,
-0xB8, 0x74, 0x01, 0xF0, 0x31, 0x91, 0x80, 0xDE,
-0x90, 0x95, 0xB5, 0xE0, 0x70, 0x12, 0xA3, 0xE0,
-0x70, 0x0E, 0xA3, 0xE0, 0x70, 0x0A, 0xA3, 0xE0,
-0x70, 0x06, 0xA3, 0xE0, 0x70, 0x02, 0x01, 0xBA,
-0xE4, 0x90, 0x95, 0x44, 0xF0, 0x31, 0xA5, 0x40,
-0x02, 0x01, 0xBA, 0x31, 0xC0, 0x31, 0xB2, 0xE0,
-0x60, 0x7C, 0x90, 0x93, 0x29, 0xE0, 0x30, 0xE0,
-0x06, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x6F, 0xE4,
-0xFF, 0xFE, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x10,
-0xD3, 0xEF, 0x94, 0xE8, 0xEE, 0x94, 0x03, 0x50,
-0x07, 0x0F, 0xBF, 0x00, 0x01, 0x0E, 0x80, 0xEA,
-0x90, 0x04, 0x1D, 0xE0, 0x70, 0x50, 0x90, 0x95,
-0x44, 0xE0, 0x24, 0x9C, 0xF5, 0x82, 0xE4, 0x34,
-0x95, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x92, 0x13,
-0x74, 0x06, 0xF0, 0x7B, 0x08, 0x7D, 0x01, 0x12,
-0x66, 0xDB, 0x90, 0x95, 0x3D, 0xEE, 0xF0, 0xA3,
-0x31, 0xFD, 0x31, 0xCF, 0x94, 0x06, 0x50, 0x1C,
-0x31, 0x98, 0x24, 0x0A, 0x31, 0x7E, 0x90, 0x95,
-0x3D, 0xA3, 0xE0, 0xFE, 0x90, 0x95, 0x43, 0xE0,
-0x2E, 0x24, 0x2C, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
-0x31, 0xEA, 0x80, 0xDE, 0x90, 0x04, 0x1F, 0x74,
-0x20, 0xF0, 0x90, 0x06, 0x35, 0xF0, 0x31, 0x91,
-0x01, 0x2D, 0x31, 0xD6, 0x12, 0xD4, 0x35, 0x90,
-0x06, 0x36, 0x74, 0xDD, 0xF0, 0x02, 0xD5, 0xE0,
-0x90, 0x95, 0x42, 0xE0, 0x60, 0x02, 0x21, 0x75,
-0x31, 0x98, 0x24, 0x16, 0x31, 0x81, 0x90, 0x06,
-0x34, 0xEF, 0xF0, 0x31, 0x98, 0x24, 0x17, 0x31,
-0x81, 0x90, 0x06, 0x37, 0x31, 0xF5, 0x31, 0xA5,
-0x50, 0x38, 0x31, 0xC0, 0xE4, 0x90, 0x95, 0x43,
-0xF0, 0x31, 0xCF, 0x94, 0x06, 0x50, 0x27, 0x31,
-0x98, 0x24, 0x04, 0x2D, 0x31, 0x81, 0x90, 0x95,
-0x44, 0xE0, 0xFE, 0x51, 0x0E, 0x12, 0x86, 0x6D,
-0x90, 0x95, 0x43, 0xE0, 0xF5, 0x82, 0x12, 0x94,
-0xCC, 0x6F, 0x60, 0x06, 0x31, 0xDF, 0xE4, 0xF0,
-0x80, 0x04, 0x31, 0xEE, 0x80, 0xD3, 0x31, 0x91,
-0x80, 0xC4, 0x90, 0x95, 0xB0, 0xE0, 0x64, 0x01,
-0x60, 0x17, 0xA3, 0xE0, 0x64, 0x01, 0x60, 0x11,
-0xA3, 0xE0, 0x64, 0x01, 0x60, 0x0B, 0xA3, 0xE0,
-0x64, 0x01, 0x60, 0x05, 0xA3, 0xE0, 0xB4, 0x01,
-0x06, 0x90, 0x95, 0x45, 0x74, 0x01, 0xF0, 0x90,
-0x95, 0x45, 0xE0, 0xB4, 0x01, 0x13, 0x12, 0xD4,
-0xC5, 0x90, 0x93, 0x03, 0xE0, 0x44, 0x20, 0xF0,
-0x12, 0xBD, 0xD6, 0x12, 0xBC, 0x7A, 0x02, 0xD5,
-0xE0, 0x12, 0xA4, 0x89, 0x90, 0x95, 0x44, 0xF0,
-0x31, 0xA5, 0x50, 0x09, 0x31, 0xDF, 0x74, 0x01,
-0xF0, 0x31, 0x91, 0x80, 0xF3, 0x31, 0xD6, 0x12,
-0xD4, 0x35, 0x02, 0xD5, 0xE0, 0x22, 0xFC, 0xED,
-0x2C, 0xFD, 0x90, 0x8A, 0xE9, 0xE0, 0xFA, 0xA3,
-0xE0, 0xFB, 0xF5, 0x82, 0x8A, 0x83, 0x02, 0x04,
-0x7E, 0x90, 0x95, 0x44, 0xE0, 0x04, 0xF0, 0x22,
-0x90, 0x95, 0x3B, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x90, 0x95, 0x3F, 0xE0, 0x22, 0x90, 0x93, 0x0E,
-0xE0, 0xFF, 0x90, 0x95, 0x44, 0xE0, 0xFE, 0xC3,
-0x9F, 0x22, 0x90, 0x95, 0x44, 0xE0, 0x24, 0xB5,
-0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0x22,
-0x74, 0x9C, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95,
-0xF5, 0x83, 0xE0, 0xFF, 0x02, 0x7B, 0x07, 0x90,
-0x95, 0x43, 0xE0, 0xFD, 0xC3, 0x22, 0x90, 0x95,
-0x39, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0x74,
-0xB0, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5,
-0x83, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x95,
-0x43, 0xE0, 0x04, 0xF0, 0x22, 0xEF, 0xF0, 0xE4,
-0x90, 0x95, 0x44, 0xF0, 0x22, 0xEF, 0xF0, 0xE4,
-0x90, 0x95, 0x43, 0xF0, 0x22, 0xF5, 0x82, 0xE4,
-0x34, 0x95, 0xF5, 0x83, 0xE0, 0x22, 0x75, 0xF0,
-0x03, 0xA4, 0x24, 0x8D, 0xF5, 0x82, 0xE4, 0x34,
-0x95, 0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x88, 0x9D, 0xE0, 0x30,
-0xE0, 0x10, 0x90, 0x88, 0xA3, 0xE0, 0xC4, 0x13,
-0x54, 0x07, 0x30, 0xE0, 0x12, 0x75, 0x10, 0x10,
-0x80, 0x44, 0x12, 0x7A, 0x65, 0xEF, 0x64, 0x01,
-0x60, 0x05, 0x75, 0x10, 0x01, 0x80, 0x37, 0x90,
-0x88, 0x31, 0x12, 0xAD, 0x26, 0x30, 0xE0, 0x05,
-0x75, 0x10, 0x02, 0x80, 0x29, 0x90, 0x88, 0x38,
-0xE0, 0xD3, 0x94, 0x04, 0x40, 0x05, 0x75, 0x10,
-0x08, 0x80, 0x1B, 0x90, 0x93, 0x29, 0xE0, 0x30,
-0xE0, 0x0B, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x05,
-0x75, 0x10, 0x11, 0x80, 0x09, 0x90, 0x01, 0xB8,
-0xE4, 0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90, 0x01,
-0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8, 0xE5,
-0x10, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x1E, 0x90,
-0x88, 0xAF, 0xE0, 0x60, 0x05, 0x75, 0x11, 0x40,
-0x61, 0x3F, 0x90, 0x88, 0x38, 0xE0, 0xD3, 0x94,
-0x00, 0x40, 0x02, 0x80, 0x2D, 0x90, 0x88, 0x9C,
-0xE0, 0x60, 0x7B, 0x80, 0x55, 0x12, 0x7A, 0x65,
-0xEF, 0x64, 0x01, 0x60, 0x05, 0x75, 0x11, 0x01,
-0x80, 0x75, 0x90, 0x88, 0x3A, 0xE0, 0xFF, 0x54,
-0x03, 0x60, 0x05, 0x75, 0x11, 0x02, 0x80, 0x67,
-0x90, 0x88, 0x38, 0xE0, 0xFE, 0xE4, 0xC3, 0x9E,
-0x50, 0x05, 0x75, 0x11, 0x04, 0x80, 0x58, 0xEF,
-0x30, 0xE2, 0x05, 0x75, 0x11, 0x08, 0x80, 0x4F,
-0x90, 0x88, 0x3A, 0xE0, 0x30, 0xE4, 0x05, 0x75,
-0x11, 0x10, 0x80, 0x43, 0x90, 0x88, 0x32, 0xE0,
-0x13, 0x13, 0x54, 0x3F, 0x20, 0xE0, 0x05, 0x75,
-0x11, 0x20, 0x80, 0x33, 0x90, 0x88, 0x9C, 0xE0,
-0x60, 0x05, 0x75, 0x11, 0x80, 0x80, 0x28, 0x90,
-0x06, 0x62, 0xE0, 0x30, 0xE1, 0x05, 0x75, 0x11,
-0x11, 0x80, 0x1C, 0x90, 0x06, 0x62, 0xE0, 0x30,
-0xE0, 0x0C, 0xE0, 0x54, 0xFC, 0xFF, 0xBF, 0x80,
-0x05, 0x75, 0x11, 0x12, 0x80, 0x09, 0x90, 0x01,
-0xB8, 0xE4, 0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90,
-0x01, 0xB9, 0x74, 0x04, 0xF0, 0x90, 0x01, 0xB8,
-0xE5, 0x11, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x90, 0x02, 0x87, 0xE0, 0x60, 0x02,
-0x80, 0x08, 0x90, 0x01, 0x00, 0xE0, 0x64, 0x3F,
-0x60, 0x05, 0x75, 0x61, 0x01, 0x80, 0x34, 0x90,
-0x02, 0x96, 0xE0, 0x60, 0x05, 0x75, 0x61, 0x10,
-0x80, 0x29, 0x90, 0x02, 0x86, 0xE0, 0x20, 0xE1,
-0x02, 0x80, 0x07, 0x90, 0x02, 0x86, 0xE0, 0x30,
-0xE3, 0x05, 0x75, 0x61, 0x04, 0x80, 0x14, 0x90,
-0x88, 0xE6, 0xE0, 0x30, 0xE0, 0x05, 0x75, 0x61,
-0x20, 0x80, 0x08, 0x90, 0x01, 0xB8, 0xE4, 0xF0,
-0x7F, 0x01, 0x22, 0x90, 0x01, 0xB9, 0x74, 0x08,
-0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x61, 0xF0, 0x7F,
-0x00, 0x22, 0x90, 0x94, 0xA1, 0x74, 0x01, 0xF0,
-0x90, 0x06, 0x92, 0x04, 0xF0, 0x90, 0x01, 0x3C,
-0x74, 0x04, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0x44,
-0x08, 0xF0, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x0C,
-0x60, 0x16, 0x90, 0x8A, 0xB9, 0x12, 0x8B, 0x46,
-0xE4, 0xFD, 0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x90,
-0x8A, 0xF9, 0x12, 0x8B, 0x46, 0x12, 0xA9, 0x17,
-0x90, 0x8A, 0xAF, 0x12, 0x8B, 0x46, 0x7D, 0x08,
-0xE4, 0xFF, 0x02, 0x04, 0x7E, 0x90, 0x88, 0x8D,
-0x74, 0x18, 0xF0, 0xA3, 0xF0, 0xA3, 0xE4, 0xF0,
-0xA3, 0x74, 0x64, 0xF0, 0xA3, 0x74, 0x05, 0xF0,
-0xA3, 0xF0, 0x22, 0x91, 0x4C, 0x9F, 0x40, 0x3A,
-0x90, 0x88, 0x50, 0xE0, 0x04, 0xF0, 0x90, 0x88,
-0x92, 0xE0, 0xFF, 0x90, 0x88, 0x50, 0xE0, 0xD3,
-0x9F, 0x50, 0x27, 0x90, 0x88, 0x48, 0xE0, 0x24,
-0x08, 0xF0, 0x90, 0x88, 0x3F, 0x12, 0xAD, 0x8C,
-0x33, 0x33, 0x33, 0x54, 0xF8, 0xFF, 0x90, 0x88,
-0x3E, 0xE0, 0x2F, 0x90, 0x88, 0x4F, 0xF0, 0xFB,
-0x90, 0x88, 0x48, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD,
-0x91, 0x43, 0x22, 0x90, 0x92, 0x98, 0x74, 0x03,
-0xF0, 0x02, 0x6E, 0x2F, 0x90, 0x88, 0x93, 0xE0,
-0xFF, 0x90, 0x88, 0x3F, 0xE0, 0xD3, 0x22, 0x90,
-0x93, 0x29, 0xE0, 0x30, 0xE0, 0x34, 0xC4, 0x13,
-0x54, 0x07, 0x30, 0xE0, 0x2D, 0x90, 0x96, 0xD2,
-0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94, 0xC8, 0x40,
-0x21, 0x90, 0x93, 0x29, 0xE0, 0x54, 0xDF, 0xF0,
-0xE4, 0x90, 0x96, 0xD2, 0xF0, 0x90, 0x93, 0x29,
-0xE0, 0x13, 0x30, 0xE0, 0x0D, 0x90, 0x88, 0x31,
-0xE0, 0x44, 0x01, 0xF0, 0x90, 0x88, 0x41, 0x74,
-0xD0, 0xF0, 0x22, 0x7B, 0x01, 0x7A, 0x95, 0x79,
-0x5B, 0x90, 0x95, 0xBD, 0x12, 0x86, 0x76, 0x90,
-0x95, 0xC0, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x74,
-0xAB, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5,
-0x83, 0x22, 0xE0, 0x54, 0xFE, 0x4E, 0xFE, 0xF0,
-0xEF, 0x54, 0x02, 0xFF, 0xEE, 0x54, 0xFD, 0x4F,
-0x22, 0x7F, 0xFB, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
-0xEF, 0x64, 0x01, 0x22, 0x24, 0x03, 0xFF, 0xE4,
-0x33, 0xFE, 0x90, 0x96, 0x87, 0x12, 0x86, 0x6D,
-0x8F, 0x82, 0x8E, 0x83, 0x22, 0x75, 0xF0, 0x03,
-0xA4, 0x24, 0x4B, 0xF5, 0x82, 0xE4, 0x34, 0x95,
-0xF5, 0x83, 0x22, 0xE0, 0x90, 0x01, 0xBA, 0xF0,
-0x90, 0x88, 0x38, 0xE0, 0x90, 0x01, 0xBB, 0x22,
-0x75, 0xF0, 0x02, 0xA4, 0xF5, 0x82, 0x85, 0xF0,
-0x83, 0x02, 0x03, 0x3E, 0x90, 0x93, 0x29, 0xE0,
-0xC3, 0x13, 0x22, 0x74, 0xA6, 0x25, 0x62, 0xF5,
-0x82, 0xE4, 0x34, 0x8E, 0x22, 0x74, 0x5F, 0x25,
-0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0x22, 0x74,
-0xE6, 0x25, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x8D,
-0x22, 0xE5, 0x62, 0x25, 0xE0, 0x24, 0x86, 0xF5,
-0x82, 0xE4, 0x22, 0x74, 0xB6, 0x25, 0x62, 0xF5,
-0x82, 0xE4, 0x34, 0x8D, 0x22, 0xFE, 0x54, 0x10,
-0xFD, 0xEF, 0x54, 0xEF, 0x4D, 0xFF, 0x22, 0x54,
-0x04, 0xFD, 0xEF, 0x54, 0xFB, 0x4D, 0xFF, 0x22,
-0xE4, 0x90, 0x92, 0x20, 0xF0, 0x90, 0x93, 0x2B,
 0x22, 0x90, 0x88, 0xA1, 0xE0, 0xC4, 0x13, 0x54,
 0x07, 0x22, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0xA3,
-0xEB, 0xF0, 0x22, 0xF0, 0xEE, 0x54, 0x20, 0xFE,
-0xEF, 0x54, 0xDF, 0x22, 0xF0, 0xEE, 0x54, 0x08,
-0xFE, 0xEF, 0x54, 0xF7, 0x22, 0x12, 0x02, 0x06,
-0xFF, 0x54, 0x01, 0xFE, 0x22, 0x8C, 0x83, 0xE4,
-0xFD, 0x02, 0x04, 0x7E, 0x90, 0x88, 0x33, 0xE0,
-0x54, 0xFE, 0xF0, 0x22, 0x25, 0xE0, 0x25, 0xE0,
-0xFE, 0xEF, 0x4E, 0x22, 0x7F, 0xF9, 0x7E, 0x01,
-0x02, 0x5F, 0xA6, 0x90, 0x88, 0x31, 0xE0, 0x54,
-0xF7, 0xF0, 0x22, 0x00, 0x4B, 0xD1
+0xEB, 0xF0, 0x22, 0x7D, 0x01, 0x7F, 0x02, 0x02,
+0x7C, 0x7E, 0x90, 0x88, 0x31, 0xE0, 0x54, 0xF7,
+0xF0, 0x22, 0x9A, 0x27
 };
 
-u32 array_length_mp_8723d_fw_ap = 24014;
+u32 array_length_mp_8723d_fw_ap = 24796;
 
 #endif /*defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP))*/
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN)) || (DM_ODM_SUPPORT_TYPE & (ODM_CE))
 
 u8 array_mp_8723d_fw_nic[] = {
-0xD1, 0x23, 0x10, 0x00, 0x27, 0x00, 0x00, 0x00,
-0x09, 0x15, 0x17, 0x38, 0x2E, 0x6C, 0x02, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xD1, 0x23, 0x10, 0x00, 0x2F, 0x00, 0x00, 0x00,
+0x12, 0x10, 0x17, 0x08, 0x5C, 0x6E, 0x02, 0x00,
+0xBE, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x02, 0x86, 0x71, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xD5, 0x5E, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xB6, 0xEF, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xDD, 0xBD, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xD8, 0x4A, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xBF, 0x08, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xB9, 0x5E, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xDD, 0x67, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xD5, 0x03, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xD5, 0x5B, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xD7, 0xF4, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
@@ -3259,2851 +3358,2164 @@ u8 array_mp_8723d_fw_nic[] = {
 0xF8, 0xE4, 0x93, 0xA3, 0xC8, 0xC5, 0x82, 0xC8,
 0xCA, 0xC5, 0x83, 0xCA, 0xF0, 0xA3, 0xC8, 0xC5,
 0x82, 0xC8, 0xCA, 0xC5, 0x83, 0xCA, 0xDF, 0xE9,
-0xDE, 0xE7, 0x80, 0xBE, 0x41, 0x97, 0x40, 0x00,
-0x41, 0x97, 0x44, 0x00, 0x00, 0xBF, 0x5F, 0xD9,
-0xE4, 0xDC, 0xF1, 0x90, 0x97, 0x3F, 0xEF, 0xF0,
+0xDE, 0xE7, 0x80, 0xBE, 0x41, 0x97, 0x6D, 0x00,
+0x41, 0x97, 0x71, 0x00, 0x00, 0xC7, 0x52, 0xD1,
+0xDD, 0x8B, 0xE7, 0x90, 0x97, 0x6C, 0xEF, 0xF0,
 0x7F, 0x02, 0xB1, 0x27, 0x90, 0x86, 0xAF, 0xE0,
-0xFF, 0x90, 0x97, 0x3F, 0xE0, 0xFE, 0xEF, 0x4E,
+0xFF, 0x90, 0x97, 0x6C, 0xE0, 0xFE, 0xEF, 0x4E,
 0x90, 0x86, 0xAF, 0xF0, 0x22, 0x90, 0x02, 0x09,
 0xE0, 0xFD, 0x12, 0x02, 0x06, 0xFE, 0xAF, 0x05,
-0xED, 0x2E, 0x90, 0x86, 0xB4, 0xF0, 0x12, 0x8F,
-0x98, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB5, 0xF0,
-0xF1, 0xF1, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB6,
-0xF1, 0x9E, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB7,
-0xF1, 0x6D, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB8,
-0xF1, 0x66, 0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB9,
-0xF1, 0xF7, 0xFF, 0xAE, 0x05, 0xED, 0x2F, 0x90,
-0x86, 0xBA, 0xF0, 0x22, 0x4E, 0xFF, 0xF0, 0x90,
-0x00, 0x05, 0x02, 0x02, 0x1F, 0xF0, 0x90, 0x00,
-0x04, 0x02, 0x02, 0x1F, 0x12, 0xAC, 0x9E, 0x12,
-0x02, 0x06, 0x90, 0x93, 0x60, 0xF0, 0x12, 0x8F,
-0x98, 0x90, 0x93, 0x61, 0xF0, 0xF1, 0xF1, 0x90,
-0x93, 0x7B, 0xF1, 0x9E, 0x90, 0x93, 0x7C, 0xF1,
-0x6D, 0x90, 0x93, 0x96, 0xF1, 0x66, 0x90, 0x93,
-0x97, 0xF0, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
-0x00, 0x03, 0x02, 0x02, 0x1F, 0x12, 0x02, 0x06,
-0xFE, 0xF1, 0xF1, 0xFF, 0x74, 0xD6, 0x2E, 0xF5,
-0x82, 0xE4, 0x34, 0x8D, 0xF1, 0x9B, 0xFF, 0x74,
-0xC6, 0x2E, 0x12, 0x9D, 0x7B, 0xEF, 0xF1, 0x6D,
-0xFF, 0x74, 0x4D, 0x2E, 0x12, 0xEC, 0x0B, 0xEF,
-0xF0, 0x74, 0xC6, 0x2E, 0x12, 0x9D, 0x7B, 0xE0,
-0x30, 0xE5, 0x18, 0x75, 0xF0, 0x12, 0xEE, 0x12,
-0x9B, 0xEB, 0x13, 0x13, 0x54, 0x03, 0xFB, 0xAF,
-0x06, 0x74, 0xD6, 0x2E, 0x12, 0x9A, 0x7F, 0xFD,
-0x12, 0x6B, 0xFD, 0x22, 0x90, 0x95, 0x4E, 0xD1,
-0x39, 0x90, 0x00, 0x02, 0x02, 0x02, 0x1F, 0xF0,
-0x90, 0x00, 0x06, 0x02, 0x02, 0x1F, 0x12, 0xBD,
-0xE7, 0x90, 0x93, 0xE7, 0xE0, 0x70, 0x12, 0x51,
-0x4E, 0x12, 0x02, 0x06, 0x13, 0x13, 0x54, 0x3F,
-0x30, 0xE0, 0x06, 0x90, 0x93, 0xED, 0x74, 0x01,
-0xF0, 0x90, 0x93, 0xE9, 0xE0, 0x70, 0x12, 0x51,
-0x4E, 0x12, 0x02, 0x06, 0xC4, 0x54, 0x0F, 0xFF,
-0xBF, 0x05, 0x06, 0x90, 0x93, 0xEE, 0x74, 0x01,
-0xF0, 0xF1, 0x92, 0xFF, 0x90, 0x95, 0x52, 0xF0,
-0x12, 0x02, 0x06, 0xC3, 0x13, 0x30, 0xE0, 0x09,
-0x12, 0x87, 0xEC, 0x90, 0x95, 0x53, 0xF0, 0x80,
-0x05, 0x90, 0x95, 0x53, 0xEF, 0xF0, 0x90, 0x95,
-0x52, 0xE0, 0x90, 0x95, 0x51, 0xF0, 0x90, 0x95,
-0x53, 0xE0, 0xFE, 0x90, 0x95, 0x51, 0xE0, 0xFF,
-0xD3, 0x9E, 0x50, 0x39, 0x51, 0x4E, 0x12, 0x02,
-0x06, 0x54, 0x01, 0xFD, 0x12, 0x6E, 0x71, 0x90,
-0x95, 0x51, 0xE0, 0xFF, 0x12, 0x78, 0x4A, 0xEF,
-0x90, 0x95, 0x51, 0x70, 0x06, 0xE0, 0xFF, 0xF1,
-0xF1, 0x80, 0x05, 0xE0, 0xFF, 0x12, 0xCF, 0xAE,
-0x90, 0x93, 0xEE, 0xE0, 0x60, 0x07, 0x90, 0x95,
-0x51, 0xE0, 0xFF, 0xF1, 0xF1, 0x90, 0x95, 0x51,
-0xE0, 0x04, 0xF0, 0x80, 0xB9, 0x90, 0x05, 0x5E,
-0xE4, 0xF0, 0x90, 0x95, 0x52, 0xE0, 0x70, 0x1A,
-0xFF, 0x12, 0x78, 0x4A, 0xEF, 0x70, 0x13, 0x90,
-0x86, 0x0C, 0x11, 0xCD, 0x90, 0x8A, 0xED, 0x11,
-0xCD, 0x12, 0xBD, 0xF4, 0x54, 0xBF, 0xF0, 0x54,
-0x7F, 0xF0, 0x22, 0x7D, 0xFF, 0xE4, 0xFF, 0x12,
-0xA4, 0xC7, 0x90, 0x8A, 0xFD, 0xE0, 0xFE, 0xA3,
-0xE0, 0xAA, 0x06, 0xF9, 0x02, 0x04, 0x7A, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x97,
-0x46, 0xED, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0xFE,
-0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
-0x41, 0x48, 0xEE, 0xF1, 0x8B, 0x30, 0xE0, 0x02,
-0x41, 0x48, 0x90, 0x88, 0x39, 0xE0, 0xFE, 0x6F,
-0x70, 0x02, 0x41, 0x48, 0xEF, 0x70, 0x02, 0x21,
-0xA4, 0x24, 0xFE, 0x70, 0x02, 0x21, 0xE9, 0x24,
-0xFE, 0x60, 0x4F, 0x24, 0xFC, 0x70, 0x02, 0x41,
-0x2E, 0x24, 0xFC, 0x60, 0x02, 0x41, 0x41, 0xEE,
-0xB4, 0x0E, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88,
-0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x78,
-0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03,
-0x12, 0x71, 0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4,
-0x04, 0x11, 0x90, 0x97, 0x46, 0xE0, 0xFF, 0x60,
-0x05, 0x12, 0x67, 0x80, 0x80, 0x05, 0x90, 0x8A,
-0xED, 0x11, 0xCD, 0x90, 0x88, 0x39, 0xE0, 0x64,
-0x08, 0x60, 0x02, 0x41, 0x41, 0x12, 0x7B, 0xCC,
-0x41, 0x41, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x05,
-0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90, 0x88, 0x39,
-0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24, 0x90,
-0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B, 0x90, 0x86,
-0x00, 0x11, 0xCD, 0xBF, 0x01, 0x03, 0x12, 0x71,
-0x5F, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x0C, 0x60,
-0x02, 0x41, 0x41, 0x90, 0x86, 0x00, 0x11, 0xCD,
-0xEF, 0x64, 0x01, 0x60, 0x02, 0x41, 0x41, 0x12,
-0x68, 0xC2, 0x41, 0x41, 0x90, 0x88, 0x39, 0xE0,
-0xB4, 0x0E, 0x0B, 0x90, 0x86, 0x00, 0x11, 0xCD,
-0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88,
-0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24,
-0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0B, 0x90,
-0x86, 0x00, 0x11, 0xCD, 0xBF, 0x01, 0x03, 0x12,
-0x68, 0xC2, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x04,
-0x70, 0x67, 0x90, 0x86, 0x02, 0x11, 0xCD, 0xEF,
-0x64, 0x01, 0x70, 0x5D, 0x12, 0x73, 0x5A, 0x80,
-0x58, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B,
-0x90, 0x86, 0x00, 0x11, 0xCD, 0xBF, 0x01, 0x03,
-0x12, 0x71, 0x5F, 0x90, 0x88, 0x39, 0xE0, 0xB4,
+0xED, 0x2E, 0x90, 0x86, 0xB4, 0xF1, 0x69, 0xFF,
+0xED, 0x2F, 0x90, 0x86, 0xB5, 0xF1, 0x96, 0xFF,
+0xED, 0x2F, 0x90, 0x86, 0xB6, 0xF1, 0xFD, 0xFF,
+0xED, 0x2F, 0x90, 0x86, 0xB7, 0xF1, 0xF3, 0xFF,
+0xED, 0x2F, 0x90, 0x86, 0xB8, 0xF0, 0xF1, 0x63,
+0xFF, 0xED, 0x2F, 0x90, 0x86, 0xB9, 0x12, 0xA2,
+0x26, 0xFF, 0xAE, 0x05, 0xED, 0x2F, 0x90, 0x86,
+0xBA, 0xF0, 0x22, 0x90, 0x00, 0x05, 0x02, 0x02,
+0x1F, 0xF0, 0x90, 0x00, 0x01, 0x02, 0x02, 0x1F,
+0x12, 0xA2, 0x1F, 0x12, 0x02, 0x06, 0x90, 0x93,
+0x60, 0xF1, 0x69, 0x90, 0x93, 0x61, 0xF1, 0x96,
+0x90, 0x93, 0x7B, 0xF1, 0xFD, 0x90, 0x93, 0x7C,
+0xF1, 0xF3, 0x90, 0x93, 0x96, 0xF0, 0xF1, 0x63,
+0x90, 0x93, 0x97, 0xF0, 0x22, 0x4F, 0xF0, 0x90,
+0x00, 0x02, 0x02, 0x02, 0x1F, 0x12, 0xA7, 0x4E,
+0xFF, 0xF1, 0x6A, 0xFE, 0x54, 0x03, 0xFD, 0xEE,
+0x13, 0x13, 0x54, 0x07, 0xFB, 0xC0, 0x03, 0xF1,
+0xEB, 0xF1, 0x97, 0x54, 0x0F, 0x90, 0x97, 0x57,
+0xF0, 0xD0, 0x03, 0x12, 0xE5, 0xB8, 0xF1, 0xEB,
+0xF1, 0x6A, 0xFE, 0x54, 0x03, 0x12, 0x8D, 0x2C,
+0x90, 0x95, 0x57, 0x74, 0x10, 0xF0, 0x90, 0x95,
+0x79, 0x74, 0x07, 0xF1, 0xEA, 0x12, 0x02, 0x06,
+0x90, 0x95, 0x59, 0xF0, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x57, 0x12, 0x90, 0x39, 0x7F, 0x04, 0x02,
+0x04, 0x7E, 0xF0, 0x90, 0x95, 0x54, 0xC1, 0x39,
+0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00, 0x04, 0x02,
+0x02, 0x1F, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00,
+0x03, 0x02, 0x02, 0x1F, 0x90, 0x95, 0x54, 0x12,
+0x86, 0x42, 0x90, 0x93, 0xE7, 0xE0, 0x70, 0x13,
+0x12, 0x87, 0xEB, 0x12, 0x02, 0x06, 0x13, 0x13,
+0x54, 0x3F, 0x30, 0xE0, 0x06, 0x90, 0x93, 0xED,
+0x74, 0x01, 0xF0, 0x90, 0x93, 0xE9, 0xE0, 0x70,
+0x13, 0x12, 0x87, 0xEB, 0x12, 0x02, 0x06, 0xC4,
+0x54, 0x0F, 0xFF, 0xBF, 0x05, 0x06, 0x90, 0x93,
+0xEE, 0x74, 0x01, 0xF0, 0x12, 0x87, 0xEB, 0x12,
+0x87, 0x6A, 0xFF, 0x90, 0x95, 0x58, 0xF0, 0x12,
+0x02, 0x06, 0xC3, 0x13, 0x30, 0xE0, 0x0C, 0x12,
+0x87, 0xEB, 0x12, 0x87, 0x97, 0x90, 0x95, 0x59,
+0xF0, 0x80, 0x05, 0x90, 0x95, 0x59, 0xEF, 0xF0,
+0x90, 0x95, 0x58, 0xE0, 0x90, 0x95, 0x57, 0xF0,
+0x90, 0x95, 0x59, 0xE0, 0xFE, 0x90, 0x95, 0x57,
+0xE0, 0xFF, 0xD3, 0x9E, 0x50, 0x3A, 0x12, 0x87,
+0xEB, 0x12, 0x02, 0x06, 0x54, 0x01, 0xFD, 0x12,
+0x6E, 0x71, 0x90, 0x95, 0x57, 0xE0, 0xFF, 0x12,
+0x78, 0x4A, 0xEF, 0x90, 0x95, 0x57, 0x70, 0x06,
+0xE0, 0xFF, 0xF1, 0xF3, 0x80, 0x05, 0xE0, 0xFF,
+0x12, 0xD0, 0x10, 0x90, 0x93, 0xEE, 0xE0, 0x60,
+0x07, 0x90, 0x95, 0x57, 0xE0, 0xFF, 0xF1, 0xF3,
+0x90, 0x95, 0x57, 0xE0, 0x04, 0xF0, 0x80, 0xB8,
+0x90, 0x05, 0x5E, 0xE4, 0xF0, 0x90, 0x95, 0x58,
+0xE0, 0x70, 0x1A, 0xFF, 0x12, 0x78, 0x4A, 0xEF,
+0x70, 0x13, 0x90, 0x86, 0x0C, 0x51, 0x66, 0x90,
+0x8A, 0xED, 0x51, 0x66, 0x12, 0xEE, 0x52, 0x54,
+0xBF, 0xF0, 0x54, 0x7F, 0xF0, 0x22, 0x90, 0x97,
+0x45, 0x12, 0x86, 0x42, 0x90, 0x97, 0x44, 0xEF,
+0xF0, 0x12, 0x86, 0x4B, 0x89, 0x6C, 0x00, 0x89,
+0x71, 0x01, 0x89, 0x75, 0x06, 0x89, 0x8B, 0x10,
+0x89, 0x90, 0x12, 0x89, 0x95, 0x14, 0x89, 0x9A,
+0x16, 0x89, 0x9F, 0x18, 0x89, 0xA4, 0x19, 0x89,
+0xA9, 0x1B, 0x89, 0xAE, 0x1C, 0x89, 0xB3, 0x1E,
+0x89, 0xB8, 0x20, 0x89, 0xBD, 0x24, 0x89, 0xC2,
+0x25, 0x89, 0xC7, 0x27, 0x89, 0xCC, 0x29, 0x89,
+0xD1, 0x2A, 0x89, 0xD6, 0x40, 0x89, 0xDD, 0x42,
+0x89, 0xE8, 0x43, 0x8A, 0x56, 0x47, 0x89, 0xED,
+0x49, 0x89, 0xF2, 0x60, 0x89, 0xF7, 0x61, 0x89,
+0xFC, 0x62, 0x8A, 0x01, 0x63, 0x8A, 0x06, 0x64,
+0x8A, 0x0B, 0x65, 0x8A, 0x10, 0x66, 0x8A, 0x15,
+0x67, 0x8A, 0x1A, 0x68, 0x8A, 0x1F, 0x69, 0x8A,
+0x24, 0x6B, 0x8A, 0x29, 0x6C, 0x8A, 0x2E, 0x6D,
+0x8A, 0x33, 0x6E, 0x8A, 0x38, 0x6F, 0x8A, 0x3D,
+0x70, 0x8A, 0x42, 0xC3, 0x89, 0x7A, 0xC6, 0x89,
+0x7A, 0xC7, 0x89, 0x7A, 0xC8, 0x89, 0x86, 0xCB,
+0x00, 0x00, 0x8A, 0x47, 0x51, 0x57, 0x02, 0x87,
+0x1D, 0x51, 0x57, 0x01, 0x04, 0x51, 0x57, 0x02,
+0xAA, 0x0F, 0x90, 0x97, 0x44, 0xE0, 0xFF, 0xA3,
+0x12, 0x86, 0x39, 0x02, 0xD0, 0x15, 0x51, 0x57,
+0x02, 0xAD, 0x6E, 0x51, 0x57, 0x02, 0x97, 0xFE,
+0x51, 0x57, 0x02, 0xA8, 0x41, 0x51, 0x57, 0x02,
+0xAF, 0xE6, 0x51, 0x57, 0x02, 0x87, 0x70, 0x51,
+0x57, 0x02, 0xA0, 0x78, 0x51, 0x57, 0x02, 0xA1,
+0x7E, 0x51, 0x57, 0x02, 0xA7, 0xC7, 0x51, 0x57,
+0x02, 0x87, 0x9D, 0x51, 0x57, 0x02, 0xA9, 0x91,
+0x51, 0x57, 0x02, 0xAF, 0xF5, 0x51, 0x57, 0x02,
+0x94, 0x23, 0x51, 0x57, 0x02, 0xC0, 0x04, 0x51,
+0x57, 0x02, 0xC0, 0x43, 0x51, 0x57, 0x02, 0xAF,
+0xB6, 0x51, 0x57, 0x02, 0xC7, 0xF7, 0x51, 0x57,
+0x90, 0x8A, 0xA5, 0x80, 0x05, 0x51, 0x57, 0x90,
+0x8A, 0xB5, 0x12, 0xAC, 0x14, 0x02, 0x04, 0x7E,
+0x51, 0x57, 0x02, 0x25, 0xEC, 0x51, 0x57, 0x02,
+0xDC, 0x82, 0x51, 0x57, 0x02, 0xC0, 0x6C, 0x51,
+0x57, 0x02, 0x77, 0x4F, 0x51, 0x57, 0x02, 0x7C,
+0x60, 0x51, 0x57, 0x02, 0x7A, 0xC6, 0x51, 0x57,
+0x02, 0x5D, 0x36, 0x51, 0x57, 0x02, 0x7B, 0xE9,
+0x51, 0x57, 0x02, 0x70, 0x33, 0x51, 0x57, 0x02,
+0x48, 0xC9, 0x51, 0x57, 0x02, 0x79, 0xF3, 0x51,
+0x57, 0x02, 0xAA, 0xA3, 0x51, 0x57, 0x02, 0x51,
+0x7B, 0x51, 0x57, 0x02, 0x79, 0x30, 0x51, 0x57,
+0x02, 0x57, 0xF2, 0x51, 0x57, 0x02, 0x74, 0x8D,
+0x51, 0x57, 0x02, 0x78, 0x9A, 0x51, 0x57, 0x02,
+0x5E, 0x0B, 0x51, 0x57, 0x02, 0xCF, 0xFA, 0x90,
+0x01, 0xC0, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x97,
+0x44, 0xE0, 0x90, 0x01, 0xC2, 0xF0, 0x22, 0x90,
+0x97, 0x45, 0x02, 0x86, 0x39, 0x7D, 0xFF, 0xE4,
+0xFF, 0xF1, 0x64, 0x90, 0x8A, 0xFD, 0xE0, 0xFE,
+0xA3, 0xE0, 0xAA, 0x06, 0xF9, 0x02, 0x04, 0x7A,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x97, 0x73, 0xED, 0xF0, 0x90, 0x88, 0x31, 0xE0,
+0xFE, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0,
+0x02, 0x61, 0xE2, 0xEE, 0x12, 0x97, 0x35, 0x30,
+0xE0, 0x02, 0x61, 0xE2, 0x90, 0x88, 0x39, 0xE0,
+0xFE, 0x6F, 0x70, 0x02, 0x61, 0xE2, 0xEF, 0x70,
+0x02, 0x61, 0x3E, 0x24, 0xFE, 0x70, 0x02, 0x61,
+0x83, 0x24, 0xFE, 0x60, 0x4F, 0x24, 0xFC, 0x70,
+0x02, 0x61, 0xC8, 0x24, 0xFC, 0x60, 0x02, 0x61,
+0xDB, 0xEE, 0xB4, 0x0E, 0x03, 0x12, 0x71, 0x5F,
+0x90, 0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01,
+0x12, 0x78, 0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4,
 0x06, 0x03, 0x12, 0x71, 0x24, 0x90, 0x88, 0x39,
-0xE0, 0xB4, 0x0C, 0x0B, 0x90, 0x86, 0x00, 0x11,
-0xCD, 0xBF, 0x01, 0x03, 0x12, 0x68, 0xC2, 0x90,
-0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12,
-0x78, 0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x04,
-0x18, 0x12, 0x7A, 0x49, 0x80, 0x13, 0x90, 0x88,
-0x39, 0xE0, 0xB4, 0x0C, 0x0C, 0x90, 0x88, 0x32,
-0x12, 0xB5, 0x2C, 0x30, 0xE0, 0x03, 0x12, 0x79,
-0xD4, 0x90, 0x88, 0x39, 0x12, 0xBE, 0x83, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90, 0x95,
-0x4E, 0x02, 0x86, 0x39, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x12, 0xD3, 0xE6, 0xFF, 0x54,
-0x01, 0xFE, 0x90, 0x88, 0x9D, 0x12, 0xBE, 0x90,
-0x4F, 0xF0, 0xFC, 0x12, 0x02, 0x06, 0xFD, 0x54,
-0x04, 0x13, 0x13, 0x54, 0x3F, 0xFF, 0x90, 0x95,
-0x38, 0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0xED, 0x54,
-0x08, 0xFF, 0xEC, 0x54, 0xF7, 0x4F, 0xFF, 0x90,
-0x88, 0x9D, 0xF0, 0x12, 0x02, 0x06, 0x12, 0xBE,
-0x6D, 0x90, 0x88, 0x9D, 0x12, 0xBE, 0x5A, 0x4E,
-0xFF, 0xF0, 0x12, 0x02, 0x06, 0xFE, 0x54, 0x40,
-0xFD, 0xEF, 0x54, 0xBF, 0x4D, 0xFF, 0x90, 0x88,
-0x9D, 0xF0, 0xEE, 0x54, 0x80, 0xFE, 0xEF, 0x54,
-0x7F, 0x4E, 0x51, 0x4D, 0xE9, 0x24, 0x01, 0xF9,
-0xE4, 0x3A, 0x8B, 0x45, 0x12, 0xAF, 0xDE, 0x7B,
-0x01, 0x7A, 0x88, 0x79, 0x9E, 0x12, 0x69, 0xF5,
-0x12, 0x87, 0xEC, 0xFF, 0x54, 0x03, 0x90, 0x88,
-0x9F, 0xF0, 0xEF, 0x54, 0x04, 0x13, 0x13, 0x54,
-0x01, 0x25, 0xE0, 0x25, 0xE0, 0xFF, 0x90, 0x95,
-0x44, 0xE0, 0x54, 0xFB, 0x4F, 0xF0, 0x12, 0x02,
-0x06, 0x20, 0xE0, 0x02, 0x81, 0x3E, 0x90, 0x05,
-0x54, 0xE0, 0x90, 0x88, 0xAE, 0xF0, 0xE0, 0xC3,
-0x13, 0x90, 0x88, 0xAD, 0xF0, 0x90, 0x88, 0xA0,
-0xE0, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x11, 0xF1,
-0x98, 0x90, 0x88, 0x9E, 0x12, 0xEC, 0x23, 0x12,
-0x87, 0xF1, 0x90, 0x88, 0x9F, 0xF0, 0x80, 0x24,
-0xF1, 0x98, 0xFF, 0xC3, 0x94, 0x2A, 0x50, 0x14,
-0xEF, 0xC3, 0x94, 0x03, 0x50, 0x07, 0x90, 0x88,
-0x9E, 0x74, 0x03, 0x80, 0x0C, 0xF1, 0x92, 0x90,
-0x88, 0x9E, 0x80, 0x05, 0x90, 0x88, 0x9E, 0x74,
-0x2A, 0x12, 0xEC, 0x23, 0x12, 0xAC, 0xC7, 0x30,
-0xE0, 0x3D, 0x90, 0x88, 0x9E, 0xE0, 0x75, 0xF0,
-0x03, 0x84, 0x90, 0x88, 0xA6, 0xF0, 0xE0, 0xC3,
-0x13, 0xA3, 0xF0, 0x90, 0x88, 0x9F, 0xE0, 0x75,
-0xF0, 0x03, 0x84, 0x90, 0x88, 0xA8, 0xF0, 0x90,
-0x88, 0x9E, 0xE0, 0xC3, 0x13, 0x90, 0x88, 0xA9,
-0xF0, 0x90, 0x88, 0x9F, 0xE0, 0xC3, 0x13, 0x90,
-0x88, 0xAA, 0xF0, 0x90, 0x01, 0x3E, 0x74, 0x08,
-0xF0, 0xFD, 0x7F, 0x02, 0x12, 0x7C, 0x05, 0xE4,
-0x90, 0x88, 0xDD, 0xF0, 0x12, 0xE6, 0x44, 0x30,
-0xE0, 0x18, 0x12, 0xEB, 0xEB, 0x30, 0xE0, 0x0C,
-0x90, 0x8A, 0x89, 0xD1, 0x5A, 0x7D, 0x04, 0x7F,
-0x02, 0x12, 0x04, 0x7E, 0x12, 0xEC, 0x1B, 0x74,
-0x11, 0xF0, 0x90, 0x95, 0x38, 0xE0, 0x30, 0xE0,
-0x33, 0x90, 0x95, 0x41, 0x74, 0x01, 0xF0, 0xE4,
-0xA3, 0xF0, 0x90, 0x06, 0xC7, 0xE0, 0xFE, 0x90,
-0x06, 0xC6, 0x12, 0xBA, 0x70, 0xFE, 0xE4, 0xFD,
-0x78, 0x10, 0x12, 0xCD, 0xF4, 0x90, 0x06, 0xC5,
-0xE0, 0xFE, 0x90, 0x06, 0xC4, 0x12, 0xBA, 0x70,
-0xFE, 0xE4, 0xFD, 0x12, 0x86, 0x20, 0x90, 0x95,
-0x3D, 0x12, 0x04, 0x31, 0x90, 0x95, 0x44, 0xE0,
-0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x13, 0xA3,
-0xE0, 0x20, 0xE0, 0x07, 0x54, 0x01, 0x44, 0x64,
-0xF0, 0x80, 0x07, 0x90, 0x95, 0x45, 0xE0, 0x54,
-0xFE, 0xF0, 0x12, 0xAF, 0xC8, 0x90, 0x88, 0xA5,
-0xE0, 0xB4, 0x01, 0x08, 0x90, 0x88, 0xB0, 0x74,
-0x01, 0xF0, 0x80, 0x2B, 0x90, 0x88, 0xA5, 0xE0,
-0xB4, 0x04, 0x08, 0x90, 0x88, 0xB0, 0x74, 0x04,
-0xF0, 0x80, 0x1C, 0x90, 0x88, 0xA5, 0xE0, 0xB4,
-0x06, 0x08, 0x90, 0x88, 0xB0, 0x74, 0x02, 0xF0,
-0x80, 0x0D, 0x90, 0x88, 0xA5, 0xE0, 0xB4, 0x07,
-0x06, 0x90, 0x88, 0xB0, 0x74, 0x05, 0xF0, 0xE4,
-0x90, 0x88, 0xA5, 0xF0, 0x80, 0x3C, 0x90, 0x8A,
-0xF1, 0x11, 0xCD, 0x90, 0x89, 0x04, 0xE0, 0x90,
-0x00, 0x40, 0x30, 0xE0, 0x08, 0xE0, 0x54, 0x0F,
-0x44, 0xA0, 0xF0, 0x80, 0x06, 0xE0, 0x54, 0x0F,
-0x44, 0x20, 0xF0, 0x51, 0x4E, 0x12, 0x87, 0x9F,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x04,
-0x7F, 0x03, 0x80, 0x02, 0x7F, 0x01, 0x12, 0x71,
-0x9A, 0x12, 0xA4, 0xC2, 0x12, 0xEC, 0x1B, 0x74,
-0x43, 0xF0, 0x90, 0x88, 0xA3, 0xE0, 0x54, 0xDF,
-0xF0, 0xE4, 0x90, 0x88, 0xAF, 0xF0, 0xF1, 0x87,
-0x30, 0xE0, 0x09, 0x90, 0x88, 0xD0, 0xE0, 0x44,
-0x02, 0xF0, 0x80, 0x11, 0x90, 0x8A, 0x97, 0xD1,
-0x5A, 0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x88,
-0xD0, 0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x8A, 0xD9,
-0xD1, 0x5A, 0x7F, 0x03, 0x12, 0x04, 0x7E, 0x90,
-0x88, 0x9D, 0xE0, 0x20, 0xE0, 0x07, 0x90, 0x88,
-0xA1, 0xE0, 0x54, 0xBF, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x90, 0x97, 0x16, 0x12, 0x86, 0x42,
-0x90, 0x97, 0x15, 0xEF, 0xF0, 0x12, 0x86, 0x4B,
-0x8D, 0x58, 0x00, 0x8D, 0x5D, 0x01, 0x8D, 0x62,
-0x06, 0x8D, 0x78, 0x10, 0x8D, 0x7D, 0x12, 0x8D,
-0x82, 0x14, 0x8D, 0x87, 0x16, 0x8D, 0x8C, 0x18,
-0x8D, 0x91, 0x19, 0x8D, 0x96, 0x1B, 0x8D, 0x9B,
-0x1C, 0x8D, 0x9F, 0x1E, 0x8D, 0xA4, 0x20, 0x8D,
-0xA9, 0x24, 0x8D, 0xAE, 0x25, 0x8D, 0xB3, 0x27,
-0x8D, 0xB8, 0x29, 0x8D, 0xBD, 0x2A, 0x8D, 0xC2,
-0x40, 0x8D, 0xC9, 0x42, 0x8D, 0xD4, 0x43, 0x8E,
-0x41, 0x47, 0x8D, 0xD9, 0x49, 0x8D, 0xDE, 0x60,
-0x8D, 0xE2, 0x61, 0x8D, 0xE7, 0x62, 0x8D, 0xEC,
-0x63, 0x8D, 0xF1, 0x64, 0x8D, 0xF6, 0x65, 0x8D,
-0xFB, 0x66, 0x8E, 0x00, 0x67, 0x8E, 0x05, 0x68,
-0x8E, 0x0A, 0x69, 0x8E, 0x0F, 0x6B, 0x8E, 0x14,
-0x6C, 0x8E, 0x19, 0x6D, 0x8E, 0x1E, 0x6E, 0x8E,
-0x23, 0x6F, 0x8E, 0x28, 0x70, 0x8E, 0x2D, 0xC3,
-0x8D, 0x67, 0xC6, 0x8D, 0x67, 0xC7, 0x8D, 0x67,
-0xC8, 0x8D, 0x73, 0xCB, 0x00, 0x00, 0x8E, 0x32,
-0xD1, 0x42, 0x02, 0x87, 0x1D, 0xD1, 0x42, 0x02,
-0x87, 0xFE, 0xD1, 0x42, 0x02, 0xCC, 0x09, 0x90,
-0x97, 0x15, 0xE0, 0xFF, 0xA3, 0x12, 0x86, 0x39,
-0x02, 0xD0, 0x3B, 0xD1, 0x42, 0x02, 0xCE, 0x00,
-0xD1, 0x42, 0x02, 0xA0, 0x08, 0xD1, 0x42, 0x02,
-0xBF, 0xDD, 0xD1, 0x42, 0x02, 0xC0, 0xB7, 0xD1,
-0x42, 0x02, 0x87, 0x74, 0xD1, 0x42, 0x02, 0xA7,
-0xFA, 0xD1, 0x42, 0x02, 0xAF, 0xE6, 0xD1, 0x42,
-0x02, 0xB0, 0x8B, 0xD1, 0x42, 0xE1, 0x9E, 0xD1,
-0x42, 0x02, 0xC0, 0xC6, 0xD1, 0x42, 0x02, 0xBD,
-0x1E, 0xD1, 0x42, 0x02, 0xA9, 0x02, 0xD1, 0x42,
-0x02, 0xC1, 0x89, 0xD1, 0x42, 0x02, 0xB0, 0xFC,
-0xD1, 0x42, 0x02, 0xC7, 0xD4, 0xD1, 0x42, 0x02,
-0xC1, 0xCC, 0xD1, 0x42, 0x90, 0x8A, 0xA5, 0x80,
-0x05, 0xD1, 0x42, 0x90, 0x8A, 0xB5, 0x12, 0xC9,
-0xA1, 0x02, 0x04, 0x7E, 0xD1, 0x42, 0x02, 0x25,
-0xEC, 0xD1, 0x42, 0x02, 0xDF, 0xB2, 0xD1, 0x42,
-0x41, 0x54, 0xD1, 0x42, 0x02, 0x77, 0x4F, 0xD1,
-0x42, 0x02, 0x7C, 0x60, 0xD1, 0x42, 0x02, 0x7A,
-0xC6, 0xD1, 0x42, 0x02, 0x5D, 0x36, 0xD1, 0x42,
-0x02, 0x7B, 0xE9, 0xD1, 0x42, 0x02, 0x70, 0x33,
-0xD1, 0x42, 0x02, 0x48, 0xC9, 0xD1, 0x42, 0x02,
-0x79, 0xF3, 0xD1, 0x42, 0x02, 0xC8, 0x20, 0xD1,
-0x42, 0x02, 0x51, 0x7B, 0xD1, 0x42, 0x02, 0x79,
-0x30, 0xD1, 0x42, 0x02, 0x57, 0xF2, 0xD1, 0x42,
-0x02, 0x74, 0x8D, 0xD1, 0x42, 0x02, 0x78, 0x9A,
-0xD1, 0x42, 0x02, 0x5E, 0x0B, 0xD1, 0x42, 0x02,
-0xCF, 0x1C, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x01,
-0xF0, 0x90, 0x97, 0x15, 0xE0, 0x90, 0x01, 0xC2,
-0xF0, 0x22, 0x90, 0x97, 0x16, 0x02, 0x86, 0x39,
-0x90, 0x8A, 0x77, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0xF5, 0x82, 0x8E, 0x83, 0x12, 0x04, 0x7E, 0x90,
-0x8A, 0x79, 0xE0, 0xFE, 0xA3, 0xE0, 0xF5, 0x82,
-0x8E, 0x83, 0x22, 0x90, 0x8A, 0xD9, 0xD1, 0x5A,
-0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA1,
-0xF1, 0x8A, 0x30, 0xE0, 0x04, 0x7F, 0x03, 0x80,
-0x02, 0x7F, 0x01, 0x12, 0x71, 0x9A, 0xE4, 0x90,
-0x88, 0xAF, 0xF0, 0xA3, 0x12, 0xE6, 0x4C, 0x30,
-0xE0, 0x09, 0x90, 0x8A, 0xF9, 0xD1, 0x5A, 0x7D,
-0x0E, 0x80, 0x32, 0x12, 0xE6, 0x44, 0x30, 0xE0,
-0x17, 0x12, 0xEB, 0xEB, 0x20, 0xE0, 0x08, 0x12,
-0xAB, 0xDD, 0xE4, 0xFD, 0x12, 0x04, 0x7E, 0x90,
-0x8A, 0xF9, 0xD1, 0x5A, 0x7D, 0x0F, 0x80, 0x15,
-0x90, 0x88, 0x36, 0xE0, 0x60, 0x14, 0x12, 0xAB,
-0xDD, 0xE4, 0xFD, 0x12, 0x04, 0x7E, 0x90, 0x8A,
-0xF9, 0xD1, 0x5A, 0x7D, 0x10, 0x7F, 0x6F, 0x12,
-0x04, 0x7E, 0x90, 0x88, 0xA0, 0xE0, 0x30, 0xE0,
-0x08, 0x90, 0x8A, 0xF9, 0xD1, 0x5A, 0x12, 0xAC,
-0x6E, 0xF1, 0x87, 0x30, 0xE0, 0x0A, 0x90, 0x8A,
-0x97, 0xD1, 0x5A, 0xE4, 0xFF, 0x12, 0x04, 0x7E,
-0x90, 0x88, 0xA1, 0xE0, 0xFF, 0xC3, 0x13, 0x30,
-0xE0, 0x0E, 0x90, 0x06, 0xCD, 0xE0, 0x54, 0xEF,
-0xF0, 0x90, 0x06, 0xCF, 0xE0, 0x54, 0xEF, 0xF0,
-0x12, 0xBE, 0x63, 0x30, 0xE0, 0x19, 0xEF, 0x13,
-0x13, 0x54, 0x3F, 0x30, 0xE0, 0x11, 0xEE, 0x44,
-0x08, 0xF0, 0xA3, 0xE0, 0xC3, 0x13, 0x54, 0x7F,
-0xFF, 0x90, 0x8A, 0xD1, 0x12, 0xAD, 0xA8, 0x90,
-0x05, 0x63, 0xE0, 0x90, 0x97, 0x2C, 0xF0, 0x90,
-0x05, 0x62, 0xE0, 0x90, 0x97, 0x2B, 0xF0, 0x90,
-0x05, 0x61, 0xE0, 0x90, 0x97, 0x2A, 0xF0, 0x90,
-0x05, 0x60, 0xE0, 0x90, 0x97, 0x29, 0x12, 0xCD,
-0xEA, 0x90, 0x97, 0x29, 0xF1, 0xEA, 0x12, 0x86,
+0xE0, 0xB4, 0x04, 0x11, 0x90, 0x97, 0x73, 0xE0,
+0xFF, 0x60, 0x05, 0x12, 0x67, 0x80, 0x80, 0x05,
+0x90, 0x8A, 0xED, 0x51, 0x66, 0x90, 0x88, 0x39,
+0xE0, 0x64, 0x08, 0x60, 0x02, 0x61, 0xDB, 0x12,
+0x7B, 0xCC, 0x61, 0xDB, 0x90, 0x88, 0x39, 0xE0,
+0x70, 0x05, 0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71,
+0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B,
+0x90, 0x86, 0x00, 0x51, 0x66, 0xBF, 0x01, 0x03,
+0x12, 0x71, 0x5F, 0x90, 0x88, 0x39, 0xE0, 0x64,
+0x0C, 0x60, 0x02, 0x61, 0xDB, 0x90, 0x86, 0x00,
+0x51, 0x66, 0xEF, 0x64, 0x01, 0x60, 0x02, 0x61,
+0xDB, 0x12, 0x68, 0xC2, 0x61, 0xDB, 0x90, 0x88,
+0x39, 0xE0, 0xB4, 0x0E, 0x0B, 0x90, 0x86, 0x00,
+0x51, 0x66, 0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F,
+0x90, 0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12,
+0x71, 0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C,
+0x0B, 0x90, 0x86, 0x00, 0x51, 0x66, 0xBF, 0x01,
+0x03, 0x12, 0x68, 0xC2, 0x90, 0x88, 0x39, 0xE0,
+0x64, 0x04, 0x70, 0x67, 0x90, 0x86, 0x02, 0x51,
+0x66, 0xEF, 0x64, 0x01, 0x70, 0x5D, 0x12, 0x73,
+0x5A, 0x80, 0x58, 0x90, 0x88, 0x39, 0xE0, 0xB4,
+0x0E, 0x0B, 0x90, 0x86, 0x00, 0x51, 0x66, 0xBF,
+0x01, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88, 0x39,
+0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0B, 0x90, 0x86,
+0x00, 0x51, 0x66, 0xBF, 0x01, 0x03, 0x12, 0x68,
+0xC2, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F,
+0x01, 0x12, 0x78, 0xC0, 0x90, 0x88, 0x39, 0xE0,
+0xB4, 0x04, 0x18, 0x12, 0x7A, 0x49, 0x80, 0x13,
+0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0C, 0x90,
+0x88, 0x32, 0x12, 0xB5, 0x23, 0x30, 0xE0, 0x03,
+0x12, 0x79, 0xD4, 0x90, 0x88, 0x39, 0x12, 0xED,
+0xB4, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4,
+0xFB, 0xFA, 0xFD, 0x7F, 0x01, 0x12, 0x85, 0x4E,
+0x90, 0x95, 0xD6, 0xEF, 0xF0, 0x60, 0xF0, 0x90,
+0x86, 0xAF, 0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0,
+0x60, 0xE5, 0xC2, 0xAF, 0xEF, 0x30, 0xE0, 0x0F,
+0x90, 0x86, 0xAF, 0xE0, 0x54, 0xFE, 0xF0, 0xE4,
+0xFF, 0x12, 0xB7, 0xE5, 0x12, 0xDD, 0x30, 0x91,
+0x42, 0x30, 0xE1, 0x08, 0x54, 0xFD, 0xF0, 0x90,
+0x86, 0x08, 0x51, 0x66, 0x91, 0x42, 0x30, 0xE2,
+0x08, 0x54, 0xFB, 0xF0, 0x90, 0x86, 0x0A, 0x51,
+0x66, 0x91, 0x42, 0x30, 0xE6, 0x08, 0x54, 0xBF,
+0xF0, 0x90, 0x8A, 0x7D, 0x51, 0x66, 0xD2, 0xAF,
+0x80, 0xB5, 0xD2, 0xAF, 0xC2, 0xAF, 0x90, 0x86,
+0xAF, 0xE0, 0x22, 0x51, 0x63, 0xEF, 0x70, 0x02,
+0xFF, 0x22, 0x12, 0x99, 0xA1, 0x90, 0x93, 0xAC,
+0xF0, 0x90, 0x93, 0x58, 0xE0, 0xFF, 0xC3, 0x13,
+0xFE, 0xEF, 0x54, 0xF1, 0xFF, 0xEE, 0x04, 0x54,
+0x07, 0x25, 0xE0, 0x4F, 0xF0, 0xA3, 0xE0, 0xFF,
+0x90, 0x93, 0x58, 0xE0, 0xFE, 0xC3, 0x13, 0x54,
+0x07, 0xB5, 0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0,
+0x12, 0x99, 0xA1, 0xF5, 0x7D, 0xE4, 0x90, 0x93,
+0x5A, 0xF0, 0xE5, 0x7D, 0x75, 0xF0, 0x1B, 0xA4,
+0x24, 0x5F, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5,
+0x83, 0xE0, 0x30, 0xE0, 0x2A, 0xB1, 0x20, 0xE0,
+0x24, 0xAF, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5,
+0x83, 0xE0, 0xFF, 0xE5, 0x7D, 0xD1, 0xFC, 0xF5,
+0x83, 0xEF, 0xB1, 0x1F, 0xE0, 0x04, 0xB1, 0x1F,
+0xE0, 0xFF, 0x90, 0x93, 0xAE, 0xE0, 0xFE, 0xEF,
+0xB5, 0x06, 0x04, 0xB1, 0x20, 0xE4, 0xF0, 0xE5,
+0x7D, 0xD1, 0xFC, 0xF5, 0x83, 0xE0, 0xFC, 0x90,
+0x93, 0xAC, 0xE0, 0xD1, 0xFC, 0xF5, 0x83, 0xE0,
+0x6C, 0x60, 0x0D, 0xE5, 0x7D, 0xF1, 0xD7, 0x12,
+0xE5, 0xA3, 0xE5, 0x7D, 0xF1, 0xD7, 0xB1, 0x2C,
+0xE5, 0x7D, 0x12, 0x9A, 0xCA, 0x54, 0x07, 0xFF,
+0x60, 0x03, 0xBF, 0x02, 0x0F, 0xE5, 0x7D, 0x12,
+0x98, 0x24, 0xE0, 0xFF, 0x7E, 0x00, 0x7B, 0x04,
+0xE4, 0xFD, 0xF1, 0x87, 0xAD, 0x7D, 0x7F, 0x01,
+0x12, 0x99, 0xAD, 0x90, 0x93, 0xAD, 0xE0, 0xC3,
+0x13, 0x54, 0x03, 0xFF, 0xBF, 0x02, 0x05, 0xE4,
+0xFF, 0x12, 0x9F, 0xF0, 0x7F, 0x01, 0x22, 0xF0,
+0x74, 0xD2, 0x25, 0x7D, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xF5, 0x83, 0x22, 0xFF, 0xEE, 0x13, 0x13,
+0x54, 0x07, 0xFD, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x97, 0x6A, 0xED, 0xF0, 0xE4,
+0xA3, 0xF0, 0xEF, 0x14, 0x60, 0x02, 0xC1, 0x17,
+0x90, 0x06, 0x03, 0xE0, 0x54, 0xFB, 0xF0, 0x90,
+0x97, 0x6A, 0xE0, 0xFB, 0xC4, 0x33, 0x54, 0xE0,
+0xFE, 0x90, 0x04, 0x42, 0xE0, 0x54, 0x9F, 0x4E,
+0xFE, 0xF0, 0xE4, 0xFD, 0x12, 0xE6, 0x3F, 0x90,
+0x97, 0x6B, 0xEF, 0xF0, 0x90, 0x04, 0x83, 0xF0,
+0x90, 0x97, 0x10, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0x01, 0x90, 0x97, 0x14, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x00, 0x01, 0xD1, 0xDF, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x00, 0x01, 0x90, 0x97, 0x14,
+0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x01, 0x7F,
+0x00, 0x7E, 0x09, 0xD1, 0xE3, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x00, 0x10, 0x90, 0x97, 0x6A, 0xF1,
+0xEC, 0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x01,
+0x12, 0x03, 0xEB, 0x78, 0x04, 0xD1, 0xE9, 0x7F,
+0x00, 0x7E, 0x0A, 0xD1, 0xE3, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x0C, 0x00, 0x90, 0x97, 0x6A, 0xF1,
+0xEC, 0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x0A,
+0xD1, 0xE9, 0x7F, 0x00, 0x7E, 0x0D, 0xD1, 0xE3,
+0x12, 0x04, 0x3D, 0x0C, 0x00, 0x00, 0x00, 0x90,
+0x97, 0x6B, 0xF1, 0xEC, 0xEF, 0x54, 0x03, 0xFF,
+0xE4, 0x78, 0x1A, 0xD1, 0xE9, 0x7F, 0x18, 0xD1,
+0xE1, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00,
+0x90, 0x97, 0x14, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0x00, 0xD1, 0xF2, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x0C, 0x00, 0x90, 0x97, 0x02, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x04, 0x00, 0x80, 0x58, 0x90,
+0x06, 0x03, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x97,
+0x10, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x01,
+0x90, 0x97, 0x14, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0x00, 0xD1, 0xDF, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0x01, 0x90, 0x97, 0x14, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x00, 0x7E,
+0x09, 0xD1, 0xE3, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x0C, 0x00, 0x90, 0x97, 0x14, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x0C, 0x00, 0xD1, 0xF2, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x97, 0x02,
+0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00, 0x7D,
+0x18, 0x7C, 0x00, 0xE4, 0xFF, 0x12, 0xE5, 0x2D,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x0E, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x70, 0x70, 0x90,
+0x97, 0x18, 0x12, 0x04, 0x31, 0x90, 0x97, 0x10,
+0x12, 0x04, 0xB8, 0x12, 0x03, 0xCD, 0x90, 0x97,
+0x18, 0x12, 0xE6, 0x39, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x97, 0x10, 0x12,
+0x04, 0xB8, 0x90, 0x97, 0x14, 0x12, 0xE6, 0x39,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0x12, 0x86, 0x20, 0x90, 0x97, 0x1C, 0x12, 0x04,
+0x31, 0x90, 0x97, 0x1C, 0x12, 0xD2, 0xF5, 0x90,
+0x97, 0x0E, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x12,
+0x70, 0xAD, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7F,
+0x00, 0x7E, 0x08, 0xD1, 0x7D, 0x90, 0x97, 0x10,
+0x22, 0x12, 0x03, 0xFE, 0x90, 0x97, 0x14, 0x02,
+0x04, 0x31, 0x7F, 0x84, 0x7E, 0x08, 0xD1, 0x7D,
+0x90, 0x96, 0xFE, 0x22, 0x75, 0xF0, 0x1B, 0xA4,
+0x24, 0x5B, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0x22,
+0x8F, 0x65, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x95,
+0x54, 0xF0, 0x7B, 0x17, 0x51, 0x5D, 0xEF, 0x64,
+0x01, 0x70, 0x36, 0xE5, 0x65, 0xD1, 0xFC, 0xF5,
+0x83, 0xE0, 0xFC, 0xF1, 0xD5, 0x12, 0xE5, 0xA3,
+0xF1, 0xD5, 0xB1, 0x2C, 0xE5, 0x65, 0x12, 0x9A,
+0xCA, 0x54, 0x07, 0xFF, 0x60, 0x03, 0xBF, 0x02,
+0x0E, 0xE5, 0x65, 0x12, 0x98, 0x24, 0xE0, 0xFF,
+0x7E, 0x00, 0xE4, 0xFB, 0xFD, 0xF1, 0x87, 0xAD,
+0x65, 0x7F, 0x01, 0x12, 0x99, 0xAD, 0x7F, 0x01,
+0x22, 0x90, 0x95, 0x54, 0xE0, 0xFD, 0x7B, 0x49,
+0xE4, 0xFF, 0xF1, 0x64, 0x7F, 0x00, 0x22, 0xE4,
+0xFB, 0xFD, 0x7F, 0xFF, 0xEB, 0xB4, 0x57, 0x05,
+0x12, 0xED, 0xE4, 0x80, 0x10, 0xEF, 0x70, 0x07,
+0x90, 0x93, 0xF3, 0xE0, 0x4D, 0x80, 0x06, 0x12,
+0xAF, 0xA4, 0x12, 0xED, 0xE4, 0x90, 0x05, 0x22,
+0xF0, 0x90, 0x93, 0x01, 0xEB, 0xF0, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x97,
+0x33, 0xEE, 0xF0, 0xA3, 0x12, 0xAF, 0x7F, 0x90,
+0x04, 0x1D, 0xE0, 0x60, 0x2A, 0x90, 0x05, 0x22,
+0xE0, 0x90, 0x97, 0x39, 0xF0, 0x7B, 0x14, 0x51,
+0x5D, 0xEF, 0x64, 0x01, 0x70, 0x08, 0x12, 0xED,
+0x49, 0x12, 0xC4, 0x1E, 0x80, 0x04, 0x7F, 0x00,
+0x80, 0x16, 0x90, 0x97, 0x39, 0xE0, 0xFD, 0x7B,
+0x15, 0xE4, 0xFF, 0xF1, 0x64, 0x80, 0x06, 0x12,
+0xED, 0x49, 0x12, 0xC4, 0x1E, 0x12, 0xC7, 0xDB,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE5, 0x65, 0x75,
+0xF0, 0x1B, 0xA4, 0x24, 0x5C, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xE0, 0xFE, 0x54, 0x03,
+0x22, 0x90, 0x95, 0x57, 0xE0, 0xFF, 0xE4, 0xFC,
+0xFD, 0xFE, 0x22, 0x7D, 0x01, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x64, 0xEF,
+0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x8A, 0xF9, 0x11,
+0x4B, 0x7D, 0x44, 0x7F, 0x6F, 0x12, 0x04, 0x7E,
+0x12, 0x8A, 0x63, 0x90, 0x97, 0x65, 0xE0, 0x90,
+0x97, 0x64, 0xB4, 0x01, 0x09, 0xE0, 0xF1, 0xB1,
+0xE0, 0x44, 0x04, 0xF0, 0x80, 0x07, 0xE0, 0xF1,
+0xB1, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x8A, 0xF9,
+0x11, 0x4B, 0xF1, 0x87, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x8A, 0x77, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0xF5, 0x82, 0x8E, 0x83, 0x12, 0x04, 0x7E,
+0x90, 0x8A, 0x79, 0xE0, 0xFE, 0xA3, 0xE0, 0xF5,
+0x82, 0x8E, 0x83, 0x22, 0x90, 0x95, 0x4E, 0xE0,
+0x04, 0xF0, 0x90, 0x8A, 0xD9, 0x11, 0x4B, 0x7F,
+0x01, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA1, 0xF1,
+0x34, 0x30, 0xE0, 0x04, 0x7F, 0x03, 0x80, 0x02,
+0x7F, 0x01, 0x12, 0x71, 0x9A, 0xE4, 0x90, 0x88,
+0xAF, 0xF0, 0xA3, 0xF1, 0xF4, 0x30, 0xE0, 0x09,
+0x90, 0x8A, 0xF9, 0x11, 0x4B, 0x7D, 0x0E, 0x80,
+0x2F, 0xF1, 0xEA, 0x30, 0xE0, 0x16, 0x12, 0xC7,
+0xE4, 0x20, 0xE0, 0x07, 0xF1, 0x3C, 0xE4, 0xFD,
+0x12, 0x04, 0x7E, 0x90, 0x8A, 0xF9, 0x11, 0x4B,
+0x7D, 0x0F, 0x80, 0x14, 0x90, 0x88, 0x36, 0xE0,
+0x60, 0x13, 0xF1, 0x3C, 0xE4, 0xFD, 0x12, 0x04,
+0x7E, 0x90, 0x8A, 0xF9, 0x11, 0x4B, 0x7D, 0x10,
+0x7F, 0x6F, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA0,
+0xE0, 0x30, 0xE0, 0x07, 0x90, 0x8A, 0xF9, 0x11,
+0x4B, 0xF1, 0x87, 0x90, 0x88, 0xA0, 0xF1, 0x34,
+0x30, 0xE0, 0x0A, 0x90, 0x8A, 0x97, 0x11, 0x4B,
+0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA1,
+0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x0E, 0x90,
+0x06, 0xCD, 0xE0, 0x54, 0xEF, 0xF0, 0x90, 0x06,
+0xCF, 0xE0, 0x54, 0xEF, 0xF0, 0x12, 0xD7, 0x80,
+0x30, 0xE0, 0x1C, 0xEF, 0x13, 0x13, 0x54, 0x3F,
+0x30, 0xE0, 0x14, 0xEE, 0x44, 0x08, 0xF0, 0xA3,
+0xE0, 0xC3, 0x13, 0x54, 0x7F, 0xFF, 0x90, 0x8A,
+0xD1, 0x12, 0xC4, 0x37, 0x12, 0x04, 0x7E, 0x90,
+0x05, 0x63, 0xE0, 0x90, 0x97, 0x3D, 0xF0, 0x90,
+0x05, 0x62, 0xE0, 0x90, 0x97, 0x3C, 0xF0, 0x90,
+0x05, 0x61, 0xE0, 0x90, 0x97, 0x3B, 0xF0, 0x90,
+0x05, 0x60, 0xE0, 0x90, 0x97, 0x3A, 0x12, 0x9D,
+0x32, 0x90, 0x97, 0x3A, 0x12, 0x8F, 0xEC, 0x12,
+0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x97, 0x3C, 0x12, 0x8F, 0xEC,
+0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0,
+0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x20,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0xA3, 0x12, 0x8F, 0xEC, 0x78, 0x18, 0x12, 0x03,
+0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x86, 0x20, 0x90, 0x95, 0x46, 0x12,
+0x04, 0x31, 0x12, 0xC6, 0x1D, 0x90, 0x97, 0x3E,
+0xF0, 0x7B, 0x01, 0x7A, 0x97, 0x79, 0x3E, 0x90,
+0x8A, 0xCF, 0x11, 0x4B, 0x7D, 0x01, 0x7F, 0x42,
+0x02, 0x04, 0x7E, 0x90, 0x95, 0x54, 0xEF, 0xF0,
+0x91, 0x1C, 0x7F, 0xF4, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x9B, 0xE0,
+0x90, 0x95, 0x9D, 0xF0, 0x91, 0x1C, 0x7F, 0xF5,
+0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08,
+0x90, 0x95, 0x9B, 0xE0, 0x90, 0x95, 0x9E, 0xF0,
+0x91, 0x1C, 0x7F, 0xF6, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x9B, 0xE0,
+0x90, 0x95, 0x9F, 0xF0, 0x91, 0x1C, 0x7F, 0xF7,
+0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08,
+0x90, 0x95, 0x9B, 0xE0, 0x90, 0x95, 0xA0, 0xF0,
+0x91, 0x1C, 0x7F, 0xF8, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x9B, 0xE0,
+0x90, 0x95, 0xA1, 0xF0, 0x91, 0x1C, 0x12, 0xAF,
+0x6F, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x9B, 0xE0,
+0x90, 0x95, 0xA2, 0xF0, 0x91, 0x1C, 0xF1, 0x8D,
+0x64, 0x01, 0x70, 0x54, 0x90, 0x95, 0x9B, 0xE0,
+0x90, 0x95, 0xA3, 0xF0, 0x54, 0x07, 0x60, 0x08,
+0x90, 0x95, 0x9B, 0xE0, 0x54, 0xE0, 0x70, 0x40,
+0x7B, 0x01, 0x7A, 0x95, 0x79, 0x9C, 0x7F, 0xFA,
+0xF1, 0x8F, 0x64, 0x01, 0x70, 0x32, 0x90, 0x95,
+0x9B, 0xE0, 0xFC, 0x54, 0x07, 0x70, 0x12, 0x90,
+0x95, 0xA3, 0xE0, 0xFE, 0x90, 0x95, 0x9C, 0xE0,
+0x54, 0x07, 0xFD, 0xEE, 0x4D, 0x90, 0x95, 0xA3,
+0xF0, 0xEC, 0x54, 0xE0, 0x70, 0x12, 0x90, 0x95,
+0xA3, 0xE0, 0xFF, 0x90, 0x95, 0x9C, 0xE0, 0x54,
+0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x95, 0xA3, 0xF0,
+0x91, 0x1C, 0x7F, 0xFD, 0xF1, 0x8F, 0x64, 0x01,
+0x70, 0x47, 0x90, 0x95, 0x9B, 0xE0, 0xFE, 0x54,
+0xCC, 0x90, 0x95, 0xA4, 0xF0, 0xEE, 0x54, 0x0C,
+0xFF, 0x60, 0x08, 0x90, 0x95, 0x9B, 0xE0, 0x54,
+0xC0, 0x70, 0x2E, 0xEF, 0x70, 0x12, 0x90, 0x95,
+0xA4, 0xE0, 0xFF, 0x90, 0x95, 0x9B, 0xE0, 0x54,
+0x03, 0x12, 0xEE, 0x42, 0x90, 0x95, 0xA4, 0xF0,
+0x90, 0x95, 0x9B, 0xE0, 0xFF, 0x54, 0xC0, 0x70,
+0x10, 0x90, 0x95, 0xA4, 0xE0, 0xFE, 0xEF, 0x54,
+0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF, 0xEE, 0x4F,
+0xF0, 0x91, 0x1C, 0x7F, 0xF0, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x9B,
+0xE0, 0x90, 0x95, 0xA5, 0xF0, 0x91, 0x1C, 0x7F,
+0xF1, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
+0x08, 0x90, 0x95, 0x9B, 0xE0, 0x90, 0x95, 0xA6,
+0xF0, 0x91, 0x1C, 0x7F, 0xF2, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x9B,
+0xE0, 0x90, 0x95, 0xA7, 0xF0, 0x91, 0x1C, 0x7F,
+0xF3, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
+0x08, 0x90, 0x95, 0x9B, 0xE0, 0x90, 0x95, 0xA8,
+0xF0, 0x91, 0x1C, 0x7F, 0xFC, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x9B,
+0xE0, 0x90, 0x95, 0xA9, 0xF0, 0x90, 0x95, 0x55,
+0x74, 0x19, 0xF0, 0x90, 0x95, 0x77, 0x74, 0x08,
+0xF0, 0x90, 0x95, 0x9D, 0xE0, 0x90, 0x95, 0x57,
+0xF0, 0x90, 0x95, 0x9E, 0xE0, 0x90, 0x95, 0x58,
+0xF0, 0x90, 0x95, 0x9F, 0xE0, 0x90, 0x95, 0x59,
+0xF0, 0x90, 0x95, 0xA0, 0xE0, 0x90, 0x95, 0x5A,
+0xF0, 0x90, 0x95, 0xA1, 0xE0, 0x90, 0x95, 0x5B,
+0xF0, 0x90, 0x95, 0xA2, 0xE0, 0x90, 0x95, 0x5C,
+0xF0, 0x90, 0x95, 0xA3, 0xE0, 0x90, 0x95, 0x5D,
+0xF0, 0x90, 0x95, 0xA4, 0xE0, 0x90, 0x95, 0x5E,
+0xF0, 0x90, 0x95, 0x78, 0x74, 0x1A, 0xF0, 0x90,
+0x95, 0x9A, 0x74, 0x05, 0xF0, 0x90, 0x95, 0xA5,
+0xE0, 0x90, 0x95, 0x7A, 0xF0, 0x90, 0x95, 0xA6,
+0xE0, 0x90, 0x95, 0x7B, 0xF0, 0x90, 0x95, 0xA7,
+0xE0, 0x90, 0x95, 0x7C, 0xF0, 0x90, 0x95, 0xA8,
+0xE0, 0x90, 0x95, 0x7D, 0xF0, 0x90, 0x95, 0xA9,
+0xE0, 0x90, 0x95, 0x7E, 0xF0, 0x90, 0x00, 0x35,
+0xE0, 0x54, 0xFC, 0x44, 0x01, 0xF0, 0x91, 0x1C,
+0x7F, 0x6F, 0x7E, 0x00, 0x12, 0x5F, 0xA6, 0xBF,
+0x01, 0x08, 0x90, 0x95, 0x9B, 0xE0, 0x90, 0x95,
+0xAA, 0xF0, 0x90, 0x00, 0x35, 0xE0, 0x54, 0xFC,
+0xF0, 0x90, 0x95, 0x54, 0xE0, 0xB4, 0x01, 0x19,
+0x7B, 0x01, 0x7A, 0x95, 0x79, 0x55, 0x12, 0xAC,
+0x11, 0x12, 0x04, 0x7E, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x78, 0x11, 0x39, 0x7F, 0x04, 0x02, 0x04,
+0x7E, 0x75, 0x45, 0x01, 0x75, 0x46, 0x95, 0x75,
+0x47, 0x55, 0x75, 0x48, 0x0A, 0x7B, 0x01, 0x7A,
+0x01, 0x79, 0xA0, 0x12, 0x69, 0xF5, 0x75, 0x45,
+0x01, 0x75, 0x46, 0x95, 0x75, 0x47, 0x7A, 0x75,
+0x48, 0x05, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xAA,
+0x12, 0x69, 0xF5, 0x90, 0x95, 0xAA, 0xE0, 0x90,
+0x01, 0xA1, 0xF0, 0x22, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x9B, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x12, 0xA2, 0x1F, 0x90, 0x05, 0x27,
+0xE0, 0x54, 0x7F, 0xF5, 0x64, 0x8B, 0x45, 0x8A,
+0x46, 0x89, 0x47, 0x75, 0x48, 0x01, 0x7B, 0x01,
+0x7A, 0x88, 0x79, 0x2C, 0x12, 0x69, 0xF5, 0x12,
+0xA1, 0x75, 0xFF, 0xC3, 0x13, 0x20, 0xE0, 0x02,
+0x81, 0xDD, 0x90, 0x88, 0x2C, 0xE0, 0x30, 0xE0,
+0x72, 0xF1, 0xDB, 0x75, 0x64, 0x21, 0x12, 0xEE,
+0x23, 0x30, 0xE0, 0x05, 0x12, 0xED, 0xA4, 0x80,
+0x0D, 0xE4, 0x90, 0x88, 0x2D, 0xF0, 0xA3, 0xF0,
+0x7D, 0x40, 0xFF, 0x12, 0x7C, 0x7E, 0x90, 0x88,
+0x2C, 0x12, 0xB5, 0x8F, 0x30, 0xE0, 0x03, 0x43,
+0x64, 0x12, 0xEF, 0xC4, 0x54, 0x0F, 0x30, 0xE0,
+0x03, 0x43, 0x64, 0x14, 0x90, 0x88, 0x2C, 0xE0,
+0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x03, 0x43,
+0x64, 0x80, 0x12, 0xC3, 0x4A, 0x20, 0xE0, 0x03,
+0x43, 0x64, 0x40, 0xB1, 0x96, 0x90, 0x88, 0x2F,
+0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0xE8, 0x85,
+0x12, 0xD7, 0x8A, 0x30, 0xE0, 0x04, 0x7F, 0x04,
+0x80, 0x0C, 0x12, 0x9E, 0x67, 0xEF, 0x60, 0x04,
+0x7F, 0x01, 0x80, 0x02, 0x7F, 0x02, 0x12, 0xE8,
+0x85, 0xA1, 0x52, 0xB1, 0x93, 0x90, 0x88, 0x2F,
+0xE0, 0x64, 0x04, 0x60, 0x02, 0xA1, 0x8E, 0xFF,
+0x12, 0xE8, 0x85, 0xA1, 0x8E, 0x90, 0x88, 0x2C,
+0xE0, 0x30, 0xE0, 0x76, 0xF1, 0xDB, 0x43, 0x64,
+0x31, 0x12, 0xEE, 0x23, 0x30, 0xE0, 0x05, 0x12,
+0xED, 0xA4, 0x80, 0x07, 0x7D, 0x40, 0xE4, 0xFF,
+0x12, 0x7C, 0x7E, 0x90, 0x88, 0x2C, 0x12, 0xB5,
+0x8F, 0x30, 0xE0, 0x03, 0x43, 0x64, 0x02, 0xEF,
+0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x03, 0x43, 0x64,
+0x04, 0xB1, 0x96, 0x12, 0xD7, 0x8A, 0x30, 0xE0,
+0x0F, 0xF1, 0xD4, 0x60, 0x35, 0x90, 0x8A, 0xB9,
+0x11, 0x4B, 0xE4, 0xFD, 0x7F, 0x02, 0x80, 0x1D,
+0xF1, 0xE2, 0xF1, 0xD4, 0x70, 0x1C, 0x12, 0x7B,
+0xAD, 0x12, 0x9E, 0x67, 0xBF, 0x01, 0x06, 0xF1,
+0x3C, 0x7D, 0x01, 0x80, 0x08, 0x90, 0x8A, 0xB9,
+0x11, 0x4B, 0xE4, 0xFD, 0xFF, 0x12, 0x04, 0x7E,
+0x80, 0x08, 0x90, 0x88, 0x39, 0xE0, 0x90, 0x88,
+0x30, 0xF0, 0x90, 0x05, 0x40, 0x74, 0x22, 0xF0,
+0x80, 0x34, 0xB1, 0x93, 0x90, 0x88, 0x30, 0xE0,
+0xB4, 0x02, 0x0B, 0x90, 0x8A, 0xB9, 0x11, 0x4B,
+0x7D, 0x01, 0x7F, 0x04, 0x80, 0x10, 0x90, 0x88,
+0x30, 0xE0, 0xB4, 0x08, 0x0C, 0x90, 0x8A, 0xB9,
+0x11, 0x4B, 0x7D, 0x01, 0x7F, 0x0C, 0x12, 0x04,
+0x7E, 0x12, 0xEA, 0x4A, 0xF1, 0x3C, 0x7D, 0x01,
+0x12, 0x04, 0x7E, 0x12, 0xAF, 0xCA, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x75, 0x64, 0x21, 0x90, 0x05,
+0x27, 0xE5, 0x64, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x54, 0x74,
+0x02, 0xF0, 0x90, 0x88, 0xC2, 0xE0, 0x44, 0x10,
+0xF0, 0x90, 0x88, 0xAF, 0xE0, 0x60, 0x02, 0xE1,
+0x2C, 0x90, 0x8A, 0xD9, 0x11, 0x4B, 0xE4, 0xFF,
+0x12, 0x04, 0x7E, 0x90, 0x88, 0xA1, 0xE0, 0x30,
+0xE0, 0x04, 0x7F, 0x01, 0x80, 0x37, 0x90, 0x88,
+0x9D, 0x12, 0xC3, 0x4D, 0x30, 0xE0, 0x04, 0x7F,
+0x0D, 0x80, 0x2A, 0x90, 0x88, 0xA0, 0xE0, 0xFF,
+0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x10, 0xEF, 0x13,
+0x13, 0x54, 0x3F, 0x30, 0xE0, 0x04, 0x7F, 0x09,
+0x80, 0x13, 0x7F, 0x03, 0x80, 0x0F, 0x90, 0x88,
+0xA0, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x04, 0x7F,
+0x03, 0x80, 0x02, 0x7F, 0x09, 0x12, 0x71, 0x9A,
+0x90, 0x88, 0xAF, 0x74, 0x01, 0xF1, 0xF4, 0x30,
+0xE0, 0x05, 0x12, 0x8F, 0x5F, 0x80, 0x3A, 0xF1,
+0xEA, 0x30, 0xE0, 0x35, 0x90, 0x88, 0xA3, 0xE0,
+0x44, 0x20, 0xF0, 0x90, 0x88, 0x9C, 0xE0, 0x60,
+0x0B, 0x90, 0x8A, 0xB9, 0x11, 0x4B, 0x7D, 0x01,
+0x7F, 0x04, 0x80, 0x11, 0x12, 0x8F, 0x5F, 0xF1,
+0x31, 0x90, 0x8A, 0xB9, 0x20, 0xE0, 0x0B, 0x11,
+0x4B, 0x7D, 0x01, 0x7F, 0x0C, 0x12, 0x04, 0x7E,
+0x80, 0x07, 0x11, 0x4B, 0xF1, 0xCD, 0x12, 0xD8,
+0xDD, 0x90, 0x88, 0x9C, 0xE0, 0x60, 0x06, 0x7B,
+0x04, 0x7D, 0x6F, 0x80, 0x03, 0xE4, 0xFB, 0xFD,
+0x7F, 0xFF, 0x12, 0x8F, 0x64, 0x90, 0x88, 0xA0,
+0xF1, 0x34, 0x30, 0xE0, 0x0A, 0x90, 0x8A, 0x97,
+0x11, 0x4B, 0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90,
+0x88, 0xA1, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x0E,
+0x90, 0x06, 0xCD, 0xE0, 0x44, 0x10, 0xF0, 0x90,
+0x06, 0xCF, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x05,
+0x63, 0xE0, 0x90, 0x95, 0x58, 0xF0, 0x90, 0x05,
+0x62, 0xE0, 0x90, 0x95, 0x57, 0xF0, 0x90, 0x05,
+0x61, 0xE0, 0x90, 0x95, 0x56, 0xF0, 0x90, 0x05,
+0x60, 0xE0, 0x90, 0x95, 0x55, 0x12, 0x9D, 0x32,
+0x90, 0x95, 0x55, 0x12, 0x8F, 0xEC, 0x12, 0x86,
 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x90, 0x97, 0x2B, 0xF1, 0xEA, 0x78, 0x10,
-0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3, 0xF1,
-0xEA, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86,
-0x20, 0x90, 0x95, 0x46, 0x02, 0x04, 0x31, 0x90,
-0x88, 0xA0, 0xE0, 0xC4, 0x13, 0x13, 0x13, 0x54,
-0x01, 0x22, 0x90, 0x95, 0x4E, 0x12, 0x86, 0x39,
-0x90, 0x00, 0x01, 0x02, 0x02, 0x1F, 0x12, 0xD3,
-0xE6, 0xFF, 0xF1, 0x98, 0xFE, 0x54, 0x03, 0xFD,
-0xEE, 0x13, 0x13, 0x54, 0x07, 0xFB, 0xC0, 0x03,
-0x12, 0x87, 0xEC, 0x54, 0x0F, 0x90, 0x97, 0x28,
-0xF0, 0xD0, 0x03, 0x12, 0xA7, 0x03, 0xF1, 0x92,
-0xFE, 0x54, 0x03, 0x12, 0xA1, 0xFC, 0x90, 0x95,
-0x51, 0x74, 0x10, 0xF0, 0x90, 0x95, 0x73, 0x74,
-0x07, 0x51, 0x4D, 0x12, 0x02, 0x06, 0x90, 0x95,
-0x53, 0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x51,
-0xD1, 0x48, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0x90,
-0x95, 0x51, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE,
-0x22, 0x7D, 0x01, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x97, 0x39, 0xEF, 0xF0, 0xA3,
-0xED, 0xF0, 0x90, 0x8A, 0xF9, 0x12, 0x8E, 0x5A,
-0x7D, 0x44, 0x7F, 0x6F, 0x12, 0x04, 0x7E, 0x12,
-0x88, 0xCA, 0x90, 0x97, 0x3A, 0xE0, 0x90, 0x97,
-0x39, 0xB4, 0x01, 0x09, 0xE0, 0x11, 0x3C, 0xE0,
-0x44, 0x04, 0xF0, 0x80, 0x07, 0xE0, 0x11, 0x3C,
-0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x8A, 0xF9, 0x12,
-0x8E, 0x5A, 0x12, 0xAC, 0x6E, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xE5, 0x0E, 0xC4, 0x54, 0xF0, 0x24,
-0x05, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
-0x22, 0x8D, 0x0E, 0xEF, 0x30, 0xE6, 0x1C, 0x11,
-0xD2, 0xE0, 0xFD, 0x11, 0x3A, 0xE0, 0x54, 0x03,
-0x90, 0x92, 0x80, 0xF0, 0xE4, 0xFB, 0xAF, 0x0E,
-0x12, 0x75, 0x80, 0x11, 0xC5, 0x11, 0xE1, 0x74,
-0x01, 0x80, 0x51, 0x11, 0xE8, 0x04, 0xF0, 0x11,
-0xE8, 0x64, 0x02, 0x70, 0x1E, 0x74, 0x5E, 0x25,
-0x0E, 0x31, 0xB7, 0xE0, 0xFD, 0xF4, 0x60, 0x02,
-0x80, 0x04, 0x11, 0xD2, 0xE0, 0xFD, 0x11, 0x3A,
-0x12, 0xEB, 0x2E, 0x11, 0xD2, 0x11, 0xE1, 0x74,
-0x02, 0x80, 0x29, 0x11, 0xE8, 0xD3, 0x94, 0x03,
-0x40, 0x13, 0x90, 0x8A, 0xB3, 0x12, 0x8E, 0x5A,
-0xAF, 0x0E, 0x12, 0x04, 0x7E, 0x11, 0xC5, 0x11,
-0xE1, 0x74, 0x03, 0x80, 0x0F, 0x11, 0xD2, 0xE0,
-0xFD, 0x11, 0x3A, 0x12, 0xEB, 0x2E, 0x11, 0xD2,
-0x11, 0xE1, 0x74, 0x02, 0xF0, 0xAB, 0x0E, 0xE4,
-0xFD, 0xFF, 0x02, 0x6F, 0x75, 0x74, 0xB6, 0x25,
-0x0E, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
-0xE4, 0xF0, 0xE5, 0x0E, 0xC4, 0x54, 0xF0, 0x24,
-0x00, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
-0x22, 0xE0, 0x90, 0x92, 0x5E, 0xF0, 0xA3, 0x22,
-0x74, 0xB6, 0x25, 0x0E, 0xF5, 0x82, 0xE4, 0x34,
-0x8E, 0xF5, 0x83, 0xE0, 0x22, 0x8F, 0x75, 0x8D,
-0x76, 0xEF, 0x11, 0xD4, 0xE0, 0xFD, 0x54, 0x7F,
-0xF5, 0x77, 0xED, 0x54, 0x80, 0xF5, 0x78, 0x12,
-0xE1, 0xB2, 0xF5, 0x7A, 0x75, 0xF0, 0x12, 0xEF,
-0x12, 0x9B, 0xEB, 0xC4, 0x54, 0x03, 0xF5, 0x7B,
-0x31, 0xB3, 0x74, 0xFF, 0xF0, 0x31, 0xBF, 0xE5,
-0x78, 0x4D, 0xFF, 0x12, 0xE1, 0x95, 0xEF, 0xF0,
-0xE5, 0x75, 0x11, 0x3C, 0xE0, 0x54, 0x03, 0xF5,
-0x79, 0x74, 0x46, 0x25, 0x75, 0x12, 0xE1, 0xA1,
-0xE5, 0x79, 0xF0, 0xE5, 0x77, 0x65, 0x7A, 0x70,
-0x22, 0x75, 0xF0, 0x12, 0xE5, 0x75, 0x12, 0x9D,
-0x5F, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x0B,
-0xE5, 0x78, 0x70, 0x07, 0xE5, 0x77, 0x44, 0x80,
-0xFD, 0x80, 0x4B, 0x31, 0xBF, 0x7D, 0x07, 0xAF,
-0x75, 0x61, 0x45, 0xE5, 0x77, 0xC3, 0x95, 0x7A,
-0x50, 0x35, 0xAB, 0x75, 0xAD, 0x7A, 0xAF, 0x77,
-0x12, 0x72, 0x7F, 0xAD, 0x07, 0xE5, 0x77, 0xC3,
-0x94, 0x0C, 0x40, 0x2A, 0x75, 0xF0, 0x12, 0xE5,
-0x75, 0x12, 0x9D, 0x5F, 0xFE, 0xC4, 0x13, 0x54,
-0x07, 0x30, 0xE0, 0x1A, 0xE5, 0x76, 0x60, 0x16,
-0xE5, 0x78, 0x70, 0x12, 0xE5, 0x77, 0x44, 0x80,
-0xFD, 0x31, 0xB3, 0xEF, 0xF0, 0x80, 0x07, 0x12,
-0xE1, 0x95, 0xE5, 0x7A, 0xF0, 0xFD, 0x90, 0x92,
-0x80, 0xE5, 0x79, 0xF0, 0xAB, 0x76, 0xAF, 0x75,
-0x02, 0x75, 0x80, 0x74, 0x5E, 0x25, 0x75, 0xF5,
-0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83, 0x22, 0xE5,
-0x77, 0x25, 0xE0, 0x24, 0x75, 0xF5, 0x82, 0xE4,
-0x34, 0x81, 0xF5, 0x83, 0xE4, 0x93, 0xFE, 0x74,
-0x01, 0x93, 0xFF, 0xE5, 0x75, 0x25, 0xE0, 0x24,
-0x75, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0xF3,
-0x12, 0xC0, 0xAE, 0x12, 0xE2, 0xE8, 0x90, 0x96,
-0xFE, 0xF0, 0xE4, 0x90, 0x96, 0xFB, 0xF0, 0x90,
-0x96, 0xF3, 0x12, 0xAB, 0xC5, 0x90, 0x96, 0xF6,
-0xF0, 0xEF, 0x54, 0x07, 0x90, 0x96, 0xF8, 0x71,
-0x2F, 0xE0, 0x90, 0x96, 0xF9, 0xF0, 0x12, 0xE1,
-0xB2, 0x54, 0x7F, 0x90, 0x96, 0xFC, 0xF0, 0x90,
-0x96, 0xF3, 0xE0, 0x12, 0xE1, 0xA9, 0xE0, 0x90,
-0x96, 0xFD, 0xF0, 0xED, 0x54, 0x7F, 0x90, 0x96,
-0xF7, 0xF0, 0xEB, 0x70, 0x21, 0x90, 0x89, 0x3D,
-0x71, 0xA8, 0xFF, 0x12, 0xEB, 0x42, 0xFD, 0x90,
-0x89, 0x40, 0x12, 0xD3, 0xCB, 0x2D, 0xFF, 0xE4,
-0x35, 0xF0, 0xC3, 0x13, 0xFE, 0xEF, 0x13, 0xFF,
-0x90, 0x96, 0xF3, 0xE0, 0x31, 0xD5, 0x90, 0x96,
-0xFC, 0xE0, 0xFF, 0x90, 0x96, 0xF7, 0xE0, 0xFE,
-0xD3, 0x9F, 0x40, 0x0C, 0x90, 0x96, 0xF4, 0xE0,
-0x54, 0x80, 0xFD, 0xEF, 0x4D, 0xF0, 0x80, 0x0F,
-0x90, 0x96, 0xFD, 0xE0, 0xFF, 0xEE, 0xC3, 0x9F,
-0x50, 0x05, 0x90, 0x96, 0xF4, 0xEF, 0xF0, 0x90,
-0x96, 0xF4, 0xE0, 0xFE, 0x54, 0x7F, 0x90, 0x96,
-0xF7, 0xF0, 0xEE, 0x54, 0x80, 0x90, 0x96, 0xFA,
-0xF0, 0x90, 0x96, 0xF5, 0xE0, 0x70, 0x22, 0xA3,
-0xE0, 0x71, 0xB0, 0xC0, 0x83, 0xC0, 0x82, 0x12,
-0xC2, 0x93, 0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8,
-0xFC, 0xF4, 0x5F, 0xD0, 0x82, 0xD0, 0x83, 0xF0,
-0x90, 0x96, 0xF9, 0xE0, 0x54, 0x7F, 0xF0, 0x80,
-0x3A, 0x90, 0x96, 0xF6, 0xE0, 0x71, 0xB0, 0xC0,
-0x83, 0xC0, 0x82, 0x12, 0xC2, 0x93, 0x08, 0x80,
-0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0xD0, 0x82,
-0xD0, 0x83, 0x71, 0x2F, 0xE0, 0x54, 0x07, 0xFF,
-0x90, 0x96, 0xF9, 0xF0, 0x90, 0x89, 0x46, 0x71,
-0xA8, 0xF5, 0x82, 0x12, 0xD3, 0xD0, 0x33, 0x33,
-0x33, 0x54, 0xF8, 0x4F, 0x90, 0x96, 0xF9, 0xF0,
-0x44, 0x80, 0xF0, 0x90, 0x96, 0xF4, 0x71, 0xA0,
-0x11, 0xD4, 0xEF, 0xF0, 0xEE, 0x70, 0x05, 0x90,
-0x01, 0xC8, 0xEF, 0xF0, 0x90, 0x96, 0xF9, 0x71,
-0xA0, 0x71, 0x34, 0xEF, 0xF0, 0xEE, 0x11, 0x3C,
-0xE0, 0x54, 0xFC, 0xFF, 0x90, 0x96, 0xFE, 0xE0,
-0x54, 0x03, 0x4F, 0xFE, 0x90, 0x96, 0xF3, 0xE0,
-0xFF, 0x11, 0x3C, 0xEE, 0xF0, 0x7D, 0x01, 0x12,
-0x61, 0xF7, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0,
-0x90, 0x96, 0xF3, 0xE0, 0xC4, 0x54, 0xF0, 0x24,
-0x01, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
-0x22, 0x7D, 0x07, 0xAF, 0x67, 0xED, 0x30, 0xE0,
-0x1E, 0x75, 0xF0, 0x12, 0xEF, 0x90, 0x89, 0x57,
-0x71, 0x8D, 0x90, 0x89, 0x59, 0x71, 0x8D, 0x90,
-0x89, 0x5B, 0x71, 0x8D, 0x90, 0x89, 0x5D, 0x71,
-0x8D, 0x90, 0x89, 0x5F, 0x71, 0x99, 0xF0, 0xED,
-0x30, 0xE1, 0x0A, 0x75, 0xF0, 0x12, 0xEF, 0x90,
-0x89, 0x53, 0x71, 0x99, 0xF0, 0xED, 0x30, 0xE2,
-0x05, 0x12, 0xD7, 0xC7, 0xE4, 0xF0, 0x12, 0xEA,
-0xDC, 0xE0, 0x54, 0xBF, 0x44, 0x80, 0xFE, 0x12,
-0xEA, 0xDC, 0xEE, 0xF0, 0x22, 0x12, 0x04, 0x6E,
-0xE4, 0xF0, 0xA3, 0xF0, 0x75, 0xF0, 0x12, 0xEF,
-0x22, 0x12, 0x04, 0x6E, 0xE4, 0xF0, 0xA3, 0x22,
-0xE0, 0xFF, 0x90, 0x96, 0xF3, 0xE0, 0xFE, 0x22,
-0x12, 0x86, 0x39, 0x90, 0x96, 0xF7, 0xE0, 0x22,
-0x24, 0x6F, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5,
-0x83, 0x22, 0x90, 0x04, 0x85, 0xE0, 0xF5, 0x70,
-0x90, 0x96, 0x5D, 0xE0, 0x04, 0xF0, 0xE4, 0xF5,
-0x67, 0x90, 0x88, 0x2B, 0xE0, 0xFF, 0xE5, 0x67,
-0xC3, 0x9F, 0x40, 0x03, 0x02, 0x9A, 0x4D, 0xE5,
-0x67, 0x11, 0xD4, 0xE0, 0xF5, 0x72, 0x12, 0xEB,
-0x97, 0xE0, 0x65, 0x72, 0x60, 0x16, 0x90, 0x92,
-0x5E, 0xE5, 0x72, 0xF0, 0xE4, 0xA3, 0xF0, 0xAB,
-0x67, 0xFD, 0xFF, 0x12, 0x6F, 0x75, 0x12, 0xEB,
-0x97, 0xE5, 0x72, 0xF0, 0x90, 0x04, 0xA0, 0xE0,
-0x64, 0x01, 0x70, 0x4E, 0xA3, 0xE0, 0x65, 0x67,
-0x70, 0x48, 0xA3, 0xE0, 0xF5, 0x68, 0xA3, 0xE0,
-0x90, 0x95, 0xDC, 0xF0, 0xE5, 0x67, 0x11, 0xD4,
-0xE0, 0x65, 0x68, 0x70, 0x03, 0x02, 0x9A, 0x48,
-0xE5, 0x67, 0x11, 0xD4, 0xE5, 0x68, 0xF0, 0xE5,
-0x67, 0x11, 0x3C, 0xE0, 0x54, 0xFC, 0xFF, 0x90,
-0x95, 0xDC, 0xE0, 0x54, 0x03, 0x4F, 0xFF, 0xE5,
-0x67, 0x11, 0x3C, 0xEF, 0xF0, 0x90, 0x92, 0x5E,
-0xE5, 0x68, 0xF0, 0xA3, 0x74, 0xFF, 0xF0, 0xAB,
-0x67, 0xE4, 0xFD, 0xFF, 0x12, 0x6F, 0x75, 0x02,
-0x9A, 0x48, 0x75, 0xF0, 0x12, 0xE5, 0x67, 0x12,
-0xD7, 0xCB, 0xE0, 0xFF, 0x90, 0x95, 0xD4, 0xE4,
-0xF0, 0xA3, 0xEF, 0xF0, 0x75, 0xF0, 0x12, 0xE5,
-0x67, 0x90, 0x89, 0x53, 0x12, 0x04, 0x6E, 0xE0,
-0xF5, 0x6D, 0xA3, 0xE0, 0xF5, 0x6E, 0xE5, 0x67,
-0x75, 0xF0, 0x12, 0xA4, 0x24, 0x57, 0xF9, 0x74,
-0x89, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x90, 0x95,
-0xD1, 0x12, 0x86, 0x42, 0x12, 0xEB, 0xD6, 0xFF,
-0x12, 0x03, 0x13, 0x2F, 0xFF, 0x12, 0xEB, 0xDC,
-0x2F, 0xFF, 0x12, 0xEB, 0x28, 0x2F, 0xFF, 0x12,
-0xEB, 0x0F, 0x2F, 0xF5, 0x71, 0xE5, 0x67, 0x11,
-0xD4, 0xE0, 0xF5, 0x68, 0x54, 0x80, 0xF5, 0x6A,
-0xE5, 0x68, 0x54, 0x7F, 0xF5, 0x69, 0x75, 0xF0,
-0x12, 0xE5, 0x67, 0x12, 0xD7, 0x75, 0xE0, 0x64,
-0x01, 0x60, 0x02, 0xC1, 0x16, 0x12, 0x9F, 0xF4,
-0x12, 0xEB, 0xD6, 0xFF, 0xAE, 0xF0, 0x12, 0x03,
-0x13, 0x2F, 0xFF, 0xE5, 0xF0, 0x3E, 0xFE, 0x12,
-0xEB, 0xDC, 0x2F, 0xFF, 0xEE, 0x12, 0xEB, 0x25,
-0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xFE, 0x12, 0xEB,
-0x0F, 0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0x90, 0x95,
-0xD6, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x03, 0x13,
-0xFF, 0xC3, 0x90, 0x95, 0xD7, 0xE0, 0x9F, 0xFE,
-0x90, 0x95, 0xD6, 0xE0, 0x95, 0xF0, 0x90, 0x95,
-0xD8, 0xF0, 0xA3, 0xCE, 0xF0, 0x12, 0xEB, 0x28,
-0xFD, 0xAC, 0xF0, 0x25, 0xE0, 0xFF, 0xEC, 0x33,
-0xFE, 0xEF, 0x2D, 0xFD, 0xEE, 0x3C, 0xFC, 0x12,
-0xEB, 0xDC, 0x25, 0xE0, 0xFF, 0xE5, 0xF0, 0x33,
-0xFE, 0x12, 0xEB, 0xD6, 0x2F, 0xFF, 0xEE, 0x35,
-0xF0, 0xCF, 0x2D, 0xFD, 0xEF, 0x3C, 0xFC, 0x12,
-0xEB, 0x09, 0xAE, 0xF0, 0x78, 0x02, 0xC3, 0x33,
-0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x2D, 0xFF, 0xEC,
-0x3E, 0x90, 0x95, 0xDA, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x95, 0xD4, 0x12, 0xEA, 0xB1, 0x12, 0xEB,
-0xAE, 0x12, 0xEA, 0xC2, 0x50, 0x08, 0x90, 0x95,
-0xD4, 0x12, 0xEA, 0xEA, 0x80, 0x04, 0x7E, 0xFF,
-0x7F, 0xFF, 0xE5, 0x67, 0x12, 0xEB, 0xAE, 0x31,
-0xDE, 0x90, 0x95, 0xD6, 0x12, 0xEA, 0xB1, 0x12,
-0xEB, 0xB8, 0x12, 0xEA, 0xC2, 0x50, 0x08, 0x90,
-0x95, 0xD6, 0x12, 0xEA, 0xEA, 0x80, 0x04, 0x7E,
-0xFF, 0x7F, 0xFF, 0xE5, 0x67, 0x12, 0xEB, 0xB8,
-0x31, 0xDE, 0x90, 0x95, 0xDA, 0x12, 0xEA, 0xB1,
-0x12, 0xEB, 0xC2, 0x12, 0xEA, 0xC2, 0x50, 0x08,
-0x90, 0x95, 0xDA, 0x12, 0xEA, 0xEA, 0x80, 0x04,
-0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x67, 0x12, 0xEB,
-0xC2, 0x31, 0xDE, 0xC3, 0x74, 0xFF, 0x95, 0x6E,
-0xFF, 0x74, 0xFF, 0x95, 0x6D, 0xFE, 0x12, 0xEB,
-0x8B, 0x12, 0xEA, 0xC2, 0x50, 0x0A, 0xE5, 0x6E,
-0x2D, 0xFF, 0xE5, 0x6D, 0x3C, 0xFE, 0x80, 0x04,
-0x7E, 0xFF, 0x7F, 0xFF, 0x12, 0xEB, 0x8B, 0x31,
-0xDE, 0x12, 0xEC, 0x13, 0xFB, 0xC3, 0x74, 0xFF,
-0x9B, 0xFF, 0x74, 0xFF, 0x9E, 0xFE, 0x74, 0xFF,
-0x94, 0x00, 0xFD, 0x74, 0xFF, 0x94, 0x00, 0xFC,
-0x90, 0x8D, 0x71, 0x12, 0xE6, 0x3D, 0x50, 0x12,
-0x12, 0xEC, 0x13, 0xFF, 0xE4, 0xFC, 0xFD, 0x90,
-0x8D, 0x71, 0x12, 0x86, 0x2D, 0x12, 0x85, 0xA9,
-0x80, 0x06, 0x74, 0xFF, 0xFF, 0xFE, 0xFD, 0xFC,
-0x90, 0x8D, 0x71, 0x12, 0x04, 0x31, 0xAF, 0x67,
-0x12, 0x78, 0x4A, 0xEF, 0x70, 0x03, 0x02, 0x9A,
-0x48, 0x75, 0xF0, 0x12, 0xE5, 0x67, 0x12, 0x9B,
-0xEB, 0x12, 0x8F, 0x8B, 0x30, 0xE0, 0x03, 0x02,
-0x9A, 0x48, 0xE5, 0x67, 0x13, 0x13, 0x13, 0x54,
-0x1F, 0x71, 0xB0, 0xE0, 0xFD, 0x7C, 0x00, 0xE5,
-0x67, 0x54, 0x07, 0xFF, 0x12, 0xC2, 0x9F, 0x80,
-0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
-0xFF, 0xEE, 0x5C, 0xFE, 0xEF, 0x5D, 0x4E, 0x60,
-0x03, 0x02, 0x9A, 0x48, 0xE5, 0x6E, 0x45, 0x6D,
-0x70, 0x0D, 0x90, 0x95, 0xD4, 0xE0, 0x70, 0x02,
-0xA3, 0xE0, 0x70, 0x03, 0x02, 0x9A, 0x48, 0x90,
-0x96, 0x4B, 0xE0, 0x60, 0x12, 0x75, 0x73, 0x0A,
-0x12, 0xEA, 0xCE, 0xE4, 0x93, 0xC3, 0x13, 0x74,
-0x01, 0x93, 0x13, 0xF5, 0x74, 0x80, 0x0A, 0x7B,
-0xFF, 0x12, 0xE0, 0x5E, 0xE4, 0xF5, 0x73, 0xF5,
-0x74, 0x75, 0xF0, 0x12, 0xE5, 0x67, 0x12, 0xE1,
-0xB6, 0xFF, 0xE5, 0x69, 0xD3, 0x9F, 0x40, 0x08,
-0x8F, 0x69, 0xE5, 0x69, 0x45, 0x6A, 0xF5, 0x68,
-0x12, 0x9A, 0x73, 0xE0, 0xC3, 0x94, 0x05, 0x40,
-0x03, 0x02, 0x98, 0x37, 0xE5, 0x69, 0x90, 0x81,
-0x61, 0x93, 0xF5, 0x6F, 0xFD, 0xAF, 0x69, 0x12,
-0x60, 0x6F, 0x8F, 0x6F, 0xE5, 0x6A, 0x60, 0x04,
-0x05, 0x6F, 0x05, 0x6F, 0xE5, 0x69, 0xC3, 0x94,
-0x0C, 0x40, 0x1D, 0x74, 0x4D, 0x25, 0x67, 0x12,
-0xEC, 0x0B, 0xE0, 0xFF, 0x54, 0x7F, 0xFE, 0xEF,
-0x30, 0xE7, 0x06, 0xE5, 0x6F, 0x2E, 0xFF, 0x80,
-0x05, 0xC3, 0xE5, 0x6F, 0x9E, 0xFF, 0x8F, 0x6F,
-0xE5, 0x6F, 0xD3, 0x94, 0x1A, 0xAF, 0x6F, 0x40,
-0x02, 0x7F, 0x1A, 0x8F, 0x6F, 0xE5, 0x68, 0x90,
-0x81, 0xD9, 0x93, 0xFF, 0xD3, 0x90, 0x95, 0xD5,
-0xE0, 0x9F, 0x90, 0x95, 0xD4, 0xE0, 0x94, 0x00,
-0x40, 0x02, 0xE1, 0xED, 0xC3, 0xE5, 0x6E, 0x94,
-0x0A, 0xE5, 0x6D, 0x94, 0x00, 0x50, 0x7C, 0x12,
-0xE0, 0x49, 0xE0, 0xC3, 0x94, 0x01, 0x40, 0x06,
-0x12, 0xE0, 0x49, 0xE0, 0x14, 0xF0, 0x12, 0xEB,
-0x09, 0xFF, 0x90, 0x95, 0xD5, 0xE0, 0x2F, 0xFF,
-0x90, 0x95, 0xD4, 0xE0, 0x12, 0xEB, 0x25, 0x2F,
-0xFD, 0xEE, 0x35, 0xF0, 0xFC, 0xE5, 0x6D, 0xC3,
-0x13, 0xFE, 0xE5, 0x6E, 0x13, 0xFF, 0xD3, 0xED,
-0x9F, 0xEC, 0x9E, 0x40, 0x0E, 0xE5, 0x67, 0x94,
-0x05, 0x50, 0x06, 0x12, 0xE0, 0x49, 0x74, 0x02,
-0xF0, 0xE1, 0xED, 0x12, 0x9F, 0xF4, 0x12, 0x03,
-0x13, 0x65, 0x71, 0x70, 0x02, 0xE5, 0xF0, 0x70,
-0x24, 0xE5, 0x67, 0xC3, 0x94, 0x05, 0x50, 0x12,
-0x12, 0xE0, 0x49, 0xE0, 0xD3, 0x94, 0x00, 0x40,
-0x09, 0x7D, 0x06, 0xAF, 0x67, 0x71, 0x45, 0x02,
-0x9A, 0x48, 0xE4, 0xFD, 0xAF, 0x67, 0x11, 0xF5,
-0x71, 0x41, 0x02, 0x9A, 0x2C, 0x12, 0xEB, 0xFC,
-0x02, 0x9A, 0x2C, 0x12, 0xE0, 0x49, 0xE4, 0xF0,
-0x90, 0x91, 0x6C, 0x74, 0x02, 0xF0, 0xAB, 0x6F,
-0xAD, 0x67, 0xAF, 0x6E, 0xAE, 0x6D, 0x12, 0x41,
-0x9C, 0x8E, 0x6B, 0x8F, 0x6C, 0x12, 0xEA, 0xCE,
-0xC3, 0x74, 0x01, 0x93, 0x95, 0x74, 0xFF, 0xE4,
-0x93, 0x94, 0x00, 0xFE, 0xD3, 0xE5, 0x6C, 0x9F,
-0xE5, 0x6B, 0x9E, 0x40, 0x0E, 0x12, 0x9F, 0xE6,
-0xE4, 0xF0, 0x7D, 0x01, 0xAF, 0x67, 0x11, 0xF5,
-0x02, 0x9A, 0x2C, 0x12, 0xEC, 0x03, 0xC3, 0xE5,
-0x6C, 0x9F, 0xE5, 0x6B, 0x94, 0x00, 0x50, 0x0F,
-0x12, 0x9F, 0xE6, 0xE4, 0xF0, 0x7D, 0x01, 0xAF,
-0x67, 0x12, 0xE0, 0xDE, 0x02, 0x9A, 0x2C, 0x71,
-0x41, 0x12, 0x9F, 0xE6, 0xE0, 0x04, 0xF0, 0xE5,
-0x69, 0x90, 0x81, 0xED, 0x93, 0x25, 0x73, 0xFF,
-0xE4, 0x33, 0xFE, 0xF1, 0xE6, 0xE0, 0xC3, 0x9F,
-0xEE, 0xB1, 0x70, 0x50, 0x02, 0x41, 0x2C, 0xF1,
-0xE6, 0xE4, 0xF0, 0x12, 0xEC, 0x03, 0x12, 0xEA,
-0xCE, 0x74, 0x01, 0x93, 0x2F, 0xFF, 0xE4, 0x93,
-0x34, 0x00, 0xC3, 0x13, 0xFE, 0xEF, 0x13, 0xFF,
-0xE5, 0x67, 0x12, 0x91, 0xD5, 0x41, 0x2C, 0x51,
-0x73, 0xE0, 0x64, 0x05, 0x60, 0x02, 0x21, 0x06,
-0x90, 0x04, 0xA0, 0xE0, 0x64, 0x02, 0x70, 0x10,
-0x51, 0x5A, 0xE4, 0xF0, 0x90, 0x04, 0xA1, 0xE0,
-0x78, 0x88, 0xF6, 0x12, 0xDF, 0xBA, 0x41, 0x40,
-0xAD, 0x69, 0xAF, 0x67, 0x12, 0x72, 0xEE, 0x12,
-0xEB, 0x7F, 0xEF, 0xF0, 0xE5, 0x67, 0x12, 0x93,
-0x34, 0xE0, 0x54, 0x07, 0x78, 0x88, 0xF6, 0x74,
-0xD6, 0x25, 0x67, 0x51, 0x7F, 0xFF, 0xC3, 0x94,
-0x30, 0x40, 0x1C, 0x75, 0xF0, 0x12, 0xE5, 0x67,
-0x71, 0xEB, 0xFE, 0xC4, 0x13, 0x13, 0x54, 0x03,
-0x20, 0xE0, 0x0C, 0x12, 0xEB, 0x7F, 0xE0, 0x60,
-0x06, 0x90, 0x96, 0x4B, 0xE0, 0x60, 0x0A, 0xE4,
-0x78, 0x88, 0xF6, 0x51, 0x5A, 0xE4, 0xF0, 0x80,
-0x5D, 0x12, 0xEB, 0x73, 0xE0, 0xFE, 0x24, 0x05,
-0xFD, 0xE4, 0x33, 0xFC, 0xEF, 0xB1, 0x6D, 0x50,
-0x20, 0x74, 0xD6, 0x25, 0x67, 0x51, 0x7F, 0x24,
-0x05, 0xFD, 0xE4, 0x33, 0xFC, 0xEE, 0xB1, 0x6D,
-0x50, 0x0F, 0x12, 0xEB, 0x67, 0xE0, 0xB5, 0x69,
-0x08, 0x51, 0x67, 0xE0, 0xC3, 0x94, 0x0A, 0x40,
-0x28, 0x78, 0x88, 0xE6, 0xFF, 0x70, 0x04, 0x76,
-0x01, 0x80, 0x0C, 0xEF, 0x78, 0x88, 0xB4, 0x01,
-0x04, 0x76, 0x03, 0x80, 0x02, 0x76, 0x05, 0x51,
-0x67, 0xE4, 0xF0, 0x74, 0xD6, 0x25, 0x67, 0x51,
-0x7F, 0xFF, 0x12, 0xEB, 0x73, 0xEF, 0xF0, 0x80,
-0x05, 0x51, 0x5A, 0xE0, 0x04, 0xF0, 0x12, 0xEB,
-0x67, 0xE5, 0x69, 0xF0, 0x41, 0x27, 0x51, 0x73,
-0xE0, 0x64, 0x06, 0x60, 0x02, 0x41, 0x2C, 0xF5,
-0x6B, 0xF5, 0x6C, 0xE5, 0x67, 0x12, 0x93, 0x34,
-0xE0, 0x54, 0x07, 0x78, 0x88, 0xF6, 0xD3, 0xE5,
-0x6E, 0x94, 0xE8, 0xE5, 0x6D, 0x94, 0x03, 0x40,
-0x06, 0x78, 0x86, 0x76, 0x05, 0x80, 0x15, 0xD3,
-0xE5, 0x6E, 0x94, 0xFA, 0xE5, 0x6D, 0x94, 0x00,
-0x40, 0x06, 0x78, 0x86, 0x76, 0x02, 0x80, 0x04,
-0xE4, 0x78, 0x86, 0xF6, 0xE5, 0x6E, 0xAE, 0x6D,
-0x78, 0x86, 0x86, 0x00, 0x08, 0x80, 0x05, 0xCE,
-0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xFF, 0x90,
-0x82, 0x06, 0xE4, 0xF1, 0xC2, 0x90, 0x95, 0xDD,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x78, 0x87,
-0xF6, 0xF1, 0xF4, 0x78, 0x87, 0xE6, 0xFD, 0x12,
-0xEB, 0x42, 0xAE, 0xF0, 0x78, 0x86, 0x86, 0x00,
-0x08, 0x80, 0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
-0xD8, 0xF9, 0xFF, 0xED, 0x90, 0x82, 0x01, 0xF1,
-0xC2, 0xEF, 0x25, 0x6C, 0xF5, 0x6C, 0xEE, 0x35,
-0x6B, 0xF5, 0x6B, 0xC3, 0x90, 0x95, 0xDE, 0xE0,
-0x95, 0x6C, 0x90, 0x95, 0xDD, 0xE0, 0x95, 0x6B,
-0x40, 0x07, 0x78, 0x87, 0x06, 0xE6, 0xB4, 0x05,
-0xC0, 0x78, 0x87, 0xE6, 0xC3, 0x13, 0xF6, 0xFD,
-0x08, 0xE6, 0x24, 0x01, 0xFF, 0xE4, 0x33, 0xA2,
-0xE7, 0x13, 0xEF, 0x13, 0x08, 0xF6, 0xD3, 0x9D,
-0x40, 0x07, 0xE6, 0x79, 0x87, 0x97, 0xF6, 0x80,
-0x04, 0xE4, 0x78, 0x89, 0xF6, 0x51, 0x4E, 0xE0,
-0xC3, 0x13, 0xFF, 0x78, 0x89, 0xE6, 0xC4, 0x33,
-0x54, 0xE0, 0x2F, 0xFF, 0x51, 0x4E, 0xEF, 0xF0,
-0x51, 0x4E, 0xE0, 0xC3, 0x94, 0xC0, 0x40, 0x05,
-0x51, 0x4E, 0x74, 0xC0, 0xF0, 0x51, 0x4E, 0xE0,
-0x24, 0x1F, 0xFF, 0xE4, 0x33, 0xFE, 0xEF, 0x78,
-0x06, 0xCE, 0xA2, 0xE7, 0x13, 0xCE, 0x13, 0xD8,
-0xF8, 0x78, 0x89, 0xF6, 0xE6, 0x25, 0xE0, 0xF6,
-0x70, 0x03, 0xFF, 0x80, 0x05, 0x78, 0x89, 0xE6,
-0x14, 0xFF, 0x78, 0x88, 0xA6, 0x07, 0xD3, 0x90,
-0x95, 0xD5, 0xE0, 0x94, 0x03, 0x90, 0x95, 0xD4,
-0xE0, 0x94, 0x00, 0x40, 0x02, 0xE4, 0xF6, 0x78,
-0x88, 0x12, 0xDF, 0xBA, 0x51, 0x73, 0xE0, 0xFF,
-0xD3, 0x94, 0x05, 0x50, 0x05, 0xEF, 0x04, 0xFF,
-0x80, 0x02, 0x7F, 0x00, 0x51, 0x73, 0xEF, 0xF0,
-0xE4, 0xF5, 0x6B, 0xF5, 0x6C, 0x12, 0xEB, 0xFC,
-0x05, 0x67, 0x02, 0x93, 0xC9, 0x22, 0x74, 0x4F,
-0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5,
-0x83, 0x22, 0x74, 0x76, 0x25, 0x67, 0xF5, 0x82,
-0xE4, 0x34, 0x8E, 0xF5, 0x83, 0xE4, 0xF0, 0x74,
-0xF6, 0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8D,
-0xF5, 0x83, 0x22, 0x74, 0x76, 0x25, 0x67, 0xF5,
-0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83, 0xE0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x7F,
-0x8F, 0x12, 0x7B, 0x41, 0xEF, 0x20, 0xE6, 0x02,
-0x61, 0xAD, 0x90, 0x00, 0x8C, 0xE0, 0x90, 0x97,
-0x30, 0xF0, 0x7F, 0x8D, 0x12, 0x7B, 0x41, 0x90,
-0x97, 0x31, 0xEF, 0xF0, 0x90, 0x00, 0x8E, 0xE0,
-0x90, 0x97, 0x32, 0xF0, 0x90, 0x97, 0x31, 0xE0,
-0x24, 0xFC, 0x60, 0x0F, 0x24, 0x03, 0x60, 0x02,
-0x61, 0x9D, 0x90, 0x97, 0x30, 0xE0, 0xFF, 0xB1,
-0x83, 0x61, 0x9D, 0x90, 0x97, 0x30, 0xE0, 0x24,
-0xD6, 0x51, 0x7F, 0xFB, 0xE4, 0xFD, 0xFF, 0x71,
-0xDF, 0x75, 0xF0, 0x12, 0x71, 0xEB, 0x13, 0x13,
-0x54, 0x03, 0xFB, 0x0D, 0xE4, 0xFF, 0x71, 0xDF,
-0x75, 0xF0, 0x12, 0x71, 0xEB, 0x12, 0x8F, 0x8B,
-0xFB, 0x0D, 0xE4, 0xFF, 0x71, 0xDF, 0x75, 0xF0,
-0x12, 0x71, 0xEB, 0xC4, 0x54, 0x03, 0xFB, 0x0D,
-0xE4, 0xFF, 0x71, 0xDF, 0x75, 0xF0, 0x12, 0x12,
-0xE1, 0xB6, 0xFB, 0xE4, 0xFD, 0x0F, 0x71, 0xDF,
-0x12, 0xE1, 0xA9, 0x71, 0xDC, 0x75, 0xF0, 0x12,
-0xB1, 0x5F, 0xC4, 0x13, 0x54, 0x01, 0xFB, 0x0D,
-0x7F, 0x01, 0x71, 0xDF, 0x75, 0xF0, 0x12, 0xB1,
-0x5F, 0x54, 0x1F, 0x71, 0xDD, 0xF1, 0xFA, 0xE0,
-0xFB, 0xE4, 0xFD, 0x0F, 0x71, 0xDF, 0x75, 0xF0,
-0x08, 0xA4, 0x24, 0x01, 0xF5, 0x82, 0xE4, 0x34,
-0x82, 0x71, 0xDA, 0x75, 0xF0, 0x08, 0xA4, 0x24,
-0x02, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0x71, 0xDA,
-0x75, 0xF0, 0x08, 0xA4, 0x24, 0x03, 0xF5, 0x82,
-0xE4, 0x34, 0x82, 0x71, 0xDA, 0x75, 0xF0, 0x08,
-0xA4, 0x24, 0x04, 0xF5, 0x82, 0xE4, 0x34, 0x82,
-0xF5, 0x83, 0xE0, 0xFB, 0xE4, 0xFD, 0x0F, 0x71,
-0xDF, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x05, 0xF5,
-0x82, 0xE4, 0x34, 0x82, 0x71, 0xDA, 0x75, 0xF0,
-0x08, 0xA4, 0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34,
-0x82, 0x71, 0xDA, 0x75, 0xF0, 0x08, 0xA4, 0x24,
-0x07, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83,
-0xE0, 0xFB, 0x0D, 0x71, 0xB2, 0x7F, 0x8F, 0x12,
-0x7B, 0x41, 0xEF, 0x30, 0xE0, 0x07, 0xE4, 0xFD,
-0x7F, 0x8D, 0x12, 0x7B, 0x2E, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xEF, 0x70, 0x04, 0x74, 0xF0, 0x80,
-0x16, 0xEF, 0xB4, 0x01, 0x04, 0x74, 0xF4, 0x80,
-0x0E, 0xEF, 0xB4, 0x02, 0x04, 0x74, 0xF8, 0x80,
-0x06, 0xEF, 0xB4, 0x03, 0x0C, 0x74, 0xFC, 0x2D,
-0xF5, 0x82, 0xE4, 0x34, 0x02, 0xF5, 0x83, 0xEB,
-0xF0, 0x22, 0xF5, 0x83, 0xE0, 0xFB, 0x0D, 0x71,
-0xB2, 0x90, 0x97, 0x30, 0xE0, 0x22, 0xFF, 0x75,
-0xF0, 0x12, 0xED, 0x90, 0x89, 0x52, 0x12, 0x04,
-0x6E, 0xE0, 0x22, 0x90, 0x96, 0xFF, 0x12, 0x86,
-0x42, 0xB1, 0x67, 0x12, 0x02, 0x06, 0x54, 0x7F,
-0xFD, 0x12, 0x8F, 0x98, 0xFE, 0x54, 0x1F, 0x90,
-0x97, 0x03, 0xF0, 0xEE, 0x54, 0x80, 0x12, 0x8F,
-0x8B, 0x90, 0x97, 0x02, 0xF0, 0x12, 0x87, 0xF1,
-0xFE, 0x54, 0x03, 0xFC, 0xEE, 0x54, 0x30, 0xC4,
-0x54, 0x0F, 0x90, 0x97, 0x05, 0xF0, 0x12, 0x87,
-0xF1, 0xFE, 0x54, 0x40, 0xC4, 0x13, 0x13, 0x54,
-0x03, 0x90, 0x97, 0x04, 0xF0, 0xEE, 0x54, 0x80,
-0x12, 0x8F, 0x8B, 0xFF, 0x12, 0x87, 0xF1, 0xFB,
-0x54, 0x08, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x90,
-0x97, 0x07, 0xF0, 0xFA, 0xEB, 0x54, 0x04, 0x13,
-0x13, 0x54, 0x3F, 0xA3, 0xF0, 0xEF, 0x54, 0x01,
-0xC4, 0x33, 0x33, 0x33, 0x54, 0x80, 0x71, 0xE6,
-0x54, 0x7F, 0x4F, 0xF0, 0x90, 0x97, 0x04, 0xE0,
-0x12, 0xE4, 0x5C, 0x71, 0xE6, 0x54, 0xBF, 0x4F,
-0xF0, 0xEA, 0x70, 0x0D, 0xEC, 0x54, 0x03, 0x25,
-0xE0, 0x25, 0xE0, 0x71, 0xE6, 0x54, 0xF3, 0x4F,
-0xF0, 0x90, 0x97, 0x03, 0xE0, 0x54, 0x1F, 0xB1,
-0x5A, 0x54, 0xE0, 0x4F, 0xF0, 0xEC, 0x54, 0x03,
-0x71, 0xE6, 0x54, 0xFC, 0x4F, 0xF0, 0x90, 0x97,
-0x02, 0xE0, 0x54, 0x01, 0xC4, 0x33, 0x54, 0xE0,
-0xB1, 0x5A, 0x54, 0xDF, 0x4F, 0xF0, 0x90, 0x97,
-0x05, 0xE0, 0x54, 0x03, 0xC4, 0x54, 0xF0, 0x71,
-0xE6, 0x54, 0xCF, 0x4F, 0xB1, 0x77, 0xE0, 0x54,
-0xFB, 0xB1, 0x77, 0xC0, 0x83, 0xC0, 0x82, 0xE0,
-0xFF, 0x90, 0x97, 0x08, 0xE0, 0x12, 0xCE, 0xF7,
-0xD0, 0x82, 0xD0, 0x83, 0xF0, 0x90, 0x93, 0xED,
-0xE0, 0x60, 0x3A, 0xB1, 0x67, 0xE9, 0x24, 0x03,
-0xF9, 0xE4, 0x3A, 0xFA, 0x12, 0x02, 0x06, 0x54,
-0x1F, 0x12, 0x02, 0x4C, 0x90, 0x97, 0x06, 0x74,
-0x01, 0xF0, 0x90, 0x97, 0x06, 0xE0, 0xFF, 0xC3,
-0x94, 0x04, 0x50, 0x19, 0xEF, 0x24, 0x03, 0xFF,
-0xE4, 0x33, 0xFE, 0xB1, 0x67, 0x8F, 0x82, 0x8E,
-0x83, 0xE4, 0x12, 0x02, 0x5E, 0x90, 0x97, 0x06,
-0xE0, 0x04, 0xF0, 0x80, 0xDD, 0x90, 0x93, 0xEB,
-0xE0, 0x54, 0x07, 0xFF, 0xBF, 0x05, 0x0A, 0xEC,
-0xB4, 0x01, 0x06, 0x90, 0x93, 0xF0, 0x74, 0x01,
-0xF0, 0xE4, 0x90, 0x97, 0x06, 0xF0, 0x90, 0x97,
-0x06, 0xE0, 0xFC, 0x24, 0x03, 0xFF, 0xE4, 0x33,
-0xFE, 0x90, 0x96, 0xFF, 0x12, 0xD2, 0x78, 0xFF,
-0xED, 0xF1, 0xFA, 0xB1, 0xD6, 0xEF, 0xF0, 0x90,
-0x97, 0x06, 0xE0, 0x04, 0xF0, 0xE0, 0xB4, 0x04,
-0xDD, 0xAF, 0x05, 0x90, 0x8A, 0xFF, 0xE0, 0xFC,
-0xA3, 0xE0, 0xFD, 0xF5, 0x82, 0x8C, 0x83, 0x02,
-0x04, 0x7E, 0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90,
-0x89, 0x51, 0x12, 0x04, 0x6E, 0xE0, 0x22, 0x90,
-0x96, 0xFF, 0x02, 0x86, 0x39, 0xD3, 0x9D, 0xEC,
-0x64, 0x80, 0xF8, 0x74, 0x80, 0x98, 0x22, 0xF0,
-0x74, 0xC6, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x8D,
-0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x97, 0x3B, 0xEF, 0xF0, 0x90,
-0x00, 0x8F, 0xE0, 0x30, 0xE6, 0x3B, 0x90, 0x00,
-0x8D, 0xE0, 0x64, 0x01, 0x70, 0x33, 0x90, 0x97,
-0x3C, 0xF0, 0x90, 0x97, 0x3C, 0xE0, 0xFD, 0x90,
-0x97, 0x3B, 0xE0, 0x12, 0x90, 0xD4, 0xE5, 0x82,
-0x2D, 0xB1, 0xD9, 0xE0, 0xFB, 0xE4, 0xFF, 0x71,
-0xB2, 0x90, 0x97, 0x3C, 0xE0, 0x04, 0xF0, 0xE0,
-0xC3, 0x94, 0x10, 0x40, 0xDD, 0x90, 0x00, 0x8F,
-0xE0, 0x30, 0xE0, 0x05, 0x90, 0x00, 0x8D, 0xE4,
-0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE5, 0x82,
-0x2C, 0xF5, 0x82, 0xE4, 0x35, 0x83, 0xF5, 0x83,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x12, 0xE2, 0xE8, 0x90, 0x97, 0x47, 0xF0, 0x90,
-0x88, 0x32, 0x12, 0x8F, 0x8A, 0x30, 0xE0, 0x02,
-0xC1, 0xAA, 0x90, 0x88, 0x31, 0xE0, 0x30, 0xE0,
-0x1F, 0x90, 0x88, 0x53, 0xE0, 0x24, 0x04, 0x33,
-0x33, 0x33, 0x54, 0xF8, 0x90, 0x88, 0x4B, 0xF0,
-0x90, 0x88, 0x53, 0xE0, 0x04, 0x33, 0x33, 0x33,
-0x54, 0xF8, 0x90, 0x88, 0x4A, 0xF0, 0x80, 0x10,
-0x90, 0x88, 0x4B, 0x74, 0x10, 0xF0, 0x90, 0x88,
-0x4A, 0x74, 0x08, 0xF0, 0x74, 0x10, 0x2B, 0xFB,
-0x90, 0x88, 0x4A, 0xE0, 0xFE, 0x90, 0x88, 0x49,
-0xE0, 0xD3, 0x9E, 0x50, 0x0E, 0x90, 0x88, 0x3E,
-0xEB, 0xF0, 0x90, 0x88, 0x4B, 0xE0, 0xC3, 0x9D,
-0x2F, 0x80, 0x11, 0xC3, 0xED, 0x9E, 0x2B, 0x90,
-0x88, 0x3E, 0xF0, 0x90, 0x88, 0x4A, 0xE0, 0xFF,
-0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x88, 0x4E, 0xF0,
-0x90, 0x88, 0x4B, 0xD1, 0xB6, 0x90, 0x88, 0x4E,
-0xE0, 0xB1, 0x6D, 0x40, 0x04, 0xEF, 0x24, 0x50,
-0xF0, 0x90, 0x88, 0x4E, 0xD1, 0xB6, 0x90, 0x88,
-0x3E, 0xE0, 0xB1, 0x6D, 0x40, 0x04, 0xEF, 0x24,
-0x50, 0xF0, 0x90, 0x88, 0x4E, 0xD1, 0xC7, 0xFF,
-0x7E, 0x00, 0x90, 0x88, 0x42, 0xEE, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x05, 0x58, 0xF0, 0x90, 0x88,
-0x4E, 0xE0, 0x54, 0x07, 0xFF, 0x90, 0x05, 0xB1,
-0xE0, 0x54, 0xF8, 0x4F, 0xF0, 0x12, 0xDF, 0x0B,
-0x80, 0x07, 0x90, 0x88, 0x33, 0xE0, 0x44, 0x01,
-0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE0, 0xFF,
-0x24, 0x50, 0xFD, 0xE4, 0x33, 0xFC, 0x22, 0xE4,
-0x90, 0x92, 0x20, 0xF0, 0x90, 0x88, 0x3E, 0xE0,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x22, 0xE4, 0xF5,
-0x7C, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x65, 0xF1,
-0xD1, 0x70, 0x61, 0x12, 0xEA, 0x89, 0x75, 0x7C,
-0x01, 0x90, 0x88, 0x2C, 0xE0, 0x30, 0xE0, 0x11,
-0x90, 0x88, 0x30, 0xE0, 0xB4, 0x02, 0x03, 0xE4,
-0xF5, 0x7C, 0xF1, 0xDA, 0xEF, 0x70, 0x02, 0xF5,
-0x7C, 0xE5, 0x7C, 0x60, 0x3F, 0x90, 0x88, 0x39,
-0xE0, 0x20, 0xE2, 0x08, 0x90, 0x8A, 0xB9, 0x12,
-0x8E, 0x5A, 0xF1, 0xBB, 0xF1, 0xC9, 0x90, 0x88,
-0x3F, 0xE0, 0x60, 0x04, 0x64, 0x01, 0x70, 0x0F,
-0xD1, 0xBF, 0xFF, 0xA3, 0xE0, 0x2F, 0xF1, 0x54,
-0xD1, 0xC4, 0xFF, 0xA3, 0xE0, 0x80, 0x0B, 0xD1,
-0xBF, 0xF1, 0x3D, 0x2F, 0xF1, 0x54, 0xD1, 0xC4,
-0xF1, 0x3D, 0x2F, 0x33, 0x33, 0x33, 0x54, 0xF8,
-0x90, 0x88, 0x4F, 0xF0, 0x22, 0xFF, 0xA3, 0xE0,
-0x75, 0xF0, 0x03, 0xA4, 0x24, 0xFE, 0x22, 0xE0,
-0x44, 0x02, 0xF0, 0xE4, 0x90, 0x92, 0x20, 0xF0,
-0x90, 0x88, 0x94, 0xE0, 0x90, 0x92, 0x21, 0xF0,
-0xE4, 0xFB, 0xFD, 0x7F, 0x54, 0x7E, 0x01, 0x02,
-0x66, 0x33, 0xE4, 0x90, 0x96, 0x15, 0xF0, 0x90,
-0x88, 0x36, 0xE0, 0x60, 0x4D, 0xF1, 0xD1, 0x70,
-0x49, 0x12, 0xEB, 0xF4, 0xF0, 0x12, 0xEA, 0x89,
-0x90, 0x96, 0x15, 0x74, 0x01, 0xF0, 0xE4, 0x90,
-0x88, 0x3D, 0xF0, 0x90, 0x88, 0x2C, 0xE0, 0x30,
-0xE0, 0x15, 0x90, 0x88, 0x30, 0xE0, 0xB4, 0x02,
-0x05, 0xE4, 0x90, 0x96, 0x15, 0xF0, 0xF1, 0xDA,
-0xEF, 0x70, 0x04, 0x90, 0x96, 0x15, 0xF0, 0x90,
-0x96, 0x15, 0xE0, 0x60, 0x15, 0x90, 0x88, 0x39,
-0xE0, 0x20, 0xE2, 0x08, 0x90, 0x8A, 0xB9, 0x12,
-0x8E, 0x5A, 0xF1, 0xBB, 0xF1, 0xC9, 0xD1, 0xBF,
-0xF1, 0x54, 0x22, 0x7D, 0x01, 0x7F, 0x04, 0x02,
-0x04, 0x7E, 0x93, 0xFD, 0x7C, 0x00, 0x02, 0x02,
-0x80, 0x90, 0x88, 0x3A, 0xE0, 0x44, 0x10, 0xF0,
-0x22, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xEF, 0x64,
-0x01, 0x22, 0x90, 0x05, 0x43, 0xE0, 0x7F, 0x00,
-0x30, 0xE7, 0x02, 0x7F, 0x01, 0x22, 0x74, 0xA6,
-0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5,
-0x83, 0x22, 0x41, 0x88, 0x90, 0x95, 0xD1, 0x02,
-0x86, 0x39, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x00,
-0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0x22,
-0x12, 0xBD, 0xE7, 0x90, 0x04, 0x24, 0xE0, 0xFF,
-0xE4, 0xFE, 0x12, 0x8A, 0x4E, 0x8E, 0x82, 0x12,
-0xD3, 0xD0, 0x2F, 0xFD, 0xEE, 0x11, 0x2B, 0xED,
-0xF0, 0x0E, 0xEE, 0xB4, 0x03, 0xEC, 0x22, 0xC3,
-0x13, 0x54, 0x07, 0x75, 0xF0, 0x1B, 0xA4, 0x24,
-0x64, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
-0x22, 0x12, 0x88, 0xCA, 0xEF, 0x70, 0x02, 0xFF,
-0x22, 0x71, 0xBC, 0x90, 0x93, 0xAC, 0xF0, 0x90,
-0x93, 0x58, 0xE0, 0xFF, 0xC3, 0x13, 0xFE, 0xEF,
-0x54, 0xF1, 0xFF, 0xEE, 0x04, 0x54, 0x07, 0x25,
-0xE0, 0x4F, 0xF0, 0xA3, 0xE0, 0xFF, 0x90, 0x93,
-0x58, 0xE0, 0xFE, 0xC3, 0x13, 0x54, 0x07, 0xB5,
-0x07, 0x04, 0xEE, 0x54, 0xF1, 0xF0, 0x71, 0xBC,
-0xF5, 0x7D, 0xE4, 0x90, 0x93, 0x5A, 0xF0, 0xE5,
-0x7D, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x5F, 0xF5,
-0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0, 0x30,
-0xE0, 0x26, 0x11, 0xFF, 0xE0, 0x24, 0xAF, 0xF5,
-0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0, 0xFF,
-0xB1, 0x8B, 0xEF, 0x11, 0xFE, 0xE0, 0x04, 0x11,
-0xFE, 0xE0, 0xFF, 0x90, 0x93, 0xAE, 0xE0, 0xFE,
-0xEF, 0xB5, 0x06, 0x04, 0x11, 0xFF, 0xE4, 0xF0,
-0xB1, 0x8B, 0xE0, 0xFC, 0x90, 0x93, 0xAC, 0xE0,
-0xB1, 0x8D, 0xE0, 0x6C, 0x60, 0x0C, 0xE5, 0x7D,
-0xB1, 0x9D, 0xD1, 0xEE, 0xE5, 0x7D, 0xB1, 0x9D,
-0x31, 0xFC, 0xE5, 0x7D, 0xD1, 0x47, 0x54, 0x07,
-0xFF, 0x60, 0x03, 0xBF, 0x02, 0x0E, 0xE5, 0x7D,
-0x11, 0x2B, 0xE0, 0xFF, 0x7E, 0x00, 0x7B, 0x04,
-0xE4, 0xFD, 0xB1, 0x3C, 0xAD, 0x7D, 0x7F, 0x01,
-0x91, 0x43, 0x90, 0x93, 0xAD, 0xE0, 0xC3, 0x13,
-0x54, 0x03, 0xFF, 0xBF, 0x02, 0x05, 0xE4, 0xFF,
-0x12, 0xB8, 0xC6, 0x7F, 0x01, 0x22, 0xF0, 0x74,
-0xD2, 0x25, 0x7D, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0x22, 0xE4, 0x90, 0x96, 0x1A, 0xF0,
-0x90, 0x93, 0x58, 0xE0, 0x20, 0xE0, 0x02, 0x21,
-0xFB, 0xD1, 0x43, 0x54, 0x07, 0x90, 0x96, 0x17,
-0xF0, 0x60, 0x05, 0xE0, 0x64, 0x02, 0x70, 0x65,
-0x90, 0x93, 0x5A, 0xE0, 0x70, 0x3F, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x96, 0x18, 0xF0, 0x7B, 0x4E,
-0x7D, 0x6F, 0xE4, 0xFF, 0x91, 0xC7, 0x90, 0x93,
-0x58, 0xE0, 0x11, 0x27, 0xE0, 0xFF, 0x7E, 0x00,
-0x7B, 0x04, 0x7D, 0x01, 0xB1, 0x3C, 0xBF, 0x01,
-0x11, 0x90, 0x93, 0x58, 0xE0, 0x91, 0x31, 0xE0,
-0x44, 0x01, 0xF0, 0x90, 0x93, 0x5A, 0x74, 0x01,
-0xF0, 0x22, 0x90, 0x96, 0x18, 0xE0, 0xFD, 0x7B,
-0x4F, 0xE4, 0xFF, 0x81, 0xC7, 0x90, 0x93, 0x5A,
-0xE0, 0xB4, 0x01, 0x03, 0x74, 0x05, 0xF0, 0x71,
-0xBC, 0xFD, 0x7F, 0x02, 0x91, 0x43, 0x90, 0x93,
-0x5A, 0xE0, 0x64, 0x05, 0x70, 0x75, 0x11, 0x39,
-0xEF, 0x70, 0x70, 0x80, 0x69, 0x90, 0x96, 0x17,
+0x07, 0x12, 0x8F, 0xE9, 0x78, 0x10, 0x12, 0x03,
+0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0xA3, 0x12, 0x8F, 0xEC,
+0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0,
+0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x20,
+0xA3, 0x12, 0x04, 0x31, 0x90, 0x88, 0xA1, 0x12,
+0xB5, 0x23, 0x30, 0xE0, 0x2F, 0x90, 0x95, 0x46,
+0x12, 0x04, 0xB8, 0x90, 0x95, 0x59, 0x12, 0xEE,
+0x3B, 0x40, 0x21, 0x90, 0x95, 0x46, 0x12, 0x86,
+0x2D, 0x90, 0x95, 0x59, 0x12, 0x04, 0xB8, 0x12,
+0x85, 0xB6, 0xE4, 0xFB, 0x7A, 0x78, 0xF9, 0xF8,
+0xC3, 0x12, 0x03, 0xDA, 0x50, 0x06, 0x90, 0x95,
+0x4B, 0xE0, 0x04, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x95, 0x44, 0xE0, 0xC4, 0x13, 0x13,
+0x13, 0x54, 0x01, 0x22, 0x90, 0x88, 0x38, 0xE0,
+0xFF, 0x90, 0x8A, 0xB9, 0xE0, 0xFC, 0xA3, 0xE0,
+0xF5, 0x82, 0x8C, 0x83, 0x22, 0x90, 0x95, 0x37,
+0x74, 0x01, 0xF0, 0x90, 0x06, 0x92, 0x04, 0xF0,
+0x90, 0x01, 0x3C, 0x74, 0x04, 0xF0, 0x90, 0x88,
+0x31, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x88, 0x39,
+0xE0, 0x64, 0x0C, 0x60, 0x0E, 0x90, 0x8A, 0xB9,
+0x11, 0x4B, 0xF1, 0xCD, 0x90, 0x8A, 0xF9, 0x11,
+0x4B, 0xF1, 0x87, 0x90, 0x8A, 0xAF, 0x11, 0x4B,
+0x7D, 0x08, 0xE4, 0xFF, 0x02, 0x04, 0x7E, 0xE4,
+0xFD, 0xFF, 0x02, 0x04, 0x7E, 0x7F, 0xFB, 0x7E,
+0x01, 0x12, 0x5F, 0xA6, 0xEF, 0x22, 0x90, 0x8A,
+0xF9, 0x11, 0x4B, 0xF1, 0x87, 0x90, 0x88, 0x2F,
+0x74, 0x01, 0xF0, 0x22, 0x90, 0x8A, 0xF9, 0x11,
+0x4B, 0xF1, 0x87, 0xF1, 0xE2, 0x80, 0xEE, 0xE5,
+0x67, 0xC4, 0x54, 0xF0, 0x24, 0x05, 0xF5, 0x82,
+0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x90, 0x86,
+0x0C, 0x12, 0x8A, 0x66, 0x90, 0x8A, 0xF9, 0x11,
+0x4B, 0xF1, 0x87, 0x80, 0xD0, 0xE4, 0xFD, 0x7F,
+0x0C, 0x02, 0x04, 0x7E, 0x90, 0x88, 0x30, 0xE0,
+0x64, 0x02, 0x22, 0x7D, 0x03, 0x7F, 0x02, 0x02,
+0x7C, 0x05, 0x90, 0x05, 0x27, 0xE0, 0x44, 0x40,
+0xF0, 0x22, 0x90, 0x88, 0x9D, 0xE0, 0xC4, 0x54,
+0x0F, 0x22, 0x80, 0xA9, 0xF0, 0x90, 0x88, 0x9D,
+0xE0, 0xC4, 0x13, 0x54, 0x07, 0x22, 0x90, 0x95,
+0x54, 0x12, 0x86, 0x42, 0x90, 0x04, 0x24, 0xE0,
+0xFF, 0xE4, 0xFE, 0x12, 0x87, 0xEB, 0x8E, 0x82,
+0x12, 0xA7, 0x24, 0x2F, 0xFD, 0xEE, 0x11, 0x24,
+0xED, 0xF0, 0x0E, 0xEE, 0xB4, 0x03, 0xEC, 0x22,
+0xC3, 0x13, 0x54, 0x07, 0x75, 0xF0, 0x1B, 0xA4,
+0x24, 0x64, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5,
+0x83, 0x22, 0xE4, 0x90, 0x96, 0x20, 0xF0, 0x90,
+0x93, 0x58, 0xE0, 0x20, 0xE0, 0x02, 0x21, 0x20,
+0x51, 0xC6, 0x54, 0x07, 0x90, 0x96, 0x1D, 0xF0,
+0x60, 0x05, 0xE0, 0x64, 0x02, 0x70, 0x66, 0x90,
+0x93, 0x5A, 0xE0, 0x70, 0x42, 0x90, 0x05, 0x22,
+0xE0, 0x90, 0x96, 0x1E, 0xF0, 0x7B, 0x4E, 0x7D,
+0x6F, 0xE4, 0xFF, 0x12, 0x8F, 0x64, 0x90, 0x93,
+0x58, 0xE0, 0x11, 0x20, 0xE0, 0xFF, 0x7E, 0x00,
+0x7B, 0x04, 0x7D, 0x01, 0x12, 0x8F, 0x87, 0xBF,
+0x01, 0x11, 0x90, 0x93, 0x58, 0xE0, 0x31, 0x21,
+0xE0, 0x44, 0x01, 0xF0, 0x90, 0x93, 0x5A, 0x74,
+0x01, 0xF0, 0x22, 0x90, 0x96, 0x1E, 0xE0, 0xFD,
+0x7B, 0x4F, 0xE4, 0xFF, 0x02, 0x8F, 0x64, 0x90,
+0x93, 0x5A, 0xE0, 0xB4, 0x01, 0x03, 0x74, 0x05,
+0xF0, 0x31, 0xA1, 0x31, 0xAA, 0x90, 0x93, 0x5A,
+0xE0, 0x64, 0x05, 0x70, 0x73, 0x12, 0x8C, 0x4B,
+0xEF, 0x70, 0x6D, 0x80, 0x67, 0x90, 0x96, 0x1D,
 0xE0, 0xFF, 0x64, 0x03, 0x60, 0x05, 0xEF, 0x64,
-0x01, 0x70, 0x60, 0x90, 0x93, 0x5A, 0xE0, 0x64,
-0x05, 0x70, 0x58, 0x90, 0x96, 0x17, 0xE0, 0x64,
-0x01, 0x70, 0x3F, 0x90, 0x96, 0x19, 0xD1, 0xDE,
+0x01, 0x70, 0x5D, 0x90, 0x93, 0x5A, 0xE0, 0x64,
+0x05, 0x70, 0x55, 0x90, 0x96, 0x1D, 0xE0, 0x64,
+0x01, 0x70, 0x3F, 0x90, 0x96, 0x1F, 0x51, 0xB1,
 0xD3, 0x94, 0x1F, 0x90, 0x93, 0x58, 0xE0, 0x40,
-0x10, 0x11, 0x28, 0xE0, 0xFF, 0x90, 0x8A, 0xBF,
-0x12, 0xAB, 0xE5, 0x7D, 0x00, 0x7C, 0x7C, 0x80,
-0x1E, 0x11, 0x27, 0xE0, 0xFB, 0x90, 0x96, 0x19,
-0xD1, 0xDE, 0x7D, 0x00, 0x25, 0xE0, 0x25, 0xE0,
+0x10, 0x11, 0x21, 0xE0, 0xFF, 0x90, 0x8A, 0xBF,
+0x12, 0x97, 0x44, 0x7D, 0x00, 0x7C, 0x7C, 0x80,
+0x1E, 0x11, 0x20, 0xE0, 0xFB, 0x90, 0x96, 0x1F,
+0x51, 0xB1, 0x7D, 0x00, 0x25, 0xE0, 0x25, 0xE0,
 0xFC, 0xAF, 0x03, 0x90, 0x8A, 0xBF, 0xE0, 0xFA,
 0xA3, 0xE0, 0xFB, 0xF5, 0x82, 0x8A, 0x83, 0x12,
-0x04, 0x7E, 0x71, 0xBC, 0xFD, 0x7F, 0x02, 0x91,
-0x43, 0x11, 0x39, 0xEF, 0x70, 0x05, 0x7F, 0x06,
-0x12, 0xB8, 0xC6, 0x22, 0xFF, 0xEE, 0x13, 0x13,
-0x54, 0x07, 0xFD, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x97, 0x3D, 0xED, 0xF0, 0xE4,
-0xA3, 0xF0, 0xEF, 0x14, 0x60, 0x02, 0x41, 0xEA,
-0x90, 0x06, 0x03, 0xE0, 0x54, 0xFB, 0xF0, 0x90,
-0x97, 0x3D, 0xE0, 0xFB, 0xC4, 0x33, 0x54, 0xE0,
-0xFE, 0x90, 0x04, 0x42, 0xE0, 0x54, 0x9F, 0x4E,
-0xFE, 0xF0, 0xE4, 0xFD, 0x12, 0xE2, 0x71, 0x90,
-0x97, 0x3E, 0xEF, 0xF0, 0x90, 0x04, 0x83, 0xF0,
-0x90, 0x96, 0xE3, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x00, 0x01, 0x90, 0x96, 0xE7, 0x12, 0x04, 0x3D,
-0x00, 0x00, 0x00, 0x01, 0x71, 0xB1, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x01, 0x90, 0x96, 0xE7,
-0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x01, 0x7F,
-0x00, 0x7E, 0x09, 0x71, 0xB5, 0x12, 0x04, 0x3D,
-0x00, 0x00, 0x00, 0x10, 0x90, 0x97, 0x3D, 0x12,
-0x8F, 0xEA, 0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78,
-0x01, 0x12, 0x03, 0xEB, 0x78, 0x04, 0xD1, 0x2B,
-0x7F, 0x00, 0x7E, 0x0A, 0x71, 0xB5, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x97, 0x3D,
-0x12, 0x8F, 0xEA, 0xEF, 0x54, 0x03, 0xFF, 0xE4,
-0x78, 0x0A, 0xD1, 0x2B, 0x7F, 0x00, 0x7E, 0x0D,
-0x71, 0xB5, 0x12, 0x04, 0x3D, 0x0C, 0x00, 0x00,
-0x00, 0x90, 0x97, 0x3E, 0x12, 0x8F, 0xEA, 0xEF,
-0x54, 0x03, 0xFF, 0xE4, 0x78, 0x1A, 0xD1, 0x2B,
-0x7F, 0x18, 0x71, 0xB3, 0x12, 0x04, 0x3D, 0x00,
-0x00, 0x0C, 0x00, 0x90, 0x96, 0xE7, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x00, 0xD1, 0x34, 0x12,
-0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x96,
-0xD5, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x04, 0x00,
-0x80, 0x58, 0x90, 0x06, 0x03, 0xE0, 0x44, 0x04,
-0xF0, 0x90, 0x96, 0xE3, 0x12, 0x04, 0x3D, 0x00,
-0x00, 0x00, 0x01, 0x90, 0x96, 0xE7, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x00, 0x71, 0xB1, 0x12,
-0x04, 0x3D, 0x00, 0x00, 0x00, 0x01, 0x90, 0x96,
-0xE7, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x00,
-0x7F, 0x00, 0x7E, 0x09, 0x71, 0xB5, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x96, 0xE7,
-0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00, 0xD1,
-0x34, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00,
-0x90, 0x96, 0xD5, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x0C, 0x00, 0x7D, 0x18, 0x7C, 0x00, 0xE4, 0xFF,
-0xF1, 0x7B, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96,
-0xE1, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x70,
-0x70, 0x90, 0x96, 0xEB, 0x12, 0x04, 0x31, 0x90,
-0x96, 0xE3, 0x12, 0x04, 0xB8, 0x12, 0x03, 0xCD,
-0x90, 0x96, 0xEB, 0x12, 0xEB, 0x3C, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x96,
-0xE3, 0x12, 0x04, 0xB8, 0x90, 0x96, 0xE7, 0x12,
-0xEB, 0x3C, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0x12, 0x86, 0x20, 0x90, 0x96, 0xEF,
-0x12, 0x04, 0x31, 0x90, 0x96, 0xEF, 0x12, 0xDA,
-0xFC, 0x90, 0x96, 0xE1, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x12, 0x70, 0xAD, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x7F, 0x00, 0x7E, 0x08, 0x71, 0x4F, 0x90,
-0x96, 0xE3, 0x22, 0xF0, 0x90, 0x93, 0x58, 0xE0,
-0xC3, 0x13, 0x54, 0x07, 0x22, 0xE4, 0x90, 0x96,
-0x15, 0xF0, 0x90, 0x93, 0x58, 0xE0, 0x30, 0xE0,
-0x5F, 0xC3, 0x13, 0x54, 0x07, 0xFF, 0x91, 0x35,
-0xE0, 0xFE, 0x30, 0xE0, 0x53, 0xEF, 0x91, 0x35,
-0xEE, 0x54, 0xFE, 0xF0, 0xEF, 0x91, 0x35, 0x12,
-0xB5, 0x2C, 0x30, 0xE0, 0x11, 0x90, 0x93, 0x58,
-0xE0, 0xFE, 0x91, 0x31, 0xEF, 0x54, 0xFB, 0xF0,
-0x90, 0x96, 0x15, 0x74, 0x01, 0xF0, 0x90, 0x04,
-0xE0, 0xE0, 0x30, 0xE1, 0x1F, 0xF1, 0xF3, 0x90,
-0x93, 0x58, 0xE0, 0x91, 0x31, 0xE0, 0x44, 0x02,
-0xF0, 0xE4, 0x90, 0x93, 0xDE, 0x71, 0xBB, 0xFD,
-0x7F, 0x02, 0x91, 0x43, 0x90, 0x96, 0x15, 0xE0,
-0x60, 0x0E, 0x21, 0x0B, 0x90, 0x93, 0x58, 0xE0,
-0x91, 0x31, 0xE0, 0x54, 0xFD, 0xF0, 0x91, 0xC2,
+0x04, 0x7E, 0x31, 0xA1, 0x31, 0xAA, 0x12, 0x8C,
+0x4B, 0xEF, 0x70, 0x04, 0x7F, 0x06, 0xF1, 0xF0,
 0x22, 0xC3, 0x13, 0x54, 0x07, 0x75, 0xF0, 0x1B,
 0xA4, 0x24, 0x62, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x97, 0x34, 0xED, 0xF0, 0x90,
-0x97, 0x33, 0xEF, 0xF0, 0x64, 0x02, 0x70, 0x24,
-0x90, 0x05, 0x22, 0xE0, 0x90, 0x97, 0x35, 0xF0,
-0x7B, 0x4A, 0x7D, 0x6F, 0x12, 0x88, 0xC5, 0xBF,
-0x01, 0x07, 0x90, 0x04, 0xD4, 0x74, 0xFF, 0x80,
-0x47, 0x90, 0x97, 0x35, 0xE0, 0xFD, 0x7B, 0x46,
-0xB1, 0x35, 0x80, 0x41, 0x90, 0x97, 0x33, 0xE0,
-0x64, 0x01, 0x70, 0x30, 0x91, 0xC3, 0x90, 0x97,
-0x34, 0xE0, 0xFF, 0x75, 0xF0, 0x1B, 0xA4, 0x24,
-0x60, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
-0xE0, 0xF4, 0x90, 0x04, 0xD4, 0xF0, 0xEF, 0x75,
-0xF0, 0x1B, 0xA4, 0x24, 0x61, 0xF5, 0x82, 0xE4,
+0xF5, 0x83, 0x22, 0xE4, 0x90, 0x96, 0x1B, 0xF0,
+0x90, 0x93, 0x58, 0xE0, 0x30, 0xE0, 0x60, 0xC3,
+0x13, 0x54, 0x07, 0xFF, 0x31, 0x25, 0xE0, 0xFE,
+0x30, 0xE0, 0x54, 0xEF, 0x31, 0x25, 0xEE, 0x54,
+0xFE, 0xF0, 0xEF, 0x31, 0x25, 0x12, 0xB5, 0x23,
+0x30, 0xE0, 0x11, 0x90, 0x93, 0x58, 0xE0, 0xFE,
+0x31, 0x21, 0xEF, 0x54, 0xFB, 0xF0, 0x90, 0x96,
+0x1B, 0x74, 0x01, 0xF0, 0x90, 0x04, 0xE0, 0xE0,
+0x30, 0xE1, 0x1F, 0xD1, 0x8D, 0x90, 0x93, 0x58,
+0xE0, 0x31, 0x21, 0xE0, 0x44, 0x02, 0xF0, 0xE4,
+0x90, 0x93, 0xDE, 0x31, 0xA0, 0xFD, 0x7F, 0x02,
+0x31, 0xAD, 0x90, 0x96, 0x1B, 0xE0, 0x60, 0x0F,
+0x01, 0x32, 0x90, 0x93, 0x58, 0xE0, 0x31, 0x21,
+0xE0, 0x54, 0xFD, 0xF0, 0x12, 0x8F, 0x5F, 0x22,
+0xF0, 0x90, 0x93, 0x58, 0xE0, 0xC3, 0x13, 0x54,
+0x07, 0x22, 0xFD, 0x7F, 0x02, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x5F, 0xED,
+0xF0, 0x90, 0x97, 0x5E, 0xEF, 0xF0, 0x64, 0x02,
+0x70, 0x25, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x97,
+0x60, 0xF0, 0x7B, 0x4A, 0x7D, 0x6F, 0x12, 0x8A,
+0x5F, 0xBF, 0x01, 0x07, 0x90, 0x04, 0xD4, 0x74,
+0xFF, 0x80, 0x49, 0x90, 0x97, 0x60, 0xE0, 0xFD,
+0x7B, 0x46, 0x12, 0x8F, 0x58, 0x80, 0x42, 0x90,
+0x97, 0x5E, 0xE0, 0x64, 0x01, 0x70, 0x31, 0x12,
+0x8F, 0x60, 0x90, 0x97, 0x5F, 0xE0, 0xFF, 0x75,
+0xF0, 0x1B, 0xA4, 0x24, 0x60, 0xF5, 0x82, 0xE4,
 0x34, 0x93, 0xF5, 0x83, 0xE0, 0xF4, 0x90, 0x04,
-0xD5, 0xF0, 0x80, 0x07, 0x90, 0x04, 0xD4, 0xE4,
-0xF0, 0xA3, 0xF0, 0x7F, 0x01, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xE4, 0xFB, 0xFD, 0x7F, 0xFF, 0xEB,
-0xB4, 0x57, 0x05, 0x12, 0xEB, 0xA3, 0x80, 0x10,
-0xEF, 0x70, 0x07, 0x90, 0x93, 0xF3, 0xE0, 0x4D,
-0x80, 0x06, 0x12, 0xC1, 0x36, 0x12, 0xEB, 0xA3,
-0x90, 0x05, 0x22, 0xF0, 0x90, 0x93, 0x01, 0xEB,
-0xF0, 0x22, 0x8F, 0x65, 0x90, 0x05, 0x22, 0xE0,
-0x90, 0x95, 0x4E, 0xF0, 0x7B, 0x17, 0x12, 0x88,
-0xC3, 0xEF, 0x64, 0x01, 0x70, 0x30, 0xE5, 0x65,
-0xB1, 0x8D, 0xE0, 0xFC, 0xB1, 0x9B, 0xD1, 0xEE,
-0xB1, 0x9B, 0x31, 0xFC, 0xE5, 0x65, 0xD1, 0x47,
-0x54, 0x07, 0xFF, 0x60, 0x03, 0xBF, 0x02, 0x0D,
-0xE5, 0x65, 0x11, 0x2B, 0xE0, 0xFF, 0x7E, 0x00,
-0xE4, 0xFB, 0xFD, 0xB1, 0x3C, 0xAD, 0x65, 0x7F,
-0x01, 0x91, 0x43, 0x7F, 0x01, 0x22, 0x90, 0x95,
-0x4E, 0xE0, 0xFD, 0x7B, 0x49, 0xE4, 0xFF, 0x91,
-0xC7, 0x7F, 0x00, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x09, 0xEE, 0xF0,
-0xA3, 0x12, 0xC0, 0xAE, 0x90, 0x04, 0x1D, 0xE0,
-0x60, 0x2B, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x97,
-0x0F, 0xF0, 0x7B, 0x14, 0x12, 0x88, 0xC3, 0xEF,
-0x64, 0x01, 0x70, 0x08, 0x12, 0xEA, 0x57, 0x12,
-0xAD, 0x8F, 0x80, 0x04, 0x7F, 0x00, 0x80, 0x16,
-0x90, 0x97, 0x0F, 0xE0, 0xFD, 0x7B, 0x15, 0xE4,
-0xFF, 0x91, 0xC7, 0x80, 0x06, 0x12, 0xEA, 0x57,
-0x12, 0xAD, 0x8F, 0x12, 0xEB, 0xE2, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xE5, 0x7D, 0x75, 0xF0, 0x1B,
-0xA4, 0x24, 0x5B, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0x22, 0xE5, 0x65, 0x75, 0xF0, 0x1B,
-0xA4, 0x24, 0x5C, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xE0, 0xFE, 0x54, 0x03, 0x22, 0xE4,
-0x90, 0x97, 0x2D, 0xF0, 0xA3, 0xF0, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x97, 0x2F, 0xF0, 0x7B, 0x47,
-0x7D, 0xFF, 0xE4, 0xFF, 0x91, 0xC7, 0x90, 0x05,
-0xF8, 0xE0, 0x70, 0x1A, 0xA3, 0xE0, 0x70, 0x16,
-0xA3, 0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E,
-0x90, 0x97, 0x2F, 0xE0, 0xFD, 0x7B, 0x48, 0xE4,
-0xFF, 0x91, 0xC7, 0x7F, 0x01, 0x22, 0x12, 0xAC,
-0xC7, 0x30, 0xE0, 0x1A, 0xD3, 0x90, 0x97, 0x2E,
-0xE0, 0x94, 0x03, 0x90, 0x97, 0x2D, 0xE0, 0x94,
-0x00, 0x40, 0x07, 0x12, 0xEB, 0x4E, 0x7B, 0x5A,
-0x80, 0x18, 0x7F, 0x01, 0x80, 0x18, 0xD3, 0x90,
-0x97, 0x2E, 0xE0, 0x94, 0xE8, 0x90, 0x97, 0x2D,
-0xE0, 0x94, 0x03, 0x40, 0x07, 0x12, 0xEB, 0x4E,
-0x7B, 0x5B, 0xA1, 0x35, 0x7F, 0x32, 0x7E, 0x00,
-0x12, 0x7C, 0x6A, 0x90, 0x97, 0x2D, 0x12, 0xBD,
-0xED, 0x80, 0x9B, 0x12, 0x03, 0xFE, 0x90, 0x96,
-0xE7, 0x02, 0x04, 0x31, 0x7F, 0x84, 0x7E, 0x08,
-0x71, 0x4F, 0x90, 0x96, 0xD1, 0x22, 0xF0, 0x90,
-0x93, 0x58, 0xE0, 0xC3, 0x13, 0x54, 0x07, 0x75,
-0xF0, 0x1B, 0xA4, 0x24, 0x5E, 0xF5, 0x82, 0xE4,
-0x34, 0x93, 0xF5, 0x83, 0xE0, 0x22, 0x90, 0x93,
-0x58, 0xE0, 0x30, 0xE0, 0x7D, 0x90, 0x93, 0xDA,
-0xE0, 0x04, 0x71, 0xBB, 0x04, 0xFF, 0x90, 0x96,
-0x15, 0xF0, 0x90, 0x93, 0x59, 0xE0, 0xB5, 0x07,
-0x05, 0xE4, 0x90, 0x96, 0x15, 0xF0, 0x90, 0x93,
-0xD8, 0xE0, 0xFF, 0x60, 0x10, 0xD1, 0xDB, 0xC3,
-0x9F, 0x12, 0xEB, 0xCC, 0xFB, 0xFD, 0x7F, 0x50,
-0x7E, 0x01, 0x12, 0x66, 0x33, 0x90, 0x96, 0x15,
-0xE0, 0xD1, 0x47, 0x54, 0x07, 0x90, 0x96, 0x16,
-0xD1, 0x3E, 0x54, 0x07, 0xFF, 0x14, 0x60, 0x0E,
-0x14, 0x60, 0x07, 0x14, 0x60, 0x08, 0x24, 0x03,
-0x70, 0x08, 0xF1, 0xF3, 0x80, 0x02, 0xF1, 0xF3,
-0x31, 0x0B, 0x12, 0xEB, 0x5B, 0x50, 0x23, 0x90,
-0x96, 0x16, 0xE0, 0xFF, 0x64, 0x02, 0x60, 0x03,
-0xEF, 0x70, 0x0F, 0xD1, 0xDB, 0x24, 0xFC, 0xFF,
-0xE4, 0x90, 0x92, 0x20, 0xF0, 0xA3, 0xEF, 0x12,
-0x9F, 0x57, 0xD1, 0xDB, 0x12, 0xEB, 0xCC, 0x12,
-0xBD, 0xFC, 0x22, 0x90, 0x96, 0x15, 0xE0, 0x75,
-0xF0, 0x1B, 0xA4, 0x24, 0x5D, 0xF5, 0x82, 0xE4,
-0x34, 0x93, 0xF5, 0x83, 0xE0, 0x22, 0xFD, 0xEE,
-0x13, 0x13, 0x54, 0x07, 0xFB, 0x90, 0x93, 0x58,
-0xE0, 0xFE, 0xC4, 0x54, 0x0F, 0x90, 0x97, 0x28,
-0xF0, 0xAF, 0x04, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x97, 0x25, 0xEF, 0xF0, 0xED,
-0x64, 0x01, 0x70, 0x31, 0xEB, 0xB4, 0x01, 0x07,
-0xE0, 0x24, 0x02, 0xF5, 0x10, 0x80, 0x08, 0x90,
-0x97, 0x25, 0xE0, 0x24, 0xFE, 0xF5, 0x10, 0x90,
-0x96, 0xD1, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0xFF, 0xAF, 0x10, 0xE4, 0xFC, 0xFD, 0xFE, 0x12,
-0xEA, 0xF6, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0xFF, 0xAF, 0x10, 0x80, 0x1F, 0x90, 0x96, 0xD1,
-0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0xFF, 0x90,
-0x97, 0x25, 0x12, 0x8F, 0xEA, 0x12, 0xEA, 0xF6,
-0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0xFF, 0x90,
-0x97, 0x25, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD, 0xFE,
-0x90, 0x96, 0xD5, 0x12, 0x04, 0x31, 0x7D, 0x18,
-0x7C, 0x00, 0x7F, 0x01, 0xF1, 0x7B, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x96, 0xCF, 0xEC, 0xF0, 0xA3,
-0xED, 0xF0, 0x90, 0x96, 0xCE, 0xEF, 0xF0, 0xA3,
-0xA3, 0xE0, 0xFD, 0x12, 0x7B, 0xBD, 0x90, 0x96,
-0xD9, 0x12, 0x04, 0x31, 0x90, 0x96, 0xD1, 0x12,
-0x04, 0xB8, 0x12, 0x03, 0xCD, 0x90, 0x96, 0xD9,
-0x12, 0xEB, 0x3C, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x96, 0xD1, 0x12, 0x04,
-0xB8, 0x90, 0x96, 0xD5, 0x12, 0xEB, 0x3C, 0xD0,
+0xD4, 0xF0, 0xEF, 0x75, 0xF0, 0x1B, 0xA4, 0x24,
+0x61, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
+0xE0, 0xF4, 0x90, 0x04, 0xD5, 0xF0, 0x80, 0x07,
+0x90, 0x04, 0xD4, 0xE4, 0xF0, 0xA3, 0xF0, 0x7F,
+0x01, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93,
+0x58, 0xE0, 0x30, 0xE0, 0x78, 0x90, 0x93, 0xDA,
+0xE0, 0x04, 0x31, 0xA0, 0x04, 0xFF, 0x90, 0x96,
+0x1B, 0xF0, 0x90, 0x93, 0x59, 0xE0, 0xB5, 0x07,
+0x05, 0xE4, 0x90, 0x96, 0x1B, 0xF0, 0x90, 0x93,
+0xD8, 0xE0, 0xFF, 0x60, 0x0F, 0x51, 0xAE, 0xC3,
+0x9F, 0xB1, 0x18, 0xFB, 0xFD, 0x7F, 0x50, 0x7E,
+0x01, 0x12, 0x66, 0x33, 0x90, 0x96, 0x1B, 0xE0,
+0x51, 0xCA, 0x54, 0x07, 0x90, 0x96, 0x1C, 0x51,
+0xC1, 0x54, 0x07, 0xFF, 0x14, 0x60, 0x0E, 0x14,
+0x60, 0x07, 0x14, 0x60, 0x08, 0x24, 0x03, 0x70,
+0x08, 0xD1, 0x8D, 0x80, 0x02, 0xD1, 0x8D, 0x11,
+0x32, 0xD1, 0xCC, 0x50, 0x20, 0x90, 0x96, 0x1C,
+0xE0, 0xFF, 0x64, 0x02, 0x60, 0x03, 0xEF, 0x70,
+0x0E, 0x51, 0xAE, 0x24, 0xFC, 0xFF, 0xE4, 0x90,
+0x92, 0x20, 0xF0, 0xA3, 0xEF, 0xB1, 0x58, 0x51,
+0xAE, 0xB1, 0x18, 0xD1, 0xC3, 0x22, 0x90, 0x96,
+0x1B, 0xE0, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x5D,
+0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0,
+0x22, 0xF0, 0x90, 0x93, 0x58, 0xE0, 0xC3, 0x13,
+0x54, 0x07, 0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x5E,
+0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0,
+0x22, 0x90, 0x93, 0x58, 0xE0, 0x20, 0xE0, 0x02,
+0xA1, 0x07, 0xC3, 0x13, 0x54, 0x07, 0x60, 0x02,
+0xA1, 0x07, 0x90, 0x93, 0xD9, 0xE0, 0x30, 0xE0,
+0x55, 0xD1, 0xCC, 0x40, 0x51, 0x90, 0x93, 0xE0,
+0xE0, 0x30, 0xE0, 0x23, 0x54, 0xFE, 0xF0, 0x90,
+0x93, 0xE2, 0xE0, 0x90, 0x93, 0xD6, 0xF0, 0x90,
+0x93, 0xE5, 0xE0, 0x90, 0x93, 0xD7, 0xF0, 0x90,
+0x93, 0xE3, 0xE0, 0x90, 0x93, 0x5D, 0xF0, 0x90,
+0x93, 0xE4, 0xE0, 0x90, 0x93, 0x78, 0xF0, 0x90,
+0x05, 0x58, 0xE0, 0x90, 0x95, 0xF9, 0x51, 0xC1,
+0x54, 0x07, 0xFF, 0x64, 0x02, 0x60, 0x03, 0xEF,
+0x70, 0x06, 0xB1, 0x22, 0x24, 0xFD, 0xB1, 0x55,
+0xB1, 0x22, 0x90, 0x92, 0x21, 0xF0, 0xE4, 0xD1,
+0xC3, 0xE4, 0x90, 0x93, 0xDA, 0xF0, 0x90, 0x93,
+0xD5, 0xE0, 0x20, 0xE0, 0x02, 0xA1, 0x07, 0x90,
+0x93, 0xD9, 0xE0, 0xFF, 0xC3, 0x13, 0xFE, 0x54,
+0x1F, 0x70, 0x02, 0xA1, 0x07, 0xEF, 0x54, 0xC1,
+0xFF, 0xEE, 0x14, 0x54, 0x1F, 0xFE, 0x25, 0xE0,
+0x4F, 0xF0, 0xE0, 0xC3, 0x13, 0x54, 0x1F, 0x60,
+0x02, 0xA1, 0x07, 0x90, 0x93, 0xE1, 0xE0, 0x30,
+0xE0, 0x17, 0x54, 0xFE, 0xF0, 0x90, 0x93, 0xE0,
+0xE0, 0x44, 0x01, 0xF0, 0xA3, 0xE0, 0x54, 0xFE,
+0xFF, 0x90, 0x93, 0xD5, 0xE0, 0x54, 0x01, 0x4F,
+0xF0, 0x90, 0x05, 0x22, 0xE0, 0x44, 0x40, 0xFD,
+0x7B, 0x58, 0x7F, 0x40, 0x12, 0x8F, 0x64, 0x90,
+0x05, 0x50, 0xE0, 0x54, 0xF7, 0xF0, 0x90, 0x05,
+0x69, 0xB1, 0x34, 0x90, 0x05, 0x68, 0x12, 0x8F,
+0xEC, 0x12, 0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05, 0x6A, 0x12,
+0x8F, 0xEC, 0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0,
 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x86, 0x20, 0x90, 0x96, 0xDD, 0x12, 0x04, 0x31,
-0x90, 0x96, 0xCF, 0xA3, 0xE0, 0xFD, 0xC0, 0x05,
-0x90, 0x96, 0xDD, 0x12, 0x04, 0xB8, 0x90, 0x8B,
-0x9F, 0x12, 0x04, 0x31, 0x90, 0x96, 0xCE, 0xE0,
-0xFF, 0xD0, 0x05, 0x12, 0x79, 0x53, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x93, 0x5A, 0x74, 0x05,
-0xF0, 0x22, 0x12, 0xAC, 0x9E, 0x12, 0x02, 0x06,
-0xFF, 0x54, 0x0F, 0xF5, 0x64, 0xEF, 0xC4, 0x54,
-0x0F, 0x64, 0x0F, 0x70, 0x41, 0x90, 0x93, 0x58,
-0xE0, 0x54, 0xFE, 0xFF, 0xF0, 0xE5, 0x64, 0x54,
-0x07, 0x25, 0xE0, 0xFE, 0xEF, 0x54, 0xF1, 0x4E,
-0x12, 0x87, 0x6D, 0xC4, 0x13, 0x54, 0x07, 0x90,
-0x93, 0xDF, 0x20, 0xE0, 0x05, 0x74, 0x06, 0xF0,
-0x80, 0x03, 0x74, 0x01, 0xF0, 0x7D, 0x20, 0xE4,
-0xFF, 0x12, 0x7C, 0x3B, 0xAF, 0x64, 0x12, 0xA4,
-0xEA, 0xBF, 0x01, 0x06, 0xE4, 0xFD, 0xFF, 0x12,
-0xA4, 0x43, 0x7F, 0x02, 0x01, 0xF4, 0xE5, 0x64,
-0x75, 0xF0, 0x1B, 0xA4, 0x24, 0x5B, 0xF9, 0x74,
-0x93, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0xC0, 0x02,
-0xC0, 0x01, 0xE5, 0x63, 0x24, 0x01, 0xF9, 0xE4,
-0x35, 0x62, 0x85, 0x61, 0x45, 0xF1, 0xDE, 0xD0,
-0x01, 0xD0, 0x02, 0x12, 0x69, 0xF5, 0xE5, 0x64,
-0x12, 0xA6, 0x47, 0x54, 0xF7, 0x11, 0xF8, 0xC4,
-0x54, 0x0F, 0x14, 0x65, 0x64, 0x70, 0x70, 0x90,
-0x88, 0x36, 0xE0, 0x70, 0x07, 0x90, 0x88, 0x2C,
-0xE0, 0x30, 0xE0, 0x04, 0x7F, 0x05, 0x80, 0x5C,
-0x11, 0xF9, 0xC4, 0x54, 0x0F, 0x90, 0x93, 0x59,
-0x12, 0x87, 0xF7, 0xFC, 0x54, 0x0F, 0xC4, 0x54,
-0xF0, 0xFE, 0x90, 0x93, 0x58, 0xE0, 0x54, 0x0F,
-0x4E, 0xF0, 0xEC, 0x54, 0x60, 0xC4, 0x54, 0x0F,
-0xFF, 0x90, 0x93, 0xAD, 0xE0, 0x54, 0xF9, 0x4F,
-0xF0, 0x90, 0x93, 0x58, 0xE0, 0x54, 0xF1, 0xF0,
-0xF1, 0xC8, 0x90, 0x93, 0xD5, 0xE0, 0x90, 0x93,
-0xD9, 0x30, 0xE0, 0x0B, 0xE0, 0x54, 0xFE, 0xF0,
-0x54, 0xC1, 0x44, 0x02, 0xF0, 0x80, 0x07, 0xE0,
-0x44, 0x01, 0xF0, 0x54, 0xC1, 0xF0, 0x90, 0x93,
-0x58, 0xE0, 0x44, 0x01, 0xF0, 0xE4, 0x90, 0x93,
-0x5A, 0xF0, 0x7F, 0x03, 0x12, 0xB8, 0xC6, 0x22,
-0xF0, 0xAB, 0x61, 0xAA, 0x62, 0xA9, 0x63, 0x02,
-0x02, 0x06, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x91, 0x9E, 0x90, 0x05, 0x27, 0xE0, 0xF5,
-0x64, 0x8B, 0x45, 0x8A, 0x46, 0x89, 0x47, 0x75,
-0x48, 0x01, 0x7B, 0x01, 0x7A, 0x88, 0x79, 0x2C,
-0x12, 0x69, 0xF5, 0x11, 0xF9, 0xFF, 0xC3, 0x13,
-0x20, 0xE0, 0x02, 0x21, 0xB6, 0x90, 0x88, 0x2C,
-0xE0, 0x30, 0xE0, 0x71, 0x71, 0x8A, 0x75, 0x64,
-0x21, 0x71, 0xB9, 0x30, 0xE0, 0x04, 0x71, 0xCD,
-0x80, 0x0D, 0xE4, 0x90, 0x88, 0x2D, 0xF0, 0xA3,
-0xF0, 0x7D, 0x40, 0xFF, 0x12, 0x7C, 0x7E, 0x90,
-0x88, 0x2C, 0x71, 0xC5, 0x30, 0xE0, 0x03, 0x43,
-0x64, 0x12, 0xEF, 0xC4, 0x54, 0x0F, 0x30, 0xE0,
-0x03, 0x43, 0x64, 0x14, 0x90, 0x88, 0x2C, 0xE0,
-0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x03, 0x43,
-0x64, 0x80, 0x90, 0x88, 0x2C, 0x91, 0xCA, 0x20,
-0xE0, 0x03, 0x43, 0x64, 0x40, 0x51, 0x71, 0x90,
-0x88, 0x2F, 0xE0, 0x70, 0x04, 0x7F, 0x01, 0x51,
-0x78, 0x90, 0x88, 0x2C, 0x71, 0x91, 0x30, 0xE0,
-0x04, 0x7F, 0x04, 0x80, 0x0C, 0x12, 0x9F, 0xDA,
-0xEF, 0x60, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F,
-0x02, 0x51, 0x78, 0x41, 0x2C, 0x51, 0x6E, 0x90,
-0x88, 0x2F, 0xE0, 0x64, 0x04, 0x60, 0x02, 0x41,
-0x69, 0xFF, 0x51, 0x78, 0x41, 0x69, 0x90, 0x88,
-0x2C, 0xE0, 0x30, 0xE0, 0x77, 0x71, 0x8A, 0x43,
-0x64, 0x31, 0x71, 0xB9, 0x30, 0xE0, 0x04, 0x71,
-0xCD, 0x80, 0x07, 0x7D, 0x40, 0xE4, 0xFF, 0x12,
-0x7C, 0x7E, 0x90, 0x88, 0x2C, 0x71, 0xC5, 0x30,
-0xE0, 0x03, 0x43, 0x64, 0x02, 0xEF, 0xC4, 0x54,
-0x0F, 0x30, 0xE0, 0x03, 0x43, 0x64, 0x04, 0x51,
-0x71, 0x90, 0x88, 0x2C, 0x71, 0x91, 0x30, 0xE0,
-0x10, 0x71, 0x83, 0x60, 0x37, 0x90, 0x8A, 0xB9,
-0x12, 0x8E, 0x5A, 0xE4, 0xFD, 0x7F, 0x02, 0x80,
-0x1E, 0x91, 0x85, 0x71, 0x83, 0x70, 0x1D, 0x12,
-0x7B, 0xAD, 0x12, 0x9F, 0xDA, 0xBF, 0x01, 0x06,
-0x71, 0xDD, 0x7D, 0x01, 0x80, 0x09, 0x90, 0x8A,
-0xB9, 0x12, 0x8E, 0x5A, 0xE4, 0xFD, 0xFF, 0x12,
-0x04, 0x7E, 0x80, 0x08, 0x90, 0x88, 0x39, 0xE0,
-0x90, 0x88, 0x30, 0xF0, 0x90, 0x05, 0x40, 0x74,
-0x22, 0xF0, 0x80, 0x35, 0x51, 0x6E, 0x90, 0x88,
-0x30, 0xE0, 0xB4, 0x02, 0x0C, 0x90, 0x8A, 0xB9,
-0x12, 0x8E, 0x5A, 0x7D, 0x01, 0x7F, 0x04, 0x80,
-0x11, 0x90, 0x88, 0x30, 0xE0, 0xB4, 0x08, 0x0D,
-0x90, 0x8A, 0xB9, 0x12, 0x8E, 0x5A, 0x7D, 0x01,
-0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x91, 0xBE, 0x71,
-0xDD, 0x7D, 0x01, 0x12, 0x04, 0x7E, 0x12, 0xCF,
-0x31, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x75, 0x64,
-0x01, 0x90, 0x05, 0x27, 0xE5, 0x64, 0xF0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x88, 0x2F, 0xE0, 0x90, 0x97, 0x45, 0xF0, 0x6F,
-0x70, 0x02, 0x61, 0x7E, 0xEF, 0x14, 0x60, 0x42,
-0x14, 0x60, 0x6C, 0x14, 0x70, 0x02, 0x61, 0x2A,
-0x14, 0x70, 0x02, 0x61, 0x55, 0x24, 0x04, 0x60,
-0x02, 0x61, 0x7E, 0x90, 0x97, 0x45, 0xE0, 0xB4,
-0x04, 0x04, 0x91, 0x4A, 0x61, 0x7E, 0x90, 0x97,
-0x45, 0xE0, 0xB4, 0x02, 0x04, 0x91, 0x5A, 0x61,
-0x7E, 0x90, 0x97, 0x45, 0xE0, 0xB4, 0x03, 0x04,
-0x91, 0x3B, 0x61, 0x7E, 0x90, 0x97, 0x45, 0xE0,
-0x64, 0x01, 0x60, 0x02, 0x61, 0x7E, 0x91, 0x3D,
-0x61, 0x7E, 0x90, 0x97, 0x45, 0xE0, 0xB4, 0x04,
-0x04, 0x91, 0x4E, 0x61, 0x7E, 0x90, 0x97, 0x45,
-0xE0, 0xB4, 0x02, 0x04, 0x91, 0x5E, 0x61, 0x7E,
-0x90, 0x97, 0x45, 0xE0, 0xB4, 0x03, 0x04, 0x91,
-0x31, 0x61, 0x7E, 0x90, 0x97, 0x45, 0xE0, 0x60,
-0x02, 0x61, 0x7E, 0x71, 0xEE, 0x80, 0x7F, 0x90,
-0x97, 0x45, 0xE0, 0xB4, 0x04, 0x04, 0x91, 0x8D,
-0x80, 0x74, 0x90, 0x97, 0x45, 0xE0, 0xB4, 0x01,
-0x04, 0x91, 0x07, 0x80, 0x69, 0x90, 0x97, 0x45,
-0xE0, 0xB4, 0x03, 0x04, 0x91, 0xAD, 0x80, 0x5E,
-0x90, 0x97, 0x45, 0xE0, 0x70, 0x58, 0x91, 0x05,
-0x80, 0x54, 0x90, 0x97, 0x45, 0xE0, 0xB4, 0x04,
-0x04, 0x91, 0x74, 0x80, 0x49, 0x90, 0x97, 0x45,
-0xE0, 0xB4, 0x01, 0x04, 0x91, 0x1D, 0x80, 0x3E,
-0x90, 0x97, 0x45, 0xE0, 0xB4, 0x02, 0x04, 0x91,
-0xA5, 0x80, 0x33, 0x90, 0x97, 0x45, 0xE0, 0x70,
-0x2D, 0x91, 0x1B, 0x80, 0x29, 0x90, 0x97, 0x45,
-0xE0, 0xB4, 0x03, 0x04, 0xD1, 0xC0, 0x80, 0x1E,
-0x90, 0x97, 0x45, 0xE0, 0xB4, 0x01, 0x04, 0x71,
-0xF7, 0x80, 0x13, 0x90, 0x97, 0x45, 0xE0, 0xB4,
-0x02, 0x04, 0xD1, 0xDE, 0x80, 0x08, 0x90, 0x97,
-0x45, 0xE0, 0x70, 0x02, 0x71, 0xF5, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x88, 0x30, 0xE0, 0x64,
-0x02, 0x22, 0x7D, 0x03, 0x7F, 0x02, 0x02, 0x7C,
-0x05, 0xE0, 0xFF, 0xC4, 0x13, 0x13, 0x54, 0x03,
-0x22, 0x90, 0x88, 0x2C, 0x71, 0x91, 0x30, 0xE0,
-0x11, 0x71, 0x83, 0x60, 0x0D, 0x90, 0x8A, 0xB9,
-0x12, 0x8E, 0x5A, 0x7D, 0x01, 0x7F, 0x02, 0x12,
-0x04, 0x7E, 0x71, 0x83, 0x60, 0x02, 0xF1, 0xA0,
-0x22, 0x90, 0x88, 0x2C, 0xE0, 0x13, 0x13, 0x54,
-0x3F, 0x22, 0x90, 0x88, 0x32, 0xE0, 0xFF, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x22, 0x90, 0x01, 0x34,
-0x74, 0x40, 0xF0, 0xFD, 0xE4, 0xFF, 0x12, 0x7C,
-0x74, 0x43, 0x64, 0x08, 0x22, 0x90, 0x88, 0x38,
-0xE0, 0xFF, 0x90, 0x8A, 0xB9, 0xE0, 0xFC, 0xA3,
-0xE0, 0xF5, 0x82, 0x8C, 0x83, 0x22, 0x90, 0x88,
-0x2F, 0x74, 0x01, 0xF0, 0x22, 0x71, 0xEE, 0x90,
-0x8A, 0xF9, 0x12, 0x8E, 0x5A, 0x7D, 0x1F, 0xD1,
-0xCE, 0x74, 0x04, 0xF0, 0x22, 0x71, 0xEE, 0x90,
-0x8A, 0xF9, 0x12, 0x8E, 0x5A, 0x7D, 0x20, 0x91,
-0xB5, 0x12, 0x88, 0xCD, 0x90, 0x88, 0x2F, 0x74,
-0x02, 0xF0, 0x22, 0x71, 0xEE, 0x90, 0x8A, 0xF9,
-0x12, 0x8E, 0x5A, 0x7D, 0x21, 0x7F, 0xFF, 0x12,
-0x04, 0x7E, 0x90, 0x88, 0x2F, 0x74, 0x03, 0xF0,
-0x22, 0x90, 0x8A, 0xF9, 0x12, 0x8E, 0x5A, 0x91,
-0x6E, 0x80, 0xB3, 0x91, 0x31, 0x90, 0x05, 0x27,
-0xE0, 0x54, 0xBF, 0xF0, 0xE4, 0x90, 0x88, 0x2F,
-0xF0, 0x22, 0x91, 0x4E, 0x80, 0xEF, 0x90, 0x8A,
-0xF9, 0x12, 0x8E, 0x5A, 0x91, 0x6E, 0x91, 0x85,
-0x80, 0x94, 0x91, 0x5E, 0x80, 0xDF, 0x90, 0x86,
-0x0C, 0x12, 0x88, 0xCD, 0x90, 0x8A, 0xF9, 0x12,
-0x8E, 0x5A, 0x91, 0x6E, 0x80, 0x80, 0xE4, 0xFD,
-0xFF, 0x02, 0x04, 0x7E, 0x90, 0x8A, 0xF9, 0x12,
-0x8E, 0x5A, 0x7D, 0x22, 0x7F, 0xFF, 0x12, 0x04,
-0x7E, 0x91, 0x85, 0x80, 0xA5, 0x90, 0x05, 0x27,
-0xE0, 0x44, 0x40, 0xF0, 0x22, 0x91, 0x85, 0x90,
-0x8A, 0xF9, 0x12, 0x8E, 0x5A, 0x7D, 0x23, 0x91,
-0xB5, 0x12, 0x88, 0xCD, 0x81, 0x14, 0x8B, 0x61,
-0x8A, 0x62, 0x89, 0x63, 0x22, 0x90, 0x86, 0x0C,
-0x12, 0x88, 0xCD, 0x81, 0x2A, 0x90, 0x8A, 0xEF,
-0x12, 0x88, 0xCD, 0x81, 0x14, 0x7F, 0xFF, 0x12,
-0x04, 0x7E, 0x90, 0x8A, 0xEF, 0x22, 0x12, 0x7A,
-0x65, 0xEF, 0x70, 0x02, 0xD1, 0xF2, 0x22, 0x90,
-0x88, 0xA1, 0xE0, 0xC4, 0x13, 0x13, 0x54, 0x03,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x97, 0x10, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
-0x90, 0x86, 0xB1, 0xE0, 0x04, 0xF0, 0x90, 0x88,
-0x9D, 0xE0, 0x30, 0xE0, 0x07, 0x90, 0x05, 0x10,
-0xE4, 0xF0, 0xA3, 0xF0, 0x90, 0x04, 0x1D, 0xE0,
-0x60, 0x3F, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x97,
-0x14, 0xF0, 0x7B, 0x26, 0x12, 0x88, 0xC3, 0xEF,
-0x64, 0x01, 0x70, 0x0B, 0xB1, 0x6D, 0x90, 0x93,
-0x58, 0xE0, 0x20, 0xE0, 0x14, 0x80, 0x0E, 0x91,
-0xC7, 0x30, 0xE0, 0x0D, 0xB1, 0x6D, 0x90, 0x93,
-0x58, 0xE0, 0x20, 0xE0, 0x04, 0xB1, 0xB4, 0xEE,
-0xF0, 0x90, 0x97, 0x14, 0xE0, 0xFD, 0x7B, 0x27,
-0xE4, 0xFF, 0x12, 0xA4, 0xC7, 0xB1, 0xA0, 0x80,
-0x0F, 0xB1, 0xA0, 0xB1, 0x6D, 0x90, 0x93, 0x58,
-0xE0, 0x20, 0xE0, 0x04, 0xB1, 0xB4, 0xEE, 0xF0,
-0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x16, 0x91,
-0xC7, 0x30, 0xE0, 0x11, 0x90, 0x05, 0x22, 0xE0,
-0x54, 0x6F, 0xFF, 0x90, 0x8A, 0xF9, 0x71, 0xE5,
-0x7D, 0x28, 0x12, 0x04, 0x7E, 0x12, 0xEB, 0xE2,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x86, 0xB6,
-0xE0, 0xFF, 0x90, 0x97, 0x11, 0xE0, 0xFB, 0x90,
-0x92, 0x13, 0x74, 0x0A, 0xF0, 0x7D, 0x01, 0x12,
-0x66, 0xDB, 0x90, 0x97, 0x12, 0xEE, 0xF0, 0xFC,
-0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x97, 0x10, 0xE0,
-0xFF, 0x90, 0x8A, 0x95, 0xE0, 0xFA, 0xA3, 0xE0,
-0xFB, 0xF5, 0x82, 0x8A, 0x83, 0x02, 0x04, 0x7E,
-0x90, 0x97, 0x10, 0xE0, 0xFF, 0x90, 0x8A, 0xC7,
-0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xF5, 0x82, 0x8C,
-0x83, 0x02, 0x04, 0x7E, 0x90, 0x97, 0x12, 0xE0,
-0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x8A, 0x9B, 0xE0,
-0xFC, 0xA3, 0xE0, 0xFD, 0xF5, 0x82, 0x8C, 0x83,
-0x12, 0x04, 0x7E, 0x90, 0x97, 0x12, 0xA3, 0xE0,
-0xFF, 0x24, 0x12, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
-0xF5, 0x83, 0xE0, 0x54, 0x01, 0xFE, 0x90, 0x97,
-0x11, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0x44, 0x02,
-0x4E, 0xFE, 0x74, 0x12, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x1A, 0xED,
-0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x97, 0x19, 0xEF,
-0xF0, 0xE4, 0xFD, 0xFC, 0x12, 0xE2, 0xE8, 0x90,
-0x97, 0x1C, 0xF0, 0x12, 0x7B, 0x07, 0x7C, 0x00,
-0xAD, 0x07, 0x90, 0x97, 0x19, 0xE0, 0x90, 0x04,
-0x25, 0xF0, 0x90, 0x97, 0x1A, 0xE0, 0x60, 0x05,
-0xD1, 0xB4, 0x44, 0x80, 0xF0, 0xAF, 0x05, 0x74,
-0x20, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xE0, 0x54, 0xC0, 0xF0, 0xD1, 0xB4, 0x54,
-0xC0, 0xF0, 0x90, 0x97, 0x1C, 0xE0, 0xFF, 0xAE,
-0x05, 0x74, 0x18, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00, 0x8B,
-0xE0, 0xD3, 0x94, 0x03, 0x74, 0x10, 0x2E, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x74, 0x04,
-0xF0, 0xAF, 0x05, 0xB1, 0xEA, 0xE0, 0x54, 0x01,
-0xFE, 0x90, 0x97, 0x1B, 0xE0, 0x25, 0xE0, 0x25,
-0xE0, 0xFB, 0xEE, 0x44, 0x02, 0x4B, 0xB1, 0xE9,
-0xEE, 0xF0, 0x74, 0x11, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0x74, 0xFF, 0xF0, 0x74,
-0x29, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xE0, 0x54, 0xF7, 0xF0, 0x74, 0x0D, 0x2D,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
-0x44, 0x80, 0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x74, 0x21, 0x2F, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22,
-0x90, 0x8A, 0xF9, 0x12, 0x8E, 0x5A, 0x7D, 0x25,
-0xD1, 0xCE, 0x74, 0x04, 0xF0, 0x22, 0x7F, 0x6F,
-0x12, 0x04, 0x7E, 0x90, 0x05, 0x27, 0xE0, 0x54,
-0xBF, 0xF0, 0x90, 0x88, 0x2F, 0x22, 0x90, 0x86,
-0x0C, 0x12, 0x88, 0xCD, 0x90, 0x8A, 0xF9, 0x12,
-0x8E, 0x5A, 0x7D, 0x24, 0xD1, 0xCE, 0x74, 0x04,
-0xF0, 0x22, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x04,
-0x02, 0xF1, 0xD6, 0x90, 0x88, 0x9D, 0xE0, 0x20,
-0xE0, 0x03, 0x12, 0xEA, 0x24, 0x22, 0x90, 0x88,
-0x2C, 0xE0, 0x90, 0x88, 0x38, 0x30, 0xE0, 0x04,
-0xE0, 0xFF, 0x80, 0x07, 0x71, 0xE0, 0x7D, 0x01,
-0x02, 0x04, 0x7E, 0xAE, 0x07, 0x12, 0x9F, 0xDA,
-0xBF, 0x01, 0x14, 0x90, 0x88, 0x2C, 0x91, 0xCA,
-0x20, 0xE0, 0x0C, 0xAF, 0x06, 0x71, 0xE2, 0x7D,
-0x01, 0x12, 0x04, 0x7E, 0x7F, 0x01, 0x22, 0x7F,
-0x00, 0x22, 0x71, 0xC2, 0x30, 0xE0, 0x0B, 0xEF,
-0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
-0xF1, 0xCF, 0x12, 0xB5, 0x29, 0x30, 0xE0, 0x09,
-0x12, 0xB5, 0xCF, 0x54, 0x07, 0x70, 0x40, 0x80,
-0x3C, 0x12, 0xEA, 0x0D, 0xD3, 0x9F, 0x40, 0x35,
-0x12, 0x9F, 0xD1, 0x70, 0x32, 0xF1, 0xC1, 0x70,
-0x08, 0x90, 0x8A, 0xF5, 0x12, 0x88, 0xCD, 0x80,
-0x27, 0x90, 0x8A, 0xF5, 0x12, 0x88, 0xCD, 0x90,
-0x88, 0x40, 0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94,
-0x02, 0x40, 0x09, 0xF1, 0x98, 0xE4, 0x90, 0x88,
-0x40, 0xF0, 0x80, 0x03, 0x12, 0xE7, 0x55, 0xE4,
-0x90, 0x88, 0x3F, 0xF0, 0x22, 0xF1, 0x06, 0x22,
-0x90, 0x88, 0x32, 0xE0, 0x54, 0xFB, 0xF0, 0x22,
-0x90, 0x88, 0x36, 0xE0, 0x64, 0x02, 0x60, 0x17,
-0xF1, 0xC1, 0x60, 0x13, 0x12, 0x7A, 0x65, 0xEF,
-0x70, 0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x8E, 0x5A,
-0xE4, 0xFD, 0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x22,
-0xF0, 0x90, 0x88, 0x34, 0xE0, 0x54, 0x0F, 0x22,
-0x90, 0x05, 0x58, 0x74, 0x02, 0xF0, 0x22, 0x7D,
-0x02, 0x7F, 0x02, 0x02, 0x7C, 0x7E, 0x90, 0x00,
-0x02, 0xE0, 0x44, 0x01, 0xF0, 0x22, 0xF5, 0x46,
-0x89, 0x47, 0x75, 0x48, 0x04, 0x22, 0x91, 0x9E,
-0x90, 0x93, 0xE0, 0xE0, 0x54, 0xFE, 0x12, 0x87,
-0x66, 0xFC, 0x30, 0xE0, 0x45, 0x90, 0x93, 0xE1,
-0xE0, 0x44, 0x01, 0xFE, 0xF0, 0x12, 0x02, 0x06,
-0x54, 0xFE, 0xFD, 0xEE, 0x54, 0x01, 0x4D, 0x90,
-0x93, 0xE1, 0xF0, 0x12, 0x8F, 0x98, 0x90, 0x93,
-0xE2, 0xF0, 0xEC, 0xC3, 0x13, 0x54, 0x7F, 0xFF,
-0xA3, 0xF0, 0x12, 0x87, 0xF1, 0xFE, 0xC3, 0x9F,
-0x90, 0x93, 0xE4, 0xF0, 0xA3, 0xEE, 0xF0, 0xBE,
-0x64, 0x04, 0x74, 0x01, 0xF0, 0x22, 0x90, 0x93,
-0xE5, 0xE0, 0x64, 0x96, 0x70, 0x54, 0x74, 0x03,
-0xF0, 0x22, 0x90, 0x93, 0xE1, 0xE0, 0x54, 0xFE,
-0x12, 0xA8, 0xF8, 0xFF, 0x54, 0x01, 0xFE, 0x90,
-0x93, 0xD5, 0xE0, 0x54, 0xFE, 0x4E, 0xFE, 0xF0,
-0xEF, 0x54, 0xFE, 0xFF, 0xEE, 0x54, 0x01, 0x4F,
-0xF0, 0x12, 0x8F, 0x98, 0x90, 0x93, 0xD6, 0xF0,
-0x12, 0x87, 0xF1, 0x90, 0x93, 0xD7, 0xF0, 0xE4,
-0xA3, 0xF0, 0x90, 0x93, 0xD7, 0xE0, 0xFF, 0xB4,
-0x64, 0x05, 0x74, 0x01, 0xF0, 0x80, 0x0A, 0xEF,
-0xB4, 0x96, 0x06, 0x90, 0x93, 0xD7, 0x74, 0x03,
-0xF0, 0x90, 0x93, 0xD7, 0xE0, 0x04, 0x90, 0x93,
-0xDA, 0xF0, 0x22, 0x11, 0xF4, 0x90, 0x93, 0x03,
-0xE0, 0x54, 0xFE, 0x4E, 0xF0, 0x30, 0xE0, 0x27,
-0xEF, 0x54, 0x04, 0x25, 0xE0, 0xFE, 0xE0, 0x54,
-0xF7, 0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x02, 0x25,
-0xE0, 0xFF, 0xEE, 0x54, 0xFB, 0x4F, 0xF0, 0x90,
-0x04, 0x57, 0xE0, 0x90, 0x93, 0x05, 0xF0, 0x90,
-0x04, 0x55, 0xE0, 0x90, 0x93, 0x04, 0xF0, 0x90,
-0x93, 0x03, 0xE0, 0x54, 0x01, 0xFF, 0xEF, 0x90,
-0x07, 0xDC, 0x60, 0x25, 0xE4, 0xF0, 0xF0, 0x90,
-0x07, 0xDE, 0xF0, 0xA3, 0x04, 0xF0, 0x90, 0x07,
-0xDD, 0x74, 0x03, 0xF0, 0x90, 0x07, 0xE3, 0xE0,
-0xF0, 0xA3, 0x74, 0x50, 0xF0, 0xA3, 0x74, 0x10,
-0xF0, 0x90, 0x07, 0xDC, 0xE0, 0x44, 0x01, 0xF0,
-0x22, 0xE4, 0xF0, 0x22, 0x12, 0x02, 0x06, 0xFF,
-0x54, 0x01, 0xFE, 0x22, 0x11, 0xF4, 0x90, 0x93,
-0x3B, 0x12, 0xBE, 0x90, 0x4F, 0xF0, 0x12, 0x8F,
-0x98, 0x90, 0x93, 0x3C, 0xF0, 0x12, 0x87, 0xF1,
-0x90, 0x93, 0x3D, 0xF0, 0xB1, 0x74, 0x90, 0x93,
-0x3B, 0xE0, 0x54, 0x01, 0xFF, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0xEF, 0x64, 0x01, 0x70,
-0x19, 0x31, 0x69, 0x60, 0x09, 0x31, 0x62, 0x12,
-0x7C, 0x05, 0xB1, 0x6B, 0x80, 0x07, 0x31, 0x62,
-0x12, 0x7C, 0x3B, 0xB1, 0x33, 0x12, 0x79, 0xD4,
-0x80, 0x17, 0x31, 0x69, 0x60, 0x07, 0x31, 0x62,
-0x12, 0x7C, 0x05, 0x80, 0x05, 0x31, 0x62, 0x12,
-0x7C, 0x3B, 0xB1, 0x1B, 0xB1, 0x22, 0x12, 0x7B,
-0xCC, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90,
-0x01, 0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F, 0x03,
-0x22, 0x90, 0x93, 0x3D, 0xE0, 0x90, 0x01, 0x3F,
-0x22, 0xE4, 0x90, 0x95, 0xE7, 0xF0, 0x12, 0x9F,
-0xD2, 0x60, 0x02, 0x41, 0xBF, 0x90, 0x88, 0x36,
-0xE0, 0x70, 0x02, 0x41, 0xBF, 0x90, 0x88, 0x2C,
-0xE0, 0x20, 0xE0, 0x36, 0x90, 0x88, 0x9D, 0xE0,
-0x20, 0xE0, 0x2F, 0x90, 0x06, 0xA9, 0xE0, 0x54,
-0xC0, 0x70, 0x27, 0x90, 0x88, 0x9C, 0xE0, 0x70,
-0x21, 0x90, 0x04, 0x1A, 0xE0, 0xF4, 0x70, 0x1A,
-0xA3, 0xE0, 0x54, 0x07, 0xFF, 0xBF, 0x07, 0x12,
-0x90, 0x06, 0x62, 0xE0, 0x54, 0x03, 0x70, 0x0A,
-0x90, 0x88, 0x39, 0xE0, 0xB4, 0x04, 0x03, 0x12,
-0xDB, 0xBC, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x88,
-0x85, 0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x88,
-0x86, 0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x88,
-0x87, 0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x88,
-0x88, 0xF0, 0x90, 0x07, 0xF1, 0xE0, 0x90, 0x95,
-0x35, 0xF0, 0x90, 0x07, 0xF0, 0xE0, 0x90, 0x95,
-0x36, 0xF0, 0xB1, 0xA1, 0xF0, 0x90, 0x88, 0x3A,
-0xE0, 0x54, 0xEC, 0xF0, 0x51, 0xDB, 0x24, 0xFD,
-0x50, 0x02, 0x80, 0x0F, 0x90, 0x88, 0x2C, 0xE0,
-0x30, 0xE0, 0x05, 0x12, 0xE6, 0x77, 0x80, 0x03,
-0x12, 0xE6, 0xF9, 0x51, 0xDB, 0x64, 0x01, 0x70,
-0x3A, 0x90, 0x06, 0xAB, 0xE0, 0x90, 0x88, 0x3D,
-0xF0, 0x90, 0x06, 0xA9, 0xE0, 0x30, 0xE5, 0x06,
-0xA3, 0xE0, 0x90, 0x95, 0xE7, 0xF0, 0x90, 0x95,
-0xE7, 0xE0, 0xFF, 0x60, 0x02, 0x80, 0x05, 0x90,
-0x88, 0x3C, 0xE0, 0xFF, 0x90, 0x88, 0x3C, 0xEF,
-0xF0, 0xA3, 0xE0, 0xFF, 0x70, 0x08, 0x90, 0x88,
-0x3C, 0xE0, 0xFE, 0xFF, 0x80, 0x00, 0x90, 0x88,
-0x3D, 0xEF, 0xF0, 0x51, 0xE4, 0xE4, 0x90, 0x88,
-0x3F, 0xF0, 0xA3, 0xF0, 0x12, 0xAB, 0xC2, 0x30,
-0xE0, 0x5B, 0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03,
-0x20, 0xE0, 0x24, 0x51, 0xD3, 0x6F, 0x70, 0x4D,
-0xEF, 0x60, 0x4A, 0x90, 0x88, 0x32, 0xE0, 0x44,
-0x40, 0xF0, 0x12, 0xEB, 0xF4, 0x31, 0x5E, 0x12,
-0x7C, 0x05, 0xB1, 0x3A, 0x12, 0xAF, 0xCF, 0x90,
-0x88, 0x3D, 0xE0, 0x14, 0xF0, 0x80, 0x2E, 0x90,
-0x88, 0x34, 0xE0, 0xC4, 0x54, 0x0F, 0x64, 0x01,
-0x70, 0x23, 0x51, 0xD3, 0xFE, 0x6F, 0x60, 0x1D,
-0x90, 0x05, 0x73, 0xE0, 0xFF, 0xEE, 0x6F, 0x60,
-0x14, 0x90, 0x88, 0x32, 0xB1, 0x2C, 0x30, 0xE0,
-0x0C, 0xEF, 0x54, 0xBF, 0x31, 0x5E, 0x12, 0x7C,
-0x3B, 0xB1, 0x22, 0xB1, 0x1B, 0x51, 0xCB, 0x90,
-0x88, 0x2C, 0xE0, 0xC3, 0x13, 0x20, 0xE0, 0x02,
-0x51, 0xCB, 0x22, 0x90, 0x88, 0x32, 0xE0, 0x44,
-0x04, 0xF0, 0x22, 0x90, 0x88, 0x3C, 0xE0, 0xFF,
-0xA3, 0xE0, 0x22, 0x90, 0x88, 0x34, 0xE0, 0xFF,
-0xC4, 0x54, 0x0F, 0x22, 0x90, 0x88, 0x85, 0x12,
-0x04, 0xB8, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x95,
-0x36, 0xE0, 0x24, 0x46, 0xFF, 0x90, 0x95, 0x35,
-0xE0, 0x34, 0x00, 0xAB, 0x07, 0xFA, 0xE4, 0xF9,
-0xF8, 0xD0, 0x07, 0xD0, 0x06, 0x12, 0x85, 0xB6,
-0x90, 0x88, 0x85, 0x91, 0xEE, 0xEF, 0x24, 0x46,
-0x12, 0xB8, 0xBB, 0x90, 0x88, 0x89, 0x91, 0xEE,
-0x90, 0x88, 0x85, 0x12, 0xB8, 0xB4, 0x50, 0x02,
-0x61, 0xD5, 0x90, 0x88, 0x89, 0x12, 0x86, 0x2D,
-0x90, 0x88, 0x85, 0x12, 0x04, 0xB8, 0x12, 0x85,
-0xB6, 0x90, 0x95, 0xEC, 0x12, 0x04, 0x31, 0x90,
-0x88, 0x31, 0xE0, 0x30, 0xE0, 0x2F, 0x90, 0x88,
-0x53, 0xE0, 0x24, 0x04, 0xFF, 0xE4, 0x33, 0xFE,
-0xEF, 0x78, 0x03, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
-0xD8, 0xF9, 0x24, 0x50, 0xFF, 0xE4, 0x3E, 0xFE,
-0x90, 0x88, 0x4E, 0xE0, 0xFD, 0xC3, 0xEF, 0x9D,
-0xFB, 0xEE, 0x94, 0x00, 0xFA, 0x91, 0xF7, 0xEB,
-0x2F, 0xFF, 0xEA, 0x80, 0x1D, 0x90, 0x88, 0x33,
-0xB1, 0x2C, 0x30, 0xE0, 0x02, 0x81, 0xD3, 0x91,
-0xF7, 0x90, 0x88, 0x4E, 0xE0, 0xFD, 0xC3, 0x74,
-0x60, 0x9D, 0xCD, 0xE4, 0x94, 0x00, 0xCD, 0x2F,
-0xFF, 0xED, 0x3E, 0x90, 0x95, 0xE8, 0xF0, 0xA3,
-0xEF, 0xF0, 0xC3, 0x90, 0x95, 0xE9, 0xE0, 0x94,
-0xA0, 0x90, 0x95, 0xE8, 0xE0, 0x94, 0x00, 0x50,
-0x34, 0xA3, 0xE0, 0xFB, 0x24, 0xF5, 0x91, 0xE6,
-0xE0, 0x04, 0xF0, 0x90, 0x95, 0xEC, 0x12, 0x04,
-0xB8, 0xEF, 0x54, 0x7F, 0xFF, 0x74, 0x95, 0x2B,
-0x91, 0xDB, 0xE0, 0xFE, 0xEF, 0xC3, 0x9E, 0x50,
-0x09, 0x90, 0x95, 0xE8, 0xA3, 0xE0, 0x91, 0xD9,
-0xEF, 0xF0, 0x90, 0x88, 0x4C, 0xE0, 0x04, 0xF0,
-0xE0, 0x90, 0x00, 0xFE, 0xF0, 0x90, 0x88, 0x4C,
-0xE0, 0xFF, 0xD3, 0x90, 0x88, 0x90, 0xE0, 0x9F,
-0x90, 0x88, 0x8F, 0xE0, 0x94, 0x00, 0x40, 0x02,
-0x81, 0xD3, 0xE4, 0xFF, 0xFE, 0x91, 0xE3, 0xE0,
-0x2F, 0xFF, 0x90, 0x88, 0x91, 0xE0, 0xFD, 0xEF,
-0xD3, 0x9D, 0x40, 0x07, 0x90, 0x95, 0xEA, 0xEE,
-0xF0, 0x80, 0x05, 0x0E, 0xEE, 0xB4, 0xA0, 0xE5,
-0xB1, 0x02, 0x40, 0x02, 0x80, 0x15, 0x90, 0x95,
-0xEA, 0xE0, 0x04, 0xFE, 0xEE, 0xC3, 0x94, 0xA0,
-0x50, 0x13, 0x91, 0xE3, 0xE0, 0x2F, 0xFF, 0xB1,
-0x02, 0x40, 0x07, 0x90, 0x95, 0xEB, 0xEE, 0xF0,
-0x80, 0x03, 0x0E, 0x80, 0xE7, 0x90, 0x05, 0x5E,
-0xE0, 0xFF, 0x91, 0xD4, 0xE0, 0xFD, 0xEF, 0xC3,
-0x9D, 0x40, 0x11, 0xEF, 0x9D, 0x90, 0x05, 0x5E,
-0xF0, 0x90, 0x88, 0x51, 0xEE, 0xF0, 0x90, 0x95,
-0xEB, 0xE0, 0x80, 0x18, 0x91, 0xD4, 0xE0, 0xFD,
-0xC3, 0x74, 0x80, 0x9D, 0x2F, 0x90, 0x05, 0x5E,
-0xF0, 0xEE, 0x04, 0x90, 0x88, 0x51, 0xF0, 0x90,
-0x95, 0xEB, 0xE0, 0x04, 0x90, 0x88, 0x52, 0xF0,
-0x90, 0x88, 0x51, 0xE0, 0xFF, 0xC3, 0x94, 0x50,
-0x40, 0x0A, 0xEF, 0x24, 0xB0, 0x90, 0x88, 0x49,
-0xF0, 0xE4, 0x80, 0x0E, 0xE4, 0x90, 0x88, 0x49,
-0xF0, 0x90, 0x88, 0x51, 0xE0, 0xFF, 0xC3, 0x74,
-0x50, 0x9F, 0x90, 0x88, 0x48, 0xF0, 0x90, 0x88,
-0x51, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90,
-0x88, 0x4F, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0x90,
-0x88, 0x8E, 0xE0, 0x24, 0x08, 0xFF, 0x90, 0x88,
-0x4F, 0xE0, 0x2F, 0xF0, 0x90, 0x88, 0x4F, 0xE0,
-0xC3, 0x94, 0x50, 0x50, 0x03, 0x74, 0x50, 0xF0,
-0x90, 0x88, 0x4F, 0xE0, 0x24, 0x10, 0xF0, 0x12,
-0xBE, 0x9E, 0x74, 0x03, 0xF0, 0x12, 0x6E, 0x2F,
-0x90, 0x8A, 0xA3, 0x12, 0x8E, 0x5A, 0xE4, 0xFF,
-0x12, 0x04, 0x7E, 0x22, 0x90, 0x95, 0xEA, 0xE0,
-0xFE, 0x24, 0x95, 0xF5, 0x82, 0xE4, 0x34, 0x94,
-0xF5, 0x83, 0x22, 0x74, 0xF5, 0x2E, 0xF5, 0x82,
-0xE4, 0x34, 0x93, 0xF5, 0x83, 0x22, 0x12, 0x04,
-0x31, 0x90, 0x88, 0x89, 0x02, 0x04, 0xB8, 0x90,
-0x95, 0xEC, 0x12, 0x04, 0xB8, 0x78, 0x07, 0x02,
-0x03, 0xEB, 0x90, 0x88, 0x91, 0xE0, 0xFD, 0xC3,
-0x90, 0x88, 0x90, 0xE0, 0x9D, 0xFD, 0x90, 0x88,
-0x8F, 0xE0, 0x94, 0x00, 0xFC, 0xEF, 0xD3, 0x9D,
-0xE4, 0x9C, 0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02,
-0x7C, 0x74, 0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C,
-0x74, 0x90, 0x88, 0x31, 0xE0, 0xFF, 0x13, 0x13,
-0x54, 0x3F, 0x22, 0x7D, 0x02, 0x7F, 0x02, 0x12,
-0x7C, 0x7E, 0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C,
-0x7E, 0x12, 0x9F, 0x62, 0xB1, 0x1B, 0x7F, 0x01,
-0xD1, 0x07, 0x90, 0x8B, 0x07, 0x12, 0x88, 0xCD,
-0x90, 0x93, 0x3B, 0xE0, 0x30, 0xE0, 0x13, 0xB1,
-0x6B, 0x90, 0x93, 0x3E, 0xE0, 0x60, 0x05, 0x14,
-0xF0, 0x02, 0x79, 0xD4, 0xB1, 0x74, 0xE4, 0xFF,
-0x31, 0x1D, 0x22, 0x90, 0x93, 0x3D, 0xE0, 0x90,
-0x05, 0x73, 0xF0, 0x22, 0x90, 0x93, 0x3C, 0xE0,
-0x14, 0x90, 0x93, 0x3E, 0xF0, 0x22, 0x90, 0x01,
-0x57, 0xE0, 0x60, 0x1C, 0xB1, 0xA4, 0xF0, 0xB1,
-0x29, 0x30, 0xE0, 0x02, 0x80, 0x41, 0x12, 0xEA,
-0x0D, 0xD3, 0x9F, 0x40, 0x0B, 0xE4, 0xFF, 0x12,
-0x78, 0x4A, 0xBF, 0x01, 0x03, 0x12, 0xAF, 0x98,
-0x22, 0x90, 0x01, 0x57, 0xE4, 0xF0, 0x90, 0x01,
-0x3C, 0x74, 0x02, 0x22, 0x12, 0x9F, 0xD1, 0x70,
-0x1D, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x17, 0x90,
-0x88, 0x3A, 0xE0, 0x20, 0xE4, 0x10, 0xB1, 0xA1,
-0xF0, 0x90, 0x88, 0x31, 0xE0, 0xB1, 0xD0, 0x54,
-0x07, 0x70, 0x03, 0x12, 0xAF, 0x06, 0x22, 0xEF,
-0x54, 0xFB, 0xF0, 0x90, 0x88, 0x3A, 0xE0, 0x54,
-0xFD, 0xF0, 0x22, 0xE4, 0xFE, 0x91, 0xE3, 0xE4,
-0xF0, 0x74, 0x95, 0x2E, 0x91, 0xDB, 0x74, 0xFF,
-0xF0, 0x0E, 0xEE, 0xB4, 0xA0, 0xEF, 0xE4, 0x90,
-0x88, 0x4D, 0xF0, 0x90, 0x88, 0x4C, 0xF0, 0x90,
-0x88, 0x50, 0xF0, 0xEF, 0xB4, 0x01, 0x07, 0xA3,
-0x74, 0xA0, 0xF0, 0xE4, 0xA3, 0xF0, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88,
-0x33, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x28, 0x90,
-0x96, 0x98, 0x74, 0x1E, 0xF0, 0x90, 0x96, 0xBA,
-0x74, 0x01, 0xF0, 0x90, 0x96, 0x9A, 0xEF, 0xF0,
-0x7B, 0x01, 0x7A, 0x96, 0x79, 0x98, 0x12, 0xC9,
-0x9E, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0xE5, 0x12,
-0x8E, 0x5A, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x88, 0x2C, 0xE0,
-0x30, 0xE0, 0x11, 0xA3, 0x74, 0x01, 0xF0, 0x90,
-0x88, 0x2C, 0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0,
-0x03, 0x12, 0xBC, 0x33, 0x12, 0x9E, 0xCE, 0xE4,
-0xFF, 0xD1, 0x07, 0x90, 0x8B, 0x07, 0x12, 0x88,
-0xCD, 0x90, 0x93, 0x58, 0xE0, 0x20, 0xE0, 0x03,
-0x02, 0xB8, 0xA3, 0xC3, 0x13, 0x54, 0x07, 0x60,
-0x03, 0x02, 0xB8, 0xA3, 0x90, 0x93, 0xD9, 0xE0,
-0x30, 0xE0, 0x5B, 0x12, 0xEB, 0x5B, 0x40, 0x56,
-0x90, 0x93, 0xE0, 0xE0, 0x30, 0xE0, 0x23, 0x54,
-0xFE, 0xF0, 0x90, 0x93, 0xE2, 0xE0, 0x90, 0x93,
-0xD6, 0xF0, 0x90, 0x93, 0xE5, 0xE0, 0x90, 0x93,
-0xD7, 0xF0, 0x90, 0x93, 0xE3, 0xE0, 0x90, 0x93,
-0x5D, 0xF0, 0x90, 0x93, 0xE4, 0xE0, 0x90, 0x93,
-0x78, 0xF0, 0x90, 0x05, 0x58, 0xE0, 0x90, 0x95,
-0xF3, 0x12, 0xA6, 0x3E, 0x54, 0x07, 0xFF, 0x64,
-0x02, 0x60, 0x03, 0xEF, 0x70, 0x08, 0x12, 0xEB,
-0x15, 0x24, 0xFD, 0x12, 0x9F, 0x54, 0x12, 0xEB,
-0x15, 0x90, 0x92, 0x21, 0xF0, 0xE4, 0x12, 0xBD,
-0xFC, 0xE4, 0x90, 0x93, 0xDA, 0xF0, 0x90, 0x93,
-0xD5, 0xE0, 0x20, 0xE0, 0x03, 0x02, 0xB8, 0xA3,
-0x90, 0x93, 0xD9, 0xE0, 0xFF, 0xC3, 0x13, 0xFE,
-0x54, 0x1F, 0x70, 0x03, 0x02, 0xB8, 0xA3, 0xEF,
-0x54, 0xC1, 0xFF, 0xEE, 0x14, 0x54, 0x1F, 0xFE,
-0x25, 0xE0, 0x4F, 0xF0, 0xE0, 0xC3, 0x13, 0x54,
-0x1F, 0x60, 0x03, 0x02, 0xB8, 0xA3, 0x90, 0x93,
-0xE1, 0xE0, 0x30, 0xE0, 0x17, 0x54, 0xFE, 0xF0,
-0x90, 0x93, 0xE0, 0xE0, 0x44, 0x01, 0xF0, 0xA3,
-0xE0, 0x54, 0xFE, 0xFF, 0x90, 0x93, 0xD5, 0xE0,
-0x54, 0x01, 0x4F, 0xF0, 0x90, 0x05, 0x22, 0xE0,
-0x44, 0x40, 0xFD, 0x7B, 0x58, 0x7F, 0x40, 0x12,
-0xA4, 0xC7, 0x90, 0x05, 0x50, 0xE0, 0x54, 0xF7,
-0xF0, 0x90, 0x05, 0x69, 0x12, 0xCD, 0xEC, 0x90,
-0x05, 0x68, 0x12, 0x8F, 0xEA, 0x12, 0x86, 0x20,
-0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0x90, 0x05, 0x6A, 0x12, 0x8F, 0xEA, 0x78, 0x10,
+0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0xA3, 0x12, 0x8F, 0xEC, 0x78, 0x18,
 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3, 0x12,
-0x8F, 0xEA, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0,
-0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x86, 0x20, 0x90, 0x95, 0xE7, 0x12, 0x04, 0x31,
-0x12, 0xB8, 0xAE, 0x90, 0x95, 0xEF, 0x12, 0x04,
-0x31, 0x90, 0x05, 0x6D, 0x12, 0xCD, 0xEC, 0x90,
-0x05, 0x6C, 0x12, 0x8F, 0xEA, 0x12, 0x86, 0x20,
+0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0x90, 0x95,
+0xED, 0x12, 0x04, 0x31, 0xB1, 0x0A, 0x90, 0x95,
+0xF5, 0x12, 0x04, 0x31, 0x90, 0x05, 0x6D, 0xB1,
+0x34, 0x90, 0x05, 0x6C, 0x12, 0x8F, 0xEC, 0x12,
+0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x05, 0x6E, 0x12, 0x8F, 0xEC,
+0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0,
+0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x20,
 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0x90, 0x05, 0x6E, 0x12, 0x8F, 0xEA, 0x78, 0x10,
-0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3, 0x12,
-0x8F, 0xEA, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0,
-0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x86, 0x20, 0x90, 0x95, 0xEB, 0x12, 0x04, 0x31,
-0x90, 0x95, 0xE7, 0x12, 0x86, 0x2D, 0xC0, 0x00,
-0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03, 0x90, 0x93,
-0xD5, 0xE0, 0xC3, 0x13, 0x54, 0x7F, 0xFF, 0xE4,
-0xFC, 0xFD, 0xFE, 0xFB, 0x7A, 0x04, 0xF9, 0xF8,
-0x12, 0x85, 0xC4, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x85, 0xA9, 0x90, 0x95,
-0xE7, 0x12, 0x04, 0x31, 0x90, 0x95, 0xEF, 0x12,
-0x04, 0xB8, 0x90, 0x95, 0xE7, 0x11, 0xB4, 0x50,
-0x0D, 0x11, 0xA6, 0xEF, 0x24, 0x01, 0x11, 0xBB,
-0x90, 0x95, 0xEB, 0x12, 0x04, 0x31, 0x11, 0xA6,
-0x78, 0x18, 0x12, 0x03, 0xEB, 0x90, 0x05, 0x67,
-0x11, 0xA4, 0x78, 0x10, 0x12, 0x03, 0xEB, 0x90,
-0x05, 0x66, 0x11, 0xA4, 0x78, 0x08, 0x12, 0x03,
-0xEB, 0x90, 0x05, 0x65, 0x11, 0xA4, 0x90, 0x05,
-0x64, 0x11, 0xAC, 0x78, 0x18, 0x12, 0x03, 0xEB,
-0x90, 0x05, 0x63, 0x11, 0xAC, 0x78, 0x10, 0x12,
-0x03, 0xEB, 0x90, 0x05, 0x62, 0x11, 0xAC, 0x78,
-0x08, 0x12, 0x03, 0xEB, 0x90, 0x05, 0x61, 0x11,
-0xAC, 0x90, 0x05, 0x60, 0xEF, 0xF0, 0x90, 0x05,
-0x50, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x05, 0x22,
-0xE0, 0x54, 0xBF, 0xFD, 0x7B, 0x59, 0x7F, 0x40,
-0x12, 0xA4, 0xC7, 0x7F, 0x08, 0x11, 0xC6, 0x90,
-0x93, 0xD9, 0xE0, 0x54, 0xC1, 0x44, 0x28, 0xF0,
-0x44, 0x01, 0xF0, 0x22, 0xEF, 0xF0, 0x90, 0x95,
-0xEB, 0x02, 0x04, 0xB8, 0xEF, 0xF0, 0x90, 0x95,
-0xE7, 0x02, 0x04, 0xB8, 0x12, 0x86, 0x2D, 0xC3,
-0x02, 0x03, 0xDA, 0xFF, 0xE4, 0x3E, 0xFE, 0xE4,
-0x3D, 0xFD, 0xE4, 0x3C, 0xFC, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xAD, 0x07, 0x90,
-0x05, 0x63, 0xE0, 0xFE, 0x90, 0x05, 0x62, 0xE0,
-0x7A, 0x00, 0x24, 0x00, 0xFF, 0xEA, 0x3E, 0x90,
-0x96, 0x96, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x05,
-0x61, 0xE0, 0xFE, 0x90, 0x05, 0x60, 0xE0, 0x24,
-0x00, 0xFF, 0xEA, 0x3E, 0xFE, 0xED, 0xB4, 0x08,
-0x0A, 0x90, 0x05, 0x58, 0xE0, 0xFC, 0x2F, 0xFF,
-0xEA, 0x3E, 0xFE, 0x90, 0x96, 0x73, 0x74, 0x17,
-0xF0, 0x90, 0x96, 0x95, 0x74, 0x06, 0xF0, 0x90,
-0x96, 0x75, 0xED, 0xF0, 0x90, 0x93, 0x58, 0xE0,
-0xFD, 0xC3, 0x13, 0x54, 0x07, 0x12, 0xA5, 0x8D,
-0xE0, 0x90, 0x96, 0x76, 0xF0, 0xA3, 0xEF, 0xF0,
-0xEE, 0xA3, 0xF0, 0x90, 0x96, 0x96, 0xE0, 0xFE,
-0xA3, 0xE0, 0x90, 0x96, 0x79, 0xF0, 0xEE, 0xA3,
-0xF0, 0x7B, 0x01, 0x7A, 0x96, 0x79, 0x73, 0x12,
-0x8E, 0x48, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93, 0x58, 0xE0,
-0x30, 0xE0, 0x0A, 0x90, 0x93, 0xD8, 0xE0, 0x60,
-0x04, 0x7F, 0x07, 0x11, 0xC6, 0x22, 0xC0, 0xE0,
-0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0,
-0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0,
-0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x5E,
-0xF0, 0x74, 0xB9, 0xA3, 0xF0, 0x12, 0x75, 0x50,
-0xE5, 0x3D, 0x30, 0xE0, 0x02, 0x31, 0x4C, 0xE5,
-0x3D, 0x30, 0xE1, 0x02, 0xD1, 0x77, 0xE5, 0x3D,
-0x30, 0xE2, 0x02, 0x51, 0x93, 0xE5, 0x3D, 0x30,
-0xE4, 0x02, 0x51, 0x79, 0xE5, 0x3D, 0x30, 0xE5,
-0x02, 0xB1, 0xE5, 0xE5, 0x3E, 0x30, 0xE0, 0x02,
-0x51, 0xB0, 0xE5, 0x3E, 0x30, 0xE3, 0x02, 0x51,
-0x36, 0xE5, 0x3E, 0x30, 0xE4, 0x02, 0xD1, 0xAF,
-0xE5, 0x3F, 0x30, 0xE1, 0x02, 0x71, 0xDF, 0xE5,
-0x3F, 0x30, 0xE0, 0x02, 0x71, 0x8B, 0xE5, 0x3F,
-0x30, 0xE4, 0x02, 0xB1, 0xE6, 0xE5, 0x3F, 0x30,
-0xE2, 0x09, 0xD1, 0xC6, 0x90, 0x07, 0x8F, 0xE0,
-0x44, 0x10, 0xF0, 0xE5, 0x40, 0x30, 0xE1, 0x0B,
-0x90, 0x8A, 0xE5, 0x12, 0x8E, 0x5A, 0x7F, 0x04,
-0x12, 0x04, 0x7E, 0xE5, 0x40, 0x30, 0xE4, 0x03,
-0x12, 0xB5, 0x41, 0xE5, 0x40, 0x30, 0xE5, 0x02,
-0x91, 0x4E, 0xE5, 0x40, 0x30, 0xE6, 0x02, 0x91,
-0xAB, 0xE5, 0x40, 0x30, 0xE7, 0x02, 0x71, 0x3A,
-0x74, 0x5E, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74,
-0xB9, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0,
-0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0,
-0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x90, 0x01,
-0x8C, 0xE4, 0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x71,
-0xF0, 0xA3, 0x74, 0x02, 0xF0, 0x90, 0x01, 0x95,
-0xE0, 0x54, 0xF0, 0x44, 0x07, 0xF0, 0x90, 0x01,
-0x01, 0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90, 0x00,
-0xAB, 0xE0, 0xFE, 0x90, 0x00, 0xAA, 0x51, 0x70,
-0x54, 0x7F, 0x90, 0x95, 0xE5, 0xF0, 0xA3, 0xEF,
-0xF0, 0xE0, 0x30, 0xE1, 0x02, 0x51, 0x36, 0x22,
-0xE0, 0x7C, 0x00, 0x24, 0x00, 0xFF, 0xEC, 0x3E,
-0x22, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x12,
-0xD1, 0x05, 0x30, 0xE0, 0x0D, 0x90, 0x8A, 0xBB,
-0x12, 0x8E, 0x5A, 0xE4, 0xFF, 0x12, 0x04, 0x7E,
-0x71, 0x83, 0x22, 0x90, 0x88, 0x36, 0xE0, 0x60,
-0x14, 0x90, 0x06, 0x92, 0xE0, 0x30, 0xE1, 0x08,
-0x90, 0x8B, 0x01, 0x12, 0x88, 0xCD, 0x80, 0x05,
-0xB1, 0xF4, 0x12, 0xAF, 0x06, 0x02, 0xA6, 0x56,
-0x51, 0xF6, 0x90, 0x96, 0x15, 0xEF, 0xF0, 0x90,
-0x8A, 0x89, 0x30, 0xE0, 0x13, 0x12, 0x8E, 0x5A,
-0x7D, 0x01, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90,
-0x88, 0x33, 0xE0, 0x44, 0x04, 0xF0, 0x80, 0x06,
-0x12, 0x8E, 0x5A, 0x12, 0xAC, 0x6E, 0x90, 0x96,
-0x15, 0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01, 0x2F,
-0xE0, 0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80, 0x06,
-0x90, 0x01, 0x2F, 0x74, 0x80, 0xF0, 0xD1, 0x9E,
-0x74, 0x02, 0xF0, 0x02, 0x6E, 0x2F, 0xE4, 0x90,
-0x96, 0x17, 0xF0, 0xA3, 0xF0, 0x7F, 0x83, 0x12,
-0x7B, 0x41, 0x90, 0x96, 0x16, 0xEF, 0xF0, 0x7F,
-0x83, 0x12, 0x7B, 0x41, 0xAE, 0x07, 0x90, 0x96,
-0x16, 0xE0, 0xFF, 0xB5, 0x06, 0x01, 0x22, 0xC3,
-0x90, 0x96, 0x18, 0xE0, 0x94, 0x64, 0x90, 0x96,
-0x17, 0xE0, 0x94, 0x00, 0x40, 0x0D, 0x90, 0x01,
-0xC0, 0xE0, 0x44, 0x40, 0xF0, 0x90, 0x96, 0x16,
-0xE0, 0xFF, 0x22, 0x90, 0x96, 0x17, 0xB1, 0xED,
-0x80, 0xC3, 0x90, 0x88, 0xB8, 0xE0, 0x30, 0xE0,
-0x05, 0x90, 0x8A, 0xEB, 0x80, 0x2C, 0x90, 0x95,
-0x44, 0x12, 0x9E, 0xC7, 0x30, 0xE0, 0x20, 0x90,
-0x88, 0xC2, 0xE0, 0xC4, 0x54, 0x0F, 0x20, 0xE0,
-0x0D, 0x90, 0x8A, 0xBB, 0x12, 0x8E, 0x5A, 0xE4,
-0xFF, 0x12, 0x04, 0x7E, 0x71, 0x83, 0x90, 0x95,
-0x44, 0xE0, 0x54, 0xF7, 0xF0, 0x80, 0x06, 0x90,
-0x8A, 0x99, 0x12, 0x88, 0xCD, 0x90, 0x88, 0xF0,
-0xE0, 0x30, 0xE0, 0x06, 0x90, 0x8A, 0xE7, 0x12,
-0x88, 0xCD, 0x22, 0x90, 0x88, 0xC2, 0xE0, 0x54,
-0xEF, 0xF0, 0x22, 0x90, 0x88, 0x2C, 0xE0, 0xFF,
-0x30, 0xE0, 0x4B, 0x90, 0x88, 0x30, 0xE0, 0x7E,
-0x00, 0xB4, 0x02, 0x02, 0x7E, 0x01, 0x90, 0x88,
-0x2F, 0xE0, 0x7D, 0x00, 0xB4, 0x04, 0x02, 0x7D,
-0x01, 0xED, 0x4E, 0x70, 0x31, 0xEF, 0xC3, 0x13,
-0x30, 0xE0, 0x02, 0x80, 0x7E, 0x12, 0xAB, 0x99,
-0x90, 0x88, 0x30, 0xE0, 0xB4, 0x08, 0x0C, 0x90,
-0x8A, 0xB9, 0x12, 0x8E, 0x5A, 0xE4, 0xFD, 0x7F,
-0x0C, 0x80, 0x10, 0x90, 0x88, 0x30, 0xE0, 0x70,
-0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x8E, 0x5A, 0xE4,
-0xFD, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x22, 0x90,
-0x88, 0x2C, 0xE0, 0xFF, 0x30, 0xE0, 0x4B, 0x90,
-0x88, 0x30, 0xE0, 0x7E, 0x00, 0xB4, 0x02, 0x02,
-0x7E, 0x01, 0x90, 0x88, 0x2F, 0xE0, 0x7D, 0x00,
-0xB4, 0x04, 0x02, 0x7D, 0x01, 0xED, 0x4E, 0x70,
-0x31, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x02, 0x80,
-0x2A, 0x12, 0xB5, 0x7E, 0x90, 0x88, 0x30, 0xE0,
-0xB4, 0x0C, 0x0C, 0x90, 0x8A, 0xB9, 0x12, 0x8E,
-0x5A, 0xE4, 0xFD, 0x7F, 0x08, 0x80, 0x10, 0x90,
-0x88, 0x30, 0xE0, 0xB4, 0x04, 0x0C, 0x90, 0x8A,
-0xB9, 0x12, 0x8E, 0x5A, 0xE4, 0xFD, 0xFF, 0x12,
-0x04, 0x7E, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x12, 0x9F, 0xDA, 0xBF, 0x01, 0x04,
-0x7F, 0x01, 0x80, 0x02, 0x7F, 0x02, 0x12, 0xAA,
-0x78, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x95,
-0x37, 0xE0, 0xB4, 0x01, 0x19, 0xE4, 0xF0, 0x90,
-0x01, 0x5B, 0xF0, 0x90, 0x92, 0x20, 0xF0, 0x90,
-0x88, 0x95, 0xE0, 0xC3, 0x13, 0x54, 0x7F, 0x90,
-0x92, 0x21, 0xF0, 0xE4, 0xB1, 0xFC, 0x90, 0x88,
-0x31, 0x12, 0xAB, 0x91, 0x30, 0xE0, 0x33, 0xEF,
-0x54, 0xBF, 0xB1, 0x0B, 0x30, 0xE0, 0x06, 0xE0,
-0x44, 0x01, 0xF0, 0x80, 0x09, 0xE0, 0x54, 0xFE,
-0xF0, 0xB1, 0x14, 0x74, 0x04, 0xF0, 0x90, 0x88,
-0xA3, 0xE0, 0xFF, 0xC4, 0x13, 0x54, 0x07, 0x30,
-0xE0, 0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x8E, 0x5A,
-0x7D, 0x01, 0x7F, 0x0C, 0x02, 0x04, 0x7E, 0x12,
-0xAF, 0x06, 0x22, 0x90, 0x88, 0x31, 0xE0, 0xFF,
-0x12, 0x8F, 0x8B, 0x30, 0xE0, 0x1F, 0xEF, 0x54,
-0x7F, 0xB1, 0x0B, 0x30, 0xE1, 0x06, 0xE0, 0x44,
-0x02, 0xF0, 0x80, 0x08, 0xE0, 0x54, 0xFD, 0xF0,
-0xB1, 0x14, 0x04, 0xF0, 0x90, 0x88, 0x36, 0xE0,
-0x60, 0x03, 0x12, 0xAF, 0x06, 0x90, 0x88, 0xA1,
-0x12, 0xAB, 0x91, 0x30, 0xE0, 0x22, 0x90, 0x88,
-0xA4, 0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x18,
-0xEF, 0x54, 0xFD, 0xF0, 0x90, 0x04, 0xE0, 0xE0,
-0x90, 0x88, 0xA4, 0x30, 0xE1, 0x06, 0xE0, 0x44,
-0x04, 0xF0, 0x80, 0x04, 0xE0, 0x54, 0xFB, 0xF0,
-0x90, 0x04, 0xE0, 0xE0, 0x30, 0xE1, 0x03, 0x12,
-0xA3, 0xC5, 0x22, 0xF0, 0x90, 0x04, 0xE0, 0xE0,
-0x90, 0x88, 0x32, 0x22, 0x90, 0x01, 0xB9, 0x74,
-0x01, 0xF0, 0x90, 0x01, 0xB8, 0x22, 0xB1, 0xE7,
-0x12, 0x8A, 0x4E, 0x12, 0x02, 0x06, 0xFF, 0x54,
-0x7F, 0x90, 0x88, 0x36, 0xF0, 0xEF, 0x12, 0x8F,
-0x8B, 0xA3, 0xF0, 0x12, 0x8F, 0x98, 0xFD, 0x54,
-0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x88, 0x34,
-0xE0, 0x54, 0xF0, 0x4F, 0x12, 0x87, 0x9E, 0xFC,
-0x54, 0x01, 0x25, 0xE0, 0xFF, 0x90, 0x88, 0x31,
-0xE0, 0x54, 0xFD, 0x4F, 0xF0, 0xEC, 0x54, 0x04,
-0xC3, 0x13, 0xFF, 0x90, 0x88, 0x33, 0xE0, 0x54,
-0xFD, 0x4F, 0xF0, 0xED, 0x54, 0x0F, 0xC4, 0x54,
-0xF0, 0xFF, 0xA3, 0xE0, 0x54, 0x0F, 0x4F, 0xF0,
-0x12, 0x87, 0xF1, 0x90, 0x88, 0x35, 0x12, 0x87,
-0x6D, 0xFD, 0x90, 0x8A, 0x89, 0x12, 0x8E, 0x5A,
-0x7F, 0x02, 0x12, 0x04, 0x7E, 0x12, 0x8A, 0x4E,
-0x12, 0x87, 0x67, 0xFF, 0x54, 0x01, 0xFE, 0x90,
-0x88, 0x9B, 0xD1, 0x90, 0x4F, 0x12, 0x87, 0x65,
-0xFE, 0x54, 0x04, 0xFD, 0xEF, 0x54, 0xFB, 0x4D,
-0xFF, 0x90, 0x88, 0x9B, 0xF0, 0xEE, 0x54, 0x08,
-0xFE, 0xEF, 0x54, 0xF7, 0x12, 0x87, 0x64, 0xD1,
-0x6D, 0x90, 0x88, 0x9B, 0xD1, 0x5A, 0x12, 0x87,
-0x64, 0x54, 0x40, 0xFE, 0xEF, 0x54, 0xBF, 0x4E,
-0x90, 0x88, 0x9B, 0xF0, 0x12, 0x5C, 0x5F, 0x90,
-0x88, 0x36, 0xE0, 0xB4, 0x01, 0x07, 0x90, 0x88,
-0x33, 0xE0, 0x54, 0xFB, 0xF0, 0xB1, 0x14, 0xF0,
-0x90, 0x88, 0x36, 0xD1, 0x83, 0x12, 0xAF, 0xC0,
-0x90, 0x01, 0xBE, 0xF0, 0x22, 0x22, 0x22, 0x90,
-0x95, 0x4E, 0x02, 0x86, 0x42, 0xE4, 0x75, 0xF0,
-0x01, 0x02, 0x02, 0xE7, 0x90, 0x88, 0x31, 0xE0,
-0x54, 0xF7, 0xF0, 0x22, 0xFB, 0xFD, 0x7F, 0x58,
-0x7E, 0x01, 0x02, 0x66, 0x33, 0x90, 0x88, 0xA1,
-0xE0, 0x13, 0x13, 0x54, 0x3F, 0x22, 0xEF, 0x64,
-0x39, 0x70, 0x46, 0x90, 0x88, 0x9D, 0xE0, 0x30,
-0xE0, 0x3F, 0xD1, 0x05, 0x30, 0xE0, 0x3A, 0x90,
-0x88, 0xC2, 0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x30,
-0xE0, 0x2F, 0x90, 0x95, 0x4A, 0xE0, 0x04, 0xF0,
-0xD1, 0x63, 0x30, 0xE0, 0x1C, 0xEE, 0x13, 0x13,
-0x13, 0x54, 0x1F, 0x30, 0xE0, 0x13, 0x90, 0x01,
-0x63, 0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x10,
-0xF0, 0xEF, 0x54, 0xEF, 0x90, 0x88, 0xC2, 0xF0,
-0x22, 0x90, 0x88, 0xB0, 0xE0, 0x70, 0x02, 0x71,
-0x83, 0x22, 0xF0, 0xEE, 0x54, 0x20, 0xFE, 0xEF,
-0x54, 0xDF, 0x22, 0x90, 0x95, 0x44, 0xE0, 0xFE,
-0x13, 0x13, 0x54, 0x3F, 0x22, 0xFE, 0x54, 0x10,
-0xFD, 0xEF, 0x54, 0xEF, 0x4D, 0xFF, 0x22, 0x90,
-0x88, 0x36, 0xE0, 0x60, 0x03, 0x12, 0xAF, 0x3A,
-0x02, 0xA1, 0x0B, 0xE0, 0x90, 0x01, 0xBA, 0xF0,
-0x90, 0x88, 0x38, 0xE0, 0x90, 0x01, 0xBB, 0x22,
+0xA3, 0x12, 0x8F, 0xEC, 0x78, 0x18, 0x12, 0x03,
+0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x86, 0x20, 0x90, 0x95, 0xF1, 0x12,
+0x04, 0x31, 0x90, 0x95, 0xED, 0x12, 0x86, 0x2D,
+0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
+0x90, 0x93, 0xD5, 0xE0, 0xC3, 0x13, 0x54, 0x7F,
+0xFF, 0xE4, 0xFC, 0xFD, 0xFE, 0xFB, 0x7A, 0x04,
+0xF9, 0xF8, 0x12, 0x85, 0xC4, 0xD0, 0x03, 0xD0,
+0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x85, 0xA9,
+0x90, 0x95, 0xED, 0x12, 0x04, 0x31, 0x90, 0x95,
+0xF5, 0x12, 0x04, 0xB8, 0x90, 0x95, 0xED, 0x12,
+0xEE, 0x2C, 0x50, 0x0E, 0xB1, 0x12, 0xEF, 0x24,
+0x01, 0x12, 0xED, 0xD9, 0x90, 0x95, 0xF1, 0x12,
+0x04, 0x31, 0xB1, 0x12, 0x78, 0x18, 0x12, 0x03,
+0xEB, 0x90, 0x05, 0x67, 0xB1, 0x10, 0x78, 0x10,
+0x12, 0x03, 0xEB, 0x90, 0x05, 0x66, 0xB1, 0x10,
+0x78, 0x08, 0x12, 0x03, 0xEB, 0x90, 0x05, 0x65,
+0xB1, 0x10, 0x90, 0x05, 0x64, 0xB1, 0x08, 0x78,
+0x18, 0x12, 0x03, 0xEB, 0x90, 0x05, 0x63, 0xB1,
+0x08, 0x78, 0x10, 0x12, 0x03, 0xEB, 0x90, 0x05,
+0x62, 0xB1, 0x08, 0x78, 0x08, 0x12, 0x03, 0xEB,
+0x90, 0x05, 0x61, 0xB1, 0x08, 0x90, 0x05, 0x60,
+0xEF, 0xF0, 0x90, 0x05, 0x50, 0xE0, 0x44, 0x08,
+0xF0, 0x90, 0x05, 0x22, 0xE0, 0x54, 0xBF, 0xFD,
+0x7B, 0x59, 0x7F, 0x40, 0x12, 0x8F, 0x64, 0x7F,
+0x08, 0xF1, 0xF0, 0x90, 0x93, 0xD9, 0xE0, 0x54,
+0xC1, 0x44, 0x28, 0xF0, 0x44, 0x01, 0xF0, 0x22,
+0xEF, 0xF0, 0x90, 0x95, 0xED, 0x02, 0x04, 0xB8,
+0xEF, 0xF0, 0x90, 0x95, 0xF1, 0x02, 0x04, 0xB8,
+0x90, 0x92, 0x21, 0xF0, 0xE4, 0x90, 0x92, 0x20,
+0xF0, 0x22, 0xE4, 0x90, 0x92, 0x20, 0xF0, 0x90,
+0x95, 0xF9, 0xE0, 0xFF, 0x90, 0x93, 0xD6, 0xE0,
+0x2F, 0x22, 0xF0, 0xA3, 0xE0, 0xFF, 0xE4, 0xFC,
+0xFD, 0xFE, 0x78, 0x08, 0x12, 0x03, 0xFE, 0xA8,
+0x04, 0xA9, 0x05, 0xAA, 0x06, 0xAB, 0x07, 0x22,
+0xE0, 0x44, 0x02, 0xF0, 0xE4, 0x90, 0x92, 0x20,
+0xF0, 0x90, 0x88, 0x94, 0xE0, 0x90, 0x92, 0x21,
+0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54, 0x7E, 0x01,
+0x02, 0x66, 0x33, 0xE4, 0xF5, 0x7C, 0x90, 0x88,
+0x36, 0xE0, 0x60, 0x64, 0xD1, 0xA3, 0x70, 0x60,
+0xF1, 0xC1, 0x75, 0x7C, 0x01, 0x90, 0x88, 0x2C,
+0xE0, 0x30, 0xE0, 0x11, 0x90, 0x88, 0x30, 0xE0,
+0xB4, 0x02, 0x03, 0xE4, 0xF5, 0x7C, 0xD1, 0x67,
+0xEF, 0x70, 0x02, 0xF5, 0x7C, 0xE5, 0x7C, 0x60,
+0x3F, 0x90, 0x88, 0x39, 0xE0, 0x20, 0xE2, 0x08,
+0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B, 0xD1, 0x94,
+0xD1, 0x9B, 0x90, 0x88, 0x3F, 0xE0, 0x60, 0x04,
+0x64, 0x01, 0x70, 0x0F, 0xB1, 0xD1, 0xFF, 0xA3,
+0xE0, 0x2F, 0xB1, 0x55, 0xB1, 0xD6, 0xFF, 0xA3,
+0xE0, 0x80, 0x0B, 0xB1, 0xD1, 0xB1, 0xE0, 0x2F,
+0xB1, 0x55, 0xB1, 0xD6, 0xB1, 0xE0, 0x2F, 0x33,
+0x33, 0x33, 0x54, 0xF8, 0x90, 0x88, 0x4F, 0xF0,
+0x22, 0xE4, 0x90, 0x92, 0x20, 0xF0, 0x90, 0x88,
+0x3E, 0xE0, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x22,
+0xFF, 0xA3, 0xE0, 0x75, 0xF0, 0x03, 0xA4, 0x24,
+0xFE, 0x22, 0x90, 0x88, 0x2C, 0xE0, 0x30, 0xE0,
+0x10, 0xA3, 0x74, 0x01, 0xF0, 0x90, 0x88, 0x2C,
+0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x02, 0xD1,
+0x73, 0xB1, 0x63, 0xE4, 0xFF, 0xF1, 0x02, 0x90,
+0x8B, 0x07, 0x12, 0x8A, 0x66, 0x41, 0xD9, 0xE4,
+0x90, 0x96, 0x1B, 0xF0, 0x90, 0x88, 0x36, 0xE0,
+0x60, 0x4C, 0xD1, 0xA3, 0x70, 0x48, 0x12, 0xEE,
+0x33, 0xF0, 0xF1, 0xC1, 0x90, 0x96, 0x1B, 0x74,
+0x01, 0xF0, 0xE4, 0x90, 0x88, 0x3D, 0xF0, 0x90,
+0x88, 0x2C, 0xE0, 0x30, 0xE0, 0x15, 0x90, 0x88,
+0x30, 0xE0, 0xB4, 0x02, 0x05, 0xE4, 0x90, 0x96,
+0x1B, 0xF0, 0xD1, 0x67, 0xEF, 0x70, 0x04, 0x90,
+0x96, 0x1B, 0xF0, 0x90, 0x96, 0x1B, 0xE0, 0x60,
+0x15, 0x90, 0x88, 0x39, 0xE0, 0x20, 0xE2, 0x08,
+0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B, 0xD1, 0x94,
+0xD1, 0x9B, 0xB1, 0xD1, 0xB1, 0x55, 0x22, 0x90,
+0x05, 0x43, 0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02,
+0x7F, 0x01, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0xD1, 0x67, 0xBF, 0x01, 0x04, 0x7F,
+0x01, 0x80, 0x02, 0x7F, 0x02, 0x12, 0xE8, 0x85,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93, 0x5A,
+0x74, 0x05, 0xF0, 0x22, 0x7D, 0x01, 0x7F, 0x04,
+0x02, 0x04, 0x7E, 0x90, 0x88, 0x3A, 0xE0, 0x44,
+0x10, 0xF0, 0x22, 0xE4, 0xFF, 0x12, 0x78, 0x4A,
+0xEF, 0x64, 0x01, 0x22, 0xD1, 0xA3, 0x70, 0x12,
+0x90, 0x88, 0x36, 0xE0, 0x60, 0x0C, 0x90, 0x88,
+0x3A, 0xE0, 0x20, 0xE4, 0x05, 0x12, 0xB5, 0xBE,
+0xB1, 0x4B, 0x22, 0xFB, 0xFD, 0x7F, 0x58, 0x7E,
+0x01, 0x02, 0x66, 0x33, 0x90, 0x93, 0xD7, 0xE0,
+0xFF, 0x90, 0x93, 0xDA, 0xE0, 0xD3, 0x9F, 0x22,
+0xD1, 0x0F, 0xF1, 0x94, 0x7F, 0x01, 0xF1, 0x02,
+0x90, 0x8B, 0x07, 0x12, 0x8A, 0x66, 0x90, 0x93,
+0x3B, 0xE0, 0x30, 0xE0, 0x14, 0xF1, 0x9B, 0x90,
+0x93, 0x3E, 0xE0, 0x60, 0x05, 0x14, 0xF0, 0x02,
+0x79, 0xD4, 0x12, 0xEE, 0x0D, 0xE4, 0xFF, 0xF1,
+0x3F, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x88, 0x33, 0xE0, 0xC3, 0x13, 0x30,
+0xE0, 0x28, 0x90, 0x96, 0xC5, 0x74, 0x1E, 0xF0,
+0x90, 0x96, 0xE7, 0x74, 0x01, 0xF0, 0x90, 0x96,
+0xC7, 0xEF, 0xF0, 0x7B, 0x01, 0x7A, 0x96, 0x79,
+0xC5, 0x12, 0xAC, 0x11, 0x12, 0x04, 0x7E, 0x90,
+0x8A, 0xE5, 0x12, 0x90, 0x4B, 0x7F, 0x04, 0x12,
+0x04, 0x7E, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xEF, 0x64,
+0x01, 0x70, 0x1A, 0xF1, 0x8C, 0x60, 0x09, 0xF1,
+0x85, 0x12, 0x7C, 0x05, 0xF1, 0x9B, 0x80, 0x08,
+0xF1, 0x85, 0x12, 0x7C, 0x3B, 0x12, 0xCC, 0xFE,
+0x12, 0x79, 0xD4, 0x80, 0x17, 0xF1, 0x8C, 0x60,
+0x07, 0xF1, 0x85, 0x12, 0x7C, 0x05, 0x80, 0x05,
+0xF1, 0x85, 0x12, 0x7C, 0x3B, 0xF1, 0x94, 0xF1,
+0xE9, 0x12, 0x7B, 0xCC, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xF0, 0x90, 0x01, 0x3F, 0x74, 0x10, 0xF0,
+0xFD, 0x7F, 0x03, 0x22, 0x90, 0x93, 0x3D, 0xE0,
+0x90, 0x01, 0x3F, 0x22, 0x7D, 0x02, 0x7F, 0x02,
+0x02, 0x7C, 0x74, 0x90, 0x93, 0x3D, 0xE0, 0x90,
+0x05, 0x73, 0xF0, 0x22, 0xAE, 0x07, 0xD1, 0x67,
+0xBF, 0x01, 0x13, 0x12, 0xC3, 0x4A, 0x20, 0xE0,
+0x0D, 0xAF, 0x06, 0x12, 0x97, 0x41, 0x7D, 0x01,
+0x12, 0x04, 0x7E, 0x7F, 0x01, 0x22, 0x7F, 0x00,
+0x22, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x88, 0x89,
+0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x88, 0x8A,
+0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x88, 0x8B,
+0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x88, 0x8C,
+0xF0, 0x90, 0x88, 0x32, 0xE0, 0x44, 0x80, 0xF0,
+0x22, 0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0x74,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xAD,
+0x07, 0x90, 0x05, 0x63, 0xE0, 0xFE, 0x90, 0x05,
+0x62, 0xE0, 0x7A, 0x00, 0x24, 0x00, 0xFF, 0xEA,
+0x3E, 0x90, 0x96, 0xC3, 0xF0, 0xA3, 0xEF, 0xF0,
+0x90, 0x05, 0x61, 0xE0, 0xFE, 0x90, 0x05, 0x60,
+0xE0, 0x24, 0x00, 0xFF, 0xEA, 0x3E, 0xFE, 0xED,
+0xB4, 0x08, 0x0A, 0x90, 0x05, 0x58, 0xE0, 0xFC,
+0x2F, 0xFF, 0xEA, 0x3E, 0xFE, 0x90, 0x96, 0xA0,
+0x74, 0x17, 0xF0, 0x90, 0x96, 0xC2, 0x74, 0x06,
+0xF0, 0x90, 0x96, 0xA2, 0xED, 0xF0, 0x90, 0x93,
+0x58, 0xE0, 0xFD, 0xC3, 0x13, 0x54, 0x07, 0x12,
+0x8E, 0xFC, 0xF5, 0x83, 0xE0, 0x90, 0x96, 0xA3,
+0xF0, 0xA3, 0xEF, 0xF0, 0xEE, 0xA3, 0xF0, 0x90,
+0x96, 0xC3, 0xE0, 0xFE, 0xA3, 0xE0, 0x90, 0x96,
+0xA6, 0xF0, 0xEE, 0xA3, 0xF0, 0x7B, 0x01, 0x7A,
+0x96, 0x79, 0xA0, 0x12, 0x90, 0x39, 0x7F, 0x04,
+0x12, 0x04, 0x7E, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0x51, 0x1F, 0x12, 0x02, 0x06, 0xFF, 0x54, 0x0F,
+0xF5, 0x64, 0xEF, 0xC4, 0x54, 0x0F, 0x64, 0x0F,
+0x70, 0x41, 0x90, 0x93, 0x58, 0xE0, 0x54, 0xFE,
+0xFF, 0xF0, 0xE5, 0x64, 0x54, 0x07, 0x25, 0xE0,
+0xFE, 0xEF, 0x54, 0xF1, 0x4E, 0x12, 0x87, 0xF3,
+0xC4, 0x13, 0x54, 0x07, 0x90, 0x93, 0xDF, 0x20,
+0xE0, 0x05, 0x74, 0x06, 0xF0, 0x80, 0x03, 0x74,
+0x01, 0xF0, 0x7D, 0x20, 0xE4, 0xFF, 0x12, 0x7C,
+0x3B, 0xAF, 0x64, 0x12, 0x8F, 0x08, 0xBF, 0x01,
+0x06, 0xE4, 0xFD, 0xFF, 0x12, 0x99, 0xAD, 0x7F,
+0x02, 0x21, 0x70, 0xE5, 0x64, 0x75, 0xF0, 0x1B,
+0xA4, 0x24, 0x5B, 0xF9, 0x74, 0x93, 0x35, 0xF0,
+0xFA, 0x7B, 0x01, 0xC0, 0x02, 0xC0, 0x01, 0xE5,
+0x63, 0x24, 0x01, 0xF9, 0xE4, 0x35, 0x62, 0x85,
+0x61, 0x45, 0xF1, 0x5E, 0xD0, 0x01, 0xD0, 0x02,
+0x12, 0x69, 0xF5, 0xE5, 0x64, 0x12, 0x9A, 0xCA,
+0x54, 0xF7, 0x31, 0x74, 0xC4, 0x54, 0x0F, 0x14,
+0x65, 0x64, 0x70, 0x6F, 0x90, 0x88, 0x36, 0xE0,
+0x70, 0x07, 0x90, 0x88, 0x2C, 0xE0, 0x30, 0xE0,
+0x04, 0x7F, 0x05, 0x80, 0x5B, 0x31, 0x75, 0xC4,
+0x54, 0x0F, 0x90, 0x93, 0x59, 0x51, 0x26, 0xFC,
+0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFE, 0x90, 0x93,
+0x58, 0xE0, 0x54, 0x0F, 0x4E, 0xF0, 0xEC, 0x54,
+0x60, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x93, 0xAD,
+0xE0, 0x54, 0xF9, 0x4F, 0xF0, 0x90, 0x93, 0x58,
+0xE0, 0x54, 0xF1, 0xF0, 0xF1, 0x57, 0x90, 0x93,
+0xD5, 0xE0, 0x90, 0x93, 0xD9, 0x30, 0xE0, 0x0B,
+0xE0, 0x54, 0xFE, 0xF0, 0x54, 0xC1, 0x44, 0x02,
+0xF0, 0x80, 0x07, 0xE0, 0x44, 0x01, 0xF0, 0x54,
+0xC1, 0xF0, 0x90, 0x93, 0x58, 0xE0, 0x44, 0x01,
+0xF0, 0xE4, 0x90, 0x93, 0x5A, 0xF0, 0x7F, 0x03,
+0x12, 0x9F, 0xF0, 0x22, 0xF0, 0xAB, 0x61, 0xAA,
+0x62, 0xA9, 0x63, 0x02, 0x02, 0x06, 0x51, 0x1F,
+0x90, 0x93, 0xE0, 0xE0, 0x54, 0xFE, 0xF0, 0x12,
+0x87, 0x63, 0xFC, 0x30, 0xE0, 0x43, 0x90, 0x93,
+0xE1, 0xE0, 0x44, 0x01, 0xFE, 0xF0, 0x12, 0x02,
+0x06, 0x54, 0xFE, 0xFD, 0xEE, 0x54, 0x01, 0x4D,
+0x90, 0x93, 0xE1, 0x12, 0x87, 0x69, 0x90, 0x93,
+0xE2, 0xF0, 0xEC, 0xC3, 0x13, 0x54, 0x7F, 0xFF,
+0xA3, 0x12, 0x87, 0x96, 0xFE, 0xC3, 0x9F, 0x90,
+0x93, 0xE4, 0xF0, 0xA3, 0xEE, 0xF0, 0xBE, 0x64,
+0x04, 0x74, 0x01, 0xF0, 0x22, 0x90, 0x93, 0xE5,
+0xE0, 0x64, 0x96, 0x70, 0x51, 0x74, 0x03, 0xF0,
+0x22, 0x90, 0x93, 0xE1, 0xE0, 0x54, 0xFE, 0x31,
+0x74, 0xFF, 0x54, 0x01, 0xFE, 0x90, 0x93, 0xD5,
 0xE0, 0x54, 0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x54,
-0x02, 0xFF, 0xEE, 0x54, 0xFD, 0x22, 0x90, 0x88,
-0x48, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x88,
-0x4F, 0xE0, 0xFB, 0x90, 0x92, 0x98, 0x22, 0x90,
-0x93, 0x03, 0xE0, 0x30, 0xE0, 0x0F, 0x13, 0x13,
-0x13, 0x54, 0x1F, 0x30, 0xE0, 0x07, 0x90, 0x04,
-0x1F, 0xE0, 0x44, 0x40, 0xF0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88, 0xF0,
-0xE0, 0x30, 0xE0, 0x2F, 0x90, 0x88, 0xF7, 0xE0,
-0xB4, 0x01, 0x18, 0xA3, 0xE0, 0xB4, 0x01, 0x23,
-0x74, 0x02, 0xF0, 0x90, 0x88, 0xFE, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x90, 0x8A, 0x7F, 0x12, 0xAD,
-0xA8, 0x80, 0x10, 0x90, 0x88, 0xF7, 0xE0, 0xB4,
-0x02, 0x09, 0x74, 0x03, 0xF0, 0x90, 0x8A, 0xE7,
-0x12, 0x88, 0xCD, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82,
-0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0,
-0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4,
-0x74, 0x08, 0xF0, 0x74, 0xBF, 0xA3, 0xF0, 0x12,
-0x6C, 0xD6, 0xE5, 0x25, 0x30, 0xE7, 0x02, 0x51,
-0x56, 0x74, 0x08, 0x04, 0x90, 0x01, 0xC4, 0xF0,
-0x74, 0xBF, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
-0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
-0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x90,
-0x00, 0x80, 0xE0, 0x44, 0x80, 0xF0, 0x12, 0xDB,
-0xC4, 0x12, 0xE1, 0xF1, 0x12, 0x7B, 0x79, 0x51,
-0x36, 0x12, 0xCF, 0x09, 0x7F, 0x01, 0x12, 0x84,
-0x15, 0x90, 0x93, 0x57, 0x74, 0x02, 0xF0, 0xFF,
-0x12, 0x84, 0x15, 0x90, 0x93, 0x57, 0xE0, 0x04,
-0xF0, 0x12, 0xD9, 0x1B, 0x12, 0xCF, 0x4E, 0x90,
-0x00, 0x80, 0xE0, 0x44, 0x40, 0xF0, 0x75, 0x20,
-0xFF, 0x12, 0x7C, 0x97, 0x90, 0x01, 0xA0, 0xE0,
-0xB4, 0xFD, 0x05, 0xE4, 0xFF, 0x12, 0xC9, 0xAB,
-0x12, 0xC5, 0xDA, 0x90, 0x00, 0x81, 0xE0, 0x44,
-0x04, 0xF0, 0x12, 0xD9, 0x9E, 0x12, 0xCE, 0x58,
-0x90, 0x00, 0xAA, 0xE0, 0x44, 0x02, 0xF0, 0xA3,
-0xE0, 0x44, 0x80, 0xF0, 0x90, 0x06, 0x0A, 0xE0,
-0x44, 0x10, 0xF0, 0x90, 0x07, 0xDB, 0xE0, 0x44,
-0x80, 0xF0, 0x90, 0x06, 0x0D, 0x74, 0xFF, 0xF0,
-0xE4, 0xFF, 0x02, 0x84, 0x9E, 0x12, 0x02, 0x06,
-0xFF, 0x90, 0x93, 0x3A, 0xF0, 0xBF, 0x01, 0x07,
-0xF1, 0xF0, 0xE4, 0x90, 0x93, 0x3A, 0xF0, 0x22,
-0x7B, 0x01, 0x7A, 0x95, 0x79, 0x4E, 0x7F, 0xEF,
+0xFE, 0xFF, 0xEE, 0x54, 0x01, 0x4F, 0x12, 0x87,
+0x69, 0x90, 0x93, 0xD6, 0x12, 0x87, 0x96, 0x90,
+0x93, 0xD7, 0xF0, 0xE4, 0xA3, 0xF0, 0x90, 0x93,
+0xD7, 0xE0, 0xFF, 0xB4, 0x64, 0x05, 0x74, 0x01,
+0xF0, 0x80, 0x0A, 0xEF, 0xB4, 0x96, 0x06, 0x90,
+0x93, 0xD7, 0x74, 0x03, 0xF0, 0x90, 0x93, 0xD7,
+0xE0, 0x04, 0x90, 0x93, 0xDA, 0xF0, 0x22, 0x8B,
+0x61, 0x8A, 0x62, 0x89, 0x63, 0x22, 0xF0, 0x90,
+0x00, 0x06, 0x02, 0x02, 0x1F, 0xEF, 0x70, 0x05,
+0x90, 0x93, 0x05, 0x80, 0x03, 0x90, 0x93, 0x04,
+0xE0, 0xFF, 0x12, 0x7B, 0x07, 0x90, 0x95, 0xED,
+0xEF, 0xF0, 0x90, 0x95, 0xED, 0xE0, 0x24, 0x38,
+0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0xA3,
+0x12, 0x86, 0x42, 0xE4, 0xFF, 0x74, 0x08, 0x2F,
+0xF5, 0x82, 0xE4, 0x34, 0x07, 0xF5, 0x83, 0xE0,
+0xFE, 0x90, 0x95, 0xEE, 0x12, 0x86, 0x39, 0x8F,
+0x82, 0x75, 0x83, 0x00, 0x51, 0xF1, 0xB4, 0x06,
+0xE4, 0x90, 0x95, 0xED, 0xE0, 0x24, 0x52, 0xF9,
+0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0xA3, 0xF1,
+0x51, 0x70, 0x5F, 0x90, 0x95, 0xEE, 0x12, 0x86,
+0x39, 0x12, 0x87, 0x6A, 0x64, 0x02, 0x70, 0x52,
+0x90, 0x24, 0x87, 0xE0, 0x90, 0x00, 0x03, 0x12,
+0x02, 0x5E, 0x90, 0x24, 0x86, 0xE0, 0x90, 0x00,
+0x04, 0x12, 0x02, 0x5E, 0x90, 0x95, 0xEE, 0x12,
+0x86, 0x39, 0x12, 0x87, 0x63, 0x64, 0x01, 0x70,
+0x31, 0x51, 0x27, 0x64, 0x0D, 0x70, 0x2B, 0xFF,
+0x74, 0x88, 0x51, 0xFA, 0xEF, 0x24, 0x08, 0x51,
+0xE3, 0xB4, 0x08, 0xF4, 0x90, 0x05, 0xDC, 0xE0,
+0xFF, 0x90, 0x95, 0xEE, 0x12, 0x86, 0x39, 0x90,
+0x00, 0x10, 0xEF, 0x12, 0x02, 0x5E, 0xE4, 0xFF,
+0x51, 0xF8, 0xEF, 0x24, 0x11, 0x51, 0xE3, 0xB4,
+0x04, 0xF6, 0x22, 0xFD, 0xE4, 0x33, 0xFC, 0x90,
+0x95, 0xEE, 0x12, 0x86, 0x39, 0x8D, 0x82, 0x8C,
+0x83, 0xEE, 0x12, 0x02, 0x5E, 0x0F, 0xEF, 0x22,
+0x74, 0x90, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x24,
+0xF5, 0x83, 0xE0, 0xFE, 0x22, 0x90, 0x93, 0x03,
+0xE0, 0x30, 0xE0, 0x1E, 0xE4, 0xFF, 0xF1, 0x85,
+0xE4, 0xFF, 0x51, 0x2D, 0x7F, 0x01, 0x51, 0x2D,
+0x90, 0x93, 0x03, 0xE0, 0x13, 0x13, 0x54, 0x3F,
+0x30, 0xE0, 0x07, 0x90, 0x04, 0x1F, 0xE0, 0x44,
+0x80, 0xF0, 0x22, 0xE4, 0xFF, 0x74, 0x94, 0x51,
+0xFA, 0x74, 0x13, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0x71, 0x52, 0xB4, 0x08, 0xEF, 0xE4, 0xFF,
+0x74, 0x9C, 0x51, 0xFA, 0x74, 0x1C, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0x93, 0x71, 0x52, 0xB4, 0x04,
+0xEF, 0x22, 0xF5, 0x83, 0xEE, 0xF0, 0x0F, 0xEF,
+0x22, 0xE4, 0xFF, 0x74, 0x88, 0x51, 0xFA, 0x74,
+0x06, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0x71,
+0x52, 0xB4, 0x08, 0xEF, 0x90, 0x05, 0xDC, 0xE0,
+0x90, 0x93, 0x0E, 0xF0, 0xE4, 0xFF, 0x51, 0xF8,
+0x74, 0x0F, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93,
+0x71, 0x52, 0xB4, 0x04, 0xF1, 0x22, 0xE4, 0x90,
+0x95, 0xEE, 0xF0, 0xF1, 0x71, 0xF1, 0x3A, 0x71,
+0x59, 0x71, 0x2B, 0x90, 0x07, 0xE3, 0xE0, 0x90,
+0x95, 0xED, 0xF0, 0xE0, 0x60, 0x59, 0xE4, 0x90,
+0x95, 0xEF, 0xF0, 0x90, 0x96, 0x11, 0x74, 0x08,
+0xF0, 0x90, 0x05, 0x68, 0xE0, 0x90, 0x95, 0xF1,
+0xF0, 0x90, 0x05, 0x69, 0xE0, 0x90, 0x95, 0xF2,
+0xF0, 0x90, 0x05, 0x6A, 0xE0, 0x90, 0x95, 0xF3,
+0xF0, 0x90, 0x05, 0x6B, 0xE0, 0x90, 0x95, 0xF4,
+0xF0, 0x90, 0x05, 0x78, 0xE0, 0x90, 0x95, 0xF5,
+0xF0, 0x90, 0x05, 0x79, 0xE0, 0x90, 0x95, 0xF6,
+0xF0, 0x90, 0x05, 0x7A, 0xE0, 0x90, 0x95, 0xF7,
+0xF0, 0x90, 0x05, 0x7B, 0xE0, 0x90, 0x95, 0xF8,
+0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0xEF, 0x12,
+0x90, 0x39, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x90,
+0x95, 0xED, 0xE0, 0xFD, 0x60, 0x3F, 0xA3, 0xE0,
+0xF1, 0x68, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0xFF, 0xEF, 0x5D, 0x60, 0xE7,
+0x90, 0x95, 0xEE, 0xE0, 0xFB, 0x74, 0x01, 0xA8,
+0x03, 0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
+0xFE, 0xF4, 0xFD, 0x90, 0x95, 0xED, 0xE0, 0x5D,
+0xF0, 0x90, 0x07, 0xE3, 0xE0, 0x4E, 0xF0, 0xAF,
+0x03, 0xB1, 0xBF, 0x91, 0x3E, 0x90, 0x95, 0xEE,
+0xE0, 0x04, 0xF0, 0x80, 0xBA, 0x22, 0xE4, 0x90,
+0x96, 0x12, 0xF0, 0x90, 0x93, 0x03, 0xE0, 0xFF,
+0xC3, 0x13, 0x20, 0xE0, 0x70, 0x91, 0xF7, 0xB1,
+0x08, 0xEF, 0x60, 0x0D, 0x7B, 0x01, 0x7A, 0x93,
+0x79, 0x13, 0x91, 0xFD, 0xB1, 0x46, 0xEF, 0x60,
+0x54, 0x91, 0xF7, 0xB1, 0x08, 0xEF, 0x60, 0x17,
+0x7B, 0x01, 0x7A, 0x93, 0x79, 0x13, 0x91, 0xFD,
+0xB1, 0x46, 0xEF, 0x60, 0x0A, 0x7B, 0x01, 0x7A,
+0x93, 0x79, 0x1C, 0xD1, 0xCD, 0x70, 0x36, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0x20, 0x90, 0x96, 0x16,
+0x12, 0x86, 0x42, 0x7A, 0x93, 0x79, 0x06, 0xB1,
+0x08, 0xEF, 0x60, 0x10, 0xB1, 0x59, 0x91, 0xFD,
+0xB1, 0x08, 0xEF, 0x60, 0x07, 0x91, 0xF7, 0xD1,
+0xFA, 0xEF, 0x70, 0x11, 0x91, 0xF7, 0xB1, 0x46,
+0xEF, 0x60, 0x29, 0x7B, 0x01, 0x7A, 0x93, 0x79,
+0x0F, 0xD1, 0xCD, 0x60, 0x1F, 0x90, 0x96, 0x12,
+0x74, 0x01, 0xF0, 0x80, 0x17, 0xB1, 0x59, 0x91,
+0xFD, 0xB1, 0x08, 0xEF, 0x60, 0x0E, 0xB1, 0x59,
+0x91, 0xFD, 0xD1, 0xFA, 0xEF, 0x70, 0x05, 0x90,
+0x96, 0x12, 0x04, 0xF0, 0x90, 0x96, 0x12, 0xE0,
+0xFF, 0x90, 0x05, 0x18, 0xE4, 0xF0, 0xA3, 0xF0,
+0xEF, 0x90, 0x05, 0xB3, 0x60, 0x0C, 0xE0, 0x44,
+0x80, 0xF0, 0x90, 0x24, 0xA0, 0xE0, 0x44, 0x01,
+0xF0, 0x22, 0xE0, 0x44, 0x20, 0xF0, 0x22, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0x06, 0x90, 0x96, 0x16,
+0x12, 0x86, 0x42, 0x7A, 0x93, 0x79, 0x20, 0x22,
+0xD1, 0xF2, 0x90, 0x96, 0x19, 0xF0, 0x90, 0x96,
+0x19, 0xE0, 0xFF, 0xC3, 0x94, 0x08, 0x50, 0x2B,
+0xD1, 0xDB, 0xFD, 0xC3, 0x74, 0x07, 0xB1, 0xAD,
+0xC3, 0x9D, 0x50, 0x03, 0x7F, 0x00, 0x22, 0x90,
+0x96, 0x19, 0xE0, 0xFF, 0xD1, 0xDB, 0xFD, 0xC3,
+0x74, 0x07, 0xB1, 0xAD, 0xD3, 0x9D, 0x40, 0x03,
+0x7F, 0x01, 0x22, 0x90, 0x96, 0x19, 0xE0, 0x04,
+0xF0, 0x80, 0xCB, 0x7F, 0x00, 0x22, 0xD1, 0xF2,
+0xFF, 0xF1, 0x0D, 0x6E, 0x60, 0x03, 0x7F, 0x00,
+0x22, 0x0F, 0xEF, 0xB4, 0x08, 0xF3, 0x7F, 0x01,
+0x22, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x2D, 0x22,
+0xD1, 0xF2, 0x90, 0x96, 0x19, 0xF0, 0x90, 0x96,
+0x19, 0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50, 0x1F,
+0xB1, 0x92, 0xC3, 0x9D, 0x50, 0x03, 0x7F, 0x00,
+0x22, 0x90, 0x96, 0x19, 0xE0, 0xFF, 0xB1, 0x92,
+0xD3, 0x9D, 0x40, 0x03, 0x7F, 0x01, 0x22, 0x90,
+0x96, 0x19, 0xE0, 0x04, 0xF0, 0x80, 0xD7, 0x7F,
+0x00, 0x22, 0x7E, 0x00, 0xC3, 0x74, 0x03, 0x9F,
+0xFD, 0xE4, 0x9E, 0xFC, 0x90, 0x96, 0x16, 0x12,
+0x86, 0x39, 0x8D, 0x82, 0x8C, 0x83, 0x12, 0x02,
+0x1F, 0xFD, 0xC3, 0x74, 0x03, 0x9F, 0xFF, 0xE4,
+0x9E, 0xFE, 0x90, 0x96, 0x13, 0x12, 0x86, 0x39,
+0x8F, 0x82, 0x8E, 0x83, 0x02, 0x02, 0x1F, 0xE4,
+0x90, 0x96, 0x16, 0xF0, 0xEF, 0x75, 0xF0, 0x40,
+0xA4, 0x24, 0x80, 0xF9, 0x74, 0x82, 0x35, 0xF0,
+0xFA, 0x7B, 0x01, 0x90, 0x96, 0x12, 0xF1, 0x51,
+0x90, 0x96, 0x15, 0xF0, 0xA3, 0x74, 0x1C, 0xF0,
+0x90, 0x96, 0x15, 0xE0, 0xFF, 0xA3, 0xE0, 0xFE,
+0xC3, 0x9F, 0x40, 0x02, 0xC1, 0xC1, 0x90, 0x96,
+0x12, 0x12, 0x86, 0x39, 0x8E, 0x82, 0xF1, 0x24,
+0x90, 0x96, 0x17, 0xF0, 0xEE, 0xFD, 0x7C, 0x00,
+0xF5, 0x82, 0x8C, 0x83, 0xA3, 0xA3, 0x12, 0x02,
+0x1F, 0xFE, 0x8D, 0x82, 0x8C, 0x83, 0xA3, 0x12,
+0x02, 0x1F, 0xFD, 0xED, 0xFF, 0x90, 0x96, 0x18,
+0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x96, 0x17,
+0xE0, 0x64, 0x01, 0x60, 0x0E, 0xA3, 0xA3, 0xE0,
+0x24, 0x03, 0xFF, 0x90, 0x96, 0x16, 0xE0, 0x2F,
+0xF0, 0x80, 0xAD, 0xE4, 0x90, 0x96, 0x1A, 0xF0,
+0x90, 0x96, 0x1A, 0xE0, 0xFF, 0xC3, 0x94, 0x08,
+0x50, 0x1A, 0x90, 0x96, 0x16, 0xE0, 0x24, 0x03,
+0xF1, 0x2A, 0xB1, 0xB5, 0xFF, 0x90, 0x96, 0x1A,
+0xE0, 0x24, 0x20, 0xF5, 0x82, 0xE4, 0x34, 0x93,
+0xD1, 0xC2, 0x80, 0xDC, 0x90, 0x96, 0x16, 0xE0,
+0x24, 0x0B, 0xFF, 0xE4, 0x33, 0xFE, 0x90, 0x96,
+0x12, 0xB1, 0xB5, 0x90, 0x93, 0x28, 0xF0, 0x70,
+0x27, 0x90, 0x96, 0x1A, 0xF0, 0x90, 0x96, 0x1A,
+0xE0, 0xFF, 0x24, 0x10, 0xFD, 0xE4, 0x33, 0xFC,
+0x90, 0x96, 0x12, 0xD1, 0xE8, 0xFE, 0x74, 0x29,
+0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
+0xEE, 0xD1, 0xC5, 0xE0, 0xB4, 0x04, 0xDE, 0x22,
+0xE4, 0x90, 0x96, 0x1A, 0xF0, 0x90, 0x96, 0x1A,
+0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50, 0x1A, 0x90,
+0x96, 0x16, 0xE0, 0x24, 0x0C, 0xF1, 0x2A, 0xB1,
+0xB5, 0xFF, 0x90, 0x96, 0x1A, 0xE0, 0x24, 0x29,
+0xF5, 0x82, 0xE4, 0x34, 0x93, 0xD1, 0xC2, 0x80,
+0xDC, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x96,
+0x1A, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x96, 0x16,
+0x12, 0x86, 0x42, 0x7A, 0x93, 0x79, 0x29, 0xB1,
+0x60, 0xEF, 0x22, 0x7E, 0x00, 0xC3, 0x74, 0x07,
+0x9F, 0xFD, 0xE4, 0x9E, 0xFC, 0x90, 0x96, 0x16,
+0x12, 0x86, 0x39, 0x8D, 0x82, 0x8C, 0x83, 0x02,
+0x02, 0x1F, 0x90, 0x96, 0x13, 0x12, 0x86, 0x42,
+0xE4, 0x22, 0xD1, 0xF2, 0xFF, 0xF1, 0x0D, 0x6E,
+0x60, 0x03, 0x7F, 0x00, 0x22, 0x0F, 0xEF, 0xB4,
+0x06, 0xF3, 0x7F, 0x01, 0x22, 0x90, 0x96, 0x16,
+0x12, 0x86, 0x39, 0x8F, 0x82, 0x75, 0x83, 0x00,
+0x12, 0x02, 0x1F, 0xFE, 0x90, 0x96, 0x13, 0x12,
+0x86, 0x39, 0x8F, 0x82, 0x75, 0x83, 0x00, 0x02,
+0x02, 0x1F, 0xFD, 0xE4, 0x33, 0xFC, 0x7E, 0x00,
+0xED, 0x2F, 0xFF, 0xEE, 0x3C, 0xFE, 0x90, 0x96,
+0x12, 0x22, 0xE4, 0xFF, 0x74, 0x80, 0x51, 0xFA,
+0x74, 0x2D, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93,
+0x71, 0x52, 0xB4, 0x08, 0xEF, 0x22, 0x90, 0x95,
+0x54, 0x12, 0x86, 0x42, 0x02, 0x02, 0x06, 0x90,
+0x05, 0x58, 0x74, 0x02, 0xF0, 0x22, 0xF5, 0x46,
+0x89, 0x47, 0x75, 0x48, 0x04, 0x22, 0x54, 0x07,
+0xFF, 0x74, 0x01, 0x7E, 0x00, 0xA8, 0x07, 0x08,
+0x22, 0x90, 0x24, 0xA0, 0xE0, 0x90, 0x93, 0x03,
+0x30, 0xE7, 0x05, 0xE0, 0x44, 0x02, 0xF0, 0x22,
+0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90, 0x95, 0xEF,
+0xEF, 0xF0, 0x90, 0x95, 0xED, 0x74, 0x18, 0xF0,
+0x90, 0x96, 0x0F, 0x74, 0x01, 0xF0, 0xFB, 0x7A,
+0x95, 0x79, 0xED, 0x12, 0x90, 0x39, 0x7F, 0x04,
+0x02, 0x04, 0x7E, 0x90, 0x93, 0x03, 0xE0, 0x30,
+0xE0, 0x04, 0x7F, 0x01, 0xF1, 0x85, 0x22, 0x90,
+0x93, 0x03, 0xE0, 0x30, 0xE0, 0x04, 0x7F, 0x02,
+0xF1, 0x85, 0x22, 0x90, 0x93, 0x03, 0xE0, 0x30,
+0xE0, 0x04, 0x7F, 0x03, 0xF1, 0x85, 0x22, 0x12,
+0xC0, 0x64, 0x90, 0x93, 0x03, 0xE0, 0x54, 0xFE,
+0x4E, 0xF0, 0x30, 0xE0, 0x30, 0xEF, 0x54, 0x04,
+0x25, 0xE0, 0xFE, 0xE0, 0x54, 0xF7, 0x4E, 0xFE,
+0xF0, 0xEF, 0x54, 0x02, 0x25, 0xE0, 0xFF, 0xEE,
+0x54, 0xFB, 0x4F, 0xF0, 0x90, 0x04, 0x57, 0xE0,
+0x90, 0x93, 0x05, 0xF0, 0x90, 0x04, 0x55, 0xE0,
+0x90, 0x93, 0x04, 0xF0, 0x7D, 0x10, 0x7F, 0x01,
+0x12, 0x7C, 0x05, 0x80, 0x07, 0x7D, 0x10, 0x7F,
+0x01, 0x12, 0x7C, 0x3B, 0x90, 0x93, 0x03, 0xE0,
+0x54, 0x01, 0xFF, 0xEF, 0x90, 0x07, 0xDC, 0x60,
+0x25, 0xE4, 0xF0, 0xF0, 0x90, 0x07, 0xDE, 0xF0,
+0xA3, 0x04, 0xF0, 0x90, 0x07, 0xDD, 0x74, 0x03,
+0xF0, 0x90, 0x07, 0xE3, 0xE0, 0xF0, 0xA3, 0x74,
+0x50, 0xF0, 0xA3, 0x74, 0x10, 0xF0, 0x90, 0x07,
+0xDC, 0xE0, 0x44, 0x01, 0xF0, 0x22, 0xE4, 0xF0,
+0x22, 0x12, 0x02, 0x06, 0xFF, 0x90, 0x93, 0x3A,
+0xF0, 0xBF, 0x01, 0x07, 0x11, 0x54, 0xE4, 0x90,
+0x93, 0x3A, 0xF0, 0x22, 0x11, 0xFF, 0x7F, 0xEF,
 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x06,
-0x90, 0x95, 0x4E, 0xE0, 0xA3, 0xF0, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x4E, 0x7F, 0xEE, 0x7E, 0x01,
+0x90, 0x95, 0x54, 0xE0, 0xA3, 0xF0, 0x11, 0xFF,
+0x7F, 0xEE, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
+0x01, 0x08, 0x90, 0x95, 0x54, 0xE0, 0x90, 0x95,
+0x56, 0xF0, 0x11, 0xFF, 0x7F, 0xED, 0x7E, 0x01,
 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95,
-0x4E, 0xE0, 0x90, 0x95, 0x50, 0xF0, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x4E, 0x7F, 0xED, 0x7E, 0x01,
+0x54, 0xE0, 0x90, 0x95, 0x57, 0xF0, 0x11, 0xFF,
+0x7F, 0xEC, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
+0x01, 0x08, 0x90, 0x95, 0x54, 0xE0, 0x90, 0x95,
+0x58, 0xF0, 0x11, 0xFF, 0x7F, 0xEB, 0x7E, 0x01,
 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95,
-0x4E, 0xE0, 0x90, 0x95, 0x51, 0xF0, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x4E, 0x7F, 0xEC, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95,
-0x4E, 0xE0, 0x90, 0x95, 0x52, 0xF0, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x4E, 0x7F, 0xEB, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95,
-0x4E, 0xE0, 0x90, 0x95, 0x53, 0xF0, 0x90, 0x95,
-0x4F, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0xA3, 0xE0,
-0xFB, 0xA3, 0xE0, 0x90, 0x95, 0x57, 0xF0, 0x90,
-0x95, 0x53, 0xE0, 0x90, 0x95, 0x58, 0xF0, 0x90,
-0x95, 0x59, 0x74, 0x12, 0xF0, 0x90, 0x95, 0x7B,
-0x74, 0x05, 0xF0, 0x90, 0x95, 0x5B, 0x11, 0xAE,
-0x90, 0x95, 0x57, 0xE0, 0x90, 0x95, 0x5E, 0xF0,
-0x90, 0x95, 0x58, 0xE0, 0x90, 0x95, 0x5F, 0xF0,
-0x7B, 0x01, 0x7A, 0x95, 0x79, 0x59, 0x12, 0x8E,
-0x48, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0xEF, 0xF0,
-0xA3, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x22, 0x12,
-0x02, 0x06, 0x54, 0x01, 0xFF, 0x90, 0x93, 0xF2,
-0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x22, 0x12, 0x02,
-0x06, 0x90, 0x95, 0x71, 0xF0, 0x12, 0x8F, 0x98,
-0x90, 0x95, 0x72, 0xF0, 0x60, 0x0E, 0x31, 0x16,
-0x31, 0x1E, 0x90, 0x95, 0x72, 0x31, 0x16, 0x7B,
-0x57, 0x12, 0xA4, 0xC7, 0x90, 0x95, 0x4E, 0x74,
-0x20, 0xF0, 0x90, 0x95, 0x70, 0x74, 0x03, 0xF0,
-0x90, 0x05, 0x22, 0xE0, 0x90, 0x95, 0x50, 0xF0,
-0x90, 0x93, 0xF3, 0xE0, 0x90, 0x95, 0x51, 0xF0,
-0x90, 0x93, 0xF4, 0xE0, 0x90, 0x95, 0x52, 0xF0,
-0x7B, 0x01, 0x7A, 0x95, 0x79, 0x4E, 0x12, 0x8E,
-0x48, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0xE0, 0xFF,
-0x90, 0x95, 0x71, 0xE0, 0xFD, 0x22, 0xEF, 0xB4,
-0xFF, 0x06, 0x90, 0x93, 0xF3, 0xED, 0xF0, 0x22,
-0xEF, 0xF4, 0xFE, 0x90, 0x93, 0xF3, 0xE0, 0x5E,
-0xFE, 0xED, 0x5F, 0x4E, 0xF0, 0x22, 0xEF, 0xB4,
-0xFF, 0x06, 0x90, 0x93, 0xF4, 0xED, 0xF0, 0x22,
-0xEF, 0xF4, 0xFE, 0x90, 0x93, 0xF4, 0x80, 0xE6,
-0x90, 0x97, 0x41, 0xED, 0xF0, 0x64, 0x01, 0x60,
-0x26, 0xE0, 0xFE, 0x64, 0x02, 0x60, 0x20, 0xEE,
-0x64, 0x29, 0x60, 0x1B, 0xEE, 0x64, 0x2A, 0x60,
-0x16, 0xEE, 0x64, 0x36, 0x60, 0x11, 0xEE, 0xB4,
-0x37, 0x02, 0x80, 0x0B, 0xAD, 0x07, 0x7F, 0xFF,
-0x31, 0x36, 0x90, 0x93, 0xF4, 0xE0, 0xFF, 0x90,
-0x93, 0xF3, 0xE0, 0x4F, 0x90, 0x05, 0x22, 0xF0,
-0x90, 0x97, 0x41, 0xE0, 0x90, 0x93, 0x01, 0xF0,
-0x22, 0x12, 0x02, 0x06, 0x90, 0x88, 0x9C, 0xF0,
-0x60, 0x39, 0xA3, 0xE0, 0x20, 0xE0, 0x34, 0x90,
-0x8A, 0xB9, 0x12, 0x8E, 0x5A, 0xE4, 0xFD, 0x7F,
-0x04, 0x12, 0x04, 0x7E, 0x90, 0x88, 0x9B, 0xE0,
-0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x1D, 0xEF, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x20, 0xE0, 0x14, 0x90,
-0x88, 0x9B, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30,
-0xE0, 0x04, 0x7F, 0x0D, 0x80, 0x02, 0x7F, 0x09,
-0x12, 0x71, 0x9A, 0x22, 0x90, 0x93, 0x3F, 0xE0,
-0x20, 0xE0, 0x02, 0x41, 0x92, 0xE4, 0x90, 0x95,
-0x4E, 0xF0, 0x12, 0xE0, 0x55, 0x40, 0x02, 0x41,
-0x92, 0x51, 0x9F, 0x80, 0x05, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x40,
-0xE0, 0xFD, 0xEF, 0x5D, 0x60, 0x02, 0x41, 0x8A,
-0x12, 0x02, 0x06, 0xFF, 0x30, 0xE0, 0x1A, 0x90,
-0x93, 0x41, 0xE0, 0xFE, 0x90, 0x95, 0x4E, 0xE0,
-0xFD, 0x74, 0x01, 0xA8, 0x05, 0x08, 0x80, 0x02,
-0xC3, 0x33, 0xD8, 0xFC, 0x4E, 0x90, 0x93, 0x41,
-0xF0, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x16, 0x90,
-0x93, 0x42, 0xE0, 0xFF, 0x90, 0x95, 0x4E, 0x51,
-0x98, 0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0x4F, 0x90, 0x93, 0x42, 0xF0, 0x12, 0x8F, 0x98,
-0xFF, 0x90, 0x95, 0x4E, 0xE0, 0xFE, 0x24, 0x43,
-0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEF,
-0xF0, 0x12, 0x87, 0xF1, 0xFF, 0x74, 0x48, 0x2E,
-0xF5, 0x82, 0xE4, 0x34, 0x93, 0x12, 0x87, 0x9B,
-0xFF, 0x74, 0x4D, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF5, 0x83, 0xEF, 0x12, 0x87, 0x6D, 0xFF,
-0x74, 0x52, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x93, 0x40, 0xE0,
-0xFF, 0x74, 0x01, 0xA8, 0x06, 0x08, 0x80, 0x02,
-0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93, 0x40,
-0xF0, 0x22, 0x90, 0x95, 0x4E, 0xE0, 0x04, 0xF0,
-0x21, 0xDA, 0x22, 0xE0, 0xFF, 0x90, 0x96, 0xF8,
-0xE0, 0xFE, 0x74, 0x01, 0xA8, 0x06, 0x22, 0x74,
-0x01, 0x7E, 0x00, 0xA8, 0x07, 0x08, 0x22, 0xE4,
-0x90, 0x95, 0xA9, 0xF0, 0x12, 0xE2, 0x99, 0xF1,
-0xCC, 0xE4, 0xFF, 0x91, 0xF5, 0x90, 0x93, 0x3F,
-0xE0, 0x20, 0xE0, 0x02, 0x61, 0xA7, 0x90, 0x00,
-0x02, 0xE0, 0x44, 0x02, 0xF0, 0xE4, 0x90, 0x95,
-0xAA, 0xF0, 0x90, 0x95, 0xAA, 0xE0, 0xFF, 0xC3,
-0x94, 0x05, 0x50, 0x35, 0x51, 0x9F, 0x80, 0x05,
-0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF,
-0x90, 0x93, 0x42, 0xE0, 0xFD, 0xEF, 0x5D, 0x60,
-0x18, 0x90, 0x95, 0xAA, 0xB1, 0x9D, 0x90, 0x01,
-0xB1, 0xF0, 0x90, 0x95, 0xAA, 0xB1, 0x81, 0x90,
-0x01, 0xB3, 0xF0, 0xE0, 0x44, 0x40, 0xF0, 0xB1,
-0x4B, 0x90, 0x95, 0xAA, 0xE0, 0x04, 0xF0, 0x80,
-0xC1, 0x90, 0x07, 0xC7, 0xE4, 0xF0, 0x90, 0x07,
-0xC6, 0xF0, 0x90, 0x07, 0xC5, 0x74, 0x77, 0xF0,
-0x90, 0x07, 0xC4, 0xE4, 0xF0, 0x90, 0x07, 0xC0,
-0x74, 0x38, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74,
-0x0F, 0xF0, 0xA3, 0x74, 0xC0, 0xF0, 0x90, 0x02,
-0x26, 0xE0, 0x44, 0x01, 0xF0, 0xE0, 0x90, 0x95,
-0xAB, 0xF0, 0x90, 0x95, 0xAB, 0xE0, 0x30, 0xE0,
-0x18, 0x90, 0x95, 0xA9, 0xE0, 0x04, 0xF1, 0xC4,
-0x90, 0x02, 0x26, 0xE0, 0x90, 0x95, 0xAB, 0xF0,
-0x90, 0x95, 0xA9, 0xE0, 0xD3, 0x94, 0xFA, 0x40,
-0xE1, 0x90, 0x02, 0x03, 0x74, 0x80, 0xF0, 0x90,
-0x04, 0x24, 0xE0, 0x90, 0x95, 0xAC, 0xF0, 0x90,
-0x04, 0x22, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x02,
-0x00, 0xE0, 0x90, 0x95, 0xAB, 0xF0, 0x90, 0x02,
-0x01, 0x71, 0xB7, 0x90, 0x02, 0x02, 0x71, 0xB7,
-0x90, 0x02, 0x14, 0x71, 0xB7, 0xE0, 0x04, 0xF0,
-0xE0, 0x90, 0x04, 0x24, 0xF0, 0x90, 0x04, 0x22,
-0xE0, 0x54, 0xEF, 0xF0, 0x90, 0x95, 0xAC, 0xE0,
-0x90, 0x04, 0x24, 0xF0, 0x90, 0xFD, 0x09, 0x74,
-0xFF, 0xF0, 0x90, 0xFD, 0x08, 0xE4, 0xF0, 0xB1,
-0x52, 0xF0, 0xE4, 0xFD, 0x12, 0x76, 0xF7, 0x90,
-0x88, 0x32, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xE0,
-0xFF, 0x90, 0x95, 0xAB, 0xE0, 0x2F, 0xF0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x71,
-0xD0, 0x51, 0xA7, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x75, 0x66, 0x14, 0x90, 0x88, 0x32, 0xE0, 0x44,
-0x10, 0xF0, 0xB1, 0x52, 0xF0, 0x7D, 0x01, 0x12,
-0x76, 0xF7, 0x90, 0x88, 0x41, 0xE0, 0x90, 0x00,
-0x93, 0xF0, 0x90, 0x88, 0x37, 0xE0, 0x60, 0x12,
-0x90, 0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74,
-0x10, 0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F, 0x74,
-0x90, 0xF0, 0x90, 0x93, 0x3F, 0xE0, 0x30, 0xE0,
-0x68, 0x90, 0xFD, 0x09, 0xE4, 0xF0, 0x90, 0xFD,
-0x08, 0xF0, 0x90, 0x0E, 0x4B, 0xE0, 0x54, 0xFC,
-0xF0, 0xE4, 0x90, 0x95, 0xA9, 0xF0, 0x90, 0x95,
-0xA9, 0xE0, 0xFF, 0xC3, 0x94, 0x05, 0x50, 0x35,
-0x51, 0x9F, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
-0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x41, 0xE0,
-0xFD, 0xEF, 0x5D, 0x60, 0x18, 0x90, 0x95, 0xA9,
-0xB1, 0x9D, 0x90, 0x01, 0xB1, 0xF0, 0x90, 0x95,
-0xA9, 0xB1, 0x81, 0x90, 0x01, 0xB3, 0xF0, 0xE0,
-0x44, 0x20, 0xF0, 0xB1, 0x4B, 0x90, 0x95, 0xA9,
-0xE0, 0x04, 0xF0, 0x80, 0xC1, 0x90, 0x00, 0x92,
-0xE0, 0x54, 0xFE, 0xF0, 0xE0, 0x44, 0x08, 0xF0,
-0x90, 0x00, 0x02, 0xE0, 0x54, 0xFD, 0xF0, 0x80,
-0x07, 0x90, 0x00, 0x92, 0xE0, 0x44, 0x01, 0xF0,
-0x90, 0x00, 0x08, 0xE0, 0x44, 0x10, 0xF0, 0x7F,
-0x01, 0x91, 0xF5, 0x90, 0x00, 0x90, 0xE0, 0x44,
-0x01, 0xF0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x14,
-0x7E, 0x00, 0x02, 0x7C, 0x6A, 0x90, 0x97, 0x36,
-0xEF, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x90,
-0x01, 0x09, 0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02,
-0x7F, 0x01, 0x90, 0x97, 0x36, 0xE0, 0x6F, 0x60,
-0x32, 0xC3, 0x90, 0x97, 0x38, 0xE0, 0x94, 0x88,
-0x90, 0x97, 0x37, 0xE0, 0x94, 0x13, 0x40, 0x08,
-0x90, 0x01, 0xC0, 0xE0, 0x44, 0x10, 0xF0, 0x22,
-0x90, 0x97, 0x37, 0xB1, 0x44, 0xD3, 0x90, 0x97,
-0x38, 0xE0, 0x94, 0x32, 0x90, 0x97, 0x37, 0xE0,
-0x94, 0x00, 0x40, 0xC3, 0x90, 0x01, 0xC6, 0xE0,
-0x30, 0xE0, 0xBC, 0x22, 0xE4, 0x75, 0xF0, 0x01,
-0x12, 0x02, 0xE7, 0x7F, 0x14, 0x7E, 0x00, 0x02,
-0x7C, 0x6A, 0x90, 0x88, 0xA0, 0xE0, 0xC4, 0x13,
-0x13, 0x54, 0x01, 0xFF, 0x90, 0x88, 0xE0, 0xE0,
-0xFB, 0x90, 0x88, 0xDF, 0xE0, 0x90, 0x92, 0x90,
-0x22, 0x90, 0x88, 0x39, 0xE0, 0xFF, 0x60, 0x03,
-0xB4, 0x08, 0x0D, 0xD1, 0x29, 0xBF, 0x01, 0x08,
-0x71, 0xC0, 0x90, 0x01, 0xE5, 0xE0, 0x04, 0xF0,
-0x22, 0xE0, 0xFF, 0x24, 0x43, 0xF5, 0x82, 0xE4,
-0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB2,
-0xF0, 0x74, 0x48, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF5, 0x83, 0xE0, 0x22, 0xE0, 0xFF, 0x24,
-0x4D, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
-0xE0, 0x90, 0x01, 0xB0, 0xF0, 0x74, 0x52, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0,
-0x22, 0x90, 0x88, 0x31, 0xE0, 0x30, 0xE0, 0x19,
-0x90, 0x88, 0x2C, 0xE0, 0xFF, 0x30, 0xE0, 0x0F,
-0xC3, 0x13, 0x30, 0xE0, 0x08, 0x12, 0xE6, 0x6A,
-0xBF, 0x01, 0x06, 0x80, 0x02, 0x80, 0x00, 0xB1,
-0x69, 0x22, 0xE4, 0x90, 0x95, 0x4E, 0xF0, 0xA3,
-0xF0, 0x12, 0xE2, 0x17, 0xEF, 0x64, 0x01, 0x60,
-0x39, 0xC3, 0x90, 0x95, 0x4F, 0xE0, 0x94, 0x88,
-0x90, 0x95, 0x4E, 0xE0, 0x94, 0x13, 0x40, 0x0F,
-0x90, 0x01, 0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90,
-0x01, 0xC7, 0x74, 0xFD, 0xF0, 0x80, 0x1B, 0x90,
-0x95, 0x4E, 0xB1, 0x44, 0xD3, 0x90, 0x95, 0x4F,
-0xE0, 0x94, 0x32, 0x90, 0x95, 0x4E, 0xE0, 0x94,
-0x00, 0x40, 0xC6, 0x90, 0x01, 0xC6, 0xE0, 0x30,
-0xE3, 0xBF, 0x90, 0x01, 0xC7, 0x74, 0xFE, 0xF0,
-0x22, 0x90, 0x93, 0x3B, 0xE0, 0xC3, 0x13, 0x20,
-0xE0, 0x35, 0x90, 0x02, 0x87, 0xE0, 0x60, 0x02,
-0x80, 0x08, 0x90, 0x01, 0x00, 0xE0, 0x64, 0x3F,
-0x60, 0x05, 0x75, 0x66, 0x01, 0x80, 0x2E, 0x90,
-0x02, 0x96, 0xE0, 0x60, 0x05, 0x75, 0x66, 0x10,
-0x80, 0x23, 0x90, 0x02, 0x86, 0xE0, 0x20, 0xE1,
-0x02, 0x80, 0x07, 0x90, 0x02, 0x86, 0xE0, 0x30,
-0xE3, 0x05, 0x75, 0x66, 0x04, 0x80, 0x0E, 0x90,
-0x88, 0xE6, 0xE0, 0x30, 0xE0, 0x05, 0x75, 0x66,
-0x20, 0x80, 0x02, 0xE1, 0xBC, 0x90, 0x01, 0xB9,
-0x74, 0x08, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x66,
-0xF0, 0x7F, 0x00, 0x22, 0xE4, 0x90, 0x95, 0xE8,
-0xF0, 0x12, 0xE6, 0x56, 0xF1, 0x40, 0xF1, 0x8F,
-0xF1, 0x5B, 0x90, 0x07, 0xE3, 0xE0, 0x90, 0x95,
-0xE7, 0xF0, 0xE0, 0x60, 0x59, 0xE4, 0x90, 0x95,
-0xE9, 0xF0, 0x90, 0x96, 0x0B, 0x74, 0x08, 0xF0,
-0x90, 0x05, 0x68, 0xE0, 0x90, 0x95, 0xEB, 0xF0,
-0x90, 0x05, 0x69, 0xE0, 0x90, 0x95, 0xEC, 0xF0,
-0x90, 0x05, 0x6A, 0xE0, 0x90, 0x95, 0xED, 0xF0,
-0x90, 0x05, 0x6B, 0xE0, 0x90, 0x95, 0xEE, 0xF0,
-0x90, 0x05, 0x78, 0xE0, 0x90, 0x95, 0xEF, 0xF0,
-0x90, 0x05, 0x79, 0xE0, 0x90, 0x95, 0xF0, 0xF0,
-0x90, 0x05, 0x7A, 0xE0, 0x90, 0x95, 0xF1, 0xF0,
-0x90, 0x05, 0x7B, 0xE0, 0x90, 0x95, 0xF2, 0xF0,
-0x7B, 0x01, 0x7A, 0x95, 0x79, 0xE9, 0x12, 0x8E,
-0x48, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x90, 0x95,
-0xE7, 0xE0, 0xFD, 0x60, 0x42, 0xA3, 0xE0, 0xFF,
-0x51, 0x9F, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
-0xCE, 0xD8, 0xF9, 0xFF, 0xEF, 0x5D, 0x60, 0xE6,
-0x90, 0x95, 0xE8, 0xE0, 0xFB, 0x74, 0x01, 0xA8,
-0x03, 0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xFE, 0xF4, 0xFD, 0x90, 0x95, 0xE7, 0xE0, 0x5D,
-0xF0, 0x90, 0x07, 0xE3, 0xE0, 0x4E, 0xF0, 0xAF,
-0x03, 0x12, 0xD2, 0x82, 0x12, 0xD1, 0x3F, 0x90,
-0x95, 0xE8, 0xE0, 0x04, 0xF0, 0x80, 0xB7, 0x22,
-0xE4, 0xFF, 0x74, 0x80, 0xF1, 0x84, 0x74, 0x2D,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF1, 0x54,
-0xB4, 0x08, 0xEF, 0x22, 0xF5, 0x83, 0xEE, 0xF0,
-0x0F, 0xEF, 0x22, 0xE4, 0xFF, 0x74, 0x94, 0xF1,
-0x84, 0x74, 0x13, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF1, 0x54, 0xB4, 0x08, 0xEF, 0xE4, 0xFF,
-0x74, 0x9C, 0xF1, 0x84, 0x74, 0x1C, 0x2F, 0xF5,
-0x82, 0xE4, 0x34, 0x93, 0xF1, 0x54, 0xB4, 0x04,
-0xEF, 0x22, 0x74, 0x90, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0x24, 0xF5, 0x83, 0xE0, 0xFE, 0x22, 0xE4,
-0xFF, 0x74, 0x88, 0xF1, 0x84, 0x74, 0x06, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF1, 0x54, 0xB4,
-0x08, 0xEF, 0x90, 0x05, 0xDC, 0xE0, 0x90, 0x93,
-0x0E, 0xF0, 0xE4, 0xFF, 0xF1, 0x82, 0x74, 0x0F,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF1, 0x54,
-0xB4, 0x04, 0xF1, 0x22, 0x90, 0x01, 0xB8, 0xE4,
-0xF0, 0x7F, 0x01, 0x22, 0xF0, 0x7F, 0x0A, 0x7E,
-0x00, 0x02, 0x7C, 0x6A, 0x90, 0x00, 0x08, 0xE0,
-0x54, 0xEF, 0xF0, 0x22, 0x12, 0x02, 0x06, 0x54,
-0x01, 0xFF, 0x90, 0x93, 0x3F, 0xE0, 0x54, 0xFE,
-0x4F, 0xF0, 0x30, 0xE0, 0x02, 0xF1, 0xE9, 0x22,
-0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
-0x22, 0x90, 0x95, 0x56, 0x74, 0x27, 0xF0, 0x90,
-0x95, 0x78, 0x74, 0x06, 0xF0, 0x90, 0x95, 0x58,
-0x74, 0x08, 0x12, 0xC7, 0xE8, 0x90, 0x95, 0x4A,
-0xE0, 0x90, 0x95, 0x5C, 0xF0, 0x90, 0x95, 0x4B,
-0xE0, 0x90, 0x95, 0x5D, 0xF0, 0x7B, 0x01, 0x7A,
-0x95, 0x79, 0x56, 0x31, 0x9E, 0x02, 0x04, 0x7E,
-0x12, 0x02, 0x06, 0xFF, 0x12, 0x8F, 0x98, 0x90,
-0x95, 0x50, 0xF0, 0x12, 0x87, 0xF1, 0x90, 0x95,
-0x51, 0x12, 0x87, 0x9E, 0x90, 0x95, 0x52, 0x12,
-0x87, 0x6D, 0x90, 0x95, 0x53, 0x12, 0x87, 0x66,
-0x90, 0x95, 0x54, 0x12, 0x87, 0xF7, 0x90, 0x95,
-0x55, 0xF0, 0xEF, 0x12, 0x86, 0x4B, 0xC8, 0x70,
-0x00, 0xC8, 0x7C, 0x01, 0xC8, 0x83, 0x02, 0xC8,
-0x8A, 0x03, 0xC8, 0x91, 0x04, 0xC8, 0x98, 0x05,
-0xC8, 0xA1, 0x06, 0xC8, 0xCA, 0x07, 0xC9, 0x25,
-0x08, 0xC9, 0x28, 0x09, 0x00, 0x00, 0xC9, 0x67,
-0x90, 0x95, 0x4E, 0x74, 0x02, 0xF0, 0xA3, 0x74,
-0x29, 0xF0, 0x21, 0x6C, 0x31, 0x96, 0x74, 0x2A,
-0xF0, 0x21, 0x6C, 0x31, 0x87, 0x74, 0x31, 0xF0,
-0x21, 0x6C, 0x31, 0x87, 0x74, 0x32, 0xF0, 0x21,
-0x6C, 0x31, 0x96, 0x74, 0x33, 0xF0, 0x21, 0x6C,
-0x31, 0x8F, 0x90, 0x8A, 0x83, 0x31, 0xA1, 0x21,
-0x83, 0x90, 0x95, 0x50, 0xE0, 0x90, 0x88, 0xE1,
-0xF0, 0x90, 0x95, 0x51, 0xE0, 0x90, 0x88, 0xE2,
-0xF0, 0x90, 0x95, 0x52, 0xE0, 0x90, 0x88, 0xE3,
-0xF0, 0x90, 0x95, 0x53, 0xE0, 0x90, 0x88, 0xE4,
-0xF0, 0x90, 0x95, 0x54, 0xE0, 0x90, 0x88, 0xE5,
-0xF0, 0x22, 0x90, 0x95, 0x50, 0xE0, 0x90, 0x95,
-0x43, 0xF0, 0x90, 0x95, 0x53, 0x12, 0x8F, 0xEA,
-0x78, 0x10, 0x12, 0x03, 0xFE, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3, 0x12, 0x8F,
-0xEA, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86,
-0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x90, 0x95, 0x52, 0x12, 0x8F, 0xEA, 0x78,
-0x08, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0xB1,
-0xF7, 0x12, 0x8F, 0xE7, 0x12, 0x86, 0x20, 0x90,
-0x95, 0x39, 0x02, 0x04, 0x31, 0x02, 0xC7, 0xF1,
-0x90, 0x95, 0x45, 0xE0, 0x44, 0x01, 0xFF, 0xF0,
-0x90, 0x95, 0x50, 0xE0, 0x54, 0x7F, 0x25, 0xE0,
-0xFE, 0xEF, 0x54, 0x01, 0x4E, 0x90, 0x95, 0x45,
-0xF0, 0xE0, 0xFF, 0xC3, 0x13, 0x54, 0x7F, 0xC3,
-0x94, 0x1E, 0x50, 0x06, 0xEF, 0x54, 0x01, 0x44,
-0x3C, 0xF0, 0x90, 0x95, 0x45, 0xE0, 0xFF, 0xC3,
-0x13, 0x54, 0x7F, 0xD3, 0x94, 0x50, 0x40, 0x26,
-0xEF, 0x54, 0x01, 0x44, 0xA0, 0xF0, 0x22, 0x31,
-0x87, 0x74, 0xFF, 0xF0, 0x90, 0x95, 0x4F, 0xE0,
-0xFF, 0x90, 0x95, 0x4E, 0xE0, 0xFD, 0x31, 0x8F,
-0x90, 0x8A, 0xCF, 0xE0, 0xF8, 0xA3, 0xE0, 0xF5,
-0x82, 0x88, 0x83, 0x12, 0x04, 0x7E, 0x22, 0x90,
-0x95, 0x4E, 0x74, 0x01, 0xF0, 0xA3, 0x22, 0x7B,
-0x01, 0x7A, 0x95, 0x79, 0x50, 0x22, 0x90, 0x95,
-0x4E, 0x74, 0x06, 0xF0, 0xA3, 0x22, 0x90, 0x8A,
-0x77, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xF5, 0x82,
-0x8E, 0x83, 0x22, 0x90, 0x95, 0x4E, 0xEF, 0xF0,
-0x71, 0xF9, 0x7F, 0xF4, 0x7E, 0x01, 0x12, 0x5F,
-0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x95, 0xE0,
-0x90, 0x95, 0x97, 0xF0, 0x71, 0xF9, 0x7F, 0xF5,
-0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08,
-0x90, 0x95, 0x95, 0xE0, 0x90, 0x95, 0x98, 0xF0,
-0x71, 0xF9, 0x7F, 0xF6, 0x7E, 0x01, 0x12, 0x5F,
-0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x95, 0xE0,
-0x90, 0x95, 0x99, 0xF0, 0x71, 0xF9, 0x7F, 0xF7,
-0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08,
-0x90, 0x95, 0x95, 0xE0, 0x90, 0x95, 0x9A, 0xF0,
-0x71, 0xF9, 0x7F, 0xF8, 0x7E, 0x01, 0x12, 0x5F,
-0xA6, 0xBF, 0x01, 0x08, 0x90, 0x95, 0x95, 0xE0,
-0x90, 0x95, 0x9B, 0xF0, 0x71, 0xF9, 0xD1, 0xEE,
-0xBF, 0x01, 0x08, 0x90, 0x95, 0x95, 0xE0, 0x90,
-0x95, 0x9C, 0xF0, 0x71, 0xF9, 0x7F, 0xFB, 0x91,
-0x00, 0x70, 0x52, 0x90, 0x95, 0x95, 0xE0, 0x90,
-0x95, 0x9D, 0xF0, 0x54, 0x07, 0x60, 0x08, 0x90,
-0x95, 0x95, 0xE0, 0x54, 0xE0, 0x70, 0x3E, 0x7B,
-0x01, 0x7A, 0x95, 0x79, 0x96, 0x7F, 0xFA, 0x91,
-0x00, 0x70, 0x32, 0x90, 0x95, 0x95, 0xE0, 0xFC,
-0x54, 0x07, 0x70, 0x12, 0x90, 0x95, 0x9D, 0xE0,
-0xFE, 0x90, 0x95, 0x96, 0xE0, 0x54, 0x07, 0xFD,
-0xEE, 0x4D, 0x90, 0x95, 0x9D, 0xF0, 0xEC, 0x54,
-0xE0, 0x70, 0x12, 0x90, 0x95, 0x9D, 0xE0, 0xFF,
-0x90, 0x95, 0x96, 0xE0, 0x54, 0xE0, 0xFE, 0xEF,
-0x4E, 0x90, 0x95, 0x9D, 0xF0, 0x71, 0xF9, 0x7F,
-0xFD, 0x91, 0x00, 0x70, 0x46, 0x90, 0x95, 0x95,
-0xE0, 0xFE, 0x54, 0xCC, 0x90, 0x95, 0x9E, 0xF0,
-0xEE, 0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90, 0x95,
-0x95, 0xE0, 0x54, 0xC0, 0x70, 0x2D, 0xEF, 0x70,
-0x11, 0x90, 0x95, 0x9E, 0xE0, 0xFF, 0x90, 0x95,
-0x95, 0xE0, 0x54, 0x03, 0xD1, 0xF7, 0x90, 0x95,
-0x9E, 0xF0, 0x90, 0x95, 0x95, 0xE0, 0xFF, 0x54,
-0xC0, 0x70, 0x10, 0x90, 0x95, 0x9E, 0xE0, 0xFE,
-0xEF, 0x54, 0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF,
-0xEE, 0x4F, 0xF0, 0x71, 0xF9, 0x7F, 0xF0, 0x7E,
-0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
-0x95, 0x95, 0xE0, 0x90, 0x95, 0x9F, 0xF0, 0x71,
-0xF9, 0x7F, 0xF1, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
-0xBF, 0x01, 0x08, 0x90, 0x95, 0x95, 0xE0, 0x90,
-0x95, 0xA0, 0xF0, 0x71, 0xF9, 0x7F, 0xF2, 0x7E,
-0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
-0x95, 0x95, 0xE0, 0x90, 0x95, 0xA1, 0xF0, 0x71,
-0xF9, 0x7F, 0xF3, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
-0xBF, 0x01, 0x08, 0x90, 0x95, 0x95, 0xE0, 0x90,
-0x95, 0xA2, 0xF0, 0x71, 0xF9, 0x7F, 0xFC, 0x7E,
-0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90,
-0x95, 0x95, 0xE0, 0x90, 0x95, 0xA3, 0xF0, 0x90,
-0x95, 0x4F, 0x74, 0x19, 0xF0, 0x90, 0x95, 0x71,
-0x74, 0x08, 0xF0, 0x90, 0x95, 0x97, 0xE0, 0x90,
-0x95, 0x51, 0xF0, 0x90, 0x95, 0x98, 0xE0, 0x90,
-0x95, 0x52, 0xF0, 0x90, 0x95, 0x99, 0xE0, 0x90,
-0x95, 0x53, 0xF0, 0x90, 0x95, 0x9A, 0xE0, 0x90,
-0x95, 0x54, 0xF0, 0x90, 0x95, 0x9B, 0xE0, 0x90,
-0x95, 0x55, 0xF0, 0x90, 0x95, 0x9C, 0xE0, 0x90,
-0x95, 0x56, 0xF0, 0x90, 0x95, 0x9D, 0xE0, 0x90,
-0x95, 0x57, 0xF0, 0x90, 0x95, 0x9E, 0xE0, 0x90,
-0x95, 0x58, 0xF0, 0x90, 0x95, 0x72, 0x74, 0x1A,
-0xF0, 0x90, 0x95, 0x94, 0x74, 0x05, 0xF0, 0x90,
-0x95, 0x9F, 0xE0, 0x90, 0x95, 0x74, 0xF0, 0x90,
-0x95, 0xA0, 0xE0, 0x90, 0x95, 0x75, 0xF0, 0x90,
-0x95, 0xA1, 0xE0, 0x90, 0x95, 0x76, 0xF0, 0x90,
-0x95, 0xA2, 0xE0, 0x90, 0x95, 0x77, 0xF0, 0x90,
-0x95, 0xA3, 0xE0, 0x90, 0x95, 0x78, 0xF0, 0x90,
-0x95, 0x4E, 0xE0, 0xB4, 0x01, 0x19, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x4F, 0x31, 0x9E, 0x12, 0x04,
-0x7E, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x72, 0x12,
-0x8E, 0x48, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0x75,
-0x45, 0x01, 0x75, 0x46, 0x95, 0x75, 0x47, 0x4F,
-0x75, 0x48, 0x0A, 0x7B, 0x01, 0x7A, 0x01, 0x79,
-0xA0, 0x12, 0x69, 0xF5, 0x75, 0x45, 0x01, 0x75,
-0x46, 0x95, 0x75, 0x47, 0x74, 0x75, 0x48, 0x05,
-0x7B, 0x01, 0x7A, 0x01, 0x79, 0xAA, 0x02, 0x69,
-0xF5, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x95, 0x22,
-0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xEF, 0x64, 0x01,
-0x22, 0x12, 0x02, 0x06, 0x64, 0x01, 0x60, 0x02,
-0x81, 0x9D, 0x90, 0x95, 0x95, 0xF0, 0x90, 0x95,
-0x95, 0xE0, 0xFF, 0xC3, 0x94, 0x10, 0x50, 0x27,
-0xEF, 0xD1, 0xFF, 0x7A, 0x95, 0x79, 0x94, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x12, 0x90, 0x95, 0x94,
-0xE0, 0xFF, 0xA3, 0xE0, 0x24, 0x96, 0xF5, 0x82,
-0xE4, 0x34, 0x95, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
-0x95, 0x95, 0xE0, 0x04, 0xF0, 0x80, 0xCF, 0x75,
-0x45, 0x01, 0x75, 0x46, 0x95, 0x75, 0x47, 0x96,
-0x75, 0x48, 0x08, 0x31, 0x8F, 0x12, 0x69, 0xF5,
-0x90, 0x95, 0x4E, 0x74, 0x24, 0xF0, 0x90, 0x95,
-0x70, 0x74, 0x08, 0xF0, 0x75, 0x45, 0x01, 0x75,
-0x46, 0x95, 0x75, 0x47, 0x9E, 0xF5, 0x48, 0x7B,
-0x01, 0x7A, 0x95, 0x79, 0x73, 0x12, 0x69, 0xF5,
-0x90, 0x95, 0x71, 0x74, 0x25, 0xF0, 0x90, 0x95,
-0x93, 0x74, 0x08, 0xF0, 0x7B, 0x01, 0x7A, 0x95,
-0x79, 0x4E, 0x31, 0x9E, 0x12, 0x04, 0x7E, 0x7B,
-0x01, 0x7A, 0x95, 0x79, 0x71, 0x12, 0x8E, 0x48,
-0x7F, 0x04, 0x12, 0x04, 0x7E, 0x22, 0xD3, 0x10,
+0x54, 0xE0, 0x90, 0x95, 0x59, 0xF0, 0x90, 0x95,
+0x55, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0xA3, 0xE0,
+0xFB, 0xA3, 0xE0, 0x90, 0x95, 0x5D, 0xF0, 0x90,
+0x95, 0x59, 0xE0, 0x90, 0x95, 0x5E, 0xF0, 0x90,
+0x95, 0x5F, 0x74, 0x12, 0xF0, 0x90, 0x95, 0x81,
+0x74, 0x05, 0xF0, 0x90, 0x95, 0x61, 0xF1, 0x7F,
+0x90, 0x95, 0x5D, 0xE0, 0x90, 0x95, 0x64, 0xF0,
+0x90, 0x95, 0x5E, 0xE0, 0x90, 0x95, 0x65, 0xF0,
+0x7B, 0x01, 0x7A, 0x95, 0x79, 0x5F, 0x12, 0x90,
+0x39, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0xF0, 0x7B,
+0x01, 0x7A, 0x95, 0x79, 0x54, 0x22, 0x7E, 0x00,
+0x7F, 0x0B, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x93,
+0x79, 0xE7, 0x12, 0x04, 0x80, 0x11, 0xFF, 0xF1,
+0x6F, 0xBF, 0x01, 0x1C, 0x90, 0x95, 0x54, 0xE0,
+0xFE, 0x54, 0x01, 0x90, 0x93, 0xE7, 0xF0, 0xEE,
+0x54, 0x04, 0x90, 0x93, 0xE9, 0xF0, 0x90, 0x95,
+0x54, 0xE0, 0x54, 0x08, 0x90, 0x93, 0xE8, 0xF0,
+0x11, 0xFF, 0x12, 0x97, 0x8D, 0x64, 0x01, 0x70,
+0x35, 0x90, 0x95, 0x54, 0xE0, 0x54, 0x07, 0x70,
+0x15, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x55, 0x7F,
+0xFA, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
+0x0F, 0x90, 0x95, 0x55, 0x80, 0x03, 0x90, 0x95,
+0x54, 0xE0, 0x54, 0x07, 0x90, 0x93, 0xEB, 0xF0,
+0x90, 0x95, 0x54, 0xE0, 0x54, 0xE0, 0xC4, 0x13,
+0x54, 0x07, 0x90, 0x93, 0xEA, 0xF0, 0x11, 0xFF,
+0x7F, 0xFD, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
+0x01, 0x0E, 0x90, 0x95, 0x54, 0xE0, 0x54, 0x0C,
+0x13, 0x13, 0x54, 0x3F, 0x90, 0x93, 0xEC, 0xF0,
+0x22, 0x12, 0x02, 0x06, 0x90, 0x95, 0x77, 0x12,
+0x87, 0x69, 0x90, 0x95, 0x78, 0xF0, 0x60, 0x0E,
+0x31, 0xEF, 0x31, 0xF7, 0x90, 0x95, 0x78, 0x31,
+0xEF, 0x7B, 0x57, 0x12, 0x8F, 0x64, 0x90, 0x88,
+0x9D, 0xE0, 0x30, 0xE0, 0x0D, 0x12, 0x97, 0x31,
+0x30, 0xE0, 0x07, 0x90, 0x06, 0x0A, 0xE0, 0x44,
+0x07, 0xF0, 0x90, 0x95, 0x54, 0x74, 0x20, 0xF0,
+0x90, 0x95, 0x76, 0x74, 0x03, 0xF0, 0x90, 0x05,
+0x22, 0xE0, 0x90, 0x95, 0x56, 0xF0, 0x90, 0x93,
+0xF3, 0xE0, 0x90, 0x95, 0x57, 0xF0, 0x90, 0x93,
+0xF4, 0xE0, 0x90, 0x95, 0x58, 0x11, 0xFE, 0x12,
+0x90, 0x39, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0xE0,
+0xFF, 0x90, 0x95, 0x77, 0xE0, 0xFD, 0x22, 0xEF,
+0xB4, 0xFF, 0x06, 0x90, 0x93, 0xF3, 0xED, 0xF0,
+0x22, 0xEF, 0xF4, 0xFE, 0x90, 0x93, 0xF3, 0xE0,
+0x5E, 0xFE, 0xED, 0x5F, 0x4E, 0xF0, 0x22, 0x12,
+0x02, 0x06, 0x64, 0x01, 0x60, 0x02, 0x41, 0xA2,
+0x90, 0x95, 0x9B, 0xF0, 0x90, 0x95, 0x9B, 0xE0,
+0xFF, 0xC3, 0x94, 0x10, 0x50, 0x27, 0xEF, 0xF1,
+0x88, 0x7A, 0x95, 0x79, 0x9A, 0x12, 0x5F, 0xA6,
+0xBF, 0x01, 0x12, 0x90, 0x95, 0x9A, 0xE0, 0xFF,
+0xA3, 0xE0, 0x24, 0x9C, 0xF5, 0x82, 0xE4, 0x34,
+0x95, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x95, 0x9B,
+0xE0, 0x04, 0xF0, 0x80, 0xCF, 0x75, 0x45, 0x01,
+0x75, 0x46, 0x95, 0x75, 0x47, 0x9C, 0x75, 0x48,
+0x08, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x56, 0x12,
+0x69, 0xF5, 0x90, 0x95, 0x54, 0x74, 0x24, 0xF0,
+0x90, 0x95, 0x76, 0x74, 0x08, 0xF0, 0x75, 0x45,
+0x01, 0x75, 0x46, 0x95, 0x75, 0x47, 0xA4, 0xF5,
+0x48, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x79, 0x12,
+0x69, 0xF5, 0x90, 0x95, 0x77, 0x74, 0x25, 0xF0,
+0x90, 0x95, 0x99, 0x74, 0x08, 0x11, 0xFE, 0x91,
+0x11, 0x12, 0x04, 0x7E, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0x77, 0x12, 0x90, 0x39, 0x7F, 0x04, 0x12,
+0x04, 0x7E, 0x22, 0x12, 0x02, 0x06, 0xFF, 0x12,
+0x87, 0x6A, 0x90, 0x95, 0x54, 0x12, 0x87, 0x96,
+0x90, 0x95, 0x55, 0x12, 0x87, 0xFD, 0x90, 0x95,
+0x56, 0x12, 0x87, 0xF3, 0x90, 0x95, 0x57, 0xF0,
+0x12, 0x87, 0x63, 0x90, 0x95, 0x58, 0x12, 0xA2,
+0x26, 0x90, 0x95, 0x59, 0xF0, 0xEF, 0x24, 0xF9,
+0x60, 0x3F, 0x14, 0x70, 0x02, 0x61, 0x6D, 0x14,
+0x70, 0x02, 0x61, 0x6F, 0x24, 0xFD, 0x70, 0x02,
+0x61, 0xAE, 0x24, 0x06, 0x60, 0x02, 0x61, 0xBE,
+0x90, 0x95, 0x54, 0xE0, 0x90, 0x88, 0xE1, 0xF0,
+0x90, 0x95, 0x55, 0xE0, 0x90, 0x88, 0xE2, 0xF0,
+0x90, 0x95, 0x56, 0xE0, 0x90, 0x88, 0xE3, 0xF0,
+0x90, 0x95, 0x57, 0xE0, 0x90, 0x88, 0xE4, 0xF0,
+0x90, 0x95, 0x58, 0xE0, 0x90, 0x88, 0xE5, 0xF0,
+0x22, 0x90, 0x95, 0x54, 0xE0, 0x90, 0x95, 0x43,
+0xF0, 0x12, 0x8F, 0xE9, 0x78, 0x10, 0x12, 0x03,
+0xFE, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0xA3, 0x12, 0x8F, 0xEC, 0x78, 0x18, 0x12,
+0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
+0xD0, 0x00, 0x12, 0x86, 0x20, 0xC0, 0x04, 0xC0,
+0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x95, 0x56,
+0x12, 0x8F, 0xEC, 0x78, 0x08, 0x12, 0x03, 0xFE,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0x12, 0x86, 0x20, 0x12, 0x9D, 0x3F, 0x90, 0x95,
+0x55, 0x12, 0x8F, 0xEC, 0x12, 0x86, 0x20, 0x90,
+0x95, 0x39, 0x02, 0x04, 0x31, 0x80, 0x66, 0x90,
+0x95, 0x45, 0xE0, 0x44, 0x01, 0xFF, 0xF0, 0x90,
+0x95, 0x54, 0xE0, 0x54, 0x7F, 0x25, 0xE0, 0xFE,
+0xEF, 0x54, 0x01, 0x4E, 0x90, 0x95, 0x45, 0xF0,
+0xE0, 0xFF, 0xC3, 0x13, 0x54, 0x7F, 0xC3, 0x94,
+0x1E, 0x50, 0x06, 0xEF, 0x54, 0x01, 0x44, 0x3C,
+0xF0, 0x90, 0x95, 0x45, 0xE0, 0xFF, 0xC3, 0x13,
+0x54, 0x7F, 0xD3, 0x94, 0x50, 0x40, 0x2D, 0xEF,
+0x54, 0x01, 0x44, 0xA0, 0xF0, 0x22, 0x90, 0x95,
+0x54, 0xE0, 0x54, 0x01, 0xFF, 0x90, 0x95, 0x4C,
+0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x22, 0x7E, 0x01,
+0x7F, 0xFF, 0xAD, 0x06, 0x11, 0xFF, 0x90, 0x8A,
+0xCF, 0xE0, 0xF8, 0xA3, 0xE0, 0xF5, 0x82, 0x88,
+0x83, 0x12, 0x04, 0x7E, 0x22, 0x90, 0x95, 0x5A,
+0x74, 0x27, 0xF0, 0x90, 0x95, 0x7C, 0x74, 0x08,
+0xF0, 0x90, 0x95, 0x5C, 0xF1, 0x76, 0x90, 0x95,
+0x4A, 0xE0, 0x90, 0x95, 0x60, 0xF0, 0x90, 0x95,
+0x4B, 0xE0, 0x90, 0x95, 0x61, 0xF0, 0x90, 0x95,
+0x4E, 0xE0, 0x90, 0x95, 0x62, 0xF0, 0x90, 0x95,
+0x4F, 0xE0, 0x90, 0x95, 0x63, 0xF0, 0x7B, 0x01,
+0x7A, 0x95, 0x79, 0x5A, 0x91, 0x11, 0x02, 0x04,
+0x7E, 0x90, 0x8A, 0x77, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0xF5, 0x82, 0x8E, 0x83, 0x22, 0xD3, 0x10,
 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0x90, 0x96,
-0x1B, 0xF0, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x96,
-0x1F, 0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x96,
-0x1E, 0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x96,
-0x1D, 0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x96,
-0x1C, 0xB1, 0xEA, 0x90, 0x96, 0x1C, 0x12, 0x8F,
-0xEA, 0x12, 0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x96, 0x1E, 0x12,
-0x8F, 0xEA, 0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0,
-0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0xA3, 0x12, 0x8F, 0xEA, 0x78, 0x18,
-0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0x90, 0x96,
-0x24, 0x12, 0x04, 0x31, 0x90, 0x96, 0x24, 0x12,
-0x86, 0x2D, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
-0xC0, 0x03, 0x90, 0x95, 0x4D, 0xE0, 0x24, 0x01,
-0xFF, 0xE4, 0x33, 0xFE, 0xE4, 0xFC, 0xFD, 0xFB,
-0x7A, 0x90, 0x79, 0x01, 0xF8, 0x12, 0x85, 0xC4,
+0x21, 0xF0, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x96,
+0x25, 0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x96,
+0x24, 0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x96,
+0x23, 0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x96,
+0x22, 0x12, 0x9D, 0x32, 0x90, 0x96, 0x22, 0x12,
+0x8F, 0xEC, 0x12, 0x86, 0x20, 0xC0, 0x04, 0xC0,
+0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x96, 0x24,
+0x12, 0x8F, 0xEC, 0x78, 0x10, 0x12, 0x03, 0xFE,
 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
-0x12, 0x85, 0xA9, 0x90, 0x96, 0x24, 0x12, 0x04,
-0x31, 0xB1, 0xDE, 0x90, 0x05, 0x2C, 0xEF, 0xF0,
-0xB1, 0xDE, 0x78, 0x08, 0x12, 0x03, 0xEB, 0x90,
-0x05, 0x2D, 0xEF, 0xF0, 0xB1, 0xDE, 0x78, 0x10,
-0x12, 0x03, 0xEB, 0x90, 0x05, 0x2E, 0xEF, 0xF0,
-0xB1, 0xDE, 0x78, 0x18, 0x12, 0x03, 0xEB, 0x90,
-0x05, 0x2F, 0xEF, 0xD1, 0x3E, 0x90, 0x96, 0x20,
-0x12, 0x04, 0x31, 0xB1, 0xE4, 0xE4, 0xFF, 0xFE,
-0xED, 0x54, 0x03, 0xFD, 0xE4, 0xFC, 0xFB, 0xFA,
-0xF9, 0xF8, 0xC3, 0x12, 0x03, 0xDA, 0x70, 0x49,
-0xB1, 0xE4, 0xE4, 0xFF, 0xEE, 0x54, 0xFC, 0xFE,
-0xE4, 0xFD, 0xFC, 0x78, 0x0A, 0x12, 0x03, 0xEB,
-0x90, 0x96, 0x1B, 0xEF, 0xF0, 0x90, 0x95, 0x4C,
-0xE0, 0xFE, 0xEF, 0xD3, 0x9E, 0x50, 0x07, 0x90,
-0x96, 0x1B, 0xE0, 0xB5, 0x06, 0x1F, 0x90, 0x96,
-0x28, 0x74, 0x28, 0xF0, 0x90, 0x96, 0x4A, 0x74,
-0x04, 0xF0, 0x90, 0x96, 0x1B, 0xE0, 0x90, 0x96,
-0x2A, 0xF0, 0x7B, 0x01, 0x7A, 0x96, 0x79, 0x28,
-0x31, 0x9E, 0x12, 0x04, 0x7E, 0xB1, 0xE4, 0xD1,
-0x46, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x96,
-0x24, 0x02, 0x04, 0xB8, 0x90, 0x96, 0x20, 0x02,
-0x04, 0xB8, 0xF0, 0xA3, 0xE0, 0xFF, 0xE4, 0xFC,
-0xFD, 0xFE, 0x78, 0x08, 0x12, 0x03, 0xFE, 0xA8,
-0x04, 0xA9, 0x05, 0xAA, 0x06, 0xAB, 0x07, 0x22,
-0x12, 0x02, 0x06, 0x64, 0x01, 0x70, 0x28, 0x12,
-0x8F, 0x98, 0x90, 0x95, 0x4C, 0xF0, 0x12, 0x87,
-0xF1, 0x90, 0x95, 0x4D, 0xD1, 0x3E, 0xD1, 0x46,
+0x12, 0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
+0x06, 0xC0, 0x07, 0xA3, 0x12, 0x8F, 0xEC, 0x78,
+0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0x90,
+0x96, 0x2A, 0x12, 0x04, 0x31, 0x90, 0x96, 0x2A,
+0x12, 0x86, 0x2D, 0xC0, 0x00, 0xC0, 0x01, 0xC0,
+0x02, 0xC0, 0x03, 0x90, 0x95, 0x51, 0xE0, 0x24,
+0x01, 0xFF, 0xE4, 0x33, 0xFE, 0xE4, 0xFC, 0xFD,
+0xFB, 0x7A, 0x90, 0x79, 0x01, 0xF8, 0x12, 0x85,
+0xC4, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x85, 0xA9, 0x90, 0x96, 0x2A, 0x12,
+0x04, 0x31, 0xB1, 0x62, 0x90, 0x05, 0x2C, 0xEF,
+0xF0, 0xB1, 0x62, 0x78, 0x08, 0x12, 0x03, 0xEB,
+0x90, 0x05, 0x2D, 0xEF, 0xF0, 0xB1, 0x62, 0x78,
+0x10, 0x12, 0x03, 0xEB, 0x90, 0x05, 0x2E, 0xEF,
+0xF0, 0xB1, 0x62, 0x78, 0x18, 0x12, 0x03, 0xEB,
+0x90, 0x05, 0x2F, 0xEF, 0xB1, 0xAE, 0x90, 0x96,
+0x26, 0x12, 0x04, 0x31, 0xB1, 0x68, 0xE4, 0xFF,
+0xFE, 0xED, 0x54, 0x03, 0xFD, 0xE4, 0xFC, 0xFB,
+0xFA, 0xF9, 0xF8, 0xC3, 0x12, 0x03, 0xDA, 0x70,
+0x4C, 0xB1, 0x68, 0xE4, 0xFF, 0xEE, 0x54, 0xFC,
+0xFE, 0xE4, 0xFD, 0xFC, 0x78, 0x0A, 0x12, 0x03,
+0xEB, 0x90, 0x96, 0x21, 0xEF, 0xF0, 0x90, 0x95,
+0x50, 0xE0, 0xFE, 0xEF, 0xD3, 0x9E, 0x50, 0x07,
+0x90, 0x96, 0x21, 0xE0, 0xB5, 0x06, 0x1F, 0x90,
+0x96, 0x2E, 0x74, 0x28, 0xF0, 0x90, 0x96, 0x50,
+0x74, 0x04, 0xF0, 0x90, 0x96, 0x21, 0xE0, 0x90,
+0x96, 0x30, 0xF0, 0x7B, 0x01, 0x7A, 0x96, 0x79,
+0x2E, 0x91, 0x11, 0x12, 0x04, 0x7E, 0xB1, 0x68,
+0xB1, 0xB6, 0x12, 0x79, 0x53, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x96, 0x2A, 0x02, 0x04, 0xB8,
+0x90, 0x96, 0x26, 0x02, 0x04, 0xB8, 0x12, 0x02,
+0x06, 0x64, 0x01, 0x70, 0x2A, 0x12, 0x87, 0x6A,
+0x90, 0x95, 0x50, 0x12, 0x87, 0x96, 0x90, 0x95,
+0x51, 0xB1, 0xAE, 0xB1, 0xB6, 0x12, 0x79, 0x53,
 0x90, 0x01, 0x25, 0x74, 0x08, 0xF0, 0xFD, 0x7F,
 0x01, 0x12, 0x7B, 0xF7, 0x90, 0x05, 0x1F, 0xE0,
-0x54, 0xFC, 0x44, 0x08, 0xF0, 0x81, 0x9E, 0x7D,
+0x54, 0xFC, 0x44, 0x08, 0xF0, 0x81, 0x1E, 0x7D,
 0x08, 0x7F, 0x01, 0x12, 0x7C, 0x2E, 0x90, 0x05,
 0x1F, 0xE0, 0x54, 0xF7, 0xF0, 0x22, 0xF0, 0x7D,
 0x42, 0xE4, 0xFF, 0x02, 0x7B, 0xBD, 0xED, 0x44,
 0x03, 0xFD, 0xEC, 0x90, 0x8B, 0x9F, 0x12, 0x04,
-0x31, 0x7D, 0x42, 0xE4, 0xFF, 0x02, 0x79, 0x53,
-0x7E, 0x00, 0x7F, 0x0B, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0xE7, 0x12, 0x04, 0x80, 0x7B,
-0x01, 0x7A, 0x95, 0x79, 0x4E, 0xD1, 0xEE, 0xBF,
-0x01, 0x1C, 0x90, 0x95, 0x4E, 0xE0, 0xFE, 0x54,
-0x01, 0x90, 0x93, 0xE7, 0xF0, 0xEE, 0x54, 0x04,
-0x90, 0x93, 0xE9, 0xF0, 0x90, 0x95, 0x4E, 0xE0,
-0x54, 0x08, 0x90, 0x93, 0xE8, 0xF0, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x4E, 0x7F, 0xFB, 0x91, 0x00,
-0x70, 0x35, 0x90, 0x95, 0x4E, 0xE0, 0x54, 0x07,
-0x70, 0x15, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x4F,
-0x7F, 0xFA, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
-0x01, 0x0F, 0x90, 0x95, 0x4F, 0x80, 0x03, 0x90,
-0x95, 0x4E, 0xE0, 0x54, 0x07, 0x90, 0x93, 0xEB,
-0xF0, 0x90, 0x95, 0x4E, 0xE0, 0x54, 0xE0, 0xC4,
-0x13, 0x54, 0x07, 0x90, 0x93, 0xEA, 0xF0, 0x7B,
-0x01, 0x7A, 0x95, 0x79, 0x4E, 0x7F, 0xFD, 0x7E,
-0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x0E, 0x90,
-0x95, 0x4E, 0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54,
-0x3F, 0x90, 0x93, 0xEC, 0xF0, 0x22, 0x7F, 0xF9,
-0x7E, 0x01, 0x02, 0x5F, 0xA6, 0x81, 0x9E, 0x25,
-0xE0, 0x25, 0xE0, 0xFE, 0xEF, 0x4E, 0x22, 0x24,
-0xA8, 0xFF, 0xE4, 0x34, 0x01, 0xFE, 0x7B, 0x01,
-0x22, 0xE4, 0x90, 0x86, 0xAF, 0xF0, 0x12, 0xC7,
-0xEA, 0x90, 0x93, 0x01, 0xF0, 0x90, 0x93, 0xF3,
-0xF0, 0xA3, 0xF0, 0x22, 0x12, 0x02, 0x06, 0xFF,
-0x90, 0x93, 0xE6, 0xF0, 0xBF, 0x01, 0x09, 0x7F,
-0x01, 0x31, 0xAB, 0xE4, 0x90, 0x93, 0xE6, 0xF0,
-0x22, 0x7E, 0x00, 0x7F, 0x01, 0x7D, 0x00, 0x7B,
-0x01, 0x7A, 0x88, 0x79, 0x2C, 0x12, 0x04, 0x80,
-0x90, 0x88, 0x2C, 0xE0, 0x54, 0xFD, 0x12, 0xC7,
-0xE8, 0xA3, 0x74, 0x0C, 0xF0, 0x22, 0xF1, 0x8C,
-0x12, 0x7B, 0xDB, 0x90, 0x8A, 0xC5, 0x12, 0x88,
-0xCD, 0x12, 0xDF, 0xD2, 0xF1, 0x31, 0x12, 0xE7,
-0x98, 0xF1, 0x87, 0xF1, 0x9F, 0x90, 0x8A, 0x73,
-0x12, 0x88, 0xCD, 0x90, 0x00, 0x6A, 0xE0, 0x30,
-0xE2, 0x14, 0x90, 0x92, 0x20, 0x74, 0x01, 0xF0,
-0xA3, 0x74, 0xF4, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F,
-0x68, 0x7E, 0x01, 0x12, 0x66, 0x33, 0x22, 0xF1,
-0x92, 0x02, 0x04, 0x80, 0xE4, 0xFD, 0xFF, 0x02,
-0x6E, 0x71, 0x7E, 0x00, 0x7F, 0x04, 0x7D, 0x00,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x3B, 0x22, 0x7E,
-0x00, 0x7F, 0x8E, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x58, 0x02, 0x04, 0x80, 0xE4, 0xFD,
-0x02, 0x8F, 0xF3, 0x90, 0x95, 0xE7, 0xEF, 0xF0,
-0x90, 0x04, 0x7E, 0xE0, 0xFF, 0xA3, 0xE0, 0x90,
-0x96, 0x0B, 0xF0, 0xE0, 0xFE, 0x6F, 0x60, 0x72,
-0x90, 0x95, 0xE8, 0x74, 0x03, 0xF0, 0x90, 0x96,
-0x0A, 0x74, 0x08, 0xF0, 0xEE, 0x04, 0x54, 0x0F,
-0xFF, 0xE4, 0xFE, 0xEF, 0x75, 0xF0, 0x08, 0xA4,
-0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0x80, 0xF5,
-0x83, 0xE5, 0x82, 0x2E, 0x12, 0x9D, 0xD9, 0xE0,
-0xFD, 0x74, 0xEA, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0x95, 0xF5, 0x83, 0xED, 0xF0, 0x0E, 0xEE, 0xB4,
-0x08, 0xD9, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0xE8,
-0x12, 0xC9, 0x9E, 0x12, 0x04, 0x7E, 0x90, 0x96,
-0x0B, 0xE0, 0x04, 0x54, 0x0F, 0xFF, 0xF0, 0xBF,
-0x0F, 0x02, 0xE4, 0xF0, 0x90, 0x96, 0x0B, 0xE0,
-0x90, 0x04, 0x7F, 0xF0, 0x90, 0x95, 0xE7, 0xE0,
-0x70, 0x05, 0x90, 0x8A, 0xE5, 0x80, 0x03, 0x90,
-0x8A, 0x79, 0x12, 0x8E, 0x5A, 0x7F, 0x04, 0x12,
-0x04, 0x7E, 0x22, 0x71, 0xE6, 0x64, 0x01, 0x60,
-0x02, 0x01, 0xC6, 0xEF, 0x24, 0x39, 0x60, 0x12,
-0x14, 0x60, 0x19, 0x24, 0x02, 0x70, 0x1F, 0xE4,
-0x90, 0x95, 0x54, 0xF0, 0xA3, 0x74, 0x06, 0xF0,
-0x80, 0x14, 0x90, 0x95, 0x54, 0x74, 0x06, 0xF0,
-0xA3, 0xF0, 0x80, 0x0A, 0x90, 0x95, 0x54, 0x74,
-0x0C, 0xF0, 0xA3, 0x74, 0x04, 0xF0, 0x11, 0xDA,
-0xF0, 0x11, 0xC7, 0x40, 0x1C, 0x90, 0x95, 0x52,
-0xE0, 0x12, 0xCE, 0xFF, 0x7A, 0x95, 0x79, 0x51,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x07, 0x90, 0x95,
-0x51, 0xE0, 0xF4, 0x70, 0x39, 0x11, 0xCF, 0x80,
-0xE0, 0x11, 0xDA, 0xF0, 0x11, 0xC7, 0x40, 0x2E,
-0x90, 0x95, 0x52, 0xE0, 0xFD, 0x7C, 0x00, 0x24,
-0xA8, 0xFF, 0xEC, 0x34, 0x01, 0xFE, 0xED, 0x24,
-0x01, 0xFD, 0xEC, 0x33, 0xFC, 0x90, 0x95, 0x54,
-0xE0, 0xFB, 0xC3, 0xED, 0x9B, 0xFD, 0xEC, 0x94,
-0x00, 0xFC, 0x90, 0x95, 0x4E, 0x11, 0xF7, 0xFD,
-0x91, 0xDA, 0x11, 0xCF, 0x80, 0xCE, 0x22, 0x90,
-0x95, 0x53, 0xE0, 0xD3, 0x94, 0x00, 0x22, 0x90,
-0x95, 0x52, 0xE0, 0x04, 0xF0, 0xA3, 0xE0, 0x14,
-0xF0, 0x22, 0x90, 0x95, 0x54, 0xE0, 0x90, 0x95,
-0x52, 0xF0, 0x90, 0x95, 0x55, 0xE0, 0x90, 0x95,
-0x53, 0x22, 0x7E, 0x00, 0xC3, 0x74, 0x07, 0x9F,
-0xFD, 0xE4, 0x9E, 0xFC, 0x90, 0x96, 0x10, 0x12,
-0x86, 0x39, 0x8D, 0x82, 0x8C, 0x83, 0x02, 0x02,
-0x1F, 0x71, 0x9E, 0x90, 0x96, 0x13, 0xF0, 0x90,
-0x96, 0x13, 0xE0, 0xFF, 0xC3, 0x94, 0x08, 0x50,
-0x2B, 0x11, 0xEA, 0xFD, 0xC3, 0x74, 0x07, 0x51,
-0x70, 0xC3, 0x9D, 0x50, 0x03, 0x7F, 0x00, 0x22,
-0x90, 0x96, 0x13, 0xE0, 0xFF, 0x11, 0xEA, 0xFD,
-0xC3, 0x74, 0x07, 0x51, 0x70, 0xD3, 0x9D, 0x40,
-0x03, 0x7F, 0x01, 0x22, 0x90, 0x96, 0x13, 0xE0,
-0x04, 0xF0, 0x80, 0xCB, 0x7F, 0x00, 0x22, 0xE4,
-0x90, 0x96, 0x0C, 0xF0, 0x90, 0x93, 0x03, 0xE0,
-0xFF, 0xC3, 0x13, 0x20, 0xE0, 0x70, 0x31, 0xF8,
-0x31, 0x01, 0xEF, 0x60, 0x0D, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x13, 0x31, 0xFE, 0x51, 0x09, 0xEF,
-0x60, 0x54, 0x31, 0xF8, 0x31, 0x01, 0xEF, 0x60,
-0x17, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x13, 0x31,
-0xFE, 0x51, 0x09, 0xEF, 0x60, 0x0A, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0x1C, 0x71, 0x90, 0x70, 0x36,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x20, 0x90, 0x96,
-0x10, 0x12, 0x86, 0x42, 0x7A, 0x93, 0x79, 0x06,
-0x31, 0x01, 0xEF, 0x60, 0x10, 0x51, 0x1C, 0x31,
-0xFE, 0x31, 0x01, 0xEF, 0x60, 0x07, 0x31, 0xF8,
-0x71, 0xA6, 0xEF, 0x70, 0x11, 0x31, 0xF8, 0x51,
-0x09, 0xEF, 0x60, 0x29, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x0F, 0x71, 0x90, 0x60, 0x1F, 0x90, 0x96,
-0x0C, 0x74, 0x01, 0xF0, 0x80, 0x17, 0x51, 0x1C,
-0x31, 0xFE, 0x31, 0x01, 0xEF, 0x60, 0x0E, 0x51,
-0x1C, 0x31, 0xFE, 0x71, 0xA6, 0xEF, 0x70, 0x05,
-0x90, 0x96, 0x0C, 0x04, 0xF0, 0x90, 0x96, 0x0C,
-0xE0, 0xFF, 0x90, 0x05, 0x18, 0xE4, 0xF0, 0xA3,
-0xF0, 0xEF, 0x90, 0x05, 0xB3, 0x60, 0x0C, 0xE0,
-0x44, 0x80, 0xF0, 0x90, 0x24, 0xA0, 0xE0, 0x44,
-0x01, 0xF0, 0x22, 0xE0, 0x44, 0x20, 0xF0, 0x22,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x06, 0x90, 0x96,
-0x10, 0x12, 0x86, 0x42, 0x7A, 0x93, 0x79, 0x20,
-0x22, 0x71, 0x9E, 0xFF, 0x71, 0xB9, 0x6E, 0x60,
-0x03, 0x7F, 0x00, 0x22, 0x0F, 0xEF, 0xB4, 0x08,
-0xF3, 0x7F, 0x01, 0x22, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x2D, 0x22, 0x71, 0x9E, 0x90, 0x96, 0x13,
-0xF0, 0x90, 0x96, 0x13, 0xE0, 0xFF, 0xC3, 0x94,
-0x04, 0x50, 0x1F, 0x51, 0x55, 0xC3, 0x9D, 0x50,
-0x03, 0x7F, 0x00, 0x22, 0x90, 0x96, 0x13, 0xE0,
-0xFF, 0x51, 0x55, 0xD3, 0x9D, 0x40, 0x03, 0x7F,
-0x01, 0x22, 0x90, 0x96, 0x13, 0xE0, 0x04, 0xF0,
-0x80, 0xD7, 0x7F, 0x00, 0x22, 0x7E, 0x00, 0xC3,
-0x74, 0x03, 0x9F, 0xFD, 0xE4, 0x9E, 0xFC, 0x90,
-0x96, 0x10, 0x12, 0x86, 0x39, 0x8D, 0x82, 0x8C,
-0x83, 0x12, 0x02, 0x1F, 0xFD, 0xC3, 0x74, 0x03,
-0x9F, 0xFF, 0xE4, 0x9E, 0xFE, 0x90, 0x96, 0x0D,
-0x12, 0x86, 0x39, 0x8F, 0x82, 0x8E, 0x83, 0x02,
-0x02, 0x1F, 0xE4, 0x90, 0x96, 0x10, 0xF0, 0xEF,
-0x75, 0xF0, 0x40, 0xA4, 0x24, 0x80, 0xF9, 0x74,
-0x82, 0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x90, 0x96,
-0x0C, 0x71, 0xE9, 0x90, 0x96, 0x0F, 0xF0, 0xA3,
-0x74, 0x1C, 0xF0, 0x90, 0x96, 0x0F, 0xE0, 0xFF,
-0xA3, 0xE0, 0xFE, 0xC3, 0x9F, 0x40, 0x02, 0x61,
-0x84, 0x90, 0x96, 0x0C, 0x12, 0x86, 0x39, 0x8E,
-0x82, 0x71, 0xD0, 0x90, 0x96, 0x11, 0xF0, 0xEE,
-0xFD, 0x7C, 0x00, 0xF5, 0x82, 0x8C, 0x83, 0xA3,
-0xA3, 0x12, 0x02, 0x1F, 0xFE, 0x8D, 0x82, 0x8C,
-0x83, 0xA3, 0x12, 0x02, 0x1F, 0xFD, 0xED, 0xFF,
-0x90, 0x96, 0x12, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x96, 0x11, 0xE0, 0x64, 0x01, 0x60, 0x0E,
-0xA3, 0xA3, 0xE0, 0x24, 0x03, 0xFF, 0x90, 0x96,
-0x10, 0xE0, 0x2F, 0xF0, 0x80, 0xAD, 0xE4, 0x90,
-0x96, 0x14, 0xF0, 0x90, 0x96, 0x14, 0xE0, 0xFF,
-0xC3, 0x94, 0x08, 0x50, 0x1A, 0x90, 0x96, 0x10,
-0xE0, 0x24, 0x03, 0x71, 0xD6, 0x51, 0x78, 0xFF,
-0x90, 0x96, 0x14, 0xE0, 0x24, 0x20, 0xF5, 0x82,
-0xE4, 0x34, 0x93, 0x71, 0x85, 0x80, 0xDC, 0x90,
-0x96, 0x10, 0xE0, 0x24, 0x0B, 0xFF, 0xE4, 0x33,
-0xFE, 0x90, 0x96, 0x0C, 0x51, 0x78, 0x90, 0x93,
-0x28, 0xF0, 0x70, 0x27, 0x90, 0x96, 0x14, 0xF0,
-0x90, 0x96, 0x14, 0xE0, 0xFF, 0x24, 0x10, 0xFD,
-0xE4, 0x33, 0xFC, 0x90, 0x96, 0x0C, 0x11, 0xF7,
-0xFE, 0x74, 0x29, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF5, 0x83, 0xEE, 0x71, 0x88, 0xE0, 0xB4,
-0x04, 0xDE, 0x22, 0xE4, 0x90, 0x96, 0x14, 0xF0,
-0x90, 0x96, 0x14, 0xE0, 0xFF, 0xC3, 0x94, 0x04,
-0x50, 0x1A, 0x90, 0x96, 0x10, 0xE0, 0x24, 0x0C,
-0x71, 0xD6, 0x51, 0x78, 0xFF, 0x90, 0x96, 0x14,
-0xE0, 0x24, 0x29, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0x71, 0x85, 0x80, 0xDC, 0x22, 0xF5, 0x83, 0xEF,
-0xF0, 0x90, 0x96, 0x14, 0xE0, 0x04, 0xF0, 0x22,
-0x90, 0x96, 0x10, 0x12, 0x86, 0x42, 0x7A, 0x93,
-0x79, 0x29, 0x51, 0x23, 0xEF, 0x22, 0x90, 0x96,
-0x0D, 0x12, 0x86, 0x42, 0xE4, 0x22, 0x71, 0x9E,
-0xFF, 0x71, 0xB9, 0x6E, 0x60, 0x03, 0x7F, 0x00,
-0x22, 0x0F, 0xEF, 0xB4, 0x06, 0xF3, 0x7F, 0x01,
-0x22, 0x90, 0x96, 0x10, 0x12, 0x86, 0x39, 0x8F,
-0x82, 0x75, 0x83, 0x00, 0x12, 0x02, 0x1F, 0xFE,
-0x90, 0x96, 0x0D, 0x12, 0x86, 0x39, 0x8F, 0x82,
-0x75, 0x83, 0x00, 0x02, 0x02, 0x1F, 0xFD, 0xE4,
-0x33, 0xFC, 0x7E, 0x00, 0xED, 0x2F, 0xFF, 0xEE,
-0x3C, 0xFE, 0x90, 0x96, 0x0C, 0x22, 0x90, 0x95,
-0x4E, 0x12, 0x86, 0x42, 0x02, 0x02, 0x06, 0xEF,
-0x70, 0x05, 0x90, 0x93, 0x05, 0x80, 0x03, 0x90,
-0x93, 0x04, 0xE0, 0xFF, 0x12, 0x7B, 0x07, 0x90,
-0x95, 0xE7, 0xEF, 0xF0, 0x90, 0x95, 0xE7, 0xE0,
-0x24, 0x38, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B,
-0x01, 0xA3, 0x12, 0x86, 0x42, 0xE4, 0xFF, 0x74,
-0x08, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x07, 0xF5,
-0x83, 0xE0, 0xFE, 0x91, 0x99, 0x8F, 0x82, 0x75,
-0x83, 0x00, 0x91, 0xAD, 0xB4, 0x06, 0xE8, 0x90,
-0x95, 0xE7, 0xE0, 0x24, 0x52, 0xF9, 0xE4, 0x34,
-0xFC, 0xFA, 0x7B, 0x01, 0xA3, 0x71, 0xE9, 0x70,
-0x57, 0x90, 0x95, 0xE8, 0x12, 0x8F, 0x95, 0x64,
-0x02, 0x70, 0x4D, 0x90, 0x24, 0x87, 0xE0, 0x90,
-0x00, 0x03, 0x12, 0x02, 0x5E, 0x90, 0x24, 0x86,
-0xE0, 0x90, 0x00, 0x04, 0x12, 0x02, 0x5E, 0x91,
-0x99, 0x12, 0x87, 0x67, 0x64, 0x01, 0x70, 0x30,
-0x12, 0x87, 0xF8, 0x64, 0x0D, 0x70, 0x29, 0xFF,
-0x74, 0x88, 0x12, 0xC7, 0x84, 0xEF, 0x24, 0x08,
-0x91, 0x9F, 0xB4, 0x08, 0xF3, 0x90, 0x05, 0xDC,
-0xE0, 0xFF, 0x91, 0x99, 0x90, 0x00, 0x10, 0xEF,
-0x12, 0x02, 0x5E, 0xE4, 0xFF, 0x12, 0xC7, 0x82,
-0xEF, 0x24, 0x11, 0x91, 0x9F, 0xB4, 0x04, 0xF5,
-0x22, 0x90, 0x95, 0xE8, 0x02, 0x86, 0x39, 0xFD,
-0xE4, 0x33, 0xFC, 0x90, 0x95, 0xE8, 0x12, 0x86,
-0x39, 0x8D, 0x82, 0x8C, 0x83, 0xEE, 0x12, 0x02,
-0x5E, 0x0F, 0xEF, 0x22, 0x90, 0x93, 0x03, 0xE0,
-0x30, 0xE0, 0x1E, 0xE4, 0xFF, 0xB1, 0x34, 0xE4,
-0xFF, 0x71, 0xEF, 0x7F, 0x01, 0x71, 0xEF, 0x90,
-0x93, 0x03, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30,
-0xE0, 0x07, 0x90, 0x04, 0x1F, 0xE0, 0x44, 0x80,
-0xF0, 0x22, 0xE4, 0x90, 0x95, 0x56, 0xF0, 0x90,
-0x00, 0x37, 0xE0, 0x44, 0x80, 0xF0, 0x90, 0x00,
-0xCF, 0x74, 0x69, 0xF0, 0xEF, 0x90, 0x00, 0x31,
-0xF0, 0xEE, 0x54, 0x03, 0xFF, 0xA3, 0xE0, 0x54,
-0xFC, 0x4F, 0xF0, 0x90, 0x00, 0x30, 0xED, 0xF0,
-0x90, 0x00, 0x33, 0xE0, 0x44, 0x80, 0xF0, 0x90,
-0x00, 0x33, 0xE0, 0x30, 0xE7, 0x09, 0xB1, 0x2C,
-0x50, 0x05, 0xE0, 0x04, 0xF0, 0x80, 0xF0, 0x90,
-0x00, 0xCF, 0xE4, 0xF0, 0x90, 0x00, 0x37, 0xE0,
-0x54, 0x7F, 0xF0, 0xB1, 0x2C, 0x7F, 0x00, 0x50,
-0x02, 0x7F, 0x01, 0x22, 0x90, 0x95, 0x56, 0xE0,
-0xC3, 0x94, 0x64, 0x22, 0x90, 0x95, 0xE9, 0xEF,
-0xF0, 0x90, 0x95, 0xE7, 0x74, 0x18, 0xF0, 0x90,
-0x96, 0x09, 0x74, 0x01, 0xF0, 0xFB, 0x7A, 0x95,
-0x79, 0xE7, 0x12, 0x8E, 0x48, 0x7F, 0x04, 0x02,
-0x04, 0x7E, 0x90, 0x93, 0x03, 0xE0, 0x30, 0xE0,
-0x04, 0x7F, 0x01, 0xB1, 0x34, 0x22, 0xC0, 0xE0,
-0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0,
-0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0,
-0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x5E,
-0xF0, 0x74, 0xD5, 0xA3, 0xF0, 0x12, 0x64, 0x7F,
-0xE5, 0x30, 0x30, 0xE1, 0x03, 0x12, 0xDF, 0x91,
-0xE5, 0x2D, 0x30, 0xE1, 0x02, 0xF1, 0xB2, 0xE5,
-0x2D, 0x30, 0xE4, 0x03, 0x12, 0xE2, 0x23, 0xE5,
-0x2D, 0x30, 0xE5, 0x03, 0x12, 0xE2, 0x34, 0xE5,
-0x2D, 0x30, 0xE6, 0x03, 0x12, 0xDD, 0xEE, 0xE5,
-0x2F, 0x30, 0xE0, 0x03, 0x12, 0xB6, 0x44, 0xE5,
-0x2F, 0x30, 0xE1, 0x03, 0x12, 0xDD, 0xFB, 0xE5,
-0x2F, 0x30, 0xE2, 0x03, 0x12, 0xDF, 0x13, 0xE5,
-0x2F, 0x30, 0xE3, 0x03, 0x12, 0xDF, 0x36, 0xE5,
-0x2F, 0x30, 0xE4, 0x03, 0x12, 0xB5, 0xAC, 0xE5,
-0x2F, 0x30, 0xE5, 0x03, 0x12, 0xDF, 0x4F, 0xE5,
-0x2F, 0x30, 0xE6, 0x03, 0x12, 0xDF, 0x71, 0xE5,
-0x30, 0x30, 0xE4, 0x02, 0xD1, 0x47, 0xE5, 0x30,
-0x30, 0xE5, 0x02, 0xF1, 0xB7, 0xE5, 0x36, 0x30,
-0xE3, 0x03, 0x12, 0xCE, 0xF5, 0xE5, 0x36, 0x30,
-0xE0, 0x03, 0x12, 0xC6, 0x84, 0xE5, 0x36, 0x30,
-0xE6, 0x02, 0x91, 0xB4, 0xE5, 0x36, 0x30, 0xE7,
-0x02, 0xB1, 0x52, 0xE5, 0x37, 0x30, 0xE2, 0x02,
-0xF1, 0x8D, 0xE5, 0x37, 0x30, 0xE3, 0x02, 0xF1,
-0x99, 0x74, 0x5E, 0x04, 0x90, 0x01, 0xC4, 0xF0,
-0x74, 0xD5, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
-0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
-0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0xE4,
-0xFF, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x96, 0xBB, 0xEF, 0xF0, 0x90, 0x88, 0x2B,
-0xE0, 0x90, 0x96, 0xCD, 0xF0, 0xE4, 0x90, 0x96,
-0xBC, 0xF0, 0x90, 0x96, 0xCD, 0xE0, 0xFE, 0x90,
-0x96, 0xBC, 0xE0, 0xFF, 0xC3, 0x9E, 0x50, 0x2C,
-0xE0, 0xFE, 0xF1, 0x6B, 0xE4, 0xF0, 0xEE, 0x12,
-0xEA, 0xDD, 0xE0, 0x30, 0xE7, 0x0A, 0x75, 0xF0,
-0x12, 0xEF, 0xF1, 0x75, 0xE4, 0xF0, 0x80, 0x0C,
-0x12, 0x7C, 0x8F, 0x90, 0x96, 0xBC, 0xE0, 0xF1,
-0x6B, 0x74, 0x01, 0xF0, 0x90, 0x96, 0xBC, 0xE0,
-0x04, 0xF0, 0x80, 0xC6, 0x7F, 0x0C, 0x7E, 0x00,
-0x12, 0x7C, 0x6A, 0xE4, 0x90, 0x96, 0xBC, 0xF0,
-0x90, 0x96, 0xCD, 0xE0, 0xFF, 0x90, 0x96, 0xBC,
-0xE0, 0xFE, 0xC3, 0x9F, 0x40, 0x02, 0xE1, 0x66,
-0x74, 0xBD, 0x2E, 0xF1, 0x6D, 0xE0, 0x70, 0x02,
-0xE1, 0x5E, 0xEE, 0xC4, 0x54, 0xF0, 0x24, 0x06,
-0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0,
-0xFD, 0xEE, 0xC4, 0x54, 0xF0, 0x24, 0x07, 0xF5,
-0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xF1, 0x7B,
-0xFC, 0x75, 0xF0, 0x12, 0x90, 0x89, 0x53, 0xF1,
-0x84, 0xEC, 0xC4, 0x54, 0xF0, 0x24, 0x0A, 0xF5,
-0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0, 0xFD,
-0xEC, 0xF1, 0xA5, 0xF1, 0x7B, 0x75, 0xF0, 0x12,
-0x90, 0x89, 0x57, 0xF1, 0x84, 0x7F, 0x01, 0x90,
-0x96, 0xBC, 0xE0, 0xFE, 0xF1, 0xA5, 0xE5, 0x82,
-0x2F, 0x12, 0x9D, 0xD9, 0xE0, 0xFD, 0x75, 0xF0,
-0x12, 0xEE, 0x90, 0x89, 0x57, 0x12, 0x04, 0x6E,
-0x75, 0xF0, 0x02, 0xEF, 0x12, 0x93, 0x99, 0xED,
-0xF0, 0x0F, 0xEF, 0xB4, 0x05, 0xD9, 0x90, 0x96,
-0xBC, 0xE0, 0xFF, 0xC4, 0x54, 0xF0, 0x24, 0x09,
-0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0,
-0xFE, 0xF1, 0xC7, 0xEE, 0xF0, 0x90, 0x96, 0xBC,
-0xE0, 0xFF, 0x90, 0x96, 0xBB, 0xE0, 0xFD, 0x12,
-0x61, 0xF7, 0x90, 0x96, 0xBC, 0xE0, 0x75, 0xF0,
-0x12, 0xF1, 0x75, 0x74, 0x01, 0xF0, 0x90, 0x96,
-0xBC, 0xE0, 0x04, 0xF0, 0xC1, 0xA8, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x24, 0xBD, 0xF5, 0x82, 0xE4,
-0x34, 0x96, 0xF5, 0x83, 0x22, 0x90, 0x89, 0x56,
-0x02, 0x04, 0x6E, 0xE0, 0xFE, 0xED, 0xFF, 0x90,
-0x96, 0xBC, 0xE0, 0x22, 0x12, 0x04, 0x6E, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x90, 0x93, 0x03,
-0xE0, 0x30, 0xE0, 0x04, 0x7F, 0x02, 0xB1, 0x34,
-0x22, 0x90, 0x93, 0x03, 0xE0, 0x30, 0xE0, 0x04,
-0x7F, 0x03, 0xB1, 0x34, 0x22, 0xC4, 0x54, 0xF0,
-0x24, 0x0B, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
-0x83, 0x22, 0xE4, 0xFF, 0x02, 0xCF, 0xB3, 0x90,
-0x8A, 0xDF, 0xF1, 0xBF, 0x02, 0x04, 0x7A, 0xE0,
-0xFE, 0xA3, 0xE0, 0xAA, 0x06, 0xF9, 0x22, 0x75,
-0xF0, 0x12, 0xEF, 0x90, 0x89, 0x55, 0x02, 0x04,
-0x6E, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x01, 0xCC, 0xE0, 0x54, 0x0F, 0xFD, 0xED,
-0x70, 0x03, 0x02, 0xD8, 0xCA, 0x90, 0x87, 0x0B,
+0x31, 0x7D, 0x42, 0xE4, 0xFF, 0x22, 0x90, 0x95,
+0xED, 0xEF, 0xF0, 0x90, 0x04, 0x7E, 0xE0, 0xFF,
+0xA3, 0xE0, 0x90, 0x96, 0x11, 0xF0, 0xE0, 0xFE,
+0x6F, 0x60, 0x70, 0x90, 0x95, 0xEE, 0x74, 0x03,
+0xF0, 0x90, 0x96, 0x10, 0x74, 0x08, 0xF0, 0xEE,
+0x04, 0x54, 0x0F, 0xFF, 0xE4, 0xFE, 0xEF, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x00, 0xF5, 0x82, 0xE4,
+0x34, 0x80, 0xF5, 0x83, 0xE5, 0x82, 0x2E, 0xD1,
+0x52, 0xE0, 0xFD, 0x74, 0xF0, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x95, 0xF5, 0x83, 0xED, 0xF0, 0x0E,
+0xEE, 0xB4, 0x08, 0xDA, 0x7B, 0x01, 0x7A, 0x95,
+0x79, 0xEE, 0x91, 0x11, 0x12, 0x04, 0x7E, 0x90,
+0x96, 0x11, 0xE0, 0x04, 0x54, 0x0F, 0xFF, 0xF0,
+0xBF, 0x0F, 0x02, 0xE4, 0xF0, 0x90, 0x96, 0x11,
+0xE0, 0x90, 0x04, 0x7F, 0xF0, 0x90, 0x95, 0xED,
+0xE0, 0x70, 0x05, 0x90, 0x8A, 0xE5, 0x80, 0x03,
+0x90, 0x8A, 0x79, 0x12, 0x90, 0x4B, 0x7F, 0x04,
+0x12, 0x04, 0x7E, 0x22, 0x12, 0x04, 0x6E, 0xE5,
+0x82, 0x2C, 0xF5, 0x82, 0xE4, 0x35, 0x83, 0xF5,
+0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x01, 0xCC, 0xE0, 0x54, 0x0F, 0xFD,
+0xED, 0x70, 0x02, 0xE1, 0x45, 0x90, 0x87, 0x0B,
 0xE0, 0xFF, 0x70, 0x06, 0xA3, 0xE0, 0x64, 0x09,
 0x60, 0x0A, 0xEF, 0x14, 0xFF, 0x90, 0x87, 0x0C,
 0xE0, 0xB5, 0x07, 0x04, 0x7F, 0x01, 0x80, 0x02,
 0x7F, 0x00, 0xEF, 0x60, 0x09, 0x90, 0x01, 0xC1,
-0xE0, 0x44, 0x01, 0xF0, 0x01, 0xCA, 0x90, 0x97,
-0x40, 0xE0, 0xFF, 0x12, 0xC2, 0x9F, 0x80, 0x05,
-0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF,
-0xED, 0xFB, 0xEF, 0x5B, 0x70, 0x02, 0x01, 0xAD,
-0xE4, 0xFC, 0x11, 0xD0, 0xA4, 0xFF, 0xEC, 0x7A,
-0x00, 0x2F, 0xFF, 0xEA, 0x35, 0xF0, 0xFE, 0x74,
-0xD0, 0x11, 0xE3, 0x90, 0x87, 0x0C, 0xE0, 0xF9,
-0x75, 0xF0, 0x08, 0x90, 0x86, 0xBB, 0x12, 0x04,
-0x6E, 0x12, 0x9D, 0xD6, 0xEF, 0x11, 0xCF, 0xA4,
-0xFF, 0xEC, 0x2F, 0xFF, 0xEA, 0x35, 0xF0, 0xFE,
-0x74, 0xF0, 0x11, 0xE3, 0x75, 0xF0, 0x08, 0xE9,
-0x90, 0x86, 0xBF, 0x12, 0x04, 0x6E, 0x12, 0x9D,
-0xD6, 0xEF, 0xF0, 0x0C, 0xEC, 0xB4, 0x04, 0xBA,
-0x11, 0xD8, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
-0xF4, 0x5D, 0xFD, 0x11, 0xD8, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0x90, 0x01, 0xCC, 0xF0, 0x90,
-0x97, 0x40, 0xE0, 0x04, 0xF0, 0xE0, 0x54, 0x03,
-0xF0, 0x90, 0x87, 0x0C, 0xE0, 0x04, 0xF0, 0xE0,
-0x7F, 0x00, 0xB4, 0x0A, 0x02, 0x7F, 0x01, 0xEF,
-0x70, 0x03, 0x02, 0xD7, 0xDF, 0xE4, 0x90, 0x87,
-0x0C, 0xF0, 0x02, 0xD7, 0xDF, 0x90, 0x01, 0xC0,
-0xE0, 0x44, 0x02, 0xF0, 0x90, 0x97, 0x40, 0xE0,
-0x44, 0x80, 0x90, 0x00, 0x8A, 0x11, 0xCF, 0x90,
-0x01, 0xD0, 0x12, 0x04, 0x6E, 0xE0, 0x90, 0x01,
-0xC3, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0,
-0x90, 0x97, 0x40, 0xE0, 0x75, 0xF0, 0x04, 0x22,
-0x90, 0x97, 0x40, 0xE0, 0xFF, 0x74, 0x01, 0xA8,
-0x07, 0x08, 0x22, 0x2F, 0xF5, 0x82, 0x74, 0x01,
-0x3E, 0xF5, 0x83, 0xE0, 0xFF, 0x22, 0x75, 0x21,
-0x80, 0xE4, 0xF5, 0x22, 0xF5, 0x23, 0x75, 0x24,
-0x80, 0x90, 0x00, 0x50, 0xE5, 0x21, 0xF0, 0xA3,
-0xE5, 0x22, 0xF0, 0xA3, 0xE5, 0x23, 0xF0, 0xA3,
-0xE5, 0x24, 0xF0, 0x22, 0x12, 0xC7, 0xCC, 0x12,
-0x76, 0x6D, 0x12, 0x75, 0xE0, 0x31, 0x63, 0x31,
-0x35, 0x80, 0xD3, 0x12, 0x7B, 0x1B, 0x90, 0x86,
-0xB3, 0xEF, 0xF0, 0x31, 0x0C, 0x90, 0x01, 0x64,
-0x74, 0x01, 0xF0, 0x90, 0x04, 0x23, 0xE0, 0x44,
-0x80, 0xF0, 0x02, 0x67, 0xD2, 0x75, 0x39, 0x07,
-0x43, 0x39, 0x10, 0x75, 0x3A, 0x01, 0x43, 0x3A,
-0x08, 0x43, 0x3A, 0x10, 0x75, 0x3B, 0x03, 0x75,
-0x3C, 0x62, 0x43, 0x3C, 0x80, 0x43, 0x3B, 0x04,
-0x90, 0x01, 0x38, 0xE5, 0x39, 0xF0, 0xA3, 0xE5,
-0x3A, 0xF0, 0xA3, 0xE5, 0x3B, 0xF0, 0xA3, 0xE5,
-0x3C, 0xF0, 0x22, 0x75, 0x29, 0x12, 0xE4, 0xF5,
-0x2A, 0x75, 0x2B, 0x07, 0x75, 0x2C, 0x32, 0xF5,
-0x31, 0x75, 0x32, 0xC1, 0x75, 0x33, 0x0C, 0xF5,
-0x34, 0x90, 0x01, 0x30, 0xE5, 0x29, 0xF0, 0xA3,
-0xE5, 0x2A, 0xF0, 0xA3, 0xE5, 0x2B, 0xF0, 0xA3,
-0xE5, 0x2C, 0xF0, 0x90, 0x01, 0x20, 0xE5, 0x31,
-0xF0, 0xA3, 0xE5, 0x32, 0xF0, 0xA3, 0xE5, 0x33,
-0xF0, 0xA3, 0xE5, 0x34, 0xF0, 0x22, 0x90, 0x01,
-0xE4, 0x74, 0x27, 0xF0, 0xA3, 0xE4, 0xF0, 0x22,
-0x7D, 0x02, 0x90, 0x01, 0xC4, 0x74, 0xA8, 0xF0,
-0x74, 0xD9, 0xA3, 0xF0, 0x90, 0x93, 0x57, 0xE0,
-0xFF, 0xED, 0xC3, 0x9F, 0x50, 0x18, 0xED, 0x25,
-0xE0, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE4, 0x0B,
-0x90, 0x01, 0xB8, 0x74, 0x08, 0xF0, 0xA3, 0xF0,
-0x7F, 0x00, 0x22, 0x0D, 0x80, 0xDE, 0x74, 0xA8,
-0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xD9, 0xA3,
-0xF0, 0x7F, 0x01, 0x22, 0xE4, 0x90, 0x95, 0xA6,
-0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x95, 0xA6,
-0xE0, 0x64, 0x01, 0xF0, 0x90, 0x93, 0xF0, 0xE0,
-0x70, 0x18, 0x90, 0x93, 0xED, 0xE0, 0x70, 0x12,
-0xA3, 0xE0, 0x70, 0x0E, 0x90, 0x95, 0xA6, 0xE0,
-0x24, 0xE4, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xD9,
-0xA3, 0xF0, 0x12, 0x7C, 0x54, 0xBF, 0x01, 0x03,
-0x12, 0x54, 0x9F, 0x90, 0x88, 0x36, 0xE0, 0x60,
-0x0F, 0x90, 0x88, 0x39, 0xE0, 0xFF, 0x90, 0x88,
-0x38, 0xE0, 0x6F, 0x60, 0x03, 0x12, 0xAF, 0x06,
-0xC2, 0xAF, 0x31, 0xA8, 0xBF, 0x01, 0x03, 0x12,
-0xC5, 0xB9, 0xD2, 0xAF, 0x51, 0x46, 0x12, 0x9F,
-0xF2, 0x12, 0x83, 0x4D, 0x80, 0xA7, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x93, 0xED,
-0xE0, 0x60, 0x24, 0x7F, 0x54, 0x7E, 0x09, 0x12,
-0x70, 0x70, 0x51, 0xF2, 0x12, 0x04, 0xB8, 0xEF,
-0x44, 0xFE, 0xFF, 0xEE, 0x44, 0x03, 0xFE, 0xED,
-0x44, 0x04, 0xFD, 0xEC, 0x51, 0xF2, 0x51, 0xFC,
-0x7F, 0x54, 0x7E, 0x09, 0x12, 0x70, 0xAD, 0x90,
-0x93, 0xE8, 0xE0, 0x70, 0x29, 0x90, 0x07, 0xCC,
-0xE0, 0x30, 0xE0, 0x22, 0xE4, 0xF0, 0x90, 0x95,
-0xAD, 0x74, 0x22, 0xF0, 0x90, 0x95, 0xCF, 0x74,
-0x01, 0xF0, 0x90, 0x95, 0xAF, 0x74, 0x03, 0xF0,
-0x7B, 0x01, 0x7A, 0x95, 0x79, 0xAD, 0x12, 0x8E,
-0x48, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x90, 0x93,
-0xF0, 0xE0, 0xFF, 0x70, 0x0A, 0x90, 0x93, 0xED,
-0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x60, 0x15, 0x90,
-0x00, 0x1F, 0xE0, 0x54, 0xF0, 0xF0, 0x90, 0x01,
-0xC5, 0x74, 0xEA, 0xF0, 0xA3, 0x74, 0xEF, 0xF0,
-0xA3, 0x74, 0xFD, 0xF0, 0xEF, 0x60, 0x06, 0x90,
-0x01, 0xC4, 0x74, 0x07, 0xF0, 0x90, 0x93, 0xED,
-0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x01,
-0xF0, 0x90, 0x93, 0xEE, 0xE0, 0x60, 0x06, 0x90,
-0x01, 0xC4, 0x74, 0x02, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x90, 0x95, 0xA9, 0x12, 0x04, 0x31,
-0x90, 0x95, 0xA9, 0x22, 0x12, 0x04, 0xB8, 0x90,
-0x92, 0x18, 0x02, 0x04, 0x31, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x71, 0x41, 0x90, 0x97,
-0x1D, 0x12, 0x04, 0x31, 0x90, 0x97, 0x1D, 0x51,
-0xFC, 0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70, 0xAD,
-0x90, 0x01, 0x01, 0xE0, 0x44, 0x02, 0xF0, 0x90,
-0x01, 0x00, 0x74, 0xFF, 0xF0, 0x90, 0x06, 0xB7,
-0x74, 0x09, 0xF0, 0x90, 0x06, 0xB4, 0x74, 0x86,
-0xF0, 0x12, 0xAF, 0xD6, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70, 0x70,
-0xED, 0x44, 0x80, 0xFD, 0xEC, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x71, 0x41, 0x90,
-0x97, 0x21, 0x12, 0x04, 0x31, 0x90, 0x97, 0x21,
-0x51, 0xFC, 0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70,
-0xAD, 0x12, 0x88, 0xCA, 0x90, 0x06, 0xB7, 0x74,
-0x11, 0xF0, 0x7F, 0x03, 0x7E, 0x00, 0x12, 0x7C,
-0x6A, 0x90, 0x06, 0xB4, 0xE0, 0x54, 0x0F, 0x70,
-0xF1, 0x90, 0x07, 0xD5, 0xE0, 0x44, 0x80, 0xF0,
-0x7F, 0x0A, 0x80, 0x09, 0x90, 0x06, 0x62, 0xE0,
-0x30, 0xE0, 0x09, 0x7F, 0x01, 0x7E, 0x00, 0x12,
-0x7C, 0x6A, 0x80, 0xF0, 0x71, 0xBC, 0x90, 0x01,
-0x00, 0x74, 0x3F, 0xF0, 0xA3, 0xE0, 0x54, 0xFD,
-0xF0, 0x90, 0x05, 0x53, 0xE0, 0x44, 0x20, 0xF0,
-0x90, 0x07, 0xD5, 0xE0, 0x54, 0x7F, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x00, 0x02, 0xE0,
-0x54, 0xFE, 0xF0, 0x22, 0x90, 0x8A, 0x79, 0x74,
-0x87, 0xF0, 0xA3, 0x74, 0x03, 0xF0, 0x90, 0x8A,
-0xE5, 0x74, 0xDD, 0xF0, 0xA3, 0x74, 0x58, 0xF0,
-0x90, 0x8B, 0x03, 0x74, 0x8C, 0xF0, 0xA3, 0x74,
-0xC2, 0xF0, 0x90, 0x8A, 0xB9, 0x74, 0x88, 0xF0,
-0xA3, 0x74, 0xD7, 0xF0, 0x90, 0x8A, 0xD5, 0x74,
-0x91, 0xF0, 0xA3, 0x74, 0xE6, 0xF0, 0x90, 0x8A,
-0xFB, 0x74, 0x90, 0xF0, 0xA3, 0x74, 0x49, 0xF0,
-0x90, 0x8A, 0xA5, 0x74, 0x9B, 0xF0, 0xA3, 0x74,
-0xF3, 0xF0, 0x90, 0x8A, 0xB5, 0x74, 0x87, 0xF0,
-0xA3, 0x74, 0xA5, 0xF0, 0x90, 0x8A, 0x75, 0x74,
-0xD7, 0xF0, 0xA3, 0x74, 0xD1, 0xF0, 0x90, 0x8A,
-0xC1, 0x74, 0x8E, 0xF0, 0xA3, 0x74, 0x63, 0xF0,
-0x90, 0x8A, 0xC3, 0x74, 0xE2, 0xF0, 0xA3, 0x74,
-0xB8, 0xF0, 0x90, 0x8A, 0xF3, 0x74, 0xE2, 0xF0,
-0xA3, 0x74, 0xF8, 0xF0, 0x90, 0x8A, 0x85, 0x74,
-0xE4, 0xF0, 0xA3, 0x74, 0x64, 0xF0, 0x90, 0x86,
-0x04, 0x74, 0xBE, 0xF0, 0xA3, 0x74, 0x0E, 0xF0,
-0x90, 0x8A, 0xA9, 0x74, 0xE3, 0xF0, 0xA3, 0x74,
-0x04, 0xF0, 0x90, 0x8B, 0x07, 0x74, 0xE3, 0xF0,
-0xA3, 0x74, 0x33, 0xF0, 0x90, 0x8A, 0xAD, 0x74,
-0xE3, 0xF0, 0xA3, 0x74, 0xE1, 0xF0, 0x90, 0x8A,
-0xBB, 0x74, 0xE4, 0xF0, 0xA3, 0x74, 0xB6, 0xF0,
-0x90, 0x86, 0x0C, 0x74, 0xDB, 0xF0, 0xA3, 0x74,
-0x05, 0xF0, 0x90, 0x8A, 0xEF, 0x74, 0xDB, 0xF0,
-0xA3, 0x74, 0x4E, 0xF0, 0x90, 0x86, 0x00, 0x74,
-0xE8, 0xF0, 0xA3, 0x74, 0x93, 0xF0, 0x90, 0x86,
-0x02, 0x74, 0xE8, 0xF0, 0xA3, 0x74, 0xF2, 0xF0,
-0x90, 0x8A, 0xFD, 0x74, 0xA5, 0xF0, 0xA3, 0x74,
-0xAF, 0xF0, 0x90, 0x8A, 0xF9, 0x74, 0xC1, 0xF0,
-0xA3, 0x74, 0x48, 0xF0, 0x90, 0x8A, 0xDB, 0x74,
-0xE1, 0xF0, 0xA3, 0x74, 0xBE, 0xF0, 0x90, 0x8A,
-0xAF, 0x74, 0xAC, 0xF0, 0xA3, 0x74, 0xD1, 0xF0,
-0x90, 0x8A, 0xD3, 0x74, 0x9D, 0xF0, 0xA3, 0x74,
-0xE1, 0xF0, 0x90, 0x8A, 0xF5, 0x74, 0xE9, 0xF0,
-0xA3, 0x74, 0xC5, 0xF0, 0x90, 0x8A, 0xA3, 0x74,
-0xB5, 0xF0, 0xA3, 0x74, 0xDB, 0xF0, 0x90, 0x86,
-0x06, 0x74, 0xAD, 0xF0, 0xA3, 0x74, 0xF5, 0xF0,
-0x22, 0xE4, 0xFB, 0xFA, 0xFD, 0x7F, 0x01, 0x12,
-0x85, 0x4E, 0x90, 0x95, 0xD0, 0xEF, 0xF0, 0x60,
-0xF0, 0x90, 0x86, 0xAF, 0xE0, 0xFF, 0x70, 0x04,
-0xA3, 0xE0, 0x60, 0xE5, 0xC2, 0xAF, 0xEF, 0x30,
-0xE0, 0x0F, 0x90, 0x86, 0xAF, 0xE0, 0x54, 0xFE,
-0xF0, 0xE4, 0xFF, 0x12, 0xD6, 0x49, 0x12, 0x93,
-0xBA, 0xB1, 0x4F, 0x30, 0xE1, 0x09, 0x54, 0xFD,
-0xF0, 0x90, 0x86, 0x08, 0x12, 0x88, 0xCD, 0xB1,
-0x4F, 0x30, 0xE2, 0x09, 0x54, 0xFB, 0xF0, 0x90,
-0x86, 0x0A, 0x12, 0x88, 0xCD, 0xB1, 0x4F, 0x30,
-0xE6, 0x09, 0x54, 0xBF, 0xF0, 0x90, 0x8A, 0x7D,
-0x12, 0x88, 0xCD, 0xD2, 0xAF, 0x80, 0xB2, 0xD2,
-0xAF, 0xC2, 0xAF, 0x90, 0x86, 0xAF, 0xE0, 0x22,
-0x8F, 0x0D, 0x7F, 0x02, 0x12, 0x85, 0x27, 0x90,
-0x86, 0xAF, 0xE0, 0x45, 0x0D, 0xF0, 0x22, 0xC0,
+0xE0, 0x44, 0x01, 0xF0, 0xE1, 0x45, 0x90, 0x97,
+0x6D, 0xE0, 0x12, 0xA7, 0x68, 0x80, 0x05, 0xC3,
+0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xED,
+0xFB, 0xEF, 0x5B, 0x60, 0x7B, 0xE4, 0xFC, 0xF1,
+0x4B, 0xA4, 0xFF, 0xEC, 0x7A, 0x00, 0x2F, 0xFF,
+0xEA, 0x35, 0xF0, 0xFE, 0x74, 0xD0, 0xF1, 0x5E,
+0x90, 0x87, 0x0C, 0xE0, 0xF9, 0x75, 0xF0, 0x08,
+0x90, 0x86, 0xBB, 0xD1, 0x4C, 0xEF, 0xF1, 0x4A,
+0xA4, 0xFF, 0xEC, 0x2F, 0xFF, 0xEA, 0x35, 0xF0,
+0xFE, 0x74, 0xF0, 0xF1, 0x5E, 0x75, 0xF0, 0x08,
+0xE9, 0x90, 0x86, 0xBF, 0xD1, 0x4C, 0xEF, 0xF0,
+0x0C, 0xEC, 0xB4, 0x04, 0xC2, 0xF1, 0x53, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5D, 0xFD,
+0xF1, 0x53, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC,
+0x90, 0x01, 0xCC, 0xF0, 0x90, 0x97, 0x6D, 0xE0,
+0x04, 0xF0, 0xE0, 0x54, 0x03, 0xF0, 0x90, 0x87,
+0x0C, 0xE0, 0x04, 0xF0, 0xE0, 0x7F, 0x00, 0xB4,
+0x0A, 0x02, 0x7F, 0x01, 0xEF, 0x70, 0x02, 0xC1,
+0x68, 0xE4, 0x90, 0x87, 0x0C, 0xF0, 0xC1, 0x68,
+0x90, 0x01, 0xC0, 0xE0, 0x44, 0x02, 0xF0, 0x90,
+0x97, 0x6D, 0xE0, 0x44, 0x80, 0x90, 0x00, 0x8A,
+0xF1, 0x4A, 0x90, 0x01, 0xD0, 0x12, 0x04, 0x6E,
+0xE0, 0x90, 0x01, 0xC3, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xF0, 0x90, 0x97, 0x6D, 0xE0, 0x75,
+0xF0, 0x04, 0x22, 0x90, 0x97, 0x6D, 0xE0, 0xFF,
+0x74, 0x01, 0xA8, 0x07, 0x08, 0x22, 0x2F, 0xF5,
+0x82, 0x74, 0x01, 0x3E, 0xF5, 0x83, 0xE0, 0xFF,
+0x22, 0x81, 0x1E, 0xE4, 0xFF, 0xA1, 0xC6, 0x7F,
+0xF9, 0x7E, 0x01, 0x02, 0x5F, 0xA6, 0xF0, 0xE4,
+0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0xEF,
+0xF0, 0xA3, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x22,
+0x24, 0xA8, 0xFF, 0xE4, 0x34, 0x01, 0xFE, 0x7B,
+0x01, 0x22, 0xE4, 0x90, 0x86, 0xAF, 0xF0, 0xF1,
+0x78, 0x90, 0x93, 0x01, 0xF0, 0x90, 0x93, 0xF3,
+0xF0, 0xA3, 0xF0, 0x22, 0xEF, 0xB4, 0xFF, 0x06,
+0x90, 0x93, 0xF4, 0xED, 0xF0, 0x22, 0xEF, 0xF4,
+0xFE, 0x90, 0x93, 0xF4, 0x41, 0x07, 0x12, 0x02,
+0x06, 0x54, 0x01, 0xFF, 0x90, 0x93, 0x3F, 0xE0,
+0x54, 0xFE, 0x4F, 0xF0, 0x30, 0xE0, 0x02, 0xF1,
+0x77, 0x22, 0x7E, 0x00, 0x7F, 0x01, 0x7D, 0x00,
+0x7B, 0x01, 0x7A, 0x88, 0x79, 0x2C, 0x12, 0x04,
+0x80, 0x90, 0x88, 0x2C, 0xE0, 0x54, 0xFD, 0xF1,
+0x76, 0xA3, 0x74, 0x0C, 0xF0, 0x22, 0x12, 0x02,
+0x06, 0x54, 0x01, 0xFF, 0x90, 0x93, 0xF2, 0xE0,
+0x54, 0xFE, 0x4F, 0xF0, 0x22, 0x12, 0xA7, 0x4E,
+0xFF, 0x54, 0x7F, 0x90, 0x88, 0x36, 0xF0, 0xEF,
+0x12, 0x97, 0x35, 0xA3, 0x12, 0x87, 0x69, 0xFD,
+0x54, 0xF0, 0xC4, 0x54, 0x0F, 0xFF, 0x90, 0x88,
+0x34, 0xE0, 0x54, 0xF0, 0x4F, 0x12, 0x87, 0xFD,
+0xFC, 0x54, 0x01, 0x25, 0xE0, 0xFF, 0x90, 0x88,
+0x31, 0xE0, 0x54, 0xFD, 0x4F, 0xF0, 0xEC, 0x54,
+0x04, 0xC3, 0x13, 0xFF, 0x90, 0x88, 0x33, 0xE0,
+0x54, 0xFD, 0x4F, 0xF0, 0xED, 0x54, 0x0F, 0xC4,
+0x54, 0xF0, 0xFF, 0xA3, 0xE0, 0x54, 0x0F, 0x12,
+0x87, 0x95, 0x90, 0x88, 0x35, 0x12, 0x87, 0xF3,
+0xFD, 0x90, 0x8A, 0x89, 0x12, 0x90, 0x4B, 0x7F,
+0x02, 0x12, 0xBF, 0xE2, 0x54, 0xFE, 0xF0, 0x54,
+0xFD, 0xF0, 0x54, 0xFB, 0xF0, 0x54, 0xF7, 0xF0,
+0x54, 0xEF, 0xF0, 0x54, 0xDF, 0xF0, 0x54, 0xBF,
+0x12, 0x87, 0xEA, 0x12, 0x5C, 0x5F, 0x90, 0x88,
+0x36, 0xE0, 0xB4, 0x01, 0x07, 0x90, 0x88, 0x33,
+0xE0, 0x54, 0xFB, 0xF0, 0x12, 0xDA, 0x73, 0xF0,
+0x90, 0x88, 0x36, 0x12, 0xED, 0xB4, 0x11, 0x93,
+0x90, 0x01, 0xBE, 0xF0, 0x22, 0x90, 0x88, 0x3A,
+0xE0, 0x44, 0x01, 0xF0, 0x90, 0x88, 0x34, 0xE0,
+0x54, 0x0F, 0x22, 0x90, 0x06, 0xA9, 0xE0, 0x90,
+0x95, 0xEE, 0xF0, 0xE0, 0xFD, 0x54, 0xC0, 0x70,
+0x04, 0x31, 0x0E, 0x80, 0x5D, 0xED, 0x30, 0xE6,
+0x47, 0x90, 0x88, 0x36, 0xE0, 0x64, 0x02, 0x70,
+0x2C, 0x90, 0x88, 0x31, 0xE0, 0xC3, 0x13, 0x20,
+0xE0, 0x09, 0x90, 0x88, 0x3A, 0xE0, 0x44, 0x01,
+0xF0, 0x80, 0x20, 0x11, 0x94, 0x64, 0x01, 0x70,
+0x29, 0x90, 0x88, 0x3A, 0xE0, 0x44, 0x04, 0xF0,
+0x90, 0x8A, 0x71, 0x12, 0x90, 0x4B, 0x7F, 0x01,
+0x12, 0x04, 0x7E, 0x80, 0x15, 0x11, 0x8D, 0x64,
+0x02, 0x60, 0x08, 0x90, 0x8A, 0xE1, 0x12, 0x8A,
+0x66, 0x80, 0x07, 0x12, 0x73, 0x8F, 0x80, 0x02,
+0x31, 0x0E, 0x90, 0x95, 0xEE, 0xE0, 0x90, 0x88,
+0x3A, 0x30, 0xE7, 0x05, 0x12, 0x9D, 0x48, 0xA1,
+0x18, 0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90, 0x88,
+0x3A, 0xE0, 0x54, 0xFE, 0xF0, 0x22, 0xE4, 0xF5,
+0x7C, 0x90, 0x06, 0xA9, 0xE0, 0xF5, 0x7C, 0x54,
+0xC0, 0x70, 0x0F, 0x31, 0x0E, 0x54, 0xFD, 0xF0,
+0xB1, 0xF6, 0x90, 0x88, 0x39, 0xE0, 0x60, 0x3C,
+0xC1, 0xC7, 0xE5, 0x7C, 0x30, 0xE6, 0x22, 0x90,
+0x88, 0x36, 0xE0, 0x64, 0x01, 0x70, 0x1C, 0x11,
+0x8D, 0x64, 0x02, 0x60, 0x0F, 0x90, 0x88, 0x9D,
+0xE0, 0x20, 0xE0, 0x0F, 0x90, 0x8A, 0xE1, 0x12,
+0x8A, 0x66, 0x80, 0x07, 0x12, 0x97, 0x4D, 0x80,
+0x02, 0x31, 0x0E, 0xE5, 0x7C, 0x90, 0x88, 0x3A,
+0x30, 0xE7, 0x05, 0x12, 0x9D, 0x48, 0xA1, 0x18,
+0xE0, 0x54, 0xFD, 0xF0, 0x22, 0xE4, 0x90, 0x95,
+0xED, 0xF0, 0x12, 0x9E, 0xA4, 0x60, 0x02, 0x41,
+0xBC, 0x90, 0x88, 0x36, 0xE0, 0x70, 0x02, 0x41,
+0xBC, 0x90, 0x88, 0x2C, 0xE0, 0x20, 0xE0, 0x36,
+0x90, 0x88, 0x9D, 0xE0, 0x20, 0xE0, 0x2F, 0x90,
+0x06, 0xA9, 0xE0, 0x54, 0xC0, 0x70, 0x27, 0x90,
+0x88, 0x9C, 0xE0, 0x70, 0x21, 0x90, 0x04, 0x1A,
+0xE0, 0xF4, 0x70, 0x1A, 0xA3, 0xE0, 0x54, 0x07,
+0xFF, 0xBF, 0x07, 0x12, 0x90, 0x06, 0x62, 0xE0,
+0x54, 0x03, 0x70, 0x0A, 0x90, 0x88, 0x39, 0xE0,
+0xB4, 0x04, 0x03, 0x12, 0xD3, 0xB5, 0x90, 0x05,
+0x63, 0xE0, 0x90, 0x88, 0x85, 0xF0, 0x90, 0x05,
+0x62, 0xE0, 0x90, 0x88, 0x86, 0xF0, 0x90, 0x05,
+0x61, 0xE0, 0x90, 0x88, 0x87, 0xF0, 0x90, 0x05,
+0x60, 0xE0, 0x90, 0x88, 0x88, 0xF0, 0x90, 0x07,
+0xF1, 0xE0, 0x90, 0x95, 0x35, 0xF0, 0x90, 0x07,
+0xF0, 0xE0, 0x90, 0x95, 0x36, 0xF0, 0xB1, 0xBE,
+0xF0, 0x90, 0x88, 0x3A, 0xE0, 0x54, 0xEC, 0xF0,
+0x51, 0xD8, 0x24, 0xFD, 0x50, 0x02, 0x80, 0x0D,
+0x90, 0x88, 0x2C, 0xE0, 0x30, 0xE0, 0x04, 0x11,
+0x9B, 0x80, 0x02, 0x31, 0x16, 0x51, 0xD8, 0x64,
+0x01, 0x70, 0x3A, 0x90, 0x06, 0xAB, 0xE0, 0x90,
+0x88, 0x3D, 0xF0, 0x90, 0x06, 0xA9, 0xE0, 0x30,
+0xE5, 0x06, 0xA3, 0xE0, 0x90, 0x95, 0xED, 0xF0,
+0x90, 0x95, 0xED, 0xE0, 0xFF, 0x60, 0x02, 0x80,
+0x05, 0x90, 0x88, 0x3C, 0xE0, 0xFF, 0x90, 0x88,
+0x3C, 0xEF, 0xF0, 0xA3, 0xE0, 0xFF, 0x70, 0x08,
+0x90, 0x88, 0x3C, 0xE0, 0xFE, 0xFF, 0x80, 0x00,
+0x90, 0x88, 0x3D, 0xEF, 0xF0, 0x51, 0xE1, 0xE4,
+0x90, 0x88, 0x3F, 0xF0, 0xA3, 0xF0, 0xB1, 0x8C,
+0x30, 0xE0, 0x5F, 0xEF, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x20, 0xE0, 0x25, 0x51, 0xD0, 0x6F, 0x70,
+0x51, 0xEF, 0x60, 0x4E, 0x90, 0x88, 0x32, 0xE0,
+0x44, 0x40, 0xF0, 0x12, 0xEE, 0x33, 0x12, 0x9F,
+0x81, 0x12, 0x7C, 0x05, 0x12, 0xCD, 0x05, 0xB1,
+0xB7, 0x90, 0x88, 0x3D, 0xE0, 0x14, 0xF0, 0x80,
+0x31, 0x90, 0x88, 0x34, 0xE0, 0xC4, 0x54, 0x0F,
+0x64, 0x01, 0x70, 0x26, 0x51, 0xD0, 0xFE, 0x6F,
+0x60, 0x20, 0x90, 0x05, 0x73, 0xE0, 0xFF, 0xEE,
+0x6F, 0x60, 0x17, 0x90, 0x88, 0x32, 0xB1, 0x23,
+0x30, 0xE0, 0x0F, 0xEF, 0x54, 0xBF, 0x12, 0x9F,
+0x81, 0x12, 0x7C, 0x3B, 0x12, 0x9F, 0xE9, 0x12,
+0x9F, 0x94, 0x51, 0xC8, 0x90, 0x88, 0x2C, 0xE0,
+0xC3, 0x13, 0x20, 0xE0, 0x02, 0x51, 0xC8, 0x22,
+0x90, 0x88, 0x32, 0xE0, 0x44, 0x04, 0xF0, 0x22,
+0x90, 0x88, 0x3C, 0xE0, 0xFF, 0xA3, 0xE0, 0x22,
+0x90, 0x88, 0x34, 0xE0, 0xFF, 0xC4, 0x54, 0x0F,
+0x22, 0x90, 0x88, 0x85, 0x12, 0x04, 0xB8, 0xC0,
+0x06, 0xC0, 0x07, 0x90, 0x95, 0x36, 0xE0, 0x24,
+0x46, 0xFF, 0x90, 0x95, 0x35, 0xE0, 0x34, 0x00,
+0xAB, 0x07, 0xFA, 0xE4, 0xF9, 0xF8, 0xD0, 0x07,
+0xD0, 0x06, 0x12, 0x85, 0xB6, 0x90, 0x88, 0x85,
+0x91, 0xEB, 0xEF, 0x24, 0x46, 0x12, 0xED, 0xD9,
+0x90, 0x88, 0x89, 0x91, 0xEB, 0x90, 0x88, 0x85,
+0x12, 0xEE, 0x2C, 0x50, 0x02, 0x61, 0xD2, 0x90,
+0x88, 0x89, 0x12, 0x86, 0x2D, 0x90, 0x88, 0x85,
+0x12, 0x04, 0xB8, 0x12, 0x85, 0xB6, 0x90, 0x95,
+0xF2, 0x12, 0x04, 0x31, 0x90, 0x88, 0x31, 0xE0,
+0x30, 0xE0, 0x2F, 0x90, 0x88, 0x53, 0xE0, 0x24,
+0x04, 0xFF, 0xE4, 0x33, 0xFE, 0xEF, 0x78, 0x03,
+0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24,
+0x50, 0xFF, 0xE4, 0x3E, 0xFE, 0x90, 0x88, 0x4E,
+0xE0, 0xFD, 0xC3, 0xEF, 0x9D, 0xFB, 0xEE, 0x94,
+0x00, 0xFA, 0x91, 0xF4, 0xEB, 0x2F, 0xFF, 0xEA,
+0x80, 0x1D, 0x90, 0x88, 0x33, 0xB1, 0x23, 0x30,
+0xE0, 0x02, 0x81, 0xD0, 0x91, 0xF4, 0x90, 0x88,
+0x4E, 0xE0, 0xFD, 0xC3, 0x74, 0x60, 0x9D, 0xCD,
+0xE4, 0x94, 0x00, 0xCD, 0x2F, 0xFF, 0xED, 0x3E,
+0x90, 0x95, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xC3,
+0x90, 0x95, 0xEF, 0xE0, 0x94, 0xA0, 0x90, 0x95,
+0xEE, 0xE0, 0x94, 0x00, 0x50, 0x34, 0xA3, 0xE0,
+0xFB, 0x24, 0xF5, 0x91, 0xE3, 0xE0, 0x04, 0xF0,
+0x90, 0x95, 0xF2, 0x12, 0x04, 0xB8, 0xEF, 0x54,
+0x7F, 0xFF, 0x74, 0x95, 0x2B, 0x91, 0xD8, 0xE0,
+0xFE, 0xEF, 0xC3, 0x9E, 0x50, 0x09, 0x90, 0x95,
+0xEE, 0xA3, 0xE0, 0x91, 0xD6, 0xEF, 0xF0, 0x90,
+0x88, 0x4C, 0xE0, 0x04, 0xF0, 0xE0, 0x90, 0x00,
+0xFE, 0xF0, 0x90, 0x88, 0x4C, 0xE0, 0xFF, 0xD3,
+0x90, 0x88, 0x90, 0xE0, 0x9F, 0x90, 0x88, 0x8F,
+0xE0, 0x94, 0x00, 0x40, 0x02, 0x81, 0xD0, 0xE4,
+0xFF, 0xFE, 0x91, 0xE0, 0xE0, 0x2F, 0xFF, 0x90,
+0x88, 0x91, 0xE0, 0xFD, 0xEF, 0xD3, 0x9D, 0x40,
+0x07, 0x90, 0x95, 0xF0, 0xEE, 0xF0, 0x80, 0x05,
+0x0E, 0xEE, 0xB4, 0xA0, 0xE5, 0x91, 0xFF, 0x40,
+0x02, 0x80, 0x15, 0x90, 0x95, 0xF0, 0xE0, 0x04,
+0xFE, 0xEE, 0xC3, 0x94, 0xA0, 0x50, 0x13, 0x91,
+0xE0, 0xE0, 0x2F, 0xFF, 0x91, 0xFF, 0x40, 0x07,
+0x90, 0x95, 0xF1, 0xEE, 0xF0, 0x80, 0x03, 0x0E,
+0x80, 0xE7, 0x90, 0x05, 0x5E, 0xE0, 0xFF, 0x91,
+0xD1, 0xE0, 0xFD, 0xEF, 0xC3, 0x9D, 0x40, 0x11,
+0xEF, 0x9D, 0x90, 0x05, 0x5E, 0xF0, 0x90, 0x88,
+0x51, 0xEE, 0xF0, 0x90, 0x95, 0xF1, 0xE0, 0x80,
+0x18, 0x91, 0xD1, 0xE0, 0xFD, 0xC3, 0x74, 0x80,
+0x9D, 0x2F, 0x90, 0x05, 0x5E, 0xF0, 0xEE, 0x04,
+0x90, 0x88, 0x51, 0xF0, 0x90, 0x95, 0xF1, 0xE0,
+0x04, 0x90, 0x88, 0x52, 0xF0, 0x90, 0x88, 0x51,
+0xE0, 0xFF, 0xC3, 0x94, 0x50, 0x40, 0x0A, 0xEF,
+0x24, 0xB0, 0x90, 0x88, 0x49, 0xF0, 0xE4, 0x80,
+0x0E, 0xE4, 0x90, 0x88, 0x49, 0xF0, 0x90, 0x88,
+0x51, 0xE0, 0xFF, 0xC3, 0x74, 0x50, 0x9F, 0x90,
+0x88, 0x48, 0xF0, 0x90, 0x88, 0x51, 0xE0, 0xFF,
+0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x88, 0x4F, 0xF0,
+0x90, 0x88, 0x31, 0xE0, 0x90, 0x88, 0x8E, 0xE0,
+0x24, 0x08, 0xFF, 0x90, 0x88, 0x4F, 0xE0, 0x2F,
+0xF0, 0x90, 0x88, 0x4F, 0xE0, 0xC3, 0x94, 0x50,
+0x50, 0x03, 0x74, 0x50, 0xF0, 0x90, 0x88, 0x4F,
+0xE0, 0x24, 0x10, 0xF0, 0x12, 0xCD, 0x0C, 0x74,
+0x03, 0xF0, 0x12, 0x6E, 0x2F, 0x90, 0x8A, 0xA3,
+0x12, 0x90, 0x4B, 0xE4, 0xFF, 0x12, 0x04, 0x7E,
+0x22, 0x90, 0x95, 0xF0, 0xE0, 0xFE, 0x24, 0x95,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83, 0x22,
+0x74, 0xF5, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93,
+0xF5, 0x83, 0x22, 0x12, 0x04, 0x31, 0x90, 0x88,
+0x89, 0x02, 0x04, 0xB8, 0x90, 0x95, 0xF2, 0x12,
+0x04, 0xB8, 0x78, 0x07, 0x02, 0x03, 0xEB, 0x90,
+0x88, 0x91, 0xE0, 0xFD, 0xC3, 0x90, 0x88, 0x90,
+0xE0, 0x9D, 0xFD, 0x90, 0x88, 0x8F, 0xE0, 0x94,
+0x00, 0xFC, 0xEF, 0xD3, 0x9D, 0xE4, 0x9C, 0x22,
+0x90, 0x88, 0x31, 0xE0, 0x44, 0x04, 0xF0, 0x22,
+0x90, 0x88, 0x31, 0xE0, 0xFF, 0x13, 0x13, 0x54,
+0x3F, 0x22, 0xB1, 0x8C, 0x30, 0xE0, 0x0B, 0xEF,
+0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
+0xB1, 0xB7, 0xB1, 0x20, 0x30, 0xE0, 0x09, 0xEF,
+0xB1, 0xC9, 0x54, 0x07, 0x70, 0x3D, 0x80, 0x39,
+0xD1, 0x24, 0x40, 0x35, 0x12, 0x9E, 0xA3, 0x70,
+0x32, 0x11, 0x94, 0x70, 0x08, 0x90, 0x8A, 0xF5,
+0x12, 0x8A, 0x66, 0x80, 0x27, 0x90, 0x8A, 0xF5,
+0x12, 0x8A, 0x66, 0x90, 0x88, 0x40, 0xE0, 0x04,
+0xF0, 0xE0, 0xD3, 0x94, 0x02, 0x40, 0x09, 0xB1,
+0x84, 0xE4, 0x90, 0x88, 0x40, 0xF0, 0x80, 0x03,
+0x12, 0x97, 0x4D, 0xE4, 0x90, 0x88, 0x3F, 0xF0,
+0x22, 0xB1, 0xF6, 0x22, 0x90, 0x88, 0x32, 0xE0,
+0x54, 0xFB, 0xF0, 0x22, 0x90, 0x88, 0x32, 0xE0,
+0xFF, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x22, 0x90,
+0x01, 0x57, 0xE0, 0x60, 0x19, 0xB1, 0xC1, 0xF0,
+0xB1, 0x20, 0x30, 0xE0, 0x03, 0xEF, 0x80, 0x21,
+0xD1, 0x24, 0x40, 0x0A, 0xE4, 0xFF, 0x12, 0x78,
+0x4A, 0xBF, 0x01, 0x02, 0xB1, 0x84, 0x22, 0x7D,
+0x02, 0x7F, 0x02, 0x02, 0x7C, 0x7E, 0x90, 0x01,
+0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x02,
+0x22, 0x54, 0xFB, 0xF0, 0x90, 0x88, 0x3A, 0xE0,
+0x54, 0xFD, 0xF0, 0x22, 0x12, 0x9E, 0xA3, 0x70,
+0x1C, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x16, 0x90,
+0x88, 0x3A, 0xE0, 0x20, 0xE4, 0x0F, 0xB1, 0xBE,
+0xF0, 0x90, 0x88, 0x31, 0xE0, 0xB1, 0xC9, 0x54,
+0x07, 0x70, 0x02, 0xB1, 0xF6, 0x22, 0x90, 0x88,
+0x2C, 0xE0, 0x90, 0x88, 0x38, 0x30, 0xE0, 0x05,
+0xE0, 0xFF, 0x02, 0x9F, 0xA4, 0x12, 0x97, 0x3F,
+0x7D, 0x01, 0x02, 0x04, 0x7E, 0xE4, 0xFF, 0x12,
+0x78, 0x4A, 0xBF, 0x01, 0x0E, 0x90, 0x88, 0x36,
+0xE0, 0x60, 0x08, 0x31, 0x0E, 0x54, 0x07, 0x70,
+0x02, 0xB1, 0xF6, 0x22, 0x90, 0x88, 0x3F, 0xE0,
+0x04, 0xF0, 0x90, 0x88, 0x3A, 0xE0, 0x54, 0xEF,
+0xF0, 0x90, 0x88, 0x93, 0xE0, 0xFF, 0x90, 0x88,
+0x3F, 0xE0, 0xD3, 0x9F, 0x22, 0x90, 0x88, 0x36,
+0xE0, 0x60, 0x14, 0x90, 0x06, 0x92, 0xE0, 0x30,
+0xE1, 0x08, 0x90, 0x8B, 0x01, 0x12, 0x8A, 0x66,
+0x80, 0x05, 0x12, 0xEE, 0x52, 0xB1, 0xF6, 0x02,
+0x9A, 0x2E, 0xE4, 0xFE, 0x91, 0xE0, 0xE4, 0xF0,
+0x74, 0x95, 0x2E, 0x91, 0xD8, 0x74, 0xFF, 0xF0,
+0x0E, 0xEE, 0xB4, 0xA0, 0xEF, 0xE4, 0x90, 0x88,
+0x4D, 0xF0, 0x90, 0x88, 0x4C, 0xF0, 0x90, 0x88,
+0x50, 0xF0, 0xEF, 0xB4, 0x01, 0x07, 0xA3, 0x74,
+0xA0, 0xF0, 0xE4, 0xA3, 0xF0, 0x22, 0x90, 0x88,
+0x36, 0xE0, 0x64, 0x01, 0x70, 0x25, 0x11, 0x94,
+0x60, 0x12, 0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B,
+0x12, 0x97, 0xCD, 0x90, 0x8B, 0x01, 0x12, 0xD9,
+0x42, 0x02, 0x04, 0x7A, 0x90, 0x88, 0x39, 0xE0,
+0x70, 0x09, 0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B,
+0x12, 0x9E, 0x94, 0x22, 0x90, 0x88, 0x39, 0xE0,
+0xB4, 0x04, 0x02, 0xD1, 0xC7, 0x90, 0x88, 0x9D,
+0xE0, 0x20, 0xE0, 0x02, 0xD1, 0x86, 0x22, 0x90,
+0x00, 0x02, 0xE0, 0x44, 0x01, 0xF0, 0x22, 0x90,
+0x88, 0x36, 0xE0, 0x70, 0x07, 0x90, 0x88, 0x2C,
+0xE0, 0x30, 0xE0, 0x12, 0x90, 0x88, 0x2C, 0xE0,
+0x30, 0xE0, 0x09, 0x12, 0x9E, 0x67, 0xBF, 0x01,
+0x05, 0x02, 0xEA, 0x54, 0xD1, 0xB4, 0x22, 0xC0,
 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0,
 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01,
 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05,
 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74,
-0x67, 0xF0, 0x74, 0xDD, 0xA3, 0xF0, 0x90, 0x8A,
-0x9D, 0x12, 0x88, 0xCD, 0x53, 0x91, 0xBF, 0x74,
-0x67, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xDD,
-0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05,
-0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83,
-0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0xC0, 0xE0, 0xC0,
-0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
-0xC0, 0x05, 0xC0, 0x07, 0x7D, 0xBD, 0x90, 0x01,
-0xC4, 0xED, 0xF0, 0x74, 0xDD, 0xFF, 0xA3, 0xF0,
-0xED, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0xA3, 0xEF,
-0xF0, 0xD0, 0x07, 0xD0, 0x05, 0xD0, 0xD0, 0xD0,
-0x82, 0xD0, 0x83, 0xD0, 0xE0, 0x32, 0x90, 0x88,
-0x2C, 0xE0, 0x30, 0xE0, 0x05, 0xE4, 0xA3, 0xF0,
-0xA3, 0xF0, 0x22, 0x90, 0x88, 0xB8, 0xE0, 0x30,
-0xE0, 0x05, 0x90, 0x8A, 0x8F, 0x80, 0x03, 0x90,
-0x8A, 0x87, 0x12, 0x88, 0xCD, 0x90, 0x88, 0xE6,
-0xE0, 0x30, 0xE0, 0x04, 0xA3, 0xE0, 0x04, 0xF0,
-0x90, 0x88, 0xE7, 0xE0, 0x64, 0x08, 0x70, 0x21,
-0x90, 0x88, 0xE6, 0xE0, 0x30, 0xE0, 0x15, 0x12,
-0xC5, 0x52, 0xF0, 0xE4, 0xFD, 0x12, 0x76, 0xF7,
-0x90, 0x88, 0xE6, 0xE0, 0x54, 0xFE, 0xF0, 0xE4,
-0xA3, 0xF0, 0x80, 0x05, 0xE4, 0x90, 0x88, 0xE7,
-0xF0, 0x12, 0xAC, 0xC7, 0x30, 0xE0, 0x13, 0x90,
-0x88, 0xE8, 0xE0, 0x04, 0xF0, 0xE0, 0xB4, 0x14,
-0x09, 0x90, 0x04, 0x9C, 0xE4, 0xF0, 0x90, 0x88,
-0xE8, 0xF0, 0x90, 0x88, 0x2C, 0xE0, 0x30, 0xE0,
-0x06, 0x90, 0x88, 0x2E, 0x74, 0x01, 0xF0, 0x90,
-0x88, 0x36, 0xE0, 0x70, 0x02, 0xC1, 0xEE, 0x90,
-0x88, 0x4D, 0xE0, 0x04, 0xF0, 0x90, 0x05, 0x61,
-0x12, 0xCD, 0xEC, 0x90, 0x05, 0x60, 0x12, 0x8F,
-0xEA, 0x12, 0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x05, 0x62, 0x12,
-0x8F, 0xEA, 0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0,
-0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
-0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0xA3, 0x12, 0x8F, 0xEA, 0x78, 0x18,
-0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x86, 0x20, 0x90, 0x88,
-0x81, 0x12, 0x04, 0x31, 0x90, 0x88, 0x32, 0xE0,
-0x54, 0x7F, 0xF0, 0xA3, 0xE0, 0x30, 0xE0, 0x0B,
-0x12, 0xBE, 0x9E, 0x74, 0x05, 0xF0, 0x12, 0x6E,
-0x2F, 0xF1, 0x0B, 0x90, 0x88, 0x32, 0x12, 0x9E,
-0xC7, 0x30, 0xE0, 0x0A, 0x90, 0x01, 0x3B, 0xE0,
-0x30, 0xE4, 0x03, 0x12, 0xB5, 0x33, 0x90, 0x8A,
-0xE5, 0x12, 0x8E, 0x5A, 0x7F, 0x01, 0x12, 0x04,
-0x7E, 0x90, 0x93, 0x3B, 0xE0, 0x30, 0xE0, 0x0A,
-0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4, 0x03, 0x12,
-0xB5, 0x33, 0x22, 0x90, 0x88, 0x33, 0xE0, 0x54,
-0xFE, 0xF0, 0x22, 0x90, 0x88, 0x2C, 0xE0, 0xFF,
-0x30, 0xE0, 0x05, 0x12, 0xAB, 0x83, 0x60, 0x15,
-0x90, 0x88, 0x36, 0xE0, 0x70, 0x04, 0xEF, 0x30,
-0xE0, 0x0B, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x02,
-0x60, 0x03, 0x12, 0xB1, 0x71, 0x22, 0x12, 0x9F,
-0xD1, 0x70, 0x13, 0x90, 0x88, 0x36, 0xE0, 0x60,
-0x0D, 0x90, 0x88, 0x3A, 0xE0, 0x20, 0xE4, 0x06,
-0x12, 0xB5, 0xA1, 0x12, 0x9F, 0x4A, 0x22, 0xE4,
-0xFF, 0x12, 0x78, 0x4A, 0xBF, 0x01, 0x19, 0x90,
-0x88, 0x36, 0xE0, 0x60, 0x13, 0x12, 0xAF, 0xC1,
-0x64, 0x02, 0x60, 0x09, 0x90, 0x8A, 0xE1, 0x12,
-0xD7, 0xBF, 0x02, 0x04, 0x7A, 0x12, 0x73, 0x8F,
-0x22, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xBF, 0x01,
-0x0F, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x09, 0xF1,
-0x89, 0x54, 0x07, 0x70, 0x03, 0x12, 0xAF, 0x06,
-0x22, 0x90, 0x88, 0x3A, 0xE0, 0x54, 0xFE, 0xF0,
-0x22, 0x90, 0x88, 0x36, 0xE0, 0x70, 0x07, 0x90,
-0x88, 0x2C, 0xE0, 0x30, 0xE0, 0x13, 0x90, 0x88,
-0x2C, 0xE0, 0x30, 0xE0, 0x09, 0x12, 0x9F, 0xDA,
-0xBF, 0x01, 0x06, 0x02, 0xAF, 0xA0, 0x12, 0xAE,
-0xF2, 0x22, 0x12, 0x02, 0x06, 0x90, 0x96, 0x4C,
-0xF0, 0x22, 0xE6, 0xFD, 0xAF, 0x67, 0xEF, 0x12,
-0x93, 0x34, 0xE0, 0x54, 0xF8, 0xF5, 0x75, 0xED,
-0x42, 0x75, 0xEF, 0x12, 0x93, 0x34, 0xE5, 0x75,
-0xF0, 0x22, 0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00,
+0xEF, 0xF0, 0x74, 0xB6, 0xA3, 0xF0, 0x12, 0x64,
+0x7F, 0xE5, 0x30, 0x30, 0xE1, 0x02, 0xD1, 0xCF,
+0xE5, 0x2D, 0x30, 0xE1, 0x03, 0x12, 0xAF, 0x6B,
+0xE5, 0x2D, 0x30, 0xE3, 0x03, 0x12, 0xE4, 0x9D,
+0xE5, 0x2D, 0x30, 0xE4, 0x03, 0x12, 0xE4, 0xB5,
+0xE5, 0x2D, 0x30, 0xE5, 0x03, 0x12, 0xE4, 0xC6,
+0xE5, 0x2D, 0x30, 0xE6, 0x03, 0x12, 0xD8, 0x7B,
+0xE5, 0x2F, 0x30, 0xE0, 0x03, 0x12, 0x9D, 0xEA,
+0xE5, 0x2F, 0x30, 0xE1, 0x03, 0x12, 0xCB, 0xF1,
+0xE5, 0x2F, 0x30, 0xE2, 0x03, 0x12, 0xD8, 0x88,
+0xE5, 0x2F, 0x30, 0xE3, 0x03, 0x12, 0x9E, 0xAC,
+0xE5, 0x2F, 0x30, 0xE4, 0x02, 0xB1, 0xD4, 0xE5,
+0x2F, 0x30, 0xE5, 0x03, 0x12, 0xD9, 0x0D, 0xE5,
+0x2F, 0x30, 0xE6, 0x02, 0xD1, 0x0D, 0xE5, 0x30,
+0x30, 0xE4, 0x02, 0xF1, 0xE3, 0xE5, 0x30, 0x30,
+0xE5, 0x03, 0x12, 0xD9, 0x4A, 0xE5, 0x36, 0x30,
+0xE3, 0x03, 0x12, 0xAF, 0x69, 0xE5, 0x36, 0x30,
+0xE0, 0x03, 0x12, 0xA3, 0x86, 0xE5, 0x36, 0x30,
+0xE6, 0x03, 0x12, 0xA3, 0x05, 0xE5, 0x36, 0x30,
+0xE7, 0x03, 0x12, 0xA7, 0xA3, 0xE5, 0x37, 0x30,
+0xE2, 0x03, 0x12, 0xA7, 0xAF, 0xE5, 0x37, 0x30,
+0xE3, 0x03, 0x12, 0xA7, 0xBB, 0x74, 0xEF, 0x04,
+0x90, 0x01, 0xC4, 0xF0, 0x74, 0xB6, 0xA3, 0xF0,
+0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
+0xD0, 0xE0, 0x32, 0xE4, 0xFF, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0xE8, 0xEF,
+0xF0, 0x90, 0x88, 0x2B, 0xE0, 0x90, 0x96, 0xFA,
+0xF0, 0xE4, 0x90, 0x96, 0xE9, 0xF0, 0x90, 0x96,
+0xFA, 0xE0, 0xFE, 0x90, 0x96, 0xE9, 0xE0, 0xFF,
+0xC3, 0x9E, 0x50, 0x2B, 0xE0, 0xFE, 0x31, 0x05,
+0xE4, 0xF0, 0xEE, 0x31, 0x91, 0xE0, 0x30, 0xE7,
+0x0A, 0x75, 0xF0, 0x12, 0xEF, 0x31, 0x0F, 0xE4,
+0xF0, 0x80, 0x0C, 0x12, 0x7C, 0x8F, 0x90, 0x96,
+0xE9, 0xE0, 0x31, 0x05, 0x74, 0x01, 0xF0, 0x90,
+0x96, 0xE9, 0xE0, 0x04, 0xF0, 0x80, 0xC7, 0x7F,
+0x0C, 0x7E, 0x00, 0x12, 0x7C, 0x6A, 0xE4, 0x90,
+0x96, 0xE9, 0xF0, 0x90, 0x96, 0xFA, 0xE0, 0xFF,
+0x90, 0x96, 0xE9, 0xE0, 0xFE, 0xC3, 0x9F, 0x40,
+0x02, 0x21, 0x00, 0x74, 0xEA, 0x2E, 0x31, 0x07,
+0xE0, 0x70, 0x02, 0x01, 0xF8, 0xEE, 0xC4, 0x54,
+0xF0, 0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34, 0x81,
+0xF5, 0x83, 0xE0, 0xFD, 0xEE, 0xC4, 0x54, 0xF0,
+0x24, 0x07, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
+0x83, 0x31, 0x15, 0xFC, 0x75, 0xF0, 0x12, 0x90,
+0x89, 0x53, 0x31, 0x1E, 0xEC, 0xC4, 0x54, 0xF0,
+0x24, 0x0A, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
+0x83, 0xE0, 0xFD, 0xEC, 0x31, 0x27, 0x31, 0x15,
+0x75, 0xF0, 0x12, 0x90, 0x89, 0x57, 0x31, 0x1E,
+0x7F, 0x01, 0x90, 0x96, 0xE9, 0xE0, 0xFE, 0x31,
+0x27, 0xE5, 0x82, 0x2F, 0x12, 0xAE, 0x52, 0xE0,
+0xFD, 0x75, 0xF0, 0x12, 0xEE, 0x90, 0x89, 0x57,
+0x12, 0x04, 0x6E, 0x75, 0xF0, 0x02, 0xEF, 0x31,
+0x34, 0xED, 0xF0, 0x0F, 0xEF, 0xB4, 0x05, 0xDA,
+0x90, 0x96, 0xE9, 0xE0, 0xFF, 0xC4, 0x54, 0xF0,
+0x24, 0x09, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
+0x83, 0xE0, 0xFE, 0xF1, 0x7D, 0xEE, 0xF0, 0x90,
+0x96, 0xE9, 0xE0, 0xFF, 0x90, 0x96, 0xE8, 0xE0,
+0xFD, 0x12, 0x61, 0xF7, 0x90, 0x96, 0xE9, 0xE0,
+0x75, 0xF0, 0x12, 0x31, 0x0F, 0x74, 0x01, 0xF0,
+0x90, 0x96, 0xE9, 0xE0, 0x04, 0xF0, 0x01, 0x43,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x24, 0xEA, 0xF5,
+0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83, 0x22, 0x90,
+0x89, 0x56, 0x02, 0x04, 0x6E, 0xE0, 0xFE, 0xED,
+0xFF, 0x90, 0x96, 0xE9, 0xE0, 0x22, 0x12, 0x04,
+0x6E, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xC4,
+0x54, 0xF0, 0x24, 0x0B, 0xF5, 0x82, 0xE4, 0x34,
+0x81, 0xF5, 0x83, 0x22, 0x12, 0x04, 0x6E, 0xE4,
+0xF0, 0xA3, 0x22, 0x7D, 0x07, 0xAF, 0x67, 0xED,
+0x30, 0xE0, 0x1E, 0x75, 0xF0, 0x12, 0xEF, 0x90,
+0x89, 0x57, 0x31, 0x84, 0x90, 0x89, 0x59, 0x31,
+0x84, 0x90, 0x89, 0x5B, 0x31, 0x84, 0x90, 0x89,
+0x5D, 0x31, 0x84, 0x90, 0x89, 0x5F, 0x31, 0x34,
+0xF0, 0xED, 0x30, 0xE1, 0x0A, 0x75, 0xF0, 0x12,
+0xEF, 0x90, 0x89, 0x53, 0x31, 0x34, 0xF0, 0xED,
+0x30, 0xE2, 0x04, 0xF1, 0x7D, 0xE4, 0xF0, 0x31,
+0x90, 0xE0, 0x54, 0xBF, 0x44, 0x80, 0xFE, 0x31,
+0x90, 0xEE, 0xF0, 0x22, 0x12, 0x04, 0x6E, 0xE4,
+0xF0, 0xA3, 0xF0, 0x75, 0xF0, 0x12, 0xEF, 0x22,
+0xEF, 0xC4, 0x54, 0xF0, 0x24, 0x03, 0xF5, 0x82,
+0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x8F, 0x75,
+0x8D, 0x76, 0xEF, 0xB1, 0x5A, 0xE0, 0xFD, 0x54,
+0x7F, 0xF5, 0x77, 0xED, 0x54, 0x80, 0xF5, 0x78,
+0xF1, 0x58, 0xF5, 0x7A, 0x75, 0xF0, 0x12, 0xEF,
+0x51, 0x9A, 0xC4, 0x54, 0x03, 0xF5, 0x7B, 0x51,
+0x89, 0x74, 0xFF, 0xF0, 0x51, 0x56, 0xE5, 0x78,
+0x4D, 0xFF, 0x51, 0x7D, 0xEF, 0xF0, 0xE5, 0x75,
+0x12, 0x97, 0xB1, 0xE0, 0x54, 0x03, 0xF5, 0x79,
+0x74, 0x46, 0x25, 0x75, 0xF1, 0x50, 0xE5, 0x79,
+0xF0, 0xE5, 0x77, 0x65, 0x7A, 0x70, 0x21, 0x75,
+0xF0, 0x12, 0xE5, 0x75, 0xB1, 0x3D, 0xC4, 0x13,
+0x54, 0x07, 0x30, 0xE0, 0x0B, 0xE5, 0x78, 0x70,
+0x07, 0xE5, 0x77, 0x44, 0x80, 0xFD, 0x80, 0x49,
+0x51, 0x56, 0x7D, 0x07, 0xAF, 0x75, 0x21, 0x3F,
+0xE5, 0x77, 0xC3, 0x95, 0x7A, 0x50, 0x34, 0xAB,
+0x75, 0xAD, 0x7A, 0xAF, 0x77, 0x12, 0x72, 0x7F,
+0xAD, 0x07, 0xE5, 0x77, 0xC3, 0x94, 0x0C, 0x40,
+0x28, 0x75, 0xF0, 0x12, 0xE5, 0x75, 0xB1, 0x3D,
+0xFE, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x19,
+0xE5, 0x76, 0x60, 0x15, 0xE5, 0x78, 0x70, 0x11,
+0xE5, 0x77, 0x44, 0x80, 0xFD, 0x51, 0x89, 0xEF,
+0xF0, 0x80, 0x06, 0x51, 0x7D, 0xE5, 0x7A, 0xF0,
+0xFD, 0x90, 0x92, 0x80, 0xE5, 0x79, 0xF0, 0xAB,
+0x76, 0xAF, 0x75, 0x02, 0x75, 0x80, 0xE5, 0x77,
+0x25, 0xE0, 0x24, 0x75, 0xF5, 0x82, 0xE4, 0x34,
+0x81, 0xF5, 0x83, 0xE4, 0x93, 0xFE, 0x74, 0x01,
+0x93, 0xFF, 0xE5, 0x75, 0x25, 0xE0, 0x24, 0x75,
+0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x74, 0xC6, 0x25,
+0x75, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
+0x22, 0x74, 0x64, 0x25, 0x75, 0xF5, 0x82, 0xE4,
+0x34, 0x96, 0xF5, 0x83, 0x22, 0xFF, 0x75, 0xF0,
+0x12, 0xED, 0x90, 0x89, 0x52, 0x12, 0x04, 0x6E,
+0xE0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x7F, 0x8F, 0x12, 0x7B, 0x41, 0xEF, 0x20,
+0xE6, 0x02, 0x61, 0xCA, 0x90, 0x00, 0x8C, 0xE0,
+0x90, 0x97, 0x5B, 0xF0, 0x7F, 0x8D, 0x12, 0x7B,
+0x41, 0x90, 0x97, 0x5C, 0xEF, 0xF0, 0x90, 0x00,
+0x8E, 0xE0, 0x90, 0x97, 0x5D, 0xF0, 0x90, 0x97,
+0x5C, 0xE0, 0x24, 0xFC, 0x60, 0x0F, 0x24, 0x03,
+0x60, 0x02, 0x61, 0xBA, 0x90, 0x97, 0x5B, 0xE0,
+0xFF, 0xD1, 0x4C, 0x61, 0xBA, 0x90, 0x97, 0x5B,
+0xE0, 0x24, 0xD6, 0x12, 0xE3, 0xF4, 0xFB, 0xE4,
+0xFD, 0xFF, 0x71, 0xFC, 0x75, 0xF0, 0x12, 0x51,
+0x9A, 0x13, 0x13, 0x54, 0x03, 0xFB, 0x0D, 0xE4,
+0xFF, 0x71, 0xFC, 0x75, 0xF0, 0x12, 0x90, 0x89,
+0x52, 0x12, 0x04, 0x6E, 0x12, 0x97, 0x34, 0xFB,
+0x0D, 0xE4, 0xFF, 0x71, 0xFC, 0x75, 0xF0, 0x12,
+0x51, 0x9A, 0xC4, 0x54, 0x03, 0xFB, 0x0D, 0xE4,
+0xFF, 0x71, 0xFC, 0x75, 0xF0, 0x12, 0xF1, 0x5C,
+0xFB, 0xE4, 0xFD, 0x0F, 0x71, 0xFC, 0xF1, 0x74,
+0x71, 0xF9, 0x75, 0xF0, 0x12, 0xB1, 0x3D, 0xC4,
+0x13, 0x54, 0x01, 0xFB, 0x0D, 0x7F, 0x01, 0x71,
+0xFC, 0x75, 0xF0, 0x12, 0xB1, 0x3D, 0x54, 0x1F,
+0x71, 0xFA, 0xF1, 0x87, 0xE0, 0xFB, 0xE4, 0xFD,
+0x0F, 0x71, 0xFC, 0x75, 0xF0, 0x08, 0xA4, 0x24,
+0x01, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0x71, 0xF7,
+0x75, 0xF0, 0x08, 0xA4, 0x24, 0x02, 0xF5, 0x82,
+0xE4, 0x34, 0x82, 0x71, 0xF7, 0x75, 0xF0, 0x08,
+0xA4, 0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34, 0x82,
+0x71, 0xF7, 0x75, 0xF0, 0x08, 0xA4, 0x24, 0x04,
+0xF5, 0x82, 0xE4, 0x34, 0x82, 0xF5, 0x83, 0xE0,
+0xFB, 0xE4, 0xFD, 0x0F, 0x71, 0xFC, 0x75, 0xF0,
+0x08, 0xA4, 0x24, 0x05, 0xF5, 0x82, 0xE4, 0x34,
+0x82, 0x71, 0xF7, 0x75, 0xF0, 0x08, 0xA4, 0x24,
+0x06, 0xF5, 0x82, 0xE4, 0x34, 0x82, 0x71, 0xF7,
+0x75, 0xF0, 0x08, 0xA4, 0x24, 0x07, 0xF5, 0x82,
+0xE4, 0x34, 0x82, 0xF5, 0x83, 0xE0, 0xFB, 0x0D,
+0x71, 0xCF, 0x7F, 0x8F, 0x12, 0x7B, 0x41, 0xEF,
+0x30, 0xE0, 0x07, 0xE4, 0xFD, 0x7F, 0x8D, 0x12,
+0x7B, 0x2E, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF,
+0x70, 0x04, 0x74, 0xF0, 0x80, 0x16, 0xEF, 0xB4,
+0x01, 0x04, 0x74, 0xF4, 0x80, 0x0E, 0xEF, 0xB4,
+0x02, 0x04, 0x74, 0xF8, 0x80, 0x06, 0xEF, 0xB4,
+0x03, 0x0C, 0x74, 0xFC, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0x02, 0xF5, 0x83, 0xEB, 0xF0, 0x22, 0xF5,
+0x83, 0xE0, 0xFB, 0x0D, 0x71, 0xCF, 0x90, 0x97,
+0x5B, 0xE0, 0x22, 0x90, 0x97, 0x2C, 0x12, 0xA7,
+0x51, 0x54, 0x7F, 0xFD, 0x12, 0x87, 0x6A, 0x54,
+0x1F, 0xB1, 0x38, 0x54, 0xE0, 0x4F, 0x12, 0x87,
+0x69, 0xFE, 0x54, 0x60, 0xC4, 0x13, 0x54, 0x07,
+0x90, 0x97, 0x2F, 0xF0, 0xEE, 0x54, 0x80, 0x12,
+0x97, 0x35, 0xC4, 0x33, 0x54, 0xE0, 0xB1, 0x38,
+0x54, 0xDF, 0x12, 0x87, 0x95, 0xFE, 0x54, 0x03,
+0xFC, 0xEE, 0x54, 0x30, 0xC4, 0x54, 0x03, 0xC4,
+0x54, 0xF0, 0x51, 0x95, 0x54, 0xCF, 0x12, 0x87,
+0x95, 0x54, 0x40, 0xC4, 0x13, 0x13, 0xF1, 0x64,
+0x51, 0x95, 0x54, 0xBF, 0x12, 0x87, 0x95, 0x54,
+0x80, 0x12, 0x97, 0x35, 0xC4, 0x33, 0x33, 0x33,
+0x54, 0x80, 0x51, 0x95, 0x54, 0x7F, 0x12, 0x87,
+0x95, 0xFE, 0x54, 0x08, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x90, 0x97, 0x31, 0xF0, 0xFB, 0xEE, 0x54,
+0x04, 0x13, 0x13, 0x54, 0x3F, 0xA3, 0xF0, 0xEC,
+0x54, 0x03, 0x51, 0x95, 0x54, 0xFC, 0x4F, 0xF0,
+0xEB, 0x70, 0x0D, 0xEC, 0x54, 0x03, 0x25, 0xE0,
+0x25, 0xE0, 0x51, 0x95, 0x54, 0xF3, 0x4F, 0xF0,
+0xB1, 0x45, 0xF5, 0x83, 0xE0, 0x54, 0xFB, 0xF0,
+0xB1, 0x45, 0xF5, 0x83, 0xC0, 0x83, 0xC0, 0x82,
+0xE0, 0xFF, 0x90, 0x97, 0x32, 0xE0, 0x12, 0xEE,
+0x42, 0xD0, 0x82, 0xD0, 0x83, 0xF0, 0x90, 0x93,
+0xED, 0xE0, 0x60, 0x3B, 0x90, 0x97, 0x2C, 0x12,
+0x86, 0x39, 0xE9, 0x24, 0x03, 0xF9, 0xE4, 0x3A,
+0xFA, 0x12, 0x02, 0x06, 0x54, 0x1F, 0x12, 0x02,
+0x4C, 0x90, 0x97, 0x30, 0x74, 0x01, 0xF0, 0x90,
+0x97, 0x30, 0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50,
+0x16, 0xEF, 0xB1, 0x4E, 0x12, 0x86, 0x39, 0x8F,
+0x82, 0x8E, 0x83, 0xE4, 0x12, 0x02, 0x5E, 0x90,
+0x97, 0x30, 0xE0, 0x04, 0xF0, 0x80, 0xE0, 0x90,
+0x93, 0xEB, 0xE0, 0x54, 0x07, 0xFF, 0xBF, 0x05,
+0x0A, 0xEC, 0xB4, 0x01, 0x06, 0x90, 0x93, 0xF0,
+0x74, 0x01, 0xF0, 0xE4, 0x90, 0x97, 0x30, 0xF0,
+0x90, 0x97, 0x30, 0xE0, 0xFC, 0xB1, 0x4E, 0x12,
+0xA5, 0xB5, 0xFF, 0xED, 0xF1, 0x87, 0x12, 0xAE,
+0x4F, 0xEF, 0xF0, 0x90, 0x97, 0x30, 0xE0, 0x04,
+0xF0, 0xE0, 0xB4, 0x04, 0xE3, 0xAF, 0x05, 0x90,
+0x8A, 0xFF, 0x12, 0xC4, 0x37, 0x02, 0x04, 0x7E,
+0xFF, 0x75, 0xF0, 0x12, 0xED, 0x90, 0x89, 0x51,
+0x12, 0x04, 0x6E, 0xE0, 0x22, 0x74, 0xC6, 0x2D,
+0xF5, 0x82, 0xE4, 0x34, 0x8D, 0x22, 0x24, 0x03,
+0xFF, 0xE4, 0x33, 0xFE, 0x90, 0x97, 0x2C, 0x22,
+0xE5, 0x67, 0xC4, 0x54, 0xF0, 0x24, 0x00, 0xF5,
+0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0x22, 0x8D,
+0x0E, 0xEF, 0x30, 0xE6, 0x1A, 0xE5, 0x0E, 0xB1,
+0x5A, 0xE0, 0xFD, 0xE5, 0x0E, 0x12, 0x97, 0xB1,
+0xD1, 0x44, 0xE4, 0xFB, 0xAF, 0x0E, 0x12, 0x75,
+0x80, 0xD1, 0x38, 0xE4, 0xF0, 0x80, 0x4E, 0xD1,
+0x38, 0xE0, 0x04, 0xF0, 0xD1, 0x38, 0xE0, 0x64,
+0x02, 0x70, 0x15, 0x74, 0x64, 0x25, 0x0E, 0x51,
+0x8D, 0xE0, 0xFD, 0xF4, 0x60, 0x02, 0x80, 0x27,
+0xE5, 0x0E, 0xB1, 0x5A, 0xE0, 0xFD, 0x80, 0x1F,
+0xD1, 0x38, 0xE0, 0xD3, 0x94, 0x03, 0x40, 0x11,
+0x90, 0x8A, 0xB3, 0x12, 0x90, 0x4B, 0xAF, 0x0E,
+0x12, 0x04, 0x7E, 0xD1, 0x38, 0xE4, 0xF0, 0x80,
+0x14, 0xE5, 0x0E, 0xB1, 0x5A, 0xE0, 0xFD, 0xE5,
+0x0E, 0x12, 0x97, 0xB1, 0xD1, 0x44, 0x7B, 0x01,
+0xAF, 0x0E, 0x12, 0x75, 0x80, 0xE5, 0x0E, 0xB1,
+0x5A, 0xE0, 0xFD, 0x90, 0x96, 0x7C, 0x74, 0x05,
+0xF0, 0xE4, 0xFB, 0xAF, 0x0E, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0x7F, 0xED,
+0xF0, 0xA3, 0xEF, 0xF0, 0xA3, 0xEB, 0xF0, 0x90,
+0x96, 0x7C, 0xE0, 0x90, 0x96, 0x82, 0xF0, 0xE4,
+0xA3, 0xF0, 0xEF, 0xF1, 0x6C, 0x34, 0x8D, 0xF5,
+0x83, 0xA3, 0xE0, 0x90, 0x96, 0x84, 0xF0, 0x74,
+0x46, 0x2F, 0xF1, 0x50, 0xE0, 0x90, 0x96, 0x85,
+0xF0, 0x90, 0x96, 0x7D, 0x74, 0x0C, 0xF0, 0x90,
+0x96, 0x9F, 0x74, 0x07, 0xF0, 0x7B, 0x01, 0x7A,
+0x96, 0x79, 0x7D, 0x12, 0x90, 0x39, 0x7F, 0x04,
+0x12, 0x04, 0x7E, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0x74, 0xB6, 0x25, 0x0E, 0xF5, 0x82, 0xE4, 0x34,
+0x8E, 0xF5, 0x83, 0x22, 0xE0, 0x54, 0x03, 0x90,
+0x92, 0x80, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x66, 0xEF, 0xF0,
+0x90, 0x00, 0x8F, 0xE0, 0x30, 0xE6, 0x3B, 0x90,
+0x00, 0x8D, 0xE0, 0x64, 0x01, 0x70, 0x33, 0x90,
+0x97, 0x67, 0xF0, 0x90, 0x97, 0x67, 0xE0, 0xFD,
+0x90, 0x97, 0x66, 0xE0, 0xB1, 0x5A, 0xE5, 0x82,
+0x2D, 0x12, 0xAE, 0x52, 0xE0, 0xFB, 0xE4, 0xFF,
+0x71, 0xCF, 0x90, 0x97, 0x67, 0xE0, 0x04, 0xF0,
+0xE0, 0xC3, 0x94, 0x10, 0x40, 0xDD, 0x90, 0x00,
+0x8F, 0xE0, 0x30, 0xE0, 0x05, 0x90, 0x00, 0x8D,
+0xE4, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xAA,
+0x07, 0xA9, 0x05, 0xEA, 0xB1, 0x5A, 0xE0, 0xF5,
+0x75, 0x54, 0x7F, 0xF5, 0x77, 0x75, 0xF0, 0x12,
+0xEA, 0xF1, 0x77, 0xE0, 0x90, 0x95, 0xE6, 0xF0,
+0x75, 0xF0, 0x12, 0xEA, 0xF1, 0x5C, 0xFF, 0xEA,
+0x12, 0x97, 0xB1, 0xE0, 0x54, 0x03, 0xF5, 0x76,
+0xE5, 0x77, 0x90, 0x81, 0x9D, 0x93, 0xFD, 0xEA,
+0xF1, 0x6C, 0x34, 0x8D, 0xF5, 0x83, 0xE4, 0xF0,
+0xA3, 0xED, 0xF0, 0x75, 0xF0, 0x12, 0xEA, 0x51,
+0x9A, 0xFE, 0xC4, 0x54, 0x03, 0x90, 0x95, 0xE5,
+0xF0, 0x74, 0xC6, 0x2A, 0x51, 0x81, 0xE5, 0x77,
+0xF0, 0x74, 0x46, 0x2A, 0xF1, 0x50, 0xE5, 0x76,
+0xF0, 0xE5, 0x77, 0xD3, 0x9F, 0x40, 0x04, 0x8F,
+0x77, 0x8F, 0x75, 0x89, 0x78, 0xE4, 0xFF, 0xEF,
+0xC3, 0x95, 0x78, 0x50, 0x34, 0xE5, 0x75, 0x30,
+0xE7, 0x09, 0x85, 0x77, 0x75, 0x19, 0xE9, 0x70,
+0x25, 0x80, 0x26, 0x90, 0x95, 0xE6, 0xE0, 0xFD,
+0xE5, 0x77, 0xD3, 0x9D, 0x40, 0x10, 0xAB, 0x02,
+0x90, 0x95, 0xEA, 0xE9, 0xF0, 0xAF, 0x77, 0x12,
+0xDC, 0x8A, 0x8F, 0x75, 0x80, 0x0B, 0x90, 0x95,
+0xE6, 0xE0, 0xF5, 0x75, 0x80, 0x03, 0x0F, 0x80,
+0xC6, 0xAF, 0x02, 0x90, 0x92, 0x80, 0xE5, 0x76,
+0xF0, 0xE4, 0xFB, 0xAD, 0x75, 0x02, 0x75, 0x80,
+0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83, 0x22,
+0x75, 0xF0, 0x12, 0xEF, 0x90, 0x89, 0x4F, 0x12,
+0x04, 0x6E, 0xE0, 0x22, 0x54, 0x01, 0xC4, 0x33,
+0x33, 0x54, 0xC0, 0x22, 0x25, 0xE0, 0x24, 0x75,
+0xF5, 0x82, 0xE4, 0x22, 0x75, 0xF0, 0x12, 0x90,
+0x89, 0x50, 0x02, 0x04, 0x6E, 0x75, 0xF0, 0x12,
+0xEF, 0x90, 0x89, 0x55, 0x02, 0x04, 0x6E, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x00, 0xF5, 0x82, 0xE4,
+0x34, 0x82, 0xF5, 0x83, 0x22, 0x12, 0x02, 0x06,
+0xFE, 0x12, 0x87, 0x97, 0xFF, 0x74, 0xD6, 0x2E,
+0xF5, 0x82, 0xE4, 0x34, 0x8D, 0x12, 0x87, 0xFA,
+0xFF, 0xF1, 0xD7, 0x12, 0x87, 0xF0, 0xFF, 0x74,
+0x53, 0x2E, 0x12, 0xE4, 0x54, 0xEF, 0xF0, 0xF1,
+0xD7, 0xF5, 0x83, 0xE0, 0x30, 0xE5, 0x17, 0x75,
+0xF0, 0x12, 0xEE, 0x51, 0x9A, 0x13, 0x13, 0x54,
+0x03, 0xFB, 0xAF, 0x06, 0x74, 0xD6, 0x2E, 0x12,
+0xE3, 0xF4, 0xFD, 0x12, 0x6B, 0xFD, 0x22, 0x74,
+0xC6, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0x22,
+0x41, 0xA2, 0x12, 0x04, 0x7E, 0x90, 0x88, 0x9B,
+0xE0, 0x22, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x12, 0x02, 0x06, 0x90,
+0x88, 0x9C, 0xF0, 0x60, 0x35, 0xA3, 0xE0, 0x20,
+0xE0, 0x30, 0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B,
+0xE4, 0xFD, 0x7F, 0x04, 0x12, 0xBF, 0xE2, 0xFF,
+0xC3, 0x13, 0x30, 0xE0, 0x1D, 0xEF, 0x13, 0x13,
+0x13, 0x54, 0x1F, 0x20, 0xE0, 0x14, 0x90, 0x88,
+0x9B, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0,
+0x04, 0x7F, 0x0D, 0x80, 0x02, 0x7F, 0x09, 0x12,
+0x71, 0x9A, 0x22, 0x11, 0x64, 0x90, 0x93, 0x3B,
+0xD1, 0x26, 0x12, 0x87, 0x69, 0x90, 0x93, 0x3C,
+0x12, 0x87, 0x96, 0x90, 0x93, 0x3D, 0xF0, 0x12,
+0xEE, 0x0D, 0x90, 0x93, 0x3B, 0xE0, 0x54, 0x01,
+0xFF, 0x02, 0x9F, 0x3F, 0x12, 0x02, 0x06, 0xFF,
+0x54, 0x01, 0xFE, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x54, 0x12, 0x86,
+0x42, 0x12, 0x87, 0xEB, 0x11, 0x64, 0x90, 0x88,
+0x9D, 0xD1, 0x26, 0xF0, 0xFC, 0x12, 0x02, 0x06,
+0xFD, 0x54, 0x04, 0x13, 0x13, 0x54, 0x3F, 0xFF,
+0x90, 0x95, 0x38, 0xE0, 0x54, 0xFE, 0x4F, 0xF0,
+0xED, 0x54, 0x08, 0xFF, 0xEC, 0x54, 0xF7, 0x4F,
+0xFF, 0x90, 0x88, 0x9D, 0xF0, 0x12, 0x02, 0x06,
+0xFE, 0x54, 0x10, 0xFD, 0xEF, 0x54, 0xEF, 0x71,
+0x32, 0x54, 0x20, 0xFE, 0xEF, 0x54, 0xDF, 0x4E,
+0xFF, 0xF0, 0x12, 0x02, 0x06, 0xFE, 0x54, 0x40,
+0xFD, 0xEF, 0x54, 0xBF, 0x71, 0x32, 0x54, 0x80,
+0xFE, 0xEF, 0x54, 0x7F, 0x4E, 0x12, 0x87, 0xEA,
+0xE9, 0x24, 0x01, 0xF9, 0xE4, 0x3A, 0x8B, 0x45,
+0x12, 0xA7, 0x5E, 0x7B, 0x01, 0x7A, 0x88, 0x79,
+0x9E, 0x12, 0x69, 0xF5, 0x12, 0x87, 0xEB, 0x12,
+0x87, 0x97, 0xFF, 0x54, 0x03, 0x90, 0x88, 0x9F,
+0xF0, 0xEF, 0x54, 0x04, 0x13, 0x13, 0x54, 0x01,
+0x25, 0xE0, 0x25, 0xE0, 0xFF, 0x90, 0x95, 0x44,
+0xE0, 0x54, 0xFB, 0x4F, 0xFF, 0x12, 0x87, 0x96,
+0xFE, 0x54, 0x08, 0x13, 0x13, 0x13, 0x54, 0x01,
+0xC4, 0x33, 0x33, 0x33, 0x54, 0x80, 0xFD, 0xEF,
+0x54, 0x7F, 0x4D, 0x90, 0x95, 0x44, 0xF0, 0x12,
+0x87, 0xEB, 0x12, 0x02, 0x06, 0x20, 0xE0, 0x02,
+0x41, 0x7A, 0x90, 0x05, 0x54, 0xE0, 0x90, 0x88,
+0xAE, 0xF0, 0xE0, 0xC3, 0x13, 0x90, 0x88, 0xAD,
+0xF0, 0x90, 0x88, 0xA0, 0xE0, 0xC4, 0x54, 0x0F,
+0x30, 0xE0, 0x0F, 0x12, 0x87, 0x6A, 0x90, 0x88,
+0x9E, 0x71, 0x2A, 0x90, 0x88, 0x9F, 0xEE, 0xF0,
+0x80, 0x25, 0x12, 0x87, 0x6A, 0xFF, 0xC3, 0x94,
+0x2A, 0x50, 0x15, 0xEF, 0xC3, 0x94, 0x03, 0x50,
+0x07, 0x90, 0x88, 0x9E, 0x74, 0x03, 0x80, 0x0D,
+0x12, 0x87, 0x6A, 0x90, 0x88, 0x9E, 0x80, 0x05,
+0x90, 0x88, 0x9E, 0x74, 0x2A, 0x71, 0x2A, 0x90,
+0x88, 0xA1, 0x71, 0x4D, 0x30, 0xE0, 0x3D, 0x90,
+0x88, 0x9E, 0xE0, 0x75, 0xF0, 0x03, 0x84, 0x90,
+0x88, 0xA6, 0xF0, 0xE0, 0xC3, 0x13, 0xA3, 0xF0,
+0x90, 0x88, 0x9F, 0xE0, 0x75, 0xF0, 0x03, 0x84,
+0x90, 0x88, 0xA8, 0xF0, 0x90, 0x88, 0x9E, 0xE0,
+0xC3, 0x13, 0x90, 0x88, 0xA9, 0xF0, 0x90, 0x88,
+0x9F, 0xE0, 0xC3, 0x13, 0x90, 0x88, 0xAA, 0xF0,
+0x90, 0x01, 0x3E, 0x74, 0x08, 0xF0, 0xFD, 0x7F,
+0x02, 0x12, 0x7C, 0x05, 0xE4, 0x90, 0x88, 0xDD,
+0xF0, 0x12, 0x97, 0xEA, 0x30, 0xE0, 0x17, 0xF1,
+0xE4, 0x30, 0xE0, 0x0D, 0x90, 0x8A, 0x89, 0x12,
+0x90, 0x4B, 0x7D, 0x04, 0x7F, 0x02, 0x12, 0x04,
+0x7E, 0x71, 0x22, 0x74, 0x11, 0xF0, 0x90, 0x95,
+0x38, 0xE0, 0x30, 0xE0, 0x33, 0x90, 0x95, 0x41,
+0x74, 0x01, 0xF0, 0xE4, 0xA3, 0xF0, 0x90, 0x06,
+0xC7, 0xE0, 0xFE, 0x90, 0x06, 0xC6, 0x71, 0x42,
+0x3E, 0xFE, 0xE4, 0xFD, 0x78, 0x10, 0x12, 0x9D,
+0x3C, 0x90, 0x06, 0xC5, 0xE0, 0xFE, 0x90, 0x06,
+0xC4, 0x71, 0x42, 0x3E, 0xFE, 0xE4, 0xFD, 0x12,
+0x86, 0x20, 0x90, 0x95, 0x3D, 0x12, 0x04, 0x31,
+0x90, 0x95, 0x44, 0xE0, 0x13, 0x13, 0x54, 0x3F,
+0x30, 0xE0, 0x13, 0xA3, 0xE0, 0x20, 0xE0, 0x07,
+0x54, 0x01, 0x44, 0x64, 0xF0, 0x80, 0x07, 0x90,
+0x95, 0x45, 0xE0, 0x54, 0xFE, 0xF0, 0x12, 0xA7,
+0x57, 0x90, 0x88, 0xA5, 0xE0, 0xB4, 0x01, 0x08,
+0x90, 0x88, 0xB0, 0x74, 0x01, 0xF0, 0x80, 0x2B,
+0x90, 0x88, 0xA5, 0xE0, 0xB4, 0x04, 0x08, 0x90,
+0x88, 0xB0, 0x74, 0x04, 0xF0, 0x80, 0x1C, 0x90,
+0x88, 0xA5, 0xE0, 0xB4, 0x06, 0x08, 0x90, 0x88,
+0xB0, 0x74, 0x02, 0xF0, 0x80, 0x0D, 0x90, 0x88,
+0xA5, 0xE0, 0xB4, 0x07, 0x06, 0x90, 0x88, 0xB0,
+0x74, 0x05, 0xF0, 0xE4, 0x90, 0x88, 0xA5, 0xF0,
+0x80, 0x3D, 0x90, 0x8A, 0xF1, 0x12, 0x8A, 0x66,
+0x90, 0x89, 0x04, 0xE0, 0x90, 0x00, 0x40, 0x30,
+0xE0, 0x08, 0xE0, 0x54, 0x0F, 0x44, 0xA0, 0xF0,
+0x80, 0x06, 0xE0, 0x54, 0x0F, 0x44, 0x20, 0xF0,
+0x12, 0x87, 0xEB, 0x12, 0x87, 0xFE, 0x13, 0x13,
+0x13, 0x54, 0x1F, 0x30, 0xE0, 0x04, 0x7F, 0x03,
+0x80, 0x02, 0x7F, 0x01, 0x12, 0x71, 0x9A, 0x12,
+0x8F, 0x5F, 0x71, 0x22, 0x74, 0x43, 0xF0, 0x90,
+0x88, 0xA3, 0xE0, 0x54, 0xDF, 0xF0, 0xE4, 0x90,
+0x88, 0xAF, 0xF0, 0x90, 0x88, 0xA0, 0x12, 0x97,
+0x34, 0x30, 0xE0, 0x09, 0x90, 0x88, 0xD0, 0xE0,
+0x44, 0x02, 0xF0, 0x80, 0x12, 0x90, 0x8A, 0x97,
+0x12, 0x90, 0x4B, 0x7F, 0x01, 0x12, 0x04, 0x7E,
+0x90, 0x88, 0xD0, 0xE0, 0x54, 0xFD, 0xF0, 0x90,
+0x8A, 0xD9, 0x12, 0x90, 0x4B, 0x7F, 0x03, 0x12,
+0x04, 0x7E, 0x12, 0x97, 0x31, 0x30, 0xE0, 0x0E,
+0x90, 0x01, 0x36, 0x74, 0x20, 0xF0, 0xFD, 0x7F,
+0x02, 0x12, 0x7C, 0x74, 0x80, 0x07, 0x7D, 0x20,
+0x7F, 0x02, 0x12, 0x7C, 0x7E, 0xF1, 0xD3, 0x90,
+0x88, 0x9D, 0xE0, 0x20, 0xE0, 0x07, 0x90, 0x88,
+0xA1, 0xE0, 0x54, 0xBF, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x05, 0x00, 0x74, 0x1C, 0xF0,
+0xA3, 0x22, 0xF0, 0x24, 0x0A, 0x90, 0x88, 0xCF,
+0xF0, 0x22, 0x4D, 0xFF, 0x90, 0x88, 0x9D, 0xF0,
+0xEE, 0x22, 0x90, 0x00, 0xAB, 0xE0, 0xFE, 0x90,
+0x00, 0xAA, 0xE0, 0x7C, 0x00, 0x24, 0x00, 0xFF,
+0xEC, 0x22, 0x90, 0x88, 0x2C, 0xE0, 0xC4, 0x13,
+0x13, 0x54, 0x03, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x3F, 0xEF, 0xF0,
+0xA3, 0xED, 0xF0, 0x90, 0x86, 0xB1, 0xE0, 0x04,
+0xF0, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x07,
+0x90, 0x05, 0x10, 0xE4, 0xF0, 0xA3, 0xF0, 0x90,
+0x04, 0x1D, 0xE0, 0x60, 0x45, 0x90, 0x05, 0x22,
+0xE0, 0x90, 0x97, 0x43, 0xF0, 0x7B, 0x26, 0x12,
+0x8A, 0x5D, 0xEF, 0x64, 0x01, 0x70, 0x0B, 0x71,
+0xFC, 0x90, 0x93, 0x58, 0xE0, 0x20, 0xE0, 0x17,
+0x80, 0x11, 0x90, 0x88, 0xA1, 0x71, 0x4D, 0x30,
+0xE0, 0x0D, 0x71, 0xFC, 0x90, 0x93, 0x58, 0xE0,
+0x20, 0xE0, 0x04, 0x91, 0x41, 0xEE, 0xF0, 0x90,
+0x97, 0x43, 0xE0, 0xFD, 0x7B, 0x27, 0xE4, 0xFF,
+0x12, 0x8F, 0x64, 0x91, 0x2F, 0x12, 0x04, 0x7E,
+0x80, 0x12, 0x91, 0x2F, 0x12, 0x04, 0x7E, 0x71,
+0xFC, 0x90, 0x93, 0x58, 0xE0, 0x20, 0xE0, 0x04,
+0x91, 0x41, 0xEE, 0xF0, 0x90, 0x88, 0x9D, 0xE0,
+0x30, 0xE0, 0x1A, 0x90, 0x88, 0xA1, 0x71, 0x4D,
+0x30, 0xE0, 0x12, 0x90, 0x05, 0x22, 0xE0, 0x54,
+0x6F, 0xFF, 0x90, 0x8A, 0xF9, 0x12, 0x97, 0x44,
+0x7D, 0x28, 0x12, 0x04, 0x7E, 0xF1, 0xDB, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x86, 0xB6, 0xE0,
+0xFF, 0x90, 0x97, 0x40, 0xE0, 0xFB, 0x90, 0x92,
+0x13, 0x74, 0x0A, 0xF0, 0x7D, 0x01, 0x12, 0x66,
+0xDB, 0x90, 0x97, 0x41, 0xEE, 0xF0, 0xFC, 0xA3,
+0xEF, 0xF0, 0xFD, 0x90, 0x97, 0x3F, 0xE0, 0xFF,
+0x90, 0x8A, 0x95, 0xE0, 0xFA, 0xA3, 0xE0, 0xFB,
+0xF5, 0x82, 0x8A, 0x83, 0x02, 0x04, 0x7E, 0x90,
+0x97, 0x3F, 0xE0, 0xFF, 0x90, 0x8A, 0xC7, 0xE0,
+0xFC, 0xA3, 0xE0, 0xFD, 0xF5, 0x82, 0x8C, 0x83,
+0x22, 0x90, 0x97, 0x41, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x90, 0x8A, 0x9B, 0xE0, 0xFC, 0xA3, 0xE0,
+0xFD, 0xF5, 0x82, 0x8C, 0x83, 0x12, 0x04, 0x7E,
+0x90, 0x97, 0x41, 0xA3, 0xE0, 0xFF, 0x24, 0x12,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
+0x54, 0x01, 0xFE, 0x90, 0x97, 0x40, 0xE0, 0x25,
+0xE0, 0x25, 0xE0, 0x44, 0x02, 0x4E, 0xFE, 0x74,
+0x12, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x97, 0x49, 0xED, 0xF0, 0xA3, 0xEB,
+0xF0, 0x90, 0x97, 0x48, 0xEF, 0xF0, 0xE4, 0xFD,
+0xFC, 0x12, 0xCA, 0xF3, 0x90, 0x97, 0x4B, 0xF0,
+0x12, 0x7B, 0x07, 0x7C, 0x00, 0xAD, 0x07, 0x90,
+0x97, 0x48, 0xE0, 0x90, 0x04, 0x25, 0xF0, 0x90,
+0x97, 0x49, 0xE0, 0x60, 0x05, 0xB1, 0x41, 0x44,
+0x80, 0xF0, 0xAF, 0x05, 0x74, 0x20, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x54,
+0xC0, 0xF0, 0xB1, 0x41, 0x54, 0xC0, 0xF0, 0x90,
+0x97, 0x4B, 0xE0, 0xFF, 0xAE, 0x05, 0x74, 0x18,
+0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xEF, 0xF0, 0x90, 0x00, 0x8B, 0xE0, 0xD3, 0x94,
+0x03, 0x74, 0x10, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0x74, 0x04, 0xF0, 0xAF, 0x05,
+0x91, 0x77, 0xE0, 0x54, 0x01, 0xFE, 0x90, 0x97,
+0x4A, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0xFB, 0xEE,
+0x44, 0x02, 0x4B, 0x91, 0x76, 0xEE, 0xF0, 0x74,
+0x11, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0x74, 0xFF, 0xF0, 0x74, 0x29, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x54,
+0xF7, 0xF0, 0x74, 0x0D, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x44, 0x80, 0xF0,
+0xAE, 0x04, 0xAF, 0x05, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x74, 0x21, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xE0, 0x22, 0x90, 0x88, 0x9D,
+0xE0, 0x20, 0xE0, 0x02, 0xC1, 0x14, 0x90, 0x8A,
+0xB1, 0x12, 0x8A, 0x66, 0x90, 0x88, 0xB0, 0xE0,
+0xFF, 0xB4, 0x01, 0x02, 0x80, 0x22, 0x90, 0x88,
+0xB0, 0xE0, 0xFF, 0xB4, 0x02, 0x05, 0x90, 0x8A,
+0xC1, 0x80, 0x18, 0x90, 0x88, 0xB0, 0xE0, 0xFF,
+0xB4, 0x03, 0x05, 0x90, 0x8A, 0xBB, 0x80, 0x0B,
+0x90, 0x88, 0xB0, 0xE0, 0xFF, 0xB4, 0x04, 0x08,
+0x90, 0x8A, 0xBD, 0x91, 0x37, 0x02, 0x04, 0x7E,
+0x90, 0x88, 0xB0, 0xE0, 0xFF, 0x64, 0x05, 0x70,
+0x7B, 0x90, 0x95, 0x4C, 0xE0, 0x20, 0xE0, 0x6A,
+0x90, 0x88, 0x9D, 0xE0, 0xFE, 0xC4, 0x54, 0x0F,
+0x20, 0xE0, 0x0A, 0xEE, 0xC4, 0x13, 0x54, 0x07,
+0x30, 0xE0, 0x02, 0x80, 0x55, 0xD1, 0x1D, 0x70,
+0x0E, 0x90, 0x01, 0x34, 0x74, 0x08, 0xF0, 0xFD,
+0xE4, 0xFF, 0x12, 0x7C, 0x74, 0x80, 0x16, 0x90,
+0x95, 0x4D, 0xE0, 0x60, 0x2B, 0xD1, 0x1D, 0xC3,
+0x94, 0x05, 0x50, 0x24, 0xE4, 0xA3, 0xF0, 0x90,
+0x95, 0x4F, 0xE0, 0x04, 0xF0, 0x90, 0x8A, 0xD1,
+0x12, 0x90, 0x4B, 0x7F, 0x05, 0xD1, 0x15, 0xFF,
+0xC3, 0x13, 0xFE, 0xEF, 0x54, 0x01, 0xFF, 0xEE,
+0x04, 0x54, 0x7F, 0x25, 0xE0, 0x4F, 0xF0, 0x22,
+0x7D, 0x08, 0xE4, 0xFF, 0x12, 0x7C, 0x7E, 0x90,
+0x01, 0x34, 0x74, 0x08, 0xF0, 0x90, 0x88, 0xB0,
+0xE0, 0xFF, 0x90, 0x8A, 0xC1, 0x91, 0x37, 0xD1,
+0x15, 0x54, 0x01, 0xF0, 0x22, 0x12, 0x04, 0x7E,
+0x90, 0x95, 0x4C, 0xE0, 0x22, 0x90, 0x95, 0x4C,
+0xE0, 0xC3, 0x13, 0x54, 0x7F, 0x22, 0xE0, 0x54,
+0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x02, 0xFF,
+0xEE, 0x54, 0xFD, 0x4F, 0x22, 0x71, 0x3A, 0x3E,
+0x54, 0x7F, 0x90, 0x95, 0x52, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0x00, 0xAB, 0xE0, 0x44, 0x80, 0xF0,
+0x90, 0x00, 0xAA, 0xE0, 0x44, 0x02, 0xF0, 0x22,
+0xF1, 0xCD, 0x12, 0x7B, 0xDB, 0x90, 0x8A, 0xC5,
+0x12, 0x8A, 0x66, 0x12, 0xCA, 0x5A, 0xD1, 0x35,
+0x12, 0xAF, 0xCA, 0x12, 0xEA, 0x71, 0xD1, 0x8D,
+0x12, 0xE4, 0x5C, 0x90, 0x8A, 0x73, 0x12, 0x8A,
+0x66, 0x90, 0x00, 0x6A, 0xE0, 0x30, 0xE2, 0x14,
+0x90, 0x92, 0x20, 0x74, 0x01, 0xF0, 0xA3, 0x74,
+0xF4, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x68, 0x7E,
+0x01, 0x12, 0x66, 0x33, 0x22, 0x12, 0xEB, 0x62,
+0x02, 0x04, 0x80, 0x71, 0x3A, 0x3E, 0x54, 0x7F,
+0x90, 0x95, 0xEB, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
+0x95, 0x53, 0xE0, 0x54, 0x02, 0xFF, 0x90, 0x95,
+0xEC, 0xE0, 0x54, 0x02, 0xFD, 0xED, 0x6F, 0x30,
+0xE1, 0x04, 0xD1, 0xD8, 0xF1, 0x02, 0x90, 0x95,
+0xEC, 0xE0, 0x20, 0xE1, 0x0B, 0x90, 0x95, 0x53,
+0xE0, 0x20, 0xE1, 0x04, 0xD1, 0xD8, 0xF1, 0x02,
+0x90, 0x95, 0xEB, 0xE0, 0xFF, 0xA3, 0xE0, 0x90,
+0x95, 0x52, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0, 0x22,
+0x90, 0x01, 0x8C, 0xE4, 0xF0, 0xA3, 0xF0, 0xA3,
+0x74, 0x71, 0xF0, 0xA3, 0x74, 0x02, 0xF0, 0x90,
+0x01, 0x95, 0xE0, 0x54, 0xF0, 0x44, 0x07, 0xF0,
+0x90, 0x01, 0x98, 0x74, 0x7F, 0xF0, 0x90, 0x01,
+0x01, 0xE0, 0x54, 0xFB, 0xF0, 0xE0, 0x44, 0x04,
+0xF0, 0x22, 0xE4, 0x90, 0x97, 0x68, 0xF0, 0xA3,
+0xF0, 0x12, 0xE4, 0x91, 0xEF, 0x64, 0x01, 0x60,
+0x3A, 0xC3, 0x90, 0x97, 0x69, 0xE0, 0x94, 0x88,
+0x90, 0x97, 0x68, 0xE0, 0x94, 0x13, 0x40, 0x0F,
+0x90, 0x01, 0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90,
+0x01, 0xC7, 0x74, 0xFD, 0xF0, 0x80, 0x1C, 0x90,
+0x97, 0x68, 0x12, 0xDC, 0x33, 0xD3, 0x90, 0x97,
+0x69, 0xE0, 0x94, 0x32, 0x90, 0x97, 0x68, 0xE0,
+0x94, 0x00, 0x40, 0xC5, 0x90, 0x01, 0xC6, 0xE0,
+0x30, 0xE3, 0xBE, 0x90, 0x01, 0xC7, 0x74, 0xFE,
+0xF0, 0x22, 0x90, 0x00, 0x80, 0xE0, 0x44, 0x80,
+0xF0, 0x12, 0xD3, 0xBD, 0x12, 0xE4, 0x6B, 0x12,
+0x7B, 0x79, 0xD1, 0xD8, 0x12, 0xAF, 0x92, 0x7F,
+0x01, 0x12, 0x84, 0x15, 0x90, 0x93, 0x57, 0x74,
+0x02, 0xF0, 0xFF, 0x12, 0x84, 0x15, 0x90, 0x93,
+0x57, 0xE0, 0x04, 0xF0, 0x12, 0xD1, 0x86, 0xD1,
+0x50, 0x90, 0x00, 0x80, 0xE0, 0x44, 0x40, 0xF0,
+0x75, 0x20, 0xFF, 0x12, 0x7C, 0x97, 0x53, 0xA8,
+0xFE, 0x90, 0x01, 0xA0, 0xE0, 0xB4, 0xFD, 0x05,
+0xE4, 0xFF, 0x12, 0x91, 0x9B, 0xF1, 0x02, 0x90,
+0x00, 0x81, 0xE0, 0x44, 0x04, 0xF0, 0xF1, 0xED,
+0x12, 0xA9, 0x06, 0xD1, 0x48, 0xA3, 0xE0, 0x44,
+0x80, 0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x44, 0x10,
+0xF0, 0x90, 0x07, 0xDB, 0xE0, 0x44, 0x80, 0xF0,
+0x90, 0x06, 0x0D, 0x74, 0xFF, 0xF0, 0xE4, 0xFF,
+0x02, 0x84, 0x9E, 0xC1, 0xD8, 0xE4, 0xFD, 0xFF,
+0x02, 0x6E, 0x71, 0x90, 0x06, 0x04, 0xE0, 0x54,
+0x7F, 0xF0, 0x22, 0x90, 0x04, 0x1F, 0x74, 0x20,
+0xF0, 0x7F, 0x01, 0x22, 0x90, 0x88, 0xA1, 0xE0,
+0xC4, 0x13, 0x54, 0x07, 0x22, 0x90, 0x01, 0xE4,
+0x74, 0x2F, 0xF0, 0xA3, 0xE4, 0xF0, 0x22, 0x90,
+0x93, 0x3F, 0xE0, 0x20, 0xE0, 0x02, 0x01, 0xB9,
+0xE4, 0x90, 0x95, 0x54, 0xF0, 0x51, 0x51, 0x40,
+0x02, 0x01, 0xB9, 0x12, 0xA7, 0x69, 0x80, 0x05,
+0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF,
+0x90, 0x93, 0x40, 0xE0, 0xFD, 0xEF, 0x5D, 0x60,
+0x02, 0x01, 0xB1, 0x12, 0x02, 0x06, 0xFF, 0x30,
+0xE0, 0x1A, 0x90, 0x93, 0x41, 0xE0, 0xFE, 0x90,
+0x95, 0x54, 0xE0, 0xFD, 0x74, 0x01, 0xA8, 0x05,
+0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4E,
+0x90, 0x93, 0x41, 0xF0, 0xEF, 0xC3, 0x13, 0x30,
+0xE0, 0x16, 0x90, 0x93, 0x42, 0xE0, 0xFF, 0x90,
+0x95, 0x54, 0x11, 0xBF, 0x08, 0x80, 0x02, 0xC3,
+0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93, 0x42, 0xF0,
+0x12, 0x87, 0x6A, 0xFF, 0x90, 0x95, 0x54, 0xE0,
+0xFE, 0x24, 0x43, 0xF5, 0x82, 0xE4, 0x34, 0x93,
+0xF5, 0x83, 0xEF, 0x12, 0x87, 0x96, 0xFF, 0x74,
+0x48, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0x12,
+0x87, 0xFA, 0xFF, 0x74, 0x4D, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0x12, 0x87, 0xF0, 0xFF, 0x74,
+0x52, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5,
+0x83, 0xEF, 0xF0, 0x90, 0x93, 0x40, 0xE0, 0xFF,
+0x74, 0x01, 0xA8, 0x06, 0x08, 0x80, 0x02, 0xC3,
+0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93, 0x40, 0xF0,
+0x22, 0x90, 0x95, 0x54, 0xE0, 0x04, 0xF0, 0x01,
+0x05, 0x22, 0xE0, 0xFF, 0x90, 0x97, 0x25, 0xE0,
+0xFE, 0x74, 0x01, 0xA8, 0x06, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x97, 0x20,
+0x12, 0xAF, 0x7F, 0x51, 0xF3, 0x90, 0x97, 0x2B,
+0xF0, 0xE4, 0x90, 0x97, 0x28, 0xF0, 0x90, 0x97,
+0x20, 0x12, 0xB5, 0x8F, 0x90, 0x97, 0x23, 0xF0,
+0xEF, 0x54, 0x07, 0x90, 0x97, 0x25, 0x51, 0x0F,
+0xE0, 0x90, 0x97, 0x26, 0xF0, 0x12, 0xBF, 0x58,
+0x54, 0x7F, 0x90, 0x97, 0x29, 0xF0, 0x90, 0x97,
+0x20, 0xE0, 0x12, 0xBF, 0x74, 0xE0, 0x90, 0x97,
+0x2A, 0xF0, 0xED, 0x54, 0x7F, 0x90, 0x97, 0x24,
+0xF0, 0xEB, 0x70, 0x21, 0x90, 0x89, 0x3D, 0x51,
+0x29, 0xFF, 0x51, 0xE7, 0xFD, 0x90, 0x89, 0x40,
+0x12, 0xA7, 0x1F, 0x2D, 0xFF, 0xE4, 0x35, 0xF0,
+0xC3, 0x13, 0xFE, 0xEF, 0x13, 0xFF, 0x90, 0x97,
+0x20, 0xE0, 0x12, 0xBA, 0x6C, 0x90, 0x97, 0x29,
+0xE0, 0xFF, 0x90, 0x97, 0x24, 0xE0, 0xFE, 0xD3,
+0x9F, 0x40, 0x0C, 0x90, 0x97, 0x21, 0xE0, 0x54,
+0x80, 0xFD, 0xEF, 0x4D, 0xF0, 0x80, 0x0F, 0x90,
+0x97, 0x2A, 0xE0, 0xFF, 0xEE, 0xC3, 0x9F, 0x50,
+0x05, 0x90, 0x97, 0x21, 0xEF, 0xF0, 0x90, 0x97,
+0x21, 0xE0, 0xFE, 0x54, 0x7F, 0x90, 0x97, 0x24,
+0xF0, 0xEE, 0x54, 0x80, 0x90, 0x97, 0x27, 0xF0,
+0x90, 0x97, 0x22, 0xE0, 0x70, 0x21, 0xA3, 0xE0,
+0x51, 0x31, 0xC0, 0x83, 0xC0, 0x82, 0x11, 0xBA,
+0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4,
+0x5F, 0xD0, 0x82, 0xD0, 0x83, 0xF0, 0x90, 0x97,
+0x26, 0xE0, 0x54, 0x7F, 0xF0, 0x80, 0x39, 0x90,
+0x97, 0x23, 0xE0, 0x51, 0x31, 0xC0, 0x83, 0xC0,
+0x82, 0x11, 0xBA, 0x08, 0x80, 0x02, 0xC3, 0x33,
+0xD8, 0xFC, 0x4F, 0xD0, 0x82, 0xD0, 0x83, 0x51,
+0x0F, 0xE0, 0x54, 0x07, 0xFF, 0x90, 0x97, 0x26,
+0xF0, 0x90, 0x89, 0x46, 0x51, 0x29, 0xF5, 0x82,
+0x12, 0xA7, 0x24, 0x33, 0x33, 0x33, 0x54, 0xF8,
+0x4F, 0x90, 0x97, 0x26, 0xF0, 0x44, 0x80, 0xF0,
+0x90, 0x97, 0x21, 0x51, 0x21, 0x12, 0xBD, 0x5A,
+0xEF, 0xF0, 0xEE, 0x70, 0x05, 0x90, 0x01, 0xC8,
+0xEF, 0xF0, 0x90, 0x97, 0x26, 0x51, 0x21, 0x51,
+0x14, 0xEF, 0xF0, 0xEE, 0x12, 0x97, 0xB1, 0xE0,
+0x54, 0xFC, 0xFF, 0x90, 0x97, 0x2B, 0xE0, 0x54,
+0x03, 0x4F, 0xFE, 0x90, 0x97, 0x20, 0xE0, 0xFF,
+0x12, 0x97, 0xB1, 0xEE, 0xF0, 0x7D, 0x01, 0x12,
+0x61, 0xF7, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0,
+0x90, 0x97, 0x20, 0xE0, 0xC4, 0x54, 0xF0, 0x24,
+0x01, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83,
+0x22, 0xE0, 0xFF, 0x90, 0x97, 0x20, 0xE0, 0xFE,
+0x22, 0x12, 0x86, 0x39, 0x90, 0x97, 0x24, 0xE0,
+0x22, 0x24, 0x6F, 0xF5, 0x82, 0xE4, 0x34, 0x8D,
+0xF5, 0x83, 0x22, 0xE6, 0xFD, 0xAF, 0x67, 0xEF,
+0x51, 0x14, 0xE0, 0x54, 0xF8, 0xF5, 0x75, 0xED,
+0x42, 0x75, 0xEF, 0x51, 0x14, 0xE5, 0x75, 0xF0,
+0x22, 0x90, 0x95, 0x54, 0xE0, 0xFF, 0xC3, 0x94,
+0x05, 0x22, 0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00,
 0x90, 0x89, 0x2E, 0x12, 0x86, 0x42, 0x7B, 0xFF,
 0x7A, 0x80, 0x79, 0x80, 0x90, 0x89, 0x31, 0x12,
 0x86, 0x42, 0x7A, 0x80, 0x79, 0xBF, 0x90, 0x89,
@@ -6111,416 +5523,1173 @@ u8 array_mp_8723d_fw_nic[] = {
 0x90, 0x89, 0x3A, 0x12, 0x86, 0x42, 0x7A, 0x81,
 0x79, 0x75, 0x90, 0x89, 0x3D, 0x12, 0x86, 0x42,
 0x7A, 0x81, 0x79, 0x9D, 0x90, 0x89, 0x40, 0x12,
-0x86, 0x42, 0x11, 0x5E, 0x7A, 0x81, 0x79, 0xD9,
+0x86, 0x42, 0x51, 0xDD, 0x7A, 0x81, 0x79, 0xD9,
 0x90, 0x89, 0x49, 0x12, 0x86, 0x42, 0x7A, 0x82,
 0x79, 0x01, 0x90, 0x89, 0x4C, 0x12, 0x86, 0x42,
-0xE4, 0x90, 0x96, 0x5D, 0xF0, 0x90, 0x96, 0x4C,
-0xF0, 0x90, 0x95, 0x4E, 0xF0, 0x11, 0x55, 0x50,
-0x0F, 0x74, 0x6E, 0x2F, 0x11, 0x4D, 0xE4, 0xF0,
-0x90, 0x95, 0x4E, 0xE0, 0x04, 0xF0, 0x80, 0xED,
-0x22, 0x74, 0x6E, 0x25, 0x67, 0xF5, 0x82, 0xE4,
-0x34, 0x96, 0xF5, 0x83, 0x22, 0x90, 0x95, 0x4E,
-0xE0, 0xFF, 0xC3, 0x94, 0x05, 0x22, 0x7A, 0x81,
-0x79, 0xB1, 0x90, 0x89, 0x46, 0x02, 0x86, 0x42,
-0xE4, 0xF5, 0x7A, 0xEF, 0x14, 0xF5, 0x79, 0xED,
-0xFF, 0xE5, 0x79, 0xF5, 0x82, 0x33, 0x95, 0xE0,
-0xF5, 0x83, 0xC3, 0xE5, 0x82, 0x9F, 0x74, 0x80,
-0xF8, 0x65, 0x83, 0x98, 0x40, 0x55, 0xE5, 0x79,
-0x78, 0x03, 0xA2, 0xE7, 0x13, 0xD8, 0xFB, 0xFF,
-0x33, 0x95, 0xE0, 0xFE, 0xEB, 0x12, 0x9F, 0xFA,
-0xE5, 0x82, 0x2F, 0xF5, 0x82, 0xE5, 0x83, 0x3E,
-0xF5, 0x83, 0xE0, 0xF5, 0x82, 0x75, 0x83, 0x00,
-0xE5, 0x79, 0x54, 0x07, 0xFF, 0x12, 0xC2, 0x9F,
-0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
-0xF9, 0xFF, 0xEE, 0x55, 0x83, 0xFE, 0xEF, 0x55,
-0x82, 0x4E, 0x60, 0x13, 0x85, 0x79, 0x7B, 0x05,
-0x7A, 0x90, 0x95, 0xE4, 0xE0, 0x65, 0x7A, 0x60,
-0x0A, 0xE5, 0x7B, 0xD3, 0x9D, 0x40, 0x04, 0x15,
-0x79, 0x80, 0x94, 0xAF, 0x7B, 0x22, 0xAA, 0x07,
-0xA9, 0x05, 0xEA, 0x12, 0x90, 0xD4, 0xE0, 0xF5,
-0x75, 0x54, 0x7F, 0xF5, 0x77, 0x75, 0xF0, 0x12,
-0xEA, 0x31, 0xAC, 0xE0, 0x90, 0x95, 0xE0, 0xF0,
-0x75, 0xF0, 0x12, 0xEA, 0x31, 0xB6, 0xFF, 0xEA,
-0x12, 0x90, 0x3C, 0xE0, 0x54, 0x03, 0xF5, 0x76,
-0xE5, 0x77, 0x90, 0x81, 0x9D, 0x93, 0xFD, 0xEA,
+0xE4, 0x90, 0x96, 0x63, 0xF0, 0x90, 0x96, 0x52,
+0xF0, 0x90, 0x95, 0x54, 0xF0, 0x51, 0x51, 0x50,
+0x0F, 0x74, 0x74, 0x2F, 0x51, 0xD5, 0xE4, 0xF0,
+0x90, 0x95, 0x54, 0xE0, 0x04, 0xF0, 0x80, 0xED,
+0x22, 0x74, 0x74, 0x25, 0x67, 0xF5, 0x82, 0xE4,
+0x34, 0x96, 0xF5, 0x83, 0x22, 0x7A, 0x81, 0x79,
+0xB1, 0x90, 0x89, 0x46, 0x02, 0x86, 0x42, 0x75,
+0xF0, 0x02, 0xA4, 0xF5, 0x82, 0x85, 0xF0, 0x83,
+0x02, 0x03, 0x3E, 0x90, 0x86, 0xAD, 0xA3, 0xE0,
+0x24, 0x7F, 0xF5, 0x82, 0xE4, 0x34, 0x84, 0xF5,
+0x83, 0xE0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x51, 0xF3, 0x90, 0x97, 0x74, 0xF0,
+0x90, 0x88, 0x32, 0x12, 0x97, 0x34, 0x30, 0xE0,
+0x02, 0x61, 0xC9, 0x90, 0x88, 0x31, 0xE0, 0x30,
+0xE0, 0x1F, 0x90, 0x88, 0x53, 0xE0, 0x24, 0x04,
+0x33, 0x33, 0x33, 0x54, 0xF8, 0x90, 0x88, 0x4B,
+0xF0, 0x90, 0x88, 0x53, 0xE0, 0x04, 0x33, 0x33,
+0x33, 0x54, 0xF8, 0x90, 0x88, 0x4A, 0xF0, 0x80,
+0x10, 0x90, 0x88, 0x4B, 0x74, 0x10, 0xF0, 0x90,
+0x88, 0x4A, 0x74, 0x08, 0xF0, 0x74, 0x10, 0x2B,
+0xFB, 0x90, 0x88, 0x4A, 0xE0, 0xFE, 0x90, 0x88,
+0x49, 0xE0, 0xD3, 0x9E, 0x50, 0x0E, 0x90, 0x88,
+0x3E, 0xEB, 0xF0, 0x90, 0x88, 0x4B, 0xE0, 0xC3,
+0x9D, 0x2F, 0x80, 0x11, 0xC3, 0xED, 0x9E, 0x2B,
+0x90, 0x88, 0x3E, 0xF0, 0x90, 0x88, 0x4A, 0xE0,
+0xFF, 0xA3, 0xE0, 0xC3, 0x9F, 0x90, 0x88, 0x4E,
+0xF0, 0x90, 0x88, 0x4B, 0x71, 0xD5, 0x90, 0x88,
+0x4E, 0x71, 0xDE, 0x40, 0x04, 0xEF, 0x24, 0x50,
+0xF0, 0x90, 0x88, 0x4E, 0x71, 0xD5, 0x90, 0x88,
+0x3E, 0x71, 0xDE, 0x40, 0x04, 0xEF, 0x24, 0x50,
+0xF0, 0x90, 0x88, 0x4E, 0x12, 0x9D, 0xD9, 0xFF,
+0x7E, 0x00, 0x90, 0x88, 0x42, 0xEE, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x05, 0x58, 0xF0, 0x90, 0x88,
+0x4E, 0xE0, 0x54, 0x07, 0xFF, 0x90, 0x05, 0xB1,
+0xE0, 0x54, 0xF8, 0x4F, 0xF0, 0x71, 0xE9, 0x80,
+0x07, 0x90, 0x88, 0x33, 0xE0, 0x44, 0x01, 0xF0,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE0, 0xFF, 0x24,
+0x50, 0xFD, 0xE4, 0x33, 0xFC, 0x22, 0xE0, 0xD3,
+0x9D, 0xEC, 0x64, 0x80, 0xF8, 0x74, 0x80, 0x98,
+0x22, 0x90, 0x88, 0x33, 0xE0, 0x54, 0xFE, 0xF0,
+0x22, 0x90, 0x88, 0xB8, 0xE0, 0x30, 0xE0, 0x05,
+0x90, 0x8A, 0x8F, 0x80, 0x03, 0x90, 0x8A, 0x87,
+0x12, 0x8A, 0x66, 0x90, 0x88, 0xE6, 0xE0, 0x30,
+0xE0, 0x04, 0xA3, 0xE0, 0x04, 0xF0, 0x90, 0x88,
+0xE7, 0xE0, 0x64, 0x08, 0x70, 0x20, 0x90, 0x88,
+0xE6, 0xE0, 0x30, 0xE0, 0x14, 0xD1, 0x47, 0xF0,
+0xE4, 0xFD, 0x12, 0x76, 0xF7, 0x90, 0x88, 0xE6,
+0xE0, 0x54, 0xFE, 0xF0, 0xE4, 0xA3, 0xF0, 0x80,
+0x05, 0xE4, 0x90, 0x88, 0xE7, 0xF0, 0x90, 0x88,
+0xA1, 0x12, 0xC3, 0x4D, 0x30, 0xE0, 0x13, 0x90,
+0x88, 0xE8, 0xE0, 0x04, 0xF0, 0xE0, 0xB4, 0x14,
+0x09, 0x90, 0x04, 0x9C, 0xE4, 0xF0, 0x90, 0x88,
+0xE8, 0xF0, 0x90, 0x88, 0x2C, 0xE0, 0x30, 0xE0,
+0x06, 0x90, 0x88, 0x2E, 0x74, 0x01, 0xF0, 0x90,
+0x88, 0x36, 0xE0, 0x60, 0x7D, 0x90, 0x88, 0x4D,
+0xE0, 0x04, 0xF0, 0x90, 0x05, 0x61, 0x12, 0x9D,
+0x34, 0x90, 0x05, 0x60, 0x12, 0x8F, 0xEC, 0x12,
+0x86, 0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x05, 0x62, 0x12, 0x8F, 0xEC,
+0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0,
+0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86, 0x20,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0xA3, 0x12, 0x8F, 0xEC, 0x78, 0x18, 0x12, 0x03,
+0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x86, 0x20, 0x90, 0x88, 0x81, 0x12,
+0x04, 0x31, 0x90, 0x88, 0x32, 0xE0, 0x54, 0x7F,
+0xF0, 0xA3, 0xE0, 0x30, 0xE0, 0x0A, 0xB1, 0x0C,
+0x74, 0x05, 0xF0, 0x12, 0x6E, 0x2F, 0x71, 0xE9,
+0x90, 0x88, 0x32, 0x12, 0x9D, 0xD9, 0x30, 0xE0,
+0x09, 0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4, 0x02,
+0x91, 0xFE, 0x90, 0x8A, 0xE5, 0x12, 0x90, 0x4B,
+0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x93, 0x3B,
+0xE0, 0x30, 0xE0, 0x09, 0x90, 0x01, 0x3B, 0xE0,
+0x30, 0xE4, 0x02, 0x91, 0xFE, 0x22, 0x7D, 0x02,
+0x7F, 0x02, 0x12, 0x7C, 0x7E, 0x7D, 0x01, 0x7F,
+0x02, 0x02, 0x7C, 0x7E, 0x90, 0x88, 0x48, 0xE0,
+0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x88, 0x4F, 0xE0,
+0xFB, 0x90, 0x92, 0x98, 0x22, 0xB1, 0x70, 0x90,
+0x96, 0x1B, 0xEF, 0xF0, 0x20, 0xE0, 0x06, 0x90,
+0x01, 0x3D, 0x74, 0x01, 0xF0, 0x90, 0x96, 0x1B,
+0xE0, 0x90, 0x8A, 0x89, 0x30, 0xE0, 0x13, 0x12,
+0x90, 0x4B, 0x7D, 0x01, 0xE4, 0xFF, 0x12, 0x04,
+0x7E, 0x90, 0x88, 0x33, 0xE0, 0x44, 0x04, 0xF0,
+0x80, 0x06, 0x12, 0x90, 0x4B, 0x12, 0x97, 0x87,
+0x90, 0x96, 0x1B, 0xE0, 0x30, 0xE6, 0x11, 0x90,
+0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x04, 0xE4, 0xF0,
+0x80, 0x06, 0x90, 0x01, 0x2F, 0x74, 0x80, 0xF0,
+0xB1, 0x0C, 0x74, 0x02, 0xF0, 0x02, 0x6E, 0x2F,
+0xE4, 0x90, 0x96, 0x1D, 0xF0, 0xA3, 0xF0, 0x7F,
+0x83, 0x12, 0x7B, 0x41, 0x90, 0x96, 0x1C, 0xEF,
+0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x41, 0xAE, 0x07,
+0x90, 0x96, 0x1C, 0xE0, 0xFF, 0xB5, 0x06, 0x01,
+0x22, 0xC3, 0x90, 0x96, 0x1E, 0xE0, 0x94, 0x64,
+0x90, 0x96, 0x1D, 0xE0, 0x94, 0x00, 0x40, 0x0D,
+0x90, 0x01, 0xC0, 0xE0, 0x44, 0x40, 0xF0, 0x90,
+0x96, 0x1C, 0xE0, 0xFF, 0x22, 0x90, 0x96, 0x1D,
+0xB1, 0xB4, 0x80, 0xC3, 0xE4, 0x75, 0xF0, 0x01,
+0x02, 0x02, 0xE7, 0xE4, 0x90, 0x97, 0x58, 0xF0,
+0xA3, 0xF0, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x97,
+0x5A, 0xF0, 0x7B, 0x47, 0x7D, 0xFF, 0xE4, 0xFF,
+0x12, 0x8F, 0x64, 0x90, 0x05, 0xF8, 0xE0, 0x70,
+0x1B, 0xA3, 0xE0, 0x70, 0x17, 0xA3, 0xE0, 0x70,
+0x13, 0xA3, 0xE0, 0x70, 0x0F, 0x90, 0x97, 0x5A,
+0xE0, 0xFD, 0x7B, 0x48, 0xE4, 0xFF, 0x12, 0x8F,
+0x64, 0x7F, 0x01, 0x22, 0x90, 0x88, 0xA1, 0x12,
+0xC3, 0x4D, 0x30, 0xE0, 0x19, 0xD3, 0x90, 0x97,
+0x59, 0xE0, 0x94, 0x03, 0x90, 0x97, 0x58, 0xE0,
+0x94, 0x00, 0x40, 0x06, 0xD1, 0x3A, 0x7B, 0x5A,
+0x80, 0x17, 0x7F, 0x01, 0x80, 0x18, 0xD3, 0x90,
+0x97, 0x59, 0xE0, 0x94, 0xE8, 0x90, 0x97, 0x58,
+0xE0, 0x94, 0x03, 0x40, 0x07, 0xD1, 0x3A, 0x7B,
+0x5B, 0x02, 0x8F, 0x58, 0x7F, 0x32, 0x7E, 0x00,
+0x12, 0x7C, 0x6A, 0x90, 0x97, 0x58, 0xB1, 0xB4,
+0x80, 0x99, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x20,
+0xF0, 0x90, 0x97, 0x5A, 0xE0, 0xFD, 0x22, 0x90,
+0x88, 0xA0, 0xE0, 0xC4, 0x13, 0x13, 0x54, 0x01,
+0xFF, 0x90, 0x88, 0xE0, 0xE0, 0xFB, 0x90, 0x88,
+0xDF, 0xE0, 0x90, 0x92, 0x90, 0x22, 0xE4, 0x90,
+0x95, 0xAF, 0xF0, 0x12, 0xE6, 0x67, 0xF1, 0xC6,
+0xE4, 0xFF, 0x12, 0xDB, 0xE4, 0x90, 0x93, 0x3F,
+0xE0, 0x20, 0xE0, 0x02, 0xE1, 0x5A, 0x90, 0x00,
+0x02, 0xE0, 0x44, 0x02, 0xF0, 0xE4, 0x90, 0x95,
+0xB0, 0xF0, 0x90, 0x95, 0xB0, 0xE0, 0xFF, 0xC3,
+0x94, 0x05, 0x50, 0x30, 0x12, 0xA7, 0x69, 0x80,
+0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
+0xFF, 0x90, 0x93, 0x42, 0xE0, 0xFD, 0xEF, 0x5D,
+0x60, 0x12, 0x90, 0x95, 0xB0, 0x12, 0xDC, 0x41,
+0x90, 0x95, 0xB0, 0x12, 0xDC, 0x61, 0x44, 0x40,
+0xF0, 0x12, 0xDC, 0x3A, 0x90, 0x95, 0xB0, 0xE0,
+0x04, 0xF0, 0x80, 0xC6, 0x90, 0x07, 0xC7, 0xE4,
+0xF0, 0x90, 0x07, 0xC6, 0xF0, 0x90, 0x07, 0xC5,
+0x74, 0x77, 0xF0, 0x90, 0x07, 0xC4, 0xE4, 0xF0,
+0x90, 0x07, 0xC0, 0x74, 0x38, 0xF0, 0xA3, 0xE4,
+0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0x74, 0xC0,
+0xF0, 0x90, 0x02, 0x26, 0xE0, 0x44, 0x01, 0xF0,
+0xE0, 0x90, 0x95, 0xB1, 0xF0, 0x90, 0x95, 0xB1,
+0xE0, 0x30, 0xE0, 0x18, 0x90, 0x95, 0xAF, 0xE0,
+0x04, 0xF1, 0xBE, 0x90, 0x02, 0x26, 0xE0, 0x90,
+0x95, 0xB1, 0xF0, 0x90, 0x95, 0xAF, 0xE0, 0xD3,
+0x94, 0xFA, 0x40, 0xE1, 0x90, 0x02, 0x03, 0x74,
+0x80, 0xF0, 0x90, 0x04, 0x24, 0xE0, 0x90, 0x95,
+0xB2, 0xF0, 0x90, 0x04, 0x22, 0xE0, 0x44, 0x10,
+0xF0, 0x90, 0x02, 0x00, 0xE0, 0x90, 0x95, 0xB1,
+0xF0, 0x90, 0x02, 0x01, 0xF1, 0x6A, 0x90, 0x02,
+0x02, 0xF1, 0x6A, 0x90, 0x02, 0x14, 0xF1, 0x6A,
+0xE0, 0x04, 0xF0, 0xE0, 0x90, 0x04, 0x24, 0xF0,
+0x90, 0x04, 0x22, 0xE0, 0x54, 0xEF, 0xF0, 0x90,
+0x95, 0xB2, 0xE0, 0x90, 0x04, 0x24, 0xF0, 0x90,
+0xFD, 0x09, 0x74, 0xFF, 0xF0, 0x90, 0xFD, 0x08,
+0xE4, 0xF0, 0xD1, 0x47, 0xF0, 0xE4, 0xFD, 0x12,
+0x76, 0xF7, 0x90, 0x88, 0x32, 0xE0, 0x54, 0xEF,
+0xF0, 0x22, 0xE0, 0xFF, 0x90, 0x95, 0xB1, 0xE0,
+0x2F, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x12, 0xDA, 0xBF, 0xD1, 0x5E, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x88, 0x39, 0xE0,
+0xFF, 0x60, 0x03, 0xB4, 0x08, 0x0E, 0x12, 0xEB,
+0xEB, 0xBF, 0x01, 0x08, 0xF1, 0x73, 0x90, 0x01,
+0xE5, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x88, 0x31,
+0xE0, 0x30, 0xE0, 0x19, 0x90, 0x88, 0x2C, 0xE0,
+0xFF, 0x30, 0xE0, 0x0F, 0xC3, 0x13, 0x30, 0xE0,
+0x08, 0x12, 0xEA, 0x3D, 0xBF, 0x01, 0x06, 0x80,
+0x02, 0x80, 0x00, 0xF1, 0x84, 0x22, 0xF0, 0x7F,
+0x0A, 0x7E, 0x00, 0x02, 0x7C, 0x6A, 0x90, 0x00,
+0x08, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xF1, 0xC6,
+0x12, 0x76, 0x6D, 0x12, 0x75, 0xE0, 0x12, 0xD1,
+0x20, 0x12, 0xD1, 0x5B, 0x75, 0x21, 0x80, 0xE4,
+0xF5, 0x22, 0xF5, 0x23, 0x75, 0x24, 0x80, 0x90,
+0x00, 0x50, 0xE5, 0x21, 0xF0, 0xA3, 0xE5, 0x22,
+0xF0, 0xA3, 0xE5, 0x23, 0xF0, 0xA3, 0xE5, 0x24,
+0xF0, 0x22, 0x12, 0x02, 0x06, 0xFF, 0x90, 0x93,
+0xE6, 0xF0, 0xBF, 0x01, 0x0A, 0x7F, 0x01, 0x12,
+0x91, 0x9B, 0xE4, 0x90, 0x93, 0xE6, 0xF0, 0x22,
+0xE4, 0xFD, 0x02, 0x8F, 0xF5, 0x12, 0xA7, 0x4E,
+0x64, 0x01, 0x60, 0x02, 0x01, 0xA2, 0xEF, 0x24,
+0x39, 0x60, 0x12, 0x14, 0x60, 0x19, 0x24, 0x02,
+0x70, 0x1F, 0xE4, 0x90, 0x95, 0x5A, 0xF0, 0xA3,
+0x74, 0x06, 0xF0, 0x80, 0x14, 0x90, 0x95, 0x5A,
+0x74, 0x06, 0xF0, 0xA3, 0xF0, 0x80, 0x0A, 0x90,
+0x95, 0x5A, 0x74, 0x0C, 0xF0, 0xA3, 0x74, 0x04,
+0xF0, 0x11, 0xB6, 0xF0, 0x11, 0xA3, 0x40, 0x1C,
+0x90, 0x95, 0x58, 0xE0, 0x12, 0xAF, 0x88, 0x7A,
+0x95, 0x79, 0x57, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
+0x07, 0x90, 0x95, 0x57, 0xE0, 0xF4, 0x70, 0x3A,
+0x11, 0xAB, 0x80, 0xE0, 0x11, 0xB6, 0xF0, 0x11,
+0xA3, 0x40, 0x2F, 0x90, 0x95, 0x58, 0xE0, 0xFD,
+0x7C, 0x00, 0x24, 0xA8, 0xFF, 0xEC, 0x34, 0x01,
+0xFE, 0xED, 0x24, 0x01, 0xFD, 0xEC, 0x33, 0xFC,
+0x90, 0x95, 0x5A, 0xE0, 0xFB, 0xC3, 0xED, 0x9B,
+0xFD, 0xEC, 0x94, 0x00, 0xFC, 0x12, 0x87, 0xEB,
+0x12, 0xA6, 0xEB, 0xFD, 0x11, 0xC6, 0x11, 0xAB,
+0x80, 0xCD, 0x22, 0x90, 0x95, 0x59, 0xE0, 0xD3,
+0x94, 0x00, 0x22, 0x90, 0x95, 0x58, 0xE0, 0x04,
+0xF0, 0xA3, 0xE0, 0x14, 0xF0, 0x22, 0x90, 0x95,
+0x5A, 0xE0, 0x90, 0x95, 0x58, 0xF0, 0x90, 0x95,
+0x5B, 0xE0, 0x90, 0x95, 0x59, 0x22, 0xE4, 0x90,
+0x95, 0x5C, 0xF0, 0x90, 0x00, 0x37, 0xE0, 0x44,
+0x80, 0xF0, 0x90, 0x00, 0xCF, 0x74, 0x69, 0xF0,
+0xEF, 0x90, 0x00, 0x31, 0xF0, 0xEE, 0x54, 0x03,
+0xFF, 0xA3, 0xE0, 0x54, 0xFC, 0x4F, 0xF0, 0x90,
+0x00, 0x30, 0xED, 0xF0, 0x90, 0x00, 0x33, 0xE0,
+0x44, 0x80, 0xF0, 0x90, 0x00, 0x33, 0xE0, 0x30,
+0xE7, 0x09, 0x31, 0x18, 0x50, 0x05, 0xE0, 0x04,
+0xF0, 0x80, 0xF0, 0x90, 0x00, 0xCF, 0xE4, 0xF0,
+0x90, 0x00, 0x37, 0xE0, 0x54, 0x7F, 0xF0, 0x31,
+0x18, 0x7F, 0x00, 0x50, 0x02, 0x7F, 0x01, 0x22,
+0x90, 0x95, 0x5C, 0xE0, 0xC3, 0x94, 0x64, 0x22,
+0x75, 0x29, 0x12, 0xE4, 0xF5, 0x2A, 0x75, 0x2B,
+0x07, 0x75, 0x2C, 0x32, 0xF5, 0x31, 0x75, 0x32,
+0xC1, 0x75, 0x33, 0x0C, 0xF5, 0x34, 0x90, 0x01,
+0x30, 0xE5, 0x29, 0xF0, 0xA3, 0xE5, 0x2A, 0xF0,
+0xA3, 0xE5, 0x2B, 0xF0, 0xA3, 0xE5, 0x2C, 0xF0,
+0x90, 0x01, 0x20, 0xE5, 0x31, 0xF0, 0xA3, 0xE5,
+0x32, 0xF0, 0xA3, 0xE5, 0x33, 0xF0, 0xA3, 0xE5,
+0x34, 0xF0, 0x22, 0x75, 0x39, 0x07, 0x43, 0x39,
+0x10, 0x75, 0x3A, 0x01, 0x43, 0x3A, 0x08, 0x75,
+0x3B, 0x03, 0x75, 0x3C, 0x62, 0x43, 0x3C, 0x80,
+0x43, 0x3B, 0x04, 0x90, 0x01, 0x38, 0xE5, 0x39,
+0xF0, 0xA3, 0xE5, 0x3A, 0xF0, 0xA3, 0xE5, 0x3B,
+0xF0, 0xA3, 0xE5, 0x3C, 0xF0, 0x22, 0x12, 0x7B,
+0x1B, 0x90, 0x86, 0xB3, 0xEF, 0xF0, 0x12, 0xCF,
+0xCE, 0x90, 0x01, 0x64, 0x74, 0x01, 0xF0, 0x90,
+0x04, 0x23, 0xE0, 0x44, 0x80, 0xF0, 0x02, 0x67,
+0xD2, 0x7D, 0x02, 0x90, 0x01, 0xC4, 0x74, 0xA1,
+0xF0, 0x74, 0xD1, 0xA3, 0xF0, 0x90, 0x93, 0x57,
+0xE0, 0xFF, 0xED, 0xC3, 0x9F, 0x50, 0x18, 0xED,
+0x25, 0xE0, 0x24, 0x81, 0xF8, 0xE6, 0x30, 0xE4,
+0x0B, 0x90, 0x01, 0xB8, 0x74, 0x08, 0xF0, 0xA3,
+0xF0, 0x7F, 0x00, 0x22, 0x0D, 0x80, 0xDE, 0x74,
+0xA1, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xD1,
+0xA3, 0xF0, 0x7F, 0x01, 0x22, 0xE4, 0x90, 0x95,
+0xAC, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x95,
+0xAC, 0xE0, 0x64, 0x01, 0xF0, 0x90, 0x93, 0xF0,
+0xE0, 0x70, 0x18, 0x90, 0x93, 0xED, 0xE0, 0x70,
+0x12, 0xA3, 0xE0, 0x70, 0x0E, 0x90, 0x95, 0xAC,
+0xE0, 0x24, 0xDD, 0x90, 0x01, 0xC4, 0xF0, 0x74,
+0xD1, 0xA3, 0xF0, 0x12, 0x7C, 0x54, 0xBF, 0x01,
+0x03, 0x12, 0x54, 0x9F, 0x90, 0x88, 0x36, 0xE0,
+0x60, 0x0F, 0x90, 0x88, 0x39, 0xE0, 0xFF, 0x90,
+0x88, 0x38, 0xE0, 0x6F, 0x60, 0x03, 0x12, 0xB5,
+0xF6, 0xC2, 0xAF, 0x31, 0xA1, 0xBF, 0x01, 0x03,
+0x12, 0xCF, 0x9D, 0xD2, 0xAF, 0x51, 0x3F, 0x12,
+0xBF, 0xE0, 0x12, 0x83, 0x4D, 0x80, 0xA7, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x93,
+0xED, 0xE0, 0x60, 0x24, 0x7F, 0x54, 0x7E, 0x09,
+0x12, 0x70, 0x70, 0x51, 0xEB, 0x12, 0x04, 0xB8,
+0xEF, 0x44, 0xFE, 0xFF, 0xEE, 0x44, 0x03, 0xFE,
+0xED, 0x44, 0x04, 0xFD, 0xEC, 0x51, 0xEB, 0x51,
+0xF5, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x70, 0xAD,
+0x90, 0x93, 0xE8, 0xE0, 0x70, 0x29, 0x90, 0x07,
+0xCC, 0xE0, 0x30, 0xE0, 0x22, 0xE4, 0xF0, 0x90,
+0x95, 0xB3, 0x74, 0x22, 0xF0, 0x90, 0x95, 0xD5,
+0x74, 0x01, 0xF0, 0x90, 0x95, 0xB5, 0x74, 0x03,
+0xF0, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0xB3, 0x12,
+0x90, 0x39, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x90,
+0x93, 0xF0, 0xE0, 0xFF, 0x70, 0x0A, 0x90, 0x93,
+0xED, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x60, 0x15,
+0x90, 0x00, 0x1F, 0xE0, 0x54, 0xF0, 0xF0, 0x90,
+0x01, 0xC5, 0x74, 0xEA, 0xF0, 0xA3, 0x74, 0xEF,
+0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0xEF, 0x60, 0x06,
+0x90, 0x01, 0xC4, 0x74, 0x07, 0xF0, 0x90, 0x93,
+0xED, 0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4, 0x74,
+0x01, 0xF0, 0x90, 0x93, 0xEE, 0xE0, 0x60, 0x06,
+0x90, 0x01, 0xC4, 0x74, 0x02, 0xF0, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x95, 0xAF, 0x12, 0x04,
+0x31, 0x90, 0x95, 0xAF, 0x22, 0x12, 0x04, 0xB8,
+0x90, 0x92, 0x18, 0x02, 0x04, 0x31, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x71, 0x3A, 0x90,
+0x97, 0x4C, 0x12, 0x04, 0x31, 0x90, 0x97, 0x4C,
+0x51, 0xF5, 0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70,
+0xAD, 0x90, 0x01, 0x01, 0xE0, 0x44, 0x02, 0xF0,
+0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x90, 0x06,
+0xB7, 0x74, 0x09, 0xF0, 0x90, 0x06, 0xB4, 0x74,
+0x86, 0xF0, 0x12, 0xB6, 0xC7, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70,
+0x70, 0xED, 0x44, 0x80, 0xFD, 0xEC, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x71, 0x3A,
+0x90, 0x97, 0x50, 0x12, 0x04, 0x31, 0x90, 0x97,
+0x50, 0x51, 0xF5, 0x7F, 0x30, 0x7E, 0x08, 0x12,
+0x70, 0xAD, 0x12, 0x8A, 0x63, 0x90, 0x06, 0xB7,
+0x74, 0x11, 0xF0, 0x7F, 0x03, 0x7E, 0x00, 0x12,
+0x7C, 0x6A, 0x90, 0x06, 0xB4, 0xE0, 0x54, 0x0F,
+0x70, 0xF1, 0x90, 0x07, 0xD5, 0xE0, 0x44, 0x80,
+0xF0, 0x7F, 0x0A, 0x80, 0x09, 0x90, 0x06, 0x62,
+0xE0, 0x30, 0xE0, 0x09, 0x7F, 0x01, 0x7E, 0x00,
+0x12, 0x7C, 0x6A, 0x80, 0xF0, 0x71, 0xB5, 0x90,
+0x01, 0x00, 0x74, 0x3F, 0xF0, 0xA3, 0xE0, 0x54,
+0xFD, 0xF0, 0x90, 0x05, 0x53, 0xE0, 0x44, 0x20,
+0xF0, 0x90, 0x07, 0xD5, 0xE0, 0x54, 0x7F, 0xF0,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x00, 0x02,
+0xE0, 0x54, 0xFE, 0xF0, 0x22, 0x90, 0x8A, 0x79,
+0x74, 0x87, 0xF0, 0xA3, 0x74, 0x03, 0xF0, 0x90,
+0x8A, 0xE5, 0x74, 0xD4, 0xF0, 0xA3, 0x74, 0xF4,
+0xF0, 0x90, 0x8B, 0x03, 0x74, 0x88, 0xF0, 0xA3,
+0x74, 0xD6, 0xF0, 0x90, 0x8A, 0xB9, 0x74, 0x8A,
+0xF0, 0xA3, 0x74, 0x70, 0xF0, 0x90, 0x8A, 0xD5,
+0x74, 0xC8, 0xF0, 0xA3, 0x74, 0xC6, 0xF0, 0x90,
+0x8A, 0xFB, 0x74, 0xBD, 0xF0, 0xA3, 0x74, 0x67,
+0xF0, 0x90, 0x8A, 0xA5, 0x74, 0xBC, 0xF0, 0xA3,
+0x74, 0x03, 0xF0, 0x90, 0x8A, 0xB5, 0x74, 0xBF,
+0xF0, 0xA3, 0x74, 0x95, 0xF0, 0x90, 0x8A, 0x75,
+0x74, 0xAE, 0xF0, 0xA3, 0x74, 0x5A, 0xF0, 0x90,
+0x8A, 0xC1, 0x74, 0x90, 0xF0, 0xA3, 0x74, 0x54,
+0xF0, 0x90, 0x8A, 0xC3, 0x74, 0xE6, 0xF0, 0xA3,
+0x74, 0x86, 0xF0, 0x90, 0x8A, 0xF3, 0x74, 0xE6,
+0xF0, 0xA3, 0x74, 0xB7, 0xF0, 0x90, 0x8A, 0x85,
+0x74, 0xE8, 0xF0, 0xA3, 0x74, 0x17, 0xF0, 0x90,
+0x8A, 0x99, 0x74, 0xC5, 0xF0, 0xA3, 0x74, 0x4D,
+0xF0, 0x90, 0x86, 0x04, 0x74, 0xD6, 0xF0, 0xA3,
+0x74, 0x5A, 0xF0, 0x90, 0x8A, 0xA9, 0x74, 0xE6,
+0xF0, 0xA3, 0x74, 0xC3, 0xF0, 0x90, 0x8B, 0x07,
+0x74, 0xE6, 0xF0, 0xA3, 0x74, 0xF2, 0xF0, 0x90,
+0x8A, 0xAD, 0x74, 0xE7, 0xF0, 0xA3, 0x74, 0xA0,
+0xF0, 0x90, 0x8A, 0xBB, 0x74, 0x95, 0xF0, 0xA3,
+0x74, 0x9D, 0xF0, 0x90, 0x86, 0x0C, 0x74, 0xD2,
+0xF0, 0xA3, 0x74, 0xFE, 0xF0, 0x90, 0x8A, 0xEF,
+0x74, 0xD3, 0xF0, 0xA3, 0x74, 0x47, 0xF0, 0x90,
+0x86, 0x00, 0x74, 0xEB, 0xF0, 0xA3, 0x74, 0x85,
+0xF0, 0x90, 0x86, 0x02, 0x74, 0xEC, 0xF0, 0xA3,
+0x74, 0x46, 0xF0, 0x90, 0x8A, 0xFD, 0x74, 0xCD,
+0xF0, 0xA3, 0x74, 0xBB, 0xF0, 0x90, 0x8A, 0xF9,
+0x74, 0xDA, 0xF0, 0xA3, 0x74, 0x7D, 0xF0, 0x90,
+0x8A, 0xDB, 0x74, 0xDC, 0xF0, 0xA3, 0x74, 0xFD,
+0xF0, 0x90, 0x8A, 0xAF, 0x74, 0xC3, 0xF0, 0xA3,
+0x74, 0x54, 0xF0, 0x90, 0x8A, 0xD3, 0x74, 0xCB,
+0xF0, 0xA3, 0x74, 0x03, 0xF0, 0x90, 0x8A, 0xF5,
+0x74, 0xED, 0xF0, 0xA3, 0x74, 0x02, 0xF0, 0x90,
+0x8A, 0xA3, 0x74, 0xB6, 0xF0, 0xA3, 0x74, 0x5A,
+0xF0, 0x90, 0x86, 0x06, 0x74, 0xC4, 0xF0, 0xA3,
+0x74, 0x82, 0xF0, 0x22, 0x8F, 0x0D, 0x7F, 0x02,
+0x12, 0x85, 0x27, 0x90, 0x86, 0xAF, 0xE0, 0x45,
+0x0D, 0xF0, 0x22, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x01, 0xC4, 0x74, 0x03, 0xF0, 0x74, 0xD5,
+0xA3, 0xF0, 0x12, 0x6C, 0xD6, 0xE5, 0x25, 0x30,
+0xE7, 0x03, 0x12, 0xC6, 0x93, 0x74, 0x03, 0x04,
+0x90, 0x01, 0xC4, 0xF0, 0x74, 0xD5, 0xA3, 0xF0,
+0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
+0xD0, 0xE0, 0x32, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
+0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x01, 0xC4, 0x74, 0x5B, 0xF0, 0x74, 0xD5,
+0xA3, 0xF0, 0x12, 0x75, 0x50, 0xE5, 0x3D, 0x30,
+0xE0, 0x03, 0x12, 0xE5, 0x02, 0xE5, 0x3D, 0x30,
+0xE1, 0x03, 0x12, 0xD9, 0x52, 0xE5, 0x3D, 0x30,
+0xE2, 0x03, 0x12, 0xB6, 0x3D, 0xE5, 0x3D, 0x30,
+0xE4, 0x02, 0xD1, 0x3C, 0xE5, 0x3D, 0x30, 0xE5,
+0x02, 0xF1, 0x7E, 0xE5, 0x3E, 0x30, 0xE0, 0x03,
+0x12, 0xCD, 0x1D, 0xE5, 0x3E, 0x30, 0xE3, 0x03,
+0x12, 0xC7, 0xCB, 0xE5, 0x3E, 0x30, 0xE4, 0x03,
+0x12, 0xE5, 0x16, 0xE5, 0x3F, 0x30, 0xE1, 0x03,
+0x12, 0xD9, 0x70, 0xE5, 0x3F, 0x30, 0xE0, 0x02,
+0xF1, 0x0A, 0xE5, 0x3F, 0x30, 0xE4, 0x02, 0xF1,
+0x7F, 0xE5, 0x3F, 0x30, 0xE2, 0x0A, 0x12, 0xD9,
+0xC5, 0x90, 0x07, 0x8F, 0xE0, 0x44, 0x10, 0xF0,
+0xE5, 0x40, 0x30, 0xE1, 0x0B, 0x90, 0x8A, 0xE5,
+0x12, 0x90, 0x4B, 0x7F, 0x04, 0x12, 0x04, 0x7E,
+0xE5, 0x40, 0x30, 0xE4, 0x03, 0x12, 0x9E, 0xD8,
+0xE5, 0x40, 0x30, 0xE5, 0x02, 0xF1, 0x95, 0xE5,
+0x40, 0x30, 0xE6, 0x03, 0x12, 0xDA, 0x0A, 0xE5,
+0x40, 0x30, 0xE7, 0x02, 0xD1, 0xC6, 0x74, 0x5B,
+0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xD5, 0xA3,
+0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0,
+0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0,
+0xF0, 0xD0, 0xE0, 0x32, 0x90, 0x88, 0x9D, 0xE0,
+0x30, 0xE0, 0x0D, 0xD1, 0x51, 0x30, 0xE0, 0x08,
+0x90, 0x8A, 0xBB, 0x12, 0x90, 0x4B, 0xD1, 0xB9,
+0x22, 0x90, 0x88, 0xA1, 0xE0, 0x13, 0x13, 0x54,
+0x3F, 0x22, 0xEF, 0x64, 0x39, 0x70, 0x59, 0x90,
+0x01, 0x63, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x10,
+0xF0, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x48,
+0xD1, 0x51, 0x30, 0xE0, 0x43, 0x90, 0x88, 0xC2,
+0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x38,
+0x90, 0x95, 0x4A, 0xE0, 0x04, 0xF0, 0xF1, 0x80,
+0x30, 0xE0, 0x11, 0xEE, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x30, 0xE0, 0x08, 0xEF, 0x54, 0xEF, 0x90,
+0x88, 0xC2, 0xF0, 0x22, 0x90, 0x88, 0xB0, 0xE0,
+0x70, 0x16, 0xD1, 0xBE, 0x90, 0x88, 0x9D, 0xE0,
+0x30, 0xE0, 0x0D, 0xD1, 0x51, 0x30, 0xE0, 0x08,
+0x90, 0x8A, 0xBB, 0x12, 0x90, 0x4B, 0xD1, 0xB9,
+0x22, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88,
+0xC2, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0x90, 0x88,
+0xB8, 0xE0, 0x30, 0xE0, 0x05, 0x90, 0x8A, 0xEB,
+0x80, 0x27, 0x90, 0x95, 0x44, 0x12, 0x9D, 0xD9,
+0x30, 0xE0, 0x1B, 0x90, 0x88, 0xC2, 0xE0, 0xC4,
+0x54, 0x0F, 0x20, 0xE0, 0x08, 0x90, 0x8A, 0xBB,
+0x12, 0x90, 0x4B, 0xD1, 0xB9, 0x90, 0x95, 0x44,
+0xE0, 0x54, 0xF7, 0xF0, 0x80, 0x06, 0x90, 0x8A,
+0x99, 0x12, 0x8A, 0x66, 0x90, 0x88, 0xF0, 0xE0,
+0x30, 0xE0, 0x06, 0x90, 0x8A, 0xE7, 0x12, 0x8A,
+0x66, 0x22, 0x90, 0x88, 0x2C, 0xE0, 0xFF, 0x30,
+0xE0, 0x4B, 0x90, 0x88, 0x30, 0xE0, 0x7E, 0x00,
+0xB4, 0x02, 0x02, 0x7E, 0x01, 0x90, 0x88, 0x2F,
+0xE0, 0x7D, 0x00, 0xB4, 0x04, 0x02, 0x7D, 0x01,
+0xED, 0x4E, 0x70, 0x31, 0xEF, 0xC3, 0x13, 0x30,
+0xE0, 0x03, 0x02, 0x9E, 0x73, 0xF1, 0x5E, 0x90,
+0x88, 0x30, 0xE0, 0xB4, 0x08, 0x0C, 0x90, 0x8A,
+0xB9, 0x12, 0x90, 0x4B, 0xE4, 0xFD, 0x7F, 0x0C,
+0x80, 0x10, 0x90, 0x88, 0x30, 0xE0, 0x70, 0x0D,
+0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B, 0xE4, 0xFD,
+0x7F, 0x04, 0x12, 0x04, 0x7E, 0x22, 0xF1, 0x8A,
+0x30, 0xE0, 0x12, 0x12, 0x97, 0xD4, 0x60, 0x0D,
+0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B, 0x7D, 0x01,
+0x7F, 0x02, 0x12, 0x04, 0x7E, 0x12, 0x97, 0xD4,
+0x60, 0x03, 0x12, 0xEA, 0x54, 0x22, 0x22, 0x22,
+0x90, 0x95, 0x44, 0xE0, 0xFE, 0x13, 0x13, 0x54,
+0x3F, 0x22, 0x90, 0x88, 0x2C, 0xE0, 0xFF, 0xC4,
+0x13, 0x13, 0x54, 0x03, 0x22, 0x90, 0x95, 0x37,
+0xE0, 0xB4, 0x01, 0x1A, 0xE4, 0xF0, 0x90, 0x01,
+0x5B, 0xF0, 0x90, 0x92, 0x20, 0xF0, 0x90, 0x88,
+0x95, 0xE0, 0xC3, 0x13, 0x54, 0x7F, 0x90, 0x92,
+0x21, 0xF0, 0xE4, 0x12, 0x9E, 0xC3, 0x90, 0x88,
+0x31, 0xF1, 0x8D, 0x30, 0xE0, 0x35, 0xEF, 0x54,
+0xBF, 0x12, 0xDA, 0x6A, 0x30, 0xE0, 0x06, 0xE0,
+0x44, 0x01, 0xF0, 0x80, 0x0A, 0xE0, 0x54, 0xFE,
+0xF0, 0x12, 0xDA, 0x73, 0x74, 0x04, 0xF0, 0x90,
+0x88, 0xA3, 0xE0, 0xFF, 0xC4, 0x13, 0x54, 0x07,
+0x30, 0xE0, 0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x90,
+0x4B, 0x7D, 0x01, 0x7F, 0x0C, 0x02, 0x04, 0x7E,
+0x12, 0xB5, 0xF6, 0x22, 0xC0, 0xE0, 0xC0, 0xF0,
+0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0,
+0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0,
+0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0x90, 0x01, 0xC4, 0x74, 0xF4, 0xF0, 0x74,
+0xD7, 0xA3, 0xF0, 0x90, 0x8A, 0x9D, 0x12, 0x8A,
+0x66, 0x53, 0x91, 0xBF, 0x74, 0xF4, 0x04, 0x90,
+0x01, 0xC4, 0xF0, 0x74, 0xD7, 0xA3, 0xF0, 0xD0,
+0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0,
+0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0,
+0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0,
+0xE0, 0x32, 0xC0, 0xE0, 0xC0, 0x83, 0xC0, 0x82,
+0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x05, 0xC0,
+0x07, 0x7D, 0x4A, 0x90, 0x01, 0xC4, 0xED, 0xF0,
+0x74, 0xD8, 0xFF, 0xA3, 0xF0, 0xED, 0x04, 0x90,
+0x01, 0xC4, 0xF0, 0xA3, 0xEF, 0xF0, 0xD0, 0x07,
+0xD0, 0x05, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83,
+0xD0, 0xE0, 0x32, 0x90, 0x88, 0x2C, 0xE0, 0x30,
+0xE0, 0x05, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x22,
+0x90, 0x88, 0x2C, 0xE0, 0xFF, 0x30, 0xE0, 0x05,
+0x12, 0x97, 0xD4, 0x60, 0x3B, 0x90, 0x88, 0x36,
+0xE0, 0x70, 0x04, 0xEF, 0x30, 0xE0, 0x1D, 0x90,
+0x88, 0x39, 0xE0, 0x64, 0x02, 0x60, 0x29, 0x90,
+0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x0B, 0x90, 0x95,
+0x44, 0xE0, 0xFF, 0x12, 0x97, 0x35, 0x20, 0xE0,
+0x03, 0x12, 0xB1, 0x6D, 0x90, 0x88, 0x9D, 0xE0,
+0x30, 0xE0, 0x0D, 0x90, 0x95, 0x44, 0xE0, 0xFF,
+0x12, 0x97, 0x35, 0x30, 0xE0, 0x02, 0x11, 0xD1,
+0x22, 0x90, 0x06, 0xA9, 0xE0, 0xF5, 0x7C, 0x30,
+0xE6, 0x02, 0x11, 0xDD, 0x22, 0x90, 0x88, 0x9D,
+0xE0, 0x30, 0xE0, 0x28, 0x12, 0x97, 0x31, 0x30,
+0xE0, 0x22, 0x90, 0x88, 0xAF, 0xE0, 0xFF, 0x70,
+0x0A, 0xEF, 0x70, 0x18, 0x90, 0x88, 0xA0, 0xE0,
+0x30, 0xE0, 0x11, 0x90, 0x06, 0x04, 0xE0, 0x44,
+0x40, 0xF0, 0xE0, 0x44, 0x80, 0xF0, 0x90, 0x8A,
+0xE1, 0x12, 0x8A, 0x66, 0x22, 0x90, 0x88, 0x9D,
+0xE0, 0x30, 0xE0, 0x0D, 0x90, 0x95, 0x44, 0xE0,
+0xFF, 0x12, 0x97, 0x35, 0x30, 0xE0, 0x02, 0x80,
+0xBC, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xBF, 0x01,
+0x18, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x12, 0x12,
+0xB0, 0x94, 0x64, 0x02, 0x60, 0x08, 0x90, 0x8A,
+0xE1, 0x31, 0x42, 0x02, 0x04, 0x7A, 0x12, 0x73,
+0x8F, 0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xAA, 0x06,
+0xF9, 0x22, 0x90, 0x8A, 0xDF, 0x31, 0x42, 0x02,
+0x04, 0x7A, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x15,
+0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x0B, 0x90,
+0x95, 0x44, 0xE0, 0xFF, 0x12, 0x97, 0x35, 0x20,
+0xE0, 0x03, 0x12, 0xB5, 0x2A, 0x02, 0x98, 0x32,
+0x90, 0x88, 0x2C, 0xE0, 0xFF, 0x30, 0xE0, 0x4C,
+0x90, 0x88, 0x30, 0xE0, 0x7E, 0x00, 0xB4, 0x02,
+0x02, 0x7E, 0x01, 0x90, 0x88, 0x2F, 0xE0, 0x7D,
+0x00, 0xB4, 0x04, 0x02, 0x7D, 0x01, 0xED, 0x4E,
+0x70, 0x32, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x03,
+0x02, 0x9E, 0x73, 0x12, 0xB5, 0x97, 0x90, 0x88,
+0x30, 0xE0, 0xB4, 0x0C, 0x0C, 0x90, 0x8A, 0xB9,
+0x12, 0x90, 0x4B, 0xE4, 0xFD, 0x7F, 0x08, 0x80,
+0x10, 0x90, 0x88, 0x30, 0xE0, 0xB4, 0x04, 0x0C,
+0x90, 0x8A, 0xB9, 0x12, 0x90, 0x4B, 0xE4, 0xFD,
+0xFF, 0x12, 0x04, 0x7E, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88, 0xF0, 0xE0,
+0x30, 0xE0, 0x32, 0x90, 0x88, 0xF7, 0xE0, 0xB4,
+0x01, 0x1B, 0xA3, 0xE0, 0xB4, 0x01, 0x26, 0x74,
+0x02, 0xF0, 0x90, 0x88, 0xFE, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x90, 0x8A, 0x7F, 0x12, 0xC4, 0x37,
+0x12, 0x04, 0x7E, 0x80, 0x10, 0x90, 0x88, 0xF7,
+0xE0, 0xB4, 0x02, 0x09, 0x74, 0x03, 0xF0, 0x90,
+0x8A, 0xE7, 0x12, 0x8A, 0x66, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x88, 0x31, 0xE0, 0xFF, 0x12,
+0x97, 0x35, 0x30, 0xE0, 0x1F, 0xEF, 0x54, 0x7F,
+0x51, 0x6A, 0x30, 0xE1, 0x06, 0xE0, 0x44, 0x02,
+0xF0, 0x80, 0x08, 0xE0, 0x54, 0xFD, 0xF0, 0x51,
+0x73, 0x04, 0xF0, 0x90, 0x88, 0x36, 0xE0, 0x60,
+0x03, 0x12, 0xB5, 0xF6, 0x90, 0x88, 0xA1, 0x12,
+0xD7, 0x8D, 0x30, 0xE0, 0x22, 0x90, 0x88, 0xA4,
+0xE0, 0xFF, 0xC3, 0x13, 0x30, 0xE0, 0x18, 0xEF,
+0x54, 0xFD, 0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x90,
+0x88, 0xA4, 0x30, 0xE1, 0x06, 0xE0, 0x44, 0x04,
+0xF0, 0x80, 0x04, 0xE0, 0x54, 0xFB, 0xF0, 0x90,
+0x04, 0xE0, 0xE0, 0x30, 0xE1, 0x03, 0x12, 0x99,
+0x33, 0x22, 0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x90,
+0x88, 0x32, 0x22, 0x90, 0x01, 0xB9, 0x74, 0x01,
+0xF0, 0x90, 0x01, 0xB8, 0x22, 0x90, 0x97, 0x6E,
+0xED, 0xF0, 0x64, 0x01, 0x60, 0x27, 0xE0, 0xFE,
+0x64, 0x02, 0x60, 0x21, 0xEE, 0x64, 0x29, 0x60,
+0x1C, 0xEE, 0x64, 0x2A, 0x60, 0x17, 0xEE, 0x64,
+0x36, 0x60, 0x12, 0xEE, 0xB4, 0x37, 0x02, 0x80,
+0x0C, 0xAD, 0x07, 0x7F, 0xFF, 0x12, 0xAF, 0xA4,
+0x90, 0x93, 0xF4, 0xE0, 0xFF, 0x90, 0x93, 0xF3,
+0xE0, 0x4F, 0x90, 0x05, 0x22, 0xF0, 0x90, 0x97,
+0x6E, 0xE0, 0x90, 0x93, 0x01, 0xF0, 0x22, 0x75,
+0x66, 0x14, 0x90, 0x88, 0x32, 0xE0, 0x44, 0x10,
+0xF0, 0x12, 0xCE, 0x47, 0xF0, 0x7D, 0x01, 0x12,
+0x76, 0xF7, 0x90, 0x00, 0x06, 0xE0, 0x44, 0x40,
+0xF0, 0x90, 0x88, 0x41, 0xE0, 0x90, 0x00, 0x93,
+0xF0, 0x90, 0x88, 0x37, 0xE0, 0x60, 0x12, 0x90,
+0x01, 0x2F, 0xE0, 0x30, 0xE7, 0x05, 0x74, 0x10,
+0xF0, 0x80, 0x06, 0x90, 0x01, 0x2F, 0x74, 0x90,
+0xF0, 0x90, 0x93, 0x3F, 0xE0, 0x30, 0xE0, 0x60,
+0x90, 0xFD, 0x09, 0xE4, 0xF0, 0x90, 0xFD, 0x08,
+0xF0, 0x90, 0x0E, 0x4B, 0xE0, 0x54, 0xFC, 0xF0,
+0xE4, 0x90, 0x95, 0xAF, 0xF0, 0x90, 0x95, 0xAF,
+0xE0, 0xFF, 0xC3, 0x94, 0x05, 0x50, 0x2D, 0x12,
+0xA7, 0x69, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x41, 0xE0,
+0xFD, 0xEF, 0x5D, 0x60, 0x0F, 0x90, 0x95, 0xAF,
+0x91, 0x41, 0x90, 0x95, 0xAF, 0x91, 0x61, 0x44,
+0x20, 0xF0, 0x91, 0x3A, 0x90, 0x95, 0xAF, 0xE0,
+0x04, 0xF0, 0x80, 0xC9, 0x90, 0x00, 0x92, 0xE0,
+0x54, 0xFE, 0xF0, 0xE0, 0x44, 0x08, 0xF0, 0x90,
+0x00, 0x02, 0xE0, 0x54, 0xFD, 0xF0, 0x80, 0x07,
+0x90, 0x00, 0x92, 0xE0, 0x44, 0x01, 0xF0, 0x90,
+0x00, 0x08, 0xE0, 0x44, 0x10, 0xF0, 0x7F, 0x01,
+0x71, 0xE4, 0x90, 0x00, 0x90, 0xE0, 0x44, 0x01,
+0xF0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x14, 0x7E,
+0x00, 0x02, 0x7C, 0x6A, 0x90, 0x97, 0x61, 0xEF,
+0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x90, 0x01,
+0x09, 0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02, 0x7F,
+0x01, 0x90, 0x97, 0x61, 0xE0, 0x6F, 0x60, 0x32,
+0xC3, 0x90, 0x97, 0x63, 0xE0, 0x94, 0x88, 0x90,
+0x97, 0x62, 0xE0, 0x94, 0x13, 0x40, 0x08, 0x90,
+0x01, 0xC0, 0xE0, 0x44, 0x10, 0xF0, 0x22, 0x90,
+0x97, 0x62, 0x91, 0x33, 0xD3, 0x90, 0x97, 0x63,
+0xE0, 0x94, 0x32, 0x90, 0x97, 0x62, 0xE0, 0x94,
+0x00, 0x40, 0xC3, 0x90, 0x01, 0xC6, 0xE0, 0x30,
+0xE0, 0xBC, 0x22, 0xE4, 0x75, 0xF0, 0x01, 0x12,
+0x02, 0xE7, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C,
+0x6A, 0xE0, 0xFF, 0x24, 0x4D, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB0,
+0xF0, 0x74, 0x52, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB1, 0xF0,
+0x22, 0xE0, 0xFF, 0x24, 0x43, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB2,
+0xF0, 0x74, 0x48, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB3, 0xF0,
+0xE0, 0x22, 0x12, 0x02, 0x06, 0x90, 0x96, 0x52,
+0xF0, 0x22, 0xE4, 0xF5, 0x7A, 0xEF, 0x14, 0xF5,
+0x79, 0xED, 0xFF, 0xE5, 0x79, 0xF5, 0x82, 0x33,
+0x95, 0xE0, 0xF5, 0x83, 0xC3, 0xE5, 0x82, 0x9F,
+0x74, 0x80, 0xF8, 0x65, 0x83, 0x98, 0x40, 0x52,
+0xE5, 0x79, 0x78, 0x03, 0xA2, 0xE7, 0x13, 0xD8,
+0xFB, 0xFF, 0x33, 0x95, 0xE0, 0xFE, 0xEB, 0x12,
+0xBF, 0x87, 0xE5, 0x82, 0x2F, 0xF5, 0x82, 0xE5,
+0x83, 0x3E, 0xF5, 0x83, 0xE0, 0xF5, 0x82, 0x75,
+0x83, 0x00, 0xE5, 0x79, 0x12, 0xA7, 0x66, 0x80,
+0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
+0xFF, 0xEE, 0x55, 0x83, 0xFE, 0xEF, 0x55, 0x82,
+0x4E, 0x60, 0x13, 0x85, 0x79, 0x7B, 0x05, 0x7A,
+0x90, 0x95, 0xEA, 0xE0, 0x65, 0x7A, 0x60, 0x0A,
+0xE5, 0x7B, 0xD3, 0x9D, 0x40, 0x04, 0x15, 0x79,
+0x80, 0x97, 0xAF, 0x7B, 0x22, 0xEF, 0x64, 0x13,
+0x60, 0x04, 0xEF, 0xB4, 0x0B, 0x05, 0x90, 0x88,
+0xE3, 0x80, 0x1F, 0xEF, 0x64, 0x12, 0x60, 0x04,
+0xEF, 0xB4, 0x0A, 0x05, 0x90, 0x88, 0xE4, 0x80,
+0x11, 0xEF, 0x64, 0x11, 0x60, 0x04, 0xEF, 0xB4,
+0x09, 0x05, 0x90, 0x88, 0xE5, 0x80, 0x03, 0x90,
+0x88, 0xE2, 0xE0, 0xF5, 0x0F, 0xAF, 0x0F, 0x22,
+0x90, 0x04, 0x85, 0xE0, 0xF5, 0x70, 0x90, 0x96,
+0x63, 0xE0, 0x04, 0xF0, 0xE4, 0xF5, 0x67, 0x90,
+0x88, 0x2B, 0xE0, 0xFF, 0xE5, 0x67, 0xC3, 0x9F,
+0x40, 0x03, 0x02, 0xE3, 0xAB, 0x12, 0xBD, 0x58,
+0xE0, 0xF5, 0x72, 0x12, 0xED, 0xCD, 0xE0, 0x65,
+0x72, 0x60, 0x15, 0x90, 0x96, 0x7C, 0x74, 0x06,
+0xF0, 0xE4, 0xFB, 0xAD, 0x72, 0xAF, 0x67, 0x12,
+0xBD, 0xE5, 0x12, 0xED, 0xCD, 0xE5, 0x72, 0xF0,
+0x90, 0x04, 0xA0, 0xE0, 0x64, 0x01, 0x70, 0x47,
+0xA3, 0xE0, 0x65, 0x67, 0x70, 0x41, 0xA3, 0xE0,
+0xF5, 0x68, 0xA3, 0xE0, 0x90, 0x95, 0xE2, 0xF0,
+0x12, 0xBD, 0x58, 0xE0, 0x65, 0x68, 0x70, 0x03,
+0x02, 0xE3, 0xA6, 0x12, 0xBD, 0x58, 0xE5, 0x68,
+0xF0, 0x12, 0x97, 0xAF, 0xE0, 0x54, 0xFC, 0xFF,
+0x90, 0x95, 0xE2, 0xE0, 0x54, 0x03, 0x4F, 0xFF,
+0x12, 0x97, 0xAF, 0xEF, 0xF0, 0x90, 0x96, 0x7C,
+0x74, 0x07, 0xF0, 0xE4, 0xFB, 0xAD, 0x68, 0xAF,
+0x67, 0x12, 0xBD, 0xE5, 0x02, 0xE3, 0xA6, 0x75,
+0xF0, 0x12, 0xE5, 0x67, 0x12, 0xBF, 0x81, 0xE0,
+0xFF, 0x90, 0x95, 0xDA, 0xE4, 0xF0, 0xA3, 0xEF,
+0xF0, 0x75, 0xF0, 0x12, 0xE5, 0x67, 0x90, 0x89,
+0x53, 0x12, 0x04, 0x6E, 0xE0, 0xF5, 0x6D, 0xA3,
+0xE0, 0xF5, 0x6E, 0xE5, 0x67, 0x75, 0xF0, 0x12,
+0xA4, 0x24, 0x57, 0xF9, 0x74, 0x89, 0x35, 0xF0,
+0xFA, 0x7B, 0x01, 0x90, 0x95, 0xD7, 0x12, 0x86,
+0x42, 0x12, 0xEE, 0x17, 0xFF, 0x12, 0x03, 0x13,
+0x2F, 0xFF, 0x12, 0xEE, 0x1D, 0x2F, 0xFF, 0x12,
+0xE4, 0x1C, 0x2F, 0xFF, 0x12, 0xE3, 0xFD, 0x2F,
+0xF5, 0x71, 0x12, 0xBD, 0x58, 0xE0, 0xF5, 0x68,
+0x54, 0x80, 0xF5, 0x6A, 0xE5, 0x68, 0x54, 0x7F,
+0xF5, 0x69, 0x75, 0xF0, 0x12, 0xE5, 0x67, 0x12,
+0xB9, 0x0F, 0xE0, 0x64, 0x01, 0x60, 0x02, 0xE1,
+0x89, 0x12, 0xE3, 0xEA, 0x12, 0xEE, 0x17, 0xFF,
+0xAE, 0xF0, 0x12, 0x03, 0x13, 0x2F, 0xFF, 0xE5,
+0xF0, 0x3E, 0xFE, 0x12, 0xEE, 0x1D, 0x2F, 0xFF,
+0xEE, 0x12, 0xE4, 0x19, 0x2F, 0xFF, 0xEE, 0x35,
+0xF0, 0xFE, 0x12, 0xE3, 0xFD, 0x2F, 0xFF, 0xEE,
+0x35, 0xF0, 0x90, 0x95, 0xDC, 0xF0, 0xA3, 0xEF,
+0xF0, 0x12, 0x03, 0x13, 0xFF, 0xC3, 0x90, 0x95,
+0xDD, 0xE0, 0x9F, 0xFE, 0x90, 0x95, 0xDC, 0xE0,
+0x95, 0xF0, 0x90, 0x95, 0xDE, 0xF0, 0xA3, 0xCE,
+0xF0, 0x12, 0xE4, 0x1C, 0xFD, 0xAC, 0xF0, 0x25,
+0xE0, 0xFF, 0xEC, 0x33, 0xFE, 0xEF, 0x2D, 0xFD,
+0xEE, 0x3C, 0xFC, 0x12, 0xEE, 0x1D, 0x25, 0xE0,
+0xFF, 0xE5, 0xF0, 0x33, 0xFE, 0x12, 0xEE, 0x17,
+0x2F, 0xFF, 0xEE, 0x35, 0xF0, 0xCF, 0x2D, 0xFD,
+0xEF, 0x3C, 0xFC, 0x12, 0xE3, 0xEA, 0x12, 0xE3,
+0xFD, 0xAE, 0xF0, 0x78, 0x02, 0xC3, 0x33, 0xCE,
+0x33, 0xCE, 0xD8, 0xF9, 0x2D, 0xFF, 0xEC, 0x3E,
+0x90, 0x95, 0xE0, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
+0x95, 0xDA, 0x12, 0xED, 0x7B, 0x12, 0xED, 0xEF,
+0x12, 0xED, 0x8C, 0x50, 0x08, 0x90, 0x95, 0xDA,
+0x12, 0xED, 0x98, 0x80, 0x04, 0x7E, 0xFF, 0x7F,
+0xFF, 0xE5, 0x67, 0x12, 0xED, 0xEF, 0x12, 0xBA,
+0x75, 0x90, 0x95, 0xDC, 0x12, 0xED, 0x7B, 0x12,
+0xED, 0xF9, 0x12, 0xED, 0x8C, 0x50, 0x08, 0x90,
+0x95, 0xDC, 0x12, 0xED, 0x98, 0x80, 0x04, 0x7E,
+0xFF, 0x7F, 0xFF, 0xE5, 0x67, 0x12, 0xED, 0xF9,
+0x12, 0xBA, 0x75, 0x90, 0x95, 0xE0, 0x12, 0xED,
+0x7B, 0x12, 0xEE, 0x03, 0x12, 0xED, 0x8C, 0x50,
+0x08, 0x90, 0x95, 0xE0, 0x12, 0xED, 0x98, 0x80,
+0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0xE5, 0x67, 0x12,
+0xEE, 0x03, 0x12, 0xBA, 0x75, 0xC3, 0x74, 0xFF,
+0x95, 0x6E, 0xFF, 0x74, 0xFF, 0x95, 0x6D, 0xFE,
+0x12, 0xED, 0xC1, 0x12, 0xED, 0x8C, 0x50, 0x0A,
+0xE5, 0x6E, 0x2D, 0xFF, 0xE5, 0x6D, 0x3C, 0xFE,
+0x80, 0x04, 0x7E, 0xFF, 0x7F, 0xFF, 0x12, 0xED,
+0xC1, 0x12, 0xBA, 0x75, 0x12, 0xEE, 0x4A, 0xFB,
+0xC3, 0x74, 0xFF, 0x9B, 0xFF, 0x74, 0xFF, 0x9E,
+0xFE, 0x74, 0xFF, 0x94, 0x00, 0xFD, 0x74, 0xFF,
+0x94, 0x00, 0xFC, 0x90, 0x8D, 0x71, 0x12, 0xEE,
+0x3B, 0x50, 0x12, 0x12, 0xEE, 0x4A, 0xFF, 0xE4,
+0xFC, 0xFD, 0x90, 0x8D, 0x71, 0x12, 0x86, 0x2D,
+0x12, 0x85, 0xA9, 0x80, 0x06, 0x74, 0xFF, 0xFF,
+0xFE, 0xFD, 0xFC, 0x90, 0x8D, 0x71, 0x12, 0x04,
+0x31, 0xAF, 0x67, 0x12, 0x78, 0x4A, 0xEF, 0x70,
+0x03, 0x02, 0xE3, 0xA6, 0x75, 0xF0, 0x12, 0xE5,
+0x67, 0x90, 0x89, 0x52, 0x12, 0x04, 0x6E, 0x12,
+0x97, 0x34, 0x30, 0xE0, 0x03, 0x02, 0xE3, 0xA6,
+0xE5, 0x67, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x12,
+0xCA, 0x31, 0xE0, 0xFD, 0x7C, 0x00, 0xE5, 0x67,
+0x12, 0xA7, 0x66, 0x80, 0x05, 0xC3, 0x33, 0xCE,
+0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEE, 0x5C, 0xFE,
+0xEF, 0x5D, 0x4E, 0x60, 0x03, 0x02, 0xE3, 0xA6,
+0xE5, 0x6E, 0x45, 0x6D, 0x70, 0x0D, 0x90, 0x95,
+0xDA, 0xE0, 0x70, 0x02, 0xA3, 0xE0, 0x70, 0x03,
+0x02, 0xE3, 0xA6, 0x90, 0x96, 0x51, 0xE0, 0x60,
+0x12, 0x75, 0x73, 0x0A, 0x12, 0xE4, 0x46, 0xE4,
+0x93, 0xC3, 0x13, 0x74, 0x01, 0x93, 0x13, 0xF5,
+0x74, 0x80, 0x0A, 0x7B, 0xFF, 0x12, 0xCA, 0xDD,
+0xE4, 0xF5, 0x73, 0xF5, 0x74, 0x75, 0xF0, 0x12,
+0xE5, 0x67, 0x12, 0xBF, 0x5C, 0xFF, 0xE5, 0x69,
+0xD3, 0x9F, 0x40, 0x08, 0x8F, 0x69, 0xE5, 0x69,
+0x45, 0x6A, 0xF5, 0x68, 0x71, 0xDD, 0xC3, 0x94,
+0x05, 0x40, 0x02, 0x21, 0x9F, 0xE5, 0x69, 0x90,
+0x81, 0x61, 0x93, 0xF5, 0x6F, 0xFD, 0xAF, 0x69,
+0x12, 0x60, 0x6F, 0x8F, 0x6F, 0xE5, 0x6A, 0x60,
+0x04, 0x05, 0x6F, 0x05, 0x6F, 0xE5, 0x69, 0xC3,
+0x94, 0x0C, 0x40, 0x1C, 0x74, 0x53, 0x25, 0x67,
+0x91, 0x54, 0xE0, 0xFF, 0x54, 0x7F, 0xFE, 0xEF,
+0x30, 0xE7, 0x06, 0xE5, 0x6F, 0x2E, 0xFF, 0x80,
+0x05, 0xC3, 0xE5, 0x6F, 0x9E, 0xFF, 0x8F, 0x6F,
+0xE5, 0x6F, 0xD3, 0x94, 0x1A, 0xAF, 0x6F, 0x40,
+0x02, 0x7F, 0x1A, 0x8F, 0x6F, 0xE5, 0x68, 0x90,
+0x81, 0xD9, 0x93, 0xFF, 0xD3, 0x90, 0x95, 0xDB,
+0xE0, 0x9F, 0x90, 0x95, 0xDA, 0xE0, 0x94, 0x00,
+0x40, 0x02, 0x21, 0x57, 0xC3, 0xE5, 0x6E, 0x94,
+0x0A, 0xE5, 0x6D, 0x94, 0x00, 0x50, 0x7A, 0x12,
+0xCA, 0xD1, 0xE0, 0xC3, 0x94, 0x01, 0x40, 0x06,
+0x12, 0xCA, 0xD1, 0xE0, 0x14, 0xF0, 0x71, 0xEA,
+0x71, 0xFD, 0xFF, 0x90, 0x95, 0xDB, 0xE0, 0x2F,
+0xFF, 0x90, 0x95, 0xDA, 0xE0, 0x91, 0x19, 0x2F,
+0xFD, 0xEE, 0x35, 0xF0, 0xFC, 0xE5, 0x6D, 0xC3,
+0x13, 0xFE, 0xE5, 0x6E, 0x13, 0xFF, 0xD3, 0xED,
+0x9F, 0xEC, 0x9E, 0x40, 0x0E, 0xE5, 0x67, 0x94,
+0x05, 0x50, 0x06, 0x12, 0xCA, 0xD1, 0x74, 0x02,
+0xF0, 0x21, 0x57, 0x71, 0xEA, 0x12, 0x03, 0x13,
+0x65, 0x71, 0x70, 0x02, 0xE5, 0xF0, 0x70, 0x25,
+0xE5, 0x67, 0xC3, 0x94, 0x05, 0x50, 0x12, 0x12,
+0xCA, 0xD1, 0xE0, 0xD3, 0x94, 0x00, 0x40, 0x09,
+0x7D, 0x06, 0xAF, 0x67, 0x12, 0xB9, 0x3F, 0x61,
+0xA6, 0xE4, 0xFD, 0xAF, 0x67, 0x12, 0xB9, 0x9E,
+0x12, 0xB9, 0x3B, 0x61, 0x83, 0x91, 0x03, 0x61,
+0x83, 0x12, 0xCA, 0xD1, 0xE4, 0xF0, 0x90, 0x91,
+0x6C, 0x74, 0x02, 0xF0, 0xAB, 0x6F, 0xAD, 0x67,
+0xAF, 0x6E, 0xAE, 0x6D, 0x12, 0x41, 0x9C, 0x8E,
+0x6B, 0x8F, 0x6C, 0x91, 0x46, 0xC3, 0x74, 0x01,
+0x93, 0x95, 0x74, 0xFF, 0xE4, 0x93, 0x94, 0x00,
+0xFE, 0xD3, 0xE5, 0x6C, 0x9F, 0xE5, 0x6B, 0x9E,
+0x40, 0x0D, 0x71, 0xB8, 0xE4, 0xF0, 0x7D, 0x01,
+0xAF, 0x67, 0x12, 0xB9, 0x9E, 0x61, 0x83, 0x91,
+0x11, 0xC3, 0xE5, 0x6C, 0x9F, 0xE5, 0x6B, 0x94,
+0x00, 0x50, 0x0D, 0x71, 0xB8, 0xE4, 0xF0, 0x7D,
+0x01, 0xAF, 0x67, 0x12, 0xBE, 0x9F, 0x61, 0x83,
+0x12, 0xB9, 0x3B, 0x71, 0xB8, 0xE0, 0x04, 0xF0,
+0xE5, 0x69, 0x90, 0x81, 0xED, 0x93, 0x25, 0x73,
+0xFF, 0xE4, 0x33, 0xFE, 0x71, 0xB8, 0xE0, 0xC3,
+0x9F, 0xEE, 0x12, 0xCB, 0xE2, 0x50, 0x02, 0x61,
+0x83, 0x71, 0xB8, 0xE4, 0xF0, 0x91, 0x11, 0x91,
+0x46, 0x74, 0x01, 0x93, 0x2F, 0xFF, 0xE4, 0x93,
+0x34, 0x00, 0xC3, 0x13, 0xFE, 0xEF, 0x13, 0xFF,
+0xE5, 0x67, 0x12, 0xBA, 0x6C, 0x61, 0x83, 0x71,
+0xDD, 0x64, 0x05, 0x60, 0x02, 0x41, 0x5E, 0x90,
+0x04, 0xA0, 0xE0, 0x64, 0x02, 0x70, 0x10, 0x71,
+0xC4, 0xE4, 0xF0, 0x90, 0x04, 0xA1, 0xE0, 0x78,
+0x88, 0xF6, 0x12, 0xCA, 0x3B, 0x61, 0x9F, 0xAD,
+0x69, 0xAF, 0x67, 0x12, 0x72, 0xEE, 0x91, 0x3A,
+0xEF, 0xF0, 0xE5, 0x67, 0x12, 0xCA, 0x14, 0xE0,
+0x54, 0x07, 0x78, 0x88, 0xF6, 0x71, 0xF0, 0xFF,
+0xC3, 0x94, 0x30, 0x40, 0x1C, 0x75, 0xF0, 0x12,
+0xE5, 0x67, 0x12, 0xBA, 0x9A, 0xFE, 0xC4, 0x13,
+0x13, 0x54, 0x03, 0x20, 0xE0, 0x0B, 0x91, 0x3A,
+0xE0, 0x60, 0x06, 0x90, 0x96, 0x51, 0xE0, 0x60,
+0x0A, 0xE4, 0x78, 0x88, 0xF6, 0x71, 0xC4, 0xE4,
+0xF0, 0x80, 0x54, 0x91, 0x2E, 0xE0, 0xFE, 0x24,
+0x05, 0xFD, 0xE4, 0x33, 0xFC, 0xEF, 0x12, 0xCB,
+0xDF, 0x50, 0x1C, 0x71, 0xF0, 0x24, 0x05, 0xFD,
+0xE4, 0x33, 0xFC, 0xEE, 0x12, 0xCB, 0xDF, 0x50,
+0x0E, 0x91, 0x22, 0xE0, 0xB5, 0x69, 0x08, 0x71,
+0xD1, 0xE0, 0xC3, 0x94, 0x0A, 0x40, 0x23, 0x78,
+0x88, 0xE6, 0xFF, 0x70, 0x04, 0x76, 0x01, 0x80,
+0x0C, 0xEF, 0x78, 0x88, 0xB4, 0x01, 0x04, 0x76,
+0x03, 0x80, 0x02, 0x76, 0x05, 0x71, 0xD1, 0xE4,
+0xF0, 0x71, 0xF0, 0xFF, 0x91, 0x2E, 0xEF, 0xF0,
+0x80, 0x05, 0x71, 0xC4, 0xE0, 0x04, 0xF0, 0x91,
+0x22, 0xE5, 0x69, 0xF0, 0x61, 0x7E, 0x71, 0xDD,
+0x64, 0x06, 0x60, 0x02, 0x61, 0x83, 0xF5, 0x6B,
+0xF5, 0x6C, 0xE5, 0x67, 0x12, 0xCA, 0x14, 0xE0,
+0x54, 0x07, 0x78, 0x88, 0xF6, 0xD3, 0xE5, 0x6E,
+0x94, 0xE8, 0xE5, 0x6D, 0x94, 0x03, 0x40, 0x06,
+0x78, 0x86, 0x76, 0x05, 0x80, 0x15, 0xD3, 0xE5,
+0x6E, 0x94, 0xFA, 0xE5, 0x6D, 0x94, 0x00, 0x40,
+0x06, 0x78, 0x86, 0x76, 0x02, 0x80, 0x04, 0xE4,
+0x78, 0x86, 0xF6, 0xE5, 0x6E, 0xAE, 0x6D, 0x78,
+0x86, 0x86, 0x00, 0x08, 0x80, 0x05, 0xCE, 0xC3,
+0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xFF, 0x90, 0x82,
+0x06, 0xE4, 0x91, 0x0A, 0x90, 0x95, 0xE3, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x78, 0x87, 0xF6,
+0x71, 0xEA, 0x78, 0x87, 0xE6, 0xFD, 0x12, 0xCA,
+0xE7, 0xAE, 0xF0, 0x78, 0x86, 0x86, 0x00, 0x08,
+0x80, 0x05, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8,
+0xF9, 0xFF, 0xED, 0x90, 0x82, 0x01, 0x91, 0x0A,
+0xEF, 0x25, 0x6C, 0xF5, 0x6C, 0xEE, 0x35, 0x6B,
+0xF5, 0x6B, 0xC3, 0x90, 0x95, 0xE4, 0xE0, 0x95,
+0x6C, 0x90, 0x95, 0xE3, 0xE0, 0x95, 0x6B, 0x40,
+0x07, 0x78, 0x87, 0x06, 0xE6, 0xB4, 0x05, 0xC0,
+0x78, 0x87, 0xE6, 0xC3, 0x13, 0xF6, 0xFD, 0x08,
+0xE6, 0x24, 0x01, 0xFF, 0xE4, 0x33, 0xA2, 0xE7,
+0x13, 0xEF, 0x13, 0x08, 0xF6, 0xD3, 0x9D, 0x40,
+0x07, 0xE6, 0x79, 0x87, 0x97, 0xF6, 0x80, 0x04,
+0xE4, 0x78, 0x89, 0xF6, 0x71, 0xAC, 0xE0, 0xC3,
+0x13, 0xFF, 0x78, 0x89, 0xE6, 0xC4, 0x33, 0x54,
+0xE0, 0x2F, 0xFF, 0x71, 0xAC, 0xEF, 0xF0, 0x71,
+0xAC, 0xE0, 0xC3, 0x94, 0xC0, 0x40, 0x05, 0x71,
+0xAC, 0x74, 0xC0, 0xF0, 0x71, 0xAC, 0xE0, 0x24,
+0x1F, 0xFF, 0xE4, 0x33, 0xFE, 0xEF, 0x78, 0x06,
+0xCE, 0xA2, 0xE7, 0x13, 0xCE, 0x13, 0xD8, 0xF8,
+0x78, 0x89, 0xF6, 0xE6, 0x25, 0xE0, 0xF6, 0x70,
+0x03, 0xFF, 0x80, 0x05, 0x78, 0x89, 0xE6, 0x14,
+0xFF, 0x78, 0x88, 0xA6, 0x07, 0xD3, 0x90, 0x95,
+0xDB, 0xE0, 0x94, 0x03, 0x90, 0x95, 0xDA, 0xE0,
+0x94, 0x00, 0x40, 0x02, 0xE4, 0xF6, 0x78, 0x88,
+0x12, 0xCA, 0x3B, 0x71, 0xDD, 0xFF, 0xD3, 0x94,
+0x05, 0x50, 0x05, 0xEF, 0x04, 0xFF, 0x80, 0x02,
+0x7F, 0x00, 0x74, 0x76, 0x25, 0x67, 0xF5, 0x82,
+0xE4, 0x34, 0x8E, 0xF5, 0x83, 0xEF, 0xF0, 0xE4,
+0xF5, 0x6B, 0xF5, 0x6C, 0x91, 0x03, 0x05, 0x67,
+0x02, 0xDD, 0x3F, 0x22, 0x74, 0x4F, 0x25, 0x67,
+0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83, 0x22,
+0x74, 0xA6, 0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34,
+0x8D, 0xF5, 0x83, 0x22, 0x74, 0x76, 0x25, 0x67,
+0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83, 0xE4,
+0xF0, 0x74, 0xF6, 0x25, 0x67, 0xF5, 0x82, 0xE4,
+0x34, 0x8D, 0xF5, 0x83, 0x22, 0x74, 0x76, 0x25,
+0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
+0xE0, 0x22, 0x90, 0x95, 0xD7, 0x02, 0x86, 0x39,
+0x74, 0xD6, 0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34,
+0x8D, 0xF5, 0x83, 0xE0, 0x22, 0x90, 0x00, 0x08,
+0x02, 0x03, 0x3E, 0x7D, 0x01, 0xAF, 0x67, 0x02,
+0x61, 0xF7, 0x93, 0xFD, 0x7C, 0x00, 0x02, 0x02,
+0x80, 0xE5, 0x69, 0x90, 0x81, 0x9D, 0x93, 0xFF,
+0x22, 0x35, 0xF0, 0xFE, 0x90, 0x00, 0x06, 0x02,
+0x03, 0x3E, 0x74, 0xA6, 0x25, 0x67, 0xF5, 0x82,
+0xE4, 0x34, 0x8E, 0xF5, 0x83, 0x22, 0x74, 0x5F,
+0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5,
+0x83, 0x22, 0x74, 0xE6, 0x25, 0x67, 0xF5, 0x82,
+0xE4, 0x34, 0x8D, 0xF5, 0x83, 0x22, 0xE5, 0x69,
 0x25, 0xE0, 0x24, 0x75, 0xF5, 0x82, 0xE4, 0x34,
-0x8D, 0xF5, 0x83, 0xE4, 0xF0, 0xA3, 0xED, 0xF0,
-0x75, 0xF0, 0x12, 0xEA, 0x12, 0x9B, 0xEB, 0xFE,
-0xC4, 0x54, 0x03, 0x90, 0x95, 0xDF, 0xF0, 0x74,
-0xC6, 0x2A, 0x31, 0x99, 0xE5, 0x77, 0xF0, 0x74,
-0x46, 0x2A, 0x31, 0xA1, 0xE5, 0x76, 0xF0, 0xE5,
-0x77, 0xD3, 0x9F, 0x40, 0x04, 0x8F, 0x77, 0x8F,
-0x75, 0x89, 0x78, 0xE4, 0xFF, 0xEF, 0xC3, 0x95,
-0x78, 0x50, 0x33, 0xE5, 0x75, 0x30, 0xE7, 0x09,
-0x85, 0x77, 0x75, 0x19, 0xE9, 0x70, 0x24, 0x80,
-0x25, 0x90, 0x95, 0xE0, 0xE0, 0xFD, 0xE5, 0x77,
-0xD3, 0x9D, 0x40, 0x0F, 0xAB, 0x02, 0x90, 0x95,
-0xE4, 0xE9, 0xF0, 0xAF, 0x77, 0x11, 0x68, 0x8F,
-0x75, 0x80, 0x0B, 0x90, 0x95, 0xE0, 0xE0, 0xF5,
-0x75, 0x80, 0x03, 0x0F, 0x80, 0xC7, 0xAF, 0x02,
-0x90, 0x92, 0x80, 0xE5, 0x76, 0xF0, 0xE4, 0xFB,
-0xAD, 0x75, 0x02, 0x75, 0x80, 0x74, 0xC6, 0x25,
-0x75, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
-0x22, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0xF5, 0x83,
-0x22, 0x75, 0xF0, 0x12, 0x90, 0x89, 0x50, 0x02,
-0x04, 0x6E, 0x75, 0xF0, 0x12, 0xEF, 0x90, 0x89,
-0x4F, 0x12, 0x04, 0x6E, 0xE0, 0x22, 0xEF, 0x64,
-0x13, 0x60, 0x04, 0xEF, 0xB4, 0x0B, 0x05, 0x90,
-0x88, 0xE3, 0x80, 0x1F, 0xEF, 0x64, 0x12, 0x60,
-0x04, 0xEF, 0xB4, 0x0A, 0x05, 0x90, 0x88, 0xE4,
-0x80, 0x11, 0xEF, 0x64, 0x11, 0x60, 0x04, 0xEF,
-0xB4, 0x09, 0x05, 0x90, 0x88, 0xE5, 0x80, 0x03,
-0x90, 0x88, 0xE2, 0xE0, 0xF5, 0x0F, 0xAF, 0x0F,
-0x22, 0x90, 0x01, 0x94, 0xE0, 0x44, 0x01, 0xF0,
-0x90, 0x01, 0xC7, 0xE4, 0xF0, 0x22, 0x90, 0x01,
-0x9A, 0xE0, 0x54, 0xC0, 0x44, 0x0B, 0x12, 0xC7,
-0xC4, 0x90, 0x01, 0x98, 0xE0, 0x54, 0xC0, 0x7F,
-0x00, 0xB4, 0x40, 0x02, 0x7F, 0x01, 0x22, 0x90,
-0x01, 0x95, 0xE0, 0x7F, 0x00, 0x30, 0xE4, 0x02,
-0x7F, 0x01, 0x22, 0x90, 0x8A, 0x75, 0x12, 0x88,
-0xCD, 0x90, 0x8A, 0xE5, 0x12, 0x8E, 0x5A, 0x7F,
-0x02, 0x02, 0x04, 0x7E, 0x90, 0x01, 0xCF, 0xE0,
-0x90, 0x95, 0xE7, 0xF0, 0xE0, 0xFF, 0x30, 0xE0,
-0x07, 0x90, 0x01, 0xCF, 0xE0, 0x54, 0xFE, 0xF0,
-0xEF, 0x30, 0xE5, 0x23, 0x90, 0x01, 0xCF, 0xE0,
-0x54, 0xDF, 0xF0, 0x90, 0x01, 0x34, 0x74, 0x20,
-0xF0, 0xE4, 0xF5, 0xA8, 0xF5, 0xE8, 0x12, 0x76,
-0x6D, 0x90, 0x00, 0x03, 0xE0, 0x54, 0xFB, 0xFD,
-0x7F, 0x03, 0x12, 0x7B, 0x2E, 0x80, 0xFE, 0x22,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0xE4, 0xFE, 0xFD, 0xEF, 0xB4, 0x01, 0x0D, 0xEB,
-0xB4, 0x02, 0x03, 0x0D, 0x80, 0x06, 0xEB, 0xB4,
-0x01, 0x02, 0x7D, 0x02, 0xAF, 0x06, 0xEF, 0xC4,
-0x54, 0xF0, 0x4D, 0xFF, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x90, 0x01, 0xC4, 0x74, 0x99, 0xF0, 0x74,
-0xE2, 0xA3, 0xF0, 0x7F, 0x90, 0x12, 0x7B, 0x41,
-0xEF, 0x20, 0xE0, 0xF7, 0x74, 0x99, 0x04, 0x90,
-0x01, 0xC4, 0xF0, 0x74, 0xE2, 0xA3, 0xF0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x51,
-0xE8, 0x90, 0x97, 0x42, 0xF0, 0xED, 0x90, 0x00,
-0x73, 0x70, 0x0D, 0xE0, 0x44, 0x04, 0xF0, 0x90,
-0x00, 0x67, 0xE0, 0x44, 0x80, 0xF0, 0x80, 0x0B,
-0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x00, 0x67, 0xE0,
-0x54, 0x7F, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x90, 0x86, 0xAD, 0xA3, 0xE0, 0x24, 0x7F, 0xF5,
-0x82, 0xE4, 0x34, 0x84, 0xF5, 0x83, 0xE0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x88, 0xB8, 0xE0,
-0x54, 0xFE, 0xF0, 0x54, 0xE1, 0xF0, 0x90, 0x88,
-0xBD, 0xE0, 0xFF, 0x12, 0x71, 0x9A, 0x90, 0x88,
-0x36, 0xE0, 0x70, 0x16, 0x90, 0x93, 0x3B, 0xE0,
-0x20, 0xE0, 0x0F, 0x90, 0x86, 0x0C, 0x12, 0x88,
-0xCD, 0x90, 0x8A, 0xF9, 0x12, 0x8E, 0x5A, 0x12,
-0xAC, 0x6E, 0x22, 0x90, 0x88, 0x9D, 0xE0, 0x30,
-0xE0, 0x64, 0x90, 0x95, 0x38, 0xE0, 0x30, 0xE0,
-0x43, 0x90, 0x95, 0x43, 0xE0, 0xFF, 0x90, 0x95,
-0x42, 0xE0, 0xC3, 0x9F, 0x40, 0x2A, 0x71, 0x9F,
-0x90, 0x06, 0xC4, 0xEF, 0xF0, 0x71, 0x9F, 0x78,
-0x08, 0x12, 0x03, 0xEB, 0x90, 0x06, 0xC5, 0xEF,
-0xF0, 0x71, 0x9F, 0x78, 0x10, 0x12, 0x03, 0xEB,
-0x90, 0x06, 0xC6, 0xEF, 0xF0, 0x71, 0x9F, 0x71,
-0xA5, 0xE4, 0x90, 0x95, 0x42, 0xF0, 0x80, 0x1B,
-0x71, 0xB0, 0x71, 0xA5, 0x90, 0x95, 0x42, 0xE0,
-0x04, 0xF0, 0x80, 0x0F, 0x90, 0x95, 0x41, 0xE0,
-0x60, 0x09, 0x71, 0xB0, 0x71, 0xA5, 0xE4, 0x90,
-0x95, 0x41, 0xF0, 0x90, 0x8A, 0xBB, 0x12, 0x8E,
-0x5A, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x22, 0x90,
-0x95, 0x39, 0x02, 0x04, 0xB8, 0x78, 0x18, 0x12,
-0x03, 0xEB, 0x90, 0x06, 0xC7, 0xEF, 0xF0, 0x22,
-0x90, 0x95, 0x3D, 0x12, 0x04, 0xB8, 0x90, 0x06,
-0xC4, 0xEF, 0xF0, 0x90, 0x95, 0x3D, 0x12, 0x04,
-0xB8, 0x78, 0x08, 0x12, 0x03, 0xEB, 0x90, 0x06,
-0xC5, 0xEF, 0xF0, 0x90, 0x95, 0x3D, 0x12, 0x04,
-0xB8, 0x78, 0x10, 0x12, 0x03, 0xEB, 0x90, 0x06,
-0xC6, 0xEF, 0xF0, 0x90, 0x95, 0x3D, 0x02, 0x04,
-0xB8, 0x7E, 0x00, 0x7F, 0x33, 0x7D, 0x00, 0x7B,
-0x01, 0x7A, 0x88, 0x79, 0x9D, 0x12, 0x04, 0x80,
-0x90, 0x88, 0x9E, 0x74, 0x0B, 0xF0, 0xA3, 0x74,
-0x08, 0xF0, 0x7E, 0x00, 0x7F, 0x14, 0x7D, 0x00,
-0x7B, 0x01, 0x7A, 0x95, 0x79, 0x38, 0x12, 0x04,
-0x80, 0x90, 0x86, 0xB3, 0xE0, 0xFC, 0x64, 0x02,
-0x70, 0x18, 0x90, 0xFD, 0x80, 0xE0, 0x7E, 0x00,
-0x30, 0xE2, 0x02, 0x7E, 0x01, 0xEE, 0x91, 0x5C,
-0xFE, 0x90, 0x88, 0xA0, 0xE0, 0x54, 0xBF, 0x4E,
-0xF0, 0x22, 0xEC, 0x64, 0x01, 0x70, 0x0D, 0x90,
-0xFD, 0x70, 0xE0, 0x7F, 0x00, 0x30, 0xE2, 0x02,
-0x7F, 0x01, 0x80, 0x13, 0x90, 0x86, 0xB3, 0xE0,
-0x64, 0x03, 0x70, 0x17, 0x90, 0xFD, 0x78, 0xE0,
-0x7F, 0x00, 0x30, 0xE2, 0x02, 0x7F, 0x01, 0xEF,
-0x91, 0x5C, 0xFF, 0x90, 0x88, 0xA0, 0xE0, 0x54,
-0xBF, 0x4F, 0xF0, 0x22, 0x54, 0x01, 0xC4, 0x33,
-0x33, 0x54, 0xC0, 0x22, 0x90, 0x97, 0x43, 0xEF,
-0xF0, 0x90, 0x88, 0xB8, 0xE0, 0x44, 0x01, 0xF0,
-0x90, 0x8A, 0xF9, 0x12, 0x8E, 0x5A, 0x7D, 0x11,
-0x12, 0xAC, 0xB5, 0x12, 0x88, 0xCD, 0x90, 0x07,
-0x78, 0xE0, 0x90, 0x88, 0xBD, 0xF0, 0x90, 0x97,
-0x43, 0xE0, 0xFD, 0x70, 0x02, 0x80, 0x1C, 0xED,
-0xB4, 0x01, 0x06, 0x91, 0xAF, 0x44, 0x20, 0xF0,
-0x22, 0x90, 0x97, 0x43, 0xE0, 0xFD, 0xB4, 0x02,
-0x06, 0x91, 0xAF, 0x44, 0x60, 0xF0, 0x22, 0xED,
-0xB4, 0x03, 0x03, 0x91, 0xAF, 0xF0, 0x22, 0x90,
-0x88, 0xB8, 0xE0, 0x54, 0x1F, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x95, 0x4E,
-0x74, 0x02, 0xF0, 0x90, 0x88, 0xC2, 0xE0, 0x44,
-0x10, 0xF0, 0x90, 0x88, 0xAF, 0xE0, 0x60, 0x02,
-0xC1, 0x38, 0x90, 0x8A, 0xD9, 0x12, 0x8E, 0x5A,
-0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA1,
-0xE0, 0x30, 0xE0, 0x04, 0x7F, 0x01, 0x80, 0x37,
-0x90, 0x88, 0x9D, 0x12, 0xAC, 0xCA, 0x30, 0xE0,
-0x04, 0x7F, 0x0D, 0x80, 0x2A, 0x90, 0x88, 0xA0,
-0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x10,
-0xEF, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x04,
-0x7F, 0x09, 0x80, 0x13, 0x7F, 0x03, 0x80, 0x0F,
-0x90, 0x88, 0xA0, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
-0x04, 0x7F, 0x03, 0x80, 0x02, 0x7F, 0x09, 0x12,
-0x71, 0x9A, 0x90, 0x88, 0xAF, 0x74, 0x01, 0xD1,
-0x4C, 0x30, 0xE0, 0x05, 0x12, 0xA4, 0xC2, 0x80,
-0x2E, 0xD1, 0x44, 0x30, 0xE0, 0x29, 0x90, 0x88,
-0xA3, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x88, 0x9C,
-0xE0, 0x60, 0x0C, 0x90, 0x8A, 0xB9, 0x12, 0x8E,
-0x5A, 0x7D, 0x01, 0x7F, 0x04, 0x80, 0x0D, 0x12,
-0xA4, 0xC2, 0x90, 0x8A, 0xB9, 0x12, 0x8E, 0x5A,
-0x7D, 0x01, 0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x90,
-0x88, 0x9C, 0xE0, 0x60, 0x06, 0x7B, 0x04, 0x7D,
-0x6F, 0x80, 0x03, 0xE4, 0xFB, 0xFD, 0x7F, 0xFF,
-0x12, 0xA4, 0xC7, 0x12, 0x8F, 0x87, 0x30, 0xE0,
-0x0B, 0x90, 0x8A, 0x97, 0x12, 0x8E, 0x5A, 0x7F,
-0x01, 0x12, 0x04, 0x7E, 0x90, 0x88, 0xA1, 0xE0,
-0xC3, 0x13, 0x30, 0xE0, 0x0E, 0x90, 0x06, 0xCD,
-0xE0, 0x44, 0x10, 0xF0, 0x90, 0x06, 0xCF, 0xE0,
-0x44, 0x10, 0xF0, 0x90, 0x05, 0x63, 0xE0, 0x90,
-0x95, 0x52, 0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90,
-0x95, 0x51, 0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90,
-0x95, 0x50, 0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90,
-0x95, 0x4F, 0x12, 0xCD, 0xEA, 0x90, 0x95, 0x4F,
-0x12, 0x8F, 0xEA, 0x12, 0x86, 0x20, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x12, 0x8F,
-0xE7, 0x78, 0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x86,
-0x20, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0xA3, 0x12, 0x8F, 0xEA, 0x78, 0x18, 0x12,
-0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0x12, 0x86, 0x20, 0xA3, 0x12, 0x04,
-0x31, 0x90, 0x88, 0xA1, 0x12, 0xB5, 0x2C, 0x30,
-0xE0, 0x2E, 0x90, 0x95, 0x46, 0x12, 0x04, 0xB8,
-0x90, 0x95, 0x53, 0xD1, 0x3D, 0x40, 0x21, 0x90,
-0x95, 0x46, 0x12, 0x86, 0x2D, 0x90, 0x95, 0x53,
-0x12, 0x04, 0xB8, 0x12, 0x85, 0xB6, 0xE4, 0xFB,
-0x7A, 0x78, 0xF9, 0xF8, 0xC3, 0x12, 0x03, 0xDA,
-0x50, 0x06, 0x90, 0x95, 0x4B, 0xE0, 0x04, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0x86, 0x2D,
-0xD3, 0x02, 0x03, 0xDA, 0x90, 0x88, 0x9D, 0xE0,
-0xC4, 0x54, 0x0F, 0x22, 0xF0, 0x90, 0x88, 0x9D,
-0xE0, 0xC4, 0x13, 0x54, 0x07, 0x22, 0x90, 0x24,
-0xA0, 0xE0, 0x90, 0x93, 0x03, 0x30, 0xE7, 0x05,
-0xE0, 0x44, 0x02, 0xF0, 0x22, 0xE0, 0x54, 0xFD,
-0xF0, 0x22, 0x90, 0x88, 0x2F, 0xE0, 0x64, 0x02,
-0x7F, 0x01, 0x60, 0x02, 0x7F, 0x00, 0x22, 0x90,
-0x06, 0xA9, 0xE0, 0x90, 0x95, 0xE8, 0xF0, 0xE0,
-0xFD, 0x54, 0xC0, 0x70, 0x05, 0x12, 0xDF, 0x89,
-0x80, 0x64, 0xED, 0x30, 0xE6, 0x47, 0x90, 0x88,
-0x36, 0xE0, 0x64, 0x02, 0x70, 0x29, 0x90, 0x88,
-0x31, 0xE0, 0xC3, 0x13, 0x20, 0xE0, 0x05, 0xD1,
-0xF2, 0xF0, 0x80, 0x24, 0x12, 0xAF, 0xC1, 0x64,
-0x01, 0x70, 0x2D, 0x90, 0x88, 0x3A, 0xE0, 0x44,
-0x04, 0xF0, 0x90, 0x8A, 0x71, 0x12, 0x8E, 0x5A,
-0x7F, 0x01, 0x12, 0x04, 0x7E, 0x80, 0x19, 0xD1,
-0xF2, 0x12, 0xAF, 0xC0, 0x64, 0x02, 0x60, 0x08,
-0x90, 0x8A, 0xE1, 0x12, 0x88, 0xCD, 0x80, 0x08,
-0x12, 0x73, 0x8F, 0x80, 0x03, 0x12, 0xDF, 0x89,
-0x90, 0x95, 0xE8, 0xE0, 0x90, 0x88, 0x3A, 0x30,
-0xE7, 0x0B, 0x12, 0x9F, 0x47, 0x90, 0x88, 0x31,
-0xE0, 0x44, 0x04, 0xF0, 0x22, 0xE0, 0x54, 0xFD,
-0xF0, 0x22, 0x90, 0x88, 0x3A, 0xE0, 0x44, 0x01,
-0x22, 0xE4, 0xF5, 0x7C, 0x90, 0x06, 0xA9, 0xE0,
-0xF5, 0x7C, 0x54, 0xC0, 0x70, 0x12, 0x12, 0xDF,
-0x89, 0x54, 0xFD, 0xF0, 0x12, 0xAF, 0x06, 0x90,
-0x88, 0x39, 0xE0, 0x60, 0x3F, 0x02, 0xAF, 0xD6,
-0xE5, 0x7C, 0x30, 0xE6, 0x1D, 0x90, 0x88, 0x36,
-0xE0, 0x64, 0x01, 0x70, 0x18, 0xD1, 0xF2, 0x12,
-0xAF, 0xC0, 0x64, 0x02, 0x60, 0x08, 0x90, 0x8A,
-0xE1, 0x12, 0x88, 0xCD, 0x80, 0x07, 0xF1, 0x55,
-0x80, 0x03, 0x12, 0xDF, 0x89, 0xE5, 0x7C, 0x90,
-0x88, 0x3A, 0x30, 0xE7, 0x0B, 0x12, 0x9F, 0x47,
-0x90, 0x88, 0x31, 0xE0, 0x44, 0x04, 0xF0, 0x22,
-0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90, 0x95, 0x37,
-0x74, 0x01, 0xF0, 0x90, 0x06, 0x92, 0x04, 0xF0,
-0x90, 0x01, 0x3C, 0x74, 0x04, 0xF0, 0x90, 0x88,
-0x31, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x88, 0x39,
-0xE0, 0x64, 0x0C, 0x60, 0x16, 0x90, 0x8A, 0xB9,
-0x12, 0x8E, 0x5A, 0xE4, 0xFD, 0x7F, 0x0C, 0x12,
-0x04, 0x7E, 0x90, 0x8A, 0xF9, 0x12, 0x8E, 0x5A,
-0x12, 0xAC, 0x6E, 0x90, 0x8A, 0xAF, 0x12, 0x8E,
-0x5A, 0x7D, 0x08, 0xE4, 0xFF, 0x02, 0x04, 0x7E,
-0x7E, 0x00, 0x7F, 0x62, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x88, 0x79, 0x31, 0x12, 0x04, 0x80, 0x12,
-0xCF, 0x92, 0x12, 0x04, 0x80, 0xE4, 0x90, 0x95,
+0x81, 0xF5, 0x83, 0x22, 0xF5, 0x82, 0xE4, 0x34,
+0x96, 0xF5, 0x83, 0x22, 0x7E, 0x00, 0x7F, 0x8E,
+0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x58,
+0x02, 0x04, 0x80, 0x90, 0x01, 0x94, 0xE0, 0x44,
+0x01, 0xF0, 0x90, 0x01, 0xC7, 0xE4, 0xF0, 0x22,
+0x90, 0x01, 0x9A, 0xE0, 0x54, 0xC0, 0x44, 0x0B,
+0x12, 0xCF, 0xBE, 0x90, 0x01, 0x98, 0xE0, 0x54,
+0xC0, 0x7F, 0x00, 0xB4, 0x40, 0x02, 0x7F, 0x01,
+0x22, 0x90, 0x01, 0x95, 0xE0, 0x7F, 0x00, 0x30,
+0xE4, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x88, 0x9D,
+0xE0, 0x30, 0xE0, 0x09, 0x90, 0x95, 0x4C, 0xE0,
+0x20, 0xE0, 0x02, 0x91, 0xAE, 0x22, 0x90, 0x95,
+0x4D, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x8A, 0x75,
+0x12, 0x8A, 0x66, 0x90, 0x8A, 0xE5, 0x12, 0x90,
+0x4B, 0x7F, 0x02, 0x02, 0x04, 0x7E, 0x90, 0x01,
+0xCF, 0xE0, 0x90, 0x95, 0xED, 0xF0, 0xE0, 0xFF,
+0x30, 0xE0, 0x07, 0x90, 0x01, 0xCF, 0xE0, 0x54,
+0xFE, 0xF0, 0xEF, 0x30, 0xE5, 0x23, 0x90, 0x01,
+0xCF, 0xE0, 0x54, 0xDF, 0xF0, 0x90, 0x01, 0x34,
+0x74, 0x20, 0xF0, 0xE4, 0xF5, 0xA8, 0xF5, 0xE8,
+0x12, 0x76, 0x6D, 0x90, 0x00, 0x03, 0xE0, 0x54,
+0xFB, 0xFD, 0x7F, 0x03, 0x12, 0x7B, 0x2E, 0x80,
+0xFE, 0x22, 0x90, 0x93, 0x58, 0xE0, 0x30, 0xE0,
+0x0B, 0x90, 0x93, 0xD8, 0xE0, 0x60, 0x05, 0x7F,
+0x07, 0x12, 0x9F, 0xF0, 0x22, 0x22, 0x90, 0x93,
+0x03, 0xE0, 0x30, 0xE0, 0x0F, 0x13, 0x13, 0x13,
+0x54, 0x1F, 0x30, 0xE0, 0x07, 0x90, 0x04, 0x1F,
+0xE0, 0x44, 0x40, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x96, 0xFC, 0xEC,
+0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x96, 0xFB, 0xEF,
+0xF0, 0xA3, 0xA3, 0xE0, 0xFD, 0x12, 0x7B, 0xBD,
+0x90, 0x97, 0x06, 0x12, 0x04, 0x31, 0x90, 0x96,
+0xFE, 0x12, 0x04, 0xB8, 0x12, 0x03, 0xCD, 0x90,
+0x97, 0x06, 0xD1, 0x39, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x90, 0x96, 0xFE, 0x12,
+0x04, 0xB8, 0x90, 0x97, 0x02, 0xD1, 0x39, 0xD0,
+0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
+0x86, 0x20, 0x90, 0x97, 0x0A, 0x12, 0x04, 0x31,
+0x90, 0x96, 0xFC, 0xA3, 0xE0, 0xFD, 0xC0, 0x05,
+0x90, 0x97, 0x0A, 0x12, 0x04, 0xB8, 0x90, 0x8B,
+0x9F, 0x12, 0x04, 0x31, 0x90, 0x96, 0xFB, 0xE0,
+0xFF, 0xD0, 0x05, 0x12, 0x79, 0x53, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0xFD, 0xEE, 0x13, 0x13, 0x54,
+0x07, 0xFB, 0x90, 0x93, 0x58, 0xE0, 0xFE, 0xC4,
+0x54, 0x0F, 0x90, 0x97, 0x57, 0xF0, 0xAF, 0x04,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x97, 0x54, 0xEF, 0xF0, 0xED, 0x64, 0x01, 0x70,
+0x2E, 0xEB, 0xB4, 0x01, 0x07, 0xE0, 0x24, 0x02,
+0xF5, 0x10, 0x80, 0x08, 0x90, 0x97, 0x54, 0xE0,
+0x24, 0xFE, 0xF5, 0x10, 0x90, 0x96, 0xFE, 0x12,
+0x04, 0x3D, 0x00, 0x00, 0x00, 0xFF, 0xAF, 0x10,
+0xD1, 0x2A, 0xD1, 0x22, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0xFF, 0xAF, 0x10, 0x80, 0x20, 0x90,
+0x96, 0xFE, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0xFF, 0x90, 0x97, 0x54, 0x12, 0x8F, 0xEC, 0xD1,
+0x2E, 0xD1, 0x22, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0xFF, 0x90, 0x97, 0x54, 0xE0, 0xFF, 0xD1,
+0x2A, 0x7F, 0x01, 0xB1, 0x2D, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xE4, 0xFF, 0xB1, 0x2D, 0x90, 0x96,
+0xFE, 0x22, 0xE4, 0xFC, 0xFD, 0xFE, 0x90, 0x97,
+0x02, 0x12, 0x04, 0x31, 0x7D, 0x18, 0x7C, 0x00,
+0x22, 0x12, 0x86, 0x2D, 0x02, 0x86, 0x13, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0xFE,
+0xFD, 0xEF, 0xB4, 0x01, 0x0D, 0xEB, 0xB4, 0x02,
+0x03, 0x0D, 0x80, 0x06, 0xEB, 0xB4, 0x01, 0x02,
+0x7D, 0x02, 0xAF, 0x06, 0xEF, 0xC4, 0x54, 0xF0,
+0x4D, 0xFF, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
+0x01, 0xC4, 0x74, 0x67, 0xF0, 0x74, 0xE6, 0xA3,
+0xF0, 0x7F, 0x90, 0x12, 0x7B, 0x41, 0xEF, 0x20,
+0xE0, 0xF7, 0x74, 0x67, 0x04, 0x90, 0x01, 0xC4,
+0xF0, 0x74, 0xE6, 0xA3, 0xF0, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0xCA, 0xF3,
+0x90, 0x97, 0x6F, 0xF0, 0xED, 0x90, 0x00, 0x73,
+0x70, 0x0D, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x00,
+0x67, 0xE0, 0x44, 0x80, 0xF0, 0x80, 0x0B, 0xE0,
+0x54, 0xFB, 0xF0, 0x90, 0x00, 0x67, 0xE0, 0x54,
+0x7F, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x88, 0xB8, 0xE0, 0x54,
+0xFE, 0xF0, 0x54, 0xE1, 0xF0, 0x90, 0x88, 0xBD,
+0xE0, 0xFF, 0x12, 0x71, 0x9A, 0x90, 0x88, 0x36,
+0xE0, 0x70, 0x16, 0x90, 0x93, 0x3B, 0xE0, 0x20,
+0xE0, 0x0F, 0x90, 0x86, 0x0C, 0x12, 0x8A, 0x66,
+0x90, 0x8A, 0xF9, 0x12, 0x90, 0x4B, 0x12, 0x97,
+0x87, 0x22, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0,
+0x64, 0x90, 0x95, 0x38, 0xE0, 0x30, 0xE0, 0x43,
+0x90, 0x95, 0x43, 0xE0, 0xFF, 0x90, 0x95, 0x42,
+0xE0, 0xC3, 0x9F, 0x40, 0x2A, 0xF1, 0x5E, 0x90,
+0x06, 0xC4, 0xEF, 0xF0, 0xF1, 0x5E, 0x78, 0x08,
+0x12, 0x03, 0xEB, 0x90, 0x06, 0xC5, 0xEF, 0xF0,
+0xF1, 0x5E, 0x78, 0x10, 0x12, 0x03, 0xEB, 0x90,
+0x06, 0xC6, 0xEF, 0xF0, 0xF1, 0x5E, 0xF1, 0x64,
+0xE4, 0x90, 0x95, 0x42, 0xF0, 0x80, 0x1B, 0xF1,
+0x6F, 0xF1, 0x64, 0x90, 0x95, 0x42, 0xE0, 0x04,
+0xF0, 0x80, 0x0F, 0x90, 0x95, 0x41, 0xE0, 0x60,
+0x09, 0xF1, 0x6F, 0xF1, 0x64, 0xE4, 0x90, 0x95,
+0x41, 0xF0, 0x90, 0x8A, 0xBB, 0x12, 0x90, 0x4B,
+0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x22, 0x90, 0x95,
+0x39, 0x02, 0x04, 0xB8, 0x78, 0x18, 0x12, 0x03,
+0xEB, 0x90, 0x06, 0xC7, 0xEF, 0xF0, 0x22, 0x90,
+0x95, 0x3D, 0x12, 0x04, 0xB8, 0x90, 0x06, 0xC4,
+0xEF, 0xF0, 0x90, 0x95, 0x3D, 0x12, 0x04, 0xB8,
+0x78, 0x08, 0x12, 0x03, 0xEB, 0x90, 0x06, 0xC5,
+0xEF, 0xF0, 0x90, 0x95, 0x3D, 0x12, 0x04, 0xB8,
+0x78, 0x10, 0x12, 0x03, 0xEB, 0x90, 0x06, 0xC6,
+0xEF, 0xF0, 0x90, 0x95, 0x3D, 0x02, 0x04, 0xB8,
+0x7E, 0x00, 0x7F, 0x33, 0x7D, 0x00, 0x7B, 0x01,
+0x7A, 0x88, 0x79, 0x9D, 0x12, 0x04, 0x80, 0x90,
+0x88, 0x9E, 0x74, 0x0B, 0xF0, 0xA3, 0x74, 0x08,
+0x12, 0xEB, 0x58, 0x7A, 0x95, 0x79, 0x38, 0x12,
+0x04, 0x80, 0x90, 0x86, 0xB3, 0xE0, 0xFC, 0x64,
+0x02, 0x70, 0x19, 0x90, 0xFD, 0x80, 0xE0, 0x7E,
+0x00, 0x30, 0xE2, 0x02, 0x7E, 0x01, 0xEE, 0x12,
+0xBF, 0x64, 0xFE, 0x90, 0x88, 0xA0, 0xE0, 0x54,
+0xBF, 0x4E, 0xF0, 0x22, 0xEC, 0x64, 0x01, 0x70,
+0x0D, 0x90, 0xFD, 0x70, 0xE0, 0x7F, 0x00, 0x30,
+0xE2, 0x02, 0x7F, 0x01, 0x80, 0x13, 0x90, 0x86,
+0xB3, 0xE0, 0x64, 0x03, 0x70, 0x18, 0x90, 0xFD,
+0x78, 0xE0, 0x7F, 0x00, 0x30, 0xE2, 0x02, 0x7F,
+0x01, 0xEF, 0x12, 0xBF, 0x64, 0xFF, 0x90, 0x88,
+0xA0, 0xE0, 0x54, 0xBF, 0x4F, 0xF0, 0x22, 0x90,
+0x97, 0x70, 0xEF, 0xF0, 0x90, 0x88, 0xB8, 0xE0,
+0x44, 0x01, 0xF0, 0x90, 0x8A, 0xF9, 0x12, 0x90,
+0x4B, 0x7D, 0x11, 0x11, 0x68, 0x12, 0x8A, 0x66,
+0x90, 0x07, 0x78, 0xE0, 0x90, 0x88, 0xBD, 0xF0,
+0x90, 0x97, 0x70, 0xE0, 0xFD, 0x70, 0x02, 0x80,
+0x1C, 0xED, 0xB4, 0x01, 0x06, 0x11, 0x61, 0x44,
+0x20, 0xF0, 0x22, 0x90, 0x97, 0x70, 0xE0, 0xFD,
+0xB4, 0x02, 0x06, 0x11, 0x61, 0x44, 0x60, 0xF0,
+0x22, 0xED, 0xB4, 0x03, 0x03, 0x11, 0x61, 0xF0,
+0x22, 0x90, 0x88, 0xB8, 0xE0, 0x54, 0x1F, 0x22,
+0x7F, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0xEF,
+0x22, 0x90, 0x8A, 0xF9, 0x12, 0x90, 0x4B, 0x7D,
+0x20, 0x11, 0x68, 0x12, 0x8A, 0x66, 0x90, 0x88,
+0x2F, 0x74, 0x02, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88, 0x2F, 0xE0,
+0x90, 0x97, 0x72, 0xF0, 0x6F, 0x70, 0x02, 0x21,
+0x8F, 0xEF, 0x14, 0x60, 0x42, 0x14, 0x60, 0x70,
+0x14, 0x70, 0x02, 0x21, 0x3B, 0x14, 0x70, 0x02,
+0x21, 0x66, 0x24, 0x04, 0x60, 0x02, 0x21, 0x8F,
+0x90, 0x97, 0x72, 0xE0, 0xB4, 0x04, 0x04, 0x31,
+0xD1, 0x21, 0x8F, 0x90, 0x97, 0x72, 0xE0, 0xB4,
+0x02, 0x04, 0x31, 0xE1, 0x21, 0x8F, 0x90, 0x97,
+0x72, 0xE0, 0xB4, 0x03, 0x04, 0x31, 0xE6, 0x21,
+0x8F, 0x90, 0x97, 0x72, 0xE0, 0x64, 0x01, 0x60,
+0x02, 0x21, 0x8F, 0x31, 0xD4, 0x21, 0x8F, 0x90,
+0x97, 0x72, 0xE0, 0xB4, 0x04, 0x05, 0x12, 0x97,
+0xA4, 0x21, 0x8F, 0x90, 0x97, 0x72, 0xE0, 0xB4,
+0x02, 0x05, 0x12, 0x97, 0xBE, 0x21, 0x8F, 0x90,
+0x97, 0x72, 0xE0, 0xB4, 0x03, 0x05, 0x12, 0x97,
+0x96, 0x21, 0x8F, 0x90, 0x97, 0x72, 0xE0, 0x60,
+0x02, 0x21, 0x8F, 0x12, 0x97, 0xF2, 0x80, 0x7F,
+0x90, 0x97, 0x72, 0xE0, 0xB4, 0x04, 0x04, 0x31,
+0x94, 0x80, 0x74, 0x90, 0x97, 0x72, 0xE0, 0xB4,
+0x01, 0x04, 0x11, 0x71, 0x80, 0x69, 0x90, 0x97,
+0x72, 0xE0, 0xB4, 0x03, 0x04, 0x31, 0xF3, 0x80,
+0x5E, 0x90, 0x97, 0x72, 0xE0, 0x70, 0x58, 0x31,
+0xB5, 0x80, 0x54, 0x90, 0x97, 0x72, 0xE0, 0xB4,
+0x04, 0x04, 0x51, 0x19, 0x80, 0x49, 0x90, 0x97,
+0x72, 0xE0, 0xB4, 0x01, 0x04, 0x31, 0xBD, 0x80,
+0x3E, 0x90, 0x97, 0x72, 0xE0, 0xB4, 0x02, 0x04,
+0x31, 0xEB, 0x80, 0x33, 0x90, 0x97, 0x72, 0xE0,
+0x70, 0x2D, 0x31, 0xBA, 0x80, 0x29, 0x90, 0x97,
+0x72, 0xE0, 0xB4, 0x03, 0x04, 0x31, 0xFB, 0x80,
+0x1E, 0x90, 0x97, 0x72, 0xE0, 0xB4, 0x01, 0x04,
+0x31, 0xA9, 0x80, 0x13, 0x90, 0x97, 0x72, 0xE0,
+0xB4, 0x02, 0x04, 0x51, 0x2B, 0x80, 0x08, 0x90,
+0x97, 0x72, 0xE0, 0x70, 0x02, 0x31, 0xA6, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x12, 0x97, 0xE2, 0x90,
+0x8A, 0xF9, 0x12, 0x90, 0x4B, 0x7D, 0x23, 0x11,
+0x68, 0x12, 0x8A, 0x66, 0x01, 0x7E, 0x12, 0x97,
+0xF2, 0x90, 0x8A, 0xF9, 0x12, 0x90, 0x4B, 0x7D,
+0x1F, 0x51, 0x07, 0xF0, 0x22, 0x12, 0x97, 0xF2,
+0x01, 0x71, 0x12, 0x97, 0xF2, 0x90, 0x8A, 0xF9,
+0x12, 0x90, 0x4B, 0x7D, 0x21, 0x7F, 0xFF, 0x12,
+0x04, 0x7E, 0x90, 0x88, 0x2F, 0x74, 0x03, 0xF0,
+0x22, 0x12, 0x97, 0xA4, 0x90, 0x05, 0x27, 0xE0,
+0x54, 0xBF, 0xF0, 0xE4, 0x90, 0x88, 0x2F, 0xF0,
+0x22, 0x12, 0x97, 0xBE, 0x80, 0xEE, 0x12, 0x97,
+0x96, 0x80, 0xE9, 0x90, 0x86, 0x0C, 0x12, 0x8A,
+0x66, 0x80, 0xD7, 0x90, 0x8A, 0xEF, 0x12, 0x8A,
+0x66, 0x01, 0x7E, 0x90, 0x8A, 0xF9, 0x12, 0x90,
+0x4B, 0x7D, 0x25, 0x51, 0x07, 0xF0, 0x22, 0x7F,
+0x6F, 0x12, 0x04, 0x7E, 0x90, 0x05, 0x27, 0xE0,
+0x54, 0xBF, 0xF0, 0x90, 0x88, 0x2F, 0x74, 0x04,
+0x22, 0x90, 0x8A, 0xF9, 0x12, 0x90, 0x4B, 0x7D,
+0x22, 0x7F, 0xFF, 0x12, 0x04, 0x7E, 0x12, 0x97,
+0xE2, 0x80, 0x9F, 0x90, 0x86, 0x0C, 0x12, 0x8A,
+0x66, 0x90, 0x8A, 0xF9, 0x12, 0x90, 0x4B, 0x7D,
+0x24, 0x51, 0x07, 0xF0, 0x22, 0x90, 0x88, 0x2F,
+0xE0, 0x64, 0x02, 0x7F, 0x01, 0x60, 0x02, 0x7F,
+0x00, 0x22, 0x12, 0x7A, 0x65, 0xEF, 0x70, 0x03,
+0x12, 0xB6, 0xB4, 0x22, 0x90, 0x88, 0x36, 0xE0,
+0x64, 0x02, 0x60, 0x14, 0x12, 0xB0, 0x94, 0x60,
+0x0F, 0x12, 0x7A, 0x65, 0xEF, 0x70, 0x09, 0x90,
+0x8A, 0xB9, 0x12, 0x90, 0x4B, 0x12, 0x97, 0xCD,
+0x22, 0x7E, 0x00, 0x7F, 0x62, 0x7D, 0x00, 0x7B,
+0x01, 0x7A, 0x88, 0x79, 0x31, 0x12, 0x04, 0x80,
+0x71, 0x62, 0x12, 0x04, 0x80, 0xE4, 0x90, 0x95,
 0x37, 0xF0, 0x90, 0x88, 0x35, 0x74, 0x02, 0xF0,
 0x90, 0x88, 0x3C, 0x14, 0xF0, 0xA3, 0xF0, 0xA3,
 0x74, 0x50, 0xF0, 0x90, 0x88, 0x42, 0xE4, 0xF0,
 0xA3, 0x74, 0x02, 0xF0, 0x90, 0x88, 0x4E, 0x74,
-0x10, 0xF0, 0xA3, 0x74, 0x50, 0xF0, 0x12, 0xE9,
-0xAF, 0x90, 0x8A, 0x89, 0x12, 0x8E, 0x5A, 0x12,
-0xAC, 0x6E, 0x90, 0x8A, 0x89, 0x12, 0x8E, 0x5A,
-0x7D, 0x0C, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x90,
-0x8A, 0x89, 0x12, 0x8E, 0x5A, 0x7D, 0x0C, 0x7F,
-0x01, 0x12, 0x04, 0x7E, 0x90, 0x86, 0xB3, 0xE0,
-0xFF, 0xB4, 0x01, 0x08, 0x90, 0x88, 0x41, 0x74,
-0xDD, 0xF0, 0x80, 0x18, 0xEF, 0xB4, 0x03, 0x0F,
-0x90, 0x88, 0x41, 0x74, 0xF4, 0xF0, 0x90, 0x00,
-0x92, 0xE0, 0x54, 0x7F, 0xF0, 0x80, 0x05, 0xE4,
+0x10, 0xF0, 0xA3, 0x74, 0x50, 0xF0, 0x71, 0x6F,
+0x90, 0x8A, 0x89, 0x12, 0x90, 0x4B, 0x12, 0x97,
+0x87, 0x90, 0x8A, 0x89, 0x12, 0x90, 0x4B, 0x7D,
+0x0C, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x90, 0x8A,
+0x89, 0x12, 0x90, 0x4B, 0x7D, 0x0C, 0x7F, 0x01,
+0x12, 0x04, 0x7E, 0x90, 0x86, 0xB3, 0xE0, 0xFF,
+0xB4, 0x01, 0x08, 0x90, 0x88, 0x41, 0x74, 0xDD,
+0xF0, 0x80, 0x11, 0xEF, 0xB4, 0x03, 0x08, 0x90,
+0x88, 0x41, 0x74, 0x14, 0xF0, 0x80, 0x05, 0xE4,
 0x90, 0x88, 0x41, 0xF0, 0x90, 0x00, 0x79, 0xE0,
 0x54, 0x03, 0xFF, 0xBF, 0x02, 0x0D, 0x90, 0x00,
 0x28, 0xE0, 0x30, 0xE2, 0x06, 0x90, 0x88, 0x53,
 0x74, 0x02, 0xF0, 0x90, 0x88, 0x93, 0x74, 0x02,
 0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0xE0, 0x54,
-0x01, 0x44, 0x28, 0xF0, 0xA3, 0x74, 0x07, 0xF0,
-0x7E, 0x00, 0x7F, 0x18, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0x3F, 0x12, 0x04, 0x80, 0x90,
-0x8A, 0xA3, 0x12, 0x8E, 0x5A, 0x7F, 0x01, 0x12,
-0x04, 0x7E, 0x12, 0xAF, 0xC8, 0x7E, 0x00, 0xFF,
-0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x88, 0x79, 0x9A,
-0x12, 0x04, 0x80, 0x90, 0x06, 0x04, 0xE0, 0x54,
-0x7F, 0xF0, 0x90, 0x06, 0x0A, 0xE0, 0x54, 0xF8,
-0xF0, 0x90, 0x05, 0x22, 0xE4, 0xF0, 0x90, 0x88,
-0x9C, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0,
-0x10, 0x90, 0x88, 0xA3, 0xE0, 0xC4, 0x13, 0x54,
-0x07, 0x30, 0xE0, 0x12, 0x75, 0x11, 0x10, 0x80,
-0x2E, 0x12, 0x7A, 0x65, 0xEF, 0x64, 0x01, 0x60,
-0x05, 0x75, 0x11, 0x01, 0x80, 0x21, 0x90, 0x88,
-0x31, 0x12, 0x9E, 0xC7, 0x30, 0xE0, 0x05, 0x75,
-0x11, 0x02, 0x80, 0x13, 0x90, 0x88, 0x38, 0xE0,
-0xD3, 0x94, 0x04, 0x40, 0x05, 0x75, 0x11, 0x08,
-0x80, 0x05, 0x12, 0xC7, 0xBC, 0x80, 0x0E, 0x90,
-0x01, 0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8,
-0xE5, 0x11, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x88, 0x9D, 0xE0, 0x30, 0xE0, 0x1E,
-0x90, 0x88, 0xAF, 0xE0, 0x60, 0x05, 0x75, 0x12,
-0x40, 0x21, 0x9C, 0x90, 0x88, 0x38, 0xE0, 0xD3,
-0x94, 0x00, 0x40, 0x02, 0x80, 0x2D, 0x90, 0x88,
-0x9C, 0xE0, 0x60, 0x7B, 0x80, 0x55, 0x12, 0x7A,
-0x65, 0xEF, 0x64, 0x01, 0x60, 0x05, 0x75, 0x12,
-0x01, 0x80, 0x71, 0x90, 0x88, 0x3A, 0xE0, 0xFF,
-0x54, 0x03, 0x60, 0x05, 0x75, 0x12, 0x02, 0x80,
-0x63, 0x90, 0x88, 0x38, 0xE0, 0xFE, 0xE4, 0xC3,
-0x9E, 0x50, 0x05, 0x75, 0x12, 0x04, 0x80, 0x54,
-0xEF, 0x30, 0xE2, 0x05, 0x75, 0x12, 0x08, 0x80,
-0x4B, 0x90, 0x88, 0x3A, 0xE0, 0x30, 0xE4, 0x05,
-0x75, 0x12, 0x10, 0x80, 0x3F, 0x90, 0x88, 0x32,
-0xE0, 0x13, 0x13, 0x54, 0x3F, 0x20, 0xE0, 0x05,
-0x75, 0x12, 0x20, 0x80, 0x2F, 0x90, 0x88, 0x9C,
-0xE0, 0x60, 0x05, 0x75, 0x12, 0x80, 0x80, 0x24,
-0x90, 0x06, 0x62, 0xE0, 0x30, 0xE1, 0x05, 0x75,
-0x12, 0x11, 0x80, 0x18, 0x90, 0x06, 0x62, 0xE0,
-0x30, 0xE0, 0x0C, 0xE0, 0x54, 0xFC, 0xFF, 0xBF,
-0x80, 0x05, 0x75, 0x12, 0x12, 0x80, 0x05, 0x12,
-0xC7, 0xBC, 0x80, 0x0E, 0x90, 0x01, 0xB9, 0x74,
-0x04, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x12, 0xF0,
-0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
+0x01, 0x44, 0x28, 0xF0, 0xA3, 0x74, 0x07, 0x71,
+0x58, 0x7A, 0x93, 0x79, 0x3F, 0x12, 0x04, 0x80,
+0x90, 0x8A, 0xA3, 0x12, 0x90, 0x4B, 0x7F, 0x01,
+0x12, 0x04, 0x7E, 0x12, 0xA7, 0x57, 0x7E, 0x00,
+0xFF, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x88, 0x79,
+0x9A, 0x12, 0x04, 0x80, 0x12, 0xC7, 0xD3, 0x90,
+0x06, 0x0A, 0xE0, 0x54, 0xF8, 0xF0, 0x90, 0x05,
+0x22, 0xE4, 0xF0, 0x90, 0x88, 0x9C, 0xF0, 0x22,
+0xF0, 0x7E, 0x00, 0x7F, 0x18, 0x7D, 0x00, 0x7B,
+0x01, 0x22, 0x7E, 0x00, 0x7F, 0x04, 0x7D, 0x00,
+0x7B, 0x01, 0x7A, 0x93, 0x79, 0x3B, 0x22, 0x90,
 0x88, 0x8D, 0x74, 0x18, 0xF0, 0xA3, 0xF0, 0xA3,
 0xE4, 0xF0, 0xA3, 0x74, 0x64, 0xF0, 0xA3, 0x74,
-0x05, 0xF0, 0xA3, 0xF0, 0x22, 0x51, 0x1A, 0xD3,
-0x9F, 0x40, 0x41, 0x90, 0x88, 0x50, 0xE0, 0x04,
-0xF0, 0x90, 0x88, 0x92, 0xE0, 0xFF, 0x90, 0x88,
-0x50, 0xE0, 0xD3, 0x9F, 0x50, 0x2E, 0x90, 0x88,
-0x48, 0xE0, 0x24, 0x08, 0xF0, 0x90, 0x88, 0x3F,
-0x12, 0x9F, 0x3F, 0x33, 0x33, 0x33, 0x54, 0xF8,
-0xFF, 0x90, 0x88, 0x3E, 0xE0, 0x2F, 0x90, 0x88,
-0x4F, 0xF0, 0xFB, 0x90, 0x88, 0x48, 0xE0, 0xFF,
-0xA3, 0xE0, 0xFD, 0x90, 0x92, 0x98, 0x74, 0x03,
-0xF0, 0x12, 0x6E, 0x2F, 0x22, 0x90, 0x88, 0x3F,
-0xE0, 0x04, 0xF0, 0x90, 0x88, 0x3A, 0xE0, 0x54,
-0xEF, 0xF0, 0x90, 0x88, 0x93, 0xE0, 0xFF, 0x90,
-0x88, 0x3F, 0xE0, 0x22, 0x90, 0x88, 0x36, 0xE0,
-0x64, 0x01, 0x70, 0x2A, 0x12, 0xAF, 0xC1, 0x60,
-0x16, 0x90, 0x8A, 0xB9, 0x12, 0x8E, 0x5A, 0xE4,
-0xFD, 0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x90, 0x8B,
-0x01, 0x12, 0xD7, 0xBF, 0x02, 0x04, 0x7A, 0x90,
-0x88, 0x39, 0xE0, 0x70, 0x09, 0x90, 0x8A, 0xB9,
-0x12, 0x8E, 0x5A, 0x12, 0x9F, 0xBB, 0x22, 0x90,
-0x97, 0x09, 0xA3, 0xE0, 0xFF, 0x90, 0x92, 0x13,
-0x74, 0x03, 0xF0, 0x7B, 0x06, 0x7D, 0x01, 0x12,
-0x66, 0xDB, 0x90, 0x97, 0x0D, 0xEE, 0xF0, 0xFC,
-0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x97, 0x0C, 0xE0,
-0xFF, 0x74, 0x10, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x97, 0x0B,
-0x22, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x88, 0x89,
-0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x88, 0x8A,
-0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x88, 0x8B,
-0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x88, 0x8C,
-0xF0, 0x90, 0x88, 0x32, 0xE0, 0x44, 0x80, 0xF0,
-0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xC3, 0x74,
-0xFF, 0x9F, 0xFF, 0x74, 0xFF, 0x9E, 0xFE, 0xE5,
-0x67, 0x22, 0xF5, 0x83, 0xE0, 0xFC, 0xA3, 0xE0,
-0xFD, 0xD3, 0x9F, 0xEC, 0x9E, 0x22, 0xE5, 0x69,
-0x25, 0xE0, 0x24, 0x75, 0xF5, 0x82, 0xE4, 0x34,
-0x81, 0xF5, 0x83, 0x22, 0xEF, 0xC4, 0x54, 0xF0,
-0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34, 0x81, 0xF5,
-0x83, 0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xED,
-0x2F, 0xFF, 0xEC, 0x3E, 0xFE, 0x22, 0x90, 0x96,
-0xD5, 0x12, 0x04, 0x31, 0x7D, 0x18, 0x7C, 0x00,
-0xE4, 0xFF, 0x12, 0xA7, 0x7B, 0x90, 0x96, 0xD1,
-0x22, 0x90, 0x95, 0xD1, 0x12, 0x86, 0x39, 0x90,
-0x00, 0x08, 0x02, 0x03, 0x3E, 0xE4, 0x90, 0x92,
-0x20, 0xF0, 0x90, 0x95, 0xF3, 0xE0, 0xFF, 0x90,
-0x93, 0xD6, 0xE0, 0x2F, 0x22, 0x35, 0xF0, 0xFE,
-0x90, 0x00, 0x06, 0x02, 0x03, 0x3E, 0xE0, 0x54,
-0x03, 0x90, 0x92, 0x80, 0xF0, 0x7B, 0x01, 0xAF,
-0x0E, 0x02, 0x75, 0x80, 0x12, 0x86, 0x2D, 0x02,
-0x86, 0x13, 0x75, 0xF0, 0x02, 0xA4, 0xF5, 0x82,
-0x85, 0xF0, 0x83, 0x02, 0x03, 0x3E, 0x90, 0x01,
-0xC0, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x97, 0x2F,
-0xE0, 0xFD, 0x22, 0x90, 0x93, 0xD7, 0xE0, 0xFF,
-0x90, 0x93, 0xDA, 0xE0, 0xD3, 0x9F, 0x22, 0x74,
-0xA6, 0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
-0xF5, 0x83, 0x22, 0x74, 0x5F, 0x25, 0x67, 0xF5,
-0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83, 0x22, 0x74,
-0xE6, 0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8D,
-0xF5, 0x83, 0x22, 0xE5, 0x67, 0x25, 0xE0, 0x24,
-0x86, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0x22, 0x74,
-0xB6, 0x25, 0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8D,
-0xF5, 0x83, 0x22, 0x90, 0x93, 0xF4, 0xE0, 0xFF,
-0x90, 0x93, 0xF3, 0xE0, 0x4F, 0x22, 0x25, 0xE0,
-0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34, 0x8E, 0x22,
-0x25, 0xE0, 0x24, 0x26, 0xF5, 0x82, 0xE4, 0x34,
-0x8E, 0x22, 0x25, 0xE0, 0x24, 0x56, 0xF5, 0x82,
-0xE4, 0x34, 0x8E, 0x22, 0x90, 0x92, 0x21, 0xF0,
-0xE4, 0x90, 0x92, 0x20, 0xF0, 0x22, 0x90, 0x00,
-0x02, 0x02, 0x03, 0x3E, 0x90, 0x00, 0x04, 0x02,
-0x03, 0x3E, 0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0,
-0x7F, 0x01, 0x22, 0x90, 0x88, 0xA1, 0xE0, 0xC4,
-0x13, 0x54, 0x07, 0x22, 0x90, 0x88, 0x3C, 0xE0,
-0x90, 0x05, 0x73, 0x22, 0x7D, 0x01, 0xAF, 0x67,
-0x02, 0x61, 0xF7, 0xE5, 0x69, 0x90, 0x81, 0x9D,
-0x93, 0xFF, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0x96,
-0xF5, 0x83, 0x22, 0x90, 0x95, 0xD8, 0xE0, 0xFE,
-0xA3, 0xE0, 0x22, 0x90, 0x05, 0x00, 0x74, 0x1C,
-0xF0, 0xA3, 0x22, 0xF0, 0x24, 0x0A, 0x90, 0x88,
-0xCF, 0xF0, 0x22, 0x00, 0xCE, 0x6A
+0x05, 0xF0, 0xA3, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88, 0x9D, 0xE0,
+0x30, 0xE0, 0x10, 0x90, 0x88, 0xA3, 0xE0, 0xC4,
+0x13, 0x54, 0x07, 0x30, 0xE0, 0x20, 0x75, 0x11,
+0x10, 0x80, 0x2D, 0x12, 0x7A, 0x65, 0xEF, 0x64,
+0x01, 0x60, 0x05, 0x75, 0x11, 0x01, 0x80, 0x20,
+0x90, 0x88, 0x31, 0x12, 0x9D, 0xD9, 0x30, 0xE0,
+0x05, 0x75, 0x11, 0x02, 0x80, 0x12, 0x90, 0x88,
+0x38, 0xE0, 0xD3, 0x94, 0x04, 0x40, 0x05, 0x75,
+0x11, 0x08, 0x80, 0x04, 0x71, 0xE3, 0x80, 0x0E,
+0x90, 0x01, 0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01,
+0xB8, 0xE5, 0x11, 0xF0, 0x7F, 0x00, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x01, 0xB8, 0xE4, 0xF0,
+0x7F, 0x01, 0x22, 0x90, 0x93, 0x3B, 0xE0, 0xC3,
+0x13, 0x20, 0xE0, 0x35, 0x90, 0x02, 0x87, 0xE0,
+0x60, 0x02, 0x80, 0x08, 0x90, 0x01, 0x00, 0xE0,
+0x64, 0x3F, 0x60, 0x05, 0x75, 0x66, 0x01, 0x80,
+0x2E, 0x90, 0x02, 0x96, 0xE0, 0x60, 0x05, 0x75,
+0x66, 0x10, 0x80, 0x23, 0x90, 0x02, 0x86, 0xE0,
+0x20, 0xE1, 0x02, 0x80, 0x07, 0x90, 0x02, 0x86,
+0xE0, 0x30, 0xE3, 0x05, 0x75, 0x66, 0x04, 0x80,
+0x0E, 0x90, 0x88, 0xE6, 0xE0, 0x30, 0xE0, 0x05,
+0x75, 0x66, 0x20, 0x80, 0x02, 0x80, 0xAC, 0x90,
+0x01, 0xB9, 0x74, 0x08, 0xF0, 0x90, 0x01, 0xB8,
+0xE5, 0x66, 0xF0, 0x7F, 0x00, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x88, 0x9D,
+0xE0, 0x30, 0xE0, 0x1E, 0x90, 0x88, 0xAF, 0xE0,
+0x60, 0x05, 0x75, 0x12, 0x40, 0x81, 0xEF, 0x90,
+0x88, 0x38, 0xE0, 0xD3, 0x94, 0x00, 0x40, 0x02,
+0x80, 0x2D, 0x90, 0x88, 0x9C, 0xE0, 0x60, 0x7B,
+0x80, 0x55, 0x12, 0x7A, 0x65, 0xEF, 0x64, 0x01,
+0x60, 0x05, 0x75, 0x12, 0x01, 0x80, 0x70, 0x90,
+0x88, 0x3A, 0xE0, 0xFF, 0x54, 0x03, 0x60, 0x05,
+0x75, 0x12, 0x02, 0x80, 0x62, 0x90, 0x88, 0x38,
+0xE0, 0xFE, 0xE4, 0xC3, 0x9E, 0x50, 0x05, 0x75,
+0x12, 0x04, 0x80, 0x53, 0xEF, 0x30, 0xE2, 0x05,
+0x75, 0x12, 0x08, 0x80, 0x4A, 0x90, 0x88, 0x3A,
+0xE0, 0x30, 0xE4, 0x05, 0x75, 0x12, 0x10, 0x80,
+0x3E, 0x90, 0x88, 0x32, 0xE0, 0x13, 0x13, 0x54,
+0x3F, 0x20, 0xE0, 0x05, 0x75, 0x12, 0x20, 0x80,
+0x2E, 0x90, 0x88, 0x9C, 0xE0, 0x60, 0x05, 0x75,
+0x12, 0x80, 0x80, 0x23, 0x90, 0x06, 0x62, 0xE0,
+0x30, 0xE1, 0x05, 0x75, 0x12, 0x11, 0x80, 0x17,
+0x90, 0x06, 0x62, 0xE0, 0x30, 0xE0, 0x0C, 0xE0,
+0x54, 0xFC, 0xFF, 0xBF, 0x80, 0x05, 0x75, 0x12,
+0x12, 0x80, 0x04, 0x71, 0xE3, 0x80, 0x0E, 0x90,
+0x01, 0xB9, 0x74, 0x04, 0xF0, 0x90, 0x01, 0xB8,
+0xE5, 0x12, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x12, 0xB6, 0x31, 0x40, 0x41, 0x90,
+0x88, 0x50, 0xE0, 0x04, 0xF0, 0x90, 0x88, 0x92,
+0xE0, 0xFF, 0x90, 0x88, 0x50, 0xE0, 0xD3, 0x9F,
+0x50, 0x2E, 0x90, 0x88, 0x48, 0xE0, 0x24, 0x08,
+0xF0, 0x90, 0x88, 0x3F, 0x12, 0x9D, 0xE2, 0x33,
+0x33, 0x33, 0x54, 0xF8, 0xFF, 0x90, 0x88, 0x3E,
+0xE0, 0x2F, 0x90, 0x88, 0x4F, 0xF0, 0xFB, 0x90,
+0x88, 0x48, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0x90,
+0x92, 0x98, 0x74, 0x03, 0xF0, 0x12, 0x6E, 0x2F,
+0x22, 0x90, 0x97, 0x33, 0xA3, 0xE0, 0xFF, 0x90,
+0x92, 0x13, 0x74, 0x03, 0xF0, 0x7B, 0x06, 0x7D,
+0x01, 0x12, 0x66, 0xDB, 0x90, 0x97, 0x37, 0xEE,
+0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x97,
+0x36, 0xE0, 0xFF, 0x74, 0x10, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
+0x97, 0x35, 0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0xC3, 0x74, 0xFF, 0x9F, 0xFF, 0x74, 0xFF, 0x9E,
+0xFE, 0xE5, 0x67, 0x22, 0xF5, 0x83, 0xE0, 0xFC,
+0xA3, 0xE0, 0xFD, 0xD3, 0x9F, 0xEC, 0x9E, 0x22,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xED, 0x2F, 0xFF,
+0xEC, 0x3E, 0xFE, 0x22, 0x90, 0x01, 0x34, 0x74,
+0x40, 0xF0, 0xFD, 0xE4, 0xFF, 0x12, 0x7C, 0x74,
+0x43, 0x64, 0x08, 0x22, 0xE0, 0x90, 0x01, 0xBA,
+0xF0, 0x90, 0x88, 0x38, 0xE0, 0x90, 0x01, 0xBB,
+0x22, 0xE5, 0x67, 0x25, 0xE0, 0x24, 0x86, 0xF5,
+0x82, 0xE4, 0x34, 0x8E, 0x22, 0x74, 0xB6, 0x25,
+0x67, 0xF5, 0x82, 0xE4, 0x34, 0x8D, 0xF5, 0x83,
+0x22, 0xFF, 0xE4, 0x3E, 0xFE, 0xE4, 0x3D, 0xFD,
+0xE4, 0x3C, 0xFC, 0x22, 0x90, 0x93, 0xF4, 0xE0,
+0xFF, 0x90, 0x93, 0xF3, 0xE0, 0x4F, 0x22, 0x25,
+0xE0, 0x24, 0x06, 0xF5, 0x82, 0xE4, 0x34, 0x8E,
+0x22, 0x25, 0xE0, 0x24, 0x26, 0xF5, 0x82, 0xE4,
+0x34, 0x8E, 0x22, 0x25, 0xE0, 0x24, 0x56, 0xF5,
+0x82, 0xE4, 0x34, 0x8E, 0x22, 0x90, 0x93, 0x3C,
+0xE0, 0x14, 0x90, 0x93, 0x3E, 0xF0, 0x22, 0x90,
+0x00, 0x02, 0x02, 0x03, 0x3E, 0x90, 0x00, 0x04,
+0x02, 0x03, 0x3E, 0x90, 0x88, 0x2C, 0xE0, 0x13,
+0x13, 0x54, 0x3F, 0x22, 0x12, 0x86, 0x2D, 0xC3,
+0x02, 0x03, 0xDA, 0x90, 0x88, 0x3C, 0xE0, 0x90,
+0x05, 0x73, 0x22, 0x12, 0x86, 0x2D, 0xD3, 0x02,
+0x03, 0xDA, 0x25, 0xE0, 0x25, 0xE0, 0xFE, 0xEF,
+0x4E, 0x22, 0x90, 0x95, 0xDE, 0xE0, 0xFE, 0xA3,
+0xE0, 0x22, 0x90, 0x88, 0x31, 0xE0, 0x54, 0xF7,
+0xF0, 0x22, 0x5F, 0x54
 };
 
-u32 array_length_mp_8723d_fw_nic = 27726;
+u32 array_length_mp_8723d_fw_nic = 28284;
 
 #ifdef CONFIG_WOWLAN
 
 u8 array_mp_8723d_fw_wowlan[] = {
-0xD1, 0x23, 0x30, 0x00, 0x27, 0x00, 0x00, 0x00,
-0x09, 0x15, 0x17, 0x39, 0xC0, 0x75, 0x02, 0x00,
-0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0xD1, 0x23, 0x30, 0x00, 0x2F, 0x00, 0x00, 0x00,
+0x12, 0x10, 0x17, 0x09, 0xAE, 0x7B, 0x02, 0x00,
+0xBE, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x02, 0x86, 0xA9, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xB3, 0xA5, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xB6, 0xA5, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC6, 0x56, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xDD, 0x18, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC5, 0xAF, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xBE, 0x78, 0x00, 0x00,
-0x00, 0x00, 0x00, 0x02, 0xC6, 0x55, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xD9, 0x95, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xDA, 0x3B, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x02, 0xDD, 0x17, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
@@ -6739,1901 +6908,2866 @@ u8 array_mp_8723d_fw_wowlan[] = {
 0xF8, 0xE4, 0x93, 0xA3, 0xC8, 0xC5, 0x82, 0xC8,
 0xCA, 0xC5, 0x83, 0xCA, 0xF0, 0xA3, 0xC8, 0xC5,
 0x82, 0xC8, 0xCA, 0xC5, 0x83, 0xCA, 0xDF, 0xE9,
-0xDE, 0xE7, 0x80, 0xBE, 0x41, 0x9C, 0x98, 0x00,
-0x41, 0x9C, 0x9D, 0x00, 0x41, 0x9B, 0x5D, 0x00,
-0x41, 0x9A, 0xDC, 0x00, 0x44, 0x9C, 0x7D, 0x00,
-0x50, 0xF2, 0x01, 0x00, 0xC0, 0xBB, 0xB9, 0xE0,
-0xC4, 0x89, 0x90, 0x9C, 0x97, 0xEF, 0xF0, 0x7F,
+0xDE, 0xE7, 0x80, 0xBE, 0x41, 0x9C, 0xE0, 0x00,
+0x41, 0x9C, 0xE5, 0x00, 0x41, 0x9B, 0x89, 0x00,
+0x41, 0x9B, 0x08, 0x00, 0x44, 0x9C, 0xC3, 0x00,
+0x50, 0xF2, 0x01, 0x00, 0xC8, 0xA8, 0xD0, 0x7F,
+0xD8, 0xA7, 0x90, 0x9C, 0xDF, 0xEF, 0xF0, 0x7F,
 0x02, 0xD1, 0x27, 0x90, 0x86, 0xAF, 0xE0, 0xFF,
-0x90, 0x9C, 0x97, 0xE0, 0xFE, 0xEF, 0x4E, 0x90,
-0x86, 0xAF, 0xF0, 0x22, 0xF1, 0xC3, 0x90, 0x86,
-0xB4, 0xF1, 0x9C, 0xFF, 0xED, 0x2F, 0x90, 0x86,
-0xB5, 0xF1, 0xA3, 0xFF, 0xED, 0x2F, 0x90, 0x86,
-0xB6, 0x12, 0x97, 0xCC, 0xFF, 0xED, 0x2F, 0x90,
-0x86, 0xB7, 0x12, 0x95, 0xF4, 0xFF, 0xED, 0x2F,
-0x90, 0x86, 0xB8, 0x12, 0xE7, 0xE3, 0xFF, 0xED,
-0x2F, 0x90, 0x86, 0xB9, 0x12, 0xEF, 0x6B, 0x90,
-0x86, 0xBA, 0xF0, 0x22, 0xF0, 0x90, 0x00, 0x01,
-0x02, 0x02, 0x1F, 0xF0, 0x90, 0x00, 0x02, 0x02,
-0x02, 0x1F, 0xF1, 0xC3, 0x90, 0x98, 0x19, 0xF1,
-0x9C, 0xFF, 0xED, 0x2F, 0x90, 0x98, 0x1A, 0xF1,
-0xA3, 0xFF, 0xAE, 0x05, 0xED, 0x2F, 0x90, 0x98,
-0x1B, 0xF0, 0x22, 0x90, 0x02, 0x09, 0xE0, 0xFD,
-0x12, 0x02, 0x06, 0xFE, 0xAF, 0x05, 0xED, 0x2E,
-0x22, 0x12, 0xDA, 0x82, 0x90, 0x93, 0x08, 0xE0,
-0x54, 0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x02,
-0xFF, 0xEE, 0x54, 0xFD, 0x4F, 0xF1, 0x9C, 0x90,
-0x93, 0x09, 0xF1, 0xA3, 0x90, 0x93, 0x0A, 0xF0,
-0x12, 0xF5, 0x4E, 0x90, 0x93, 0x08, 0xE0, 0x54,
-0x01, 0xFF, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x9C, 0xA0, 0xEF, 0xF0, 0x90, 0x93,
-0x04, 0x31, 0xF1, 0x30, 0xE0, 0x39, 0x12, 0xD7,
-0x98, 0x60, 0x10, 0x12, 0xD7, 0x8E, 0x40, 0x0B,
-0xE4, 0x7F, 0x0A, 0xFE, 0xFD, 0xFC, 0x90, 0x95,
-0xC9, 0x80, 0x09, 0xE4, 0x7F, 0x0A, 0xFE, 0xFD,
-0xFC, 0x90, 0x95, 0xC1, 0x12, 0x82, 0x12, 0x12,
-0x80, 0xDB, 0xC0, 0x07, 0x90, 0x93, 0x0A, 0xE0,
-0xFB, 0xE4, 0xFA, 0xF9, 0xF8, 0xD0, 0x07, 0x12,
-0x81, 0x66, 0x90, 0x93, 0x0B, 0xEF, 0xF0, 0x90,
-0x9C, 0xA0, 0xE0, 0x64, 0x01, 0x70, 0x1B, 0x11,
-0x96, 0x60, 0x0A, 0x11, 0x8F, 0x12, 0x7C, 0x05,
-0x12, 0xF5, 0x61, 0x80, 0x08, 0x11, 0x8F, 0x12,
-0x7C, 0x3B, 0x12, 0xF4, 0xD2, 0x12, 0x79, 0xD4,
-0x80, 0x1C, 0x11, 0x96, 0x60, 0x07, 0x11, 0x8F,
-0x12, 0x7C, 0x05, 0x80, 0x05, 0x11, 0x8F, 0x12,
-0x7C, 0x3B, 0x7D, 0x02, 0x7F, 0x02, 0x12, 0x7C,
-0x74, 0xF1, 0xEE, 0x12, 0x7B, 0xCC, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xF0, 0x90, 0x01, 0x3F, 0x74,
-0x10, 0xF0, 0xFD, 0x7F, 0x03, 0x22, 0x90, 0x93,
-0x0A, 0xE0, 0x90, 0x01, 0x3F, 0x22, 0xE4, 0x90,
-0x9A, 0xCF, 0xF0, 0x12, 0xB3, 0x4B, 0x60, 0x02,
-0x21, 0xDC, 0x90, 0x88, 0x36, 0xE0, 0x70, 0x02,
-0x21, 0xDC, 0x90, 0x06, 0xA9, 0xE0, 0x54, 0xC0,
-0x70, 0x27, 0x90, 0x88, 0x9C, 0xE0, 0x70, 0x21,
-0x90, 0x04, 0x1A, 0xE0, 0xF4, 0x70, 0x1A, 0xA3,
-0xE0, 0x54, 0x07, 0xFF, 0xBF, 0x07, 0x12, 0x90,
-0x06, 0x62, 0xE0, 0x54, 0x03, 0x70, 0x0A, 0x90,
-0x88, 0x39, 0xE0, 0xB4, 0x04, 0x03, 0x12, 0xD0,
-0x62, 0x90, 0x05, 0x63, 0xE0, 0x90, 0x88, 0x85,
-0xF0, 0x90, 0x05, 0x62, 0xE0, 0x90, 0x88, 0x86,
-0xF0, 0x90, 0x05, 0x61, 0xE0, 0x90, 0x88, 0x87,
-0xF0, 0x90, 0x05, 0x60, 0xE0, 0x90, 0x88, 0x88,
-0xF0, 0x90, 0x07, 0xF1, 0xE0, 0x90, 0x99, 0x81,
-0xF0, 0x90, 0x07, 0xF0, 0xE0, 0x90, 0x99, 0x82,
-0xF0, 0x12, 0xB7, 0xEE, 0xF0, 0x90, 0x88, 0x3A,
-0xE0, 0x54, 0xEC, 0xF0, 0x31, 0xE5, 0x24, 0xFD,
-0x50, 0x02, 0x80, 0x03, 0x12, 0xC6, 0xDC, 0x31,
-0xE5, 0x64, 0x01, 0x70, 0x3A, 0x90, 0x06, 0xAB,
-0xE0, 0x90, 0x88, 0x3D, 0xF0, 0x90, 0x06, 0xA9,
-0xE0, 0x30, 0xE5, 0x06, 0xA3, 0xE0, 0x90, 0x9A,
-0xCF, 0xF0, 0x90, 0x9A, 0xCF, 0xE0, 0xFF, 0x60,
-0x02, 0x80, 0x05, 0x90, 0x88, 0x3C, 0xE0, 0xFF,
-0x90, 0x88, 0x3C, 0xEF, 0xF0, 0xA3, 0xE0, 0xFF,
-0x70, 0x08, 0x90, 0x88, 0x3C, 0xE0, 0xFE, 0xFF,
-0x80, 0x00, 0x90, 0x88, 0x3D, 0xEF, 0xF0, 0x12,
-0xC8, 0x46, 0xE4, 0x90, 0x88, 0x3F, 0xF0, 0xA3,
-0xF0, 0x31, 0xEE, 0x30, 0xE0, 0x5F, 0xEF, 0xC4,
-0x13, 0x13, 0x54, 0x03, 0x20, 0xE0, 0x25, 0x31,
-0xDD, 0x6F, 0x70, 0x51, 0xEF, 0x60, 0x4E, 0x90,
-0x88, 0x32, 0xE0, 0x44, 0x40, 0xF0, 0x12, 0xF5,
-0x97, 0x11, 0x8B, 0x12, 0x7C, 0x05, 0x12, 0xF4,
-0xD9, 0x12, 0xBF, 0xD9, 0x90, 0x88, 0x3D, 0xE0,
-0x14, 0xF0, 0x80, 0x31, 0x90, 0x88, 0x34, 0xE0,
-0xC4, 0x54, 0x0F, 0x64, 0x01, 0x70, 0x26, 0x31,
-0xDD, 0xFE, 0x6F, 0x60, 0x20, 0x90, 0x05, 0x73,
-0xE0, 0xFF, 0xEE, 0x6F, 0x60, 0x17, 0x12, 0xBF,
-0xB7, 0x30, 0xE0, 0x11, 0xEF, 0x54, 0xBF, 0x11,
-0x8B, 0x12, 0x7C, 0x3B, 0xF1, 0xEE, 0x7D, 0x02,
-0x7F, 0x02, 0x12, 0x7C, 0x74, 0x90, 0x88, 0x32,
-0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90, 0x88, 0x3C,
-0xE0, 0xFF, 0xA3, 0xE0, 0x22, 0x90, 0x88, 0x34,
-0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x22, 0x90, 0x88,
-0x32, 0xE0, 0xFF, 0x13, 0x13, 0x13, 0x54, 0x1F,
-0x22, 0xF1, 0xE5, 0xA3, 0xED, 0xF0, 0x78, 0x0B,
-0x7C, 0x9A, 0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x80,
-0x79, 0x94, 0x7E, 0x00, 0x7F, 0x06, 0x12, 0x01,
-0xE0, 0x12, 0xF5, 0x8E, 0x7A, 0x80, 0x79, 0x9A,
-0x12, 0xF5, 0xAF, 0x78, 0x21, 0x7C, 0x9A, 0x7D,
-0x01, 0x7B, 0xFF, 0x7A, 0x80, 0x79, 0xAA, 0x12,
-0xF5, 0xAF, 0xE4, 0x90, 0x9A, 0x34, 0xF1, 0x10,
-0xA3, 0xE0, 0xFD, 0x12, 0xE7, 0xEA, 0xEF, 0x64,
-0x01, 0x60, 0x02, 0x61, 0xC2, 0xB1, 0x7E, 0xCF,
-0x24, 0x0E, 0xCF, 0x34, 0x00, 0x71, 0xE7, 0xEF,
-0x64, 0x3A, 0x60, 0x02, 0x61, 0xC2, 0xB1, 0x7E,
-0xCF, 0x24, 0x30, 0xCF, 0x34, 0x00, 0x71, 0xE7,
-0xEF, 0x64, 0x87, 0x60, 0x02, 0x61, 0xC2, 0x90,
-0x9A, 0x34, 0x04, 0xF0, 0xE4, 0x90, 0x9A, 0x31,
-0xF0, 0xD1, 0xF7, 0x94, 0x10, 0x50, 0x18, 0xD1,
-0xE4, 0xB1, 0x89, 0xCD, 0x24, 0x38, 0x71, 0xDC,
-0x90, 0x9A, 0x31, 0xE0, 0x24, 0x21, 0xF5, 0x82,
-0xE4, 0x34, 0x9A, 0xF1, 0xD2, 0x80, 0xE2, 0xE4,
-0x90, 0x9A, 0x32, 0xF0, 0x90, 0x9A, 0x32, 0xE0,
-0xFF, 0xC3, 0x94, 0x02, 0x40, 0x02, 0x61, 0xC2,
-0x75, 0xF0, 0x38, 0xEF, 0x12, 0xF5, 0xA7, 0x20,
-0xE0, 0x02, 0x61, 0xC2, 0xE4, 0x90, 0x9A, 0x33,
-0xF0, 0x12, 0xF5, 0x7C, 0x90, 0x93, 0x62, 0x12,
-0x04, 0x6E, 0xE0, 0xFE, 0x90, 0x9A, 0x33, 0xE0,
-0xC3, 0x9E, 0x40, 0x02, 0x61, 0xBA, 0xEF, 0x75,
-0xF0, 0x38, 0xA4, 0x24, 0x79, 0xF9, 0x74, 0x93,
-0x35, 0xF0, 0xFA, 0x7B, 0x01, 0xE0, 0x75, 0xF0,
-0x10, 0xA4, 0x29, 0xF9, 0xEA, 0x35, 0xF0, 0xFA,
-0x78, 0x21, 0x7C, 0x9A, 0x12, 0xF5, 0x43, 0x60,
-0x02, 0x61, 0xAB, 0x90, 0x06, 0x33, 0xE0, 0x44,
-0x01, 0x54, 0xFB, 0xF0, 0xE4, 0x90, 0x9A, 0x31,
-0xF0, 0xD1, 0xF7, 0x94, 0x06, 0x50, 0x13, 0xD1,
-0xE4, 0xB1, 0x89, 0xCD, 0x24, 0x4A, 0x71, 0xDC,
-0x90, 0x9A, 0x31, 0x12, 0xF5, 0x85, 0xF1, 0xD2,
-0x80, 0xE7, 0xE4, 0x90, 0x9A, 0x31, 0xF0, 0xD1,
-0xF7, 0x94, 0x10, 0x50, 0x0B, 0x71, 0xC8, 0x90,
-0x9A, 0x31, 0xF1, 0xF5, 0xF1, 0xD2, 0x80, 0xEF,
-0x12, 0xF5, 0x7C, 0x12, 0xF5, 0xA7, 0xFE, 0xC3,
-0x13, 0x30, 0xE0, 0x2B, 0xEF, 0x75, 0xF0, 0x38,
-0xA4, 0x24, 0x69, 0xF9, 0x74, 0x93, 0x35, 0xF0,
-0xFA, 0x7B, 0x01, 0x78, 0x11, 0x7C, 0x9A, 0x12,
-0xF5, 0x43, 0x70, 0x6E, 0x90, 0x98, 0x09, 0xE0,
-0xB4, 0x02, 0x0A, 0x90, 0x93, 0x25, 0x31, 0xF1,
-0x20, 0xE0, 0x1C, 0x80, 0x11, 0x80, 0x18, 0x90,
-0x98, 0x09, 0xE0, 0xB4, 0x02, 0x11, 0x90, 0x93,
-0x25, 0x31, 0xF1, 0x20, 0xE0, 0x09, 0x90, 0x01,
-0xC7, 0x74, 0x0A, 0xF1, 0xC9, 0x80, 0x53, 0x7B,
-0x01, 0x7A, 0x9A, 0x79, 0x0B, 0x90, 0x9A, 0x38,
-0x12, 0x82, 0x27, 0x7A, 0x9A, 0x79, 0x21, 0x90,
-0x9A, 0x3B, 0x12, 0x82, 0x27, 0x90, 0x9A, 0x32,
-0xE0, 0x75, 0xF0, 0x38, 0xA4, 0x24, 0x63, 0xF9,
-0x74, 0x93, 0x35, 0xF0, 0xFA, 0x90, 0x9A, 0x3E,
-0x12, 0x82, 0x27, 0xE4, 0x90, 0x9A, 0x41, 0xF0,
-0xA3, 0xF0, 0x7A, 0x9A, 0x79, 0x11, 0x12, 0x9C,
-0x2F, 0x80, 0x07, 0x90, 0x06, 0x33, 0xE0, 0x44,
-0x05, 0xF0, 0x90, 0x9A, 0x33, 0xE0, 0x04, 0xF0,
-0x41, 0xA9, 0x90, 0x9A, 0x32, 0xE0, 0x04, 0xF0,
-0x41, 0x8C, 0x90, 0x9A, 0x34, 0xE0, 0xFF, 0x22,
-0x90, 0x9A, 0x0A, 0xE0, 0xFD, 0x90, 0x9A, 0x09,
-0xE0, 0x2D, 0xFD, 0x90, 0x9A, 0x08, 0xE0, 0x34,
-0x00, 0xCD, 0x24, 0x10, 0xCD, 0x34, 0x00, 0xFC,
-0x7E, 0x00, 0xED, 0x2F, 0xFF, 0xEE, 0x3C, 0xFE,
-0x90, 0x8A, 0xE9, 0xE0, 0xFC, 0xA3, 0xE0, 0xF5,
-0x82, 0x8C, 0x83, 0xE4, 0xFD, 0x02, 0x04, 0x7E,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x06, 0x31, 0xE0, 0x54, 0xEF, 0x44, 0x08, 0xF0,
-0xED, 0x2F, 0xFF, 0xE4, 0x3E, 0xFE, 0x7C, 0x00,
-0xEF, 0x24, 0x08, 0x12, 0xF5, 0x38, 0x7E, 0x00,
-0x7F, 0xE3, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x94,
-0x79, 0x39, 0x12, 0x04, 0x80, 0x90, 0x9A, 0x12,
-0xE0, 0x24, 0x01, 0xB1, 0x6B, 0x71, 0xE7, 0x90,
-0x94, 0x3A, 0xEF, 0xF0, 0x90, 0x9A, 0x12, 0xE0,
-0x24, 0x04, 0xB1, 0x6B, 0x71, 0xE7, 0x90, 0x94,
-0x3D, 0xEF, 0xF0, 0x90, 0x9A, 0x12, 0xE0, 0x24,
-0x05, 0xB1, 0x6B, 0x71, 0xE7, 0x90, 0x94, 0x3E,
-0xEF, 0xF0, 0x90, 0x9A, 0x12, 0xE0, 0x24, 0x06,
-0xB1, 0x6B, 0x71, 0xE7, 0x90, 0x94, 0x3F, 0xEF,
-0xF0, 0x90, 0x9A, 0x12, 0xE0, 0x24, 0x07, 0xB1,
-0x6B, 0x71, 0xE7, 0x90, 0x94, 0x40, 0xEF, 0xF0,
-0x90, 0x9A, 0x12, 0xE0, 0x24, 0x08, 0xB1, 0x6B,
-0x71, 0xE7, 0x90, 0x94, 0x41, 0xEF, 0xF0, 0xE4,
-0x90, 0x9A, 0x10, 0xF0, 0xD1, 0xF0, 0x94, 0x08,
-0x50, 0x1C, 0x90, 0x9A, 0x12, 0xE0, 0x24, 0x09,
-0xFD, 0x90, 0x9A, 0x11, 0xE0, 0x71, 0xDD, 0x90,
-0x9A, 0x10, 0xE0, 0x24, 0x42, 0xF5, 0x82, 0xE4,
-0x34, 0x94, 0xB1, 0x73, 0x80, 0xDE, 0xE4, 0x90,
-0x9A, 0x10, 0xF0, 0xD1, 0xF0, 0x94, 0x02, 0x50,
-0x1C, 0x90, 0x9A, 0x12, 0xE0, 0x24, 0x61, 0xFD,
-0x90, 0x9A, 0x11, 0xE0, 0x71, 0xDD, 0x90, 0x9A,
-0x10, 0xE0, 0x24, 0x9A, 0xF5, 0x82, 0xE4, 0x34,
-0x94, 0xB1, 0x73, 0x80, 0xDE, 0xE4, 0x90, 0x9A,
-0x10, 0xF0, 0xD1, 0xF0, 0x94, 0x10, 0x50, 0x1C,
-0x90, 0x9A, 0x12, 0xE0, 0x24, 0x31, 0xFD, 0x90,
-0x9A, 0x11, 0xE0, 0x71, 0xDD, 0x90, 0x9A, 0x10,
-0xE0, 0x24, 0x6A, 0xF5, 0x82, 0xE4, 0x34, 0x94,
-0xB1, 0x73, 0x80, 0xDE, 0xE4, 0x90, 0x9A, 0x10,
-0xF0, 0x90, 0x94, 0x9B, 0xE0, 0xFF, 0x90, 0x9A,
-0x10, 0xE0, 0xFE, 0xC3, 0x9F, 0x50, 0x1F, 0x90,
-0x9A, 0x12, 0xE0, 0x24, 0x63, 0xFD, 0xB1, 0x6C,
-0xFC, 0xEE, 0x7E, 0x00, 0x2D, 0x71, 0xE4, 0x90,
-0x9A, 0x10, 0xE0, 0x24, 0x9C, 0xF5, 0x82, 0xE4,
-0x34, 0x94, 0xB1, 0x73, 0x80, 0xD3, 0x90, 0x94,
-0x3E, 0x12, 0xEE, 0x5A, 0x90, 0x9A, 0x0E, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0x30, 0xE3, 0x0D, 0x90,
-0x01, 0xC7, 0x74, 0x03, 0xF0, 0x7F, 0x01, 0x12,
-0xBC, 0x2E, 0x80, 0x20, 0x7E, 0x00, 0x90, 0x9A,
-0x0F, 0xE0, 0x54, 0x07, 0xFF, 0x64, 0x01, 0x60,
-0x05, 0xEF, 0x64, 0x02, 0x70, 0x0E, 0xE4, 0xFD,
-0x12, 0xEC, 0x94, 0x90, 0x06, 0x31, 0xE0, 0x54,
-0xF7, 0x44, 0x10, 0xF0, 0x7F, 0x00, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xFF, 0x90, 0x9A, 0x11, 0xE0,
-0x34, 0x00, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
-0x9A, 0x10, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x9A,
-0x0A, 0xE0, 0xFF, 0x90, 0x9A, 0x09, 0xE0, 0x2F,
-0xFF, 0x90, 0x9A, 0x08, 0xE0, 0x34, 0x00, 0x22,
-0xF1, 0xE5, 0xA3, 0xED, 0xF0, 0x12, 0xF5, 0x8E,
-0x7A, 0x80, 0x79, 0x80, 0x7E, 0x00, 0x7F, 0x06,
-0x12, 0x01, 0xE0, 0x78, 0x17, 0x7C, 0x9A, 0x7D,
-0x01, 0x7B, 0xFF, 0x7A, 0x80, 0x79, 0x86, 0x7E,
-0x00, 0x7F, 0x04, 0x12, 0x01, 0xE0, 0x78, 0x1B,
-0x7C, 0x9A, 0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x80,
-0x79, 0x8A, 0x7E, 0x00, 0x7F, 0x04, 0x12, 0x01,
-0xE0, 0xE4, 0x90, 0x9A, 0x20, 0xF0, 0xB1, 0x7E,
-0xCF, 0x24, 0x06, 0xCF, 0x34, 0x00, 0x71, 0xE7,
-0xEF, 0x64, 0x08, 0x60, 0x02, 0xC1, 0xD3, 0xB1,
-0x7E, 0xCF, 0x24, 0x07, 0xCF, 0x34, 0x00, 0x71,
-0xE7, 0xEF, 0x64, 0x06, 0x60, 0x02, 0xC1, 0xD3,
-0x90, 0x9A, 0x20, 0x04, 0xF0, 0xE4, 0x90, 0x9A,
-0x1F, 0xF0, 0xF1, 0x07, 0x50, 0x17, 0x90, 0x9A,
-0x09, 0xE0, 0x24, 0x0A, 0xFD, 0x90, 0x9A, 0x08,
-0xE0, 0x71, 0xDD, 0x90, 0x9A, 0x1F, 0x12, 0xF5,
-0x85, 0xD1, 0xD9, 0x80, 0xE5, 0x78, 0x0B, 0x7C,
-0x9A, 0x7D, 0x01, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0x38, 0x12, 0xA7, 0xED, 0x60, 0x02, 0xC1, 0xD3,
-0x90, 0x9A, 0x1F, 0xF0, 0xD1, 0xFE, 0x50, 0x18,
-0xD1, 0xE4, 0xB1, 0x89, 0xCD, 0x24, 0x20, 0x71,
-0xDC, 0x90, 0x9A, 0x1F, 0xE0, 0x24, 0x1B, 0xF5,
-0x82, 0xE4, 0x34, 0x9A, 0xD1, 0xD9, 0x80, 0xE4,
-0x78, 0x1B, 0x7C, 0x9A, 0x12, 0xEE, 0x62, 0xEF,
-0x70, 0x78, 0x90, 0x06, 0x30, 0xE0, 0x44, 0x01,
-0x54, 0xDF, 0xF0, 0x90, 0x93, 0x26, 0xE0, 0x30,
-0xE0, 0x02, 0x80, 0x10, 0x90, 0x98, 0x09, 0xE0,
-0xB4, 0x02, 0x12, 0x90, 0x93, 0x25, 0x12, 0xB2,
-0xDA, 0x20, 0xE0, 0x09, 0x90, 0x01, 0xC7, 0x74,
-0x09, 0xF1, 0xC9, 0x80, 0x56, 0xE4, 0x90, 0x9A,
-0x1F, 0xF0, 0xF1, 0x07, 0x50, 0x0B, 0x71, 0xC8,
-0x90, 0x9A, 0x1F, 0xF1, 0xF5, 0xD1, 0xD9, 0x80,
-0xF1, 0xE4, 0x90, 0x9A, 0x1F, 0xF0, 0xD1, 0xFE,
-0x50, 0x18, 0xD1, 0xE4, 0xB1, 0x89, 0xCD, 0x24,
-0x16, 0x71, 0xDC, 0x90, 0x9A, 0x1F, 0xE0, 0x24,
-0x17, 0xF5, 0x82, 0xE4, 0x34, 0x9A, 0xD1, 0xD9,
-0x80, 0xE4, 0x12, 0xC7, 0x56, 0x7B, 0x01, 0x7A,
-0x9A, 0x79, 0x11, 0x12, 0xDA, 0x04, 0xF0, 0xA3,
-0xF0, 0x7A, 0x9A, 0x79, 0x17, 0x12, 0x9D, 0xCC,
-0x80, 0x09, 0x90, 0x06, 0x30, 0xE0, 0x44, 0x21,
-0x54, 0xEF, 0xF0, 0x90, 0x9A, 0x20, 0xE0, 0xFF,
-0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x9A, 0x1F,
-0xE0, 0x04, 0xF0, 0x22, 0x90, 0x9A, 0x0A, 0xE0,
-0xFD, 0x90, 0x9A, 0x09, 0xE0, 0x2D, 0xFD, 0x22,
-0x90, 0x9A, 0x10, 0xE0, 0xFF, 0xC3, 0x22, 0x90,
-0x9A, 0x31, 0xE0, 0xFF, 0xC3, 0x22, 0x90, 0x9A,
-0x1F, 0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x22, 0x90,
-0x9A, 0x1F, 0xE0, 0xFF, 0xC3, 0x94, 0x06, 0x22,
-0xF0, 0x90, 0x9A, 0x08, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x22, 0xF1, 0xDD, 0xE4, 0x90, 0x9A, 0x0D,
-0xF0, 0x71, 0xE8, 0xEF, 0x54, 0x0C, 0x64, 0x08,
-0x70, 0x74, 0xF1, 0x11, 0xA3, 0xE0, 0x24, 0x06,
-0xF1, 0xB9, 0xEF, 0x64, 0x88, 0x70, 0x67, 0xF1,
-0x11, 0xA3, 0xE0, 0x24, 0x07, 0xF1, 0xB9, 0xEF,
-0x64, 0x8E, 0x70, 0x5A, 0x90, 0x9A, 0x0D, 0xF1,
-0xA4, 0xEF, 0x64, 0x03, 0x70, 0x50, 0xF1, 0x11,
-0x12, 0xEE, 0xD6, 0x24, 0x06, 0xF1, 0xB9, 0xEF,
-0x30, 0xE3, 0x07, 0x90, 0x01, 0xC7, 0x74, 0x01,
-0x80, 0x3A, 0x90, 0x93, 0x24, 0x12, 0xB2, 0xDA,
-0x30, 0xE0, 0x23, 0x90, 0x98, 0x09, 0xE0, 0x64,
-0x02, 0x70, 0x12, 0x90, 0x93, 0x25, 0x12, 0xB2,
-0xDA, 0x30, 0xE0, 0x02, 0x80, 0x07, 0x90, 0x01,
-0xC7, 0x74, 0x02, 0x80, 0x17, 0xF1, 0x11, 0xA3,
-0xE0, 0xFD, 0x71, 0xF8, 0x80, 0x10, 0x90, 0x93,
-0x29, 0x12, 0xA6, 0xEE, 0x30, 0xE0, 0x07, 0x90,
-0x01, 0xC7, 0x74, 0x02, 0xF1, 0xC9, 0x90, 0x9A,
-0x0D, 0xE0, 0xFF, 0x22, 0x04, 0xF0, 0x90, 0x9A,
-0x08, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x9A,
-0x0B, 0xE0, 0xFD, 0x90, 0x9A, 0x0A, 0xE0, 0x2D,
-0x04, 0xFD, 0x90, 0x8A, 0xE9, 0xE0, 0xFA, 0xA3,
-0xE0, 0xFB, 0xF5, 0x82, 0x8A, 0x83, 0x02, 0x04,
-0x7E, 0xF0, 0x90, 0x93, 0x31, 0xE0, 0x44, 0x01,
-0xF0, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x9A,
-0x31, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x9A, 0x0A,
-0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x9A, 0x08,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x7D, 0x01,
-0x7F, 0x02, 0x02, 0x7C, 0x74, 0xE0, 0x24, 0x11,
-0xF5, 0x82, 0xE4, 0x34, 0x9A, 0x22, 0x90, 0x99,
-0x85, 0x12, 0x82, 0x27, 0x90, 0x98, 0x2D, 0xE0,
-0x70, 0x12, 0x31, 0xAD, 0x12, 0x02, 0x06, 0x13,
+0x90, 0x9C, 0xDF, 0xE0, 0xFE, 0xEF, 0x4E, 0x90,
+0x86, 0xAF, 0xF0, 0x22, 0xF1, 0xED, 0x2E, 0x90,
+0x86, 0xB4, 0xF0, 0x12, 0x9C, 0x5A, 0xFF, 0xED,
+0x2F, 0x90, 0x86, 0xB5, 0xF1, 0xE6, 0xFF, 0xED,
+0x2F, 0x90, 0x86, 0xB6, 0xF1, 0xA3, 0xFF, 0xED,
+0x2F, 0x90, 0x86, 0xB7, 0xF1, 0xD1, 0xFF, 0xED,
+0x2F, 0x90, 0x86, 0xB8, 0xF1, 0x9B, 0xFF, 0xED,
+0x2F, 0x90, 0x86, 0xB9, 0xF1, 0xD8, 0x90, 0x86,
+0xBA, 0xF0, 0x22, 0xF0, 0x90, 0x00, 0x05, 0x02,
+0x02, 0x1F, 0x4F, 0xF0, 0x90, 0x00, 0x03, 0x02,
+0x02, 0x1F, 0x90, 0x02, 0x09, 0xE0, 0xFD, 0xF1,
+0xA4, 0xFE, 0xAF, 0x05, 0xED, 0x2E, 0x90, 0x98,
+0x41, 0xF1, 0xD1, 0xFF, 0xED, 0x2F, 0x90, 0x98,
+0x42, 0xF1, 0x9B, 0xFF, 0xED, 0x2F, 0x90, 0x98,
+0x43, 0xF1, 0xD8, 0x90, 0x98, 0x44, 0xF0, 0x22,
+0x4F, 0xF0, 0x90, 0x00, 0x04, 0x02, 0x02, 0x1F,
+0xF0, 0x90, 0x00, 0x06, 0x12, 0x02, 0x1F, 0xFF,
+0xAE, 0x05, 0xED, 0x2F, 0x22, 0x4F, 0xF0, 0x90,
+0x00, 0x02, 0x02, 0x02, 0x1F, 0x90, 0x02, 0x09,
+0xE0, 0xFD, 0x12, 0x02, 0x06, 0xFE, 0xAF, 0x05,
+0xED, 0x22, 0x90, 0x99, 0xB1, 0x51, 0x27, 0x90,
+0x98, 0x59, 0xE0, 0x70, 0x0F, 0xF1, 0x6A, 0x13,
 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x06, 0x90, 0x98,
-0x33, 0x74, 0x01, 0xF0, 0x90, 0x98, 0x2F, 0xE0,
-0x70, 0x12, 0x31, 0xAD, 0x12, 0x02, 0x06, 0xC4,
-0x54, 0x0F, 0xFF, 0xBF, 0x05, 0x06, 0x90, 0x98,
-0x34, 0x74, 0x01, 0xF0, 0x31, 0xAD, 0x12, 0x87,
-0x9D, 0xFF, 0x90, 0x99, 0x89, 0xF0, 0x12, 0x02,
-0x06, 0xC3, 0x13, 0x30, 0xE0, 0x0B, 0x31, 0xAD,
-0x12, 0x87, 0xA4, 0x90, 0x99, 0x8A, 0xF0, 0x80,
-0x05, 0x90, 0x99, 0x8A, 0xEF, 0xF0, 0x90, 0x99,
-0x89, 0xE0, 0x90, 0x99, 0x88, 0xF0, 0x90, 0x99,
-0x8A, 0xE0, 0xFE, 0x90, 0x99, 0x88, 0xE0, 0xFF,
-0xD3, 0x9E, 0x50, 0x38, 0x31, 0xAD, 0x12, 0x02,
-0x06, 0x54, 0x01, 0xFD, 0x12, 0x6E, 0x71, 0x90,
-0x99, 0x88, 0xE0, 0xFF, 0x12, 0x78, 0x4A, 0xEF,
-0x90, 0x99, 0x88, 0x70, 0x06, 0xE0, 0xFF, 0xF1,
-0xAA, 0x80, 0x04, 0xE0, 0xFF, 0xF1, 0xC8, 0x90,
-0x98, 0x34, 0xE0, 0x60, 0x07, 0x90, 0x99, 0x88,
-0xE0, 0xFF, 0xF1, 0xAA, 0x90, 0x99, 0x88, 0xE0,
-0x04, 0xF0, 0x80, 0xBA, 0x90, 0x05, 0x5E, 0xE4,
-0xF0, 0x90, 0x99, 0x89, 0xE0, 0x70, 0x1A, 0xFF,
-0x12, 0x78, 0x4A, 0xEF, 0x70, 0x13, 0x90, 0x86,
-0x0C, 0x31, 0xBD, 0x90, 0x8A, 0xED, 0x31, 0xBD,
-0x12, 0xF5, 0xB6, 0x54, 0xBF, 0xF0, 0x54, 0x7F,
-0xF0, 0x22, 0x90, 0x9C, 0x66, 0x12, 0x82, 0x27,
-0x90, 0x9C, 0x65, 0xEF, 0xF0, 0x12, 0x82, 0x30,
-0x91, 0x24, 0x00, 0x91, 0x29, 0x01, 0x91, 0x2E,
-0x03, 0x91, 0x33, 0x04, 0x91, 0x38, 0x06, 0x91,
-0x49, 0x12, 0x91, 0x4E, 0x14, 0x91, 0x53, 0x1E,
-0x91, 0x58, 0x20, 0x91, 0x5C, 0x25, 0x91, 0x61,
-0x27, 0x91, 0x66, 0x29, 0x91, 0x6B, 0x2A, 0x91,
-0x75, 0x80, 0x91, 0x70, 0x81, 0x91, 0x79, 0x82,
-0x91, 0x7E, 0x83, 0x91, 0x83, 0x84, 0x91, 0x8D,
-0x86, 0x91, 0x88, 0x88, 0x91, 0x92, 0xC3, 0x91,
-0x3D, 0xC6, 0x91, 0x3D, 0xC7, 0x91, 0x3D, 0xC8,
-0x00, 0x00, 0x91, 0x97, 0x31, 0xA7, 0x02, 0x87,
-0x64, 0x31, 0xA7, 0x02, 0x8F, 0xFE, 0x31, 0xA7,
-0x02, 0xDA, 0x5E, 0x31, 0xA7, 0x02, 0xEF, 0xE5,
-0x31, 0xA7, 0x02, 0xB0, 0x73, 0x90, 0x9C, 0x65,
-0xE0, 0xFF, 0xA3, 0x12, 0x82, 0x1E, 0x02, 0xB1,
-0x0C, 0x31, 0xA7, 0x02, 0x98, 0x04, 0x31, 0xA7,
-0x02, 0x9F, 0xF7, 0x31, 0xA7, 0x02, 0x9B, 0xBC,
-0x31, 0xA7, 0xC1, 0xBC, 0x31, 0xA7, 0x02, 0xA0,
-0x06, 0x31, 0xA7, 0x02, 0x87, 0xD1, 0x31, 0xA7,
-0x02, 0xA7, 0xF6, 0x31, 0xA7, 0x02, 0xA0, 0x0E,
-0x31, 0xA7, 0x02, 0xDB, 0x4F, 0x31, 0xA7, 0x61,
-0x38, 0x31, 0xA7, 0x02, 0xEF, 0x23, 0x31, 0xA7,
-0x02, 0xEF, 0x31, 0x31, 0xA7, 0x02, 0xEF, 0x78,
-0x31, 0xA7, 0x02, 0x87, 0xAA, 0x31, 0xA7, 0x02,
-0xDA, 0x8A, 0x31, 0xA7, 0x02, 0xAF, 0xF2, 0x90,
-0x01, 0xC0, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x9C,
-0x65, 0xE0, 0x90, 0x01, 0xC2, 0xF0, 0x22, 0x90,
-0x9C, 0x66, 0x02, 0x82, 0x1E, 0x90, 0x99, 0x85,
-0x02, 0x82, 0x1E, 0x7D, 0xFF, 0xE4, 0xFF, 0x12,
-0x9C, 0x0E, 0x90, 0x8A, 0xFD, 0xE0, 0xFE, 0xA3,
-0xE0, 0xAA, 0x06, 0xF9, 0x02, 0x04, 0x7A, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9C,
-0x9E, 0xED, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0xFE,
-0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
-0x61, 0x33, 0xEE, 0xF1, 0xB2, 0x30, 0xE0, 0x02,
-0x61, 0x33, 0x90, 0x88, 0x39, 0xE0, 0xFE, 0x6F,
-0x70, 0x02, 0x61, 0x33, 0xEF, 0x70, 0x02, 0x41,
-0x94, 0x24, 0xFE, 0x70, 0x02, 0x41, 0xD9, 0x24,
-0xFE, 0x60, 0x4F, 0x24, 0xFC, 0x70, 0x02, 0x61,
-0x1E, 0x24, 0xFC, 0x60, 0x02, 0x61, 0x2E, 0xEE,
-0xB4, 0x0E, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88,
+0x5F, 0x74, 0x01, 0xF0, 0x90, 0x98, 0x5B, 0xE0,
+0x70, 0x0F, 0xF1, 0x6A, 0xC4, 0x54, 0x0F, 0xFF,
+0xBF, 0x05, 0x06, 0x90, 0x98, 0x60, 0x74, 0x01,
+0xF0, 0x90, 0x99, 0xB1, 0x12, 0x9C, 0x57, 0xFF,
+0x90, 0x99, 0xB5, 0xF0, 0x12, 0x02, 0x06, 0xC3,
+0x13, 0x30, 0xE0, 0x0C, 0x12, 0xC7, 0x95, 0x12,
+0x87, 0xE7, 0x90, 0x99, 0xB6, 0xF0, 0x80, 0x05,
+0x90, 0x99, 0xB6, 0xEF, 0xF0, 0x90, 0x99, 0xB5,
+0xE0, 0x90, 0x99, 0xB4, 0xF0, 0x90, 0x99, 0xB6,
+0xE0, 0xFE, 0x90, 0x99, 0xB4, 0xE0, 0xFF, 0xD3,
+0x9E, 0x50, 0x36, 0xF1, 0x6A, 0x54, 0x01, 0xFD,
+0x12, 0x6E, 0x71, 0x90, 0x99, 0xB4, 0xE0, 0xFF,
+0x12, 0x78, 0x4A, 0xEF, 0x90, 0x99, 0xB4, 0x70,
+0x06, 0xE0, 0xFF, 0xF1, 0xF3, 0x80, 0x05, 0xE0,
+0xFF, 0x12, 0xBF, 0xF5, 0x90, 0x98, 0x60, 0xE0,
+0x60, 0x07, 0x90, 0x99, 0xB4, 0xE0, 0xFF, 0xF1,
+0xF3, 0x90, 0x99, 0xB4, 0xE0, 0x04, 0xF0, 0x80,
+0xBC, 0x90, 0x05, 0x5E, 0xE4, 0xF0, 0x90, 0x99,
+0xB5, 0xE0, 0x70, 0x1A, 0xFF, 0x12, 0x78, 0x4A,
+0xEF, 0x70, 0x13, 0x90, 0x86, 0x0C, 0x11, 0xC8,
+0x90, 0x8A, 0xED, 0x11, 0xC8, 0x12, 0xDC, 0xC1,
+0x54, 0xBF, 0xF0, 0x54, 0x7F, 0xF0, 0x22, 0x7D,
+0xFF, 0xE4, 0xFF, 0xB1, 0x1E, 0x90, 0x8A, 0xFD,
+0xE0, 0xFE, 0xA3, 0xE0, 0xAA, 0x06, 0xF9, 0x02,
+0x04, 0x7A, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x9C, 0xE6, 0xED, 0xF0, 0x90, 0x88,
+0x31, 0xE0, 0xFE, 0xC4, 0x13, 0x13, 0x54, 0x03,
+0x30, 0xE0, 0x02, 0x41, 0x40, 0xEE, 0x12, 0xA8,
+0xAA, 0x30, 0xE0, 0x02, 0x41, 0x40, 0x90, 0x88,
+0x39, 0xE0, 0xFE, 0x6F, 0x70, 0x02, 0x41, 0x40,
+0xEF, 0x70, 0x02, 0x21, 0xA0, 0x24, 0xFE, 0x70,
+0x02, 0x21, 0xE5, 0x24, 0xFE, 0x60, 0x4F, 0x24,
+0xFC, 0x70, 0x02, 0x41, 0x2A, 0x24, 0xFC, 0x60,
+0x02, 0x41, 0x3A, 0xEE, 0xB4, 0x0E, 0x03, 0x12,
+0x71, 0x5F, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x05,
+0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90, 0x88, 0x39,
+0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x04, 0x11, 0x90, 0x9C,
+0xE6, 0xE0, 0xFF, 0x60, 0x05, 0x12, 0x67, 0x80,
+0x80, 0x05, 0x90, 0x8A, 0xED, 0x11, 0xC8, 0x90,
+0x88, 0x39, 0xE0, 0x64, 0x08, 0x60, 0x02, 0x41,
+0x3A, 0x12, 0x7B, 0xCC, 0x41, 0x3A, 0x90, 0x88,
 0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12, 0x78,
 0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03,
 0x12, 0x71, 0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4,
-0x04, 0x11, 0x90, 0x9C, 0x9E, 0xE0, 0xFF, 0x60,
-0x05, 0x12, 0x67, 0x80, 0x80, 0x05, 0x90, 0x8A,
-0xED, 0x31, 0xBD, 0x90, 0x88, 0x39, 0xE0, 0x64,
-0x08, 0x60, 0x02, 0x61, 0x2E, 0x12, 0x7B, 0xCC,
-0x61, 0x2E, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x05,
-0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90, 0x88, 0x39,
-0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24, 0x90,
-0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B, 0x90, 0x86,
-0x00, 0x31, 0xBD, 0xBF, 0x01, 0x03, 0x12, 0x71,
-0x5F, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x0C, 0x60,
-0x02, 0x61, 0x2E, 0x90, 0x86, 0x00, 0x31, 0xBD,
-0xEF, 0x64, 0x01, 0x60, 0x02, 0x61, 0x2E, 0x12,
-0x68, 0xC2, 0x61, 0x2E, 0x90, 0x88, 0x39, 0xE0,
-0xB4, 0x0E, 0x0B, 0x90, 0x86, 0x00, 0x31, 0xBD,
-0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88,
-0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71, 0x24,
-0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0B, 0x90,
-0x86, 0x00, 0x31, 0xBD, 0xBF, 0x01, 0x03, 0x12,
-0x68, 0xC2, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x04,
-0x70, 0x64, 0x90, 0x86, 0x02, 0x31, 0xBD, 0xEF,
-0x64, 0x01, 0x70, 0x5A, 0x12, 0x73, 0x5A, 0x80,
-0x55, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B,
-0x90, 0x86, 0x00, 0x31, 0xBD, 0xBF, 0x01, 0x03,
-0x12, 0x71, 0x5F, 0x90, 0x88, 0x39, 0xE0, 0xB4,
-0x06, 0x03, 0x12, 0x71, 0x24, 0x90, 0x88, 0x39,
-0xE0, 0xB4, 0x0C, 0x0B, 0x90, 0x86, 0x00, 0x31,
-0xBD, 0xBF, 0x01, 0x03, 0x12, 0x68, 0xC2, 0x90,
-0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12,
-0x78, 0xC0, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x04,
-0x15, 0x12, 0x7A, 0x49, 0x80, 0x10, 0x90, 0x88,
-0x39, 0xE0, 0xB4, 0x0C, 0x09, 0x12, 0xBF, 0xB7,
-0x30, 0xE0, 0x03, 0x12, 0x79, 0xD4, 0x90, 0x88,
-0x39, 0xF1, 0xF6, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xF1,
-0xE3, 0x20, 0xE0, 0x0C, 0x90, 0x00, 0x04, 0xE0,
-0x54, 0xF7, 0xF0, 0x12, 0xE1, 0x6C, 0x81, 0x84,
-0x31, 0xAD, 0x12, 0xDA, 0x82, 0x90, 0x93, 0x29,
-0x12, 0xDC, 0x94, 0xFD, 0xEF, 0x54, 0xFB, 0x4D,
-0xFF, 0x90, 0x93, 0x29, 0x12, 0xDB, 0x41, 0x12,
-0xDF, 0x76, 0x90, 0x93, 0x29, 0x12, 0xDF, 0x6D,
-0x12, 0xDB, 0x49, 0x12, 0xDC, 0x83, 0x4D, 0xFF,
-0x90, 0x93, 0x29, 0x12, 0xDF, 0x80, 0x12, 0x87,
-0x9C, 0x54, 0x80, 0xFF, 0x90, 0x93, 0x2A, 0xE0,
-0x54, 0x7F, 0xB1, 0xF3, 0xFF, 0x54, 0x02, 0xFE,
-0x90, 0x93, 0x2D, 0xE0, 0x54, 0xFD, 0x4E, 0xFE,
-0xF0, 0xEF, 0x54, 0x08, 0xFF, 0xEE, 0x54, 0xF7,
-0x4F, 0x12, 0xE7, 0xE3, 0x90, 0x93, 0x2E, 0xB1,
-0xF4, 0x54, 0x10, 0xFF, 0x90, 0x93, 0x2D, 0xE0,
-0x54, 0xEF, 0x4F, 0xF0, 0x12, 0x02, 0x06, 0xFF,
-0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0, 0x07, 0x90,
-0x06, 0x90, 0xE0, 0x44, 0x04, 0xF0, 0xEF, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x07, 0x90,
-0x06, 0x90, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x93,
-0x2E, 0xE0, 0x70, 0x02, 0x04, 0xF0, 0x31, 0xAD,
-0xB1, 0xF5, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x0E,
-0x7F, 0x05, 0x12, 0x7B, 0x41, 0xEF, 0x54, 0x7F,
-0xFD, 0x7F, 0x05, 0x12, 0x7B, 0x2E, 0x90, 0x86,
-0xB3, 0xE0, 0xB4, 0x02, 0x05, 0xF1, 0xAE, 0x20,
-0xE0, 0x64, 0x31, 0xAD, 0x12, 0x87, 0x9D, 0x54,
-0x7F, 0xFF, 0x90, 0x93, 0x2A, 0xE0, 0x54, 0x80,
-0x4F, 0x12, 0x87, 0xA3, 0x54, 0x7F, 0xFF, 0x90,
-0x93, 0x2B, 0xE0, 0x54, 0x80, 0x4F, 0xF1, 0xCC,
-0xFF, 0x54, 0x01, 0xFE, 0x90, 0x93, 0x2C, 0xE0,
-0x54, 0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0xFE,
-0xFF, 0xEE, 0x54, 0x01, 0xB1, 0xF3, 0xFF, 0x54,
-0x04, 0xFE, 0x90, 0x93, 0x2D, 0xE0, 0x54, 0xFB,
-0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x01, 0xFF, 0xEE,
-0x54, 0xFE, 0x4F, 0xF0, 0xB1, 0xE4, 0x54, 0x07,
-0x7D, 0x00, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0x91,
-0x89, 0x90, 0x93, 0x2D, 0xE0, 0xFF, 0xC3, 0x13,
-0x30, 0xE0, 0x03, 0x12, 0xE2, 0x08, 0x90, 0x86,
-0xB3, 0xE0, 0xB4, 0x01, 0x07, 0x90, 0xFE, 0x10,
-0xE0, 0x44, 0x04, 0xF0, 0x90, 0x95, 0x63, 0x74,
-0x05, 0xF0, 0x12, 0xF5, 0x73, 0x7A, 0x94, 0x79,
-0x42, 0x12, 0x04, 0x80, 0xD0, 0xD0, 0x92, 0xAF,
+0x0E, 0x0B, 0x90, 0x86, 0x00, 0x11, 0xC8, 0xBF,
+0x01, 0x03, 0x12, 0x71, 0x5F, 0x90, 0x88, 0x39,
+0xE0, 0x64, 0x0C, 0x60, 0x02, 0x41, 0x3A, 0x90,
+0x86, 0x00, 0x11, 0xC8, 0xEF, 0x64, 0x01, 0x60,
+0x02, 0x41, 0x3A, 0x12, 0x68, 0xC2, 0x41, 0x3A,
+0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0E, 0x0B, 0x90,
+0x86, 0x00, 0x11, 0xC8, 0xBF, 0x01, 0x03, 0x12,
+0x71, 0x5F, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x06,
+0x03, 0x12, 0x71, 0x24, 0x90, 0x88, 0x39, 0xE0,
+0xB4, 0x0C, 0x0B, 0x90, 0x86, 0x00, 0x11, 0xC8,
+0xBF, 0x01, 0x03, 0x12, 0x68, 0xC2, 0x90, 0x88,
+0x39, 0xE0, 0x64, 0x04, 0x70, 0x64, 0x90, 0x86,
+0x02, 0x11, 0xC8, 0xEF, 0x64, 0x01, 0x70, 0x5A,
+0x12, 0x73, 0x5A, 0x80, 0x55, 0x90, 0x88, 0x39,
+0xE0, 0xB4, 0x0E, 0x0B, 0x90, 0x86, 0x00, 0x11,
+0xC8, 0xBF, 0x01, 0x03, 0x12, 0x71, 0x5F, 0x90,
+0x88, 0x39, 0xE0, 0xB4, 0x06, 0x03, 0x12, 0x71,
+0x24, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C, 0x0B,
+0x90, 0x86, 0x00, 0x11, 0xC8, 0xBF, 0x01, 0x03,
+0x12, 0x68, 0xC2, 0x90, 0x88, 0x39, 0xE0, 0x70,
+0x05, 0x7F, 0x01, 0x12, 0x78, 0xC0, 0x90, 0x88,
+0x39, 0xE0, 0xB4, 0x04, 0x15, 0x12, 0x7A, 0x49,
+0x80, 0x10, 0x90, 0x88, 0x39, 0xE0, 0xB4, 0x0C,
+0x09, 0x12, 0xB4, 0xA0, 0x30, 0xE0, 0x03, 0x12,
+0x79, 0xD4, 0x90, 0x88, 0x39, 0x12, 0xFA, 0x75,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x9A, 0x61,
+0x12, 0x82, 0x27, 0x90, 0x05, 0x22, 0xE0, 0x90,
+0x9A, 0x72, 0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60,
+0x0B, 0x7B, 0x39, 0x11, 0xBF, 0xEF, 0x64, 0x01,
+0x70, 0x1C, 0x80, 0x00, 0x90, 0x98, 0x39, 0xE0,
+0xFF, 0x90, 0x92, 0x13, 0x74, 0x11, 0xF0, 0x7B,
+0x18, 0x7D, 0x01, 0x12, 0x66, 0xDB, 0x90, 0x9A,
+0x6F, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x9A,
+0x6F, 0xD1, 0xA3, 0x90, 0x9A, 0x71, 0xEF, 0xF0,
+0x90, 0x9A, 0x6F, 0x12, 0xFA, 0x1D, 0x7B, 0x01,
+0x90, 0x9A, 0x6D, 0xE0, 0xFD, 0x12, 0xF0, 0x46,
+0x90, 0x9A, 0x6E, 0xE0, 0x60, 0x02, 0x61, 0x21,
+0xB1, 0x48, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01,
+0x90, 0x9A, 0x64, 0x71, 0xE0, 0x75, 0x48, 0x06,
+0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03, 0x71, 0xD0,
+0xF1, 0xE9, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01,
+0x90, 0x9A, 0x61, 0x71, 0xE0, 0x75, 0x48, 0x10,
+0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03, 0x71, 0xD0,
+0xB1, 0x4B, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01,
+0x71, 0xDD, 0x75, 0x48, 0x10, 0xD0, 0x01, 0xD0,
+0x02, 0xD0, 0x03, 0x71, 0xD0, 0x24, 0x60, 0xF9,
+0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0xC0, 0x03,
+0xC0, 0x02, 0xC0, 0x01, 0x71, 0xDD, 0x75, 0x48,
+0x10, 0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03, 0x71,
+0xD0, 0x24, 0x72, 0xF9, 0xE4, 0x34, 0xFC, 0xFA,
+0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01,
+0x90, 0x9A, 0x6A, 0x71, 0xE0, 0x75, 0x48, 0x06,
+0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03, 0x12, 0x69,
+0xF5, 0x90, 0x9A, 0x67, 0x12, 0x82, 0x1E, 0x90,
+0x9A, 0x9E, 0x12, 0x82, 0x27, 0x90, 0x9A, 0xA1,
+0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x20, 0x90,
+0x9A, 0xA5, 0x74, 0x3A, 0xF0, 0x90, 0x9A, 0x61,
+0x12, 0x82, 0x1E, 0x12, 0xF1, 0xA0, 0x71, 0xD3,
+0xF1, 0xE2, 0xB1, 0xC9, 0x75, 0x48, 0x28, 0x7B,
+0x01, 0x7A, 0x9A, 0x79, 0x73, 0x71, 0xD0, 0xF1,
+0xE2, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0x8B, 0x45,
+0x75, 0x46, 0x93, 0x75, 0x47, 0xD1, 0x75, 0x48,
+0x28, 0xD0, 0x03, 0x12, 0x69, 0xF5, 0x90, 0x9A,
+0x71, 0xE0, 0xFF, 0x90, 0x9A, 0x70, 0xE0, 0x2F,
+0xFF, 0x90, 0x9A, 0x6F, 0xE0, 0x34, 0x00, 0xCF,
+0x24, 0x30, 0xFD, 0xE4, 0x3F, 0xFC, 0x90, 0x98,
+0x39, 0xE0, 0xFB, 0x7F, 0x3A, 0x12, 0xC3, 0xF8,
+0x71, 0xD3, 0xF1, 0xE2, 0xFA, 0x7B, 0x01, 0xC0,
+0x03, 0x8B, 0x45, 0x75, 0x46, 0x9A, 0x75, 0x47,
+0x73, 0x75, 0x48, 0x28, 0xD0, 0x03, 0x12, 0x69,
+0xF5, 0x90, 0x98, 0x35, 0xE0, 0xB4, 0x02, 0x0D,
+0x90, 0x98, 0x39, 0xE0, 0xFF, 0x90, 0x9A, 0x71,
+0xE0, 0xFD, 0x12, 0xF1, 0xDF, 0x90, 0x06, 0x33,
+0xE0, 0x44, 0x02, 0xF0, 0x90, 0x9A, 0x72, 0xE0,
+0xFD, 0x7B, 0x3A, 0x12, 0xFA, 0xDA, 0xF0, 0x22,
+0x12, 0x69, 0xF5, 0x90, 0x9A, 0x6F, 0xA3, 0xE0,
+0xFF, 0xA3, 0xE0, 0x2F, 0x22, 0x90, 0x9A, 0x67,
+0x12, 0x82, 0x1E, 0x8B, 0x45, 0x8A, 0x46, 0x89,
+0x47, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x9C, 0x3F, 0x12, 0x82, 0x27, 0x78,
+0x4B, 0x7C, 0x9C, 0x7D, 0x01, 0x7B, 0xFF, 0x7A,
+0x80, 0x79, 0x8E, 0x7E, 0x00, 0x7F, 0x06, 0x12,
+0x01, 0xE0, 0x90, 0x05, 0x22, 0xE0, 0x90, 0x9C,
+0x4A, 0xF0, 0x90, 0x04, 0x1D, 0xE0, 0x60, 0x0B,
+0x7B, 0x33, 0x11, 0xBF, 0xEF, 0x64, 0x01, 0x70,
+0x1C, 0x80, 0x00, 0x90, 0x98, 0x38, 0xE0, 0xFF,
+0x90, 0x92, 0x13, 0x74, 0x10, 0xF0, 0x7B, 0x18,
+0x7D, 0x01, 0x12, 0x66, 0xDB, 0x90, 0x9C, 0x47,
+0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x9C, 0x47,
+0xD1, 0xA3, 0x90, 0x9C, 0x49, 0xEF, 0xF0, 0x90,
+0x9C, 0x47, 0x12, 0xFA, 0x1D, 0x7B, 0x01, 0x90,
+0x9C, 0x45, 0xE0, 0xFD, 0x12, 0xF0, 0x46, 0x90,
+0x9C, 0x46, 0xE0, 0x70, 0x4D, 0xB1, 0x48, 0xC0,
+0x03, 0xC0, 0x02, 0xC0, 0x01, 0x90, 0x9C, 0x42,
+0x71, 0xE0, 0x75, 0x48, 0x06, 0xD0, 0x01, 0xD0,
+0x02, 0xD0, 0x03, 0xB1, 0x41, 0x71, 0xD6, 0xF1,
+0xDB, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02,
+0xC0, 0x01, 0x90, 0x9C, 0x42, 0x71, 0xE0, 0x75,
+0x48, 0x06, 0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03,
+0xB1, 0x41, 0x71, 0xD6, 0xF1, 0xE9, 0xC0, 0x03,
+0xC0, 0x02, 0xC0, 0x01, 0x90, 0x9C, 0x3F, 0x71,
+0xE0, 0x75, 0x48, 0x04, 0xD0, 0x01, 0xD0, 0x02,
+0x80, 0x44, 0x90, 0x9C, 0x46, 0xE0, 0x64, 0x01,
+0x70, 0x41, 0xB1, 0x48, 0xC0, 0x03, 0x8B, 0x45,
+0x75, 0x46, 0x93, 0x75, 0x47, 0x4D, 0x75, 0x48,
+0x06, 0xD0, 0x03, 0xB1, 0x41, 0x71, 0xD6, 0xF1,
+0xDB, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0x8B, 0x45,
+0x75, 0x46, 0x93, 0x75, 0x47, 0x57, 0x75, 0x48,
+0x06, 0xD0, 0x03, 0xB1, 0x41, 0x71, 0xD6, 0xF1,
+0xE9, 0xC0, 0x03, 0x8B, 0x45, 0x75, 0x46, 0x93,
+0x75, 0x47, 0x5D, 0x75, 0x48, 0x04, 0xD0, 0x03,
+0x12, 0x69, 0xF5, 0x90, 0x98, 0x35, 0xE0, 0xB4,
+0x02, 0x0D, 0x90, 0x98, 0x38, 0xE0, 0xFF, 0x90,
+0x9C, 0x49, 0xE0, 0xFD, 0x12, 0xF1, 0xDF, 0x90,
+0x06, 0x30, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x9C,
+0x4A, 0xE0, 0xFD, 0x7B, 0x34, 0x12, 0xFA, 0xDA,
+0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEB, 0xB4,
+0x57, 0x05, 0x12, 0xFA, 0xE5, 0x80, 0x10, 0xEF,
+0x70, 0x07, 0x90, 0x98, 0x6A, 0xE0, 0x4D, 0x80,
+0x06, 0x12, 0xC0, 0x48, 0x12, 0xFA, 0xE5, 0x90,
+0x05, 0x22, 0xF0, 0x90, 0x93, 0x01, 0xEB, 0xF0,
+0x22, 0x12, 0x69, 0xF5, 0x90, 0x9C, 0x47, 0x22,
+0xA3, 0xA3, 0xE0, 0x24, 0x38, 0xF9, 0xE4, 0x34,
+0xFC, 0xFA, 0x7B, 0x01, 0x22, 0xD1, 0x82, 0xE4,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x99, 0xB1, 0xD1,
+0xA3, 0x90, 0x99, 0xB3, 0xEF, 0xF0, 0x90, 0x99,
+0xB1, 0xA3, 0xE0, 0x24, 0x38, 0xF9, 0xE4, 0x34,
+0xFC, 0xB1, 0xC9, 0x75, 0x48, 0x06, 0x7B, 0x01,
+0x7A, 0x93, 0x79, 0x4D, 0xF1, 0x63, 0x71, 0xD6,
+0x24, 0x3E, 0xF9, 0xE4, 0x34, 0xFC, 0xB1, 0xC9,
+0x75, 0x48, 0x04, 0x7B, 0x01, 0x7A, 0x93, 0x79,
+0x53, 0xF1, 0x63, 0x71, 0xD6, 0xF1, 0xDB, 0xB1,
+0xC9, 0x75, 0x48, 0x06, 0x7B, 0x01, 0x7A, 0x93,
+0x79, 0x57, 0xF1, 0x63, 0x71, 0xD6, 0x24, 0x48,
+0xF9, 0xE4, 0x34, 0xFC, 0xB1, 0xC9, 0x75, 0x48,
+0x04, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x5D, 0x02,
+0x69, 0xF5, 0xE0, 0xFF, 0x90, 0x99, 0xB1, 0xE0,
+0x2F, 0xF0, 0xE0, 0x24, 0x00, 0xF9, 0xE4, 0x34,
+0xFC, 0x75, 0x45, 0x01, 0xF5, 0x46, 0x89, 0x47,
+0x22, 0x90, 0x98, 0x42, 0xD1, 0x80, 0xEF, 0xF0,
+0xE0, 0xFE, 0x12, 0xFA, 0xAF, 0xFF, 0x74, 0x29,
+0x2E, 0x12, 0xDE, 0x3E, 0xFD, 0x90, 0x99, 0xB1,
+0xE0, 0x24, 0x2C, 0xD1, 0xC0, 0x90, 0x99, 0xB1,
+0xE0, 0x2F, 0x24, 0x30, 0xA3, 0xF0, 0xE0, 0xFD,
+0x24, 0x04, 0x12, 0xD7, 0x1C, 0xFE, 0x74, 0x05,
+0x2D, 0x12, 0xC7, 0xB0, 0x12, 0xC7, 0x8C, 0x90,
+0x95, 0x9D, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x99,
+0xB2, 0xE0, 0x24, 0x0C, 0xF9, 0xE4, 0x34, 0xFC,
+0xB1, 0xC9, 0x75, 0x48, 0x04, 0x7B, 0x01, 0x7A,
+0x95, 0x79, 0x9F, 0x12, 0x69, 0xF5, 0x90, 0x99,
+0xB2, 0xE0, 0x24, 0x14, 0xF0, 0xE0, 0xFD, 0x24,
+0x01, 0x12, 0xC3, 0xF0, 0xE0, 0xFE, 0x74, 0x00,
+0x2D, 0xD1, 0x9B, 0x12, 0xC7, 0x8C, 0x90, 0x95,
+0xA3, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x98, 0x43,
+0xD1, 0x80, 0xEF, 0xF0, 0x90, 0x95, 0x99, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x4E, 0x60, 0x10, 0x90,
+0x99, 0xB1, 0xB1, 0xC2, 0x8F, 0x48, 0x7B, 0x01,
+0x7A, 0x95, 0x79, 0xA7, 0x12, 0x69, 0xF5, 0x90,
+0x98, 0x44, 0xD1, 0x80, 0xEF, 0xF0, 0xB1, 0xC3,
+0x90, 0x95, 0x9B, 0xA3, 0xE0, 0xF5, 0x48, 0x7B,
+0x01, 0x7A, 0x95, 0x79, 0xC7, 0x02, 0x69, 0xF5,
+0xE0, 0xFF, 0x12, 0x7B, 0x07, 0x90, 0x99, 0xB1,
+0x22, 0x12, 0x80, 0xC0, 0xA8, 0x04, 0xA9, 0x05,
+0xAA, 0x06, 0xAB, 0x07, 0x90, 0x99, 0xB1, 0xA3,
+0xE0, 0x24, 0x00, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
+0xF5, 0x83, 0x22, 0xA3, 0xE0, 0xFE, 0x24, 0x28,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
+0xFF, 0x74, 0x29, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xE0, 0xFD, 0x74, 0x2C, 0x2E,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
+0xFB, 0xE4, 0xFE, 0xEF, 0x30, 0xE7, 0x04, 0x7C,
+0x02, 0x80, 0x02, 0xE4, 0xFC, 0xED, 0x30, 0xE6,
+0x09, 0xAF, 0x03, 0x12, 0xF0, 0x07, 0xAE, 0x07,
+0x80, 0x02, 0xE4, 0xFE, 0xEC, 0x24, 0x18, 0x2E,
+0xFF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x93, 0x07, 0x12, 0xD7, 0x25, 0xD1,
+0x9B, 0xE0, 0x90, 0x9B, 0x26, 0xF0, 0x74, 0x01,
+0x2F, 0x12, 0xC3, 0xF0, 0xE0, 0x90, 0x9B, 0x47,
+0x12, 0xD7, 0x0B, 0x90, 0x9B, 0x68, 0xF0, 0xEF,
+0x24, 0x20, 0x90, 0x99, 0xB1, 0xF0, 0xB1, 0xC3,
+0x90, 0x9B, 0x26, 0xE0, 0xF5, 0x48, 0x7B, 0x01,
+0x7A, 0x9B, 0x79, 0x27, 0x12, 0x69, 0xF5, 0x90,
+0x9B, 0x26, 0xB1, 0xBA, 0x90, 0x9B, 0x47, 0xE0,
+0xF5, 0x48, 0x7B, 0x01, 0x7A, 0x9B, 0x79, 0x48,
+0x12, 0x69, 0xF5, 0x90, 0x9B, 0x47, 0xB1, 0xBA,
+0x90, 0x9B, 0x68, 0xE0, 0xF5, 0x48, 0x7B, 0x01,
+0x7A, 0x9B, 0x79, 0x69, 0x12, 0x69, 0xF5, 0xE4,
+0xFF, 0x90, 0x9B, 0x26, 0xE0, 0xFE, 0xEF, 0xC3,
+0x9E, 0x50, 0x03, 0x0F, 0x80, 0xF3, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x12, 0x69, 0xF5, 0x90, 0x99,
+0xB1, 0x22, 0x90, 0x99, 0xB1, 0x12, 0x82, 0x1E,
+0x02, 0x02, 0x06, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x9C, 0xA6, 0xEF, 0xF0, 0xA3,
+0xED, 0xF0, 0x90, 0x86, 0xB1, 0xE0, 0x04, 0xF0,
+0x90, 0x04, 0x1D, 0xE0, 0x60, 0x2F, 0x90, 0x05,
+0x22, 0xE0, 0x90, 0x9C, 0xAA, 0xF0, 0x7B, 0x26,
+0x11, 0xBF, 0xEF, 0x64, 0x01, 0x70, 0x0B, 0x12,
+0xF9, 0x5F, 0x12, 0xAF, 0xCA, 0x12, 0xDD, 0xFD,
+0xEE, 0xF0, 0x90, 0x9C, 0xAA, 0xE0, 0xFD, 0x7B,
+0x27, 0xE4, 0xFF, 0xB1, 0x1E, 0x12, 0xF9, 0xF9,
+0x12, 0x04, 0x7E, 0x80, 0x11, 0x12, 0xF9, 0xF9,
+0x12, 0x04, 0x7E, 0x12, 0xF9, 0x5F, 0x12, 0xAF,
+0xCA, 0x12, 0xDD, 0xFD, 0xEE, 0xF0, 0x90, 0x04,
+0x1F, 0x74, 0x20, 0xF0, 0x7F, 0x01, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x24, 0x42, 0xF9, 0xE4, 0x34,
+0xFC, 0x22, 0x24, 0x30, 0xF9, 0xE4, 0x34, 0xFC,
+0x22, 0x24, 0x48, 0xF9, 0xE4, 0x34, 0xFC, 0xFA,
+0x7B, 0x01, 0x22, 0x7D, 0x01, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9C, 0xD3, 0xEF,
+0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x8A, 0xF9, 0x11,
+0x47, 0x7D, 0x44, 0x7F, 0x6F, 0x12, 0x04, 0x7E,
+0x12, 0x88, 0xC5, 0x90, 0x9C, 0xD4, 0xE0, 0x90,
+0x9C, 0xD3, 0xB4, 0x01, 0x07, 0x91, 0xF0, 0x44,
+0x04, 0xF0, 0x80, 0x05, 0x91, 0xF0, 0x54, 0xFB,
+0xF0, 0x90, 0x8A, 0xF9, 0x11, 0x47, 0x91, 0x98,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x8A, 0x77,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xF5, 0x82, 0x8E,
+0x83, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0x79, 0xE0,
+0xFE, 0xA3, 0xE0, 0xF5, 0x82, 0x8E, 0x83, 0x22,
+0x90, 0x99, 0xB1, 0xEF, 0x51, 0xCD, 0x7F, 0xF4,
+0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08,
+0x90, 0x99, 0xF8, 0xE0, 0x90, 0x99, 0xFA, 0xF0,
+0x51, 0xCE, 0x7F, 0xF5, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99, 0xF8, 0xE0,
+0x90, 0x99, 0xFB, 0xF0, 0x51, 0xCE, 0x7F, 0xF6,
+0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08,
+0x90, 0x99, 0xF8, 0xE0, 0x90, 0x99, 0xFC, 0xF0,
+0x51, 0xCE, 0x7F, 0xF7, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99, 0xF8, 0xE0,
+0x90, 0x99, 0xFD, 0xF0, 0x51, 0xCE, 0x7F, 0xF8,
+0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08,
+0x90, 0x99, 0xF8, 0xE0, 0x90, 0x99, 0xFE, 0xF0,
+0x51, 0xCE, 0x12, 0xFB, 0xA4, 0xBF, 0x01, 0x08,
+0x90, 0x99, 0xF8, 0xE0, 0x90, 0x99, 0xFF, 0xF0,
+0x51, 0xCE, 0x71, 0xC7, 0x64, 0x01, 0x70, 0x54,
+0x90, 0x99, 0xF8, 0xE0, 0x90, 0x9A, 0x00, 0xF0,
+0x54, 0x07, 0x60, 0x08, 0x90, 0x99, 0xF8, 0xE0,
+0x54, 0xE0, 0x70, 0x40, 0x7B, 0x01, 0x7A, 0x99,
+0x79, 0xF9, 0x7F, 0xFA, 0x71, 0xC9, 0x64, 0x01,
+0x70, 0x32, 0x90, 0x99, 0xF8, 0xE0, 0xFC, 0x54,
+0x07, 0x70, 0x12, 0x90, 0x9A, 0x00, 0xE0, 0xFE,
+0x90, 0x99, 0xF9, 0xE0, 0x54, 0x07, 0xFD, 0xEE,
+0x4D, 0x90, 0x9A, 0x00, 0xF0, 0xEC, 0x54, 0xE0,
+0x70, 0x12, 0x90, 0x9A, 0x00, 0xE0, 0xFF, 0x90,
+0x99, 0xF9, 0xE0, 0x54, 0xE0, 0xFE, 0xEF, 0x4E,
+0x90, 0x9A, 0x00, 0xF0, 0x51, 0xCE, 0x7F, 0xFD,
+0x71, 0xC9, 0x64, 0x01, 0x70, 0x4B, 0x90, 0x99,
+0xF8, 0xE0, 0xFE, 0x54, 0xCC, 0x90, 0x9A, 0x01,
+0xF0, 0xEE, 0x54, 0x0C, 0xFF, 0x60, 0x08, 0x90,
+0x99, 0xF8, 0xE0, 0x54, 0xC0, 0x70, 0x32, 0xEF,
+0x70, 0x16, 0x90, 0x9A, 0x01, 0xE0, 0xFF, 0x90,
+0x99, 0xF8, 0xE0, 0x54, 0x03, 0x25, 0xE0, 0x25,
+0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x9A, 0x01, 0xF0,
+0x90, 0x99, 0xF8, 0xE0, 0xFF, 0x54, 0xC0, 0x70,
+0x10, 0x90, 0x9A, 0x01, 0xE0, 0xFE, 0xEF, 0x54,
+0x30, 0x25, 0xE0, 0x25, 0xE0, 0xFF, 0xEE, 0x4F,
+0xF0, 0x51, 0xCE, 0x7F, 0xF0, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99, 0xF8,
+0xE0, 0x90, 0x9A, 0x02, 0xF0, 0x51, 0xCE, 0x7F,
+0xF1, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
+0x08, 0x90, 0x99, 0xF8, 0xE0, 0x90, 0x9A, 0x03,
+0xF0, 0x51, 0xCE, 0x7F, 0xF2, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99, 0xF8,
+0xE0, 0x90, 0x9A, 0x04, 0xF0, 0x51, 0xCE, 0x7F,
+0xF3, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
+0x08, 0x90, 0x99, 0xF8, 0xE0, 0x90, 0x9A, 0x05,
+0xF0, 0x51, 0xCE, 0x7F, 0xFC, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99, 0xF8,
+0xE0, 0x90, 0x9A, 0x06, 0xF0, 0x90, 0x99, 0xB2,
+0x74, 0x19, 0xF0, 0x90, 0x99, 0xD4, 0x74, 0x08,
+0xF0, 0x90, 0x99, 0xFA, 0xE0, 0x90, 0x99, 0xB4,
+0xF0, 0x90, 0x99, 0xFB, 0xE0, 0x90, 0x99, 0xB5,
+0xF0, 0x90, 0x99, 0xFC, 0xE0, 0x90, 0x99, 0xB6,
+0xF0, 0x90, 0x99, 0xFD, 0xE0, 0x90, 0x99, 0xB7,
+0xF0, 0x90, 0x99, 0xFE, 0xE0, 0x90, 0x99, 0xB8,
+0xF0, 0x90, 0x99, 0xFF, 0xE0, 0x90, 0x99, 0xB9,
+0xF0, 0x90, 0x9A, 0x00, 0xE0, 0x90, 0x99, 0xBA,
+0xF0, 0x90, 0x9A, 0x01, 0xE0, 0x90, 0x99, 0xBB,
+0xF0, 0x90, 0x99, 0xD5, 0x74, 0x1A, 0xF0, 0x90,
+0x99, 0xF7, 0x74, 0x05, 0xF0, 0x90, 0x9A, 0x02,
+0xE0, 0x90, 0x99, 0xD7, 0xF0, 0x90, 0x9A, 0x03,
+0xE0, 0x90, 0x99, 0xD8, 0xF0, 0x90, 0x9A, 0x04,
+0xE0, 0x90, 0x99, 0xD9, 0xF0, 0x90, 0x9A, 0x05,
+0xE0, 0x90, 0x99, 0xDA, 0xF0, 0x90, 0x9A, 0x06,
+0xE0, 0x90, 0x99, 0xDB, 0xF0, 0x90, 0x00, 0x35,
+0xE0, 0x54, 0xFC, 0x44, 0x01, 0x51, 0xCD, 0x7F,
+0x6F, 0x7E, 0x00, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
+0x08, 0x90, 0x99, 0xF8, 0xE0, 0x90, 0x9A, 0x07,
+0xF0, 0x90, 0x00, 0x35, 0xE0, 0x54, 0xFC, 0xF0,
+0x90, 0x99, 0xB1, 0xE0, 0xB4, 0x01, 0x16, 0x7B,
+0x01, 0x7A, 0x99, 0x79, 0xB2, 0x12, 0xF9, 0xC3,
+0x7B, 0x01, 0x7A, 0x99, 0x79, 0xD5, 0x11, 0x35,
+0x7F, 0x04, 0x02, 0x04, 0x7E, 0x75, 0x45, 0x01,
+0x75, 0x46, 0x99, 0x75, 0x47, 0xB2, 0x75, 0x48,
+0x0A, 0x7B, 0x01, 0x7A, 0x01, 0x79, 0xA0, 0x12,
+0xFB, 0x0B, 0x75, 0x46, 0x99, 0x75, 0x47, 0xD7,
+0x75, 0x48, 0x05, 0x7B, 0x01, 0x7A, 0x01, 0x79,
+0xAA, 0x12, 0x69, 0xF5, 0x90, 0x9A, 0x07, 0xE0,
+0x90, 0x01, 0xA1, 0xF0, 0x22, 0xF0, 0x7B, 0x01,
+0x7A, 0x99, 0x79, 0xF8, 0x22, 0x7E, 0x00, 0x7F,
+0x62, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x88, 0x79,
+0x31, 0x12, 0x04, 0x80, 0x12, 0xFA, 0x95, 0x12,
+0x04, 0x80, 0xE4, 0x90, 0x99, 0xAF, 0xF0, 0x90,
+0x88, 0x35, 0x74, 0x02, 0xF0, 0x90, 0x88, 0x3C,
+0x14, 0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x50, 0xF0,
+0x90, 0x88, 0x42, 0xE4, 0xF0, 0xA3, 0x74, 0x02,
+0xF0, 0x90, 0x88, 0x4E, 0x74, 0x10, 0xF0, 0xA3,
+0x74, 0x50, 0xF0, 0x12, 0xF8, 0xA6, 0x90, 0x8A,
+0x89, 0x11, 0x47, 0x91, 0x98, 0x90, 0x8A, 0x89,
+0x11, 0x47, 0x7D, 0x0C, 0x7F, 0x02, 0x12, 0x04,
+0x7E, 0x90, 0x8A, 0x89, 0x11, 0x47, 0x7D, 0x0C,
+0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x86, 0xB3,
+0xE0, 0xFF, 0xB4, 0x01, 0x08, 0x90, 0x88, 0x41,
+0x74, 0xD4, 0xF0, 0x80, 0x11, 0xEF, 0xB4, 0x03,
+0x08, 0x90, 0x88, 0x41, 0x74, 0x14, 0xF0, 0x80,
+0x05, 0xE4, 0x90, 0x88, 0x41, 0xF0, 0x90, 0x00,
+0x79, 0xE0, 0x54, 0x03, 0xFF, 0xBF, 0x02, 0x0D,
+0x90, 0x00, 0x28, 0xE0, 0x30, 0xE2, 0x06, 0x90,
+0x88, 0x53, 0x74, 0x02, 0xF0, 0x90, 0x88, 0x93,
+0x74, 0x03, 0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3,
+0xE0, 0x54, 0x01, 0x44, 0x28, 0xF0, 0xA3, 0x74,
+0x07, 0xF0, 0x7E, 0x00, 0x7F, 0x18, 0x7D, 0x00,
+0x7B, 0x01, 0x7A, 0x93, 0x79, 0x0C, 0x12, 0x04,
+0x80, 0x90, 0x8A, 0xA3, 0x11, 0x47, 0x7F, 0x01,
+0x12, 0x04, 0x7E, 0x90, 0x05, 0x58, 0x74, 0x02,
+0xF0, 0x7E, 0x00, 0xFF, 0x7D, 0x00, 0x7B, 0x01,
+0x7A, 0x88, 0x79, 0x9A, 0x12, 0x04, 0x80, 0x90,
+0x06, 0x04, 0xE0, 0x54, 0x7F, 0xF0, 0x90, 0x06,
+0x0A, 0xE0, 0x54, 0xF8, 0xF0, 0x90, 0x05, 0x22,
+0xE4, 0xF0, 0x90, 0x88, 0x9C, 0xF0, 0x22, 0x7F,
+0xFB, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xEF, 0x22,
+0x90, 0x99, 0xAF, 0x74, 0x01, 0xF0, 0x90, 0x06,
+0x92, 0x04, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x04,
+0xF0, 0x90, 0x88, 0x31, 0xE0, 0x44, 0x08, 0xF0,
+0x90, 0x88, 0x39, 0xE0, 0x64, 0x0C, 0x60, 0x13,
+0x90, 0x8A, 0xB9, 0x11, 0x47, 0xE4, 0xFD, 0x7F,
+0x0C, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0xF9, 0x11,
+0x47, 0x91, 0x98, 0x90, 0x8A, 0xAF, 0x11, 0x47,
+0x7D, 0x08, 0xE4, 0xFF, 0x02, 0x04, 0x7E, 0xE4,
+0x90, 0x9A, 0x35, 0xF0, 0x90, 0x9B, 0x89, 0x04,
+0xF0, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x04, 0xF0,
+0x90, 0x98, 0x31, 0x12, 0x04, 0xB8, 0xEF, 0x24,
+0x01, 0x12, 0xB7, 0xEA, 0x90, 0x98, 0x31, 0x12,
+0x04, 0x31, 0x12, 0xD3, 0x57, 0xE4, 0x90, 0x9B,
+0x0A, 0xF0, 0xFF, 0x12, 0xF4, 0xE3, 0xF1, 0xE0,
+0x70, 0x48, 0x90, 0x8A, 0xB9, 0x11, 0x47, 0x7D,
+0x01, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x7F, 0x05,
+0x7E, 0x00, 0x12, 0x7A, 0xAE, 0x12, 0xFB, 0x2F,
+0x90, 0x8A, 0x89, 0x11, 0x47, 0x12, 0xFB, 0x6E,
+0x90, 0x88, 0x39, 0xE0, 0x64, 0x02, 0x60, 0x22,
+0x90, 0x9A, 0x35, 0xE0, 0x04, 0xF0, 0x7F, 0x01,
+0x7E, 0x00, 0x12, 0x7A, 0xAE, 0x90, 0x8A, 0xB9,
+0x11, 0x47, 0x7D, 0x01, 0x7F, 0x02, 0x12, 0x04,
+0x7E, 0x90, 0x9A, 0x35, 0xE0, 0xD3, 0x94, 0x0A,
+0x40, 0xD6, 0x90, 0x9C, 0x9B, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x00, 0x0A, 0xF1, 0xD8, 0xA1, 0x37,
+0xE4, 0xFD, 0xFF, 0x02, 0x04, 0x7E, 0x12, 0xE2,
+0xE3, 0x90, 0x9B, 0x04, 0xEF, 0xF0, 0x20, 0xE0,
+0x06, 0x90, 0x01, 0x3D, 0x74, 0x01, 0xF0, 0x90,
+0x9B, 0x04, 0xE0, 0x90, 0x8A, 0x89, 0x30, 0xE0,
+0x12, 0x11, 0x47, 0x7D, 0x01, 0xE4, 0xFF, 0x12,
+0x04, 0x7E, 0x90, 0x88, 0x33, 0xE0, 0x44, 0x04,
+0xF0, 0x80, 0x04, 0x11, 0x47, 0x91, 0x98, 0x90,
+0x9B, 0x04, 0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01,
+0x2F, 0xE0, 0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80,
+0x06, 0x90, 0x01, 0x2F, 0x74, 0x80, 0xF0, 0x12,
+0xF9, 0xB2, 0x74, 0x02, 0xF0, 0x02, 0x6E, 0x2F,
+0xE0, 0xC4, 0x54, 0xF0, 0x24, 0x05, 0xF5, 0x82,
+0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0, 0x22, 0x90,
+0x88, 0x36, 0xE0, 0x64, 0x01, 0x70, 0x28, 0xF1,
+0xF3, 0x60, 0x12, 0x90, 0x8A, 0xB9, 0x11, 0x47,
+0xE4, 0xFD, 0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x12,
+0xDC, 0xD4, 0x02, 0x04, 0x7A, 0x90, 0x88, 0x39,
+0xE0, 0x70, 0x0C, 0x90, 0x8A, 0xB9, 0x11, 0x47,
+0x7D, 0x01, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x22,
+0xE4, 0x90, 0x9C, 0x9F, 0xF0, 0x7F, 0x03, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9C,
+0x9A, 0xEF, 0xF0, 0x12, 0xA0, 0x03, 0x90, 0x9C,
+0x9A, 0xE0, 0xFF, 0x12, 0xF9, 0x88, 0x74, 0x01,
+0xF0, 0x90, 0x9C, 0x9F, 0xE0, 0xFE, 0xEF, 0xF1,
+0xFA, 0xEE, 0xF0, 0x90, 0x9C, 0x9A, 0xE0, 0xB1,
+0x9D, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x01,
+0xB1, 0x92, 0x78, 0x10, 0x12, 0x03, 0xEB, 0xAB,
+0x07, 0xB1, 0x92, 0x78, 0x08, 0x12, 0x03, 0xEB,
+0x90, 0x92, 0x20, 0xEF, 0xF0, 0xB1, 0x92, 0x90,
+0x92, 0x21, 0xEF, 0xF0, 0x7D, 0x01, 0x7F, 0x50,
+0x7E, 0x01, 0x12, 0x66, 0x33, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x90, 0x9C, 0x9B, 0x02, 0x04, 0xB8,
+0x90, 0x9A, 0x34, 0xE0, 0xFB, 0x75, 0xF0, 0x0A,
+0xA4, 0x24, 0x8A, 0xF5, 0x82, 0xE4, 0x34, 0x9B,
+0xF5, 0x83, 0x22, 0xE4, 0x90, 0x9A, 0x34, 0xF0,
+0x90, 0x9A, 0x34, 0xE0, 0xFF, 0xC3, 0x94, 0x08,
+0x40, 0x02, 0xC1, 0x40, 0x12, 0xF9, 0x87, 0xE0,
+0x64, 0x01, 0x70, 0x74, 0x90, 0x9A, 0x34, 0xE0,
+0xB1, 0x9D, 0x12, 0x04, 0xB8, 0xE4, 0x7B, 0x01,
+0xF1, 0x4B, 0x70, 0x3A, 0x90, 0x9A, 0x34, 0xE0,
+0xFB, 0xF1, 0xFA, 0xE0, 0x60, 0x21, 0x14, 0x70,
+0x57, 0xEB, 0x75, 0xF0, 0x0A, 0xA4, 0x24, 0x8E,
+0xF5, 0x82, 0xE4, 0x34, 0x9B, 0xF5, 0x83, 0x12,
+0x04, 0xB8, 0xEB, 0xB1, 0x9D, 0x12, 0x04, 0x31,
+0x90, 0x9A, 0x34, 0xE0, 0xFF, 0x80, 0x0B, 0xB1,
+0x98, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x00,
+0xAF, 0x03, 0xF1, 0x52, 0x80, 0x2A, 0x90, 0x9A,
+0x34, 0xE0, 0xB1, 0x9D, 0x12, 0x04, 0xB8, 0xE4,
+0xFB, 0xF1, 0x4B, 0x50, 0x1B, 0xB1, 0x98, 0x12,
+0x04, 0xB8, 0xEF, 0x24, 0xFF, 0xFF, 0xEE, 0x34,
+0xFF, 0xFE, 0xED, 0x34, 0xFF, 0xFD, 0xEC, 0x34,
+0xFF, 0xFC, 0xEB, 0xB1, 0x9D, 0x12, 0x04, 0x31,
+0x90, 0x9A, 0x34, 0xE0, 0x04, 0xF0, 0xA1, 0xB0,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x9B, 0x1D, 0xE0, 0xFF, 0x12, 0xF5, 0x19,
+0xEF, 0x70, 0x02, 0xC1, 0xFF, 0x90, 0x9B, 0x1E,
+0xE0, 0xFB, 0xD3, 0x94, 0x00, 0x40, 0x1A, 0x90,
+0x9C, 0x2F, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0x0F, 0xAF, 0x03, 0xE4, 0xFC, 0xFD, 0xFE, 0x12,
+0xD4, 0x36, 0x7F, 0x08, 0x7E, 0x0E, 0x12, 0xD1,
+0xA3, 0x90, 0x9B, 0x1D, 0xE0, 0xFF, 0x90, 0x06,
+0x33, 0xF0, 0x12, 0xD5, 0x43, 0xE4, 0xFB, 0xFD,
+0x12, 0xD4, 0xC2, 0x90, 0x9B, 0x20, 0xE0, 0x60,
+0x08, 0x90, 0x93, 0x05, 0xE0, 0xFF, 0x12, 0xF5,
+0x44, 0x12, 0xCF, 0x7F, 0x30, 0xE0, 0x3B, 0x90,
+0x95, 0xEA, 0xE0, 0x60, 0x35, 0xE4, 0x90, 0x9A,
+0x36, 0xF0, 0x90, 0x95, 0xEA, 0xE0, 0xFF, 0x90,
+0x9A, 0x36, 0xE0, 0xC3, 0x9F, 0x50, 0x23, 0x7F,
+0x03, 0x7E, 0x00, 0x12, 0x7A, 0xAE, 0x90, 0x9A,
+0x36, 0xE0, 0x24, 0x29, 0x12, 0xC7, 0xE9, 0xE0,
+0xFF, 0x12, 0xF5, 0x44, 0x90, 0x01, 0xA6, 0xE0,
+0x04, 0xF0, 0x90, 0x9A, 0x36, 0xE0, 0x04, 0xF0,
+0x80, 0xD0, 0x90, 0x9B, 0x1F, 0xE0, 0x90, 0x9A,
+0x35, 0xF0, 0x90, 0x9B, 0x0A, 0xE0, 0x04, 0xF0,
+0xE0, 0xFF, 0x12, 0xF4, 0xE3, 0x90, 0x9A, 0x35,
+0x12, 0xAF, 0x13, 0x90, 0x9C, 0x9B, 0x12, 0x04,
+0x31, 0xF1, 0xD8, 0xB1, 0x37, 0x80, 0x47, 0xE4,
+0x90, 0x9B, 0x0A, 0xF0, 0x90, 0x9B, 0x89, 0xF0,
+0x90, 0x06, 0x32, 0xE0, 0x54, 0xFB, 0xF0, 0x12,
+0xD3, 0xC6, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xBF,
+0x01, 0x12, 0x90, 0x9B, 0x22, 0xE0, 0xFD, 0x90,
+0x8A, 0x89, 0x11, 0x47, 0x7F, 0x02, 0x12, 0x04,
+0x7E, 0x12, 0x7B, 0xAD, 0x90, 0x9A, 0x37, 0x74,
+0x07, 0xF0, 0x90, 0x9A, 0x59, 0xF0, 0x7B, 0x01,
+0x7A, 0x9A, 0x79, 0x37, 0x11, 0x35, 0x7F, 0x04,
+0x12, 0x04, 0x7E, 0x12, 0xB5, 0x79, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0xFA, 0xF9, 0xF8, 0xC3, 0x02,
+0x03, 0xDA, 0xEF, 0x24, 0xFC, 0x60, 0x05, 0x04,
+0x70, 0x04, 0x81, 0x0F, 0xD1, 0x41, 0x22, 0xE4,
+0xF5, 0x0F, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x56,
+0xF1, 0xE0, 0x70, 0x52, 0x12, 0xF9, 0x37, 0x75,
+0x0F, 0x01, 0xE5, 0x0F, 0x60, 0x48, 0x90, 0x88,
+0x39, 0xE0, 0x20, 0xE2, 0x0C, 0x90, 0x8A, 0xB9,
+0x11, 0x47, 0x7D, 0x01, 0x7F, 0x04, 0x12, 0x04,
+0x7E, 0x12, 0xB7, 0xB0, 0x90, 0x88, 0x3F, 0xE0,
+0x60, 0x04, 0x64, 0x01, 0x70, 0x11, 0xE4, 0x90,
+0x92, 0x20, 0xF0, 0xF1, 0xCE, 0xFF, 0xA3, 0xE0,
+0xF1, 0xBF, 0xFF, 0xA3, 0xE0, 0x80, 0x0D, 0xE4,
+0x90, 0x92, 0x20, 0xF0, 0xF1, 0xCE, 0xF1, 0xE9,
+0xF1, 0xBF, 0xF1, 0xE9, 0x2F, 0x33, 0x33, 0x33,
+0x54, 0xF8, 0x90, 0x88, 0x4F, 0xF0, 0x22, 0x2F,
+0x90, 0x92, 0x21, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F,
+0x54, 0x7E, 0x01, 0x12, 0x66, 0x33, 0x90, 0x88,
+0x3E, 0xE0, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x22,
+0xE4, 0x90, 0x9C, 0x9F, 0xF0, 0x7F, 0x04, 0x22,
+0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xEF, 0x64, 0x01,
+0x22, 0xFF, 0xA3, 0xE0, 0x75, 0xF0, 0x03, 0xA4,
+0x24, 0xFE, 0x22, 0x90, 0x88, 0x34, 0xE0, 0x54,
+0x0F, 0x22, 0x75, 0xF0, 0x0A, 0xA4, 0x24, 0x92,
+0xF5, 0x82, 0xE4, 0x34, 0x9B, 0xF5, 0x83, 0x22,
+0x12, 0x02, 0x06, 0xFF, 0x90, 0x93, 0x03, 0xF0,
+0xBF, 0x01, 0x07, 0x11, 0xFC, 0xE4, 0x90, 0x93,
+0x03, 0xF0, 0x22, 0x90, 0x9C, 0xAC, 0x12, 0x82,
+0x27, 0x90, 0x9C, 0xAB, 0xEF, 0xF0, 0x12, 0x82,
+0x30, 0x98, 0x75, 0x00, 0x98, 0x7A, 0x01, 0x98,
+0x7F, 0x03, 0x98, 0x84, 0x04, 0x98, 0x89, 0x06,
+0x98, 0x99, 0x12, 0x98, 0x9D, 0x14, 0x98, 0xA2,
+0x1E, 0x98, 0xA6, 0x20, 0x98, 0xAB, 0x25, 0x98,
+0xB0, 0x27, 0x98, 0xB5, 0x29, 0x98, 0xBA, 0x2A,
+0x98, 0xC3, 0x80, 0x98, 0xBF, 0x81, 0x98, 0xC8,
+0x82, 0x98, 0xCD, 0x83, 0x98, 0xD2, 0x84, 0x98,
+0xDC, 0x86, 0x98, 0xD7, 0x88, 0x98, 0xE1, 0xC3,
+0x98, 0x8D, 0xC6, 0x98, 0x8D, 0xC7, 0x98, 0x8D,
+0xC8, 0x00, 0x00, 0x98, 0xE6, 0x11, 0xF6, 0x02,
+0x87, 0x64, 0x11, 0xF6, 0x02, 0x87, 0xFA, 0x11,
+0xF6, 0x02, 0xE5, 0xF4, 0x11, 0xF6, 0x02, 0xDC,
+0x71, 0x11, 0xF6, 0x41, 0x8F, 0x90, 0x9C, 0xAB,
+0xE0, 0xFF, 0xA3, 0x12, 0x82, 0x1E, 0x02, 0xC0,
+0x9B, 0x11, 0xF6, 0x01, 0x08, 0x11, 0xF6, 0x02,
+0xA8, 0x01, 0x11, 0xF6, 0x41, 0x3C, 0x11, 0xF6,
+0x02, 0xA8, 0x10, 0x11, 0xF6, 0x02, 0xAF, 0xFA,
+0x11, 0xF6, 0x02, 0xB0, 0x02, 0x11, 0xF6, 0x02,
+0xC0, 0x04, 0x11, 0xF6, 0x02, 0xB7, 0xF5, 0x11,
+0xF6, 0x61, 0x1F, 0x11, 0xF6, 0x02, 0xE6, 0x46,
+0x11, 0xF6, 0x02, 0xF4, 0x5F, 0x11, 0xF6, 0x02,
+0xF4, 0x6E, 0x11, 0xF6, 0x02, 0x87, 0xAA, 0x11,
+0xF6, 0x02, 0xF4, 0xAB, 0x11, 0xF6, 0x02, 0xD5,
+0x55, 0x11, 0xF6, 0x02, 0xC0, 0x1A, 0x90, 0x01,
+0xC0, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x9C, 0xAB,
+0xE0, 0x90, 0x01, 0xC2, 0xF0, 0x22, 0x90, 0x9C,
+0xAC, 0x02, 0x82, 0x1E, 0x31, 0xA9, 0x7F, 0xEF,
+0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x06,
+0x90, 0x99, 0xB1, 0xE0, 0xA3, 0xF0, 0x31, 0xA9,
+0x7F, 0xEE, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
+0x01, 0x08, 0x90, 0x99, 0xB1, 0xE0, 0x90, 0x99,
+0xB3, 0xF0, 0x31, 0xA9, 0x7F, 0xED, 0x7E, 0x01,
+0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99,
+0xB1, 0xE0, 0x90, 0x99, 0xB4, 0xF0, 0x31, 0xA9,
+0x7F, 0xEC, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
+0x01, 0x08, 0x90, 0x99, 0xB1, 0xE0, 0x90, 0x99,
+0xB5, 0xF0, 0x31, 0xA9, 0x7F, 0xEB, 0x7E, 0x01,
+0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99,
+0xB1, 0xE0, 0x90, 0x99, 0xB6, 0xF0, 0x90, 0x99,
+0xB2, 0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0xA3, 0xE0,
+0xFB, 0xA3, 0xE0, 0x90, 0x99, 0xBA, 0xF0, 0x90,
+0x99, 0xB6, 0xE0, 0x90, 0x99, 0xBB, 0xF0, 0x90,
+0x99, 0xBC, 0x74, 0x12, 0xF0, 0x90, 0x99, 0xDE,
+0x74, 0x05, 0xF0, 0x90, 0x99, 0xBE, 0xEF, 0x12,
+0xC7, 0xE1, 0x90, 0x99, 0xBA, 0xE0, 0x90, 0x99,
+0xC1, 0xF0, 0x90, 0x99, 0xBB, 0xE0, 0x90, 0x99,
+0xC2, 0xF0, 0x7B, 0x01, 0x7A, 0x99, 0x79, 0xBC,
+0x12, 0x90, 0x35, 0x7F, 0x04, 0x02, 0x04, 0x7E,
+0xF0, 0x7B, 0x01, 0x7A, 0x99, 0x79, 0xB1, 0x22,
+0x7E, 0x00, 0x7F, 0x0B, 0x7D, 0x00, 0x7B, 0x01,
+0x7A, 0x98, 0x79, 0x59, 0x12, 0x04, 0x80, 0x31,
+0xA9, 0x12, 0xFB, 0xA4, 0xBF, 0x01, 0x1C, 0x90,
+0x99, 0xB1, 0xE0, 0xFE, 0x54, 0x01, 0x90, 0x98,
+0x59, 0xF0, 0xEE, 0x54, 0x04, 0x90, 0x98, 0x5B,
+0xF0, 0x90, 0x99, 0xB1, 0xE0, 0x54, 0x08, 0x90,
+0x98, 0x5A, 0xF0, 0x31, 0xA9, 0x12, 0x93, 0xC7,
+0x64, 0x01, 0x70, 0x35, 0x90, 0x99, 0xB1, 0xE0,
+0x54, 0x07, 0x70, 0x15, 0x7B, 0x01, 0x7A, 0x99,
+0x79, 0xB2, 0x7F, 0xFA, 0x7E, 0x01, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x0F, 0x90, 0x99, 0xB2, 0x80,
+0x03, 0x90, 0x99, 0xB1, 0xE0, 0x54, 0x07, 0x90,
+0x98, 0x5D, 0xF0, 0x90, 0x99, 0xB1, 0xE0, 0x54,
+0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90, 0x98, 0x5C,
+0xF0, 0x31, 0xA9, 0x7F, 0xFD, 0x7E, 0x01, 0x12,
+0x5F, 0xA6, 0xBF, 0x01, 0x0E, 0x90, 0x99, 0xB1,
+0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F, 0x90,
+0x98, 0x5E, 0xF0, 0x22, 0x12, 0x02, 0x06, 0x90,
+0x99, 0xD4, 0xF0, 0x91, 0x5A, 0x90, 0x99, 0xD5,
+0xF0, 0x60, 0x0F, 0x51, 0x87, 0x12, 0xC0, 0x30,
+0x90, 0x99, 0xD5, 0x51, 0x87, 0x7B, 0x57, 0x12,
+0x8D, 0x1E, 0x90, 0x99, 0xB1, 0x74, 0x20, 0xF0,
+0x90, 0x99, 0xD3, 0x74, 0x03, 0xF0, 0x90, 0x05,
+0x22, 0xE0, 0x90, 0x99, 0xB3, 0xF0, 0x90, 0x98,
+0x6A, 0xE0, 0x90, 0x99, 0xB4, 0xF0, 0x90, 0x98,
+0x6B, 0xE0, 0x90, 0x99, 0xB5, 0x31, 0xA8, 0x12,
+0x90, 0x35, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0xE0,
+0xFF, 0x90, 0x99, 0xD4, 0xE0, 0xFD, 0x22, 0x12,
+0x02, 0x06, 0x64, 0x01, 0x60, 0x02, 0x61, 0x1E,
+0x90, 0x99, 0xF8, 0xF0, 0x90, 0x99, 0xF8, 0xE0,
+0xFF, 0xC3, 0x94, 0x10, 0x50, 0x28, 0xEF, 0x12,
+0xFB, 0x1C, 0x7A, 0x99, 0x79, 0xF7, 0x12, 0x5F,
+0xA6, 0xBF, 0x01, 0x12, 0x90, 0x99, 0xF7, 0xE0,
+0xFF, 0xA3, 0xE0, 0x24, 0xF9, 0xF5, 0x82, 0xE4,
+0x34, 0x99, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x99,
+0xF8, 0xE0, 0x04, 0xF0, 0x80, 0xCE, 0x75, 0x45,
+0x01, 0x75, 0x46, 0x99, 0x75, 0x47, 0xF9, 0x75,
+0x48, 0x08, 0x7B, 0x01, 0x7A, 0x99, 0x79, 0xB3,
+0x12, 0x8F, 0x63, 0x74, 0x24, 0xF0, 0x90, 0x99,
+0xD3, 0x74, 0x08, 0xF0, 0x75, 0x45, 0x01, 0x75,
+0x46, 0x9A, 0x75, 0x47, 0x01, 0xF5, 0x48, 0x7B,
+0x01, 0x7A, 0x99, 0x79, 0xD6, 0x12, 0x69, 0xF5,
+0x90, 0x99, 0xD4, 0x74, 0x25, 0xF0, 0x90, 0x99,
+0xF6, 0x74, 0x08, 0x31, 0xA8, 0x12, 0xF9, 0xC3,
+0x7B, 0x01, 0x7A, 0x99, 0x79, 0xD4, 0x12, 0x90,
+0x35, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x02,
+0x06, 0xFF, 0x54, 0x01, 0xFE, 0x90, 0x93, 0x24,
+0x12, 0xD7, 0x4C, 0xFD, 0xEF, 0x54, 0xFB, 0x4D,
+0xFF, 0x90, 0x93, 0x24, 0xF1, 0xE1, 0x12, 0xE7,
+0xB4, 0xFF, 0x90, 0x93, 0x24, 0x12, 0xE7, 0xC6,
+0xF1, 0xE9, 0x12, 0xE7, 0xBD, 0xFF, 0x90, 0x93,
+0x24, 0x12, 0xE7, 0xCF, 0x12, 0x87, 0xE6, 0xFF,
+0x54, 0x01, 0xFE, 0x90, 0x93, 0x26, 0xE0, 0x54,
+0xFE, 0x4E, 0xF0, 0x91, 0x5A, 0xFE, 0x54, 0x01,
+0xFD, 0x90, 0x93, 0x25, 0xE0, 0x54, 0xFE, 0x4D,
+0xFD, 0xF0, 0xEE, 0x54, 0x04, 0xFE, 0xED, 0x54,
+0xFB, 0x4E, 0xFE, 0xF0, 0x91, 0x5A, 0xFD, 0x54,
+0x08, 0xFC, 0xEE, 0x54, 0xF7, 0x4C, 0xFE, 0x90,
+0x93, 0x25, 0xF0, 0xED, 0x54, 0x10, 0xFD, 0xEE,
+0x54, 0xEF, 0x4D, 0xFE, 0xF0, 0x91, 0x5A, 0xFD,
+0x54, 0x20, 0xFC, 0xEE, 0x54, 0xDF, 0x4C, 0x90,
+0x93, 0x25, 0xF0, 0xEF, 0x54, 0x10, 0xFF, 0xA3,
+0xE0, 0x54, 0xEF, 0x4F, 0xFF, 0x12, 0x87, 0xE6,
+0xFE, 0x54, 0x20, 0xFC, 0xEF, 0x54, 0xDF, 0x4C,
+0x90, 0x93, 0x26, 0xF0, 0xED, 0x54, 0x40, 0xFF,
+0x90, 0x93, 0x25, 0xE0, 0x54, 0xBF, 0x12, 0x87,
+0xA2, 0x54, 0x07, 0xFF, 0x90, 0x93, 0x27, 0xE0,
+0x54, 0xF8, 0x4F, 0xF0, 0xEE, 0x54, 0x40, 0xFF,
+0x90, 0x93, 0x26, 0xE0, 0x54, 0xBF, 0x4F, 0x12,
+0xC7, 0x83, 0x12, 0xCF, 0x77, 0x90, 0x93, 0x24,
+0xE0, 0xC3, 0x13, 0x54, 0x01, 0xFF, 0x12, 0xF4,
+0xC9, 0xF1, 0xA6, 0x54, 0x01, 0xFF, 0x12, 0xF1,
+0x5D, 0x90, 0x93, 0x25, 0x12, 0x97, 0xD1, 0x30,
+0xE0, 0x1F, 0x90, 0x93, 0x24, 0x12, 0xB4, 0xAD,
+0x20, 0xE0, 0x0E, 0xEF, 0xC3, 0x13, 0x20, 0xE0,
+0x08, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0,
+0x04, 0x7F, 0x01, 0x80, 0x0A, 0x7F, 0x00, 0x80,
+0x06, 0xF1, 0xA6, 0x13, 0x54, 0x01, 0xFF, 0x12,
+0xD7, 0xA9, 0x90, 0x93, 0x24, 0xE0, 0xC4, 0x54,
+0x01, 0xFF, 0x12, 0xF4, 0xD5, 0x90, 0x93, 0x24,
+0xE0, 0xC4, 0x13, 0x13, 0x54, 0x01, 0xFF, 0x12,
+0xD7, 0x2E, 0x90, 0x93, 0x24, 0xE0, 0x54, 0x01,
+0xFF, 0x12, 0xCB, 0x44, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x12, 0x02, 0x4C, 0x90, 0x9C, 0x90, 0x12,
+0x82, 0x1E, 0x90, 0x00, 0x01, 0x02, 0x02, 0x1F,
+0x90, 0x9C, 0x8D, 0x12, 0x82, 0x27, 0x90, 0x9C,
+0x93, 0xE0, 0xFF, 0xB4, 0x04, 0x1C, 0x90, 0x9C,
+0x90, 0x12, 0x8F, 0x6D, 0xFE, 0x91, 0xF8, 0xEE,
+0x91, 0x51, 0xFE, 0x91, 0xF8, 0x90, 0x00, 0x01,
+0xEE, 0x12, 0x02, 0x5E, 0x90, 0x00, 0x02, 0xE4,
+0x80, 0x20, 0xEF, 0x64, 0x02, 0x70, 0x1E, 0x91,
+0x54, 0x91, 0xF7, 0xEF, 0x91, 0x51, 0x44, 0x20,
+0x54, 0x7F, 0x91, 0xF7, 0x90, 0x00, 0x01, 0xB1,
+0xD1, 0x12, 0x8F, 0x6D, 0x91, 0xF7, 0x90, 0x00,
+0x02, 0xEF, 0x12, 0x02, 0x5E, 0x91, 0xF8, 0xE9,
+0x24, 0x03, 0xF9, 0xE4, 0x3A, 0xFA, 0x12, 0x02,
+0x06, 0x44, 0x20, 0x12, 0x02, 0x4C, 0x90, 0x9C,
+0x90, 0x12, 0x82, 0x1E, 0x12, 0x87, 0xE7, 0x91,
+0xF7, 0x90, 0x00, 0x04, 0xB1, 0xD1, 0x12, 0x82,
+0x1E, 0x12, 0x87, 0xA4, 0x91, 0xF7, 0x90, 0x00,
+0x05, 0xB1, 0xD1, 0x12, 0x82, 0x1E, 0x12, 0x87,
+0xD2, 0x91, 0xF7, 0x90, 0x00, 0x06, 0xB1, 0xD1,
+0x12, 0x82, 0x1E, 0x12, 0x87, 0x9C, 0x91, 0xF7,
+0x90, 0x00, 0x07, 0xEF, 0x02, 0x02, 0x5E, 0xFF,
+0x90, 0x9C, 0x8D, 0x02, 0x82, 0x1E, 0x90, 0x9C,
+0x7B, 0x12, 0x82, 0x27, 0x90, 0x9C, 0x84, 0xE0,
+0xFF, 0x64, 0x04, 0x70, 0x4C, 0xB1, 0xC1, 0x12,
+0x02, 0x06, 0xB1, 0xCA, 0xEE, 0x12, 0x02, 0x4C,
+0x90, 0x9C, 0x7B, 0x91, 0x57, 0xB1, 0xCA, 0x90,
+0x00, 0x01, 0xB1, 0xBD, 0x90, 0x00, 0x04, 0xB1,
+0xC7, 0x90, 0x00, 0x02, 0xB1, 0xBD, 0x90, 0x00,
+0x05, 0xB1, 0xC7, 0x90, 0x00, 0x03, 0xB1, 0xBD,
+0x90, 0x00, 0x06, 0xB1, 0xC7, 0x90, 0x00, 0x04,
+0xB1, 0xBD, 0x90, 0x00, 0x07, 0xB1, 0xC7, 0x90,
+0x00, 0x05, 0xB1, 0xBD, 0x12, 0x87, 0xA4, 0xFE,
+0x90, 0x9C, 0x81, 0x12, 0x82, 0x1E, 0xEE, 0x80,
+0x60, 0xEF, 0x64, 0x02, 0x70, 0x5E, 0xB1, 0xC1,
+0x12, 0x87, 0xE7, 0xFF, 0xB1, 0xCB, 0xEF, 0x12,
+0x02, 0x4C, 0xB1, 0xC1, 0x12, 0x02, 0x06, 0xFF,
+0xB1, 0xCB, 0x90, 0x00, 0x01, 0xEF, 0xB1, 0xBE,
+0x12, 0x87, 0xD2, 0xFF, 0xB1, 0xCB, 0x90, 0x00,
+0x02, 0xEF, 0xB1, 0xBE, 0x12, 0x87, 0x9C, 0xFF,
+0xB1, 0xCB, 0x90, 0x00, 0x03, 0xEF, 0xB1, 0xBE,
+0x90, 0x00, 0x06, 0x12, 0x02, 0x1F, 0xFF, 0xB1,
+0xCB, 0x90, 0x00, 0x04, 0xEF, 0xB1, 0xBE, 0x90,
+0x00, 0x07, 0x12, 0x02, 0x1F, 0xFF, 0xB1, 0xCB,
+0x90, 0x00, 0x05, 0xEF, 0xB1, 0xBE, 0x12, 0x87,
+0xA4, 0xFF, 0x90, 0x9C, 0x81, 0x12, 0x82, 0x1E,
+0xEF, 0x12, 0x02, 0x4C, 0x22, 0xEE, 0x12, 0x02,
+0x5E, 0x90, 0x9C, 0x7B, 0x02, 0x82, 0x1E, 0x12,
+0x02, 0x1F, 0xFE, 0x90, 0x9C, 0x7E, 0x02, 0x82,
+0x1E, 0xEF, 0x12, 0x02, 0x5E, 0x90, 0x9C, 0x90,
+0x22, 0x90, 0x9A, 0x42, 0x12, 0x82, 0x27, 0xF1,
+0x90, 0xD1, 0x40, 0x12, 0x04, 0x80, 0xF1, 0x90,
+0xD1, 0x39, 0x12, 0x04, 0x80, 0xD1, 0x40, 0xF1,
+0x7F, 0x7A, 0x9A, 0x79, 0x5A, 0xD1, 0x47, 0x90,
+0x9C, 0x84, 0xF1, 0x97, 0x91, 0xFE, 0xD1, 0x39,
+0xF1, 0x7F, 0x7A, 0x9A, 0x79, 0x59, 0xD1, 0x47,
+0x90, 0x9C, 0x84, 0xF0, 0x90, 0x9A, 0x45, 0x12,
+0x82, 0x1E, 0x91, 0xFE, 0xD1, 0x40, 0x12, 0xE5,
+0xA4, 0x74, 0x08, 0xF0, 0x7A, 0x9A, 0x79, 0x51,
+0x12, 0xE5, 0xAE, 0x40, 0x11, 0xD1, 0x39, 0x90,
+0x9C, 0x90, 0xD1, 0x4A, 0x90, 0x9C, 0x93, 0xF1,
+0x97, 0x91, 0x60, 0x7F, 0x01, 0x22, 0x7F, 0x00,
+0x22, 0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x51, 0x22,
+0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x49, 0x22, 0x90,
+0x9C, 0x81, 0x12, 0x82, 0x27, 0x90, 0x9A, 0x48,
+0xE0, 0x22, 0xFF, 0x90, 0x9A, 0xF6, 0xF0, 0x7B,
+0x01, 0x7A, 0x9A, 0x79, 0xF7, 0x12, 0x02, 0x06,
+0x90, 0x06, 0x74, 0xF0, 0x91, 0x5A, 0x90, 0x06,
+0x75, 0x12, 0x87, 0xE6, 0x90, 0x06, 0x76, 0x12,
+0x87, 0xA3, 0x90, 0x06, 0x77, 0xF0, 0x12, 0xCF,
+0xE1, 0x04, 0x12, 0xCF, 0xD7, 0x02, 0x7C, 0x6A,
+0x90, 0x9A, 0xF1, 0xEF, 0xF0, 0xA3, 0xED, 0xF0,
+0xA3, 0x12, 0x82, 0x27, 0x90, 0x9A, 0xF3, 0x12,
+0x8B, 0xE0, 0xF1, 0x0E, 0x24, 0x02, 0xD1, 0x52,
+0x90, 0x9A, 0xF3, 0x12, 0x82, 0x1E, 0xE9, 0x24,
+0x04, 0xF1, 0x05, 0x24, 0x03, 0xD1, 0x52, 0x90,
+0x9A, 0xF3, 0x12, 0x82, 0x1E, 0xE9, 0x24, 0x08,
+0xF1, 0x05, 0x24, 0x04, 0xD1, 0x52, 0x90, 0x9A,
+0xF3, 0x12, 0x82, 0x1E, 0xE9, 0x24, 0x0C, 0xF1,
+0x05, 0x24, 0x05, 0xD1, 0x52, 0x90, 0x9A, 0xF2,
+0xE0, 0xFD, 0xB4, 0x02, 0x08, 0x90, 0x9A, 0xF1,
+0xE0, 0x44, 0x48, 0x80, 0x0A, 0xED, 0xB4, 0x04,
+0x0A, 0x90, 0x9A, 0xF1, 0xE0, 0x44, 0x50, 0x90,
+0x9A, 0xF7, 0xF0, 0x90, 0x9A, 0xF8, 0x74, 0x80,
+0xF0, 0xA3, 0x74, 0xFF, 0xF0, 0xA3, 0xF0, 0xF1,
+0x1A, 0xD1, 0x52, 0x90, 0x9A, 0xF7, 0x74, 0xFF,
+0xF1, 0xAF, 0xF1, 0x1A, 0x04, 0xD1, 0x52, 0x90,
+0x06, 0x72, 0xE4, 0xF0, 0x22, 0xF9, 0xE4, 0x3A,
+0x8B, 0x45, 0xF5, 0x46, 0x89, 0x47, 0x75, 0x48,
+0x04, 0x7B, 0x01, 0x7A, 0x9A, 0x79, 0xF7, 0x12,
+0x69, 0xF5, 0x90, 0x9A, 0xF1, 0xE0, 0x75, 0xF0,
+0x08, 0xA4, 0x22, 0x90, 0x9C, 0x60, 0x12, 0x82,
+0x27, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01, 0x7B,
+0x01, 0x7A, 0x9C, 0x79, 0x65, 0xF1, 0x7F, 0x7A,
+0x9C, 0x79, 0x6D, 0x90, 0x9C, 0x81, 0xF1, 0x9E,
+0x90, 0x9C, 0x84, 0xF0, 0xD0, 0x01, 0xD0, 0x02,
+0xD0, 0x03, 0x91, 0xFE, 0xED, 0x70, 0x19, 0xFF,
+0xF1, 0x85, 0xE0, 0xB4, 0xFF, 0x06, 0xF1, 0x85,
+0xE4, 0xF0, 0x80, 0x07, 0xF1, 0x85, 0xE0, 0x04,
+0xF0, 0x80, 0x05, 0x0F, 0xEF, 0xB4, 0x06, 0xE8,
+0x7B, 0x01, 0x7A, 0x9C, 0x79, 0x65, 0x90, 0x9C,
+0x90, 0xF1, 0x9E, 0x90, 0x9C, 0x93, 0xF0, 0x90,
+0x9C, 0x60, 0x12, 0x82, 0x1E, 0x81, 0x60, 0x90,
+0x9C, 0x7E, 0x02, 0x82, 0x27, 0x74, 0x65, 0x2F,
+0xF5, 0x82, 0xE4, 0x34, 0x9C, 0xF5, 0x83, 0x22,
+0x7E, 0x00, 0x7F, 0x08, 0x7D, 0x00, 0x22, 0xF0,
+0x90, 0x9A, 0x42, 0x02, 0x82, 0x1E, 0x12, 0x82,
+0x27, 0x90, 0x9C, 0x64, 0xE0, 0x22, 0x90, 0x93,
+0x24, 0xE0, 0x13, 0x13, 0x22, 0xF0, 0xA3, 0xF0,
+0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x12,
+0xAD, 0xF3, 0xE4, 0x90, 0x98, 0x41, 0xF1, 0xAF,
+0x90, 0x95, 0x93, 0xF1, 0xAD, 0xA3, 0xF1, 0xAD,
+0x90, 0x95, 0xA5, 0xF0, 0xA3, 0xF0, 0x90, 0x95,
+0xE7, 0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x93, 0x24,
+0x12, 0xDC, 0xB9, 0x30, 0xE0, 0x02, 0xF1, 0xB7,
+0x22, 0xF0, 0xEE, 0x54, 0x08, 0xFE, 0xEF, 0x54,
+0xF7, 0x4E, 0xFF, 0xF0, 0x02, 0x02, 0x06, 0xF1,
+0xD5, 0x90, 0x93, 0x24, 0xE0, 0xFF, 0xC4, 0x54,
+0x0F, 0x30, 0xE0, 0x06, 0x12, 0xA0, 0x03, 0x12,
+0xCA, 0x2D, 0x22, 0x90, 0x01, 0x53, 0xE4, 0xF0,
+0xFF, 0x12, 0xF9, 0x87, 0xE4, 0xF0, 0x0F, 0xEF,
+0xB4, 0x08, 0xF6, 0x22, 0x90, 0x9A, 0x38, 0xEC,
+0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x9A, 0x36, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x90, 0x9A, 0x5C,
+0xF0, 0xEF, 0x24, 0x24, 0xFF, 0xE4, 0x3E, 0xFE,
+0xC0, 0x06, 0x91, 0xB0, 0xD0, 0x06, 0xE4, 0xFB,
+0xFA, 0x91, 0x64, 0x4E, 0x60, 0x39, 0xE0, 0x24,
+0x01, 0x71, 0xC7, 0x51, 0x3B, 0x90, 0x9A, 0x3B,
+0x91, 0x99, 0x90, 0x9A, 0x3B, 0x91, 0x84, 0xFE,
+0xC3, 0x9F, 0x50, 0x23, 0x90, 0x9A, 0x5E, 0xE0,
+0x24, 0x02, 0xFD, 0x71, 0xC8, 0xFC, 0xEE, 0x7E,
+0x00, 0x2D, 0x51, 0x38, 0x90, 0x9A, 0x3A, 0xE0,
+0x24, 0x3C, 0xF5, 0x82, 0xE4, 0x34, 0x9A, 0xF5,
+0x83, 0xEF, 0xF0, 0x91, 0x7A, 0x80, 0xD3, 0x91,
+0xA1, 0xC0, 0x06, 0x91, 0xB0, 0xD0, 0x06, 0x7B,
+0x03, 0x91, 0x61, 0x90, 0x9A, 0x37, 0xE0, 0x24,
+0x22, 0x91, 0xA7, 0x90, 0x9A, 0x5D, 0xF0, 0xA3,
+0xEF, 0xF0, 0x51, 0x3C, 0xEF, 0x20, 0xE4, 0x02,
+0x21, 0x3A, 0x90, 0x9A, 0x5C, 0xE0, 0x04, 0xF0,
+0x91, 0xA1, 0xC0, 0x06, 0x91, 0xB0, 0xD0, 0x06,
+0x7B, 0x30, 0x91, 0x61, 0x4E, 0x60, 0x3C, 0xE0,
+0x24, 0x08, 0x71, 0xC7, 0x51, 0x3B, 0x91, 0x96,
+0x91, 0x81, 0xC3, 0x9F, 0x50, 0x2D, 0x90, 0x9A,
+0x5E, 0xE0, 0x24, 0x0D, 0x71, 0xC7, 0x51, 0x3B,
+0x90, 0x9A, 0x5F, 0xEF, 0xF0, 0xBF, 0x02, 0x09,
+0x90, 0x9A, 0x5C, 0xE0, 0x24, 0x20, 0xF0, 0x80,
+0x0E, 0x90, 0x9A, 0x5F, 0xE0, 0xB4, 0x04, 0x07,
+0x90, 0x9A, 0x5C, 0xE0, 0x24, 0x40, 0xF0, 0x91,
+0x70, 0x80, 0xCD, 0x91, 0xA1, 0xC0, 0x06, 0x91,
+0xB0, 0xD0, 0x06, 0x7B, 0xDD, 0x7A, 0x00, 0x7D,
+0x01, 0x91, 0x65, 0x4E, 0x60, 0x41, 0xE0, 0x24,
+0x0C, 0x71, 0xC7, 0x51, 0x3B, 0x91, 0x96, 0x91,
+0x81, 0xC3, 0x9F, 0x50, 0x32, 0x90, 0x9A, 0x5E,
+0xE0, 0x24, 0x11, 0x71, 0xC7, 0x51, 0x3B, 0x90,
+0x9A, 0x5F, 0xEF, 0xF0, 0xBF, 0x02, 0x09, 0x90,
+0x9A, 0x5C, 0xE0, 0x24, 0x02, 0xF0, 0x80, 0x0E,
+0x90, 0x9A, 0x5F, 0xE0, 0xB4, 0x04, 0x07, 0x90,
+0x9A, 0x5C, 0xE0, 0x24, 0x04, 0xF0, 0x91, 0x70,
+0x80, 0xCD, 0xE4, 0x90, 0x9A, 0x5C, 0xF0, 0x90,
+0x95, 0xE9, 0xE0, 0x90, 0x04, 0xFD, 0x91, 0x9A,
+0x90, 0x95, 0xE9, 0x91, 0x84, 0xFE, 0xC3, 0x9F,
+0x50, 0x5C, 0x12, 0xFB, 0x26, 0xF5, 0x83, 0xF1,
+0xDE, 0x6F, 0x70, 0x4E, 0x90, 0x04, 0xFC, 0xE0,
+0x04, 0xF0, 0x90, 0x9A, 0x3A, 0xE0, 0x24, 0x09,
+0xF5, 0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83, 0xE0,
+0xFF, 0x90, 0x9A, 0x5C, 0xE0, 0xFD, 0x4F, 0x60,
+0x04, 0xED, 0x5F, 0x60, 0x2D, 0xEE, 0xFF, 0x7E,
+0x00, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x9A, 0x3A,
+0xE0, 0x75, 0xF0, 0x20, 0xA4, 0x24, 0x31, 0xF9,
+0x74, 0x96, 0xF1, 0x88, 0x7D, 0x01, 0xD0, 0x07,
+0xD0, 0x06, 0x12, 0x83, 0xDC, 0xEF, 0x70, 0x0A,
+0x90, 0x01, 0xC7, 0x74, 0x55, 0xF1, 0x70, 0x12,
+0x9F, 0xF1, 0x91, 0x7A, 0x80, 0x9A, 0xE4, 0x90,
+0x9A, 0x3A, 0xF0, 0x90, 0x9A, 0x3A, 0xE0, 0xFF,
+0xC3, 0x94, 0x03, 0x50, 0x5E, 0xA3, 0xE0, 0xFE,
+0x60, 0x55, 0xEF, 0x75, 0xF0, 0x21, 0xA4, 0x24,
+0x26, 0xF5, 0x82, 0xE4, 0x34, 0x9B, 0xF5, 0x83,
+0xE0, 0xFF, 0xEE, 0x6F, 0x70, 0x41, 0x90, 0x04,
+0xFC, 0xE0, 0x04, 0xF0, 0x90, 0x9A, 0x3B, 0xE0,
+0xFF, 0x7E, 0x00, 0xC0, 0x06, 0xC0, 0x07, 0x90,
+0x9A, 0x3A, 0xE0, 0x75, 0xF0, 0x21, 0xA4, 0x24,
+0x27, 0xF9, 0x74, 0x9B, 0xF1, 0x88, 0x7D, 0x01,
+0xD0, 0x07, 0xD0, 0x06, 0x12, 0x83, 0xDC, 0xEF,
+0x70, 0x15, 0x90, 0x01, 0xC7, 0x74, 0x24, 0xF1,
+0x70, 0x12, 0xD6, 0x11, 0x30, 0xE0, 0x02, 0x11,
+0x03, 0xF1, 0x82, 0xE4, 0xFF, 0xD1, 0xCA, 0x91,
+0x7A, 0x80, 0x98, 0x22, 0x90, 0x9A, 0x36, 0xE0,
+0xFD, 0x90, 0x9A, 0x35, 0xE0, 0x2D, 0xFD, 0x90,
+0x9A, 0x34, 0xE0, 0x34, 0x00, 0xCD, 0x24, 0x10,
+0xCD, 0x34, 0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F,
+0xFF, 0xEE, 0x3C, 0xFE, 0x90, 0x8A, 0xE9, 0xE0,
+0xFC, 0xA3, 0xE0, 0xF5, 0x82, 0x8C, 0x83, 0xE4,
+0xFD, 0x02, 0x04, 0x7E, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x06, 0x31, 0xE0, 0x54,
+0xEF, 0x44, 0x08, 0xF0, 0xED, 0x2F, 0xFF, 0xE4,
+0x3E, 0xFE, 0x7C, 0x00, 0xEF, 0x24, 0x08, 0x12,
+0xFA, 0xC4, 0x7E, 0x00, 0x7F, 0xE3, 0x7D, 0x00,
+0x7B, 0x01, 0x7A, 0x94, 0x79, 0x39, 0x12, 0x04,
+0x80, 0x90, 0x9A, 0x3E, 0xE0, 0x24, 0x01, 0x71,
+0xBF, 0x51, 0x3B, 0x90, 0x94, 0x3A, 0xEF, 0xF0,
+0x90, 0x9A, 0x3E, 0xE0, 0x24, 0x04, 0x71, 0xBF,
+0x51, 0x3B, 0x90, 0x94, 0x3D, 0xEF, 0xF0, 0x90,
+0x9A, 0x3E, 0xE0, 0x24, 0x05, 0x71, 0xBF, 0x51,
+0x3B, 0x90, 0x94, 0x3E, 0xEF, 0xF0, 0x90, 0x9A,
+0x3E, 0xE0, 0x24, 0x06, 0x71, 0xBF, 0x51, 0x3B,
+0x90, 0x94, 0x3F, 0xEF, 0xF0, 0x90, 0x9A, 0x3E,
+0xE0, 0x24, 0x07, 0x71, 0xBF, 0x51, 0x3B, 0x90,
+0x94, 0x40, 0xEF, 0xF0, 0x90, 0x9A, 0x3E, 0xE0,
+0x24, 0x08, 0x71, 0xBF, 0x51, 0x3B, 0x90, 0x94,
+0x41, 0xEF, 0xF0, 0xE4, 0x90, 0x9A, 0x3C, 0xF0,
+0xD1, 0x39, 0x94, 0x08, 0x50, 0x1C, 0x90, 0x9A,
+0x3E, 0xE0, 0x24, 0x09, 0xFD, 0x90, 0x9A, 0x3D,
+0xE0, 0x51, 0x31, 0x90, 0x9A, 0x3C, 0xE0, 0x24,
+0x42, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0x91, 0x8B,
+0x80, 0xDE, 0xE4, 0x90, 0x9A, 0x3C, 0xF0, 0xD1,
+0x39, 0x94, 0x02, 0x50, 0x1C, 0x90, 0x9A, 0x3E,
+0xE0, 0x24, 0x61, 0xFD, 0x90, 0x9A, 0x3D, 0xE0,
+0x51, 0x31, 0x90, 0x9A, 0x3C, 0xE0, 0x24, 0x9A,
+0xF5, 0x82, 0xE4, 0x34, 0x94, 0x91, 0x8B, 0x80,
+0xDE, 0xE4, 0x90, 0x9A, 0x3C, 0xF0, 0xD1, 0x39,
+0x94, 0x10, 0x50, 0x1C, 0x90, 0x9A, 0x3E, 0xE0,
+0x24, 0x31, 0xFD, 0x90, 0x9A, 0x3D, 0xE0, 0x51,
+0x31, 0x90, 0x9A, 0x3C, 0xE0, 0x24, 0x6A, 0xF5,
+0x82, 0xE4, 0x34, 0x94, 0x91, 0x8B, 0x80, 0xDE,
+0xE4, 0x90, 0x9A, 0x3C, 0xF0, 0x90, 0x94, 0x9B,
+0xE0, 0xFF, 0x90, 0x9A, 0x3C, 0xE0, 0xFE, 0xC3,
+0x9F, 0x50, 0x1F, 0x90, 0x9A, 0x3E, 0xE0, 0x24,
+0x63, 0xFD, 0x71, 0xC0, 0xFC, 0xEE, 0x7E, 0x00,
+0x2D, 0x51, 0x38, 0x90, 0x9A, 0x3C, 0xE0, 0x24,
+0x9C, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0x91, 0x8B,
+0x80, 0xD3, 0x90, 0x94, 0x3E, 0x12, 0xFB, 0x9C,
+0x90, 0x9A, 0x3A, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
+0x30, 0xE3, 0x0D, 0x90, 0x01, 0xC7, 0x74, 0x03,
+0xF0, 0x7F, 0x01, 0x12, 0xAD, 0x5E, 0x80, 0x20,
+0x7E, 0x00, 0x90, 0x9A, 0x3B, 0xE0, 0x54, 0x07,
+0xFF, 0x64, 0x01, 0x60, 0x05, 0xEF, 0x64, 0x02,
+0x70, 0x0E, 0xE4, 0xFD, 0x12, 0xEC, 0xE4, 0x90,
+0x06, 0x31, 0xE0, 0x54, 0xF7, 0x44, 0x10, 0xF0,
+0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xFF,
+0x90, 0x9A, 0x3D, 0xE0, 0x34, 0x00, 0x22, 0xFF,
+0x90, 0x9A, 0x5D, 0xE0, 0x34, 0x00, 0x22, 0xF1,
+0xE6, 0xA3, 0xEA, 0xF0, 0xA3, 0xEB, 0xF0, 0xC3,
+0x90, 0x9A, 0x67, 0xE0, 0x94, 0x01, 0x90, 0x9A,
+0x66, 0xE0, 0x94, 0x00, 0x50, 0x02, 0x80, 0x75,
+0xE4, 0x90, 0x9A, 0x6A, 0xF0, 0xA3, 0xF0, 0xF1,
+0x79, 0x51, 0x3C, 0x90, 0x9A, 0x64, 0xE0, 0x70,
+0x03, 0xA3, 0xE0, 0x6F, 0x70, 0x1D, 0x90, 0x9A,
+0x62, 0xE0, 0x24, 0x02, 0xFF, 0x90, 0x9A, 0x61,
+0xE0, 0x34, 0x00, 0xFE, 0x90, 0x9A, 0x63, 0xE0,
+0xFD, 0x12, 0xF6, 0x3B, 0xBF, 0x01, 0x02, 0xE1,
+0x79, 0x80, 0x00, 0x90, 0x9A, 0x62, 0xE0, 0x24,
+0x01, 0xFF, 0x90, 0x9A, 0x61, 0xE0, 0x34, 0x00,
+0x51, 0x3B, 0x7E, 0x00, 0x90, 0x9A, 0x68, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x24, 0x02, 0xFF, 0xEE,
+0x33, 0xFE, 0x90, 0x9A, 0x61, 0x8F, 0xF0, 0x12,
+0x02, 0xE7, 0x90, 0x9A, 0x6A, 0xEE, 0x8F, 0xF0,
+0x12, 0x02, 0xE7, 0x90, 0x9A, 0x66, 0x12, 0xC7,
+0x9B, 0x90, 0x9A, 0x6B, 0xE0, 0x9F, 0x90, 0x9A,
+0x6A, 0xE0, 0x9E, 0x40, 0x92, 0xE4, 0xFE, 0xFF,
+0x22, 0x7A, 0x00, 0xE4, 0xFD, 0x71, 0xCF, 0x90,
+0x9A, 0x5D, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22,
+0x90, 0x9A, 0x5D, 0xE4, 0x75, 0xF0, 0x04, 0x12,
+0x02, 0xE7, 0x90, 0x9A, 0x3A, 0xE0, 0x04, 0xF0,
+0x22, 0x90, 0x9A, 0x60, 0xE0, 0xFF, 0x90, 0x9A,
+0x3A, 0xE0, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
+0x9A, 0x3C, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x9A,
+0x60, 0xEF, 0xF0, 0xE4, 0x90, 0x9A, 0x3A, 0xF0,
+0x22, 0x90, 0x9A, 0x37, 0xE0, 0x24, 0x24, 0xFF,
+0x90, 0x9A, 0x36, 0xE0, 0x34, 0x00, 0xFE, 0x22,
+0x90, 0x9A, 0x39, 0xE0, 0x24, 0xDC, 0xFE, 0x90,
+0x9A, 0x38, 0xE0, 0x34, 0xFF, 0x90, 0x9A, 0x66,
+0xF0, 0xA3, 0xCE, 0xF0, 0x22, 0x12, 0xE8, 0x98,
+0xA3, 0xED, 0xF0, 0x12, 0xFB, 0x65, 0x7A, 0x80,
+0x79, 0x80, 0x7E, 0x00, 0x7F, 0x06, 0x12, 0x01,
+0xE0, 0x78, 0x43, 0x7C, 0x9A, 0x7D, 0x01, 0x7B,
+0xFF, 0x7A, 0x80, 0x79, 0x86, 0x7E, 0x00, 0x7F,
+0x04, 0x12, 0x01, 0xE0, 0x78, 0x47, 0x7C, 0x9A,
+0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x80, 0x79, 0x8A,
+0x7E, 0x00, 0x7F, 0x04, 0x12, 0x01, 0xE0, 0xE4,
+0x90, 0x9A, 0x4C, 0xF0, 0xD1, 0x27, 0xCF, 0x24,
+0x06, 0xCF, 0x34, 0x00, 0x51, 0x3B, 0xEF, 0x64,
+0x08, 0x60, 0x02, 0xC1, 0x0F, 0xD1, 0x27, 0xCF,
+0x24, 0x07, 0xCF, 0x34, 0x00, 0x51, 0x3B, 0xEF,
+0x64, 0x06, 0x60, 0x02, 0xC1, 0x0F, 0x90, 0x9A,
+0x4C, 0x04, 0xF0, 0xE4, 0x90, 0x9A, 0x4B, 0xF0,
+0xD1, 0x15, 0x94, 0x06, 0x50, 0x17, 0x90, 0x9A,
+0x35, 0xE0, 0x24, 0x0A, 0xFD, 0x90, 0x9A, 0x34,
+0xE0, 0x51, 0x31, 0x90, 0x9A, 0x4B, 0x12, 0xFB,
+0x5C, 0xD1, 0x1C, 0x80, 0xE3, 0x78, 0x37, 0x7C,
+0x9A, 0x7D, 0x01, 0x7B, 0x01, 0x7A, 0x93, 0x79,
+0x38, 0x12, 0xE8, 0x87, 0x60, 0x02, 0xC1, 0x0F,
+0x90, 0x9A, 0x4B, 0xF0, 0xD1, 0x15, 0x94, 0x04,
+0x50, 0x18, 0xF1, 0x92, 0xD1, 0x32, 0xCD, 0x24,
+0x20, 0x51, 0x30, 0x90, 0x9A, 0x4B, 0xE0, 0x24,
+0x47, 0xF5, 0x82, 0xE4, 0x34, 0x9A, 0xD1, 0x1C,
+0x80, 0xE2, 0x78, 0x47, 0x7C, 0x9A, 0xF1, 0xF2,
+0xEF, 0x70, 0x7B, 0x90, 0x06, 0x30, 0xE0, 0x44,
+0x01, 0x54, 0xDF, 0xF0, 0x90, 0x93, 0x26, 0xE0,
+0x30, 0xE0, 0x02, 0x80, 0x10, 0x90, 0x98, 0x35,
+0xE0, 0xB4, 0x02, 0x12, 0x90, 0x93, 0x25, 0x12,
+0x97, 0xD1, 0x20, 0xE0, 0x09, 0x90, 0x01, 0xC7,
+0x74, 0x09, 0xF1, 0x70, 0x80, 0x59, 0xE4, 0x90,
+0x9A, 0x4B, 0xF0, 0xD1, 0x15, 0x94, 0x06, 0x50,
+0x0C, 0x51, 0x1C, 0x90, 0x9A, 0x4B, 0x12, 0xFA,
+0x8C, 0xD1, 0x1C, 0x80, 0xEE, 0xE4, 0x90, 0x9A,
+0x4B, 0xF0, 0xD1, 0x15, 0x94, 0x04, 0x50, 0x18,
+0xF1, 0x92, 0xD1, 0x32, 0xCD, 0x24, 0x16, 0x51,
+0x30, 0x90, 0x9A, 0x4B, 0xE0, 0x24, 0x43, 0xF5,
+0x82, 0xE4, 0x34, 0x9A, 0xD1, 0x1C, 0x80, 0xE2,
+0x12, 0x94, 0xFF, 0x7B, 0x01, 0x7A, 0x9A, 0x79,
+0x3D, 0x12, 0xFA, 0xA2, 0xF0, 0x7A, 0x9A, 0x79,
+0x43, 0x12, 0x8B, 0xEA, 0x80, 0x09, 0x90, 0x06,
+0x30, 0xE0, 0x44, 0x21, 0x54, 0xEF, 0xF0, 0x90,
+0x9A, 0x4C, 0xE0, 0xFF, 0x22, 0x90, 0x9A, 0x4B,
+0xE0, 0xFF, 0xC3, 0x22, 0xF5, 0x83, 0xEF, 0xF0,
+0x90, 0x9A, 0x4B, 0xE0, 0x04, 0xF0, 0x22, 0x90,
+0x9A, 0x36, 0xE0, 0xFF, 0x90, 0x9A, 0x35, 0xE0,
+0x2F, 0xFF, 0x90, 0x9A, 0x34, 0xE0, 0x34, 0x00,
+0x22, 0x90, 0x9A, 0x3C, 0xE0, 0xFF, 0xC3, 0x22,
+0x90, 0x9A, 0x3B, 0xF1, 0xE9, 0x78, 0x3F, 0x7C,
+0x9A, 0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x80, 0x79,
+0xBA, 0x7E, 0x00, 0x7F, 0x04, 0x12, 0x01, 0xE0,
+0x90, 0x9A, 0x3D, 0xE0, 0xFF, 0x90, 0x9A, 0x3C,
+0xE0, 0x2F, 0x12, 0xFA, 0x83, 0x90, 0x9A, 0x43,
+0xF0, 0xA3, 0xEF, 0xF0, 0x24, 0x06, 0xFF, 0xE4,
+0x3E, 0x51, 0x3B, 0xEF, 0x64, 0x08, 0x70, 0x51,
+0x90, 0x9A, 0x44, 0xE0, 0x24, 0x07, 0xFF, 0x90,
+0x9A, 0x43, 0xE0, 0x34, 0x00, 0x51, 0x3B, 0xEF,
+0x70, 0x3F, 0x90, 0x9A, 0x3E, 0xF0, 0x90, 0x9A,
+0x3E, 0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50, 0x24,
+0x90, 0x9A, 0x44, 0xE0, 0x24, 0x18, 0xFD, 0x90,
+0x9A, 0x43, 0xE0, 0x51, 0x31, 0x90, 0x9A, 0x3E,
+0xE0, 0x24, 0x3F, 0xF5, 0x82, 0xE4, 0x34, 0x9A,
+0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x9A, 0x3E, 0xE0,
+0x04, 0xF0, 0x80, 0xD2, 0x78, 0x3F, 0x7C, 0x9A,
+0xF1, 0xF2, 0xEF, 0x7F, 0x00, 0x70, 0x02, 0x7F,
+0x01, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x9C, 0xE8, 0xEF, 0xF0, 0x90, 0x93,
+0x04, 0x12, 0xB4, 0xAD, 0x30, 0xE0, 0x39, 0x12,
+0xB7, 0xD4, 0x60, 0x10, 0x12, 0xB7, 0xCA, 0x40,
+0x0B, 0xE4, 0x7F, 0x0A, 0xFE, 0xFD, 0xFC, 0x90,
+0x95, 0xF5, 0x80, 0x09, 0xE4, 0x7F, 0x0A, 0xFE,
+0xFD, 0xFC, 0x90, 0x95, 0xED, 0x12, 0x82, 0x12,
+0x12, 0x80, 0xDB, 0xC0, 0x07, 0x90, 0x93, 0x0A,
+0xE0, 0xFB, 0xE4, 0xFA, 0xF9, 0xF8, 0xD0, 0x07,
+0x12, 0x81, 0x66, 0x90, 0x93, 0x0B, 0xEF, 0xF0,
+0x90, 0x9C, 0xE8, 0xE0, 0x64, 0x01, 0x70, 0x1B,
+0xF1, 0x68, 0x60, 0x0A, 0xF1, 0x61, 0x12, 0x7C,
+0x05, 0x12, 0xB7, 0xB8, 0x80, 0x08, 0xF1, 0x61,
+0x12, 0x7C, 0x3B, 0x12, 0xF9, 0x15, 0x12, 0x79,
+0xD4, 0x80, 0x1D, 0xF1, 0x68, 0x60, 0x07, 0xF1,
+0x61, 0x12, 0x7C, 0x05, 0x80, 0x05, 0xF1, 0x61,
+0x12, 0x7C, 0x3B, 0x7D, 0x02, 0x7F, 0x02, 0x12,
+0x7C, 0x74, 0x12, 0xB7, 0xA1, 0x12, 0x7B, 0xCC,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0, 0x90, 0x01,
+0x3F, 0x74, 0x10, 0xF0, 0xFD, 0x7F, 0x03, 0x22,
+0x90, 0x93, 0x0A, 0xE0, 0x90, 0x01, 0x3F, 0x22,
+0xF0, 0x90, 0x93, 0x31, 0xE0, 0x44, 0x01, 0xF0,
+0x22, 0x90, 0x9A, 0x61, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x22, 0x12, 0xFA, 0x95, 0x02, 0x04, 0x80,
+0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x78, 0x3C, 0x7C,
+0x9A, 0x22, 0x90, 0x9A, 0x36, 0xE0, 0xFD, 0x90,
+0x9A, 0x35, 0xE0, 0x2D, 0xFD, 0x22, 0x12, 0xE8,
+0x98, 0x12, 0xC7, 0xE2, 0xE4, 0x90, 0x9A, 0x3B,
+0xF0, 0xF0, 0x90, 0x9A, 0x37, 0xF1, 0xDE, 0xC3,
+0x9F, 0x50, 0x2A, 0xF1, 0x92, 0xD1, 0x32, 0xFC,
+0xEF, 0x12, 0xFB, 0x12, 0xEE, 0x7E, 0x00, 0x2D,
+0x51, 0x38, 0x90, 0x9A, 0x38, 0x12, 0x82, 0x1E,
+0x90, 0x9A, 0x3B, 0xE0, 0xF5, 0x82, 0x75, 0x83,
+0x00, 0xEF, 0x12, 0x02, 0x5E, 0x90, 0x9A, 0x3B,
+0xE0, 0x04, 0xF0, 0x80, 0xCD, 0x22, 0xE0, 0xFF,
+0x90, 0x9A, 0x3B, 0xE0, 0xFE, 0x22, 0x90, 0x9A,
+0x61, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xA3, 0xED,
+0xF0, 0x22, 0x7D, 0x01, 0x7B, 0x01, 0x7A, 0x93,
+0x79, 0x53, 0x7E, 0x00, 0x7F, 0x04, 0x02, 0x83,
+0xDC, 0x12, 0x02, 0x06, 0x54, 0x01, 0xFF, 0x90,
+0x98, 0x69, 0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x22,
+0x12, 0xE7, 0xAB, 0xFF, 0x54, 0x7F, 0x90, 0x88,
+0x36, 0xF0, 0xEF, 0x11, 0xAA, 0xA3, 0xF0, 0x12,
+0x9C, 0x5A, 0xFD, 0x54, 0xF0, 0xC4, 0x54, 0x0F,
+0xFF, 0x90, 0x88, 0x34, 0xE0, 0x54, 0xF0, 0x12,
+0x87, 0xA2, 0xFC, 0x54, 0x01, 0x25, 0xE0, 0xFF,
+0x90, 0x88, 0x31, 0xE0, 0x54, 0xFD, 0x4F, 0xF0,
+0xEC, 0x54, 0x04, 0xC3, 0x13, 0xFF, 0x90, 0x88,
+0x33, 0xE0, 0x54, 0xFD, 0x4F, 0xF0, 0xED, 0x54,
+0x0F, 0xC4, 0x54, 0xF0, 0xFF, 0xA3, 0xE0, 0x54,
+0x0F, 0x12, 0x87, 0xE5, 0x90, 0x88, 0x35, 0x12,
+0x87, 0xD1, 0xFD, 0x90, 0x8A, 0x89, 0x12, 0x90,
+0x47, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x90, 0x9B,
+0x89, 0xE0, 0x60, 0x0C, 0x12, 0xFB, 0x2F, 0x90,
+0x8A, 0x89, 0x12, 0x90, 0x47, 0x12, 0xFB, 0x6E,
+0x12, 0xC7, 0x95, 0x12, 0x5C, 0x5F, 0x90, 0x88,
+0x36, 0xE0, 0xB4, 0x01, 0x07, 0x90, 0x88, 0x33,
+0xE0, 0x54, 0xFB, 0xF0, 0x12, 0xDC, 0x59, 0xF0,
+0x90, 0x88, 0x36, 0x12, 0xFA, 0x75, 0x12, 0x97,
+0xF3, 0x90, 0x01, 0xBE, 0xF0, 0x22, 0x90, 0x93,
+0x2A, 0xE0, 0xC4, 0x13, 0x13, 0x13, 0x54, 0x01,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0xE4, 0x90, 0x9C, 0x08, 0xF0, 0xA3, 0x74, 0x08,
+0xF0, 0xA3, 0x12, 0xCA, 0x89, 0x90, 0x9C, 0x0F,
+0xF0, 0xA3, 0xF0, 0x90, 0x9C, 0x19, 0x12, 0xCF,
+0xCD, 0x12, 0xC7, 0x8C, 0x90, 0x9B, 0xFD, 0x12,
+0xCF, 0xB1, 0x90, 0x9C, 0x06, 0xF0, 0x90, 0x93,
+0x24, 0xE0, 0x20, 0xE0, 0x02, 0x81, 0x2A, 0xE4,
+0x90, 0x9C, 0x05, 0xF0, 0x90, 0x9C, 0x06, 0xE0,
+0xFF, 0x90, 0x9C, 0x05, 0xE0, 0xC3, 0x9F, 0x40,
+0x02, 0x81, 0x2A, 0x12, 0xFB, 0x4A, 0xEC, 0xFF,
+0x90, 0xFD, 0x11, 0xF0, 0x90, 0x9C, 0x0F, 0xEF,
+0xF0, 0x12, 0xD7, 0x63, 0x3E, 0x54, 0x3F, 0xFE,
+0x90, 0x9B, 0xFF, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
+0x9C, 0x0B, 0xEE, 0x12, 0xF9, 0xD2, 0x30, 0xE0,
+0x0A, 0xC3, 0x13, 0x20, 0xE0, 0x05, 0x12, 0xFA,
+0x66, 0x80, 0x02, 0x7E, 0x00, 0xEF, 0x24, 0x18,
+0x2E, 0xFF, 0x90, 0x9C, 0x10, 0xF0, 0x90, 0x9B,
+0xFE, 0xE0, 0x2F, 0xFF, 0x90, 0x9B, 0xFD, 0xE0,
+0x34, 0x00, 0xFE, 0x90, 0x9C, 0x01, 0xF0, 0xA3,
+0xEF, 0xF0, 0x12, 0xA2, 0x3C, 0xC0, 0x07, 0x90,
+0x9C, 0x01, 0x91, 0x49, 0x7D, 0x01, 0x12, 0x04,
+0x7E, 0xC0, 0x07, 0x90, 0x9C, 0x01, 0x91, 0x49,
+0x7D, 0x04, 0x12, 0x04, 0x7E, 0xAB, 0x07, 0xD0,
+0x05, 0xD0, 0x07, 0x12, 0x8E, 0xC9, 0x90, 0x9C,
+0x07, 0xEF, 0xF0, 0x91, 0x3D, 0x12, 0xA2, 0x3C,
+0xEF, 0x54, 0xFC, 0x90, 0x9C, 0x03, 0xF0, 0x90,
+0x9C, 0x10, 0xE0, 0xFF, 0x90, 0x9B, 0xFF, 0xE4,
+0x8F, 0xF0, 0x12, 0x02, 0xE7, 0x12, 0xFB, 0x53,
+0x12, 0xCD, 0xEE, 0x90, 0x9B, 0xFF, 0xEE, 0xF0,
+0xA3, 0xEF, 0xF0, 0x90, 0x9B, 0xFD, 0x91, 0x49,
+0x7D, 0x0F, 0x12, 0x04, 0x7E, 0x90, 0x9C, 0x04,
+0xEF, 0xF0, 0x90, 0x9B, 0x89, 0xE0, 0x60, 0x39,
+0x90, 0x9C, 0x03, 0xE0, 0x24, 0xB0, 0x60, 0x15,
+0x24, 0xD0, 0x60, 0x02, 0x61, 0x4C, 0x12, 0xD6,
+0x11, 0x20, 0xE0, 0x16, 0xF1, 0xEB, 0x20, 0xE0,
+0x02, 0x61, 0x4C, 0x80, 0x0D, 0x12, 0xD6, 0x11,
+0x20, 0xE0, 0x07, 0xF1, 0xEB, 0x20, 0xE0, 0x02,
+0x61, 0x4C, 0x91, 0x3D, 0x90, 0x9C, 0x0B, 0xE0,
+0xFC, 0xA3, 0xE0, 0xFD, 0x12, 0xF6, 0x21, 0x61,
+0x4C, 0x90, 0x9C, 0x03, 0xE0, 0x24, 0xF8, 0x60,
+0x35, 0x24, 0x80, 0x60, 0x31, 0x24, 0xC8, 0x60,
+0x06, 0x24, 0x20, 0x60, 0x02, 0x61, 0x4C, 0x90,
+0x93, 0x29, 0x11, 0xA9, 0x20, 0xE0, 0x02, 0x61,
+0x4C, 0x91, 0x3D, 0xB1, 0x0C, 0xEF, 0x70, 0x02,
+0x61, 0x4C, 0x91, 0x3D, 0x12, 0xE8, 0x44, 0xEF,
+0x70, 0x02, 0x61, 0x4C, 0x90, 0x9C, 0x03, 0xE0,
+0xFF, 0x12, 0xE8, 0x32, 0x61, 0x4C, 0x12, 0xFA,
+0x47, 0xFF, 0x12, 0xF0, 0x07, 0xAC, 0x07, 0x91,
+0x2F, 0xAB, 0x04, 0xC0, 0x03, 0x7B, 0x01, 0x7A,
+0x9C, 0x79, 0x11, 0x90, 0x9A, 0x38, 0x12, 0x82,
+0x27, 0xD0, 0x03, 0x12, 0xA7, 0x9E, 0x91, 0x3D,
+0xB1, 0x0C, 0x90, 0x9A, 0x38, 0xEF, 0xF0, 0x7B,
+0x01, 0x7A, 0x9C, 0x79, 0x11, 0x12, 0xFA, 0x47,
+0xFD, 0x12, 0xE4, 0x7A, 0xEF, 0x70, 0x02, 0x61,
+0x4C, 0x90, 0x93, 0x24, 0xB1, 0xFB, 0x30, 0xE0,
+0x5F, 0x90, 0x9C, 0x07, 0xE0, 0xFF, 0x90, 0x9C,
+0x02, 0xE0, 0x2F, 0xFF, 0x90, 0x9C, 0x01, 0xE0,
+0x34, 0x00, 0xCF, 0x24, 0x08, 0xCF, 0x34, 0x00,
+0xFE, 0x90, 0x9C, 0x0D, 0xF0, 0xA3, 0xEF, 0xF0,
+0x12, 0xA2, 0x3C, 0xEF, 0x64, 0x45, 0x70, 0x38,
+0xB1, 0x03, 0x12, 0xF6, 0xEA, 0xEF, 0x64, 0x01,
+0x70, 0x2E, 0xB1, 0x03, 0x12, 0xF7, 0x26, 0xEF,
+0x64, 0x01, 0x70, 0x24, 0x90, 0x9C, 0x19, 0x04,
+0xB1, 0x02, 0xA3, 0xE0, 0xFD, 0x12, 0xF6, 0x48,
+0xEF, 0x70, 0x0D, 0x90, 0x9C, 0x0F, 0xE0, 0xFD,
+0x90, 0xFD, 0x11, 0xB1, 0x02, 0x12, 0xF6, 0xA3,
+0x90, 0x9C, 0x0F, 0xE0, 0x90, 0xFD, 0x11, 0xF0,
+0x91, 0x3D, 0xB1, 0x0C, 0xEF, 0x60, 0x30, 0x91,
+0x2F, 0x90, 0x9C, 0x0A, 0xE0, 0xFB, 0x90, 0x9C,
+0x0F, 0xE0, 0x90, 0x9A, 0x38, 0xF0, 0xF1, 0x24,
+0xEF, 0x60, 0x02, 0x91, 0xFB, 0x90, 0x93, 0x25,
+0xE0, 0xC4, 0x13, 0x54, 0x07, 0x30, 0xE0, 0x0F,
+0x91, 0x2F, 0x90, 0x9C, 0x0A, 0xE0, 0xFB, 0x12,
+0xF3, 0xAD, 0xEF, 0x60, 0x02, 0x91, 0xFB, 0x90,
+0x93, 0x24, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x0A,
+0x91, 0x2F, 0x12, 0xA4, 0xC5, 0xEF, 0x60, 0x02,
+0x91, 0xFB, 0x12, 0x9F, 0xA6, 0x54, 0x3F, 0x30,
+0xE0, 0x0A, 0x91, 0x2F, 0x12, 0xE8, 0xA1, 0xEF,
+0x60, 0x02, 0x91, 0xFB, 0x90, 0x93, 0x24, 0x11,
+0xA9, 0x30, 0xE0, 0x16, 0x90, 0x9C, 0x19, 0xE0,
+0x70, 0x10, 0x91, 0x2F, 0xF1, 0xD6, 0xEF, 0x60,
+0x09, 0x12, 0xA7, 0x71, 0x90, 0x01, 0xC7, 0x74,
+0x22, 0xF0, 0x91, 0x2F, 0x91, 0x5A, 0xEF, 0x60,
+0x03, 0x12, 0xC9, 0x35, 0x90, 0x9C, 0x04, 0xE0,
+0xFF, 0x7D, 0x01, 0x12, 0xF4, 0x1D, 0xEF, 0x60,
+0x12, 0x12, 0xA7, 0x71, 0x90, 0x9B, 0xFD, 0x91,
+0x49, 0x7D, 0x10, 0x12, 0x04, 0x7E, 0x90, 0x95,
+0x65, 0xEF, 0xF0, 0x90, 0x9C, 0x19, 0xE0, 0x70,
+0x1E, 0x90, 0x93, 0x26, 0xB1, 0xFB, 0x30, 0xE0,
+0x16, 0x90, 0x9C, 0x03, 0xE0, 0xFF, 0x64, 0x08,
+0x60, 0x04, 0xEF, 0xB4, 0x88, 0x09, 0x12, 0xA7,
+0x71, 0x90, 0x01, 0xC7, 0x74, 0x25, 0xF0, 0x90,
+0x93, 0x31, 0xE0, 0x30, 0xE0, 0x13, 0x90, 0x93,
+0x25, 0xB1, 0xFB, 0x30, 0xE0, 0x0B, 0x91, 0x2F,
+0x12, 0xBC, 0x13, 0xBF, 0x01, 0x03, 0x12, 0xC9,
+0x35, 0x12, 0xFB, 0x53, 0x90, 0x9B, 0xFD, 0x12,
+0xFA, 0x57, 0x12, 0xFB, 0x4A, 0xD3, 0x9F, 0xEC,
+0x9E, 0x40, 0x0F, 0x12, 0xFA, 0x37, 0xED, 0x9F,
+0xFF, 0xEC, 0x9E, 0x90, 0x9B, 0xFD, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x93, 0x31, 0xE0, 0x30, 0xE0,
+0x04, 0x7F, 0x01, 0xB1, 0x5E, 0x12, 0xE8, 0x1B,
+0xEF, 0x64, 0x01, 0x70, 0x31, 0x12, 0xE6, 0x30,
+0xAD, 0x07, 0xEF, 0x64, 0x01, 0x60, 0x1F, 0x12,
+0xA7, 0x71, 0xED, 0xB4, 0x02, 0x08, 0x90, 0x01,
+0xC7, 0x74, 0x42, 0xF0, 0x80, 0x0A, 0xED, 0xB4,
+0x04, 0x06, 0x90, 0x01, 0xC7, 0x74, 0x43, 0xF0,
+0x7F, 0x01, 0xB1, 0x5E, 0x80, 0x24, 0x90, 0x9B,
+0xFD, 0x12, 0xE6, 0x1D, 0x80, 0x14, 0x90, 0x93,
+0x26, 0xE0, 0xC4, 0x13, 0x54, 0x07, 0x20, 0xE0,
+0x11, 0x90, 0x93, 0x24, 0xE0, 0x54, 0xFE, 0xF0,
+0x80, 0x08, 0x90, 0x9C, 0x05, 0xE0, 0x04, 0xF0,
+0x01, 0xEC, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
+0x9C, 0x01, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90,
+0x9C, 0x07, 0xE0, 0xFD, 0x22, 0x90, 0x9C, 0x01,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0x90, 0x9A,
+0x39, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x8A,
+0xE9, 0xE0, 0xFC, 0xA3, 0xE0, 0xF5, 0x82, 0x8C,
+0x83, 0x22, 0x90, 0x9A, 0x36, 0xED, 0x12, 0xE8,
+0x97, 0xB1, 0x0C, 0xEF, 0x70, 0x02, 0x81, 0xF8,
+0xF1, 0x1B, 0xF1, 0xF2, 0x70, 0x02, 0x81, 0xF8,
+0x12, 0xA6, 0x27, 0xCF, 0x24, 0x08, 0x12, 0xFA,
+0xCF, 0x90, 0x93, 0x25, 0xE0, 0xC4, 0x54, 0x0F,
+0x30, 0xE0, 0x33, 0x91, 0x46, 0x7D, 0x09, 0x12,
+0x04, 0x7E, 0xEF, 0x64, 0x06, 0x70, 0x27, 0x91,
+0x46, 0x7D, 0x14, 0x12, 0x04, 0x7E, 0xEF, 0x70,
+0x1D, 0x91, 0x46, 0x7D, 0x15, 0x12, 0x04, 0x7E,
+0xEF, 0x64, 0x50, 0x70, 0x11, 0x91, 0x46, 0x7D,
+0x21, 0x12, 0x04, 0x7E, 0xEF, 0x20, 0xE0, 0x03,
+0x30, 0xE2, 0x03, 0x7F, 0x01, 0x22, 0x90, 0x93,
+0x25, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0,
+0x37, 0x91, 0x46, 0x7D, 0x09, 0x12, 0x04, 0x7E,
+0xEF, 0x64, 0x11, 0x70, 0x2B, 0x90, 0x9A, 0x3A,
+0xE0, 0x24, 0x14, 0xFF, 0x90, 0x9A, 0x39, 0xE0,
+0x34, 0x00, 0xFE, 0x12, 0xBF, 0xED, 0x91, 0x4E,
+0x7D, 0x02, 0x12, 0x04, 0x7E, 0xEF, 0x70, 0x10,
+0x90, 0x9A, 0x37, 0x91, 0x49, 0x7D, 0x03, 0x12,
+0x04, 0x7E, 0xBF, 0x89, 0x03, 0x7F, 0x01, 0x22,
+0x7F, 0x00, 0x22, 0x90, 0x9C, 0x19, 0x74, 0x01,
+0xF0, 0x22, 0xF0, 0x90, 0x9C, 0x0D, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0x22, 0x90, 0x9A, 0x3B, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x90, 0x9A, 0x43,
+0xF0, 0x90, 0x9A, 0x43, 0xE0, 0xFD, 0xC3, 0x94,
+0x06, 0x50, 0x1D, 0x90, 0x9A, 0x3C, 0xE0, 0x24,
+0x04, 0x12, 0xFA, 0x83, 0xF1, 0xC7, 0x90, 0x9A,
+0x43, 0x12, 0xFA, 0x8C, 0xF5, 0x83, 0xEF, 0xF0,
+0x90, 0x9A, 0x43, 0xE0, 0x04, 0xF0, 0x80, 0xD9,
+0x78, 0x32, 0x7C, 0x93, 0x7D, 0x01, 0x7B, 0x01,
+0x7A, 0x9A, 0x79, 0x3D, 0x12, 0xE8, 0x87, 0x7F,
+0x00, 0x70, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x01,
+0xC7, 0x74, 0x10, 0xF0, 0x7F, 0x01, 0x90, 0x9C,
+0xE4, 0xEF, 0xF0, 0x90, 0x86, 0xB3, 0xE0, 0x64,
+0x02, 0x70, 0x21, 0x90, 0x9C, 0xE4, 0xE0, 0xFD,
+0x64, 0x01, 0x70, 0x7B, 0x12, 0xA7, 0x71, 0x11,
+0xA6, 0x30, 0xE0, 0x09, 0x90, 0x01, 0x4D, 0xE0,
+0x64, 0x80, 0xF0, 0x80, 0x6A, 0xAF, 0x05, 0x12,
+0xE2, 0x07, 0x80, 0x63, 0x90, 0x86, 0xB3, 0xE0,
+0x64, 0x03, 0x70, 0x2E, 0x90, 0x99, 0xB0, 0xE0,
+0xFF, 0x30, 0xE0, 0x26, 0x90, 0x00, 0xD4, 0xE0,
+0x54, 0xEF, 0xF0, 0x90, 0x00, 0xC6, 0xE0, 0x54,
+0xFD, 0xF0, 0x90, 0x00, 0x01, 0xE0, 0x44, 0x30,
+0xF0, 0x90, 0x00, 0x23, 0xE0, 0x44, 0x80, 0xF0,
+0x12, 0xBF, 0x73, 0xEF, 0x54, 0xFE, 0x90, 0x99,
+0xB0, 0xF0, 0x90, 0x06, 0x90, 0xE0, 0x44, 0x20,
+0x12, 0xDE, 0xC8, 0x12, 0xFB, 0x95, 0x90, 0x06,
+0x90, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x9C, 0xE4,
+0xE0, 0xFF, 0x12, 0xE2, 0x07, 0x12, 0xBF, 0xE6,
+0xFB, 0xFD, 0x12, 0xBA, 0x4C, 0x12, 0xBF, 0x5E,
+0x90, 0x00, 0x04, 0xE0, 0x44, 0x08, 0xF0, 0x12,
+0xDB, 0xC0, 0xF0, 0x90, 0x93, 0x24, 0xE0, 0x54,
+0xBF, 0xF0, 0x22, 0xE0, 0xC4, 0x13, 0x13, 0x54,
+0x03, 0x22, 0x90, 0x88, 0x36, 0xE0, 0x70, 0x02,
+0xC1, 0x90, 0x90, 0x88, 0x4D, 0xE0, 0x04, 0xF0,
+0x90, 0x05, 0x61, 0xF1, 0x13, 0x78, 0x08, 0x12,
+0x03, 0xFE, 0xA8, 0x04, 0xA9, 0x05, 0xAA, 0x06,
+0xAB, 0x07, 0x90, 0x05, 0x60, 0xF1, 0x13, 0x12,
+0x82, 0x05, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x05, 0x62, 0xF1, 0x13, 0x78,
+0x10, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x82, 0x05, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3,
+0xF1, 0x13, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0,
+0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
+0x82, 0x05, 0x90, 0x88, 0x81, 0x12, 0x04, 0x31,
+0x90, 0x88, 0x32, 0xE0, 0x54, 0x7F, 0xF0, 0xA3,
+0xE0, 0x30, 0xE0, 0x0C, 0x12, 0xF9, 0xB2, 0x74,
+0x05, 0xF0, 0x12, 0x6E, 0x2F, 0x12, 0xFB, 0x75,
+0x12, 0xB4, 0xAA, 0x30, 0xE0, 0x0A, 0x90, 0x01,
+0x3B, 0xE0, 0x30, 0xE4, 0x03, 0x12, 0xF9, 0x15,
+0x12, 0xDB, 0xC7, 0x12, 0xE5, 0xB7, 0xE4, 0x90,
+0x98, 0x4F, 0xF0, 0x12, 0xF9, 0x04, 0x90, 0x93,
+0x24, 0xB1, 0xFB, 0x30, 0xE0, 0x51, 0x90, 0x95,
+0x93, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x7C, 0x00,
+0x7D, 0x64, 0x12, 0x02, 0x92, 0x90, 0x95, 0xE7,
+0xE0, 0x6E, 0x70, 0x03, 0xA3, 0xE0, 0x6F, 0x60,
+0x0A, 0x90, 0x95, 0xE7, 0xE4, 0x75, 0xF0, 0x01,
+0x02, 0x02, 0xE7, 0x90, 0x95, 0x97, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0x90, 0x95, 0xA5, 0xE0, 0xB5,
+0x06, 0x13, 0xA3, 0xE0, 0xB5, 0x07, 0x0E, 0xEF,
+0x4E, 0x60, 0x0A, 0x90, 0x01, 0xC7, 0x74, 0x31,
+0xF0, 0x7F, 0x01, 0xA1, 0x5E, 0x12, 0xC6, 0x06,
+0xE4, 0x90, 0x95, 0xE7, 0xF0, 0xA3, 0xF0, 0x22,
+0x12, 0x04, 0x31, 0x90, 0x99, 0xB1, 0xE4, 0x75,
+0xF0, 0x04, 0x12, 0x02, 0xE7, 0x90, 0x99, 0xB1,
+0xA3, 0xE0, 0x24, 0x02, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xE0, 0xFF, 0xE4, 0xFC, 0xFD,
+0xFE, 0x22, 0xF0, 0x90, 0x9A, 0x34, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0x22, 0x12, 0xE8, 0x90, 0xE4,
+0x90, 0x9A, 0x39, 0xF0, 0x12, 0xA2, 0x3C, 0xEF,
+0x54, 0x0C, 0x64, 0x08, 0x70, 0x75, 0xF1, 0x1B,
+0xA3, 0xE0, 0x24, 0x06, 0xF1, 0xC6, 0xEF, 0x64,
+0x88, 0x70, 0x68, 0xF1, 0x1B, 0xA3, 0xE0, 0x24,
+0x07, 0xF1, 0xC6, 0xEF, 0x64, 0x8E, 0x70, 0x5B,
+0x90, 0x9A, 0x39, 0xF1, 0xB1, 0xEF, 0x64, 0x03,
+0x70, 0x51, 0xF1, 0x1B, 0x12, 0xF4, 0x12, 0x24,
+0x06, 0xF1, 0xC6, 0xEF, 0x30, 0xE3, 0x07, 0x90,
+0x01, 0xC7, 0x74, 0x01, 0x80, 0x3A, 0x90, 0x93,
+0x24, 0x12, 0x97, 0xD1, 0x30, 0xE0, 0x24, 0x90,
+0x98, 0x35, 0xE0, 0x64, 0x02, 0x70, 0x12, 0x90,
+0x93, 0x25, 0x12, 0x97, 0xD1, 0x30, 0xE0, 0x02,
+0x80, 0x07, 0x90, 0x01, 0xC7, 0x74, 0x02, 0x80,
+0x17, 0xF1, 0x1B, 0xA3, 0xE0, 0xFD, 0x12, 0xA2,
+0x4C, 0x80, 0x10, 0x90, 0x93, 0x29, 0xB1, 0xFB,
+0x30, 0xE0, 0x08, 0x90, 0x01, 0xC7, 0x74, 0x02,
+0x12, 0xA7, 0x70, 0x90, 0x9A, 0x39, 0xE0, 0xFF,
+0x22, 0x04, 0xF0, 0x90, 0x9A, 0x34, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0x90, 0x9A, 0x37, 0xE0, 0xFD,
+0x90, 0x9A, 0x36, 0xE0, 0x2D, 0x04, 0xFD, 0x90,
+0x8A, 0xE9, 0xE0, 0xFA, 0xA3, 0xE0, 0xFB, 0xF5,
+0x82, 0x8A, 0x83, 0x02, 0x04, 0x7E, 0x90, 0x9A,
+0x36, 0xED, 0x12, 0xE8, 0x97, 0xB1, 0x0C, 0xEF,
+0x60, 0x08, 0xF1, 0x1B, 0xF1, 0xF2, 0x60, 0x02,
+0x7F, 0x01, 0x22, 0xEF, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x22, 0xA3, 0xE0, 0xFD, 0x12, 0xA6, 0x40,
+0xEF, 0x22, 0x12, 0x02, 0x06, 0x90, 0x88, 0x9C,
+0xF0, 0x22, 0x12, 0x02, 0x06, 0xFF, 0x54, 0x01,
+0xFE, 0x90, 0x93, 0x08, 0xE0, 0x54, 0xFE, 0x4E,
+0xFE, 0xF0, 0xEF, 0x54, 0x02, 0xFF, 0xEE, 0x54,
+0xFD, 0x4F, 0xF0, 0x12, 0x9C, 0x5A, 0x90, 0x93,
+0x09, 0x12, 0x87, 0xE6, 0x90, 0x93, 0x0A, 0xF0,
+0x11, 0x34, 0x90, 0x93, 0x08, 0xE0, 0x54, 0x01,
+0xFF, 0x02, 0xA6, 0xCA, 0x90, 0x93, 0x09, 0xE0,
+0x14, 0x90, 0x93, 0x0B, 0xF0, 0x22, 0x90, 0x93,
+0x08, 0xE0, 0x30, 0xE0, 0x37, 0xF1, 0xB8, 0x90,
+0x93, 0x0B, 0xE0, 0x60, 0x0B, 0x14, 0xF0, 0x90,
+0x9B, 0x89, 0xE0, 0x70, 0x27, 0x02, 0x79, 0xD4,
+0x11, 0x34, 0xE4, 0xFF, 0x12, 0xA6, 0xCA, 0x90,
+0x93, 0x04, 0xE0, 0xFF, 0x20, 0xE0, 0x08, 0x13,
+0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x0D, 0x90,
+0x9C, 0x9B, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0x01, 0x12, 0x95, 0x30, 0x22, 0x11, 0xC6, 0x7D,
+0x02, 0x7F, 0x02, 0x12, 0x7C, 0x74, 0x7F, 0x01,
+0x11, 0x8C, 0x80, 0xB2, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x88, 0x33, 0xE0, 0xC3,
+0x13, 0x30, 0xE0, 0x25, 0x90, 0x9B, 0xDA, 0x74,
+0x1E, 0xF0, 0x90, 0x9B, 0xFC, 0x74, 0x01, 0xF0,
+0x90, 0x9B, 0xDC, 0xEF, 0xF0, 0x7B, 0x01, 0x7A,
+0x9B, 0x79, 0xDA, 0x12, 0xF9, 0xC3, 0x90, 0x8A,
+0xE5, 0x12, 0x90, 0x47, 0x7F, 0x04, 0x12, 0x04,
+0x7E, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4, 0x90,
+0x9B, 0x04, 0xF0, 0x90, 0x88, 0x36, 0xE0, 0x60,
+0x39, 0x12, 0x97, 0xE0, 0x70, 0x34, 0x31, 0x12,
+0xF0, 0x12, 0xF9, 0x37, 0x90, 0x9B, 0x04, 0x74,
+0x01, 0xF0, 0xE4, 0x90, 0x88, 0x3D, 0xF0, 0x04,
+0x60, 0x20, 0x90, 0x88, 0x39, 0xE0, 0x20, 0xE2,
+0x0D, 0x90, 0x8A, 0xB9, 0x12, 0x90, 0x47, 0x7D,
+0x01, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xF1, 0xB0,
+0xE4, 0x90, 0x92, 0x20, 0xF0, 0x12, 0x97, 0xCE,
+0xD1, 0x55, 0x22, 0x12, 0x97, 0x5F, 0xE4, 0xFF,
+0x01, 0x8C, 0x90, 0x88, 0x3C, 0xE0, 0x90, 0x05,
+0x73, 0x22, 0xE4, 0x90, 0x9A, 0xFB, 0xF0, 0x12,
+0x97, 0xE1, 0x60, 0x02, 0x41, 0x53, 0x90, 0x88,
+0x36, 0xE0, 0x70, 0x02, 0x41, 0x53, 0x90, 0x06,
+0xA9, 0xE0, 0x54, 0xC0, 0x70, 0x26, 0x90, 0x88,
+0x9C, 0xE0, 0x70, 0x20, 0x90, 0x04, 0x1A, 0xE0,
+0xF4, 0x70, 0x19, 0xA3, 0xE0, 0x54, 0x07, 0xFF,
+0xBF, 0x07, 0x11, 0x90, 0x06, 0x62, 0xE0, 0x54,
+0x03, 0x70, 0x09, 0x90, 0x88, 0x39, 0xE0, 0xB4,
+0x04, 0x02, 0xF1, 0xA8, 0x90, 0x05, 0x63, 0xE0,
+0x90, 0x88, 0x85, 0xF0, 0x90, 0x05, 0x62, 0xE0,
+0x90, 0x88, 0x86, 0xF0, 0x90, 0x05, 0x61, 0xE0,
+0x90, 0x88, 0x87, 0xF0, 0x90, 0x05, 0x60, 0xE0,
+0x90, 0x88, 0x88, 0xF0, 0x90, 0x07, 0xF1, 0xE0,
+0x90, 0x99, 0xAD, 0xF0, 0x90, 0x07, 0xF0, 0xE0,
+0x90, 0x99, 0xAE, 0xF0, 0xD1, 0x7A, 0xF0, 0x90,
+0x88, 0x3A, 0xE0, 0x54, 0xEC, 0xF0, 0x51, 0x5C,
+0x24, 0xFD, 0x50, 0x02, 0x80, 0x02, 0xB1, 0xC9,
+0x51, 0x5C, 0x64, 0x01, 0x70, 0x3A, 0x90, 0x06,
+0xAB, 0xE0, 0x90, 0x88, 0x3D, 0xF0, 0x90, 0x06,
+0xA9, 0xE0, 0x30, 0xE5, 0x06, 0xA3, 0xE0, 0x90,
+0x9A, 0xFB, 0xF0, 0x90, 0x9A, 0xFB, 0xE0, 0xFF,
+0x60, 0x02, 0x80, 0x05, 0x90, 0x88, 0x3C, 0xE0,
+0xFF, 0x90, 0x88, 0x3C, 0xEF, 0xF0, 0xA3, 0xE0,
+0xFF, 0x70, 0x08, 0x90, 0x88, 0x3C, 0xE0, 0xFE,
+0xFF, 0x80, 0x00, 0x90, 0x88, 0x3D, 0xEF, 0xF0,
+0x51, 0x65, 0xE4, 0x90, 0x88, 0x3F, 0xF0, 0xA3,
+0xF0, 0x91, 0xAA, 0x30, 0xE0, 0x5E, 0xEF, 0xC4,
+0x13, 0x13, 0x54, 0x03, 0x20, 0xE0, 0x24, 0x51,
+0x54, 0x6F, 0x70, 0x50, 0xEF, 0x60, 0x4D, 0x90,
+0x88, 0x32, 0xE0, 0x44, 0x40, 0xF0, 0x31, 0x12,
+0x12, 0xA7, 0x5D, 0x12, 0x7C, 0x05, 0x12, 0xF9,
+0x1C, 0xB1, 0x27, 0x90, 0x88, 0x3D, 0xE0, 0x14,
+0xF0, 0x80, 0x31, 0x90, 0x88, 0x34, 0xE0, 0xC4,
+0x54, 0x0F, 0x64, 0x01, 0x70, 0x26, 0x51, 0x54,
+0xFE, 0x6F, 0x60, 0x20, 0x90, 0x05, 0x73, 0xE0,
+0xFF, 0xEE, 0x6F, 0x60, 0x17, 0x91, 0xA0, 0x30,
+0xE0, 0x12, 0xEF, 0x54, 0xBF, 0x12, 0xA7, 0x5D,
+0x12, 0x7C, 0x3B, 0xF1, 0xA1, 0x7D, 0x02, 0x7F,
+0x02, 0x12, 0x7C, 0x74, 0x90, 0x88, 0x32, 0xE0,
+0x44, 0x04, 0xF0, 0x22, 0x90, 0x88, 0x3C, 0xE0,
+0xFF, 0xA3, 0xE0, 0x22, 0x90, 0x88, 0x34, 0xE0,
+0xFF, 0xC4, 0x54, 0x0F, 0x22, 0x90, 0x88, 0x85,
+0x12, 0x04, 0xB8, 0xC0, 0x06, 0xC0, 0x07, 0x90,
+0x99, 0xAE, 0xE0, 0x24, 0x46, 0xFF, 0x90, 0x99,
+0xAD, 0xE0, 0x34, 0x00, 0xAB, 0x07, 0xFA, 0xE4,
+0xF9, 0xF8, 0xD0, 0x07, 0xD0, 0x06, 0x12, 0x80,
+0xCD, 0x90, 0x88, 0x85, 0x91, 0x7E, 0xEF, 0x24,
+0x46, 0xF1, 0xEA, 0x90, 0x88, 0x89, 0x91, 0x7E,
+0x90, 0x88, 0x85, 0x12, 0x82, 0x12, 0xC3, 0x12,
+0x03, 0xDA, 0x50, 0x02, 0x61, 0x5F, 0x90, 0x88,
+0x89, 0x12, 0x82, 0x12, 0x90, 0x88, 0x85, 0x12,
+0x04, 0xB8, 0x12, 0x80, 0xCD, 0x90, 0x9B, 0x00,
+0x12, 0x04, 0x31, 0x90, 0x88, 0x31, 0xE0, 0x30,
+0xE0, 0x34, 0x90, 0x88, 0x53, 0xE0, 0x24, 0x04,
+0xFF, 0xE4, 0x33, 0xFE, 0xEF, 0x78, 0x03, 0xC3,
+0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24, 0x50,
+0xFF, 0xE4, 0x3E, 0xFE, 0x90, 0x88, 0x4E, 0xE0,
+0xFD, 0xC3, 0xEF, 0x9D, 0xFB, 0xEE, 0x94, 0x00,
+0xFA, 0x91, 0x6D, 0x78, 0x07, 0x12, 0x03, 0xEB,
+0xEB, 0x2F, 0xFF, 0xEA, 0x80, 0x22, 0x90, 0x88,
+0x33, 0x91, 0xA3, 0x30, 0xE0, 0x02, 0x81, 0x5D,
+0x91, 0x6D, 0x78, 0x07, 0x12, 0x03, 0xEB, 0x90,
+0x88, 0x4E, 0xE0, 0xFD, 0xC3, 0x74, 0x60, 0x9D,
+0xCD, 0xE4, 0x94, 0x00, 0xCD, 0x2F, 0xFF, 0xED,
+0x3E, 0x90, 0x9A, 0xFC, 0xF0, 0xA3, 0xEF, 0xF0,
+0xC3, 0x90, 0x9A, 0xFD, 0xE0, 0x94, 0xA0, 0x90,
+0x9A, 0xFC, 0xE0, 0x94, 0x00, 0x50, 0x30, 0xA3,
+0xE0, 0xFB, 0x24, 0x6D, 0x91, 0x76, 0xE0, 0x04,
+0xF0, 0x91, 0x6D, 0xEF, 0x54, 0x7F, 0xFF, 0x74,
+0x0D, 0x2B, 0x91, 0x65, 0xE0, 0xFE, 0xEF, 0xC3,
+0x9E, 0x50, 0x09, 0x90, 0x9A, 0xFC, 0xA3, 0xE0,
+0x91, 0x63, 0xEF, 0xF0, 0x90, 0x88, 0x4C, 0xE0,
+0x04, 0xF0, 0xE0, 0x90, 0x00, 0xFE, 0xF0, 0x90,
+0x88, 0x4C, 0xE0, 0xFF, 0xD3, 0x90, 0x88, 0x90,
+0xE0, 0x9F, 0x90, 0x88, 0x8F, 0xE0, 0x94, 0x00,
+0x40, 0x02, 0x81, 0x5D, 0xE4, 0xFF, 0xFE, 0x91,
+0x73, 0xE0, 0x2F, 0xFF, 0x90, 0x88, 0x91, 0xE0,
+0xFD, 0xEF, 0xD3, 0x9D, 0x40, 0x07, 0x90, 0x9A,
+0xFE, 0xEE, 0xF0, 0x80, 0x05, 0x0E, 0xEE, 0xB4,
+0xA0, 0xE5, 0x91, 0x87, 0x40, 0x02, 0x80, 0x15,
+0x90, 0x9A, 0xFE, 0xE0, 0x04, 0xFE, 0xEE, 0xC3,
+0x94, 0xA0, 0x50, 0x13, 0x91, 0x73, 0xE0, 0x2F,
+0xFF, 0x91, 0x87, 0x40, 0x07, 0x90, 0x9A, 0xFF,
+0xEE, 0xF0, 0x80, 0x03, 0x0E, 0x80, 0xE7, 0x90,
+0x05, 0x5E, 0xE0, 0xFF, 0x91, 0x5E, 0xE0, 0xFD,
+0xEF, 0xC3, 0x9D, 0x40, 0x11, 0xEF, 0x9D, 0x90,
+0x05, 0x5E, 0xF0, 0x90, 0x88, 0x51, 0xEE, 0xF0,
+0x90, 0x9A, 0xFF, 0xE0, 0x80, 0x18, 0x91, 0x5E,
+0xE0, 0xFD, 0xC3, 0x74, 0x80, 0x9D, 0x2F, 0x90,
+0x05, 0x5E, 0xF0, 0xEE, 0x04, 0x90, 0x88, 0x51,
+0xF0, 0x90, 0x9A, 0xFF, 0xE0, 0x04, 0x90, 0x88,
+0x52, 0xF0, 0x90, 0x88, 0x51, 0xE0, 0xFF, 0xC3,
+0x94, 0x50, 0x40, 0x0A, 0xEF, 0x24, 0xB0, 0x90,
+0x88, 0x49, 0xF0, 0xE4, 0x80, 0x0E, 0xE4, 0x90,
+0x88, 0x49, 0xF0, 0x90, 0x88, 0x51, 0xE0, 0xFF,
+0xC3, 0x74, 0x50, 0x9F, 0x90, 0x88, 0x48, 0xF0,
+0x90, 0x88, 0x51, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3,
+0x9F, 0x90, 0x88, 0x4F, 0xF0, 0x90, 0x88, 0x31,
+0xE0, 0x90, 0x88, 0x8E, 0xE0, 0x24, 0x08, 0xFF,
+0x90, 0x88, 0x4F, 0xE0, 0x2F, 0xF0, 0x90, 0x88,
+0x4F, 0xE0, 0xC3, 0x94, 0x50, 0x50, 0x03, 0x74,
+0x50, 0xF0, 0x90, 0x88, 0x4F, 0xE0, 0x24, 0x10,
+0xF0, 0x12, 0xF9, 0xB2, 0x74, 0x03, 0xF0, 0x12,
+0x6E, 0x2F, 0x90, 0x8A, 0xA3, 0x12, 0x90, 0x47,
+0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x22, 0x90, 0x9A,
+0xFE, 0xE0, 0xFE, 0x24, 0x0D, 0xF5, 0x82, 0xE4,
+0x34, 0x99, 0xF5, 0x83, 0x22, 0x90, 0x9B, 0x00,
+0x02, 0x04, 0xB8, 0x74, 0x6D, 0x2E, 0xF5, 0x82,
+0xE4, 0x34, 0x98, 0xF5, 0x83, 0x22, 0x12, 0x04,
+0x31, 0x90, 0x88, 0x89, 0x02, 0x04, 0xB8, 0x90,
+0x88, 0x91, 0xE0, 0xFD, 0xC3, 0x90, 0x88, 0x90,
+0xE0, 0x9D, 0xFD, 0x90, 0x88, 0x8F, 0xE0, 0x94,
+0x00, 0xFC, 0xEF, 0xD3, 0x9D, 0xE4, 0x9C, 0x22,
+0x90, 0x88, 0x32, 0xE0, 0xFF, 0x13, 0x13, 0x54,
+0x3F, 0x22, 0x90, 0x88, 0x32, 0xE0, 0xFF, 0x13,
+0x13, 0x13, 0x54, 0x1F, 0x22, 0x91, 0xAA, 0x30,
+0xE0, 0x0B, 0xEF, 0xC4, 0x13, 0x13, 0x54, 0x03,
+0x30, 0xE0, 0x02, 0xB1, 0x27, 0x90, 0x88, 0x31,
+0x91, 0xA3, 0x30, 0xE0, 0x07, 0xEF, 0xF1, 0x68,
+0x70, 0x4C, 0x80, 0x48, 0x90, 0x88, 0x3F, 0xE0,
+0x04, 0xF0, 0x90, 0x88, 0x3A, 0xE0, 0x54, 0xEF,
+0xF0, 0xF1, 0xDF, 0x9F, 0x40, 0x36, 0x12, 0x97,
+0xE0, 0x70, 0x33, 0x12, 0x97, 0xF3, 0x70, 0x08,
+0x90, 0x8A, 0xF5, 0x12, 0x88, 0xC8, 0x80, 0x27,
+0x90, 0x8A, 0xF5, 0x12, 0x88, 0xC8, 0x90, 0x88,
+0x40, 0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94, 0x02,
+0x40, 0x09, 0xB1, 0x1F, 0xE4, 0x90, 0x88, 0x40,
+0xF0, 0x80, 0x03, 0x12, 0x93, 0xD0, 0xE4, 0x90,
+0x88, 0x3F, 0xF0, 0x22, 0xD1, 0x3B, 0x22, 0x90,
+0x88, 0x32, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0x7D,
+0x02, 0x7F, 0x02, 0x02, 0x7C, 0x7E, 0x90, 0x98,
+0x4C, 0x91, 0xA3, 0x30, 0xE0, 0x0A, 0xF1, 0x9A,
+0x12, 0xFA, 0xA2, 0x04, 0xF0, 0x02, 0x8B, 0xEA,
+0x90, 0x8A, 0xAF, 0x12, 0x90, 0x47, 0x7D, 0x08,
+0xE4, 0xFF, 0x02, 0x04, 0x7E, 0xE4, 0xFE, 0x91,
+0x73, 0xE4, 0xF0, 0x74, 0x0D, 0x2E, 0x91, 0x65,
+0x74, 0xFF, 0xF0, 0x0E, 0xEE, 0xB4, 0xA0, 0xEF,
+0xE4, 0x90, 0x88, 0x4D, 0xF0, 0x90, 0x88, 0x4C,
+0xF0, 0x90, 0x88, 0x50, 0xF0, 0xEF, 0xB4, 0x01,
+0x07, 0xA3, 0x74, 0xA0, 0xF0, 0xE4, 0xA3, 0xF0,
+0x22, 0x90, 0x93, 0x04, 0x91, 0xAD, 0x30, 0xE0,
+0x31, 0xEF, 0xC4, 0x54, 0x0F, 0x20, 0xE0, 0x25,
+0xF1, 0xD4, 0x60, 0x0B, 0xF1, 0xCA, 0x40, 0x07,
+0xB1, 0xC1, 0x90, 0x95, 0xF5, 0x80, 0x05, 0xB1,
+0xC1, 0x90, 0x95, 0xED, 0x12, 0x82, 0x12, 0x12,
+0x80, 0xDB, 0x90, 0x9C, 0x9B, 0x12, 0x04, 0x31,
+0x12, 0x95, 0x30, 0x80, 0x05, 0x7F, 0x01, 0x12,
+0xA6, 0xCA, 0x90, 0x93, 0x04, 0xE0, 0xC3, 0x13,
+0x30, 0xE0, 0x05, 0x7F, 0x01, 0x12, 0xA6, 0xCA,
+0x22, 0xE4, 0x7F, 0xE8, 0x7E, 0x03, 0xFD, 0xFC,
+0x22, 0xE4, 0xF5, 0x0F, 0x90, 0x06, 0xA9, 0xE0,
+0xF5, 0x0F, 0x54, 0xC0, 0x70, 0x12, 0xD1, 0x34,
+0xF0, 0x54, 0xFD, 0xF0, 0xD1, 0x3B, 0x90, 0x88,
+0x39, 0xE0, 0x60, 0x4F, 0xF1, 0x82, 0xF0, 0x22,
+0xE5, 0x0F, 0x30, 0xE6, 0x2A, 0x90, 0x88, 0x36,
+0xE0, 0x64, 0x01, 0x70, 0x25, 0x90, 0x88, 0x3A,
+0xE0, 0x44, 0x01, 0xF0, 0x12, 0x97, 0xF3, 0x64,
+0x02, 0x60, 0x0F, 0x90, 0x88, 0x9D, 0xE0, 0x20,
+0xE0, 0x10, 0x90, 0x8A, 0xE1, 0x12, 0x88, 0xC8,
+0x80, 0x08, 0x12, 0x93, 0xD0, 0x80, 0x03, 0xD1,
+0x34, 0xF0, 0xE5, 0x0F, 0x90, 0x88, 0x3A, 0x30,
+0xE7, 0x0D, 0xE0, 0x44, 0x02, 0xD1, 0x4B, 0x90,
+0x88, 0x31, 0xE0, 0x44, 0x04, 0xF0, 0x22, 0xE0,
+0x54, 0xFD, 0xF0, 0x22, 0x90, 0x88, 0x3A, 0xE0,
+0x54, 0xFE, 0x22, 0x90, 0x88, 0x38, 0xE0, 0xFF,
+0x90, 0x8A, 0xB9, 0x12, 0xAC, 0x51, 0x7D, 0x01,
+0x02, 0x04, 0x7E, 0xF0, 0xE4, 0x90, 0x92, 0x20,
+0xF0, 0x90, 0x88, 0x94, 0xE0, 0x90, 0x92, 0x21,
+0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54, 0x7E, 0x01,
+0x02, 0x66, 0x33, 0x12, 0x97, 0xE0, 0x70, 0x11,
+0x90, 0x88, 0x36, 0xE0, 0x60, 0x0B, 0x90, 0x88,
+0x3A, 0xE0, 0x20, 0xE4, 0x04, 0xD1, 0x7A, 0xD1,
+0x4B, 0x22, 0x90, 0x01, 0x57, 0xE4, 0xF0, 0x90,
+0x01, 0x3C, 0x74, 0x02, 0x22, 0x12, 0x97, 0xE0,
+0x70, 0x1A, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x14,
+0x90, 0x88, 0x3A, 0xE0, 0x20, 0xE4, 0x0D, 0xD1,
+0x7A, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0xF1, 0x68,
+0x70, 0x02, 0xD1, 0x3B, 0x22, 0xC0, 0xE0, 0xC0,
+0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
+0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
+0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0xA5, 0xF0,
+0x74, 0xB6, 0xA3, 0xF0, 0x12, 0x64, 0x7F, 0xE5,
+0x30, 0x30, 0xE1, 0x02, 0xF1, 0x5F, 0xE5, 0x2D,
+0x30, 0xE3, 0x03, 0x12, 0xE2, 0x83, 0xE5, 0x2D,
+0x30, 0xE4, 0x03, 0x12, 0xE2, 0x96, 0xE5, 0x2D,
+0x30, 0xE5, 0x03, 0x12, 0xE2, 0xA7, 0xE5, 0x2F,
+0x30, 0xE0, 0x02, 0x31, 0x0B, 0xE5, 0x2F, 0x30,
+0xE1, 0x03, 0x12, 0xAE, 0x02, 0xE5, 0x2F, 0x30,
+0xE2, 0x02, 0xF1, 0x89, 0xE5, 0x2F, 0x30, 0xE3,
+0x02, 0xD1, 0x63, 0xE5, 0x2F, 0x30, 0xE4, 0x02,
+0xD1, 0x85, 0xE5, 0x2F, 0x30, 0xE5, 0x03, 0x12,
+0xDC, 0xF6, 0xE5, 0x2F, 0x30, 0xE6, 0x02, 0xF1,
+0x47, 0x74, 0xA5, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xB6, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
+0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
+0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0xE4,
+0xFF, 0x12, 0x78, 0x4A, 0xBF, 0x01, 0x0F, 0x90,
+0x88, 0x36, 0xE0, 0x60, 0x09, 0xD1, 0x34, 0xF0,
+0x54, 0x07, 0x70, 0x02, 0xD1, 0x3B, 0x22, 0x90,
+0x88, 0x36, 0xE0, 0x60, 0x02, 0xF1, 0x75, 0x22,
+0x54, 0xFB, 0xF0, 0x90, 0x88, 0x3A, 0xE0, 0x54,
+0xFD, 0xF0, 0x54, 0x07, 0x22, 0x90, 0x88, 0x39,
+0xE0, 0xB4, 0x04, 0x03, 0xF1, 0x82, 0xF0, 0x02,
+0x94, 0xFF, 0x90, 0x00, 0x02, 0xE0, 0x44, 0x01,
+0x22, 0x90, 0x98, 0x56, 0xE0, 0x04, 0xF0, 0x90,
+0x88, 0x39, 0xE0, 0x64, 0x02, 0x60, 0x02, 0x31,
+0x1A, 0x22, 0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00,
+0x22, 0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0x74,
+0x90, 0x00, 0x02, 0xE0, 0x54, 0xFE, 0xF0, 0x22,
+0x90, 0x88, 0x3A, 0xE0, 0x44, 0x10, 0xF0, 0x22,
+0x90, 0x93, 0x0A, 0xE0, 0x90, 0x05, 0x73, 0xF0,
+0x22, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x02, 0x91,
+0xB5, 0x22, 0x90, 0x98, 0x31, 0x12, 0x82, 0x12,
+0xD3, 0x02, 0x03, 0xDA, 0x90, 0x95, 0xF1, 0x12,
+0x04, 0xB8, 0xEC, 0x4D, 0x4E, 0x4F, 0x22, 0x90,
+0x88, 0x93, 0xE0, 0xFF, 0x90, 0x88, 0x3F, 0xE0,
+0xD3, 0x22, 0xFF, 0xE4, 0x3E, 0xFE, 0xE4, 0x3D,
+0xFD, 0xE4, 0x3C, 0xFC, 0x22, 0x90, 0x93, 0x0C,
+0xE0, 0x20, 0xE0, 0x03, 0x02, 0xB8, 0xC2, 0xE4,
+0x90, 0x99, 0xB1, 0xF0, 0x90, 0x99, 0xB1, 0xE0,
+0xFF, 0xC3, 0x94, 0x05, 0x40, 0x02, 0x01, 0xC2,
+0x91, 0x0B, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x0D, 0xE0,
+0xFD, 0xEF, 0x5D, 0x60, 0x02, 0x01, 0xBA, 0x12,
+0x02, 0x06, 0xFF, 0x30, 0xE0, 0x1A, 0x90, 0x93,
+0x0E, 0xE0, 0xFE, 0x90, 0x99, 0xB1, 0xE0, 0xFD,
+0x74, 0x01, 0xA8, 0x05, 0x08, 0x80, 0x02, 0xC3,
+0x33, 0xD8, 0xFC, 0x4E, 0x90, 0x93, 0x0E, 0xF0,
+0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x15, 0x90, 0x93,
+0x0F, 0xE0, 0xFF, 0x90, 0x99, 0xB1, 0x11, 0xC9,
+0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0x90,
+0x93, 0x0F, 0xF0, 0x12, 0x9C, 0x5A, 0xFF, 0x90,
+0x99, 0xB1, 0xE0, 0xFE, 0x24, 0x10, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEF, 0x12, 0x87,
+0xE6, 0xFF, 0x74, 0x15, 0x2E, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xEF, 0x12, 0x87, 0xA3,
+0xFF, 0x74, 0x1A, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xF5, 0x83, 0xEF, 0x12, 0x87, 0xD1, 0xFF,
+0x74, 0x1F, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x93,
+0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x93, 0x0D, 0xE0,
+0xFF, 0x74, 0x01, 0xA8, 0x06, 0x08, 0x80, 0x02,
+0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93, 0x0D,
+0xF0, 0x22, 0x90, 0x99, 0xB1, 0xE0, 0x04, 0xF0,
+0x01, 0x04, 0x22, 0x12, 0x7B, 0x41, 0x90, 0x9C,
+0xD7, 0xE0, 0xFE, 0x74, 0x01, 0xA8, 0x06, 0x08,
 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x9C, 0x92, 0xED, 0xF0, 0x90, 0x9C, 0x91,
+0x90, 0x9C, 0xD8, 0xED, 0xF0, 0x90, 0x9C, 0xD7,
 0xEF, 0xF0, 0xD3, 0x94, 0x07, 0x50, 0x42, 0x7F,
-0x47, 0xB1, 0x33, 0x80, 0x02, 0xC3, 0x33, 0xD8,
+0x47, 0x11, 0xC3, 0x80, 0x02, 0xC3, 0x33, 0xD8,
 0xFC, 0xF4, 0x5F, 0xFD, 0x7F, 0x47, 0x12, 0x7B,
-0x2E, 0x7F, 0x46, 0xB1, 0x33, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0x4F, 0xFD, 0x7F, 0x46, 0xF1,
-0xDB, 0x60, 0x0D, 0x7F, 0x45, 0xB1, 0x33, 0x80,
+0x2E, 0x7F, 0x46, 0x11, 0xC3, 0x80, 0x02, 0xC3,
+0x33, 0xD8, 0xFC, 0x4F, 0xFD, 0x7F, 0x46, 0x51,
+0xF6, 0x60, 0x0D, 0x7F, 0x45, 0x11, 0xC3, 0x80,
 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0x80, 0x0C,
-0x7F, 0x45, 0xB1, 0x33, 0x80, 0x02, 0xC3, 0x33,
+0x7F, 0x45, 0x11, 0xC3, 0x80, 0x02, 0xC3, 0x33,
 0xD8, 0xFC, 0xF4, 0x5F, 0xFD, 0x7F, 0x45, 0x80,
-0x4A, 0x90, 0x9C, 0x91, 0xE0, 0x24, 0xF8, 0xF0,
-0x7F, 0x63, 0xB1, 0x33, 0x80, 0x02, 0xC3, 0x33,
+0x4A, 0x90, 0x9C, 0xD7, 0xE0, 0x24, 0xF8, 0xF0,
+0x7F, 0x63, 0x11, 0xC3, 0x80, 0x02, 0xC3, 0x33,
 0xD8, 0xFC, 0xF4, 0x5F, 0xFD, 0x7F, 0x63, 0x12,
-0x7B, 0x2E, 0x7F, 0x62, 0xB1, 0x33, 0x80, 0x02,
+0x7B, 0x2E, 0x7F, 0x62, 0x11, 0xC3, 0x80, 0x02,
 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0xFD, 0x7F, 0x62,
-0xF1, 0xDB, 0x60, 0x10, 0x7F, 0x61, 0xB1, 0x33,
+0x51, 0xF6, 0x60, 0x10, 0x7F, 0x61, 0x11, 0xC3,
 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0xFD,
-0x7F, 0x61, 0x80, 0x0F, 0x7F, 0x61, 0xB1, 0x33,
+0x7F, 0x61, 0x80, 0x0F, 0x7F, 0x61, 0x11, 0xC3,
 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F,
 0xFD, 0x7F, 0x61, 0x12, 0x7B, 0x2E, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x12, 0x7B, 0x41, 0x90, 0x9C,
-0x91, 0xE0, 0xFE, 0x74, 0x01, 0xA8, 0x06, 0x08,
-0x22, 0x90, 0x9C, 0x4E, 0xEE, 0xF0, 0xA3, 0xEF,
-0xF0, 0x90, 0x9C, 0x51, 0xEB, 0xF0, 0x90, 0x9C,
-0x50, 0xED, 0xF0, 0x60, 0x13, 0xF1, 0xD3, 0x78,
-0x03, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
-0xF0, 0xEE, 0x90, 0x9C, 0x4E, 0xF0, 0x80, 0x19,
-0xF1, 0xD3, 0x78, 0x06, 0xC3, 0x33, 0xCE, 0x33,
-0xCE, 0xD8, 0xF9, 0xF0, 0xEE, 0x90, 0x9C, 0x4E,
-0xF0, 0x74, 0xFF, 0x75, 0xF0, 0xD0, 0x12, 0x02,
-0xE7, 0xB1, 0xE4, 0x54, 0x07, 0x7D, 0x00, 0x20,
-0xE0, 0x02, 0x7D, 0x01, 0x91, 0x89, 0xB1, 0xE4,
-0x54, 0x01, 0xFD, 0x91, 0x89, 0x90, 0x9C, 0x52,
-0xE0, 0x60, 0x3B, 0xB1, 0xD7, 0x54, 0x07, 0x7D,
-0x00, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0x91, 0x89,
-0xE4, 0x90, 0x9C, 0x53, 0xF0, 0x90, 0x9C, 0x51,
-0xE0, 0xFF, 0x90, 0x9C, 0x53, 0xE0, 0xC3, 0x9F,
-0x50, 0x1C, 0xB1, 0xD7, 0x54, 0x01, 0xFD, 0x91,
-0x89, 0xB1, 0xD7, 0x54, 0x07, 0x7D, 0x00, 0x20,
-0xE0, 0x02, 0x7D, 0x01, 0x91, 0x89, 0x90, 0x9C,
-0x53, 0xE0, 0x04, 0xF0, 0x80, 0xD7, 0x22, 0x90,
-0x9C, 0x4E, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xA3,
-0xE0, 0xFD, 0xB1, 0xFB, 0x90, 0x93, 0x2A, 0xE0,
-0x54, 0x7F, 0xFF, 0x90, 0x93, 0x29, 0xE0, 0xFE,
-0xC4, 0x13, 0x22, 0x4F, 0xF0, 0x90, 0x00, 0x04,
-0x02, 0x02, 0x1F, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x8E, 0x10, 0x8F, 0x11, 0xBD, 0x01,
-0x05, 0x12, 0x7A, 0xAE, 0x80, 0x07, 0xAF, 0x11,
-0xAE, 0x10, 0x12, 0x7C, 0x6A, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x9C, 0x8B, 0xED, 0xF0, 0xA3, 0xEB,
-0xF0, 0x90, 0x9C, 0x8A, 0xEF, 0xF0, 0xC3, 0x94,
-0x08, 0x40, 0x04, 0xE0, 0x24, 0xF8, 0xF0, 0x7F,
-0x62, 0xD1, 0xB5, 0xB1, 0x39, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0xFD, 0x7F, 0x62,
-0x12, 0x7B, 0x2E, 0x90, 0x9C, 0x8B, 0xE0, 0x60,
-0x3F, 0x7F, 0x63, 0xD1, 0xB5, 0xB1, 0x39, 0x80,
-0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0xFD, 0x7F,
-0x63, 0x12, 0x7B, 0x2E, 0x90, 0x9C, 0x8C, 0xE0,
-0x60, 0x12, 0xF1, 0xEC, 0x08, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0xF4, 0xFF, 0x90, 0x00, 0x49,
-0xE0, 0x5F, 0x80, 0x0F, 0xF1, 0xEC, 0x08, 0x80,
-0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xFF, 0x90, 0x00,
-0x49, 0xE0, 0x4F, 0xFD, 0x7F, 0x49, 0x80, 0x11,
-0x7F, 0x63, 0xD1, 0xB5, 0xB1, 0x39, 0x80, 0x02,
-0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0xFD, 0x7F,
-0x63, 0x12, 0x7B, 0x2E, 0x90, 0x00, 0x4A, 0xE0,
-0x54, 0xF0, 0xFD, 0x7F, 0x4A, 0x12, 0x7B, 0x2E,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0x7B, 0x41,
-0x90, 0x9C, 0x8A, 0x22, 0xF1, 0xE3, 0xFF, 0x54,
-0x7F, 0x90, 0x88, 0x36, 0xF0, 0xEF, 0xF1, 0xB2,
-0xA3, 0x12, 0x87, 0x9C, 0xFD, 0x54, 0xF0, 0xC4,
-0x54, 0x0F, 0xFF, 0x90, 0x88, 0x34, 0xE0, 0x54,
-0xF0, 0x4F, 0xF1, 0xCC, 0xFC, 0x54, 0x01, 0x25,
-0xE0, 0xFF, 0x90, 0x88, 0x31, 0xE0, 0x54, 0xFD,
-0x4F, 0xF0, 0xEC, 0x54, 0x04, 0xC3, 0x13, 0xFF,
-0x90, 0x88, 0x33, 0xE0, 0x54, 0xFD, 0x4F, 0xF0,
-0xED, 0x54, 0x0F, 0xC4, 0x54, 0xF0, 0xFF, 0xA3,
-0xE0, 0x54, 0x0F, 0x4F, 0x12, 0x87, 0xA3, 0x90,
-0x88, 0x35, 0xB1, 0xF4, 0xFD, 0x90, 0x8A, 0x89,
-0xF1, 0x5E, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x90,
-0x9B, 0x5D, 0xE0, 0x60, 0x0B, 0x12, 0xF5, 0x6A,
-0x90, 0x8A, 0x89, 0xF1, 0x5E, 0x12, 0xAF, 0xE3,
-0x31, 0xAD, 0x12, 0x5C, 0x5F, 0x90, 0x88, 0x36,
-0xE0, 0xB4, 0x01, 0x07, 0x90, 0x88, 0x33, 0xE0,
-0x54, 0xFB, 0xF0, 0x12, 0xBF, 0xC1, 0xF0, 0x90,
-0x88, 0x36, 0xF1, 0xF6, 0x12, 0xBF, 0xCB, 0x90,
-0x01, 0xBE, 0xF0, 0x22, 0x90, 0x8A, 0x77, 0xE0,
-0xFE, 0xA3, 0xE0, 0xFF, 0xF5, 0x82, 0x8E, 0x83,
-0x12, 0x04, 0x7E, 0x90, 0x8A, 0x79, 0xE0, 0xFE,
-0xA3, 0xE0, 0xF5, 0x82, 0x8E, 0x83, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9C,
-0x8D, 0xEF, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x8A,
-0xF9, 0xF1, 0x5E, 0x7D, 0x44, 0x7F, 0x6F, 0x12,
-0x04, 0x7E, 0x31, 0xBA, 0x90, 0x9C, 0x8E, 0xE0,
-0x90, 0x9C, 0x8D, 0xB4, 0x01, 0x07, 0xF1, 0xB9,
-0x44, 0x04, 0xF0, 0x80, 0x05, 0xF1, 0xB9, 0x54,
-0xFB, 0xF0, 0x90, 0x8A, 0xF9, 0xF1, 0x5E, 0xE4,
-0xFD, 0xFF, 0x12, 0x04, 0x7E, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x7D, 0x01, 0x80, 0xB9, 0x90, 0x93,
-0x2A, 0xE0, 0xC4, 0x13, 0x13, 0x13, 0x54, 0x01,
-0x22, 0xE0, 0xC4, 0x54, 0xF0, 0x24, 0x05, 0xF5,
-0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE0, 0x22,
-0xE4, 0xFD, 0x80, 0x9B, 0xF0, 0x90, 0x00, 0x03,
-0x02, 0x02, 0x1F, 0x90, 0x9C, 0x4E, 0xE0, 0xFE,
-0xA3, 0xE0, 0x22, 0x12, 0x7B, 0x2E, 0x90, 0x9C,
-0x92, 0xE0, 0x22, 0x90, 0x99, 0x85, 0x12, 0x82,
-0x27, 0x02, 0x02, 0x06, 0x90, 0x9C, 0x8A, 0xE0,
-0xFF, 0x74, 0x01, 0xA8, 0x07, 0x22, 0xE0, 0x90,
-0x01, 0xBA, 0xF0, 0x90, 0x88, 0x38, 0xE0, 0x90,
-0x01, 0xBB, 0xF0, 0x22, 0x12, 0x02, 0x06, 0xFF,
-0x90, 0x93, 0x03, 0xF0, 0xBF, 0x01, 0x07, 0x11,
-0x17, 0xE4, 0x90, 0x93, 0x03, 0xF0, 0x22, 0x11,
-0xC3, 0x7F, 0xEF, 0x7E, 0x01, 0x12, 0x5F, 0xA6,
-0xBF, 0x01, 0x06, 0x90, 0x99, 0x85, 0xE0, 0xA3,
-0xF0, 0x11, 0xC3, 0x7F, 0xEE, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99, 0x85,
-0xE0, 0x90, 0x99, 0x87, 0xF0, 0x11, 0xC3, 0x7F,
-0xED, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
-0x08, 0x90, 0x99, 0x85, 0xE0, 0x90, 0x99, 0x88,
-0xF0, 0x11, 0xC3, 0x7F, 0xEC, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99, 0x85,
-0xE0, 0x90, 0x99, 0x89, 0xF0, 0x11, 0xC3, 0x7F,
-0xEB, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF, 0x01,
-0x08, 0x90, 0x99, 0x85, 0xE0, 0x90, 0x99, 0x8A,
-0xF0, 0x90, 0x99, 0x86, 0xE0, 0xFF, 0xA3, 0xE0,
-0xFD, 0xA3, 0xE0, 0xFB, 0xA3, 0xE0, 0x90, 0x99,
-0x8E, 0xF0, 0x90, 0x99, 0x8A, 0xE0, 0x90, 0x99,
-0x8F, 0xF0, 0x90, 0x99, 0x90, 0x74, 0x12, 0xF0,
-0x90, 0x99, 0xB2, 0x74, 0x05, 0xF0, 0x90, 0x99,
-0x92, 0xEF, 0xF1, 0xE6, 0x90, 0x99, 0x8E, 0xE0,
-0x90, 0x99, 0x95, 0xF0, 0x90, 0x99, 0x8F, 0xE0,
-0x90, 0x99, 0x96, 0xF0, 0x7B, 0x01, 0x7A, 0x99,
-0x79, 0x90, 0x12, 0x97, 0x4C, 0x7F, 0x04, 0x02,
-0x04, 0x7E, 0xF0, 0x7B, 0x01, 0x7A, 0x99, 0x79,
-0x85, 0x22, 0x7E, 0x00, 0x7F, 0x0B, 0x7D, 0x00,
-0x7B, 0x01, 0x7A, 0x98, 0x79, 0x2D, 0x12, 0x04,
-0x80, 0x11, 0xC3, 0x71, 0xB5, 0xBF, 0x01, 0x1C,
-0x90, 0x99, 0x85, 0xE0, 0xFE, 0x54, 0x01, 0x90,
-0x98, 0x2D, 0xF0, 0xEE, 0x54, 0x04, 0x90, 0x98,
-0x2F, 0xF0, 0x90, 0x99, 0x85, 0xE0, 0x54, 0x08,
-0x90, 0x98, 0x2E, 0xF0, 0x11, 0xC3, 0x31, 0x54,
-0x64, 0x01, 0x70, 0x35, 0x90, 0x99, 0x85, 0xE0,
-0x54, 0x07, 0x70, 0x15, 0x7B, 0x01, 0x7A, 0x99,
-0x79, 0x86, 0x7F, 0xFA, 0x7E, 0x01, 0x12, 0x5F,
-0xA6, 0xBF, 0x01, 0x0F, 0x90, 0x99, 0x86, 0x80,
-0x03, 0x90, 0x99, 0x85, 0xE0, 0x54, 0x07, 0x90,
-0x98, 0x31, 0xF0, 0x90, 0x99, 0x85, 0xE0, 0x54,
-0xE0, 0xC4, 0x13, 0x54, 0x07, 0x90, 0x98, 0x30,
-0xF0, 0x11, 0xC3, 0x7F, 0xFD, 0x7E, 0x01, 0x12,
-0x5F, 0xA6, 0xBF, 0x01, 0x0E, 0x90, 0x99, 0x85,
-0xE0, 0x54, 0x0C, 0x13, 0x13, 0x54, 0x3F, 0x90,
-0x98, 0x32, 0xF0, 0x22, 0x7F, 0xFB, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xEF, 0x22, 0x90, 0x99, 0x85,
-0xEF, 0xF0, 0x71, 0xAE, 0x7F, 0xF4, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99,
-0xCC, 0xE0, 0x90, 0x99, 0xCE, 0xF0, 0x71, 0xAE,
-0x7F, 0xF5, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
-0x01, 0x08, 0x90, 0x99, 0xCC, 0xE0, 0x90, 0x99,
-0xCF, 0xF0, 0x71, 0xAE, 0x7F, 0xF6, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99,
-0xCC, 0xE0, 0x90, 0x99, 0xD0, 0xF0, 0x71, 0xAE,
-0x7F, 0xF7, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
-0x01, 0x08, 0x90, 0x99, 0xCC, 0xE0, 0x90, 0x99,
-0xD1, 0xF0, 0x71, 0xAE, 0x7F, 0xF8, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99,
-0xCC, 0xE0, 0x90, 0x99, 0xD2, 0xF0, 0x71, 0xAE,
-0x71, 0xB5, 0xBF, 0x01, 0x08, 0x90, 0x99, 0xCC,
-0xE0, 0x90, 0x99, 0xD3, 0xF0, 0x71, 0xAE, 0x31,
-0x54, 0x64, 0x01, 0x70, 0x54, 0x90, 0x99, 0xCC,
-0xE0, 0x90, 0x99, 0xD4, 0xF0, 0x54, 0x07, 0x60,
-0x08, 0x90, 0x99, 0xCC, 0xE0, 0x54, 0xE0, 0x70,
-0x40, 0x7B, 0x01, 0x7A, 0x99, 0x79, 0xCD, 0x7F,
-0xFA, 0x31, 0x56, 0x64, 0x01, 0x70, 0x32, 0x90,
-0x99, 0xCC, 0xE0, 0xFC, 0x54, 0x07, 0x70, 0x12,
-0x90, 0x99, 0xD4, 0xE0, 0xFE, 0x90, 0x99, 0xCD,
-0xE0, 0x54, 0x07, 0xFD, 0xEE, 0x4D, 0x90, 0x99,
-0xD4, 0xF0, 0xEC, 0x54, 0xE0, 0x70, 0x12, 0x90,
-0x99, 0xD4, 0xE0, 0xFF, 0x90, 0x99, 0xCD, 0xE0,
-0x54, 0xE0, 0xFE, 0xEF, 0x4E, 0x90, 0x99, 0xD4,
-0xF0, 0x71, 0xAE, 0x7F, 0xFD, 0x31, 0x56, 0x64,
-0x01, 0x70, 0x4B, 0x90, 0x99, 0xCC, 0xE0, 0xFE,
-0x54, 0xCC, 0x90, 0x99, 0xD5, 0xF0, 0xEE, 0x54,
-0x0C, 0xFF, 0x60, 0x08, 0x90, 0x99, 0xCC, 0xE0,
-0x54, 0xC0, 0x70, 0x32, 0xEF, 0x70, 0x16, 0x90,
-0x99, 0xD5, 0xE0, 0xFF, 0x90, 0x99, 0xCC, 0xE0,
-0x54, 0x03, 0x25, 0xE0, 0x25, 0xE0, 0xFE, 0xEF,
-0x4E, 0x90, 0x99, 0xD5, 0xF0, 0x90, 0x99, 0xCC,
-0xE0, 0xFF, 0x54, 0xC0, 0x70, 0x10, 0x90, 0x99,
-0xD5, 0xE0, 0xFE, 0xEF, 0x54, 0x30, 0x25, 0xE0,
-0x25, 0xE0, 0xFF, 0xEE, 0x4F, 0xF0, 0x71, 0xAE,
-0x7F, 0xF0, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
-0x01, 0x08, 0x90, 0x99, 0xCC, 0xE0, 0x90, 0x99,
-0xD6, 0xF0, 0x71, 0xAE, 0x7F, 0xF1, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99,
-0xCC, 0xE0, 0x90, 0x99, 0xD7, 0xF0, 0x71, 0xAE,
-0x7F, 0xF2, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
-0x01, 0x08, 0x90, 0x99, 0xCC, 0xE0, 0x90, 0x99,
-0xD8, 0xF0, 0x71, 0xAE, 0x7F, 0xF3, 0x7E, 0x01,
-0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x08, 0x90, 0x99,
-0xCC, 0xE0, 0x90, 0x99, 0xD9, 0xF0, 0x71, 0xAE,
-0x7F, 0xFC, 0x7E, 0x01, 0x12, 0x5F, 0xA6, 0xBF,
-0x01, 0x08, 0x90, 0x99, 0xCC, 0xE0, 0x90, 0x99,
-0xDA, 0xF0, 0x90, 0x99, 0x86, 0x74, 0x19, 0xF0,
-0x90, 0x99, 0xA8, 0x74, 0x08, 0xF0, 0x90, 0x99,
-0xCE, 0xE0, 0x90, 0x99, 0x88, 0xF0, 0x90, 0x99,
-0xCF, 0xE0, 0x90, 0x99, 0x89, 0xF0, 0x90, 0x99,
-0xD0, 0xE0, 0x90, 0x99, 0x8A, 0xF0, 0x90, 0x99,
-0xD1, 0xE0, 0x90, 0x99, 0x8B, 0xF0, 0x90, 0x99,
-0xD2, 0xE0, 0x90, 0x99, 0x8C, 0xF0, 0x90, 0x99,
-0xD3, 0xE0, 0x90, 0x99, 0x8D, 0xF0, 0x90, 0x99,
-0xD4, 0xE0, 0x90, 0x99, 0x8E, 0xF0, 0x90, 0x99,
-0xD5, 0xE0, 0x90, 0x99, 0x8F, 0xF0, 0x90, 0x99,
-0xA9, 0x74, 0x1A, 0xF0, 0x90, 0x99, 0xCB, 0x74,
-0x05, 0xF0, 0x90, 0x99, 0xD6, 0xE0, 0x90, 0x99,
-0xAB, 0xF0, 0x90, 0x99, 0xD7, 0xE0, 0x90, 0x99,
-0xAC, 0xF0, 0x90, 0x99, 0xD8, 0xE0, 0x90, 0x99,
-0xAD, 0xF0, 0x90, 0x99, 0xD9, 0xE0, 0x90, 0x99,
-0xAE, 0xF0, 0x90, 0x99, 0xDA, 0xE0, 0x90, 0x99,
-0xAF, 0xF0, 0x90, 0x99, 0x85, 0xE0, 0xB4, 0x01,
-0x17, 0x7B, 0x01, 0x7A, 0x99, 0x79, 0x86, 0x12,
-0xB2, 0x1A, 0x7B, 0x01, 0x7A, 0x99, 0x79, 0xA9,
-0x12, 0x97, 0x4C, 0x7F, 0x04, 0x02, 0x04, 0x7E,
-0x75, 0x45, 0x01, 0x75, 0x46, 0x99, 0x75, 0x47,
-0x86, 0x75, 0x48, 0x0A, 0x7B, 0x01, 0x7A, 0x01,
-0x79, 0xA0, 0xF1, 0xDF, 0x75, 0x46, 0x99, 0x75,
-0x47, 0xAB, 0x75, 0x48, 0x05, 0x7B, 0x01, 0x7A,
-0x01, 0x79, 0xAA, 0x02, 0x69, 0xF5, 0x7B, 0x01,
-0x7A, 0x99, 0x79, 0xCC, 0x22, 0x7F, 0xF9, 0x7E,
-0x01, 0x02, 0x5F, 0xA6, 0x12, 0x02, 0x06, 0x90,
-0x99, 0xA8, 0x12, 0x87, 0x9C, 0x90, 0x99, 0xA9,
-0xF0, 0x60, 0x0E, 0x91, 0x06, 0x12, 0xB0, 0x08,
-0x90, 0x99, 0xA9, 0x91, 0x06, 0x7B, 0x57, 0x91,
-0x0E, 0x90, 0x99, 0x85, 0x74, 0x20, 0xF0, 0x90,
-0x99, 0xA7, 0x74, 0x03, 0xF0, 0x90, 0x05, 0x22,
-0xE0, 0x90, 0x99, 0x87, 0xF0, 0x90, 0x98, 0x3E,
-0xE0, 0x90, 0x99, 0x88, 0xF0, 0x90, 0x98, 0x3F,
-0xE0, 0x90, 0x99, 0x89, 0x11, 0xC2, 0x12, 0x97,
-0x4C, 0x7F, 0x04, 0x02, 0x04, 0x7E, 0xE0, 0xFF,
-0x90, 0x99, 0xA8, 0xE0, 0xFD, 0x22, 0xEB, 0xB4,
-0x57, 0x04, 0xF1, 0xAF, 0x80, 0x0F, 0xEF, 0x70,
-0x07, 0x90, 0x98, 0x3E, 0xE0, 0x4D, 0x80, 0x05,
-0x12, 0xB0, 0x20, 0xF1, 0xAF, 0x90, 0x05, 0x22,
-0xF0, 0x90, 0x93, 0x01, 0xEB, 0xF0, 0x22, 0x90,
-0x9A, 0x35, 0x12, 0x82, 0x27, 0x90, 0x05, 0x22,
-0xE0, 0x90, 0x9A, 0x46, 0xF0, 0x90, 0x04, 0x1D,
-0xE0, 0x60, 0x0C, 0x7B, 0x39, 0x12, 0x91, 0xB3,
-0xEF, 0x64, 0x01, 0x70, 0x16, 0x80, 0x00, 0x90,
-0x98, 0x0D, 0xE0, 0xFF, 0x90, 0x92, 0x13, 0x74,
-0x11, 0xF1, 0xBA, 0x90, 0x9A, 0x43, 0xEE, 0xF0,
-0xA3, 0xEF, 0xF0, 0x90, 0x9A, 0x43, 0x12, 0xE4,
-0xFD, 0x90, 0x9A, 0x45, 0xEF, 0xF0, 0x90, 0x9A,
-0x43, 0xF1, 0xC2, 0x90, 0x9A, 0x41, 0xE0, 0xFD,
-0x12, 0xE2, 0xF7, 0x90, 0x9A, 0x42, 0xE0, 0x60,
-0x02, 0xA1, 0x0A, 0xF1, 0x0E, 0xC0, 0x03, 0xC0,
-0x02, 0xC0, 0x01, 0x90, 0x9A, 0x38, 0xF1, 0x04,
-0x75, 0x48, 0x06, 0xD0, 0x01, 0xD0, 0x02, 0xD0,
-0x03, 0xB1, 0xBF, 0xF1, 0xA5, 0xC0, 0x03, 0xC0,
-0x02, 0xC0, 0x01, 0x90, 0x9A, 0x35, 0xF1, 0x04,
-0x75, 0x48, 0x10, 0xD0, 0x01, 0xD0, 0x02, 0xD0,
-0x03, 0xB1, 0xBF, 0xF1, 0x11, 0xC0, 0x03, 0xC0,
-0x02, 0xC0, 0x01, 0x90, 0x9A, 0x3B, 0xF1, 0x04,
-0x75, 0x48, 0x10, 0xD0, 0x01, 0xD0, 0x02, 0xD0,
-0x03, 0xB1, 0xBF, 0x24, 0x60, 0xF9, 0xE4, 0x34,
-0xFC, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02,
-0xC0, 0x01, 0x90, 0x9A, 0x3B, 0xF1, 0x04, 0x75,
-0x48, 0x10, 0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03,
-0xB1, 0xBF, 0x24, 0x72, 0xF9, 0xE4, 0x34, 0xFC,
-0xFA, 0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x02, 0xC0,
-0x01, 0x90, 0x9A, 0x3E, 0xF1, 0x04, 0x75, 0x48,
-0x06, 0xD0, 0x01, 0xD0, 0x02, 0xD0, 0x03, 0x12,
-0x69, 0xF5, 0x90, 0x9A, 0x3B, 0x12, 0x82, 0x1E,
-0x90, 0x9A, 0x72, 0x12, 0x82, 0x27, 0x90, 0x9A,
-0x75, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x20,
-0x90, 0x9A, 0x79, 0x74, 0x3A, 0xF0, 0x90, 0x9A,
-0x35, 0x12, 0x82, 0x1E, 0x12, 0xE8, 0x25, 0xB1,
-0xC2, 0xF1, 0x9E, 0xF1, 0x88, 0x75, 0x48, 0x28,
-0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x47, 0xB1, 0xBF,
-0xF1, 0x9E, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0x8B,
-0x45, 0x75, 0x46, 0x93, 0x75, 0x47, 0xD1, 0x75,
-0x48, 0x28, 0xD0, 0x03, 0x12, 0x69, 0xF5, 0x90,
-0x9A, 0x45, 0xE0, 0xFF, 0x90, 0x9A, 0x44, 0xE0,
-0x2F, 0xFF, 0x90, 0x9A, 0x43, 0xE0, 0x34, 0x00,
-0xCF, 0x24, 0x30, 0xFD, 0xE4, 0x3F, 0xFC, 0x90,
-0x98, 0x0D, 0xE0, 0xFB, 0x7F, 0x3A, 0x12, 0xE5,
-0xD6, 0xB1, 0xC2, 0xF1, 0x9E, 0xFA, 0x7B, 0x01,
-0xC0, 0x03, 0x8B, 0x45, 0x75, 0x46, 0x9A, 0x75,
-0x47, 0x47, 0x75, 0x48, 0x28, 0xD0, 0x03, 0x12,
-0x69, 0xF5, 0x90, 0x98, 0x09, 0xE0, 0xB4, 0x02,
-0x0D, 0x90, 0x98, 0x0D, 0xE0, 0xFF, 0x90, 0x9A,
-0x45, 0xE0, 0xFD, 0x12, 0xCD, 0xE9, 0x90, 0x06,
-0x33, 0xE0, 0x44, 0x02, 0xF0, 0x90, 0x9A, 0x46,
-0xE0, 0xFD, 0x7B, 0x3A, 0xE4, 0xFF, 0x91, 0x0E,
-0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0, 0x22, 0x12,
-0x69, 0xF5, 0x90, 0x9A, 0x43, 0xA3, 0xE0, 0xFF,
-0xA3, 0xE0, 0x2F, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x9C, 0x0B, 0x12, 0x82,
-0x27, 0x78, 0x17, 0x7C, 0x9C, 0x7D, 0x01, 0x7B,
-0xFF, 0x7A, 0x80, 0x79, 0x8E, 0x7E, 0x00, 0x7F,
-0x06, 0x12, 0x01, 0xE0, 0x90, 0x05, 0x22, 0xE0,
-0x90, 0x9C, 0x16, 0xF0, 0x90, 0x04, 0x1D, 0xE0,
-0x60, 0x0C, 0x7B, 0x33, 0x12, 0x91, 0xB3, 0xEF,
-0x64, 0x01, 0x70, 0x16, 0x80, 0x00, 0x90, 0x98,
-0x0C, 0xE0, 0xFF, 0x90, 0x92, 0x13, 0x74, 0x10,
-0xF1, 0xBA, 0x90, 0x9C, 0x13, 0xEE, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x9C, 0x13, 0x12, 0xE4, 0xFD,
-0x90, 0x9C, 0x15, 0xEF, 0xF0, 0x90, 0x9C, 0x13,
-0xF1, 0xC2, 0x90, 0x9C, 0x11, 0xE0, 0xFD, 0x12,
-0xE2, 0xF7, 0x90, 0x9C, 0x12, 0xE0, 0x70, 0x4F,
-0xF1, 0x0E, 0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01,
-0xF1, 0x01, 0x75, 0x48, 0x06, 0xD0, 0x01, 0xD0,
-0x02, 0xD0, 0x03, 0x12, 0x69, 0xF5, 0x90, 0x9C,
-0x13, 0xB1, 0xC5, 0xF1, 0x97, 0xFA, 0x7B, 0x01,
-0xC0, 0x03, 0xC0, 0x02, 0xC0, 0x01, 0xF1, 0x01,
-0x75, 0x48, 0x06, 0xD0, 0x01, 0xD0, 0x02, 0xD0,
-0x03, 0x12, 0x69, 0xF5, 0x90, 0x9C, 0x13, 0xB1,
-0xC5, 0xF1, 0xA5, 0xC0, 0x03, 0xC0, 0x02, 0xC0,
-0x01, 0x90, 0x9C, 0x0B, 0xF1, 0x04, 0x75, 0x48,
-0x04, 0xD0, 0x01, 0xD0, 0x02, 0x80, 0x4C, 0x90,
-0x9C, 0x12, 0xE0, 0x64, 0x01, 0x70, 0x49, 0xF1,
-0x0E, 0xC0, 0x03, 0x8B, 0x45, 0x75, 0x46, 0x93,
-0x75, 0x47, 0x4D, 0x75, 0x48, 0x06, 0xD0, 0x03,
-0x12, 0x69, 0xF5, 0x90, 0x9C, 0x13, 0xB1, 0xC5,
-0xF1, 0x97, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0x8B,
-0x45, 0x75, 0x46, 0x93, 0x75, 0x47, 0x57, 0x75,
-0x48, 0x06, 0xD0, 0x03, 0x12, 0x69, 0xF5, 0x90,
-0x9C, 0x13, 0xB1, 0xC5, 0xF1, 0xA5, 0xC0, 0x03,
-0x8B, 0x45, 0x75, 0x46, 0x93, 0x75, 0x47, 0x5D,
-0x75, 0x48, 0x04, 0xD0, 0x03, 0x12, 0x69, 0xF5,
-0x90, 0x98, 0x09, 0xE0, 0xB4, 0x02, 0x0D, 0x90,
-0x98, 0x0C, 0xE0, 0xFF, 0x90, 0x9C, 0x15, 0xE0,
-0xFD, 0x12, 0xCD, 0xE9, 0x90, 0x06, 0x30, 0xE0,
-0x44, 0x10, 0xF0, 0x90, 0x9C, 0x16, 0xE0, 0xFD,
-0x7B, 0x34, 0xB1, 0xB4, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x90, 0x9C, 0x0E, 0x12, 0x82, 0x1E, 0x8B,
-0x45, 0x8A, 0x46, 0x89, 0x47, 0x22, 0xA3, 0xA3,
-0xE0, 0x24, 0x38, 0xF9, 0xE4, 0x34, 0xFC, 0xFA,
-0x7B, 0x01, 0x22, 0xF1, 0xF0, 0xE4, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x99, 0x85, 0x12, 0xE4, 0xFD,
-0x90, 0x99, 0x87, 0xEF, 0xF0, 0x90, 0x99, 0x85,
-0xA3, 0xE0, 0x24, 0x38, 0xF9, 0xE4, 0x34, 0xFC,
-0xF1, 0x88, 0x75, 0x48, 0x06, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x4D, 0xF1, 0x90, 0xB1, 0xC5, 0x24,
-0x3E, 0xF9, 0xE4, 0x34, 0xFC, 0xF1, 0x88, 0x75,
-0x48, 0x04, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0x53,
-0xF1, 0x90, 0xB1, 0xC5, 0xF1, 0x97, 0xF1, 0x88,
-0x75, 0x48, 0x06, 0x7B, 0x01, 0x7A, 0x93, 0x79,
-0x57, 0xF1, 0x90, 0xB1, 0xC5, 0x24, 0x48, 0xF9,
-0xE4, 0x34, 0xFC, 0xF1, 0x88, 0x75, 0x48, 0x04,
-0x7B, 0x01, 0x7A, 0x93, 0x79, 0x5D, 0x02, 0x69,
-0xF5, 0xE0, 0x24, 0x00, 0xF9, 0xE4, 0x34, 0xFC,
-0x75, 0x45, 0x01, 0xF5, 0x46, 0x89, 0x47, 0x22,
-0x12, 0x69, 0xF5, 0x90, 0x99, 0x85, 0x22, 0x24,
-0x42, 0xF9, 0xE4, 0x34, 0xFC, 0x22, 0x24, 0x30,
-0xF9, 0xE4, 0x34, 0xFC, 0x22, 0x24, 0x48, 0xF9,
-0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01, 0x22, 0x90,
-0x98, 0x3F, 0xE0, 0xFF, 0x90, 0x98, 0x3E, 0xE0,
-0x4F, 0x22, 0xF0, 0x7B, 0x18, 0x7D, 0x01, 0x02,
-0x66, 0xDB, 0xA3, 0xE0, 0x24, 0x28, 0xF9, 0xE4,
-0x34, 0xFC, 0xFA, 0x7B, 0x01, 0x22, 0x12, 0xDF,
-0xCC, 0xF1, 0x84, 0x75, 0x48, 0x70, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0x61, 0x02, 0x69, 0xF5, 0x12,
-0x69, 0xF5, 0x75, 0x45, 0x01, 0x22, 0xF0, 0xA3,
-0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x22, 0xE0, 0xFF,
-0x12, 0x7B, 0x07, 0x90, 0x99, 0x85, 0x22, 0x12,
-0x02, 0x06, 0x54, 0x01, 0xFF, 0x90, 0x98, 0x3D,
-0xE0, 0x54, 0xFE, 0x4F, 0xF0, 0x22, 0x12, 0x02,
-0x06, 0x90, 0x88, 0x9C, 0xF0, 0x22, 0x90, 0x93,
-0x0C, 0xE0, 0x20, 0xE0, 0x02, 0x01, 0xDB, 0xE4,
-0x90, 0x99, 0x85, 0xF0, 0x90, 0x99, 0x85, 0xE0,
-0xFF, 0xC3, 0x94, 0x05, 0x40, 0x02, 0x01, 0xDB,
-0x11, 0xDE, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
-0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x0D, 0xE0,
-0xFD, 0xEF, 0x5D, 0x60, 0x02, 0x01, 0xD3, 0x12,
-0x02, 0x06, 0xFF, 0x30, 0xE0, 0x1A, 0x90, 0x93,
-0x0E, 0xE0, 0xFE, 0x90, 0x99, 0x85, 0xE0, 0xFD,
-0x74, 0x01, 0xA8, 0x05, 0x08, 0x80, 0x02, 0xC3,
-0x33, 0xD8, 0xFC, 0x4E, 0x90, 0x93, 0x0E, 0xF0,
-0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x16, 0x90, 0x93,
-0x0F, 0xE0, 0xFF, 0x90, 0x99, 0x85, 0x12, 0x95,
-0x39, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F,
-0x90, 0x93, 0x0F, 0xF0, 0x12, 0x87, 0x9D, 0xFF,
-0x90, 0x99, 0x85, 0xE0, 0xFE, 0x24, 0x10, 0xF5,
-0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEF, 0x12,
-0x87, 0xA3, 0xFF, 0x74, 0x15, 0x2E, 0xF5, 0x82,
-0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEF, 0x12, 0x97,
-0xCC, 0xFF, 0x74, 0x1A, 0x2E, 0xF5, 0x82, 0xE4,
-0x34, 0x93, 0xF5, 0x83, 0xEF, 0x12, 0x95, 0xF4,
-0xFF, 0x74, 0x1F, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0x93, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x93, 0x0D,
-0xE0, 0xFF, 0x74, 0x01, 0xA8, 0x06, 0x08, 0x80,
-0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F, 0x90, 0x93,
-0x0D, 0xF0, 0x22, 0x90, 0x99, 0x85, 0xE0, 0x04,
-0xF0, 0x01, 0x1C, 0x22, 0xE0, 0xFF, 0x74, 0x01,
-0x7E, 0x00, 0xA8, 0x07, 0x08, 0x22, 0x12, 0x8F,
-0xE5, 0xA3, 0xED, 0xF0, 0x90, 0x98, 0x1B, 0xE0,
-0xFF, 0x12, 0x7B, 0x07, 0x90, 0x9A, 0x0B, 0xE4,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0xFD, 0x10, 0xE0,
-0x90, 0x9A, 0x0B, 0x75, 0xF0, 0x00, 0x12, 0x02,
-0xE7, 0xE4, 0x90, 0x9A, 0x15, 0xF0, 0x90, 0x93,
-0x27, 0xE0, 0x54, 0x07, 0xFF, 0x90, 0x9A, 0x15,
-0xE0, 0xC3, 0x9F, 0x40, 0x02, 0x41, 0x81, 0x90,
-0x9A, 0x09, 0xE0, 0x24, 0x04, 0xFE, 0x12, 0x8D,
-0x89, 0x90, 0x9A, 0x0D, 0xF0, 0xA3, 0xCE, 0xF0,
-0x90, 0x9A, 0x0C, 0xE0, 0x24, 0x01, 0xFF, 0x90,
-0x9A, 0x0B, 0xD1, 0xE5, 0x7F, 0x00, 0xFE, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x9A, 0x0B, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x12, 0x7A, 0x7E, 0xEF, 0xFD,
-0xD0, 0xE0, 0x2D, 0xFF, 0xD0, 0xE0, 0x34, 0x00,
-0xFE, 0x90, 0x9A, 0x0F, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x9A, 0x0C, 0xE0, 0x24, 0x02, 0xFD, 0x90,
-0x9A, 0x0B, 0xE0, 0x34, 0x00, 0xFC, 0x90, 0x9A,
-0x13, 0xF0, 0xA3, 0xED, 0xF0, 0x2F, 0x12, 0xF5,
-0x38, 0x90, 0x9A, 0x18, 0x74, 0x01, 0xF0, 0xE4,
-0x90, 0x9A, 0x17, 0xF0, 0x90, 0x9A, 0x17, 0xE0,
-0xFF, 0xFD, 0xD3, 0x90, 0x9A, 0x10, 0xE0, 0x9D,
-0x90, 0x9A, 0x0F, 0xE0, 0x94, 0x00, 0x50, 0x02,
-0x41, 0x4F, 0xEF, 0xB4, 0x12, 0x08, 0x12, 0x8D,
-0x7E, 0xCF, 0x24, 0x06, 0xF1, 0x90, 0x90, 0x9A,
-0x17, 0xE0, 0x75, 0xF0, 0x02, 0xA4, 0xFD, 0xAC,
-0xF0, 0xAE, 0x04, 0x78, 0x03, 0xCE, 0xA2, 0xE7,
-0x13, 0xCE, 0x13, 0xD8, 0xF8, 0xFF, 0xED, 0x54,
-0x07, 0x90, 0x9A, 0x16, 0xF0, 0x90, 0x9A, 0x12,
-0xE0, 0x2F, 0x12, 0x8D, 0x6B, 0xFE, 0x12, 0x7A,
-0x7E, 0x90, 0x9A, 0x19, 0xEF, 0xF0, 0xFD, 0x90,
-0x9A, 0x16, 0x11, 0xDC, 0x80, 0x05, 0xC3, 0x33,
-0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xEF, 0x5D,
-0x6F, 0x70, 0x01, 0xEE, 0x70, 0x16, 0xD1, 0xD7,
-0x54, 0x0F, 0xFF, 0xC0, 0x07, 0xD1, 0xF5, 0x12,
-0x8B, 0xE8, 0xEF, 0x54, 0x0F, 0xD0, 0x07, 0x6F,
-0x60, 0x02, 0x80, 0x32, 0x90, 0x9A, 0x16, 0xE0,
-0x04, 0x11, 0xDD, 0x80, 0x05, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x9A, 0x19,
-0xE0, 0xFD, 0xEF, 0x5D, 0x6F, 0x70, 0x01, 0xEE,
-0x70, 0x1B, 0xD1, 0xD7, 0x54, 0xF0, 0xFF, 0xC0,
-0x07, 0xD1, 0xF5, 0x12, 0x8B, 0xE8, 0xEF, 0x54,
-0xF0, 0xD0, 0x07, 0x6F, 0x60, 0x07, 0xE4, 0x90,
-0x9A, 0x18, 0xF0, 0x80, 0x12, 0x90, 0x9A, 0x0D,
-0xE4, 0x75, 0xF0, 0x01, 0x12, 0x02, 0xE7, 0x90,
-0x9A, 0x17, 0xE0, 0x04, 0xF0, 0x21, 0x84, 0x90,
-0x9A, 0x18, 0xE0, 0xB4, 0x01, 0x03, 0x7F, 0x01,
-0x22, 0x90, 0x9A, 0x10, 0xE0, 0x24, 0x03, 0xF1,
-0x75, 0xEF, 0x78, 0x02, 0xCE, 0xC3, 0x13, 0xCE,
-0x13, 0xD8, 0xF9, 0xFF, 0x90, 0x9A, 0x12, 0xE0,
-0x2F, 0xFF, 0x90, 0x9A, 0x11, 0xE0, 0x3E, 0xF1,
-0x6D, 0x90, 0x9A, 0x15, 0xE0, 0x04, 0xF0, 0x21,
-0x0E, 0x7F, 0x00, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0xE4, 0x90, 0x9B, 0xDB, 0xF0,
-0xA3, 0xF0, 0xA3, 0x74, 0x08, 0xF0, 0xA3, 0xF1,
-0xDE, 0x90, 0x9B, 0xE3, 0xF0, 0xA3, 0xF0, 0xA3,
-0xF0, 0x90, 0x01, 0xC4, 0x74, 0x84, 0xF0, 0x74,
-0xA2, 0xA3, 0x12, 0xD7, 0x84, 0x12, 0xCF, 0x24,
-0x90, 0x9B, 0xD1, 0x12, 0xE0, 0xF0, 0x90, 0x9B,
-0xDA, 0xF0, 0x90, 0x93, 0x24, 0xE0, 0x20, 0xE0,
-0x02, 0xA1, 0xF1, 0xE4, 0x90, 0x9B, 0xD9, 0xF0,
-0x90, 0x9B, 0xDA, 0xE0, 0xFF, 0x90, 0x9B, 0xD9,
-0xE0, 0xC3, 0x9F, 0x40, 0x02, 0xA1, 0xF1, 0xF1,
-0x7E, 0xEC, 0xFF, 0x90, 0xFD, 0x11, 0xF0, 0x90,
-0x9B, 0xE3, 0xEF, 0xF0, 0x12, 0xD7, 0xA3, 0x3E,
-0x54, 0x3F, 0xFE, 0x90, 0x9B, 0xD3, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x9B, 0xDF, 0xEE, 0x12, 0xE1,
-0x3D, 0x30, 0xE0, 0x0A, 0xC3, 0x13, 0x20, 0xE0,
-0x05, 0x12, 0xE1, 0x08, 0x80, 0x02, 0x7E, 0x00,
-0xEF, 0x24, 0x18, 0x2E, 0xFF, 0x90, 0x9B, 0xE4,
-0xF0, 0x90, 0x9B, 0xD2, 0xE0, 0x2F, 0xFF, 0x90,
-0x9B, 0xD1, 0xE0, 0x34, 0x00, 0xFE, 0x90, 0x9B,
-0xD5, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x8B, 0xE8,
-0xC0, 0x07, 0x90, 0x9B, 0xD5, 0xD1, 0x12, 0x7D,
-0x01, 0x12, 0x04, 0x7E, 0xC0, 0x07, 0x90, 0x9B,
-0xD5, 0xD1, 0x12, 0x7D, 0x04, 0x12, 0x04, 0x7E,
-0xAB, 0x07, 0xD0, 0x05, 0xD0, 0x07, 0x12, 0xE5,
-0x23, 0x90, 0x9B, 0xDB, 0xEF, 0xD1, 0xC3, 0x12,
-0x8B, 0xE8, 0xEF, 0x54, 0xFC, 0x90, 0x9B, 0xD7,
-0xF0, 0x90, 0x9B, 0xE4, 0xE0, 0xFF, 0x90, 0x9B,
-0xD3, 0xE4, 0x8F, 0xF0, 0x12, 0x02, 0xE7, 0xF1,
-0x87, 0x12, 0xDF, 0xE8, 0x90, 0x9B, 0xD3, 0xEE,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x9B, 0xD1, 0xD1,
-0x12, 0x7D, 0x0F, 0x12, 0x04, 0x7E, 0x90, 0x9B,
-0xD8, 0xEF, 0xF0, 0x90, 0x9B, 0x5D, 0xE0, 0x60,
-0x3F, 0x90, 0x9B, 0xD7, 0xE0, 0x24, 0xB0, 0x60,
-0x18, 0x24, 0xD0, 0x60, 0x02, 0xA1, 0x0F, 0xF1,
-0x47, 0x20, 0xE0, 0x1D, 0xEF, 0x13, 0x13, 0x13,
-0x54, 0x1F, 0x20, 0xE0, 0x02, 0xA1, 0x0F, 0x80,
-0x10, 0xF1, 0x47, 0x20, 0xE0, 0x0B, 0xEF, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x20, 0xE0, 0x02, 0xA1,
-0x0F, 0xD1, 0xC4, 0x90, 0x9B, 0xDF, 0xE0, 0xFC,
-0xA3, 0xE0, 0xFD, 0x12, 0xF0, 0x8F, 0xA1, 0x0F,
-0x90, 0x9B, 0xD7, 0xE0, 0x24, 0xF8, 0x60, 0x41,
-0x24, 0x80, 0x60, 0x3D, 0x24, 0xC8, 0x60, 0x06,
-0x24, 0x20, 0x60, 0x02, 0xA1, 0x0F, 0x90, 0x93,
-0x29, 0x12, 0x97, 0xB1, 0x20, 0xE0, 0x02, 0xA1,
-0x0F, 0x90, 0x93, 0x3E, 0xE0, 0x04, 0xD1, 0xC3,
-0xD1, 0xFE, 0xEF, 0x70, 0x02, 0xA1, 0x0F, 0xD1,
-0xC4, 0x12, 0xE2, 0x73, 0xEF, 0x70, 0x02, 0xA1,
-0x0F, 0x90, 0x9B, 0xD7, 0xE0, 0xFF, 0x12, 0xE2,
-0x61, 0x90, 0x93, 0x3F, 0xE0, 0x04, 0xF0, 0xA1,
-0x0F, 0x90, 0x93, 0x24, 0xD1, 0xEE, 0x30, 0xE0,
-0x5E, 0x90, 0x9B, 0xDB, 0xE0, 0xFF, 0x90, 0x9B,
-0xD6, 0xE0, 0x2F, 0xFF, 0x90, 0x9B, 0xD5, 0xE0,
-0x34, 0x00, 0xCF, 0x24, 0x08, 0xCF, 0x34, 0x00,
-0xFE, 0x90, 0x9B, 0xE1, 0xF0, 0xA3, 0xEF, 0xF0,
-0x12, 0x8B, 0xE8, 0xEF, 0x64, 0x45, 0x70, 0x37,
-0xD1, 0xCE, 0x12, 0xF1, 0x82, 0xEF, 0x64, 0x01,
-0x70, 0x2D, 0xD1, 0xCE, 0xF1, 0xA8, 0xEF, 0x64,
-0x01, 0x70, 0x24, 0x90, 0x9B, 0xE5, 0x04, 0xD1,
-0xCD, 0xA3, 0xE0, 0xFD, 0x12, 0xF0, 0xB6, 0xEF,
-0x70, 0x0D, 0x90, 0x9B, 0xE3, 0xE0, 0xFD, 0x90,
-0xFD, 0x11, 0xD1, 0xCD, 0x12, 0xF1, 0x11, 0x90,
-0x9B, 0xE3, 0xE0, 0x90, 0xFD, 0x11, 0xF0, 0xD1,
-0xC4, 0xD1, 0xFE, 0xEF, 0x60, 0x39, 0xD1, 0x01,
-0x90, 0x9B, 0xDE, 0xE0, 0xFB, 0x90, 0x9B, 0xE3,
-0xE0, 0x90, 0x9A, 0x0C, 0xF0, 0x12, 0x8F, 0x1A,
-0xEF, 0x60, 0x06, 0x90, 0x9B, 0xE5, 0x74, 0x01,
-0xF0, 0x90, 0x93, 0x25, 0xE0, 0xC4, 0x13, 0x54,
-0x07, 0x30, 0xE0, 0x13, 0xD1, 0x01, 0x90, 0x9B,
-0xDE, 0xE0, 0xFB, 0x12, 0xEE, 0x71, 0xEF, 0x60,
-0x06, 0x90, 0x9B, 0xE5, 0x74, 0x01, 0xF0, 0x90,
-0x93, 0x24, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x0E,
-0xD1, 0x01, 0x12, 0x8D, 0x90, 0xEF, 0x60, 0x06,
-0x90, 0x9B, 0xE5, 0x74, 0x01, 0xF0, 0x90, 0x93,
-0x24, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0,
-0x0E, 0xD1, 0x01, 0x12, 0x89, 0xF9, 0xEF, 0x60,
-0x06, 0x90, 0x9B, 0xE5, 0x74, 0x01, 0xF0, 0x90,
-0x93, 0x24, 0x12, 0x97, 0xB1, 0x30, 0xE0, 0x16,
-0x90, 0x9B, 0xE5, 0xE0, 0x70, 0x10, 0xD1, 0x01,
-0xF1, 0x57, 0xEF, 0x60, 0x09, 0x12, 0x8F, 0xCA,
-0x90, 0x01, 0xC7, 0x74, 0x22, 0xF0, 0xD1, 0x01,
-0xD1, 0x23, 0xEF, 0x60, 0x02, 0xF1, 0x9B, 0x90,
-0x9B, 0xD8, 0xE0, 0xFF, 0x7D, 0x01, 0x12, 0xEE,
-0xE1, 0xEF, 0x60, 0x12, 0x12, 0x8F, 0xCA, 0x90,
-0x9B, 0xD1, 0xD1, 0x12, 0x7D, 0x10, 0x12, 0x04,
-0x7E, 0x90, 0x95, 0x65, 0xEF, 0xF0, 0x90, 0x9B,
-0xE5, 0xE0, 0x70, 0x1E, 0x90, 0x93, 0x26, 0xD1,
-0xEE, 0x30, 0xE0, 0x16, 0x90, 0x9B, 0xD7, 0xE0,
-0xFF, 0x64, 0x08, 0x60, 0x04, 0xEF, 0xB4, 0x88,
-0x09, 0x12, 0x8F, 0xCA, 0x90, 0x01, 0xC7, 0x74,
-0x25, 0xF0, 0x90, 0x93, 0x31, 0xE0, 0x30, 0xE0,
-0x11, 0x90, 0x93, 0x25, 0xD1, 0xEE, 0x30, 0xE0,
-0x09, 0xD1, 0x01, 0x11, 0xE6, 0xBF, 0x01, 0x02,
-0xF1, 0x9B, 0xF1, 0x87, 0x90, 0x9B, 0xD1, 0x12,
-0xE0, 0xF9, 0xF1, 0x7E, 0xD3, 0x9F, 0xEC, 0x9E,
-0x40, 0x0F, 0x12, 0xE1, 0x17, 0xED, 0x9F, 0xFF,
-0xEC, 0x9E, 0x90, 0x9B, 0xD1, 0xF0, 0xA3, 0xEF,
-0xF0, 0x90, 0x93, 0x31, 0xE0, 0x30, 0xE0, 0x05,
-0x7F, 0x01, 0x12, 0xBC, 0x2E, 0x12, 0xE2, 0x4A,
-0xEF, 0x64, 0x01, 0x70, 0x38, 0x90, 0x93, 0x40,
-0xE0, 0x04, 0xF0, 0x12, 0xE1, 0x27, 0xAD, 0x07,
-0xEF, 0x64, 0x01, 0x60, 0x20, 0x12, 0x8F, 0xCA,
-0xED, 0xB4, 0x02, 0x08, 0x90, 0x01, 0xC7, 0x74,
-0x42, 0xF0, 0x80, 0x0A, 0xED, 0xB4, 0x04, 0x06,
-0x90, 0x01, 0xC7, 0x74, 0x43, 0xF0, 0x7F, 0x01,
-0x12, 0xBC, 0x2E, 0x80, 0x24, 0x90, 0x9B, 0xD1,
-0x12, 0xDF, 0xD5, 0x80, 0x14, 0x90, 0x93, 0x26,
-0xE0, 0xC4, 0x13, 0x54, 0x07, 0x20, 0xE0, 0x11,
-0x90, 0x93, 0x24, 0xE0, 0x54, 0xFE, 0xF0, 0x80,
-0x08, 0x90, 0x9B, 0xD9, 0xE0, 0x04, 0xF0, 0x41,
-0xC8, 0x74, 0x84, 0x04, 0x90, 0x01, 0xC4, 0xF0,
-0x74, 0xA2, 0xA3, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x90, 0x9B, 0xD5, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x90, 0x9B, 0xDB, 0xE0, 0xFD, 0x22, 0x90,
-0x9A, 0x0D, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90,
-0x8A, 0xE9, 0xE0, 0xFC, 0xA3, 0xE0, 0xF5, 0x82,
-0x8C, 0x83, 0x22, 0x90, 0x9A, 0x0A, 0xED, 0x12,
-0x8F, 0xE4, 0xD1, 0xFE, 0xEF, 0x70, 0x02, 0xC1,
-0xC0, 0x12, 0x8F, 0x11, 0xF1, 0x4F, 0x70, 0x02,
-0xC1, 0xC0, 0x12, 0x8D, 0x7E, 0xCF, 0x24, 0x08,
-0xF1, 0x90, 0x90, 0x93, 0x25, 0xE0, 0xC4, 0x54,
-0x0F, 0x30, 0xE0, 0x33, 0xD1, 0x0F, 0x7D, 0x09,
-0x12, 0x04, 0x7E, 0xEF, 0x64, 0x06, 0x70, 0x27,
-0xD1, 0x0F, 0x7D, 0x14, 0x12, 0x04, 0x7E, 0xEF,
-0x70, 0x1D, 0xD1, 0x0F, 0x7D, 0x15, 0x12, 0x04,
-0x7E, 0xEF, 0x64, 0x50, 0x70, 0x11, 0xD1, 0x0F,
-0x7D, 0x21, 0x12, 0x04, 0x7E, 0xEF, 0x20, 0xE0,
-0x03, 0x30, 0xE2, 0x03, 0x7F, 0x01, 0x22, 0x90,
-0x93, 0x25, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x30,
-0xE0, 0x36, 0xD1, 0x0F, 0x7D, 0x09, 0x12, 0x04,
-0x7E, 0xEF, 0x64, 0x11, 0x70, 0x2A, 0x90, 0x9A,
-0x0E, 0xE0, 0x24, 0x14, 0xFF, 0x90, 0x9A, 0x0D,
-0xE0, 0x34, 0x00, 0xFE, 0xF1, 0x6D, 0xD1, 0x17,
-0x7D, 0x02, 0x12, 0x04, 0x7E, 0xEF, 0x70, 0x10,
-0x90, 0x9A, 0x0B, 0xD1, 0x12, 0x7D, 0x03, 0x12,
-0x04, 0x7E, 0xBF, 0x89, 0x03, 0x7F, 0x01, 0x22,
-0x7F, 0x00, 0x22, 0xF0, 0x90, 0x9B, 0xD5, 0xE0,
-0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0xF0, 0x90, 0x9B,
-0xE1, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0x90,
-0x9A, 0x17, 0xE0, 0xFF, 0x90, 0x9A, 0x14, 0xE0,
-0x2F, 0xFF, 0x90, 0x9A, 0x13, 0xE0, 0x34, 0x00,
-0xFE, 0x12, 0x7A, 0x7E, 0xEF, 0x22, 0xE0, 0xC4,
-0x13, 0x13, 0x54, 0x03, 0x22, 0x90, 0x9A, 0x0D,
-0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0x90, 0x9A,
-0x0F, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x90,
-0x9A, 0x17, 0xF0, 0x90, 0x9A, 0x17, 0xE0, 0xFD,
-0xC3, 0x94, 0x06, 0x50, 0x1D, 0x90, 0x9A, 0x10,
-0xE0, 0x24, 0x04, 0xF1, 0x75, 0x12, 0x8F, 0xBA,
-0x90, 0x9A, 0x17, 0x12, 0x8F, 0xF5, 0xF5, 0x83,
-0xEF, 0xF0, 0x90, 0x9A, 0x17, 0xE0, 0x04, 0xF0,
-0x80, 0xD9, 0x78, 0x32, 0x7C, 0x93, 0x7D, 0x01,
-0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x11, 0xF1, 0xED,
-0x7F, 0x00, 0x70, 0x02, 0x7F, 0x01, 0x22, 0x90,
-0x93, 0x04, 0xE0, 0xFF, 0xC3, 0x13, 0x22, 0xA3,
-0xE0, 0xFD, 0x12, 0xE8, 0x64, 0xEF, 0x22, 0x90,
-0x9A, 0x0A, 0xED, 0x12, 0x8F, 0xE4, 0xD1, 0xFE,
-0xEF, 0x60, 0x09, 0x12, 0x8F, 0x11, 0xF1, 0x4F,
-0x60, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x9A, 0x0B,
-0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xFF, 0x90, 0x9A,
-0x0F, 0xE0, 0x34, 0x00, 0xFE, 0x22, 0x90, 0x9B,
-0xD1, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0x22, 0x90,
-0x9B, 0xD3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0xCF, 0x34, 0x00, 0x90, 0x9A, 0x0D, 0xF0, 0xA3,
-0xEF, 0xF0, 0x22, 0x90, 0x93, 0x31, 0xE0, 0x54,
-0xFE, 0xF0, 0x90, 0x01, 0xC7, 0xE4, 0xF0, 0x22,
-0x12, 0x8F, 0xE5, 0x24, 0x16, 0xFF, 0xE4, 0x3E,
-0x12, 0x8B, 0xE7, 0x90, 0x95, 0x77, 0xA3, 0xE0,
-0xB5, 0x07, 0x1D, 0x90, 0x9A, 0x09, 0xE0, 0x24,
-0x16, 0x12, 0x8D, 0x88, 0xFE, 0xD1, 0x17, 0x7D,
-0x01, 0x12, 0x04, 0x7E, 0xEF, 0xFD, 0x90, 0x95,
-0x77, 0xE0, 0x6D, 0x70, 0x01, 0xE4, 0x60, 0x03,
-0x7F, 0x00, 0x22, 0x7F, 0x01, 0x22, 0xF0, 0xE4,
-0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x90, 0x01, 0x94,
-0xE0, 0x44, 0x01, 0x80, 0xB4, 0x7E, 0x00, 0x7F,
-0x06, 0x12, 0x83, 0xDC, 0xEF, 0x22, 0x12, 0x02,
-0x06, 0x54, 0x01, 0xFF, 0x90, 0x93, 0x0C, 0xE0,
-0x54, 0xFE, 0x4F, 0xF0, 0x30, 0xE0, 0x03, 0xE4,
-0x11, 0x0E, 0x22, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
-0xA3, 0xF0, 0xA3, 0xF0, 0x22, 0x12, 0xBC, 0xBD,
-0xE4, 0x90, 0x98, 0x15, 0x11, 0x0D, 0x90, 0x95,
-0x67, 0x11, 0x0B, 0xA3, 0x11, 0x0B, 0x90, 0x95,
-0x79, 0xF0, 0xA3, 0xF0, 0x90, 0x95, 0xBB, 0xF0,
-0xA3, 0xF0, 0x22, 0x90, 0x9A, 0xC5, 0xEF, 0xF0,
-0xA3, 0xED, 0xF0, 0xA3, 0x12, 0x82, 0x27, 0x90,
-0x9A, 0xC7, 0x12, 0x82, 0x1E, 0x8B, 0x45, 0x8A,
-0x46, 0x11, 0xBA, 0x24, 0x02, 0x31, 0x00, 0x24,
-0x04, 0x11, 0xB3, 0x24, 0x03, 0x31, 0x00, 0x24,
-0x08, 0x11, 0xB3, 0x24, 0x04, 0x31, 0x00, 0x24,
-0x0C, 0x11, 0xB3, 0x24, 0x05, 0x31, 0x15, 0x79,
-0xCB, 0x11, 0xD1, 0x90, 0x9A, 0xC6, 0xE0, 0xFD,
-0xB4, 0x02, 0x08, 0x90, 0x9A, 0xC5, 0xE0, 0x44,
-0x48, 0x80, 0x0A, 0xED, 0xB4, 0x04, 0x0A, 0x90,
-0x9A, 0xC5, 0xE0, 0x44, 0x50, 0x90, 0x9A, 0xCB,
-0xF0, 0x90, 0x9A, 0xCC, 0x74, 0x80, 0xF0, 0xA3,
-0x74, 0xFF, 0xF0, 0xA3, 0xF0, 0x11, 0xC8, 0x31,
-0x15, 0x79, 0xCB, 0x11, 0xD1, 0x90, 0x9A, 0xCB,
-0x74, 0xFF, 0x11, 0x0D, 0x11, 0xC8, 0x04, 0x31,
-0x15, 0x79, 0xCB, 0x11, 0xD1, 0x90, 0x06, 0x72,
-0xE4, 0xF0, 0x22, 0xF9, 0xE4, 0x3A, 0x8B, 0x45,
-0xF5, 0x46, 0x89, 0x47, 0x75, 0x48, 0x04, 0x7B,
-0x01, 0x7A, 0x9A, 0x79, 0xCB, 0x12, 0x69, 0xF5,
-0x90, 0x9A, 0xC5, 0xE0, 0x75, 0xF0, 0x08, 0xA4,
-0x22, 0x12, 0x02, 0x06, 0x90, 0x06, 0x74, 0x12,
-0x87, 0x9C, 0x90, 0x06, 0x75, 0x12, 0x87, 0xA3,
-0x90, 0x06, 0x76, 0x12, 0x97, 0xCC, 0x90, 0x06,
-0x77, 0xF0, 0x90, 0x06, 0x70, 0xEF, 0xF0, 0xA3,
-0xE4, 0xF0, 0xA3, 0x04, 0xF0, 0xA3, 0x74, 0x80,
-0xF0, 0x7F, 0x01, 0x7E, 0x00, 0x02, 0x7C, 0x6A,
-0xFF, 0x90, 0x9A, 0xCA, 0xF0, 0x7B, 0x01, 0x7A,
-0x9A, 0x79, 0xCB, 0x11, 0xD1, 0x90, 0x9A, 0xC7,
-0x12, 0x82, 0x1E, 0xE9, 0x22, 0xFF, 0x90, 0x9A,
-0xCA, 0xF0, 0x7B, 0x01, 0x7A, 0x9A, 0x22, 0x7E,
-0x00, 0x7F, 0x29, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
-0x93, 0x79, 0x24, 0x12, 0x04, 0x80, 0x90, 0x06,
-0x90, 0xE0, 0x54, 0xDF, 0xF0, 0x12, 0xE1, 0x59,
-0x11, 0x15, 0x90, 0x86, 0xB3, 0xE0, 0xFF, 0x64,
-0x02, 0x70, 0x2E, 0x90, 0xFD, 0x80, 0xE0, 0x7E,
-0x00, 0x30, 0xE0, 0x02, 0x7E, 0x01, 0x90, 0x93,
-0x47, 0x51, 0x08, 0x7E, 0x00, 0x30, 0xE1, 0x02,
-0x7E, 0x01, 0x90, 0x93, 0x45, 0x51, 0x08, 0x7E,
-0x00, 0x30, 0xE2, 0x02, 0x7E, 0x01, 0x90, 0x93,
-0x46, 0x51, 0x08, 0x90, 0x02, 0xFB, 0xF0, 0x80,
-0x52, 0xEF, 0x64, 0x01, 0x70, 0x21, 0x51, 0x01,
-0x30, 0xE0, 0x02, 0x7F, 0x01, 0x90, 0x93, 0x47,
-0xEF, 0xF0, 0x51, 0x01, 0x30, 0xE1, 0x02, 0x7F,
-0x01, 0x90, 0x93, 0x45, 0xEF, 0xF0, 0x51, 0x01,
-0x30, 0xE2, 0x02, 0x7F, 0x01, 0x80, 0x27, 0x90,
-0x86, 0xB3, 0xE0, 0x64, 0x03, 0x70, 0x24, 0x31,
-0xFA, 0x30, 0xE0, 0x02, 0x7F, 0x01, 0x90, 0x93,
-0x47, 0xEF, 0xF0, 0x31, 0xFA, 0x30, 0xE1, 0x02,
-0x7F, 0x01, 0x90, 0x93, 0x45, 0xEF, 0xF0, 0x31,
-0xFA, 0x30, 0xE2, 0x02, 0x7F, 0x01, 0x90, 0x93,
-0x46, 0xEF, 0xF0, 0x90, 0x93, 0x24, 0xE0, 0x54,
-0xEF, 0xF0, 0xE4, 0x90, 0x95, 0xBD, 0xF0, 0xA3,
-0xF0, 0x90, 0x95, 0xC5, 0x12, 0x04, 0x3D, 0x00,
-0x00, 0x00, 0x00, 0x90, 0x95, 0xC9, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x00, 0x90, 0x95, 0xC1,
+0x92, 0xAF, 0x22, 0x90, 0x9C, 0x94, 0xEE, 0xF0,
+0xA3, 0xEF, 0xF0, 0x90, 0x9C, 0x97, 0xEB, 0xF0,
+0x90, 0x9C, 0x96, 0xED, 0xF0, 0x60, 0x13, 0x51,
+0xEE, 0x78, 0x03, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
+0xD8, 0xF9, 0xF0, 0xEE, 0x90, 0x9C, 0x94, 0xF0,
+0x80, 0x19, 0x51, 0xEE, 0x78, 0x06, 0xC3, 0x33,
+0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xF0, 0xEE, 0x90,
+0x9C, 0x94, 0xF0, 0x74, 0xFF, 0x75, 0xF0, 0xD0,
+0x12, 0x02, 0xE7, 0x51, 0x1E, 0x54, 0x07, 0x7D,
+0x00, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0x11, 0xD1,
+0x51, 0x1E, 0x54, 0x01, 0xFD, 0x11, 0xD1, 0x90,
+0x9C, 0x98, 0xE0, 0x60, 0x3B, 0x51, 0x11, 0x54,
+0x07, 0x7D, 0x00, 0x20, 0xE0, 0x02, 0x7D, 0x01,
+0x11, 0xD1, 0xE4, 0x90, 0x9C, 0x99, 0xF0, 0x90,
+0x9C, 0x97, 0xE0, 0xFF, 0x90, 0x9C, 0x99, 0xE0,
+0xC3, 0x9F, 0x50, 0x1C, 0x51, 0x11, 0x54, 0x01,
+0xFD, 0x11, 0xD1, 0x51, 0x11, 0x54, 0x07, 0x7D,
+0x00, 0x20, 0xE0, 0x02, 0x7D, 0x01, 0x11, 0xD1,
+0x90, 0x9C, 0x99, 0xE0, 0x04, 0xF0, 0x80, 0xD7,
+0x22, 0x90, 0x9C, 0x94, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0xA3, 0xE0, 0xFD, 0x51, 0x2D, 0x90, 0x93,
+0x2A, 0xE0, 0x54, 0x7F, 0xFF, 0x90, 0x93, 0x29,
+0xE0, 0xFE, 0xC4, 0x13, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x8E, 0x10, 0x8F, 0x11,
+0xBD, 0x01, 0x05, 0x12, 0x7A, 0xAE, 0x80, 0x07,
+0xAF, 0x11, 0xAE, 0x10, 0x12, 0x7C, 0x6A, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x9C, 0xD1, 0xED, 0xF0,
+0xA3, 0xEB, 0xF0, 0x90, 0x9C, 0xD0, 0xEF, 0xF0,
+0xC3, 0x94, 0x08, 0x40, 0x04, 0xE0, 0x24, 0xF8,
+0xF0, 0x7F, 0x62, 0x51, 0xE7, 0x11, 0xC9, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F, 0xFD,
+0x7F, 0x62, 0x12, 0x7B, 0x2E, 0x90, 0x9C, 0xD1,
+0xE0, 0x60, 0x3F, 0x7F, 0x63, 0x51, 0xE7, 0x11,
+0xC9, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x4F,
+0xFD, 0x7F, 0x63, 0x12, 0x7B, 0x2E, 0x90, 0x9C,
+0xD2, 0xE0, 0x60, 0x12, 0x51, 0xFE, 0x08, 0x80,
+0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0xFF, 0x90,
+0x00, 0x49, 0xE0, 0x5F, 0x80, 0x0F, 0x51, 0xFE,
+0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xFF,
+0x90, 0x00, 0x49, 0xE0, 0x4F, 0xFD, 0x7F, 0x49,
+0x80, 0x11, 0x7F, 0x63, 0x51, 0xE7, 0x11, 0xC9,
+0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5F,
+0xFD, 0x7F, 0x63, 0x12, 0x7B, 0x2E, 0x90, 0x00,
+0x4A, 0xE0, 0x54, 0xF0, 0xFD, 0x7F, 0x4A, 0x12,
+0x7B, 0x2E, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12,
+0x7B, 0x41, 0x90, 0x9C, 0xD0, 0x22, 0x90, 0x9C,
+0x94, 0xE0, 0xFE, 0xA3, 0xE0, 0x22, 0x12, 0x7B,
+0x2E, 0x90, 0x9C, 0xD8, 0xE0, 0x22, 0x90, 0x9C,
+0xD0, 0xE0, 0xFF, 0x74, 0x01, 0xA8, 0x07, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x01, 0xCC, 0xE0, 0x54, 0x0F, 0xFD, 0xED, 0x70,
+0x02, 0x61, 0xFB, 0x90, 0x87, 0x0B, 0xE0, 0xFF,
+0x70, 0x06, 0xA3, 0xE0, 0x64, 0x09, 0x60, 0x0A,
+0xEF, 0x14, 0xFF, 0x90, 0x87, 0x0C, 0xE0, 0xB5,
+0x07, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F, 0x00,
+0xEF, 0x60, 0x09, 0x90, 0x01, 0xC1, 0xE0, 0x44,
+0x01, 0xF0, 0x61, 0xFB, 0x90, 0x9C, 0xE0, 0x91,
+0x09, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
+0xD8, 0xF9, 0xFF, 0xED, 0xFB, 0xEF, 0x5B, 0x70,
+0x02, 0x61, 0xDE, 0xE4, 0xFC, 0x91, 0x01, 0xA4,
+0xFF, 0xEC, 0x7A, 0x00, 0x2F, 0xFF, 0xEA, 0x35,
+0xF0, 0xFE, 0x74, 0xD0, 0xB1, 0xCE, 0x90, 0x87,
+0x0C, 0xE0, 0xF9, 0x75, 0xF0, 0x08, 0x90, 0x86,
+0xBB, 0xB1, 0xD9, 0xEF, 0x91, 0x00, 0xA4, 0xFF,
+0xEC, 0x2F, 0xFF, 0xEA, 0x35, 0xF0, 0xFE, 0x74,
+0xF0, 0xB1, 0xCE, 0x75, 0xF0, 0x08, 0xE9, 0x90,
+0x86, 0xBF, 0xB1, 0xD9, 0xEF, 0xF0, 0x0C, 0xEC,
+0xB4, 0x04, 0xC2, 0x90, 0x9C, 0xE0, 0x71, 0x01,
+0x08, 0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4,
+0x5D, 0xFD, 0x90, 0x9C, 0xE0, 0x71, 0x01, 0x08,
+0x80, 0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x90, 0x01,
+0xCC, 0xF0, 0x90, 0x9C, 0xE0, 0xE0, 0x04, 0xF0,
+0xE0, 0x54, 0x03, 0xF0, 0x90, 0x87, 0x0C, 0xE0,
+0x04, 0xF0, 0xE0, 0x7F, 0x00, 0xB4, 0x0A, 0x02,
+0x7F, 0x01, 0xEF, 0x70, 0x02, 0x61, 0x16, 0xE4,
+0x90, 0x87, 0x0C, 0xF0, 0x61, 0x16, 0x90, 0x01,
+0xC0, 0xE0, 0x44, 0x02, 0xF0, 0x90, 0x9C, 0xE0,
+0xE0, 0x44, 0x80, 0x90, 0x00, 0x8A, 0x91, 0x00,
+0x90, 0x01, 0xD0, 0x12, 0x04, 0x6E, 0xE0, 0x90,
+0x01, 0xC3, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0xF0, 0x90, 0x9C, 0xE0, 0xE0, 0x75, 0xF0, 0x04,
+0x22, 0xE0, 0xFF, 0x74, 0x01, 0x7E, 0x00, 0xA8,
+0x07, 0x08, 0x22, 0x12, 0xE8, 0x98, 0xA3, 0xED,
+0xF0, 0x90, 0x98, 0x47, 0xE0, 0xFF, 0x12, 0x7B,
+0x07, 0x90, 0x9A, 0x37, 0xE4, 0xF0, 0xA3, 0xEF,
+0xF0, 0x90, 0xFD, 0x10, 0xE0, 0x90, 0x9A, 0x37,
+0x75, 0xF0, 0x00, 0x12, 0x02, 0xE7, 0xE4, 0x90,
+0x9A, 0x41, 0xF0, 0x90, 0x93, 0x27, 0xE0, 0x54,
+0x07, 0xFF, 0x90, 0x9A, 0x41, 0xE0, 0xC3, 0x9F,
+0x40, 0x02, 0xA1, 0xAB, 0x90, 0x9A, 0x35, 0xE0,
+0x24, 0x04, 0xFE, 0x12, 0xA6, 0x32, 0x90, 0x9A,
+0x39, 0xF0, 0xA3, 0xCE, 0xF0, 0x90, 0x9A, 0x38,
+0xE0, 0x24, 0x01, 0xFF, 0x90, 0x9A, 0x37, 0xB1,
+0xBC, 0x7F, 0x00, 0xFE, 0xC0, 0x06, 0xC0, 0x07,
+0x90, 0x9A, 0x37, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0x12, 0x7A, 0x7E, 0xEF, 0xFD, 0xD0, 0xE0, 0x2D,
+0xFF, 0xD0, 0xE0, 0x34, 0x00, 0xFE, 0x90, 0x9A,
+0x3B, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x9A, 0x38,
+0xE0, 0x24, 0x02, 0xFD, 0x90, 0x9A, 0x37, 0xE0,
+0x34, 0x00, 0xFC, 0x90, 0x9A, 0x3F, 0xF0, 0xA3,
+0xED, 0xF0, 0x2F, 0x12, 0xFA, 0xC4, 0x90, 0x9A,
+0x44, 0x74, 0x01, 0xF0, 0xE4, 0x90, 0x9A, 0x43,
+0xF0, 0x90, 0x9A, 0x43, 0xE0, 0xFF, 0xFD, 0xD3,
+0x90, 0x9A, 0x3C, 0xE0, 0x9D, 0x90, 0x9A, 0x3B,
+0xE0, 0x94, 0x00, 0x50, 0x02, 0xA1, 0x78, 0xEF,
+0xB4, 0x12, 0x09, 0x12, 0xA6, 0x27, 0xCF, 0x24,
+0x06, 0x12, 0xFA, 0xCF, 0x90, 0x9A, 0x43, 0xE0,
+0x75, 0xF0, 0x02, 0xA4, 0xFD, 0xAC, 0xF0, 0xAE,
+0x04, 0x78, 0x03, 0xCE, 0xA2, 0xE7, 0x13, 0xCE,
+0x13, 0xD8, 0xF8, 0xFF, 0xED, 0x54, 0x07, 0x90,
+0x9A, 0x42, 0xF0, 0x90, 0x9A, 0x3E, 0xE0, 0x2F,
+0x12, 0xA3, 0xBF, 0xFE, 0x12, 0x7A, 0x7E, 0x90,
+0x9A, 0x45, 0xEF, 0xF0, 0xFD, 0x90, 0x9A, 0x42,
+0x91, 0x09, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0xFF, 0xEF, 0x5D, 0x6F, 0x70,
+0x01, 0xEE, 0x70, 0x16, 0xB1, 0xAE, 0x54, 0x0F,
+0xFF, 0xC0, 0x07, 0xB1, 0xC5, 0x12, 0xA2, 0x3C,
+0xEF, 0x54, 0x0F, 0xD0, 0x07, 0x6F, 0x60, 0x02,
+0x80, 0x32, 0x90, 0x9A, 0x42, 0xE0, 0x04, 0x91,
+0x0A, 0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
+0xD8, 0xF9, 0xFF, 0x90, 0x9A, 0x45, 0xE0, 0xFD,
+0xEF, 0x5D, 0x6F, 0x70, 0x01, 0xEE, 0x70, 0x1B,
+0xB1, 0xAE, 0x54, 0xF0, 0xFF, 0xC0, 0x07, 0xB1,
+0xC5, 0x12, 0xA2, 0x3C, 0xEF, 0x54, 0xF0, 0xD0,
+0x07, 0x6F, 0x60, 0x07, 0xE4, 0x90, 0x9A, 0x44,
+0xF0, 0x80, 0x0D, 0x90, 0x9A, 0x39, 0xF1, 0xA5,
+0x90, 0x9A, 0x43, 0xE0, 0x04, 0xF0, 0x81, 0xB1,
+0x90, 0x9A, 0x44, 0xE0, 0xB4, 0x01, 0x03, 0x7F,
+0x01, 0x22, 0x90, 0x9A, 0x3C, 0xE0, 0x24, 0x03,
+0x12, 0xFA, 0x83, 0xEF, 0x78, 0x02, 0xCE, 0xC3,
+0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xFF, 0x90, 0x9A,
+0x3E, 0xE0, 0x2F, 0xFF, 0x90, 0x9A, 0x3D, 0xE0,
+0x3E, 0xF1, 0xED, 0x90, 0x9A, 0x41, 0xE0, 0x04,
+0xF0, 0x81, 0x3B, 0x7F, 0x00, 0x22, 0x90, 0x9A,
+0x43, 0xE0, 0xFF, 0x90, 0x9A, 0x40, 0xE0, 0x2F,
+0xFF, 0x90, 0x9A, 0x3F, 0xE0, 0x34, 0x00, 0xFE,
+0x12, 0x7A, 0x7E, 0xEF, 0x22, 0x90, 0x9A, 0x39,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0x2F, 0xF5,
+0x82, 0x74, 0x01, 0x3E, 0xF5, 0x83, 0xE0, 0xFF,
+0x22, 0x12, 0x04, 0x6E, 0xE5, 0x82, 0x2C, 0xF5,
+0x82, 0xE4, 0x35, 0x83, 0xF5, 0x83, 0x22, 0xE4,
+0x90, 0x9A, 0x0C, 0xF0, 0x12, 0xE3, 0x28, 0x12,
+0xCF, 0x97, 0xE4, 0xFF, 0x12, 0xE1, 0x32, 0x90,
+0x93, 0x0C, 0xE0, 0x20, 0xE0, 0x02, 0xC1, 0xE3,
+0x90, 0x00, 0x02, 0xE0, 0x44, 0x02, 0xF0, 0xE4,
+0x90, 0x9A, 0x0D, 0xF0, 0x90, 0x9A, 0x0D, 0xE0,
+0xFF, 0xC3, 0x94, 0x05, 0x50, 0x2E, 0x91, 0x0B,
+0x80, 0x05, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
+0xF9, 0xFF, 0x90, 0x93, 0x0F, 0xE0, 0xFD, 0xEF,
+0x5D, 0x60, 0x11, 0x90, 0x9A, 0x0D, 0x12, 0xE0,
+0xF1, 0x90, 0x9A, 0x0D, 0x12, 0xE1, 0x11, 0x44,
+0x40, 0xF0, 0xF1, 0xDF, 0x90, 0x9A, 0x0D, 0xE0,
+0x04, 0xF0, 0x80, 0xC8, 0x90, 0x07, 0xC7, 0xE4,
+0xF0, 0x90, 0x07, 0xC6, 0xF0, 0x90, 0x07, 0xC5,
+0x74, 0x77, 0xF0, 0x90, 0x07, 0xC4, 0xE4, 0xF0,
+0x90, 0x07, 0xC0, 0x74, 0x38, 0xF0, 0xA3, 0xE4,
+0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0x74, 0xC0,
+0xF0, 0x90, 0x02, 0x26, 0xE0, 0x44, 0x01, 0xF0,
+0xE0, 0x90, 0x9A, 0x0E, 0xF0, 0x90, 0x9A, 0x0E,
+0xE0, 0x30, 0xE0, 0x19, 0x90, 0x9A, 0x0C, 0xE0,
+0x04, 0xF0, 0xD1, 0xF4, 0x90, 0x02, 0x26, 0xE0,
+0x90, 0x9A, 0x0E, 0xF0, 0x90, 0x9A, 0x0C, 0xE0,
+0xD3, 0x94, 0xFA, 0x40, 0xE0, 0x90, 0x02, 0x03,
+0x74, 0x80, 0xF0, 0x90, 0x04, 0x24, 0xE0, 0x90,
+0x9A, 0x0F, 0xF0, 0x90, 0x04, 0x22, 0xE0, 0x44,
+0x10, 0xF0, 0x90, 0x02, 0x00, 0xE0, 0x90, 0x9A,
+0x0E, 0xF0, 0x90, 0x02, 0x01, 0xD1, 0xEB, 0x90,
+0x02, 0x02, 0xD1, 0xEB, 0x90, 0x02, 0x14, 0xD1,
+0xEB, 0xE0, 0x04, 0xF0, 0xE0, 0x90, 0x04, 0x24,
+0xF0, 0x90, 0x04, 0x22, 0xE0, 0x54, 0xEF, 0xF0,
+0x90, 0x9A, 0x0F, 0xE0, 0x90, 0x04, 0x24, 0xF0,
+0x90, 0xFD, 0x09, 0x74, 0xFF, 0xF0, 0x90, 0xFD,
+0x08, 0xE4, 0xF0, 0x90, 0x88, 0x32, 0xE0, 0x54,
+0xEF, 0xF0, 0x22, 0xE0, 0xFF, 0x90, 0x9A, 0x0E,
+0xE0, 0x2F, 0xF0, 0x22, 0x7F, 0x0A, 0x7E, 0x00,
+0x02, 0x7C, 0x6A, 0x90, 0x93, 0x2D, 0xE0, 0xC3,
+0x13, 0x30, 0xE0, 0x28, 0x12, 0xD9, 0x66, 0x70,
+0x1D, 0x90, 0x93, 0x2D, 0xE0, 0x30, 0xE0, 0x0B,
+0xF1, 0x4E, 0xF1, 0x6D, 0xF1, 0x46, 0x20, 0xE0,
+0x02, 0xD1, 0xF4, 0x90, 0x98, 0x48, 0xE0, 0xFF,
+0x7B, 0x01, 0x7D, 0x01, 0x80, 0x04, 0xF1, 0xE6,
+0xFB, 0xFD, 0x41, 0x4C, 0x90, 0x93, 0x2D, 0xE0,
+0x30, 0xE0, 0x12, 0xF1, 0x4E, 0xF1, 0x6D, 0xF1,
+0x46, 0x20, 0xE0, 0x02, 0xD1, 0xF4, 0x90, 0x93,
+0x2D, 0xE0, 0x54, 0xFE, 0xF0, 0x22, 0x90, 0x93,
+0x2D, 0xE0, 0xC4, 0x54, 0x0F, 0x22, 0x90, 0x00,
+0xCC, 0xE0, 0x44, 0x04, 0xF0, 0x7F, 0x02, 0x12,
+0x7B, 0x41, 0xEF, 0x54, 0xFB, 0x22, 0x90, 0x00,
+0xCC, 0xE0, 0x44, 0x04, 0xF0, 0x7F, 0x02, 0x12,
+0x7B, 0x41, 0xEF, 0x44, 0x04, 0xFD, 0x7F, 0x02,
+0x12, 0x7B, 0x2E, 0x90, 0x00, 0xCC, 0xE0, 0x54,
+0xFB, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x12, 0xDF, 0xD4, 0xB1, 0xE7, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x88, 0x39, 0xE0,
+0xFF, 0x60, 0x03, 0xB4, 0x08, 0x0E, 0x12, 0xF8,
+0x45, 0xBF, 0x01, 0x08, 0xF1, 0x7B, 0x90, 0x01,
+0xE5, 0xE0, 0x04, 0xF0, 0x22, 0xE4, 0x75, 0xF0,
+0x01, 0x02, 0x02, 0xE7, 0xE4, 0x90, 0x9C, 0xDD,
+0xF0, 0xA3, 0xF0, 0x90, 0x02, 0x86, 0xE0, 0x20,
+0xE1, 0x22, 0xC3, 0x90, 0x9C, 0xDE, 0xE0, 0x94,
+0xD0, 0x90, 0x9C, 0xDD, 0xE0, 0x94, 0x07, 0x40,
+0x0A, 0x90, 0x01, 0xC1, 0xE0, 0x44, 0x04, 0xF0,
+0x7F, 0x00, 0x22, 0x90, 0x9C, 0xDD, 0xF1, 0xA5,
+0xD1, 0xF4, 0x80, 0xD7, 0x7F, 0x01, 0x22, 0x7F,
+0x14, 0x7E, 0x00, 0x02, 0x7C, 0x6A, 0x90, 0x98,
+0x48, 0xE0, 0xFF, 0xE4, 0x22, 0x90, 0x9A, 0x37,
+0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xE4, 0xFD, 0x02,
+0x8F, 0xF5, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+0x00, 0x00, 0x00, 0x00, 0x12, 0x02, 0x06, 0x54,
+0x01, 0xFF, 0x90, 0x93, 0x0C, 0xE0, 0x54, 0xFE,
+0x4F, 0xF0, 0x30, 0xE0, 0x04, 0xE4, 0x12, 0x9F,
+0xB0, 0x22, 0x12, 0x02, 0x06, 0xFF, 0x90, 0x98,
+0x58, 0xF0, 0xBF, 0x01, 0x0A, 0x7F, 0x01, 0x12,
+0x90, 0x50, 0xE4, 0x90, 0x98, 0x58, 0xF0, 0x22,
+0xEF, 0xB4, 0xFF, 0x06, 0x90, 0x98, 0x6A, 0xED,
+0xF0, 0x22, 0xEF, 0xF4, 0xFE, 0x90, 0x98, 0x6A,
+0xE0, 0x5E, 0xFE, 0xED, 0x5F, 0x4E, 0xF0, 0x22,
+0xEF, 0xB4, 0xFF, 0x06, 0x90, 0x98, 0x6B, 0xED,
+0xF0, 0x22, 0xEF, 0xF4, 0xFE, 0x90, 0x98, 0x6B,
+0x80, 0xE6, 0x90, 0x9C, 0xE1, 0xED, 0xF0, 0x64,
+0x01, 0x60, 0x26, 0xE0, 0xFE, 0x64, 0x02, 0x60,
+0x20, 0xEE, 0x64, 0x29, 0x60, 0x1B, 0xEE, 0x64,
+0x2A, 0x60, 0x16, 0xEE, 0x64, 0x36, 0x60, 0x11,
+0xEE, 0xB4, 0x37, 0x02, 0x80, 0x0B, 0xAD, 0x07,
+0x7F, 0xFF, 0x11, 0x48, 0x90, 0x98, 0x6B, 0xE0,
+0xFF, 0x90, 0x98, 0x6A, 0xE0, 0x4F, 0x90, 0x05,
+0x22, 0xF0, 0x90, 0x9C, 0xE1, 0xE0, 0x90, 0x93,
+0x01, 0xF0, 0x22, 0x12, 0xE7, 0xAB, 0x64, 0x01,
+0x60, 0x02, 0x21, 0x2E, 0xEF, 0x24, 0x39, 0x60,
+0x12, 0x14, 0x60, 0x19, 0x24, 0x02, 0x70, 0x1F,
+0xE4, 0x90, 0x99, 0xB7, 0xF0, 0xA3, 0x74, 0x06,
+0xF0, 0x80, 0x14, 0x90, 0x99, 0xB7, 0x74, 0x06,
+0xF0, 0xA3, 0xF0, 0x80, 0x0A, 0x90, 0x99, 0xB7,
+0x74, 0x0C, 0xF0, 0xA3, 0x74, 0x04, 0xF0, 0xB1,
+0xF6, 0xF0, 0x71, 0xE2, 0x40, 0x20, 0x90, 0x99,
+0xB5, 0xE0, 0x12, 0xFB, 0x1C, 0x7A, 0x99, 0x79,
+0xB4, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x07, 0x90,
+0x99, 0xB4, 0xE0, 0xF4, 0x70, 0x40, 0x31, 0x2F,
+0xA3, 0xE0, 0x14, 0xF0, 0x80, 0xDC, 0xB1, 0xF6,
+0xF0, 0x71, 0xE2, 0x40, 0x31, 0x90, 0x99, 0xB5,
+0xE0, 0xFD, 0x7C, 0x00, 0x24, 0xA8, 0xFF, 0xEC,
+0x34, 0x01, 0xFE, 0xED, 0x24, 0x01, 0xFD, 0xEC,
+0x33, 0xFC, 0x90, 0x99, 0xB7, 0xE0, 0x12, 0xFB,
+0x12, 0xF1, 0x95, 0x8D, 0x82, 0x8C, 0x83, 0x12,
+0x02, 0x1F, 0xFD, 0x12, 0xC8, 0x3C, 0x31, 0x2F,
+0xA3, 0xE0, 0x14, 0xF0, 0x80, 0xCB, 0x22, 0x90,
+0x99, 0xB5, 0xE0, 0x04, 0xF0, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xE4, 0x90, 0x99,
+0xB1, 0xF0, 0xA3, 0xF0, 0x90, 0x99, 0xB6, 0xF0,
+0x90, 0x02, 0x09, 0xE0, 0x90, 0x99, 0xB7, 0xF0,
+0x90, 0x98, 0x45, 0xF1, 0xF1, 0x90, 0x99, 0xB1,
+0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x8E, 0x99,
+0xE0, 0x90, 0x95, 0xE9, 0xF0, 0x74, 0x01, 0x2F,
+0x71, 0xF0, 0xE0, 0x90, 0x95, 0xEA, 0xF0, 0x71,
+0xDA, 0x12, 0x02, 0xE7, 0x90, 0x99, 0xB1, 0xA3,
+0xE0, 0x24, 0x02, 0x12, 0xD7, 0x0F, 0xFF, 0xE4,
+0xFC, 0xFD, 0x78, 0x10, 0x12, 0x03, 0xFE, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x71,
+0xCD, 0x12, 0xAF, 0x11, 0x78, 0x18, 0x12, 0x03,
+0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x80, 0xC0, 0xC0, 0x04, 0xC0, 0x05,
+0xC0, 0x06, 0xC0, 0x07, 0x71, 0xC0, 0x12, 0xAF,
+0x11, 0x78, 0x08, 0x12, 0x03, 0xFE, 0xD0, 0x03,
+0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x8E,
+0x89, 0x12, 0xAF, 0x13, 0x12, 0x80, 0xC0, 0x90,
+0x95, 0xED, 0x12, 0xAE, 0xF8, 0x78, 0x10, 0x12,
+0x03, 0xFE, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x71, 0xCD, 0x12, 0xAF, 0x11, 0x78,
+0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x80, 0xC0, 0xC0,
+0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x71,
+0xC0, 0x12, 0xAF, 0x11, 0x78, 0x08, 0x12, 0x03,
+0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x8E, 0x89, 0x12, 0xAF, 0x13, 0x12,
+0x80, 0xC0, 0x90, 0x95, 0xF1, 0x12, 0xAE, 0xF8,
+0x78, 0x10, 0x12, 0x03, 0xFE, 0xC0, 0x04, 0xC0,
+0x05, 0xC0, 0x06, 0xC0, 0x07, 0x71, 0xCD, 0x12,
+0xAF, 0x11, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0,
+0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12,
+0x80, 0xC0, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
+0xC0, 0x07, 0x71, 0xC0, 0x12, 0xAF, 0x11, 0x78,
+0x08, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x8E, 0x89, 0x12,
+0xAF, 0x13, 0x12, 0x80, 0xC0, 0x90, 0x95, 0xF5,
+0x12, 0x04, 0x31, 0x71, 0xDA, 0x71, 0xAC, 0x71,
+0xB5, 0x12, 0x8E, 0x99, 0xE0, 0xFF, 0x12, 0xFB,
+0x26, 0x71, 0x9A, 0xE0, 0xB4, 0x10, 0xF0, 0x71,
+0xA5, 0x71, 0xB5, 0x12, 0x8E, 0x99, 0xE0, 0xFF,
+0x74, 0x09, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x96,
+0x71, 0x9A, 0xE0, 0xB4, 0x10, 0xEB, 0x71, 0xA5,
+0x71, 0xB5, 0x12, 0x8E, 0x99, 0xE0, 0xFF, 0x74,
+0x19, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x96, 0x71,
+0x9A, 0xE0, 0xB4, 0x10, 0xEB, 0x90, 0x99, 0xB1,
+0xF1, 0xA2, 0x90, 0x98, 0x45, 0x12, 0x8E, 0x80,
+0xE4, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x99, 0xB1,
+0xE4, 0x75, 0xF0, 0x40, 0x71, 0xAC, 0x90, 0x99,
+0xB3, 0xE0, 0xFF, 0xC3, 0x94, 0x08, 0x50, 0x1F,
+0x90, 0x99, 0xB1, 0xA3, 0xE0, 0xFE, 0xEF, 0x2E,
+0x12, 0x8E, 0x99, 0xE0, 0xFE, 0x90, 0x99, 0xB7,
+0xE0, 0xFD, 0xEE, 0x2D, 0xFE, 0x74, 0x29, 0x2F,
+0xF1, 0xE9, 0xEE, 0x71, 0x9D, 0x80, 0xD7, 0x90,
+0x98, 0x45, 0xE0, 0x04, 0x90, 0x99, 0xB5, 0xF0,
+0xE4, 0x90, 0x99, 0xB4, 0xF0, 0x90, 0x95, 0xE9,
+0xE0, 0x13, 0x13, 0x54, 0x3F, 0x24, 0x01, 0xFF,
+0xE4, 0x33, 0xFE, 0x90, 0x99, 0xB4, 0xE0, 0xC3,
+0x9F, 0xEE, 0xD1, 0x9F, 0x50, 0x75, 0xA3, 0x12,
+0x8E, 0x80, 0xE4, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4,
+0xA3, 0xF0, 0x90, 0x99, 0xB3, 0xE0, 0xFD, 0xC3,
+0x94, 0x04, 0x50, 0x55, 0xA3, 0xE0, 0x75, 0xF0,
+0x04, 0xA4, 0x7C, 0x00, 0x2D, 0xFF, 0xEC, 0x35,
+0xF0, 0xFE, 0x90, 0x95, 0xE9, 0xE0, 0xFD, 0xC3,
+0xEF, 0x9D, 0x74, 0x80, 0xF8, 0x6E, 0x98, 0x50,
+0x38, 0xEF, 0x78, 0x05, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0x24, 0x31, 0xF9, 0x74, 0x96,
+0x3E, 0xFA, 0x7B, 0x01, 0xC0, 0x03, 0xC0, 0x01,
+0x90, 0x99, 0xB1, 0xA3, 0xE0, 0x24, 0x00, 0xF9,
+0xE4, 0x34, 0xFC, 0x8B, 0x45, 0xF5, 0x46, 0x89,
+0x47, 0x75, 0x48, 0x20, 0xD0, 0x01, 0xD0, 0x03,
+0x12, 0x8F, 0x63, 0xF1, 0xA9, 0x71, 0x9E, 0x80,
+0xA1, 0x31, 0x2F, 0x90, 0x99, 0xB4, 0xE0, 0x04,
+0xF0, 0x41, 0xF5, 0xE4, 0x90, 0x99, 0xB3, 0xF0,
+0xE4, 0xFF, 0x0F, 0xEF, 0xB4, 0x20, 0xFB, 0x71,
+0x9E, 0xE0, 0xB4, 0x10, 0xF3, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x99,
+0xB3, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x99, 0xB1,
+0xE4, 0x75, 0xF0, 0x10, 0x12, 0x02, 0xE7, 0xE4,
+0x90, 0x99, 0xB3, 0xF0, 0x22, 0x90, 0x99, 0xB1,
+0xA3, 0xE0, 0xFF, 0xA3, 0xE0, 0xFE, 0x2F, 0x22,
+0x90, 0x99, 0xB1, 0xA3, 0xE0, 0x24, 0x01, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0x22, 0x90, 0x99, 0xB1,
+0xA3, 0xE0, 0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0x22, 0x90, 0x99, 0xB1, 0xE4, 0x75, 0xF0,
+0x04, 0x22, 0x90, 0x99, 0xB6, 0xE0, 0xD3, 0x94,
+0x00, 0x22, 0x74, 0x03, 0xF0, 0x74, 0x01, 0x2E,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x9C, 0x6E, 0xEC, 0xF1, 0xE1, 0xAA, 0x07, 0x90,
+0x9C, 0x75, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0x00, 0xB1, 0xEB, 0xEA, 0x24, 0xEF, 0x60, 0x3A,
+0x24, 0xD7, 0x70, 0x02, 0xA1, 0x53, 0x24, 0x3A,
+0x60, 0x02, 0xA1, 0x8D, 0xB1, 0xC1, 0x24, 0x0A,
+0xB1, 0xCF, 0xED, 0xF0, 0xFE, 0x12, 0x8E, 0x99,
+0xE4, 0x71, 0xEC, 0xE4, 0xF0, 0xFE, 0x74, 0x00,
+0x2F, 0xB1, 0xE3, 0x7D, 0x14, 0xB1, 0xAA, 0x12,
+0xB7, 0x9A, 0xB1, 0xB5, 0x90, 0x90, 0xBE, 0x12,
+0x04, 0x31, 0x7D, 0x14, 0x7C, 0x00, 0xE4, 0xFF,
+0xA1, 0x4E, 0x90, 0x9C, 0x6E, 0xE4, 0x75, 0xF0,
+0x14, 0x12, 0x02, 0xE7, 0x90, 0x9C, 0x6E, 0xA3,
+0xE0, 0xFB, 0xFF, 0x24, 0x06, 0xFC, 0xB1, 0xD0,
+0xCC, 0xF0, 0x90, 0x9C, 0x79, 0xA3, 0xE0, 0xFE,
+0x12, 0x8E, 0x99, 0xE4, 0x71, 0xEC, 0xE4, 0x12,
+0xD7, 0x18, 0xFE, 0xA9, 0x03, 0x74, 0x05, 0x29,
+0xF1, 0xB0, 0xF1, 0x8C, 0xFE, 0x90, 0x9C, 0x73,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x9C, 0x6E, 0xE0,
+0xFC, 0xA3, 0xE0, 0x2F, 0xFF, 0xEC, 0x3E, 0xFE,
+0xD3, 0xEF, 0x94, 0x00, 0xEE, 0x94, 0x01, 0x90,
+0x9C, 0x6E, 0x40, 0x66, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0xE9, 0x7C, 0x00, 0x24, 0x00, 0xF9, 0xEC,
+0x34, 0xFC, 0xFA, 0x7B, 0x01, 0xC3, 0xE4, 0x9F,
+0xFD, 0x74, 0x01, 0x9E, 0xFC, 0xB1, 0xAC, 0x90,
+0x9C, 0x70, 0xE0, 0x24, 0x01, 0xFF, 0xE4, 0x33,
+0xA2, 0xE7, 0x13, 0xEF, 0x13, 0x90, 0xFD, 0x10,
+0xF0, 0xB1, 0xDD, 0xC0, 0x00, 0xC0, 0x01, 0xC0,
+0x02, 0xC0, 0x03, 0x7B, 0x01, 0x7A, 0xFC, 0x79,
+0x00, 0x90, 0x9C, 0x6E, 0xF1, 0x9B, 0xE4, 0x9F,
+0xFF, 0x74, 0x01, 0x9E, 0xFE, 0xB1, 0xC8, 0xE0,
+0xC3, 0x9F, 0xFD, 0xEC, 0x9E, 0xFC, 0x12, 0x45,
+0xC2, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
+0x00, 0x12, 0x80, 0xC0, 0xB1, 0xAF, 0xB1, 0xEB,
+0x80, 0x0E, 0xA3, 0xE0, 0x7E, 0x00, 0x24, 0x00,
+0xB1, 0xE3, 0xB1, 0xC8, 0xE0, 0xFD, 0xB1, 0xAC,
+0x90, 0x9C, 0x6E, 0x74, 0xFF, 0x75, 0xF0, 0xEC,
+0x12, 0x02, 0xE7, 0xB1, 0xC1, 0x7E, 0x00, 0x24,
+0x0C, 0xF9, 0xEE, 0x34, 0xFC, 0xFA, 0x7B, 0x01,
+0xC0, 0x02, 0xC0, 0x01, 0x74, 0x10, 0x2F, 0xF9,
+0xEE, 0x34, 0xFC, 0xFA, 0xB1, 0xB5, 0x90, 0x90,
+0xBE, 0x12, 0x04, 0x31, 0xB1, 0xC8, 0xE0, 0xFD,
+0xD0, 0x01, 0xD0, 0x02, 0x7F, 0x11, 0x12, 0x3C,
+0xD9, 0x80, 0x32, 0xB1, 0xC1, 0x24, 0x2A, 0xB1,
+0xCF, 0xED, 0xF0, 0xFE, 0x12, 0x8E, 0x99, 0xE4,
+0x71, 0xEC, 0xE4, 0xF0, 0x12, 0xF9, 0xEE, 0x7D,
+0x48, 0xB1, 0xAA, 0xB1, 0xBB, 0xB1, 0xD8, 0x12,
+0x80, 0xC0, 0xE4, 0xFD, 0xFC, 0xB1, 0xAF, 0xB1,
+0xBB, 0xB1, 0xD8, 0x12, 0x80, 0xC0, 0xB1, 0xAF,
+0xB1, 0xBB, 0x12, 0x03, 0xCD, 0x90, 0x9C, 0x71,
+0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x9C, 0x71,
+0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xEC, 0xFF, 0x90,
+0x9C, 0x79, 0xA3, 0xE0, 0xFE, 0x12, 0x8E, 0x99,
+0xEF, 0x71, 0xEC, 0xED, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x7C, 0x00, 0x12, 0x45, 0xC2, 0x90,
+0x9C, 0x75, 0x02, 0x04, 0x31, 0x90, 0x90, 0xBB,
+0x12, 0x82, 0x27, 0x90, 0x9C, 0x75, 0x02, 0x04,
+0xB8, 0x90, 0x9C, 0x6E, 0xA3, 0xE0, 0xFF, 0x22,
+0x90, 0x9C, 0x73, 0xE0, 0xFC, 0xA3, 0x22, 0xFD,
+0xE4, 0x33, 0x90, 0x9C, 0x79, 0xF0, 0xA3, 0x22,
+0x78, 0x10, 0x12, 0x03, 0xEB, 0x90, 0x9C, 0x75,
+0x02, 0x82, 0x12, 0xF9, 0xEE, 0x34, 0xFC, 0xFA,
+0x7B, 0x01, 0x22, 0x90, 0x9C, 0x70, 0xE0, 0xC3,
+0x13, 0x90, 0xFD, 0x10, 0xF0, 0x22, 0x90, 0x99,
+0xB7, 0xE0, 0x90, 0x99, 0xB5, 0xF0, 0x90, 0x99,
+0xB8, 0xE0, 0x90, 0x99, 0xB6, 0x22, 0xE4, 0x90,
+0x9A, 0xFE, 0xF0, 0xA3, 0xF0, 0x90, 0x06, 0x32,
+0xE0, 0x44, 0x20, 0xF0, 0x12, 0x76, 0x9B, 0xEF,
+0x64, 0x01, 0x70, 0x75, 0x90, 0x98, 0x42, 0xE0,
+0xFF, 0x90, 0x92, 0x13, 0x74, 0x0D, 0xF0, 0x7B,
+0x08, 0x7D, 0x01, 0x12, 0x66, 0xDB, 0x90, 0x9A,
+0xFB, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x9A,
+0xFB, 0x12, 0x8E, 0xA3, 0x90, 0x9A, 0xFD, 0xEF,
+0xF0, 0x90, 0x9A, 0xFB, 0x12, 0xFA, 0x1D, 0x7B,
+0x01, 0xE4, 0xFD, 0x12, 0xF0, 0x46, 0x90, 0x9A,
+0xFD, 0xE0, 0xFF, 0x90, 0x9A, 0xFC, 0xE0, 0x2F,
+0xFF, 0x90, 0x9A, 0xFB, 0xE0, 0x34, 0x00, 0xCF,
+0x24, 0x30, 0xCF, 0x34, 0x00, 0xFE, 0x90, 0x9A,
+0xFE, 0xF0, 0xA3, 0xEF, 0xF0, 0xF1, 0xB8, 0xD1,
+0x92, 0x90, 0x98, 0x42, 0xE0, 0xFB, 0xE4, 0xFF,
+0x71, 0xF8, 0xD1, 0x92, 0x90, 0x98, 0x3E, 0xE0,
+0xFB, 0x7F, 0x11, 0x71, 0xF8, 0x90, 0x04, 0x1F,
+0x74, 0x20, 0xF0, 0x90, 0x95, 0xA5, 0x12, 0xBF,
+0xA5, 0x22, 0x90, 0x9A, 0xFE, 0xE0, 0xFC, 0xA3,
+0xE0, 0xFD, 0x22, 0xE0, 0xD3, 0x9D, 0xEC, 0x64,
+0x80, 0xF8, 0x74, 0x80, 0x98, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0xDE, 0x47,
+0x90, 0x9C, 0xE7, 0xF0, 0x90, 0x88, 0x32, 0x12,
+0xA8, 0xA9, 0x30, 0xE0, 0x02, 0xE1, 0x6E, 0x90,
+0x88, 0x31, 0xE0, 0x30, 0xE0, 0x1F, 0x90, 0x88,
+0x53, 0xE0, 0x24, 0x04, 0x33, 0x33, 0x33, 0x54,
+0xF8, 0x90, 0x88, 0x4B, 0xF0, 0x90, 0x88, 0x53,
+0xE0, 0x04, 0x33, 0x33, 0x33, 0x54, 0xF8, 0x90,
+0x88, 0x4A, 0xF0, 0x80, 0x10, 0x90, 0x88, 0x4B,
+0x74, 0x10, 0xF0, 0x90, 0x88, 0x4A, 0x74, 0x08,
+0xF0, 0x74, 0x10, 0x2B, 0xFB, 0x90, 0x88, 0x4A,
+0xE0, 0xFE, 0x90, 0x88, 0x49, 0xE0, 0xD3, 0x9E,
+0x50, 0x0E, 0x90, 0x88, 0x3E, 0xEB, 0xF0, 0x90,
+0x88, 0x4B, 0xE0, 0xC3, 0x9D, 0x2F, 0x80, 0x11,
+0xC3, 0xED, 0x9E, 0x2B, 0x90, 0x88, 0x3E, 0xF0,
+0x90, 0x88, 0x4A, 0xE0, 0xFF, 0xA3, 0xE0, 0xC3,
+0x9F, 0x90, 0x88, 0x4E, 0xF0, 0x90, 0x88, 0x4B,
+0xF1, 0x7A, 0x90, 0x88, 0x4E, 0xD1, 0x9B, 0x40,
+0x04, 0xEF, 0x24, 0x50, 0xF0, 0x90, 0x88, 0x4E,
+0xF1, 0x7A, 0x90, 0x88, 0x3E, 0xD1, 0x9B, 0x40,
+0x04, 0xEF, 0x24, 0x50, 0xF0, 0x90, 0x88, 0x4E,
+0x12, 0x97, 0xD1, 0xFF, 0x7E, 0x00, 0x90, 0x88,
+0x42, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x05,
+0x58, 0xF0, 0x90, 0x88, 0x4E, 0xE0, 0x54, 0x07,
+0xFF, 0x90, 0x05, 0xB1, 0xE0, 0x54, 0xF8, 0x4F,
+0xF0, 0x12, 0xFB, 0x75, 0x80, 0x07, 0x90, 0x88,
+0x33, 0xE0, 0x44, 0x01, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xE0, 0xFF, 0x24, 0x50, 0xFD, 0xE4,
+0x33, 0xFC, 0x22, 0xF0, 0x90, 0x01, 0x17, 0xE0,
+0xFE, 0x90, 0x01, 0x16, 0xE0, 0x7C, 0x00, 0x24,
+0x00, 0xFF, 0xEC, 0x3E, 0x22, 0x90, 0x99, 0xB1,
+0x02, 0x82, 0x1E, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0xC3, 0x22, 0xE4, 0x75, 0xF0, 0x10, 0x02, 0x02,
+0xE7, 0xE4, 0x75, 0xF0, 0x20, 0x02, 0x02, 0xE7,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22,
+0xAD, 0x07, 0x90, 0x95, 0x9D, 0x12, 0xBF, 0xA5,
+0x90, 0x95, 0x9D, 0xE0, 0xFF, 0xAE, 0x05, 0x74,
+0x04, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xEF, 0xF0, 0x90, 0x95, 0x9D, 0xA3, 0xE0,
+0xFF, 0x74, 0x05, 0x2E, 0xF1, 0xB0, 0xEF, 0xF0,
+0x22, 0xF0, 0xA3, 0xED, 0xF0, 0xA3, 0xEB, 0xF0,
+0x22, 0xF5, 0x82, 0xE4, 0x34, 0x96, 0xF5, 0x83,
+0x22, 0xE0, 0xFF, 0x12, 0x7B, 0x07, 0x7E, 0x00,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x7F, 0x8F, 0x12, 0x7B, 0x41, 0xEF, 0x30, 0xE6,
+0x2E, 0x90, 0x00, 0x8C, 0xE0, 0x90, 0x9C, 0xCA,
+0xF0, 0x7F, 0x8D, 0x12, 0x7B, 0x41, 0x90, 0x9C,
+0xCB, 0xEF, 0xF0, 0x90, 0x00, 0x8E, 0xE0, 0x90,
+0x9C, 0xCC, 0xF0, 0x90, 0x9C, 0xCB, 0xE0, 0x7F,
+0x8F, 0x12, 0x7B, 0x41, 0xEF, 0x30, 0xE0, 0x07,
+0xE4, 0xFD, 0x7F, 0x8D, 0x12, 0x7B, 0x2E, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0xE4, 0x90, 0x99, 0xB9,
+0xF0, 0x90, 0x00, 0x37, 0xE0, 0x44, 0x80, 0xF0,
+0x90, 0x00, 0xCF, 0x74, 0x69, 0xF0, 0xEF, 0x90,
+0x00, 0x31, 0xF0, 0xEE, 0x54, 0x03, 0xFF, 0xA3,
+0xE0, 0x54, 0xFC, 0x4F, 0xF0, 0x90, 0x00, 0x30,
+0xED, 0xF0, 0x90, 0x00, 0x33, 0xE0, 0x44, 0x80,
+0xF0, 0x90, 0x00, 0x33, 0xE0, 0x30, 0xE7, 0x09,
+0x11, 0x8E, 0x50, 0x05, 0xE0, 0x04, 0xF0, 0x80,
+0xF0, 0x90, 0x00, 0xCF, 0xE4, 0xF0, 0x90, 0x00,
+0x37, 0xE0, 0x54, 0x7F, 0xF0, 0x11, 0x8E, 0x7F,
+0x00, 0x50, 0x02, 0x7F, 0x01, 0x22, 0x90, 0x99,
+0xB9, 0xE0, 0xC3, 0x94, 0x64, 0x22, 0xE4, 0x90,
+0x86, 0xAF, 0x12, 0x9F, 0xAF, 0x90, 0x93, 0x01,
+0xF0, 0x90, 0x98, 0x6A, 0xF0, 0xA3, 0xF0, 0x22,
+0x90, 0x00, 0x80, 0xE0, 0x44, 0x80, 0xF0, 0x12,
+0xD7, 0xE8, 0x31, 0x2D, 0x12, 0x7B, 0x79, 0x12,
+0xE2, 0x33, 0x11, 0x96, 0x7F, 0x01, 0x12, 0x85,
+0x15, 0x90, 0x98, 0x4B, 0x74, 0x02, 0xF0, 0xFF,
+0x12, 0x85, 0x15, 0x90, 0x98, 0x4B, 0xE0, 0x04,
+0xF0, 0x51, 0x90, 0x31, 0x5A, 0x90, 0x00, 0x80,
+0xE0, 0x44, 0x40, 0xF0, 0x75, 0x20, 0xFF, 0x12,
+0x7C, 0x97, 0x53, 0xA8, 0xFE, 0x90, 0x01, 0xA0,
+0xE0, 0xB4, 0xFD, 0x05, 0xE4, 0xFF, 0x12, 0x90,
+0x50, 0x51, 0xF1, 0x31, 0x42, 0x90, 0x00, 0x81,
+0xE0, 0x44, 0x04, 0xF0, 0xF1, 0xC3, 0x12, 0x99,
+0xB0, 0x90, 0x00, 0xAA, 0xE0, 0x44, 0x02, 0xF0,
+0xA3, 0xE0, 0x44, 0x80, 0xF0, 0x90, 0x99, 0xB0,
+0xE0, 0x54, 0xFE, 0xF0, 0x90, 0x06, 0x0A, 0xE0,
+0x44, 0x10, 0xF0, 0x90, 0x07, 0xDB, 0xE0, 0x44,
+0x80, 0xF0, 0x90, 0x06, 0x0D, 0x74, 0xFF, 0xF0,
+0xE4, 0xFF, 0x02, 0x85, 0x9E, 0x90, 0x01, 0x94,
+0xE0, 0x44, 0x01, 0x80, 0x06, 0x90, 0x93, 0x31,
+0xE0, 0x54, 0xFE, 0xF0, 0x90, 0x01, 0xC7, 0xE4,
+0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0xE4, 0xFF, 0x12, 0xF9, 0x87, 0xE4, 0xF0,
+0x0F, 0xEF, 0xB4, 0x08, 0xF6, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xF1, 0x63, 0x12, 0x7B, 0xDB, 0x12,
+0x92, 0xD5, 0x12, 0xA7, 0x82, 0x31, 0x89, 0x51,
+0x79, 0x12, 0xDC, 0xDF, 0x90, 0x98, 0x64, 0xE0,
+0x54, 0x7F, 0xF0, 0x54, 0xBF, 0xF0, 0x54, 0xDF,
+0xF0, 0x54, 0xF0, 0xF0, 0xE4, 0x90, 0x98, 0x66,
+0xF0, 0x90, 0x98, 0x64, 0xE0, 0x54, 0xEF, 0xF0,
+0x22, 0x7E, 0x00, 0x7F, 0x29, 0x7D, 0x00, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0x24, 0x12, 0x04, 0x80,
+0x90, 0x06, 0x90, 0xE0, 0x54, 0xDF, 0xF0, 0x91,
+0x8A, 0x12, 0x9F, 0xB7, 0x90, 0x86, 0xB3, 0xE0,
+0xFF, 0x64, 0x02, 0x70, 0x2E, 0x90, 0xFD, 0x80,
+0xE0, 0x7E, 0x00, 0x30, 0xE0, 0x02, 0x7E, 0x01,
+0x90, 0x93, 0x47, 0x51, 0x72, 0x7E, 0x00, 0x30,
+0xE1, 0x02, 0x7E, 0x01, 0x90, 0x93, 0x45, 0x51,
+0x72, 0x7E, 0x00, 0x30, 0xE2, 0x02, 0x7E, 0x01,
+0x90, 0x93, 0x46, 0x51, 0x72, 0x90, 0x02, 0xFB,
+0xF0, 0x80, 0x52, 0xEF, 0x64, 0x01, 0x70, 0x21,
+0x51, 0x6B, 0x30, 0xE0, 0x02, 0x7F, 0x01, 0x90,
+0x93, 0x47, 0xEF, 0xF0, 0x51, 0x6B, 0x30, 0xE1,
+0x02, 0x7F, 0x01, 0x90, 0x93, 0x45, 0xEF, 0xF0,
+0x51, 0x6B, 0x30, 0xE2, 0x02, 0x7F, 0x01, 0x80,
+0x27, 0x90, 0x86, 0xB3, 0xE0, 0x64, 0x03, 0x70,
+0x24, 0x51, 0x64, 0x30, 0xE0, 0x02, 0x7F, 0x01,
+0x90, 0x93, 0x47, 0xEF, 0xF0, 0x51, 0x64, 0x30,
+0xE1, 0x02, 0x7F, 0x01, 0x90, 0x93, 0x45, 0xEF,
+0xF0, 0x51, 0x64, 0x30, 0xE2, 0x02, 0x7F, 0x01,
+0x90, 0x93, 0x46, 0xEF, 0xF0, 0x90, 0x93, 0x24,
+0xE0, 0x54, 0xEF, 0xF0, 0xE4, 0x90, 0x95, 0xE9,
+0xF0, 0xA3, 0xF0, 0x90, 0x95, 0xF1, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x00, 0x00, 0x90, 0x95, 0xF5,
 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x00, 0x90,
-0x98, 0x05, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0x00, 0x22, 0x90, 0xFD, 0x78, 0xE0, 0x7F, 0x00,
-0x22, 0x90, 0xFD, 0x70, 0xE0, 0x7F, 0x00, 0x22,
-0xEE, 0xF0, 0x90, 0xFD, 0x80, 0xE0, 0x22, 0x90,
-0x93, 0x24, 0x12, 0xF5, 0x9F, 0x30, 0xE0, 0x02,
-0x11, 0x15, 0x22, 0x51, 0x0F, 0x90, 0x93, 0x24,
-0xE0, 0xFF, 0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x04,
-0xB1, 0x52, 0x31, 0xC3, 0x22, 0x90, 0x9A, 0x0C,
-0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x9A, 0x0A,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xE4, 0x90, 0x9A,
-0x30, 0xF0, 0xEF, 0x24, 0x24, 0xFF, 0xE4, 0x3E,
-0xFE, 0xC0, 0x06, 0xB1, 0x2A, 0xD0, 0x06, 0xE4,
-0xFB, 0xFA, 0x91, 0xFA, 0x4E, 0x60, 0x3B, 0xE0,
-0x24, 0x01, 0x91, 0x43, 0x12, 0x8B, 0xE7, 0x90,
-0x9A, 0x0F, 0xB1, 0x13, 0x90, 0x9A, 0x0F, 0xB1,
-0x09, 0xFE, 0xC3, 0x9F, 0x50, 0x24, 0x90, 0x9A,
-0x32, 0xE0, 0x24, 0x02, 0xFD, 0x91, 0x44, 0xFC,
-0xEE, 0x7E, 0x00, 0x2D, 0x12, 0x8B, 0xE4, 0x90,
-0x9A, 0x0E, 0xE0, 0x24, 0x10, 0xF5, 0x82, 0xE4,
-0x34, 0x9A, 0xF5, 0x83, 0xEF, 0xF0, 0x91, 0x55,
-0x80, 0xD2, 0xB1, 0x1B, 0xC0, 0x06, 0xB1, 0x2A,
-0xD0, 0x06, 0x7B, 0x03, 0x91, 0xF7, 0x90, 0x9A,
-0x0B, 0xE0, 0x24, 0x22, 0xB1, 0x21, 0x90, 0x9A,
-0x31, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x8B, 0xE8,
-0xEF, 0x20, 0xE4, 0x02, 0x61, 0x5A, 0x90, 0x9A,
-0x30, 0xE0, 0x04, 0xF0, 0xB1, 0x1B, 0xC0, 0x06,
-0xB1, 0x2A, 0xD0, 0x06, 0x7B, 0x30, 0x91, 0xF7,
-0x4E, 0x60, 0x3E, 0xE0, 0x24, 0x08, 0x91, 0x43,
-0x12, 0x8B, 0xE7, 0xB1, 0x10, 0xB1, 0x06, 0xC3,
-0x9F, 0x50, 0x2E, 0x90, 0x9A, 0x32, 0xE0, 0x24,
-0x0D, 0x91, 0x43, 0x12, 0x8B, 0xE7, 0x90, 0x9A,
-0x33, 0xEF, 0xF0, 0xBF, 0x02, 0x09, 0x90, 0x9A,
-0x30, 0xE0, 0x24, 0x20, 0xF0, 0x80, 0x0E, 0x90,
-0x9A, 0x33, 0xE0, 0xB4, 0x04, 0x07, 0x90, 0x9A,
-0x30, 0xE0, 0x24, 0x40, 0xF0, 0x91, 0x4B, 0x80,
-0xCC, 0xB1, 0x1B, 0xC0, 0x06, 0xB1, 0x2A, 0xD0,
-0x06, 0x7B, 0xDD, 0x7A, 0x00, 0x7D, 0x01, 0x91,
-0xFB, 0x4E, 0x60, 0x43, 0xE0, 0x24, 0x0C, 0x91,
-0x43, 0x12, 0x8B, 0xE7, 0xB1, 0x10, 0xB1, 0x06,
-0xC3, 0x9F, 0x50, 0x33, 0x90, 0x9A, 0x32, 0xE0,
-0x24, 0x11, 0x91, 0x43, 0x12, 0x8B, 0xE7, 0x90,
-0x9A, 0x33, 0xEF, 0xF0, 0xBF, 0x02, 0x09, 0x90,
-0x9A, 0x30, 0xE0, 0x24, 0x02, 0xF0, 0x80, 0x0E,
-0x90, 0x9A, 0x33, 0xE0, 0xB4, 0x04, 0x07, 0x90,
-0x9A, 0x30, 0xE0, 0x24, 0x04, 0xF0, 0x91, 0x4B,
-0x80, 0xCC, 0xE4, 0x90, 0x9A, 0x30, 0xF0, 0x90,
-0x95, 0xBD, 0xE0, 0x90, 0x04, 0xFD, 0xB1, 0x14,
-0x90, 0x95, 0xBD, 0xB1, 0x09, 0xFE, 0xC3, 0x9F,
-0x50, 0x61, 0x12, 0xF5, 0x58, 0xF5, 0x83, 0xE0,
-0xFF, 0x90, 0x9A, 0x0F, 0xE0, 0xFE, 0x6F, 0x70,
-0x4E, 0x90, 0x04, 0xFC, 0xE0, 0x04, 0xF0, 0x90,
-0x9A, 0x0E, 0xE0, 0x24, 0xDD, 0xF5, 0x82, 0xE4,
-0x34, 0x95, 0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x9A,
-0x30, 0xE0, 0xFD, 0x4F, 0x60, 0x04, 0xED, 0x5F,
-0x60, 0x2D, 0xEE, 0xFF, 0x7E, 0x00, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x9A, 0x0E, 0xE0, 0x75, 0xF0,
-0x20, 0xA4, 0x24, 0x05, 0xF9, 0x74, 0x96, 0xB1,
-0x48, 0x7D, 0x01, 0xD0, 0x07, 0xD0, 0x06, 0x12,
-0x83, 0xDC, 0xEF, 0x70, 0x0A, 0x90, 0x01, 0xC7,
-0x74, 0x55, 0x12, 0x8F, 0xC9, 0x51, 0x1D, 0x91,
-0x55, 0x80, 0x95, 0xE4, 0x90, 0x9A, 0x0E, 0xF0,
-0x90, 0x9A, 0x0E, 0xE0, 0xFF, 0xC3, 0x94, 0x03,
-0x50, 0x60, 0xA3, 0xE0, 0xFE, 0x60, 0x57, 0xEF,
-0x75, 0xF0, 0x21, 0xA4, 0x24, 0xFA, 0xF5, 0x82,
-0xE4, 0x34, 0x9A, 0xF5, 0x83, 0xE0, 0xFF, 0xEE,
-0x6F, 0x70, 0x43, 0x90, 0x04, 0xFC, 0xE0, 0x04,
-0xF0, 0x90, 0x9A, 0x0F, 0xE0, 0xFF, 0x7E, 0x00,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x9A, 0x0E, 0xE0,
-0x75, 0xF0, 0x21, 0xA4, 0x24, 0xFB, 0xF9, 0x74,
-0x9A, 0xB1, 0x48, 0x7D, 0x01, 0xD0, 0x07, 0xD0,
-0x06, 0x12, 0x83, 0xDC, 0xEF, 0x70, 0x17, 0x90,
-0x01, 0xC7, 0x74, 0x24, 0x12, 0x8F, 0xC9, 0x12,
-0xA7, 0x47, 0x30, 0xE0, 0x02, 0xB1, 0x52, 0xD1,
-0x87, 0xE4, 0xFF, 0x12, 0x87, 0xFA, 0x91, 0x55,
-0x80, 0x96, 0x22, 0xFF, 0x90, 0x9A, 0x31, 0xE0,
-0x34, 0x00, 0x22, 0x90, 0x9A, 0x31, 0xE4, 0x75,
-0xF0, 0x04, 0x12, 0x02, 0xE7, 0x90, 0x9A, 0x0E,
-0xE0, 0x04, 0xF0, 0x22, 0x90, 0x9A, 0x35, 0x12,
-0xE8, 0xF1, 0xA3, 0xEA, 0xF0, 0xA3, 0xEB, 0xF0,
-0xC3, 0x90, 0x9A, 0x3B, 0xE0, 0x94, 0x01, 0x90,
-0x9A, 0x3A, 0xE0, 0x94, 0x00, 0x50, 0x02, 0x80,
-0x7A, 0xE4, 0x90, 0x9A, 0x3E, 0xF0, 0xA3, 0xF0,
-0xB1, 0x3F, 0x12, 0x8B, 0xE8, 0x90, 0x9A, 0x38,
-0xE0, 0x70, 0x03, 0xA3, 0xE0, 0x6F, 0x70, 0x1D,
-0x90, 0x9A, 0x36, 0xE0, 0x24, 0x02, 0xFF, 0x90,
-0x9A, 0x35, 0xE0, 0x34, 0x00, 0xFE, 0x90, 0x9A,
-0x37, 0xE0, 0xFD, 0x12, 0xF0, 0xA9, 0xBF, 0x01,
-0x02, 0xA1, 0x3F, 0x80, 0x00, 0x90, 0x9A, 0x36,
-0xE0, 0x24, 0x01, 0xFF, 0x90, 0x9A, 0x35, 0xE0,
-0x34, 0x00, 0x12, 0x8B, 0xE7, 0x7E, 0x00, 0x90,
-0x9A, 0x3C, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x24,
-0x02, 0xFF, 0xEE, 0x33, 0xFE, 0x90, 0x9A, 0x35,
-0x8F, 0xF0, 0x12, 0x02, 0xE7, 0x90, 0x9A, 0x3E,
-0xEE, 0x8F, 0xF0, 0x12, 0x02, 0xE7, 0x90, 0x9A,
-0x3A, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xC3, 0x90,
-0x9A, 0x3F, 0xE0, 0x9F, 0x90, 0x9A, 0x3E, 0xE0,
-0x9E, 0x40, 0x8D, 0xE4, 0xFE, 0xFF, 0x22, 0x7A,
-0x00, 0xE4, 0xFD, 0x91, 0x5C, 0x90, 0x9A, 0x31,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x90, 0x9A,
-0x34, 0xE0, 0xFF, 0x90, 0x9A, 0x0E, 0xE0, 0x22,
-0x90, 0x9A, 0x34, 0xEF, 0xF0, 0xE4, 0x90, 0x9A,
-0x0E, 0xF0, 0x22, 0x90, 0x9A, 0x0B, 0xE0, 0x24,
-0x24, 0xFF, 0x90, 0x9A, 0x0A, 0xE0, 0x34, 0x00,
-0xFE, 0x22, 0x90, 0x9A, 0x0D, 0xE0, 0x24, 0xDC,
-0xFE, 0x90, 0x9A, 0x0C, 0xE0, 0x34, 0xFF, 0x90,
-0x9A, 0x3A, 0xF0, 0xA3, 0xCE, 0xF0, 0x22, 0x90,
-0x9A, 0x35, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0x35, 0xF0, 0xFA, 0x7B, 0x01, 0x78, 0x10, 0x7C,
-0x9A, 0x22, 0x90, 0x01, 0x53, 0xE4, 0xF0, 0xFF,
-0xEF, 0xD1, 0x79, 0xE4, 0xF0, 0x0F, 0xEF, 0xB4,
-0x08, 0xF6, 0x22, 0xE4, 0x90, 0x9C, 0x59, 0xF0,
-0x7F, 0x03, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x9C, 0x54, 0xEF, 0xF0, 0xB1, 0x52,
-0x90, 0x9C, 0x54, 0xE0, 0xFF, 0xD1, 0x79, 0x74,
-0x01, 0xF0, 0x90, 0x9C, 0x59, 0xE0, 0xFE, 0xEF,
-0xD1, 0xBD, 0xEE, 0xF0, 0x90, 0x9C, 0x54, 0xE0,
-0xB1, 0xCE, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0x01, 0xB1, 0xC3, 0x78, 0x10, 0x12, 0x03, 0xEB,
-0xAB, 0x07, 0xB1, 0xC3, 0x78, 0x08, 0x12, 0x03,
-0xEB, 0x90, 0x92, 0x20, 0xEF, 0xF0, 0xB1, 0xC3,
-0x90, 0x92, 0x21, 0xEF, 0xF0, 0x7D, 0x01, 0x7F,
-0x50, 0x7E, 0x01, 0x12, 0x66, 0x33, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x9C, 0x55, 0x02, 0x04,
-0xB8, 0x90, 0x9A, 0x08, 0xE0, 0xFB, 0x75, 0xF0,
-0x0A, 0xA4, 0x24, 0x5E, 0xF5, 0x82, 0xE4, 0x34,
-0x9B, 0xF5, 0x83, 0x22, 0xE4, 0x90, 0x9A, 0x08,
-0xF0, 0x90, 0x9A, 0x08, 0xE0, 0xFF, 0xC3, 0x94,
-0x08, 0x40, 0x02, 0xC1, 0x71, 0xEF, 0xD1, 0x79,
-0xE0, 0x64, 0x01, 0x70, 0x74, 0x90, 0x9A, 0x08,
-0xE0, 0xB1, 0xCE, 0x12, 0x04, 0xB8, 0xE4, 0x7B,
-0x01, 0xD1, 0x72, 0x70, 0x3A, 0x90, 0x9A, 0x08,
-0xE0, 0xFB, 0xD1, 0xBD, 0xE0, 0x60, 0x21, 0x14,
-0x70, 0x57, 0xEB, 0x75, 0xF0, 0x0A, 0xA4, 0x24,
-0x62, 0xF5, 0x82, 0xE4, 0x34, 0x9B, 0xF5, 0x83,
-0x12, 0x04, 0xB8, 0xEB, 0xB1, 0xCE, 0x12, 0x04,
-0x31, 0x90, 0x9A, 0x08, 0xE0, 0xFF, 0x80, 0x0B,
-0xB1, 0xC9, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0x00, 0xAF, 0x03, 0xD1, 0xCB, 0x80, 0x2A, 0x90,
-0x9A, 0x08, 0xE0, 0xB1, 0xCE, 0x12, 0x04, 0xB8,
-0xE4, 0xFB, 0xD1, 0x72, 0x50, 0x1B, 0xB1, 0xC9,
-0x12, 0x04, 0xB8, 0xEF, 0x24, 0xFF, 0xFF, 0xEE,
-0x34, 0xFF, 0xFE, 0xED, 0x34, 0xFF, 0xFD, 0xEC,
-0x34, 0xFF, 0xFC, 0xEB, 0xB1, 0xCE, 0x12, 0x04,
-0x31, 0x90, 0x9A, 0x08, 0xE0, 0x04, 0xF0, 0xA1,
-0xE1, 0x22, 0xFA, 0xF9, 0xF8, 0xC3, 0x02, 0x03,
-0xDA, 0x75, 0xF0, 0x0A, 0xA4, 0x24, 0x67, 0xF5,
-0x82, 0xE4, 0x34, 0x9B, 0xF5, 0x83, 0x22, 0x12,
-0xF2, 0xBF, 0x79, 0x08, 0x02, 0x04, 0x80, 0xF1,
-0xD8, 0x12, 0x7B, 0xDB, 0x12, 0xF1, 0xBE, 0xD1,
-0x87, 0x31, 0x1F, 0x12, 0xDA, 0x4B, 0xF1, 0x66,
-0x90, 0x98, 0x38, 0xE0, 0x54, 0x7F, 0xF0, 0x54,
-0xBF, 0xF0, 0x54, 0xDF, 0xF0, 0x54, 0xF0, 0xF0,
-0xE4, 0x90, 0x98, 0x3A, 0xF0, 0x90, 0x98, 0x38,
-0xE0, 0x54, 0xEF, 0xF0, 0x22, 0x75, 0xF0, 0x0A,
-0xA4, 0x24, 0x66, 0xF5, 0x82, 0xE4, 0x34, 0x9B,
-0xF5, 0x83, 0x22, 0xEF, 0x24, 0xFC, 0x60, 0x05,
-0x04, 0x70, 0x05, 0x80, 0x04, 0x12, 0xD4, 0x2C,
-0x22, 0xE4, 0x90, 0x9A, 0x09, 0xF0, 0x90, 0x9B,
-0x5D, 0x04, 0xF0, 0x90, 0x06, 0x32, 0xE0, 0x44,
-0x04, 0xF0, 0x90, 0x98, 0x05, 0x12, 0x04, 0xB8,
-0xEF, 0x24, 0x01, 0x12, 0xCA, 0xAD, 0x90, 0x98,
-0x05, 0x12, 0x04, 0x31, 0x12, 0xD3, 0x3E, 0xE4,
-0x90, 0x9A, 0xDE, 0xF0, 0xFF, 0x12, 0xF0, 0x2E,
-0x12, 0xB3, 0x4A, 0x70, 0x4A, 0x90, 0x8A, 0xB9,
-0x12, 0x97, 0x5E, 0x7D, 0x01, 0x7F, 0x02, 0x12,
-0x04, 0x7E, 0x7F, 0x05, 0x7E, 0x00, 0x12, 0x7A,
-0xAE, 0x12, 0xF5, 0x6A, 0x90, 0x8A, 0x89, 0x12,
-0x97, 0x5E, 0xF1, 0xE3, 0x90, 0x88, 0x39, 0xE0,
-0x64, 0x02, 0x60, 0x23, 0x90, 0x9A, 0x09, 0xE0,
-0x04, 0xF0, 0x7F, 0x01, 0x7E, 0x00, 0x12, 0x7A,
-0xAE, 0x90, 0x8A, 0xB9, 0x12, 0x97, 0x5E, 0x7D,
-0x01, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x90, 0x9A,
-0x09, 0xE0, 0xD3, 0x94, 0x0A, 0x40, 0xD5, 0x90,
-0x9C, 0x55, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0x0A, 0x12, 0xD7, 0x73, 0xA1, 0x6A, 0x12, 0xF5,
-0x73, 0x7A, 0x98, 0x79, 0x24, 0x12, 0x04, 0x80,
-0x90, 0x98, 0x25, 0x74, 0x08, 0xF0, 0xA3, 0x74,
-0x03, 0xF0, 0x22, 0xF1, 0xEA, 0x30, 0xE0, 0x17,
-0x90, 0x93, 0x04, 0xE0, 0xFF, 0xC4, 0x54, 0x0F,
-0x20, 0xE0, 0x0C, 0x90, 0x9C, 0x55, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x14, 0xB1, 0x63, 0x22,
-0x90, 0x93, 0x08, 0xE0, 0x30, 0xE0, 0x38, 0x12,
-0xF5, 0x61, 0x90, 0x93, 0x0B, 0xE0, 0x60, 0x0B,
-0x14, 0xF0, 0x90, 0x9B, 0x5D, 0xE0, 0x70, 0x27,
-0x02, 0x79, 0xD4, 0x12, 0xF5, 0x4E, 0xE4, 0xFF,
-0x12, 0x87, 0xFA, 0x90, 0x93, 0x04, 0xE0, 0xFF,
-0x20, 0xE0, 0x08, 0x13, 0x13, 0x13, 0x54, 0x1F,
-0x30, 0xE0, 0x0C, 0x90, 0x9C, 0x55, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x01, 0xB1, 0x63, 0x22,
-0xE4, 0xFD, 0xFF, 0x02, 0x6E, 0x71, 0xF1, 0xE2,
-0x80, 0x99, 0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02,
-0x04, 0x7E, 0x90, 0x93, 0x24, 0xE0, 0xC4, 0x54,
-0x0F, 0x22, 0x12, 0x02, 0x06, 0xFF, 0x90, 0x98,
-0x2C, 0xF0, 0xBF, 0x01, 0x0A, 0x7F, 0x01, 0x12,
-0x99, 0x5D, 0xE4, 0x90, 0x98, 0x2C, 0xF0, 0x22,
-0xEF, 0xB4, 0xFF, 0x06, 0x90, 0x98, 0x3E, 0xED,
-0xF0, 0x22, 0xEF, 0xF4, 0xFE, 0x90, 0x98, 0x3E,
-0xE0, 0x5E, 0xFE, 0xED, 0x5F, 0x4E, 0xF0, 0x22,
-0xEF, 0xB4, 0xFF, 0x06, 0x90, 0x98, 0x3F, 0xED,
-0xF0, 0x22, 0xEF, 0xF4, 0xFE, 0x90, 0x98, 0x3F,
-0x80, 0xE6, 0x90, 0x9C, 0x99, 0xED, 0xF0, 0x64,
-0x01, 0x60, 0x26, 0xE0, 0xFE, 0x64, 0x02, 0x60,
-0x20, 0xEE, 0x64, 0x29, 0x60, 0x1B, 0xEE, 0x64,
-0x2A, 0x60, 0x16, 0xEE, 0x64, 0x36, 0x60, 0x11,
-0xEE, 0xB4, 0x37, 0x02, 0x80, 0x0B, 0xAD, 0x07,
-0x7F, 0xFF, 0x11, 0x20, 0x90, 0x98, 0x3F, 0xE0,
-0xFF, 0x90, 0x98, 0x3E, 0xE0, 0x4F, 0x90, 0x05,
-0x22, 0xF0, 0x90, 0x9C, 0x99, 0xE0, 0x90, 0x93,
-0x01, 0xF0, 0x22, 0x12, 0x02, 0x06, 0x64, 0x01,
-0x60, 0x02, 0x21, 0x01, 0x90, 0x99, 0xCC, 0xF0,
-0x90, 0x99, 0xCC, 0xE0, 0xFF, 0xC3, 0x94, 0x10,
-0x50, 0x27, 0xEF, 0x31, 0x02, 0x7A, 0x99, 0x79,
-0xCB, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x12, 0x90,
-0x99, 0xCB, 0xE0, 0xFF, 0xA3, 0xE0, 0x24, 0xCD,
-0xF5, 0x82, 0xE4, 0x34, 0x99, 0xF5, 0x83, 0xEF,
-0xF0, 0x90, 0x99, 0xCC, 0xE0, 0x04, 0xF0, 0x80,
-0xCF, 0x75, 0x45, 0x01, 0x75, 0x46, 0x99, 0x75,
-0x47, 0xCD, 0x75, 0x48, 0x08, 0x7B, 0x01, 0x7A,
-0x99, 0x79, 0x87, 0x12, 0x9F, 0x90, 0x74, 0x24,
-0xF0, 0x90, 0x99, 0xA7, 0x74, 0x08, 0xF0, 0x75,
-0x45, 0x01, 0x75, 0x46, 0x99, 0x75, 0x47, 0xD5,
-0xF5, 0x48, 0x7B, 0x01, 0x7A, 0x99, 0x79, 0xAA,
-0x12, 0x69, 0xF5, 0x90, 0x99, 0xA8, 0x74, 0x25,
-0xF0, 0x90, 0x99, 0xCA, 0x74, 0x08, 0x12, 0x98,
-0xC2, 0x51, 0x1A, 0x7B, 0x01, 0x7A, 0x99, 0x79,
-0xA8, 0x12, 0x97, 0x4C, 0x7F, 0x04, 0x12, 0x04,
-0x7E, 0x22, 0x24, 0xA8, 0xFF, 0xE4, 0x34, 0x01,
-0xFE, 0x7B, 0x01, 0x22, 0x12, 0x97, 0xE3, 0x64,
-0x01, 0x60, 0x02, 0x21, 0x9C, 0xEF, 0x24, 0x39,
-0x60, 0x12, 0x14, 0x60, 0x19, 0x24, 0x02, 0x70,
-0x1F, 0xE4, 0x90, 0x99, 0x8B, 0xF0, 0xA3, 0x74,
-0x06, 0xF0, 0x80, 0x14, 0x90, 0x99, 0x8B, 0x74,
-0x06, 0xF0, 0xA3, 0xF0, 0x80, 0x0A, 0x90, 0x99,
-0x8B, 0x74, 0x0C, 0xF0, 0xA3, 0x74, 0x04, 0xF0,
-0x31, 0xB0, 0xF0, 0x31, 0x9D, 0x40, 0x1B, 0x90,
-0x99, 0x89, 0xE0, 0x31, 0x02, 0x7A, 0x99, 0x79,
-0x88, 0x12, 0x5F, 0xA6, 0xBF, 0x01, 0x07, 0x90,
-0x99, 0x88, 0xE0, 0xF4, 0x70, 0x3E, 0x31, 0xA5,
-0x80, 0xE1, 0x31, 0xB0, 0xF0, 0x31, 0x9D, 0x40,
-0x33, 0x90, 0x99, 0x89, 0xE0, 0xFD, 0x7C, 0x00,
-0x24, 0xA8, 0xFF, 0xEC, 0x34, 0x01, 0xFE, 0xED,
-0x24, 0x01, 0xFD, 0xEC, 0x33, 0xFC, 0x90, 0x99,
-0x8B, 0xE0, 0xFB, 0xC3, 0xED, 0x9B, 0xFD, 0xEC,
-0x94, 0x00, 0xFC, 0x12, 0x91, 0xAD, 0x8D, 0x82,
-0x8C, 0x83, 0x12, 0x02, 0x1F, 0xFD, 0x31, 0xC0,
-0x31, 0xA5, 0x80, 0xC9, 0x22, 0x90, 0x99, 0x8A,
-0xE0, 0xD3, 0x94, 0x00, 0x22, 0x90, 0x99, 0x89,
-0xE0, 0x04, 0xF0, 0xA3, 0xE0, 0x14, 0xF0, 0x22,
-0x90, 0x99, 0x8B, 0xE0, 0x90, 0x99, 0x89, 0xF0,
-0x90, 0x99, 0x8C, 0xE0, 0x90, 0x99, 0x8A, 0x22,
-0xE4, 0x90, 0x99, 0x8D, 0xF0, 0x90, 0x00, 0x37,
-0xE0, 0x44, 0x80, 0xF0, 0x90, 0x00, 0xCF, 0x74,
-0x69, 0xF0, 0xEF, 0x90, 0x00, 0x31, 0xF0, 0xEE,
-0x54, 0x03, 0xFF, 0xA3, 0xE0, 0x54, 0xFC, 0x4F,
-0xF0, 0x90, 0x00, 0x30, 0xED, 0xF0, 0x90, 0x00,
-0x33, 0xE0, 0x44, 0x80, 0xF0, 0x90, 0x00, 0x33,
-0xE0, 0x30, 0xE7, 0x09, 0x51, 0x12, 0x50, 0x05,
-0xE0, 0x04, 0xF0, 0x80, 0xF0, 0x90, 0x00, 0xCF,
-0xE4, 0xF0, 0x90, 0x00, 0x37, 0xE0, 0x54, 0x7F,
-0xF0, 0x51, 0x12, 0x7F, 0x00, 0x50, 0x02, 0x7F,
-0x01, 0x22, 0x90, 0x99, 0x8D, 0xE0, 0xC3, 0x94,
-0x64, 0x22, 0x90, 0x8A, 0x77, 0xE0, 0xFE, 0xA3,
-0xE0, 0xFF, 0xF5, 0x82, 0x8E, 0x83, 0x02, 0x04,
-0x7E, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x88, 0x33, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
-0x24, 0x90, 0x9B, 0xAE, 0x74, 0x1E, 0xF0, 0x90,
-0x9B, 0xD0, 0x74, 0x01, 0xF0, 0x90, 0x9B, 0xB0,
-0xEF, 0xF0, 0x7B, 0x01, 0x7A, 0x9B, 0x79, 0xAE,
-0x51, 0x1A, 0x90, 0x8A, 0xE5, 0x12, 0x97, 0x5E,
-0x7F, 0x04, 0x12, 0x04, 0x7E, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x51, 0x68, 0xE4, 0xFF, 0x80, 0xC1,
-0xE4, 0xF5, 0x0F, 0x90, 0x88, 0x36, 0xE0, 0x60,
-0x56, 0x71, 0x4A, 0x70, 0x52, 0x12, 0xF4, 0xE0,
-0x75, 0x0F, 0x01, 0xE5, 0x0F, 0x60, 0x48, 0x90,
-0x88, 0x39, 0xE0, 0x20, 0xE2, 0x0D, 0x90, 0x8A,
-0xB9, 0x12, 0x97, 0x5E, 0x7D, 0x01, 0x7F, 0x04,
-0x12, 0x04, 0x7E, 0x71, 0x42, 0x90, 0x88, 0x3F,
-0xE0, 0x60, 0x04, 0x64, 0x01, 0x70, 0x11, 0xE4,
-0x90, 0x92, 0x20, 0xF0, 0x51, 0xD7, 0xFF, 0xA3,
-0xE0, 0x51, 0xC8, 0xFF, 0xA3, 0xE0, 0x80, 0x0D,
-0xE4, 0x90, 0x92, 0x20, 0xF0, 0x51, 0xD7, 0x51,
-0xE1, 0x51, 0xC8, 0x51, 0xE1, 0x2F, 0x33, 0x33,
-0x33, 0x54, 0xF8, 0x90, 0x88, 0x4F, 0xF0, 0x22,
-0x2F, 0x90, 0x92, 0x21, 0xF0, 0xE4, 0xFB, 0xFD,
-0x7F, 0x54, 0x7E, 0x01, 0x12, 0x66, 0x33, 0x90,
-0x88, 0x3E, 0xE0, 0x13, 0x13, 0x13, 0x54, 0x1F,
-0x22, 0xFF, 0xA3, 0xE0, 0x75, 0xF0, 0x03, 0xA4,
-0x24, 0xFE, 0x22, 0x51, 0xFB, 0x7D, 0x02, 0x7F,
-0x02, 0x12, 0x7C, 0x74, 0x7F, 0x01, 0x51, 0x29,
-0x02, 0xAF, 0x98, 0xE4, 0x90, 0x9A, 0xD8, 0xF0,
-0x90, 0x88, 0x36, 0xE0, 0x60, 0x3B, 0x71, 0x4A,
-0x70, 0x37, 0x12, 0xF5, 0x97, 0xF0, 0x12, 0xF4,
-0xE0, 0x90, 0x9A, 0xD8, 0x74, 0x01, 0xF0, 0xE4,
-0x90, 0x88, 0x3D, 0xF0, 0x04, 0x60, 0x22, 0x90,
-0x88, 0x39, 0xE0, 0x20, 0xE2, 0x0D, 0x90, 0x8A,
-0xB9, 0x12, 0x97, 0x5E, 0x7D, 0x01, 0x7F, 0x04,
-0x12, 0x04, 0x7E, 0x71, 0x42, 0xE4, 0x90, 0x92,
-0x20, 0xF0, 0x51, 0xD7, 0x71, 0x76, 0x12, 0x66,
-0x33, 0x22, 0x90, 0x88, 0x3A, 0xE0, 0x44, 0x10,
-0xF0, 0x22, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xEF,
-0x64, 0x01, 0x22, 0x71, 0x4A, 0x70, 0x14, 0x90,
-0x88, 0x36, 0xE0, 0x60, 0x0E, 0x90, 0x88, 0x3A,
-0xE0, 0x20, 0xE4, 0x07, 0xF1, 0xEE, 0x71, 0x6C,
-0x12, 0x66, 0x33, 0x22, 0xF0, 0xE4, 0x90, 0x92,
-0x20, 0xF0, 0x90, 0x88, 0x94, 0xE0, 0x90, 0x92,
-0x21, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x54, 0x7E,
-0x01, 0x22, 0x71, 0x4A, 0x70, 0x1E, 0x90, 0x88,
-0x36, 0xE0, 0x60, 0x18, 0x90, 0x88, 0x3A, 0xE0,
-0x20, 0xE4, 0x11, 0xF1, 0xEE, 0xF0, 0x90, 0x88,
-0x31, 0xE0, 0x12, 0xF5, 0x2D, 0x54, 0x07, 0x70,
-0x03, 0x12, 0xBE, 0x1B, 0x22, 0xC0, 0xE0, 0xC0,
+0x95, 0xED, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0x00, 0x90, 0x98, 0x31, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0x00, 0x22, 0x90, 0xFD, 0x78, 0xE0,
+0x7F, 0x00, 0x22, 0x90, 0xFD, 0x70, 0xE0, 0x7F,
+0x00, 0x22, 0xEE, 0xF0, 0x90, 0xFD, 0x80, 0xE0,
+0x22, 0x90, 0x98, 0x4C, 0xE0, 0x54, 0xFE, 0xF0,
+0x54, 0x7F, 0xF0, 0x54, 0xFB, 0xF0, 0xA3, 0x74,
+0x0A, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0x22,
+0x12, 0x7B, 0x1B, 0x90, 0x86, 0xB3, 0xEF, 0xF0,
+0x51, 0xAA, 0x90, 0x01, 0x64, 0x74, 0x01, 0xF0,
+0x90, 0x04, 0x23, 0xE0, 0x44, 0x80, 0xF0, 0x02,
+0x67, 0xD2, 0xF1, 0x97, 0x12, 0x76, 0x6D, 0x12,
+0x75, 0xE0, 0xF1, 0xEB, 0x12, 0xD0, 0x24, 0xE4,
+0xF5, 0x21, 0x90, 0x86, 0xB3, 0xE0, 0xFF, 0xB4,
+0x03, 0x05, 0x75, 0x22, 0x08, 0x80, 0x03, 0xE4,
+0xF5, 0x22, 0xEF, 0xB4, 0x01, 0x0A, 0x90, 0x00,
+0x75, 0xE0, 0x54, 0xFB, 0xF0, 0x75, 0x22, 0x04,
+0x75, 0x23, 0x10, 0x75, 0x24, 0x80, 0x90, 0x00,
+0x50, 0xE5, 0x21, 0xF0, 0xA3, 0xE5, 0x22, 0xF0,
+0xA3, 0xE5, 0x23, 0xF0, 0xA3, 0xE5, 0x24, 0xF0,
+0x22, 0xE4, 0x90, 0x9C, 0xD9, 0xF0, 0xA3, 0xF0,
+0x12, 0xE2, 0x77, 0xEF, 0x64, 0x01, 0x60, 0x3D,
+0xC3, 0x90, 0x9C, 0xDA, 0xE0, 0x94, 0x88, 0x90,
+0x9C, 0xD9, 0xE0, 0x94, 0x13, 0x40, 0x0F, 0x90,
+0x01, 0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x01,
+0xC7, 0x74, 0xFD, 0xF0, 0x80, 0x1F, 0x90, 0x9C,
+0xD9, 0x12, 0xBF, 0xA5, 0x12, 0xBF, 0xDF, 0xD3,
+0x90, 0x9C, 0xDA, 0xE0, 0x94, 0x32, 0x90, 0x9C,
+0xD9, 0xE0, 0x94, 0x00, 0x40, 0xC2, 0x90, 0x01,
+0xC6, 0xE0, 0x30, 0xE3, 0xBB, 0x90, 0x01, 0xC7,
+0x74, 0xFE, 0xF0, 0x22, 0xEF, 0x70, 0x02, 0x61,
+0xF5, 0x90, 0x06, 0x0F, 0xE0, 0x20, 0xE6, 0x1D,
+0x90, 0x98, 0x6C, 0xE0, 0x54, 0xFE, 0xF0, 0x90,
+0x06, 0x0F, 0xE0, 0x20, 0xE5, 0x07, 0x90, 0x01,
+0x0C, 0xE0, 0x30, 0xE1, 0x45, 0x90, 0x01, 0xC7,
+0x74, 0x44, 0xF0, 0x80, 0xFE, 0x90, 0x98, 0x6C,
+0xE0, 0x44, 0x01, 0xF0, 0x90, 0x06, 0x0F, 0xE0,
+0x30, 0xE5, 0x10, 0x90, 0x01, 0x0C, 0xE0, 0x20,
+0xE1, 0x09, 0x90, 0x98, 0x6C, 0xE0, 0x54, 0xFD,
+0xF0, 0x80, 0x1F, 0x90, 0x06, 0x0F, 0xE0, 0x20,
+0xE5, 0x10, 0x90, 0x01, 0x0C, 0xE0, 0x30, 0xE1,
+0x09, 0x90, 0x98, 0x6C, 0xE0, 0x44, 0x02, 0xF0,
+0x80, 0x08, 0x90, 0x01, 0xC7, 0x74, 0x44, 0xF0,
+0x80, 0xFE, 0x90, 0x98, 0x37, 0xE0, 0xFF, 0x60,
+0x02, 0xD1, 0x10, 0x90, 0x01, 0xC7, 0xE4, 0x12,
+0xC7, 0x83, 0xF1, 0x77, 0x90, 0x06, 0x09, 0xE0,
+0x54, 0xFE, 0xF0, 0x7B, 0x35, 0x7D, 0xFF, 0x7F,
+0xFF, 0x12, 0x8D, 0x1E, 0x90, 0x8A, 0xEF, 0x12,
+0x88, 0xC8, 0xF1, 0x69, 0xF0, 0x91, 0x9D, 0x91,
+0x0D, 0x90, 0x86, 0x0C, 0x12, 0x88, 0xC8, 0xE4,
+0xFB, 0xFD, 0x7F, 0xFF, 0x12, 0x8D, 0x1E, 0x91,
+0x2D, 0x90, 0x01, 0x34, 0x74, 0x08, 0xF0, 0xFD,
+0xE4, 0xFF, 0x02, 0x7C, 0x74, 0x7D, 0x08, 0xE4,
+0xFF, 0x12, 0x7C, 0x7E, 0x90, 0x06, 0x90, 0xE0,
+0x54, 0xF0, 0xF0, 0xF1, 0x70, 0xF0, 0x91, 0x60,
+0x12, 0x9F, 0xEF, 0x21, 0x89, 0xF1, 0x62, 0xF1,
+0x7F, 0x30, 0xE0, 0x18, 0x90, 0x93, 0x04, 0xE0,
+0xFF, 0xC4, 0x54, 0x0F, 0x20, 0xE0, 0x0D, 0x90,
+0x9C, 0x9B, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0x14, 0x12, 0x95, 0x30, 0x22, 0xE4, 0xFF, 0x74,
+0x18, 0x91, 0x55, 0x74, 0x38, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEE, 0xF0, 0x74,
+0x10, 0x91, 0x55, 0x74, 0x32, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0x93, 0xF5, 0x83, 0xEE, 0xF0, 0x0F,
+0xEF, 0xB4, 0x06, 0xDB, 0x22, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0x06, 0xF5, 0x83, 0xE0, 0xFE, 0x22,
+0x91, 0x8A, 0x90, 0x98, 0x46, 0xE0, 0xFF, 0x91,
+0xEA, 0x90, 0x01, 0x3F, 0x74, 0x04, 0xF0, 0x90,
+0x86, 0xB3, 0xE0, 0xFF, 0xB4, 0x01, 0x07, 0x90,
+0xFD, 0x00, 0xE0, 0x54, 0xEF, 0xF0, 0xEF, 0xB4,
+0x01, 0x07, 0x90, 0xFE, 0x10, 0xE0, 0x54, 0xFB,
+0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0xE4, 0xFD, 0x7F, 0x8F, 0x12, 0x7B, 0x2E,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0xE6, 0x30,
+0xAD, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x9D, 0xF0,
+0x74, 0xCC, 0xA3, 0xF0, 0xED, 0x64, 0x01, 0x60,
+0x1E, 0x12, 0xA7, 0x71, 0xED, 0xB4, 0x02, 0x08,
+0x90, 0x01, 0xC7, 0x74, 0x40, 0xF0, 0x80, 0x0A,
+0xED, 0xB4, 0x04, 0x06, 0x90, 0x01, 0xC7, 0x74,
+0x41, 0xF0, 0x7F, 0x01, 0x02, 0xAD, 0x5E, 0xB1,
+0x54, 0x90, 0x02, 0x87, 0xE0, 0x70, 0xF8, 0x90,
+0x06, 0x90, 0xE0, 0x44, 0x02, 0xF0, 0x74, 0x9D,
+0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xCC, 0xA3,
+0xF0, 0x22, 0x90, 0x99, 0xB4, 0xEF, 0xF0, 0xE4,
+0xFF, 0x74, 0x33, 0x2F, 0xD1, 0xD7, 0xE0, 0xFE,
+0x74, 0x84, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x04,
+0xF5, 0x83, 0xEE, 0xF0, 0x0F, 0xEF, 0xB4, 0x08,
+0xE8, 0x90, 0x95, 0x63, 0xE0, 0x90, 0x04, 0x8C,
+0xF0, 0x90, 0x95, 0x65, 0xE0, 0x90, 0x04, 0x8D,
+0xF0, 0x90, 0x95, 0x66, 0x74, 0x01, 0xF0, 0xF5,
+0x45, 0x75, 0x46, 0x94, 0x75, 0x47, 0x42, 0x75,
+0x48, 0x08, 0xFB, 0x7A, 0x95, 0x79, 0x3B, 0x12,
+0x69, 0xF5, 0x90, 0x98, 0x46, 0xE0, 0x60, 0x1B,
+0x90, 0x99, 0xB4, 0x12, 0xC7, 0xF1, 0x12, 0xF9,
+0xEE, 0xC0, 0x03, 0x8B, 0x45, 0x75, 0x46, 0x95,
+0x75, 0x47, 0x33, 0x75, 0x48, 0x60, 0xD0, 0x03,
+0x12, 0x69, 0xF5, 0x22, 0xF1, 0xCE, 0x12, 0xC7,
+0x8C, 0x90, 0x99, 0xB1, 0xF1, 0xB1, 0xF9, 0x90,
+0x93, 0x24, 0xE0, 0x20, 0xE0, 0x02, 0xA1, 0xED,
+0xEC, 0xC3, 0x99, 0x40, 0x02, 0xA1, 0xED, 0x90,
+0x99, 0xB1, 0xE0, 0xFA, 0xA3, 0xE0, 0xFB, 0xEA,
+0x90, 0xFD, 0x11, 0xF0, 0xAF, 0x03, 0xAD, 0x07,
+0x12, 0xD7, 0x63, 0x3E, 0x54, 0x3F, 0x90, 0x99,
+0xB3, 0x12, 0xF9, 0xD2, 0x30, 0xE0, 0x0A, 0xC3,
+0x13, 0x20, 0xE0, 0x05, 0x12, 0xFA, 0x66, 0x80,
+0x02, 0x7E, 0x00, 0xEE, 0xFB, 0xEF, 0x24, 0x18,
+0xFF, 0xE4, 0x33, 0xCF, 0x2B, 0xCF, 0x34, 0x00,
+0x90, 0x99, 0xB3, 0x8F, 0xF0, 0x12, 0x02, 0xE7,
+0x90, 0x99, 0xB3, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0xB1, 0xEE, 0x90, 0x99, 0xB3, 0xEE, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x99, 0xB1, 0x12, 0xFA, 0x57,
+0xD3, 0x90, 0x99, 0xB2, 0xE0, 0x9F, 0x90, 0x99,
+0xB1, 0xE0, 0x9E, 0x40, 0x0F, 0x12, 0xFA, 0x37,
+0x90, 0x99, 0xB2, 0xE0, 0x9F, 0xF0, 0x90, 0x99,
+0xB1, 0xE0, 0x9E, 0xF0, 0x90, 0x99, 0xB1, 0x12,
+0xE6, 0x1D, 0x0C, 0xA1, 0x68, 0x22, 0x7D, 0x07,
+0xEF, 0x5D, 0xC3, 0x60, 0x0A, 0xD1, 0x03, 0x24,
+0x08, 0xFF, 0xE4, 0x3E, 0xFE, 0x80, 0x03, 0xD1,
+0x03, 0xFF, 0x22, 0x74, 0xFF, 0x9D, 0xFD, 0x74,
+0xFF, 0x94, 0x00, 0x5E, 0xFE, 0xED, 0x5F, 0x22,
+0x12, 0x7B, 0x07, 0x7E, 0x00, 0xE4, 0xFD, 0xEF,
+0x2D, 0x12, 0x8E, 0x99, 0xE0, 0xFC, 0x74, 0x33,
+0x2D, 0xD1, 0xD7, 0xEC, 0xF0, 0x0D, 0xED, 0xB4,
+0x08, 0xED, 0xAC, 0x07, 0x74, 0x08, 0x2C, 0xF1,
+0x9F, 0x64, 0xDD, 0x60, 0x02, 0xC1, 0xD6, 0x74,
+0x09, 0x2C, 0xF1, 0xA8, 0xFC, 0x30, 0xE0, 0x1B,
+0xE4, 0xFD, 0xEF, 0x2D, 0x24, 0x10, 0xF1, 0x8F,
+0xE0, 0xFB, 0x74, 0x6B, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0x95, 0xF5, 0x83, 0xEB, 0xF0, 0x0D, 0xED,
+0xB4, 0x08, 0xE7, 0xEC, 0x30, 0xE1, 0x77, 0x74,
+0x0A, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0x90, 0x95, 0x63, 0xF0, 0xE4, 0xFD,
+0xA9, 0x07, 0xE9, 0x2D, 0xFC, 0x24, 0x18, 0xF1,
+0x87, 0xE0, 0xFB, 0x74, 0x73, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0x95, 0xF5, 0x83, 0xEB, 0xF0, 0x74,
+0x20, 0x2C, 0xF1, 0xBA, 0xFC, 0x74, 0x7B, 0x2D,
+0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0xEC,
+0xF0, 0xE9, 0x2D, 0xFC, 0x12, 0xFA, 0xAF, 0xFB,
+0x74, 0x83, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xF5, 0x83, 0xEB, 0xF0, 0x74, 0x30, 0x2C, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFC,
+0x74, 0x8B, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x95,
+0xF5, 0x83, 0xEC, 0xF0, 0x0D, 0xED, 0xB4, 0x08,
+0xA7, 0x90, 0x95, 0x63, 0xE0, 0xFF, 0x7B, 0x01,
+0x7A, 0x95, 0x79, 0x43, 0xD1, 0xDF, 0x22, 0xF5,
+0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0x22, 0x90,
+0x99, 0xB1, 0xEF, 0xF0, 0xA3, 0x12, 0x82, 0x27,
+0xE4, 0x90, 0x99, 0xB5, 0xF0, 0xF0, 0x90, 0x99,
+0xB5, 0xE0, 0xFF, 0xC3, 0x94, 0x04, 0x50, 0x2B,
+0xEF, 0x75, 0xF0, 0x04, 0xA4, 0xFF, 0x90, 0x99,
+0xB2, 0x12, 0x82, 0x1E, 0xE9, 0x2F, 0xF9, 0xEA,
+0x35, 0xF0, 0xFA, 0x90, 0x99, 0xB1, 0xE0, 0x75,
+0xF0, 0x08, 0xA4, 0x24, 0x02, 0xFF, 0x90, 0x99,
+0xB5, 0xE0, 0x2F, 0xFF, 0xF1, 0x24, 0x12, 0xC1,
+0x2F, 0x80, 0xCB, 0x22, 0x90, 0x99, 0xB6, 0x12,
+0x82, 0x27, 0xF1, 0xE1, 0xF1, 0xD7, 0x12, 0x7C,
+0x6A, 0x90, 0x06, 0x78, 0xF1, 0x5A, 0xEF, 0x12,
+0x02, 0x4C, 0x90, 0x06, 0x79, 0xF1, 0x5A, 0x90,
+0x00, 0x01, 0xEF, 0x12, 0x02, 0x5E, 0x90, 0x06,
+0x7A, 0xE0, 0x90, 0x00, 0x02, 0x12, 0x02, 0x5E,
+0x90, 0x06, 0x7B, 0xE0, 0x90, 0x00, 0x03, 0x02,
+0x02, 0x5E, 0xE0, 0xFF, 0x90, 0x99, 0xB6, 0x02,
+0x82, 0x1E, 0x22, 0xE4, 0xFD, 0xFF, 0x02, 0x6E,
+0x71, 0x90, 0x02, 0x86, 0xE0, 0x44, 0x04, 0x22,
+0x90, 0x02, 0x86, 0xE0, 0x54, 0xFB, 0x22, 0x90,
+0x88, 0x27, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0x90,
+0x93, 0x24, 0xE0, 0xC4, 0x54, 0x0F, 0x22, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0x90,
+0x00, 0x08, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22,
+0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
+0x22, 0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x02, 0x87,
+0xE0, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0x22, 0x90, 0x01, 0xE4, 0x74, 0x2F,
+0xF0, 0xA3, 0xE4, 0xF0, 0x22, 0xF0, 0x90, 0x01,
+0x1F, 0xE0, 0xFE, 0x90, 0x01, 0x1E, 0x22, 0xF0,
+0xA3, 0x74, 0x80, 0xF0, 0x7F, 0x01, 0x7E, 0x00,
+0x22, 0x90, 0x06, 0x70, 0xEF, 0xF0, 0xA3, 0xE4,
+0xF0, 0xA3, 0x22, 0x75, 0x29, 0x10, 0xE4, 0xF5,
+0x2A, 0x75, 0x2B, 0x07, 0x75, 0x2C, 0x02, 0xF5,
+0x31, 0xF5, 0x32, 0xF5, 0x33, 0xF5, 0x34, 0x90,
+0x01, 0x30, 0xE5, 0x29, 0xF0, 0xA3, 0xE5, 0x2A,
+0xF0, 0xA3, 0xE5, 0x2B, 0xF0, 0xA3, 0xE5, 0x2C,
+0xF0, 0x90, 0x01, 0x20, 0xE5, 0x31, 0xF0, 0xA3,
+0xE5, 0x32, 0xF0, 0xA3, 0xE5, 0x33, 0xF0, 0xA3,
+0xE5, 0x34, 0xF0, 0x22, 0x75, 0x39, 0x0F, 0x75,
+0x3A, 0x01, 0x75, 0x3B, 0x03, 0x75, 0x3C, 0x62,
+0x90, 0x01, 0x38, 0xE5, 0x39, 0xF0, 0xA3, 0xE5,
+0x3A, 0xF0, 0xA3, 0xE5, 0x3B, 0xF0, 0xA3, 0xE5,
+0x3C, 0xF0, 0x22, 0x7D, 0x02, 0x90, 0x01, 0xC4,
+0x74, 0x43, 0xF0, 0x74, 0xD0, 0xA3, 0xF0, 0x90,
+0x98, 0x4B, 0xE0, 0xFF, 0xED, 0xC3, 0x9F, 0x50,
+0x18, 0xED, 0x25, 0xE0, 0x24, 0x81, 0xF8, 0xE6,
+0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8, 0x74, 0x08,
+0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22, 0x0D, 0x80,
+0xDE, 0x74, 0x43, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xD0, 0xA3, 0xF0, 0x7F, 0x01, 0x22, 0xE4,
+0x90, 0x9A, 0x09, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0,
+0x90, 0x9A, 0x09, 0xE0, 0x64, 0x01, 0xF0, 0x90,
+0x98, 0x62, 0xE0, 0x70, 0x18, 0x90, 0x98, 0x5F,
+0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E, 0x90,
+0x9A, 0x09, 0xE0, 0x24, 0x7F, 0x90, 0x01, 0xC4,
+0xF0, 0x74, 0xD0, 0xA3, 0xF0, 0x12, 0x7C, 0x54,
+0xBF, 0x01, 0x03, 0x12, 0x54, 0x9F, 0x90, 0x88,
+0x36, 0xE0, 0x60, 0x0F, 0x90, 0x88, 0x39, 0xE0,
+0xFF, 0x90, 0x88, 0x38, 0xE0, 0x6F, 0x60, 0x03,
+0x12, 0xB6, 0x3B, 0xC2, 0xAF, 0x11, 0x43, 0xBF,
+0x01, 0x02, 0xF1, 0x41, 0xD2, 0xAF, 0x11, 0xE0,
+0x12, 0xC7, 0xF9, 0x12, 0x84, 0x4D, 0x80, 0xA8,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x98, 0x5F, 0xE0, 0x60, 0x24, 0x7F, 0x54, 0x7E,
+0x09, 0x12, 0x70, 0x70, 0x31, 0x8C, 0x12, 0x04,
+0xB8, 0xEF, 0x44, 0xFE, 0xFF, 0xEE, 0x44, 0x03,
+0xFE, 0xED, 0x44, 0x04, 0xFD, 0xEC, 0x31, 0x8C,
+0x31, 0x96, 0x7F, 0x54, 0x7E, 0x09, 0x12, 0x70,
+0xAD, 0x90, 0x98, 0x5A, 0xE0, 0x70, 0x29, 0x90,
+0x07, 0xCC, 0xE0, 0x30, 0xE0, 0x22, 0xE4, 0xF0,
+0x90, 0x9A, 0x10, 0x74, 0x22, 0xF0, 0x90, 0x9A,
+0x32, 0x74, 0x01, 0xF0, 0x90, 0x9A, 0x12, 0x74,
+0x03, 0xF0, 0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x10,
+0x12, 0x90, 0x35, 0x7F, 0x04, 0x12, 0x04, 0x7E,
+0x90, 0x98, 0x62, 0xE0, 0xFF, 0x70, 0x0A, 0x90,
+0x98, 0x5F, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x60,
+0x15, 0x90, 0x00, 0x1F, 0xE0, 0x54, 0xF0, 0xF0,
+0x90, 0x01, 0xC5, 0x74, 0xEA, 0xF0, 0xA3, 0x74,
+0xEF, 0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0xEF, 0x60,
+0x06, 0x90, 0x01, 0xC4, 0x74, 0x07, 0xF0, 0x90,
+0x98, 0x5F, 0xE0, 0x60, 0x06, 0x90, 0x01, 0xC4,
+0x74, 0x01, 0xF0, 0x90, 0x98, 0x60, 0xE0, 0x60,
+0x06, 0x90, 0x01, 0xC4, 0x74, 0x02, 0xF0, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0x90, 0x9A, 0x0C, 0x12,
+0x04, 0x31, 0x90, 0x9A, 0x0C, 0x22, 0x12, 0x04,
+0xB8, 0x90, 0x92, 0x18, 0x02, 0x04, 0x31, 0x7F,
+0x58, 0x7E, 0x0C, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x9C, 0x2D, 0xEE, 0xF0, 0xA3,
+0xEF, 0xF0, 0x12, 0x70, 0x70, 0x90, 0x9C, 0x37,
+0x12, 0x04, 0x31, 0x90, 0x9C, 0x2F, 0x12, 0x04,
+0xB8, 0x12, 0x03, 0xCD, 0x90, 0x9C, 0x37, 0x91,
+0x46, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
+0x07, 0x90, 0x9C, 0x2F, 0x12, 0x04, 0xB8, 0x90,
+0x9C, 0x33, 0x91, 0x46, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0x12, 0x82, 0x05, 0x90,
+0x9C, 0x3B, 0x12, 0x04, 0x31, 0x90, 0x9C, 0x3B,
+0x31, 0x96, 0x90, 0x9C, 0x2D, 0xE0, 0xFE, 0xA3,
+0xE0, 0xFF, 0x12, 0x70, 0xAD, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x9C, 0xDB, 0xED, 0xF0, 0xE4, 0xA3,
+0xF0, 0xEF, 0x14, 0x60, 0x02, 0x41, 0xE8, 0x90,
+0x06, 0x03, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x9C,
+0xDB, 0xE0, 0xFB, 0xC4, 0x33, 0x54, 0xE0, 0xFE,
+0x90, 0x04, 0x42, 0xE0, 0x54, 0x9F, 0x4E, 0xFE,
+0xF0, 0xE4, 0xFD, 0xF1, 0x81, 0x90, 0x9C, 0xDC,
+0xEF, 0xF0, 0x90, 0x04, 0x83, 0xF0, 0x90, 0x9C,
+0x2F, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x01,
+0x90, 0x9C, 0x33, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0x01, 0x71, 0x4D, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0x01, 0x90, 0x9C, 0x33, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x00, 0x01, 0x7F, 0x00, 0x7E,
+0x09, 0x71, 0x51, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0x10, 0x90, 0x9C, 0xDB, 0x12, 0xAF, 0x13,
+0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x01, 0x12,
+0x03, 0xEB, 0x78, 0x04, 0x91, 0x33, 0x7F, 0x00,
+0x7E, 0x0A, 0x71, 0x51, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x0C, 0x00, 0x90, 0x9C, 0xDB, 0x12, 0xAF,
+0x13, 0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x0A,
+0x91, 0x33, 0x7F, 0x00, 0x7E, 0x0D, 0x71, 0x51,
+0x12, 0x04, 0x3D, 0x0C, 0x00, 0x00, 0x00, 0x90,
+0x9C, 0xDC, 0x12, 0xAF, 0x13, 0xEF, 0x54, 0x03,
+0xFF, 0xE4, 0x78, 0x1A, 0x91, 0x33, 0x7F, 0x18,
+0x71, 0x4F, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C,
+0x00, 0x90, 0x9C, 0x33, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0x00, 0x91, 0x3C, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x0C, 0x00, 0x90, 0x9C, 0x21, 0x12,
+0x04, 0x3D, 0x00, 0x00, 0x04, 0x00, 0x80, 0x58,
+0x90, 0x06, 0x03, 0xE0, 0x44, 0x04, 0xF0, 0x90,
+0x9C, 0x2F, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0x01, 0x90, 0x9C, 0x33, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0x00, 0x71, 0x4D, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x00, 0x01, 0x90, 0x9C, 0x33, 0x12,
+0x04, 0x3D, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x00,
+0x7E, 0x09, 0x71, 0x51, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x0C, 0x00, 0x90, 0x9C, 0x33, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x0C, 0x00, 0x91, 0x3C, 0x12,
+0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x9C,
+0x21, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00,
+0x7D, 0x18, 0x7C, 0x00, 0xE4, 0xFF, 0x91, 0x4C,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7F, 0x00, 0x7E,
+0x08, 0x31, 0xA3, 0x90, 0x9C, 0x2F, 0x22, 0x7F,
+0x50, 0x7E, 0x0C, 0x12, 0x70, 0x70, 0x90, 0x9B,
+0x0B, 0xEF, 0xF0, 0x7F, 0x58, 0x7E, 0x0C, 0x12,
+0x70, 0x70, 0x90, 0x9B, 0x0C, 0xEF, 0xF0, 0x90,
+0x9C, 0x2F, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
+0x7F, 0x90, 0x9C, 0x33, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0x17, 0x7F, 0x50, 0x7E, 0x0C, 0x71,
+0x51, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x7F,
+0x90, 0x9C, 0x33, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0x17, 0x31, 0x9F, 0x90, 0x06, 0x08, 0xE0,
+0x90, 0x9B, 0x21, 0xF0, 0x90, 0x06, 0xA1, 0xE0,
+0xFE, 0x90, 0x06, 0xA0, 0x12, 0xC7, 0x8C, 0x90,
+0x9B, 0x23, 0xF0, 0xA3, 0xEF, 0xB1, 0x4C, 0x90,
+0x06, 0xA0, 0x74, 0x20, 0xF0, 0xA3, 0x74, 0x01,
+0xF0, 0xE4, 0xFD, 0xFF, 0x41, 0x02, 0x90, 0x93,
+0x04, 0x12, 0xB4, 0xA3, 0x30, 0xE0, 0x09, 0x12,
+0xCF, 0x70, 0xF0, 0xE4, 0x90, 0x9B, 0x25, 0xF0,
+0x90, 0x9C, 0x2F, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x00, 0x7F, 0x90, 0x9B, 0x0B, 0x12, 0xAF, 0x13,
+0x91, 0x36, 0x7F, 0x50, 0x7E, 0x0C, 0x71, 0x51,
+0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x7F, 0x90,
+0x9B, 0x0C, 0x12, 0xAF, 0x13, 0x91, 0x36, 0x31,
+0x9F, 0x90, 0x9B, 0x21, 0xE0, 0x90, 0x06, 0x08,
+0xF0, 0x90, 0x9B, 0x23, 0xA3, 0xE0, 0x90, 0x06,
+0xA0, 0xF0, 0xA3, 0xE4, 0xF0, 0x90, 0x9B, 0x0F,
+0xE0, 0xFF, 0x60, 0x05, 0xA3, 0xE0, 0xFD, 0x51,
+0x02, 0x90, 0x9B, 0x0E, 0xE0, 0xFF, 0x60, 0x0A,
+0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFB, 0xB1, 0x43,
+0x91, 0xC2, 0x22, 0x12, 0x03, 0xFE, 0x90, 0x9C,
+0x33, 0x02, 0x04, 0x31, 0x7F, 0x84, 0x7E, 0x08,
+0x31, 0xA3, 0x90, 0x9C, 0x1D, 0x22, 0x12, 0x82,
+0x12, 0x02, 0x81, 0xF8, 0xD3, 0x10, 0xAF, 0x01,
+0xC3, 0xC0, 0xD0, 0x90, 0x9C, 0x1B, 0xEC, 0xF0,
+0xA3, 0xED, 0xF0, 0x90, 0x9C, 0x1A, 0xEF, 0xF0,
+0xA3, 0xA3, 0xE0, 0xFD, 0x12, 0x7B, 0xBD, 0x90,
+0x9C, 0x25, 0x12, 0x04, 0x31, 0x90, 0x9C, 0x1D,
+0x12, 0x04, 0xB8, 0x12, 0x03, 0xCD, 0x90, 0x9C,
+0x25, 0x91, 0x46, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
+0x06, 0xC0, 0x07, 0x90, 0x9C, 0x1D, 0x12, 0x04,
+0xB8, 0x90, 0x9C, 0x21, 0x91, 0x46, 0xD0, 0x03,
+0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x82,
+0x05, 0x90, 0x9C, 0x29, 0x12, 0x04, 0x31, 0x90,
+0x9C, 0x1B, 0xA3, 0xE0, 0xFD, 0xC0, 0x05, 0x90,
+0x9C, 0x29, 0x12, 0x04, 0xB8, 0x90, 0x8B, 0x9F,
+0x12, 0x04, 0x31, 0x90, 0x9C, 0x1A, 0xE0, 0xFF,
+0xD0, 0x05, 0x12, 0x79, 0x53, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x9C, 0xBB, 0xEF, 0xF0, 0xED, 0x64,
+0x01, 0x70, 0x2E, 0xEB, 0xB4, 0x01, 0x07, 0xE0,
+0x24, 0x02, 0xF5, 0x13, 0x80, 0x08, 0x90, 0x9C,
+0xBB, 0xE0, 0x24, 0xFE, 0xF5, 0x13, 0x90, 0x9C,
+0x1D, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0xFF,
+0xAF, 0x13, 0xB1, 0x34, 0xB1, 0x2C, 0x12, 0x04,
+0x3D, 0x00, 0x00, 0x00, 0xFF, 0xAF, 0x13, 0x80,
+0x20, 0x90, 0x9C, 0x1D, 0x12, 0x04, 0x3D, 0x00,
+0x00, 0x00, 0xFF, 0x90, 0x9C, 0xBB, 0x12, 0xAF,
+0x13, 0xB1, 0x38, 0xB1, 0x2C, 0x12, 0x04, 0x3D,
+0x00, 0x00, 0x00, 0xFF, 0x90, 0x9C, 0xBB, 0xE0,
+0xFF, 0xB1, 0x34, 0x7F, 0x01, 0x91, 0x4C, 0xD0,
+0xD0, 0x92, 0xAF, 0x22, 0xE4, 0xFF, 0x91, 0x4C,
+0x90, 0x9C, 0x1D, 0x22, 0xE4, 0xFC, 0xFD, 0xFE,
+0x90, 0x9C, 0x21, 0x12, 0x04, 0x31, 0x7D, 0x18,
+0x7C, 0x00, 0x22, 0x90, 0x9B, 0x15, 0xE0, 0x90,
+0x9C, 0xBE, 0xF0, 0x22, 0xF0, 0x90, 0x06, 0x08,
+0xE0, 0x54, 0x7F, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x02, 0x09, 0xE0,
+0xFD, 0x12, 0x02, 0x06, 0xFF, 0x54, 0x01, 0xFE,
+0x90, 0x93, 0x04, 0xF1, 0x4C, 0xFC, 0xEF, 0x54,
+0xFB, 0x4C, 0xFF, 0x90, 0x93, 0x04, 0x12, 0x9F,
+0xE1, 0x54, 0x10, 0xFE, 0xEF, 0x54, 0xEF, 0x4E,
+0x90, 0x93, 0x04, 0xF0, 0x12, 0x9C, 0x5A, 0xFF,
+0xED, 0x2F, 0x90, 0x93, 0x05, 0x12, 0x87, 0xE6,
+0xFF, 0xED, 0x2F, 0x90, 0x93, 0x06, 0x12, 0x87,
+0xA3, 0xFF, 0xAE, 0x05, 0xED, 0x2F, 0x90, 0x93,
+0x07, 0xF0, 0x90, 0x93, 0x04, 0xE0, 0xFF, 0x20,
+0xE0, 0x08, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x30,
+0xE0, 0x09, 0x90, 0x06, 0x31, 0xE0, 0x44, 0x40,
+0xF0, 0xD1, 0x19, 0x90, 0x93, 0x04, 0xE0, 0xFF,
+0x30, 0xE0, 0x3A, 0x90, 0x06, 0x32, 0xE0, 0x44,
+0x01, 0xF0, 0x90, 0x06, 0x09, 0xE0, 0x54, 0xFE,
+0xB1, 0x4C, 0xEF, 0x13, 0x13, 0x54, 0x3F, 0x30,
+0xE0, 0x0A, 0x12, 0xCF, 0x69, 0xF0, 0x90, 0x9B,
+0x25, 0x74, 0x01, 0xF0, 0x7D, 0x08, 0xE4, 0xFF,
+0x12, 0x7C, 0x74, 0xD1, 0x11, 0x20, 0xE0, 0x0D,
+0x90, 0x9C, 0x9B, 0x12, 0x04, 0x3D, 0x00, 0x00,
+0x27, 0x10, 0x12, 0x95, 0x30, 0xD1, 0x11, 0x30,
+0xE0, 0x0A, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x02,
+0xF0, 0x12, 0x8E, 0xEA, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0x90, 0x93, 0x04, 0xE0, 0xFF, 0xC3, 0x13,
+0x22, 0x90, 0x93, 0x06, 0xF1, 0x25, 0x12, 0x8E,
+0x9B, 0xE0, 0x90, 0x9B, 0x0D, 0xF0, 0x74, 0x01,
+0x2F, 0x12, 0xC3, 0xF0, 0xE0, 0x90, 0x9B, 0x0E,
+0xF1, 0x0B, 0x90, 0x9B, 0x0F, 0xF0, 0x74, 0x03,
+0x2F, 0xD1, 0x6D, 0xE0, 0x90, 0x9B, 0x10, 0xF1,
+0x18, 0x90, 0x9B, 0x11, 0xF0, 0x74, 0x05, 0x2F,
+0x12, 0xC7, 0xB0, 0xE0, 0x90, 0x9B, 0x12, 0xF0,
+0x74, 0x06, 0x2F, 0xD1, 0xF9, 0x90, 0x9B, 0x13,
+0xF0, 0x74, 0x07, 0x2F, 0xF1, 0x02, 0x90, 0x9B,
+0x14, 0xF0, 0x74, 0x08, 0x2F, 0x12, 0xCF, 0x9F,
+0x90, 0x9B, 0x15, 0xF0, 0x22, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0x22, 0xE4, 0xFD, 0xFC,
+0x90, 0x98, 0x41, 0xF1, 0x37, 0xAB, 0x05, 0x74,
+0x01, 0x2B, 0x12, 0xC3, 0xF0, 0xE0, 0xFE, 0x74,
+0x00, 0x2B, 0x12, 0x8E, 0x9B, 0xF1, 0x79, 0x3E,
+0x90, 0x95, 0x93, 0xF0, 0xA3, 0xEF, 0xF0, 0x74,
+0x03, 0x2B, 0xD1, 0x6D, 0xE0, 0xFE, 0x74, 0x02,
+0x2B, 0xF1, 0x0F, 0x24, 0x00, 0xFF, 0xEA, 0x3E,
+0x90, 0x95, 0x95, 0xF0, 0xA3, 0xEF, 0xF0, 0x74,
+0x05, 0x2B, 0x12, 0xC7, 0xB0, 0xE0, 0xFE, 0x74,
+0x04, 0x2B, 0xF1, 0x1C, 0x24, 0x00, 0xFF, 0xEA,
+0x3E, 0x90, 0x95, 0x97, 0xF0, 0xA3, 0xEF, 0xF0,
+0x74, 0x07, 0x2B, 0xF1, 0x02, 0xFE, 0x74, 0x06,
+0x2B, 0xD1, 0xF9, 0x24, 0x00, 0xFF, 0xEA, 0x3E,
+0x90, 0x95, 0x99, 0xF0, 0xA3, 0xEF, 0xF0, 0x74,
+0x09, 0x2B, 0x12, 0xCF, 0xA8, 0xFE, 0x74, 0x08,
+0x2B, 0x12, 0xCF, 0x9F, 0x24, 0x00, 0xFF, 0xEC,
+0x3E, 0x90, 0x95, 0x9B, 0xF0, 0xA3, 0xEF, 0xF0,
+0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xE0, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
+0x83, 0xE0, 0x22, 0xF0, 0x74, 0x02, 0x2F, 0xF5,
+0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22,
+0xF0, 0x74, 0x04, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xE0, 0x22, 0xE0, 0xFF, 0x12,
+0x7B, 0x07, 0x74, 0x00, 0x2F, 0x22, 0xEF, 0x60,
+0x05, 0xD1, 0x75, 0x12, 0x8D, 0xD1, 0x22, 0xE0,
+0xFF, 0x12, 0x7B, 0x07, 0x7C, 0x00, 0xAD, 0x07,
+0x22, 0x90, 0x88, 0x31, 0xE0, 0x30, 0xE0, 0x03,
+0x12, 0xBF, 0x8C, 0x22, 0xE0, 0x54, 0xFE, 0x4E,
+0xFE, 0xF0, 0xEF, 0x54, 0x02, 0xFF, 0xEE, 0x54,
+0xFD, 0x4F, 0xFF, 0xF0, 0x12, 0x02, 0x06, 0xFE,
+0x54, 0x04, 0x22, 0x74, 0x01, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0xFE, 0x74,
+0x00, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5,
+0x83, 0xE0, 0x7A, 0x00, 0x24, 0x00, 0xFF, 0xEA,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0xE4, 0xFE, 0xFD, 0xEF, 0xB4, 0x01, 0x0D, 0xEB,
+0xB4, 0x02, 0x03, 0x0D, 0x80, 0x06, 0xEB, 0xB4,
+0x01, 0x02, 0x7D, 0x02, 0xAF, 0x06, 0xEF, 0xC4,
+0x54, 0xF0, 0x4D, 0xFF, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xE4, 0xFD, 0xFC, 0xEF, 0x60, 0x2F, 0x90,
+0x98, 0x3B, 0xF1, 0x37, 0x12, 0xF9, 0xEE, 0x90,
+0x99, 0xB1, 0x12, 0x82, 0x27, 0x90, 0x99, 0xB1,
+0x12, 0x8B, 0xE0, 0x75, 0x48, 0x40, 0x7B, 0x01,
+0x7A, 0x93, 0x79, 0xF9, 0x12, 0x69, 0xF5, 0x12,
+0xF3, 0x4E, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8,
+0xF9, 0xF1, 0xDF, 0x12, 0x54, 0x1E, 0x22, 0xFF,
+0x12, 0x77, 0xA4, 0x7D, 0x01, 0x7F, 0x03, 0x22,
+0x90, 0x8A, 0x79, 0x74, 0x87, 0xF0, 0xA3, 0x74,
+0x4A, 0xF0, 0x90, 0x8A, 0xE5, 0x74, 0xD9, 0xF0,
+0xA3, 0x74, 0x73, 0xF0, 0x90, 0x8B, 0x03, 0x74,
+0x98, 0xF0, 0xA3, 0x74, 0x1B, 0xF0, 0x90, 0x8A,
+0xB9, 0x74, 0x88, 0xF0, 0xA3, 0x74, 0xD2, 0xF0,
+0x90, 0x8A, 0x75, 0x74, 0xBB, 0xF0, 0xA3, 0x74,
+0x08, 0xF0, 0x90, 0x8A, 0xC3, 0x74, 0xDE, 0xF0,
+0xA3, 0x74, 0x57, 0xF0, 0x90, 0x8A, 0xF3, 0x74,
+0xE3, 0xF0, 0xA3, 0x74, 0x47, 0xF0, 0x90, 0x8A,
+0x85, 0x74, 0xE3, 0xF0, 0xA3, 0x74, 0x53, 0xF0,
+0x90, 0x86, 0x0C, 0x74, 0xDE, 0xF0, 0xA3, 0x74,
+0x87, 0xF0, 0x90, 0x8A, 0xEF, 0x74, 0xDE, 0xF0,
+0xA3, 0x74, 0xEF, 0xF0, 0x90, 0x86, 0x00, 0x74,
+0xF7, 0xF0, 0xA3, 0x74, 0x5D, 0xF0, 0x90, 0x86,
+0x02, 0x74, 0xF7, 0xF0, 0xA3, 0x74, 0xA9, 0xF0,
+0x90, 0x8A, 0xFD, 0x74, 0xDF, 0xF0, 0xA3, 0x74,
+0x67, 0xF0, 0x90, 0x8A, 0xF9, 0x74, 0xC0, 0xF0,
+0xA3, 0x74, 0x5A, 0xF0, 0x90, 0x8A, 0xAF, 0x74,
+0x8F, 0xF0, 0xA3, 0x74, 0x73, 0xF0, 0x90, 0x8A,
+0xD3, 0x74, 0xC6, 0xF0, 0xA3, 0x74, 0xA6, 0xF0,
+0x90, 0x8A, 0xF5, 0x74, 0xF8, 0xF0, 0xA3, 0x74,
+0xBC, 0xF0, 0x90, 0x8A, 0xA3, 0x74, 0xB5, 0xF0,
+0xA3, 0x74, 0x4D, 0xF0, 0x90, 0x86, 0x06, 0x74,
+0xDD, 0xF0, 0xA3, 0x74, 0x49, 0xF0, 0x22, 0xE4,
+0xFB, 0xFA, 0xFD, 0x7F, 0x01, 0x12, 0x86, 0x4E,
+0x90, 0x9A, 0x33, 0xEF, 0xF0, 0x60, 0xF0, 0x90,
+0x86, 0xAF, 0xE0, 0xFF, 0x70, 0x04, 0xA3, 0xE0,
+0x60, 0xE5, 0xC2, 0xAF, 0xEF, 0x30, 0xE1, 0x0D,
+0x90, 0x86, 0xAF, 0xE0, 0x54, 0xFD, 0xF0, 0x90,
+0x86, 0x08, 0x12, 0x88, 0xC8, 0x31, 0x16, 0x30,
+0xE2, 0x09, 0x54, 0xFB, 0xF0, 0x90, 0x86, 0x0A,
+0x12, 0x88, 0xC8, 0x31, 0x16, 0xFF, 0x30, 0xE4,
+0x0C, 0x54, 0xEF, 0xF0, 0x12, 0xBF, 0xAC, 0xBF,
+0x01, 0x03, 0x12, 0xA8, 0xB1, 0x31, 0x16, 0xFF,
+0x30, 0xE7, 0x06, 0x54, 0x7F, 0xF0, 0x12, 0x95,
+0xAB, 0xD2, 0xAF, 0xC2, 0xAF, 0x90, 0x86, 0xB0,
+0xE0, 0xFF, 0x30, 0xE2, 0x05, 0x54, 0xFB, 0xF0,
+0x31, 0x1F, 0xD2, 0xAF, 0x80, 0xA1, 0xD2, 0xAF,
+0xC2, 0xAF, 0x90, 0x86, 0xAF, 0xE0, 0x22, 0x90,
+0x93, 0x2D, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x3D,
+0x31, 0x66, 0x60, 0x0E, 0x12, 0xBF, 0x5E, 0xE4,
+0x90, 0x92, 0x20, 0xF0, 0xA3, 0x04, 0xF0, 0xE4,
+0x80, 0x22, 0x90, 0x93, 0x2D, 0x12, 0x97, 0xD1,
+0x30, 0xE0, 0x0B, 0xA3, 0xE0, 0x90, 0x92, 0x20,
+0xF0, 0xE4, 0xA3, 0xF0, 0x80, 0x0E, 0xE4, 0x90,
+0x92, 0x20, 0xF0, 0x90, 0x93, 0x2E, 0xE0, 0x90,
+0x92, 0x21, 0xF0, 0xE4, 0xFB, 0xFD, 0x7F, 0x5C,
+0x7E, 0x01, 0x12, 0x66, 0x33, 0x22, 0x7F, 0x60,
+0x12, 0x7B, 0x41, 0xEF, 0x54, 0x01, 0x90, 0x98,
+0x4A, 0xF0, 0x22, 0x8F, 0x12, 0x7F, 0x02, 0x12,
+0x86, 0x27, 0x90, 0x86, 0xAF, 0xE0, 0x45, 0x12,
+0xF0, 0x22, 0x8F, 0x0E, 0x7F, 0x02, 0x12, 0x86,
+0x27, 0x90, 0x86, 0xB0, 0xE0, 0x45, 0x0E, 0xF0,
+0x22, 0x7F, 0x04, 0x80, 0xED, 0xC0, 0xE0, 0xC0,
 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75,
 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0xA5, 0xF0,
-0x74, 0xB3, 0xA3, 0xF0, 0x12, 0x64, 0x7F, 0xE5,
-0x30, 0x30, 0xE1, 0x03, 0x12, 0xC7, 0x8E, 0xE5,
-0x2D, 0x30, 0xE3, 0x03, 0x12, 0xD1, 0x12, 0xE5,
-0x2D, 0x30, 0xE4, 0x03, 0x12, 0xD1, 0x25, 0xE5,
-0x2D, 0x30, 0xE5, 0x03, 0x12, 0xD1, 0x36, 0xE5,
-0x2F, 0x30, 0xE0, 0x02, 0x51, 0x62, 0xE5, 0x2F,
-0x30, 0xE1, 0x02, 0x91, 0x49, 0xE5, 0x2F, 0x30,
-0xE2, 0x03, 0x12, 0xC6, 0x87, 0xE5, 0x2F, 0x30,
-0xE3, 0x02, 0x71, 0x53, 0xE5, 0x2F, 0x30, 0xE4,
-0x02, 0x71, 0x82, 0xE5, 0x2F, 0x30, 0xE5, 0x03,
-0x12, 0xC6, 0x99, 0xE5, 0x2F, 0x30, 0xE6, 0x03,
-0x12, 0xC6, 0xBC, 0x74, 0xA5, 0x04, 0x90, 0x01,
-0xC4, 0xF0, 0x74, 0xB3, 0xA3, 0xF0, 0xD0, 0x07,
-0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0,
-0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0,
-0x32, 0x90, 0x88, 0x36, 0xE0, 0x70, 0x02, 0x81,
-0xD7, 0x90, 0x88, 0x4D, 0xE0, 0x04, 0xF0, 0x90,
-0x05, 0x61, 0xB1, 0x5C, 0x78, 0x08, 0x12, 0x03,
-0xFE, 0xA8, 0x04, 0xA9, 0x05, 0xAA, 0x06, 0xAB,
-0x07, 0x90, 0x05, 0x60, 0xB1, 0x5C, 0x12, 0x82,
-0x05, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x90, 0x05, 0x62, 0xB1, 0x5C, 0x78, 0x10,
-0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0x82, 0x05, 0xC0, 0x04,
-0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0xA3, 0xB1,
-0x5C, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x82,
-0x05, 0x90, 0x88, 0x81, 0x12, 0x04, 0x31, 0x90,
-0x88, 0x32, 0xE0, 0x54, 0x7F, 0xF0, 0xA3, 0xE0,
-0x30, 0xE0, 0x0C, 0x12, 0xC8, 0x35, 0x74, 0x05,
-0xF0, 0x12, 0x6E, 0x2F, 0x12, 0xD9, 0x77, 0x12,
-0x89, 0xEE, 0x30, 0xE0, 0x0A, 0x90, 0x01, 0x3B,
-0xE0, 0x30, 0xE4, 0x03, 0x12, 0xF4, 0xD2, 0x12,
-0xBC, 0xF8, 0x12, 0xDA, 0x0F, 0xE4, 0x90, 0x98,
-0x23, 0xF0, 0x12, 0xF4, 0xC1, 0x90, 0x93, 0x24,
-0x12, 0xA6, 0xEE, 0x30, 0xE0, 0x52, 0x90, 0x95,
-0x67, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x7C, 0x00,
-0x7D, 0x64, 0x12, 0x02, 0x92, 0x90, 0x95, 0xBB,
-0xE0, 0x6E, 0x70, 0x03, 0xA3, 0xE0, 0x6F, 0x60,
-0x0A, 0x90, 0x95, 0xBB, 0xE4, 0x75, 0xF0, 0x01,
-0x02, 0x02, 0xE7, 0x90, 0x95, 0x6B, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x90, 0x95, 0x79, 0xE0, 0xB5,
-0x06, 0x14, 0xA3, 0xE0, 0xB5, 0x07, 0x0F, 0xEF,
-0x4E, 0x60, 0x0B, 0x90, 0x01, 0xC7, 0x74, 0x31,
-0xF0, 0x7F, 0x01, 0x02, 0xBC, 0x2E, 0x12, 0xE5,
-0x43, 0xE4, 0x90, 0x95, 0xBB, 0xF0, 0xA3, 0xF0,
-0x22, 0x12, 0x04, 0x31, 0x90, 0x99, 0x85, 0xE4,
-0x75, 0xF0, 0x04, 0x12, 0x02, 0xE7, 0x90, 0x99,
-0x85, 0xA3, 0xE0, 0x24, 0x02, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFF, 0xE4, 0xFC,
-0xFD, 0xFE, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
-0xC0, 0xD0, 0x12, 0xC1, 0x87, 0x90, 0x99, 0x8A,
-0xF0, 0x90, 0x02, 0x09, 0xE0, 0x90, 0x99, 0x8B,
-0xF0, 0x90, 0x98, 0x19, 0x12, 0xE2, 0x00, 0x90,
-0x99, 0x85, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12,
-0xCD, 0xDF, 0xE0, 0x90, 0x95, 0xBD, 0xF0, 0x74,
-0x01, 0x2F, 0x12, 0xCF, 0x6A, 0xE0, 0x90, 0x95,
-0xBE, 0xF0, 0xF1, 0xE6, 0x12, 0x02, 0xE7, 0x90,
-0x99, 0x85, 0xA3, 0xE0, 0x24, 0x02, 0x12, 0xDD,
-0xC9, 0xFF, 0xE4, 0xFC, 0xFD, 0x78, 0x10, 0x12,
-0x03, 0xFE, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06,
-0xC0, 0x07, 0x12, 0xF5, 0x15, 0xB1, 0x5A, 0x78,
-0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0x12, 0x80, 0xC0, 0xC0,
-0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07, 0x12,
-0xF5, 0x08, 0xB1, 0x5A, 0x78, 0x08, 0x12, 0x03,
-0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0,
-0x00, 0x12, 0xCD, 0xCF, 0xB1, 0x5C, 0x12, 0x80,
-0xC0, 0x90, 0x95, 0xC1, 0xB1, 0x41, 0x78, 0x10,
-0x12, 0x03, 0xFE, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x12, 0xF5, 0x15, 0xB1, 0x5A,
-0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0,
-0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x80, 0xC0,
+0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74, 0x95, 0xF0,
+0x74, 0xD9, 0xA3, 0xF0, 0x12, 0x6C, 0xD6, 0xE5,
+0x27, 0x30, 0xE4, 0x02, 0x31, 0x91, 0x90, 0x86,
+0xB3, 0xE0, 0xFC, 0x64, 0x03, 0x70, 0x37, 0x90,
+0x99, 0xB0, 0xE0, 0xFE, 0x20, 0xE0, 0x2F, 0xE5,
+0x26, 0x30, 0xE3, 0x2A, 0x90, 0x00, 0xCC, 0xE0,
+0x44, 0x04, 0xF0, 0x90, 0x00, 0xD4, 0xE0, 0x44,
+0x10, 0xF0, 0x90, 0x00, 0xC6, 0xE0, 0x44, 0x02,
+0xF0, 0x90, 0x00, 0x01, 0xE0, 0x54, 0xCF, 0xF0,
+0x90, 0x00, 0x23, 0xE0, 0x54, 0x7F, 0xF0, 0xEE,
+0x44, 0x01, 0x90, 0x99, 0xB0, 0xF0, 0xEC, 0xB4,
+0x01, 0x0B, 0xE5, 0x26, 0x30, 0xE2, 0x06, 0x90,
+0x88, 0x41, 0x74, 0xDD, 0xF0, 0x74, 0x95, 0x04,
+0x90, 0x01, 0xC4, 0xF0, 0x74, 0xD9, 0xA3, 0xF0,
+0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
+0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
+0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
+0xD0, 0xE0, 0x32, 0xC0, 0xE0, 0xC0, 0xF0, 0xC0,
+0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0, 0x00,
+0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02, 0xC0, 0x03,
 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0, 0x07,
-0x12, 0xF5, 0x08, 0xB1, 0x5A, 0x78, 0x08, 0x12,
-0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0x12, 0xCD, 0xCF, 0xB1, 0x5C, 0x12,
-0x80, 0xC0, 0x90, 0x95, 0xC5, 0xB1, 0x41, 0x78,
-0x10, 0x12, 0x03, 0xFE, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x12, 0xF5, 0x15, 0xB1,
-0x5A, 0x78, 0x18, 0x12, 0x03, 0xFE, 0xD0, 0x03,
-0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00, 0x12, 0x80,
-0xC0, 0xC0, 0x04, 0xC0, 0x05, 0xC0, 0x06, 0xC0,
-0x07, 0x12, 0xF5, 0x08, 0xB1, 0x5A, 0x78, 0x08,
-0x12, 0x03, 0xFE, 0xD0, 0x03, 0xD0, 0x02, 0xD0,
-0x01, 0xD0, 0x00, 0x12, 0xCD, 0xCF, 0xB1, 0x5C,
-0x12, 0x80, 0xC0, 0x90, 0x95, 0xC9, 0x12, 0x04,
-0x31, 0xF1, 0xE6, 0xF1, 0xDD, 0x12, 0xF5, 0x22,
-0x12, 0xCD, 0xDF, 0xE0, 0xFF, 0x12, 0xF5, 0x58,
-0xF1, 0xCB, 0xE0, 0xB4, 0x10, 0xEF, 0xF1, 0xD6,
-0x12, 0xF5, 0x22, 0x12, 0xCD, 0xDF, 0xE0, 0xFF,
-0x74, 0xDD, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95,
-0xF1, 0xCB, 0xE0, 0xB4, 0x10, 0xEA, 0xF1, 0xD6,
-0x12, 0xF5, 0x22, 0x12, 0xCD, 0xDF, 0xE0, 0xFF,
-0x74, 0xED, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95,
-0xF1, 0xCB, 0xE0, 0xB4, 0x10, 0xEA, 0x90, 0x99,
-0x85, 0x12, 0xEE, 0x4C, 0x90, 0x98, 0x19, 0x12,
-0x9F, 0xEE, 0xE4, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
-0x99, 0x85, 0xE4, 0x75, 0xF0, 0x40, 0xF1, 0xDD,
-0x90, 0x99, 0x87, 0xE0, 0xFF, 0xC3, 0x94, 0x08,
-0x50, 0x20, 0x90, 0x99, 0x85, 0xA3, 0xE0, 0xFE,
-0xEF, 0x2E, 0x12, 0xCD, 0xDF, 0xE0, 0xFE, 0x90,
-0x99, 0x8B, 0xE0, 0xFD, 0xEE, 0x2D, 0xFE, 0x74,
-0xFD, 0x2F, 0x12, 0xD7, 0x6B, 0xEE, 0xF1, 0xCE,
-0x80, 0xD6, 0x90, 0x98, 0x19, 0xE0, 0x04, 0x90,
-0x99, 0x89, 0xF0, 0xE4, 0x90, 0x99, 0x88, 0xF0,
-0x90, 0x95, 0xBD, 0xE0, 0x13, 0x13, 0x54, 0x3F,
-0x24, 0x01, 0xFF, 0xE4, 0x33, 0xFE, 0x90, 0x99,
-0x88, 0xE0, 0xC3, 0x9F, 0xEE, 0x12, 0xD9, 0x70,
-0x50, 0x7A, 0xA3, 0x12, 0x9F, 0xEE, 0xE4, 0xF0,
-0xA3, 0xEF, 0xF0, 0xE4, 0xA3, 0xF0, 0x90, 0x99,
-0x87, 0xE0, 0xFD, 0xC3, 0x94, 0x04, 0x50, 0x56,
-0xA3, 0xE0, 0x75, 0xF0, 0x04, 0xA4, 0x7C, 0x00,
-0x2D, 0xFF, 0xEC, 0x35, 0xF0, 0xFE, 0x90, 0x95,
-0xBD, 0xE0, 0xFD, 0xC3, 0xEF, 0x9D, 0x74, 0x80,
-0xF8, 0x6E, 0x98, 0x50, 0x39, 0xEF, 0x78, 0x05,
-0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24,
-0x05, 0xF9, 0x74, 0x96, 0x3E, 0xFA, 0x7B, 0x01,
-0xC0, 0x03, 0xC0, 0x01, 0x90, 0x99, 0x85, 0xA3,
-0xE0, 0x24, 0x00, 0xF9, 0xE4, 0x34, 0xFC, 0x8B,
-0x45, 0xF5, 0x46, 0x89, 0x47, 0x75, 0x48, 0x20,
-0xD0, 0x01, 0xD0, 0x03, 0x12, 0x9F, 0x90, 0x12,
-0xEE, 0x53, 0xF1, 0xCF, 0x80, 0xA0, 0x90, 0x99,
-0x89, 0xE0, 0x04, 0xF0, 0x90, 0x99, 0x88, 0xE0,
-0x04, 0xF0, 0xE1, 0x20, 0xE4, 0x90, 0x99, 0x87,
-0xF0, 0xE4, 0xFF, 0x0F, 0xEF, 0xB4, 0x20, 0xFB,
-0xF1, 0xCF, 0xE0, 0xB4, 0x10, 0xF3, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xF5, 0x83, 0xEF, 0xF0, 0x90,
-0x99, 0x87, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x99,
-0x85, 0xE4, 0x75, 0xF0, 0x10, 0x12, 0x02, 0xE7,
-0xE4, 0x90, 0x99, 0x87, 0xF0, 0x22, 0x90, 0x99,
-0x85, 0xE4, 0x75, 0xF0, 0x04, 0x22, 0x90, 0x01,
-0x57, 0xE4, 0xF0, 0x90, 0x01, 0x3C, 0x74, 0x02,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x01, 0xCC, 0xE0, 0x54, 0x0F, 0xFD, 0xED,
-0x70, 0x02, 0x01, 0xF0, 0x90, 0x87, 0x0B, 0xE0,
-0xFF, 0x70, 0x06, 0xA3, 0xE0, 0x64, 0x09, 0x60,
-0x0A, 0xEF, 0x14, 0xFF, 0x90, 0x87, 0x0C, 0xE0,
-0xB5, 0x07, 0x04, 0x7F, 0x01, 0x80, 0x02, 0x7F,
-0x00, 0xEF, 0x60, 0x09, 0x90, 0x01, 0xC1, 0xE0,
-0x44, 0x01, 0xF0, 0x01, 0xF0, 0x90, 0x9C, 0x98,
-0x12, 0xA0, 0xDC, 0x80, 0x05, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0xED, 0xFB, 0xEF,
-0x5B, 0x70, 0x02, 0x01, 0xCD, 0xE4, 0xFC, 0x31,
-0x00, 0x7A, 0x00, 0x2F, 0xFF, 0xEA, 0x35, 0xF0,
-0xFE, 0x74, 0xD0, 0x11, 0xF5, 0x90, 0x87, 0x0C,
-0xE0, 0xF9, 0x75, 0xF0, 0x08, 0x90, 0x86, 0xBB,
-0x31, 0x0B, 0xEF, 0xF0, 0x31, 0x00, 0x2F, 0xFF,
-0xEA, 0x35, 0xF0, 0xFE, 0x74, 0xF0, 0x11, 0xF5,
-0x75, 0xF0, 0x08, 0xE9, 0x90, 0x86, 0xBF, 0x31,
-0x0B, 0xEF, 0xF0, 0x0C, 0xEC, 0xB4, 0x04, 0xC7,
-0x90, 0x9C, 0x98, 0x12, 0x97, 0xEF, 0x08, 0x80,
-0x02, 0xC3, 0x33, 0xD8, 0xFC, 0xF4, 0x5D, 0xFD,
-0x90, 0x9C, 0x98, 0x12, 0x97, 0xEF, 0x08, 0x80,
-0x02, 0xC3, 0x33, 0xD8, 0xFC, 0x90, 0x01, 0xCC,
-0xF0, 0x90, 0x9C, 0x98, 0xE0, 0x04, 0xF0, 0xE0,
-0x54, 0x03, 0xF0, 0x90, 0x87, 0x0C, 0xE0, 0x04,
-0xF0, 0xE0, 0x7F, 0x00, 0xB4, 0x0A, 0x02, 0x7F,
-0x01, 0xEF, 0x70, 0x02, 0x01, 0x07, 0xE4, 0x90,
-0x87, 0x0C, 0xF0, 0x01, 0x07, 0x90, 0x01, 0xC0,
-0xE0, 0x44, 0x02, 0xF0, 0x90, 0x9C, 0x98, 0xE0,
-0x44, 0x80, 0x90, 0x00, 0x8A, 0xF0, 0x90, 0x9C,
-0x98, 0xE0, 0x75, 0xF0, 0x04, 0x90, 0x01, 0xD0,
-0x12, 0x04, 0x6E, 0xE0, 0x90, 0x01, 0xC3, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x2F, 0xF5, 0x82,
-0x74, 0x01, 0x3E, 0xF5, 0x83, 0xE0, 0xFF, 0x22,
-0x90, 0x9C, 0x98, 0xE0, 0x75, 0xF0, 0x04, 0xA4,
-0xFF, 0xEC, 0x22, 0x12, 0x04, 0x6E, 0xE5, 0x82,
-0x2C, 0xF5, 0x82, 0xE4, 0x35, 0x83, 0xF5, 0x83,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x9C, 0x8F, 0xEF, 0xF0, 0x90, 0x00, 0x8F,
-0xE0, 0x30, 0xE6, 0x44, 0x90, 0x00, 0x8D, 0xE0,
-0x64, 0x01, 0x70, 0x3C, 0x90, 0x9C, 0x90, 0xF0,
-0x90, 0x9C, 0x90, 0xE0, 0xFD, 0x90, 0x9C, 0x8F,
-0xE0, 0xC4, 0x54, 0xF0, 0x24, 0x00, 0xF5, 0x82,
-0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE5, 0x82, 0x2D,
-0x31, 0x11, 0xE0, 0xFB, 0xE4, 0xFF, 0x31, 0x75,
-0x90, 0x9C, 0x90, 0xE0, 0x04, 0xF0, 0xE0, 0xC3,
-0x94, 0x10, 0x40, 0xD4, 0x90, 0x00, 0x8F, 0xE0,
-0x30, 0xE0, 0x05, 0x90, 0x00, 0x8D, 0xE4, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF, 0x70, 0x04,
-0x74, 0xF0, 0x80, 0x16, 0xEF, 0xB4, 0x01, 0x04,
-0x74, 0xF4, 0x80, 0x0E, 0xEF, 0xB4, 0x02, 0x04,
-0x74, 0xF8, 0x80, 0x06, 0xEF, 0xB4, 0x03, 0x0C,
-0x74, 0xFC, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0x02,
-0xF5, 0x83, 0xEB, 0xF0, 0x22, 0xD3, 0x10, 0xAF,
-0x01, 0xC3, 0xC0, 0xD0, 0x7F, 0x8F, 0x12, 0x7B,
-0x41, 0xEF, 0x30, 0xE6, 0x2E, 0x90, 0x00, 0x8C,
-0xE0, 0x90, 0x9C, 0x84, 0xF0, 0x7F, 0x8D, 0x12,
-0x7B, 0x41, 0x90, 0x9C, 0x85, 0xEF, 0xF0, 0x90,
-0x00, 0x8E, 0xE0, 0x90, 0x9C, 0x86, 0xF0, 0x90,
-0x9C, 0x85, 0xE0, 0x7F, 0x8F, 0x12, 0x7B, 0x41,
-0xEF, 0x30, 0xE0, 0x07, 0xE4, 0xFD, 0x7F, 0x8D,
-0x12, 0x7B, 0x2E, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xE4, 0x90, 0x99, 0xDD, 0xF0, 0xA3, 0xF0, 0xA3,
-0xF0, 0x90, 0x99, 0xDD, 0xE0, 0x64, 0x01, 0xF0,
-0x90, 0x98, 0x36, 0xE0, 0x70, 0x18, 0x90, 0x98,
-0x33, 0xE0, 0x70, 0x12, 0xA3, 0xE0, 0x70, 0x0E,
-0x90, 0x99, 0xDD, 0xE0, 0x24, 0xE0, 0x90, 0x01,
-0xC4, 0xF0, 0x74, 0xB9, 0xA3, 0xF0, 0x12, 0x7C,
-0x54, 0xBF, 0x01, 0x03, 0x12, 0x54, 0x9F, 0x90,
-0x88, 0x36, 0xE0, 0x60, 0x0E, 0x90, 0x88, 0x39,
-0xE0, 0xFF, 0x90, 0x88, 0x38, 0xE0, 0x6F, 0x60,
-0x02, 0xD1, 0x1B, 0xC2, 0xAF, 0x12, 0xC4, 0x4D,
-0xBF, 0x01, 0x16, 0x90, 0x86, 0xB3, 0xE0, 0xFF,
-0xB4, 0x03, 0x07, 0x90, 0x99, 0x84, 0xE0, 0x20,
-0xE0, 0x05, 0xEF, 0x64, 0x03, 0x60, 0x02, 0x51,
-0x55, 0xD2, 0xAF, 0x12, 0xCA, 0xB8, 0x31, 0x9D,
-0x12, 0x84, 0x4D, 0x80, 0x94, 0x90, 0x88, 0x31,
-0xE0, 0x30, 0xE0, 0x02, 0x51, 0x5F, 0x22, 0x90,
-0x88, 0x39, 0xE0, 0xFF, 0x60, 0x03, 0xB4, 0x08,
-0x0E, 0x12, 0xF3, 0xC8, 0xBF, 0x01, 0x08, 0x51,
-0x78, 0x90, 0x01, 0xE5, 0xE0, 0x04, 0xF0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12,
-0xC1, 0xB3, 0x51, 0x89, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xE4, 0x90, 0x99, 0xE0, 0xF0, 0x12, 0xD8,
-0x32, 0x12, 0xC0, 0x41, 0xE4, 0xFF, 0x12, 0xC2,
-0xC8, 0x90, 0x93, 0x0C, 0xE0, 0x20, 0xE0, 0x02,
-0x61, 0x87, 0x90, 0x00, 0x02, 0xE0, 0x44, 0x02,
-0xF0, 0xE4, 0x90, 0x99, 0xE1, 0xF0, 0x90, 0x99,
-0xE1, 0xE0, 0xFF, 0xC3, 0x94, 0x05, 0x50, 0x30,
-0x12, 0xA0, 0xDE, 0x80, 0x05, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x93, 0x0F,
-0xE0, 0xFD, 0xEF, 0x5D, 0x60, 0x12, 0x90, 0x99,
-0xE1, 0x12, 0xC3, 0x4D, 0x90, 0x99, 0xE1, 0x12,
-0xC3, 0x6D, 0x44, 0x40, 0xF0, 0x12, 0xC1, 0xAC,
-0x90, 0x99, 0xE1, 0xE0, 0x04, 0xF0, 0x80, 0xC6,
-0x90, 0x07, 0xC7, 0xE4, 0xF0, 0x90, 0x07, 0xC6,
-0xF0, 0x90, 0x07, 0xC5, 0x74, 0x77, 0xF0, 0x90,
-0x07, 0xC4, 0xE4, 0xF0, 0x90, 0x07, 0xC0, 0x74,
-0x38, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x0F,
-0xF0, 0xA3, 0x74, 0xC0, 0xF0, 0x90, 0x02, 0x26,
-0xE0, 0x44, 0x01, 0xF0, 0xE0, 0x90, 0x99, 0xE2,
-0xF0, 0x90, 0x99, 0xE2, 0xE0, 0x30, 0xE0, 0x19,
-0x90, 0x99, 0xE0, 0xE0, 0x04, 0xF0, 0x71, 0x98,
-0x90, 0x02, 0x26, 0xE0, 0x90, 0x99, 0xE2, 0xF0,
-0x90, 0x99, 0xE0, 0xE0, 0xD3, 0x94, 0xFA, 0x40,
-0xE0, 0x90, 0x02, 0x03, 0x74, 0x80, 0xF0, 0x90,
-0x04, 0x24, 0xE0, 0x90, 0x99, 0xE3, 0xF0, 0x90,
-0x04, 0x22, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x02,
-0x00, 0xE0, 0x90, 0x99, 0xE2, 0xF0, 0x90, 0x02,
-0x01, 0x71, 0x8F, 0x90, 0x02, 0x02, 0x71, 0x8F,
-0x90, 0x02, 0x14, 0x71, 0x8F, 0xE0, 0x04, 0xF0,
-0xE0, 0x90, 0x04, 0x24, 0xF0, 0x90, 0x04, 0x22,
-0xE0, 0x54, 0xEF, 0xF0, 0x90, 0x99, 0xE3, 0xE0,
-0x90, 0x04, 0x24, 0xF0, 0x90, 0xFD, 0x09, 0x74,
-0xFF, 0xF0, 0x90, 0xFD, 0x08, 0xE4, 0xF0, 0x90,
-0x88, 0x32, 0xE0, 0x54, 0xEF, 0xF0, 0x22, 0xE0,
-0xFF, 0x90, 0x99, 0xE2, 0xE0, 0x2F, 0xF0, 0x22,
-0x7F, 0x0A, 0x7E, 0x00, 0x02, 0x7C, 0x6A, 0x90,
-0x93, 0x2D, 0xE0, 0xC3, 0x13, 0x30, 0xE0, 0x32,
-0x12, 0xC5, 0x4B, 0x90, 0x98, 0x1E, 0xF0, 0x70,
-0x22, 0x90, 0x93, 0x2D, 0xE0, 0x30, 0xE0, 0x10,
-0x71, 0xF9, 0x91, 0x18, 0x90, 0x93, 0x2D, 0xE0,
-0xC4, 0x54, 0x0F, 0x20, 0xE0, 0x02, 0x71, 0x98,
-0x90, 0x98, 0x1C, 0xE0, 0xFF, 0x7B, 0x01, 0x7D,
-0x01, 0x80, 0x04, 0xB1, 0xD0, 0xFB, 0xFD, 0x02,
-0x96, 0x1A, 0x90, 0x93, 0x2D, 0xE0, 0x30, 0xE0,
-0x17, 0x71, 0xF9, 0x91, 0x18, 0x90, 0x93, 0x2D,
-0xE0, 0xC4, 0x54, 0x0F, 0x20, 0xE0, 0x02, 0x71,
-0x98, 0x90, 0x93, 0x2D, 0xE0, 0x54, 0xFE, 0xF0,
-0x22, 0x90, 0x00, 0xCC, 0xE0, 0x44, 0x04, 0xF0,
-0x7F, 0x02, 0x12, 0x7B, 0x41, 0xEF, 0x54, 0xFB,
-0x22, 0x90, 0x00, 0xCC, 0xE0, 0x44, 0x04, 0xF0,
-0x7F, 0x02, 0x12, 0x7B, 0x41, 0xEF, 0x44, 0x04,
-0xFD, 0x7F, 0x02, 0x12, 0x7B, 0x2E, 0x90, 0x00,
-0xCC, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0x90, 0x01,
-0xC7, 0x74, 0x10, 0xF0, 0x7F, 0x01, 0x90, 0x9C,
-0x9C, 0xEF, 0xF0, 0x90, 0x86, 0xB3, 0xE0, 0x64,
-0x02, 0x70, 0x21, 0x90, 0x9C, 0x9C, 0xE0, 0xFD,
-0x64, 0x01, 0x70, 0x76, 0x12, 0x8F, 0xCA, 0x12,
-0x97, 0xAE, 0x30, 0xE0, 0x09, 0x90, 0x01, 0x4D,
-0xE0, 0x64, 0x80, 0xF0, 0x80, 0x64, 0xAF, 0x05,
-0x91, 0xC5, 0x80, 0x5E, 0x90, 0x86, 0xB3, 0xE0,
-0x64, 0x03, 0x70, 0x2D, 0x90, 0x99, 0x84, 0xE0,
-0xFF, 0x30, 0xE0, 0x25, 0x90, 0x00, 0xD4, 0xE0,
-0x54, 0xEF, 0xF0, 0x90, 0x00, 0xC6, 0xE0, 0x54,
-0xFD, 0xF0, 0x90, 0x00, 0x01, 0xE0, 0x44, 0x30,
-0xF0, 0x90, 0x00, 0x23, 0xE0, 0x44, 0x80, 0xF0,
-0x91, 0x1E, 0xEF, 0x54, 0xFE, 0x90, 0x99, 0x84,
-0xF0, 0x90, 0x06, 0x90, 0xE0, 0x44, 0x20, 0x12,
-0xC7, 0xDA, 0xF1, 0xE0, 0x90, 0x06, 0x90, 0xE0,
-0x44, 0x01, 0xF0, 0x90, 0x9C, 0x9C, 0xE0, 0xFF,
-0x91, 0xC5, 0xB1, 0xD0, 0xFB, 0xFD, 0x12, 0x96,
-0x1A, 0x91, 0x09, 0x90, 0x00, 0x04, 0xE0, 0x44,
-0x08, 0xF0, 0x91, 0xF1, 0xF0, 0x90, 0x93, 0x24,
-0xE0, 0x54, 0xBF, 0xF0, 0x22, 0xEF, 0x64, 0x01,
-0x70, 0x26, 0x90, 0x93, 0x2B, 0xE0, 0x54, 0x7F,
-0xFF, 0x7E, 0x00, 0x90, 0x93, 0x2D, 0xE0, 0x13,
-0x13, 0x54, 0x01, 0xFD, 0x90, 0x93, 0x2C, 0xE0,
-0xFC, 0xC3, 0x13, 0x54, 0x7F, 0xFB, 0xEC, 0x54,
-0x01, 0x90, 0x9C, 0x52, 0xF0, 0x12, 0x95, 0x41,
-0x22, 0x90, 0x98, 0x24, 0xE0, 0x54, 0xFE, 0x22,
-0x90, 0x98, 0x24, 0xE0, 0x30, 0xE0, 0x79, 0x90,
-0x98, 0x28, 0xE0, 0x04, 0xF0, 0x90, 0x98, 0x2B,
-0xE0, 0x64, 0x01, 0x70, 0x32, 0x90, 0x98, 0x24,
-0xF1, 0xBA, 0x30, 0xE0, 0x2A, 0x90, 0x98, 0x2A,
-0xE0, 0x70, 0x24, 0x90, 0x98, 0x27, 0xE0, 0xFE,
-0xA3, 0xE0, 0xC3, 0x9E, 0x40, 0x19, 0xEF, 0x13,
-0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x0A, 0xB1,
-0xD7, 0x12, 0x97, 0xAA, 0x91, 0xF1, 0xF0, 0x80,
-0x06, 0x91, 0x26, 0x91, 0xF1, 0xF0, 0x22, 0x90,
-0x98, 0x28, 0xE0, 0xFF, 0x90, 0x98, 0x25, 0xE0,
-0xD3, 0x9F, 0x50, 0x2C, 0x90, 0x06, 0x92, 0xE0,
-0x20, 0xE2, 0x16, 0x90, 0x98, 0x2A, 0xE0, 0x70,
-0x10, 0x90, 0x8A, 0xAF, 0x12, 0x97, 0x5E, 0xB1,
-0xE0, 0x90, 0x98, 0x23, 0xE0, 0x04, 0xF0, 0x80,
-0x06, 0x90, 0x06, 0x92, 0x74, 0x04, 0xF0, 0xE4,
-0x90, 0x98, 0x28, 0xF0, 0x90, 0x98, 0x2A, 0xF0,
-0x22, 0x90, 0x98, 0x24, 0xE0, 0xFD, 0x30, 0xE0,
-0x4E, 0x90, 0x98, 0x29, 0xE0, 0xFC, 0x60, 0x47,
-0x12, 0xA0, 0xDE, 0x80, 0x05, 0xC3, 0x33, 0xCE,
-0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x04, 0xE0,
-0xE0, 0xFB, 0xEF, 0x5B, 0x60, 0x0B, 0xE4, 0x90,
-0x98, 0x29, 0xF0, 0x90, 0x98, 0x2B, 0x04, 0xF0,
-0x22, 0x90, 0x98, 0x26, 0xE0, 0xD3, 0x9C, 0x50,
-0x16, 0xED, 0x13, 0x13, 0x13, 0x54, 0x1F, 0x30,
-0xE0, 0x07, 0xB1, 0xD7, 0x12, 0x97, 0xAA, 0x80,
-0x02, 0x91, 0x26, 0x91, 0xF1, 0xF0, 0x22, 0x90,
-0x8A, 0xAF, 0x12, 0x97, 0x5E, 0xB1, 0xE0, 0x22,
-0x90, 0x98, 0x1C, 0xE0, 0xFF, 0xE4, 0x22, 0xE4,
-0xFD, 0xFF, 0x12, 0x6E, 0x71, 0xE4, 0xFF, 0x22,
-0x7D, 0x08, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x90,
-0x98, 0x29, 0xE0, 0x04, 0xF0, 0x22, 0x90, 0x88,
-0x31, 0xE0, 0xFF, 0x12, 0x97, 0xB2, 0x30, 0xE0,
-0x1E, 0xEF, 0x54, 0x7F, 0xF1, 0x2F, 0x30, 0xE1,
-0x06, 0xE0, 0x44, 0x02, 0xF0, 0x80, 0x08, 0xE0,
-0x54, 0xFD, 0xF0, 0xF1, 0xC1, 0x04, 0xF0, 0x90,
-0x88, 0x36, 0xE0, 0x60, 0x02, 0xD1, 0x1B, 0x7F,
-0x01, 0xA1, 0x79, 0x90, 0x88, 0x38, 0xE0, 0xFF,
-0x90, 0x8A, 0xB9, 0x12, 0xA6, 0x1A, 0x7D, 0x01,
-0x02, 0x04, 0x7E, 0x90, 0x99, 0x83, 0xE0, 0xB4,
+0x90, 0x01, 0xC4, 0x74, 0x3B, 0xF0, 0x74, 0xDA,
+0xA3, 0xF0, 0x12, 0x75, 0x50, 0xE5, 0x3D, 0x30,
+0xE0, 0x02, 0x91, 0xC9, 0xE5, 0x3D, 0x30, 0xE1,
+0x03, 0x12, 0xB7, 0xC1, 0xE5, 0x3D, 0x30, 0xE2,
+0x02, 0x51, 0xD7, 0xE5, 0x3D, 0x30, 0xE3, 0x03,
+0x12, 0xBE, 0xFB, 0xE5, 0x3E, 0x30, 0xE0, 0x03,
+0x12, 0x94, 0x9E, 0xE5, 0x40, 0x30, 0xE1, 0x0B,
+0x90, 0x8A, 0xE5, 0x12, 0x90, 0x47, 0x7F, 0x04,
+0x12, 0x04, 0x7E, 0xE5, 0x40, 0x30, 0xE4, 0x03,
+0x12, 0xB0, 0x7D, 0xE5, 0x40, 0x30, 0xE5, 0x02,
+0x71, 0x73, 0xE5, 0x40, 0x30, 0xE6, 0x02, 0x51,
+0xEF, 0x74, 0x3B, 0x04, 0x90, 0x01, 0xC4, 0xF0,
+0x74, 0xDA, 0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06,
+0xD0, 0x05, 0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02,
+0xD0, 0x01, 0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82,
+0xD0, 0x83, 0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x90,
+0x88, 0x36, 0xE0, 0x60, 0x11, 0x90, 0x06, 0x92,
+0xE0, 0x30, 0xE1, 0x05, 0x91, 0xD4, 0x02, 0x04,
+0x7A, 0x91, 0xC1, 0x12, 0xB6, 0x3B, 0x22, 0x90,
+0x88, 0x31, 0xE0, 0xFF, 0x12, 0xA8, 0xAA, 0x30,
+0xE0, 0x1F, 0xEF, 0x54, 0x7F, 0x91, 0x50, 0x30,
+0xE1, 0x06, 0xE0, 0x44, 0x02, 0xF0, 0x80, 0x08,
+0xE0, 0x54, 0xFD, 0xF0, 0x91, 0x59, 0x04, 0xF0,
+0x90, 0x88, 0x36, 0xE0, 0x60, 0x03, 0x12, 0xB6,
+0x3B, 0x7F, 0x01, 0x90, 0x98, 0x50, 0xE0, 0xFD,
+0x30, 0xE0, 0x4F, 0x90, 0x98, 0x55, 0xE0, 0xFC,
+0x60, 0x48, 0x12, 0xBC, 0x0B, 0x80, 0x05, 0xC3,
+0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90,
+0x04, 0xE0, 0xE0, 0xFB, 0xEF, 0x5B, 0x60, 0x0B,
+0xE4, 0x90, 0x98, 0x55, 0xF0, 0x90, 0x98, 0x57,
+0x04, 0xF0, 0x22, 0x90, 0x98, 0x52, 0xE0, 0xD3,
+0x9C, 0x50, 0x17, 0xED, 0x13, 0x13, 0x13, 0x54,
+0x1F, 0x30, 0xE0, 0x07, 0x91, 0x47, 0x12, 0x8F,
+0xF3, 0x80, 0x03, 0x12, 0xAD, 0x56, 0x71, 0xC0,
+0xF0, 0x22, 0x90, 0x8A, 0xAF, 0x12, 0x90, 0x47,
+0x91, 0x63, 0x22, 0x90, 0x99, 0xAF, 0xE0, 0xB4,
 0x01, 0x20, 0xE4, 0xF0, 0x90, 0x01, 0x5B, 0xF0,
 0x90, 0x92, 0x20, 0xF0, 0x90, 0x88, 0x95, 0xE0,
 0xC3, 0x13, 0x54, 0x7F, 0x90, 0x92, 0x21, 0xF0,
 0xE4, 0xFB, 0xFD, 0x7F, 0x58, 0x7E, 0x01, 0x12,
-0x66, 0x33, 0x90, 0x88, 0x31, 0x12, 0xF5, 0x9F,
-0x30, 0xE0, 0x19, 0xEF, 0x54, 0xBF, 0xF1, 0x2F,
-0x30, 0xE0, 0x06, 0xE0, 0x44, 0x01, 0xF0, 0x80,
-0x09, 0xE0, 0x54, 0xFE, 0xF0, 0xF1, 0xC1, 0x74,
-0x04, 0xF0, 0xD1, 0x1B, 0xE4, 0xFF, 0xA1, 0x79,
-0xC0, 0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82,
-0xC0, 0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0,
-0x01, 0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4,
-0x74, 0x78, 0xF0, 0x74, 0xBE, 0xA3, 0xF0, 0x12,
-0x75, 0x50, 0xE5, 0x3D, 0x30, 0xE0, 0x03, 0x12,
-0xD1, 0x72, 0xE5, 0x3D, 0x30, 0xE1, 0x02, 0xF1,
-0x38, 0xE5, 0x3D, 0x30, 0xE2, 0x02, 0xF1, 0x13,
-0xE5, 0x3D, 0x30, 0xE3, 0x02, 0x71, 0x9F, 0xE5,
-0x3E, 0x30, 0xE0, 0x03, 0x12, 0xC7, 0xEB, 0xE5,
-0x40, 0x30, 0xE1, 0x0B, 0x90, 0x8A, 0xE5, 0x12,
-0x97, 0x5E, 0x7F, 0x04, 0x12, 0x04, 0x7E, 0xE5,
-0x40, 0x30, 0xE4, 0x03, 0x12, 0xB2, 0xEB, 0xE5,
-0x40, 0x30, 0xE5, 0x02, 0xD1, 0x2B, 0xE5, 0x40,
-0x30, 0xE6, 0x02, 0xB1, 0xEE, 0x74, 0x78, 0x04,
-0x90, 0x01, 0xC4, 0xF0, 0x74, 0xBE, 0xA3, 0xF0,
-0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05, 0xD0, 0x04,
-0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01, 0xD0, 0x00,
-0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xF0,
-0xD0, 0xE0, 0x32, 0x90, 0x88, 0x36, 0xE0, 0x60,
-0x15, 0x90, 0x06, 0x92, 0xE0, 0x30, 0xE1, 0x09,
-0x90, 0x8B, 0x01, 0xF1, 0xD2, 0xF9, 0x02, 0x04,
-0x7A, 0x12, 0xF5, 0xB6, 0xD1, 0x1B, 0x22, 0xF0,
-0x90, 0x04, 0xE0, 0xE0, 0x90, 0x88, 0x32, 0x22,
-0x90, 0x88, 0x36, 0xE0, 0x60, 0x02, 0xF1, 0x41,
-0x22, 0x12, 0x89, 0xEE, 0x30, 0xE0, 0x0B, 0xEF,
-0xC4, 0x13, 0x13, 0x54, 0x03, 0x30, 0xE0, 0x02,
-0xF1, 0xD9, 0x90, 0x88, 0x31, 0xF1, 0xBA, 0x30,
-0xE0, 0x0A, 0xEF, 0x12, 0xF5, 0x2D, 0x54, 0x07,
-0x70, 0x4C, 0x80, 0x48, 0x90, 0x88, 0x3F, 0xE0,
-0x04, 0xF0, 0x90, 0x88, 0x3A, 0xE0, 0x54, 0xEF,
-0xF0, 0x12, 0xF4, 0xB6, 0x9F, 0x40, 0x35, 0x12,
-0xB3, 0x4A, 0x70, 0x32, 0xF1, 0xCB, 0x70, 0x08,
-0x90, 0x8A, 0xF5, 0x12, 0x91, 0xBD, 0x80, 0x27,
-0x90, 0x8A, 0xF5, 0x12, 0x91, 0xBD, 0x90, 0x88,
-0x40, 0xE0, 0x04, 0xF0, 0xE0, 0xD3, 0x94, 0x02,
-0x40, 0x09, 0xF1, 0xAF, 0xE4, 0x90, 0x88, 0x40,
-0xF0, 0x80, 0x03, 0x12, 0xF4, 0x29, 0xE4, 0x90,
-0x88, 0x3F, 0xF0, 0x22, 0xD1, 0x1B, 0x22, 0x90,
-0x88, 0x32, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0x90,
-0x88, 0x32, 0xE0, 0xFF, 0x13, 0x13, 0x54, 0x3F,
+0x66, 0x33, 0x90, 0x88, 0x31, 0x91, 0xB9, 0x30,
+0xE0, 0x1A, 0xEF, 0x54, 0xBF, 0x91, 0x50, 0x30,
+0xE0, 0x06, 0xE0, 0x44, 0x01, 0xF0, 0x80, 0x09,
+0xE0, 0x54, 0xFE, 0xF0, 0x91, 0x59, 0x74, 0x04,
+0xF0, 0x12, 0xB6, 0x3B, 0xE4, 0xFF, 0x61, 0x1B,
+0x90, 0x98, 0x50, 0xE0, 0x54, 0xFE, 0x22, 0x90,
+0x98, 0x50, 0xE0, 0x30, 0xE0, 0x78, 0x90, 0x98,
+0x54, 0xE0, 0x04, 0xF0, 0x90, 0x98, 0x57, 0xE0,
+0x64, 0x01, 0x70, 0x31, 0x90, 0x98, 0x50, 0x12,
+0xB4, 0xA3, 0x30, 0xE0, 0x28, 0x90, 0x98, 0x56,
+0xE0, 0x70, 0x22, 0x90, 0x98, 0x53, 0xE0, 0xFE,
+0xA3, 0xE0, 0xC3, 0x9E, 0x40, 0x17, 0x12, 0xAF,
+0xEB, 0x30, 0xE0, 0x0A, 0x91, 0x47, 0x12, 0x8F,
+0xF3, 0x71, 0xC0, 0xF0, 0x80, 0x07, 0x12, 0xAD,
+0x56, 0x71, 0xC0, 0xF0, 0x22, 0x90, 0x98, 0x54,
+0xE0, 0xFF, 0x90, 0x98, 0x51, 0xE0, 0xD3, 0x9F,
+0x50, 0x2C, 0x90, 0x06, 0x92, 0xE0, 0x20, 0xE2,
+0x16, 0x90, 0x98, 0x56, 0xE0, 0x70, 0x10, 0x90,
+0x8A, 0xAF, 0x12, 0x90, 0x47, 0x91, 0x63, 0x90,
+0x98, 0x4F, 0xE0, 0x04, 0xF0, 0x80, 0x06, 0x90,
+0x06, 0x92, 0x74, 0x04, 0xF0, 0xE4, 0x90, 0x98,
+0x54, 0xF0, 0x90, 0x98, 0x56, 0xF0, 0x22, 0xE4,
+0xFD, 0xFF, 0x12, 0x6E, 0x71, 0xE4, 0xFF, 0x22,
+0xF0, 0x90, 0x04, 0xE0, 0xE0, 0x90, 0x88, 0x32,
 0x22, 0x90, 0x01, 0xB9, 0x74, 0x01, 0xF0, 0x90,
-0x01, 0xB8, 0x22, 0x90, 0x88, 0x34, 0xE0, 0x54,
-0x0F, 0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xAA, 0x06,
-0x22, 0x7D, 0x02, 0x7F, 0x02, 0x02, 0x7C, 0x7E,
-0x7F, 0x64, 0x7E, 0x00, 0x02, 0x7C, 0x6A, 0xE4,
-0x90, 0x86, 0xAF, 0x12, 0xA8, 0x0D, 0x90, 0x93,
-0x01, 0xF0, 0x90, 0x98, 0x3E, 0xF0, 0xA3, 0xF0,
-0x22, 0xE4, 0xF5, 0x21, 0x90, 0x86, 0xB3, 0xE0,
-0xFF, 0xB4, 0x03, 0x05, 0x75, 0x22, 0x08, 0x80,
-0x03, 0xE4, 0xF5, 0x22, 0xEF, 0xB4, 0x01, 0x0A,
-0x90, 0x00, 0x75, 0xE0, 0x54, 0xFB, 0xF0, 0x75,
-0x22, 0x04, 0x75, 0x23, 0x10, 0x75, 0x24, 0x80,
-0x90, 0x00, 0x50, 0xE5, 0x21, 0xF0, 0xA3, 0xE5,
-0x22, 0xF0, 0xA3, 0xE5, 0x23, 0xF0, 0xA3, 0xE5,
-0x24, 0xF0, 0x22, 0x11, 0x41, 0x12, 0x76, 0x6D,
-0x12, 0x75, 0xE0, 0x11, 0x82, 0x11, 0x63, 0x80,
-0xB8, 0x90, 0x00, 0x08, 0xE0, 0x54, 0xEF, 0xF0,
-0x22, 0x12, 0x7B, 0x1B, 0x90, 0x86, 0xB3, 0xEF,
-0xF0, 0x11, 0x33, 0x90, 0x01, 0x64, 0x74, 0x01,
-0xF0, 0x90, 0x04, 0x23, 0xE0, 0x44, 0x80, 0xF0,
-0x02, 0x67, 0xD2, 0x75, 0x39, 0x0F, 0x75, 0x3A,
-0x01, 0x75, 0x3B, 0x03, 0x75, 0x3C, 0x62, 0x90,
-0x01, 0x38, 0xE5, 0x39, 0xF0, 0xA3, 0xE5, 0x3A,
-0xF0, 0xA3, 0xE5, 0x3B, 0xF0, 0xA3, 0xE5, 0x3C,
-0xF0, 0x22, 0x75, 0x29, 0x10, 0xE4, 0xF5, 0x2A,
-0x75, 0x2B, 0x07, 0x75, 0x2C, 0x02, 0xF5, 0x31,
-0xF5, 0x32, 0xF5, 0x33, 0xF5, 0x34, 0x90, 0x01,
-0x30, 0xE5, 0x29, 0xF0, 0xA3, 0xE5, 0x2A, 0xF0,
-0xA3, 0xE5, 0x2B, 0xF0, 0xA3, 0xE5, 0x2C, 0xF0,
-0x90, 0x01, 0x20, 0xE5, 0x31, 0xF0, 0xA3, 0xE5,
-0x32, 0xF0, 0xA3, 0xE5, 0x33, 0xF0, 0xA3, 0xE5,
-0x34, 0xF0, 0x22, 0x90, 0x00, 0x80, 0xE0, 0x44,
-0x80, 0xF0, 0x71, 0x8E, 0x12, 0xA7, 0xE5, 0x12,
-0x7B, 0x79, 0x71, 0x2D, 0x12, 0xBF, 0xE7, 0x7F,
-0x01, 0x12, 0x85, 0x15, 0x90, 0x98, 0x1F, 0x74,
-0x02, 0xF0, 0xFF, 0x12, 0x85, 0x15, 0x90, 0x98,
-0x1F, 0xE0, 0x04, 0xF0, 0x11, 0x49, 0x12, 0xAE,
-0x8F, 0x90, 0x00, 0x80, 0xE0, 0x44, 0x40, 0xF0,
-0x75, 0x20, 0xFF, 0x12, 0x7C, 0x97, 0x90, 0x01,
-0xA0, 0xE0, 0xB4, 0xFD, 0x05, 0xE4, 0xFF, 0x12,
-0x99, 0x5D, 0x31, 0x3E, 0x71, 0x14, 0x90, 0x00,
-0x81, 0xE0, 0x44, 0x04, 0xF0, 0x31, 0x8F, 0x12,
-0x98, 0xCA, 0x90, 0x00, 0xAA, 0xE0, 0x44, 0x02,
-0xF0, 0xA3, 0xE0, 0x44, 0x80, 0xF0, 0x90, 0x99,
-0x84, 0xE0, 0x54, 0xFE, 0xF0, 0x90, 0x06, 0x0A,
-0xE0, 0x44, 0x10, 0xF0, 0x90, 0x07, 0xDB, 0xE0,
-0x44, 0x80, 0xF0, 0x90, 0x06, 0x0D, 0x74, 0xFF,
-0xF0, 0xE4, 0xFF, 0x02, 0x85, 0x9E, 0x31, 0x87,
-0x31, 0x99, 0xEF, 0x64, 0x01, 0x60, 0x39, 0xC3,
-0x90, 0x99, 0x86, 0xE0, 0x94, 0x88, 0x90, 0x99,
-0x85, 0xE0, 0x94, 0x13, 0x40, 0x0F, 0x90, 0x01,
-0xC1, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x01, 0xC7,
-0x74, 0xFD, 0xF0, 0x80, 0x1B, 0x90, 0x99, 0x85,
-0x31, 0xA5, 0xD3, 0x90, 0x99, 0x86, 0xE0, 0x94,
-0x32, 0x90, 0x99, 0x85, 0xE0, 0x94, 0x00, 0x40,
-0xC7, 0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE3, 0xC0,
-0x90, 0x01, 0xC7, 0x74, 0xFE, 0xF0, 0x22, 0xE4,
-0x90, 0x99, 0x85, 0xF0, 0xA3, 0xF0, 0x22, 0x90,
-0x01, 0xE4, 0x74, 0x27, 0xF0, 0xA3, 0xE4, 0xF0,
-0x22, 0x90, 0x01, 0x95, 0xE0, 0x7F, 0x00, 0x30,
-0xE4, 0x02, 0x7F, 0x01, 0x22, 0xE4, 0x75, 0xF0,
-0x01, 0x12, 0x02, 0xE7, 0x7F, 0x14, 0x7E, 0x00,
-0x02, 0x7C, 0x6A, 0x75, 0x0D, 0x14, 0x90, 0x88,
-0x32, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x88, 0x41,
+0x01, 0xB8, 0x22, 0x7D, 0x08, 0xE4, 0xFF, 0x12,
+0x04, 0x7E, 0x90, 0x98, 0x55, 0xE0, 0x04, 0xF0,
+0x22, 0x90, 0x99, 0xB1, 0x12, 0x82, 0x27, 0x91,
+0xDF, 0x12, 0x8F, 0x6A, 0xFF, 0x54, 0x01, 0xFE,
+0x71, 0xC0, 0x4E, 0xF0, 0xEF, 0xC3, 0x13, 0x30,
+0xE0, 0x2E, 0x12, 0x9C, 0x5A, 0x90, 0x98, 0x51,
+0x12, 0x87, 0xE6, 0x90, 0x98, 0x52, 0xF0, 0x12,
+0x02, 0x06, 0xFF, 0x54, 0x04, 0xFE, 0x90, 0x98,
+0x50, 0xE0, 0x54, 0xFB, 0x4E, 0x12, 0x87, 0xA3,
+0x90, 0x98, 0x53, 0xF0, 0xEF, 0x54, 0x08, 0xFF,
+0x90, 0x98, 0x50, 0xE0, 0x54, 0xF7, 0x4F, 0xF0,
+0x22, 0xE0, 0xFF, 0xC4, 0x13, 0x13, 0x54, 0x03,
+0x22, 0x90, 0x88, 0x31, 0xE0, 0x54, 0xF7, 0xF0,
+0x22, 0x90, 0x8A, 0xE5, 0x12, 0x90, 0x47, 0x7F,
+0x80, 0x02, 0x04, 0x7E, 0x90, 0x8B, 0x01, 0xE0,
+0xFE, 0xA3, 0xE0, 0xAA, 0x06, 0xF9, 0x22, 0x12,
+0x9F, 0x90, 0x7B, 0x01, 0x7A, 0x98, 0x79, 0x50,
+0x12, 0x04, 0x80, 0x90, 0x98, 0x51, 0x74, 0x08,
+0xF0, 0xA3, 0x74, 0x03, 0xF0, 0x22, 0xE4, 0xFF,
+0x12, 0x78, 0x4A, 0xBF, 0x01, 0x18, 0x90, 0x88,
+0x36, 0xE0, 0x60, 0x12, 0x12, 0x97, 0xF3, 0x64,
+0x02, 0x60, 0x08, 0x90, 0x8A, 0xE1, 0x91, 0xD7,
+0x02, 0x04, 0x7A, 0x12, 0x73, 0x8F, 0x22, 0x32,
+0xC0, 0xE0, 0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0,
+0x75, 0xD0, 0x00, 0xC0, 0x05, 0xC0, 0x07, 0x7D,
+0x18, 0x90, 0x01, 0xC4, 0xED, 0xF0, 0x74, 0xDD,
+0xFF, 0xA3, 0xF0, 0xED, 0x04, 0x90, 0x01, 0xC4,
+0xF0, 0xA3, 0xEF, 0xF0, 0xD0, 0x07, 0xD0, 0x05,
+0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xE0,
+0x32, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x9C, 0xB0, 0xED, 0xF0, 0xA3, 0xEB, 0xF0,
+0x90, 0x9C, 0xAF, 0xEF, 0xF0, 0xE4, 0xFD, 0xFC,
+0xD1, 0x47, 0x90, 0x9C, 0xB2, 0xF0, 0x12, 0xD7,
+0x39, 0x90, 0x9C, 0xAF, 0xE0, 0x90, 0x04, 0x25,
+0xF0, 0x90, 0x9C, 0xB0, 0xE0, 0x60, 0x06, 0xB1,
+0xF2, 0xE0, 0x44, 0x80, 0xF0, 0xAF, 0x05, 0x74,
+0x20, 0x2F, 0x12, 0xCF, 0xBA, 0x54, 0xC0, 0xF0,
+0xB1, 0xF2, 0xE0, 0x54, 0xC0, 0xF0, 0x90, 0x9C,
+0xB2, 0xE0, 0xFF, 0xAE, 0x05, 0x74, 0x18, 0x2E,
+0x12, 0xCF, 0x87, 0xEF, 0xF0, 0x90, 0x00, 0x8B,
+0xE0, 0xD3, 0x94, 0x03, 0x74, 0x10, 0x2E, 0x12,
+0xCF, 0x8F, 0x74, 0x04, 0xF0, 0xAF, 0x05, 0xD1,
+0x33, 0xE0, 0x54, 0x01, 0xFE, 0x90, 0x9C, 0xB1,
+0xE0, 0x25, 0xE0, 0x25, 0xE0, 0xFB, 0xEE, 0x44,
+0x02, 0x4B, 0xD1, 0x32, 0xEE, 0xF0, 0x74, 0x11,
+0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0x74, 0xFF, 0xF0, 0x74, 0x29, 0x2F, 0xD1, 0x3E,
+0x54, 0xF7, 0xF0, 0x74, 0x0D, 0x2D, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x44, 0x80,
+0xF0, 0xAE, 0x04, 0xAF, 0x05, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0x74, 0x21, 0x2F, 0xF5, 0x82, 0xE4,
+0x34, 0xFC, 0xF5, 0x83, 0x22, 0x90, 0x9C, 0xA8,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x90, 0x8A, 0x9B,
+0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xF5, 0x82, 0x8C,
+0x83, 0x12, 0x04, 0x7E, 0x90, 0x9C, 0xA8, 0xA3,
+0xE0, 0xFF, 0x24, 0x12, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0xE0, 0x54, 0x01, 0xFE, 0x90,
+0x9C, 0xA7, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0x44,
+0x02, 0x4E, 0xFE, 0x74, 0x12, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0xF5, 0x82,
+0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22, 0x90,
+0x86, 0xAD, 0xA3, 0xE0, 0x24, 0x7F, 0xF5, 0x82,
+0xE4, 0x34, 0x84, 0xF5, 0x83, 0xE0, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD1, 0x47,
+0x90, 0x9C, 0xE2, 0xF0, 0xED, 0x90, 0x00, 0x73,
+0x70, 0x0D, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x00,
+0x67, 0xE0, 0x44, 0x80, 0xF0, 0x80, 0x0B, 0xE0,
+0x54, 0xFB, 0xF0, 0x90, 0x00, 0x67, 0xE0, 0x54,
+0x7F, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD1, 0xD0,
+0x90, 0x9C, 0xB3, 0x12, 0x04, 0x31, 0x90, 0x9C,
+0xB3, 0x12, 0xD1, 0x96, 0x7F, 0x30, 0x7E, 0x08,
+0x12, 0x70, 0xAD, 0x90, 0x01, 0x01, 0xE0, 0x44,
+0x02, 0xD1, 0xC8, 0x90, 0x06, 0xB7, 0x74, 0x09,
+0xF0, 0x90, 0x06, 0xB4, 0x74, 0x86, 0xF0, 0xD1,
+0xDD, 0xF0, 0xE4, 0xFD, 0x12, 0x76, 0xF7, 0x12,
+0xB7, 0x82, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0xF0, 0x90, 0x01, 0x00, 0x74, 0xFF, 0xF0, 0x22,
+0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70, 0x70, 0xED,
+0x44, 0x80, 0xFD, 0xEC, 0x22, 0x90, 0x93, 0x46,
+0xE0, 0xFF, 0x90, 0x93, 0x45, 0xE0, 0xFB, 0x90,
+0x93, 0x47, 0xE0, 0x90, 0x92, 0x90, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD1, 0xD0,
+0x90, 0x9C, 0xB7, 0x12, 0x04, 0x31, 0x90, 0x9C,
+0xB7, 0x12, 0xD1, 0x96, 0x7F, 0x30, 0x7E, 0x08,
+0x12, 0x70, 0xAD, 0xD1, 0xDD, 0xF0, 0x7D, 0x01,
+0x12, 0x76, 0xF7, 0x12, 0x88, 0xC5, 0x90, 0x06,
+0xB7, 0x74, 0x11, 0xF0, 0x7F, 0x03, 0x7E, 0x00,
+0x12, 0x7C, 0x6A, 0x90, 0x06, 0xB4, 0xE0, 0x54,
+0x0F, 0x70, 0xF1, 0x90, 0x07, 0xD5, 0xE0, 0x44,
+0x80, 0xF0, 0x7F, 0x0A, 0x80, 0x09, 0x90, 0x06,
+0x62, 0xE0, 0x30, 0xE0, 0x09, 0x7F, 0x01, 0x7E,
+0x00, 0x12, 0x7C, 0x6A, 0x80, 0xF0, 0x12, 0xB7,
+0xA8, 0x90, 0x01, 0x00, 0x74, 0x3F, 0xF0, 0xA3,
+0xE0, 0x54, 0xFD, 0xF0, 0x90, 0x05, 0x53, 0xE0,
+0x44, 0x20, 0xF0, 0x90, 0x07, 0xD5, 0xE0, 0x54,
+0x7F, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xE4,
+0x90, 0x9C, 0xC7, 0xF0, 0xA3, 0xF0, 0x90, 0x05,
+0x22, 0xE0, 0x90, 0x9C, 0xC9, 0xF0, 0x7B, 0x47,
+0x7D, 0xFF, 0xE4, 0xFF, 0x12, 0x8D, 0x1E, 0x90,
+0x05, 0xF8, 0xE0, 0x70, 0x1B, 0xA3, 0xE0, 0x70,
+0x17, 0xA3, 0xE0, 0x70, 0x13, 0xA3, 0xE0, 0x70,
+0x0F, 0x90, 0x9C, 0xC9, 0xE0, 0xFD, 0x7B, 0x48,
+0xE4, 0xFF, 0x12, 0x8D, 0x1E, 0x7F, 0x01, 0x22,
+0xD3, 0x90, 0x9C, 0xC8, 0xE0, 0x94, 0xE8, 0x90,
+0x9C, 0xC7, 0xE0, 0x94, 0x03, 0x40, 0x16, 0x90,
+0x01, 0xC0, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x9C,
+0xC9, 0xE0, 0xFD, 0x7B, 0x5B, 0xE4, 0xFF, 0x12,
+0x8D, 0x1E, 0x7F, 0x00, 0x22, 0x7F, 0x32, 0x7E,
+0x00, 0x12, 0x7C, 0x6A, 0x90, 0x9C, 0xC7, 0x12,
+0xBF, 0xA5, 0x80, 0xAB, 0x75, 0x0D, 0x14, 0x90,
+0x88, 0x32, 0xE0, 0x44, 0x10, 0xF0, 0x90, 0x00,
+0x06, 0xE0, 0x44, 0x40, 0xF0, 0x90, 0x88, 0x41,
 0xE0, 0x90, 0x00, 0x93, 0xF0, 0x90, 0x88, 0x37,
 0xE0, 0x60, 0x12, 0x90, 0x01, 0x2F, 0xE0, 0x30,
 0xE7, 0x05, 0x74, 0x10, 0xF0, 0x80, 0x06, 0x90,
 0x01, 0x2F, 0x74, 0x90, 0xF0, 0x90, 0x93, 0x0C,
-0xE0, 0x30, 0xE0, 0x60, 0x90, 0xFD, 0x09, 0xE4,
+0xE0, 0x30, 0xE0, 0x61, 0x90, 0xFD, 0x09, 0xE4,
 0xF0, 0x90, 0xFD, 0x08, 0xF0, 0x90, 0x0E, 0x4B,
-0xE0, 0x54, 0xFC, 0xF0, 0xE4, 0x90, 0x99, 0xE0,
-0xF0, 0x90, 0x99, 0xE0, 0xE0, 0xFF, 0xC3, 0x94,
-0x05, 0x50, 0x2D, 0x12, 0xA0, 0xDE, 0x80, 0x05,
+0xE0, 0x54, 0xFC, 0xF0, 0xE4, 0x90, 0x9A, 0x0C,
+0xF0, 0x90, 0x9A, 0x0C, 0xE0, 0xFF, 0xC3, 0x94,
+0x05, 0x50, 0x2E, 0x12, 0xBC, 0x0B, 0x80, 0x05,
 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF,
 0x90, 0x93, 0x0E, 0xE0, 0xFD, 0xEF, 0x5D, 0x60,
-0x0F, 0x90, 0x99, 0xE0, 0x71, 0x4D, 0x90, 0x99,
-0xE0, 0x71, 0x6D, 0x44, 0x20, 0xF0, 0x31, 0xAC,
-0x90, 0x99, 0xE0, 0xE0, 0x04, 0xF0, 0x80, 0xC9,
-0x90, 0x00, 0x92, 0xE0, 0x54, 0xFE, 0xF0, 0xE0,
-0x44, 0x08, 0xF0, 0x90, 0x00, 0x02, 0xE0, 0x54,
-0xFD, 0xF0, 0x80, 0x07, 0x90, 0x00, 0x92, 0xE0,
-0x44, 0x01, 0xF0, 0x90, 0x00, 0x08, 0xE0, 0x44,
-0x10, 0xF0, 0x7F, 0x01, 0x51, 0xC8, 0x90, 0x00,
-0x90, 0xE0, 0x44, 0x01, 0xF0, 0x00, 0x00, 0x00,
+0x10, 0x90, 0x9A, 0x0C, 0x11, 0xF1, 0x90, 0x9A,
+0x0C, 0x31, 0x11, 0x44, 0x20, 0xF0, 0x12, 0xBF,
+0xDF, 0x90, 0x9A, 0x0C, 0xE0, 0x04, 0xF0, 0x80,
+0xC8, 0x90, 0x00, 0x92, 0xE0, 0x54, 0xFE, 0xF0,
+0xE0, 0x44, 0x08, 0xF0, 0x90, 0x00, 0x02, 0xE0,
+0x54, 0xFD, 0xF0, 0x80, 0x07, 0x90, 0x00, 0x92,
+0xE0, 0x44, 0x01, 0xF0, 0x90, 0x00, 0x08, 0xE0,
+0x44, 0x10, 0xF0, 0x7F, 0x01, 0x31, 0x32, 0x90,
+0x00, 0x90, 0xE0, 0x44, 0x01, 0xF0, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
@@ -8646,1641 +9780,866 @@ u8 array_mp_8723d_fw_wowlan[] = {
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-0x00, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C, 0x6A,
-0x90, 0x9C, 0x87, 0xEF, 0x12, 0xA7, 0xDE, 0x90,
-0x01, 0x09, 0xE0, 0x7F, 0x00, 0x30, 0xE7, 0x02,
-0x7F, 0x01, 0x90, 0x9C, 0x87, 0xE0, 0x6F, 0x60,
-0x32, 0xC3, 0x90, 0x9C, 0x89, 0xE0, 0x94, 0x88,
-0x90, 0x9C, 0x88, 0xE0, 0x94, 0x13, 0x40, 0x08,
-0x90, 0x01, 0xC0, 0xE0, 0x44, 0x10, 0xF0, 0x22,
-0x90, 0x9C, 0x88, 0x31, 0xA5, 0xD3, 0x90, 0x9C,
-0x89, 0xE0, 0x94, 0x32, 0x90, 0x9C, 0x88, 0xE0,
-0x94, 0x00, 0x40, 0xC3, 0x90, 0x01, 0xC6, 0xE0,
-0x30, 0xE0, 0xBC, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0xE4, 0xFF, 0xEF, 0x12, 0xAE,
-0x79, 0xE4, 0xF0, 0x0F, 0xEF, 0xB4, 0x08, 0xF5,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x01, 0x8C,
-0xE4, 0xF0, 0xA3, 0xF0, 0xA3, 0x74, 0x71, 0xF0,
-0xA3, 0x74, 0x02, 0xF0, 0x90, 0x01, 0x95, 0xE0,
-0x54, 0xF0, 0x44, 0x07, 0xF0, 0x90, 0x01, 0x01,
-0xE0, 0x44, 0x04, 0xF0, 0x22, 0xE0, 0xFF, 0x24,
-0x1A, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
-0xE0, 0x90, 0x01, 0xB0, 0xF0, 0x74, 0x1F, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0,
-0x90, 0x01, 0xB1, 0xF0, 0x22, 0xE0, 0xFF, 0x24,
-0x10, 0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83,
-0xE0, 0x90, 0x01, 0xB2, 0xF0, 0x74, 0x15, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0x93, 0xF5, 0x83, 0xE0,
-0x90, 0x01, 0xB3, 0xF0, 0xE0, 0x22, 0x90, 0x8A,
-0x79, 0x74, 0x87, 0xF0, 0xA3, 0x74, 0x4A, 0xF0,
-0x90, 0x8A, 0xE5, 0x74, 0xC5, 0xF0, 0xA3, 0x74,
-0x8D, 0xF0, 0x90, 0x8B, 0x03, 0x74, 0x90, 0xF0,
-0xA3, 0x74, 0xCA, 0xF0, 0x90, 0x8A, 0xB9, 0x74,
-0x91, 0xF0, 0xA3, 0x74, 0xC7, 0xF0, 0x90, 0x8A,
-0x75, 0x74, 0xB7, 0xF0, 0xA3, 0x74, 0xF9, 0xF0,
-0x90, 0x8A, 0xC3, 0x74, 0xD8, 0xF0, 0xA3, 0x74,
-0x51, 0xF0, 0x90, 0x8A, 0xF3, 0x74, 0xD9, 0xF0,
-0xA3, 0x74, 0x7F, 0xF0, 0x90, 0x8A, 0x85, 0x74,
-0xD9, 0xF0, 0xA3, 0x74, 0x8B, 0xF0, 0x90, 0x86,
-0x0C, 0x74, 0xC7, 0xF0, 0xA3, 0x74, 0x97, 0xF0,
-0x90, 0x8A, 0xEF, 0x74, 0xCF, 0xF0, 0xA3, 0x74,
-0xE8, 0xF0, 0x90, 0x86, 0x00, 0x74, 0xF2, 0xF0,
-0xA3, 0x74, 0xE0, 0xF0, 0x90, 0x86, 0x02, 0x74,
-0xF3, 0xF0, 0xA3, 0x74, 0x2C, 0xF0, 0x90, 0x8A,
-0xFD, 0x74, 0xD0, 0xF0, 0xA3, 0x74, 0x87, 0xF0,
-0x90, 0x8A, 0xF9, 0x74, 0xB0, 0xF0, 0xA3, 0x74,
-0x32, 0xF0, 0x90, 0x8A, 0xAF, 0x74, 0xCC, 0xF0,
-0xA3, 0x74, 0x72, 0xF0, 0x90, 0x8A, 0xD3, 0x74,
-0xD8, 0xF0, 0xA3, 0x74, 0x91, 0xF0, 0x90, 0x8A,
-0xF5, 0x74, 0xF4, 0xF0, 0xA3, 0x74, 0x6F, 0xF0,
-0x90, 0x8A, 0xA3, 0x74, 0xCA, 0xF0, 0xA3, 0x74,
-0x81, 0xF0, 0x90, 0x86, 0x06, 0x74, 0xCB, 0xF0,
-0xA3, 0x74, 0x6F, 0xF0, 0x22, 0x7D, 0x02, 0x90,
-0x01, 0xC4, 0x74, 0x4D, 0xF0, 0x74, 0xC4, 0xA3,
-0xF0, 0x90, 0x98, 0x1F, 0xE0, 0xFF, 0xED, 0xC3,
-0x9F, 0x50, 0x18, 0xED, 0x25, 0xE0, 0x24, 0x81,
-0xF8, 0xE6, 0x30, 0xE4, 0x0B, 0x90, 0x01, 0xB8,
-0x74, 0x08, 0xF0, 0xA3, 0xF0, 0x7F, 0x00, 0x22,
-0x0D, 0x80, 0xDE, 0x74, 0x4D, 0x04, 0x90, 0x01,
-0xC4, 0xF0, 0x74, 0xC4, 0xA3, 0xF0, 0x7F, 0x01,
-0x22, 0xE4, 0xFB, 0xFA, 0xFD, 0x7F, 0x01, 0x12,
-0x86, 0x4E, 0x90, 0x9A, 0x07, 0xEF, 0xF0, 0x60,
-0xF0, 0x90, 0x86, 0xAF, 0xE0, 0xFF, 0x70, 0x04,
-0xA3, 0xE0, 0x60, 0xE5, 0xC2, 0xAF, 0xEF, 0x30,
-0xE1, 0x0D, 0x90, 0x86, 0xAF, 0xE0, 0x54, 0xFD,
-0xF0, 0x90, 0x86, 0x08, 0x12, 0x91, 0xBD, 0x91,
-0xF7, 0x30, 0xE2, 0x09, 0x54, 0xFB, 0xF0, 0x90,
-0x86, 0x0A, 0x12, 0x91, 0xBD, 0x91, 0xF7, 0xFF,
-0x30, 0xE4, 0x0B, 0x54, 0xEF, 0xF0, 0xB1, 0x54,
-0xBF, 0x01, 0x03, 0x12, 0xA2, 0x84, 0x91, 0xF7,
-0xFF, 0x30, 0xE7, 0x06, 0x54, 0x7F, 0xF0, 0x12,
-0xAD, 0xDC, 0xD2, 0xAF, 0xC2, 0xAF, 0x90, 0x86,
-0xB0, 0xE0, 0xFF, 0x30, 0xE2, 0x05, 0x54, 0xFB,
-0xF0, 0xB1, 0x00, 0xD2, 0xAF, 0x80, 0xA2, 0xD2,
-0xAF, 0xC2, 0xAF, 0x90, 0x86, 0xAF, 0xE0, 0x22,
-0x90, 0x93, 0x2D, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
-0x41, 0xB1, 0x4B, 0x90, 0x98, 0x1E, 0xF0, 0x60,
-0x0E, 0x12, 0xBC, 0x09, 0xE4, 0x90, 0x92, 0x20,
-0xF0, 0xA3, 0x04, 0xF0, 0xE4, 0x80, 0x22, 0x90,
-0x93, 0x2D, 0x12, 0xB2, 0xDA, 0x30, 0xE0, 0x0B,
-0xA3, 0xE0, 0x90, 0x92, 0x20, 0xF0, 0xE4, 0xA3,
-0xF0, 0x80, 0x0E, 0xE4, 0x90, 0x92, 0x20, 0xF0,
-0x90, 0x93, 0x2E, 0xE0, 0x90, 0x92, 0x21, 0xF0,
-0xE4, 0xFB, 0xFD, 0x7F, 0x5C, 0x7E, 0x01, 0x12,
-0x66, 0x33, 0x22, 0x7F, 0x60, 0x12, 0x7B, 0x41,
-0xEF, 0x54, 0x01, 0x22, 0xE4, 0x90, 0x9C, 0x95,
-0xF0, 0xA3, 0xF0, 0x90, 0x02, 0x86, 0xE0, 0x20,
-0xE1, 0x28, 0xC3, 0x90, 0x9C, 0x96, 0xE0, 0x94,
-0xD0, 0x90, 0x9C, 0x95, 0xE0, 0x94, 0x07, 0x40,
-0x0A, 0x90, 0x01, 0xC1, 0xE0, 0x44, 0x04, 0xF0,
-0x7F, 0x00, 0x22, 0x90, 0x9C, 0x95, 0xE4, 0x75,
-0xF0, 0x01, 0x12, 0x02, 0xE7, 0x12, 0xBB, 0x98,
-0x80, 0xD1, 0x7F, 0x01, 0x22, 0x8F, 0x12, 0x7F,
-0x02, 0x12, 0x86, 0x27, 0x90, 0x86, 0xAF, 0xE0,
-0x45, 0x12, 0xF0, 0x22, 0x8F, 0x0E, 0x7F, 0x02,
-0x12, 0x86, 0x27, 0x90, 0x86, 0xB0, 0xE0, 0x45,
-0x0E, 0xF0, 0x22, 0x7F, 0x04, 0x80, 0xED, 0xC0,
-0xE0, 0xC0, 0xF0, 0xC0, 0x83, 0xC0, 0x82, 0xC0,
-0xD0, 0x75, 0xD0, 0x00, 0xC0, 0x00, 0xC0, 0x01,
-0xC0, 0x02, 0xC0, 0x03, 0xC0, 0x04, 0xC0, 0x05,
-0xC0, 0x06, 0xC0, 0x07, 0x90, 0x01, 0xC4, 0x74,
-0xAF, 0xF0, 0x74, 0xC5, 0xA3, 0xF0, 0x12, 0x6C,
-0xD6, 0xE5, 0x27, 0x30, 0xE4, 0x02, 0xB1, 0xAB,
-0x90, 0x86, 0xB3, 0xE0, 0xFC, 0x64, 0x03, 0x70,
-0x37, 0x90, 0x99, 0x84, 0xE0, 0xFE, 0x20, 0xE0,
-0x2F, 0xE5, 0x26, 0x30, 0xE3, 0x2A, 0x90, 0x00,
-0xCC, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x00, 0xD4,
-0xE0, 0x44, 0x10, 0xF0, 0x90, 0x00, 0xC6, 0xE0,
-0x44, 0x02, 0xF0, 0x90, 0x00, 0x01, 0xE0, 0x54,
-0xCF, 0xF0, 0x90, 0x00, 0x23, 0xE0, 0x54, 0x7F,
-0xF0, 0xEE, 0x44, 0x01, 0x90, 0x99, 0x84, 0xF0,
-0xEC, 0xB4, 0x01, 0x0B, 0xE5, 0x26, 0x30, 0xE2,
-0x06, 0x90, 0x88, 0x41, 0x74, 0xDD, 0xF0, 0x74,
-0xAF, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0x74, 0xC5,
-0xA3, 0xF0, 0xD0, 0x07, 0xD0, 0x06, 0xD0, 0x05,
-0xD0, 0x04, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0xD0, 0xD0, 0xD0, 0x82, 0xD0, 0x83,
-0xD0, 0xF0, 0xD0, 0xE0, 0x32, 0x32, 0xC0, 0xE0,
-0xC0, 0x83, 0xC0, 0x82, 0xC0, 0xD0, 0x75, 0xD0,
-0x00, 0xC0, 0x05, 0xC0, 0x07, 0x7D, 0x56, 0x90,
-0x01, 0xC4, 0xED, 0xF0, 0x74, 0xC6, 0xFF, 0xA3,
-0xF0, 0xED, 0x04, 0x90, 0x01, 0xC4, 0xF0, 0xA3,
-0xEF, 0xF0, 0xD0, 0x07, 0xD0, 0x05, 0xD0, 0xD0,
-0xD0, 0x82, 0xD0, 0x83, 0xD0, 0xE0, 0x32, 0x90,
-0x98, 0x2A, 0xE0, 0x04, 0xF0, 0x90, 0x88, 0x39,
-0xE0, 0x64, 0x02, 0x60, 0x03, 0x12, 0x88, 0x9E,
-0x22, 0xE4, 0xFF, 0x12, 0x78, 0x4A, 0xBF, 0x01,
-0x1A, 0x90, 0x88, 0x36, 0xE0, 0x60, 0x14, 0x12,
-0xBF, 0xCB, 0x64, 0x02, 0x60, 0x0A, 0x90, 0x8A,
-0xE1, 0x12, 0xBF, 0xD2, 0xF9, 0x02, 0x04, 0x7A,
-0x12, 0x73, 0x8F, 0x22, 0xE4, 0xFF, 0x12, 0x78,
-0x4A, 0xBF, 0x01, 0x10, 0x90, 0x88, 0x36, 0xE0,
-0x60, 0x0A, 0xD1, 0xD5, 0xF0, 0x54, 0x07, 0x70,
-0x03, 0x12, 0xBE, 0x1B, 0x22, 0x90, 0x88, 0x3A,
-0xE0, 0x54, 0xFE, 0x22, 0xE4, 0xF5, 0x0F, 0x90,
-0x06, 0xA9, 0xE0, 0xF5, 0x0F, 0x54, 0xC0, 0x70,
-0x13, 0xD1, 0xD5, 0xF0, 0x54, 0xFD, 0xF0, 0x12,
-0xBE, 0x1B, 0x90, 0x88, 0x39, 0xE0, 0x60, 0x4C,
-0xF1, 0x45, 0xF0, 0x22, 0xE5, 0x0F, 0x30, 0xE6,
-0x23, 0x90, 0x88, 0x36, 0xE0, 0x64, 0x01, 0x70,
-0x1E, 0x90, 0x88, 0x3A, 0xE0, 0x44, 0x01, 0xF0,
-0x12, 0xBF, 0xCB, 0x64, 0x02, 0x60, 0x08, 0x90,
-0x8A, 0xE1, 0x12, 0x91, 0xBD, 0x80, 0x08, 0x12,
-0xF4, 0x29, 0x80, 0x03, 0xD1, 0xD5, 0xF0, 0xE5,
-0x0F, 0x90, 0x88, 0x3A, 0x30, 0xE7, 0x11, 0xE0,
-0x44, 0x02, 0x12, 0xB3, 0x6C, 0x12, 0x66, 0x33,
-0x90, 0x88, 0x31, 0xE0, 0x44, 0x04, 0xF0, 0x22,
-0xE0, 0x54, 0xFD, 0xF0, 0x22, 0x90, 0x00, 0x02,
-0xE0, 0x44, 0x01, 0x22, 0x90, 0x88, 0x39, 0xE0,
-0xB4, 0x04, 0x03, 0xF1, 0x45, 0xF0, 0x90, 0x88,
-0x36, 0xE0, 0x64, 0x01, 0x70, 0x2F, 0x12, 0xBF,
-0xCB, 0x60, 0x17, 0x90, 0x8A, 0xB9, 0x12, 0x97,
-0x5E, 0xE4, 0xFD, 0x7F, 0x0C, 0x12, 0x04, 0x7E,
-0x90, 0x8B, 0x01, 0x12, 0xBF, 0xD2, 0xF9, 0x02,
-0x04, 0x7A, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x0D,
-0x90, 0x8A, 0xB9, 0x12, 0x97, 0x5E, 0x7D, 0x01,
-0x7F, 0x04, 0x12, 0x04, 0x7E, 0x22, 0x90, 0x88,
-0x36, 0xE0, 0x60, 0x02, 0xF1, 0x4C, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12, 0xD0,
-0x6A, 0xFD, 0xEC, 0x90, 0x9C, 0x6D, 0x12, 0x04,
-0x31, 0x90, 0x9C, 0x6D, 0xF1, 0xE2, 0x7F, 0x30,
-0x7E, 0x08, 0x12, 0x70, 0xAD, 0x90, 0x01, 0x01,
-0xE0, 0x44, 0x02, 0xF1, 0xDA, 0x90, 0x06, 0xB7,
-0x74, 0x09, 0xF0, 0x90, 0x06, 0xB4, 0x74, 0x86,
-0xF0, 0x12, 0xD0, 0x75, 0xF0, 0xE4, 0xFD, 0x12,
-0x76, 0xF7, 0xF1, 0x45, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xF0, 0x90, 0x01, 0x00, 0x74, 0xFF,
-0xF0, 0x22, 0x12, 0x04, 0xB8, 0x90, 0x92, 0x18,
-0x02, 0x04, 0x31, 0x12, 0xD7, 0xE9, 0x90, 0x9A,
-0xD8, 0xEF, 0xF0, 0x90, 0x8A, 0x89, 0x30, 0xE0,
-0x13, 0x12, 0x97, 0x5E, 0x7D, 0x01, 0xE4, 0xFF,
-0x12, 0x04, 0x7E, 0x90, 0x88, 0x33, 0xE0, 0x44,
-0x04, 0xF0, 0x80, 0x09, 0x12, 0x97, 0x5E, 0xE4,
-0xFD, 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x9A, 0xD8,
-0xE0, 0x30, 0xE6, 0x11, 0x90, 0x01, 0x2F, 0xE0,
-0x30, 0xE7, 0x04, 0xE4, 0xF0, 0x80, 0x06, 0x90,
-0x01, 0x2F, 0x74, 0x80, 0xF0, 0x11, 0x35, 0x74,
-0x02, 0xF0, 0x02, 0x6E, 0x2F, 0x90, 0x88, 0x48,
-0xE0, 0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x88, 0x4F,
-0xE0, 0xFB, 0x90, 0x92, 0x98, 0x22, 0x90, 0x88,
-0x85, 0x12, 0x04, 0xB8, 0xC0, 0x06, 0xC0, 0x07,
-0x90, 0x99, 0x82, 0xE0, 0x24, 0x46, 0xFF, 0x90,
-0x99, 0x81, 0xE0, 0x34, 0x00, 0xAB, 0x07, 0xFA,
-0xE4, 0xF9, 0xF8, 0xD0, 0x07, 0xD0, 0x06, 0x12,
-0x80, 0xCD, 0x90, 0x88, 0x85, 0x51, 0x5F, 0xEF,
-0x24, 0x46, 0x51, 0xAD, 0x90, 0x88, 0x89, 0x51,
-0x5F, 0x90, 0x88, 0x85, 0x12, 0x82, 0x12, 0xC3,
-0x12, 0x03, 0xDA, 0x50, 0x02, 0x21, 0x41, 0x90,
-0x88, 0x89, 0x12, 0x82, 0x12, 0x90, 0x88, 0x85,
-0x12, 0x04, 0xB8, 0x12, 0x80, 0xCD, 0x90, 0x9A,
-0xD4, 0x12, 0x04, 0x31, 0x90, 0x88, 0x31, 0xE0,
-0x30, 0xE0, 0x34, 0x90, 0x88, 0x53, 0xE0, 0x24,
-0x04, 0xFF, 0xE4, 0x33, 0xFE, 0xEF, 0x78, 0x03,
-0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0x24,
-0x50, 0xFF, 0xE4, 0x3E, 0xFE, 0x90, 0x88, 0x4E,
-0xE0, 0xFD, 0xC3, 0xEF, 0x9D, 0xFB, 0xEE, 0x94,
-0x00, 0xFA, 0x51, 0x4E, 0x78, 0x07, 0x12, 0x03,
-0xEB, 0xEB, 0x2F, 0xFF, 0xEA, 0x80, 0x23, 0x90,
-0x88, 0x33, 0x12, 0xBF, 0xBA, 0x30, 0xE0, 0x02,
-0x41, 0x3E, 0x51, 0x4E, 0x78, 0x07, 0x12, 0x03,
-0xEB, 0x90, 0x88, 0x4E, 0xE0, 0xFD, 0xC3, 0x74,
-0x60, 0x9D, 0xCD, 0xE4, 0x94, 0x00, 0xCD, 0x2F,
-0xFF, 0xED, 0x3E, 0x90, 0x9A, 0xD0, 0xF0, 0xA3,
-0xEF, 0xF0, 0xC3, 0x90, 0x9A, 0xD1, 0xE0, 0x94,
-0xA0, 0x90, 0x9A, 0xD0, 0xE0, 0x94, 0x00, 0x50,
-0x30, 0xA3, 0xE0, 0xFB, 0x24, 0x41, 0x51, 0x57,
-0xE0, 0x04, 0xF0, 0x51, 0x4E, 0xEF, 0x54, 0x7F,
-0xFF, 0x74, 0xE1, 0x2B, 0x51, 0x46, 0xE0, 0xFE,
-0xEF, 0xC3, 0x9E, 0x50, 0x09, 0x90, 0x9A, 0xD0,
-0xA3, 0xE0, 0x51, 0x44, 0xEF, 0xF0, 0x90, 0x88,
-0x4C, 0xE0, 0x04, 0xF0, 0xE0, 0x90, 0x00, 0xFE,
-0xF0, 0x90, 0x88, 0x4C, 0xE0, 0xFF, 0xD3, 0x90,
-0x88, 0x90, 0xE0, 0x9F, 0x90, 0x88, 0x8F, 0xE0,
-0x94, 0x00, 0x40, 0x02, 0x41, 0x3E, 0xE4, 0xFF,
-0xFE, 0x51, 0x54, 0xE0, 0x2F, 0xFF, 0x90, 0x88,
-0x91, 0xE0, 0xFD, 0xEF, 0xD3, 0x9D, 0x40, 0x07,
-0x90, 0x9A, 0xD2, 0xEE, 0xF0, 0x80, 0x05, 0x0E,
-0xEE, 0xB4, 0xA0, 0xE5, 0x51, 0x68, 0x40, 0x02,
-0x80, 0x15, 0x90, 0x9A, 0xD2, 0xE0, 0x04, 0xFE,
-0xEE, 0xC3, 0x94, 0xA0, 0x50, 0x13, 0x51, 0x54,
-0xE0, 0x2F, 0xFF, 0x51, 0x68, 0x40, 0x07, 0x90,
-0x9A, 0xD3, 0xEE, 0xF0, 0x80, 0x03, 0x0E, 0x80,
-0xE7, 0x90, 0x05, 0x5E, 0xE0, 0xFF, 0x51, 0x3F,
-0xE0, 0xFD, 0xEF, 0xC3, 0x9D, 0x40, 0x11, 0xEF,
-0x9D, 0x90, 0x05, 0x5E, 0xF0, 0x90, 0x88, 0x51,
-0xEE, 0xF0, 0x90, 0x9A, 0xD3, 0xE0, 0x80, 0x18,
-0x51, 0x3F, 0xE0, 0xFD, 0xC3, 0x74, 0x80, 0x9D,
-0x2F, 0x90, 0x05, 0x5E, 0xF0, 0xEE, 0x04, 0x90,
-0x88, 0x51, 0xF0, 0x90, 0x9A, 0xD3, 0xE0, 0x04,
-0x90, 0x88, 0x52, 0xF0, 0x90, 0x88, 0x51, 0xE0,
-0xFF, 0xC3, 0x94, 0x50, 0x40, 0x0A, 0xEF, 0x24,
-0xB0, 0x90, 0x88, 0x49, 0xF0, 0xE4, 0x80, 0x0E,
-0xE4, 0x90, 0x88, 0x49, 0xF0, 0x90, 0x88, 0x51,
-0xE0, 0xFF, 0xC3, 0x74, 0x50, 0x9F, 0x90, 0x88,
-0x48, 0xF0, 0x90, 0x88, 0x51, 0xE0, 0xFF, 0xA3,
-0xE0, 0xC3, 0x9F, 0x90, 0x88, 0x4F, 0xF0, 0x90,
-0x88, 0x31, 0xE0, 0x90, 0x88, 0x8E, 0xE0, 0x24,
-0x08, 0xFF, 0x90, 0x88, 0x4F, 0xE0, 0x2F, 0xF0,
-0x90, 0x88, 0x4F, 0xE0, 0xC3, 0x94, 0x50, 0x50,
-0x03, 0x74, 0x50, 0xF0, 0x90, 0x88, 0x4F, 0xE0,
-0x24, 0x10, 0xF0, 0x11, 0x35, 0x74, 0x03, 0xF0,
-0x12, 0x6E, 0x2F, 0x90, 0x8A, 0xA3, 0x12, 0x97,
-0x5E, 0xE4, 0xFF, 0x12, 0x04, 0x7E, 0x22, 0x90,
-0x9A, 0xD2, 0xE0, 0xFE, 0x24, 0xE1, 0xF5, 0x82,
-0xE4, 0x34, 0x98, 0xF5, 0x83, 0x22, 0x90, 0x9A,
-0xD4, 0x02, 0x04, 0xB8, 0x74, 0x41, 0x2E, 0xF5,
-0x82, 0xE4, 0x34, 0x98, 0xF5, 0x83, 0x22, 0x12,
-0x04, 0x31, 0x90, 0x88, 0x89, 0x02, 0x04, 0xB8,
-0x90, 0x88, 0x91, 0xE0, 0xFD, 0xC3, 0x90, 0x88,
-0x90, 0xE0, 0x9D, 0xFD, 0x90, 0x88, 0x8F, 0xE0,
-0x94, 0x00, 0xFC, 0xEF, 0xD3, 0x9D, 0xE4, 0x9C,
-0x22, 0xE4, 0xFE, 0x51, 0x54, 0xE4, 0xF0, 0x74,
-0xE1, 0x2E, 0x51, 0x46, 0x74, 0xFF, 0xF0, 0x0E,
-0xEE, 0xB4, 0xA0, 0xEF, 0xE4, 0x90, 0x88, 0x4D,
-0xF0, 0x90, 0x88, 0x4C, 0xF0, 0x90, 0x88, 0x50,
-0xF0, 0xEF, 0xB4, 0x01, 0x07, 0xA3, 0x74, 0xA0,
-0xF0, 0xE4, 0xA3, 0xF0, 0x22, 0xFF, 0xE4, 0x3E,
-0xFE, 0xE4, 0x3D, 0xFD, 0xE4, 0x3C, 0xFC, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x98, 0x33, 0xE0, 0x60, 0x25, 0x7F, 0x54, 0x7E,
-0x09, 0x12, 0x70, 0x70, 0x71, 0x65, 0x12, 0x04,
-0xB8, 0xEF, 0x44, 0xFE, 0xFF, 0xEE, 0x44, 0x03,
-0xFE, 0xED, 0x44, 0x04, 0xFD, 0xEC, 0x71, 0x65,
-0x12, 0xC7, 0xE2, 0x7F, 0x54, 0x7E, 0x09, 0x12,
-0x70, 0xAD, 0x90, 0x98, 0x2E, 0xE0, 0x70, 0x29,
-0x90, 0x07, 0xCC, 0xE0, 0x30, 0xE0, 0x22, 0xE4,
-0xF0, 0x90, 0x99, 0xE4, 0x74, 0x22, 0xF0, 0x90,
-0x9A, 0x06, 0x74, 0x01, 0xF0, 0x90, 0x99, 0xE6,
-0x74, 0x03, 0xF0, 0x7B, 0x01, 0x7A, 0x99, 0x79,
-0xE4, 0x12, 0x97, 0x4C, 0x7F, 0x04, 0x12, 0x04,
-0x7E, 0x90, 0x98, 0x36, 0xE0, 0xFF, 0x70, 0x0A,
-0x90, 0x98, 0x33, 0xE0, 0x70, 0x04, 0xA3, 0xE0,
-0x60, 0x15, 0x90, 0x00, 0x1F, 0xE0, 0x54, 0xF0,
-0xF0, 0x90, 0x01, 0xC5, 0x74, 0xEA, 0xF0, 0xA3,
-0x74, 0xEF, 0xF0, 0xA3, 0x74, 0xFD, 0xF0, 0xEF,
-0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x07, 0xF0,
-0x90, 0x98, 0x33, 0xE0, 0x60, 0x06, 0x90, 0x01,
-0xC4, 0x74, 0x01, 0xF0, 0x90, 0x98, 0x34, 0xE0,
-0x60, 0x06, 0x90, 0x01, 0xC4, 0x74, 0x02, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x99, 0xE0,
-0x12, 0x04, 0x31, 0x90, 0x99, 0xE0, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9C,
-0x6A, 0xED, 0xF0, 0xA3, 0xEB, 0xF0, 0x90, 0x9C,
-0x69, 0xEF, 0xF0, 0xE4, 0xFD, 0xFC, 0x12, 0xD8,
-0x81, 0x90, 0x9C, 0x6C, 0xF0, 0x12, 0xDE, 0x81,
-0x90, 0x9C, 0x69, 0xE0, 0x90, 0x04, 0x25, 0xF0,
-0x90, 0x9C, 0x6A, 0xE0, 0x60, 0x06, 0x91, 0x26,
-0xE0, 0x44, 0x80, 0xF0, 0xAF, 0x05, 0x74, 0x20,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0x54, 0xC0, 0xF0, 0x91, 0x26, 0xE0, 0x54,
-0xC0, 0xF0, 0x90, 0x9C, 0x6C, 0xE0, 0xFF, 0xAE,
-0x05, 0x74, 0x18, 0x2E, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xEF, 0xF0, 0x90, 0x00, 0x8B,
-0xE0, 0xD3, 0x94, 0x03, 0x74, 0x10, 0x2E, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x74, 0x04,
-0xF0, 0xAF, 0x05, 0x91, 0x67, 0xE0, 0x54, 0x01,
-0xFE, 0x90, 0x9C, 0x6B, 0xE0, 0x25, 0xE0, 0x25,
-0xE0, 0xFB, 0xEE, 0x44, 0x02, 0x4B, 0x91, 0x66,
-0xEE, 0xF0, 0x74, 0x11, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0x74, 0xFF, 0xF0, 0x74,
-0x29, 0x2F, 0xB1, 0x0D, 0x54, 0xF7, 0xF0, 0x74,
-0x0D, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xE0, 0x44, 0x80, 0xF0, 0xAE, 0x04, 0xAF,
-0x05, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x74, 0x21,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0x22, 0x90, 0x9C, 0x62, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x90, 0x8A, 0x9B, 0xE0, 0xFC, 0xA3, 0xE0,
-0xFD, 0xF5, 0x82, 0x8C, 0x83, 0x12, 0x04, 0x7E,
-0x90, 0x9C, 0x62, 0xA3, 0xE0, 0xFF, 0x24, 0x12,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
-0x54, 0x01, 0xFE, 0x90, 0x9C, 0x61, 0xE0, 0x25,
-0xE0, 0x25, 0xE0, 0x44, 0x02, 0x4E, 0xFE, 0x74,
-0x12, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x9C, 0x60, 0xEF, 0xF0, 0xA3, 0xED,
-0xF0, 0x90, 0x86, 0xB1, 0xE0, 0x04, 0xF0, 0x90,
-0x04, 0x1D, 0xE0, 0x60, 0x2E, 0x90, 0x05, 0x22,
-0xE0, 0x90, 0x9C, 0x64, 0xF0, 0x7B, 0x26, 0x12,
-0x91, 0xB3, 0xEF, 0x64, 0x01, 0x70, 0x09, 0x91,
-0xE5, 0x12, 0x8F, 0xBD, 0x91, 0x31, 0xEE, 0xF0,
-0x90, 0x9C, 0x64, 0xE0, 0xFD, 0x7B, 0x27, 0xE4,
-0xFF, 0x12, 0x9C, 0x0E, 0x91, 0xD3, 0x12, 0x04,
-0x7E, 0x80, 0x0E, 0x91, 0xD3, 0x12, 0x04, 0x7E,
-0x91, 0xE5, 0x12, 0x8F, 0xBD, 0x91, 0x31, 0xEE,
-0xF0, 0x12, 0x9D, 0xB8, 0x7F, 0x01, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x9C, 0x60, 0xE0, 0xFF,
-0x90, 0x8A, 0xC7, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD,
-0xF5, 0x82, 0x8C, 0x83, 0x22, 0x90, 0x86, 0xB6,
-0xE0, 0xFF, 0x90, 0x9C, 0x61, 0xE0, 0xFB, 0x90,
-0x92, 0x13, 0x74, 0x0A, 0xF0, 0x7D, 0x01, 0x12,
-0x66, 0xDB, 0x90, 0x9C, 0x62, 0xEE, 0xF0, 0xFC,
-0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x9C, 0x60, 0xE0,
-0xFF, 0x90, 0x8A, 0x95, 0x22, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22, 0x90, 0x98,
-0x16, 0x12, 0x9F, 0xEE, 0xEF, 0xF0, 0xE0, 0xFE,
-0x24, 0x28, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xE0, 0xFF, 0x74, 0x29, 0x2E, 0xB1, 0x0D,
-0xFD, 0x90, 0x99, 0x85, 0xE0, 0x24, 0x2C, 0x12,
-0xE5, 0x1A, 0x90, 0x99, 0x85, 0xE0, 0x2F, 0x24,
-0x30, 0xA3, 0xF0, 0xE0, 0xFD, 0x24, 0x04, 0x12,
-0xDE, 0x8D, 0xE0, 0xFE, 0x74, 0x05, 0x2D, 0xF1,
-0xD7, 0xF1, 0x24, 0x90, 0x95, 0x71, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x99, 0x86, 0xE0, 0x24, 0x0C,
-0xF9, 0xE4, 0x34, 0xFC, 0x12, 0x9F, 0x88, 0x75,
-0x48, 0x04, 0x7B, 0x01, 0x7A, 0x95, 0x79, 0x73,
-0x12, 0x69, 0xF5, 0x90, 0x99, 0x86, 0xE0, 0x24,
-0x14, 0xF0, 0xE0, 0xFD, 0x24, 0x01, 0xF1, 0x6A,
-0xE0, 0xFE, 0x74, 0x00, 0x2D, 0xB1, 0xE1, 0xF1,
-0x24, 0x90, 0x95, 0x77, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x98, 0x17, 0x12, 0x9F, 0xEE, 0xEF, 0xF0,
-0x90, 0x95, 0x6D, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0x4E, 0x60, 0x11, 0x90, 0x99, 0x85, 0x12, 0x9F,
-0x81, 0x8F, 0x48, 0x7B, 0x01, 0x7A, 0x95, 0x79,
-0x7B, 0x12, 0x69, 0xF5, 0x90, 0x98, 0x18, 0x12,
-0x9F, 0xEE, 0xEF, 0xF0, 0x12, 0x9F, 0x82, 0x90,
-0x95, 0x6F, 0xA3, 0xE0, 0xF5, 0x48, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x9B, 0x02, 0x69, 0xF5, 0x12,
-0x80, 0xC0, 0xA8, 0x04, 0xA9, 0x05, 0xAA, 0x06,
-0xAB, 0x07, 0x90, 0x99, 0x85, 0xA3, 0xE0, 0x24,
-0x00, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x9C, 0x1E, 0xED, 0xF0, 0x90, 0x9C, 0x1D,
-0xEF, 0xF0, 0x12, 0x7B, 0x07, 0x90, 0x9C, 0x2B,
-0xEF, 0xF0, 0xE0, 0xFD, 0x24, 0x01, 0xF1, 0x6A,
-0xE0, 0xFE, 0x74, 0x00, 0x2D, 0xB1, 0xE1, 0xF1,
-0x24, 0x54, 0x3F, 0x90, 0x9C, 0x28, 0xF0, 0xA3,
-0xEF, 0xF0, 0xE4, 0x90, 0x9C, 0x27, 0xF0, 0xF1,
-0x45, 0x50, 0x09, 0xF1, 0xA2, 0xB1, 0xDE, 0xE4,
-0xF1, 0x2D, 0x80, 0xF3, 0x90, 0x9C, 0x29, 0xE0,
-0x24, 0xF8, 0xFB, 0x90, 0x9C, 0x28, 0xE0, 0x34,
-0xFF, 0xFA, 0x90, 0x9C, 0x1E, 0xE0, 0xFF, 0x90,
-0x91, 0xDC, 0xE4, 0xF0, 0xA3, 0xEF, 0xF0, 0xA3,
-0x74, 0x01, 0xF0, 0x7D, 0x0A, 0x7C, 0x00, 0x7F,
-0x10, 0x7E, 0x00, 0x12, 0x6D, 0xED, 0x90, 0x98,
-0x0F, 0xE0, 0xFF, 0x90, 0x9C, 0x1D, 0xE0, 0xFD,
-0xD3, 0x9F, 0x40, 0x36, 0x90, 0x98, 0x0F, 0xE0,
-0xFC, 0xF1, 0x7D, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
-0xD8, 0xF9, 0xF1, 0x4E, 0xEC, 0xFF, 0xC3, 0xED,
-0xF1, 0x5A, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8,
-0xF9, 0x24, 0x28, 0xFF, 0xE4, 0x3E, 0xFE, 0xF1,
-0x3D, 0xFD, 0x90, 0x9C, 0x1E, 0xE0, 0xFC, 0xC3,
-0xED, 0x9C, 0xF1, 0x35, 0x7D, 0x38, 0x7C, 0x00,
-0x80, 0x35, 0x90, 0x9C, 0x1D, 0xE0, 0xFD, 0xF1,
-0x7D, 0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9,
-0xF1, 0x4E, 0xED, 0xFF, 0x90, 0x98, 0x0F, 0xF1,
-0x58, 0xC3, 0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9,
-0x24, 0x38, 0xFD, 0xE4, 0x3E, 0xFC, 0xF1, 0x3D,
-0xFF, 0x90, 0x9C, 0x1E, 0xE0, 0xFE, 0xC3, 0xEF,
-0x9E, 0xF1, 0x35, 0x7F, 0x28, 0x7E, 0x00, 0x12,
-0x71, 0xD4, 0xF1, 0xD0, 0x90, 0x91, 0x45, 0x12,
-0x82, 0x27, 0x0B, 0x7A, 0x9C, 0x79, 0x1F, 0x90,
-0x91, 0x48, 0x12, 0x82, 0x27, 0x90, 0x91, 0x4B,
-0x74, 0x08, 0xF0, 0x7A, 0x94, 0x79, 0x31, 0x12,
-0x4E, 0xA5, 0xE4, 0x90, 0x9C, 0x27, 0xF0, 0xF1,
-0x45, 0x50, 0x1B, 0xF1, 0xA2, 0x90, 0x9C, 0x27,
-0xE0, 0x24, 0x1F, 0xF5, 0x82, 0xE4, 0x34, 0x9C,
-0xF5, 0x83, 0xE0, 0xFF, 0x90, 0x9C, 0x2A, 0xB1,
-0xDE, 0xEF, 0xF1, 0x2D, 0x80, 0xE1, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xF0, 0x90, 0x01, 0x17, 0xE0,
-0xFE, 0x90, 0x01, 0x16, 0xE0, 0x7C, 0x00, 0x24,
-0x00, 0xFF, 0xEC, 0x3E, 0x22, 0xF0, 0x90, 0x9C,
-0x27, 0xE0, 0x04, 0xF0, 0x22, 0xFB, 0x90, 0x92,
-0x06, 0x74, 0x08, 0xF0, 0x22, 0x90, 0x9C, 0x28,
-0xA3, 0xE0, 0x24, 0xF8, 0x22, 0x90, 0x9C, 0x27,
-0xE0, 0xFF, 0xC3, 0x94, 0x08, 0x22, 0xFF, 0x90,
-0x92, 0x07, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x22,
-0xE0, 0xC3, 0x9F, 0xFF, 0xE4, 0x94, 0x00, 0xFE,
-0xEF, 0x78, 0x07, 0x22, 0x74, 0x03, 0xF0, 0x74,
-0x01, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0x22, 0xE4, 0xFD, 0x7F, 0x03, 0x12, 0x54,
-0x1E, 0x90, 0x98, 0x10, 0xE0, 0x75, 0xF0, 0x80,
-0xA4, 0xAE, 0xF0, 0x78, 0x03, 0x22, 0xE4, 0xFD,
-0x7F, 0x03, 0x12, 0x54, 0x1E, 0x90, 0x01, 0x85,
-0xE0, 0x54, 0xFE, 0xF0, 0xF1, 0x72, 0xCE, 0xC3,
-0x13, 0xCE, 0x13, 0xD8, 0xF9, 0xF1, 0xDF, 0x02,
-0x54, 0x1E, 0x90, 0x9C, 0x2B, 0xE0, 0xFD, 0x90,
-0x9C, 0x29, 0xE0, 0x2D, 0xFD, 0x90, 0x9C, 0x28,
-0xE0, 0x34, 0x00, 0xCD, 0x24, 0x20, 0xCD, 0x34,
-0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F, 0xFF, 0xEE,
-0x3C, 0xFE, 0x90, 0x9C, 0x1D, 0xE0, 0xFD, 0x12,
-0x7B, 0x8B, 0x90, 0x9C, 0x2A, 0xEF, 0xF0, 0x22,
-0x7B, 0x00, 0x7A, 0x00, 0x79, 0x00, 0x22, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x22, 0xFF,
-0x12, 0x77, 0xA4, 0x7D, 0x01, 0x7F, 0x03, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12,
-0xD0, 0x6A, 0xFD, 0xEC, 0x90, 0x9C, 0x71, 0x12,
-0x04, 0x31, 0x90, 0x9C, 0x71, 0x12, 0xC7, 0xE2,
-0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70, 0xAD, 0x11,
-0x75, 0xF0, 0x7D, 0x01, 0x12, 0x76, 0xF7, 0x12,
-0x91, 0xBA, 0x90, 0x06, 0xB7, 0x74, 0x11, 0xF0,
-0x7F, 0x03, 0x7E, 0x00, 0x12, 0x7C, 0x6A, 0x90,
-0x06, 0xB4, 0xE0, 0x54, 0x0F, 0x70, 0xF1, 0x90,
-0x07, 0xD5, 0xE0, 0x44, 0x80, 0xF0, 0x7F, 0x0A,
-0x80, 0x09, 0x90, 0x06, 0x62, 0xE0, 0x30, 0xE0,
-0x09, 0x7F, 0x01, 0x7E, 0x00, 0x12, 0x7C, 0x6A,
-0x80, 0xF0, 0x11, 0x62, 0x90, 0x01, 0x00, 0x74,
-0x3F, 0xF0, 0xA3, 0xE0, 0x54, 0xFD, 0xF0, 0x90,
-0x05, 0x53, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x07,
-0xD5, 0xE0, 0x54, 0x7F, 0xF0, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0x90, 0x00, 0x02, 0xE0, 0x54, 0xFE,
-0xF0, 0x22, 0x7F, 0x30, 0x7E, 0x08, 0x12, 0x70,
-0x70, 0xED, 0x44, 0x80, 0x22, 0x90, 0x93, 0x46,
-0xE0, 0xFF, 0x90, 0x93, 0x45, 0xE0, 0xFB, 0x90,
-0x93, 0x47, 0xE0, 0x90, 0x92, 0x90, 0x22, 0xE4,
-0x90, 0x9C, 0x81, 0xF0, 0xA3, 0xF0, 0x90, 0x05,
-0x22, 0xE0, 0x90, 0x9C, 0x83, 0xF0, 0x7B, 0x47,
-0x7D, 0xFF, 0xE4, 0xFF, 0x12, 0x9C, 0x0E, 0x90,
-0x05, 0xF8, 0xE0, 0x70, 0x1B, 0xA3, 0xE0, 0x70,
-0x17, 0xA3, 0xE0, 0x70, 0x13, 0xA3, 0xE0, 0x70,
-0x0F, 0x90, 0x9C, 0x83, 0xE0, 0xFD, 0x7B, 0x48,
-0xE4, 0xFF, 0x12, 0x9C, 0x0E, 0x7F, 0x01, 0x22,
-0xD3, 0x90, 0x9C, 0x82, 0xE0, 0x94, 0xE8, 0x90,
-0x9C, 0x81, 0xE0, 0x94, 0x03, 0x40, 0x16, 0x90,
-0x01, 0xC0, 0xE0, 0x44, 0x20, 0xF0, 0x90, 0x9C,
-0x83, 0xE0, 0xFD, 0x7B, 0x5B, 0xE4, 0xFF, 0x12,
-0x9C, 0x0E, 0x7F, 0x00, 0x22, 0x7F, 0x32, 0x7E,
-0x00, 0x12, 0x7C, 0x6A, 0x90, 0x9C, 0x81, 0xE4,
-0x75, 0xF0, 0x01, 0x12, 0x02, 0xE7, 0x80, 0xA7,
-0x90, 0x01, 0x9A, 0xE0, 0x54, 0xC0, 0x44, 0x0B,
-0xF0, 0x12, 0xBB, 0x98, 0x90, 0x01, 0x98, 0xE0,
-0x54, 0xC0, 0x7F, 0x00, 0xB4, 0x40, 0x02, 0x7F,
-0x01, 0x22, 0x90, 0x93, 0x24, 0xE0, 0x30, 0xE0,
-0x0B, 0x90, 0x8A, 0xE5, 0x12, 0x97, 0x5E, 0x7F,
-0x10, 0x12, 0x04, 0x7E, 0x22, 0x90, 0x8A, 0x75,
-0x12, 0x91, 0xBD, 0x90, 0x8A, 0xE5, 0x12, 0x97,
-0x5E, 0x7F, 0x02, 0x02, 0x04, 0x7E, 0x90, 0x01,
-0xCF, 0xE0, 0x90, 0x9A, 0xCF, 0xF0, 0xE0, 0xFF,
-0x30, 0xE0, 0x07, 0x90, 0x01, 0xCF, 0xE0, 0x54,
-0xFE, 0xF0, 0xEF, 0x30, 0xE5, 0x23, 0x90, 0x01,
-0xCF, 0xE0, 0x54, 0xDF, 0xF0, 0x90, 0x01, 0x34,
-0x74, 0x20, 0xF0, 0xE4, 0xF5, 0xA8, 0xF5, 0xE8,
-0x12, 0x76, 0x6D, 0x90, 0x00, 0x03, 0xE0, 0x54,
-0xFB, 0xFD, 0x7F, 0x03, 0x12, 0x7B, 0x2E, 0x80,
-0xFE, 0x22, 0x90, 0x8A, 0xE5, 0x12, 0x97, 0x5E,
-0x7F, 0x80, 0x02, 0x04, 0x7E, 0x7F, 0x58, 0x7E,
-0x0C, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x9B, 0xF9, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
-0x12, 0x70, 0x70, 0x90, 0x9C, 0x03, 0x12, 0x04,
-0x31, 0x90, 0x9B, 0xFB, 0x12, 0x04, 0xB8, 0x12,
-0x03, 0xCD, 0x90, 0x9C, 0x03, 0x12, 0x82, 0x12,
-0x12, 0x81, 0xF8, 0xC0, 0x04, 0xC0, 0x05, 0xC0,
-0x06, 0xC0, 0x07, 0x90, 0x9B, 0xFB, 0x12, 0x04,
-0xB8, 0x90, 0x9B, 0xFF, 0x12, 0x82, 0x12, 0x12,
-0x81, 0xF8, 0xD0, 0x03, 0xD0, 0x02, 0xD0, 0x01,
-0xD0, 0x00, 0x12, 0x82, 0x05, 0x90, 0x9C, 0x07,
-0x12, 0x04, 0x31, 0x90, 0x9C, 0x07, 0x12, 0xC7,
-0xE2, 0x90, 0x9B, 0xF9, 0xE0, 0xFE, 0xA3, 0xE0,
-0xFF, 0x12, 0x70, 0xAD, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x90, 0x9C, 0x93, 0xED, 0xF0, 0xE4, 0xA3, 0xF0,
-0xEF, 0x14, 0x60, 0x02, 0x41, 0xCF, 0x90, 0x06,
-0x03, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x9C, 0x93,
-0xE0, 0xFB, 0xC4, 0x33, 0x54, 0xE0, 0xFE, 0x90,
-0x04, 0x42, 0xE0, 0x54, 0x9F, 0x4E, 0xFE, 0xF0,
-0xE4, 0xFD, 0xF1, 0xC1, 0x90, 0x9C, 0x94, 0xEF,
-0xF0, 0x90, 0x04, 0x83, 0xF0, 0x90, 0x9B, 0xFB,
-0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x01, 0x90,
-0x9B, 0xFF, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0x01, 0x71, 0x34, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x00, 0x01, 0x90, 0x9B, 0xFF, 0x12, 0x04, 0x3D,
-0x00, 0x00, 0x00, 0x01, 0x7F, 0x00, 0x7E, 0x09,
-0x71, 0x38, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0x10, 0x90, 0x9C, 0x93, 0x12, 0xB5, 0x5C, 0xEF,
-0x54, 0x03, 0xFF, 0xE4, 0x78, 0x01, 0x12, 0x03,
-0xEB, 0x78, 0x04, 0x91, 0x19, 0x7F, 0x00, 0x7E,
-0x0A, 0x71, 0x38, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x0C, 0x00, 0x90, 0x9C, 0x93, 0x12, 0xB5, 0x5C,
-0xEF, 0x54, 0x03, 0xFF, 0xE4, 0x78, 0x0A, 0x91,
-0x19, 0x7F, 0x00, 0x7E, 0x0D, 0x71, 0x38, 0x12,
-0x04, 0x3D, 0x0C, 0x00, 0x00, 0x00, 0x90, 0x9C,
-0x94, 0x12, 0xB5, 0x5C, 0xEF, 0x54, 0x03, 0xFF,
-0xE4, 0x78, 0x1A, 0x91, 0x19, 0x7F, 0x18, 0x71,
-0x36, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00,
-0x90, 0x9B, 0xFF, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x00, 0x00, 0x91, 0x22, 0x12, 0x04, 0x3D, 0x00,
-0x00, 0x0C, 0x00, 0x90, 0x9B, 0xED, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x04, 0x00, 0x80, 0x58, 0x90,
-0x06, 0x03, 0xE0, 0x44, 0x04, 0xF0, 0x90, 0x9B,
-0xFB, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x01,
-0x90, 0x9B, 0xFF, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x00, 0x00, 0x71, 0x34, 0x12, 0x04, 0x3D, 0x00,
-0x00, 0x00, 0x01, 0x90, 0x9B, 0xFF, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x00, 0x7F, 0x00, 0x7E,
-0x09, 0x71, 0x38, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x0C, 0x00, 0x90, 0x9B, 0xFF, 0x12, 0x04, 0x3D,
-0x00, 0x00, 0x0C, 0x00, 0x91, 0x22, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x0C, 0x00, 0x90, 0x9B, 0xED,
-0x12, 0x04, 0x3D, 0x00, 0x00, 0x0C, 0x00, 0x7D,
-0x18, 0x7C, 0x00, 0xE4, 0xFF, 0xB1, 0x9A, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x7F, 0x00, 0x7E, 0x08,
-0x31, 0x81, 0x90, 0x9B, 0xFB, 0x22, 0x7F, 0x50,
-0x7E, 0x0C, 0x12, 0x70, 0x70, 0x90, 0x9A, 0xDF,
-0xEF, 0xF0, 0x7F, 0x58, 0x7E, 0x0C, 0x12, 0x70,
-0x70, 0x90, 0x9A, 0xE0, 0xEF, 0xF0, 0x90, 0x9B,
-0xFB, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x7F,
-0x90, 0x9B, 0xFF, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x00, 0x17, 0x7F, 0x50, 0x7E, 0x0C, 0x71, 0x38,
-0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x7F, 0x90,
-0x9B, 0xFF, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0x17, 0x31, 0x7D, 0x90, 0x06, 0x08, 0xE0, 0x90,
-0x9A, 0xF5, 0xF0, 0x90, 0x06, 0xA1, 0xE0, 0xFE,
-0x90, 0x06, 0xA0, 0x12, 0xCF, 0x24, 0x90, 0x9A,
-0xF7, 0xF0, 0xA3, 0xEF, 0xF1, 0x7B, 0x90, 0x06,
-0xA0, 0x74, 0x20, 0xF0, 0xA3, 0x74, 0x01, 0xF0,
-0xE4, 0xFD, 0xFF, 0x21, 0xE9, 0x90, 0x93, 0x04,
-0x12, 0xBF, 0xBA, 0x30, 0xE0, 0x08, 0xD1, 0xBF,
-0xF0, 0xE4, 0x90, 0x9A, 0xF9, 0xF0, 0x90, 0x9B,
-0xFB, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x7F,
-0x90, 0x9A, 0xDF, 0x12, 0xB5, 0x5C, 0x91, 0x1C,
-0x7F, 0x50, 0x7E, 0x0C, 0x71, 0x38, 0x12, 0x04,
-0x3D, 0x00, 0x00, 0x00, 0x7F, 0x90, 0x9A, 0xE0,
-0x12, 0xB5, 0x5C, 0x91, 0x1C, 0x31, 0x7D, 0x90,
-0x9A, 0xF5, 0xE0, 0x90, 0x06, 0x08, 0xF0, 0x90,
-0x9A, 0xF7, 0xA3, 0xE0, 0x90, 0x06, 0xA0, 0xF0,
-0xA3, 0xE4, 0xF0, 0x90, 0x9A, 0xE3, 0xE0, 0xFF,
-0x60, 0x05, 0xA3, 0xE0, 0xFD, 0x31, 0xE9, 0x90,
-0x9A, 0xE2, 0xE0, 0xFF, 0x60, 0x0A, 0xA3, 0xE0,
-0xFD, 0xA3, 0xE0, 0xFB, 0xD1, 0x65, 0xB1, 0x30,
-0x22, 0x12, 0x03, 0xFE, 0x90, 0x9B, 0xFF, 0x02,
-0x04, 0x31, 0x7F, 0x84, 0x7E, 0x08, 0x31, 0x81,
-0x90, 0x9B, 0xE9, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x9A, 0xF1, 0xE0, 0xFF,
-0x12, 0xF0, 0x64, 0xEF, 0x70, 0x02, 0x81, 0xE4,
-0x90, 0x9A, 0xF2, 0xE0, 0xFB, 0xD3, 0x94, 0x00,
-0x40, 0x18, 0x90, 0x9B, 0xFB, 0x12, 0x04, 0x3D,
-0x00, 0x00, 0x00, 0x0F, 0xAF, 0x03, 0xE4, 0xFC,
-0xFD, 0xFE, 0x91, 0x1C, 0x7F, 0x08, 0x7E, 0x0E,
-0x31, 0x81, 0x90, 0x9A, 0xF1, 0xE0, 0xFF, 0x90,
-0x06, 0x33, 0xF0, 0xD1, 0x65, 0xE4, 0xFB, 0xFD,
-0xB1, 0x30, 0x90, 0x9A, 0xF4, 0xE0, 0x60, 0x07,
-0x90, 0x93, 0x05, 0xE0, 0xFF, 0xD1, 0x2F, 0x12,
-0xAF, 0xEA, 0x30, 0xE0, 0x39, 0x90, 0x95, 0xBE,
-0xE0, 0x60, 0x33, 0xE4, 0x90, 0x9A, 0x0A, 0xF0,
-0x90, 0x95, 0xBE, 0xE0, 0xFF, 0x90, 0x9A, 0x0A,
-0xE0, 0xC3, 0x9F, 0x50, 0x21, 0x7F, 0x03, 0x7E,
-0x00, 0x12, 0x7A, 0xAE, 0x90, 0x9A, 0x0A, 0xE0,
-0x24, 0xFD, 0xF1, 0x6B, 0xE0, 0xFF, 0xD1, 0x2F,
-0x90, 0x01, 0xA6, 0xE0, 0x04, 0xF0, 0x90, 0x9A,
-0x0A, 0xE0, 0x04, 0xF0, 0x80, 0xD2, 0x90, 0x9A,
-0xF3, 0xE0, 0x90, 0x9A, 0x09, 0xF0, 0x90, 0x9A,
-0xDE, 0xE0, 0x04, 0xF0, 0xE0, 0xFF, 0x12, 0xF0,
-0x2E, 0x90, 0x9A, 0x09, 0x12, 0xB5, 0x5C, 0x90,
-0x9C, 0x55, 0x12, 0x04, 0x31, 0xF1, 0x73, 0x12,
-0xAD, 0x6A, 0x80, 0x47, 0xE4, 0x90, 0x9A, 0xDE,
-0xF0, 0x90, 0x9B, 0x5D, 0xF0, 0x90, 0x06, 0x32,
-0xE0, 0x54, 0xFB, 0xF0, 0x71, 0xAD, 0xE4, 0xFF,
-0x12, 0x78, 0x4A, 0xBF, 0x01, 0x13, 0x90, 0x9A,
-0xF6, 0xE0, 0xFD, 0x90, 0x8A, 0x89, 0x12, 0x97,
-0x5E, 0x7F, 0x02, 0x12, 0x04, 0x7E, 0x12, 0x7B,
-0xAD, 0x90, 0x9A, 0x0B, 0x74, 0x07, 0xF0, 0x90,
-0x9A, 0x2D, 0xF0, 0x7B, 0x01, 0x7A, 0x9A, 0x79,
-0x0B, 0x12, 0x97, 0x4C, 0x7F, 0x04, 0x12, 0x04,
-0x7E, 0xD1, 0x6E, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x9C, 0x75, 0xEF, 0xF0, 0xED, 0x64, 0x01, 0x70,
-0x2E, 0xEB, 0xB4, 0x01, 0x07, 0xE0, 0x24, 0x02,
-0xF5, 0x13, 0x80, 0x08, 0x90, 0x9C, 0x75, 0xE0,
-0x24, 0xFE, 0xF5, 0x13, 0x90, 0x9B, 0xE9, 0x12,
-0x04, 0x3D, 0x00, 0x00, 0x00, 0xFF, 0xAF, 0x13,
-0xD1, 0x20, 0xD1, 0x18, 0x12, 0x04, 0x3D, 0x00,
-0x00, 0x00, 0xFF, 0xAF, 0x13, 0x80, 0x20, 0x90,
-0x9B, 0xE9, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00,
-0xFF, 0x90, 0x9C, 0x75, 0x12, 0xB5, 0x5C, 0xD1,
-0x24, 0xD1, 0x18, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x00, 0xFF, 0x90, 0x9C, 0x75, 0xE0, 0xFF, 0xD1,
-0x20, 0x7F, 0x01, 0xB1, 0x9A, 0xD0, 0xD0, 0x92,
-0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x9B, 0xE7, 0xEC, 0xF0, 0xA3, 0xED,
-0xF0, 0x90, 0x9B, 0xE6, 0xEF, 0xF0, 0xA3, 0xA3,
-0xE0, 0xFD, 0x12, 0x7B, 0xBD, 0x90, 0x9B, 0xF1,
-0x12, 0x04, 0x31, 0x90, 0x9B, 0xE9, 0x12, 0x04,
-0xB8, 0x12, 0x03, 0xCD, 0x90, 0x9B, 0xF1, 0x12,
-0x82, 0x12, 0x12, 0x81, 0xF8, 0xC0, 0x04, 0xC0,
-0x05, 0xC0, 0x06, 0xC0, 0x07, 0x90, 0x9B, 0xE9,
-0x12, 0x04, 0xB8, 0x90, 0x9B, 0xED, 0x12, 0x82,
-0x12, 0x12, 0x81, 0xF8, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0x12, 0x82, 0x05, 0x90,
-0x9B, 0xF5, 0x12, 0x04, 0x31, 0x90, 0x9B, 0xE7,
-0xA3, 0xE0, 0xFD, 0xC0, 0x05, 0x90, 0x9B, 0xF5,
-0x12, 0x04, 0xB8, 0x90, 0x8B, 0x9F, 0x12, 0x04,
-0x31, 0x90, 0x9B, 0xE6, 0xE0, 0xFF, 0xD0, 0x05,
-0x12, 0x79, 0x53, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0xE4, 0xFF, 0xB1, 0x9A, 0x90, 0x9B, 0xE9, 0x22,
-0xE4, 0xFC, 0xFD, 0xFE, 0x90, 0x9B, 0xED, 0x12,
-0x04, 0x31, 0x7D, 0x18, 0x7C, 0x00, 0x22, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9A,
-0x2E, 0xEF, 0xF0, 0x12, 0x76, 0x9B, 0xBF, 0x01,
-0x1F, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x08, 0xF0,
-0x90, 0x9A, 0x2E, 0xE0, 0xFF, 0x90, 0x92, 0x13,
-0x74, 0x07, 0x12, 0x9F, 0xBA, 0x90, 0x9A, 0x2F,
-0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0x9D, 0xB8,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x9A, 0xE9,
-0xE0, 0x90, 0x9C, 0x78, 0xF0, 0x22, 0x90, 0x93,
-0x04, 0x12, 0x89, 0xF1, 0x30, 0xE0, 0x31, 0xEF,
-0xC4, 0x54, 0x0F, 0x20, 0xE0, 0x25, 0xF1, 0x98,
-0x60, 0x0B, 0xF1, 0x8E, 0x40, 0x07, 0xD1, 0xB7,
-0x90, 0x95, 0xC9, 0x80, 0x05, 0xD1, 0xB7, 0x90,
-0x95, 0xC1, 0x12, 0x82, 0x12, 0x12, 0x80, 0xDB,
-0x90, 0x9C, 0x55, 0x12, 0x04, 0x31, 0x12, 0xAD,
-0x63, 0x80, 0x05, 0x7F, 0x01, 0x12, 0x87, 0xFA,
-0x90, 0x93, 0x04, 0xE0, 0xC3, 0x13, 0x30, 0xE0,
-0x05, 0x7F, 0x01, 0x12, 0x87, 0xFA, 0x22, 0xE4,
-0x7F, 0xE8, 0x7E, 0x03, 0xFD, 0xFC, 0x22, 0x90,
-0x02, 0x86, 0xE0, 0x54, 0xFB, 0x22, 0xE4, 0xFD,
-0xFC, 0x90, 0x01, 0x1D, 0xE0, 0xFE, 0x90, 0x01,
-0x1C, 0xF1, 0xB9, 0x3E, 0x90, 0x9C, 0x79, 0xF0,
-0xA3, 0xEF, 0xF1, 0x84, 0xE0, 0x24, 0x00, 0xFF,
-0xEA, 0x3E, 0x90, 0x9C, 0x7B, 0xF0, 0xA3, 0xEF,
-0xF0, 0xF1, 0x5B, 0x90, 0x9C, 0x79, 0xE0, 0xFA,
-0xA3, 0xE0, 0xFB, 0xB5, 0x07, 0x06, 0xEA, 0xB5,
-0x06, 0x02, 0x80, 0x40, 0xF1, 0x5B, 0xD3, 0xEB,
-0x9F, 0xEA, 0x9E, 0x40, 0x0E, 0x90, 0x9C, 0x7A,
-0xE0, 0x9F, 0xFD, 0x90, 0x9C, 0x79, 0xE0, 0x9E,
-0xFC, 0x80, 0x29, 0xF1, 0x5B, 0xC3, 0x90, 0x9C,
-0x7A, 0xE0, 0x9F, 0x90, 0x9C, 0x79, 0xE0, 0x9E,
-0x50, 0x1A, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0xC3,
-0x90, 0x9C, 0x7C, 0xE0, 0x9F, 0xFF, 0x90, 0x9C,
-0x7B, 0xE0, 0x9E, 0xFE, 0xC3, 0xE4, 0x9F, 0xFD,
-0x74, 0x40, 0x9E, 0xFC, 0xD3, 0xED, 0x94, 0x00,
-0xEC, 0x94, 0x38, 0x40, 0x04, 0xD1, 0xBF, 0xF0,
-0x22, 0xC3, 0xEC, 0x94, 0x08, 0x50, 0x0B, 0xED,
-0x94, 0x00, 0xEC, 0x94, 0x00, 0x40, 0x03, 0xF1,
-0x64, 0xF0, 0x22, 0x90, 0x9C, 0x7B, 0xE0, 0xFE,
-0xA3, 0xE0, 0xFF, 0x22, 0x90, 0x02, 0x86, 0xE0,
-0x44, 0x04, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0x95,
-0xF5, 0x83, 0x22, 0xE4, 0x90, 0x9C, 0x59, 0xF0,
-0x7F, 0x04, 0x22, 0xF0, 0x90, 0x06, 0x08, 0xE0,
-0x54, 0x7F, 0xF0, 0x22, 0xF0, 0x90, 0x01, 0x1F,
-0xE0, 0xFE, 0x90, 0x01, 0x1E, 0x22, 0x90, 0x98,
-0x05, 0x12, 0x82, 0x12, 0xD3, 0x02, 0x03, 0xDA,
-0x90, 0x95, 0xC5, 0x12, 0x04, 0xB8, 0xEC, 0x4D,
-0x4E, 0x4F, 0x22, 0x74, 0x01, 0x2D, 0xF5, 0x82,
-0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0xFE, 0x74,
-0x00, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5,
-0x83, 0xE0, 0x7A, 0x00, 0x24, 0x00, 0xFF, 0xEA,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0xE4, 0xFE, 0xFD, 0xEF, 0xB4, 0x01, 0x0D, 0xEB,
-0xB4, 0x02, 0x03, 0x0D, 0x80, 0x06, 0xEB, 0xB4,
-0x01, 0x02, 0x7D, 0x02, 0xAF, 0x06, 0xEF, 0xC4,
-0x54, 0xF0, 0x4D, 0xFF, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xE4, 0x90, 0x9A, 0xDA, 0xF0, 0xA3, 0xF0,
-0x7F, 0x83, 0x12, 0x7B, 0x41, 0x90, 0x9A, 0xD9,
-0xEF, 0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x41, 0xAE,
-0x07, 0x90, 0x9A, 0xD9, 0xE0, 0xFF, 0xB5, 0x06,
-0x01, 0x22, 0xC3, 0x90, 0x9A, 0xDB, 0xE0, 0x94,
-0x64, 0x90, 0x9A, 0xDA, 0xE0, 0x94, 0x00, 0x40,
-0x0D, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x40, 0xF0,
-0x90, 0x9A, 0xD9, 0xE0, 0xFF, 0x22, 0x90, 0x9A,
-0xDA, 0xE4, 0x75, 0xF0, 0x01, 0x12, 0x02, 0xE7,
-0x80, 0xBE, 0x90, 0x01, 0xC4, 0x74, 0x32, 0xF0,
-0x74, 0xD8, 0xA3, 0xF0, 0x7F, 0x90, 0x12, 0x7B,
-0x41, 0xEF, 0x20, 0xE0, 0xF7, 0x74, 0x32, 0x04,
-0x90, 0x01, 0xC4, 0xF0, 0x74, 0xD8, 0xA3, 0xF0,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x11, 0x81, 0x90, 0x9C, 0x9A, 0xF0, 0xED, 0x90,
-0x00, 0x73, 0x70, 0x0D, 0xE0, 0x44, 0x04, 0xF0,
-0x90, 0x00, 0x67, 0xE0, 0x44, 0x80, 0xF0, 0x80,
-0x0B, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x00, 0x67,
-0xE0, 0x54, 0x7F, 0xF0, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0x90, 0x86, 0xAD, 0xA3, 0xE0, 0x24, 0x7F,
-0xF5, 0x82, 0xE4, 0x34, 0x84, 0xF5, 0x83, 0xE0,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0x11, 0x81, 0x90, 0x9C, 0x9F, 0xF0, 0x90, 0x88,
-0x32, 0x12, 0x97, 0xB1, 0x30, 0xE0, 0x02, 0x21,
-0x57, 0x90, 0x88, 0x31, 0xE0, 0x30, 0xE0, 0x1F,
-0x90, 0x88, 0x53, 0xE0, 0x24, 0x04, 0x33, 0x33,
-0x33, 0x54, 0xF8, 0x90, 0x88, 0x4B, 0xF0, 0x90,
-0x88, 0x53, 0xE0, 0x04, 0x33, 0x33, 0x33, 0x54,
-0xF8, 0x90, 0x88, 0x4A, 0xF0, 0x80, 0x10, 0x90,
-0x88, 0x4B, 0x74, 0x10, 0xF0, 0x90, 0x88, 0x4A,
-0x74, 0x08, 0xF0, 0x74, 0x10, 0x2B, 0xFB, 0x90,
-0x88, 0x4A, 0xE0, 0xFE, 0x90, 0x88, 0x49, 0xE0,
-0xD3, 0x9E, 0x50, 0x0E, 0x90, 0x88, 0x3E, 0xEB,
-0xF0, 0x90, 0x88, 0x4B, 0xE0, 0xC3, 0x9D, 0x2F,
-0x80, 0x11, 0xC3, 0xED, 0x9E, 0x2B, 0x90, 0x88,
-0x3E, 0xF0, 0x90, 0x88, 0x4A, 0xE0, 0xFF, 0xA3,
-0xE0, 0xC3, 0x9F, 0x90, 0x88, 0x4E, 0xF0, 0x90,
-0x88, 0x4B, 0x31, 0x63, 0x90, 0x88, 0x4E, 0x31,
-0x6C, 0x40, 0x04, 0xEF, 0x24, 0x50, 0xF0, 0x90,
-0x88, 0x4E, 0x31, 0x63, 0x90, 0x88, 0x3E, 0x31,
-0x6C, 0x40, 0x04, 0xEF, 0x24, 0x50, 0xF0, 0x90,
-0x88, 0x4E, 0x12, 0xB2, 0xDA, 0xFF, 0x7E, 0x00,
-0x90, 0x88, 0x42, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x05, 0x58, 0xF0, 0x90, 0x88, 0x4E, 0xE0,
-0x54, 0x07, 0xFF, 0x90, 0x05, 0xB1, 0xE0, 0x54,
-0xF8, 0x4F, 0xF0, 0x31, 0x77, 0x80, 0x07, 0x90,
-0x88, 0x33, 0xE0, 0x44, 0x01, 0xF0, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xE0, 0xFF, 0x24, 0x50, 0xFD,
-0xE4, 0x33, 0xFC, 0x22, 0xE0, 0xD3, 0x9D, 0xEC,
-0x64, 0x80, 0xF8, 0x74, 0x80, 0x98, 0x22, 0x90,
-0x88, 0x33, 0xE0, 0x54, 0xFE, 0xF0, 0x22, 0xD3,
+0x00, 0x00, 0x7F, 0x14, 0x7E, 0x00, 0x02, 0x7C,
+0x6A, 0xE0, 0xFF, 0x24, 0x1A, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB0,
+0xF0, 0x74, 0x1F, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB1, 0xF0,
+0x22, 0xE0, 0xFF, 0x24, 0x10, 0xF5, 0x82, 0xE4,
+0x34, 0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB2,
+0xF0, 0x74, 0x15, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0x93, 0xF5, 0x83, 0xE0, 0x90, 0x01, 0xB3, 0xF0,
+0xE0, 0x22, 0x90, 0x9C, 0xCD, 0xEF, 0x12, 0xCA,
+0x89, 0x90, 0x01, 0x09, 0xE0, 0x7F, 0x00, 0x30,
+0xE7, 0x02, 0x7F, 0x01, 0x90, 0x9C, 0xCD, 0xE0,
+0x6F, 0x60, 0x36, 0xC3, 0x90, 0x9C, 0xCF, 0xE0,
+0x94, 0x88, 0x90, 0x9C, 0xCE, 0xE0, 0x94, 0x13,
+0x40, 0x08, 0x90, 0x01, 0xC0, 0xE0, 0x44, 0x10,
+0xF0, 0x22, 0x90, 0x9C, 0xCE, 0x12, 0xBF, 0xA5,
+0x12, 0xBF, 0xDF, 0xD3, 0x90, 0x9C, 0xCF, 0xE0,
+0x94, 0x32, 0x90, 0x9C, 0xCE, 0xE0, 0x94, 0x00,
+0x40, 0xBF, 0x90, 0x01, 0xC6, 0xE0, 0x30, 0xE0,
+0xB8, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
+0xD0, 0x90, 0x9C, 0xD5, 0xEF, 0xF0, 0x90, 0x00,
+0x8F, 0xE0, 0x30, 0xE6, 0x45, 0x90, 0x00, 0x8D,
+0xE0, 0x64, 0x01, 0x70, 0x3D, 0x90, 0x9C, 0xD6,
+0xF0, 0x90, 0x9C, 0xD6, 0xE0, 0xFD, 0x90, 0x9C,
+0xD5, 0xE0, 0xC4, 0x54, 0xF0, 0x24, 0x00, 0xF5,
+0x82, 0xE4, 0x34, 0x81, 0xF5, 0x83, 0xE5, 0x82,
+0x2D, 0x12, 0xBD, 0xDF, 0xE0, 0xFB, 0xE4, 0xFF,
+0x31, 0xDF, 0x90, 0x9C, 0xD6, 0xE0, 0x04, 0xF0,
+0xE0, 0xC3, 0x94, 0x10, 0x40, 0xD3, 0x90, 0x00,
+0x8F, 0xE0, 0x30, 0xE0, 0x05, 0x90, 0x00, 0x8D,
+0xE4, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xEF,
+0x70, 0x04, 0x74, 0xF0, 0x80, 0x16, 0xEF, 0xB4,
+0x01, 0x04, 0x74, 0xF4, 0x80, 0x0E, 0xEF, 0xB4,
+0x02, 0x04, 0x74, 0xF8, 0x80, 0x06, 0xEF, 0xB4,
+0x03, 0x0C, 0x74, 0xFC, 0x2D, 0xF5, 0x82, 0xE4,
+0x34, 0x02, 0xF5, 0x83, 0xEB, 0xF0, 0x22, 0xEF,
+0x64, 0x01, 0x70, 0x26, 0x90, 0x93, 0x2B, 0xE0,
+0x54, 0x7F, 0xFF, 0x7E, 0x00, 0x90, 0x93, 0x2D,
+0xE0, 0x13, 0x13, 0x54, 0x01, 0xFD, 0x90, 0x93,
+0x2C, 0xE0, 0xFC, 0xC3, 0x13, 0x54, 0x7F, 0xFB,
+0xEC, 0x54, 0x01, 0x90, 0x9C, 0x98, 0xF0, 0x12,
+0xB9, 0x7B, 0x22, 0x90, 0x01, 0x8C, 0xE4, 0xF0,
+0xA3, 0xF0, 0xA3, 0x74, 0x71, 0xF0, 0xA3, 0x74,
+0x02, 0xF0, 0x90, 0x01, 0x95, 0xE0, 0x54, 0xF0,
+0x44, 0x07, 0xF0, 0x90, 0x01, 0x98, 0x74, 0x7F,
+0xF0, 0x90, 0x01, 0x01, 0xE0, 0x54, 0xFB, 0xF0,
+0xE0, 0x44, 0x04, 0xF0, 0x22, 0x90, 0x01, 0x9A,
+0xE0, 0x54, 0xC0, 0x44, 0x0B, 0xF0, 0x12, 0xBE,
+0xF4, 0x90, 0x01, 0x98, 0xE0, 0x54, 0xC0, 0x7F,
+0x00, 0xB4, 0x40, 0x02, 0x7F, 0x01, 0x22, 0x90,
+0x01, 0x95, 0xE0, 0x7F, 0x00, 0x30, 0xE4, 0x02,
+0x7F, 0x01, 0x22, 0x90, 0x93, 0x24, 0xE0, 0x30,
+0xE0, 0x0B, 0x90, 0x8A, 0xE5, 0x12, 0x90, 0x47,
+0x7F, 0x10, 0x12, 0x04, 0x7E, 0x22, 0x90, 0x8A,
+0x75, 0x12, 0x88, 0xC8, 0x90, 0x8A, 0xE5, 0x12,
+0x90, 0x47, 0x7F, 0x02, 0x02, 0x04, 0x7E, 0x90,
+0x01, 0xCF, 0xE0, 0x90, 0x9A, 0xFB, 0xF0, 0xE0,
+0xFF, 0x30, 0xE0, 0x07, 0x90, 0x01, 0xCF, 0xE0,
+0x54, 0xFE, 0xF0, 0xEF, 0x30, 0xE5, 0x23, 0x90,
+0x01, 0xCF, 0xE0, 0x54, 0xDF, 0xF0, 0x90, 0x01,
+0x34, 0x74, 0x20, 0xF0, 0xE4, 0xF5, 0xA8, 0xF5,
+0xE8, 0x12, 0x76, 0x6D, 0x90, 0x00, 0x03, 0xE0,
+0x54, 0xFB, 0xFD, 0x7F, 0x03, 0x12, 0x7B, 0x2E,
+0x80, 0xFE, 0x22, 0xE4, 0x90, 0x9B, 0x06, 0xF0,
+0xA3, 0xF0, 0x7F, 0x83, 0x12, 0x7B, 0x41, 0x90,
+0x9B, 0x05, 0xEF, 0xF0, 0x7F, 0x83, 0x12, 0x7B,
+0x41, 0xAE, 0x07, 0x90, 0x9B, 0x05, 0xE0, 0xFF,
+0xB5, 0x06, 0x01, 0x22, 0xC3, 0x90, 0x9B, 0x07,
+0xE0, 0x94, 0x64, 0x90, 0x9B, 0x06, 0xE0, 0x94,
+0x00, 0x40, 0x0D, 0x90, 0x01, 0xC0, 0xE0, 0x44,
+0x40, 0xF0, 0x90, 0x9B, 0x05, 0xE0, 0xFF, 0x22,
+0x90, 0x9B, 0x06, 0x12, 0xBF, 0xA5, 0x80, 0xC2,
+0x90, 0x01, 0xC4, 0x74, 0x28, 0xF0, 0x74, 0xE3,
+0xA3, 0xF0, 0x7F, 0x90, 0x12, 0x7B, 0x41, 0xEF,
+0x20, 0xE0, 0xF7, 0x74, 0x28, 0x04, 0x90, 0x01,
+0xC4, 0xF0, 0x74, 0xE3, 0xA3, 0xF0, 0x22, 0xD3,
 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0x90, 0x9C, 0x9B, 0xEF, 0xF0,
+0x92, 0xAF, 0x22, 0x90, 0x9C, 0xE3, 0xEF, 0xF0,
 0x90, 0x88, 0xB8, 0xE0, 0x44, 0x01, 0xF0, 0x90,
-0x8A, 0xF9, 0x12, 0x97, 0x5E, 0x7D, 0x11, 0x7F,
+0x8A, 0xF9, 0x12, 0x90, 0x47, 0x7D, 0x11, 0x7F,
 0xFF, 0x12, 0x04, 0x7E, 0x90, 0x8A, 0xEF, 0x12,
-0x91, 0xBD, 0x90, 0x07, 0x78, 0xE0, 0x90, 0x88,
-0xBD, 0xF0, 0x90, 0x9C, 0x9B, 0xE0, 0xFD, 0x70,
-0x02, 0x80, 0x1C, 0xED, 0xB4, 0x01, 0x06, 0x31,
-0xDB, 0x44, 0x20, 0xF0, 0x22, 0x90, 0x9C, 0x9B,
-0xE0, 0xFD, 0xB4, 0x02, 0x06, 0x31, 0xDB, 0x44,
-0x60, 0xF0, 0x22, 0xED, 0xB4, 0x03, 0x03, 0x31,
-0xDB, 0xF0, 0x22, 0x90, 0x88, 0xB8, 0xE0, 0x54,
-0x1F, 0x22, 0x90, 0x98, 0x20, 0x12, 0xBF, 0xBA,
-0x30, 0xE0, 0x0C, 0x12, 0xCF, 0xD0, 0x51, 0x04,
-0xF0, 0xA3, 0x04, 0xF0, 0x02, 0x9D, 0xCC, 0x90,
-0x8A, 0xAF, 0x12, 0x97, 0x5E, 0x7D, 0x08, 0xE4,
-0xFF, 0x02, 0x04, 0x7E, 0x90, 0x9C, 0x0E, 0x12,
-0x82, 0x27, 0xE4, 0x90, 0x9C, 0x11, 0x22, 0x90,
-0x98, 0x20, 0xE0, 0x30, 0xE0, 0x34, 0x12, 0xB3,
-0x4A, 0x70, 0x2F, 0x90, 0x9C, 0x9D, 0xE0, 0x04,
-0xF0, 0xE0, 0xB4, 0x0A, 0x0B, 0x90, 0x98, 0x22,
-0xE0, 0x04, 0xF0, 0xE4, 0x90, 0x9C, 0x9D, 0xF0,
-0x90, 0x98, 0x22, 0xE0, 0xFF, 0x90, 0x98, 0x21,
-0xE0, 0xD3, 0x9F, 0x50, 0x0D, 0x90, 0x98, 0x23,
-0xE0, 0x70, 0x07, 0xE4, 0x90, 0x98, 0x22, 0xF0,
-0x31, 0xE2, 0x22, 0x90, 0x98, 0x20, 0xE0, 0x54,
-0xFE, 0xF0, 0x54, 0x7F, 0xF0, 0x54, 0xFB, 0xF0,
-0xA3, 0x74, 0x0A, 0x02, 0xA7, 0xDE, 0x51, 0x82,
-0x90, 0x98, 0x20, 0xE0, 0x54, 0xFE, 0x4E, 0xFE,
-0xF0, 0xEF, 0x54, 0x04, 0xFF, 0xEE, 0x54, 0xFB,
-0x4F, 0xF0, 0x12, 0x02, 0x06, 0xC3, 0x13, 0x30,
-0xE0, 0x07, 0x12, 0x87, 0x9D, 0x90, 0x98, 0x21,
-0xF0, 0x22, 0x12, 0x02, 0x06, 0xFF, 0x54, 0x01,
-0xFE, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x02, 0x09, 0xE0, 0xFD, 0x51, 0x82,
-0x90, 0x93, 0x04, 0x91, 0x94, 0xFC, 0xEF, 0x54,
-0xFB, 0x4C, 0xFF, 0x90, 0x93, 0x04, 0x71, 0x41,
-0x54, 0x10, 0xFE, 0xEF, 0x54, 0xEF, 0x4E, 0x90,
-0x93, 0x04, 0x12, 0x87, 0x9C, 0xFF, 0xED, 0x2F,
-0x90, 0x93, 0x05, 0x12, 0x87, 0xA3, 0xFF, 0xED,
-0x2F, 0x90, 0x93, 0x06, 0x12, 0x97, 0xCC, 0xFF,
-0xAE, 0x05, 0xED, 0x2F, 0x90, 0x93, 0x07, 0xF0,
-0x90, 0x93, 0x04, 0xE0, 0xFF, 0x20, 0xE0, 0x08,
-0x13, 0x13, 0x13, 0x54, 0x1F, 0x30, 0xE0, 0x09,
-0x90, 0x06, 0x31, 0xE0, 0x44, 0x40, 0xF0, 0x91,
-0xE1, 0x90, 0x93, 0x04, 0xE0, 0xFF, 0x30, 0xE0,
-0x3C, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x01, 0xF0,
-0x90, 0x06, 0x09, 0xE0, 0x54, 0xFE, 0x12, 0xD7,
-0x7B, 0xEF, 0x13, 0x13, 0x54, 0x3F, 0x30, 0xE0,
-0x0A, 0x12, 0xD7, 0x64, 0xF0, 0x90, 0x9A, 0xF9,
-0x74, 0x01, 0xF0, 0x7D, 0x08, 0xE4, 0xFF, 0x12,
-0x7C, 0x74, 0x12, 0xA7, 0x47, 0x20, 0xE0, 0x0D,
-0x90, 0x9C, 0x55, 0x12, 0x04, 0x3D, 0x00, 0x00,
-0x27, 0x10, 0x12, 0xAD, 0x63, 0x12, 0xA7, 0x47,
-0x30, 0xE0, 0x09, 0x90, 0x06, 0x32, 0xE0, 0x44,
-0x02, 0xF0, 0xB1, 0x34, 0xD0, 0xD0, 0x92, 0xAF,
-0x22, 0xF0, 0xEE, 0x54, 0x08, 0xFE, 0xEF, 0x54,
-0xF7, 0x4E, 0xFF, 0xF0, 0x02, 0x02, 0x06, 0xD3,
-0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x51, 0x82,
-0x90, 0x93, 0x24, 0x91, 0x94, 0xFD, 0xEF, 0x54,
-0xFB, 0x4D, 0xFF, 0x90, 0x93, 0x24, 0x71, 0x41,
-0xF1, 0x76, 0x90, 0x93, 0x24, 0xF1, 0x6D, 0x71,
-0x49, 0x91, 0x83, 0x4D, 0xFF, 0x90, 0x93, 0x24,
-0xF1, 0x80, 0x12, 0x87, 0xA3, 0xFF, 0x54, 0x01,
-0xFE, 0x90, 0x93, 0x26, 0xE0, 0x54, 0xFE, 0x4E,
-0x12, 0x87, 0x9C, 0xFE, 0x54, 0x01, 0xFD, 0x90,
-0x93, 0x25, 0xE0, 0x54, 0xFE, 0x4D, 0xFD, 0xF0,
-0xEE, 0x54, 0x04, 0xFE, 0xED, 0x54, 0xFB, 0x4E,
-0xFE, 0x12, 0x87, 0x9C, 0xFD, 0x54, 0x08, 0xFC,
-0xEE, 0x54, 0xF7, 0x4C, 0xFE, 0x90, 0x93, 0x25,
-0xF0, 0xED, 0x54, 0x10, 0xFD, 0xEE, 0x54, 0xEF,
-0x4D, 0xFE, 0x12, 0x87, 0x9C, 0xFD, 0x54, 0x20,
-0xFC, 0xEE, 0x54, 0xDF, 0x4C, 0x90, 0x93, 0x25,
-0xF0, 0xEF, 0x54, 0x10, 0xFF, 0xA3, 0xE0, 0x54,
-0xEF, 0x4F, 0xFF, 0x12, 0x87, 0xA3, 0xFE, 0x54,
-0x20, 0xFC, 0xEF, 0x54, 0xDF, 0x4C, 0x90, 0x93,
-0x26, 0xF0, 0xED, 0x54, 0x02, 0xFF, 0x90, 0x93,
-0x25, 0xE0, 0x54, 0xFD, 0x4F, 0xFF, 0x12, 0x87,
-0x9C, 0x91, 0x84, 0x4D, 0x90, 0x93, 0x25, 0x12,
-0x97, 0xCC, 0x54, 0x07, 0xFF, 0x90, 0x93, 0x27,
-0xE0, 0x54, 0xF8, 0x4F, 0xF0, 0xEE, 0x54, 0x40,
-0xFF, 0x90, 0x93, 0x26, 0xE0, 0x54, 0xBF, 0x4F,
-0x12, 0xCF, 0x1B, 0xD1, 0x95, 0x90, 0x93, 0x24,
-0xE0, 0xC3, 0x13, 0x54, 0x01, 0xFF, 0xF1, 0x95,
-0x90, 0x93, 0x24, 0xE0, 0x13, 0x13, 0x54, 0x01,
-0xFF, 0xF1, 0xA1, 0x90, 0x93, 0x25, 0x12, 0xB2,
-0xDA, 0x30, 0xE0, 0x1F, 0x90, 0x93, 0x24, 0x12,
-0x89, 0xF1, 0x20, 0xE0, 0x0E, 0xEF, 0xC3, 0x13,
-0x20, 0xE0, 0x08, 0xE0, 0x13, 0x13, 0x54, 0x3F,
-0x30, 0xE0, 0x04, 0x7F, 0x01, 0x80, 0x0E, 0x7F,
-0x00, 0x80, 0x0A, 0x90, 0x93, 0x24, 0xE0, 0x13,
-0x13, 0x13, 0x54, 0x01, 0xFF, 0x91, 0xAB, 0x90,
-0x93, 0x24, 0xE0, 0xC4, 0x54, 0x01, 0xFF, 0xF1,
-0xAD, 0x90, 0x93, 0x24, 0xE0, 0xC4, 0x13, 0x13,
-0x54, 0x01, 0xFF, 0x91, 0x8B, 0x90, 0x93, 0x24,
-0xE0, 0x54, 0x01, 0xFF, 0xD1, 0x9D, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xFE, 0x54, 0x40, 0xFD, 0xEF,
-0x54, 0xBF, 0x22, 0xEF, 0x60, 0x05, 0xB1, 0xD2,
-0x12, 0xCD, 0x16, 0x22, 0xE0, 0x54, 0xFE, 0x4E,
-0xFE, 0xF0, 0xEF, 0x54, 0x02, 0xFF, 0xEE, 0x54,
-0xFD, 0x4F, 0xFF, 0xF0, 0x12, 0x02, 0x06, 0xFE,
-0x54, 0x04, 0x22, 0xE4, 0xFD, 0xFC, 0xEF, 0x60,
-0x2F, 0x90, 0x98, 0x0F, 0xD1, 0x7F, 0xF1, 0x8A,
-0x90, 0x99, 0x85, 0x12, 0x82, 0x27, 0x90, 0x99,
-0x85, 0x12, 0x9F, 0x04, 0x75, 0x48, 0x40, 0x7B,
-0x01, 0x7A, 0x93, 0x79, 0xF9, 0x12, 0x69, 0xF5,
-0x12, 0xCF, 0x72, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
-0xD8, 0xF9, 0x12, 0xCF, 0xDF, 0x12, 0x54, 0x1E,
-0x22, 0x90, 0x93, 0x06, 0xB1, 0xBC, 0x12, 0xCD,
-0xE1, 0xE0, 0x90, 0x9A, 0xE1, 0xF0, 0x74, 0x01,
-0x2F, 0x12, 0xCF, 0x6A, 0xE0, 0x90, 0x9A, 0xE2,
-0xB1, 0xC5, 0x90, 0x9A, 0xE3, 0xF0, 0x74, 0x03,
-0x2F, 0xD1, 0x5B, 0x90, 0x9A, 0xE4, 0xD1, 0x89,
-0xE0, 0x90, 0x9A, 0xE5, 0xF0, 0x74, 0x05, 0x2F,
-0x12, 0xCF, 0xD7, 0xE0, 0x90, 0x9A, 0xE6, 0xF0,
-0x74, 0x06, 0x2F, 0xD1, 0x6D, 0x90, 0x9A, 0xE7,
-0xF0, 0x74, 0x07, 0x2F, 0xD1, 0x76, 0x90, 0x9A,
-0xE8, 0xF0, 0x74, 0x08, 0x2F, 0xD1, 0x64, 0x90,
-0x9A, 0xE9, 0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x93, 0x07, 0xB1, 0xBC,
-0x12, 0xCD, 0xE1, 0xE0, 0x90, 0x9A, 0xFA, 0xF0,
-0x74, 0x01, 0x2F, 0x12, 0xCF, 0x6A, 0xE0, 0x90,
-0x9B, 0x1B, 0xB1, 0xC5, 0x90, 0x9B, 0x3C, 0xF0,
-0xEF, 0x24, 0x20, 0x90, 0x99, 0x85, 0xF0, 0x12,
-0x9F, 0x82, 0x90, 0x9A, 0xFA, 0xE0, 0xF5, 0x48,
-0x7B, 0x01, 0x7A, 0x9A, 0x79, 0xFB, 0x12, 0x69,
-0xF5, 0x90, 0x9A, 0xFA, 0xB1, 0xB3, 0x12, 0x9F,
-0x81, 0x90, 0x9B, 0x1B, 0xE0, 0xF5, 0x48, 0x7B,
-0x01, 0x7A, 0x9B, 0x79, 0x1C, 0x12, 0x69, 0xF5,
-0x90, 0x9B, 0x1B, 0xB1, 0xB3, 0x12, 0x9F, 0x81,
-0x90, 0x9B, 0x3C, 0xE0, 0xF5, 0x48, 0x7B, 0x01,
-0x7A, 0x9B, 0x79, 0x3D, 0x12, 0x69, 0xF5, 0xE4,
-0xFF, 0x90, 0x9A, 0xFA, 0xE0, 0xFE, 0xEF, 0xC3,
-0x9E, 0x50, 0x03, 0x0F, 0x80, 0xF3, 0xD0, 0xD0,
-0x92, 0xAF, 0x22, 0xE0, 0xFF, 0x90, 0x99, 0x85,
-0xE0, 0x2F, 0xF0, 0x22, 0xE0, 0xFF, 0x12, 0x7B,
-0x07, 0x74, 0x00, 0x2F, 0x22, 0xF0, 0x74, 0x02,
-0x2F, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
-0xE0, 0x22, 0xE4, 0xFD, 0xFC, 0x90, 0x98, 0x15,
-0xD1, 0x7F, 0xAB, 0x05, 0x74, 0x01, 0x2B, 0x12,
-0xCF, 0x6A, 0xE0, 0xFE, 0x74, 0x00, 0x2B, 0x12,
-0xCD, 0xE1, 0x12, 0xD7, 0xB9, 0x3E, 0x90, 0x95,
-0x67, 0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x03, 0x2B,
-0xD1, 0x5B, 0xFE, 0x74, 0x02, 0x2B, 0xB1, 0xC9,
-0x24, 0x00, 0xFF, 0xEA, 0x3E, 0x90, 0x95, 0x69,
-0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x05, 0x2B, 0x12,
-0xCF, 0xD7, 0xE0, 0xFE, 0x74, 0x04, 0x2B, 0xD1,
-0x8D, 0xE0, 0x24, 0x00, 0xFF, 0xEA, 0x3E, 0x90,
-0x95, 0x6B, 0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x07,
-0x2B, 0xD1, 0x76, 0xFE, 0x74, 0x06, 0x2B, 0xD1,
-0x6D, 0x24, 0x00, 0xFF, 0xEA, 0x3E, 0x90, 0x95,
-0x6D, 0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x09, 0x2B,
-0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0,
-0xFE, 0x74, 0x08, 0x2B, 0xD1, 0x64, 0x24, 0x00,
-0xFF, 0xEC, 0x3E, 0x90, 0x95, 0x6F, 0xF0, 0xA3,
-0xEF, 0xF0, 0x22, 0xF5, 0x82, 0xE4, 0x34, 0xFC,
-0xF5, 0x83, 0xE0, 0x22, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0xF5, 0x83, 0xE0, 0x22, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0x22, 0xE0,
-0xFF, 0x12, 0x7B, 0x07, 0x7C, 0x00, 0xAD, 0x07,
-0x22, 0xF0, 0x74, 0x04, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0xFC, 0xF5, 0x83, 0x22, 0x90, 0x88, 0x27,
-0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xEF, 0x70, 0x02,
-0xE1, 0x52, 0x90, 0x06, 0x0F, 0xE0, 0x20, 0xE6,
-0x1D, 0x90, 0x98, 0x40, 0xE0, 0x54, 0xFE, 0xF0,
-0x90, 0x06, 0x0F, 0xE0, 0x20, 0xE5, 0x07, 0x90,
-0x01, 0x0C, 0xE0, 0x30, 0xE1, 0x45, 0x90, 0x01,
-0xC7, 0x74, 0x44, 0xF0, 0x80, 0xFE, 0x90, 0x98,
-0x40, 0xE0, 0x44, 0x01, 0xF0, 0x90, 0x06, 0x0F,
-0xE0, 0x30, 0xE5, 0x10, 0x90, 0x01, 0x0C, 0xE0,
-0x20, 0xE1, 0x09, 0x90, 0x98, 0x40, 0xE0, 0x54,
-0xFD, 0xF0, 0x80, 0x1F, 0x90, 0x06, 0x0F, 0xE0,
-0x20, 0xE5, 0x10, 0x90, 0x01, 0x0C, 0xE0, 0x30,
-0xE1, 0x09, 0x90, 0x98, 0x40, 0xE0, 0x44, 0x02,
-0xF0, 0x80, 0x08, 0x90, 0x01, 0xC7, 0x74, 0x44,
-0xF0, 0x80, 0xFE, 0x90, 0x98, 0x0B, 0xE0, 0xFF,
-0x60, 0x02, 0xF1, 0xBB, 0x90, 0x01, 0xC7, 0xE4,
-0x12, 0xCF, 0x1B, 0xD1, 0x95, 0x90, 0x06, 0x09,
-0xE0, 0x54, 0xFE, 0xF0, 0x7B, 0x35, 0x7D, 0xFF,
-0x7F, 0xFF, 0x12, 0x9C, 0x0E, 0x90, 0x8A, 0xEF,
-0x12, 0x91, 0xBD, 0x12, 0xD7, 0x64, 0xF0, 0x12,
-0xE0, 0xA4, 0x12, 0xAF, 0xDE, 0x90, 0x86, 0x0C,
-0x12, 0x91, 0xBD, 0xE4, 0xFB, 0xFD, 0x7F, 0xFF,
-0x12, 0x9C, 0x0E, 0x12, 0xEF, 0xB2, 0x90, 0x01,
-0x34, 0x74, 0x08, 0xF0, 0xFD, 0xE4, 0xFF, 0x02,
-0x7C, 0x74, 0x7D, 0x08, 0xE4, 0xFF, 0x12, 0x7C,
-0x7E, 0x90, 0x06, 0x90, 0xE0, 0x54, 0xF0, 0xF0,
-0x12, 0xD6, 0xBF, 0xF0, 0x12, 0xE1, 0x6C, 0x12,
-0xAA, 0x1B, 0x02, 0xA9, 0x1F, 0xF0, 0xEE, 0x54,
-0x20, 0xFE, 0xEF, 0x54, 0xDF, 0x22, 0xFE, 0x54,
-0x10, 0xFD, 0xEF, 0x54, 0xEF, 0x4D, 0xFF, 0x22,
-0xF0, 0xEE, 0x54, 0x80, 0xFE, 0xEF, 0x54, 0x7F,
-0x4E, 0x22, 0x74, 0x00, 0x2F, 0xF9, 0xE4, 0x34,
-0xFC, 0xFA, 0x7B, 0x01, 0x22, 0xEF, 0x60, 0x08,
-0x90, 0x98, 0x0C, 0xE0, 0xFF, 0x12, 0x9F, 0x1B,
-0x22, 0xEF, 0x60, 0x08, 0x90, 0x98, 0x11, 0xE0,
-0xFF, 0x12, 0x9F, 0xCE, 0x22, 0xEF, 0x60, 0x0A,
-0x90, 0x06, 0x31, 0xE0, 0x44, 0x80, 0xF0, 0x12,
-0xB5, 0x63, 0x22, 0xF1, 0xCC, 0x12, 0x9F, 0x84,
-0x75, 0x48, 0x08, 0x7B, 0x01, 0x7A, 0x95, 0x79,
-0x33, 0x02, 0x69, 0xF5, 0x12, 0x7B, 0x07, 0x7E,
-0x00, 0x74, 0x00, 0x2F, 0x22, 0xE0, 0xFE, 0xA3,
+0x88, 0xC8, 0x90, 0x07, 0x78, 0xE0, 0x90, 0x88,
+0xBD, 0xF0, 0x90, 0x9C, 0xE3, 0xE0, 0xFD, 0x70,
+0x02, 0x80, 0x1C, 0xED, 0xB4, 0x01, 0x06, 0x71,
+0xA3, 0x44, 0x20, 0xF0, 0x22, 0x90, 0x9C, 0xE3,
+0xE0, 0xFD, 0xB4, 0x02, 0x06, 0x71, 0xA3, 0x44,
+0x60, 0xF0, 0x22, 0xED, 0xB4, 0x03, 0x03, 0x71,
+0xA3, 0xF0, 0x22, 0x90, 0x88, 0xB8, 0xE0, 0x54,
+0x1F, 0x22, 0x90, 0x9A, 0x62, 0x12, 0x82, 0x27,
+0x90, 0x9A, 0x5E, 0x12, 0x82, 0x1E, 0x90, 0x9A,
+0x65, 0xB1, 0xA7, 0xE0, 0x24, 0xFF, 0xFF, 0xE4,
+0x34, 0xFF, 0xFE, 0x90, 0x9A, 0x63, 0x8F, 0xF0,
+0x12, 0x02, 0xE7, 0x90, 0x9A, 0x66, 0xEE, 0x8F,
+0xF0, 0x12, 0x02, 0xE7, 0x90, 0x9A, 0x61, 0xE0,
+0xD3, 0x94, 0x00, 0x40, 0x28, 0x90, 0x9A, 0x65,
+0x12, 0x8F, 0x6D, 0xFF, 0x90, 0x9A, 0x62, 0x12,
+0x8F, 0x6D, 0xFE, 0x6F, 0x60, 0x05, 0xC3, 0xEE,
+0x9F, 0xFF, 0x22, 0x90, 0x9A, 0x63, 0x91, 0x08,
+0x90, 0x9A, 0x66, 0x91, 0x08, 0x90, 0x9A, 0x61,
+0xE0, 0x14, 0xF0, 0x80, 0xCF, 0x7F, 0x00, 0x22,
+0x74, 0xFF, 0xF5, 0xF0, 0x02, 0x02, 0xE7, 0x90,
+0x9A, 0x42, 0x12, 0x82, 0x27, 0x90, 0x9A, 0x45,
+0x12, 0x82, 0x1E, 0x12, 0x87, 0xA4, 0x90, 0x9A,
+0x4E, 0x12, 0x9F, 0x97, 0x12, 0x87, 0xA4, 0x90,
+0x9A, 0x4F, 0xF0, 0x90, 0x9A, 0x45, 0x12, 0x8B,
+0xE0, 0x75, 0x48, 0x03, 0x7B, 0x01, 0x7A, 0x9A,
+0x79, 0x48, 0x12, 0x69, 0xF5, 0x90, 0x9A, 0x42,
+0x12, 0x8B, 0xE0, 0x75, 0x48, 0x03, 0x7B, 0x01,
+0x7A, 0x9A, 0x79, 0x4B, 0x12, 0x69, 0xF5, 0x7B,
+0x01, 0x7A, 0x9A, 0x79, 0x4B, 0xB1, 0xA4, 0x74,
+0x03, 0xF0, 0x7A, 0x9A, 0x79, 0x48, 0xB1, 0xAE,
+0x40, 0x15, 0x75, 0x45, 0x01, 0x75, 0x46, 0x9A,
+0x75, 0x47, 0x48, 0x75, 0x48, 0x03, 0x12, 0x9F,
+0x98, 0x12, 0x69, 0xF5, 0x7F, 0x01, 0x22, 0x7F,
+0x00, 0x22, 0x90, 0x9A, 0x34, 0x12, 0x82, 0x27,
+0x90, 0x9A, 0x37, 0xED, 0xF0, 0x90, 0x9A, 0x39,
+0x74, 0x01, 0xF0, 0x12, 0x9F, 0x90, 0xFB, 0x7A,
+0x9A, 0x79, 0x3A, 0x12, 0x04, 0x80, 0x90, 0x9A,
+0x37, 0xE0, 0x20, 0xE0, 0x1B, 0xA3, 0xE0, 0xB4,
+0x01, 0x13, 0x90, 0x98, 0x35, 0xE0, 0x90, 0x95,
+0x64, 0xF0, 0x75, 0x45, 0x01, 0x75, 0x46, 0x95,
+0x75, 0x47, 0x6B, 0x80, 0x46, 0x7F, 0x00, 0x22,
+0x90, 0x98, 0x36, 0xE0, 0x90, 0x95, 0x64, 0xF0,
+0x90, 0x95, 0x63, 0xE0, 0x14, 0x60, 0x15, 0x14,
+0x60, 0x1D, 0x14, 0x60, 0x25, 0x24, 0x03, 0x70,
+0x32, 0x75, 0x45, 0x01, 0x75, 0x46, 0x95, 0x75,
+0x47, 0x73, 0x80, 0x1F, 0x75, 0x45, 0x01, 0x75,
+0x46, 0x95, 0x75, 0x47, 0x7B, 0x80, 0x14, 0x75,
+0x45, 0x01, 0x75, 0x46, 0x95, 0x75, 0x47, 0x83,
+0x80, 0x09, 0x75, 0x45, 0x01, 0x75, 0x46, 0x95,
+0x75, 0x47, 0x8B, 0x75, 0x48, 0x08, 0xB1, 0x91,
+0x12, 0x69, 0xF5, 0x90, 0x95, 0x64, 0xE0, 0x24,
+0xFE, 0x60, 0x16, 0x24, 0xFE, 0x60, 0x12, 0x14,
+0x60, 0x07, 0x14, 0x60, 0x04, 0x24, 0x05, 0x70,
+0x1C, 0xB1, 0x98, 0xB1, 0x91, 0x91, 0x0F, 0x80,
+0x0F, 0xB1, 0x98, 0x90, 0x95, 0x64, 0xE0, 0x90,
+0x9A, 0x48, 0xF0, 0xB1, 0x91, 0x12, 0x9D, 0xD9,
+0x90, 0x9A, 0x39, 0xEF, 0xF0, 0x90, 0x9A, 0x39,
+0xE0, 0x60, 0x41, 0x90, 0x9A, 0x37, 0xE0, 0x20,
+0xE0, 0x08, 0xB1, 0x82, 0x7A, 0x95, 0x79, 0x6B,
+0x80, 0x2F, 0x90, 0x95, 0x63, 0xE0, 0x14, 0x60,
+0x12, 0x14, 0x60, 0x17, 0x14, 0x60, 0x1C, 0x24,
+0x03, 0x70, 0x21, 0xB1, 0x82, 0x7A, 0x95, 0x79,
+0x73, 0x80, 0x16, 0xB1, 0x82, 0x7A, 0x95, 0x79,
+0x7B, 0x80, 0x0E, 0xB1, 0x82, 0x7A, 0x95, 0x79,
+0x83, 0x80, 0x06, 0xB1, 0x82, 0x7A, 0x95, 0x79,
+0x8B, 0x12, 0x69, 0xF5, 0x90, 0x9A, 0x39, 0xE0,
+0xFF, 0x22, 0x75, 0x45, 0x01, 0x75, 0x46, 0x9A,
+0x75, 0x47, 0x3A, 0x75, 0x48, 0x08, 0x7B, 0x01,
+0x22, 0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x3A, 0x22,
+0x90, 0x9A, 0x34, 0x12, 0x82, 0x1E, 0x90, 0x9A,
+0x45, 0x02, 0x82, 0x27, 0x90, 0x9A, 0x5E, 0x12,
+0x82, 0x27, 0x90, 0x9A, 0x61, 0x22, 0x71, 0xAA,
+0xD3, 0xEF, 0x64, 0x80, 0x94, 0x80, 0x22, 0x90,
+0x98, 0x4C, 0xE0, 0x30, 0xE0, 0x35, 0x12, 0x97,
+0xE0, 0x70, 0x30, 0x90, 0x9C, 0xE5, 0xE0, 0x04,
+0xF0, 0xE0, 0xB4, 0x0A, 0x0B, 0x90, 0x98, 0x4E,
+0xE0, 0x04, 0xF0, 0xE4, 0x90, 0x9C, 0xE5, 0xF0,
+0x90, 0x98, 0x4E, 0xE0, 0xFF, 0x90, 0x98, 0x4D,
+0xE0, 0xD3, 0x9F, 0x50, 0x0E, 0x90, 0x98, 0x4F,
+0xE0, 0x70, 0x08, 0xE4, 0x90, 0x98, 0x4E, 0xF0,
+0x12, 0xB5, 0x2E, 0x22, 0x12, 0x02, 0x06, 0xFF,
+0x54, 0x01, 0xFE, 0x90, 0x98, 0x4C, 0xE0, 0x54,
+0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x04, 0xFF,
+0xEE, 0x54, 0xFB, 0x4F, 0xF0, 0x12, 0x02, 0x06,
+0xC3, 0x13, 0x30, 0xE0, 0x07, 0x12, 0x9C, 0x5A,
+0x90, 0x98, 0x4D, 0xF0, 0x22, 0xE0, 0xFE, 0xA3,
 0xE0, 0xFF, 0x90, 0x02, 0x84, 0xEF, 0xF0, 0xEE,
 0xA3, 0xF0, 0xA3, 0xE0, 0x44, 0x01, 0xF0, 0x22,
-0x7D, 0x07, 0xEF, 0x5D, 0xC3, 0x60, 0x0D, 0x12,
-0xE0, 0x03, 0xED, 0x5F, 0x24, 0x08, 0xFF, 0xE4,
-0x3E, 0xFE, 0x80, 0x06, 0x12, 0xE0, 0x03, 0xED,
-0x5F, 0xFF, 0x22, 0x74, 0xFF, 0x9D, 0xFD, 0x74,
-0xFF, 0x94, 0x00, 0x5E, 0xFE, 0x22, 0x12, 0xD7,
-0x85, 0x12, 0xCF, 0x24, 0x90, 0x99, 0x85, 0x11,
-0xF0, 0xF9, 0x90, 0x93, 0x24, 0xE0, 0x20, 0xE0,
-0x02, 0x01, 0xA3, 0xEC, 0xC3, 0x99, 0x50, 0x7B,
-0x90, 0x99, 0x85, 0xE0, 0xFA, 0xA3, 0xE0, 0xFB,
-0xEA, 0x90, 0xFD, 0x11, 0xF0, 0xAF, 0x03, 0xAD,
-0x07, 0x12, 0xD7, 0xA3, 0x3E, 0x54, 0x3F, 0x90,
-0x99, 0x87, 0x31, 0x3D, 0x30, 0xE0, 0x09, 0xC3,
-0x13, 0x20, 0xE0, 0x04, 0x31, 0x08, 0x80, 0x02,
-0x7E, 0x00, 0xEE, 0xFB, 0xEF, 0x24, 0x18, 0xFF,
-0xE4, 0x33, 0xCF, 0x2B, 0xCF, 0x34, 0x00, 0x90,
-0x99, 0x87, 0x8F, 0xF0, 0x12, 0x02, 0xE7, 0x90,
-0x99, 0x87, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x12,
-0xDF, 0xE8, 0x90, 0x99, 0x87, 0xEE, 0xF0, 0xA3,
-0xEF, 0xF0, 0x90, 0x99, 0x85, 0x11, 0xF9, 0xD3,
-0x90, 0x99, 0x86, 0xE0, 0x9F, 0x90, 0x99, 0x85,
-0xE0, 0x9E, 0x40, 0x0E, 0x31, 0x17, 0x90, 0x99,
-0x86, 0xE0, 0x9F, 0xF0, 0x90, 0x99, 0x85, 0xE0,
-0x9E, 0xF0, 0x90, 0x99, 0x85, 0x12, 0xDF, 0xD5,
-0x0C, 0x80, 0x80, 0x22, 0x31, 0x27, 0xAD, 0x07,
-0x90, 0x01, 0xC4, 0x74, 0xA4, 0xF0, 0x74, 0xE0,
-0xA3, 0xF0, 0xED, 0x64, 0x01, 0x60, 0x1E, 0x12,
-0x8F, 0xCA, 0xED, 0xB4, 0x02, 0x08, 0x90, 0x01,
-0xC7, 0x74, 0x40, 0xF0, 0x80, 0x0A, 0xED, 0xB4,
-0x04, 0x06, 0x90, 0x01, 0xC7, 0x74, 0x41, 0xF0,
-0x7F, 0x01, 0x02, 0xBC, 0x2E, 0x11, 0x0E, 0x90,
-0x02, 0x87, 0xE0, 0x70, 0xF8, 0x90, 0x06, 0x90,
-0xE0, 0x44, 0x02, 0xF0, 0x74, 0xA4, 0x04, 0x90,
-0x01, 0xC4, 0xF0, 0x74, 0xE0, 0xA3, 0xF0, 0x22,
-0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x02, 0x87, 0xE0,
-0x22, 0xEE, 0x8F, 0xF0, 0x12, 0x02, 0xE7, 0x90,
-0x88, 0x27, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0x74, 0x03, 0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB,
-0xF5, 0x83, 0xE0, 0x54, 0x03, 0xFE, 0x22, 0x90,
-0x88, 0x28, 0xE0, 0x24, 0x01, 0xFF, 0x90, 0x88,
-0x27, 0xE0, 0x34, 0x00, 0xFE, 0xC3, 0x22, 0x90,
-0x02, 0x86, 0xE0, 0x20, 0xE2, 0x03, 0x7F, 0x04,
-0x22, 0x90, 0x02, 0x86, 0xE0, 0x7F, 0x01, 0x20,
-0xE1, 0x02, 0x7F, 0x02, 0x22, 0xF0, 0xA3, 0xEF,
-0xF0, 0x74, 0x02, 0x2D, 0xF5, 0x82, 0xE4, 0x34,
-0xFB, 0xF5, 0x83, 0xE0, 0x54, 0x0F, 0x33, 0x33,
-0x33, 0x54, 0xF8, 0xFF, 0x90, 0x98, 0x40, 0xE0,
-0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
-0xE4, 0xFD, 0x7F, 0x8F, 0x12, 0x7B, 0x2E, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x31, 0x59, 0x90, 0x98,
-0x1A, 0xE0, 0xFF, 0x31, 0x96, 0x90, 0x01, 0x3F,
-0x74, 0x04, 0xF0, 0x90, 0x86, 0xB3, 0xE0, 0xFF,
-0xB4, 0x01, 0x07, 0x90, 0xFD, 0x00, 0xE0, 0x54,
-0xEF, 0xF0, 0xEF, 0xB4, 0x01, 0x07, 0x90, 0xFE,
-0x10, 0xE0, 0x54, 0xFB, 0xF0, 0x22, 0x90, 0x99,
-0x88, 0xEF, 0xF0, 0xE4, 0xFF, 0x74, 0x33, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0xE0,
-0xFE, 0x74, 0x84, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
-0x04, 0xF5, 0x83, 0xEE, 0xF0, 0x0F, 0xEF, 0xB4,
-0x08, 0xE3, 0x90, 0x95, 0x63, 0xE0, 0x90, 0x04,
-0x8C, 0xF0, 0x90, 0x95, 0x65, 0xE0, 0x90, 0x04,
-0x8D, 0xF0, 0x75, 0x45, 0x01, 0x75, 0x46, 0x94,
-0x75, 0x47, 0x42, 0x75, 0x48, 0x08, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x3B, 0x12, 0x69, 0xF5, 0x90,
-0x98, 0x1A, 0xE0, 0x60, 0x1A, 0x90, 0x99, 0x88,
-0x51, 0x00, 0x12, 0xDF, 0x8A, 0xC0, 0x03, 0x8B,
-0x45, 0x75, 0x46, 0x95, 0x75, 0x47, 0x33, 0x75,
-0x48, 0x34, 0xD0, 0x03, 0x12, 0x69, 0xF5, 0x22,
-0xE0, 0xFF, 0x12, 0x7B, 0x07, 0x7E, 0x00, 0x22,
-0x90, 0x98, 0x1D, 0x74, 0x06, 0xF0, 0x90, 0x98,
-0x1C, 0x74, 0x08, 0xF0, 0x90, 0x00, 0x4A, 0xE0,
-0x54, 0xFE, 0xF0, 0x90, 0x00, 0x4F, 0xE0, 0x44,
-0x40, 0xF0, 0x90, 0x00, 0x40, 0xE0, 0x44, 0x08,
-0xF0, 0x90, 0x93, 0x29, 0xE0, 0xC4, 0x13, 0x54,
-0x07, 0x90, 0x00, 0x65, 0x30, 0xE0, 0x06, 0xE0,
-0x44, 0x20, 0xF0, 0x80, 0x04, 0xE0, 0x54, 0xDF,
-0xF0, 0x12, 0xBD, 0xD0, 0xFB, 0x7D, 0x01, 0x02,
-0x96, 0x1A, 0x90, 0x93, 0x31, 0xE0, 0x30, 0xE0,
-0x0D, 0x90, 0x93, 0x29, 0xE0, 0xC4, 0x54, 0x0F,
-0x20, 0xE0, 0x03, 0x7F, 0x00, 0x22, 0x7F, 0x01,
-0x22, 0xEF, 0x90, 0x01, 0xC7, 0xB4, 0xA0, 0x05,
-0x74, 0x04, 0xF0, 0x80, 0x03, 0x74, 0x08, 0xF0,
-0x02, 0x8F, 0xCA, 0x12, 0x8F, 0xE5, 0xE4, 0x90,
-0x9A, 0x10, 0xF0, 0x90, 0x9A, 0x10, 0xE0, 0xFD,
-0xC3, 0x94, 0x06, 0x50, 0x1D, 0x90, 0x9A, 0x09,
-0xE0, 0x24, 0x10, 0x12, 0x8D, 0x88, 0xFE, 0x12,
-0x8F, 0xBA, 0x90, 0x9A, 0x10, 0xE0, 0x24, 0x0A,
-0xF5, 0x82, 0xE4, 0x34, 0x9A, 0x12, 0x8D, 0x73,
+0x90, 0x02, 0x86, 0xE0, 0x20, 0xE2, 0x03, 0x7F,
+0x04, 0x22, 0x90, 0x02, 0x86, 0xE0, 0x7F, 0x01,
+0x20, 0xE1, 0x02, 0x7F, 0x02, 0x22, 0xD3, 0x10,
+0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xF1, 0xAB, 0x20,
+0xE0, 0x0C, 0x90, 0x00, 0x04, 0xE0, 0x54, 0xF7,
+0xF0, 0x12, 0xCC, 0x60, 0xE1, 0xA6, 0x12, 0x8F,
+0x6A, 0xFF, 0x54, 0x01, 0xFE, 0x90, 0x93, 0x29,
+0x12, 0xD7, 0x4C, 0xFD, 0xEF, 0x54, 0xFB, 0x4D,
+0xFF, 0x90, 0x93, 0x29, 0x12, 0x9F, 0xE1, 0xF1,
+0xB4, 0xFF, 0x90, 0x93, 0x29, 0xF1, 0xC6, 0x12,
+0x9F, 0xE9, 0xF1, 0xBD, 0xFF, 0x90, 0x93, 0x29,
+0xF1, 0xCF, 0xF0, 0x12, 0x9C, 0x5A, 0x54, 0x80,
+0xFF, 0x90, 0x93, 0x2A, 0xE0, 0x54, 0x7F, 0x12,
+0x87, 0xD0, 0xFF, 0x54, 0x02, 0xFE, 0x90, 0x93,
+0x2D, 0xE0, 0x54, 0xFD, 0x4E, 0xFE, 0xF0, 0xEF,
+0x54, 0x08, 0xFF, 0xEE, 0x54, 0xF7, 0x4F, 0x12,
+0x87, 0x9B, 0x90, 0x93, 0x2E, 0x12, 0x87, 0xD1,
+0x54, 0x10, 0xFF, 0x90, 0x93, 0x2D, 0xE0, 0x54,
+0xEF, 0x4F, 0xF0, 0x12, 0x02, 0x06, 0xFF, 0x13,
+0x13, 0x54, 0x3F, 0x30, 0xE0, 0x07, 0x90, 0x06,
+0x90, 0xE0, 0x44, 0x04, 0xF0, 0x12, 0xAF, 0xEB,
+0x30, 0xE0, 0x07, 0x90, 0x06, 0x90, 0xE0, 0x44,
+0x08, 0xF0, 0x90, 0x93, 0x2E, 0xE0, 0x70, 0x02,
+0x04, 0xF0, 0x12, 0xC7, 0x95, 0x12, 0x87, 0xD2,
+0xC4, 0x54, 0x0F, 0x30, 0xE0, 0x0E, 0x7F, 0x05,
+0x12, 0x7B, 0x41, 0xEF, 0x54, 0x7F, 0xFD, 0x7F,
+0x05, 0x12, 0x7B, 0x2E, 0x90, 0x86, 0xB3, 0xE0,
+0xB4, 0x02, 0x06, 0x12, 0xA8, 0xA6, 0x20, 0xE0,
+0x66, 0x90, 0x99, 0xB1, 0x12, 0x9C, 0x57, 0x54,
+0x7F, 0xFF, 0x90, 0x93, 0x2A, 0xE0, 0x54, 0x80,
+0x12, 0x87, 0xE5, 0x54, 0x7F, 0xFF, 0x90, 0x93,
+0x2B, 0xE0, 0x54, 0x80, 0x12, 0x87, 0xA2, 0xFF,
+0x54, 0x01, 0xFE, 0x90, 0x93, 0x2C, 0xE0, 0x54,
+0xFE, 0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0xFE, 0xFF,
+0xEE, 0x54, 0x01, 0x12, 0x87, 0xD0, 0xFF, 0x54,
+0x04, 0xFE, 0x90, 0x93, 0x2D, 0xE0, 0x54, 0xFB,
+0x4E, 0xFE, 0xF0, 0xEF, 0x54, 0x01, 0xFF, 0xEE,
+0x54, 0xFE, 0x4F, 0xF0, 0x12, 0xBA, 0x1E, 0x54,
+0x07, 0x7D, 0x00, 0x20, 0xE0, 0x02, 0x7D, 0x01,
+0x12, 0xB8, 0xD1, 0x90, 0x93, 0x2D, 0xE0, 0xFF,
+0xC3, 0x13, 0x30, 0xE0, 0x02, 0xF1, 0xD9, 0x90,
+0x86, 0xB3, 0xE0, 0xB4, 0x01, 0x07, 0x90, 0xFE,
+0x10, 0xE0, 0x44, 0x04, 0xF0, 0x7E, 0x00, 0x7F,
+0x60, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x95, 0x79,
+0x33, 0x12, 0x04, 0x80, 0x90, 0x95, 0x63, 0x74,
+0x05, 0xF0, 0x12, 0x9F, 0x90, 0x7B, 0x01, 0x7A,
+0x94, 0x79, 0x42, 0x12, 0x04, 0x80, 0xD0, 0xD0,
+0x92, 0xAF, 0x22, 0x90, 0x99, 0xB1, 0x12, 0x82,
+0x27, 0x02, 0x02, 0x06, 0xFE, 0x54, 0x10, 0xFD,
+0xEF, 0x54, 0xEF, 0x4D, 0x22, 0xFE, 0x54, 0x40,
+0xFD, 0xEF, 0x54, 0xBF, 0x4D, 0x22, 0xF0, 0xEE,
+0x54, 0x20, 0xFE, 0xEF, 0x54, 0xDF, 0x22, 0xF0,
+0xEE, 0x54, 0x80, 0xFE, 0xEF, 0x54, 0x7F, 0x4E,
+0x22, 0x90, 0x98, 0x49, 0x74, 0x06, 0xF0, 0x90,
+0x98, 0x48, 0x74, 0x08, 0xF0, 0x90, 0x00, 0x4A,
+0xE0, 0x54, 0xFE, 0xF0, 0x90, 0x00, 0x4F, 0xE0,
+0x44, 0x40, 0xF0, 0x90, 0x00, 0x40, 0xE0, 0x44,
+0x08, 0xF0, 0x90, 0x93, 0x29, 0xE0, 0xC4, 0x13,
+0x54, 0x07, 0x90, 0x00, 0x65, 0x30, 0xE0, 0x06,
+0xE0, 0x44, 0x20, 0xF0, 0x80, 0x04, 0xE0, 0x54,
+0xDF, 0xF0, 0x12, 0xBF, 0xE6, 0xFB, 0x7D, 0x01,
+0x02, 0xBA, 0x4C, 0x90, 0x93, 0x31, 0xE0, 0x30,
+0xE0, 0x0D, 0x90, 0x93, 0x29, 0xE0, 0xC4, 0x54,
+0x0F, 0x20, 0xE0, 0x03, 0x7F, 0x00, 0x22, 0x7F,
+0x01, 0x22, 0xEF, 0x90, 0x01, 0xC7, 0xB4, 0xA0,
+0x05, 0x74, 0x04, 0xF0, 0x80, 0x03, 0x74, 0x08,
+0xF0, 0x02, 0xA7, 0x71, 0x11, 0x98, 0xE4, 0x90,
+0x9A, 0x3C, 0xF0, 0x90, 0x9A, 0x3C, 0xE0, 0xFD,
+0xC3, 0x94, 0x06, 0x50, 0x1D, 0x90, 0x9A, 0x35,
+0xE0, 0x24, 0x10, 0x12, 0xA6, 0x31, 0xFE, 0x12,
+0xAF, 0xC7, 0x90, 0x9A, 0x3C, 0xE0, 0x24, 0x36,
+0xF5, 0x82, 0xE4, 0x34, 0x9A, 0x12, 0xA4, 0x8B,
 0x80, 0xD9, 0x78, 0x38, 0x7C, 0x93, 0x7D, 0x01,
-0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x0A, 0x12, 0xA7,
-0xED, 0x7F, 0x00, 0x70, 0x02, 0x7F, 0x01, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xEF,
-0x20, 0xE0, 0x05, 0x90, 0x98, 0x09, 0x80, 0x03,
-0x90, 0x98, 0x0A, 0xE0, 0x90, 0x95, 0x64, 0xF0,
-0x90, 0x95, 0x64, 0xE0, 0x14, 0x60, 0x13, 0x14,
-0x60, 0x14, 0x24, 0xFE, 0x60, 0x10, 0x14, 0x60,
-0x09, 0x14, 0x60, 0x06, 0x24, 0x06, 0xE4, 0xFE,
-0x80, 0x06, 0x7E, 0x04, 0x80, 0x02, 0x7E, 0x08,
-0xAF, 0x06, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90,
-0x9C, 0x5D, 0xED, 0xF0, 0x90, 0x9C, 0x5A, 0x12,
-0x82, 0x27, 0xE4, 0x90, 0x9C, 0x5E, 0xF0, 0xA3,
-0xF0, 0x12, 0x02, 0x06, 0xFF, 0x12, 0x87, 0x9D,
-0xFD, 0x12, 0x95, 0xF5, 0xFB, 0xB1, 0x23, 0x90,
-0x9C, 0x5E, 0xEF, 0xF0, 0x90, 0x9C, 0x5A, 0x12,
-0x82, 0x1E, 0x12, 0x95, 0xF5, 0xFF, 0x51, 0xB8,
-0x90, 0x9C, 0x5F, 0xEF, 0xF0, 0x90, 0x95, 0x64,
-0xE0, 0x24, 0xFE, 0x60, 0x15, 0x24, 0xFE, 0x60,
-0x11, 0x14, 0x60, 0x07, 0x14, 0x60, 0x04, 0x24,
-0x05, 0x70, 0x42, 0x91, 0x8E, 0xFD, 0x91, 0x99,
-0x80, 0x0D, 0x91, 0x8E, 0xFD, 0x90, 0x95, 0x64,
-0xE0, 0x90, 0x9C, 0x3D, 0xF0, 0x71, 0x86, 0x90,
-0x9C, 0x5F, 0xE0, 0xFF, 0x90, 0x9C, 0x5A, 0x12,
-0x82, 0x1E, 0x90, 0x9C, 0x5E, 0xE0, 0x7C, 0x00,
-0x29, 0xF9, 0xEC, 0x3A, 0xFA, 0xC3, 0xE9, 0x9F,
-0xF9, 0xEA, 0x94, 0x00, 0xFA, 0x75, 0x45, 0x01,
-0x75, 0x46, 0x95, 0x75, 0x47, 0x33, 0xA3, 0xE0,
-0xF5, 0x48, 0x12, 0x69, 0xF5, 0x22, 0x90, 0x9C,
-0x39, 0x12, 0x82, 0x27, 0x90, 0x9C, 0x3D, 0xE0,
-0xFE, 0x64, 0x04, 0x70, 0x0D, 0x91, 0x75, 0x12,
-0x02, 0x06, 0x90, 0x9C, 0x3E, 0x12, 0x87, 0x9C,
-0x80, 0x11, 0xEE, 0x64, 0x02, 0x70, 0x32, 0x91,
-0x75, 0x12, 0x87, 0xA4, 0x90, 0x9C, 0x3E, 0xF0,
-0x12, 0x02, 0x06, 0x90, 0x9C, 0x3F, 0x12, 0x95,
-0xF4, 0x90, 0x9C, 0x40, 0xF1, 0xE3, 0x90, 0x9C,
-0x41, 0xF0, 0x90, 0x00, 0x06, 0x12, 0x02, 0x1F,
-0x90, 0x9C, 0x42, 0xF0, 0x90, 0x00, 0x07, 0x12,
-0x02, 0x1F, 0x90, 0x9C, 0x43, 0x12, 0x97, 0xCC,
-0xFF, 0xED, 0x70, 0x19, 0xFE, 0x91, 0x7B, 0xE0,
-0xB4, 0xFF, 0x06, 0x91, 0x7B, 0xE4, 0xF0, 0x80,
-0x07, 0x91, 0x7B, 0xE0, 0x04, 0xF0, 0x80, 0x05,
-0x0E, 0xEE, 0xB4, 0x06, 0xE8, 0x90, 0x9C, 0x3D,
-0xE0, 0xFE, 0xB4, 0x04, 0x18, 0xA3, 0xE0, 0xFD,
-0x91, 0x75, 0xED, 0x91, 0x86, 0xFD, 0x91, 0x75,
-0x90, 0x00, 0x01, 0xED, 0x12, 0x02, 0x5E, 0x90,
-0x00, 0x02, 0xE4, 0x80, 0x20, 0xEE, 0xB4, 0x02,
-0x1F, 0x90, 0x9C, 0x3F, 0x91, 0x73, 0xEE, 0x91,
-0x86, 0x44, 0x20, 0x54, 0x7F, 0x91, 0x74, 0x90,
-0x00, 0x01, 0xEE, 0x12, 0x02, 0x5E, 0x90, 0x9C,
-0x3E, 0xE0, 0x90, 0x00, 0x02, 0x12, 0x02, 0x5E,
-0x91, 0x75, 0xE9, 0x24, 0x03, 0xF9, 0xE4, 0x3A,
-0xFA, 0x12, 0x02, 0x06, 0x44, 0x20, 0x12, 0x02,
-0x4C, 0x90, 0x9C, 0x40, 0x91, 0x73, 0x90, 0x00,
-0x04, 0xEE, 0x12, 0x02, 0x5E, 0x90, 0x9C, 0x41,
-0xE0, 0x90, 0x00, 0x05, 0x12, 0x02, 0x5E, 0x90,
-0x9C, 0x42, 0xE0, 0x90, 0x00, 0x06, 0x12, 0x02,
-0x5E, 0x90, 0x9C, 0x43, 0xE0, 0x90, 0x00, 0x07,
-0x02, 0x02, 0x5E, 0xE0, 0xFE, 0x90, 0x9C, 0x39,
-0x02, 0x82, 0x1E, 0x74, 0x3E, 0x2E, 0xF5, 0x82,
-0xE4, 0x34, 0x9C, 0xF5, 0x83, 0x22, 0x12, 0x02,
-0x4C, 0x90, 0x9C, 0x3F, 0xE0, 0x22, 0x7B, 0x01,
-0x7A, 0x95, 0x79, 0x33, 0x90, 0x9C, 0x5D, 0xE0,
-0x22, 0x90, 0x9C, 0x49, 0xED, 0xF0, 0x90, 0x9C,
-0x46, 0x12, 0x82, 0x27, 0x12, 0x97, 0xCD, 0x90,
-0x9C, 0x4D, 0xF0, 0x90, 0x9C, 0x46, 0x12, 0x9F,
-0x04, 0x75, 0x48, 0x03, 0x7B, 0x01, 0x7A, 0x9C,
-0x79, 0x4A, 0x12, 0x69, 0xF5, 0x90, 0x9C, 0x49,
-0xE0, 0x70, 0x2E, 0xFF, 0x91, 0xF2, 0xE0, 0xB4,
-0xFF, 0x06, 0x91, 0xF2, 0xE4, 0xF0, 0x80, 0x07,
-0x91, 0xF2, 0xE0, 0x04, 0xF0, 0x80, 0x05, 0x0F,
-0xEF, 0xB4, 0x03, 0xE8, 0x75, 0x45, 0x01, 0x75,
-0x46, 0x9C, 0x75, 0x47, 0x4A, 0x75, 0x48, 0x03,
-0x90, 0x9C, 0x46, 0x12, 0x82, 0x1E, 0x12, 0x69,
-0xF5, 0x22, 0x74, 0x4A, 0x2F, 0xF5, 0x82, 0xE4,
-0x34, 0x9C, 0xF5, 0x83, 0x22, 0xA3, 0xE0, 0xFE,
-0x24, 0x28, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xE0, 0xFF, 0x74, 0x29, 0x2E, 0xF5, 0x82,
-0xE4, 0x34, 0xFC, 0xF5, 0x83, 0xE0, 0xFD, 0x74,
-0x2C, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5,
-0x83, 0xE0, 0xFB, 0xE4, 0xFE, 0xEF, 0x30, 0xE7,
-0x04, 0x7C, 0x02, 0x80, 0x02, 0xE4, 0xFC, 0xED,
-0x30, 0xE6, 0x08, 0xAF, 0x03, 0x51, 0xB8, 0xAE,
-0x07, 0x80, 0x02, 0xE4, 0xFE, 0xEC, 0x24, 0x18,
-0x2E, 0xFF, 0x22, 0xE4, 0x90, 0x9A, 0xD2, 0xF0,
-0xA3, 0xF0, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x20,
-0xF0, 0x12, 0x76, 0x9B, 0xEF, 0x64, 0x01, 0x70,
-0x73, 0x90, 0x98, 0x16, 0xE0, 0xFF, 0x90, 0x92,
-0x13, 0x74, 0x0D, 0xF0, 0x7B, 0x08, 0x7D, 0x01,
-0x12, 0x66, 0xDB, 0x90, 0x9A, 0xCF, 0xEE, 0xF0,
-0xA3, 0xEF, 0xF0, 0x90, 0x9A, 0xCF, 0x91, 0xFD,
-0x90, 0x9A, 0xD1, 0xEF, 0xF0, 0x90, 0x9A, 0xCF,
-0x12, 0x9F, 0xC2, 0xE4, 0xFD, 0x51, 0xF7, 0x90,
-0x9A, 0xD1, 0xE0, 0xFF, 0x90, 0x9A, 0xD0, 0xE0,
-0x2F, 0xFF, 0x90, 0x9A, 0xCF, 0xE0, 0x34, 0x00,
-0xCF, 0x24, 0x30, 0xCF, 0x34, 0x00, 0xFE, 0x90,
-0x9A, 0xD2, 0xF0, 0xA3, 0xEF, 0xF0, 0x12, 0xF1,
-0x58, 0xB1, 0xCD, 0x90, 0x98, 0x16, 0xE0, 0xFB,
-0xE4, 0xFF, 0xB1, 0xD6, 0xB1, 0xCD, 0x90, 0x98,
-0x12, 0xE0, 0xFB, 0x7F, 0x11, 0xB1, 0xD6, 0x12,
-0x9D, 0xB8, 0x90, 0x95, 0x79, 0xE4, 0x75, 0xF0,
-0x01, 0x12, 0x02, 0xE7, 0x22, 0x90, 0x9A, 0xD2,
-0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9C, 0x2C,
-0xEC, 0x12, 0x9F, 0xE6, 0xAA, 0x07, 0x90, 0x9C,
-0x33, 0x12, 0x04, 0x3D, 0x00, 0x00, 0x00, 0x00,
-0xF1, 0xD8, 0xEA, 0x24, 0xEF, 0x60, 0x39, 0x24,
-0xD7, 0x70, 0x02, 0xE1, 0x3E, 0x24, 0x3A, 0x60,
-0x02, 0xE1, 0x77, 0xF1, 0xAC, 0x24, 0x0A, 0xF1,
-0xCD, 0xFE, 0x12, 0xCD, 0xDF, 0xE4, 0x12, 0xCF,
-0x66, 0xE4, 0xF0, 0xFE, 0x74, 0x00, 0x2F, 0xF1,
-0xC5, 0x7D, 0x14, 0xF1, 0x95, 0x12, 0xCF, 0xD0,
-0xF1, 0xA0, 0x90, 0x90, 0xBE, 0x12, 0x04, 0x31,
-0x7D, 0x14, 0x7C, 0x00, 0xE4, 0xFF, 0xE1, 0x39,
-0x90, 0x9C, 0x2C, 0xE4, 0x75, 0xF0, 0x14, 0x12,
-0x02, 0xE7, 0x90, 0x9C, 0x2C, 0xA3, 0xE0, 0xFB,
-0xFF, 0x24, 0x06, 0xFC, 0xE4, 0x33, 0x90, 0x9C,
-0x37, 0xF0, 0xA3, 0xCC, 0xF0, 0x90, 0x9C, 0x37,
-0xA3, 0xE0, 0xFE, 0x12, 0xCD, 0xDF, 0xE4, 0x12,
-0xCF, 0x66, 0xE4, 0x12, 0xDE, 0x89, 0xE0, 0xFE,
-0xA9, 0x03, 0x74, 0x05, 0x29, 0x12, 0xCF, 0xD7,
-0x12, 0xCF, 0x24, 0xFE, 0x90, 0x9C, 0x31, 0xF0,
-0xA3, 0xEF, 0xF0, 0x90, 0x9C, 0x2C, 0xE0, 0xFC,
-0xA3, 0xE0, 0x2F, 0xFF, 0xEC, 0x3E, 0xFE, 0xD3,
-0xEF, 0x94, 0x00, 0xEE, 0x94, 0x01, 0x90, 0x9C,
-0x2C, 0x40, 0x6A, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0xE9, 0x7C, 0x00, 0x24, 0x00, 0xF9, 0xEC, 0x34,
-0xFC, 0xFA, 0x7B, 0x01, 0xC3, 0xE4, 0x9F, 0xFD,
-0x74, 0x01, 0x9E, 0xFC, 0xF1, 0x97, 0x90, 0x9C,
-0x2E, 0xE0, 0x24, 0x01, 0xFF, 0xE4, 0x33, 0xA2,
-0xE7, 0x13, 0xEF, 0x13, 0x90, 0xFD, 0x10, 0xF0,
-0xF1, 0xBF, 0xC0, 0x00, 0xC0, 0x01, 0xC0, 0x02,
-0xC0, 0x03, 0x7B, 0x01, 0x7A, 0xFC, 0x79, 0x00,
-0x90, 0x9C, 0x2C, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
-0xC3, 0xE4, 0x9F, 0xFF, 0x74, 0x01, 0x9E, 0xFE,
-0xF1, 0xB3, 0xE0, 0xC3, 0x9F, 0xFD, 0xEC, 0x9E,
-0xFC, 0x12, 0x45, 0xC2, 0xD0, 0x03, 0xD0, 0x02,
-0xD0, 0x01, 0xD0, 0x00, 0x12, 0x80, 0xC0, 0xF1,
-0x9A, 0xF1, 0xD8, 0x80, 0x0E, 0xA3, 0xE0, 0x7E,
-0x00, 0x24, 0x00, 0xF1, 0xC5, 0xF1, 0xB3, 0xE0,
-0xFD, 0xF1, 0x97, 0x90, 0x9C, 0x2C, 0x74, 0xFF,
-0x75, 0xF0, 0xEC, 0x12, 0x02, 0xE7, 0xF1, 0xAC,
-0x7E, 0x00, 0x24, 0x0C, 0xF9, 0xEE, 0x34, 0xFC,
-0xFA, 0x7B, 0x01, 0xC0, 0x02, 0xC0, 0x01, 0x74,
-0x10, 0x2F, 0xF9, 0xEE, 0x34, 0xFC, 0xFA, 0xF1,
-0xA0, 0x90, 0x90, 0xBE, 0x12, 0x04, 0x31, 0xF1,
-0xB3, 0xE0, 0xFD, 0xD0, 0x01, 0xD0, 0x02, 0x7F,
-0x11, 0x12, 0x3C, 0xD9, 0x80, 0x31, 0xF1, 0xAC,
-0x24, 0x2A, 0xF1, 0xCD, 0xFE, 0x12, 0xCD, 0xDF,
-0xE4, 0x12, 0xCF, 0x66, 0xE4, 0xF0, 0x12, 0xDF,
-0x8A, 0x7D, 0x48, 0xF1, 0x95, 0xF1, 0xA6, 0xF1,
-0xBA, 0x12, 0x80, 0xC0, 0xE4, 0xFD, 0xFC, 0xF1,
-0x9A, 0xF1, 0xA6, 0xF1, 0xBA, 0x12, 0x80, 0xC0,
-0xF1, 0x9A, 0xF1, 0xA6, 0x12, 0x03, 0xCD, 0x90,
-0x9C, 0x2F, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
-0x9C, 0x2F, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xEC,
-0xFF, 0x90, 0x9C, 0x37, 0xA3, 0xE0, 0xFE, 0x12,
-0xCD, 0xDF, 0xEF, 0x12, 0xCF, 0x66, 0xED, 0xF0,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x7C, 0x00, 0x12,
-0x45, 0xC2, 0x90, 0x9C, 0x33, 0x02, 0x04, 0x31,
-0x90, 0x90, 0xBB, 0x12, 0x82, 0x27, 0x90, 0x9C,
-0x33, 0x02, 0x04, 0xB8, 0x90, 0x9C, 0x2C, 0xA3,
-0xE0, 0xFF, 0x22, 0x90, 0x9C, 0x31, 0xE0, 0xFC,
-0xA3, 0x22, 0x78, 0x10, 0x12, 0x03, 0xEB, 0x90,
-0x9C, 0x33, 0x02, 0x82, 0x12, 0xF9, 0xEE, 0x34,
-0xFC, 0xFA, 0x7B, 0x01, 0x22, 0xFD, 0xE4, 0x33,
-0x90, 0x9C, 0x37, 0xF0, 0xA3, 0xED, 0xF0, 0x22,
-0x90, 0x9C, 0x2E, 0xE0, 0xC3, 0x13, 0x90, 0xFD,
-0x10, 0xF0, 0x22, 0xF0, 0x90, 0x00, 0x05, 0x02,
-0x02, 0x1F, 0x90, 0x9A, 0x35, 0x12, 0xE8, 0xF1,
-0x2F, 0xFF, 0xE4, 0x3E, 0xCF, 0x24, 0x06, 0xCF,
-0x34, 0x00, 0x12, 0x8B, 0xE7, 0xEF, 0x64, 0x86,
-0x70, 0x20, 0x90, 0x9A, 0x37, 0xE0, 0xFF, 0x90,
-0x9A, 0x36, 0xE0, 0x2F, 0xFF, 0x90, 0x9A, 0x35,
-0xE0, 0x34, 0x00, 0xCF, 0x24, 0x07, 0xCF, 0x34,
-0x00, 0x12, 0x8B, 0xE7, 0xBF, 0xDD, 0x03, 0x7F,
-0x01, 0x22, 0x7F, 0x00, 0x22, 0x90, 0x9A, 0x6F,
-0x12, 0x82, 0x27, 0x90, 0x9A, 0x72, 0x12, 0x9F,
-0x04, 0x75, 0x48, 0x10, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0xD1, 0x12, 0x69, 0xF5, 0x90, 0x9A, 0x6F,
-0x12, 0x9F, 0x04, 0x75, 0x48, 0x10, 0x7B, 0x01,
-0x7A, 0x93, 0x79, 0xE1, 0x12, 0x69, 0xF5, 0x90,
-0x9A, 0x75, 0x12, 0x04, 0xB8, 0x90, 0x93, 0xF1,
-0x12, 0x04, 0x31, 0x90, 0x9A, 0x79, 0xE0, 0x90,
-0x93, 0xF8, 0xF0, 0x22, 0x90, 0x9A, 0x0F, 0x11,
-0xF1, 0x78, 0x13, 0x7C, 0x9A, 0x7D, 0x01, 0x7B,
-0xFF, 0x7A, 0x80, 0x79, 0xBA, 0x7E, 0x00, 0x7F,
-0x04, 0x12, 0x01, 0xE0, 0x90, 0x9A, 0x11, 0xE0,
-0xFF, 0x90, 0x9A, 0x10, 0xE0, 0x2F, 0x12, 0xA7,
-0x75, 0x90, 0x9A, 0x17, 0xF0, 0xA3, 0xEF, 0xF0,
-0x24, 0x06, 0xFF, 0xE4, 0x3E, 0x12, 0x8B, 0xE7,
-0xEF, 0x64, 0x08, 0x70, 0x53, 0x90, 0x9A, 0x18,
-0xE0, 0x24, 0x07, 0xFF, 0x90, 0x9A, 0x17, 0xE0,
-0x34, 0x00, 0x12, 0x8B, 0xE7, 0xEF, 0x70, 0x40,
-0x90, 0x9A, 0x12, 0xF0, 0x90, 0x9A, 0x12, 0xE0,
-0xFF, 0xC3, 0x94, 0x04, 0x50, 0x25, 0x90, 0x9A,
-0x18, 0xE0, 0x24, 0x18, 0xFD, 0x90, 0x9A, 0x17,
-0xE0, 0x12, 0x8B, 0xDD, 0x90, 0x9A, 0x12, 0xE0,
-0x24, 0x13, 0xF5, 0x82, 0xE4, 0x34, 0x9A, 0xF5,
-0x83, 0xEF, 0xF0, 0x90, 0x9A, 0x12, 0xE0, 0x04,
-0xF0, 0x80, 0xD1, 0x78, 0x13, 0x7C, 0x9A, 0xD1,
-0x62, 0xEF, 0x7F, 0x00, 0x70, 0x02, 0x7F, 0x01,
-0x22, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0xA3, 0xED,
-0xF0, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0,
-0xD0, 0x90, 0x9A, 0x16, 0x11, 0xF1, 0x90, 0x9A,
-0x2E, 0x74, 0x18, 0xF0, 0x7E, 0x00, 0x7F, 0x80,
-0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x36,
-0x12, 0x04, 0x80, 0x90, 0x01, 0xC4, 0x74, 0xFA,
-0xF0, 0x74, 0xE8, 0xA3, 0xF0, 0x90, 0x98, 0x0E,
-0xE0, 0xFF, 0x12, 0x7B, 0x07, 0x90, 0x9A, 0x2D,
-0xEF, 0xF0, 0xF9, 0xE0, 0xFE, 0x24, 0x29, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83, 0x74, 0x41,
-0xF0, 0xEE, 0x24, 0x28, 0xFD, 0xE4, 0x33, 0xFC,
-0x90, 0x9A, 0x2E, 0xE0, 0x7A, 0x00, 0x2D, 0xFE,
-0xEA, 0x3C, 0x90, 0x9A, 0x32, 0xF0, 0xA3, 0xCE,
-0xF0, 0x74, 0x28, 0x29, 0x12, 0x9F, 0xC6, 0x90,
-0x9A, 0x18, 0xE0, 0xFD, 0x12, 0xE2, 0xF7, 0x91,
-0x1F, 0x90, 0x9A, 0x32, 0xE0, 0xFF, 0xA3, 0xE0,
-0x90, 0x9A, 0x30, 0xCF, 0xF0, 0xA3, 0xEF, 0xF0,
-0x90, 0x9A, 0x36, 0x74, 0x01, 0xF0, 0xA3, 0x74,
-0x03, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0x74, 0x5F,
-0xF0, 0x90, 0x9A, 0x32, 0xE4, 0x75, 0xF0, 0x04,
-0x12, 0x02, 0xE7, 0x90, 0x94, 0x3D, 0xE0, 0xFF,
-0x7E, 0x02, 0xB4, 0xFE, 0x02, 0x7E, 0xFE, 0x90,
-0x9A, 0x32, 0xA3, 0xE0, 0xFD, 0x12, 0xCD, 0xDF,
-0xEE, 0xF0, 0x74, 0x00, 0x2D, 0x12, 0xCD, 0xE1,
-0xE0, 0x90, 0x9A, 0x3A, 0xF0, 0x90, 0x9A, 0x32,
-0xE4, 0x75, 0xF0, 0x01, 0x12, 0x02, 0xE7, 0x90,
-0x95, 0x32, 0xE0, 0x90, 0x9A, 0x16, 0xB4, 0x01,
-0x0B, 0xE0, 0x44, 0x03, 0xFC, 0xA3, 0xE0, 0x44,
-0x10, 0xFD, 0x80, 0x09, 0xE0, 0x44, 0x03, 0xFC,
-0xA3, 0xE0, 0x44, 0x20, 0xFD, 0x90, 0x9A, 0x34,
-0xEC, 0xF0, 0xA3, 0xED, 0xF0, 0x90, 0x9A, 0x16,
-0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01, 0x90,
-0x9A, 0x32, 0x70, 0x18, 0xA3, 0xE0, 0xFE, 0x12,
-0xCD, 0xDF, 0x12, 0xCF, 0x64, 0x74, 0x01, 0xF0,
-0x90, 0x9A, 0x3B, 0x74, 0x03, 0xF0, 0xA3, 0x74,
-0x01, 0xF0, 0x80, 0x14, 0xA3, 0xE0, 0xFE, 0x12,
-0xCD, 0xDF, 0x12, 0xCF, 0x64, 0x74, 0x02, 0xF0,
-0x90, 0x9A, 0x3B, 0x04, 0xF0, 0xA3, 0x14, 0xF0,
-0x91, 0x54, 0xEF, 0x64, 0xFE, 0x90, 0x9A, 0x32,
-0x70, 0x1F, 0xA3, 0xE0, 0x24, 0x00, 0x12, 0xDF,
-0x8D, 0xC0, 0x03, 0x8B, 0x45, 0x91, 0x68, 0xD0,
-0x03, 0x12, 0x9F, 0xDF, 0x91, 0x68, 0x7B, 0x01,
-0x7A, 0x9A, 0x79, 0x3D, 0x12, 0x69, 0xF5, 0x80,
-0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x24, 0x00,
-0xF5, 0x82, 0x74, 0xFC, 0x3E, 0xF5, 0x83, 0xE4,
-0xF0, 0x74, 0x01, 0x2F, 0xF5, 0x82, 0x74, 0xFC,
-0x3E, 0xF5, 0x83, 0xE4, 0xF0, 0x90, 0x9A, 0x3D,
-0xF0, 0xA3, 0xF0, 0x91, 0x54, 0xE4, 0x90, 0x9A,
-0x2F, 0xF0, 0x91, 0x72, 0xFE, 0x90, 0x9A, 0x32,
-0xA3, 0xE0, 0xFD, 0xEF, 0x2D, 0x12, 0xCD, 0xDF,
-0xEE, 0xF0, 0x91, 0x72, 0xFE, 0x74, 0x3F, 0x2F,
-0xF5, 0x82, 0xE4, 0x34, 0x9A, 0xF5, 0x83, 0xEE,
-0x91, 0x18, 0xF0, 0xE0, 0xB4, 0x08, 0xDB, 0x91,
-0x29, 0x90, 0x9A, 0x32, 0xD1, 0x53, 0x90, 0x9A,
-0x32, 0xD1, 0x4C, 0x91, 0x1F, 0xE4, 0x90, 0x9A,
-0xB9, 0xF0, 0xE4, 0x90, 0x9A, 0x2F, 0xF0, 0x91,
-0x4B, 0x50, 0x10, 0x91, 0x82, 0xA3, 0x91, 0x11,
-0x91, 0x5E, 0x12, 0xCD, 0xDE, 0xE4, 0x91, 0x18,
-0xF0, 0x80, 0xEC, 0x12, 0xBF, 0xE0, 0x90, 0x06,
-0x31, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0x98, 0x0F,
-0xE0, 0xFD, 0x12, 0xCF, 0x7D, 0xCE, 0xC3, 0x13,
-0xCE, 0x13, 0xD8, 0xF9, 0x12, 0xCF, 0x4E, 0xED,
-0xFF, 0x90, 0x98, 0x0E, 0x12, 0xCF, 0x58, 0xC3,
-0x33, 0xCE, 0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90,
-0x9A, 0x2E, 0xE0, 0x7C, 0x00, 0x2F, 0xFF, 0xEC,
-0x3E, 0xCF, 0x24, 0x38, 0xCF, 0x34, 0x00, 0xFE,
-0x90, 0x92, 0x06, 0x74, 0x10, 0xF0, 0x7B, 0x63,
-0xE4, 0xFD, 0x12, 0x71, 0xD4, 0x90, 0x9A, 0x16,
-0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01, 0x7B,
-0x01, 0x7A, 0x9A, 0x79, 0x36, 0x70, 0x15, 0x90,
-0x91, 0xA0, 0x91, 0x43, 0x90, 0x91, 0xA3, 0x12,
-0x82, 0x27, 0x90, 0x91, 0xA6, 0x91, 0x3B, 0x12,
-0x6F, 0x34, 0x80, 0x13, 0x90, 0x91, 0x96, 0x91,
-0x43, 0x90, 0x91, 0x99, 0x12, 0x82, 0x27, 0x90,
-0x91, 0x9C, 0x91, 0x3B, 0x12, 0x6E, 0xF3, 0x90,
-0x9A, 0xB9, 0xE0, 0x04, 0xF0, 0x90, 0x06, 0x31,
-0xE0, 0x30, 0xE2, 0x06, 0x91, 0x33, 0x50, 0x02,
-0x41, 0xAA, 0x91, 0x33, 0x40, 0x0A, 0x90, 0x06,
-0x35, 0xE0, 0x44, 0x20, 0x90, 0x06, 0x34, 0xF0,
-0xE4, 0x90, 0x9A, 0x2F, 0xF0, 0x91, 0x4B, 0x50,
-0x22, 0x91, 0x82, 0xA3, 0x91, 0x11, 0x91, 0x5E,
-0x90, 0x9A, 0x2F, 0xE0, 0x24, 0x19, 0xF5, 0x82,
-0xE4, 0x34, 0x9A, 0xF5, 0x83, 0xE0, 0xFF, 0x90,
-0x9A, 0x2D, 0x12, 0xCD, 0xDE, 0xEF, 0x91, 0x18,
-0xF0, 0x80, 0xDA, 0x90, 0x9A, 0x16, 0xE0, 0x70,
-0x04, 0xA3, 0xE0, 0x64, 0x01, 0x70, 0x0F, 0x90,
-0x98, 0x0E, 0xE0, 0xFF, 0x90, 0x9A, 0x2E, 0xE0,
-0x24, 0x08, 0xFD, 0x12, 0xCD, 0xE9, 0x90, 0x04,
-0x1D, 0xE0, 0x60, 0x24, 0x90, 0x05, 0x22, 0xE0,
-0x90, 0x9A, 0xB8, 0xF0, 0x7B, 0x1D, 0x12, 0x91,
-0xB3, 0xBF, 0x01, 0x06, 0x71, 0xFC, 0x90, 0x04,
-0x25, 0xF0, 0x90, 0x9A, 0xB8, 0xE0, 0xFD, 0x7B,
-0x1E, 0xE4, 0xFF, 0x12, 0x9C, 0x0E, 0x80, 0x06,
-0x71, 0xFC, 0x90, 0x04, 0x25, 0xF0, 0x12, 0x9D,
-0xB8, 0x90, 0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F,
-0x01, 0x12, 0x78, 0xC0, 0x74, 0xFA, 0x04, 0x90,
-0x01, 0xC4, 0xF0, 0x74, 0xE8, 0xA3, 0xF0, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0x90, 0x98, 0x0E, 0xE0,
-0xFF, 0x90, 0x92, 0x13, 0x74, 0x08, 0xF0, 0x7B,
-0x18, 0x7D, 0x01, 0x12, 0x66, 0xDB, 0x90, 0x9A,
-0x2D, 0xEF, 0xF0, 0x90, 0x98, 0x0E, 0xE0, 0x22,
-0xF0, 0x90, 0x9A, 0x2F, 0xE0, 0x04, 0x22, 0x90,
-0x9A, 0x32, 0xE4, 0x75, 0xF0, 0x08, 0x12, 0x02,
-0xE7, 0x90, 0x9A, 0x32, 0xE4, 0x75, 0xF0, 0x08,
-0x02, 0x02, 0xE7, 0x90, 0x9A, 0xB9, 0xE0, 0xC3,
-0x94, 0x0A, 0x22, 0x74, 0x10, 0xF0, 0x7A, 0x93,
-0x79, 0xF9, 0x22, 0x12, 0x82, 0x27, 0x7A, 0x9A,
-0x79, 0x19, 0x22, 0x90, 0x9A, 0x2F, 0xE0, 0xFF,
-0xC3, 0x94, 0x10, 0x22, 0x90, 0x9A, 0x32, 0xE4,
-0x75, 0xF0, 0x02, 0x02, 0x02, 0xE7, 0xFD, 0x12,
-0x7B, 0x8B, 0x90, 0x9A, 0x2D, 0xEF, 0xF0, 0x22,
-0x75, 0x46, 0x94, 0x75, 0x47, 0x40, 0x75, 0x48,
-0x02, 0x22, 0x90, 0x9A, 0x2F, 0xE0, 0xFF, 0x24,
-0x42, 0xF5, 0x82, 0xE4, 0x34, 0x94, 0xF5, 0x83,
-0xE0, 0x22, 0x90, 0x9A, 0x33, 0xE0, 0x2F, 0xFF,
-0x90, 0x9A, 0x32, 0xE0, 0x34, 0x00, 0xFE, 0x90,
-0x9A, 0xB6, 0xF0, 0x22, 0x90, 0x9A, 0x13, 0x11,
-0xF1, 0x12, 0xCF, 0x86, 0x91, 0xA7, 0x91, 0xB0,
-0x91, 0xA7, 0xA3, 0xE0, 0xFD, 0x01, 0xFA, 0x90,
-0x9A, 0x13, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
-0x9A, 0x16, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
-0x98, 0x0A, 0xE0, 0xFF, 0xB4, 0x02, 0x07, 0xD1,
-0x1D, 0x74, 0x08, 0xF0, 0x80, 0x09, 0xEF, 0xB4,
-0x04, 0x05, 0xD1, 0x1D, 0x74, 0x10, 0xF0, 0x90,
-0x9A, 0x16, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x64,
-0x02, 0x4E, 0x60, 0x08, 0xEF, 0x64, 0x01, 0x4E,
-0x60, 0x02, 0xC1, 0x10, 0x90, 0x94, 0x3A, 0xE0,
-0xFF, 0x64, 0xFE, 0x70, 0x02, 0xC1, 0x10, 0xEF,
-0x64, 0x02, 0x60, 0x07, 0xEF, 0x64, 0x03, 0x60,
-0x02, 0xC1, 0x10, 0x90, 0x94, 0x9A, 0xD1, 0x5A,
-0x90, 0x9A, 0xA3, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
-0x7E, 0x00, 0x7F, 0x28, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x9A, 0x79, 0x39, 0x12, 0x04, 0x80, 0x7E,
-0x00, 0x7F, 0x40, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
-0x9A, 0x79, 0x61, 0x12, 0x04, 0x80, 0x90, 0x9A,
-0x16, 0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01,
-0x70, 0x4D, 0x75, 0x45, 0x01, 0x75, 0x46, 0x94,
-0x75, 0x47, 0x6A, 0x75, 0x48, 0x10, 0x7B, 0x01,
-0x7A, 0x9A, 0x79, 0xA5, 0x12, 0x9F, 0xDF, 0x75,
-0x46, 0x94, 0x75, 0x47, 0x09, 0x75, 0x48, 0x10,
-0x7B, 0x01, 0x7A, 0x9A, 0x79, 0xB5, 0x12, 0x69,
-0xF5, 0xD1, 0x2E, 0x74, 0x20, 0xD1, 0x38, 0x90,
-0x8F, 0x3A, 0xD1, 0x15, 0x90, 0x8F, 0x3D, 0xD1,
-0x25, 0x90, 0x8F, 0x40, 0xF0, 0x7A, 0x9A, 0x79,
-0xA5, 0x12, 0x4C, 0x23, 0x75, 0x45, 0x01, 0x75,
-0x46, 0x9A, 0x75, 0x47, 0x61, 0x80, 0x24, 0xD1,
-0x2E, 0x74, 0x10, 0xD1, 0x38, 0x90, 0x91, 0x8C,
-0xD1, 0x15, 0x90, 0x91, 0x8F, 0xD1, 0x25, 0x90,
-0x91, 0x92, 0xF0, 0x7A, 0x94, 0x79, 0x09, 0x12,
-0x61, 0x34, 0x75, 0x45, 0x01, 0x75, 0x46, 0x9A,
-0x75, 0x47, 0x69, 0x75, 0x48, 0x28, 0x7B, 0x01,
-0x7A, 0x9A, 0x79, 0x39, 0x12, 0x69, 0xF5, 0x75,
-0x45, 0x01, 0x75, 0x46, 0x9A, 0x75, 0x47, 0x41,
-0x75, 0x48, 0x20, 0x7B, 0x01, 0x7A, 0x9A, 0x79,
-0x18, 0x12, 0x69, 0xF5, 0x90, 0x9A, 0x3F, 0xE0,
-0x54, 0x03, 0x90, 0x9A, 0x38, 0xF0, 0xC3, 0x94,
-0x04, 0x50, 0x1C, 0xE0, 0x90, 0x95, 0x63, 0xF0,
-0x75, 0x45, 0x01, 0x75, 0x46, 0x9A, 0x75, 0x47,
-0x18, 0x75, 0x48, 0x20, 0x7B, 0x01, 0x7A, 0x95,
-0x79, 0x43, 0x12, 0x69, 0xF5, 0x80, 0x06, 0x90,
-0x95, 0x63, 0x74, 0x05, 0xF0, 0x90, 0x9A, 0x38,
-0xE0, 0xFF, 0x90, 0x98, 0x0A, 0xE0, 0xFD, 0x7B,
-0x01, 0x7A, 0x9A, 0x79, 0x18, 0x12, 0xA8, 0x33,
-0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12, 0x82, 0x27,
-0x7A, 0x9A, 0x79, 0x61, 0x22, 0x90, 0x9A, 0xA1,
+0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x36, 0x11, 0x87,
+0x7F, 0x00, 0x70, 0x02, 0x7F, 0x01, 0x22, 0x7E,
+0x00, 0x7F, 0x06, 0x12, 0x83, 0xDC, 0xEF, 0x22,
+0x90, 0x9A, 0x36, 0xED, 0xF0, 0xA3, 0xEB, 0xF0,
+0x90, 0x9A, 0x34, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0,
+0x22, 0x11, 0x98, 0xA3, 0xED, 0xF0, 0x78, 0x37,
+0x7C, 0x9A, 0x7D, 0x01, 0x7B, 0xFF, 0x7A, 0x80,
+0x79, 0x94, 0x7E, 0x00, 0x7F, 0x06, 0x12, 0x01,
+0xE0, 0x12, 0xFB, 0x65, 0x7A, 0x80, 0x79, 0x9A,
+0x51, 0x8A, 0x78, 0x4D, 0x7C, 0x9A, 0x7D, 0x01,
+0x7B, 0xFF, 0x7A, 0x80, 0x79, 0xAA, 0x51, 0x8A,
+0xE4, 0x90, 0x9A, 0x60, 0x12, 0xAF, 0x1A, 0xA3,
+0xE0, 0xFD, 0x12, 0xF1, 0x68, 0xEF, 0x64, 0x01,
+0x60, 0x02, 0x41, 0x72, 0x12, 0xA6, 0x27, 0xCF,
+0x24, 0x0E, 0xCF, 0x34, 0x00, 0x12, 0xA2, 0x3B,
+0xEF, 0x64, 0x3A, 0x60, 0x02, 0x41, 0x72, 0x12,
+0xA6, 0x27, 0xCF, 0x24, 0x30, 0xCF, 0x34, 0x00,
+0x12, 0xA2, 0x3B, 0xEF, 0x64, 0x87, 0x60, 0x02,
+0x41, 0x72, 0x90, 0x9A, 0x60, 0x04, 0xF0, 0xE4,
+0x90, 0x9A, 0x5D, 0xF0, 0x51, 0x78, 0x94, 0x10,
+0x50, 0x1B, 0x12, 0xA7, 0x92, 0x12, 0xA6, 0x32,
+0xCD, 0x24, 0x38, 0x12, 0xA2, 0x30, 0x90, 0x9A,
+0x5D, 0xE0, 0x24, 0x4D, 0xF5, 0x82, 0xE4, 0x34,
+0x9A, 0x51, 0x7F, 0x80, 0xDF, 0xE4, 0x90, 0x9A,
+0x5E, 0xF0, 0x90, 0x9A, 0x5E, 0xE0, 0xFF, 0xC3,
+0x94, 0x02, 0x40, 0x02, 0x41, 0x72, 0x75, 0xF0,
+0x38, 0xEF, 0x51, 0x91, 0x20, 0xE0, 0x02, 0x41,
+0x72, 0xE4, 0x90, 0x9A, 0x5F, 0xF0, 0x51, 0x99,
+0x90, 0x93, 0x62, 0x12, 0x04, 0x6E, 0xE0, 0xFE,
+0x90, 0x9A, 0x5F, 0xE0, 0xC3, 0x9E, 0x40, 0x02,
+0x41, 0x6A, 0xEF, 0x75, 0xF0, 0x38, 0xA4, 0x24,
+0x79, 0xF9, 0x74, 0x93, 0x35, 0xF0, 0xFA, 0x7B,
+0x01, 0xE0, 0x75, 0xF0, 0x10, 0xA4, 0x29, 0xF9,
+0xEA, 0x35, 0xF0, 0xFA, 0x78, 0x4D, 0x7C, 0x9A,
+0x51, 0xA2, 0x60, 0x02, 0x41, 0x5B, 0x90, 0x06,
+0x33, 0xE0, 0x44, 0x01, 0x54, 0xFB, 0xF0, 0xE4,
+0x90, 0x9A, 0x5D, 0xF0, 0x51, 0x78, 0x94, 0x06,
+0x50, 0x16, 0x12, 0xA7, 0x92, 0x12, 0xA6, 0x32,
+0xCD, 0x24, 0x4A, 0x12, 0xA2, 0x30, 0x90, 0x9A,
+0x5D, 0x12, 0xFB, 0x5C, 0x51, 0x7F, 0x80, 0xE4,
+0xE4, 0x90, 0x9A, 0x5D, 0xF0, 0x51, 0x78, 0x94,
+0x10, 0x50, 0x0D, 0x12, 0xA2, 0x1C, 0x90, 0x9A,
+0x5D, 0x12, 0xFA, 0x8C, 0x51, 0x7F, 0x80, 0xED,
+0x51, 0x99, 0x51, 0x91, 0xFE, 0xC3, 0x13, 0x30,
+0xE0, 0x2B, 0xEF, 0x75, 0xF0, 0x38, 0xA4, 0x24,
+0x69, 0xF9, 0x74, 0x93, 0x35, 0xF0, 0xFA, 0x7B,
+0x01, 0x78, 0x3D, 0x7C, 0x9A, 0x51, 0xA2, 0x70,
+0x71, 0x90, 0x98, 0x35, 0xE0, 0xB4, 0x02, 0x0B,
+0x90, 0x93, 0x25, 0x12, 0xB4, 0xAD, 0x20, 0xE0,
+0x1E, 0x80, 0x12, 0x80, 0x1A, 0x90, 0x98, 0x35,
+0xE0, 0xB4, 0x02, 0x13, 0x90, 0x93, 0x25, 0x12,
+0xB4, 0xAD, 0x20, 0xE0, 0x0A, 0x90, 0x01, 0xC7,
+0x74, 0x0A, 0x12, 0xA7, 0x70, 0x80, 0x53, 0x7B,
+0x01, 0x7A, 0x9A, 0x79, 0x37, 0x90, 0x9A, 0x64,
+0x12, 0x82, 0x27, 0x7A, 0x9A, 0x79, 0x4D, 0x90,
+0x9A, 0x67, 0x12, 0x82, 0x27, 0x90, 0x9A, 0x5E,
+0xE0, 0x75, 0xF0, 0x38, 0xA4, 0x24, 0x63, 0xF9,
+0x74, 0x93, 0x35, 0xF0, 0xFA, 0x90, 0x9A, 0x6A,
+0x12, 0x82, 0x27, 0xE4, 0x90, 0x9A, 0x6D, 0xF0,
+0xA3, 0xF0, 0x7A, 0x9A, 0x79, 0x3D, 0x12, 0x8A,
+0x45, 0x80, 0x07, 0x90, 0x06, 0x33, 0xE0, 0x44,
+0x05, 0xF0, 0x90, 0x9A, 0x5F, 0xE0, 0x04, 0xF0,
+0x21, 0x56, 0x90, 0x9A, 0x5E, 0xE0, 0x04, 0xF0,
+0x21, 0x3A, 0x90, 0x9A, 0x60, 0xE0, 0xFF, 0x22,
+0x90, 0x9A, 0x5D, 0xE0, 0xFF, 0xC3, 0x22, 0xF5,
+0x83, 0xEF, 0xF0, 0x90, 0x9A, 0x5D, 0xE0, 0x04,
+0xF0, 0x22, 0x7E, 0x00, 0x7F, 0x10, 0x02, 0x01,
+0xE0, 0x90, 0x93, 0x61, 0x12, 0x04, 0x6E, 0xE0,
+0x22, 0x90, 0x9A, 0x5E, 0xE0, 0xFF, 0x75, 0xF0,
+0x38, 0x22, 0x7D, 0x01, 0x7E, 0x00, 0x7F, 0x10,
+0x12, 0x83, 0xDC, 0xEF, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9A, 0x42, 0xEE,
+0xF0, 0xA3, 0xEF, 0xF0, 0x90, 0x98, 0x36, 0xE0,
+0xFF, 0xB4, 0x02, 0x07, 0x91, 0xA5, 0x74, 0x08,
+0xF0, 0x80, 0x09, 0xEF, 0xB4, 0x04, 0x05, 0x91,
+0xA5, 0x74, 0x10, 0xF0, 0x90, 0x9A, 0x42, 0xE0,
+0xFE, 0xA3, 0xE0, 0xFF, 0x64, 0x02, 0x4E, 0x60,
+0x08, 0xEF, 0x64, 0x01, 0x4E, 0x60, 0x02, 0x81,
+0x7B, 0x90, 0x94, 0x9A, 0x12, 0xFB, 0x9C, 0x90,
+0x9A, 0xCF, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x7E,
+0x00, 0x7F, 0x28, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
+0x9A, 0x79, 0x65, 0x12, 0x04, 0x80, 0x7E, 0x00,
+0x7F, 0x40, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x9A,
+0x79, 0x8D, 0x12, 0x04, 0x80, 0x90, 0x9A, 0x42,
+0xE0, 0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01, 0x70,
+0x4D, 0x75, 0x45, 0x01, 0x75, 0x46, 0x94, 0x75,
+0x47, 0x6A, 0x75, 0x48, 0x10, 0x7B, 0x01, 0x7A,
+0x9A, 0x79, 0xD1, 0x12, 0xFB, 0x0B, 0x75, 0x46,
+0x94, 0x75, 0x47, 0x09, 0x75, 0x48, 0x10, 0x7B,
+0x01, 0x7A, 0x9A, 0x79, 0xE1, 0x12, 0x69, 0xF5,
+0x91, 0xB6, 0x74, 0x20, 0x91, 0xD0, 0x90, 0x8F,
+0x3A, 0x91, 0x9D, 0x90, 0x8F, 0x3D, 0x91, 0xAD,
+0x90, 0x8F, 0x40, 0xF0, 0x7A, 0x9A, 0x79, 0xD1,
+0x12, 0x4C, 0x23, 0x75, 0x45, 0x01, 0x75, 0x46,
+0x9A, 0x75, 0x47, 0x8D, 0x80, 0x24, 0x91, 0xB6,
+0x74, 0x10, 0x91, 0xD0, 0x90, 0x91, 0x8C, 0x91,
+0x9D, 0x90, 0x91, 0x8F, 0x91, 0xAD, 0x90, 0x91,
+0x92, 0xF0, 0x7A, 0x94, 0x79, 0x09, 0x12, 0x61,
+0x34, 0x75, 0x45, 0x01, 0x75, 0x46, 0x9A, 0x75,
+0x47, 0x95, 0x75, 0x48, 0x28, 0x7B, 0x01, 0x7A,
+0x9A, 0x79, 0x65, 0x12, 0x69, 0xF5, 0x90, 0x94,
+0x3D, 0xE0, 0x64, 0xFE, 0x70, 0x1A, 0x90, 0x94,
+0x3F, 0xE0, 0x54, 0x30, 0xFF, 0xC4, 0x54, 0x0F,
+0x91, 0x95, 0x75, 0x46, 0x9A, 0x75, 0x47, 0x65,
+0x91, 0xC0, 0xE0, 0x44, 0x10, 0xF0, 0x80, 0x31,
+0x90, 0x94, 0x3D, 0xE0, 0xFF, 0x64, 0x02, 0x60,
+0x05, 0xEF, 0x64, 0x03, 0x70, 0x16, 0x90, 0x9A,
+0x6B, 0xE0, 0x54, 0x03, 0x91, 0x95, 0x75, 0x46,
+0x9A, 0x75, 0x47, 0x6D, 0x91, 0xC0, 0xE0, 0x44,
+0x20, 0xF0, 0x80, 0x0D, 0x90, 0x9A, 0x64, 0x74,
+0x05, 0xF0, 0x90, 0x06, 0x33, 0xE0, 0x44, 0x40,
+0xF0, 0x78, 0x43, 0x7C, 0x95, 0x7D, 0x01, 0x7B,
+0x01, 0x7A, 0x9A, 0x79, 0x44, 0x51, 0xA4, 0x70,
+0x09, 0x90, 0x06, 0x33, 0xE0, 0x44, 0x08, 0xF0,
+0x80, 0x71, 0x90, 0x9A, 0x64, 0xE0, 0xFF, 0xC3,
+0x94, 0x04, 0x50, 0x61, 0x90, 0x95, 0x63, 0xEF,
+0xF0, 0x75, 0x45, 0x01, 0x75, 0x46, 0x9A, 0x75,
+0x47, 0x44, 0x75, 0x48, 0x20, 0x7B, 0x01, 0x7A,
+0x95, 0x79, 0x43, 0x12, 0x69, 0xF5, 0x90, 0x9A,
+0x64, 0xE0, 0xFF, 0x90, 0x98, 0x36, 0xE0, 0xFD,
+0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x44, 0x12, 0x9E,
+0x80, 0x90, 0x95, 0x63, 0xE0, 0x14, 0x60, 0x12,
+0x14, 0x60, 0x17, 0x14, 0x60, 0x1C, 0x24, 0x03,
+0x70, 0x29, 0x91, 0x80, 0x7A, 0x95, 0x79, 0x73,
+0x80, 0x16, 0x91, 0x80, 0x7A, 0x95, 0x79, 0x7B,
+0x80, 0x0E, 0x91, 0x80, 0x7A, 0x95, 0x79, 0x83,
+0x80, 0x06, 0x91, 0x80, 0x7A, 0x95, 0x79, 0x8B,
+0x12, 0x9C, 0x60, 0x80, 0x06, 0x90, 0x95, 0x63,
+0x74, 0x05, 0xF0, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
+0x7B, 0x01, 0x7A, 0x94, 0x79, 0x7A, 0x90, 0x9C,
+0x90, 0x12, 0x82, 0x27, 0x90, 0x98, 0x36, 0xE0,
+0x90, 0x9C, 0x93, 0xF0, 0x22, 0x90, 0x9A, 0x64,
+0xF0, 0x75, 0x45, 0x01, 0x22, 0x12, 0x82, 0x27,
+0x7A, 0x9A, 0x79, 0x8D, 0x22, 0x90, 0x9A, 0xCD,
 0x74, 0x80, 0xF0, 0xA3, 0x22, 0x12, 0x82, 0x27,
-0x90, 0x9A, 0xA3, 0xA3, 0xE0, 0x22, 0x90, 0x9A,
-0xA3, 0xA3, 0xE0, 0xFB, 0x90, 0x92, 0x06, 0x22,
+0x90, 0x9A, 0xCF, 0xA3, 0xE0, 0x22, 0x90, 0x9A,
+0xCF, 0xA3, 0xE0, 0xFB, 0x90, 0x92, 0x06, 0x22,
+0x75, 0x48, 0x20, 0x7B, 0x01, 0x7A, 0x9A, 0x79,
+0x44, 0x12, 0x69, 0xF5, 0x90, 0x06, 0x33, 0x22,
 0xF0, 0xE4, 0xA3, 0xF0, 0xA3, 0xF0, 0xFD, 0xFC,
 0xFF, 0xFE, 0x12, 0x71, 0xD4, 0x7B, 0x01, 0x7A,
-0x94, 0x79, 0x9C, 0x22, 0xE4, 0x75, 0xF0, 0x10,
-0x02, 0x02, 0xE7, 0xE4, 0x75, 0xF0, 0x20, 0x02,
-0x02, 0xE7, 0xE0, 0xFE, 0xA3, 0xE0, 0xFD, 0xED,
-0xFF, 0x22, 0x7D, 0x01, 0x7B, 0x01, 0x7A, 0x93,
-0x79, 0x53, 0x7E, 0x00, 0x7F, 0x04, 0x02, 0x83,
-0xDC, 0x12, 0x8F, 0xDD, 0xE4, 0x90, 0x9A, 0x0C,
-0xF0, 0xA3, 0xF0, 0x12, 0x8B, 0xE8, 0xEF, 0x54,
-0x0C, 0x64, 0x08, 0x70, 0x4B, 0x12, 0x8F, 0x11,
-0xA3, 0xE0, 0x24, 0x06, 0x12, 0x8F, 0xB9, 0xEF,
-0x64, 0x88, 0x70, 0x3C, 0x12, 0x8F, 0x11, 0xA3,
-0xE0, 0x24, 0x07, 0x12, 0x8F, 0xB9, 0xEF, 0x64,
-0x8E, 0x70, 0x2D, 0x90, 0x9A, 0x0C, 0x12, 0x8F,
-0xA4, 0xEF, 0x70, 0x24, 0x12, 0x8F, 0x11, 0xD1,
-0xD6, 0x24, 0x04, 0x12, 0x8F, 0xB9, 0xEF, 0x64,
-0x01, 0x70, 0x15, 0x12, 0x8F, 0x11, 0xD1, 0xD6,
-0x24, 0x08, 0x12, 0x8F, 0xB9, 0xBF, 0x01, 0x08,
-0x90, 0x01, 0xC7, 0x74, 0x0B, 0x12, 0x8F, 0xC9,
-0x90, 0x9A, 0x0C, 0xE0, 0xFF, 0x22, 0x90, 0x9A,
-0x0B, 0xE0, 0xFD, 0x90, 0x9A, 0x0A, 0xE0, 0x2D,
-0x22, 0xE4, 0xFE, 0xED, 0x30, 0xE1, 0x11, 0x90,
-0x01, 0x3F, 0xE0, 0x30, 0xE2, 0x0A, 0x74, 0x04,
-0xF0, 0x90, 0x01, 0xC7, 0x74, 0x23, 0xF0, 0x0E,
-0xED, 0x30, 0xE0, 0x24, 0xEF, 0x30, 0xE6, 0x08,
-0x90, 0x01, 0xC7, 0x74, 0x22, 0xF0, 0x7E, 0x01,
-0xEF, 0x30, 0xE7, 0x08, 0x90, 0x01, 0xC7, 0x74,
-0x21, 0xF0, 0x7E, 0x01, 0xEF, 0x30, 0xE5, 0x08,
-0x90, 0x01, 0xC7, 0x74, 0x23, 0xF0, 0x7E, 0x01,
-0xAF, 0x06, 0x22, 0x12, 0x02, 0x06, 0x90, 0x98,
-0x09, 0x12, 0x87, 0x9C, 0x90, 0x98, 0x0A, 0xF0,
-0x22, 0x12, 0x87, 0xC3, 0x90, 0x98, 0x0B, 0x12,
-0x87, 0x9C, 0xFF, 0xED, 0x2F, 0x90, 0x98, 0x0C,
+0x94, 0x79, 0x9C, 0x22, 0x90, 0x9A, 0x3F, 0x12,
+0xA7, 0xE9, 0x12, 0xF3, 0x90, 0x12, 0xFB, 0x41,
+0x51, 0xAD, 0x12, 0xFB, 0x41, 0xA3, 0xE0, 0xFD,
+0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90,
+0x9A, 0x42, 0x12, 0xA7, 0xE9, 0x90, 0x9A, 0x5A,
+0x74, 0x18, 0xF0, 0x7E, 0x00, 0x7F, 0x80, 0x7D,
+0x00, 0x7B, 0x01, 0x7A, 0x9A, 0x79, 0x62, 0x12,
+0x04, 0x80, 0x90, 0x98, 0x3A, 0xE0, 0xFF, 0x12,
+0x7B, 0x07, 0x90, 0x9A, 0x59, 0xEF, 0xF0, 0xF9,
+0xE0, 0xFE, 0x24, 0x29, 0xF5, 0x82, 0xE4, 0x34,
+0xFC, 0xF5, 0x83, 0x74, 0x41, 0xF0, 0xEE, 0x24,
+0x28, 0xFD, 0xE4, 0x33, 0xFC, 0x90, 0x9A, 0x5A,
+0xE0, 0x7A, 0x00, 0x2D, 0xFE, 0xEA, 0x3C, 0x90,
+0x9A, 0x5E, 0xF0, 0xA3, 0xCE, 0xF0, 0x74, 0x28,
+0x29, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01,
+0x90, 0x9A, 0x44, 0xE0, 0xFD, 0x12, 0xF0, 0x46,
+0x12, 0xF9, 0x23, 0x90, 0x9A, 0x5E, 0xE0, 0xFF,
+0xA3, 0xE0, 0x90, 0x9A, 0x5C, 0xCF, 0xF0, 0xA3,
+0xEF, 0xF0, 0x90, 0x9A, 0x62, 0x74, 0x01, 0xF0,
+0xA3, 0x74, 0x03, 0xF0, 0xE4, 0xA3, 0xF0, 0xA3,
+0x74, 0x5F, 0xF0, 0x90, 0x9A, 0x5E, 0xE4, 0x75,
+0xF0, 0x04, 0x12, 0x02, 0xE7, 0x90, 0x94, 0x3D,
+0xE0, 0xFF, 0x7E, 0x02, 0xB4, 0xFE, 0x02, 0x7E,
+0xFE, 0x90, 0x9A, 0x5E, 0xA3, 0xE0, 0xFD, 0x12,
+0x8E, 0x99, 0xEE, 0xF0, 0x74, 0x00, 0x2D, 0x12,
+0x8E, 0x9B, 0xE0, 0x90, 0x9A, 0x66, 0xF0, 0x90,
+0x9A, 0x5E, 0x12, 0xBF, 0xA5, 0x90, 0x95, 0x32,
+0xE0, 0x90, 0x9A, 0x42, 0xB4, 0x01, 0x0B, 0xE0,
+0x44, 0x03, 0xFC, 0xA3, 0xE0, 0x44, 0x10, 0xFD,
+0x80, 0x09, 0xE0, 0x44, 0x03, 0xFC, 0xA3, 0xE0,
+0x44, 0x20, 0xFD, 0x90, 0x9A, 0x60, 0xEC, 0xF0,
+0xA3, 0xED, 0xF0, 0x90, 0x9A, 0x42, 0xE0, 0x70,
+0x04, 0xA3, 0xE0, 0x64, 0x01, 0x90, 0x9A, 0x5E,
+0x70, 0x18, 0xA3, 0xE0, 0xFE, 0x12, 0x8E, 0x99,
+0x12, 0xC3, 0xEA, 0x74, 0x01, 0xF0, 0x90, 0x9A,
+0x67, 0x74, 0x03, 0xF0, 0xA3, 0x74, 0x01, 0xF0,
+0x80, 0x14, 0xA3, 0xE0, 0xFE, 0x12, 0x8E, 0x99,
+0x12, 0xC3, 0xEA, 0x74, 0x02, 0xF0, 0x90, 0x9A,
+0x67, 0x04, 0xF0, 0xA3, 0x14, 0xF0, 0x12, 0xFA,
+0xBA, 0xEF, 0x64, 0xFE, 0x90, 0x9A, 0x5E, 0x70,
+0x21, 0xA3, 0xE0, 0x24, 0x00, 0x12, 0xF9, 0xF1,
+0xC0, 0x03, 0x8B, 0x45, 0x12, 0xFB, 0x01, 0xD0,
+0x03, 0x12, 0xFB, 0x0B, 0x12, 0xFB, 0x01, 0x7B,
+0x01, 0x7A, 0x9A, 0x79, 0x69, 0x12, 0x69, 0xF5,
+0x80, 0x22, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x24,
+0x00, 0xF5, 0x82, 0x74, 0xFC, 0x3E, 0xF5, 0x83,
+0xE4, 0xF0, 0x74, 0x01, 0x2F, 0xF5, 0x82, 0x74,
+0xFC, 0x3E, 0xF5, 0x83, 0xE4, 0xF0, 0x90, 0x9A,
+0x69, 0xF0, 0xA3, 0xF0, 0x12, 0xFA, 0xBA, 0xE4,
+0x90, 0x9A, 0x5B, 0xF0, 0x12, 0xFA, 0x27, 0xFE,
+0x90, 0x9A, 0x5E, 0xA3, 0xE0, 0xFD, 0xEF, 0x2D,
+0x12, 0x8E, 0x99, 0xEE, 0xF0, 0x12, 0xFA, 0x27,
+0xFE, 0x74, 0x6B, 0x2F, 0xF5, 0x82, 0xE4, 0x34,
+0x9A, 0xF5, 0x83, 0xEE, 0x12, 0xFA, 0xFA, 0xF0,
+0xE0, 0xB4, 0x08, 0xD8, 0x12, 0xF9, 0x2D, 0x90,
+0x9A, 0x5E, 0x12, 0xC7, 0xA9, 0x90, 0x9A, 0x5E,
+0x12, 0xC7, 0xA2, 0x12, 0xF9, 0x23, 0xE4, 0x90,
+0x9A, 0xE5, 0xF0, 0xE4, 0x90, 0x9A, 0x5B, 0xF0,
+0x12, 0xFB, 0x38, 0x50, 0x14, 0x12, 0xFA, 0x0B,
+0xA3, 0x12, 0xF9, 0xAB, 0x12, 0xFA, 0xF0, 0x12,
+0x8E, 0x98, 0xE4, 0x12, 0xFA, 0xFA, 0xF0, 0x80,
+0xE7, 0x12, 0xFB, 0x95, 0x90, 0x06, 0x31, 0xE0,
+0x54, 0xFB, 0xF0, 0x90, 0x98, 0x3B, 0xE0, 0xFD,
+0x12, 0xF3, 0x59, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
+0xD8, 0xF9, 0x12, 0xF3, 0x38, 0xED, 0xFF, 0x90,
+0x98, 0x3A, 0x12, 0xF3, 0x42, 0xC3, 0x33, 0xCE,
+0x33, 0xCE, 0xD8, 0xF9, 0xFF, 0x90, 0x9A, 0x5A,
+0xE0, 0x7C, 0x00, 0x2F, 0xFF, 0xEC, 0x3E, 0xCF,
+0x24, 0x38, 0xCF, 0x34, 0x00, 0xFE, 0x90, 0x92,
+0x06, 0x74, 0x10, 0xF0, 0x7B, 0x63, 0xE4, 0xFD,
+0x12, 0x71, 0xD4, 0x90, 0x9A, 0x42, 0xE0, 0x70,
+0x04, 0xA3, 0xE0, 0x64, 0x01, 0x7B, 0x01, 0x7A,
+0x9A, 0x79, 0x62, 0x70, 0x17, 0x90, 0x91, 0xA0,
+0x12, 0xFB, 0x8D, 0x90, 0x91, 0xA3, 0x12, 0x82,
+0x27, 0x90, 0x91, 0xA6, 0x12, 0xFB, 0x85, 0x12,
+0x6F, 0x34, 0x80, 0x15, 0x90, 0x91, 0x96, 0x12,
+0xFB, 0x8D, 0x90, 0x91, 0x99, 0x12, 0x82, 0x27,
+0x90, 0x91, 0x9C, 0x12, 0xFB, 0x85, 0x12, 0x6E,
+0xF3, 0x90, 0x9A, 0xE5, 0xE0, 0x04, 0xF0, 0x90,
+0x06, 0x31, 0xE0, 0x30, 0xE2, 0x07, 0x12, 0xFB,
+0x7D, 0x50, 0x02, 0xC1, 0xAB, 0x12, 0xFB, 0x7D,
+0x40, 0x0A, 0x90, 0x06, 0x35, 0xE0, 0x44, 0x20,
+0x90, 0x06, 0x34, 0xF0, 0xE4, 0x90, 0x9A, 0x5B,
+0xF0, 0x12, 0xFB, 0x38, 0x50, 0x26, 0x12, 0xFA,
+0x0B, 0xA3, 0x12, 0xF9, 0xAB, 0x12, 0xFA, 0xF0,
+0x90, 0x9A, 0x5B, 0xE0, 0x24, 0x45, 0xF5, 0x82,
+0xE4, 0x34, 0x9A, 0xF5, 0x83, 0xE0, 0xFF, 0x90,
+0x9A, 0x59, 0x12, 0x8E, 0x98, 0xEF, 0x12, 0xFA,
+0xFA, 0xF0, 0x80, 0xD5, 0x90, 0x9A, 0x42, 0xE0,
+0x70, 0x04, 0xA3, 0xE0, 0x64, 0x01, 0x70, 0x0F,
+0x90, 0x98, 0x3A, 0xE0, 0xFF, 0x90, 0x9A, 0x5A,
+0xE0, 0x24, 0x08, 0xFD, 0x12, 0xF1, 0xDF, 0x90,
+0x04, 0x1D, 0xE0, 0x60, 0x25, 0x90, 0x05, 0x22,
+0xE0, 0x90, 0x9A, 0xE4, 0xF0, 0x7B, 0x1D, 0x12,
+0x88, 0xBF, 0xBF, 0x01, 0x07, 0x12, 0xF9, 0x96,
+0x90, 0x04, 0x25, 0xF0, 0x90, 0x9A, 0xE4, 0xE0,
+0xFD, 0x7B, 0x1E, 0xE4, 0xFF, 0x12, 0x8D, 0x1E,
+0x80, 0x07, 0x12, 0xF9, 0x96, 0x90, 0x04, 0x25,
+0xF0, 0x90, 0x04, 0x1F, 0x74, 0x20, 0xF0, 0x90,
+0x88, 0x39, 0xE0, 0x70, 0x05, 0x7F, 0x01, 0x12,
+0x78, 0xC0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0xEF, 0x20,
+0xE0, 0x05, 0x90, 0x98, 0x35, 0x80, 0x03, 0x90,
+0x98, 0x36, 0xE0, 0x90, 0x95, 0x64, 0xF0, 0x90,
+0x95, 0x64, 0xE0, 0x14, 0x60, 0x13, 0x14, 0x60,
+0x14, 0x24, 0xFE, 0x60, 0x10, 0x14, 0x60, 0x09,
+0x14, 0x60, 0x06, 0x24, 0x06, 0xE4, 0xFE, 0x80,
+0x06, 0x7E, 0x04, 0x80, 0x02, 0x7E, 0x08, 0xAF,
+0x06, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x9C,
+0xA3, 0xED, 0xF0, 0x90, 0x9C, 0xA0, 0x12, 0x82,
+0x27, 0xE4, 0x90, 0x9C, 0xA4, 0xF0, 0xA3, 0xF0,
+0x12, 0x02, 0x06, 0xFF, 0x12, 0x9C, 0x5A, 0xFD,
+0x12, 0x87, 0xD2, 0xFB, 0x12, 0x8E, 0xC9, 0x90,
+0x9C, 0xA4, 0xEF, 0xF0, 0x90, 0x9C, 0xA0, 0x12,
+0x82, 0x1E, 0x12, 0x87, 0xD2, 0xFF, 0x11, 0x07,
+0x90, 0x9C, 0xA5, 0xEF, 0xF0, 0x90, 0x95, 0x64,
+0xE0, 0x24, 0xFE, 0x60, 0x15, 0x24, 0xFE, 0x60,
+0x11, 0x14, 0x60, 0x07, 0x14, 0x60, 0x04, 0x24,
+0x05, 0x70, 0x43, 0x11, 0xD7, 0xFD, 0x11, 0xE2,
+0x80, 0x0E, 0x11, 0xD7, 0xFD, 0x90, 0x95, 0x64,
+0xE0, 0x90, 0x9C, 0x64, 0xF0, 0x12, 0x9F, 0x23,
+0x90, 0x9C, 0xA5, 0xE0, 0xFF, 0x90, 0x9C, 0xA0,
+0x12, 0x82, 0x1E, 0x90, 0x9C, 0xA4, 0xE0, 0x7C,
+0x00, 0x29, 0xF9, 0xEC, 0x3A, 0xFA, 0xC3, 0xE9,
+0x9F, 0xF9, 0xEA, 0x94, 0x00, 0xFA, 0x75, 0x45,
+0x01, 0x75, 0x46, 0x95, 0x75, 0x47, 0x33, 0xA3,
+0xE0, 0xF5, 0x48, 0x12, 0x69, 0xF5, 0x22, 0x7B,
+0x01, 0x7A, 0x95, 0x79, 0x33, 0x90, 0x9C, 0xA3,
+0xE0, 0x22, 0x90, 0x9C, 0x88, 0xED, 0xF0, 0x90,
+0x9C, 0x85, 0x12, 0x82, 0x27, 0x12, 0x87, 0xA4,
+0x90, 0x9C, 0x8C, 0xF0, 0x90, 0x9C, 0x85, 0x12,
+0x8B, 0xE0, 0x75, 0x48, 0x03, 0x7B, 0x01, 0x7A,
+0x9C, 0x79, 0x89, 0x12, 0x69, 0xF5, 0x90, 0x9C,
+0x88, 0xE0, 0x70, 0x2E, 0xFF, 0x31, 0x3B, 0xE0,
+0xB4, 0xFF, 0x06, 0x31, 0x3B, 0xE4, 0xF0, 0x80,
+0x07, 0x31, 0x3B, 0xE0, 0x04, 0xF0, 0x80, 0x05,
+0x0F, 0xEF, 0xB4, 0x03, 0xE8, 0x75, 0x45, 0x01,
+0x75, 0x46, 0x9C, 0x75, 0x47, 0x89, 0x75, 0x48,
+0x03, 0x90, 0x9C, 0x85, 0x12, 0x82, 0x1E, 0x12,
+0x69, 0xF5, 0x22, 0x74, 0x89, 0x2F, 0xF5, 0x82,
+0xE4, 0x34, 0x9C, 0xF5, 0x83, 0x22, 0x12, 0x7B,
+0x07, 0x7E, 0x00, 0x74, 0x00, 0x2F, 0x12, 0x8D,
+0xC5, 0x75, 0x48, 0x70, 0x7B, 0x01, 0x7A, 0x93,
+0x79, 0x61, 0x02, 0x69, 0xF5, 0xEF, 0x60, 0x07,
+0x90, 0x98, 0x3D, 0xE0, 0xFF, 0x31, 0x46, 0x22,
+0x12, 0xA7, 0xE6, 0x2F, 0xFF, 0xE4, 0x3E, 0xCF,
+0x24, 0x06, 0xCF, 0x34, 0x00, 0x12, 0xA2, 0x3B,
+0xEF, 0x64, 0x86, 0x70, 0x20, 0x90, 0x9A, 0x63,
+0xE0, 0xFF, 0x90, 0x9A, 0x62, 0xE0, 0x2F, 0xFF,
+0x90, 0x9A, 0x61, 0xE0, 0x34, 0x00, 0xCF, 0x24,
+0x07, 0xCF, 0x34, 0x00, 0x12, 0xA2, 0x3B, 0xBF,
+0xDD, 0x03, 0x7F, 0x01, 0x22, 0x7F, 0x00, 0x22,
+0x90, 0x9A, 0x9B, 0x12, 0x82, 0x27, 0x90, 0x9A,
+0x9E, 0x12, 0x8B, 0xE0, 0x75, 0x48, 0x10, 0x7B,
+0x01, 0x7A, 0x93, 0x79, 0xD1, 0x12, 0x69, 0xF5,
+0x90, 0x9A, 0x9B, 0x12, 0x8B, 0xE0, 0x75, 0x48,
+0x10, 0x7B, 0x01, 0x7A, 0x93, 0x79, 0xE1, 0x12,
+0x69, 0xF5, 0x90, 0x9A, 0xA1, 0x12, 0x04, 0xB8,
+0x90, 0x93, 0xF1, 0x12, 0x04, 0x31, 0x90, 0x9A,
+0xA5, 0xE0, 0x90, 0x93, 0xF8, 0xF0, 0x22, 0xD3,
+0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9C,
+0x52, 0xED, 0xF0, 0x90, 0x9C, 0x51, 0xEF, 0xF0,
+0x12, 0x7B, 0x07, 0x90, 0x9C, 0x5F, 0xEF, 0xF0,
+0xE0, 0xFD, 0x24, 0x01, 0x12, 0xC3, 0xF0, 0xE0,
+0xFE, 0x74, 0x00, 0x2D, 0x12, 0x8E, 0x9B, 0x12,
+0xC7, 0x8C, 0x54, 0x3F, 0x90, 0x9C, 0x5C, 0xF0,
+0xA3, 0xEF, 0xF0, 0xE4, 0x90, 0x9C, 0x5B, 0xF0,
+0x71, 0x2F, 0x50, 0x0A, 0x71, 0x62, 0x12, 0x8E,
+0x98, 0xE4, 0x71, 0x17, 0x80, 0xF2, 0x90, 0x9C,
+0x5D, 0xE0, 0x24, 0xF8, 0xFB, 0x90, 0x9C, 0x5C,
+0xE0, 0x34, 0xFF, 0xFA, 0x90, 0x9C, 0x52, 0xE0,
+0xFF, 0x90, 0x91, 0xDC, 0xE4, 0xF0, 0xA3, 0xEF,
+0xF0, 0xA3, 0x74, 0x01, 0xF0, 0x7D, 0x0A, 0x7C,
+0x00, 0x7F, 0x10, 0x7E, 0x00, 0x12, 0x6D, 0xED,
+0x90, 0x98, 0x3B, 0xE0, 0xFF, 0x90, 0x9C, 0x51,
+0xE0, 0xFD, 0xD3, 0x9F, 0x40, 0x36, 0x90, 0x98,
+0x3B, 0xE0, 0xFC, 0x71, 0x59, 0xCE, 0xC3, 0x13,
+0xCE, 0x13, 0xD8, 0xF9, 0x71, 0x38, 0xEC, 0xFF,
+0xC3, 0xED, 0x71, 0x44, 0xC3, 0x33, 0xCE, 0x33,
+0xCE, 0xD8, 0xF9, 0x24, 0x28, 0xFF, 0xE4, 0x3E,
+0xFE, 0x71, 0x27, 0xFD, 0x90, 0x9C, 0x52, 0xE0,
+0xFC, 0xC3, 0xED, 0x9C, 0x71, 0x1F, 0x7D, 0x38,
+0x7C, 0x00, 0x80, 0x35, 0x90, 0x9C, 0x51, 0xE0,
+0xFD, 0x71, 0x59, 0xCE, 0xC3, 0x13, 0xCE, 0x13,
+0xD8, 0xF9, 0x71, 0x38, 0xED, 0xFF, 0x90, 0x98,
+0x3B, 0x71, 0x42, 0xC3, 0x33, 0xCE, 0x33, 0xCE,
+0xD8, 0xF9, 0x24, 0x38, 0xFD, 0xE4, 0x3E, 0xFC,
+0x71, 0x27, 0xFF, 0x90, 0x9C, 0x52, 0xE0, 0xFE,
+0xC3, 0xEF, 0x9E, 0x71, 0x1F, 0x7F, 0x28, 0x7E,
+0x00, 0x12, 0x71, 0xD4, 0x12, 0xB7, 0x9A, 0x90,
+0x91, 0x45, 0x12, 0x82, 0x27, 0x0B, 0x7A, 0x9C,
+0x79, 0x53, 0x90, 0x91, 0x48, 0x12, 0x82, 0x27,
+0x90, 0x91, 0x4B, 0x74, 0x08, 0xF0, 0x7A, 0x94,
+0x79, 0x31, 0x12, 0x4E, 0xA5, 0xE4, 0x90, 0x9C,
+0x5B, 0xF0, 0x71, 0x2F, 0x50, 0x1C, 0x71, 0x62,
+0x90, 0x9C, 0x5B, 0xE0, 0x24, 0x53, 0xF5, 0x82,
+0xE4, 0x34, 0x9C, 0xF5, 0x83, 0xE0, 0xFF, 0x90,
+0x9C, 0x5E, 0x12, 0x8E, 0x98, 0xEF, 0x71, 0x17,
+0x80, 0xE0, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0xF0,
+0x90, 0x9C, 0x5B, 0xE0, 0x04, 0xF0, 0x22, 0xFB,
+0x90, 0x92, 0x06, 0x74, 0x08, 0xF0, 0x22, 0x90,
+0x9C, 0x5C, 0xA3, 0xE0, 0x24, 0xF8, 0x22, 0x90,
+0x9C, 0x5B, 0xE0, 0xFF, 0xC3, 0x94, 0x08, 0x22,
+0xFF, 0x90, 0x92, 0x07, 0xEE, 0xF0, 0xA3, 0xEF,
+0xF0, 0x22, 0xE0, 0xC3, 0x9F, 0xFF, 0xE4, 0x94,
+0x00, 0xFE, 0xEF, 0x78, 0x07, 0x22, 0xE4, 0xFD,
+0x7F, 0x03, 0x12, 0x54, 0x1E, 0x90, 0x98, 0x3C,
+0xE0, 0x75, 0xF0, 0x80, 0xA4, 0xAE, 0xF0, 0x78,
+0x03, 0x22, 0x90, 0x9C, 0x5F, 0xE0, 0xFD, 0x90,
+0x9C, 0x5D, 0xE0, 0x2D, 0xFD, 0x90, 0x9C, 0x5C,
+0xE0, 0x34, 0x00, 0xCD, 0x24, 0x20, 0xCD, 0x34,
+0x00, 0xFC, 0x7E, 0x00, 0xED, 0x2F, 0xFF, 0xEE,
+0x3C, 0xFE, 0x90, 0x9C, 0x51, 0xE0, 0xFD, 0x12,
+0x7B, 0x8B, 0x90, 0x9C, 0x5E, 0xEF, 0xF0, 0x22,
+0xE4, 0xFD, 0x7F, 0x03, 0x12, 0x54, 0x1E, 0x90,
+0x01, 0x85, 0xE0, 0x54, 0xFE, 0xF0, 0x71, 0x4E,
+0xCE, 0xC3, 0x13, 0xCE, 0x13, 0xD8, 0xF9, 0x12,
+0xD7, 0xDF, 0x02, 0x54, 0x1E, 0x12, 0xE8, 0x90,
+0xE4, 0x90, 0x9A, 0x38, 0xF0, 0xA3, 0xF0, 0x12,
+0xA2, 0x3C, 0xEF, 0x54, 0x0C, 0x64, 0x08, 0x70,
+0x4B, 0x12, 0xAF, 0x1B, 0xA3, 0xE0, 0x24, 0x06,
+0x12, 0xAF, 0xC6, 0xEF, 0x64, 0x88, 0x70, 0x3C,
+0x12, 0xAF, 0x1B, 0xA3, 0xE0, 0x24, 0x07, 0x12,
+0xAF, 0xC6, 0xEF, 0x64, 0x8E, 0x70, 0x2D, 0x90,
+0x9A, 0x38, 0x12, 0xAF, 0xB1, 0xEF, 0x70, 0x24,
+0x12, 0xAF, 0x1B, 0x91, 0x12, 0x24, 0x04, 0x12,
+0xAF, 0xC6, 0xEF, 0x64, 0x01, 0x70, 0x15, 0x12,
+0xAF, 0x1B, 0x91, 0x12, 0x24, 0x08, 0x12, 0xAF,
+0xC6, 0xBF, 0x01, 0x08, 0x90, 0x01, 0xC7, 0x74,
+0x0B, 0x12, 0xA7, 0x70, 0x90, 0x9A, 0x38, 0xE0,
+0xFF, 0x22, 0x90, 0x9A, 0x37, 0xE0, 0xFD, 0x90,
+0x9A, 0x36, 0xE0, 0x2D, 0x22, 0xE4, 0xFE, 0xED,
+0x30, 0xE1, 0x11, 0x90, 0x01, 0x3F, 0xE0, 0x30,
+0xE2, 0x0A, 0x74, 0x04, 0xF0, 0x90, 0x01, 0xC7,
+0x74, 0x23, 0xF0, 0x0E, 0xED, 0x30, 0xE0, 0x24,
+0xEF, 0x30, 0xE6, 0x08, 0x90, 0x01, 0xC7, 0x74,
+0x22, 0xF0, 0x7E, 0x01, 0xEF, 0x30, 0xE7, 0x08,
+0x90, 0x01, 0xC7, 0x74, 0x21, 0xF0, 0x7E, 0x01,
+0xEF, 0x30, 0xE5, 0x08, 0x90, 0x01, 0xC7, 0x74,
+0x23, 0xF0, 0x7E, 0x01, 0xAF, 0x06, 0x22, 0x12,
+0x02, 0x06, 0x90, 0x98, 0x35, 0xF0, 0x12, 0x9C,
+0x5A, 0x90, 0x98, 0x36, 0xF0, 0x22, 0x12, 0x87,
+0xED, 0x2E, 0x90, 0x98, 0x37, 0xF0, 0x12, 0x9C,
+0x5A, 0xFF, 0xED, 0x2F, 0x90, 0x98, 0x38, 0x12,
+0x87, 0xE6, 0xFF, 0xED, 0x2F, 0x90, 0x98, 0x39,
 0x12, 0x87, 0xA3, 0xFF, 0xED, 0x2F, 0x90, 0x98,
-0x0D, 0x12, 0x97, 0xCC, 0xFF, 0xED, 0x2F, 0x90,
-0x98, 0x0E, 0x12, 0x95, 0xF4, 0xFF, 0xED, 0x2F,
-0x90, 0x98, 0x0F, 0x12, 0xE7, 0xE3, 0xFF, 0xED,
-0x2F, 0x90, 0x98, 0x10, 0xF1, 0x6B, 0x90, 0x98,
-0x11, 0xF0, 0x22, 0xF0, 0x90, 0x00, 0x06, 0x12,
-0x02, 0x1F, 0xFF, 0xAE, 0x05, 0xED, 0x2F, 0x22,
-0x12, 0x87, 0xC3, 0x90, 0x98, 0x12, 0x12, 0x87,
-0x9C, 0xFF, 0xED, 0x2F, 0x90, 0x98, 0x13, 0x12,
-0x87, 0xA3, 0xFF, 0xED, 0x2F, 0x90, 0x98, 0x14,
-0x12, 0x97, 0xCC, 0xFF, 0xED, 0x2F, 0x90, 0x98,
-0x15, 0x12, 0x95, 0xF4, 0xFF, 0xED, 0x2F, 0x90,
-0x98, 0x16, 0x12, 0xE7, 0xE3, 0xFF, 0xED, 0x2F,
-0x90, 0x98, 0x17, 0xF1, 0x6B, 0x90, 0x98, 0x18,
-0xF0, 0x22, 0xE4, 0xFF, 0x74, 0x18, 0xF1, 0xDA,
-0x74, 0x38, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xEE, 0xF0, 0x74, 0x10, 0xF1, 0xDA,
-0x74, 0x32, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x93,
-0xF5, 0x83, 0xEE, 0xF0, 0x0F, 0xEF, 0xB4, 0x06,
-0xDB, 0x22, 0x2F, 0xF5, 0x82, 0xE4, 0x34, 0x06,
-0xF5, 0x83, 0xE0, 0xFE, 0x22, 0x90, 0x99, 0x85,
-0x12, 0x82, 0x27, 0x12, 0xAF, 0x66, 0x12, 0x91,
-0xAD, 0x12, 0xDA, 0x82, 0x12, 0xBC, 0xF1, 0x4E,
-0xF0, 0xEF, 0xC3, 0x13, 0x30, 0xE0, 0x2E, 0x12,
-0x87, 0x9D, 0x90, 0x98, 0x25, 0x12, 0x87, 0xA3,
-0x90, 0x98, 0x26, 0xF0, 0x12, 0x02, 0x06, 0xFF,
-0x54, 0x04, 0xFE, 0x90, 0x98, 0x24, 0xE0, 0x54,
-0xFB, 0x4E, 0x12, 0x97, 0xCC, 0x90, 0x98, 0x27,
-0xF0, 0xEF, 0x54, 0x08, 0xFF, 0x90, 0x98, 0x24,
-0xE0, 0x54, 0xF7, 0x4F, 0xF0, 0x22, 0xD3, 0x10,
-0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x90, 0x9A, 0x2E,
-0xEF, 0xF0, 0x90, 0x93, 0x06, 0xE0, 0xFF, 0x12,
-0x7B, 0x07, 0x74, 0x10, 0x2F, 0xFF, 0x90, 0x9A,
-0x2E, 0xE0, 0x25, 0xE0, 0x25, 0xE0, 0x2F, 0xFF,
-0x12, 0x9F, 0x82, 0x75, 0x48, 0x04, 0x7B, 0x01,
-0x7A, 0x9A, 0x79, 0xF1, 0x12, 0x69, 0xF5, 0xD0,
+0x3A, 0x12, 0x87, 0xD1, 0xFF, 0xED, 0x2F, 0x90,
+0x98, 0x3B, 0x12, 0x87, 0x9B, 0xFF, 0xED, 0x2F,
+0x90, 0x98, 0x3C, 0x12, 0x87, 0xD8, 0x90, 0x98,
+0x3D, 0xF0, 0x22, 0x12, 0x87, 0xED, 0x2E, 0x90,
+0x98, 0x45, 0xF0, 0x12, 0x9C, 0x5A, 0xFF, 0xED,
+0x2F, 0x90, 0x98, 0x46, 0x12, 0x87, 0xE6, 0xFF,
+0xAE, 0x05, 0xED, 0x2F, 0x90, 0x98, 0x47, 0xF0,
+0x22, 0xEF, 0x60, 0x08, 0x90, 0x98, 0x38, 0xE0,
+0xFF, 0x12, 0x8D, 0x55, 0x22, 0xEF, 0x60, 0x0A,
+0x90, 0x06, 0x31, 0xE0, 0x44, 0x80, 0xF0, 0x12,
+0xC1, 0x36, 0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3,
+0xC0, 0xD0, 0x90, 0x9A, 0x5A, 0xEF, 0xF0, 0x90,
+0x93, 0x06, 0xE0, 0xFF, 0x12, 0x7B, 0x07, 0x74,
+0x10, 0x2F, 0xFF, 0x90, 0x9A, 0x5A, 0xE0, 0x25,
+0xE0, 0x25, 0xE0, 0x2F, 0xFF, 0x12, 0x8D, 0xC3,
+0x75, 0x48, 0x04, 0x7B, 0x01, 0x7A, 0x9B, 0x79,
+0x1D, 0x12, 0x69, 0xF5, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x90, 0x9B, 0x0D, 0xE0, 0xFE, 0x90, 0x9B, 0x0A,
+0xE0, 0xC3, 0x9E, 0x40, 0x04, 0x7F, 0x00, 0x80,
+0x0E, 0xEF, 0x60, 0x05, 0xD3, 0x94, 0x0E, 0x40,
+0x04, 0x7F, 0x00, 0x80, 0x02, 0x7F, 0x01, 0xD0,
 0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x90, 0x9A, 0xE1, 0xE0, 0xFE,
-0x90, 0x9A, 0xDE, 0xE0, 0xC3, 0x9E, 0x40, 0x04,
-0x7F, 0x00, 0x80, 0x0E, 0xEF, 0x60, 0x05, 0xD3,
-0x94, 0x0E, 0x40, 0x04, 0x7F, 0x00, 0x80, 0x02,
-0x7F, 0x01, 0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x12,
-0x8F, 0xE5, 0x90, 0x9A, 0xDC, 0xE0, 0x64, 0x01,
-0xF0, 0xE0, 0x24, 0x8F, 0x90, 0x01, 0xC4, 0xF0,
-0x74, 0xF0, 0xA3, 0x12, 0x8F, 0x10, 0x02, 0xAA,
-0x2D, 0xED, 0x14, 0x60, 0x06, 0x04, 0x70, 0x03,
-0x7F, 0x01, 0x22, 0x7F, 0x01, 0x22, 0x12, 0x8F,
-0xE5, 0xA3, 0xED, 0xF0, 0x90, 0x95, 0x6D, 0xE0,
-0x70, 0x02, 0xA3, 0xE0, 0x60, 0x2E, 0xE4, 0x90,
-0x9A, 0x0B, 0xF0, 0x31, 0x08, 0x50, 0x28, 0x12,
-0x8F, 0x11, 0xED, 0x24, 0x1C, 0x12, 0x8F, 0xB9,
-0x90, 0x9A, 0x0B, 0xE0, 0x24, 0x7B, 0xF5, 0x82,
-0xE4, 0x34, 0x95, 0xF5, 0x83, 0xE0, 0x6F, 0x60,
-0x03, 0x7F, 0x00, 0x22, 0x90, 0x9A, 0x0B, 0xE0,
-0x04, 0xF0, 0x80, 0xD7, 0x7F, 0x00, 0x22, 0x90,
-0x06, 0x32, 0xE0, 0x44, 0x40, 0xF0, 0xE4, 0x90,
-0x95, 0x79, 0xF0, 0xA3, 0xF0, 0x7F, 0x01, 0x22,
-0x90, 0x9A, 0x0B, 0xE0, 0xFD, 0xC3, 0x94, 0x02,
-0x22, 0x12, 0x8F, 0xE5, 0xA3, 0xED, 0xF0, 0xE4,
-0xA3, 0xF0, 0x31, 0x08, 0x50, 0x22, 0x12, 0x8F,
-0x11, 0xED, 0x24, 0x1C, 0x12, 0x8F, 0xB9, 0x90,
-0x9A, 0x0B, 0xE0, 0x24, 0x9B, 0xF5, 0x82, 0xE4,
-0x34, 0x95, 0xF5, 0x83, 0xE0, 0xB5, 0x07, 0x1D,
-0x90, 0x9A, 0x0B, 0xE0, 0x04, 0xF0, 0x80, 0xDA,
-0x90, 0x06, 0x32, 0xE0, 0x44, 0x80, 0xF0, 0x90,
-0x01, 0xC7, 0x74, 0x30, 0xF0, 0x7F, 0x01, 0x12,
-0xBC, 0x2E, 0x7F, 0x01, 0x22, 0x7F, 0x00, 0x22,
-0xAD, 0x07, 0x90, 0x95, 0x71, 0xE4, 0x75, 0xF0,
-0x01, 0x12, 0x02, 0xE7, 0x90, 0x95, 0x71, 0xE0,
-0xFF, 0xAE, 0x05, 0x74, 0x04, 0x2E, 0x12, 0xDE,
-0x8D, 0xEF, 0xF0, 0x90, 0x95, 0x71, 0xA3, 0xE0,
-0xFF, 0x74, 0x05, 0x2E, 0x12, 0xCF, 0xD7, 0xEF,
-0xF0, 0x22, 0x12, 0x8F, 0xE5, 0xE4, 0xA3, 0xF0,
-0x90, 0x9A, 0x0A, 0xE0, 0xFD, 0xC3, 0x94, 0x04,
-0x50, 0x29, 0x90, 0x9A, 0x09, 0xE0, 0x24, 0x10,
-0x12, 0x8D, 0x88, 0xFE, 0x12, 0x8F, 0xBA, 0x90,
-0x9A, 0x0A, 0xE0, 0x24, 0x73, 0xF5, 0x82, 0xE4,
+0xC3, 0xC0, 0xD0, 0x90, 0x9A, 0x5A, 0xEF, 0xF0,
+0x12, 0x76, 0x9B, 0xBF, 0x01, 0x27, 0x90, 0x06,
+0x32, 0xE0, 0x44, 0x08, 0xF0, 0x90, 0x9A, 0x5A,
+0xE0, 0xFF, 0x90, 0x92, 0x13, 0x74, 0x07, 0xF0,
+0x7B, 0x18, 0x7D, 0x01, 0x12, 0x66, 0xDB, 0x90,
+0x9A, 0x5B, 0xEE, 0xF0, 0xA3, 0xEF, 0xF0, 0x90,
+0x04, 0x1F, 0x74, 0x20, 0xF0, 0xD0, 0xD0, 0x92,
+0xAF, 0x22, 0xE4, 0xFD, 0xFC, 0x90, 0x01, 0x1D,
+0xE0, 0xFE, 0x90, 0x01, 0x1C, 0x12, 0xD7, 0x79,
+0x3E, 0x90, 0x9C, 0xBF, 0xF0, 0xA3, 0xEF, 0x12,
+0xCF, 0xCD, 0xE0, 0x24, 0x00, 0xFF, 0xEA, 0x3E,
+0x90, 0x9C, 0xC1, 0xF0, 0xA3, 0xEF, 0xF0, 0xD1,
+0x18, 0x90, 0x9C, 0xBF, 0xE0, 0xFA, 0xA3, 0xE0,
+0xFB, 0xB5, 0x07, 0x06, 0xEA, 0xB5, 0x06, 0x02,
+0x80, 0x3D, 0xD1, 0x18, 0xD3, 0xEB, 0x9F, 0xEA,
+0x9E, 0x40, 0x0E, 0x90, 0x9C, 0xC0, 0xE0, 0x9F,
+0xFD, 0x90, 0x9C, 0xBF, 0xE0, 0x9E, 0xFC, 0x80,
+0x26, 0xD1, 0x18, 0xC3, 0x90, 0x9C, 0xC0, 0xE0,
+0x9F, 0x90, 0x9C, 0xBF, 0xE0, 0x9E, 0x50, 0x17,
+0x12, 0xC7, 0x9B, 0x90, 0x9C, 0xC2, 0xE0, 0x9F,
+0xFF, 0x90, 0x9C, 0xC1, 0xE0, 0x9E, 0xFE, 0xC3,
+0xE4, 0x9F, 0xFD, 0x74, 0x40, 0x9E, 0xFC, 0xD3,
+0xED, 0x94, 0x00, 0xEC, 0x94, 0x38, 0x40, 0x05,
+0x12, 0xCF, 0x70, 0xF0, 0x22, 0xC3, 0xEC, 0x94,
+0x08, 0x50, 0x0C, 0xED, 0x94, 0x00, 0xEC, 0x94,
+0x00, 0x40, 0x04, 0x12, 0xCF, 0x69, 0xF0, 0x22,
+0x90, 0x9C, 0xC1, 0xE0, 0xFE, 0xA3, 0xE0, 0xFF,
+0x22, 0x12, 0xE8, 0x98, 0x90, 0x9B, 0x08, 0xE0,
+0x64, 0x01, 0xF0, 0xE0, 0x24, 0x21, 0x90, 0x01,
+0xC4, 0xF0, 0x74, 0xF6, 0xA3, 0x12, 0xAF, 0x1A,
+0x02, 0xA0, 0x14, 0xED, 0x14, 0x60, 0x06, 0x04,
+0x70, 0x03, 0x7F, 0x01, 0x22, 0x7F, 0x01, 0x22,
+0x12, 0xE8, 0x98, 0xA3, 0xED, 0xF0, 0x90, 0x95,
+0x99, 0xE0, 0x70, 0x02, 0xA3, 0xE0, 0x60, 0x2E,
+0xE4, 0x90, 0x9A, 0x37, 0xF0, 0xD1, 0x9A, 0x50,
+0x28, 0x12, 0xAF, 0x1B, 0xED, 0x24, 0x1C, 0x12,
+0xAF, 0xC6, 0x90, 0x9A, 0x37, 0xE0, 0x24, 0xA7,
+0xF5, 0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0xE0,
+0x6F, 0x60, 0x03, 0x7F, 0x00, 0x22, 0x90, 0x9A,
+0x37, 0xE0, 0x04, 0xF0, 0x80, 0xD7, 0x7F, 0x00,
+0x22, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x40, 0xF0,
+0xE4, 0x90, 0x95, 0xA5, 0xF0, 0xA3, 0xF0, 0x7F,
+0x01, 0x22, 0x90, 0x9A, 0x37, 0xE0, 0xFD, 0xC3,
+0x94, 0x02, 0x22, 0x12, 0xE8, 0x98, 0xA3, 0xED,
+0xF0, 0xE4, 0xA3, 0xF0, 0xD1, 0x9A, 0x50, 0x22,
+0x12, 0xAF, 0x1B, 0xED, 0x24, 0x1C, 0x12, 0xAF,
+0xC6, 0x90, 0x9A, 0x37, 0xE0, 0x24, 0xC7, 0xF5,
+0x82, 0xE4, 0x34, 0x95, 0xF5, 0x83, 0xE0, 0xB5,
+0x07, 0x1D, 0x90, 0x9A, 0x37, 0xE0, 0x04, 0xF0,
+0x80, 0xDA, 0x90, 0x06, 0x32, 0xE0, 0x44, 0x80,
+0xF0, 0x90, 0x01, 0xC7, 0x74, 0x30, 0xF0, 0x7F,
+0x01, 0x12, 0xAD, 0x5E, 0x7F, 0x01, 0x22, 0x7F,
+0x00, 0x22, 0x12, 0xE8, 0x98, 0xE4, 0xA3, 0xF0,
+0x90, 0x9A, 0x36, 0xE0, 0xFD, 0xC3, 0x94, 0x04,
+0x50, 0x29, 0x90, 0x9A, 0x35, 0xE0, 0x24, 0x10,
+0x12, 0xA6, 0x31, 0xFE, 0x12, 0xAF, 0xC7, 0x90,
+0x9A, 0x36, 0xE0, 0x24, 0x9F, 0xF5, 0x82, 0xE4,
 0x34, 0x95, 0xF5, 0x83, 0xE0, 0x6F, 0x60, 0x03,
-0x7F, 0x00, 0x22, 0x90, 0x9A, 0x0A, 0xE0, 0x04,
-0xF0, 0x80, 0xCD, 0x7F, 0x01, 0x22, 0x7E, 0x00,
-0x7F, 0x62, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x88,
-0x79, 0x31, 0x12, 0x04, 0x80, 0x51, 0xBF, 0x79,
-0x08, 0x12, 0x04, 0x80, 0xE4, 0x90, 0x99, 0x83,
-0xF0, 0x90, 0x88, 0x35, 0x74, 0x02, 0xF0, 0x90,
-0x88, 0x3C, 0x14, 0xF0, 0xA3, 0xF0, 0xA3, 0x74,
-0x50, 0xF0, 0x90, 0x88, 0x42, 0xE4, 0xF0, 0xA3,
-0x74, 0x02, 0xF0, 0x90, 0x88, 0x4E, 0x74, 0x10,
-0xF0, 0xA3, 0x74, 0x50, 0xF0, 0x51, 0xCA, 0x90,
-0x8A, 0x89, 0x12, 0x97, 0x5E, 0xE4, 0xFD, 0xFF,
-0x12, 0x04, 0x7E, 0x90, 0x8A, 0x89, 0x12, 0x97,
-0x5E, 0x7D, 0x0C, 0x7F, 0x02, 0x12, 0x04, 0x7E,
-0x90, 0x8A, 0x89, 0x12, 0x97, 0x5E, 0x7D, 0x0C,
-0x7F, 0x01, 0x12, 0x04, 0x7E, 0x90, 0x86, 0xB3,
-0xE0, 0xFF, 0xB4, 0x01, 0x08, 0x90, 0x88, 0x41,
-0x74, 0xD4, 0xF0, 0x80, 0x18, 0xEF, 0xB4, 0x03,
-0x0F, 0x90, 0x88, 0x41, 0x74, 0xF4, 0xF0, 0x90,
-0x00, 0x92, 0xE0, 0x54, 0x7F, 0xF0, 0x80, 0x05,
-0xE4, 0x90, 0x88, 0x41, 0xF0, 0x90, 0x00, 0x79,
-0xE0, 0x54, 0x03, 0xFF, 0xBF, 0x02, 0x0D, 0x90,
-0x00, 0x28, 0xE0, 0x30, 0xE2, 0x06, 0x90, 0x88,
-0x53, 0x74, 0x02, 0xF0, 0x90, 0x88, 0x93, 0x74,
-0x03, 0xF0, 0xA3, 0x74, 0x0F, 0xF0, 0xA3, 0xE0,
-0x54, 0x01, 0x44, 0x28, 0xF0, 0xA3, 0x74, 0x07,
-0xF0, 0x7E, 0x00, 0x7F, 0x18, 0x7D, 0x00, 0x7B,
-0x01, 0x7A, 0x93, 0x79, 0x0C, 0x12, 0x04, 0x80,
-0x90, 0x8A, 0xA3, 0x12, 0x97, 0x5E, 0x7F, 0x01,
-0x12, 0x04, 0x7E, 0x90, 0x05, 0x58, 0x74, 0x02,
-0xF0, 0x7E, 0x00, 0xFF, 0x7D, 0x00, 0x7B, 0x01,
-0x7A, 0x88, 0x79, 0x9A, 0x12, 0x04, 0x80, 0x90,
-0x06, 0x04, 0xE0, 0x54, 0x7F, 0xF0, 0x90, 0x06,
-0x0A, 0xE0, 0x54, 0xF8, 0xF0, 0x90, 0x05, 0x22,
-0xE4, 0xF0, 0x90, 0x88, 0x9C, 0xF0, 0x22, 0x7E,
-0x00, 0x7F, 0x04, 0x7D, 0x00, 0x7B, 0x01, 0x7A,
-0x93, 0x22, 0x90, 0x88, 0x8D, 0x74, 0x18, 0xF0,
-0xA3, 0xF0, 0xA3, 0xE4, 0xF0, 0xA3, 0x74, 0x64,
-0xF0, 0xA3, 0x74, 0x05, 0xF0, 0xA3, 0xF0, 0x22,
-0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0, 0x12,
-0x7A, 0x65, 0xEF, 0x64, 0x01, 0x60, 0x05, 0x75,
-0x14, 0x01, 0x80, 0x25, 0x90, 0x88, 0x31, 0x12,
-0xB2, 0xDA, 0x30, 0xE0, 0x05, 0x75, 0x14, 0x02,
-0x80, 0x17, 0x90, 0x88, 0x38, 0xE0, 0xD3, 0x94,
-0x04, 0x40, 0x05, 0x75, 0x14, 0x08, 0x80, 0x09,
-0x90, 0x01, 0xB8, 0xE4, 0xF0, 0x7F, 0x01, 0x80,
-0x0E, 0x90, 0x01, 0xB9, 0x74, 0x02, 0xF0, 0x90,
-0x01, 0xB8, 0xE5, 0x14, 0xF0, 0x7F, 0x00, 0xD0,
-0xD0, 0x92, 0xAF, 0x22, 0xD3, 0x10, 0xAF, 0x01,
-0xC3, 0xC0, 0xD0, 0x12, 0x7A, 0x65, 0xEF, 0x64,
-0x01, 0x60, 0x05, 0x75, 0x15, 0x01, 0x80, 0x75,
-0x90, 0x88, 0x3A, 0xE0, 0xFF, 0x54, 0x03, 0x60,
-0x05, 0x75, 0x15, 0x02, 0x80, 0x67, 0x90, 0x88,
-0x38, 0xE0, 0xFE, 0xE4, 0xC3, 0x9E, 0x50, 0x05,
-0x75, 0x15, 0x04, 0x80, 0x58, 0xEF, 0x30, 0xE2,
-0x05, 0x75, 0x15, 0x08, 0x80, 0x4F, 0x90, 0x88,
-0x3A, 0xE0, 0x30, 0xE4, 0x05, 0x75, 0x15, 0x10,
-0x80, 0x43, 0x90, 0x88, 0x32, 0xE0, 0x13, 0x13,
-0x54, 0x3F, 0x20, 0xE0, 0x05, 0x75, 0x15, 0x20,
-0x80, 0x33, 0x90, 0x88, 0x9C, 0xE0, 0x60, 0x05,
-0x75, 0x15, 0x80, 0x80, 0x28, 0x90, 0x06, 0x62,
-0xE0, 0x30, 0xE1, 0x05, 0x75, 0x15, 0x11, 0x80,
-0x1C, 0x90, 0x06, 0x62, 0xE0, 0x30, 0xE0, 0x0C,
-0xE0, 0x54, 0xFC, 0xFF, 0xBF, 0x80, 0x05, 0x75,
-0x15, 0x12, 0x80, 0x09, 0x90, 0x01, 0xB8, 0xE4,
-0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90, 0x01, 0xB9,
-0x74, 0x04, 0xF0, 0x90, 0x01, 0xB8, 0xE5, 0x15,
-0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF, 0x22,
-0x90, 0x93, 0x08, 0xE0, 0xC3, 0x13, 0x20, 0xE0,
-0x36, 0x90, 0x02, 0x87, 0xE0, 0x60, 0x02, 0x80,
-0x08, 0x90, 0x01, 0x00, 0xE0, 0x64, 0x3F, 0x60,
-0x05, 0x75, 0x0D, 0x01, 0x80, 0x34, 0x90, 0x93,
-0x31, 0xE0, 0x30, 0xE0, 0x05, 0x75, 0x0D, 0x08,
-0x80, 0x28, 0x90, 0x02, 0x86, 0xE0, 0x20, 0xE1,
-0x02, 0x80, 0x07, 0x90, 0x02, 0x86, 0xE0, 0x30,
-0xE3, 0x05, 0x75, 0x0D, 0x04, 0x80, 0x13, 0x90,
-0x04, 0x1D, 0xE0, 0x60, 0x05, 0x75, 0x0D, 0x40,
-0x80, 0x08, 0x90, 0x01, 0xB8, 0xE4, 0xF0, 0x7F,
-0x01, 0x22, 0x90, 0x01, 0xB9, 0x74, 0x08, 0xF0,
-0x90, 0x01, 0xB8, 0xE5, 0x0D, 0xF0, 0x7F, 0x00,
-0x22, 0x90, 0x99, 0x83, 0x74, 0x01, 0xF0, 0x90,
-0x06, 0x92, 0x04, 0xF0, 0x90, 0x01, 0x3C, 0x74,
-0x04, 0xF0, 0x90, 0x88, 0x31, 0xE0, 0x44, 0x08,
-0xF0, 0x90, 0x88, 0x39, 0xE0, 0x64, 0x0C, 0x60,
-0x19, 0x90, 0x8A, 0xB9, 0x12, 0x97, 0x5E, 0xE4,
-0xFD, 0x7F, 0x0C, 0x12, 0x04, 0x7E, 0x90, 0x8A,
-0xF9, 0x12, 0x97, 0x5E, 0xE4, 0xFD, 0xFF, 0x12,
-0x04, 0x7E, 0x90, 0x8A, 0xAF, 0x12, 0x97, 0x5E,
-0x7D, 0x08, 0xE4, 0xFF, 0x02, 0x04, 0x7E, 0x91,
-0xB6, 0x9F, 0x40, 0x41, 0x90, 0x88, 0x50, 0xE0,
-0x04, 0xF0, 0x90, 0x88, 0x92, 0xE0, 0xFF, 0x90,
-0x88, 0x50, 0xE0, 0xD3, 0x9F, 0x50, 0x2E, 0x90,
-0x88, 0x48, 0xE0, 0x24, 0x08, 0xF0, 0x90, 0x88,
-0x3F, 0x12, 0xB2, 0xE3, 0x33, 0x33, 0x33, 0x54,
-0xF8, 0xFF, 0x90, 0x88, 0x3E, 0xE0, 0x2F, 0x90,
-0x88, 0x4F, 0xF0, 0xFB, 0x90, 0x88, 0x48, 0xE0,
-0xFF, 0xA3, 0xE0, 0xFD, 0x90, 0x92, 0x98, 0x74,
-0x03, 0xF0, 0x12, 0x6E, 0x2F, 0x22, 0x90, 0x88,
-0x93, 0xE0, 0xFF, 0x90, 0x88, 0x3F, 0xE0, 0xD3,
-0x22, 0x90, 0x93, 0x08, 0xE0, 0x30, 0xE0, 0x09,
-0x90, 0x01, 0x3B, 0xE0, 0x30, 0xE4, 0x02, 0x91,
-0xD2, 0x22, 0x7D, 0x02, 0x7F, 0x02, 0x12, 0x7C,
-0x7E, 0x7D, 0x01, 0x7F, 0x02, 0x02, 0x7C, 0x7E,
-0x90, 0x05, 0x63, 0xE0, 0x90, 0x88, 0x89, 0xF0,
-0x90, 0x05, 0x62, 0xE0, 0x90, 0x88, 0x8A, 0xF0,
-0x90, 0x05, 0x61, 0xE0, 0x90, 0x88, 0x8B, 0xF0,
-0x90, 0x05, 0x60, 0xE0, 0x90, 0x88, 0x8C, 0xF0,
-0x90, 0x88, 0x32, 0xE0, 0x44, 0x80, 0xF0, 0x22,
-0x90, 0x99, 0x85, 0xA3, 0xE0, 0x24, 0x01, 0xF5,
-0x82, 0xE4, 0x34, 0xFC, 0x22, 0x90, 0x99, 0x85,
-0xA3, 0xE0, 0x24, 0x03, 0xF5, 0x82, 0xE4, 0x34,
-0xFC, 0x22, 0x90, 0x99, 0x85, 0xA3, 0xE0, 0xFF,
-0xA3, 0xE0, 0xFE, 0x2F, 0x22, 0x54, 0xFB, 0xF0,
-0x90, 0x88, 0x3A, 0xE0, 0x54, 0xFD, 0xF0, 0x22,
-0xFF, 0xEC, 0x3E, 0x90, 0x9A, 0x11, 0xF0, 0xA3,
-0xEF, 0xF0, 0x22, 0x7D, 0x01, 0x7E, 0x00, 0x7F,
-0x10, 0x12, 0x83, 0xDC, 0xEF, 0x22, 0x90, 0x93,
-0x09, 0xE0, 0x14, 0x90, 0x93, 0x0B, 0xF0, 0x22,
-0x74, 0xCD, 0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95,
-0x22, 0x90, 0x93, 0x0A, 0xE0, 0x90, 0x05, 0x73,
-0xF0, 0x22, 0x90, 0x88, 0x38, 0xE0, 0x90, 0x9A,
-0xF6, 0xF0, 0x22, 0x7E, 0x00, 0x7F, 0x08, 0x7D,
-0x00, 0x7B, 0x01, 0x22, 0x90, 0x9A, 0x32, 0xE0,
-0xFF, 0x75, 0xF0, 0x38, 0x22, 0xE0, 0x24, 0x0B,
-0xF5, 0x82, 0xE4, 0x34, 0x9A, 0x22, 0x78, 0x11,
-0x7C, 0x9A, 0x7D, 0x01, 0x7B, 0xFF, 0x22, 0x90,
-0x88, 0x3C, 0xE0, 0x90, 0x05, 0x73, 0x22, 0xE0,
-0xFF, 0xC4, 0x13, 0x13, 0x54, 0x03, 0x22, 0x90,
-0x93, 0x61, 0x12, 0x04, 0x6E, 0xE0, 0x22, 0x7E,
-0x00, 0x7F, 0x10, 0x02, 0x01, 0xE0, 0x90, 0x88,
-0x31, 0xE0, 0x54, 0xF7, 0xF0, 0x22, 0x1A, 0x7F
+0x7F, 0x00, 0x22, 0x90, 0x9A, 0x36, 0xE0, 0x04,
+0xF0, 0x80, 0xCD, 0x7F, 0x01, 0x22, 0x12, 0xE8,
+0x98, 0x24, 0x16, 0xFF, 0xE4, 0x3E, 0x12, 0xA2,
+0x3B, 0x90, 0x95, 0xA3, 0xA3, 0xE0, 0xB5, 0x07,
+0x1E, 0x90, 0x9A, 0x35, 0xE0, 0x24, 0x16, 0x12,
+0xA6, 0x31, 0xFE, 0x12, 0xAC, 0x4E, 0x7D, 0x01,
+0x12, 0x04, 0x7E, 0xEF, 0xFD, 0x90, 0x95, 0xA3,
+0xE0, 0x6D, 0x70, 0x01, 0xE4, 0x60, 0x03, 0x7F,
+0x00, 0x22, 0x7F, 0x01, 0x22, 0xD3, 0x10, 0xAF,
+0x01, 0xC3, 0xC0, 0xD0, 0x12, 0x7A, 0x65, 0xEF,
+0x64, 0x01, 0x60, 0x05, 0x75, 0x14, 0x01, 0x80,
+0x25, 0x90, 0x88, 0x31, 0x12, 0x97, 0xD1, 0x30,
+0xE0, 0x05, 0x75, 0x14, 0x02, 0x80, 0x17, 0x90,
+0x88, 0x38, 0xE0, 0xD3, 0x94, 0x04, 0x40, 0x05,
+0x75, 0x14, 0x08, 0x80, 0x09, 0x90, 0x01, 0xB8,
+0xE4, 0xF0, 0x7F, 0x01, 0x80, 0x0E, 0x90, 0x01,
+0xB9, 0x74, 0x02, 0xF0, 0x90, 0x01, 0xB8, 0xE5,
+0x14, 0xF0, 0x7F, 0x00, 0xD0, 0xD0, 0x92, 0xAF,
+0x22, 0xD3, 0x10, 0xAF, 0x01, 0xC3, 0xC0, 0xD0,
+0x12, 0x7A, 0x65, 0xEF, 0x64, 0x01, 0x60, 0x05,
+0x75, 0x15, 0x01, 0x80, 0x75, 0x90, 0x88, 0x3A,
+0xE0, 0xFF, 0x54, 0x03, 0x60, 0x05, 0x75, 0x15,
+0x02, 0x80, 0x67, 0x90, 0x88, 0x38, 0xE0, 0xFE,
+0xE4, 0xC3, 0x9E, 0x50, 0x05, 0x75, 0x15, 0x04,
+0x80, 0x58, 0xEF, 0x30, 0xE2, 0x05, 0x75, 0x15,
+0x08, 0x80, 0x4F, 0x90, 0x88, 0x3A, 0xE0, 0x30,
+0xE4, 0x05, 0x75, 0x15, 0x10, 0x80, 0x43, 0x90,
+0x88, 0x32, 0xE0, 0x13, 0x13, 0x54, 0x3F, 0x20,
+0xE0, 0x05, 0x75, 0x15, 0x20, 0x80, 0x33, 0x90,
+0x88, 0x9C, 0xE0, 0x60, 0x05, 0x75, 0x15, 0x80,
+0x80, 0x28, 0x90, 0x06, 0x62, 0xE0, 0x30, 0xE1,
+0x05, 0x75, 0x15, 0x11, 0x80, 0x1C, 0x90, 0x06,
+0x62, 0xE0, 0x30, 0xE0, 0x0C, 0xE0, 0x54, 0xFC,
+0xFF, 0xBF, 0x80, 0x05, 0x75, 0x15, 0x12, 0x80,
+0x09, 0x90, 0x01, 0xB8, 0xE4, 0xF0, 0x7F, 0x01,
+0x80, 0x0E, 0x90, 0x01, 0xB9, 0x74, 0x04, 0xF0,
+0x90, 0x01, 0xB8, 0xE5, 0x15, 0xF0, 0x7F, 0x00,
+0xD0, 0xD0, 0x92, 0xAF, 0x22, 0x90, 0x93, 0x08,
+0xE0, 0xC3, 0x13, 0x20, 0xE0, 0x36, 0x90, 0x02,
+0x87, 0xE0, 0x60, 0x02, 0x80, 0x08, 0x90, 0x01,
+0x00, 0xE0, 0x64, 0x3F, 0x60, 0x05, 0x75, 0x0D,
+0x01, 0x80, 0x34, 0x90, 0x93, 0x31, 0xE0, 0x30,
+0xE0, 0x05, 0x75, 0x0D, 0x08, 0x80, 0x28, 0x90,
+0x02, 0x86, 0xE0, 0x20, 0xE1, 0x02, 0x80, 0x07,
+0x90, 0x02, 0x86, 0xE0, 0x30, 0xE3, 0x05, 0x75,
+0x0D, 0x04, 0x80, 0x13, 0x90, 0x04, 0x1D, 0xE0,
+0x60, 0x05, 0x75, 0x0D, 0x40, 0x80, 0x08, 0x90,
+0x01, 0xB8, 0xE4, 0xF0, 0x7F, 0x01, 0x22, 0x90,
+0x01, 0xB9, 0x74, 0x08, 0xF0, 0x90, 0x01, 0xB8,
+0xE5, 0x0D, 0xF0, 0x7F, 0x00, 0x22, 0x90, 0x88,
+0x8D, 0x74, 0x18, 0xF0, 0xA3, 0xF0, 0xA3, 0xE4,
+0xF0, 0xA3, 0x74, 0x64, 0xF0, 0xA3, 0x74, 0x05,
+0xF0, 0xA3, 0xF0, 0x22, 0x12, 0xB7, 0xDF, 0x9F,
+0x40, 0x41, 0x90, 0x88, 0x50, 0xE0, 0x04, 0xF0,
+0x90, 0x88, 0x92, 0xE0, 0xFF, 0x90, 0x88, 0x50,
+0xE0, 0xD3, 0x9F, 0x50, 0x2E, 0x90, 0x88, 0x48,
+0xE0, 0x24, 0x08, 0xF0, 0x90, 0x88, 0x3F, 0x12,
+0x97, 0xEB, 0x33, 0x33, 0x33, 0x54, 0xF8, 0xFF,
+0x90, 0x88, 0x3E, 0xE0, 0x2F, 0x90, 0x88, 0x4F,
+0xF0, 0xFB, 0x90, 0x88, 0x48, 0xE0, 0xFF, 0xA3,
+0xE0, 0xFD, 0x90, 0x92, 0x98, 0x74, 0x03, 0xF0,
+0x12, 0x6E, 0x2F, 0x22, 0x90, 0x93, 0x08, 0xE0,
+0x30, 0xE0, 0x09, 0x90, 0x01, 0x3B, 0xE0, 0x30,
+0xE4, 0x02, 0x31, 0x15, 0x22, 0x7D, 0x02, 0x7F,
+0x02, 0x12, 0x7C, 0x7E, 0x7D, 0x01, 0x7F, 0x02,
+0x02, 0x7C, 0x7E, 0x90, 0x9A, 0x5E, 0xE4, 0x75,
+0xF0, 0x08, 0x12, 0x02, 0xE7, 0x90, 0x9A, 0x5E,
+0xE4, 0x75, 0xF0, 0x08, 0x02, 0x02, 0xE7, 0x90,
+0x05, 0x63, 0xE0, 0x90, 0x88, 0x89, 0xF0, 0x90,
+0x05, 0x62, 0xE0, 0x90, 0x88, 0x8A, 0xF0, 0x90,
+0x05, 0x61, 0xE0, 0x90, 0x88, 0x8B, 0xF0, 0x90,
+0x05, 0x60, 0xE0, 0x90, 0x88, 0x8C, 0xF0, 0x90,
+0x88, 0x32, 0xE0, 0x44, 0x80, 0xF0, 0x22, 0x90,
+0x86, 0xB6, 0xE0, 0xFF, 0x90, 0x9C, 0xA7, 0xE0,
+0xFB, 0x90, 0x92, 0x13, 0x74, 0x0A, 0xF0, 0x7D,
+0x01, 0x12, 0x66, 0xDB, 0x90, 0x9C, 0xA8, 0xEE,
+0xF0, 0xFC, 0xA3, 0xEF, 0xF0, 0xFD, 0x90, 0x9C,
+0xA6, 0xE0, 0xFF, 0x90, 0x8A, 0x95, 0x22, 0xEF,
+0x75, 0xF0, 0x0A, 0xA4, 0x24, 0x93, 0xF5, 0x82,
+0xE4, 0x34, 0x9B, 0xF5, 0x83, 0x22, 0x90, 0x98,
+0x3A, 0xE0, 0xFF, 0x90, 0x92, 0x13, 0x74, 0x08,
+0xF0, 0x7B, 0x18, 0x7D, 0x01, 0x12, 0x66, 0xDB,
+0x90, 0x9A, 0x59, 0xEF, 0xF0, 0x90, 0x98, 0x3A,
+0xE0, 0x22, 0x90, 0x88, 0x48, 0xE0, 0xFF, 0xA3,
+0xE0, 0xFD, 0x90, 0x88, 0x4F, 0xE0, 0xFB, 0x90,
+0x92, 0x98, 0x22, 0x90, 0x8A, 0x77, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0xF5, 0x82, 0x8E, 0x83, 0x02,
+0x04, 0x7E, 0xF0, 0xA3, 0xEF, 0xF0, 0x74, 0x02,
+0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83,
+0xE0, 0x54, 0x0F, 0x33, 0x33, 0x33, 0x54, 0xF8,
+0xFF, 0x90, 0x98, 0x6C, 0xE0, 0x22, 0x74, 0x00,
+0x2F, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x7B, 0x01,
+0x22, 0x90, 0x9C, 0xA6, 0xE0, 0xFF, 0x90, 0x8A,
+0xC7, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xF5, 0x82,
+0x8C, 0x83, 0x22, 0x90, 0x9A, 0x5F, 0xE0, 0x2F,
+0xFF, 0x90, 0x9A, 0x5E, 0xE0, 0x34, 0x00, 0xFE,
+0x90, 0x9A, 0xE2, 0xF0, 0x22, 0xA3, 0xE0, 0x24,
+0x28, 0xF9, 0xE4, 0x34, 0xFC, 0xFA, 0x22, 0x90,
+0x9A, 0x5B, 0xE0, 0xFF, 0x24, 0x42, 0xF5, 0x82,
+0xE4, 0x34, 0x94, 0xF5, 0x83, 0xE0, 0x22, 0x90,
+0x88, 0x28, 0xE0, 0x24, 0x01, 0xFF, 0x90, 0x88,
+0x27, 0xE0, 0x34, 0x00, 0xFE, 0xC3, 0x22, 0x90,
+0x9C, 0x01, 0xA3, 0xE0, 0x24, 0x04, 0xF5, 0x82,
+0xE4, 0x34, 0xFB, 0xF5, 0x83, 0xE0, 0x22, 0xEE,
+0x8F, 0xF0, 0x12, 0x02, 0xE7, 0x90, 0x88, 0x27,
+0xE0, 0xFE, 0xA3, 0xE0, 0xFF, 0x22, 0x74, 0x03,
+0x2D, 0xF5, 0x82, 0xE4, 0x34, 0xFB, 0xF5, 0x83,
+0xE0, 0x54, 0x03, 0xFE, 0x22, 0xE0, 0x90, 0x01,
+0xBA, 0xF0, 0x90, 0x88, 0x38, 0xE0, 0x90, 0x01,
+0xBB, 0xF0, 0x22, 0xFF, 0x90, 0x9A, 0x3B, 0xE0,
+0x34, 0x00, 0xFE, 0x22, 0xE0, 0x24, 0x3D, 0xF5,
+0x82, 0xE4, 0x34, 0x9A, 0x22, 0x7E, 0x00, 0x7F,
+0x04, 0x7D, 0x00, 0x7B, 0x01, 0x7A, 0x93, 0x79,
+0x08, 0x22, 0x90, 0x9C, 0x42, 0x12, 0x82, 0x27,
+0xE4, 0x90, 0x9C, 0x45, 0xF0, 0xA3, 0x22, 0x24,
+0x28, 0xF5, 0x82, 0xE4, 0x34, 0xFC, 0xF5, 0x83,
+0xE0, 0x22, 0x90, 0x9A, 0x5E, 0xE4, 0x75, 0xF0,
+0x02, 0x02, 0x02, 0xE7, 0xFF, 0xEC, 0x3E, 0x90,
+0x9A, 0x3D, 0xF0, 0xA3, 0xEF, 0xF0, 0x22, 0xCF,
+0x34, 0x00, 0x90, 0x9A, 0x39, 0xF0, 0xA3, 0xEF,
+0xF0, 0x22, 0xE4, 0xFF, 0x12, 0x8D, 0x1E, 0x90,
+0x04, 0x1F, 0x74, 0x20, 0x22, 0x90, 0x98, 0x6B,
+0xE0, 0xFF, 0x90, 0x98, 0x6A, 0xE0, 0x4F, 0x22,
+0xFD, 0x12, 0x7B, 0x8B, 0x90, 0x9A, 0x59, 0xEF,
+0xF0, 0x22, 0xF0, 0x90, 0x9A, 0x5B, 0xE0, 0x04,
+0x22, 0x75, 0x46, 0x94, 0x75, 0x47, 0x40, 0x75,
+0x48, 0x02, 0x22, 0x12, 0x69, 0xF5, 0x75, 0x45,
+0x01, 0x22, 0xFB, 0xC3, 0xED, 0x9B, 0xFD, 0xEC,
+0x94, 0x00, 0xFC, 0x22, 0x24, 0xA8, 0xFF, 0xE4,
+0x34, 0x01, 0xFE, 0x7B, 0x01, 0x22, 0x74, 0xF9,
+0x2E, 0xF5, 0x82, 0xE4, 0x34, 0x95, 0x22, 0x90,
+0x88, 0x38, 0xE0, 0x90, 0x9B, 0x22, 0xF0, 0x22,
+0x90, 0x9A, 0x5B, 0xE0, 0xFF, 0xC3, 0x94, 0x10,
+0x22, 0x90, 0x9A, 0x3F, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFF, 0x22, 0x90, 0x9B, 0xFD, 0xE0, 0xFC, 0xA3,
+0xE0, 0xFD, 0x22, 0x90, 0x9B, 0xFF, 0xE0, 0xFE,
+0xA3, 0xE0, 0xFF, 0x22, 0xE0, 0x24, 0x37, 0xF5,
+0x82, 0xE4, 0x34, 0x9A, 0x22, 0x78, 0x3D, 0x7C,
+0x9A, 0x7D, 0x01, 0x7B, 0xFF, 0x22, 0x7D, 0x02,
+0x7F, 0x02, 0x02, 0x04, 0x7E, 0x90, 0x88, 0x33,
+0xE0, 0x54, 0xFE, 0xF0, 0x22, 0x90, 0x9A, 0xE5,
+0xE0, 0xC3, 0x94, 0x0A, 0x22, 0x74, 0x10, 0xF0,
+0x7A, 0x93, 0x79, 0xF9, 0x22, 0x12, 0x82, 0x27,
+0x7A, 0x9A, 0x79, 0x45, 0x22, 0x7F, 0x64, 0x7E,
+0x00, 0x02, 0x7C, 0x6A, 0xE0, 0xFE, 0xA3, 0xE0,
+0xFD, 0xED, 0xFF, 0x22, 0x7F, 0xF9, 0x7E, 0x01,
+0x02, 0x5F, 0xA6, 0x00, 0x4F, 0x1E
 };
 
-u32 array_length_mp_8723d_fw_wowlan = 30176;
+u32 array_length_mp_8723d_fw_wowlan = 31694;
 
 #endif /*CONFIG_WOWLAN*/
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.h
index e890c251818f..a4b91afbf8b2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/hal8723d_fw.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
 *
 * Copyright(c) 2012 - 2017 Realtek Corporation.
@@ -20,15 +21,15 @@
 
 #ifdef LOAD_FW_HEADER_FROM_DRIVER
 #if (defined(CONFIG_AP_WOWLAN) || (DM_ODM_SUPPORT_TYPE & (ODM_AP)))
-extern u8 array_mp_8723d_fw_ap[24014];
+extern u8 array_mp_8723d_fw_ap[24796];
 extern u32 array_length_mp_8723d_fw_ap;
 #endif
 
 #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN)) || (DM_ODM_SUPPORT_TYPE & (ODM_CE))
-extern u8 array_mp_8723d_fw_nic[27726];
+extern u8 array_mp_8723d_fw_nic[28284];
 extern u32 array_length_mp_8723d_fw_nic;
 #ifdef CONFIG_WOWLAN
-extern u8 array_mp_8723d_fw_wowlan[30176];
+extern u8 array_mp_8723d_fw_wowlan[31694];
 extern u32 array_length_mp_8723d_fw_wowlan;
 #endif /*CONFIG_WOWLAN*/
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_cmd.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_cmd.c
index 56614a9bd583..059f669da02a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_cmd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_cmd.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -135,203 +136,6 @@ exit:
 	return ret;
 }
 
-static void ConstructBeacon(_adapter *padapter, u8 *pframe, u32 *pLength)
-{
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16					*fctrl;
-	u32					rate_len, pktlen;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX		*cur_network = &(pmlmeinfo->network);
-	u8	bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-
-
-	/* RTW_INFO("%s\n", __FUNCTION__); */
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-
-	_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
-
-	SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
-	/* pmlmeext->mgnt_seq++; */
-	set_frame_sub_type(pframe, WIFI_BEACON);
-
-	pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
-	pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-
-	/* timestamp will be inserted by hardware */
-	pframe += 8;
-	pktlen += 8;
-
-	/* beacon interval: 2 bytes */
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
-
-	pframe += 2;
-	pktlen += 2;
-
-	/* capability info: 2 bytes */
-	_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
-
-	pframe += 2;
-	pktlen += 2;
-
-	if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
-		/* RTW_INFO("ie len=%d\n", cur_network->IELength); */
-		pktlen += cur_network->IELength - sizeof(NDIS_802_11_FIXED_IEs);
-		_rtw_memcpy(pframe, cur_network->IEs + sizeof(NDIS_802_11_FIXED_IEs), pktlen);
-
-		goto _ConstructBeacon;
-	}
-
-	/* below for ad-hoc mode */
-
-	/* SSID */
-	pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pktlen);
-
-	/* supported rates... */
-	rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
-	pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pktlen);
-
-	/* DS parameter set */
-	pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pktlen);
-
-	if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
-		u32 ATIMWindow;
-		/* IBSS Parameter Set... */
-		/* ATIMWindow = cur->Configuration.ATIMWindow; */
-		ATIMWindow = 0;
-		pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pktlen);
-	}
-
-
-	/* todo: ERP IE */
-
-
-	/* EXTERNDED SUPPORTED RATE */
-	if (rate_len > 8)
-		pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pktlen);
-
-
-	/* todo:HT for adhoc */
-
-_ConstructBeacon:
-
-	if ((pktlen + TXDESC_SIZE) > 512) {
-		RTW_INFO("beacon frame too large\n");
-		return;
-	}
-
-	*pLength = pktlen;
-
-	/* RTW_INFO("%s bcn_sz=%d\n", __FUNCTION__, pktlen); */
-
-}
-
-static void ConstructPSPoll(_adapter *padapter, u8 *pframe, u32 *pLength)
-{
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16					*fctrl;
-	u32					pktlen;
-	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-	/* RTW_INFO("%s\n", __FUNCTION__); */
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	/* Frame control. */
-	fctrl = &(pwlanhdr->frame_ctl);
-	*(fctrl) = 0;
-	SetPwrMgt(fctrl);
-	set_frame_sub_type(pframe, WIFI_PSPOLL);
-
-	/* AID. */
-	set_duration(pframe, (pmlmeinfo->aid | 0xc000));
-
-	/* BSSID. */
-	_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-
-	/* TA. */
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-
-	*pLength = 16;
-}
-
-static void ConstructNullFunctionData(
-	PADAPTER padapter,
-	u8		*pframe,
-	u32		*pLength,
-	u8		*StaAddr,
-	u8		bQoS,
-	u8		AC,
-	u8		bEosp,
-	u8		bForcePowerSave)
-{
-	struct rtw_ieee80211_hdr	*pwlanhdr;
-	u16						*fctrl;
-	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);
-
-
-	/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*(fctrl) = 0;
-	if (bForcePowerSave)
-		SetPwrMgt(fctrl);
-
-	switch (cur_network->network.InfrastructureMode) {
-	case Ndis802_11Infrastructure:
-		SetToDs(fctrl);
-		_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, StaAddr, ETH_ALEN);
-		break;
-	case Ndis802_11APMode:
-		SetFrDs(fctrl);
-		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr2, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
-		break;
-	case Ndis802_11IBSS:
-	default:
-		_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-		_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
-		break;
-	}
-
-	SetSeqNum(pwlanhdr, 0);
-
-	if (bQoS == _TRUE) {
-		struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
-
-		set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
-
-		pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos *)pframe;
-		SetPriority(&pwlanqoshdr->qc, AC);
-		SetEOSP(&pwlanqoshdr->qc, bEosp);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-	} else {
-		set_frame_sub_type(pframe, WIFI_DATA_NULL);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-	}
-
-	*pLength = pktlen;
-}
-
 /*
  * Description: Get the reserved page number in Tx packet buffer.
  * Retrun value: the page number.
@@ -351,76 +155,12 @@ u8 GetTxBufferRsvdPageNum8723D(_adapter *padapter, bool wowlan)
 	return RsvdPageNum;
 }
 
-static void rtl8723d_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
-{
-	u8 u1H2CRsvdPageParm[H2C_RSVDPAGE_LOC_LEN] = {0};
-
-	RTW_INFO("8723DRsvdPageLoc: ProbeRsp=%d PsPoll=%d Null=%d QoSNull=%d BTNull=%d\n",
-		 rsvdpageloc->LocProbeRsp, rsvdpageloc->LocPsPoll,
-		 rsvdpageloc->LocNullData, rsvdpageloc->LocQosNull,
-		 rsvdpageloc->LocBTQosNull);
-
-	SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(u1H2CRsvdPageParm, rsvdpageloc->LocProbeRsp);
-	SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(u1H2CRsvdPageParm, rsvdpageloc->LocPsPoll);
-	SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocNullData);
-	SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocQosNull);
-	SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocBTQosNull);
-
-	RTW_DBG_DUMP("u1H2CRsvdPageParm:",
-		     u1H2CRsvdPageParm, H2C_RSVDPAGE_LOC_LEN);
-
-	FillH2CCmd8723D(padapter, H2C_8723D_RSVD_PAGE, H2C_RSVDPAGE_LOC_LEN, u1H2CRsvdPageParm);
-}
-
-static void rtl8723d_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
-{
-	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	u8	res = 0, count = 0;
-#ifdef CONFIG_WOWLAN
-	u8 u1H2CAoacRsvdPageParm[H2C_AOAC_RSVDPAGE_LOC_LEN] = {0};
-
-	RTW_INFO("8723DAOACRsvdPageLoc: RWC=%d ArpRsp=%d NbrAdv=%d GtkRsp=%d GtkInfo=%d ProbeReq=%d NetworkList=%d\n",
-		 rsvdpageloc->LocRemoteCtrlInfo, rsvdpageloc->LocArpRsp,
-		 rsvdpageloc->LocNbrAdv, rsvdpageloc->LocGTKRsp,
-		 rsvdpageloc->LocGTKInfo, rsvdpageloc->LocProbeReq,
-		 rsvdpageloc->LocNetList);
-
-	if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-		SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocRemoteCtrlInfo);
-		SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(u1H2CAoacRsvdPageParm, rsvdpageloc->LocArpRsp);
-		/* SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(u1H2CAoacRsvdPageParm, rsvdpageloc->LocNbrAdv); */
-		SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKRsp);
-		SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKInfo);
-#ifdef CONFIG_GTK_OL
-		SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKEXTMEM);
-#endif /* CONFIG_GTK_OL */
-		RTW_DBG_DUMP("u1H2CAoacRsvdPageParm:",
-			     u1H2CAoacRsvdPageParm, H2C_AOAC_RSVDPAGE_LOC_LEN);
-
-		FillH2CCmd8723D(padapter, H2C_8723D_AOAC_RSVD_PAGE, H2C_AOAC_RSVDPAGE_LOC_LEN, u1H2CAoacRsvdPageParm);
-	} else {
-#ifdef CONFIG_PNO_SUPPORT
-		if (!pwrpriv->wowlan_in_resume) {
-			RTW_INFO("NLO_INFO=%d\n", rsvdpageloc->LocPNOInfo);
-			_rtw_memset(&u1H2CAoacRsvdPageParm, 0, sizeof(u1H2CAoacRsvdPageParm));
-			SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocPNOInfo);
-			FillH2CCmd8723D(padapter, H2C_AOAC_RSVDPAGE3, H2C_AOAC_RSVDPAGE_LOC_LEN, u1H2CAoacRsvdPageParm);
-			rtw_msleep_os(10);
-		}
-#endif
-	}
-
-#endif /* CONFIG_WOWLAN */
-}
 void rtl8723d_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 {
-	int i;
 	u8 smart_ps = 0;
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	u8 u1H2CPwrModeParm[H2C_PWRMODE_LEN] = {0};
-	u8 PowerState = 0, awake_intvl = 1, byte5 = 0, rlbm = 0;
+	u8 PowerState = 0, awake_intvl = 1, rlbm = 0;
 #ifdef CONFIG_P2P
 	struct wifidirect_info *wdinfo = &(padapter->wdinfo);
 #endif /* CONFIG_P2P */
@@ -474,26 +214,13 @@ void rtl8723d_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 
 	if (psmode > 0) {
 #ifdef CONFIG_BT_COEXIST
-		if (rtw_btcoex_IsBtControlLps(padapter) == _TRUE) {
+		if (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
 			PowerState = rtw_btcoex_RpwmVal(padapter);
-			byte5 = rtw_btcoex_LpsVal(padapter);
-
-			if ((rlbm == 2) && (byte5 & BIT(4))) {
-				/* Keep awake interval to 1 to prevent from */
-				/* decreasing coex performance */
-				awake_intvl = 2;
-				rlbm = 2;
-			}
-		} else
+		else
 #endif /* CONFIG_BT_COEXIST */
-		{
 			PowerState = 0x00;/* AllON(0x0C), RFON(0x04), RFOFF(0x00) */
-			byte5 = 0x40;
-		}
-	} else {
+	} else
 		PowerState = 0x0C;/* AllON(0x0C), RFON(0x04), RFOFF(0x00) */
-		byte5 = 0x40;
-	}
 
 	SET_8723D_H2CCMD_PWRMODE_PARM_MODE(u1H2CPwrModeParm, (psmode > 0) ? 1 : 0);
 	SET_8723D_H2CCMD_PWRMODE_PARM_SMART_PS(u1H2CPwrModeParm, smart_ps);
@@ -501,65 +228,6 @@ void rtl8723d_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)
 	SET_8723D_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(u1H2CPwrModeParm, awake_intvl);
 	SET_8723D_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(u1H2CPwrModeParm, allQueueUAPSD);
 	SET_8723D_H2CCMD_PWRMODE_PARM_PWR_STATE(u1H2CPwrModeParm, PowerState);
-	SET_8723D_H2CCMD_PWRMODE_PARM_BYTE5(u1H2CPwrModeParm, byte5);
-#ifdef CONFIG_LPS_LCLK
-	if (psmode != PS_MODE_ACTIVE) {
-		if (pmlmeext->adaptive_tsf_done == _FALSE && pmlmeext->bcn_cnt > 0) {
-			u8 ratio_20_delay, ratio_80_delay;
-
-			/* byte 6 for adaptive_early_32k */
-			/* [0:3] = DrvBcnEarly  (ms) , [4:7] = DrvBcnTimeOut  (ms) */
-			/* 20% for DrvBcnEarly, 80% for DrvBcnTimeOut */
-			ratio_20_delay = 0;
-			ratio_80_delay = 0;
-			pmlmeext->DrvBcnEarly = 0xff;
-			pmlmeext->DrvBcnTimeOut = 0xff;
-
-			/* RTW_INFO("%s(): bcn_cnt = %d\n", __func__, pmlmeext->bcn_cnt); */
-
-			for (i = 0; i < 9; i++) {
-				pmlmeext->bcn_delay_ratio[i] = (pmlmeext->bcn_delay_cnt[i] * 100) / pmlmeext->bcn_cnt;
-
-				/* RTW_INFO("%s(): bcn_delay_cnt[%d]=%d, bcn_delay_ratio[%d] = %d\n", __func__, i, pmlmeext->bcn_delay_cnt[i] */
-				/*	,i ,pmlmeext->bcn_delay_ratio[i]); */
-
-				ratio_20_delay += pmlmeext->bcn_delay_ratio[i];
-				ratio_80_delay += pmlmeext->bcn_delay_ratio[i];
-
-				if (ratio_20_delay > 20 && pmlmeext->DrvBcnEarly == 0xff) {
-					pmlmeext->DrvBcnEarly = i;
-					/* RTW_INFO("%s(): DrvBcnEarly = %d\n", __func__, pmlmeext->DrvBcnEarly); */
-				}
-
-				if (ratio_80_delay > 80 && pmlmeext->DrvBcnTimeOut == 0xff) {
-					pmlmeext->DrvBcnTimeOut = i;
-					/* RTW_INFO("%s(): DrvBcnTimeOut = %d\n", __func__, pmlmeext->DrvBcnTimeOut); */
-				}
-
-				/* reset adaptive_early_32k cnt */
-				pmlmeext->bcn_delay_cnt[i] = 0;
-				pmlmeext->bcn_delay_ratio[i] = 0;
-
-			}
-
-			pmlmeext->bcn_cnt = 0;
-			pmlmeext->adaptive_tsf_done = _TRUE;
-
-		} else {
-			/* RTW_INFO("%s(): DrvBcnEarly = %d\n", __func__, pmlmeext->DrvBcnEarly); */
-			/* RTW_INFO("%s(): DrvBcnTimeOut = %d\n", __func__, pmlmeext->DrvBcnTimeOut); */
-		}
-
-		/* offload to FW if fw version > v15.10
-				pmlmeext->DrvBcnEarly=0;
-				pmlmeext->DrvBcnTimeOut=7;
-
-				if((pmlmeext->DrvBcnEarly!=0Xff) && (pmlmeext->DrvBcnTimeOut!=0xff))
-					u1H2CPwrModeParm[H2C_PWRMODE_LEN-1] = BIT(0) | ((pmlmeext->DrvBcnEarly<<1)&0x0E) |((pmlmeext->DrvBcnTimeOut<<4)&0xf0) ;
-		*/
-
-	}
-#endif
 
 #ifdef CONFIG_BT_COEXIST
 	rtw_btcoex_RecordPwrMode(padapter, u1H2CPwrModeParm, H2C_PWRMODE_LEN);
@@ -584,7 +252,6 @@ void rtl8723d_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable)
 	SET_8723D_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(u1H2CSetPwrMode, 0);
 	SET_8723D_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(u1H2CSetPwrMode, enable);
 	SET_8723D_H2CCMD_PWRMODE_PARM_PWR_STATE(u1H2CSetPwrMode, 0x0C);
-	SET_8723D_H2CCMD_PWRMODE_PARM_BYTE5(u1H2CSetPwrMode, 0);
 	FillH2CCmd8723D(padapter, H2C_8723D_SET_PWR_MODE, sizeof(u1H2CSetPwrMode), u1H2CSetPwrMode);
 }
 #endif
@@ -622,13 +289,14 @@ void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 	BOOLEAN		bcn_valid = _FALSE;
 	u8	DLBcnCount = 0;
 	u32 poll = 0;
-	u8 val8, RegFwHwTxQCtrl;
+	u8 RegFwHwTxQCtrl;
 
 
 	RTW_INFO("+" FUNC_ADPT_FMT ": hw_port=%d mstatus(%x)\n",
 		 FUNC_ADPT_ARG(padapter), get_hw_port(padapter), mstatus);
 
 	if (mstatus == RT_MEDIA_CONNECT) {
+		u8 bcn_ctrl = rtw_read8(padapter, REG_BCN_CTRL);
 		BOOLEAN bRecover = _FALSE;
 		u8 v8;
 
@@ -644,10 +312,7 @@ void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 		/* 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. */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL);
-		val8 &= ~EN_BCN_FUNCTION;
-		val8 |= DIS_TSF_UDT;
-		rtw_write8(padapter, REG_BCN_CTRL, val8);
+		rtw_write8(padapter, REG_BCN_CTRL, (bcn_ctrl & (~EN_BCN_FUNCTION)) | DIS_TSF_UDT);
 
 		/* Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame. */
 		RegFwHwTxQCtrl = rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2);
@@ -666,7 +331,7 @@ void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 		poll = 0;
 		do {
 			/* download rsvd page. */
-			rtw_hal_set_fw_rsvd_page(padapter, 0);
+			rtw_hal_set_fw_rsvd_page(padapter, _FALSE);
 			DLBcnCount++;
 			do {
 				rtw_yield_os();
@@ -681,21 +346,19 @@ void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 		if (RTW_CANNOT_RUN(padapter))
 			;
 		else if (!bcn_valid)
-			RTW_INFO(ADPT_FMT": 1 DL RSVD page failed! DLBcnCount:%u, poll:%u\n",
+			RTW_ERR(ADPT_FMT": 1 DL RSVD page failed! DLBcnCount:%u, poll:%u\n",
 				 ADPT_ARG(padapter) , DLBcnCount, poll);
 		else {
 			struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 
 			pwrctl->fw_psmode_iface_id = padapter->iface_id;
+			rtw_hal_set_fw_rsvd_page(padapter, _TRUE);
 			RTW_INFO(ADPT_FMT": 1 DL RSVD page success! DLBcnCount:%u, poll:%u\n",
 				 ADPT_ARG(padapter), DLBcnCount, poll);
 		}
 
-		/* 2010.05.11. Added by tynli. */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL);
-		val8 |= EN_BCN_FUNCTION;
-		val8 &= ~DIS_TSF_UDT;
-		rtw_write8(padapter, REG_BCN_CTRL, val8);
+		/* restore bcn_ctrl */
+		rtw_write8(padapter, REG_BCN_CTRL, bcn_ctrl);
 
 		/* 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 */
@@ -719,287 +382,14 @@ void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus)
 
 void rtl8723d_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus)
 {
-	struct sta_info *psta = NULL;
-	struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(padapter);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-
 	if (mstatus == 1)
 		rtl8723d_download_rsvd_page(padapter, RT_MEDIA_CONNECT);
 }
 
 #ifdef CONFIG_BT_COEXIST
-static void ConstructBtNullFunctionData(
-	PADAPTER padapter,
-	u8 *pframe,
-	u32 *pLength,
-	u8 *StaAddr,
-	u8 bQoS,
-	u8 AC,
-	u8 bEosp,
-	u8 bForcePowerSave)
-{
-	struct rtw_ieee80211_hdr *pwlanhdr;
-	u16 *fctrl;
-	u32 pktlen;
-	struct mlme_ext_priv *pmlmeext;
-	struct mlme_ext_info *pmlmeinfo;
-	u8 bssid[ETH_ALEN];
-
-
-	RTW_INFO("+" FUNC_ADPT_FMT ": qos=%d eosp=%d ps=%d\n",
-		 FUNC_ADPT_ARG(padapter), bQoS, bEosp, bForcePowerSave);
-
-	pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
-	pmlmeext = &padapter->mlmeextpriv;
-	pmlmeinfo = &pmlmeext->mlmext_info;
-
-	if (NULL == StaAddr) {
-		_rtw_memcpy(bssid, adapter_mac_addr(padapter), ETH_ALEN);
-		StaAddr = bssid;
-	}
-
-	fctrl = &pwlanhdr->frame_ctl;
-	*fctrl = 0;
-	if (bForcePowerSave)
-		SetPwrMgt(fctrl);
-
-	SetFrDs(fctrl);
-	_rtw_memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
-	_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
-
-	set_duration(pwlanhdr, 0);
-	SetSeqNum(pwlanhdr, 0);
-
-	if (bQoS == _TRUE) {
-		struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
-
-		set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
-
-		pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos *)pframe;
-		SetPriority(&pwlanqoshdr->qc, AC);
-		SetEOSP(&pwlanqoshdr->qc, bEosp);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
-	} else {
-		set_frame_sub_type(pframe, WIFI_DATA_NULL);
-
-		pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
-	}
-
-	*pLength = pktlen;
-}
-
-static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)
-{
-	PHAL_DATA_TYPE pHalData;
-	struct xmit_frame *pcmdframe;
-	struct pkt_attrib *pattrib;
-	struct xmit_priv *pxmitpriv;
-	struct mlme_ext_priv *pmlmeext;
-	struct mlme_ext_info *pmlmeinfo;
-	u32	BeaconLength = 0;
-	u32	BTQosNullLength = 0;
-	u8 *ReservedPagePacket;
-	u8 TxDescLen, TxDescOffset;
-	u8 TotalPageNum = 0, CurtPktPageNum = 0, RsvdPageNum = 0;
-	u16	BufIndex, PageSize;
-	u32	TotalPacketLen, MaxRsvdPageBufSize = 0;
-	RSVDPAGE_LOC RsvdPageLoc;
-
-
-	/*	RTW_INFO("+" FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(padapter)); */
-
-	pHalData = GET_HAL_DATA(padapter);
-	pxmitpriv = &padapter->xmitpriv;
-	pmlmeext = &padapter->mlmeextpriv;
-	pmlmeinfo = &pmlmeext->mlmext_info;
-	TxDescLen = TXDESC_SIZE;
-	TxDescOffset = TXDESC_OFFSET;
-	PageSize = PAGE_SIZE_TX_8723D;
-
-	RsvdPageNum = BCNQ_PAGE_NUM_8723D;
-	MaxRsvdPageBufSize = RsvdPageNum * PageSize;
-
-	pcmdframe = rtw_alloc_cmdxmitframe(pxmitpriv);
-	if (pcmdframe == NULL) {
-		RTW_INFO("%s: alloc ReservedPagePacket fail!\n", __FUNCTION__);
-		return;
-	}
-
-	ReservedPagePacket = pcmdframe->buf_addr;
-	_rtw_memset(&RsvdPageLoc, 0, sizeof(RSVDPAGE_LOC));
-
-	/* 3 (1) beacon */
-	BufIndex = TxDescOffset;
-	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. */
-	CurtPktPageNum = (u8)PageNum_128(TxDescLen + BeaconLength);
-	/* If we don't add 1 more page, the WOWLAN function has a problem. Baron thinks it's a bug of firmware */
-	if (CurtPktPageNum == 1)
-		CurtPktPageNum += 1;
-	TotalPageNum += CurtPktPageNum;
-
-	BufIndex += (CurtPktPageNum * PageSize);
-
-	/* Jump to lastest page */
-	if (BufIndex < (MaxRsvdPageBufSize - PageSize)) {
-		BufIndex = TxDescOffset + (MaxRsvdPageBufSize - PageSize);
-		TotalPageNum = BCNQ_PAGE_NUM_8723D - 1;
-	}
-
-	/* 3 (6) BT Qos null data */
-	RsvdPageLoc.LocBTQosNull = TotalPageNum;
-	ConstructBtNullFunctionData(
-		padapter,
-		&ReservedPagePacket[BufIndex],
-		&BTQosNullLength,
-		NULL,
-		_TRUE, 0, 0, _FALSE);
-	rtl8723d_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex - TxDescLen], BTQosNullLength, _FALSE, _TRUE, _FALSE);
-
-	CurtPktPageNum = (u8)PageNum_128(TxDescLen + BTQosNullLength);
-
-	TotalPageNum += CurtPktPageNum;
-
-	TotalPacketLen = BufIndex + BTQosNullLength;
-	if (TotalPacketLen > MaxRsvdPageBufSize) {
-		RTW_INFO(FUNC_ADPT_FMT ": ERROR: The rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
-			FUNC_ADPT_ARG(padapter), TotalPacketLen, MaxRsvdPageBufSize);
-		goto error;
-	}
-
-	/* update attribute */
-	pattrib = &pcmdframe->attrib;
-	update_mgntframe_attrib(padapter, pattrib);
-	pattrib->qsel = QSLT_BEACON;
-	pattrib->pktlen = pattrib->last_txcmdsz = TotalPacketLen - TxDescOffset;
-#ifdef CONFIG_PCI_HCI
-	dump_mgntframe(padapter, pcmdframe);
-#else
-	dump_mgntframe_and_wait(padapter, pcmdframe, 100);
-#endif
-
-	/*	RTW_INFO(FUNC_ADPT_FMT ": Set RSVD page location to Fw, TotalPacketLen(%d), TotalPageNum(%d)\n",
-	 *		FUNC_ADPT_ARG(padapter), TotalPacketLen, TotalPageNum); */
-	rtl8723d_set_FwRsvdPage_cmd(padapter, &RsvdPageLoc);
-	rtl8723d_set_FwAoacRsvdPage_cmd(padapter, &RsvdPageLoc);
-
-	return;
-
-error:
-	rtw_free_xmitframe(pxmitpriv, pcmdframe);
-}
-
 void rtl8723d_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter)
 {
-	PHAL_DATA_TYPE pHalData;
-	struct mlme_ext_priv *pmlmeext;
-	struct mlme_ext_info *pmlmeinfo;
-	u8 bRecover = _FALSE;
-	u8 bcn_valid = _FALSE;
-	u8 DLBcnCount = 0;
-	u32 poll = 0;
-	u8 val8, RegFwHwTxQCtrl;
-
-
-	RTW_INFO("+" FUNC_ADPT_FMT ": hw_port=%d fw_state=0x%08X\n",
-		FUNC_ADPT_ARG(padapter), get_hw_port(padapter), get_fwstate(&padapter->mlmepriv));
-
-#ifdef CONFIG_RTW_DEBUG
-	if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _FALSE) {
-		RTW_INFO(FUNC_ADPT_FMT ": [WARNING] not in AP mode!!\n",
-			 FUNC_ADPT_ARG(padapter));
-	}
-#endif /* CONFIG_RTW_DEBUG */
-
-	pHalData = GET_HAL_DATA(padapter);
-	pmlmeext = &padapter->mlmeextpriv;
-	pmlmeinfo = &pmlmeext->mlmext_info;
-
-	/* We should set AID, correct TSF, HW seq enable before set JoinBssReport to Fw in 88/92C. */
-	/* Suggested by filen. Added by tynli. */
-	rtw_write16(padapter, REG_BCN_PSR_RPT, (0xC000 | pmlmeinfo->aid));
-
-	/* set REG_CR bit 8 */
-	val8 = rtw_read8(padapter, REG_CR + 1);
-	val8 |= BIT(0); /* ENSWBCN */
-	rtw_write8(padapter,  REG_CR + 1, val8);
-
-	/* 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. */
-	val8 = rtw_read8(padapter, REG_BCN_CTRL);
-	val8 &= ~EN_BCN_FUNCTION;
-	val8 |= DIS_TSF_UDT;
-	rtw_write8(padapter, REG_BCN_CTRL, val8);
-
-	/* Set FWHW_TXQ_CTRL 0x422[6]=0 to tell Hw the packet is not a real beacon frame. */
-	RegFwHwTxQCtrl = rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2);
-	if (RegFwHwTxQCtrl & BIT(6))
-		bRecover = _TRUE;
-
-	/* To tell Hw the packet is not a real beacon frame. */
-	RegFwHwTxQCtrl &= ~BIT(6);
-	rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, RegFwHwTxQCtrl);
-
-	/* Clear beacon valid check bit. */
-	rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
-	rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
-
-	DLBcnCount = 0;
-	poll = 0;
-	do {
-		SetFwRsvdPagePkt_BTCoex(padapter);
-		DLBcnCount++;
-		do {
-			rtw_yield_os();
-			/*			rtw_mdelay_os(10); */
-			/* check rsvd page download OK. */
-			rtw_hal_get_hwreg(padapter, HW_VAR_BCN_VALID, &bcn_valid);
-			poll++;
-		} while (!bcn_valid && (poll % 10) != 0 && !RTW_CANNOT_RUN(padapter));
-	} while (!bcn_valid && (DLBcnCount <= 100) && !RTW_CANNOT_RUN(padapter));
-
-	if (_TRUE == bcn_valid) {
-		struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
-
-		pwrctl->fw_psmode_iface_id = padapter->iface_id;
-		RTW_INFO(ADPT_FMT": DL RSVD page success! DLBcnCount:%d, poll:%d\n",
-			 ADPT_ARG(padapter), DLBcnCount, poll);
-	} else {
-		RTW_INFO(ADPT_FMT": DL RSVD page fail! DLBcnCount:%d, poll:%d\n",
-			 ADPT_ARG(padapter), DLBcnCount, poll);
-		RTW_INFO(ADPT_FMT": DL RSVD page fail! bSurpriseRemoved=%s\n",
-			ADPT_ARG(padapter), rtw_is_surprise_removed(padapter) ? "True" : "False");
-		RTW_INFO(ADPT_FMT": DL RSVD page fail! bDriverStopped=%s\n",
-			ADPT_ARG(padapter), rtw_is_drv_stopped(padapter) ? "True" : "False");
-	}
-
-	/* 2010.05.11. Added by tynli. */
-	val8 = rtw_read8(padapter, REG_BCN_CTRL);
-	val8 |= EN_BCN_FUNCTION;
-	val8 &= ~DIS_TSF_UDT;
-	rtw_write8(padapter, REG_BCN_CTRL, val8);
-
-	/* 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) {
-		RegFwHwTxQCtrl |= BIT(6);
-		rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2, RegFwHwTxQCtrl);
-	}
-
-	/* Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
-#ifndef CONFIG_PCI_HCI
-	val8 = rtw_read8(padapter, REG_CR + 1);
-	val8 &= ~BIT(0); /* ~ENSWBCN */
-	rtw_write8(padapter, REG_CR + 1, val8);
-#endif
+	rtl8723d_download_rsvd_page(padapter, RT_MEDIA_CONNECT);
 }
 #endif /* CONFIG_BT_COEXIST */
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_dm.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_dm.c
index 7db737029b4e..a795e244e55c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_dm.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_dm.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -207,7 +208,7 @@ dm_InitGPIOSetting(
 static void Init_ODM_ComInfo_8723d(PADAPTER	Adapter)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 	u8	cut_ver, fab_ver;
 
 	Init_ODM_ComInfo(Adapter);
@@ -228,13 +229,12 @@ rtl8723d_InitHalDm(
 )
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 #ifdef CONFIG_USB_HCI
 	dm_InitGPIOSetting(Adapter);
 #endif
-	odm_dm_init(pDM_Odm);
-
+	rtw_phydm_init(Adapter);
 }
 
 VOID
@@ -245,6 +245,8 @@ rtl8723d_HalDmWatchDog(
 	BOOLEAN		bFwCurrentInPSMode = _FALSE;
 	u8 bFwPSAwake = _TRUE;
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(Adapter);
+	u8 in_lps = _FALSE;
 
 #ifdef CONFIG_MP_INCLUDED
 	/* #if MP_DRIVER */
@@ -257,7 +259,7 @@ rtl8723d_HalDmWatchDog(
 		goto skip_dm;
 
 #ifdef CONFIG_LPS
-	bFwCurrentInPSMode = adapter_to_pwrctl(Adapter)->bFwCurrentInPSMode;
+	bFwCurrentInPSMode = pwrpriv->bFwCurrentInPSMode;
 	rtw_hal_get_hwreg(Adapter, HW_VAR_FWLPS_RF_ON, &bFwPSAwake);
 #endif
 
@@ -291,7 +293,13 @@ rtl8723d_HalDmWatchDog(
 #ifdef CONFIG_DISABLE_ODM
 	goto skip_dm;
 #endif
-	rtw_phydm_watchdog(Adapter);
+
+#ifdef CONFIG_LPS
+	if (pwrpriv->bLeisurePs && bFwCurrentInPSMode && pwrpriv->pwr_mode != PS_MODE_ACTIVE)
+		in_lps = _TRUE;
+#endif
+
+	rtw_phydm_watchdog(Adapter, in_lps);
 
 skip_dm:
 
@@ -311,7 +319,7 @@ skip_dm:
 void rtl8723d_init_dm_priv(IN PADAPTER Adapter)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT		*podmpriv = &pHalData->odmpriv;
+	struct dm_struct		*podmpriv = &pHalData->odmpriv;
 
 	Init_ODM_ComInfo_8723d(Adapter);
 	odm_init_all_timers(podmpriv);
@@ -321,7 +329,7 @@ void rtl8723d_init_dm_priv(IN PADAPTER Adapter)
 void rtl8723d_deinit_dm_priv(IN PADAPTER Adapter)
 {
 	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
-	struct PHY_DM_STRUCT		*podmpriv = &pHalData->odmpriv;
+	struct dm_struct		*podmpriv = &pHalData->odmpriv;
 
 	odm_cancel_all_timers(podmpriv);
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_hal_init.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_hal_init.c
index 5161a90e4833..75f7bb005a27 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_hal_init.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_hal_init.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -425,11 +426,11 @@ int _WriteBTFWtoTxPktBuf8723D(
 	struct pkt_attrib	*pattrib;
 	u8			txdesc_offset = TXDESC_OFFSET;
 	u8			val8, RegFwHwTxQCtrl;
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#ifdef CONFIG_PCI_HCI
 	u8			u1bTmp;
 #endif
 
-#if 1/* (DEV_BUS_TYPE == RT_PCI_INTERFACE) */
+#if 1/* #ifdef CONFIG_PCI_HCI */
 	TotalPktLen = FwBufLen;
 #else
 	TotalPktLen = FwBufLen + pHalData->HWDescHeadLength;
@@ -449,7 +450,7 @@ int _WriteBTFWtoTxPktBuf8723D(
 
 	_rtw_memset(ReservedPagePacket, 0, TotalPktLen);
 
-#if 1/* (DEV_BUS_TYPE == RT_PCI_INTERFACE) */
+#if 1/* #ifdef CONFIG_PCI_HCI */
 	_rtw_memcpy(ReservedPagePacket, FwbufferPtr, FwBufLen);
 
 #else
@@ -460,7 +461,7 @@ int _WriteBTFWtoTxPktBuf8723D(
 	/* 1. Pause BCN */
 	/* --------------------------------------------------------- */
 	/* Set REG_CR bit 8. DMA beacon by SW. */
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#ifdef CONFIG_PCI_HCI
 	u1bTmp = PlatformEFIORead1Byte(Adapter, REG_CR + 1);
 	PlatformEFIOWrite1Byte(Adapter,  REG_CR + 1, (u1bTmp | BIT(0)));
 #else
@@ -476,7 +477,7 @@ int _WriteBTFWtoTxPktBuf8723D(
 	val8 |= DIS_TSF_UDT;
 	rtw_write8(Adapter, REG_BCN_CTRL, val8);
 
-#if 0/* (DEV_BUS_TYPE == RT_PCI_INTERFACE) */
+#if 0/* #ifdef CONFIG_PCI_HCI */
 	tmpReg422 = PlatformEFIORead1Byte(Adapter, REG_FWHW_TXQ_CTRL + 2);
 	if (tmpReg422 & BIT(6))
 		bRecover = TRUE;
@@ -492,7 +493,7 @@ int _WriteBTFWtoTxPktBuf8723D(
 	/* --------------------------------------------------------- */
 	/* 2. Adjust LLT table to an even boundary. */
 	/* --------------------------------------------------------- */
-#if 0/* (DEV_BUS_TYPE == RT_SDIO_INTERFACE) */
+#if 0/* #ifdef CONFIG_SDIO_HCI */
 	txpktbuf_bndy = 10; /* rsvd page start address should be an even value.														 */
 	rtStatus =	InitLLTTable8723DS(Adapter, txpktbuf_bndy);
 	if (RT_STATUS_SUCCESS != rtStatus) {
@@ -686,7 +687,7 @@ _CheckWLANFwPatchBTFwReady(
 	/* --------------------------------------------------------- */
 	/* Reset beacon setting to the initial value. */
 	/* --------------------------------------------------------- */
-#if 0/* (DEV_BUS_TYPE == RT_PCI_INTERFACE) */
+#if 0/* #ifdef CONFIG_PCI_HCI */
 	if (LLT_table_init(Adapter, FALSE, 0) == RT_STATUS_FAILURE) {
 		dbgdump("Init self define for BT Fw patch LLT table fail.\n");
 		/* return RT_STATUS_FAILURE; */
@@ -2803,7 +2804,7 @@ void rtl8723d_InitBeaconParameters(PADAPTER padapter)
 
 	/* 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 */
-	rtw_write16(padapter, REG_BCNTCFG, 0x660F);
+	rtw_write16(padapter, REG_BCNTCFG, 0x4413);
 
 }
 
@@ -2816,47 +2817,32 @@ void rtl8723d_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode)
 #endif
 }
 
-void	_InitBurstPktLen_8723DS(PADAPTER Adapter)
-{
-	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(Adapter);
-
-	rtw_write8(Adapter, 0x4c7, rtw_read8(Adapter, 0x4c7) | BIT(7)); /* enable single pkt ampdu */
-	rtw_write8(Adapter, REG_RX_PKT_LIMIT_8723D, 0x18);		/* for VHT packet length 11K */
-	rtw_write8(Adapter, REG_MAX_AGGR_NUM_8723D, 0x1F);
-	rtw_write8(Adapter, REG_PIFS_8723D, 0x00);
-	rtw_write8(Adapter, REG_FWHW_TXQ_CTRL_8723D, rtw_read8(Adapter, REG_FWHW_TXQ_CTRL) & (~BIT(7)));
-	if (pHalData->AMPDUBurstMode)
-		rtw_write8(Adapter, REG_AMPDU_BURST_MODE_8723D,  0x5F);
-	rtw_write8(Adapter, REG_AMPDU_MAX_TIME_8723D, 0x70);
-
-	/* ARFB table 9 for 11ac 5G 2SS */
-	rtw_write32(Adapter, REG_ARFR0_8723D, 0x00000010);
-	if (IS_NORMAL_CHIP(pHalData->version_id))
-		rtw_write32(Adapter, REG_ARFR0_8723D + 4, 0xfffff000);
-	else
-		rtw_write32(Adapter, REG_ARFR0_8723D + 4, 0x3e0ff000);
-
-	/* ARFB table 10 for 11ac 5G 1SS */
-	rtw_write32(Adapter, REG_ARFR1_8723D, 0x00000010);
-	rtw_write32(Adapter, REG_ARFR1_8723D + 4, 0x003ff000);
-}
-
-void _InitLTECoex_8723DS(PADAPTER Adapter)
-{
-	/* LTE COEX setting */
-	rtw_write16(Adapter, REG_LTECOEX_WRITE_DATA, 0x7700);
-	rtw_write32(Adapter, REG_LTECOEX_CTRL, 0xc0020038);
-	rtw_write8(Adapter, 0x73, 0x04);
-}
-
 void _InitMacAPLLSetting_8723D(PADAPTER Adapter)
 {
+
+	PHAL_DATA_TYPE	pHalData = GET_HAL_DATA(Adapter);
 	u16 RegValue;
+	u8	afe;
 
 	RegValue = rtw_read16(Adapter, REG_AFE_CTRL_4_8723D);
 	RegValue |= BIT(4);
 	RegValue |= BIT(15);
 	rtw_write16(Adapter, REG_AFE_CTRL_4_8723D, RegValue);
+
+	/*
+	 *	8723D with 24MHz xtal has VCO noise issue
+	 *  This will cause some TRx test fail
+	 *	Therefore, set MAC GM parameter for 24MHz xtal
+	 *	AFE[0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ] =
+	 *	[ 40M 25M 13M 19.2M 20M 26M 38.4M 17.664M 16M 14.318M 12M 52M 48M 27M 24M ]
+	 */
+	afe = (pHalData->efuse_eeprom_data[4] >>4);
+	if( afe == 14) {
+		rtw_write32(Adapter, 0x2c, (rtw_read32(Adapter, 0x2c) | BIT28));
+		rtw_write32(Adapter, 0x24, (rtw_read32(Adapter, 0x24) & 0xFFFFFF0F));
+		rtw_write32(Adapter, 0x7c, ((rtw_read32(Adapter, 0x7c) | BIT29) & (~BIT28)));
+	}
+
 }
 
 static void _BeaconFunctionEnable(PADAPTER padapter, u8 Enable, u8 Linked)
@@ -2876,7 +2862,7 @@ static void rtl8723d_SetBeaconRelatedRegisters(PADAPTER padapter)
 
 	/* reset TSF, enable update TSF, correcting TSF On Beacon */
 
-	/* REG_BCN_INTERVAL */
+	/* REG_MBSSID_BCN_SPACE */
 	/* REG_BCNDMATIM */
 	/* REG_ATIMWND */
 	/* REG_TBTT_PROHIBIT */
@@ -2901,7 +2887,7 @@ static void rtl8723d_SetBeaconRelatedRegisters(PADAPTER padapter)
 	/* */
 	/* Beacon interval (in unit of TU). */
 	/* */
-	rtw_write16(padapter, REG_BCN_INTERVAL, pmlmeinfo->bcn_interval);
+	rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)&pmlmeinfo->bcn_interval);
 
 	rtl8723d_InitBeaconParameters(padapter);
 
@@ -3126,6 +3112,8 @@ void init_hal_spec_8723d(_adapter *adapter)
 	hal_spec->sec_cap = SEC_CAP_CHK_BMC;
 	hal_spec->rfpath_num_2g = 2;
 	hal_spec->rfpath_num_5g = 0;
+	hal_spec->txgi_max = 63;
+	hal_spec->txgi_pdbm = 2;
 	hal_spec->max_tx_cnt = 1;
 	hal_spec->tx_nss_num = 1;
 	hal_spec->rx_nss_num = 1;
@@ -3140,6 +3128,9 @@ void init_hal_spec_8723d(_adapter *adapter)
 			    | WL_FUNC_TDLS
 			    ;
 
+	hal_spec->pg_txpwr_saddr = 0x10;
+	hal_spec->pg_txgi_diff_factor = 1;
+
 	rtw_macid_ctl_init_sleep_reg(adapter_to_macidctl(adapter)
 		, REG_MACID_SLEEP, 0, 0, 0);
 }
@@ -3151,8 +3142,6 @@ void rtl8723d_init_default_value(PADAPTER padapter)
 
 	pHalData = GET_HAL_DATA(padapter);
 
-	padapter->registrypriv.wireless_mode = WIRELESS_11BG_24N;
-
 	/* init default value */
 	pHalData->fw_ractrl = _FALSE;
 	if (!adapter_to_pwrctl(padapter)->bkeepfwalive)
@@ -3160,10 +3149,6 @@ void rtl8723d_init_default_value(PADAPTER padapter)
 
 	/* init phydm default value */
 	pHalData->bIQKInitialized = _FALSE;
-	pHalData->odmpriv.rf_calibrate_info.tm_trigger = 0;/* for IQK */
-	pHalData->odmpriv.rf_calibrate_info.thermal_value_hp_index = 0;
-	for (i = 0; i < HP_THERMAL_NUM; i++)
-		pHalData->odmpriv.rf_calibrate_info.thermal_value_hp[i] = 0;
 
 	/* init Efuse variables */
 	pHalData->EfuseUsedBytes = 0;
@@ -3760,55 +3745,6 @@ Hal_EfuseParseEEPROMVer_8723D(
 		pHalData->EEPROMVersion = 1;
 }
 
-
-VOID
-Hal_EfuseParsePackageType_8723D(
-	IN	PADAPTER		pAdapter,
-	IN	u8				*hwinfo,
-	IN	BOOLEAN		AutoLoadFail
-)
-{
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(pAdapter);
-	u1Byte			package;
-	u8 efuseContent;
-
-	Efuse_PowerSwitch(pAdapter, _FALSE, _TRUE);
-	efuse_OneByteRead(pAdapter, 0x1FB, &efuseContent, FALSE);
-	RTW_INFO("%s phy efuse read 0x1FB =%x\n", __func__, efuseContent);
-	Efuse_PowerSwitch(pAdapter, _FALSE, _FALSE);
-
-	package = efuseContent & 0x7;
-	switch (package) {
-	case 0x4:
-		pHalData->PackageType = PACKAGE_TFBGA79;
-		break;
-	case 0x5:
-		pHalData->PackageType = PACKAGE_TFBGA90;
-		break;
-	case 0x6:
-		pHalData->PackageType = PACKAGE_QFN68;
-		break;
-	case 0x7:
-		pHalData->PackageType = PACKAGE_TFBGA80;
-		break;
-
-	default:
-		pHalData->PackageType = PACKAGE_DEFAULT;
-		break;
-	}
-
-	RTW_INFO("PackageType = 0x%X\n", pHalData->PackageType);
-
-#ifdef CONFIG_SDIO_HCI
-	/* RTL8703AS: 0x1FB[5:4] 2b'10 */
-	/* RTL8723DS: 0x1FB[5:4] 2b'11 */
-	if ((efuseContent & 0x30) == 0x20) {
-		pAdapter->registrypriv.bw_mode &= 0xF0;
-		RTW_INFO("This is the case of 8703AS\n");
-	}
-#endif
-}
-
 VOID
 Hal_EfuseParseVoltage_8723D(
 	IN	PADAPTER		pAdapter,
@@ -4258,10 +4194,16 @@ static void rtl8723d_fill_default_txdesc(
 			SET_TX_DESC_USE_RATE_8723D(pbuf, 1);
 			if (pmlmeinfo->preamble_mode == PREAMBLE_SHORT)
 				SET_TX_DESC_DATA_SHORT_8723D(pbuf, 1);
-			SET_TX_DESC_TX_RATE_8723D(pbuf, MRateToHwRate(pmlmeext->tx_rate));
-
-			RTW_INFO(FUNC_ADPT_FMT ": SP Packet(0x%04X) rate=0x%x\n",
-				FUNC_ADPT_ARG(padapter), pattrib->ether_type, MRateToHwRate(pmlmeext->tx_rate));
+#ifdef CONFIG_IP_R_MONITOR
+			if((pattrib->ether_type == ETH_P_ARP) &&
+				(IsSupportedTxOFDM(padapter->registrypriv.wireless_mode))) 
+				SET_TX_DESC_TX_RATE_8723D(pbuf, MRateToHwRate(IEEE80211_OFDM_RATE_6MB));
+			 else
+#endif/*CONFIG_IP_R_MONITOR*/
+				SET_TX_DESC_TX_RATE_8723D(pbuf, MRateToHwRate(pmlmeext->tx_rate));
+
+			RTW_INFO(FUNC_ADPT_FMT ": SP Packet(0x%04X) rate=0x%x SeqNum = %d\n",
+				FUNC_ADPT_ARG(padapter), pattrib->ether_type, MRateToHwRate(pmlmeext->tx_rate), pattrib->seqnum);
 		}
 
 #if defined(CONFIG_USB_TX_AGGREGATION) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
@@ -4393,13 +4335,15 @@ static void hw_var_set_monitor(PADAPTER Adapter, u8 variable, u8 *val)
 
 	if (*((u8 *)val) == _HW_STATE_MONITOR_) {
 
-
+#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
+		rcr_bits = RCR_AAP | RCR_APM | RCR_AM | RCR_AB | RCR_APWRMGT | RCR_ADF | RCR_AMF | RCR_APP_PHYST_RXFF;
+#else
 		/* Receive all type */
 		rcr_bits = RCR_AAP | RCR_APM | RCR_AM | RCR_AB | RCR_APWRMGT | RCR_ADF | RCR_ACF | RCR_AMF | RCR_APP_PHYST_RXFF;
 
 		/* Append FCS */
 		rcr_bits |= RCR_APPFCS;
-
+#endif
 #if 0
 		/*
 		   CRC and ICV packet will drop in recvbuf2recvframe()
@@ -4455,9 +4399,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 #ifdef CONFIG_CONCURRENT_MODE
 	if (padapter->hw_port == HW_PORT1) {
 		/* disable Port1 TSF update */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
-		val8 |= DIS_TSF_UDT;
-		rtw_write8(padapter, REG_BCN_CTRL_1, val8);
+		rtw_iface_disable_tsf_update(padapter);
 
 		Set_MSR(padapter, mode);
 
@@ -4507,8 +4449,6 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 #endif /* CONFIG_INTERRUPT_BASED_TXBCN */
 #endif /* !CONFIG_PCI_HCI */
 
-			ResumeTxBeacon(padapter);
-
 			rtw_write8(padapter, REG_BCN_CTRL_1, DIS_TSF_UDT | DIS_BCNQ_SUB);
 
 			/* enable to rx data frame*/
@@ -4521,7 +4461,6 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			/* rtw_write8(padapter, REG_BCN_MAX_ERR, 0xFF); */
 			rtw_write8(padapter, REG_ATIMWND_1, 0x0c); /* 13ms for port1 */
-			rtw_write16(padapter, REG_BCNTCFG, 0x00);
 
 			rtw_write16(padapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
 
@@ -4549,8 +4488,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 #ifdef CONFIG_TSF_RESET_OFFLOAD
 			/* Reset TSF for STA+AP concurrent mode */
-			if (rtw_mi_buddy_check_fwstate(padapter,
-				(WIFI_STATION_STATE | WIFI_ASOC_STATE))) {
+			if (DEV_STA_LD_NUM(adapter_to_dvobj(padapter))) {
 				if (rtw_hal_reset_tsf(padapter, HW_PORT1) == _FAIL)
 					RTW_INFO("ERROR! %s()-%d: Reset port1 TSF fail\n",
 						 __FUNCTION__, __LINE__);
@@ -4564,9 +4502,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 		hw_var_set_opmode_mbid(padapter, mode);
 #else
 		/* disable Port0 TSF update */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL);
-		val8 |= DIS_TSF_UDT;
-		rtw_write8(padapter, REG_BCN_CTRL, val8);
+		rtw_iface_disable_tsf_update(padapter);
 
 		/* set net_type */
 		Set_MSR(padapter, mode);
@@ -4599,7 +4535,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			/* disable atim wnd */
 			rtw_write8(padapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_ATIM);
-			/* rtw_write8(padapter,REG_BCN_CTRL, 0x18); */
+			/* rtw_write8(padapter,REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION); */
 		} else if (mode == _HW_STATE_ADHOC_) {
 			ResumeTxBeacon(padapter);
 			rtw_write8(padapter, REG_BCN_CTRL, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_BCNQ_SUB);
@@ -4619,8 +4555,6 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 #endif /* CONFIG_INTERRUPT_BASED_TXBCN */
 #endif
 
-			ResumeTxBeacon(padapter);
-
 			rtw_write8(padapter, REG_BCN_CTRL, DIS_TSF_UDT | DIS_BCNQ_SUB);
 
 			/* enable to rx data frame */
@@ -4633,7 +4567,6 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 
 			/* rtw_write8(padapter, REG_BCN_MAX_ERR, 0xFF); */
 			rtw_write8(padapter, REG_ATIMWND, 0x0c); /* 13ms */
-			rtw_write16(padapter, REG_BCNTCFG, 0x00);
 
 			rtw_write16(padapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
 
@@ -4658,8 +4591,7 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 			rtw_write8(padapter, REG_BCN_CTRL_1, val8);
 #ifdef CONFIG_TSF_RESET_OFFLOAD
 			/* Reset TSF for STA+AP concurrent mode */
-			if (rtw_mi_buddy_check_fwstate(padapter,
-				(WIFI_STATION_STATE | WIFI_ASOC_STATE))) {
+			if (DEV_STA_LD_NUM(adapter_to_dvobj(padapter))) {
 				if (rtw_hal_reset_tsf(padapter, HW_PORT0) == _FAIL)
 					RTW_INFO("ERROR! %s()-%d: Reset port0 TSF fail\n",
 						 __FUNCTION__, __LINE__);
@@ -4670,163 +4602,6 @@ static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)
 	}
 }
 
-static void hw_var_set_bcn_func(PADAPTER padapter, u8 variable, u8 *val)
-{
-	u32 bcn_ctrl_reg;
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->hw_port == HW_PORT1)
-		bcn_ctrl_reg = REG_BCN_CTRL_1;
-	else
-#endif
-	{
-		bcn_ctrl_reg = REG_BCN_CTRL;
-	}
-
-	if (*(u8 *)val)
-		rtw_write8(padapter, bcn_ctrl_reg, (EN_BCN_FUNCTION | EN_TXBCN_RPT));
-	else {
-		u8 val8;
-
-		val8 = rtw_read8(padapter, bcn_ctrl_reg);
-		val8 &= ~(EN_BCN_FUNCTION | EN_TXBCN_RPT);
-#ifdef CONFIG_BT_COEXIST
-		/* Always enable port0 beacon function for PSTDMA */
-		if (REG_BCN_CTRL == bcn_ctrl_reg)
-			val8 |= EN_BCN_FUNCTION;
-#endif
-		rtw_write8(padapter, bcn_ctrl_reg, val8);
-	}
-}
-
-static void hw_var_set_mlme_disconnect(PADAPTER padapter, u8 variable, u8 *val)
-{
-	u8 val8;
-
-	/* reject all data frames */
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_mi_check_status(padapter, MI_LINKED) == _FALSE)
-#endif
-		rtw_write16(padapter, REG_RXFLTMAP2, 0);
-
-#ifdef CONFIG_CONCURRENT_MODE
-	if (padapter->hw_port == HW_PORT1) {
-	/* reset TSF1 */
-		rtw_write8(padapter, REG_DUAL_TSF_RST, BIT(1));
-
-	/* disable update TSF1 */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
-		val8 |= DIS_TSF_UDT;
-		rtw_write8(padapter, REG_BCN_CTRL_1, val8);
-	} else
-#endif
-	{
-	/* reset TSF */
-		rtw_write8(padapter, REG_DUAL_TSF_RST, BIT(0));
-
-	/* disable update TSF */
-		val8 = rtw_read8(padapter, REG_BCN_CTRL);
-		val8 |= DIS_TSF_UDT;
-		rtw_write8(padapter, REG_BCN_CTRL, val8);
-	}
-}
-
-static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)
-{
-	u8 val8;
-	u16 val16;
-	u32 val32;
-	u8 RetryLimit;
-	u8 type;
-	PHAL_DATA_TYPE pHalData;
-	struct mlme_priv *pmlmepriv;
-
-	RetryLimit = RL_VAL_STA;
-	type = *(u8 *)val;
-	pHalData = GET_HAL_DATA(padapter);
-	pmlmepriv = &padapter->mlmepriv;
-#ifdef CONFIG_CONCURRENT_MODE
-	if (type == 0) {
-		/* prepare to join */
-		if (rtw_mi_get_ap_num(padapter) || rtw_mi_get_mesh_num(padapter))
-			StopTxBeacon(padapter);
-
-		/* enable to rx data frame.Accept all data frame */
-		rtw_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
-
-		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-			RetryLimit = (pHalData->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
-		else /* Ad-hoc Mode */
-			RetryLimit = RL_VAL_AP;
-		} else if (type == 1) {
-			/* joinbss_event call back when join res < 0 */
-			if (rtw_mi_check_status(padapter, MI_LINKED) == _FALSE)
-				rtw_write16(padapter, REG_RXFLTMAP2, 0x00);
-
-			if (rtw_mi_get_ap_num(padapter) || rtw_mi_get_mesh_num(padapter)) {
-				ResumeTxBeacon(padapter);
-				/* reset TSF 1/2 after ResumeTxBeacon */
-				rtw_write8(padapter, REG_DUAL_TSF_RST, BIT(1) | BIT(0));
-			}
-		} else if (type == 2) {
-			/* sta add event call back */
-#ifdef CONFIG_MI_WITH_MBSSID_CAM
-			/*if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) && (rtw_mi_get_assoced_sta_num(padapter) == 1))
-				rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL)&(~DIS_TSF_UDT));*/
-#else
-			/* enable update TSF */
-			if (padapter->hw_port == HW_PORT1) {
-				val8 = rtw_read8(padapter, REG_BCN_CTRL_1);
-				val8 &= ~DIS_TSF_UDT;
-				rtw_write8(padapter, REG_BCN_CTRL_1, val8);
-			} else {
-				val8 = rtw_read8(padapter, REG_BCN_CTRL);
-				val8 &= ~DIS_TSF_UDT;
-				rtw_write8(padapter, REG_BCN_CTRL, val8);
-			}
-#endif
-			if (check_fwstate(pmlmepriv,
-				WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
-				rtw_write8(padapter, 0x542 , 0x02);
-				RetryLimit = RL_VAL_AP;
-			}
-
-			if (rtw_mi_get_ap_num(padapter) || rtw_mi_get_mesh_num(padapter)) {
-				ResumeTxBeacon(padapter);
-
-			/* reset TSF 1/2 after ResumeTxBeacon */
-				rtw_write8(padapter, REG_DUAL_TSF_RST, BIT(1) | BIT(0));
-			}
-		}
-
-		val16 = (RetryLimit << RETRY_LIMIT_SHORT_SHIFT) | (RetryLimit << RETRY_LIMIT_LONG_SHIFT);
-		rtw_write16(padapter, REG_RL, val16);
-#else /* !CONFIG_CONCURRENT_MODE */
-		if (type == 0) { /* prepare to join */
-			/* enable to rx data frame.Accept all data frame */
-			rtw_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
-
-			if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
-				RetryLimit = (pHalData->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
-			else /* Ad-hoc Mode */
-				RetryLimit = RL_VAL_AP;
-		} else if (type == 1) /* joinbss_event call back when join res < 0 */
-			rtw_write16(padapter, REG_RXFLTMAP2, 0x00);
-		else if (type == 2) { /* sta add event call back */
-			/* enable update TSF */
-			val8 = rtw_read8(padapter, REG_BCN_CTRL);
-			val8 &= ~DIS_TSF_UDT;
-			rtw_write8(padapter, REG_BCN_CTRL, val8);
-
-			if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE))
-				RetryLimit = RL_VAL_AP;
-		}
-
-	val16 = (RetryLimit << RETRY_LIMIT_SHORT_SHIFT) | (RetryLimit << RETRY_LIMIT_LONG_SHIFT);
-	rtw_write16(padapter, REG_RL, val16);
-#endif /* !CONFIG_CONCURRENT_MODE */
-}
-
 void CCX_FwC2HTxRpt_8723d(PADAPTER padapter, u8 *pdata, u8 len)
 {
 	u8 seq_no;
@@ -4926,56 +4701,6 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 		rtw_write8(padapter, REG_TXPAUSE, *val);
 		break;
 
-	case HW_VAR_BCN_FUNC:
-		hw_var_set_bcn_func(padapter, variable, val);
-		break;
-
-	case HW_VAR_MLME_DISCONNECT:
-		hw_var_set_mlme_disconnect(padapter, variable, val);
-		break;
-
-	case HW_VAR_MLME_JOIN:
-		hw_var_set_mlme_join(padapter, variable, val);
-
-#ifdef CONFIG_BT_COEXIST
-		switch (*val) {
-		case 0:
-			/* Notify coex. mechanism before join */
-			rtw_btcoex_ConnectNotify(padapter, _TRUE);
-			break;
-		case 1:
-		case 2:
-			/* Notify coex. mechanism after join, whether successful or failed */
-			rtw_btcoex_ConnectNotify(padapter, _FALSE);
-			break;
-		}
-#endif /* CONFIG_BT_COEXIST */
-		break;
-
-	case HW_VAR_BEACON_INTERVAL:
-		{
-			u16 bcn_interval = *((u16 *)val);
-
-			#ifdef CONFIG_SWTIMER_BASED_TXBCN
-			bcn_interval = rtw_hal_bcn_interval_adjust(padapter, bcn_interval);
-			#endif
-
-			rtw_write16(padapter, REG_BCN_INTERVAL, bcn_interval);
-
-			#ifdef CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
-			{
-				struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-				struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
-
-				if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
-					RTW_INFO("%s==> bcn_interval:%d, eraly_int:%d\n", __func__, bcn_interval, bcn_interval >> 1);
-					rtw_write8(padapter, REG_DRVERLYINT, bcn_interval >> 1);
-				}
-			}
-			#endif/* CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT */
-		}
-		break;
-
 	case HW_VAR_SLOT_TIME:
 		rtw_write8(padapter, REG_SLOT, *val);
 		break;
@@ -5032,6 +4757,7 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 				/* 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;
@@ -5070,13 +4796,13 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 		if (ctrl != 0) {
 			hwctrl |= AcmHw_HwEn;
 
-		if (ctrl & BIT(1)) /* BE */
+		if (ctrl & BIT(3)) /* BE */
 			hwctrl |= AcmHw_BeqEn;
 
 		if (ctrl & BIT(2)) /* VI */
 			hwctrl |= AcmHw_ViqEn;
 
-		if (ctrl & BIT(3)) /* VO */
+		if (ctrl & BIT(1)) /* VO */
 			hwctrl |= AcmHw_VoqEn;
 		}
 
@@ -5084,7 +4810,7 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 		rtw_write8(padapter, REG_ACMHWCTRL, hwctrl);
 	}
 		break;
-
+#ifdef CONFIG_80211N_HT
 	case HW_VAR_AMPDU_FACTOR: {
 		u32	AMPDULen = (*((u8 *)val));
 
@@ -5096,7 +4822,7 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 		rtw_write32(padapter, REG_AMPDU_MAX_LENGTH_8723D, AMPDULen);
 	}
 		break;
-
+#endif /* CONFIG_80211N_HT */
 #if 0
 	case HW_VAR_RXDMA_AGG_PG_TH:
 		rtw_write8(padapter, REG_RXDMA_AGG_PG_TH, *val);
@@ -5125,6 +4851,17 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 #endif
 		break;
 
+	case HW_VAR_DL_RSVD_PAGE:
+#ifdef CONFIG_BT_COEXIST
+		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
+			rtl8723d_download_BTCoex_AP_mode_rsvd_page(padapter);
+		else
+#endif /* CONFIG_BT_COEXIST */
+		{
+			rtl8723d_download_rsvd_page(padapter, RT_MEDIA_CONNECT);
+		}
+		break;
+
 #ifdef CONFIG_P2P
 	case HW_VAR_H2C_FW_P2P_PS_OFFLOAD:
 		rtl8723d_set_p2p_ps_offload_cmd(padapter, *val);
@@ -5215,8 +4952,8 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 		u8 RetryLimit = 0x01;
 		u32 reg_200, reg_204;
 
-		val16 = RetryLimit << RETRY_LIMIT_SHORT_SHIFT | RetryLimit << RETRY_LIMIT_LONG_SHIFT;
-		rtw_write16(padapter, REG_RL, val16);
+		val16 = BIT_SRL(RetryLimit) | BIT_LRL(RetryLimit);
+		rtw_write16(padapter, REG_RETRY_LIMIT, val16);
 
 		for (i = 0; i < 200; i++) { /* polling 200x10=2000 msec */
 			reg_200 = rtw_read32(padapter, 0x200);
@@ -5234,8 +4971,8 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 			RTW_INFO("packets in tx buffer - 0x204=%x, 0x200=%x\n", reg_204, reg_200);
 
 		RetryLimit = RL_VAL_STA;
-		val16 = RetryLimit << RETRY_LIMIT_SHORT_SHIFT | RetryLimit << RETRY_LIMIT_LONG_SHIFT;
-		rtw_write16(padapter, REG_RL, val16);
+		val16 = BIT_SRL(RetryLimit) | BIT_LRL(RetryLimit);
+		rtw_write16(padapter, REG_RETRY_LIMIT, val16);
 	}
 		break;
 #endif /* CONFIG_CONCURRENT_MODE */
@@ -5285,23 +5022,6 @@ u8 SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 			rtw_write8(padapter, REG_DWBCN1_CTRL_8723D + 2, val8);
 		}
 		break;
-	case HW_VAR_DO_IQK:
-		if (*val)
-			pHalData->bNeedIQK = _TRUE;
-		else
-			pHalData->bNeedIQK = _FALSE;
-		break;
-
-	case HW_VAR_DL_RSVD_PAGE:
-#ifdef CONFIG_BT_COEXIST
-		if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
-			rtl8723d_download_BTCoex_AP_mode_rsvd_page(padapter);
-		else
-#endif /* CONFIG_BT_COEXIST */
-		{
-			rtl8723d_download_rsvd_page(padapter, RT_MEDIA_CONNECT);
-		}
-		break;
 
 #if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
 	case HW_VAR_TDLS_BCN_EARLY_C2H_RPT:
@@ -5405,6 +5125,48 @@ static void dump_mac_txfifo_8723d(void *sel, _adapter *adapter)
 			, hpq, lpq, npq, epq, pubq);
 }
 
+void rtl8723d_read_wmmedca_reg(PADAPTER adapter, u16 *vo_params, u16 *vi_params, u16 *be_params, u16 *bk_params)
+{
+	u8 vo_reg_params[4];
+	u8 vi_reg_params[4];
+	u8 be_reg_params[4];
+	u8 bk_reg_params[4];
+
+	GetHwReg8723D(adapter, HW_VAR_AC_PARAM_VO, vo_reg_params);
+	GetHwReg8723D(adapter, HW_VAR_AC_PARAM_VI, vi_reg_params);
+	GetHwReg8723D(adapter, HW_VAR_AC_PARAM_BE, be_reg_params);
+	GetHwReg8723D(adapter, HW_VAR_AC_PARAM_BK, bk_reg_params);
+
+	vo_params[0] = vo_reg_params[0];
+	vo_params[1] = vo_reg_params[1] & 0x0F;
+	vo_params[2] = (vo_reg_params[1] & 0xF0) >> 4;
+	vo_params[3] = ((vo_reg_params[3] << 8) | (vo_reg_params[2])) * 32;
+
+	vi_params[0] = vi_reg_params[0];
+	vi_params[1] = vi_reg_params[1] & 0x0F;
+	vi_params[2] = (vi_reg_params[1] & 0xF0) >> 4;
+	vi_params[3] = ((vi_reg_params[3] << 8) | (vi_reg_params[2])) * 32;
+
+	be_params[0] = be_reg_params[0];
+	be_params[1] = be_reg_params[1] & 0x0F;
+	be_params[2] = (be_reg_params[1] & 0xF0) >> 4;
+	be_params[3] = ((be_reg_params[3] << 8) | (be_reg_params[2])) * 32;
+
+	bk_params[0] = bk_reg_params[0];
+	bk_params[1] = bk_reg_params[1] & 0x0F;
+	bk_params[2] = (bk_reg_params[1] & 0xF0) >> 4;
+	bk_params[3] = ((bk_reg_params[3] << 8) | (bk_reg_params[2])) * 32;
+
+	vo_params[1] = (1 << vo_params[1]) - 1;
+	vo_params[2] = (1 << vo_params[2]) - 1;
+	vi_params[1] = (1 << vi_params[1]) - 1;
+	vi_params[2] = (1 << vi_params[2]) - 1;
+	be_params[1] = (1 << be_params[1]) - 1;
+	be_params[2] = (1 << be_params[2]) - 1;
+	bk_params[1] = (1 << bk_params[1]) - 1;
+	bk_params[2] = (1 << bk_params[2]) - 1;
+}
+
 void GetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
@@ -5431,6 +5193,38 @@ void GetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)
 		}
 		break;
 
+	case HW_VAR_AC_PARAM_VO:
+		val32 = rtw_read32(padapter, REG_EDCA_VO_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
+	case HW_VAR_AC_PARAM_VI:
+		val32 = rtw_read32(padapter, REG_EDCA_VI_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
+	case HW_VAR_AC_PARAM_BE:
+		val32 = rtw_read32(padapter, REG_EDCA_BE_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
+	case HW_VAR_AC_PARAM_BK:
+		val32 = rtw_read32(padapter, REG_EDCA_BK_PARAM);
+		val[0] = val32 & 0xFF;
+		val[1] = (val32 >> 8) & 0xFF;
+		val[2] = (val32 >> 16) & 0xFF;
+		val[3] = (val32 >> 24) & 0x07;
+		break;
+
 	case HW_VAR_EFUSE_USAGE:
 		*val = pHalData->EfuseUsedPercentage;
 		break;
@@ -5529,8 +5323,8 @@ void hal_ra_info_dump(_adapter *padapter , void *sel)
 			rtw_write32(padapter, REG_HMEBOX_DBG_2_8723D, cmd);
 			rtw_msleep_os(10);
 			ra_info1 = rtw_read32(padapter, 0x2F0);
-			curr_tx_rate = ra_info1 & 0x7F;
-			curr_tx_sgi = (ra_info1 >> 7) & 0x01;
+			curr_tx_sgi = rtw_get_current_tx_sgi(padapter, macid_ctl->sta[mac_id]);
+			curr_tx_rate = rtw_get_current_tx_rate(padapter, macid_ctl->sta[mac_id]);
 
 			_RTW_PRINT_SEL(sel , "[ ra_info1:0x%08x ] =>cur_tx_rate= %s,cur_sgi:%d\n", ra_info1, HDATA_RATE(curr_tx_rate), curr_tx_sgi);
 			_RTW_PRINT_SEL(sel , "[ ra_info1:0x%08x ] => PWRSTS = 0x%02x\n", ra_info1, (ra_info1 >> 8)  & 0x07);
@@ -5683,10 +5477,13 @@ void rtl8723d_start_thread(_adapter *padapter)
 #ifndef CONFIG_SDIO_TX_TASKLET
 	struct xmit_priv *xmitpriv = &padapter->xmitpriv;
 
-	xmitpriv->SdioXmitThread = kthread_run(rtl8723ds_xmit_thread, padapter, "RTWHALXT");
-	if (IS_ERR(xmitpriv->SdioXmitThread)) {
-		RTW_ERR("%s: start rtl8723ds_xmit_thread FAIL!!\n", __func__);
-		xmitpriv->SdioXmitThread = NULL;
+	if (xmitpriv->SdioXmitThread == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT " start RTWHALXT\n", FUNC_ADPT_ARG(padapter));
+		xmitpriv->SdioXmitThread = kthread_run(rtl8723ds_xmit_thread, padapter, "RTWHALXT");
+		if (IS_ERR(xmitpriv->SdioXmitThread)) {
+			RTW_ERR("%s: start rtl8723ds_xmit_thread FAIL!!\n", __func__);
+			xmitpriv->SdioXmitThread = NULL;
+		}
 	}
 #endif
 #endif
@@ -5750,6 +5547,7 @@ void rtl8723d_set_hal_ops(struct hal_ops *pHalFunc)
 	pHalFunc->set_chnl_bw_handler = &PHY_SetSwChnlBWMode8723D;
 	pHalFunc->set_tx_power_level_handler = &PHY_SetTxPowerLevel8723D;
 	pHalFunc->get_tx_power_level_handler = &PHY_GetTxPowerLevel8723D;
+	pHalFunc->set_tx_power_index_handler = PHY_SetTxPowerIndex_8723D;
 	pHalFunc->get_tx_power_index_handler = &PHY_GetTxPowerIndex_8723D;
 	pHalFunc->hal_dm_watchdog = &rtl8723d_HalDmWatchDog;
 
@@ -5760,6 +5558,7 @@ void rtl8723d_set_hal_ops(struct hal_ops *pHalFunc)
 	pHalFunc->write_bbreg = &PHY_SetBBReg_8723D;
 	pHalFunc->read_rfreg = &PHY_QueryRFReg_8723D;
 	pHalFunc->write_rfreg = &PHY_SetRFReg_8723D;
+	pHalFunc->read_wmmedca_reg = &rtl8723d_read_wmmedca_reg;
 
 	/* Efuse related function */
 	pHalFunc->BTEfusePowerSwitch = &Hal_BT_EfusePowerSwitch;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_lps_poff.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_lps_poff.c
index ee574c8718e3..68a8f9e14861 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_lps_poff.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_lps_poff.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -204,7 +205,7 @@ static void rtl8723d_lps_poff_set_tx_bndy(PADAPTER padapter, u8 tx_bndy)
 	u32	val32 = 0;
 	u8	val8  = 0;
 
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#ifdef CONFIG_PCI_HCI
 	numHQ = 0x8;
 	numLQ = 0x8;
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_phycfg.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_phycfg.c
index 0bdb826b500c..fdb55589d959 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_phycfg.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_phycfg.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -595,7 +596,7 @@ PHY_BBConfig8723D(
 {
 	int	rtStatus = _SUCCESS;
 	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(Adapter);
-	u32	RegVal;
+	u16	RegVal;
 	u8	TmpU1B = 0;
 	u8	value8;
 
@@ -603,17 +604,16 @@ PHY_BBConfig8723D(
 
 	/* Enable BB and RF */
 	RegVal = rtw_read16(Adapter, REG_SYS_FUNC_EN);
-	rtw_write16(Adapter, REG_SYS_FUNC_EN, (u16)(RegVal | BIT(13) | BIT(0) | BIT(1)));
+	RegVal |= FEN_EN_25_1 | FEN_BB_GLB_RSTn | FEN_BBRSTB;
+	rtw_write16(Adapter, REG_SYS_FUNC_EN, RegVal);
 
 	rtw_write8(Adapter, REG_RF_CTRL, RF_EN | RF_RSTB | RF_SDMRSTB);
 
-#if (DEV_BUS_TYPE == RT_USB_INTERFACE)
-	rtw_write8(Adapter, REG_SYS_FUNC_EN, FEN_USBA | FEN_USBD | FEN_BB_GLB_RSTn | FEN_BBRSTB);
-#else
+#if defined(CONFIG_PCI_HCI)
 	rtw_write8(Adapter, REG_SYS_FUNC_EN, FEN_PPLL | FEN_PCIEA | FEN_DIO_PCIE | FEN_BB_GLB_RSTn | FEN_BBRSTB);
 #endif
 
-#if DEV_BUS_TYPE == RT_USB_INTERFACE
+#ifdef CONFIG_USB_HCI
 	/* To Fix MAC loopback mode fail. Suggested by SD4 Johnny. 2010.03.23. */
 	PlatformEFIOWrite1Byte(Adapter, REG_LDOHCI12_CTRL, 0x0f);
 	PlatformEFIOWrite1Byte(Adapter, 0x15, 0xe9);
@@ -808,6 +808,7 @@ PHY_GetTxPowerIndex_8723D(
 )
 {
 	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
+	struct hal_spec_t *hal_spec = GET_HAL_SPEC(pAdapter);
 	s16 power_idx;
 	u8 base_idx = 0;
 	s8 by_rate_diff = 0, limit = 0, tpt_offset = 0, extra_bias = 0;
@@ -834,8 +835,8 @@ PHY_GetTxPowerIndex_8723D(
 
 	if (power_idx < 0)
 		power_idx = 0;
-	else if (power_idx > MAX_POWER_INDEX)
-		power_idx = MAX_POWER_INDEX;
+	else if (power_idx > hal_spec->txgi_max)
+		power_idx = hal_spec->txgi_max;
 
 	return power_idx;
 }
@@ -899,7 +900,7 @@ phy_SpurCalibration_8723D(
 	/* add for notch */
 	u4Byte				wlan_channel, CurrentChannel;
 	HAL_DATA_TYPE		*pHalData	= GET_HAL_DATA(pAdapter);
-	struct PHY_DM_STRUCT		*pDM_Odm = &(pHalData->odmpriv);
+	struct dm_struct		*pDM_Odm = &(pHalData->odmpriv);
 
 	/* check threshold */
 	if (threshold <= 0x0)
@@ -1167,6 +1168,16 @@ phy_SwChnlAndSetBwMode8723D(
 		pHalData->bSetChnlBW = _FALSE;
 	}
 
+	if (pHalData->bNeedIQK == _TRUE) {
+		if (pHalData->neediqk_24g == _TRUE) {
+
+			halrf_iqk_trigger(&pHalData->odmpriv, _FALSE);
+			pHalData->bIQKInitialized = _TRUE;
+			pHalData->neediqk_24g = _FALSE;
+		}
+		pHalData->bNeedIQK = _FALSE;
+	}
+
 	PHY_SetTxPowerLevel8723D(Adapter, pHalData->current_channel);
 }
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rf6052.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rf6052.c
index 9d5f46acb323..638d5036247d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rf6052.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rf6052.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -45,9 +46,11 @@
 
 
 /*------------------------Define local variable------------------------------*/
+#ifdef CONFIG_RF_SHADOW_RW
 /* 2008/11/20 MH For Debug only, RF
  * static	RF_SHADOW_T	RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG] = {0}; */
 static	RF_SHADOW_T	RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
+#endif /*CONFIG_RF_SHADOW_RW*/
 /*------------------------Define local variable------------------------------*/
 
 /*-----------------------------------------------------------------------------
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rxdesc.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rxdesc.c
index 10eb324da203..92bfd9446a22 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rxdesc.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_rxdesc.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -50,7 +51,7 @@ void rtl8723d_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc)
 
 		/* Offset 12 */
 		pattrib->data_rate = (u8)GET_RX_STATUS_DESC_RX_RATE_8723D(pdesc);
-
+		pattrib->bw = CHANNEL_WIDTH_MAX;
 		/* Offset 20 */
 		/* pattrib->tsfl=(u8)GET_RX_STATUS_DESC_TSFL_8723D(pdesc); */
 	}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_sreset.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_sreset.c
index db38541a4079..052f961a711b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_sreset.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/rtl8723d_sreset.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_led.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_led.c
index 6a7fbc709069..8424a64570ea 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_led.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_led.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -90,7 +91,7 @@ rtl8723ds_InitSwLeds(
 )
 {
 #if 0
-	struct led_priv *pledpriv = &(padapter->ledpriv);
+	struct led_priv *pledpriv = adapter_to_led(padapter);
 
 	pledpriv->LedControlHandler = LedControlSDIO;
 
@@ -114,7 +115,7 @@ rtl8723ds_DeInitSwLeds(
 )
 {
 #if 0
-	struct led_priv	*ledpriv = &(padapter->ledpriv);
+	struct led_priv	*ledpriv = adapter_to_led(padapter);
 
 	DeInitLed871x(&(ledpriv->SwLed0));
 	DeInitLed871x(&(ledpriv->SwLed1));
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_recv.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_recv.c
index 1bed99eb9f65..79bbde6d4f7f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_recv.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_recv.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -164,7 +165,9 @@ s32 rtl8723ds_recv_hdl(_adapter *padapter)
 		d = adapter_to_dvobj(padapter);
 		for (i = 0; i < d->iface_nums; i++) {
 			a = d->padapters[i];
-			if (rtw_if_up(a) == _TRUE)
+			precvpriv = &a->recvpriv;
+			if (rtw_if_up(a) == _TRUE
+				&& skb_queue_len(&precvpriv->rx_napi_skb_queue))
 				napi_schedule(&a->napi);
 	
 		}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_xmit.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_xmit.c
index fe31d6f5ea1b..ae65466ab71b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_xmit.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/rtl8723ds_xmit.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -128,7 +129,10 @@ query_free_page:
 		goto free_xmitbuf;
 
 #ifdef CONFIG_CHECK_LEAVE_LPS
-	traffic_check_for_leave_lps(padapter, _TRUE, pxmitbuf->agg_num);
+	#ifdef CONFIG_LPS_CHK_BY_TP
+	if (!adapter_to_pwrctl(padapter)->lps_chk_by_tp)
+	#endif
+		traffic_check_for_leave_lps(padapter, _TRUE, pxmitbuf->agg_num);
 #endif
 
 	rtw_write_port(padapter, deviceId, pxmitbuf->len, (u8 *)pxmitbuf);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_halinit.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_halinit.c
index fe80a43ec5f9..81e5aa73fa65 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_halinit.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_halinit.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -214,7 +215,7 @@ static void _InitQueueReservedPage(PADAPTER padapter)
 	value32 = _HPQ(numHQ) | _LPQ(numLQ) | _PUBQ(numPubQ) | LD_RQPN;
 	rtw_write32(padapter, REG_RQPN, value32);
 
-	rtw_hal_set_sdio_tx_max_length(padapter, numHQ, numNQ, numLQ, numPubQ);
+	rtw_hal_set_sdio_tx_max_length(padapter, numHQ, numNQ, numLQ, numPubQ, SDIO_TX_DIV_NUM);
 
 #ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT
 	_init_available_page_threshold(padapter, numHQ, numNQ, numLQ, numPubQ);
@@ -511,8 +512,8 @@ void _InitAdaptiveCtrl(PADAPTER padapter)
 	rtw_write16(padapter, REG_SPEC_SIFS, value16);
 
 	/* Retry Limit */
-	value16 = _LRL(RL_VAL_STA) | _SRL(RL_VAL_STA);
-	rtw_write16(padapter, REG_RL, value16);
+	value16 = BIT_LRL(RL_VAL_STA) | BIT_SRL(RL_VAL_STA);
+	rtw_write16(padapter, REG_RETRY_LIMIT, value16);
 }
 
 void _InitEDCA(PADAPTER padapter)
@@ -777,6 +778,39 @@ static BOOLEAN HalDetectPwrDownMode(PADAPTER Adapter)
 	return pHalData->pwrdown;
 }	/* HalDetectPwrDownMode */
 
+static void	rtl8723ds_init_burst_pkt_len(PADAPTER padapter)
+{
+	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
+
+	rtw_write8(padapter, 0x4c7, rtw_read8(padapter, 0x4c7) | BIT(7)); /* enable single pkt ampdu */
+	rtw_write8(padapter, REG_RX_PKT_LIMIT_8723D, 0x18);		/* for VHT packet length 11K */
+	rtw_write8(padapter, REG_MAX_AGGR_NUM_8723D, 0x1F);
+	rtw_write8(padapter, REG_PIFS_8723D, 0x00);
+	rtw_write8(padapter, REG_FWHW_TXQ_CTRL_8723D, rtw_read8(padapter, REG_FWHW_TXQ_CTRL) & (~BIT(7)));
+	if (pHalData->AMPDUBurstMode)
+		rtw_write8(padapter, REG_AMPDU_BURST_MODE_8723D,  0x5F);
+	rtw_write8(padapter, REG_AMPDU_MAX_TIME_8723D, 0x70);
+
+	/* ARFB table 9 for 11ac 5G 2SS */
+	rtw_write32(padapter, REG_ARFR0_8723D, 0x00000010);
+	if (IS_NORMAL_CHIP(pHalData->version_id))
+		rtw_write32(padapter, REG_ARFR0_8723D + 4, 0xfffff000);
+	else
+		rtw_write32(padapter, REG_ARFR0_8723D + 4, 0x3e0ff000);
+
+	/* ARFB table 10 for 11ac 5G 1SS */
+	rtw_write32(padapter, REG_ARFR1_8723D, 0x00000010);
+	rtw_write32(padapter, REG_ARFR1_8723D + 4, 0x003ff000);
+}
+
+static void rtl8723ds_init_lte_coex(PADAPTER padapter)
+{
+	/* LTE COEX setting */
+	rtw_write16(padapter, REG_LTECOEX_WRITE_DATA, 0x7700);
+	rtw_write32(padapter, REG_LTECOEX_CTRL, 0xc0020038);
+	rtw_write8(padapter, 0x73, 0x04);
+}
+
 static u32 rtl8723ds_hal_init(PADAPTER padapter)
 {
 	s32 ret;
@@ -903,23 +937,23 @@ static u32 rtl8723ds_hal_init(PADAPTER padapter)
 		RTW_INFO("FW exist before power on!!\n");
 	else
 		RTW_INFO("FW does not exist before power on!!\n");
-
+#ifdef DBG_CHECK_FW_PS_STATE
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
 		RTW_INFO("check fw_ps_state fail before PowerOn!\n");
 		pdbgpriv->dbg_ips_drvopen_fail_cnt++;
 	}
-
+#endif
 	ret = rtw_hal_power_on(padapter);
 	if (_FAIL == ret) {
 		return _FAIL;
 	}
 	RTW_INFO("Power on ok!\n");
-
+#ifdef DBG_CHECK_FW_PS_STATE
 	if (rtw_fw_ps_state(padapter) == _FAIL) {
 		RTW_INFO("check fw_ps_state fail after PowerOn!\n");
 		pdbgpriv->dbg_ips_drvopen_fail_cnt++;
 	}
-
+#endif
 
 	rtw_write8(padapter, REG_EARLY_MODE_CONTROL, 0);
 
@@ -1028,11 +1062,11 @@ static u32 rtl8723ds_hal_init(PADAPTER padapter)
 	rtl8723d_InitBeaconParameters(padapter);
 	rtl8723d_InitBeaconMaxError(padapter, _TRUE);
 	_InitInterrupt(padapter);
-	_InitBurstPktLen_8723DS(padapter);
+	rtl8723ds_init_burst_pkt_len(padapter);
 
 #if 0
 	/* 8723D new ADD */
-	_InitLTECoex_8723DS(padapter);
+	rtl8723ds_init_lte_coex(padapter);
 #endif
 
 	/* YJ,TODO */
@@ -1141,6 +1175,8 @@ static u32 rtl8723ds_hal_init(PADAPTER padapter)
 
 			pwrpriv = adapter_to_pwrctl(padapter);
 
+			halrf_lck_trigger(&pHalData->odmpriv);
+
 			/* Inform WiFi FW that it is the beginning of IQK */
 			h2cCmdBuf = 1;
 			FillH2CCmd8723D(padapter, H2C_8723D_BT_WLAN_CALIBRATION, 1, &h2cCmdBuf);
@@ -1156,9 +1192,8 @@ static u32 rtl8723ds_hal_init(PADAPTER padapter)
 #ifdef CONFIG_BT_COEXIST
 			rtw_btcoex_IQKNotify(padapter, _TRUE);
 #endif
-			/*phy_iq_calibrate_8723d(padapter, _FALSE);*/
-			halrf_iqk_trigger(&pHalData->odmpriv, _FALSE);
-			pHalData->bIQKInitialized = _TRUE;
+
+			pHalData->neediqk_24g= _TRUE;
 #ifdef CONFIG_BT_COEXIST
 			rtw_btcoex_IQKNotify(padapter, _FALSE);
 #endif
@@ -1179,6 +1214,9 @@ static u32 rtl8723ds_hal_init(PADAPTER padapter)
 		rtw_btcoex_HAL_Initialize(padapter, _FALSE);
 #endif
 
+	if (padapter->registrypriv.wifi_spec == 1)
+		phy_set_bb_reg(padapter, rOFDM0_ECCAThreshold,
+			       0x00ff00ff, 0x00250029);
 
 	return _SUCCESS;
 }
@@ -1645,7 +1683,6 @@ u8 SetHwReg8723DS(PADAPTER padapter, u8 variable, u8 *val)
 		} else if (enable == _FALSE) {
 			RTW_INFO("%s: keep WLAN ctrl\n", __func__);
 		}
-		// 0x66[4,8]=0
 		/*0x66 bit4*/
 		value = rtw_read8(padapter, REG_PAD_CTRL_1 + 2);
 		if (enable && (value & BIT(4))) {
@@ -1743,8 +1780,6 @@ GetHalDefVar8723DSDIO(
 		else
 			*(HT_CAP_AMPDU_FACTOR *)pValue = MAX_AMPDU_FACTOR_16K;
 		break;
-		*(HT_CAP_AMPDU_FACTOR *)pValue = MAX_AMPDU_FACTOR_16K;
-		break;
 	default:
 		bResult = GetHalDefVar8723D(Adapter, eVariable, pValue);
 		break;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_ops.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_ops.c
index 96aef43424b7..afd6792a3ef2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_ops.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/rtl8723d/sdio/sdio_ops.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -492,7 +493,6 @@ static u32 sdio_read_port(
 	u8 *mem)
 {
 	PADAPTER padapter;
-	PSDIO_DATA psdio;
 	PHAL_DATA_TYPE phal;
 	u32 oldcnt;
 #ifdef SDIO_DYNAMIC_ALLOC_MEM
@@ -502,15 +502,12 @@ static u32 sdio_read_port(
 
 
 	padapter = pintfhdl->padapter;
-	psdio = &adapter_to_dvobj(padapter)->intf_data;
 	phal = GET_HAL_DATA(padapter);
 
 	HalSdioGetCmdAddr8723DSdio(padapter, addr, phal->SdioRxFIFOCnt++, &addr);
 
 	oldcnt = cnt;
-	if (cnt > psdio->block_transfer_len)
-		cnt = _RND(cnt, psdio->block_transfer_len);
-	/*	cnt = sdio_align_size(cnt); */
+	cnt = rtw_sdio_cmd53_align_size(adapter_to_dvobj(padapter), cnt);
 
 	if (oldcnt != cnt) {
 #ifdef SDIO_DYNAMIC_ALLOC_MEM
@@ -565,12 +562,10 @@ static u32 sdio_write_port(
 	u8 *mem)
 {
 	PADAPTER padapter;
-	PSDIO_DATA psdio;
 	s32 err;
 	struct xmit_buf *xmitbuf = (struct xmit_buf *)mem;
 
 	padapter = pintfhdl->padapter;
-	psdio = &adapter_to_dvobj(padapter)->intf_data;
 
 #ifndef CONFIG_DLFW_TXPKT
 	if (!rtw_is_hw_init_completed(padapter)) {
@@ -583,9 +578,7 @@ static u32 sdio_write_port(
 	cnt = _RND4(cnt);
 	HalSdioGetCmdAddr8723DSdio(padapter, addr, cnt >> 2, &addr);
 
-	if (cnt > psdio->block_transfer_len)
-		cnt = _RND(cnt, psdio->block_transfer_len);
-	/*	cnt = sdio_align_size(cnt); */
+	cnt = rtw_sdio_cmd53_align_size(adapter_to_dvobj(padapter), cnt);
 
 	err = sd_write(pintfhdl, addr, cnt, xmitbuf->pdata);
 
@@ -1272,7 +1265,7 @@ static void sd_recv_loopback(PADAPTER padapter, u32 size)
 
 	readsize = size;
 	RTW_INFO("%s: read size=%d\n", __func__, readsize);
-	allocsize = _RND(readsize, adapter_to_dvobj(padapter)->intf_data.block_transfer_len);
+	allocsize = _RND(readsize, rtw_sdio_get_block_size(adapter_to_dvobj(padapter)));
 
 	ploopback = padapter->ploopback;
 	if (ploopback) {
@@ -1380,14 +1373,13 @@ exit:
 #else /* !CONFIG_SDIO_RX_COPY */
 static struct recv_buf *sd_recv_rxfifo(PADAPTER padapter, u32 size)
 {
-	u32 sdioblksize, readsize, allocsize, ret;
+	u32 readsize, allocsize, ret;
 	u8 *preadbuf;
 	_pkt *ppkt;
 	struct recv_priv *precvpriv;
 	struct recv_buf	*precvbuf;
 
 
-	sdioblksize = adapter_to_dvobj(padapter)->intf_data.block_transfer_len;
 #if 0
 	readsize = size;
 #else
@@ -1398,10 +1390,7 @@ static struct recv_buf *sd_recv_rxfifo(PADAPTER padapter, u32 size)
 
 	/* 3 1. alloc skb */
 	/* align to block size */
-	if (readsize > sdioblksize)
-		allocsize = _RND(readsize, sdioblksize);
-	else
-		allocsize = readsize;
+	allocsize = rtw_sdio_cmd53_align_size(adapter_to_dvobj(padapter), readsize);
 
 	ppkt = rtw_skb_alloc(allocsize);
 
@@ -1463,6 +1452,138 @@ static void sd_rxhandler(PADAPTER padapter, struct recv_buf *precvbuf)
 #endif /* CONFIG_RECV_THREAD_MODE */
 }
 
+#ifndef CMD52_ACCESS_HISR_RX_REQ_LEN
+#define CMD52_ACCESS_HISR_RX_REQ_LEN 0
+#endif
+
+#ifndef SD_INT_HDL_DIS_HIMR_RX_REQ
+#define SD_INT_HDL_DIS_HIMR_RX_REQ 1
+#endif
+
+#if SD_INT_HDL_DIS_HIMR_RX_REQ
+static void disable_himr_rx_req_8723d_sdio(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
+	u32 himr = cpu_to_le32(hal->sdio_himr & ~SDIO_HISR_RX_REQUEST);
+
+	SdioLocalCmd52Write1Byte(adapter, SDIO_REG_HIMR, *((u8 *)&himr));
+}
+static void restore_himr_8723d_sdio(_adapter *adapter)
+{
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
+	u32 himr = cpu_to_le32(hal->sdio_himr);
+
+	SdioLocalCmd52Write1Byte(adapter, SDIO_REG_HIMR, *((u8 *)&himr));
+}
+#endif
+static u32 sdio_recv_and_drop(PADAPTER padapter, u32 size)
+{
+	u32 readsz, blksz, bufsz;
+	u8 *rbuf;
+	s32 ret = _SUCCESS;
+
+	/*
+	 * Patch for some SDIO Host 4 bytes issue
+	 * ex. RK3188
+	 */
+	readsz = RND4(size);
+
+	/* round to block size */
+	blksz = adapter_to_dvobj(padapter)->intf_data.block_transfer_len;
+	if (readsz > blksz)
+		bufsz = _RND(readsz, blksz);
+	else
+		bufsz = readsz;
+
+	rbuf = rtw_zmalloc(bufsz);
+	if (NULL == rbuf) {
+		RTW_ERR("%s: NULL == rbuf!\n", __FUNCTION__);
+		ret = _FAIL;
+		goto _exit;
+	}
+
+	ret = sdio_read_port(&padapter->iopriv.intf, WLAN_RX0FF_DEVICE_ID, bufsz, rbuf);
+	if (_FAIL == ret)
+		RTW_ERR("%s: read port FAIL!\n", __FUNCTION__);
+
+	if (NULL != rbuf)
+		rtw_mfree(rbuf, bufsz);
+
+_exit:
+	return ret;
+}
+
+void sd_recv(PADAPTER padapter)
+{
+	PHAL_DATA_TYPE phal = GET_HAL_DATA(padapter);
+	struct recv_buf *precvbuf;
+	int alloc_fail_time = 0;
+	u32 rx_cnt = 0;
+
+	do {
+		if (phal->SdioRxFIFOSize == 0) {
+			#if CMD52_ACCESS_HISR_RX_REQ_LEN
+			u16 rx_req_len;
+
+			rx_req_len = SdioLocalCmd52Read2Byte(padapter, SDIO_REG_RX0_REQ_LEN);
+			if (rx_req_len) {
+				if (rx_req_len % 256 == 0)
+					rx_req_len += SdioLocalCmd52Read1Byte(padapter, SDIO_REG_RX0_REQ_LEN);
+				phal->SdioRxFIFOSize = rx_req_len;
+			}
+			#else
+			u8 data[4];
+
+			_sdio_local_read(padapter, SDIO_REG_RX0_REQ_LEN, 4, data);
+			phal->SdioRxFIFOSize = le16_to_cpu(*(u16 *)data);
+			#endif
+		}
+
+		if (phal->SdioRxFIFOSize != 0) {
+			u32 ret;
+
+			#ifdef CONFIG_MAC_LOOPBACK_DRIVER
+			sd_recv_loopback(padapter, phal->SdioRxFIFOSize);
+			#else
+			ret = sd_recv_rxfifo(padapter, phal->SdioRxFIFOSize, &precvbuf);
+			if (precvbuf) {
+				sd_rxhandler(padapter, precvbuf);
+				phal->SdioRxFIFOSize = 0;
+				rx_cnt++;
+			} else {
+				alloc_fail_time++;
+#ifdef CONFIG_RECV_THREAD_MODE
+					if (alloc_fail_time >= 10) {
+						if (_FAIL == sdio_recv_and_drop(padapter, phal->SdioRxFIFOSize))
+							break;
+		
+						alloc_fail_time = 0;
+						phal->SdioRxFIFOSize = 0;
+						rx_cnt = 0;
+						RTW_INFO("%s RECV_THREAD_MODE drop pkt due to alloc_fail_time >= 10 \n",__func__);
+					} else {
+						rtw_msleep_os(1);
+						continue;
+					}
+#else /* !CONFIG_RECV_THREAD_MODE */
+				if (ret == RTW_RBUF_UNAVAIL || ret == RTW_RBUF_PKT_UNAVAIL)
+					rtw_msleep_os(10);
+				else {
+					RTW_INFO("%s: recv fail!(time=%d)\n", __func__, alloc_fail_time);
+					phal->SdioRxFIFOSize = 0;
+				}
+				if (alloc_fail_time >= 10 && rx_cnt != 0)
+					break;
+#endif /* !CONFIG_RECV_THREAD_MODE */
+			}
+			#endif
+		} else
+			break;
+	} while (1);
+
+	if (alloc_fail_time >= 10)
+		RTW_INFO("%s: exit because recv failed more than 10 times!, rx_cnt:%u\n", __func__, rx_cnt);
+}
 void sd_int_dpc(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE phal;
@@ -1542,74 +1663,72 @@ void sd_int_dpc(PADAPTER padapter)
 		RTW_INFO("%s: Rx Error\n", __func__);
 
 	if (phal->sdio_hisr & SDIO_HISR_RX_REQUEST) {
-		struct recv_buf *precvbuf;
-		int alloc_fail_time = 0;
-		u32 hisr = 0, rx_cnt = 0, ret = 0;
-
 		phal->sdio_hisr ^= SDIO_HISR_RX_REQUEST;
-		do {
-			phal->SdioRxFIFOSize = SdioLocalCmd52Read2Byte(padapter, SDIO_REG_RX0_REQ_LEN);
-			if (phal->SdioRxFIFOSize != 0) {
-#ifdef CONFIG_MAC_LOOPBACK_DRIVER
-				sd_recv_loopback(padapter, phal->SdioRxFIFOSize);
-#else
-				ret = sd_recv_rxfifo(padapter, phal->SdioRxFIFOSize, &precvbuf);
-				if (precvbuf) {
-					sd_rxhandler(padapter, precvbuf);
-					phal->SdioRxFIFOSize = 0;
-					rx_cnt++;
-				} else {
-					alloc_fail_time++;
-					if (ret == RTW_RBUF_UNAVAIL || ret == RTW_RBUF_PKT_UNAVAIL)
-						rtw_msleep_os(10);
-					else {
-						RTW_INFO("%s: recv fail!(time=%d)\n", __func__, alloc_fail_time);
-						phal->SdioRxFIFOSize = 0;
-					}
-					if (alloc_fail_time >= 10 && rx_cnt != 0)
-						break;
-				}
-#endif
-			} else
-				break;
-
-			hisr = 0;
-			ReadInterrupt8723DSdio(padapter, &hisr);
-			hisr &= SDIO_HISR_RX_REQUEST;
-			if (!hisr)
-				break;
-		} while (1);
-
-		if (alloc_fail_time == 10)
-			RTW_INFO("%s: exit because recv failed more than 10 times!\n", __func__);
+		sd_recv(padapter);
 	}
 }
-
+#ifndef DBG_SD_INT_HISR_HIMR
+#define DBG_SD_INT_HISR_HIMR 0
+#endif
 void sd_int_hdl(PADAPTER padapter)
 {
 	PHAL_DATA_TYPE phal;
-
+	#if !CMD52_ACCESS_HISR_RX_REQ_LEN
+	u8 data[6];
+	#endif
 
 	if (RTW_CANNOT_RUN(padapter))
 		return;
 
 	phal = GET_HAL_DATA(padapter);
 
+	#if SD_INT_HDL_DIS_HIMR_RX_REQ
+	disable_himr_rx_req_8723d_sdio(padapter);
+	#endif
+
+	#if CMD52_ACCESS_HISR_RX_REQ_LEN
 	phal->sdio_hisr = 0;
 	ReadInterrupt8723DSdio(padapter, &phal->sdio_hisr);
-
+	#else
+	_sdio_local_read(padapter, SDIO_REG_HISR, 6, data);
+	phal->sdio_hisr = le32_to_cpu(*(u32 *)data);
+	phal->SdioRxFIFOSize = le16_to_cpu(*(u16 *)&data[4]);
+	#endif
+	
 	if (phal->sdio_hisr & phal->sdio_himr) {
 		u32 v32;
-
+		#if DBG_SD_INT_HISR_HIMR
+		static u32 match_cnt = 0;
+
+		if ((match_cnt++) % 1000 == 0)
+			RTW_INFO("%s: HISR(0x%08x) and HIMR(0x%08x) match!\n"
+				, __func__, phal->sdio_hisr, phal->sdio_himr);
+		#endif
+		
 		phal->sdio_hisr &= phal->sdio_himr;
 
 		/* clear HISR */
 		v32 = phal->sdio_hisr & MASK_SDIO_HISR_CLEAR;
-		if (v32)
+		if (v32) {
+			#if CMD52_ACCESS_HISR_RX_REQ_LEN
 			SdioLocalCmd52Write4Byte(padapter, SDIO_REG_HISR, v32);
+			#else
+			v32 = cpu_to_le32(v32);
+			_sdio_local_write(padapter, SDIO_REG_HISR, 4, (u8 *)&v32);
+			#endif
+		}
 
 		sd_int_dpc(padapter);
 	}
+	#if DBG_SD_INT_HISR_HIMR
+	else
+		RTW_INFO("%s: HISR(0x%08x) and HIMR(0x%08x) not match!\n"
+			, __func__, phal->sdio_hisr, phal->sdio_himr);
+	#endif
+
+	#if SD_INT_HDL_DIS_HIMR_RX_REQ
+	restore_himr_8723d_sdio(padapter);
+	#endif	
 }
 
 /*
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyCfg.h
index 98f6f4f90af5..4b69372108a7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -162,7 +163,7 @@ PHY_SetRFEReg_8188E(
 /*
  * BB/MAC/RF other monitor API
  *   */
-VOID phy_set_rf_path_switch_8188e(IN	PADAPTER	pAdapter, IN	bool		bMain);
+VOID phy_set_rf_path_switch_8188e(IN	struct dm_struct	*phydm, IN	bool		bMain);
 
 extern	VOID
 PHY_SwitchEphyParameter(
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyReg.h
index 2eab8313aa5d..94972bf7200f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPwrSeq.h
index 46c61abacb92..4eab945a7a17 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188EPwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyCfg.h
index cca0b63a70b2..18e79f1c4e03 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -123,7 +124,7 @@ PHY_SetSwChnlBWMode8188F(
 );
 
 VOID phy_set_rf_path_switch_8188f(
-	IN	PADAPTER	pAdapter,
+	IN	struct		dm_struct *phydm,
 	IN	bool		bMain
 );
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyReg.h
index a831faade96d..f87c348bc333 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPwrSeq.h
index 5cad428fdd0b..56088ab60aac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8188FPwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyCfg.h
index b7822d5121f9..2273431218e4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
@@ -140,7 +141,7 @@ phy_SpurCalibration_8192E_NBI(
 
 VOID
 phy_set_rf_path_switch_8192e(
-	IN	PADAPTER	pAdapter,
+	IN	struct dm_struct		*phydm,
 	IN	bool		bMain
 );
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyReg.h
index 30b771111164..4cd2c35540ae 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPwrSeq.h
index 1f2ba8722572..c56e0ec00b12 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192EPwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPhyCfg.h
new file mode 100644
index 000000000000..d2f006f1a4cb
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPhyCfg.h
@@ -0,0 +1,132 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8192FPHYCFG_H__
+#define __INC_HAL8192FPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8192F(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8192F(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8192F(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8192F(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8192F(PADAPTER	Adapter	);
+
+int PHY_RFConfig8192F(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8192F(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8192F(
+	IN	PADAPTER			Adapter,
+	IN	u8				*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8192F(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8192F(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8192F(			
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8192F(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8192F(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+VOID phy_set_rf_path_switch_8192f(
+	IN	PADAPTER	pAdapter,
+	IN	bool		bMain
+);
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPhyReg.h
new file mode 100644
index 000000000000..952358a4b0e3
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPhyReg.h
@@ -0,0 +1,1135 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8192FPHYREG_H__
+#define __INC_HAL8192FPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other definition for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+#define	rBBrx_DFIR					0x954
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 imbalance 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_T_METER_88E				0x42
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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))
+#define		RF_TX_GAIN_OFFSET_8192F(_val) (abs((_val)) | (((_val) > 0) ? BIT(4) : 0))
+
+/* 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPwrSeq.h
new file mode 100644
index 000000000000..50408b558e5f
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8192FPwrSeq.h
@@ -0,0 +1,221 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8192F
+#define REALTEK_POWER_SEQUENCE_8192F
+#define POWER_SEQUENCE_8192F_VER 04
+/* #include "PwrSeqCmd.h" */
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20110607-Paul-RTL8192e_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 transition 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
+*/
+#define	RTL8192F_TRANS_CARDEMU_TO_ACT_STEPS	38
+#define	RTL8192F_TRANS_ACT_TO_CARDEMU_STEPS	8
+#define	RTL8192F_TRANS_CARDEMU_TO_SUS_STEPS	7
+#define	RTL8192F_TRANS_SUS_TO_CARDEMU_STEPS	5
+#define	RTL8192F_TRANS_CARDEMU_TO_CARDDIS_STEPS	8
+#define	RTL8192F_TRANS_CARDDIS_TO_CARDEMU_STEPS	8
+#define	RTL8192F_TRANS_CARDEMU_TO_PDN_STEPS	4
+#define	RTL8192F_TRANS_PDN_TO_CARDEMU_STEPS	1
+#define	RTL8192F_TRANS_ACT_TO_LPS_STEPS		13
+#define	RTL8192F_TRANS_LPS_TO_ACT_STEPS		11	
+#define	RTL8192F_TRANS_END_STEPS	1
+
+
+#define RTL8192F_TRANS_CARDEMU_TO_ACT 														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0}, /*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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/	\
+	{0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, 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, (BIT4|BIT3|BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/ \
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , BIT0},/* Disable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, BIT1},/* wait till 0x04[17] = 1    power ready*/	\
+	{0x0075, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0 , 0},/* Enable USB suspend */	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* release WLON reset  0x04[16]=1*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, (BIT1|BIT0), 0}, \
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2},/* SWR OCP enable 0x10[18]=1*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 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, (BIT4|BIT3), 0},/* disable WL suspend*/ \
+	{0x007f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x7c[31]=1,LDO has max output capability*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* polling until return 0*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/ \
+	{0x0010, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/* Enable WL control XTAL setting*/ \
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1},/*Enable falling edge triggering interrupt*/\
+	{0x0063, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 data mode*/\
+	{0x0062, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable GPIO9 input mode*/\
+	{0x0058, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/*Enable HSISR GPIO[C:0] interrupt*/\
+	{0x0068, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3, 0},/*RF HW ON/OFF Enable*/\
+	{0x001C, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/*Register Lock Disable*/\
+	{0x0069, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT6, BIT6},/*For GPIO9 internal pull high setting*/\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*reset RF path S1*/\
+	{0x007B, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*reset RF path S0*/\
+	{0x001f, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x07},/*enable RF path S1*/\
+	{0x007B, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x07},/*enalbe RF path S0*/\
+	{0x0097, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*AFE_Ctrl*/\
+	{0x00DC, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xCC},/*AFE_Ctrl*/\
+	{0x0024, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0x18, 0x00},/*AFE_Ctrl 0x24[4:3]=00 for xtal gmn*/\
+	{0x1050, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*GPIO_A[7:0] Pull down software register*/\
+	{0x1051, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*GPIO_A[15:8] Pull down software register*/\
+	{0x1052, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*GPIO_A[23:16] Pull down software register*/\
+	{0x1053, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*GPIO_A[31:24] Pull down software register*/\
+	{0x105B, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*GPIO_B[7:0] Pull down software register*/\
+	{0x001C, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/*Register Lock Enable*/\
+	{0x0077, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, (BIT7|BIT6), 0x3},/*set HCI Power sequence state delay time:0*/
+
+	
+#define RTL8192F_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	/*{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*/	\
+	{0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*0x2[0]=0 Reset BB,RF enter Power Down mode*/ \
+	{0x0049, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, 0},/*Enable rising edge triggering interrupt*/ \
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, BIT0},/* release WLON reset  0x04[16]=1*/ \
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, 0}, /*0x10[18] = 0 to disable ocp*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*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, BIT1, 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_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5}, /*0x00[5] = 1b'1 analog Ips to digital ,1:isolation*/   \
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/\
+
+
+#define RTL8192F_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, (BIT4|BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 USB|SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8192F_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+	
+
+#define RTL8192F_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07=0x20 , SOP option to disable BG/MB*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT2, BIT2}, /*0x04[10] = 1, enable SW LPS*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend*/	\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/   \
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8192F_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0}, /*0x48[16] = 0 to disable GPIO9 as EXT WAKEUP*/	\
+	{0x0012, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT2, BIT2}, /*0x10[18] = 1 to enable ocp*/	\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0},/*PCIe DMA start*/
+
+
+#define RTL8192F_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8192F_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8192F_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/ \
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	\
+
+
+#define RTL8192F_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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 RTL8192F_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
+
+
+extern WLAN_PWR_CFG rtl8192F_power_on_flow[RTL8192F_TRANS_CARDEMU_TO_ACT_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_radio_off_flow[RTL8192F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_card_disable_flow[RTL8192F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192F_TRANS_CARDEMU_TO_CARDDIS_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_card_enable_flow[RTL8192F_TRANS_CARDDIS_TO_CARDEMU_STEPS+RTL8192F_TRANS_CARDEMU_TO_ACT_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_suspend_flow[RTL8192F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192F_TRANS_CARDEMU_TO_SUS_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_resume_flow[RTL8192F_TRANS_SUS_TO_CARDEMU_STEPS+RTL8192F_TRANS_CARDEMU_TO_ACT_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_hwpdn_flow[RTL8192F_TRANS_ACT_TO_CARDEMU_STEPS+RTL8192F_TRANS_CARDEMU_TO_PDN_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_enter_lps_flow[RTL8192F_TRANS_ACT_TO_LPS_STEPS+RTL8192F_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8192F_leave_lps_flow[RTL8192F_TRANS_LPS_TO_ACT_STEPS+RTL8192F_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyCfg.h
index 7ef2a8cd88ea..96585e66a9f4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -123,7 +124,7 @@ PHY_SetSwChnlBWMode8703B(
 );
 
 VOID phy_set_rf_path_switch_8703b(
-	IN	PADAPTER	pAdapter,
+	IN	struct dm_struct		*phydm,
 	IN	bool		bMain
 );
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyReg.h
index 881a13cfac87..75e154a48a03 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPwrSeq.h
index 0dac13ee34a9..a94e9e67c4a8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8703BPwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPhyCfg.h
new file mode 100644
index 000000000000..c2b6df129ef9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPhyCfg.h
@@ -0,0 +1,128 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8710BPHYCFG_H__
+#define __INC_HAL8710BPHYCFG_H__
+
+/*--------------------------Define Parameters-------------------------------*/
+#define LOOP_LIMIT				5
+#define MAX_STALL_TIME			50		/* us */
+#define AntennaDiversityValue	0x80	/* (Adapter->bSoftwareAntennaDiversity ? 0x00 : 0x80) */
+#define MAX_TXPWR_IDX_NMODE_92S	63
+#define Reset_Cnt_Limit			3
+
+#ifdef CONFIG_PCI_HCI
+	#define MAX_AGGR_NUM	0x0B
+#else
+	#define MAX_AGGR_NUM	0x07
+#endif /* CONFIG_PCI_HCI */
+
+
+/*--------------------------Define Parameters End-------------------------------*/
+
+
+/*------------------------------Define structure----------------------------*/
+
+/*------------------------------Define structure End----------------------------*/
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_QueryBBReg_8710B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask
+);
+
+VOID
+PHY_SetBBReg_8710B(
+	IN	PADAPTER	Adapter,
+	IN	u32		RegAddr,
+	IN	u32		BitMask,
+	IN	u32		Data
+);
+
+u32
+PHY_QueryRFReg_8710B(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask
+);
+
+VOID
+PHY_SetRFReg_8710B(
+	IN	PADAPTER		Adapter,
+	IN	enum rf_path		eRFPath,
+	IN	u32				RegAddr,
+	IN	u32				BitMask,
+	IN	u32				Data
+);
+
+/* MAC/BB/RF HAL config */
+int PHY_BBConfig8710B(PADAPTER	Adapter);
+
+int PHY_RFConfig8710B(PADAPTER	Adapter);
+
+s32 PHY_MACConfig8710B(PADAPTER padapter);
+
+int
+PHY_ConfigRFWithParaFile_8710B(
+	IN	PADAPTER			Adapter,
+	IN	u8				*pFileName,
+	enum rf_path				eRFPath
+);
+
+VOID
+PHY_SetTxPowerIndex_8710B(
+	IN	PADAPTER			Adapter,
+	IN	u32					PowerIndex,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate
+);
+
+u8
+PHY_GetTxPowerIndex_8710B(
+	IN	PADAPTER			pAdapter,
+	IN	enum rf_path			RFPath,
+	IN	u8					Rate,
+	IN	u8					BandWidth,
+	IN	u8					Channel,
+	struct txpwr_idx_comp *tic
+);
+
+VOID
+PHY_GetTxPowerLevel8710B(
+	IN	PADAPTER		Adapter,
+	OUT s32				*powerlevel
+);
+
+VOID
+PHY_SetTxPowerLevel8710B(
+	IN	PADAPTER		Adapter,
+	IN	u8			channel
+);
+
+VOID
+PHY_SetSwChnlBWMode8710B(
+	IN	PADAPTER			Adapter,
+	IN	u8					channel,
+	IN	enum channel_width	Bandwidth,
+	IN	u8					Offset40,
+	IN	u8					Offset80
+);
+
+/*--------------------------Exported Function prototype End---------------------*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPhyReg.h
new file mode 100644
index 000000000000..310c97ed8660
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPhyReg.h
@@ -0,0 +1,1135 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_HAL8710BPHYREG_H__
+#define __INC_HAL8710BPHYREG_H__
+
+#define		rSYM_WLBT_PAPE_SEL		0x64
+/*
+ * BB-PHY register PMAC 0x100 PHY 0x800 - 0xEFF
+ * 1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF
+ * 2. 0x800/0x900/0xA00/0xC00/0xD00/0xE00
+ * 3. RF register 0x00-2E
+ * 4. Bit Mask for BB/RF register
+ * 5. Other definition for BB/RF R/W
+ *   */
+
+
+/*
+ * 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?? */
+#define	rDPDT_control				0x92c
+#define	rfe_ctrl_anta_src				0x930
+#define	rS0S1_PathSwitch			0x948
+#define	rBBrx_DFIR					0x954
+
+/*
+ * 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 rPdp_AntA_8						0xb08
+#define rPdp_AntA_C						0xb0c
+#define rPdp_AntA_10					0xb10
+#define rPdp_AntA_14					0xb14
+#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
+/*
+ * 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 imbalance 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 */
+
+/* #endif */
+#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 */
+#define	RF_TX_BIAS_A				0x35
+#define	RF_TX_BIAS_D				0x36
+#define	RF_LOBF_9					0x38
+#define	RF_RXRF_A3					0x3C	/*	 */
+#define	RF_TRSW					0x3F
+
+#define	RF_TXRF_A2					0x41
+#define	RF_T_METER_88E				0x42
+#define	RF_TXPA_G4					0x46
+#define	RF_TXPA_A4					0x4B
+#define	RF_0x52					0x52
+#define	RF_WE_LUT					0xEF
+#define	RF_S0S1					0xB0
+
+/*
+ * 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))
+#define		RF_TX_GAIN_OFFSET_8710B(_val) (abs((_val)) | (((_val) > 0) ? BIT(4) : 0))
+
+/* 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		bMaskH3Bytes		0xffffff00
+#define		bMask12Bits			0xfff
+#define		bMaskH4Bits			0xf0000000
+#define		bMaskOFDM_D		0xffc00000
+#define		bMaskCCK			0x3f3f3f3f
+
+
+#define		bEnable			0x1	/* Useless */
+#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
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPwrSeq.h
new file mode 100644
index 000000000000..8a88d07eafc1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8710BPwrSeq.h
@@ -0,0 +1,168 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2017 Realtek Corporation.
+ *
+ * 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 REALTEK_POWER_SEQUENCE_8710B
+#define REALTEK_POWER_SEQUENCE_8710B
+
+/* #include "PwrSeqCmd.h" */
+#include "HalPwrSeqCmd.h"
+
+/*
+	Check document WM-20110607-Paul-RTL8192e_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 transition 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
+*/
+#define RTL8710B_TRANS_CARDEMU_TO_ACT_STEPS 5
+#define RTL8710B_TRANS_ACT_TO_CARDEMU_STEPS 4
+#define RTL8710B_TRANS_CARDEMU_TO_SUS_STEPS 7
+#define RTL8710B_TRANS_SUS_TO_CARDEMU_STEPS 15
+#define RTL8710B_TRANS_CARDEMU_TO_PDN_STEPS 15
+#define RTL8710B_TRANS_PDN_TO_CARDEMU_STEPS 15
+#define RTL8710B_TRANS_ACT_TO_LPS_STEPS 	15
+#define RTL8710B_TRANS_LPS_TO_ACT_STEPS 	15	
+#define RTL8710B_TRANS_ACT_TO_SWLPS_STEPS		22
+#define RTL8710B_TRANS_SWLPS_TO_ACT_STEPS		15
+#define RTL8710B_TRANS_END_STEPS		1
+
+
+#define RTL8710B_TRANS_CARDEMU_TO_ACT 														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x005D, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 0},/*AFE power mode selection:1:  LDO mode ,0:  Power-cut mode*/\
+	{0x0004, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1},\
+	{0x0056, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x0E},\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT0, 1},\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT0, 0},/**/ 
+
+	
+#define RTL8710B_TRANS_ACT_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	/*{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*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, (BIT0|BIT1|BIT2), 0},/*0x04[24:26] = 0 turn off RF*/	\
+	{0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, (BIT0|BIT1), 0},/*0x04[16:17] = 0 BB reset*/	\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT1, BIT1}, /*0x20[1] = 1 turn off MAC by HW state machine*/	\
+	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_POLLING, BIT1, 0}, /*wait till 0x20[1] = 0 polling until return 0 to disable*/ \
+
+
+#define RTL8710B_TRANS_CARDEMU_TO_SUS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4|BIT3, (BIT4|BIT3)}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/ \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK|PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3}, /*0x04[12:11] = 2b'01 enable WL suspend*/	\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SDIO SOP option to disable BG/MB/ACK/SWR*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, BIT3|BIT4}, /*0x04[12:11] = 2b'11 enable WL suspend for PCIe*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, BIT0}, /*Set SDIO suspend local register*/	\
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, 0}, /*wait power state to suspend*/
+
+#define RTL8710B_TRANS_SUS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3 | BIT7, 0}, /*clear suspend enable and power down enable*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, BIT0, 0}, /*Set SDIO suspend local register*/ \
+	{0x0086, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_POLLING, BIT1, BIT1}, /*wait power state to suspend*/\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, 0}, /*0x23[4] = 1b'0 12H LDO enter normal mode*/   \
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT3|BIT4, 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
+	
+
+#define RTL8710B_TRANS_CARDEMU_TO_CARDDIS													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/	\
+
+#define RTL8710B_TRANS_CARDDIS_TO_CARDEMU													\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+
+
+#define RTL8710B_TRANS_CARDEMU_TO_PDN												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0023, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT4, BIT4}, /*0x23[4] = 1b'1 12H LDO enter sleep mode*/	\
+	{0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_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, BIT0, 0},/* 0x04[16] = 0*/\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, BIT7},/* 0x04[15] = 1*/
+
+#define RTL8710B_TRANS_PDN_TO_CARDEMU												\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT7, 0},/* 0x04[15] = 0*/
+
+#define RTL8710B_TRANS_ACT_TO_LPS														\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0301, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0xFF},/*PCIe DMA stop*/	\
+	{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, BIT0, 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, BIT1, 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, BIT1, 0},/*check if removed later*/ \
+	{0x0093, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x00},/*When driver enter Sus/ Disable, enable LOP for BT*/	\
+	{0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, BIT5, BIT5},/*Respond TxOK to scheduler*/	
+
+
+#define RTL8710B_TRANS_LPS_TO_ACT															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0x0080, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_SDIO_MSK,PWR_BASEADDR_SDIO,PWR_CMD_WRITE, 0xFF, 0x84}, /*SDIO RPWM*/\
+	{0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
+	{0x0361, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK,PWR_BASEADDR_MAC,PWR_CMD_WRITE, 0xFF, 0x84}, /*PCIe 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, BIT4, 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, BIT7, 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, BIT6|BIT7, 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, BIT1, BIT1}, /*.	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, BIT1|BIT0, BIT1|BIT0}, /*.	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 RTL8710B_TRANS_END															\
+	/* format */																\
+	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, // comments here*/								\
+	{0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK,0,PWR_CMD_END, 0, 0}, //
+
+
+extern WLAN_PWR_CFG rtl8710B_power_on_flow[RTL8710B_TRANS_CARDEMU_TO_ACT_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_radio_off_flow[RTL8710B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_card_disable_flow[RTL8710B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8710B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_card_enable_flow[RTL8710B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8710B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_suspend_flow[RTL8710B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8710B_TRANS_CARDEMU_TO_SUS_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_resume_flow[RTL8710B_TRANS_SUS_TO_CARDEMU_STEPS+RTL8710B_TRANS_CARDEMU_TO_ACT_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_hwpdn_flow[RTL8710B_TRANS_ACT_TO_CARDEMU_STEPS+RTL8710B_TRANS_CARDEMU_TO_PDN_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_enter_lps_flow[RTL8710B_TRANS_ACT_TO_LPS_STEPS+RTL8710B_TRANS_END_STEPS];
+extern WLAN_PWR_CFG rtl8710B_leave_lps_flow[RTL8710B_TRANS_LPS_TO_ACT_STEPS+RTL8710B_TRANS_END_STEPS];
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyCfg.h
index 594cf3fa20f1..2a3e4c50418e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -123,7 +124,7 @@ PHY_SetSwChnlBWMode8723B(
 );
 
 VOID phy_set_rf_path_switch_8723b(
-	IN	PADAPTER	pAdapter,
+	IN	struct dm_struct		*phydm,
 	IN	bool		bMain
 );
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyReg.h
index ce485c2ab4be..a816352009e2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPwrSeq.h
index 1aec885cbb1d..26a6cf8744e9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723BPwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyCfg.h
index e447407270f5..da572858d125 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -123,7 +124,7 @@ PHY_SetSwChnlBWMode8723D(
 );
 
 VOID phy_set_rf_path_switch_8723d(
-	IN	PADAPTER	pAdapter,
+	IN	struct dm_struct		*phydm,
 	IN	bool		bMain
 );
 /*--------------------------Exported Function prototype End---------------------*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyReg.h
index 036144a388bb..f8b190dc790b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPwrSeq.h
index 70afbdbf4ace..021c414c5a94 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723DPwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -56,7 +57,6 @@
 	/* format */																\
 	/* { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value }, / comments here*/								\
 	{0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK | PWR_INTF_SDIO_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_INTF_SDIO_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_INTF_SDIO_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_INTF_SDIO_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(4) | BIT(3) | BIT2), 0},/* disable SW LPS 0x04[10]=0 and WLSUS_EN 0x04[11]=0*/ \
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723PwrSeq.h
index 22de83375e66..22d600607d9b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723PwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8723PwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyCfg.h
index bdd1e3443810..7a6403f459f1 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -135,7 +136,7 @@ PHY_SetSwChnlBWMode8812(
 
 VOID
 phy_set_rf_path_switch_8812a(
-	IN	PADAPTER	pAdapter,
+	IN	struct dm_struct		*phydm,
 	IN	bool		bMain
 );
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyReg.h
index ef4abb299b6e..e53bde42c283 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -163,6 +164,8 @@
 #define rB_RFE_Inv_Jaguar		0xeb4 /* Path_B RFE control */
 #define rA_RFE_Jaguar			0xcb8  /* Path_A RFE cotrol   */
 #define rB_RFE_Jaguar			0xeb8 /* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
 #define r_ANTSEL_SW_Jaguar		0x900 /* ANTSEL SW Control */
 #define bMask_RFEInv_Jaguar		0x3ff00000
 #define bMask_AntselPathFollow_Jaguar 0x00030000
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PwrSeq.h
index 498faf8114ae..28758abc8690 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8812PwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyCfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyCfg.h
index ffa67ee9f16c..2d9a00794f61 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyCfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyCfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -167,12 +168,12 @@ PHY_GetTxBBSwing_8814A(
 
 
 /* 1 6. Channel setting API */
-
+#if 0
 VOID
 PHY_SwChnlTimerCallback8814A(
 	IN	struct timer_list		*p_timer
 );
-
+#endif
 VOID
 PHY_SwChnlWorkItemCallback8814A(
 	IN PVOID            pContext
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyReg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyReg.h
index 2fa46dd165f9..97b6d8998c20 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyReg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PhyReg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -197,6 +198,8 @@
 #define rB_RFE_Inv_Jaguar		0xeb4 /* Path_B RFE control */
 #define rA_RFE_Jaguar			0xcb8  /* Path_A RFE cotrol   */
 #define rB_RFE_Jaguar			0xeb8 /* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
 #define r_ANTSEL_SW_Jaguar		0x900 /* ANTSEL SW Control */
 #define bMask_RFEInv_Jaguar		0x3ff00000
 #define bMask_AntselPathFollow_Jaguar 0x00030000
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PwrSeq.h
index 5f4097d0f739..e39ac1b4aec7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8814PwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8821APwrSeq.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8821APwrSeq.h
index 568b8e5fc1e9..ffbae537c2dd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8821APwrSeq.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/Hal8821APwrSeq.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalPwrSeqCmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalPwrSeqCmd.h
index f67ed22d1fc9..1f9a175e305e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalPwrSeqCmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalPwrSeqCmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalVerDef.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalVerDef.h
index 1909da7a0094..983d8ebed417 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalVerDef.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/HalVerDef.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -35,7 +36,10 @@ typedef enum tag_HAL_IC_Type_Definition {
 	CHIP_8188F	=	12,
 	CHIP_8822B	=	13,
 	CHIP_8723D	=	14,
-	CHIP_8821C	=	15
+	CHIP_8821C	=	15,
+	CHIP_8710B	=	16,
+	CHIP_8192F	=	17,
+	CHIP_8188GTV =	18,
 } HAL_IC_TYPE_E;
 
 /* HAL_CHIP_TYPE_E */
@@ -112,6 +116,7 @@ typedef	struct tag_HAL_VERSION {
 
 #define IS_8188E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188E) ? TRUE : FALSE)
 #define IS_8188F(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188F) ? TRUE : FALSE)
+#define IS_8188GTV(version)					((GET_CVID_IC_TYPE(version) == CHIP_8188GTV) ? TRUE : FALSE)
 #define IS_8192E(version)					((GET_CVID_IC_TYPE(version) == CHIP_8192E) ? TRUE : FALSE)
 #define IS_8812_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8812) ? TRUE : FALSE)
 #define IS_8821_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8821) ? TRUE : FALSE)
@@ -120,8 +125,11 @@ typedef	struct tag_HAL_VERSION {
 #define IS_8703B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8703B) ? TRUE : FALSE)
 #define IS_8822B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8822B) ? TRUE : FALSE)
 #define IS_8821C_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8821C) ? TRUE : FALSE)
-#define IS_8723D_SERIES(version)\
-	((GET_CVID_IC_TYPE(version) == CHIP_8723D) ? TRUE : FALSE)
+#define IS_8723D_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8723D) ? TRUE : FALSE)
+#define IS_8710B_SERIES(version)			((GET_CVID_IC_TYPE(version) == CHIP_8710B) ? TRUE : FALSE)
+
+#define IS_8192F_SERIES(version)\
+	((GET_CVID_IC_TYPE(version) == CHIP_8192F) ? TRUE : FALSE)
 /* HAL_CHIP_TYPE_E */
 #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)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/autoconf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/autoconf.h
index 27f3147c2ae6..02698f805218 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/autoconf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/autoconf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -72,7 +73,7 @@
 	#define CONFIG_P2P_PS
 	#define CONFIG_P2P_OP_CHK_SOCIAL_CH
 	#define CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT  /* replace CONFIG_P2P_CHK_INVITE_CH_LIST flag */
-	#define CONFIG_P2P_INVITE_IOT
+	/*#define CONFIG_P2P_INVITE_IOT*/
 #endif
 
 /* Added by Kurt 20110511 */
@@ -98,14 +99,11 @@
 #define CONFIG_LAYER2_ROAMING
 #define CONFIG_LAYER2_ROAMING_RESUME
 
-/* #define CONFIG_80211D */
-
-
 /*
  * Hareware/Firmware Related Config
  */
 /* #define CONFIG_BT_COEXIST */	/* Set from Makefile */
-/* #define CONFIG_ANTENNA_DIVERSITY */	/* Set from Makefile */
+/* #define CONFIG_ANTENNA_DIVERSITY */
 /* #define SUPPORT_HW_RFOFF_DETECTED */
 
 /*#define CONFIG_RTW_LED*/
@@ -133,6 +131,9 @@
 #define CONFIG_XMIT_THREAD_MODE
 /* #define CONFIG_SDIO_TX_ENABLE_AVAL_INT */
 /* #define CONFIG_RECV_THREAD_MODE */
+#ifdef CONFIG_RECV_THREAD_MODE
+#define RTW_RECV_THREAD_HIGH_PRIORITY
+#endif/*CONFIG_RECV_THREAD_MODE*/
 
 /*
  * Others
@@ -154,7 +155,6 @@
 
 #define CONFIG_LONG_DELAY_ISSUE
 /* #define CONFIG_PATCH_JOIN_WRONG_CHANNEL */
-#define CONFIG_ATTEMPT_TO_FIX_AP_BEACON_ERROR
 
 
 /*
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/basic_types.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/basic_types.h
index c0737f5bf235..ebab784baf3b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/basic_types.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/basic_types.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/big_endian.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/big_endian.h
index 6b1dc449e578..76542f0c4867 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/big_endian.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/big_endian.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/generic.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/generic.h
index f85114bf796c..32d424a1d7a8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/generic.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/generic.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/little_endian.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/little_endian.h
index c4b64512f296..1f9287f205ad 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/little_endian.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/little_endian.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swab.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swab.h
index a8dd46bd3a60..8c3eb866c0be 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swab.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swab.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swabb.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swabb.h
index 634519a0b826..2e6b196051f9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swabb.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/byteorder/swabb.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/circ_buf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/circ_buf.h
index 7a5b8ef1a202..cccb0602e27d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/circ_buf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/circ_buf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmd_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmd_osdep.h
index e4ba2b6d3b62..c98ba148679e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmd_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmd_osdep.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmn_info/rtw_sta_info.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmn_info/rtw_sta_info.h
index 4ad7b6c08774..2b9f91c8ce18 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmn_info/rtw_sta_info.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/cmn_info/rtw_sta_info.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
@@ -85,7 +86,7 @@ enum rf_type {
 	RF_3T3R			= 5,
 	RF_3T4R			= 6,
 	RF_4T4R			= 7,
-	RF_TYPE_MAX = 0x0F,
+	RF_TYPE_MAX,
 };
 
 enum bb_path {
@@ -106,7 +107,7 @@ enum bb_path {
 	BB_PATH_ACD = (BB_PATH_A | BB_PATH_C | BB_PATH_D),
 	BB_PATH_BCD = (BB_PATH_B | BB_PATH_C | BB_PATH_D),
 
-	BB_PATH_ABCD = (BB_PATH_A | BB_PATH_B | BB_PATH_D | BB_PATH_D),
+	BB_PATH_ABCD = (BB_PATH_A | BB_PATH_B | BB_PATH_C | BB_PATH_D),
 };
 
 enum rf_path {
@@ -121,11 +122,17 @@ enum rf_path {
 	RF_PATH_BD,
 	RF_PATH_CD,
 	RF_PATH_ABC,
+	RF_PATH_ABD,
 	RF_PATH_ACD,
 	RF_PATH_BCD,
 	RF_PATH_ABCD,
 };
 
+enum rf_syn {
+	RF_SYN0 = 0,
+	RF_SYN1 = 1,
+};
+
 enum wireless_set {
 	WIRELESS_CCK	= 0x00000001,
 	WIRELESS_OFDM	= 0x00000002,
@@ -155,47 +162,54 @@ struct rssi_info {
 	u16		cck_sum_power;
 	u8		is_send_rssi;
 	u8		valid_bit;
+	s16		rssi_acc;	/*accumulate RSSI for per packet MA sum*/
 };
 
 struct ra_sta_info {
-	u8	rate_id;			/*ratr_idx*/
-	u8	rssi_level;
-
-	/*New*/
-	u8	is_first_connect:1;	/*CE: ra_rpt_linked, AP: H2C_rssi_rpt*/
-	u8	is_support_sgi:1;	/*driver*/
-	u8	is_vht_enable:2;		/*driver*/
-	u8	disable_ra:1;		/*driver*/
-	u8	disable_pt:1;		/*driver*/  /*remove is_disable_power_training*/
-	u8	txrx_state:2;		/*0: Tx, 1:Rx, 2:bi-direction*/
-	u8	is_noisy:1;
-	
-	u8 curr_tx_rate;					/*FW->Driver*/
-	enum channel_width	ra_bw_mode;	/*max bandwidth, for RA only*/
-	enum channel_width	curr_tx_bw;    /*FW->Driver*/
-	u8 curr_retry_ratio;				/*FW->Driver*/
-
+	u8	rate_id;			/*[PHYDM] ratr_idx*/
+	u8	rssi_level;			/*[PHYDM]*/
+	u8	is_first_connect:1;		/*[PHYDM] CE: ra_rpt_linked, AP: H2C_rssi_rpt*/
+	u8	is_support_sgi:1;		/*[driver]*/
+	u8	is_vht_enable:2;		/*[driver]*/
+	u8	disable_ra:1;			/*[driver]*/
+	u8	disable_pt:1;			/*[driver] remove is_disable_power_training*/
+	u8	txrx_state:2;			/*[PHYDM] 0: Tx, 1:Rx, 2:bi-direction*/
+	u8	is_noisy:1;			/*[PHYDM]*/
+	u8	curr_tx_rate;			/*[PHYDM] FW->Driver*/
+	enum channel_width	ra_bw_mode;	/*[Driver] max bandwidth, for RA only*/
+	enum channel_width	curr_tx_bw;	/*[PHYDM] FW->Driver*/
+	u8	curr_retry_ratio;		/*[PHYDM] FW->Driver*/
 	u64	ramask;
 };
 
+struct dtp_info {
+	u8	dyn_tx_power;	/*Dynamic Tx power offset*/
+	u8	last_tx_power;
+	u8	sta_tx_high_power_lvl:4;
+	u8	sta_last_dtp_lvl:4;
+};
+
 struct cmn_sta_info {
-	u16	dm_ctrl;
-	enum channel_width	bw_mode;	/*max bandwidth*/
-	u8	mac_id;
-	u8	mac_addr[6];
-	u16	aid;
-	enum rf_type mimo_type;		/*sta XTXR*/
-	struct rssi_info	rssi_stat;
-	struct ra_sta_info	ra_info;
-	u16	tx_moving_average_tp;	/*tx average MBps*/
-	u16	rx_moving_average_tp;	/*rx average MBps*/
-	u8	stbc_en:2;		/*Driver : really use stbc!!*/
-	u8	ldpc_en:2;
-	enum wireless_set	support_wireless_set;
+	u16	dm_ctrl;			/*[Driver]*/			
+	enum channel_width	bw_mode;	/*[Driver] max support BW*/
+	u8	mac_id;				/*[Driver]*/
+	u8	mac_addr[6];			/*[Driver]*/
+	u16	aid;				/*[Driver]*/
+	enum rf_type mimo_type;			/*[Driver] sta XTXR*/
+	struct rssi_info	rssi_stat;	/*[PHYDM]*/
+	struct ra_sta_info	ra_info;	/*[Driver&PHYDM]*/
+	u16	tx_moving_average_tp;		/*[Driver] tx average MBps*/
+	u16	rx_moving_average_tp;		/*[Driver] rx average MBps*/
+	u8	stbc_en:2;			/*[Driver] really transmitt STBC*/
+	u8	ldpc_en:2;			/*[Driver] really transmitt LDPC*/
+	enum wireless_set	support_wireless_set;/*[Driver]*/
 #ifdef CONFIG_BEAMFORMING
-	struct bf_cmn_info	bf_info;
+	struct bf_cmn_info	bf_info;	/*[Driver]*/
 #endif
-	u8	sm_ps:2;
+	u8	sm_ps:2;			/*[Driver]*/
+	struct dtp_info dtp_stat;		/*[PHYDM] Dynamic Tx power offset*/
+	/*u8		pw2cca_over_TH_cnt;*/
+	/*u8		total_pw2cca_cnt;*/
 };
 
 struct phydm_phyinfo_struct {
@@ -212,6 +226,7 @@ struct phydm_phyinfo_struct {
 	u8		signal_strength;				/* in 0-100 index. */
 	s8		rx_pwr[4];					/* per-path's pwdb */
 	s8		rx_snr[4];					/* per-path's SNR	*/
+	u8		ant_idx[4];	/*per-path's antenna index*/
 /*ODM_PHY_STATUS_NEW_TYPE_SUPPORT*/
 	u8		rx_count:2;					/* RX path counter---*/
 	u8		band_width:2;
@@ -219,12 +234,16 @@ struct phydm_phyinfo_struct {
 	u8		channel;						/* channel number---*/
 	u8		is_mu_packet:1;				/* is MU packet or not---boolean*/
 	u8		is_beamformed:1;				/* BF packet---boolean*/
+	u8		cnt_pw2cca;
+	u8		cnt_cca2agc_rdy;
 /*ODM_PHY_STATUS_NEW_TYPE_SUPPORT*/
 };
 
 struct phydm_perpkt_info_struct {
 	u8		data_rate;
 	u8		station_id;
+	u8		is_cck_rate: 1;
+	u8		rate_ss:3;			/*spatial stream of data rate*/
 	u8		is_packet_match_bssid:1;	/*boolean*/
 	u8		is_packet_to_self:1;		/*boolean*/
 	u8		is_packet_beacon:1;		/*boolean*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/custom_gpio.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/custom_gpio.h
index 49411b662efb..0c2597da7b33 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/custom_gpio.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/custom_gpio.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_conf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_conf.h
index dab2936bfd7b..4816a694490b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_conf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_conf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -16,13 +17,12 @@
 #define __DRV_CONF_H__
 #include "autoconf.h"
 #include "hal_ic_cfg.h"
-
 #if defined(PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
 
 	#error "Shall be Linux or Windows, but not both!\n"
 
 #endif
-
+#define CONFIG_RSSI_PRIORITY
 #ifdef CONFIG_RTW_REPEATER_SON
 	#ifndef CONFIG_AP
 		#define CONFIG_AP
@@ -115,9 +115,71 @@
 	#define CONFIG_USB_VENDOR_REQ_MUTEX
 #endif
 
+#if defined(CONFIG_DFS_SLAVE_WITH_RADAR_DETECT) && !defined(CONFIG_DFS_MASTER)
+	#define CONFIG_DFS_MASTER
+#endif
+
 #if !defined(CONFIG_AP_MODE) && defined(CONFIG_DFS_MASTER)
-	#warning "undef CONFIG_DFS_MASTER because CONFIG_AP_MODE is not defined"
-	#undef CONFIG_DFS_MASTER
+	#error "enable CONFIG_DFS_MASTER without CONFIG_AP_MODE"
+#endif
+
+#ifdef CONFIG_WIFI_MONITOR
+	/*	#define CONFIG_MONITOR_MODE_XMIT	*/
+#endif
+
+#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
+	#ifndef CONFIG_WIFI_MONITOR
+		#define CONFIG_WIFI_MONITOR
+	#endif
+	#ifndef CONFIG_MONITOR_MODE_XMIT
+		#define CONFIG_MONITOR_MODE_XMIT
+	#endif
+	#ifdef CONFIG_POWER_SAVING
+		#undef CONFIG_POWER_SAVING
+	#endif
+#endif
+
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
+	#ifdef CONFIG_POWER_SAVING
+		#undef CONFIG_POWER_SAVING
+	#endif
+	#ifdef CONFIG_BEAMFORMING
+		#undef CONFIG_BEAMFORMING
+	#endif
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	#ifndef CONFIG_RTW_MESH_ACNODE_PREVENT
+	#define CONFIG_RTW_MESH_ACNODE_PREVENT 1
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_OFFCH_CAND
+	#define CONFIG_RTW_MESH_OFFCH_CAND 1
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_PEER_BLACKLIST
+	#define CONFIG_RTW_MESH_PEER_BLACKLIST 1
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	#define CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST 1
+	#endif
+	#ifndef CONFIG_RTW_MESH_CTO_MGATE_CARRIER
+	#define CONFIG_RTW_MESH_CTO_MGATE_CARRIER CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	#endif
+
+	#ifndef CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+	#define CONFIG_RTW_MPM_TX_IES_SYNC_BSS 1
+	#endif
+	#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
+		#ifndef CONFIG_RTW_MESH_AEK
+		#define CONFIG_RTW_MESH_AEK
+		#endif
+	#endif
+
+	#ifndef CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	#define CONFIG_RTW_MESH_DATA_BMC_TO_UC 1
+	#endif
 #endif
 
 #if !defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_AP_MODE)
@@ -140,14 +202,6 @@
 	#define CONFIG_RTW_ADAPTIVITY_MODE 0
 #endif
 
-#ifndef CONFIG_RTW_ADAPTIVITY_DML
-	#define CONFIG_RTW_ADAPTIVITY_DML 0
-#endif
-
-#ifndef CONFIG_RTW_ADAPTIVITY_DC_BACKOFF
-	#define CONFIG_RTW_ADAPTIVITY_DC_BACKOFF 2
-#endif
-
 #ifndef CONFIG_RTW_ADAPTIVITY_TH_L2H_INI
 	#define CONFIG_RTW_ADAPTIVITY_TH_L2H_INI 0
 #endif
@@ -210,8 +264,11 @@
 	#define CONFIG_RTW_CUSTOMIZE_BEEDCA		0x0000431C
 	#define CONFIG_RTW_CUSTOMIZE_BWMODE		0x00
 	#define CONFIG_RTW_CUSTOMIZE_RLSTA		0x7
+#if defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8192F) || defined(CONFIG_RTL8822B)
+	#define CONFIG_RTW_TX_2PATH_EN		/*	mutually incompatible with STBC_TX & Beamformer	*/
 #endif
-
+#endif
+/*#define CONFIG_EXTEND_LOWRATE_TXOP			*/
 
 #ifndef CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS
 	#define CONFIG_RTW_RX_AMPDU_SZ_LIMIT_1SS {0xFF, 0xFF, 0xFF, 0xFF}
@@ -293,11 +350,33 @@
 #endif
 
 #if (CONFIG_IFACE_NUMBER == 0)
-	#error "CONFIG_IFACE_NUMBER cound not equel to 0 !!"
+	#error "CONFIG_IFACE_NUMBER cound not be 0 !!"
 #endif
 
-#if (CONFIG_IFACE_NUMBER > 3)
-	#error "Not support over 3 interfaces yet !!"
+#if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8188F) || \
+defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8192F) || \
+defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8710B) || \
+defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || defined(CONFIG_RTL8723D)
+#define CONFIG_HWMPCAP_GEN1
+#elif defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C) /*|| defined(CONFIG_RTL8814A)*/
+#define CONFIG_HWMPCAP_GEN2
+#elif defined(CONFIG_RTL8814B) /*Address CAM - 128*/
+#define CONFIG_HWMPCAP_GEN3
+#endif
+
+#if defined(CONFIG_HWMPCAP_GEN1) && (CONFIG_IFACE_NUMBER > 2) 
+	#ifdef CONFIG_POWER_SAVING
+	/*#warning "Disable PS when CONFIG_IFACE_NUMBER > 2"*/
+	#undef CONFIG_POWER_SAVING
+	#endif
+
+	#ifdef CONFIG_WOWLAN
+	#error "This IC can't support MI and WoWLan at the same time"
+	#endif
+#endif
+
+#if (CONFIG_IFACE_NUMBER > 4)
+	#error "Not support over 4 interfaces yet !!"
 #endif
 
 #if (CONFIG_IFACE_NUMBER > 8)	/*IFACE_ID_MAX*/
@@ -315,10 +394,28 @@
 	#endif
 
 	#ifdef CONFIG_AP_MODE
+		#define CONFIG_SUPPORT_MULTI_BCN
+
 		#define CONFIG_SWTIMER_BASED_TXBCN
-		/*#define CONFIG_FW_BASED_BCN*/
-	#endif
-#endif
+
+		#ifdef CONFIG_HWMPCAP_GEN2 /*CONFIG_RTL8822B/CONFIG_RTL8821C/CONFIG_RTL8822C*/
+		#define CONFIG_FW_HANDLE_TXBCN
+
+		#ifdef CONFIG_FW_HANDLE_TXBCN
+			#ifdef CONFIG_SWTIMER_BASED_TXBCN
+				#undef CONFIG_SWTIMER_BASED_TXBCN
+			#endif
+
+			#define CONFIG_LIMITED_AP_NUM	4
+		#endif
+	#endif /*CONFIG_HWMPCAP_GEN2*/
+	#endif /*CONFIG_AP_MODE*/
+
+	#ifdef CONFIG_HWMPCAP_GEN2 /*CONFIG_RTL8822B/CONFIG_RTL8821C/CONFIG_RTL8822C*/
+	#define CONFIG_CLIENT_PORT_CFG
+	#define CONFIG_NEW_NETDEV_HDL
+	#endif/*CONFIG_HWMPCAP_GEN2*/
+#endif/*(CONFIG_IFACE_NUMBER > 2)*/
 
 #define MACID_NUM_SW_LIMIT 32
 #define SEC_CAM_ENT_NUM_SW_LIMIT 32
@@ -327,10 +424,18 @@
 	#define CONFIG_IEEE80211_BAND_5GHZ
 #endif
 
-#if defined(CONFIG_WOWLAN) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C))
+#if defined(CONFIG_WOWLAN) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8814A))
 	#define CONFIG_WOW_PATTERN_HW_CAM
 #endif
 
+#ifndef CONFIG_TSF_UPDATE_PAUSE_FACTOR
+#define CONFIG_TSF_UPDATE_PAUSE_FACTOR 200
+#endif
+
+#ifndef CONFIG_TSF_UPDATE_RESTORE_FACTOR
+#define CONFIG_TSF_UPDATE_RESTORE_FACTOR 5
+#endif
+
 /*
 	Mark CONFIG_DEAUTH_BEFORE_CONNECT by Arvin 2015/07/20
 	If the failure of Wi-Fi connection is due to some irregular disconnection behavior (like unplug dongle,
@@ -343,6 +448,7 @@
 
 
 /*#define CONFIG_DOSCAN_IN_BUSYTRAFFIC	*/
+/*#define CONFIG_PHDYM_FW_FIXRATE		*/	/*	Another way to fix tx rate	*/
 
 /*Don't release SDIO irq in suspend/resume procedure*/
 #define CONFIG_RTW_SDIO_KEEP_IRQ	0
@@ -384,4 +490,24 @@
 #define CONFIG_IPS
 #endif
 #endif
+
+#ifdef RTW_REDUCE_SCAN_SWITCH_CH_TIME
+#ifndef CONFIG_RTL8822B
+	#error "Only 8822B support RTW_REDUCE_SCAN_SWITCH_CH_TIME"
+#endif
+	#ifndef RTW_CHANNEL_SWITCH_OFFLOAD
+		#define RTW_CHANNEL_SWITCH_OFFLOAD
+	#endif
+#endif
+
+#define CONFIG_RTW_TPT_MODE 
+
+#ifdef CONFIG_PCI_BCN_POLLING
+#define CONFIG_BCN_ICF
+#endif 
+
+#ifndef CONFIG_PCI_MSI
+#define CONFIG_RTW_PCI_MSI_DISABLE
+#endif
+
 #endif /* __DRV_CONF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types.h
index 265e511eee32..65355809c41b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -60,6 +61,7 @@ typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;
 #include <rtw_debug.h>
 #include <cmn_info/rtw_sta_info.h>
 #include <rtw_rf.h>
+#include "../core/rtw_chplan.h"
 
 #ifdef CONFIG_80211N_HT
 	#include <rtw_ht.h>
@@ -109,6 +111,9 @@ typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;
 #include <rtw_mlme_ext.h>
 #include <rtw_mi.h>
 #include <rtw_ap.h>
+#ifdef CONFIG_RTW_MESH
+#include "../core/mesh/rtw_mesh.h"
+#endif
 #include <rtw_efuse.h>
 #include <rtw_version.h>
 #include <rtw_odm.h>
@@ -194,6 +199,7 @@ struct registry_priv {
 	u8	power_mgnt;
 	u8	ips_mode;
 	u8	lps_level;
+	u8	lps_chk_by_tp;
 	u8	smart_ps;
 #ifdef CONFIG_WMMPS_STA
 	u8	wmm_smart_ps;
@@ -203,6 +209,7 @@ struct registry_priv {
 	u8	long_retry_lmt;
 	u8	short_retry_lmt;
 	u16	busy_thresh;
+	u16	max_bss_cnt;
 	u8	ack_policy;
 	u8	mp_mode;
 #if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTW_CUSTOMER_STR)
@@ -340,6 +347,9 @@ struct registry_priv {
 	s8 target_tx_pwr_5g[RF_PATH_MAX][RATE_SECTION_NUM - 1];
 #endif
 
+	u8 tsf_update_pause_factor;
+	u8 tsf_update_restore_factor;
+
 	s8	TxBBSwing_2G;
 	s8	TxBBSwing_5G;
 	u8	AmplifierType_2G;
@@ -363,8 +373,6 @@ struct registry_priv {
 	u8 hiq_filter;
 	u8 adaptivity_en;
 	u8 adaptivity_mode;
-	u8 adaptivity_dml;
-	u8 adaptivity_dc_backoff;
 	s8 adaptivity_th_l2h_ini;
 	s8 adaptivity_th_edcca_hl_diff;
 
@@ -398,11 +406,7 @@ struct registry_priv {
 	u32 rtw_mcc_sta_bw80_target_tx_tp;
 	s8 rtw_mcc_policy_table_idx;
 	u8 rtw_mcc_duration;
-	u8 rtw_mcc_tsf_sync_offset;
-	u8 rtw_mcc_start_time_offset;
-	u8 rtw_mcc_interval;
-	s8 rtw_mcc_guard_offset0;
-	s8 rtw_mcc_guard_offset1;
+	u8 rtw_mcc_enable_runtime_duration;
 #endif /* CONFIG_MCC_MODE */
 
 #ifdef CONFIG_RTW_NAPI
@@ -417,16 +421,18 @@ struct registry_priv {
 
 #ifdef CONFIG_WOWLAN
 	u8 wakeup_event;
+	u8 suspend_type;
 #endif
 
 #ifdef CONFIG_SUPPORT_TRX_SHARED
 	u8 trx_share_mode;
 #endif
 	u8 check_hw_status;
-
+	u8 wowlan_sta_mix_mode;
 	u32 pci_aspm_config;
 
 	u8 iqk_fw_offload;
+	u8 ch_switch_offload;
 
 #ifdef CONFIG_TDLS
 	u8 en_tdls;
@@ -439,6 +445,25 @@ struct registry_priv {
 #ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
 	u8 fw_param_init;
 #endif
+#ifdef CONFIG_DYNAMIC_SOML
+	u8 dyn_soml_en;
+	u8 dyn_soml_train_num;
+	u8 dyn_soml_interval;
+	u8 dyn_soml_period;
+	u8 dyn_soml_delay;
+#endif
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	u8 fw_tbtt_rpt;
+#endif
+
+#ifdef DBG_LA_MODE
+	u8 la_mode_en;
+#endif
+#ifdef CONFIG_TDMADIG
+	u8 tdmadig_en;
+	u8 tdmadig_mode;
+	u8 tdmadig_dynamic;
+#endif/*CONFIG_TDMADIG*/
 };
 
 /* For registry parameters */
@@ -456,13 +481,19 @@ struct registry_priv {
 #define GetRegGLNAType(_Adapter)	(_Adapter->registrypriv.GLNA_Type)
 #define GetRegPowerTrackingType(_Adapter)	(_Adapter->registrypriv.PowerTracking_Type)
 
+#define WOWLAN_IS_STA_MIX_MODE(_Adapter)	(_Adapter->registrypriv.wowlan_sta_mix_mode)
 #define BSSID_OFT(field) ((ULONG)FIELD_OFFSET(WLAN_BSSID_EX, field))
 #define BSSID_SZ(field)   sizeof(((PWLAN_BSSID_EX) 0)->field)
 
 #define BW_MODE_2G(bw_mode) ((bw_mode) & 0x0F)
 #define BW_MODE_5G(bw_mode) ((bw_mode) >> 4)
+#ifdef CONFIG_80211N_HT
 #define REGSTY_BW_2G(regsty) BW_MODE_2G((regsty)->bw_mode)
 #define REGSTY_BW_5G(regsty) BW_MODE_5G((regsty)->bw_mode)
+#else
+#define REGSTY_BW_2G(regsty) CHANNEL_WIDTH_20
+#define REGSTY_BW_5G(regsty) CHANNEL_WIDTH_20
+#endif
 #define REGSTY_IS_BW_2G_SUPPORT(regsty, bw) (REGSTY_BW_2G((regsty)) >= (bw))
 #define REGSTY_IS_BW_5G_SUPPORT(regsty, bw) (REGSTY_BW_5G((regsty)) >= (bw))
 
@@ -684,7 +715,7 @@ struct rtw_traffic_statistics {
 	u64	tx_drop;
 	u64	cur_tx_bytes;
 	u64	last_tx_bytes;
-	u32	cur_tx_tp; /* Tx throughput in MBps. */
+	u32	cur_tx_tp; /* Tx throughput in Mbps. */
 
 	/* rx statistics */
 	u64	rx_bytes;
@@ -692,7 +723,7 @@ struct rtw_traffic_statistics {
 	u64	rx_drop;
 	u64	cur_rx_bytes;
 	u64	last_rx_bytes;
-	u32	cur_rx_tp; /* Rx throughput in MBps. */
+	u32	cur_rx_tp; /* Rx throughput in Mbps. */
 };
 
 #define SEC_CAP_CHK_BMC	BIT0
@@ -750,6 +781,15 @@ struct macid_bmp {
 #endif
 };
 
+#ifdef CONFIG_CLIENT_PORT_CFG
+struct clt_port_t{
+	_lock lock;
+	u8 bmp;
+	s8 num;
+};
+#define get_clt_num(adapter) (adapter_to_dvobj(adapter)->clt_port.num)
+#endif
+
 struct macid_ctl_t {
 	_lock lock;
 	u8 num;
@@ -826,6 +866,11 @@ struct macid_ctl_t {
 #define TXPWR_LMT_HAS_OFDM_3T	BIT6
 #define TXPWR_LMT_HAS_OFDM_4T	BIT7
 
+#define OFFCHS_NONE			0
+#define OFFCHS_LEAVING_OP	1
+#define OFFCHS_LEAVE_OP		2
+#define OFFCHS_BACKING_OP	3
+
 struct rf_ctl_t {
 	const struct country_chplan *country_ent;
 	u8 ChannelPlan;
@@ -833,6 +878,9 @@ struct rf_ctl_t {
 	RT_CHANNEL_INFO channel_set[MAX_CHANNEL_NUM];
 	struct p2p_channels channel_list;
 
+	_mutex offch_mutex;
+	u8 offch_state;
+
 	/* used for debug or by tx power limit */
 	u16 rate_bmp_cck_ofdm;		/* 20MHz */
 	u32 rate_bmp_ht_by_bw[2];	/* 20MHz, 40MHz. 4SS supported */
@@ -857,9 +905,15 @@ struct rf_ctl_t {
 	#endif
 #endif
 
+	u8 ch_sel_same_band_prefer;
+
+#ifdef CONFIG_DFS
+	u8 csa_ch;
+
 #ifdef CONFIG_DFS_MASTER
+	_timer radar_detect_timer;
 	bool radar_detect_by_others;
-	u8 dfs_master_enabled;
+	u8 radar_detect_enabled;
 	bool radar_detected;
 
 	u8 radar_detect_ch;
@@ -868,19 +922,38 @@ struct rf_ctl_t {
 
 	systime cac_start_time;
 	systime cac_end_time;
+	u8 cac_force_stop;
 
+#ifdef CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
+	u8 dfs_slave_with_rd;
+#endif
 	u8 dfs_ch_sel_d_flags;
 
-	u8 dbg_dfs_master_fake_radar_detect_cnt;
-	u8 dbg_dfs_master_radar_detect_trigger_non;
-	u8 dbg_dfs_master_choose_dfs_ch_first;
-#endif
+	u8 dbg_dfs_fake_radar_detect_cnt;
+	u8 dbg_dfs_radar_detect_trigger_non;
+	u8 dbg_dfs_choose_dfs_ch_first;
+#endif /* CONFIG_DFS_MASTER */
+#endif /* CONFIG_DFS */
 };
 
 #define RTW_CAC_STOPPED 0
+#ifdef CONFIG_DFS_MASTER
 #define IS_CAC_STOPPED(rfctl) ((rfctl)->cac_end_time == RTW_CAC_STOPPED)
-#define IS_CH_WAITING(rfctl) (!IS_CAC_STOPPED(rfctl) && time_after((rfctl)->cac_end_time, rtw_get_current_time()))
-#define IS_UNDER_CAC(rfctl) (IS_CH_WAITING(rfctl) && time_after(rtw_get_current_time(), (rfctl)->cac_start_time))
+#define IS_CH_WAITING(rfctl) (!IS_CAC_STOPPED(rfctl) && rtw_time_after((rfctl)->cac_end_time, rtw_get_current_time()))
+#define IS_UNDER_CAC(rfctl) (IS_CH_WAITING(rfctl) && rtw_time_after(rtw_get_current_time(), (rfctl)->cac_start_time))
+#define IS_RADAR_DETECTED(rfctl) ((rfctl)->radar_detected)
+#else
+#define IS_CAC_STOPPED(rfctl) 1
+#define IS_CH_WAITING(rfctl) 0
+#define IS_UNDER_CAC(rfctl) 0
+#define IS_RADAR_DETECTED(rfctl) 0
+#endif /* CONFIG_DFS_MASTER */
+
+#ifdef CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
+#define IS_DFS_SLAVE_WITH_RD(rfctl) ((rfctl)->dfs_slave_with_rd)
+#else
+#define IS_DFS_SLAVE_WITH_RD(rfctl) 0
+#endif
 
 #ifdef CONFIG_MBSSID_CAM
 #define TOTAL_MBID_CAM_NUM	8
@@ -920,6 +993,21 @@ struct halmacpriv {
 };
 #endif /* RTW_HALMAC */
 
+#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
+/*info for H2C-0x2C*/
+struct dft_info {
+	u8 port_id;
+	u8 mac_id;
+};
+#endif
+
+#ifdef CONFIG_HW_P0_TSF_SYNC
+struct tsf_info {
+	u8 sync_port;/*port_x's tsf sync to port_0*/
+	u8 offset; /*tsf timer offset*/
+};
+#endif
+
 struct dvobj_priv {
 	/*-------- below is common data --------*/
 	u8	chip_type;
@@ -949,6 +1037,10 @@ struct dvobj_priv {
 	_mutex sd_indirect_access_mutex;
 #endif
 
+#ifdef CONFIG_SYSON_INDIRECT_ACCESS
+	_mutex syson_indirect_access_mutex;	/* System On Reg R/W */
+#endif
+
 	unsigned char	oper_channel; /* saved channel info when call set_channel_bw */
 	unsigned char	oper_bwmode;
 	unsigned char	oper_ch_offset;/* PRIME_CHNL_OFFSET */
@@ -959,14 +1051,27 @@ struct dvobj_priv {
 	struct mi_state iface_state;
 
 #ifdef CONFIG_AP_MODE
-	u8 nr_ap_if; /* total interface s number of ap/go mode. */
-	u16 inter_bcn_space; /* unit:ms */
+	#ifdef CONFIG_SUPPORT_MULTI_BCN
+	u8		nr_ap_if; /* total interface number of ap /go /mesh / nan mode. */
+	u16		inter_bcn_space; /* unit:ms */
 	_queue	ap_if_q;
-#ifdef CONFIG_RTW_REPEATER_SON
+	u8		vap_map;
+	u8		fw_bcn_offload;
+	u8		vap_tbtt_rpt_map;
+	#endif /*CONFIG_SUPPORT_MULTI_BCN*/
+	#ifdef CONFIG_RTW_REPEATER_SON
 	struct rtw_rson_struct  rson_data;
+	#endif
+#endif
+#ifdef CONFIG_CLIENT_PORT_CFG
+	struct clt_port_t clt_port;
 #endif
 
+#ifdef CONFIG_HW_P0_TSF_SYNC
+	struct tsf_info p0_tsf;
 #endif
+	systime periodic_tsf_update_etime;
+	_timer periodic_tsf_update_end_timer;
 
 	struct macid_ctl_t macid_ctl;
 
@@ -1024,8 +1129,14 @@ struct dvobj_priv {
 #endif /* RTW_HALMAC */
 
 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
-	u8 default_port_id;
+	/*info for H2C-0x2C*/
+	struct dft_info dft;
 #endif
+
+#ifdef CONFIG_RTW_WIFI_HAL
+	u32 nodfs;
+#endif
+
 	/*-------- below is for SDIO INTERFACE --------*/
 
 #ifdef INTF_DATA
@@ -1148,6 +1259,15 @@ struct dvobj_priv {
 #ifdef CONFIG_MCC_MODE
 	struct mcc_obj_priv mcc_objpriv;
 #endif /*CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_TPT_MODE
+	u8 tpt_mode; /* RTK T/P Testing Mode, 0:default mode */
+	u32 edca_be_ul;
+	u32 edca_be_dl;
+#endif 
+	/* also for RTK T/P Testing Mode */ 
+	u8 scan_deny;
+
 };
 
 #define DEV_STA_NUM(_dvobj)			MSTATE_STA_NUM(&((_dvobj)->iface_state))
@@ -1155,11 +1275,15 @@ struct dvobj_priv {
 #define DEV_STA_LG_NUM(_dvobj)		MSTATE_STA_LG_NUM(&((_dvobj)->iface_state))
 #define DEV_TDLS_LD_NUM(_dvobj)		MSTATE_TDLS_LD_NUM(&((_dvobj)->iface_state))
 #define DEV_AP_NUM(_dvobj)			MSTATE_AP_NUM(&((_dvobj)->iface_state))
+#define DEV_AP_STARTING_NUM(_dvobj)	MSTATE_AP_STARTING_NUM(&((_dvobj)->iface_state))
 #define DEV_AP_LD_NUM(_dvobj)		MSTATE_AP_LD_NUM(&((_dvobj)->iface_state))
 #define DEV_ADHOC_NUM(_dvobj)		MSTATE_ADHOC_NUM(&((_dvobj)->iface_state))
 #define DEV_ADHOC_LD_NUM(_dvobj)	MSTATE_ADHOC_LD_NUM(&((_dvobj)->iface_state))
 #define DEV_MESH_NUM(_dvobj)		MSTATE_MESH_NUM(&((_dvobj)->iface_state))
 #define DEV_MESH_LD_NUM(_dvobj)		MSTATE_MESH_LD_NUM(&((_dvobj)->iface_state))
+#define DEV_P2P_DV_NUM(_dvobj)		MSTATE_P2P_DV_NUM(&((_dvobj)->iface_state))
+#define DEV_P2P_GC_NUM(_dvobj)		MSTATE_P2P_GC_NUM(&((_dvobj)->iface_state))
+#define DEV_P2P_GO_NUM(_dvobj)		MSTATE_P2P_GO_NUM(&((_dvobj)->iface_state))
 #define DEV_SCAN_NUM(_dvobj)		MSTATE_SCAN_NUM(&((_dvobj)->iface_state))
 #define DEV_WPS_NUM(_dvobj)			MSTATE_WPS_NUM(&((_dvobj)->iface_state))
 #define DEV_ROCH_NUM(_dvobj)		MSTATE_ROCH_NUM(&((_dvobj)->iface_state))
@@ -1199,7 +1323,7 @@ static inline void dev_clr_drv_stopped(struct dvobj_priv *dvobj)
 #define dev_is_drv_stopped(dvobj)		(ATOMIC_READ(&dvobj->bDriverStopped) == _TRUE)
 
 #ifdef PLATFORM_LINUX
-static struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
+static inline struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
 {
 	/* todo: get interface type from dvobj and the return the dev accordingly */
 #ifdef RTW_DVOBJ_CHIP_HW_TYPE
@@ -1234,6 +1358,19 @@ enum _hw_port {
 	MAX_HW_PORT,
 };
 
+#ifdef CONFIG_CLIENT_PORT_CFG
+enum _client_port {
+	CLT_PORT0 = HW_PORT1,
+	CLT_PORT1 = HW_PORT2,
+	CLT_PORT2 = HW_PORT3,
+	CLT_PORT3 = HW_PORT4,
+	CLT_PORT_INVALID = HW_PORT0,
+};
+
+#define MAX_CLIENT_PORT_NUM	4
+#define get_clt_port(adapter) (adapter->client_port)
+#endif
+
 enum _ADAPTER_TYPE {
 	PRIMARY_ADAPTER,
 	VIRTUAL_ADAPTER,
@@ -1281,11 +1418,6 @@ typedef struct loopbackdata {
 } LOOPBACKDATA, *PLOOPBACKDATA;
 #endif
 
-struct tsf_info {
-	u8 sync_port;/*tsf sync from portx*/
-	u8 offset; /*tsf timer offset*/
-};
-
 #define ADAPTER_TX_BW_2G(adapter) BW_MODE_2G((adapter)->driver_tx_bw_mode)
 #define ADAPTER_TX_BW_5G(adapter) BW_MODE_5G((adapter)->driver_tx_bw_mode)
 
@@ -1294,8 +1426,10 @@ struct _ADAPTER {
 	int	pid[3];/* process id from UI, 0:wps, 1:hostapd, 2:dhcpcd */
 	int	bDongle;/* build-in module or external dongle */
 
+	#if defined(CONFIG_AP_MODE) && defined(CONFIG_SUPPORT_MULTI_BCN)
 	_list	list;
-
+	u8 vap_id;
+	#endif
 	struct dvobj_priv *dvobj;
 	struct	mlme_priv mlmepriv;
 	struct	mlme_ext_priv mlmeextpriv;
@@ -1313,10 +1447,6 @@ struct _ADAPTER {
 	struct	security_priv	securitypriv;
 	_lock   security_key_mutex; /* add for CONFIG_IEEE80211W, none 11w also can use */
 	struct	registry_priv	registrypriv;
-#ifdef CONFIG_RTW_LED
-	struct	led_priv	ledpriv;
-#endif
-
 
 #ifdef CONFIG_RTW_NAPI
 	struct	napi_struct napi;
@@ -1481,12 +1611,14 @@ struct _ADAPTER {
 	**	refer to iface_id if iface_nums>2 and isprimary is false and the adapter_type value is 0xff.*/
 	u8 adapter_type;/*be used in  Multi-interface to recognize whether is PRIMARY_ADAPTER  or not(PRIMARY_ADAPTER/VIRTUAL_ADAPTER) .*/
 	u8 hw_port; /*interface port type, it depends on HW port */
-	struct tsf_info tsf;
 
+	#ifdef CONFIG_CLIENT_PORT_CFG
+	u8 client_id;
+	u8 client_port;
+	#endif
+	/*struct tsf_info tsf;*//*reserve define for 8814B*/
 
 	/*extend to support multi interface*/
-	/*IFACE_ID0 is equals to PRIMARY_ADAPTER
-	IFACE_ID1 is equals to VIRTUAL_ADAPTER*/
 	u8 iface_id;
 
 #ifdef CONFIG_BR_EXT
@@ -1560,6 +1692,16 @@ struct _ADAPTER {
 #ifdef CONFIG_MCC_MODE
 	struct mcc_adapter_priv mcc_adapterpriv;
 #endif /* CONFIG_MCC_MODE */
+
+#ifdef CONFIG_RTW_MESH
+	struct rtw_mesh_cfg mesh_cfg;
+	struct rtw_mesh_info mesh_info;
+	_timer mesh_path_timer;
+	_timer mesh_path_root_timer;
+	_timer mesh_atlm_param_req_timer; /* airtime link metrics param request timer */
+	_workitem mesh_work;
+	unsigned long wrkq_flags;
+#endif /* CONFIG_RTW_MESH */
 };
 
 #define adapter_to_dvobj(adapter) ((adapter)->dvobj)
@@ -1576,6 +1718,11 @@ struct _ADAPTER {
 #define adapter_to_macidctl(adapter) dvobj_to_macidctl(adapter_to_dvobj((adapter)))
 
 #define adapter_mac_addr(adapter) (adapter->mac_addr)
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+#define adapter_pno_mac_addr(adapter) \
+	((adapter_wdev_data(adapter))->pno_mac_addr)
+#endif
+
 #define adapter_to_chset(adapter) (adapter_to_rfctl((adapter))->channel_set)
 
 #define mlme_to_adapter(mlme) container_of((mlme), struct _ADAPTER, mlmepriv)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_ce.h
index c00dea8e6b35..a8e8e2a07546 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_ce.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_gspi.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_gspi.h
index c22c4972232d..142ff0d5884e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_gspi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_gspi.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_linux.h
index 91ca68b39c26..66e88cfe4b31 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_linux.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_pci.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_pci.h
index a3a492708860..4222c1b5fbff 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_pci.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_pci.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_sdio.h
index 9feca1216820..a143e26fdfb2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_sdio.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_sdio.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_xp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_xp.h
index 81c45047ae11..7bbd2403ca71 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_xp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/drv_types_xp.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ethernet.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ethernet.h
index 2bafa4d98edc..36ad72110f45 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ethernet.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ethernet.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_hal.h
index 6da0f071d499..5aefa3ed42b4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops.h
index bcfaad2e0bba..676bf658e2cb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops_linux.h
index 0ba263de8fd7..a70f86c75e28 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_ops_linux.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_osintf.h
index 6393f779dcf8..f2f03e86ec54 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/gspi_osintf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/h2clbk.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/h2clbk.h
index 4e22afcd8652..d62d04dad90b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/h2clbk.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/h2clbk.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex.h
index 03021fee323a..c7e5b491df7a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex_wifionly.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex_wifionly.h
index 8dc76ea6cc8a..038a0bf990dd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex_wifionly.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_btcoex_wifionly.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -18,6 +19,15 @@
 #include <drv_types.h>
 #include <hal_data.h>
 
+/* Define the ICs that support wifi only cfg in coex. codes */
+#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
+#define CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG 1
+#else
+#define CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG 0
+#endif
+
+#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
+
 typedef enum _WIFIONLY_CHIP_INTERFACE {
 	WIFIONLY_INTF_UNKNOWN	= 0,
 	WIFIONLY_INTF_PCI		= 1,
@@ -56,7 +66,17 @@ void halwifionly_phy_set_rf_reg(PVOID pwifionlyContext, enum rf_path eRFPath, u3
 void halwifionly_phy_set_bb_reg(PVOID pwifionlyContext, u32 RegAddr, u32 BitMask, u32 Data);
 void hal_btcoex_wifionly_switchband_notify(PADAPTER padapter);
 void hal_btcoex_wifionly_scan_notify(PADAPTER padapter);
+void hal_btcoex_wifionly_connect_notify(PADAPTER padapter);
 void hal_btcoex_wifionly_hw_config(PADAPTER padapter);
 void hal_btcoex_wifionly_initlizevariables(PADAPTER padapter);
 void hal_btcoex_wifionly_AntInfoSetting(PADAPTER padapter);
+#else
+#define hal_btcoex_wifionly_switchband_notify(padapter)
+#define hal_btcoex_wifionly_scan_notify(padapter)
+#define hal_btcoex_wifionly_connect_notify(padapter)
+#define hal_btcoex_wifionly_hw_config(padapter)
+#define hal_btcoex_wifionly_initlizevariables(padapter)
+#define hal_btcoex_wifionly_AntInfoSetting(padapter)
+#endif
+
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com.h
index 7ba3815ec362..9fe882365c86 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -265,6 +266,8 @@ struct dbg_rx_counter {
 	u32	rx_ht_fa;
 };
 
+u8 rtw_hal_get_port(_adapter *adapter);
+
 #ifdef CONFIG_MBSSID_CAM
 	#define DBG_MBID_CAM_DUMP
 
@@ -275,7 +278,10 @@ struct dbg_rx_counter {
 	u8 rtw_get_mbid_cam_entry_num(_adapter *adapter);
 	int rtw_mbid_cam_cache_dump(void *sel, const char *fun_name , _adapter *adapter);
 	int rtw_mbid_cam_dump(void *sel, const char *fun_name, _adapter *adapter);
-	void rtw_mbid_cam_restore(_adapter *adapter);
+	void rtw_mi_set_mbid_cam(_adapter *adapter);
+	u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr);
+	void rtw_ap_set_mbid_num(_adapter *adapter, u8 ap_num);
+	void rtw_mbid_cam_enable(_adapter *adapter);
 #endif
 
 #ifdef CONFIG_MI_WITH_MBSSID_CAM
@@ -284,6 +290,7 @@ struct dbg_rx_counter {
 	#ifdef CONFIG_SWTIMER_BASED_TXBCN
 	u16 rtw_hal_bcn_interval_adjust(_adapter *adapter, u16 bcn_interval);
 	#endif
+	void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode);
 #endif
 
 void rtw_dump_mac_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter);
@@ -343,6 +350,7 @@ bool hal_chk_proto_cap(_adapter *adapter, u8 cap);
 bool hal_is_band_support(_adapter *adapter, u8 band);
 bool hal_is_bw_support(_adapter *adapter, u8 bw);
 bool hal_is_wireless_mode_support(_adapter *adapter, u8 mode);
+bool hal_is_mimo_support(_adapter *adapter);
 u8 hal_largest_bw(_adapter *adapter, u8 in_bw);
 
 bool hal_chk_wl_func(_adapter *adapter, u8 func);
@@ -358,6 +366,10 @@ void hal_com_config_channel_plan(
 );
 
 int hal_config_macaddr(_adapter *adapter, bool autoload_fail);
+#ifdef RTW_HALMAC
+void rtw_hal_hw_port_enable(_adapter *adapter);
+void rtw_hal_hw_port_disable(_adapter *adapter);
+#endif
 
 BOOLEAN
 HAL_IsLegalChannel(
@@ -382,7 +394,7 @@ Hal_MappingOutPipe(
 
 void rtw_dump_fw_info(void *sel, _adapter *adapter);
 void rtw_restore_hw_port_cfg(_adapter *adapter);
-void rtw_restore_mac_addr(_adapter *adapter);/*set mac addr when hal_init for all iface*/
+void rtw_mi_set_mac_addr(_adapter *adapter);/*set mac addr when hal_init for all iface*/
 void rtw_hal_dump_macaddr(void *sel, _adapter *adapter);
 
 void rtw_init_hal_com_default_value(PADAPTER Adapter);
@@ -418,6 +430,11 @@ u8 rtw_hal_rcr_add(_adapter *adapter, u32 add);
 u8 rtw_hal_rcr_clear(_adapter *adapter, u32 clear);
 void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action);
 
+void rtw_iface_enable_tsf_update(_adapter *adapter);
+void rtw_iface_disable_tsf_update(_adapter *adapter);
+void rtw_hal_periodic_tsf_update_chk(_adapter *adapter);
+void rtw_hal_periodic_tsf_update_end_timer_hdl(void *ctx);
+
 void hw_var_port_switch(_adapter *adapter);
 
 u8 SetHwReg(PADAPTER padapter, u8 variable, u8 *val);
@@ -492,13 +509,12 @@ void linked_info_dump(_adapter *padapter, u8 benable);
 #endif
 void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe);
 #define		HWSET_MAX_SIZE			1024
+
 #ifdef CONFIG_EFUSE_CONFIG_FILE
-	#define		EFUSE_FILE_COLUMN_NUM		16
-	u32 Hal_readPGDataFromConfigFile(PADAPTER padapter);
-	u32 Hal_ReadMACAddrFromFile(PADAPTER padapter, u8 *mac_addr);
+u32 Hal_readPGDataFromConfigFile(PADAPTER padapter);
+u32 Hal_ReadMACAddrFromFile(PADAPTER padapter, u8 *mac_addr);
 #endif /* CONFIG_EFUSE_CONFIG_FILE */
 
-int check_phy_efuse_tx_power_info_valid(PADAPTER padapter);
 int hal_efuse_macaddr_offset(_adapter *adapter);
 int Hal_GetPhyEfuseMACAddr(PADAPTER padapter, u8 *mac_addr);
 void rtw_dump_cur_efuse(PADAPTER padapter);
@@ -512,14 +528,16 @@ u8 rtw_hal_busagg_qsel_check(_adapter *padapter, u8 pre_qsel, u8 next_qsel);
 
 u8 rtw_get_current_tx_rate(_adapter *padapter, struct sta_info *psta);
 u8 rtw_get_current_tx_sgi(_adapter *padapter, struct sta_info *psta);
-void rtw_hal_construct_NullFunctionData(PADAPTER, u8 *pframe, u32 *pLength, u8 *StaAddr, u8 bQoS, u8 AC, u8 bEosp, u8 bForcePowerSave);
-
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
+void rtw_hal_set_pathb_phase(_adapter *adapter, u8 phase_idx);
+#endif
 void rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished);
 u8 rtw_hal_get_rsvd_page_num(struct _ADAPTER *adapter);
 
 #ifdef CONFIG_TSF_RESET_OFFLOAD
 int rtw_hal_reset_tsf(_adapter *adapter, u8 reset_port);
 #endif
+u64 rtw_hal_get_tsftr_by_port(_adapter *adapter, u8 port);
 
 #ifdef CONFIG_TDLS
 	#ifdef CONFIG_TDLS_CH_SW
@@ -527,7 +545,7 @@ int rtw_hal_reset_tsf(_adapter *adapter, u8 reset_port);
 	#endif
 #endif
 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
-s32 rtw_hal_set_wifi_port_id_cmd(_adapter *adapter);
+s32 rtw_hal_set_wifi_btc_port_id_cmd(_adapter *adapter);
 #endif
 
 #ifdef CONFIG_GPIO_API
@@ -555,16 +573,13 @@ void rtw_hal_ch_sw_iqk_info_restore(_adapter *padapter, u8 ch_sw_use_case);
 #endif
 
 void update_IOT_info(_adapter *padapter);
-
+#ifdef CONFIG_RTS_FULL_BW
+void rtw_set_rts_bw(_adapter *padapter);
+#endif/*CONFIG_RTS_FULL_BW*/
 void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap);
-void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf);
 
 void ResumeTxBeacon(_adapter *padapter);
 void StopTxBeacon(_adapter *padapter);
-#ifdef CONFIG_MI_WITH_MBSSID_CAM /*HW port0 - MBSS*/
-	void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode);
-	u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr);
-#endif
 
 #ifdef CONFIG_ANTENNA_DIVERSITY
 	u8	rtw_hal_antdiv_before_linked(_adapter *padapter);
@@ -594,13 +609,17 @@ void StopTxBeacon(_adapter *padapter);
 enum lps_pg_hdl_id {
 	LPS_PG_INFO_CFG = 0,
 	LPS_PG_REDLEMEM,
-	LPS_PG_RESEND_H2C,
+	LPS_PG_PHYDM_DIS,
+	LPS_PG_PHYDM_EN,
 };
 
 	u8 rtw_hal_set_lps_pg_info(_adapter *adapter);
 #endif
 
 int rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset, u32 page_num, u8 *buffer, u32 buffer_size);
+void rtw_hal_construct_beacon(_adapter *padapter, u8 *pframe, u32 *pLength);
+void rtw_hal_construct_NullFunctionData(PADAPTER, u8 *pframe, u32 *pLength,
+				u8 bQoS, u8 AC, u8 bEosp, u8 bForcePowerSave);
 
 #ifdef CONFIG_WOWLAN
 struct rtl_wow_pattern {
@@ -624,7 +643,16 @@ struct rtw_ndp_info {
 	u8 remote_ipv6_addr[16]; /* Just respond IP */
 	u8 target_ipv6_addr[16]; /* target IP */
 };
-#endif
+#define REMOTE_INFO_CTRL_SET_VALD_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 0, 0, 8, _value)
+#define REMOTE_INFO_CTRL_SET_PTK_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 1, 0, 1, _value)
+#define REMOTE_INFO_CTRL_SET_GTK_EN(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 1, 1, 1, _value)
+#define REMOTE_INFO_CTRL_SET_GTK_IDX(target, _value) \
+	SET_BITS_TO_LE_4BYTE(target + 2, 0, 8, _value)
+#endif /*CONFIG_WOWLAN*/
+
 void rtw_dump_phy_cap(void *sel, _adapter *adapter);
 void rtw_dump_rsvd_page(void *sel, _adapter *adapter, u8 page_offset, u8 page_num);
 #ifdef CONFIG_SUPPORT_FIFO_DUMP
@@ -635,6 +663,11 @@ void rtw_dump_fifo(void *sel, _adapter *adapter, u8 fifo_sel, u32 fifo_addr, u32
 s32 rtw_hal_set_default_port_id_cmd(_adapter *adapter, u8 mac_id);
 s32 rtw_set_default_port_id(_adapter *adapter);
 s32 rtw_set_ps_rsvd_page(_adapter *adapter);
+
+#define get_dft_portid(adapter) (adapter_to_dvobj(adapter)->dft.port_id)
+#define get_dft_macid(adapter) (adapter_to_dvobj(adapter)->dft.mac_id)
+
+/*void rtw_search_default_port(_adapter *adapter);*/
 #endif
 
 #ifdef CONFIG_P2P_PS
@@ -642,8 +675,17 @@ s32 rtw_set_ps_rsvd_page(_adapter *adapter);
 void rtw_set_p2p_ps_offload_cmd(_adapter *adapter, u8 p2p_ps_state);
 #endif
 #endif
+
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+void rtw_hal_switch_chnl_and_set_bw_offload(_adapter *adapter, u8 central_ch, u8 pri_ch_idx, u8 bw);
+#endif
+
 s16 translate_dbm_to_percentage(s16 signal);
 
+#ifdef CONFIG_SUPPORT_MULTI_BCN
+void rtw_ap_multi_bcn_cfg(_adapter *adapter);
+#endif
+
 #ifdef CONFIG_SWTIMER_BASED_TXBCN
 #ifdef CONFIG_BCN_RECOVERY
 u8 rtw_ap_bcn_recovery(_adapter *padapter);
@@ -653,4 +695,26 @@ u8 rtw_ap_bcn_queue_empty_check(_adapter *padapter, u32 txbcn_timer_ms);
 #endif
 #endif /*CONFIG_SWTIMER_BASED_TXBCN*/
 
+#ifdef CONFIG_FW_HANDLE_TXBCN
+void rtw_ap_mbid_bcn_en(_adapter *adapter, u8 mbcn_id);
+void rtw_ap_mbid_bcn_dis(_adapter *adapter, u8 mbcn_id);
+#endif
+
+void rtw_hal_get_rf_path(struct dvobj_priv *d, enum rf_type *type,
+			 enum bb_path *tx, enum bb_path *rx);
+#ifdef CONFIG_BEAMFORMING
+#ifdef RTW_BEAMFORMING_VERSION_2
+void rtw_hal_beamforming_config_csirate(PADAPTER adapter);
+#endif
+#endif
+#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8812A) ||\
+	defined(CONFIG_RTL8192F) || defined(CONFIG_RTL8192E) ||\
+	defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821A)
+u8 phy_get_current_tx_num(IN PADAPTER pAdapter, IN u8 Rate);
+#endif
+
+#ifdef CONFIG_RTL8812A
+u8 * rtw_hal_set_8812a_vendor_ie(_adapter *padapter , u8 *pframe ,uint *frlen );
+#endif
+
 #endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_h2c.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_h2c.h
index d1b26c8b9ae5..e2af2ebd516e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_h2c.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_h2c.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -35,14 +36,16 @@ enum h2c_cmd {
 	H2C_FCS_INFO = 0x11,
 	H2C_AP_WOW_GPIO_CTRL = 0x13,
 #ifdef CONFIG_MCC_MODE
-	H2C_MCC_UPDATE_PARAM = 0x15,
+	H2C_MCC_RQT_TSF = 0x15,
 	H2C_MCC_MACID_BITMAP = 0x16,
 	H2C_MCC_LOCATION = 0x10,
+	H2C_MCC_CTRL_V2 = 0x17,
 	H2C_MCC_CTRL = 0x18,
-	H2C_MCC_NOA_PARAM = 0x19,
+	H2C_MCC_TIME_SETTING = 0x19,
 	H2C_MCC_IQK_PARAM = 0x1A,
 #endif /* CONFIG_MCC_MODE */
 	H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C,
+	H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D,
 
 	/* PoweSave Class: 001 */
 	H2C_SET_PWR_MODE = 0x20,
@@ -78,7 +81,9 @@ enum h2c_cmd {
 	H2C_DYNAMIC_TX_PATH = 0x48,/* for 8814A */
 
 	H2C_FW_TRACE_EN = 0x49,
-
+#ifdef RTW_PER_CMD_SUPPORT_FW
+	H2C_REQ_PER_RPT = 0x4e,
+#endif
 	/* BT Class: 011 */
 	H2C_B_TYPE_TDMA = 0x60,
 	H2C_BT_INFO = 0x61,
@@ -106,16 +111,23 @@ enum h2c_cmd {
 	H2C_AOAC_RSVDPAGE3 = 0x88,
 	H2C_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
 	H2C_P2P_OFFLOAD = 0x8B,
-
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	H2C_FW_BCN_OFFLOAD = 0xBA,
+#endif
 	H2C_RESET_TSF = 0xC0,
+#ifdef CONFIG_FW_CORRECT_BCN
 	H2C_BCNHWSEQ = 0xC5,
+#endif
 	H2C_CUSTOMER_STR_W1 = 0xC6,
 	H2C_CUSTOMER_STR_W2 = 0xC7,
 	H2C_CUSTOMER_STR_W3 = 0xC8,
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	H2C_FW_DBG_MSG_PKT = 0xE1,
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 	H2C_MAXID,
 };
 
-#define H2C_INACTIVE_PS_LEN		3
+#define H2C_INACTIVE_PS_LEN		4
 #define H2C_RSVDPAGE_LOC_LEN		5
 #ifdef CONFIG_FW_MULTI_PORT_SUPPORT
 #define H2C_DEFAULT_PORT_ID_LEN		2
@@ -132,7 +144,7 @@ enum h2c_cmd {
 #define H2C_PSTUNEPARAM_LEN			4
 #define H2C_MACID_CFG_LEN		7
 #define H2C_BTMP_OPER_LEN			5
-#define H2C_WOWLAN_LEN			6
+#define H2C_WOWLAN_LEN			7
 #define H2C_REMOTE_WAKE_CTRL_LEN	3
 #define H2C_AOAC_GLOBAL_INFO_LEN	2
 #define H2C_AOAC_RSVDPAGE_LOC_LEN	7
@@ -147,10 +159,14 @@ enum h2c_cmd {
 #define H2C_P2P_OFFLOAD_LEN	3
 #ifdef CONFIG_MCC_MODE
 	#define H2C_MCC_CTRL_LEN			7
+#ifdef CONFIG_MCC_MODE_V2
+	#define H2C_MCC_LOCATION_LEN		7
+#else
 	#define H2C_MCC_LOCATION_LEN		3
+#endif
 	#define H2C_MCC_MACID_BITMAP_LEN	6
-	#define H2C_MCC_UPDATE_INFO_LEN		4
-	#define H2C_MCC_NOA_PARAM_LEN		4
+	#define H2C_MCC_RQT_TSF_LEN		1
+	#define H2C_MCC_TIME_SETTING_LEN		6
 	#define H2C_MCC_IQK_PARAM_LEN		7
 #endif /* CONFIG_MCC_MODE */
 #ifdef CONFIG_LPS_PG
@@ -165,35 +181,19 @@ enum h2c_cmd {
 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
 #define H2C_BTC_WL_PORT_ID_LEN	1
 #endif
+
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	#define H2C_FW_DBG_MSG_PKT_LEN	2
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+#define H2C_SINGLE_CHANNELSWITCH_V2_LEN 2
+
 #define eq_mac_addr(a, b)						(((a)[0] == (b)[0] && (a)[1] == (b)[1] && (a)[2] == (b)[2] && (a)[3] == (b)[3] && (a)[4] == (b)[4] && (a)[5] == (b)[5]) ? 1 : 0)
 #define cp_mac_addr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3], (des)[4] = (src)[4], (des)[5] = (src)[5])
 #define cpIpAddr(des, src)					((des)[0] = (src)[0], (des)[1] = (src)[1], (des)[2] = (src)[2], (des)[3] = (src)[3])
 
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
-/*
-* ARP packet
-*
-* LLC Header */
-#define GET_ARP_PKT_LLC_TYPE(__pHeader)					ReadLE2Byte(((u8 *)(__pHeader)) + 6)
-
-/* ARP element */
-#define GET_ARP_PKT_OPERATION(__pHeader)				ReadLE2Byte(((u8 *)(__pHeader)) + 6)
-#define GET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+8)
-#define GET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+14)
-#define GET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cp_mac_addr((u8 *)(_val), ((u8 *)(__pHeader))+18)
-#define GET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)	cpIpAddr((u8 *)(_val), ((u8 *)(__pHeader))+24)
-
-#define SET_ARP_PKT_HW(__pHeader, __Value)					WriteLE2Byte(((u8 *)(__pHeader)) + 0, __Value)
-#define SET_ARP_PKT_PROTOCOL(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 2, __Value)
-#define SET_ARP_PKT_HW_ADDR_LEN(__pHeader, __Value)			WriteLE1Byte(((u8 *)(__pHeader)) + 4, __Value)
-#define SET_ARP_PKT_PROTOCOL_ADDR_LEN(__pHeader, __Value)	WriteLE1Byte(((u8 *)(__pHeader)) + 5, __Value)
-#define SET_ARP_PKT_OPERATION(__pHeader, __Value)			WriteLE2Byte(((u8 *)(__pHeader)) + 6, __Value)
-#define SET_ARP_PKT_SENDER_MAC_ADDR(__pHeader, _val)	cp_mac_addr(((u8 *)(__pHeader))+8, (u8 *)(_val))
-#define SET_ARP_PKT_SENDER_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+14, (u8 *)(_val))
-#define SET_ARP_PKT_TARGET_MAC_ADDR(__pHeader, _val)	cp_mac_addr(((u8 *)(__pHeader))+18, (u8 *)(_val))
-#define SET_ARP_PKT_TARGET_IP_ADDR(__pHeader, _val)		cpIpAddr(((u8 *)(__pHeader))+24, (u8 *)(_val))
-
 #define FW_WOWLAN_FUN_EN				BIT(0)
 #define FW_WOWLAN_PATTERN_MATCH			BIT(1)
 #define FW_WOWLAN_MAGIC_PKT				BIT(2)
@@ -218,6 +218,9 @@ enum h2c_cmd {
 #define FW_REALWOWLAN_EN				BIT(5)
 #define FW_WOW_FW_UNICAST_EN			BIT(7)
 
+#define FW_IPS_DISABLE_BBRF		BIT(0)
+#define FW_IPS_WRC				BIT(1)
+
 #endif /* CONFIG_WOWLAN */
 
 /* _RSVDPAGE_LOC_CMD_0x00 */
@@ -275,9 +278,12 @@ s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool
 /* _DISCONNECT_DECISION_CMD_0x04 */
 #define SET_H2CCMD_DISCONDECISION_PARM_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
 #define SET_H2CCMD_DISCONDECISION_PARM_ADOPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_DISCONDECISION_PARM_TRY_BCN_FAIL_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_DISCONDECISION_PARM_DISCONNECT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
 #define SET_H2CCMD_DISCONDECISION_PORT_NUM(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 3, __Value)
 #define SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
 #define SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_H2CCMD_DISCONDECISION_PARM_TRY_OK_BCN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
 
 #ifdef CONFIG_RTW_CUSTOMER_STR
 #define RTW_CUSTOMER_STR_LEN 16
@@ -330,6 +336,22 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_AP_WOW_PS_RF(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
 #define SET_H2CCMD_AP_WOW_PS_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 
+/* INACTIVE_PS 0x27, duration unit is TBTT */
+#define SET_H2CCMD_INACTIVE_PS_EN(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_INACTIVE_IGNORE_PS(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_H2CCMD_INACTIVE_PERIOD_SCAN_EN(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
+#define SET_H2CCMD_INACTIVE_DISBBRF(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
+#define SET_H2CCMD_INACTIVE_PS_FREQ(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd + 1, 0, 8, __Value)
+#define SET_H2CCMD_INACTIVE_PS_DURATION(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd + 2, 0, 8, __Value)
+#define SET_H2CCMD_INACTIVE_PS_PERIOD_SCAN_TIME(__pH2CCmd, __Value) \
+	SET_BITS_TO_LE_1BYTE(__pH2CCmd + 3, 0, 8, __Value)
+
 #ifdef CONFIG_LPS_POFF
 /*PARTIAL OFF Control 0x29*/
 #define SET_H2CCMD_LPS_POFF_CTRL_EN(__pH2CCmd, __Value) \
@@ -358,12 +380,36 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #ifdef CONFIG_MCC_MODE
 /* MCC LOC CMD 0x10 */
 #define SET_H2CCMD_MCC_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 0, 1, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_OFFLOAD_RFNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 3, 4, 4, __Value)
+#define SET_H2CCMD_MCC_PWRIDX_RSVDPAGE_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 4, 0, 8, __Value)
+
+/* MCC RQT TSF 0x15 */
+#define SET_H2CCMD_MCC_RQT_TSFX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_RQT_TSFY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
 
 /* MCC MAC ID CMD 0x16 */
 #define SET_H2CCMD_MCC_MACID_BITMAP_L(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
 #define SET_H2CCMD_MCC_MACID_BITMAP_H(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
 
-/* MCC INFO CMD 0x18 */
+/* NEW MCC CTRL CMD 0x17 */
+#define SET_H2CCMD_MCC_CTRL_V2_ORDER(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_CENTRAL_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_PRIMARY_CH(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_BW(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DURATION(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_ROLE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 3, __Value)			
+#define SET_H2CCMD_MCC_CTRL_V2_INCURCH(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DIS_SW_RETRY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_DISTXNULL(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_C2HRPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 6, 2, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_TSFX(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_NULL_EARLY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 4, 4, __Value)
+#define SET_H2CCMD_MCC_CTRL_V2_UPDATE_PARM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
+
+
+/* MCC CTRL CMD 0x18 */
 #define SET_H2CCMD_MCC_CTRL_ORDER(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
 #define SET_H2CCMD_MCC_CTRL_TOTALNUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
 #define SET_H2CCMD_MCC_CTRL_CHIDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
@@ -380,12 +426,16 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_MCC_CTRL_C2HRPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 5, 2, __Value)
 #define SET_H2CCMD_MCC_CTRL_CHSCAN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 7, 1, __Value)
 
-/* MCC NoA CMD 0x19 */
-#define SET_H2CCMD_MCC_NOA_FW_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
-#define SET_H2CCMD_MCC_NOA_TSF_SYNC_OFFSET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value)
-#define SET_H2CCMD_MCC_NOA_START_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
-#define SET_H2CCMD_MCC_NOA_INTERVAL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
-#define SET_H2CCMD_MCC_EARLY_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+/* MCC Time CMD 0x19 */
+#define SET_H2CCMD_MCC_TIME_SETTING_FW_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 7, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_START_TIME(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 4, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 4, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_UPDATE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 1, __Value)
+#define  SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 1, 7, __Value)
 
 /* MCC IQK CMD 0x1A */
 #define SET_H2CCMD_MCC_IQK_READY(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
@@ -408,6 +458,12 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 5, 3, __Value)
 #define SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 2, 0, 4, __Value)
 
+/* H2C_SINGLE_CHANNELSWITCH_V2 = 0x1D */
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_CENTRAL_CH_NUM(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_PRIMARY_CH_IDX(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 0, 4, __Value)
+#define SET_H2CCMD_SINGLE_CH_SWITCH_V2_BW(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd) + 1, 4, 4, __Value)
+
+
 #if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
 #define SET_H2CCMD_BTC_WL_PORT_ID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
 #endif
@@ -433,6 +489,9 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_WOWLAN_UNIT_FOR_UPHY_DISABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 3, 1, __Value)
 #define SET_H2CCMD_WOWLAN_TAKE_PDN_UPHY_DIS_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 4, 1, __Value)
 #define SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 5, 1, __Value)
+#define SET_H2CCMD_WOWLAN_DEV2HST_EN(__pH2CCmd, __Value) 	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 7, 1, __Value)
+#define SET_H2CCMD_WOWLAN_TIME_FOR_UPHY_DISABLE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+#define SET_H2CCMD_WOWLAN_RISE_HST2DEV(__pH2CCmd, __Value) 	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+6, 2, 1, __Value)
 
 /* _REMOTE_WAKEUP_CMD_0x81 */
 #define SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
@@ -502,6 +561,11 @@ s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs);
 #define SET_H2CCMD_LPSPG_LOC(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)/*Loc_LPS_PG*/
 #endif
 
+#ifdef DBG_FW_DEBUG_MSG_PKT
+#define SET_H2CCMD_FW_DBG_MSG_PKT_EN(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)/*sniffer_dbg_en*/
+#define SET_H2CCMD_RSVDPAGE_LOC_FW_DBG_MSG_PKT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value) /*loc_debug_packet*/
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
 /* ---------------------------------------------------------------------------------------------------------
  * -------------------------------------------    Structure    --------------------------------------------------
  * --------------------------------------------------------------------------------------------------------- */
@@ -539,6 +603,9 @@ typedef struct _RSVDPAGE_LOC {
 	u8 LocInviteRsp;
 	u8 LocPDRsp;
 #endif /* CONFIG_P2P_WOWLAN */
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	u8 loc_fw_dbg_msg_pkt;
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
 } RSVDPAGE_LOC, *PRSVDPAGE_LOC;
 
 #endif
@@ -554,3 +621,8 @@ u8 rtw_hal_set_fw_media_status_cmd(_adapter *adapter, u8 mstatus, u8 macid);
 		u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter);
 	#endif /* CONFIG_P2P_WOWLAN */
 #endif
+
+#ifdef RTW_PER_CMD_SUPPORT_FW
+u8 rtw_hal_set_req_per_rpt_cmd(_adapter *adapter, u8 group_macid,
+			       u8 rpt_type, u32 macid_bitmap);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_led.h
index 8d4419141670..597cb648fd80 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -101,17 +102,21 @@ typedef enum _LED_CTL_MODE {
 	LED_CTL_POWER_ON = 1,
 	LED_CTL_LINK = 2,
 	LED_CTL_NO_LINK = 3,
-	LED_CTL_TX = 4,
-	LED_CTL_RX = 5,
-	LED_CTL_SITE_SURVEY = 6,
-	LED_CTL_POWER_OFF = 7,
-	LED_CTL_START_TO_LINK = 8,
-	LED_CTL_START_WPS = 9,
-	LED_CTL_STOP_WPS = 10,
-	LED_CTL_START_WPS_BOTTON = 11, /* added for runtop */
-	LED_CTL_STOP_WPS_FAIL = 12, /* added for ALPHA	 */
-	LED_CTL_STOP_WPS_FAIL_OVERLAP = 13, /* added for BELKIN */
-	LED_CTL_CONNECTION_NO_TRANSFER = 14,
+	LED_CTL_TX = 4, /* unspecific data TX, including single & group addressed */
+	LED_CTL_RX = 5, /* unspecific data RX, including single & group addressed */
+	LED_CTL_UC_TX = 6, /* single addressed data TX */
+	LED_CTL_UC_RX = 7, /* single addressed data RX */
+	LED_CTL_BMC_TX = 8, /* group addressed data TX */
+	LED_CTL_BMC_RX = 9, /* group addressed data RX */
+	LED_CTL_SITE_SURVEY = 10,
+	LED_CTL_POWER_OFF = 11,
+	LED_CTL_START_TO_LINK = 12,
+	LED_CTL_START_WPS = 13,
+	LED_CTL_STOP_WPS = 14,
+	LED_CTL_START_WPS_BOTTON = 15, /* added for runtop */
+	LED_CTL_STOP_WPS_FAIL = 16, /* added for ALPHA	 */
+	LED_CTL_STOP_WPS_FAIL_OVERLAP = 17, /* added for BELKIN */
+	LED_CTL_CONNECTION_NO_TRANSFER = 18,
 } LED_CTL_MODE;
 
 typedef	enum _LED_STATE {
@@ -158,7 +163,8 @@ typedef enum _LED_PIN {
 #ifdef CONFIG_PCI_HCI
 typedef	enum _LED_STRATEGY_PCIE {
 	/* start from 2 */
-	SW_LED_MODE0 = 2, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
 	SW_LED_MODE1, /* SW control for PCI Express */
 	SW_LED_MODE2, /* SW control for Cameo. */
 	SW_LED_MODE3, /* SW contorl for RunTop. */
@@ -219,7 +225,8 @@ gen_RefreshLedState(
 
 typedef	enum _LED_STRATEGY_USB {
 	/* start from 2 */
-	SW_LED_MODE0 = 2, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
 	SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
 	SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
 	SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
@@ -291,7 +298,8 @@ LedControlUSB(
 
 typedef	enum _LED_STRATEGY_SDIO {
 	/* start from 2 */
-	SW_LED_MODE0 = 2, /* SW control 1 LED via GPIO0. It is default option. */
+	SW_LED_MODE_UC_TRX_ONLY = 2,
+	SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
 	SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
 	SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
 	SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
@@ -340,28 +348,28 @@ LedControlSDIO(
 struct led_priv {
 	LED_STRATEGY		LedStrategy;
 #ifdef CONFIG_RTW_SW_LED
-	/* add for led controll */
 	LED_DATA			SwLed0;
 	LED_DATA			SwLed1;
 	LED_DATA			SwLed2;
 	u8					bRegUseLed;
+	u8 iface_en_mask;
+	u32 ctl_en_mask[CONFIG_IFACE_NUMBER];
 	void (*LedControlHandler)(_adapter *padapter, LED_CTL_MODE LedAction);
 	void (*SwLedOn)(_adapter *padapter, PLED_DATA pLed);
 	void (*SwLedOff)(_adapter *padapter, PLED_DATA pLed);
-	/* add for led controll */
 #endif
 };
 
 #define SwLedOn(adapter, pLed) \
 	do { \
-		if ((adapter)->ledpriv.SwLedOn) \
-			(adapter)->ledpriv.SwLedOn((adapter), (pLed)); \
+		if (adapter_to_led(adapter)->SwLedOn) \
+			adapter_to_led(adapter)->SwLedOn((adapter), (pLed)); \
 	} while (0)
 
 #define SwLedOff(adapter, pLed) \
 	do { \
-		if ((adapter)->ledpriv.SwLedOff) \
-			(adapter)->ledpriv.SwLedOff((adapter), (pLed)); \
+		if (adapter_to_led(adapter)->SwLedOff) \
+			adapter_to_led(adapter)->SwLedOff((adapter), (pLed)); \
 	} while (0)
 
 void BlinkTimerCallback(void *data);
@@ -383,20 +391,12 @@ DeInitLed(
 
 /* hal... */
 extern void BlinkHandler(PLED_DATA	pLed);
+void dump_led_config(void *sel, _adapter *adapter);
+void rtw_led_set_strategy(_adapter *adapter, u8 strategy);
 #endif /* CONFIG_RTW_LED */
 
-#if defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED)
-#define rtw_led_control(adapter, LedAction) \
-	do { \
-		if ((adapter)->ledpriv.LedControlHandler) \
-			(adapter)->ledpriv.LedControlHandler((adapter), (LedAction)); \
-	} while (0)
-#else
-#define rtw_led_control(adapter, LedAction) do {} while (0)
-#endif
-
 #if defined(CONFIG_RTW_LED)
-#define rtw_led_get_strategy(adapter) ((adapter)->ledpriv.LedStrategy)
+#define rtw_led_get_strategy(adapter) (adapter_to_led(adapter)->LedStrategy)
 #else
 #define rtw_led_get_strategy(adapter) NO_LED
 #endif
@@ -405,5 +405,34 @@ extern void BlinkHandler(PLED_DATA	pLed);
 #define IS_HW_LED_STRATEGY(s) ((s) == HW_LED)
 #define IS_SW_LED_STRATEGY(s) ((s) != NO_LED && (s) != HW_LED)
 
+#if defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED)
+
+#ifndef CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+#define CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY 0
+#endif
+
+#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
+void rtw_sw_led_blink_uc_trx_only(LED_DATA *led);
+void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl);
+#endif
+void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl);
+void rtw_led_tx_control(_adapter *adapter, const u8 *da);
+void rtw_led_rx_control(_adapter *adapter, const u8 *da);
+void rtw_led_set_iface_en(_adapter *adapter, u8 en);
+void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask);
+void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask);
+void rtw_led_set_ctl_en_mask_primary(_adapter *adapter);
+void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter);
+#else
+#define rtw_led_control(adapter, ctl) do {} while (0)
+#define rtw_led_tx_control(adapter, da) do {} while (0)
+#define rtw_led_rx_control(adapter, da) do {} while (0)
+#define rtw_led_set_iface_en(adapter, en) do {} while (0)
+#define rtw_led_set_iface_en_mask(adapter, mask) do {} while (0)
+#define rtw_led_set_ctl_en_mask(adapter, ctl_mask) do {} while (0)
+#define rtw_led_set_ctl_en_mask_primary(adapter) do {} while (0)
+#define rtw_led_set_ctl_en_mask_virtual(adapter) do {} while (0)
+#endif /* defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED) */
+
 #endif /*__HAL_COMMON_LED_H_*/
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_phycfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_phycfg.h
index 978e556d2b64..8e79ae259fc3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_phycfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_phycfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -29,8 +30,6 @@ typedef enum _RF_TX_NUM {
 	RF_TX_NUM_NONIMPLEMENT,
 } RF_TX_NUM;
 
-#define MAX_POWER_INDEX		0x3F
-
 /*------------------------------Define structure----------------------------*/
 typedef struct _BB_REGISTER_DEFINITION {
 	u32 rfintfs;			/* set software control: */
@@ -182,9 +181,9 @@ s8 PHY_GetTxPowerLimit(_adapter *adapter
 	, u8 rfpath, u8 rate, u8 ntx_idx, u8 cch
 );
 #else
-#define phy_get_txpwr_lmt_abs(adapter, regd_name, band, bw, tlrs, ntx_idx, cch, lock) MAX_POWER_INDEX
-#define phy_get_txpwr_lmt(adapter, regd_name, band, bw, rfpath, rs, ntx_idx, cch, lock) MAX_POWER_INDEX
-#define PHY_GetTxPowerLimit(adapter, regd_name, band, bw, rfpath, rate, ntx_idx, cch) MAX_POWER_INDEX
+#define phy_get_txpwr_lmt_abs(adapter, regd_name, band, bw, tlrs, ntx_idx, cch, lock) (GET_HAL_SPEC(adapter)->txgi_max)
+#define phy_get_txpwr_lmt(adapter, regd_name, band, bw, rfpath, rs, ntx_idx, cch, lock) (GET_HAL_SPEC(adapter)->txgi_max)
+#define PHY_GetTxPowerLimit(adapter, regd_name, band, bw, rfpath, rate, ntx_idx, cch) (GET_HAL_SPEC(adapter)->txgi_max)
 #endif /* CONFIG_TXPWR_LIMIT */
 
 s8
@@ -236,6 +235,10 @@ void phy_reload_default_tx_power_ext_info(_adapter *adapter);
 
 const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter);
 
+#ifdef CONFIG_EFUSE_CONFIG_FILE
+int check_phy_efuse_tx_power_info_valid(_adapter *adapter);
+#endif
+
 void dump_hal_txpwr_info_2g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt);
 void dump_hal_txpwr_info_5g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt);
 
@@ -293,5 +296,5 @@ int PHY_ConfigRFWithPowerLimitTableParaFile(IN PADAPTER	Adapter, IN const char *
 void phy_free_filebuf_mask(_adapter *padapter, u8 mask);
 void phy_free_filebuf(_adapter *padapter);
 #endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
-
+u8 phy_check_under_survey_ch(_adapter *adapter);
 #endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_reg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_reg.h
index 7caa55b207c2..318ae8c13ccd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_reg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_com_reg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -257,7 +258,7 @@
 #define REG_LIFETIME_CTRL				0x0426
 #define REG_MULTI_BCNQ_OFFSET			0x0427
 #define REG_SPEC_SIFS					0x0428
-#define REG_RL							0x042A
+#define REG_RETRY_LIMIT					0x042A
 #define REG_DARFRC						0x0430
 #define REG_RARFRC						0x0438
 #define REG_RRSR						0x0440
@@ -313,6 +314,11 @@
 #define REG_MACID_SLEEP	0x04D4
 
 #define REG_NQOS_SEQ					0x04DC
+#define REG_HW_SEQ0						0x04D8
+#define REG_HW_SEQ1						0x04DA
+#define REG_HW_SEQ2						0x04DC
+#define REG_HW_SEQ3						0x04DE
+
 #define REG_QOS_SEQ					0x04DE
 #define REG_NEED_CPU_HANDLE			0x04E0
 #define REG_PKT_LOSE_RPT				0x04E1
@@ -364,7 +370,7 @@
 #define REG_BCN_CTRL_1					0x0551
 #define REG_MBID_NUM					0x0552
 #define REG_DUAL_TSF_RST				0x0553
-#define REG_BCN_INTERVAL				0x0554	/* The same as REG_MBSSID_BCN_SPACE */
+#define REG_MBSSID_BCN_SPACE			0x0554
 #define REG_DRVERLYINT					0x0558
 #define REG_BCNDMATIM					0x0559
 #define REG_ATIMWND					0x055A
@@ -379,6 +385,7 @@
 #define REG_PSTIMER						0x0580
 #define REG_TIMER0						0x0584
 #define REG_TIMER1						0x0588
+#define REG_HIQ_NO_LMT_EN				0x05A7
 #define REG_ACMHWCTRL					0x05C0
 #define REG_NOA_DESC_SEL				0x05CF
 #define REG_NOA_DESC_DURATION		0x05E0
@@ -423,6 +430,8 @@
 #define REG_CTS2TO						0x0641
 #define REG_EIFS							0x0642
 
+/*REG_TCR*/
+#define BIT_PWRBIT_OW_EN BIT(7)
 
 /* RXERR_RPT */
 #define RXERR_TYPE_OFDM_PPDU			0
@@ -484,9 +493,25 @@
 #define REG_BCN_PSR_RPT				0x06A8
 #define REG_BT_COEX_TABLE				0x06C0
 
+#define BIT_WKFCAM_WE					BIT(16)
+#define BIT_WKFCAM_POLLING_V1				BIT(31)
+#define BIT_WKFCAM_CLR_V1				BIT(30)
+#define BIT_SHIFT_WKFCAM_ADDR_V2			8
+#define BIT_MASK_WKFCAM_ADDR_V2			0xff
+#define BIT_WKFCAM_ADDR_V2(x)				(((x) & BIT_MASK_WKFCAM_ADDR_V2) << BIT_SHIFT_WKFCAM_ADDR_V2)
+
 /* Hardware Port 1 */
 #define REG_MACID1						0x0700
 #define REG_BSSID1						0x0708
+
+/* Enable/Disable Port 0 and Port 1 for Specific ICs (ex. 8192F)*/
+#define REG_WLAN_ACT_MASK_CTRL_1		0x076C
+
+/* GPIO Control */
+#define REG_SW_GPIO_SHARE_CTRL			0x1038
+#define REG_SW_GPIO_A_OUT				0x1040
+#define REG_SW_GPIO_A_OEN				0x1044
+
 /* Hardware Port 2 */
 #define REG_MACID2						0x1620
 #define REG_BSSID2						0x1628
@@ -1228,6 +1253,15 @@ Current IOREG MAP
 #define EFUSE_BT_SEL_1			0x2
 #define EFUSE_BT_SEL_2			0x3
 
+/* 2 REG_GPIO_INTM				(Offset 0x0048) */
+#define BIT_EXTWOL_EN 			BIT(16)
+
+/* 2 REG_LED_CFG				(Offset 0x004C) */
+#define BIT_SW_SPDT_SEL			BIT(22)
+
+/* 2 REG_SW_GPIO_SHARE_CTRL		(Offset 0x1038) */
+#define BIT_BTGP_WAKE_LOC		(BIT(10) | BIT(11))
+#define BIT_SW_GPIO_FUNC 		BIT(0)
 
 /* 2 8051FWDL
  * 2 MCUFWDL */
@@ -1373,7 +1407,8 @@ Current IOREG MAP
 #define QUEUE_LOW				1
 #define QUEUE_NORMAL			2
 #define QUEUE_HIGH				3
-
+#define QUEUE_EXTRA_1			4
+#define QUEUE_EXTRA_2			5
 
 /* 2 TRXFF_BNDY */
 
@@ -1475,8 +1510,13 @@ Current IOREG MAP
 #define _SPEC_SIFS_OFDM(x)			(((x) & 0xFF) << 8)
 
 /* 2 RL */
-#define	RETRY_LIMIT_SHORT_SHIFT			8
-#define	RETRY_LIMIT_LONG_SHIFT			0
+#define BIT_SHIFT_SRL 8
+#define BIT_MASK_SRL 0x3f
+#define BIT_SRL(x) (((x) & BIT_MASK_SRL) << BIT_SHIFT_SRL)
+
+#define BIT_SHIFT_LRL 0
+#define BIT_MASK_LRL 0x3f
+#define BIT_LRL(x) (((x) & BIT_MASK_LRL) << BIT_SHIFT_LRL)
 
 #define	RL_VAL_AP					7
 #ifdef CONFIG_RTW_CUSTOMIZE_RLSTA
@@ -1496,11 +1536,6 @@ Current IOREG MAP
 #define AC_PARAM_ECW_MIN_OFFSET			8
 #define AC_PARAM_AIFS_OFFSET				0
 
-
-#define _LRL(x)					((x) & 0x3F)
-#define _SRL(x)					(((x) & 0x3F) << 8)
-
-
 /* 2 BCN_CTRL */
 #define EN_TXBCN_RPT			BIT(2)
 #define EN_BCN_FUNCTION		BIT(3)
@@ -1511,19 +1546,14 @@ Current IOREG MAP
 #define DIS_BCNQ_SUB			BIT(1)
 #define DIS_TSF_UDT				BIT(4)
 
-/* 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_VoqEn			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)
+#define AcmHw_BeqEn			BIT(3)
+#define AcmHw_VoqStatus		BIT(5)
+#define AcmHw_ViqStatus			BIT(6)
+#define AcmHw_BeqStatus		BIT(7)
 
 /* 2 */ /* REG_DUAL_TSF_RST (0x553) */
 #define DUAL_TSF_RST_P2P		BIT(4)
@@ -1604,6 +1634,13 @@ Current IOREG MAP
 #define BIT_LSIC_TXOP_EN		BIT(17)
 #define BIT_CTS_EN				BIT(16)
 
+/*REG_RXFLTMAP1 (Offset 0x6A2)*/
+#define BIT_CTRLFLT10EN	BIT(10) /*PS-POLL*/
+
+/*REG_WLAN_ACT_MASK_CTRL_1	(Offset 0x76C)*/
+#define EN_PORT_0_FUNCTION		BIT(12)
+#define EN_PORT_1_FUNCTION		BIT(13)
+
 /* -----------------------------------------------------
  *
  *	SDIO Bus Specification
@@ -1645,6 +1682,7 @@ Current IOREG MAP
 #define SDIO_MAX_RX_QUEUE			1
 
 #define SDIO_REG_TX_CTRL			0x0000 /* SDIO Tx Control */
+#define SDIO_REG_TIMEOUT			0x0002/*SDIO status timeout*/
 #define SDIO_REG_HIMR				0x0014 /* SDIO Host Interrupt Mask */
 #define SDIO_REG_HISR				0x0018 /* SDIO Host Interrupt Service Routine */
 #define SDIO_REG_HCPWM			0x0019 /* HCI Current Power Mode */
@@ -1739,6 +1777,19 @@ Current IOREG MAP
 #define SDIO_TX_FREE_PG_QUEUE			4	/* The number of Tx FIFO free page */
 #define SDIO_TX_FIFO_PAGE_SZ			128
 
+/* indirect access */
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+#define SDIO_REG_INDIRECT_REG_CFG		0x40
+#define SDIO_REG_INDIRECT_REG_DATA	0x44
+#define SET_INDIRECT_REG_ADDR(_cmd, _addr)	SET_BITS_TO_LE_2BYTE(((u8 *)(_cmd)) + 0, 0, 16, (_addr))
+#define SET_INDIRECT_REG_SIZE_1BYTE(_cmd)		SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 0)
+#define SET_INDIRECT_REG_SIZE_2BYTE(_cmd)		SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 1)
+#define SET_INDIRECT_REG_SIZE_4BYTE(_cmd)		SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 2)
+#define SET_INDIRECT_REG_WRITE(_cmd)			SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 2, 1, 1)
+#define SET_INDIRECT_REG_READ(_cmd)			SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 3, 1, 1)
+#define GET_INDIRECT_REG_RDY(_cmd)			LE_BITS_TO_1BYTE(((u8 *)(_cmd)) + 2, 4, 1)
+#endif/*CONFIG_SDIO_INDIRECT_ACCESS*/
+
 #ifdef CONFIG_SDIO_HCI
 	#define MAX_TX_AGG_PACKET_NUMBER	0x8
 #else
@@ -1816,8 +1867,10 @@ Current IOREG MAP
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8703B		255
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_DUAL_MAC	127
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8188F		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8188GTV		255
 #define LAST_ENTRY_OF_TX_PKT_BUFFER_8723D		255
-
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8710B		255
+#define LAST_ENTRY_OF_TX_PKT_BUFFER_8192F		255
 #define POLLING_LLT_THRESHOLD				20
 #if defined(CONFIG_RTL8723B) && defined(CONFIG_PCI_HCI)
 	#define POLLING_READY_TIMEOUT_COUNT		6000
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_data.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_data.h
index 33f216ff7671..895fed10d37f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_data.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_data.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -21,6 +22,7 @@
 #ifdef CONFIG_BT_COEXIST
 	#include <hal_btcoex.h>
 #endif
+	#include <hal_btcoex_wifionly.h>
 
 #ifdef CONFIG_SDIO_HCI
 	#include <hal_sdio.h>
@@ -96,21 +98,6 @@ typedef enum _RT_AMPDU_BRUST_MODE {
 #define MAX_BASE_NUM_IN_PHY_REG_PG_2_4G			10 /* CCK:1, OFDM:1, HT:4, VHT:4 */
 #define MAX_BASE_NUM_IN_PHY_REG_PG_5G			9 /* OFDM:1, HT:4, VHT:4 */
 
-
-/* ###### duplicate code,will move to ODM ######### */
-/* #define IQK_MAC_REG_NUM		4 */
-/* #define IQK_ADDA_REG_NUM		16 */
-
-/* #define IQK_BB_REG_NUM			10 */
-#define IQK_BB_REG_NUM_92C	9
-#define IQK_BB_REG_NUM_92D	10
-#define IQK_BB_REG_NUM_test	6
-
-#define IQK_Matrix_Settings_NUM_92D	(1+24+21)
-
-/* #define HP_THERMAL_NUM		8 */
-/* ###### duplicate code,will move to ODM ######### */
-
 #ifdef RTW_RX_AGGREGATION
 typedef enum _RX_AGG_MODE {
 	RX_AGG_DISABLE,
@@ -148,10 +135,19 @@ typedef enum _RX_AGG_MODE {
 #ifdef CONFIG_RTL8188F
 	#define EFUSE_MAP_SIZE	512
 #endif
+#ifdef CONFIG_RTL8188GTV
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8710B
+	#define EFUSE_MAP_SIZE	512
+#endif
+#ifdef CONFIG_RTL8192F
+	#define EFUSE_MAP_SIZE	512
+#endif
 
 #if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
 	#define EFUSE_MAX_SIZE	1024
-#elif defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8703B)
+#elif defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8703B) || defined(CONFIG_RTL8710B)
 	#define EFUSE_MAX_SIZE	256
 #else
 	#define EFUSE_MAX_SIZE	512
@@ -207,9 +203,6 @@ typedef struct _BB_INIT_REGISTER {
 #define MACADDR_FILE_FAILED 1
 #define MACADDR_FILE_LOADED 2
 
-#define KFREE_FLAG_ON				BIT(0)
-#define KFREE_FLAG_THERMAL_K_ON		BIT(1)
-
 #define MAX_IQK_INFO_BACKUP_CHNL_NUM	5
 #define MAX_IQK_INFO_BACKUP_REG_NUM		10
 
@@ -235,6 +228,8 @@ struct hal_spec_t {
 
 	u8 rfpath_num_2g:4;	/* used for tx power index path */
 	u8 rfpath_num_5g:4;	/* used for tx power index path */
+	u8 txgi_max; /* maximum tx power gain index */
+	u8 txgi_pdbm; /* tx power gain index per dBm */
 
 	u8 max_tx_cnt;
 	u8 tx_nss_num:4;
@@ -244,6 +239,12 @@ struct hal_spec_t {
 	u8 port_num;
 	u8 proto_cap;	/* value of PROTO_CAP_XXX */
 	u8 wl_func;		/* value of WL_FUNC_XXX */
+
+	u8 rx_tsf_filter:1;
+
+	u8 pg_txpwr_saddr; /* starting address of PG tx power info */
+	u8 pg_txgi_diff_factor; /* PG tx power gain index diff to tx power gain index */
+
 	u8 hci_type;	/* value of HCI Type */
 };
 
@@ -280,7 +281,7 @@ typedef struct hal_p2p_ps_para {
 	u8  noa_sel:1;
 	u8  all_sta_sleep:1;
 	u8  discovery:1;
-	u8  rsvd2:1;
+	u8  disable_close_rf:1;
 	u8  p2p_port_id;
 	u8  p2p_group;
 	u8  p2p_macid;
@@ -397,9 +398,9 @@ typedef struct hal_com_data {
 	u16	ForcedDataRate;	/* Force Data Rate. 0: Auto, 0x02: 1M ~ 0x6C: 54M. */
 	u8	bDumpRxPkt;
 	u8	bDumpTxPkt;
-	u8	bDisableTXPowerTraining;
-	u8	dis_turboedca;
-
+	u8	dis_turboedca; /* 1: disable turboedca, 
+						  2: disable turboedca and setting EDCA parameter based on the input parameter*/
+	u32 edca_param_mode;
 
 	/****** EEPROM setting.******/
 	u8	bautoload_fail_flag;
@@ -445,7 +446,9 @@ typedef struct hal_com_data {
 #endif /*CONFIG_RF_POWER_TRIM*/
 
 #if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || \
-	defined(CONFIG_RTL8723D)
+	defined(CONFIG_RTL8723D) || \
+	defined(CONFIG_RTL8192F)
+
 	u8	adjuseVoltageVal;
 	u8	need_restore;
 #endif
@@ -536,10 +539,11 @@ typedef struct hal_com_data {
 	_lock		IQKSpinLock;
 	u8			INIDATA_RATE[MACID_NUM_SW_LIMIT];
 
-	struct PHY_DM_STRUCT	 odmpriv;
+	struct dm_struct	 odmpriv;
 	u64			bk_rf_ability;
 	u8			bIQKInitialized;
 	u8			bNeedIQK;
+	u8			neediqk_24g;
 	u8			IQK_MP_Switch;
 	u8			bScanInProcess;
 	/******** PHY DM & DM Section **********/
@@ -553,7 +557,11 @@ typedef struct hal_com_data {
 	u32	interfaceIndex;
 
 #ifdef CONFIG_P2P
+#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+	u16 p2p_ps_offload;
+#else
 	u8	p2p_ps_offload;
+#endif
 #endif
 	/* Auto FSM to Turn On, include clock, isolation, power control for MAC only */
 	u8	bMacPwrCtrlOn;
@@ -561,6 +569,8 @@ typedef struct hal_com_data {
 
 	u8	RegIQKFWOffload;
 	struct submit_ctx	iqk_sctx;
+	u8 ch_switch_offload;
+	struct submit_ctx chsw_sctx;
 
 	RT_AMPDU_BRUST		AMPDUBurstMode; /* 92C maybe not use, but for compile successfully */
 
@@ -593,7 +603,11 @@ typedef struct hal_com_data {
 	/* SDIO Tx FIFO related. */
 	/*  */
 	/* HIQ, MID, LOW, PUB free pages; padapter->xmitpriv.free_txpg */
+#ifdef CONFIG_RTL8192F
+	u16			SdioTxFIFOFreePage[SDIO_TX_FREE_PG_QUEUE];
+#else
 	u8			SdioTxFIFOFreePage[SDIO_TX_FREE_PG_QUEUE];
+#endif/*CONFIG_RTL8192F*/
 	_lock		SdioTxFIFOFreePageLock;
 	u8			SdioTxOQTMaxFreeSpace;
 	u8			SdioTxOQTFreeSpace;
@@ -697,7 +711,7 @@ typedef struct hal_com_data {
 #endif /* CONFIG_BT_COEXIST */
 
 #if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) \
-	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8723D)
+	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8723D)|| defined(CONFIG_RTL8192F)
 #ifndef CONFIG_PCI_HCI	/* mutual exclusive with PCI -- so they're SDIO and GSPI */
 	/* Interrupt relatd register information. */
 	u32			SysIntrStatus;
@@ -749,7 +763,7 @@ typedef struct hal_com_data {
 	struct hal_iqk_reg_backup iqk_reg_backup[MAX_IQK_INFO_BACKUP_CHNL_NUM];
 
 #ifdef RTW_HALMAC
-	u8 drv_rsvd_page_number;
+	u16 drv_rsvd_page_number;
 #endif
 
 #ifdef CONFIG_BEAMFORMING
@@ -763,13 +777,16 @@ typedef struct hal_com_data {
 	u8 phydm_op_mode;
 
 	u8 in_cta_test;
-} HAL_DATA_COMMON, *PHAL_DATA_COMMON;
-
 
+#ifdef CONFIG_RTW_LED
+	struct led_priv led;
+#endif
+} HAL_DATA_COMMON, *PHAL_DATA_COMMON;
 
 typedef struct hal_com_data HAL_DATA_TYPE, *PHAL_DATA_TYPE;
-#define GET_HAL_DATA(__pAdapter)			((HAL_DATA_TYPE *)((__pAdapter)->HalData))
+#define GET_HAL_DATA(__pAdapter)			((HAL_DATA_TYPE *)(((struct _ADAPTER*)__pAdapter)->HalData))
 #define GET_HAL_SPEC(__pAdapter)			(&(GET_HAL_DATA((__pAdapter))->hal_spec))
+#define adapter_to_led(adapter) (&(GET_HAL_DATA(adapter)->led))
 
 #define GET_HAL_RFPATH_NUM(__pAdapter)		(((HAL_DATA_TYPE *)((__pAdapter)->HalData))->NumTotalRFPath)
 #define RT_GetInterfaceSelection(_Adapter)		(GET_HAL_DATA(_Adapter)->InterfaceSel)
@@ -783,6 +800,7 @@ typedef struct hal_com_data HAL_DATA_TYPE, *PHAL_DATA_TYPE;
 #define get_hal_mac_addr(adapter)				(GET_HAL_DATA(adapter)->EEPROMMACAddr)
 #define is_boot_from_eeprom(adapter)			(GET_HAL_DATA(adapter)->EepromOrEfuse)
 #define rtw_get_hw_init_completed(adapter)		(GET_HAL_DATA(adapter)->hw_init_completed)
+#define rtw_set_hw_init_completed(adapter, cmp)	(GET_HAL_DATA(adapter)->hw_init_completed = cmp)
 #define rtw_is_hw_init_completed(adapter)		(GET_HAL_DATA(adapter)->hw_init_completed == _TRUE)
 #endif
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_gspi.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_gspi.h
index 51d491cdb505..f9a6d2ca916c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_gspi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_gspi.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_ic_cfg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_ic_cfg.h
index 08a2a9f1c43c..03997ebe1cab 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_ic_cfg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_ic_cfg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -21,6 +22,7 @@
 #define RTL8723B_SUPPORT				0
 #define RTL8723D_SUPPORT				0
 #define RTL8192E_SUPPORT				0
+#define RTL8192F_SUPPORT				0
 #define RTL8814A_SUPPORT				0
 #define RTL8195A_SUPPORT				0
 #define RTL8197F_SUPPORT				0
@@ -32,7 +34,12 @@
 #define RTL8710B_SUPPORT				0
 #define RTL8814B_SUPPORT				0
 #define RTL8824B_SUPPORT				0
-
+#define RTL8198F_SUPPORT				0
+#define RTL8195B_SUPPORT				0
+#define RTL8822C_SUPPORT				0
+#define RTL8812F_SUPPORT				0
+#define RTL8197G_SUPPORT				0
+#define RTL8721D_SUPPORT				0
 
 /*#if (RTL8188E_SUPPORT==1)*/
 #define RATE_ADAPTIVE_SUPPORT			0
@@ -57,6 +64,7 @@
 	#ifndef CONFIG_FW_C2H_PKT
 		#define CONFIG_FW_C2H_PKT
 	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8821A
@@ -65,6 +73,7 @@
 	#ifndef CONFIG_FW_C2H_PKT
 		#define CONFIG_FW_C2H_PKT
 	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8192E
@@ -73,6 +82,24 @@
 	#ifndef CONFIG_FW_C2H_PKT
 		#define CONFIG_FW_C2H_PKT
 	#endif
+	#define CONFIG_RTS_FULL_BW
+#endif
+
+#ifdef CONFIG_RTL8192F
+	#undef RTL8192F_SUPPORT
+	#define RTL8192F_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
+	/*#define CONFIG_AMPDU_PRETX_CD*/
+	/*#define DBG_LA_MODE*/
+	#ifdef CONFIG_P2P_PS
+		#define CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8723B
@@ -81,6 +108,7 @@
 	#ifndef CONFIG_FW_C2H_PKT
 		#define CONFIG_FW_C2H_PKT
 	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8723D
@@ -95,6 +123,7 @@
 	#ifndef CONFIG_RTW_CUSTOMER_STR
 		#define CONFIG_RTW_CUSTOMER_STR
 	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8814A
@@ -103,6 +132,8 @@
 	#ifndef CONFIG_FW_C2H_PKT
 		#define CONFIG_FW_C2H_PKT
 	#endif
+	#define CONFIG_FW_CORRECT_BCN
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8703B
@@ -114,6 +145,7 @@
 	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
 		#define CONFIG_RTW_MAC_HIDDEN_RPT
 	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8188F
@@ -128,6 +160,22 @@
 	#ifndef CONFIG_RTW_CUSTOMER_STR
 		#define CONFIG_RTW_CUSTOMER_STR
 	#endif
+	#define CONFIG_RTS_FULL_BW
+#endif
+
+#ifdef CONFIG_RTL8188GTV
+	#undef RTL8188F_SUPPORT
+	#define RTL8188F_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#ifndef CONFIG_RTW_MAC_HIDDEN_RPT
+		#define CONFIG_RTW_MAC_HIDDEN_RPT
+	#endif
+	#ifndef CONFIG_RTW_CUSTOMER_STR
+		#define CONFIG_RTW_CUSTOMER_STR
+	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #ifdef CONFIG_RTL8822B
@@ -138,10 +186,11 @@
 	#endif /* CONFIG_FW_C2H_PKT */
 	#define RTW_TX_PA_BIAS	/* Adjust TX PA Bias from eFuse */
 	#define CONFIG_DFS	/* Enable 5G band 2&3 channel */
+	#define RTW_AMPDU_AGG_RETRY_AND_NEW
 
 	#ifdef CONFIG_WOWLAN
 		#define CONFIG_GTK_OL
-		#define CONFIG_ARP_KEEP_ALIVE
+		/*#define CONFIG_ARP_KEEP_ALIVE*/
 
 		#ifdef CONFIG_GPIO_WAKEUP
 			#ifndef WAKEUP_GPIO_IDX
@@ -158,10 +207,6 @@
 	/*
 	 * Beamforming related definition
 	 */
-	#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_BEAMFORMING)
-		#undef CONFIG_BEAMFORMING
-		#warning "Not support Beamforming in concurrent mode yet!!"
-	#endif /* CONFIG_CONCURRENT_MODE && CONFIG_BEAMFORMING */
 	/* Beamforming mechanism is on driver not phydm, always disable it */
 	#define BEAMFORMING_SUPPORT				0
 	/* Only support new beamforming mechanism */
@@ -177,10 +222,41 @@
 		#define DBG_RX_DFRAME_RAW_DATA
 	#endif /* DBG_RX_DFRAME_RAW_DATA */
 
-	/*#ifndef RTW_IQK_FW_OFFLOAD
+	#ifndef RTW_IQK_FW_OFFLOAD
 		#define RTW_IQK_FW_OFFLOAD
-	#endif*/ /* RTW_IQK_FW_OFFLOAD */
+	#endif /* RTW_IQK_FW_OFFLOAD */
+
+	/* Checksum offload feature */
+	/*#define CONFIG_TCP_CSUM_OFFLOAD_TX*/ /* not ready */
+	#define CONFIG_TCP_CSUM_OFFLOAD_RX
+
 	#define CONFIG_ADVANCE_OTA
+
+	#ifdef CONFIG_MCC_MODE
+		#define CONFIG_MCC_MODE_V2
+	#endif /* CONFIG_MCC_MODE */
+
+	#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
+		#define CONFIG_TDLS_CH_SW_V2
+	#endif
+
+	#ifndef RTW_CHANNEL_SWITCH_OFFLOAD
+		#ifdef CONFIG_TDLS_CH_SW_V2
+			#define RTW_CHANNEL_SWITCH_OFFLOAD
+		#endif
+	#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+
+	#if defined(CONFIG_RTW_MESH) && !defined(RTW_PER_CMD_SUPPORT_FW)
+		/* Supported since fw v22.1 */
+		#define RTW_PER_CMD_SUPPORT_FW
+	#endif /* RTW_PER_CMD_SUPPORT_FW */
+	#define CONFIG_SUPPORT_FIFO_DUMP
+	#define CONFIG_HW_P0_TSF_SYNC
+	#define CONFIG_BCN_RECV_TIME
+	#ifdef CONFIG_P2P_PS
+		#define CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif /* CONFIG_RTL8822B */
 
 #ifdef CONFIG_RTL8821C
@@ -205,9 +281,34 @@
 	#define CONFIG_FW_MULTI_PORT_SUPPORT
 	#endif
 	#define CONFIG_SUPPORT_FIFO_DUMP
-	/*#ifndef RTW_IQK_FW_OFFLOAD
+	#ifndef RTW_IQK_FW_OFFLOAD
 		#define RTW_IQK_FW_OFFLOAD
-	#endif*/ /* RTW_IQK_FW_OFFLOAD */
+	#endif /* RTW_IQK_FW_OFFLOAD */
+	/*#define CONFIG_AMPDU_PRETX_CD*/
+	/*#define DBG_PRE_TX_HANG*/
+
+	/* Beamforming related definition */
+	/* Beamforming mechanism is on driver not phydm, always disable it */
+	#define BEAMFORMING_SUPPORT				0
+	/* Only support new beamforming mechanism */
+	#ifdef CONFIG_BEAMFORMING
+		#define RTW_BEAMFORMING_VERSION_2
+	#endif /* CONFIG_BEAMFORMING */
+	#define CONFIG_HW_P0_TSF_SYNC
+	#define CONFIG_BCN_RECV_TIME
+	#ifdef CONFIG_P2P_PS
+		#define CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+	#endif
+	#define CONFIG_RTS_FULL_BW
+#endif /*CONFIG_RTL8821C*/
+
+#ifdef CONFIG_RTL8710B
+	#undef RTL8710B_SUPPORT
+	#define RTL8710B_SUPPORT				1
+	#ifndef CONFIG_FW_C2H_PKT
+		#define CONFIG_FW_C2H_PKT
+	#endif
+	#define CONFIG_RTS_FULL_BW
 #endif
 
 #endif /*__HAL_IC_CFG_H__*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_intf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_intf.h
index c4a08cb7274f..ebe420da8cd5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_intf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_intf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -34,9 +35,12 @@ enum _CHIP_TYPE {
 	RTL8814A,
 	RTL8703B,
 	RTL8188F,
+	RTL8188GTV,
 	RTL8822B,
 	RTL8723D,
 	RTL8821C,
+	RTL8710B,
+	RTL8192F,
 	MAX_CHIP_TYPE
 };
 
@@ -67,6 +71,7 @@ typedef enum _HW_VARIABLES {
 	HW_VAR_BASIC_RATE,
 	HW_VAR_TXPAUSE,
 	HW_VAR_BCN_FUNC,
+	HW_VAR_BCN_CTRL_ADDR,
 	HW_VAR_CORRECT_TSF,
 	HW_VAR_RCR,
 	HW_VAR_MLME_DISCONNECT,
@@ -82,7 +87,6 @@ typedef enum _HW_VARIABLES {
 	HW_VAR_SEC_DK_CFG,
 	HW_VAR_BCN_VALID,
 	HW_VAR_RF_TYPE,
-	HW_VAR_TSF,
 	HW_VAR_FREECNT,
 
 	/* PHYDM odm->SupportAbility */
@@ -97,11 +101,14 @@ typedef enum _HW_VARIABLES {
 	HW_VAR_UAPSD_TID,
 #endif /* CONFIG_WMMPS_STA */
 	HW_VAR_AMPDU_MIN_SPACE,
+#ifdef CONFIG_80211N_HT
 	HW_VAR_AMPDU_FACTOR,
+#endif /* CONFIG_80211N_HT */
 	HW_VAR_RXDMA_AGG_PG_TH,
 	HW_VAR_SET_RPWM,
 	HW_VAR_CPWM,
 	HW_VAR_H2C_FW_PWRMODE,
+	HW_VAR_H2C_INACTIVE_IPS,
 	HW_VAR_H2C_PS_TUNE_PARAM,
 	HW_VAR_H2C_FW_JOINBSSRPT,
 	HW_VAR_FWLPS_RF_ON,
@@ -137,6 +144,8 @@ typedef enum _HW_VARIABLES {
 #endif
 	HW_VAR_RPWM_TOG,
 #ifdef CONFIG_GPIO_WAKEUP
+	HW_VAR_WOW_OUTPUT_GPIO,
+	HW_VAR_WOW_INPUT_GPIO,
 	HW_SET_GPIO_WL_CTRL,
 #endif
 	HW_VAR_SYS_CLKR,
@@ -195,6 +204,19 @@ typedef enum _HW_VARIABLES {
 #endif
 	HW_VAR_DUMP_MAC_TXFIFO,
 	HW_VAR_PWR_CMD,
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	HW_VAR_BCN_HEAD_SEL,
+#endif
+	HW_VAR_SET_SOML_PARAM,
+	HW_VAR_ENABLE_RX_BAR,
+	HW_VAR_TSF_AUTO_SYNC,
+	HW_VAR_LPS_STATE_CHK,
+	#ifdef CONFIG_RTS_FULL_BW
+	HW_VAR_SET_RTS_BW,
+	#endif
+#if defined(CONFIG_PCI_HCI)
+	HW_VAR_ENSWBCN,
+#endif
 } HW_VARIABLES;
 
 typedef enum _HAL_DEF_VARIABLE {
@@ -231,7 +253,6 @@ typedef enum _HAL_DEF_VARIABLE {
 	HAL_DEF_PCI_SUUPORT_L1_BACKDOOR, /* Determine if the L1 Backdoor setting is turned on. */
 	HAL_DEF_PCI_AMD_L1_SUPPORT,
 	HAL_DEF_PCI_ASPM_OSC, /* Support for ASPM OSC, added by Roger, 2013.03.27. */
-	HAL_DEF_DBG_DIS_PWT, /* disable Tx power training or not. */
 	HAL_DEF_EFUSE_USAGE,	/* Get current EFUSE utilization. 2008.12.19. Added by Roger. */
 	HAL_DEF_EFUSE_BYTES,
 	HW_VAR_BEST_AMPDU_DENSITY,
@@ -303,6 +324,7 @@ struct hal_ops {
 	u8(*check_ips_status)(_adapter *padapter);
 #if defined(CONFIG_PCI_HCI)
 	s32(*interrupt_handler)(_adapter *padapter);
+	void (*unmap_beacon_icf)(_adapter *padapter);
 #endif
 
 #if defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
@@ -349,7 +371,12 @@ struct hal_ops {
 	void	(*write_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
 	u32 (*read_rfreg)(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask);
 	void	(*write_rfreg)(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
-
+#ifdef CONFIG_SYSON_INDIRECT_ACCESS
+	u32 (*read_syson_reg)(_adapter *padapter, u32 RegAddr, u32 BitMask);
+	void (*write_syson_reg)(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
+#endif
+	void (*read_wmmedca_reg)(_adapter *padapter, u16 *vo_params, u16 *vi_params, u16 *be_params, u16 *bk_params);
+	
 #ifdef CONFIG_HOSTAPD_MLME
 	s32(*hostap_mgnt_xmit_entry)(_adapter *padapter, _pkt *pkt);
 #endif
@@ -363,6 +390,9 @@ struct hal_ops {
 	int	(*Efuse_PgPacketWrite)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
 	u8(*Efuse_WordEnableDataWrite)(_adapter *padapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
 	BOOLEAN(*Efuse_PgPacketWrite_BT)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
+#if defined(CONFIG_RTL8710B)
+	BOOLEAN(*efuse_indirect_read4)(_adapter *padapter, u16 regaddr, u8 *value);
+#endif
 
 #ifdef DBG_CONFIG_ERROR_DETECT
 	void (*sreset_init_value)(_adapter *padapter);
@@ -402,7 +432,9 @@ struct hal_ops {
 	int (*hal_gpio_func_check)(_adapter *padapter, u8 gpio_num);
 	void (*hal_gpio_multi_func_reset)(_adapter *padapter, u8 gpio_num);
 #endif
+#ifdef CONFIG_FW_CORRECT_BCN
 	void (*fw_correct_bcn)(PADAPTER padapter);
+#endif
 
 #ifdef RTW_HALMAC
 	u8(*init_mac_register)(PADAPTER);
@@ -465,12 +497,18 @@ typedef enum _HARDWARE_TYPE {
 	HARDWARE_TYPE_RTL8188FE,
 	HARDWARE_TYPE_RTL8188FU,
 	HARDWARE_TYPE_RTL8188FS,
+	HARDWARE_TYPE_RTL8188GTVU,
+	HARDWARE_TYPE_RTL8188GTVS,
 	HARDWARE_TYPE_RTL8723DE,
 	HARDWARE_TYPE_RTL8723DU,
 	HARDWARE_TYPE_RTL8723DS,
 	HARDWARE_TYPE_RTL8821CE,
 	HARDWARE_TYPE_RTL8821CU,
 	HARDWARE_TYPE_RTL8821CS,
+	HARDWARE_TYPE_RTL8710BU,
+	HARDWARE_TYPE_RTL8192FS,
+	HARDWARE_TYPE_RTL8192FU,
+	HARDWARE_TYPE_RTL8192FE,
 	HARDWARE_TYPE_MAX,
 } HARDWARE_TYPE;
 
@@ -544,6 +582,18 @@ typedef enum _HARDWARE_TYPE {
 	 IS_HARDWARE_TYPE_8723DU(_Adapter) || \
 	 IS_HARDWARE_TYPE_8723DS(_Adapter))
 
+/* RTL8192F Series */
+#define IS_HARDWARE_TYPE_8192FS(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192FS)
+#define IS_HARDWARE_TYPE_8192FU(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192FU)	
+#define IS_HARDWARE_TYPE_8192FE(_Adapter)\
+	(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8192FE)	
+#define	IS_HARDWARE_TYPE_8192F(_Adapter)\
+	(IS_HARDWARE_TYPE_8192FS(_Adapter) ||\
+	 IS_HARDWARE_TYPE_8192FU(_Adapter) ||\
+	 IS_HARDWARE_TYPE_8192FE(_Adapter))
+
 /* RTL8188F Series */
 #define IS_HARDWARE_TYPE_8188FE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FE)
 #define IS_HARDWARE_TYPE_8188FS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188FS)
@@ -551,6 +601,15 @@ typedef enum _HARDWARE_TYPE {
 #define	IS_HARDWARE_TYPE_8188F(_Adapter)			\
 	(IS_HARDWARE_TYPE_8188FE(_Adapter) || IS_HARDWARE_TYPE_8188FU(_Adapter) || IS_HARDWARE_TYPE_8188FS(_Adapter))
 
+#define IS_HARDWARE_TYPE_8188GTVU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188GTVU)
+#define IS_HARDWARE_TYPE_8188GTVS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8188GTVS)
+#define	IS_HARDWARE_TYPE_8188GTV(_Adapter)			\
+	(IS_HARDWARE_TYPE_8188GTVU(_Adapter) || IS_HARDWARE_TYPE_8188GTVS(_Adapter))
+
+/* RTL8710B Series */
+#define IS_HARDWARE_TYPE_8710BU(_Adapter) (rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8710BU)
+#define IS_HARDWARE_TYPE_8710B(_Adapter) (IS_HARDWARE_TYPE_8710BU(_Adapter))
+
 #define IS_HARDWARE_TYPE_8821BE(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BE)
 #define IS_HARDWARE_TYPE_8821BU(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BU)
 #define IS_HARDWARE_TYPE_8821BS(_Adapter)		(rtw_get_hw_type(_Adapter) == HARDWARE_TYPE_RTL8821BS)
@@ -609,6 +668,9 @@ u32 rtw_hal_power_on(_adapter *padapter);
 void rtw_hal_power_off(_adapter *padapter);
 
 uint rtw_hal_init(_adapter *padapter);
+#ifdef CONFIG_NEW_NETDEV_HDL
+uint rtw_hal_iface_init(_adapter *adapter);
+#endif
 uint rtw_hal_deinit(_adapter *padapter);
 void rtw_hal_stop(_adapter *padapter);
 u8 rtw_hal_set_hwreg(PADAPTER padapter, u8 variable, u8 *val);
@@ -674,12 +736,19 @@ void	rtw_hal_write_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr,
 #define phy_query_rf_reg(Adapter, eRFPath, RegAddr, BitMask) rtw_hal_read_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask))
 #define phy_set_rf_reg(Adapter, eRFPath, RegAddr, BitMask, Data) rtw_hal_write_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask), (Data))
 
+#ifdef CONFIG_SYSON_INDIRECT_ACCESS
+u32 rtw_hal_read_syson_reg(PADAPTER padapter, u32 RegAddr, u32 BitMask);
+void rtw_hal_write_syson_reg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
+#define hal_query_syson_reg(Adapter, RegAddr, BitMask) rtw_hal_read_syson_reg((Adapter), (RegAddr), (BitMask))
+#define hal_set_syson_reg(Adapter, RegAddr, BitMask, Data) rtw_hal_write_syson_reg((Adapter), (RegAddr), (BitMask), (Data))
+#endif
+
 #define phy_set_mac_reg	phy_set_bb_reg
 #define phy_query_mac_reg phy_query_bb_reg
 
-
 #if defined(CONFIG_PCI_HCI)
 	s32	rtw_hal_interrupt_handler(_adapter *padapter);
+	void	rtw_hal_unmap_beacon_icf(_adapter *padapter);
 #endif
 #if  defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
 	void	rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf);
@@ -753,8 +822,9 @@ void rtw_hal_update_hisr_hsisr_ind(_adapter *padapter, u32 flag);
 int rtw_hal_gpio_func_check(_adapter *padapter, u8 gpio_num);
 void rtw_hal_gpio_multi_func_reset(_adapter *padapter, u8 gpio_num);
 #endif
-
+#ifdef CONFIG_FW_CORRECT_BCN
 void rtw_hal_fw_correct_bcn(_adapter *padapter);
+#endif
 s32 rtw_hal_fw_dl(_adapter *padapter, u8 wowlan);
 
 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_pg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_pg.h
index c60f7fce3b7a..cc470a036fcd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_pg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_pg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -29,8 +30,6 @@
 /* ****************************************************
  *			EEPROM/Efuse PG Offset for 88EE/88EU/88ES
  * **************************************************** */
-#define EEPROM_TX_PWR_INX_88E					0x10
-
 #define EEPROM_ChannelPlan_88E					0xB8
 #define EEPROM_XTAL_88E						0xB9
 #define EEPROM_THERMAL_METER_88E				0xBA
@@ -69,9 +68,6 @@
 #define PPG_BB_GAIN_2G_TXA_OFFSET_8192E	0x1F6
 #define PPG_THERMAL_OFFSET_8192E		0x1F5
 
-/* 0x10 ~ 0x63 = TX power area. */
-#define	EEPROM_TX_PWR_INX_8192E				0x10
-
 #define	EEPROM_ChannelPlan_8192E				0xB8
 #define	EEPROM_XTAL_8192E						0xB9
 #define	EEPROM_THERMAL_METER_8192E			0xBA
@@ -112,10 +108,8 @@
 #define	EEPROM_MAC_ADDR_8192ES				0x11A
 /* ****************************************************
  *			EEPROM/Efuse PG Offset for 8812AE/8812AU/8812AS
- * ****************************************************
- * 0x10 ~ 0x63 = TX power area. */
+ * *****************************************************/
 #define EEPROM_USB_MODE_8812					0x08
-#define EEPROM_TX_PWR_INX_8812				0x10
 
 #define EEPROM_ChannelPlan_8812				0xB8
 #define EEPROM_XTAL_8812						0xB9
@@ -180,7 +174,6 @@
 
 #define PPG_THERMAL_OFFSET_8814A		0x3EF
 
-#define EEPROM_TX_PWR_INX_8814				0x10
 #define EEPROM_USB_MODE_8814A				0x0E
 #define EEPROM_ChannelPlan_8814				0xB8
 #define EEPROM_XTAL_8814					0xB9
@@ -228,8 +221,6 @@
 #define PPG_BB_GAIN_5GMB2_TXA_OFFSET_8821A	0x1F1
 #define PPG_BB_GAIN_5GHB_TXA_OFFSET_8821A	0x1F0
 
-#define EEPROM_TX_PWR_INX_8821				0x10
-
 #define EEPROM_ChannelPlan_8821				0xB8
 #define EEPROM_XTAL_8821						0xB9
 #define EEPROM_THERMAL_METER_8821			0xBA
@@ -297,9 +288,6 @@
 #define PPG_BB_GAIN_2G_TXA_OFFSET_8188F	0xEE
 #define PPG_THERMAL_OFFSET_8188F		0xEF
 
-/* 0x10 ~ 0x63 = TX power area. */
-#define	EEPROM_TX_PWR_INX_8188F				0x10
-
 #define	EEPROM_ChannelPlan_8188F			0xB8
 #define	EEPROM_XTAL_8188F					0xB9
 #define	EEPROM_THERMAL_METER_8188F			0xBA
@@ -333,12 +321,53 @@
 #define	EEPROM_MAC_ADDR_8188FS				0x11A
 #define EEPROM_Voltage_ADDR_8188F			0x8
 
+/* ====================================================
+	EEPROM/Efuse PG Offset for 8188GTV/8188GTVS
+   ====================================================
+ */
+
+#define GET_PG_KFREE_ON_8188GTV(_pg_m)				LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC1, 4, 1)
+#define GET_PG_KFREE_THERMAL_K_ON_8188GTV(_pg_m)	LE_BITS_TO_1BYTE(((u8 *)(_pg_m)) + 0xC8, 5, 1)
+
+#define PPG_BB_GAIN_2G_TXA_OFFSET_8188GTV	0xEE
+#define PPG_THERMAL_OFFSET_8188GTV			0xEF
+
+#define	EEPROM_ChannelPlan_8188GTV				0xB8
+#define	EEPROM_XTAL_8188GTV						0xB9
+#define	EEPROM_THERMAL_METER_8188GTV			0xBA
+#define	EEPROM_IQK_LCK_8188GTV					0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8188GTV			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8188GTV		0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8188GTV		0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8188GTV			0xC1
+#define	EEPROM_FEATURE_OPTION_8188GTV			0xC2
+#define	EEPROM_RF_BT_SETTING_8188GTV			0xC3
+#define	EEPROM_VERSION_8188GTV					0xC4
+#define	EEPROM_CustomID_8188GTV					0xC5
+#define	EEPROM_TX_BBSWING_2G_8188GTV			0xC6
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8188GTV	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8188GTV			0xC9
+#define	EEPROM_RFE_OPTION_8188GTV				0xCA
+#define EEPROM_COUNTRY_CODE_8188GTV				0xCB
+#define EEPROM_CUSTOMER_ID_8188GTV				0x7F
+#define EEPROM_SUBCUSTOMER_ID_8188GTV			0x59
+
+/* RTL8188GTVU */
+#define EEPROM_MAC_ADDR_8188GTVU				0xD7
+#define EEPROM_VID_8188GTVU						0xD0
+#define EEPROM_PID_8188GTVU						0xD2
+#define EEPROM_PA_TYPE_8188GTVU					0xBC
+#define EEPROM_LNA_TYPE_2G_8188GTVU				0xBD
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8188GTVU	0xD4
+
+/* RTL8188GTVS */
+#define	EEPROM_MAC_ADDR_8188GTVS				0x11A
+#define EEPROM_Voltage_ADDR_8188GTV				0x8
+
 /* ****************************************************
  *			EEPROM/Efuse PG Offset for 8723BE/8723BU/8723BS
- * ****************************************************
- * 0x10 ~ 0x63 = TX power area. */
-#define	EEPROM_TX_PWR_INX_8723B				0x10
-
+ * *****************************************************/
 #define	EEPROM_ChannelPlan_8723B				0xB8
 #define	EEPROM_XTAL_8723B						0xB9
 #define	EEPROM_THERMAL_METER_8723B			0xBA
@@ -386,8 +415,6 @@
 #define PPG_BB_GAIN_2G_TXA_OFFSET_8703B	0xEE
 #define PPG_THERMAL_OFFSET_8703B		0xEF
 
-#define	EEPROM_TX_PWR_INX_8703B				0x10
-
 #define	EEPROM_ChannelPlan_8703B				0xB8
 #define	EEPROM_XTAL_8703B					0xB9
 #define	EEPROM_THERMAL_METER_8703B			0xBA
@@ -424,8 +451,6 @@
  *	EEPROM/Efuse PG Offset for 8822B
  * ====================================================
  */
-#define	EEPROM_TX_PWR_INX_8822B			0x10
-
 #define	EEPROM_ChannelPlan_8822B		0xB8
 #define	EEPROM_XTAL_8822B			0xB9
 #define	EEPROM_THERMAL_METER_8822B		0xBA
@@ -468,8 +493,6 @@
  *	EEPROM/Efuse PG Offset for 8821C
  * ====================================================
  */
-#define	EEPROM_TX_PWR_INX_8821C			0x10
-
 #define	EEPROM_CHANNEL_PLAN_8821C		0xB8
 #define	EEPROM_XTAL_8821C			0xB9
 #define	EEPROM_THERMAL_METER_8821C		0xBA
@@ -523,8 +546,6 @@
 #define PPG_BB_GAIN_2G_TX_OFFSET_8723D		0x1EE
 #define PPG_THERMAL_OFFSET_8723D		0xEF
 
-#define	EEPROM_TX_PWR_INX_8723D			0x10
-
 #define	EEPROM_ChannelPlan_8723D		0xB8
 #define	EEPROM_XTAL_8723D			0xB9
 #define	EEPROM_THERMAL_METER_8723D		0xBA
@@ -561,10 +582,82 @@
 #define	EEPROM_MAC_ADDR_8723DS			0x11A
 #define	EEPROM_Voltage_ADDR_8723D		0x8
 
+/* ****************************************************
+ *	EEPROM/Efuse PG Offset for 8192F
+ * **************************************************** */
+#define	EEPROM_ChannelPlan_8192F			0xB8
+#define	EEPROM_XTAL_8192F					0xB9
+#define	EEPROM_THERMAL_METER_8192F			0xBA
+#define	EEPROM_IQK_LCK_8192F				0xBB
+#define	EEPROM_2G_5G_PA_TYPE_8192F			0xBC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8192F	0xBD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8192F	0xBF
+
+#define	EEPROM_RF_BOARD_OPTION_8192F		0xC1
+#define	EEPROM_FEATURE_OPTION_8192F			0xC2
+#define	EEPROM_RF_BT_SETTING_8192F			0xC3
+#define	EEPROM_VERSION_8192F				0xC4
+#define	EEPROM_CustomID_8192F				0xC5
+#define	EEPROM_TX_BBSWING_2G_8192F			0xC6
+#define	EEPROM_TX_BBSWING_5G_8192F			0xC7
+#define	EEPROM_TX_PWR_CALIBRATE_RATE_8192F	0xC8
+#define	EEPROM_RF_ANTENNA_OPT_8192F			0xC9
+#define	EEPROM_RFE_OPTION_8192F				0xCA
+#define EEPROM_COUNTRY_CODE_8192F			0xCB
+/*RTL8192FS*/
+#define	EEPROM_MAC_ADDR_8192FS				0x11A
+#define EEPROM_Voltage_ADDR_8192F			0x8
+/* RTL8192FU */
+#define EEPROM_MAC_ADDR_8192FU					0x107
+#define EEPROM_VID_8192FU							0x100
+#define EEPROM_PID_8192FU							0x102
+#define EEPROM_USB_OPTIONAL_FUNCTION0_8192FU	0x104
+/* RTL8192FE */
+#define EEPROM_MAC_ADDR_8192FE					0xD0
+#define EEPROM_VID_8192FE							0xD6
+#define EEPROM_DID_8192FE							0xD8
+#define EEPROM_SVID_8192FE							0xDA
+#define EEPROM_SMID_8192FE						0xDC
+
+/* ****************************************************
+ *	EEPROM/Efuse PG Offset for 8710B
+ * **************************************************** */
+#define RTL_EEPROM_ID_8710B 					0x8195
+#define EEPROM_Default_ThermalMeter_8710B		0x1A
+
+#define	EEPROM_CHANNEL_PLAN_8710B			0xC8
+#define	EEPROM_XTAL_8710B					0xC9
+#define	EEPROM_THERMAL_METER_8710B			0xCA
+#define	EEPROM_IQK_LCK_8710B					0xCB
+#define	EEPROM_2G_5G_PA_TYPE_8710B			0xCC
+#define	EEPROM_2G_LNA_TYPE_GAIN_SEL_8710B	0xCD
+#define	EEPROM_5G_LNA_TYPE_GAIN_SEL_8710B	0xCF
+#define 	EEPROM_TX_KFREE_8710B				0xEE    //Physical  Efuse Address
+#define 	EEPROM_THERMAL_8710B				0xEF    //Physical  Efuse Address
+#define 	EEPROM_PACKAGE_TYPE_8710B			0xF8    //Physical  Efuse Address
+
+#define EEPROM_RF_BOARD_OPTION_8710B		0x131
+#define EEPROM_RF_FEATURE_OPTION_8710B		0x132
+#define EEPROM_RF_BT_SETTING_8710B			0x133
+#define EEPROM_VERSION_8710B					0x134
+#define EEPROM_CUSTOM_ID_8710B				0x135
+#define EEPROM_TX_BBSWING_2G_8710B			0x136
+#define EEPROM_TX_BBSWING_5G_8710B			0x137
+#define EEPROM_TX_PWR_CALIBRATE_RATE_8710B	0x138
+#define EEPROM_RF_ANTENNA_OPT_8710B			0x139
+#define EEPROM_RFE_OPTION_8710B				0x13A
+#define EEPROM_COUNTRY_CODE_8710B			0x13B
+#define EEPROM_COUNTRY_CODE_2_8710B			0x13C
+
+#define EEPROM_MAC_ADDR_8710B 				0x11A
+#define EEPROM_VID_8710BU						0x1C0
+#define EEPROM_PID_8710BU						0x1C2
+
 /* ****************************************************
  *			EEPROM/Efuse Value Type
  * **************************************************** */
 #define EETYPE_TX_PWR							0x0
+#define EETYPE_MAX_RFE_8192F					0x31
 /* ****************************************************
  *			EEPROM/Efuse Default Value
  * **************************************************** */
@@ -612,8 +705,9 @@
 #define	EEPROM_Default_ThermalMeter_8703B		0x18
 #define	EEPROM_Default_ThermalMeter_8723D		0x18
 #define	EEPROM_Default_ThermalMeter_8188F		0x18
+#define	EEPROM_Default_ThermalMeter_8188GTV		0x18
 #define EEPROM_Default_ThermalMeter_8814A		0x18
-
+#define	EEPROM_Default_ThermalMeter_8192F		0x1A
 
 #define EEPROM_Default_CrystalCap				0x0
 #define EEPROM_Default_CrystalCap_8723A		0x20
@@ -625,6 +719,8 @@
 #define EEPROM_Default_CrystalCap_8703B			0x20
 #define EEPROM_Default_CrystalCap_8723D			0x20
 #define EEPROM_Default_CrystalCap_8188F			0x20
+#define EEPROM_Default_CrystalCap_8188GTV		0x20
+#define EEPROM_Default_CrystalCap_8192F			0x20
 #define EEPROM_Default_CrystalFreq				0x0
 #define EEPROM_Default_TxPowerLevel_92C		0x22
 #define EEPROM_Default_TxPowerLevel_2G			0x2C
@@ -772,7 +868,8 @@ typedef	enum _BT_CoType {
 	BT_RTL8703B		= 12,
 	BT_RTL8822B		= 13,
 	BT_RTL8723D		= 14,
-	BT_RTL8821C		= 15
+	BT_RTL8821C		= 15,
+	BT_RTL8192F		= 16,
 } BT_CoType, *PBT_CoType;
 
 typedef	enum _BT_RadioShared {
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy.h
index a90b2664e40e..c369a7af3af6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -151,6 +152,14 @@ typedef struct _R_ANTENNA_SELECT_CCK {
 	u8			r_ccktx_enable:4;
 } R_ANTENNA_SELECT_CCK;
 
+
+/*--------------------------Exported Function prototype---------------------*/
+u32
+PHY_CalculateBitShift(
+	u32 BitMask
+);
+
+#ifdef CONFIG_RF_SHADOW_RW
 typedef struct RF_Shadow_Compare_Map {
 	/* Shadow register value */
 	u32		Value;
@@ -164,13 +173,6 @@ typedef struct RF_Shadow_Compare_Map {
 	u8		Driver_Write;
 } RF_SHADOW_T;
 
-/*--------------------------Exported Function prototype---------------------*/
-
-u32
-PHY_CalculateBitShift(
-	u32 BitMask
-);
-
 u32
 PHY_RFShadowRead(
 	IN	PADAPTER		Adapter,
@@ -229,5 +231,5 @@ PHY_RFShadowRecorverFlagSetAll(
 VOID
 PHY_RFShadowRefresh(
 	IN	PADAPTER		Adapter);
-
+#endif /*#CONFIG_RF_SHADOW_RW*/
 #endif /* __HAL_COMMON_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy_reg.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy_reg.h
index 6e6a99e61272..a970094f0b21 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy_reg.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_phy_reg.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_sdio.h
index 3c22eb9b9993..c798b97315c2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_sdio.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/hal_sdio.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -20,7 +21,7 @@
 u8 rtw_hal_sdio_max_txoqt_free_space(_adapter *padapter);
 u8 rtw_hal_sdio_query_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum);
 void rtw_hal_sdio_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum);
-void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ);
+void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ, u8 div_num);
 u32 rtw_hal_get_sdio_tx_max_length(PADAPTER padapter, u8 queue_idx);
 bool sdio_power_on_check(PADAPTER padapter);
 
@@ -28,4 +29,29 @@ bool sdio_power_on_check(PADAPTER padapter);
 void sd_c2h_hisr_hdl(_adapter *adapter);
 #endif
 
+#if defined(CONFIG_RTL8188F) || defined (CONFIG_RTL8188GTV) || defined (CONFIG_RTL8192F)
+#define SDIO_LOCAL_CMD_ADDR(addr) ((SDIO_LOCAL_DEVICE_ID << 13) | ((addr) & SDIO_LOCAL_MSK))
+#endif
+
+#ifdef CONFIG_SDIO_CHK_HCI_RESUME
+bool sdio_chk_hci_resume(struct intf_hdl *pintfhdl);
+void sdio_chk_hci_suspend(struct intf_hdl *pintfhdl);
+#else
+#define sdio_chk_hci_resume(pintfhdl) _FALSE
+#define sdio_chk_hci_suspend(pintfhdl) do {} while (0)
+#endif /* CONFIG_SDIO_CHK_HCI_RESUME */
+
+#ifdef CONFIG_SDIO_INDIRECT_ACCESS
+/* program indirect access register in sdio local to read/write page0 registers */
+s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v);
+s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v);
+u8 sdio_iread8(struct intf_hdl *pintfhdl, u32 addr);
+u16 sdio_iread16(struct intf_hdl *pintfhdl, u32 addr);
+u32 sdio_iread32(struct intf_hdl *pintfhdl, u32 addr);
+s32 sdio_iwrite8(struct intf_hdl *pintfhdl, u32 addr, u8 val);
+s32 sdio_iwrite16(struct intf_hdl *pintfhdl, u32 addr, u16 val);
+s32 sdio_iwrite32(struct intf_hdl *pintfhdl, u32 addr, u32 val);
+#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
+u32 cmd53_4byte_alignment(struct intf_hdl *pintfhdl, u32 addr);
+
 #endif /* __HAL_SDIO_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211.h
index c07f2d3f655a..9f6a636c0d42 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -151,6 +152,58 @@ extern u8 RSN_CIPHER_SUITE_WRAP[];
 extern u8 RSN_CIPHER_SUITE_CCMP[];
 extern u8 RSN_CIPHER_SUITE_WEP104[];
 
+/* IEEE 802.11i */
+#define PMKID_LEN 16
+#define PMK_LEN 32
+#define PMK_LEN_SUITE_B_192 48
+#define PMK_LEN_MAX 48
+#define WPA_REPLAY_COUNTER_LEN 8
+#define WPA_NONCE_LEN 32
+#define WPA_KEY_RSC_LEN 8
+#define WPA_GMK_LEN 32
+#define WPA_GTK_MAX_LEN 32
+
+/* IEEE 802.11, 8.5.2 EAPOL-Key frames */
+#define WPA_KEY_INFO_TYPE_MASK ((u16) (BIT(0) | BIT(1) | BIT(2)))
+#define WPA_KEY_INFO_TYPE_AKM_DEFINED 0
+#define WPA_KEY_INFO_TYPE_HMAC_MD5_RC4 BIT(0)
+#define WPA_KEY_INFO_TYPE_HMAC_SHA1_AES BIT(1)
+#define WPA_KEY_INFO_TYPE_AES_128_CMAC 3
+#define WPA_KEY_INFO_KEY_TYPE BIT(3) /* 1 = Pairwise, 0 = Group key */
+/* bit4..5 is used in WPA, but is reserved in IEEE 802.11i/RSN */
+#define WPA_KEY_INFO_KEY_INDEX_MASK (BIT(4) | BIT(5))
+#define WPA_KEY_INFO_KEY_INDEX_SHIFT 4
+#define WPA_KEY_INFO_INSTALL BIT(6) /* pairwise */
+#define WPA_KEY_INFO_TXRX BIT(6) /* group */
+#define WPA_KEY_INFO_ACK BIT(7)
+#define WPA_KEY_INFO_MIC BIT(8)
+#define WPA_KEY_INFO_SECURE BIT(9)
+#define WPA_KEY_INFO_ERROR BIT(10)
+#define WPA_KEY_INFO_REQUEST BIT(11)
+#define WPA_KEY_INFO_ENCR_KEY_DATA BIT(12) /* IEEE 802.11i/RSN only */
+#define WPA_KEY_INFO_SMK_MESSAGE BIT(13)
+
+struct ieee802_1x_hdr {
+	u8 version;
+	u8 type;
+	u16 length;
+	/* followed by length octets of data */
+};
+
+struct wpa_eapol_key {
+	u8 type;
+	/* Note: key_info, key_length, and key_data_length are unaligned */
+	u8 key_info[2]; /* big endian */
+	u8 key_length[2]; /* big endian */
+	u8 replay_counter[WPA_REPLAY_COUNTER_LEN];
+	u8 key_nonce[WPA_NONCE_LEN];
+	u8 key_iv[16];
+	u8 key_rsc[WPA_KEY_RSC_LEN];
+	u8 key_id[8]; /* Reserved in IEEE 802.11i/RSN */
+	u8 key_mic[16];
+	u8 key_data_length[2]; /* big endian */
+	/* followed by key_data_length bytes of key_data */
+};
 
 typedef enum _RATEID_IDX_ {
 	RATEID_IDX_BGN_40M_2SS = 0,
@@ -391,6 +444,28 @@ struct eapol {
 	u16 length;
 } __attribute__((packed));
 
+struct rtw_ieee80211s_hdr {
+	u8 flags;
+	u8 ttl;
+	u32 seqnum;
+	u8 eaddr1[ETH_ALEN];
+	u8 eaddr2[ETH_ALEN];
+} __attribute__((packed));
+
+/**
+ * struct rtw_ieee80211_rann_ie
+ *
+ * This structure refers to "Root Announcement information element"
+ */
+ struct rtw_ieee80211_rann_ie {
+	u8 rann_flags;
+	u8 rann_hopcount;
+	u8 rann_ttl;
+	u8 rann_addr[ETH_ALEN];
+	u32 rann_seq;
+	u32 rann_interval;
+	u32 rann_metric;
+} __attribute__((packed));
 #endif
 
 
@@ -631,10 +706,33 @@ struct ieee80211_snap_hdr {
 #define WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA 7
 #define WLAN_REASON_DISASSOC_STA_HAS_LEFT 8
 #define WLAN_REASON_STA_REQ_ASSOC_WITHOUT_AUTH 9
+#define WLAN_REASON_MESH_PEER_CANCELED 52
+#define WLAN_REASON_MESH_MAX_PEERS 53
+#define WLAN_REASON_MESH_CONFIG 54
+#define WLAN_REASON_MESH_CLOSE 55
+#define WLAN_REASON_MESH_MAX_RETRIES 56 
+#define WLAN_REASON_MESH_CONFIRM_TIMEOUT 57
+#define WLAN_REASON_MESH_INVALID_GTK 58
+#define WLAN_REASON_MESH_INCONSISTENT_PARAM 59
+#define WLAN_REASON_MESH_INVALID_SECURITY 60
+#define WLAN_REASON_MESH_PATH_NOPROXY 61
+#define WLAN_REASON_MESH_PATH_NOFORWARD 62
+#define WLAN_REASON_MESH_PATH_DEST_UNREACHABLE 63
+#define WLAN_REASON_MAC_EXISTS_IN_MBSS 64
+#define WLAN_REASON_MESH_CHAN_REGULATORY 65
+#define WLAN_REASON_MESH_CHAN 66
+#define WLAN_REASON_SA_QUERY_TIMEOUT 65532
 #define WLAN_REASON_ACTIVE_ROAM 65533
 #define WLAN_REASON_JOIN_WRONG_CHANNEL       65534
 #define WLAN_REASON_EXPIRATION_CHK 65535
 
+#define WLAN_REASON_IS_PRIVATE(reason) ( \
+	reason == WLAN_REASON_EXPIRATION_CHK \
+	|| reason == WLAN_REASON_JOIN_WRONG_CHANNEL \
+	|| reason == WLAN_REASON_ACTIVE_ROAM \
+	|| reason == WLAN_REASON_SA_QUERY_TIMEOUT \
+	)
+
 /* Information Element IDs */
 #define WLAN_EID_SSID 0
 #define WLAN_EID_SUPP_RATES 1
@@ -670,6 +768,15 @@ struct ieee80211_snap_hdr {
 #define WLAN_EID_20_40_BSS_INTOLERANT 73
 #define WLAN_EID_OVERLAPPING_BSS_SCAN_PARAMS 74
 #define WLAN_EID_MMIE 76
+#define WLAN_EID_MESH_CONFIG 113
+#define WLAN_EID_MESH_ID 114
+#define WLAN_EID_MPM 117
+#define	WLAN_EID_RANN 126
+#define	WLAN_EID_PREQ 130
+#define	WLAN_EID_PREP 131
+#define	WLAN_EID_PERR 132
+#define WLAN_EID_AMPE 139
+#define WLAN_EID_MIC 140
 #define WLAN_EID_VENDOR_SPECIFIC 221
 #define WLAN_EID_GENERIC (WLAN_EID_VENDOR_SPECIFIC)
 #define WLAN_EID_VHT_CAPABILITY 191
@@ -1099,11 +1206,8 @@ struct ieee80211_softmac_stats {
 
 #define WEP_KEYS 4
 #define WEP_KEY_LEN 13
-
-#ifdef CONFIG_IEEE80211W
-	#define BIP_MAX_KEYID 5
-	#define BIP_AAD_SIZE  20
-#endif /* CONFIG_IEEE80211W */
+#define BIP_MAX_KEYID 5
+#define BIP_AAD_SIZE  20
 
 #if defined(PLATFORM_LINUX) || defined(CONFIG_RTL8711FW)
 
@@ -1544,12 +1648,27 @@ enum rtw_ieee80211_category {
 	RTW_WLAN_CATEGORY_WNM = 10,
 	RTW_WLAN_CATEGORY_UNPROTECTED_WNM = 11, /* add for CONFIG_IEEE80211W, none 11w also can use */
 	RTW_WLAN_CATEGORY_TDLS = 12,
-	RTW_WLAN_CATEGORY_SELF_PROTECTED = 15, /* add for CONFIG_IEEE80211W, none 11w also can use */
+	RTW_WLAN_CATEGORY_MESH = 13,
+	RTW_WLAN_CATEGORY_MULTIHOP = 14,
+	RTW_WLAN_CATEGORY_SELF_PROTECTED = 15,
 	RTW_WLAN_CATEGORY_WMM = 17,
 	RTW_WLAN_CATEGORY_VHT = 21,
 	RTW_WLAN_CATEGORY_P2P = 0x7f,/* P2P action frames */
 };
 
+#define CATEGORY_IS_GROUP_PRIVACY(cat) \
+	(cat == RTW_WLAN_CATEGORY_MESH || cat == RTW_WLAN_CATEGORY_MULTIHOP)
+
+#define CATEGORY_IS_NON_ROBUST(cat) \
+	(cat == RTW_WLAN_CATEGORY_PUBLIC \
+	|| cat == RTW_WLAN_CATEGORY_HT \
+	|| cat == RTW_WLAN_CATEGORY_UNPROTECTED_WNM \
+	|| cat == RTW_WLAN_CATEGORY_SELF_PROTECTED \
+	|| cat == RTW_WLAN_CATEGORY_VHT \
+	|| cat == RTW_WLAN_CATEGORY_P2P)
+
+#define CATEGORY_IS_ROBUST(cat) !CATEGORY_IS_NON_ROBUST(cat)
+
 /* SPECTRUM_MGMT action code */
 enum rtw_ieee80211_spectrum_mgmt_actioncode {
 	RTW_WLAN_ACTION_SPCT_MSR_REQ = 0,
@@ -1560,6 +1679,32 @@ enum rtw_ieee80211_spectrum_mgmt_actioncode {
 	RTW_WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,
 };
 
+/* SELF_PROTECTED action code */
+enum rtw_ieee80211_self_protected_actioncode {
+	RTW_ACT_SELF_PROTECTED_RSVD = 0,
+	RTW_ACT_SELF_PROTECTED_MESH_OPEN = 1,
+	RTW_ACT_SELF_PROTECTED_MESH_CONF = 2,
+	RTW_ACT_SELF_PROTECTED_MESH_CLOSE = 3,
+	RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM = 4,
+	RTW_ACT_SELF_PROTECTED_MESH_GK_ACK = 5,
+	RTW_ACT_SELF_PROTECTED_NUM,
+};
+
+/* MESH action code */
+enum rtw_ieee80211_mesh_actioncode {
+	RTW_ACT_MESH_LINK_METRIC_REPORT,
+	RTW_ACT_MESH_HWMP_PATH_SELECTION,
+	RTW_ACT_MESH_GATE_ANNOUNCEMENT,
+	RTW_ACT_MESH_CONGESTION_CONTROL_NOTIFICATION,
+	RTW_ACT_MESH_MCCA_SETUP_REQUEST,
+	RTW_ACT_MESH_MCCA_SETUP_REPLY,
+	RTW_ACT_MESH_MCCA_ADVERTISEMENT_REQUEST,
+	RTW_ACT_MESH_MCCA_ADVERTISEMENT,
+	RTW_ACT_MESH_MCCA_TEARDOWN,
+	RTW_ACT_MESH_TBTT_ADJUSTMENT_REQUEST,
+	RTW_ACT_MESH_TBTT_ADJUSTMENT_RESPONSE,
+};
+
 enum _PUBLIC_ACTION {
 	ACT_PUBLIC_BSSCOEXIST = 0, /* 20/40 BSS Coexistence */
 	ACT_PUBLIC_DSE_ENABLE = 1,
@@ -1644,14 +1789,22 @@ enum rtw_ieee80211_vht_actioncode {
 #ifdef CONFIG_RTW_80211R
 enum rtw_ieee80211_ft_actioncode {
 	RTW_WLAN_ACTION_FT_RESV,
-	RTW_WLAN_ACTION_FT_REQUEST,
-	RTW_WLAN_ACTION_FT_RESPONSE,
-	RTW_WLAN_ACTION_FT_CONFIRM,
+	RTW_WLAN_ACTION_FT_REQ,
+	RTW_WLAN_ACTION_FT_RSP,
+	RTW_WLAN_ACTION_FT_CONF,
 	RTW_WLAN_ACTION_FT_ACK,
 	RTW_WLAN_ACTION_FT_MAX,
 };
 #endif
 
+#ifdef CONFIG_RTW_WNM
+enum rtw_ieee80211_wnm_actioncode {
+	RTW_WLAN_ACTION_WNM_BTM_QUERY = 6,
+	RTW_WLAN_ACTION_WNM_BTM_REQ = 7,
+	RTW_WLAN_ACTION_WNM_BTM_RSP = 8,
+};
+#endif
+
 #define OUI_MICROSOFT 0x0050f2 /* Microsoft (also used in Wi-Fi specs)
 				* 00:50:F2 */
 #ifndef PLATFORM_FREEBSD /* Baron BSD has defined */
@@ -1679,6 +1832,55 @@ enum rtw_ieee80211_ft_actioncode {
 
 #define VENDOR_HT_CAPAB_OUI_TYPE 0x33 /* 00-90-4c:0x33 */
 
+enum rtw_ieee80211_rann_flags {
+	RTW_RANN_FLAG_IS_GATE = 1 << 0,
+};
+
+/**
+ * enum rtw_ieee80211_preq_flags - mesh PREQ element flags
+ *
+ * @RTW_IEEE80211_PREQ_IS_GATE_FLAG: Gate Announcement subfield
+ * @RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG: proactive PREP subfield
+ */
+enum rtw_ieee80211_preq_flags {
+	RTW_IEEE80211_PREQ_IS_GATE_FLAG = 1 << 0,
+	RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG	= 1 << 2,
+};
+
+/**
+ * enum rtw_ieee80211_preq_target_flags - mesh PREQ element per target flags
+ *
+ * @RTW_IEEE80211_PREQ_TO_FLAG: target only subfield
+ * @RTW_IEEE80211_PREQ_USN_FLAG: unknown target HWMP sequence number subfield
+ */
+enum rtw_ieee80211_preq_target_flags {
+	RTW_IEEE80211_PREQ_TO_FLAG	= 1<<0,
+	RTW_IEEE80211_PREQ_USN_FLAG	= 1<<2,
+};
+
+/**
+ * enum rtw_ieee80211_root_mode_identifier - root mesh STA mode identifier
+ *
+ * These attribute are used by dot11MeshHWMPRootMode to set root mesh STA mode
+ *
+ * @RTW_IEEE80211_ROOTMODE_NO_ROOT: the mesh STA is not a root mesh STA (default)
+ * @RTW_IEEE80211_ROOTMODE_ROOT: the mesh STA is a root mesh STA if greater than
+ *	this value
+ * @RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP: the mesh STA is a root mesh STA supports
+ *	the proactive PREQ with proactive PREP subfield set to 0
+ * @RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP: the mesh STA is a root mesh STA
+ *	supports the proactive PREQ with proactive PREP subfield set to 1
+ * @RTW_IEEE80211_PROACTIVE_RANN: the mesh STA is a root mesh STA supports
+ *	the proactive RANN
+ */
+enum rtw_ieee80211_root_mode_identifier {
+	RTW_IEEE80211_ROOTMODE_NO_ROOT = 0,
+	RTW_IEEE80211_ROOTMODE_ROOT = 1,
+	RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP = 2,
+	RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP = 3,
+	RTW_IEEE80211_PROACTIVE_RANN = 4,
+};
+
 /**
  * enum rtw_ieee80211_channel_flags - channel flags
  *
@@ -1803,6 +2005,16 @@ struct rtw_ieee802_11_elems {
 	u8 vht_op_mode_notify_len;
 	u8 *rm_en_cap;
 	u8 rm_en_cap_len;
+#ifdef CONFIG_RTW_MESH
+	u8 *preq;
+	u8 preq_len;
+	u8 *prep;
+	u8 prep_len;
+	u8 *perr;
+	u8 perr_len;
+	u8 *rann;
+	u8 rann_len;
+#endif
 };
 
 typedef enum { ParseOK = 0, ParseUnknown = 1, ParseFailed = -1 } ParseRes;
@@ -1812,7 +2024,7 @@ ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
 				int show_errors);
 
 u8 *rtw_set_fixed_ie(unsigned char *pbuf, unsigned int len, unsigned char *source, unsigned int *frlen);
-u8 *rtw_set_ie(u8 *pbuf, sint index, uint len, u8 *source, uint *frlen);
+u8 *rtw_set_ie(u8 *pbuf, sint index, uint len, const u8 *source, uint *frlen);
 
 enum secondary_ch_offset {
 	SCN = 0, /* no secondary channel */
@@ -1825,25 +2037,48 @@ u8 *rtw_set_ie_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode, u8 new_ch, u8
 u8 *rtw_set_ie_secondary_ch_offset(u8 *buf, u32 *buf_len, u8 secondary_ch_offset);
 u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl, u8 flags, u16 reason, u16 precedence);
 
-u8 *rtw_get_ie(u8 *pbuf, sint index, sint *len, sint limit);
-u8 *rtw_get_ie_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len, u8 *ie, uint *ielen);
+u8 *rtw_get_ie(const u8 *pbuf, sint index, sint *len, sint limit);
+int rtw_remove_ie_g_rate(u8 *ie, uint *ie_len, uint offset, u8 eid);
+u8 *rtw_get_ie_ex(const u8 *in_ie, uint in_len, u8 eid, const u8 *oui, u8 oui_len, u8 *ie, uint *ielen);
 int rtw_ies_remove_ie(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 oui_len);
 
 void rtw_set_supported_rate(u8 *SupportedRates, uint mode) ;
 
+#define GET_RSN_CAP_MFP_OPTION(cap)	LE_BITS_TO_2BYTE(((u8 *)(cap)), 6, 2)
+
+#define MFP_NO			0
+#define MFP_INVALID		1
+#define MFP_OPTIONAL	2
+#define MFP_REQUIRED	3
+
+struct rsne_info {
+	u8 *gcs;
+	u16 pcs_cnt;
+	u8 *pcs_list;
+	u16 akm_cnt;
+	u8 *akm_list;
+	u8 *cap;
+	u16 pmkid_cnt;
+	u8 *pmkid_list;
+	u8 *gmcs;
+
+	u8 err;
+};
+int rtw_rsne_info_parse(const u8 *ie, uint ie_len, struct rsne_info *info);
+
 unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit);
 unsigned char *rtw_get_wpa2_ie(unsigned char *pie, int *rsn_ie_len, int limit);
 int rtw_get_wpa_cipher_suite(u8 *s);
 int rtw_get_wpa2_cipher_suite(u8 *s);
 int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len);
 int rtw_parse_wpa_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
-int rtw_parse_wpa2_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
+int rtw_parse_wpa2_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x, u8 *mfp_opt);
 
 int rtw_get_sec_ie(u8 *in_ie, uint in_len, u8 *rsn_ie, u16 *rsn_len, u8 *wpa_ie, u16 *wpa_len);
 
 u8 rtw_is_wps_ie(u8 *ie_ptr, uint *wps_ielen);
 u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, enum bss_type frame_type);
-u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen);
+u8 *rtw_get_wps_ie(const u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen);
 u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_attr, u32 *len_attr);
 u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_content, uint *len_content);
 
@@ -1856,17 +2091,21 @@ u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8
 #define for_each_ie(ie, buf, buf_len) \
 	for (ie = (void *)buf; (((u8 *)ie) - ((u8 *)buf) + 1) < buf_len; ie = (void *)(((u8 *)ie) + *(((u8 *)ie)+1) + 2))
 
-void dump_ies(void *sel, u8 *buf, u32 buf_len);
+void dump_ies(void *sel, const u8 *buf, u32 buf_len);
 
 #ifdef CONFIG_80211N_HT
-void dump_ht_cap_ie_content(void *sel, u8 *buf, u32 buf_len);
+#define HT_SC_OFFSET_MAX 4
+extern const char *const _ht_sc_offset_str[];
+#define ht_sc_offset_str(sc) (((sc) >= HT_SC_OFFSET_MAX) ? _ht_sc_offset_str[2] : _ht_sc_offset_str[(sc)])
+
+void dump_ht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len);
 #endif
 
-void dump_wps_ie(void *sel, u8 *ie, u32 ie_len);
+void dump_wps_ie(void *sel, const u8 *ie, u32 ie_len);
 
-void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset);
+void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht);
 
-void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset);
+void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht);
 
 bool rtw_is_chbw_grouped(u8 ch_a, u8 bw_a, u8 offset_a
 	, u8 ch_b, u8 bw_b, u8 offset_b);
@@ -1875,8 +2114,8 @@ void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
 
 u32 rtw_get_p2p_merged_ies_len(u8 *in_ie, u32 in_len);
 int rtw_p2p_merge_ies(u8 *in_ie, u32 in_len, u8 *merge_ie);
-void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len);
-u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen);
+void dump_p2p_ie(void *sel, const u8 *ie, u32 ie_len);
+u8 *rtw_get_p2p_ie(const u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen);
 u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr);
 u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content);
 u32 rtw_set_p2p_attr_content(u8 *pbuf, u8 attr_id, u16 attr_len, u8 *pdata_attr);
@@ -1886,8 +2125,8 @@ u8 *rtw_bss_ex_get_p2p_ie(WLAN_BSSID_EX *bss_ex, u8 *p2p_ie, uint *p2p_ielen);
 void rtw_bss_ex_del_p2p_ie(WLAN_BSSID_EX *bss_ex);
 void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id);
 
-void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len);
-u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen);
+void dump_wfd_ie(void *sel, const u8 *ie, u32 ie_len);
+u8 *rtw_get_wfd_ie(const u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen);
 u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr);
 u8 *rtw_get_wfd_attr_content(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content);
 uint rtw_del_wfd_ie(u8 *ies, uint ies_len_ori, const char *msg);
@@ -1906,7 +2145,7 @@ int rtw_get_bit_value_from_ieee_value(u8 val);
 uint	rtw_is_cckrates_included(u8 *rate);
 
 uint	rtw_is_cckratesonly_included(u8 *rate);
-
+uint rtw_get_cckrate_size(u8 *rate,u32 rate_length);
 int rtw_check_network_type(unsigned char *rate, int ratelen, int channel);
 
 void rtw_get_bcn_info(struct wlan_network *pnetwork);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211_ext.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211_ext.h
index 94a8e582d151..3008777dac11 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211_ext.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ieee80211_ext.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/if_ether.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/if_ether.h
index a3007c4ab22d..335233b55272 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/if_ether.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/if_ether.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ip.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ip.h
index 4feb98fb072a..339e23d50d1d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ip.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/ip.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/linux/wireless.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/linux/wireless.h
index c7f4a6c9b66a..acaa37384089 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/linux/wireless.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/linux/wireless.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mlme_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mlme_osdep.h
index 7669fb319c38..29b8426c59ac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mlme_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mlme_osdep.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -15,11 +16,6 @@
 #ifndef	__MLME_OSDEP_H_
 #define __MLME_OSDEP_H_
 
-
-#if defined(PLATFORM_WINDOWS) || defined(PLATFORM_MPIXEL)
-	extern int time_after(systime now, systime old);
-#endif
-
 extern void rtw_os_indicate_disconnect(_adapter *adapter, u16 reason, u8 locally_generated);
 extern void rtw_os_indicate_connect(_adapter *adapter);
 void rtw_os_indicate_scan_done(_adapter *padapter, bool aborted);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mp_custom_oid.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mp_custom_oid.h
index 8ed14413c62d..51146ef49446 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mp_custom_oid.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/mp_custom_oid.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/nic_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/nic_spec.h
index 913ef9ba801a..5e66f6c82b3b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/nic_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/nic_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_intf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_intf.h
index 7be08808d34f..fcd5c972e3fc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_intf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_intf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service.h
index 6cea063d72ad..d5d94b81a880 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -24,6 +25,9 @@
 #define RTW_RBUF_UNAVAIL		5
 #define RTW_RBUF_PKT_UNAVAIL	6
 #define RTW_SDIO_READ_PORT_FAIL	7
+#define RTW_ALREADY				8
+#define RTW_RA_RESOLVING		9
+#define RTW_BMC_NO_NEED			10
 
 /* #define RTW_STATUS_TIMEDOUT -110 */
 
@@ -137,12 +141,13 @@ typedef enum mstat_status {
 #ifdef DBG_MEM_ALLOC
 void rtw_mstat_update(const enum mstat_f flags, const MSTAT_STATUS status, u32 sz);
 void rtw_mstat_dump(void *sel);
-u8 *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-u8 *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-void dbg_rtw_vmfree(u8 *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
-u8 *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-u8 *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
-void dbg_rtw_mfree(u8 *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
+bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size);
+void *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_vmfree(void *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
+void *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line);
+void dbg_rtw_mfree(void *pbuf, const enum mstat_f flags, u32 sz, const char *func, const int line);
 
 struct sk_buff *dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, const int line);
 void dbg_rtw_skb_free(struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line);
@@ -209,12 +214,13 @@ void dbg_rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dm
 #else /* DBG_MEM_ALLOC */
 #define rtw_mstat_update(flag, status, sz) do {} while (0)
 #define rtw_mstat_dump(sel) do {} while (0)
-u8 *_rtw_vmalloc(u32 sz);
-u8 *_rtw_zvmalloc(u32 sz);
-void	_rtw_vmfree(u8 *pbuf, u32 sz);
-u8 *_rtw_zmalloc(u32 sz);
-u8 *_rtw_malloc(u32 sz);
-void	_rtw_mfree(u8 *pbuf, u32 sz);
+#define match_mstat_sniff_rules(flags, size) _FALSE
+void *_rtw_vmalloc(u32 sz);
+void *_rtw_zvmalloc(u32 sz);
+void _rtw_vmfree(void *pbuf, u32 sz);
+void *_rtw_zmalloc(u32 sz);
+void *_rtw_malloc(u32 sz);
+void _rtw_mfree(void *pbuf, u32 sz);
 
 struct sk_buff *_rtw_skb_alloc(u32 sz);
 void _rtw_skb_free(struct sk_buff *skb);
@@ -284,6 +290,7 @@ extern void	*rtw_malloc2d(int h, int w, size_t size);
 extern void	rtw_mfree2d(void *pbuf, int h, int w, int size);
 
 void rtw_os_pkt_free(_pkt *pkt);
+_pkt *rtw_os_pkt_copy(_pkt *pkt);
 void *rtw_os_pkt_data(_pkt *pkt);
 u32 rtw_os_pkt_len(_pkt *pkt);
 
@@ -296,10 +303,20 @@ extern void	_rtw_init_listhead(_list *list);
 extern u32	rtw_is_list_empty(_list *phead);
 extern void	rtw_list_insert_head(_list *plist, _list *phead);
 extern void	rtw_list_insert_tail(_list *plist, _list *phead);
+void rtw_list_splice(_list *list, _list *head);
+void rtw_list_splice_init(_list *list, _list *head);
+void rtw_list_splice_tail(_list *list, _list *head);
+
 #ifndef PLATFORM_FREEBSD
 extern void	rtw_list_delete(_list *plist);
 #endif /* PLATFORM_FREEBSD */
 
+void rtw_hlist_head_init(rtw_hlist_head *h);
+void rtw_hlist_add_head(rtw_hlist_node *n, rtw_hlist_head *h);
+void rtw_hlist_del(rtw_hlist_node *n);
+void rtw_hlist_add_head_rcu(rtw_hlist_node *n, rtw_hlist_head *h);
+void rtw_hlist_del_rcu(rtw_hlist_node *n);
+
 extern void	_rtw_init_sema(_sema *sema, int init_val);
 extern void	_rtw_free_sema(_sema	*sema);
 extern void	_rtw_up_sema(_sema	*sema);
@@ -323,21 +340,32 @@ extern u32	rtw_end_of_queue_search(_list *queue, _list *pelement);
 extern systime _rtw_get_current_time(void);
 extern u32	_rtw_systime_to_ms(systime stime);
 extern systime _rtw_ms_to_systime(u32 ms);
+extern systime _rtw_us_to_systime(u32 us);
 extern s32	_rtw_get_passing_time_ms(systime start);
+extern s32 _rtw_get_remaining_time_ms(systime end);
 extern s32	_rtw_get_time_interval_ms(systime start, systime end);
+extern bool _rtw_time_after(systime a, systime b);
 
 #ifdef DBG_SYSTIME
 #define rtw_get_current_time() ({systime __stime = _rtw_get_current_time(); __stime;})
 #define rtw_systime_to_ms(stime) ({u32 __ms = _rtw_systime_to_ms(stime); typecheck(systime, stime); __ms;})
 #define rtw_ms_to_systime(ms) ({systime __stime = _rtw_ms_to_systime(ms); __stime;})
+#define rtw_us_to_systime(us) ({systime __stime = _rtw_us_to_systime(us); __stime;})
 #define rtw_get_passing_time_ms(start) ({u32 __ms = _rtw_get_passing_time_ms(start); typecheck(systime, start); __ms;})
+#define rtw_get_remaining_time_ms(end) ({u32 __ms = _rtw_get_remaining_time_ms(end); typecheck(systime, end); __ms;})
 #define rtw_get_time_interval_ms(start, end) ({u32 __ms = _rtw_get_time_interval_ms(start, end); typecheck(systime, start); typecheck(systime, end); __ms;})
+#define rtw_time_after(a,b) ({bool __r = _rtw_time_after(a,b); typecheck(systime, a); typecheck(systime, b); __r;})
+#define rtw_time_before(a,b) ({bool __r = _rtw_time_after(b, a); typecheck(systime, a); typecheck(systime, b); __r;})
 #else
 #define rtw_get_current_time() _rtw_get_current_time()
 #define rtw_systime_to_ms(stime) _rtw_systime_to_ms(stime)
 #define rtw_ms_to_systime(ms) _rtw_ms_to_systime(ms)
+#define rtw_us_to_systime(us) _rtw_us_to_systime(us)
 #define rtw_get_passing_time_ms(start) _rtw_get_passing_time_ms(start)
+#define rtw_get_remaining_time_ms(end) _rtw_get_remaining_time_ms(end)
 #define rtw_get_time_interval_ms(start, end) _rtw_get_time_interval_ms(start, end)
+#define rtw_time_after(a,b) _rtw_time_after(a,b)
+#define rtw_time_before(a,b) _rtw_time_after(b,a)
 #endif
 
 extern void	rtw_sleep_schedulable(int ms);
@@ -551,6 +579,7 @@ static inline int largest_bit(u32 bitmask)
 	return i;
 }
 
+#define rtw_abs(a) (a < 0 ? -a : a)
 #define rtw_min(a, b) ((a > b) ? b : a)
 #define rtw_is_range_a_in_b(hi_a, lo_a, hi_b, lo_b) (((hi_a) <= (hi_b)) && ((lo_a) >= (lo_b)))
 #define rtw_is_range_overlap(hi_a, lo_a, hi_b, lo_b) (((hi_a) > (lo_b)) && ((lo_a) < (hi_b)))
@@ -562,16 +591,14 @@ static inline int largest_bit(u32 bitmask)
 #define MAC_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5]
 #endif
 
+bool rtw_macaddr_is_larger(const u8 *a, const u8 *b);
 
 extern void rtw_suspend_lock_init(void);
 extern void rtw_suspend_lock_uninit(void);
 extern void rtw_lock_suspend(void);
 extern void rtw_unlock_suspend(void);
 extern void rtw_lock_suspend_timeout(u32 timeout_ms);
-extern void rtw_lock_ext_suspend_timeout(u32 timeout_ms);
-extern void rtw_lock_rx_suspend_timeout(u32 timeout_ms);
 extern void rtw_lock_traffic_suspend_timeout(u32 timeout_ms);
-extern void rtw_lock_resume_scan_timeout(u32 timeout_ms);
 extern void rtw_resume_lock_suspend(void);
 extern void rtw_resume_unlock_suspend(void);
 #ifdef CONFIG_AP_WOWLAN
@@ -579,6 +606,10 @@ extern void rtw_softap_lock_suspend(void);
 extern void rtw_softap_unlock_suspend(void);
 #endif
 
+extern void rtw_set_bit(int nr, unsigned long *addr);
+extern void rtw_clear_bit(int nr, unsigned long *addr);
+extern int rtw_test_and_clear_bit(int nr, unsigned long *addr);
+
 extern void ATOMIC_SET(ATOMIC_T *v, int i);
 extern int ATOMIC_READ(ATOMIC_T *v);
 extern void ATOMIC_ADD(ATOMIC_T *v, int i);
@@ -589,6 +620,7 @@ extern int ATOMIC_ADD_RETURN(ATOMIC_T *v, int i);
 extern int ATOMIC_SUB_RETURN(ATOMIC_T *v, int i);
 extern int ATOMIC_INC_RETURN(ATOMIC_T *v);
 extern int ATOMIC_DEC_RETURN(ATOMIC_T *v);
+extern bool ATOMIC_INC_UNLESS(ATOMIC_T *v, int u);
 
 /* File operation APIs, just for linux now */
 extern int rtw_is_file_readable(const char *path);
@@ -671,6 +703,17 @@ extern u32 rtw_random32(void);
 			 (((u64) (a)[5]) << 40) | (((u64) (a)[4]) << 32) | \
 			 (((u64) (a)[3]) << 24) | (((u64) (a)[2]) << 16) | \
 			 (((u64) (a)[1]) << 8) | ((u64) (a)[0]))
+#define RTW_PUT_LE64(a, val)					\
+	do {							\
+		(a)[7] = (u8) ((((u64) (val)) >> 56) & 0xff);	\
+		(a)[6] = (u8) ((((u64) (val)) >> 48) & 0xff);	\
+		(a)[5] = (u8) ((((u64) (val)) >> 40) & 0xff);	\
+		(a)[4] = (u8) ((((u64) (val)) >> 32) & 0xff);	\
+		(a)[3] = (u8) ((((u64) (val)) >> 24) & 0xff);	\
+		(a)[2] = (u8) ((((u64) (val)) >> 16) & 0xff);	\
+		(a)[1] = (u8) ((((u64) (val)) >> 8) & 0xff);	\
+		(a)[0] = (u8) (((u64) (val)) & 0xff);		\
+	} while (0)
 
 void rtw_buf_free(u8 **buf, u32 *buf_len);
 void rtw_buf_update(u8 **buf, u32 *buf_len, u8 *src, u32 src_len);
@@ -714,6 +757,18 @@ struct map_t {
 int map_readN(const struct map_t *map, u16 offset, u16 len, u8 *buf);
 u8 map_read8(const struct map_t *map, u16 offset);
 
+struct blacklist_ent {
+	_list list;
+	u8 addr[ETH_ALEN];
+	systime exp_time;
+};
+
+int rtw_blacklist_add(_queue *blist, const u8 *addr, u32 timeout_ms);
+int rtw_blacklist_del(_queue *blist, const u8 *addr);
+int rtw_blacklist_search(_queue *blist, const u8 *addr);
+void rtw_blacklist_flush(_queue *blist);
+void dump_blacklist(void *sel, _queue *blist, const char *title);
+
 /* String handler */
 
 BOOLEAN is_null(char c);
@@ -724,6 +779,10 @@ BOOLEAN IsHexDigit(char chTmp);
 BOOLEAN is_alpha(char chTmp);
 char alpha_to_upper(char c);
 
+int hex2num_i(char c);
+int hex2byte_i(const char *hex);
+int hexstr2bin(const char *hex, u8 *buf, size_t len);
+
 /*
  * Write formatted output to sized buffer
  */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_bsd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_bsd.h
index 20c14d77a2b9..cdadd2ca9b98 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_bsd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_bsd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -77,7 +78,7 @@
 //	typedef	spinlock_t	_lock;
 	typedef	struct mtx	_lock;
 	typedef struct mtx 		_mutex;
-	typedef struct timer_list _timer;
+	typedef struct rtw_timer_list _timer;
 	struct list_head {
 	struct list_head *next, *prev;
 	};
@@ -128,7 +129,7 @@
  * See (linux_compat) processes.c
  *
  */
-struct timer_list {
+struct rtw_timer_list {
 	struct callout callout;
 	void (*function)(void *);
 	void *arg;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_ce.h
index bc920c08e942..e9b408a785ba 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_ce.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -40,7 +41,7 @@ typedef u32	_irqL;
 
 typedef NDIS_HANDLE  _nic_hdl;
 
-struct timer_list {
+struct rtw_timer_list {
 	NDIS_MINIPORT_TIMER ndis_timer;
 	void (*function)(void *);
 	void *arg;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_linux.h
index f52dd4255455..6d2854a0ddb0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_linux.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -93,10 +94,6 @@
 	#include <net/cfg80211.h>
 #endif /* CONFIG_IOCTL_CFG80211 */
 
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
-	#include <linux/in.h>
-	#include <linux/udp.h>
-#endif
 
 #ifdef CONFIG_HAS_EARLYSUSPEND
 	#include <linux/earlysuspend.h>
@@ -160,7 +157,13 @@ typedef	spinlock_t	_lock;
 #else
 	typedef struct semaphore	_mutex;
 #endif
-typedef struct timer_list _timer;
+struct rtw_timer_list {
+	struct timer_list timer;
+	void (*function)(void *);
+	void *arg;
+};
+
+typedef struct rtw_timer_list _timer;
 typedef struct completion _completion;
 
 struct	__queue	{
@@ -173,6 +176,25 @@ typedef unsigned char	_buffer;
 
 typedef struct	__queue	_queue;
 typedef struct	list_head	_list;
+
+/* hlist */
+typedef struct	hlist_head	rtw_hlist_head;
+typedef struct	hlist_node	rtw_hlist_node;
+
+/* RCU */
+typedef struct rcu_head rtw_rcu_head;
+#define rtw_rcu_dereference(p) rcu_dereference((p))
+#define rtw_rcu_dereference_protected(p, c) rcu_dereference_protected(p, c)
+#define rtw_rcu_assign_pointer(p, v) rcu_assign_pointer((p), (v))
+#define rtw_rcu_read_lock() rcu_read_lock()
+#define rtw_rcu_read_unlock() rcu_read_unlock()
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 34))
+#define rtw_rcu_access_pointer(p) rcu_access_pointer(p)
+#endif
+
+/* rhashtable */
+#include "../os_dep/linux/rtw_rhashtable.h"
+
 typedef	int	_OS_STATUS;
 /* typedef u32	_irqL; */
 typedef unsigned long _irqL;
@@ -220,20 +242,31 @@ static inline unsigned char *skb_end_pointer(const struct sk_buff *skb)
 }
 #endif
 
-__inline static _list *get_next(_list	*list)
+__inline static void rtw_list_delete(_list *plist)
 {
-	return list->next;
+	list_del_init(plist);
 }
 
-__inline static _list	*get_list_head(_queue	*queue)
+__inline static _list *get_next(_list	*list)
 {
-	return &(queue->queue);
+	return list->next;
 }
 
-
 #define LIST_CONTAINOR(ptr, type, member) \
 	((type *)((char *)(ptr)-(SIZE_T)(&((type *)0)->member)))
 
+#define rtw_list_first_entry(ptr, type, member) list_first_entry(ptr, type, member)
+
+#define rtw_hlist_for_each_entry(pos, head, member) hlist_for_each_entry(pos, head, member)
+#define rtw_hlist_for_each_safe(pos, n, head) hlist_for_each_safe(pos, n, head)
+#define rtw_hlist_entry(ptr, type, member) hlist_entry(ptr, type, member)
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+#define rtw_hlist_for_each_entry_safe(pos, np, n, head, member) hlist_for_each_entry_safe(pos, n, head, member)
+#define rtw_hlist_for_each_entry_rcu(pos, node, head, member) hlist_for_each_entry_rcu(pos, head, member)
+#else
+#define rtw_hlist_for_each_entry_safe(pos, np, n, head, member) hlist_for_each_entry_safe(pos, np, n, head, member)
+#define rtw_hlist_for_each_entry_rcu(pos, node, head, member) hlist_for_each_entry_rcu(pos, node, head, member)
+#endif
 
 __inline static void _enter_critical(_lock *plock, _irqL *pirqL)
 {
@@ -265,6 +298,16 @@ __inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)
 	spin_unlock_bh(plock);
 }
 
+__inline static void enter_critical_bh(_lock *plock)
+{
+	spin_lock_bh(plock);
+}
+
+__inline static void exit_critical_bh(_lock *plock)
+{
+	spin_unlock_bh(plock);
+}
+
 __inline static int _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
 {
 	int ret = 0;
@@ -278,6 +321,17 @@ __inline static int _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)
 }
 
 
+__inline static int _enter_critical_mutex_lock(_mutex *pmutex, _irqL *pirqL)
+{
+	int ret = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+	mutex_lock(pmutex);
+#else
+	down(pmutex);
+#endif
+	return ret;
+}
+
 __inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
 {
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
@@ -287,27 +341,48 @@ __inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)
 #endif
 }
 
-__inline static void rtw_list_delete(_list *plist)
+__inline static _list	*get_list_head(_queue	*queue)
 {
-	list_del_init(plist);
+	return &(queue->queue);
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+static inline void timer_hdl(struct timer_list *in_timer)
+#else
+static inline void timer_hdl(unsigned long cntx)
+#endif
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+	_timer *ptimer = from_timer(ptimer, in_timer, timer);
+#else
+	_timer *ptimer = (_timer *)cntx;
+#endif
+	ptimer->function(ptimer->arg);
 }
 
 __inline static void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)
 {
-	/* setup_timer(ptimer, pfunc,(u32)cntx);	 */
 	ptimer->function = pfunc;
-	ptimer->data = (unsigned long)cntx;
-	init_timer(ptimer);
+	ptimer->arg = cntx;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+	timer_setup(&ptimer->timer, timer_hdl, 0);
+#else
+	/* setup_timer(ptimer, pfunc,(u32)cntx);	 */
+	ptimer->timer.function = timer_hdl;
+	ptimer->timer.data = (unsigned long)ptimer;
+	init_timer(&ptimer->timer);
+#endif
 }
 
 __inline static void _set_timer(_timer *ptimer, u32 delay_time)
 {
-	mod_timer(ptimer , (jiffies + (delay_time * HZ / 1000)));
+	mod_timer(&ptimer->timer , (jiffies + (delay_time * HZ / 1000)));
 }
 
 __inline static void _cancel_timer(_timer *ptimer, u8 *bcancelled)
 {
-	*bcancelled = del_timer_sync(ptimer) == 1 ? 1 : 0;
+	*bcancelled = del_timer_sync(&ptimer->timer) == 1 ? 1 : 0;
 }
 
 static inline void _init_workitem(_workitem *pwork, void *pfunc, void *cntx)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_xp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_xp.h
index fdbdb5095fce..50d2aa1c824d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_xp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/osdep_service_xp.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -40,7 +41,7 @@
 	// USB_PIPE for WINCE , but handle can be use just integer under windows
 	typedef NDIS_HANDLE  _nic_hdl;
 
-	struct timer_list {
+	struct rtw_timer_list {
 		NDIS_MINIPORT_TIMER ndis_timer;
 		void (*function)(void *);
 		void *arg;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_hal.h
index 16eac21f02a7..d2486fe0c9ef 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -27,6 +28,10 @@
 	void rtl8192ee_set_hal_ops(_adapter *padapter);
 #endif
 
+#if defined(CONFIG_RTL8192F)
+	void rtl8192fe_set_hal_ops(_adapter *padapter);
+#endif
+
 #ifdef CONFIG_RTL8723B
 	void rtl8723be_set_hal_ops(_adapter *padapter);
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_ops.h
index f195f5b4fafd..fa59add2c527 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_ops.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -25,6 +26,7 @@
 	void	rtl8188ee_recv_tasklet(void *priv);
 	void	rtl8188ee_prepare_bcn_tasklet(void *priv);
 	void	rtl8188ee_set_intf_ops(struct _io_ops	*pops);
+	void	rtw8188ee_unmap_beacon_icf(_adapter *padapter);
 #endif
 
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
@@ -36,6 +38,7 @@
 	void	rtl8812ae_recv_tasklet(void *priv);
 	void	rtl8812ae_prepare_bcn_tasklet(void *priv);
 	void	rtl8812ae_set_intf_ops(struct _io_ops	*pops);
+	void	rtw8812ae_unmap_beacon_icf(_adapter *padapter);
 #endif
 
 #ifdef CONFIG_RTL8192E
@@ -46,6 +49,19 @@
 	void	rtl8192ee_prepare_bcn_tasklet(void *priv);
 	int	rtl8192ee_interrupt(PADAPTER Adapter);
 	void	rtl8192ee_set_intf_ops(struct _io_ops	*pops);
+	void	rtw8192ee_unmap_beacon_icf(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8192F
+	u32	rtl8192fe_init_desc_ring(_adapter *padapter);
+	u32	rtl8192fe_free_desc_ring(_adapter *padapter);
+	void	rtl8192fe_reset_desc_ring(_adapter *padapter);
+	int	rtl8192fe_interrupt(PADAPTER Adapter);
+	void	rtl8192fe_recv_tasklet(void *priv);
+	void	rtl8192fe_prepare_bcn_tasklet(void *priv);
+	void	rtl8192fe_set_intf_ops(struct _io_ops	*pops);
+	u8 check_tx_desc_resource(_adapter *padapter, int prio);
+	void	rtl8192fe_unmap_beacon_icf(PADAPTER Adapter);
 #endif
 
 #ifdef CONFIG_RTL8723B
@@ -56,6 +72,7 @@
 	void	rtl8723be_recv_tasklet(void *priv);
 	void	rtl8723be_prepare_bcn_tasklet(void *priv);
 	void	rtl8723be_set_intf_ops(struct _io_ops	*pops);
+	void	rtl8723be_unmap_beacon_icf(PADAPTER Adapter);
 #endif
 
 #ifdef CONFIG_RTL8723D
@@ -67,6 +84,7 @@
 	void	rtl8723de_prepare_bcn_tasklet(void *priv);
 	void	rtl8723de_set_intf_ops(struct _io_ops	*pops);
 	u8 check_tx_desc_resource(_adapter *padapter, int prio);
+	void 	rtl8723de_unmap_beacon_icf(PADAPTER Adapter);
 #endif
 
 #ifdef CONFIG_RTL8814A
@@ -78,6 +96,7 @@
 	void	rtl8814ae_recv_tasklet(void *priv);
 	void	rtl8814ae_prepare_bcn_tasklet(void *priv);
 	void	rtl8814ae_set_intf_ops(struct _io_ops	*pops);
+	void	rtl8814ae_unmap_beacon_icf(PADAPTER Adapter);
 #endif
 
 #ifdef CONFIG_RTL8822B
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_osintf.h
index c6a0fddf651a..56d6942277f9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/pci_osintf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/recv_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/recv_osdep.h
index 58038e58afa5..7ff484c989b3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/recv_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/recv_osdep.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -21,6 +22,7 @@ extern void _rtw_free_recv_priv(struct recv_priv *precvpriv);
 
 
 extern s32  rtw_recv_entry(union recv_frame *precv_frame);
+void rtw_rframe_set_os_pkt(union recv_frame *rframe);
 extern int rtw_recv_indicatepkt(_adapter *adapter, union recv_frame *precv_frame);
 extern void rtw_recv_returnpacket(IN _nic_hdl cnxt, IN _pkt *preturnedpkt);
 
@@ -47,7 +49,7 @@ void rtw_os_free_recvframe(union recv_frame *precvframe);
 int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf);
 int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf);
 
-_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8 *pdata);
+_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, const u8 *da, const u8 *sa, u8 *msdu ,u16 msdu_len);
 void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, union recv_frame *rframe);
 
 void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf);
@@ -57,6 +59,9 @@ void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf);
 #include <linux/netdevice.h>	/* struct napi_struct */
 
 int rtw_recv_napi_poll(struct napi_struct *, int budget);
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+void dynamic_napi_th_chk (_adapter *adapter);
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
 #endif /* CONFIG_RTW_NAPI */
 #endif /* PLATFORM_LINUX */
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_cmd.h
index 99a9cba972b7..2f26184b79a8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -135,7 +136,6 @@ typedef struct _RSVDPAGE_LOC_88E {
 /* host message to firmware cmd */
 void rtl8188e_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8188e_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
-u8 rtl8188e_set_rssi_cmd(PADAPTER padapter, u8 *param);
 s32 FillH2CCmd_88E(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 /* u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period); */
 u8 GetTxBufferRsvdPageNum8188E(_adapter *padapter, bool wowlan);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_dm.h
index 501d3a9c6e2b..70ce157f54f3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_hal.h
index 23c435e8d090..143f8701345e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -128,16 +129,18 @@ typedef struct _RT_8188E_FIRMWARE_HDR {
 
 #define MAX_TX_REPORT_BUFFER_SIZE			0x0400 /* 1k */
 
+#define PAGE_SIZE_TX_88E PAGE_SIZE_128
 /* Note: We will divide number of page equally for each queue other than public queue!
  * 22k = 22528 bytes = 176 pages (@page =  128 bytes)
- * must reserved about 7 pages for LPS =>  176-7 = 169 (0xA9)
- * 2*BCN / 1*ps-poll / 1*null-data /1*prob_rsp /1*QOS null-data /1*BT QOS null-data  */
+ * BCN rsvd_page_num = MAX_BEACON_LEN / PAGE_SIZE_TX_88E
+ * 1 ps-poll / 1 null-data /1 prob_rsp /1 QOS null-data = 4 pages */
 
-#define BCNQ_PAGE_NUM_88E		0x09
+#define BCNQ_PAGE_NUM_88E		(MAX_BEACON_LEN / PAGE_SIZE_TX_88E + 4) /*0x09*/
 
 /* For WoWLan , more reserved page */
 #ifdef CONFIG_WOWLAN
-	#define WOWLAN_PAGE_NUM_88E	0x00
+	/* 1 ArpRsp + 2 NbrAdv + 2 NDPInfo + 1 RCI + 1 AOAC = 7 pages */
+	#define WOWLAN_PAGE_NUM_88E	0x07
 #else
 	#define WOWLAN_PAGE_NUM_88E	0x00
 #endif
@@ -283,7 +286,6 @@ BOOLEAN HalDetectPwrDownMode88E(PADAPTER Adapter);
 	void Hal_ReadRFGainOffset(PADAPTER pAdapter, u8 *hwinfo, BOOLEAN AutoLoadFail);
 #endif /*CONFIG_RF_POWER_TRIM*/
 
-void rtl8188e_init_default_value(_adapter *adapter);
 
 void InitBeaconParameters_8188e(_adapter *adapter);
 void SetBeaconRelatedRegisters8188E(PADAPTER padapter);
@@ -291,9 +293,6 @@ void SetBeaconRelatedRegisters8188E(PADAPTER padapter);
 void rtl8188e_set_hal_ops(struct hal_ops *pHalFunc);
 void init_hal_spec_8188e(_adapter *adapter);
 
-/* register */
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
-
 void rtl8188e_start_thread(_adapter *padapter);
 void rtl8188e_stop_thread(_adapter *padapter);
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_led.h
index ef054675024a..5d42f8013d01 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_recv.h
index 92425a859f5b..f82ca8b2ea88 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_rf.h
index f5c5fbdfd19f..58488beed640 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_spec.h
index 802659a5fd07..e87126e41ed6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_sreset.h
index f4ec2d88c327..7fa89af73715 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_xmit.h
index f625576608cb..790d334b9e09 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188e_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_cmd.h
index a198e33523d4..1dfce16acfe4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -113,7 +114,6 @@ enum h2c_cmd_8188F {
 #define SET_8188F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8188F_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#define SET_8188F_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8188F_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
@@ -178,7 +178,6 @@ enum h2c_cmd_8188F {
 /* host message to firmware cmd */
 void rtl8188f_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8188f_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
-void rtl8188f_set_rssi_cmd(PADAPTER padapter, u8 *param);
 void rtl8188f_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
 /* s32 rtl8188f_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
 void rtl8188f_set_FwPsTuneParam_cmd(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_dm.h
index 342ade9a515c..146490e88a04 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_hal.h
index 7aaead7ca35e..fcd93c2e40fe 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -104,18 +105,10 @@ typedef struct _RT_8188F_FIRMWARE_HDR {
 /* Note: We will divide number of page equally for each queue other than public queue! */
 
 /* For General Reserved Page Number(Beacon Queue is reserved page)
- * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
-#define BCNQ_PAGE_NUM_8188F		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-	#define BCNQ1_PAGE_NUM_8188F		0x08 /* 0x04 */
-#else
-	#define BCNQ1_PAGE_NUM_8188F		0x00
-#endif
+ * BCN rsvd_page_num = MAX_BEACON_LEN / PAGE_SIZE_TX_8188F,
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1, CTS-2-SELF / LTE QoS Null */
 
-#ifdef CONFIG_PNO_SUPPORT
-#undef BCNQ1_PAGE_NUM_8188F
-#define BCNQ1_PAGE_NUM_8188F		0x00 /* 0x04 */
-#endif
+#define BCNQ_PAGE_NUM_8188F		(MAX_BEACON_LEN / PAGE_SIZE_TX_8188F + 6) /*0x08*/
 
 /* For WoWLan , more reserved page
  * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt:1 ,PNO: 6
@@ -136,7 +129,7 @@ typedef struct _RT_8188F_FIRMWARE_HDR {
 #define AP_WOWLAN_PAGE_NUM_8188F	0x02
 #endif
 
-#define TX_TOTAL_PAGE_NUMBER_8188F	(0xFF - BCNQ_PAGE_NUM_8188F - BCNQ1_PAGE_NUM_8188F - WOWLAN_PAGE_NUM_8188F)
+#define TX_TOTAL_PAGE_NUMBER_8188F	(0xFF - BCNQ_PAGE_NUM_8188F - WOWLAN_PAGE_NUM_8188F)
 #define TX_PAGE_BOUNDARY_8188F		(TX_TOTAL_PAGE_NUMBER_8188F + 1)
 
 #define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8188F	TX_TOTAL_PAGE_NUMBER_8188F
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_led.h
index ef5d1a7761a8..67258fde0842 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_recv.h
index 6366b8105274..99acfa5aef89 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_rf.h
index bf4f5911751e..871ea98ffdc4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_spec.h
index 6e99acf24772..deb97ab4b152 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -150,18 +151,6 @@
 
 #define SDIO_REG_HCPWM1_8188F			0x0038
 
-/* indirect access */
-#define SDIO_REG_INDIRECT_REG_CFG_8188F		0x40
-#define SET_INDIRECT_REG_ADDR(_cmd, _addr)	SET_BITS_TO_LE_2BYTE(((u8 *)(_cmd)) + 0, 0, 16, (_addr))
-#define SET_INDIRECT_REG_SIZE_1BYTE(_cmd)	SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 0)
-#define SET_INDIRECT_REG_SIZE_2BYTE(_cmd)	SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 1)
-#define SET_INDIRECT_REG_SIZE_4BYTE(_cmd)	SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 0, 2, 2)
-#define SET_INDIRECT_REG_WRITE(_cmd)		SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 2, 1, 1)
-#define SET_INDIRECT_REG_READ(_cmd)			SET_BITS_TO_LE_1BYTE(((u8 *)(_cmd)) + 2, 3, 1, 1)
-#define GET_INDIRECT_REG_RDY(_cmd)			LE_BITS_TO_1BYTE(((u8 *)(_cmd)) + 2, 4, 1)
-
-#define SDIO_REG_INDIRECT_REG_DATA_8188F	0x44
-
 /* ****************************************************************************
  *	8188 Regsiter Bit and Content definition
  * **************************************************************************** */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_sreset.h
index fe56567e7396..bd0193b3ab4d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_xmit.h
index 069183d27459..de05b4ccfb29 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8188f_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -184,13 +185,15 @@
 #define SET_TX_DESC_ANTSEL_D_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
 
 /* Dword 7 */
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#ifdef CONFIG_PCI_HCI
 #define SET_TX_DESC_TX_BUFFER_SIZE_8188F(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
 #define SET_TX_DESC_TX_DESC_CHECKSUM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
 #endif
 #define SET_TX_DESC_USB_TXAGG_NUM_8188F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+#ifdef CONFIG_SDIO_HCI
 #define SET_TX_DESC_SDIO_TXSEQ_8188F(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
 #endif
 
@@ -301,9 +304,10 @@ thread_return rtl8188fs_xmit_thread(thread_context context);
 #endif
 
 #ifdef CONFIG_USB_HCI
+#ifdef CONFIG_XMIT_THREAD_MODE
 s32 rtl8188fu_xmit_buf_handler(PADAPTER padapter);
 #define hal_xmit_handler rtl8188fu_xmit_buf_handler
-
+#endif
 
 s32 rtl8188fu_init_xmit_priv(PADAPTER padapter);
 void rtl8188fu_free_xmit_priv(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_cmd.h
index 6aff7ea36771..e9ff31c3ef11 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
@@ -101,7 +102,6 @@ typedef struct _RSVDPAGE_LOC_92E {
 #define SET_8192E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8192E_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#define SET_8192E_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 #define GET_8192E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)						LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
 /* _P2P_PS_OFFLOAD */
@@ -116,7 +116,6 @@ typedef struct _RSVDPAGE_LOC_92E {
 /* host message to firmware cmd */
 void rtl8192e_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8192e_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
-u8 rtl8192e_set_rssi_cmd(PADAPTER padapter, u8 *param);
 s32 FillH2CCmd_8192E(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
 u8 GetTxBufferRsvdPageNum8192E(_adapter *padapter, bool wowlan);
 /* u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period); */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_dm.h
index 5f6ee4b0e61a..555faff59152 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_hal.h
index edd4040053a5..b9223bd97edd 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
@@ -121,10 +122,15 @@ typedef struct _RT_FIRMWARE_8192E {
 #endif
 #define MAX_RX_DMA_BUFFER_SIZE_8192E		(RX_DMA_SIZE_8192E-RX_DMA_RESERVED_SIZE_8192E)	/*RX 16K*/
 
+
+#define PAGE_SIZE_TX_92E	PAGE_SIZE_256
+
 /* For General Reserved Page Number(Beacon Queue is reserved page)
  * if (CONFIG_2BCN_EN) Beacon:4, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1
- * Beacon:2, PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1 */
-#define RSVD_PAGE_NUM_8192E		0x08
+ * Beacon: MAX_BEACON_LEN / PAGE_SIZE_TX_92E
+ * PS-Poll:1, Null Data:1,Prob Rsp:1,Qos Null Data:1,CTS-2-SELF / LTE QoS Null*/
+
+#define RSVD_PAGE_NUM_8192E		(MAX_BEACON_LEN / PAGE_SIZE_TX_92E + 6) /*0x08*/
 /* For WoWLan , more reserved page
  * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1,PNO: 6
  * NS offload: 2 NDP info: 1
@@ -154,7 +160,6 @@ Total page numbers : 256(0x100)
 #define	TX_PAGE_BOUNDARY_8192E	(TX_TOTAL_PAGE_NUMBER_8192E) /* beacon header start address */
 
 
-#define PAGE_SIZE_TX_92E	PAGE_SIZE_256
 #define RSVD_PKT_LEN_92E	(TOTAL_RSVD_PAGE_NUMBER_8192E * PAGE_SIZE_TX_92E)
 
 #define TX_PAGE_LOAD_FW_BOUNDARY_8192E		0x47 /* 0xA5 */
@@ -304,8 +309,6 @@ GetHalDefVar8192E(
 void rtl8192e_set_hal_ops(struct hal_ops *pHalFunc);
 void init_hal_spec_8192e(_adapter *adapter);
 void rtl8192e_init_default_value(_adapter *padapter);
-/* register */
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
 
 void rtl8192e_start_thread(_adapter *padapter);
 void rtl8192e_stop_thread(_adapter *padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_led.h
index 3d795c4055a8..b276d62b61c9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_recv.h
index 3faf16c7fb28..3ac9a03346a3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
@@ -35,6 +36,10 @@
 				/* #define MAX_RECVBUF_SZ (10240)  */ /* 10K */
 				/* #define MAX_RECVBUF_SZ (16384) */ /* 16k - 92E RX BUF :16K */
 				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k		 */
+				#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
+					#undef MAX_RECVBUF_SZ
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+				#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
 			#endif
 		#endif
 	#endif /* !MAX_RECVBUF_SZ */
@@ -139,6 +144,12 @@
 #define GET_RX_STATUS_DESC_UNICAST_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
 #define GET_RX_STATUS_DESC_MAGIC_WAKE_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
 
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_SPLCP_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 1)
+#define GET_RX_STATUS_DESC_LDPC_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 1, 1)
+#define GET_RX_STATUS_DESC_STBC_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 2, 1)
+#define GET_RX_STATUS_DESC_BW_92E(__pRxDesc)			LE_BITS_TO_4BYTE(__pRxDesc+16, 4, 2)
+
 
 /* DWORD 5 */
 #define GET_RX_STATUS_DESC_TSFL_92E(__pRxStatusDesc)				LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
@@ -150,6 +161,7 @@
 #ifdef CONFIG_SDIO_HCI
 	s32 rtl8192es_init_recv_priv(PADAPTER padapter);
 	void rtl8192es_free_recv_priv(PADAPTER padapter);
+	s32 rtl8192es_recv_hdl(_adapter *padapter);
 #endif
 
 #ifdef CONFIG_USB_HCI
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_rf.h
index f15e07041ba8..3686c63fe2b4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_spec.h
index c9b2b41e6e48..2ff0768f5946 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_sreset.h
index 78109aea468f..60e6afae36ea 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_xmit.h
index 0202302c8392..40e1e956d9fe 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192e_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2012 - 2017 Realtek Corporation.
@@ -317,9 +318,11 @@ typedef struct txdescriptor_8192e {
 #define SET_TX_DESC_ANTSEL_D_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
 
 /* Dword 7 */
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#ifdef CONFIG_PCI_HCI
 	#define SET_TX_DESC_TX_BUFFER_SIZE_92E(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
+#endif
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
 	#define SET_TX_DESC_TX_DESC_CHECKSUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
 #endif
 #define SET_TX_DESC_USB_TXAGG_NUM_92E(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_cmd.h
new file mode 100644
index 000000000000..e63aba6c22b5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_cmd.h
@@ -0,0 +1,195 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192F_CMD_H__
+#define __RTL8192F_CMD_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+enum h2c_cmd_8192F {
+	/* Common Class: 000 */
+	H2C_8192F_RSVD_PAGE = 0x00,
+	H2C_8192F_MEDIA_STATUS_RPT = 0x01,
+	H2C_8192F_SCAN_ENABLE = 0x02,
+	H2C_8192F_KEEP_ALIVE = 0x03,
+	H2C_8192F_DISCON_DECISION = 0x04,	
+	H2C_8192F_PSD_OFFLOAD = 0x05,	
+	H2C_8192F_AP_OFFLOAD = 0x08,	
+	H2C_8192F_BCN_RSVDPAGE = 0x09,	
+	H2C_8192F_PROBERSP_RSVDPAGE = 0x0A,	
+	H2C_8192F_FCS_RSVDPAGE = 0x10,	
+	H2C_8192F_FCS_INFO = 0x11,	
+	H2C_8192F_AP_WOW_GPIO_CTRL = 0x13,
+
+	/* PoweSave Class: 001 */
+	H2C_8192F_SET_PWR_MODE = 0x20,
+	H2C_8192F_PS_TUNING_PARA = 0x21,
+	H2C_8192F_PS_TUNING_PARA2 = 0x22,
+	H2C_8192F_P2P_LPS_PARAM = 0x23,	
+	H2C_8192F_P2P_PS_OFFLOAD = 0x24,	
+	H2C_8192F_PS_SCAN_ENABLE = 0x25,	
+	H2C_8192F_SAP_PS_ = 0x26,
+	H2C_8192F_INACTIVE_PS_ = 0x27,/* Inactive_PS */
+	H2C_8192F_FWLPS_IN_IPS_ = 0x28,
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8192F_MACID_CFG = 0x40,	
+	H2C_8192F_TXBF = 0x41,	
+	H2C_8192F_RSSI_SETTING = 0x42,	
+	H2C_8192F_AP_REQ_TXRPT = 0x43,	
+	H2C_8192F_INIT_RATE_COLLECT = 0x44,	
+	H2C_8192F_RA_PARA_ADJUST = 0x46,
+
+	/* BT Class: 011 */
+	H2C_8192F_B_TYPE_TDMA = 0x60,
+	H2C_8192F_BT_INFO = 0x61,
+	H2C_8192F_FORCE_BT_TXPWR = 0x62,
+	H2C_8192F_BT_IGNORE_WLANACT = 0x63,
+	H2C_8192F_DAC_SWING_VALUE = 0x64,
+	H2C_8192F_ANT_SEL_RSV = 0x65,
+	H2C_8192F_WL_OPMODE = 0x66,
+	H2C_8192F_BT_MP_OPER = 0x67,
+	H2C_8192F_BT_CONTROL = 0x68,
+	H2C_8192F_BT_WIFI_CTRL = 0x69,
+	H2C_8192F_BT_FW_PATCH = 0x6A,
+	H2C_8192F_BT_WLAN_CALIBRATION = 0x6D,
+
+	/* WOWLAN Class: 100 */
+	H2C_8192F_WOWLAN = 0x80,
+	H2C_8192F_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8192F_AOAC_GLOBAL_INFO = 0x82,	
+	H2C_8192F_AOAC_RSVD_PAGE = 0x83,	
+	H2C_8192F_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_8192F_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_8192F_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_8192F_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_8192F_P2P_OFFLOAD_RSVD_PAGE = 0x8A,	
+	H2C_8192F_P2P_OFFLOAD = 0x8B,
+
+	H2C_8192F_RESET_TSF = 0xC0,
+	H2C_8192F_MAXID,
+};
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_8192F_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8192F_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8192F_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8192F_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8192F_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/*_MEDIA_STATUS_RPT_PARM_CMD_0x01*/
+#define SET_8192F_H2CCMD_MSRRPT_PARM_OPMODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
+#define SET_8192F_H2CCMD_MSRRPT_PARM_MACID_IND(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
+#define SET_8192F_H2CCMD_MSRRPT_PARM_MACID(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8192F_H2CCMD_MSRRPT_PARM_MACID_END(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+/* _PWR_MOD_CMD_0x20 */
+#define SET_8192F_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8192F_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8192F_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8192F_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8192F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8192F_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8192F_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+#define GET_8192F_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _PS_TUNE_PARAM_CMD_0x21 */
+#define SET_8192F_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8192F_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8192F_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
+#define SET_8192F_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
+#define SET_8192F_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _MACID_CFG_CMD_0x40 */
+#define SET_8192F_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
+#define SET_8192F_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
+
+/* _RSSI_SETTING_CMD_0x42 */
+#define SET_8192F_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8192F_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
+#define SET_8192F_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _AP_REQ_TXRPT_CMD_0x43 */
+#define SET_8192F_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8192F_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _FORCE_BT_TXPWR_CMD_0x62 */
+#define SET_8192F_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
+#define SET_8192F_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_8192F_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_8192F_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8192F_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_8192F_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8192F_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+
+/* _BT_FW_PATCH_0x6A */
+#define SET_8192F_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8192F_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8192F_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8192F_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8192F_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+/* host message to firmware cmd */
+void rtl8192f_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8192f_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
+/* s32 rtl8192f__set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
+void rtl8192f_set_FwPsTuneParam_cmd(PADAPTER padapter);
+void rtl8192f_download_rsvd_page(PADAPTER padapter, u8 mstatus);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8192f__download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P
+	void rtl8192f_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8192f_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+	void rtl8192f_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+#endif
+
+s32 FillH2CCmd8192F(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8192F(_adapter *padapter, bool wowlan);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822bwifionly.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_dm.h
similarity index 54%
rename from drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822bwifionly.h
rename to drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_dm.h
index 4ca6f4837e70..b1d0d7b13e50 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8822bwifionly.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_dm.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
  *
  * 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
@@ -12,25 +13,16 @@
  * more details.
  *
  *****************************************************************************/
-#ifndef __INC_HAL8822BWIFIONLYHWCFG_H
-#define __INC_HAL8822BWIFIONLYHWCFG_H
+#ifndef __RTL8192F_DM_H__
+#define __RTL8192F_DM_H__
+
+void rtl8192f_init_dm_priv(IN PADAPTER Adapter);
+void rtl8192f_deinit_dm_priv(IN PADAPTER Adapter);
+void rtl8192f_InitHalDm(IN PADAPTER Adapter);
+void rtl8192f_HalDmWatchDog(IN PADAPTER Adapter);
+
+/* VOID rtl8192c_dm_CheckTXPowerTracking(IN PADAPTER Adapter); */
+
+/* void rtl8192c_dm_RF_Saving(IN PADAPTER pAdapter, IN u8 bForceInNormal); */
 
-VOID
-ex_hal8822b_wifi_only_hw_config(
-	IN struct wifi_only_cfg *pwifionlycfg
-	);
-VOID
-ex_hal8822b_wifi_only_scannotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	);
-VOID
-ex_hal8822b_wifi_only_switchbandnotify(
-	IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	);
-VOID
-hal8822b_wifi_only_switch_antenna(IN struct wifi_only_cfg *pwifionlycfg,
-	IN u1Byte  is_5g
-	);
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_hal.h
new file mode 100644
index 000000000000..8086ba46de58
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_hal.h
@@ -0,0 +1,316 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192F_HAL_H__
+#define __RTL8192F_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8192f_spec.h"
+#include "rtl8192f_rf.h"
+#include "rtl8192f_dm.h"
+#include "rtl8192f_recv.h"
+#include "rtl8192f_xmit.h"
+#include "rtl8192f_cmd.h"
+#include "rtl8192f_led.h"
+#include "Hal8192FPwrSeq.h"
+#include "Hal8192FPhyReg.h"
+#include "Hal8192FPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+#include "rtl8192f_sreset.h"
+#endif
+#ifdef CONFIG_LPS_POFF
+	#include "rtl8192f_lps_poff.h"
+#endif
+
+#define FW_8192F_SIZE		0x8000
+#define FW_8192F_START_ADDRESS	0x4000
+#define FW_8192F_END_ADDRESS	0x5000 /* brian_zhang@realsil.com.cn */
+
+#define IS_FW_HEADER_EXIST_8192F(_pFwHdr)\
+	((le16_to_cpu(_pFwHdr->Signature) & 0xFFF0) == 0x92F0)
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8192F_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8192F, *PRT_FIRMWARE_8192F;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8192F_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8192F_FIRMWARE_HDR, *PRT_8192F_FIRMWARE_HDR;
+#define DRIVER_EARLY_INT_TIME_8192F		0x05
+#define BCN_DMA_ATIME_INT_TIME_8192F		0x02
+/* for 8192F
+ * TX 64K, RX 16K, Page size 256B for TX*/
+#define PAGE_SIZE_TX_8192F			256
+#define PAGE_SIZE_RX_8192F			8
+#define TX_DMA_SIZE_8192F			0x10000/* 64K(TX) */
+#define RX_DMA_SIZE_8192F			0x4000/* 16K(RX) */
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8192F	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8192F	0xc0	/* 192B, reserved for tx report 24*8=192*/
+#endif
+#define RX_DMA_BOUNDARY_8192F\
+	(RX_DMA_SIZE_8192F - RX_DMA_RESERVED_SIZE_8192F - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:MAX_BEACON_LEN/PAGE_SIZE_TX_8192F
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
+#define BCNQ_PAGE_NUM_8192F		(MAX_BEACON_LEN/PAGE_SIZE_TX_8192F + 6) /*0x08*/
+
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt 1, PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8192F	0x07
+#else
+	#define WOWLAN_PAGE_NUM_8192F	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8192F
+	#define WOWLAN_PAGE_NUM_8192F	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8192F	0x02
+#endif
+
+#ifdef DBG_LA_MODE
+	#define LA_MODE_PAGE_NUM 0xE0
+#endif
+
+#define MAX_RX_DMA_BUFFER_SIZE_8192F	(RX_DMA_SIZE_8192F - RX_DMA_RESERVED_SIZE_8192F)
+
+#ifdef DBG_LA_MODE
+	#define TX_TOTAL_PAGE_NUMBER_8192F	(0xFF - LA_MODE_PAGE_NUM)
+#else
+	#define TX_TOTAL_PAGE_NUMBER_8192F	(0xFF - BCNQ_PAGE_NUM_8192F - WOWLAN_PAGE_NUM_8192F)
+#endif
+
+#define TX_PAGE_BOUNDARY_8192F		(TX_TOTAL_PAGE_NUMBER_8192F + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8192F \
+	TX_TOTAL_PAGE_NUMBER_8192F
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8192F \
+	(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8192F + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8192F */
+#define NORMAL_PAGE_NUM_HPQ_8192F		0x8
+#define NORMAL_PAGE_NUM_LPQ_8192F		0x8
+#define NORMAL_PAGE_NUM_NPQ_8192F		0x8
+#define NORMAL_PAGE_NUM_EPQ_8192F		0x00
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8192F		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8192F		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8192F		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8192F		0x00
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES 56 /*0x1C8~0x1FF*/
+
+#define HAL_EFUSE_MEMORY
+#define HWSET_MAX_SIZE_8192F                512
+#define EFUSE_REAL_CONTENT_LEN_8192F        512
+#define EFUSE_MAP_LEN_8192F                 512
+#define EFUSE_MAX_SECTION_8192F            64
+
+/* For some inferiority IC purpose. added by Roger, 2009.09.02.*/
+#define EFUSE_IC_ID_OFFSET			506
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8192F)
+
+#define EFUSE_ACCESS_ON		0x69
+#define EFUSE_ACCESS_OFF	0x00
+
+/* ********************************************************
+ *			EFUSE for BT definition
+ * ******************************************************** */
+#define BANK_NUM			1
+#define EFUSE_BT_REAL_BANK_CONTENT_LEN	512
+#define EFUSE_BT_REAL_CONTENT_LEN	1536/*512 * 3 */
+/*	(EFUSE_BT_REAL_BANK_CONTENT_LEN * BANK_NUM)*/
+#define EFUSE_BT_MAP_LEN		1024	/* 1k bytes */
+#define EFUSE_BT_MAX_SECTION		128 /* 1024/8 */
+#define EFUSE_PROTECT_BYTES_BANK	16
+
+typedef enum tag_Package_Definition {
+	PACKAGE_DEFAULT,
+	PACKAGE_QFN32,
+	PACKAGE_QFN40,
+	PACKAGE_QFN46
+} PACKAGE_TYPE_E;
+
+#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)
+
+#ifdef CONFIG_FILE_FWIMG
+	extern char *rtw_fw_file_path;
+	extern char *rtw_fw_wow_file_path;
+	#ifdef CONFIG_MP_INCLUDED
+		extern char *rtw_fw_mp_bt_file_path;
+	#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
+
+/* rtl8192f_hal_init.c */
+s32 rtl8192f_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8192f_FirmwareSelfReset(PADAPTER padapter);
+void rtl8192f_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8192f_InitAntenna_Selection(PADAPTER padapter);
+void rtl8192f_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8192f_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8192f_init_default_value(PADAPTER padapter);
+
+s32 rtl8192f_InitLLTTable(PADAPTER padapter);
+
+s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU);
+s32 CardDisableWithoutHWSM(PADAPTER padapter);
+
+/* EFuse */
+u8 GetEEPROMSize8192F(PADAPTER padapter);
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8192F(PADAPTER padapter,
+					u8 *PROMContent, BOOLEAN AutoLoadFail);
+/*
+void Hal_EfuseParseBTCoexistInfo_8192F(PADAPTER padapter,
+				       u8 *hwinfo, BOOLEAN AutoLoadFail);
+*/
+void Hal_EfuseParseEEPROMVer_8192F(PADAPTER padapter,
+				   u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8192F(PADAPTER padapter,
+				  u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8192F(PADAPTER padapter,
+				    u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8192F(PADAPTER padapter,
+		u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8192F(PADAPTER pAdapter,
+			      u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8192F(PADAPTER padapter,
+				      u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParseVoltage_8192F(PADAPTER pAdapter,
+				 u8 *hwinfo, BOOLEAN	AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8192F(PADAPTER Adapter,
+				   u8	*PROMContent, BOOLEAN AutoloadFail);
+u8	Hal_ReadRFEType_8192F(PADAPTER Adapter, u8 *PROMContent, BOOLEAN AutoloadFail);
+void rtl8192f_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8192f(_adapter *adapter);
+u8 SetHwReg8192F(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8192F(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8192F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8192F(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8192f_InitBeaconParameters(PADAPTER padapter);
+void rtl8192f_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+
+void _InitMacAPLLSetting_8192F(PADAPTER Adapter);
+void _8051Reset8192F(PADAPTER padapter);
+#ifdef CONFIG_WOWLAN
+	void Hal_DetectWoWMode(PADAPTER pAdapter);
+#endif /* CONFIG_WOWLAN */
+
+void rtl8192f_start_thread(_adapter *padapter);
+void rtl8192f_stop_thread(_adapter *padapter);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void rtl8192fs_init_checkbthang_workqueue(_adapter *adapter);
+	void rtl8192fs_free_checkbthang_workqueue(_adapter *adapter);
+	void rtl8192fs_cancle_checkbthang_workqueue(_adapter *adapter);
+	void rtl8192fs_hal_check_bt_hang(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+#ifdef CONFIG_MP_INCLUDED
+int FirmwareDownloadBT(IN PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware);
+#endif
+void CCX_FwC2HTxRpt_8192f(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8192F(u8 rate);
+u8 HwRateToMRate8192F(u8 rate);
+
+#if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST)
+	void check_bt_status_work(void *data);
+#endif
+
+
+void rtl8192f_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+
+#ifdef CONFIG_AMPDU_PRETX_CD
+void rtl8192f_pretx_cd_config(_adapter *adapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	BOOLEAN	InterruptRecognized8192FE(PADAPTER Adapter);
+	VOID	UpdateInterruptMask8192FE(PADAPTER Adapter, u32 AddMSR, u32 AddMSR1, u32 RemoveMSR, u32 RemoveMSR1);
+	VOID InitMAC_TRXBD_8192FE(PADAPTER Adapter);
+
+	u16 get_txbd_rw_reg(u16 ff_hwaddr);
+#endif
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_led.h
new file mode 100644
index 000000000000..f86442f1ce8a
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_led.h
@@ -0,0 +1,43 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192F_LED_H__
+#define __RTL8192F_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+void rtl8192fu_InitSwLeds(PADAPTER padapter);
+void rtl8192fu_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+void rtl8192fs_InitSwLeds(PADAPTER padapter);
+void rtl8192fs_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+void rtl8192fe_InitSwLeds(PADAPTER padapter);
+void rtl8192fe_DeInitSwLeds(PADAPTER padapter);
+#endif
+#endif /*#ifdef CONFIG_RTW_SW_LED*/
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_recv.h
new file mode 100644
index 000000000000..59d0755a657d
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_recv.h
@@ -0,0 +1,112 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192F_RECV_H__
+#define __RTL8192F_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifndef CONFIG_MINIMAL_MEMORY_USAGE
+				/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+				/* #define MAX_RECVBUF_SZ (16384) */ /* 16K */
+				/* #define MAX_RECVBUF_SZ (10240) */ /* 10K */
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#else
+					#define MAX_RECVBUF_SZ (32768) /* 32k */
+				#endif
+				/* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */
+			#else
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+
+#elif defined(CONFIG_PCI_HCI)
+	#define MAX_RECVBUF_SZ (4000) /* about 4K */
+
+#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+
+	#define MAX_RECVBUF_SZ (RX_DMA_BOUNDARY_8192F + 1)
+
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+#ifdef CONFIG_SDIO_HCI
+	#ifndef CONFIG_SDIO_RX_COPY
+		#undef MAX_RECVBUF_SZ
+		#define MAX_RECVBUF_SZ	(RX_DMA_SIZE_8192F - RX_DMA_RESERVED_SIZE_8192F)
+	#endif /* !CONFIG_SDIO_RX_COPY */
+#endif /* CONFIG_SDIO_HCI */
+
+/*-----------------------------------------------------------------*/
+/*	RTL8192F RX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+/*DWORD 0*/
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_8192F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_8192F(__pRxStatusDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_8192F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8192F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 15, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_8192F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_8192F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_FS_8192F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 1)
+#ifdef USING_RX_TAG
+	#define GET_RX_BUFFER_DESC_RX_TAG_8192F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 13)
+#else
+	#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8192F(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+#endif
+
+/*DWORD 1*/
+#define SET_RX_BUFFER_PHYSICAL_LOW_8192F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+
+/*DWORD 2*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8192F(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+#else
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8192F(__pRxStatusDesc, __Value)
+#endif
+
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8192fs_init_recv_priv(PADAPTER padapter);
+	void rtl8192fs_free_recv_priv(PADAPTER padapter);
+	s32 rtl8192fs_recv_hdl(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8192fu_init_recv_priv(_adapter *padapter);
+	void rtl8192fu_free_recv_priv(_adapter *padapter);
+	void rtl8192fu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8192fe_init_recv_priv(_adapter *padapter);
+	void rtl8192fe_free_recv_priv(_adapter *padapter);
+#endif
+
+void rtl8192f_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8192F_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_rf.h
new file mode 100644
index 000000000000..3d89fed5f7d9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_rf.h
@@ -0,0 +1,84 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2012 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192F_RF_H__
+#define __RTL8192F_RF_H__
+
+/*default*/
+/*#define CONFIG_8192F_DRV_DIS*/
+/*AP*/
+#define CONFIG_8192F_TYPE3_DRV_DIS
+#define CONFIG_8192F_TYPE4_DRV_DIS
+/*unused*/
+#define CONFIG_8192F_TYPE10_DRV_DIS
+#define CONFIG_8192F_TYPE11_DRV_DIS
+#define CONFIG_8192F_TYPE12_DRV_DIS
+#define CONFIG_8192F_TYPE13_DRV_DIS
+#define CONFIG_8192F_TYPE14_DRV_DIS
+#define CONFIG_8192F_TYPE15_DRV_DIS
+#define CONFIG_8192F_TYPE16_DRV_DIS
+#define CONFIG_8192F_TYPE17_DRV_DIS
+#define CONFIG_8192F_TYPE18_DRV_DIS
+#define CONFIG_8192F_TYPE19_DRV_DIS
+#define CONFIG_8192F_TYPE20_DRV_DIS
+#define CONFIG_8192F_TYPE21_DRV_DIS
+#define CONFIG_8192F_TYPE22_DRV_DIS
+#define CONFIG_8192F_TYPE23_DRV_DIS
+#define CONFIG_8192F_TYPE24_DRV_DIS
+#define CONFIG_8192F_TYPE25_DRV_DIS
+#define CONFIG_8192F_TYPE26_DRV_DIS
+#define CONFIG_8192F_TYPE27_DRV_DIS
+#define CONFIG_8192F_TYPE28_DRV_DIS
+#define CONFIG_8192F_TYPE29_DRV_DIS
+#define CONFIG_8192F_TYPE30_DRV_DIS
+#define CONFIG_8192F_TYPE31_DRV_DIS
+
+
+#ifdef CONFIG_SDIO_HCI /**/
+/*usb*/
+#define CONFIG_8192F_TYPE1_DRV_DIS
+#define CONFIG_8192F_TYPE5_DRV_DIS
+/*pcie*/
+#define CONFIG_8192F_TYPE0_DRV_DIS
+#define CONFIG_8192F_TYPE6_DRV_DIS
+#define CONFIG_8192F_TYPE7_DRV_DIS
+#define CONFIG_8192F_TYPE8_DRV_DIS
+#define CONFIG_8192F_TYPE9_DRV_DIS
+#endif/*CONFIG_SDIO_HCI*/
+
+#ifdef CONFIG_USB_HCI
+/*sdio*/
+#define CONFIG_8192F_TYPE2_DRV_DIS
+/*pcie*/
+#define CONFIG_8192F_TYPE0_DRV_DIS
+#define CONFIG_8192F_TYPE6_DRV_DIS
+#define CONFIG_8192F_TYPE7_DRV_DIS
+#define CONFIG_8192F_TYPE8_DRV_DIS
+#define CONFIG_8192F_TYPE9_DRV_DIS
+#endif/*CONFIG_USB_HCI*/
+
+#ifdef CONFIG_PCI_HCI
+/*sdio*/
+#define CONFIG_8192F_TYPE2_DRV_DIS
+/*usb*/
+#define CONFIG_8192F_TYPE1_DRV_DIS
+#define CONFIG_8192F_TYPE5_DRV_DIS
+#endif/*CONFIG_PCI_HCI*/
+
+int PHY_RF6052_Config8192F(IN PADAPTER pdapter);
+
+void PHY_RF6052SetBandwidth8192F(IN PADAPTER Adapter, IN enum channel_width Bandwidth);
+
+#endif/* __RTL8192F_RF_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_spec.h
new file mode 100644
index 000000000000..6b3b77beec67
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_spec.h
@@ -0,0 +1,539 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192F_SPEC_H__
+#define __RTL8192F_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8192F		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8192F			0x0000	/* 2 Byte */
+#define REG_SYS_FUNC_EN_8192F			0x0002	/* 2 Byte */
+#define REG_APS_FSMCO_8192F			0x0004	/* 4 Byte */
+#define REG_SYS_CLKR_8192F				0x0008	/* 2 Byte */
+#define REG_9346CR_8192F				0x000A	/* 2 Byte */
+#define REG_EE_VPD_8192F				0x000C	/* 2 Byte */
+#define REG_AFE_MISC_8192F				0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8192F				0x0011	/* 7 Byte */
+#define REG_SPS_OCP_CFG_8192F			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8192F				0x001C	/* 3 Byte */
+#define REG_RF_CTRL_8192F				0x001F	/* 1 Byte */
+#define REG_LPLDO_CTRL_8192F			0x0023	/* 1 Byte */
+#define REG_AFE_XTAL_CTRL_8192F		0x0024	/* 4 Byte */
+#define REG_AFE_PLL_CTRL_8192F			0x0028	/* 4 Byte */
+#define REG_MAC_PLL_CTRL_EXT_8192F		0x002c	/* 4 Byte */
+#define REG_EFUSE_CTRL_8192F			0x0030
+#define REG_EFUSE_TEST_8192F			0x0034
+#define REG_PWR_DATA_8192F				0x0038
+#define REG_CAL_TIMER_8192F				0x003C
+#define REG_ACLK_MON_8192F				0x003E
+#define REG_GPIO_MUXCFG_8192F			0x0040
+#define REG_GPIO_IO_SEL_8192F			0x0042
+#define REG_MAC_PINMUX_CFG_8192F		0x0043
+#define REG_GPIO_PIN_CTRL_8192F			0x0044
+#define REG_GPIO_INTM_8192F				0x0048
+#define REG_LEDCFG0_8192F				0x004C
+#define REG_LEDCFG1_8192F				0x004D
+#define REG_LEDCFG2_8192F				0x004E
+#define REG_LEDCFG3_8192F				0x004F
+#define REG_FSIMR_8192F					0x0050
+#define REG_FSISR_8192F					0x0054
+#define REG_HSIMR_8192F					0x0058
+#define REG_HSISR_8192F					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_PAD_CTRL1_8192F		0x0064
+#define REG_MULTI_FUNC_CTRL_8192F		0x0068
+#define REG_GPIO_STATUS_8192F			0x006C
+#define REG_SDIO_CTRL_8192F				0x0070
+#define REG_OPT_CTRL_8192F				0x0074
+#define REG_AFE_CTRL_4_8192F		0x0078
+#define REG_MCUFWDL_8192F				0x0080
+#define REG_8051FW_CTRL_8192F			0x0080
+#define REG_HMEBOX_DBG_0_8192F	0x0088
+#define REG_HMEBOX_DBG_1_8192F	0x008A
+#define REG_HMEBOX_DBG_2_8192F	0x008C
+#define REG_HMEBOX_DBG_3_8192F	0x008E
+#define REG_WLLPS_CTRL		0x0090
+#define REG_HIMR0_8192F					0x00B0
+#define REG_HISR0_8192F				0x00B4
+#define REG_HIMR1_8192F					0x00B8
+#define REG_HISR1_8192F					0x00BC
+#define REG_PMC_DBG_CTRL2_8192F			0x00CC
+#define	REG_EFUSE_BURN_GNT_8192F		0x00CF
+#define REG_HPON_FSM_8192F				0x00EC
+#define REG_SYS_CFG1_8192F				0x00F0
+#define REG_SYS_CFG2_8192F				0x00FC
+#define REG_ROM_VERSION					0x00FD
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_CR_8192F						0x0100
+#define REG_PBP_8192F					0x0104
+#define REG_PKT_BUFF_ACCESS_CTRL_8192F	0x0106
+#define REG_TRXDMA_CTRL_8192F			0x010C
+#define REG_TRXFF_BNDY_8192F			0x0114
+#define REG_TRXFF_STATUS_8192F			0x0118
+#define REG_RXFF_PTR_8192F				0x011C
+#define REG_CPWM_8192F					0x012C
+#define REG_FWIMR_8192F					0x0130
+#define REG_FWISR_8192F					0x0134
+#define REG_FTIMR_8192F					0x0138
+#define REG_PKTBUF_DBG_CTRL_8192F		0x0140
+#define REG_RXPKTBUF_CTRL_8192F		0x0142
+#define REG_PKTBUF_DBG_DATA_L_8192F	0x0144
+#define REG_PKTBUF_DBG_DATA_H_8192F	0x0148
+
+#define REG_TC0_CTRL_8192F				0x0150
+#define REG_TC1_CTRL_8192F				0x0154
+#define REG_TC2_CTRL_8192F				0x0158
+#define REG_TC3_CTRL_8192F				0x015C
+#define REG_TC4_CTRL_8192F				0x0160
+#define REG_TCUNIT_BASE_8192F			0x0164
+#define REG_RSVD3_8192F					0x0168
+#define REG_C2HEVT_CMD_ID_8192F	0x01A0
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_8192F        0x01AE
+#define REG_C2HEVT_CLEAR_8192F			0x01AF
+#define REG_MCUTST_1_8192F				0x01C0
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_FMETHR_8192F				0x01C8
+#define REG_HMETFR_8192F				0x01CC
+#define REG_HMEBOX_0_8192F				0x01D0
+#define REG_HMEBOX_1_8192F				0x01D4
+#define REG_HMEBOX_2_8192F				0x01D8
+#define REG_HMEBOX_3_8192F				0x01DC
+#define REG_LLT_INIT_8192F				0x01E0
+#define REG_HMEBOX_EXT0_8192F			0x01F0
+#define REG_HMEBOX_EXT1_8192F			0x01F4
+#define REG_HMEBOX_EXT2_8192F			0x01F8
+#define REG_HMEBOX_EXT3_8192F			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RQPN_8192F					0x0200
+#define REG_FIFOPAGE_8192F				0x0204
+#define REG_DWBCN0_CTRL_8192F			REG_TDECTRL
+#define REG_TXDMA_OFFSET_CHK_8192F	0x020C
+#define REG_TXDMA_STATUS_8192F		0x0210
+#define REG_RQPN_NPQ_8192F			0x0214
+#define REG_DWBCN1_CTRL_8192F			0x0228
+#define REG_RQPN_EXQ1_EXQ2			0x0230
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8192F		0x0280
+#define REG_FW_UPD_RDPTR_8192F		0x0284 /* FW shall update this register before FW write RXPKT_RELEASE_POLL to 1 */
+#define REG_RXDMA_CONTROL_8192F		0x0286 /* Control the RX DMA. */
+#define REG_RXDMA_STATUS_8192F			0x0288
+#define REG_RXDMA_MODE_CTRL_8192F		0x0290
+#define REG_EARLY_MODE_CONTROL_8192F	0x02BC
+#define REG_RSVD5_8192F					0x02F0
+#define REG_RSVD6_8192F					0x02F4
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8192F		0x0300
+#define	REG_INT_MIG_8192F				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8192F		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8192F			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8192F			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8192F			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8192F			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8192F			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8192F			0x0338	/* RX Queue	Descriptor Address */
+#define REG_HI0Q_TXBD_DESA_8192F		0x0340
+#define REG_HI1Q_TXBD_DESA_8192F		0x0348
+#define REG_HI2Q_TXBD_DESA_8192F		0x0350
+#define REG_HI3Q_TXBD_DESA_8192F		0x0358
+#define REG_HI4Q_TXBD_DESA_8192F		0x0360
+#define REG_HI5Q_TXBD_DESA_8192F		0x0368
+#define REG_HI6Q_TXBD_DESA_8192F		0x0370
+#define REG_HI7Q_TXBD_DESA_8192F		0x0378
+#define	REG_MGQ_TXBD_NUM_8192F			0x0380
+#define	REG_RX_RXBD_NUM_8192F			0x0382
+#define	REG_VOQ_TXBD_NUM_8192F			0x0384
+#define	REG_VIQ_TXBD_NUM_8192F			0x0386
+#define	REG_BEQ_TXBD_NUM_8192F			0x0388
+#define	REG_BKQ_TXBD_NUM_8192F			0x038A
+#define	REG_HI0Q_TXBD_NUM_8192F			0x038C
+#define	REG_HI1Q_TXBD_NUM_8192F			0x038E
+#define	REG_HI2Q_TXBD_NUM_8192F			0x0390
+#define	REG_HI3Q_TXBD_NUM_8192F			0x0392
+#define	REG_HI4Q_TXBD_NUM_8192F			0x0394
+#define	REG_HI5Q_TXBD_NUM_8192F			0x0396
+#define	REG_HI6Q_TXBD_NUM_8192F			0x0398
+#define	REG_HI7Q_TXBD_NUM_8192F			0x039A
+#define	REG_TSFTIMER_HCI_8192F			0x039C
+#define	REG_BD_RW_PTR_CLR_8192F			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8192F			0x03A0
+#define	REG_VIQ_TXBD_IDX_8192F			0x03A4
+#define	REG_BEQ_TXBD_IDX_8192F			0x03A8
+#define	REG_BKQ_TXBD_IDX_8192F			0x03AC
+#define	REG_MGQ_TXBD_IDX_8192F			0x03B0
+#define	REG_RXQ_TXBD_IDX_8192F			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8192F			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8192F			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8192F			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8192F			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8192F			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8192F			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8192F			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8192F			0x03D4
+#define	REG_DBI_WDATA_V1_8192F			0x03E8
+#define	REG_DBI_RDATA_V1_8192F			0x03EC
+#define	REG_DBI_FLAG_V1_8192F			0x03F0
+#define REG_MDIO_V1_8192F			0x03F4
+#define REG_HCI_MIX_CFG_8192F			0x03FC
+#define REG_PCIE_HCPWM_8192FE				0x03D8
+#define REG_PCIE_HRPWM_8192FE				0x03DC
+#define REG_PCIE_MIX_CFG_8192F				0x03F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_QUEUELIST_INFO0_8192F		0x0400
+#define REG_QUEUELIST_INFO1_8192F		0x0404
+#define REG_QUEUELIST_INFO2_8192F		0x0414
+#define REG_TXPKT_EMPTY_8192F			0x0418
+
+#define REG_FWHW_TXQ_CTRL_8192F		0x0420
+#define REG_HWSEQ_CTRL_8192F			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8192F	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8192F	0x0425
+#define REG_LIFECTRL_CTRL_8192F			0x0426
+#define REG_MULTI_BCNQ_OFFSET_8192F	0x0427
+#define REG_SPEC_SIFS_8192F				0x0428
+#define REG_RL_8192F						0x042A
+#define REG_TXBF_CTRL_8192F				0x042C
+#define REG_DARFRC_8192F				0x0430
+#define REG_RARFRC_8192F				0x0438
+#define REG_RRSR_8192F					0x0440
+#define REG_ARFR0_8192F					0x0444
+#define REG_ARFR1_8192F					0x044C
+#define REG_CCK_CHECK_8192F				0x0454
+#define REG_AMPDU_MAX_TIME_8192F		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8192F	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8192F	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8192F	0x045D
+#define REG_NDPA_OPT_CTRL_8192F		0x045F
+#define REG_FAST_EDCA_CTRL_8192F		0x0460
+#define REG_RD_RESP_PKT_TH_8192F		0x0463
+#define REG_DATA_SC_8192F				0x0483
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_POWER_STAGE1_8192F		0x04B4
+#define REG_POWER_STAGE2_8192F		0x04B8
+#define REG_AMPDU_BURST_MODE_8192F	0x04BC
+#define REG_PKT_VO_VI_LIFE_TIME_8192F	0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8192F	0x04C2
+#define REG_STBC_SETTING_8192F			0x04C4
+#define REG_HT_SINGLE_AMPDU_8192F		0x04C7
+#define REG_PROT_MODE_CTRL_8192F		0x04C8
+#define REG_MAX_AGGR_NUM_8192F		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8192F	0x04CB
+#define REG_BAR_MODE_CTRL_8192F		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8192F	0x04CF
+#define REG_MACID_PKT_DROP0_8192F		0x04D0
+#define REG_MACID_PKT_SLEEP_8192F		0x04D4
+#define REG_PRECNT_CTRL_8192F			0x04E5
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8192F		0x0500
+#define REG_EDCA_VI_PARAM_8192F		0x0504
+#define REG_EDCA_BE_PARAM_8192F		0x0508
+#define REG_EDCA_BK_PARAM_8192F		0x050C
+#define REG_BCNTCFG_8192F				0x0510
+#define REG_PIFS_8192F					0x0512
+#define REG_RDG_PIFS_8192F				0x0513
+#define REG_SIFS_CTX_8192F				0x0514
+#define REG_SIFS_TRX_8192F				0x0516
+#define REG_AGGR_BREAK_TIME_8192F		0x051A
+#define REG_SLOT_8192F					0x051B
+#define REG_TX_PTCL_CTRL_8192F			0x0520
+#define REG_TXPAUSE_8192F				0x0522
+#define REG_DIS_TXREQ_CLR_8192F		0x0523
+#define REG_RD_CTRL_8192F				0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8192F			0x0540
+#define REG_RD_NAV_NXT_8192F			0x0544
+#define REG_NAV_PROT_LEN_8192F			0x0546
+#define REG_BCN_CTRL_8192F				0x0550
+#define REG_BCN_CTRL_1_8192F			0x0551
+#define REG_MBID_NUM_8192F				0x0552
+#define REG_DUAL_TSF_RST_8192F			0x0553
+#define REG_BCN_INTERVAL_8192F			0x0554
+#define REG_DRVERLYINT_8192F			0x0558
+#define REG_BCNDMATIM_8192F			0x0559
+#define REG_ATIMWND_8192F				0x055A
+#define REG_USTIME_TSF_8192F			0x055C
+#define REG_BCN_MAX_ERR_8192F			0x055D
+#define REG_RXTSF_OFFSET_CCK_8192F		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8192F	0x055F	
+#define REG_TSFTR_8192F					0x0560
+#define REG_CTWND_8192F					0x0572
+#define REG_SECONDARY_CCA_CTRL_8192F	0x0577
+#define REG_PSTIMER_8192F				0x0580
+#define REG_TIMER0_8192F				0x0584
+#define REG_TIMER1_8192F				0x0588
+#define REG_ACMHWCTRL_8192F			0x05C0
+#define REG_SCH_TXCMD_8192F			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8192F				0x0600
+#define REG_TCR_8192F					0x0604
+#define REG_RCR_8192F					0x0608
+#define REG_RX_PKT_LIMIT_8192F			0x060C
+#define REG_RX_DLK_TIME_8192F			0x060D
+#define REG_RX_DRVINFO_SZ_8192F	0x060F
+
+#define REG_MACID_8192F					0x0610
+#define REG_BSSID_8192F					0x0618
+#define REG_MAR_8192F					0x0620
+#define REG_MBIDCAMCFG_8192F			0x0628
+
+
+#define REG_USTIME_EDCA_8192F			0x0638
+#define REG_MAC_SPEC_SIFS_8192F		0x063A
+#define REG_RESP_SIFP_CCK_8192F			0x063C
+#define REG_RESP_SIFS_OFDM_8192F		0x063E
+#define REG_ACKTO_8192F					0x0640
+#define REG_CTS2TO_8192F				0x0641
+#define REG_EIFS_8192F					0x0642
+
+#define REG_NAV_UPPER_8192F			0x0652	/* unit of 128*/
+#define REG_TRXPTCL_CTL_8192F			0x0668
+
+/* Security*/
+#define REG_CAMCMD_8192F				0x0670
+#define REG_CAMWRITE_8192F				0x0674
+#define REG_CAMREAD_8192F				0x0678
+#define REG_CAMDBG_8192F				0x067C
+#define REG_SECCFG_8192F				0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8192F				0x0690
+#define REG_PS_RX_INFO_8192F			0x0692
+#define REG_UAPSD_TID_8192F				0x0693
+#define REG_WKFMCAM_CMD_8192F			0x0698
+#define REG_WKFMCAM_NUM_8192F			0x0698
+#define REG_WKFMCAM_RWD_8192F			0x069C
+#define REG_RXFLTMAP0_8192F				0x06A0
+#define REG_RXFLTMAP1_8192F				0x06A2
+#define REG_RXFLTMAP2_8192F				0x06A4
+#define REG_BCN_PSR_RPT_8192F			0x06A8
+#define REG_BT_COEX_TABLE_8192F		0x06C0
+#define REG_BFMER0_INFO_8192F			0x06E4
+#define REG_BFMER1_INFO_8192F			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8192F	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8192F	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8192F	0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8192F				0x0700
+#define REG_BSSID1_8192F				0x0708
+#define REG_BFMEE_SEL_8192F				0x0714
+#define REG_SND_PTCL_CTRL_8192F		0x0718
+
+/* LTR */
+#define REG_LTR_CTRL_BASIC_8192F		0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8192F		0x0798
+#define REG_LTR_ACTIVE_LATENCY_V1_8192F	0x079C
+
+/* GPIO Control */
+#define REG_SW_GPIO_SHARE_CTRL_8192F	0x1038
+#define REG_SW_GPIO_A_OUT_8192F			0x1040
+#define REG_SW_GPIO_A_OEN_8192F			0x1044
+
+/* ************************************************************
+ * SDIO Bus Specification
+ * ************************************************************ */
+
+/* -----------------------------------------------------
+ * SDIO CMD Address Mapping
+ * ----------------------------------------------------- */
+
+/* -----------------------------------------------------
+ * I/O bus domain (Host)
+ * ----------------------------------------------------- */
+/*SDIO Host Interrupt Mask Register */
+#define SDIO_HIMR_CRCERR_MSK			BIT(31)
+/* SDIO Host Interrupt Service Routine */
+#define SDIO_HISR_HEISR_IND_INT		BIT(28)
+#define SDIO_HISR_HSISR2_IND_INT		BIT(29)
+#define SDIO_HISR_HSISR3_IND_INT		BIT(30)
+#define SDIO_HISR_SDIO_CRCERR			BIT(31)
+/* -----------------------------------------------------
+ * SDIO register
+ * ----------------------------------------------------- */
+#define SDIO_REG_HCPWM1_8192F	0x038/* HCI Current Power Mode 1 */
+#define SDIO_REG_FREE_TXPG1_8192F		0x0020 /* Free Tx Buffer Page1*/
+#define SDIO_REG_FREE_TXPG2_8192F		0x0024 /* Free Tx Buffer Page1*/
+#define SDIO_REG_FREE_TXPG3_8192F		0x0028
+#define SDIO_REG_AC_OQT_FREEPG_8192F		0x002A
+#define SDIO_REG_NOAC_OQT_FREEPG_8192F		0x002B
+/* ****************************************************************************
+ *	8192F Regsiter Bit and Content definition
+ * **************************************************************************** */
+
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+#ifdef CONFIG_AMPDU_PRETX_CD
+/*#define BIT_ERRORHDL_INT			BIT(2)*/
+/*#define BIT_MACTX_ERR_3			BIT(4)*/
+#define BIT_PRE_TX_CMD_8192F		BIT(6)
+#define BIT_EN_PRECNT_8192F		BIT(11)
+#endif
+/* SDIO Host Interrupt Service Routine */
+#define SDIO_HISR_HEISR_IND_INT	BIT(28)
+#define SDIO_HISR_HSISR2_IND_INT	BIT(29)
+#define SDIO_HISR_HSISR3_IND_INT	BIT(30)
+#define SDIO_HISR_SDIO_CRCERR		BIT(31)
+
+/* PCIE Host Interrupt Mask Register (HIMR) */
+#ifdef CONFIG_PCI_HCI
+/* ----------------------------------------------------------------------------
+ *   * 8192F IMR/ISR bits							(offset 0xB0,  8bits)
+ *     * ---------------------------------------------------------------------------- */
+
+#define IMR_DISABLED_8192F					0
+/* IMR DW0(0x00B0-00B3) Bit 0-31 */
+#define IMR_TIMER2_8192F					BIT(31)         /* Timeout interrupt 2 */
+#define IMR_TIMER1_8192F					BIT(30)		/* Timeout interrupt 1 */
+#define IMR_PSTIMEOUT_8192F				BIT(29)		/* Power Save Time Out Interrupt */
+#define IMR_GTINT4_8192F					BIT(28)		/* When GTIMER4 expires, this bit is set to 1 */
+#define IMR_GTINT3_8192F					BIT(27)		/* When GTIMER3 expires, this bit is set to 1 */
+#define IMR_TXBCN0ERR_8192F				BIT(26)		/* Transmit Beacon0 Error */
+#define IMR_TXBCN0OK_8192F				BIT(25)		/* Transmit Beacon0 OK */
+#define IMR_TSF_BIT32_TOGGLE_8192F		BIT(24)		/* TSF Timer BIT32 toggle indication interrupt */
+#define IMR_BCNDMAINT0_8192F				BIT(20)		/* Beacon DMA Interrupt 0 */
+#define IMR_BCNDERR0_8192F				BIT(16)		/* Beacon Queue DMA OK0 */
+#define IMR_HSISR_IND_ON_INT_8192F		BIT(15)		/* HSISR Indicator (HSIMR & HSISR is true, this bit is set to 1) */
+#define IMR_BCNDMAINT_E_8192F				BIT(14)		/* Beacon DMA Interrupt Extension for Win7 */
+#define IMR_ATIMEND_8192F					BIT(12)         /* CTWidnow End or ATIM Window End */
+#define IMR_C2HCMD_8192F					BIT(10)		/* CPU to Host Command INT status, Write 1 clear */
+#define IMR_CPWM2_8192F					BIT(9)          /* CPU power mode exchange INT status, Write 1 clear */
+#define IMR_CPWM_8192F						BIT(8)		/* CPU power mode exchange INT status, Write 1 clear */
+#define IMR_HIGHDOK_8192F					BIT(7)		/* High Queue DMA OK */
+#define IMR_MGNTDOK_8192F					BIT(6)		/* Management Queue DMA OK */
+#define IMR_BKDOK_8192F					BIT(5)		/* AC_BK DMA OK */
+#define IMR_BEDOK_8192F					BIT(4)		/* AC_BE DMA OK */
+#define IMR_VIDOK_8192F					BIT(3)		/* AC_VI DMA OK */
+#define IMR_VODOK_8192F					BIT(2)		/* AC_VO DMA OK */
+#define IMR_RDU_8192F						BIT(1)		/* Rx Descriptor Unavailable */
+#define IMR_ROK_8192F						BIT(0)		/* Receive DMA OK */
+
+/* IMR DW1(0x00B4-00B7) Bit 0-31 */
+#define IMR_MCUERR_8192F					BIT(28)
+#define IMR_BCNDMAINT7_8192F				BIT(27) 		/* Beacon DMA Interrupt 7 */
+#define IMR_BCNDMAINT6_8192F				BIT(26)		/* Beacon DMA Interrupt 6 */
+#define IMR_BCNDMAINT5_8192F				BIT(25)		/* Beacon DMA Interrupt 5 */
+#define IMR_BCNDMAINT4_8192F				BIT(24)		/* Beacon DMA Interrupt 4 */
+#define IMR_BCNDMAINT3_8192F				BIT(23)		/* Beacon DMA Interrupt 3 */
+#define IMR_BCNDMAINT2_8192F				BIT(22)		/* Beacon DMA Interrupt 2 */
+#define IMR_BCNDMAINT1_8192F 				BIT(21)		/* Beacon DMA Interrupt 1 */
+#define IMR_BCNDOK7_8192F 					BIT(20)		/* Beacon Queue DMA OK Interrup 7 */
+#define IMR_BCNDOK6_8192F					BIT(19) 		/* Beacon Queue DMA OK Interrup 6 */
+#define IMR_BCNDOK5_8192F					BIT(18)		/* Beacon Queue DMA OK Interrup 5 */
+#define IMR_BCNDOK4_8192F					BIT(17)		/* Beacon Queue DMA OK Interrup 4 */
+#define IMR_BCNDOK3_8192F					BIT(16)		/* Beacon Queue DMA OK Interrup 3 */
+#define IMR_BCNDOK2_8192F					BIT(15)		/* Beacon Queue DMA OK Interrup 2 */
+#define IMR_BCNDOK1_8192F					BIT(14)		/* Beacon Queue DMA OK Interrup 1 */
+#define IMR_ATIMEND_E_8192F				BIT(13)		/* ATIM Window End Extension for Win7 */
+#define IMR_TXERR_8192F					BIT(11)		/* Tx Error Flag Interrupt status, write 1 clear. */
+#define IMR_RXERR_8192F					BIT(10)		/* Rx Error Flag INT status, Write 1 clear */
+#define IMR_TXFOVW_8192F					BIT(9)		/* Transmit FIFO Overflow */
+#define IMR_RXFOVW_8192F 					BIT(8)		/* Receive FIFO Overflow */
+
+/* #define IMR_RX_MASK			(IMR_ROK_8192F|IMR_RDU_8192F|IMR_RXFOVW_8192F) */
+#define IMR_TX_MASK			(IMR_VODOK_8192F | IMR_VIDOK_8192F | IMR_BEDOK_8192F | IMR_BKDOK_8192F | IMR_MGNTDOK_8192F | IMR_HIGHDOK_8192F)
+#define RT_BCN_INT_MASKS		(IMR_BCNDMAINT0_8192F | IMR_TXBCN0OK_8192F | IMR_TXBCN0ERR_8192F | IMR_BCNDERR0_8192F)
+#define RT_AC_INT_MASKS		(IMR_VIDOK_8192F | IMR_VODOK_8192F | IMR_BEDOK_8192F | IMR_BKDOK_8192F)
+#endif /* CONFIG_PCI_HCI */
+
+/* 2 HSISR
+ * 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)
+
+#define _TXDMA_HIQ_MAP_8192F(x)			(((x) & 0x7) << 19)
+#define _TXDMA_MGQ_MAP_8192F(x)			(((x) & 0x7) << 16)
+#define _TXDMA_BKQ_MAP_8192F(x)			(((x) & 0x7) << 13)
+#define _TXDMA_BEQ_MAP_8192F(x)			(((x) & 0x7) << 10)
+#define _TXDMA_VIQ_MAP_8192F(x)			(((x) & 0x7) << 7)
+#define _TXDMA_VOQ_MAP_8192F(x)			(((x) & 0x7) << 4)
+
+/*mac queue info*/
+#define QUEUE_TOTAL_NUM	20/*reg414h : 0~f ac queue 0x10~0x13MGQ HIQ BCNQ CMDQ*/
+#define QUEUE_ACQ_NUM		16 
+#define QUEUE_INDEX_MGQ		0x10
+#define QUEUE_INDEX_HIQ		0x11
+#define QUEUE_INDEX_BCNQ	0x12
+#define QUEUE_INDEX_CMDQ	0x13
+#endif /* __RTL8192F_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_sreset.h
new file mode 100644
index 000000000000..a8fca762f4b8
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_sreset.h
@@ -0,0 +1,25 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8192F_SRESET_H_
+#define _RTL8192F_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8192f_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8192f_sreset_linked_status_check(_adapter *padapter);
+#endif /* DBG_CONFIG_ERROR_DETECT */
+#endif /* _RTL8192F_SRESET_H_ */
\ No newline at end of file
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_xmit.h
new file mode 100644
index 000000000000..86408d6585d9
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8192f_xmit.h
@@ -0,0 +1,532 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8192F_XMIT_H__
+#define __RTL8192F_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8192FDESC_H
+#define __INC_HAL8192FDESC_H
+
+#define RX_STATUS_DESC_SIZE_8192F		24
+#define RX_DRV_INFO_SIZE_UNIT_8192F 	8
+
+
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8192F(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8192F(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8192F(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_EOR_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_AMSDU_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_IPVER_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_IS_TCPUDP__8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_CHK_VLD_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+#define GET_RX_STATUS_DESC_FCS_OK_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#ifdef CONFIG_USB_RX_AGGREGATION
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+#endif
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_MATCH_ID_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 7)
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8192F(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8192F(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+
+
+/* Dword 0, rsvd: bit26, bit28 */
+#define GET_TX_DESC_OWN_8192F(__pTxDesc)\
+	LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+#define SET_TX_DESC_PKT_SIZE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_AMSDU_PAD_EN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+
+/* Dword 2 ADD HW_DIG*/
+#define SET_TX_DESC_PAID_92F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 0, 9, __Value)
+#define SET_TX_DESC_CCA_RTS_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL0_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL1_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_CCX_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_INT_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_HW_DIG_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 24, 7, __Value)
+
+/* Dword 3 */
+#define SET_TX_DESC_HWSEQ_SEL_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_CHK_EN_92F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 1, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_NDPA_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 22, 2, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TX_TRY_RATE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_EN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_LDPC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 7, 1, __Value)
+#define SET_TX_DESC_DATA_STBC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_RTS_STBC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_PORT_ID_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 21, 1, __Value)
+#define SET_TX_DESC_DROP_ID_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 22, 2, __Value)
+#define SET_TX_DESC_PATH_A_EN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 1, __Value)
+#define SET_TX_DESC_PATH_B_EN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 25, 1, __Value)
+#define SET_TX_DESC_TXPWR_OF_SET_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_RF_SEL_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+
+/* Dword 7 */
+#ifdef CONFIG_PCI_HCI
+#define SET_TX_DESC_TX_BUFFER_SIZE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+
+#ifdef CONFIG_USB_HCI
+#define SET_TX_DESC_TX_DESC_CHECKSUM_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+#define SET_TX_DESC_TX_TIMESTAMP_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 6, 18, __Value)
+#endif
+
+#define SET_TX_DESC_USB_TXAGG_NUM_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+/* Dword 8 */
+#define SET_TX_DESC_RTS_RC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_HWSEQ_EN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#define SET_TX_DESC_NEXTHEADPAGE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#define SET_TX_DESC_TAILPAGE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LEN_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_SEQ_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_FINAL_DATA_RATE_8192F(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 8, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_8192F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8192F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8192F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8192F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8192F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+#define SET_EARLYMODE_LEN3_8192F(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+
+/*-----------------------------------------------------------------*/
+/*	RTL8192F TX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+8, 0, 32, __Valeu)
+#else
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu)	/* 64 BIT mode only */
+#endif
+/* ********************************************************* */
+
+/* 64 bits  -- 32 bits */
+/* =======     ======= */
+/* Dword 0     0 */
+#define SET_TX_BUFF_DESC_LEN_0_8192F(__pTxDesc, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 14, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_8192F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_8192F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1     1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_8192F(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_LOW_0_8192F(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+/* Dword 2     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 0, __Value)
+#ifdef CONFIG_64BIT_DMA
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8192F(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+8, 0, 32)
+#else
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8192F(__pTxDesc) 0
+#endif
+/* Dword 3     NA */
+/* RESERVED 0 */
+/* Dword 4     2 */
+#define SET_TX_BUFF_DESC_LEN_1_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 1, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_1_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 5     3 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_1_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 6     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_1_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 7     NA */
+/*RESERVED 0 */
+/* Dword 8     4 */
+#define SET_TX_BUFF_DESC_LEN_2_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 2, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_2_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 9     5 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_2_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 10    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_2_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 11    NA */
+/*RESERVED 0 */
+/* Dword 12    6 */
+#define SET_TX_BUFF_DESC_LEN_3_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 3, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_3_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 13    7 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_3_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 14    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_3_8192F(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 15    NA */
+/*RESERVED 0 */
+
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8192F_RATE1M				0x00
+#define DESC8192F_RATE2M				0x01
+#define DESC8192F_RATE5_5M				0x02
+#define DESC8192F_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8192F_RATE6M				0x04
+#define DESC8192F_RATE9M				0x05
+#define DESC8192F_RATE12M				0x06
+#define DESC8192F_RATE18M				0x07
+#define DESC8192F_RATE24M				0x08
+#define DESC8192F_RATE36M				0x09
+#define DESC8192F_RATE48M				0x0a
+#define DESC8192F_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8192F_RATEMCS0				0x0c
+#define DESC8192F_RATEMCS1				0x0d
+#define DESC8192F_RATEMCS2				0x0e
+#define DESC8192F_RATEMCS3				0x0f
+#define DESC8192F_RATEMCS4				0x10
+#define DESC8192F_RATEMCS5				0x11
+#define DESC8192F_RATEMCS6				0x12
+#define DESC8192F_RATEMCS7				0x13
+#define DESC8192F_RATEMCS8				0x14
+#define DESC8192F_RATEMCS9				0x15
+#define DESC8192F_RATEMCS10		0x16
+#define DESC8192F_RATEMCS11		0x17
+#define DESC8192F_RATEMCS12		0x18
+#define DESC8192F_RATEMCS13		0x19
+#define DESC8192F_RATEMCS14		0x1a
+#define DESC8192F_RATEMCS15		0x1b
+#define DESC8192F_RATEVHTSS1MCS0		0x2c
+#define DESC8192F_RATEVHTSS1MCS1		0x2d
+#define DESC8192F_RATEVHTSS1MCS2		0x2e
+#define DESC8192F_RATEVHTSS1MCS3		0x2f
+#define DESC8192F_RATEVHTSS1MCS4		0x30
+#define DESC8192F_RATEVHTSS1MCS5		0x31
+#define DESC8192F_RATEVHTSS1MCS6		0x32
+#define DESC8192F_RATEVHTSS1MCS7		0x33
+#define DESC8192F_RATEVHTSS1MCS8		0x34
+#define DESC8192F_RATEVHTSS1MCS9		0x35
+#define DESC8192F_RATEVHTSS2MCS0		0x36
+#define DESC8192F_RATEVHTSS2MCS1		0x37
+#define DESC8192F_RATEVHTSS2MCS2		0x38
+#define DESC8192F_RATEVHTSS2MCS3		0x39
+#define DESC8192F_RATEVHTSS2MCS4		0x3a
+#define DESC8192F_RATEVHTSS2MCS5		0x3b
+#define DESC8192F_RATEVHTSS2MCS6		0x3c
+#define DESC8192F_RATEVHTSS2MCS7		0x3d
+#define DESC8192F_RATEVHTSS2MCS8		0x3e
+#define DESC8192F_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8192F(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8192F(pDesc) == DESC8192F_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8192F(pDesc) == DESC8192F_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8192F(pDesc) == DESC8192F_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8192F(pDesc) == DESC8192F_RATE11M)
+
+#ifdef CONFIG_TRX_BD_ARCH
+	struct tx_desc;
+#endif
+
+void rtl8192f_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+void rtl8192f_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8192f_fill_txdesc_sectype(struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8192f_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8192f_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8192f_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8192fs_init_xmit_priv(PADAPTER padapter);
+	void rtl8192fs_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8192fs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192fs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8192fs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192fs_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8192fs_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8192fs_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8192fu_init_xmit_priv(PADAPTER padapter);
+	void rtl8192fu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8192fu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192fu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8192fu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192fu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8192fu_xmit_buf_handler
+	void rtl8192fu_xmit_tasklet(void *priv);
+	s32 rtl8192fu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter,int frame_tag,struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8192fe_init_xmit_priv(PADAPTER padapter);
+	void rtl8192fe_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8192fe_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void    rtl8192fe_xmitframe_resume(_adapter *padapter);
+	s32 rtl8192fe_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8192fe_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32     rtl8192fe_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8192fe_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8192F(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8192F(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_cmd.h
index 43f7a8805cb5..9df7d97d233e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -113,7 +114,6 @@ enum h2c_cmd_8703B {
 #define SET_8703B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8703B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#define SET_8703B_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8703B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
@@ -177,7 +177,6 @@ enum h2c_cmd_8703B {
 /* host message to firmware cmd */
 void rtl8703b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8703b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
-void rtl8703b_set_rssi_cmd(PADAPTER padapter, u8 *param);
 void rtl8703b_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
 /* s32 rtl8703b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
 void rtl8703b_set_FwPsTuneParam_cmd(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_dm.h
index 912c7da079ea..1fe6a521d16b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_hal.h
index dfc9b6d70abf..7da88c2bf01a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -106,18 +107,10 @@ typedef struct _RT_8703B_FIRMWARE_HDR {
 /* Note: We will divide number of page equally for each queue other than public queue! */
 
 /* For General Reserved Page Number(Beacon Queue is reserved page)
- * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
-#define BCNQ_PAGE_NUM_8703B		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-	#define BCNQ1_PAGE_NUM_8703B		0x08 /* 0x04 */
-#else
-	#define BCNQ1_PAGE_NUM_8703B		0x00
-#endif
+ * Beacon:MAX_BEACON_LEN/PAGE_SIZE_TX_8703B
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
 
-#ifdef CONFIG_PNO_SUPPORT
-	#undef BCNQ1_PAGE_NUM_8703B
-	#define BCNQ1_PAGE_NUM_8703B		0x00 /* 0x04 */
-#endif
+#define BCNQ_PAGE_NUM_8703B		(MAX_BEACON_LEN/PAGE_SIZE_TX_8703B + 6) /*0x08*/
 
 /* For WoWLan , more reserved page
  * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1 PNO: 6
@@ -138,7 +131,7 @@ typedef struct _RT_8703B_FIRMWARE_HDR {
 	#define AP_WOWLAN_PAGE_NUM_8703B	0x02
 #endif
 
-#define TX_TOTAL_PAGE_NUMBER_8703B	(0xFF - BCNQ_PAGE_NUM_8703B - BCNQ1_PAGE_NUM_8703B - WOWLAN_PAGE_NUM_8703B)
+#define TX_TOTAL_PAGE_NUMBER_8703B	(0xFF - BCNQ_PAGE_NUM_8703B - WOWLAN_PAGE_NUM_8703B)
 #define TX_PAGE_BOUNDARY_8703B		(TX_TOTAL_PAGE_NUMBER_8703B + 1)
 
 #define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B	TX_TOTAL_PAGE_NUMBER_8703B
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_led.h
index 99e590d31bc5..4a79ce03f984 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_recv.h
index e796e6e603de..941f6289e6ed 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_rf.h
index 8d980a88fa67..28ff2f9b5600 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_spec.h
index 633b23b1bf10..a71151090dad 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_sreset.h
index 5fe53cf414a1..5433c19e1383 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_xmit.h
index 2bcd5a7b85c5..0bfb318987f8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8703b_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -184,13 +185,14 @@
 	#define SET_TX_DESC_ANTSEL_D_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
 
 	/* Dword 7 */
-	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	#ifdef CONFIG_PCI_HCI
 		#define SET_TX_DESC_TX_BUFFER_SIZE_8703B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-	#else
+	#endif /*CONFIG_PCI_HCI*/
+	#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
 		#define SET_TX_DESC_TX_DESC_CHECKSUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
 	#endif
 	#define SET_TX_DESC_USB_TXAGG_NUM_8703B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-	#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+	#ifdef CONFIG_SDIO_HCI
 		#define SET_TX_DESC_SDIO_TXSEQ_8703B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
 	#endif
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_cmd.h
new file mode 100644
index 000000000000..4112c941dcb2
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_cmd.h
@@ -0,0 +1,176 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8710B_CMD_H__
+#define __RTL8710B_CMD_H__
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD DEFINITION    ------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+enum h2c_cmd_8710B {
+	/* Common Class: 000 */
+	H2C_8710B_RSVD_PAGE = 0x00,
+	H2C_8710B_MEDIA_STATUS_RPT = 0x01,
+	H2C_8710B_SCAN_ENABLE = 0x02,
+	H2C_8710B_KEEP_ALIVE = 0x03,
+	H2C_8710B_DISCON_DECISION = 0x04,
+	H2C_8710B_PSD_OFFLOAD = 0x05,
+	H2C_8710B_AP_OFFLOAD = 0x08,
+	H2C_8710B_BCN_RSVDPAGE = 0x09,
+	H2C_8710B_PROBERSP_RSVDPAGE = 0x0A,
+	H2C_8710B_FCS_RSVDPAGE = 0x10,
+	H2C_8710B_FCS_INFO = 0x11,
+	H2C_8710B_AP_WOW_GPIO_CTRL = 0x13,
+
+	/* PoweSave Class: 001 */
+	H2C_8710B_SET_PWR_MODE = 0x20,
+	H2C_8710B_PS_TUNING_PARA = 0x21,
+	H2C_8710B_PS_TUNING_PARA2 = 0x22,
+	H2C_8710B_P2P_LPS_PARAM = 0x23,
+	H2C_8710B_P2P_PS_OFFLOAD = 0x24,
+	H2C_8710B_PS_SCAN_ENABLE = 0x25,
+	H2C_8710B_SAP_PS_ = 0x26,
+	H2C_8710B_INACTIVE_PS_ = 0x27, /* Inactive_PS */
+	H2C_8710B_FWLPS_IN_IPS_ = 0x28,
+
+	/* Dynamic Mechanism Class: 010 */
+	H2C_8710B_MACID_CFG = 0x40,
+	H2C_8710B_TXBF = 0x41,
+	H2C_8710B_RSSI_SETTING = 0x42,
+	H2C_8710B_AP_REQ_TXRPT = 0x43,
+	H2C_8710B_INIT_RATE_COLLECT = 0x44,
+	H2C_8710B_RA_PARA_ADJUST = 0x46,
+
+	/* WOWLAN Class: 100 */
+	H2C_8710B_WOWLAN = 0x80,
+	H2C_8710B_REMOTE_WAKE_CTRL = 0x81,
+	H2C_8710B_AOAC_GLOBAL_INFO = 0x82,
+	H2C_8710B_AOAC_RSVD_PAGE = 0x83,
+	H2C_8710B_AOAC_RSVD_PAGE2 = 0x84,
+	H2C_8710B_D0_SCAN_OFFLOAD_CTRL = 0x85,
+	H2C_8710B_D0_SCAN_OFFLOAD_INFO = 0x86,
+	H2C_8710B_CHNL_SWITCH_OFFLOAD = 0x87,
+	H2C_8710B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
+	H2C_8710B_P2P_OFFLOAD = 0x8B,
+
+	H2C_8710B_RESET_TSF = 0xC0,
+	H2C_8710B_MAXID,
+};
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    H2C CMD CONTENT    --------------------------------------------------
+ * ---------------------------------------------------------------------------------------------------------
+ * _RSVDPAGE_LOC_CMD_0x00 */
+#define SET_8710B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8710B_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
+#define SET_8710B_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8710B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8710B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+/* _PWR_MOD_CMD_0x20 */
+#define SET_8710B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8710B_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
+#define SET_8710B_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
+#define SET_8710B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8710B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8710B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
+#define SET_8710B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+
+#define GET_8710B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
+
+/* _PS_TUNE_PARAM_CMD_0x21 */
+#define SET_8710B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8710B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8710B_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
+#define SET_8710B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
+#define SET_8710B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _MACID_CFG_CMD_0x40 */
+#define SET_8710B_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
+#define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
+
+/* _RSSI_SETTING_CMD_0x42 */
+#define SET_8710B_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8710B_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
+#define SET_8710B_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+
+/* _AP_REQ_TXRPT_CMD_0x43 */
+#define SET_8710B_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+#define SET_8710B_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value)		SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+
+/* _FORCE_BT_TXPWR_CMD_0x62 */
+#define SET_8710B_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
+
+/* _FORCE_BT_MP_OPER_CMD_0x67 */
+#define SET_8710B_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
+#define SET_8710B_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
+#define SET_8710B_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
+#define SET_8710B_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
+#define SET_8710B_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
+#define SET_8710B_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value)							SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
+
+/* _BT_FW_PATCH_0x6A */
+#define SET_8710B_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)					SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
+#define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
+#define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
+#define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
+#define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value)					SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
+
+/* ---------------------------------------------------------------------------------------------------------
+ * -------------------------------------------    Structure    --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+
+/* ---------------------------------------------------------------------------------------------------------
+ * ----------------------------------    Function Statement     --------------------------------------------------
+ * --------------------------------------------------------------------------------------------------------- */
+
+/* host message to firmware cmd */
+void rtl8710b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
+void rtl8710b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
+/* s32 rtl8710b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
+void rtl8710b_set_FwPsTuneParam_cmd(PADAPTER padapter);
+void rtl8710b_download_rsvd_page(PADAPTER padapter, u8 mstatus);
+#ifdef CONFIG_BT_COEXIST
+	void rtl8710b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
+#endif /* CONFIG_BT_COEXIST */
+#ifdef CONFIG_P2P
+	void rtl8710b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_TDLS
+#ifdef CONFIG_TDLS_CH_SW
+void rtl8710b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
+#endif
+#endif
+
+#ifdef CONFIG_P2P_WOWLAN
+	void rtl8710b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
+#endif
+
+s32 FillH2CCmd8710B(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
+u8 GetTxBufferRsvdPageNum8710B(_adapter *padapter, bool wowlan);
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_dm.h
new file mode 100644
index 000000000000..56412d62efe7
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_dm.h
@@ -0,0 +1,40 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8710B_DM_H__
+#define __RTL8710B_DM_H__
+/* ************************************************************
+ * Description:
+ *
+ * This file is for 8710B dynamic mechanism only
+ *
+ *
+ * ************************************************************ */
+
+/* ************************************************************
+ * structure and define
+ * ************************************************************ */
+
+/* ************************************************************
+ * function prototype
+ * ************************************************************ */
+
+void rtl8710b_init_dm_priv(PADAPTER padapter);
+void rtl8710b_deinit_dm_priv(PADAPTER padapter);
+
+void rtl8710b_InitHalDm(PADAPTER padapter);
+void rtl8710b_HalDmWatchDog(PADAPTER padapter);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_hal.h
new file mode 100644
index 000000000000..1ae2cba8e1d4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_hal.h
@@ -0,0 +1,278 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8710B_HAL_H__
+#define __RTL8710B_HAL_H__
+
+#include "hal_data.h"
+
+#include "rtl8710b_spec.h"
+#include "rtl8710b_rf.h"
+#include "rtl8710b_dm.h"
+#include "rtl8710b_recv.h"
+#include "rtl8710b_xmit.h"
+#include "rtl8710b_cmd.h"
+#include "rtl8710b_led.h"
+#include "Hal8710BPwrSeq.h"
+#include "Hal8710BPhyReg.h"
+#include "Hal8710BPhyCfg.h"
+#ifdef DBG_CONFIG_ERROR_DETECT
+	#include "rtl8710b_sreset.h"
+#endif
+#ifdef CONFIG_LPS_POFF
+	#include "rtl8710b_lps_poff.h"
+#endif
+
+#define FW_8710B_SIZE		0x8000
+#define FW_8710B_START_ADDRESS	0x1000
+#define FW_8710B_END_ADDRESS	0x1FFF /* 0x5FFF */
+
+typedef struct _RT_FIRMWARE {
+	FIRMWARE_SOURCE	eFWSource;
+#ifdef CONFIG_EMBEDDED_FWIMG
+	u8			*szFwBuffer;
+#else
+	u8			szFwBuffer[FW_8710B_SIZE];
+#endif
+	u32			ulFwLength;
+} RT_FIRMWARE_8710B, *PRT_FIRMWARE_8710B;
+
+/*
+ * This structure must be cared byte-ordering
+ *
+ * Added by tynli. 2009.12.04. */
+typedef struct _RT_8710B_FIRMWARE_HDR {
+	/* 8-byte alinment required */
+
+	/* --- LONG WORD 0 ---- */
+	u16		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 */
+	u16		Version;		/* FW Version */
+	u16		Subversion;	/* FW Subversion, default 0x00 */
+
+	/* --- 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 */
+	u16		RamCodeSize;	/* The size of RAM code */
+	u16		Rsvd2;
+
+	/* --- LONG WORD 2 ---- */
+	u32		SvnIdx;	/* The SVN entry index */
+	u32		Rsvd3;
+
+	/* --- LONG WORD 3 ---- */
+	u32		Rsvd4;
+	u32		Rsvd5;
+} RT_8710B_FIRMWARE_HDR, *PRT_8710B_FIRMWARE_HDR;
+
+#define DRIVER_EARLY_INT_TIME_8710B		0x05
+#define BCN_DMA_ATIME_INT_TIME_8710B		0x02
+
+/* for 8710B
+ * TX 32K, RX 16K, Page size 128B for TX, 8B for RX */
+#define PAGE_SIZE_TX_8710B			128
+#define PAGE_SIZE_RX_8710B			8
+
+#define TX_DMA_SIZE_8710B			0x8000	/* 32K(TX) */
+#define RX_DMA_SIZE_8710B			0x4000	/* 16K(RX) */
+
+#ifdef CONFIG_WOWLAN
+	#define RESV_FMWF	(WKFMCAM_SIZE * MAX_WKFM_CAM_NUM) /* 16 entries, for each is 24 bytes*/
+#else
+	#define RESV_FMWF	0
+#endif
+
+#ifdef CONFIG_FW_C2H_DEBUG
+	#define RX_DMA_RESERVED_SIZE_8710B	0x100	/* 256B, reserved for c2h debug message */
+#else
+	#define RX_DMA_RESERVED_SIZE_8710B	0x80	/* 128B, reserved for tx report */
+#endif
+#define RX_DMA_BOUNDARY_8710B\
+	(RX_DMA_SIZE_8710B - RX_DMA_RESERVED_SIZE_8710B - 1)
+
+
+/* Note: We will divide number of page equally for each queue other than public queue! */
+
+/* For General Reserved Page Number(Beacon Queue is reserved page)
+ * Beacon:MAX_BEACON_LEN/PAGE_SIZE_TX_8710B
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
+#define BCNQ_PAGE_NUM_8710B	(MAX_BEACON_LEN/PAGE_SIZE_TX_8710B + 6) /*0x08*/
+
+
+/* For WoWLan , more reserved page
+ * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt 1, PNO: 6
+ * NS offload: 2 NDP info: 1
+ */
+#ifdef CONFIG_WOWLAN
+	#define WOWLAN_PAGE_NUM_8710B	0x0b
+#else
+	#define WOWLAN_PAGE_NUM_8710B	0x00
+#endif
+
+#ifdef CONFIG_PNO_SUPPORT
+	#undef WOWLAN_PAGE_NUM_8710B
+	#define WOWLAN_PAGE_NUM_8710B	0x15
+#endif
+
+#ifdef CONFIG_AP_WOWLAN
+	#define AP_WOWLAN_PAGE_NUM_8710B	0x02
+#endif
+
+#define TX_TOTAL_PAGE_NUMBER_8710B\
+	(0xFF - BCNQ_PAGE_NUM_8710B -WOWLAN_PAGE_NUM_8710B)
+#define TX_PAGE_BOUNDARY_8710B		(TX_TOTAL_PAGE_NUMBER_8710B + 1)
+
+#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8710B	TX_TOTAL_PAGE_NUMBER_8710B
+#define WMM_NORMAL_TX_PAGE_BOUNDARY_8710B\
+	(WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8710B + 1)
+
+/* For Normal Chip Setting
+ * (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER_8710B */
+#define NORMAL_PAGE_NUM_HPQ_8710B		0x0C
+#define NORMAL_PAGE_NUM_LPQ_8710B		0x02
+#define NORMAL_PAGE_NUM_NPQ_8710B		0x02
+#define NORMAL_PAGE_NUM_EPQ_8710B		0x04
+
+/* Note: For Normal Chip Setting, modify later */
+#define WMM_NORMAL_PAGE_NUM_HPQ_8710B		0x30
+#define WMM_NORMAL_PAGE_NUM_LPQ_8710B		0x20
+#define WMM_NORMAL_PAGE_NUM_NPQ_8710B		0x20
+#define WMM_NORMAL_PAGE_NUM_EPQ_8710B		0x00
+
+
+#include "HalVerDef.h"
+#include "hal_com.h"
+
+#define EFUSE_OOB_PROTECT_BYTES (96 + 1)
+
+#define HAL_EFUSE_MEMORY
+#define HWSET_MAX_SIZE_8710B                512
+#define EFUSE_REAL_CONTENT_LEN_8710B        512
+#define EFUSE_MAP_LEN_8710B                 512
+#define EFUSE_MAX_SECTION_8710B             64
+
+/* For some inferiority IC purpose. added by Roger, 2009.09.02.*/
+#define EFUSE_IC_ID_OFFSET			506
+#define AVAILABLE_EFUSE_ADDR(addr)	(addr < EFUSE_REAL_CONTENT_LEN_8710B)
+
+#define EFUSE_ACCESS_ON	0x69
+#define EFUSE_ACCESS_OFF	0x00
+
+#define   PACKAGE_QFN32_S           0
+#define   PACKAGE_QFN48M_S        1    //definiton 8188GU Dongle Package, Efuse Physical Address 0xF8 = 0xFE
+#define   PACKAGE_QFN48_S  	       2
+#define   PACKAGE_QFN64_S  	       3     
+#define   PACKAGE_QFN32_U  		4    
+#define   PACKAGE_QFN48M_U  	5   //definiton 8188GU Dongle Package, Efuse Physical Address 0xF8 = 0xEE
+#define   PACKAGE_QFN48_U  		6 
+#define   PACKAGE_QFN68_U  		7
+
+typedef enum _PACKAGE_TYPE_E
+{
+    PACKAGE_DEFAULT,
+    PACKAGE_QFN68,
+    PACKAGE_TFBGA90,
+    PACKAGE_TFBGA80,
+    PACKAGE_TFBGA79
+}PACKAGE_TYPE_E;
+
+#define INCLUDE_MULTI_FUNC_GPS(_Adapter) \
+	(GET_HAL_DATA(_Adapter)->MultiFunc & RT_MULTI_FUNC_GPS)
+
+#ifdef CONFIG_FILE_FWIMG
+	extern char *rtw_fw_file_path;
+	extern char *rtw_fw_wow_file_path;
+	#ifdef CONFIG_MP_INCLUDED
+		extern char *rtw_fw_mp_bt_file_path;
+	#endif /* CONFIG_MP_INCLUDED */
+#endif /* CONFIG_FILE_FWIMG */
+
+/* rtl8710b_hal_init.c */
+s32 rtl8710b_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw);
+void rtl8710b_FirmwareSelfReset(PADAPTER padapter);
+void rtl8710b_InitializeFirmwareVars(PADAPTER padapter);
+
+void rtl8710b_InitAntenna_Selection(PADAPTER padapter);
+void rtl8710b_DeinitAntenna_Selection(PADAPTER padapter);
+void rtl8710b_CheckAntenna_Selection(PADAPTER padapter);
+void rtl8710b_init_default_value(PADAPTER padapter);
+
+
+u32 indirect_read32_8710b(PADAPTER padapter, u32 regaddr);
+VOID indirect_write32_8710b(PADAPTER padapter, u32 regaddr, u32 data);
+u32 hal_query_syson_reg_8710b(PADAPTER padapter, u32 regaddr, u32 bitmask);
+VOID hal_set_syson_reg_8710b(PADAPTER padapter, u32 regaddr, u32 bitmask, u32 data);
+#define HAL_SetSYSOnReg hal_set_syson_reg_8710b
+
+
+/* EFuse */
+u8 GetEEPROMSize8710B(PADAPTER padapter);
+
+#if 0
+void Hal_InitPGData(PADAPTER padapter, u8 *PROMContent);
+void Hal_EfuseParseIDCode(PADAPTER padapter, u8 *hwinfo);
+void Hal_EfuseParseTxPowerInfo_8710B(PADAPTER padapter,
+				     u8 *PROMContent, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseEEPROMVer_8710B(PADAPTER padapter,
+				   u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParsePackageType_8710B(PADAPTER pAdapter,
+				     u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseChnlPlan_8710B(PADAPTER padapter,
+				  u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseCustomerID_8710B(PADAPTER padapter,
+				    u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseAntennaDiversity_8710B(PADAPTER padapter,
+		u8 *hwinfo, BOOLEAN AutoLoadFail);
+void Hal_EfuseParseXtal_8710B(PADAPTER pAdapter,
+			      u8 *hwinfo, u8 AutoLoadFail);
+void Hal_EfuseParseThermalMeter_8710B(PADAPTER padapter,
+				      u8 *hwinfo, u8 AutoLoadFail);
+VOID Hal_EfuseParseBoardType_8710B(PADAPTER Adapter,
+				   u8	*PROMContent, BOOLEAN AutoloadFail);
+#endif
+
+void rtl8710b_set_hal_ops(struct hal_ops *pHalFunc);
+void init_hal_spec_8710b(_adapter *adapter);
+u8 SetHwReg8710B(PADAPTER padapter, u8 variable, u8 *val);
+void GetHwReg8710B(PADAPTER padapter, u8 variable, u8 *val);
+u8 SetHalDefVar8710B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+u8 GetHalDefVar8710B(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
+
+/* register */
+void rtl8710b_InitBeaconParameters(PADAPTER padapter);
+void rtl8710b_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
+void _8051Reset8710(PADAPTER padapter);
+
+void rtl8710b_start_thread(_adapter *padapter);
+void rtl8710b_stop_thread(_adapter *padapter);
+
+#ifdef CONFIG_GPIO_WAKEUP
+	void HalSetOutPutGPIO(PADAPTER padapter, u8 index, u8 OutPutValue);
+#endif
+
+void CCX_FwC2HTxRpt_8710b(PADAPTER padapter, u8 *pdata, u8 len);
+
+u8 MRateToHwRate8710B(u8 rate);
+u8 HwRateToMRate8710B(u8 rate);
+
+#ifdef CONFIG_USB_HCI
+	void rtl8710b_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+#endif
+
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_led.h
new file mode 100644
index 000000000000..1077b595f4ce
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_led.h
@@ -0,0 +1,45 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8710B_LED_H__
+#define __RTL8710B_LED_H__
+
+#include <drv_conf.h>
+#include <osdep_service.h>
+#include <drv_types.h>
+
+#ifdef CONFIG_RTW_SW_LED
+/* ********************************************************************************
+ * Interface to manipulate LED objects.
+ * ******************************************************************************** */
+#ifdef CONFIG_USB_HCI
+	void rtl8710bu_InitSwLeds(PADAPTER padapter);
+	void rtl8710bu_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_SDIO_HCI
+	void rtl8710bs_InitSwLeds(PADAPTER padapter);
+	void rtl8710bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_GSPI_HCI
+	void rtl8710bs_InitSwLeds(PADAPTER padapter);
+	void rtl8710bs_DeInitSwLeds(PADAPTER padapter);
+#endif
+#ifdef CONFIG_PCI_HCI
+	void rtl8710be_InitSwLeds(PADAPTER padapter);
+	void rtl8710be_DeInitSwLeds(PADAPTER padapter);
+#endif
+
+#endif /*#ifdef CONFIG_RTW_SW_LED*/
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_lps_poff.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_lps_poff.h
new file mode 100644
index 000000000000..0528d3774a67
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_lps_poff.h
@@ -0,0 +1,57 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+/******************************************** CONST  ************************/
+#define NUM_OF_REGISTER_BANK	13
+#define NUM_OF_TOTAL_DWORD (NUM_OF_REGISTER_BANK * 64)
+#define TOTAL_LEN_FOR_HIOE ((NUM_OF_TOTAL_DWORD + 1) * 8)
+#define LPS_POFF_STATIC_FILE_LEN (TOTAL_LEN_FOR_HIOE + TXDESC_SIZE)
+#define LPS_POFF_DYNAMIC_FILE_LEN	(512 + TXDESC_SIZE)
+/******************************************** CONST  ************************/
+
+/******************************************** MACRO   ************************/
+/* HOIE Entry Definition */
+#define SET_HOIE_ENTRY_LOW_DATA(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE),	0, 16, __Value)
+#define SET_HOIE_ENTRY_HIGH_DATA(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE), 16, 16, __Value)
+#define SET_HOIE_ENTRY_MODE_SELECT(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 0, 1, __Value)
+#define SET_HOIE_ENTRY_ADDRESS(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 1, 14, __Value)
+#define SET_HOIE_ENTRY_BYTE_MASK(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 15, 4, __Value)
+#define SET_HOIE_ENTRY_IO_LOCK(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 19, 1, __Value)
+#define SET_HOIE_ENTRY_RD_EN(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 20, 1, __Value)
+#define SET_HOIE_ENTRY_WR_EN(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 21, 1, __Value)
+#define SET_HOIE_ENTRY_RAW_RW(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 22, 1, __Value)
+#define SET_HOIE_ENTRY_RAW(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 23, 1, __Value)
+#define SET_HOIE_ENTRY_IO_DELAY(__pHOIE, __Value) \
+	SET_BITS_TO_LE_4BYTE((__pHOIE)+4, 24, 8, __Value)
+
+/*********************Function Definition*******************************************/
+void rtl8710b_lps_poff_init(PADAPTER padapter);
+void rtl8710b_lps_poff_deinit(PADAPTER padapter);
+bool rtl8710b_lps_poff_get_txbndy_status(PADAPTER padapter);
+void rtl8710b_lps_poff_h2c_ctrl(PADAPTER padapter, u8 enable);
+void rtl8710b_lps_poff_set_ps_mode(PADAPTER padapter, bool bEnterLPS);
+bool rtl8710b_lps_poff_get_status(PADAPTER padapter);
+void rtl8710b_lps_poff_wow(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_recv.h
new file mode 100644
index 000000000000..69e2c633b708
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_recv.h
@@ -0,0 +1,86 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8710B_RECV_H__
+#define __RTL8710B_RECV_H__
+
+#define RECV_BLK_SZ 512
+#define RECV_BLK_CNT 16
+#define RECV_BLK_TH RECV_BLK_CNT
+
+#if defined(CONFIG_USB_HCI)
+	#ifndef MAX_RECVBUF_SZ
+		#ifdef PLATFORM_OS_CE
+			#define MAX_RECVBUF_SZ (8192+1024) /* 8K+1k */
+		#else
+			#ifdef CONFIG_MINIMAL_MEMORY_USAGE
+				#define MAX_RECVBUF_SZ (4000) /* about 4K */
+			#else
+				#ifdef CONFIG_PLATFORM_MSTAR
+					#define MAX_RECVBUF_SZ (8192) /* 8K */
+				#elif defined(CONFIG_PLATFORM_HISILICON)
+					#define MAX_RECVBUF_SZ (16384) /* 16k */
+				#else
+					#define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
+					/* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
+					/* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
+					/* #define MAX_RECVBUF_SZ (10240)  */ /* 10K */
+					/* #define MAX_RECVBUF_SZ (16384) */ /* 16k - 92E RX BUF :16K */
+				#endif
+			#endif
+		#endif
+	#endif /* !MAX_RECVBUF_SZ */
+#endif
+
+/* Rx smooth factor */
+#define	Rx_Smooth_Factor (20)
+
+/*-----------------------------------------------------------------*/
+/*	RTL8710B RX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+/*DWORD 0*/
+#define SET_RX_BUFFER_DESC_DATA_LENGTH_8710B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_BUFFER_DESC_LS_8710B(__pRxStatusDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
+#define SET_RX_BUFFER_DESC_FS_8710B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 1, __Value)
+#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8710B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 15, __Value)
+
+#define GET_RX_BUFFER_DESC_OWN_8710B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+#define GET_RX_BUFFER_DESC_LS_8710B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_BUFFER_DESC_FS_8710B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 1)
+#ifdef USING_RX_TAG
+	#define GET_RX_BUFFER_DESC_RX_TAG_8710B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 13)
+#else
+	#define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8710B(__pRxStatusDesc)		LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
+#endif
+
+/*DWORD 1*/
+#define SET_RX_BUFFER_PHYSICAL_LOW_8710B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
+
+/*DWORD 2*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8710B(__pRxStatusDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
+#else
+	#define SET_RX_BUFFER_PHYSICAL_HIGH_8710B(__pRxStatusDesc, __Value)
+#endif
+
+#ifdef CONFIG_USB_HCI
+	int rtl8710bu_init_recv_priv(_adapter *padapter);
+	void rtl8710bu_free_recv_priv(_adapter *padapter);
+	void rtl8710bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
+#endif
+
+void rtl8710b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
+
+#endif /* __RTL8710B_RECV_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723bwifionly.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_rf.h
similarity index 74%
rename from drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723bwifionly.h
rename to drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_rf.h
index 9d386644318a..feb34c9106c2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/hal/btc/halbtc8723bwifionly.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_rf.h
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2016 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
  *
  * 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
@@ -12,11 +13,9 @@
  * more details.
  *
  *****************************************************************************/
-#ifndef __INC_HAL8723BWIFIONLYHWCFG_H
-#define __INC_HAL8723BWIFIONLYHWCFG_H
+#ifndef __RTL8710B_RF_H__
+#define __RTL8710B_RF_H__
+
+int PHY_RF6052_Config8710B(IN PADAPTER pdapter);
 
-VOID
-ex_hal8723b_wifi_only_hw_config(
-	IN struct wifi_only_cfg *pwifionlycfg
-	);
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_spec.h
new file mode 100644
index 000000000000..171144208dd1
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_spec.h
@@ -0,0 +1,482 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8710B_SPEC_H__
+#define __RTL8710B_SPEC_H__
+
+#include <drv_conf.h>
+
+
+#define HAL_NAV_UPPER_UNIT_8710B		128		/* micro-second */
+
+/* -----------------------------------------------------
+ *
+ *	0x0000h ~ 0x00FFh	System Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_SYS_ISO_CTRL_8710B			0x0000	/* 2 Byte */
+#define REG_APS_FSMCO_8710B			0x0004	/* 4 Byte */
+#define REG_SYS_CLKR_8710B				0x0008	/* 2 Byte */
+#define REG_9346CR_8710B				0x000A	/* 2 Byte */
+#define REG_EE_VPD_8710B				0x000C	/* 2 Byte */
+#define REG_AFE_MISC_8710B				0x0010	/* 1 Byte */
+#define REG_SPS0_CTRL_8710B				0x0011	/* 7 Byte */
+#define REG_SPS_OCP_CFG_8710B			0x0018	/* 4 Byte */
+#define REG_RSV_CTRL_8710B				0x001C	/* 3 Byte */
+#define REG_RF_CTRL_8710B				0x001F	/* 1 Byte */
+#define REG_LPLDO_CTRL_8710B			0x0023	/* 1 Byte */
+#define REG_AFE_XTAL_CTRL_8710B		0x0024	/* 4 Byte */
+#define REG_AFE_PLL_CTRL_8710B			0x0028	/* 4 Byte */
+#define REG_MAC_PLL_CTRL_EXT_8710B		0x002c	/* 4 Byte */
+#define REG_EFUSE_CTRL_8710B			0x0030
+#define REG_EFUSE_TEST_8710B			0x0034
+#define REG_PWR_DATA_8710B				0x0038
+#define REG_CAL_TIMER_8710B				0x003C
+#define REG_ACLK_MON_8710B				0x003E
+#define REG_GPIO_MUXCFG_8710B			0x0040
+#define REG_GPIO_IO_SEL_8710B			0x0042
+#define REG_MAC_PINMUX_CFG_8710B		0x0043
+#define REG_GPIO_PIN_CTRL_8710B			0x0044
+#define REG_GPIO_INTM_8710B				0x0048
+#define REG_LEDCFG0_8710B				0x004C
+#define REG_LEDCFG1_8710B				0x004D
+#define REG_LEDCFG2_8710B				0x004E
+#define REG_LEDCFG3_8710B				0x004F
+#define REG_FSIMR_8710B					0x0050
+#define REG_FSISR_8710B					0x0054
+#define REG_HSIMR_8710B					0x0058
+#define REG_HSISR_8710B					0x005c
+#define REG_GPIO_EXT_CTRL				0x0060
+#define REG_PAD_CTRL1_8710B		0x0064
+#define REG_MULTI_FUNC_CTRL_8710B		0x0068
+#define REG_GPIO_STATUS_8710B			0x006C
+#define REG_SDIO_CTRL_8710B				0x0070
+#define REG_OPT_CTRL_8710B				0x0074
+#define REG_AFE_CTRL_4_8710B		0x0078
+#define REG_MCUFWDL_8710B				0x0080
+#define REG_8051FW_CTRL_8710B			0x0080
+#define REG_HMEBOX_DBG_0_8710B	0x0088
+#define REG_HMEBOX_DBG_1_8710B	0x008A
+#define REG_HMEBOX_DBG_2_8710B	0x008C
+#define REG_HMEBOX_DBG_3_8710B	0x008E
+#define REG_WLLPS_CTRL		0x0090
+
+#define REG_PMC_DBG_CTRL2_8710B			0x00CC
+#define	REG_EFUSE_BURN_GNT_8710B		0x00CF
+#define REG_HPON_FSM_8710B				0x00EC
+#define REG_SYS_CFG1_8710B				0x00F0
+#define REG_SYS_CFG_8710B				0x00FC
+#define REG_ROM_VERSION					0x00FD
+
+/* -----------------------------------------------------
+ *
+ *	0x0100h ~ 0x01FFh	MACTOP General Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_C2HEVT_CMD_ID_8710B	0x01A0
+#define REG_C2HEVT_CMD_SEQ_88XX		0x01A1
+#define REG_C2hEVT_CMD_CONTENT_88XX	0x01A2
+#define REG_C2HEVT_CMD_LEN_8710B        0x01AE
+#define REG_C2HEVT_CLEAR_8710B			0x01AF
+#define REG_MCUTST_1_8710B				0x01C0
+#define REG_WOWLAN_WAKE_REASON 0x01C7
+#define REG_FMETHR_8710B				0x01C8
+#define REG_HMETFR_8710B				0x01CC
+#define REG_HMEBOX_0_8710B				0x01D0
+#define REG_HMEBOX_1_8710B				0x01D4
+#define REG_HMEBOX_2_8710B				0x01D8
+#define REG_HMEBOX_3_8710B				0x01DC
+#define REG_LLT_INIT_8710B				0x01E0
+#define REG_HMEBOX_EXT0_8710B			0x01F0
+#define REG_HMEBOX_EXT1_8710B			0x01F4
+#define REG_HMEBOX_EXT2_8710B			0x01F8
+#define REG_HMEBOX_EXT3_8710B			0x01FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0200h ~ 0x027Fh	TXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RQPN_8710B					0x0200
+#define REG_FIFOPAGE_8710B				0x0204
+#define REG_DWBCN0_CTRL_8710B			REG_TDECTRL
+#define REG_TXDMA_OFFSET_CHK_8710B	0x020C
+#define REG_TXDMA_STATUS_8710B		0x0210
+#define REG_RQPN_NPQ_8710B			0x0214
+#define REG_DWBCN1_CTRL_8710B			0x0228
+
+
+/* -----------------------------------------------------
+ *
+ *	0x0280h ~ 0x02FFh	RXDMA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_RXDMA_AGG_PG_TH_8710B		0x0280
+#define REG_FW_UPD_RDPTR_8710B		0x0284 /* FW shall update this register before FW write RXPKT_RELEASE_POLL to 1 */
+#define REG_RXDMA_CONTROL_8710B		0x0286 /* Control the RX DMA. */
+#define REG_RXDMA_STATUS_8710B			0x0288
+#define REG_RXDMA_MODE_CTRL_8710B		0x0290
+#define REG_EARLY_MODE_CONTROL_8710B	0x02BC
+#define REG_RSVD5_8710B					0x02F0
+#define REG_RSVD6_8710B					0x02F4
+
+/* -----------------------------------------------------
+ *
+ *	0x0300h ~ 0x03FFh	PCIe
+ *
+ * ----------------------------------------------------- */
+#define	REG_PCIE_CTRL_REG_8710B			0x0300
+#define	REG_INT_MIG_8710B				0x0304	/* Interrupt Migration */
+#define	REG_BCNQ_TXBD_DESA_8710B		0x0308	/* TX Beacon Descriptor Address */
+#define	REG_MGQ_TXBD_DESA_8710B			0x0310	/* TX Manage Queue Descriptor Address */
+#define	REG_VOQ_TXBD_DESA_8710B			0x0318	/* TX VO Queue Descriptor Address */
+#define	REG_VIQ_TXBD_DESA_8710B			0x0320	/* TX VI Queue Descriptor Address */
+#define	REG_BEQ_TXBD_DESA_8710B			0x0328	/* TX BE Queue Descriptor Address */
+#define	REG_BKQ_TXBD_DESA_8710B			0x0330	/* TX BK Queue Descriptor Address */
+#define	REG_RXQ_RXBD_DESA_8710B			0x0338	/* RX Queue	Descriptor Address */
+#define REG_HI0Q_TXBD_DESA_8710B		0x0340
+#define REG_HI1Q_TXBD_DESA_8710B		0x0348
+#define REG_HI2Q_TXBD_DESA_8710B		0x0350
+#define REG_HI3Q_TXBD_DESA_8710B		0x0358
+#define REG_HI4Q_TXBD_DESA_8710B		0x0360
+#define REG_HI5Q_TXBD_DESA_8710B		0x0368
+#define REG_HI6Q_TXBD_DESA_8710B		0x0370
+#define REG_HI7Q_TXBD_DESA_8710B		0x0378
+#define	REG_MGQ_TXBD_NUM_8710B			0x0380
+#define	REG_RX_RXBD_NUM_8710B			0x0382
+#define	REG_VOQ_TXBD_NUM_8710B			0x0384
+#define	REG_VIQ_TXBD_NUM_8710B			0x0386
+#define	REG_BEQ_TXBD_NUM_8710B			0x0388
+#define	REG_BKQ_TXBD_NUM_8710B			0x038A
+#define	REG_HI0Q_TXBD_NUM_8710B			0x038C
+#define	REG_HI1Q_TXBD_NUM_8710B			0x038E
+#define	REG_HI2Q_TXBD_NUM_8710B			0x0390
+#define	REG_HI3Q_TXBD_NUM_8710B			0x0392
+#define	REG_HI4Q_TXBD_NUM_8710B			0x0394
+#define	REG_HI5Q_TXBD_NUM_8710B			0x0396
+#define	REG_HI6Q_TXBD_NUM_8710B			0x0398
+#define	REG_HI7Q_TXBD_NUM_8710B			0x039A
+#define	REG_TSFTIMER_HCI_8710B			0x039C
+#define	REG_BD_RW_PTR_CLR_8710B			0x039C
+
+/* Read Write Point */
+#define	REG_VOQ_TXBD_IDX_8710B			0x03A0
+#define	REG_VIQ_TXBD_IDX_8710B			0x03A4
+#define	REG_BEQ_TXBD_IDX_8710B			0x03A8
+#define	REG_BKQ_TXBD_IDX_8710B			0x03AC
+#define	REG_MGQ_TXBD_IDX_8710B			0x03B0
+#define	REG_RXQ_TXBD_IDX_8710B			0x03B4
+#define	REG_HI0Q_TXBD_IDX_8710B			0x03B8
+#define	REG_HI1Q_TXBD_IDX_8710B			0x03BC
+#define	REG_HI2Q_TXBD_IDX_8710B			0x03C0
+#define	REG_HI3Q_TXBD_IDX_8710B			0x03C4
+#define	REG_HI4Q_TXBD_IDX_8710B			0x03C8
+#define	REG_HI5Q_TXBD_IDX_8710B			0x03CC
+#define	REG_HI6Q_TXBD_IDX_8710B			0x03D0
+#define	REG_HI7Q_TXBD_IDX_8710B			0x03D4
+
+#define	REG_PCIE_HCPWM_8710BE			0x03D8 /* ?????? */
+#define	REG_PCIE_HRPWM_8710BE			0x03DC	/* PCIe RPWM  ?????? */
+#define	REG_DBI_WDATA_V1_8710B			0x03E8
+#define	REG_DBI_RDATA_V1_8710B			0x03EC
+#define	REG_DBI_FLAG_V1_8710B			0x03F0
+#define REG_MDIO_V1_8710B				0x03F4
+#define REG_PCIE_MIX_CFG_8710B			0x03F8
+#define REG_HCI_MIX_CFG_8710B			0x03FC
+
+/* -----------------------------------------------------
+ *
+ *	0x0400h ~ 0x047Fh	Protocol Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_VOQ_INFORMATION_8710B		0x0400
+#define REG_VIQ_INFORMATION_8710B		0x0404
+#define REG_BEQ_INFORMATION_8710B		0x0408
+#define REG_BKQ_INFORMATION_8710B		0x040C
+#define REG_MGQ_INFORMATION_8710B		0x0410
+#define REG_HGQ_INFORMATION_8710B		0x0414
+#define REG_BCNQ_INFORMATION_8710B	0x0418
+#define REG_TXPKT_EMPTY_8710B			0x041A
+
+#define REG_FWHW_TXQ_CTRL_8710B		0x0420
+#define REG_HWSEQ_CTRL_8710B			0x0423
+#define REG_TXPKTBUF_BCNQ_BDNY_8710B	0x0424
+#define REG_TXPKTBUF_MGQ_BDNY_8710B	0x0425
+#define REG_LIFECTRL_CTRL_8710B			0x0426
+#define REG_MULTI_BCNQ_OFFSET_8710B	0x0427
+#define REG_SPEC_SIFS_8710B				0x0428
+#define REG_RL_8710B						0x042A
+#define REG_TXBF_CTRL_8710B				0x042C
+#define REG_DARFRC_8710B				0x0430
+#define REG_RARFRC_8710B				0x0438
+#define REG_RRSR_8710B					0x0440
+#define REG_ARFR0_8710B					0x0444
+#define REG_ARFR1_8710B					0x044C
+#define REG_CCK_CHECK_8710B				0x0454
+#define REG_AMPDU_MAX_TIME_8710B		0x0456
+#define REG_TXPKTBUF_BCNQ_BDNY1_8710B	0x0457
+
+#define REG_AMPDU_MAX_LENGTH_8710B	0x0458
+#define REG_TXPKTBUF_WMAC_LBK_BF_HD_8710B	0x045D
+#define REG_NDPA_OPT_CTRL_8710B		0x045F
+#define REG_FAST_EDCA_CTRL_8710B		0x0460
+#define REG_RD_RESP_PKT_TH_8710B		0x0463
+#define REG_DATA_SC_8710B				0x0483
+#ifdef CONFIG_WOWLAN
+	#define REG_TXPKTBUF_IV_LOW             0x0484
+	#define REG_TXPKTBUF_IV_HIGH            0x0488
+#endif
+#define REG_TXRPT_START_OFFSET		0x04AC
+#define REG_POWER_STAGE1_8710B		0x04B4
+#define REG_POWER_STAGE2_8710B		0x04B8
+#define REG_AMPDU_BURST_MODE_8710B	0x04BC
+#define REG_PKT_VO_VI_LIFE_TIME_8710B	0x04C0
+#define REG_PKT_BE_BK_LIFE_TIME_8710B	0x04C2
+#define REG_STBC_SETTING_8710B			0x04C4
+#define REG_HT_SINGLE_AMPDU_8710B		0x04C7
+#define REG_PROT_MODE_CTRL_8710B		0x04C8
+#define REG_MAX_AGGR_NUM_8710B		0x04CA
+#define REG_RTS_MAX_AGGR_NUM_8710B	0x04CB
+#define REG_BAR_MODE_CTRL_8710B		0x04CC
+#define REG_RA_TRY_RATE_AGG_LMT_8710B	0x04CF
+#define REG_MACID_PKT_DROP0_8710B		0x04D0
+#define REG_MACID_PKT_SLEEP_8710B		0x04D4
+
+/* -----------------------------------------------------
+ *
+ *	0x0500h ~ 0x05FFh	EDCA Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_EDCA_VO_PARAM_8710B		0x0500
+#define REG_EDCA_VI_PARAM_8710B		0x0504
+#define REG_EDCA_BE_PARAM_8710B		0x0508
+#define REG_EDCA_BK_PARAM_8710B		0x050C
+#define REG_BCNTCFG_8710B				0x0510
+#define REG_PIFS_8710B					0x0512
+#define REG_RDG_PIFS_8710B				0x0513
+#define REG_SIFS_CTX_8710B				0x0514
+#define REG_SIFS_TRX_8710B				0x0516
+#define REG_AGGR_BREAK_TIME_8710B		0x051A
+#define REG_SLOT_8710B					0x051B
+#define REG_TX_PTCL_CTRL_8710B			0x0520
+#define REG_TXPAUSE_8710B				0x0522
+#define REG_DIS_TXREQ_CLR_8710B		0x0523
+#define REG_RD_CTRL_8710B				0x0524
+/*
+ * Format for offset 540h-542h:
+ *	[3:0]:   TBTT prohibit setup in unit of 32us. The time for HW getting beacon content before TBTT.
+ *	[7:4]:   Reserved.
+ *	[19:8]:  TBTT prohibit hold in unit of 32us. The time for HW holding to send the beacon packet.
+ *	[23:20]: Reserved
+ * Description:
+ *	              |
+ * |<--Setup--|--Hold------------>|
+ *	--------------|----------------------
+ * |
+ * TBTT
+ * Note: We cannot update beacon content to HW or send any AC packets during the time between Setup and Hold.
+ * Described by Designer Tim and Bruce, 2011-01-14.
+ *   */
+#define REG_TBTT_PROHIBIT_8710B			0x0540
+#define REG_RD_NAV_NXT_8710B			0x0544
+#define REG_NAV_PROT_LEN_8710B			0x0546
+#define REG_BCN_CTRL_8710B				0x0550
+#define REG_BCN_CTRL_1_8710B			0x0551
+#define REG_MBID_NUM_8710B				0x0552
+#define REG_DUAL_TSF_RST_8710B			0x0553
+#define REG_BCN_INTERVAL_8710B			0x0554
+#define REG_DRVERLYINT_8710B			0x0558
+#define REG_BCNDMATIM_8710B			0x0559
+#define REG_ATIMWND_8710B				0x055A
+#define REG_USTIME_TSF_8710B			0x055C
+#define REG_BCN_MAX_ERR_8710B			0x055D
+#define REG_RXTSF_OFFSET_CCK_8710B		0x055E
+#define REG_RXTSF_OFFSET_OFDM_8710B	0x055F
+#define REG_TSFTR_8710B					0x0560
+#define REG_CTWND_8710B					0x0572
+#define REG_SECONDARY_CCA_CTRL_8710B	0x0577
+#define REG_PSTIMER_8710B				0x0580
+#define REG_TIMER0_8710B				0x0584
+#define REG_TIMER1_8710B				0x0588
+#define REG_ACMHWCTRL_8710B			0x05C0
+#define REG_SCH_TXCMD_8710B			0x05F8
+
+/* -----------------------------------------------------
+ *
+ *	0x0600h ~ 0x07FFh	WMAC Configuration
+ *
+ * ----------------------------------------------------- */
+#define REG_MAC_CR_8710B				0x0600
+#define REG_TCR_8710B					0x0604
+#define REG_RCR_8710B					0x0608
+#define REG_RX_PKT_LIMIT_8710B			0x060C
+#define REG_RX_DLK_TIME_8710B			0x060D
+#define REG_RX_DRVINFO_SZ_8710B		0x060F
+
+#define REG_MACID_8710B					0x0610
+#define REG_BSSID_8710B					0x0618
+#define REG_MAR_8710B					0x0620
+#define REG_MBIDCAMCFG_8710B			0x0628
+#define REG_WOWLAN_GTK_DBG1	0x630
+#define REG_WOWLAN_GTK_DBG2	0x634
+
+#define REG_USTIME_EDCA_8710B			0x0638
+#define REG_MAC_SPEC_SIFS_8710B		0x063A
+#define REG_RESP_SIFP_CCK_8710B			0x063C
+#define REG_RESP_SIFS_OFDM_8710B		0x063E
+#define REG_ACKTO_8710B					0x0640
+#define REG_CTS2TO_8710B				0x0641
+#define REG_EIFS_8710B					0x0642
+
+#define REG_NAV_UPPER_8710B			0x0652	/* unit of 128 */
+#define REG_TRXPTCL_CTL_8710B			0x0668
+
+/* Security */
+#define REG_CAMCMD_8710B				0x0670
+#define REG_CAMWRITE_8710B				0x0674
+#define REG_CAMREAD_8710B				0x0678
+#define REG_CAMDBG_8710B				0x067C
+#define REG_SECCFG_8710B				0x0680
+
+/* Power */
+#define REG_WOW_CTRL_8710B				0x0690
+#define REG_PS_RX_INFO_8710B			0x0692
+#define REG_UAPSD_TID_8710B				0x0693
+#define REG_WKFMCAM_CMD_8710B			0x0698
+#define REG_WKFMCAM_NUM_8710B			0x0698
+#define REG_WKFMCAM_RWD_8710B			0x069C
+#define REG_RXFLTMAP0_8710B				0x06A0
+#define REG_RXFLTMAP1_8710B				0x06A2
+#define REG_RXFLTMAP2_8710B				0x06A4
+#define REG_BCN_PSR_RPT_8710B			0x06A8
+#define REG_BT_COEX_TABLE_8710B		0x06C0
+#define REG_BFMER0_INFO_8710B			0x06E4
+#define REG_BFMER1_INFO_8710B			0x06EC
+#define REG_CSI_RPT_PARAM_BW20_8710B	0x06F4
+#define REG_CSI_RPT_PARAM_BW40_8710B	0x06F8
+#define REG_CSI_RPT_PARAM_BW80_8710B	0x06FC
+
+/* Hardware Port 2 */
+#define REG_MACID1_8710B				0x0700
+#define REG_BSSID1_8710B				0x0708
+#define REG_BFMEE_SEL_8710B				0x0714
+#define REG_SND_PTCL_CTRL_8710B		0x0718
+
+/* LTR */
+#define REG_LTR_CTRL_BASIC_8710B		0x07A4
+#define REG_LTR_IDLE_LATENCY_V1_8710B		0x0798
+#define REG_LTR_ACTIVE_LATENCY_V1_8710B		0x079C
+
+/* LTE_COEX */
+#define REG_LTECOEX_CTRL			0x07C0
+#define REG_LTECOEX_WRITE_DATA		0x07C4
+#define REG_LTECOEX_READ_DATA		0x07C8
+#define REG_LTECOEX_PATH_CONTROL	0x70
+
+/* Other */
+#define REG_USB_ACCESS_TIMEOUT 0xFE4C
+
+/* -----------------------------------------------------
+ * SYSON_REG_SPEC
+ * ----------------------------------------------------- */
+#define SYSON_REG_BASE_ADDR_8710B 0x40000000
+#define REG_SYS_XTAL_CTRL0	0x0060
+#define REG_SYS_SYSTEM_CFG0 0x1F0
+#define REG_SYS_SYSTEM_CFG1 0x1F4
+#define REG_SYS_SYSTEM_CFG2 0x1F8
+#define REG_SYS_EEPROM_CTRL0 0x0E0
+
+
+/* -----------------------------------------------------
+ * Indirect_R/W_SPEC
+ * ----------------------------------------------------- */
+#define NORMAL_REG_READ_OFFSET 0x83000000
+#define NORMAL_REG_WRITE_OFFSET 0x84000000
+#define EFUSE_READ_OFFSET 0x85000000
+#define EFUSE_WRITE_OFFSET 0x86000000
+
+
+/* -----------------------------------------------------
+ * PAGE0_WLANON_REG_SPEC
+ * ----------------------------------------------------- */
+#define PAGE0_OFFSET 0x0 // WLANON_PAGE0_REG needs to add an offset.
+
+
+
+/* ****************************************************************************
+ *	8723 Regsiter Bit and Content definition
+ * **************************************************************************** */
+ 
+ /* -----------------------------------------------------
+ * REG_SYS_SYSTEM_CFG0 
+ * ----------------------------------------------------- */
+#define BIT_RTL_ID_8710B BIT(16)
+
+#define BIT_MASK_CHIP_VER_8710B 0xf
+#define BIT_GET_CHIP_VER_8710B(x) ((x) & BIT_MASK_CHIP_VER_8710B)
+
+#define BIT_SHIFT_VENDOR_ID_8710B 4
+#define BIT_MASK_VENDOR_ID_8710B 0xf
+#define BIT_GET_VENDOR_ID_8710B(x) (((x) >> BIT_SHIFT_VENDOR_ID_8710B) & BIT_MASK_VENDOR_ID_8710B)
+
+ /* -----------------------------------------------------
+ * REG_SYS_SYSTEM_CFG1 
+ * ----------------------------------------------------- */
+#define BIT_SPSLDO_SEL_8710B BIT(25)
+
+ /* -----------------------------------------------------
+ * REG_SYS_SYSTEM_CFG2 
+ * ----------------------------------------------------- */
+#define BIT_MASK_RF_RL_ID_8710B 0xf
+#define BIT_GET_RF_RL_ID_8710B(x) ((x) & BIT_MASK_RF_RL_ID_8710B)
+
+ /* -----------------------------------------------------
+ * REG_SYS_SYSTEM_CFG2 
+ * ----------------------------------------------------- */
+#define BIT_EERPOMSEL_8710B BIT(4)
+#define BIT_AUTOLOAD_SUS_8710B BIT(5)
+
+
+ /* -----------------------------------------------------
+ * Other
+ * ----------------------------------------------------- */
+
+
+#define BIT_USB_RXDMA_AGG_EN	BIT(31)
+#define RXDMA_AGG_MODE_EN		BIT(1)
+
+#ifdef CONFIG_WOWLAN
+	#define RXPKT_RELEASE_POLL		BIT(16)
+	#define RXDMA_IDLE				BIT(17)
+	#define RW_RELEASE_EN			BIT(18)
+#endif
+
+/* 2 HSISR
+ * 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)
+
+#ifdef CONFIG_RF_POWER_TRIM
+	#ifdef CONFIG_RTL8710B
+		#define EEPROM_RF_GAIN_OFFSET			0xC1
+	#endif
+
+	#define EEPROM_RF_GAIN_VAL				0x1F6
+#endif /*CONFIG_RF_POWER_TRIM*/
+
+#endif /* __RTL8710B_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_sreset.h
new file mode 100644
index 000000000000..cac8aacf7d76
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_sreset.h
@@ -0,0 +1,25 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 _RTL8710B_SRESET_H_
+#define _RTL8710B_SRESET_H_
+
+#include <rtw_sreset.h>
+
+#ifdef DBG_CONFIG_ERROR_DETECT
+	extern void rtl8710b_sreset_xmit_status_check(_adapter *padapter);
+	extern void rtl8710b_sreset_linked_status_check(_adapter *padapter);
+#endif
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_xmit.h
new file mode 100644
index 000000000000..a249df07eca6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8710b_xmit.h
@@ -0,0 +1,523 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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 __RTL8710B_XMIT_H__
+#define __RTL8710B_XMIT_H__
+
+
+#define MAX_TID (15)
+
+
+#ifndef __INC_HAL8710BDESC_H
+#define __INC_HAL8710BDESC_H
+
+#define RX_STATUS_DESC_SIZE_8710B		24
+#define RX_DRV_INFO_SIZE_UNIT_8710B 8
+
+
+/* DWORD 0 */
+#define SET_RX_STATUS_DESC_PKT_LEN_8710B(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
+#define SET_RX_STATUS_DESC_EOR_8710B(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 30, 1, __Value)
+#define SET_RX_STATUS_DESC_OWN_8710B(__pRxStatusDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 31, 1, __Value)
+
+#define GET_RX_STATUS_DESC_PKT_LEN_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 0, 14)
+#define GET_RX_STATUS_DESC_CRC32_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 14, 1)
+#define GET_RX_STATUS_DESC_ICV_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
+#define GET_RX_STATUS_DESC_DRVINFO_SIZE_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 4)
+#define GET_RX_STATUS_DESC_SECURITY_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 20, 3)
+#define GET_RX_STATUS_DESC_QOS_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 23, 1)
+#define GET_RX_STATUS_DESC_SHIFT_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 24, 2)
+#define GET_RX_STATUS_DESC_PHY_STATUS_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 26, 1)
+#define GET_RX_STATUS_DESC_SWDEC_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 27, 1)
+#define GET_RX_STATUS_DESC_EOR_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 30, 1)
+#define GET_RX_STATUS_DESC_OWN_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
+
+/* DWORD 1 */
+#define GET_RX_STATUS_DESC_MACID_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 0, 7)
+#define GET_RX_STATUS_DESC_TID_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 8, 4)
+#define GET_RX_STATUS_DESC_AMSDU_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 13, 1)
+#define GET_RX_STATUS_DESC_RXID_MATCH_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 14, 1)
+#define GET_RX_STATUS_DESC_PAGGR_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 15, 1)
+#define GET_RX_STATUS_DESC_A1_FIT_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 16, 4)
+#define GET_RX_STATUS_DESC_CHKERR_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 20, 1)
+#define GET_RX_STATUS_DESC_IPVER_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 21, 1)
+#define GET_RX_STATUS_DESC_IS_TCPUDP__8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 22, 1)
+#define GET_RX_STATUS_DESC_CHK_VLD_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 23, 1)
+#define GET_RX_STATUS_DESC_PAM_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 24, 1)
+#define GET_RX_STATUS_DESC_PWR_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 25, 1)
+#define GET_RX_STATUS_DESC_MORE_DATA_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 26, 1)
+#define GET_RX_STATUS_DESC_MORE_FRAG_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 27, 1)
+#define GET_RX_STATUS_DESC_TYPE_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 28, 2)
+#define GET_RX_STATUS_DESC_MC_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 30, 1)
+#define GET_RX_STATUS_DESC_BC_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+4, 31, 1)
+
+/* DWORD 2 */
+#define GET_RX_STATUS_DESC_SEQ_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 0, 12)
+#define GET_RX_STATUS_DESC_FRAG_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 12, 4)
+#define GET_RX_STATUS_DESC_RX_IS_QOS_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 16, 1)
+#define GET_RX_STATUS_DESC_WLANHD_IV_LEN_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 18, 6)
+#define GET_RX_STATUS_DESC_RPT_SEL_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 28, 1)
+#define GET_RX_STATUS_DESC_FCS_OK_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+8, 31, 1)
+
+/* DWORD 3 */
+#define GET_RX_STATUS_DESC_RX_RATE_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 0, 7)
+#define GET_RX_STATUS_DESC_HTC_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 10, 1)
+#define GET_RX_STATUS_DESC_EOSP_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 11, 1)
+#define GET_RX_STATUS_DESC_BSSID_FIT_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 12, 2)
+#ifdef CONFIG_USB_RX_AGGREGATION
+#define GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+12, 16, 8)
+#endif
+#define GET_RX_STATUS_DESC_PATTERN_MATCH_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 29, 1)
+#define GET_RX_STATUS_DESC_UNICAST_MATCH_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 30, 1)
+#define GET_RX_STATUS_DESC_MAGIC_MATCH_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+12, 31, 1)
+
+/* DWORD 6 */
+#define GET_RX_STATUS_DESC_MATCH_ID_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+16, 0, 7)
+
+/* DWORD 5 */
+#define GET_RX_STATUS_DESC_TSFL_8710B(__pRxStatusDesc) \
+	LE_BITS_TO_4BYTE(__pRxStatusDesc+20, 0, 32)
+
+#define GET_RX_STATUS_DESC_BUFF_ADDR_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+24, 0, 32)
+#define GET_RX_STATUS_DESC_BUFF_ADDR64_8710B(__pRxDesc) \
+	LE_BITS_TO_4BYTE(__pRxDesc+28, 0, 32)
+
+#define SET_RX_STATUS_DESC_BUFF_ADDR_8710B(__pRxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pRxDesc+24, 0, 32, __Value)
+
+
+/* Dword 0, rsvd: bit26, bit28 */
+#define GET_TX_DESC_OWN_8710B(__pTxDesc)\
+	LE_BITS_TO_4BYTE(__pTxDesc, 31, 1)
+
+#define SET_TX_DESC_PKT_SIZE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 16, __Value)
+#define SET_TX_DESC_OFFSET_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 8, __Value)
+#define SET_TX_DESC_BMC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 24, 1, __Value)
+#define SET_TX_DESC_HTC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 25, 1, __Value)
+#define SET_TX_DESC_AMSDU_PAD_EN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 27, 1, __Value)
+#define SET_TX_DESC_NO_ACM_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 29, 1, __Value)
+#define SET_TX_DESC_GF_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc, 30, 1, __Value)
+
+/* Dword 1 */
+#define SET_TX_DESC_MACID_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 7, __Value)
+#define SET_TX_DESC_QUEUE_SEL_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 8, 5, __Value)
+#define SET_TX_DESC_RDG_NAV_EXT_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 13, 1, __Value)
+#define SET_TX_DESC_LSIG_TXOP_EN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 14, 1, __Value)
+#define SET_TX_DESC_PIFS_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 15, 1, __Value)
+#define SET_TX_DESC_RATE_ID_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 16, 5, __Value)
+#define SET_TX_DESC_EN_DESC_ID_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 21, 1, __Value)
+#define SET_TX_DESC_SEC_TYPE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 22, 2, __Value)
+#define SET_TX_DESC_PKT_OFFSET_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 24, 5, __Value)
+#define SET_TX_DESC_MORE_DATA_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 29, 1, __Value)
+
+/* Dword 2  remove P_AID, G_ID field*/
+#define SET_TX_DESC_CCA_RTS_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 10, 2, __Value)
+#define SET_TX_DESC_AGG_ENABLE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 12, 1, __Value)
+#define SET_TX_DESC_RDG_ENABLE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 13, 1, __Value)
+#define SET_TX_DESC_NULL0_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 14, 1, __Value)
+#define SET_TX_DESC_NULL1_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 15, 1, __Value)
+#define SET_TX_DESC_BK_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 16, 1, __Value)
+#define SET_TX_DESC_MORE_FRAG_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 17, 1, __Value)
+#define SET_TX_DESC_RAW_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 18, 1, __Value)
+#define SET_TX_DESC_CCX_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 19, 1, __Value)
+#define SET_TX_DESC_AMPDU_DENSITY_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 20, 3, __Value)
+#define SET_TX_DESC_BT_INT_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 23, 1, __Value)
+#define SET_TX_DESC_FTM_EN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 30, 1, __Value)
+
+/* Dword 3 */
+#define SET_TX_DESC_NAV_USE_HDR_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
+#define SET_TX_DESC_HWSEQ_SEL_8710B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_USE_RATE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
+#define SET_TX_DESC_DISABLE_RTS_FB_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 9, 1, __Value)
+#define SET_TX_DESC_DISABLE_FB_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 10, 1, __Value)
+#define SET_TX_DESC_CTS2SELF_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 11, 1, __Value)
+#define SET_TX_DESC_RTS_ENABLE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 12, 1, __Value)
+#define SET_TX_DESC_HW_RTS_ENABLE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
+#define SET_TX_DESC_PORT_ID_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 2, __Value)
+#define SET_TX_DESC_USE_MAX_LEN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
+#define SET_TX_DESC_MAX_AGG_NUM_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 17, 5, __Value)
+#define SET_TX_DESC_AMPDU_MAX_TIME_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 24, 8, __Value)
+
+/* Dword 4 */
+#define SET_TX_DESC_TX_RATE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 0, 7, __Value)
+#define SET_TX_DESC_TX_TRY_RATE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 7, 1, __Value)
+#define SET_TX_DESC_DATA_RATE_FB_LIMIT_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 8, 5, __Value)
+#define SET_TX_DESC_RTS_RATE_FB_LIMIT_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 13, 4, __Value)
+#define SET_TX_DESC_RETRY_LIMIT_ENABLE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 17, 1, __Value)
+#define SET_TX_DESC_DATA_RETRY_LIMIT_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 18, 6, __Value)
+#define SET_TX_DESC_RTS_RATE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 24, 5, __Value)
+#define SET_TX_DESC_PCTS_EN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 29, 1, __Value)
+#define SET_TX_DESC_PCTS_MASK_IDX_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+16, 30, 2, __Value)
+
+/* Dword 5 */
+#define SET_TX_DESC_DATA_SC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 0, 4, __Value)
+#define SET_TX_DESC_DATA_SHORT_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 4, 1, __Value)
+#define SET_TX_DESC_DATA_BW_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 5, 2, __Value)
+#define SET_TX_DESC_DATA_STBC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 8, 2, __Value)
+#define SET_TX_DESC_RTS_STBC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 10, 2, __Value)
+#define SET_TX_DESC_RTS_SHORT_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 12, 1, __Value)
+#define SET_TX_DESC_RTS_SC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 13, 4, __Value)
+#define SET_TX_DESC_PATH_A_EN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 24, 1, __Value)
+#define SET_TX_DESC_TXPWR_OF_SET_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+20, 28, 3, __Value)
+
+/* Dword 6 */
+#define SET_TX_DESC_SW_DEFINE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 0, 12, __Value)
+#define SET_TX_DESC_MBSSID_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 12, 4, __Value)
+#define SET_TX_DESC_RF_SEL_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
+
+/* Dword 7 */
+#ifdef CONFIG_PCI_HCI
+#define SET_TX_DESC_TX_BUFFER_SIZE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+
+#ifdef CONFIG_USB_HCI
+#define SET_TX_DESC_TX_DESC_CHECKSUM_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+#define SET_TX_DESC_TX_TIMESTAMP_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 6, 18, __Value)
+#endif
+
+#define SET_TX_DESC_USB_TXAGG_NUM_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
+
+/* Dword 8 */
+#define SET_TX_DESC_RTS_RC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 0, 6, __Value)
+#define SET_TX_DESC_BAR_RC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 6, 2, __Value)
+#define SET_TX_DESC_DATA_RC_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
+#define SET_TX_DESC_HWSEQ_EN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
+#define SET_TX_DESC_NEXTHEADPAGE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
+#define SET_TX_DESC_TAILPAGE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
+
+/* Dword 9 */
+#define SET_TX_DESC_PADDING_LEN_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 0, 11, __Value)
+#define SET_TX_DESC_SEQ_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 12, 12, __Value)
+#define SET_TX_DESC_FINAL_DATA_RATE_8710B(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+36, 24, 8, __Value)
+
+
+#define SET_EARLYMODE_PKTNUM_8710B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 0, 4, __Value)
+#define SET_EARLYMODE_LEN0_8710B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 4, 15, __Value)
+#define SET_EARLYMODE_LEN1_1_8710B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr, 19, 13, __Value)
+#define SET_EARLYMODE_LEN1_2_8710B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 0, 2, __Value)
+#define SET_EARLYMODE_LEN2_8710B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 2, 15,	__Value)
+#define SET_EARLYMODE_LEN3_8710B(__pAddr, __Value)					SET_BITS_TO_LE_4BYTE(__pAddr+4, 17, 15, __Value)
+
+
+/*-----------------------------------------------------------------*/
+/*	RTL8710B TX BUFFER DESC                                      */
+/*-----------------------------------------------------------------*/
+#ifdef CONFIG_64BIT_DMA
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+((__Offset)*16)+8, 0, 32, __Valeu)
+#else
+	#define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
+	#define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
+	#define SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, __Offset, __Valeu)	/* 64 BIT mode only */
+#endif
+/* ********************************************************* */
+
+/* 64 bits  -- 32 bits */
+/* =======     ======= */
+/* Dword 0     0 */
+#define SET_TX_BUFF_DESC_LEN_0_8710B(__pTxDesc, __Valeu) SET_BITS_TO_LE_4BYTE(__pTxDesc, 0, 14, __Valeu)
+#define SET_TX_BUFF_DESC_PSB_8710B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 16, 15, __Value)
+#define SET_TX_BUFF_DESC_OWN_8710B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc, 31, 1, __Value)
+
+/* Dword 1     1 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_0_8710B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+4, 0, 32, __Value)
+#define GET_TX_BUFF_DESC_ADDR_LOW_0_8710B(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+4, 0, 32)
+/* Dword 2     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_0_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 0, __Value)
+#ifdef CONFIG_64BIT_DMA
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8710B(__pTxDesc) LE_BITS_TO_4BYTE(__pTxDesc+8, 0, 32)
+#else
+	#define GET_TX_BUFF_DESC_ADDR_HIGH_0_8710B(__pTxDesc) 0
+#endif
+/* Dword 3     NA */
+/* RESERVED 0 */
+/* Dword 4     2 */
+#define SET_TX_BUFF_DESC_LEN_1_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 1, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_1_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 5     3 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_1_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 6     NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_1_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 1, __Value)
+/* Dword 7     NA */
+/*RESERVED 0 */
+/* Dword 8     4 */
+#define SET_TX_BUFF_DESC_LEN_2_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 2, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_2_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 9     5 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_2_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 10    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_2_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 2, __Value)
+/* Dword 11    NA */
+/*RESERVED 0 */
+/* Dword 12    6 */
+#define SET_TX_BUFF_DESC_LEN_3_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, 3, __Value)
+#define SET_TX_BUFF_DESC_AMSDU_3_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 13    7 */
+#define SET_TX_BUFF_DESC_ADDR_LOW_3_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 14    NA */
+#define SET_TX_BUFF_DESC_ADDR_HIGH_3_8710B(__pTxDesc, __Value) SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET(__pTxDesc, 3, __Value)
+/* Dword 15    NA */
+/*RESERVED 0 */
+
+
+#endif
+/* -----------------------------------------------------------
+ *
+ *	Rate
+ *
+ * -----------------------------------------------------------
+ * CCK Rates, TxHT = 0 */
+#define DESC8710B_RATE1M				0x00
+#define DESC8710B_RATE2M				0x01
+#define DESC8710B_RATE5_5M				0x02
+#define DESC8710B_RATE11M				0x03
+
+/* OFDM Rates, TxHT = 0 */
+#define DESC8710B_RATE6M				0x04
+#define DESC8710B_RATE9M				0x05
+#define DESC8710B_RATE12M				0x06
+#define DESC8710B_RATE18M				0x07
+#define DESC8710B_RATE24M				0x08
+#define DESC8710B_RATE36M				0x09
+#define DESC8710B_RATE48M				0x0a
+#define DESC8710B_RATE54M				0x0b
+
+/* MCS Rates, TxHT = 1 */
+#define DESC8710B_RATEMCS0				0x0c
+#define DESC8710B_RATEMCS1				0x0d
+#define DESC8710B_RATEMCS2				0x0e
+#define DESC8710B_RATEMCS3				0x0f
+#define DESC8710B_RATEMCS4				0x10
+#define DESC8710B_RATEMCS5				0x11
+#define DESC8710B_RATEMCS6				0x12
+#define DESC8710B_RATEMCS7				0x13
+#define DESC8710B_RATEMCS8				0x14
+#define DESC8710B_RATEMCS9				0x15
+#define DESC8710B_RATEMCS10		0x16
+#define DESC8710B_RATEMCS11		0x17
+#define DESC8710B_RATEMCS12		0x18
+#define DESC8710B_RATEMCS13		0x19
+#define DESC8710B_RATEMCS14		0x1a
+#define DESC8710B_RATEMCS15		0x1b
+#define DESC8710B_RATEVHTSS1MCS0		0x2c
+#define DESC8710B_RATEVHTSS1MCS1		0x2d
+#define DESC8710B_RATEVHTSS1MCS2		0x2e
+#define DESC8710B_RATEVHTSS1MCS3		0x2f
+#define DESC8710B_RATEVHTSS1MCS4		0x30
+#define DESC8710B_RATEVHTSS1MCS5		0x31
+#define DESC8710B_RATEVHTSS1MCS6		0x32
+#define DESC8710B_RATEVHTSS1MCS7		0x33
+#define DESC8710B_RATEVHTSS1MCS8		0x34
+#define DESC8710B_RATEVHTSS1MCS9		0x35
+#define DESC8710B_RATEVHTSS2MCS0		0x36
+#define DESC8710B_RATEVHTSS2MCS1		0x37
+#define DESC8710B_RATEVHTSS2MCS2		0x38
+#define DESC8710B_RATEVHTSS2MCS3		0x39
+#define DESC8710B_RATEVHTSS2MCS4		0x3a
+#define DESC8710B_RATEVHTSS2MCS5		0x3b
+#define DESC8710B_RATEVHTSS2MCS6		0x3c
+#define DESC8710B_RATEVHTSS2MCS7		0x3d
+#define DESC8710B_RATEVHTSS2MCS8		0x3e
+#define DESC8710B_RATEVHTSS2MCS9		0x3f
+
+
+#define	RX_HAL_IS_CCK_RATE_8710B(pDesc)\
+	(GET_RX_STATUS_DESC_RX_RATE_8710B(pDesc) == DESC8710B_RATE1M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8710B(pDesc) == DESC8710B_RATE2M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8710B(pDesc) == DESC8710B_RATE5_5M || \
+	 GET_RX_STATUS_DESC_RX_RATE_8710B(pDesc) == DESC8710B_RATE11M)
+
+#ifdef CONFIG_TRX_BD_ARCH
+	struct tx_desc;
+#endif
+
+void rtl8710b_cal_txdesc_chksum(struct tx_desc *ptxdesc);
+void rtl8710b_update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem);
+void rtl8710b_fill_txdesc_sectype(struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8710b_fill_txdesc_vcs(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8710b_fill_txdesc_phy(PADAPTER padapter, struct pkt_attrib *pattrib, struct tx_desc *ptxdesc);
+void rtl8710b_fill_fake_txdesc(PADAPTER padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
+
+#if defined(CONFIG_CONCURRENT_MODE)
+	void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc);
+#endif
+void fill_txdesc_bmc_tx_rate(struct pkt_attrib *pattrib, u8 *ptxdesc);
+
+#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
+	s32 rtl8710bs_init_xmit_priv(PADAPTER padapter);
+	void rtl8710bs_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8710bs_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8710bs_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8710bs_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8710bs_xmit_buf_handler(PADAPTER padapter);
+	thread_return rtl8710bs_xmit_thread(thread_context context);
+	#define hal_xmit_handler rtl8710bs_xmit_buf_handler
+#endif
+
+#ifdef CONFIG_USB_HCI
+	s32 rtl8710bu_xmit_buf_handler(PADAPTER padapter);
+	#define hal_xmit_handler rtl8710bu_xmit_buf_handler
+	s32 rtl8710bu_init_xmit_priv(PADAPTER padapter);
+	void rtl8710bu_free_xmit_priv(PADAPTER padapter);
+	s32 rtl8710bu_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8710bu_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	 rtl8710bu_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8710bu_xmit_tasklet(void *priv);
+	s32 rtl8710bu_xmitframe_complete(_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
+	void _dbg_dump_tx_info(_adapter	*padapter, int frame_tag, struct tx_desc *ptxdesc);
+#endif
+
+#ifdef CONFIG_PCI_HCI
+	s32 rtl8710be_init_xmit_priv(PADAPTER padapter);
+	void rtl8710be_free_xmit_priv(PADAPTER padapter);
+	struct xmit_buf *rtl8710be_dequeue_xmitbuf(struct rtw_tx_ring *ring);
+	void	rtl8710be_xmitframe_resume(_adapter *padapter);
+	s32 rtl8710be_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe);
+	s32 rtl8710be_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe);
+	s32	rtl8710be_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
+	void rtl8710be_xmit_tasklet(void *priv);
+#endif
+
+u8	BWMapping_8710B(PADAPTER Adapter, struct pkt_attrib *pattrib);
+u8	SCMapping_8710B(PADAPTER Adapter, struct pkt_attrib	*pattrib);
+
+#endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_cmd.h
index f284a05425fc..a711671c10ac 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -113,7 +114,6 @@ enum h2c_cmd_8723B {
 #define SET_8723B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8723B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#define SET_8723B_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8723B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
@@ -177,7 +177,6 @@ enum h2c_cmd_8723B {
 /* host message to firmware cmd */
 void rtl8723b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
 void rtl8723b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
-void rtl8723b_set_rssi_cmd(PADAPTER padapter, u8 *param);
 void rtl8723b_fw_try_ap_cmd(PADAPTER padapter, u32 need_ack);
 /* s32 rtl8723b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
 void rtl8723b_set_FwPsTuneParam_cmd(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_dm.h
index ea517175f0bd..0a18c1654b42 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_hal.h
index 6e9ac57dd089..082bf4d39d3b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -106,18 +107,10 @@ typedef struct _RT_8723B_FIRMWARE_HDR {
 /* Note: We will divide number of page equally for each queue other than public queue! */
 
 /* For General Reserved Page Number(Beacon Queue is reserved page)
- * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
-#define BCNQ_PAGE_NUM_8723B		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-	#define BCNQ1_PAGE_NUM_8723B		0x08 /* 0x04 */
-#else
-	#define BCNQ1_PAGE_NUM_8723B		0x00
-#endif
+ * Beacon:MAX_BEACON_LEN/PAGE_SIZE_TX_8723B
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
+#define BCNQ_PAGE_NUM_8723B		(MAX_BEACON_LEN / PAGE_SIZE_TX_8723B + 6) /*0x08*/
 
-#ifdef CONFIG_PNO_SUPPORT
-	#undef BCNQ1_PAGE_NUM_8723B
-	#define BCNQ1_PAGE_NUM_8723B		0x00 /* 0x04 */
-#endif
 
 /* For WoWLan , more reserved page
  * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt: 1,PNO: 6
@@ -138,7 +131,7 @@ typedef struct _RT_8723B_FIRMWARE_HDR {
 	#define AP_WOWLAN_PAGE_NUM_8723B	0x02
 #endif
 
-#define TX_TOTAL_PAGE_NUMBER_8723B	(0xFF - BCNQ_PAGE_NUM_8723B - BCNQ1_PAGE_NUM_8723B - WOWLAN_PAGE_NUM_8723B)
+#define TX_TOTAL_PAGE_NUMBER_8723B	(0xFF - BCNQ_PAGE_NUM_8723B - WOWLAN_PAGE_NUM_8723B)
 #define TX_PAGE_BOUNDARY_8723B		(TX_TOTAL_PAGE_NUMBER_8723B + 1)
 
 #define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B	TX_TOTAL_PAGE_NUMBER_8723B
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_led.h
index 6b772cceb7ec..1261c5e9a4d3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_recv.h
index cf5e18b66613..ec20f1016eec 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_rf.h
index 6325ad5b8358..5341460705af 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_spec.h
index b0fb4aa41d17..d8643cc4afdc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_sreset.h
index c97f2648ac60..5bae23bc608c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_xmit.h
index 1364951d9db0..cc838526b8e4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723b_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -184,13 +185,14 @@
 	#define SET_TX_DESC_ANTSEL_D_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 25, 3, __Value)
 
 	/* Dword 7 */
-	#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+	#ifdef CONFIG_PCI_HCI
 		#define SET_TX_DESC_TX_BUFFER_SIZE_8723B(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-	#else
+	#endif
+	#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_USB_HCI)
 		#define SET_TX_DESC_TX_DESC_CHECKSUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
 	#endif
 	#define SET_TX_DESC_USB_TXAGG_NUM_8723B(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 24, 8, __Value)
-	#if (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
+	#ifdef CONFIG_SDIO_HCI
 		#define SET_TX_DESC_SDIO_TXSEQ_8723B(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 16, 8, __Value)
 	#endif
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_cmd.h
index c90b8ea8042c..79d92337e276 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -101,7 +102,6 @@ enum h2c_cmd_8723D {
 #define SET_8723D_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8723D_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8723D_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#define SET_8723D_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8723D_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_dm.h
index 0612f0620e79..f0d3a2e7de9f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_hal.h
index fc57eba26245..b44d17489e7e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -111,18 +112,10 @@ typedef struct _RT_8723D_FIRMWARE_HDR {
 /* Note: We will divide number of page equally for each queue other than public queue! */
 
 /* For General Reserved Page Number(Beacon Queue is reserved page)
- * Beacon:2, PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1 */
-#define BCNQ_PAGE_NUM_8723D		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-	#define BCNQ1_PAGE_NUM_8723D		0x08 /* 0x04 */
-#else
-	#define BCNQ1_PAGE_NUM_8723D		0x00
-#endif
+ * Beacon:MAX_BEACON_LEN/PAGE_SIZE_TX_8723D
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
 
-#ifdef CONFIG_PNO_SUPPORT
-	#undef BCNQ1_PAGE_NUM_8723D
-	#define BCNQ1_PAGE_NUM_8723D		0x00 /* 0x04 */
-#endif
+#define BCNQ_PAGE_NUM_8723D		(MAX_BEACON_LEN/PAGE_SIZE_TX_8723D + 6) /*0x08*/
 
 /* For WoWLan , more reserved page
  * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:2,GTK EXT MEM:2, AOAC rpt 1, PNO: 6
@@ -144,7 +137,7 @@ typedef struct _RT_8723D_FIRMWARE_HDR {
 #endif
 
 #define TX_TOTAL_PAGE_NUMBER_8723D\
-	(0xFF - BCNQ_PAGE_NUM_8723D - BCNQ1_PAGE_NUM_8723D - WOWLAN_PAGE_NUM_8723D)
+	(0xFF - BCNQ_PAGE_NUM_8723D - WOWLAN_PAGE_NUM_8723D)
 #define TX_PAGE_BOUNDARY_8723D		(TX_TOTAL_PAGE_NUMBER_8723D + 1)
 
 #define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723D	TX_TOTAL_PAGE_NUMBER_8723D
@@ -240,8 +233,6 @@ void Hal_EfuseParseBTCoexistInfo_8723D(PADAPTER padapter,
 				       u8 *hwinfo, BOOLEAN AutoLoadFail);
 void Hal_EfuseParseEEPROMVer_8723D(PADAPTER padapter,
 				   u8 *hwinfo, BOOLEAN AutoLoadFail);
-void Hal_EfuseParsePackageType_8723D(PADAPTER pAdapter,
-				     u8 *hwinfo, BOOLEAN AutoLoadFail);
 void Hal_EfuseParseChnlPlan_8723D(PADAPTER padapter,
 				  u8 *hwinfo, BOOLEAN AutoLoadFail);
 void Hal_EfuseParseCustomerID_8723D(PADAPTER padapter,
@@ -267,8 +258,6 @@ u8 GetHalDefVar8723D(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
 /* register */
 void rtl8723d_InitBeaconParameters(PADAPTER padapter);
 void rtl8723d_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode);
-void _InitBurstPktLen_8723DS(PADAPTER Adapter);
-void _InitLTECoex_8723DS(PADAPTER Adapter);
 void _InitMacAPLLSetting_8723D(PADAPTER Adapter);
 void _8051Reset8723(PADAPTER padapter);
 #ifdef CONFIG_WOWLAN
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_led.h
index 1905e8bed02c..80d5001b88d5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_lps_poff.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_lps_poff.h
index 138a0ca66732..0193d46fc4d7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_lps_poff.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_lps_poff.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_recv.h
index 03539a8b0a39..5964355dd131 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_rf.h
index 733eb0a46518..8479dfb48216 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_spec.h
index 5106b23b7722..72f0b8ca0845 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_sreset.h
index db75dba73e32..6310e8208e77 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_xmit.h
index a7360566cdeb..6b078141bf4b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8723d_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -212,9 +213,8 @@
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+8, 30, 1, __Value)
 
 /* Dword 3 */
-#define SET_TX_DESC_NAV_USE_HDR_8723D(__pTxDesc, __Value) \
-	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 5, 1, __Value)
-#define SET_TX_DESC_HWSEQ_SEL_8723D(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
+#define SET_TX_DESC_HWSEQ_SEL_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 6, 2, __Value)
 #define SET_TX_DESC_USE_RATE_8723D(__pTxDesc, __Value) \
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 8, 1, __Value)
 #define SET_TX_DESC_DISABLE_RTS_FB_8723D(__pTxDesc, __Value) \
@@ -229,6 +229,8 @@
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 13, 1, __Value)
 #define SET_TX_DESC_PORT_ID_8723D(__pTxDesc, __Value) \
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 14, 2, __Value)
+#define SET_TX_DESC_NAV_USE_HDR_8723D(__pTxDesc, __Value) \
+	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 15, 1, __Value)
 #define SET_TX_DESC_USE_MAX_LEN_8723D(__pTxDesc, __Value) \
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+12, 16, 1, __Value)
 #define SET_TX_DESC_MAX_AGG_NUM_8723D(__pTxDesc, __Value) \
@@ -285,13 +287,17 @@
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+24, 16, 3, __Value)
 
 /* Dword 7 */
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#ifdef CONFIG_PCI_HCI
 #define SET_TX_DESC_TX_BUFFER_SIZE_8723D(__pTxDesc, __Value) \
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#elif(DEV_BUS_TYPE == RT_USB_INTERFACE)
+#endif
+
+#ifdef CONFIG_USB_HCI
 #define SET_TX_DESC_TX_DESC_CHECKSUM_8723D(__pTxDesc, __Value) \
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
+#endif
+
+#ifdef CONFIG_SDIO_HCI
 #define SET_TX_DESC_TX_TIMESTAMP_8723D(__pTxDesc, __Value) \
 	SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 6, 18, __Value)
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_cmd.h
index 17dd2dd939af..53652f83f9d9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -84,7 +85,6 @@ struct H2C_SS_RFOFF_PARAM {
 #define SET_8812_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8812_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)			SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#define SET_8812_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)				SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8812_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)							LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_dm.h
index 584f6d342deb..90b8f37002c4 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_hal.h
index e3fe2659617f..9459237d7d60 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -135,7 +136,11 @@ typedef struct _RT_FIRMWARE_8812 {
 #endif
 #define RX_DMA_BOUNDARY_8812		(MAX_RX_DMA_BUFFER_SIZE_8812 - RX_DMA_RESERVED_SIZE_8812 - 1)
 
-#define BCNQ_PAGE_NUM_8812		0x07
+#define PAGE_SIZE_TX_8812A PAGE_SIZE_512
+
+/* Beacon:MAX_BEACON_LEN/PAGE_SIZE_TX_8812A
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
+#define BCNQ_PAGE_NUM_8812		(MAX_BEACON_LEN / PAGE_SIZE_TX_8812A + 6) /*0x07*/
 
 /* For WoWLan , more reserved page
  * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, AOAC rpt: 1,PNO: 6
@@ -154,7 +159,13 @@ typedef struct _RT_FIRMWARE_8812 {
 	#define FW_NDPA_PAGE_NUM	0x00
 #endif
 
-#define TX_TOTAL_PAGE_NUMBER_8812	(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812-FW_NDPA_PAGE_NUM)
+#ifdef DBG_FW_DEBUG_MSG_PKT
+	#define FW_DBG_MSG_PKT_PAGE_NUM_8812	0x01
+#else
+	#define FW_DBG_MSG_PKT_PAGE_NUM_8812	0x00
+#endif /*DBG_FW_DEBUG_MSG_PKT*/
+
+#define TX_TOTAL_PAGE_NUMBER_8812	(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812 - FW_NDPA_PAGE_NUM - FW_DBG_MSG_PKT_PAGE_NUM_8812)
 #define TX_PAGE_BOUNDARY_8812			(TX_TOTAL_PAGE_NUMBER_8812 + 1)
 
 #define TX_PAGE_BOUNDARY_WOWLAN_8812		(0xFF - BCNQ_PAGE_NUM_8812 - WOWLAN_PAGE_NUM_8812 + 1)
@@ -187,12 +198,11 @@ typedef struct _RT_FIRMWARE_8812 {
 #endif
 #define RX_DMA_BOUNDARY_8821		(MAX_RX_DMA_BUFFER_SIZE_8821 - RX_DMA_RESERVED_SIZE_8821 - 1)
 
-#define BCNQ_PAGE_NUM_8821		0x08
-#ifdef CONFIG_CONCURRENT_MODE
-	#define BCNQ1_PAGE_NUM_8821		0x04
-#else
-	#define BCNQ1_PAGE_NUM_8821		0x00
-#endif
+/* Beacon:MAX_BEACON_LEN/PAGE_SIZE_TX_8821A
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
+
+#define BCNQ_PAGE_NUM_8821		(MAX_BEACON_LEN / PAGE_SIZE_TX_8821A + 6) /*0x08*/
+
 
 /* For WoWLan , more reserved page
  * ARP Rsp:1, RWC:1, GTK Info:1,GTK RSP:1,GTK EXT MEM:1, PNO: 6 */
@@ -202,7 +212,7 @@ typedef struct _RT_FIRMWARE_8812 {
 	#define WOWLAN_PAGE_NUM_8821	0x00
 #endif
 
-#define TX_TOTAL_PAGE_NUMBER_8821	(0xFF - BCNQ_PAGE_NUM_8821 - BCNQ1_PAGE_NUM_8821 - WOWLAN_PAGE_NUM_8821)
+#define TX_TOTAL_PAGE_NUMBER_8821	(0xFF - BCNQ_PAGE_NUM_8821 - WOWLAN_PAGE_NUM_8821)
 #define TX_PAGE_BOUNDARY_8821				(TX_TOTAL_PAGE_NUMBER_8821 + 1)
 /* #define TX_PAGE_BOUNDARY_WOWLAN_8821		0xE0 */
 
@@ -338,9 +348,6 @@ void init_hal_spec_8821a(_adapter *adapter);
 
 u32 upload_txpktbuf_8812au(_adapter *adapter, u8 *buf, u32 buflen);
 
-/* register */
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
-
 void rtl8812_start_thread(PADAPTER padapter);
 void rtl8812_stop_thread(PADAPTER padapter);
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_led.h
index 30c676e526f3..7396fed0d56d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_recv.h
index bf1d4b651ea1..e26304f9da0f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_rf.h
index 9a7b60e6138c..4250d3672b40 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_spec.h
index 37ba2472296c..8d038ca9d09e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_sreset.h
index d4bbd5867b24..309ada941815 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_xmit.h
index 6105a8e4192d..790317bd975d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8812a_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_cmd.h
index 53c2828ae5e5..84b20486536d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -31,7 +32,6 @@
 #define SET_8814A_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
 #define SET_8814A_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
-#define SET_8814A_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)	SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
 
 #define GET_8814A_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)					LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
@@ -140,7 +140,6 @@ void rtl8814_set_wowlan_cmd(_adapter *padapter, u8 enable);
 void rtl8814_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
 void rtl8814_set_FwPwrMode_cmd(PADAPTER padapter, u8 PSMode);
 u8 GetTxBufferRsvdPageNum8814(_adapter *padapter, bool wowlan);
-u8 rtl8814_set_rssi_cmd(_adapter *padapter, u8 *param);
 void rtl8814_req_txrpt_cmd(PADAPTER padapter, u8 macid);
 
 #ifdef CONFIG_TDLS
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_dm.h
index afbc8be2565c..ba749723e813 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_hal.h
index b7631df6169d..d2b996030791 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -51,7 +52,10 @@ typedef struct _RT_FIRMWARE_8814 {
 } RT_FIRMWARE_8814, *PRT_FIRMWARE_8814;
 
 #define PAGE_SIZE_TX_8814	PAGE_SIZE_128
-#define BCNQ_PAGE_NUM_8814		0x08
+/* BCN rsvd_page_num = MAX_BEACON_LEN / PAGE_SIZE_TX_8814
+ * PS-Poll:1, Null Data:1,Qos Null Data:1,BT Qos Null Data:1,CTS-2-SELF,LTE QoS Null*/
+
+#define BCNQ_PAGE_NUM_8814		(MAX_BEACON_LEN / PAGE_SIZE_TX_8814 + 6) /*0x08*/
 
 #define Rtl8814A_NIC_PWR_ON_FLOW				rtl8814A_power_on_flow
 #define Rtl8814A_NIC_RF_OFF_FLOW				rtl8814A_radio_off_flow
@@ -196,12 +200,12 @@ Chip specific
 /* pic buffer descriptor */
 #if 1 /* according to the define in the rtw_xmit.h, rtw_recv.h */
 	#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
-	#define TX_DESC_NUM_8814A  TXDESC_NUM   /* 128 */
+	#define TX_DESC_NUM_8814A  TX_BD_NUM   /* 128 */
 	#define RX_DESC_NUM_8814A  PCI_MAX_RX_COUNT /* 128 */
 	#ifdef CONFIG_CONCURRENT_MODE
-		#define BE_QUEUE_TX_DESC_NUM_8814A  (TXDESC_NUM<<1)    /* 256 */
+		#define BE_QUEUE_TX_DESC_NUM_8814A  (TX_BD_NUM<<1)    /* 256 */
 	#else
-		#define BE_QUEUE_TX_DESC_NUM_8814A  (TXDESC_NUM+(TXDESC_NUM>>1)) /* 192 */
+		#define BE_QUEUE_TX_DESC_NUM_8814A  (TX_BD_NUM+(TX_BD_NUM>>1)) /* 192 */
 	#endif
 #else
 	#define RTL8814AE_SEG_NUM  TX_BUFFER_SEG_NUM /* 0:2 seg, 1: 4 seg, 2: 8 seg */
@@ -309,9 +313,6 @@ u8 GetHalDefVar8814A(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval);
 void rtl8814_set_hal_ops(struct hal_ops *pHalFunc);
 void init_hal_spec_8814a(_adapter *adapter);
 
-/* register */
-void SetBcnCtrlReg(PADAPTER padapter, u8 SetBits, u8 ClearBits);
-void SetBcnCtrlReg(PADAPTER	Adapter, u8	SetBits, u8	ClearBits);
 void rtl8814_start_thread(PADAPTER padapter);
 void rtl8814_stop_thread(PADAPTER padapter);
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_led.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_led.h
index cc457921efa1..755b1b6662fb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_led.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_led.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_recv.h
index c6792d8a5194..131b33973f7a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_rf.h
index e374439caaf2..5c83ecf65bc8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_spec.h
index 917b96178d66..58364c79bc34 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_sreset.h
index d65cb98a530e..23649b882787 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_xmit.h
index 5b1e9660cddc..8cad3bd37a4f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8814a_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -218,9 +219,10 @@ typedef struct txdescriptor_8814 {
 
 
 /* Dword 7 */
-#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
+#ifdef CONFIG_PCI_HCI
 	#define SET_TX_DESC_TX_BUFFER_SIZE_8814A(__pTxDesc, __Value)		SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
-#else
+#endif
+#if defined(CONFIG_SDIO_HCI)|| defined(CONFIG_USB_HCI)
 	#define SET_TX_DESC_TX_DESC_CHECKSUM_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 0, 16, __Value)
 #endif
 #define SET_TX_DESC_NTX_MAP_8814A(__pTxDesc, __Value) SET_BITS_TO_LE_4BYTE(__pTxDesc+28, 20, 4, __Value)
@@ -233,9 +235,10 @@ typedef struct txdescriptor_8814 {
 #define SET_TX_DESC_DATA_RC_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 8, 6, __Value)
 #define SET_TX_DESC_EN_HWEXSEQ_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 14, 1, __Value)
 #define SET_TX_DESC_HWSEQ_EN_8814A(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 15, 1, __Value)
-#if (DEV_BUS_TYPE != RT_SDIO_INTERFACE)
+#if defined(CONFIG_PCI_HCI)|| defined(CONFIG_USB_HCI)
 	#define SET_TX_DESC_NEXT_HEAD_PAGE_L_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)	SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value)
-#else
+#endif
+#ifdef CONFIG_SDIO_HCI
 	#define SET_TX_DESC_SDIO_SEQ_8814A(__pTxDesc, __Value)(__pTxDesc, __Value) 			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 16, 8, __Value) /* 20130415 KaiYuan add for 8814AS */
 #endif
 #define SET_TX_DESC_TAIL_PAGE_L_8814A(__pTxDesc, __Value)(__pTxDesc, __Value)			SET_BITS_TO_LE_4BYTE(__pTxDesc+32, 24, 8, __Value)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_spec.h
index 1379ffc3cf9d..ead9de2db0cb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_xmit.h
index 5d973cdc7926..b457d15adb41 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821a_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_dm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_dm.h
index b1e4fe608b2a..32cf516206f9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_dm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_dm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_hal.h
index 75d87505a265..a4a93ec1fe75 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -75,6 +76,7 @@ void init_hal_spec_rtl8821c(PADAPTER);
 void rtl8821c_prepare_mp_txdesc(PADAPTER, struct mp_priv *);	/* rtw_mp.c */
 void rtl8821c_mp_config_rfpath(PADAPTER);			/* hal_mp.c */
 #endif
+void rtl8821c_dl_rsvd_page(PADAPTER adapter, u8 mstatus);
 
 #ifdef CONFIG_PCI_HCI
 u16 get_txbd_rw_reg(u16 q_idx);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_spec.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_spec.h
index 61843322fad9..9e0dbb033bfa 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_spec.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821c_spec.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -29,7 +30,7 @@
 #define REG_C2HEVT_MSG_NORMAL		0x1A0			/* hal_com.c */
 #define REG_C2HEVT_CLEAR			0x1AF			/* hal_com.c */
 #define REG_BCN_CTRL_1				REG_BCN_CTRL_CLINT0_8821C/* hal_com.c */
-#define REG_TSFTR1					REG_FREERUN_CNT_8821C	/* hal_com.c */
+
 #define REG_WOWLAN_WAKE_REASON	0x01C7
 #define REG_GPIO_PIN_CTRL_2			REG_GPIO_EXT_CTRL_8821C
 
@@ -112,7 +113,18 @@
 #define rOFDM0_XBAGCCore1			0xC58	/* phydm only */
 #define rOFDM0_XATxIQImbalance		0xC80	/* phydm only */
 #define rA_LSSIWrite_Jaguar			0xC90	/* RF write addr, LSSI Parameter (rtl8821c_phy.c) */
-#define rA_RFE_Pinmux_Jaguar			0xCB0	/* hal_mp.c */
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xCB0	/* hal_mp.c */
+#define	rB_RFE_Pinmux_Jaguar	0xEB0	/* Path_B RFE control pinmux */
+#define	rA_RFE_Inv_Jaguar		0xCB4	/* Path_A RFE cotrol */  
+#define	rB_RFE_Inv_Jaguar		0xEB4	/* Path_B RFE control */
+#define	rA_RFE_Jaguar			0xCB8 	/* Path_A RFE cotrol */  
+#define	rB_RFE_Jaguar			0xEB8	/* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define	r_ANTSEL_SW_Jaguar		0x900	/* ANTSEL SW Control */
+#define	bMask_RFEInv_Jaguar	0x3FF00000
+#define	bMask_AntselPathFollow_Jaguar 0x00030000   
 
 #define rOFDM1_LSTF					0xD00
 #define rOFDM1_TRxPathEnable			0xD04	/* hal_mp.c */
@@ -131,7 +143,6 @@
 #define rB_TxScale_Jaguar				0xE1C	/* Path_B TX scaling factor (hal_mp.c) */
 #define rB_IGI_Jaguar					0xE50	/* Initial Gain for path-B (hal_mp.c) */
 #define rB_LSSIWrite_Jaguar			0xE90	/* RF write addr, LSSI Parameter (rtl8821c_phy.c) */
-#define rB_RFE_Pinmux_Jaguar			0xEB0	/* hal_mp.c */
 
 /* Page1(0x100) */
 #define bBBResetB					0x100
@@ -177,8 +188,8 @@
 struct hw_port_reg {
 	u32 net_type;	/*reg_offset*/
 	u8 net_type_shift;
-	u32 macaddr;	/*reg_offset*/
-	u32 bssid;	/*reg_offset*/
+	u32 macaddr;		/*reg_offset*/
+	u32 bssid;		/*reg_offset*/
 	u32 bcn_ctl;			/*reg_offset*/
 	u32 tsf_rst;			/*reg_offset*/
 	u8 tsf_rst_bit;
@@ -186,6 +197,7 @@ struct hw_port_reg {
 	u8 bcn_space_shift;
 	u16 bcn_space_mask;
 	u32	ps_aid;			/*reg_offset*/
+	u32	ta;				/*reg_offset*/
 };
 
 #endif /* __RTL8192E_SPEC_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821ce_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821ce_hal.h
index 426002a30c9a..b1683ad0648b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821ce_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821ce_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cs_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cs_hal.h
index ceecc15f966d..bec0e21f9761 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cs_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cs_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cu_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cu_hal.h
index aec437224c73..d21d5f5cef7e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cu_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8821cu_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822b_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822b_hal.h
index 8c4093b44372..71f2a62130f5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822b_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822b_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
@@ -38,7 +39,7 @@
 #define REG_C2HEVT_MSG_NORMAL	0x1A0			/* hal_com.c */
 #define REG_C2HEVT_CLEAR	0x1AF			/* hal_com.c */
 #define REG_BCN_CTRL_1		REG_BCN_CTRL_CLINT0_8822B	/* hal_com.c */
-#define REG_TSFTR1		REG_FREERUN_CNT_8822B	/* hal_com.c */
+
 #define REG_WOWLAN_WAKE_REASON	0x01C7 /* hal_com.c */
 #define REG_GPIO_PIN_CTRL_2		REG_GPIO_EXT_CTRL_8822B		/* hal_com.c */
 
@@ -128,7 +129,6 @@
 #define rOFDM0_XBAGCCore1		0xC58	/* phydm only */
 #define rOFDM0_XATxIQImbalance		0xC80	/* phydm only */
 #define rA_LSSIWrite_Jaguar		0xC90	/* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
-#define rA_RFE_Pinmux_Jaguar		0xCB0	/* hal_mp.c */
 
 #define rOFDM1_LSTF			0xD00
 #define rOFDM1_TRxPathEnable		0xD04	/* hal_mp.c */
@@ -147,7 +147,22 @@
 #define rB_TxScale_Jaguar		0xE1C	/* Path_B TX scaling factor (hal_mp.c) */
 #define rB_IGI_Jaguar			0xE50	/* Initial Gain for path-B (hal_mp.c) */
 #define rB_LSSIWrite_Jaguar		0xE90	/* RF write addr, LSSI Parameter (rtl8822b_phy.c) */
-#define rB_RFE_Pinmux_Jaguar		0xEB0	/* hal_mp.c */
+/* RFE */
+#define rA_RFE_Pinmux_Jaguar	0xCB0	/* hal_mp.c */
+#define	rB_RFE_Pinmux_Jaguar	0xEB0	/* Path_B RFE control pinmux */
+#define	rA_RFE_Inv_Jaguar		0xCB4	/* Path_A RFE cotrol */  
+#define	rB_RFE_Inv_Jaguar		0xEB4	/* Path_B RFE control */
+#define	rA_RFE_Jaguar			0xCB8 	/* Path_A RFE cotrol */  
+#define	rB_RFE_Jaguar			0xEB8	/* Path_B RFE control */
+#define	rA_RFE_Inverse_Jaguar	0xCBC	/* Path_A RFE control inverse */
+#define	rB_RFE_Inverse_Jaguar	0xEBC	/* Path_B RFE control inverse */
+#define	r_ANTSEL_SW_Jaguar		0x900	/* ANTSEL SW Control */
+#define	bMask_RFEInv_Jaguar	0x3FF00000
+#define	bMask_AntselPathFollow_Jaguar 0x00030000
+
+#define		rC_RFE_Pinmux_Jaguar	0x18B4	/* Path_C RFE cotrol pinmux*/
+#define		rD_RFE_Pinmux_Jaguar	0x1AB4	/* Path_D RFE cotrol pinmux*/
+#define		rA_RFE_Sel_Jaguar2		0x1990
 
 /* Page1(0x100) */
 #define bBBResetB			0x100
@@ -203,6 +218,7 @@ void rtl8822b_init_hal_spec(PADAPTER);				/* hal/hal_com.c */
 void rtl8822b_prepare_mp_txdesc(PADAPTER, struct mp_priv *);	/* rtw_mp.c */
 void rtl8822b_mp_config_rfpath(PADAPTER);			/* hal_mp.c */
 #endif
+void hw_var_set_dl_rsvd_page(PADAPTER adapter, u8 mstatus);
 
 #ifdef CONFIG_USB_HCI
 #include <rtl8822bu_hal.h>
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822be_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822be_hal.h
index a81445fa166f..38e5d6fa1536 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822be_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822be_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bs_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bs_hal.h
index ffaddee09832..bb92cbc6113e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bs_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bs_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bu_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bu_hal.h
index 39618c9ea42d..6e5f23c26d56 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bu_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtl8822bu_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_android.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_android.h
index 16ae9c87f1b6..d12e056bd99b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_android.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_android.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -30,6 +31,7 @@ enum ANDROID_WIFI_CMD {
 	ANDROID_WIFI_CMD_BTCOEXSCAN_START,
 	ANDROID_WIFI_CMD_BTCOEXSCAN_STOP,
 	ANDROID_WIFI_CMD_BTCOEXMODE,
+	ANDROID_WIFI_CMD_SETSUSPENDMODE,
 	ANDROID_WIFI_CMD_SETSUSPENDOPT,
 	ANDROID_WIFI_CMD_P2P_DEV_ADDR,
 	ANDROID_WIFI_CMD_SETFWPATH,
@@ -69,6 +71,7 @@ enum ANDROID_WIFI_CMD {
 	ANDROID_WIFI_CMD_GTK_REKEY_OFFLOAD,
 #endif /* CONFIG_GTK_OL */
 	ANDROID_WIFI_CMD_P2P_DISABLE,
+	ANDROID_WIFI_CMD_SET_AEK,
 	ANDROID_WIFI_CMD_DRIVERVERSION,
 	ANDROID_WIFI_CMD_MAX
 };
@@ -90,13 +93,13 @@ void *wl_android_prealloc(int section, unsigned long size);
 int wifi_get_irq_number(unsigned long *irq_flags_ptr);
 int wifi_set_power(int on, unsigned long msec);
 int wifi_get_mac_addr(unsigned char *buf);
-void *wifi_get_country_code(char *ccode, u32 flags);
+void *wifi_get_country_code(char *ccode);
 #else
-static int rtw_android_wifictrl_func_add(void)
+static inline int rtw_android_wifictrl_func_add(void)
 {
 	return 0;
 }
-static void rtw_android_wifictrl_func_del(void) {}
+static inline void rtw_android_wifictrl_func_del(void) {}
 #endif /* defined(RTW_ENABLE_WIFI_CONTROL_FUNC) */
 
 #ifdef CONFIG_GPIO_WAKEUP
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ap.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ap.h
index 8c73cd0b73e8..446d8191cec0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ap.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ap.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -25,6 +26,8 @@ extern void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info
 
 void init_mlme_ap_info(_adapter *padapter);
 void free_mlme_ap_info(_adapter *padapter);
+u8 rtw_set_tim_ie(u8 dtim_cnt, u8 dtim_period
+	, const u8 *tim_bmp, u8 tim_bmp_len, u8 *tim_ie);
 /* void update_BCNTIM(_adapter *padapter); */
 void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len);
 void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index);
@@ -41,11 +44,15 @@ int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len);
 void rtw_ap_restore_network(_adapter *padapter);
 
 #if CONFIG_RTW_MACADDR_ACL
-void rtw_set_macaddr_acl(_adapter *adapter, int mode);
-int rtw_acl_add_sta(_adapter *adapter, const u8 *addr);
-int rtw_acl_remove_sta(_adapter *adapter, const u8 *addr);
+void rtw_macaddr_acl_init(_adapter *adapter, u8 period);
+void rtw_macaddr_acl_deinit(_adapter *adapter, u8 period);
+void rtw_macaddr_acl_clear(_adapter *adapter, u8 period);
+void rtw_set_macaddr_acl(_adapter *adapter, u8 period, int mode);
+int rtw_acl_add_sta(_adapter *adapter, u8 period, const u8 *addr);
+int rtw_acl_remove_sta(_adapter *adapter, u8 period, const u8 *addr);
 #endif /* CONFIG_RTW_MACADDR_ACL */
 
+u8 rtw_ap_set_sta_key(_adapter *adapter, const u8 *addr, u8 alg, const u8 *key, u8 keyid, u8 gk);
 u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta);
 int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid);
 int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx);
@@ -64,7 +71,8 @@ void stop_ap_mode(_adapter *padapter);
 #endif
 
 void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset);
-bool rtw_ap_chbw_decision(_adapter *adapter, s16 req_ch, s8 req_bw, s8 req_offset, u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow);
+u8 rtw_ap_chbw_decision(_adapter *adapter, u8 ifbmp, u8 excl_ifbmp
+	, s16 req_ch, s8 req_bw, s8 req_offset, u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow);
 
 #ifdef CONFIG_AUTO_AP_MODE
 void rtw_auto_ap_rx_msg_dump(_adapter *padapter, union recv_frame *precv_frame, u8 *ehdr_pos);
@@ -86,8 +94,15 @@ void rtw_update_bmc_sta_tx_rate(_adapter *adapter);
 
 void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field);
 void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len);
+#ifdef CONFIG_80211N_HT
 int rtw_ht_operation_update(_adapter *padapter);
-u8 rtw_ap_sta_linking_state_check(_adapter *adapter);
+#endif /* CONFIG_80211N_HT */
+u8 rtw_ap_sta_states_check(_adapter *adapter);
+
+#ifdef CONFIG_FW_HANDLE_TXBCN
+#define rtw_ap_get_nums(adapter)	(adapter_to_dvobj(adapter)->nr_ap_if)
+bool rtw_ap_nums_check(_adapter *adapter);
+#endif
 
 #ifdef CONFIG_SWTIMER_BASED_TXBCN
 void tx_beacon_handlder(struct dvobj_priv *pdvobj);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_beamforming.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_beamforming.h
index c0d6e0dccda2..2bb673a0a36c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_beamforming.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_beamforming.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -208,6 +209,7 @@ struct beamforming_info {
 	u32 beamformee_mu_reg_maping;
 	u8 first_mu_bfee_index;
 	u8 mu_bfer_curidx;
+	u8 cur_csi_rpt_rate;
 
 	struct sounding_info sounding_info;
 	/* schedule regular timer for sounding */
@@ -257,6 +259,21 @@ void rtw_bf_update_traffic(PADAPTER);
 #define beamforming_wk_cmd				rtw_bf_cmd
 #define update_attrib_txbf_info				rtw_bf_update_attrib
 
+#define HT_BF_CAP(adapter) ((adapter)->mlmepriv.htpriv.beamform_cap)
+#define VHT_BF_CAP(adapter) ((adapter)->mlmepriv.vhtpriv.beamform_cap)
+
+#define IS_HT_BEAMFORMEE(adapter) \
+		(HT_BF_CAP(adapter) & \
+		(BEAMFORMING_HT_BEAMFORMEE_ENABLE))
+
+#define IS_VHT_BEAMFORMEE(adapter) \
+		(VHT_BF_CAP(adapter) & \
+		(BEAMFORMING_VHT_BEAMFORMEE_ENABLE | \
+		 BEAMFORMING_VHT_MU_MIMO_STA_ENABLE))
+
+#define IS_BEAMFORMEE(adapter) (IS_HT_BEAMFORMEE(adapter) | \
+				IS_VHT_BEAMFORMEE(adapter))
+
 #else /* !RTW_BEAMFORMING_VERSION_2 */
 
 #if (BEAMFORMING_SUPPORT == 0) /*for diver defined beamforming*/
@@ -311,7 +328,7 @@ struct beamforming_entry {
 	u16	mac_id;		/* Used to Set Reg42C in IBSS mode. */
 	u16	p_aid;		/* Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. */
 	u16 g_id;
-	u8	mac_addr[6];/* Used to fill Reg6E4 to fill Mac address of CSI report frame. */
+	u8	mac_addr[ETH_ALEN];/* Used to fill Reg6E4 to fill Mac address of CSI report frame. */
 	enum channel_width	sound_bw;	/* Sounding BandWidth */
 	u16	sound_period;
 	BEAMFORMING_CAP	beamforming_entry_cap;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_br_ext.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_br_ext.h
index 54ba75ea1df5..40e72a49d030 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_br_ext.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_br_ext.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_bt_mp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_bt_mp.h
index a152d18e9765..fa5eea300038 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_bt_mp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_bt_mp.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex.h
index fd422489acde..975ea8f30b3e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex_wifionly.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex_wifionly.h
index c5a074092c5c..ffaf36723fcc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex_wifionly.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_btcoex_wifionly.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -17,6 +18,7 @@
 
 void rtw_btcoex_wifionly_switchband_notify(PADAPTER padapter);
 void rtw_btcoex_wifionly_scan_notify(PADAPTER padapter);
+void rtw_btcoex_wifionly_connect_notify(PADAPTER padapter);
 void rtw_btcoex_wifionly_hw_config(PADAPTER padapter);
 void rtw_btcoex_wifionly_initialize(PADAPTER padapter);
 void rtw_btcoex_wifionly_AntInfoSetting(PADAPTER padapter);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_byteorder.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_byteorder.h
index 8e6bb7a6df01..f117fe317d4e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_byteorder.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_byteorder.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_cmd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_cmd.h
index 1e5147ada979..1a8e7382ae04 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_cmd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_cmd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -150,6 +151,10 @@ struct P2P_PS_Offload_t {
 	u8 AllStaSleep:1; /* Only valid in Owner */
 	u8 discovery:1;
 	u8 rsvd:1;
+#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
+	u8 p2p_macid:7;
+	u8 disable_close_rf:1; /*1: not close RF but just pause p2p_macid when NoA duration*/
+#endif /* CONFIG_P2P_PS_NOA_USE_MACID_SLEEP */
 };
 
 struct P2P_PS_CTWPeriod_t {
@@ -206,6 +211,11 @@ u8 p2p_roch_cmd(_adapter *adapter
 );
 u8 p2p_cancel_roch_cmd(_adapter *adapter, u64 cookie, struct wireless_dev *wdev, u8 flags);
 
+#endif /* CONFIG_IOCTL_CFG80211 */
+#endif /* CONFIG_P2P */
+
+#ifdef CONFIG_IOCTL_CFG80211 
+u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack, u8 flags);
 struct mgnt_tx_parm {
 	u8 tx_ch;
 	u8 no_cck;
@@ -213,9 +223,7 @@ struct mgnt_tx_parm {
 	size_t len;
 	int wait_ack;
 };
-u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack, u8 flags);
-#endif /* CONFIG_IOCTL_CFG80211 */
-#endif /* CONFIG_P2P */
+#endif
 
 #else
 /* #include <ieee80211.h> */
@@ -243,9 +251,11 @@ enum rtw_drvextra_cmd_id {
 	BEAMFORMING_WK_CID,
 	LPS_CHANGE_DTIM_CID,
 	BTINFO_WK_CID,
-	DFS_MASTER_WK_CID,
+	DFS_RADAR_DETECT_WK_CID,
+	DFS_RADAR_DETECT_EN_DEC_WK_CID,
 	SESSION_TRACKER_WK_CID,
 	EN_HW_UPDATE_TSF_WK_CID,
+	PERIOD_TSF_UPDATE_END_WK_CID,
 	TEST_H2C_CID,
 	MP_CMD_WK_CID,
 	CUSTOMER_STR_WK_CID,
@@ -253,6 +263,14 @@ enum rtw_drvextra_cmd_id {
 	RSON_SCAN_WK_CID,
 #endif
 	MGNT_TX_WK_CID,
+#ifdef CONFIG_MCC_MODE
+	MCC_SET_DURATION_WK_CID,
+#endif /* CONFIG_MCC_MODE */
+	REQ_PER_CMD_WK_CID,
+	SSMPS_WK_CID,
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+	TXSS_WK_CID,
+#endif
 	MAX_WK_CID
 };
 
@@ -337,7 +355,9 @@ Command Mode
 struct createbss_parm {
 	bool adhoc;
 
-	/* used by AP mode now */
+	/* used by AP/Mesh mode now */
+	u8 ifbmp;
+	u8 excl_ifbmp;
 	s16 req_ch;
 	s8 req_bw;
 	s8 req_offset;
@@ -417,7 +437,6 @@ when 802.1x ==> keyid > 2 ==> unicast key
 struct setkey_parm {
 	u8	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 */
 };
@@ -432,10 +451,11 @@ when shared key ==> algorithm/keyid
 
 */
 struct set_stakey_parm {
-	u8	addr[ETH_ALEN];
-	u8	algorithm;
-	u8	keyid;
-	u8	key[16];
+	u8 addr[ETH_ALEN];
+	u8 algorithm;
+	u8 keyid;
+	u8 key[16];
+	u8 gk;
 };
 
 struct set_stakey_rsp {
@@ -954,11 +974,6 @@ struct LedBlink_param {
 	PVOID	 pLed;
 };
 
-/*H2C Handler index: 61 */
-struct SetChannelSwitch_param {
-	u8 new_ch_no;
-};
-
 /*H2C Handler index: 62 */
 struct TDLSoption_param {
 	u8 addr[ETH_ALEN];
@@ -1006,7 +1021,14 @@ void rtw_init_sitesurvey_parm(_adapter *padapter, struct sitesurvey_parm *pparm)
 u8 rtw_sitesurvey_cmd(_adapter *padapter, struct sitesurvey_parm *pparm);
 u8 rtw_create_ibss_cmd(_adapter *adapter, int flags);
 u8 rtw_startbss_cmd(_adapter *adapter, int flags);
-u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, s16 req_ch, s8 req_bw, s8 req_offset);
+
+#define REQ_CH_NONE		-1
+#define REQ_BW_NONE		-1
+#define REQ_BW_ORI		-2
+#define REQ_OFFSET_NONE	-1
+
+u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags
+	, u8 ifbmp, u8 excl_ifbmp, s16 req_ch, s8 req_bw, s8 req_offset);
 
 extern u8 rtw_setphy_cmd(_adapter  *padapter, u8 modem, u8 ch);
 
@@ -1016,7 +1038,7 @@ extern u8 rtw_clearstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 enque
 
 extern u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork);
 u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, int flags);
-extern u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, bool enqueue);
+extern u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, u8 flags);
 extern u8 rtw_setdatarate_cmd(_adapter  *padapter, u8 *rateset);
 extern u8 rtw_setbasicrate_cmd(_adapter  *padapter, u8 *rateset);
 extern u8 rtw_getmacreg_cmd(_adapter *padapter, u8 len, u32 addr);
@@ -1037,7 +1059,7 @@ extern u8 rtw_addbareq_cmd(_adapter *padapter, u8 tid, u8 *addr);
 extern u8 rtw_addbarsp_cmd(_adapter *padapter, u8 *addr, u16 tid, u8 status, u8 size, u16 start_seq);
 /* add for CONFIG_IEEE80211W, none 11w also can use */
 extern u8 rtw_reset_securitypriv_cmd(_adapter *padapter);
-extern u8 rtw_free_assoc_resources_cmd(_adapter *padapter);
+extern u8 rtw_free_assoc_resources_cmd(_adapter *padapter, u8 lock_scanned_queue, int flags);
 extern u8 rtw_dynamic_chk_wk_cmd(_adapter *adapter);
 
 u8 rtw_lps_ctrl_wk_cmd(_adapter *padapter, u8 lps_ctrl_type, u8 enqueue);
@@ -1056,14 +1078,17 @@ u8 rtw_dm_ra_mask_wk_cmd(_adapter *padapter, u8 *psta);
 
 extern u8 rtw_ps_cmd(_adapter *padapter);
 
+#ifdef CONFIG_DFS
+void rtw_dfs_ch_switch_hdl(struct dvobj_priv *dvobj);
+#endif
+
 #ifdef CONFIG_AP_MODE
 u8 rtw_chk_hi_queue_cmd(_adapter *padapter);
 #ifdef CONFIG_DFS_MASTER
-u8 rtw_dfs_master_cmd(_adapter *adapter, bool enqueue);
-void rtw_dfs_master_timer_hdl(void *ctx);
-void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset);
-void rtw_dfs_master_disable(_adapter *adapter, u8 ch, u8 bw, u8 offset, bool by_others);
-void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action);
+u8 rtw_dfs_rd_cmd(_adapter *adapter, bool enqueue);
+void rtw_dfs_rd_timer_hdl(void *ctx);
+void rtw_dfs_rd_en_decision(_adapter *adapter, u8 mlme_act, u8 excl_ifbmp);
+u8 rtw_dfs_rd_en_decision_cmd(_adapter *adapter);
 #endif /* CONFIG_DFS_MASTER */
 #endif /* CONFIG_AP_MODE */
 
@@ -1074,6 +1099,7 @@ u8 rtw_btinfo_cmd(PADAPTER padapter, u8 *pbuf, u16 length);
 u8 rtw_test_h2c_cmd(_adapter *adapter, u8 *buf, u8 len);
 
 u8 rtw_enable_hw_update_tsf_cmd(_adapter *padapter);
+u8 rtw_periodic_tsf_update_end_cmd(_adapter *adapter);
 
 u8 rtw_set_chbw_cmd(_adapter *padapter, u8 ch, u8 bw, u8 ch_offset, u8 flags);
 
@@ -1081,7 +1107,7 @@ u8 rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, u8 swconfig);
 u8 rtw_set_country_cmd(_adapter *adapter, int flags, const char *country_code, u8 swconfig);
 
 extern u8 rtw_led_blink_cmd(_adapter *padapter, PVOID pLed);
-extern u8 rtw_set_csa_cmd(_adapter *padapter, u8 new_ch_no);
+extern u8 rtw_set_csa_cmd(_adapter *adapter);
 extern u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option);
 
 u8 rtw_mp_cmd(_adapter *adapter, u8 mp_cmd_id, u8 flags);
@@ -1106,10 +1132,35 @@ u8 rtw_rson_scan_wk_cmd(_adapter *adapter, int op);
 
 u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void *), void *context);
 
+struct ssmps_cmd_parm {
+	struct sta_info *sta;
+	u8 smps;
+};
+u8 rtw_ssmps_wk_cmd(_adapter *adapter, struct sta_info *sta, u8 smps, u8 enqueue);
+
 u8 session_tracker_chk_cmd(_adapter *adapter, struct sta_info *sta);
 u8 session_tracker_add_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
 u8 session_tracker_del_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);
 
+#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
+u8 rtw_req_per_cmd(_adapter * adapter);
+#endif
+
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+struct txss_cmd_parm {
+	struct sta_info *sta;
+	u8 tx_1ss;
+};
+
+void rtw_ctrl_txss_update_mimo_type(_adapter *adapter, struct sta_info *sta);
+u8 rtw_ctrl_txss(_adapter *adapter, struct sta_info *sta, u8 tx_1ss);
+void rtw_ctrl_tx_ss_by_tp(_adapter *adapter, u8 from_timer);
+
+#ifdef DBG_CTRL_TXSS
+void dbg_ctrl_txss(_adapter *adapter, u8 tx_1ss);
+#endif
+#endif
+
 u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf);
 
 extern void rtw_survey_cmd_callback(_adapter  *padapter, struct cmd_obj *pcmd);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_debug.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_debug.h
index 42c3c864824e..41b6990c9b19 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_debug.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_debug.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -68,8 +69,6 @@ extern void rtl871x_cedbg(const char *fmt, ...);
 
 #define RTW_DBGDUMP 0 /* 'stream' for _dbgdump */
 
-/* don't use these 3 APIs anymore, will be removed later */
-#define RT_TRACE(_Comp, _Level, Fmt) do {} while (0)
 
 
 #undef _dbgdump
@@ -308,12 +307,6 @@ int proc_get_rf_info(struct seq_file *m, void *v);
 int proc_get_scan_param(struct seq_file *m, void *v);
 ssize_t proc_set_scan_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_scan_abort(struct seq_file *m, void *v);
-#ifdef CONFIG_SCAN_BACKOP
-int proc_get_backop_flags_sta(struct seq_file *m, void *v);
-ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-int proc_get_backop_flags_ap(struct seq_file *m, void *v);
-ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-#endif /* CONFIG_SCAN_BACKOP */
 #ifdef CONFIG_RTW_REPEATER_SON
 int proc_get_rson_data(struct seq_file *m, void *v);
 ssize_t proc_set_rson_data(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
@@ -321,6 +314,9 @@ ssize_t proc_set_rson_data(struct file *file, const char __user *buffer, size_t
 int proc_get_survey_info(struct seq_file *m, void *v);
 ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_ap_info(struct seq_file *m, void *v);
+#ifdef ROKU_PRIVATE
+int proc_get_infra_ap(struct seq_file *m, void *v);
+#endif /* ROKU_PRIVATE */
 ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_trx_info(struct seq_file *m, void *v);
 ssize_t proc_set_tx_power_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
@@ -340,9 +336,6 @@ int proc_get_bmc_tx_rate(struct seq_file *m, void *v);
 ssize_t proc_set_bmc_tx_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #endif /*CONFIG_AP_MODE*/
 
-int proc_get_dis_pwt(struct seq_file *m, void *v);
-ssize_t proc_set_dis_pwt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-
 int proc_get_ps_dbg_info(struct seq_file *m, void *v);
 ssize_t proc_set_ps_dbg_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
@@ -351,16 +344,17 @@ bool rtw_fwdl_test_trigger_wintint_rdy_fail(void);
 ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void);
 ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-#ifdef CONFIG_DFS_MASTER
-int proc_get_dfs_master_test_case(struct seq_file *m, void *v);
-ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
-#endif /* CONFIG_DFS_MASTER */
 u32 rtw_get_wait_hiq_empty_ms(void);
 ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 void rtw_sta_linking_test_set_start(void);
 bool rtw_sta_linking_test_wait_done(void);
 bool rtw_sta_linking_test_force_fail(void);
 ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#ifdef CONFIG_AP_MODE
+u16 rtw_ap_linking_test_force_auth_fail(void);
+u16 rtw_ap_linking_test_force_asoc_fail(void);
+ssize_t proc_set_ap_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
 
 int proc_get_rx_stat(struct seq_file *m, void *v);
 int proc_get_tx_stat(struct seq_file *m, void *v);
@@ -379,10 +373,15 @@ ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size
 
 int proc_get_trx_info_debug(struct seq_file *m, void *v);
 
+#ifdef CONFIG_HUAWEI_PROC
+int proc_get_huawei_trx_info(struct seq_file *m, void *v);
+#endif
+
 int proc_get_rx_signal(struct seq_file *m, void *v);
 ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_hw_status(struct seq_file *m, void *v);
 ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_mac_rptbuf(struct seq_file *m, void *v);
 
 #ifdef CONFIG_80211N_HT
 int proc_get_ht_enable(struct seq_file *m, void *v);
@@ -394,8 +393,6 @@ ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t co
 int proc_get_ampdu_enable(struct seq_file *m, void *v);
 ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
-int proc_get_mac_rptbuf(struct seq_file *m, void *v);
-
 void dump_regsty_rx_ampdu_size_limit(void *sel, _adapter *adapter);
 int proc_get_rx_ampdu(struct seq_file *m, void *v);
 ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
@@ -471,6 +468,13 @@ int proc_get_int_logs(struct seq_file *m, void *v);
 int proc_get_rx_ring(struct seq_file *m, void *v);
 int proc_get_tx_ring(struct seq_file *m, void *v);
 int proc_get_pci_aspm(struct seq_file *m, void *v);
+int proc_get_pci_conf_space(struct seq_file *m, void *v);
+ssize_t proc_set_pci_conf_space(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+int proc_get_pci_bridge_conf_space(struct seq_file *m, void *v);
+ssize_t proc_set_pci_bridge_conf_space(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+
 #ifdef DBG_TXBD_DESC_DUMP
 int proc_get_tx_ring_ext(struct seq_file *m, void *v);
 ssize_t proc_set_tx_ring_ext(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
@@ -502,6 +506,7 @@ ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_
 
 #ifdef CONFIG_POWER_SAVING
 int proc_get_ps_info(struct seq_file *m, void *v);
+ssize_t proc_set_ps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #ifdef CONFIG_WMMPS_STA	
 int proc_get_wmmps_info(struct seq_file *m, void *v);
 ssize_t proc_set_wmmps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
@@ -536,13 +541,20 @@ int proc_get_tx_auth(struct seq_file *m, void *v);
 #endif /* CONFIG_IEEE80211W */
 
 #endif /* CONFIG_PROC_DEBUG */
+ssize_t proc_set_tx_auth_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
 int proc_get_efuse_map(struct seq_file *m, void *v);
 ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
+int proc_get_pathb_phase(struct seq_file *m, void *v);
+ssize_t proc_set_pathb_phase(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+#endif
+
 #ifdef CONFIG_MCC_MODE
 int proc_get_mcc_info(struct seq_file *m, void *v);
 ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+ssize_t proc_set_mcc_duration(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 ssize_t proc_set_mcc_single_tx_criteria(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 ssize_t proc_set_mcc_ap_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 ssize_t proc_set_mcc_ap_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
@@ -551,14 +563,18 @@ ssize_t proc_set_mcc_sta_bw20_target_tp(struct file *file, const char __user *bu
 ssize_t proc_set_mcc_sta_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 ssize_t proc_set_mcc_sta_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 int proc_get_mcc_policy_table(struct seq_file *m, void *v);
-ssize_t proc_set_mcc_policy_table(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #endif /* CONFIG_MCC_MODE */
 
 int proc_get_ack_timeout(struct seq_file *m, void *v);
 ssize_t proc_set_ack_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 
-int proc_get_iqk_fw_offload(struct seq_file *m, void *v);
-ssize_t proc_set_iqk_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_fw_offload(struct seq_file *m, void *v);
+ssize_t proc_set_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+
+#ifdef CONFIG_FW_HANDLE_TXBCN
+ssize_t proc_set_fw_tbtt_rpt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_fw_tbtt_rpt(struct seq_file *m, void *v);
+#endif
 
 #ifdef CONFIG_DBG_RF_CAL
 int proc_get_iqk_info(struct seq_file *m, void *v);
@@ -567,6 +583,25 @@ int proc_get_lck_info(struct seq_file *m, void *v);
 ssize_t proc_set_lck(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
 #endif /*CONFIG_DBG_RF_CAL*/
 
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+ssize_t proc_set_txss_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_txss_tp(struct seq_file *m, void *v);
+#ifdef DBG_CTRL_TXSS
+ssize_t proc_set_txss_ctrl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_txss_ctrl(struct seq_file *m, void *v);
+#endif
+#endif
+
+#ifdef CONFIG_LPS_CHK_BY_TP
+ssize_t proc_set_lps_chk_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_lps_chk_tp(struct seq_file *m, void *v);
+#endif
+
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+ssize_t proc_set_smps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
+int proc_get_smps(struct seq_file *m, void *v);
+#endif
+
 #define _drv_always_		1
 #define _drv_emerg_			2
 #define _drv_alert_			3
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_eeprom.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_eeprom.h
index 62304d577f38..02c160dc114d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_eeprom.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_eeprom.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_efuse.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_efuse.h
index 2e7334287f9a..fdd1d7bbcc25 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_efuse.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_efuse.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -50,7 +51,7 @@ enum _EFUSE_DEF_TYPE {
 #define		EFUSE_MAX_SECTION_NUM	128
 #define		EFUSE_MAX_BANK_SIZE		512
 
-/*RTL8822B 8821C BT EFUSE Define 1 BANK 128 size logical map 1024*/ 
+/*RTL8822B 8821C BT EFUSE Define 1 BANK 128 size logical map 1024*/
 #ifdef RTW_HALMAC
 #define BANK_NUM		1
 #define EFUSE_BT_REAL_BANK_CONTENT_LEN	128
@@ -179,13 +180,6 @@ extern u8 fakeBTEfuseModifiedMap[];
 #define		MAX_SEGMENT_NUM			200
 #define		MAX_BUF_SIZE				(MAX_SEGMENT_SIZE*MAX_SEGMENT_NUM)
 #define		TMP_BUF_SIZE				100
-
-static	u8	dcmd_Return_Buffer[MAX_BUF_SIZE] = {0};
-static	u32	dcmd_Buf_Idx = 0;
-static	u32	dcmd_Finifh_Flag = 0;
-
-static	char	dcmd_Buf[TMP_BUF_SIZE];
-
 #define		rtprintf					dcmd_Store_Return_Buf
 
 u8	efuse_bt_GetCurrentSize(PADAPTER padapter, u16 *size);
@@ -222,6 +216,9 @@ void	EFUSE_ShadowMapUpdate(PADAPTER pAdapter, u8 efuseType, BOOLEAN bPseudoTest)
 void	EFUSE_ShadowRead(PADAPTER pAdapter, u8 Type, u16 Offset, u32 *Value);
 #define efuse_logical_map_read(adapter, type, offset, value) EFUSE_ShadowRead((adapter), (type), (offset), (value))
 
+BOOLEAN rtw_file_efuse_IsMasked(PADAPTER pAdapter, u16 Offset);
+BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset);
+
 VOID	hal_ReadEFuse_BT_logic_map(
 	PADAPTER	padapter,
 	u16			_offset,
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_event.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_event.h
index 8e4d5d6f5c5c..4d2220323f11 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_event.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_event.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ht.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ht.h
index e6a22ab63da2..8b1536b5430c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ht.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ht.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -15,6 +16,8 @@
 #ifndef _RTW_HT_H_
 #define _RTW_HT_H_
 
+#define HT_CAP_IE_LEN 26
+#define HT_OP_IE_LEN 22
 
 struct ht_priv {
 	u8	ht_option;
@@ -42,9 +45,27 @@ struct ht_priv {
 	u8	beamform_cap;
 	u8	smps_cap; /*spatial multiplexing power save mode. 0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
 
+	u8 op_present:1; /* ht_op is present */
+
 	struct rtw_ieee80211_ht_cap ht_cap;
+	u8 ht_op[HT_OP_IE_LEN];
+
+};
 
+#ifdef ROKU_PRIVATE
+struct ht_priv_infra_ap {
+
+	/*Infra mode, only store AP's info , not intersection of STA and AP*/
+	u8	channel_width_infra_ap;
+	u8	sgi_20m_infra_ap;
+	u8	sgi_40m_infra_ap;
+	u8	ldpc_cap_infra_ap;
+	u8	stbc_cap_infra_ap;
+	u8	MCS_set_infra_ap[16];
+	u8	Rx_ss_infra_ap;
+	u16	rx_highest_data_rate_infra_ap;
 };
+#endif /* ROKU_PRIVATE */
 
 typedef enum AGGRE_SIZE {
 	HT_AGG_SIZE_8K = 0,
@@ -57,23 +78,6 @@ typedef enum AGGRE_SIZE {
 	VHT_AGG_SIZE_1024K = 7,
 } AGGRE_SIZE_E, *PAGGRE_SIZE_E;
 
-typedef enum _RT_HT_INF0_CAP {
-	RT_HT_CAP_USE_TURBO_AGGR = 0x01,
-	RT_HT_CAP_USE_LONG_PREAMBLE = 0x02,
-	RT_HT_CAP_USE_AMPDU = 0x04,
-	RT_HT_CAP_USE_WOW = 0x8,
-	RT_HT_CAP_USE_SOFTAP = 0x10,
-	RT_HT_CAP_USE_92SE = 0x20,
-	RT_HT_CAP_USE_88C_92C = 0x40,
-	RT_HT_CAP_USE_AP_CLIENT_MODE = 0x80,	/* AP team request to reserve this bit, by Emily */
-} RT_HT_INF0_CAPBILITY, *PRT_HT_INF0_CAPBILITY;
-
-typedef enum _RT_HT_INF1_CAP {
-	RT_HT_CAP_USE_VIDEO_CLIENT = 0x01,
-	RT_HT_CAP_USE_JAGUAR_BCUT = 0x02,
-	RT_HT_CAP_USE_JAGUAR_CCUT = 0x04,
-} RT_HT_INF1_CAPBILITY, *PRT_HT_INF1_CAPBILITY;
-
 #define	LDPC_HT_ENABLE_RX			BIT0
 #define	LDPC_HT_ENABLE_TX			BIT1
 #define	LDPC_HT_TEST_TX_ENABLE		BIT2
@@ -138,6 +142,9 @@ typedef enum _RT_HT_INF1_CAP {
 	, (1 << (13+GET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(((u8 *)x)-2)))-1 \
 	, GET_HT_CAP_ELE_MIN_MPDU_S_SPACE(((u8 *)x)-2)
 
+#define SET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 0, 2, _val)
+#define SET_HT_CAP_ELE_MIN_MPDU_S_SPACE(_pEleStart, _val)	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart)) + 2, 2, 3, _val)
+
 /* Supported MCS Set field */
 #define HT_CAP_ELE_SUP_MCS_SET(_pEleStart)				(((u8 *)(_pEleStart))+3)
 #define HT_CAP_ELE_RX_MCS_MAP(_pEleStart)				HT_CAP_ELE_SUP_MCS_SET(_pEleStart)
@@ -147,11 +154,14 @@ typedef enum _RT_HT_INF1_CAP {
 #define GET_HT_CAP_ELE_TX_MAX_SS(_pEleStart)			LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 2, 2)
 #define GET_HT_CAP_ELE_TX_UEQM(_pEleStart)				LE_BITS_TO_1BYTE(((u8 *)(_pEleStart))+15, 4, 1)
 
-#define HT_SUP_MCS_SET_FMT "%02x %02x %02x %02x %02x%02x%02x%02x%02x%02x" \
+#define HT_RX_MCS_BMP_FMT "%02x %02x %02x %02x %02x%02x%02x%02x%02x%02x"
+#define HT_RX_MCS_BMP_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
+	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9]
+
+#define HT_SUP_MCS_SET_FMT HT_RX_MCS_BMP_FMT \
 	/* "\n%02x%02x%02x%02x%02x%02x" */\
 	" %uMbps %s%s%s"
-#define HT_SUP_MCS_SET_ARG(x) ((u8 *)(x))[0], ((u8 *)(x))[1], ((u8 *)(x))[2], ((u8 *)(x))[3], ((u8 *)(x))[4], ((u8 *)(x))[5], \
-	((u8 *)(x))[6], ((u8 *)(x))[7], ((u8 *)(x))[8], ((u8 *)(x))[9] \
+#define HT_SUP_MCS_SET_ARG(x) HT_RX_MCS_BMP_ARG(x) \
 	/*,((u8 *)(x))[10], ((u8 *)(x))[11], ((u8 *)(x))[12], ((u8 *)(x))[13], ((u8 *)(x))[14], ((u8 *)(x))[15] */\
 	, GET_HT_CAP_ELE_RX_HIGHEST_DATA_RATE(((u8 *)x)-3) \
 	, GET_HT_CAP_ELE_TX_MCS_DEF(((u8 *)x)-3) ? "TX_MCS_DEF " : "" \
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_io.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_io.h
index 28430d8b7fa1..1b4e2a5b90dc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_io.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_io.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -395,10 +396,12 @@ u32 _rtw_write_port_and_wait(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem, int
 extern void _rtw_write_port_cancel(_adapter *adapter);
 
 #ifdef DBG_IO
-bool match_read_sniff_ranges(u32 addr, u16 len);
-bool match_write_sniff_ranges(u32 addr, u16 len);
-bool match_rf_read_sniff_ranges(u8 path, u32 addr, u32 mask);
-bool match_rf_write_sniff_ranges(u8 path, u32 addr, u32 mask);
+struct rtw_io_sniff_ent;
+const char *rtw_io_sniff_ent_get_tag(const struct rtw_io_sniff_ent *ent);
+const struct rtw_io_sniff_ent *match_read_sniff(_adapter *adapter, u32 addr, u16 len, u32 val);
+const struct rtw_io_sniff_ent *match_write_sniff(_adapter *adapter, u32 addr, u16 len, u32 val);
+bool match_rf_read_sniff_ranges(_adapter *adapter, u8 path, u32 addr, u32 mask);
+bool match_rf_write_sniff_ranges(_adapter *adapter, u8 path, u32 addr, u32 mask);
 
 extern u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line);
 extern u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int line);
@@ -455,10 +458,6 @@ int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller
 #endif /* CONFIG_SDIO_HCI */
 
 #else /* DBG_IO */
-#define match_read_sniff_ranges(addr, len) _FALSE
-#define match_write_sniff_ranges(addr, len) _FALSE
-#define match_rf_read_sniff_ranges(path, addr, mask) _FALSE
-#define match_rf_write_sniff_ranges(path, addr, mask) _FALSE
 #define rtw_read8(adapter, addr) _rtw_read8((adapter), (addr))
 #define rtw_read16(adapter, addr) _rtw_read16((adapter), (addr))
 #define rtw_read32(adapter, addr) _rtw_read32((adapter), (addr))
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl.h
index 4924751c2456..8621af5d444d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_query.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_query.h
index cc7b557ee346..549ee371591c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_query.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_query.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_rtl.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_rtl.h
index 2df8713ad500..f3e0bbeb9389 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_rtl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_rtl.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_set.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_set.h
index 5d811f79aecd..d8688ac5bd51 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_set.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_ioctl_set.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -46,17 +47,14 @@ void rtw_pnp_sleep_wk(void *context);
 
 #endif
 
-u8 rtw_set_802_11_add_key(_adapter *padapter, NDIS_802_11_KEY *key);
 u8 rtw_set_802_11_authentication_mode(_adapter *pdapter, NDIS_802_11_AUTHENTICATION_MODE authmode);
 u8 rtw_set_802_11_bssid(_adapter *padapter, u8 *bssid);
 u8 rtw_set_802_11_add_wep(_adapter *padapter, NDIS_802_11_WEP *wep);
 u8 rtw_set_802_11_disassociate(_adapter *padapter);
 u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, struct sitesurvey_parm *pparm);
 u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype);
-u8 rtw_set_802_11_remove_wep(_adapter *padapter, u32 keyindex);
 u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid);
 u8 rtw_set_802_11_connect(_adapter *padapter, u8 *bssid, NDIS_802_11_SSID *ssid);
-u8 rtw_set_802_11_remove_key(_adapter *padapter, NDIS_802_11_REMOVE_KEY *key);
 
 u8 rtw_validate_bssid(u8 *bssid);
 u8 rtw_validate_ssid(NDIS_802_11_SSID *ssid);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_iol.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_iol.h
index fa35a59c75c7..21e1af8a61ed 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_iol.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_iol.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mcc.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mcc.h
index b08054785231..bb417026ce53 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mcc.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mcc.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
@@ -28,6 +29,7 @@
 #define MCC_SWCH_FW_EARLY_TIME 10 /* ms */
 #define MCC_EXPIRE_TIME 50 /* ms */
 #define MCC_TOLERANCE_TIME 2 /* 2*2 = 4s */
+#define MCC_UPDATE_PARAMETER_THRESHOLD 5 /* ms */
 
 #define MCC_ROLE_STA_GC_MGMT_QUEUE_MACID 0
 #define MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID 1
@@ -55,8 +57,19 @@
 #define MAX_MCC_NUM 2
 
 #define MCC_STOP(adapter) (adapter->mcc_adapterpriv.mcc_tx_stop)
-#define MCC_EN(adapter) (adapter->registrypriv.en_mcc)
-
+#define MCC_EN(adapter) (adapter_to_dvobj(adapter)->mcc_objpriv.en_mcc)
+#define SET_MCC_EN_FLAG(adapter, flag)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.en_mcc = (flag); \
+	} while (0)
+#define SET_MCC_DURATION(adapter, val)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.duration = (val); \
+	} while (0)
+#define SET_MCC_RUNTIME_DURATION(adapter, flag)\
+	do { \
+		adapter_to_dvobj(adapter)->mcc_objpriv.enable_runtime_duration = (flag); \
+	} while (0)
 /* Represent Channel Tx Null setting */
 enum mcc_channel_tx_null {
 	MCC_ENABLE_TX_NULL = 0,
@@ -84,10 +97,11 @@ enum mcc_status_rpt {
 	MCC_RPT_READY = 3,
 	MCC_RPT_SWICH_CHANNEL_NOTIFY = 7,
 	MCC_RPT_UPDATE_NOA_START_TIME = 8,
+	MCC_RPT_TSF = 9,
 	MCC_RPT_MAX,
 };
 
-enum MCC_ROLE {
+enum mcc_role {
 	MCC_ROLE_STA = 0,
 	MCC_ROLE_AP = 1,
 	MCC_ROLE_GC = 2,
@@ -102,10 +116,21 @@ struct mcc_iqk_backup {
 	u16 RX_Y;
 };
 
+enum MCC_DURATION_SETTING {
+	MCC_DURATION_MAPPING = 0,
+	MCC_DURATION_DIRECET = 1,
+};
+
+enum MCC_SCHED_MODE {
+	MCC_FAIR_SCHEDULE = 0,
+	MCC_FAVOE_STA = 1,
+	MCC_FAVOE_P2P = 2,
+};
+
 /*  mcc data for adapter */
 struct mcc_adapter_priv {
 	u8 order;		/* FW document, softap/AP must be 0 */
-	u8 role;			/* MCC role(AP,STA,GO,GC) */
+	enum mcc_role role;			/* MCC role(AP,STA,GO,GC) */
 	u8 mcc_duration; /* channel stay period, UNIT:1TU */
 
 	/* flow control */
@@ -134,10 +159,20 @@ struct mcc_adapter_priv {
 
 	u8 p2p_go_noa_ie[MAX_P2P_IE_LEN];
 	u32 p2p_go_noa_ie_len;
+	u64 tsf;
+#ifdef CONFIG_TDLS
+	u8 backup_tdls_en;
+#endif /* CONFIG_TDLS */
+
+	u8 null_early;
+	u8 null_rty_num;
 };
 
 struct mcc_obj_priv {
-	u8 duration; /* channel stay period, UNIT:1TU */
+	u8 en_mcc; /* enable MCC or not */
+	u8 duration; /* store duration(%) from registry, for primary adapter */
+	u8 interval;
+	u8 start_time;
 	u8 mcc_c2h_status;
 	u8 cur_mcc_success_cnt; /* used for check mcc switch channel success */
 	u8 prev_mcc_success_cnt; /* used for check mcc switch channel success */
@@ -145,11 +180,25 @@ struct mcc_obj_priv {
 	u8 mcc_loc_rsvd_paga[MAX_MCC_NUM];  /* mcc rsvd page */
 	u8 mcc_status; /* mcc status stop or start .... */
 	u8 policy_index;
+	u8 mcc_stop_threshold;
+	u8 current_order;
+	u8 last_tsfdiff;
 	systime mcc_launch_time; /* mcc launch time, used for starting detect mcc switch channel success */
 	_mutex mcc_mutex;
 	_lock mcc_lock;
 	PADAPTER iface[MAX_MCC_NUM]; /* by order, use for mcc parameter cmd */
 	struct submit_ctx mcc_sctx;
+	struct submit_ctx mcc_tsf_req_sctx;
+	_mutex mcc_tsf_req_mutex;
+	u8 mcc_tsf_req_sctx_order; /* record current order for mcc_tsf_req_sctx */
+#ifdef CONFIG_MCC_MODE_V2
+	u8 mcc_iqk_value_rsvd_page[3];
+#endif /* CONFIG_MCC_MODE_V2 */
+	u8 mcc_pwr_idx_rsvd_page[MAX_MCC_NUM];
+	u8 enable_runtime_duration;
+	u32 backup_phydm_ability;
+	/* for LG */
+	u8 mchan_sched_mode;
 };
 
 /* backup IQK val */
@@ -166,7 +215,7 @@ void rtw_hal_clear_mcc_status(PADAPTER padapter, u8 mcc_status);
 
 /* dl mcc rsvd page */
 u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index
-	, u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len, RSVDPAGE_LOC *rsvd_page_loc);
+	, u8 tx_desc, u32 page_size, u8 *total_page_num, RSVDPAGE_LOC *rsvd_page_loc, u8 *page_num);
 
 /* handle C2H */
 void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf);
@@ -208,9 +257,16 @@ void rtw_hal_mcc_issue_null_data(_adapter *padapter, u8 chbw_allow, u8 ps_mode);
 
 u8 *rtw_hal_mcc_append_go_p2p_ie(PADAPTER padapter, u8 *pframe, u32 *len);
 
-void rtw_hal_mcc_update_switch_channel_policy_table(PADAPTER padapter);
-
 void rtw_hal_dump_mcc_policy_table(void *sel);
 
+void rtw_hal_mcc_update_macid_bitmap(PADAPTER padapter, int mac_id, u8 add);
+
+void rtw_hal_mcc_process_noa(PADAPTER padapter);
+
+void rtw_hal_mcc_parameter_init(PADAPTER padapter);
+
+u8 rtw_set_mcc_duration_hdl(PADAPTER adapter, u8 type, const u8 *val);
+
+u8 rtw_set_mcc_duration_cmd(_adapter *adapter, u8 type, u8 val);
 #endif /* _RTW_MCC_H_ */
 #endif /* CONFIG_MCC_MODE */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mem.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mem.h
index 229028c35fa7..2dcef922a038 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mem.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mem.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mi.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mi.h
index 76d4e9ea6bf9..66d33d00b552 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mi.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -18,6 +19,8 @@
 void rtw_mi_update_union_chan_inf(_adapter *adapter, u8 ch, u8 offset , u8 bw);
 u8 rtw_mi_stayin_union_ch_chk(_adapter *adapter);
 u8 rtw_mi_stayin_union_band_chk(_adapter *adapter);
+
+int rtw_mi_get_ch_setting_union_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp, u8 *ch, u8 *bw, u8 *offset);
 int rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
 int rtw_mi_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset);
 
@@ -30,6 +33,7 @@ struct mi_state {
 #endif
 #ifdef CONFIG_AP_MODE
 	u8 ap_num;			/* WIFI_AP_STATE && _FW_LINKED */
+	u8 starting_ap_num;	/*WIFI_FW_AP_STATE*/
 	u8 ld_ap_num;		/* WIFI_AP_STATE && _FW_LINKED && asoc_sta_count > 2 */
 #endif
 	u8 adhoc_num;		/* (WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) && _FW_LINKED */
@@ -47,7 +51,11 @@ struct mi_state {
 	#endif
 	u8 mgmt_tx_num;
 #endif
-
+#ifdef CONFIG_P2P
+	u8 p2p_device_num;
+	u8 p2p_gc;
+	u8 p2p_go;
+#endif
 	u8 union_ch;
 	u8 union_bw;
 	u8 union_offset;
@@ -65,9 +73,11 @@ struct mi_state {
 
 #ifdef CONFIG_AP_MODE
 #define MSTATE_AP_NUM(_mstate)			((_mstate)->ap_num)
+#define MSTATE_AP_STARTING_NUM(_mstate)	((_mstate)->starting_ap_num)
 #define MSTATE_AP_LD_NUM(_mstate)		((_mstate)->ld_ap_num)
 #else
 #define MSTATE_AP_NUM(_mstate)			0
+#define MSTATE_AP_STARTING_NUM(_mstate) 0
 #define MSTATE_AP_LD_NUM(_mstate)		0
 #endif
 
@@ -92,6 +102,16 @@ struct mi_state {
 #define MSTATE_ROCH_NUM(_mstate)		0
 #endif
 
+#ifdef CONFIG_P2P
+#define MSTATE_P2P_DV_NUM(_mstate)		((_mstate)->p2p_device_num)
+#define MSTATE_P2P_GC_NUM(_mstate)		((_mstate)->p2p_gc)
+#define MSTATE_P2P_GO_NUM(_mstate)		((_mstate)->p2p_go)
+#else
+#define MSTATE_P2P_DV_NUM(_mstate)		0
+#define MSTATE_P2P_GC_NUM(_mstate)		0
+#define MSTATE_P2P_GO_NUM(_mstate)		0
+#endif
+
 #if defined(CONFIG_IOCTL_CFG80211)
 #define MSTATE_MGMT_TX_NUM(_mstate)		((_mstate)->mgmt_tx_num)
 #else
@@ -109,8 +129,10 @@ struct mi_state {
 #define rtw_mi_get_assoced_sta_num(adapter)	DEV_STA_LD_NUM(adapter_to_dvobj(adapter))
 #define rtw_mi_get_ap_num(adapter)			DEV_AP_NUM(adapter_to_dvobj(adapter))
 #define rtw_mi_get_mesh_num(adapter)		DEV_MESH_NUM(adapter_to_dvobj(adapter))
+u8 rtw_mi_get_assoc_if_num(_adapter *adapter);
 
 /* For now, not return union_ch/bw/offset */
+void rtw_mi_status_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp, struct mi_state *mstate);
 void rtw_mi_status(_adapter *adapter, struct mi_state *mstate);
 void rtw_mi_status_no_self(_adapter *adapter, struct mi_state *mstate);
 void rtw_mi_status_no_others(_adapter *adapter, struct mi_state *mstate);
@@ -138,8 +160,8 @@ u8 rtw_mi_buddy_netif_caron_qstart(_adapter *padapter);
 
 void rtw_mi_scan_abort(_adapter *adapter, bool bwait);
 void rtw_mi_buddy_scan_abort(_adapter *adapter, bool bwait);
-void rtw_mi_start_drv_threads(_adapter *adapter);
-void rtw_mi_buddy_start_drv_threads(_adapter *adapter);
+u32 rtw_mi_start_drv_threads(_adapter *adapter);
+u32 rtw_mi_buddy_start_drv_threads(_adapter *adapter);
 void rtw_mi_stop_drv_threads(_adapter *adapter);
 void rtw_mi_buddy_stop_drv_threads(_adapter *adapter);
 void rtw_mi_cancel_all_timer(_adapter *adapter);
@@ -154,6 +176,9 @@ void rtw_mi_buddy_intf_start(_adapter *adapter);
 void rtw_mi_intf_stop(_adapter *adapter);
 void rtw_mi_buddy_intf_stop(_adapter *adapter);
 
+#ifdef CONFIG_NEW_NETDEV_HDL
+u8 rtw_mi_hal_iface_init(_adapter *padapter);
+#endif
 void rtw_mi_suspend_free_assoc_resource(_adapter *adapter);
 void rtw_mi_buddy_suspend_free_assoc_resource(_adapter *adapter);
 
@@ -233,9 +258,6 @@ void rtw_mi_buddy_adapter_reset(_adapter *padapter);
 u8 rtw_mi_dynamic_check_timer_handlder(_adapter *padapter);
 u8 rtw_mi_buddy_dynamic_check_timer_handlder(_adapter *padapter);
 
-u8 rtw_mi_dev_unload(_adapter *padapter);
-u8 rtw_mi_buddy_dev_unload(_adapter *padapter);
-
 extern void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter);
 u8 rtw_mi_dynamic_chk_wk_hdl(_adapter *padapter);
 u8 rtw_mi_buddy_dynamic_chk_wk_hdl(_adapter *padapter);
@@ -250,6 +272,9 @@ extern void sreset_start_adapter(_adapter *padapter);
 extern void sreset_stop_adapter(_adapter *padapter);
 u8 rtw_mi_sreset_adapter_hdl(_adapter *padapter, u8 bstart);
 u8 rtw_mi_buddy_sreset_adapter_hdl(_adapter *padapter, u8 bstart);
+#if defined(DBG_CONFIG_ERROR_RESET) && defined(CONFIG_CONCURRENT_MODE)
+void rtw_mi_ap_info_restore(_adapter *adapter);
+#endif
 
 u8 rtw_mi_tx_beacon_hdl(_adapter *padapter);
 u8 rtw_mi_buddy_tx_beacon_hdl(_adapter *padapter);
@@ -265,7 +290,7 @@ u8 rtw_mi_buddy_stay_in_p2p_mode(_adapter *padapter);
 #endif
 
 _adapter *rtw_get_iface_by_id(_adapter *padapter, u8 iface_id);
-_adapter *rtw_get_iface_by_macddr(_adapter *padapter, u8 *mac_addr);
+_adapter *rtw_get_iface_by_macddr(_adapter *padapter, const u8 *mac_addr);
 _adapter *rtw_get_iface_by_hwport(_adapter *padapter, u8 hw_port);
 
 void rtw_mi_buddy_clone_bcmc_packet(_adapter *padapter, union recv_frame *precvframe, u8 *pphy_status);
@@ -275,6 +300,8 @@ void rtw_mi_buddy_clone_bcmc_packet(_adapter *padapter, union recv_frame *precvf
 _adapter *rtw_mi_get_ap_adapter(_adapter *padapter);
 #endif
 
+u8 rtw_mi_get_ld_sta_ifbmp(_adapter *adapter);
+u8 rtw_mi_get_ap_mesh_ifbmp(_adapter *adapter);
 void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b);
 
 #endif /*__RTW_MI_H_*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme.h
index 3ad89a000524..e2490d4643b7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -56,7 +57,7 @@
 #define WIFI_MP_CTX_CCK_CS				0x00200000 /* in continuous tx with carrier suppression */
 #define WIFI_MP_LPBK_STATE				0x00400000
 #define WIFI_OP_CH_SWITCHING			0x00800000
-/*#define WIFI_UNDEFINED_STATE			0x01000000*/
+#define WIFI_UNDER_KEY_HANDSHAKE	0x01000000
 /*#define WIFI_UNDEFINED_STATE			0x02000000*/
 /*#define WIFI_UNDEFINED_STATE			0x04000000*/
 /*#define WIFI_UNDEFINED_STATE			0x08000000*/
@@ -78,15 +79,16 @@ const char *get_miracast_mode_str(int mode);
 void rtw_wfd_st_switch(struct sta_info *sta, bool on);
 
 #define MLME_STATE(adapter) get_fwstate(&((adapter)->mlmepriv))
-
-#define MLME_IS_NULL(adapter) (check_fwstate(&((adapter)->mlmepriv), WIFI_NULL_STATE))
-#define MLME_IS_STA(adapter) (MLME_STATE((adapter)) & WIFI_STATION_STATE)
-#define MLME_IS_AP(adapter) (MLME_STATE((adapter)) & WIFI_AP_STATE)
-#define MLME_IS_ADHOC(adapter) (MLME_STATE((adapter)) & WIFI_ADHOC_STATE)
-#define MLME_IS_ADHOC_MASTER(adapter) (MLME_STATE((adapter)) & WIFI_ADHOC_MASTER_STATE)
-#define MLME_IS_MESH(adapter) (MLME_STATE((adapter)) & WIFI_MESH_STATE)
-#define MLME_IS_MONITOR(adapter) (MLME_STATE((adapter)) & WIFI_MONITOR_STATE)
-#define MLME_IS_MP(adapter) (MLME_STATE((adapter)) & WIFI_MP_STATE)
+#define CHK_MLME_STATE(adapter, state) check_fwstate(&((adapter)->mlmepriv), (state))
+
+#define MLME_IS_NULL(adapter) CHK_MLME_STATE(adapter, WIFI_NULL_STATE)
+#define MLME_IS_STA(adapter) CHK_MLME_STATE(adapter, WIFI_STATION_STATE)
+#define MLME_IS_AP(adapter) CHK_MLME_STATE(adapter, WIFI_AP_STATE)
+#define MLME_IS_ADHOC(adapter) CHK_MLME_STATE(adapter, WIFI_ADHOC_STATE)
+#define MLME_IS_ADHOC_MASTER(adapter) CHK_MLME_STATE(adapter, WIFI_ADHOC_MASTER_STATE)
+#define MLME_IS_MESH(adapter) CHK_MLME_STATE(adapter, WIFI_MESH_STATE)
+#define MLME_IS_MONITOR(adapter) CHK_MLME_STATE(adapter, WIFI_MONITOR_STATE)
+#define MLME_IS_MP(adapter) CHK_MLME_STATE(adapter, WIFI_MP_STATE)
 #ifdef CONFIG_P2P
 	#define MLME_IS_PD(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_DEVICE)
 	#define MLME_IS_GC(adapter) rtw_p2p_chk_role(&(adapter)->wdinfo, P2P_ROLE_CLIENT)
@@ -97,15 +99,21 @@ void rtw_wfd_st_switch(struct sta_info *sta, bool on);
 	#define MLME_IS_GO(adapter) 0
 #endif /* !CONFIG_P2P */
 
+#define MLME_IS_MSRC(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SOURCE)
+#define MLME_IS_MSINK(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SINK)
+
+#define MLME_IS_SCAN(adapter) CHK_MLME_STATE(adapter, WIFI_SITE_MONITOR)
+#define MLME_IS_LINKING(adapter) CHK_MLME_STATE(adapter, WIFI_UNDER_LINKING)
+#define MLME_IS_ASOC(adapter) CHK_MLME_STATE(adapter, WIFI_ASOC_STATE)
+#define MLME_IS_OPCH_SW(adapter) CHK_MLME_STATE(adapter, WIFI_OP_CH_SWITCHING)
+#define MLME_IS_WPS(adapter) CHK_MLME_STATE(adapter, WIFI_UNDER_WPS)
+
 #if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_P2P)
 #define MLME_IS_ROCH(adapter) (rtw_cfg80211_get_is_roch(adapter) == _TRUE)
 #else
 #define MLME_IS_ROCH(adapter) 0
 #endif
 
-#define MLME_IS_MSRC(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SOURCE)
-#define MLME_IS_MSINK(adapter) rtw_chk_miracast_mode((adapter), MIRACAST_SINK)
-
 #ifdef CONFIG_IOCTL_CFG80211
 #define MLME_IS_MGMT_TX(adapter) rtw_cfg80211_get_is_mgmt_tx(adapter)
 #else
@@ -124,11 +132,11 @@ void rtw_wfd_st_switch(struct sta_info *sta, bool on);
 	MLME_IS_PD((adapter)) ? " PD" : "", \
 	MLME_IS_MSRC((adapter)) ? " MSRC" : "", \
 	MLME_IS_MSINK((adapter)) ? " MSINK" : "", \
-	(MLME_STATE((adapter)) & WIFI_SITE_MONITOR) ? " SCAN" : "", \
-	(MLME_STATE((adapter)) & WIFI_UNDER_LINKING) ? " LINKING" : "", \
-	(MLME_STATE((adapter)) & WIFI_ASOC_STATE) ? " ASOC" : "", \
-	(MLME_STATE((adapter)) & WIFI_OP_CH_SWITCHING) ? " OP_CH_SW" : "", \
-	(MLME_STATE((adapter)) & WIFI_UNDER_WPS) ? " WPS" : "", \
+	MLME_IS_SCAN((adapter)) ? " SCAN" : "", \
+	MLME_IS_LINKING((adapter)) ? " LINKING" : "", \
+	MLME_IS_ASOC((adapter)) ? " ASOC" : "", \
+	MLME_IS_OPCH_SW((adapter)) ? " OPCH_SW" : "", \
+	MLME_IS_WPS((adapter)) ? " WPS" : "", \
 	MLME_IS_ROCH((adapter)) ? " ROCH" : "", \
 	MLME_IS_MGMT_TX((adapter)) ? " MGMT_TX" : "", \
 	(MLME_STATE((adapter)) & WIFI_SLEEP_STATE) ? " SLEEP" : ""
@@ -151,6 +159,7 @@ enum {
 	MLME_ADHOC_STOPPED,
 	MLME_MESH_STARTED,
 	MLME_MESH_STOPPED,
+	MLME_OPCH_SWITCH,
 };
 
 #define _FW_UNDER_LINKING	WIFI_UNDER_LINKING
@@ -530,9 +539,10 @@ struct beacon_keys {
 	int is_8021x;
 };
 #ifdef CONFIG_RTW_80211R
-#define FT_ACTION_REQ_LIMIT	4
+#define RTW_FT_ACTION_REQ_LMT	4
+#define RTW_FT_MAX_IE_SZ	256
 
-typedef enum _RTW_WIFI_FT_STA_STATUS {
+enum _rtw_ft_sta_status {
 	RTW_FT_UNASSOCIATED_STA = 0,
 	RTW_FT_AUTHENTICATING_STA,
 	RTW_FT_AUTHENTICATED_STA,
@@ -542,51 +552,198 @@ typedef enum _RTW_WIFI_FT_STA_STATUS {
 	RTW_FT_REQUESTED_STA,
 	RTW_FT_CONFIRMED_STA,
 	RTW_FT_UNSPECIFIED_STA
-} RTW_WIFI_FT_STA_STATUS;
+};
+
+#define rtw_ft_chk_status(a, s) \
+	((a)->mlmepriv.ft_roam.ft_status == (s))
+
+#define rtw_ft_roam_status(a, s)	\
+	((rtw_to_roam(a) > 0) && rtw_ft_chk_status(a, s))
+
+#define rtw_ft_authed_sta(a)	\
+	((rtw_ft_chk_status(a, RTW_FT_AUTHENTICATED_STA)) ||	\
+	(rtw_ft_chk_status(a, RTW_FT_ASSOCIATING_STA)) ||	\
+	(rtw_ft_chk_status(a, RTW_FT_ASSOCIATED_STA)))
 
-#define rtw_chk_ft_status(adapter, status) ((adapter)->mlmepriv.ftpriv.ft_status == status)
-#define rtw_set_ft_status(adapter, status) \
+#define rtw_ft_set_status(a, s) \
 	do { \
-		((adapter)->mlmepriv.ftpriv.ft_status = status); \
+		((a)->mlmepriv.ft_roam.ft_status = (s)); \
 	} while (0)
 
-#define rtw_reset_ft_status(adapter) \
+#define rtw_ft_lock_set_status(a, s, irq) \
 	do { \
-		((adapter)->mlmepriv.ftpriv.ft_status = RTW_FT_UNASSOCIATED_STA); \
+		_enter_critical_bh(&(a)->mlmepriv.lock, ((_irqL *)(irq)));	\
+		((a)->mlmepriv.ft_roam.ft_status = (s));	\
+		_exit_critical_bh(&(a)->mlmepriv.lock, ((_irqL *)(irq)));	\
 	} while (0)
 
-typedef enum _RTW_WIFI_FT_CAPABILITY {
-	RTW_FT_STA_SUPPORTED = BIT0,
-	RTW_FT_STA_OVER_DS_SUPPORTED = BIT1,
-	RTW_FT_SUPPORTED = BIT2,
-	RTW_FT_OVER_DS_SUPPORTED = BIT3,
-} RTW_WIFI_FT_CAPABILITY;
+#define rtw_ft_reset_status(a) \
+	do { \
+		((a)->mlmepriv.ft_roam.ft_status = RTW_FT_UNASSOCIATED_STA); \
+	} while (0)
+
+enum rtw_ft_capability {
+	RTW_FT_EN = BIT0,
+	RTW_FT_OTD_EN = BIT1,
+	RTW_FT_PEER_EN = BIT2,
+	RTW_FT_PEER_OTD_EN = BIT3,
+	RTW_FT_BTM_ROAM = BIT4,
+};
+
+#define rtw_ft_chk_flags(a, f) \
+	((a)->mlmepriv.ft_roam.ft_flags & (f))
 
-#define rtw_chk_ft_flags(adapter, flags) ((adapter)->mlmepriv.ftpriv.ft_flags & (flags))
-#define rtw_set_ft_flags(adapter, flags) \
+#define rtw_ft_set_flags(a, f) \
 	do { \
-		((adapter)->mlmepriv.ftpriv.ft_flags |= (flags)); \
+		((a)->mlmepriv.ft_roam.ft_flags |= (f)); \
 	} while (0)
 
-#define rtw_clr_ft_flags(adapter, flags) \
+#define rtw_ft_clr_flags(a, f) \
 	do { \
-		((adapter)->mlmepriv.ftpriv.ft_flags &= ~(flags)); \
+		((a)->mlmepriv.ft_roam.ft_flags &= ~(f)); \
 	} while (0)
 
-#define RTW_MAX_FTIE_SZ	256
-typedef struct _ft_priv {
+#define rtw_ft_roam(a)	\
+	((rtw_to_roam(a) > 0) && rtw_ft_chk_flags(a, RTW_FT_PEER_EN))
+	
+#define rtw_ft_valid_akm(a, t)	\
+	((rtw_ft_chk_flags(a, RTW_FT_EN)) && \
+	(((t) == 3) || ((t) == 4)))
+
+#define rtw_ft_roam_expired(a, r)	\
+	((rtw_chk_roam_flags(a, RTW_ROAM_ON_EXPIRED)) \
+	&& (r == WLAN_REASON_ACTIVE_ROAM))
+
+#define rtw_ft_otd_roam_en(a)	\
+	((rtw_ft_chk_flags(a, RTW_FT_OTD_EN))	\
+	&& ((a)->mlmepriv.ft_roam.ft_roam_on_expired == _FALSE)	\
+	&& ((a)->mlmepriv.ft_roam.ft_cap & 0x01))
+	
+#define rtw_ft_otd_roam(a) \
+	rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN)
+
+#define rtw_ft_valid_otd_candidate(a, p)	\
+	((rtw_ft_chk_flags(a, RTW_FT_OTD_EN)) 	\
+	&& ((rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN)	\
+	&& ((*((p)+4) & 0x01) == 0))	\
+	|| ((rtw_ft_chk_flags(a, RTW_FT_PEER_OTD_EN) == 0)	\
+	&& (*((p)+4) & 0x01))))
+
+struct ft_roam_info {
 	u16	mdid;
-	u8	ft_cap;	/*b0: FT over DS, b1: Resource Req Protocol Cap, b2~b7: Reserved*/
-	u8	updated_ft_ies[RTW_MAX_FTIE_SZ];
+	u8	ft_cap;	
+	/*b0: FT over DS, b1: Resource Req Protocol Cap, b2~b7: Reserved*/
+	u8	updated_ft_ies[RTW_FT_MAX_IE_SZ];
 	u16	updated_ft_ies_len;
-	u8	ft_action[RTW_MAX_FTIE_SZ];
+	u8	ft_action[RTW_FT_MAX_IE_SZ];
 	u16	ft_action_len;
 	struct cfg80211_ft_event_params ft_event;
 	u8	ft_roam_on_expired;
 	u8	ft_flags;
 	u32 ft_status;
 	u32 ft_req_retry_cnt;
-} ft_priv;
+	bool ft_updated_bcn;	
+};
+#endif
+
+#ifdef CONFIG_LAYER2_ROAMING
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+#define RTW_RRM_NB_RPT_EN		BIT(1)
+#define RTW_MAX_NB_RPT_NUM	8
+
+#define rtw_roam_busy_scan(a, nb)	\
+	(((a)->mlmepriv.LinkDetectInfo.bBusyTraffic == _TRUE) && \
+	(((a)->mlmepriv.ch_cnt) < ((nb)->nb_rpt_ch_list_num)))
+
+#define rtw_wnm_btm_preference_cap(a) \
+	((a)->mlmepriv.nb_info.preference_en == _TRUE)
+
+#define rtw_wnm_btm_diff_bss(a) \
+	((rtw_wnm_btm_preference_cap(a)) && \
+	(is_zero_mac_addr((a)->mlmepriv.nb_info.roam_target_addr) == _FALSE) && \
+	(_rtw_memcmp((a)->mlmepriv.nb_info.roam_target_addr,\
+		(a)->mlmepriv.cur_network.network.MacAddress, ETH_ALEN) == _FALSE))
+
+#define rtw_wnm_btm_roam_candidate(a, c) \
+	((rtw_wnm_btm_preference_cap(a)) && \
+	(is_zero_mac_addr((a)->mlmepriv.nb_info.roam_target_addr) == _FALSE) && \
+	(_rtw_memcmp((a)->mlmepriv.nb_info.roam_target_addr,\
+		(c)->network.MacAddress, ETH_ALEN)))
+
+#define rtw_wnm_set_ext_cap_btm(_pEleStart, _val) \
+	SET_BITS_TO_LE_1BYTE(((u8 *)(_pEleStart))+2, 3, 1, _val)
+
+#define wnm_btm_bss_term_inc(p) (*((u8 *)((p)+3)) & BSS_TERMINATION_INCLUDED)
+
+#define wnm_btm_ess_disassoc_im(p) (*((u8 *)((p)+3)) & ESS_DISASSOC_IMMINENT)
+
+#define wnm_btm_req_mode(p) (*((u8 *)((p)+3)))
+
+#define wnm_btm_disassoc_timer(p) (*((u16 *)((p)+4)))
+
+#define wnm_btm_valid_interval(p) (*((u8 *)((p)+6)))
+
+#define wnm_btm_term_duration_offset(p) ((p)+7)
+
+/*IEEE Std 80211k Figure 7-95b Neighbor Report element format*/
+struct nb_rpt_hdr {
+	u8 id; /*0x34: Neighbor Report Element ID*/
+	u8 len;
+	u8 bssid[ETH_ALEN];
+	u32 bss_info;
+	u8 reg_class;
+	u8 ch_num;
+	u8 phy_type;	
+};
+
+/*IEEE Std 80211v, Figure 7-95e2—BSS Termination Duration subelement field format */
+struct btm_term_duration {
+	u8 id;
+	u8 len;
+	u64 tsf;
+	u16 duration;
+};
+
+/*IEEE Std 80211v, Figure 7-101n8—BSS Transition Management Request frame body format */
+struct btm_req_hdr {
+	u8 req_mode;
+	u16 disassoc_timer;
+	u8 validity_interval;
+	struct btm_term_duration term_duration;
+};
+
+/*IEEE Std 80211v,  Table 7-43b Optional Subelement IDs for Neighbor Report*/
+/* BSS Transition Candidate Preference */
+#define WNM_BTM_CAND_PREF_SUBEID 0x03
+
+/* BSS Termination Duration */
+#define WNM_BTM_TERM_DUR_SUBEID		0x04
+
+struct wnm_btm_cant {
+	struct nb_rpt_hdr nb_rpt;
+	u8 preference;	/* BSS Transition Candidate Preference */
+};
+
+enum rtw_btm_req_mod {
+	PREFERRED_CANDIDATE_LIST_INCLUDED = BIT0,
+	ABRIDGED = BIT1,
+	DISASSOC_IMMINENT = BIT2,
+	BSS_TERMINATION_INCLUDED = BIT3,
+	ESS_DISASSOC_IMMINENT = BIT4,
+};
+
+struct roam_nb_info {
+	struct nb_rpt_hdr nb_rpt[RTW_MAX_NB_RPT_NUM];
+	struct rtw_ieee80211_channel nb_rpt_ch_list[RTW_MAX_NB_RPT_NUM];
+	bool	nb_rpt_valid;
+	u8	nb_rpt_ch_list_num;
+	u8 preference_en;
+	u8 roam_target_addr[ETH_ALEN];
+	u32	last_nb_rpt_entries;
+	bool	nb_rpt_is_same;
+	_timer roam_scan_timer;
+};
+#endif	/* defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K) */
 #endif
 
 struct mlme_priv {
@@ -594,20 +751,22 @@ struct mlme_priv {
 	_lock	lock;
 	sint	fw_state;	/* shall we protect this variable? maybe not necessarily... */
 	u8	to_join; /* flag */
+	u16 join_status;
 #ifdef CONFIG_LAYER2_ROAMING
 	u8 to_roam; /* roaming trying times */
 	struct wlan_network *roam_network; /* the target of active roam */
 	u8 roam_flags;
 	u8 roam_rssi_diff_th; /* rssi difference threshold for active scan candidate selection */
-	u32 roam_scan_int_ms; /* scan interval for active roam */
+	u32 roam_scan_int; 		/* scan interval for active roam (Unit:2 second)*/
 	u32 roam_scanr_exp_ms; /* scan result expire time in ms  for roam */
 	u8 roam_tgt_addr[ETH_ALEN]; /* request to roam to speicific target without other consideration */
 	u8 roam_rssi_threshold;
+	systime last_roaming;
 	bool need_to_roam;
 #endif
 
 	u8	*nic_hdl;
-
+	u32	max_bss_cnt;		/*	The size of scan queue	*/
 	_list		*pscanned;
 	_queue	free_bss_pool;
 	_queue	scanned_queue;
@@ -622,14 +781,16 @@ struct mlme_priv {
 
 	/* bcn check info */
 	struct beacon_keys cur_beacon_keys; /* save current beacon keys */
+#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
 	struct beacon_keys new_beacon_keys; /* save new beacon keys */
 	u8 new_beacon_cnts; /* if new_beacon_cnts >= threshold, ap beacon is changed */
+#endif
 
 #ifdef CONFIG_ARP_KEEP_ALIVE
 	/* for arp offload keep alive */
 	u8 bGetGateway;
 	u8	GetGatewayTryCnt;
-	u8	gw_mac_addr[6];
+	u8	gw_mac_addr[ETH_ALEN];
 	u8	gw_ip[4];
 #endif
 
@@ -649,6 +810,7 @@ struct mlme_priv {
 	_timer set_scan_deny_timer;
 	ATOMIC_T set_scan_deny; /* 0: allowed, 1: deny */
 #endif
+	u8 wpa_phase;/*wpa_phase after wps finished*/
 
 	struct qos_priv qospriv;
 
@@ -669,7 +831,16 @@ struct mlme_priv {
 
 #ifdef CONFIG_80211AC_VHT
 	struct vht_priv	vhtpriv;
+#ifdef ROKU_PRIVATE
+	/*infra mode, used to store AP's info*/
+	struct vht_priv_infra_ap vhtpriv_infra_ap;
+#endif /* ROKU_PRIVATE */
 #endif
+
+#ifdef ROKU_PRIVATE
+	struct ht_priv_infra_ap htpriv_infra_ap;
+#endif /* ROKU_PRIVATE */
+
 #ifdef CONFIG_BEAMFORMING
 #ifndef RTW_BEAMFORMING_VERSION_2
 #if (BEAMFORMING_SUPPORT == 0)/*for driver beamforming*/
@@ -678,15 +849,12 @@ struct mlme_priv {
 #endif /* !RTW_BEAMFORMING_VERSION_2 */
 #endif
 
-#ifdef CONFIG_DFS
-	u8	handle_dfs;
-#endif
-#ifdef CONFIG_DFS_MASTER
-	/* TODO: move to rfctl */
-	_timer dfs_master_timer;
-#endif
 #ifdef CONFIG_RTW_80211R
-	ft_priv ftpriv;
+	struct ft_roam_info ft_roam;
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+	struct roam_nb_info nb_info;
+	u8 ch_cnt;
 #endif
 
 	RT_LINK_DETECT_T	LinkDetectInfo;
@@ -781,6 +949,9 @@ struct mlme_priv {
 	u8 ori_ch;
 	u8 ori_bw;
 	u8 ori_offset;
+	#ifdef CONFIG_80211AC_VHT
+	u8 ori_vht_en;
+	#endif
 #endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
 
 #if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
@@ -840,11 +1011,6 @@ struct mlme_priv {
 	u8	scanning_via_buddy_intf;
 #endif
 
-#if 0
-	u8	NumOfBcnInfoChkFail;
-	u32	timeBcnInfoChkStart;
-#endif
-
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
 	u32 vendor_ie_mask[WLAN_MAX_VENDOR_IE_NUM];
 	u8 vendor_ie[WLAN_MAX_VENDOR_IE_NUM][WLAN_MAX_VENDOR_IE_LEN];
@@ -863,10 +1029,11 @@ struct mlme_priv {
 		adapter->mlmepriv.auto_scan_int_ms = ms; \
 	} while (0)
 
-#define RTW_AUTO_SCAN_REASON_UNSPECIFIED	0
-#define RTW_AUTO_SCAN_REASON_2040_BSS		BIT0
-#define RTW_AUTO_SCAN_REASON_ACS			BIT1
-#define RTW_AUTO_SCAN_REASON_ROAM			BIT2
+#define RTW_AUTO_SCAN_REASON_UNSPECIFIED		0
+#define RTW_AUTO_SCAN_REASON_2040_BSS			BIT0
+#define RTW_AUTO_SCAN_REASON_ACS				BIT1
+#define RTW_AUTO_SCAN_REASON_ROAM				BIT2
+#define RTW_AUTO_SCAN_REASON_MESH_OFFCH_CAND	BIT3
 
 void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason);
 
@@ -887,7 +1054,7 @@ extern void hostapd_mode_unload(_adapter *padapter);
 #endif
 
 
-extern void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf);
+extern void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf, u16 status);
 extern void rtw_survey_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_surveydone_event_callback(_adapter *adapter, u8 *pbuf);
 extern void rtw_joinbss_event_callback(_adapter *adapter, u8 *pbuf);
@@ -902,9 +1069,15 @@ extern void rtw_wmm_event_callback(PADAPTER padapter, u8 *pbuf);
 void rtw_sta_timeout_event_callback(_adapter *adapter, u8 *pbuf);
 #endif /* CONFIG_IEEE80211W */
 #ifdef CONFIG_RTW_80211R
-void rtw_update_ft_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork);
+void rtw_ft_info_init(struct ft_roam_info *pft);
+u8 rtw_ft_chk_roaming_candidate(_adapter *padapter, 
+	struct wlan_network *competitor);
+void rtw_ft_update_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork);
 void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf);
 #endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+void rtw_roam_nb_info_init(_adapter *padapter);
+#endif
 
 thread_return event_thread(thread_context context);
 
@@ -1010,15 +1183,16 @@ __inline static void set_scanned_network_val(struct mlme_priv *pmlmepriv, sint v
 }
 
 extern u16 rtw_get_capability(WLAN_BSSID_EX *bss);
-extern void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target);
+extern bool rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target);
 extern void rtw_disconnect_hdl_under_linked(_adapter *adapter, struct sta_info *psta, u8 free_assoc);
 extern void rtw_generate_random_ibss(u8 *pibss);
-extern struct wlan_network *rtw_find_network(_queue *scanned_queue, u8 *addr);
+struct wlan_network *_rtw_find_network(_queue *scanned_queue, const u8 *addr);
+struct wlan_network *rtw_find_network(_queue *scanned_queue, const u8 *addr);
 extern struct wlan_network *rtw_get_oldest_wlan_network(_queue *scanned_queue);
 struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network);
 struct wlan_network *rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network);
 
-extern void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue);
+extern void rtw_free_assoc_resources(_adapter *adapter, u8 lock_scanned_queue);
 extern void rtw_indicate_disconnect(_adapter *adapter, u16 reason, u8 locally_generated);
 extern void rtw_indicate_connect(_adapter *adapter);
 void rtw_indicate_scan_done(_adapter *padapter, bool aborted);
@@ -1028,8 +1202,9 @@ void rtw_scan_wait_completed(_adapter *adapter);
 u32 rtw_scan_abort_timeout(_adapter *adapter, u32 timeout_ms);
 void rtw_scan_abort_no_wait(_adapter *adapter);
 void rtw_scan_abort(_adapter *adapter);
+u32 rtw_join_abort_timeout(_adapter *adapter, u32 timeout_ms);
 
-extern int rtw_restruct_sec_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len);
+extern int rtw_restruct_sec_ie(_adapter *adapter, u8 *out_ie);
 #ifdef CONFIG_WMMPS_STA
 void rtw_uapsd_use_default_setting(_adapter *padapter);
 bool rtw_is_wmmps_mode(_adapter *padapter);
@@ -1047,6 +1222,29 @@ extern void rtw_scan_timeout_handler(void *ctx);
 extern void rtw_dynamic_check_timer_handlder(void *ctx);
 extern void rtw_iface_dynamic_check_timer_handlder(_adapter *adapter);
 
+enum {
+	SS_DENY_MP_MODE,
+	SS_DENY_RSON_SCANING,
+	SS_DENY_BLOCK_SCAN,
+	SS_DENY_BY_DRV,
+	SS_DENY_SELF_AP_UNDER_WPS,
+	SS_DENY_SELF_AP_UNDER_LINKING,
+	SS_DENY_SELF_AP_UNDER_SURVEY,
+	/*SS_DENY_SELF_STA_UNDER_WPS,*/
+	SS_DENY_SELF_STA_UNDER_LINKING,
+	SS_DENY_SELF_STA_UNDER_SURVEY,
+	SS_DENY_BUDDY_UNDER_LINK_WPS,
+	SS_DENY_BUDDY_UNDER_SURVEY,
+	SS_DENY_BUSY_TRAFFIC,
+	SS_ALLOW,
+#ifdef DBG_LA_MODE
+	SS_DENY_LA_MODE,
+#endif
+};
+
+u8 _rtw_sitesurvey_condition_check(const char *caller, _adapter *adapter, bool check_sc_interval);
+#define rtw_sitesurvey_condition_check(adapter, check_sc_interval) _rtw_sitesurvey_condition_check(__func__, adapter, check_sc_interval)
+
 #ifdef CONFIG_SET_SCAN_DENY_TIMER
 bool rtw_is_scan_deny(_adapter *adapter);
 void rtw_clear_scan_deny(_adapter *adapter);
@@ -1080,9 +1278,6 @@ extern struct wlan_network *_rtw_alloc_network(struct mlme_priv *pmlmepriv);
 extern void _rtw_free_network(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork, u8 isfreeall);
 extern void _rtw_free_network_nolock(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork);
 
-
-extern struct wlan_network *_rtw_find_network(_queue *scanned_queue, u8 *addr);
-
 extern void _rtw_free_network_queue(_adapter *padapter, u8 isfreeall);
 
 extern sint rtw_if_up(_adapter *padapter);
@@ -1164,6 +1359,40 @@ void rtw_proxim_disable(_adapter *padapter);
 void rtw_proxim_send_packet(_adapter *padapter, u8 *pbuf, u16 len, u8 m_rate);
 #endif /* CONFIG_INTEL_PROXIM */
 
+#define GET_ARP_HTYPE(_arp)	BE_BITS_TO_2BYTE(((u8 *)(_arp)) + 0, 0, 16)
+#define GET_ARP_PTYPE(_arp)	BE_BITS_TO_2BYTE(((u8 *)(_arp)) + 2, 0, 16)
+#define GET_ARP_HLEN(_arp)	BE_BITS_TO_1BYTE(((u8 *)(_arp)) + 4, 0, 8)
+#define GET_ARP_PLEN(_arp)	BE_BITS_TO_1BYTE(((u8 *)(_arp)) + 5, 0, 8)
+#define GET_ARP_OPER(_arp)	BE_BITS_TO_2BYTE(((u8 *)(_arp)) + 6, 0, 16)
+
+#define SET_ARP_HTYPE(_arp, _val)	SET_BITS_TO_BE_2BYTE(((u8 *)(_arp)) + 0, 0, 16, _val)
+#define SET_ARP_PTYPE(_arp, _val)	SET_BITS_TO_BE_2BYTE(((u8 *)(_arp)) + 2, 0, 16, _val)
+#define SET_ARP_HLEN(_arp, _val)	SET_BITS_TO_BE_1BYTE(((u8 *)(_arp)) + 4, 0, 8, _val)
+#define SET_ARP_PLEN(_arp, _val)	SET_BITS_TO_BE_1BYTE(((u8 *)(_arp)) + 5, 0, 8, _val)
+#define SET_ARP_OPER(_arp, _val)	SET_BITS_TO_BE_2BYTE(((u8 *)(_arp)) + 6, 0, 16, _val)
+
+#define ARP_SHA(_arp, _hlen, _plen)	(((u8 *)(_arp)) + 8)
+#define ARP_SPA(_arp, _hlen, _plen)	(((u8 *)(_arp)) + 8 + (_hlen))
+#define ARP_THA(_arp, _hlen, _plen)	(((u8 *)(_arp)) + 8 + (_hlen) + (_plen))
+#define ARP_TPA(_arp, _hlen, _plen)	(((u8 *)(_arp)) + 8 + 2 * (_hlen) + (_plen))
+
+#define ARP_SENDER_MAC_ADDR(_arp)	ARP_SHA(_arp, ETH_ALEN, RTW_IP_ADDR_LEN)
+#define ARP_SENDER_IP_ADDR(_arp)	ARP_SPA(_arp, ETH_ALEN, RTW_IP_ADDR_LEN)
+#define ARP_TARGET_MAC_ADDR(_arp)	ARP_THA(_arp, ETH_ALEN, RTW_IP_ADDR_LEN)
+#define ARP_TARGET_IP_ADDR(_arp)	ARP_TPA(_arp, ETH_ALEN, RTW_IP_ADDR_LEN)
+
+#define GET_ARP_SENDER_MAC_ADDR(_arp, _val)	_rtw_memcpy(_val, ARP_SENDER_MAC_ADDR(_arp), ETH_ALEN)
+#define GET_ARP_SENDER_IP_ADDR(_arp, _val)	_rtw_memcpy(_val, ARP_SENDER_IP_ADDR(_arp), RTW_IP_ADDR_LEN)
+#define GET_ARP_TARGET_MAC_ADDR(_arp, _val)	_rtw_memcpy(_val, ARP_TARGET_MAC_ADDR(_arp), ETH_ALEN)
+#define GET_ARP_TARGET_IP_ADDR(_arp, _val)	_rtw_memcpy(_val, ARP_TARGET_IP_ADDR(_arp), RTW_IP_ADDR_LEN)
+
+#define SET_ARP_SENDER_MAC_ADDR(_arp, _val)	_rtw_memcpy(ARP_SENDER_MAC_ADDR(_arp), _val, ETH_ALEN)
+#define SET_ARP_SENDER_IP_ADDR(_arp, _val)	_rtw_memcpy(ARP_SENDER_IP_ADDR(_arp), _val, RTW_IP_ADDR_LEN)
+#define SET_ARP_TARGET_MAC_ADDR(_arp, _val)	_rtw_memcpy(ARP_TARGET_MAC_ADDR(_arp), _val, ETH_ALEN)
+#define SET_ARP_TARGET_IP_ADDR(_arp, _val)	_rtw_memcpy(ARP_TARGET_IP_ADDR(_arp), _val, RTW_IP_ADDR_LEN)
+
+void dump_arp_pkt(void *sel, u8 *da, u8 *sa, u8 *arp, bool tx);
+
 #define IPV4_SRC(_iphdr)			(((u8 *)(_iphdr)) + 12)
 #define IPV4_DST(_iphdr)			(((u8 *)(_iphdr)) + 16)
 #define GET_IPV4_IHL(_iphdr)		BE_BITS_TO_1BYTE(((u8 *)(_iphdr)) + 0, 0, 4)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme_ext.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme_ext.h
index 50d05de07f73..bbf7861790fb 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme_ext.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mlme_ext.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -21,7 +22,7 @@
  *	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 SURVEY_TO		(500)
 
 #define REAUTH_TO		(300) /* (50) */
 #define REASSOC_TO		(300) /* (50) */
@@ -88,216 +89,11 @@ extern unsigned char P2P_OUI[];
 extern unsigned char WMM_INFO_OUI[];
 extern unsigned char WMM_PARA_OUI[];
 
-typedef enum _RT_CHANNEL_DOMAIN {
-	/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
-	RTW_CHPLAN_FCC = 0x00,
-	RTW_CHPLAN_IC = 0x01,
-	RTW_CHPLAN_ETSI = 0x02,
-	RTW_CHPLAN_SPAIN = 0x03,
-	RTW_CHPLAN_FRANCE = 0x04,
-	RTW_CHPLAN_MKK = 0x05,
-	RTW_CHPLAN_MKK1 = 0x06,
-	RTW_CHPLAN_ISRAEL = 0x07,
-	RTW_CHPLAN_TELEC = 0x08,
-	RTW_CHPLAN_GLOBAL_DOAMIN = 0x09,
-	RTW_CHPLAN_WORLD_WIDE_13 = 0x0A,
-	RTW_CHPLAN_TAIWAN = 0x0B,
-	RTW_CHPLAN_CHINA = 0x0C,
-	RTW_CHPLAN_SINGAPORE_INDIA_MEXICO = 0x0D,
-	RTW_CHPLAN_KOREA = 0x0E,
-	RTW_CHPLAN_TURKEY = 0x0F,
-	RTW_CHPLAN_JAPAN = 0x10,
-	RTW_CHPLAN_FCC_NO_DFS = 0x11,
-	RTW_CHPLAN_JAPAN_NO_DFS = 0x12,
-	RTW_CHPLAN_WORLD_WIDE_5G = 0x13,
-	RTW_CHPLAN_TAIWAN_NO_DFS = 0x14,
-
-	/* ===== 0x20 ~ 0x7F, new channel plan ===== */
-	RTW_CHPLAN_WORLD_NULL = 0x20,
-	RTW_CHPLAN_ETSI1_NULL = 0x21,
-	RTW_CHPLAN_FCC1_NULL = 0x22,
-	RTW_CHPLAN_MKK1_NULL = 0x23,
-	RTW_CHPLAN_ETSI2_NULL = 0x24,
-	RTW_CHPLAN_FCC1_FCC1 = 0x25,
-	RTW_CHPLAN_WORLD_ETSI1 = 0x26,
-	RTW_CHPLAN_MKK1_MKK1 = 0x27,
-	RTW_CHPLAN_WORLD_KCC1 = 0x28,
-	RTW_CHPLAN_WORLD_FCC2 = 0x29,
-	RTW_CHPLAN_FCC2_NULL = 0x2A,
-	RTW_CHPLAN_IC1_IC2 = 0x2B,
-	RTW_CHPLAN_WORLD_FCC3 = 0x30,
-	RTW_CHPLAN_WORLD_FCC4 = 0x31,
-	RTW_CHPLAN_WORLD_FCC5 = 0x32,
-	RTW_CHPLAN_WORLD_FCC6 = 0x33,
-	RTW_CHPLAN_FCC1_FCC7 = 0x34,
-	RTW_CHPLAN_WORLD_ETSI2 = 0x35,
-	RTW_CHPLAN_WORLD_ETSI3 = 0x36,
-	RTW_CHPLAN_MKK1_MKK2 = 0x37,
-	RTW_CHPLAN_MKK1_MKK3 = 0x38,
-	RTW_CHPLAN_FCC1_NCC1 = 0x39,
-	RTW_CHPLAN_FCC1_NCC2 = 0x40,
-	RTW_CHPLAN_GLOBAL_NULL = 0x41,
-	RTW_CHPLAN_ETSI1_ETSI4 = 0x42,
-	RTW_CHPLAN_FCC1_FCC2 = 0x43,
-	RTW_CHPLAN_FCC1_NCC3 = 0x44,
-	RTW_CHPLAN_WORLD_ETSI5 = 0x45,
-	RTW_CHPLAN_FCC1_FCC8 = 0x46,
-	RTW_CHPLAN_WORLD_ETSI6 = 0x47,
-	RTW_CHPLAN_WORLD_ETSI7 = 0x48,
-	RTW_CHPLAN_WORLD_ETSI8 = 0x49,
-	RTW_CHPLAN_WORLD_ETSI9 = 0x50,
-	RTW_CHPLAN_WORLD_ETSI10 = 0x51,
-	RTW_CHPLAN_WORLD_ETSI11 = 0x52,
-	RTW_CHPLAN_FCC1_NCC4 = 0x53,
-	RTW_CHPLAN_WORLD_ETSI12 = 0x54,
-	RTW_CHPLAN_FCC1_FCC9 = 0x55,
-	RTW_CHPLAN_WORLD_ETSI13 = 0x56,
-	RTW_CHPLAN_FCC1_FCC10 = 0x57,
-	RTW_CHPLAN_MKK2_MKK4 = 0x58,
-	RTW_CHPLAN_WORLD_ETSI14 = 0x59,
-	RTW_CHPLAN_FCC1_FCC5 = 0x60,
-	RTW_CHPLAN_FCC2_FCC7 = 0x61,
-	RTW_CHPLAN_FCC2_FCC1 = 0x62,
-	RTW_CHPLAN_WORLD_ETSI15 = 0x63,
-	RTW_CHPLAN_MKK2_MKK5 = 0x64,
-	RTW_CHPLAN_ETSI1_ETSI16 = 0x65,
-	RTW_CHPLAN_FCC1_FCC14 = 0x66,
-	RTW_CHPLAN_FCC1_FCC12 = 0x67,
-	RTW_CHPLAN_FCC2_FCC14 = 0x68,
-	RTW_CHPLAN_FCC2_FCC12 = 0x69,
-	RTW_CHPLAN_ETSI1_ETSI17 = 0x6A,
-	RTW_CHPLAN_WORLD_FCC16 = 0x6B,
-	RTW_CHPLAN_WORLD_FCC13 = 0x6C,
-	RTW_CHPLAN_FCC2_FCC15 = 0x6D,
-	RTW_CHPLAN_WORLD_FCC12 = 0x6E,
-	RTW_CHPLAN_NULL_ETSI8 = 0x6F,
-	RTW_CHPLAN_NULL_ETSI18 = 0x70,
-	RTW_CHPLAN_NULL_ETSI17 = 0x71,
-	RTW_CHPLAN_NULL_ETSI19 = 0x72,
-	RTW_CHPLAN_WORLD_FCC7 = 0x73,
-	RTW_CHPLAN_FCC2_FCC17 = 0x74,
-	RTW_CHPLAN_WORLD_ETSI20 = 0x75,
-	RTW_CHPLAN_FCC2_FCC11 = 0x76,
-	RTW_CHPLAN_WORLD_ETSI21 = 0x77,
-	RTW_CHPLAN_FCC1_FCC18 = 0x78,
-	RTW_CHPLAN_MKK2_MKK1 = 0x79,
-
-	RTW_CHPLAN_MAX,
-	RTW_CHPLAN_REALTEK_DEFINE = 0x7F,
-	RTW_CHPLAN_UNSPECIFIED = 0xFF,
-} RT_CHANNEL_DOMAIN, *PRT_CHANNEL_DOMAIN;
-
-typedef enum _RT_CHANNEL_DOMAIN_2G {
-	RTW_RD_2G_NULL = 0,
-	RTW_RD_2G_WORLD = 1,	/* Worldwird 13 */
-	RTW_RD_2G_ETSI1 = 2,	/* Europe */
-	RTW_RD_2G_FCC1 = 3,		/* US */
-	RTW_RD_2G_MKK1 = 4,		/* Japan */
-	RTW_RD_2G_ETSI2 = 5,	/* France */
-	RTW_RD_2G_GLOBAL = 6,	/* Global domain */
-	RTW_RD_2G_MKK2 = 7,		/* Japan */
-	RTW_RD_2G_FCC2 = 8,		/* US */
-	RTW_RD_2G_IC1 = 9,		/* Canada */
-
-	RTW_RD_2G_MAX,
-} RT_CHANNEL_DOMAIN_2G, *PRT_CHANNEL_DOMAIN_2G;
-
-typedef enum _RT_CHANNEL_DOMAIN_5G {
-	RTW_RD_5G_NULL = 0,		/*	*/
-	RTW_RD_5G_ETSI1 = 1,	/* Europe */
-	RTW_RD_5G_ETSI2 = 2,	/* Australia, New Zealand */
-	RTW_RD_5G_ETSI3 = 3,	/* Russia */
-	RTW_RD_5G_FCC1 = 4,		/* US */
-	RTW_RD_5G_FCC2 = 5,		/* FCC w/o DFS Channels */
-	RTW_RD_5G_FCC3 = 6,		/* Bolivia, Chile, El Salvador, Venezuela */
-	RTW_RD_5G_FCC4 = 7,		/* Venezuela */
-	RTW_RD_5G_FCC5 = 8,		/* China */
-	RTW_RD_5G_FCC6 = 9,		/*	*/
-	RTW_RD_5G_FCC7 = 10,	/* US(w/o Weather radar) */
-	RTW_RD_5G_IC1 = 11,		/* Canada(w/o Weather radar) */
-	RTW_RD_5G_KCC1 = 12,	/* Korea */
-	RTW_RD_5G_MKK1 = 13,	/* Japan */
-	RTW_RD_5G_MKK2 = 14,	/* Japan (W52, W53) */
-	RTW_RD_5G_MKK3 = 15,	/* Japan (W56) */
-	RTW_RD_5G_NCC1 = 16,	/* Taiwan, (w/o Weather radar) */
-	RTW_RD_5G_NCC2 = 17,	/* Taiwan, Band2, Band4 */
-	RTW_RD_5G_NCC3 = 18,	/* Taiwan w/o DFS, Band4 only */
-	RTW_RD_5G_ETSI4 = 19,	/* Europe w/o DFS, Band1 only */
-	RTW_RD_5G_ETSI5 = 20,	/* Australia, New Zealand(w/o Weather radar) */
-	RTW_RD_5G_FCC8 = 21,	/* Latin America */
-	RTW_RD_5G_ETSI6 = 22,	/* Israel, Bahrain, Egypt, India, China, Malaysia */
-	RTW_RD_5G_ETSI7 = 23,	/* China */
-	RTW_RD_5G_ETSI8 = 24,	/* Jordan */
-	RTW_RD_5G_ETSI9 = 25,	/* Lebanon */
-	RTW_RD_5G_ETSI10 = 26,	/* Qatar */
-	RTW_RD_5G_ETSI11 = 27,	/* Russia */
-	RTW_RD_5G_NCC4 = 28,	/* Taiwan, (w/o Weather radar) */
-	RTW_RD_5G_ETSI12 = 29,	/* Indonesia */
-	RTW_RD_5G_FCC9 = 30,	/* (w/o Weather radar) */
-	RTW_RD_5G_ETSI13 = 31,	/* (w/o Weather radar) */
-	RTW_RD_5G_FCC10 = 32,	/* Argentina(w/o Weather radar) */
-	RTW_RD_5G_MKK4 = 33,	/* Japan (W52) */
-	RTW_RD_5G_ETSI14 = 34,	/* Russia */
-	RTW_RD_5G_FCC11 = 35,	/* US(include CH144) */
-	RTW_RD_5G_ETSI15 = 36,	/* Malaysia */
-	RTW_RD_5G_MKK5 = 37,	/* Japan */
-	RTW_RD_5G_ETSI16 = 38,	/* Europe */
-	RTW_RD_5G_ETSI17 = 39,	/* Europe */
-	RTW_RD_5G_FCC12 = 40,	/* FCC */
-	RTW_RD_5G_FCC13 = 41,	/* FCC */
-	RTW_RD_5G_FCC14 = 42,	/* FCC w/o Weather radar(w/o 5600~5650MHz) */
-	RTW_RD_5G_FCC15 = 43,	/* FCC w/o Band3 */
-	RTW_RD_5G_FCC16 = 44,	/* FCC w/o Band3 */
-	RTW_RD_5G_ETSI18 = 45,	/* ETSI w/o DFS Band2&3 */
-	RTW_RD_5G_ETSI19 = 46,	/* Europe */
-	RTW_RD_5G_FCC17 = 47,	/* FCC w/o Weather radar(w/o 5600~5650MHz) */
-	RTW_RD_5G_ETSI20 = 48,	/* Europe */
-	RTW_RD_5G_IC2 = 49,		/* Canada(w/o Weather radar), include ch144 */
-	RTW_RD_5G_ETSI21 = 50,	/* Australia, New Zealand(w/o Weather radar) */
-	RTW_RD_5G_FCC18 = 51,	/*  */
-	RTW_RD_5G_WORLD = 52,	/* Worldwide */
-
-	/* === Below are driver defined for legacy channel plan compatible, DON'T assign index ==== */
-	RTW_RD_5G_OLD_FCC1,
-	RTW_RD_5G_OLD_NCC1,
-	RTW_RD_5G_OLD_KCC1,
-
-	RTW_RD_5G_MAX,
-} RT_CHANNEL_DOMAIN_5G, *PRT_CHANNEL_DOMAIN_5G;
-
-bool rtw_chplan_is_empty(u8 id);
-#define rtw_is_channel_plan_valid(chplan) (((chplan) < RTW_CHPLAN_MAX || (chplan) == RTW_CHPLAN_REALTEK_DEFINE) && !rtw_chplan_is_empty(chplan))
-#define rtw_is_legacy_channel_plan(chplan) ((chplan) < 0x20)
-
 typedef struct _RT_CHANNEL_PLAN {
 	unsigned char	Channel[MAX_CHANNEL_NUM];
 	unsigned char	Len;
 } RT_CHANNEL_PLAN, *PRT_CHANNEL_PLAN;
 
-struct ch_list_t {
-	u8 *len_ch;
-};
-
-#define CH_LIST_ENT(_len, arg...) \
-	{.len_ch = (u8[_len + 1]) {_len, ##arg}, }
-
-#define CH_LIST_LEN(_ch_list) (_ch_list.len_ch[0])
-#define CH_LIST_CH(_ch_list, _i) (_ch_list.len_ch[_i + 1])
-
-typedef struct _RT_CHANNEL_PLAN_MAP {
-	u8 Index2G;
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-	u8 Index5G;
-#endif
-	u8 regd; /* value of REGULATION_TXPWR_LMT */
-} RT_CHANNEL_PLAN_MAP, *PRT_CHANNEL_PLAN_MAP;
-
-#ifdef CONFIG_IEEE80211_BAND_5GHZ
-#define CHPLAN_ENT(i2g, i5g, regd) {i2g, i5g, regd}
-#else
-#define CHPLAN_ENT(i2g, i5g, regd) {i2g, regd}
-#endif
-
 enum Associated_AP {
 	atherosAP	= 0,
 	broadcomAP	= 1,
@@ -332,6 +128,24 @@ typedef enum _HT_IOT_PEER {
 	HT_IOT_PEER_MAX				= 18
 } HT_IOT_PEER_E, *PHTIOT_PEER_E;
 
+
+typedef enum _RT_HT_INF0_CAP {
+	RT_HT_CAP_USE_TURBO_AGGR = 0x01,
+	RT_HT_CAP_USE_LONG_PREAMBLE = 0x02,
+	RT_HT_CAP_USE_AMPDU = 0x04,
+	RT_HT_CAP_USE_WOW = 0x8,
+	RT_HT_CAP_USE_SOFTAP = 0x10,
+	RT_HT_CAP_USE_92SE = 0x20,
+	RT_HT_CAP_USE_88C_92C = 0x40,
+	RT_HT_CAP_USE_AP_CLIENT_MODE = 0x80,	/* AP team request to reserve this bit, by Emily */
+} RT_HT_INF0_CAPBILITY, *PRT_HT_INF0_CAPBILITY;
+
+typedef enum _RT_HT_INF1_CAP {
+	RT_HT_CAP_USE_VIDEO_CLIENT = 0x01,
+	RT_HT_CAP_USE_JAGUAR_BCUT = 0x02,
+	RT_HT_CAP_USE_JAGUAR_CCUT = 0x04,
+} RT_HT_INF1_CAPBILITY, *PRT_HT_INF1_CAPBILITY;
+
 struct mlme_handler {
 	unsigned int   num;
 	char *str;
@@ -395,7 +209,12 @@ struct ss_res {
 	u8 igi_before_scan; /* used for restoring IGI value without enable DIG & FA_CNT */
 #ifdef CONFIG_SCAN_BACKOP
 	u8 backop_flags_sta; /* policy for station mode*/
+	#ifdef CONFIG_AP_MODE
 	u8 backop_flags_ap; /* policy for ap mode */
+	#endif
+	#ifdef CONFIG_RTW_MESH
+	u8 backop_flags_mesh; /* policy for mesh mode */
+	#endif
 	u8 backop_flags; /* per backop runtime decision */
 	u8 scan_cnt;
 	u8 scan_cnt_max;
@@ -450,7 +269,9 @@ enum TDLS_option {
 	TDLS_CH_SW_END,
 	TDLS_RS_RCR,
 	TDLS_TEARDOWN_STA,
+	TDLS_TEARDOWN_STA_NO_WAIT,
 	TDLS_TEARDOWN_STA_LOCALLY,
+	TDLS_TEARDOWN_STA_LOCALLY_POST,
 	maxTDLS,
 };
 
@@ -495,6 +316,7 @@ struct mlme_ext_info {
 	u32	link_count;
 	u32	auth_seq;
 	u32	auth_algo;	/* 802.11 auth, could be open, shared, auto */
+	u16 auth_status;
 	u32	authModeToggle;
 	u32	enc_algo;/* encrypt algorithm; */
 	u32	key_index;	/* this is only valid for legendary wep, 0~3 for key id. */
@@ -534,6 +356,11 @@ struct mlme_ext_info {
 	struct HT_caps_element	HT_caps;
 	struct HT_info_element		HT_info;
 	WLAN_BSSID_EX			network;/* join network or bss_network, if in ap mode, it is the same to cur_network.network */
+#ifdef ROKU_PRIVATE
+	/*infra mode, store supported rates from AssocRsp*/
+	NDIS_802_11_RATES_EX	SupportedRates_infra_ap;
+	u8 ht_vht_received;/*ht_vht_received used to show debug msg BIT(0):HT BIT(1):VHT */
+#endif /* ROKU_PRIVATE */
 };
 
 /* The channel information about this channel including joining, scanning, and power constraints. */
@@ -554,7 +381,6 @@ typedef struct _RT_CHANNEL_INFO {
 #endif
 } RT_CHANNEL_INFO, *PRT_CHANNEL_INFO;
 
-#define DFS_MASTER_TIMER_MS 100
 #define CAC_TIME_MS (60*1000)
 #define CAC_TIME_CE_MS (10*60*1000)
 #define NON_OCP_TIME_MS (30*60*1000)
@@ -567,19 +393,22 @@ void rtw_rfctl_deinit(_adapter *adapter);
 
 #ifdef CONFIG_DFS_MASTER
 struct rf_ctl_t;
-#define CH_IS_NON_OCP(rt_ch_info) (time_after((rt_ch_info)->non_ocp_end_time, rtw_get_current_time()))
-bool rtw_is_cac_reset_needed(_adapter *adapter, u8 ch, u8 bw, u8 offset);
+#define CH_IS_NON_OCP(rt_ch_info) (rtw_time_after((rt_ch_info)->non_ocp_end_time, rtw_get_current_time()))
+bool rtw_is_cac_reset_needed(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset);
 bool _rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset);
 bool rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl);
 bool rtw_rfctl_is_tx_blocked_by_ch_waiting(struct rf_ctl_t *rfctl);
-bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
+bool rtw_chset_is_chbw_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
+bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch);
 void rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
 void rtw_chset_update_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms);
-u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms);
-void rtw_reset_cac(_adapter *adapter, u8 ch, u8 bw, u8 offset);
+u32 rtw_get_ch_waiting_ms(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms);
+void rtw_reset_cac(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset);
+u32 rtw_force_stop_cac(struct rf_ctl_t *rfctl, u32 timeout_ms);
 #else
 #define CH_IS_NON_OCP(rt_ch_info) 0
-#define rtw_chset_is_ch_non_ocp(ch_set, ch, bw, offset) _FALSE
+#define rtw_chset_is_chbw_non_ocp(ch_set, ch, bw, offset) _FALSE
+#define rtw_chset_is_ch_non_ocp(ch_set, ch) _FALSE
 #define rtw_rfctl_is_tx_blocked_by_ch_waiting(rfctl) _FALSE
 #endif
 
@@ -593,17 +422,17 @@ enum {
 	RTW_CHF_NON_OCP = BIT6,
 };
 
-bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset, u8 d_flags);
+bool rtw_choose_shortest_waiting_ch(struct rf_ctl_t *rfctl, u8 sel_ch, u8 max_bw
+	, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset
+	, u8 d_flags, u8 cur_ch, u8 same_band_prefer, u8 mesh_only);
 
-void dump_country_chplan(void *sel, const struct country_chplan *ent);
-void dump_country_chplan_map(void *sel);
-void dump_chplan_id_list(void *sel);
-void dump_chplan_test(void *sel);
 void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set);
-void dump_cur_chset(void *sel, _adapter *adapter);
+void dump_cur_chset(void *sel, struct rf_ctl_t *rfctl);
 
 int rtw_chset_search_ch(RT_CHANNEL_INFO *ch_set, const u32 ch);
 u8 rtw_chset_is_chbw_valid(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset);
+void rtw_chset_sync_chbw(RT_CHANNEL_INFO *ch_set, u8 *req_ch, u8 *req_bw, u8 *req_offset
+	, u8 *g_ch, u8 *g_bw, u8 *g_offset);
 
 bool rtw_mlme_band_check(_adapter *adapter, const u32 ch);
 
@@ -658,9 +487,7 @@ struct mlme_ext_priv {
 	u16	mgnt_seq;
 #ifdef CONFIG_IEEE80211W
 	u16	sa_query_seq;
-	u64 mgnt_80211w_IPN;
-	u64 mgnt_80211w_IPN_rx;
-#endif /* CONFIG_IEEE80211W */
+#endif
 	/* struct fw_priv 	fwpriv; */
 
 	unsigned char	cur_channel;
@@ -690,20 +517,22 @@ struct mlme_ext_priv {
 
 	systime last_scan_time;
 	u8	scan_abort;
+	u8 join_abort;
 	u8	tx_rate; /* TXRATE when USERATE is set. */
 
 	u32	retry; /* retry for issue probereq */
 
 	u64 TSFValue;
-
-	/* for LPS-32K to adaptive bcn early and timeout */
-	u8 adaptive_tsf_done;
-	u32 bcn_delay_cnt[9];
-	u32 bcn_delay_ratio[9];
 	u32 bcn_cnt;
-	u8 DrvBcnEarly;
-	u8 DrvBcnTimeOut;
-
+	u32 last_bcn_cnt;
+	u8 cur_bcn_cnt;/*2s*/
+	u8 dtim;/*DTIM Period*/
+#ifdef DBG_RX_BCN
+	u8 tim[4];
+#endif
+#ifdef CONFIG_BCN_RECV_TIME
+	u16 bcn_rx_time;
+#endif
 #ifdef CONFIG_AP_MODE
 	unsigned char bstart_bss;
 #endif
@@ -721,8 +550,34 @@ struct mlme_ext_priv {
 #ifdef DBG_FIXED_CHAN
 	u8 fixed_chan;
 #endif
-	/* set hw sync bcn tsf register or not */
-	u8 en_hw_update_tsf;
+
+	u8 tsf_update_required:1;
+	u8 en_hw_update_tsf:1; /* set hw sync bcn tsf register or not */
+	systime tsf_update_pause_stime;
+	u8 tsf_update_pause_factor; /* num of bcn intervals to stay TSF update pause status */
+	u8 tsf_update_restore_factor; /* num of bcn interval to stay TSF update restore status */
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+	u8 ssmps_en;
+	u16 ssmps_tx_tp_th;/*Mbps*/
+	u16 ssmps_rx_tp_th;/*Mbps*/
+	#ifdef DBG_STATIC_SMPS
+	u8 ssmps_test;
+	u8 ssmps_test_en;
+	#endif
+#endif
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+	u8 txss_ctrl_en;
+	u16 txss_tp_th;/*Mbps*/
+	u8 txss_tp_chk_cnt;/*unit 2s*/
+	u8 txss_1ss;
+	u8 txss_momi_type_bk;
+#endif
+};
+
+struct support_rate_handler {
+	u8 rate;
+	bool basic;
+	bool existence;
 };
 
 static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)
@@ -733,6 +588,8 @@ static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)
 	return _FALSE;
 }
 
+void sitesurvey_set_offch_state(_adapter *adapter, u8 scan_state);
+
 #define mlmeext_msr(mlmeext) ((mlmeext)->mlmext_info.state & 0x03)
 #define mlmeext_scan_state(mlmeext) ((mlmeext)->sitesurvey_res.state)
 #define mlmeext_scan_state_str(mlmeext) scan_state_str((mlmeext)->sitesurvey_res.state)
@@ -743,6 +600,7 @@ static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)
 		((mlmeext)->sitesurvey_res.next_state = (_state)); \
 		rtw_mi_update_iface_status(&((container_of(mlmeext, _adapter, mlmeextpriv)->mlmepriv)), 0); \
 		/* RTW_INFO("set_scan_state:%s\n", scan_state_str(_state)); */ \
+		sitesurvey_set_offch_state(container_of(mlmeext, _adapter, mlmeextpriv), _state); \
 	} while (0)
 
 #define mlmeext_scan_next_state(mlmeext) ((mlmeext)->sitesurvey_res.next_state)
@@ -767,13 +625,6 @@ static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)
 	do { \
 		((mlmeext)->sitesurvey_res.backop_flags_sta = (flags)); \
 	} while (0)
-
-#define mlmeext_scan_backop_flags_ap(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_ap)
-#define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_ap & (flags))
-#define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) \
-	do { \
-		((mlmeext)->sitesurvey_res.backop_flags_ap = (flags)); \
-	} while (0)
 #else
 #define mlmeext_scan_backop_flags(mlmeext) (0)
 #define mlmeext_chk_scan_backop_flags(mlmeext, flags) (0)
@@ -782,11 +633,34 @@ static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)
 #define mlmeext_scan_backop_flags_sta(mlmeext) (0)
 #define mlmeext_chk_scan_backop_flags_sta(mlmeext, flags) (0)
 #define mlmeext_assign_scan_backop_flags_sta(mlmeext, flags) do {} while (0)
+#endif /* CONFIG_SCAN_BACKOP */
 
+#if defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_AP_MODE)
+#define mlmeext_scan_backop_flags_ap(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_ap)
+#define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_ap & (flags))
+#define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) \
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags_ap = (flags)); \
+	} while (0)
+#else
 #define mlmeext_scan_backop_flags_ap(mlmeext) (0)
 #define mlmeext_chk_scan_backop_flags_ap(mlmeext, flags) (0)
 #define mlmeext_assign_scan_backop_flags_ap(mlmeext, flags) do {} while (0)
-#endif
+#endif /* defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_AP_MODE) */
+
+#if defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_RTW_MESH)
+#define mlmeext_scan_backop_flags_mesh(mlmeext) ((mlmeext)->sitesurvey_res.backop_flags_mesh)
+#define mlmeext_chk_scan_backop_flags_mesh(mlmeext, flags) ((mlmeext)->sitesurvey_res.backop_flags_mesh & (flags))
+#define mlmeext_assign_scan_backop_flags_mesh(mlmeext, flags) \
+	do { \
+		((mlmeext)->sitesurvey_res.backop_flags_mesh = (flags)); \
+	} while (0)
+#else
+#define mlmeext_scan_backop_flags_mesh(mlmeext) (0)
+#define mlmeext_chk_scan_backop_flags_mesh(mlmeext, flags) (0)
+#define mlmeext_assign_scan_backop_flags_mesh(mlmeext, flags) do {} while (0)
+#endif /* defined(CONFIG_SCAN_BACKOP) && defined(CONFIG_RTW_MESH) */
+
 u32 rtw_scan_timeout_decision(_adapter *padapter);
 
 void init_mlme_default_rate_set(_adapter *padapter);
@@ -817,7 +691,6 @@ systime rtw_get_on_oper_ch_time(_adapter *adapter);
 systime rtw_get_on_cur_ch_time(_adapter *adapter);
 
 u8 rtw_get_offset_by_chbw(u8 ch, u8 bw, u8 *r_offset);
-u8 rtw_get_offset_by_ch(u8 channel);
 
 void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char channel_offset, unsigned short bwmode);
 
@@ -848,7 +721,6 @@ void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType);
 u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid);
 void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src, _adapter *padapter, bool update_ie);
 
-int get_bsstype(unsigned short capability);
 u8 *get_my_bssid(WLAN_BSSID_EX *pnetwork);
 u16 get_beacon_interval(WLAN_BSSID_EX *bss);
 
@@ -857,6 +729,13 @@ int is_client_associated_to_ibss(_adapter *padapter);
 int is_IBSS_empty(_adapter *padapter);
 
 unsigned char check_assoc_AP(u8 *pframe, uint len);
+void get_assoc_AP_Vendor(char *vendor, u8 assoc_AP_vendor);
+#ifdef CONFIG_RTS_FULL_BW
+void rtw_parse_sta_vendor_ie_8812(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len);
+#endif/*CONFIG_RTS_FULL_BW*/
+#ifdef CONFIG_80211AC_VHT
+unsigned char get_vht_mu_bfer_cap(u8 *pframe, uint len);
+#endif
 
 int WMM_param_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs	pIE);
 #ifdef CONFIG_WFD
@@ -866,13 +745,24 @@ void rtw_process_wfd_ies(_adapter *adapter, u8 *ies, u8 ies_len, const char *tag
 void WMMOnAssocRsp(_adapter *padapter);
 
 void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+#ifdef ROKU_PRIVATE
+void HT_caps_handler_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+#endif
 void HT_info_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
 void HTOnAssocRsp(_adapter *padapter);
 
+#ifdef ROKU_PRIVATE
+void Supported_rate_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+void Extended_Supported_rate_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+#endif
+
 void ERP_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
 void VCS_update(_adapter *padapter, struct sta_info *psta);
 void	update_ldpc_stbc_cap(struct sta_info *psta);
 
+bool rtw_validate_value(u16 EID, u8 *p, u16 len);
+bool hidden_ssid_ap(WLAN_BSSID_EX *snetwork);
+void rtw_absorb_ssid_ifneed(_adapter *padapter, WLAN_BSSID_EX *bssid, u8 *pframe);
 int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
 		struct beacon_keys *recv_beacon);
 int validate_beacon_len(u8 *pframe, uint len);
@@ -880,7 +770,7 @@ void rtw_dump_bcn_keys(struct beacon_keys *recv_beacon);
 int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len);
 void update_beacon_info(_adapter *padapter, u8 *pframe, uint len, struct sta_info *psta);
 #ifdef CONFIG_DFS
-void process_csa_ie(_adapter *padapter, u8 *pframe, uint len);
+void process_csa_ie(_adapter *padapter, u8 *ies, uint ies_len);
 #endif /* CONFIG_DFS */
 void update_capinfo(PADAPTER Adapter, u16 updateCap);
 void update_wireless_mode(_adapter *padapter);
@@ -906,6 +796,8 @@ unsigned int is_ap_in_tkip(_adapter *padapter);
 unsigned int is_ap_in_wep(_adapter *padapter);
 unsigned int should_forbid_n_rate(_adapter *padapter);
 
+void parsing_eapol_packet(_adapter *padapter, u8 *key_payload, struct sta_info *psta, u8 trx_type);
+
 bool _rtw_camctl_chk_cap(_adapter *adapter, u8 cap);
 void _rtw_camctl_set_flags(_adapter *adapter, u32 flags);
 void rtw_camctl_set_flags(_adapter *adapter, u32 flags);
@@ -920,7 +812,7 @@ void rtw_sec_cam_map_clr_all(struct sec_cam_bmp *map);
 bool _rtw_camid_is_gk(_adapter *adapter, u8 cam_id);
 bool rtw_camid_is_gk(_adapter *adapter, u8 cam_id);
 s16 rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk);
-s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used);
+s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, u8 gk, bool *used);
 void rtw_camid_free(_adapter *adapter, u8 cam_id);
 u8 rtw_get_sec_camid(_adapter *adapter, u8 max_bk_key_num, u8 *sec_key_id);
 
@@ -928,6 +820,7 @@ struct macid_bmp;
 struct macid_ctl_t;
 void dump_macid_map(void *sel, struct macid_bmp *map, u8 max_num);
 bool rtw_macid_is_set(struct macid_bmp *map, u8 id);
+void rtw_macid_map_clr(struct macid_bmp *map, u8 id);
 bool rtw_macid_is_used(struct macid_ctl_t *macid_ctl, u8 id);
 bool rtw_macid_is_bmc(struct macid_ctl_t *macid_ctl, u8 id);
 u8 rtw_macid_get_iface_bmp(struct macid_ctl_t *macid_ctl, u8 id);
@@ -947,8 +840,24 @@ void rtw_macid_ctl_init(struct macid_ctl_t *macid_ctl);
 void rtw_macid_ctl_deinit(struct macid_ctl_t *macid_ctl);
 u8 rtw_iface_bcmc_id_get(_adapter *padapter);
 void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id);
+#if defined(DBG_CONFIG_ERROR_RESET) && defined(CONFIG_CONCURRENT_MODE)
+void rtw_iface_bcmc_sec_cam_map_restore(_adapter *adapter);
+#endif
+bool rtw_bmp_is_set(const u8 *bmp, u8 bmp_len, u8 id);
+void rtw_bmp_set(u8 *bmp, u8 bmp_len, u8 id);
+void rtw_bmp_clear(u8 *bmp, u8 bmp_len, u8 id);
+bool rtw_bmp_not_empty(const u8 *bmp, u8 bmp_len);
+bool rtw_bmp_not_empty_exclude_bit0(const u8 *bmp, u8 bmp_len);
 
-u32 report_join_res(_adapter *padapter, int res);
+#ifdef CONFIG_AP_MODE
+bool rtw_tim_map_is_set(_adapter *padapter, const u8 *map, u8 id);
+void rtw_tim_map_set(_adapter *padapter, u8 *map, u8 id);
+void rtw_tim_map_clear(_adapter *padapter, u8 *map, u8 id);
+bool rtw_tim_map_anyone_be_set(_adapter *padapter, const u8 *map);
+bool rtw_tim_map_anyone_be_set_exclude_aid0(_adapter *padapter, const u8 *map);
+#endif /* CONFIG_AP_MODE */
+
+u32 report_join_res(_adapter *padapter, int aid_res, u16 status);
 void report_survey_event(_adapter *padapter, union recv_frame *precv_frame);
 void report_surveydone_event(_adapter *padapter);
 u32 report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated);
@@ -986,10 +895,11 @@ void issue_assocreq(_adapter *padapter);
 void issue_reassocreq(_adapter *padapter);
 void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *pstat, int pkt_type);
 void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status);
-void issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da);
-s32 issue_probereq_ex(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch, bool append_wps, int try_cnt, int wait_ms);
+void issue_auth_for_monitor(_adapter *padapter, u8 *pmac_addr, unsigned short status);
+void issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da);
+s32 issue_probereq_ex(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps, int try_cnt, int wait_ms);
 int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms);
-int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int try_cnt, int wait_ms);
+int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int try_cnt, int wait_ms);
 int issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason);
 int issue_deauth_ex(_adapter *padapter, u8 *da, unsigned short reason, int try_cnt, int wait_ms);
 void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset);
@@ -1068,12 +978,32 @@ unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame);
 unsigned int OnAction_p2p(_adapter *padapter, union recv_frame *precv_frame);
 
 #ifdef CONFIG_RTW_80211R
-void start_clnt_ft_action(_adapter *padapter, u8 *pTargetAddr);
-void issue_action_ft_request(_adapter *padapter, u8 *pTargetAddr);
-void report_ft_event(_adapter *padapter);
-void report_ft_reassoc_event(_adapter *padapter, u8 *pMacAddr);
-void ft_link_timer_hdl(void *ctx);
-void ft_roam_timer_hdl(void *ctx);
+void rtw_ft_update_bcn(_adapter *padapter, union recv_frame *precv_frame);
+void rtw_ft_start_clnt_join(_adapter *padapter);
+u8 rtw_ft_update_rsnie(_adapter *padapter, u8 bwrite, 
+	struct pkt_attrib *pattrib, u8 **pframe);
+void rtw_ft_build_auth_req_ies(_adapter *padapter, 
+	struct pkt_attrib *pattrib, u8 **pframe);
+void rtw_ft_build_assoc_req_ies(_adapter *padapter, 
+	u8 is_reassoc, struct pkt_attrib *pattrib, u8 **pframe);
+u8 rtw_ft_update_auth_rsp_ies(_adapter *padapter, u8 *pframe, u32 len);
+void rtw_ft_start_roam(_adapter *padapter, u8 *pTargetAddr);
+void rtw_ft_issue_action_req(_adapter *padapter, u8 *pTargetAddr);
+void rtw_ft_report_evt(_adapter *padapter);
+void rtw_ft_report_reassoc_evt(_adapter *padapter, u8 *pMacAddr);
+void rtw_ft_link_timer_hdl(void *ctx);
+void rtw_ft_roam_timer_hdl(void *ctx);
+void rtw_ft_roam_status_reset(_adapter *padapter);
+#endif
+#ifdef CONFIG_RTW_WNM
+void rtw_wnm_roam_scan_hdl(void *ctx);
+void rtw_wnm_process_btm_req(_adapter *padapter,  u8* pframe, u32 frame_len);
+void rtw_wnm_reset_btm_candidate(struct roam_nb_info *pnb);
+void rtw_wnm_reset_btm_state(_adapter *padapter);
+void rtw_wnm_issue_action(_adapter *padapter, u8 action, u8 reason);
+#endif
+#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
+u32 rtw_wnm_btm_candidates_survey(_adapter *padapter, u8* pframe, u32 elem_len, u8 is_preference);
 #endif
 void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res);
 void mlmeext_sta_del_event_callback(_adapter *padapter);
@@ -1081,6 +1011,10 @@ void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta);
 
 void linked_status_chk(_adapter *padapter, u8 from_timer);
 
+#define rtw_get_bcn_cnt(adapter)	(adapter->mlmeextpriv.cur_bcn_cnt)
+#define rtw_get_bcn_dtim_period(adapter)	(adapter->mlmeextpriv.dtim)
+void rtw_collect_bcn_info(_adapter *adapter);
+
 void _linked_info_dump(_adapter *padapter);
 
 void survey_timer_hdl(void *ctx);
@@ -1109,17 +1043,23 @@ void reassoc_timer_hdl(_adapter *padapter);
 		_set_timer(&(mlmeext)->link_timer, (ms)); \
 	} while (0)
 
+bool rtw_is_basic_rate_cck(u8 rate);
+bool rtw_is_basic_rate_ofdm(u8 rate);
+bool rtw_is_basic_rate_mix(u8 rate);
+
 extern int cckrates_included(unsigned char *rate, int ratelen);
 extern int cckratesonly_included(unsigned char *rate, int ratelen);
 
 extern void process_addba_req(_adapter *padapter, u8 *paddba_req, u8 *addr);
 
 extern void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len);
-extern void correct_TSF(_adapter *padapter, struct mlme_ext_priv *pmlmeext);
-extern void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len);
+extern void correct_TSF(_adapter *padapter, u8 mlme_state);
+#ifdef CONFIG_BCN_RECV_TIME
+void rtw_rx_bcn_time_update(_adapter *adapter, uint bcn_len, u8 data_rate);
+#endif
 extern u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer);
 
-
+void rtw_process_bar_frame(_adapter *padapter, union recv_frame *precv_frame);
 void rtw_join_done_chk_ch(_adapter *padapter, int join_res);
 
 int rtw_chk_start_clnt_join(_adapter *padapter, u8 *ch, u8 *bw, u8 *offset);
@@ -1244,7 +1184,7 @@ struct cmd_hdl wlancmds[] = {
 	GEN_MLME_EXT_HANDLER(sizeof(struct SetChannelPlan_param), set_chplan_hdl) /*59*/
 	GEN_MLME_EXT_HANDLER(sizeof(struct LedBlink_param), led_blink_hdl) /*60*/
 
-	GEN_MLME_EXT_HANDLER(sizeof(struct SetChannelSwitch_param), set_csa_hdl) /*61*/
+	GEN_MLME_EXT_HANDLER(0, set_csa_hdl) /*61*/
 	GEN_MLME_EXT_HANDLER(sizeof(struct TDLSoption_param), tdls_hdl) /*62*/
 	GEN_MLME_EXT_HANDLER(0, chk_bmc_sleepq_hdl) /*63*/
 	GEN_MLME_EXT_HANDLER(sizeof(struct RunInThread_param), run_in_thread_hdl) /*64*/
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp.h
index d3805e905b78..7111e818f167 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -271,6 +272,7 @@ enum {
 	MP_STOP,
 	MP_RATE,
 	MP_CHANNEL,
+	MP_CHL_OFFSET,
 	MP_BANDWIDTH,
 	MP_TXPOWER,
 	MP_ANT_TX,
@@ -307,6 +309,7 @@ enum {
 	MP_PWRBYRATE,
 	BT_EFUSE_FILE,
 	MP_SetBT,
+	MP_SWRFPath,
 	MP_NULL,
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
 	VENDOR_IE_SET ,
@@ -350,6 +353,7 @@ struct mp_priv {
 	u32 rx_pktloss;
 	BOOLEAN  rx_bindicatePkt;
 	struct recv_stat rxstat;
+	BOOLEAN brx_filter_beacon;
 
 	/* RF/BB relative */
 	u8 channel;
@@ -374,6 +378,9 @@ struct mp_priv {
 	u8 mac_filter[ETH_ALEN];
 	u8 bmac_filter;
 
+	/* RF PATH Setting for WLG WLA BTG BT */
+	u8 rf_path_cfg;
+
 	struct wlan_network mp_network;
 	NDIS_802_11_MAC_ADDRESS network_macaddr;
 
@@ -417,6 +424,7 @@ struct mp_priv {
 
 
 	u8		*TXradomBuffer;
+	u8		CureFuseBTCoex;
 };
 
 typedef struct _IOCMD_STRUCT_ {
@@ -748,6 +756,7 @@ void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart);
 void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart);
 void mpt_ProSetPMacTx(PADAPTER	Adapter);
 void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter , BOOLEAN bMain);
+void mp_phy_switch_rf_path_set(PADAPTER pAdapter , u8 *pstate);
 u8 MP_PHY_QueryRFPathSwitch(PADAPTER pAdapter);
 ULONG mpt_ProQueryCalTxPower(PADAPTER	pAdapter, u8 RfPath);
 void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart);
@@ -817,6 +826,9 @@ int rtw_mp_rate(struct net_device *dev,
 int rtw_mp_channel(struct net_device *dev,
 		struct iw_request_info *info,
 		struct iw_point *wrqu, char *extra);
+int rtw_mp_ch_offset(struct net_device *dev,
+		struct iw_request_info *info,
+		struct iw_point *wrqu, char *extra);
 int rtw_mp_bandwidth(struct net_device *dev,
 		struct iw_request_info *info,
 		struct iw_point *wrqu, char *extra);
@@ -874,6 +886,9 @@ int rtw_mp_phypara(struct net_device *dev,
 int rtw_mp_SetRFPath(struct net_device *dev,
 		struct iw_request_info *info,
 		struct iw_point *wrqu, char *extra);
+int rtw_mp_switch_rf_path(struct net_device *dev,
+			struct iw_request_info *info,
+			struct iw_point *wrqu, char *extra);
 int rtw_mp_QueryDrv(struct net_device *dev,
 		struct iw_request_info *info,
 		union iwreq_data *wrqu, char *extra);
@@ -918,7 +933,7 @@ u8 HwRateToMPTRate(u8 rate);
 int rtw_mp_iqk(struct net_device *dev,
 		 struct iw_request_info *info,
 		 struct iw_point *wrqu, char *extra);
-int rtw_mp_lck(struct net_device *dev, 
-		struct iw_request_info *info, 
+int rtw_mp_lck(struct net_device *dev,
+		struct iw_request_info *info,
 		struct iw_point *wrqu, char *extra);
 #endif /* _RTW_MP_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_ioctl.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_ioctl.h
index a9dabfcefddf..df9286989805 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_ioctl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_ioctl.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_phy_regdef.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_phy_regdef.h
index be627800e522..330ecbfdd957 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_phy_regdef.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_mp_phy_regdef.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_odm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_odm.h
index 4ce6fe1407a4..7a1b5544e296 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_odm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_odm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -77,18 +78,19 @@ void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter);
 
 bool rtw_odm_adaptivity_needed(_adapter *adapter);
 void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter);
-void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff, s8 th_l2h_ini_mode2, s8 th_edcca_hl_diff_mode2, u8 edcca_enable);
+void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff);
 void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter);
 void rtw_odm_acquirespinlock(_adapter *adapter,	enum rt_spinlock_type type);
 void rtw_odm_releasespinlock(_adapter *adapter,	enum rt_spinlock_type type);
 
-u8 rtw_odm_get_dfs_domain(_adapter *adapter);
-u8 rtw_odm_dfs_domain_unknown(_adapter *adapter);
+u8 rtw_odm_get_dfs_domain(struct dvobj_priv *dvobj);
+u8 rtw_odm_dfs_domain_unknown(struct dvobj_priv *dvobj);
 #ifdef CONFIG_DFS_MASTER
 VOID rtw_odm_radar_detect_reset(_adapter *adapter);
 VOID rtw_odm_radar_detect_disable(_adapter *adapter);
 VOID rtw_odm_radar_detect_enable(_adapter *adapter);
 BOOLEAN rtw_odm_radar_detect(_adapter *adapter);
+u8 rtw_odm_radar_detect_polling_int_ms(struct dvobj_priv *dvobj);
 #endif /* CONFIG_DFS_MASTER */
 
 void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_p2p.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_p2p.h
index f5fe3c157e85..697b2fcaae31 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_p2p.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_p2p.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -70,6 +71,7 @@ u8	p2p_ps_wk_cmd(_adapter *padapter, u8 p2p_ps_state, u8 enqueue);
 #endif /* CONFIG_P2P_PS */
 
 #ifdef CONFIG_IOCTL_CFG80211
+u8 roch_stay_in_cur_chan(_adapter *padapter);
 void rtw_init_cfg80211_wifidirect_info(_adapter	*padapter);
 int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx);
 #endif /* CONFIG_IOCTL_CFG80211 */
@@ -101,11 +103,8 @@ static inline void _rtw_p2p_restore_state(struct wifidirect_info *wdinfo)
 	}
 }
 #endif
-static inline void _rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)
-{
-	if (wdinfo->role != role)
-		wdinfo->role = role;
-}
+void _rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role);
+
 static inline int _rtw_p2p_state(struct wifidirect_info *wdinfo)
 {
 	return wdinfo->p2p_state;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_pwrctrl.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_pwrctrl.h
index c3c81232d8ec..de2b26ed0652 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_pwrctrl.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_pwrctrl.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -303,6 +304,13 @@ struct aoac_report {
 	u8 group_key[32];
 	u8 key_index;
 	u8 security_type;
+	u8 wow_pattern_idx;
+	u8 version_info;
+	u8 rekey_ok:1;
+	u8 dummy:7;
+	u8 reserved[3];
+	u8 rxptk_iv[8];
+	u8 rxgtk_iv[4][8];
 };
 
 struct pwrctrl_priv {
@@ -312,11 +320,23 @@ struct pwrctrl_priv {
 	volatile u8 cpwm; /* fw current power state. updated when 1. read from HCPWM 2. driver lowers power level */
 	volatile u8 tog; /* toggling */
 	volatile u8 cpwm_tog; /* toggling */
+	u8 rpwm_retry;
 
 	u8	pwr_mode;
 	u8	smart_ps;
 	u8	bcn_ant_mode;
 	u8	dtim;
+#ifdef CONFIG_LPS_CHK_BY_TP
+	u8	lps_chk_by_tp;
+	u16	lps_tx_tp_th;/*Mbps*/
+	u16	lps_rx_tp_th;/*Mbps*/
+	u16	lps_bi_tp_th;/*Mbps*//*TRX TP*/
+	int	lps_chk_cnt_th;
+	int	lps_chk_cnt;
+	u32	lps_tx_pkts;
+	u32	lps_rx_pkts;
+
+#endif
 
 #ifdef CONFIG_WMMPS_STA
 	u8 wmm_smart_ps;
@@ -392,6 +412,7 @@ struct pwrctrl_priv {
 #ifdef CONFIG_GPIO_WAKEUP
 	u8		is_high_active;
 #endif /* CONFIG_GPIO_WAKEUP */
+	u8		hst2dev_high_active;
 #ifdef CONFIG_WOWLAN
 	bool		default_patterns_en;
 #ifdef CONFIG_IPV6
@@ -458,6 +479,16 @@ struct pwrctrl_priv {
 	u8 blpspg_info_up;
 #endif
 	u8 current_lps_hw_port_id;
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	systime radio_on_start_time;
+	systime pwr_saving_start_time;
+	u32 pwr_saving_time;
+	u32 on_time;
+	u32 tx_time;
+	u32 rx_time;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 };
 
 #define rtw_get_ips_mode_req(pwrctl) \
@@ -514,16 +545,22 @@ rt_rf_power_state RfOnOffDetect(IN	PADAPTER pAdapter);
 #endif
 
 
+#ifdef DBG_CHECK_FW_PS_STATE
 int rtw_fw_ps_state(PADAPTER padapter);
+#endif
 
 #ifdef CONFIG_LPS
-s32 LPS_RF_ON_check(PADAPTER padapter, u32 delay_ms);
 void LPS_Enter(PADAPTER padapter, const char *msg);
 void LPS_Leave(PADAPTER padapter, const char *msg);
+#ifdef CONFIG_CHECK_LEAVE_LPS
+#ifdef CONFIG_LPS_CHK_BY_TP
+void traffic_check_for_leave_lps_by_tp(PADAPTER padapter, u8 tx, struct sta_info *sta);
+#endif
 void traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets);
+#endif /*CONFIG_CHECK_LEAVE_LPS*/
 void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode, const char *msg);
 void rtw_set_fw_in_ips_mode(PADAPTER padapter, u8 enable);
-void rtw_set_rpwm(_adapter *padapter, u8 val8);
+u8 rtw_set_rpwm(_adapter *padapter, u8 val8);
 void rtw_wow_lps_level_decide(_adapter *adapter, u8 wow_en);
 #endif
 
@@ -568,4 +605,6 @@ void rtw_wow_pattern_sw_reset(_adapter *adapter);
 u8 rtw_set_default_pattern(_adapter *adapter);
 void rtw_wow_pattern_sw_dump(_adapter *adapter);
 #endif /* CONFIG_WOWLAN */
+void rtw_ssmps_enter(_adapter *adapter, struct sta_info *sta);
+void rtw_ssmps_leave(_adapter *adapter, struct sta_info *sta);
 #endif /* __RTL871X_PWRCTRL_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_qos.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_qos.h
index 8e1d013e128f..c3011b4148d3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_qos.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_qos.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_recv.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_recv.h
index 3db4876e236a..7d8ce80f9cb8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_recv.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_recv.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -15,6 +16,10 @@
 #ifndef _RTW_RECV_H_
 #define _RTW_RECV_H_
 
+#define RTW_RX_MSDU_ACT_NONE		0
+#define RTW_RX_MSDU_ACT_INDICATE	BIT0
+#define RTW_RX_MSDU_ACT_FORWARD		BIT1
+
 #ifdef PLATFORM_OS_XP
 	#ifdef CONFIG_SDIO_HCI
 		#define NR_RECVBUFF 1024/* 512 */ /* 128 */
@@ -80,20 +85,10 @@
 #define RX_CMD_QUEUE				1
 #define RX_MAX_QUEUE				2
 
-static u8 SNAP_ETH_TYPE_IPX[2] = {0x81, 0x37};
-
-static u8 SNAP_ETH_TYPE_APPLETALK_AARP[2] = {0x80, 0xf3};
-static u8 SNAP_ETH_TYPE_APPLETALK_DDP[2] = {0x80, 0x9b};
-static u8 SNAP_ETH_TYPE_TDLS[2] = {0x89, 0x0d};
-static u8 SNAP_HDR_APPLETALK_DDP[3] = {0x08, 0x00, 0x07}; /* Datagram Delivery Protocol */
-
-static u8 oui_8021h[] = {0x00, 0x00, 0xf8};
-static u8 oui_rfc1042[] = {0x00, 0x00, 0x00};
-
 #define MAX_SUBFRAME_COUNT	64
-static u8 rtw_rfc1042_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };
 /* Bridge-Tunnel header (for EtherTypes ETH_P_AARP and ETH_P_IPX) */
-static u8 rtw_bridge_tunnel_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8 };
+extern u8 rtw_bridge_tunnel_header[];
+extern u8 rtw_rfc1042_header[];
 
 /* for Rx reordering buffer control */
 struct recv_reorder_ctrl {
@@ -112,6 +107,7 @@ struct recv_reorder_ctrl {
 struct	stainfo_rxcache	{
 	u16	tid_rxseq[16];
 	u8 iv[16][8];
+	u8 last_tid;
 #if 0
 	unsigned short	tid0_rxseq;
 	unsigned short	tid1_rxseq;
@@ -193,6 +189,12 @@ struct rx_pkt_attrib	{
 	u8	ta[ETH_ALEN];
 	u8	ra[ETH_ALEN];
 	u8	bssid[ETH_ALEN];
+#ifdef CONFIG_RTW_MESH
+	u8	msa[ETH_ALEN]; /* mesh sa */
+	u8	mda[ETH_ALEN]; /* mesh da */
+	u8 mesh_ctrl_present;
+	u8	mesh_ctrl_len; /* length of mesh control field */
+#endif
 
 	u8	ack_policy;
 
@@ -210,8 +212,19 @@ struct rx_pkt_attrib	{
 	u8	ppdu_cnt;
 	u32 	free_cnt;		/* free run counter */
 	struct phydm_phyinfo_struct phy_info;
+
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_RX
+	/* checksum offload realted varaiables */
+	u8 csum_valid;		/* Checksum valid, 0: not check, 1: checked */
+	u8 csum_err;		/* Checksum Error occurs */
+#endif /* CONFIG_TCP_CSUM_OFFLOAD_RX */
 };
 
+#ifdef CONFIG_RTW_MESH
+#define RATTRIB_GET_MCTRL_LEN(rattrib) ((rattrib)->mesh_ctrl_len)
+#else
+#define RATTRIB_GET_MCTRL_LEN(rattrib) 0
+#endif
 
 /* These definition is used for Rx packet reordering. */
 #define SN_LESS(a, b)		(((a-b) & 0x800) != 0)
@@ -220,7 +233,11 @@ struct rx_pkt_attrib	{
 /* #define REORDER_ENTRY_NUM	128 */
 #define REORDER_WAIT_TIME	(50) /* (ms) */
 
-#define RECVBUFF_ALIGN_SZ 8
+#if defined(CONFIG_PLATFORM_RTK390X) && defined(CONFIG_USB_HCI)
+	#define RECVBUFF_ALIGN_SZ 32
+#else
+	#define RECVBUFF_ALIGN_SZ 8
+#endif
 
 #ifdef CONFIG_TRX_BD_ARCH
 	#define RX_WIFI_INFO_SIZE	24
@@ -484,6 +501,9 @@ struct sta_recv_priv {
 	_queue defrag_q;	 /* keeping the fragment frame until defrag */
 
 	struct	stainfo_rxcache rxcache;
+	u16	bmc_tid_rxseq[16];
+	u16	nonqos_rxseq;
+	u16	nonqos_bmc_rxseq;
 
 	/* uint	sta_rx_bytes; */
 	/* uint	sta_rx_pkts; */
@@ -847,15 +867,8 @@ __inline static s32 translate_percentage_to_dbm(u32 SignalStrengthIndex)
 {
 	s32	SignalPower; /* in dBm. */
 
-#ifdef CONFIG_SIGNAL_SCALE_MAPPING
-	/* Translate to dBm (x=0.5y-95). */
-	SignalPower = (s32)((SignalStrengthIndex + 1) >> 1);
-	SignalPower -= 95;
-#else
 	/* Translate to dBm (x=y-100) */
 	SignalPower = SignalStrengthIndex - 100;
-#endif
-
 	return SignalPower;
 }
 
@@ -867,5 +880,6 @@ extern void  mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame);
 
 u8 adapter_allow_bmc_data_rx(_adapter *adapter);
 s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status);
+void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info *sta);
 
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rf.h
index ab0d5d77c442..a790ef7fed59 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -16,7 +17,9 @@
 #define __RTW_RF_H_
 
 #define NumRates	(13)
-
+#define	B_MODE_RATE_NUM	(4)
+#define	G_MODE_RATE_NUM	(8)
+#define	G_MODE_BASIC_RATE_NUM	(3)
 /* slot time for 11g */
 #define SHORT_SLOT_TIME					9
 #define NON_SHORT_SLOT_TIME				20
@@ -101,10 +104,10 @@ extern const u8 _band_to_band_cap[];
 
 
 extern const char *const _ch_width_str[];
-#define ch_width_str(bw) (((bw) >= CHANNEL_WIDTH_MAX) ? _ch_width_str[CHANNEL_WIDTH_MAX] : _ch_width_str[(bw)])
+#define ch_width_str(bw) (((bw) < CHANNEL_WIDTH_MAX) ? _ch_width_str[(bw)] : "CHANNEL_WIDTH_MAX")
 
 extern const u8 _ch_width_to_bw_cap[];
-#define ch_width_to_bw_cap(bw) (((bw) >= CHANNEL_WIDTH_MAX) ? _ch_width_to_bw_cap[CHANNEL_WIDTH_MAX] : _ch_width_to_bw_cap[(bw)])
+#define ch_width_to_bw_cap(bw) (((bw) < CHANNEL_WIDTH_MAX) ? _ch_width_to_bw_cap[(bw)] : 0)
 
 /*
  * Represent Extention Channel Offset in HT Capabilities
@@ -149,44 +152,6 @@ int rtw_ch2freq(int chan);
 int rtw_freq2ch(int freq);
 bool rtw_chbw_to_freq_range(u8 ch, u8 bw, u8 offset, u32 *hi, u32 *lo);
 
-#define RTW_MODULE_RTL8821AE_HMC_M2		BIT0 /* RTL8821AE(HMC + M.2) */
-#define RTW_MODULE_RTL8821AU			BIT1 /* RTL8821AU */
-#define RTW_MODULE_RTL8812AENF_NGFF		BIT2 /* RTL8812AENF(8812AE+8761)_NGFF */
-#define RTW_MODULE_RTL8812AEBT_HMC		BIT3 /* RTL8812AEBT(8812AE+8761)_HMC */
-#define RTW_MODULE_RTL8188EE_HMC_M2		BIT4 /* RTL8188EE(HMC + M.2) */
-#define RTW_MODULE_RTL8723BE_HMC_M2		BIT5 /* RTL8723BE(HMC + M.2) */
-#define RTW_MODULE_RTL8723BS_NGFF1216	BIT6 /* RTL8723BS(NGFF1216) */
-#define RTW_MODULE_RTL8192EEBT_HMC_M2	BIT7 /* RTL8192EEBT(8192EE+8761AU)_(HMC + M.2) */
-#define RTW_MODULE_RTL8723DE_NGFF1630	BIT8 /* RTL8723DE(NGFF1630) */
-#define RTW_MODULE_RTL8822BE			BIT9 /* RTL8822BE */
-
-#define IS_ALPHA2_NO_SPECIFIED(_alpha2) ((*((u16 *)(_alpha2))) == 0xFFFF)
-
-struct country_chplan {
-	char alpha2[2];
-	u8 chplan;
-#ifdef CONFIG_80211AC_VHT
-	u8 en_11ac;
-#endif
-#if RTW_DEF_MODULE_REGULATORY_CERT
-	u16 def_module_flags; /* RTW_MODULE_RTLXXX */
-#endif
-};
-
-#ifdef CONFIG_80211AC_VHT
-#define COUNTRY_CHPLAN_EN_11AC(_ent) ((_ent)->en_11ac)
-#else
-#define COUNTRY_CHPLAN_EN_11AC(_ent) 0
-#endif
-
-#if RTW_DEF_MODULE_REGULATORY_CERT
-#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) ((_ent)->def_module_flags)
-#else
-#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) 0
-#endif
-
-const struct country_chplan *rtw_get_chplan_from_country(const char *country_code);
-
 struct rf_ctl_t;
 
 typedef enum _REGULATION_TXPWR_LMT {
@@ -196,7 +161,9 @@ typedef enum _REGULATION_TXPWR_LMT {
 	TXPWR_LMT_ETSI = 3,
 	TXPWR_LMT_IC = 4,
 	TXPWR_LMT_KCC = 5,
-	TXPWR_LMT_WW = 6, /* smallest of all available limit, keep last */
+	TXPWR_LMT_ACMA = 6,
+	TXPWR_LMT_CHILE = 7,
+	TXPWR_LMT_WW = 8, /* smallest of all available limit, keep last */
 } REGULATION_TXPWR_LMT;
 
 extern const char *const _regd_str[];
@@ -246,10 +213,22 @@ int rtw_ch_to_bb_gain_sel(int ch);
 void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset);
 void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch);
 
-u8 rtw_is_5g_band1(u8 ch);
-u8 rtw_is_5g_band2(u8 ch);
-u8 rtw_is_5g_band3(u8 ch);
-u8 rtw_is_5g_band4(u8 ch);
+/* only check channel ranges */
+#define rtw_is_2g_ch(ch) (ch >= 1 && ch <= 14)
+#define rtw_is_5g_ch(ch) ((ch) >= 36 && (ch) <= 177)
+#define rtw_is_same_band(a, b) \
+	((rtw_is_2g_ch(a) && rtw_is_2g_ch(b)) \
+	|| (rtw_is_5g_ch(a) && rtw_is_5g_ch(b)))
+
+#define rtw_is_5g_band1(ch) ((ch) >= 36 && (ch) <= 48)
+#define rtw_is_5g_band2(ch) ((ch) >= 52 && (ch) <= 64)
+#define rtw_is_5g_band3(ch) ((ch) >= 100 && (ch) <= 144)
+#define rtw_is_5g_band4(ch) ((ch) >= 149 && (ch) <= 177)
+#define rtw_is_same_5g_band(a, b) \
+	((rtw_is_5g_band1(a) && rtw_is_5g_band1(b)) \
+	|| (rtw_is_5g_band2(a) && rtw_is_5g_band2(b)) \
+	|| (rtw_is_5g_band3(a) && rtw_is_5g_band3(b)) \
+	|| (rtw_is_5g_band4(a) && rtw_is_5g_band4(b)))
 
 u8 rtw_is_dfs_range(u32 hi, u32 lo);
 u8 rtw_is_dfs_ch(u8 ch);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm.h
index 1752101ab654..840015d6b44a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -82,5 +83,7 @@ void rtw_ap_parse_sta_rm_en_cap(_adapter *padapter,
 int rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid);
 void rm_handler(_adapter *padapter, struct rm_event *pev);
 
+u8 rm_add_nb_req(_adapter *padapter, struct sta_info *psta);
+
 #endif /*CONFIG_RTW_80211K */
 #endif /* __RTW_RM_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm_fsm.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm_fsm.h
index ba903a9c46bb..8b319666c0b9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm_fsm.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rm_fsm.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 
 /******************************************************************************
  *
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rson.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rson.h
index 6996738b071a..e9e27efe76f1 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rson.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_rson.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sdio.h
index 7490b5481328..b4d28e97e298 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sdio.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sdio.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2015 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_security.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_security.h
index ad96a545f705..9c042e682ea9 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_security.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_security.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -22,16 +23,18 @@
 #define _TKIP_WTMIC_		0x3
 #define _AES_				0x4
 #define _WEP104_			0x5
-#define _WEP_WPA_MIXED_	0x07  /* WEP + WPA */
 #define _SMS4_				0x06
-#ifdef CONFIG_IEEE80211W
+#define _WEP_WPA_MIXED_		0x07 /* WEP + WPA */
 #define _BIP_				0x8
-#endif /* CONFIG_IEEE80211W */
+
 /* 802.11W use wrong key */
 #define IEEE80211W_RIGHT_KEY	0x0
 #define IEEE80211W_WRONG_KEY	0x1
 #define IEEE80211W_NO_KEY		0x2
 
+#define CCMPH_2_PN(ch)	((ch) & 0x000000000000ffff) \
+			| (((ch) & 0xffffffff00000000) >> 16)
+
 #define is_wep_enc(alg) (((alg) == _WEP40_) || ((alg) == _WEP104_))
 
 const char *security_type_str(u8 value);
@@ -124,24 +127,24 @@ struct security_priv {
 
 	/* WEP */
 	u32	  dot11PrivacyKeyIndex;	/* this is only valid for legendary wep, 0~3 for key id. (tx key index) */
-	union Keytype dot11DefKey[4];			/* this is only valid for def. key	 */
-	u32	dot11DefKeylen[4];
-	u8	dot11Def_camid[4];
+	union Keytype dot11DefKey[6];			/* this is only valid for def. key	 */
+	u32	dot11DefKeylen[6];
+	u8	dot11Def_camid[6];
 	u8 	key_mask; /* use to restore wep key after hal_init */
 
 	u32 dot118021XGrpPrivacy;	/* This 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 Group Key, for inx0 and inx1	 */
-	union Keytype	dot118021XGrptxmickey[4];
-	union Keytype	dot118021XGrprxmickey[4];
+	union Keytype	dot118021XGrpKey[6];	/* 802.1x Group Key, for inx0 and inx1	 */
+	union Keytype	dot118021XGrptxmickey[6];
+	union Keytype	dot118021XGrprxmickey[6];
 	union pn48		dot11Grptxpn;			/* PN48 used for Grp Key xmit. */
 	union pn48		dot11Grprxpn;			/* PN48 used for Grp Key recv. */
 	u8				iv_seq[4][8];
 #ifdef CONFIG_IEEE80211W
 	u32	dot11wBIPKeyid;						/* key id used for BIP Key ( tx key index) */
 	union Keytype	dot11wBIPKey[6];		/* BIP Key, for index4 and index5 */
-	union pn48		dot11wBIPtxpn;			/* PN48 used for Grp Key xmit. */
-	union pn48		dot11wBIPrxpn;			/* PN48 used for Grp Key recv. */
+	union pn48		dot11wBIPtxpn;			/* PN48 used for BIP xmit. */
+	union pn48		dot11wBIPrxpn;			/* PN48 used for BIP recv. */
 #endif /* CONFIG_IEEE80211W */
 #ifdef CONFIG_AP_MODE
 	/* extend security capabilities for AP_MODE */
@@ -151,6 +154,7 @@ struct security_priv {
 	unsigned int wpa2_group_cipher;
 	unsigned int wpa_pairwise_cipher;
 	unsigned int wpa2_pairwise_cipher;
+	u8 mfp_opt;
 #endif
 #ifdef CONFIG_CONCURRENT_MODE
 	u8	dot118021x_bmc_cam_id;
@@ -240,6 +244,12 @@ struct security_priv {
 #endif /* DBG_SW_SEC_CNT */
 };
 
+#ifdef CONFIG_IEEE80211W
+#define SEC_IS_BIP_KEY_INSTALLED(sec) ((sec)->binstallBIPkey)
+#else
+#define SEC_IS_BIP_KEY_INSTALLED(sec) _FALSE
+#endif
+
 struct sha256_state {
 	u64 length;
 	u32 state[8], curlen;
@@ -435,8 +445,14 @@ static const unsigned long K[64] = {
 #define MIN(x, y) (((x) < (y)) ? (x) : (y))
 #endif
 #ifdef CONFIG_IEEE80211W
-int omac1_aes_128(u8 *key, u8 *data, size_t data_len, u8 *mac);
+int omac1_aes_128(const u8 *key, const u8 *data, size_t data_len, u8 *mac);
 #endif /* CONFIG_IEEE80211W */
+#ifdef CONFIG_RTW_MESH_AEK
+int aes_siv_encrypt(const u8 *key, const u8 *pw, size_t pwlen
+	, size_t num_elem, const u8 *addr[], const size_t *len, u8 *out);
+int aes_siv_decrypt(const u8 *key, const u8 *iv_crypt, size_t iv_c_len
+	, size_t num_elem, const u8 *addr[], const size_t *len, u8 *out);
+#endif
 void rtw_secmicsetkey(struct mic_data *pmicdata, u8 *key);
 void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b);
 void rtw_secmicappend(struct mic_data *pmicdata, u8 *src, u32 nBytes);
@@ -458,8 +474,9 @@ u32 rtw_aes_decrypt(_adapter *padapter, u8  *precvframe);
 u32 rtw_tkip_decrypt(_adapter *padapter, u8  *precvframe);
 void rtw_wep_decrypt(_adapter *padapter, u8  *precvframe);
 #ifdef CONFIG_IEEE80211W
-u32	rtw_BIP_verify(_adapter *padapter, u8 *precvframe);
-#endif /* CONFIG_IEEE80211W */
+u32	rtw_BIP_verify(_adapter *padapter, u8 *whdr_pos, sint flen
+	, const u8 *key, u16 id, u64* ipn);
+#endif
 #ifdef CONFIG_TDLS
 void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta);
 int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sreset.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sreset.h
index f02cfb6e18c8..c3dda35a90a3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sreset.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_sreset.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -21,6 +22,7 @@ enum {
 	SRESET_TGP_NULL = 0,
 	SRESET_TGP_XMIT_STATUS = 1,
 	SRESET_TGP_LINK_STATUS = 2,
+	SRESET_TGP_INFO = 99,
 };
 
 struct sreset_priv {
@@ -34,15 +36,12 @@ struct sreset_priv {
 	u64 self_dect_tx_cnt;
 	u64 self_dect_rx_cnt;
 	u64 self_dect_fw_cnt;
-	u64 self_dect_scan_cnt;
-	u64 txbuf_empty_cnt;
 	u64 tx_dma_status_cnt;
 	u64 rx_dma_status_cnt;
 	u8 rx_cnt;
 	u8 self_dect_fw;
-	u8 self_dect_scan;
-	u8 is_txbuf_empty;
 	u8 self_dect_case;
+	u16 last_mac_rxff_ptr;
 	u8 dbg_sreset_ctrl;
 };
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_tdls.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_tdls.h
index 9e3e811259ae..a18dd823c768 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_tdls.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_tdls.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -120,13 +121,14 @@ void rtw_tdls_set_link_established(_adapter *adapter, bool en);
 void rtw_reset_tdls_info(_adapter *padapter);
 int rtw_init_tdls_info(_adapter *padapter);
 void rtw_free_tdls_info(struct tdls_info *ptdlsinfo);
-void rtw_free_all_tdls_sta(_adapter *padapter, u8 from_cmd_thread);
+void rtw_free_all_tdls_sta(_adapter *padapter, u8 enqueue_cmd);
 void rtw_enable_tdls_func(_adapter *padapter);
-void rtw_disable_tdls_func(_adapter *padapter, u8 from_cmd_thread);
+void rtw_disable_tdls_func(_adapter *padapter, u8 enqueue_cmd);
 int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms);
 void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta);
-void	rtw_free_tdls_timer(struct sta_info *psta);
-void free_tdls_sta(_adapter *padapter, struct sta_info *ptdls_sta);
+void	rtw_cancel_tdls_timer(struct sta_info *psta);
+void rtw_tdls_teardown_pre_hdl(_adapter *padapter, struct sta_info *psta);
+void rtw_tdls_teardown_post_hdl(_adapter *padapter, struct sta_info *psta, u8 enqueue_cmd);
 
 #ifdef CONFIG_TDLS_CH_SW
 void rtw_tdls_set_ch_sw_oper_control(_adapter *padapter, u8 enable);
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_version.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_version.h
index 45f786493ffa..9b9225fa3d3b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_version.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_version.h
@@ -1,3 +1,3 @@
 /* SPDX-License-Identifier: GPL-2.0 */
-#define DRIVERVERSION	"v5.2.15.1_25011.20171107_COEX20171025-2020"
-#define BTCOEXVERSION	"COEX20171025-2020"
+#define DRIVERVERSION	"v5.6.5_31752.20181221_COEX20181130-2e2e"
+#define BTCOEXVERSION	"COEX20181130-2e2e"
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_vht.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_vht.h
index 31988955d80e..dd86d21a1944 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_vht.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_vht.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -15,6 +16,9 @@
 #ifndef _RTW_VHT_H_
 #define _RTW_VHT_H_
 
+#define VHT_CAP_IE_LEN 12
+#define VHT_OP_IE_LEN 5
+
 #define	LDPC_VHT_ENABLE_RX			BIT0
 #define	LDPC_VHT_ENABLE_TX			BIT1
 #define	LDPC_VHT_TEST_TX_ENABLE		BIT2
@@ -93,22 +97,60 @@
 #define SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(_pEleStart, _val)			SET_BITS_TO_LE_1BYTE((_pEleStart)+7, 6, 1, _val)
 #define GET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(_pEleStart)				LE_BITS_TO_1BYTE((_pEleStart)+7, 6, 1)
 
+#define VHT_MAX_MPDU_LEN_MAX 3
+extern const u16 _vht_max_mpdu_len[];
+#define vht_max_mpdu_len(val) (((val) >= VHT_MAX_MPDU_LEN_MAX) ? _vht_max_mpdu_len[VHT_MAX_MPDU_LEN_MAX] : _vht_max_mpdu_len[(val)])
+
+#define VHT_SUP_CH_WIDTH_SET_MAX 3
+extern const u8 _vht_sup_ch_width_set_to_bw_cap[];
+#define vht_sup_ch_width_set_to_bw_cap(set) (((set) >= VHT_SUP_CH_WIDTH_SET_MAX) ? _vht_sup_ch_width_set_to_bw_cap[VHT_SUP_CH_WIDTH_SET_MAX] : _vht_sup_ch_width_set_to_bw_cap[(set)])
+extern const char *const _vht_sup_ch_width_set_str[];
+#define vht_sup_ch_width_set_str(set) (((set) >= VHT_SUP_CH_WIDTH_SET_MAX) ? _vht_sup_ch_width_set_str[VHT_SUP_CH_WIDTH_SET_MAX] : _vht_sup_ch_width_set_str[(set)])
+
+#define VHT_MAX_AMPDU_LEN(f) ((1 << (13 + f)) - 1)
+void dump_vht_cap_ie(void *sel, const u8 *ie, u32 ie_len);
+
+#define VHT_OP_CH_WIDTH_MAX 4
+extern const char *const _vht_op_ch_width_str[];
+#define vht_op_ch_width_str(ch_width) (((ch_width) >= VHT_OP_CH_WIDTH_MAX) ? _vht_op_ch_width_str[VHT_OP_CH_WIDTH_MAX] : _vht_op_ch_width_str[(ch_width)])
+
+void dump_vht_op_ie(void *sel, const u8 *ie, u32 ie_len);
+
 struct vht_priv {
 	u8	vht_option;
 
 	u8	ldpc_cap;
 	u8	stbc_cap;
 	u16	beamform_cap;
+	u8	ap_is_mu_bfer;
 
 	u8	sgi_80m;/* short GI */
 	u8	ampdu_len;
 
-	u8	vht_op_mode_notify;
 	u8	vht_highest_rate;
 	u8	vht_mcs_map[2];
 
-	u8	vht_cap[32];
+	u8 op_present:1; /* vht_op is present */
+	u8 notify_present:1; /* vht_op_mode_notify is present */
+
+	u8 vht_cap[32];
+	u8 vht_op[VHT_OP_IE_LEN];
+	u8 vht_op_mode_notify;
+};
+
+#ifdef ROKU_PRIVATE
+struct vht_priv_infra_ap {
+
+	/* Infra mode, only store for AP's info, not intersection of STA and AP*/
+	u8	ldpc_cap_infra_ap;
+	u8	stbc_cap_infra_ap;
+	u16	beamform_cap_infra_ap;
+	u8	vht_mcs_map_infra_ap[2];
+	u8	vht_mcs_map_tx_infra_ap[2];
+	u8	channel_width_infra_ap;
+	u8	number_of_streams_infra_ap;
 };
+#endif /* ROKU_PRIVATE */
 
 u8	rtw_get_vht_highest_rate(u8 *pvht_mcs_map);
 u16	rtw_vht_mcs_to_data_rate(u8 bw, u8 short_GI, u8 vht_mcs_rate);
@@ -120,6 +162,9 @@ u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf);
 void	update_sta_vht_info_apmode(_adapter *padapter, PVOID psta);
 void	update_hw_vht_param(_adapter *padapter);
 void	VHT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+#ifdef ROKU_PRIVATE
+void	VHT_caps_handler_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
+#endif /* ROKU_PRIVATE */
 void	VHT_operation_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE);
 void	rtw_process_vht_op_mode_notify(_adapter *padapter, u8 *pframe, PVOID sta);
 u32	rtw_restructure_vht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len);
@@ -128,4 +173,5 @@ u8	rtw_vht_mcsmap_to_nss(u8 *pvht_mcs_map);
 void rtw_vht_nss_to_mcsmap(u8 nss, u8 *target_mcs_map, u8 *cur_mcs_map);
 void rtw_vht_ies_attach(_adapter *padapter, WLAN_BSSID_EX *pcur_network);
 void rtw_vht_ies_detach(_adapter *padapter, WLAN_BSSID_EX *pcur_network);
+void rtw_check_for_vht20(_adapter *adapter, u8 *ies, int ies_len);
 #endif /* _RTW_VHT_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wapi.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wapi.h
index 26f2855d8717..8e2479a46ba3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wapi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wapi.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2016 - 2017 Realtek Corporation.
@@ -225,4 +226,6 @@ u8 WapiIncreasePN(u8 *PN, u8 AddCount);
 
 bool rtw_wapi_drop_for_key_absent(_adapter *padapter, u8 *pRA);
 
+void rtw_wapi_set_set_encryption(_adapter *padapter, struct ieee_param *param);
+
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wifi_regd.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wifi_regd.h
index f56008cf7c4b..b5c5d62ff76e 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wifi_regd.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_wifi_regd.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2009-2010 - 2017 Realtek Corporation.
@@ -28,7 +29,7 @@ enum country_code_type_t {
 	COUNTRY_CODE_MAX
 };
 
-int rtw_regd_init(_adapter *padapter);
-void rtw_reg_notify_by_driver(_adapter *adapter);
+void rtw_regd_apply_flags(struct wiphy *wiphy);
+int rtw_regd_init(struct wiphy *wiphy);
 
 #endif /* __RTW_WIFI_REGD_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_xmit.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_xmit.h
index 0ee90199df3a..8c3bd58d29e6 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_xmit.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/rtw_xmit.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -27,6 +28,7 @@
 
 	#if defined CONFIG_SDIO_HCI
 		#define NR_XMITBUFF	(16)
+		#define SDIO_TX_DIV_NUM (2)
 	#endif
 	#if defined(CONFIG_GSPI_HCI)
 		#define NR_XMITBUFF	(128)
@@ -84,13 +86,15 @@
 #endif
 
 #ifdef CONFIG_RTL8812A
-	#define MAX_CMDBUF_SZ	(512 * 17)
+	#define MAX_CMDBUF_SZ	(512 * 18)
 #elif defined(CONFIG_RTL8723D) && defined(CONFIG_LPS_POFF)
 	#define MAX_CMDBUF_SZ	(128*70) /*(8960)*/
 #else
 	#define MAX_CMDBUF_SZ	(5120)	/* (4096) */
 #endif
 
+#define MAX_BEACON_LEN	512
+
 #define MAX_NUMBLKS		(1)
 
 #define XMIT_VO_QUEUE (0)
@@ -119,16 +123,17 @@
 
 #define WEP_IV(pattrib_iv, dot11txpn, keyidx)\
 	do {\
+		dot11txpn.val = (dot11txpn.val == 0xffffff) ? 0 : (dot11txpn.val + 1);\
 		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 {\
+		dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 : (dot11txpn.val + 1);\
 		pattrib_iv[0] = dot11txpn._byte_.TSC1;\
 		pattrib_iv[1] = (dot11txpn._byte_.TSC1 | 0x20) & 0x7f;\
 		pattrib_iv[2] = dot11txpn._byte_.TSC0;\
@@ -137,11 +142,11 @@
 		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 {\
+		dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 : (dot11txpn.val + 1);\
 		pattrib_iv[0] = dot11txpn._byte_.TSC0;\
 		pattrib_iv[1] = dot11txpn._byte_.TSC1;\
 		pattrib_iv[2] = 0;\
@@ -150,7 +155,6 @@
 		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)
 
 /* Check if AMPDU Tx is supported or not. If it is supported,
@@ -182,7 +186,8 @@
 #if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) ||\
 	defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8192E) ||\
 	defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8703B) ||\
-	defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8723D)
+	defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8723D) ||\
+	defined(CONFIG_RTL8710B) || defined(CONFIG_RTL8192F)
 	#define TXDESC_SIZE 40
 #elif defined(CONFIG_RTL8822B)
 	#define TXDESC_SIZE 48		/* HALMAC_TX_DESC_SIZE_8822B */
@@ -236,7 +241,8 @@ enum TXDESC_SC {
 		#define TXDESC_64_BYTES
 	#endif
 #elif defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8723B) \
-	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8723D)
+	|| defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) || defined(CONFIG_RTL8723D) \
+	|| defined(CONFIG_RTL8192F)
 	#define TXDESC_40_BYTES
 #endif
 
@@ -390,9 +396,6 @@ struct pkt_attrib {
 	u16	seqnum;
 
 	struct sta_info *psta;
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
-	u8	hw_tcp_csum;
-#endif
 };
 #else
 /* reduce size */
@@ -425,6 +428,20 @@ struct pkt_attrib {
 	u8	src[ETH_ALEN];
 	u8	ta[ETH_ALEN];
 	u8	ra[ETH_ALEN];
+#ifdef CONFIG_RTW_MESH
+	u8	mda[ETH_ALEN];	/* mesh da */
+	u8	msa[ETH_ALEN];	/* mesh sa */
+	u8	meshctrl_len;	/* Length of Mesh Control field */
+	u8	mesh_frame_mode;
+	#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	u8 mb2u;
+	#endif
+	u8 mfwd_ttl;
+	u32 mseq;
+#endif
+#ifdef CONFIG_TX_CSUM_OFFLOAD
+	u8	hw_csum;
+#endif
 	u8	key_idx;
 	u8	qos_en;
 	u8	ht_en;
@@ -453,9 +470,6 @@ struct pkt_attrib {
 #endif /* CONFIG_WMMPS_STA */
 	
 	struct sta_info *psta;
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
-	u8	hw_tcp_csum;
-#endif
 
 	u8 rtsen;
 	u8 cts2self;
@@ -487,6 +501,12 @@ struct pkt_attrib {
 };
 #endif
 
+#ifdef CONFIG_RTW_MESH
+#define XATTRIB_GET_MCTRL_LEN(xattrib) ((xattrib)->meshctrl_len)
+#else
+#define XATTRIB_GET_MCTRL_LEN(xattrib) 0
+#endif
+
 #ifdef CONFIG_TX_AMSDU
 enum {
 	RTW_AMSDU_TIMER_UNSET = 0,
@@ -888,6 +908,30 @@ extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8822be(struct xmit_priv *pxmi
 extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8821ce(struct xmit_priv *pxmitpriv,
 		enum cmdbuf_type buf_type);
 #define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8821ce(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8192F) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8192fe(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8192fe(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8812A) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8812ae(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8812ae(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8723D) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8723de(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8723de(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8723B) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8723be(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8723be(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8814A) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8814ae(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8814ae(p, CMDBUF_BEACON)
+#elif defined(CONFIG_RTL8188E) && defined(CONFIG_PCI_HCI)
+extern struct xmit_frame *__rtw_alloc_cmdxmitframe_8188ee(struct xmit_priv *pxmitpriv,
+		enum cmdbuf_type buf_type);
+#define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe_8188ee(p, CMDBUF_BEACON)
 #else
 #define rtw_alloc_bcnxmitframe(p) __rtw_alloc_cmdxmitframe(p, CMDBUF_BEACON)
 #endif
@@ -900,8 +944,6 @@ extern s32 rtw_free_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitb
 
 void rtw_count_tx_stats(_adapter *padapter, struct xmit_frame *pxmitframe, int sz);
 extern void rtw_update_protection(_adapter *padapter, u8 *ie, uint ie_len);
-static s32 update_attrib_sec_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
-static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta);
 
 #ifdef CONFIG_WMMPS_STA
 static void update_attrib_trigger_frame_info(_adapter *padapter, struct pkt_attrib *pattrib);
@@ -923,9 +965,9 @@ extern s32 rtw_xmit_classifier(_adapter *padapter, struct xmit_frame *pxmitframe
 extern u32 rtw_calculate_wlan_pkt_size_by_attribue(struct pkt_attrib *pattrib);
 #define rtw_wlan_pkt_size(f) rtw_calculate_wlan_pkt_size_by_attribue(&f->attrib)
 extern s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe);
-#ifdef CONFIG_IEEE80211W
+#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
 extern s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe);
-#endif /* CONFIG_IEEE80211W */
+#endif
 #ifdef CONFIG_TDLS
 extern struct tdls_txmgmt *ptxmgmt;
 s32 rtw_xmit_tdls_coalesce(_adapter *padapter, struct xmit_frame *pxmitframe, struct tdls_txmgmt *ptxmgmt);
@@ -949,6 +991,7 @@ void rtw_free_hwxmits(_adapter *padapter);
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
 s32 rtw_monitor_xmit_entry(struct sk_buff *skb, struct net_device *ndev);
 #endif
+s32 rtw_xmit_posthandle(_adapter *padapter, struct xmit_frame *pxmitframe, _pkt *pkt);
 s32 rtw_xmit(_adapter *padapter, _pkt **pkt);
 bool xmitframe_hiq_filter(struct xmit_frame *xmitframe);
 #if defined(CONFIG_AP_MODE) || defined(CONFIG_TDLS)
@@ -1004,7 +1047,6 @@ void rtw_tx_desc_backup_reset(void);
 u8 rtw_get_tx_desc_backup(_adapter *padapter, u8 hwq, struct rtw_tx_desc_backup **pbak);
 #endif
 
-static void do_queue_select(_adapter *padapter, struct pkt_attrib *pattrib);
 u32	rtw_get_ff_hwaddr(struct xmit_frame	*pxmitframe);
 
 #ifdef CONFIG_XMIT_ACK
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_hal.h
index 62e7f79d9506..39ae2c9ad745 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -46,4 +47,12 @@ void rtl8723ds_set_hal_ops(PADAPTER padapter);
 void rtl8188fs_set_hal_ops(PADAPTER padapter);
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+void rtl8188gtvs_set_hal_ops(PADAPTER padapter);
+#endif
+
+#ifdef CONFIG_RTL8192F
+void rtl8192fs_set_hal_ops(PADAPTER padapter);
+#endif
+
 #endif /* __SDIO_HAL_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops.h
index 95d34d6f06b2..81ff2d7dff1c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -146,6 +147,20 @@ extern void ClearInterrupt8723DSdio(PADAPTER padapter);
 #endif /* CONFIG_WOWLAN */
 #endif
 
+#ifdef CONFIG_RTL8192F
+extern void InitInterrupt8192FSdio(PADAPTER padapter);
+extern void InitSysInterrupt8192FSdio(PADAPTER padapter);
+extern void EnableInterrupt8192FSdio(PADAPTER padapter);
+extern void DisableInterrupt8192FSdio(PADAPTER padapter);
+extern void UpdateInterruptMask8192FSdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
+extern u8 HalQueryTxBufferStatus8192FSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8192FSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm2192fSdio(PADAPTER padapter);
+extern void ClearInterrupt8192FSdio(PADAPTER padapter);
+#endif /* CONFIG_WOWLAN */
+#endif
+
 #ifdef CONFIG_RTL8188F
 extern void InitInterrupt8188FSdio(PADAPTER padapter);
 extern void InitSysInterrupt8188FSdio(PADAPTER padapter);
@@ -159,4 +174,52 @@ extern void ClearInterrupt8188FSdio(PADAPTER padapter);
 #endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+extern void InitInterrupt8188GTVSdio(PADAPTER padapter);
+extern void InitSysInterrupt8188GTVSdio(PADAPTER padapter);
+extern void EnableInterrupt8188GTVSdio(PADAPTER padapter);
+extern void DisableInterrupt8188GTVSdio(PADAPTER padapter);
+extern u8 HalQueryTxBufferStatus8188GTVSdio(PADAPTER padapter);
+extern u8 HalQueryTxOQTBufferStatus8188GTVSdio(PADAPTER padapter);
+#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
+extern void DisableInterruptButCpwm28188GTVSdio(PADAPTER padapter);
+extern void ClearInterrupt8188GTVSdio(PADAPTER padapter);
+#endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
+#endif
+
+/**
+ * rtw_sdio_get_block_size() - Get block size of SDIO transfer
+ * @d		struct dvobj_priv*
+ *
+ * The unit of return value is byte.
+ */
+static inline u32 rtw_sdio_get_block_size(struct dvobj_priv *d)
+{
+	return d->intf_data.block_transfer_len;
+}
+
+/**
+ * rtw_sdio_cmd53_align_size() - Align size to one CMD53 could complete
+ * @d		struct dvobj_priv*
+ * @len		length to align
+ *
+ * Adjust len to align block size, and the new size could be transfered by one
+ * CMD53.
+ * If len < block size, it would keep original value, otherwise the value
+ * would be rounded up by block size.
+ *
+ * Return adjusted length.
+ */
+static inline size_t rtw_sdio_cmd53_align_size(struct dvobj_priv *d, size_t len)
+{
+	u32 blk_sz;
+
+
+	blk_sz = rtw_sdio_get_block_size(d);
+	if (len <= blk_sz)
+		return len;
+
+	return _RND(len, blk_sz);
+}
+
 #endif /* !__SDIO_OPS_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_ce.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_ce.h
index d542cb7ea206..b4e994bddd99 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_ce.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_ce.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_linux.h
index 4bbd8fe7ff68..bc0862fbc4a3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_linux.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_xp.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_xp.h
index d3d8764d3878..a00a25c38fbc 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_xp.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_ops_xp.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_osintf.h
index 7c2abd14d2af..dc271ad9bfc5 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sdio_osintf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sta_info.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sta_info.h
index 468f0f85aa68..e545445f79be 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sta_info.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/sta_info.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -29,14 +30,21 @@
 #endif
 
 #define NUM_ACL 16
+
+#define RTW_ACL_PERIOD_DEV 0
+#define RTW_ACL_PERIOD_BSS 1
+#define RTW_ACL_PERIOD_NUM 2
+
 #define RTW_ACL_MODE_DISABLED				0
 #define RTW_ACL_MODE_ACCEPT_UNLESS_LISTED	1
 #define RTW_ACL_MODE_DENY_UNLESS_LISTED		2
 #define RTW_ACL_MODE_MAX					3
 
 #if CONFIG_RTW_MACADDR_ACL
-extern const char *const _acl_mode_str[];
-#define acl_mode_str(mode) (((mode) >= RTW_ACL_MODE_MAX) ? _acl_mode_str[RTW_ACL_MODE_DISABLED] : _acl_mode_str[(mode)])
+extern const char *const _acl_period_str[RTW_ACL_PERIOD_NUM];
+#define acl_period_str(mode) (((mode) >= RTW_ACL_PERIOD_NUM) ? "INVALID" : _acl_period_str[(mode)])
+extern const char *const _acl_mode_str[RTW_ACL_MODE_MAX];
+#define acl_mode_str(mode) (((mode) >= RTW_ACL_MODE_MAX) ? "INVALID" : _acl_mode_str[(mode)])
 #endif
 
 #ifndef RTW_PRE_LINK_STA_NUM
@@ -89,29 +97,30 @@ struct wlan_acl_pool {
 };
 
 struct	stainfo_stats	{
+	systime last_rx_time;
 
 	u64 rx_mgnt_pkts;
-		u64 rx_beacon_pkts;
-		u64 rx_probereq_pkts;
-		u64 rx_probersp_pkts; /* unicast to self */
-		u64 rx_probersp_bm_pkts;
-		u64 rx_probersp_uo_pkts; /* unicast to others */
+	u64 rx_beacon_pkts;
+	u64 rx_probereq_pkts;
+	u64 rx_probersp_pkts; /* unicast to self */
+	u64 rx_probersp_bm_pkts;
+	u64 rx_probersp_uo_pkts; /* unicast to others */
 	u64 rx_ctrl_pkts;
 	u64 rx_data_pkts;
-		u64 rx_data_bc_pkts;
-		u64 rx_data_mc_pkts;
+	u64 rx_data_bc_pkts;
+	u64 rx_data_mc_pkts;
 	u64 rx_data_qos_pkts[TID_NUM]; /* unicast only */
 
 	u64	last_rx_mgnt_pkts;
-		u64 last_rx_beacon_pkts;
-		u64 last_rx_probereq_pkts;
-		u64 last_rx_probersp_pkts; /* unicast to self */
-		u64 last_rx_probersp_bm_pkts;
-		u64 last_rx_probersp_uo_pkts; /* unicast to others */
+	u64 last_rx_beacon_pkts;
+	u64 last_rx_probereq_pkts;
+	u64 last_rx_probersp_pkts; /* unicast to self */
+	u64 last_rx_probersp_bm_pkts;
+	u64 last_rx_probersp_uo_pkts; /* unicast to others */
 	u64	last_rx_ctrl_pkts;
 	u64	last_rx_data_pkts;
-		u64 last_rx_data_bc_pkts;
-		u64 last_rx_data_mc_pkts;
+	u64 last_rx_data_bc_pkts;
+	u64 last_rx_data_mc_pkts;
 	u64 last_rx_data_qos_pkts[TID_NUM]; /* unicast only */
 
 #ifdef CONFIG_TDLS
@@ -120,13 +129,14 @@ struct	stainfo_stats	{
 #endif
 
 	u64	rx_bytes;
-		u64	rx_bc_bytes;
-		u64	rx_mc_bytes;
+	u64	rx_bc_bytes;
+	u64	rx_mc_bytes;
 	u64	last_rx_bytes;
-		u64 last_rx_bc_bytes;
-		u64 last_rx_mc_bytes;
+	u64 last_rx_bc_bytes;
+	u64 last_rx_mc_bytes;
 	u64	rx_drops; /* TBD */
-	u16 rx_tp_mbytes;
+	u32 rx_tp_kbits;
+	u32 smooth_rx_tp_kbits;
 
 	u64	tx_pkts;
 	u64	last_tx_pkts;
@@ -134,7 +144,13 @@ struct	stainfo_stats	{
 	u64	tx_bytes;
 	u64	last_tx_bytes;
 	u64 tx_drops; /* TBD */
-	u16 tx_tp_mbytes;
+	u32 tx_tp_kbits;
+	u32 smooth_tx_tp_kbits;
+
+#ifdef CONFIG_LPS_CHK_BY_TP
+	u64 acc_tx_bytes;
+	u64 acc_rx_bytes;
+#endif
 
 	/* unicast only */
 	u64 last_rx_data_uc_pkts; /* For Read & Clear requirement in proc_get_rx_stat() */
@@ -143,6 +159,10 @@ struct	stainfo_stats	{
 	u32 tx_ok_cnt;		/* Read & Clear, in proc_get_tx_stat() */
 	u32 tx_fail_cnt;	/* Read & Clear, in proc_get_tx_stat() */
 	u32 tx_retry_cnt;	/* Read & Clear, in proc_get_tx_stat() */
+#ifdef CONFIG_RTW_MESH
+	u32 rx_hwmp_pkts;
+	u32 last_rx_hwmp_pkts;
+#endif
 };
 
 #ifndef DBG_SESSION_TRACKER
@@ -224,6 +244,21 @@ struct sta_recv_dframe_info {
 };
 #endif
 
+#ifdef CONFIG_RTW_MESH
+struct mesh_plink_ent;
+struct rtw_ewma_err_rate {
+	unsigned long internal;
+};
+
+/* Mesh airtime link metrics parameters */
+struct rtw_atlm_param {
+	struct rtw_ewma_err_rate err_rate; /* Now is PACKET error rate */
+	u16 data_rate; /* The unit is 100Kbps */
+	u16 total_pkt;
+	u16 overhead; /* Channel access overhead */
+};
+#endif
+
 struct sta_info {
 
 	_lock	lock;
@@ -260,17 +295,29 @@ struct sta_info {
 	union Keytype	dot11tkiprxmickey;
 	union Keytype	dot118021x_UncstKey;
 	union pn48		dot11txpn;			/* PN48 used for Unicast xmit */
+	union pn48		dot11rxpn;			/* PN48 used for Unicast recv. */
+#ifdef CONFIG_RTW_MESH
+	/* peer's GTK, RX only */
+	u8 group_privacy;
+	u8 gtk_bmp;
+	union Keytype gtk;
+	union pn48 gtk_pn;
+	#ifdef CONFIG_IEEE80211W
+	/* peer's IGTK, RX only */
+	u8 igtk_bmp;
+	u8 igtk_id;
+	union Keytype igtk;
+	union pn48 igtk_pn;
+	#endif /* CONFIG_IEEE80211W */
+#endif /* CONFIG_RTW_MESH */
 #ifdef CONFIG_GTK_OL
 	u8 kek[RTW_KEK_LEN];
 	u8 kck[RTW_KCK_LEN];
 	u8 replay_ctr[RTW_REPLAY_CTR_LEN];
 #endif /* CONFIG_GTK_OL */
 #ifdef CONFIG_IEEE80211W
-	union pn48		dot11wtxpn;			/* PN48 used for Unicast mgmt xmit. */
 	_timer dot11w_expire_timer;
 #endif /* CONFIG_IEEE80211W */
-	union pn48		dot11rxpn;			/* PN48 used for Unicast recv. */
-
 
 	u8	bssrateset[16];
 	u32	bssratelen;
@@ -421,6 +468,16 @@ struct sta_info {
 
 #endif /* CONFIG_AP_MODE	 */
 
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink;
+
+	u8 local_mps;
+	u8 peer_mps;
+	u8 nonpeer_mps;
+
+	struct rtw_atlm_param metrics;
+#endif
+
 #ifdef CONFIG_IOCTL_CFG80211
 	u8 *passoc_req;
 	u32 assoc_req_len;
@@ -438,8 +495,17 @@ struct sta_info {
 	u8 max_agg_num_minimal_record; /*keep minimal tx desc max_agg_num setting*/
 	u8 curr_rx_rate;
 	u8 curr_rx_rate_bmc;
+#ifdef CONFIG_RTS_FULL_BW
+	bool vendor_8812;
+#endif
 };
 
+#ifdef CONFIG_RTW_MESH
+#define STA_SET_MESH_PLINK(sta, link) (sta)->plink = link
+#else
+#define STA_SET_MESH_PLINK(sta, link) do {} while (0)
+#endif
+
 #define sta_tx_pkts(sta) \
 	(sta->sta_stats.tx_pkts)
 
@@ -504,6 +570,15 @@ struct sta_info {
 #define sta_last_rx_probersp_uo_pkts(sta) \
 	(sta->sta_stats.last_rx_probersp_uo_pkts)
 
+#ifdef CONFIG_RTW_MESH
+#define update_last_rx_hwmp_pkts(sta) \
+	do { \
+		sta->sta_stats.last_rx_hwmp_pkts = sta->sta_stats.rx_hwmp_pkts; \
+	} while(0)
+#else
+#define update_last_rx_hwmp_pkts(sta) do {} while(0)
+#endif
+
 #define sta_update_last_rx_pkts(sta) \
 	do { \
 		int __i; \
@@ -515,6 +590,7 @@ struct sta_info {
 		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; \
+		update_last_rx_hwmp_pkts(sta); \
 		\
 		sta->sta_stats.last_rx_data_pkts = sta->sta_stats.rx_data_pkts; \
 		sta->sta_stats.last_rx_data_bc_pkts = sta->sta_stats.rx_data_bc_pkts; \
@@ -551,6 +627,8 @@ struct sta_info {
 #define STA_SET_OP_WFD_MODE(sta, mode) do {} while (0)
 #endif
 
+#define AID_BMP_LEN(max_aid) ((max_aid + 1) / 8 + (((max_aid + 1) % 8) ? 1 : 0))
+
 struct	sta_priv {
 
 	u8 *pallocated_stainfo_buf;
@@ -579,19 +657,22 @@ struct	sta_priv {
 	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, staion aid bitmap for sleeping sta. */
-	u16 tim_bitmap;/* only support 15 stations, aid=0~15 mapping bit0~bit15	 */
+	/*
+	* 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
+	*/
+	struct sta_info **sta_aid;
+	u16 max_aid;
+	u16 started_aid; /* started AID for allocation search */
+	bool rr_aid; /* round robin AID allocation, will modify started_aid */
+	u8 aid_bmp_len; /* in byte */
+	u8 *sta_dz_bitmap;
+	u8 *tim_bitmap;
 
 	u16 max_num_sta;
 
 #if CONFIG_RTW_MACADDR_ACL
-	struct wlan_acl_pool acl_list;
+	struct wlan_acl_pool acl_list[RTW_ACL_PERIOD_NUM];
 #endif
 
 	#if CONFIG_RTW_PRE_LINK_STA
@@ -603,12 +684,13 @@ struct	sta_priv {
 #ifdef CONFIG_ATMEL_RC_PATCH
 	u8 atmel_rc_pattern[6];
 #endif
-	struct sta_info *c2h_sta;
+	u8 c2h_sta_mac[ETH_ALEN];
+	u8 c2h_adapter_id;
 	struct submit_ctx *gotc2h;
 };
 
 
-__inline static u32 wifi_mac_hash(u8 *mac)
+__inline static u32 wifi_mac_hash(const u8 *mac)
 {
 	u32 x;
 
@@ -633,15 +715,20 @@ extern u32	_rtw_free_sta_priv(struct sta_priv *pstapriv);
 int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta);
 struct sta_info *rtw_get_stainfo_by_offset(struct sta_priv *stapriv, int offset);
 
-extern struct sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr);
+extern struct sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, const u8 *hwaddr);
 extern u32	rtw_free_stainfo(_adapter *padapter , struct sta_info *psta);
 extern void rtw_free_all_stainfo(_adapter *padapter);
-extern struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, u8 *hwaddr);
+extern struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, const u8 *hwaddr);
 extern u32 rtw_init_bcmc_stainfo(_adapter *padapter);
 extern struct sta_info *rtw_get_bcmc_stainfo(_adapter *padapter);
 
+#ifdef CONFIG_AP_MODE
+u16 rtw_aid_alloc(_adapter *adapter, struct sta_info *sta);
+void dump_aid_status(void *sel, _adapter *adapter);
+#endif
+
 #if CONFIG_RTW_MACADDR_ACL
-extern u8 rtw_access_ctrl(_adapter *adapter, u8 *mac_addr);
+extern u8 rtw_access_ctrl(_adapter *adapter, const u8 *mac_addr);
 void dump_macaddr_acl(void *sel, _adapter *adapter);
 #endif
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_hal.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_hal.h
index a5af048b4198..f8bc2b64814f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_hal.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_hal.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -48,6 +49,10 @@ void rtl8814au_set_hal_ops(_adapter *padapter);
 void rtl8188fu_set_hal_ops(_adapter *padapter);
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+void rtl8188gtvu_set_hal_ops(_adapter *padapter);
+#endif
+
 #ifdef CONFIG_RTL8703B
 void rtl8703bu_set_hal_ops(_adapter *padapter);
 #endif
@@ -56,6 +61,14 @@ void rtl8703bu_set_hal_ops(_adapter *padapter);
 void rtl8723du_set_hal_ops(_adapter *padapter);
 #endif
 
+#ifdef CONFIG_RTL8710B
+void rtl8710bu_set_hal_ops(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTL8192F
+void rtl8192fu_set_hal_ops(_adapter *padapter);
+#endif /* CONFIG_RTL8192F */
+
 #ifdef CONFIG_INTEL_PROXIM
 extern _adapter  *rtw_usb_get_sw_pointer(void);
 #endif /* CONFIG_INTEL_PROXIM */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops.h
index a0238f142dd8..fa7d81958584 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -70,6 +71,13 @@ void interrupt_handler_8188fu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+void rtl8188gtvu_set_hw_type(struct dvobj_priv *pdvobj);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8188gtvu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif
+#endif
+
 #ifdef CONFIG_RTL8723B
 void rtl8723bu_set_hw_type(struct dvobj_priv *pdvobj);
 #ifdef CONFIG_SUPPORT_USB_INT
@@ -96,6 +104,24 @@ void interrupt_handler_8723du(_adapter *padapter, u16 pkt_len, u8 *pbuf);
 #endif /* CONFIG_SUPPORT_USB_INT */
 #endif /* CONFIG_RTL8723D */
 
+#ifdef CONFIG_RTL8710B
+void rtl8710bu_set_hw_type(struct dvobj_priv *pdvobj);
+void rtl8710bu_set_intf_ops(struct _io_ops *pops);
+void rtl8710bu_recv_tasklet(void *priv);
+void rtl8710bu_xmit_tasklet(void *priv);
+#ifdef CONFIG_SUPPORT_USB_INT
+void interrupt_handler_8710bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif /* CONFIG_SUPPORT_USB_INT */
+#endif /* CONFIG_RTL8710B */
+
+#ifdef CONFIG_RTL8192F
+void rtl8192fu_set_hw_type(struct dvobj_priv *pdvobj);
+void rtl8192fu_xmit_tasklet(void *priv);
+#ifdef CONFIG_SUPPORT_USB_INT
+void rtl8192fu_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf);
+#endif /* CONFIG_SUPPORT_USB_INT */
+#endif /* CONFIG_RTL8192F */
+
 enum RTW_USB_SPEED {
 	RTW_USB_SPEED_UNKNOWN	= 0,
 	RTW_USB_SPEED_1_1	= 1,
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops_linux.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops_linux.h
index bf59ca0fa51a..6ed3b29b9de2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops_linux.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_ops_linux.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_osintf.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_osintf.h
index 7e5feed174de..21e0391a5bbf 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_osintf.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_osintf.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_vendor_req.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_vendor_req.h
index a003bfb8cd2a..54972ead3114 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_vendor_req.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/usb_vendor_req.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wifi.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wifi.h
index 561eadbada6f..c2c21675ed82 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wifi.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wifi.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -17,11 +18,10 @@
 
 
 #ifndef BIT
-/* #error	"BIT define occurred earlier elsewhere!\n" */
-/* #undef BIT */
-#define BIT(x)  (1 << (x))
+#define BIT(x)	(1 << (x))
 #endif
 
+
 #define WLAN_ETHHDR_LEN		14
 #define WLAN_ETHADDR_LEN	6
 #define WLAN_IEEE_OUI_LEN	3
@@ -43,6 +43,7 @@
 #define WLAN_MAX_ETHFRM_LEN	1514
 #define WLAN_ETHHDR_LEN		14
 #define WLAN_WMM_LEN		24
+#define VENDOR_NAME_LEN		20
 
 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
 #define WLAN_MAX_VENDOR_IE_LEN 255
@@ -52,6 +53,13 @@
 #define WIFI_PROBERESP_VENDOR_IE_BIT BIT(2)
 #define WIFI_ASSOCREQ_VENDOR_IE_BIT BIT(3)
 #define WIFI_ASSOCRESP_VENDOR_IE_BIT BIT(4)
+#ifdef CONFIG_P2P
+#define WIFI_P2P_PROBEREQ_VENDOR_IE_BIT BIT(5)
+#define WIFI_P2P_PROBERESP_VENDOR_IE_BIT BIT(6)
+#define WLAN_MAX_VENDOR_IE_MASK_MAX 7
+#else
+#define WLAN_MAX_VENDOR_IE_MASK_MAX 5
+#endif
 #endif
 
 #define P80211CAPTURE_VERSION	0x80211001
@@ -91,6 +99,7 @@ enum WIFI_FRAME_SUBTYPE {
 	/* below is for control frame */
 	WIFI_BF_REPORT_POLL = (BIT(6) | WIFI_CTRL_TYPE),
 	WIFI_NDPA         = (BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
+	WIFI_BAR            = (BIT(7) | WIFI_CTRL_TYPE),
 	WIFI_PSPOLL         = (BIT(7) | BIT(5) | WIFI_CTRL_TYPE),
 	WIFI_RTS            = (BIT(7) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
 	WIFI_CTS            = (BIT(7) | BIT(6) | WIFI_CTRL_TYPE),
@@ -399,31 +408,26 @@ enum WIFI_REG_DOMAIN {
 	} while (0)
 
 
-#define SetPriority(pbuf, tid)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16(tid & 0xf); \
-	} while (0)
+/* QoS control field */
+#define SetPriority(qc, tid)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 0, 4, tid)
+#define SetEOSP(qc, eosp)		SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 4, 1, eosp)
+#define SetAckpolicy(qc, ack)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 5, 2, ack)
+#define SetAMsdu(qc, amsdu)		SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 7, 1, amsdu)
 
-#define GetPriority(pbuf)	((le16_to_cpu(*(unsigned short *)(pbuf))) & 0xf)
+#define GetPriority(qc)		LE_BITS_TO_2BYTE(((u8 *)(qc)), 0, 4)
+#define GetEOSP(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 4, 1)
+#define GetAckpolicy(qc)	LE_BITS_TO_2BYTE(((u8 *)(qc)), 5, 2)
+#define GetAMsdu(qc)		LE_BITS_TO_2BYTE(((u8 *)(qc)), 7, 1)
 
-#define SetEOSP(pbuf, eosp)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16((eosp & 1) << 4); \
-	} while (0)
+/* QoS control field (MSTA only) */
+#define set_mctrl_present(qc, p)	SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 8, 1, p)
+#define set_mps_lv(qc, lv)			SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 9, 1, lv)
+#define set_rspi(qc, rspi)			SET_BITS_TO_LE_2BYTE(((u8 *)(qc)), 10, 1, rspi)
 
-#define SetAckpolicy(pbuf, ack)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16((ack & 3) << 5); \
-	} while (0)
+#define get_mctrl_present(qc)	LE_BITS_TO_2BYTE(((u8 *)(qc)), 8, 1)
+#define get_mps_lv(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 9, 1)
+#define get_rspi(qc)			LE_BITS_TO_2BYTE(((u8 *)(qc)), 10, 1)
 
-#define GetAckpolicy(pbuf) (((le16_to_cpu(*(unsigned short *)pbuf)) >> 5) & 0x3)
-
-#define GetAMsdu(pbuf) (((le16_to_cpu(*(unsigned short *)pbuf)) >> 7) & 0x1)
-
-#define SetAMsdu(pbuf, amsdu)	\
-	do	{	\
-		*(unsigned short *)(pbuf) |= cpu_to_le16((amsdu & 1) << 7); \
-	} while (0)
 
 #define GetAid(pbuf)	(cpu_to_le16(*(unsigned short *)((SIZE_PTR)(pbuf) + 2)) & 0x3fff)
 
@@ -445,7 +449,7 @@ enum WIFI_REG_DOMAIN {
 	  (addr[4] == 0xff) && (addr[5] == 0xff)) ? _TRUE : _FALSE \
 	)
 
-__inline static int IS_MCAST(unsigned char *da)
+__inline static int IS_MCAST(const u8 *da)
 {
 	if ((*da) & 0x01)
 		return _TRUE;
@@ -757,9 +761,8 @@ typedef	enum _ELEMENT_ID {
 #define _WEP_WPA_MIXED_PRIVACY_ 6	/*  WEP + WPA */
 #endif
 
-#ifdef CONFIG_IEEE80211W
 #define _MME_IE_LENGTH_  18
-#endif /* CONFIG_IEEE80211W */
+
 /*-----------------------------------------------------------------------------
 				Below is the definition for WMM
 ------------------------------------------------------------------------------*/
@@ -1032,7 +1035,7 @@ typedef enum _HT_CAP_AMPDU_DENSITY {
  * According to IEEE802.11n spec size varies from 8K to 64K (in powers of 2)
  */
 #define IEEE80211_MIN_AMPDU_BUF 0x8
-#define IEEE80211_MAX_AMPDU_BUF 0x40
+#define IEEE80211_MAX_AMPDU_BUF_HT 0x40
 
 
 /* Spatial Multiplexing Power Save Modes */
@@ -1377,10 +1380,8 @@ enum P2P_PS_MODE {
 #define	WFD_DEVINFO_PC_TDLS					0x0080
 #define	WFD_DEVINFO_HDCP_SUPPORT			0x0100
 
-#ifdef CONFIG_TX_MCAST2UNI
 #define IP_MCAST_MAC(mac)		((mac[0] == 0x01) && (mac[1] == 0x00) && (mac[2] == 0x5e))
 #define ICMPV6_MCAST_MAC(mac)	((mac[0] == 0x33) && (mac[1] == 0x33) && (mac[2] != 0xff))
-#endif /* CONFIG_TX_MCAST2UNI */
 
 #ifdef CONFIG_IOCTL_CFG80211
 /* Regulatroy Domain */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wlan_bssdef.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wlan_bssdef.h
index 76408d1adf69..219e21a829f2 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wlan_bssdef.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/wlan_bssdef.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -25,7 +26,7 @@
 #define NDIS_802_11_LENGTH_RATES        8
 #define NDIS_802_11_LENGTH_RATES_EX     16
 
-typedef unsigned char   NDIS_802_11_MAC_ADDRESS[6];
+typedef unsigned char   NDIS_802_11_MAC_ADDRESS[ETH_ALEN];
 typedef long    		NDIS_802_11_RSSI;           /* in dBm */
 typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        /* Set of 8 data rates */
 typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  /* Set of 16 data rates */
@@ -77,6 +78,7 @@ typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE {
 	Ndis802_11InfrastructureMax,     /* Not a real value, defined as upper bound */
 	Ndis802_11APMode,
 	Ndis802_11Monitor,
+	Ndis802_11_mesh,
 } NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;
 
 
@@ -274,7 +276,7 @@ typedef struct _NDIS_802_11_TEST {
 #define NDIS_802_11_LENGTH_RATES        8
 #define NDIS_802_11_LENGTH_RATES_EX     16
 
-typedef unsigned char   NDIS_802_11_MAC_ADDRESS[6];
+typedef unsigned char   NDIS_802_11_MAC_ADDRESS[ETH_ALEN];
 typedef long    		NDIS_802_11_RSSI;           /* in dBm */
 typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        /* Set of 8 data rates */
 typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  /* Set of 16 data rates */
@@ -561,6 +563,7 @@ typedef struct _WLAN_BSSID_EX {
 	NDIS_802_11_MAC_ADDRESS  MacAddress;
 	UCHAR  Reserved[2];/* [0]: IS beacon frame , bss_type*/
 	NDIS_802_11_SSID  Ssid;
+	NDIS_802_11_SSID  mesh_id;
 	ULONG  Privacy;
 	NDIS_802_11_RSSI  Rssi;/* (in dBM,raw data ,get from PHY) */
 	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;
@@ -616,6 +619,12 @@ struct	wlan_network {
 	int	network_type;	/* refer to ieee80211.h for WIRELESS_11A/B/G */
 	int	fixed;			/* set to fixed when not to be removed as site-surveying */
 	systime last_scanned; /* timestamp for the network */
+#ifdef CONFIG_RTW_MESH
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	systime acnode_stime;
+	systime acnode_notify_etime;
+#endif
+#endif
 	int	aid;			/* will only be valid when a BSS is joinned. */
 	int	join_res;
 	WLAN_BSSID_EX	network; /* must be the last item */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/xmit_osdep.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/xmit_osdep.h
index 70070a890fa1..f9145d55f6d3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/xmit_osdep.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/include/xmit_osdep.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/custom_gpio_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/custom_gpio_linux.c
index 23401b7d6b7c..e46c4be2fde8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/custom_gpio_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/custom_gpio_linux.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.c
index 66c716ae3dd1..06fbfcb06eea 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -19,12 +20,27 @@
 
 #ifdef CONFIG_IOCTL_CFG80211
 
+#ifndef DBG_RTW_CFG80211_STA_PARAM
+#define DBG_RTW_CFG80211_STA_PARAM 0
+#endif
+
+#ifndef DBG_RTW_CFG80211_MESH_CONF
+#define DBG_RTW_CFG80211_MESH_CONF 0
+#endif
+
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 0, 0))
-#define STATION_INFO_SIGNAL		BIT(NL80211_STA_INFO_SIGNAL)
+#define STATION_INFO_INACTIVE_TIME	BIT(NL80211_STA_INFO_INACTIVE_TIME)
+#define STATION_INFO_LLID			BIT(NL80211_STA_INFO_LLID)
+#define STATION_INFO_PLID			BIT(NL80211_STA_INFO_PLID)
+#define STATION_INFO_PLINK_STATE	BIT(NL80211_STA_INFO_PLINK_STATE)
+#define STATION_INFO_SIGNAL			BIT(NL80211_STA_INFO_SIGNAL)
 #define STATION_INFO_TX_BITRATE		BIT(NL80211_STA_INFO_TX_BITRATE)
 #define STATION_INFO_RX_PACKETS		BIT(NL80211_STA_INFO_RX_PACKETS)
 #define STATION_INFO_TX_PACKETS		BIT(NL80211_STA_INFO_TX_PACKETS)
 #define STATION_INFO_TX_FAILED		BIT(NL80211_STA_INFO_TX_FAILED)
+#define STATION_INFO_LOCAL_PM		BIT(NL80211_STA_INFO_LOCAL_PM)
+#define STATION_INFO_PEER_PM		BIT(NL80211_STA_INFO_PEER_PM)
+#define STATION_INFO_NONPEER_PM		BIT(NL80211_STA_INFO_NONPEER_PM)
 #define STATION_INFO_ASSOC_REQ_IES	0
 #endif /* Linux kernel >= 4.0.0 */
 
@@ -59,10 +75,21 @@
 
 #endif /* CONFIG_WAPI_SUPPORT */
 
+#if (LINUX_VERSION_CODE <= KERNEL_VERSION(4, 11, 12))
 #ifdef CONFIG_RTW_80211R
 #define WLAN_AKM_SUITE_FT_8021X		0x000FAC03
 #define WLAN_AKM_SUITE_FT_PSK			0x000FAC04
 #endif
+#endif
+
+/*
+ * In the current design of Wi-Fi driver, it will return success to the system (e.g. supplicant) 
+ * when Wi-Fi driver decides to abort the scan request in the scan flow by default.
+ * Defining this flag makes Wi-Fi driver to return -EBUSY to the system if Wi-Fi driver is too busy to do the scan.
+ */
+#ifndef CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY
+	#define CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY 0
+#endif
 
 static const u32 rtw_cipher_suites[] = {
 	WLAN_CIPHER_SUITE_WEP40,
@@ -556,9 +583,110 @@ static const struct ieee80211_txrx_stypes
 			BIT(IEEE80211_STYPE_PROBE_REQ >> 4)
 	},
 #endif
+#if defined(CONFIG_RTW_MESH)
+	[NL80211_IFTYPE_MESH_POINT] = {
+		.tx = 0xffff,
+		.rx = BIT(IEEE80211_STYPE_ACTION >> 4)
+			| BIT(IEEE80211_STYPE_AUTH >> 4)
+	},
+#endif
+
 };
 #endif
 
+NDIS_802_11_NETWORK_INFRASTRUCTURE nl80211_iftype_to_rtw_network_type(enum nl80211_iftype type)
+{
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		return Ndis802_11IBSS;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	#endif
+	case NL80211_IFTYPE_STATION:
+		return Ndis802_11Infrastructure;
+
+#ifdef CONFIG_AP_MODE
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+	#endif
+	case NL80211_IFTYPE_AP:
+		return Ndis802_11APMode;
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		return Ndis802_11_mesh;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		return Ndis802_11Monitor;
+
+	default:
+		return Ndis802_11InfrastructureMax;
+	}
+}
+
+u32 nl80211_iftype_to_rtw_mlme_state(enum nl80211_iftype type)
+{
+	switch (type) {
+	case NL80211_IFTYPE_ADHOC:
+		return WIFI_ADHOC_STATE;
+
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_CLIENT:
+	#endif
+	case NL80211_IFTYPE_STATION:
+		return WIFI_STATION_STATE;
+
+#ifdef CONFIG_AP_MODE
+	#if defined(CONFIG_P2P) && ((LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE))
+	case NL80211_IFTYPE_P2P_GO:
+	#endif
+	case NL80211_IFTYPE_AP:
+		return WIFI_AP_STATE;
+#endif
+
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		return WIFI_MESH_STATE;
+#endif
+
+	case NL80211_IFTYPE_MONITOR:
+		return WIFI_MONITOR_STATE;
+
+	default:
+		return WIFI_NULL_STATE;
+	}
+}
+
+static int rtw_cfg80211_sync_iftype(_adapter *adapter)
+{
+	struct wireless_dev *rtw_wdev = adapter->rtw_wdev;
+
+	if (!(nl80211_iftype_to_rtw_mlme_state(rtw_wdev->iftype) & MLME_STATE(adapter))) {
+		/* iftype and mlme state is not syc */
+		NDIS_802_11_NETWORK_INFRASTRUCTURE network_type;
+
+		network_type = nl80211_iftype_to_rtw_network_type(rtw_wdev->iftype);
+		if (network_type != Ndis802_11InfrastructureMax) {
+			if (rtw_pwr_wakeup(adapter) == _FAIL) {
+				RTW_WARN(FUNC_ADPT_FMT" call rtw_pwr_wakeup fail\n", FUNC_ADPT_ARG(adapter));
+				return _FAIL;
+			}
+
+			rtw_set_802_11_infrastructure_mode(adapter, network_type);
+			rtw_setopmode_cmd(adapter, network_type, RTW_CMDF_WAIT_ACK);
+		} else {
+			rtw_warn_on(1);
+			RTW_WARN(FUNC_ADPT_FMT" iftype:%u is not support\n", FUNC_ADPT_ARG(adapter), rtw_wdev->iftype);
+			return _FAIL;
+		}
+	}
+
+	return _SUCCESS;
+}
+
 static u64 rtw_get_systime_us(void)
 {
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39))
@@ -575,7 +703,6 @@ static u64 rtw_get_systime_us(void)
 /* Try to remove non target BSS's SR to reduce PBC overlap rate */
 static int rtw_cfg80211_clear_wps_sr_of_non_target_bss(_adapter *padapter, struct wlan_network *pnetwork, struct cfg80211_ssid *req_ssid)
 {
-	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(padapter);
 	int ret = 0;
 	u8 *psr = NULL, sr = 0;
 	NDIS_802_11_SSID *pssid = &pnetwork->network.Ssid;
@@ -816,7 +943,6 @@ void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter)
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
 	struct wireless_dev *pwdev = padapter->rtw_wdev;
-	struct cfg80211_bss *bss = NULL;
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
 	struct wiphy *wiphy = pwdev->wiphy;
 	int freq = 2412;
@@ -825,13 +951,6 @@ void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter)
 
 	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
-	freq = rtw_ch2freq(cur_network->network.Configuration.DSConfig);
-
-	if (0)
-		RTW_INFO("chan: %d, freq: %d\n", cur_network->network.Configuration.DSConfig, freq);
-#endif
-
 	if (pwdev->iftype != NL80211_IFTYPE_ADHOC)
 		return;
 
@@ -874,6 +993,9 @@ void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter)
 	}
 	/* notify cfg80211 that device joined an IBSS */
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 15, 0))
+	freq = rtw_ch2freq(cur_network->network.Configuration.DSConfig);
+	if (1)
+		RTW_INFO("chan: %d, freq: %d\n", cur_network->network.Configuration.DSConfig, freq);
 	notify_channel = ieee80211_get_channel(wiphy, freq);
 	cfg80211_ibss_joined(padapter->pnetdev, cur_network->network.MacAddress, notify_channel, GFP_ATOMIC);
 #else
@@ -891,8 +1013,6 @@ void rtw_cfg80211_indicate_connect(_adapter *padapter)
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 #endif
-	struct cfg80211_bss *bss = NULL;
-
 #if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
 	struct cfg80211_roam_info roam_info ={};
 #endif
@@ -990,8 +1110,8 @@ check_bss:
 		RTW_INFO(FUNC_ADPT_FMT" call cfg80211_roamed\n", FUNC_ADPT_ARG(padapter));
 
 #ifdef CONFIG_RTW_80211R
-		if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED))
-			rtw_set_ft_status(padapter, RTW_FT_ASSOCIATED_STA);
+		if (rtw_ft_roam(padapter))
+			rtw_ft_set_status(padapter, RTW_FT_ASSOCIATED_STA);
 #endif
 	} else {
 		#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 11, 0) || defined(COMPAT_KERNEL_RELEASE)
@@ -1017,7 +1137,6 @@ check_bss:
 
 void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)
 {
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct wireless_dev *pwdev = padapter->rtw_wdev;
 	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
 	_irqL irqL;
@@ -1028,7 +1147,7 @@ void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally
 	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
 
 	/*always replace privated definitions with wifi reserved value 0*/
-	if ((reason == WLAN_REASON_ACTIVE_ROAM) || (reason == WLAN_REASON_JOIN_WRONG_CHANNEL) || (reason == WLAN_REASON_EXPIRATION_CHK))
+	if (WLAN_REASON_IS_PRIVATE(reason))
 		reason = 0;
 
 	if (pwdev->iftype != NL80211_IFTYPE_STATION
@@ -1067,7 +1186,7 @@ void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally
 		if (pwdev->sme_state == CFG80211_SME_CONNECTING) {
 			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_connect_result\n", FUNC_ADPT_ARG(padapter));
 			rtw_cfg80211_connect_result(pwdev, NULL, NULL, 0, NULL, 0,
-				WLAN_STATUS_UNSPECIFIED_FAILURE, GFP_ATOMIC);
+				reason, GFP_ATOMIC);
 		} else if (pwdev->sme_state == CFG80211_SME_CONNECTED) {
 			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
 			rtw_cfg80211_disconnected(pwdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
@@ -1078,7 +1197,7 @@ void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally
 		if (pwdev_priv->connect_req) {
 			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_connect_result\n", FUNC_ADPT_ARG(padapter));
 			rtw_cfg80211_connect_result(pwdev, NULL, NULL, 0, NULL, 0,
-				WLAN_STATUS_UNSPECIFIED_FAILURE, GFP_ATOMIC);
+				reason, GFP_ATOMIC);
 		} else {
 			RTW_INFO(FUNC_ADPT_FMT" call cfg80211_disconnected\n", FUNC_ADPT_ARG(padapter));
 			rtw_cfg80211_disconnected(pwdev, reason, NULL, 0, locally_generated, GFP_ATOMIC);
@@ -1093,13 +1212,13 @@ void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally
 
 
 #ifdef CONFIG_AP_MODE
-static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
+static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_param *param)
 {
 	int ret = 0;
-	u32 wep_key_idx, wep_key_len, wep_total_len;
+	u32 wep_key_idx, wep_key_len;
 	struct sta_info *psta = NULL, *pbcmc_sta = NULL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
+	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct security_priv *psecuritypriv = &(padapter->securitypriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
@@ -1108,20 +1227,11 @@ static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_pa
 	param->u.crypt.err = 0;
 	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
 
-	/* sizeof(struct ieee_param) = 64 bytes; */
-	/* if (param_len !=  (u32) ((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len) */
-	if (param_len !=  sizeof(struct ieee_param) + param->u.crypt.key_len) {
-		ret =  -EINVAL;
-		goto exit;
-	}
-
-	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
-	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) {
+	if (is_broadcast_mac_addr(param->sta_addr)) {
 		if (param->u.crypt.idx >= WEP_KEYS
-#ifdef CONFIG_IEEE80211W
+			#ifdef CONFIG_IEEE80211W
 			&& param->u.crypt.idx > BIP_MAX_KEYID
-#endif /* CONFIG_IEEE80211W */
+			#endif
 		) {
 			ret = -EINVAL;
 			goto exit;
@@ -1129,8 +1239,9 @@ static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_pa
 	} else {
 		psta = rtw_get_stainfo(pstapriv, param->sta_addr);
 		if (!psta) {
-			/* ret = -EINVAL; */
-			RTW_INFO("rtw_set_encryption(), sta has already been removed or never been added\n");
+			ret = -EINVAL;
+			RTW_INFO(FUNC_ADPT_FMT", sta "MAC_FMT" not found\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(param->sta_addr));
 			goto exit;
 		}
 	}
@@ -1186,76 +1297,64 @@ static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_pa
 
 	}
 
-
-	if (!psta && check_fwstate(pmlmepriv, WIFI_AP_STATE)) { /* group key */
-		if (param->u.crypt.set_tx == 0) { /* group key */
+	if (!psta) { /* group key */
+		if (param->u.crypt.set_tx == 0) { /* group key, TX only */
 			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
-				RTW_INFO("%s, set group_key, WEP\n", __FUNCTION__);
-
+				RTW_INFO(FUNC_ADPT_FMT" set WEP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
 				psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
 				if (param->u.crypt.key_len == 13)
 					psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
 
 			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
-				RTW_INFO("%s, set group_key, TKIP\n", __FUNCTION__);
-
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
-
 				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
-				/* DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len); */
 				/* set mic key */
 				_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
 				_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
-
 				psecuritypriv->busetkipkey = _TRUE;
 
 			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
-				RTW_INFO("%s, set group_key, CCMP\n", __FUNCTION__);
-
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				psecuritypriv->dot118021XGrpPrivacy = _AES_;
-
 				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-			}
-#ifdef CONFIG_IEEE80211W
-			else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
-				int no;
 
-				RTW_INFO("BIP key_len=%d , index=%d\n", param->u.crypt.key_len, param->u.crypt.idx);
-				/* save the IGTK key, length 16 bytes */
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TX IGTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-				/* RTW_INFO("IGTK key below:\n");
-				for(no=0;no<16;no++)
-					printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-				RTW_INFO("\n"); */
 				padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
+				psecuritypriv->dot11wBIPtxpn.val = RTW_GET_LE64(param->u.crypt.seq);
 				padapter->securitypriv.binstallBIPkey = _TRUE;
-				RTW_INFO(" ~~~~set sta key:IGKT\n");
 				goto exit;
-			}
-#endif /* CONFIG_IEEE80211W */
-			else {
-				RTW_INFO("%s, set group_key, none\n", __FUNCTION__);
+			#endif /* CONFIG_IEEE80211W */
 
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key, idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx);
 				psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key, not support\n"
+					, FUNC_ADPT_ARG(padapter));
+				goto exit;
 			}
 
 			psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
-			psecuritypriv->binstallGrpkey = _TRUE;
-
-			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
-
-			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
-
 			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
 			if (pbcmc_sta) {
+				pbcmc_sta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
 				pbcmc_sta->ieee8021x_blocked = _FALSE;
 				pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
 			}
+			psecuritypriv->binstallGrpkey = _TRUE;
+			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
 
+			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
 		}
 
 		goto exit;
@@ -1263,102 +1362,113 @@ static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_pa
 	}
 
 	if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) { /* psk/802_1x */
-		if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-			if (param->u.crypt.set_tx == 1) { /* pairwise key */
-				_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
-				if (strcmp(param->u.crypt.alg, "WEP") == 0) {
-					RTW_INFO("%s, set pairwise key, WEP\n", __FUNCTION__);
-
-					psta->dot118021XPrivacy = _WEP40_;
-					if (param->u.crypt.key_len == 13)
-						psta->dot118021XPrivacy = _WEP104_;
-				} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
-					RTW_INFO("%s, set pairwise key, TKIP\n", __FUNCTION__);
-
-					psta->dot118021XPrivacy = _TKIP_;
-
-					/* DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len); */
-					/* set mic key */
-					_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
-					_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
-					psecuritypriv->busetkipkey = _TRUE;
-
-				} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
-
-					RTW_INFO("%s, set pairwise key, CCMP\n", __FUNCTION__);
+		if (param->u.crypt.set_tx == 1) {
+			/* pairwise key */
+			_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
 
-					psta->dot118021XPrivacy = _AES_;
-				} else {
-					RTW_INFO("%s, set pairwise key, none\n", __FUNCTION__);
+			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set WEP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _WEP40_;
+				if (param->u.crypt.key_len == 13)
+					psta->dot118021XPrivacy = _WEP104_;
 
-					psta->dot118021XPrivacy = _NO_PRIVACY_;
-				}
+			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _TKIP_;
+				/* set mic key */
+				_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
+				_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
+				psecuritypriv->busetkipkey = _TRUE;
 
-				rtw_ap_set_pairwise_key(padapter, psta);
+			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP PTK of "MAC_FMT" idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->dot118021XPrivacy = _AES_;
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear pairwise key of "MAC_FMT" idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx);
+				psta->dot118021XPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set pairwise key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
+			}
 
-				psta->ieee8021x_blocked = _FALSE;
+			psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+			psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+			psta->ieee8021x_blocked = _FALSE;
 
+			if (psta->dot118021XPrivacy != _NO_PRIVACY_) {
 				psta->bpairwise_key_installed = _TRUE;
 
-			} else { /* group key??? */
-				if (strcmp(param->u.crypt.alg, "WEP") == 0) {
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
-					psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-					if (param->u.crypt.key_len == 13)
-						psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-				} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
-					psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
-
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
-					/* DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len); */
-					/* set mic key */
-					_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
-					_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
-
-					psecuritypriv->busetkipkey = _TRUE;
-
-				} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
-					psecuritypriv->dot118021XGrpPrivacy = _AES_;
-
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-				} else
-					psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
-
-				psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
-				psecuritypriv->binstallGrpkey = _TRUE;
-
-				psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
-
-				rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
-
-				pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
-				if (pbcmc_sta) {
-					pbcmc_sta->ieee8021x_blocked = _FALSE;
-					pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
-				}
+				/* WPA2 key-handshake has completed */
+				if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK)
+					psta->state &= (~WIFI_UNDER_KEY_HANDSHAKE);
+			}
 
+			rtw_ap_set_pairwise_key(padapter, psta);
+		} else {
+			/* peer's group key, RX only */
+			#ifdef CONFIG_RTW_MESH
+			if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP GTK of "MAC_FMT", idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				psta->group_privacy = _AES_;
+				_rtw_memcpy(psta->gtk.skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psta->gtk_bmp |= BIT(param->u.crypt.idx);
+				psta->gtk_pn.val = RTW_GET_LE64(param->u.crypt.seq);
+
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set IGTK of "MAC_FMT", idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx, param->u.crypt.key_len);
+				_rtw_memcpy(psta->igtk.skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
+				psta->igtk_bmp |= BIT(param->u.crypt.idx);
+				psta->igtk_id = param->u.crypt.idx;
+				psta->igtk_pn.val = RTW_GET_LE64(param->u.crypt.seq);
+				goto exit;
+			#endif /* CONFIG_IEEE80211W */
+
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key of "MAC_FMT", idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+					, param->u.crypt.idx);
+				psta->group_privacy = _NO_PRIVACY_;
+				psta->gtk_bmp &= ~BIT(param->u.crypt.idx);
+			} else
+			#endif /* CONFIG_RTW_MESH */
+			{
+				RTW_WARN(FUNC_ADPT_FMT" set group key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
 			}
 
+			#ifdef CONFIG_RTW_MESH
+			rtw_ap_set_sta_key(padapter, psta->cmn.mac_addr, psta->group_privacy
+				, param->u.crypt.key, param->u.crypt.idx, 1);
+			#endif
 		}
 
 	}
 
 exit:
-
 	return ret;
-
 }
-#endif
+#endif /* CONFIG_AP_MODE */
 
-static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
+static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param *param)
 {
 	int ret = 0;
-	u32 wep_key_idx, wep_key_len, wep_total_len;
+	u32 wep_key_idx, wep_key_len;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
@@ -1366,24 +1476,16 @@ static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param
 	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
 #endif /* CONFIG_P2P */
 
-
 	RTW_INFO("%s\n", __func__);
 
 	param->u.crypt.err = 0;
 	param->u.crypt.alg[IEEE_CRYPT_ALG_NAME_LEN - 1] = '\0';
 
-	if (param_len < (u32)((u8 *) param->u.crypt.key - (u8 *) param) + param->u.crypt.key_len) {
-		ret =  -EINVAL;
-		goto exit;
-	}
-
-	if (param->sta_addr[0] == 0xff && param->sta_addr[1] == 0xff &&
-	    param->sta_addr[2] == 0xff && param->sta_addr[3] == 0xff &&
-	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff) {
+	if (is_broadcast_mac_addr(param->sta_addr)) {
 		if (param->u.crypt.idx >= WEP_KEYS
-#ifdef CONFIG_IEEE80211W
+			#ifdef CONFIG_IEEE80211W
 			&& param->u.crypt.idx > BIP_MAX_KEYID
-#endif /* CONFIG_IEEE80211W */
+			#endif
 		) {
 			ret = -EINVAL;
 			goto exit;
@@ -1404,7 +1506,7 @@ static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param
 		wep_key_idx = param->u.crypt.idx;
 		wep_key_len = param->u.crypt.key_len;
 
-		if ((wep_key_idx > WEP_KEYS) || (wep_key_len <= 0)) {
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
 			ret = -EINVAL;
 			goto exit;
 		}
@@ -1443,7 +1545,7 @@ static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param
 
 		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_MP_STATE) == _TRUE) { /* sta mode */
 #ifdef CONFIG_RTW_80211R
-			if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_flags(padapter, RTW_FT_SUPPORTED))
+			if (rtw_ft_roam(padapter))
 				psta = rtw_get_stainfo(pstapriv, pmlmepriv->assoc_bssid);
 			else
 #endif
@@ -1456,34 +1558,31 @@ static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param
 				if (strcmp(param->u.crypt.alg, "none") != 0)
 					psta->ieee8021x_blocked = _FALSE;
 
-
 				if ((padapter->securitypriv.ndisencryptstatus == Ndis802_11Encryption2Enabled) ||
 				    (padapter->securitypriv.ndisencryptstatus ==  Ndis802_11Encryption3Enabled))
 					psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
 
 				if (param->u.crypt.set_tx == 1) { /* pairwise key */
-
-					RTW_INFO("%s, : param->u.crypt.set_tx ==1\n", __func__);
-
+					RTW_INFO(FUNC_ADPT_FMT" set %s PTK idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
 					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
 					if (strcmp(param->u.crypt.alg, "TKIP") == 0) { /* set mic key */
-						/* DEBUG_ERR(("\nset key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len)); */
 						_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
 						_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
 						padapter->securitypriv.busetkipkey = _FALSE;
 					}
+					psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
 					psta->bpairwise_key_installed = _TRUE;
-#ifdef CONFIG_RTW_80211R
+					#ifdef CONFIG_RTW_80211R
 					psta->ft_pairwise_key_installed = _TRUE;
-#endif
-					/* DEBUG_ERR((" param->u.crypt.key_len=%d\n",param->u.crypt.key_len)); */
-					RTW_INFO(" ~~~~set sta key:unicastkey\n");
-
+					#endif
 					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
+
 				} else { /* group key */
 					if (strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set %s GTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
 						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,
 							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
 						_rtw_memcpy(padapter->securitypriv.dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
@@ -1491,29 +1590,21 @@ static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param
 						padapter->securitypriv.binstallGrpkey = _TRUE;
 						if (param->u.crypt.idx < 4) 
 							_rtw_memcpy(padapter->securitypriv.iv_seq[param->u.crypt.idx], param->u.crypt.seq, 8);							
-
-						/* DEBUG_ERR((" param->u.crypt.key_len=%d\n", param->u.crypt.key_len)); */
-						RTW_INFO(" ~~~~set sta key:groupkey\n");
-
 						padapter->securitypriv.dot118021XGrpKeyid = param->u.crypt.idx;
 						rtw_set_key(padapter, &padapter->securitypriv, param->u.crypt.idx, 1, _TRUE);
-					}
-#ifdef CONFIG_IEEE80211W
-					else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
-						int no;
-						/* RTW_INFO("BIP key_len=%d , index=%d @@@@@@@@@@@@@@@@@@\n", param->u.crypt.key_len, param->u.crypt.idx); */
-						/* save the IGTK key, length 16 bytes */
+
+					#ifdef CONFIG_IEEE80211W
+					} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set IGTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,
 							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-						/*RTW_INFO("IGTK key below:\n");
-						for(no=0;no<16;no++)
-							printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-						RTW_INFO("\n");*/
-						padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
-						padapter->securitypriv.binstallBIPkey = _TRUE;
-						RTW_INFO(" ~~~~set sta key:IGKT\n");
+						psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+						psecuritypriv->dot11wBIPrxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+						psecuritypriv->binstallBIPkey = _TRUE;
+					#endif /* CONFIG_IEEE80211W */
+
 					}
-#endif /* CONFIG_IEEE80211W */
 
 #ifdef CONFIG_P2P
 					if (pwdinfo->driver_interface == DRIVER_CFG80211) {
@@ -1522,6 +1613,9 @@ static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param
 					}
 #endif /* CONFIG_P2P */
 
+					/* WPA/WPA2 key-handshake has completed */
+					clr_fwstate(pmlmepriv, WIFI_UNDER_KEY_HANDSHAKE);
+
 				}
 			}
 
@@ -1541,64 +1635,10 @@ static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param
 		}
 	}
 
-#ifdef CONFIG_WAPI_SUPPORT
-	if (strcmp(param->u.crypt.alg, "SMS4") == 0) {
-		PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
-		PRT_WAPI_STA_INFO	pWapiSta;
-		u8					WapiASUEPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
-		u8					WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
-		u8					WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
-
-		if (param->u.crypt.set_tx == 1) {
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if (_rtw_memcmp(pWapiSta->PeerMacAddr, param->sta_addr, 6)) {
-					_rtw_memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
-
-					pWapiSta->wapiUsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiUsk.dataKey, param->u.crypt.key, 16);
-					_rtw_memcpy(pWapiSta->wapiUsk.micKey, param->u.crypt.key + 16, 16);
-					pWapiSta->wapiUsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiUsk.bTxEnable = true;
-
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
-					pWapiSta->wapiUskUpdate.bTxEnable = false;
-					pWapiSta->wapiUskUpdate.bSet = false;
-
-					if (psecuritypriv->sw_encrypt == false || psecuritypriv->sw_decrypt == false) {
-						/* set unicast key for ASUE */
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiUsk, pWapiSta, false, false);
-					}
-				}
-			}
-		} else {
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if (_rtw_memcmp(pWapiSta->PeerMacAddr, get_bssid(pmlmepriv), 6)) {
-					pWapiSta->wapiMsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiMsk.dataKey, param->u.crypt.key, 16);
-					_rtw_memcpy(pWapiSta->wapiMsk.micKey, param->u.crypt.key + 16, 16);
-					pWapiSta->wapiMsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiMsk.bTxEnable = false;
-					if (!pWapiSta->bSetkeyOk)
-						pWapiSta->bSetkeyOk = true;
-					pWapiSta->bAuthenticateInProgress = false;
-
-					_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
-
-					if (psecuritypriv->sw_decrypt == false) {
-						/* set rx broadcast key for ASUE */
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiMsk, pWapiSta, true, false);
-					}
-				}
-
-			}
-		}
-	}
-#endif
-
+	#ifdef CONFIG_WAPI_SUPPORT
+	if (strcmp(param->u.crypt.alg, "SMS4") == 0)
+		rtw_wapi_set_set_encryption(padapter, param);
+	#endif
 
 exit:
 
@@ -1608,13 +1648,12 @@ exit:
 	return ret;
 }
 
-static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev,
+static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev
+	, u8 key_index
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
-	u8 key_index, bool pairwise, const u8 *mac_addr,
-#else	/* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
-	u8 key_index, const u8 *mac_addr,
-#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
-	struct key_params *params)
+	, bool pairwise
+#endif
+	, const u8 *mac_addr, struct key_params *params)
 {
 	char *alg_name;
 	u32 param_len;
@@ -1627,17 +1666,21 @@ static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev,
 	struct sta_info *ptdls_sta;
 #endif /* CONFIG_TDLS */
 
-	RTW_INFO(FUNC_NDEV_FMT" adding key for %pM\n", FUNC_NDEV_ARG(ndev), mac_addr);
-	RTW_INFO("cipher=0x%x\n", params->cipher);
-	RTW_INFO("key_len=0x%x\n", params->key_len);
-	RTW_INFO("seq_len=0x%x\n", params->seq_len);
-	RTW_INFO("key_index=%d\n", key_index);
+	if (mac_addr)
+		RTW_INFO(FUNC_NDEV_FMT" adding key for %pM\n", FUNC_NDEV_ARG(ndev), mac_addr);
+	RTW_INFO(FUNC_NDEV_FMT" cipher=0x%x\n", FUNC_NDEV_ARG(ndev), params->cipher);
+	RTW_INFO(FUNC_NDEV_FMT" key_len=%d, key_index=%d\n", FUNC_NDEV_ARG(ndev), params->key_len, key_index);
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
-	RTW_INFO("pairwise=%d\n", pairwise);
-#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
+	RTW_INFO(FUNC_NDEV_FMT" pairwise=%d\n", FUNC_NDEV_ARG(ndev), pairwise);
+#endif
+
+	if (rtw_cfg80211_sync_iftype(padapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto addkey_end;
+	}
 
 	param_len = sizeof(struct ieee_param) + params->key_len;
-	param = (struct ieee_param *)rtw_malloc(param_len);
+	param = rtw_malloc(param_len);
 	if (param == NULL)
 		return -1;
 
@@ -1690,18 +1733,23 @@ static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev,
 	strncpy((char *)param->u.crypt.alg, alg_name, IEEE_CRYPT_ALG_NAME_LEN);
 
 
-	if (!mac_addr || is_broadcast_ether_addr(mac_addr)) {
+	if (!mac_addr || is_broadcast_ether_addr(mac_addr)
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		|| !pairwise
+		#endif
+	) {
 		param->u.crypt.set_tx = 0; /* for wpa/wpa2 group key */
 	} else {
 		param->u.crypt.set_tx = 1; /* for wpa/wpa2 pairwise key */
 	}
 
-
-	/* param->u.crypt.idx = key_index - 1; */
 	param->u.crypt.idx = key_index;
 
-	if (params->seq_len && params->seq)
+	if (params->seq_len && params->seq) {
 		_rtw_memcpy(param->u.crypt.seq, (u8 *)params->seq, params->seq_len);
+		RTW_INFO(FUNC_NDEV_FMT" seq_len:%u, seq:0x%llx\n", FUNC_NDEV_ARG(ndev)
+			, params->seq_len, RTW_GET_LE64(param->u.crypt.seq));
+	}
 
 	if (params->key_len && params->key) {
 		param->u.crypt.key_len = params->key_len;
@@ -1719,66 +1767,198 @@ static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev,
 			}
 		}
 #endif /* CONFIG_TDLS */
-
-		ret =  rtw_cfg80211_set_encryption(ndev, param, param_len);
-	} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
+		ret = rtw_cfg80211_set_encryption(ndev, param);
+	} else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
 #ifdef CONFIG_AP_MODE
 		if (mac_addr)
 			_rtw_memcpy(param->sta_addr, (void *)mac_addr, ETH_ALEN);
 
-		ret = rtw_cfg80211_ap_set_encryption(ndev, param, param_len);
+		ret = rtw_cfg80211_ap_set_encryption(ndev, param);
 #endif
 	} else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE
 		|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE
 	) {
 		/* RTW_INFO("@@@@@@@@@@ fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype); */
-		ret =  rtw_cfg80211_set_encryption(ndev, param, param_len);
+		ret = rtw_cfg80211_set_encryption(ndev, param);
 	} else
 		RTW_INFO("error! fw_state=0x%x, iftype=%d\n", pmlmepriv->fw_state, rtw_wdev->iftype);
 
 
 addkey_end:
 	if (param)
-		rtw_mfree((u8 *)param, param_len);
+		rtw_mfree(param, param_len);
 
 	return ret;
 
 }
 
-static int cfg80211_rtw_get_key(struct wiphy *wiphy, struct net_device *ndev,
+static int cfg80211_rtw_get_key(struct wiphy *wiphy, struct net_device *ndev
+	, u8 keyid
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
-	u8 key_index, bool pairwise, const u8 *mac_addr,
-#else	/* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
-	u8 key_index, const u8 *mac_addr,
-#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
-	void *cookie,
-	void (*callback)(void *cookie, struct key_params *))
+	, bool pairwise
+#endif
+	, const u8 *mac_addr, void *cookie
+	, void (*callback)(void *cookie, struct key_params *))
 {
-#if 0
-	struct iwm_priv *iwm = ndev_to_iwm(ndev);
-	struct iwm_key *key = &iwm->keys[key_index];
-	struct key_params params;
+#define GET_KEY_PARAM_FMT_S " keyid=%d"
+#define GET_KEY_PARAM_ARG_S , keyid
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	#define GET_KEY_PARAM_FMT_2_6_37 ", pairwise=%d"
+	#define GET_KEY_PARAM_ARG_2_6_37 , pairwise
+#else
+	#define GET_KEY_PARAM_FMT_2_6_37 ""
+	#define GET_KEY_PARAM_ARG_2_6_37
+#endif
+#define GET_KEY_PARAM_FMT_E ", addr=%pM"
+#define GET_KEY_PARAM_ARG_E , mac_addr
 
-	IWM_DBG_WEXT(iwm, DBG, "Getting key %d\n", key_index);
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct security_priv *sec = &adapter->securitypriv;
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta = NULL;
+	u32 cipher = _NO_PRIVACY_;
+	union Keytype *key = NULL;
+	u8 key_len = 0;
+	u64 *pn = NULL;
+	u8 pn_len = 0;
+	u8 pn_val[8] = {0};
 
-	memset(&params, 0, sizeof(params));
+	struct key_params params;
+	int ret = -ENOENT;
 
-	params.cipher = key->cipher;
-	params.key_len = key->key_len;
-	params.seq_len = key->seq_len;
-	params.seq = key->seq;
-	params.key = key->key;
+	if (keyid >= WEP_KEYS
+		#ifdef CONFIG_IEEE80211W
+		&& keyid > BIP_MAX_KEYID
+		#endif
+	)
+		goto exit;
 
-	callback(cookie, &params);
+	if (!mac_addr || is_broadcast_ether_addr(mac_addr)
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+		|| (MLME_IS_STA(adapter) && !pairwise)
+		#endif
+	) {	
+		/* WEP key, TX GTK/IGTK, RX GTK/IGTK(for STA mode) */
+		if (is_wep_enc(sec->dot118021XGrpPrivacy)) {
+			if (keyid >= WEP_KEYS)
+				goto exit;
+			if (!(sec->key_mask & BIT(keyid)))
+				goto exit;
+			cipher = sec->dot118021XGrpPrivacy;
+			key = &sec->dot11DefKey[keyid];
+		} else {
+			if (keyid < WEP_KEYS) {
+				if (sec->binstallGrpkey != _TRUE)
+					goto exit;
+				cipher = sec->dot118021XGrpPrivacy;
+				key = &sec->dot118021XGrpKey[keyid];
+				sta = rtw_get_bcmc_stainfo(adapter);
+				if (sta)
+					pn = &sta->dot11txpn.val;
+			#ifdef CONFIG_IEEE80211W
+			} else if (keyid < BIP_MAX_KEYID) {
+				if (SEC_IS_BIP_KEY_INSTALLED(sec) != _TRUE)
+					goto exit;
+				cipher = _BIP_;
+				key = &sec->dot11wBIPKey[keyid];
+				pn = &sec->dot11wBIPtxpn.val;
+			#endif
+			}
+		}
+	} else {
+		/* Pairwise key, RX GTK/IGTK for specific peer */
+		sta = rtw_get_stainfo(stapriv, mac_addr);
+		if (!sta)
+			goto exit;
 
-	return key->key_len ? 0 : -ENOENT;
-#endif
-	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-	return 0;
-}
+		if (keyid < WEP_KEYS && pairwise) {
+			if (sta->bpairwise_key_installed != _TRUE)
+				goto exit;
+			cipher = sta->dot118021XPrivacy;
+			key = &sta->dot118021x_UncstKey;
+		#ifdef CONFIG_RTW_MESH
+		} else if (keyid < WEP_KEYS && !pairwise) {
+			if (!(sta->gtk_bmp & BIT(keyid)))
+				goto exit;
+			cipher = sta->group_privacy;
+			key = &sta->gtk;
+		#ifdef CONFIG_IEEE80211W
+		} else if (keyid < BIP_MAX_KEYID && !pairwise) {
+			if (!(sta->igtk_bmp & BIT(keyid)))
+				goto exit;
+			cipher = _BIP_;
+			key = &sta->igtk;
+			pn = &sta->igtk_pn.val;
+		#endif
+		#endif /* CONFIG_RTW_MESH */
+		}
+	}
 
-static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	if (!key)
+		goto exit;
+
+	if (cipher == _WEP40_) {
+		cipher = WLAN_CIPHER_SUITE_WEP40;
+		key_len = sec->dot11DefKeylen[keyid];
+	} else if (cipher == _WEP104_) {
+		cipher = WLAN_CIPHER_SUITE_WEP104;
+		key_len = sec->dot11DefKeylen[keyid];
+	} else if (cipher == _TKIP_) {
+		cipher = WLAN_CIPHER_SUITE_TKIP;
+		key_len = 16;
+	} else if (cipher == _AES_) {
+		cipher = WLAN_CIPHER_SUITE_CCMP;
+		key_len = 16;
+	#ifdef CONFIG_IEEE80211W
+	} else if (cipher == _BIP_) {
+		cipher = WLAN_CIPHER_SUITE_AES_CMAC;
+		key_len = 16;
+	#endif
+	} else {
+		RTW_WARN(FUNC_NDEV_FMT" unknown cipher:%u\n", FUNC_NDEV_ARG(ndev), cipher);
+		rtw_warn_on(1);
+		goto exit;
+	}
+
+	if (pn) {
+		*((u64 *)pn_val) = cpu_to_le64(*pn);
+		pn_len = 6;
+	}
+
+	ret = 0;
+	
+exit:
+	RTW_INFO(FUNC_NDEV_FMT
+		GET_KEY_PARAM_FMT_S
+		GET_KEY_PARAM_FMT_2_6_37
+		GET_KEY_PARAM_FMT_E
+		" ret %d\n", FUNC_NDEV_ARG(ndev)
+		GET_KEY_PARAM_ARG_S
+		GET_KEY_PARAM_ARG_2_6_37
+		GET_KEY_PARAM_ARG_E
+		, ret);
+	if (pn)
+		RTW_INFO(FUNC_NDEV_FMT " seq:0x%llx\n", FUNC_NDEV_ARG(ndev), *pn);
+
+	if (ret == 0) {
+		_rtw_memset(&params, 0, sizeof(params));
+
+		params.cipher = cipher;
+		params.key = key->skey;
+		params.key_len = key_len;
+		if (pn) {
+			params.seq = pn_val;
+			params.seq_len = pn_len;
+		}
+
+		callback(cookie, &params);
+	}
+
+	return ret;
+}
+
+static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
 				u8 key_index, bool pairwise, const u8 *mac_addr)
 #else	/* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) */
 				u8 key_index, const u8 *mac_addr)
@@ -1787,7 +1967,7 @@ static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 
-	RTW_INFO(FUNC_NDEV_FMT" key_index=%d\n", FUNC_NDEV_ARG(ndev), key_index);
+	RTW_INFO(FUNC_NDEV_FMT" key_index=%d, addr=%pM\n", FUNC_NDEV_ARG(ndev), key_index, mac_addr);
 
 	if (key_index == psecuritypriv->dot11PrivacyKeyIndex) {
 		/* clear the flag of wep default key set. */
@@ -1843,6 +2023,24 @@ static int cfg80211_rtw_set_default_key(struct wiphy *wiphy,
 	return 0;
 
 }
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 30))
+int cfg80211_rtw_set_default_mgmt_key(struct wiphy *wiphy,
+	struct net_device *ndev, u8 key_index)
+{
+#define SET_DEF_KEY_PARAM_FMT " key_index=%d"
+#define SET_DEF_KEY_PARAM_ARG , key_index
+
+	RTW_INFO(FUNC_NDEV_FMT
+		SET_DEF_KEY_PARAM_FMT
+		"\n", FUNC_NDEV_ARG(ndev)
+		SET_DEF_KEY_PARAM_ARG
+	);
+
+	return 0;
+}
+#endif
+
 #if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
 static int cfg80211_rtw_set_rekey_data(struct wiphy *wiphy,
 	struct net_device *ndev,
@@ -1878,6 +2076,101 @@ static int cfg80211_rtw_set_rekey_data(struct wiphy *wiphy,
 	return 0;
 }
 #endif /*CONFIG_GTK_OL*/
+
+#ifdef CONFIG_RTW_MESH
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+static enum nl80211_mesh_power_mode rtw_mesh_ps_to_nl80211_mesh_power_mode(u8 ps)
+{
+	if (ps == RTW_MESH_PS_UNKNOWN)
+		return NL80211_MESH_POWER_UNKNOWN;
+	if (ps == RTW_MESH_PS_ACTIVE)
+		return NL80211_MESH_POWER_ACTIVE;
+	if (ps == RTW_MESH_PS_LSLEEP)
+		return NL80211_MESH_POWER_LIGHT_SLEEP;
+	if (ps == RTW_MESH_PS_DSLEEP)
+		return NL80211_MESH_POWER_DEEP_SLEEP;
+
+	rtw_warn_on(1);
+	return NL80211_MESH_POWER_UNKNOWN;
+}
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+enum nl80211_plink_state rtw_plink_state_to_nl80211_plink_state(u8 plink_state)
+{
+	if (plink_state == RTW_MESH_PLINK_UNKNOWN)
+		return NUM_NL80211_PLINK_STATES;
+	if (plink_state == RTW_MESH_PLINK_LISTEN)
+		return NL80211_PLINK_LISTEN;
+	if (plink_state == RTW_MESH_PLINK_OPN_SNT)
+		return NL80211_PLINK_OPN_SNT;
+	if (plink_state == RTW_MESH_PLINK_OPN_RCVD)
+		return NL80211_PLINK_OPN_RCVD;
+	if (plink_state == RTW_MESH_PLINK_CNF_RCVD)
+		return NL80211_PLINK_CNF_RCVD;
+	if (plink_state == RTW_MESH_PLINK_ESTAB)
+		return NL80211_PLINK_ESTAB;
+	if (plink_state == RTW_MESH_PLINK_HOLDING)
+		return NL80211_PLINK_HOLDING;
+	if (plink_state == RTW_MESH_PLINK_BLOCKED)
+		return NL80211_PLINK_BLOCKED;
+
+	rtw_warn_on(1);
+	return NUM_NL80211_PLINK_STATES;
+}
+
+u8 nl80211_plink_state_to_rtw_plink_state(enum nl80211_plink_state plink_state)
+{
+	if (plink_state == NL80211_PLINK_LISTEN)
+		return RTW_MESH_PLINK_LISTEN;
+	if (plink_state == NL80211_PLINK_OPN_SNT)
+		return RTW_MESH_PLINK_OPN_SNT;
+	if (plink_state == NL80211_PLINK_OPN_RCVD)
+		return RTW_MESH_PLINK_OPN_RCVD;
+	if (plink_state == NL80211_PLINK_CNF_RCVD)
+		return RTW_MESH_PLINK_CNF_RCVD;
+	if (plink_state == NL80211_PLINK_ESTAB)
+		return RTW_MESH_PLINK_ESTAB;
+	if (plink_state == NL80211_PLINK_HOLDING)
+		return RTW_MESH_PLINK_HOLDING;
+	if (plink_state == NL80211_PLINK_BLOCKED)
+		return RTW_MESH_PLINK_BLOCKED;
+
+	rtw_warn_on(1);
+	return RTW_MESH_PLINK_UNKNOWN;
+}
+#endif
+
+static void rtw_cfg80211_fill_mesh_only_sta_info(struct mesh_plink_ent *plink, struct sta_info *sta, struct station_info *sinfo)
+{
+	sinfo->filled |= STATION_INFO_LLID;
+	sinfo->llid = plink->llid;
+	sinfo->filled |= STATION_INFO_PLID;
+	sinfo->plid = plink->plid;
+	sinfo->filled |= STATION_INFO_PLINK_STATE;
+	sinfo->plink_state = rtw_plink_state_to_nl80211_plink_state(plink->plink_state);
+	if (!sta && plink->scanned) {
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(plink->scanned->network.PhyInfo.SignalStrength);
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		if (plink->plink_state == RTW_MESH_PLINK_UNKNOWN)
+			sinfo->inactive_time = 0 - 1;
+		else
+			sinfo->inactive_time = rtw_get_passing_time_ms(plink->scanned->last_scanned);
+	}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (sta) {
+		sinfo->filled |= STATION_INFO_LOCAL_PM;
+		sinfo->local_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->local_mps);
+		sinfo->filled |= STATION_INFO_PEER_PM;
+		sinfo->peer_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->peer_mps);
+		sinfo->filled |= STATION_INFO_NONPEER_PM;
+		sinfo->nonpeer_pm = rtw_mesh_ps_to_nl80211_mesh_power_mode(sta->nonpeer_mps);
+	}
+#endif
+}
+#endif /* CONFIG_RTW_MESH */
+
 static int cfg80211_rtw_get_station(struct wiphy *wiphy,
 	struct net_device *ndev,
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
@@ -1892,6 +2185,9 @@ static int cfg80211_rtw_get_station(struct wiphy *wiphy,
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct sta_info *psta = NULL;
 	struct sta_priv *pstapriv = &padapter->stapriv;
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink = NULL;
+#endif
 
 	sinfo->filled = 0;
 
@@ -1901,9 +2197,23 @@ static int cfg80211_rtw_get_station(struct wiphy *wiphy,
 		goto exit;
 	}
 
-	psta = rtw_get_stainfo(pstapriv, (u8 *)mac);
-	if (psta == NULL) {
-		RTW_INFO("%s, sta_info is null\n", __func__);
+	psta = rtw_get_stainfo(pstapriv, mac);
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (psta)
+			plink = psta->plink;
+		if (!plink)
+			plink = rtw_mesh_plink_get(padapter, mac);
+	}
+#endif /* CONFIG_RTW_MESH */
+
+	if ((!MLME_IS_MESH(padapter) && !psta)
+		#ifdef CONFIG_RTW_MESH
+		|| (MLME_IS_MESH(padapter) && !plink)
+		#endif
+	) {
+		RTW_INFO(FUNC_NDEV_FMT" no sta info for mac="MAC_FMT"\n"
+			, FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
 		ret = -ENOENT;
 		goto exit;
 	}
@@ -1929,26 +2239,29 @@ static int cfg80211_rtw_get_station(struct wiphy *wiphy,
 
 		sinfo->filled |= STATION_INFO_TX_BITRATE;
 		sinfo->txrate.legacy = rtw_get_cur_max_rate(padapter);
+	}
 
+	if (psta) {
+		if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE
+			|| check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE
+		) {
+			sinfo->filled |= STATION_INFO_SIGNAL;
+			sinfo->signal = translate_percentage_to_dbm(psta->cmn.rssi_stat.rssi);
+		}
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		sinfo->inactive_time = rtw_get_passing_time_ms(psta->sta_stats.last_rx_time);
 		sinfo->filled |= STATION_INFO_RX_PACKETS;
 		sinfo->rx_packets = sta_rx_data_pkts(psta);
-
 		sinfo->filled |= STATION_INFO_TX_PACKETS;
 		sinfo->tx_packets = psta->sta_stats.tx_pkts;
-
-        sinfo->filled |= STATION_INFO_TX_FAILED;
-        sinfo->tx_failed = psta->sta_stats.tx_fail_cnt;
-
+		sinfo->filled |= STATION_INFO_TX_FAILED;
+		sinfo->tx_failed = psta->sta_stats.tx_fail_cnt;
 	}
 
-	/* 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... */
-	}
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_cfg80211_fill_mesh_only_sta_info(plink, psta, sinfo);
+#endif
 
 exit:
 	return ret;
@@ -1989,6 +2302,9 @@ static int cfg80211_rtw_change_iface(struct wiphy *wiphy,
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 	u8 is_p2p = _FALSE;
+#endif
+#ifdef CONFIG_MONITOR_MODE_XMIT
+	struct mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 #endif
 	int ret = 0;
 	u8 change = _FALSE;
@@ -2091,6 +2407,12 @@ static int cfg80211_rtw_change_iface(struct wiphy *wiphy,
 
 		break;
 
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+		networkType = Ndis802_11_mesh;
+		break;
+#endif
+
 	case NL80211_IFTYPE_MONITOR:
 		networkType = Ndis802_11Monitor;
 #if 0
@@ -2111,8 +2433,11 @@ static int cfg80211_rtw_change_iface(struct wiphy *wiphy,
 		goto exit;
 	}
 
-	rtw_setopmode_cmd(padapter, networkType, _TRUE);
-
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
+#ifdef CONFIG_MONITOR_MODE_XMIT
+	if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE)
+		rtw_indicate_connect(padapter);
+#endif
 exit:
 
 	RTW_INFO(FUNC_NDEV_FMT" ret:%d\n", FUNC_NDEV_ARG(ndev), ret);
@@ -2238,17 +2563,17 @@ exit:
 
 static void _rtw_cfg80211_surveydone_event_callback(_adapter *padapter, struct cfg80211_scan_request *scan_req)
 {
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	RT_CHANNEL_INFO *chset = rfctl->channel_set;
 	_irqL	irqL;
 	_list					*plist, *phead;
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	_queue				*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
-	u32 cnt = 0;
-	u32 wait_for_surveydone;
-	sint wait_status;
 	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
 	struct cfg80211_ssid target_ssid;
 	u8 target_wps_scan = 0;
+	u8 ch;
 
 #ifdef CONFIG_DEBUG_CFG80211
 	RTW_INFO("%s\n", __func__);
@@ -2273,11 +2598,15 @@ static void _rtw_cfg80211_surveydone_event_callback(_adapter *padapter, struct c
 			break;
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		ch = pnetwork->network.Configuration.DSConfig;
 
 		/* report network only if the current channel set contains the channel to which this network belongs */
-		if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
-			&& rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
+		if (rtw_chset_search_ch(chset, ch) >= 0
+			&& rtw_mlme_band_check(padapter, ch) == _TRUE
 			&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
+			&& (!IS_DFS_SLAVE_WITH_RD(rfctl)
+				|| rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
+				|| !rtw_chset_is_ch_non_ocp(chset, ch))
 		) {
 			if (target_wps_scan)
 				rtw_cfg80211_clear_wps_sr_of_non_target_bss(padapter, pnetwork, &target_ssid);
@@ -2478,10 +2807,11 @@ void rtw_cfg80211_indicate_scan_done_for_buddy(_adapter *padapter, bool bscan_ab
 
 			indicate_buddy_scan = _FALSE;
 			_enter_critical_bh(&wdev_priv->scan_req_lock, &irqL);
-			if (wdev_priv->scan_request && mlmepriv->scanning_via_buddy_intf == _TRUE) {
+			if (mlmepriv->scanning_via_buddy_intf == _TRUE) {
 				mlmepriv->scanning_via_buddy_intf = _FALSE;
 				clr_fwstate(mlmepriv, _FW_UNDER_SURVEY);
-				indicate_buddy_scan = _TRUE;
+				if (wdev_priv->scan_request)
+					indicate_buddy_scan = _TRUE;
 			}
 			_exit_critical_bh(&wdev_priv->scan_req_lock, &irqL);
 
@@ -2501,26 +2831,22 @@ static int cfg80211_rtw_scan(struct wiphy *wiphy
 	#endif
 	, struct cfg80211_scan_request *request)
 {
-	int i, chan_num = 0;
+	int i;
 	u8 _status = _FALSE;
 	int ret = 0;
 	struct sitesurvey_parm parm;
 	_irqL	irqL;
-	u8 *wps_ie = NULL;
-	uint wps_ielen = 0;
-	u8 *p2p_ie = NULL;
-	uint p2p_ielen = 0;
 	u8 survey_times = 3;
 	u8 survey_times_for_one_ch = 6;
 	struct cfg80211_ssid *ssids = request->ssids;
 	int social_channel = 0, j = 0;
 	bool need_indicate_scan_done = _FALSE;
 	bool ps_denied = _FALSE;
-
+	u8 ssc_chk;
 	_adapter *padapter;
 	struct wireless_dev *wdev;
 	struct rtw_wdev_priv *pwdev_priv;
-	struct mlme_priv *pmlmepriv;
+	struct mlme_priv *pmlmepriv = NULL;
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo;
 #endif /* CONFIG_P2P */
@@ -2556,26 +2882,103 @@ static int cfg80211_rtw_scan(struct wiphy *wiphy
 	RTW_INFO(FUNC_ADPT_FMT"%s\n", FUNC_ADPT_ARG(padapter)
 		, wdev == wiphy_to_pd_wdev(wiphy) ? " PD" : "");
 
-#ifdef CONFIG_MP_INCLUDED
-	if (rtw_mp_mode_check(padapter)) {
-		RTW_INFO("MP mode block Scan request\n");
-		ret = -EPERM;
-		goto exit;
-	}
+#if 1
+	ssc_chk = rtw_sitesurvey_condition_check(padapter, _TRUE);
+
+	if (ssc_chk == SS_DENY_MP_MODE)
+		goto bypass_p2p_chk;
+#ifdef DBG_LA_MODE
+	if (ssc_chk == SS_DENY_LA_MODE)
+		goto bypass_p2p_chk;
 #endif
+#ifdef CONFIG_P2P
+	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
+		if (ssids->ssid != NULL
+			&& _rtw_memcmp(ssids->ssid, "DIRECT-", 7)
+			&& rtw_get_p2p_ie((u8 *)request->ie, request->ie_len, NULL, NULL)
+		) {
+			if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
+				rtw_p2p_enable(padapter, P2P_ROLE_DEVICE);
+			else {
+				rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
+				#ifdef CONFIG_DEBUG_CFG80211
+				RTW_INFO("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
+				#endif
+			}
+			rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
 
-#ifdef CONFIG_RTW_REPEATER_SON
-	if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
-		RTW_INFO(FUNC_ADPT_FMT" blocking scan for under rson scanning process\n", FUNC_ADPT_ARG(padapter));
-		need_indicate_scan_done = _TRUE;
-		goto check_need_indicate_scan_done;
+			if (request->n_channels == 3 &&
+				request->channels[0]->hw_value == 1 &&
+				request->channels[1]->hw_value == 6 &&
+				request->channels[2]->hw_value == 11
+			)
+				social_channel = 1;
+		}
 	}
-#endif
+#endif /*CONFIG_P2P*/
 
-	if (adapter_wdev_data(padapter)->block_scan == _TRUE) {
-		RTW_INFO(FUNC_ADPT_FMT" wdev_priv.block_scan is set\n", FUNC_ADPT_ARG(padapter));
-		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);
+
+bypass_p2p_chk:
+
+	switch (ssc_chk) {
+		case SS_ALLOW :
+			break;
+
+		case SS_DENY_MP_MODE:
+			ret = -EPERM;
+			goto exit;
+		#ifdef DBG_LA_MODE
+		case SS_DENY_LA_MODE:
+			ret = -EPERM;
+			goto exit;
+		#endif
+		#ifdef CONFIG_RTW_REPEATER_SON
+		case SS_DENY_RSON_SCANING :
+		#endif
+		case SS_DENY_BLOCK_SCAN :
+		case SS_DENY_SELF_AP_UNDER_WPS :
+		case SS_DENY_SELF_AP_UNDER_LINKING :
+		case SS_DENY_SELF_AP_UNDER_SURVEY :
+		case SS_DENY_SELF_STA_UNDER_SURVEY :
+		#ifdef CONFIG_CONCURRENT_MODE
+		case SS_DENY_BUDDY_UNDER_LINK_WPS :
+		#endif
+		case SS_DENY_BUSY_TRAFFIC :
+			need_indicate_scan_done = _TRUE;
+			goto check_need_indicate_scan_done;
+
+		case SS_DENY_BY_DRV :
+			#if CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY
+			ret = -EBUSY;
+			goto exit;
+			#else
+			need_indicate_scan_done = _TRUE;
+			goto check_need_indicate_scan_done;
+			#endif
+			break;
+
+		case SS_DENY_SELF_STA_UNDER_LINKING :
+			ret = -EBUSY;
+			goto check_need_indicate_scan_done;
+
+		#ifdef CONFIG_CONCURRENT_MODE
+		case SS_DENY_BUDDY_UNDER_SURVEY :
+			{
+				bool scan_via_buddy = rtw_cfg80211_scan_via_buddy(padapter, request);
+
+				if (scan_via_buddy == _FALSE)
+					need_indicate_scan_done = _TRUE;
+
+				goto check_need_indicate_scan_done;
+			}
+		#endif
+
+		default :
+			RTW_ERR("site survey check code (%d) unknown\n", ssc_chk);
+			need_indicate_scan_done = _TRUE;
+			goto check_need_indicate_scan_done;
 	}
 
 	rtw_ps_deny(padapter, PS_DENY_SCAN);
@@ -2585,6 +2988,17 @@ static int cfg80211_rtw_scan(struct wiphy *wiphy
 		goto check_need_indicate_scan_done;
 	}
 
+#else
+
+
+#ifdef CONFIG_MP_INCLUDED
+	if (rtw_mp_mode_check(padapter)) {
+		RTW_INFO("MP mode block Scan request\n");
+		ret = -EPERM;
+		goto exit;
+	}
+#endif
+
 #ifdef CONFIG_P2P
 	if (pwdinfo->driver_interface == DRIVER_CFG80211) {
 		if (ssids->ssid != NULL
@@ -2614,10 +3028,36 @@ static int cfg80211_rtw_scan(struct wiphy *wiphy
 	if (request->ie && request->ie_len > 0)
 		rtw_cfg80211_set_probe_req_wpsp2pie(padapter, (u8 *)request->ie, request->ie_len);
 
+#ifdef CONFIG_RTW_REPEATER_SON
+	if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
+		RTW_INFO(FUNC_ADPT_FMT" blocking scan for under rson scanning process\n", FUNC_ADPT_ARG(padapter));
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+#endif
+
+	if (adapter_wdev_data(padapter)->block_scan == _TRUE) {
+		RTW_INFO(FUNC_ADPT_FMT" wdev_priv.block_scan is set\n", FUNC_ADPT_ARG(padapter));
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	ps_denied = _TRUE;
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		need_indicate_scan_done = _TRUE;
+		goto check_need_indicate_scan_done;
+	}
+
 	if (rtw_is_scan_deny(padapter)) {
 		RTW_INFO(FUNC_ADPT_FMT	": scan deny\n", FUNC_ADPT_ARG(padapter));
+#if CONFIG_NOTIFY_SCAN_ABORT_WITH_BUSY
+		ret = -EBUSY;
+		goto exit;
+#else
 		need_indicate_scan_done = _TRUE;
 		goto check_need_indicate_scan_done;
+#endif
 	}
 
 	/* check fw state*/
@@ -2669,11 +3109,11 @@ static int cfg80211_rtw_scan(struct wiphy *wiphy
 		need_indicate_scan_done = _TRUE;
 		goto check_need_indicate_scan_done;
 	}
+#endif
 
 #ifdef CONFIG_P2P
 	if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
 		rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
-		rtw_free_network_queue(padapter, _TRUE);
 
 		if (social_channel == 0)
 			rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
@@ -2747,8 +3187,10 @@ cancel_ps_deny:
 		rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
 
 exit:
-	return ret;
+	if (pmlmepriv)
+		pmlmepriv->lastscantime = rtw_get_current_time();
 
+	return ret;
 }
 
 static int cfg80211_rtw_set_wiphy_params(struct wiphy *wiphy, u32 changed)
@@ -2957,8 +3399,8 @@ static int rtw_cfg80211_set_key_mgt(struct security_priv *psecuritypriv, u32 key
 static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)
 {
 	u8 *buf = NULL, *pos = NULL;
-	u32 left;
 	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
 	int ret = 0;
 	int wpa_ielen = 0;
 	int wpa2_ielen = 0;
@@ -2984,13 +3426,8 @@ static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)
 
 	_rtw_memcpy(buf, pie , ielen);
 
-	/* dump */
-	{
-		int i;
-		RTW_INFO("set wpa_ie(length:%zu):\n", ielen);
-		for (i = 0; i < ielen; i = i + 8)
-			RTW_INFO("0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x 0x%.2x\n", buf[i], buf[i + 1], buf[i + 2], buf[i + 3], buf[i + 4], buf[i + 5], buf[i + 6], buf[i + 7]);
-	}
+	RTW_INFO("set wpa_ie(length:%zu):\n", ielen);
+	RTW_INFO_DUMP(NULL, buf, ielen);
 
 	pos = buf;
 	if (ielen < RSN_HEADER_LEN) {
@@ -3011,7 +3448,7 @@ static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)
 
 	pwpa2 = rtw_get_wpa2_ie(buf, &wpa2_ielen, ielen);
 	if (pwpa2 && wpa2_ielen > 0) {
-		if (rtw_parse_wpa2_ie(pwpa2, wpa2_ielen + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+		if (rtw_parse_wpa2_ie(pwpa2, wpa2_ielen + 2, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
 			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
 			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK;
 			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &pwpa2[0], wpa2_ielen + 2);
@@ -3071,6 +3508,13 @@ static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)
 		break;
 	}
 
+	if (mfp_opt == MFP_INVALID) {
+		RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+		ret = -EINVAL;
+		goto exit;
+	}
+	padapter->securitypriv.mfp_opt = mfp_opt;
+
 	{/* handle wps_ie */
 		uint wps_ielen;
 		u8 *wps_ie;
@@ -3157,10 +3601,7 @@ static int cfg80211_rtw_join_ibss(struct wiphy *wiphy, struct net_device *ndev,
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
 	NDIS_802_11_SSID ndis_ssid;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-	struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
-	WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
 	struct cfg80211_chan_def *pch_def;
 #endif
@@ -3233,13 +3674,14 @@ static int cfg80211_rtw_leave_ibss(struct wiphy *wiphy, struct net_device *ndev)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
 	struct wireless_dev *rtw_wdev = padapter->rtw_wdev;
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
 	enum nl80211_iftype old_type;
 	int ret = 0;
 
 	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
 
-	rtw_wdev_set_not_indic_disco(pwdev_priv, 1);
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 1);
+#endif
 
 	old_type = rtw_wdev->iftype;
 
@@ -3256,12 +3698,62 @@ static int cfg80211_rtw_leave_ibss(struct wiphy *wiphy, struct net_device *ndev)
 			ret = -EPERM;
 			goto leave_ibss;
 		}
-		rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, _TRUE);
+		rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
 	}
 
 leave_ibss:
-	rtw_wdev_set_not_indic_disco(pwdev_priv, 0);
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 0);
+#endif
+
+	return 0;
+}
+
+bool rtw_cfg80211_is_connect_requested(_adapter *adapter)
+{
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+	_irqL irqL;
+	bool requested;
+
+	_enter_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+	requested = pwdev_priv->connect_req ? 1 : 0;
+	_exit_critical_bh(&pwdev_priv->connect_req_lock, &irqL);
+
+	return requested;
+}
+
+static int _rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev)
+{
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+
+
+	/* if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)) */
+	{
+		rtw_scan_abort(padapter);
+		rtw_join_abort_timeout(padapter, 300);
+		LeaveAllPowerSaveMode(padapter);
+		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
+#ifdef CONFIG_RTW_REPEATER_SON
+		rtw_rson_do_disconnect(padapter);
+#endif
+		RTW_INFO("%s...call rtw_indicate_disconnect\n", __func__);
+
+		rtw_free_assoc_resources_cmd(padapter, _TRUE, RTW_CMDF_WAIT_ACK);
+
+		/* indicate locally_generated = 0 when suspend */
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
+		rtw_indicate_disconnect(padapter, 0, wiphy->dev.power.is_prepared ? _FALSE : _TRUE);
+		#else
+		/*
+		* for kernel < 4.2, DISCONNECT event is hardcoded with
+		* NL80211_ATTR_DISCONNECTED_BY_AP=1 in NL80211 layer
+		* no need to judge if under suspend
+		*/
+		rtw_indicate_disconnect(padapter, 0, _TRUE);
+		#endif
 
+		rtw_pwr_wakeup(padapter);
+	}
 	return 0;
 }
 
@@ -3269,35 +3761,37 @@ static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,
 				struct cfg80211_connect_params *sme)
 {
 	int ret = 0;
-	struct wlan_network *pnetwork = NULL;
 	NDIS_802_11_AUTHENTICATION_MODE authmode;
 	NDIS_802_11_SSID ndis_ssid;
-	u8 *dst_ssid, *src_ssid;
-	u8 *dst_bssid, *src_bssid;
 	/* u8 matched_by_bssid=_FALSE; */
 	/* u8 matched_by_ssid=_FALSE; */
-	u8 matched = _FALSE;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
-	_queue *queue = &pmlmepriv->scanned_queue;
-	struct wireless_dev *pwdev = padapter->rtw_wdev;
 	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	_irqL irqL;
 
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT)
 	rtw_wdev_set_not_indic_disco(pwdev_priv, 1);
+#endif
 
 	RTW_INFO("=>"FUNC_NDEV_FMT" - Start to Connection\n", FUNC_NDEV_ARG(ndev));
 	RTW_INFO("privacy=%d, key=%p, key_len=%d, key_idx=%d, auth_type=%d\n",
 		sme->privacy, sme->key, sme->key_len, sme->key_idx, sme->auth_type);
 
-
 	if (pwdev_priv->block == _TRUE) {
 		ret = -EBUSY;
 		RTW_INFO("%s wdev_priv.block is set\n", __FUNCTION__);
 		goto exit;
 	}
 
+       if (check_fwstate(pmlmepriv, _FW_LINKED | _FW_UNDER_LINKING) == _TRUE) {
+
+		_rtw_disconnect(wiphy, ndev);
+		RTW_INFO("%s disconnect before connecting! fw_state=0x%x\n",
+			__FUNCTION__, pmlmepriv->fw_state);
+	}
+
 #ifdef CONFIG_PLATFORM_MSTAR_SCAN_BEFORE_CONNECT
 	printk("MStar Android!\n");
 	if (pwdev_priv->bandroid_scan == _FALSE) {
@@ -3329,12 +3823,9 @@ static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,
 		goto cancel_ps_deny;
 	}
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
-		ret = -EBUSY;
-		RTW_INFO("%s, fw_state=0x%x, goto exit\n", __func__, pmlmepriv->fw_state);
-		goto cancel_ps_deny;
-	}
+	rtw_mi_scan_abort(padapter, _TRUE);
 
+	rtw_join_abort_timeout(padapter, 300);
 #ifdef CONFIG_CONCURRENT_MODE
 	if (rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING)) {
 		ret = -EINVAL;
@@ -3342,8 +3833,6 @@ static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,
 	}
 #endif
 
-	rtw_mi_scan_abort(padapter, _TRUE);
-
 	_rtw_memset(&ndis_ssid, 0, sizeof(NDIS_802_11_SSID));
 	ndis_ssid.SsidLength = sme->ssid_len;
 	_rtw_memcpy(ndis_ssid.Ssid, (u8 *)sme->ssid, sme->ssid_len);
@@ -3511,7 +4000,9 @@ cancel_ps_deny:
 exit:
 	RTW_INFO("<=%s, ret %d\n", __FUNCTION__, ret);
 
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT)
 	rtw_wdev_set_not_indic_disco(pwdev_priv, 0);
+#endif
 
 	return ret;
 }
@@ -3520,34 +4011,26 @@ static int cfg80211_rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev,
 				   u16 reason_code)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
 
 	RTW_INFO(FUNC_NDEV_FMT" - Start to Disconnect\n", FUNC_NDEV_ARG(ndev));
 
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
 	if (!wiphy->dev.power.is_prepared)
+	#endif
+		rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 1);
 #endif
-		rtw_wdev_set_not_indic_disco(pwdev_priv, 1);
 
 	rtw_set_to_roam(padapter, 0);
 
 	/* if(check_fwstate(&padapter->mlmepriv, _FW_LINKED)) */
 	{
-		rtw_scan_abort(padapter);
-		LeaveAllPowerSaveMode(padapter);
-		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
-#ifdef CONFIG_RTW_REPEATER_SON
-		rtw_rson_do_disconnect(padapter);
-#endif
-		RTW_INFO("%s...call rtw_indicate_disconnect\n", __func__);
-
-		rtw_free_assoc_resources(padapter, 1);
-		rtw_indicate_disconnect(padapter, 0, wiphy->dev.power.is_prepared ? _FALSE : _TRUE);
-
-		rtw_pwr_wakeup(padapter);
+		_rtw_disconnect(wiphy, ndev);
 	}
 
-	rtw_wdev_set_not_indic_disco(pwdev_priv, 0);
+#if (RTW_CFG80211_BLOCK_STA_DISCON_EVENT & RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+	rtw_wdev_set_not_indic_disco(adapter_wdev_data(padapter), 0);
+#endif
 
 	RTW_INFO(FUNC_NDEV_FMT" return 0\n", FUNC_NDEV_ARG(ndev));
 	return 0;
@@ -3735,10 +4218,12 @@ static int cfg80211_rtw_flush_pmksa(struct wiphy *wiphy,
 #ifdef CONFIG_AP_MODE
 void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len)
 {
+#if !defined(RTW_USE_CFG80211_STA_EVENT) && !defined(COMPAT_KERNEL_RELEASE)
 	s32 freq;
 	int channel;
 	struct wireless_dev *pwdev = padapter->rtw_wdev;
 	struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
+#endif
 	struct net_device *ndev = padapter->pnetdev;
 
 	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
@@ -3783,8 +4268,9 @@ void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint f
 
 }
 
-void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, unsigned char *da, unsigned short reason)
+void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, const u8 *da, unsigned short reason)
 {
+#if !defined(RTW_USE_CFG80211_STA_EVENT) && !defined(COMPAT_KERNEL_RELEASE)
 	s32 freq;
 	int channel;
 	u8 *pmgmt_frame;
@@ -3795,6 +4281,7 @@ void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, unsigned char *da, u
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	struct wireless_dev *wdev = padapter->rtw_wdev;
+#endif
 	struct net_device *ndev = padapter->pnetdev;
 
 	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
@@ -3863,17 +4350,27 @@ static int rtw_cfg80211_monitor_if_xmit_entry(struct sk_buff *skb, struct net_de
 	int snap_len = 6;
 	unsigned char *pdata;
 	u16 frame_ctl;
-	unsigned char src_mac_addr[6];
-	unsigned char dst_mac_addr[6];
+	unsigned char src_mac_addr[ETH_ALEN];
+	unsigned char dst_mac_addr[ETH_ALEN];
 	struct rtw_ieee80211_hdr *dot11_hdr;
 	struct ieee80211_radiotap_header *rtap_hdr;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+#ifdef CONFIG_DFS_MASTER
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+#endif
 
 	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
 
 	if (skb)
 		rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
 
+	if (IS_CH_WAITING(rfctl)) {
+		#ifdef CONFIG_DFS_MASTER
+		if (rtw_rfctl_overlap_radar_detect_ch(rfctl))
+			goto fail;
+		#endif
+	}
+
 	if (unlikely(skb->len < sizeof(struct ieee80211_radiotap_header)))
 		goto fail;
 
@@ -4161,6 +4658,9 @@ static int
 #endif
 	case NL80211_IFTYPE_STATION:
 	case NL80211_IFTYPE_AP:
+#ifdef CONFIG_RTW_MESH
+	case NL80211_IFTYPE_MESH_POINT:
+#endif
 		padapter = dvobj_get_unregisterd_adapter(dvobj);
 		if (!padapter) {
 			RTW_WARN("adapter pool empty!\n");
@@ -4189,7 +4689,6 @@ static int
 	case NL80211_IFTYPE_ADHOC:
 	case NL80211_IFTYPE_AP_VLAN:
 	case NL80211_IFTYPE_WDS:
-	case NL80211_IFTYPE_MESH_POINT:
 	default:
 		ret = -ENODEV;
 		RTW_INFO("Unsupported interface type\n");
@@ -4270,7 +4769,6 @@ static int rtw_add_beacon(_adapter *adapter, const u8 *head, size_t head_len, co
 	u8 *pbuf = NULL;
 	uint len, wps_ielen = 0;
 	uint p2p_ielen = 0;
-	u8 *p2p_ie;
 	u8 got_p2p_ie = _FALSE;
 	struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
 	/* struct sta_priv *pstapriv = &padapter->stapriv; */
@@ -4285,6 +4783,12 @@ static int rtw_add_beacon(_adapter *adapter, const u8 *head, size_t head_len, co
 	if (head_len < 24)
 		return -EINVAL;
 
+	#ifdef CONFIG_FW_HANDLE_TXBCN
+	if (!rtw_ap_nums_check(adapter)) {
+		RTW_ERR(FUNC_ADPT_FMT"failed, con't support over %d BCN\n", FUNC_ADPT_ARG(adapter), CONFIG_LIMITED_AP_NUM);
+		return -EINVAL;
+	}
+	#endif /*CONFIG_FW_HANDLE_TXBCN*/
 
 	pbuf = rtw_zmalloc(head_len + tail_len);
 	if (!pbuf)
@@ -4310,7 +4814,6 @@ static int rtw_add_beacon(_adapter *adapter, const u8 *head, size_t head_len, co
 	if (adapter->wdinfo.driver_interface == DRIVER_CFG80211) {
 		/* check p2p if enable */
 		if (rtw_get_p2p_ie(pbuf + _FIXED_IE_LENGTH_, len - _FIXED_IE_LENGTH_, NULL, &p2p_ielen)) {
-			struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
 			struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
 
 			RTW_INFO("got p2p_ie, len=%d\n", p2p_ielen);
@@ -4364,8 +4867,16 @@ static int cfg80211_rtw_add_beacon(struct wiphy *wiphy, struct net_device *ndev,
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
 
 	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+	rtw_mi_scan_abort(adapter, _TRUE);
+	rtw_mi_buddy_set_scan_deny(adapter, 300);
 	ret = rtw_add_beacon(adapter, info->head, info->head_len, info->tail, info->tail_len);
 
+exit:
 	return ret;
 }
 
@@ -4386,8 +4897,13 @@ static int cfg80211_rtw_set_beacon(struct wiphy *wiphy, struct net_device *ndev,
 
 static int	cfg80211_rtw_del_beacon(struct wiphy *wiphy, struct net_device *ndev)
 {
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
 	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
 
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
 	return 0;
 }
 #else
@@ -4400,6 +4916,12 @@ static int cfg80211_rtw_start_ap(struct wiphy *wiphy, struct net_device *ndev,
 	RTW_INFO(FUNC_NDEV_FMT" hidden_ssid:%d, auth_type:%d\n", FUNC_NDEV_ARG(ndev),
 		settings->hidden_ssid, settings->auth_type);
 
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+	rtw_mi_scan_abort(adapter, _TRUE);
+	rtw_mi_buddy_set_scan_deny(adapter, 300);
 	ret = rtw_add_beacon(adapter, settings->beacon.head, settings->beacon.head_len,
 		settings->beacon.tail, settings->beacon.tail_len);
 
@@ -4425,6 +4947,7 @@ static int cfg80211_rtw_start_ap(struct wiphy *wiphy, struct net_device *ndev,
 				pbss_network_ext->Ssid.Ssid, pbss_network_ext->Ssid.SsidLength);
 	}
 
+exit:
 	return ret;
 }
 
@@ -4443,10 +4966,15 @@ static int cfg80211_rtw_change_beacon(struct wiphy *wiphy, struct net_device *nd
 
 static int cfg80211_rtw_stop_ap(struct wiphy *wiphy, struct net_device *ndev)
 {
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+
 	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
 	return 0;
 }
-
 #endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3, 4, 0)) */
 
 #if CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
@@ -4460,6 +4988,7 @@ static int cfg80211_rtw_set_mac_acl(struct wiphy *wiphy, struct net_device *ndev
 
 	if (!params) {
 		RTW_WARN(FUNC_ADPT_FMT" params NULL\n", FUNC_ADPT_ARG(adapter));
+		rtw_macaddr_acl_clear(adapter, RTW_ACL_PERIOD_BSS);
 		goto exit;
 	}
 
@@ -4471,25 +5000,197 @@ static int cfg80211_rtw_set_mac_acl(struct wiphy *wiphy, struct net_device *ndev
 	else if (params->acl_policy == NL80211_ACL_POLICY_DENY_UNLESS_LISTED)
 		acl_mode = RTW_ACL_MODE_DENY_UNLESS_LISTED;
 
-	if (!params->n_acl_entries) {
-		if (acl_mode != RTW_ACL_MODE_DISABLED)
-			RTW_WARN(FUNC_ADPT_FMT" acl_policy:%d with no entry\n"
-				, FUNC_ADPT_ARG(adapter), params->acl_policy);
-		acl_mode = RTW_ACL_MODE_DISABLED;
-		goto exit;
-	}
+	rtw_macaddr_acl_clear(adapter, RTW_ACL_PERIOD_BSS);
+
+	rtw_set_macaddr_acl(adapter, RTW_ACL_PERIOD_BSS, acl_mode);
 
 	for (i = 0; i < params->n_acl_entries; i++)
-		rtw_acl_add_sta(adapter, params->mac_addrs[i].addr);
+		rtw_acl_add_sta(adapter, RTW_ACL_PERIOD_BSS, params->mac_addrs[i].addr);
 
 	ret = 0;
 
 exit:
-	rtw_set_macaddr_acl(adapter, acl_mode);
 	return ret;
 }
 #endif /* CONFIG_RTW_MACADDR_ACL && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0)) */
 
+const char *_nl80211_sta_flags_str[] = {
+	"INVALID",
+	"AUTHORIZED",
+	"SHORT_PREAMBLE",
+	"WME",
+	"MFP",
+	"AUTHENTICATED",
+	"TDLS_PEER",
+	"ASSOCIATED",
+};
+
+#define nl80211_sta_flags_str(_f) ((_f <= NL80211_STA_FLAG_MAX) ? _nl80211_sta_flags_str[_f] : _nl80211_sta_flags_str[0])
+
+const char *_nl80211_plink_state_str[] = {
+	"LISTEN",
+	"OPN_SNT",
+	"OPN_RCVD",
+	"CNF_RCVD",
+	"ESTAB",
+	"HOLDING",
+	"BLOCKED",
+	"UNKNOWN",
+};
+
+#define nl80211_plink_state_str(_s) ((_s < NUM_NL80211_PLINK_STATES) ? _nl80211_plink_state_str[_s] : _nl80211_plink_state_str[NUM_NL80211_PLINK_STATES])
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
+#define NL80211_PLINK_ACTION_NO_ACTION PLINK_ACTION_INVALID
+#define NL80211_PLINK_ACTION_OPEN PLINK_ACTION_OPEN
+#define NL80211_PLINK_ACTION_BLOCK PLINK_ACTION_BLOCK
+#define NUM_NL80211_PLINK_ACTIONS 3
+#endif
+
+const char *_nl80211_plink_actions_str[] = {
+	"NO_ACTION",
+	"OPEN",
+	"BLOCK",
+	"UNKNOWN",
+};
+
+#define nl80211_plink_actions_str(_a) ((_a < NUM_NL80211_PLINK_ACTIONS) ? _nl80211_plink_actions_str[_a] : _nl80211_plink_actions_str[NUM_NL80211_PLINK_ACTIONS])
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+const char *_nl80211_mesh_power_mode_str[] = {
+	"UNKNOWN",
+	"ACTIVE",
+	"LIGHT_SLEEP",
+	"DEEP_SLEEP",
+};
+
+#define nl80211_mesh_power_mode_str(_p) ((_p <= NL80211_MESH_POWER_MAX) ? _nl80211_mesh_power_mode_str[_p] : _nl80211_mesh_power_mode_str[0])
+#endif
+
+void dump_station_parameters(void *sel, struct wiphy *wiphy, const struct station_parameters *params)
+{
+#if DBG_RTW_CFG80211_STA_PARAM
+	if (params->supported_rates_len) {
+		#define SUPP_RATES_BUF_LEN (3 * RTW_G_RATES_NUM + 1)
+		int i;
+		char supp_rates_buf[SUPP_RATES_BUF_LEN] = {0};
+		u8 cnt = 0;
+
+		rtw_warn_on(params->supported_rates_len > RTW_G_RATES_NUM);
+
+		for (i = 0; i < params->supported_rates_len; i++) {
+			if (i >= RTW_G_RATES_NUM)
+				break;
+			cnt += snprintf(supp_rates_buf + cnt, SUPP_RATES_BUF_LEN - cnt -1
+				, "%02X ", params->supported_rates[i]);
+			if (cnt >= SUPP_RATES_BUF_LEN - 1)
+				break;
+		}
+
+		RTW_PRINT_SEL(sel, "supported_rates:%s\n", supp_rates_buf);
+	}
+
+	if (params->vlan)
+		RTW_PRINT_SEL(sel, "vlan:"NDEV_FMT"\n", NDEV_ARG(params->vlan));
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 31))
+	if (params->sta_flags_mask) {
+		#define STA_FLAGS_BUF_LEN 128
+		int i = 0;
+		char sta_flags_buf[STA_FLAGS_BUF_LEN] = {0};
+		u8 cnt = 0;
+
+		for (i = 1; i <= NL80211_STA_FLAG_MAX; i++) {
+			if (params->sta_flags_mask & BIT(i)) {
+				cnt += snprintf(sta_flags_buf + cnt, STA_FLAGS_BUF_LEN - cnt -1, "%s=%u "
+					, nl80211_sta_flags_str(i), (params->sta_flags_set & BIT(i)) ? 1 : 0);
+				if (cnt >= STA_FLAGS_BUF_LEN - 1)
+					break;
+			}
+		}
+
+		RTW_PRINT_SEL(sel, "sta_flags:%s\n", sta_flags_buf);
+	}
+#else
+	u32 station_flags;
+	#error "TBD\n"
+#endif
+
+	if (params->listen_interval != -1)
+		RTW_PRINT_SEL(sel, "listen_interval:%d\n", params->listen_interval);
+
+	if (params->aid)
+		RTW_PRINT_SEL(sel, "aid:%u\n", params->aid);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 8, 0))
+	if (params->peer_aid)
+		RTW_PRINT_SEL(sel, "peer_aid:%u\n", params->peer_aid);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26))
+	if (params->plink_action != NL80211_PLINK_ACTION_NO_ACTION)
+		RTW_PRINT_SEL(sel, "plink_action:%s\n", nl80211_plink_actions_str(params->plink_action));
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+	#endif
+		RTW_PRINT_SEL(sel, "plink_state:%s\n"
+			, nl80211_plink_state_str(params->plink_state));
+#endif
+
+#if 0 /* TODO */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 28))
+	const struct ieee80211_ht_cap *ht_capa;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	const struct ieee80211_vht_cap *vht_capa;
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_UAPSD)
+		RTW_PRINT_SEL(sel, "uapsd_queues:0x%02x\n", params->uapsd_queues);
+	if (params->max_sp)
+		RTW_PRINT_SEL(sel, "max_sp:%u\n", params->max_sp);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (params->local_pm != NL80211_MESH_POWER_UNKNOWN) {
+		RTW_PRINT_SEL(sel, "local_pm:%s\n"
+			, nl80211_mesh_power_mode_str(params->local_pm));
+	}
+
+	if (params->sta_modify_mask & STATION_PARAM_APPLY_CAPABILITY)
+		RTW_PRINT_SEL(sel, "capability:0x%04x\n", params->capability);
+
+#if 0 /* TODO */
+	const u8 *ext_capab;
+	u8 ext_capab_len;
+#endif
+#endif
+
+#if 0 /* TODO */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0))
+	const u8 *supported_channels;
+	u8 supported_channels_len;
+	const u8 *supported_oper_classes;
+	u8 supported_oper_classes_len;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0))
+	u8 opmode_notif;
+	bool opmode_notif_used;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+	int support_p2p_ps;
+#endif
+#endif
+#endif /* DBG_RTW_CFG80211_STA_PARAM */
+}
+
 static int	cfg80211_rtw_add_station(struct wiphy *wiphy, struct net_device *ndev,
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 16, 0))
 	u8 *mac,
@@ -4499,12 +5200,148 @@ static int	cfg80211_rtw_add_station(struct wiphy *wiphy, struct net_device *ndev
 	struct station_parameters *params)
 {
 	int ret = 0;
-#ifdef CONFIG_TDLS
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
+#if defined(CONFIG_TDLS) || defined(CONFIG_RTW_MESH)
 	struct sta_priv *pstapriv = &padapter->stapriv;
+#endif
+#ifdef CONFIG_TDLS
 	struct sta_info *psta;
 #endif /* CONFIG_TDLS */
-	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+
+	RTW_INFO(FUNC_NDEV_FMT" mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
+
+#if CONFIG_RTW_MACADDR_ACL
+	if (rtw_access_ctrl(padapter, mac) == _FALSE) {
+		RTW_INFO(FUNC_NDEV_FMT" deny by macaddr ACL\n", FUNC_NDEV_ARG(ndev));
+		ret = -EINVAL;
+		goto exit;
+	}
+#endif
+
+	dump_station_parameters(RTW_DBGDUMP, wiphy, params);
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		struct rtw_mesh_cfg *mcfg = &padapter->mesh_cfg;
+		struct rtw_mesh_info *minfo = &padapter->mesh_info;
+		struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+		struct mesh_plink_ent *plink = NULL;
+		struct wlan_network *scanned = NULL;
+		bool acnode = 0;
+		u8 add_new_sta = 0, probe_req = 0;
+		_irqL irqL;
+
+		if (params->plink_state != NL80211_PLINK_LISTEN) {
+			RTW_WARN(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(ndev), nl80211_plink_state_str(params->plink_state));
+			rtw_warn_on(1);
+		}
+		if (!params->aid || params->aid > pstapriv->max_aid) {
+			RTW_WARN(FUNC_NDEV_FMT" invalid aid:%u\n", FUNC_NDEV_ARG(ndev), params->aid);
+			rtw_warn_on(1);
+			ret = -EINVAL;
+			goto exit;
+		}
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL);
+
+		plink = _rtw_mesh_plink_get(padapter, mac);
+		if (plink)
+			goto release_plink_ctl;
+
+		#if CONFIG_RTW_MESH_PEER_BLACKLIST
+		if (rtw_mesh_peer_blacklist_search(padapter, mac)) {
+			RTW_INFO(FUNC_NDEV_FMT" deny by peer blacklist\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+		#endif
+
+		scanned = rtw_find_network(&padapter->mlmepriv.scanned_queue, mac);
+		if (!scanned
+			|| rtw_get_passing_time_ms(scanned->last_scanned) >= mcfg->peer_sel_policy.scanr_exp_ms
+		) {
+			if (!scanned)
+				RTW_INFO(FUNC_NDEV_FMT" corresponding network not found\n", FUNC_NDEV_ARG(ndev));
+			else
+				RTW_INFO(FUNC_NDEV_FMT" corresponding network too old\n", FUNC_NDEV_ARG(ndev));
+
+			if (adapter_to_rfctl(padapter)->offch_state == OFFCHS_NONE)
+				probe_req = 1;
+
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		#if CONFIG_RTW_MESH_ACNODE_PREVENT
+		if (plink_ctl->acnode_rsvd)
+			acnode = rtw_mesh_scanned_is_acnode_confirmed(padapter, scanned);
+		#endif
+
+		/* wpa_supplicant's auto peer will initiate peering when candidate peer is reported without max_peer_links consideration */
+		if (plink_ctl->num >= mcfg->max_peer_links + acnode ? 1 : 0) {
+			RTW_INFO(FUNC_NDEV_FMT" exceed max_peer_links:%u%s\n"
+				, FUNC_NDEV_ARG(ndev), mcfg->max_peer_links, acnode ? " acn" : "");
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		if (!rtw_bss_is_candidate_mesh_peer(&padapter->mlmepriv.cur_network.network, &scanned->network, 1, 1)) {
+			RTW_WARN(FUNC_NDEV_FMT" corresponding network is not candidate with same ch\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+
+		#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+		if (!rtw_mesh_cto_mgate_network_filter(padapter, scanned)) {
+			RTW_INFO(FUNC_NDEV_FMT" peer filtered out by cto_mgate check\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+			goto release_plink_ctl;
+		}
+		#endif
+
+		if (_rtw_mesh_plink_add(padapter, mac) == _SUCCESS) {
+			/* hook corresponding network in scan queue */
+			plink = _rtw_mesh_plink_get(padapter, mac);
+			plink->aid = params->aid;
+			plink->scanned = scanned;
+
+			#if CONFIG_RTW_MESH_ACNODE_PREVENT
+			if (acnode) {
+				RTW_INFO(FUNC_ADPT_FMT" acnode "MAC_FMT"\n"
+				, FUNC_ADPT_ARG(padapter), MAC_ARG(scanned->network.MacAddress));
+			}
+			#endif
+
+			add_new_sta = 1;
+		} else {
+			RTW_WARN(FUNC_NDEV_FMT" rtw_mesh_plink_add not success\n"
+				, FUNC_NDEV_ARG(ndev));
+			ret = -EINVAL;
+		}
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL);
+
+		if (probe_req)
+			issue_probereq(padapter, &padapter->mlmepriv.cur_network.network.mesh_id, mac);
+
+		if (add_new_sta) {
+			struct station_info sinfo;
+
+			#ifdef CONFIG_DFS_MASTER
+			if (IS_UNDER_CAC(adapter_to_rfctl(padapter)))
+				rtw_force_stop_cac(adapter_to_rfctl(padapter), 300);
+			#endif
+
+			/* indicate new sta */
+			_rtw_memset(&sinfo, 0, sizeof(sinfo));
+			cfg80211_new_sta(ndev, mac, &sinfo, GFP_ATOMIC);
+		}
+		goto exit;
+	}
+#endif /* CONFIG_RTW_MESH */
 
 #ifdef CONFIG_TDLS
 	psta = rtw_get_stainfo(pstapriv, (u8 *)mac);
@@ -4542,15 +5379,14 @@ static int	cfg80211_rtw_del_station(struct wiphy *wiphy, struct net_device *ndev
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 
-	RTW_INFO("+"FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
-
-
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 19, 0))
 	target_mac = mac;
 #else
 	target_mac = params->mac;
 #endif
 
+	RTW_INFO("+"FUNC_NDEV_FMT" mac=%pM\n", FUNC_NDEV_ARG(ndev), target_mac);
+
 	if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE)) != _TRUE) {
 		RTW_INFO("%s, fw_state != FW_LINKED|WIFI_AP_STATE|WIFI_MESH_STATE\n", __func__);
 		return -EINVAL;
@@ -4596,6 +5432,7 @@ static int	cfg80211_rtw_del_station(struct wiphy *wiphy, struct net_device *ndev
 
 				rtw_list_delete(&psta->asoc_list);
 				pstapriv->asoc_list_cnt--;
+				STA_SET_MESH_PLINK(psta, NULL);
 
 				/* _exit_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
 				if (MLME_IS_AP(padapter))
@@ -4617,6 +5454,11 @@ static int	cfg80211_rtw_del_station(struct wiphy *wiphy, struct net_device *ndev
 
 	associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_mesh_plink_del(padapter, target_mac);
+#endif
+
 	RTW_INFO("-"FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
 
 	return ret;
@@ -4631,15 +5473,131 @@ static int	cfg80211_rtw_change_station(struct wiphy *wiphy, struct net_device *n
 #endif
 	struct station_parameters *params)
 {
-	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+#ifdef CONFIG_RTW_MESH
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta = NULL;
+	_irqL irqL;
+#endif
+	int ret = 0;
 
-	return 0;
-}
+	RTW_INFO(FUNC_NDEV_FMT" mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(mac));
 
-struct sta_info *rtw_sta_info_get_by_idx(const int idx, struct sta_priv *pstapriv)
+	dump_station_parameters(RTW_DBGDUMP, wiphy, params);
 
-{
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		enum cfg80211_station_type sta_type = CFG80211_STA_MESH_PEER_USER;
+		struct rtw_mesh_info *minfo = &adapter->mesh_info;
+		struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
+		struct mesh_plink_ent *plink = NULL;
+		_irqL irqL2;
+		struct sta_info *del_sta = NULL;
+
+		ret = cfg80211_check_station_change(wiphy, params, sta_type);
+		if (ret) {
+			RTW_INFO("cfg80211_check_station_change return %d\n", ret);
+			goto exit;
+		}
+
+		_enter_critical_bh(&(plink_ctl->lock), &irqL2);
+
+		plink = _rtw_mesh_plink_get(adapter, mac);
+		if (!plink) {
+			ret = -ENOENT;
+			goto release_plink_ctl;
+		}
+
+		plink->plink_state = nl80211_plink_state_to_rtw_plink_state(params->plink_state);
+
+		#if CONFIG_RTW_MESH_ACNODE_PREVENT
+		if (params->plink_state == NL80211_PLINK_OPN_SNT
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+			&& (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+			#endif
+		) {
+			if (rtw_mesh_scanned_is_acnode_confirmed(adapter, plink->scanned)
+				&& rtw_mesh_acnode_prevent_allow_sacrifice(adapter)
+			) {
+				struct sta_info *sac = rtw_mesh_acnode_prevent_pick_sacrifice(adapter);
+
+				if (sac) {
+					del_sta = sac;
+					_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+					if (!rtw_is_list_empty(&del_sta->asoc_list)) {
+						rtw_list_delete(&del_sta->asoc_list);
+						stapriv->asoc_list_cnt--;
+						STA_SET_MESH_PLINK(del_sta, NULL);
+					}
+					_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+					RTW_INFO(FUNC_ADPT_FMT" sacrifice "MAC_FMT" for acnode\n"
+						, FUNC_ADPT_ARG(adapter), MAC_ARG(del_sta->cmn.mac_addr));
+				}
+			}
+		} else
+		#endif
+		if ((params->plink_state == NL80211_PLINK_OPN_RCVD
+				|| params->plink_state == NL80211_PLINK_CNF_RCVD
+				|| params->plink_state == NL80211_PLINK_ESTAB)
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+			&& (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+			#endif
+		) {
+			sta = rtw_get_stainfo(stapriv, mac);
+			if (!sta) {
+				sta = rtw_alloc_stainfo(stapriv, mac);
+				if (!sta)
+					goto release_plink_ctl;
+			}
+
+			if (params->plink_state == NL80211_PLINK_ESTAB) {
+				if (rtw_mesh_peer_establish(adapter, plink, sta) != _SUCCESS) {
+					rtw_free_stainfo(adapter, sta);
+					ret = -ENOENT;
+					goto release_plink_ctl;
+				}
+			}
+		}
+		else if (params->plink_state == NL80211_PLINK_HOLDING
+			#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+			&& (params->sta_modify_mask & STATION_PARAM_APPLY_PLINK_STATE)
+			#endif
+		) {
+			del_sta = rtw_get_stainfo(stapriv, mac);
+			if (!del_sta)
+				goto release_plink_ctl;
+
+			_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
+			if (!rtw_is_list_empty(&del_sta->asoc_list)) {
+				rtw_list_delete(&del_sta->asoc_list);
+				stapriv->asoc_list_cnt--;
+				STA_SET_MESH_PLINK(del_sta, NULL);
+			}
+			_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
+		}
 
+release_plink_ctl:
+		_exit_critical_bh(&(plink_ctl->lock), &irqL2);
+
+		if (del_sta) {
+			u8 sta_addr[ETH_ALEN];
+			u8 updated = _FALSE;
+			
+			_rtw_memcpy(sta_addr, del_sta->cmn.mac_addr, ETH_ALEN);
+			updated = ap_free_sta(adapter, del_sta, 0, 0, 1);
+			rtw_mesh_expire_peer(stapriv->padapter, sta_addr);
+
+			associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
+		}
+	}
+#endif /* CONFIG_RTW_MESH */
+
+exit:
+	return ret;
+}
+
+struct sta_info *rtw_sta_info_get_by_idx(struct sta_priv *pstapriv, const int idx, u8 *asoc_list_num)
+{
 	_list	*phead, *plist;
 	struct sta_info *psta = NULL;
 	int i = 0;
@@ -4654,32 +5612,75 @@ struct sta_info *rtw_sta_info_get_by_idx(const int idx, struct sta_priv *pstapri
 		plist = get_next(plist);
 		i++;
 	}
+
+	if (asoc_list_num)
+		*asoc_list_num = i;
+
 	return psta;
 }
 
 static int	cfg80211_rtw_dump_station(struct wiphy *wiphy, struct net_device *ndev,
 		int idx, u8 *mac, struct station_info *sinfo)
 {
+#define DBG_DUMP_STATION 0
 
 	int ret = 0;
 	_irqL irqL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
-	struct sta_info *psta = NULL;
 	struct sta_priv *pstapriv = &padapter->stapriv;
-	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
+	struct sta_info *psta = NULL;
+#ifdef CONFIG_RTW_MESH
+	struct mesh_plink_ent *plink = NULL;
+#endif
+	u8 asoc_list_num;
+
+	if (DBG_DUMP_STATION)
+		RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
 
 	_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	psta = rtw_sta_info_get_by_idx(idx, pstapriv);
+	psta = rtw_sta_info_get_by_idx(pstapriv, idx, &asoc_list_num);
 	_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
-	if (NULL == psta) {
-		RTW_INFO("Station is not found\n");
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		if (psta)
+			plink = psta->plink;
+		if (!plink)
+			plink = rtw_mesh_plink_get_no_estab_by_idx(padapter, idx - asoc_list_num);
+	}
+#endif /* CONFIG_RTW_MESH */
+
+	if ((!MLME_IS_MESH(padapter) && !psta)
+		#ifdef CONFIG_RTW_MESH
+		|| (MLME_IS_MESH(padapter) && !plink)
+		#endif
+	) {
+		if (DBG_DUMP_STATION)
+			RTW_INFO(FUNC_NDEV_FMT" end with idx:%d\n", FUNC_NDEV_ARG(ndev), idx);
 		ret = -ENOENT;
 		goto exit;
 	}
-	_rtw_memcpy(mac, psta->cmn.mac_addr, ETH_ALEN);
+
+	if (psta)
+		_rtw_memcpy(mac, psta->cmn.mac_addr, ETH_ALEN);
+	#ifdef CONFIG_RTW_MESH
+	else
+		_rtw_memcpy(mac, plink->addr, ETH_ALEN);
+	#endif
+	
 	sinfo->filled = 0;
-	sinfo->filled |= STATION_INFO_SIGNAL;
-	sinfo->signal = translate_percentage_to_dbm(psta->cmn.rssi_stat.rssi);
+
+	if (psta) {
+		sinfo->filled |= STATION_INFO_SIGNAL;
+		sinfo->signal = translate_percentage_to_dbm(psta->cmn.rssi_stat.rssi);
+		sinfo->filled |= STATION_INFO_INACTIVE_TIME;
+		sinfo->inactive_time = rtw_get_passing_time_ms(psta->sta_stats.last_rx_time);
+	}
+
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter))
+		rtw_cfg80211_fill_mesh_only_sta_info(plink, psta, sinfo);
+#endif
 
 exit:
 	return ret;
@@ -4688,8 +5689,6 @@ exit:
 static int	cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,
 		struct bss_parameters *params)
 {
-	u8 i;
-
 	RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(ndev));
 /*
 	RTW_INFO("use_cts_prot=%d\n", params->use_cts_prot);
@@ -4705,6 +5704,97 @@ static int	cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,
 
 }
 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+static int	cfg80211_rtw_set_txq_params(struct wiphy *wiphy
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	, struct net_device *ndev
+#endif
+	, struct ieee80211_txq_params *params)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	_adapter *padapter = rtw_netdev_priv(ndev);
+#else
+	_adapter *padapter = wiphy_to_adapter(wiphy);
+#endif
+	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
+	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	u8	ac, AIFS, ECWMin, ECWMax, aSifsTime;
+	u16	TXOP;
+	u8	shift_count = 0;
+	u32	acParm;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	ac = params->ac;
+#else
+	ac = params->queue;
+#endif
+
+#if 0
+	RTW_INFO("ac=%d\n", ac);
+	RTW_INFO("txop=%u\n", params->txop);
+	RTW_INFO("cwmin=%u\n", params->cwmin);
+	RTW_INFO("cwmax=%u\n", params->cwmax);
+	RTW_INFO("aifs=%u\n", params->aifs);
+#endif
+
+	if (is_supported_5g(pmlmeext->cur_wireless_mode) ||
+	    (pmlmeext->cur_wireless_mode & WIRELESS_11_24N))
+		aSifsTime = 16;
+	else
+		aSifsTime = 10;
+
+	AIFS = params->aifs * pmlmeinfo->slotTime + aSifsTime;
+
+	while ((params->cwmin + 1) >> shift_count != 1) {
+		shift_count++;
+		if (shift_count == 15)
+			break;
+	}
+
+	ECWMin = shift_count;
+
+	shift_count = 0;
+	while ((params->cwmax + 1) >> shift_count != 1) {
+		shift_count++;
+		if (shift_count == 15)
+			break;
+	}
+
+	ECWMax = shift_count;
+
+	TXOP = le16_to_cpu(params->txop);
+
+	acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
+
+	switch (ac) {
+	case NL80211_TXQ_Q_VO:
+		RTW_INFO(FUNC_NDEV_FMT" AC_VO = 0x%08x\n", FUNC_ADPT_ARG(padapter), acParm);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
+		break;
+
+	case NL80211_TXQ_Q_VI:
+		RTW_INFO(FUNC_NDEV_FMT" AC_VI = 0x%08x\n", FUNC_ADPT_ARG(padapter), acParm);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
+		break;
+
+	case NL80211_TXQ_Q_BE:
+		RTW_INFO(FUNC_NDEV_FMT" AC_BE = 0x%08x\n", FUNC_ADPT_ARG(padapter), acParm);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
+		break;
+
+	case NL80211_TXQ_Q_BK:
+		RTW_INFO(FUNC_NDEV_FMT" AC_BK = 0x%08x\n", FUNC_ADPT_ARG(padapter), acParm);
+		rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
+		break;
+
+	default:
+		break;
+	}
+
+	return 0;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29)) */
+
 static int	cfg80211_rtw_set_channel(struct wiphy *wiphy
 	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	, struct net_device *ndev
@@ -4871,7 +5961,6 @@ static int	cfg80211_rtw_assoc(struct wiphy *wiphy, struct net_device *ndev,
 void rtw_cfg80211_rx_probe_request(_adapter *adapter, union recv_frame *rframe)
 {
 	struct wireless_dev *wdev = adapter->rtw_wdev;
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
 	u8 *frame = get_recvframe_data(rframe);
 	uint frame_len = rframe->u.hdr.len;
 	s32 freq;
@@ -4939,7 +6028,7 @@ void rtw_cfg80211_rx_p2p_action_public(_adapter *adapter, union recv_frame *rfra
 	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
 	freq = rtw_ch2freq(ch);
 
-	RTW_INFO("RTW_Rx:ch=%d(%d, ta="MAC_FMT")\n"
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
 		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
 	#ifdef CONFIG_P2P
 	type = rtw_p2p_check_frames(adapter, frame, frame_len, _FALSE);
@@ -4968,6 +6057,7 @@ void rtw_cfg80211_rx_p2p_action_public(_adapter *adapter, union recv_frame *rfra
 			break;
 		case P2P_PROVISION_DISC_RESP:
 		case P2P_INVIT_RESP:
+			rtw_clear_scan_deny(adapter);
 			#if !RTW_P2P_GROUP_INTERFACE
 			rtw_mi_buddy_set_scan_deny(adapter, 2000);
 			#endif
@@ -4996,12 +6086,12 @@ indicate:
 void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const char *msg)
 {
 	struct wireless_dev *wdev = adapter->rtw_wdev;
-	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
 	u8 *frame = get_recvframe_data(rframe);
 	uint frame_len = rframe->u.hdr.len;
 	s32 freq;
 	u8 ch, sch = rtw_get_oper_ch(adapter);
 	u8 category, action;
+	int type = -1;
 
 	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
 	freq = rtw_ch2freq(ch);
@@ -5009,6 +6099,13 @@ void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const c
 	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
 		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
 
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(adapter)) {
+		type = rtw_mesh_check_frames_rx(adapter, frame, frame_len);
+		if (type >= 0)
+			goto indicate;
+	}
+#endif
 	rtw_action_frame_parse(frame, frame_len, &category, &action);
 	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
 		if (action == ACT_PUBLIC_GAS_INITIAL_REQ) {
@@ -5017,16 +6114,19 @@ void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const c
 		}
 	}
 
+indicate:
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
 	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
 #else
 	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
 #endif
 
-	if (msg)
-		RTW_INFO("RTW_Rx:%s\n", msg);
-	else
-		RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+	if (type == -1) {
+		if (msg)
+			RTW_INFO("RTW_Rx:%s\n", msg);
+		else
+			RTW_INFO("RTW_Rx:category(%u), action(%u)\n", category, action);
+	}
 }
 
 #ifdef CONFIG_RTW_80211K
@@ -5035,10 +6135,10 @@ void rtw_cfg80211_rx_rrm_action(_adapter *adapter, union recv_frame *rframe)
 	struct wireless_dev *wdev = adapter->rtw_wdev;
 	u8 *frame = get_recvframe_data(rframe);
 	uint frame_len = rframe->u.hdr.len;
-	s32 ch, freq;
-
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
 
-	ch = rtw_get_oper_ch(adapter);
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
 	freq = rtw_ch2freq(ch);
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
@@ -5046,10 +6146,40 @@ void rtw_cfg80211_rx_rrm_action(_adapter *adapter, union recv_frame *rframe)
 #else
 	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
 #endif
-	RTW_INFO("RTW_Rx:ch=%d, freq=%d\n", ch, freq);
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n"
+		, ch, sch, MAC_ARG(get_addr2_ptr(frame)));
 }
 #endif /* CONFIG_RTW_80211K */
 
+void rtw_cfg80211_rx_mframe(_adapter *adapter, union recv_frame *rframe, const char *msg)
+{
+	struct wireless_dev *wdev = adapter->rtw_wdev;
+	u8 *frame = get_recvframe_data(rframe);
+	uint frame_len = rframe->u.hdr.len;
+	s32 freq;
+	u8 ch, sch = rtw_get_oper_ch(adapter);
+
+	ch = rframe->u.hdr.attrib.ch ? rframe->u.hdr.attrib.ch : sch;
+	freq = rtw_ch2freq(ch);
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
+	rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, frame_len, GFP_ATOMIC);
+#else
+	cfg80211_rx_action(adapter->pnetdev, freq, frame, frame_len, GFP_ATOMIC);
+#endif
+
+	RTW_INFO("RTW_Rx:ch=%d(%d), ta="MAC_FMT"\n", ch, sch, MAC_ARG(get_addr2_ptr(frame)));
+	#ifdef CONFIG_RTW_MESH
+	if (!rtw_sae_check_frames(adapter, frame, frame_len, _FALSE))
+	#endif
+	{
+		if (msg)
+			RTW_INFO("RTW_Rx:%s\n", msg);
+		else
+			RTW_INFO("RTW_Rx:frame_control:0x%02x\n", le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)rframe)->frame_ctl));
+	}
+}
+
 #ifdef CONFIG_P2P
 void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len)
 {
@@ -5080,7 +6210,6 @@ void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf,
 	unsigned short				*fctrl;
 	struct xmit_priv			*pxmitpriv = &(padapter->xmitpriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 	u8 *frame_body = (unsigned char *)(buf + sizeof(struct rtw_ieee80211_hdr_3addr));
@@ -5281,7 +6410,7 @@ static s32 cfg80211_rtw_update_ft_ies(struct wiphy *wiphy,
 {
 	_adapter *padapter = NULL;
 	struct mlme_priv *pmlmepriv = NULL;
-	ft_priv *pftpriv = NULL;
+	struct ft_roam_info *pft_roam = NULL;
 	_irqL irqL;
 	u8 *p;
 	u8 *pie = NULL;
@@ -5292,24 +6421,22 @@ static s32 cfg80211_rtw_update_ft_ies(struct wiphy *wiphy,
 
 	padapter = (_adapter *)rtw_netdev_priv(ndev);
 	pmlmepriv = &(padapter->mlmepriv);
-	pftpriv = &pmlmepriv->ftpriv;
+	pft_roam = &(pmlmepriv->ft_roam);
 
 	p = (u8 *)ftie->ie;
-	if (ftie->ie_len <= sizeof(pftpriv->updated_ft_ies)) {
+	if (ftie->ie_len <= sizeof(pft_roam->updated_ft_ies)) {
 		_enter_critical_bh(&pmlmepriv->lock, &irqL);
-		_rtw_memcpy(pftpriv->updated_ft_ies, ftie->ie, ftie->ie_len);
-		pftpriv->updated_ft_ies_len = ftie->ie_len;
+		_rtw_memcpy(pft_roam->updated_ft_ies, ftie->ie, ftie->ie_len);
+		pft_roam->updated_ft_ies_len = ftie->ie_len;
 		_exit_critical_bh(&pmlmepriv->lock, &irqL);
 	} else {
 		RTW_ERR("FTIEs parsing fail!\n");
 		return -EINVAL;
 	}
 
-	if ((rtw_to_roam(padapter) > 0) && rtw_chk_ft_status(padapter, RTW_FT_AUTHENTICATED_STA)) {
+	if (rtw_ft_roam_status(padapter, RTW_FT_AUTHENTICATED_STA)) {
 		RTW_PRINT("auth success, start reassoc\n");
-		_enter_critical_bh(&pmlmepriv->lock, &irqL);
-		rtw_set_ft_status(padapter, RTW_FT_ASSOCIATING_STA);
-		_exit_critical_bh(&pmlmepriv->lock, &irqL);
+		rtw_ft_lock_set_status(padapter, RTW_FT_ASSOCIATING_STA, &irqL);
 		start_clnt_assoc(padapter);
 	}
 
@@ -5328,6 +6455,24 @@ inline bool rtw_cfg80211_get_is_roch(_adapter *adapter)
 	return adapter->cfg80211_wdinfo.is_ro_ch;
 }
 
+inline bool rtw_cfg80211_is_ro_ch_once(_adapter *adapter)
+{
+	return adapter->cfg80211_wdinfo.last_ro_ch_time ? 1 : 0;
+}
+
+inline void rtw_cfg80211_set_last_ro_ch_time(_adapter *adapter)
+{
+	adapter->cfg80211_wdinfo.last_ro_ch_time = rtw_get_current_time();
+
+	if (!adapter->cfg80211_wdinfo.last_ro_ch_time)
+		adapter->cfg80211_wdinfo.last_ro_ch_time++;
+}
+
+inline s32 rtw_cfg80211_get_last_ro_ch_passing_ms(_adapter *adapter)
+{
+	return rtw_get_passing_time_ms(adapter->cfg80211_wdinfo.last_ro_ch_time);
+}
+
 static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
 	struct wireless_dev *wdev,
@@ -5342,13 +6487,13 @@ static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,
 {
 	s32 err = 0;
 	u8 remain_ch = (u8) ieee80211_frequency_to_channel(channel->center_freq);
-	u8 union_ch = 0, union_bw = 0, union_offset = 0;
-	u8 i;
 	_adapter *padapter = NULL;
 	struct rtw_wdev_priv *pwdev_priv;
 	struct wifidirect_info *pwdinfo;
 	struct cfg80211_wifidirect_info *pcfg80211_wdinfo;
+#ifdef CONFIG_CONCURRENT_MODE
 	u8 is_p2p_find = _FALSE;
+#endif
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
 	#if defined(RTW_DEDICATED_P2P_DEVICE)
@@ -5458,7 +6603,7 @@ static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,
 	rtw_cfg80211_set_is_roch(padapter, _TRUE);
 	pcfg80211_wdinfo->ro_ch_wdev = wdev;
 	pcfg80211_wdinfo->remain_on_ch_cookie = *cookie;
-	pcfg80211_wdinfo->last_ro_ch_time = rtw_get_current_time();
+	rtw_cfg80211_set_last_ro_ch_time(padapter);
 	_rtw_memcpy(&pcfg80211_wdinfo->remain_on_ch_channel, channel, sizeof(struct ieee80211_channel));
 	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 8, 0))
 	pcfg80211_wdinfo->remain_on_ch_type = channel_type;
@@ -5529,9 +6674,6 @@ exit:
 
 inline int rtw_cfg80211_iface_has_p2p_group_cap(_adapter *adapter)
 {
-	struct wiphy *wiphy = adapter_to_wiphy(adapter);
-	struct rtw_wdev_priv *wdev_data = adapter_wdev_data(adapter);
-
 #if RTW_P2P_GROUP_INTERFACE
 	if (is_primary_adapter(adapter))
 		return 0;
@@ -5728,15 +6870,19 @@ static int _cfg80211_rtw_mgmt_tx(_adapter *padapter, u8 tx_ch, u8 no_cck, const
 	int ret = _FAIL;
 	bool ack = _TRUE;
 	struct rtw_ieee80211_hdr *pwlanhdr;
+#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_P2P) && defined(CONFIG_CONCURRENT_MODE)
 	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+#endif
 	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-
+	u8 u_ch = rtw_mi_get_union_chan(padapter);
+	u8 leave_op = 0;
 #ifdef CONFIG_P2P
+	struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
+	#ifdef CONFIG_CONCURRENT_MODE
 	struct wifidirect_info *pwdinfo = &padapter->wdinfo;
-#endif /* CONFIG_P2P */
-	/* struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo; */
+	#endif
+#endif
 
 	rtw_cfg80211_set_is_mgmt_tx(padapter, 1);
 
@@ -5763,47 +6909,31 @@ static int _cfg80211_rtw_mgmt_tx(_adapter *padapter, u8 tx_ch, u8 no_cck, const
 	}
 #endif /* CONFIG_MCC_MODE */
 
-#ifdef CONFIG_CONCURRENT_MODE
-	if (rtw_mi_check_status(padapter, MI_LINKED)) {
-		u8 union_ch = rtw_mi_get_union_chan(padapter);
-		u8 co_channel = 0xff;
-		co_channel = rtw_get_oper_ch(padapter);
+	if (rtw_mi_check_status(padapter, MI_LINKED)
+		&& tx_ch != u_ch
+	) {
+		rtw_leave_opch(padapter);
+		leave_op = 1;
 
-		if (tx_ch != union_ch) {
+		#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_P2P) && defined(CONFIG_CONCURRENT_MODE)
+		if (rtw_cfg80211_get_is_roch(padapter)
+			&& ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1
+		) {
 			u16 ext_listen_period;
 
-			if (ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1) {
-				rtw_leave_opch(padapter);
-
-				ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
-				/* RTW_INFO("%s, set switch ch timer, period=%d\n", __func__, pwdinfo->ext_listen_period); */
-				/* _set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_period); */
-			}
-
 			if (check_fwstate(&padapter->mlmepriv, _FW_LINKED))
-				ext_listen_period = 500;/*500ms*/
-#ifdef CONFIG_P2P				
+				ext_listen_period = 500;
 			else
 				ext_listen_period = pwdinfo->ext_listen_period;
-
+			ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
 			_set_timer(&pwdinfo->ap_p2p_switch_timer, ext_listen_period);
-#endif
 			RTW_INFO("%s, set switch ch timer, period=%d\n", __func__, ext_listen_period);
 		}
+		#endif /* RTW_ROCH_BACK_OP && CONFIG_P2P && CONFIG_CONCURRENT_MODE */
+	}
 
-		if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED))
-			pmlmeext->cur_channel = tx_ch;
-
-		if (tx_ch != co_channel)
-			set_channel_bwmode(padapter, tx_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-	} else
-#endif /* CONFIG_CONCURRENT_MODE */
-	/* if (tx_ch != pmlmeext->cur_channel) { */
-	if (tx_ch != rtw_get_oper_ch(padapter)) {
-		if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED))
-			pmlmeext->cur_channel = tx_ch;
+	if (tx_ch != rtw_get_oper_ch(padapter))
 		set_channel_bwmode(padapter, tx_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
-	}
 
 issue_mgmt_frame:
 	/* starting alloc mgmt frame to dump it */
@@ -5856,7 +6986,8 @@ issue_mgmt_frame:
 		} else {
 
 #ifdef CONFIG_XMIT_ACK
-			rtw_msleep_os(50);
+			if (!MLME_IS_MESH(padapter)) /* TODO: remove this sleep for all mode */
+				rtw_msleep_os(50);
 #endif
 #ifdef CONFIG_DEBUG_CFG80211
 			RTW_INFO("%s, ack=%d, ok!\n", __func__, ack);
@@ -5867,7 +6998,29 @@ issue_mgmt_frame:
 		dump_mgntframe(padapter, pmgntframe);
 		ret = _SUCCESS;
 	}
+
 exit:
+	#ifdef CONFIG_P2P
+	if (rtw_cfg80211_get_is_roch(padapter)
+		&& !roch_stay_in_cur_chan(padapter)
+		&& pcfg80211_wdinfo->remain_on_ch_channel.hw_value != u_ch
+	) {
+		/* roch is ongoing, switch back to rch */
+		if (pcfg80211_wdinfo->remain_on_ch_channel.hw_value != tx_ch)
+			set_channel_bwmode(padapter, pcfg80211_wdinfo->remain_on_ch_channel.hw_value
+				, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
+	} else
+	#endif
+	if (leave_op) {
+		if (rtw_mi_check_status(padapter, MI_LINKED)) {
+			u8 u_bw = rtw_mi_get_union_bw(padapter);
+			u8 u_offset = rtw_mi_get_union_offset(padapter);
+
+			set_channel_bwmode(padapter, u_ch, u_offset, u_bw);
+		}
+		rtw_back_opch(padapter);
+	}
+
 	rtw_cfg80211_set_is_mgmt_tx(padapter, 0);
 
 #ifdef CONFIG_BT_COEXIST
@@ -5928,12 +7081,9 @@ static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
 {
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(COMPAT_KERNEL_RELEASE)
 	struct ieee80211_channel *chan = params->chan;
-	bool offchan = params->offchan;
-	unsigned int wait = params->wait;
 	const u8 *buf = params->buf;
 	size_t len = params->len;
 	bool no_cck = params->no_cck;
-	bool dont_wait_for_ack = params->dont_wait_for_ack;
 #endif
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 2, 0))
 	bool no_cck = 0;
@@ -5941,6 +7091,8 @@ static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
 	int ret = 0;
 	u8 tx_ret;
 	int wait_ack = 1;
+	const u8 *dump_buf = buf;
+	size_t dump_len = len;
 	u32 dump_limit = RTW_MAX_MGMT_TX_CNT;
 	u32 dump_cnt = 0;
 	u32 sleep_ms = 0;
@@ -5957,6 +7109,7 @@ static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
 	_adapter *padapter;
 	struct dvobj_priv *dvobj;
 	struct rtw_wdev_priv *pwdev_priv;
+	struct rf_ctl_t *rfctl;
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
 	#if defined(RTW_DEDICATED_P2P_DEVICE)
@@ -5986,13 +7139,22 @@ static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
 		goto exit;
 	}
 
+	rfctl = adapter_to_rfctl(padapter);
 	tx_ch = (u8)ieee80211_frequency_to_channel(chan->center_freq);
+	if (IS_CH_WAITING(rfctl)) {
+		#ifdef CONFIG_DFS_MASTER
+		if (_rtw_rfctl_overlap_radar_detect_ch(rfctl, tx_ch, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE)) {
+			ret = -EINVAL;
+			goto exit;
+		}
+		#endif
+	}
 
 	dvobj = adapter_to_dvobj(padapter);
 	pwdev_priv = adapter_wdev_data(padapter);
 
 	/* cookie generation */
-	*cookie = (unsigned long) buf;
+	*cookie = pwdev_priv->mgmt_tx_cookie++;
 
 #ifdef CONFIG_DEBUG_CFG80211
 	RTW_INFO(FUNC_ADPT_FMT"%s len=%zu, ch=%d"
@@ -6028,6 +7190,15 @@ static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
 		wait_ack = 0;
 		goto dump;
 	}
+#ifdef CONFIG_RTW_MESH
+	else if (frame_styp == RTW_IEEE80211_STYPE_AUTH) {
+		RTW_INFO("RTW_Tx:tx_ch=%d, no_cck=%u, da="MAC_FMT"\n", tx_ch, no_cck, MAC_ARG(GetAddr1Ptr(buf)));
+		if (!rtw_sae_check_frames(padapter, buf, len, _TRUE))
+			RTW_INFO("RTW_Tx:AUTH\n");
+		dump_limit = 1;
+		goto dump;
+	}
+#endif
 
 	if (rtw_action_frame_parse(buf, len, &category, &action) == _FALSE) {
 		RTW_INFO(FUNC_ADPT_FMT" frame_control:0x%02x\n", FUNC_ADPT_ARG(padapter),
@@ -6043,6 +7214,15 @@ static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,
 		no_cck = 1; /* force no CCK for P2P frames */
 		goto dump;
 	}
+#endif
+#ifdef CONFIG_RTW_MESH
+	if (MLME_IS_MESH(padapter)) {
+		type = rtw_mesh_check_frames_tx(padapter, &dump_buf, &dump_len);
+		if (type >= 0) {
+			dump_limit = 1;
+			goto dump;
+		}
+	}
 #endif
 	if (category == RTW_WLAN_CATEGORY_PUBLIC) {
 		RTW_INFO("RTW_Tx:%s\n", action_public_str(action));
@@ -6074,7 +7254,7 @@ dump:
 
 		rtw_mi_set_scan_deny(padapter, 1000);
 		rtw_mi_scan_abort(padapter, _TRUE);
-		tx_ret = rtw_mgnt_tx_cmd(padapter, tx_ch, no_cck, buf, len, wait_ack, RTW_CMDF_WAIT_ACK);
+		tx_ret = rtw_mgnt_tx_cmd(padapter, tx_ch, no_cck, dump_buf, dump_len, wait_ack, RTW_CMDF_WAIT_ACK);
 		if (tx_ret == _SUCCESS
 			|| (dump_cnt >= dump_limit && rtw_get_passing_time_ms(start) >= retry_guarantee_ms))
 			break;
@@ -6116,6 +7296,7 @@ dump:
 			if (pwdev_priv->invit_info.flags & BIT(0)
 				&& pwdev_priv->invit_info.status == 0
 			) {
+				rtw_clear_scan_deny(padapter);
 				RTW_INFO(FUNC_ADPT_FMT" agree with invitation of persistent group\n",
 					FUNC_ADPT_ARG(padapter));
 				#if !RTW_P2P_GROUP_INTERFACE
@@ -6130,6 +7311,9 @@ dump:
 
 cancel_ps_deny:
 	rtw_ps_deny_cancel(padapter, PS_DENY_MGNT_TX);
+
+	if (dump_buf != buf)
+		rtw_mfree((u8 *)dump_buf, dump_len);
 exit:
 	return ret;
 }
@@ -6353,89 +7537,1077 @@ static int cfg80211_rtw_tdls_oper(struct wiphy *wiphy,
 	case NL80211_TDLS_DISABLE_LINK:
 		RTW_INFO(FUNC_NDEV_FMT", NL80211_TDLS_DISABLE_LINK;mac:"MAC_FMT"\n", FUNC_NDEV_ARG(ndev), MAC_ARG(peer));
 		ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), (u8 *)peer);
-		if (ptdls_sta != NULL)
-			rtw_tdls_cmd(padapter, (u8 *)peer, TDLS_TEARDOWN_STA_LOCALLY);
+		if (ptdls_sta != NULL) {
+			rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
+			rtw_tdls_cmd(padapter, (u8 *)peer, TDLS_TEARDOWN_STA_LOCALLY_POST);
+		}
 		break;
 	}
 	return 0;
 }
 #endif /* CONFIG_TDLS */
 
-#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
-static int cfg80211_rtw_sched_scan_start(struct wiphy *wiphy,
-		struct net_device *dev,
-		struct cfg80211_sched_scan_request *request)
+#if defined(CONFIG_RTW_MESH) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38))
+
+#if DBG_RTW_CFG80211_MESH_CONF
+#define LEGACY_RATES_STR_LEN (RTW_G_RATES_NUM * 5 + 1)
+int get_legacy_rates_str(struct wiphy *wiphy, enum nl80211_band band, u32 mask, char *buf)
 {
+	int i;
+	int cnt = 0;
+
+	for (i = 0; i < wiphy->bands[band]->n_bitrates; i++) {
+		if (mask & BIT(i)) {
+			cnt += snprintf(buf + cnt, LEGACY_RATES_STR_LEN - cnt -1, "%d.%d "
+				, wiphy->bands[band]->bitrates[i].bitrate / 10
+				, wiphy->bands[band]->bitrates[i].bitrate % 10);
+			if (cnt >= LEGACY_RATES_STR_LEN - 1)
+				break;
+		}
+	}
 
-	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	struct cfg80211_ssid *ssids;
-	int n_ssids = 0;
-	int interval = 0;
-	int i = 0;
-	u8 ret;
+	return cnt;
+}
 
-	if (padapter->bup == _FALSE) {
-		RTW_INFO("%s: net device is down.\n", __func__);
-		return -EIO;
+void dump_mesh_setup(void *sel, struct wiphy *wiphy, const struct mesh_setup *setup)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *chdef = (struct cfg80211_chan_def *)(&setup->chandef);
+#endif
+	struct ieee80211_channel *chan;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	chan = (struct ieee80211_channel *)chdef->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	chan = (struct ieee80211_channel *)setup->channel;
+#endif
+
+	RTW_PRINT_SEL(sel, "mesh_id:\"%s\", len:%u\n", setup->mesh_id, setup->mesh_id_len);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "sync_method:%u\n", setup->sync_method);
+#endif
+	RTW_PRINT_SEL(sel, "path_sel_proto:%u, path_metric:%u\n", setup->path_sel_proto, setup->path_metric);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	RTW_PRINT_SEL(sel, "auth_id:%u\n", setup->auth_id);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	if (setup->ie && setup->ie_len) {
+		RTW_PRINT_SEL(sel, "ie:%p, len:%u\n", setup->ie, setup->ie_len);
+		dump_ies(RTW_DBGDUMP, setup->ie, setup->ie_len);
+	}
+#else
+	if (setup->vendor_ie && setup->vendor_ie_len) {
+		RTW_PRINT_SEL(sel, "ie:%p, len:%u\n", setup->vendor_ie, setup->vendor_ie_len);
+		dump_ies(RTW_DBGDUMP, setup->vendor_ie, setup->vendor_ie_len);
 	}
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+	RTW_PRINT_SEL(sel, "is_authenticated:%d, is_secure:%d\n", setup->is_authenticated, setup->is_secure);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+	RTW_PRINT_SEL(sel, "user_mpm:%d\n", setup->user_mpm);
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	RTW_PRINT_SEL(sel, "dtim_period:%u, beacon_interval:%u\n", setup->dtim_period, setup->beacon_interval);
+#endif
 
-	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE ||
-		check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE  ||
-		check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
-		RTW_INFO("%s: device is busy.\n", __func__);
-		rtw_scan_abort(padapter);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	RTW_PRINT_SEL(sel, "center_freq:%u, ch:%u, width:%s, cfreq1:%u, cfreq2:%u\n"
+		, chan->center_freq, chan->hw_value, nl80211_chan_width_str(chdef->width), chdef->center_freq1, chdef->center_freq2);
+#else
+	RTW_PRINT_SEL(sel, "center_freq:%u, ch:%u, channel_type:%s\n"
+		, chan->center_freq, chan->hw_value, nl80211_channel_type_str(setup->channel_type));
+#endif
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	if (setup->mcast_rate[chan->band]) {
+		RTW_PRINT_SEL(sel, "mcast_rate:%d.%d\n"
+			, wiphy->bands[chan->band]->bitrates[setup->mcast_rate[chan->band] - 1].bitrate / 10
+			, wiphy->bands[chan->band]->bitrates[setup->mcast_rate[chan->band] - 1].bitrate % 10
+		);
 	}
+#endif
 
-	if (request == NULL) {
-		RTW_INFO("%s: invalid cfg80211_requests parameters.\n", __func__);
-		return -EINVAL;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (setup->basic_rates) {
+		char buf[LEGACY_RATES_STR_LEN] = {0};
+
+		get_legacy_rates_str(wiphy, chan->band, setup->basic_rates, buf);
+		RTW_PRINT_SEL(sel, "basic_rates:%s\n", buf);
 	}
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
-	interval = request->interval;
-	n_ssids = request->n_match_sets;
-	ssids = (struct cfg80211_ssid *)rtw_zmalloc(n_ssids * sizeof(struct cfg80211_ssid));
-	if(ssids == NULL) {
-		RTW_ERR("Fail to allocate ssids for PNO\n");
-		return -ENOMEM;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 9, 0))
+	if (setup->beacon_rate.control[chan->band].legacy) {
+		char buf[LEGACY_RATES_STR_LEN] = {0};
+
+		get_legacy_rates_str(wiphy, chan->band, setup->beacon_rate.control[chan->band].legacy, buf);
+		RTW_PRINT_SEL(sel, "beacon_rate.legacy:%s\n", buf);
 	}
-	for (i=0;i<request->n_match_sets;i++) {
-			ssids[i].ssid_len = request->match_sets[i].ssid.ssid_len;
-			memcpy(ssids[i].ssid, request->match_sets[i].ssid.ssid,
-					request->match_sets[i].ssid.ssid_len);
+	if (*((u32 *)&(setup->beacon_rate.control[chan->band].ht_mcs[0]))
+		|| *((u32 *)&(setup->beacon_rate.control[chan->band].ht_mcs[4]))
+		|| *((u16 *)&(setup->beacon_rate.control[chan->band].ht_mcs[8]))
+	) {
+		RTW_PRINT_SEL(sel, "beacon_rate.ht_mcs:"HT_RX_MCS_BMP_FMT"\n"
+			, HT_RX_MCS_BMP_ARG(setup->beacon_rate.control[chan->band].ht_mcs));
 	}
-#else
-	interval = request->interval;
-	n_ssids = request->n_ssids;
-	ssids = request->ssids;
-#endif
-ret = rtw_android_cfg80211_pno_setup(dev, ssids,
-			n_ssids, interval);
-	if (ret < 0) {
-		RTW_INFO("%s ret: %d\n", __func__, ret);
-		goto exit;
+
+	if (setup->beacon_rate.control[chan->band].vht_mcs[0]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[1]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[2]
+		|| setup->beacon_rate.control[chan->band].vht_mcs[3]
+	) {
+		int i;
+
+		for (i = 0; i < 4; i++) {/* parsing up to 4SS */
+			u16 mcs_mask = setup->beacon_rate.control[chan->band].vht_mcs[i];
+
+			RTW_PRINT_SEL(sel, "beacon_rate.vht_mcs[%d]:%s\n", i
+				, mcs_mask == 0x00FF ? "0~7" : mcs_mask == 0x01FF ? "0~8" : mcs_mask == 0x03FF ? "0~9" : "invalid");
+		}
 	}
 
-	ret = rtw_android_pno_enable(dev, _TRUE);
-	if (ret < 0) {
-		RTW_INFO("%s ret: %d\n", __func__, ret);
-		goto exit;
+	if (setup->beacon_rate.control[chan->band].gi) {
+		RTW_PRINT_SEL(sel, "beacon_rate.gi:%s\n"
+			, setup->beacon_rate.control[chan->band].gi == NL80211_TXRATE_FORCE_SGI ? "SGI" :
+				setup->beacon_rate.control[chan->band].gi == NL80211_TXRATE_FORCE_LGI ? "LGI" : "invalid"
+		);
 	}
-exit:
-	return ret;
+#endif
 }
 
-static int cfg80211_rtw_sched_scan_stop(struct wiphy *wiphy,
-		struct net_device *dev)
+void dump_mesh_config(void *sel, const struct mesh_config *conf)
 {
-	return rtw_android_pno_enable(dev, _FALSE);
-}
+	RTW_PRINT_SEL(sel, "dot11MeshRetryTimeout:%u\n", conf->dot11MeshRetryTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshConfirmTimeout:%u\n", conf->dot11MeshConfirmTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHoldingTimeout:%u\n", conf->dot11MeshHoldingTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshMaxPeerLinks:%u\n", conf->dot11MeshMaxPeerLinks);
+	RTW_PRINT_SEL(sel, "dot11MeshMaxRetries:%u\n", conf->dot11MeshMaxRetries);
+	RTW_PRINT_SEL(sel, "dot11MeshTTL:%u\n", conf->dot11MeshTTL);
+	RTW_PRINT_SEL(sel, "element_ttl:%u\n", conf->element_ttl);
+	RTW_PRINT_SEL(sel, "auto_open_plinks:%d\n", conf->auto_open_plinks);
 
-int	cfg80211_rtw_suspend(struct wiphy *wiphy, struct cfg80211_wowlan *wow) {
-	RTW_DBG("==> %s\n",__func__);
-	RTW_DBG("<== %s\n",__func__);
-	return 0;
-}
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshNbrOffsetMaxNeighbor:%u\n", conf->dot11MeshNbrOffsetMaxNeighbor);
+#endif
+
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPmaxPREQretries:%u\n", conf->dot11MeshHWMPmaxPREQretries);
+	RTW_PRINT_SEL(sel, "path_refresh_time:%u\n", conf->path_refresh_time);
+	RTW_PRINT_SEL(sel, "min_discovery_timeout:%u\n", conf->min_discovery_timeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPactivePathTimeout:%u\n", conf->dot11MeshHWMPactivePathTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPpreqMinInterval:%u\n", conf->dot11MeshHWMPpreqMinInterval);	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPperrMinInterval:%u\n", conf->dot11MeshHWMPperrMinInterval);
+#endif
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPnetDiameterTraversalTime:%u\n", conf->dot11MeshHWMPnetDiameterTraversalTime);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPRootMode:%u\n", conf->dot11MeshHWMPRootMode);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPRannInterval:%u\n", conf->dot11MeshHWMPRannInterval);
+	RTW_PRINT_SEL(sel, "dot11MeshGateAnnouncementProtocol:%d\n", conf->dot11MeshGateAnnouncementProtocol);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshForwarding:%d\n", conf->dot11MeshForwarding);
+	RTW_PRINT_SEL(sel, "rssi_threshold:%d\n", conf->rssi_threshold);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	RTW_PRINT_SEL(sel, "ht_opmode:0x%04x\n", conf->ht_opmode);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPactivePathToRootTimeout:%u\n", conf->dot11MeshHWMPactivePathToRootTimeout);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMProotInterval:%u\n", conf->dot11MeshHWMProotInterval);
+	RTW_PRINT_SEL(sel, "dot11MeshHWMPconfirmationInterval:%u\n", conf->dot11MeshHWMPconfirmationInterval);
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	RTW_PRINT_SEL(sel, "power_mode:%s\n", nl80211_mesh_power_mode_str(conf->power_mode));
+	RTW_PRINT_SEL(sel, "dot11MeshAwakeWindowDuration:%u\n", conf->dot11MeshAwakeWindowDuration);
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	RTW_PRINT_SEL(sel, "plink_timeout:%u\n", conf->plink_timeout);
+#endif
+}
+#endif /* DBG_RTW_CFG80211_MESH_CONF */
+
+static void rtw_cfg80211_mesh_info_set_profile(struct rtw_mesh_info *minfo, const struct mesh_setup *setup)
+{
+	_rtw_memcpy(minfo->mesh_id, setup->mesh_id, setup->mesh_id_len);
+	minfo->mesh_id_len = setup->mesh_id_len;
+	minfo->mesh_pp_id = setup->path_sel_proto;
+	minfo->mesh_pm_id = setup->path_metric;
+	minfo->mesh_cc_id = 0;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	minfo->mesh_sp_id = setup->sync_method;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	minfo->mesh_auth_id = setup->auth_id;
+#else
+	if (setup->is_authenticated) {
+		u8 *rsn_ie;
+		sint rsn_ie_len;
+		struct rsne_info info;
+		u8 *akm;
+		u8 AKM_SUITE_SAE[4] = {0x00, 0x0F, 0xAC, 0x08};
+
+		rsn_ie = rtw_get_ie(setup->ie, WLAN_EID_RSN, &rsn_ie_len, setup->ie_len);
+		if (!rsn_ie || !rsn_ie_len) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		if (rtw_rsne_info_parse(rsn_ie, rsn_ie_len + 2, &info) != _SUCCESS) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		if (!info.akm_list || !info.akm_cnt) {
+			rtw_warn_on(1);
+			return;
+		}
+
+		akm = info.akm_list;
+		while (akm < info.akm_list + info.akm_cnt * 4) {
+			if (_rtw_memcmp(akm, AKM_SUITE_SAE, 4) == _TRUE) {
+				minfo->mesh_auth_id = 0x01;
+				break;
+			}
+		}
+
+		if (!minfo->mesh_auth_id) {
+			rtw_warn_on(1);
+			return;
+		}
+	}
+#endif
+}
+
+static inline bool chk_mesh_attr(enum nl80211_meshconf_params parm, u32 mask)
+{
+	return (mask >> (parm - 1)) & 0x1;
+}
+
+static void rtw_cfg80211_mesh_cfg_set(_adapter *adapter, const struct mesh_config *conf, u32 mask)
+{
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+
+#if 0 /* driver MPM */
+	if (chk_mesh_attr(NL80211_MESHCONF_RETRY_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_CONFIRM_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_HOLDING_TIMEOUT, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_MAX_PEER_LINKS, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_MAX_RETRIES, mask));
+#endif
+
+	if (chk_mesh_attr(NL80211_MESHCONF_TTL, mask))
+		mcfg->dot11MeshTTL = conf->dot11MeshTTL;
+	if (chk_mesh_attr(NL80211_MESHCONF_ELEMENT_TTL, mask))
+		mcfg->element_ttl = conf->element_ttl;
+
+#if 0 /* driver MPM */
+	if (chk_mesh_attr(NL80211_MESHCONF_AUTO_OPEN_PLINKS, mask));
+#endif
+
+#if 0 /* TBD: synchronization */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_SYNC_OFFSET_MAX_NEIGHBOR, mask));
+#endif
+#endif
+
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_MAX_PREQ_RETRIES, mask))
+		mcfg->dot11MeshHWMPmaxPREQretries = conf->dot11MeshHWMPmaxPREQretries;
+	if (chk_mesh_attr(NL80211_MESHCONF_PATH_REFRESH_TIME, mask))
+		mcfg->path_refresh_time = conf->path_refresh_time;
+	if (chk_mesh_attr(NL80211_MESHCONF_MIN_DISCOVERY_TIMEOUT, mask))
+		mcfg->min_discovery_timeout = conf->min_discovery_timeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ACTIVE_PATH_TIMEOUT, mask))
+		mcfg->dot11MeshHWMPactivePathTimeout = conf->dot11MeshHWMPactivePathTimeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PREQ_MIN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPpreqMinInterval = conf->dot11MeshHWMPpreqMinInterval;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PERR_MIN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPperrMinInterval = conf->dot11MeshHWMPperrMinInterval;
+#endif
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_NET_DIAM_TRVS_TIME, mask))
+		mcfg->dot11MeshHWMPnetDiameterTraversalTime = conf->dot11MeshHWMPnetDiameterTraversalTime;
+
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ROOTMODE, mask))
+		mcfg->dot11MeshHWMPRootMode = conf->dot11MeshHWMPRootMode;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_GATE_ANNOUNCEMENTS, mask))
+		mcfg->dot11MeshGateAnnouncementProtocol = conf->dot11MeshGateAnnouncementProtocol;
+	/* our current gate annc implementation rides on root annc with gate annc bit in PREQ flags */
+	if (mcfg->dot11MeshGateAnnouncementProtocol
+		&& mcfg->dot11MeshHWMPRootMode <= RTW_IEEE80211_ROOTMODE_ROOT
+	) {
+		mcfg->dot11MeshHWMPRootMode = RTW_IEEE80211_PROACTIVE_RANN;
+		RTW_INFO(ADPT_FMT" enable PROACTIVE_RANN becaue gate annc is needed\n", ADPT_ARG(adapter));
+	}
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_RANN_INTERVAL, mask))
+		mcfg->dot11MeshHWMPRannInterval = conf->dot11MeshHWMPRannInterval;
+#endif
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_FORWARDING, mask))
+		mcfg->dot11MeshForwarding = conf->dot11MeshForwarding;
+
+	if (chk_mesh_attr(NL80211_MESHCONF_RSSI_THRESHOLD, mask))
+		mcfg->rssi_threshold = conf->rssi_threshold;
+#endif
+
+#if 0 /* controlled by driver */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HT_OPMODE, mask));
+#endif
+#endif
+	
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_PATH_TO_ROOT_TIMEOUT, mask))
+		mcfg->dot11MeshHWMPactivePathToRootTimeout = conf->dot11MeshHWMPactivePathToRootTimeout;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_ROOT_INTERVAL, mask))
+		mcfg->dot11MeshHWMProotInterval = conf->dot11MeshHWMProotInterval;
+	if (chk_mesh_attr(NL80211_MESHCONF_HWMP_CONFIRMATION_INTERVAL, mask))
+		mcfg->dot11MeshHWMPconfirmationInterval = conf->dot11MeshHWMPconfirmationInterval;	
+#endif
+
+#if 0 /* TBD */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_POWER_MODE, mask));
+	if (chk_mesh_attr(NL80211_MESHCONF_AWAKE_WINDOW, mask));
+#endif
+#endif
+
+#if 0 /* driver MPM */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	if (chk_mesh_attr(NL80211_MESHCONF_PLINK_TIMEOUT, mask));
+#endif
+#endif
+}
+
+u8 *rtw_cfg80211_construct_mesh_beacon_ies(struct wiphy *wiphy, _adapter *adapter
+	, const struct mesh_config *conf, const struct mesh_setup *setup
+	, uint *ies_len)
+{
+	struct rtw_mesh_info *minfo = &adapter->mesh_info;
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	struct cfg80211_chan_def *chdef = (struct cfg80211_chan_def *)(&setup->chandef);
+#endif
+	struct ieee80211_channel *chan;
+	u8 ch, bw, offset;
+#endif
+	uint len;
+	u8 n_bitrates;
+	u8 ht = 0;
+	u8 vht = 0;
+	u8 *rsn_ie = NULL;
+	sint rsn_ie_len = 0;
+	u8 *ies = NULL, *c;
+	u8 supported_rates[RTW_G_RATES_NUM] = {0};
+	int i;
+
+	*ies_len = 0;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	chan = (struct ieee80211_channel *)chdef->chan;
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	chan = (struct ieee80211_channel *)setup->channel;
+#endif
+
+	n_bitrates = wiphy->bands[chan->band]->n_bitrates;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 8, 0))
+	rtw_get_chbw_from_cfg80211_chan_def(chdef, &ht, &ch, &bw, &offset);
+#else
+	rtw_get_chbw_from_nl80211_channel_type(chan, setup->channel_type, &ht, &ch, &bw, &offset);
+#endif
+	if (!ch)
+		goto exit;
+	
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	vht = ht && ch > 14 && bw >= CHANNEL_WIDTH_80; /* VHT40/VHT20? */
+#endif
+
+	RTW_INFO(FUNC_ADPT_FMT" => ch:%u,%u,%u, ht:%u, vht:%u\n"
+		, FUNC_ADPT_ARG(adapter), ch, bw, offset, ht, vht);
+#endif
+
+	rsn_ie = rtw_get_ie(setup->ie, WLAN_EID_RSN, &rsn_ie_len, setup->ie_len);
+	if (rsn_ie && !rsn_ie_len) {
+		rtw_warn_on(1);
+		rsn_ie = NULL;
+	}
+
+	len = _BEACON_IE_OFFSET_
+		+ 2 /* 0-length SSID */
+		+ (n_bitrates >= 8 ? 8 : n_bitrates) + 2 /* Supported Rates */
+		+ 3 /* DS parameter set */
+		+ 6 /* TIM  */
+		+ (n_bitrates > 8 ? n_bitrates - 8 + 2 : 0) /* Extended Supported Rates */
+		+ (rsn_ie ? rsn_ie_len + 2 : 0) /* RSN */
+		#if defined(CONFIG_80211N_HT)
+		+ (ht ? HT_CAP_IE_LEN + 2 + HT_OP_IE_LEN + 2 : 0) /* HT */
+		#endif
+		#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+		+ (vht ? VHT_CAP_IE_LEN + 2 + VHT_OP_IE_LEN + 2 : 0) /* VHT */
+		#endif
+		+ minfo->mesh_id_len + 2 /* Mesh ID */
+		+ 9 /* Mesh configuration */
+		;
+
+	ies = rtw_zmalloc(len);
+	if (!ies)
+		goto exit;
+
+	/* timestamp */
+	c = ies + 8;
+
+	/* beacon interval */
+	RTW_PUT_LE16(c , setup->beacon_interval);
+	c += 2;
+
+	/* capability */
+	if (rsn_ie)
+		*((u16 *)c) |= cpu_to_le16(cap_Privacy);
+	c += 2;
+
+	/* SSID */
+	c = rtw_set_ie(c, WLAN_EID_SSID, 0, NULL, NULL);
+
+	/* Supported Rates */
+	for (i = 0; i < n_bitrates; i++) {
+		supported_rates[i] = wiphy->bands[chan->band]->bitrates[i].bitrate / 5;
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+		if (setup->basic_rates & BIT(i))
+		#else
+		if (rtw_is_basic_rate_mix(supported_rates[i]))
+		#endif
+			supported_rates[i] |= IEEE80211_BASIC_RATE_MASK;
+	}
+	c = rtw_set_ie(c, WLAN_EID_SUPP_RATES, (n_bitrates >= 8 ? 8 : n_bitrates), supported_rates, NULL);
+
+	/* DS parameter set */
+	c = rtw_set_ie(c, WLAN_EID_DS_PARAMS, 1, &ch, NULL);
+
+	/* TIM */
+	*c = WLAN_EID_TIM;
+	*(c + 1) = 4;
+	c += 6;
+	//c = rtw_set_ie(c, _TIM_IE_, 4, NULL, NULL);
+
+	/* Extended Supported Rates */
+	if (n_bitrates > 8)
+		c = rtw_set_ie(c, WLAN_EID_EXT_SUPP_RATES, n_bitrates - 8, supported_rates + 8, NULL);
+
+	/* RSN */
+	if (rsn_ie)
+		c = rtw_set_ie(c, WLAN_EID_RSN, rsn_ie_len, rsn_ie + 2, NULL);
+
+#if defined(CONFIG_80211N_HT)
+	if (ht) {
+		struct ieee80211_sta_ht_cap *sta_ht_cap = &wiphy->bands[chan->band]->ht_cap;
+		u8 ht_cap[HT_CAP_IE_LEN];
+		u8 ht_op[HT_OP_IE_LEN];
+
+		_rtw_memset(ht_cap, 0, HT_CAP_IE_LEN);
+		_rtw_memset(ht_op, 0, HT_OP_IE_LEN);
+
+		/* WLAN_EID_HT_CAP */
+		RTW_PUT_LE16(HT_CAP_ELE_CAP_INFO(ht_cap), sta_ht_cap->cap);
+		SET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP(ht_cap, sta_ht_cap->ampdu_factor);
+		SET_HT_CAP_ELE_MIN_MPDU_S_SPACE(ht_cap, sta_ht_cap->ampdu_density);
+		_rtw_memcpy(HT_CAP_ELE_SUP_MCS_SET(ht_cap), &sta_ht_cap->mcs, 16);
+		c = rtw_set_ie(c, WLAN_EID_HT_CAP, HT_CAP_IE_LEN, ht_cap, NULL);
+
+		/* WLAN_EID_HT_OPERATION */
+		SET_HT_OP_ELE_PRI_CHL(ht_op, ch);
+		switch (offset) {
+		case HAL_PRIME_CHNL_OFFSET_LOWER:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCA);
+			break;
+		case HAL_PRIME_CHNL_OFFSET_UPPER:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCB);
+			break;
+		case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
+		default:
+			SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op, SCN);
+			break;
+		}
+		if (bw >= CHANNEL_WIDTH_40)
+			SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op, 1);
+		else
+			SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op, 0);
+		c = rtw_set_ie(c, WLAN_EID_HT_OPERATION, HT_OP_IE_LEN, ht_op, NULL);
+	}
+#endif /* defined(CONFIG_80211N_HT) */
+
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	if (vht) {
+		struct ieee80211_sta_vht_cap *sta_vht_cap = &wiphy->bands[chan->band]->vht_cap;
+		u8 vht_cap[VHT_CAP_IE_LEN];
+		u8 vht_op[VHT_OP_IE_LEN];
+		u8 cch = rtw_get_center_ch(ch, bw, offset);
+
+		_rtw_memset(vht_op, 0, VHT_OP_IE_LEN);
+
+		/* WLAN_EID_VHT_CAPABILITY */
+		_rtw_memcpy(vht_cap, &sta_vht_cap->cap, 4);
+		_rtw_memcpy(vht_cap + 4, &sta_vht_cap->vht_mcs, 8);
+		c = rtw_set_ie(c, WLAN_EID_VHT_CAPABILITY, VHT_CAP_IE_LEN, vht_cap, NULL);
+
+		/* WLAN_EID_VHT_OPERATION */
+		if (bw < CHANNEL_WIDTH_80) {
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op, 0);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op, 0);
+		} else if (bw == CHANNEL_WIDTH_80) {
+			SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op, 1);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op, cch);
+			SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op, 0);
+		} else {
+			RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(adapter), bw);
+			rtw_warn_on(1);
+			rtw_mfree(ies, len);
+			goto exit;
+		}
+
+		/* Hard code 1 stream, MCS0-7 is a min Basic VHT MCS rates */
+		vht_op[3] = 0xfc;
+		vht_op[4] = 0xff;
+		c = rtw_set_ie(c, WLAN_EID_VHT_OPERATION, VHT_OP_IE_LEN, vht_op, NULL);
+	}
+#endif /* defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)) */
+
+	/* Mesh ID */
+	c = rtw_set_ie_mesh_id(c, NULL, minfo->mesh_id, minfo->mesh_id_len);
+
+	/* Mesh configuration */
+	c = rtw_set_ie_mesh_config(c, NULL
+		, minfo->mesh_pp_id
+		, minfo->mesh_pm_id
+		, minfo->mesh_cc_id
+		, minfo->mesh_sp_id
+		, minfo->mesh_auth_id
+		, 0, 0, 0
+		, 1
+		, 0, 0
+		, mcfg->dot11MeshForwarding
+		, 0, 0, 0
+	);
+
+#if DBG_RTW_CFG80211_MESH_CONF
+	RTW_INFO(FUNC_ADPT_FMT" ies_len:%u\n", FUNC_ADPT_ARG(adapter), len);
+	dump_ies(RTW_DBGDUMP, ies + _BEACON_IE_OFFSET_, len - _BEACON_IE_OFFSET_);
+#endif
+
+exit:
+	if (ies)
+		*ies_len = len;
+	return ies;
+}
+
+static int cfg80211_rtw_get_mesh_config(struct wiphy *wiphy, struct net_device *dev
+	, struct mesh_config *conf)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_cfg *mesh_cfg = &adapter->mesh_cfg;
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+	/* driver MPM */
+	conf->dot11MeshRetryTimeout = 0;
+	conf->dot11MeshConfirmTimeout = 0;
+	conf->dot11MeshHoldingTimeout = 0;
+	conf->dot11MeshMaxPeerLinks = mesh_cfg->max_peer_links;
+	conf->dot11MeshMaxRetries = 0;
+
+	conf->dot11MeshTTL = mesh_cfg->dot11MeshTTL;
+	conf->element_ttl = mesh_cfg->element_ttl;
+
+	/* driver MPM */
+	conf->auto_open_plinks = 0;
+
+	/* TBD: synchronization */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	conf->dot11MeshNbrOffsetMaxNeighbor = 0;
+#endif
+
+	conf->dot11MeshHWMPmaxPREQretries = mesh_cfg->dot11MeshHWMPmaxPREQretries;
+	conf->path_refresh_time = mesh_cfg->path_refresh_time;
+	conf->min_discovery_timeout = mesh_cfg->min_discovery_timeout;
+	conf->dot11MeshHWMPactivePathTimeout = mesh_cfg->dot11MeshHWMPactivePathTimeout;
+	conf->dot11MeshHWMPpreqMinInterval = mesh_cfg->dot11MeshHWMPpreqMinInterval;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	conf->dot11MeshHWMPperrMinInterval = mesh_cfg->dot11MeshHWMPperrMinInterval;
+#endif
+	conf->dot11MeshHWMPnetDiameterTraversalTime = mesh_cfg->dot11MeshHWMPnetDiameterTraversalTime;
+	conf->dot11MeshHWMPRootMode = mesh_cfg->dot11MeshHWMPRootMode;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
+	conf->dot11MeshHWMPRannInterval = mesh_cfg->dot11MeshHWMPRannInterval;
+#endif
+	conf->dot11MeshGateAnnouncementProtocol = mesh_cfg->dot11MeshGateAnnouncementProtocol;
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 4, 0))
+	conf->dot11MeshForwarding = mesh_cfg->dot11MeshForwarding;
+	conf->rssi_threshold = mesh_cfg->rssi_threshold;
+#endif
+
+	/* TBD */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
+	conf->ht_opmode = 0xffff;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+	conf->dot11MeshHWMPactivePathToRootTimeout = mesh_cfg->dot11MeshHWMPactivePathToRootTimeout;
+	conf->dot11MeshHWMProotInterval = mesh_cfg->dot11MeshHWMProotInterval;
+	conf->dot11MeshHWMPconfirmationInterval = mesh_cfg->dot11MeshHWMPconfirmationInterval;
+#endif
+
+	/* TBD: power save */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 9, 0))
+	conf->power_mode = NL80211_MESH_POWER_ACTIVE;
+	conf->dot11MeshAwakeWindowDuration = 0;
+#endif
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	conf->plink_timeout = mesh_cfg->plink_timeout;
+#endif
+
+	return ret;
+}
+
+static void rtw_mbss_info_change_notify(_adapter *adapter, bool minfo_changed, bool need_work)
+{
+	if (need_work)
+		rtw_mesh_work(&adapter->mesh_work);
+}
+
+static int cfg80211_rtw_update_mesh_config(struct wiphy *wiphy, struct net_device *dev
+	, u32 mask, const struct mesh_config *nconf)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+	bool minfo_changed = _FALSE, need_work = _FALSE;
+
+	RTW_INFO(FUNC_ADPT_FMT" mask:0x%08x\n", FUNC_ADPT_ARG(adapter), mask);
+
+	rtw_cfg80211_mesh_cfg_set(adapter, nconf, mask);
+	update_beacon(adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE);
+#if CONFIG_RTW_MESH_CTO_MGATE_CARRIER
+	if (rtw_mesh_cto_mgate_required(adapter))
+		rtw_netif_carrier_off(adapter->pnetdev);
+	else
+		rtw_netif_carrier_on(adapter->pnetdev);
+#endif
+	need_work = rtw_ieee80211_mesh_root_setup(adapter);
+
+	rtw_mbss_info_change_notify(adapter, minfo_changed, need_work);
+
+	return ret;
+}
+
+static int cfg80211_rtw_join_mesh(struct wiphy *wiphy, struct net_device *dev,
+	const struct mesh_config *conf, const struct mesh_setup *setup)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	u8 *ies = NULL;
+	uint ies_len;
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+#if DBG_RTW_CFG80211_MESH_CONF
+	RTW_INFO(FUNC_ADPT_FMT" mesh_setup:\n", FUNC_ADPT_ARG(adapter));
+	dump_mesh_setup(RTW_DBGDUMP, wiphy, setup);
+	RTW_INFO(FUNC_ADPT_FMT" mesh_config:\n", FUNC_ADPT_ARG(adapter));
+	dump_mesh_config(RTW_DBGDUMP, conf);
+#endif
+
+	if (rtw_cfg80211_sync_iftype(adapter) != _SUCCESS) {
+		ret = -ENOTSUPP;
+		goto exit;
+	}
+
+	/* initialization */
+	rtw_mesh_init_mesh_info(adapter);
+
+	/* apply cfg80211 settings*/
+	rtw_cfg80211_mesh_info_set_profile(&adapter->mesh_info, setup);
+	rtw_cfg80211_mesh_cfg_set(adapter, conf, 0xFFFFFFFF);
+
+	/* apply cfg80211 settings (join only) */
+	rtw_mesh_cfg_init_max_peer_links(adapter, conf->dot11MeshMaxPeerLinks);
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
+	rtw_mesh_cfg_init_plink_timeout(adapter, conf->plink_timeout);
+	#endif
+
+	rtw_ieee80211_mesh_root_setup(adapter);
+
+	ies = rtw_cfg80211_construct_mesh_beacon_ies(wiphy, adapter, conf, setup, &ies_len);
+	if (!ies) {
+		ret = -EINVAL;
+		goto exit;
+	}
+
+	/* start mbss */
+	if (rtw_check_beacon_data(adapter, ies,  ies_len) != _SUCCESS) {
+		ret = -EINVAL;
+		goto exit;
+	}
+	
+	rtw_mesh_work(&adapter->mesh_work);
+
+exit:
+	if (ies)
+		rtw_mfree(ies, ies_len);
+	if (ret)
+		rtw_mesh_deinit_mesh_info(adapter);
+
+	return ret;
+}
+
+static int cfg80211_rtw_leave_mesh(struct wiphy *wiphy, struct net_device *dev)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+
+	RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
+
+	rtw_mesh_deinit_mesh_info(adapter);
+
+	rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11Infrastructure);
+	rtw_setopmode_cmd(adapter, Ndis802_11Infrastructure, RTW_CMDF_WAIT_ACK);
+
+	return ret;
+}
+
+static int cfg80211_rtw_add_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst, const u8 *next_hop
+	#else
+	, u8 *dst, u8 *next_hop
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	sta = rtw_get_stainfo(stapriv, next_hop);
+	if (!sta) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	mpath = rtw_mesh_path_add(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_mesh_path_fix_nexthop(mpath, sta);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_del_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst
+	#else
+	, u8 *dst
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	int ret = 0;
+
+	if (dst) {
+		if (rtw_mesh_path_del(adapter, dst)) {
+			ret = -ENOENT;
+			goto exit;
+		}
+	} else {
+		rtw_mesh_path_flush_by_iface(adapter);
+	}	
+
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_change_mpath(struct wiphy *wiphy, struct net_device *dev
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 16, 0))
+	, const u8 *dst, const u8 *next_hop
+	#else
+	, u8 *dst, u8 *next_hop
+	#endif
+)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+	struct sta_info *sta;
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	sta = rtw_get_stainfo(stapriv, next_hop);
+	if (!sta) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	mpath = rtw_mesh_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_mesh_path_fix_nexthop(mpath, sta);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static void rtw_cfg80211_mpath_set_pinfo(struct rtw_mesh_path *mpath, u8 *next_hop, struct mpath_info *pinfo)
+{
+	struct sta_info *next_hop_sta = rtw_rcu_dereference(mpath->next_hop);
+
+	if (next_hop_sta)
+		_rtw_memcpy(next_hop, next_hop_sta->cmn.mac_addr, ETH_ALEN);
+	else
+		_rtw_memset(next_hop, 0, ETH_ALEN);
+
+	_rtw_memset(pinfo, 0, sizeof(*pinfo));
+
+	pinfo->generation = mpath->adapter->mesh_info.mesh_paths_generation;
+
+	pinfo->filled = 0
+		| MPATH_INFO_FRAME_QLEN
+		| MPATH_INFO_SN
+		| MPATH_INFO_METRIC
+		| MPATH_INFO_EXPTIME
+		| MPATH_INFO_DISCOVERY_TIMEOUT
+		| MPATH_INFO_DISCOVERY_RETRIES
+		| MPATH_INFO_FLAGS
+		;
+
+	pinfo->frame_qlen = mpath->frame_queue_len;
+	pinfo->sn = mpath->sn;
+	pinfo->metric = mpath->metric;
+	if (rtw_time_after(mpath->exp_time, rtw_get_current_time()))
+		pinfo->exptime = rtw_get_remaining_time_ms(mpath->exp_time);
+	pinfo->discovery_timeout = rtw_systime_to_ms(mpath->discovery_timeout);
+	pinfo->discovery_retries = mpath->discovery_retries;
+	if (mpath->flags & RTW_MESH_PATH_ACTIVE)
+		pinfo->flags |= NL80211_MPATH_FLAG_ACTIVE;
+	if (mpath->flags & RTW_MESH_PATH_RESOLVING)
+		pinfo->flags |= NL80211_MPATH_FLAG_RESOLVING;
+	if (mpath->flags & RTW_MESH_PATH_SN_VALID)
+		pinfo->flags |= NL80211_MPATH_FLAG_SN_VALID;
+	if (mpath->flags & RTW_MESH_PATH_FIXED)
+		pinfo->flags |= NL80211_MPATH_FLAG_FIXED;
+	if (mpath->flags & RTW_MESH_PATH_RESOLVED)
+		pinfo->flags |= NL80211_MPATH_FLAG_RESOLVED;
+}
+
+static int cfg80211_rtw_get_mpath(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mesh_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_cfg80211_mpath_set_pinfo(mpath, next_hop, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_dump_mpath(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mesh_path_lookup_by_idx(adapter, idx);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+	rtw_cfg80211_mpath_set_pinfo(mpath, next_hop, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+static void rtw_cfg80211_mpp_set_pinfo(struct rtw_mesh_path *mpath, u8 *mpp, struct mpath_info *pinfo)
+{
+	_rtw_memcpy(mpp, mpath->mpp, ETH_ALEN);
+
+	_rtw_memset(pinfo, 0, sizeof(*pinfo));
+	pinfo->generation = mpath->adapter->mesh_info.mpp_paths_generation;
+}
+
+static int cfg80211_rtw_get_mpp(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mpp_path_lookup(adapter, dst);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	rtw_cfg80211_mpp_set_pinfo(mpath, mpp, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+
+static int cfg80211_rtw_dump_mpp(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo)
+{
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_path *mpath;
+	int ret = 0;
+
+	rtw_rcu_read_lock();
+
+	mpath = rtw_mpp_path_lookup_by_idx(adapter, idx);
+	if (!mpath) {
+		ret = -ENOENT;
+		goto exit;
+	}
+
+	_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
+	rtw_cfg80211_mpp_set_pinfo(mpath, mpp, pinfo);
+
+exit:
+	rtw_rcu_read_unlock();
+
+	return ret;
+}
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0)) */
+
+#endif /* defined(CONFIG_RTW_MESH) */
+
+#if defined(CONFIG_PNO_SUPPORT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+static int cfg80211_rtw_sched_scan_start(struct wiphy *wiphy,
+		struct net_device *dev,
+		struct cfg80211_sched_scan_request *request)
+{
+
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct cfg80211_ssid *ssids;
+	int n_ssids = 0;
+	int interval = 0;
+	int i = 0;
+	u8 ret;
+
+	if (padapter->bup == _FALSE) {
+		RTW_INFO("%s: net device is down.\n", __func__);
+		return -EIO;
+	}
+
+	if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE ||
+		check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE  ||
+		check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
+		RTW_INFO("%s: device is busy.\n", __func__);
+		rtw_scan_abort(padapter);
+	}
+
+	if (request == NULL) {
+		RTW_INFO("%s: invalid cfg80211_requests parameters.\n", __func__);
+		return -EINVAL;
+	}
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0)
+	interval = request->scan_plans->interval;
+#else
+	interval = request->interval;
+#endif
+	n_ssids = request->n_match_sets;
+	ssids = (struct cfg80211_ssid *)rtw_zmalloc(n_ssids * sizeof(struct cfg80211_ssid));
+	if(ssids == NULL) {
+		RTW_ERR("Fail to allocate ssids for PNO\n");
+		return -ENOMEM;
+	}
+	for (i=0;i<request->n_match_sets;i++) {
+			ssids[i].ssid_len = request->match_sets[i].ssid.ssid_len;
+			memcpy(ssids[i].ssid, request->match_sets[i].ssid.ssid,
+					request->match_sets[i].ssid.ssid_len);
+	}
+#else
+	interval = request->interval;
+	n_ssids = request->n_ssids;
+	ssids = request->ssids;
+#endif
+ret = rtw_android_cfg80211_pno_setup(dev, ssids,
+			n_ssids, interval);
+	if (ret < 0) {
+		RTW_INFO("%s ret: %d\n", __func__, ret);
+		goto exit;
+	}
+
+	ret = rtw_android_pno_enable(dev, _TRUE);
+	if (ret < 0) {
+		RTW_INFO("%s ret: %d\n", __func__, ret);
+		goto exit;
+	}
+exit:
+	return ret;
+}
+
+static int cfg80211_rtw_sched_scan_stop(struct wiphy *wiphy,
+		struct net_device *dev)
+{
+	return rtw_android_pno_enable(dev, _FALSE);
+}
+
+int	cfg80211_rtw_suspend(struct wiphy *wiphy, struct cfg80211_wowlan *wow) {
+	RTW_DBG("==> %s\n",__func__);
+	RTW_DBG("<== %s\n",__func__);
+	return 0;
+}
 
 int	cfg80211_rtw_resume(struct wiphy *wiphy) {
 
@@ -6462,11 +8634,9 @@ int	cfg80211_rtw_resume(struct wiphy *wiphy) {
 		for (i=0;i<pwrpriv->pnlo_info->ssid_num && i < RTW_SSID_SCAN_AMOUNT; i++) {
 			len = pwrpriv->pno_ssid_list->node[i].SSID_len;
 			_rtw_memcpy(&parm.ssid[i].Ssid, pwrpriv->pno_ssid_list->node[i].SSID, len);
-			parm->ssid[i].SsidLength = len;
+			parm.ssid[i].SsidLength = len;
 		}
-		prm->ssid_num = pwrpriv->pnlo_info->ssid_num;
-
-		rtw_lock_ext_suspend_timeout(10000);
+		parm.ssid_num = pwrpriv->pnlo_info->ssid_num;
 
 		_enter_critical_bh(&pmlmepriv->lock, &irqL);
 		//This modification fix PNO wakeup reconnect issue with hidden SSID AP.
@@ -6848,6 +9018,7 @@ int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len,
 
 }
 
+#ifdef CONFIG_80211N_HT
 static void rtw_cfg80211_init_ht_capab_ex(_adapter *padapter
 	, struct ieee80211_sta_ht_cap *ht_cap, BAND_TYPE band, u8 rf_type)
 {
@@ -6900,10 +9071,14 @@ static void rtw_cfg80211_init_ht_capab_ex(_adapter *padapter
 static void rtw_cfg80211_init_ht_capab(_adapter *padapter
 	, struct ieee80211_sta_ht_cap *ht_cap, BAND_TYPE band, u8 rf_type)
 {
+	struct registry_priv *regsty = &padapter->registrypriv;
 	struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
 	u8 rx_nss = 0;
 
-	ht_cap->ht_supported = _TRUE;
+	if (!regsty->ht_enable || !is_supported_ht(regsty->wireless_mode))
+		return;
+
+	ht_cap->ht_supported = 1;
 
 	ht_cap->cap = IEEE80211_HT_CAP_SUP_WIDTH_20_40 |
 				IEEE80211_HT_CAP_SGI_40 | IEEE80211_HT_CAP_SGI_20 |
@@ -6952,6 +9127,27 @@ static void rtw_cfg80211_init_ht_capab(_adapter *padapter
 			, hal_is_bw_support(padapter, CHANNEL_WIDTH_40) ? ht_cap->cap & IEEE80211_HT_CAP_SGI_40 : ht_cap->cap & IEEE80211_HT_CAP_SGI_20
 			, ht_cap->mcs.rx_mask) / 10);
 }
+#endif /* CONFIG_80211N_HT */
+
+#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+static void rtw_cfg80211_init_vht_capab(_adapter *padapter
+	, struct ieee80211_sta_vht_cap *sta_vht_cap, BAND_TYPE band, u8 rf_type)
+{
+	struct registry_priv *regsty = &padapter->registrypriv;
+	u8 vht_cap_ie[2 + 12] = {0};
+
+	if (!REGSTY_IS_11AC_ENABLE(regsty) || !is_supported_vht(regsty->wireless_mode))
+		return;
+
+	rtw_vht_use_default_setting(padapter);
+	rtw_build_vht_cap_ie(padapter, vht_cap_ie);
+
+	sta_vht_cap->vht_supported = 1;
+
+	_rtw_memcpy(&sta_vht_cap->cap, vht_cap_ie + 2, 4);
+	_rtw_memcpy(&sta_vht_cap->vht_mcs, vht_cap_ie + 2 + 4, 8);
+}
+#endif /* defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)) */
 
 void rtw_cfg80211_init_wdev_data(_adapter *padapter)
 {
@@ -6975,18 +9171,25 @@ void rtw_cfg80211_init_wiphy(_adapter *padapter)
 
 	if (IsSupported24G(padapter->registrypriv.wireless_mode)) {
 		band = wiphy->bands[NL80211_BAND_2GHZ];
-		if (band)
+		if (band) {
+			#if defined(CONFIG_80211N_HT)
 			rtw_cfg80211_init_ht_capab(padapter, &band->ht_cap, BAND_ON_2_4G, rf_type);
+			#endif
+		}
 	}
 #ifdef CONFIG_IEEE80211_BAND_5GHZ
 	if (is_supported_5g(padapter->registrypriv.wireless_mode)) {
 		band = wiphy->bands[NL80211_BAND_5GHZ];
-		if (band)
+		if (band) {
+			#if defined(CONFIG_80211N_HT)
 			rtw_cfg80211_init_ht_capab(padapter, &band->ht_cap, BAND_ON_5G, rf_type);
+			#endif
+			#if defined(CONFIG_80211AC_VHT) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
+			rtw_cfg80211_init_vht_capab(padapter, &band->vht_cap, BAND_ON_5G, rf_type);
+			#endif
+		}
 	}
 #endif
-	/* init regulary domain */
-	rtw_regd_init(padapter);
 
 	/* copy mac_addr to wiphy */
 	_rtw_memcpy(wiphy->perm_addr, adapter_mac_addr(padapter), ETH_ALEN);
@@ -7015,7 +9218,13 @@ struct ieee80211_iface_limit rtw_limits[] = {
 	{
 		.max = 1,
 		.types = BIT(NL80211_IFTYPE_P2P_DEVICE)
-	}
+	},
+	#endif
+	#if defined(CONFIG_RTW_MESH)
+	{
+		.max = 1,
+		.types = BIT(NL80211_IFTYPE_MESH_POINT)
+	},
 	#endif
 };
 
@@ -7066,9 +9275,19 @@ static void rtw_cfg80211_preinit_wiphy(_adapter *adapter, struct wiphy *wiphy)
 								#if defined(RTW_DEDICATED_P2P_DEVICE)
 								| BIT(NL80211_IFTYPE_P2P_DEVICE)
 								#endif
+#endif
+#ifdef CONFIG_RTW_MESH
+								| BIT(NL80211_IFTYPE_MESH_POINT) /* 2.6.26 */
 #endif
 								;
 
+#if defined(CONFIG_ANDROID) && !defined(RTW_SINGLE_WIPHY)
+        if (is_primary_adapter(adapter)) {
+                wiphy->interface_modes &= ~(BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT));
+                RTW_INFO("%s primary- don't set p2p capability\n", __func__);
+        }
+#endif
+
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
 #ifdef CONFIG_AP_MODE
 	wiphy->mgmt_stypes = rtw_cfg80211_default_mgmt_stypes;
@@ -7143,6 +9362,25 @@ static void rtw_cfg80211_preinit_wiphy(_adapter *adapter, struct wiphy *wiphy)
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 2, 0))
 	/* wiphy->flags |= WIPHY_FLAG_SUPPORTS_FW_ROAM; */
 #endif
+
+#ifdef CONFIG_RTW_MESH
+	wiphy->flags |= 0
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37))
+		| WIPHY_FLAG_IBSS_RSN
+		#endif
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+		| WIPHY_FLAG_MESH_AUTH
+		#endif
+		;
+
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0))
+	wiphy->features |= 0
+		#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0))
+		| NL80211_FEATURE_USERSPACE_MPM
+		#endif
+		;
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 3, 0)) */
+#endif /* CONFIG_RTW_MESH */
 }
 
 #ifdef CONFIG_RFKILL_POLL
@@ -7322,6 +9560,9 @@ static struct cfg80211_ops rtw_cfg80211_ops = {
 	.get_key = cfg80211_rtw_get_key,
 	.del_key = cfg80211_rtw_del_key,
 	.set_default_key = cfg80211_rtw_set_default_key,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 30))
+	.set_default_mgmt_key = cfg80211_rtw_set_default_mgmt_key,
+#endif
 #if defined(CONFIG_GTK_OL) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0))
 	.set_rekey_data = cfg80211_rtw_set_rekey_data,
 #endif /*CONFIG_GTK_OL*/
@@ -7362,6 +9603,9 @@ static struct cfg80211_ops rtw_cfg80211_ops = {
 	.change_station = cfg80211_rtw_change_station,
 	.dump_station = cfg80211_rtw_dump_station,
 	.change_bss = cfg80211_rtw_change_bss,
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
+	.set_txq_params = cfg80211_rtw_set_txq_params,
+#endif
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0))
 	.set_channel = cfg80211_rtw_set_channel,
 #endif
@@ -7369,6 +9613,22 @@ static struct cfg80211_ops rtw_cfg80211_ops = {
 	/* .assoc = cfg80211_rtw_assoc,	 */
 #endif /* CONFIG_AP_MODE */
 
+#if defined(CONFIG_RTW_MESH) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 38))
+	.get_mesh_config = cfg80211_rtw_get_mesh_config,
+	.update_mesh_config = cfg80211_rtw_update_mesh_config,
+	.join_mesh = cfg80211_rtw_join_mesh,
+	.leave_mesh = cfg80211_rtw_leave_mesh,
+	.add_mpath = cfg80211_rtw_add_mpath,
+	.del_mpath = cfg80211_rtw_del_mpath,
+	.change_mpath = cfg80211_rtw_change_mpath,
+	.get_mpath = cfg80211_rtw_get_mpath,
+	.dump_mpath = cfg80211_rtw_dump_mpath,
+	#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
+	.get_mpp = cfg80211_rtw_get_mpp,
+	.dump_mpp = cfg80211_rtw_dump_mpp,
+	#endif
+#endif
+
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 6, 0))
 	.set_monitor_channel = cfg80211_rtw_set_monitor_channel,
 #endif
@@ -7467,6 +9727,8 @@ int rtw_wiphy_register(struct wiphy *wiphy)
 	rtw_cfgvendor_attach(wiphy);
 #endif
 
+	rtw_regd_init(wiphy);
+
 	return wiphy_register(wiphy);
 }
 
@@ -7503,11 +9765,7 @@ int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy)
 	}
 	wdev->wiphy = wiphy;
 	wdev->netdev = pnetdev;
-
-	wdev->iftype = NL80211_IFTYPE_STATION;	/* will be init in rtw_hal_init() */
-											/* Must sync with _rtw_init_mlme_priv() */
-											/* pmlmepriv->fw_state = WIFI_STATION_STATE */
-	/* wdev->iftype = NL80211_IFTYPE_MONITOR; */ /* for rtw_setopmode_cmd() in cfg80211_rtw_change_iface() */
+	wdev->iftype = NL80211_IFTYPE_STATION;
 	padapter->rtw_wdev = wdev;
 	pnetdev->ieee80211_ptr = wdev;
 
@@ -7541,6 +9799,13 @@ int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy)
 	ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
 #endif
 
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+        pwdev_priv->rssi_monitor_enable = 0;
+        pwdev_priv->rssi_monitor_max = 0;
+        pwdev_priv->rssi_monitor_min = 0;
+#endif
+
+
 exit:
 	return ret;
 }
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.h
index 046dbaa0a584..b23e2290ba2b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_cfg80211.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -15,9 +16,15 @@
 #ifndef __IOCTL_CFG80211_H__
 #define __IOCTL_CFG80211_H__
 
+#define RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT		BIT0
+#define RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT	BIT1
 
-#ifndef RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT
-	#define RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT 0
+#ifndef RTW_CFG80211_BLOCK_STA_DISCON_EVENT
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 2, 0))
+#define RTW_CFG80211_BLOCK_STA_DISCON_EVENT (RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT)
+#else
+#define RTW_CFG80211_BLOCK_STA_DISCON_EVENT (RTW_CFG80211_BLOCK_DISCON_WHEN_CONNECT | RTW_CFG80211_BLOCK_DISCON_WHEN_DISCONNECT)
+#endif
 #endif
 
 #if defined(RTW_USE_CFG80211_STA_EVENT)
@@ -67,6 +74,12 @@
 	#error "RTW_DEDICATED_P2P_DEVICE can't be enabled when kernel < 3.7.0\n"
 #endif
 
+#ifdef CONFIG_RTW_MESH
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0))
+		#error "CONFIG_RTW_MESH can't be enabled when kernel < 3.10.0\n"
+	#endif
+#endif
+
 struct rtw_wdev_invit_info {
 	u8 state; /* 0: req, 1:rep */
 	u8 peer_mac[ETH_ALEN];
@@ -130,7 +143,7 @@ struct rtw_wdev_priv {
 
 	_adapter *padapter;
 
-	#if !RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT
+	#if RTW_CFG80211_BLOCK_STA_DISCON_EVENT
 	u8 not_indic_disco;
 	#endif
 
@@ -160,6 +173,7 @@ struct rtw_wdev_priv {
 	u16 report_mgmt;
 
 	u8 is_mgmt_tx;
+	u16 mgmt_tx_cookie;
 
 	_mutex roch_mutex;
 
@@ -167,14 +181,27 @@ struct rtw_wdev_priv {
 	ATOMIC_T switch_ch_to;
 #endif
 
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+	u8 pno_mac_addr[ETH_ALEN];
+	u16 pno_scan_seq_num;
+#endif
+
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+        s8 rssi_monitor_max;
+        s8 rssi_monitor_min;
+        u8 rssi_monitor_enable;
+#endif
+
 };
 
-#if RTW_CFG80211_ALWAYS_INFORM_STA_DISCONNECT_EVENT
-#define rtw_wdev_not_indic_disco(rtw_wdev_data) 0
-#define rtw_wdev_set_not_indic_disco(rtw_wdev_data, val) do {} while (0)
-#else
+bool rtw_cfg80211_is_connect_requested(_adapter *adapter);
+
+#if RTW_CFG80211_BLOCK_STA_DISCON_EVENT
 #define rtw_wdev_not_indic_disco(rtw_wdev_data) ((rtw_wdev_data)->not_indic_disco)
 #define rtw_wdev_set_not_indic_disco(rtw_wdev_data, val) do { (rtw_wdev_data)->not_indic_disco = (val); } while (0)
+#else
+#define rtw_wdev_not_indic_disco(rtw_wdev_data) 0
+#define rtw_wdev_set_not_indic_disco(rtw_wdev_data, val) do {} while (0)
 #endif
 
 #define rtw_wdev_free_connect_req(rtw_wdev_data) \
@@ -262,12 +289,15 @@ void rtw_cfg80211_indicate_scan_done_for_buddy(_adapter *padapter, bool bscan_ab
 
 #ifdef CONFIG_AP_MODE
 void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len);
-void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, unsigned char *da, unsigned short reason);
+void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, const u8 *da, unsigned short reason);
 #endif /* CONFIG_AP_MODE */
 
 #ifdef CONFIG_P2P
 void rtw_cfg80211_set_is_roch(_adapter *adapter, bool val);
 bool rtw_cfg80211_get_is_roch(_adapter *adapter);
+bool rtw_cfg80211_is_ro_ch_once(_adapter *adapter);
+void rtw_cfg80211_set_last_ro_ch_time(_adapter *adapter);
+s32 rtw_cfg80211_get_last_ro_ch_passing_ms(_adapter *adapter);
 
 int rtw_cfg80211_iface_has_p2p_group_cap(_adapter *adapter);
 int rtw_cfg80211_is_p2p_scan(_adapter *adapter);
@@ -288,6 +318,7 @@ void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf,
 void rtw_cfg80211_rx_p2p_action_public(_adapter *padapter, union recv_frame *rframe);
 void rtw_cfg80211_rx_action_p2p(_adapter *padapter, union recv_frame *rframe);
 void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const char *msg);
+void rtw_cfg80211_rx_mframe(_adapter *adapter, union recv_frame *rframe, const char *msg);
 void rtw_cfg80211_rx_probe_request(_adapter *padapter, union recv_frame *rframe);
 
 int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len, int type);
@@ -339,7 +370,7 @@ void rtw_cfg80211_deinit_rfkill(struct wiphy *wiphy);
 
 #define rtw_cfg80211_connect_result(wdev, bssid, req_ie, req_ie_len, resp_ie, resp_ie_len, status, gfp) cfg80211_connect_result(wdev_to_ndev(wdev), bssid, req_ie, req_ie_len, resp_ie, resp_ie_len, status, gfp)
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 2, 0)) && !defined(CONFIG_PLATFORM_INTEL_CHT_ANDROID60)
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 2, 0))
 #define rtw_cfg80211_disconnected(wdev, reason, ie, ie_len, locally_generated, gfp) cfg80211_disconnected(wdev_to_ndev(wdev), reason, ie, ie_len, gfp)
 #else
 #define rtw_cfg80211_disconnected(wdev, reason, ie, ie_len, locally_generated, gfp) cfg80211_disconnected(wdev_to_ndev(wdev), reason, ie, ie_len, locally_generated, gfp)
@@ -353,6 +384,10 @@ void rtw_cfg80211_deinit_rfkill(struct wiphy *wiphy);
 #endif
 #endif
 
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
+#define rtw_cfg80211_notify_new_peer_candidate(wdev, addr, ie, ie_len, gfp) cfg80211_notify_new_peer_candidate(wdev_to_ndev(wdev), addr, ie, ie_len, gfp)
+#endif
+
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
 u8 rtw_cfg80211_ch_switch_notify(_adapter *adapter, u8 ch, u8 bw, u8 offset, u8 ht);
 #endif
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_linux.c
index 53233854829f..e6c602c7277a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_linux.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -37,6 +38,7 @@ extern int rtw_ht_enable;
 #define SCAN_ITEM_SIZE 768
 #define MAX_CUSTOM_LEN 64
 #define RATE_COUNT 4
+#define MAX_SCAN_BUFFER_LEN 65535
 
 #ifdef CONFIG_GLOBAL_UI_PID
 extern int ui_pid[3];
@@ -68,29 +70,6 @@ static const char *const iw_operation_mode[] = {
 	"Auto", "Ad-Hoc", "Managed",  "Master", "Repeater", "Secondary", "Monitor"
 };
 
-static int hex2num_i(char c)
-{
-	if (c >= '0' && c <= '9')
-		return c - '0';
-	if (c >= 'a' && c <= 'f')
-		return c - 'a' + 10;
-	if (c >= 'A' && c <= 'F')
-		return c - 'A' + 10;
-	return -1;
-}
-
-static int hex2byte_i(const char *hex)
-{
-	int a, b;
-	a = hex2num_i(*hex++);
-	if (a < 0)
-		return -1;
-	b = hex2num_i(*hex++);
-	if (b < 0)
-		return -1;
-	return (a << 4) | b;
-}
-
 /**
  * hwaddr_aton - Convert ASCII string to MAC address
  * @txt: MAC address as a string (e.g., "00:11:22:33:44:55")
@@ -120,7 +99,7 @@ static int hwaddr_aton_i(const char *txt, u8 *addr)
 
 static void indicate_wx_custom_event(_adapter *padapter, char *msg)
 {
-	u8 *buff, *p;
+	u8 *buff;
 	union iwreq_data wrqu;
 
 	if (strlen(msg) > IW_CUSTOM_MAX) {
@@ -207,7 +186,6 @@ void rtw_request_wps_pbc_event(_adapter *padapter)
 void indicate_wx_scan_complete_event(_adapter *padapter)
 {
 	union iwreq_data wrqu;
-	struct	mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
 	_rtw_memset(&wrqu, 0, sizeof(union iwreq_data));
 
@@ -443,16 +421,22 @@ static inline char *iwe_stream_protocol_process(_adapter *padapter,
 	char *p;
 	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12); /* Probe Request	 */
 
+#ifdef CONFIG_80211N_HT
 	/* parsing HT_CAP_IE	 */
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
-	if (p && ht_ielen > 0)
-		ht_cap = _TRUE;
+	if(padapter->registrypriv.ht_enable && is_supported_ht(padapter->registrypriv.wireless_mode)) {
+		p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
+		if (p && ht_ielen > 0)
+			ht_cap = _TRUE;
+	}
+#endif
 
 #ifdef CONFIG_80211AC_VHT
 	/* parsing VHT_CAP_IE */
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
-	if (p && vht_ielen > 0)
-		vht_cap = _TRUE;
+	if(padapter->registrypriv.wireless_mode & WIRELESS_11AC) {
+		p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
+		if (p && vht_ielen > 0)
+			vht_cap = _TRUE;
+	}
 #endif
 	/* Add the protocol name */
 	iwe->cmd = SIOCGIWNAME;
@@ -504,33 +488,36 @@ static inline char *iwe_stream_rate_process(_adapter *padapter,
 	u8 ie_offset = (pnetwork->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12); /* Probe Request	 */
 
 	/* parsing HT_CAP_IE	 */
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
-	if (p && ht_ielen > 0) {
-		struct rtw_ieee80211_ht_cap *pht_capie;
-		ht_cap = _TRUE;
-		pht_capie = (struct rtw_ieee80211_ht_cap *)(p + 2);
-		_rtw_memcpy(&mcs_rate , pht_capie->supp_mcs_set, 2);
-		bw_40MHz = (pht_capie->cap_info & IEEE80211_HT_CAP_SUP_WIDTH) ? 1 : 0;
-		short_GI = (pht_capie->cap_info & (IEEE80211_HT_CAP_SGI_20 | IEEE80211_HT_CAP_SGI_40)) ? 1 : 0;
+	if(is_supported_ht(padapter->registrypriv.wireless_mode)) {
+		p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], _HT_CAPABILITY_IE_, &ht_ielen, pnetwork->network.IELength - ie_offset);
+		if (p && ht_ielen > 0) {
+			struct rtw_ieee80211_ht_cap *pht_capie;
+			ht_cap = _TRUE;
+			pht_capie = (struct rtw_ieee80211_ht_cap *)(p + 2);
+			_rtw_memcpy(&mcs_rate , pht_capie->supp_mcs_set, 2);
+			bw_40MHz = (pht_capie->cap_info & IEEE80211_HT_CAP_SUP_WIDTH) ? 1 : 0;
+			short_GI = (pht_capie->cap_info & (IEEE80211_HT_CAP_SGI_20 | IEEE80211_HT_CAP_SGI_40)) ? 1 : 0;
+		}
 	}
-
 #ifdef CONFIG_80211AC_VHT
 	/* parsing VHT_CAP_IE */
-	p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
-	if (p && vht_ielen > 0) {
-		u8	mcs_map[2];
-
-		vht_cap = _TRUE;
-		bw_160MHz = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p + 2);
-		if (bw_160MHz)
-			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI160M(p + 2);
-		else
-			short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI80M(p + 2);
+	if(padapter->registrypriv.wireless_mode & WIRELESS_11AC){
+		p = rtw_get_ie(&pnetwork->network.IEs[ie_offset], EID_VHTCapability, &vht_ielen, pnetwork->network.IELength - ie_offset);
+		if (p && vht_ielen > 0) {
+			u8	mcs_map[2];
+
+			vht_cap = _TRUE;
+			bw_160MHz = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(p + 2);
+			if (bw_160MHz)
+				short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI160M(p + 2);
+			else
+				short_GI = GET_VHT_CAPABILITY_ELE_SHORT_GI80M(p + 2);
 
-		_rtw_memcpy(mcs_map, GET_VHT_CAPABILITY_ELE_TX_MCS(p + 2), 2);
+			_rtw_memcpy(mcs_map, GET_VHT_CAPABILITY_ELE_TX_MCS(p + 2), 2);
 
-		vht_highest_rate = rtw_get_vht_highest_rate(mcs_map);
-		vht_data_rate = rtw_vht_mcs_to_data_rate(CHANNEL_WIDTH_80, short_GI, vht_highest_rate);
+			vht_highest_rate = rtw_get_vht_highest_rate(mcs_map);
+			vht_data_rate = rtw_vht_mcs_to_data_rate(CHANNEL_WIDTH_80, short_GI, vht_highest_rate);
+		}
 	}
 #endif
 
@@ -720,8 +707,10 @@ static inline char   *iwe_stream_rssi_process(_adapter *padapter,
 		char *start, char *stop, struct iw_event *iwe)
 {
 	u8 ss, sq;
-	s16 noise = 0;
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
+#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
+	s16 noise = 0;
+#endif
 
 	/* Add quality statistics */
 	iwe->cmd = IWEVQUAL;
@@ -749,17 +738,7 @@ static inline char   *iwe_stream_rssi_process(_adapter *padapter,
 #ifdef CONFIG_SIGNAL_DISPLAY_DBM
 	iwe->u.qual.level = (u8) translate_percentage_to_dbm(ss); /* dbm */
 #else
-#ifdef CONFIG_SIGNAL_SCALE_MAPPING
 	iwe->u.qual.level = (u8)ss; /* % */
-#else
-	{
-		/* Do signal scale mapping when using percentage as the unit of signal strength, since the scale mapping is skipped in odm */
-
-		HAL_DATA_TYPE *pHal = GET_HAL_DATA(padapter);
-
-		iwe->u.qual.level = (u8)phydm_signal_scale_mapping(&pHal->odmpriv, ss);
-	}
-#endif
 #endif
 
 	iwe->u.qual.qual = (u8)sq;   /* signal quality */
@@ -792,7 +771,6 @@ static inline char   *iwe_stream_net_rsv_process(_adapter *padapter,
 {
 	u8 buf[32] = {0};
 	u8 *p, *pos;
-	int len;
 	p = buf;
 	pos = pnetwork->network.Reserved;
 
@@ -886,7 +864,7 @@ static int wpa_set_auth_algs(struct net_device *dev, u32 value)
 static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)
 {
 	int ret = 0;
-	u32 wep_key_idx, wep_key_len, wep_total_len;
+	u32 wep_key_idx, wep_key_len;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
@@ -931,7 +909,7 @@ static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param,
 		wep_key_idx = param->u.crypt.idx;
 		wep_key_len = param->u.crypt.key_len;
 
-		if ((wep_key_idx > WEP_KEYS) || (wep_key_len <= 0)) {
+		if ((wep_key_idx >= WEP_KEYS) || (wep_key_len <= 0)) {
 			ret = -EINVAL;
 			goto exit;
 		}
@@ -959,6 +937,7 @@ static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param,
 
 		psecuritypriv->key_mask |= BIT(wep_key_idx);
 
+		padapter->mlmeextpriv.mlmext_info.key_index = wep_key_idx;
 		goto exit;
 	}
 
@@ -980,25 +959,23 @@ static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param,
 					psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
 
 				if (param->u.crypt.set_tx == 1) { /* pairwise key */
+					RTW_INFO(FUNC_ADPT_FMT" set %s PTK idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
 					_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
 					if (strcmp(param->u.crypt.alg, "TKIP") == 0) { /* set mic key */
-						/* DEBUG_ERR(("\nset key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len)); */
 						_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
 						_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
 						padapter->securitypriv.busetkipkey = _FALSE;
 					}
-
-					/* DEBUG_ERR((" param->u.crypt.key_len=%d\n",param->u.crypt.key_len)); */
-					RTW_INFO(" ~~~~set sta key:unicastkey\n");
-
-					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
-
+					psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+					psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
 					psta->bpairwise_key_installed = _TRUE;
+					rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _TRUE);
 
 				} else { /* group key */
 					if (strcmp(param->u.crypt.alg, "TKIP") == 0 || strcmp(param->u.crypt.alg, "CCMP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set %s GTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.alg, param->u.crypt.idx, param->u.crypt.key_len);
 						_rtw_memcpy(padapter->securitypriv.dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key,
 							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
 						/* only TKIP group key need to install this */
@@ -1007,37 +984,31 @@ static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param,
 							_rtw_memcpy(padapter->securitypriv.dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
 						}
 						padapter->securitypriv.binstallGrpkey = _TRUE;
-						/* DEBUG_ERR((" param->u.crypt.key_len=%d\n", param->u.crypt.key_len)); */
-						if (param->u.crypt.idx < 4) 
-							_rtw_memcpy(padapter->securitypriv.iv_seq[param->u.crypt.idx], param->u.crypt.seq, 8);							
-						RTW_INFO(" ~~~~set sta key:groupkey\n");
-
+						if (param->u.crypt.idx < 4)
+							_rtw_memcpy(padapter->securitypriv.iv_seq[param->u.crypt.idx], param->u.crypt.seq, 8);
 						padapter->securitypriv.dot118021XGrpKeyid = param->u.crypt.idx;
-
 						rtw_set_key(padapter, &padapter->securitypriv, param->u.crypt.idx, 1, _TRUE);
-					}
-#ifdef CONFIG_IEEE80211W
-					else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
-						int no;
-						/* printk("BIP key_len=%d , index=%d @@@@@@@@@@@@@@@@@@\n", param->u.crypt.key_len, param->u.crypt.idx); */
-						/* save the IGTK key, length 16 bytes */
+
+					#ifdef CONFIG_IEEE80211W
+					} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+						RTW_INFO(FUNC_ADPT_FMT" set IGTK idx:%u, len:%u\n"
+							, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 						_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey,  param->u.crypt.key,
 							(param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-						/*printk("IGTK key below:\n");
-						for(no=0;no<16;no++)
-							printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-						printk("\n");*/
-						padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
-						padapter->securitypriv.binstallBIPkey = _TRUE;
-						RTW_INFO(" ~~~~set sta key:IGKT\n");
+						psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+						psecuritypriv->dot11wBIPrxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+						psecuritypriv->binstallBIPkey = _TRUE;
+					#endif /* CONFIG_IEEE80211W */
+
 					}
-#endif /* CONFIG_IEEE80211W */
 
 #ifdef CONFIG_P2P
 					if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
 						rtw_p2p_set_state(pwdinfo, P2P_STATE_PROVISIONING_DONE);
 #endif /* CONFIG_P2P */
 
+					/* WPA/WPA2 key-handshake has completed */
+					clr_fwstate(pmlmepriv, WIFI_UNDER_KEY_HANDSHAKE);
 				}
 			}
 
@@ -1058,61 +1029,8 @@ static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param,
 	}
 
 #ifdef CONFIG_WAPI_SUPPORT
-	if (strcmp(param->u.crypt.alg, "SMS4") == 0) {
-		PRT_WAPI_T			pWapiInfo = &padapter->wapiInfo;
-		PRT_WAPI_STA_INFO	pWapiSta;
-		u8					WapiASUEPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
-		u8					WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
-		u8					WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
-
-		if (param->u.crypt.set_tx == 1) {
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if (_rtw_memcmp(pWapiSta->PeerMacAddr, param->sta_addr, 6)) {
-					_rtw_memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
-
-					pWapiSta->wapiUsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiUsk.dataKey, param->u.crypt.key, 16);
-					_rtw_memcpy(pWapiSta->wapiUsk.micKey, param->u.crypt.key + 16, 16);
-					pWapiSta->wapiUsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiUsk.bTxEnable = true;
-
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiAEPNInitialValueSrc, 16);
-					_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
-					pWapiSta->wapiUskUpdate.bTxEnable = false;
-					pWapiSta->wapiUskUpdate.bSet = false;
-
-					if (psecuritypriv->sw_encrypt == false || psecuritypriv->sw_decrypt == false) {
-						/* set unicast key for ASUE */
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiUsk, pWapiSta, false, false);
-					}
-				}
-			}
-		} else {
-			list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
-				if (_rtw_memcmp(pWapiSta->PeerMacAddr, get_bssid(pmlmepriv), 6)) {
-					pWapiSta->wapiMsk.bSet = true;
-					_rtw_memcpy(pWapiSta->wapiMsk.dataKey, param->u.crypt.key, 16);
-					_rtw_memcpy(pWapiSta->wapiMsk.micKey, param->u.crypt.key + 16, 16);
-					pWapiSta->wapiMsk.keyId = param->u.crypt.idx ;
-					pWapiSta->wapiMsk.bTxEnable = false;
-					if (!pWapiSta->bSetkeyOk)
-						pWapiSta->bSetkeyOk = true;
-					pWapiSta->bAuthenticateInProgress = false;
-
-					_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
-
-					if (psecuritypriv->sw_decrypt == false) {
-						/* set rx broadcast key for ASUE */
-						rtw_wapi_set_key(padapter, &pWapiSta->wapiMsk, pWapiSta, true, false);
-					}
-				}
-
-			}
-		}
-	}
+	if (strcmp(param->u.crypt.alg, "SMS4") == 0)
+		rtw_wapi_set_set_encryption(padapter, param);
 #endif
 
 exit:
@@ -1124,8 +1042,8 @@ exit:
 static int rtw_set_wpa_ie(_adapter *padapter, char *pie, unsigned short ielen)
 {
 	u8 *buf = NULL, *pos = NULL;
-	u32 left;
 	int group_cipher = 0, pairwise_cipher = 0;
+	u8 mfp_opt = MFP_NO;
 	int ret = 0;
 	u8 null_addr[] = {0, 0, 0, 0, 0, 0};
 #ifdef CONFIG_P2P
@@ -1163,26 +1081,13 @@ static int rtw_set_wpa_ie(_adapter *padapter, char *pie, unsigned short ielen)
 			goto exit;
 		}
 
-#if 0
-		pos += RSN_HEADER_LEN;
-		left  = ielen - RSN_HEADER_LEN;
-
-		if (left >= RSN_SELECTOR_LEN) {
-			pos += RSN_SELECTOR_LEN;
-			left -= RSN_SELECTOR_LEN;
-		} else if (left > 0) {
-			ret = -1;
-			goto exit;
-		}
-#endif
-
 		if (rtw_parse_wpa_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
 			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
 			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPAPSK;
 			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);
 		}
 
-		if (rtw_parse_wpa2_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
+		if (rtw_parse_wpa2_ie(buf, ielen, &group_cipher, &pairwise_cipher, NULL, &mfp_opt) == _SUCCESS) {
 			padapter->securitypriv.dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
 			padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeWPA2PSK;
 			_rtw_memcpy(padapter->securitypriv.supplicant_ie, &buf[0], ielen);
@@ -1239,6 +1144,13 @@ static int rtw_set_wpa_ie(_adapter *padapter, char *pie, unsigned short ielen)
 			break;
 		}
 
+		if (mfp_opt == MFP_INVALID) {
+			RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
+			ret = -EINVAL;
+			goto exit;
+		}
+		padapter->securitypriv.mfp_opt = mfp_opt;
+
 		_clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
 		{/* set wps_ie	 */
 			u16 cnt = 0;
@@ -1292,7 +1204,6 @@ static int rtw_wx_get_name(struct net_device *dev,
 			   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	u16 cap;
 	u32 ht_ielen = 0;
 	char *p;
 	u8 ht_cap = _FALSE, vht_cap = _FALSE;
@@ -1304,17 +1215,18 @@ static int rtw_wx_get_name(struct net_device *dev,
 
 	if (check_fwstate(pmlmepriv, _FW_LINKED | WIFI_ADHOC_MASTER_STATE) == _TRUE) {
 		/* parsing HT_CAP_IE */
-		p = rtw_get_ie(&pcur_bss->IEs[12], _HT_CAPABILITY_IE_, &ht_ielen, pcur_bss->IELength - 12);
-		if (p && ht_ielen > 0)
-			ht_cap = _TRUE;
-
+		if( is_supported_ht(padapter->registrypriv.wireless_mode)&&(padapter->registrypriv.ht_enable)) {
+			p = rtw_get_ie(&pcur_bss->IEs[12], _HT_CAPABILITY_IE_, &ht_ielen, pcur_bss->IELength - 12);
+			if (p && ht_ielen > 0 )
+				ht_cap = _TRUE;
+		}
 #ifdef CONFIG_80211AC_VHT
-		if (pmlmepriv->vhtpriv.vht_option == _TRUE)
+		if ((padapter->registrypriv.wireless_mode & WIRELESS_11AC) &&
+			(pmlmepriv->vhtpriv.vht_option == _TRUE))
 			vht_cap = _TRUE;
 #endif
 
 		prates = &pcur_bss->SupportedRates;
-
 		if (rtw_is_cckratesonly_included((u8 *)prates) == _TRUE) {
 			if (ht_cap == _TRUE)
 				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bn");
@@ -1323,8 +1235,12 @@ static int rtw_wx_get_name(struct net_device *dev,
 		} else if ((rtw_is_cckrates_included((u8 *)prates)) == _TRUE) {
 			if (ht_cap == _TRUE)
 				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bgn");
-			else
-				snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bg");
+			else {
+				if(padapter->registrypriv.wireless_mode & WIRELESS_11G)
+					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11bg");
+				else
+					snprintf(wrqu->name, IFNAMSIZ, "IEEE 802.11b");
+			}
 		} else {
 			if (pcur_bss->Configuration.DSConfig > 14) {
 #ifdef CONFIG_80211AC_VHT
@@ -1361,12 +1277,8 @@ static int rtw_wx_set_freq(struct net_device *dev,
 {
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	struct wlan_network  *cur_network = &(pmlmepriv->cur_network);
 	int exp = 1, freq = 0, div = 0;
 
-
 	rtw_ps_deny(padapter, PS_DENY_IOCTL);
 	if (rtw_pwr_wakeup(padapter) == _FALSE)
 		goto exit;
@@ -1447,6 +1359,7 @@ static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	NDIS_802_11_NETWORK_INFRASTRUCTURE networkType ;
 	int ret = 0;
+	u32 val32 = 0;
 
 
 	if (_FAIL == rtw_pwr_wakeup(padapter)) {
@@ -1495,7 +1408,6 @@ static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,
 	case IW_MODE_MASTER:
 		networkType = Ndis802_11APMode;
 		RTW_INFO("set_mode = IW_MODE_MASTER\n");
-		/* rtw_setopmode_cmd(padapter, networkType,_TRUE);	 */
 		break;
 	case IW_MODE_INFRA:
 		networkType = Ndis802_11Infrastructure;
@@ -1507,17 +1419,6 @@ static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,
 		goto exit;
 	}
 
-	/*
-		if(Ndis802_11APMode == networkType)
-		{
-			rtw_setopmode_cmd(padapter, networkType,_TRUE);
-		}
-		else
-		{
-			rtw_setopmode_cmd(padapter, Ndis802_11AutoUnknown,_TRUE);
-		}
-	*/
-
 	if (rtw_set_802_11_infrastructure_mode(padapter, networkType) == _FALSE) {
 
 		ret = -EPERM;
@@ -1525,7 +1426,11 @@ static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,
 
 	}
 
-	rtw_setopmode_cmd(padapter, networkType, _TRUE);
+	rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
+
+	//WIFIDBG
+	val32 = rtw_read32(padapter, REG_RCR);
+	RTW_INFO("[WIFIDBG] %s() networkType : %d REG_RCR : 0x%08X\n", __func__, networkType, val32);
 
 	if (check_fwstate(pmlmepriv, WIFI_MONITOR_STATE) == _TRUE)
 		rtw_indicate_connect(padapter);
@@ -1571,7 +1476,6 @@ static int rtw_wx_set_pmkid(struct net_device *dev,
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	u8          j, blInserted = _FALSE;
 	int         intReturn = _FALSE;
-	struct mlme_priv  *pmlmepriv = &padapter->mlmepriv;
 	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	struct iw_pmksa  *pPMK = (struct iw_pmksa *) extra;
 	u8     strZeroMacAddress[ETH_ALEN] = { 0x00 };
@@ -1680,8 +1584,6 @@ static int rtw_wx_get_range(struct net_device *dev,
 	struct iw_range *range = (struct iw_range *)extra;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-
 	u16 val;
 	int i;
 
@@ -1722,7 +1624,6 @@ static int rtw_wx_get_range(struct net_device *dev,
 	 * If percentage range is 0~100
 	 * Signal strength dbm range logical is -100 ~ 0
 	 * but usually value is -90 ~ -20
-	 * When CONFIG_SIGNAL_SCALE_MAPPING is defined, dbm range is -95 ~ -45
 	 */
 	range->max_qual.qual = 100;
 #ifdef CONFIG_SIGNAL_DISPLAY_DBM
@@ -2032,18 +1933,53 @@ static int rtw_wx_set_scan(struct net_device *dev, struct iw_request_info *a,
 	u8 _status = _FALSE;
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+	/*struct mlme_priv *pmlmepriv = &padapter->mlmepriv;*/
 	struct sitesurvey_parm parm;
-
+	u8 ssc_chk;
 #ifdef CONFIG_P2P
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 #endif /* CONFIG_P2P */
 
-
 #ifdef DBG_IOCTL
 	RTW_INFO("DBG_IOCTL %s:%d\n", __FUNCTION__, __LINE__);
 #endif
 
+#if 1
+	ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
+
+	#ifdef CONFIG_DOSCAN_IN_BUSYTRAFFIC
+	if ((ssc_chk != SS_ALLOW) && (ssc_chk != SS_DENY_BUSY_TRAFFIC))
+	#else
+	/* When Busy Traffic, driver do not site survey. So driver return success. */
+	/* wpa_supplicant will not issue SIOCSIWSCAN cmd again after scan timeout. */
+	/* modify by thomas 2011-02-22. */
+	if (ssc_chk != SS_ALLOW)
+	#endif
+	{
+		if (ssc_chk == SS_DENY_MP_MODE)
+			ret = -EPERM;
+		#ifdef DBG_LA_MODE
+		else if (ssc_chk == SS_DENY_LA_MODE)
+			ret = -EPERM;
+		#endif
+		else
+			indicate_wx_scan_complete_event(padapter);
+
+		goto exit;
+	} else
+		RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
+
+	rtw_ps_deny(padapter, PS_DENY_SCAN);
+	if (_FAIL == rtw_pwr_wakeup(padapter)) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+	if (!rtw_is_adapter_up(padapter)) {
+		ret = -1;
+		goto cancel_ps_deny;
+	}
+#else
+
 #ifdef CONFIG_MP_INCLUDED
 	if (rtw_mp_mode_check(padapter)) {
 		RTW_INFO("MP mode block Scan request\n");
@@ -2102,6 +2038,7 @@ static int rtw_wx_set_scan(struct net_device *dev, struct iw_request_info *a,
 		goto cancel_ps_deny;
 	}
 #endif
+#endif
 
 #ifdef CONFIG_P2P
 	if (pwdinfo->p2p_state != P2P_STATE_NONE) {
@@ -2243,15 +2180,17 @@ static int rtw_wx_get_scan(struct net_device *dev, struct iw_request_info *a,
 	_irqL	irqL;
 	_list					*plist, *phead;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
+	RT_CHANNEL_INFO *chset = rfctl->channel_set;
 	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
 	_queue				*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
 	char *ev = extra;
 	char *stop = ev + wrqu->data.length;
 	u32 ret = 0;
-	u32 cnt = 0;
 	u32 wait_for_surveydone;
 	sint wait_status;
+	u8 ch;
 
 #ifdef CONFIG_P2P
 	struct	wifidirect_info	*pwdinfo = &padapter->wdinfo;
@@ -2313,17 +2252,26 @@ static int rtw_wx_get_scan(struct net_device *dev, struct iw_request_info *a,
 			break;
 
 		if ((stop - ev) < SCAN_ITEM_SIZE) {
+			if(wrqu->data.length == MAX_SCAN_BUFFER_LEN){ /*max buffer len defined by iwlist*/
+				ret = 0;
+				RTW_INFO("%s: Scan results incomplete\n", __FUNCTION__);
+				break;
+			}
 			ret = -E2BIG;
 			break;
 		}
 
 		pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
+		ch = pnetwork->network.Configuration.DSConfig;
 
 		/* report network only if the current channel set contains the channel to which this network belongs */
-		if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
-		    && rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
-		    && _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
-		   )
+		if (rtw_chset_search_ch(chset, ch) >= 0
+			&& rtw_mlme_band_check(padapter, ch) == _TRUE
+			&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))
+			&& (!IS_DFS_SLAVE_WITH_RD(rfctl)
+				|| rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
+				|| !rtw_chset_is_ch_non_ocp(chset, ch))
+		)
 			ev = translate_scan(padapter, a, pnetwork, ev, stop);
 
 		plist = get_next(plist);
@@ -2360,7 +2308,6 @@ static int rtw_wx_set_essid(struct net_device *dev,
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	_queue *queue = &pmlmepriv->scanned_queue;
 	_list *phead;
-	s8 status = _TRUE;
 	struct wlan_network *pnetwork = NULL;
 	NDIS_802_11_AUTHENTICATION_MODE authmode;
 	NDIS_802_11_SSID ndis_ssid;
@@ -3001,11 +2948,14 @@ static int rtw_wx_set_auth(struct net_device *dev,
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_param *param = (struct iw_param *)&(wrqu->param);
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-	struct security_priv *psecuritypriv = &padapter->securitypriv;
+#ifdef CONFIG_WAPI_SUPPORT
+#ifndef CONFIG_IOCTL_CFG80211
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
+	struct security_priv *psecuritypriv = &padapter->securitypriv;
 	u32 value = param->value;
+#endif
+#endif
 	int ret = 0;
 
 	switch (param->flags & IW_AUTH_INDEX) {
@@ -3095,10 +3045,10 @@ static int rtw_wx_set_auth(struct net_device *dev,
 		*/
 		if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
 			LeaveAllPowerSaveMode(padapter);
-			rtw_disassoc_cmd(padapter, 500, RTW_CMDF_DIRECTLY);
+			rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
 			RTW_INFO("%s...call rtw_indicate_disconnect\n ", __FUNCTION__);
 			rtw_indicate_disconnect(padapter, 0, _FALSE);
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources_cmd(padapter, _TRUE, RTW_CMDF_WAIT_ACK);
 		}
 #endif
 
@@ -3503,7 +3453,6 @@ static int rtw_wx_set_channel_plan(struct net_device *dev,
 				   union iwreq_data *wrqu, char *extra)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	u8 channel_plan_req = (u8)(*((int *)wrqu));
 
 	if (_SUCCESS != rtw_set_channel_plan(padapter, channel_plan_req))
@@ -3762,7 +3711,7 @@ static int rtw_get_ap_info(struct net_device *dev,
 			   struct iw_request_info *info,
 			   union iwreq_data *wrqu, char *extra)
 {
-	int bssid_match, ret = 0;
+	int ret = 0;
 	u32 cnt = 0, wpa_ielen;
 	_irqL	irqL;
 	_list	*plist, *phead;
@@ -3936,8 +3885,6 @@ static int rtw_wext_p2p_enable(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 	enum P2P_ROLE init_role = P2P_ROLE_DISABLE;
@@ -4003,8 +3950,6 @@ static int rtw_p2p_set_go_nego_ssid(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
 
 	RTW_INFO("[%s] ssid = %s, len = %zu\n", __FUNCTION__, extra, strlen(extra));
@@ -4169,7 +4114,6 @@ static int rtw_p2p_get_status(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	if (padapter->bShowGetP2PState) {
@@ -4200,7 +4144,6 @@ static int rtw_p2p_get_req_cm(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	sprintf(extra, "\n\nCM=%s\n", pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req);
@@ -4217,10 +4160,8 @@ static int rtw_p2p_get_role(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
-
 	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
 		pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1], pwdinfo->p2p_peer_interface_addr[2],
 		pwdinfo->p2p_peer_interface_addr[3], pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
@@ -4239,7 +4180,6 @@ static int rtw_p2p_get_peer_ifaddr(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
@@ -4263,7 +4203,6 @@ static int rtw_p2p_get_peer_devaddr(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
@@ -4287,7 +4226,6 @@ static int rtw_p2p_get_peer_devaddr_by_invitation(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	RTW_INFO("[%s] Role = %d, Status = %d, peer addr = %.2X:%.2X:%.2X:%.2X:%.2X:%.2X\n", __FUNCTION__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo),
@@ -4311,7 +4249,6 @@ static int rtw_p2p_get_groupid(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	sprintf(extra, "\n%.2X:%.2X:%.2X:%.2X:%.2X:%.2X %s",
@@ -4332,7 +4269,6 @@ static int rtw_p2p_get_op_ch(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 
@@ -4424,7 +4360,6 @@ static int rtw_p2p_get_peer_wfd_port(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	RTW_INFO("[%s] p2p_state = %d\n", __FUNCTION__, rtw_p2p_state(pwdinfo));
@@ -4444,7 +4379,6 @@ static int rtw_p2p_get_peer_wfd_preferred_connection(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	sprintf(extra, "\n\nwfd_pc=%d\n", pwdinfo->wfd_info->wfd_pc);
@@ -4463,7 +4397,6 @@ static int rtw_p2p_get_peer_wfd_session_available(struct net_device *dev,
 
 	int ret = 0;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point *pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 
 	sprintf(extra, "\n\nwfd_sa=%d\n", pwdinfo->wfd_info->peer_session_avail);
@@ -4797,7 +4730,6 @@ static int rtw_p2p_connect(struct net_device *dev,
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	u8					peerMAC[ETH_ALEN] = { 0x00 };
 	int					jj, kk;
-	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	_irqL				irqL;
 	_list					*plist, *phead;
@@ -4933,16 +4865,14 @@ static int rtw_p2p_invite_req(struct net_device *dev,
 
 	int ret = 0;
 	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point			*pdata = &wrqu->data;
 	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
 	int						jj, kk;
-	u8						peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
 	_list						*plist, *phead;
 	_queue					*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network		*pnetwork = NULL;
 	uint						uintPeerChannel = 0;
-	u8						attr_content[50] = { 0x00 }, _status = 0;
+	u8						attr_content[50] = { 0x00 };
 	u8						*p2pie;
 	uint						p2pielen = 0, attr_contentlen = 0;
 	_irqL					irqL;
@@ -5116,20 +5046,7 @@ static int rtw_p2p_set_persistent(struct net_device *dev,
 
 	int ret = 0;
 	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point			*pdata = &wrqu->data;
 	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
-	int						jj, kk;
-	u8						peerMACStr[ETH_ALEN * 2] = { 0x00 };
-	struct mlme_priv			*pmlmepriv = &padapter->mlmepriv;
-	_list						*plist, *phead;
-	_queue					*queue	= &(pmlmepriv->scanned_queue);
-	struct	wlan_network		*pnetwork = NULL;
-	uint						uintPeerChannel = 0;
-	u8						attr_content[50] = { 0x00 }, _status = 0;
-	u8						*p2pie;
-	uint						p2pielen = 0, attr_contentlen = 0;
-	_irqL					irqL;
-	struct tx_invite_req_info	*pinvite_req_info = &pwdinfo->invitereq_info;
 
 	/*	Commented by Albert 20120328 */
 	/*	The input data is 0 or 1 */
@@ -5157,23 +5074,6 @@ exit:
 
 }
 
-static int hexstr2bin(const char *hex, u8 *buf, size_t len)
-{
-	size_t i;
-	int a;
-	const char *ipos = hex;
-	u8 *opos = buf;
-
-	for (i = 0; i < len; i++) {
-		a = hex2byte_i(ipos);
-		if (a < 0)
-			return -1;
-		*opos++ = a;
-		ipos += 2;
-	}
-	return 0;
-}
-
 static int uuid_str2bin(const char *str, u8 *bin)
 {
 	const char *pos;
@@ -5237,16 +5137,14 @@ static int rtw_p2p_set_pc(struct net_device *dev,
 
 	int ret = 0;
 	_adapter				*padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point		*pdata = &wrqu->data;
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	u8					peerMAC[ETH_ALEN] = { 0x00 };
 	int					jj, kk;
-	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	_list					*plist, *phead;
 	_queue				*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
-	u8					attr_content[50] = { 0x00 }, _status = 0;
+	u8					attr_content[50] = { 0x00 };
 	u8 *p2pie;
 	uint					p2pielen = 0, attr_contentlen = 0;
 	_irqL				irqL;
@@ -5353,7 +5251,6 @@ static int rtw_p2p_set_wfd_device_type(struct net_device *dev,
 
 	int ret = 0;
 	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point			*pdata = &wrqu->data;
 	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
 	struct wifi_display_info		*pwfd_info = pwdinfo->wfd_info;
 
@@ -5427,9 +5324,7 @@ static int rtw_p2p_set_sa(struct net_device *dev,
 
 	int ret = 0;
 	_adapter					*padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct iw_point			*pdata = &wrqu->data;
 	struct wifidirect_info		*pwdinfo = &(padapter->wdinfo);
-	struct wifi_display_info		*pwfd_info = pwdinfo->wfd_info;
 
 	RTW_INFO("[%s] data = %s\n", __FUNCTION__, extra);
 
@@ -5462,13 +5357,12 @@ static int rtw_p2p_prov_disc(struct net_device *dev,
 	struct wifidirect_info	*pwdinfo = &(padapter->wdinfo);
 	u8					peerMAC[ETH_ALEN] = { 0x00 };
 	int					jj, kk;
-	u8					peerMACStr[ETH_ALEN * 2] = { 0x00 };
 	struct mlme_priv		*pmlmepriv = &padapter->mlmepriv;
 	_list					*plist, *phead;
 	_queue				*queue	= &(pmlmepriv->scanned_queue);
 	struct	wlan_network	*pnetwork = NULL;
 	uint					uintPeerChannel = 0;
-	u8					attr_content[100] = { 0x00 }, _status = 0;
+	u8					attr_content[100] = { 0x00 };
 	u8 *p2pie;
 	uint					p2pielen = 0, attr_contentlen = 0;
 	_irqL				irqL;
@@ -5722,15 +5616,9 @@ static int rtw_p2p_set(struct net_device *dev,
 		       struct iw_request_info *info,
 		       union iwreq_data *wrqu, char *extra)
 {
-
 	int ret = 0;
 #ifdef CONFIG_P2P
-
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 
 	RTW_INFO("[%s] extra = %s\n", __FUNCTION__, extra);
 
@@ -5816,16 +5704,9 @@ static int rtw_p2p_get(struct net_device *dev,
 		       struct iw_request_info *info,
 		       union iwreq_data *wrqu, char *extra)
 {
-
 	int ret = 0;
-
 #ifdef CONFIG_P2P
-
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
-	struct iw_point *pdata = &wrqu->data;
-	struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
-	struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
 
 	if (padapter->bShowGetP2PState)
 		RTW_INFO("[%s] extra = %s\n", __FUNCTION__, (char *) wrqu->data.pointer);
@@ -5976,10 +5857,6 @@ static int rtw_rereg_nd_name(struct net_device *dev,
 		goto exit;
 
 	if (_rtw_memcmp(rereg_priv->old_ifname, "disable%d", 9) == _TRUE) {
-		#ifdef CONFIG_RTW_SW_LED
-		padapter->ledpriv.bRegUseLed = rereg_priv->old_bRegUseLed;
-		rtw_hal_sw_led_init(padapter);
-		#endif
 		/* rtw_ips_mode_req(&padapter->pwrctrlpriv, rereg_priv->old_ips_mode); */
 	}
 
@@ -5992,13 +5869,6 @@ static int rtw_rereg_nd_name(struct net_device *dev,
 		/* free network queue for Android's timming issue */
 		rtw_free_network_queue(padapter, _TRUE);
 
-		/* close led */
-		rtw_led_control(padapter, LED_CTL_POWER_OFF);
-		#ifdef CONFIG_RTW_SW_LED
-		rereg_priv->old_bRegUseLed = padapter->ledpriv.bRegUseLed;
-		padapter->ledpriv.bRegUseLed = _FALSE;
-		rtw_hal_sw_led_deinit(padapter);
-		#endif
 		/* the interface is being "disabled", we can do deeper IPS */
 		/* rereg_priv->old_ips_mode = rtw_get_ips_mode_req(&padapter->pwrctrlpriv); */
 		/* rtw_ips_mode_req(&padapter->pwrctrlpriv, IPS_NORMAL); */
@@ -6017,11 +5887,7 @@ exit:
 #ifdef DBG_CMD_QUEUE
 u8 dump_cmd_id = 0;
 #endif
-/*
-#ifdef DBG_DUMP_TSF_BY_PORT
-extern void get_tsf_by_port(_adapter *adapter, u8 *tsftr, u8 hw_port);
-#endif
-*/
+
 static int rtw_dbg_port(struct net_device *dev,
 			struct iw_request_info *info,
 			union iwreq_data *wrqu, char *extra)
@@ -6305,11 +6171,6 @@ static int rtw_dbg_port(struct net_device *dev,
 				psecuritypriv->dot11AuthAlgrthm, psecuritypriv->dot11PrivacyAlgrthm,
 				psecuritypriv->ndisauthtype, psecuritypriv->ndisencryptstatus);
 			break;
-		case 0x02:
-			RTW_INFO("pmlmeinfo->state=0x%x\n", pmlmeinfo->state);
-			RTW_INFO("DrvBcnEarly=%d\n", pmlmeext->DrvBcnEarly);
-			RTW_INFO("DrvBcnTimeOut=%d\n", pmlmeext->DrvBcnTimeOut);
-			break;
 		case 0x03:
 			RTW_INFO("qos_option=%d\n", pmlmepriv->qospriv.qos_option);
 #ifdef CONFIG_80211N_HT
@@ -6348,12 +6209,10 @@ static int rtw_dbg_port(struct net_device *dev,
 				RTW_INFO("can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
 			break;
 		case 0x06: {
-				#ifdef DBG_DUMP_TSF_BY_PORT
 				u64 tsf = 0;
 
-				get_tsf_by_port(padapter, (u8 *)&tsf, extra_arg);
-				RTW_INFO(" PORT-%d TSF :%lld\n", extra_arg, tsf);
-				#endif
+				tsf = rtw_hal_get_tsftr_by_port(padapter, extra_arg);
+				RTW_INFO(" PORT-%d TSF :%21lld\n", extra_arg, tsf);
 		}
 			break;
 		case 0x07:
@@ -6381,7 +6240,8 @@ static int rtw_dbg_port(struct net_device *dev,
 			_list	*plist, *phead;
 
 #ifdef CONFIG_AP_MODE
-			RTW_INFO("sta_dz_bitmap=0x%x, tim_bitmap=0x%x\n", pstapriv->sta_dz_bitmap, pstapriv->tim_bitmap);
+			RTW_INFO_DUMP("sta_dz_bitmap:", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
+			RTW_INFO_DUMP("tim_bitmap:", pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
 #endif
 			_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
 
@@ -6709,9 +6569,6 @@ static int rtw_dbg_port(struct net_device *dev,
 			{
 				if (arg == 0xAA) {
 					u8 page_offset, page_num;
-					u32 page_size = 0;
-					u8 *buffer = NULL;
-					u32 buf_size = 0;
 
 					page_offset = (u8)(extra_arg >> 16);
 					page_num = (u8)(extra_arg & 0xFF);
@@ -6864,7 +6721,6 @@ static int rtw_dbg_port(struct net_device *dev,
 static int wpa_set_param(struct net_device *dev, u8 name, u32 value)
 {
 	uint ret = 0;
-	u32 flags;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 
 	switch (name) {
@@ -7201,72 +7057,61 @@ static int rtw_set_encryption(struct net_device *dev, struct ieee_param *param,
 	if (!psta && check_fwstate(pmlmepriv, WIFI_AP_STATE)) /*  */ { /* group key */
 		if (param->u.crypt.set_tx == 1) {
 			if (strcmp(param->u.crypt.alg, "WEP") == 0) {
-				RTW_INFO("%s, set group_key, WEP\n", __FUNCTION__);
-
+				RTW_INFO(FUNC_ADPT_FMT" set WEP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
 				psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
 				if (param->u.crypt.key_len == 13)
 					psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
 
 			} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
-				RTW_INFO("%s, set group_key, TKIP\n", __FUNCTION__);
-
+				RTW_INFO(FUNC_ADPT_FMT" set TKIP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
-
 				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
-				/* DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len); */
 				/* set mic key */
 				_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
 				_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
-
 				psecuritypriv->busetkipkey = _TRUE;
 
 			} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
-				RTW_INFO("%s, set group_key, CCMP\n", __FUNCTION__);
-
+				RTW_INFO(FUNC_ADPT_FMT" set CCMP TX GTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				psecuritypriv->dot118021XGrpPrivacy = _AES_;
-
 				_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-			}
-#ifdef CONFIG_IEEE80211W
-			else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
-				int no;
 
-				RTW_INFO("BIP key_len=%d , index=%d\n", param->u.crypt.key_len, param->u.crypt.idx);
-				/* save the IGTK key, length 16 bytes */
+			#ifdef CONFIG_IEEE80211W
+			} else if (strcmp(param->u.crypt.alg, "BIP") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" set TX IGTK idx:%u, len:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx, param->u.crypt.key_len);
 				_rtw_memcpy(padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey, param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-				/* RTW_INFO("IGTK key below:\n");
-				for(no=0;no<16;no++)
-					printk(" %02x ", padapter->securitypriv.dot11wBIPKey[param->u.crypt.idx].skey[no]);
-				RTW_INFO("\n"); */
-				padapter->securitypriv.dot11wBIPKeyid = param->u.crypt.idx;
-				padapter->securitypriv.binstallBIPkey = _TRUE;
-				RTW_INFO(" ~~~~set sta key:IGKT\n");
+				psecuritypriv->dot11wBIPKeyid = param->u.crypt.idx;
+				psecuritypriv->dot11wBIPtxpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psecuritypriv->binstallBIPkey = _TRUE;
 				goto exit;
-			}
-#endif /* CONFIG_IEEE80211W */
-			else {
-				RTW_INFO("%s, set group_key, none\n", __FUNCTION__);
+			#endif /* CONFIG_IEEE80211W */
 
+			} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+				RTW_INFO(FUNC_ADPT_FMT" clear group key, idx:%u\n"
+					, FUNC_ADPT_ARG(padapter), param->u.crypt.idx);
 				psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key, not support\n"
+					, FUNC_ADPT_ARG(padapter));
+				goto exit;
 			}
 
 			psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
-			psecuritypriv->binstallGrpkey = _TRUE;
-
-			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
-
-			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
-
 			pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
 			if (pbcmc_sta) {
+				pbcmc_sta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
 				pbcmc_sta->ieee8021x_blocked = _FALSE;
 				pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
 			}
+			psecuritypriv->binstallGrpkey = _TRUE;
+			psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
 
+			rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
 		}
 
 		goto exit;
@@ -7279,80 +7124,58 @@ static int rtw_set_encryption(struct net_device *dev, struct ieee_param *param,
 				_rtw_memcpy(psta->dot118021x_UncstKey.skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
 
 				if (strcmp(param->u.crypt.alg, "WEP") == 0) {
-					RTW_INFO("%s, set pairwise key, WEP\n", __FUNCTION__);
-
+					RTW_INFO(FUNC_ADPT_FMT" set WEP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
 					psta->dot118021XPrivacy = _WEP40_;
 					if (param->u.crypt.key_len == 13)
 						psta->dot118021XPrivacy = _WEP104_;
-				} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
-					RTW_INFO("%s, set pairwise key, TKIP\n", __FUNCTION__);
 
+				} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" set TKIP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
 					psta->dot118021XPrivacy = _TKIP_;
-
-					/* DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len); */
 					/* set mic key */
 					_rtw_memcpy(psta->dot11tkiptxmickey.skey, &(param->u.crypt.key[16]), 8);
 					_rtw_memcpy(psta->dot11tkiprxmickey.skey, &(param->u.crypt.key[24]), 8);
-
 					psecuritypriv->busetkipkey = _TRUE;
 
 				} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
-
-					RTW_INFO("%s, set pairwise key, CCMP\n", __FUNCTION__);
-
+					RTW_INFO(FUNC_ADPT_FMT" set CCMP PTK of "MAC_FMT" idx:%u, len:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx, param->u.crypt.key_len);
 					psta->dot118021XPrivacy = _AES_;
-				} else {
-					RTW_INFO("%s, set pairwise key, none\n", __FUNCTION__);
 
+				} else if (strcmp(param->u.crypt.alg, "none") == 0) {
+					RTW_INFO(FUNC_ADPT_FMT" clear pairwise key of "MAC_FMT" idx:%u\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
+						, param->u.crypt.idx);
 					psta->dot118021XPrivacy = _NO_PRIVACY_;
-				}
 
-				rtw_ap_set_pairwise_key(padapter, psta);
+				} else {
+					RTW_WARN(FUNC_ADPT_FMT" set pairwise key of "MAC_FMT", not support\n"
+						, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+					goto exit;
+				}
 
+				psta->dot11txpn.val = RTW_GET_LE64(param->u.crypt.seq);
+				psta->dot11rxpn.val = RTW_GET_LE64(param->u.crypt.seq);
 				psta->ieee8021x_blocked = _FALSE;
 
-				psta->bpairwise_key_installed = _TRUE;
-
-			} else { /* group key??? */
-				if (strcmp(param->u.crypt.alg, "WEP") == 0) {
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
-					psecuritypriv->dot118021XGrpPrivacy = _WEP40_;
-					if (param->u.crypt.key_len == 13)
-						psecuritypriv->dot118021XGrpPrivacy = _WEP104_;
-				} else if (strcmp(param->u.crypt.alg, "TKIP") == 0) {
-					psecuritypriv->dot118021XGrpPrivacy = _TKIP_;
-
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-
-					/* DEBUG_ERR("set key length :param->u.crypt.key_len=%d\n", param->u.crypt.key_len); */
-					/* set mic key */
-					_rtw_memcpy(psecuritypriv->dot118021XGrptxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[16]), 8);
-					_rtw_memcpy(psecuritypriv->dot118021XGrprxmickey[param->u.crypt.idx].skey, &(param->u.crypt.key[24]), 8);
-
-					psecuritypriv->busetkipkey = _TRUE;
-
-				} else if (strcmp(param->u.crypt.alg, "CCMP") == 0) {
-					psecuritypriv->dot118021XGrpPrivacy = _AES_;
-
-					_rtw_memcpy(psecuritypriv->dot118021XGrpKey[param->u.crypt.idx].skey,  param->u.crypt.key, (param->u.crypt.key_len > 16 ? 16 : param->u.crypt.key_len));
-				} else
-					psecuritypriv->dot118021XGrpPrivacy = _NO_PRIVACY_;
-
-				psecuritypriv->dot118021XGrpKeyid = param->u.crypt.idx;
-
-				psecuritypriv->binstallGrpkey = _TRUE;
-
-				psecuritypriv->dot11PrivacyAlgrthm = psecuritypriv->dot118021XGrpPrivacy;/* !!! */
-
-				rtw_ap_set_group_key(padapter, param->u.crypt.key, psecuritypriv->dot118021XGrpPrivacy, param->u.crypt.idx);
+				if (psta->dot118021XPrivacy != _NO_PRIVACY_) {
+					psta->bpairwise_key_installed = _TRUE;
 
-				pbcmc_sta = rtw_get_bcmc_stainfo(padapter);
-				if (pbcmc_sta) {
-					pbcmc_sta->ieee8021x_blocked = _FALSE;
-					pbcmc_sta->dot118021XPrivacy = psecuritypriv->dot118021XGrpPrivacy; /* rx will use bmc_sta's dot118021XPrivacy			 */
+					/* WPA2 key-handshake has completed */
+					if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK)
+						psta->state &= (~WIFI_UNDER_KEY_HANDSHAKE);
 				}
 
+				rtw_ap_set_pairwise_key(padapter, psta);
+			} else {
+				RTW_WARN(FUNC_ADPT_FMT" set group key of "MAC_FMT", not support\n"
+					, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
+				goto exit;
 			}
 
 		}
@@ -7419,7 +7242,6 @@ static int rtw_hostapd_sta_flush(struct net_device *dev)
 
 static int rtw_add_sta(struct net_device *dev, struct ieee_param *param)
 {
-	_irqL irqL;
 	int ret = 0;
 	struct sta_info *psta = NULL;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
@@ -7471,7 +7293,9 @@ static int rtw_add_sta(struct net_device *dev, struct ieee_param *param)
 
 #ifdef CONFIG_80211N_HT
 		/* chec 802.11n ht cap. */
-		if (WLAN_STA_HT & flags) {
+		if (padapter->registrypriv.ht_enable &&
+			is_supported_ht(padapter->registrypriv.wireless_mode) &&
+			(WLAN_STA_HT & flags)) {
 			psta->htpriv.ht_option = _TRUE;
 			psta->qos_option = 1;
 			_rtw_memcpy((void *)&psta->htpriv.ht_cap, (void *)&param->u.add_sta.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
@@ -7480,6 +7304,7 @@ static int rtw_add_sta(struct net_device *dev, struct ieee_param *param)
 
 		if (pmlmepriv->htpriv.ht_option == _FALSE)
 			psta->htpriv.ht_option = _FALSE;
+
 #endif
 
 
@@ -7604,7 +7429,8 @@ static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *par
 		psta_data->tx_supp_rates_len =  psta->bssratelen;
 		_rtw_memcpy(psta_data->tx_supp_rates, psta->bssrateset, psta->bssratelen);
 #ifdef CONFIG_80211N_HT
-		_rtw_memcpy(&psta_data->ht_cap, &psta->htpriv.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
+		if(padapter->registrypriv.ht_enable && is_supported_ht(padapter->registrypriv.wireless_mode))
+			_rtw_memcpy(&psta_data->ht_cap, &psta->htpriv.ht_cap, sizeof(struct rtw_ieee80211_ht_cap));
 #endif /* CONFIG_80211N_HT */
 		psta_data->rx_pkts = psta->sta_stats.rx_data_pkts;
 		psta_data->rx_bytes = psta->sta_stats.rx_bytes;
@@ -7671,7 +7497,6 @@ static int rtw_set_wps_beacon(struct net_device *dev, struct ieee_param *param,
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	struct mlme_ext_priv	*pmlmeext = &(padapter->mlmeextpriv);
-	struct mlme_ext_info	*pmlmeinfo = &(pmlmeext->mlmext_info);
 	int ie_len;
 
 	RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
@@ -7848,7 +7673,7 @@ static int rtw_ioctl_acl_remove_sta(struct net_device *dev, struct ieee_param *p
 	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
 		return -EINVAL;
 
-	ret = rtw_acl_remove_sta(padapter, param->sta_addr);
+	ret = rtw_acl_remove_sta(padapter, RTW_ACL_PERIOD_BSS, param->sta_addr);
 
 	return ret;
 
@@ -7868,7 +7693,7 @@ static int rtw_ioctl_acl_add_sta(struct net_device *dev, struct ieee_param *para
 	    param->sta_addr[4] == 0xff && param->sta_addr[5] == 0xff)
 		return -EINVAL;
 
-	ret = rtw_acl_add_sta(padapter, param->sta_addr);
+	ret = rtw_acl_add_sta(padapter, RTW_ACL_PERIOD_BSS, param->sta_addr);
 
 	return ret;
 
@@ -7883,7 +7708,7 @@ static int rtw_ioctl_set_macaddr_acl(struct net_device *dev, struct ieee_param *
 	if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
 		return -EINVAL;
 
-	rtw_set_macaddr_acl(padapter, param->u.mlme.command);
+	rtw_set_macaddr_acl(padapter, RTW_ACL_PERIOD_BSS, param->u.mlme.command);
 
 	return ret;
 }
@@ -8040,7 +7865,9 @@ static int rtw_wx_set_priv(struct net_device *dev,
 	int ret = 0;
 	int len = 0;
 	char *ext;
+#ifdef CONFIG_ANDROID
 	int i;
+#endif
 
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct iw_point *dwrq = (struct iw_point *)awrq;
@@ -8211,7 +8038,8 @@ static int rtw_wowlan_ctrl(struct net_device *dev,
 	RTW_INFO("+rtw_wowlan_ctrl: %s\n", extra);
 
 	if (!check_fwstate(pmlmepriv, _FW_LINKED) &&
-	    check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
+		check_fwstate(pmlmepriv, WIFI_STATION_STATE) &&
+		!WOWLAN_IS_STA_MIX_MODE(padapter)) {
 #ifdef CONFIG_PNO_SUPPORT
 		pwrctrlpriv->wowlan_pno_enable = _TRUE;
 #else
@@ -8470,6 +8298,12 @@ int rtw_vendor_ie_get_data(struct net_device *dev, int vendor_ie_num, char *extr
 		pstring += sprintf(pstring , "[Assoc Req]");
 	if (vendor_ie_mask & WIFI_ASSOCRESP_VENDOR_IE_BIT)
 		pstring += sprintf(pstring , "[Assoc Resp]");
+#ifdef CONFIG_P2P
+	if (vendor_ie_mask & WIFI_P2P_PROBEREQ_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[P2P_Probe Req]");
+	if (vendor_ie_mask & WIFI_P2P_PROBERESP_VENDOR_IE_BIT)
+		pstring += sprintf(pstring , "[P2P_Probe Resp]");
+#endif
 
 	pstring += sprintf(pstring , "\nVendor IE:\n");
 	for (j = 0 ; j < pmlmepriv->vendor_ielen[vendor_ie_num]  ; j++)
@@ -8520,6 +8354,7 @@ int rtw_vendor_ie_set(struct net_device *dev, struct iw_request_info *info, unio
 	struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
 	u32 vendor_ie_mask = 0;
 	u32 vendor_ie_num = 0;
+	u32 vendor_ie_mask_max = BIT(WLAN_MAX_VENDOR_IE_MASK_MAX) - 1;
 	u32 id, elen;
 
 	ret = sscanf(extra, "%d,%x,%*s", &vendor_ie_num , &vendor_ie_mask);
@@ -8528,10 +8363,10 @@ int rtw_vendor_ie_set(struct net_device *dev, struct iw_request_info *info, unio
 	else
 		return -EINVAL;
 	totoal_ie_len = strlen(extra);
-	RTW_INFO("[%s] vendor_ie_num = %d , vendor_ie_mask = %x , vendor_ie = %s , len = %d\n", __func__ , vendor_ie_num , vendor_ie_mask , extra  , totoal_ie_len);
+	RTW_INFO("[%s] vendor_ie_num = %d , vendor_ie_mask = 0x%x , vendor_ie = %s , len = %d\n", __func__ , vendor_ie_num , vendor_ie_mask , extra  , totoal_ie_len);
 
 	if (vendor_ie_num  > WLAN_MAX_VENDOR_IE_NUM - 1) {
-		RTW_INFO("[%s] only support %d vendor ie\n", __func__ , WLAN_MAX_VENDOR_IE_NUM);
+		RTW_INFO("[%s] Fail, only support %d vendor ie\n", __func__ , WLAN_MAX_VENDOR_IE_NUM);
 		return -EFAULT;
 	}
 
@@ -8540,6 +8375,11 @@ int rtw_vendor_ie_set(struct net_device *dev, struct iw_request_info *info, unio
 		return -EFAULT;
 	}
 
+	if (vendor_ie_mask > vendor_ie_mask_max) {
+		RTW_INFO("[%s] Fail, not support vendor_ie_mask more than 0x%x\n", __func__ , vendor_ie_mask_max);
+		return -EFAULT;
+	}
+
 	if (vendor_ie_mask == 0) {
 		RTW_INFO("[%s] Clear vendor_ie_num %d group\n", __func__ , vendor_ie_num);
 		goto _clear_path;
@@ -8581,11 +8421,17 @@ int rtw_vendor_ie_set(struct net_device *dev, struct iw_request_info *info, unio
 	if (vendor_ie_mask & WIFI_PROBEREQ_VENDOR_IE_BIT)
 		RTW_INFO("[%s] Probe Req append vendor ie\n", __func__);
 	if (vendor_ie_mask & WIFI_PROBERESP_VENDOR_IE_BIT)
-		RTW_INFO("[%s] Probe Resp  append vendor ie\n", __func__);
+		RTW_INFO("[%s] Probe Resp append vendor ie\n", __func__);
 	if (vendor_ie_mask & WIFI_ASSOCREQ_VENDOR_IE_BIT)
 		RTW_INFO("[%s] Assoc Req append vendor ie\n", __func__);
 	if (vendor_ie_mask & WIFI_ASSOCRESP_VENDOR_IE_BIT)
 		RTW_INFO("[%s] Assoc Resp append vendor ie\n", __func__);
+#ifdef CONFIG_P2P
+	if (vendor_ie_mask & WIFI_P2P_PROBEREQ_VENDOR_IE_BIT)
+		RTW_INFO("[%s] P2P Probe Req append vendor ie\n", __func__);
+	if (vendor_ie_mask & WIFI_P2P_PROBERESP_VENDOR_IE_BIT)
+		RTW_INFO("[%s] P2P Probe Resp append vendor ie\n", __func__);
+#endif
 
 	pmlmepriv->vendor_ie_mask[vendor_ie_num] = vendor_ie_mask;
 
@@ -8609,7 +8455,6 @@ static int rtw_mp_efuse_get(struct net_device *dev,
 	PEFUSE_HAL pEfuseHal;
 	struct iw_point *wrqu;
 
-	u8	*PROMContent = pHalData->efuse_eeprom_data;
 	u8 ips_mode = IPS_NUM; /* init invalid value */
 	u8 lps_mode = PS_MODE_NUM; /* init invalid value */
 	struct pwrctrl_priv *pwrctrlpriv ;
@@ -8951,6 +8796,10 @@ static int rtw_mp_efuse_get(struct net_device *dev,
 		addr = EEPROM_VID_8188FU;
 #endif /* CONFIG_RTL8188F */
 
+#ifdef CONFIG_RTL8188GTV
+		addr = EEPROM_VID_8188GTVU;
+#endif
+
 #ifdef CONFIG_RTL8703B
 #ifdef CONFIG_USB_HCI
 		addr = EEPROM_VID_8703BU;
@@ -9304,6 +9153,8 @@ static int rtw_mp_efuse_set(struct net_device *dev,
 	u16 addr = 0xFF, cnts = 0, BTStatus = 0 , max_available_len = 0;
 	u16 wifimaplen;
 	int err;
+	boolean bcmpchk = _TRUE;
+
 
 	wrqu = (struct iw_point *)wdata;
 	padapter = rtw_netdev_priv(dev);
@@ -9590,6 +9441,10 @@ static int rtw_mp_efuse_set(struct net_device *dev,
 		addr = EEPROM_VID_8188FU;
 #endif
 
+#ifdef CONFIG_RTL8188GTV
+		addr = EEPROM_VID_8188GTVU;
+#endif
+
 #ifdef CONFIG_RTL8703B
 #ifdef CONFIG_USB_HCI
 		addr = EEPROM_VID_8703BU;
@@ -9830,7 +9685,8 @@ static int rtw_mp_efuse_set(struct net_device *dev,
 
 		if (padapter->registrypriv.bFileMaskEfuse != _TRUE && pmp_priv->bloadefusemap == _TRUE) {
 			RTW_INFO("%s: File eFuse mask file not to be loaded\n", __FUNCTION__);
-			sprintf(extra, "Not load eFuse mask file yet, Please use the efuse_mask CMD.\n");
+			sprintf(extra, "Not load eFuse mask file yet, Please use the efuse_mask CMD, now remove the interface !!!!\n");
+			rtw_set_surprise_removed(padapter);
 			err = 0;
 			goto exit;
 		}
@@ -9846,18 +9702,42 @@ static int rtw_mp_efuse_set(struct net_device *dev,
 		}
 
 		if (rtw_efuse_mask_map_read(padapter, 0x00, wifimaplen, ShadowMapWiFi) == _SUCCESS) {
-			if (_rtw_memcmp((void *)ShadowMapWiFi , (void *)pEfuseHal->fakeEfuseModifiedMap, cnts)) {
-				RTW_INFO("%s: WiFi write map afterf compare OK\n", __FUNCTION__);
-				sprintf(extra, "WiFi write map compare OK\n");
-				err = 0;
-				goto exit;
-			} else {
-				sprintf(extra, "WiFi write map compare FAIL\n");
-				RTW_INFO("%s: WiFi write map compare Fail\n", __FUNCTION__);
-				err = 0;
-				goto exit;
+			addr = 0x00;
+			err = _TRUE;
+
+			for (i = 0; i < cnts; i++) {
+				if (padapter->registrypriv.boffefusemask == 0) {
+					if (padapter->registrypriv.bFileMaskEfuse == _TRUE) {
+						if (rtw_file_efuse_IsMasked(padapter, addr + i) == _TRUE)	/*use file efuse mask. */
+							bcmpchk = _FALSE;
+					} else {
+						if (efuse_IsMasked(padapter, addr + i) == _TRUE)
+							bcmpchk = _FALSE;
+					}
+				}
+
+				if (bcmpchk == _TRUE) {
+					RTW_INFO("compare readMapWiFi[0x%02x] = %x, ModifiedMap = %x\n", addr + i, ShadowMapWiFi[ addr + i], pEfuseHal->fakeEfuseModifiedMap[addr + i]);
+					if (_rtw_memcmp((void *) &ShadowMapWiFi[addr + i], (void *)&pEfuseHal->fakeEfuseModifiedMap[addr + i], 1) == _FALSE){
+						err = _FALSE;
+						break;
+					}
+				}
+				bcmpchk = _TRUE;
 			}
 		}
+
+		if (err) {
+			RTW_INFO("%s: WiFi write map afterf compare OK\n", __FUNCTION__);
+			sprintf(extra, "WiFi write map compare OK\n");
+			err = 0;
+			goto exit;
+		} else {
+			sprintf(extra, "WiFi write map compare FAIL\n");
+			RTW_INFO("%s: WiFi write map compare Fail\n", __FUNCTION__);
+			err = 0;
+			goto exit;
+		}
 	} else if (strcmp(tmp[0], "wlwfake") == 0) {
 		if ((tmp[1] == NULL) || (tmp[2] == NULL)) {
 			err = -EINVAL;
@@ -10001,7 +9881,7 @@ static int rtw_mp_customer_str(
 		|| !adapter->registrypriv.mp_customer_str)
 		return -EFAULT;
 
-	len = wrqu->data.length;
+	len = wrqu->data.length + 1;
 
 	pbuf = (u8 *)rtw_zmalloc(len);
 	if (pbuf == NULL) {
@@ -10009,7 +9889,7 @@ static int rtw_mp_customer_str(
 		return -ENOMEM;
 	}
 
-	if (copy_from_user(pbuf, wrqu->data.pointer, len)) {
+	if (copy_from_user(pbuf, wrqu->data.pointer, wrqu->data.length)) {
 		rtw_mfree(pbuf, len);
 		RTW_WARN("%s: copy from user fail!\n", __func__);
 		return -EFAULT;
@@ -10085,7 +9965,9 @@ static int rtw_priv_mp_set(struct net_device *dev,
 
 	struct iw_point *wrqu = (struct iw_point *)wdata;
 	u32 subcmd = wrqu->flags;
+#ifdef CONFIG_CONCURRENT_MODE
 	PADAPTER padapter = rtw_netdev_priv(dev);
+#endif
 
 	if (!is_primary_adapter(padapter)) {
 		RTW_INFO("MP mode only primary Adapter support\n");
@@ -10124,7 +10006,9 @@ static int rtw_priv_mp_get(struct net_device *dev,
 
 	struct iw_point *wrqu = (struct iw_point *)wdata;
 	u32 subcmd = wrqu->flags;
+#ifdef CONFIG_CONCURRENT_MODE
 	PADAPTER padapter = rtw_netdev_priv(dev);
+#endif
 
 	if (!is_primary_adapter(padapter)) {
 		RTW_INFO("MP mode only primary Adapter support\n");
@@ -10166,6 +10050,10 @@ static int rtw_priv_mp_get(struct net_device *dev,
 		RTW_INFO("set case mp_channel\n");
 		rtw_mp_channel(dev , info, wrqu, extra);
 		break;
+    	case  MP_CHL_OFFSET:
+       		RTW_INFO("set case mp_ch_offset\n");
+        	rtw_mp_ch_offset(dev , info, wrqu, extra);
+        	break;
 	case READ_REG:
 		RTW_INFO("mp_get  READ_REG\n");
 		rtw_mp_read_reg(dev, info, wrqu, extra);
@@ -10284,7 +10172,11 @@ static int rtw_priv_mp_get(struct net_device *dev,
 	case  BT_EFUSE_FILE:
 		RTW_INFO("mp_get BT EFUSE_FILE\n");
 		rtw_bt_efuse_file_map(dev, info, wdata, extra);
-		break;	
+		break;
+	case  MP_SWRFPath:
+		RTW_INFO("mp_get MP_SWRFPath\n");
+		rtw_mp_switch_rf_path(dev, info, wrqu, extra);
+		break;
 	default:
 		return -EIO;
 	}
@@ -10523,7 +10415,7 @@ static int rtw_priv_get(struct net_device *dev,
 	if (subcmd < MP_NULL) {
 #ifdef CONFIG_MP_INCLUDED
 		rtw_priv_mp_get(dev, info, wdata, extra);
-#endif		
+#endif
 		return 0;
 	}
 
@@ -10618,7 +10510,7 @@ static int rtw_tdls_enable(struct net_device *dev,
 	RTW_INFO("[%s] %s %d\n", __FUNCTION__, extra, wrqu->data.length - 1);
 
 	if (extra[0] == '0')
-		rtw_disable_tdls_func(padapter, _FALSE);
+		rtw_disable_tdls_func(padapter, _TRUE);
 	else if (extra[0] == '1')
 		rtw_enable_tdls_func(padapter);
 #endif /* CONFIG_TDLS */
@@ -11222,7 +11114,6 @@ static int rtw_tdls_get_best_ch(struct net_device *dev,
 #ifdef CONFIG_FIND_BEST_CHANNEL
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
 	u32 i, best_channel_24G = 1, best_channel_5G = 36, index_24G = 0, index_5G = 0;
 
 	for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
@@ -11474,6 +11365,11 @@ extern void rtl8723b_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf
 #define fill_default_txdesc rtl8723d_fill_default_txdesc
 #endif /* CONFIG_RTL8723D */
 
+#if defined(CONFIG_RTL8710B)
+#define cal_txdesc_chksum rtl8710b_cal_txdesc_chksum
+#define fill_default_txdesc rtl8710b_fill_default_txdesc
+#endif /* CONFIG_RTL8710B */
+
 #if defined(CONFIG_RTL8192E)
 extern void rtl8192e_cal_txdesc_chksum(struct tx_desc *ptxdesc);
 #define cal_txdesc_chksum rtl8192e_cal_txdesc_chksum
@@ -11483,6 +11379,13 @@ extern void rtl8192es_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbu
 #endif /* CONFIG_SDIO_HCI */
 #endif /* CONFIG_RTL8192E */
 
+#if defined(CONFIG_RTL8192F)
+/* extern void rtl8192f_cal_txdesc_chksum(struct tx_desc *ptxdesc); */
+#define cal_txdesc_chksum rtl8192f_cal_txdesc_chksum
+/* extern void rtl8192f_fill_default_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf); */
+#define fill_default_txdesc rtl8192f_fill_default_txdesc
+#endif /* CONFIG_RTL8192F */
+
 static s32 initLoopback(PADAPTER padapter)
 {
 	PLOOPBACKDATA ploopback;
@@ -11527,7 +11430,7 @@ static s32 initpseudoadhoc(PADAPTER padapter)
 	if (err == _FALSE)
 		return _FAIL;
 
-	err = rtw_setopmode_cmd(padapter, networkType, _TRUE);
+	err = rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_WAIT_ACK);
 	if (err == _FAIL)
 		return _FAIL;
 
@@ -12029,7 +11932,7 @@ static int rtw_test(
 	}
 
 	pbuf[len] = '\0';
-	
+
 	RTW_INFO("%s: string=\"%s\"\n", __func__, pbuf);
 
 	ptmp = (char *)pbuf;
@@ -12340,6 +12243,7 @@ static const struct iw_priv_args rtw_mp_private_args[] = {
 	{ MP_PHYPARA, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_phypara" },
 	{ MP_STOP , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_stop" },
 	{ MP_CHANNEL , IW_PRIV_TYPE_CHAR | 1024 , IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_channel" },
+	{ MP_CHL_OFFSET , IW_PRIV_TYPE_CHAR | 1024 , IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_ch_offset" },
 	{ MP_BANDWIDTH , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_bandwidth"},
 	{ MP_RATE , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_rate" },
 	{ MP_RESET_STATS , IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_reset_stats"},
@@ -12378,6 +12282,7 @@ static const struct iw_priv_args rtw_mp_private_args[] = {
 	{ MP_IQK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_iqk"},
 	{ MP_LCK, IW_PRIV_TYPE_CHAR | 1024, 0, "mp_lck"},
 	{ BT_EFUSE_FILE, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "bt_efuse_file" },
+	{ MP_SWRFPath, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "mp_swrfpath" },
 #ifdef CONFIG_RTW_CUSTOMER_STR
 	{ MP_CUSTOMER_STR, IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | IW_PRIV_SIZE_MASK, "customer_str" },
 #endif
@@ -12434,7 +12339,7 @@ static iw_handler rtw_private_handler[] = {
 	rtw_wx_priv_null,				/* 0x19 */
 #ifdef CONFIG_MP_INCLUDED
 	rtw_wx_priv_null,				/* 0x1A */
-	rtw_wx_priv_null,				/* 0x1B */	
+	rtw_wx_priv_null,				/* 0x1B */
 #else
 	rtw_wx_priv_null,				/* 0x1A */
 	rtw_mp_efuse_get,				/* 0x1B */
@@ -12465,17 +12370,7 @@ static struct iw_statistics *rtw_get_wireless_stats(struct net_device *dev)
 #ifdef CONFIG_SIGNAL_DISPLAY_DBM
 		tmp_level = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);
 #else
-#ifdef CONFIG_SIGNAL_SCALE_MAPPING
 		tmp_level = padapter->recvpriv.signal_strength;
-#else
-		{
-			/* Do signal scale mapping when using percentage as the unit of signal strength, since the scale mapping is skipped in odm */
-
-			HAL_DATA_TYPE *pHal = GET_HAL_DATA(padapter);
-
-			tmp_level = (u8)phydm_signal_scale_mapping(&pHal->odmpriv, padapter->recvpriv.signal_strength);
-		}
-#endif
 #endif
 
 		tmp_qual = padapter->recvpriv.signal_qual;
@@ -12935,7 +12830,6 @@ static int rtw_ioctl_compat_wext_private(struct net_device *dev, struct ifreq *r
 static int rtw_ioctl_standard_wext_private(struct net_device *dev, struct ifreq *rq)
 {
 	struct iw_point *iwp;
-	struct ifreq ifrq;
 	union iwreq_data wrq_data;
 	int err = 0;
 	iwp = &wrq_data.data;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_mp.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_mp.c
index eacd685857f2..afd10ab97fd8 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_mp.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/ioctl_mp.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -37,9 +38,9 @@ int rtw_mp_write_reg(struct net_device *dev,
 		     struct iw_request_info *info,
 		     struct iw_point *wrqu, char *extra)
 {
-	char *pch, *pnext, *ptmp;
+	char *pch, *pnext;
 	char *width_str;
-	char width, buf[5];
+	char width;
 	u32 addr, data;
 	int ret;
 	PADAPTER padapter = rtw_netdev_priv(dev);
@@ -130,10 +131,10 @@ int rtw_mp_read_reg(struct net_device *dev,
 		    struct iw_point *wrqu, char *extra)
 {
 	char input[wrqu->length + 1];
-	char *pch, *pnext, *ptmp;
+	char *pch, *pnext;
 	char *width_str;
 	char width;
-	char data[20], tmp[20], buf[3];
+	char data[20], tmp[20];
 	u32 addr = 0, strtout = 0;
 	u32 i = 0, j = 0, ret = 0, data32 = 0;
 	PADAPTER padapter = rtw_netdev_priv(dev);
@@ -306,8 +307,8 @@ int rtw_mp_read_rf(struct net_device *dev,
 		   struct iw_point *wrqu, char *extra)
 {
 	char input[wrqu->length];
-	char *pch, *pnext, *ptmp;
-	char data[20], tmp[20], buf[3];
+	char *pch, *pnext;
+	char data[20], tmp[20];
 	u32 path, addr, strtou;
 	u32 ret, i = 0 , j = 0;
 	PADAPTER padapter = rtw_netdev_priv(dev);
@@ -367,10 +368,7 @@ int rtw_mp_start(struct net_device *dev,
 		 struct iw_point *wrqu, char *extra)
 {
 	int ret = 0;
-	u8 val8;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct hal_ops *pHalFunc = &padapter->hal_func;
 
 	rtw_pm_set_ips(padapter, IPS_NONE);
 	LeaveAllPowerSaveMode(padapter);
@@ -396,7 +394,6 @@ int rtw_mp_stop(struct net_device *dev,
 {
 	int ret = 0;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	struct hal_ops *pHalFunc = &padapter->hal_func;
 
 	if (rtw_mp_cmd(padapter, MP_STOP, RTW_CMDF_WAIT_ACK) != _SUCCESS)
 		ret = -EPERM;
@@ -466,7 +463,6 @@ int rtw_mp_channel(struct net_device *dev,
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	u8		input[wrqu->length + 1];
 	u32	channel = 1;
-	int cur_ch_offset;
 
 	_rtw_memset(input, 0, sizeof(input));
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
@@ -486,12 +482,37 @@ int rtw_mp_channel(struct net_device *dev,
 }
 
 
+int rtw_mp_ch_offset(struct net_device *dev,
+		   struct iw_request_info *info,
+		   struct iw_point *wrqu, char *extra)
+{
+
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	u8		input[wrqu->length + 1];
+	u32	ch_offset = 0;
+
+	_rtw_memset(input, 0, sizeof(input));
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	input[wrqu->length] = '\0';
+	ch_offset = rtw_atoi(input);
+	/*RTW_INFO("%s: channel=%d\n", __func__, channel);*/
+	_rtw_memset(extra, 0, wrqu->length);
+	sprintf(extra, "Change prime channel offset %d to %d", padapter->mppriv.prime_channel_offset , ch_offset);
+	padapter->mppriv.prime_channel_offset = ch_offset;
+	SetChannel(padapter);
+
+	wrqu->length = strlen(extra);
+	return 0;
+}
+
+
 int rtw_mp_bandwidth(struct net_device *dev,
 		     struct iw_request_info *info,
 		     struct iw_point *wrqu, char *extra)
 {
 	u32 bandwidth = 0, sg = 0;
-	int cur_ch_offset;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	u8		input[wrqu->length];
@@ -514,8 +535,7 @@ int rtw_mp_bandwidth(struct net_device *dev,
 
 	SetBandwidth(padapter);
 	pHalData->current_channel_bw = bandwidth;
-	/*cur_ch_offset =  rtw_get_offset_by_ch(padapter->mppriv.channel);*/
-	/*set_channel_bwmode(padapter, padapter->mppriv.channel, cur_ch_offset, bandwidth);*/
+
 	wrqu->length = strlen(extra);
 
 	return 0;
@@ -527,6 +547,7 @@ int rtw_mp_txpower_index(struct net_device *dev,
 			 struct iw_point *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
+ 	HAL_DATA_TYPE	*phal_data	= GET_HAL_DATA(padapter);
 	char input[wrqu->length + 1];
 	u32 rfpath;
 	u32 txpower_inx;
@@ -541,9 +562,26 @@ int rtw_mp_txpower_index(struct net_device *dev,
 
 	input[wrqu->length] = '\0';
 
-	rfpath = rtw_atoi(input);
-	txpower_inx = mpt_ProQueryCalTxPower(padapter, rfpath);
-	sprintf(extra, " %d", txpower_inx);
+	if (wrqu->length == 2) {
+		rfpath = rtw_atoi(input);
+		txpower_inx = mpt_ProQueryCalTxPower(padapter, rfpath);
+		sprintf(extra, " %d", txpower_inx);
+	} else {
+		txpower_inx = mpt_ProQueryCalTxPower(padapter, 0);
+		sprintf(extra, "patha=%d", txpower_inx);
+		if (phal_data->rf_type > RF_1T2R) {
+			txpower_inx = mpt_ProQueryCalTxPower(padapter, 1);
+			sprintf(extra, "%s,pathb=%d", extra, txpower_inx);
+		}
+		if (phal_data->rf_type > RF_2T4R) {
+			txpower_inx = mpt_ProQueryCalTxPower(padapter, 2);
+			sprintf(extra, "%s,pathc=%d", extra, txpower_inx);
+		}
+		if (phal_data->rf_type > RF_3T4R) {
+			txpower_inx = mpt_ProQueryCalTxPower(padapter, 3);
+			sprintf(extra, "%s,pathd=%d", extra, txpower_inx);
+		}
+	}
 	wrqu->length = strlen(extra);
 
 	return 0;
@@ -554,7 +592,7 @@ int rtw_mp_txpower(struct net_device *dev,
 		   struct iw_request_info *info,
 		   struct iw_point *wrqu, char *extra)
 {
-	u32 idx_a = 0, idx_b = 0, idx_c = 0, idx_d = 0, status = 0;
+	u32 idx_a = 0, idx_b = 0, idx_c = 0, idx_d = 0;
 	int MsetPower = 1;
 	u8		input[wrqu->length];
 
@@ -818,15 +856,15 @@ int rtw_mp_disable_bt_coexist(struct net_device *dev,
 			      struct iw_request_info *info,
 			      union iwreq_data *wrqu, char *extra)
 {
+#ifdef CONFIG_BT_COEXIST
 	PADAPTER padapter = (PADAPTER)rtw_netdev_priv(dev);
-	HAL_DATA_TYPE	*pHalData = GET_HAL_DATA(padapter);
-	struct hal_ops *pHalFunc = &padapter->hal_func;
 
+#endif
 	u8 input[wrqu->data.length + 1];
 	u32 bt_coexist;
 
 	_rtw_memset(input, 0, sizeof(input));
-	
+
 	if (copy_from_user(input, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
 
@@ -858,11 +896,11 @@ int rtw_mp_arx(struct net_device *dev,
 	       struct iw_request_info *info,
 	       struct iw_point *wrqu, char *extra)
 {
-	int bStartRx = 0, bStopRx = 0, bQueryPhy = 0, bQueryMac = 0, bSetBssid = 0;
-	int bmac_filter = 0, bfilter_init = 0, bmon = 0, bSmpCfg = 0, bloopbk = 0;
+	int bStartRx = 0, bStopRx = 0, bQueryPhy = 0, bQueryMac = 0, bSetBssid = 0, bSetRxframe = 0;
+	int bmac_filter = 0, bmon = 0, bSmpCfg = 0;
 	u8		input[wrqu->length];
-	char *pch, *ptmp, *token, *tmp[2] = {0x00, 0x00};
-	u32 i = 0, ii = 0, jj = 0, kk = 0, cnts = 0, ret;
+	char *pch, *token, *tmp[2] = {0x00, 0x00};
+	u32 i = 0, jj = 0, kk = 0, cnts = 0, ret;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	struct mp_priv *pmppriv = &padapter->mppriv;
 	struct dbg_rx_counter rx_counter;
@@ -883,6 +921,7 @@ int rtw_mp_arx(struct net_device *dev,
 	bQueryPhy = (strncmp(input, "phy", 3) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
 	bQueryMac = (strncmp(input, "mac", 3) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
 	bSetBssid = (strncmp(input, "setbssid=", 8) == 0) ? 1 : 0; /* strncmp TRUE is 0*/
+	bSetRxframe = (strncmp(input, "frametype", 9) == 0) ? 1 : 0;
 	/*bfilter_init = (strncmp(input, "filter_init",11)==0)?1:0;*/
 	bmac_filter = (strncmp(input, "accept_mac", 10) == 0) ? 1 : 0;
 	bmon = (strncmp(input, "mon=", 4) == 0) ? 1 : 0;
@@ -912,6 +951,12 @@ int rtw_mp_arx(struct net_device *dev,
 
 		pmppriv->bSetRxBssid = _TRUE;
 	}
+	if (bSetRxframe) {
+		if (strncmp(input, "frametype beacon", 16) == 0)
+			pmppriv->brx_filter_beacon = _TRUE;
+		else
+			pmppriv->brx_filter_beacon = _FALSE;
+	}
 
 	if (bmac_filter) {
 		pmppriv->bmac_filter = bmac_filter;
@@ -1038,7 +1083,6 @@ int rtw_mp_pwrtrk(struct net_device *dev,
 	u32 thermal;
 	s32 ret;
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	HAL_DATA_TYPE			*pHalData = GET_HAL_DATA(padapter);
 	u8		input[wrqu->length];
 
 	if (copy_from_user(input, wrqu->pointer, wrqu->length))
@@ -1108,6 +1152,9 @@ int rtw_mp_thermal(struct net_device *dev,
 #ifdef CONFIG_RTL8192E
 	u16 addr = EEPROM_THERMAL_METER_8192E;
 #endif
+#ifdef CONFIG_RTL8192F
+	u16 addr = EEPROM_THERMAL_METER_8192F;
+#endif
 #ifdef CONFIG_RTL8723B
 	u16 addr = EEPROM_THERMAL_METER_8723B;
 #endif
@@ -1120,11 +1167,17 @@ int rtw_mp_thermal(struct net_device *dev,
 #ifdef CONFIG_RTL8188F
 	u16 addr = EEPROM_THERMAL_METER_8188F;
 #endif
+#ifdef CONFIG_RTL8188GTV
+	u16 addr = EEPROM_THERMAL_METER_8188GTV;
+#endif
 #ifdef CONFIG_RTL8822B
 	u16 addr = EEPROM_THERMAL_METER_8822B;
 #endif
 #ifdef CONFIG_RTL8821C
 	u16 addr = EEPROM_THERMAL_METER_8821C;
+#endif
+#ifdef CONFIG_RTL8710B
+	u16 addr = EEPROM_THERMAL_METER_8710B;
 #endif
 	u16 cnt = 1;
 	u16 max_available_size = 0;
@@ -1163,7 +1216,6 @@ int rtw_mp_reset_stats(struct net_device *dev,
 		       struct iw_point *wrqu, char *extra)
 {
 	struct mp_priv *pmp_priv;
-	struct pkt_attrib *pattrib;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 
 	pmp_priv = &padapter->mppriv;
@@ -1190,11 +1242,7 @@ int rtw_mp_dump(struct net_device *dev,
 		struct iw_point *wrqu, char *extra)
 {
 	struct mp_priv *pmp_priv;
-	struct pkt_attrib *pattrib;
-	u32 value;
 	u8		input[wrqu->length];
-	u8 rf_type, path_nums = 0;
-	u32 i, j = 1, path;
 	PADAPTER padapter = rtw_netdev_priv(dev);
 
 	pmp_priv = &padapter->mppriv;
@@ -1246,7 +1294,9 @@ int rtw_mp_SetRFPath(struct net_device *dev,
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	char	input[wrqu->length];
 	int		bMain = 1, bTurnoff = 1;
+#ifdef CONFIG_ANTENNA_DIVERSITY
 	u8 ret = _TRUE;
+#endif
 
 	RTW_INFO("%s:iwpriv in=%s\n", __func__, input);
 
@@ -1287,6 +1337,56 @@ int rtw_mp_SetRFPath(struct net_device *dev,
 }
 
 
+int rtw_mp_switch_rf_path(struct net_device *dev,
+			struct iw_request_info *info,
+			struct iw_point *wrqu, char *extra)
+{
+	PADAPTER padapter = rtw_netdev_priv(dev);
+	struct mp_priv *pmp_priv;
+	char	input[wrqu->length];
+	int		bwlg = 1, bwla = 1, btg = 1, bbt=1;
+	u8 ret = 0;
+
+
+	if (copy_from_user(input, wrqu->pointer, wrqu->length))
+		return -EFAULT;
+
+	pmp_priv = &padapter->mppriv;
+
+	RTW_INFO("%s: in=%s\n", __func__, input);
+
+	bwlg = strncmp(input, "WLG", 3); /* strncmp TRUE is 0*/
+	bwla = strncmp(input, "WLA", 3); /* strncmp TRUE is 0*/
+	btg = strncmp(input, "BTG", 3); /* strncmp TRUE is 0*/
+	bbt = strncmp(input, "BT", 3); /* strncmp TRUE is 0*/
+
+	_rtw_memset(extra, 0, wrqu->length);
+#ifdef CONFIG_RTL8821C /* only support for 8821c wlg/wla/btg/bt RF switch path */
+	if (bwlg == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_WLG;
+		sprintf(extra, "switch rf path WLG\n");
+	} else if (bwla == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_WLA;
+		sprintf(extra, "switch rf path WLA\n");
+	} else if (btg == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_BTG;
+		sprintf(extra, "switch rf path BTG\n");
+	} else if (bbt == 0) {
+		pmp_priv->rf_path_cfg = SWITCH_TO_BT;
+		sprintf(extra, "switch rf path BG\n");
+	} else {
+		sprintf(extra, "Error set %s\n", __func__);
+		return -EFAULT;
+	}
+
+	mp_phy_switch_rf_path_set(padapter, &pmp_priv->rf_path_cfg);
+#endif
+
+	wrqu->length = strlen(extra);
+
+	return ret;
+
+}
 int rtw_mp_QueryDrv(struct net_device *dev,
 		    struct iw_request_info *info,
 		    union iwreq_data *wrqu, char *extra)
@@ -1425,7 +1525,7 @@ int rtw_mp_mon(struct net_device *dev,
 		if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
 			rtw_disassoc_cmd(padapter, 500, 0);
 			rtw_indicate_disconnect(padapter, 0, _FALSE);
-			/*rtw_free_assoc_resources(padapter, 1);*/
+			/*rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);*/
 		}
 		rtw_pm_set_ips(padapter, IPS_NORMAL);
 		sprintf(extra, "monitor mode Stop\n");
@@ -1437,9 +1537,7 @@ int rtw_mp_mon(struct net_device *dev,
 
 int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra)
 {
-	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	struct mp_priv *pmp_priv = &padapter->mppriv;
-	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
 	char *pextra = extra;
 
 	switch (pmp_priv->mode) {
@@ -1495,7 +1593,9 @@ int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra)
 			rtw_msleep_os(5);
 		}
 #ifdef CONFIG_80211N_HT
-		pmp_priv->tx.attrib.ht_en = 1;
+		if(padapter->registrypriv.ht_enable &&
+			is_supported_ht(padapter->registrypriv.wireless_mode))
+			pmp_priv->tx.attrib.ht_en = 1;
 #endif
 		pmp_priv->tx.stop = 0;
 		pmp_priv->tx.count = 1;
@@ -1525,10 +1625,12 @@ int rtw_mp_tx(struct net_device *dev,
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
-	struct registry_priv	*pregistrypriv = &padapter->registrypriv;
 	char *pextra = extra;
 	u32 bandwidth = 0, sg = 0, channel = 6, txpower = 40, rate = 108, ant = 0, txmode = 1, count = 0;
-	u8 i = 0, j = 0, bStartTest = 1, status = 0, Idx = 0, tmpU1B = 0;
+	u8 bStartTest = 1, status = 0;
+#ifdef CONFIG_MP_VHT_HW_TX_MODE
+	u8 Idx = 0, tmpU1B;
+#endif
 	u16 antenna = 0;
 
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
@@ -1845,7 +1947,6 @@ int rtw_mp_rx(struct net_device *dev,
 	PADAPTER padapter = rtw_netdev_priv(dev);
 	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	struct mp_priv *pmp_priv = &padapter->mppriv;
-	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
 	char *pextra = extra;
 	u32 bandwidth = 0, sg = 0, channel = 6, ant = 0;
 	u16 antenna = 0;
@@ -1966,7 +2067,6 @@ int rtw_mp_hwtx(struct net_device *dev,
 		union iwreq_data *wrqu, char *extra)
 {
 	PADAPTER padapter = rtw_netdev_priv(dev);
-	HAL_DATA_TYPE	*pHalData	= GET_HAL_DATA(padapter);
 	struct mp_priv *pmp_priv = &padapter->mppriv;
 	PMPT_CONTEXT		pMptCtx = &(padapter->mppriv.mpt_ctx);
 
@@ -1978,10 +2078,16 @@ int rtw_mp_hwtx(struct net_device *dev,
 
 	_rtw_memset(&pMptCtx->PMacTxInfo, 0, sizeof(RT_PMAC_TX_INFO));
 	_rtw_memcpy((void *)&pMptCtx->PMacTxInfo, (void *)input, sizeof(RT_PMAC_TX_INFO));
+	_rtw_memset(wrqu->data.pointer, 0, wrqu->data.length);
 
-	mpt_ProSetPMacTx(padapter);
-	sprintf(extra, "Set PMac Tx Mode start\n");
-
+	if (pMptCtx->PMacTxInfo.bEnPMacTx == 1 && pmp_priv->mode != MP_ON) {
+		sprintf(extra, "MP Tx Running, Please Set PMac Tx Mode Stop\n");
+		RTW_INFO("Error !!! MP Tx Running, Please Set PMac Tx Mode Stop\n");
+	} else {
+		RTW_INFO("To set MAC Tx mode\n");
+		mpt_ProSetPMacTx(padapter);
+		sprintf(extra, "Set PMac Tx Mode OK\n");
+	}
 	wrqu->data.length = strlen(extra);
 #endif
 	return 0;
@@ -1998,6 +2104,8 @@ int rtw_mp_pwrlmt(struct net_device *dev,
 
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
+
+	*(extra + wrqu->data.length) = '\0';
 #ifdef CONFIG_TXPWR_LIMIT
 	pwrlimtstat = registry_par->RegEnableTxPowerLimit;
 	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
@@ -2026,6 +2134,7 @@ int rtw_mp_pwrbyrate(struct net_device *dev,
 	if (copy_from_user(extra, wrqu->data.pointer, wrqu->data.length))
 		return -EFAULT;
 
+	*(extra + wrqu->data.length) = '\0';
 	if (strncmp(extra, "off", 3) == 0 && strlen(extra) < 4) {
 		padapter->registrypriv.RegEnableTxPowerByRate = 0;
 		sprintf(extra, "Turn off Tx Power by Rate\n");
@@ -2069,11 +2178,10 @@ int rtw_efuse_mask_file(struct net_device *dev,
 		return 0;
 	}
 	if (strncmp(extra, "data,", 5) == 0) {
-		u8	*pch, *pdata;
+		u8	*pch;
 		char	*ptmp, tmp;
 		u8	count = 0;
 		u8	i = 0;
-		u32	datalen = 0;
 
 		ptmp = extra;
 		pch = strsep(&ptmp, ",");
@@ -2113,9 +2221,14 @@ int rtw_efuse_mask_file(struct net_device *dev,
 	if (rtw_is_file_readable(rtw_efuse_mask_file_path) == _TRUE) {
 		RTW_INFO("%s do rtw_efuse_mask_file_read = %s! ,sizeof maskfileBuffer %zu\n", __func__, rtw_efuse_mask_file_path, sizeof(maskfileBuffer));
 		Status = rtw_efuse_file_read(padapter, rtw_efuse_mask_file_path, maskfileBuffer, sizeof(maskfileBuffer));
-		if (Status == _TRUE)
+		if (Status == _TRUE) {
 			padapter->registrypriv.bFileMaskEfuse = _TRUE;
-		sprintf(extra, "efuse mask file read OK\n");
+			sprintf(extra, "efuse mask file read OK\n");
+		} else {
+			padapter->registrypriv.bFileMaskEfuse = _FALSE;
+			sprintf(extra, "read efuse mask file FAIL\n");
+			RTW_INFO("%s rtw_efuse_file_read mask fail!\n", __func__);
+		}
 	} else {
 		padapter->registrypriv.bFileMaskEfuse = _FALSE;
 		sprintf(extra, "efuse mask file readable FAIL\n");
@@ -2227,7 +2340,7 @@ int rtw_mp_SetBT(struct net_device *dev,
 		return -EFAULT;
 
 	*(extra + wrqu->data.length) = '\0';
-	
+
 	if (strlen(extra) < 1)
 		return -EFAULT;
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/mlme_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/mlme_linux.c
index 67255452de65..67a56aaa07ab 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/mlme_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/mlme_linux.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -67,7 +68,13 @@ void rtw_os_indicate_connect(_adapter *adapter)
 #endif /* CONFIG_IOCTL_CFG80211 */
 
 	rtw_indicate_wx_assoc_event(adapter);
-	rtw_netif_carrier_on(adapter->pnetdev);
+
+#ifdef CONFIG_RTW_MESH
+#if CONFIG_RTW_MESH_CTO_MGATE_CARRIER
+	if (!rtw_mesh_cto_mgate_required(adapter))
+#endif
+#endif
+		rtw_netif_carrier_on(adapter->pnetdev);
 
 	if (adapter->pid[2] != 0)
 		rtw_signal_process(adapter->pid[2], SIGALRM);
@@ -96,7 +103,6 @@ void rtw_reset_securitypriv(_adapter *adapter)
 	u32	backupTKIPcountermeasure_time = 0;
 	/* add for CONFIG_IEEE80211W, none 11w also can use */
 	_irqL irqL;
-	struct mlme_ext_priv	*pmlmeext = &adapter->mlmeextpriv;
 
 	_enter_critical_bh(&adapter->security_key_mutex, &irqL);
 
@@ -113,10 +119,6 @@ void rtw_reset_securitypriv(_adapter *adapter)
 		backupPMKIDIndex = adapter->securitypriv.PMKIDIndex;
 		backupTKIPCountermeasure = adapter->securitypriv.btkip_countermeasure;
 		backupTKIPcountermeasure_time = adapter->securitypriv.btkip_countermeasure_time;
-#ifdef CONFIG_IEEE80211W
-		/* reset RX BIP packet number */
-		pmlmeext->mgnt_80211w_IPN_rx = 0;
-#endif /* CONFIG_IEEE80211W */
 		_rtw_memset((unsigned char *)&adapter->securitypriv, 0, sizeof(struct security_priv));
 
 		/* Added by Albert 2009/02/18 */
@@ -228,7 +230,7 @@ void rtw_indicate_sta_assoc_event(_adapter *padapter, struct sta_info *psta)
 	if (psta == NULL)
 		return;
 
-	if (psta->cmn.aid > NUM_STA)
+	if (psta->cmn.aid > pstapriv->max_aid)
 		return;
 
 	if (pstapriv->sta_aid[psta->cmn.aid - 1] != psta)
@@ -255,7 +257,7 @@ void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info *psta)
 	if (psta == NULL)
 		return;
 
-	if (psta->cmn.aid > NUM_STA)
+	if (psta->cmn.aid > pstapriv->max_aid)
 		return;
 
 	if (pstapriv->sta_aid[psta->cmn.aid - 1] != psta)
@@ -382,9 +384,6 @@ int hostapd_mode_init(_adapter *padapter)
 
 	/* pnetdev->wireless_handlers = NULL; */
 
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
-	pnetdev->features |= NETIF_F_IP_CSUM;
-#endif
 
 
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/os_intfs.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/os_intfs.c
index 1c35c0b86c86..bbb629580382 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/os_intfs.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/os_intfs.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -33,20 +34,21 @@ MODULE_VERSION(DRIVERVERSION);
 int rtw_chip_version = 0x00;
 int rtw_rfintfs = HWPI;
 int rtw_lbkmode = 0;/* RTL8712_AIR_TRX; */
-
-
+#ifdef DBG_LA_MODE
+int rtw_la_mode_en=1;
+module_param(rtw_la_mode_en, int, 0644);
+#endif
 int rtw_network_mode = Ndis802_11IBSS;/* Ndis802_11Infrastructure; */ /* infra, ad-hoc, auto */
 /* NDIS_802_11_SSID	ssid; */
 int rtw_channel = 1;/* ad-hoc support requirement */
 int rtw_wireless_mode = WIRELESS_MODE_MAX;
+module_param(rtw_wireless_mode, int, 0644);
 int rtw_vrtl_carrier_sense = AUTO_VCS;
 int rtw_vcs_type = RTS_CTS;
 int rtw_rts_thresh = 2347;
 int rtw_frag_thresh = 2346;
 int rtw_preamble = PREAMBLE_LONG;/* long, short, auto */
 int rtw_scan_mode = 1;/* active, passive */
-int rtw_adhoc_tx_pwr = 1;
-int rtw_soft_ap = 0;
 /* int smart_ps = 1; */
 #ifdef CONFIG_POWER_SAVING
 	int rtw_power_mgnt = PS_MODE_MAX;
@@ -62,16 +64,20 @@ int rtw_soft_ap = 0;
 		#if defined(CONFIG_LPS_PG)
 			/*int rtw_lps_level = LPS_PG;*//*FW not support yet*/
 			int rtw_lps_level = LPS_LCLK;
+		#elif defined(CONFIG_LPS_PG_DDMA)
+			int rtw_lps_level = LPS_PG;
 		#elif defined(CONFIG_LPS_LCLK)
 			int rtw_lps_level = LPS_LCLK;
 		#else
 			int rtw_lps_level = LPS_NORMAL;
 		#endif
 	#endif/*CONFIG_USB_HCI*/
+	int rtw_lps_chk_by_tp = 1;
 #else /* !CONFIG_POWER_SAVING */
 	int rtw_power_mgnt = PS_MODE_ACTIVE;
 	int rtw_ips_mode = IPS_NONE;
 	int rtw_lps_level = LPS_NORMAL;
+	int rtw_lps_chk_by_tp = 0;
 #endif /* CONFIG_POWER_SAVING */
 
 
@@ -81,6 +87,8 @@ MODULE_PARM_DESC(rtw_ips_mode, "The default IPS mode");
 module_param(rtw_lps_level, int, 0644);
 MODULE_PARM_DESC(rtw_lps_level, "The default LPS level");
 
+module_param(rtw_lps_chk_by_tp, int, 0644);
+
 /* LPS: 
  * rtw_smart_ps = 0 => TX: pwr bit = 1, RX: PS_Poll
  * rtw_smart_ps = 1 => TX: pwr bit = 0, RX: PS_Poll
@@ -88,6 +96,8 @@ MODULE_PARM_DESC(rtw_lps_level, "The default LPS level");
 */
 int rtw_smart_ps = 2;
 
+int rtw_max_bss_cnt = 0;
+module_param(rtw_max_bss_cnt, int, 0644);
 #ifdef CONFIG_WMMPS_STA	
 /* WMMPS: 
  * rtw_smart_ps = 0 => Only for fw test
@@ -112,6 +122,7 @@ module_param(rtw_dynamic_agg_enable, int, 0644);
 /* set log level when inserting driver module, default log level is _DRV_INFO_ = 4,
 * please refer to "How_to_set_driver_debug_log_level.doc" to set the available level.
 */
+#ifdef CONFIG_RTW_DEBUG
 #ifdef RTW_LOG_LEVEL
 	uint rtw_drv_log_level = (uint)RTW_LOG_LEVEL; /* from Makefile */
 #else
@@ -119,7 +130,7 @@ module_param(rtw_dynamic_agg_enable, int, 0644);
 #endif
 module_param(rtw_drv_log_level, uint, 0644);
 MODULE_PARM_DESC(rtw_drv_log_level, "set log level when insert driver module, default log level is _DRV_INFO_ = 4");
-
+#endif
 int rtw_radio_enable = 1;
 int rtw_long_retry_lmt = 7;
 int rtw_short_retry_lmt = 7;
@@ -163,6 +174,11 @@ uint rtw_tx_bw_mode = 0x21;
 module_param(rtw_tx_bw_mode, uint, 0644);
 MODULE_PARM_DESC(rtw_tx_bw_mode, "The max tx bw for 2.4G and 5G. format is the same as rtw_bw_mode");
 
+#ifdef CONFIG_FW_HANDLE_TXBCN
+uint rtw_tbtt_rpt = 0;	/*ROOT AP - BIT0, VAP1 - BIT1, VAP2 - BIT2, VAP3 - VAP3, FW report TBTT INT by C2H*/
+module_param(rtw_tbtt_rpt, uint, 0644);
+#endif
+
 #ifdef CONFIG_80211N_HT
 int rtw_ht_enable = 1;
 /* 0: 20 MHz, 1: 40 MHz, 2: 80 MHz, 3: 160MHz, 4: 80+80MHz
@@ -177,6 +193,8 @@ int rtw_ampdu_enable = 1;/* for enable tx_ampdu , */ /* 0: disable, 0x1:enable *
 int rtw_rx_stbc = 1;/* 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 */
 #if (defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B)) && defined(CONFIG_PCI_HCI)
 int rtw_rx_ampdu_amsdu = 2;/* 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on */
+#elif (defined(CONFIG_RTL8822B) && defined(CONFIG_SDIO_HCI))
+int rtw_rx_ampdu_amsdu = 1;
 #else
 int rtw_rx_ampdu_amsdu;/* 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on */
 #endif
@@ -217,6 +235,7 @@ int rtw_short_gi = 0xf;
 int rtw_ldpc_cap = 0x33;
 /* BIT0: Enable VHT STBC Rx, BIT1: Enable VHT STBC Tx, BIT4: Enable HT STBC Rx, BIT5: Enable HT STBC Tx */
 int rtw_stbc_cap = 0x13;
+
 /*
 * BIT0: Enable VHT SU Beamformer
 * BIT1: Enable VHT SU Beamformee
@@ -251,11 +270,7 @@ module_param(rtw_rf_config, int, 0644);
 int rtw_check_hw_status = 0;
 
 int rtw_low_power = 0;
-#ifdef CONFIG_WIFI_TEST
-	int rtw_wifi_spec = 1;/* for wifi test */
-#else
-	int rtw_wifi_spec = 0;
-#endif
+int rtw_wifi_spec = 0;
 
 int rtw_special_rf_path = 0; /* 0: 2T2R ,1: only turn on path A 1T1R */
 
@@ -390,6 +405,12 @@ char *rtw_initmac = 0;  /* temp mac address if users want to use instead of the
 #ifdef CONFIG_AP_MODE
 u8 rtw_bmc_tx_rate = MGN_UNKNOWN;
 #endif
+#ifdef RTW_WOW_STA_MIX
+int rtw_wowlan_sta_mix_mode = 1;
+#else
+int rtw_wowlan_sta_mix_mode = 0;
+#endif
+module_param(rtw_wowlan_sta_mix_mode, int, 0644);
 module_param(rtw_pwrtrim_enable, int, 0644);
 module_param(rtw_initmac, charp, 0644);
 module_param(rtw_special_rf_path, int, 0644);
@@ -518,14 +539,6 @@ uint rtw_adaptivity_mode = CONFIG_RTW_ADAPTIVITY_MODE;
 module_param(rtw_adaptivity_mode, uint, 0644);
 MODULE_PARM_DESC(rtw_adaptivity_mode, "0:normal, 1:carrier sense");
 
-uint rtw_adaptivity_dml = CONFIG_RTW_ADAPTIVITY_DML;
-module_param(rtw_adaptivity_dml, uint, 0644);
-MODULE_PARM_DESC(rtw_adaptivity_dml, "0:disable, 1:enable");
-
-uint rtw_adaptivity_dc_backoff = CONFIG_RTW_ADAPTIVITY_DC_BACKOFF;
-module_param(rtw_adaptivity_dc_backoff, uint, 0644);
-MODULE_PARM_DESC(rtw_adaptivity_dc_backoff, "DC backoff for Adaptivity");
-
 int rtw_adaptivity_th_l2h_ini = CONFIG_RTW_ADAPTIVITY_TH_L2H_INI;
 module_param(rtw_adaptivity_th_l2h_ini, int, 0644);
 MODULE_PARM_DESC(rtw_adaptivity_th_l2h_ini, "th_l2h_ini for Adaptivity");
@@ -648,6 +661,14 @@ module_param_array(rtw_target_tx_pwr_5g_d, int, &rtw_target_tx_pwr_5g_d_num, 064
 MODULE_PARM_DESC(rtw_target_tx_pwr_5g_d, "5G target tx power (unit:dBm) of RF path D for each rate section, should match the real calibrate power, -1: undefined");
 #endif /* CONFIG_IEEE80211_BAND_5GHZ */
 
+int rtw_tsf_update_pause_factor = CONFIG_TSF_UPDATE_PAUSE_FACTOR;
+module_param(rtw_tsf_update_pause_factor, int, 0644);
+MODULE_PARM_DESC(rtw_tsf_update_pause_factor, "num of bcn intervals to stay TSF update pause status");
+
+int rtw_tsf_update_restore_factor = CONFIG_TSF_UPDATE_RESTORE_FACTOR;
+module_param(rtw_tsf_update_restore_factor, int, 0644);
+MODULE_PARM_DESC(rtw_tsf_update_restore_factor, "num of bcn intervals to stay TSF update restore status");
+
 #ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
 char *rtw_phy_file_path = REALTEK_CONFIG_PATH;
 module_param(rtw_phy_file_path, charp, 0644);
@@ -678,11 +699,34 @@ module_param(rtw_trx_share_mode, int, 0644);
 MODULE_PARM_DESC(rtw_trx_share_mode, "TRx FIFO Shared");
 #endif
 
+#ifdef CONFIG_DYNAMIC_SOML
+uint rtw_dynamic_soml_en = 1;
+module_param(rtw_dynamic_soml_en, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_en, "0: disable, 1: enable with default param, 2: enable with specified param.");
+
+uint rtw_dynamic_soml_train_num = 0;
+module_param(rtw_dynamic_soml_train_num, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_train_num, "SOML training number");
+
+uint rtw_dynamic_soml_interval = 0;
+module_param(rtw_dynamic_soml_interval, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_interval, "SOML training interval");
+
+uint rtw_dynamic_soml_period = 0;
+module_param(rtw_dynamic_soml_period, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_period, "SOML training period");
+
+uint rtw_dynamic_soml_delay = 0;
+module_param(rtw_dynamic_soml_delay, int, 0644);
+MODULE_PARM_DESC(rtw_dynamic_soml_delay, "SOML training delay");
+#endif
+
+
 int _netdev_open(struct net_device *pnetdev);
 int netdev_open(struct net_device *pnetdev);
 static int netdev_close(struct net_device *pnetdev);
-#if defined(CONFIG_PLATFORM_INTEL_BYT) && defined(CONFIG_SDIO_HCI)
-extern int rtw_sdio_set_power(struct sdio_func *func, int on);
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+extern int rtw_sdio_set_power(int on);
 #endif /* CONFIG_PLATFORM_INTEL_BYT */
 
 #ifdef CONFIG_MCC_MODE
@@ -698,11 +742,7 @@ int rtw_mcc_sta_bw80_target_tx_tp = MCC_STA_BW80_TARGET_TX_TP;
 int rtw_mcc_single_tx_cri = MCC_SINGLE_TX_CRITERIA;
 int rtw_mcc_policy_table_idx = 0;
 int rtw_mcc_duration = 0;
-int rtw_mcc_tsf_sync_offset = 0;
-int rtw_mcc_start_time_offset = 0;
-int rtw_mcc_interval = 0;
-int rtw_mcc_guard_offset0 = -1;
-int rtw_mcc_guard_offset1 = -1;
+int rtw_mcc_enable_runtime_duration = 1;
 module_param(rtw_en_mcc, int, 0644);
 module_param(rtw_mcc_single_tx_cri, int, 0644);
 module_param(rtw_mcc_ap_bw20_target_tx_tp, int, 0644);
@@ -713,11 +753,6 @@ module_param(rtw_mcc_sta_bw40_target_tx_tp, int, 0644);
 module_param(rtw_mcc_sta_bw80_target_tx_tp, int, 0644);
 module_param(rtw_mcc_policy_table_idx, int, 0644);
 module_param(rtw_mcc_duration, int, 0644);
-module_param(rtw_mcc_tsf_sync_offset, int, 0644);
-module_param(rtw_mcc_start_time_offset, int, 0644);
-module_param(rtw_mcc_interval, int, 0644);
-module_param(rtw_mcc_guard_offset0, int, 0644);
-module_param(rtw_mcc_guard_offset1, int, 0644);
 #endif /*CONFIG_MCC_MODE */
 
 #ifdef CONFIG_RTW_NAPI
@@ -744,6 +779,13 @@ int rtw_iqk_fw_offload;
 #endif /* RTW_IQK_FW_OFFLOAD */
 module_param(rtw_iqk_fw_offload, int, 0644);
 
+#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
+int rtw_ch_switch_offload = 0;
+#else
+int rtw_ch_switch_offload;
+#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
+module_param(rtw_ch_switch_offload, int, 0644);
+
 #ifdef CONFIG_TDLS
 int rtw_en_tdls = 1;
 module_param(rtw_en_tdls, int, 0644);
@@ -754,6 +796,19 @@ int rtw_fw_param_init = 1;
 module_param(rtw_fw_param_init, int, 0644);
 #endif
 
+#ifdef CONFIG_TDMADIG
+int rtw_tdmadig_en = 1;
+/*
+1:MODE_PERFORMANCE
+2:MODE_COVERAGE
+*/
+int rtw_tdmadig_mode = 1;
+int rtw_dynamic_tdmadig = 0;
+module_param(rtw_tdmadig_en, int, 0644);
+module_param(rtw_tdmadig_mode, int, 0644);
+module_param(rtw_dynamic_tdmadig, int, 0644);
+#endif/*CONFIG_TDMADIG*/
+
 #ifdef CONFIG_WOWLAN
 /*
  * bit[0]: magic packet wake up
@@ -762,6 +817,13 @@ module_param(rtw_fw_param_init, int, 0644);
  */
 uint rtw_wakeup_event = RTW_WAKEUP_EVENT;
 module_param(rtw_wakeup_event, uint, 0644);
+/*
+ * 0: common WOWLAN
+ * bit[0]: disable BB RF
+ * bit[1]: For wireless remote controller with or without connection
+ */
+uint rtw_suspend_type = RTW_SUSPEND_TYPE;
+module_param(rtw_suspend_type, uint, 0644);
 #endif
 
 void rtw_regsty_load_target_tx_power(struct registry_priv *regsty)
@@ -871,17 +933,25 @@ uint loadparam(_adapter *padapter)
 	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->check_fw_ps = (u8)rtw_check_fw_ps;
-	registry_par->power_mgnt = (u8)rtw_power_mgnt;
-	registry_par->ips_mode = (u8)rtw_ips_mode;
+	#ifdef CONFIG_TDMADIG
+		registry_par->tdmadig_en = (u8)rtw_tdmadig_en;
+		registry_par->tdmadig_mode = (u8)rtw_tdmadig_mode;
+		registry_par->tdmadig_dynamic = (u8) rtw_dynamic_tdmadig;
+		registry_par->power_mgnt = PS_MODE_ACTIVE;
+		registry_par->ips_mode = IPS_NONE;
+	#else
+		registry_par->power_mgnt = (u8)rtw_power_mgnt;
+		registry_par->ips_mode = (u8)rtw_ips_mode;
+	#endif/*CONFIG_TDMADIG*/
 	registry_par->lps_level = (u8)rtw_lps_level;
+	registry_par->lps_chk_by_tp = (u8)rtw_lps_chk_by_tp;
 	registry_par->radio_enable = (u8)rtw_radio_enable;
 	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->max_bss_cnt = (u16)rtw_max_bss_cnt;
 	/* registry_par->qos_enable = (u8)rtw_qos_enable; */
 	registry_par->ack_policy = (u8)rtw_ack_policy;
 	registry_par->mp_mode = (u8)rtw_mp_mode;
@@ -911,20 +981,32 @@ uint loadparam(_adapter *padapter)
 
 #ifdef CONFIG_80211N_HT
 	registry_par->ht_enable = (u8)rtw_ht_enable;
-	registry_par->bw_mode = (u8)rtw_bw_mode;
-	registry_par->ampdu_enable = (u8)rtw_ampdu_enable;
-	registry_par->rx_stbc = (u8)rtw_rx_stbc;
-	registry_par->rx_ampdu_amsdu = (u8)rtw_rx_ampdu_amsdu;
-	registry_par->tx_ampdu_amsdu = (u8)rtw_tx_ampdu_amsdu;
-	registry_par->short_gi = (u8)rtw_short_gi;
-	registry_par->ldpc_cap = (u8)rtw_ldpc_cap;
-	registry_par->stbc_cap = (u8)rtw_stbc_cap;
-	registry_par->beamform_cap = (u8)rtw_beamform_cap;
-	registry_par->beamformer_rf_num = (u8)rtw_bfer_rf_number;
-	registry_par->beamformee_rf_num = (u8)rtw_bfee_rf_number;
-	rtw_regsty_init_rx_ampdu_sz_limit(registry_par);
+	if (registry_par->ht_enable && is_supported_ht(registry_par->wireless_mode)) {
+		registry_par->bw_mode = (u8)rtw_bw_mode;
+		registry_par->ampdu_enable = (u8)rtw_ampdu_enable;
+		registry_par->rx_stbc = (u8)rtw_rx_stbc;
+		registry_par->rx_ampdu_amsdu = (u8)rtw_rx_ampdu_amsdu;
+		registry_par->tx_ampdu_amsdu = (u8)rtw_tx_ampdu_amsdu;
+		registry_par->short_gi = (u8)rtw_short_gi;
+		registry_par->ldpc_cap = (u8)rtw_ldpc_cap;
+#if defined(CONFIG_CUSTOMER01_SMART_ANTENNA)
+		rtw_stbc_cap = 0x0;
+#elif defined(CONFIG_RTW_TX_2PATH_EN)
+		rtw_stbc_cap &= ~(BIT1|BIT5);
+#endif
+		registry_par->stbc_cap = (u8)rtw_stbc_cap;
+#if defined(CONFIG_RTW_TX_2PATH_EN)
+		rtw_beamform_cap &= ~(BIT0|BIT2|BIT4);
+#endif
+		registry_par->beamform_cap = (u8)rtw_beamform_cap;
+		registry_par->beamformer_rf_num = (u8)rtw_bfer_rf_number;
+		registry_par->beamformee_rf_num = (u8)rtw_bfee_rf_number;
+		rtw_regsty_init_rx_ampdu_sz_limit(registry_par);
+	}
+#endif
+#ifdef DBG_LA_MODE
+	registry_par->la_mode_en = (u8)rtw_la_mode_en;
 #endif
-
 #ifdef CONFIG_80211AC_VHT
 	registry_par->vht_enable = (u8)rtw_vht_enable;
 	registry_par->ampdu_factor = (u8)rtw_ampdu_factor;
@@ -1024,6 +1106,9 @@ uint loadparam(_adapter *padapter)
 
 	rtw_regsty_load_target_tx_power(registry_par);
 
+	registry_par->tsf_update_pause_factor = (u8)rtw_tsf_update_pause_factor;
+	registry_par->tsf_update_restore_factor = (u8)rtw_tsf_update_restore_factor;
+
 	registry_par->TxBBSwing_2G = (s8)rtw_TxBBSwing_2G;
 	registry_par->TxBBSwing_5G = (s8)rtw_TxBBSwing_5G;
 	registry_par->bEn_RFE = 1;
@@ -1042,11 +1127,17 @@ uint loadparam(_adapter *padapter)
 
 	registry_par->adaptivity_en = (u8)rtw_adaptivity_en;
 	registry_par->adaptivity_mode = (u8)rtw_adaptivity_mode;
-	registry_par->adaptivity_dml = (u8)rtw_adaptivity_dml;
-	registry_par->adaptivity_dc_backoff = (u8)rtw_adaptivity_dc_backoff;
 	registry_par->adaptivity_th_l2h_ini = (s8)rtw_adaptivity_th_l2h_ini;
 	registry_par->adaptivity_th_edcca_hl_diff = (s8)rtw_adaptivity_th_edcca_hl_diff;
 
+#ifdef CONFIG_DYNAMIC_SOML
+	registry_par->dyn_soml_en = (u8)rtw_dynamic_soml_en;
+	registry_par->dyn_soml_train_num = (u8)rtw_dynamic_soml_train_num;
+	registry_par->dyn_soml_interval = (u8)rtw_dynamic_soml_interval;
+	registry_par->dyn_soml_period = (u8)rtw_dynamic_soml_period;
+	registry_par->dyn_soml_delay = (u8)rtw_dynamic_soml_delay;
+#endif
+
 	registry_par->boffefusemask = (u8)rtw_OffEfuseMask;
 	registry_par->bFileMaskEfuse = (u8)rtw_FileMaskEfuse;
 
@@ -1077,20 +1168,18 @@ uint loadparam(_adapter *padapter)
 	registry_par->rtw_mcc_single_tx_cri = (u32)rtw_mcc_single_tx_cri;
 	registry_par->rtw_mcc_policy_table_idx = rtw_mcc_policy_table_idx;
 	registry_par->rtw_mcc_duration = (u8)rtw_mcc_duration;
-	registry_par->rtw_mcc_tsf_sync_offset = (u8)rtw_mcc_tsf_sync_offset;
-	registry_par->rtw_mcc_start_time_offset = (u8)rtw_mcc_start_time_offset;
-	registry_par->rtw_mcc_interval = (u8)rtw_mcc_interval;
-	registry_par->rtw_mcc_guard_offset0 = rtw_mcc_guard_offset0;
-	registry_par->rtw_mcc_guard_offset1 = rtw_mcc_guard_offset1;
+	registry_par->rtw_mcc_enable_runtime_duration = rtw_mcc_enable_runtime_duration;
 #endif /*CONFIG_MCC_MODE */
 
 #ifdef CONFIG_WOWLAN
 	registry_par->wakeup_event = rtw_wakeup_event;
+	registry_par->suspend_type = rtw_suspend_type;
 #endif
 
 #ifdef CONFIG_SUPPORT_TRX_SHARED
 	registry_par->trx_share_mode = rtw_trx_share_mode;
 #endif
+	registry_par->wowlan_sta_mix_mode = rtw_wowlan_sta_mix_mode;
 
 #ifdef CONFIG_PCI_HCI
 	registry_par->pci_aspm_config = rtw_pci_aspm_enable;
@@ -1111,6 +1200,7 @@ uint loadparam(_adapter *padapter)
 #endif /* CONFIG_RTW_NAPI */
 
 	registry_par->iqk_fw_offload = (u8)rtw_iqk_fw_offload;
+	registry_par->ch_switch_offload = (u8)rtw_ch_switch_offload;
 
 #ifdef CONFIG_TDLS
 	registry_par->en_tdls = rtw_en_tdls;
@@ -1125,6 +1215,10 @@ uint loadparam(_adapter *padapter)
 #ifdef CONFIG_AP_MODE
 	registry_par->bmc_tx_rate = rtw_bmc_tx_rate;
 #endif
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	registry_par->fw_tbtt_rpt = rtw_tbtt_rpt;
+#endif
+
 	return status;
 }
 
@@ -1266,7 +1360,11 @@ unsigned int rtw_classify8021d(struct sk_buff *skb)
 
 static u16 rtw_select_queue(struct net_device *dev, struct sk_buff *skb
 #if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0)
+	#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 19, 0)
+	, struct net_device *sb_dev
+	#else
 	, void *accel_priv
+	#endif
 	#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
 	, select_queue_fallback_t fallback
 	#endif
@@ -1351,6 +1449,15 @@ static int rtw_ndev_notifier_call(struct notifier_block *nb, unsigned long state
 	case NETDEV_CHANGENAME:
 		rtw_adapter_proc_replace(ndev);
 		break;
+	#ifdef CONFIG_NEW_NETDEV_HDL
+	case NETDEV_PRE_UP :
+		{
+			_adapter *adapter = rtw_netdev_priv(ndev);
+
+			rtw_pwr_wakeup(adapter);
+		}
+		break;
+	#endif
 	}
 
 	return NOTIFY_DONE;
@@ -1410,9 +1517,8 @@ static const struct net_device_ops rtw_netdev_ops = {
 
 int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname)
 {
-	_adapter *padapter = rtw_netdev_priv(pnetdev);
-
 #ifdef CONFIG_EASY_REPLACEMENT
+	_adapter *padapter = rtw_netdev_priv(pnetdev);
 	struct net_device	*TargetNetdev = NULL;
 	_adapter			*TargetAdapter = NULL;
 	struct net		*devnet = NULL;
@@ -1500,10 +1606,27 @@ struct net_device *rtw_init_netdev(_adapter *old_padapter)
 		rtw_hook_vir_if_ops(pnetdev);
 #endif /* CONFIG_CONCURRENT_MODE */
 
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
-	pnetdev->features |= NETIF_F_IP_CSUM;
+
+#ifdef CONFIG_TX_CSUM_OFFLOAD
+        pnetdev->features |= (NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM);
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
+        pnetdev->hw_features |= (NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM);
+#endif
 #endif
 
+#ifdef CONFIG_RTW_NETIF_SG
+        pnetdev->features |= NETIF_F_SG;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
+        pnetdev->hw_features |= NETIF_F_SG;
+#endif
+#endif
+
+	if ((pnetdev->features & NETIF_F_SG) && (pnetdev->features & NETIF_F_IP_CSUM)) {
+		pnetdev->features |= (NETIF_F_TSO | NETIF_F_GSO);
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
+		pnetdev->hw_features |= (NETIF_F_TSO | NETIF_F_GSO);
+#endif
+	}
 	/* pnetdev->tx_timeout = NULL; */
 	pnetdev->watchdog_timeo = HZ * 3; /* 3 second timeout */
 
@@ -1561,6 +1684,12 @@ void rtw_os_ndev_free(_adapter *adapter)
 	rtw_cfg80211_ndev_res_free(adapter);
 #endif
 
+	/* free the old_pnetdev */
+	if (adapter->rereg_nd_name_priv.old_pnetdev) {
+		rtw_free_netdev(adapter->rereg_nd_name_priv.old_pnetdev);
+		adapter->rereg_nd_name_priv.old_pnetdev = NULL;
+	}
+
 	if (adapter->pnetdev) {
 		rtw_free_netdev(adapter->pnetdev);
 		adapter->pnetdev = NULL;
@@ -1585,7 +1714,9 @@ int rtw_os_ndev_register(_adapter *adapter, const char *name)
 		goto exit;
 	}
 #endif
-
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0)) && defined(CONFIG_PCI_HCI)
+	ndev->gro_flush_timeout = 100000;
+#endif
 	/* alloc netdev name */
 	rtw_init_netdev_name(ndev, name);
 
@@ -1785,46 +1916,59 @@ u32 rtw_start_drv_threads(_adapter *padapter)
 {
 	u32 _status = _SUCCESS;
 
+	RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(padapter));
 
 #ifdef CONFIG_XMIT_THREAD_MODE
 #if defined(CONFIG_SDIO_HCI)
 	if (is_primary_adapter(padapter))
 #endif
 	{
-		padapter->xmitThread = kthread_run(rtw_xmit_thread, padapter, "RTW_XMIT_THREAD");
-		if (IS_ERR(padapter->xmitThread)) {
-			padapter->xmitThread = NULL;
-			_status = _FAIL;
+		if (padapter->xmitThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_XMIT_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->xmitThread = kthread_run(rtw_xmit_thread, padapter, "RTW_XMIT_THREAD");
+			if (IS_ERR(padapter->xmitThread)) {
+				padapter->xmitThread = NULL;
+				_status = _FAIL;
+			}
 		}
 	}
 #endif /* #ifdef CONFIG_XMIT_THREAD_MODE */
 
 #ifdef CONFIG_RECV_THREAD_MODE
 	if (is_primary_adapter(padapter)) {
-		padapter->recvThread = kthread_run(rtw_recv_thread, padapter, "RTW_RECV_THREAD");
-		if (IS_ERR(padapter->recvThread)) {
-			padapter->recvThread = NULL;
-			_status = _FAIL;
+		if (padapter->recvThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_RECV_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->recvThread = kthread_run(rtw_recv_thread, padapter, "RTW_RECV_THREAD");
+			if (IS_ERR(padapter->recvThread)) {
+				padapter->recvThread = NULL;
+				_status = _FAIL;
+			}
 		}
 	}
 #endif
 
 	if (is_primary_adapter(padapter)) {
-		padapter->cmdThread = kthread_run(rtw_cmd_thread, padapter, "RTW_CMD_THREAD");
-		if (IS_ERR(padapter->cmdThread)) {
-			padapter->cmdThread = NULL;
-			_status = _FAIL;
+		if (padapter->cmdThread == NULL) {
+			RTW_INFO(FUNC_ADPT_FMT " start RTW_CMD_THREAD\n", FUNC_ADPT_ARG(padapter));
+			padapter->cmdThread = kthread_run(rtw_cmd_thread, padapter, "RTW_CMD_THREAD");
+			if (IS_ERR(padapter->cmdThread)) {
+				padapter->cmdThread = NULL;
+				_status = _FAIL;
+			}
+			else
+				_rtw_down_sema(&padapter->cmdpriv.start_cmdthread_sema); /* wait for cmd_thread to run */
 		}
-		else
-			_rtw_down_sema(&padapter->cmdpriv.start_cmdthread_sema); /* wait for cmd_thread to run */
 	}
 
 
 #ifdef CONFIG_EVENT_THREAD_MODE
-	padapter->evtThread = kthread_run(event_thread, padapter, "RTW_EVENT_THREAD");
-	if (IS_ERR(padapter->evtThread)) {
-		padapter->evtThread = NULL;
-		_status = _FAIL;
+	if (padapter->evtThread == NULL) {
+		RTW_INFO(FUNC_ADPT_FMT " start RTW_EVENT_THREAD\n", FUNC_ADPT_ARG(padapter));
+		padapter->evtThread = kthread_run(event_thread, padapter, "RTW_EVENT_THREAD");
+		if (IS_ERR(padapter->evtThread)) {
+			padapter->evtThread = NULL;
+			_status = _FAIL;
+		}
 	}
 #endif
 
@@ -1835,7 +1979,7 @@ u32 rtw_start_drv_threads(_adapter *padapter)
 
 void rtw_stop_drv_threads(_adapter *padapter)
 {
-
+	RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(padapter));
 	if (is_primary_adapter(padapter))
 		rtw_stop_cmd_thread(padapter);
 
@@ -1874,13 +2018,11 @@ void rtw_stop_drv_threads(_adapter *padapter)
 	rtw_hal_stop_thread(padapter);
 }
 
-u8 rtw_init_default_value(_adapter *padapter);
 u8 rtw_init_default_value(_adapter *padapter)
 {
 	u8 ret  = _SUCCESS;
 	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 */
@@ -1925,6 +2067,11 @@ u8 rtw_init_default_value(_adapter *padapter)
 	/* hal_priv */
 	rtw_hal_def_value_init(padapter);
 
+#ifdef CONFIG_MCC_MODE
+	/* MCC parameter */
+	rtw_hal_mcc_parameter_init(padapter);
+#endif /* CONFIG_MCC_MODE */
+
 	/* misc. */
 	RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
 	RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
@@ -1965,8 +2112,6 @@ u8 rtw_init_default_value(_adapter *padapter)
 #ifdef CONFIG_RTW_NAPI
 	padapter->napi_state = NAPI_DISABLE;
 #endif
-	padapter->tsf.sync_port =  MAX_HW_PORT;
-	padapter->tsf.offset = 0;
 
 #ifdef CONFIG_RTW_ACS
 	if (pregistrypriv->acs_mode)
@@ -1982,6 +2127,10 @@ u8 rtw_init_default_value(_adapter *padapter)
 #endif
 	return ret;
 }
+#ifdef CONFIG_CLIENT_PORT_CFG
+extern void rtw_clt_port_init(struct clt_port_t  *cltp);
+extern void rtw_clt_port_deinit(struct clt_port_t  *cltp);
+#endif
 
 struct dvobj_priv *devobj_init(void)
 {
@@ -1999,7 +2148,9 @@ struct dvobj_priv *devobj_init(void)
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
 	_rtw_mutex_init(&pdvobj->sd_indirect_access_mutex);
 #endif
-
+#ifdef CONFIG_SYSON_INDIRECT_ACCESS
+	_rtw_mutex_init(&pdvobj->syson_indirect_access_mutex);
+#endif
 #ifdef CONFIG_RTW_CUSTOMER_STR
 	_rtw_mutex_init(&pdvobj->customer_str_mutex);
 	_rtw_memset(pdvobj->customer_str, 0xFF, RTW_CUSTOMER_STR_LEN);
@@ -2010,6 +2161,9 @@ struct dvobj_priv *devobj_init(void)
 	ATOMIC_SET(&pdvobj->disable_func, 0);
 
 	rtw_macid_ctl_init(&pdvobj->macid_ctl);
+#ifdef CONFIG_CLIENT_PORT_CFG
+	rtw_clt_port_init(&pdvobj->clt_port);
+#endif
 	_rtw_spinlock_init(&pdvobj->cam_ctl.lock);
 	_rtw_mutex_init(&pdvobj->cam_ctl.sec_cam_access_mutex);
 #if defined(RTK_129X_PLATFORM) && defined(CONFIG_PCI_HCI)
@@ -2020,18 +2174,23 @@ struct dvobj_priv *devobj_init(void)
 #endif
 
 #ifdef CONFIG_AP_MODE
+	#ifdef CONFIG_SUPPORT_MULTI_BCN
 	pdvobj->nr_ap_if = 0;
 	pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL; /* default value is equal to the default beacon_interval (100ms) */
 	_rtw_init_queue(&pdvobj->ap_if_q);
-#ifdef CONFIG_SWTIMER_BASED_TXBCN
+	pdvobj->vap_map = 0;
+	#endif /*CONFIG_SUPPORT_MULTI_BCN*/
+	#ifdef CONFIG_SWTIMER_BASED_TXBCN
 	rtw_init_timer(&(pdvobj->txbcn_timer), NULL, tx_beacon_timer_handlder, pdvobj);
-#endif
+	#endif
 #endif
 
 	rtw_init_timer(&(pdvobj->dynamic_chk_timer), NULL, rtw_dynamic_check_timer_handlder, pdvobj);
+	rtw_init_timer(&(pdvobj->periodic_tsf_update_end_timer), NULL, rtw_hal_periodic_tsf_update_end_timer_hdl, pdvobj);
 
 #ifdef CONFIG_MCC_MODE
 	_rtw_mutex_init(&(pdvobj->mcc_objpriv.mcc_mutex));
+	_rtw_mutex_init(&(pdvobj->mcc_objpriv.mcc_tsf_req_mutex));
 	_rtw_spinlock_init(&pdvobj->mcc_objpriv.mcc_lock);
 #endif /* CONFIG_MCC_MODE */
 
@@ -2040,6 +2199,13 @@ struct dvobj_priv *devobj_init(void)
 #endif /* CONFIG_RTW_NAPI_DYNAMIC */
 
 
+#ifdef CONFIG_RTW_TPT_MODE
+	pdvobj->tpt_mode = 0;
+	pdvobj->edca_be_ul = 0x5ea42b;
+	pdvobj->edca_be_dl = 0x00a42b;
+#endif 
+	pdvobj->scan_deny = _FALSE;
+
 	return pdvobj;
 
 }
@@ -2056,6 +2222,7 @@ void devobj_deinit(struct dvobj_priv *pdvobj)
 
 #ifdef CONFIG_MCC_MODE
 	_rtw_mutex_free(&(pdvobj->mcc_objpriv.mcc_mutex));
+	_rtw_mutex_free(&(pdvobj->mcc_objpriv.mcc_tsf_req_mutex));
 	_rtw_spinlock_free(&pdvobj->mcc_objpriv.mcc_lock);
 #endif /* CONFIG_MCC_MODE */
 
@@ -2072,8 +2239,15 @@ void devobj_deinit(struct dvobj_priv *pdvobj)
 #ifdef CONFIG_SDIO_INDIRECT_ACCESS
 	_rtw_mutex_free(&pdvobj->sd_indirect_access_mutex);
 #endif
+#ifdef CONFIG_SYSON_INDIRECT_ACCESS
+	_rtw_mutex_free(&pdvobj->syson_indirect_access_mutex);
+#endif
 
 	rtw_macid_ctl_deinit(&pdvobj->macid_ctl);
+#ifdef CONFIG_CLIENT_PORT_CFG
+	rtw_clt_port_deinit(&pdvobj->clt_port);
+#endif
+
 	_rtw_spinlock_free(&pdvobj->cam_ctl.lock);
 	_rtw_mutex_free(&pdvobj->cam_ctl.sec_cam_access_mutex);
 
@@ -2083,9 +2257,9 @@ void devobj_deinit(struct dvobj_priv *pdvobj)
 #ifdef CONFIG_MBSSID_CAM
 	rtw_mbid_cam_deinit(pdvobj);
 #endif
-
+#ifdef CONFIG_SUPPORT_MULTI_BCN
 	_rtw_spinlock_free(&(pdvobj->ap_if_q.lock));
-
+#endif
 	rtw_mfree((u8 *)pdvobj, sizeof(*pdvobj));
 }
 
@@ -2130,15 +2304,11 @@ u8 rtw_reset_drv_sw(_adapter *padapter)
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
 
 	/* hal_priv */
-	if (is_primary_adapter(padapter))
-		rtw_hal_def_value_init(padapter);
+	rtw_hal_def_value_init(padapter);
 
 	RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
 	RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
 
-	padapter->tsf.sync_port =  MAX_HW_PORT;
-	padapter->tsf.offset = 0;
-
 	padapter->bLinkInfoDump = 0;
 
 	padapter->xmitpriv.tx_pkts = 0;
@@ -2177,12 +2347,25 @@ u8 rtw_reset_drv_sw(_adapter *padapter)
 
 u8 rtw_init_drv_sw(_adapter *padapter)
 {
-
 	u8	ret8 = _SUCCESS;
 
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+#endif
 
-
+	#if defined(CONFIG_AP_MODE) && defined(CONFIG_SUPPORT_MULTI_BCN)
 	_rtw_init_listhead(&padapter->list);
+	#ifdef CONFIG_FW_HANDLE_TXBCN
+	padapter->vap_id = CONFIG_LIMITED_AP_NUM;
+	if (is_primary_adapter(padapter))
+		adapter_to_dvobj(padapter)->vap_tbtt_rpt_map = adapter_to_regsty(padapter)->fw_tbtt_rpt;
+	#endif
+	#endif
+
+	#ifdef CONFIG_CLIENT_PORT_CFG
+	padapter->client_id = MAX_CLIENT_PORT_NUM;
+	padapter->client_port = CLT_PORT_INVALID;
+	#endif
 
 	ret8 = rtw_init_default_value(padapter);
 
@@ -2232,6 +2415,10 @@ u8 rtw_init_drv_sw(_adapter *padapter)
 	}
 #endif /* CONFIG_TDLS */
 
+#ifdef CONFIG_RTW_MESH
+	rtw_mesh_cfg_init(padapter);
+#endif
+
 	if (_rtw_init_xmit_priv(&padapter->xmitpriv, padapter) == _FAIL) {
 		RTW_INFO("Can't _rtw_init_xmit_priv\n");
 		ret8 = _FAIL;
@@ -2255,7 +2442,6 @@ u8 rtw_init_drv_sw(_adapter *padapter)
 		goto exit;
 	}
 
-	padapter->stapriv.padapter = padapter;
 	padapter->setband = WIFI_FREQUENCY_BAND_AUTO;
 	padapter->fix_rate = 0xFF;
 	padapter->power_offset = 0;
@@ -2321,6 +2507,10 @@ u8 rtw_init_drv_sw(_adapter *padapter)
 	rtw_init_rm(padapter);
 #endif
 
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+	memset(pwdev_priv->pno_mac_addr, 0xFF, ETH_ALEN);
+#endif
+
 exit:
 
 
@@ -2344,10 +2534,11 @@ void rtw_cancel_all_timer(_adapter *padapter)
 	_cancel_timer_ex(&padapter->mlmepriv.scan_to_timer);
 
 #ifdef CONFIG_DFS_MASTER
-	_cancel_timer_ex(&padapter->mlmepriv.dfs_master_timer);
+	_cancel_timer_ex(&adapter_to_rfctl(padapter)->radar_detect_timer);
 #endif
 
 	_cancel_timer_ex(&adapter_to_dvobj(padapter)->dynamic_chk_timer);
+	_cancel_timer_ex(&adapter_to_dvobj(padapter)->periodic_tsf_update_end_timer);
 #ifdef CONFIG_RTW_SW_LED
 	/* cancel sw led timer */
 	rtw_hal_sw_led_deinit(padapter);
@@ -2456,13 +2647,6 @@ u8 rtw_free_drv_sw(_adapter *padapter)
 
 	rtw_hal_free_data(padapter);
 
-
-	/* free the old_pnetdev */
-	if (padapter->rereg_nd_name_priv.old_pnetdev) {
-		free_netdev(padapter->rereg_nd_name_priv.old_pnetdev);
-		padapter->rereg_nd_name_priv.old_pnetdev = NULL;
-	}
-
 	return _SUCCESS;
 
 }
@@ -2478,6 +2662,7 @@ void rtw_intf_stop(_adapter *adapter)
 }
 
 #ifdef CONFIG_CONCURRENT_MODE
+#ifndef CONFIG_NEW_NETDEV_HDL
 int _netdev_vir_if_open(struct net_device *pnetdev)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
@@ -2612,13 +2797,19 @@ static int netdev_vir_if_close(struct net_device *pnetdev)
 
 	return 0;
 }
+#endif /*#ifndef CONFIG_NEW_NETDEV_HDL*/
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 static const struct net_device_ops rtw_netdev_vir_if_ops = {
 	.ndo_init = rtw_ndev_init,
 	.ndo_uninit = rtw_ndev_uninit,
+	#ifdef CONFIG_NEW_NETDEV_HDL
+	.ndo_open = netdev_open,
+	.ndo_stop = netdev_close,
+	#else
 	.ndo_open = netdev_vir_if_open,
 	.ndo_stop = netdev_vir_if_close,
+	#endif
 	.ndo_start_xmit = rtw_xmit_entry,
 	.ndo_set_mac_address = rtw_net_set_mac_address,
 	.ndo_get_stats = rtw_net_get_stats,
@@ -2636,8 +2827,14 @@ static void rtw_hook_vir_if_ops(struct net_device *ndev)
 #else
 	ndev->init = rtw_ndev_init;
 	ndev->uninit = rtw_ndev_uninit;
+	#ifdef CONFIG_NEW_NETDEV_HDL
+	ndev->open = netdev_open;
+	ndev->stop = netdev_close;
+	#else
 	ndev->open = netdev_vir_if_open;
 	ndev->stop = netdev_vir_if_close;
+	#endif
+
 	ndev->set_mac_address = rtw_net_set_mac_address;
 #endif
 }
@@ -2714,6 +2911,10 @@ _adapter *rtw_drv_add_vir_if(_adapter *primary_padapter,
 #ifdef CONFIG_P2P
 	rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
 #endif
+
+	rtw_led_set_ctl_en_mask_virtual(padapter);
+	rtw_led_set_iface_en(padapter, 1);
+
 	res = _SUCCESS;
 
 free_drv_sw:
@@ -2735,6 +2936,7 @@ void rtw_drv_stop_vir_if(_adapter *padapter)
 
 	if (padapter == NULL)
 		return;
+	RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(padapter));
 
 	pnetdev = padapter->pnetdev;
 
@@ -2757,11 +2959,14 @@ void rtw_drv_stop_vir_if(_adapter *padapter)
 		#endif
 
 		rtw_intf_stop(padapter);
-
+	#ifndef CONFIG_NEW_NETDEV_HDL
 		rtw_stop_drv_threads(padapter);
-
+	#endif
 		padapter->bup = _FALSE;
 	}
+	#ifdef CONFIG_NEW_NETDEV_HDL
+	rtw_stop_drv_threads(padapter);
+	#endif
 	/* cancel timer after thread stop */
 	rtw_cancel_all_timer(padapter);
 }
@@ -2797,21 +3002,6 @@ void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj)
 		rtw_drv_free_vir_if(dvobj->padapters[i]);
 }
 
-void rtw_drv_del_vir_if(_adapter *padapter)
-{
-	rtw_drv_stop_vir_if(padapter);
-	rtw_drv_free_vir_if(padapter);
-}
-
-void rtw_drv_del_vir_ifaces(_adapter *primary_padapter)
-{
-	int i;
-	struct dvobj_priv *dvobj = primary_padapter->dvobj;
-
-	for (i = VIF_START_ID; i < dvobj->iface_nums; i++)
-		rtw_drv_del_vir_if(dvobj->padapters[i]);
-
-}
 
 #endif /*end of CONFIG_CONCURRENT_MODE*/
 
@@ -2866,7 +3056,6 @@ static int rtw_inet6addr_notifier_call(struct notifier_block *nb,
 {
 	struct inet6_ifaddr *inet6_ifa = data;
 	struct net_device *ndev;
-	struct ipv6_addr *_ipv6_addr = NULL;
 	struct pwrctrl_priv *pwrctl = NULL;
 	struct mlme_ext_priv *pmlmeext = NULL;
 	struct mlme_ext_info *pmlmeinfo = NULL;
@@ -3113,14 +3302,121 @@ void netdev_br_init(struct net_device *netdev)
 }
 #endif /* CONFIG_BR_EXT */
 
+#ifdef CONFIG_NEW_NETDEV_HDL
+int _netdev_open(struct net_device *pnetdev)
+{
+	uint status;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+
+	RTW_INFO(FUNC_NDEV_FMT" start\n", FUNC_NDEV_ARG(pnetdev));
+
+	#ifdef CONFIG_AUTOSUSPEND
+	if (pwrctrlpriv->ps_flag == _TRUE) {
+		padapter->net_closed = _FALSE;
+		goto netdev_open_normal_process;
+	}
+	#endif /*CONFIG_AUTOSUSPEND*/
+
+	if (!rtw_is_hw_init_completed(padapter)) { // ips 
+		rtw_clr_surprise_removed(padapter);
+		rtw_clr_drv_stopped(padapter);
+		RTW_ENABLE_FUNC(padapter, DF_RX_BIT);
+		RTW_ENABLE_FUNC(padapter, DF_TX_BIT);
+		status = rtw_hal_init(padapter);
+		if (status == _FAIL)
+			goto netdev_open_error;
+		rtw_led_control(padapter, LED_CTL_NO_LINK);
+		#ifndef RTW_HALMAC
+		status = rtw_mi_start_drv_threads(padapter);
+		if (status == _FAIL) {
+			RTW_ERR(FUNC_NDEV_FMT "Initialize driver thread failed!\n", FUNC_NDEV_ARG(pnetdev));
+			goto netdev_open_error;
+		}
+
+		rtw_intf_start(GET_PRIMARY_ADAPTER(padapter));
+		#endif /* !RTW_HALMAC */
+
+		{
+	#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
+			_adapter *prim_adpt = GET_PRIMARY_ADAPTER(padapter);
+		
+			if (prim_adpt && (_TRUE == prim_adpt->EEPROMBluetoothCoexist)) {
+				rtw_btcoex_init_socket(prim_adpt);
+				prim_adpt->coex_info.BtMgnt.ExtConfig.HCIExtensionVer = 0x04;
+				rtw_btcoex_SetHciVersion(prim_adpt, 0x04);
+			}
+	#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
+
+			_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
+
+	#ifndef CONFIG_IPS_CHECK_IN_WD
+			rtw_set_pwr_state_check_timer(pwrctrlpriv);
+	#endif /*CONFIG_IPS_CHECK_IN_WD*/
+		}
+
+	}
+
+	/*if (padapter->bup == _FALSE) */
+	{
+		rtw_hal_iface_init(padapter);
+
+		#ifdef CONFIG_RTW_NAPI
+		if(padapter->napi_state == NAPI_DISABLE) {
+			napi_enable(&padapter->napi);
+			padapter->napi_state = NAPI_ENABLE;
+		}
+		#endif
+
+		#ifdef CONFIG_IOCTL_CFG80211
+		rtw_cfg80211_init_wiphy(padapter);
+		rtw_cfg80211_init_wdev_data(padapter);
+		#endif
+		/* rtw_netif_carrier_on(pnetdev); */ /* call this func when rtw_joinbss_event_callback return success */
+		rtw_netif_wake_queue(pnetdev);
+
+		#ifdef CONFIG_BR_EXT
+		if (is_primary_adapter(padapter))
+			netdev_br_init(pnetdev);
+		#endif /* CONFIG_BR_EXT */
+
+
+		padapter->bup = _TRUE;
+		padapter->net_closed = _FALSE;
+		padapter->netif_up = _TRUE;
+		pwrctrlpriv->bips_processing = _FALSE;
+	}
+
+
+netdev_open_normal_process:
+	RTW_INFO(FUNC_NDEV_FMT" Success (bup=%d)\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+	return 0;
+
+netdev_open_error:
+	padapter->bup = _FALSE;
+
+	#ifdef CONFIG_RTW_NAPI
+	if(padapter->napi_state == NAPI_ENABLE) {
+		napi_disable(&padapter->napi);
+		padapter->napi_state = NAPI_DISABLE;
+	}
+	#endif
+
+	rtw_netif_carrier_off(pnetdev);
+	rtw_netif_stop_queue(pnetdev);
+
+	RTW_ERR(FUNC_NDEV_FMT" Failed!! (bup=%d)\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+
+	return -1;
+
+}
+
+#else
 int _netdev_open(struct net_device *pnetdev)
 {
 	uint status;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
 	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
-#if defined(CONFIG_PLATFORM_INTEL_BYT) && defined(CONFIG_SDIO_HCI)
-	struct sdio_func *func = padapter->dvobj->intf_data.func;
-#endif /* CONFIG_PLATFORM_INTEL_BYT */
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
 #endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
@@ -3130,6 +3426,10 @@ int _netdev_open(struct net_device *pnetdev)
 
 	padapter->netif_up = _TRUE;
 
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+	rtw_sdio_set_power(1);
+#endif /* CONFIG_PLATFORM_INTEL_BYT */
+
 	#ifdef CONFIG_AUTOSUSPEND
 	if (pwrctrlpriv->ps_flag == _TRUE) {
 		padapter->net_closed = _FALSE;
@@ -3145,9 +3445,6 @@ int _netdev_open(struct net_device *pnetdev)
 #endif
 		rtw_init_wifidirect_addrs(padapter, adapter_mac_addr(padapter), adapter_mac_addr(padapter));
 		_rtw_memcpy(pnetdev->dev_addr, adapter_mac_addr(padapter), ETH_ALEN);
-#if defined(CONFIG_SDIO_HCI)
-		rtw_sdio_set_power(func,1);
-#endif
 #endif /* CONFIG_PLATFORM_INTEL_BYT */
 
 		rtw_clr_surprise_removed(padapter);
@@ -3236,6 +3533,15 @@ netdev_open_normal_process:
 	}
 #endif
 
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	pwrctrlpriv->radio_on_start_time = rtw_get_current_time();
+	pwrctrlpriv->pwr_saving_start_time = rtw_get_current_time();
+	pwrctrlpriv->pwr_saving_time = 0;
+	pwrctrlpriv->on_time = 0;
+	pwrctrlpriv->tx_time = 0;
+	pwrctrlpriv->rx_time = 0;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
 	RTW_INFO("-871x_drv - drv_open, bup=%d\n", padapter->bup);
 
 	return 0;
@@ -3259,7 +3565,7 @@ netdev_open_error:
 	return -1;
 
 }
-
+#endif
 int netdev_open(struct net_device *pnetdev)
 {
 	int ret = _FALSE;
@@ -3272,11 +3578,15 @@ int netdev_open(struct net_device *pnetdev)
 	}
 
 	_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+#ifdef CONFIG_NEW_NETDEV_HDL
+	ret = _netdev_open(pnetdev);
+#else
 	if (is_primary_adapter(padapter))
 		ret = _netdev_open(pnetdev);
 #ifdef CONFIG_CONCURRENT_MODE
 	else
 		ret = _netdev_vir_if_open(pnetdev);
+#endif
 #endif
 	_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
 
@@ -3302,13 +3612,22 @@ int  ips_netdrv_open(_adapter *padapter)
 
 	rtw_clr_drv_stopped(padapter);
 	/* padapter->bup = _TRUE; */
-
+#ifdef CONFIG_NEW_NETDEV_HDL
+	if (!rtw_is_hw_init_completed(padapter)) {
+		status = rtw_hal_init(padapter);
+		if (status == _FAIL) {
+			goto netdev_open_error;
+		}
+		rtw_mi_hal_iface_init(padapter);
+	}
+#else
 	status = rtw_hal_init(padapter);
 	if (status == _FAIL) {
 		goto netdev_open_error;
 	}
+#endif
 #if 0
-	rtw_restore_mac_addr(padapter);
+	rtw_mi_set_mac_addr(padapter);
 #endif
 #ifndef RTW_HALMAC
 	rtw_intf_start(padapter);
@@ -3331,10 +3650,12 @@ netdev_open_error:
 int rtw_ips_pwr_up(_adapter *padapter)
 {
 	int result;
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+#if defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
 #ifdef DBG_CONFIG_ERROR_DETECT
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
 #endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+#endif /* defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS) */
 	systime start_time = rtw_get_current_time();
 	RTW_INFO("===>  rtw_ips_pwr_up..............\n");
 
@@ -3367,12 +3688,12 @@ void rtw_ips_pwr_down(_adapter *padapter)
 #endif
 void rtw_ips_dev_unload(_adapter *padapter)
 {
-	struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
-	struct xmit_priv	*pxmitpriv = &(padapter->xmitpriv);
-	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
+#if defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS)
 #ifdef DBG_CONFIG_ERROR_DETECT
+	PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
 	struct sreset_priv *psrtpriv = &pHalData->srestpriv;
 #endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
+#endif /* defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_FWLPS_IN_IPS) */
 	RTW_INFO("====> %s...\n", __FUNCTION__);
 
 
@@ -3390,7 +3711,97 @@ void rtw_ips_dev_unload(_adapter *padapter)
 		rtw_hal_deinit(padapter);
 
 }
+#ifdef CONFIG_NEW_NETDEV_HDL
+int _pm_netdev_open(_adapter *padapter)
+{
+	uint status;
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
+	struct net_device *pnetdev = padapter->pnetdev;
+
+	RTW_INFO(FUNC_NDEV_FMT" start\n", FUNC_NDEV_ARG(pnetdev));
+
+	#ifdef CONFIG_AUTOSUSPEND
+	if (pwrctrlpriv->ps_flag == _TRUE) {
+		padapter->net_closed = _FALSE;
+		goto netdev_open_normal_process;
+	}
+	#endif /*CONFIG_AUTOSUSPEND*/
 
+	if (!rtw_is_hw_init_completed(padapter)) { // ips 
+		rtw_clr_surprise_removed(padapter);
+		rtw_clr_drv_stopped(padapter);
+		status = rtw_hal_init(padapter);
+		if (status == _FAIL)
+			goto netdev_open_error;
+		rtw_led_control(padapter, LED_CTL_NO_LINK);
+		#ifndef RTW_HALMAC
+		status = rtw_mi_start_drv_threads(padapter);
+		if (status == _FAIL) {
+			RTW_ERR(FUNC_NDEV_FMT "Initialize driver thread failed!\n", FUNC_NDEV_ARG(pnetdev));
+			goto netdev_open_error;
+		}
+
+		rtw_intf_start(GET_PRIMARY_ADAPTER(padapter));
+		#endif /* !RTW_HALMAC */
+
+		{
+			_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
+
+	#ifndef CONFIG_IPS_CHECK_IN_WD
+			rtw_set_pwr_state_check_timer(pwrctrlpriv);
+	#endif /*CONFIG_IPS_CHECK_IN_WD*/
+		}
+
+	}
+
+	/*if (padapter->bup == _FALSE) */
+	{
+		rtw_hal_iface_init(padapter);
+
+		padapter->bup = _TRUE;
+		padapter->net_closed = _FALSE;
+		padapter->netif_up = _TRUE;
+		pwrctrlpriv->bips_processing = _FALSE;
+	}
+
+
+netdev_open_normal_process:
+	RTW_INFO(FUNC_NDEV_FMT" Success (bup=%d)\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+	return 0;
+
+netdev_open_error:
+	padapter->bup = _FALSE;
+
+	rtw_netif_carrier_off(pnetdev);
+	rtw_netif_stop_queue(pnetdev);
+
+	RTW_ERR(FUNC_NDEV_FMT" Failed!! (bup=%d)\n", FUNC_NDEV_ARG(pnetdev), padapter->bup);
+
+	return -1;
+
+}
+int _mi_pm_netdev_open(struct net_device *pnetdev)
+{
+	int i;
+	int status = 0;
+	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
+	_adapter *iface;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface->netif_up) {
+			status = _pm_netdev_open(iface);
+			if (status == -1) {
+				RTW_ERR("%s failled\n", __func__);
+				break;
+			}
+		}
+	}
+
+	return status;
+}
+#endif /*CONFIG_NEW_NETDEV_HDL*/
 int pm_netdev_open(struct net_device *pnetdev, u8 bnormal)
 {
 	int status = 0;
@@ -3399,10 +3810,11 @@ int pm_netdev_open(struct net_device *pnetdev, u8 bnormal)
 
 	if (_TRUE == bnormal) {
 		_enter_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
+		#ifdef CONFIG_NEW_NETDEV_HDL
+		status = _mi_pm_netdev_open(pnetdev);
+		#else
 		status = _netdev_open(pnetdev);
-#if 0
-		rtw_restore_mac_addr(padapter);
-#endif
+		#endif
 		_exit_critical_mutex(&(adapter_to_dvobj(padapter)->hw_init_mutex), NULL);
 	}
 #ifdef CONFIG_IPS
@@ -3412,15 +3824,14 @@ int pm_netdev_open(struct net_device *pnetdev, u8 bnormal)
 
 	return status;
 }
-
+#ifdef CONFIG_CLIENT_PORT_CFG
+extern void rtw_hw_client_port_release(_adapter *adapter);
+#endif
 static int netdev_close(struct net_device *pnetdev)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
-#if defined(CONFIG_PLATFORM_INTEL_BYT) && defined(CONFIG_SDIO_HCI)
-	struct sdio_func *func = padapter->dvobj->intf_data.func;
-#endif /* CONFIG_PLATFORM_INTEL_BYT */
 #ifdef CONFIG_BT_COEXIST_SOCKET_TRX
 	HAL_DATA_TYPE		*pHalData = GET_HAL_DATA(padapter);
 #endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
@@ -3438,6 +3849,10 @@ static int netdev_close(struct net_device *pnetdev)
 	padapter->netif_up = _FALSE;
 	pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
 
+#ifdef CONFIG_CLIENT_PORT_CFG
+	if (MLME_IS_STA(padapter))
+		rtw_hw_client_port_release(padapter);
+#endif
 	/*	if (!rtw_is_hw_init_completed(padapter)) {
 			RTW_INFO("(1)871x_drv - drv_close, bup=%d, hw_init_completed=%s\n", padapter->bup, rtw_is_hw_init_completed(padapter)?"_TRUE":"_FALSE");
 
@@ -3456,16 +3871,14 @@ static int netdev_close(struct net_device *pnetdev)
 #ifndef CONFIG_ANDROID
 		/* s2. */
 		LeaveAllPowerSaveMode(padapter);
-		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_DIRECTLY);
+		rtw_disassoc_cmd(padapter, 500, RTW_CMDF_WAIT_ACK);
 		/* s2-2.  indicate disconnect to os */
 		rtw_indicate_disconnect(padapter, 0, _FALSE);
 		/* s2-3. */
-		rtw_free_assoc_resources(padapter, 1);
+		rtw_free_assoc_resources_cmd(padapter, _TRUE, RTW_CMDF_WAIT_ACK);
 		/* s2-4. */
 		rtw_free_network_queue(padapter, _TRUE);
 #endif
-		/* Close LED */
-		rtw_led_control(padapter, LED_CTL_POWER_OFF);
 	}
 
 #ifdef CONFIG_BR_EXT
@@ -3481,8 +3894,8 @@ static int netdev_close(struct net_device *pnetdev)
 		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
 #endif /* CONFIG_P2P */
 
+	rtw_scan_abort(padapter); /* stop scanning process before wifi is going to down */
 #ifdef CONFIG_IOCTL_CFG80211
-	rtw_scan_abort(padapter);
 	rtw_cfg80211_wait_scan_req_empty(padapter, 200);
 	adapter_wdev_data(padapter)->bandroid_scan = _FALSE;
 	/* padapter->rtw_wdev->iftype = NL80211_IFTYPE_MONITOR; */ /* set this at the end */
@@ -3514,9 +3927,8 @@ static int netdev_close(struct net_device *pnetdev)
 		rtw_msleep_os(1);
 
 	rtw_dev_unload(padapter);
-#if defined(CONFIG_SDIO_HCI)
-	rtw_sdio_set_power(func,0);
-#endif
+	rtw_sdio_set_power(0);
+
 #endif /* !CONFIG_PLATFORM_INTEL_BYT */
 
 	RTW_INFO("-871x_drv - drv_close, bup=%d\n", padapter->bup);
@@ -3668,7 +4080,11 @@ restart:
 
 		oldfs = get_fs();
 		set_fs(KERNEL_DS);
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+		err = sock_recvmsg(sock, &msg, MSG_DONTWAIT);
+#else
 		err = sock_recvmsg(sock, &msg, PAGE_SIZE, MSG_DONTWAIT);
+#endif
 		set_fs(oldfs);
 
 		if (err < 0)
@@ -3826,7 +4242,7 @@ int	rtw_gw_addr_query(_adapter *padapter)
 		pmlmepriv->gw_ip[1] = (gw_addr & 0xff00) >> 8;
 		pmlmepriv->gw_ip[2] = (gw_addr & 0xff0000) >> 16;
 		pmlmepriv->gw_ip[3] = (gw_addr & 0xff000000) >> 24;
-		_rtw_memcpy(pmlmepriv->gw_mac_addr, gw_mac, 6);
+		_rtw_memcpy(pmlmepriv->gw_mac_addr, gw_mac, ETH_ALEN);
 		RTW_INFO("%s Gateway Mac:\t" MAC_FMT "\n", __FUNCTION__, MAC_ARG(pmlmepriv->gw_mac_addr));
 		RTW_INFO("%s Gateway IP:\t" IP_FMT "\n", __FUNCTION__, IP_ARG(pmlmepriv->gw_ip));
 	} else
@@ -3838,13 +4254,10 @@ int	rtw_gw_addr_query(_adapter *padapter)
 
 void rtw_dev_unload(PADAPTER padapter)
 {
-	struct net_device *pnetdev = (struct net_device *)padapter->pnetdev;
 	struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
 	struct dvobj_priv *pobjpriv = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &pobjpriv->drv_dbg;
 	struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-	u8 cnt = 0;
-
 
 	if (padapter->bup == _TRUE) {
 		RTW_INFO("==> "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
@@ -3912,7 +4325,6 @@ void rtw_dev_unload(PADAPTER padapter)
 int rtw_suspend_free_assoc_resource(_adapter *padapter)
 {
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct net_device *pnetdev = padapter->pnetdev;
 #ifdef CONFIG_P2P
 	struct wifidirect_info	*pwdinfo = &padapter->wdinfo;
 #endif /* CONFIG_P2P */
@@ -3950,7 +4362,7 @@ int rtw_suspend_free_assoc_resource(_adapter *padapter)
 #endif
 
 	/* s2-3. */
-	rtw_free_assoc_resources(padapter, 1);
+	rtw_free_assoc_resources(padapter, _TRUE);
 
 	/* s2-4. */
 #ifdef CONFIG_AUTOSUSPEND
@@ -4207,8 +4619,6 @@ int rtw_suspend_ap_wow(_adapter *padapter)
 
 int rtw_suspend_normal(_adapter *padapter)
 {
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
 	int ret = _SUCCESS;
 
 	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
@@ -4251,7 +4661,9 @@ int rtw_suspend_common(_adapter *padapter)
 	struct dvobj_priv *dvobj = padapter->dvobj;
 	struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
 	struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
+#ifdef CONFIG_WOWLAN
 	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
+#endif
 
 	int ret = 0;
 	systime start_time = rtw_get_current_time();
@@ -4292,7 +4704,7 @@ int rtw_suspend_common(_adapter *padapter)
 
 	if (rtw_mi_check_status(padapter, MI_AP_MODE) == _FALSE) {
 #ifdef CONFIG_WOWLAN
-		if (check_fwstate(pmlmepriv, _FW_LINKED))
+		if (check_fwstate(pmlmepriv, _FW_LINKED) || WOWLAN_IS_STA_MIX_MODE(padapter))
 			pwrpriv->wowlan_mode = _TRUE;
 		else if (pwrpriv->wowlan_pno_enable == _TRUE)
 			pwrpriv->wowlan_mode |= pwrpriv->wowlan_pno_enable;
@@ -4339,6 +4751,7 @@ int rtw_resume_process_wow(_adapter *padapter)
 	struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
 	struct wowlan_ioctl_param poidparam;
 	struct sta_info	*psta = NULL;
+	struct registry_priv  *registry_par = &padapter->registrypriv;
 	int ret = _SUCCESS;
 
 	RTW_INFO("==> "FUNC_ADPT_FMT" entry....\n", FUNC_ADPT_ARG(padapter));
@@ -4410,6 +4823,14 @@ int rtw_resume_process_wow(_adapter *padapter)
 		rtw_mi_start_drv_threads(padapter);
 
 		rtw_mi_intf_start(padapter);
+		
+		if(registry_par->suspend_type == FW_IPS_DISABLE_BBRF && !check_fwstate(pmlmepriv, _FW_LINKED)) {
+			if (!rtw_is_surprise_removed(padapter)) {
+				rtw_hal_deinit(padapter);
+				rtw_hal_init(padapter);
+			}
+			RTW_INFO("FW_IPS_DISABLE_BBRF hal deinit, hal init \n");
+		}
 
 #ifdef CONFIG_CONCURRENT_MODE
 		rtw_mi_buddy_netif_carrier_on(padapter);
@@ -4440,7 +4861,7 @@ int rtw_resume_process_wow(_adapter *padapter)
 					 rtw_get_stainfo(&padapter->stapriv,
 					 get_bssid(&padapter->mlmepriv)), 0);
 
-			rtw_free_assoc_resources(padapter, 1);
+			rtw_free_assoc_resources(padapter, _TRUE);
 			pmlmeinfo->state = WIFI_FW_NULL_STATE;
 
 		} else {
@@ -4449,14 +4870,6 @@ int rtw_resume_process_wow(_adapter *padapter)
 		}
 	}
 
-	if (pwrpriv->wowlan_wake_reason == FW_DECISION_DISCONNECT)
-		rtw_lock_ext_suspend_timeout(2000);
-
-	if (pwrpriv->wowlan_wake_reason == RX_GTK ||
-	    pwrpriv->wowlan_wake_reason == RX_DISASSOC||
-	    pwrpriv->wowlan_wake_reason == RX_DEAUTH)
-		rtw_lock_ext_suspend_timeout(8000);
-
 	if (pwrpriv->wowlan_mode == _TRUE) {
 		pwrpriv->bips_processing = _FALSE;
 		_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
@@ -4591,9 +5004,6 @@ int rtw_resume_process_ap_wow(_adapter *padapter)
 	/* rtw_unlock_suspend(); */
 #endif /* CONFIG_RESUME_IN_WORKQUEUE */
 
-	if (pwrpriv->wowlan_wake_reason == AP_OFFLOAD_WAKEUP)
-		rtw_lock_ext_suspend_timeout(8000);
-
 	pwrpriv->bips_processing = _FALSE;
 	_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
 #ifndef CONFIG_IPS_CHECK_IN_WD
@@ -4725,8 +5135,6 @@ int rtw_resume_common(_adapter *padapter)
 	int ret = 0;
 	systime start_time = rtw_get_current_time();
 	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
 
 	if (pwrpriv->bInSuspend == _FALSE)
 		return 0;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/recv_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/recv_linux.c
index 9f4dbead9a39..795035356ac3 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/recv_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/recv_linux.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -20,7 +21,6 @@ int rtw_os_recvframe_duplicate_skb(_adapter *padapter, union recv_frame *pclonef
 {
 	int res = _SUCCESS;
 	_pkt	*pkt_copy = NULL;
-	struct rx_pkt_attrib *pattrib = &pcloneframe->u.hdr.attrib;
 
 	if (pskb == NULL) {
 		RTW_INFO("%s [WARN] skb == NULL, drop frag frame\n", __func__);
@@ -215,8 +215,10 @@ int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf)
 	int res = _SUCCESS;
 
 #ifdef CONFIG_USB_HCI
+#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
 	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
 	struct usb_device	*pusbd = pdvobjpriv->pusbdev;
+#endif
 
 	precvbuf->irp_pending = _FALSE;
 	precvbuf->purb = usb_alloc_urb(0, GFP_KERNEL);
@@ -281,7 +283,7 @@ int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf)
 
 }
 
-_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8 *pdata)
+_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, const u8 *da, const u8 *sa, u8 *msdu ,u16 msdu_len)
 {
 	u16	eth_type;
 	u8	*data_ptr;
@@ -291,19 +293,19 @@ _pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8
 	pattrib = &prframe->u.hdr.attrib;
 
 #ifdef CONFIG_SKB_COPY
-	sub_skb = rtw_skb_alloc(nSubframe_Length + 14);
+	sub_skb = rtw_skb_alloc(msdu_len + 14);
 	if (sub_skb) {
 		skb_reserve(sub_skb, 14);
-		data_ptr = (u8 *)skb_put(sub_skb, nSubframe_Length);
-		_rtw_memcpy(data_ptr, (pdata + ETH_HLEN), nSubframe_Length);
+		data_ptr = (u8 *)skb_put(sub_skb, msdu_len);
+		_rtw_memcpy(data_ptr, msdu, msdu_len);
 	} else
 #endif /* CONFIG_SKB_COPY */
 	{
 		sub_skb = rtw_skb_clone(prframe->u.hdr.pkt);
 		if (sub_skb) {
-			sub_skb->data = pdata + ETH_HLEN;
-			sub_skb->len = nSubframe_Length;
-			skb_set_tail_pointer(sub_skb, nSubframe_Length);
+			sub_skb->data = msdu;
+			sub_skb->len = msdu_len;
+			skb_set_tail_pointer(sub_skb, msdu_len);
 		} else {
 			RTW_INFO("%s(): rtw_skb_clone() Fail!!!\n", __FUNCTION__);
 			return NULL;
@@ -312,21 +314,23 @@ _pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8
 
 	eth_type = RTW_GET_BE16(&sub_skb->data[6]);
 
-	if (sub_skb->len >= 8 &&
-	    ((_rtw_memcmp(sub_skb->data, rtw_rfc1042_header, SNAP_SIZE) &&
-	      eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) ||
-	     _rtw_memcmp(sub_skb->data, rtw_bridge_tunnel_header, SNAP_SIZE))) {
+	if (sub_skb->len >= 8
+		&& ((_rtw_memcmp(sub_skb->data, rtw_rfc1042_header, SNAP_SIZE)
+				&& eth_type != ETH_P_AARP && eth_type != ETH_P_IPX)
+			|| _rtw_memcmp(sub_skb->data, rtw_bridge_tunnel_header, SNAP_SIZE))
+	) {
 		/* remove RFC1042 or Bridge-Tunnel encapsulation and replace EtherType */
 		skb_pull(sub_skb, SNAP_SIZE);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pdata + 6, ETH_ALEN);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pdata, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), sa, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), da, ETH_ALEN);
 	} else {
-		u16 len;
 		/* Leave Ethernet header part of hdr and full payload */
+		u16 len;
+
 		len = htons(sub_skb->len);
 		_rtw_memcpy(skb_push(sub_skb, 2), &len, 2);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pdata + 6, ETH_ALEN);
-		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), pdata, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), sa, ETH_ALEN);
+		_rtw_memcpy(skb_push(sub_skb, ETH_ALEN), da, ETH_ALEN);
 	}
 
 	return sub_skb;
@@ -382,13 +386,36 @@ int rtw_recv_napi_poll(struct napi_struct *napi, int budget)
 
 	work_done = napi_recv(padapter, budget);
 	if (work_done < budget) {
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0)) && defined(CONFIG_PCI_HCI)
+		napi_complete_done(napi, work_done);
+#else
 		napi_complete(napi);
+#endif
 		if (!skb_queue_empty(&precvpriv->rx_napi_skb_queue))
 			napi_schedule(napi);
 	}
 
 	return work_done;
 }
+
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+void dynamic_napi_th_chk (_adapter *adapter)
+{
+
+	if (adapter->registrypriv.en_napi) {
+		struct dvobj_priv *dvobj;
+		struct registry_priv *registry;
+	
+		dvobj = adapter_to_dvobj(adapter);
+		registry = &adapter->registrypriv;
+		if (dvobj->traffic_stat.cur_rx_tp > registry->napi_threshold)
+			dvobj->en_napi_dynamic = 1;
+		else
+			dvobj->en_napi_dynamic = 0;
+	}
+
+}
+#endif /* CONFIG_RTW_NAPI_DYNAMIC */
 #endif /* CONFIG_RTW_NAPI */
 
 void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, union recv_frame *rframe)
@@ -485,8 +512,20 @@ void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, union recv_frame *r
 		pkt->protocol = eth_type_trans(pkt, padapter->pnetdev);
 		pkt->dev = padapter->pnetdev;
 		pkt->ip_summed = CHECKSUM_NONE; /* CONFIG_TCP_CSUM_OFFLOAD_RX */
+#ifdef CONFIG_TCP_CSUM_OFFLOAD_RX
+		if ((rframe->u.hdr.attrib.csum_valid == 1)
+		    && (rframe->u.hdr.attrib.csum_err == 0))
+			pkt->ip_summed = CHECKSUM_UNNECESSARY;
+#endif /* CONFIG_TCP_CSUM_OFFLOAD_RX */
 
 #ifdef CONFIG_RTW_NAPI
+#ifdef CONFIG_RTW_NAPI_DYNAMIC
+		if (!skb_queue_empty(&precvpriv->rx_napi_skb_queue)
+			&& !adapter_to_dvobj(padapter)->en_napi_dynamic			
+			)
+			napi_recv(padapter, RTL_NAPI_WEIGHT);
+#endif
+
 		if (pregistrypriv->en_napi
 			#ifdef CONFIG_RTW_NAPI_DYNAMIC
 			&& adapter_to_dvobj(padapter)->en_napi_dynamic
@@ -515,7 +554,6 @@ void rtw_handle_tkip_mic_err(_adapter *padapter, struct sta_info *sta, u8 bgroup
 #endif
 	union iwreq_data wrqu;
 	struct iw_michaelmicfailure    ev;
-	struct mlme_priv              *pmlmepriv  = &padapter->mlmepriv;
 	struct security_priv	*psecuritypriv = &padapter->securitypriv;
 	systime cur_time = 0;
 
@@ -604,7 +642,6 @@ int rtw_recv_monitor(_adapter *padapter, union recv_frame *precv_frame)
 	struct recv_priv *precvpriv;
 	_queue	*pfree_recv_queue;
 	_pkt *skb;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 	struct rx_pkt_attrib *pattrib;
 
 	if (NULL == precv_frame)
@@ -644,25 +681,27 @@ _recv_drop:
 
 }
 
+inline void rtw_rframe_set_os_pkt(union recv_frame *rframe)
+{
+	_pkt *skb = rframe->u.hdr.pkt;
+
+	skb->data = rframe->u.hdr.rx_data;
+	skb_set_tail_pointer(skb, rframe->u.hdr.len);
+	skb->len = rframe->u.hdr.len;
+}
+
 int rtw_recv_indicatepkt(_adapter *padapter, union recv_frame *precv_frame)
 {
 	struct recv_priv *precvpriv;
 	_queue	*pfree_recv_queue;
-	_pkt *skb;
-	struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
 
 	precvpriv = &(padapter->recvpriv);
 	pfree_recv_queue = &(precvpriv->free_recv_queue);
 
-	skb = precv_frame->u.hdr.pkt;
-	if (skb == NULL)
+	if (precv_frame->u.hdr.pkt == NULL)
 		goto _recv_indicatepkt_drop;
 
-	skb->data = precv_frame->u.hdr.rx_data;
-	skb_set_tail_pointer(skb, precv_frame->u.hdr.len);
-	skb->len = precv_frame->u.hdr.len;
-
-	rtw_os_recv_indicate_pkt(padapter, skb, precv_frame);
+	rtw_os_recv_indicate_pkt(padapter, precv_frame->u.hdr.pkt, precv_frame);
 
 _recv_indicatepkt_end:
 	precv_frame->u.hdr.pkt = NULL;
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rhashtable.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rhashtable.c
new file mode 100644
index 000000000000..e910d6fbcfe6
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rhashtable.c
@@ -0,0 +1,845 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Resizable, Scalable, Concurrent Hash Table
+ *
+ * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au>
+ * Copyright (c) 2014-2015 Thomas Graf <tgraf@suug.ch>
+ * Copyright (c) 2008-2014 Patrick McHardy <kaber@trash.net>
+ *
+ * Code partially derived from nft_hash
+ * Rewritten with rehash code from br_multicast plus single list
+ * pointer as suggested by Josh Triplett
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#include <linux/atomic.h>
+#include <linux/kernel.h>
+#include <linux/init.h>
+#include <linux/log2.h>
+#include <linux/sched.h>
+#include <linux/slab.h>
+#include <linux/vmalloc.h>
+#include <linux/mm.h>
+#include <linux/jhash.h>
+#include <linux/random.h>
+#include <linux/err.h>
+#include <linux/export.h>
+
+#define HASH_DEFAULT_SIZE	64UL
+#define HASH_MIN_SIZE		4U
+#define BUCKET_LOCKS_PER_CPU   128UL
+
+static u32 head_hashfn(struct rhashtable *ht,
+		       const struct bucket_table *tbl,
+		       const struct rhash_head *he)
+{
+	return rht_head_hashfn(ht, tbl, he, ht->p);
+}
+
+#ifdef CONFIG_PROVE_LOCKING
+#define ASSERT_RHT_MUTEX(HT) BUG_ON(!lockdep_rht_mutex_is_held(HT))
+
+int lockdep_rht_mutex_is_held(struct rhashtable *ht)
+{
+	return (debug_locks) ? lockdep_is_held(&ht->mutex) : 1;
+}
+
+int lockdep_rht_bucket_is_held(const struct bucket_table *tbl, u32 hash)
+{
+	spinlock_t *lock = rht_bucket_lock(tbl, hash);
+
+	return (debug_locks) ? lockdep_is_held(lock) : 1;
+}
+#else
+#define ASSERT_RHT_MUTEX(HT)
+#endif
+
+
+static int alloc_bucket_locks(struct rhashtable *ht, struct bucket_table *tbl,
+			      gfp_t gfp)
+{
+	unsigned int i, size;
+#if defined(CONFIG_PROVE_LOCKING)
+	unsigned int nr_pcpus = 2;
+#else
+	unsigned int nr_pcpus = num_possible_cpus();
+#endif
+
+	nr_pcpus = min_t(unsigned int, nr_pcpus, 32UL);
+	size = roundup_pow_of_two(nr_pcpus * ht->p.locks_mul);
+
+	/* Never allocate more than 0.5 locks per bucket */
+	size = min_t(unsigned int, size, tbl->size >> 1);
+
+	if (sizeof(spinlock_t) != 0) {
+#ifdef CONFIG_NUMA
+		if (size * sizeof(spinlock_t) > PAGE_SIZE &&
+		    gfp == GFP_KERNEL)
+			tbl->locks = vmalloc(size * sizeof(spinlock_t));
+		else
+#endif
+		tbl->locks = kmalloc_array(size, sizeof(spinlock_t),
+					   gfp);
+		if (!tbl->locks)
+			return -ENOMEM;
+		for (i = 0; i < size; i++)
+			spin_lock_init(&tbl->locks[i]);
+	}
+	tbl->locks_mask = size - 1;
+
+	return 0;
+}
+
+static void bucket_table_free(const struct bucket_table *tbl)
+{
+	if (tbl)
+		kvfree(tbl->locks);
+
+	kvfree(tbl);
+}
+
+static void bucket_table_free_rcu(struct rcu_head *head)
+{
+	bucket_table_free(container_of(head, struct bucket_table, rcu));
+}
+
+static struct bucket_table *bucket_table_alloc(struct rhashtable *ht,
+					       size_t nbuckets,
+					       gfp_t gfp)
+{
+	struct bucket_table *tbl = NULL;
+	size_t size;
+	int i;
+
+	size = sizeof(*tbl) + nbuckets * sizeof(tbl->buckets[0]);
+	if (size <= (PAGE_SIZE << PAGE_ALLOC_COSTLY_ORDER) ||
+	    gfp != GFP_KERNEL)
+		tbl = kzalloc(size, gfp | __GFP_NOWARN | __GFP_NORETRY);
+	if (tbl == NULL && gfp == GFP_KERNEL)
+		tbl = vzalloc(size);
+	if (tbl == NULL)
+		return NULL;
+
+	tbl->size = nbuckets;
+
+	if (alloc_bucket_locks(ht, tbl, gfp) < 0) {
+		bucket_table_free(tbl);
+		return NULL;
+	}
+
+	INIT_LIST_HEAD(&tbl->walkers);
+
+	get_random_bytes(&tbl->hash_rnd, sizeof(tbl->hash_rnd));
+
+	for (i = 0; i < nbuckets; i++)
+		INIT_RHT_NULLS_HEAD(tbl->buckets[i], ht, i);
+
+	return tbl;
+}
+
+static struct bucket_table *rhashtable_last_table(struct rhashtable *ht,
+						  struct bucket_table *tbl)
+{
+	struct bucket_table *new_tbl;
+
+	do {
+		new_tbl = tbl;
+		tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	} while (tbl);
+
+	return new_tbl;
+}
+
+static int rhashtable_rehash_one(struct rhashtable *ht, unsigned int old_hash)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	struct bucket_table *new_tbl = rhashtable_last_table(ht,
+		rht_dereference_rcu(old_tbl->future_tbl, ht));
+	struct rhash_head __rcu **pprev = &old_tbl->buckets[old_hash];
+	int err = -ENOENT;
+	struct rhash_head *head, *next, *entry;
+	spinlock_t *new_bucket_lock;
+	unsigned int new_hash;
+
+	rht_for_each(entry, old_tbl, old_hash) {
+		err = 0;
+		next = rht_dereference_bucket(entry->next, old_tbl, old_hash);
+
+		if (rht_is_a_nulls(next))
+			break;
+
+		pprev = &entry->next;
+	}
+
+	if (err)
+		goto out;
+
+	new_hash = head_hashfn(ht, new_tbl, entry);
+
+	new_bucket_lock = rht_bucket_lock(new_tbl, new_hash);
+
+	spin_lock_nested(new_bucket_lock, SINGLE_DEPTH_NESTING);
+	head = rht_dereference_bucket(new_tbl->buckets[new_hash],
+				      new_tbl, new_hash);
+
+	RCU_INIT_POINTER(entry->next, head);
+
+	rcu_assign_pointer(new_tbl->buckets[new_hash], entry);
+	spin_unlock(new_bucket_lock);
+
+	rcu_assign_pointer(*pprev, next);
+
+out:
+	return err;
+}
+
+static void rhashtable_rehash_chain(struct rhashtable *ht,
+				    unsigned int old_hash)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	spinlock_t *old_bucket_lock;
+
+	old_bucket_lock = rht_bucket_lock(old_tbl, old_hash);
+
+	spin_lock_bh(old_bucket_lock);
+	while (!rhashtable_rehash_one(ht, old_hash))
+		;
+	old_tbl->rehash++;
+	spin_unlock_bh(old_bucket_lock);
+}
+
+static int rhashtable_rehash_attach(struct rhashtable *ht,
+				    struct bucket_table *old_tbl,
+				    struct bucket_table *new_tbl)
+{
+	/* Protect future_tbl using the first bucket lock. */
+	spin_lock_bh(old_tbl->locks);
+
+	/* Did somebody beat us to it? */
+	if (rcu_access_pointer(old_tbl->future_tbl)) {
+		spin_unlock_bh(old_tbl->locks);
+		return -EEXIST;
+	}
+
+	/* Make insertions go into the new, empty table right away. Deletions
+	 * and lookups will be attempted in both tables until we synchronize.
+	 */
+	rcu_assign_pointer(old_tbl->future_tbl, new_tbl);
+
+	/* Ensure the new table is visible to readers. */
+	smp_wmb();
+
+	spin_unlock_bh(old_tbl->locks);
+
+	return 0;
+}
+
+static int rhashtable_rehash_table(struct rhashtable *ht)
+{
+	struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
+	struct bucket_table *new_tbl;
+	struct rhashtable_walker *walker;
+	unsigned int old_hash;
+
+	new_tbl = rht_dereference(old_tbl->future_tbl, ht);
+	if (!new_tbl)
+		return 0;
+
+	for (old_hash = 0; old_hash < old_tbl->size; old_hash++)
+		rhashtable_rehash_chain(ht, old_hash);
+
+	/* Publish the new table pointer. */
+	rcu_assign_pointer(ht->tbl, new_tbl);
+
+	spin_lock(&ht->lock);
+	list_for_each_entry(walker, &old_tbl->walkers, list)
+		walker->tbl = NULL;
+	spin_unlock(&ht->lock);
+
+	/* Wait for readers. All new readers will see the new
+	 * table, and thus no references to the old table will
+	 * remain.
+	 */
+	call_rcu(&old_tbl->rcu, bucket_table_free_rcu);
+
+	return rht_dereference(new_tbl->future_tbl, ht) ? -EAGAIN : 0;
+}
+
+/**
+ * rhashtable_expand - Expand hash table while allowing concurrent lookups
+ * @ht:		the hash table to expand
+ *
+ * A secondary bucket array is allocated and the hash entries are migrated.
+ *
+ * This function may only be called in a context where it is safe to call
+ * synchronize_rcu(), e.g. not within a rcu_read_lock() section.
+ *
+ * The caller must ensure that no concurrent resizing occurs by holding
+ * ht->mutex.
+ *
+ * It is valid to have concurrent insertions and deletions protected by per
+ * bucket locks or concurrent RCU protected lookups and traversals.
+ */
+static int rhashtable_expand(struct rhashtable *ht)
+{
+	struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht);
+	int err;
+
+	ASSERT_RHT_MUTEX(ht);
+
+	old_tbl = rhashtable_last_table(ht, old_tbl);
+
+	new_tbl = bucket_table_alloc(ht, old_tbl->size * 2, GFP_KERNEL);
+	if (new_tbl == NULL)
+		return -ENOMEM;
+
+	err = rhashtable_rehash_attach(ht, old_tbl, new_tbl);
+	if (err)
+		bucket_table_free(new_tbl);
+
+	return err;
+}
+
+/**
+ * rhashtable_shrink - Shrink hash table while allowing concurrent lookups
+ * @ht:		the hash table to shrink
+ *
+ * This function shrinks the hash table to fit, i.e., the smallest
+ * size would not cause it to expand right away automatically.
+ *
+ * The caller must ensure that no concurrent resizing occurs by holding
+ * ht->mutex.
+ *
+ * The caller must ensure that no concurrent table mutations take place.
+ * It is however valid to have concurrent lookups if they are RCU protected.
+ *
+ * It is valid to have concurrent insertions and deletions protected by per
+ * bucket locks or concurrent RCU protected lookups and traversals.
+ */
+static int rhashtable_shrink(struct rhashtable *ht)
+{
+	struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht);
+	unsigned int size;
+	int err;
+
+	ASSERT_RHT_MUTEX(ht);
+
+	size = roundup_pow_of_two(atomic_read(&ht->nelems) * 3 / 2);
+	if (size < ht->p.min_size)
+		size = ht->p.min_size;
+
+	if (old_tbl->size <= size)
+		return 0;
+
+	if (rht_dereference(old_tbl->future_tbl, ht))
+		return -EEXIST;
+
+	new_tbl = bucket_table_alloc(ht, size, GFP_KERNEL);
+	if (new_tbl == NULL)
+		return -ENOMEM;
+
+	err = rhashtable_rehash_attach(ht, old_tbl, new_tbl);
+	if (err)
+		bucket_table_free(new_tbl);
+
+	return err;
+}
+
+static void rht_deferred_worker(struct work_struct *work)
+{
+	struct rhashtable *ht;
+	struct bucket_table *tbl;
+	int err = 0;
+
+	ht = container_of(work, struct rhashtable, run_work);
+	mutex_lock(&ht->mutex);
+
+	tbl = rht_dereference(ht->tbl, ht);
+	tbl = rhashtable_last_table(ht, tbl);
+
+	if (rht_grow_above_75(ht, tbl))
+		rhashtable_expand(ht);
+	else if (ht->p.automatic_shrinking && rht_shrink_below_30(ht, tbl))
+		rhashtable_shrink(ht);
+
+	err = rhashtable_rehash_table(ht);
+
+	mutex_unlock(&ht->mutex);
+
+	if (err)
+		schedule_work(&ht->run_work);
+}
+
+static bool rhashtable_check_elasticity(struct rhashtable *ht,
+					struct bucket_table *tbl,
+					unsigned int hash)
+{
+	unsigned int elasticity = ht->elasticity;
+	struct rhash_head *head;
+
+	rht_for_each(head, tbl, hash)
+		if (!--elasticity)
+			return true;
+
+	return false;
+}
+
+int rhashtable_insert_rehash(struct rhashtable *ht,
+			     struct bucket_table *tbl)
+{
+	struct bucket_table *old_tbl;
+	struct bucket_table *new_tbl;
+	unsigned int size;
+	int err;
+
+	old_tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	size = tbl->size;
+
+	err = -EBUSY;
+
+	if (rht_grow_above_75(ht, tbl))
+		size *= 2;
+	/* Do not schedule more than one rehash */
+	else if (old_tbl != tbl)
+		goto fail;
+
+	err = -ENOMEM;
+
+	new_tbl = bucket_table_alloc(ht, size, GFP_ATOMIC);
+	if (new_tbl == NULL)
+		goto fail;
+
+	err = rhashtable_rehash_attach(ht, tbl, new_tbl);
+	if (err) {
+		bucket_table_free(new_tbl);
+		if (err == -EEXIST)
+			err = 0;
+	} else
+		schedule_work(&ht->run_work);
+
+	return err;
+
+fail:
+	/* Do not fail the insert if someone else did a rehash. */
+	if (likely(rcu_dereference_raw(tbl->future_tbl)))
+		return 0;
+
+	/* Schedule async rehash to retry allocation in process context. */
+	if (err == -ENOMEM)
+		schedule_work(&ht->run_work);
+
+	return err;
+}
+
+struct bucket_table *rhashtable_insert_slow(struct rhashtable *ht,
+					    const void *key,
+					    struct rhash_head *obj,
+					    struct bucket_table *tbl)
+{
+	struct rhash_head *head;
+	unsigned int hash;
+	int err;
+
+	tbl = rhashtable_last_table(ht, tbl);
+	hash = head_hashfn(ht, tbl, obj);
+	spin_lock_nested(rht_bucket_lock(tbl, hash), SINGLE_DEPTH_NESTING);
+
+	err = -EEXIST;
+	if (key && rhashtable_lookup_fast(ht, key, ht->p))
+		goto exit;
+
+	err = -E2BIG;
+	if (unlikely(rht_grow_above_max(ht, tbl)))
+		goto exit;
+
+	err = -EAGAIN;
+	if (rhashtable_check_elasticity(ht, tbl, hash) ||
+	    rht_grow_above_100(ht, tbl))
+		goto exit;
+
+	err = 0;
+
+	head = rht_dereference_bucket(tbl->buckets[hash], tbl, hash);
+
+	RCU_INIT_POINTER(obj->next, head);
+
+	rcu_assign_pointer(tbl->buckets[hash], obj);
+
+	atomic_inc(&ht->nelems);
+
+exit:
+	spin_unlock(rht_bucket_lock(tbl, hash));
+
+	if (err == 0)
+		return NULL;
+	else if (err == -EAGAIN)
+		return tbl;
+	else
+		return ERR_PTR(err);
+}
+
+/**
+ * rhashtable_walk_init - Initialise an iterator
+ * @ht:		Table to walk over
+ * @iter:	Hash table Iterator
+ *
+ * This function prepares a hash table walk.
+ *
+ * Note that if you restart a walk after rhashtable_walk_stop you
+ * may see the same object twice.  Also, you may miss objects if
+ * there are removals in between rhashtable_walk_stop and the next
+ * call to rhashtable_walk_start.
+ *
+ * For a completely stable walk you should construct your own data
+ * structure outside the hash table.
+ *
+ * This function may sleep so you must not call it from interrupt
+ * context or with spin locks held.
+ *
+ * You must call rhashtable_walk_exit if this function returns
+ * successfully.
+ */
+int rhashtable_walk_init(struct rhashtable *ht, struct rhashtable_iter *iter)
+{
+	iter->ht = ht;
+	iter->p = NULL;
+	iter->slot = 0;
+	iter->skip = 0;
+
+	iter->walker = kmalloc(sizeof(*iter->walker), GFP_KERNEL);
+	if (!iter->walker)
+		return -ENOMEM;
+
+	spin_lock(&ht->lock);
+	iter->walker->tbl =
+		rcu_dereference_protected(ht->tbl, lockdep_is_held(&ht->lock));
+	list_add(&iter->walker->list, &iter->walker->tbl->walkers);
+	spin_unlock(&ht->lock);
+
+	return 0;
+}
+
+/**
+ * rhashtable_walk_exit - Free an iterator
+ * @iter:	Hash table Iterator
+ *
+ * This function frees resources allocated by rhashtable_walk_init.
+ */
+void rhashtable_walk_exit(struct rhashtable_iter *iter)
+{
+	spin_lock(&iter->ht->lock);
+	if (iter->walker->tbl)
+		list_del(&iter->walker->list);
+	spin_unlock(&iter->ht->lock);
+	kfree(iter->walker);
+}
+
+/**
+ * rhashtable_walk_start - Start a hash table walk
+ * @iter:	Hash table iterator
+ *
+ * Start a hash table walk.  Note that we take the RCU lock in all
+ * cases including when we return an error.  So you must always call
+ * rhashtable_walk_stop to clean up.
+ *
+ * Returns zero if successful.
+ *
+ * Returns -EAGAIN if resize event occured.  Note that the iterator
+ * will rewind back to the beginning and you may use it immediately
+ * by calling rhashtable_walk_next.
+ */
+int rhashtable_walk_start(struct rhashtable_iter *iter)
+	__acquires(RCU)
+{
+	struct rhashtable *ht = iter->ht;
+
+	rcu_read_lock();
+
+	spin_lock(&ht->lock);
+	if (iter->walker->tbl)
+		list_del(&iter->walker->list);
+	spin_unlock(&ht->lock);
+
+	if (!iter->walker->tbl) {
+		iter->walker->tbl = rht_dereference_rcu(ht->tbl, ht);
+		return -EAGAIN;
+	}
+
+	return 0;
+}
+
+/**
+ * rhashtable_walk_next - Return the next object and advance the iterator
+ * @iter:	Hash table iterator
+ *
+ * Note that you must call rhashtable_walk_stop when you are finished
+ * with the walk.
+ *
+ * Returns the next object or NULL when the end of the table is reached.
+ *
+ * Returns -EAGAIN if resize event occured.  Note that the iterator
+ * will rewind back to the beginning and you may continue to use it.
+ */
+void *rhashtable_walk_next(struct rhashtable_iter *iter)
+{
+	struct bucket_table *tbl = iter->walker->tbl;
+	struct rhashtable *ht = iter->ht;
+	struct rhash_head *p = iter->p;
+
+	if (p) {
+		p = rht_dereference_bucket_rcu(p->next, tbl, iter->slot);
+		goto next;
+	}
+
+	for (; iter->slot < tbl->size; iter->slot++) {
+		int skip = iter->skip;
+
+		rht_for_each_rcu(p, tbl, iter->slot) {
+			if (!skip)
+				break;
+			skip--;
+		}
+
+next:
+		if (!rht_is_a_nulls(p)) {
+			iter->skip++;
+			iter->p = p;
+			return rht_obj(ht, p);
+		}
+
+		iter->skip = 0;
+	}
+
+	iter->p = NULL;
+
+	/* Ensure we see any new tables. */
+	smp_rmb();
+
+	iter->walker->tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (iter->walker->tbl) {
+		iter->slot = 0;
+		iter->skip = 0;
+		return ERR_PTR(-EAGAIN);
+	}
+
+	return NULL;
+}
+
+/**
+ * rhashtable_walk_stop - Finish a hash table walk
+ * @iter:	Hash table iterator
+ *
+ * Finish a hash table walk.
+ */
+void rhashtable_walk_stop(struct rhashtable_iter *iter)
+	__releases(RCU)
+{
+	struct rhashtable *ht;
+	struct bucket_table *tbl = iter->walker->tbl;
+
+	if (!tbl)
+		goto out;
+
+	ht = iter->ht;
+
+	spin_lock(&ht->lock);
+	if (tbl->rehash < tbl->size)
+		list_add(&iter->walker->list, &tbl->walkers);
+	else
+		iter->walker->tbl = NULL;
+	spin_unlock(&ht->lock);
+
+	iter->p = NULL;
+
+out:
+	rcu_read_unlock();
+}
+
+static size_t rounded_hashtable_size(const struct rhashtable_params *params)
+{
+	return max(roundup_pow_of_two(params->nelem_hint * 4 / 3),
+		   (unsigned long)params->min_size);
+}
+
+static u32 rhashtable_jhash2(const void *key, u32 length, u32 seed)
+{
+	return jhash2(key, length, seed);
+}
+
+/**
+ * rhashtable_init - initialize a new hash table
+ * @ht:		hash table to be initialized
+ * @params:	configuration parameters
+ *
+ * Initializes a new hash table based on the provided configuration
+ * parameters. A table can be configured either with a variable or
+ * fixed length key:
+ *
+ * Configuration Example 1: Fixed length keys
+ * struct test_obj {
+ *	int			key;
+ *	void *			my_member;
+ *	struct rhash_head	node;
+ * };
+ *
+ * struct rhashtable_params params = {
+ *	.head_offset = offsetof(struct test_obj, node),
+ *	.key_offset = offsetof(struct test_obj, key),
+ *	.key_len = sizeof(int),
+ *	.hashfn = jhash,
+ *	.nulls_base = (1U << RHT_BASE_SHIFT),
+ * };
+ *
+ * Configuration Example 2: Variable length keys
+ * struct test_obj {
+ *	[...]
+ *	struct rhash_head	node;
+ * };
+ *
+ * u32 my_hash_fn(const void *data, u32 len, u32 seed)
+ * {
+ *	struct test_obj *obj = data;
+ *
+ *	return [... hash ...];
+ * }
+ *
+ * struct rhashtable_params params = {
+ *	.head_offset = offsetof(struct test_obj, node),
+ *	.hashfn = jhash,
+ *	.obj_hashfn = my_hash_fn,
+ * };
+ */
+int rhashtable_init(struct rhashtable *ht,
+		    const struct rhashtable_params *params)
+{
+	struct bucket_table *tbl;
+	size_t size;
+
+	size = HASH_DEFAULT_SIZE;
+
+	if ((!params->key_len && !params->obj_hashfn) ||
+	    (params->obj_hashfn && !params->obj_cmpfn))
+		return -EINVAL;
+
+	if (params->nulls_base && params->nulls_base < (1U << RHT_BASE_SHIFT))
+		return -EINVAL;
+
+	memset(ht, 0, sizeof(*ht));
+	mutex_init(&ht->mutex);
+	spin_lock_init(&ht->lock);
+	memcpy(&ht->p, params, sizeof(*params));
+
+	if (params->min_size)
+		ht->p.min_size = roundup_pow_of_two(params->min_size);
+
+	if (params->max_size)
+		ht->p.max_size = rounddown_pow_of_two(params->max_size);
+
+	if (params->insecure_max_entries)
+		ht->p.insecure_max_entries =
+			rounddown_pow_of_two(params->insecure_max_entries);
+	else
+		ht->p.insecure_max_entries = ht->p.max_size * 2;
+
+	ht->p.min_size = max(ht->p.min_size, HASH_MIN_SIZE);
+
+	if (params->nelem_hint)
+		size = rounded_hashtable_size(&ht->p);
+
+	/* The maximum (not average) chain length grows with the
+	 * size of the hash table, at a rate of (log N)/(log log N).
+	 * The value of 16 is selected so that even if the hash
+	 * table grew to 2^32 you would not expect the maximum
+	 * chain length to exceed it unless we are under attack
+	 * (or extremely unlucky).
+	 *
+	 * As this limit is only to detect attacks, we don't need
+	 * to set it to a lower value as you'd need the chain
+	 * length to vastly exceed 16 to have any real effect
+	 * on the system.
+	 */
+	if (!params->insecure_elasticity)
+		ht->elasticity = 16;
+
+	if (params->locks_mul)
+		ht->p.locks_mul = roundup_pow_of_two(params->locks_mul);
+	else
+		ht->p.locks_mul = BUCKET_LOCKS_PER_CPU;
+
+	ht->key_len = ht->p.key_len;
+	if (!params->hashfn) {
+		ht->p.hashfn = jhash;
+
+		if (!(ht->key_len & (sizeof(u32) - 1))) {
+			ht->key_len /= sizeof(u32);
+			ht->p.hashfn = rhashtable_jhash2;
+		}
+	}
+
+	tbl = bucket_table_alloc(ht, size, GFP_KERNEL);
+	if (tbl == NULL)
+		return -ENOMEM;
+
+	atomic_set(&ht->nelems, 0);
+
+	RCU_INIT_POINTER(ht->tbl, tbl);
+
+	INIT_WORK(&ht->run_work, rht_deferred_worker);
+
+	return 0;
+}
+
+/**
+ * rhashtable_free_and_destroy - free elements and destroy hash table
+ * @ht:		the hash table to destroy
+ * @free_fn:	callback to release resources of element
+ * @arg:	pointer passed to free_fn
+ *
+ * Stops an eventual async resize. If defined, invokes free_fn for each
+ * element to releasal resources. Please note that RCU protected
+ * readers may still be accessing the elements. Releasing of resources
+ * must occur in a compatible manner. Then frees the bucket array.
+ *
+ * This function will eventually sleep to wait for an async resize
+ * to complete. The caller is responsible that no further write operations
+ * occurs in parallel.
+ */
+void rhashtable_free_and_destroy(struct rhashtable *ht,
+				 void (*free_fn)(void *ptr, void *arg),
+				 void *arg)
+{
+	const struct bucket_table *tbl;
+	unsigned int i;
+
+	cancel_work_sync(&ht->run_work);
+
+	mutex_lock(&ht->mutex);
+	tbl = rht_dereference(ht->tbl, ht);
+	if (free_fn) {
+		for (i = 0; i < tbl->size; i++) {
+			struct rhash_head *pos, *next;
+
+			for (pos = rht_dereference(tbl->buckets[i], ht),
+			     next = !rht_is_a_nulls(pos) ?
+					rht_dereference(pos->next, ht) : NULL;
+			     !rht_is_a_nulls(pos);
+			     pos = next,
+			     next = !rht_is_a_nulls(pos) ?
+					rht_dereference(pos->next, ht) : NULL)
+				free_fn(rht_obj(ht, pos), arg);
+		}
+	}
+
+	bucket_table_free(tbl);
+	mutex_unlock(&ht->mutex);
+}
+
+void rhashtable_destroy(struct rhashtable *ht)
+{
+	return rhashtable_free_and_destroy(ht, NULL, NULL);
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rhashtable.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rhashtable.h
new file mode 100644
index 000000000000..d6e7a55037ee
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rhashtable.h
@@ -0,0 +1,828 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Resizable, Scalable, Concurrent Hash Table
+ *
+ * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au>
+ * Copyright (c) 2014-2015 Thomas Graf <tgraf@suug.ch>
+ * Copyright (c) 2008-2014 Patrick McHardy <kaber@trash.net>
+ *
+ * Code partially derived from nft_hash
+ * Rewritten with rehash code from br_multicast plus single list
+ * pointer as suggested by Josh Triplett
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#ifndef _LINUX_RHASHTABLE_H
+#define _LINUX_RHASHTABLE_H
+
+#include <linux/atomic.h>
+#include <linux/compiler.h>
+#include <linux/err.h>
+#include <linux/errno.h>
+#include <linux/jhash.h>
+#include <linux/list_nulls.h>
+#include <linux/workqueue.h>
+#include <linux/mutex.h>
+#include <linux/rcupdate.h>
+
+/*
+ * The end of the chain is marked with a special nulls marks which has
+ * the following format:
+ *
+ * +-------+-----------------------------------------------------+-+
+ * | Base  |                      Hash                           |1|
+ * +-------+-----------------------------------------------------+-+
+ *
+ * Base (4 bits) : Reserved to distinguish between multiple tables.
+ *                 Specified via &struct rhashtable_params.nulls_base.
+ * Hash (27 bits): Full hash (unmasked) of first element added to bucket
+ * 1 (1 bit)     : Nulls marker (always set)
+ *
+ * The remaining bits of the next pointer remain unused for now.
+ */
+#define RHT_BASE_BITS		4
+#define RHT_HASH_BITS		27
+#define RHT_BASE_SHIFT		RHT_HASH_BITS
+
+/* Base bits plus 1 bit for nulls marker */
+#define RHT_HASH_RESERVED_SPACE	(RHT_BASE_BITS + 1)
+
+struct rhash_head {
+	struct rhash_head __rcu		*next;
+};
+
+/**
+ * struct bucket_table - Table of hash buckets
+ * @size: Number of hash buckets
+ * @rehash: Current bucket being rehashed
+ * @hash_rnd: Random seed to fold into hash
+ * @locks_mask: Mask to apply before accessing locks[]
+ * @locks: Array of spinlocks protecting individual buckets
+ * @walkers: List of active walkers
+ * @rcu: RCU structure for freeing the table
+ * @future_tbl: Table under construction during rehashing
+ * @buckets: size * hash buckets
+ */
+struct bucket_table {
+	unsigned int		size;
+	unsigned int		rehash;
+	u32			hash_rnd;
+	unsigned int		locks_mask;
+	spinlock_t		*locks;
+	struct list_head	walkers;
+	struct rcu_head		rcu;
+
+	struct bucket_table __rcu *future_tbl;
+
+	struct rhash_head __rcu	*buckets[] ____cacheline_aligned_in_smp;
+};
+
+/**
+ * struct rhashtable_compare_arg - Key for the function rhashtable_compare
+ * @ht: Hash table
+ * @key: Key to compare against
+ */
+struct rhashtable_compare_arg {
+	struct rhashtable *ht;
+	const void *key;
+};
+
+typedef u32 (*rht_hashfn_t)(const void *data, u32 len, u32 seed);
+typedef u32 (*rht_obj_hashfn_t)(const void *data, u32 len, u32 seed);
+typedef int (*rht_obj_cmpfn_t)(struct rhashtable_compare_arg *arg,
+			       const void *obj);
+
+struct rhashtable;
+
+/**
+ * struct rhashtable_params - Hash table construction parameters
+ * @nelem_hint: Hint on number of elements, should be 75% of desired size
+ * @key_len: Length of key
+ * @key_offset: Offset of key in struct to be hashed
+ * @head_offset: Offset of rhash_head in struct to be hashed
+ * @insecure_max_entries: Maximum number of entries (may be exceeded)
+ * @max_size: Maximum size while expanding
+ * @min_size: Minimum size while shrinking
+ * @nulls_base: Base value to generate nulls marker
+ * @insecure_elasticity: Set to true to disable chain length checks
+ * @automatic_shrinking: Enable automatic shrinking of tables
+ * @locks_mul: Number of bucket locks to allocate per cpu (default: 128)
+ * @hashfn: Hash function (default: jhash2 if !(key_len % 4), or jhash)
+ * @obj_hashfn: Function to hash object
+ * @obj_cmpfn: Function to compare key with object
+ */
+struct rhashtable_params {
+	size_t			nelem_hint;
+	size_t			key_len;
+	size_t			key_offset;
+	size_t			head_offset;
+	unsigned int		insecure_max_entries;
+	unsigned int		max_size;
+	unsigned int		min_size;
+	u32			nulls_base;
+	bool			insecure_elasticity;
+	bool			automatic_shrinking;
+	size_t			locks_mul;
+	rht_hashfn_t		hashfn;
+	rht_obj_hashfn_t	obj_hashfn;
+	rht_obj_cmpfn_t		obj_cmpfn;
+};
+
+/**
+ * struct rhashtable - Hash table handle
+ * @tbl: Bucket table
+ * @nelems: Number of elements in table
+ * @key_len: Key length for hashfn
+ * @elasticity: Maximum chain length before rehash
+ * @p: Configuration parameters
+ * @run_work: Deferred worker to expand/shrink asynchronously
+ * @mutex: Mutex to protect current/future table swapping
+ * @lock: Spin lock to protect walker list
+ */
+struct rhashtable {
+	struct bucket_table __rcu	*tbl;
+	atomic_t			nelems;
+	unsigned int			key_len;
+	unsigned int			elasticity;
+	struct rhashtable_params	p;
+	struct work_struct		run_work;
+	struct mutex                    mutex;
+	spinlock_t			lock;
+};
+
+/**
+ * struct rhashtable_walker - Hash table walker
+ * @list: List entry on list of walkers
+ * @tbl: The table that we were walking over
+ */
+struct rhashtable_walker {
+	struct list_head list;
+	struct bucket_table *tbl;
+};
+
+/**
+ * struct rhashtable_iter - Hash table iterator, fits into netlink cb
+ * @ht: Table to iterate through
+ * @p: Current pointer
+ * @walker: Associated rhashtable walker
+ * @slot: Current slot
+ * @skip: Number of entries to skip in slot
+ */
+struct rhashtable_iter {
+	struct rhashtable *ht;
+	struct rhash_head *p;
+	struct rhashtable_walker *walker;
+	unsigned int slot;
+	unsigned int skip;
+};
+
+static inline unsigned long rht_marker(const struct rhashtable *ht, u32 hash)
+{
+	return NULLS_MARKER(ht->p.nulls_base + hash);
+}
+
+#define INIT_RHT_NULLS_HEAD(ptr, ht, hash) \
+	((ptr) = (typeof(ptr)) rht_marker(ht, hash))
+
+static inline bool rht_is_a_nulls(const struct rhash_head *ptr)
+{
+	return ((unsigned long) ptr & 1);
+}
+
+static inline unsigned long rht_get_nulls_value(const struct rhash_head *ptr)
+{
+	return ((unsigned long) ptr) >> 1;
+}
+
+static inline void *rht_obj(const struct rhashtable *ht,
+			    const struct rhash_head *he)
+{
+	return (char *)he - ht->p.head_offset;
+}
+
+static inline unsigned int rht_bucket_index(const struct bucket_table *tbl,
+					    unsigned int hash)
+{
+	return (hash >> RHT_HASH_RESERVED_SPACE) & (tbl->size - 1);
+}
+
+static inline unsigned int rht_key_hashfn(
+	struct rhashtable *ht, const struct bucket_table *tbl,
+	const void *key, const struct rhashtable_params params)
+{
+	unsigned int hash;
+
+	/* params must be equal to ht->p if it isn't constant. */
+	if (!__builtin_constant_p(params.key_len))
+		hash = ht->p.hashfn(key, ht->key_len, tbl->hash_rnd);
+	else if (params.key_len) {
+		unsigned int key_len = params.key_len;
+
+		if (params.hashfn)
+			hash = params.hashfn(key, key_len, tbl->hash_rnd);
+		else if (key_len & (sizeof(u32) - 1))
+			hash = jhash(key, key_len, tbl->hash_rnd);
+		else
+			hash = jhash2(key, key_len / sizeof(u32),
+				      tbl->hash_rnd);
+	} else {
+		unsigned int key_len = ht->p.key_len;
+
+		if (params.hashfn)
+			hash = params.hashfn(key, key_len, tbl->hash_rnd);
+		else
+			hash = jhash(key, key_len, tbl->hash_rnd);
+	}
+
+	return rht_bucket_index(tbl, hash);
+}
+
+static inline unsigned int rht_head_hashfn(
+	struct rhashtable *ht, const struct bucket_table *tbl,
+	const struct rhash_head *he, const struct rhashtable_params params)
+{
+	const char *ptr = rht_obj(ht, he);
+
+	return likely(params.obj_hashfn) ?
+	       rht_bucket_index(tbl, params.obj_hashfn(ptr, params.key_len ?:
+							    ht->p.key_len,
+						       tbl->hash_rnd)) :
+	       rht_key_hashfn(ht, tbl, ptr + params.key_offset, params);
+}
+
+/**
+ * rht_grow_above_75 - returns true if nelems > 0.75 * table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_75(const struct rhashtable *ht,
+				     const struct bucket_table *tbl)
+{
+	/* Expand table when exceeding 75% load */
+	return atomic_read(&ht->nelems) > (tbl->size / 4 * 3) &&
+	       (!ht->p.max_size || tbl->size < ht->p.max_size);
+}
+
+/**
+ * rht_shrink_below_30 - returns true if nelems < 0.3 * table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_shrink_below_30(const struct rhashtable *ht,
+				       const struct bucket_table *tbl)
+{
+	/* Shrink table beneath 30% load */
+	return atomic_read(&ht->nelems) < (tbl->size * 3 / 10) &&
+	       tbl->size > ht->p.min_size;
+}
+
+/**
+ * rht_grow_above_100 - returns true if nelems > table-size
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_100(const struct rhashtable *ht,
+				      const struct bucket_table *tbl)
+{
+	return atomic_read(&ht->nelems) > tbl->size &&
+		(!ht->p.max_size || tbl->size < ht->p.max_size);
+}
+
+/**
+ * rht_grow_above_max - returns true if table is above maximum
+ * @ht:		hash table
+ * @tbl:	current table
+ */
+static inline bool rht_grow_above_max(const struct rhashtable *ht,
+				      const struct bucket_table *tbl)
+{
+	return ht->p.insecure_max_entries &&
+	       atomic_read(&ht->nelems) >= ht->p.insecure_max_entries;
+}
+
+/* The bucket lock is selected based on the hash and protects mutations
+ * on a group of hash buckets.
+ *
+ * A maximum of tbl->size/2 bucket locks is allocated. This ensures that
+ * a single lock always covers both buckets which may both contains
+ * entries which link to the same bucket of the old table during resizing.
+ * This allows to simplify the locking as locking the bucket in both
+ * tables during resize always guarantee protection.
+ *
+ * IMPORTANT: When holding the bucket lock of both the old and new table
+ * during expansions and shrinking, the old bucket lock must always be
+ * acquired first.
+ */
+static inline spinlock_t *rht_bucket_lock(const struct bucket_table *tbl,
+					  unsigned int hash)
+{
+	return &tbl->locks[hash & tbl->locks_mask];
+}
+
+#ifdef CONFIG_PROVE_LOCKING
+int lockdep_rht_mutex_is_held(struct rhashtable *ht);
+int lockdep_rht_bucket_is_held(const struct bucket_table *tbl, u32 hash);
+#else
+static inline int lockdep_rht_mutex_is_held(struct rhashtable *ht)
+{
+	return 1;
+}
+
+static inline int lockdep_rht_bucket_is_held(const struct bucket_table *tbl,
+					     u32 hash)
+{
+	return 1;
+}
+#endif /* CONFIG_PROVE_LOCKING */
+
+int rhashtable_init(struct rhashtable *ht,
+		    const struct rhashtable_params *params);
+
+struct bucket_table *rhashtable_insert_slow(struct rhashtable *ht,
+					    const void *key,
+					    struct rhash_head *obj,
+					    struct bucket_table *old_tbl);
+int rhashtable_insert_rehash(struct rhashtable *ht, struct bucket_table *tbl);
+
+int rhashtable_walk_init(struct rhashtable *ht, struct rhashtable_iter *iter);
+void rhashtable_walk_exit(struct rhashtable_iter *iter);
+int rhashtable_walk_start(struct rhashtable_iter *iter) __acquires(RCU);
+void *rhashtable_walk_next(struct rhashtable_iter *iter);
+void rhashtable_walk_stop(struct rhashtable_iter *iter) __releases(RCU);
+
+void rhashtable_free_and_destroy(struct rhashtable *ht,
+				 void (*free_fn)(void *ptr, void *arg),
+				 void *arg);
+void rhashtable_destroy(struct rhashtable *ht);
+
+#define rht_dereference(p, ht) \
+	rcu_dereference_protected(p, lockdep_rht_mutex_is_held(ht))
+
+#define rht_dereference_rcu(p, ht) \
+	rcu_dereference_check(p, lockdep_rht_mutex_is_held(ht))
+
+#define rht_dereference_bucket(p, tbl, hash) \
+	rcu_dereference_protected(p, lockdep_rht_bucket_is_held(tbl, hash))
+
+#define rht_dereference_bucket_rcu(p, tbl, hash) \
+	rcu_dereference_check(p, lockdep_rht_bucket_is_held(tbl, hash))
+
+#define rht_entry(tpos, pos, member) \
+	({ tpos = container_of(pos, typeof(*tpos), member); 1; })
+
+/**
+ * rht_for_each_continue - continue iterating over hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ */
+#define rht_for_each_continue(pos, head, tbl, hash) \
+	for (pos = rht_dereference_bucket(head, tbl, hash); \
+	     !rht_is_a_nulls(pos); \
+	     pos = rht_dereference_bucket((pos)->next, tbl, hash))
+
+/**
+ * rht_for_each - iterate over hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ */
+#define rht_for_each(pos, tbl, hash) \
+	rht_for_each_continue(pos, (tbl)->buckets[hash], tbl, hash)
+
+/**
+ * rht_for_each_entry_continue - continue iterating over hash chain
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ */
+#define rht_for_each_entry_continue(tpos, pos, head, tbl, hash, member)	\
+	for (pos = rht_dereference_bucket(head, tbl, hash);		\
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	\
+	     pos = rht_dereference_bucket((pos)->next, tbl, hash))
+
+/**
+ * rht_for_each_entry - iterate over hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ */
+#define rht_for_each_entry(tpos, pos, tbl, hash, member)		\
+	rht_for_each_entry_continue(tpos, pos, (tbl)->buckets[hash],	\
+				    tbl, hash, member)
+
+/**
+ * rht_for_each_entry_safe - safely iterate over hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @next:	the &struct rhash_head to use as next in loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive allows for the looped code to
+ * remove the loop cursor from the list.
+ */
+#define rht_for_each_entry_safe(tpos, pos, next, tbl, hash, member)	    \
+	for (pos = rht_dereference_bucket((tbl)->buckets[hash], tbl, hash), \
+	     next = !rht_is_a_nulls(pos) ?				    \
+		       rht_dereference_bucket(pos->next, tbl, hash) : NULL; \
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	    \
+	     pos = next,						    \
+	     next = !rht_is_a_nulls(pos) ?				    \
+		       rht_dereference_bucket(pos->next, tbl, hash) : NULL)
+
+/**
+ * rht_for_each_rcu_continue - continue iterating over rcu hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_rcu_continue(pos, head, tbl, hash)			\
+	for (({barrier(); }),						\
+	     pos = rht_dereference_bucket_rcu(head, tbl, hash);		\
+	     !rht_is_a_nulls(pos);					\
+	     pos = rcu_dereference_raw(pos->next))
+
+/**
+ * rht_for_each_rcu - iterate over rcu hash chain
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_rcu(pos, tbl, hash)				\
+	rht_for_each_rcu_continue(pos, (tbl)->buckets[hash], tbl, hash)
+
+/**
+ * rht_for_each_entry_rcu_continue - continue iterating over rcu hash chain
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @head:	the previous &struct rhash_head to continue from
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_entry_rcu_continue(tpos, pos, head, tbl, hash, member) \
+	for (({barrier(); }),						    \
+	     pos = rht_dereference_bucket_rcu(head, tbl, hash);		    \
+	     (!rht_is_a_nulls(pos)) && rht_entry(tpos, pos, member);	    \
+	     pos = rht_dereference_bucket_rcu(pos->next, tbl, hash))
+
+/**
+ * rht_for_each_entry_rcu - iterate over rcu hash chain of given type
+ * @tpos:	the type * to use as a loop cursor.
+ * @pos:	the &struct rhash_head to use as a loop cursor.
+ * @tbl:	the &struct bucket_table
+ * @hash:	the hash value / bucket index
+ * @member:	name of the &struct rhash_head within the hashable struct.
+ *
+ * This hash chain list-traversal primitive may safely run concurrently with
+ * the _rcu mutation primitives such as rhashtable_insert() as long as the
+ * traversal is guarded by rcu_read_lock().
+ */
+#define rht_for_each_entry_rcu(tpos, pos, tbl, hash, member)		\
+	rht_for_each_entry_rcu_continue(tpos, pos, (tbl)->buckets[hash],\
+					tbl, hash, member)
+
+static inline int rhashtable_compare(struct rhashtable_compare_arg *arg,
+				     const void *obj)
+{
+	struct rhashtable *ht = arg->ht;
+	const char *ptr = obj;
+
+	return memcmp(ptr + ht->p.key_offset, arg->key, ht->p.key_len);
+}
+
+/**
+ * rhashtable_lookup_fast - search hash table, inlined version
+ * @ht:		hash table
+ * @key:	the pointer to the key
+ * @params:	hash table parameters
+ *
+ * Computes the hash value for the key and traverses the bucket chain looking
+ * for a entry with an identical key. The first matching entry is returned.
+ *
+ * Returns the first entry on which the compare function returned true.
+ */
+static inline void *rhashtable_lookup_fast(
+	struct rhashtable *ht, const void *key,
+	const struct rhashtable_params params)
+{
+	struct rhashtable_compare_arg arg = {
+		.ht = ht,
+		.key = key,
+	};
+	const struct bucket_table *tbl;
+	struct rhash_head *he;
+	unsigned int hash;
+
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+restart:
+	hash = rht_key_hashfn(ht, tbl, key, params);
+	rht_for_each_rcu(he, tbl, hash) {
+		if (params.obj_cmpfn ?
+		    params.obj_cmpfn(&arg, rht_obj(ht, he)) :
+		    rhashtable_compare(&arg, rht_obj(ht, he)))
+			continue;
+		rcu_read_unlock();
+		return rht_obj(ht, he);
+	}
+
+	/* Ensure we see any new tables. */
+	smp_rmb();
+
+	tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (unlikely(tbl))
+		goto restart;
+	rcu_read_unlock();
+
+	return NULL;
+}
+
+/* Internal function, please use rhashtable_insert_fast() instead */
+static inline int __rhashtable_insert_fast(
+	struct rhashtable *ht, const void *key, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	struct rhashtable_compare_arg arg = {
+		.ht = ht,
+		.key = key,
+	};
+	struct bucket_table *tbl, *new_tbl;
+	struct rhash_head *head;
+	spinlock_t *lock;
+	unsigned int elasticity;
+	unsigned int hash;
+	int err;
+
+restart:
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	/* All insertions must grab the oldest table containing
+	 * the hashed bucket that is yet to be rehashed.
+	 */
+	for (;;) {
+		hash = rht_head_hashfn(ht, tbl, obj, params);
+		lock = rht_bucket_lock(tbl, hash);
+		spin_lock_bh(lock);
+
+		if (tbl->rehash <= hash)
+			break;
+
+		spin_unlock_bh(lock);
+		tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	}
+
+	new_tbl = rht_dereference_rcu(tbl->future_tbl, ht);
+	if (unlikely(new_tbl)) {
+		tbl = rhashtable_insert_slow(ht, key, obj, new_tbl);
+		if (!IS_ERR_OR_NULL(tbl))
+			goto slow_path;
+
+		err = PTR_ERR(tbl);
+		goto out;
+	}
+
+	err = -E2BIG;
+	if (unlikely(rht_grow_above_max(ht, tbl)))
+		goto out;
+
+	if (unlikely(rht_grow_above_100(ht, tbl))) {
+slow_path:
+		spin_unlock_bh(lock);
+		err = rhashtable_insert_rehash(ht, tbl);
+		rcu_read_unlock();
+		if (err)
+			return err;
+
+		goto restart;
+	}
+
+	err = -EEXIST;
+	elasticity = ht->elasticity;
+	rht_for_each(head, tbl, hash) {
+		if (key &&
+		    unlikely(!(params.obj_cmpfn ?
+			       params.obj_cmpfn(&arg, rht_obj(ht, head)) :
+			       rhashtable_compare(&arg, rht_obj(ht, head)))))
+			goto out;
+		if (!--elasticity)
+			goto slow_path;
+	}
+
+	err = 0;
+
+	head = rht_dereference_bucket(tbl->buckets[hash], tbl, hash);
+
+	RCU_INIT_POINTER(obj->next, head);
+
+	rcu_assign_pointer(tbl->buckets[hash], obj);
+
+	atomic_inc(&ht->nelems);
+	if (rht_grow_above_75(ht, tbl))
+		schedule_work(&ht->run_work);
+
+out:
+	spin_unlock_bh(lock);
+	rcu_read_unlock();
+
+	return err;
+}
+
+/**
+ * rhashtable_insert_fast - insert object into hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Will take a per bucket spinlock to protect against mutual mutations
+ * on the same bucket. Multiple insertions may occur in parallel unless
+ * they map to the same bucket lock.
+ *
+ * It is safe to call this function from atomic context.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ */
+static inline int rhashtable_insert_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	return __rhashtable_insert_fast(ht, NULL, obj, params);
+}
+
+/**
+ * rhashtable_lookup_insert_fast - lookup and insert object into hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Locks down the bucket chain in both the old and new table if a resize
+ * is in progress to ensure that writers can't remove from the old table
+ * and can't insert to the new table during the atomic operation of search
+ * and insertion. Searches for duplicates in both the old and new table if
+ * a resize is in progress.
+ *
+ * This lookup function may only be used for fixed key hash table (key_len
+ * parameter set). It will BUG() if used inappropriately.
+ *
+ * It is safe to call this function from atomic context.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ */
+static inline int rhashtable_lookup_insert_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	const char *key = rht_obj(ht, obj);
+
+	BUG_ON(ht->p.obj_hashfn);
+
+	return __rhashtable_insert_fast(ht, key + ht->p.key_offset, obj,
+					params);
+}
+
+/**
+ * rhashtable_lookup_insert_key - search and insert object to hash table
+ *				  with explicit key
+ * @ht:		hash table
+ * @key:	key
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Locks down the bucket chain in both the old and new table if a resize
+ * is in progress to ensure that writers can't remove from the old table
+ * and can't insert to the new table during the atomic operation of search
+ * and insertion. Searches for duplicates in both the old and new table if
+ * a resize is in progress.
+ *
+ * Lookups may occur in parallel with hashtable mutations and resizing.
+ *
+ * Will trigger an automatic deferred table resizing if the size grows
+ * beyond the watermark indicated by grow_decision() which can be passed
+ * to rhashtable_init().
+ *
+ * Returns zero on success.
+ */
+static inline int rhashtable_lookup_insert_key(
+	struct rhashtable *ht, const void *key, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	BUG_ON(!ht->p.obj_hashfn || !key);
+
+	return __rhashtable_insert_fast(ht, key, obj, params);
+}
+
+/* Internal function, please use rhashtable_remove_fast() instead */
+static inline int __rhashtable_remove_fast(
+	struct rhashtable *ht, struct bucket_table *tbl,
+	struct rhash_head *obj, const struct rhashtable_params params)
+{
+	struct rhash_head __rcu **pprev;
+	struct rhash_head *he;
+	spinlock_t * lock;
+	unsigned int hash;
+	int err = -ENOENT;
+
+	hash = rht_head_hashfn(ht, tbl, obj, params);
+	lock = rht_bucket_lock(tbl, hash);
+
+	spin_lock_bh(lock);
+
+	pprev = &tbl->buckets[hash];
+	rht_for_each(he, tbl, hash) {
+		if (he != obj) {
+			pprev = &he->next;
+			continue;
+		}
+
+		rcu_assign_pointer(*pprev, obj->next);
+		err = 0;
+		break;
+	}
+
+	spin_unlock_bh(lock);
+
+	return err;
+}
+
+/**
+ * rhashtable_remove_fast - remove object from hash table
+ * @ht:		hash table
+ * @obj:	pointer to hash head inside object
+ * @params:	hash table parameters
+ *
+ * Since the hash chain is single linked, the removal operation needs to
+ * walk the bucket chain upon removal. The removal operation is thus
+ * considerable slow if the hash table is not correctly sized.
+ *
+ * Will automatically shrink the table via rhashtable_expand() if the
+ * shrink_decision function specified at rhashtable_init() returns true.
+ *
+ * Returns zero on success, -ENOENT if the entry could not be found.
+ */
+static inline int rhashtable_remove_fast(
+	struct rhashtable *ht, struct rhash_head *obj,
+	const struct rhashtable_params params)
+{
+	struct bucket_table *tbl;
+	int err;
+
+	rcu_read_lock();
+
+	tbl = rht_dereference_rcu(ht->tbl, ht);
+
+	/* Because we have already taken (and released) the bucket
+	 * lock in old_tbl, if we find that future_tbl is not yet
+	 * visible then that guarantees the entry to still be in
+	 * the old tbl if it exists.
+	 */
+	while ((err = __rhashtable_remove_fast(ht, tbl, obj, params)) &&
+	       (tbl = rht_dereference_rcu(tbl->future_tbl, ht)))
+		;
+
+	if (err)
+		goto out;
+
+	atomic_dec(&ht->nelems);
+	if (unlikely(ht->p.automatic_shrinking &&
+		     rht_shrink_below_30(ht, tbl)))
+		schedule_work(&ht->run_work);
+
+out:
+	rcu_read_unlock();
+
+	return err;
+}
+
+#endif /* _LINUX_RHASHTABLE_H */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_android.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_android.c
index ec939344b05e..ae034de0a99f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_android.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_android.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -55,6 +56,7 @@ const char *android_wifi_cmd_str[ANDROID_WIFI_CMD_MAX] = {
 	"BTCOEXSCAN-START",
 	"BTCOEXSCAN-STOP",
 	"BTCOEXMODE",
+	"SETSUSPENDMODE",
 	"SETSUSPENDOPT",
 	"P2P_DEV_ADDR",
 	"SETFWPATH",
@@ -93,6 +95,7 @@ const char *android_wifi_cmd_str[ANDROID_WIFI_CMD_MAX] = {
 #endif /* CONFIG_GTK_OL */
 /*	Private command for	P2P disable*/
 	"P2P_DISABLE",
+	"SET_AEK",
 	"DRIVER_VERSION"
 };
 
@@ -379,8 +382,6 @@ int rtw_android_get_rssi(struct net_device *net, char *command, int total_len)
 int rtw_android_get_link_speed(struct net_device *net, char *command, int total_len)
 {
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
-	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
-	struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
 	int bytes_written = 0;
 	u16 link_speed = 0;
 
@@ -392,7 +393,6 @@ int rtw_android_get_link_speed(struct net_device *net, char *command, int total_
 
 int rtw_android_get_macaddr(struct net_device *net, char *command, int total_len)
 {
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(net);
 	int bytes_written = 0;
 
 	bytes_written = snprintf(command, total_len, "Macaddr = "MAC_FMT, MAC_ARG(net->dev_addr));
@@ -564,8 +564,41 @@ int rtw_gtk_offload(struct net_device *net, u8 *cmd_ptr)
 }
 #endif /* CONFIG_GTK_OL */
 
+#ifdef CONFIG_RTW_MESH_AEK
+static int rtw_android_set_aek(struct net_device *ndev, char *command, int total_len)
+{
+#define SET_AEK_DATA_LEN (ETH_ALEN + 32)
+
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(ndev);
+	u8 *addr;
+	u8 *aek;
+	int err = 0;
+
+	if (total_len - strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AEK]) - 1 != SET_AEK_DATA_LEN) {
+		err = -EINVAL;
+		goto exit;
+	}
+
+	addr = command + strlen(android_wifi_cmd_str[ANDROID_WIFI_CMD_SET_AEK]) + 1;
+	aek = addr + ETH_ALEN;
+
+	RTW_PRINT(FUNC_NDEV_FMT" addr="MAC_FMT"\n"
+		, FUNC_NDEV_ARG(ndev), MAC_ARG(addr));
+	if (0)
+		RTW_PRINT(FUNC_NDEV_FMT" aek="KEY_FMT KEY_FMT"\n"
+			, FUNC_NDEV_ARG(ndev), KEY_ARG(aek), KEY_ARG(aek + 16));
+
+	if (rtw_mesh_plink_set_aek(adapter, addr, aek) != _SUCCESS)
+		err = -ENOENT;
+
+exit:
+	return err;
+}
+#endif /* CONFIG_RTW_MESH_AEK */
+
 int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 {
+	#define PRIVATE_COMMAND_MAX_LEN        8192
 	int ret = 0;
 	char *command = NULL;
 	int cmd_num;
@@ -617,7 +650,14 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		goto exit;
 	}
 	/*RTW_INFO("%s priv_cmd.buf=%p priv_cmd.total_len=%d  priv_cmd.used_len=%d\n",__func__,priv_cmd.buf,priv_cmd.total_len,priv_cmd.used_len);*/
-	command = rtw_zmalloc(priv_cmd.total_len);
+	if (priv_cmd.total_len > PRIVATE_COMMAND_MAX_LEN || priv_cmd.total_len < 0) {
+		RTW_WARN("%s: invalid private command (%d)\n", __FUNCTION__,
+			priv_cmd.total_len);
+		ret = -EFAULT;
+		goto exit;
+	}
+	
+	command = rtw_zmalloc(priv_cmd.total_len+1);
 	if (!command) {
 		RTW_INFO("%s: failed to allocate memory\n", __FUNCTION__);
 		ret = -ENOMEM;
@@ -633,7 +673,7 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		ret = -EFAULT;
 		goto exit;
 	}
-
+	command[priv_cmd.total_len] = '\0';
 	RTW_INFO("%s: Android private cmd \"%s\" on %s\n"
 		 , __FUNCTION__, command, ifr->ifr_name);
 
@@ -736,6 +776,9 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 #endif
 		break;
 
+	case ANDROID_WIFI_CMD_SETSUSPENDMODE:
+		break;
+
 	case ANDROID_WIFI_CMD_SETSUSPENDOPT:
 		/* bytes_written = wl_android_set_suspendopt(net, command, priv_cmd.total_len); */
 		break;
@@ -820,7 +863,7 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 		/*	wpa_cli driver wfd-set-tcpport = 554 */
 
 		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
-			rtw_wfd_set_ctrl_port(padapter, (u16)get_int_from_command(priv_cmd.buf));
+			rtw_wfd_set_ctrl_port(padapter, (u16)get_int_from_command(command));
 		break;
 	}
 	case ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT: {
@@ -832,7 +875,7 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 
 		pwfd_info = &padapter->wfd_info;
 		if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
-			pwfd_info->wfd_device_type = (u8) get_int_from_command(priv_cmd.buf);
+			pwfd_info->wfd_device_type = (u8) get_int_from_command(command);
 			pwfd_info->wfd_device_type &= WFD_DEVINFO_DUAL;
 		}
 		break;
@@ -841,7 +884,7 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 	case ANDROID_WIFI_CMD_CHANGE_DTIM: {
 #ifdef CONFIG_LPS
 		u8 dtim;
-		u8 *ptr = (u8 *) &priv_cmd.buf;
+		u8 *ptr = (u8 *) command;
 
 		ptr += 9;/* string command length of  "SET_DTIM"; */
 
@@ -856,19 +899,19 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 
 #if CONFIG_RTW_MACADDR_ACL
 	case ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL: {
-		rtw_set_macaddr_acl(padapter, get_int_from_command(command));
+		rtw_set_macaddr_acl(padapter, RTW_ACL_PERIOD_BSS, get_int_from_command(command));
 		break;
 	}
 	case ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA: {
 		u8 addr[ETH_ALEN] = {0x00};
 		macstr2num(addr, command + strlen("HOSTAPD_ACL_ADD_STA") + 3);	/* 3 is space bar + "=" + space bar these 3 chars */
-		rtw_acl_add_sta(padapter, addr);
+		rtw_acl_add_sta(padapter, RTW_ACL_PERIOD_BSS, addr);
 		break;
 	}
 	case ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA: {
 		u8 addr[ETH_ALEN] = {0x00};
 		macstr2num(addr, command + strlen("HOSTAPD_ACL_REMOVE_STA") + 3);	/* 3 is space bar + "=" + space bar these 3 chars */
-		rtw_acl_remove_sta(padapter, addr);
+		rtw_acl_remove_sta(padapter, RTW_ACL_PERIOD_BSS, addr);
 		break;
 	}
 #endif /* CONFIG_RTW_MACADDR_ACL */
@@ -879,14 +922,17 @@ int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)
 #endif /* CONFIG_GTK_OL		 */
 	case ANDROID_WIFI_CMD_P2P_DISABLE: {
 #ifdef CONFIG_P2P
-		struct mlme_ext_priv	*pmlmeext = &padapter->mlmeextpriv;
-		u8 channel, ch_offset;
-		u16 bwmode;
-
 		rtw_p2p_enable(padapter, P2P_ROLE_DISABLE);
 #endif /* CONFIG_P2P */
 		break;
 	}
+
+#ifdef CONFIG_RTW_MESH_AEK
+	case ANDROID_WIFI_CMD_SET_AEK:
+		bytes_written = rtw_android_set_aek(net, command, priv_cmd.total_len);
+		break;
+#endif
+	
 	case ANDROID_WIFI_CMD_DRIVERVERSION: {
 		bytes_written = strlen(DRIVERVERSION);
 		snprintf(command, bytes_written + 1, DRIVERVERSION);
@@ -1019,13 +1065,13 @@ int wifi_get_mac_addr(unsigned char *buf)
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35)) */
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)) || defined(COMPAT_KERNEL_RELEASE)
-void *wifi_get_country_code(char *ccode, u32 flags)
+void *wifi_get_country_code(char *ccode)
 {
 	RTW_INFO("%s\n", __FUNCTION__);
 	if (!ccode)
 		return NULL;
-	if (wifi_control_data && wifi_control_data->get_country_code)
-		return wifi_control_data->get_country_code(ccode,flags);
+	//if (wifi_control_data && wifi_control_data->get_country_code)
+	//	return wifi_control_data->get_country_code(ccode);
 	return NULL;
 }
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)) */
@@ -1080,6 +1126,81 @@ static int wifi_probe(struct platform_device *pdev)
 	return 0;
 }
 
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+extern PADAPTER g_test_adapter;
+
+static void shutdown_card(void)
+{
+	u32 addr;
+	u8 tmp8, cnt = 0;
+
+	if (NULL == g_test_adapter) {
+		RTW_INFO("%s: padapter==NULL\n", __FUNCTION__);
+		return;
+	}
+
+#ifdef CONFIG_FWLPS_IN_IPS
+	LeaveAllPowerSaveMode(g_test_adapter);
+#endif /* CONFIG_FWLPS_IN_IPS */
+
+#ifdef CONFIG_WOWLAN
+#ifdef CONFIG_GPIO_WAKEUP
+	/*default wake up pin change to BT*/
+	RTW_INFO("%s:default wake up pin change to BT\n", __FUNCTION__);
+	rtw_hal_switch_gpio_wl_ctrl(g_test_adapter, WAKEUP_GPIO_IDX, _FALSE);
+#endif /* CONFIG_GPIO_WAKEUP */
+#endif /* CONFIG_WOWLAN */
+
+	/* Leave SDIO HCI Suspend */
+	addr = 0x10250086;
+	rtw_write8(g_test_adapter, addr, 0);
+	do {
+		tmp8 = rtw_read8(g_test_adapter, addr);
+		cnt++;
+		RTW_INFO(FUNC_ADPT_FMT ": polling SDIO_HSUS_CTRL(0x%x)=0x%x, cnt=%d\n",
+			 FUNC_ADPT_ARG(g_test_adapter), addr, tmp8, cnt);
+
+		if (tmp8 & BIT(1))
+			break;
+
+		if (cnt >= 100) {
+			RTW_INFO(FUNC_ADPT_FMT ": polling 0x%x[1]==1 FAIL!!\n",
+				 FUNC_ADPT_ARG(g_test_adapter), addr);
+			break;
+		}
+
+		rtw_mdelay_os(10);
+	} while (1);
+
+	/* unlock register I/O */
+	rtw_write8(g_test_adapter, 0x1C, 0);
+
+	/* enable power down function */
+	/* 0x04[4] = 1 */
+	/* 0x05[7] = 1 */
+	addr = 0x04;
+	tmp8 = rtw_read8(g_test_adapter, addr);
+	tmp8 |= BIT(4);
+	rtw_write8(g_test_adapter, addr, tmp8);
+	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
+		FUNC_ADPT_ARG(g_test_adapter), addr, rtw_read8(g_test_adapter, addr));
+
+	addr = 0x05;
+	tmp8 = rtw_read8(g_test_adapter, addr);
+	tmp8 |= BIT(7);
+	rtw_write8(g_test_adapter, addr, tmp8);
+	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
+		FUNC_ADPT_ARG(g_test_adapter), addr, rtw_read8(g_test_adapter, addr));
+
+	/* lock register page0 0x0~0xB read/write */
+	rtw_write8(g_test_adapter, 0x1C, 0x0E);
+
+	rtw_set_surprise_removed(g_test_adapter);
+	RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=%s\n",
+		FUNC_ADPT_ARG(g_test_adapter), rtw_is_surprise_removed(g_test_adapter) ? "True" : "False");
+}
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
+
 static int wifi_remove(struct platform_device *pdev)
 {
 	struct wifi_platform_data *wifi_ctrl =
@@ -1095,6 +1216,23 @@ static int wifi_remove(struct platform_device *pdev)
 	return 0;
 }
 
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+static void wifi_shutdown(struct platform_device *pdev)
+{
+	struct wifi_platform_data *wifi_ctrl =
+		(struct wifi_platform_data *)(pdev->dev.platform_data);
+
+
+	RTW_INFO("## %s\n", __FUNCTION__);
+
+	wifi_control_data = wifi_ctrl;
+
+	shutdown_card();
+	wifi_set_power(0, 0);	/* Power Off */
+	wifi_set_carddetect(0);	/* CardDetect (1->0) */
+}
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
+
 static int wifi_suspend(struct platform_device *pdev, pm_message_t state)
 {
 	RTW_INFO("##> %s\n", __FUNCTION__);
@@ -1120,6 +1258,9 @@ static struct platform_driver wifi_device = {
 	.remove         = wifi_remove,
 	.suspend        = wifi_suspend,
 	.resume         = wifi_resume,
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+	.shutdown       = wifi_shutdown,
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 	.driver         = {
 		.name   = "bcmdhd_wlan",
 	}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.c
index 79e3f9874a29..1eb8f666033b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -209,22 +210,34 @@ static int rtw_cfgvendor_send_cmd_reply(struct wiphy *wiphy,
 	return rtw_cfg80211_vendor_cmd_reply(skb);
 }
 
-#define WIFI_FEATURE_INFRA              0x0001      /* Basic infrastructure mode       */
-#define WIFI_FEATURE_INFRA_5G           0x0002      /* Support for 5 GHz Band          */
-#define WIFI_FEATURE_HOTSPOT            0x0004      /* Support for GAS/ANQP            */
-#define WIFI_FEATURE_P2P                0x0008      /* Wifi-Direct                     */
-#define WIFI_FEATURE_SOFT_AP            0x0010      /* Soft AP                         */
-#define WIFI_FEATURE_GSCAN              0x0020      /* Google-Scan APIs                */
-#define WIFI_FEATURE_NAN                0x0040      /* Neighbor Awareness Networking   */
-#define WIFI_FEATURE_D2D_RTT            0x0080      /* Device-to-device RTT            */
-#define WIFI_FEATURE_D2AP_RTT           0x0100      /* Device-to-AP RTT                */
-#define WIFI_FEATURE_BATCH_SCAN         0x0200      /* Batched Scan (legacy)           */
-#define WIFI_FEATURE_PNO                0x0400      /* Preferred network offload       */
-#define WIFI_FEATURE_ADDITIONAL_STA     0x0800      /* Support for two STAs            */
-#define WIFI_FEATURE_TDLS               0x1000      /* Tunnel directed link setup      */
-#define WIFI_FEATURE_TDLS_OFFCHANNEL    0x2000      /* Support for TDLS off channel    */
-#define WIFI_FEATURE_EPR                0x4000      /* Enhanced power reporting        */
-#define WIFI_FEATURE_AP_STA             0x8000      /* Support for AP STA Concurrency  */
+/* Feature enums */
+#define WIFI_FEATURE_INFRA              0x0001      // Basic infrastructure mode
+#define WIFI_FEATURE_INFRA_5G           0x0002      // Support for 5 GHz Band
+#define WIFI_FEATURE_HOTSPOT            0x0004      // Support for GAS/ANQP
+#define WIFI_FEATURE_P2P                0x0008      // Wifi-Direct
+#define WIFI_FEATURE_SOFT_AP            0x0010      // Soft AP
+#define WIFI_FEATURE_GSCAN              0x0020      // Google-Scan APIs
+#define WIFI_FEATURE_NAN                0x0040      // Neighbor Awareness Networking
+#define WIFI_FEATURE_D2D_RTT            0x0080      // Device-to-device RTT
+#define WIFI_FEATURE_D2AP_RTT           0x0100      // Device-to-AP RTT
+#define WIFI_FEATURE_BATCH_SCAN         0x0200      // Batched Scan (legacy)
+#define WIFI_FEATURE_PNO                0x0400      // Preferred network offload
+#define WIFI_FEATURE_ADDITIONAL_STA     0x0800      // Support for two STAs
+#define WIFI_FEATURE_TDLS               0x1000      // Tunnel directed link setup
+#define WIFI_FEATURE_TDLS_OFFCHANNEL    0x2000      // Support for TDLS off channel
+#define WIFI_FEATURE_EPR                0x4000      // Enhanced power reporting
+#define WIFI_FEATURE_AP_STA             0x8000      // Support for AP STA Concurrency
+#define WIFI_FEATURE_LINK_LAYER_STATS   0x10000     // Link layer stats collection
+#define WIFI_FEATURE_LOGGER             0x20000     // WiFi Logger
+#define WIFI_FEATURE_HAL_EPNO           0x40000     // WiFi PNO enhanced
+#define WIFI_FEATURE_RSSI_MONITOR       0x80000     // RSSI Monitor
+#define WIFI_FEATURE_MKEEP_ALIVE        0x100000    // WiFi mkeep_alive
+#define WIFI_FEATURE_CONFIG_NDO         0x200000    // ND offload configure
+#define WIFI_FEATURE_TX_TRANSMIT_POWER  0x400000    // Capture Tx transmit power levels
+#define WIFI_FEATURE_CONTROL_ROAMING    0x800000    // Enable/Disable firmware roaming
+#define WIFI_FEATURE_IE_WHITELIST       0x1000000   // Support Probe IE white listing
+#define WIFI_FEATURE_SCAN_RAND          0x2000000   // Support MAC & Probe Sequence Number randomization
+// Add more features here
 
 #define MAX_FEATURE_SET_CONCURRRENT_GROUPS  3
 
@@ -239,14 +252,31 @@ int rtw_dev_get_feature_set(struct net_device *dev)
 
 	feature_set |= WIFI_FEATURE_INFRA;
 
-	if (IS_8814A_SERIES(*hal_ver) || IS_8812_SERIES(*hal_ver) ||
-	    IS_8821_SERIES(*hal_ver))
+#ifdef CONFIG_IEEE80211_BAND_5GHZ
+	if (is_supported_5g(adapter_to_regsty(adapter)->wireless_mode))
 		feature_set |= WIFI_FEATURE_INFRA_5G;
+#endif
 
 	feature_set |= WIFI_FEATURE_P2P;
 	feature_set |= WIFI_FEATURE_SOFT_AP;
 
 	feature_set |= WIFI_FEATURE_ADDITIONAL_STA;
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+	feature_set |= WIFI_FEATURE_LINK_LAYER_STATS;
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+        feature_set |= WIFI_FEATURE_RSSI_MONITOR;
+#endif
+
+#ifdef CONFIG_RTW_CFGVENDOR_WIFI_LOGGER
+	feature_set |= WIFI_FEATURE_LOGGER;
+#endif
+
+#ifdef CONFIG_RTW_WIFI_HAL
+	feature_set |= WIFI_FEATURE_CONFIG_NDO;
+	feature_set |= WIFI_FEATURE_SCAN_RAND;
+#endif
 
 	return feature_set;
 }
@@ -362,8 +392,8 @@ exit:
 }
 
 #if defined(GSCAN_SUPPORT) && 0
-int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
-	struct net_device *dev, void  *data, int len, wl_vendor_event_t event)
+int rtw_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
+	struct net_device *dev, void  *data, int len, rtw_vendor_event_t event)
 {
 	u16 kflags;
 	const void *ptr;
@@ -413,7 +443,7 @@ int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
 }
 
 
-static int wl_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
+static int rtw_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
 		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
@@ -440,7 +470,7 @@ static int wl_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,
 	return err;
 }
 
-static int wl_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,
+static int rtw_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,
 		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0, type, band;
@@ -487,7 +517,7 @@ exit:
 	return err;
 }
 
-static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
+static int rtw_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
 		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
@@ -571,7 +601,7 @@ static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,
 	return rtw_cfg80211_vendor_cmd_reply(skb);
 }
 
-static int wl_cfgvendor_initiate_gscan(struct wiphy *wiphy,
+static int rtw_cfgvendor_initiate_gscan(struct wiphy *wiphy,
 		       struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
@@ -601,7 +631,7 @@ static int wl_cfgvendor_initiate_gscan(struct wiphy *wiphy,
 
 }
 
-static int wl_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,
+static int rtw_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,
 		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
@@ -625,7 +655,7 @@ static int wl_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,
 	return err;
 }
 
-static int wl_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
+static int rtw_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
 		     struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
@@ -717,7 +747,7 @@ static int wl_cfgvendor_set_scan_cfg(struct wiphy *wiphy,
 
 }
 
-static int wl_cfgvendor_hotlist_cfg(struct wiphy *wiphy,
+static int rtw_cfgvendor_hotlist_cfg(struct wiphy *wiphy,
 		    struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
@@ -783,7 +813,7 @@ exit:
 	kfree(hotlist_params);
 	return err;
 }
-static int wl_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
+static int rtw_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
 		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0, tmp, type;
@@ -820,7 +850,7 @@ static int wl_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,
 	return err;
 }
 
-static int wl_cfgvendor_significant_change_cfg(struct wiphy *wiphy,
+static int rtw_cfgvendor_significant_change_cfg(struct wiphy *wiphy,
 		struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
@@ -894,7 +924,7 @@ exit:
 #endif /* GSCAN_SUPPORT */
 
 #if defined(RTT_SUPPORT) && 0
-void wl_cfgvendor_rtt_evt(void *ctx, void *rtt_data)
+void rtw_cfgvendor_rtt_evt(void *ctx, void *rtt_data)
 {
 	struct wireless_dev *wdev = (struct wireless_dev *)ctx;
 	struct wiphy *wiphy;
@@ -958,7 +988,7 @@ exit:
 	return;
 }
 
-static int wl_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev *wdev,
+static int rtw_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev *wdev,
 				       const void *data, int len)
 {
 	int err = 0, rem, rem1, rem2, type;
@@ -1045,7 +1075,7 @@ exit:
 	return err;
 }
 
-static int wl_cfgvendor_rtt_cancel_config(struct wiphy *wiphy, struct wireless_dev *wdev,
+static int rtw_cfgvendor_rtt_cancel_config(struct wiphy *wiphy, struct wireless_dev *wdev,
 		const void *data, int len)
 {
 	int err = 0, rem, type, target_cnt = 0;
@@ -1085,7 +1115,7 @@ exit:
 		kfree(mac_list);
 	return err;
 }
-static int wl_cfgvendor_rtt_get_capability(struct wiphy *wiphy, struct wireless_dev *wdev,
+static int rtw_cfgvendor_rtt_get_capability(struct wiphy *wiphy, struct wireless_dev *wdev,
 		const void *data, int len)
 {
 	int err = 0;
@@ -1107,57 +1137,611 @@ exit:
 }
 
 #endif /* RTT_SUPPORT */
-static int wl_cfgvendor_priv_string_handler(struct wiphy *wiphy,
-		struct wireless_dev *wdev, const void  *data, int len)
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+enum {
+    LSTATS_SUBCMD_GET_INFO = ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START,
+	LSTATS_SUBCMD_SET_INFO,
+	LSTATS_SUBCMD_CLEAR_INFO,
+};
+static void LinkLayerStats(_adapter *padapter)
+{
+	struct xmit_priv		*pxmitpriv = &(padapter->xmitpriv);
+	struct recv_priv		*precvpriv = &(padapter->recvpriv);
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	struct dvobj_priv	*pdvobjpriv = adapter_to_dvobj(padapter);
+	u32 ps_time, trx_total_time;
+	u64 tx_bytes, rx_bytes, trx_total_bytes = 0;
+	u64 tmp = 0;
+	
+	RTW_DBG("%s adapter type : %u\n", __func__, padapter->adapter_type);
+
+	tx_bytes = 0;
+	rx_bytes = 0;
+	ps_time = 0;
+	trx_total_time = 0;
+
+	if ( padapter->netif_up == _TRUE ) {
+
+		pwrpriv->on_time = rtw_get_passing_time_ms(pwrpriv->radio_on_start_time);
+
+		if (rtw_mi_check_fwstate(padapter, _FW_LINKED)) {
+			if ( pwrpriv->bpower_saving == _TRUE ) {
+				pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+			}
+		} else {		
+#ifdef CONFIG_IPS
+			if ( pwrpriv->bpower_saving == _TRUE ) {
+				pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
+				pwrpriv->pwr_saving_start_time = rtw_get_current_time();
+			}
+#else
+			pwrpriv->pwr_saving_time = pwrpriv->on_time;
+#endif
+		}
+
+		ps_time = pwrpriv->pwr_saving_time;
+
+		/* Deviation caused by caculation start time */
+		if ( ps_time > pwrpriv->on_time )
+			ps_time = pwrpriv->on_time;
+
+		tx_bytes = pdvobjpriv->traffic_stat.last_tx_bytes;
+		rx_bytes = pdvobjpriv->traffic_stat.last_rx_bytes;		
+		trx_total_bytes = tx_bytes + rx_bytes;
+
+		trx_total_time = pwrpriv->on_time - ps_time;
+
+		if ( trx_total_bytes == 0) {
+			pwrpriv->tx_time = 0;
+			pwrpriv->rx_time = 0;
+		} else {
+
+			/* tx_time = (trx_total_time * tx_total_bytes) / trx_total_bytes; */
+			/* rx_time = (trx_total_time * rx_total_bytes) / trx_total_bytes; */
+
+			tmp = (tx_bytes * trx_total_time);
+			tmp = rtw_division64(tmp, trx_total_bytes);
+			pwrpriv->tx_time = tmp;
+
+			tmp = (rx_bytes * trx_total_time);
+			tmp = rtw_division64(tmp, trx_total_bytes);
+			pwrpriv->rx_time = tmp;		
+
+		}
+	
+	}
+	else {
+			pwrpriv->on_time = 0;
+			pwrpriv->tx_time = 0;
+			pwrpriv->rx_time = 0;	
+	}
+
+#ifdef CONFIG_RTW_WIFI_HAL_DEBUG
+	RTW_INFO("- tx_bytes : %llu rx_bytes : %llu total bytes : %llu\n", tx_bytes, rx_bytes, trx_total_bytes);
+	RTW_INFO("- netif_up = %s, on_time : %u ms\n", padapter->netif_up ? "1":"0", pwrpriv->on_time);
+	RTW_INFO("- pwr_saving_time : %u (%u) ms\n", pwrpriv->pwr_saving_time, ps_time);
+	RTW_INFO("- trx_total_time : %u ms\n", trx_total_time);		
+	RTW_INFO("- tx_time : %u ms\n", pwrpriv->tx_time);
+	RTW_INFO("- rx_time : %u ms\n", pwrpriv->rx_time);	
+#endif /* CONFIG_RTW_WIFI_HAL_DEBUG */
+
+}
+
+#define DUMMY_TIME_STATICS 99
+static int rtw_cfgvendor_lstats_get_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
 {
 	int err = 0;
-	u8 resp[1] = {'\0'};
+	_adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+	struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
+	wifi_radio_stat_internal *radio;
+	wifi_iface_stat *iface;
+	char *output;
+
+	output = rtw_malloc(sizeof(wifi_radio_stat_internal) + sizeof(wifi_iface_stat));
+	if (output == NULL) {
+		RTW_DBG("Allocate lstats info buffer fail!\n");
+	}
 
-	RTW_PRINT(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char *)data);
-	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), resp, 1);
+	radio = (wifi_radio_stat_internal *)output;
+
+	radio->num_channels = 0;
+	radio->radio = 1;
+
+	/* to get on_time, tx_time, rx_time */
+	LinkLayerStats(padapter); 
+	
+	radio->on_time = pwrpriv->on_time;
+	radio->tx_time = pwrpriv->tx_time;
+	radio->rx_time = pwrpriv->rx_time;
+	radio->on_time_scan = 0;
+	radio->on_time_nbd = 0;
+	radio->on_time_gscan = 0;
+	radio->on_time_pno_scan = 0;
+	radio->on_time_hs20 = 0;
+	#ifdef CONFIG_RTW_WIFI_HAL_DEBUG
+	RTW_INFO("==== %s ====\n", __func__);
+	RTW_INFO("radio->radio : %d\n", (radio->radio));
+	RTW_INFO("pwrpriv->on_time : %u ms\n", (pwrpriv->on_time));
+	RTW_INFO("pwrpriv->tx_time :  %u ms\n", (pwrpriv->tx_time));
+	RTW_INFO("pwrpriv->rx_time :  %u ms\n", (pwrpriv->rx_time));
+	RTW_INFO("radio->on_time :  %u ms\n", (radio->on_time));
+	RTW_INFO("radio->tx_time :  %u ms\n", (radio->tx_time));
+	RTW_INFO("radio->rx_time :  %u ms\n", (radio->rx_time));
+	#endif /* CONFIG_RTW_WIFI_HAL_DEBUG */
+	
+	RTW_DBG(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
+	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), 
+		output, sizeof(wifi_iface_stat) + sizeof(wifi_radio_stat_internal));
 	if (unlikely(err))
-		RTW_ERR(FUNC_NDEV_FMT"Vendor Command reply failed ret:%d\n"
+		RTW_ERR(FUNC_NDEV_FMT"Vendor Command reply failed ret:%d \n"
 			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
-
+	rtw_mfree(output, sizeof(wifi_iface_stat) + sizeof(wifi_radio_stat_internal));
 	return err;
-#if 0
-	struct bcm_cfg80211 *cfg = wiphy_priv(wiphy);
+}
+static int rtw_cfgvendor_lstats_set_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
 	int err = 0;
-	int data_len = 0;
+	RTW_INFO("%s\n", __func__);
+	return err;
+}
+static int rtw_cfgvendor_lstats_clear_info(struct wiphy *wiphy,	
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	RTW_INFO("%s\n", __func__);
+	return err;
+}
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+static int rtw_cfgvendor_set_rssi_monitor(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+        _adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+        struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
 
-	bzero(cfg->ioctl_buf, WLC_IOCTL_MAXLEN);
+        struct recv_priv *precvpriv = &padapter->recvpriv;
+	int err = 0, rem, type;
+        const struct nlattr *iter;
 
-	if (strncmp((char *)data, BRCM_VENDOR_SCMD_CAPA, strlen(BRCM_VENDOR_SCMD_CAPA)) == 0) {
-		err = wldev_iovar_getbuf(bcmcfg_to_prmry_ndev(cfg), "cap", NULL, 0,
-			cfg->ioctl_buf, WLC_IOCTL_MAXLEN, &cfg->ioctl_buf_sync);
-		if (unlikely(err)) {
-			WL_ERR(("error (%d)\n", err));
-			return err;
+        RTW_DBG(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
+
+	nla_for_each_attr(iter, data, len, rem) {
+		type = nla_type(iter);
+
+		switch (type) {
+        		case RSSI_MONITOR_ATTRIBUTE_MAX_RSSI:
+                                pwdev_priv->rssi_monitor_max = (s8)nla_get_u32(iter);;
+	        		break;
+		        case RSSI_MONITOR_ATTRIBUTE_MIN_RSSI:
+                                pwdev_priv->rssi_monitor_min = (s8)nla_get_u32(iter);
+			        break;
+        		case RSSI_MONITOR_ATTRIBUTE_START:
+                                pwdev_priv->rssi_monitor_enable = (u8)nla_get_u32(iter);
+	        		break;
 		}
-		data_len = strlen(cfg->ioctl_buf);
-		cfg->ioctl_buf[data_len] = '\0';
 	}
 
-	err =  rtw_cfgvendor_send_cmd_reply(wiphy, bcmcfg_to_prmry_ndev(cfg),
-					    cfg->ioctl_buf, data_len + 1);
+	return err;
+}
+
+void rtw_cfgvendor_rssi_monitor_evt(_adapter *padapter) {
+	struct wireless_dev *wdev =  padapter->rtw_wdev;
+	struct wiphy *wiphy= wdev->wiphy;
+        struct recv_priv *precvpriv = &padapter->recvpriv;
+	struct	mlme_priv	*pmlmepriv = &(padapter->mlmepriv);
+	struct	wlan_network	*pcur_network = &pmlmepriv->cur_network;
+        struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
+	struct sk_buff *skb;
+	u32 tot_len = NLMSG_DEFAULT_SIZE;
+	gfp_t kflags;
+        rssi_monitor_evt data ;
+        s8 rssi = precvpriv->rssi;
+
+        if (pwdev_priv->rssi_monitor_enable == 0 || check_fwstate(pmlmepriv, _FW_LINKED) != _TRUE)
+                return;
+
+        if (rssi < pwdev_priv->rssi_monitor_max || rssi > pwdev_priv->rssi_monitor_min)
+                return;
+
+	kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+
+	/* Alloc the SKB for vendor_event */
+	skb = rtw_cfg80211_vendor_event_alloc(wiphy, wdev, tot_len, GOOGLE_RSSI_MONITOR_EVENT, kflags);
+	if (!skb) {
+		goto exit;
+	}
+
+        _rtw_memset(&data, 0, sizeof(data));
+
+        data.version = RSSI_MONITOR_EVT_VERSION;
+        data.cur_rssi = rssi;
+        _rtw_memcpy(data.BSSID, pcur_network->network.MacAddress, sizeof(mac_addr));
+
+        nla_append(skb, sizeof(data), &data);
+
+	rtw_cfg80211_vendor_event(skb, kflags);
+exit:
+	return;
+}
+#endif /* CONFIG_RTW_CFGVEDNOR_RSSIMONITR */
+
+#ifdef CONFIG_RTW_CFGVENDOR_WIFI_LOGGER
+static int rtw_cfgvendor_logger_start_logging(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int ret = 0, rem, type;
+	char ring_name[32] = {0};
+	int log_level = 0, flags = 0, time_intval = 0, threshold = 0;
+	const struct nlattr *iter;
+
+	nla_for_each_attr(iter, data, len, rem) {
+		type = nla_type(iter);
+		switch (type) {
+			case LOGGER_ATTRIBUTE_RING_NAME:
+				strncpy(ring_name, nla_data(iter),
+					MIN(sizeof(ring_name) -1, nla_len(iter)));
+				break;
+			case LOGGER_ATTRIBUTE_LOG_LEVEL:
+				log_level = nla_get_u32(iter);
+				break;
+			case LOGGER_ATTRIBUTE_RING_FLAGS:
+				flags = nla_get_u32(iter);
+				break;
+			case LOGGER_ATTRIBUTE_LOG_TIME_INTVAL:
+				time_intval = nla_get_u32(iter);
+				break;
+			case LOGGER_ATTRIBUTE_LOG_MIN_DATA_SIZE:
+				threshold = nla_get_u32(iter);
+				break;
+			default:
+				RTW_ERR("Unknown type: %d\n", type);
+				ret = WIFI_ERROR_INVALID_ARGS;
+				goto exit;
+		}
+	}
+
+exit:
+	return ret;
+}
+static int rtw_cfgvendor_logger_get_feature(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void *data, int len)
+{
+	int err = 0;
+	u32 supported_features = 0;
+
+	err =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), &supported_features, sizeof(supported_features));
+
 	if (unlikely(err))
-		WL_ERR(("Vendor Command reply failed ret:%d\n", err));
-	else
-		WL_INFORM(("Vendor Command reply sent successfully!\n"));
+		RTW_ERR(FUNC_NDEV_FMT" Vendor Command reply failed ret:%d\n"
+			, FUNC_NDEV_ARG(wdev_to_ndev(wdev)), err);
+
+	return err;
+}
+static int rtw_cfgvendor_logger_get_version(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void *data, int len)
+{
+	_adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+	HAL_DATA_TYPE *hal = GET_HAL_DATA(padapter);
+	int ret = 0, rem, type;
+	int buf_len = 1024;
+	char *buf_ptr;
+	const struct nlattr *iter;
+	gfp_t kflags;
+
+	kflags = in_atomic() ? GFP_ATOMIC : GFP_KERNEL;
+	buf_ptr = kzalloc(buf_len, kflags);
+	if (!buf_ptr) {
+		RTW_ERR("failed to allocate the buffer for version n");
+		ret = -ENOMEM;
+		goto exit;
+	}
+	nla_for_each_attr(iter, data, len, rem) {
+		type = nla_type(iter);
+		switch (type) {
+			case LOGGER_ATTRIBUTE_GET_DRIVER:
+				memcpy(buf_ptr, DRIVERVERSION, strlen(DRIVERVERSION)+1);
+				break;
+			case LOGGER_ATTRIBUTE_GET_FW:
+				sprintf(buf_ptr, "v%d.%d", hal->firmware_version, hal->firmware_sub_version);
+				break;
+			default:
+				RTW_ERR("Unknown type: %d\n", type);
+				ret = -EINVAL;
+				goto exit;
+		}
+	}
+	if (ret < 0) {
+		RTW_ERR("failed to get the version %d\n", ret);
+		goto exit;
+	}
+
+
+	ret =  rtw_cfgvendor_send_cmd_reply(wiphy, wdev_to_ndev(wdev), buf_ptr, strlen(buf_ptr));
+exit:
+	kfree(buf_ptr);
+	return ret;
+}
+
+static int rtw_cfgvendor_logger_get_ring_status(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int ret = 0;
+	int ring_id;
+	char ring_buf_name[] = "RTW_RING_BUFFER";
+
+	struct sk_buff *skb;
+	wifi_ring_buffer_status ring_status;
+
+
+	_rtw_memcpy(ring_status.name, ring_buf_name, strlen(ring_buf_name)+1);
+	ring_status.ring_id = 1;
+	/* Alloc the SKB for vendor_event */
+	skb = cfg80211_vendor_cmd_alloc_reply_skb(wiphy,
+		sizeof(wifi_ring_buffer_status));
+	if (!skb) {
+		RTW_ERR("skb allocation is failed\n");
+		ret = FAIL;
+		goto exit;
+	}
+
+	nla_put_u32(skb, LOGGER_ATTRIBUTE_RING_NUM, 1);
+	nla_put(skb, LOGGER_ATTRIBUTE_RING_STATUS, sizeof(wifi_ring_buffer_status),
+				&ring_status);
+	ret = cfg80211_vendor_cmd_reply(skb);
+
+	if (ret) {
+		RTW_ERR("Vendor Command reply failed ret:%d \n", ret);
+	}
+exit:
+	return ret;
+}
+
+static int rtw_cfgvendor_logger_get_ring_data(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int ret = 0, rem, type;
+	char ring_name[32] = {0};
+	const struct nlattr *iter;
+
+	nla_for_each_attr(iter, data, len, rem) {
+		type = nla_type(iter);
+		switch (type) {
+			case LOGGER_ATTRIBUTE_RING_NAME:
+				strncpy(ring_name, nla_data(iter),
+					MIN(sizeof(ring_name) -1, nla_len(iter)));
+				RTW_INFO(" %s LOGGER_ATTRIBUTE_RING_NAME : %s\n", __func__, ring_name);
+				break;
+			default:
+				RTW_ERR("Unknown type: %d\n", type);
+				return ret;
+		}
+	}
+
+
+	return ret;
+}
+
+static int rtw_cfgvendor_logger_get_firmware_memory_dump(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int ret = WIFI_ERROR_NOT_SUPPORTED;
+
+	return ret;
+}
+
+static int rtw_cfgvendor_logger_start_pkt_fate_monitoring(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int ret = WIFI_SUCCESS;
+
+	return ret;
+}
+
+static int rtw_cfgvendor_logger_get_tx_pkt_fates(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int ret = WIFI_SUCCESS;
+
+	return ret;
+}
+
+static int rtw_cfgvendor_logger_get_rx_pkt_fates(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+	int ret = WIFI_SUCCESS;
+
+	return ret;
+}
+
+#endif /* CONFIG_RTW_CFGVENDOR_WIFI_LOGGER */
+#ifdef CONFIG_RTW_WIFI_HAL
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+
+#ifndef ETHER_ISMULTI
+#define ETHER_ISMULTI(ea) (((const u8 *)(ea))[0] & 1)
+#endif
+
+
+static u8 null_addr[ETH_ALEN] = {0};
+static void rtw_hal_random_gen_mac_addr(u8 *mac_addr)
+{
+	do {
+		get_random_bytes(&mac_addr[3], ETH_ALEN-3);
+		if (memcmp(mac_addr, null_addr, ETH_ALEN) != 0)
+			break;
+	} while(1);
+}
+
+void rtw_hal_pno_random_gen_mac_addr(PADAPTER adapter)
+{
+	u8 mac_addr[ETH_ALEN];
+	struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
+
+	memcpy(mac_addr, pwdev_priv->pno_mac_addr, ETH_ALEN);
+	if (mac_addr[0] == 0xFF) return;
+	rtw_hal_random_gen_mac_addr(mac_addr);
+	memcpy(pwdev_priv->pno_mac_addr, mac_addr, ETH_ALEN);
+#ifdef CONFIG_RTW_DEBUG
+	print_hex_dump(KERN_DEBUG, "pno_mac_addr: ",
+		       DUMP_PREFIX_OFFSET, 16, 1, pwdev_priv->pno_mac_addr,
+		       ETH_ALEN, 1);
+#endif
+}
+
+void rtw_hal_set_hw_mac_addr(PADAPTER adapter, u8 *mac_addr)
+{
+	rtw_ps_deny(adapter, PS_DENY_IOCTL);
+	LeaveAllPowerSaveModeDirect(adapter);
+
+	rtw_hal_set_hwreg(adapter, HW_VAR_MAC_ADDR, mac_addr);
+#ifdef CONFIG_RTW_DEBUG
+	rtw_hal_dump_macaddr(RTW_DBGDUMP, adapter);
+#endif
+	rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
+}
+
+static int rtw_cfgvendor_set_rand_mac_oui(struct wiphy *wiphy,
+		struct wireless_dev *wdev, const void  *data, int len)
+{
+	int err = 0;
+	PADAPTER adapter;
+	void *devaddr;
+	struct net_device *netdev;
+	int type, mac_len;
+	u8 pno_random_mac_oui[3];
+	u8 mac_addr[ETH_ALEN] = {0};
+	struct pwrctrl_priv *pwrctl;
+	struct rtw_wdev_priv *pwdev_priv;
+
+	type = nla_type(data);
+	mac_len = nla_len(data);
+	if (mac_len != 3) {
+		RTW_ERR("%s oui len error %d != 3\n", __func__, mac_len);
+		return -1;
+	}
+
+	if (type == ANDR_WIFI_ATTRIBUTE_RANDOM_MAC_OUI) {
+		memcpy(pno_random_mac_oui, nla_data(data), 3);
+		print_hex_dump(KERN_DEBUG, "pno_random_mac_oui: ",
+			       DUMP_PREFIX_OFFSET, 16, 1, pno_random_mac_oui,
+			       3, 1);
+
+		if (ETHER_ISMULTI(pno_random_mac_oui)) {
+			pr_err("%s: oui is multicast address\n", __func__);
+			return -1;
+		}
+
+		adapter = wiphy_to_adapter(wiphy);
+		if (adapter == NULL) {
+			pr_err("%s: wiphy_to_adapter == NULL\n", __func__);
+			return -1;
+		}
+
+		pwdev_priv = adapter_wdev_data(adapter);
+
+		memcpy(mac_addr, pno_random_mac_oui, 3);
+		rtw_hal_random_gen_mac_addr(mac_addr);
+		memcpy(pwdev_priv->pno_mac_addr, mac_addr, ETH_ALEN);
+#ifdef CONFIG_RTW_DEBUG
+		print_hex_dump(KERN_DEBUG, "pno_mac_addr: ",
+			       DUMP_PREFIX_OFFSET, 16, 1, pwdev_priv->pno_mac_addr,
+			       ETH_ALEN, 1);
+#endif
+	} else {
+		RTW_ERR("%s oui type error %x != 0x2\n", __func__, type);
+		err = -1;
+	}
+
 
 	return err;
+}
+
 #endif
+
+
+static int rtw_cfgvendor_set_nodfs_flag(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void *data, int len)
+{
+	int err = 0;	
+	int type;
+	u32 nodfs = 0;
+	_adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+
+	RTW_DBG(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
+
+	type = nla_type(data);
+	if (type == ANDR_WIFI_ATTRIBUTE_NODFS_SET) {
+		nodfs = nla_get_u32(data);
+		adapter_to_dvobj(padapter)->nodfs = nodfs;
+	} else {
+		err = -EINVAL;
+	}
+
+	RTW_INFO("%s nodfs=%d, err=%d\n", __func__, nodfs, err);
+	
+	return err;
 }
 
+static int rtw_cfgvendor_set_country(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void  *data, int len)
+{
+#define CNTRY_BUF_SZ	4	/* Country string is 3 bytes + NUL */
+	int err = 0, rem, type;
+	char country_code[CNTRY_BUF_SZ] = {0};
+	const struct nlattr *iter;
+	_adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+
+	RTW_DBG(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
+
+	nla_for_each_attr(iter, data, len, rem) {
+		type = nla_type(iter);
+		switch (type) {
+			case ANDR_WIFI_ATTRIBUTE_COUNTRY:
+				_rtw_memcpy(country_code, nla_data(iter),
+					MIN(nla_len(iter), CNTRY_BUF_SZ));
+				break;
+			default:
+				RTW_ERR("Unknown type: %d\n", type);
+				return -EINVAL;
+		}
+	}
+
+	RTW_INFO("%s country_code:\"%c%c\" \n", __func__, country_code[0], country_code[1]);
+
+	rtw_set_country(padapter, country_code);
+
+	return err;
+}
+
+static int rtw_cfgvendor_set_nd_offload(struct wiphy *wiphy,
+	struct wireless_dev *wdev, const void *data, int len)
+{
+	int err = 0;	
+	int type;
+	u8 nd_en = 0;
+	_adapter *padapter = GET_PRIMARY_ADAPTER(wiphy_to_adapter(wiphy));
+
+	RTW_DBG(FUNC_NDEV_FMT" %s\n", FUNC_NDEV_ARG(wdev_to_ndev(wdev)), (char*)data);
+
+	type = nla_type(data);
+	if (type == ANDR_WIFI_ATTRIBUTE_ND_OFFLOAD_VALUE) {
+		nd_en = nla_get_u8(data);
+		/* ND has been enabled when wow is enabled */
+	} else {
+		err = -EINVAL;
+	}
+
+	RTW_INFO("%s nd_en=%d, err=%d\n", __func__, nd_en, err);
+	
+	return err;
+}
+#endif /* CONFIG_RTW_WIFI_HAL */
+
 static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
-	{
-		{
-			.vendor_id = OUI_BRCM,
-			.subcmd = BRCM_VENDOR_SCMD_PRIV_STR
-		},
-		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_priv_string_handler
-	},
 #if defined(GSCAN_SUPPORT) && 0
 	{
 		{
@@ -1165,7 +1749,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_GET_CAPABILITIES
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_gscan_get_capabilities
+		.doit = rtw_cfgvendor_gscan_get_capabilities
 	},
 	{
 		{
@@ -1173,7 +1757,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_SET_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_set_scan_cfg
+		.doit = rtw_cfgvendor_set_scan_cfg
 	},
 	{
 		{
@@ -1181,7 +1765,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_SET_SCAN_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_set_batch_scan_cfg
+		.doit = rtw_cfgvendor_set_batch_scan_cfg
 	},
 	{
 		{
@@ -1189,7 +1773,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_ENABLE_GSCAN
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_initiate_gscan
+		.doit = rtw_cfgvendor_initiate_gscan
 	},
 	{
 		{
@@ -1197,7 +1781,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_enable_full_scan_result
+		.doit = rtw_cfgvendor_enable_full_scan_result
 	},
 	{
 		{
@@ -1205,7 +1789,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_SET_HOTLIST
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_hotlist_cfg
+		.doit = rtw_cfgvendor_hotlist_cfg
 	},
 	{
 		{
@@ -1213,7 +1797,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_significant_change_cfg
+		.doit = rtw_cfgvendor_significant_change_cfg
 	},
 	{
 		{
@@ -1221,7 +1805,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_GET_SCAN_RESULTS
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_gscan_get_batch_results
+		.doit = rtw_cfgvendor_gscan_get_batch_results
 	},
 	{
 		{
@@ -1229,7 +1813,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = GSCAN_SUBCMD_GET_CHANNEL_LIST
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_gscan_get_channel_list
+		.doit = rtw_cfgvendor_gscan_get_channel_list
 	},
 #endif /* GSCAN_SUPPORT */
 #if defined(RTT_SUPPORT) && 0
@@ -1239,7 +1823,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = RTT_SUBCMD_SET_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_rtt_set_config
+		.doit = rtw_cfgvendor_rtt_set_config
 	},
 	{
 		{
@@ -1247,7 +1831,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = RTT_SUBCMD_CANCEL_CONFIG
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_rtt_cancel_config
+		.doit = rtw_cfgvendor_rtt_cancel_config
 	},
 	{
 		{
@@ -1255,13 +1839,160 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 			.subcmd = RTT_SUBCMD_GETCAPABILITY
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
-		.doit = wl_cfgvendor_rtt_get_capability
+		.doit = rtw_cfgvendor_rtt_get_capability
 	},
 #endif /* RTT_SUPPORT */
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
 	{
 		{
 			.vendor_id = OUI_GOOGLE,
-			.subcmd = ANDR_WIFI_SUBCMD_GET_FEATURE_SET
+			.subcmd = LSTATS_SUBCMD_GET_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_get_info
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LSTATS_SUBCMD_SET_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_set_info
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LSTATS_SUBCMD_CLEAR_INFO
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_lstats_clear_info
+	},
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+        {
+                {
+                        .vendor_id = OUI_GOOGLE,
+                        .subcmd = WIFI_SUBCMD_SET_RSSI_MONITOR
+                },
+                .flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+                .doit = rtw_cfgvendor_set_rssi_monitor
+        },
+#endif /* CONFIG_RTW_CFGVEDNOR_RSSIMONITOR */
+#ifdef CONFIG_RTW_CFGVENDOR_WIFI_LOGGER
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_START_LOGGING
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_start_logging
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_GET_FEATURE
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_get_feature
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_GET_VER
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_get_version
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_GET_RING_STATUS
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_get_ring_status
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_GET_RING_DATA
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_get_ring_data
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_TRIGGER_MEM_DUMP
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_get_firmware_memory_dump
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_START_PKT_FATE_MONITORING
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_start_pkt_fate_monitoring
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_GET_TX_PKT_FATES
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_get_tx_pkt_fates
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = LOGGER_GET_RX_PKT_FATES
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_logger_get_rx_pkt_fates
+	},	
+#endif /* CONFIG_RTW_CFGVENDOR_WIFI_LOGGER */
+#ifdef CONFIG_RTW_WIFI_HAL
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_SET_PNO_RANDOM_MAC_OUI
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_set_rand_mac_oui
+	},
+#endif
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_NODFS_SET
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_set_nodfs_flag
+
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_SET_COUNTRY_CODE
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_set_country
+	},
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_CONFIG_ND_OFFLOAD
+		},
+		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
+		.doit = rtw_cfgvendor_set_nd_offload
+	},
+#endif /* CONFIG_RTW_WIFI_HAL */
+	{
+		{
+			.vendor_id = OUI_GOOGLE,
+			.subcmd = WIFI_SUBCMD_GET_FEATURE_SET
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
 		.doit = rtw_cfgvendor_get_feature_set
@@ -1269,7 +2000,7 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 	{
 		{
 			.vendor_id = OUI_GOOGLE,
-			.subcmd = ANDR_WIFI_SUBCMD_GET_FEATURE_SET_MATRIX
+			.subcmd = WIFI_SUBCMD_GET_FEATURE_SET_MATRIX
 		},
 		.flags = WIPHY_VENDOR_CMD_NEED_WDEV | WIPHY_VENDOR_CMD_NEED_NETDEV,
 		.doit = rtw_cfgvendor_get_feature_set_matrix
@@ -1277,20 +2008,23 @@ static const struct wiphy_vendor_command rtw_vendor_cmds[] = {
 };
 
 static const struct  nl80211_vendor_cmd_info rtw_vendor_events[] = {
-	{ OUI_BRCM, BRCM_VENDOR_EVENT_UNSPEC },
-	{ OUI_BRCM, BRCM_VENDOR_EVENT_PRIV_STR },
 #if defined(GSCAN_SUPPORT) && 0
-	{ OUI_GOOGLE, GOOGLE_GSCAN_SIGNIFICANT_EVENT },
-	{ OUI_GOOGLE, GOOGLE_GSCAN_GEOFENCE_FOUND_EVENT },
-	{ OUI_GOOGLE, GOOGLE_GSCAN_BATCH_SCAN_EVENT },
-	{ OUI_GOOGLE, GOOGLE_SCAN_FULL_RESULTS_EVENT },
+	{ OUI_GOOGLE, GSCAN_EVENT_SIGNIFICANT_CHANGE_RESULTS },
+	{ OUI_GOOGLE, GSCAN_EVENT_HOTLIST_RESULTS_FOUND },
+	{ OUI_GOOGLE, GSCAN_EVENT_SCAN_RESULTS_AVAILABLE },
+	{ OUI_GOOGLE, GSCAN_EVENT_FULL_SCAN_RESULTS },
 #endif /* GSCAN_SUPPORT */
 #if defined(RTT_SUPPORT) && 0
-	{ OUI_GOOGLE, GOOGLE_RTT_COMPLETE_EVENT },
+	{ OUI_GOOGLE, RTT_EVENT_COMPLETE },
 #endif /* RTT_SUPPORT */
+
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+	{ OUI_GOOGLE, GOOGLE_RSSI_MONITOR_EVENT },
+#endif /* RTW_CFGVEDNOR_RSSIMONITR */
+
 #if defined(GSCAN_SUPPORT) && 0
-	{ OUI_GOOGLE, GOOGLE_SCAN_COMPLETE_EVENT },
-	{ OUI_GOOGLE, GOOGLE_GSCAN_GEOFENCE_LOST_EVENT }
+	{ OUI_GOOGLE, GSCAN_EVENT_COMPLETE_SCAN },
+	{ OUI_GOOGLE, GSCAN_EVENT_HOTLIST_RESULTS_LOST }
 #endif /* GSCAN_SUPPORT */
 };
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.h
index 9f36e9fd472e..2f33a5b63e02 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_cfgvendor.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -16,9 +17,7 @@
 #ifndef _RTW_CFGVENDOR_H_
 #define _RTW_CFGVENDOR_H_
 
-#define OUI_BRCM    0x001018
 #define OUI_GOOGLE  0x001A11
-#define BRCM_VENDOR_SUBCMD_PRIV_STR	1
 #define ATTRIBUTE_U32_LEN                  (NLA_HDRLEN  + 4)
 #define VENDOR_ID_OVERHEAD                 ATTRIBUTE_U32_LEN
 #define VENDOR_SUBCMD_OVERHEAD             ATTRIBUTE_U32_LEN
@@ -39,53 +38,106 @@
 				     VENDOR_SUBCMD_OVERHEAD + \
 				     VENDOR_DATA_OVERHEAD)
 typedef enum {
-	/* don't use 0 as a valid subcommand */
-	VENDOR_NL80211_SUBCMD_UNSPECIFIED,
+    /* don't use 0 as a valid subcommand */
+    VENDOR_NL80211_SUBCMD_UNSPECIFIED,
 
-	/* define all vendor startup commands between 0x0 and 0x0FFF */
-	VENDOR_NL80211_SUBCMD_RANGE_START = 0x0001,
-	VENDOR_NL80211_SUBCMD_RANGE_END   = 0x0FFF,
+    /* define all vendor startup commands between 0x0 and 0x0FFF */
+    VENDOR_NL80211_SUBCMD_RANGE_START = 0x0001,
+    VENDOR_NL80211_SUBCMD_RANGE_END   = 0x0FFF,
 
-	/* define all GScan related commands between 0x1000 and 0x10FF */
-	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START = 0x1000,
-	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END   = 0x10FF,
+    /* define all GScan related commands between 0x1000 and 0x10FF */
+    ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START = 0x1000,
+    ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END   = 0x10FF,
 
-	/* define all NearbyDiscovery related commands between 0x1100 and 0x11FF */
-	ANDROID_NL80211_SUBCMD_NBD_RANGE_START = 0x1100,
-	ANDROID_NL80211_SUBCMD_NBD_RANGE_END   = 0x11FF,
+    /* define all NearbyDiscovery related commands between 0x1100 and 0x11FF */
+    ANDROID_NL80211_SUBCMD_NBD_RANGE_START = 0x1100,
+    ANDROID_NL80211_SUBCMD_NBD_RANGE_END   = 0x11FF,
 
-	/* define all RTT related commands between 0x1100 and 0x11FF */
-	ANDROID_NL80211_SUBCMD_RTT_RANGE_START = 0x1100,
-	ANDROID_NL80211_SUBCMD_RTT_RANGE_END   = 0x11FF,
+    /* define all RTT related commands between 0x1100 and 0x11FF */
+    ANDROID_NL80211_SUBCMD_RTT_RANGE_START = 0x1100,
+    ANDROID_NL80211_SUBCMD_RTT_RANGE_END   = 0x11FF,
 
-	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START = 0x1200,
-	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END   = 0x12FF,
+    ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START = 0x1200,
+    ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END   = 0x12FF,
 
-	ANDROID_NL80211_SUBCMD_TDLS_RANGE_START = 0x1300,
-	ANDROID_NL80211_SUBCMD_TDLS_RANGE_END	= 0x13FF,
-	/* This is reserved for future usage */
+    /* define all Logger related commands between 0x1400 and 0x14FF */
+    ANDROID_NL80211_SUBCMD_DEBUG_RANGE_START = 0x1400,
+    ANDROID_NL80211_SUBCMD_DEBUG_RANGE_END   = 0x14FF,
+
+    /* define all wifi offload related commands between 0x1600 and 0x16FF */
+    ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_START = 0x1600,
+    ANDROID_NL80211_SUBCMD_WIFI_OFFLOAD_RANGE_END   = 0x16FF,
+
+    /* define all NAN related commands between 0x1700 and 0x17FF */
+    ANDROID_NL80211_SUBCMD_NAN_RANGE_START = 0x1700,
+    ANDROID_NL80211_SUBCMD_NAN_RANGE_END   = 0x17FF,
+
+    /* define all Android Packet Filter related commands between 0x1800 and 0x18FF */
+    ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START = 0x1800,
+    ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_END   = 0x18FF,
+
+    /* This is reserved for future usage */
 
 } ANDROID_VENDOR_SUB_COMMAND;
 
-enum wl_vendor_subcmd {
-	BRCM_VENDOR_SCMD_UNSPEC,
-	BRCM_VENDOR_SCMD_PRIV_STR,
-	GSCAN_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START,
-	GSCAN_SUBCMD_SET_CONFIG,
-	GSCAN_SUBCMD_SET_SCAN_CONFIG,
-	GSCAN_SUBCMD_ENABLE_GSCAN,
-	GSCAN_SUBCMD_GET_SCAN_RESULTS,
-	GSCAN_SUBCMD_SCAN_RESULTS,
-	GSCAN_SUBCMD_SET_HOTLIST,
-	GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG,
-	GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS,
-	GSCAN_SUBCMD_GET_CHANNEL_LIST,
-	ANDR_WIFI_SUBCMD_GET_FEATURE_SET,
-	ANDR_WIFI_SUBCMD_GET_FEATURE_SET_MATRIX,
+enum rtw_vendor_subcmd {
+    GSCAN_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START,
+
+    GSCAN_SUBCMD_SET_CONFIG,                            /* 0x1001 */
+
+    GSCAN_SUBCMD_SET_SCAN_CONFIG,                       /* 0x1002 */
+    GSCAN_SUBCMD_ENABLE_GSCAN,                          /* 0x1003 */
+    GSCAN_SUBCMD_GET_SCAN_RESULTS,                      /* 0x1004 */
+    GSCAN_SUBCMD_SCAN_RESULTS,                          /* 0x1005 */
+
+    GSCAN_SUBCMD_SET_HOTLIST,                           /* 0x1006 */
+
+    GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG,         /* 0x1007 */
+    GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS,              /* 0x1008 */
+    GSCAN_SUBCMD_GET_CHANNEL_LIST,                       /* 0x1009 */
+
+    WIFI_SUBCMD_GET_FEATURE_SET,                         /* 0x100A */
+    WIFI_SUBCMD_GET_FEATURE_SET_MATRIX,                  /* 0x100B */
+    WIFI_SUBCMD_SET_PNO_RANDOM_MAC_OUI,                  /* 0x100C */
+    WIFI_SUBCMD_NODFS_SET,                               /* 0x100D */
+    WIFI_SUBCMD_SET_COUNTRY_CODE,                             /* 0x100E */
+    /* Add more sub commands here */
+    GSCAN_SUBCMD_SET_EPNO_SSID,                          /* 0x100F */
+
+    WIFI_SUBCMD_SET_SSID_WHITE_LIST,                    /* 0x1010 */
+    WIFI_SUBCMD_SET_ROAM_PARAMS,                        /* 0x1011 */
+    WIFI_SUBCMD_ENABLE_LAZY_ROAM,                       /* 0x1012 */
+    WIFI_SUBCMD_SET_BSSID_PREF,                         /* 0x1013 */
+    WIFI_SUBCMD_SET_BSSID_BLACKLIST,                     /* 0x1014 */
+
+    GSCAN_SUBCMD_ANQPO_CONFIG,                          /* 0x1015 */
+    WIFI_SUBCMD_SET_RSSI_MONITOR,                       /* 0x1016 */
+    WIFI_SUBCMD_CONFIG_ND_OFFLOAD,                      /* 0x1017 */
+    /* Add more sub commands here */
+
+    GSCAN_SUBCMD_MAX,
+
 	RTT_SUBCMD_SET_CONFIG = ANDROID_NL80211_SUBCMD_RTT_RANGE_START,
 	RTT_SUBCMD_CANCEL_CONFIG,
 	RTT_SUBCMD_GETCAPABILITY,
-	/* Add more sub commands here */
+
+    APF_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_PKT_FILTER_RANGE_START,
+    APF_SUBCMD_SET_FILTER,
+    
+    LOGGER_START_LOGGING = ANDROID_NL80211_SUBCMD_DEBUG_RANGE_START,
+    LOGGER_TRIGGER_MEM_DUMP,
+    LOGGER_GET_MEM_DUMP,
+    LOGGER_GET_VER,
+    LOGGER_GET_RING_STATUS,
+    LOGGER_GET_RING_DATA,
+    LOGGER_GET_FEATURE,
+    LOGGER_RESET_LOGGING,
+    LOGGER_TRIGGER_DRIVER_MEM_DUMP,
+    LOGGER_GET_DRIVER_MEM_DUMP,
+    LOGGER_START_PKT_FATE_MONITORING,
+    LOGGER_GET_TX_PKT_FATES,
+    LOGGER_GET_RX_PKT_FATES,
+
 	VENDOR_SUBCMD_MAX
 };
 
@@ -164,6 +216,13 @@ enum gscan_ch_attributes {
 	GSCAN_ATTRIBUTE_CH_ID_7
 };
 
+enum wifi_rssi_monitor_attr {
+        RSSI_MONITOR_ATTRIBUTE_MAX_RSSI,
+        RSSI_MONITOR_ATTRIBUTE_MIN_RSSI,
+        RSSI_MONITOR_ATTRIBUTE_START,
+};
+
+
 enum rtt_attributes {
 	RTT_ATTRIBUTE_TARGET_CNT,
 	RTT_ATTRIBUTE_TARGET_INFO,
@@ -178,24 +237,49 @@ enum rtt_attributes {
 	RTT_ATTRIBUTE_TARGET_NUM_RETRY
 };
 
-typedef enum wl_vendor_event {
-	BRCM_VENDOR_EVENT_UNSPEC,
-	BRCM_VENDOR_EVENT_PRIV_STR,
-	GOOGLE_GSCAN_SIGNIFICANT_EVENT,
-	GOOGLE_GSCAN_GEOFENCE_FOUND_EVENT,
-	GOOGLE_GSCAN_BATCH_SCAN_EVENT,
-	GOOGLE_SCAN_FULL_RESULTS_EVENT,
-	GOOGLE_RTT_COMPLETE_EVENT,
-	GOOGLE_SCAN_COMPLETE_EVENT,
-	GOOGLE_GSCAN_GEOFENCE_LOST_EVENT
-} wl_vendor_event_t;
+enum logger_attributes {
+	LOGGER_ATTRIBUTE_GET_DRIVER,
+	LOGGER_ATTRIBUTE_GET_FW,
+	LOGGER_ATTRIBUTE_RING_ID,
+	LOGGER_ATTRIBUTE_RING_NAME,
+	LOGGER_ATTRIBUTE_RING_FLAGS,
+	LOGGER_ATTRIBUTE_LOG_LEVEL,
+	LOGGER_ATTRIBUTE_LOG_TIME_INTVAL,
+	LOGGER_ATTRIBUTE_LOG_MIN_DATA_SIZE,
+	LOGGER_ATTRIBUTE_FW_DUMP_LEN,
+	LOGGER_ATTRIBUTE_FW_DUMP_DATA,
+	LOGGERG_ATTRIBUTE_RING_DATA,
+	LOGGER_ATTRIBUTE_RING_STATUS,
+	LOGGER_ATTRIBUTE_RING_NUM
+};
+typedef enum rtw_vendor_event {
+    RTK_RESERVED1,
+    RTK_RESERVED2,
+    GSCAN_EVENT_SIGNIFICANT_CHANGE_RESULTS ,
+    GSCAN_EVENT_HOTLIST_RESULTS_FOUND,
+    GSCAN_EVENT_SCAN_RESULTS_AVAILABLE,
+    GSCAN_EVENT_FULL_SCAN_RESULTS,
+    RTT_EVENT_COMPLETE,
+    GSCAN_EVENT_COMPLETE_SCAN,
+    GSCAN_EVENT_HOTLIST_RESULTS_LOST,
+    GSCAN_EVENT_EPNO_EVENT,
+    GOOGLE_DEBUG_RING_EVENT,
+    GOOGLE_DEBUG_MEM_DUMP_EVENT,
+    GSCAN_EVENT_ANQPO_HOTSPOT_MATCH,
+    GOOGLE_RSSI_MONITOR_EVENT
+} rtw_vendor_event_t;
 
 enum andr_wifi_feature_set_attr {
 	ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET,
-	ANDR_WIFI_ATTRIBUTE_FEATURE_SET
+	ANDR_WIFI_ATTRIBUTE_FEATURE_SET,
+	ANDR_WIFI_ATTRIBUTE_RANDOM_MAC_OUI,
+	ANDR_WIFI_ATTRIBUTE_NODFS_SET,
+	ANDR_WIFI_ATTRIBUTE_COUNTRY,
+	ANDR_WIFI_ATTRIBUTE_ND_OFFLOAD_VALUE
+	// Add more attribute here
 };
 
-typedef enum wl_vendor_gscan_attribute {
+typedef enum rtw_vendor_gscan_attribute {
 	ATTR_START_GSCAN,
 	ATTR_STOP_GSCAN,
 	ATTR_SET_SCAN_BATCH_CFG_ID, /* set batch scan params */
@@ -205,7 +289,7 @@ typedef enum wl_vendor_gscan_attribute {
 	ATTR_GET_GSCAN_CAPABILITIES_ID,
 	/* Add more sub commands here */
 	ATTR_GSCAN_MAX
-} wl_vendor_gscan_attribute_t;
+} rtw_vendor_gscan_attribute_t;
 
 typedef enum gscan_batch_attribute {
 	ATTR_GSCAN_BATCH_BESTN,
@@ -222,9 +306,309 @@ typedef enum gscan_complete_event {
 	WIFI_SCAN_BUFFER_FULL,
 	WIFI_SCAN_COMPLETE
 } gscan_complete_event_t;
+/* wifi_hal.h */
+/* WiFi Common definitions */
+typedef unsigned char byte;
+typedef int wifi_request_id;
+typedef int wifi_channel;                       // indicates channel frequency in MHz
+typedef int wifi_rssi;
+typedef byte mac_addr[6];
+typedef byte oui[3];
+typedef int64_t wifi_timestamp;                 // In microseconds (us)
+typedef int64_t wifi_timespan;                  // In picoseconds  (ps)
+
+struct wifi_info;
+struct wifi_interface_info;
+typedef struct wifi_info *wifi_handle;
+typedef struct wifi_interface_info *wifi_interface_handle;
+
+/* channel operating width */
+typedef enum {
+    WIFI_CHAN_WIDTH_20    = 0,
+    WIFI_CHAN_WIDTH_40    = 1,
+    WIFI_CHAN_WIDTH_80    = 2,
+    WIFI_CHAN_WIDTH_160   = 3,
+    WIFI_CHAN_WIDTH_80P80 = 4,
+    WIFI_CHAN_WIDTH_5     = 5,
+    WIFI_CHAN_WIDTH_10    = 6,
+    WIFI_CHAN_WIDTH_INVALID = -1
+} wifi_channel_width;
+
+typedef int wifi_radio;
+
+typedef struct {
+    wifi_channel_width width;
+    int center_frequency0;
+    int center_frequency1;
+    int primary_frequency;
+} wifi_channel_spec;
+
+typedef enum {
+    WIFI_SUCCESS = 0,
+    WIFI_ERROR_NONE = 0,
+    WIFI_ERROR_UNKNOWN = -1,
+    WIFI_ERROR_UNINITIALIZED = -2,
+    WIFI_ERROR_NOT_SUPPORTED = -3,
+    WIFI_ERROR_NOT_AVAILABLE = -4,              // Not available right now, but try later
+    WIFI_ERROR_INVALID_ARGS = -5,
+    WIFI_ERROR_INVALID_REQUEST_ID = -6,
+    WIFI_ERROR_TIMED_OUT = -7,
+    WIFI_ERROR_TOO_MANY_REQUESTS = -8,          // Too many instances of this request
+    WIFI_ERROR_OUT_OF_MEMORY = -9,
+    WIFI_ERROR_BUSY = -10,
+} wifi_error;
+
+typedef int wifi_ring_buffer_id;
+/* ring buffer params */
+/**
+ * written_bytes and read_bytes implement a producer consumer API
+ *     hence written_bytes >= read_bytes
+ * a modulo arithmetic of the buffer size has to be applied to those counters:
+ * actual offset into ring buffer = written_bytes % ring_buffer_byte_size
+ *
+ */
+typedef struct {
+    u8 name[32];
+    u32 flags;
+    wifi_ring_buffer_id ring_id; // unique integer representing the ring
+    u32 ring_buffer_byte_size;   // total memory size allocated for the buffer
+    u32 verbose_level;           // verbose level for ring buffer
+    u32 written_bytes;           // number of bytes that was written to the buffer by driver,
+                                 // monotonously increasing integer
+    u32 read_bytes;              // number of bytes that was read from the buffer by user land,
+                                 // monotonously increasing integer
+    u32 written_records;         // number of records that was written to the buffer by driver,
+                                 // monotonously increasing integer
+} wifi_ring_buffer_status;
+
+#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
+#define STATS_MAJOR_VERSION      1
+#define STATS_MINOR_VERSION      0
+#define STATS_MICRO_VERSION      0
+
+typedef enum {
+    WIFI_DISCONNECTED = 0,
+    WIFI_AUTHENTICATING = 1,
+    WIFI_ASSOCIATING = 2,
+    WIFI_ASSOCIATED = 3,
+    WIFI_EAPOL_STARTED = 4,   // if done by firmware/driver
+    WIFI_EAPOL_COMPLETED = 5, // if done by firmware/driver
+} wifi_connection_state;
+
+typedef enum {
+    WIFI_ROAMING_IDLE = 0,
+    WIFI_ROAMING_ACTIVE = 1,
+} wifi_roam_state;
+
+typedef enum {
+    WIFI_INTERFACE_STA = 0,
+    WIFI_INTERFACE_SOFTAP = 1,
+    WIFI_INTERFACE_IBSS = 2,
+    WIFI_INTERFACE_P2P_CLIENT = 3,
+    WIFI_INTERFACE_P2P_GO = 4,
+    WIFI_INTERFACE_NAN = 5,
+    WIFI_INTERFACE_MESH = 6,
+    WIFI_INTERFACE_UNKNOWN = -1
+ } wifi_interface_mode;
+
+#define WIFI_CAPABILITY_QOS          0x00000001     // set for QOS association
+#define WIFI_CAPABILITY_PROTECTED    0x00000002     // set for protected association (802.11 beacon frame control protected bit set)
+#define WIFI_CAPABILITY_INTERWORKING 0x00000004     // set if 802.11 Extended Capabilities element interworking bit is set
+#define WIFI_CAPABILITY_HS20         0x00000008     // set for HS20 association
+#define WIFI_CAPABILITY_SSID_UTF8    0x00000010     // set is 802.11 Extended Capabilities element UTF-8 SSID bit is set
+#define WIFI_CAPABILITY_COUNTRY      0x00000020     // set is 802.11 Country Element is present
+
+typedef struct {
+   wifi_interface_mode mode;     // interface mode
+   u8 mac_addr[6];               // interface mac address (self)
+   wifi_connection_state state;  // connection state (valid for STA, CLI only)
+   wifi_roam_state roaming;      // roaming state
+   u32 capabilities;             // WIFI_CAPABILITY_XXX (self)
+   u8 ssid[33];                  // null terminated SSID
+   u8 bssid[6];                  // bssid
+   u8 ap_country_str[3];         // country string advertised by AP
+   u8 country_str[3];            // country string for this association
+} wifi_interface_link_layer_info;
+
+/* channel information */
+typedef struct {
+   wifi_channel_width width;   // channel width (20, 40, 80, 80+80, 160)
+   wifi_channel center_freq;   // primary 20 MHz channel
+   wifi_channel center_freq0;  // center frequency (MHz) first segment
+   wifi_channel center_freq1;  // center frequency (MHz) second segment
+} wifi_channel_info;
+
+/* wifi rate */
+typedef struct {
+   u32 preamble   :3;   // 0: OFDM, 1:CCK, 2:HT 3:VHT 4..7 reserved
+   u32 nss        :2;   // 0:1x1, 1:2x2, 3:3x3, 4:4x4
+   u32 bw         :3;   // 0:20MHz, 1:40Mhz, 2:80Mhz, 3:160Mhz
+   u32 rateMcsIdx :8;   // OFDM/CCK rate code would be as per ieee std in the units of 0.5mbps
+                        // HT/VHT it would be mcs index
+   u32 reserved  :16;   // reserved
+   u32 bitrate;         // units of 100 Kbps
+} wifi_rate;
+
+/* channel statistics */
+typedef struct {
+   wifi_channel_info channel;  // channel
+   u32 on_time;                // msecs the radio is awake (32 bits number accruing over time)
+   u32 cca_busy_time;          // msecs the CCA register is busy (32 bits number accruing over time)
+} wifi_channel_stat;
+
+// Max number of tx power levels. The actual number vary per device and is specified by |num_tx_levels|
+#define RADIO_STAT_MAX_TX_LEVELS 256
+
+/* Internal radio statistics structure in the driver */
+typedef struct {
+   wifi_radio radio;                      // wifi radio (if multiple radio supported)
+   u32 on_time;                           // msecs the radio is awake (32 bits number accruing over time)
+   u32 tx_time;                           // msecs the radio is transmitting (32 bits number accruing over time)
+   u32 rx_time;                           // msecs the radio is in active receive (32 bits number accruing over time)
+   u32 on_time_scan;                      // msecs the radio is awake due to all scan (32 bits number accruing over time)
+   u32 on_time_nbd;                       // msecs the radio is awake due to NAN (32 bits number accruing over time)
+   u32 on_time_gscan;                     // msecs the radio is awake due to G?scan (32 bits number accruing over time)
+   u32 on_time_roam_scan;                 // msecs the radio is awake due to roam?scan (32 bits number accruing over time)
+   u32 on_time_pno_scan;                  // msecs the radio is awake due to PNO scan (32 bits number accruing over time)
+   u32 on_time_hs20;                      // msecs the radio is awake due to HS2.0 scans and GAS exchange (32 bits number accruing over time)
+   u32 num_channels;                      // number of channels
+   wifi_channel_stat channels[];          // channel statistics
+} wifi_radio_stat_internal;
+
+/**
+ * Packet statistics reporting by firmware is performed on MPDU basi (i.e. counters increase by 1 for each MPDU)
+ * As well, "data packet" in associated comments, shall be interpreted as 802.11 data packet,
+ * that is, 802.11 frame control subtype == 2 and excluding management and control frames.
+ *
+ * As an example, in the case of transmission of an MSDU fragmented in 16 MPDUs which are transmitted
+ * OTA in a 16 units long a-mpdu, for which a block ack is received with 5 bits set:
+ *          tx_mpdu : shall increase by 5
+ *          retries : shall increase by 16
+ *          tx_ampdu : shall increase by 1
+ * data packet counters shall not increase regardless of the number of BAR potentially sent by device for this a-mpdu
+ * data packet counters shall not increase regardless of the number of BA received by device for this a-mpdu
+ *
+ * For each subsequent retransmission of the 11 remaining non ACK'ed mpdus
+ * (regardless of the fact that they are transmitted in a-mpdu or not)
+ *          retries : shall increase by 1
+ *
+ * If no subsequent BA or ACK are received from AP, until packet lifetime expires for those 11 packet that were not ACK'ed
+ *          mpdu_lost : shall increase by 11
+ */
+
+/* per rate statistics */
+typedef struct {
+   wifi_rate rate;     // rate information
+   u32 tx_mpdu;        // number of successfully transmitted data pkts (ACK rcvd)
+   u32 rx_mpdu;        // number of received data pkts
+   u32 mpdu_lost;      // number of data packet losses (no ACK)
+   u32 retries;        // total number of data pkt retries
+   u32 retries_short;  // number of short data pkt retries
+   u32 retries_long;   // number of long data pkt retries
+} wifi_rate_stat;
+
+/* access categories */
+typedef enum {
+   WIFI_AC_VO  = 0,
+   WIFI_AC_VI  = 1,
+   WIFI_AC_BE  = 2,
+   WIFI_AC_BK  = 3,
+   WIFI_AC_MAX = 4,
+} wifi_traffic_ac;
+
+/* wifi peer type */
+typedef enum
+{
+   WIFI_PEER_STA,
+   WIFI_PEER_AP,
+   WIFI_PEER_P2P_GO,
+   WIFI_PEER_P2P_CLIENT,
+   WIFI_PEER_NAN,
+   WIFI_PEER_TDLS,
+   WIFI_PEER_INVALID,
+} wifi_peer_type;
+
+/* per peer statistics */
+typedef struct {
+   wifi_peer_type type;           // peer type (AP, TDLS, GO etc.)
+   u8 peer_mac_address[6];        // mac address
+   u32 capabilities;              // peer WIFI_CAPABILITY_XXX
+   u32 num_rate;                  // number of rates
+   wifi_rate_stat rate_stats[];   // per rate statistics, number of entries  = num_rate
+} wifi_peer_info;
+
+/* Per access category statistics */
+typedef struct {
+   wifi_traffic_ac ac;             // access category (VI, VO, BE, BK)
+   u32 tx_mpdu;                    // number of successfully transmitted unicast data pkts (ACK rcvd)
+   u32 rx_mpdu;                    // number of received unicast data packets
+   u32 tx_mcast;                   // number of succesfully transmitted multicast data packets
+                                   // STA case: implies ACK received from AP for the unicast packet in which mcast pkt was sent
+   u32 rx_mcast;                   // number of received multicast data packets
+   u32 rx_ampdu;                   // number of received unicast a-mpdus; support of this counter is optional
+   u32 tx_ampdu;                   // number of transmitted unicast a-mpdus; support of this counter is optional
+   u32 mpdu_lost;                  // number of data pkt losses (no ACK)
+   u32 retries;                    // total number of data pkt retries
+   u32 retries_short;              // number of short data pkt retries
+   u32 retries_long;               // number of long data pkt retries
+   u32 contention_time_min;        // data pkt min contention time (usecs)
+   u32 contention_time_max;        // data pkt max contention time (usecs)
+   u32 contention_time_avg;        // data pkt avg contention time (usecs)
+   u32 contention_num_samples;     // num of data pkts used for contention statistics
+} wifi_wmm_ac_stat;
+
+/* interface statistics */
+typedef struct {
+   wifi_interface_handle iface;          // wifi interface
+   wifi_interface_link_layer_info info;  // current state of the interface
+   u32 beacon_rx;                        // access point beacon received count from connected AP
+   u64 average_tsf_offset;               // average beacon offset encountered (beacon_TSF - TBTT)
+                                         // The average_tsf_offset field is used so as to calculate the
+                                         // typical beacon contention time on the channel as well may be
+                                         // used to debug beacon synchronization and related power consumption issue
+   u32 leaky_ap_detected;                // indicate that this AP typically leaks packets beyond the driver guard time.
+   u32 leaky_ap_avg_num_frames_leaked;  // average number of frame leaked by AP after frame with PM bit set was ACK'ed by AP
+   u32 leaky_ap_guard_time;              // guard time currently in force (when implementing IEEE power management based on
+                                         // frame control PM bit), How long driver waits before shutting down the radio and
+                                         // after receiving an ACK for a data frame with PM bit set)
+   u32 mgmt_rx;                          // access point mgmt frames received count from connected AP (including Beacon)
+   u32 mgmt_action_rx;                   // action frames received count
+   u32 mgmt_action_tx;                   // action frames transmit count
+   wifi_rssi rssi_mgmt;                  // access Point Beacon and Management frames RSSI (averaged)
+   wifi_rssi rssi_data;                  // access Point Data Frames RSSI (averaged) from connected AP
+   wifi_rssi rssi_ack;                   // access Point ACK RSSI (averaged) from connected AP
+   wifi_wmm_ac_stat ac[WIFI_AC_MAX];     // per ac data packet statistics
+   u32 num_peers;                        // number of peers
+   wifi_peer_info peer_info[];           // per peer statistics
+} wifi_iface_stat;
+
+/* configuration params */
+typedef struct {
+   u32 mpdu_size_threshold;             // threshold to classify the pkts as short or long
+                                        // packet size < mpdu_size_threshold => short
+   u32 aggressive_statistics_gathering; // set for field debug mode. Driver should collect all statistics regardless of performance impact.
+} wifi_link_layer_params;
+
+#define RSSI_MONITOR_EVT_VERSION   1
+typedef struct {
+    u8 version;
+    s8 cur_rssi;
+    mac_addr BSSID;
+} rssi_monitor_evt;
+
+
+/* wifi statistics bitmap  */
+#define WIFI_STATS_RADIO              0x00000001      // all radio statistics
+#define WIFI_STATS_RADIO_CCA          0x00000002      // cca_busy_time (within radio statistics)
+#define WIFI_STATS_RADIO_CHANNELS     0x00000004      // all channel statistics (within radio statistics)
+#define WIFI_STATS_RADIO_SCAN         0x00000008      // all scan statistics (within radio statistics)
+#define WIFI_STATS_IFACE              0x00000010      // all interface statistics
+#define WIFI_STATS_IFACE_TXRATE       0x00000020      // all tx rate statistics (within interface statistics)
+#define WIFI_STATS_IFACE_AC           0x00000040      // all ac statistics (within interface statistics)
+#define WIFI_STATS_IFACE_CONTENTION   0x00000080      // all contention (min, max, avg) statistics (within ac statisctics)
+
+#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
 
-/* Capture the BRCM_VENDOR_SUBCMD_PRIV_STRINGS* here */
-#define BRCM_VENDOR_SCMD_CAPA	"cap"
 
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT)
 extern int rtw_cfgvendor_attach(struct wiphy *wiphy);
@@ -232,9 +616,19 @@ extern int rtw_cfgvendor_detach(struct wiphy *wiphy);
 extern int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,
 	struct net_device *dev, int event_id, const void  *data, int len);
 #if defined(GSCAN_SUPPORT) && 0
-extern int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
-	struct net_device *dev, void  *data, int len, wl_vendor_event_t event);
+extern int rtw_cfgvendor_send_hotlist_event(struct wiphy *wiphy,
+	struct net_device *dev, void  *data, int len, rtw_vendor_event_t event);
 #endif
 #endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) || defined(RTW_VENDOR_EXT_SUPPORT) */
 
+#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
+void rtw_cfgvendor_rssi_monitor_evt(_adapter *padapter);
+#endif
+
+#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
+void rtw_hal_pno_random_gen_mac_addr(PADAPTER adapter);
+void rtw_hal_set_hw_mac_addr(PADAPTER adapter, u8 *mac_addr);
+#endif
+
+
 #endif /* _RTW_CFGVENDOR_H_ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.c
index 4fa6ef4d4994..3dab9bf1b219 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -120,7 +121,8 @@ static ssize_t proc_set_log_level(struct file *file, const char __user *buffer,
 
 		int num = sscanf(tmp, "%d ", &log_level);
 
-		if (log_level >= _DRV_NONE_ && log_level <= _DRV_MAX_) {
+		if (num == 1 &&
+		    log_level >= _DRV_NONE_ && log_level <= _DRV_MAX_) {
 			rtw_drv_log_level = log_level;
 			printk("rtw_drv_log_level:%d\n", rtw_drv_log_level);
 		}
@@ -159,6 +161,12 @@ static int proc_get_chplan_test(struct seq_file *m, void *v)
 	return 0;
 }
 
+static int proc_get_chplan_ver(struct seq_file *m, void *v)
+{
+	dump_chplan_ver(m);
+	return 0;
+}
+
 #ifdef RTW_HALMAC
 extern void rtw_halmac_get_version(char *str, u32 len);
 
@@ -188,6 +196,7 @@ const struct rtw_proc_hdl drv_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("country_chplan_map", proc_get_country_chplan_map, NULL),
 	RTW_PROC_HDL_SSEQ("chplan_id_list", proc_get_chplan_id_list, NULL),
 	RTW_PROC_HDL_SSEQ("chplan_test", proc_get_chplan_test, NULL),
+	RTW_PROC_HDL_SSEQ("chplan_ver", proc_get_chplan_ver, NULL),
 #ifdef RTW_HALMAC
 	RTW_PROC_HDL_SSEQ("halmac_info", proc_get_halmac_info, NULL),
 #endif /* RTW_HALMAC */
@@ -441,6 +450,93 @@ static int proc_get_rf_reg_dump(struct seq_file *m, void *v)
 	return 0;
 }
 
+#ifdef CONFIG_RTW_LED
+int proc_get_led_config(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_led_config(m, adapter);
+
+	return 0;
+}
+
+ssize_t proc_set_led_config(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	char tmp[32];
+	u8 strategy;
+	u8 iface_en_mask;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhx", &strategy, &iface_en_mask);
+
+		if (num >= 1)
+			rtw_led_set_strategy(adapter, strategy);
+		if (num >= 2)
+			rtw_led_set_iface_en_mask(adapter, iface_en_mask);
+	}
+
+	return count;
+}
+#endif /* CONFIG_RTW_LED */
+
+#ifdef CONFIG_AP_MODE
+int proc_get_aid_status(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_aid_status(m, adapter);
+
+	return 0;
+}
+
+ssize_t proc_set_aid_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct sta_priv *stapriv = &adapter->stapriv;
+
+	char tmp[32];
+	u8 rr;
+	u16 started_aid;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hu", &rr, &started_aid);
+
+		if (num >= 1)
+			stapriv->rr_aid = rr ? 1 : 0;
+		if (num >= 2) {
+			started_aid = started_aid % (stapriv->max_aid + 1);
+			stapriv->started_aid = started_aid ? started_aid : 1;
+		}
+	}
+
+	return count;
+}
+#endif /* CONFIG_AP_MODE */
+
 static int proc_get_dump_tx_rate_bmp(struct seq_file *m, void *v)
 {
 	struct net_device *dev = m->private;
@@ -483,6 +579,130 @@ exit:
 }
 #endif /* CONFIG_RTW_CUSTOMER_STR */
 
+#ifdef CONFIG_SCAN_BACKOP
+static int proc_get_backop_flags_sta(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_sta(mlmeext));
+
+	return 0;
+}
+
+static ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	char tmp[32];
+	u8 flags;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &flags);
+
+		if (num == 1)
+			mlmeext_assign_scan_backop_flags_sta(mlmeext, flags);
+	}
+
+	return count;
+}
+
+#ifdef CONFIG_AP_MODE
+static int proc_get_backop_flags_ap(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_ap(mlmeext));
+
+	return 0;
+}
+
+static ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	char tmp[32];
+	u8 flags;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &flags);
+
+		if (num == 1)
+			mlmeext_assign_scan_backop_flags_ap(mlmeext, flags);
+	}
+
+	return count;
+}
+#endif /* CONFIG_AP_MODE */
+
+#ifdef CONFIG_RTW_MESH
+static int proc_get_backop_flags_mesh(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	RTW_PRINT_SEL(m, "0x%02x\n", mlmeext_scan_backop_flags_mesh(mlmeext));
+
+	return 0;
+}
+
+static ssize_t proc_set_backop_flags_mesh(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
+
+	char tmp[32];
+	u8 flags;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhx", &flags);
+
+		if (num == 1)
+			mlmeext_assign_scan_backop_flags_mesh(mlmeext, flags);
+	}
+
+	return count;
+}
+#endif /* CONFIG_RTW_MESH */
+
+#endif /* CONFIG_SCAN_BACKOP */
+
 /* gpio setting */
 #ifdef CONFIG_GPIO_API
 static ssize_t proc_set_config_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
@@ -600,7 +820,8 @@ static ssize_t proc_set_rx_info_msg(struct file *file, const char __user *buffer
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 		int num = sscanf(tmp, "%d", &phy_info_flag);
 
-		precvpriv->store_law_data_flag = (BOOLEAN) phy_info_flag;
+		if (num == 1)
+			precvpriv->store_law_data_flag = (BOOLEAN) phy_info_flag;
 
 		/*RTW_INFO("precvpriv->store_law_data_flag = %d\n",( BOOLEAN )(precvpriv->store_law_data_flag));*/
 	}
@@ -619,11 +840,9 @@ static int proc_get_tx_info_msg(struct seq_file *m, void *v)
 	_irqL irqL;
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
-	struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
 	struct sta_info *psta;
-	u8 bc_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-	u8 null_addr[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
+	u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+	u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	struct sta_priv *pstapriv = &padapter->stapriv;
 	int i;
@@ -653,9 +872,9 @@ static int proc_get_tx_info_msg(struct seq_file *m, void *v)
 
 			plist = get_next(plist);
 
-			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6)  !=  _TRUE)
-				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) != _TRUE)
-				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), 6) != _TRUE)) {
+			if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN)  !=  _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
+				&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), ETH_ALEN) != _TRUE)) {
 
 				switch (psta->cmn.bw_mode) {
 
@@ -810,8 +1029,21 @@ static int proc_get_turboedca_ctrl(struct seq_file *m, void *v)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
 
-	if (hal_data)
-		RTW_PRINT_SEL(m, "Turbo-EDCA :%s\n", (hal_data->dis_turboedca) ? "Disable" : "Enable");
+	if (hal_data) {
+
+		u32 edca_param;
+
+		if (hal_data->dis_turboedca == 0)
+			RTW_PRINT_SEL(m, "Turbo-EDCA : %s\n", "Enable"); 
+		else 		
+			RTW_PRINT_SEL(m, "Turbo-EDCA : %s, mode=%d, edca_param_mode=0x%x\n", "Disable", hal_data->dis_turboedca, hal_data->edca_param_mode);
+
+
+		rtw_hal_get_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&edca_param));
+
+		_RTW_PRINT_SEL(m, "PARAM_BE:0x%x\n", edca_param);
+		
+	}
 
 	return 0;
 }
@@ -821,9 +1053,9 @@ static ssize_t proc_set_turboedca_ctrl(struct file *file, const char __user *buf
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
-
 	char tmp[32] = {0};
 	int mode = 0, num = 0;
+	u32 param_mode = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -833,15 +1065,38 @@ static ssize_t proc_set_turboedca_ctrl(struct file *file, const char __user *buf
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		num	= sscanf(tmp, "%d ", &mode);
+		num = sscanf(tmp, "%d %x", &mode, &param_mode);
 
-		if (num != 1) {
+		if (num < 1 || num > 2) {
 			RTW_INFO("argument number is wrong\n");
 			return -EFAULT;
 		}
+
+		/*  0: enable turboedca,
+			1: disable turboedca, 
+			2: disable turboedca and setting EDCA parameter based on the input parameter
+			> 2 : currently reset to 0 */ 
+			
+		if (mode > 2) 
+			mode = 0;
+
 		hal_data->dis_turboedca = mode;
+		
+		hal_data->edca_param_mode = 0; /* init. value */
+
+		RTW_INFO("dis_turboedca mode = 0x%x\n", hal_data->dis_turboedca);
+		
+		if (num == 2) {
+
+			hal_data->edca_param_mode = param_mode;			
+
+			RTW_INFO("param_mode = 0x%x\n", param_mode);
+		}
+		
 	}
+	
 	return count;
+
 }
 #ifdef CONFIG_WOWLAN
 static int proc_get_wow_lps_ctrl(struct seq_file *m, void *v)
@@ -911,7 +1166,7 @@ static int proc_get_chan_plan(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	dump_cur_chset(m, adapter);
+	dump_cur_chset(m, adapter_to_rfctl(adapter));
 
 	return 0;
 }
@@ -1004,12 +1259,26 @@ ssize_t proc_set_macaddr_acl(struct file *file, const char __user *buffer, size_
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *mlme = &adapter->mlmepriv;
-	struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
 	char tmp[17 * NUM_ACL + 32] = {0};
+	u8 period;
+	char cmd[32];
 	u8 mode;
 	u8 addr[ETH_ALEN];
 
+#define MAC_ACL_CMD_MODE	0
+#define MAC_ACL_CMD_ADD		1
+#define MAC_ACL_CMD_DEL		2
+#define MAC_ACL_CMD_CLR		3
+#define MAC_ACL_CMD_NUM		4
+	
+	static const char * const mac_acl_cmd_str[] = {
+		"mode",
+		"add",
+		"del",
+		"clr",
+	};
+	u8 cmd_id = MAC_ACL_CMD_NUM;
+
 	if (count < 1)
 		return -EFAULT;
 
@@ -1019,36 +1288,93 @@ ssize_t proc_set_macaddr_acl(struct file *file, const char __user *buffer, size_
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		/* mode [<macaddr>] */
+		/*
+		* <period> mode <mode> <macaddr> [<macaddr>]
+		* <period> mode <mode>
+		* <period> add <macaddr> [<macaddr>]
+		* <period> del <macaddr> [<macaddr>]
+		* <period> clr
+		*/
 		char *c, *next;
+		int i;
+		u8 is_bcast;
 
 		next = tmp;
 		c = strsep(&next, " \t");
+		if (!c || sscanf(c, "%hhu", &period) != 1)
+			goto exit;
+
+		if (period >= RTW_ACL_PERIOD_NUM) {
+			RTW_WARN(FUNC_ADPT_FMT" invalid period:%u", FUNC_ADPT_ARG(adapter), period);
+			goto exit;
+		}
+
+		c = strsep(&next, " \t");
+		if (!c || sscanf(c, "%s", cmd) != 1)
+			goto exit;
 
-		if (sscanf(c, "%hhu", &mode) != 1)
-			return count;
+		for (i = 0; i < MAC_ACL_CMD_NUM; i++)
+			if (strcmp(mac_acl_cmd_str[i], cmd) == 0)
+				cmd_id = i;
 
-		if (mode >= RTW_ACL_MODE_MAX)
-			mode = RTW_ACL_MODE_DISABLED;
+		switch (cmd_id) {
+		case MAC_ACL_CMD_MODE:
+			c = strsep(&next, " \t");
+			if (!c || sscanf(c, "%hhu", &mode) != 1)
+				goto exit;
 
-		rtw_set_macaddr_acl(adapter, RTW_ACL_MODE_DISABLED); /* deinit first */
-		if (mode == RTW_ACL_MODE_DISABLED)
-			return count;
+			if (mode >= RTW_ACL_MODE_MAX) {
+				RTW_WARN(FUNC_ADPT_FMT" invalid mode:%u", FUNC_ADPT_ARG(adapter), mode);
+				goto exit;
+			}
+			break;
 
-		rtw_set_macaddr_acl(adapter, mode);
+		case MAC_ACL_CMD_ADD:
+		case MAC_ACL_CMD_DEL:
+			break;
 
-		/* macaddr list */
+		case MAC_ACL_CMD_CLR:
+			/* clear settings */
+			rtw_macaddr_acl_clear(adapter, period);
+			goto exit;
+
+		default:
+			RTW_WARN(FUNC_ADPT_FMT" invalid cmd:\"%s\"", FUNC_ADPT_ARG(adapter), cmd);
+			goto exit;
+		}
+
+		/* check for macaddr list */
 		c = strsep(&next, " \t");
+		if (!c && cmd_id == MAC_ACL_CMD_MODE) {
+			/* set mode only  */
+			rtw_set_macaddr_acl(adapter, period, mode);
+			goto exit;
+		}
+
+		if (cmd_id == MAC_ACL_CMD_MODE) {
+			/* set mode and entire macaddr list */
+			rtw_macaddr_acl_clear(adapter, period);
+			rtw_set_macaddr_acl(adapter, period, mode);
+		}
+
 		while (c != NULL) {
 			if (sscanf(c, MAC_SFMT, MAC_SARG(addr)) != 6)
 				break;
 
-			if (rtw_check_invalid_mac_address(addr, 0) == _FALSE)
-				rtw_acl_add_sta(adapter, addr);
-
+			is_bcast = is_broadcast_mac_addr(addr);
+			if (is_bcast
+				|| rtw_check_invalid_mac_address(addr, 0) == _FALSE
+			) {
+				if (cmd_id == MAC_ACL_CMD_DEL) {
+					rtw_acl_remove_sta(adapter, period, addr);
+					if (is_bcast)
+						break;
+				 } else if (!is_bcast)
+					rtw_acl_add_sta(adapter, period, addr);
+			}
+		
 			c = strsep(&next, " \t");
 		}
-
 	}
 
 exit:
@@ -1144,15 +1470,27 @@ exit:
 }
 #endif /* CONFIG_RTW_PRE_LINK_STA */
 
-#ifdef CONFIG_DFS_MASTER
-ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+static int proc_get_ch_sel_policy(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "%-16s\n", "same_band_prefer");
+
+	RTW_PRINT_SEL(m, "%16u\n", rfctl->ch_sel_same_band_prefer);
+
+	return 0;
+}
+
+static ssize_t proc_set_ch_sel_policy(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
 	char tmp[32];
-	u8 ch, bw = CHANNEL_WIDTH_20, offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-	int ms = -1;
+	u8 sb_prefer;
+	int num;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1162,31 +1500,104 @@ ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, si
 		return -EFAULT;
 	}
 
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-
-		int num = sscanf(tmp, "%hhu %hhu %hhu %d", &ch, &bw, &offset, &ms);
-
-		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
-			goto exit;
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
 
-		if (bw == CHANNEL_WIDTH_20)
-			rtw_chset_update_non_ocp_ms(rfctl->channel_set
-				, ch, bw, HAL_PRIME_CHNL_OFFSET_DONT_CARE, ms);
-		else
-			rtw_chset_update_non_ocp_ms(rfctl->channel_set
-				, ch, bw, offset, ms);
-	}
+	num = sscanf(tmp, "%hhu", &sb_prefer);
+	if (num >=	1)
+		rfctl->ch_sel_same_band_prefer = sb_prefer;
 
 exit:
 	return count;
 }
 
-ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+#ifdef CONFIG_DFS_MASTER
+static int proc_get_dfs_test_case(struct seq_file *m, void *v)
 {
-	struct net_device *dev = data;
+	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
-	char tmp[32];
+
+	RTW_PRINT_SEL(m, "%-24s %-19s\n", "radar_detect_trigger_non", "choose_dfs_ch_first");
+	RTW_PRINT_SEL(m, "%24hhu %19hhu\n"
+		, rfctl->dbg_dfs_radar_detect_trigger_non
+		, rfctl->dbg_dfs_choose_dfs_ch_first
+	);
+
+	return 0;
+}
+
+static ssize_t proc_set_dfs_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 radar_detect_trigger_non;
+	u8 choose_dfs_ch_first;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		int num = sscanf(tmp, "%hhu %hhu", &radar_detect_trigger_non, &choose_dfs_ch_first);
+
+		if (num >= 1)
+			rfctl->dbg_dfs_radar_detect_trigger_non = radar_detect_trigger_non;
+		if (num >= 2)
+			rfctl->dbg_dfs_choose_dfs_ch_first = choose_dfs_ch_first;
+	}
+
+	return count;
+}
+
+ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 ch, bw = CHANNEL_WIDTH_20, offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
+	int ms = -1;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+
+		int num = sscanf(tmp, "%hhu %hhu %hhu %d", &ch, &bw, &offset, &ms);
+
+		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
+			goto exit;
+
+		if (bw == CHANNEL_WIDTH_20)
+			rtw_chset_update_non_ocp_ms(rfctl->channel_set
+				, ch, bw, HAL_PRIME_CHNL_OFFSET_DONT_CARE, ms);
+		else
+			rtw_chset_update_non_ocp_ms(rfctl->channel_set
+				, ch, bw, offset, ms);
+	}
+
+exit:
+	return count;
+}
+
+ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
 	u8 fake_radar_detect_cnt = 0;
 
 	if (count < 1)
@@ -1204,7 +1615,7 @@ ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size
 		if (num < 1)
 			goto exit;
 
-		rfctl->dbg_dfs_master_fake_radar_detect_cnt = fake_radar_detect_cnt;
+		rfctl->dbg_dfs_fake_radar_detect_cnt = fake_radar_detect_cnt;
 	}
 
 exit:
@@ -1243,7 +1654,7 @@ static ssize_t proc_set_dfs_ch_sel_d_flags(struct file *file, const char __user
 		goto exit;
 
 	num = sscanf(tmp, "%hhx", &d_flags);
-	if (num !=	1)
+	if (num != 1)
 		goto exit;
 
 	rfctl->dfs_ch_sel_d_flags = d_flags;
@@ -1251,6 +1662,54 @@ static ssize_t proc_set_dfs_ch_sel_d_flags(struct file *file, const char __user
 exit:
 	return count;
 }
+
+#ifdef CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
+static int proc_get_dfs_slave_with_rd(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+
+	RTW_PRINT_SEL(m, "%u\n", rfctl->dfs_slave_with_rd);
+
+	return 0;
+}
+
+static ssize_t proc_set_dfs_slave_with_rd(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
+	char tmp[32];
+	u8 rd;
+	int num;
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%hhu", &rd);
+	if (num != 1)
+		goto exit;
+
+	rd = rd ? 1 : 0;
+
+	if (rfctl->dfs_slave_with_rd != rd) {
+		rfctl->dfs_slave_with_rd = rd;
+		rtw_dfs_rd_en_decision_cmd(adapter);
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_DFS_SLAVE_WITH_RADAR_DETECT */
 #endif /* CONFIG_DFS_MASTER */
 
 #ifdef CONFIG_80211N_HT
@@ -1509,11 +1968,12 @@ static ssize_t proc_set_change_bss_chbw(struct file *file, const char __user *bu
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct mlme_priv *mlme = &(adapter->mlmepriv);
-	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	int i;
 	char tmp[32];
 	s16 ch;
-	s8 bw = -1, offset = -1;
+	s8 bw = REQ_BW_NONE, offset = REQ_OFFSET_NONE;
+	u8 ifbmp = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -1525,14 +1985,27 @@ static ssize_t proc_set_change_bss_chbw(struct file *file, const char __user *bu
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%hd %hhd %hhd", &ch, &bw, &offset);
+		int num = sscanf(tmp, "%hd %hhd %hhd %hhx", &ch, &bw, &offset, &ifbmp);
 
 		if (num < 1 || (bw != CHANNEL_WIDTH_20 && num < 3))
 			goto exit;
 
-		if ((MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))
-			&& check_fwstate(mlme, WIFI_ASOC_STATE))
-			rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_WAIT_ACK, ch, bw, offset);
+		if (num < 4)
+			ifbmp = BIT(adapter->iface_id);
+		else
+			ifbmp &= (1 << dvobj->iface_nums) - 1;
+
+		for (i = 0; i < dvobj->iface_nums; i++) {
+			if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
+				continue;
+
+			if (!CHK_MLME_STATE(dvobj->padapters[i], WIFI_AP_STATE | WIFI_MESH_STATE)
+				|| !MLME_IS_ASOC(dvobj->padapters[i]))
+				ifbmp &= ~BIT(i);
+		}
+
+		if (ifbmp)
+			rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_WAIT_ACK, ifbmp, 0, ch, bw, offset);
 	}
 
 exit:
@@ -1551,13 +2024,38 @@ static int proc_get_tx_bw_mode(struct seq_file *m, void *v)
 	return 0;
 }
 
+static void rtw_set_tx_bw_mode(struct _ADAPTER *adapter, u8 bw_mode)
+{
+	struct mlme_priv *mlme = &(adapter->mlmepriv);
+	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
+	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
+	u8 update = _FALSE;
+
+	if ((MLME_STATE(adapter) & WIFI_ASOC_STATE)
+		&& ((mlmeext->cur_channel <= 14 && BW_MODE_2G(bw_mode) != ADAPTER_TX_BW_2G(adapter))
+			|| (mlmeext->cur_channel >= 36 && BW_MODE_5G(bw_mode) != ADAPTER_TX_BW_5G(adapter)))
+	) {
+		/* RA mask update needed */
+		update = _TRUE;
+	}		
+	adapter->driver_tx_bw_mode = bw_mode;
+
+	if (update == _TRUE) {
+		struct sta_info *sta;
+		int i;
+
+		for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
+			sta = macid_ctl->sta[i];
+			if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr))
+				rtw_dm_ra_mask_wk_cmd(adapter, (u8 *)sta);
+		}
+	}
+}
+
 static ssize_t proc_set_tx_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
-	struct mlme_priv *mlme = &(adapter->mlmepriv);
-	struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
 	char tmp[32];
 	u8 bw_mode;
 
@@ -1571,31 +2069,12 @@ static ssize_t proc_set_tx_bw_mode(struct file *file, const char __user *buffer,
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		u8 update = _FALSE;
 		int num = sscanf(tmp, "%hhx", &bw_mode);
 
 		if (num < 1 || bw_mode == adapter->driver_tx_bw_mode)
 			goto exit;
 
-		if ((MLME_STATE(adapter) & WIFI_ASOC_STATE)
-			&& ((mlmeext->cur_channel <= 14 && BW_MODE_2G(bw_mode) != ADAPTER_TX_BW_2G(adapter))
-				|| (mlmeext->cur_channel >= 36 && BW_MODE_5G(bw_mode) != ADAPTER_TX_BW_5G(adapter)))
-		) {
-			/* RA mask update needed */
-			update = _TRUE;
-		}
-		adapter->driver_tx_bw_mode = bw_mode;
-
-		if (update == _TRUE) {
-			struct sta_info *sta;
-			int i;
-
-			for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
-				sta = macid_ctl->sta[i];
-				if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr))
-					rtw_dm_ra_mask_wk_cmd(adapter, (u8 *)sta);
-			}
-		}
+		rtw_set_tx_bw_mode(adapter, bw_mode);
 	}
 
 exit:
@@ -1686,13 +2165,15 @@ static ssize_t proc_set_tx_power_ext_info(struct file *file, const char __user *
 		#endif
 
 		rtw_ps_deny(adapter, PS_DENY_IOCTL);
-		LeaveAllPowerSaveModeDirect(adapter);
+		if (rtw_pwr_wakeup(adapter) == _FALSE)
+			goto clear_ps_deny;
 
 		if (strcmp("default", cmd) == 0)
 			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_default_tx_power_ext_info)), adapter);
 		else
 			rtw_run_in_thread_cmd(adapter, ((void *)(phy_reload_tx_power_ext_info)), adapter);
 
+clear_ps_deny:
 		rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
 	}
 
@@ -1701,10 +2182,7 @@ static ssize_t proc_set_tx_power_ext_info(struct file *file, const char __user *
 
 static void *proc_start_tx_power_idx(struct seq_file *m, loff_t *pos)
 {
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 path = ((*pos) & 0xFF00) >> 8;
-	u8 rs = *pos & 0xFF;
 
 	if (path >= RF_PATH_MAX)
 		return NULL;
@@ -1713,14 +2191,10 @@ static void *proc_start_tx_power_idx(struct seq_file *m, loff_t *pos)
 }
 static void proc_stop_tx_power_idx(struct seq_file *m, void *v)
 {
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 }
 
 static void *proc_next_tx_power_idx(struct seq_file *m, void *v, loff_t *pos)
 {
-	struct net_device *dev = m->private;
-	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 	u8 path = ((*pos) & 0xFF00) >> 8;
 	u8 rs = *pos & 0xFF;
 
@@ -1835,10 +2309,9 @@ static ssize_t proc_set_kfree_bb_gain(struct file *file, const char __user *buff
 {
 	struct net_device *dev = data;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
-	HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
 	struct kfree_data_t *kfree_data = GET_KFREE_DATA(adapter);
 	char tmp[BB_GAIN_NUM * RF_PATH_MAX] = {0};
-	u8 path, chidx;
+	u8 chidx;
 	s8 bb_gain[BB_GAIN_NUM];
 	char ch_band_Group[6];
 
@@ -1950,7 +2423,6 @@ static ssize_t proc_set_tx_gain_offset(struct file *file, const char __user *buf
 	}
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		u8 write_value;
 		int num = sscanf(tmp, "%hhu %hhd", &rf_path, &offset);
 
 		if (num < 2)
@@ -2330,16 +2802,23 @@ static int proc_get_best_chan(struct seq_file *m, void *v)
 	struct net_device *dev = m->private;
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	rtw_acs_info_dump(m, adapter);
+	if (IS_ACS_ENABLE(adapter))
+		rtw_acs_info_dump(m, adapter);
+	else
+		_RTW_PRINT_SEL(m,"ACS disabled\n");
 	return 0;
 }
 
 static ssize_t proc_set_acs(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
 {
+#ifdef CONFIG_RTW_ACS_DBG
 	struct net_device *dev = data;
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
 	u8 acs_state = 0;
+	u16 scan_ch_ms= 0, acs_scan_ch_ms = 0;
+	u8 scan_type = SCAN_ACTIVE, igi= 0, bw = 0;
+	u8 acs_scan_type = SCAN_ACTIVE, acs_igi= 0, acs_bw = 0;
 
 	if (count < 1)
 		return -EFAULT;
@@ -2350,7 +2829,8 @@ static ssize_t proc_set_acs(struct file *file, const char __user *buffer, size_t
 	}
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%hhu", &acs_state);
+		int num = sscanf(tmp, "%hhu %hhu %hu %hhx %hhu",
+			&acs_state, &scan_type, &scan_ch_ms, &igi, &bw);
 
 		if (num < 1)
 			return -EINVAL;
@@ -2359,8 +2839,21 @@ static ssize_t proc_set_acs(struct file *file, const char __user *buffer, size_t
 			rtw_acs_start(padapter);
 		else
 			rtw_acs_stop(padapter);
-
+		num = num -1;
+
+		if(num) {
+			if (num-- > 0)
+				acs_scan_type = scan_type;
+			if (num-- > 0)
+				acs_scan_ch_ms = scan_ch_ms;
+			if (num-- > 0)
+				acs_igi = igi;
+			if (num-- > 0)
+				acs_bw = bw;
+			rtw_acs_adv_setting(padapter, acs_scan_type, acs_scan_ch_ms, acs_igi, acs_bw);
+		}
 	}
+#endif /*CONFIG_RTW_ACS_DBG*/
 	return count;
 }
 #endif /*CONFIG_RTW_ACS*/
@@ -2421,8 +2914,10 @@ static int proc_get_phy_cap(struct seq_file *m, void *v)
 	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
 	rtw_dump_phy_cap(m, adapter);
+#ifdef CONFIG_80211N_HT
 	rtw_dump_drv_phy_cap(m, adapter);
 	rtw_get_dft_phy_cap(m, adapter);
+#endif /* CONFIG_80211N_HT */
 	return 0;
 }
 
@@ -2579,9 +3074,11 @@ static ssize_t proc_set_napi_th(struct file *file, const char __user *buffer, si
 	struct net_device *dev = data;
 	struct _ADAPTER *adapter = (struct _ADAPTER *)rtw_netdev_priv(dev);
 	struct registry_priv *registry = &adapter->registrypriv;
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	PADAPTER iface = NULL;
 	char tmp[32] = {0};
 	int thrshld = 0;
-	int num = 0;
+	int num = 0, i = 0;
 
 
 	if (count < 1)
@@ -2594,11 +3091,18 @@ static ssize_t proc_set_napi_th(struct file *file, const char __user *buffer, si
 
 	RTW_INFO("%s: Last threshold = %d Mbps\n", __FUNCTION__, registry->napi_threshold);
 
-	if (buffer && !copy_from_user(tmp, buffer, count)) {
-		num = sscanf(tmp, "%d", &thrshld);
-		if (num > 0) {
-			if (thrshld > 0)
-				registry->napi_threshold = thrshld;
+
+	for (i = 0; i < dvobj->iface_nums; i++) {
+		iface = dvobj->padapters[i];
+		if (iface) {	
+			if (buffer && !copy_from_user(tmp, buffer, count)) {
+				registry = &iface->registrypriv;
+				num = sscanf(tmp, "%d", &thrshld);
+				if (num > 0) {
+					if (thrshld > 0)
+						registry->napi_threshold = thrshld;
+				}
+			}
 		}
 	}
 	RTW_INFO("%s: New threshold = %d Mbps\n", __FUNCTION__, registry->napi_threshold);
@@ -2658,110 +3162,705 @@ static int proc_get_dynamic_agg_enable(struct seq_file *m, void *v)
 	return 0;
 }
 
-/*
-* rtw_adapter_proc:
-* init/deinit when register/unregister net_device
-*/
-const struct rtw_proc_hdl adapter_proc_hdls[] = {
-#if RTW_SEQ_FILE_TEST
-	RTW_PROC_HDL_SEQ("seq_file_test", &seq_file_test, NULL),
-#endif
-	RTW_PROC_HDL_SSEQ("write_reg", NULL, proc_set_write_reg),
-	RTW_PROC_HDL_SSEQ("read_reg", proc_get_read_reg, proc_set_read_reg),
-	RTW_PROC_HDL_SSEQ("tx_rate_bmp", proc_get_dump_tx_rate_bmp, NULL),
-	RTW_PROC_HDL_SSEQ("adapters_status", proc_get_dump_adapters_status, NULL),
-#ifdef CONFIG_RTW_CUSTOMER_STR
-	RTW_PROC_HDL_SSEQ("customer_str", proc_get_customer_str, NULL),
-#endif
-	RTW_PROC_HDL_SSEQ("fwstate", proc_get_fwstate, NULL),
-	RTW_PROC_HDL_SSEQ("sec_info", proc_get_sec_info, NULL),
-	RTW_PROC_HDL_SSEQ("mlmext_state", proc_get_mlmext_state, NULL),
-	RTW_PROC_HDL_SSEQ("qos_option", proc_get_qos_option, NULL),
-	RTW_PROC_HDL_SSEQ("ht_option", proc_get_ht_option, NULL),
-	RTW_PROC_HDL_SSEQ("rf_info", proc_get_rf_info, NULL),
-	RTW_PROC_HDL_SSEQ("scan_param", proc_get_scan_param, proc_set_scan_param),
-	RTW_PROC_HDL_SSEQ("scan_abort", proc_get_scan_abort, NULL),
-#ifdef CONFIG_SCAN_BACKOP
-	RTW_PROC_HDL_SSEQ("backop_flags_sta", proc_get_backop_flags_sta, proc_set_backop_flags_sta),
-	RTW_PROC_HDL_SSEQ("backop_flags_ap", proc_get_backop_flags_ap, proc_set_backop_flags_ap),
-#endif
-#ifdef CONFIG_RTW_REPEATER_SON
-	RTW_PROC_HDL_SSEQ("rson_data", proc_get_rson_data, proc_set_rson_data),
-#endif
-	RTW_PROC_HDL_SSEQ("survey_info", proc_get_survey_info, proc_set_survey_info),
-	RTW_PROC_HDL_SSEQ("ap_info", proc_get_ap_info, NULL),
-	RTW_PROC_HDL_SSEQ("trx_info", proc_get_trx_info, proc_reset_trx_info),
-	RTW_PROC_HDL_SSEQ("tx_power_offset", proc_get_tx_power_offset, proc_set_tx_power_offset),
-	RTW_PROC_HDL_SSEQ("rate_ctl", proc_get_rate_ctl, proc_set_rate_ctl),
-	RTW_PROC_HDL_SSEQ("bw_ctl", proc_get_bw_ctl, proc_set_bw_ctl),
-	RTW_PROC_HDL_SSEQ("dis_pwt_ctl", proc_get_dis_pwt, proc_set_dis_pwt),
-	RTW_PROC_HDL_SSEQ("mac_qinfo", proc_get_mac_qinfo, NULL),
-	RTW_PROC_HDL_SSEQ("macid_info", proc_get_macid_info, NULL),
-	RTW_PROC_HDL_SSEQ("bcmc_info", proc_get_mi_ap_bc_info, NULL),
-	RTW_PROC_HDL_SSEQ("sec_cam", proc_get_sec_cam, proc_set_sec_cam),
-	RTW_PROC_HDL_SSEQ("sec_cam_cache", proc_get_sec_cam_cache, NULL),
-	RTW_PROC_HDL_SSEQ("ps_dbg_info", proc_get_ps_dbg_info, proc_set_ps_dbg_info),
-	RTW_PROC_HDL_SSEQ("wifi_spec", proc_get_wifi_spec, NULL),
-#ifdef CONFIG_LAYER2_ROAMING
-	RTW_PROC_HDL_SSEQ("roam_flags", proc_get_roam_flags, proc_set_roam_flags),
-	RTW_PROC_HDL_SSEQ("roam_param", proc_get_roam_param, proc_set_roam_param),
-	RTW_PROC_HDL_SSEQ("roam_tgt_addr", NULL, proc_set_roam_tgt_addr),
-#endif /* CONFIG_LAYER2_ROAMING */
+#ifdef CONFIG_RTW_MESH
+static int proc_get_mesh_peer_sel_policy(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-#ifdef CONFIG_RTW_80211R
-	RTW_PROC_HDL_SSEQ("ft_flags", proc_get_ft_flags, proc_set_ft_flags),
-#endif
+	dump_mesh_peer_sel_policy(m, adapter);
 
-#ifdef CONFIG_SDIO_HCI
-	RTW_PROC_HDL_SSEQ("sd_f0_reg_dump", proc_get_sd_f0_reg_dump, NULL),
-	RTW_PROC_HDL_SSEQ("sdio_local_reg_dump", proc_get_sdio_local_reg_dump, NULL),
-	RTW_PROC_HDL_SSEQ("sdio_card_info", proc_get_sdio_card_info, NULL),
-#endif /* CONFIG_SDIO_HCI */
+	return 0;
+}
 
-	RTW_PROC_HDL_SSEQ("fwdl_test_case", NULL, proc_set_fwdl_test_case),
-	RTW_PROC_HDL_SSEQ("del_rx_ampdu_test_case", NULL, proc_set_del_rx_ampdu_test_case),
-	RTW_PROC_HDL_SSEQ("wait_hiq_empty", NULL, proc_set_wait_hiq_empty),
-	RTW_PROC_HDL_SSEQ("sta_linking_test", NULL, proc_set_sta_linking_test),
+#if CONFIG_RTW_MESH_ACNODE_PREVENT
+static int proc_get_mesh_acnode_prevent(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
 
-	RTW_PROC_HDL_SSEQ("mac_reg_dump", proc_get_mac_reg_dump, NULL),
-	RTW_PROC_HDL_SSEQ("bb_reg_dump", proc_get_bb_reg_dump, NULL),
-	RTW_PROC_HDL_SSEQ("bb_reg_dump_ex", proc_get_bb_reg_dump_ex, NULL),
-	RTW_PROC_HDL_SSEQ("rf_reg_dump", proc_get_rf_reg_dump, NULL),
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_acnode_prevent_settings(m, adapter);
 
-#ifdef CONFIG_AP_MODE
-	RTW_PROC_HDL_SSEQ("all_sta_info", proc_get_all_sta_info, NULL),
-	RTW_PROC_HDL_SSEQ("bmc_tx_rate", proc_get_bmc_tx_rate, proc_set_bmc_tx_rate),
-#endif /* CONFIG_AP_MODE */
+	return 0;
+}
 
-#ifdef DBG_MEMORY_LEAK
-	RTW_PROC_HDL_SSEQ("_malloc_cnt", proc_get_malloc_cnt, NULL),
-#endif /* DBG_MEMORY_LEAK */
+static ssize_t proc_set_mesh_acnode_prevent(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
 
-#ifdef CONFIG_FIND_BEST_CHANNEL
-	RTW_PROC_HDL_SSEQ("best_channel", proc_get_best_channel, proc_set_best_channel),
-#endif
+	if (count < 1)
+		return -EFAULT;
 
-	RTW_PROC_HDL_SSEQ("rx_signal", proc_get_rx_signal, proc_set_rx_signal),
-	RTW_PROC_HDL_SSEQ("hw_info", proc_get_hw_status, proc_set_hw_status),
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
 
-#ifdef CONFIG_80211N_HT
-	RTW_PROC_HDL_SSEQ("ht_enable", proc_get_ht_enable, proc_set_ht_enable),
-	RTW_PROC_HDL_SSEQ("bw_mode", proc_get_bw_mode, proc_set_bw_mode),
-	RTW_PROC_HDL_SSEQ("ampdu_enable", proc_get_ampdu_enable, proc_set_ampdu_enable),
-	RTW_PROC_HDL_SSEQ("rx_ampdu", proc_get_rx_ampdu, proc_set_rx_ampdu),
-	RTW_PROC_HDL_SSEQ("rx_ampdu_size_limit", proc_get_rx_ampdu_size_limit, proc_set_rx_ampdu_size_limit),
-	RTW_PROC_HDL_SSEQ("rx_ampdu_factor", proc_get_rx_ampdu_factor, proc_set_rx_ampdu_factor),
-	RTW_PROC_HDL_SSEQ("rx_ampdu_density", proc_get_rx_ampdu_density, proc_set_rx_ampdu_density),
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u8 enable;
+		u32 conf_timeout_ms;
+		u32 notify_timeout_ms;
+		int num = sscanf(tmp, "%hhu %u %u", &enable, &conf_timeout_ms, &notify_timeout_ms);
+
+		if (num >= 1)
+			peer_sel_policy->acnode_prevent = enable;
+		if (num >= 2)
+			peer_sel_policy->acnode_conf_timeout_ms = conf_timeout_ms;
+		if (num >= 3)
+			peer_sel_policy->acnode_notify_timeout_ms = notify_timeout_ms;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_ACNODE_PREVENT */
+
+#if CONFIG_RTW_MESH_OFFCH_CAND
+static int proc_get_mesh_offch_cand(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_offch_cand_settings(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_offch_cand(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u8 enable;
+		u32 find_int_ms;
+		int num = sscanf(tmp, "%hhu %u", &enable, &find_int_ms);
+
+		if (num >= 1)
+			peer_sel_policy->offch_cand = enable;
+		if (num >= 2)
+			peer_sel_policy->offch_find_int_ms = find_int_ms;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_OFFCH_CAND */
+
+#if CONFIG_RTW_MESH_PEER_BLACKLIST
+static int proc_get_mesh_peer_blacklist(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter)) {
+		dump_mesh_peer_blacklist_settings(m, adapter);
+		if (MLME_IS_ASOC(adapter))
+			dump_mesh_peer_blacklist(m, adapter);
+	}
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_peer_blacklist(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u32 conf_timeout_ms;
+		u32 blacklist_timeout_ms;
+		int num = sscanf(tmp, "%u %u", &conf_timeout_ms, &blacklist_timeout_ms);
+
+		if (num >= 1)
+			peer_sel_policy->peer_conf_timeout_ms = conf_timeout_ms;
+		if (num >= 2)
+			peer_sel_policy->peer_blacklist_timeout_ms = blacklist_timeout_ms;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
+
+#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+static int proc_get_mesh_cto_mgate_require(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		RTW_PRINT_SEL(m, "%u\n", adapter->mesh_cfg.peer_sel_policy.cto_mgate_require);
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_cto_mgate_require(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u8 require;
+		int num = sscanf(tmp, "%hhu", &require);
+
+		if (num >= 1) {
+			peer_sel_policy->cto_mgate_require = require;
+			#if CONFIG_RTW_MESH_CTO_MGATE_CARRIER
+			if (rtw_mesh_cto_mgate_required(adapter))
+				rtw_netif_carrier_off(adapter->pnetdev);
+			else
+				rtw_netif_carrier_on(adapter->pnetdev);
+			#endif
+		}
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_mesh_cto_mgate_blacklist(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter)) {
+		dump_mesh_cto_mgate_blacklist_settings(m, adapter);
+		if (MLME_IS_ASOC(adapter))
+			dump_mesh_cto_mgate_blacklist(m, adapter);
+	}
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_cto_mgate_blacklist(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
+		u32 conf_timeout_ms;
+		u32 blacklist_timeout_ms;
+		int num = sscanf(tmp, "%u %u", &conf_timeout_ms, &blacklist_timeout_ms);
+
+		if (num >= 1)
+			peer_sel_policy->cto_mgate_conf_timeout_ms = conf_timeout_ms;
+		if (num >= 2)
+			peer_sel_policy->cto_mgate_blacklist_timeout_ms = blacklist_timeout_ms;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
+
+static int proc_get_mesh_networks(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	dump_mesh_networks(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_mesh_plink_ctl(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_plink_ctl(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_mesh_mpath(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter))
+		dump_mpath(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_mesh_mpp(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter))
+		dump_mpp(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_mesh_known_gates(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_known_gates(m, adapter);
+
+	return 0;
+}
+
+#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+static int proc_get_mesh_b2u_flags(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_b2u_flags(m, adapter);
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_b2u_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+		u8 msrc, mfwd;
+		int num = sscanf(tmp, "%hhx %hhx", &msrc, &mfwd);
+
+		if (num >= 1)
+			mcfg->b2u_flags_msrc = msrc;
+		if (num >= 2)
+			mcfg->b2u_flags_mfwd = mfwd;
+	}
+
+exit:
+	return count;
+}
+#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
+
+static int proc_get_mesh_stats(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		dump_mesh_stats(m, adapter);
+
+	return 0;
+}
+
+static int proc_get_mesh_gate_timeout(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+
+	if (MLME_IS_MESH(adapter))
+		RTW_PRINT_SEL(m, "%u factor\n",
+			       adapter->mesh_cfg.path_gate_timeout_factor);
+
+	return 0;
+}
+
+static ssize_t proc_set_mesh_gate_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	char tmp[32];
+
+	if (count < 1)
+		return -EFAULT;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (buffer && !copy_from_user(tmp, buffer, count)) {
+		struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+		u32 timeout;
+		int num = sscanf(tmp, "%u", &timeout);
+
+		if (num < 1)
+			goto exit;
+
+		mcfg->path_gate_timeout_factor = timeout;
+	}
+
+exit:
+	return count;
+}
+
+static int proc_get_mesh_gate_state(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
+	u8 cto_mgate = 0;
+
+	if (MLME_IS_MESH(adapter)) {
+		if (rtw_mesh_is_primary_gate(adapter))
+			RTW_PRINT_SEL(m, "PG\n");
+		else if (mcfg->dot11MeshGateAnnouncementProtocol)
+			RTW_PRINT_SEL(m, "G\n");
+		else if (rtw_mesh_gate_num(adapter))
+			RTW_PRINT_SEL(m, "C\n");
+		else
+			RTW_PRINT_SEL(m, "N\n");
+	}
+
+	return 0;
+}
+
+#endif /* CONFIG_RTW_MESH */
+
+static int proc_get_scan_deny(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	struct _ADAPTER *adapter= (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	RTW_PRINT_SEL(m, "scan_deny is %s\n", (dvobj->scan_deny == _TRUE) ? "enable":"disable");
+
+	return 0;
+}
+
+static ssize_t proc_set_scan_deny(struct file *file, const char __user *buffer,
+				size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	struct _ADAPTER *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	char tmp[8];
+	int num = 0;
+	int enable = 0;
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%d", &enable);
+	if (num !=  1) {
+		RTW_ERR("%s: invalid parameter!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	dvobj->scan_deny = enable ? _TRUE : _FALSE;
+
+	RTW_PRINT("%s: scan_deny is %s\n",
+		  __FUNCTION__, (dvobj->scan_deny == _TRUE) ? "enable":"disable");
+
+exit:
+	return count;
+}
+
+#ifdef CONFIG_RTW_TPT_MODE
+static int proc_get_tpt_mode(struct seq_file *m, void *v)
+{
+	struct net_device *dev = m->private;
+	struct _ADAPTER *adapter= (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	RTW_PRINT_SEL(m, "current tpt_mode = %d\n", dvobj->tpt_mode);
+
+	return 0;
+}
+
+static void tpt_mode_default(struct _ADAPTER *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+
+	/* 1. disable scan deny */
+	dvobj->scan_deny = _FALSE;
+
+	/* 2. back to original LPS mode */
+#ifdef CONFIG_LPS		
+	rtw_pm_set_lps(adapter, adapter->registrypriv.power_mgnt);
+#endif
+
+	/* 3. back to original 2.4 tx bw mode */
+	rtw_set_tx_bw_mode(adapter, adapter->registrypriv.tx_bw_mode);
+}
+
+static void rtw_tpt_mode(struct _ADAPTER *adapter)
+{
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(adapter);
+
+	if (dvobj->tpt_mode > 0) {
+
+		/* when enable each tpt mode 
+			1. scan deny
+			2. disable LPS */
+			
+		dvobj->scan_deny = _TRUE;
+
+#ifdef CONFIG_LPS		
+		rtw_pm_set_lps(adapter, PS_MODE_ACTIVE);
+#endif
+
+	}
+
+	switch (dvobj->tpt_mode) {
+		case 0: /* default mode */
+			tpt_mode_default(adapter);
+			break;
+		case 1: /* High TP*/
+			/*tpt_mode1(adapter);*/			 
+			dvobj->edca_be_ul = 0x5e431c;
+			dvobj->edca_be_dl = 0x00431c;			 
+			break;
+		case 2: /* noise */
+			/* tpt_mode2(adapter); */
+			dvobj->edca_be_ul = 0x00431c;
+			dvobj->edca_be_dl = 0x00431c;
+
+			rtw_set_tx_bw_mode(adapter, 0x20); /* for 2.4g, fixed tx_bw_mode to 20Mhz */
+			break;
+		case 3: /* long distance */
+			/* tpt_mode3(adapter); */
+			dvobj->edca_be_ul = 0x00431c;
+			dvobj->edca_be_dl = 0x00431c;
+
+			rtw_set_tx_bw_mode(adapter, 0x20); /* for 2.4g, fixed tx_bw_mode to 20Mhz */
+			break;
+		case 4: /* noise + long distance */
+			/* tpt_mode4(adapter); */
+			dvobj->edca_be_ul = 0x00431c;
+			dvobj->edca_be_dl = 0x00431c;
+
+			rtw_set_tx_bw_mode(adapter, 0x20); /* for 2.4g, fixed tx_bw_mode to 20Mhz */
+			break;
+		default: /* default mode */
+			tpt_mode_default(adapter);		
+			break;
+	}
+
+}
+
+static ssize_t proc_set_tpt_mode(struct file *file, const char __user *buffer,
+				size_t count, loff_t *pos, void *data)
+{
+	struct net_device *dev = data;
+	struct _ADAPTER *adapter = (_adapter *)rtw_netdev_priv(dev);
+	struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
+	char tmp[32];
+	int num = 0;
+	int mode = 0;
+
+#define MAX_TPT_MODE_NUM 4
+
+	if (count > sizeof(tmp)) {
+		rtw_warn_on(1);
+		return -EFAULT;
+	}
+
+	if (!buffer || copy_from_user(tmp, buffer, count))
+		goto exit;
+
+	num = sscanf(tmp, "%d", &mode);
+	if (num !=  1) {
+		RTW_ERR("%s: invalid parameter!\n", __FUNCTION__);
+		goto exit;
+	}
+
+	if (mode > MAX_TPT_MODE_NUM )
+		mode = 0;	
+
+	RTW_PRINT("%s: previous mode =  %d\n",
+		  __FUNCTION__, dvobj->tpt_mode);
+
+	RTW_PRINT("%s: enabled mode = %d\n",
+		  __FUNCTION__, mode);
+
+	dvobj->tpt_mode = mode;
+
+	rtw_tpt_mode(adapter);
+
+exit:
+	return count;
+
+}
+#endif /* CONFIG_RTW_TPT_MODE */
+
+/*
+* rtw_adapter_proc:
+* init/deinit when register/unregister net_device
+*/
+const struct rtw_proc_hdl adapter_proc_hdls[] = {
+#if RTW_SEQ_FILE_TEST
+	RTW_PROC_HDL_SEQ("seq_file_test", &seq_file_test, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("write_reg", NULL, proc_set_write_reg),
+	RTW_PROC_HDL_SSEQ("read_reg", proc_get_read_reg, proc_set_read_reg),
+	RTW_PROC_HDL_SSEQ("tx_rate_bmp", proc_get_dump_tx_rate_bmp, NULL),
+	RTW_PROC_HDL_SSEQ("adapters_status", proc_get_dump_adapters_status, NULL),
+#ifdef CONFIG_RTW_CUSTOMER_STR
+	RTW_PROC_HDL_SSEQ("customer_str", proc_get_customer_str, NULL),
+#endif
+	RTW_PROC_HDL_SSEQ("fwstate", proc_get_fwstate, NULL),
+	RTW_PROC_HDL_SSEQ("sec_info", proc_get_sec_info, NULL),
+	RTW_PROC_HDL_SSEQ("mlmext_state", proc_get_mlmext_state, NULL),
+	RTW_PROC_HDL_SSEQ("qos_option", proc_get_qos_option, NULL),
+	RTW_PROC_HDL_SSEQ("ht_option", proc_get_ht_option, NULL),
+	RTW_PROC_HDL_SSEQ("rf_info", proc_get_rf_info, NULL),
+	RTW_PROC_HDL_SSEQ("scan_param", proc_get_scan_param, proc_set_scan_param),
+	RTW_PROC_HDL_SSEQ("scan_abort", proc_get_scan_abort, NULL),
+#ifdef CONFIG_SCAN_BACKOP
+	RTW_PROC_HDL_SSEQ("backop_flags_sta", proc_get_backop_flags_sta, proc_set_backop_flags_sta),
+	#ifdef CONFIG_AP_MODE
+	RTW_PROC_HDL_SSEQ("backop_flags_ap", proc_get_backop_flags_ap, proc_set_backop_flags_ap),
+	#endif
+	#ifdef CONFIG_RTW_MESH
+	RTW_PROC_HDL_SSEQ("backop_flags_mesh", proc_get_backop_flags_mesh, proc_set_backop_flags_mesh),
+	#endif
+#endif
+#ifdef CONFIG_RTW_REPEATER_SON
+	RTW_PROC_HDL_SSEQ("rson_data", proc_get_rson_data, proc_set_rson_data),
+#endif
+	RTW_PROC_HDL_SSEQ("survey_info", proc_get_survey_info, proc_set_survey_info),
+	RTW_PROC_HDL_SSEQ("ap_info", proc_get_ap_info, NULL),
+#ifdef ROKU_PRIVATE
+	RTW_PROC_HDL_SSEQ("infra_ap", proc_get_infra_ap, NULL),
+#endif /* ROKU_PRIVATE */
+	RTW_PROC_HDL_SSEQ("trx_info", proc_get_trx_info, proc_reset_trx_info),
+	RTW_PROC_HDL_SSEQ("tx_power_offset", proc_get_tx_power_offset, proc_set_tx_power_offset),
+	RTW_PROC_HDL_SSEQ("rate_ctl", proc_get_rate_ctl, proc_set_rate_ctl),
+	RTW_PROC_HDL_SSEQ("bw_ctl", proc_get_bw_ctl, proc_set_bw_ctl),
+	RTW_PROC_HDL_SSEQ("mac_qinfo", proc_get_mac_qinfo, NULL),
+	RTW_PROC_HDL_SSEQ("macid_info", proc_get_macid_info, NULL),
+	RTW_PROC_HDL_SSEQ("bcmc_info", proc_get_mi_ap_bc_info, NULL),
+	RTW_PROC_HDL_SSEQ("sec_cam", proc_get_sec_cam, proc_set_sec_cam),
+	RTW_PROC_HDL_SSEQ("sec_cam_cache", proc_get_sec_cam_cache, NULL),
+	RTW_PROC_HDL_SSEQ("ps_dbg_info", proc_get_ps_dbg_info, proc_set_ps_dbg_info),
+	RTW_PROC_HDL_SSEQ("wifi_spec", proc_get_wifi_spec, NULL),
+#ifdef CONFIG_LAYER2_ROAMING
+	RTW_PROC_HDL_SSEQ("roam_flags", proc_get_roam_flags, proc_set_roam_flags),
+	RTW_PROC_HDL_SSEQ("roam_param", proc_get_roam_param, proc_set_roam_param),
+	RTW_PROC_HDL_SSEQ("roam_tgt_addr", NULL, proc_set_roam_tgt_addr),
+#endif /* CONFIG_LAYER2_ROAMING */
+
+#ifdef CONFIG_RTW_80211R
+	RTW_PROC_HDL_SSEQ("ft_flags", proc_get_ft_flags, proc_set_ft_flags),
+#endif
+
+#ifdef CONFIG_SDIO_HCI
+	RTW_PROC_HDL_SSEQ("sd_f0_reg_dump", proc_get_sd_f0_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("sdio_local_reg_dump", proc_get_sdio_local_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("sdio_card_info", proc_get_sdio_card_info, NULL),
+#endif /* CONFIG_SDIO_HCI */
+
+	RTW_PROC_HDL_SSEQ("fwdl_test_case", NULL, proc_set_fwdl_test_case),
+	RTW_PROC_HDL_SSEQ("del_rx_ampdu_test_case", NULL, proc_set_del_rx_ampdu_test_case),
+	RTW_PROC_HDL_SSEQ("wait_hiq_empty", NULL, proc_set_wait_hiq_empty),
+	RTW_PROC_HDL_SSEQ("sta_linking_test", NULL, proc_set_sta_linking_test),
+#ifdef CONFIG_AP_MODE
+	RTW_PROC_HDL_SSEQ("ap_linking_test", NULL, proc_set_ap_linking_test),
+#endif
+
+	RTW_PROC_HDL_SSEQ("mac_reg_dump", proc_get_mac_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("bb_reg_dump", proc_get_bb_reg_dump, NULL),
+	RTW_PROC_HDL_SSEQ("bb_reg_dump_ex", proc_get_bb_reg_dump_ex, NULL),
+	RTW_PROC_HDL_SSEQ("rf_reg_dump", proc_get_rf_reg_dump, NULL),
+
+#ifdef CONFIG_RTW_LED
+	RTW_PROC_HDL_SSEQ("led_config", proc_get_led_config, proc_set_led_config),
+#endif
+
+#ifdef CONFIG_AP_MODE
+	RTW_PROC_HDL_SSEQ("aid_status", proc_get_aid_status, proc_set_aid_status),
+	RTW_PROC_HDL_SSEQ("all_sta_info", proc_get_all_sta_info, NULL),
+	RTW_PROC_HDL_SSEQ("bmc_tx_rate", proc_get_bmc_tx_rate, proc_set_bmc_tx_rate),
+#endif /* CONFIG_AP_MODE */
+
+#ifdef DBG_MEMORY_LEAK
+	RTW_PROC_HDL_SSEQ("_malloc_cnt", proc_get_malloc_cnt, NULL),
+#endif /* DBG_MEMORY_LEAK */
+
+#ifdef CONFIG_FIND_BEST_CHANNEL
+	RTW_PROC_HDL_SSEQ("best_channel", proc_get_best_channel, proc_set_best_channel),
+#endif
+
+	RTW_PROC_HDL_SSEQ("rx_signal", proc_get_rx_signal, proc_set_rx_signal),
+	RTW_PROC_HDL_SSEQ("hw_info", proc_get_hw_status, proc_set_hw_status),
+	RTW_PROC_HDL_SSEQ("mac_rptbuf", proc_get_mac_rptbuf, NULL),
+#ifdef CONFIG_80211N_HT
+	RTW_PROC_HDL_SSEQ("ht_enable", proc_get_ht_enable, proc_set_ht_enable),
+	RTW_PROC_HDL_SSEQ("bw_mode", proc_get_bw_mode, proc_set_bw_mode),
+	RTW_PROC_HDL_SSEQ("ampdu_enable", proc_get_ampdu_enable, proc_set_ampdu_enable),
+	RTW_PROC_HDL_SSEQ("rx_ampdu", proc_get_rx_ampdu, proc_set_rx_ampdu),
+	RTW_PROC_HDL_SSEQ("rx_ampdu_size_limit", proc_get_rx_ampdu_size_limit, proc_set_rx_ampdu_size_limit),
+	RTW_PROC_HDL_SSEQ("rx_ampdu_factor", proc_get_rx_ampdu_factor, proc_set_rx_ampdu_factor),
+	RTW_PROC_HDL_SSEQ("rx_ampdu_density", proc_get_rx_ampdu_density, proc_set_rx_ampdu_density),
 	RTW_PROC_HDL_SSEQ("tx_ampdu_density", proc_get_tx_ampdu_density, proc_set_tx_ampdu_density),
+	RTW_PROC_HDL_SSEQ("tx_max_agg_num", proc_get_tx_max_agg_num, proc_set_tx_max_agg_num),
 #ifdef CONFIG_TX_AMSDU
 	RTW_PROC_HDL_SSEQ("tx_amsdu", proc_get_tx_amsdu, proc_set_tx_amsdu),
 	RTW_PROC_HDL_SSEQ("tx_amsdu_rate", proc_get_tx_amsdu_rate, proc_set_tx_amsdu_rate),
 #endif
 #endif /* CONFIG_80211N_HT */
-	RTW_PROC_HDL_SSEQ("tx_max_agg_num", proc_get_tx_max_agg_num, proc_set_tx_max_agg_num),
 
 	RTW_PROC_HDL_SSEQ("en_fwps", proc_get_en_fwps, proc_set_en_fwps),
-	RTW_PROC_HDL_SSEQ("mac_rptbuf", proc_get_mac_rptbuf, NULL),
 
 	/* RTW_PROC_HDL_SSEQ("path_rssi", proc_get_two_path_rssi, NULL),
 	* 	RTW_PROC_HDL_SSEQ("rssi_disp",proc_get_rssi_disp, proc_set_rssi_disp), */
@@ -2781,6 +3880,10 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("sreset", proc_get_sreset, proc_set_sreset),
 #endif /* DBG_CONFIG_ERROR_DETECT */
 	RTW_PROC_HDL_SSEQ("trx_info_debug", proc_get_trx_info_debug, NULL),
+
+#ifdef CONFIG_HUAWEI_PROC
+	RTW_PROC_HDL_SSEQ("huawei_trx_info", proc_get_huawei_trx_info, NULL),
+#endif
 	RTW_PROC_HDL_SSEQ("linked_info_dump", proc_get_linked_info_dump, proc_set_linked_info_dump),
 	RTW_PROC_HDL_SSEQ("sta_tp_dump", proc_get_sta_tp_dump, proc_set_sta_tp_dump),
 	RTW_PROC_HDL_SSEQ("sta_tp_info", proc_get_sta_tp_info, NULL),
@@ -2812,6 +3915,11 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("tx_ring_ext", proc_get_tx_ring_ext, proc_set_tx_ring_ext),
 #endif
 	RTW_PROC_HDL_SSEQ("pci_aspm", proc_get_pci_aspm, NULL),
+
+	RTW_PROC_HDL_SSEQ("pci_conf_space", proc_get_pci_conf_space, proc_set_pci_conf_space),
+
+	RTW_PROC_HDL_SSEQ("pci_bridge_conf_space", proc_get_pci_bridge_conf_space, proc_set_pci_bridge_conf_space),
+
 #endif
 
 #ifdef CONFIG_WOWLAN
@@ -2839,13 +3947,19 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 #if CONFIG_RTW_PRE_LINK_STA
 	RTW_PROC_HDL_SSEQ("pre_link_sta", proc_get_pre_link_sta, proc_set_pre_link_sta),
 #endif
+	RTW_PROC_HDL_SSEQ("ch_sel_policy", proc_get_ch_sel_policy, proc_set_ch_sel_policy),
 #ifdef CONFIG_DFS_MASTER
-	RTW_PROC_HDL_SSEQ("dfs_master_test_case", proc_get_dfs_master_test_case, proc_set_dfs_master_test_case),
+	RTW_PROC_HDL_SSEQ("dfs_test_case", proc_get_dfs_test_case, proc_set_dfs_test_case),
 	RTW_PROC_HDL_SSEQ("update_non_ocp", NULL, proc_set_update_non_ocp),
 	RTW_PROC_HDL_SSEQ("radar_detect", NULL, proc_set_radar_detect),
 	RTW_PROC_HDL_SSEQ("dfs_ch_sel_d_flags", proc_get_dfs_ch_sel_d_flags, proc_set_dfs_ch_sel_d_flags),
+	#ifdef CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
+	RTW_PROC_HDL_SSEQ("dfs_slave_with_rd", proc_get_dfs_slave_with_rd, proc_set_dfs_slave_with_rd),
+	#endif
 #endif
+#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
 	RTW_PROC_HDL_SSEQ("new_bcn_max", proc_get_new_bcn_max, proc_set_new_bcn_max),
+#endif
 	RTW_PROC_HDL_SSEQ("sink_udpport", proc_get_udpport, proc_set_udpport),
 #ifdef DBG_RX_COUNTER_DUMP
 	RTW_PROC_HDL_SSEQ("dump_rx_cnt_mode", proc_get_rx_cnt_dump, proc_set_rx_cnt_dump),
@@ -2867,7 +3981,7 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("kfree_thermal", proc_get_kfree_thermal, proc_set_kfree_thermal),
 #endif
 #ifdef CONFIG_POWER_SAVING
-	RTW_PROC_HDL_SSEQ("ps_info", proc_get_ps_info, NULL),
+	RTW_PROC_HDL_SSEQ("ps_info", proc_get_ps_info, proc_set_ps_info),
 #ifdef CONFIG_WMMPS_STA
 	RTW_PROC_HDL_SSEQ("wmmps_info", proc_get_wmmps_info, proc_set_wmmps_info),
 #endif /* CONFIG_WMMPS_STA */	
@@ -2897,6 +4011,12 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("11w_tx_auth", proc_get_tx_auth, proc_set_tx_auth),
 #endif /* CONFIG_IEEE80211W */
 
+	RTW_PROC_HDL_SSEQ("tx_auth_monitor", NULL, proc_set_tx_auth_monitor),
+
+#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
+	RTW_PROC_HDL_SSEQ("pathb_phase", proc_get_pathb_phase, proc_set_pathb_phase),
+#endif
+
 #ifdef CONFIG_MBSSID_CAM
 	RTW_PROC_HDL_SSEQ("mbid_cam", proc_get_mbid_cam_cache, NULL),
 #endif
@@ -2909,10 +4029,11 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("tx_stat", proc_get_tx_stat, NULL),
 	/**** PHY Capability ****/
 	RTW_PROC_HDL_SSEQ("phy_cap", proc_get_phy_cap, NULL),
-
+#ifdef CONFIG_80211N_HT
 	RTW_PROC_HDL_SSEQ("rx_stbc", proc_get_rx_stbc, proc_set_rx_stbc),
 	RTW_PROC_HDL_SSEQ("stbc_cap", proc_get_stbc_cap, proc_set_stbc_cap),
 	RTW_PROC_HDL_SSEQ("ldpc_cap", proc_get_ldpc_cap, proc_set_ldpc_cap),
+#endif /* CONFIG_80211N_HT */
 #ifdef CONFIG_BEAMFORMING
 	RTW_PROC_HDL_SSEQ("txbf_cap", proc_get_txbf_cap, proc_set_txbf_cap),
 #endif
@@ -2939,7 +4060,56 @@ const struct rtw_proc_hdl adapter_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("ack_timeout", proc_get_ack_timeout, proc_set_ack_timeout),
 
 	RTW_PROC_HDL_SSEQ("dynamic_agg_enable", proc_get_dynamic_agg_enable, proc_set_dynamic_agg_enable),
-	RTW_PROC_HDL_SSEQ("iqk_fw_offload", proc_get_iqk_fw_offload, proc_set_iqk_fw_offload),
+	RTW_PROC_HDL_SSEQ("fw_offload", proc_get_fw_offload, proc_set_fw_offload),
+
+#ifdef CONFIG_RTW_MESH
+	#if CONFIG_RTW_MESH_ACNODE_PREVENT
+	RTW_PROC_HDL_SSEQ("mesh_acnode_prevent", proc_get_mesh_acnode_prevent, proc_set_mesh_acnode_prevent),
+	#endif
+	#if CONFIG_RTW_MESH_OFFCH_CAND
+	RTW_PROC_HDL_SSEQ("mesh_offch_cand", proc_get_mesh_offch_cand, proc_set_mesh_offch_cand),
+	#endif
+	#if CONFIG_RTW_MESH_PEER_BLACKLIST
+	RTW_PROC_HDL_SSEQ("mesh_peer_blacklist", proc_get_mesh_peer_blacklist, proc_set_mesh_peer_blacklist),
+	#endif
+	#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
+	RTW_PROC_HDL_SSEQ("mesh_cto_mgate_require", proc_get_mesh_cto_mgate_require, proc_set_mesh_cto_mgate_require),
+	RTW_PROC_HDL_SSEQ("mesh_cto_mgate_blacklist", proc_get_mesh_cto_mgate_blacklist, proc_set_mesh_cto_mgate_blacklist),
+	#endif
+	RTW_PROC_HDL_SSEQ("mesh_peer_sel_policy", proc_get_mesh_peer_sel_policy, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_networks", proc_get_mesh_networks, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_plink_ctl", proc_get_mesh_plink_ctl, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_mpath", proc_get_mesh_mpath, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_mpp", proc_get_mesh_mpp, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_known_gates", proc_get_mesh_known_gates, NULL),
+	#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
+	RTW_PROC_HDL_SSEQ("mesh_b2u_flags", proc_get_mesh_b2u_flags, proc_set_mesh_b2u_flags),
+	#endif
+	RTW_PROC_HDL_SSEQ("mesh_stats", proc_get_mesh_stats, NULL),
+	RTW_PROC_HDL_SSEQ("mesh_gate_timeout_factor", proc_get_mesh_gate_timeout, proc_set_mesh_gate_timeout),
+	RTW_PROC_HDL_SSEQ("mesh_gate_state", proc_get_mesh_gate_state, NULL),
+#endif
+#ifdef CONFIG_FW_HANDLE_TXBCN
+	RTW_PROC_HDL_SSEQ("fw_tbtt_rpt", proc_get_fw_tbtt_rpt, proc_set_fw_tbtt_rpt),
+#endif
+#ifdef CONFIG_LPS_CHK_BY_TP
+	RTW_PROC_HDL_SSEQ("lps_chk_tp", proc_get_lps_chk_tp, proc_set_lps_chk_tp),
+#endif
+#ifdef CONFIG_SUPPORT_STATIC_SMPS
+	RTW_PROC_HDL_SSEQ("smps", proc_get_smps, proc_set_smps),
+#endif
+
+	RTW_PROC_HDL_SSEQ("scan_deny", proc_get_scan_deny, proc_set_scan_deny),
+#ifdef CONFIG_RTW_TPT_MODE
+	RTW_PROC_HDL_SSEQ("tpt_mode", proc_get_tpt_mode, proc_set_tpt_mode),
+#endif
+
+#ifdef CONFIG_CTRL_TXSS_BY_TP
+	RTW_PROC_HDL_SSEQ("txss_tp", proc_get_txss_tp, proc_set_txss_tp),
+	#ifdef DBG_CTRL_TXSS
+	RTW_PROC_HDL_SSEQ("txss_ctrl", proc_get_txss_ctrl, proc_set_txss_ctrl),
+	#endif
+#endif
 
 };
 
@@ -3013,10 +4183,7 @@ ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, si
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
 	char tmp[32];
 	u32 th_l2h_ini;
-	u32 th_l2h_ini_mode2;
 	s8 th_edcca_hl_diff;
-	s8 th_edcca_hl_diff_mode2;
-	u8 edcca_enable;
 
 	if (count < 1)
 		return -EFAULT;
@@ -3028,12 +4195,12 @@ ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, si
 
 	if (buffer && !copy_from_user(tmp, buffer, count)) {
 
-		int num = sscanf(tmp, "%x %hhd %x %hhd %hhu", &th_l2h_ini, &th_edcca_hl_diff, &th_l2h_ini_mode2, &th_edcca_hl_diff_mode2, &edcca_enable);
+		int num = sscanf(tmp, "%x %hhd", &th_l2h_ini, &th_edcca_hl_diff);
 
-		if (num != 5)
+		if (num != 2)
 			return count;
 
-		rtw_odm_adaptivity_parm_set(padapter, (s8)th_l2h_ini, th_edcca_hl_diff, (s8)th_l2h_ini_mode2, th_edcca_hl_diff_mode2, edcca_enable);
+		rtw_odm_adaptivity_parm_set(padapter, (s8)th_l2h_ini, th_edcca_hl_diff);
 	}
 
 	return count;
@@ -3046,7 +4213,7 @@ int proc_get_phydm_cmd(struct seq_file *m, void *v)
 {
 	struct net_device *netdev;
 	PADAPTER padapter;
-	struct PHY_DM_STRUCT *phydm;
+	struct dm_struct *phydm;
 
 
 	netdev = m->private;
@@ -3073,7 +4240,7 @@ ssize_t proc_set_phydm_cmd(struct file *file, const char __user *buffer, size_t
 {
 	struct net_device *netdev;
 	PADAPTER padapter;
-	struct PHY_DM_STRUCT *phydm;
+	struct dm_struct *phydm;
 	char tmp[64] = {0};
 
 
@@ -3245,6 +4412,7 @@ void rtw_odm_proc_deinit(_adapter	*adapter)
 const struct rtw_proc_hdl mcc_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("mcc_info", proc_get_mcc_info, NULL),
 	RTW_PROC_HDL_SSEQ("mcc_enable", proc_get_mcc_info, proc_set_mcc_enable),
+	RTW_PROC_HDL_SSEQ("mcc_duration", proc_get_mcc_info, proc_set_mcc_duration),
 	RTW_PROC_HDL_SSEQ("mcc_single_tx_criteria", proc_get_mcc_info, proc_set_mcc_single_tx_criteria),
 	RTW_PROC_HDL_SSEQ("mcc_ap_bw20_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw20_target_tp),
 	RTW_PROC_HDL_SSEQ("mcc_ap_bw40_target_tp", proc_get_mcc_info, proc_set_mcc_ap_bw40_target_tp),
@@ -3252,7 +4420,7 @@ const struct rtw_proc_hdl mcc_proc_hdls[] = {
 	RTW_PROC_HDL_SSEQ("mcc_sta_bw20_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw20_target_tp),
 	RTW_PROC_HDL_SSEQ("mcc_sta_bw40_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw40_target_tp),
 	RTW_PROC_HDL_SSEQ("mcc_sta_bw80_target_tp", proc_get_mcc_info, proc_set_mcc_sta_bw80_target_tp),
-	RTW_PROC_HDL_SSEQ("mcc_policy_table", proc_get_mcc_policy_table, proc_set_mcc_policy_table),
+	RTW_PROC_HDL_SSEQ("mcc_policy_table", proc_get_mcc_policy_table, NULL),
 };
 
 const int mcc_proc_hdls_num = sizeof(mcc_proc_hdls) / sizeof(struct rtw_proc_hdl);
@@ -3379,7 +4547,6 @@ struct proc_dir_entry *rtw_adapter_proc_init(struct net_device *dev)
 	struct proc_dir_entry *dir_dev = NULL;
 	struct proc_dir_entry *entry = NULL;
 	_adapter *adapter = rtw_netdev_priv(dev);
-	u8 rf_type;
 	ssize_t i;
 
 	if (drv_proc == NULL) {
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.h
index c2c7c8ed8b8e..bdeace1928ee 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_proc.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_rhashtable.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_rhashtable.c
new file mode 100644
index 000000000000..3bbdc3c9140c
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_rhashtable.c
@@ -0,0 +1,75 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#ifdef CONFIG_RTW_MESH /* for now, only promised for kernel versions we support mesh */
+
+#include <drv_types.h>
+
+int rtw_rhashtable_walk_enter(rtw_rhashtable *ht, rtw_rhashtable_iter *iter)
+{
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 7, 0))
+	return rhashtable_walk_init((ht), (iter), GFP_ATOMIC);
+#else
+	/* kernel >= 4.4.0 rhashtable_walk_init use GFP_KERNEL to alloc, spin_lock for assignment */
+	iter->ht = ht;
+	iter->p = NULL;
+	iter->slot = 0;
+	iter->skip = 0;
+
+	iter->walker = kmalloc(sizeof(*iter->walker), GFP_ATOMIC);
+	if (!iter->walker)
+		return -ENOMEM;
+
+	spin_lock(&ht->lock);
+	iter->walker->tbl =
+		rcu_dereference_protected(ht->tbl, lockdep_is_held(&ht->lock));
+	list_add(&iter->walker->list, &iter->walker->tbl->walkers);
+	spin_unlock(&ht->lock);
+
+	return 0;
+#endif
+}
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25))
+static inline int is_vmalloc_addr(const void *x)
+{
+#ifdef CONFIG_MMU
+	unsigned long addr = (unsigned long)x;
+
+	return addr >= VMALLOC_START && addr < VMALLOC_END;
+#else
+	return 0;
+#endif
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25)) */
+
+void kvfree(const void *addr)
+{
+	if (is_vmalloc_addr(addr))
+		vfree(addr);
+	else
+		kfree(addr);
+}
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0)) */
+
+#include "rhashtable.c"
+
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0)) */
+
+#endif /* CONFIG_RTW_MESH */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_rhashtable.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_rhashtable.h
new file mode 100644
index 000000000000..a79cecc17007
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/rtw_rhashtable.h
@@ -0,0 +1,56 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2017 Realtek Corporation.
+ *
+ * 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_RHASHTABLE_H__
+#define __RTW_RHASHTABLE_H__
+
+#ifdef CONFIG_RTW_MESH /* for now, only promised for kernel versions we support mesh */
+
+/* directly reference rhashtable in kernel */
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0))
+#include <linux/rhashtable.h>
+#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 4, 0)) */
+
+/* Use rhashtable from kernel 4.4 */
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0))
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 0, 0))
+#define NULLS_MARKER(value) (1UL | (((long)value) << 1))
+#endif
+#include "rhashtable.h"
+#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0)) */
+
+typedef struct rhashtable rtw_rhashtable;
+typedef struct rhash_head rtw_rhash_head;
+typedef struct rhashtable_params rtw_rhashtable_params;
+
+#define rtw_rhashtable_init(ht, params) rhashtable_init(ht, params)
+
+typedef struct rhashtable_iter rtw_rhashtable_iter;
+
+int rtw_rhashtable_walk_enter(rtw_rhashtable *ht, rtw_rhashtable_iter *iter);
+#define rtw_rhashtable_walk_exit(iter) rhashtable_walk_exit(iter)
+#define rtw_rhashtable_walk_start(iter) rhashtable_walk_start(iter)
+#define rtw_rhashtable_walk_next(iter) rhashtable_walk_next(iter)
+#define rtw_rhashtable_walk_stop(iter) rhashtable_walk_stop(iter)
+
+#define rtw_rhashtable_free_and_destroy(ht, free_fn, arg) rhashtable_free_and_destroy((ht), (free_fn), (arg))
+#define rtw_rhashtable_lookup_fast(ht, key, params) rhashtable_lookup_fast((ht), (key), (params))
+#define rtw_rhashtable_lookup_insert_fast(ht, obj, params) rhashtable_lookup_insert_fast((ht), (obj), (params))
+#define rtw_rhashtable_remove_fast(ht, obj, params) rhashtable_remove_fast((ht), (obj), (params))
+
+#endif /* CONFIG_RTW_MESH */
+
+#endif /* __RTW_RHASHTABLE_H__ */
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_intf.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_intf.c
index 5538983273a6..312faacac07f 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_intf.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_intf.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -29,14 +30,7 @@
 #ifdef CONFIG_PLATFORM_INTEL_BYT
 #ifdef CONFIG_ACPI
 #include <linux/acpi.h>
-#ifdef CONFIG_GPIO_WAKEUP
-#include <linux/gpio.h>
-#endif
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,14,0))
-#include <linux/gpio/consumer.h>
-#else
 #include <linux/acpi_gpio.h>
-#endif
 #include "rtw_android.h"
 #endif
 static int wlan_en_gpio = -1;
@@ -73,6 +67,11 @@ static const struct sdio_device_id sdio_ids[] = {
 #ifdef CONFIG_RTL8188F
 	{SDIO_DEVICE(0x024c, 0xF179), .driver_data = RTL8188F},
 #endif
+
+#ifdef CONFIG_RTL8188GTV
+	{SDIO_DEVICE(0x024c, 0x018C), .driver_data = RTL8188GTV},
+#endif
+
 #ifdef CONFIG_RTL8822B
 	{SDIO_DEVICE(0x024c, 0xB822), .driver_data = RTL8822B},
 #endif
@@ -82,6 +81,11 @@ static const struct sdio_device_id sdio_ids[] = {
 	{ SDIO_DEVICE(0x024c, 0xD724), .driver_data = RTL8723D},
 #endif
 
+#ifdef CONFIG_RTL8192F
+	{ SDIO_DEVICE(0x024c, 0x818C), .driver_data = RTL8192F},/*A CUT*/
+	{ SDIO_DEVICE(0x024c, 0xF192), .driver_data = RTL8192F},/*B CUT*/
+#endif /* CONFIG_RTL8192F */
+
 #ifdef CONFIG_RTL8821C
 	{SDIO_DEVICE(0x024C, 0xB821), .driver_data = RTL8821C},
 	{SDIO_DEVICE(0x024C, 0xC821), .driver_data = RTL8821C},
@@ -99,11 +103,8 @@ static int rtw_drv_init(struct sdio_func *func, const struct sdio_device_id *id)
 static void rtw_dev_remove(struct sdio_func *func);
 static int rtw_sdio_resume(struct device *dev);
 static int rtw_sdio_suspend(struct device *dev);
-static void rtw_sdio_shutdown(struct device *dev);
 extern void rtw_dev_unload(PADAPTER padapter);
-#if defined(CONFIG_PLATFORM_INTEL_BYT)
-int rtw_sdio_set_power(struct sdio_func *func, int on);
-#endif /* CONFIG_PLATFORM_INTEL_BYT */
+
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 static const struct dev_pm_ops rtw_sdio_pm_ops = {
 	.suspend	= rtw_sdio_suspend,
@@ -123,7 +124,6 @@ static struct sdio_drv_priv sdio_drvpriv = {
 	.r871xs_drv.id_table = sdio_ids,
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29))
 	.r871xs_drv.drv = {
-		.shutdown = rtw_sdio_shutdown,
 		.pm = &rtw_sdio_pm_ops,
 	}
 #endif
@@ -231,7 +231,7 @@ static u8 gpio_hostwakeup_alloc_irq(PADAPTER padapter)
 	status = IRQF_NO_SUSPEND;
 #endif
 
-	if (HIGH_ACTIVE)
+	if (HIGH_ACTIVE_DEV2HST)
 		status |= IRQF_TRIGGER_RISING;
 	else
 		status |= IRQF_TRIGGER_FALLING;
@@ -463,6 +463,13 @@ static void rtw_decide_chip_type_by_device_id(struct dvobj_priv *dvobj, const st
 	}
 #endif
 
+#if defined(CONFIG_RTL8188GTV)
+	if (dvobj->chip_type == RTL8188GTV) {
+		dvobj->HardwareType = HARDWARE_TYPE_RTL8188GTVS;
+		RTW_INFO("CHIP TYPE: RTL8188GTV\n");
+	}
+#endif
+
 #if defined(CONFIG_RTL8822B)
 	if (dvobj->chip_type == RTL8822B) {
 		dvobj->HardwareType = HARDWARE_TYPE_RTL8822BS;
@@ -476,6 +483,13 @@ static void rtw_decide_chip_type_by_device_id(struct dvobj_priv *dvobj, const st
 		RTW_INFO("CHIP TYPE: RTL8821C\n");
 	}
 #endif
+
+#if defined(CONFIG_RTL8192F)
+	if (dvobj->chip_type == RTL8192F) {
+		dvobj->HardwareType = HARDWARE_TYPE_RTL8192FS;
+		RTW_INFO("CHIP TYPE: RTL8192F\n");
+	}
+#endif
 }
 
 static struct dvobj_priv *sdio_dvobj_init(struct sdio_func *func, const struct sdio_device_id  *pdid)
@@ -571,6 +585,11 @@ u8 rtw_set_hal_ops(PADAPTER padapter)
 		rtl8188fs_set_hal_ops(padapter);
 #endif
 
+#if defined(CONFIG_RTL8188GTV)
+	if (rtw_get_chip_type(padapter) == RTL8188GTV)
+		rtl8188gtvs_set_hal_ops(padapter);
+#endif
+
 #if defined(CONFIG_RTL8822B)
 	if (rtw_get_chip_type(padapter) == RTL8822B)
 		rtl8822bs_set_hal_ops(padapter);
@@ -583,6 +602,11 @@ u8 rtw_set_hal_ops(PADAPTER padapter)
 	}
 #endif
 
+#if defined(CONFIG_RTL8192F)
+	if (rtw_get_chip_type(padapter) == RTL8192F)
+		rtl8192fs_set_hal_ops(padapter);
+#endif
+
 	if (rtw_hal_ops_check(padapter) == _FAIL)
 		return _FAIL;
 
@@ -614,6 +638,11 @@ static void sd_intf_stop(PADAPTER padapter)
 	rtw_hal_disable_interrupt(padapter);
 }
 
+
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+PADAPTER g_test_adapter = NULL;
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
+
 _adapter *rtw_sdio_primary_adapter_init(struct dvobj_priv *dvobj)
 {
 	int status = _FAIL;
@@ -626,6 +655,9 @@ _adapter *rtw_sdio_primary_adapter_init(struct dvobj_priv *dvobj)
 	if (loadparam(padapter) != _SUCCESS)
 		goto free_adapter;
 
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+	g_test_adapter = padapter;
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 	padapter->dvobj = dvobj;
 
 	rtw_set_drv_stopped(padapter);/*init*/
@@ -702,6 +734,9 @@ free_hal_data:
 
 free_adapter:
 	if (status != _SUCCESS && padapter) {
+		#ifdef RTW_HALMAC
+		rtw_halmac_deinit_adapter(dvobj);
+		#endif
 		rtw_vmfree((u8 *)padapter, sizeof(*padapter));
 		padapter = NULL;
 	}
@@ -760,6 +795,9 @@ static void rtw_sdio_primary_adapter_deinit(_adapter *padapter)
 	rtd2885_wlan_netlink_sendMsg("linkdown", "8712");
 #endif
 
+#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
+	g_test_adapter = NULL;
+#endif /* RTW_SUPPORT_PLATFORM_SHUTDOWN */
 }
 
 /*
@@ -791,38 +829,6 @@ static int rtw_drv_init(
 	handle = ACPI_HANDLE(&func->dev);
 
 	if (handle) {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3,14,0))
-		struct gpio_desc *oob_gpio = NULL;
-		/* Dont try to do acpi pm for the wifi module */
-		if (!handle || acpi_bus_get_device(handle, &adev))
-			RTW_INFO("Could not get acpi pointer!\n");
-		else {
-			adev->power.flags.ignore_parent = 1;
-			adev->flags.power_manageable = 0;
-			RTW_INFO("Disabling ACPI power management support!\n");
-		}
-		//oob_irq = acpi_get_gpio_by_index(&func->dev, 0, NULL);
-		// KERNEL_VERSION >= 3.14 (change to how gpio index is found for irq, the
-		// acpi_get_gpio_by_index() is no longer an EXPORT_SYMBOL_GPL
-		oob_gpio = devm_gpiod_get_index(&func->dev,
-						"rtw_wifi_gpio_wakeup", 0);
-		if (IS_ERR_OR_NULL(oob_gpio)) {
-			pr_err("%s: failed to get GPIO descriptor\n", __func__);
-			goto exit;
-		}
-
-		if (gpiod_direction_input(oob_gpio)) {
-			pr_err("## %s Cannot set GPIO direction input\n", __FUNCTION__);
-			goto exit;
-		}
-
-		if ((oob_irq = gpiod_to_irq(oob_gpio)) < 0) {
-			pr_err("## %s Cannot convert GPIO to IRQ\n", __FUNCTION__);
-			goto exit;
-		}
-
-		RTW_INFO("## %s OOB_IRQ=%d\n", __FUNCTION__, oob_irq);
-#else
 		/* Dont try to do acpi pm for the wifi module */
 		if (!handle || acpi_bus_get_device(handle, &adev))
 			RTW_INFO("Could not get acpi pointer!\n");
@@ -833,12 +839,11 @@ static int rtw_drv_init(
 		oob_gpio = acpi_get_gpio_by_index(&func->dev, 0, NULL);
 		RTW_INFO("rtw_drv_init: ACPI_HANDLE found oob_gpio %d!\n", oob_gpio);
 		wifi_configure_gpio();
-#endif
 	} else
 		RTW_INFO("rtw_drv_init: ACPI_HANDLE NOT found!\n");
 #endif
 
-#if defined(CONFIG_ACPI) && (LINUX_VERSION_CODE < KERNEL_VERSION(3,14,0))
+#if defined(CONFIG_ACPI)
 	if (&func->dev && ACPI_HANDLE(&func->dev)) {
 		wlan_en_gpio = acpi_get_gpio_by_index(&func->dev, 1, NULL);
 		RTW_INFO("rtw_drv_init: ACPI_HANDLE found wlan_en %d!\n", wlan_en_gpio);
@@ -928,9 +933,6 @@ free_dvobj:
 	if (status != _SUCCESS)
 		sdio_dvobj_deinit(func);
 exit:
-#if defined(CONFIG_PLATFORM_INTEL_BYT)
-	rtw_sdio_set_power(func,0);
-#endif /* CONFIG_PLATFORM_INTEL_BYT */
 	return status == _SUCCESS ? 0 : -ENODEV;
 }
 
@@ -1110,43 +1112,6 @@ static int rtw_sdio_resume(struct device *dev)
 
 }
 
-static void rtw_sdio_shutdown(struct device *dev)
-{
-	struct sdio_func *func = dev_to_sdio_func(dev);
-	struct dvobj_priv *psdpriv = sdio_get_drvdata(func);
-	_adapter *padapter = psdpriv->padapters[IFACE_ID0];
-
-	u32 addr;
-	u8 tmp8, cnt = 0;
-
-	RTW_INFO("%s: enter\n", __func__);
-
-#ifdef CONFIG_FWLPS_IN_IPS
-	rtw_ps_deny(padapter, PS_DENY_DRV_REMOVE);
-	rtw_pm_set_ips(padapter, IPS_NONE);
-	rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
-	LeaveAllPowerSaveMode(padapter);
-#endif /* CONFIG_FWLPS_IN_IPS */
-
-	/* enable power down function */
-	/* 0x04[4] = 1 */
-	/* 0x05[7] = 1 */
-	addr = 0x04;
-	tmp8 = rtw_read8(padapter, addr);
-	tmp8 |= BIT(4);
-	rtw_write8(padapter, addr, tmp8);
-	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
-		FUNC_ADPT_ARG(padapter), addr, rtw_read8(padapter, addr));
-
-	addr = 0x05;
-	tmp8 = rtw_read8(padapter, addr);
-	tmp8 |= BIT(7);
-	rtw_write8(padapter, addr, tmp8);
-	RTW_INFO(FUNC_ADPT_FMT ": read after write 0x%x=0x%x\n",
-		FUNC_ADPT_ARG(padapter), addr, rtw_read8(padapter, addr));
-
-}
-
 static int rtw_drv_entry(void)
 {
 	int ret = 0;
@@ -1217,37 +1182,18 @@ static void rtw_drv_halt(void)
 	rtw_mstat_dump(RTW_DBGDUMP);
 }
 
-#if defined(CONFIG_PLATFORM_INTEL_BYT)
-int rtw_sdio_set_power(struct sdio_func *func, int on)
+#ifdef CONFIG_PLATFORM_INTEL_BYT
+int rtw_sdio_set_power(int on)
 {
-#if defined(CONFIG_ACPI)
-	acpi_handle *handle;
-	struct acpi_device *adev = NULL;
-	int ret;
-
-	handle = ACPI_HANDLE(&func->dev);
-	if (IS_ERR_OR_NULL(handle))
-		return -ENOENT;
 
-	acpi_bus_get_device(handle, &adev);
-	if (!adev)
-		return -ENOENT;
-
-	RTW_INFO("turn wifi %s\n", on ? "on" : "off");
-
-	adev->flags.power_manageable = 1;
-
-	if (on)
-		ret = acpi_device_set_power(adev, ACPI_STATE_D0);
-	else
-		ret = acpi_device_set_power(adev, ACPI_STATE_D3_COLD);
-
-	adev->flags.power_manageable = 0;
+	if (wlan_en_gpio >= 0) {
+		if (on)
+			gpio_set_value(wlan_en_gpio, 1);
+		else
+			gpio_set_value(wlan_en_gpio, 0);
+	}
 
-	return ret;
-#else
 	return 0;
-#endif
 }
 #endif /* CONFIG_PLATFORM_INTEL_BYT */
 
@@ -1305,6 +1251,6 @@ EXPORT_SYMBOL(rockchip_wifi_init_module_rtkwifi);
 EXPORT_SYMBOL(rockchip_wifi_exit_module_rtkwifi);
 #endif
 #endif
+
 //module_init(rtw_drv_entry);
 //module_exit(rtw_drv_halt);
-
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_ops_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_ops_linux.c
index 583641888ff1..c3ce78f8633c 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_ops_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/sdio_ops_linux.c
@@ -1,6 +1,7 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
+ * Copyright(c) 2007 - 2018 Realtek Corporation.
  *
  * 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
@@ -864,6 +865,13 @@ s32 sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)
 
 #if 1
 /*#define RTW_SDIO_DUMP*/
+#ifdef RTW_SDIO_DUMP
+#define DUMP_LEN_LMT	0	/* buffer dump size limit */
+				/* unit: byte, 0 for no limit */
+#else 
+#define DUMP_LEN_LMT	32
+#endif
+#define GET_DUMP_LEN(len)	(DUMP_LEN_LMT ? MIN(len, DUMP_LEN_LMT) : len)
 
 /**
  *	Returns driver error code,
@@ -982,7 +990,7 @@ int __must_check rtw_sdio_raw_read(struct dvobj_priv *d, unsigned int addr,
 #ifdef RTW_SDIO_DUMP
 	print_hex_dump(KERN_DEBUG, "rtw_sdio: READ ",
 		       DUMP_PREFIX_OFFSET, 16, 1,
-		       buf, len, false);
+		       buf, GET_DUMP_LEN(len), false);
 #endif /* RTW_SDIO_DUMP */
 
 	if (WARN_ON(error)) {
@@ -997,7 +1005,7 @@ int __must_check rtw_sdio_raw_read(struct dvobj_priv *d, unsigned int addr,
 		dev_err(&func->dev, "rtw_sdio: READ from 0x%05x, %zu bytes\n", addr, len);
 		print_hex_dump(KERN_ERR, "rtw_sdio: READ ",
 			       DUMP_PREFIX_OFFSET, 16, 1,
-			       buf, len, false);
+			       buf, GET_DUMP_LEN(len), false);
 #endif /* !RTW_SDIO_DUMP */
 	}
 
@@ -1049,7 +1057,7 @@ int __must_check rtw_sdio_raw_write(struct dvobj_priv *d, unsigned int addr,
 	dev_dbg(&func->dev, "rtw_sdio: WRITE to 0x%05x\n", addr);
 	print_hex_dump(KERN_DEBUG, "rtw_sdio: WRITE ",
 		       DUMP_PREFIX_OFFSET, 16, 1,
-		       buf, len, false);
+		       buf, GET_DUMP_LEN(len), false);
 #endif /* RTW_SDIO_DUMP */
 
 	if (claim_needed)
@@ -1111,7 +1119,7 @@ int __must_check rtw_sdio_raw_write(struct dvobj_priv *d, unsigned int addr,
 		dev_err(&func->dev, "rtw_sdio: WRITE to 0x%05x, %zu bytes\n", addr, len);
 		print_hex_dump(KERN_ERR, "rtw_sdio: WRITE ",
 			       DUMP_PREFIX_OFFSET, 16, 1,
-			       buf, len, false);
+			       buf, GET_DUMP_LEN(len), false);
 #endif /* !RTW_SDIO_DUMP */
 	}
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/wifi_regd.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/wifi_regd.c
index c710b25b0d83..ddc5aa99a221 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/wifi_regd.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/wifi_regd.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2009-2010 - 2017 Realtek Corporation.
@@ -252,66 +253,10 @@ static void _rtw_reg_apply_active_scan_flags(struct wiphy *wiphy,
 }
 #endif
 
-/*
- * Always apply Radar/DFS rules on
- * freq range 5260 MHz - 5700 MHz
- */
-static void _rtw_reg_apply_radar_flags(struct wiphy *wiphy)
+void rtw_regd_apply_flags(struct wiphy *wiphy)
 {
-	struct ieee80211_supported_band *sband;
-	struct ieee80211_channel *ch;
-	unsigned int i;
-
-	if (!wiphy->bands[NL80211_BAND_5GHZ])
-		return;
-
-	sband = wiphy->bands[NL80211_BAND_5GHZ];
-
-	for (i = 0; i < sband->n_channels; i++) {
-		ch = &sband->channels[i];
-		if (!rtw_is_dfs_ch(ch->hw_value))
-			continue;
-#ifdef CONFIG_DFS
-		if (!(ch->flags & IEEE80211_CHAN_DISABLED)
-			#if defined(CONFIG_DFS_MASTER)
-			&& rtw_odm_dfs_domain_unknown(wiphy_to_adapter(wiphy))
-			#endif
-		) {
-			ch->flags |= IEEE80211_CHAN_RADAR;
-			#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
-			ch->flags |= (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
-			#else
-			ch->flags |= IEEE80211_CHAN_NO_IR;
-			#endif
-		}
-#endif /* CONFIG_DFS */
-
-#if 0
-		/*
-		 * We always enable radar detection/DFS on this
-		 * frequency range. Additionally we also apply on
-		 * this frequency range:
-		 * - If STA mode does not yet have DFS supports disable
-		 *  active scanning
-		 * - If adhoc mode does not support DFS yet then disable
-		 *  adhoc in the frequency.
-		 * - If AP mode does not yet support radar detection/DFS
-		 *  do not allow AP mode
-		 */
-		if (!(ch->flags & IEEE80211_CHAN_DISABLED))
-			ch->flags |= IEEE80211_CHAN_RADAR |
-				     IEEE80211_CHAN_NO_IBSS |
-				     IEEE80211_CHAN_PASSIVE_SCAN;
-#endif
-	}
-}
-
-static void _rtw_reg_apply_flags(struct wiphy *wiphy)
-{
-#if 1				/* by channel plan */
-	_adapter *padapter = wiphy_to_adapter(wiphy);
-	struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
-	u8 channel_plan = rfctl->ChannelPlan;
+	struct dvobj_priv *dvobj = wiphy_to_dvobj(wiphy);
+	struct rf_ctl_t *rfctl = dvobj_to_rfctl(dvobj);
 	RT_CHANNEL_INFO *channel_set = rfctl->channel_set;
 	u8 max_chan_nums = rfctl->max_chan_nums;
 
@@ -341,109 +286,37 @@ static void _rtw_reg_apply_flags(struct wiphy *wiphy)
 		freq = rtw_ch2freq(channel);
 
 		ch = ieee80211_get_channel(wiphy, freq);
-		if (ch) {
-			if (channel_set[i].ScanType == SCAN_PASSIVE
-				#if defined(CONFIG_DFS_MASTER)
-				&& rtw_odm_dfs_domain_unknown(wiphy_to_adapter(wiphy))
-				#endif
-			) {
-				#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
-				ch->flags = (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
-				#else
-				ch->flags = IEEE80211_CHAN_NO_IR;
-				#endif
-			} else
-				ch->flags = 0;
-		}
-	}
-
-#else
-	struct ieee80211_supported_band *sband;
-	struct ieee80211_channel *ch;
-	unsigned int i, j;
-	u16 channels[37] = {
-		1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56,
-		60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140,
-		149, 153,
-		157, 161, 165
-	};
-	u16 channel;
-	u32 freq;
-
-	for (i = 0; i < NUM_NL80211_BANDS; i++) {
-		sband = wiphy->bands[i];
-
-		if (sband)
-			for (j = 0; j < sband->n_channels; j++) {
-				ch = &sband->channels[j];
-
-				if (ch)
-					ch->flags = IEEE80211_CHAN_DISABLED;
-			}
-	}
+		if (!ch)
+			continue;
 
-	for (i = 0; i < 37; i++) {
-		channel = channels[i];
-		freq = rtw_ch2freq(channel);
+		if (channel_set[i].ScanType == SCAN_PASSIVE
+			#if defined(CONFIG_DFS_MASTER)
+			&& rtw_odm_dfs_domain_unknown(dvobj)
+			#endif
+		) {
+			#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+			ch->flags = (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
+			#else
+			ch->flags = IEEE80211_CHAN_NO_IR;
+			#endif
+		} else
+			ch->flags = 0;
 
-		ch = ieee80211_get_channel(wiphy, freq);
-		if (ch) {
-			if (channel <= 11)
-				ch->flags = 0;
-			else
-				ch->flags = 0;	/* IEEE80211_CHAN_PASSIVE_SCAN; */
+		#ifdef CONFIG_DFS
+		if (rtw_is_dfs_ch(ch->hw_value)
+			#if defined(CONFIG_DFS_MASTER)
+			&& rtw_odm_dfs_domain_unknown(dvobj)
+			#endif
+		) {
+			ch->flags |= IEEE80211_CHAN_RADAR;
+			#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+			ch->flags |= (IEEE80211_CHAN_NO_IBSS | IEEE80211_CHAN_PASSIVE_SCAN);
+			#else
+			ch->flags |= IEEE80211_CHAN_NO_IR;
+			#endif
 		}
-		/* printk("%s: freq %d(%d) flag 0x%02X\n", __func__, freq, channel, ch->flags); */
-	}
-#endif
-}
-
-static void _rtw_reg_apply_world_flags(struct wiphy *wiphy,
-				       enum nl80211_reg_initiator initiator,
-				       struct rtw_regulatory *reg)
-{
-	/* _rtw_reg_apply_beaconing_flags(wiphy, initiator); */
-	/* _rtw_reg_apply_active_scan_flags(wiphy, initiator); */
-	return;
-}
-
-static int _rtw_reg_notifier_apply(struct wiphy *wiphy,
-				   struct regulatory_request *request,
-				   struct rtw_regulatory *reg)
-{
-
-	/* Hard code flags */
-	_rtw_reg_apply_flags(wiphy);
-
-	/* We always apply this */
-	_rtw_reg_apply_radar_flags(wiphy);
-
-	switch (request->initiator) {
-	case NL80211_REGDOM_SET_BY_DRIVER:
-		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_DRIVER");
-		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
-					   reg);
-		break;
-	case NL80211_REGDOM_SET_BY_CORE:
-		RTW_INFO("%s: %s\n", __func__,
-			 "NL80211_REGDOM_SET_BY_CORE to DRV");
-		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
-					   reg);
-		break;
-	case NL80211_REGDOM_SET_BY_USER:
-		RTW_INFO("%s: %s\n", __func__,
-			 "NL80211_REGDOM_SET_BY_USER to DRV");
-		_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER,
-					   reg);
-		break;
-	case NL80211_REGDOM_SET_BY_COUNTRY_IE:
-		RTW_INFO("%s: %s\n", __func__,
-			 "NL80211_REGDOM_SET_BY_COUNTRY_IE");
-		_rtw_reg_apply_world_flags(wiphy, request->initiator, reg);
-		break;
+		#endif /* CONFIG_DFS */
 	}
-
-	return 0;
 }
 
 static const struct ieee80211_regdomain *_rtw_regdomain_select(struct
@@ -461,41 +334,45 @@ static const struct ieee80211_regdomain *_rtw_regdomain_select(struct
 #endif
 }
 
-void _rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
+static void rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
 {
-	struct rtw_regulatory *reg = NULL;
-
-	RTW_INFO("%s\n", __func__);
+	switch (request->initiator) {
+	case NL80211_REGDOM_SET_BY_DRIVER:
+		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_DRIVER");
+		break;
+	case NL80211_REGDOM_SET_BY_CORE:
+		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_CORE");
+		break;
+	case NL80211_REGDOM_SET_BY_USER:
+		RTW_INFO("%s: %s alpha2:%c%c\n", __func__, "NL80211_REGDOM_SET_BY_USER"
+			, request->alpha2[0], request->alpha2[1]);
+		rtw_set_country(wiphy_to_adapter(wiphy), request->alpha2);
+		break;
+	case NL80211_REGDOM_SET_BY_COUNTRY_IE:
+		RTW_INFO("%s: %s\n", __func__, "NL80211_REGDOM_SET_BY_COUNTRY_IE");
+		break;
+	}
 
-	_rtw_reg_notifier_apply(wiphy, request, reg);
+	rtw_regd_apply_flags(wiphy);
 }
 
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
-int rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
-#else
-void rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)
-#endif
+static int rtw_reg_notifier_return(struct wiphy *wiphy, struct regulatory_request *request)
 {
-	_rtw_reg_notifier(wiphy, request);
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
+	rtw_reg_notifier(wiphy, request);
 	return 0;
-#endif
-}
-
-void rtw_reg_notify_by_driver(_adapter *adapter)
-{
-	if ((adapter->rtw_wdev != NULL) && (adapter->rtw_wdev->wiphy)) {
-		struct regulatory_request request;
-		request.initiator = NL80211_REGDOM_SET_BY_DRIVER;
-		rtw_reg_notifier(adapter->rtw_wdev->wiphy, &request);
-	}
 }
+#endif
 
 static void _rtw_regd_init_wiphy(struct rtw_regulatory *reg, struct wiphy *wiphy)
 {
 	const struct ieee80211_regdomain *regd;
 
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 9, 0))
+	wiphy->reg_notifier = rtw_reg_notifier_return;
+#else
 	wiphy->reg_notifier = rtw_reg_notifier;
+#endif
 
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
 	wiphy->flags |= WIPHY_FLAG_CUSTOM_REGULATORY;
@@ -510,10 +387,7 @@ static void _rtw_regd_init_wiphy(struct rtw_regulatory *reg, struct wiphy *wiphy
 	regd = _rtw_regdomain_select(reg);
 	wiphy_apply_custom_regulatory(wiphy, regd);
 
-	/* Hard code flags */
-	_rtw_reg_apply_flags(wiphy);
-	_rtw_reg_apply_radar_flags(wiphy);
-	_rtw_reg_apply_world_flags(wiphy, NL80211_REGDOM_SET_BY_DRIVER, reg);
+	rtw_regd_apply_flags(wiphy);
 }
 
 static struct country_code_to_enum_rd *_rtw_regd_find_country(u16 countrycode)
@@ -527,10 +401,8 @@ static struct country_code_to_enum_rd *_rtw_regd_find_country(u16 countrycode)
 	return NULL;
 }
 
-int rtw_regd_init(_adapter *padapter)
+int rtw_regd_init(struct wiphy *wiphy)
 {
-	struct wiphy *wiphy = padapter->rtw_wdev->wiphy;
-
 #if 0
 	if (rtw_regd == NULL) {
 		rtw_regd = (struct rtw_regulatory *)
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/xmit_linux.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/xmit_linux.c
index 570249c4dce8..328b8df6c442 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/xmit_linux.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/linux/xmit_linux.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -65,36 +66,41 @@ sint rtw_endofpktfile(struct pkt_file *pfile)
 
 void rtw_set_tx_chksum_offload(_pkt *pkt, struct pkt_attrib *pattrib)
 {
-
-#ifdef CONFIG_TCP_CSUM_OFFLOAD_TX
+#ifdef CONFIG_TX_CSUM_OFFLOAD	
 	struct sk_buff *skb = (struct sk_buff *)pkt;
-	pattrib->hw_tcp_csum = 0;
-
-	if (skb->ip_summed == CHECKSUM_PARTIAL) {
-		if (skb_shinfo(skb)->nr_frags == 0) {
-			const struct iphdr *ip = ip_hdr(skb);
-			if (ip->protocol == IPPROTO_TCP) {
-				/* TCP checksum offload by HW */
-				RTW_INFO("CHECKSUM_PARTIAL TCP\n");
-				pattrib->hw_tcp_csum = 1;
-				/* skb_checksum_help(skb); */
-			} else if (ip->protocol == IPPROTO_UDP) {
-				/* RTW_INFO("CHECKSUM_PARTIAL UDP\n"); */
-#if 1
-				skb_checksum_help(skb);
-#else
-				/* Set UDP checksum = 0 to skip checksum check */
-				struct udphdr *udp = skb_transport_header(skb);
-				udp->check = 0;
-#endif
-			} else {
-				RTW_INFO("%s-%d TCP CSUM offload Error!!\n", __FUNCTION__, __LINE__);
-				WARN_ON(1);     /* we need a WARN() */
-			}
-		} else { /* IP fragmentation case */
-			RTW_INFO("%s-%d nr_frags != 0, using skb_checksum_help(skb);!!\n", __FUNCTION__, __LINE__);
-			skb_checksum_help(skb);
-		}
+	struct iphdr *iph = NULL;
+	struct ipv6hdr *i6ph = NULL;
+	struct udphdr *uh = NULL;
+	struct tcphdr *th = NULL;
+	u8 	protocol = 0xFF;
+
+	if (skb->protocol == htons(ETH_P_IP)) {
+		iph = (struct iphdr *)skb_network_header(skb);
+		protocol = iph->protocol;
+	} else if (skb->protocol == htons(ETH_P_IPV6)) {
+		i6ph = (struct ipv6hdr *)skb_network_header(skb);
+		protocol = i6ph->nexthdr;
+	} else
+		{}
+
+	/*	For HW rule, clear ipv4_csum & UDP/TCP_csum if it is UDP/TCP packet	*/
+	switch (protocol) {
+	case IPPROTO_UDP:
+		uh = (struct udphdr *)skb_transport_header(skb);
+		uh->check = 0;
+		if (iph)
+			iph->check = 0;
+		pattrib->hw_csum = _TRUE;
+		break;
+	case IPPROTO_TCP:
+		th = (struct tcphdr *)skb_transport_header(skb);
+		th->check = 0;
+		if (iph)
+			iph->check = 0;
+		pattrib->hw_csum = _TRUE;
+		break;
+	default:
+		break;
 	}
 #endif
 
@@ -313,7 +319,6 @@ void rtw_os_xmit_schedule(_adapter *padapter)
 static bool rtw_check_xmit_resource(_adapter *padapter, _pkt *pkt)
 {
 	bool busy = _FALSE;
-	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
 	u16	qidx;
 
@@ -404,9 +409,9 @@ int rtw_mlcst2unicst(_adapter *padapter, struct sk_buff *skb)
 		}
 
 		/* avoid come from STA1 and send back STA1 */
-		if (_rtw_memcmp(psta->cmn.mac_addr, &skb->data[6], 6) == _TRUE
-			|| _rtw_memcmp(psta->cmn.mac_addr, null_addr, 6) == _TRUE
-			|| _rtw_memcmp(psta->cmn.mac_addr, bc_addr, 6) == _TRUE
+		if (_rtw_memcmp(psta->cmn.mac_addr, &skb->data[6], ETH_ALEN) == _TRUE
+			|| _rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) == _TRUE
+			|| _rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) == _TRUE
 		) {
 			DBG_COUNTER(padapter->tx_logs.os_tx_m2u_ignore_self);
 			continue;
@@ -417,7 +422,7 @@ int rtw_mlcst2unicst(_adapter *padapter, struct sk_buff *skb)
 		newskb = rtw_skb_copy(skb);
 
 		if (newskb) {
-			_rtw_memcpy(newskb->data, psta->cmn.mac_addr, 6);
+			_rtw_memcpy(newskb->data, psta->cmn.mac_addr, ETH_ALEN);
 			res = rtw_xmit(padapter, &newskb);
 			if (res < 0) {
 				DBG_COUNTER(padapter->tx_logs.os_tx_m2u_entry_err_xmit);
@@ -445,14 +450,14 @@ int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
 	_adapter *padapter = (_adapter *)rtw_netdev_priv(pnetdev);
 	struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
 #ifdef CONFIG_TX_MCAST2UNI
-	struct mlme_priv	*pmlmepriv = &padapter->mlmepriv;
 	extern int rtw_mc2u_disable;
 #endif /* CONFIG_TX_MCAST2UNI	 */
-	s32 res = 0;
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
-	u16 queue;
+#ifdef CONFIG_TX_CSUM_OFFLOAD	
+	struct sk_buff *skb = pkt;
+	struct sk_buff *segs, *nskb;
+	netdev_features_t features = padapter->pnetdev->features;
 #endif
-
+	s32 res = 0;
 
 	if (padapter->registrypriv.mp_mode) {
 		RTW_INFO("MP_TX_DROP_OS_FRAME\n");
@@ -472,7 +477,7 @@ int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
 
 #ifdef CONFIG_TX_MCAST2UNI
 	if (!rtw_mc2u_disable
-		&& (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter))
+		&& MLME_IS_AP(padapter)
 		&& (IP_MCAST_MAC(pkt->data)
 			|| ICMPV6_MCAST_MAC(pkt->data)
 			#ifdef CONFIG_TX_BCAST2UNI
@@ -493,6 +498,33 @@ int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)
 	}
 #endif /* CONFIG_TX_MCAST2UNI	 */
 
+#ifdef CONFIG_TX_CSUM_OFFLOAD
+	if (skb_shinfo(skb)->gso_size) {
+	/*	split a big(65k) skb into several small(1.5k) skbs */
+		features &= ~(NETIF_F_TSO | NETIF_F_TSO6);
+		segs = skb_gso_segment(skb, features);
+		if (IS_ERR(segs) || !segs)
+			goto drop_packet;
+
+		do {
+			nskb = segs;
+			segs = segs->next;
+			nskb->next = NULL;
+			rtw_mstat_update( MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, nskb->truesize);
+			res = rtw_xmit(padapter, &nskb);
+			if (res < 0) {
+				#ifdef DBG_TX_DROP_FRAME
+				RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit fail\n", __FUNCTION__);
+				#endif
+				pxmitpriv->tx_drop++;
+				rtw_os_pkt_complete(padapter, nskb);
+			}
+		} while (segs);
+		rtw_os_pkt_complete(padapter, skb);
+		goto exit;
+	}
+#endif
+
 	res = rtw_xmit(padapter, &pkt);
 	if (res < 0) {
 		#ifdef DBG_TX_DROP_FRAME
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/osdep_service.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/osdep_service.c
index cfa603b516ec..54984b6d9301 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/osdep_service.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/os_dep/osdep_service.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2017 Realtek Corporation.
@@ -73,9 +74,9 @@ u32 rtw_atoi(u8 *s)
 
 }
 
-inline u8 *_rtw_vmalloc(u32 sz)
+inline void *_rtw_vmalloc(u32 sz)
 {
-	u8	*pbuf;
+	void *pbuf;
 #ifdef PLATFORM_LINUX
 	pbuf = vmalloc(sz);
 #endif
@@ -99,9 +100,9 @@ inline u8 *_rtw_vmalloc(u32 sz)
 	return pbuf;
 }
 
-inline u8 *_rtw_zvmalloc(u32 sz)
+inline void *_rtw_zvmalloc(u32 sz)
 {
-	u8	*pbuf;
+	void *pbuf;
 #ifdef PLATFORM_LINUX
 	pbuf = _rtw_vmalloc(sz);
 	if (pbuf != NULL)
@@ -119,7 +120,7 @@ inline u8 *_rtw_zvmalloc(u32 sz)
 	return pbuf;
 }
 
-inline void _rtw_vmfree(u8 *pbuf, u32 sz)
+inline void _rtw_vmfree(void *pbuf, u32 sz)
 {
 #ifdef PLATFORM_LINUX
 	vfree(pbuf);
@@ -139,15 +140,14 @@ inline void _rtw_vmfree(u8 *pbuf, u32 sz)
 #endif /* DBG_MEMORY_LEAK */
 }
 
-u8 *_rtw_malloc(u32 sz)
+void *_rtw_malloc(u32 sz)
 {
-
-	u8	*pbuf = NULL;
+	void *pbuf = NULL;
 
 #ifdef PLATFORM_LINUX
 #ifdef RTK_DMP_PLATFORM
 	if (sz > 0x4000)
-		pbuf = (u8 *)dvr_malloc(sz);
+		pbuf = dvr_malloc(sz);
 	else
 #endif
 		pbuf = kmalloc(sz, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
@@ -176,12 +176,12 @@ u8 *_rtw_malloc(u32 sz)
 }
 
 
-u8 *_rtw_zmalloc(u32 sz)
+void *_rtw_zmalloc(u32 sz)
 {
 #ifdef PLATFORM_FREEBSD
 	return malloc(sz, M_DEVBUF, M_ZERO | M_NOWAIT);
 #else /* PLATFORM_FREEBSD */
-	u8	*pbuf = _rtw_malloc(sz);
+	void *pbuf = _rtw_malloc(sz);
 
 	if (pbuf != NULL) {
 
@@ -199,7 +199,7 @@ u8 *_rtw_zmalloc(u32 sz)
 #endif /* PLATFORM_FREEBSD */
 }
 
-void	_rtw_mfree(u8 *pbuf, u32 sz)
+void _rtw_mfree(void *pbuf, u32 sz)
 {
 
 #ifdef PLATFORM_LINUX
@@ -236,8 +236,8 @@ struct sk_buff *dev_alloc_skb(unsigned int size)
 	struct sk_buff *skb = NULL;
 	u8 *data = NULL;
 
-	/* skb = (struct sk_buff *)_rtw_zmalloc(sizeof(struct sk_buff)); */ /* for skb->len, etc. */
-	skb = (struct sk_buff *)_rtw_malloc(sizeof(struct sk_buff));
+	/* skb = _rtw_zmalloc(sizeof(struct sk_buff)); */ /* for skb->len, etc. */
+	skb = _rtw_malloc(sizeof(struct sk_buff));
 	if (!skb)
 		goto out;
 	data = _rtw_malloc(size);
@@ -254,7 +254,7 @@ struct sk_buff *dev_alloc_skb(unsigned int size)
 out:
 	return skb;
 nodata:
-	_rtw_mfree((u8 *)skb, sizeof(struct sk_buff));
+	_rtw_mfree(skb, sizeof(struct sk_buff));
 	skb = NULL;
 	goto out;
 
@@ -267,7 +267,7 @@ void dev_kfree_skb_any(struct sk_buff *skb)
 		_rtw_mfree(skb->head, 0);
 	/* printf("%s()-%d: skb = %p\n", __FUNCTION__, __LINE__, skb); */
 	if (skb)
-		_rtw_mfree((u8 *)skb, 0);
+		_rtw_mfree(skb, 0);
 }
 struct sk_buff *skb_clone(const struct sk_buff *skb)
 {
@@ -569,9 +569,9 @@ bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size)
 	return _FALSE;
 }
 
-inline u8 *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8  *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
 		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
@@ -587,9 +587,9 @@ inline u8 *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, c
 	return p;
 }
 
-inline u8 *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8 *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
 		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
@@ -605,7 +605,7 @@ inline u8 *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func,
 	return p;
 }
 
-inline void dbg_rtw_vmfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void dbg_rtw_vmfree(void *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
 
 	if (match_mstat_sniff_rules(flags, sz))
@@ -620,9 +620,9 @@ inline void dbg_rtw_vmfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const cha
 	);
 }
 
-inline u8 *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8 *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
 		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
@@ -638,9 +638,9 @@ inline u8 *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, co
 	return p;
 }
 
-inline u8 *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
-	u8 *p;
+	void *p;
 
 	if (match_mstat_sniff_rules(flags, sz))
 		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
@@ -656,7 +656,7 @@ inline u8 *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, c
 	return p;
 }
 
-inline void dbg_rtw_mfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
+inline void dbg_rtw_mfree(void *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)
 {
 	if (match_mstat_sniff_rules(flags, sz))
 		RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%d)\n", func, line, __FUNCTION__, (sz));
@@ -890,6 +890,17 @@ inline void rtw_os_pkt_free(_pkt *pkt)
 #endif
 }
 
+inline _pkt *rtw_os_pkt_copy(_pkt *pkt)
+{
+#if defined(PLATFORM_LINUX)
+	return rtw_skb_copy(pkt);
+#elif defined(PLATFORM_FREEBSD)
+	return m_dup(pkt, M_NOWAIT);
+#else
+	#error "TBD\n"
+#endif
+}
+
 inline void *rtw_os_pkt_data(_pkt *pkt)
 {
 #if defined(PLATFORM_LINUX)
@@ -934,7 +945,7 @@ inline void _rtw_memmove(void *dst, const void *src, u32 sz)
 #if defined(PLATFORM_LINUX)
 	memmove(dst, src, sz);
 #else
-	#warning "no implementation\n"
+	#error "TBD\n"
 #endif
 }
 
@@ -1094,6 +1105,83 @@ void rtw_list_insert_tail(_list *plist, _list *phead)
 
 }
 
+inline void rtw_list_splice(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	list_splice(list, head);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_list_splice_init(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	list_splice_init(list, head);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_list_splice_tail(_list *list, _list *head)
+{
+#ifdef PLATFORM_LINUX
+	#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27))
+	if (!list_empty(list))
+		__list_splice(list, head);
+	#else
+	list_splice_tail(list, head);
+	#endif
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_head_init(rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	INIT_HLIST_HEAD(h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_add_head(rtw_hlist_node *n, rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	hlist_add_head(n, h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_del(rtw_hlist_node *n)
+{
+#ifdef PLATFORM_LINUX
+	hlist_del(n);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_add_head_rcu(rtw_hlist_node *n, rtw_hlist_head *h)
+{
+#ifdef PLATFORM_LINUX
+	hlist_add_head_rcu(n, h);
+#else
+	#error "TBD\n"
+#endif
+}
+
+inline void rtw_hlist_del_rcu(rtw_hlist_node *n)
+{
+#ifdef PLATFORM_LINUX
+	hlist_del_rcu(n);
+#else
+	#error "TBD\n"
+#endif
+}
+
 void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc, void *ctx)
 {
 	_adapter *adapter = (_adapter *)padapter;
@@ -1492,17 +1580,40 @@ inline systime _rtw_ms_to_systime(u32 ms)
 #endif
 }
 
+inline systime _rtw_us_to_systime(u32 us)
+{
+#ifdef PLATFORM_LINUX
+	return usecs_to_jiffies(us);
+#else
+	#error "TBD\n"
+#endif
+}
+
 /* the input parameter start use the same unit as returned by rtw_get_current_time */
 inline s32 _rtw_get_passing_time_ms(systime start)
 {
 	return _rtw_systime_to_ms(_rtw_get_current_time() - start);
 }
 
+inline s32 _rtw_get_remaining_time_ms(systime end)
+{
+	return _rtw_systime_to_ms(end - _rtw_get_current_time());
+}
+
 inline s32 _rtw_get_time_interval_ms(systime start, systime end)
 {
 	return _rtw_systime_to_ms(end - start);
 }
 
+inline bool _rtw_time_after(systime a, systime b)
+{
+#ifdef PLATFORM_LINUX
+	return time_after(a, b);
+#else
+	#error "TBD\n"
+#endif
+}
+
 void rtw_sleep_schedulable(int ms)
 {
 
@@ -1698,56 +1809,49 @@ void rtw_yield_os(void)
 #endif
 }
 
+bool rtw_macaddr_is_larger(const u8 *a, const u8 *b)
+{
+	u32 va, vb;
+
+	va = be32_to_cpu(*((u32 *)a));
+	vb = be32_to_cpu(*((u32 *)b));
+	if (va > vb)
+		return 1;
+	else if (va < vb)
+		return 0;
+
+	return be16_to_cpu(*((u16 *)(a + 4))) > be16_to_cpu(*((u16 *)(b + 4)));
+}
+
 #define RTW_SUSPEND_LOCK_NAME "rtw_wifi"
-#define RTW_SUSPEND_EXT_LOCK_NAME "rtw_wifi_ext"
-#define RTW_SUSPEND_RX_LOCK_NAME "rtw_wifi_rx"
 #define RTW_SUSPEND_TRAFFIC_LOCK_NAME "rtw_wifi_traffic"
 #define RTW_SUSPEND_RESUME_LOCK_NAME "rtw_wifi_resume"
-#define RTW_RESUME_SCAN_LOCK_NAME "rtw_wifi_scan"
 #ifdef CONFIG_WAKELOCK
 static struct wake_lock rtw_suspend_lock;
-static struct wake_lock rtw_suspend_ext_lock;
-static struct wake_lock rtw_suspend_rx_lock;
 static struct wake_lock rtw_suspend_traffic_lock;
 static struct wake_lock rtw_suspend_resume_lock;
-static struct wake_lock rtw_resume_scan_lock;
 #elif defined(CONFIG_ANDROID_POWER)
 static android_suspend_lock_t rtw_suspend_lock = {
 	.name = RTW_SUSPEND_LOCK_NAME
 };
-static android_suspend_lock_t rtw_suspend_ext_lock = {
-	.name = RTW_SUSPEND_EXT_LOCK_NAME
-};
-static android_suspend_lock_t rtw_suspend_rx_lock = {
-	.name = RTW_SUSPEND_RX_LOCK_NAME
-};
 static android_suspend_lock_t rtw_suspend_traffic_lock = {
 	.name = RTW_SUSPEND_TRAFFIC_LOCK_NAME
 };
 static android_suspend_lock_t rtw_suspend_resume_lock = {
 	.name = RTW_SUSPEND_RESUME_LOCK_NAME
 };
-static android_suspend_lock_t rtw_resume_scan_lock = {
-	.name = RTW_RESUME_SCAN_LOCK_NAME
-};
 #endif
 
 inline void rtw_suspend_lock_init(void)
 {
 #ifdef CONFIG_WAKELOCK
 	wake_lock_init(&rtw_suspend_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_LOCK_NAME);
-	wake_lock_init(&rtw_suspend_ext_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_EXT_LOCK_NAME);
-	wake_lock_init(&rtw_suspend_rx_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_RX_LOCK_NAME);
 	wake_lock_init(&rtw_suspend_traffic_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_TRAFFIC_LOCK_NAME);
 	wake_lock_init(&rtw_suspend_resume_lock, WAKE_LOCK_SUSPEND, RTW_SUSPEND_RESUME_LOCK_NAME);
-	wake_lock_init(&rtw_resume_scan_lock, WAKE_LOCK_SUSPEND, RTW_RESUME_SCAN_LOCK_NAME);
 #elif defined(CONFIG_ANDROID_POWER)
 	android_init_suspend_lock(&rtw_suspend_lock);
-	android_init_suspend_lock(&rtw_suspend_ext_lock);
-	android_init_suspend_lock(&rtw_suspend_rx_lock);
 	android_init_suspend_lock(&rtw_suspend_traffic_lock);
 	android_init_suspend_lock(&rtw_suspend_resume_lock);
-	android_init_suspend_lock(&rtw_resume_scan_lock);
 #endif
 }
 
@@ -1755,18 +1859,12 @@ inline void rtw_suspend_lock_uninit(void)
 {
 #ifdef CONFIG_WAKELOCK
 	wake_lock_destroy(&rtw_suspend_lock);
-	wake_lock_destroy(&rtw_suspend_ext_lock);
-	wake_lock_destroy(&rtw_suspend_rx_lock);
 	wake_lock_destroy(&rtw_suspend_traffic_lock);
 	wake_lock_destroy(&rtw_suspend_resume_lock);
-	wake_lock_destroy(&rtw_resume_scan_lock);
 #elif defined(CONFIG_ANDROID_POWER)
 	android_uninit_suspend_lock(&rtw_suspend_lock);
-	android_uninit_suspend_lock(&rtw_suspend_ext_lock);
-	android_uninit_suspend_lock(&rtw_suspend_rx_lock);
 	android_uninit_suspend_lock(&rtw_suspend_traffic_lock);
 	android_uninit_suspend_lock(&rtw_suspend_resume_lock);
-	android_uninit_suspend_lock(&rtw_resume_scan_lock);
 #endif
 }
 
@@ -1831,45 +1929,42 @@ inline void rtw_lock_suspend_timeout(u32 timeout_ms)
 #endif
 }
 
-inline void rtw_lock_ext_suspend_timeout(u32 timeout_ms)
+
+inline void rtw_lock_traffic_suspend_timeout(u32 timeout_ms)
 {
 #ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_suspend_ext_lock, rtw_ms_to_systime(timeout_ms));
+	wake_lock_timeout(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
 #elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_suspend_ext_lock, rtw_ms_to_systime(timeout_ms));
+	android_lock_suspend_auto_expire(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
 #endif
-	/* RTW_INFO("EXT lock timeout:%d\n", timeout_ms); */
+	/* RTW_INFO("traffic lock timeout:%d\n", timeout_ms); */
 }
 
-inline void rtw_lock_rx_suspend_timeout(u32 timeout_ms)
+inline void rtw_set_bit(int nr, unsigned long *addr)
 {
-#ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_suspend_rx_lock, rtw_ms_to_systime(timeout_ms));
-#elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_suspend_rx_lock, rtw_ms_to_systime(timeout_ms));
+#ifdef PLATFORM_LINUX
+	set_bit(nr, addr);
+#else
+	#error "TBD\n";
 #endif
-	/* RTW_INFO("RX lock timeout:%d\n", timeout_ms); */
 }
 
-
-inline void rtw_lock_traffic_suspend_timeout(u32 timeout_ms)
+inline void rtw_clear_bit(int nr, unsigned long *addr)
 {
-#ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
-#elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_suspend_traffic_lock, rtw_ms_to_systime(timeout_ms));
+#ifdef PLATFORM_LINUX
+	clear_bit(nr, addr);
+#else
+	#error "TBD\n";
 #endif
-	/* RTW_INFO("traffic lock timeout:%d\n", timeout_ms); */
 }
 
-inline void rtw_lock_resume_scan_timeout(u32 timeout_ms)
+inline int rtw_test_and_clear_bit(int nr, unsigned long *addr)
 {
-#ifdef CONFIG_WAKELOCK
-	wake_lock_timeout(&rtw_resume_scan_lock, rtw_ms_to_systime(timeout_ms));
-#elif defined(CONFIG_ANDROID_POWER)
-	android_lock_suspend_auto_expire(&rtw_resume_scan_lock, rtw_ms_to_systime(timeout_ms));
+#ifdef PLATFORM_LINUX
+	return test_and_clear_bit(nr, addr);
+#else
+	#error "TBD\n";
 #endif
-	/* RTW_INFO("resume scan lock:%d\n", timeout_ms); */
 }
 
 inline void ATOMIC_SET(ATOMIC_T *v, int i)
@@ -1985,6 +2080,23 @@ inline int ATOMIC_DEC_RETURN(ATOMIC_T *v)
 #endif
 }
 
+inline bool ATOMIC_INC_UNLESS(ATOMIC_T *v, int u)
+{
+#ifdef PLATFORM_LINUX
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 15))
+	return atomic_add_unless(v, 1, u);
+#else
+	/* only make sure not exceed after this function */
+	if (ATOMIC_INC_RETURN(v) > u) {
+		ATOMIC_DEC(v);
+		return 0;
+	}
+	return 1;
+#endif
+#else
+	#error "TBD\n"
+#endif
+}
 
 #ifdef PLATFORM_LINUX
 /*
@@ -2032,7 +2144,9 @@ static int readFile(struct file *fp, char *buf, int len)
 		return -EPERM;
 
 	while (sum < len) {
-#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 14, 0))
+		rlen = kernel_read(fp, buf + sum, len - sum, &fp->f_pos);
+#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
 		rlen = __vfs_read(fp, buf + sum, len - sum, &fp->f_pos);
 #else
 		rlen = fp->f_op->read(fp, buf + sum, len - sum, &fp->f_pos);
@@ -2731,6 +2845,167 @@ exit:
 	return val;
 }
 
+int rtw_blacklist_add(_queue *blist, const u8 *addr, u32 timeout_ms)
+{
+	struct blacklist_ent *ent;
+	_list *list, *head;
+	u8 exist = _FALSE, timeout = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			exist = _TRUE;
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time))
+				timeout = _TRUE;
+			ent->exp_time = rtw_get_current_time()
+				+ rtw_ms_to_systime(timeout_ms);
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	if (exist == _FALSE) {
+		ent = rtw_malloc(sizeof(struct blacklist_ent));
+		if (ent) {
+			_rtw_memcpy(ent->addr, addr, ETH_ALEN);
+			ent->exp_time = rtw_get_current_time()
+				+ rtw_ms_to_systime(timeout_ms);
+			rtw_list_insert_tail(&ent->list, head);
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return (exist == _TRUE && timeout == _FALSE) ? RTW_ALREADY : (ent ? _SUCCESS : _FAIL);
+}
+
+int rtw_blacklist_del(_queue *blist, const u8 *addr)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+	u8 exist = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+			exist = _TRUE;
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return exist == _TRUE ? _SUCCESS : RTW_ALREADY;
+}
+
+int rtw_blacklist_search(_queue *blist, const u8 *addr)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+	u8 exist = _FALSE;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+
+		if (_rtw_memcmp(ent->addr, addr, ETH_ALEN) == _TRUE) {
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+				rtw_list_delete(&ent->list);
+				rtw_mfree(ent, sizeof(struct blacklist_ent));
+			} else
+				exist = _TRUE;
+			break;
+		}
+
+		if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
+			rtw_list_delete(&ent->list);
+			rtw_mfree(ent, sizeof(struct blacklist_ent));
+		}
+	}
+
+	exit_critical_bh(&blist->lock);
+
+exit:
+	return exist;
+}
+
+void rtw_blacklist_flush(_queue *blist)
+{
+	struct blacklist_ent *ent;
+	_list *list, *head;
+	_list tmp;
+
+	_rtw_init_listhead(&tmp);
+
+	enter_critical_bh(&blist->lock);
+	rtw_list_splice_init(&blist->queue, &tmp);
+	exit_critical_bh(&blist->lock);
+
+	head = &tmp;
+	list = get_next(head);
+	while (rtw_end_of_queue_search(head, list) == _FALSE) {
+		ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+		list = get_next(list);
+		rtw_list_delete(&ent->list);
+		rtw_mfree(ent, sizeof(struct blacklist_ent));
+	}
+}
+
+void dump_blacklist(void *sel, _queue *blist, const char *title)
+{
+	struct blacklist_ent *ent = NULL;
+	_list *list, *head;
+
+	enter_critical_bh(&blist->lock);
+	head = &blist->queue;
+	list = get_next(head);
+
+	if (rtw_end_of_queue_search(head, list) == _FALSE) {
+		if (title)
+			RTW_PRINT_SEL(sel, "%s:\n", title);
+	
+		while (rtw_end_of_queue_search(head, list) == _FALSE) {
+			ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
+			list = get_next(list);
+
+			if (rtw_time_after(rtw_get_current_time(), ent->exp_time))
+				RTW_PRINT_SEL(sel, MAC_FMT" expired\n", MAC_ARG(ent->addr));
+			else
+				RTW_PRINT_SEL(sel, MAC_FMT" %u\n", MAC_ARG(ent->addr)
+					, rtw_get_remaining_time_ms(ent->exp_time));
+		}
+
+	}
+	exit_critical_bh(&blist->lock);
+}
+
 /**
 * is_null -
 *
@@ -2819,3 +3094,44 @@ inline char alpha_to_upper(char c)
 		c = 'A' + (c - 'a');
 	return c;
 }
+
+int hex2num_i(char c)
+{
+	if (c >= '0' && c <= '9')
+		return c - '0';
+	if (c >= 'a' && c <= 'f')
+		return c - 'a' + 10;
+	if (c >= 'A' && c <= 'F')
+		return c - 'A' + 10;
+	return -1;
+}
+
+int hex2byte_i(const char *hex)
+{
+	int a, b;
+	a = hex2num_i(*hex++);
+	if (a < 0)
+		return -1;
+	b = hex2num_i(*hex++);
+	if (b < 0)
+		return -1;
+	return (a << 4) | b;
+}
+
+int hexstr2bin(const char *hex, u8 *buf, size_t len)
+{
+	size_t i;
+	int a;
+	const char *ipos = hex;
+	u8 *opos = buf;
+
+	for (i = 0; i < len; i++) {
+		a = hex2byte_i(ipos);
+		if (a < 0)
+			return -1;
+		*opos++ = a;
+		ipos += 2;
+	}
+	return 0;
+}
+
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/custom_country_chplan.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/custom_country_chplan.h
index f8cc13bf10c3..30322fa85a6b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/custom_country_chplan.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/custom_country_chplan.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUN50IW1P1_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUN50IW1P1_sdio.c
index 2586455de8c3..76df77886d70 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUN50IW1P1_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUN50IW1P1_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNnI_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNnI_sdio.c
index 8a52aa90cb0d..11e0736b31c0 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNnI_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNnI_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_sdio.c
index 795b7e7f7998..c1937844918d 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_usb.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_usb.c
index 9c2abc4f6f44..caf6a6ecabd7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_usb.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_SUNxI_usb.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_WMT_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_WMT_sdio.c
index d85002c15fd3..b4f59209b4ee 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_WMT_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ARM_WMT_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_RTK_DMP_usb.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_RTK_DMP_usb.c
index cb740b2eebb5..cd15f96d157a 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_RTK_DMP_usb.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_RTK_DMP_usb.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_aml_s905_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_aml_s905_sdio.c
new file mode 100644
index 000000000000..1ce4e06fd2d4
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_aml_s905_sdio.c
@@ -0,0 +1,55 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/printk.h>		/* pr_info(() */
+#include <linux/delay.h>		/* msleep() */
+#include "platform_aml_s905_sdio.h"	/* sdio_reinit() and etc */
+
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+	ret = wifi_setup_dt();
+	if (ret) {
+		pr_err("%s: setup dt failed!!(%d)\n", __func__, ret);
+		return -1;
+	}
+#endif /* kernel < 3.14.0 */
+
+#if 0 /* Seems redundancy? Already done before insert driver */
+	pr_info("######%s:\n", __func__);
+	extern_wifi_set_enable(0);
+	msleep(500);
+	extern_wifi_set_enable(1);
+	msleep(500);
+	sdio_reinit();
+#endif
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+	wifi_teardown_dt();
+#endif /* kernel < 3.14.0 */
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_aml_s905_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_aml_s905_sdio.h
new file mode 100644
index 000000000000..f8cebf1073a5
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_aml_s905_sdio.h
@@ -0,0 +1,29 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_AML_S905_SDIO_H__
+#define __PLATFORM_AML_S905_SDIO_H__
+
+#include <linux/version.h>	/* Linux vresion */
+
+extern void sdio_reinit(void);
+extern void extern_wifi_set_enable(int is_on);
+
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 14, 0))
+extern void wifi_teardown_dt(void);
+extern int wifi_setup_dt(void);
+#endif /* kernel < 3.14.0 */
+
+#endif /* __PLATFORM_AML_S905_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_arm_act_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_arm_act_sdio.c
index ad7b6cfed455..a106b36aa290 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_arm_act_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_arm_act_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_hisilicon_hi3798_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_hisilicon_hi3798_sdio.c
new file mode 100644
index 000000000000..4ecbcf0add29
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_hisilicon_hi3798_sdio.c
@@ -0,0 +1,111 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/delay.h>		/* mdelay() */
+#include <mach/hardware.h>		/* __io_address(), readl(), writel() */
+#include "platform_hisilicon_hi3798_sdio.h"	/* HI_S32() and etc. */
+
+typedef enum hi_GPIO_DIR_E {
+	HI_DIR_OUT = 0,
+	HI_DIR_IN  = 1,
+} HI_GPIO_DIR_E;
+
+#define RTL_REG_ON_GPIO		(4*8 + 3)
+
+#define REG_BASE_CTRL		__io_address(0xf8a20008)
+
+int gpio_wlan_reg_on = RTL_REG_ON_GPIO;
+#if 0
+module_param(gpio_wlan_reg_on, uint, 0644);
+MODULE_PARM_DESC(gpio_wlan_reg_on, "wlan reg_on gpio num (default:gpio4_3)");
+#endif
+
+static int hi_gpio_set_value(u32 gpio, u32 value)
+{
+	HI_S32 s32Status;
+
+	s32Status = HI_DRV_GPIO_SetDirBit(gpio, HI_DIR_OUT);
+	if (s32Status != HI_SUCCESS) {
+		pr_err("gpio(%d) HI_DRV_GPIO_SetDirBit HI_DIR_OUT failed\n",
+			gpio);
+		return -1;
+	}
+
+	s32Status = HI_DRV_GPIO_WriteBit(gpio, value);
+	if (s32Status != HI_SUCCESS) {
+		pr_err("gpio(%d) HI_DRV_GPIO_WriteBit value(%d) failed\n",
+			gpio, value);
+		return -1;
+	}
+
+	return 0;
+}
+
+static int hisi_wlan_set_carddetect(bool present)
+{
+	u32 regval;
+	u32 mask;
+
+
+#ifndef CONFIG_HISI_SDIO_ID
+	return;
+#endif
+	pr_info("SDIO ID=%d\n", CONFIG_HISI_SDIO_ID);
+#if (CONFIG_HISI_SDIO_ID == 1)
+	mask = 1;
+#elif (CONFIG_HISI_SDIO_ID == 0)
+	mask = 2;
+#endif
+
+	regval = readl(REG_BASE_CTRL);
+	if (present) {
+		pr_info("====== Card detection to detect SDIO card! ======\n");
+		/* set card_detect low to detect card */
+		regval |= mask;
+	} else {
+		pr_info("====== Card detection to remove SDIO card! ======\n");
+		/* set card_detect high to remove card */
+		regval &= ~(mask);
+	}
+	writel(regval, REG_BASE_CTRL);
+
+	return 0;
+}
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others: power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+
+	hi_gpio_set_value(gpio_wlan_reg_on, 1);
+	mdelay(100);
+	hisi_wlan_set_carddetect(1);
+	mdelay(2000);
+	pr_info("======== set_carddetect delay 2s! ========\n");
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	hisi_wlan_set_carddetect(0);
+	mdelay(100);
+	hi_gpio_set_value(gpio_wlan_reg_on, 0);
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_hisilicon_hi3798_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_hisilicon_hi3798_sdio.h
new file mode 100644
index 000000000000..07a4e6a6e62b
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_hisilicon_hi3798_sdio.h
@@ -0,0 +1,29 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2017 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_HISILICON_HI3798_SDIO_H__
+#define __PLATFORM_HISILICON_HI3798_SDIO_H__
+
+typedef unsigned int	HI_U32;
+
+typedef int		HI_S32;
+
+#define HI_SUCCESS	0
+#define HI_FAILURE	(-1)
+
+extern HI_S32 HI_DRV_GPIO_SetDirBit(HI_U32 u32GpioNo, HI_U32 u32DirBit);
+extern HI_S32 HI_DRV_GPIO_WriteBit(HI_U32 u32GpioNo, HI_U32 u32BitValue);
+
+#endif /* __PLATFORM_HISILICON_HI3798_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.c
index c281dcb8f121..a3b8f9e36908 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
@@ -25,6 +26,7 @@ int platform_wifi_power_on(void)
 	int ret = 0;
 
 	oob_irq = rockchip_wifi_get_oob_irq();
+
 	return ret;
 }
 
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.h
index 12caf3c853a1..6f8588e8670b 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.h
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_ops.h
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_sprd_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_sprd_sdio.c
index 34061d05d428..4a0240f491a7 100644
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_sprd_sdio.c
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_sprd_sdio.c
@@ -1,3 +1,4 @@
+/* SPDX-License-Identifier: GPL-2.0 */
 /******************************************************************************
  *
  * Copyright(c) 2013 - 2017 Realtek Corporation.
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_zte_zx296716_sdio.c b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_zte_zx296716_sdio.c
new file mode 100644
index 000000000000..abd82a0ca28e
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_zte_zx296716_sdio.c
@@ -0,0 +1,54 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 <linux/printk.h>		/* pr_info(() */
+#include <linux/delay.h>		/* msleep() */
+#include "platform_zte_zx296716_sdio.h"	/* sdio_reinit() and etc */
+
+
+/*
+ * Return:
+ *	0:	power on successfully
+ *	others:	power on failed
+ */
+int platform_wifi_power_on(void)
+{
+	int ret = 0;
+
+	pr_info("######%s: disable--1--\n", __func__);
+	extern_wifi_set_enable(0);
+	/*msleep(500);*/ /* add in function:extern_wifi_set_enable */
+	pr_info("######%s: enable--2---\n", __func__);
+	extern_wifi_set_enable(1);
+	/*msleep(500);*/
+	sdio_reinit();
+
+	return ret;
+}
+
+void platform_wifi_power_off(void)
+{
+	int card_val;
+
+	pr_info("######%s:\n", __func__);
+#ifdef CONFIG_A16T03_BOARD
+	card_val = sdio_host_is_null();
+	if (card_val)
+		remove_card();
+#endif /* CONFIG_A16T03_BOARD */
+	extern_wifi_set_enable(0);
+
+	/*msleep(500);*/
+}
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_zte_zx296716_sdio.h b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_zte_zx296716_sdio.h
new file mode 100644
index 000000000000..a03647ccf664
--- /dev/null
+++ b/drivers/net/wireless/rockchip_wlan/rtl8723ds/platform/platform_zte_zx296716_sdio.h
@@ -0,0 +1,26 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/******************************************************************************
+ *
+ * Copyright(c) 2016 - 2018 Realtek Corporation.
+ *
+ * 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 __PLATFORM_ZTE_ZX296716_SDIO_H__
+#define __PLATFORM_ZTE_ZX296716_SDIO_H__
+
+extern void sdio_reinit(void);
+extern void extern_wifi_set_enable(int val);
+#ifdef CONFIG_A16T03_BOARD
+extern int sdio_host_is_null(void);
+extern void remove_card(void);
+#endif /* CONFIG_A16T03_BOARD */
+
+#endif /* __PLATFORM_ZTE_ZX296716_SDIO_H__ */
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8723ds/tags b/drivers/net/wireless/rockchip_wlan/rtl8723ds/tags
deleted file mode 100644
index a083150d24c6..000000000000
--- a/drivers/net/wireless/rockchip_wlan/rtl8723ds/tags
+++ /dev/null
@@ -1,44665 +0,0 @@
-!_TAG_FILE_FORMAT	2	/extended format; --format=1 will not append ;" to lines/
-!_TAG_FILE_SORTED	1	/0=unsorted, 1=sorted, 2=foldcase/
-!_TAG_PROGRAM_AUTHOR	Darren Hiebert	/dhiebert@users.sourceforge.net/
-!_TAG_PROGRAM_NAME	Exuberant Ctags	//
-!_TAG_PROGRAM_URL	http://ctags.sourceforge.net	/official site/
-!_TAG_PROGRAM_VERSION	5.9~svn20110310	//
-A2dp_rate	include/rtw_btcoex.h	/^	u8 A2dp_rate:1;$/;"	m	struct:btinfo_8761ATV
-AAP	include/hal_com_reg.h	1544;"	d
-AB	include/hal_com_reg.h	1547;"	d
-ACF	include/hal_com_reg.h	1556;"	d
-ACI_AIFSN	include/wifi.h	/^	unsigned char		ACI_AIFSN;$/;"	m	struct:AC_param
-ACLK_VLD	include/hal_com_reg.h	1254;"	d
-ACL_TRx_TP_high	include/rtw_btcoex.h	/^	u8 ACL_TRx_TP_high;$/;"	m	struct:btinfo_8761ATV
-ACL_TRx_TP_low	include/rtw_btcoex.h	/^	u8 ACL_TRx_TP_low;$/;"	m	struct:btinfo_8761ATV
-ACQUIRE_GLOBAL_MUTEX	include/osdep_service_bsd.h	718;"	d
-ACQUIRE_GLOBAL_MUTEX	include/osdep_service_ce.h	159;"	d
-ACQUIRE_GLOBAL_MUTEX	include/osdep_service_linux.h	338;"	d
-ACQUIRE_GLOBAL_MUTEX	include/osdep_service_xp.h	169;"	d
-ACRC	include/hal_com_reg.h	1538;"	d
-ACRC32	include/hal_com_reg.h	1553;"	d
-ACS	hal/phydm/phydm_acs.h	/^}ACS, *PACS;$/;"	t	typeref:struct:_ACS_
-ACS_DISABLE	include/hal_data.h	/^	ACS_DISABLE,$/;"	e	enum:_ACS_STATE
-ACS_ENABLE	include/hal_data.h	/^	ACS_ENABLE,$/;"	e	enum:_ACS_STATE
-ACS_INIT	include/hal_data.h	/^	ACS_INIT,		\/*ACS - Variable init*\/$/;"	e	enum:_ACS_OP
-ACS_NHM_SETTING	hal/phydm/phydm_acs.h	33;"	d
-ACS_OP	include/hal_data.h	/^} ACS_OP;$/;"	t	typeref:enum:_ACS_OP
-ACS_RESET	include/hal_data.h	/^	ACS_RESET,		\/*ACS - NHM Counter reset*\/$/;"	e	enum:_ACS_OP
-ACS_SELECT	include/hal_data.h	/^	ACS_SELECT,		\/*ACS - NHM Counter Statistics *\/$/;"	e	enum:_ACS_OP
-ACS_STATE	include/hal_data.h	/^} ACS_STATE;$/;"	t	typeref:enum:_ACS_STATE
-ACS_Step	hal/phydm/phydm_acs.h	/^    u1Byte              ACS_Step;$/;"	m	struct:_ACS_
-ACS_VERSION	hal/phydm/phydm_acs.h	24;"	d
-ACTIVE_TP_THRESHOLD	hal/phydm/phydm_rainfo.h	39;"	d
-ACT_CAT_VENDOR	include/wifi.h	764;"	d
-ACT_PUBLIC_BSSCOEXIST	include/ieee80211.h	/^	ACT_PUBLIC_BSSCOEXIST = 0, \/* 20\/40 BSS Coexistence *\/$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_DSE_DEENABLE	include/ieee80211.h	/^	ACT_PUBLIC_DSE_DEENABLE = 2,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_DSE_ENABLE	include/ieee80211.h	/^	ACT_PUBLIC_DSE_ENABLE = 1,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_DSE_MSR_REQ	include/ieee80211.h	/^	ACT_PUBLIC_DSE_MSR_REQ = 5,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_DSE_MSR_RPRT	include/ieee80211.h	/^	ACT_PUBLIC_DSE_MSR_RPRT = 6,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_DSE_PWR_CONSTRAINT	include/ieee80211.h	/^	ACT_PUBLIC_DSE_PWR_CONSTRAINT = 8,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_DSE_REG_LOCATION	include/ieee80211.h	/^	ACT_PUBLIC_DSE_REG_LOCATION = 3,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_EXT_CHL_SWITCH	include/ieee80211.h	/^	ACT_PUBLIC_EXT_CHL_SWITCH = 4,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_GAS_COMEBACK_REQ	include/ieee80211.h	/^	ACT_PUBLIC_GAS_COMEBACK_REQ = 12,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_GAS_COMEBACK_RSP	include/ieee80211.h	/^	ACT_PUBLIC_GAS_COMEBACK_RSP = 13,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_GAS_INITIAL_REQ	include/ieee80211.h	/^	ACT_PUBLIC_GAS_INITIAL_REQ = 10,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_GAS_INITIAL_RSP	include/ieee80211.h	/^	ACT_PUBLIC_GAS_INITIAL_RSP = 11,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_LOCATION_TRACK	include/ieee80211.h	/^	ACT_PUBLIC_LOCATION_TRACK = 15,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_MAX	include/ieee80211.h	/^	ACT_PUBLIC_MAX$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_MP	include/ieee80211.h	/^	ACT_PUBLIC_MP = 7, \/* Measurement Pilot *\/$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_TDLS_DISCOVERY_RSP	include/ieee80211.h	/^	ACT_PUBLIC_TDLS_DISCOVERY_RSP = 14,$/;"	e	enum:_PUBLIC_ACTION
-ACT_PUBLIC_VENDOR	include/ieee80211.h	/^	ACT_PUBLIC_VENDOR = 9, \/* for WIFI_DIRECT *\/$/;"	e	enum:_PUBLIC_ACTION
-AC_PARAM_AIFS_OFFSET	include/hal_com_reg.h	1485;"	d
-AC_PARAM_ECW_MAX_OFFSET	include/hal_com_reg.h	1483;"	d
-AC_PARAM_ECW_MIN_OFFSET	include/hal_com_reg.h	1484;"	d
-AC_PARAM_TXOP_LIMIT_OFFSET	include/hal_com_reg.h	1482;"	d
-AC_param	include/wifi.h	/^struct AC_param {$/;"	s
-ADAPTER	hal/phydm/phydm.h	/^} ADAPTER, *PADAPTER;$/;"	t	typeref:struct:_ADAPTER
-ADAPTER	include/drv_types.h	/^typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;$/;"	t	typeref:struct:
-ADAPTER_TX_BW_2G	include/drv_types.h	1194;"	d
-ADAPTER_TX_BW_2G	include/drv_types.h	1197;"	d
-ADAPTER_TX_BW_5G	include/drv_types.h	1195;"	d
-ADAPTER_TX_BW_5G	include/drv_types.h	1198;"	d
-ADAPTIVITY_STATISTICS	hal/phydm/phydm_adaptivity.h	/^} ADAPTIVITY_STATISTICS, *PADAPTIVITY_STATISTICS;$/;"	t	typeref:struct:_ADAPTIVITY_STATISTICS
-ADAPTIVITY_VERSION	hal/phydm/phydm_adaptivity.h	25;"	d
-ADCSMP_BB_TRIG	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_BB_TRIG, $/;"	e	enum:_RT_ADCSMP_TRIG_SEL
-ADCSMP_MAC_TRIG	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_MAC_TRIG, $/;"	e	enum:_RT_ADCSMP_TRIG_SEL
-ADCSMP_STATE_IDLE	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_STATE_IDLE, $/;"	e	enum:_RT_ADCSMP_STATE
-ADCSMP_STATE_QUERY	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_STATE_QUERY,$/;"	e	enum:_RT_ADCSMP_STATE
-ADCSMP_STATE_SET	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_STATE_SET, $/;"	e	enum:_RT_ADCSMP_STATE
-ADCSMP_TRIG_CCA	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_TRIG_CCA,$/;"	e	enum:_RT_ADCSMP_TRIG_SIG_SEL
-ADCSMP_TRIG_CRCFAIL	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_TRIG_CRCFAIL, $/;"	e	enum:_RT_ADCSMP_TRIG_SIG_SEL
-ADCSMP_TRIG_CRCOK	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_TRIG_CRCOK, $/;"	e	enum:_RT_ADCSMP_TRIG_SIG_SEL
-ADCSMP_TRIG_REG	hal/phydm/phydm_adc_sampling.h	/^	ADCSMP_TRIG_REG,$/;"	e	enum:_RT_ADCSMP_TRIG_SIG_SEL
-ADCSmpBuf	hal/phydm/phydm_adc_sampling.h	/^	RT_ADCSMP_STRING		ADCSmpBuf;$/;"	m	struct:_RT_ADCSMP
-ADCSmpDmaDataSigSel	hal/phydm/phydm_adc_sampling.h	/^	u1Byte					ADCSmpDmaDataSigSel;$/;"	m	struct:_RT_ADCSMP
-ADCSmpPollingTime	hal/phydm/phydm_adc_sampling.h	/^	u2Byte					ADCSmpPollingTime;$/;"	m	struct:_RT_ADCSMP
-ADCSmpState	hal/phydm/phydm_adc_sampling.h	/^	RT_ADCSMP_STATE			ADCSmpState;$/;"	m	struct:_RT_ADCSMP
-ADCSmpTrigSel	hal/phydm/phydm_adc_sampling.h	/^	RT_ADCSMP_TRIG_SEL		ADCSmpTrigSel;$/;"	m	struct:_RT_ADCSMP
-ADCSmpTrigSigSel	hal/phydm/phydm_adc_sampling.h	/^	RT_ADCSMP_TRIG_SIG_SEL	ADCSmpTrigSigSel;$/;"	m	struct:_RT_ADCSMP
-ADCSmpTriggerTime	hal/phydm/phydm_adc_sampling.h	/^	u1Byte					ADCSmpTriggerTime;$/;"	m	struct:_RT_ADCSMP
-ADCSmpWorkItem	hal/phydm/phydm_adc_sampling.h	/^	RT_WORK_ITEM	ADCSmpWorkItem;$/;"	m	struct:_RT_ADCSMP
-ADCSmpWorkItemCallback	hal/phydm/phydm_adc_sampling.c	/^ADCSmpWorkItemCallback($/;"	f
-ADCSmp_BufferAllocate	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_BufferAllocate($/;"	f
-ADCSmp_DeInit	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_DeInit($/;"	f
-ADCSmp_GetTxPktBuf	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_GetTxPktBuf($/;"	f
-ADCSmp_Init	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_Init($/;"	f
-ADCSmp_Query	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_Query($/;"	f
-ADCSmp_Set	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_Set($/;"	f
-ADCSmp_Start	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_Start($/;"	f
-ADCSmp_Stop	hal/phydm/phydm_adc_sampling.c	/^ADCSmp_Stop($/;"	f
-ADCSmp_count	hal/phydm/phydm.h	/^	u4Byte			ADCSmp_count;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ADCSmp_dbg_port	hal/phydm/phydm.h	/^	u4Byte			ADCSmp_dbg_port;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ADCSmp_trigger_edge	hal/phydm/phydm.h	/^	BOOLEAN			ADCSmp_trigger_edge;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ADCsmp_smp_rate	hal/phydm/phydm.h	/^	u1Byte			ADCsmp_smp_rate;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ADCsmp_time_unit	hal/phydm/phydm.h	/^	u4Byte			ADCsmp_time_unit;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ADD3	include/hal_com_reg.h	1548;"	d
-ADDA_backup	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	ADDA_backup[IQK_ADDA_REG_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ADDA_backup	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	ADDA_backup[IQK_ADDA_REG_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ADDA_backup	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	ADDA_backup[IQK_ADDA_REG_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ADDBA_TO	include/rtw_mlme_ext.h	34;"	d
-ADDBA_req	include/rtw_mlme_ext.h	/^	struct ADDBA_request		ADDBA_req;$/;"	m	struct:mlme_ext_info	typeref:struct:mlme_ext_info::ADDBA_request
-ADDBA_request	include/wifi.h	/^struct ADDBA_request {$/;"	s
-ADDBA_retry_count	include/rtw_mlme_ext.h	/^	u8	ADDBA_retry_count;$/;"	m	struct:mlme_ext_info
-ADF	include/hal_com_reg.h	1555;"	d
-ADHOCMODE	core/rtw_ioctl_rtl.c	/^	ADHOCMODE,$/;"	e	enum:_CONNECT_STATE_	file:
-ADPT_ARG	include/osdep_service_bsd.h	740;"	d
-ADPT_ARG	include/osdep_service_ce.h	182;"	d
-ADPT_ARG	include/osdep_service_linux.h	428;"	d
-ADPT_ARG	include/osdep_service_xp.h	193;"	d
-ADPT_FMT	include/osdep_service_bsd.h	739;"	d
-ADPT_FMT	include/osdep_service_ce.h	181;"	d
-ADPT_FMT	include/osdep_service_linux.h	427;"	d
-ADPT_FMT	include/osdep_service_xp.h	192;"	d
-ADSL_AP_BUILD_WORKAROUND	hal/phydm/phydm_types.h	130;"	d
-AES_BLOCK_SIZE	include/rtw_security.h	48;"	d
-AES_IV	include/rtw_xmit.h	148;"	d
-AES_PRIV_SIZE	include/rtw_security.h	49;"	d
-AES_SW_DEC_CNT_INC	core/rtw_security.c	107;"	d	file:
-AES_SW_DEC_CNT_INC	core/rtw_security.c	93;"	d	file:
-AES_SW_ENC_CNT_INC	core/rtw_security.c	106;"	d	file:
-AES_SW_ENC_CNT_INC	core/rtw_security.c	84;"	d	file:
-AFE_PHASE_SEL	hal/phydm/halphyrf_ce.h	/^	AFE_PHASE_SEL$/;"	e	enum:_SPUR_CAL_METHOD
-AFE_PHASE_SEL	hal/phydm/halphyrf_win.h	/^	AFE_PHASE_SEL$/;"	e	enum:_SPUR_CAL_METHOD
-AFSM_HSUS	include/hal_com_reg.h	1179;"	d
-AFSM_PCIE	include/hal_com_reg.h	1180;"	d
-AGC_DIFF_CONFIG	hal/phydm/phydm_hwconfig.h	41;"	d
-AGC_DIFF_CONFIG_MP	hal/phydm/phydm_hwconfig.h	36;"	d
-AGC_DIFF_CONFIG_TC	hal/phydm/phydm_hwconfig.h	38;"	d
-AGC_table_select	include/Hal8188FPhyReg.h	1120;"	d
-AGGRE_SIZE	include/rtw_ht.h	/^typedef enum AGGRE_SIZE {$/;"	g
-AGGRE_SIZE_E	include/rtw_ht.h	/^} AGGRE_SIZE_E, *PAGGRE_SIZE_E;$/;"	t	typeref:enum:AGGRE_SIZE
-AGG_BK	include/rtl8188e_xmit.h	60;"	d
-AGG_BK	include/rtl8192e_xmit.h	165;"	d
-AGG_BK	include/rtl8812a_xmit.h	58;"	d
-AGG_EN	include/rtl8188e_xmit.h	59;"	d
-AGG_EN	include/rtl8192e_xmit.h	164;"	d
-AGG_EN	include/rtl8812a_xmit.h	57;"	d
-AICV	include/hal_com_reg.h	1554;"	d
-AID	hal/phydm/phydm_beamforming.h	/^	u2Byte						AID; $/;"	m	struct:_RT_BEAMFORM_STAINFO
-AID	hal/phydm/phydm_beamforming.h	/^	u2Byte				AID;$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-AID	hal/phydm/phydm_beamforming.h	/^	u2Byte	AID:12;	$/;"	m	struct:_RT_NDPA_STA_INFO
-AID	hal/phydm/phydm_beamforming.h	/^	u2Byte	AID;				\/*Used to construct AID field of NDPA packet.*\/$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-AIRGOCAP_OUI	core/rtw_wlan_util.c	/^unsigned char AIRGOCAP_OUI[] = {0x00, 0x0a, 0xf5};$/;"	v
-ALIGNMENT_UNIT	include/usb_ops.h	34;"	d
-ALIVE_MAX	core/rtw_mlme_ext.c	12295;"	d	file:
-ALIVE_MIN	core/rtw_mlme_ext.c	12294;"	d	file:
-ALL_WORDS_DISABLED	include/rtw_efuse.h	68;"	d
-AM	include/hal_com_reg.h	1546;"	d
-AMD_VENDOR_ID	include/drv_types_pci.h	33;"	d
-AMF	include/hal_com_reg.h	1557;"	d
-AMPDUBurstMode	include/hal_data.h	/^	RT_AMPDU_BRUST		AMPDUBurstMode; \/* 92C maybe not use, but for compile successfully *\/$/;"	m	struct:hal_com_data
-AMPDU_DENSITY_SHT	include/rtl8188e_xmit.h	61;"	d
-AMPDU_DENSITY_SHT	include/rtl8192e_xmit.h	166;"	d
-AMPDU_DENSITY_SHT	include/rtl8812a_xmit.h	59;"	d
-AMPDU_DENSITY_VALUE_0	include/wifi.h	/^	AMPDU_DENSITY_VALUE_0 = 0 , \/* For no restriction *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_DENSITY_VALUE_1	include/wifi.h	/^	AMPDU_DENSITY_VALUE_1 = 1 , \/* For 1\/4 us *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_DENSITY_VALUE_2	include/wifi.h	/^	AMPDU_DENSITY_VALUE_2 = 2 , \/* For 1\/2 us *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_DENSITY_VALUE_3	include/wifi.h	/^	AMPDU_DENSITY_VALUE_3 = 3 , \/* For 1 us *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_DENSITY_VALUE_4	include/wifi.h	/^	AMPDU_DENSITY_VALUE_4 = 4 , \/* For 2 us *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_DENSITY_VALUE_5	include/wifi.h	/^	AMPDU_DENSITY_VALUE_5 = 5 , \/* For 4 us *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_DENSITY_VALUE_6	include/wifi.h	/^	AMPDU_DENSITY_VALUE_6 = 6 , \/* For 8 us *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_DENSITY_VALUE_7	include/wifi.h	/^	AMPDU_DENSITY_VALUE_7 = 7 , \/* For 16 us *\/$/;"	e	enum:_HT_CAP_AMPDU_DENSITY
-AMPDU_para	include/wifi.h	/^			unsigned char	AMPDU_para;$/;"	m	struct:HT_caps_element::__anon54::__anon55
-AMPDU_para	include/wifi.h	/^			unsigned char	AMPDU_para;$/;"	m	struct:HT_caps_element::__anon56::__anon57
-AMSDU_FRAMETAG	include/rtw_xmit.h	460;"	d
-ANA8M	include/hal_com_reg.h	1199;"	d
-ANAD16V_EN	include/hal_com_reg.h	1198;"	d
-ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_END   = 0x10FF,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START = 0x1000,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_END   = 0x12FF,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_LSTATS_RANGE_START = 0x1200,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_NBD_RANGE_END	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_NBD_RANGE_END   = 0x11FF,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_NBD_RANGE_START	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_NBD_RANGE_START = 0x1100,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_RTT_RANGE_END	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_RTT_RANGE_END   = 0x11FF,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_RTT_RANGE_START	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_RTT_RANGE_START = 0x1100,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_TDLS_RANGE_END	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_TDLS_RANGE_END	= 0x13FF,$/;"	e	enum:__anon82
-ANDROID_NL80211_SUBCMD_TDLS_RANGE_START	os_dep/linux/rtw_cfgvendor.h	/^	ANDROID_NL80211_SUBCMD_TDLS_RANGE_START = 0x1300,$/;"	e	enum:__anon82
-ANDROID_VENDOR_SUB_COMMAND	os_dep/linux/rtw_cfgvendor.h	/^} ANDROID_VENDOR_SUB_COMMAND;$/;"	t	typeref:enum:__anon82
-ANDROID_WIFI_CMD	include/rtw_android.h	/^enum ANDROID_WIFI_CMD {$/;"	g
-ANDROID_WIFI_CMD_BLOCK	include/rtw_android.h	/^	ANDROID_WIFI_CMD_BLOCK,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_BLOCK_SCAN	include/rtw_android.h	/^	ANDROID_WIFI_CMD_BLOCK_SCAN,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_BTCOEXMODE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_BTCOEXMODE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_BTCOEXSCAN_START	include/rtw_android.h	/^	ANDROID_WIFI_CMD_BTCOEXSCAN_START,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_BTCOEXSCAN_STOP	include/rtw_android.h	/^	ANDROID_WIFI_CMD_BTCOEXSCAN_STOP,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_CHANGE_DTIM	include/rtw_android.h	/^	ANDROID_WIFI_CMD_CHANGE_DTIM,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_COUNTRY	include/rtw_android.h	/^	ANDROID_WIFI_CMD_COUNTRY,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_DRIVERVERSION	include/rtw_android.h	/^	ANDROID_WIFI_CMD_DRIVERVERSION,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_GETBAND	include/rtw_android.h	/^	ANDROID_WIFI_CMD_GETBAND,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_GTK_REKEY_OFFLOAD	include/rtw_android.h	/^	ANDROID_WIFI_CMD_GTK_REKEY_OFFLOAD,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA	include/rtw_android.h	/^	ANDROID_WIFI_CMD_HOSTAPD_ACL_ADD_STA,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA	include/rtw_android.h	/^	ANDROID_WIFI_CMD_HOSTAPD_ACL_REMOVE_STA,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL	include/rtw_android.h	/^	ANDROID_WIFI_CMD_HOSTAPD_SET_MACADDR_ACL,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_LINKSPEED	include/rtw_android.h	/^	ANDROID_WIFI_CMD_LINKSPEED,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_MACADDR	include/rtw_android.h	/^	ANDROID_WIFI_CMD_MACADDR,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_MAX	include/rtw_android.h	/^	ANDROID_WIFI_CMD_MAX$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_MIRACAST	include/rtw_android.h	/^	ANDROID_WIFI_CMD_MIRACAST,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_P2P_DEV_ADDR	include/rtw_android.h	/^	ANDROID_WIFI_CMD_P2P_DEV_ADDR,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_P2P_DISABLE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_P2P_DISABLE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_P2P_GET_NOA	include/rtw_android.h	/^	ANDROID_WIFI_CMD_P2P_GET_NOA,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_P2P_SET_NOA	include/rtw_android.h	/^	ANDROID_WIFI_CMD_P2P_SET_NOA,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_P2P_SET_PS	include/rtw_android.h	/^	ANDROID_WIFI_CMD_P2P_SET_PS,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_PNODEBUG_SET	include/rtw_android.h	/^	ANDROID_WIFI_CMD_PNODEBUG_SET,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_PNOENABLE_SET	include/rtw_android.h	/^	ANDROID_WIFI_CMD_PNOENABLE_SET,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_PNOSETUP_SET	include/rtw_android.h	/^	ANDROID_WIFI_CMD_PNOSETUP_SET,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_PNOSSIDCLR_SET	include/rtw_android.h	/^	ANDROID_WIFI_CMD_PNOSSIDCLR_SET,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_RSSI	include/rtw_android.h	/^	ANDROID_WIFI_CMD_RSSI,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_RXFILTER_ADD	include/rtw_android.h	/^	ANDROID_WIFI_CMD_RXFILTER_ADD,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_RXFILTER_REMOVE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_RXFILTER_REMOVE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_RXFILTER_START	include/rtw_android.h	/^	ANDROID_WIFI_CMD_RXFILTER_START,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_RXFILTER_STOP	include/rtw_android.h	/^	ANDROID_WIFI_CMD_RXFILTER_STOP,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_SCAN_ACTIVE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_SCAN_ACTIVE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_SCAN_PASSIVE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_SCAN_PASSIVE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_SETBAND	include/rtw_android.h	/^	ANDROID_WIFI_CMD_SETBAND,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_SETFWPATH	include/rtw_android.h	/^	ANDROID_WIFI_CMD_SETFWPATH,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_SETSUSPENDOPT	include/rtw_android.h	/^	ANDROID_WIFI_CMD_SETSUSPENDOPT,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_SET_AP_WPS_P2P_IE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_START	include/rtw_android.h	/^	ANDROID_WIFI_CMD_START,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_STOP	include/rtw_android.h	/^	ANDROID_WIFI_CMD_STOP,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_WFD_DISABLE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_WFD_DISABLE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_WFD_ENABLE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_WFD_ENABLE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_WFD_SET_DEVTYPE	include/rtw_android.h	/^	ANDROID_WIFI_CMD_WFD_SET_DEVTYPE,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT	include/rtw_android.h	/^	ANDROID_WIFI_CMD_WFD_SET_MAX_TPUT,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDROID_WIFI_CMD_WFD_SET_TCPPORT	include/rtw_android.h	/^	ANDROID_WIFI_CMD_WFD_SET_TCPPORT,$/;"	e	enum:ANDROID_WIFI_CMD
-ANDR_WIFI_ATTRIBUTE_FEATURE_SET	os_dep/linux/rtw_cfgvendor.h	/^	ANDR_WIFI_ATTRIBUTE_FEATURE_SET$/;"	e	enum:andr_wifi_feature_set_attr
-ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET	os_dep/linux/rtw_cfgvendor.h	/^	ANDR_WIFI_ATTRIBUTE_NUM_FEATURE_SET,$/;"	e	enum:andr_wifi_feature_set_attr
-ANDR_WIFI_SUBCMD_GET_FEATURE_SET	os_dep/linux/rtw_cfgvendor.h	/^	ANDR_WIFI_SUBCMD_GET_FEATURE_SET,$/;"	e	enum:wl_vendor_subcmd
-ANDR_WIFI_SUBCMD_GET_FEATURE_SET_MATRIX	os_dep/linux/rtw_cfgvendor.h	/^	ANDR_WIFI_SUBCMD_GET_FEATURE_SET_MATRIX,$/;"	e	enum:wl_vendor_subcmd
-ANT1_2G	hal/phydm/phydm_antdiv.h	47;"	d
-ANT2_2G	hal/phydm/phydm_antdiv.h	48;"	d
-ANTA_ON	hal/phydm/phydm_antdiv.h	/^	BOOLEAN		ANTA_ON;	\/*To indicate Ant A is or not*\/$/;"	m	struct:_SW_Antenna_Switch_
-ANTB_ON	hal/phydm/phydm_antdiv.h	/^	BOOLEAN		ANTB_ON;	\/*To indicate Ant B is on or not*\/$/;"	m	struct:_SW_Antenna_Switch_
-ANTDECT_VERSION	hal/phydm/phydm_antdect.h	24;"	d
-ANTDIV_INIT	hal/phydm/phydm_antdiv.h	42;"	d
-ANTDIV_OFF	hal/phydm/phydm_antdiv.h	78;"	d
-ANTDIV_ON	hal/phydm/phydm_antdiv.h	77;"	d
-ANTDIV_VERSION	hal/phydm/phydm_antdiv.h	36;"	d
-ANTENNA_A	include/hal_phy.h	/^	ANTENNA_A		= 8,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_AB	include/hal_phy.h	/^	ANTENNA_AB	= 12,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_ABC	include/hal_phy.h	/^	ANTENNA_ABC	= 14,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_ABCD	include/hal_phy.h	/^	ANTENNA_ABCD	= 15$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_ABD	include/hal_phy.h	/^	ANTENNA_ABD	= 13,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_AC	include/hal_phy.h	/^	ANTENNA_AC	= 10,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_ACD	include/hal_phy.h	/^	ANTENNA_ACD	= 11,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_AD	include/hal_phy.h	/^	ANTENNA_AD	= 9,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_B	include/hal_phy.h	/^	ANTENNA_B		= 4,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_BC	include/hal_phy.h	/^	ANTENNA_BC	= 6,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_BCD	include/hal_phy.h	/^	ANTENNA_BCD	= 7,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_BD	include/hal_phy.h	/^	ANTENNA_BD	= 5,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_C	include/hal_phy.h	/^	ANTENNA_C		= 2,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_CD	include/hal_phy.h	/^	ANTENNA_CD	= 3,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_D	include/hal_phy.h	/^	ANTENNA_D		= 1,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_NONE	include/hal_phy.h	/^	ANTENNA_NONE	= 0,$/;"	e	enum:_ANTENNA_PATH
-ANTENNA_PATH	include/hal_phy.h	/^} ANTENNA_PATH;$/;"	t	typeref:enum:_ANTENNA_PATH
-ANTSEL_A	include/rtl8188e_xmit.h	62;"	d
-ANTSEL_A	include/rtl8192e_xmit.h	167;"	d
-ANTSEL_A	include/rtl8812a_xmit.h	60;"	d
-ANTSEL_B	include/rtl8188e_xmit.h	63;"	d
-ANTSEL_B	include/rtl8192e_xmit.h	168;"	d
-ANTSEL_B	include/rtl8812a_xmit.h	61;"	d
-ANTTESTA	hal/phydm/phydm_antdect.h	30;"	d
-ANTTESTALL	hal/phydm/phydm_antdect.h	29;"	d
-ANTTESTB	hal/phydm/phydm_antdect.h	31;"	d
-ANT_DECT_RSSI_TH	hal/phydm/phydm_pathdiv.h	30;"	d
-ANT_DETECTED_INFO	hal/phydm/phydm_antdect.h	/^}ANT_DETECTED_INFO, *PANT_DETECTED_INFO;$/;"	t	typeref:struct:_ANT_DETECTED_INFO
-ANT_DETECT_BY_RSSI	include/hal_phy.h	53;"	d
-ANT_DETECT_BY_SINGLE_TONE	include/hal_phy.h	52;"	d
-ANT_DIV_TYPE_E	hal/phydm/phydm_antdiv.h	/^}ANT_DIV_TYPE_E, *PANT_DIV_TYPE_E;$/;"	t	typeref:enum:_ANT_DIV_TYPE
-ANT_SELECT_WK_CID	include/rtw_cmd.h	/^	ANT_SELECT_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-ANonce	include/sta_info.h	/^	u8	ANonce[32];$/;"	m	struct:sta_info
-APDM_HOST	include/hal_com_reg.h	1182;"	d
-APDM_HPDN	include/hal_com_reg.h	1183;"	d
-APDM_MAC	include/hal_com_reg.h	1181;"	d
-APFM_OFF	include/hal_com_reg.h	1177;"	d
-APFM_ONMAC	include/hal_com_reg.h	1176;"	d
-APFM_RSM	include/hal_com_reg.h	1178;"	d
-APK_BB_REG_NUM	hal/phydm/halphyrf_ap.c	1973;"	d	file:
-APK_BB_REG_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	2593;"	d	file:
-APK_CURVE_REG_NUM	hal/phydm/halphyrf_ap.c	1974;"	d	file:
-APK_CURVE_REG_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	2594;"	d	file:
-APK_bound	include/rtw_mp.h	/^	u8		APK_bound[2];	\/* for APK	path A\/path B *\/$/;"	m	struct:_MPT_CONTEXT
-APKoutput	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	APKoutput[2][2]; \/\/path A\/B; output1_1a\/output1_2a$/;"	m	struct:ODM_RF_Calibration_Structure
-APKoutput	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	APKoutput[2][2]; \/\/path A\/B; output1_1a\/output1_2a$/;"	m	struct:ODM_RF_Calibration_Structure
-APKoutput	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	APKoutput[2][2]; \/\/path A\/B; output1_1a\/output1_2a$/;"	m	struct:ODM_RF_Calibration_Structure
-APM	include/hal_com_reg.h	1545;"	d
-APNumTH	hal/phydm/phydm_adaptivity.h	/^	u1Byte			APNumTH;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-APP_BASSN	include/hal_com_reg.h	1565;"	d
-APP_FCS	include/hal_com_reg.h	1569;"	d
-APP_ICV	include/hal_com_reg.h	1567;"	d
-APP_MIC	include/hal_com_reg.h	1568;"	d
-APP_PHYSTS	include/hal_com_reg.h	1566;"	d
-APSDOFF	include/hal_com_reg.h	1530;"	d
-APTotalNum	hal/phydm/phydm.h	/^	u1Byte			APTotalNum;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-APWRMGT	include/hal_com_reg.h	1549;"	d
-AP_BUILD_WORKAROUND	hal/phydm/phydm_types.h	131;"	d
-AP_InitRateAdaptiveState	hal/phydm/phydm_rainfo.h	73;"	d
-AP_OFFLOAD_WAKEUP	include/hal_com.h	/^	AP_OFFLOAD_WAKEUP				= 0x66,$/;"	e	enum:_WAKEUP_REASON
-AP_WOWLAN_PAGE_NUM_8188F	include/rtl8188f_hal.h	139;"	d
-AP_WOWLAN_PAGE_NUM_8703B	include/rtl8703b_hal.h	141;"	d
-AP_WOWLAN_PAGE_NUM_8723B	include/rtl8723b_hal.h	141;"	d
-AP_WOWLAN_PAGE_NUM_8723D	include/rtl8723d_hal.h	146;"	d
-ARCH	Makefile	/^ARCH := $(R_ARCH)$/;"	m
-ARCH	Makefile	/^ARCH := $(SUBARCH)$/;"	m
-ARCH	Makefile	/^ARCH := arm$/;"	m
-ARCH	Makefile	/^ARCH := arm64$/;"	m
-ARCH	Makefile	/^ARCH := mips$/;"	m
-ARCH	Makefile	/^ARCH := mn10300$/;"	m
-ARCH	Makefile	/^ARCH ?= $(SUBARCH)$/;"	m
-ARCH	Makefile	/^ARCH ?= arm$/;"	m
-ARCH	Makefile	/^ARCH ?= mips$/;"	m
-ARCH	Makefile	/^ARCH:= arm$/;"	m
-ARCH	Makefile	/^ARCH:=$/;"	m
-ARCH	Makefile	/^ARCH:=arm$/;"	m
-ARCH	Makefile	/^ARCH:=mips$/;"	m
-ARFR_0_RATE_ID	hal/phydm/phydm_rainfo.h	/^	ARFR_0_RATE_ID	=	0x9,$/;"	e	enum:_phydm_arfr_num
-ARFR_1_RATE_ID	hal/phydm/phydm_rainfo.h	/^	ARFR_1_RATE_ID	=	0xa,$/;"	e	enum:_phydm_arfr_num
-ARFR_2_RATE_ID	hal/phydm/phydm_rainfo.h	/^	ARFR_2_RATE_ID	=	0xb,$/;"	e	enum:_phydm_arfr_num
-ARFR_3_RATE_ID	hal/phydm/phydm_rainfo.h	/^	ARFR_3_RATE_ID	=	0xc,$/;"	e	enum:_phydm_arfr_num
-ARFR_4_RATE_ID	hal/phydm/phydm_rainfo.h	/^	ARFR_4_RATE_ID	=	0xd,$/;"	e	enum:_phydm_arfr_num
-ARFR_5_RATE_ID	hal/phydm/phydm_rainfo.h	/^	ARFR_5_RATE_ID	=	0xe$/;"	e	enum:_phydm_arfr_num
-ARTHEROS_OUI1	core/rtw_wlan_util.c	/^unsigned char ARTHEROS_OUI1[] = {0x00, 0x03, 0x7f};$/;"	v
-ARTHEROS_OUI2	core/rtw_wlan_util.c	/^unsigned char ARTHEROS_OUI2[] = {0x00, 0x13, 0x74};$/;"	v
-ASEL_caps	include/wifi.h	/^			unsigned char	ASEL_caps;$/;"	m	struct:HT_caps_element::__anon54::__anon55
-ASEL_caps	include/wifi.h	/^			unsigned char	ASEL_caps;$/;"	m	struct:HT_caps_element::__anon56::__anon57
-ASSERT	hal/phydm/phydm_debug.h	145;"	d
-ASSOCIATED	core/rtw_ioctl_rtl.c	/^	ASSOCIATED,$/;"	e	enum:_CONNECT_STATE_	file:
-ASSOCIATE_ENTRY_NUM	hal/phydm/phydm_pre_define.h	70;"	d
-ASSOCIATE_ENTRY_NUM	hal/phydm/phydm_pre_define.h	73;"	d
-ATIMWindow	include/wlan_bssdef.h	/^	ULONG           ATIMWindow;         \/* units are Kusec *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION
-ATI_DEVICE_ID	include/drv_types_pci.h	32;"	d
-ATI_VENDOR_ID	include/drv_types_pci.h	31;"	d
-ATOMIC_ADD	os_dep/osdep_service.c	/^inline void ATOMIC_ADD(ATOMIC_T *v, int i)$/;"	f
-ATOMIC_ADD_RETURN	os_dep/osdep_service.c	/^inline int ATOMIC_ADD_RETURN(ATOMIC_T *v, int i)$/;"	f
-ATOMIC_DEC	os_dep/osdep_service.c	/^inline void ATOMIC_DEC(ATOMIC_T *v)$/;"	f
-ATOMIC_DEC_RETURN	os_dep/osdep_service.c	/^inline int ATOMIC_DEC_RETURN(ATOMIC_T *v)$/;"	f
-ATOMIC_INC	os_dep/osdep_service.c	/^inline void ATOMIC_INC(ATOMIC_T *v)$/;"	f
-ATOMIC_INC_RETURN	os_dep/osdep_service.c	/^inline int ATOMIC_INC_RETURN(ATOMIC_T *v)$/;"	f
-ATOMIC_INIT	include/osdep_service_bsd.h	726;"	d
-ATOMIC_INIT	include/osdep_service_ce.h	153;"	d
-ATOMIC_INIT	include/osdep_service_xp.h	163;"	d
-ATOMIC_READ	os_dep/osdep_service.c	/^inline int ATOMIC_READ(ATOMIC_T *v)$/;"	f
-ATOMIC_SET	os_dep/osdep_service.c	/^inline void ATOMIC_SET(ATOMIC_T *v, int i)$/;"	f
-ATOMIC_SUB	os_dep/osdep_service.c	/^inline void ATOMIC_SUB(ATOMIC_T *v, int i)$/;"	f
-ATOMIC_SUB_RETURN	os_dep/osdep_service.c	/^inline int ATOMIC_SUB_RETURN(ATOMIC_T *v, int i)$/;"	f
-ATOMIC_T	include/osdep_service_bsd.h	/^typedef uint32_t ATOMIC_T ;$/;"	t
-ATOMIC_T	include/osdep_service_ce.h	177;"	d
-ATOMIC_T	include/osdep_service_linux.h	421;"	d
-ATOMIC_T	include/osdep_service_xp.h	187;"	d
-ATTRIBUTE_U32_LEN	os_dep/linux/rtw_cfgvendor.h	27;"	d
-ATTR_GET_GSCAN_CAPABILITIES_ID	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_GET_GSCAN_CAPABILITIES_ID,$/;"	e	enum:wl_vendor_gscan_attribute
-ATTR_GSCAN_BATCH_BESTN	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_GSCAN_BATCH_BESTN,$/;"	e	enum:gscan_batch_attribute
-ATTR_GSCAN_BATCH_BUFFER_THRESHOLD	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_GSCAN_BATCH_BUFFER_THRESHOLD$/;"	e	enum:gscan_batch_attribute
-ATTR_GSCAN_BATCH_MSCAN	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_GSCAN_BATCH_MSCAN,$/;"	e	enum:gscan_batch_attribute
-ATTR_GSCAN_HOTLIST_BSSID	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_GSCAN_HOTLIST_BSSID$/;"	e	enum:gscan_geofence_attribute
-ATTR_GSCAN_MAX	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_GSCAN_MAX$/;"	e	enum:wl_vendor_gscan_attribute
-ATTR_GSCAN_NUM_HOTLIST_BSSID	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_GSCAN_NUM_HOTLIST_BSSID,$/;"	e	enum:gscan_geofence_attribute
-ATTR_SET_SCAN_BATCH_CFG_ID	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_SET_SCAN_BATCH_CFG_ID, \/* set batch scan params *\/$/;"	e	enum:wl_vendor_gscan_attribute
-ATTR_SET_SCAN_CFG_ID	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_SET_SCAN_CFG_ID, \/* set common scan config params here *\/$/;"	e	enum:wl_vendor_gscan_attribute
-ATTR_SET_SCAN_GEOFENCE_CFG_ID	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_SET_SCAN_GEOFENCE_CFG_ID, \/* set list of bssids to track *\/$/;"	e	enum:wl_vendor_gscan_attribute
-ATTR_SET_SCAN_SIGNIFICANT_CFG_ID	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_SET_SCAN_SIGNIFICANT_CFG_ID, \/* set list of bssids, rssi threshold etc.. *\/$/;"	e	enum:wl_vendor_gscan_attribute
-ATTR_START_GSCAN	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_START_GSCAN,$/;"	e	enum:wl_vendor_gscan_attribute
-ATTR_STOP_GSCAN	os_dep/linux/rtw_cfgvendor.h	/^	ATTR_STOP_GSCAN,$/;"	e	enum:wl_vendor_gscan_attribute
-AUTH_ALG_LEAP	include/ieee80211.h	109;"	d
-AUTH_ALG_OPEN_SYSTEM	include/ieee80211.h	107;"	d
-AUTH_ALG_SHARED_KEY	include/ieee80211.h	108;"	d
-AUTH_EVEN_TO	include/wifi.h	707;"	d
-AUTH_ODD_TO	include/wifi.h	706;"	d
-AUTOCONF_INCLUDED	include/autoconf.h	23;"	d
-AUTO_VCS	include/wlan_bssdef.h	/^	AUTO_VCS$/;"	e	enum:VRTL_CARRIER_SENSE
-AUX_ANT	hal/phydm/phydm_antdiv.h	44;"	d
-AVAILABLE_EFUSE_ADDR	include/rtl8188e_hal.h	195;"	d
-AVAILABLE_EFUSE_ADDR	include/rtl8188f_hal.h	173;"	d
-AVAILABLE_EFUSE_ADDR	include/rtl8703b_hal.h	175;"	d
-AVAILABLE_EFUSE_ADDR	include/rtl8723b_hal.h	175;"	d
-AVAILABLE_EFUSE_ADDR	include/rtl8723d_hal.h	182;"	d
-AVAILABLE_EFUSE_ADDR	include/rtw_efuse.h	64;"	d
-AVAILABLE_EFUSE_ADDR_8192E	include/rtl8192e_hal.h	202;"	d
-AVAILABLE_EFUSE_ADDR_8812	include/rtl8812a_hal.h	247;"	d
-AVAILABLE_EFUSE_ADDR_8814A	include/rtl8814a_hal.h	195;"	d
-AVAILABLE_EFUSE_ADDR_88E	include/rtl8188e_hal.h	212;"	d
-AVG_THERMAL_NUM	hal/phydm/phydm_powertracking_ap.h	53;"	d
-AVG_THERMAL_NUM	hal/phydm/phydm_powertracking_ce.h	39;"	d
-AVG_THERMAL_NUM	hal/phydm/phydm_powertracking_win.h	41;"	d
-AVG_THERMAL_NUM_8723D	hal/phydm/rtl8723d/halphyrf_8723d.h	27;"	d
-AVG_THERMAL_NUM_8812	hal/phydm/phydm_powertracking_ap.h	104;"	d
-A_CUT_VERSION	include/HalVerDef.h	/^	A_CUT_VERSION		=	0,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-Absolute_CCKSwingIdx	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte			Absolute_CCKSwingIdx[MAX_RF_PATH]; $/;"	m	struct:ODM_RF_Calibration_Structure
-Absolute_CCKSwingIdx	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte			Absolute_CCKSwingIdx[MAX_RF_PATH]; $/;"	m	struct:ODM_RF_Calibration_Structure
-Absolute_CCKSwingIdx	hal/phydm/phydm_powertracking_win.h	/^	s1Byte			Absolute_CCKSwingIdx[MAX_RF_PATH]; $/;"	m	struct:ODM_RF_Calibration_Structure
-Absolute_OFDMSwingIdx	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte			Absolute_OFDMSwingIdx[MAX_RF_PATH];   $/;"	m	struct:ODM_RF_Calibration_Structure
-Absolute_OFDMSwingIdx	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte			Absolute_OFDMSwingIdx[MAX_RF_PATH];   $/;"	m	struct:ODM_RF_Calibration_Structure
-Absolute_OFDMSwingIdx	hal/phydm/phydm_powertracking_win.h	/^	s1Byte			Absolute_OFDMSwingIdx[MAX_RF_PATH];   $/;"	m	struct:ODM_RF_Calibration_Structure
-AcParam_BE	include/hal_data.h	/^	u32	AcParam_BE; \/* Original parameter for BE, use for EDCA turbo.	*\/$/;"	m	struct:hal_com_data
-AccumulatePWDB	hal/phydm/phydm.h	/^	s4Byte			AccumulatePWDB[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-AcmHw_BeqEn	include/hal_com_reg.h	1509;"	d
-AcmHw_BeqEn_8192E	include/rtl8192e_spec.h	312;"	d
-AcmHw_BeqEn_8723D	hal/phydm/rtl8723d/hal8723dreg.h	885;"	d
-AcmHw_BeqEn_8812	include/rtl8812a_spec.h	255;"	d
-AcmHw_BeqStatus	include/hal_com_reg.h	1512;"	d
-AcmHw_BeqStatus_8192E	include/rtl8192e_spec.h	315;"	d
-AcmHw_BeqStatus_8723D	hal/phydm/rtl8723d/hal8723dreg.h	888;"	d
-AcmHw_BeqStatus_8812	include/rtl8812a_spec.h	258;"	d
-AcmHw_HwEn	include/hal_com_reg.h	1508;"	d
-AcmHw_HwEn_8192E	include/rtl8192e_spec.h	309;"	d
-AcmHw_HwEn_8723D	hal/phydm/rtl8723d/hal8723dreg.h	882;"	d
-AcmHw_HwEn_8812	include/rtl8812a_spec.h	252;"	d
-AcmHw_ViqEn	include/hal_com_reg.h	1510;"	d
-AcmHw_ViqEn_8192E	include/rtl8192e_spec.h	311;"	d
-AcmHw_ViqEn_8723D	hal/phydm/rtl8723d/hal8723dreg.h	884;"	d
-AcmHw_ViqEn_8812	include/rtl8812a_spec.h	254;"	d
-AcmHw_ViqStatus	include/hal_com_reg.h	1513;"	d
-AcmHw_ViqStatus_8192E	include/rtl8192e_spec.h	314;"	d
-AcmHw_ViqStatus_8723D	hal/phydm/rtl8723d/hal8723dreg.h	887;"	d
-AcmHw_ViqStatus_8812	include/rtl8812a_spec.h	257;"	d
-AcmHw_VoqEn	include/hal_com_reg.h	1511;"	d
-AcmHw_VoqEn_8192E	include/rtl8192e_spec.h	310;"	d
-AcmHw_VoqEn_8723D	hal/phydm/rtl8723d/hal8723dreg.h	883;"	d
-AcmHw_VoqEn_8812	include/rtl8812a_spec.h	253;"	d
-AcmHw_VoqStatus	include/hal_com_reg.h	1514;"	d
-AcmHw_VoqStatus_8192E	include/rtl8192e_spec.h	313;"	d
-AcmHw_VoqStatus_8723D	hal/phydm/rtl8723d/hal8723dreg.h	886;"	d
-AcmHw_VoqStatus_8812	include/rtl8812a_spec.h	256;"	d
-AcsForAdaptivity	hal/phydm/phydm_adaptivity.h	/^	BOOLEAN			AcsForAdaptivity;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-Active	hal/phydm/phydm_rainfo.h	/^	u1Byte Active;$/;"	m	struct:_ODM_RA_Info_
-AdajustIGILevel	hal/phydm/phydm_adaptivity.h	/^	u1Byte			AdajustIGILevel;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-Adapter	hal/btc/HalBtcOutSrc.h	/^	PVOID				Adapter;		\/*default adapter*\/$/;"	m	struct:btc_coexist
-Adapter	hal/phydm/phydm.h	/^	PADAPTER		Adapter;		\/*For CE\/NIC team*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Adaptivity	hal/phydm/phydm.h	/^	ADAPTIVITY_STATISTICS	Adaptivity;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Adaptivity_IGI_upper	hal/phydm/phydm.h	/^	u1Byte			Adaptivity_IGI_upper;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Adaptivity_enable	hal/phydm/phydm.h	/^	BOOLEAN			Adaptivity_enable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-AllStaSleep	include/rtw_cmd.h	/^	u8 AllStaSleep:1; \/* Only valid in Owner *\/$/;"	m	struct:P2P_PS_Offload_t
-AmplifierType_2G	include/drv_types.h	/^	u8	AmplifierType_2G;$/;"	m	struct:registry_priv
-AmplifierType_5G	include/drv_types.h	/^	u8	AmplifierType_5G;$/;"	m	struct:registry_priv
-Anonce	include/rtw_tdls.h	/^	u8 Anonce[WPA_NONCE_LEN]; \/* Responder Nonce in TDLS *\/$/;"	m	struct:wpa_tdls_ftie
-Ant2G	hal/phydm/phydm_antdiv.h	/^	u1Byte		Ant2G;$/;"	m	struct:_SW_Antenna_Switch_
-Ant5G	hal/phydm/phydm_antdiv.h	/^	u1Byte		Ant5G;$/;"	m	struct:_SW_Antenna_Switch_
-AntDetectedInfo	hal/phydm/phydm.h	/^	ANT_DETECTED_INFO	AntDetectedInfo;	\/* Antenna detected information for RSSI tool*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-AntDetection	include/hal_data.h	/^	u8	AntDetection;$/;"	m	struct:hal_com_data
-AntDivCfg	include/hal_data.h	/^	u8	AntDivCfg;$/;"	m	struct:hal_com_data
-AntDivType	hal/phydm/phydm.h	/^	u1Byte			AntDivType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-AntDiv_2G_5G	hal/phydm/phydm_antdiv.h	/^	u1Byte	AntDiv_2G_5G;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AntDiv_OnOff	hal/phydm/phydm_antdiv.h	/^	u1Byte	AntDiv_OnOff;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AntDiv_RSSI_max	hal/phydm/phydm_dig.h	/^	u4Byte		AntDiv_RSSI_max;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-AntType	hal/phydm/phydm.h	/^	u1Byte			AntType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Ant_x1	include/hal_pg.h	/^	Ant_x1	= 1$/;"	e	enum:_BT_Ant_NUM
-Ant_x2	include/hal_pg.h	/^	Ant_x2	= 0,$/;"	e	enum:_BT_Ant_NUM
-AntennaDiversityValue	include/Hal8188EPhyCfg.h	27;"	d
-AntennaDiversityValue	include/Hal8188FPhyCfg.h	26;"	d
-AntennaDiversityValue	include/Hal8192EPhyCfg.h	27;"	d
-AntennaDiversityValue	include/Hal8703BPhyCfg.h	26;"	d
-AntennaDiversityValue	include/Hal8723BPhyCfg.h	26;"	d
-AntennaDiversityValue	include/Hal8723DPhyCfg.h	26;"	d
-AntennaDiversityValue	include/Hal8812PhyCfg.h	27;"	d
-AntennaDiversityValue	include/Hal8814PhyCfg.h	27;"	d
-AntennaRxPath	include/hal_data.h	/^	u32	AntennaRxPath;					\/* Antenna path Rx *\/$/;"	m	struct:hal_com_data
-AntennaTxPath	include/hal_data.h	/^	u32	AntennaTxPath;					\/* Antenna path Tx *\/$/;"	m	struct:hal_com_data
-Antenna_A	hal/phydm/phydm_antdect.h	/^	Antenna_A = 1,$/;"	e	enum:tag_SW_Antenna_Switch_Definition
-Antenna_B	hal/phydm/phydm_antdect.h	/^	Antenna_B = 2,	$/;"	e	enum:tag_SW_Antenna_Switch_Definition
-Antenna_MAX	hal/phydm/phydm_antdect.h	/^	Antenna_MAX = 3,$/;"	e	enum:tag_SW_Antenna_Switch_Definition
-ArrayLength_MP_8723D_FW_AP	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^u4Byte ArrayLength_MP_8723D_FW_AP = 21184;$/;"	v
-Array_MP_8723D_AGC_TAB	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^u4Byte Array_MP_8723D_AGC_TAB[] = { $/;"	v
-Array_MP_8723D_MAC_REG	hal/phydm/rtl8723d/halhwimg8723d_mac.c	/^u4Byte Array_MP_8723D_MAC_REG[] = { $/;"	v
-Array_MP_8723D_MPCIE	hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c	/^u1Byte Array_MP_8723D_MPCIE[] = {$/;"	v
-Array_MP_8723D_MSDIO	hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c	/^u1Byte Array_MP_8723D_MSDIO[] = {$/;"	v
-Array_MP_8723D_MUSB	hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c	/^u1Byte Array_MP_8723D_MUSB[] = {$/;"	v
-Array_MP_8723D_PHY_REG	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^u4Byte Array_MP_8723D_PHY_REG[] = { $/;"	v
-Array_MP_8723D_PHY_REG_PG	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^u4Byte Array_MP_8723D_PHY_REG_PG[] = { $/;"	v
-Array_MP_8723D_RadioA	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u4Byte Array_MP_8723D_RadioA[] = { $/;"	v
-Array_MP_8723D_TXPWR_LMT	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^const char *Array_MP_8723D_TXPWR_LMT[] = { $/;"	v
-Array_kfreemap	hal/hal_com.c	/^u32 Array_kfreemap[] = {$/;"	v
-Associated_AP	include/rtw_mlme_ext.h	/^enum Associated_AP {$/;"	g
-AssociationId	include/wlan_bssdef.h	/^	USHORT AssociationId;$/;"	m	struct:_NDIS_802_11_AI_RESFI
-AuthModeSupported	include/wlan_bssdef.h	/^	NDIS_802_11_AUTHENTICATION_MODE AuthModeSupported;$/;"	m	struct:_NDIS_802_11_AUTHENTICATION_ENCRYPTION
-AuthenticationEncryptionSupported	include/wlan_bssdef.h	/^	NDIS_802_11_AUTHENTICATION_ENCRYPTION AuthenticationEncryptionSupported[1];$/;"	m	struct:_NDIS_802_11_CAPABILITY
-AuthenticationEvent	include/wlan_bssdef.h	/^		NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;$/;"	m	union:_NDIS_802_11_TEST::__anon70
-AuthenticationEvent	include/wlan_bssdef.h	/^		NDIS_802_11_AUTHENTICATION_EVENT AuthenticationEvent;$/;"	m	union:_NDIS_802_11_TEST::__anon71
-AuxAntEVM_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	AuxAntEVM_Cnt[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxAntEVM_Sum	hal/phydm/phydm_antdiv.h	/^	u4Byte	AuxAntEVM_Sum[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxAnt_Cnt	hal/phydm/phydm_antdiv.h	/^	u2Byte	AuxAnt_Cnt[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxAnt_Cnt_cck	hal/phydm/phydm_antdiv.h	/^	u2Byte	AuxAnt_Cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];	$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxAnt_CtrlFrame_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	AuxAnt_CtrlFrame_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxAnt_CtrlFrame_Sum	hal/phydm/phydm_antdiv.h	/^	u4Byte	AuxAnt_CtrlFrame_Sum;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxAnt_Sum	hal/phydm/phydm_antdiv.h	/^	u2Byte	AuxAnt_Sum[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxAnt_Sum_cck	hal/phydm/phydm_antdiv.h	/^	u2Byte	AuxAnt_Sum_cck[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxCRC32_Fail_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	AuxCRC32_Fail_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AuxCRC32_Ok_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	AuxCRC32_Ok_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-Aux_FailDetec_Counter	hal/phydm/phydm_antdiv.h	/^	u2Byte		Aux_FailDetec_Counter;$/;"	m	struct:_SW_Antenna_Switch_
-Aux_MPDU_OK_cnt	hal/phydm/phydm_antdiv.h	/^	u2Byte	Aux_MPDU_OK_cnt;	$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-AvailableRequestFixedIEs	include/wlan_bssdef.h	/^	USHORT                  AvailableRequestFixedIEs;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-AvailableResponseFixedIEs	include/wlan_bssdef.h	/^	USHORT                  AvailableResponseFixedIEs;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-AverageThermalNum	hal/phydm/halphyrf_ap.h	/^	u1Byte 		AverageThermalNum;$/;"	m	struct:_TXPWRTRACK_CFG
-AverageThermalNum	hal/phydm/halphyrf_ce.h	/^	u1Byte 		AverageThermalNum;$/;"	m	struct:_TXPWRTRACK_CFG
-AverageThermalNum	hal/phydm/halphyrf_win.h	/^	u1Byte 		AverageThermalNum;$/;"	m	struct:_TXPWRTRACK_CFG
-AwakeInterval	include/rtl8188e_cmd.h	/^	u8 AwakeInterval;	\/* unit: beacon interval *\/$/;"	m	struct:_SETPWRMODE_PARM
-AwakeInterval	include/rtl8192e_cmd.h	/^	u8 AwakeInterval;	\/* unit: beacon interval *\/$/;"	m	struct:_SETPWRMODE_PARM
-BAND_24G	include/rtw_mlme_ext.h	/^	BAND_24G = BIT0,$/;"	e	enum:__anon52
-BAND_5G	include/rtw_mlme_ext.h	/^	BAND_5G = BIT1,$/;"	e	enum:__anon52
-BAND_CAP_2G	include/hal_com.h	310;"	d
-BAND_CAP_5G	include/hal_com.h	311;"	d
-BAND_CAP_8188F	include/rtl8188f_spec.h	299;"	d
-BAND_CAP_8192E	include/rtl8192e_spec.h	325;"	d
-BAND_CAP_8703B	include/rtl8703b_spec.h	476;"	d
-BAND_CAP_8723B	include/rtl8723b_spec.h	292;"	d
-BAND_CAP_8723D	include/rtl8723d_spec.h	453;"	d
-BAND_CAP_8812A	include/rtl8812a_spec.h	268;"	d
-BAND_CAP_8814A	include/rtl8814a_spec.h	647;"	d
-BAND_CAP_8821A	include/rtl8821a_spec.h	104;"	d
-BAND_CAP_88E	include/rtl8188e_spec.h	154;"	d
-BAND_CAP_BIT_NUM	include/hal_com.h	312;"	d
-BAND_MAX	include/rtw_rf.h	/^	BAND_MAX = 3,$/;"	e	enum:_BAND_TYPE
-BAND_NUM	hal/phydm/phydm_powertracking_ap.h	40;"	d
-BAND_NUM	hal/phydm/phydm_powertracking_ce.h	37;"	d
-BAND_NUM	hal/phydm/phydm_powertracking_win.h	33;"	d
-BAND_ON_2_4G	include/rtw_rf.h	/^	BAND_ON_2_4G = 0,$/;"	e	enum:_BAND_TYPE
-BAND_ON_5G	include/rtw_rf.h	/^	BAND_ON_5G = 1,$/;"	e	enum:_BAND_TYPE
-BAND_ON_BOTH	include/rtw_rf.h	/^	BAND_ON_BOTH = 2,$/;"	e	enum:_BAND_TYPE
-BAND_TYPE	include/rtw_rf.h	/^} BAND_TYPE, *PBAND_TYPE;$/;"	t	typeref:enum:_BAND_TYPE
-BANK_NUM	include/rtl8703b_hal.h	183;"	d
-BANK_NUM	include/rtl8723d_hal.h	190;"	d
-BANK_NUM	include/rtw_efuse.h	58;"	d
-BASIC_RXFF_SIZE_8814A	include/rtl8814a_hal.h	130;"	d
-BA_para_set	include/wifi.h	/^	unsigned short	BA_para_set;$/;"	m	struct:ADDBA_request
-BA_starting_seqctrl	include/sta_info.h	/^	u16	BA_starting_seqctrl[16];$/;"	m	struct:sta_info
-BA_starting_seqctrl	include/wifi.h	/^	unsigned short	BA_starting_seqctrl;$/;"	m	struct:ADDBA_request
-BA_timeout_value	include/wifi.h	/^	unsigned short	BA_timeout_value;$/;"	m	struct:ADDBA_request
-BBAddr	include/hal_com_reg.h	590;"	d
-BBINI_RDY	include/hal_com_reg.h	1243;"	d
-BBSWING	hal/phydm/halphyrf_ap.h	/^	BBSWING,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-BBSWING	hal/phydm/halphyrf_ce.h	/^	BBSWING,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-BBSWING	hal/phydm/halphyrf_win.h	/^	BBSWING,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-BBSwingDiff2G	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte  BBSwingDiff2G, BBSwingDiff5G; \/\/ Unit: dB$/;"	m	struct:ODM_RF_Calibration_Structure
-BBSwingDiff2G	hal/phydm/phydm_powertracking_win.h	/^	s1Byte  BBSwingDiff2G, BBSwingDiff5G; \/\/ Unit: dB$/;"	m	struct:ODM_RF_Calibration_Structure
-BBSwingDiff5G	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte  BBSwingDiff2G, BBSwingDiff5G; \/\/ Unit: dB$/;"	m	struct:ODM_RF_Calibration_Structure
-BBSwingDiff5G	hal/phydm/phydm_powertracking_win.h	/^	s1Byte  BBSwingDiff2G, BBSwingDiff5G; \/\/ Unit: dB$/;"	m	struct:ODM_RF_Calibration_Structure
-BB_GAIN_2G	include/rtw_rf.h	263;"	d
-BB_GAIN_5GHB	include/rtw_rf.h	269;"	d
-BB_GAIN_5GLB1	include/rtw_rf.h	265;"	d
-BB_GAIN_5GLB2	include/rtw_rf.h	266;"	d
-BB_GAIN_5GMB1	include/rtw_rf.h	267;"	d
-BB_GAIN_5GMB2	include/rtw_rf.h	268;"	d
-BB_GAIN_NUM	include/rtw_rf.h	273;"	d
-BB_GAIN_NUM	include/rtw_rf.h	275;"	d
-BB_INIT_REGISTER	include/hal_data.h	/^} BB_INIT_REGISTER, *PBB_INIT_REGISTER;$/;"	t	typeref:struct:_BB_INIT_REGISTER
-BB_REGISTER_DEFINITION_T	include/hal_com_phycfg.h	/^} BB_REGISTER_DEFINITION_T, *PBB_REGISTER_DEFINITION_T;$/;"	t	typeref:struct:_BB_REGISTER_DEFINITION
-BB_REG_BASE_ADDR	include/rtw_mp.h	496;"	d
-BBrx_DFIR	include/Hal8188FPhyReg.h	1119;"	d
-BCNQ1_PAGE_NUM_8188F	include/rtl8188f_hal.h	115;"	d
-BCNQ1_PAGE_NUM_8188F	include/rtl8188f_hal.h	117;"	d
-BCNQ1_PAGE_NUM_8188F	include/rtl8188f_hal.h	121;"	d
-BCNQ1_PAGE_NUM_8188F	include/rtl8188f_hal.h	122;"	d
-BCNQ1_PAGE_NUM_8703B	include/rtl8703b_hal.h	117;"	d
-BCNQ1_PAGE_NUM_8703B	include/rtl8703b_hal.h	119;"	d
-BCNQ1_PAGE_NUM_8703B	include/rtl8703b_hal.h	123;"	d
-BCNQ1_PAGE_NUM_8703B	include/rtl8703b_hal.h	124;"	d
-BCNQ1_PAGE_NUM_8723B	include/rtl8723b_hal.h	117;"	d
-BCNQ1_PAGE_NUM_8723B	include/rtl8723b_hal.h	119;"	d
-BCNQ1_PAGE_NUM_8723B	include/rtl8723b_hal.h	123;"	d
-BCNQ1_PAGE_NUM_8723B	include/rtl8723b_hal.h	124;"	d
-BCNQ1_PAGE_NUM_8723D	include/rtl8723d_hal.h	122;"	d
-BCNQ1_PAGE_NUM_8723D	include/rtl8723d_hal.h	124;"	d
-BCNQ1_PAGE_NUM_8723D	include/rtl8723d_hal.h	128;"	d
-BCNQ1_PAGE_NUM_8723D	include/rtl8723d_hal.h	129;"	d
-BCNQ1_PAGE_NUM_8821	include/rtl8812a_hal.h	195;"	d
-BCNQ1_PAGE_NUM_8821	include/rtl8812a_hal.h	197;"	d
-BCNQ_PAGE_NUM_8188F	include/rtl8188f_hal.h	113;"	d
-BCNQ_PAGE_NUM_8703B	include/rtl8703b_hal.h	115;"	d
-BCNQ_PAGE_NUM_8723B	include/rtl8723b_hal.h	115;"	d
-BCNQ_PAGE_NUM_8723D	include/rtl8723d_hal.h	120;"	d
-BCNQ_PAGE_NUM_8812	include/rtl8812a_hal.h	143;"	d
-BCNQ_PAGE_NUM_8814	include/rtl8814a_hal.h	59;"	d
-BCNQ_PAGE_NUM_8821	include/rtl8812a_hal.h	193;"	d
-BCNQ_PAGE_NUM_88E	include/rtl8188e_hal.h	141;"	d
-BCN_DMA_ATIME_INT_TIME_8188E	include/rtl8188e_hal.h	114;"	d
-BCN_DMA_ATIME_INT_TIME_8188F	include/rtl8188f_hal.h	87;"	d
-BCN_DMA_ATIME_INT_TIME_8192E	include/rtl8192e_hal.h	113;"	d
-BCN_DMA_ATIME_INT_TIME_8703B	include/rtl8703b_hal.h	87;"	d
-BCN_DMA_ATIME_INT_TIME_8723B	include/rtl8723b_hal.h	87;"	d
-BCN_DMA_ATIME_INT_TIME_8723D	include/rtl8723d_hal.h	91;"	d
-BCN_DMA_ATIME_INT_TIME_8812	include/rtl8812a_hal.h	124;"	d
-BCN_DMA_ATIME_INT_TIME_8814	include/rtl8814a_hal.h	177;"	d
-BCN_QUEUE_INX	include/rtw_xmit.h	106;"	d
-BCQ_PGNUM_8814A	include/rtl8814a_hal.h	146;"	d
-BDC_BF_HOLD_STATE	hal/phydm/phydm_antdiv.h	115;"	d
-BDC_BFer_TRAIN_STATE	hal/phydm/phydm_antdiv.h	113;"	d
-BDC_DECISION_STATE	hal/phydm/phydm_antdiv.h	114;"	d
-BDC_DIV_HOLD_STATE	hal/phydm/phydm_antdiv.h	116;"	d
-BDC_DIV_TRAIN_STATE	hal/phydm/phydm_antdiv.h	112;"	d
-BDC_Hold_counter	hal/phydm/phydm_antdiv.h	/^	u1Byte BDC_Hold_counter;$/;"	m	struct:_BF_DIV_COEX_
-BDC_MODE_1	hal/phydm/phydm_antdiv.h	118;"	d
-BDC_MODE_2	hal/phydm/phydm_antdiv.h	119;"	d
-BDC_MODE_3	hal/phydm/phydm_antdiv.h	120;"	d
-BDC_MODE_4	hal/phydm/phydm_antdiv.h	121;"	d
-BDC_MODE_NULL	hal/phydm/phydm_antdiv.h	122;"	d
-BDC_Mode	hal/phydm/phydm_antdiv.h	/^	u1Byte BDC_Mode;$/;"	m	struct:_BF_DIV_COEX_
-BDC_RxIdleUpdate_counter	hal/phydm/phydm_antdiv.h	/^	u1Byte BDC_RxIdleUpdate_counter;$/;"	m	struct:_BF_DIV_COEX_
-BDC_T	hal/phydm/phydm_antdiv.h	/^}BDC_T,*pBDC_T;$/;"	t	typeref:struct:_BF_DIV_COEX_
-BDC_Try_counter	hal/phydm/phydm_antdiv.h	/^	u1Byte BDC_Try_counter;$/;"	m	struct:_BF_DIV_COEX_
-BDC_Try_flag	hal/phydm/phydm_antdiv.h	/^	BOOLEAN BDC_Try_flag;$/;"	m	struct:_BF_DIV_COEX_
-BDC_active_Mode	hal/phydm/phydm_antdiv.h	/^	u1Byte BDC_active_Mode;$/;"	m	struct:_BF_DIV_COEX_
-BDC_state	hal/phydm/phydm_antdiv.h	/^	u1Byte BDC_state;$/;"	m	struct:_BF_DIV_COEX_
-BDCcoexType_wBfer	hal/phydm/phydm_antdiv.h	/^	u1Byte  BDCcoexType_wBfer;$/;"	m	struct:_BF_DIV_COEX_
-BD_HCI_SEL	include/hal_com_reg.h	1272;"	d
-BD_MAC1	include/hal_com_reg.h	1262;"	d
-BD_MAC2	include/hal_com_reg.h	1261;"	d
-BD_PKG_SEL	include/hal_com_reg.h	1271;"	d
-BEACON_EARLY_TIME	core/rtw_ap.c	3981;"	d	file:
-BEACON_PROBE_SSID_ID_POSITION	include/ieee80211.h	1168;"	d
-BEACON_QUEUE	hal/phydm/phydm_beamforming.h	33;"	d
-BEAMFORMEE_CAP	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_CAP = BIT10,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_CAP	include/rtw_beamforming.h	/^	BEAMFORMEE_CAP = 0x80,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_CAP_HT_EXPLICIT	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_CAP_HT_EXPLICIT = BIT2, $/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_CAP_HT_EXPLICIT	include/rtw_beamforming.h	/^	BEAMFORMEE_CAP_HT_EXPLICIT = 0x2,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_CAP_VHT_MU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_CAP_VHT_MU = BIT8,			\/* Self has ee Cap, because Reg ee & peer er *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_CAP_VHT_MU	include/rtw_beamforming.h	/^	BEAMFORMEE_CAP_VHT_MU = 0x20,			\/* Self has ee Cap, because Reg ee & peer er *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_CAP_VHT_SU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_CAP_VHT_SU = BIT6,			\/* Self has ee Cap, because Reg ee & peer er *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_CAP_VHT_SU	include/rtw_beamforming.h	/^	BEAMFORMEE_CAP_VHT_SU = 0x8, 			\/* Self has ee Cap, because Reg ee & peer er *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMEE_ENTRY_NUM	hal/phydm/phydm_beamforming.h	28;"	d
-BEAMFORMEE_NOTIFY_ADD_MU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_NOTIFY_ADD_MU,$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMEE_NOTIFY_ADD_SU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_NOTIFY_ADD_SU,$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMEE_NOTIFY_DELETE_MU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_NOTIFY_DELETE_MU,$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMEE_NOTIFY_DELETE_SU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMEE_NOTIFY_DELETE_SU,$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMER_CAP	hal/phydm/phydm_beamforming.h	/^	BEAMFORMER_CAP = BIT9,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_CAP	include/rtw_beamforming.h	/^	BEAMFORMER_CAP = 0x40,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_CAP_HT_EXPLICIT	hal/phydm/phydm_beamforming.h	/^	BEAMFORMER_CAP_HT_EXPLICIT = BIT1, $/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_CAP_HT_EXPLICIT	include/rtw_beamforming.h	/^	BEAMFORMER_CAP_HT_EXPLICIT = 0x1,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_CAP_VHT_MU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMER_CAP_VHT_MU = BIT7,			\/* Self has er Cap, because Reg er  & peer ee *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_CAP_VHT_MU	include/rtw_beamforming.h	/^	BEAMFORMER_CAP_VHT_MU = 0x10,			\/* Self has er Cap, because Reg er & peer ee *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_CAP_VHT_SU	hal/phydm/phydm_beamforming.h	/^	BEAMFORMER_CAP_VHT_SU = BIT5,			\/* Self has er Cap, because Reg er  & peer ee *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_CAP_VHT_SU	include/rtw_beamforming.h	/^	BEAMFORMER_CAP_VHT_SU = 0x4,			\/* Self has er Cap, because Reg er  & peer ee *\/$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMER_ENTRY_NUM	hal/phydm/phydm_beamforming.h	29;"	d
-BEAMFORMING_CAP	hal/phydm/phydm_beamforming.h	/^}BEAMFORMING_CAP, *PBEAMFORMING_CAP;$/;"	t	typeref:enum:_BEAMFORMING_CAP
-BEAMFORMING_CAP	include/rtw_beamforming.h	/^} BEAMFORMING_CAP, *PBEAMFORMING_CAP;$/;"	t	typeref:enum:_BEAMFORMING_CAP
-BEAMFORMING_CAP_NONE	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_CAP_NONE = 0x0,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMING_CAP_NONE	include/rtw_beamforming.h	/^	BEAMFORMING_CAP_NONE = 0x0,$/;"	e	enum:_BEAMFORMING_CAP
-BEAMFORMING_CTRL_END_PERIOD	include/rtw_beamforming.h	/^	BEAMFORMING_CTRL_END_PERIOD = 3,$/;"	e	enum:BEAMFORMING_CTRL_TYPE
-BEAMFORMING_CTRL_ENTER	include/rtw_beamforming.h	/^	BEAMFORMING_CTRL_ENTER = 0,$/;"	e	enum:BEAMFORMING_CTRL_TYPE
-BEAMFORMING_CTRL_LEAVE	include/rtw_beamforming.h	/^	BEAMFORMING_CTRL_LEAVE = 1,$/;"	e	enum:BEAMFORMING_CTRL_TYPE
-BEAMFORMING_CTRL_SET_GID_TABLE	include/rtw_beamforming.h	/^	BEAMFORMING_CTRL_SET_GID_TABLE = 6,$/;"	e	enum:BEAMFORMING_CTRL_TYPE
-BEAMFORMING_CTRL_SOUNDING_CLK	include/rtw_beamforming.h	/^	BEAMFORMING_CTRL_SOUNDING_CLK = 5,$/;"	e	enum:BEAMFORMING_CTRL_TYPE
-BEAMFORMING_CTRL_SOUNDING_FAIL	include/rtw_beamforming.h	/^	BEAMFORMING_CTRL_SOUNDING_FAIL = 4,$/;"	e	enum:BEAMFORMING_CTRL_TYPE
-BEAMFORMING_CTRL_START_PERIOD	include/rtw_beamforming.h	/^	BEAMFORMING_CTRL_START_PERIOD = 2,$/;"	e	enum:BEAMFORMING_CTRL_TYPE
-BEAMFORMING_CTRL_TYPE	include/rtw_beamforming.h	/^enum BEAMFORMING_CTRL_TYPE {$/;"	g
-BEAMFORMING_ENTRY_NUM	include/rtw_beamforming.h	39;"	d
-BEAMFORMING_ENTRY_STATE	hal/phydm/phydm_beamforming.h	/^} BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;$/;"	t	typeref:enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE	include/rtw_beamforming.h	/^} BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;$/;"	t	typeref:enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_INITIALIZED	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_INITIALIZED, $/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_INITIALIZED	include/rtw_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_INITIALIZED,$/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_INITIALIZEING	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_INITIALIZEING, $/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_INITIALIZEING	include/rtw_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_INITIALIZEING,$/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_PROGRESSED	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_PROGRESSED $/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_PROGRESSED	include/rtw_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_PROGRESSED,$/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_PROGRESSING	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_PROGRESSING, $/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_PROGRESSING	include/rtw_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_PROGRESSING,$/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_UNINITIALIZE	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_UNINITIALIZE, $/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_ENTRY_STATE_UNINITIALIZE	include/rtw_beamforming.h	/^	BEAMFORMING_ENTRY_STATE_UNINITIALIZE,$/;"	e	enum:_BEAMFORMING_ENTRY_STATE
-BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP	include/rtw_ht.h	96;"	d
-BEAMFORMING_HT_BEAMFORMEE_ENABLE	include/rtw_ht.h	93;"	d
-BEAMFORMING_HT_BEAMFORMER_ENABLE	include/rtw_ht.h	92;"	d
-BEAMFORMING_HT_BEAMFORMER_STEER_NUM	include/rtw_ht.h	95;"	d
-BEAMFORMING_HT_BEAMFORMER_TEST	include/rtw_ht.h	94;"	d
-BEAMFORMING_NOTIFY_ADD	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_NOTIFY_ADD,$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMING_NOTIFY_DELETE	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_NOTIFY_DELETE,$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMING_NOTIFY_NONE	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_NOTIFY_NONE,$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMING_NOTIFY_RESET	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_NOTIFY_RESET$/;"	e	enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMING_NOTIFY_STATE	hal/phydm/phydm_beamforming.h	/^} BEAMFORMING_NOTIFY_STATE, *PBEAMFORMING_NOTIFY_STATE;$/;"	t	typeref:enum:_BEAMFORMING_NOTIFY_STATE
-BEAMFORMING_STATE	include/rtw_beamforming.h	/^} BEAMFORMING_STATE, *PBEAMFORMING_STATE;$/;"	t	typeref:enum:_BEAMFORMING_STATE
-BEAMFORMING_STATE_END	include/rtw_beamforming.h	/^	BEAMFORMING_STATE_END,$/;"	e	enum:_BEAMFORMING_STATE
-BEAMFORMING_STATE_IDLE	include/rtw_beamforming.h	/^	BEAMFORMING_STATE_IDLE,$/;"	e	enum:_BEAMFORMING_STATE
-BEAMFORMING_STATE_START	include/rtw_beamforming.h	/^	BEAMFORMING_STATE_START,$/;"	e	enum:_BEAMFORMING_STATE
-BEAMFORMING_SUPPORT	hal/phydm/phydm_beamforming.h	5;"	d
-BEAMFORMING_VHT_BEAMFORMEE_ENABLE	include/rtw_vht.h	34;"	d
-BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM	include/rtw_vht.h	39;"	d
-BEAMFORMING_VHT_BEAMFORMER_ENABLE	include/rtw_vht.h	33;"	d
-BEAMFORMING_VHT_BEAMFORMER_STS_CAP	include/rtw_vht.h	38;"	d
-BEAMFORMING_VHT_BEAMFORMER_TEST	include/rtw_vht.h	37;"	d
-BEAMFORMING_VHT_MU_MIMO_AP_ENABLE	include/rtw_vht.h	35;"	d
-BEAMFORMING_VHT_MU_MIMO_STA_ENABLE	include/rtw_vht.h	36;"	d
-BEAMFORMING_WK_CID	include/rtw_cmd.h	/^	BEAMFORMING_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-BEAMFORM_ENTRY_HW_STATE_ADDED	include/rtw_beamforming.h	/^	BEAMFORM_ENTRY_HW_STATE_ADDED,$/;"	e	enum:_BEAMFORM_ENTRY_HW_STATE
-BEAMFORM_ENTRY_HW_STATE_ADDING	include/rtw_beamforming.h	/^	BEAMFORM_ENTRY_HW_STATE_ADDING,$/;"	e	enum:_BEAMFORM_ENTRY_HW_STATE
-BEAMFORM_ENTRY_HW_STATE_ADD_INIT	include/rtw_beamforming.h	/^	BEAMFORM_ENTRY_HW_STATE_ADD_INIT,$/;"	e	enum:_BEAMFORM_ENTRY_HW_STATE
-BEAMFORM_ENTRY_HW_STATE_DELETE_INIT	include/rtw_beamforming.h	/^	BEAMFORM_ENTRY_HW_STATE_DELETE_INIT,$/;"	e	enum:_BEAMFORM_ENTRY_HW_STATE
-BEAMFORM_ENTRY_HW_STATE_DELETING	include/rtw_beamforming.h	/^	BEAMFORM_ENTRY_HW_STATE_DELETING,$/;"	e	enum:_BEAMFORM_ENTRY_HW_STATE
-BEAMFORM_ENTRY_HW_STATE_MAX	include/rtw_beamforming.h	/^	BEAMFORM_ENTRY_HW_STATE_MAX$/;"	e	enum:_BEAMFORM_ENTRY_HW_STATE
-BEAMFORM_ENTRY_HW_STATE_NONE	include/rtw_beamforming.h	/^	BEAMFORM_ENTRY_HW_STATE_NONE,$/;"	e	enum:_BEAMFORM_ENTRY_HW_STATE
-BE_BITS_CLEARED_TO_1BYTE	include/basic_types.h	286;"	d
-BE_BITS_CLEARED_TO_2BYTE	include/basic_types.h	283;"	d
-BE_BITS_CLEARED_TO_4BYTE	include/basic_types.h	280;"	d
-BE_BITS_TO_1BYTE	include/basic_types.h	260;"	d
-BE_BITS_TO_2BYTE	include/basic_types.h	257;"	d
-BE_BITS_TO_4BYTE	include/basic_types.h	254;"	d
-BE_P1BYTE_TO_HOST_1BYTE	include/basic_types.h	235;"	d
-BE_P2BYTE_TO_HOST_2BYTE	include/basic_types.h	234;"	d
-BE_P4BYTE_TO_HOST_4BYTE	include/basic_types.h	233;"	d
-BE_QUEUE_INX	include/rtw_xmit.h	104;"	d
-BE_QUEUE_TX_DESC_NUM_8188EE	include/rtl8188e_hal.h	242;"	d
-BE_QUEUE_TX_DESC_NUM_8188EE	include/rtl8188e_hal.h	245;"	d
-BE_QUEUE_TX_DESC_NUM_8814A	include/rtl8814a_hal.h	207;"	d
-BE_QUEUE_TX_DESC_NUM_8814A	include/rtl8814a_hal.h	209;"	d
-BFP_BTC_COEX_H2C_PROCESS	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_COEX_H2C_PROCESS)($/;"	t
-BFP_BTC_DISP_DBG_MSG	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_DISP_DBG_MSG)($/;"	t
-BFP_BTC_FILL_H2C	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_FILL_H2C)($/;"	t
-BFP_BTC_GET	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET)($/;"	t
-BFP_BTC_GET_ANT_DET_VAL_FROM_BT	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_ANT_DET_VAL_FROM_BT)($/;"	t
-BFP_BTC_GET_BB_REG	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_BB_REG)($/;"	t
-BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT)($/;"	t
-BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT)($/;"	t
-BFP_BTC_GET_BT_AFH_MAP_FROM_BT	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_BT_AFH_MAP_FROM_BT)($/;"	t
-BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE)($/;"	t
-BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION)($/;"	t
-BFP_BTC_GET_BT_REG	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_BT_REG)($/;"	t
-BFP_BTC_GET_PHYDM_VERSION	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_PHYDM_VERSION)($/;"	t
-BFP_BTC_GET_RF_REG	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_GET_RF_REG)($/;"	t
-BFP_BTC_LOCAL_REG_W1	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_LOCAL_REG_W1)($/;"	t
-BFP_BTC_R1	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_R1)($/;"	t
-BFP_BTC_R2	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_R2)($/;"	t
-BFP_BTC_R4	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_R4)($/;"	t
-BFP_BTC_SET	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_SET)($/;"	t
-BFP_BTC_SET_BB_REG	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_SET_BB_REG)($/;"	t
-BFP_BTC_SET_BT_ANT_DETECTION	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_SET_BT_ANT_DETECTION)($/;"	t
-BFP_BTC_SET_BT_REG	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_SET_BT_REG)($/;"	t
-BFP_BTC_SET_BT_TRX_MASK	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_SET_BT_TRX_MASK)($/;"	t
-BFP_BTC_SET_RF_REG	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_SET_RF_REG)($/;"	t
-BFP_BTC_W1	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_W1)($/;"	t
-BFP_BTC_W1_BIT_MASK	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_W1_BIT_MASK)($/;"	t
-BFP_BTC_W2	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_W2)($/;"	t
-BFP_BTC_W4	hal/btc/HalBtcOutSrc.h	/^(*BFP_BTC_W4)($/;"	t
-BF_pass	hal/phydm/phydm_antdiv.h	/^	BOOLEAN BF_pass;$/;"	m	struct:_BF_DIV_COEX_
-BIP_AAD_SIZE	include/ieee80211.h	1107;"	d
-BIP_MAX_KEYID	include/ieee80211.h	1106;"	d
-BIST	include/drv_types_pci.h	/^	u8	BIST;$/;"	m	struct:_PCI_COMMON_CONFIG
-BIT	include/osdep_service.h	58;"	d
-BIT	include/wifi.h	26;"	d
-BIT	include/wifi.h	28;"	d
-BIT0	include/osdep_service.h	61;"	d
-BIT1	include/osdep_service.h	62;"	d
-BIT10	include/osdep_service.h	71;"	d
-BIT11	include/osdep_service.h	72;"	d
-BIT12	include/osdep_service.h	73;"	d
-BIT13	include/osdep_service.h	74;"	d
-BIT14	include/osdep_service.h	75;"	d
-BIT15	include/osdep_service.h	76;"	d
-BIT16	include/osdep_service.h	77;"	d
-BIT17	include/osdep_service.h	78;"	d
-BIT18	include/osdep_service.h	79;"	d
-BIT19	include/osdep_service.h	80;"	d
-BIT2	include/osdep_service.h	63;"	d
-BIT20	include/osdep_service.h	81;"	d
-BIT21	include/osdep_service.h	82;"	d
-BIT22	include/osdep_service.h	83;"	d
-BIT23	include/osdep_service.h	84;"	d
-BIT24	include/osdep_service.h	85;"	d
-BIT25	include/osdep_service.h	86;"	d
-BIT26	include/osdep_service.h	87;"	d
-BIT27	include/osdep_service.h	88;"	d
-BIT28	include/osdep_service.h	89;"	d
-BIT29	include/osdep_service.h	90;"	d
-BIT3	include/osdep_service.h	64;"	d
-BIT30	include/osdep_service.h	91;"	d
-BIT31	include/osdep_service.h	92;"	d
-BIT32	include/osdep_service.h	93;"	d
-BIT33	include/osdep_service.h	94;"	d
-BIT34	include/osdep_service.h	95;"	d
-BIT35	include/osdep_service.h	96;"	d
-BIT36	include/osdep_service.h	97;"	d
-BIT4	include/osdep_service.h	65;"	d
-BIT5	include/osdep_service.h	66;"	d
-BIT6	include/osdep_service.h	67;"	d
-BIT7	include/osdep_service.h	68;"	d
-BIT8	include/osdep_service.h	69;"	d
-BIT9	include/osdep_service.h	70;"	d
-BITS_PER_LONG	include/osdep_service_bsd.h	174;"	d
-BIT_AUTO_INIT_LLT	include/hal_com_reg.h	1429;"	d
-BIT_BCN_PORT_SEL	include/hal_com_reg.h	712;"	d
-BIT_BCN_PORT_SEL	include/rtl8188f_spec.h	217;"	d
-BIT_BCN_PORT_SEL	include/rtl8192e_spec.h	302;"	d
-BIT_BCN_PORT_SEL	include/rtl8703b_spec.h	396;"	d
-BIT_BCN_PORT_SEL	include/rtl8723b_spec.h	201;"	d
-BIT_CTS_EN	include/hal_com_reg.h	1593;"	d
-BIT_DMA_MODE	include/rtl8192e_spec.h	290;"	d
-BIT_FA_RESET	hal/phydm/phydm_reg.h	210;"	d
-BIT_LEN_MASK_16	include/basic_types.h	175;"	d
-BIT_LEN_MASK_32	include/basic_types.h	174;"	d
-BIT_LEN_MASK_8	include/basic_types.h	176;"	d
-BIT_LSIC_TXOP_EN	include/hal_com_reg.h	1592;"	d
-BIT_MASK_TXPKTNUM	include/hal_com_reg.h	1425;"	d
-BIT_MASK_Tx_OQT_free_space	include/hal_com_reg.h	1432;"	d
-BIT_MBIDCAM_POLL	include/hal_com_reg.h	1585;"	d
-BIT_MBIDCAM_VALID	include/hal_com_reg.h	1591;"	d
-BIT_MBIDCAM_WT_EN	include/hal_com_reg.h	1586;"	d
-BIT_OFFSET_LEN_MASK_16	include/basic_types.h	185;"	d
-BIT_OFFSET_LEN_MASK_32	include/basic_types.h	184;"	d
-BIT_OFFSET_LEN_MASK_8	include/basic_types.h	186;"	d
-BIT_REG_LED_CFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	56;"	d
-BIT_SHIFT_TXPKTNUM	include/hal_com_reg.h	1424;"	d
-BIT_SHIFT_Tx_OQT_free_space	include/hal_com_reg.h	1431;"	d
-BIT_SPSLDO_SEL	include/rtl8192e_spec.h	296;"	d
-BIT_TDE_DBG_SEL	include/hal_com_reg.h	1428;"	d
-BIT_TXPKTNUM	include/hal_com_reg.h	1426;"	d
-BIT_Tx_OQT_free_space	include/hal_com_reg.h	1433;"	d
-BIT_USB_RXDMA_AGG_EN	include/rtl8188f_spec.h	199;"	d
-BIT_USB_RXDMA_AGG_EN	include/rtl8192e_spec.h	291;"	d
-BIT_USB_RXDMA_AGG_EN	include/rtl8703b_spec.h	375;"	d
-BIT_USB_RXDMA_AGG_EN	include/rtl8723b_spec.h	183;"	d
-BIT_USB_RXDMA_AGG_EN	include/rtl8723d_spec.h	411;"	d
-BK_QUEUE_INX	include/rtw_xmit.h	105;"	d
-BK_SupportAbility	hal/phydm/phydm.h	/^	u4Byte			BK_SupportAbility;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-BLK_DESC_NUM_MASK	include/hal_com_reg.h	1417;"	d
-BLK_DESC_NUM_SHIFT	include/hal_com_reg.h	1416;"	d
-BLOCK_ACK	include/ieee80211.h	536;"	d
-BMC	include/rtl8188e_xmit.h	44;"	d
-BMC	include/rtl8192e_xmit.h	149;"	d
-BMC	include/rtl8812a_xmit.h	42;"	d
-BM_DATA_EN	include/hal_com_reg.h	1560;"	d
-BOOLEAN	hal/phydm/phydm_types.h	/^	typedef unsigned char			BOOLEAN,*PBOOLEAN;$/;"	t
-BOOLEAN	include/basic_types.h	/^typedef unsigned char	BOOLEAN, *PBOOLEAN, boolean;$/;"	t
-BOOLEAN_temp	hal/phydm/phydm.h	/^	BOOLEAN			BOOLEAN_temp;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-BOOT_FROM_EEPROM	include/hal_com_reg.h	1205;"	d
-BRCM_VENDOR_EVENT_PRIV_STR	os_dep/linux/rtw_cfgvendor.h	/^	BRCM_VENDOR_EVENT_PRIV_STR,$/;"	e	enum:wl_vendor_event
-BRCM_VENDOR_EVENT_UNSPEC	os_dep/linux/rtw_cfgvendor.h	/^	BRCM_VENDOR_EVENT_UNSPEC,$/;"	e	enum:wl_vendor_event
-BRCM_VENDOR_SCMD_CAPA	os_dep/linux/rtw_cfgvendor.h	232;"	d
-BRCM_VENDOR_SCMD_PRIV_STR	os_dep/linux/rtw_cfgvendor.h	/^	BRCM_VENDOR_SCMD_PRIV_STR,$/;"	e	enum:wl_vendor_subcmd
-BRCM_VENDOR_SCMD_UNSPEC	os_dep/linux/rtw_cfgvendor.h	/^	BRCM_VENDOR_SCMD_UNSPEC,$/;"	e	enum:wl_vendor_subcmd
-BRCM_VENDOR_SUBCMD_PRIV_STR	os_dep/linux/rtw_cfgvendor.h	26;"	d
-BROADCAST_FLAG	core/rtw_br_ext.c	1498;"	d	file:
-BROADCOM_OUI1	core/rtw_wlan_util.c	/^unsigned char BROADCOM_OUI1[] = {0x00, 0x10, 0x18};$/;"	v
-BROADCOM_OUI2	core/rtw_wlan_util.c	/^unsigned char BROADCOM_OUI2[] = {0x00, 0x0a, 0xf7};$/;"	v
-BROADCOM_OUI3	core/rtw_wlan_util.c	/^unsigned char BROADCOM_OUI3[] = {0x00, 0x05, 0xb5};$/;"	v
-BR_NAME	Makefile	/^BR_NAME = br0$/;"	m
-BSSID	include/rtw_ioctl_set.h	/^	NDIS_802_11_MAC_ADDRESS  BSSID;$/;"	m	struct:_BSSIDInfo
-BSSID	include/wlan_bssdef.h	/^	NDIS_802_11_MAC_ADDRESS BSSID;$/;"	m	struct:_NDIS_802_11_KEY
-BSSID	include/wlan_bssdef.h	/^	NDIS_802_11_MAC_ADDRESS BSSID;$/;"	m	struct:_NDIS_802_11_REMOVE_KEY
-BSSID	include/wlan_bssdef.h	/^	NDIS_802_11_MAC_ADDRESS BSSID;$/;"	m	struct:_PMKID_CANDIDATE
-BSSIDInfo	include/rtw_ioctl_set.h	/^	BSSIDInfo BSSIDInfo[1];$/;"	m	struct:_NDIS_802_11_PMKID
-BSSIDInfo	include/rtw_ioctl_set.h	/^} BSSIDInfo, *PBSSIDInfo;$/;"	t	typeref:struct:_BSSIDInfo
-BSSIDInfoCount	include/rtw_ioctl_set.h	/^	u32	BSSIDInfoCount;$/;"	m	struct:_NDIS_802_11_PMKID
-BSSID_OFT	include/drv_types.h	427;"	d
-BSSID_SZ	include/drv_types.h	428;"	d
-BSS_EX_FIXED_IE_OFFSET	include/wlan_bssdef.h	577;"	d
-BSS_EX_IES	include/wlan_bssdef.h	575;"	d
-BSS_EX_IES_LEN	include/wlan_bssdef.h	576;"	d
-BSS_EX_TLV_IES	include/wlan_bssdef.h	578;"	d
-BSS_EX_TLV_IES_LEN	include/wlan_bssdef.h	579;"	d
-BT30_CurIGI	hal/phydm/phydm_dig.h	/^	u1Byte		BT30_CurIGI;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-BTAsocCount	include/rtw_btcoex.h	/^	u1Byte				BTAsocCount;$/;"	m	struct:_BT_MGNT
-BTAuthCount	include/rtw_btcoex.h	/^	u1Byte				BTAuthCount;$/;"	m	struct:_BT_MGNT
-BTCDBGINFO	hal/hal_btcoex.c	/^} BTCDBGINFO, *PBTCDBGINFO;$/;"	t	typeref:struct:_btcoexdbginfo	file:
-BTCOEXVERSION	include/rtw_version.h	2;"	d
-BTCOEX_ALIVE	include/rtw_pwrctrl.h	44;"	d
-BTCOEX_SUSPEND_STATE	include/rtw_btcoex.h	/^} BTCOEX_SUSPEND_STATE, *PBTCOEX_SUSPEND_STATE;$/;"	t	typeref:enum:_BTCOEX_SUSPEND_STATE
-BTCOEX_SUSPEND_STATE_MAX	include/rtw_btcoex.h	/^	BTCOEX_SUSPEND_STATE_MAX$/;"	e	enum:_BTCOEX_SUSPEND_STATE
-BTCOEX_SUSPEND_STATE_RESUME	include/rtw_btcoex.h	/^	BTCOEX_SUSPEND_STATE_RESUME					= 0x0,$/;"	e	enum:_BTCOEX_SUSPEND_STATE
-BTCOEX_SUSPEND_STATE_SUSPEND	include/rtw_btcoex.h	/^	BTCOEX_SUSPEND_STATE_SUSPEND				= 0x1,$/;"	e	enum:_BTCOEX_SUSPEND_STATE
-BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT	include/rtw_btcoex.h	/^	BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT		= 0x2,$/;"	e	enum:_BTCOEX_SUSPEND_STATE
-BTC_ANTENNA_AT_AUX_PORT	hal/btc/HalBtcOutSrc.h	/^	BTC_ANTENNA_AT_AUX_PORT				= 0x2,$/;"	e	enum:_BTC_ANTENNA_POS
-BTC_ANTENNA_AT_MAIN_PORT	hal/btc/HalBtcOutSrc.h	/^	BTC_ANTENNA_AT_MAIN_PORT				= 0x1,$/;"	e	enum:_BTC_ANTENNA_POS
-BTC_ANTENNA_POS	hal/btc/HalBtcOutSrc.h	/^} BTC_ANTENNA_POS, *PBTC_ANTENNA_POS;$/;"	t	typeref:enum:_BTC_ANTENNA_POS
-BTC_ANT_PATH_AUTO	hal/btc/HalBtcOutSrc.h	50;"	d
-BTC_ANT_PATH_BT	hal/btc/HalBtcOutSrc.h	47;"	d
-BTC_ANT_PATH_PTA	hal/btc/HalBtcOutSrc.h	48;"	d
-BTC_ANT_PATH_WIFI	hal/btc/HalBtcOutSrc.h	46;"	d
-BTC_ANT_PATH_WIFI5G	hal/btc/HalBtcOutSrc.h	49;"	d
-BTC_ANT_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_ANT_TYPE, *PBTC_ANT_TYPE;$/;"	t	typeref:enum:_BTC_ANT_TYPE
-BTC_ANT_TYPE_0	hal/btc/HalBtcOutSrc.h	/^	BTC_ANT_TYPE_0,$/;"	e	enum:_BTC_ANT_TYPE
-BTC_ANT_TYPE_1	hal/btc/HalBtcOutSrc.h	/^	BTC_ANT_TYPE_1,$/;"	e	enum:_BTC_ANT_TYPE
-BTC_ANT_TYPE_2	hal/btc/HalBtcOutSrc.h	/^	BTC_ANT_TYPE_2,$/;"	e	enum:_BTC_ANT_TYPE
-BTC_ANT_TYPE_3	hal/btc/HalBtcOutSrc.h	/^	BTC_ANT_TYPE_3,$/;"	e	enum:_BTC_ANT_TYPE
-BTC_ANT_TYPE_4	hal/btc/HalBtcOutSrc.h	/^	BTC_ANT_TYPE_4,$/;"	e	enum:_BTC_ANT_TYPE
-BTC_ANT_TYPE_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_ANT_TYPE_MAX$/;"	e	enum:_BTC_ANT_TYPE
-BTC_ANT_WIFI_AT_AUX	hal/btc/HalBtcOutSrc.h	53;"	d
-BTC_ANT_WIFI_AT_CPL_AUX	hal/btc/HalBtcOutSrc.h	57;"	d
-BTC_ANT_WIFI_AT_CPL_MAIN	hal/btc/HalBtcOutSrc.h	56;"	d
-BTC_ANT_WIFI_AT_DIVERSITY	hal/btc/HalBtcOutSrc.h	54;"	d
-BTC_ANT_WIFI_AT_MAIN	hal/btc/HalBtcOutSrc.h	52;"	d
-BTC_ASSOCIATE_5G_FINISH	hal/btc/HalBtcOutSrc.h	/^	BTC_ASSOCIATE_5G_FINISH						= 0x2,$/;"	e	enum:_BTC_NOTIFY_TYPE_ASSOCIATE
-BTC_ASSOCIATE_5G_START	hal/btc/HalBtcOutSrc.h	/^	BTC_ASSOCIATE_5G_START						= 0x3,$/;"	e	enum:_BTC_NOTIFY_TYPE_ASSOCIATE
-BTC_ASSOCIATE_FINISH	hal/btc/HalBtcOutSrc.h	/^	BTC_ASSOCIATE_FINISH						= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_ASSOCIATE
-BTC_ASSOCIATE_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_ASSOCIATE_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_ASSOCIATE
-BTC_ASSOCIATE_START	hal/btc/HalBtcOutSrc.h	/^	BTC_ASSOCIATE_START						= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_ASSOCIATE
-BTC_BTOFFON	hal/btc/HalBtcOutSrc.h	/^} BTC_BTOFFON, *PBTC_BT_OFFON;$/;"	t	typeref:enum:_BTC_BT_OFFON
-BTC_BT_OFF	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_OFF				= 0x0,$/;"	e	enum:_BTC_BT_OFFON
-BTC_BT_ON	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_ON				= 0x1,$/;"	e	enum:_BTC_BT_OFFON
-BTC_BT_REG_BLUEWIZE	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_REG_BLUEWIZE					= 2,$/;"	e	enum:_BTC_BT_REG_TYPE
-BTC_BT_REG_LE	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_REG_LE						= 4,$/;"	e	enum:_BTC_BT_REG_TYPE
-BTC_BT_REG_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_REG_MAX$/;"	e	enum:_BTC_BT_REG_TYPE
-BTC_BT_REG_MODEM	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_REG_MODEM					= 1,$/;"	e	enum:_BTC_BT_REG_TYPE
-BTC_BT_REG_RF	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_REG_RF						= 0,$/;"	e	enum:_BTC_BT_REG_TYPE
-BTC_BT_REG_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_BT_REG_TYPE, *PBTC_BT_REG_TYPE;$/;"	t	typeref:enum:_BTC_BT_REG_TYPE
-BTC_BT_REG_VENDOR	hal/btc/HalBtcOutSrc.h	/^	BTC_BT_REG_VENDOR					= 3,$/;"	e	enum:_BTC_BT_REG_TYPE
-BTC_CHIP_CSR_BC4	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_CSR_BC4		= 1,$/;"	e	enum:_BTC_CHIP_TYPE
-BTC_CHIP_CSR_BC8	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_CSR_BC8		= 2,$/;"	e	enum:_BTC_CHIP_TYPE
-BTC_CHIP_INTERFACE	hal/btc/HalBtcOutSrc.h	/^} BTC_CHIP_INTERFACE, *PBTC_CHIP_INTERFACE;$/;"	t	typeref:enum:_BTC_CHIP_INTERFACE
-BTC_CHIP_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_MAX$/;"	e	enum:_BTC_CHIP_TYPE
-BTC_CHIP_RTL8723A	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_RTL8723A		= 3,$/;"	e	enum:_BTC_CHIP_TYPE
-BTC_CHIP_RTL8723B	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_RTL8723B		= 5,$/;"	e	enum:_BTC_CHIP_TYPE
-BTC_CHIP_RTL8821	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_RTL8821		= 4,$/;"	e	enum:_BTC_CHIP_TYPE
-BTC_CHIP_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_CHIP_TYPE, *PBTC_CHIP_TYPE;$/;"	t	typeref:enum:_BTC_CHIP_TYPE
-BTC_CHIP_UNDEF	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_UNDEF		= 0,$/;"	e	enum:_BTC_CHIP_TYPE
-BTC_COEX_OFFLOAD	hal/btc/HalBtcOutSrc.h	5;"	d
-BTC_DBG_DISP_BT_LINK_INFO	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_DISP_BT_LINK_INFO				= 0x1,$/;"	e	enum:_BTC_DBG_DISP_TYPE
-BTC_DBG_DISP_COEX_STATISTICS	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_DISP_COEX_STATISTICS				= 0x0,$/;"	e	enum:_BTC_DBG_DISP_TYPE
-BTC_DBG_DISP_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_DISP_MAX$/;"	e	enum:_BTC_DBG_DISP_TYPE
-BTC_DBG_DISP_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_DBG_DISP_TYPE, *PBTC_DBG_DISP_TYPE;$/;"	t	typeref:enum:_BTC_DBG_DISP_TYPE
-BTC_DBG_DISP_WIFI_STATUS	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_DISP_WIFI_STATUS				= 0x2,$/;"	e	enum:_BTC_DBG_DISP_TYPE
-BTC_DBG_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_MAX$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DBG_OPCODE	hal/btc/HalBtcOutSrc.h	/^} BTC_DBG_OPCODE, *PBTC_DBG_OPCODE;$/;"	t	typeref:enum:_BTC_DBG_OPCODE
-BTC_DBG_SET_COEX_BT_AFH_MAP	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_SET_COEX_BT_AFH_MAP				= 0x4,$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT		= 0x5,$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DBG_SET_COEX_BT_ONLY	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_SET_COEX_BT_ONLY				= 0x2,$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DBG_SET_COEX_DEC_BT_PWR	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_SET_COEX_DEC_BT_PWR				= 0x3,$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DBG_SET_COEX_MANUAL_CTRL	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_SET_COEX_MANUAL_CTRL				= 0x6,$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DBG_SET_COEX_NORMAL	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_SET_COEX_NORMAL				= 0x0,$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DBG_SET_COEX_WIFI_ONLY	hal/btc/HalBtcOutSrc.h	/^	BTC_DBG_SET_COEX_WIFI_ONLY				= 0x1,$/;"	e	enum:_BTC_DBG_OPCODE
-BTC_DMDP	hal/btc/HalBtcOutSrc.h	31;"	d
-BTC_DMSP	hal/btc/HalBtcOutSrc.h	32;"	d
-BTC_FREQ_2_4G	hal/btc/HalBtcOutSrc.h	/^	BTC_FREQ_2_4G					= 0x0,$/;"	e	enum:_BTC_WIRELESS_FREQ
-BTC_FREQ_5G	hal/btc/HalBtcOutSrc.h	/^	BTC_FREQ_5G						= 0x1,$/;"	e	enum:_BTC_WIRELESS_FREQ
-BTC_FREQ_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_FREQ_MAX$/;"	e	enum:_BTC_WIRELESS_FREQ
-BTC_GET_BL_EXT_SWITCH	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_EXT_SWITCH,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_HS_CONNECTING	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_HS_CONNECTING,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_HS_OPERATION	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_HS_OPERATION,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_IS_ASUS_8723B	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_IS_ASUS_8723B,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_4_WAY_PROGRESS	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_4_WAY_PROGRESS,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_AP_MODE_ENABLE	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_AP_MODE_ENABLE,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_BUSY	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_BUSY,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_CONNECTED	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_CONNECTED,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_ENABLE_ENCRYPTION	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_IS_IN_MP_MODE	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_IS_IN_MP_MODE,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_LINK	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_LINK,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_ROAM	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_ROAM,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_SCAN	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_SCAN,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_UNDER_5G	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_UNDER_5G,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_BL_WIFI_UNDER_B_MODE	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_BL_WIFI_UNDER_B_MODE,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_MAX$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_S4_HS_RSSI	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_S4_HS_RSSI,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_S4_WIFI_RSSI	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_S4_WIFI_RSSI,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_GET_TYPE, *PBTC_GET_TYPE;$/;"	t	typeref:enum:_BTC_GET_TYPE
-BTC_GET_U1_ANT_TYPE	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_ANT_TYPE,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_AP_NUM	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_AP_NUM,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_IOT_PEER	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_IOT_PEER,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_LPS_MODE	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_LPS_MODE,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_MAC_PHY_MODE	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_MAC_PHY_MODE,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_WIFI_CENTRAL_CHNL	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_WIFI_CENTRAL_CHNL,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_WIFI_DOT11_CHNL	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_WIFI_DOT11_CHNL,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_WIFI_HS_CHNL	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_WIFI_HS_CHNL,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U1_WIFI_P2P_CHNL	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U1_WIFI_P2P_CHNL,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_BT_PATCH_VER	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_BT_PATCH_VER,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_SUPPORTED_FEATURE	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_SUPPORTED_FEATURE,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_SUPPORTED_VERSION	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_SUPPORTED_VERSION,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_VENDOR	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_VENDOR,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_WIFI_BW	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_WIFI_BW,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_WIFI_FW_VER	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_WIFI_FW_VER,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_WIFI_IQK_FAIL	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_WIFI_IQK_FAIL,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_WIFI_IQK_OK	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_WIFI_IQK_OK,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_WIFI_IQK_TOTAL	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_WIFI_IQK_TOTAL,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_WIFI_LINK_STATUS	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_WIFI_LINK_STATUS,$/;"	e	enum:_BTC_GET_TYPE
-BTC_GET_U4_WIFI_TRAFFIC_DIRECTION	hal/btc/HalBtcOutSrc.h	/^	BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,$/;"	e	enum:_BTC_GET_TYPE
-BTC_INTF_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_INTF_MAX$/;"	e	enum:_BTC_CHIP_INTERFACE
-BTC_INTF_PCI	hal/btc/HalBtcOutSrc.h	/^	BTC_INTF_PCI			= 1,$/;"	e	enum:_BTC_CHIP_INTERFACE
-BTC_INTF_SDIO	hal/btc/HalBtcOutSrc.h	/^	BTC_INTF_SDIO		= 3,$/;"	e	enum:_BTC_CHIP_INTERFACE
-BTC_INTF_UNKNOWN	hal/btc/HalBtcOutSrc.h	/^	BTC_INTF_UNKNOWN	= 0,$/;"	e	enum:_BTC_CHIP_INTERFACE
-BTC_INTF_USB	hal/btc/HalBtcOutSrc.h	/^	BTC_INTF_USB			= 2,$/;"	e	enum:_BTC_CHIP_INTERFACE
-BTC_IOT_PEER	hal/btc/HalBtcOutSrc.h	/^} BTC_IOT_PEER, *PBTC_IOT_PEER;$/;"	t	typeref:enum:_BTC_IOT_PEER
-BTC_IOT_PEER_AIRGO	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_AIRGO = 11,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_ATHEROS	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_ATHEROS = 5,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_BROADCOM	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_BROADCOM = 3,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_CISCO	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_CISCO = 6,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_INTEL	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_INTEL				= 12,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_MARVELL	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_MARVELL = 8,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_MAX,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_MERU	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_MERU = 7,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_RALINK	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_RALINK = 4,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_REALTEK	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_REALTEK = 1,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_REALTEK_81XX	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_REALTEK_81XX		= 14,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_REALTEK_92SE	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_REALTEK_92SE = 2,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_REALTEK_JAGUAR_BCUTAP	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_REALTEK_JAGUAR_BCUTAP = 16,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_REALTEK_JAGUAR_CCUTAP	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_REALTEK_SOFTAP	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_REALTEK_SOFTAP = 9, \/* peer is RealTek SOFT_AP, by Bohn, 2009.12.17 *\/$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_REALTEK_WOW	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_REALTEK_WOW		= 15,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_RTK_APCLIENT	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_RTK_APCLIENT		= 13,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_SELF_SOFTAP	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_SELF_SOFTAP = 10, \/* Self is SoftAP *\/$/;"	e	enum:_BTC_IOT_PEER
-BTC_IOT_PEER_UNKNOWN	hal/btc/HalBtcOutSrc.h	/^	BTC_IOT_PEER_UNKNOWN = 0,$/;"	e	enum:_BTC_IOT_PEER
-BTC_IPS_ENTER	hal/btc/HalBtcOutSrc.h	/^	BTC_IPS_ENTER							= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_IPS
-BTC_IPS_LEAVE	hal/btc/HalBtcOutSrc.h	/^	BTC_IPS_LEAVE							= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_IPS
-BTC_IPS_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_IPS_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_IPS
-BTC_LPS_DISABLE	hal/btc/HalBtcOutSrc.h	/^	BTC_LPS_DISABLE							= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_LPS
-BTC_LPS_ENABLE	hal/btc/HalBtcOutSrc.h	/^	BTC_LPS_ENABLE							= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_LPS
-BTC_LPS_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_LPS_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_LPS
-BTC_MEDIA_CONNECT	hal/btc/HalBtcOutSrc.h	/^	BTC_MEDIA_CONNECT						= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_MEDIA_STATUS
-BTC_MEDIA_DISCONNECT	hal/btc/HalBtcOutSrc.h	/^	BTC_MEDIA_DISCONNECT					= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_MEDIA_STATUS
-BTC_MEDIA_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_MEDIA_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_MEDIA_STATUS
-BTC_MIMO_PS_DYNAMIC	hal/btc/HalBtcOutSrc.h	40;"	d
-BTC_MIMO_PS_STATIC	hal/btc/HalBtcOutSrc.h	39;"	d
-BTC_MPOPER_TIMEOUT	hal/hal_btcoex.c	187;"	d	file:
-BTC_MP_UNKNOWN	hal/btc/HalBtcOutSrc.h	33;"	d
-BTC_MSG_COMP_TYPE	hal/btc/Mp_Precomp.h	/^}BTC_MSG_COMP_TYPE;$/;"	t	typeref:enum:_BTC_MSG_COMP_TYPE
-BTC_NOTIFY_TYPE_ASSOCIATE	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_ASSOCIATE, *PBTC_NOTIFY_TYPE_ASSOCIATE;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_ASSOCIATE
-BTC_NOTIFY_TYPE_IPS	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_IPS, *PBTC_NOTIFY_TYPE_IPS;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_IPS
-BTC_NOTIFY_TYPE_LPS	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_LPS, *PBTC_NOTIFY_TYPE_LPS;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_LPS
-BTC_NOTIFY_TYPE_MEDIA_STATUS	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_MEDIA_STATUS, *PBTC_NOTIFY_TYPE_MEDIA_STATUS;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_MEDIA_STATUS
-BTC_NOTIFY_TYPE_SCAN	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_SCAN, *PBTC_NOTIFY_TYPE_SCAN;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_SCAN
-BTC_NOTIFY_TYPE_SPECIFIC_PACKET	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_SPECIFIC_PACKET, *PBTC_NOTIFY_TYPE_SPECIFIC_PACKET;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_SPECIFIC_PACKET
-BTC_NOTIFY_TYPE_STACK_OPERATION	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_STACK_OPERATION, *PBTC_NOTIFY_TYPE_STACK_OPERATION;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_STACK_OPERATION
-BTC_NOTIFY_TYPE_SWITCHBAND	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_SWITCHBAND, *PBTC_NOTIFY_TYPE_SWITCHBAND;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_SWITCHBAND
-BTC_NOT_SWITCH	hal/btc/HalBtcOutSrc.h	/^	BTC_NOT_SWITCH							= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_SWITCHBAND
-BTC_OFFLOAD	hal/btc/HalBtcOutSrc.h	/^} BTC_OFFLOAD, *PBTC_OFFLOAD;$/;"	t	typeref:struct:_BTC_OFFLOAD
-BTC_PACKET_ARP	hal/btc/HalBtcOutSrc.h	/^	BTC_PACKET_ARP							= 0x2,$/;"	e	enum:_BTC_NOTIFY_TYPE_SPECIFIC_PACKET
-BTC_PACKET_DHCP	hal/btc/HalBtcOutSrc.h	/^	BTC_PACKET_DHCP							= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_SPECIFIC_PACKET
-BTC_PACKET_EAPOL	hal/btc/HalBtcOutSrc.h	/^	BTC_PACKET_EAPOL						= 0x3,$/;"	e	enum:_BTC_NOTIFY_TYPE_SPECIFIC_PACKET
-BTC_PACKET_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_PACKET_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_SPECIFIC_PACKET
-BTC_PACKET_UNKNOWN	hal/btc/HalBtcOutSrc.h	/^	BTC_PACKET_UNKNOWN					= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_SPECIFIC_PACKET
-BTC_PHYDM_CMNINFOQUERY	hal/btc/HalBtcOutSrc.h	/^(*BTC_PHYDM_CMNINFOQUERY)($/;"	t
-BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD	hal/btc/HalBtcOutSrc.h	/^(*BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD)($/;"	t
-BTC_POWERSAVE_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_POWERSAVE_TYPE, *PBTC_POWERSAVE_TYPE;$/;"	t	typeref:enum:_BTC_POWERSAVE_TYPE
-BTC_PS_LPS_OFF	hal/btc/HalBtcOutSrc.h	/^	BTC_PS_LPS_OFF				= 2,$/;"	e	enum:_BTC_POWERSAVE_TYPE
-BTC_PS_LPS_ON	hal/btc/HalBtcOutSrc.h	/^	BTC_PS_LPS_ON				= 1,$/;"	e	enum:_BTC_POWERSAVE_TYPE
-BTC_PS_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_PS_MAX$/;"	e	enum:_BTC_POWERSAVE_TYPE
-BTC_PS_WIFI_NATIVE	hal/btc/HalBtcOutSrc.h	/^	BTC_PS_WIFI_NATIVE			= 0,	\/* wifi original power save behavior *\/$/;"	e	enum:_BTC_POWERSAVE_TYPE
-BTC_RATE_DISABLE	hal/btc/HalBtcOutSrc.h	42;"	d
-BTC_RATE_ENABLE	hal/btc/HalBtcOutSrc.h	43;"	d
-BTC_RF_A	hal/btc/HalBtcOutSrc.h	25;"	d
-BTC_RF_B	hal/btc/HalBtcOutSrc.h	26;"	d
-BTC_RF_C	hal/btc/HalBtcOutSrc.h	27;"	d
-BTC_RF_D	hal/btc/HalBtcOutSrc.h	28;"	d
-BTC_RF_OFF	hal/btc/HalBtcOutSrc.h	22;"	d
-BTC_RF_ON	hal/btc/HalBtcOutSrc.h	23;"	d
-BTC_ROLE_AP	hal/btc/HalBtcOutSrc.h	/^	BTC_ROLE_AP								= 0x1,$/;"	e	enum:_BTC_WIFI_ROLE
-BTC_ROLE_HS_MODE	hal/btc/HalBtcOutSrc.h	/^	BTC_ROLE_HS_MODE						= 0x3,$/;"	e	enum:_BTC_WIFI_ROLE
-BTC_ROLE_IBSS	hal/btc/HalBtcOutSrc.h	/^	BTC_ROLE_IBSS							= 0x2,$/;"	e	enum:_BTC_WIFI_ROLE
-BTC_ROLE_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_ROLE_MAX$/;"	e	enum:_BTC_WIFI_ROLE
-BTC_ROLE_STATION	hal/btc/HalBtcOutSrc.h	/^	BTC_ROLE_STATION						= 0x0,$/;"	e	enum:_BTC_WIFI_ROLE
-BTC_RSSI_COEX_THRESH_TOL_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	4;"	d
-BTC_RSSI_COEX_THRESH_TOL_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	4;"	d
-BTC_RSSI_COEX_THRESH_TOL_8192E_1ANT	hal/btc/HalBtc8192e1Ant.h	23;"	d
-BTC_RSSI_COEX_THRESH_TOL_8192E_2ANT	hal/btc/HalBtc8192e2Ant.h	19;"	d
-BTC_RSSI_COEX_THRESH_TOL_8703B_1ANT	hal/btc/HalBtc8703b1Ant.h	23;"	d
-BTC_RSSI_COEX_THRESH_TOL_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	26;"	d
-BTC_RSSI_COEX_THRESH_TOL_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	13;"	d
-BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT	hal/btc/HalBtc8723b1Ant.h	22;"	d
-BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT	hal/btc/HalBtc8723b2Ant.h	20;"	d
-BTC_RSSI_COEX_THRESH_TOL_8723D_1ANT	hal/btc/halbtc8723d1ant.h	24;"	d
-BTC_RSSI_COEX_THRESH_TOL_8723D_2ANT	hal/btc/halbtc8723d2ant.h	22;"	d
-BTC_RSSI_COEX_THRESH_TOL_8812A_1ANT	hal/btc/HalBtc8812a1Ant.h	23;"	d
-BTC_RSSI_COEX_THRESH_TOL_8812A_2ANT	hal/btc/HalBtc8812a2Ant.h	23;"	d
-BTC_RSSI_COEX_THRESH_TOL_8821A_1ANT	hal/btc/HalBtc8821a1Ant.h	23;"	d
-BTC_RSSI_COEX_THRESH_TOL_8821A_2ANT	hal/btc/HalBtc8821a2Ant.h	21;"	d
-BTC_RSSI_COEX_THRESH_TOL_8821A_CSR_2ANT	hal/btc/HalBtc8821aCsr2Ant.h	18;"	d
-BTC_RSSI_COEX_THRESH_TOL_8821C_1ANT	hal/btc/halbtc8821c1ant.h	23;"	d
-BTC_RSSI_COEX_THRESH_TOL_8821C_2ANT	hal/btc/halbtc8821c2ant.h	21;"	d
-BTC_RSSI_COEX_THRESH_TOL_8822B_1ANT	hal/btc/HalBtc8822b1Ant.h	23;"	d
-BTC_RSSI_HIGH	hal/btc/HalBtcOutSrc.h	143;"	d
-BTC_RSSI_LOW	hal/btc/HalBtcOutSrc.h	145;"	d
-BTC_RSSI_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_RSSI_MAX$/;"	e	enum:_BTC_RSSI_STATE
-BTC_RSSI_MEDIUM	hal/btc/HalBtcOutSrc.h	144;"	d
-BTC_RSSI_STATE	hal/btc/HalBtcOutSrc.h	/^} BTC_RSSI_STATE, *PBTC_RSSI_STATE;$/;"	t	typeref:enum:_BTC_RSSI_STATE
-BTC_RSSI_STATE_HIGH	hal/btc/HalBtcOutSrc.h	/^	BTC_RSSI_STATE_HIGH						= 0x0,$/;"	e	enum:_BTC_RSSI_STATE
-BTC_RSSI_STATE_LOW	hal/btc/HalBtcOutSrc.h	/^	BTC_RSSI_STATE_LOW						= 0x2,$/;"	e	enum:_BTC_RSSI_STATE
-BTC_RSSI_STATE_MEDIUM	hal/btc/HalBtcOutSrc.h	/^	BTC_RSSI_STATE_MEDIUM					= 0x1,$/;"	e	enum:_BTC_RSSI_STATE
-BTC_RSSI_STATE_STAY_HIGH	hal/btc/HalBtcOutSrc.h	/^	BTC_RSSI_STATE_STAY_HIGH					= 0x3,$/;"	e	enum:_BTC_RSSI_STATE
-BTC_RSSI_STATE_STAY_LOW	hal/btc/HalBtcOutSrc.h	/^	BTC_RSSI_STATE_STAY_LOW					= 0x5,$/;"	e	enum:_BTC_RSSI_STATE
-BTC_RSSI_STATE_STAY_MEDIUM	hal/btc/HalBtcOutSrc.h	/^	BTC_RSSI_STATE_STAY_MEDIUM				= 0x4,$/;"	e	enum:_BTC_RSSI_STATE
-BTC_SCAN_FINISH	hal/btc/HalBtcOutSrc.h	/^	BTC_SCAN_FINISH							= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_SCAN
-BTC_SCAN_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_SCAN_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_SCAN
-BTC_SCAN_START	hal/btc/HalBtcOutSrc.h	/^	BTC_SCAN_START							= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_SCAN
-BTC_SCAN_START_2G	hal/btc/HalBtcOutSrc.h	/^	BTC_SCAN_START_2G						= 0x2,$/;"	e	enum:_BTC_NOTIFY_TYPE_SCAN
-BTC_SET_ACT_AGGREGATE_CTRL	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_AGGREGATE_CTRL,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_ANTPOSREGRISTRY_CTRL	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_CTRL_8723B_ANT	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_CTRL_8723B_ANT,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_CTRL_BT_COEX	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_CTRL_BT_COEX,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_CTRL_BT_INFO	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_CTRL_BT_INFO,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_DISABLE_LOW_POWER	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_DISABLE_LOW_POWER,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_ENTER_LPS	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_ENTER_LPS,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_GET_BT_RSSI	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_GET_BT_RSSI,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_LEAVE_LPS	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_LEAVE_LPS,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_NORMAL_LPS	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_NORMAL_LPS,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_SEND_MIMO_PS	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_SEND_MIMO_PS,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_ACT_UPDATE_RAMASK	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_ACT_UPDATE_RAMASK,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_BT_CTRL_AGG_SIZE	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_BT_CTRL_AGG_SIZE,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_BT_DISABLE	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_BT_DISABLE,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_BT_LIMITED_DIG	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_BT_LIMITED_DIG,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_BT_TRAFFIC_BUSY	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_BT_TRAFFIC_BUSY,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_BT_TX_RX_MASK	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_BT_TX_RX_MASK,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_FORCE_TO_ROAM	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_FORCE_TO_ROAM,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_INC_SCAN_DEV_NUM	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_INC_SCAN_DEV_NUM,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_MIRACAST_PLUS_BT	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_MIRACAST_PLUS_BT,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_BL_TO_REJ_AP_AGG_PKT	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_BL_TO_REJ_AP_AGG_PKT,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_MAX$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_SET_TYPE, *PBTC_SET_TYPE;$/;"	t	typeref:enum:_BTC_SET_TYPE
-BTC_SET_U1_AGG_BUF_SIZE	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_U1_AGG_BUF_SIZE,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_U1_LPS_VAL	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_U1_LPS_VAL,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_U1_RPWM_VAL	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_U1_RPWM_VAL,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON	hal/btc/HalBtcOutSrc.h	/^	BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,$/;"	e	enum:_BTC_SET_TYPE
-BTC_SMSP	hal/btc/HalBtcOutSrc.h	30;"	d
-BTC_SPRINTF	hal/btc/HalBtcOutSrc.h	9;"	d
-BTC_STACK_OP_INQ_PAGE_PAIR_FINISH	hal/btc/HalBtcOutSrc.h	/^	BTC_STACK_OP_INQ_PAGE_PAIR_FINISH	= 0x2,$/;"	e	enum:_BTC_NOTIFY_TYPE_STACK_OPERATION
-BTC_STACK_OP_INQ_PAGE_PAIR_START	hal/btc/HalBtcOutSrc.h	/^	BTC_STACK_OP_INQ_PAGE_PAIR_START		= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_STACK_OPERATION
-BTC_STACK_OP_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_STACK_OP_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_STACK_OPERATION
-BTC_STACK_OP_NONE	hal/btc/HalBtcOutSrc.h	/^	BTC_STACK_OP_NONE					= 0x0,$/;"	e	enum:_BTC_NOTIFY_TYPE_STACK_OPERATION
-BTC_SWITCH_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_SWITCH_MAX$/;"	e	enum:_BTC_NOTIFY_TYPE_SWITCHBAND
-BTC_SWITCH_TO_24G	hal/btc/HalBtcOutSrc.h	/^	BTC_SWITCH_TO_24G						= 0x1,$/;"	e	enum:_BTC_NOTIFY_TYPE_SWITCHBAND
-BTC_SWITCH_TO_24G_NOFORSCAN	hal/btc/HalBtcOutSrc.h	/^	BTC_SWITCH_TO_24G_NOFORSCAN				= 0x3,$/;"	e	enum:_BTC_NOTIFY_TYPE_SWITCHBAND
-BTC_SWITCH_TO_5G	hal/btc/HalBtcOutSrc.h	/^	BTC_SWITCH_TO_5G						= 0x2,$/;"	e	enum:_BTC_NOTIFY_TYPE_SWITCHBAND
-BTC_TMP_BUF_SHORT	hal/btc/HalBtcOutSrc.h	6;"	d
-BTC_TRACE	hal/btc/HalBtcOutSrc.h	10;"	d
-BTC_VENDOR	hal/btc/HalBtcOutSrc.h	/^} BTC_VENDOR, *PBTC_VENDOR;$/;"	t	typeref:enum:_BTC_VENDOR
-BTC_VENDOR_ASUS	hal/btc/HalBtcOutSrc.h	/^	BTC_VENDOR_ASUS,$/;"	e	enum:_BTC_VENDOR
-BTC_VENDOR_LENOVO	hal/btc/HalBtcOutSrc.h	/^	BTC_VENDOR_LENOVO,$/;"	e	enum:_BTC_VENDOR
-BTC_VENDOR_OTHER	hal/btc/HalBtcOutSrc.h	/^	BTC_VENDOR_OTHER$/;"	e	enum:_BTC_VENDOR
-BTC_WIFI_BW_HT160	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_BW_HT160					= 0x4,$/;"	e	enum:_BTC_WIFI_BW_MODE
-BTC_WIFI_BW_HT20	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_BW_HT20					= 0x1,$/;"	e	enum:_BTC_WIFI_BW_MODE
-BTC_WIFI_BW_HT40	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_BW_HT40					= 0x2,$/;"	e	enum:_BTC_WIFI_BW_MODE
-BTC_WIFI_BW_HT80	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_BW_HT80					= 0x3,$/;"	e	enum:_BTC_WIFI_BW_MODE
-BTC_WIFI_BW_LEGACY	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_BW_LEGACY					= 0x0,$/;"	e	enum:_BTC_WIFI_BW_MODE
-BTC_WIFI_BW_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_BW_MAX$/;"	e	enum:_BTC_WIFI_BW_MODE
-BTC_WIFI_BW_MODE	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_BW_MODE, *PBTC_WIFI_BW_MODE;$/;"	t	typeref:enum:_BTC_WIFI_BW_MODE
-BTC_WIFI_COEX_STATE	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_COEX_STATE, *PBTC_WIFI_COEX_STATE;$/;"	t	typeref:enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_PNP	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_PNP, *PBTC_WIFI_PNP;$/;"	t	typeref:enum:_BTC_WIFI_PNP
-BTC_WIFI_PNP_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_PNP_MAX$/;"	e	enum:_BTC_WIFI_PNP
-BTC_WIFI_PNP_SLEEP	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_PNP_SLEEP						= 0x1,$/;"	e	enum:_BTC_WIFI_PNP
-BTC_WIFI_PNP_SLEEP_KEEP_ANT	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_PNP_SLEEP_KEEP_ANT				= 0x2,$/;"	e	enum:_BTC_WIFI_PNP
-BTC_WIFI_PNP_WAKE_UP	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_PNP_WAKE_UP					= 0x0,$/;"	e	enum:_BTC_WIFI_PNP
-BTC_WIFI_ROLE	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_ROLE, *PBTC_WIFI_ROLE;$/;"	t	typeref:enum:_BTC_WIFI_ROLE
-BTC_WIFI_STAT_ANT_DIV	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_STAT_ANT_DIV,$/;"	e	enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_STAT_INIT	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_STAT_INIT,$/;"	e	enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_STAT_IQK	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_STAT_IQK,$/;"	e	enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_STAT_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_STAT_MAX$/;"	e	enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_STAT_MP_OFF	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_STAT_MP_OFF,$/;"	e	enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_STAT_NORMAL	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_STAT_NORMAL,$/;"	e	enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_STAT_NORMAL_OFF	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_STAT_NORMAL_OFF,$/;"	e	enum:_BTC_WIFI_COEX_STATE
-BTC_WIFI_TRAFFIC_DIR	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_TRAFFIC_DIR, *PBTC_WIFI_TRAFFIC_DIR;$/;"	t	typeref:enum:_BTC_WIFI_TRAFFIC_DIR
-BTC_WIFI_TRAFFIC_MAX	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_TRAFFIC_MAX$/;"	e	enum:_BTC_WIFI_TRAFFIC_DIR
-BTC_WIFI_TRAFFIC_RX	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_TRAFFIC_RX					= 0x1,$/;"	e	enum:_BTC_WIFI_TRAFFIC_DIR
-BTC_WIFI_TRAFFIC_TX	hal/btc/HalBtcOutSrc.h	/^	BTC_WIFI_TRAFFIC_TX					= 0x0,$/;"	e	enum:_BTC_WIFI_TRAFFIC_DIR
-BTC_WIRELESS_FREQ	hal/btc/HalBtcOutSrc.h	/^} BTC_WIRELESS_FREQ, *PBTC_WIRELESS_FREQ;$/;"	t	typeref:enum:_BTC_WIRELESS_FREQ
-BTChannel	include/rtw_btcoex.h	/^	u1Byte				BTChannel;$/;"	m	struct:_BT_MGNT
-BTCoreSpec	include/rtw_btcoex.h	/^	u1Byte					BTCoreSpec;$/;"	m	struct:_HCI_LINK_INFO
-BTCurrentConnectType	include/rtw_btcoex.h	/^	BT_CONNECT_TYPE		BTCurrentConnectType;$/;"	m	struct:_BT_MGNT
-BTEfuseContent	core/efuse/rtw_efuse.c	/^u8	BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];$/;"	v
-BTEfuseContent	include/rtw_efuse.h	/^	u8	BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];$/;"	m	struct:_EFUSE_HAL
-BTEfuseInitMap	core/efuse/rtw_efuse.c	/^u8	BTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN] = {0};$/;"	v
-BTEfuseInitMap	include/rtw_efuse.h	/^	u8	BTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN];$/;"	m	struct:_EFUSE_HAL
-BTEfuseModifiedMap	core/efuse/rtw_efuse.c	/^u8	BTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN] = {0};$/;"	v
-BTEfuseModifiedMap	include/rtw_efuse.h	/^	u8	BTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN];$/;"	m	struct:_EFUSE_HAL
-BTEfusePowerSwitch	include/hal_intf.h	/^	void (*BTEfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);$/;"	m	struct:hal_ops
-BTEfuseUsedBytes	core/efuse/rtw_efuse.c	/^u32	BTEfuseUsedBytes = {0};$/;"	v
-BTEfuseUsedBytes	include/rtw_efuse.h	/^	u16	BTEfuseUsedBytes;$/;"	m	struct:_EFUSE_HAL
-BTEfuseUsedPercentage	include/rtw_efuse.h	/^	u8	BTEfuseUsedPercentage;$/;"	m	struct:_EFUSE_HAL
-BTEfuse_PowerSwitch	core/efuse/rtw_efuse.c	/^BTEfuse_PowerSwitch($/;"	f
-BTEfuse_PowerSwitch	core/efuse/rtw_efuse.c	/^void BTEfuse_PowerSwitch(PADAPTER adapter, u8 write, u8 pwrstate)$/;"	f
-BTINFO_BT_AUTO_RPT	core/rtw_cmd.c	3716;"	d	file:
-BTINFO_WIFI_FETCH	core/rtw_cmd.c	3715;"	d	file:
-BTINFO_WK_CID	include/rtw_cmd.h	/^	BTINFO_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-BTNeedAMPStatusChg	include/rtw_btcoex.h	/^	BOOLEAN				BTNeedAMPStatusChg;$/;"	m	struct:_BT_MGNT
-BTProfile	include/rtw_btcoex.h	/^	u1Byte					BTProfile;$/;"	m	struct:_HCI_LINK_INFO
-BTRF_HWPDN_N	include/hal_com_reg.h	1294;"	d
-BTReceiveConnectPkt	include/rtw_btcoex.h	/^	BT_CONNECT_TYPE		BTReceiveConnectPkt;$/;"	m	struct:_BT_MGNT
-BTRxRSSIPercentage	hal/phydm/phydm.h	/^	u1Byte		BTRxRSSIPercentage;$/;"	m	struct:_ODM_Phy_Status_Info_
-BTRxRSSIPercentage	include/rtw_recv.h	/^	u8			BTRxRSSIPercentage;$/;"	m	struct:phy_info
-BT_2WIRE	include/hal_pg.h	/^	BT_2WIRE		= 0,$/;"	e	enum:_BT_CoType
-BT_8188C_2ANT_BT_STATUS	hal/btc/HalBtc8188c2Ant.h	/^}BT_8188C_2ANT_BT_STATUS,*PBT_8188C_2ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8188C_2ANT_BT_STATUS
-BT_8188C_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,$/;"	e	enum:_BT_8188C_2ANT_BT_STATUS
-BT_8188C_2ANT_BT_STATUS_IDLE	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_BT_STATUS_IDLE				= 0x0,$/;"	e	enum:_BT_8188C_2ANT_BT_STATUS
-BT_8188C_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_BT_STATUS_MAX$/;"	e	enum:_BT_8188C_2ANT_BT_STATUS
-BT_8188C_2ANT_BT_STATUS_NON_IDLE	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_BT_STATUS_NON_IDLE			= 0x2,$/;"	e	enum:_BT_8188C_2ANT_BT_STATUS
-BT_8188C_2ANT_COEX_ALGO	hal/btc/HalBtc8188c2Ant.h	/^}BT_8188C_2ANT_COEX_ALGO,*PBT_8188C_2ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_HID					= 0x2,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_HID_A2DP			= 0x5,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_HID_PAN	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_HID_PAN				= 0x6,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_MAX$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_PAN	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_PAN					= 0x4,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_PAN_A2DP	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_PAN_A2DP			= 0x7,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_SCO					= 0x1,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8188C_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8188c2Ant.h	/^	BT_8188C_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:_BT_8188C_2ANT_COEX_ALGO
-BT_8192D_2ANT_BT_STATUS	hal/btc/HalBtc8192d2Ant.h	/^}BT_8192D_2ANT_BT_STATUS,*PBT_8192D_2ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8192D_2ANT_BT_STATUS
-BT_8192D_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,$/;"	e	enum:_BT_8192D_2ANT_BT_STATUS
-BT_8192D_2ANT_BT_STATUS_IDLE	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_BT_STATUS_IDLE				= 0x0,$/;"	e	enum:_BT_8192D_2ANT_BT_STATUS
-BT_8192D_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_BT_STATUS_MAX$/;"	e	enum:_BT_8192D_2ANT_BT_STATUS
-BT_8192D_2ANT_BT_STATUS_NON_IDLE	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_BT_STATUS_NON_IDLE			= 0x2,$/;"	e	enum:_BT_8192D_2ANT_BT_STATUS
-BT_8192D_2ANT_COEX_ALGO	hal/btc/HalBtc8192d2Ant.h	/^}BT_8192D_2ANT_COEX_ALGO,*PBT_8192D_2ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_HID					= 0x2,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_HID_A2DP			= 0x5,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_HID_PAN	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_HID_PAN				= 0x6,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_MAX$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_PAN	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_PAN					= 0x4,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_PAN_A2DP	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_PAN_A2DP			= 0x7,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_SCO					= 0x1,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192D_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8192d2Ant.h	/^	BT_8192D_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:_BT_8192D_2ANT_COEX_ALGO
-BT_8192E_1ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8192e_1ant_bt_status
-BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8192e_1ant_bt_status
-BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8192e_1ant_bt_status
-BT_8192E_1ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8192e_1ant_bt_status
-BT_8192E_1ANT_BT_STATUS_MAX	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8192e_1ant_bt_status
-BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8192e_1ant_bt_status
-BT_8192E_1ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8192e_1ant_bt_status
-BT_8192E_1ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_HID	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_MAX	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_SCO	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8192e_1ant_coex_algo
-BT_8192E_1ANT_WIFI_NOISY_THRESH	hal/btc/HalBtc8192e1Ant.h	25;"	d
-BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8192e_1ant_wifi_status
-BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8192e_1ant_wifi_status
-BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8192e_1ant_wifi_status
-BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8192e_1ant_wifi_status
-BT_8192E_1ANT_WIFI_STATUS_MAX	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8192e_1ant_wifi_status
-BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8192e_1ant_wifi_status
-BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8192e1Ant.h	/^	BT_8192E_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8192e_1ant_wifi_status
-BT_8192E_2ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8192e_2ant_bt_status
-BT_8192E_2ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8192e_2ant_bt_status
-BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8192e_2ant_bt_status
-BT_8192E_2ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8192e_2ant_bt_status
-BT_8192E_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_BT_STATUS_MAX$/;"	e	enum:bt_8192e_2ant_bt_status
-BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8192e_2ant_bt_status
-BT_8192E_2ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8192e_2ant_bt_status
-BT_8192E_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_A2DP			= 0x4,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_A2DP_PANHS		= 0x5,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_HID				= 0x3,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_HID_A2DP		= 0xb,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0xa,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_MAX				= 0xc$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_PANEDR			= 0x6,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x8,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_PANEDR_HID		= 0x9,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_PANHS			= 0x7,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_SCO_PAN	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_SCO_PAN			= 0x2,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8192E_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8192e2Ant.h	/^	BT_8192E_2ANT_COEX_ALGO_UNDEFINED		= 0x0,$/;"	e	enum:bt_8192e_2ant_coex_algo
-BT_8703B_1ANT_ANTDET_BUF_LEN	hal/btc/HalBtc8703b1Ant.h	244;"	d
-BT_8703B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE	hal/btc/HalBtc8703b1Ant.h	35;"	d
-BT_8703B_1ANT_ANTDET_ENABLE	hal/btc/HalBtc8703b1Ant.h	34;"	d
-BT_8703B_1ANT_ANTDET_PSDTHRES_1ANT	hal/btc/HalBtc8703b1Ant.h	31;"	d
-BT_8703B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION	hal/btc/HalBtc8703b1Ant.h	29;"	d
-BT_8703B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	hal/btc/HalBtc8703b1Ant.h	30;"	d
-BT_8703B_1ANT_ANTDET_PSDTHRES_BACKGROUND	hal/btc/HalBtc8703b1Ant.h	28;"	d
-BT_8703B_1ANT_ANTDET_PSD_AVGNUM	hal/btc/HalBtc8703b1Ant.h	243;"	d
-BT_8703B_1ANT_ANTDET_PSD_POINTS	hal/btc/HalBtc8703b1Ant.h	242;"	d
-BT_8703B_1ANT_ANTDET_RETRY_INTERVAL	hal/btc/HalBtc8703b1Ant.h	32;"	d
-BT_8703B_1ANT_ANTDET_SWEEPPOINT_DELAY	hal/btc/HalBtc8703b1Ant.h	33;"	d
-BT_8703B_1ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8703b_1ant_bt_status
-BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8703b_1ant_bt_status
-BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8703b_1ant_bt_status
-BT_8703B_1ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8703b_1ant_bt_status
-BT_8703B_1ANT_BT_STATUS_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8703b_1ant_bt_status
-BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8703b_1ant_bt_status
-BT_8703B_1ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8703b_1ant_bt_status
-BT_8703B_1ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_HID	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_SCO	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8703b_1ant_coex_algo
-BT_8703B_1ANT_CTT_BT_VS_LTE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_CTT_BT_VS_LTE			= 0x1,$/;"	e	enum:bt_8703b_1ant_lte_coex_table_type
-BT_8703B_1ANT_CTT_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_CTT_MAX$/;"	e	enum:bt_8703b_1ant_lte_coex_table_type
-BT_8703B_1ANT_CTT_WL_VS_LTE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_CTT_WL_VS_LTE			= 0x0,$/;"	e	enum:bt_8703b_1ant_lte_coex_table_type
-BT_8703B_1ANT_ENABLE_GNTBT_TO_GPIO14	hal/btc/HalBtc8703b1Ant.h	9;"	d
-BT_8703B_1ANT_GNT_BLOCK_BB	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_GNT_BLOCK_BB			= 0x2,$/;"	e	enum:bt_8703b_1ant_gnt_ctrl_block
-BT_8703B_1ANT_GNT_BLOCK_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_GNT_BLOCK_MAX$/;"	e	enum:bt_8703b_1ant_gnt_ctrl_block
-BT_8703B_1ANT_GNT_BLOCK_RFC	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_GNT_BLOCK_RFC			= 0x1,$/;"	e	enum:bt_8703b_1ant_gnt_ctrl_block
-BT_8703B_1ANT_GNT_BLOCK_RFC_BB	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_GNT_BLOCK_RFC_BB		= 0x0,$/;"	e	enum:bt_8703b_1ant_gnt_ctrl_block
-BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,$/;"	e	enum:bt_8703b_1ant_gnt_ctrl_type
-BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,$/;"	e	enum:bt_8703b_1ant_gnt_ctrl_type
-BT_8703B_1ANT_GNT_TYPE_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_GNT_TYPE_MAX$/;"	e	enum:bt_8703b_1ant_gnt_ctrl_type
-BT_8703B_1ANT_LBTT_BT_BREAK_LTE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_LBTT_BT_BREAK_LTE				= 0x1,$/;"	e	enum:bt_8703b_1ant_lte_break_table_type
-BT_8703B_1ANT_LBTT_LTE_BREAK_BT	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_LBTT_LTE_BREAK_BT				= 0x3,$/;"	e	enum:bt_8703b_1ant_lte_break_table_type
-BT_8703B_1ANT_LBTT_LTE_BREAK_WL	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_LBTT_LTE_BREAK_WL			= 0x2,$/;"	e	enum:bt_8703b_1ant_lte_break_table_type
-BT_8703B_1ANT_LBTT_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_LBTT_MAX$/;"	e	enum:bt_8703b_1ant_lte_break_table_type
-BT_8703B_1ANT_LBTT_WL_BREAK_LTE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_LBTT_WL_BREAK_LTE			= 0x0,$/;"	e	enum:bt_8703b_1ant_lte_break_table_type
-BT_8703B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT	hal/btc/HalBtc8703b1Ant.h	37;"	d
-BT_8703B_1ANT_PCO_BTSIDE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_PCO_BTSIDE		= 0x0,$/;"	e	enum:bt_8703b_1ant_path_ctrl_owner
-BT_8703B_1ANT_PCO_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_PCO_MAX$/;"	e	enum:bt_8703b_1ant_path_ctrl_owner
-BT_8703B_1ANT_PCO_WLSIDE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_PCO_WLSIDE	= 0x1,$/;"	e	enum:bt_8703b_1ant_path_ctrl_owner
-BT_8703B_1ANT_SIG_STA_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_SIG_STA_MAX$/;"	e	enum:bt_8703b_1ant_signal_state
-BT_8703B_1ANT_SIG_STA_SET_BY_HW	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_SIG_STA_SET_BY_HW		= 0x0,$/;"	e	enum:bt_8703b_1ant_signal_state
-BT_8703B_1ANT_SIG_STA_SET_TO_HIGH	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,$/;"	e	enum:bt_8703b_1ant_signal_state
-BT_8703B_1ANT_SIG_STA_SET_TO_LOW	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_SIG_STA_SET_TO_LOW		= 0x0,$/;"	e	enum:bt_8703b_1ant_signal_state
-BT_8703B_1ANT_WIFI_NOISY_THRESH	hal/btc/HalBtc8703b1Ant.h	25;"	d
-BT_8703B_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8703b_1ant_wifi_status
-BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8703b_1ant_wifi_status
-BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8703b_1ant_wifi_status
-BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8703b_1ant_wifi_status
-BT_8703B_1ANT_WIFI_STATUS_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8703b_1ant_wifi_status
-BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8703b_1ant_wifi_status
-BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8703b1Ant.h	/^	BT_8703B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8703b_1ant_wifi_status
-BT_8723A_1ANT_BT_STATUS	hal/btc/HalBtc8723a1Ant.h	/^}BT_8723A_1ANT_BT_STATUS,*PBT_8723A_1ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8723A_1ANT_BT_STATUS
-BT_8723A_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,$/;"	e	enum:_BT_8723A_1ANT_BT_STATUS
-BT_8723A_1ANT_BT_STATUS_IDLE	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_BT_STATUS_IDLE				= 0x0,$/;"	e	enum:_BT_8723A_1ANT_BT_STATUS
-BT_8723A_1ANT_BT_STATUS_MAX	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_BT_STATUS_MAX$/;"	e	enum:_BT_8723A_1ANT_BT_STATUS
-BT_8723A_1ANT_BT_STATUS_NON_IDLE	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_BT_STATUS_NON_IDLE			= 0x2,$/;"	e	enum:_BT_8723A_1ANT_BT_STATUS
-BT_8723A_1ANT_COEX_ALGO	hal/btc/HalBtc8723a1Ant.h	/^}BT_8723A_1ANT_COEX_ALGO,*PBT_8723A_1ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_HID	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_HID_A2DP			= 0x9,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x8,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_MAX	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_MAX$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_PANEDR			= 0x4,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x6,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_PANEDR_HID		= 0x7,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_PANHS			= 0x5,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_SCO	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_1ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8723a1Ant.h	/^	BT_8723A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:_BT_8723A_1ANT_COEX_ALGO
-BT_8723A_2ANT_BT_STATUS	hal/btc/HalBtc8723a2Ant.h	/^}BT_8723A_2ANT_BT_STATUS,*PBT_8723A_2ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8723A_2ANT_BT_STATUS
-BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,$/;"	e	enum:_BT_8723A_2ANT_BT_STATUS
-BT_8723A_2ANT_BT_STATUS_IDLE	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_BT_STATUS_IDLE				= 0x0,$/;"	e	enum:_BT_8723A_2ANT_BT_STATUS
-BT_8723A_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_BT_STATUS_MAX$/;"	e	enum:_BT_8723A_2ANT_BT_STATUS
-BT_8723A_2ANT_BT_STATUS_NON_IDLE	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_BT_STATUS_NON_IDLE			= 0x2,$/;"	e	enum:_BT_8723A_2ANT_BT_STATUS
-BT_8723A_2ANT_COEX_ALGO	hal/btc/HalBtc8723a2Ant.h	/^}BT_8723A_2ANT_COEX_ALGO,*PBT_8723A_2ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_HID_A2DP			= 0x9,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x8,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_MAX$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_PANEDR			= 0x4,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x6,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_PANEDR_HID		= 0x7,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_PANHS			= 0x5,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723A_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8723a2Ant.h	/^	BT_8723A_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:_BT_8723A_2ANT_COEX_ALGO
-BT_8723B_1ANT_ANTDET_BTTXCHANNEL	hal/btc/HalBtc8723b1Ant.h	36;"	d
-BT_8723B_1ANT_ANTDET_BTTXTIME	hal/btc/HalBtc8723b1Ant.h	35;"	d
-BT_8723B_1ANT_ANTDET_BUF_LEN	hal/btc/HalBtc8723b1Ant.h	191;"	d
-BT_8723B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE	hal/btc/HalBtc8723b1Ant.h	34;"	d
-BT_8723B_1ANT_ANTDET_ENABLE	hal/btc/HalBtc8723b1Ant.h	33;"	d
-BT_8723B_1ANT_ANTDET_PSDTHRES_1ANT	hal/btc/HalBtc8723b1Ant.h	30;"	d
-BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION	hal/btc/HalBtc8723b1Ant.h	28;"	d
-BT_8723B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	hal/btc/HalBtc8723b1Ant.h	29;"	d
-BT_8723B_1ANT_ANTDET_PSDTHRES_BACKGROUND	hal/btc/HalBtc8723b1Ant.h	27;"	d
-BT_8723B_1ANT_ANTDET_PSD_AVGNUM	hal/btc/HalBtc8723b1Ant.h	190;"	d
-BT_8723B_1ANT_ANTDET_PSD_POINTS	hal/btc/HalBtc8723b1Ant.h	189;"	d
-BT_8723B_1ANT_ANTDET_RETRY_INTERVAL	hal/btc/HalBtc8723b1Ant.h	31;"	d
-BT_8723B_1ANT_ANTDET_SWEEPPOINT_DELAY	hal/btc/HalBtc8723b1Ant.h	32;"	d
-BT_8723B_1ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8723b_1ant_bt_status
-BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8723b_1ant_bt_status
-BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8723b_1ant_bt_status
-BT_8723B_1ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8723b_1ant_bt_status
-BT_8723B_1ANT_BT_STATUS_MAX	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8723b_1ant_bt_status
-BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8723b_1ant_bt_status
-BT_8723B_1ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8723b_1ant_bt_status
-BT_8723B_1ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_HID	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_MAX	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_SCO	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8723b_1ant_coex_algo
-BT_8723B_1ANT_WIFI_NOISY_THRESH	hal/btc/HalBtc8723b1Ant.h	24;"	d
-BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8723b_1ant_wifi_status
-BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8723b_1ant_wifi_status
-BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8723b_1ant_wifi_status
-BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8723b_1ant_wifi_status
-BT_8723B_1ANT_WIFI_STATUS_MAX	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8723b_1ant_wifi_status
-BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8723b_1ant_wifi_status
-BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8723b1Ant.h	/^	BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8723b_1ant_wifi_status
-BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES	hal/btc/HalBtc8723b2Ant.h	24;"	d
-BT_8723B_2ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8723b_2ant_bt_status
-BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8723b_2ant_bt_status
-BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8723b_2ant_bt_status
-BT_8723B_2ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8723b_2ant_bt_status
-BT_8723B_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_BT_STATUS_MAX$/;"	e	enum:bt_8723b_2ant_bt_status
-BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8723b_2ant_bt_status
-BT_8723B_2ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8723b_2ant_bt_status
-BT_8723B_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8723b2Ant.h	/^	BT_8723B_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8723b_2ant_coex_algo
-BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES	hal/btc/HalBtc8723b2Ant.h	23;"	d
-BT_8723D_1ANT_ANTDET_BTTXCHANNEL	hal/btc/halbtc8723d1ant.h	39;"	d
-BT_8723D_1ANT_ANTDET_BTTXTIME	hal/btc/halbtc8723d1ant.h	38;"	d
-BT_8723D_1ANT_ANTDET_BUF_LEN	hal/btc/halbtc8723d1ant.h	304;"	d
-BT_8723D_1ANT_ANTDET_ENABLE	hal/btc/halbtc8723d1ant.h	37;"	d
-BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT	hal/btc/halbtc8723d1ant.h	34;"	d
-BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION	hal/btc/halbtc8723d1ant.h	32;"	d
-BT_8723D_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	hal/btc/halbtc8723d1ant.h	33;"	d
-BT_8723D_1ANT_ANTDET_PSDTHRES_BACKGROUND	hal/btc/halbtc8723d1ant.h	31;"	d
-BT_8723D_1ANT_ANTDET_PSD_AVGNUM	hal/btc/halbtc8723d1ant.h	303;"	d
-BT_8723D_1ANT_ANTDET_PSD_POINTS	hal/btc/halbtc8723d1ant.h	302;"	d
-BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT	hal/btc/halbtc8723d1ant.h	40;"	d
-BT_8723D_1ANT_ANTDET_RETRY_INTERVAL	hal/btc/halbtc8723d1ant.h	35;"	d
-BT_8723D_1ANT_ANTDET_SWEEPPOINT_DELAY	hal/btc/halbtc8723d1ant.h	36;"	d
-BT_8723D_1ANT_BT_STATUS_ACL_BUSY	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8723d_1ant_bt_status
-BT_8723D_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8723d_1ant_bt_status
-BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8723d_1ant_bt_status
-BT_8723D_1ANT_BT_STATUS_INQ_PAGE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8723d_1ant_bt_status
-BT_8723D_1ANT_BT_STATUS_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8723d_1ant_bt_status
-BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8723d_1ant_bt_status
-BT_8723D_1ANT_BT_STATUS_SCO_BUSY	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8723d_1ant_bt_status
-BT_8723D_1ANT_COEX_ALGO_A2DP	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_HID	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_HID_A2DP	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_PANEDR	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_PANHS	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_SCO	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_ALGO_UNDEFINED	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8723d_1ant_coex_algo
-BT_8723D_1ANT_COEX_DBG	hal/btc/halbtc8723d1ant.h	9;"	d
-BT_8723D_1ANT_CTT_BT_VS_LTE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_CTT_BT_VS_LTE			= 0x1,$/;"	e	enum:bt_8723d_1ant_lte_coex_table_type
-BT_8723D_1ANT_CTT_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_CTT_MAX$/;"	e	enum:bt_8723d_1ant_lte_coex_table_type
-BT_8723D_1ANT_CTT_WL_VS_LTE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_CTT_WL_VS_LTE			= 0x0,$/;"	e	enum:bt_8723d_1ant_lte_coex_table_type
-BT_8723D_1ANT_DEFAULT_ISOLATION	hal/btc/halbtc8723d1ant.h	27;"	d
-BT_8723D_1ANT_GNT_BLOCK_BB	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_GNT_BLOCK_BB			= 0x2,$/;"	e	enum:bt_8723d_1ant_gnt_ctrl_block
-BT_8723D_1ANT_GNT_BLOCK_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_GNT_BLOCK_MAX$/;"	e	enum:bt_8723d_1ant_gnt_ctrl_block
-BT_8723D_1ANT_GNT_BLOCK_RFC	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_GNT_BLOCK_RFC			= 0x1,$/;"	e	enum:bt_8723d_1ant_gnt_ctrl_block
-BT_8723D_1ANT_GNT_BLOCK_RFC_BB	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_GNT_BLOCK_RFC_BB		= 0x0,$/;"	e	enum:bt_8723d_1ant_gnt_ctrl_block
-BT_8723D_1ANT_GNT_TYPE_CTRL_BY_PTA	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,$/;"	e	enum:bt_8723d_1ant_gnt_ctrl_type
-BT_8723D_1ANT_GNT_TYPE_CTRL_BY_SW	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,$/;"	e	enum:bt_8723d_1ant_gnt_ctrl_type
-BT_8723D_1ANT_GNT_TYPE_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_GNT_TYPE_MAX$/;"	e	enum:bt_8723d_1ant_gnt_ctrl_type
-BT_8723D_1ANT_LBTT_BT_BREAK_LTE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_LBTT_BT_BREAK_LTE				= 0x1,$/;"	e	enum:bt_8723d_1ant_lte_break_table_type
-BT_8723D_1ANT_LBTT_LTE_BREAK_BT	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_LBTT_LTE_BREAK_BT				= 0x3,$/;"	e	enum:bt_8723d_1ant_lte_break_table_type
-BT_8723D_1ANT_LBTT_LTE_BREAK_WL	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_LBTT_LTE_BREAK_WL			= 0x2,$/;"	e	enum:bt_8723d_1ant_lte_break_table_type
-BT_8723D_1ANT_LBTT_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_LBTT_MAX$/;"	e	enum:bt_8723d_1ant_lte_break_table_type
-BT_8723D_1ANT_LBTT_WL_BREAK_LTE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_LBTT_WL_BREAK_LTE			= 0x0,$/;"	e	enum:bt_8723d_1ant_lte_break_table_type
-BT_8723D_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT	hal/btc/halbtc8723d1ant.h	42;"	d
-BT_8723D_1ANT_PCO_BTSIDE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PCO_BTSIDE		= 0x0,$/;"	e	enum:bt_8723d_1ant_path_ctrl_owner
-BT_8723D_1ANT_PCO_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PCO_MAX$/;"	e	enum:bt_8723d_1ant_path_ctrl_owner
-BT_8723D_1ANT_PCO_WLSIDE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PCO_WLSIDE	= 0x1,$/;"	e	enum:bt_8723d_1ant_path_ctrl_owner
-BT_8723D_1ANT_PHASE_2G_RUNTIME	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_2G_RUNTIME								= 0x3,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_5G_RUNTIME	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_5G_RUNTIME								= 0x4,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_ANTENNA_DET	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_ANTENNA_DET								= 0x6,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_BTMPMODE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_BTMPMODE								= 0x5,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_COEX_INIT	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_COEX_INIT								= 0x0,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_COEX_POWERON	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_COEX_POWERON							= 0x7,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_MAX$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_WLANONLY_INIT	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_WLANONLY_INIT							= 0x1,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_PHASE_WLAN_OFF	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_PHASE_WLAN_OFF								= 0x2,$/;"	e	enum:bt_8723d_1ant_phase
-BT_8723D_1ANT_SCOREBOARD_ACTIVE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SCOREBOARD_ACTIVE								= BIT(0),$/;"	e	enum:bt_8723d_1ant_Scoreboard
-BT_8723D_1ANT_SCOREBOARD_ONOFF	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SCOREBOARD_ONOFF								= BIT(1),$/;"	e	enum:bt_8723d_1ant_Scoreboard
-BT_8723D_1ANT_SCOREBOARD_SCAN	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SCOREBOARD_SCAN								= BIT(2),$/;"	e	enum:bt_8723d_1ant_Scoreboard
-BT_8723D_1ANT_SCOREBOARD_UNDERTEST	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SCOREBOARD_UNDERTEST							= BIT(3),$/;"	e	enum:bt_8723d_1ant_Scoreboard
-BT_8723D_1ANT_SCOREBOARD_WLBUSY	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SCOREBOARD_WLBUSY								= BIT(6)$/;"	e	enum:bt_8723d_1ant_Scoreboard
-BT_8723D_1ANT_SIG_STA_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SIG_STA_MAX$/;"	e	enum:bt_8723d_1ant_signal_state
-BT_8723D_1ANT_SIG_STA_SET_BY_HW	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SIG_STA_SET_BY_HW		= 0x0,$/;"	e	enum:bt_8723d_1ant_signal_state
-BT_8723D_1ANT_SIG_STA_SET_TO_HIGH	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,$/;"	e	enum:bt_8723d_1ant_signal_state
-BT_8723D_1ANT_SIG_STA_SET_TO_LOW	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_SIG_STA_SET_TO_LOW		= 0x0,$/;"	e	enum:bt_8723d_1ant_signal_state
-BT_8723D_1ANT_WIFI_NOISY_THRESH	hal/btc/halbtc8723d1ant.h	26;"	d
-BT_8723D_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8723d_1ant_wifi_status
-BT_8723D_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8723d_1ant_wifi_status
-BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8723d_1ant_wifi_status
-BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8723d_1ant_wifi_status
-BT_8723D_1ANT_WIFI_STATUS_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8723d_1ant_wifi_status
-BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8723d_1ant_wifi_status
-BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/halbtc8723d1ant.h	/^	BT_8723D_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8723d_1ant_wifi_status
-BT_8723D_2ANT_ANTDET_BTTXCHANNEL	hal/btc/halbtc8723d2ant.h	47;"	d
-BT_8723D_2ANT_ANTDET_BTTXTIME	hal/btc/halbtc8723d2ant.h	46;"	d
-BT_8723D_2ANT_ANTDET_BUF_LEN	hal/btc/halbtc8723d2ant.h	318;"	d
-BT_8723D_2ANT_ANTDET_ENABLE	hal/btc/halbtc8723d2ant.h	45;"	d
-BT_8723D_2ANT_ANTDET_PSDTHRES_1ANT	hal/btc/halbtc8723d2ant.h	42;"	d
-BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION	hal/btc/halbtc8723d2ant.h	40;"	d
-BT_8723D_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	hal/btc/halbtc8723d2ant.h	41;"	d
-BT_8723D_2ANT_ANTDET_PSDTHRES_BACKGROUND	hal/btc/halbtc8723d2ant.h	39;"	d
-BT_8723D_2ANT_ANTDET_PSD_AVGNUM	hal/btc/halbtc8723d2ant.h	317;"	d
-BT_8723D_2ANT_ANTDET_PSD_POINTS	hal/btc/halbtc8723d2ant.h	316;"	d
-BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT	hal/btc/halbtc8723d2ant.h	48;"	d
-BT_8723D_2ANT_ANTDET_RETRY_INTERVAL	hal/btc/halbtc8723d2ant.h	43;"	d
-BT_8723D_2ANT_ANTDET_SWEEPPOINT_DELAY	hal/btc/halbtc8723d2ant.h	44;"	d
-BT_8723D_2ANT_BT_MAX_TX_POWER	hal/btc/halbtc8723d2ant.h	31;"	d
-BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES1	hal/btc/halbtc8723d2ant.h	26;"	d
-BT_8723D_2ANT_BT_RSSI_COEXSWITCH_THRES2	hal/btc/halbtc8723d2ant.h	28;"	d
-BT_8723D_2ANT_BT_SIR_THRES1	hal/btc/halbtc8723d2ant.h	34;"	d
-BT_8723D_2ANT_BT_SIR_THRES2	hal/btc/halbtc8723d2ant.h	35;"	d
-BT_8723D_2ANT_BT_STATUS_ACL_BUSY	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8723d_2ant_bt_status
-BT_8723D_2ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8723d_2ant_bt_status
-BT_8723D_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8723d_2ant_bt_status
-BT_8723D_2ANT_BT_STATUS_INQ_PAGE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8723d_2ant_bt_status
-BT_8723D_2ANT_BT_STATUS_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_BT_STATUS_MAX$/;"	e	enum:bt_8723d_2ant_bt_status
-BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8723d_2ant_bt_status
-BT_8723D_2ANT_BT_STATUS_SCO_BUSY	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8723d_2ant_bt_status
-BT_8723D_2ANT_COEX_ALGO_A2DP	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_A2DP_PANHS	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_HID	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_HID_A2DP	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_MAX$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_NOPROFILEBUSY	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_NOPROFILEBUSY		= 0xb,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_PANEDR	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_PANHS	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_SCO	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_ALGO_UNDEFINED	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8723d_2ant_coex_algo
-BT_8723D_2ANT_COEX_DBG	hal/btc/halbtc8723d2ant.h	9;"	d
-BT_8723D_2ANT_CTT_BT_VS_LTE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_CTT_BT_VS_LTE			= 0x1,$/;"	e	enum:bt_8723d_2ant_lte_coex_table_type
-BT_8723D_2ANT_CTT_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_CTT_MAX$/;"	e	enum:bt_8723d_2ant_lte_coex_table_type
-BT_8723D_2ANT_CTT_WL_VS_LTE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_CTT_WL_VS_LTE			= 0x0,$/;"	e	enum:bt_8723d_2ant_lte_coex_table_type
-BT_8723D_2ANT_DEFAULT_ISOLATION	hal/btc/halbtc8723d2ant.h	29;"	d
-BT_8723D_2ANT_GNT_BLOCK_BB	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_GNT_BLOCK_BB			= 0x2,$/;"	e	enum:bt_8723d_2ant_gnt_ctrl_block
-BT_8723D_2ANT_GNT_BLOCK_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_GNT_BLOCK_MAX$/;"	e	enum:bt_8723d_2ant_gnt_ctrl_block
-BT_8723D_2ANT_GNT_BLOCK_RFC	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_GNT_BLOCK_RFC			= 0x1,$/;"	e	enum:bt_8723d_2ant_gnt_ctrl_block
-BT_8723D_2ANT_GNT_BLOCK_RFC_BB	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_GNT_BLOCK_RFC_BB		= 0x0,$/;"	e	enum:bt_8723d_2ant_gnt_ctrl_block
-BT_8723D_2ANT_GNT_TYPE_CTRL_BY_PTA	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,$/;"	e	enum:bt_8723d_2ant_gnt_ctrl_type
-BT_8723D_2ANT_GNT_TYPE_CTRL_BY_SW	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,$/;"	e	enum:bt_8723d_2ant_gnt_ctrl_type
-BT_8723D_2ANT_GNT_TYPE_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_GNT_TYPE_MAX$/;"	e	enum:bt_8723d_2ant_gnt_ctrl_type
-BT_8723D_2ANT_LBTT_BT_BREAK_LTE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_LBTT_BT_BREAK_LTE				= 0x1,$/;"	e	enum:bt_8723d_2ant_lte_break_table_type
-BT_8723D_2ANT_LBTT_LTE_BREAK_BT	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_LBTT_LTE_BREAK_BT				= 0x3,$/;"	e	enum:bt_8723d_2ant_lte_break_table_type
-BT_8723D_2ANT_LBTT_LTE_BREAK_WL	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_LBTT_LTE_BREAK_WL			= 0x2,$/;"	e	enum:bt_8723d_2ant_lte_break_table_type
-BT_8723D_2ANT_LBTT_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_LBTT_MAX$/;"	e	enum:bt_8723d_2ant_lte_break_table_type
-BT_8723D_2ANT_LBTT_WL_BREAK_LTE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_LBTT_WL_BREAK_LTE			= 0x0,$/;"	e	enum:bt_8723d_2ant_lte_break_table_type
-BT_8723D_2ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT	hal/btc/halbtc8723d2ant.h	51;"	d
-BT_8723D_2ANT_PCO_BTSIDE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PCO_BTSIDE		= 0x0,$/;"	e	enum:bt_8723d_2ant_path_ctrl_owner
-BT_8723D_2ANT_PCO_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PCO_MAX$/;"	e	enum:bt_8723d_2ant_path_ctrl_owner
-BT_8723D_2ANT_PCO_WLSIDE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PCO_WLSIDE	= 0x1,$/;"	e	enum:bt_8723d_2ant_path_ctrl_owner
-BT_8723D_2ANT_PHASE_2G_RUNTIME	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_2G_RUNTIME								= 0x3,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_5G_RUNTIME	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_5G_RUNTIME								= 0x4,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_ANTENNA_DET	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_ANTENNA_DET								= 0x6,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_BTMPMODE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_BTMPMODE								= 0x5,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_COEX_INIT	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_COEX_INIT								= 0x0,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_COEX_POWERON	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_COEX_POWERON							= 0x7,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_MAX$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_WLANONLY_INIT	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_WLANONLY_INIT							= 0x1,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_PHASE_WLAN_OFF	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_PHASE_WLAN_OFF								= 0x2,$/;"	e	enum:bt_8723d_2ant_phase
-BT_8723D_2ANT_SCOREBOARD_ACTIVE	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SCOREBOARD_ACTIVE								= BIT(0),$/;"	e	enum:bt_8723d_2ant_Scoreboard
-BT_8723D_2ANT_SCOREBOARD_ONOFF	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SCOREBOARD_ONOFF								= BIT(1),$/;"	e	enum:bt_8723d_2ant_Scoreboard
-BT_8723D_2ANT_SCOREBOARD_SCAN	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SCOREBOARD_SCAN								= BIT(2),$/;"	e	enum:bt_8723d_2ant_Scoreboard
-BT_8723D_2ANT_SCOREBOARD_UNDERTEST	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SCOREBOARD_UNDERTEST							= BIT(3),$/;"	e	enum:bt_8723d_2ant_Scoreboard
-BT_8723D_2ANT_SCOREBOARD_WLBUSY	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SCOREBOARD_WLBUSY								= BIT(6)$/;"	e	enum:bt_8723d_2ant_Scoreboard
-BT_8723D_2ANT_SIG_STA_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SIG_STA_MAX$/;"	e	enum:bt_8723d_2ant_signal_state
-BT_8723D_2ANT_SIG_STA_SET_BY_HW	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SIG_STA_SET_BY_HW		= 0x0,$/;"	e	enum:bt_8723d_2ant_signal_state
-BT_8723D_2ANT_SIG_STA_SET_TO_HIGH	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SIG_STA_SET_TO_HIGH		= 0x1,$/;"	e	enum:bt_8723d_2ant_signal_state
-BT_8723D_2ANT_SIG_STA_SET_TO_LOW	hal/btc/halbtc8723d2ant.h	/^	BT_8723D_2ANT_SIG_STA_SET_TO_LOW		= 0x0,$/;"	e	enum:bt_8723d_2ant_signal_state
-BT_8723D_2ANT_WIFI_MAX_TX_POWER	hal/btc/halbtc8723d2ant.h	30;"	d
-BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES1	hal/btc/halbtc8723d2ant.h	25;"	d
-BT_8723D_2ANT_WIFI_RSSI_COEXSWITCH_THRES2	hal/btc/halbtc8723d2ant.h	27;"	d
-BT_8723D_2ANT_WIFI_SIR_THRES1	hal/btc/halbtc8723d2ant.h	32;"	d
-BT_8723D_2ANT_WIFI_SIR_THRES2	hal/btc/halbtc8723d2ant.h	33;"	d
-BT_8812A_1ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8812a_1ant_bt_status
-BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8812a_1ant_bt_status
-BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8812a_1ant_bt_status
-BT_8812A_1ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8812a_1ant_bt_status
-BT_8812A_1ANT_BT_STATUS_MAX	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8812a_1ant_bt_status
-BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8812a_1ant_bt_status
-BT_8812A_1ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8812a_1ant_bt_status
-BT_8812A_1ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_HID	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_MAX	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_SCO	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8812a_1ant_coex_algo
-BT_8812A_1ANT_WIFI_NOISY_THRESH	hal/btc/HalBtc8812a1Ant.h	25;"	d
-BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8812a_1ant_wifi_status
-BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8812a_1ant_wifi_status
-BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8812a_1ant_wifi_status
-BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8812a_1ant_wifi_status
-BT_8812A_1ANT_WIFI_STATUS_MAX	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8812a_1ant_wifi_status
-BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8812a_1ant_wifi_status
-BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8812a1Ant.h	/^	BT_8812A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8812a_1ant_wifi_status
-BT_8812A_2ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8812a_2ant_bt_status
-BT_8812A_2ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8812a_2ant_bt_status
-BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8812a_2ant_bt_status
-BT_8812A_2ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8812a_2ant_bt_status
-BT_8812A_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_BT_STATUS_MAX$/;"	e	enum:bt_8812a_2ant_bt_status
-BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8812a_2ant_bt_status
-BT_8812A_2ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8812a_2ant_bt_status
-BT_8812A_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_A2DP			= 0x4,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_A2DP_PANHS		= 0x5,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_HID				= 0x3,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_HID_A2DP		= 0xc,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0xa,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_HID_A2DP_PANHS	= 0xb,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_MAX				= 0xd$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_PANEDR			= 0x6,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x8,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_PANEDR_HID		= 0x9,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_PANHS			= 0x7,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_SCO_HID	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_SCO_HID		= 0x2,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8812A_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8812a2Ant.h	/^	BT_8812A_2ANT_COEX_ALGO_UNDEFINED		= 0x0,$/;"	e	enum:bt_8812a_2ant_coex_algo
-BT_8821A_1ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8821a_1ant_bt_status
-BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8821a_1ant_bt_status
-BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8821a_1ant_bt_status
-BT_8821A_1ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8821a_1ant_bt_status
-BT_8821A_1ANT_BT_STATUS_MAX	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8821a_1ant_bt_status
-BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8821a_1ant_bt_status
-BT_8821A_1ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8821a_1ant_bt_status
-BT_8821A_1ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_HID	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_MAX	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_SCO	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8821a_1ant_coex_algo
-BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8821a_1ant_wifi_status
-BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8821a_1ant_wifi_status
-BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8821a_1ant_wifi_status
-BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8821a_1ant_wifi_status
-BT_8821A_1ANT_WIFI_STATUS_MAX	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8821a_1ant_wifi_status
-BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8821a_1ant_wifi_status
-BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8821a1Ant.h	/^	BT_8821A_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8821a_1ant_wifi_status
-BT_8821A_2ANT_BT_RSSI_COEXSWITCH_THRES	hal/btc/HalBtc8821a2Ant.h	25;"	d
-BT_8821A_2ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8821a_2ant_bt_status
-BT_8821A_2ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8821a_2ant_bt_status
-BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8821a_2ant_bt_status
-BT_8821A_2ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8821a_2ant_bt_status
-BT_8821A_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_BT_STATUS_MAX$/;"	e	enum:bt_8821a_2ant_bt_status
-BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8821a_2ant_bt_status
-BT_8821A_2ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8821a_2ant_bt_status
-BT_8821A_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8821a2Ant.h	/^	BT_8821A_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8821a_2ant_coex_algo
-BT_8821A_2ANT_WIFI_RSSI_COEXSWITCH_THRES	hal/btc/HalBtc8821a2Ant.h	24;"	d
-BT_8821A_CSR_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_BT_STATUS_CONNECTED_IDLE	= 0x1,$/;"	e	enum:bt_8821a_csr_2ant_bt_status
-BT_8821A_CSR_2ANT_BT_STATUS_IDLE	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_BT_STATUS_IDLE				= 0x0,$/;"	e	enum:bt_8821a_csr_2ant_bt_status
-BT_8821A_CSR_2ANT_BT_STATUS_MAX	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_BT_STATUS_MAX$/;"	e	enum:bt_8821a_csr_2ant_bt_status
-BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_BT_STATUS_NON_IDLE			= 0x2,$/;"	e	enum:bt_8821a_csr_2ant_bt_status
-BT_8821A_CSR_2ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_HID	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_MAX	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_SCO	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821A_CSR_2ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_8821A_CSR_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8821a_csr_2ant_coex_algo
-BT_8821C_1ANT_ANTDET_BTTXCHANNEL	hal/btc/halbtc8821c1ant.h	37;"	d
-BT_8821C_1ANT_ANTDET_BTTXTIME	hal/btc/halbtc8821c1ant.h	36;"	d
-BT_8821C_1ANT_ANTDET_BUF_LEN	hal/btc/halbtc8821c1ant.h	327;"	d
-BT_8821C_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE	hal/btc/halbtc8821c1ant.h	35;"	d
-BT_8821C_1ANT_ANTDET_ENABLE	hal/btc/halbtc8821c1ant.h	34;"	d
-BT_8821C_1ANT_ANTDET_PSDTHRES_1ANT	hal/btc/halbtc8821c1ant.h	31;"	d
-BT_8821C_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION	hal/btc/halbtc8821c1ant.h	29;"	d
-BT_8821C_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	hal/btc/halbtc8821c1ant.h	30;"	d
-BT_8821C_1ANT_ANTDET_PSDTHRES_BACKGROUND	hal/btc/halbtc8821c1ant.h	28;"	d
-BT_8821C_1ANT_ANTDET_PSD_AVGNUM	hal/btc/halbtc8821c1ant.h	326;"	d
-BT_8821C_1ANT_ANTDET_PSD_POINTS	hal/btc/halbtc8821c1ant.h	325;"	d
-BT_8821C_1ANT_ANTDET_RETRY_INTERVAL	hal/btc/halbtc8821c1ant.h	32;"	d
-BT_8821C_1ANT_ANTDET_SWEEPPOINT_DELAY	hal/btc/halbtc8821c1ant.h	33;"	d
-BT_8821C_1ANT_BT_STATUS_ACL_BUSY	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8821c_1ant_bt_status
-BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8821c_1ant_bt_status
-BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8821c_1ant_bt_status
-BT_8821C_1ANT_BT_STATUS_INQ_PAGE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8821c_1ant_bt_status
-BT_8821C_1ANT_BT_STATUS_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8821c_1ant_bt_status
-BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8821c_1ant_bt_status
-BT_8821C_1ANT_BT_STATUS_SCO_BUSY	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8821c_1ant_bt_status
-BT_8821C_1ANT_COEX_ALGO_A2DP	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_HID	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_HID_A2DP	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_PANEDR	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_PANHS	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_SCO	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_COEX_ALGO_UNDEFINED	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8821c_1ant_coex_algo
-BT_8821C_1ANT_CTT_BT_VS_LTE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_CTT_BT_VS_LTE			= 0x1,$/;"	e	enum:bt_8821c_1ant_lte_coex_table_type
-BT_8821C_1ANT_CTT_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_CTT_MAX$/;"	e	enum:bt_8821c_1ant_lte_coex_table_type
-BT_8821C_1ANT_CTT_WL_VS_LTE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_CTT_WL_VS_LTE			= 0x0,$/;"	e	enum:bt_8821c_1ant_lte_coex_table_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_ctrl_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	= 0x0,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_ctrl_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_ctrl_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC		= 0x3,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_ctrl_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA		= 0x1,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_ctrl_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_CTRL_MAX$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_ctrl_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_MAX$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_TO_BT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_BT			= 0x0,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_pos_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_TO_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_MAX$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_pos_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_TO_NOCARE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_NOCARE		= 0x3,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_pos_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLA	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLA			= 0x2,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_pos_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLG	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_TO_WLG			= 0x1,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_pos_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_USE_DPDT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_USE_DPDT		= 0x0,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_type
-BT_8821C_1ANT_EXT_ANT_SWITCH_USE_SPDT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_ANT_SWITCH_USE_SPDT		= 0x1,$/;"	e	enum:bt_8821c_1ant_ext_ant_switch_type
-BT_8821C_1ANT_EXT_BAND_SWITCH_TO_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_BAND_SWITCH_TO_MAX$/;"	e	enum:bt_8821c_1ant_ext_band_switch_pos_type
-BT_8821C_1ANT_EXT_BAND_SWITCH_TO_WLA	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_BAND_SWITCH_TO_WLA			= 0x1,$/;"	e	enum:bt_8821c_1ant_ext_band_switch_pos_type
-BT_8821C_1ANT_EXT_BAND_SWITCH_TO_WLG	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_EXT_BAND_SWITCH_TO_WLG			= 0x0,$/;"	e	enum:bt_8821c_1ant_ext_band_switch_pos_type
-BT_8821C_1ANT_EXT_BAND_SWITCH_USE_DPDT	hal/btc/halbtc8821c1ant.h	305;"	d
-BT_8821C_1ANT_EXT_BAND_SWITCH_USE_SPDT	hal/btc/halbtc8821c1ant.h	306;"	d
-BT_8821C_1ANT_GNT_BLOCK_BB	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_GNT_BLOCK_BB			= 0x2,$/;"	e	enum:bt_8821c_1ant_gnt_ctrl_block
-BT_8821C_1ANT_GNT_BLOCK_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_GNT_BLOCK_MAX$/;"	e	enum:bt_8821c_1ant_gnt_ctrl_block
-BT_8821C_1ANT_GNT_BLOCK_RFC	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_GNT_BLOCK_RFC			= 0x1,$/;"	e	enum:bt_8821c_1ant_gnt_ctrl_block
-BT_8821C_1ANT_GNT_BLOCK_RFC_BB	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_GNT_BLOCK_RFC_BB		= 0x0,$/;"	e	enum:bt_8821c_1ant_gnt_ctrl_block
-BT_8821C_1ANT_GNT_TYPE_CTRL_BY_PTA	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,$/;"	e	enum:bt_8821c_1ant_gnt_ctrl_type
-BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,$/;"	e	enum:bt_8821c_1ant_gnt_ctrl_type
-BT_8821C_1ANT_GNT_TYPE_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_GNT_TYPE_MAX$/;"	e	enum:bt_8821c_1ant_gnt_ctrl_type
-BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_MAX$/;"	e	enum:bt_8821c_1ant_int_block
-BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG		= 0x2,$/;"	e	enum:bt_8821c_1ant_int_block
-BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG			= 0x0,$/;"	e	enum:bt_8821c_1ant_int_block
-BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG		= 0x1,$/;"	e	enum:bt_8821c_1ant_int_block
-BT_8821C_1ANT_LBTT_BT_BREAK_LTE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_LBTT_BT_BREAK_LTE				= 0x1,$/;"	e	enum:bt_8821c_1ant_lte_break_table_type
-BT_8821C_1ANT_LBTT_LTE_BREAK_BT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_LBTT_LTE_BREAK_BT				= 0x3,$/;"	e	enum:bt_8821c_1ant_lte_break_table_type
-BT_8821C_1ANT_LBTT_LTE_BREAK_WL	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_LBTT_LTE_BREAK_WL			= 0x2,$/;"	e	enum:bt_8821c_1ant_lte_break_table_type
-BT_8821C_1ANT_LBTT_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_LBTT_MAX$/;"	e	enum:bt_8821c_1ant_lte_break_table_type
-BT_8821C_1ANT_LBTT_WL_BREAK_LTE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_LBTT_WL_BREAK_LTE			= 0x0,$/;"	e	enum:bt_8821c_1ant_lte_break_table_type
-BT_8821C_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT	hal/btc/halbtc8821c1ant.h	39;"	d
-BT_8821C_1ANT_PCO_BTSIDE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PCO_BTSIDE		= 0x0,$/;"	e	enum:bt_8821c_1ant_path_ctrl_owner
-BT_8821C_1ANT_PCO_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PCO_MAX$/;"	e	enum:bt_8821c_1ant_path_ctrl_owner
-BT_8821C_1ANT_PCO_WLSIDE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PCO_WLSIDE	= 0x1,$/;"	e	enum:bt_8821c_1ant_path_ctrl_owner
-BT_8821C_1ANT_PHASE_2G_RUNTIME	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PHASE_2G_RUNTIME								= 0x3,$/;"	e	enum:bt_8821c_1ant_phase
-BT_8821C_1ANT_PHASE_5G_RUNTIME	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PHASE_5G_RUNTIME								= 0x4,$/;"	e	enum:bt_8821c_1ant_phase
-BT_8821C_1ANT_PHASE_BTMPMODE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PHASE_BTMPMODE									= 0x5,$/;"	e	enum:bt_8821c_1ant_phase
-BT_8821C_1ANT_PHASE_COEX_INIT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PHASE_COEX_INIT								= 0x0,$/;"	e	enum:bt_8821c_1ant_phase
-BT_8821C_1ANT_PHASE_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PHASE_MAX$/;"	e	enum:bt_8821c_1ant_phase
-BT_8821C_1ANT_PHASE_WLANONLY_INIT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PHASE_WLANONLY_INIT							= 0x1,	$/;"	e	enum:bt_8821c_1ant_phase
-BT_8821C_1ANT_PHASE_WLAN_OFF	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_PHASE_WLAN_OFF								= 0x2,$/;"	e	enum:bt_8821c_1ant_phase
-BT_8821C_1ANT_SIG_STA_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_SIG_STA_MAX$/;"	e	enum:bt_8821c_1ant_signal_state
-BT_8821C_1ANT_SIG_STA_SET_BY_HW	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_SIG_STA_SET_BY_HW		= 0x0,$/;"	e	enum:bt_8821c_1ant_signal_state
-BT_8821C_1ANT_SIG_STA_SET_TO_HIGH	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,$/;"	e	enum:bt_8821c_1ant_signal_state
-BT_8821C_1ANT_SIG_STA_SET_TO_LOW	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_SIG_STA_SET_TO_LOW		= 0x0,$/;"	e	enum:bt_8821c_1ant_signal_state
-BT_8821C_1ANT_WIFI_NOISY_THRESH	hal/btc/halbtc8821c1ant.h	25;"	d
-BT_8821C_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8821c_1ant_wifi_status
-BT_8821C_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8821c_1ant_wifi_status
-BT_8821C_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8821c_1ant_wifi_status
-BT_8821C_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8821c_1ant_wifi_status
-BT_8821C_1ANT_WIFI_STATUS_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8821c_1ant_wifi_status
-BT_8821C_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8821c_1ant_wifi_status
-BT_8821C_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/halbtc8821c1ant.h	/^	BT_8821C_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8821c_1ant_wifi_status
-BT_8821C_2ANT_ANTDET_BTTXCHANNEL	hal/btc/halbtc8821c2ant.h	47;"	d
-BT_8821C_2ANT_ANTDET_BTTXTIME	hal/btc/halbtc8821c2ant.h	46;"	d
-BT_8821C_2ANT_ANTDET_BUF_LEN	hal/btc/halbtc8821c2ant.h	335;"	d
-BT_8821C_2ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE	hal/btc/halbtc8821c2ant.h	45;"	d
-BT_8821C_2ANT_ANTDET_ENABLE	hal/btc/halbtc8821c2ant.h	44;"	d
-BT_8821C_2ANT_ANTDET_PSDTHRES_1ANT	hal/btc/halbtc8821c2ant.h	41;"	d
-BT_8821C_2ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION	hal/btc/halbtc8821c2ant.h	39;"	d
-BT_8821C_2ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	hal/btc/halbtc8821c2ant.h	40;"	d
-BT_8821C_2ANT_ANTDET_PSDTHRES_BACKGROUND	hal/btc/halbtc8821c2ant.h	38;"	d
-BT_8821C_2ANT_ANTDET_PSD_AVGNUM	hal/btc/halbtc8821c2ant.h	334;"	d
-BT_8821C_2ANT_ANTDET_PSD_POINTS	hal/btc/halbtc8821c2ant.h	333;"	d
-BT_8821C_2ANT_ANTDET_RETRY_INTERVAL	hal/btc/halbtc8821c2ant.h	42;"	d
-BT_8821C_2ANT_ANTDET_SWEEPPOINT_DELAY	hal/btc/halbtc8821c2ant.h	43;"	d
-BT_8821C_2ANT_BT_MAX_TX_POWER	hal/btc/halbtc8821c2ant.h	30;"	d
-BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES1	hal/btc/halbtc8821c2ant.h	25;"	d
-BT_8821C_2ANT_BT_RSSI_COEXSWITCH_THRES2	hal/btc/halbtc8821c2ant.h	27;"	d
-BT_8821C_2ANT_BT_SIR_THRES1	hal/btc/halbtc8821c2ant.h	33;"	d
-BT_8821C_2ANT_BT_SIR_THRES2	hal/btc/halbtc8821c2ant.h	34;"	d
-BT_8821C_2ANT_BT_STATUS_ACL_BUSY	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8821c_2ant_bt_status
-BT_8821C_2ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8821c_2ant_bt_status
-BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8821c_2ant_bt_status
-BT_8821C_2ANT_BT_STATUS_INQ_PAGE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8821c_2ant_bt_status
-BT_8821C_2ANT_BT_STATUS_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_BT_STATUS_MAX$/;"	e	enum:bt_8821c_2ant_bt_status
-BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8821c_2ant_bt_status
-BT_8821C_2ANT_BT_STATUS_SCO_BUSY	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8821c_2ant_bt_status
-BT_8821C_2ANT_COEX_ALGO_A2DP	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_A2DP_PANHS	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_HID	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_HID_A2DP	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_MAX$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_NOPROFILEBUSY	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_NOPROFILEBUSY		= 0xb,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_PANEDR	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_PANEDR_HID	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_PANHS	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_SCO	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_COEX_ALGO_UNDEFINED	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8821c_2ant_coex_algo
-BT_8821C_2ANT_CTT_BT_VS_LTE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_CTT_BT_VS_LTE			= 0x1,$/;"	e	enum:bt_8821c_2ant_lte_coex_table_type
-BT_8821C_2ANT_CTT_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_CTT_MAX$/;"	e	enum:bt_8821c_2ant_lte_coex_table_type
-BT_8821C_2ANT_CTT_WL_VS_LTE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_CTT_WL_VS_LTE			= 0x0,$/;"	e	enum:bt_8821c_2ant_lte_coex_table_type
-BT_8821C_2ANT_DEFAULT_ISOLATION	hal/btc/halbtc8821c2ant.h	28;"	d
-BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_ctrl_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	= 0x0,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_ctrl_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_ctrl_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_MAC	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_MAC		= 0x3,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_ctrl_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_PTA	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_BY_PTA		= 0x1,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_ctrl_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_CTRL_MAX$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_ctrl_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_BT	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_BT			= 0x0,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_pos_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_MAX$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_pos_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_NOCARE		= 0x3,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_pos_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLA	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLA			= 0x2,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_pos_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLG	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_ANT_SWITCH_MAIN_TO_WLG			= 0x1,$/;"	e	enum:bt_8821c_2ant_ext_ant_switch_pos_type
-BT_8821C_2ANT_EXT_ANT_SWITCH_USE_DPDT	hal/btc/halbtc8821c2ant.h	310;"	d
-BT_8821C_2ANT_EXT_ANT_SWITCH_USE_SPDT	hal/btc/halbtc8821c2ant.h	311;"	d
-BT_8821C_2ANT_EXT_BAND_SWITCH_TO_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_BAND_SWITCH_TO_MAX$/;"	e	enum:bt_8821c_2ant_ext_band_switch_pos_type
-BT_8821C_2ANT_EXT_BAND_SWITCH_TO_WLA	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_BAND_SWITCH_TO_WLA			= 0x1,$/;"	e	enum:bt_8821c_2ant_ext_band_switch_pos_type
-BT_8821C_2ANT_EXT_BAND_SWITCH_TO_WLG	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_EXT_BAND_SWITCH_TO_WLG			= 0x0,$/;"	e	enum:bt_8821c_2ant_ext_band_switch_pos_type
-BT_8821C_2ANT_EXT_BAND_SWITCH_USE_DPDT	hal/btc/halbtc8821c2ant.h	313;"	d
-BT_8821C_2ANT_EXT_BAND_SWITCH_USE_SPDT	hal/btc/halbtc8821c2ant.h	314;"	d
-BT_8821C_2ANT_GNT_BLOCK_BB	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_GNT_BLOCK_BB			= 0x2,$/;"	e	enum:bt_8821c_2ant_gnt_ctrl_block
-BT_8821C_2ANT_GNT_BLOCK_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_GNT_BLOCK_MAX$/;"	e	enum:bt_8821c_2ant_gnt_ctrl_block
-BT_8821C_2ANT_GNT_BLOCK_RFC	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_GNT_BLOCK_RFC			= 0x1,$/;"	e	enum:bt_8821c_2ant_gnt_ctrl_block
-BT_8821C_2ANT_GNT_BLOCK_RFC_BB	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_GNT_BLOCK_RFC_BB		= 0x0,$/;"	e	enum:bt_8821c_2ant_gnt_ctrl_block
-BT_8821C_2ANT_GNT_TYPE_CTRL_BY_PTA	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_GNT_TYPE_CTRL_BY_PTA		= 0x0,$/;"	e	enum:bt_8821c_2ant_gnt_ctrl_type
-BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_GNT_TYPE_CTRL_BY_SW		= 0x1,$/;"	e	enum:bt_8821c_2ant_gnt_ctrl_type
-BT_8821C_2ANT_GNT_TYPE_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_GNT_TYPE_MAX$/;"	e	enum:bt_8821c_2ant_gnt_ctrl_type
-BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_MAX$/;"	e	enum:bt_8821c_2ant_int_block
-BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLA_OF_WLAG		= 0x2,$/;"	e	enum:bt_8821c_2ant_int_block
-BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_BTG			= 0x0,$/;"	e	enum:bt_8821c_2ant_int_block
-BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_INT_BLOCK_SWITCH_TO_WLG_OF_WLAG		= 0x1,$/;"	e	enum:bt_8821c_2ant_int_block
-BT_8821C_2ANT_LBTT_BT_BREAK_LTE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_LBTT_BT_BREAK_LTE				= 0x1,$/;"	e	enum:bt_8821c_2ant_lte_break_table_type
-BT_8821C_2ANT_LBTT_LTE_BREAK_BT	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_LBTT_LTE_BREAK_BT				= 0x3,$/;"	e	enum:bt_8821c_2ant_lte_break_table_type
-BT_8821C_2ANT_LBTT_LTE_BREAK_WL	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_LBTT_LTE_BREAK_WL			= 0x2,$/;"	e	enum:bt_8821c_2ant_lte_break_table_type
-BT_8821C_2ANT_LBTT_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_LBTT_MAX$/;"	e	enum:bt_8821c_2ant_lte_break_table_type
-BT_8821C_2ANT_LBTT_WL_BREAK_LTE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_LBTT_WL_BREAK_LTE			= 0x0,$/;"	e	enum:bt_8821c_2ant_lte_break_table_type
-BT_8821C_2ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT	hal/btc/halbtc8821c2ant.h	49;"	d
-BT_8821C_2ANT_PCO_BTSIDE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PCO_BTSIDE		= 0x0,$/;"	e	enum:bt_8821c_2ant_path_ctrl_owner
-BT_8821C_2ANT_PCO_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PCO_MAX$/;"	e	enum:bt_8821c_2ant_path_ctrl_owner
-BT_8821C_2ANT_PCO_WLSIDE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PCO_WLSIDE	= 0x1,$/;"	e	enum:bt_8821c_2ant_path_ctrl_owner
-BT_8821C_2ANT_PHASE_2G_RUNTIME	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PHASE_2G_RUNTIME								= 0x3,$/;"	e	enum:bt_8821c_2ant_phase
-BT_8821C_2ANT_PHASE_5G_RUNTIME	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PHASE_5G_RUNTIME								= 0x4,$/;"	e	enum:bt_8821c_2ant_phase
-BT_8821C_2ANT_PHASE_BTMPMODE	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PHASE_BTMPMODE									= 0x5,$/;"	e	enum:bt_8821c_2ant_phase
-BT_8821C_2ANT_PHASE_COEX_INIT	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PHASE_COEX_INIT								= 0x0,$/;"	e	enum:bt_8821c_2ant_phase
-BT_8821C_2ANT_PHASE_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PHASE_MAX$/;"	e	enum:bt_8821c_2ant_phase
-BT_8821C_2ANT_PHASE_WLANONLY_INIT	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PHASE_WLANONLY_INIT							= 0x1,	$/;"	e	enum:bt_8821c_2ant_phase
-BT_8821C_2ANT_PHASE_WLAN_OFF	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_PHASE_WLAN_OFF								= 0x2,$/;"	e	enum:bt_8821c_2ant_phase
-BT_8821C_2ANT_SIG_STA_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_SIG_STA_MAX$/;"	e	enum:bt_8821c_2ant_signal_state
-BT_8821C_2ANT_SIG_STA_SET_BY_HW	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_SIG_STA_SET_BY_HW		= 0x0,$/;"	e	enum:bt_8821c_2ant_signal_state
-BT_8821C_2ANT_SIG_STA_SET_TO_HIGH	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_SIG_STA_SET_TO_HIGH		= 0x1,$/;"	e	enum:bt_8821c_2ant_signal_state
-BT_8821C_2ANT_SIG_STA_SET_TO_LOW	hal/btc/halbtc8821c2ant.h	/^	BT_8821C_2ANT_SIG_STA_SET_TO_LOW		= 0x0,$/;"	e	enum:bt_8821c_2ant_signal_state
-BT_8821C_2ANT_WIFI_MAX_TX_POWER	hal/btc/halbtc8821c2ant.h	29;"	d
-BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES1	hal/btc/halbtc8821c2ant.h	24;"	d
-BT_8821C_2ANT_WIFI_RSSI_COEXSWITCH_THRES2	hal/btc/halbtc8821c2ant.h	26;"	d
-BT_8821C_2ANT_WIFI_SIR_THRES1	hal/btc/halbtc8821c2ant.h	31;"	d
-BT_8821C_2ANT_WIFI_SIR_THRES2	hal/btc/halbtc8821c2ant.h	32;"	d
-BT_8822B_1ANT_ANTDET_BUF_LEN	hal/btc/HalBtc8822b1Ant.h	296;"	d
-BT_8822B_1ANT_ANTDET_COEXMECHANISMSWITCH_ENABLE	hal/btc/HalBtc8822b1Ant.h	34;"	d
-BT_8822B_1ANT_ANTDET_ENABLE	hal/btc/HalBtc8822b1Ant.h	33;"	d
-BT_8822B_1ANT_ANTDET_PSDTHRES_1ANT	hal/btc/HalBtc8822b1Ant.h	31;"	d
-BT_8822B_1ANT_ANTDET_PSDTHRES_2ANT_BADISOLATION	hal/btc/HalBtc8822b1Ant.h	29;"	d
-BT_8822B_1ANT_ANTDET_PSDTHRES_2ANT_GOODISOLATION	hal/btc/HalBtc8822b1Ant.h	30;"	d
-BT_8822B_1ANT_ANTDET_PSDTHRES_BACKGROUND	hal/btc/HalBtc8822b1Ant.h	28;"	d
-BT_8822B_1ANT_ANTDET_PSD_AVGNUM	hal/btc/HalBtc8822b1Ant.h	295;"	d
-BT_8822B_1ANT_ANTDET_PSD_POINTS	hal/btc/HalBtc8822b1Ant.h	294;"	d
-BT_8822B_1ANT_ANTDET_RETRY_INTERVAL	hal/btc/HalBtc8822b1Ant.h	32;"	d
-BT_8822B_1ANT_BT_STATUS_ACL_BUSY	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_BT_STATUS_ACL_BUSY				= 0x3,$/;"	e	enum:bt_8822b_1ant_bt_status
-BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_BT_STATUS_ACL_SCO_BUSY			= 0x5,$/;"	e	enum:bt_8822b_1ant_bt_status
-BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_BT_STATUS_CONNECTED_IDLE		= 0x1,$/;"	e	enum:bt_8822b_1ant_bt_status
-BT_8822B_1ANT_BT_STATUS_INQ_PAGE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_BT_STATUS_INQ_PAGE				= 0x2,$/;"	e	enum:bt_8822b_1ant_bt_status
-BT_8822B_1ANT_BT_STATUS_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_BT_STATUS_MAX$/;"	e	enum:bt_8822b_1ant_bt_status
-BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_BT_STATUS_NON_CONNECTED_IDLE	= 0x0,$/;"	e	enum:bt_8822b_1ant_bt_status
-BT_8822B_1ANT_BT_STATUS_SCO_BUSY	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_BT_STATUS_SCO_BUSY				= 0x4,$/;"	e	enum:bt_8822b_1ant_bt_status
-BT_8822B_1ANT_COEX_ALGO_A2DP	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_A2DP				= 0x3,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_A2DP_PANHS	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_A2DP_PANHS		= 0x4,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_HID	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_HID				= 0x2,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_HID_A2DP	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_HID_A2DP			= 0xa,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_HID_A2DP_PANEDR	= 0x9,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_MAX				= 0xb,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_PANEDR	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_PANEDR			= 0x5,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_PANEDR_A2DP	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_PANEDR_A2DP		= 0x7,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_PANEDR_HID	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_PANEDR_HID		= 0x8,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_PANHS	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_PANHS			= 0x6,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_SCO	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_SCO				= 0x1,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_COEX_ALGO_UNDEFINED	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_COEX_ALGO_UNDEFINED			= 0x0,$/;"	e	enum:bt_8822b_1ant_coex_algo
-BT_8822B_1ANT_CTT_BT_VS_LTE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_CTT_BT_VS_LTE			= 0x1,$/;"	e	enum:bt_8822b_1ant_lte_coex_table_type
-BT_8822B_1ANT_CTT_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_CTT_MAX$/;"	e	enum:bt_8822b_1ant_lte_coex_table_type
-BT_8822B_1ANT_CTT_WL_VS_LTE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_CTT_WL_VS_LTE			= 0x0,$/;"	e	enum:bt_8822b_1ant_lte_coex_table_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_ANTDIV	= 0x2,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_ctrl_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BBSW	= 0x0,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_ctrl_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_BT		= 0x4,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_ctrl_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_MAC	= 0x3,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_ctrl_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_BY_PTA	= 0x1,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_ctrl_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_CTRL_MAX$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_ctrl_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_MAX$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_TO_BT	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_BT			= 0x0,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_pos_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_TO_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_MAX$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_pos_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_TO_NOCARE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_NOCARE		= 0x3,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_pos_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLA	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLA			= 0x2,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_pos_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLG	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_TO_WLG			= 0x1,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_pos_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SP3T	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SP3T		= 0x1,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_type
-BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_EXT_ANT_SWITCH_USE_SPDT		= 0x0,$/;"	e	enum:bt_8822b_1ant_ext_ant_switch_type
-BT_8822B_1ANT_GNT_BLOCK_BB	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_GNT_BLOCK_BB			= 0x2,$/;"	e	enum:bt_8822b_1ant_gnt_ctrl_block
-BT_8822B_1ANT_GNT_BLOCK_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_GNT_BLOCK_MAX$/;"	e	enum:bt_8822b_1ant_gnt_ctrl_block
-BT_8822B_1ANT_GNT_BLOCK_RFC	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_GNT_BLOCK_RFC			= 0x1,$/;"	e	enum:bt_8822b_1ant_gnt_ctrl_block
-BT_8822B_1ANT_GNT_BLOCK_RFC_BB	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_GNT_BLOCK_RFC_BB		= 0x0,$/;"	e	enum:bt_8822b_1ant_gnt_ctrl_block
-BT_8822B_1ANT_GNT_CTRL_BY_PTA	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_GNT_CTRL_BY_PTA		= 0x0,$/;"	e	enum:bt_8822b_1ant_gnt_ctrl_type
-BT_8822B_1ANT_GNT_CTRL_BY_SW	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_GNT_CTRL_BY_SW		= 0x1,$/;"	e	enum:bt_8822b_1ant_gnt_ctrl_type
-BT_8822B_1ANT_GNT_CTRL_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_GNT_CTRL_MAX$/;"	e	enum:bt_8822b_1ant_gnt_ctrl_type
-BT_8822B_1ANT_LBTT_BT_BREAK_LTE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_LBTT_BT_BREAK_LTE				= 0x1,$/;"	e	enum:bt_8822b_1ant_lte_break_table_type
-BT_8822B_1ANT_LBTT_LTE_BREAK_BT	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_LBTT_LTE_BREAK_BT				= 0x3,$/;"	e	enum:bt_8822b_1ant_lte_break_table_type
-BT_8822B_1ANT_LBTT_LTE_BREAK_WL	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_LBTT_LTE_BREAK_WL			= 0x2,$/;"	e	enum:bt_8822b_1ant_lte_break_table_type
-BT_8822B_1ANT_LBTT_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_LBTT_MAX$/;"	e	enum:bt_8822b_1ant_lte_break_table_type
-BT_8822B_1ANT_LBTT_WL_BREAK_LTE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_LBTT_WL_BREAK_LTE			= 0x0,$/;"	e	enum:bt_8822b_1ant_lte_break_table_type
-BT_8822B_1ANT_LTECOEX_INDIRECTREG_ACCESS_TIMEOUT	hal/btc/HalBtc8822b1Ant.h	36;"	d
-BT_8822B_1ANT_PCO_BTSIDE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PCO_BTSIDE		= 0x0,$/;"	e	enum:bt_8822b_1ant_path_ctrl_owner
-BT_8822B_1ANT_PCO_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PCO_MAX$/;"	e	enum:bt_8822b_1ant_path_ctrl_owner
-BT_8822B_1ANT_PCO_WLSIDE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PCO_WLSIDE	= 0x1,$/;"	e	enum:bt_8822b_1ant_path_ctrl_owner
-BT_8822B_1ANT_PHASE_2G_RUNTIME	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PHASE_2G_RUNTIME				= 0x3,$/;"	e	enum:bt_8822b_1ant_phase
-BT_8822B_1ANT_PHASE_5G_RUNTIME	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PHASE_5G_RUNTIME				= 0x4,$/;"	e	enum:bt_8822b_1ant_phase
-BT_8822B_1ANT_PHASE_BTMPMODE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PHASE_BTMPMODE				= 0x5,$/;"	e	enum:bt_8822b_1ant_phase
-BT_8822B_1ANT_PHASE_COEX_INIT	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PHASE_COEX_INIT				= 0x0,$/;"	e	enum:bt_8822b_1ant_phase
-BT_8822B_1ANT_PHASE_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PHASE_MAX$/;"	e	enum:bt_8822b_1ant_phase
-BT_8822B_1ANT_PHASE_WLANONLY_INIT	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PHASE_WLANONLY_INIT			= 0x1,	$/;"	e	enum:bt_8822b_1ant_phase
-BT_8822B_1ANT_PHASE_WLAN_OFF	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_PHASE_WLAN_OFF				= 0x2,$/;"	e	enum:bt_8822b_1ant_phase
-BT_8822B_1ANT_SIG_STA_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_SIG_STA_MAX$/;"	e	enum:bt_8822b_1ant_signal_state
-BT_8822B_1ANT_SIG_STA_SET_BY_HW	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_SIG_STA_SET_BY_HW		= 0x0,$/;"	e	enum:bt_8822b_1ant_signal_state
-BT_8822B_1ANT_SIG_STA_SET_TO_HIGH	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_SIG_STA_SET_TO_HIGH		= 0x1,$/;"	e	enum:bt_8822b_1ant_signal_state
-BT_8822B_1ANT_SIG_STA_SET_TO_LOW	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_SIG_STA_SET_TO_LOW		= 0x0,$/;"	e	enum:bt_8822b_1ant_signal_state
-BT_8822B_1ANT_WIFI_NOISY_THRESH	hal/btc/HalBtc8822b1Ant.h	25;"	d
-BT_8822B_1ANT_WIFI_NOISY_THRESH	hal/btc/HalBtc8822b1Ant.h	37;"	d
-BT_8822B_1ANT_WIFI_STATUS_CONNECTED_BUSY	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_BUSY					= 0x5,$/;"	e	enum:bt_8822b_1ant_wifi_status
-BT_8822B_1ANT_WIFI_STATUS_CONNECTED_IDLE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_IDLE					= 0x4,$/;"	e	enum:bt_8822b_1ant_wifi_status
-BT_8822B_1ANT_WIFI_STATUS_CONNECTED_SCAN	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_SCAN					= 0x2,$/;"	e	enum:bt_8822b_1ant_wifi_status
-BT_8822B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_WIFI_STATUS_CONNECTED_SPECIFIC_PKT				= 0x3,$/;"	e	enum:bt_8822b_1ant_wifi_status
-BT_8822B_1ANT_WIFI_STATUS_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_WIFI_STATUS_MAX$/;"	e	enum:bt_8822b_1ant_wifi_status
-BT_8822B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN		= 0x1,$/;"	e	enum:bt_8822b_1ant_wifi_status
-BT_8822B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE	hal/btc/HalBtc8822b1Ant.h	/^	BT_8822B_1ANT_WIFI_STATUS_NON_CONNECTED_IDLE				= 0x0,$/;"	e	enum:bt_8822b_1ant_wifi_status
-BT_ACCEL	include/hal_pg.h	/^	BT_ACCEL		= 2,$/;"	e	enum:_BT_CoType
-BT_AFH_MAP_BT_PSD_ONLY	include/rtw_bt_mp.h	/^	BT_AFH_MAP_BT_PSD_ONLY					= 3,$/;"	e	enum:_BT_AFH_MAP_TYPE
-BT_AFH_MAP_HOST_CLASSIFICATION_ONLY	include/rtw_bt_mp.h	/^	BT_AFH_MAP_HOST_CLASSIFICATION_ONLY	= 4,$/;"	e	enum:_BT_AFH_MAP_TYPE
-BT_AFH_MAP_MAX	include/rtw_bt_mp.h	/^	BT_AFH_MAP_MAX$/;"	e	enum:_BT_AFH_MAP_TYPE
-BT_AFH_MAP_RESULT	include/rtw_bt_mp.h	/^	BT_AFH_MAP_RESULT						= 0,$/;"	e	enum:_BT_AFH_MAP_TYPE
-BT_AFH_MAP_TYPE	include/rtw_bt_mp.h	/^} BT_AFH_MAP_TYPE, *PBT_AFH_MAP_TYPE;$/;"	t	typeref:enum:_BT_AFH_MAP_TYPE
-BT_AFH_MAP_WIFI_CH_BW_ONLY	include/rtw_bt_mp.h	/^	BT_AFH_MAP_WIFI_CH_BW_ONLY				= 2,$/;"	e	enum:_BT_AFH_MAP_TYPE
-BT_AFH_MAP_WIFI_PSD_ONLY	include/rtw_bt_mp.h	/^	BT_AFH_MAP_WIFI_PSD_ONLY				= 1,$/;"	e	enum:_BT_AFH_MAP_TYPE
-BT_AUTO_REPORT_ONLY_8192E_1ANT	hal/btc/HalBtc8192e1Ant.h	9;"	d
-BT_AUTO_REPORT_ONLY_8192E_2ANT	hal/btc/HalBtc8192e2Ant.h	8;"	d
-BT_AUTO_REPORT_ONLY_8703B_1ANT	hal/btc/HalBtc8703b1Ant.h	8;"	d
-BT_AUTO_REPORT_ONLY_8723B_1ANT	hal/btc/HalBtc8723b1Ant.h	8;"	d
-BT_AUTO_REPORT_ONLY_8723B_2ANT	hal/btc/HalBtc8723b2Ant.h	8;"	d
-BT_AUTO_REPORT_ONLY_8723D_1ANT	hal/btc/halbtc8723d1ant.h	10;"	d
-BT_AUTO_REPORT_ONLY_8723D_2ANT	hal/btc/halbtc8723d2ant.h	10;"	d
-BT_AUTO_REPORT_ONLY_8812A_1ANT	hal/btc/HalBtc8812a1Ant.h	9;"	d
-BT_AUTO_REPORT_ONLY_8812A_2ANT	hal/btc/HalBtc8812a2Ant.h	9;"	d
-BT_AUTO_REPORT_ONLY_8821A_1ANT	hal/btc/HalBtc8821a1Ant.h	9;"	d
-BT_AUTO_REPORT_ONLY_8821A_2ANT	hal/btc/HalBtc8821a2Ant.h	9;"	d
-BT_AUTO_REPORT_ONLY_8821C_1ANT	hal/btc/halbtc8821c1ant.h	9;"	d
-BT_AUTO_REPORT_ONLY_8821C_2ANT	hal/btc/halbtc8821c2ant.h	9;"	d
-BT_AUTO_REPORT_ONLY_8822B_1ANT	hal/btc/HalBtc8822b1Ant.h	9;"	d
-BT_Ant_NUM	include/hal_pg.h	/^} BT_Ant_NUM, *PBT_Ant_NUM;$/;"	t	typeref:enum:_BT_Ant_NUM
-BT_C2H_STATUS	hal/hal_btcoex.c	/^} BT_C2H_STATUS;$/;"	t	typeref:enum:_bt_c2h_status	file:
-BT_COEXIST	include/hal_btcoex.h	/^} BT_COEXIST, *PBT_COEXIST;$/;"	t	typeref:struct:_BT_COEXIST
-BT_COEX_ANT_TYPE_ANTDIV	hal/btc/HalBtcOutSrc.h	36;"	d
-BT_COEX_ANT_TYPE_DETECTED	hal/btc/HalBtcOutSrc.h	37;"	d
-BT_COEX_ANT_TYPE_PG	hal/btc/HalBtcOutSrc.h	35;"	d
-BT_CONNECT_ASOC_REQ	include/rtw_btcoex.h	/^	BT_CONNECT_ASOC_REQ								= 0x02,$/;"	e	enum:_BT_CONNECT_TYPE
-BT_CONNECT_ASOC_RSP	include/rtw_btcoex.h	/^	BT_CONNECT_ASOC_RSP								= 0x03,$/;"	e	enum:_BT_CONNECT_TYPE
-BT_CONNECT_AUTH_REQ	include/rtw_btcoex.h	/^	BT_CONNECT_AUTH_REQ								= 0x00,$/;"	e	enum:_BT_CONNECT_TYPE
-BT_CONNECT_AUTH_RSP	include/rtw_btcoex.h	/^	BT_CONNECT_AUTH_RSP								= 0x01,$/;"	e	enum:_BT_CONNECT_TYPE
-BT_CONNECT_TYPE	include/rtw_btcoex.h	/^} BT_CONNECT_TYPE, *PBT_CONNECT_TYPE;$/;"	t	typeref:enum:_BT_CONNECT_TYPE
-BT_CSR_BC4	include/hal_pg.h	/^	BT_CSR_BC4		= 3,$/;"	e	enum:_BT_CoType
-BT_CSR_BC8	include/hal_pg.h	/^	BT_CSR_BC8		= 4,$/;"	e	enum:_BT_CoType
-BT_CTL_HWPDN	include/hal_com_reg.h	1298;"	d
-BT_CTRL_OPCODE_LOWER	include/rtw_bt_mp.h	/^} BT_CTRL_OPCODE_LOWER, *PBT_CTRL_OPCODE_LOWER;$/;"	t	typeref:enum:_BT_CTRL_OPCODE_LOWER
-BT_CTRL_OPCODE_UPPER	include/rtw_bt_mp.h	/^} BT_CTRL_OPCODE_UPPER, *PBT_CTRL_OPCODE_UPPER;$/;"	t	typeref:enum:_BT_CTRL_OPCODE_UPPER
-BT_CTRL_STATUS	include/rtw_btcoex.h	/^} BT_CTRL_STATUS, *PBT_CTRL_STATUS;$/;"	t	typeref:enum:_BT_CTRL_STATUS
-BT_CoType	include/hal_pg.h	/^} BT_CoType, *PBT_CoType;$/;"	t	typeref:enum:_BT_CoType
-BT_DISCONNECT	include/rtw_btcoex.h	/^	BT_DISCONNECT										= 0x04$/;"	e	enum:_BT_CONNECT_TYPE
-BT_ENABLE_CFO_TRACKING	include/rtw_bt_mp.h	/^	BT_ENABLE_CFO_TRACKING									= 0x06,$/;"	e	enum:_BT_SET_GENERAL
-BT_EXT_C2H	include/rtw_bt_mp.h	/^} BT_EXT_C2H, *PBT_EXT_C2H;$/;"	t	typeref:struct:_BT_EXT_C2H
-BT_EXT_EID	hal/hal_btcoex.c	/^} BT_EXT_EID;$/;"	t	typeref:enum:_bt_ext_eid	file:
-BT_FUNC	include/hal_com_reg.h	1265;"	d
-BT_FUNC_EN	include/hal_com_reg.h	1770;"	d
-BT_GET_GENERAL	include/rtw_bt_mp.h	/^} BT_GET_GENERAL, *PBT_GET_GENERAL;$/;"	t	typeref:enum:_BT_GET_GENERAL
-BT_GGET_AFH_MAP	include/rtw_bt_mp.h	/^	BT_GGET_AFH_MAP										= 0x03,$/;"	e	enum:_BT_GET_GENERAL
-BT_GGET_AFH_STATUS	include/rtw_bt_mp.h	/^	BT_GGET_AFH_STATUS										= 0x04,$/;"	e	enum:_BT_GET_GENERAL
-BT_GGET_MAX	include/rtw_bt_mp.h	/^	BT_GGET_MAX$/;"	e	enum:_BT_GET_GENERAL
-BT_GGET_REG	include/rtw_bt_mp.h	/^	BT_GGET_REG											= 0x00,$/;"	e	enum:_BT_GET_GENERAL
-BT_GGET_REPORT	include/rtw_bt_mp.h	/^	BT_GGET_REPORT											= 0x02,$/;"	e	enum:_BT_GET_GENERAL
-BT_GGET_STATUS	include/rtw_bt_mp.h	/^	BT_GGET_STATUS											= 0x01,$/;"	e	enum:_BT_GET_GENERAL
-BT_GSET_MAX	include/rtw_bt_mp.h	/^	BT_GSET_MAX$/;"	e	enum:_BT_SET_GENERAL
-BT_GSET_REG	include/rtw_bt_mp.h	/^	BT_GSET_REG											= 0x00,$/;"	e	enum:_BT_SET_GENERAL
-BT_GSET_RESET	include/rtw_bt_mp.h	/^	BT_GSET_RESET											= 0x01,$/;"	e	enum:_BT_SET_GENERAL
-BT_GSET_TARGET_BD_ADDR	include/rtw_bt_mp.h	/^	BT_GSET_TARGET_BD_ADDR									= 0x02,$/;"	e	enum:_BT_SET_GENERAL
-BT_GSET_TX_PWR_FINETUNE	include/rtw_bt_mp.h	/^	BT_GSET_TX_PWR_FINETUNE								= 0x03,$/;"	e	enum:_BT_SET_GENERAL
-BT_GSET_UPDATE_BT_PATCH	include/rtw_bt_mp.h	/^	BT_GSET_UPDATE_BT_PATCH								= 0x07,$/;"	e	enum:_BT_SET_GENERAL
-BT_H2C	include/rtw_bt_mp.h	/^} BT_H2C, *PBT_H2C;$/;"	t	typeref:struct:_BT_H2C
-BT_H2C_MAX_RETRY	include/rtw_bt_mp.h	200;"	d
-BT_HWPDN_EN	include/hal_com_reg.h	1768;"	d
-BT_HWPDN_SL	include/hal_com_reg.h	1769;"	d
-BT_HWROF_EN	include/hal_com_reg.h	1771;"	d
-BT_INFO_8192E_1ANT_A2DP_BASIC_RATE	hal/btc/HalBtc8192e1Ant.h	20;"	d
-BT_INFO_8192E_1ANT_B_A2DP	hal/btc/HalBtc8192e1Ant.h	12;"	d
-BT_INFO_8192E_1ANT_B_ACL_BUSY	hal/btc/HalBtc8192e1Ant.h	15;"	d
-BT_INFO_8192E_1ANT_B_CONNECTION	hal/btc/HalBtc8192e1Ant.h	18;"	d
-BT_INFO_8192E_1ANT_B_FTP	hal/btc/HalBtc8192e1Ant.h	11;"	d
-BT_INFO_8192E_1ANT_B_HID	hal/btc/HalBtc8192e1Ant.h	13;"	d
-BT_INFO_8192E_1ANT_B_INQ_PAGE	hal/btc/HalBtc8192e1Ant.h	16;"	d
-BT_INFO_8192E_1ANT_B_SCO_BUSY	hal/btc/HalBtc8192e1Ant.h	14;"	d
-BT_INFO_8192E_1ANT_B_SCO_ESCO	hal/btc/HalBtc8192e1Ant.h	17;"	d
-BT_INFO_8192E_2ANT_B_A2DP	hal/btc/HalBtc8192e2Ant.h	11;"	d
-BT_INFO_8192E_2ANT_B_ACL_BUSY	hal/btc/HalBtc8192e2Ant.h	14;"	d
-BT_INFO_8192E_2ANT_B_CONNECTION	hal/btc/HalBtc8192e2Ant.h	17;"	d
-BT_INFO_8192E_2ANT_B_FTP	hal/btc/HalBtc8192e2Ant.h	10;"	d
-BT_INFO_8192E_2ANT_B_HID	hal/btc/HalBtc8192e2Ant.h	12;"	d
-BT_INFO_8192E_2ANT_B_INQ_PAGE	hal/btc/HalBtc8192e2Ant.h	15;"	d
-BT_INFO_8192E_2ANT_B_SCO_BUSY	hal/btc/HalBtc8192e2Ant.h	13;"	d
-BT_INFO_8192E_2ANT_B_SCO_ESCO	hal/btc/HalBtc8192e2Ant.h	16;"	d
-BT_INFO_8703B_1ANT_A2DP_BASIC_RATE	hal/btc/HalBtc8703b1Ant.h	20;"	d
-BT_INFO_8703B_1ANT_B_A2DP	hal/btc/HalBtc8703b1Ant.h	12;"	d
-BT_INFO_8703B_1ANT_B_ACL_BUSY	hal/btc/HalBtc8703b1Ant.h	15;"	d
-BT_INFO_8703B_1ANT_B_CONNECTION	hal/btc/HalBtc8703b1Ant.h	18;"	d
-BT_INFO_8703B_1ANT_B_FTP	hal/btc/HalBtc8703b1Ant.h	11;"	d
-BT_INFO_8703B_1ANT_B_HID	hal/btc/HalBtc8703b1Ant.h	13;"	d
-BT_INFO_8703B_1ANT_B_INQ_PAGE	hal/btc/HalBtc8703b1Ant.h	16;"	d
-BT_INFO_8703B_1ANT_B_SCO_BUSY	hal/btc/HalBtc8703b1Ant.h	14;"	d
-BT_INFO_8703B_1ANT_B_SCO_ESCO	hal/btc/HalBtc8703b1Ant.h	17;"	d
-BT_INFO_8723A_1ANT_B_A2DP	hal/btc/HalBtc8723a1Ant.h	5;"	d
-BT_INFO_8723A_1ANT_B_ACL_BUSY	hal/btc/HalBtc8723a1Ant.h	8;"	d
-BT_INFO_8723A_1ANT_B_CONNECTION	hal/btc/HalBtc8723a1Ant.h	11;"	d
-BT_INFO_8723A_1ANT_B_FTP	hal/btc/HalBtc8723a1Ant.h	4;"	d
-BT_INFO_8723A_1ANT_B_HID	hal/btc/HalBtc8723a1Ant.h	6;"	d
-BT_INFO_8723A_1ANT_B_INQ_PAGE	hal/btc/HalBtc8723a1Ant.h	9;"	d
-BT_INFO_8723A_1ANT_B_SCO_BUSY	hal/btc/HalBtc8723a1Ant.h	7;"	d
-BT_INFO_8723A_1ANT_B_SCO_ESCO	hal/btc/HalBtc8723a1Ant.h	10;"	d
-BT_INFO_8723A_2ANT_B_A2DP	hal/btc/HalBtc8723a2Ant.h	5;"	d
-BT_INFO_8723A_2ANT_B_ACL_BUSY	hal/btc/HalBtc8723a2Ant.h	8;"	d
-BT_INFO_8723A_2ANT_B_CONNECTION	hal/btc/HalBtc8723a2Ant.h	11;"	d
-BT_INFO_8723A_2ANT_B_FTP	hal/btc/HalBtc8723a2Ant.h	4;"	d
-BT_INFO_8723A_2ANT_B_HID	hal/btc/HalBtc8723a2Ant.h	6;"	d
-BT_INFO_8723A_2ANT_B_INQ_PAGE	hal/btc/HalBtc8723a2Ant.h	9;"	d
-BT_INFO_8723A_2ANT_B_SCO_BUSY	hal/btc/HalBtc8723a2Ant.h	7;"	d
-BT_INFO_8723A_2ANT_B_SCO_ESCO	hal/btc/HalBtc8723a2Ant.h	10;"	d
-BT_INFO_8723B_1ANT_A2DP_BASIC_RATE	hal/btc/HalBtc8723b1Ant.h	19;"	d
-BT_INFO_8723B_1ANT_B_A2DP	hal/btc/HalBtc8723b1Ant.h	11;"	d
-BT_INFO_8723B_1ANT_B_ACL_BUSY	hal/btc/HalBtc8723b1Ant.h	14;"	d
-BT_INFO_8723B_1ANT_B_CONNECTION	hal/btc/HalBtc8723b1Ant.h	17;"	d
-BT_INFO_8723B_1ANT_B_FTP	hal/btc/HalBtc8723b1Ant.h	10;"	d
-BT_INFO_8723B_1ANT_B_HID	hal/btc/HalBtc8723b1Ant.h	12;"	d
-BT_INFO_8723B_1ANT_B_INQ_PAGE	hal/btc/HalBtc8723b1Ant.h	15;"	d
-BT_INFO_8723B_1ANT_B_SCO_BUSY	hal/btc/HalBtc8723b1Ant.h	13;"	d
-BT_INFO_8723B_1ANT_B_SCO_ESCO	hal/btc/HalBtc8723b1Ant.h	16;"	d
-BT_INFO_8723B_2ANT_B_A2DP	hal/btc/HalBtc8723b2Ant.h	12;"	d
-BT_INFO_8723B_2ANT_B_ACL_BUSY	hal/btc/HalBtc8723b2Ant.h	15;"	d
-BT_INFO_8723B_2ANT_B_CONNECTION	hal/btc/HalBtc8723b2Ant.h	18;"	d
-BT_INFO_8723B_2ANT_B_FTP	hal/btc/HalBtc8723b2Ant.h	11;"	d
-BT_INFO_8723B_2ANT_B_HID	hal/btc/HalBtc8723b2Ant.h	13;"	d
-BT_INFO_8723B_2ANT_B_INQ_PAGE	hal/btc/HalBtc8723b2Ant.h	16;"	d
-BT_INFO_8723B_2ANT_B_SCO_BUSY	hal/btc/HalBtc8723b2Ant.h	14;"	d
-BT_INFO_8723B_2ANT_B_SCO_ESCO	hal/btc/HalBtc8723b2Ant.h	17;"	d
-BT_INFO_8723D_1ANT_A2DP_BASIC_RATE	hal/btc/halbtc8723d1ant.h	21;"	d
-BT_INFO_8723D_1ANT_B_A2DP	hal/btc/halbtc8723d1ant.h	13;"	d
-BT_INFO_8723D_1ANT_B_ACL_BUSY	hal/btc/halbtc8723d1ant.h	16;"	d
-BT_INFO_8723D_1ANT_B_CONNECTION	hal/btc/halbtc8723d1ant.h	19;"	d
-BT_INFO_8723D_1ANT_B_FTP	hal/btc/halbtc8723d1ant.h	12;"	d
-BT_INFO_8723D_1ANT_B_HID	hal/btc/halbtc8723d1ant.h	14;"	d
-BT_INFO_8723D_1ANT_B_INQ_PAGE	hal/btc/halbtc8723d1ant.h	17;"	d
-BT_INFO_8723D_1ANT_B_SCO_BUSY	hal/btc/halbtc8723d1ant.h	15;"	d
-BT_INFO_8723D_1ANT_B_SCO_ESCO	hal/btc/halbtc8723d1ant.h	18;"	d
-BT_INFO_8723D_2ANT_B_A2DP	hal/btc/halbtc8723d2ant.h	14;"	d
-BT_INFO_8723D_2ANT_B_ACL_BUSY	hal/btc/halbtc8723d2ant.h	17;"	d
-BT_INFO_8723D_2ANT_B_CONNECTION	hal/btc/halbtc8723d2ant.h	20;"	d
-BT_INFO_8723D_2ANT_B_FTP	hal/btc/halbtc8723d2ant.h	13;"	d
-BT_INFO_8723D_2ANT_B_HID	hal/btc/halbtc8723d2ant.h	15;"	d
-BT_INFO_8723D_2ANT_B_INQ_PAGE	hal/btc/halbtc8723d2ant.h	18;"	d
-BT_INFO_8723D_2ANT_B_SCO_BUSY	hal/btc/halbtc8723d2ant.h	16;"	d
-BT_INFO_8723D_2ANT_B_SCO_ESCO	hal/btc/halbtc8723d2ant.h	19;"	d
-BT_INFO_8812A_1ANT_A2DP_BASIC_RATE	hal/btc/HalBtc8812a1Ant.h	20;"	d
-BT_INFO_8812A_1ANT_B_A2DP	hal/btc/HalBtc8812a1Ant.h	12;"	d
-BT_INFO_8812A_1ANT_B_ACL_BUSY	hal/btc/HalBtc8812a1Ant.h	15;"	d
-BT_INFO_8812A_1ANT_B_CONNECTION	hal/btc/HalBtc8812a1Ant.h	18;"	d
-BT_INFO_8812A_1ANT_B_FTP	hal/btc/HalBtc8812a1Ant.h	11;"	d
-BT_INFO_8812A_1ANT_B_HID	hal/btc/HalBtc8812a1Ant.h	13;"	d
-BT_INFO_8812A_1ANT_B_INQ_PAGE	hal/btc/HalBtc8812a1Ant.h	16;"	d
-BT_INFO_8812A_1ANT_B_SCO_BUSY	hal/btc/HalBtc8812a1Ant.h	14;"	d
-BT_INFO_8812A_1ANT_B_SCO_ESCO	hal/btc/HalBtc8812a1Ant.h	17;"	d
-BT_INFO_8812A_2ANT_A2DP_BASIC_RATE	hal/btc/HalBtc8812a2Ant.h	20;"	d
-BT_INFO_8812A_2ANT_B_A2DP	hal/btc/HalBtc8812a2Ant.h	12;"	d
-BT_INFO_8812A_2ANT_B_ACL_BUSY	hal/btc/HalBtc8812a2Ant.h	15;"	d
-BT_INFO_8812A_2ANT_B_CONNECTION	hal/btc/HalBtc8812a2Ant.h	18;"	d
-BT_INFO_8812A_2ANT_B_FTP	hal/btc/HalBtc8812a2Ant.h	11;"	d
-BT_INFO_8812A_2ANT_B_HID	hal/btc/HalBtc8812a2Ant.h	13;"	d
-BT_INFO_8812A_2ANT_B_INQ_PAGE	hal/btc/HalBtc8812a2Ant.h	16;"	d
-BT_INFO_8812A_2ANT_B_SCO_BUSY	hal/btc/HalBtc8812a2Ant.h	14;"	d
-BT_INFO_8812A_2ANT_B_SCO_ESCO	hal/btc/HalBtc8812a2Ant.h	17;"	d
-BT_INFO_8821A_1ANT_A2DP_BASIC_RATE	hal/btc/HalBtc8821a1Ant.h	20;"	d
-BT_INFO_8821A_1ANT_B_A2DP	hal/btc/HalBtc8821a1Ant.h	12;"	d
-BT_INFO_8821A_1ANT_B_ACL_BUSY	hal/btc/HalBtc8821a1Ant.h	15;"	d
-BT_INFO_8821A_1ANT_B_CONNECTION	hal/btc/HalBtc8821a1Ant.h	18;"	d
-BT_INFO_8821A_1ANT_B_FTP	hal/btc/HalBtc8821a1Ant.h	11;"	d
-BT_INFO_8821A_1ANT_B_HID	hal/btc/HalBtc8821a1Ant.h	13;"	d
-BT_INFO_8821A_1ANT_B_INQ_PAGE	hal/btc/HalBtc8821a1Ant.h	16;"	d
-BT_INFO_8821A_1ANT_B_SCO_BUSY	hal/btc/HalBtc8821a1Ant.h	14;"	d
-BT_INFO_8821A_1ANT_B_SCO_ESCO	hal/btc/HalBtc8821a1Ant.h	17;"	d
-BT_INFO_8821A_2ANT_B_A2DP	hal/btc/HalBtc8821a2Ant.h	13;"	d
-BT_INFO_8821A_2ANT_B_ACL_BUSY	hal/btc/HalBtc8821a2Ant.h	16;"	d
-BT_INFO_8821A_2ANT_B_CONNECTION	hal/btc/HalBtc8821a2Ant.h	19;"	d
-BT_INFO_8821A_2ANT_B_FTP	hal/btc/HalBtc8821a2Ant.h	12;"	d
-BT_INFO_8821A_2ANT_B_HID	hal/btc/HalBtc8821a2Ant.h	14;"	d
-BT_INFO_8821A_2ANT_B_INQ_PAGE	hal/btc/HalBtc8821a2Ant.h	17;"	d
-BT_INFO_8821A_2ANT_B_SCO_BUSY	hal/btc/HalBtc8821a2Ant.h	15;"	d
-BT_INFO_8821A_2ANT_B_SCO_ESCO	hal/btc/HalBtc8821a2Ant.h	18;"	d
-BT_INFO_8821A_CSR_2ANT_B_A2DP	hal/btc/HalBtc8821aCsr2Ant.h	10;"	d
-BT_INFO_8821A_CSR_2ANT_B_ACL_BUSY	hal/btc/HalBtc8821aCsr2Ant.h	13;"	d
-BT_INFO_8821A_CSR_2ANT_B_CONNECTION	hal/btc/HalBtc8821aCsr2Ant.h	16;"	d
-BT_INFO_8821A_CSR_2ANT_B_FTP	hal/btc/HalBtc8821aCsr2Ant.h	9;"	d
-BT_INFO_8821A_CSR_2ANT_B_HID	hal/btc/HalBtc8821aCsr2Ant.h	11;"	d
-BT_INFO_8821A_CSR_2ANT_B_INQ_PAGE	hal/btc/HalBtc8821aCsr2Ant.h	14;"	d
-BT_INFO_8821A_CSR_2ANT_B_SCO_BUSY	hal/btc/HalBtc8821aCsr2Ant.h	12;"	d
-BT_INFO_8821A_CSR_2ANT_B_SCO_ESCO	hal/btc/HalBtc8821aCsr2Ant.h	15;"	d
-BT_INFO_8821C_1ANT_A2DP_BASIC_RATE	hal/btc/halbtc8821c1ant.h	20;"	d
-BT_INFO_8821C_1ANT_B_A2DP	hal/btc/halbtc8821c1ant.h	12;"	d
-BT_INFO_8821C_1ANT_B_ACL_BUSY	hal/btc/halbtc8821c1ant.h	15;"	d
-BT_INFO_8821C_1ANT_B_CONNECTION	hal/btc/halbtc8821c1ant.h	18;"	d
-BT_INFO_8821C_1ANT_B_FTP	hal/btc/halbtc8821c1ant.h	11;"	d
-BT_INFO_8821C_1ANT_B_HID	hal/btc/halbtc8821c1ant.h	13;"	d
-BT_INFO_8821C_1ANT_B_INQ_PAGE	hal/btc/halbtc8821c1ant.h	16;"	d
-BT_INFO_8821C_1ANT_B_SCO_BUSY	hal/btc/halbtc8821c1ant.h	14;"	d
-BT_INFO_8821C_1ANT_B_SCO_ESCO	hal/btc/halbtc8821c1ant.h	17;"	d
-BT_INFO_8821C_2ANT_B_A2DP	hal/btc/halbtc8821c2ant.h	13;"	d
-BT_INFO_8821C_2ANT_B_ACL_BUSY	hal/btc/halbtc8821c2ant.h	16;"	d
-BT_INFO_8821C_2ANT_B_CONNECTION	hal/btc/halbtc8821c2ant.h	19;"	d
-BT_INFO_8821C_2ANT_B_FTP	hal/btc/halbtc8821c2ant.h	12;"	d
-BT_INFO_8821C_2ANT_B_HID	hal/btc/halbtc8821c2ant.h	14;"	d
-BT_INFO_8821C_2ANT_B_INQ_PAGE	hal/btc/halbtc8821c2ant.h	17;"	d
-BT_INFO_8821C_2ANT_B_SCO_BUSY	hal/btc/halbtc8821c2ant.h	15;"	d
-BT_INFO_8821C_2ANT_B_SCO_ESCO	hal/btc/halbtc8821c2ant.h	18;"	d
-BT_INFO_8822B_1ANT_A2DP_BASIC_RATE	hal/btc/HalBtc8822b1Ant.h	20;"	d
-BT_INFO_8822B_1ANT_B_A2DP	hal/btc/HalBtc8822b1Ant.h	12;"	d
-BT_INFO_8822B_1ANT_B_ACL_BUSY	hal/btc/HalBtc8822b1Ant.h	15;"	d
-BT_INFO_8822B_1ANT_B_CONNECTION	hal/btc/HalBtc8822b1Ant.h	18;"	d
-BT_INFO_8822B_1ANT_B_FTP	hal/btc/HalBtc8822b1Ant.h	11;"	d
-BT_INFO_8822B_1ANT_B_HID	hal/btc/HalBtc8822b1Ant.h	13;"	d
-BT_INFO_8822B_1ANT_B_INQ_PAGE	hal/btc/HalBtc8822b1Ant.h	16;"	d
-BT_INFO_8822B_1ANT_B_SCO_BUSY	hal/btc/HalBtc8822b1Ant.h	14;"	d
-BT_INFO_8822B_1ANT_B_SCO_ESCO	hal/btc/HalBtc8822b1Ant.h	17;"	d
-BT_INFO_LEN	include/rtw_btcoex.h	93;"	d
-BT_INFO_LENGTH	core/rtw_btcoex.c	581;"	d	file:
-BT_INFO_NOTIFY_CMD	include/rtw_btcoex.h	92;"	d
-BT_INFO_SRC_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^}BT_INFO_SRC_8188C_2ANT,*PBT_INFO_SRC_8188C_2ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8188C_2ANT
-BT_INFO_SRC_8188C_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8188c2Ant.h	/^	BT_INFO_SRC_8188C_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:_BT_INFO_SRC_8188C_2ANT
-BT_INFO_SRC_8188C_2ANT_BT_RSP	hal/btc/HalBtc8188c2Ant.h	/^	BT_INFO_SRC_8188C_2ANT_BT_RSP				= 0x1,$/;"	e	enum:_BT_INFO_SRC_8188C_2ANT
-BT_INFO_SRC_8188C_2ANT_MAX	hal/btc/HalBtc8188c2Ant.h	/^	BT_INFO_SRC_8188C_2ANT_MAX$/;"	e	enum:_BT_INFO_SRC_8188C_2ANT
-BT_INFO_SRC_8188C_2ANT_WIFI_FW	hal/btc/HalBtc8188c2Ant.h	/^	BT_INFO_SRC_8188C_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:_BT_INFO_SRC_8188C_2ANT
-BT_INFO_SRC_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^}BT_INFO_SRC_8192D_2ANT,*PBT_INFO_SRC_8192D_2ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8192D_2ANT
-BT_INFO_SRC_8192D_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8192d2Ant.h	/^	BT_INFO_SRC_8192D_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:_BT_INFO_SRC_8192D_2ANT
-BT_INFO_SRC_8192D_2ANT_BT_RSP	hal/btc/HalBtc8192d2Ant.h	/^	BT_INFO_SRC_8192D_2ANT_BT_RSP				= 0x1,$/;"	e	enum:_BT_INFO_SRC_8192D_2ANT
-BT_INFO_SRC_8192D_2ANT_MAX	hal/btc/HalBtc8192d2Ant.h	/^	BT_INFO_SRC_8192D_2ANT_MAX$/;"	e	enum:_BT_INFO_SRC_8192D_2ANT
-BT_INFO_SRC_8192D_2ANT_WIFI_FW	hal/btc/HalBtc8192d2Ant.h	/^	BT_INFO_SRC_8192D_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:_BT_INFO_SRC_8192D_2ANT
-BT_INFO_SRC_8192E_1ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8192e1Ant.h	/^	BT_INFO_SRC_8192E_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8192e_1ant
-BT_INFO_SRC_8192E_1ANT_BT_RSP	hal/btc/HalBtc8192e1Ant.h	/^	BT_INFO_SRC_8192E_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8192e_1ant
-BT_INFO_SRC_8192E_1ANT_MAX	hal/btc/HalBtc8192e1Ant.h	/^	BT_INFO_SRC_8192E_1ANT_MAX$/;"	e	enum:bt_info_src_8192e_1ant
-BT_INFO_SRC_8192E_1ANT_WIFI_FW	hal/btc/HalBtc8192e1Ant.h	/^	BT_INFO_SRC_8192E_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8192e_1ant
-BT_INFO_SRC_8192E_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8192e2Ant.h	/^	BT_INFO_SRC_8192E_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8192e_2ant
-BT_INFO_SRC_8192E_2ANT_BT_RSP	hal/btc/HalBtc8192e2Ant.h	/^	BT_INFO_SRC_8192E_2ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8192e_2ant
-BT_INFO_SRC_8192E_2ANT_MAX	hal/btc/HalBtc8192e2Ant.h	/^	BT_INFO_SRC_8192E_2ANT_MAX$/;"	e	enum:bt_info_src_8192e_2ant
-BT_INFO_SRC_8192E_2ANT_WIFI_FW	hal/btc/HalBtc8192e2Ant.h	/^	BT_INFO_SRC_8192E_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8192e_2ant
-BT_INFO_SRC_8703B_1ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8703b1Ant.h	/^	BT_INFO_SRC_8703B_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8703b_1ant
-BT_INFO_SRC_8703B_1ANT_BT_RSP	hal/btc/HalBtc8703b1Ant.h	/^	BT_INFO_SRC_8703B_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8703b_1ant
-BT_INFO_SRC_8703B_1ANT_MAX	hal/btc/HalBtc8703b1Ant.h	/^	BT_INFO_SRC_8703B_1ANT_MAX$/;"	e	enum:bt_info_src_8703b_1ant
-BT_INFO_SRC_8703B_1ANT_WIFI_FW	hal/btc/HalBtc8703b1Ant.h	/^	BT_INFO_SRC_8703B_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8703b_1ant
-BT_INFO_SRC_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^}BT_INFO_SRC_8723A_1ANT,*PBT_INFO_SRC_8723A_1ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8723A_1ANT
-BT_INFO_SRC_8723A_1ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8723a1Ant.h	/^	BT_INFO_SRC_8723A_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:_BT_INFO_SRC_8723A_1ANT
-BT_INFO_SRC_8723A_1ANT_BT_RSP	hal/btc/HalBtc8723a1Ant.h	/^	BT_INFO_SRC_8723A_1ANT_BT_RSP				= 0x1,$/;"	e	enum:_BT_INFO_SRC_8723A_1ANT
-BT_INFO_SRC_8723A_1ANT_MAX	hal/btc/HalBtc8723a1Ant.h	/^	BT_INFO_SRC_8723A_1ANT_MAX$/;"	e	enum:_BT_INFO_SRC_8723A_1ANT
-BT_INFO_SRC_8723A_1ANT_WIFI_FW	hal/btc/HalBtc8723a1Ant.h	/^	BT_INFO_SRC_8723A_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:_BT_INFO_SRC_8723A_1ANT
-BT_INFO_SRC_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^}BT_INFO_SRC_8723A_2ANT,*PBT_INFO_SRC_8723A_2ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8723A_2ANT
-BT_INFO_SRC_8723A_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8723a2Ant.h	/^	BT_INFO_SRC_8723A_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:_BT_INFO_SRC_8723A_2ANT
-BT_INFO_SRC_8723A_2ANT_BT_RSP	hal/btc/HalBtc8723a2Ant.h	/^	BT_INFO_SRC_8723A_2ANT_BT_RSP				= 0x1,$/;"	e	enum:_BT_INFO_SRC_8723A_2ANT
-BT_INFO_SRC_8723A_2ANT_MAX	hal/btc/HalBtc8723a2Ant.h	/^	BT_INFO_SRC_8723A_2ANT_MAX$/;"	e	enum:_BT_INFO_SRC_8723A_2ANT
-BT_INFO_SRC_8723A_2ANT_WIFI_FW	hal/btc/HalBtc8723a2Ant.h	/^	BT_INFO_SRC_8723A_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:_BT_INFO_SRC_8723A_2ANT
-BT_INFO_SRC_8723B_1ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8723b1Ant.h	/^	BT_INFO_SRC_8723B_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8723b_1ant
-BT_INFO_SRC_8723B_1ANT_BT_RSP	hal/btc/HalBtc8723b1Ant.h	/^	BT_INFO_SRC_8723B_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8723b_1ant
-BT_INFO_SRC_8723B_1ANT_MAX	hal/btc/HalBtc8723b1Ant.h	/^	BT_INFO_SRC_8723B_1ANT_MAX$/;"	e	enum:bt_info_src_8723b_1ant
-BT_INFO_SRC_8723B_1ANT_WIFI_FW	hal/btc/HalBtc8723b1Ant.h	/^	BT_INFO_SRC_8723B_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8723b_1ant
-BT_INFO_SRC_8723B_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8723b2Ant.h	/^	BT_INFO_SRC_8723B_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8723b_2ant
-BT_INFO_SRC_8723B_2ANT_BT_RSP	hal/btc/HalBtc8723b2Ant.h	/^	BT_INFO_SRC_8723B_2ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8723b_2ant
-BT_INFO_SRC_8723B_2ANT_MAX	hal/btc/HalBtc8723b2Ant.h	/^	BT_INFO_SRC_8723B_2ANT_MAX$/;"	e	enum:bt_info_src_8723b_2ant
-BT_INFO_SRC_8723B_2ANT_WIFI_FW	hal/btc/HalBtc8723b2Ant.h	/^	BT_INFO_SRC_8723B_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8723b_2ant
-BT_INFO_SRC_8723D_1ANT_BT_ACTIVE_SEND	hal/btc/halbtc8723d1ant.h	/^	BT_INFO_SRC_8723D_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8723d_1ant
-BT_INFO_SRC_8723D_1ANT_BT_RSP	hal/btc/halbtc8723d1ant.h	/^	BT_INFO_SRC_8723D_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8723d_1ant
-BT_INFO_SRC_8723D_1ANT_MAX	hal/btc/halbtc8723d1ant.h	/^	BT_INFO_SRC_8723D_1ANT_MAX$/;"	e	enum:bt_info_src_8723d_1ant
-BT_INFO_SRC_8723D_1ANT_WIFI_FW	hal/btc/halbtc8723d1ant.h	/^	BT_INFO_SRC_8723D_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8723d_1ant
-BT_INFO_SRC_8723D_2ANT_BT_ACTIVE_SEND	hal/btc/halbtc8723d2ant.h	/^	BT_INFO_SRC_8723D_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8723d_2ant
-BT_INFO_SRC_8723D_2ANT_BT_RSP	hal/btc/halbtc8723d2ant.h	/^	BT_INFO_SRC_8723D_2ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8723d_2ant
-BT_INFO_SRC_8723D_2ANT_MAX	hal/btc/halbtc8723d2ant.h	/^	BT_INFO_SRC_8723D_2ANT_MAX$/;"	e	enum:bt_info_src_8723d_2ant
-BT_INFO_SRC_8723D_2ANT_WIFI_FW	hal/btc/halbtc8723d2ant.h	/^	BT_INFO_SRC_8723D_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8723d_2ant
-BT_INFO_SRC_8812A_1ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8812a1Ant.h	/^	BT_INFO_SRC_8812A_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8812a_1ant
-BT_INFO_SRC_8812A_1ANT_BT_RSP	hal/btc/HalBtc8812a1Ant.h	/^	BT_INFO_SRC_8812A_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8812a_1ant
-BT_INFO_SRC_8812A_1ANT_MAX	hal/btc/HalBtc8812a1Ant.h	/^	BT_INFO_SRC_8812A_1ANT_MAX$/;"	e	enum:bt_info_src_8812a_1ant
-BT_INFO_SRC_8812A_1ANT_WIFI_FW	hal/btc/HalBtc8812a1Ant.h	/^	BT_INFO_SRC_8812A_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8812a_1ant
-BT_INFO_SRC_8812A_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8812a2Ant.h	/^	BT_INFO_SRC_8812A_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8812a_2ant
-BT_INFO_SRC_8812A_2ANT_BT_RSP	hal/btc/HalBtc8812a2Ant.h	/^	BT_INFO_SRC_8812A_2ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8812a_2ant
-BT_INFO_SRC_8812A_2ANT_MAX	hal/btc/HalBtc8812a2Ant.h	/^	BT_INFO_SRC_8812A_2ANT_MAX$/;"	e	enum:bt_info_src_8812a_2ant
-BT_INFO_SRC_8812A_2ANT_WIFI_FW	hal/btc/HalBtc8812a2Ant.h	/^	BT_INFO_SRC_8812A_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8812a_2ant
-BT_INFO_SRC_8821A_1ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8821a1Ant.h	/^	BT_INFO_SRC_8821A_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8821a_1ant
-BT_INFO_SRC_8821A_1ANT_BT_RSP	hal/btc/HalBtc8821a1Ant.h	/^	BT_INFO_SRC_8821A_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8821a_1ant
-BT_INFO_SRC_8821A_1ANT_MAX	hal/btc/HalBtc8821a1Ant.h	/^	BT_INFO_SRC_8821A_1ANT_MAX$/;"	e	enum:bt_info_src_8821a_1ant
-BT_INFO_SRC_8821A_1ANT_WIFI_FW	hal/btc/HalBtc8821a1Ant.h	/^	BT_INFO_SRC_8821A_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8821a_1ant
-BT_INFO_SRC_8821A_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8821a2Ant.h	/^	BT_INFO_SRC_8821A_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8821a_2ant
-BT_INFO_SRC_8821A_2ANT_BT_RSP	hal/btc/HalBtc8821a2Ant.h	/^	BT_INFO_SRC_8821A_2ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8821a_2ant
-BT_INFO_SRC_8821A_2ANT_MAX	hal/btc/HalBtc8821a2Ant.h	/^	BT_INFO_SRC_8821A_2ANT_MAX$/;"	e	enum:bt_info_src_8821a_2ant
-BT_INFO_SRC_8821A_2ANT_WIFI_FW	hal/btc/HalBtc8821a2Ant.h	/^	BT_INFO_SRC_8821A_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8821a_2ant
-BT_INFO_SRC_8821A_CSR_2ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_INFO_SRC_8821A_CSR_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8821a_csr_2ant
-BT_INFO_SRC_8821A_CSR_2ANT_BT_RSP	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_INFO_SRC_8821A_CSR_2ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8821a_csr_2ant
-BT_INFO_SRC_8821A_CSR_2ANT_MAX	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_INFO_SRC_8821A_CSR_2ANT_MAX$/;"	e	enum:bt_info_src_8821a_csr_2ant
-BT_INFO_SRC_8821A_CSR_2ANT_WIFI_FW	hal/btc/HalBtc8821aCsr2Ant.h	/^	BT_INFO_SRC_8821A_CSR_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8821a_csr_2ant
-BT_INFO_SRC_8821C_1ANT_BT_ACTIVE_SEND	hal/btc/halbtc8821c1ant.h	/^	BT_INFO_SRC_8821C_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8821c_1ant
-BT_INFO_SRC_8821C_1ANT_BT_RSP	hal/btc/halbtc8821c1ant.h	/^	BT_INFO_SRC_8821C_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8821c_1ant
-BT_INFO_SRC_8821C_1ANT_MAX	hal/btc/halbtc8821c1ant.h	/^	BT_INFO_SRC_8821C_1ANT_MAX$/;"	e	enum:bt_info_src_8821c_1ant
-BT_INFO_SRC_8821C_1ANT_WIFI_FW	hal/btc/halbtc8821c1ant.h	/^	BT_INFO_SRC_8821C_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8821c_1ant
-BT_INFO_SRC_8821C_2ANT_BT_ACTIVE_SEND	hal/btc/halbtc8821c2ant.h	/^	BT_INFO_SRC_8821C_2ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8821c_2ant
-BT_INFO_SRC_8821C_2ANT_BT_RSP	hal/btc/halbtc8821c2ant.h	/^	BT_INFO_SRC_8821C_2ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8821c_2ant
-BT_INFO_SRC_8821C_2ANT_MAX	hal/btc/halbtc8821c2ant.h	/^	BT_INFO_SRC_8821C_2ANT_MAX$/;"	e	enum:bt_info_src_8821c_2ant
-BT_INFO_SRC_8821C_2ANT_WIFI_FW	hal/btc/halbtc8821c2ant.h	/^	BT_INFO_SRC_8821C_2ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8821c_2ant
-BT_INFO_SRC_8822B_1ANT_BT_ACTIVE_SEND	hal/btc/HalBtc8822b1Ant.h	/^	BT_INFO_SRC_8822B_1ANT_BT_ACTIVE_SEND		= 0x2,$/;"	e	enum:bt_info_src_8822b_1ant
-BT_INFO_SRC_8822B_1ANT_BT_RSP	hal/btc/HalBtc8822b1Ant.h	/^	BT_INFO_SRC_8822B_1ANT_BT_RSP				= 0x1,$/;"	e	enum:bt_info_src_8822b_1ant
-BT_INFO_SRC_8822B_1ANT_MAX	hal/btc/HalBtc8822b1Ant.h	/^	BT_INFO_SRC_8822B_1ANT_MAX$/;"	e	enum:bt_info_src_8822b_1ant
-BT_INFO_SRC_8822B_1ANT_WIFI_FW	hal/btc/HalBtc8822b1Ant.h	/^	BT_INFO_SRC_8822B_1ANT_WIFI_FW			= 0x0,$/;"	e	enum:bt_info_src_8822b_1ant
-BT_ISSC_3WIRE	include/hal_pg.h	/^	BT_ISSC_3WIRE	= 1,$/;"	e	enum:_BT_CoType
-BT_LO_OP_ENABLE_CFO_TRACKING	include/rtw_bt_mp.h	/^	BT_LO_OP_ENABLE_CFO_TRACKING								= 0x24,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_AFH_MAP_H	hal/hal_btcoex.c	/^	BT_LO_OP_GET_AFH_MAP_H					= 0x20,$/;"	e	enum:_bt_op_code	file:
-BT_LO_OP_GET_AFH_MAP_H	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_AFH_MAP_H										= 0x20,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_AFH_MAP_L	hal/hal_btcoex.c	/^	BT_LO_OP_GET_AFH_MAP_L					= 0x1e,$/;"	e	enum:_bt_op_code	file:
-BT_LO_OP_GET_AFH_MAP_L	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_AFH_MAP_L										= 0x1e,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_AFH_MAP_M	hal/hal_btcoex.c	/^	BT_LO_OP_GET_AFH_MAP_M					= 0x1f,$/;"	e	enum:_bt_op_code	file:
-BT_LO_OP_GET_AFH_MAP_M	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_AFH_MAP_M										= 0x1f,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_AFH_STATUS	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_AFH_STATUS									= 0x21,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_BD_ADDR_H	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_BD_ADDR_H										= 0x10,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_BD_ADDR_L	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_BD_ADDR_L										= 0x0f,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_BT_STATUS	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_BT_STATUS										= 0x0e,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_BT_VERSION	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_BT_VERSION									= 0x00,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_CFO_HDR_QUALITY_H	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_CFO_HDR_QUALITY_H								= 0x1b,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_CFO_HDR_QUALITY_L	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_CFO_HDR_QUALITY_L								= 0x1a,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_RSSI	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_RSSI											= 0x19,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_RX_ERROR_BITS_H	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_RX_ERROR_BITS_H								= 0x18,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_RX_ERROR_BITS_L	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_RX_ERROR_BITS_L								= 0x17,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_RX_PKT_CNT_H	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_RX_PKT_CNT_H									= 0x16,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_RX_PKT_CNT_L	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_RX_PKT_CNT_L									= 0x15,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_TARGET_BD_ADDR_H	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_TARGET_BD_ADDR_H								= 0x1d,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_GET_TARGET_BD_ADDR_L	include/rtw_bt_mp.h	/^	BT_LO_OP_GET_TARGET_BD_ADDR_L								= 0x1c,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_MAX	include/rtw_bt_mp.h	/^	BT_LO_OP_MAX$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_READ_REG	include/rtw_bt_mp.h	/^	BT_LO_OP_READ_REG											= 0x11,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_RESET	include/rtw_bt_mp.h	/^	BT_LO_OP_RESET												= 0x01,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_BD_ADDR_H	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_BD_ADDR_H										= 0x0b,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_BD_ADDR_L	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_BD_ADDR_L										= 0x0a,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_BT_MODE	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_BT_MODE										= 0x03,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_CHNL_TX_GAIN	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_CHNL_TX_GAIN									= 0x04,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_PKT_CNT_H_PKT_INTV	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_PKT_CNT_H_PKT_INTV							= 0x07,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_PKT_CNT_L_PL_TYPE	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_PKT_CNT_L_PL_TYPE								= 0x06,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_PKT_HEADER	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_PKT_HEADER									= 0x08,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_PKT_TYPE_LEN	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_PKT_TYPE_LEN									= 0x05,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_TARGET_BD_ADDR_H	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_TARGET_BD_ADDR_H								= 0x13,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_TARGET_BD_ADDR_L	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_TARGET_BD_ADDR_L								= 0x12,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_THERMAL_METER	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_THERMAL_METER									= 0x23,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_TRACKING_INTERVAL	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_TRACKING_INTERVAL								= 0x22,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_TX_POWER_CALIBRATION	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_TX_POWER_CALIBRATION							= 0x14,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_SET_WHITENCOEFF	include/rtw_bt_mp.h	/^	BT_LO_OP_SET_WHITENCOEFF									= 0x09,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_TEST_CTRL	include/rtw_bt_mp.h	/^	BT_LO_OP_TEST_CTRL											= 0x02,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_WRITE_REG_ADDR	include/rtw_bt_mp.h	/^	BT_LO_OP_WRITE_REG_ADDR									= 0x0c,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_LO_OP_WRITE_REG_VALUE	include/rtw_bt_mp.h	/^	BT_LO_OP_WRITE_REG_VALUE									= 0x0d,$/;"	e	enum:_BT_CTRL_OPCODE_LOWER
-BT_MAX_C2H_LEN	include/rtw_bt_mp.h	201;"	d
-BT_MGNT	include/rtw_btcoex.h	/^} BT_MGNT, *PBT_MGNT;$/;"	t	typeref:struct:_BT_MGNT
-BT_MOTOR_EXT_BE	include/rtw_btcoex.h	/^	BT_MOTOR_EXT_BE		= 0x00, \/* Best Effort. Default. for HCRP, PAN, SDP, RFCOMM-based profiles like FTP,OPP, SPP, DUN, etc. *\/$/;"	e	enum:_BT_TRAFFIC_MODE
-BT_MOTOR_EXT_GUB	include/rtw_btcoex.h	/^	BT_MOTOR_EXT_GUB		= 0X02, \/* Guaranteed Bandwidth. *\/$/;"	e	enum:_BT_TRAFFIC_MODE
-BT_MOTOR_EXT_GUL	include/rtw_btcoex.h	/^	BT_MOTOR_EXT_GUL		= 0x01, \/* Guaranteed Latency. This type of traffic is used e.g. for HID and AVRCP. *\/$/;"	e	enum:_BT_TRAFFIC_MODE
-BT_MOTOR_EXT_GULB	include/rtw_btcoex.h	/^	BT_MOTOR_EXT_GULB	= 0X03  \/* Guaranteed Latency and Bandwidth. for A2DP and VDP. *\/$/;"	e	enum:_BT_TRAFFIC_MODE
-BT_OPCODE_STATUS	include/rtw_bt_mp.h	/^} BT_OPCODE_STATUS, *PBT_OPCODE_STATUS;$/;"	t	typeref:enum:_BT_OPCODE_STATUS
-BT_OP_CODE	hal/hal_btcoex.c	/^} BT_OP_CODE;$/;"	t	typeref:enum:_bt_op_code	file:
-BT_OP_GET_BT_ANT_DET_VAL	hal/hal_btcoex.c	/^	BT_OP_GET_BT_ANT_DET_VAL				= 0x2c,$/;"	e	enum:_bt_op_code	file:
-BT_OP_GET_BT_BLE_SCAN_PARA	hal/hal_btcoex.c	/^	BT_OP_GET_BT_BLE_SCAN_PARA				= 0x2d,$/;"	e	enum:_bt_op_code	file:
-BT_OP_GET_BT_BLE_SCAN_TYPE	hal/hal_btcoex.c	/^	BT_OP_GET_BT_BLE_SCAN_TYPE				= 0x2e,$/;"	e	enum:_bt_op_code	file:
-BT_OP_GET_BT_COEX_SUPPORTED_FEATURE	hal/hal_btcoex.c	/^	BT_OP_GET_BT_COEX_SUPPORTED_FEATURE		= 0x2a,$/;"	e	enum:_bt_op_code	file:
-BT_OP_GET_BT_COEX_SUPPORTED_VERSION	hal/hal_btcoex.c	/^	BT_OP_GET_BT_COEX_SUPPORTED_VERSION		= 0x2b,$/;"	e	enum:_bt_op_code	file:
-BT_OP_GET_BT_VERSION	hal/hal_btcoex.c	/^	BT_OP_GET_BT_VERSION					= 0x00,$/;"	e	enum:_bt_op_code	file:
-BT_OP_MAX	hal/hal_btcoex.c	/^	BT_OP_MAX$/;"	e	enum:_bt_op_code	file:
-BT_OP_READ_REG	hal/hal_btcoex.c	/^	BT_OP_READ_REG							= 0x11,$/;"	e	enum:_bt_op_code	file:
-BT_OP_STATUS_ERROR_PARAMETER	include/rtw_bt_mp.h	/^	BT_OP_STATUS_ERROR_PARAMETER							= 0x03,$/;"	e	enum:_BT_OPCODE_STATUS
-BT_OP_STATUS_MAX	include/rtw_bt_mp.h	/^	BT_OP_STATUS_MAX$/;"	e	enum:_BT_OPCODE_STATUS
-BT_OP_STATUS_SUCCESS	include/rtw_bt_mp.h	/^	BT_OP_STATUS_SUCCESS									= 0x00, \/* Success *\/$/;"	e	enum:_BT_OPCODE_STATUS
-BT_OP_STATUS_UNKNOWN_OPCODE	include/rtw_bt_mp.h	/^	BT_OP_STATUS_UNKNOWN_OPCODE								= 0x02,$/;"	e	enum:_BT_OPCODE_STATUS
-BT_OP_STATUS_VERSION_MISMATCH	include/rtw_bt_mp.h	/^	BT_OP_STATUS_VERSION_MISMATCH							= 0x01,$/;"	e	enum:_BT_OPCODE_STATUS
-BT_OP_WRITE_REG_ADDR	hal/hal_btcoex.c	/^	BT_OP_WRITE_REG_ADDR					= 0x0c,$/;"	e	enum:_bt_op_code	file:
-BT_OP_WRITE_REG_VALUE	hal/hal_btcoex.c	/^	BT_OP_WRITE_REG_VALUE					= 0x0d,$/;"	e	enum:_bt_op_code	file:
-BT_Operation	hal/hal_btcoex.c	217;"	d	file:
-BT_PROFILE_A2DP	include/rtw_btcoex.h	/^	BT_PROFILE_A2DP,$/;"	e	enum:_BT_TRAFFIC_MODE_PROFILE
-BT_PROFILE_HID	include/rtw_btcoex.h	/^	BT_PROFILE_HID,$/;"	e	enum:_BT_TRAFFIC_MODE_PROFILE
-BT_PROFILE_NONE	include/rtw_btcoex.h	/^	BT_PROFILE_NONE,$/;"	e	enum:_BT_TRAFFIC_MODE_PROFILE
-BT_PROFILE_PAN	include/rtw_btcoex.h	/^	BT_PROFILE_PAN	,$/;"	e	enum:_BT_TRAFFIC_MODE_PROFILE
-BT_PROFILE_SCO	include/rtw_btcoex.h	/^	BT_PROFILE_SCO$/;"	e	enum:_BT_TRAFFIC_MODE_PROFILE
-BT_PrintData	hal/btc/HalBtcOutSrc.h	16;"	d
-BT_REG_BLUEWIZE	include/rtw_bt_mp.h	/^	BT_REG_BLUEWIZE						= 2,$/;"	e	enum:_BT_REG_TYPE
-BT_REG_LE	include/rtw_bt_mp.h	/^	BT_REG_LE								= 4,$/;"	e	enum:_BT_REG_TYPE
-BT_REG_MAX	include/rtw_bt_mp.h	/^	BT_REG_MAX$/;"	e	enum:_BT_REG_TYPE
-BT_REG_MODEM	include/rtw_bt_mp.h	/^	BT_REG_MODEM							= 1,$/;"	e	enum:_BT_REG_TYPE
-BT_REG_RF	include/rtw_bt_mp.h	/^	BT_REG_RF								= 0,$/;"	e	enum:_BT_REG_TYPE
-BT_REG_TYPE	include/rtw_bt_mp.h	/^} BT_REG_TYPE, *PBT_REG_TYPE;$/;"	t	typeref:enum:_BT_REG_TYPE
-BT_REG_VENDOR	include/rtw_bt_mp.h	/^	BT_REG_VENDOR							= 3,$/;"	e	enum:_BT_REG_TYPE
-BT_REPORT_CFO_HDR_QUALITY	include/rtw_bt_mp.h	/^	BT_REPORT_CFO_HDR_QUALITY				= 3,$/;"	e	enum:_BT_REPORT_TYPE
-BT_REPORT_CONNECT_TARGET_BD_ADDR	include/rtw_bt_mp.h	/^	BT_REPORT_CONNECT_TARGET_BD_ADDR		= 4,$/;"	e	enum:_BT_REPORT_TYPE
-BT_REPORT_MAX	include/rtw_bt_mp.h	/^	BT_REPORT_MAX$/;"	e	enum:_BT_REPORT_TYPE
-BT_REPORT_RSSI	include/rtw_bt_mp.h	/^	BT_REPORT_RSSI							= 2,$/;"	e	enum:_BT_REPORT_TYPE
-BT_REPORT_RX_ERROR_BITS	include/rtw_bt_mp.h	/^	BT_REPORT_RX_ERROR_BITS				= 1,$/;"	e	enum:_BT_REPORT_TYPE
-BT_REPORT_RX_PACKET_CNT	include/rtw_bt_mp.h	/^	BT_REPORT_RX_PACKET_CNT				= 0,$/;"	e	enum:_BT_REPORT_TYPE
-BT_REPORT_TYPE	include/rtw_bt_mp.h	/^} BT_REPORT_TYPE, *PBT_REPORT_TYPE;$/;"	t	typeref:enum:_BT_REPORT_TYPE
-BT_REQ_CMD	include/rtw_bt_mp.h	/^} BT_REQ_CMD, *PBT_REQ_CMD;$/;"	t	typeref:struct:_BT_REQ_CMD
-BT_RSP_CMD	include/rtw_bt_mp.h	/^} BT_RSP_CMD, *PBT_RSP_CMD;$/;"	t	typeref:struct:_BT_RSP_CMD
-BT_RSSI	include/rtw_btcoex.h	/^	s1Byte					BT_RSSI;$/;"	m	struct:_HCI_LINK_INFO
-BT_RTL8192E	include/hal_pg.h	/^	BT_RTL8192E		= 9,$/;"	e	enum:_BT_CoType
-BT_RTL8703B	include/hal_pg.h	/^	BT_RTL8703B		= 12,$/;"	e	enum:_BT_CoType
-BT_RTL8723A	include/hal_pg.h	/^	BT_RTL8723A		= 6,$/;"	e	enum:_BT_CoType
-BT_RTL8723B	include/hal_pg.h	/^	BT_RTL8723B		= 8,$/;"	e	enum:_BT_CoType
-BT_RTL8723D	include/hal_pg.h	/^	BT_RTL8723D		= 14,$/;"	e	enum:_BT_CoType
-BT_RTL8756	include/hal_pg.h	/^	BT_RTL8756		= 5,$/;"	e	enum:_BT_CoType
-BT_RTL8812A	include/hal_pg.h	/^	BT_RTL8812A		= 11,$/;"	e	enum:_BT_CoType
-BT_RTL8814A	include/hal_pg.h	/^	BT_RTL8814A		= 10,$/;"	e	enum:_BT_CoType
-BT_RTL8821	include/hal_pg.h	/^	BT_RTL8821		= 7,$/;"	e	enum:_BT_CoType
-BT_RTL8821C	include/hal_pg.h	/^	BT_RTL8821C		= 15$/;"	e	enum:_BT_CoType
-BT_RTL8822B	include/hal_pg.h	/^	BT_RTL8822B		= 13,$/;"	e	enum:_BT_CoType
-BT_RadioShared	include/hal_pg.h	/^} BT_RadioShared, *PBT_RadioShared;$/;"	t	typeref:enum:_BT_RadioShared
-BT_Radio_Individual	include/hal_pg.h	/^	BT_Radio_Individual	= 1,$/;"	e	enum:_BT_RadioShared
-BT_Radio_Shared	include/hal_pg.h	/^	BT_Radio_Shared	= 0,$/;"	e	enum:_BT_RadioShared
-BT_SET_GENERAL	include/rtw_bt_mp.h	/^} BT_SET_GENERAL, *PBT_SET_GENERAL;$/;"	t	typeref:enum:_BT_SET_GENERAL
-BT_SET_THERMAL_METER	include/rtw_bt_mp.h	/^	BT_SET_THERMAL_METER									= 0x05,$/;"	e	enum:_BT_SET_GENERAL
-BT_SET_TRACKING_INTERVAL	include/rtw_bt_mp.h	/^	BT_SET_TRACKING_INTERVAL								= 0x04,$/;"	e	enum:_BT_SET_GENERAL
-BT_STATE_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^}BT_STATE_8723A_1ANT, *PBT_STATE_8723A_1ANT;$/;"	t	typeref:enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_ACL_ONLY_BUSY	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_ACL_ONLY_BUSY		= 4,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_ACL_SCO_BUSY	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_ACL_SCO_BUSY			= 6,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_CONNECT_IDLE	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_CONNECT_IDLE		= 2,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_DISABLED	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_DISABLED				= 0,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_HID_BUSY	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_HID_BUSY				= 7,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_HID_SCO_BUSY	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_HID_SCO_BUSY			= 8,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_INQ_OR_PAG	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_INQ_OR_PAG			= 3,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_MAX	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_MAX$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_NO_CONNECTION	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_NO_CONNECTION		= 1,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATE_8723A_1ANT_SCO_ONLY_BUSY	hal/btc/HalBtc8723a1Ant.h	/^	BT_STATE_8723A_1ANT_SCO_ONLY_BUSY		= 5,$/;"	e	enum:_BT_STATE_8723A_1ANT
-BT_STATUS_BT_OP_SUCCESS	include/rtw_btcoex.h	/^	BT_STATUS_BT_OP_SUCCESS							= 0x01, \/* bt fw op execution success *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_BT_STACK_NOT_BIND	include/rtw_btcoex.h	/^	BT_STATUS_BT_STACK_NOT_BIND						= 0x18, \/* stack not bind wifi driver *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_BT_STACK_NOT_SUPPORT	include/rtw_btcoex.h	/^	BT_STATUS_BT_STACK_NOT_SUPPORT					= 0x16, \/* stack version not support this. *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_BT_STACK_NO_RSP	include/rtw_btcoex.h	/^	BT_STATUS_BT_STACK_NO_RSP						= 0x19, \/* stack doesn't have any rsp. *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_BT_STACK_OP_SUCCESS	include/rtw_btcoex.h	/^	BT_STATUS_BT_STACK_OP_SUCCESS					= 0x15, \/* bt stack op execution success *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_BT_STACK_SEND_HCI_EVENT_FAIL	include/rtw_btcoex.h	/^	BT_STATUS_BT_STACK_SEND_HCI_EVENT_FAIL			= 0x17, \/* send hci event fail *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_C2H_REQNUM_MISMATCH	include/rtw_btcoex.h	/^	BT_STATUS_C2H_REQNUM_MISMATCH					= 0x08, \/* bt fw wrong rsp *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_C2H_SUCCESS	include/rtw_btcoex.h	/^	BT_STATUS_C2H_SUCCESS							= 0x07, \/* C2h success *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_ERROR_PARAMETER	hal/hal_btcoex.c	/^	BT_STATUS_ERROR_PARAMETER$/;"	e	enum:_bt_c2h_status	file:
-BT_STATUS_H2C_BT_NO_RSP	include/rtw_btcoex.h	/^	BT_STATUS_H2C_BT_NO_RSP							= 0x06, \/* H2c sent, bt no rsp *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_H2C_FAIL	include/rtw_btcoex.h	/^	BT_STATUS_H2C_FAIL								= 0x03, \/* H2c fail *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_H2C_LENGTH_EXCEEDED	include/rtw_btcoex.h	/^	BT_STATUS_H2C_LENGTH_EXCEEDED					= 0x04, \/* H2c command length exceeded *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_H2C_SUCCESS	include/rtw_btcoex.h	/^	BT_STATUS_H2C_SUCCESS							= 0x02, \/* H2c success *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_H2C_TIMTOUT	include/rtw_btcoex.h	/^	BT_STATUS_H2C_TIMTOUT							= 0x05, \/* H2c timeout *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_MAX	include/rtw_btcoex.h	/^	BT_STATUS_MAX$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_NOT_IMPLEMENT	include/rtw_btcoex.h	/^	BT_STATUS_NOT_IMPLEMENT						= 0x14, \/* op code not implemented yet *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_OK	hal/hal_btcoex.c	/^	BT_STATUS_OK = 0,$/;"	e	enum:_bt_c2h_status	file:
-BT_STATUS_OPCODE_L_VERSION_MISMATCH	include/rtw_btcoex.h	/^	BT_STATUS_OPCODE_L_VERSION_MISMATCH				= 0x0a, \/* Lower layer OP code version mismatch. *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_OPCODE_U_VERSION_MISMATCH	include/rtw_btcoex.h	/^	BT_STATUS_OPCODE_U_VERSION_MISMATCH				= 0x08, \/* Upper layer OP code version mismatch. *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_PARAMETER_FORMAT_ERROR_L	include/rtw_btcoex.h	/^	BT_STATUS_PARAMETER_FORMAT_ERROR_L				= 0x0e, \/* bt fw parameter format is not consistency *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_PARAMETER_FORMAT_ERROR_U	include/rtw_btcoex.h	/^	BT_STATUS_PARAMETER_FORMAT_ERROR_U				= 0x0d, \/* Wrong parameters sent by upper layer. *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_PARAMETER_OUT_OF_RANGE_L	include/rtw_btcoex.h	/^	BT_STATUS_PARAMETER_OUT_OF_RANGE_L				= 0x10, \/* bt fw parameter value is out of range *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_PARAMETER_OUT_OF_RANGE_U	include/rtw_btcoex.h	/^	BT_STATUS_PARAMETER_OUT_OF_RANGE_U				= 0x0f, \/* uppery layer parameter value is out of range *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_SUCCESS	include/rtw_btcoex.h	/^	BT_STATUS_SUCCESS								= 0x00, \/* Success *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_UNKNOWN_OPCODE	hal/hal_btcoex.c	/^	BT_STATUS_UNKNOWN_OPCODE,$/;"	e	enum:_bt_c2h_status	file:
-BT_STATUS_UNKNOWN_OPCODE_L	include/rtw_btcoex.h	/^	BT_STATUS_UNKNOWN_OPCODE_L						= 0x0c, \/* Unknown Lower layer OP code *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_UNKNOWN_OPCODE_U	include/rtw_btcoex.h	/^	BT_STATUS_UNKNOWN_OPCODE_U						= 0x0b, \/* Unknown Upper layer OP code *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_UNKNOWN_STATUS_H	include/rtw_btcoex.h	/^	BT_STATUS_UNKNOWN_STATUS_H						= 0x12, \/* driver need to do error handle or not handle-well. *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_UNKNOWN_STATUS_L	include/rtw_btcoex.h	/^	BT_STATUS_UNKNOWN_STATUS_L						= 0x11, \/* bt returned an defined status code *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_STATUS_VERSION_MISMATCH	hal/hal_btcoex.c	/^	BT_STATUS_VERSION_MISMATCH,$/;"	e	enum:_bt_c2h_status	file:
-BT_STATUS_WRONG_LEVEL	include/rtw_btcoex.h	/^	BT_STATUS_WRONG_LEVEL							= 0x13, \/* should be under passive level *\/$/;"	e	enum:_BT_CTRL_STATUS
-BT_SUPPORT	hal/btc/Mp_Precomp.h	58;"	d
-BT_SUPPORT	hal/btc/Mp_Precomp.h	62;"	d
-BT_SUPPORT	hal/phydm/phydm_features.h	135;"	d
-BT_SendEventExtBtCoexControl	include/rtw_btcoex.h	424;"	d
-BT_SendEventExtBtInfoControl	include/rtw_btcoex.h	425;"	d
-BT_TMP_BUF_SIZE	hal/btc/Mp_Precomp.h	26;"	d
-BT_TRAFFIC_MODE	include/rtw_btcoex.h	/^} BT_TRAFFIC_MODE;$/;"	t	typeref:enum:_BT_TRAFFIC_MODE
-BT_TRAFFIC_MODE_PROFILE	include/rtw_btcoex.h	/^} BT_TRAFFIC_MODE_PROFILE;$/;"	t	typeref:enum:_BT_TRAFFIC_MODE_PROFILE
-BT_TXRX_PARAMETERS	include/rtw_bt_mp.h	/^} BT_TXRX_PARAMETERS, *PBT_TXRX_PARAMETERS;$/;"	t	typeref:struct:_BT_TXRX_PARAMETERS
-BT_UP_OP_BT_GET_GENERAL	include/rtw_bt_mp.h	/^	BT_UP_OP_BT_GET_GENERAL								= 0x04,$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_UP_OP_BT_READY	include/rtw_bt_mp.h	/^	BT_UP_OP_BT_READY										= 0x00,$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_UP_OP_BT_SET_GENERAL	include/rtw_bt_mp.h	/^	BT_UP_OP_BT_SET_GENERAL								= 0x03,$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_UP_OP_BT_SET_MODE	include/rtw_bt_mp.h	/^	BT_UP_OP_BT_SET_MODE									= 0x01,$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_UP_OP_BT_SET_TX_RX_PARAMETER	include/rtw_bt_mp.h	/^	BT_UP_OP_BT_SET_TX_RX_PARAMETER						= 0x02,$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_UP_OP_BT_TEST_CTRL	include/rtw_bt_mp.h	/^	BT_UP_OP_BT_TEST_CTRL									= 0x05,$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_UP_OP_MAX	include/rtw_bt_mp.h	/^	BT_UP_OP_MAX$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_UP_OP_TEST_BT	include/rtw_bt_mp.h	/^	BT_UP_OP_TEST_BT										= 0x06,$/;"	e	enum:_BT_CTRL_OPCODE_UPPER
-BT_attend	include/rtw_btcoex.h	/^	u8 BT_attend;$/;"	m	struct:bt_coex_info
-BUSY_TRAFFIC_SCAN_DENY_PERIOD	include/rtw_mlme_ext.h	1056;"	d
-BUSY_TRAFFIC_SCAN_DENY_PERIOD	include/rtw_mlme_ext.h	1058;"	d
-BW	hal/phydm/phydm_beamforming.h	/^	CHANNEL_WIDTH				BW;$/;"	m	struct:_RT_BEAMFORM_STAINFO
-BW	hal/phydm/txbf/halcomtxbf.h	/^	u1Byte				BW;$/;"	m	struct:_HAL_TXBF_INFO
-BW160_Diff	include/hal_pg.h	/^	s8 BW160_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo5G
-BW20	include/rtw_mlme_ext.h	/^	enum { BW20, BW40PLUS, BW40MINUS } bw;$/;"	e	enum:p2p_oper_class_map::__anon53
-BW20_24G_Diff	include/hal_data.h	/^	s8	BW20_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-BW20_5G_Diff	include/hal_data.h	/^	s8	BW20_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-BW20_Diff	include/hal_pg.h	/^	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo24G
-BW20_Diff	include/hal_pg.h	/^	s8 BW20_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo5G
-BW40MINUS	include/rtw_mlme_ext.h	/^	enum { BW20, BW40PLUS, BW40MINUS } bw;$/;"	e	enum:p2p_oper_class_map::__anon53
-BW40PLUS	include/rtw_mlme_ext.h	/^	enum { BW20, BW40PLUS, BW40MINUS } bw;$/;"	e	enum:p2p_oper_class_map::__anon53
-BW40_24G_Diff	include/hal_data.h	/^	s8	BW40_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-BW40_5G_Diff	include/hal_data.h	/^	s8	BW40_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-BW40_Diff	include/hal_pg.h	/^	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo24G
-BW40_Diff	include/hal_pg.h	/^	s8 BW40_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo5G
-BW80_5G_Diff	include/hal_data.h	/^	s8	BW80_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-BW80_Diff	include/hal_pg.h	/^	s8 BW80_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo5G
-BWMapping_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^BWMapping_8723D($/;"	f
-BW_CAP_10M	include/hal_com.h	315;"	d
-BW_CAP_160M	include/hal_com.h	319;"	d
-BW_CAP_20M	include/hal_com.h	316;"	d
-BW_CAP_40M	include/hal_com.h	317;"	d
-BW_CAP_5M	include/hal_com.h	314;"	d
-BW_CAP_80M	include/hal_com.h	318;"	d
-BW_CAP_80_80M	include/hal_com.h	320;"	d
-BW_CAP_8188F	include/rtl8188f_spec.h	300;"	d
-BW_CAP_8192E	include/rtl8192e_spec.h	326;"	d
-BW_CAP_8703B	include/rtl8703b_spec.h	477;"	d
-BW_CAP_8723B	include/rtl8723b_spec.h	293;"	d
-BW_CAP_8723D	include/rtl8723d_spec.h	454;"	d
-BW_CAP_8812A	include/rtl8812a_spec.h	269;"	d
-BW_CAP_8814A	include/rtl8814a_spec.h	648;"	d
-BW_CAP_8821A	include/rtl8821a_spec.h	105;"	d
-BW_CAP_88E	include/rtl8188e_spec.h	155;"	d
-BW_CAP_BIT_NUM	include/hal_com.h	321;"	d
-BW_MODE_2G	include/drv_types.h	431;"	d
-BW_MODE_5G	include/drv_types.h	432;"	d
-BW_OPMODE_20MHZ	include/hal_com_reg.h	804;"	d
-BW_OPMODE_5G	include/hal_com_reg.h	805;"	d
-B_CUT_VERSION	include/HalVerDef.h	/^	B_CUT_VERSION		=	1,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-BackUp_BB_REG_4_2nd_CCA	include/hal_data.h	/^	u32				BackUp_BB_REG_4_2nd_CCA[3];$/;"	m	struct:hal_com_data
-BackUp_IG_REG_4_Chnl_Section	include/hal_data.h	/^	u8 BackUp_IG_REG_4_Chnl_Section[4]; \/*{A,B,C,D}*\/$/;"	m	struct:hal_com_data
-BackoffVal	hal/phydm/phydm_dig.h	/^	s1Byte		BackoffVal;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-BackoffVal_range_max	hal/phydm/phydm_dig.h	/^	s1Byte		BackoffVal_range_max;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-BackoffVal_range_min	hal/phydm/phydm_dig.h	/^	s1Byte		BackoffVal_range_min;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-BackupIGValue	hal/phydm/phydm_dig.h	/^	u1Byte		BackupIGValue;		\/\/MP DIG$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-BandSet	include/hal_data.h	/^	BAND_TYPE		BandSet;$/;"	m	struct:hal_com_data
-BandWidth	hal/phydm/phydm.h	/^	u1Byte		BandWidth:2;$/;"	m	struct:_ODM_Phy_Status_Info_
-BandWidth	hal/phydm/phydm.h	/^	u1Byte		BandWidth;$/;"	m	struct:_ODM_Phy_Status_Info_
-BandWidth	include/rtw_mp.h	/^	u8			BandWidth:3;		\/* 0: 20 1:40 2:80Mhz *\/$/;"	m	struct:_RT_PMAC_TX_INFO
-BandWidth	include/rtw_recv.h	/^	u8			BandWidth:2;$/;"	m	struct:phy_info
-BandWidth	include/rtw_recv.h	/^	u8			BandWidth;$/;"	m	struct:phy_info
-Band_Useful_Num	hal/phydm/rtchnlplan.h	/^	u1Byte				Band_Useful_Num;$/;"	m	struct:_RT_CHANNEL_PLAN_MAXPWR
-BankAvailBytes	include/rtw_efuse.h	/^	const u16  BankAvailBytes;$/;"	m	struct:_EFUSE_HAL
-BankNum_BT	include/rtw_efuse.h	/^	const u16  BankNum_BT;$/;"	m	struct:_EFUSE_HAL
-BankNum_WiFi	include/rtw_efuse.h	/^	const u16  BankNum_WiFi;$/;"	m	struct:_EFUSE_HAL
-BankSize	include/rtw_efuse.h	/^	const u16  BankSize;$/;"	m	struct:_EFUSE_HAL
-BaseAddresses	include/drv_types_pci.h	/^			u32	BaseAddresses[6];$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-BaseBand_Config_AGC_TAB	include/hal_phy.h	/^	BaseBand_Config_AGC_TAB = 1,			\/* Radio Path B *\/$/;"	e	enum:_BaseBand_Config_Type
-BaseBand_Config_AGC_TAB_2G	include/hal_phy.h	/^	BaseBand_Config_AGC_TAB_2G = 2,$/;"	e	enum:_BaseBand_Config_Type
-BaseBand_Config_AGC_TAB_5G	include/hal_phy.h	/^	BaseBand_Config_AGC_TAB_5G = 3,$/;"	e	enum:_BaseBand_Config_Type
-BaseBand_Config_PHY_REG	include/hal_phy.h	/^	BaseBand_Config_PHY_REG = 0,			\/* Radio Path A *\/$/;"	e	enum:_BaseBand_Config_Type
-BaseBand_Config_PHY_REG_PG	include/hal_phy.h	/^	BaseBand_Config_PHY_REG_PG$/;"	e	enum:_BaseBand_Config_Type
-BaseBand_Config_Type	include/hal_phy.h	/^} BaseBand_Config_Type, *PBaseBand_Config_Type;$/;"	t	typeref:enum:_BaseBand_Config_Type
-BaseClass	include/drv_types_pci.h	/^	u8	BaseClass;$/;"	m	struct:_PCI_COMMON_CONFIG
-BasicRateSet	include/hal_data.h	/^	u16				BasicRateSet;$/;"	m	struct:hal_com_data
-BbSwingFlagCck	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN			BbSwingFlagCck;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingFlagCck	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN			BbSwingFlagCck;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingFlagCck	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN			BbSwingFlagCck;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingFlagOfdm	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN			BbSwingFlagOfdm;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingFlagOfdm	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN			BbSwingFlagOfdm;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingFlagOfdm	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN			BbSwingFlagOfdm;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCck	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			BbSwingIdxCck;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCck	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			BbSwingIdxCck;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCck	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			BbSwingIdxCck;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCckBase	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			BbSwingIdxCckBase;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCckBase	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			BbSwingIdxCckBase;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCckBase	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			BbSwingIdxCckBase;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCckCurrent	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			BbSwingIdxCckCurrent;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCckCurrent	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			BbSwingIdxCckCurrent;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxCckCurrent	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			BbSwingIdxCckCurrent;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdm	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			BbSwingIdxOfdm[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdm	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			BbSwingIdxOfdm[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdm	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			BbSwingIdxOfdm[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmBase	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			BbSwingIdxOfdmBase;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmBase	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			BbSwingIdxOfdmBase[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmBase	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			BbSwingIdxOfdmBase;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmBase	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			BbSwingIdxOfdmBase[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmBase	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			BbSwingIdxOfdmBase;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmBase	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			BbSwingIdxOfdmBase[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmCurrent	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			BbSwingIdxOfdmCurrent;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmCurrent	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			BbSwingIdxOfdmCurrent;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingIdxOfdmCurrent	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			BbSwingIdxOfdmCurrent;$/;"	m	struct:ODM_RF_Calibration_Structure
-BbSwingOffsetA	hal/phydm/phydm.h	/^	u4Byte			BbSwingOffsetA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-BbSwingOffsetB	hal/phydm/phydm.h	/^	u4Byte			BbSwingOffsetB;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-BcnInfo	include/wlan_bssdef.h	/^	WLAN_BCN_INFO	BcnInfo;$/;"	m	struct:wlan_network
-BeaconInterval	include/wlan_bssdef.h	/^	USHORT  BeaconInterval;$/;"	m	struct:_NDIS_802_11_FIXED_IEs
-BeaconPeriod	include/wlan_bssdef.h	/^	ULONG           BeaconPeriod;       \/* units are Kusec *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION
-BeamformCap	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_CAP			BeamformCap;$/;"	m	struct:_RT_BEAMFORMING_INFO
-BeamformCap	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_CAP			BeamformCap;$/;"	m	struct:_RT_BEAMFORM_STAINFO
-BeamformEntryCap	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_CAP			BeamformEntryCap;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-BeamformEntryCap	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_CAP		BeamformEntryCap;$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-BeamformEntryState	hal/phydm/phydm_beamforming.h	/^	BEAMFORMING_ENTRY_STATE	BeamformEntryState;	$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-BeamformSTAinfo	hal/phydm/phydm_beamforming.h	/^	RT_BEAMFORM_STAINFO		BeamformSTAinfo;$/;"	m	struct:_RT_BEAMFORMING_INFO
-BeamformeeCurIdx	hal/phydm/phydm_beamforming.h	/^	u1Byte					BeamformeeCurIdx;$/;"	m	struct:_RT_BEAMFORMING_INFO
-BeamformeeEntry	hal/phydm/phydm_beamforming.h	/^	RT_BEAMFORMEE_ENTRY		BeamformeeEntry[BEAMFORMEE_ENTRY_NUM];$/;"	m	struct:_RT_BEAMFORMING_INFO
-BeamformerEntry	hal/phydm/phydm_beamforming.h	/^	RT_BEAMFORMER_ENTRY		BeamformerEntry[BEAMFORMER_ENTRY_NUM];$/;"	m	struct:_RT_BEAMFORMING_INFO
-BeamformingControl_V1	hal/phydm/phydm_beamforming.c	/^BeamformingControl_V1($/;"	f
-BeamformingControl_V1	hal/phydm/phydm_beamforming.h	356;"	d
-BeamformingControl_V2	hal/phydm/phydm_beamforming.h	357;"	d
-BeamformingInfo	hal/phydm/phydm.h	/^	RT_BEAMFORMING_INFO BeamformingInfo;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-BeamformingOidInfo	hal/phydm/phydm_beamforming.h	/^	RT_BEAMFORMING_OID_INFO	BeamformingOidInfo;$/;"	m	struct:_RT_BEAMFORMING_INFO
-BeamformingStart_FW	hal/phydm/phydm_beamforming.c	/^BeamformingStart_FW($/;"	f
-BeamformingStart_SW	hal/phydm/phydm_beamforming.c	/^BeamformingStart_SW($/;"	f
-BeamformingStart_V1	hal/phydm/phydm_beamforming.c	/^BeamformingStart_V1($/;"	f
-BeamformingTimer	hal/phydm/phydm_beamforming.h	/^	RT_TIMER					BeamformingTimer;$/;"	m	struct:_RT_BEAMFORMING_INFO
-Beamforming_AddBFeeEntry	hal/phydm/phydm_beamforming.c	/^Beamforming_AddBFeeEntry($/;"	f
-Beamforming_AddBFerEntry	hal/phydm/phydm_beamforming.c	/^Beamforming_AddBFerEntry($/;"	f
-Beamforming_CheckSoundingSuccess	hal/phydm/phydm_beamforming.c	/^Beamforming_CheckSoundingSuccess($/;"	f
-Beamforming_DeInitEntry	hal/phydm/phydm_beamforming.c	/^Beamforming_DeInitEntry($/;"	f
-Beamforming_DymPeriod	hal/phydm/phydm_beamforming.c	/^Beamforming_DymPeriod($/;"	f
-Beamforming_End_FW	hal/phydm/phydm_beamforming.h	355;"	d
-Beamforming_Enter	hal/phydm/phydm_beamforming.c	/^Beamforming_Enter($/;"	f
-Beamforming_Enter	hal/phydm/phydm_beamforming.h	353;"	d
-Beamforming_GetHTNDPTxRate	hal/phydm/txbf/phydm_hal_txbf_api.c	/^Beamforming_GetHTNDPTxRate($/;"	f
-Beamforming_GetNDPAFrame	hal/phydm/txbf/haltxbfinterface.c	/^Beamforming_GetNDPAFrame($/;"	f
-Beamforming_GetNDPAFrame	hal/phydm/txbf/haltxbfinterface.h	146;"	d
-Beamforming_GetReportFrame	hal/phydm/txbf/haltxbfinterface.c	/^Beamforming_GetReportFrame($/;"	f
-Beamforming_GetReportFrame	hal/phydm/txbf/haltxbfinterface.h	148;"	d
-Beamforming_GetReportFrame	hal/phydm/txbf/haltxbfinterface.h	150;"	d
-Beamforming_GetVHTGIDMgntFrame	hal/phydm/txbf/haltxbfinterface.c	/^Beamforming_GetVHTGIDMgntFrame($/;"	f
-Beamforming_GetVHTGIDMgntFrame	hal/phydm/txbf/haltxbfinterface.h	151;"	d
-Beamforming_GetVHTGIDMgntFrame	hal/phydm/txbf/haltxbfinterface.h	83;"	d
-Beamforming_GetVHTNDPTxRate	hal/phydm/txbf/phydm_hal_txbf_api.c	/^Beamforming_GetVHTNDPTxRate($/;"	f
-Beamforming_GidPAid	hal/phydm/phydm_beamforming.h	351;"	d
-Beamforming_GidPAid	hal/phydm/txbf/haltxbfinterface.c	/^Beamforming_GidPAid($/;"	f
-Beamforming_InitEntry	hal/phydm/phydm_beamforming.c	/^Beamforming_InitEntry($/;"	f
-Beamforming_Leave	hal/phydm/phydm_beamforming.c	/^Beamforming_Leave($/;"	f
-Beamforming_Leave	hal/phydm/phydm_beamforming.h	354;"	d
-Beamforming_SWTimerCallback	hal/phydm/phydm_beamforming.c	/^Beamforming_SWTimerCallback($/;"	f
-Beamforming_SendHTNDPAPacket	hal/phydm/phydm_beamforming.c	/^Beamforming_SendHTNDPAPacket($/;"	f
-Beamforming_SendVHTNDPAPacket	hal/phydm/phydm_beamforming.c	/^Beamforming_SendVHTNDPAPacket($/;"	f
-Beamforming_TimerCallback	hal/phydm/phydm_beamforming.c	/^Beamforming_TimerCallback($/;"	f
-Beamforming_TimerCallback	hal/phydm/phydm_beamforming.h	359;"	d
-Beamforming_Watchdog	hal/phydm/phydm_beamforming.h	362;"	d
-Beamforming_caps	include/wifi.h	/^			unsigned int	Beamforming_caps;$/;"	m	struct:HT_caps_element::__anon54::__anon55
-Beamforming_caps	include/wifi.h	/^			unsigned int	Beamforming_caps;$/;"	m	struct:HT_caps_element::__anon56::__anon57
-BlinkCounter	include/hal_com_led.h	/^	u8					BlinkCounter; \/* Added for turn off overlap led after blinking a while, by page, 20120821 *\/$/;"	m	struct:_LED_USB
-BlinkHandler	hal/led/hal_sdio_led.c	/^void BlinkHandler(PLED_SDIO	pLed)$/;"	f
-BlinkTimer	include/hal_com_led.h	/^	_timer				BlinkTimer; \/* Timer object for led blinking. *\/$/;"	m	struct:_LED_SDIO
-BlinkTimer	include/hal_com_led.h	/^	_timer				BlinkTimer; \/* Timer object for led blinking. *\/$/;"	m	struct:_LED_USB
-BlinkTimer	include/hal_com_led.h	/^	_timer			BlinkTimer; \/* Timer object for led blinking. *\/$/;"	m	struct:_LED_PCIE
-BlinkTimerCallback	hal/led/hal_sdio_led.c	/^void BlinkTimerCallback(void *data)$/;"	f
-BlinkTimes	include/hal_com_led.h	/^	u32					BlinkTimes; \/* Number of times to toggle led state for blinking. *\/$/;"	m	struct:_LED_SDIO
-BlinkTimes	include/hal_com_led.h	/^	u32					BlinkTimes; \/* Number of times to toggle led state for blinking. *\/$/;"	m	struct:_LED_USB
-BlinkTimes	include/hal_com_led.h	/^	u32				BlinkTimes; \/* Number of times to toggle led state for blinking. *\/$/;"	m	struct:_LED_PCIE
-BlinkWorkItem	include/hal_com_led.h	/^	_workitem			BlinkWorkItem; \/* Workitem used by BlinkTimer to manipulate H\/W to blink LED. *\/$/;"	m	struct:_LED_SDIO
-BlinkWorkItem	include/hal_com_led.h	/^	_workitem			BlinkWorkItem; \/* Workitem used by BlinkTimer to manipulate H\/W to blink LED.' *\/$/;"	m	struct:_LED_USB
-BlinkWorkItemCallback	hal/led/hal_sdio_led.c	/^void BlinkWorkItemCallback(_workitem *work)$/;"	f
-BlinkingLedState	include/hal_com_led.h	/^	LED_STATE			BlinkingLedState; \/* Next state for blinking, either LED_ON or LED_OFF are. *\/$/;"	m	struct:_LED_SDIO
-BlinkingLedState	include/hal_com_led.h	/^	LED_STATE			BlinkingLedState; \/* Next state for blinking, either LED_ON or LED_OFF are. *\/$/;"	m	struct:_LED_USB
-BlinkingLedState	include/hal_com_led.h	/^	LED_STATE		BlinkingLedState; \/* Next state for blinking, either LED_ON or LED_OFF are. *\/$/;"	m	struct:_LED_PCIE
-BoardType	hal/phydm/phydm.h	/^	u1Byte			BoardType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-BoundingCounter	hal/phydm/phydm_rainfo.h	/^	u1Byte BoundingCounter;$/;"	m	struct:_ODM_RA_Info_
-BoundingLearningTime	hal/phydm/phydm_rainfo.h	/^	u1Byte BoundingLearningTime;$/;"	m	struct:_ODM_RA_Info_
-BoundingType	hal/phydm/phydm_rainfo.h	/^	u1Byte BoundingType;$/;"	m	struct:_ODM_RA_Info_
-Bssid	hal/phydm/phydm_antdiv.h	/^	u1Byte	Bssid[6];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-Bssid	include/rtw_security.h	/^	u8						Bssid[6];$/;"	m	struct:_RT_PMKID_LIST
-Bssid	include/wlan_bssdef.h	/^	NDIS_802_11_MAC_ADDRESS Bssid;$/;"	m	struct:_NDIS_802_11_AUTHENTICATION_REQUEST
-BtCurrentLogLinkhandle	include/rtw_btcoex.h	/^	u2Byte				BtCurrentLogLinkhandle;$/;"	m	struct:_BT_MGNT
-BtCurrentPhyLinkhandle	include/rtw_btcoex.h	/^	u1Byte				BtCurrentPhyLinkhandle;$/;"	m	struct:_BT_MGNT
-BtLinkRoleString	hal/hal_btcoex.c	/^const char *const BtLinkRoleString[] = {$/;"	v
-BtMgnt	include/rtw_btcoex.h	/^	BT_MGNT BtMgnt;$/;"	m	struct:bt_coex_info
-BtOperationOn	include/rtw_btcoex.h	/^	BOOLEAN				BtOperationOn;$/;"	m	struct:_BT_MGNT
-BtProfileString	hal/hal_btcoex.c	/^const char *const BtProfileString[] = {$/;"	v
-BtSpecString	hal/hal_btcoex.c	/^const char *const BtSpecString[] = {$/;"	v
-BurstMode	include/rtw_io.h	/^	u32		BurstMode:1;$/;"	m	struct:reg_protocol_rd
-BurstMode	include/rtw_io.h	/^	u32		BurstMode:1;$/;"	m	struct:reg_protocol_wt
-Burst_RW_Reg	include/rtw_mp_ioctl.h	/^} burst_rw_reg, Burst_RW_Reg, *pBurst_RW_Reg;$/;"	t	typeref:struct:_BURST_RW_REG
-BusAddress	include/rtw_io.h	/^	u32		BusAddress;$/;"	m	struct:reg_protocol_rd
-BusAddress	include/rtw_io.h	/^	u32		BusAddress;$/;"	m	struct:reg_protocol_wt
-Byte1Access	include/rtw_io.h	/^	u32		Byte1Access:1;$/;"	m	struct:reg_protocol_rd
-Byte1Access	include/rtw_io.h	/^	u32		Byte1Access:1;$/;"	m	struct:reg_protocol_wt
-Byte2Access	include/rtw_io.h	/^	u32		Byte2Access:1;$/;"	m	struct:reg_protocol_rd
-Byte2Access	include/rtw_io.h	/^	u32		Byte2Access:1;$/;"	m	struct:reg_protocol_wt
-Byte4Access	include/rtw_io.h	/^	u32		Byte4Access:1;$/;"	m	struct:reg_protocol_rd
-Byte4Access	include/rtw_io.h	/^	u32		Byte4Access:1;$/;"	m	struct:reg_protocol_wt
-ByteCount	include/rtw_io.h	/^	u32		ByteCount:7;$/;"	m	struct:reg_protocol_rd
-ByteCount	include/rtw_io.h	/^	u32		ByteCount:7;$/;"	m	struct:reg_protocol_wt
-ByteSub	core/rtw_wapi_sms4.c	51;"	d	file:
-ByteToBit	core/rtw_mp.c	/^void ByteToBit($/;"	f
-C2HEVENT_SZ	include/rtw_event.h	109;"	d
-C2HEvent_Header	include/rtw_mlme_ext.h	/^struct C2HEvent_Header {$/;"	s
-C2H_BCN_EARLY_RPT	hal/hal_com_c2h.h	/^	C2H_BCN_EARLY_RPT = 0x1E,$/;"	e	enum:_C2H_EVT
-C2H_BT_INFO	hal/hal_com_c2h.h	/^	C2H_BT_INFO = 0x09,$/;"	e	enum:_C2H_EVT
-C2H_BT_MP_INFO	hal/hal_com_c2h.h	/^	C2H_BT_MP_INFO = 0x0B,$/;"	e	enum:_C2H_EVT
-C2H_CCX_TX_RPT	hal/hal_com_c2h.h	/^	C2H_CCX_TX_RPT = 0x03,$/;"	e	enum:_C2H_EVT
-C2H_CUSTOMER_STR_RPT	hal/hal_com_c2h.h	/^	C2H_CUSTOMER_STR_RPT = 0x24,$/;"	e	enum:_C2H_EVT
-C2H_CUSTOMER_STR_RPT_2	hal/hal_com_c2h.h	/^	C2H_CUSTOMER_STR_RPT_2 = 0x25,$/;"	e	enum:_C2H_EVT
-C2H_CUSTOMER_STR_RPT_2_BYTE8	hal/hal_com.c	1555;"	d	file:
-C2H_CUSTOMER_STR_RPT_BYTE0	hal/hal_com.c	1554;"	d	file:
-C2H_DBG	hal/hal_com_c2h.h	/^	C2H_DBG = 0x00,$/;"	e	enum:_C2H_EVT
-C2H_DEFEATURE_DBG	hal/hal_com_c2h.h	/^	C2H_DEFEATURE_DBG = 0x22,$/;"	e	enum:_C2H_EVT
-C2H_DEFEATURE_RSVD	hal/hal_com_c2h.h	/^	C2H_DEFEATURE_RSVD = 0xFD,$/;"	e	enum:_C2H_EVT
-C2H_EVT	hal/hal_com_c2h.h	/^} C2H_EVT;$/;"	t	typeref:enum:_C2H_EVT
-C2H_EVT_FW_CLOSE	include/hal_com_reg.h	1760;"	d
-C2H_EVT_HOST_CLOSE	include/hal_com_reg.h	1759;"	d
-C2H_EXTEND	hal/hal_com_c2h.h	/^	C2H_EXTEND = 0xff,$/;"	e	enum:_C2H_EVT
-C2H_FW_CHNL_SWITCH_COMPLETE	hal/hal_com_c2h.h	/^	C2H_FW_CHNL_SWITCH_COMPLETE = 0x10,$/;"	e	enum:_C2H_EVT
-C2H_FW_SCAN_COMPLETE	hal/hal_com_c2h.h	/^	C2H_FW_SCAN_COMPLETE = 0x7,$/;"	e	enum:_C2H_EVT
-C2H_ID	hal/hal_com_c2h.h	31;"	d
-C2H_ID_88XX	hal/hal_com_c2h.h	45;"	d
-C2H_IQK_FINISH	hal/hal_com_c2h.h	/^	C2H_IQK_FINISH = 0x11,$/;"	e	enum:_C2H_EVT
-C2H_LB	hal/hal_com_c2h.h	/^	C2H_LB = 0x01,$/;"	e	enum:_C2H_EVT
-C2H_MAC_HIDDEN_RPT	hal/hal_com_c2h.h	/^	C2H_MAC_HIDDEN_RPT = 0x19,$/;"	e	enum:_C2H_EVT
-C2H_MAC_HIDDEN_RPT_2	hal/hal_com_c2h.h	/^	C2H_MAC_HIDDEN_RPT_2 = 0x1A,$/;"	e	enum:_C2H_EVT
-C2H_MAILBOX_STATUS	hal/hal_com_c2h.h	/^	C2H_MAILBOX_STATUS = 0x15,$/;"	e	enum:_C2H_EVT
-C2H_MAX_SIZE	hal/hal_btcoex.c	189;"	d	file:
-C2H_MCC	hal/hal_com_c2h.h	/^	C2H_MCC = 0x17,$/;"	e	enum:_C2H_EVT
-C2H_MEM_SZ	include/rtw_cmd.h	24;"	d
-C2H_P2P_RPORT	hal/hal_com_c2h.h	/^	C2H_P2P_RPORT = 0x16,$/;"	e	enum:_C2H_EVT
-C2H_PACKET	include/rtw_recv.h	/^	C2H_PACKET$/;"	e	enum:_RX_PACKET_TYPE
-C2H_PAYLOAD	hal/hal_com_c2h.h	34;"	d
-C2H_PAYLOAD_88XX	hal/hal_com_c2h.h	47;"	d
-C2H_PLEN	hal/hal_com_c2h.h	32;"	d
-C2H_PLEN_88XX	hal/hal_com_c2h.h	48;"	d
-C2H_QUEUE_MAX_LEN	include/rtw_cmd.h	105;"	d
-C2H_RA_PARA_RPT	hal/hal_com_c2h.h	/^	C2H_RA_PARA_RPT = 0x0E,$/;"	e	enum:_C2H_EVT
-C2H_RA_RPT	hal/hal_com_c2h.h	/^	C2H_RA_RPT = 0x0C,$/;"	e	enum:_C2H_EVT
-C2H_REG_LEN	hal/hal_com_c2h.h	84;"	d
-C2H_SEQ	hal/hal_com_c2h.h	33;"	d
-C2H_SEQ_88XX	hal/hal_com_c2h.h	46;"	d
-C2H_TRIGGER_88XX	hal/hal_com_c2h.h	49;"	d
-C2H_TRIG_BY_BT_FW	hal/hal_btcoex.c	/^	C2H_TRIG_BY_BT_FW$/;"	e	enum:_bt_ext_eid	file:
-C2H_TXBF	hal/hal_com_c2h.h	/^	C2H_TXBF = 0x02,$/;"	e	enum:_C2H_EVT
-C2H_TYPE_PKT	hal/hal_com_c2h.h	24;"	d
-C2H_TYPE_REG	hal/hal_com_c2h.h	23;"	d
-C2H_WIFI_FW_ACTIVE_RSP	hal/hal_btcoex.c	/^	C2H_WIFI_FW_ACTIVE_RSP	= 0,$/;"	e	enum:_bt_ext_eid	file:
-C2H_WK_CID	include/rtw_cmd.h	/^	C2H_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-CAC_TIME_CE_MS	include/rtw_mlme_ext.h	501;"	d
-CAC_TIME_MS	include/rtw_mlme_ext.h	500;"	d
-CALCULATE_SWINGTALBE_OFFSET	hal/phydm/halphyrf_ap.c	30;"	d	file:
-CALCULATE_SWINGTALBE_OFFSET	hal/phydm/halphyrf_ce.c	24;"	d	file:
-CALCULATE_SWINGTALBE_OFFSET	hal/phydm/halphyrf_win.c	24;"	d	file:
-CALTMR_EN	include/hal_com_reg.h	1325;"	d
-CAMDBG	include/hal_com_reg.h	583;"	d
-CAMDBG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	457;"	d
-CAMDBG_8814A	include/rtl8814a_spec.h	556;"	d
-CAM_AES	include/hal_com_reg.h	819;"	d
-CAM_CONFIG_NO_USEDK	include/hal_com_reg.h	827;"	d
-CAM_CONFIG_USEDK	include/hal_com_reg.h	826;"	d
-CAM_CONTENT_COUNT	include/hal_com_reg.h	814;"	d
-CAM_NONE	include/hal_com_reg.h	816;"	d
-CAM_NOTVALID	include/hal_com_reg.h	811;"	d
-CAM_POLLINIG	include/hal_com_reg.h	831;"	d
-CAM_READ	include/hal_com_reg.h	830;"	d
-CAM_SMS4	include/hal_com_reg.h	821;"	d
-CAM_TKIP	include/hal_com_reg.h	818;"	d
-CAM_USEDK	include/hal_com_reg.h	812;"	d
-CAM_VALID	include/hal_com_reg.h	810;"	d
-CAM_WEP104	include/hal_com_reg.h	820;"	d
-CAM_WEP40	include/hal_com_reg.h	817;"	d
-CAM_WRITE	include/hal_com_reg.h	829;"	d
-CAM_empty_entry	core/rtw_wlan_util.c	/^void CAM_empty_entry($/;"	f
-CANCEL_ANTDIV_TIMMER	hal/phydm/phydm_antdiv.h	91;"	d
-CAPABILITY	include/rtw_rf.h	/^} CAPABILITY, *PCAPABILITY;$/;"	t	typeref:enum:_CAPABILITY
-CBSSID	include/hal_com_reg.h	1550;"	d
-CBSSID_BCN	include/hal_com_reg.h	1552;"	d
-CBSSID_DATA	include/hal_com_reg.h	1551;"	d
-CCA_PATHDIV_DISABLE	hal/phydm/phydm.h	/^	CCA_PATHDIV_DISABLE		= 0,$/;"	e	enum:CCA_PATHDIV_EN
-CCA_PATHDIV_EN	hal/phydm/phydm.h	/^typedef enum CCA_PATHDIV_EN {$/;"	g
-CCA_PATHDIV_ENABLE	hal/phydm/phydm.h	/^	CCA_PATHDIV_ENABLE		= 1,$/;"	e	enum:CCA_PATHDIV_EN
-CCA_PATHDIV_EN_E	hal/phydm/phydm.h	/^} CCA_PATHDIV_EN_E;$/;"	t	typeref:enum:CCA_PATHDIV_EN
-CCK	include/ieee80211.h	/^	CCK = 0,$/;"	e	enum:_RATE_SECTION
-CCKPDBackup	hal/phydm/phydm_dig.h	/^	u1Byte		CCKPDBackup;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-CCKPathDiversityTimer	hal/phydm/phydm.h	/^	RT_TIMER	CCKPathDiversityTimer;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-CCKPathDiversityWorkitem	hal/phydm/phydm.h	/^	RT_WORK_ITEM			CCKPathDiversityWorkitem;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-CCKSwingTable_Ch14	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch14 [CCK_TABLE_SIZE][8]= {$/;"	v
-CCKSwingTable_Ch14	hal/phydm/phydm_powertracking_ce.c	/^u1Byte	CCKSwingTable_Ch14[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch14	hal/phydm/phydm_powertracking_win.c	/^u1Byte	CCKSwingTable_Ch14[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch14_88F	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch14_88F	hal/phydm/phydm_powertracking_ce.c	/^u1Byte CCKSwingTable_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch14_88F	hal/phydm/phydm_powertracking_win.c	/^u1Byte CCKSwingTable_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch14_92E	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch14_92E[CCK_TABLE_SIZE_92E][8] = {$/;"	v
-CCKSwingTable_Ch14_New	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch14_New[CCK_TABLE_SIZE][8]= {$/;"	v
-CCKSwingTable_Ch14_New	hal/phydm/phydm_powertracking_ce.c	/^u1Byte CCKSwingTable_Ch14_New[CCK_TABLE_SIZE][8]= {$/;"	v
-CCKSwingTable_Ch14_New	hal/phydm/phydm_powertracking_win.c	/^u1Byte CCKSwingTable_Ch14_New[CCK_TABLE_SIZE][8]= {$/;"	v
-CCKSwingTable_Ch1_Ch13	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch1_Ch13	hal/phydm/phydm_powertracking_ce.c	/^u1Byte	CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch1_Ch13	hal/phydm/phydm_powertracking_win.c	/^u1Byte	CCKSwingTable_Ch1_Ch13[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch1_Ch13_88F	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch1_Ch13_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch1_Ch13_88F	hal/phydm/phydm_powertracking_ce.c	/^u1Byte CCKSwingTable_Ch1_Ch13_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch1_Ch13_88F	hal/phydm/phydm_powertracking_win.c	/^u1Byte CCKSwingTable_Ch1_Ch13_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch1_Ch13_92E	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch1_Ch13_92E[CCK_TABLE_SIZE_92E][8] = {$/;"	v
-CCKSwingTable_Ch1_Ch13_New	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch1_Ch13_New	hal/phydm/phydm_powertracking_ce.c	/^u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch1_Ch13_New	hal/phydm/phydm_powertracking_win.c	/^u1Byte CCKSwingTable_Ch1_Ch13_New[CCK_TABLE_SIZE][8] = {$/;"	v
-CCKSwingTable_Ch1_Ch14_8723D	hal/phydm/phydm_powertracking_ap.c	/^u4Byte CCKSwingTable_Ch1_Ch14_8723D[CCK_TABLE_SIZE_8723D] = {$/;"	v
-CCKSwingTable_Ch1_Ch14_8723D	hal/phydm/phydm_powertracking_ce.c	/^u4Byte CCKSwingTable_Ch1_Ch14_8723D[CCK_TABLE_SIZE_8723D] = {$/;"	v
-CCKSwingTable_Ch1_Ch14_8723D	hal/phydm/phydm_powertracking_win.c	/^u4Byte CCKSwingTable_Ch1_Ch14_8723D[CCK_TABLE_SIZE_8723D] = {$/;"	v
-CCKSwingTable_Ch1_Ch14_88F	hal/phydm/phydm_powertracking_ap.c	/^u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch1_Ch14_88F	hal/phydm/phydm_powertracking_ce.c	/^u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCKSwingTable_Ch1_Ch14_88F	hal/phydm/phydm_powertracking_win.c	/^u1Byte CCKSwingTable_Ch1_Ch14_88F[CCK_TABLE_SIZE_88F][16] = {$/;"	v
-CCK_24G_Diff	include/hal_data.h	/^	s8	CCK_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-CCK_Carrier_Suppression_TX	include/rtw_mp.h	/^	CCK_Carrier_Suppression_TX$/;"	e	enum:_TEST_MODE
-CCK_CtrlFrame_Cnt_aux	hal/phydm/phydm_antdiv.h	/^	u4Byte    CCK_CtrlFrame_Cnt_aux;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-CCK_CtrlFrame_Cnt_main	hal/phydm/phydm_antdiv.h	/^	u4Byte    CCK_CtrlFrame_Cnt_main;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-CCK_Diff	include/hal_pg.h	/^	s8 CCK_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo24G
-CCK_PHY	include/rtw_rf.h	26;"	d
-CCK_RSSI_INIT_COUNT	hal/phydm/phydm_hwconfig.h	27;"	d
-CCK_RX_Cnt	hal/phydm/phydm.h	/^	u8Byte			CCK_RX_Cnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-CCK_TABLE_SIZE	hal/phydm/phydm_powertracking_ap.h	61;"	d
-CCK_TABLE_SIZE	hal/phydm/phydm_powertracking_ce.h	29;"	d
-CCK_TABLE_SIZE_8723D	hal/phydm/phydm_powertracking_ap.h	43;"	d
-CCK_TABLE_SIZE_8723D	hal/phydm/phydm_powertracking_ce.h	32;"	d
-CCK_TABLE_SIZE_8723D	hal/phydm/phydm_powertracking_win.h	29;"	d
-CCK_TABLE_SIZE_88F	hal/phydm/phydm_powertracking_ap.h	62;"	d
-CCK_TABLE_SIZE_88F	hal/phydm/phydm_powertracking_ce.h	30;"	d
-CCK_TABLE_SIZE_88F	hal/phydm/phydm_powertracking_win.h	35;"	d
-CCK_TABLE_SIZE_92E	hal/phydm/phydm_powertracking_ap.h	97;"	d
-CCK_counter_aux	hal/phydm/phydm_antdiv.h	/^	u4Byte    CCK_counter_aux;	$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-CCK_counter_main	hal/phydm/phydm_antdiv.h	/^	u4Byte    CCK_counter_main;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-CCK_flag	include/rtw_cmd.h	/^	u8 CCK_flag; \/*1:CCK 2:OFDM*\/$/;"	m	struct:SetContinuousTx_parm
-CCK_generator	core/rtw_mp.c	/^void CCK_generator($/;"	f
-CCK_index	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	CCK_index;$/;"	m	struct:ODM_RF_Calibration_Structure
-CCK_index	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	CCK_index;$/;"	m	struct:ODM_RF_Calibration_Structure
-CCK_index	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	CCK_index;$/;"	m	struct:ODM_RF_Calibration_Structure
-CCK_pkt	include/sta_info.h	/^	u8	CCK_pkt;$/;"	m	struct:_RSSI_STA
-CCK_sum_power	include/sta_info.h	/^	u16	CCK_sum_power;$/;"	m	struct:_RSSI_STA
-CCX_EN	hal/phydm/phydm_ccx.h	4;"	d
-CCX_FwC2HTxRpt_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^void CCX_FwC2HTxRpt_8723d(PADAPTER padapter, u8 *pdata, u8 len)$/;"	f
-CCX_INFO	hal/phydm/phydm_ccx.h	/^}CCX_INFO, *PCCX_INFO;$/;"	t	typeref:struct:_CCX_INFO
-CEILING_NEG	core/rtw_mp.c	33;"	d	file:
-CEILING_POS	core/rtw_mp.c	32;"	d	file:
-CENTER_CH_2G_40M_NUM	include/rtw_rf.h	50;"	d
-CENTER_CH_2G_NUM	include/rtw_rf.h	51;"	d
-CENTER_CH_5G_160M_NUM	include/rtw_rf.h	55;"	d
-CENTER_CH_5G_20M_NUM	include/rtw_rf.h	52;"	d
-CENTER_CH_5G_40M_NUM	include/rtw_rf.h	53;"	d
-CENTER_CH_5G_80M_NUM	include/rtw_rf.h	54;"	d
-CENTER_CH_5G_ALL_NUM	include/rtw_rf.h	56;"	d
-CFENDFORM	include/hal_com_reg.h	1539;"	d
-CFG_DBG_MSG_STRUCT	include/rtw_mp_ioctl.h	/^typedef struct CFG_DBG_MSG_STRUCT {$/;"	s
-CFG_DBG_MSG_STRUCT	include/rtw_mp_ioctl.h	/^} CFG_DBG_MSG_STRUCT, *PCFG_DBG_MSG_STRUCT;$/;"	t	typeref:struct:CFG_DBG_MSG_STRUCT
-CFG_IEEE80211_COMPUTE_FCS	include/ieee80211.h	1503;"	d
-CFG_IEEE80211_RESERVE_FCS	include/ieee80211.h	1502;"	d
-CFO_HW_RPT_2_MHZ	hal/phydm/phydm_hwconfig.h	33;"	d
-CFO_TH_ATC	hal/phydm/phydm_cfotracking.h	28;"	d
-CFO_TH_XTAL_HIGH	hal/phydm/phydm_cfotracking.h	26;"	d
-CFO_TH_XTAL_LOW	hal/phydm/phydm_cfotracking.h	27;"	d
-CFO_TRACKING	hal/phydm/phydm_cfotracking.h	/^}CFO_TRACKING, *PCFO_TRACKING;$/;"	t	typeref:struct:_CFO_TRACKING_
-CFO_TRACKING_VERSION	hal/phydm/phydm_cfotracking.h	24;"	d
-CFO_ave_pre	hal/phydm/phydm_cfotracking.h	/^	s4Byte			CFO_ave_pre;$/;"	m	struct:_CFO_TRACKING_
-CFO_cnt	hal/phydm/phydm_cfotracking.h	/^	u4Byte			CFO_cnt[4];$/;"	m	struct:_CFO_TRACKING_
-CFO_tail	hal/phydm/phydm_cfotracking.h	/^	s4Byte			CFO_tail[4];$/;"	m	struct:_CFO_TRACKING_
-CGCS_RX_HW_ANTDIV	hal/phydm/phydm_antdiv.h	/^	CGCS_RX_HW_ANTDIV		= 0x02,$/;"	e	enum:_ANT_DIV_TYPE
-CGCS_RX_SW_ANTDIV	hal/phydm/phydm_antdiv.h	/^	CGCS_RX_SW_ANTDIV	= 0x05,$/;"	e	enum:_ANT_DIV_TYPE
-CG_TRX_HW_ANTDIV	hal/phydm/phydm_antdiv.h	/^	CG_TRX_HW_ANTDIV			= 0x01,$/;"	e	enum:_ANT_DIV_TYPE
-CG_TRX_SMART_ANTDIV	hal/phydm/phydm_antdiv.h	/^	CG_TRX_SMART_ANTDIV	= 0x04,$/;"	e	enum:_ANT_DIV_TYPE
-CHAN2FREQ	core/rtw_recv.c	3562;"	d	file:
-CHAN2G	os_dep/linux/ioctl_cfg80211.c	90;"	d	file:
-CHAN5G	os_dep/linux/ioctl_cfg80211.c	99;"	d	file:
-CHANNEL_WIDTH	include/rtw_rf.h	/^} CHANNEL_WIDTH, *PCHANNEL_WIDTH;$/;"	t	typeref:enum:_CHANNEL_WIDTH
-CHANNEL_WIDTH_160	include/rtw_rf.h	/^	CHANNEL_WIDTH_160 = 3,$/;"	e	enum:_CHANNEL_WIDTH
-CHANNEL_WIDTH_20	include/rtw_rf.h	/^	CHANNEL_WIDTH_20 = 0,$/;"	e	enum:_CHANNEL_WIDTH
-CHANNEL_WIDTH_40	include/rtw_rf.h	/^	CHANNEL_WIDTH_40 = 1,$/;"	e	enum:_CHANNEL_WIDTH
-CHANNEL_WIDTH_80	include/rtw_rf.h	/^	CHANNEL_WIDTH_80 = 2,$/;"	e	enum:_CHANNEL_WIDTH
-CHANNEL_WIDTH_80_80	include/rtw_rf.h	/^	CHANNEL_WIDTH_80_80 = 4,$/;"	e	enum:_CHANNEL_WIDTH
-CHANNEL_WIDTH_MAX	include/rtw_rf.h	/^	CHANNEL_WIDTH_MAX = 5,$/;"	e	enum:_CHANNEL_WIDTH
-CHAN_ARG	include/ieee80211.h	1740;"	d
-CHAN_FMT	include/ieee80211.h	1727;"	d
-CHECKINGSTATUS	core/rtw_ioctl_rtl.c	/^	CHECKINGSTATUS,$/;"	e	enum:_CONNECT_STATE_	file:
-CHECKSUM_NONE	include/osdep_service_bsd.h	189;"	d
-CHECK_HIQ_WK_CID	include/rtw_cmd.h	/^	CHECK_HIQ_WK_CID,\/* for softap mode, check hi queue if empty *\/$/;"	e	enum:rtw_drvextra_cmd_id
-CHECK_STATUS_CODE_FROM_BT_MP_OPER_RET	include/rtw_btcoex.h	66;"	d
-CHIP_8188C	include/HalVerDef.h	/^	CHIP_8188C	=	1,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8188E	include/HalVerDef.h	/^	CHIP_8188E	=	5,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8188F	include/HalVerDef.h	/^	CHIP_8188F	=	12,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8192C	include/HalVerDef.h	/^	CHIP_8192C	=	2,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8192D	include/HalVerDef.h	/^	CHIP_8192D	=	3,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8192E	include/HalVerDef.h	/^	CHIP_8192E	=	9,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8192S	include/HalVerDef.h	/^	CHIP_8192S	=	0,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8703B	include/HalVerDef.h	/^	CHIP_8703B	=	11,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8723A	include/HalVerDef.h	/^	CHIP_8723A	=	4,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8723B	include/HalVerDef.h	/^	CHIP_8723B	=	8,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8723D	include/HalVerDef.h	/^	CHIP_8723D	=	14,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8812	include/HalVerDef.h	/^	CHIP_8812	=	6,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8814A	include/HalVerDef.h	/^	CHIP_8814A	=	10,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8821	include/HalVerDef.h	/^	CHIP_8821	=	7,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8821C	include/HalVerDef.h	/^	CHIP_8821C	=	15$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_8822B	include/HalVerDef.h	/^	CHIP_8822B	=	13,$/;"	e	enum:tag_HAL_IC_Type_Definition
-CHIP_BONDING_88C_USB_HP	include/rtl8188e_hal.h	184;"	d
-CHIP_BONDING_88C_USB_MCARD	include/rtl8188e_hal.h	183;"	d
-CHIP_BONDING_92C_1T2R	include/rtl8188e_hal.h	182;"	d
-CHIP_BONDING_IDENTIFIER	include/rtl8188e_hal.h	181;"	d
-CHIP_VENDOR_SMIC	include/HalVerDef.h	/^	CHIP_VENDOR_SMIC	=	2,$/;"	e	enum:tag_HAL_Manufacturer_Version_Definition
-CHIP_VENDOR_TSMC	include/HalVerDef.h	/^	CHIP_VENDOR_TSMC	=	0,$/;"	e	enum:tag_HAL_Manufacturer_Version_Definition
-CHIP_VENDOR_UMC	include/HalVerDef.h	/^	CHIP_VENDOR_UMC	=	1,$/;"	e	enum:tag_HAL_Manufacturer_Version_Definition
-CHIP_VER	include/hal_com_reg.h	1264;"	d
-CHIP_VER_RTL_MASK	include/hal_com_reg.h	1280;"	d
-CHIP_VER_RTL_SHIFT	include/hal_com_reg.h	1281;"	d
-CHNL_RT_2G_EFSI1	hal/phydm/rtchnlplan.h	405;"	d
-CHNL_RT_2G_EFSI1_SCAN_TYPE	hal/phydm/rtchnlplan.h	421;"	d
-CHNL_RT_2G_ETSI2	hal/phydm/rtchnlplan.h	411;"	d
-CHNL_RT_2G_ETSI2_SCAN_TYPE	hal/phydm/rtchnlplan.h	427;"	d
-CHNL_RT_2G_FCC1	hal/phydm/rtchnlplan.h	407;"	d
-CHNL_RT_2G_FCC1_SCAN_TYPE	hal/phydm/rtchnlplan.h	423;"	d
-CHNL_RT_2G_MKK1	hal/phydm/rtchnlplan.h	409;"	d
-CHNL_RT_2G_MKK1_SCAN_TYPE	hal/phydm/rtchnlplan.h	425;"	d
-CHNL_RT_2G_NULL	hal/phydm/rtchnlplan.h	398;"	d
-CHNL_RT_2G_NULL_SCAN_TYPE	hal/phydm/rtchnlplan.h	417;"	d
-CHNL_RT_2G_WORLD	hal/phydm/rtchnlplan.h	400;"	d
-CHNL_RT_2G_WORLD_SCAN_TYPE	hal/phydm/rtchnlplan.h	419;"	d
-CHNL_RT_2G_WORLD_TEST	hal/phydm/rtchnlplan.h	402;"	d
-CHNL_RT_5G_ETSI1	hal/phydm/rtchnlplan.h	483;"	d
-CHNL_RT_5G_ETSI1_SCAN_TYPE	hal/phydm/rtchnlplan.h	523;"	d
-CHNL_RT_5G_ETSI2	hal/phydm/rtchnlplan.h	485;"	d
-CHNL_RT_5G_ETSI2_SCAN_TYPE	hal/phydm/rtchnlplan.h	525;"	d
-CHNL_RT_5G_ETSI3	hal/phydm/rtchnlplan.h	487;"	d
-CHNL_RT_5G_ETSI3_SCAN_TYPE	hal/phydm/rtchnlplan.h	527;"	d
-CHNL_RT_5G_FCC1	hal/phydm/rtchnlplan.h	489;"	d
-CHNL_RT_5G_FCC1_SCAN_TYPE	hal/phydm/rtchnlplan.h	529;"	d
-CHNL_RT_5G_FCC2	hal/phydm/rtchnlplan.h	491;"	d
-CHNL_RT_5G_FCC2_SCAN_TYPE	hal/phydm/rtchnlplan.h	531;"	d
-CHNL_RT_5G_FCC3	hal/phydm/rtchnlplan.h	493;"	d
-CHNL_RT_5G_FCC3_SCAN_TYPE	hal/phydm/rtchnlplan.h	533;"	d
-CHNL_RT_5G_FCC4	hal/phydm/rtchnlplan.h	495;"	d
-CHNL_RT_5G_FCC4_SCAN_TYPE	hal/phydm/rtchnlplan.h	535;"	d
-CHNL_RT_5G_FCC5	hal/phydm/rtchnlplan.h	497;"	d
-CHNL_RT_5G_FCC5_SCAN_TYPE	hal/phydm/rtchnlplan.h	537;"	d
-CHNL_RT_5G_FCC6	hal/phydm/rtchnlplan.h	499;"	d
-CHNL_RT_5G_FCC6_SCAN_TYPE	hal/phydm/rtchnlplan.h	539;"	d
-CHNL_RT_5G_FCC7	hal/phydm/rtchnlplan.h	501;"	d
-CHNL_RT_5G_FCC7_SCAN_TYPE	hal/phydm/rtchnlplan.h	541;"	d
-CHNL_RT_5G_IC1	hal/phydm/rtchnlplan.h	503;"	d
-CHNL_RT_5G_IC1_SCAN_TYPE	hal/phydm/rtchnlplan.h	543;"	d
-CHNL_RT_5G_KCC1	hal/phydm/rtchnlplan.h	505;"	d
-CHNL_RT_5G_KCC1_SCAN_TYPE	hal/phydm/rtchnlplan.h	545;"	d
-CHNL_RT_5G_MKK1	hal/phydm/rtchnlplan.h	507;"	d
-CHNL_RT_5G_MKK1_SCAN_TYPE	hal/phydm/rtchnlplan.h	547;"	d
-CHNL_RT_5G_MKK2	hal/phydm/rtchnlplan.h	509;"	d
-CHNL_RT_5G_MKK2_SCAN_TYPE	hal/phydm/rtchnlplan.h	549;"	d
-CHNL_RT_5G_MKK3	hal/phydm/rtchnlplan.h	511;"	d
-CHNL_RT_5G_MKK3_SCAN_TYPE	hal/phydm/rtchnlplan.h	551;"	d
-CHNL_RT_5G_NCC1	hal/phydm/rtchnlplan.h	513;"	d
-CHNL_RT_5G_NCC1_SCAN_TYPE	hal/phydm/rtchnlplan.h	553;"	d
-CHNL_RT_5G_NULL	hal/phydm/rtchnlplan.h	479;"	d
-CHNL_RT_5G_NULL_SCAN_TYPE	hal/phydm/rtchnlplan.h	519;"	d
-CHNL_RT_5G_WORLD	hal/phydm/rtchnlplan.h	481;"	d
-CHNL_RT_5G_WORLD_SCAN_TYPE	hal/phydm/rtchnlplan.h	521;"	d
-CHPLAN_ENT	include/rtw_mlme_ext.h	257;"	d
-CHPLAN_ENT	include/rtw_mlme_ext.h	259;"	d
-CH_IS_NON_OCP	include/rtw_mlme_ext.h	508;"	d
-CH_IS_NON_OCP	include/rtw_mlme_ext.h	520;"	d
-CH_LIST_CH	include/rtw_mlme_ext.h	246;"	d
-CH_LIST_ENT	include/rtw_mlme_ext.h	242;"	d
-CH_LIST_LEN	include/rtw_mlme_ext.h	245;"	d
-CH_OFFSET_40M	hal/phydm/phydm.h	88;"	d
-CH_OFFSET_80M	hal/phydm/phydm.h	89;"	d
-CH_SW_USE_CASE	include/hal_com.h	/^} CH_SW_USE_CASE;$/;"	t	typeref:enum:_CH_SW_USE_CASE
-CH_SW_USE_CASE_MCC	include/hal_com.h	/^	CH_SW_USE_CASE_MCC		= 1$/;"	e	enum:_CH_SW_USE_CASE
-CH_SW_USE_CASE_TDLS	include/hal_com.h	/^	CH_SW_USE_CASE_TDLS		= 0,$/;"	e	enum:_CH_SW_USE_CASE
-CH_offset	hal/phydm/phydm.h	/^	u1Byte	CH_offset;$/;"	m	struct:_Dynamic_Primary_CCA
-CIPHER_IE	core/rtw_wlan_util.c	4517;"	d	file:
-CIPHER_NONE	core/rtw_wlan_util.c	4518;"	d	file:
-CIPHER_WPA_EAP	core/rtw_wlan_util.c	4520;"	d	file:
-CIPHER_WPA_PSK	core/rtw_wlan_util.c	4519;"	d	file:
-CIRC_CNT	include/circ_buf.h	23;"	d
-CIRC_SPACE	include/circ_buf.h	25;"	d
-CIS	include/drv_types_pci.h	/^			u32	CIS;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-CISCO_OUI	core/rtw_wlan_util.c	/^unsigned char CISCO_OUI[] = {0x00, 0x40, 0x96};$/;"	v
-CK	core/rtw_wapi_sms4.c	/^const u32 CK[32] = {$/;"	v
-CLEAR_FLAG	include/basic_types.h	380;"	d
-CLEAR_FLAGS	include/basic_types.h	381;"	d
-CLIENT_PORT	core/rtw_br_ext.c	1496;"	d	file:
-CLK_32K_LOCK	include/hal_com.h	/^	CLK_32K_LOCK					= 0xFE$/;"	e	enum:_WAKEUP_REASON
-CLK_32K_UNLOCK	include/hal_com.h	/^	CLK_32K_UNLOCK					= 0xFD,$/;"	e	enum:_WAKEUP_REASON
-CLM_VERSION	hal/phydm/phydm_acs.h	25;"	d
-CLM_period	hal/phydm/phydm_ccx.h	/^	u2Byte					CLM_period;				\/* 4us per unit *\/$/;"	m	struct:_CCX_INFO
-CLM_period_restore	hal/phydm/phydm_ccx.h	/^	u2Byte					CLM_period_restore;				\/* 4us per unit *\/$/;"	m	struct:_CCX_INFO
-CLM_result	hal/phydm/phydm_ccx.h	/^	u2Byte		CLM_result;$/;"	m	struct:_CCX_INFO
-CLOCK_RATE	include/rtw_eeprom.h	34;"	d
-CLR_PS_STATE	include/rtw_pwrctrl.h	149;"	d
-CL_IPV6_PASS	include/rtw_br_ext.h	24;"	d
-CL_PRINTF	hal/btc/HalBtcOutSrc.h	102;"	d
-CL_SPRINTF	hal/btc/HalBtcOutSrc.h	101;"	d
-CMDBUFF_ALIGN_SZ	include/rtw_cmd.h	35;"	d
-CMDBUFF_ALIGN_SZ	include/rtw_cmd.h	37;"	d
-CMDBUF_BEACON	include/rtw_xmit.h	/^	CMDBUF_BEACON = 0x00,$/;"	e	enum:cmdbuf_type
-CMDBUF_MAX	include/rtw_xmit.h	/^	CMDBUF_MAX$/;"	e	enum:cmdbuf_type
-CMDBUF_RSVD	include/rtw_xmit.h	/^	CMDBUF_RSVD,$/;"	e	enum:cmdbuf_type
-CMD_ALIVE	include/rtw_pwrctrl.h	41;"	d
-CMD_ARG	include/rtw_cmd.h	1312;"	d
-CMD_EFUSE_PATCH	include/rtl8188e_spec.h	115;"	d
-CMD_EFUSE_PATCH_ERR	include/rtl8188e_spec.h	119;"	d
-CMD_FMT	include/rtw_cmd.h	1311;"	d
-CMD_INIT_LLT	include/rtl8188e_spec.h	113;"	d
-CMD_INIT_LLT_ERR	include/rtl8188e_spec.h	117;"	d
-CMD_IOCONFIG	include/rtl8188e_spec.h	116;"	d
-CMD_IOCONFIG_ERR	include/rtl8188e_spec.h	120;"	d
-CMD_READ_EFUSE_MAP	include/rtl8188e_spec.h	114;"	d
-CMD_READ_EFUSE_MAP_ERR	include/rtl8188e_spec.h	118;"	d
-COEX_DM_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^} COEX_DM_8188C_2ANT, *PCOEX_DM_8188C_2ANT;$/;"	t	typeref:struct:_COEX_DM_8188C_2ANT
-COEX_DM_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^} COEX_DM_8192D_2ANT, *PCOEX_DM_8192D_2ANT;$/;"	t	typeref:struct:_COEX_DM_8192D_2ANT
-COEX_DM_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^} COEX_DM_8723A_1ANT, *PCOEX_DM_8723A_1ANT;$/;"	t	typeref:struct:_COEX_DM_8723A_1ANT
-COEX_DM_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^} COEX_DM_8723A_2ANT, *PCOEX_DM_8723A_2ANT;$/;"	t	typeref:struct:_COEX_DM_8723A_2ANT
-COEX_STA_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^}COEX_STA_8188C_2ANT, *PCOEX_STA_8188C_2ANT;$/;"	t	typeref:struct:_COEX_STA_8188C_2ANT
-COEX_STA_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^}COEX_STA_8192D_2ANT, *PCOEX_STA_8192D_2ANT;$/;"	t	typeref:struct:_COEX_STA_8192D_2ANT
-COEX_STA_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^}COEX_STA_8723A_1ANT, *PCOEX_STA_8723A_1ANT;$/;"	t	typeref:struct:_COEX_STA_8723A_1ANT
-COEX_STA_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^}COEX_STA_8723A_2ANT, *PCOEX_STA_8723A_2ANT;$/;"	t	typeref:struct:_COEX_STA_8723A_2ANT
-COEX_SUPPORT	hal/btc/Mp_Precomp.h	59;"	d
-COEX_SUPPORT	hal/btc/Mp_Precomp.h	63;"	d
-COL_C2H_ACK	hal/btc/HalBtcOutSrc.h	/^} COL_C2H_ACK, *PCOL_C2H_ACK;$/;"	t	typeref:struct:_COL_C2H_ACK
-COL_C2H_ACK_HDR_LEN	hal/btc/HalBtcOutSrc.h	405;"	d
-COL_C2H_IND	hal/btc/HalBtcOutSrc.h	/^} COL_C2H_IND, *PCOL_C2H_IND;$/;"	t	typeref:struct:_COL_C2H_IND
-COL_C2H_IND_HDR_LEN	hal/btc/HalBtcOutSrc.h	414;"	d
-COL_H2C	hal/btc/HalBtcOutSrc.h	/^} COL_H2C, *PCOL_H2C;$/;"	t	typeref:struct:_COL_H2C
-COL_H2C_BUF_LEN	hal/btc/HalBtcOutSrc.h	445;"	d
-COL_H2C_STATUS	hal/btc/HalBtcOutSrc.h	/^} COL_H2C_STATUS, *PCOL_H2C_STATUS;$/;"	t	typeref:enum:_COL_H2C_STATUS
-COL_IND_BT_INFO	hal/btc/HalBtcOutSrc.h	/^	COL_IND_BT_INFO								= 0x0,$/;"	e	enum:_COL_IND_TYPE
-COL_IND_COEX_TABLE	hal/btc/HalBtcOutSrc.h	/^	COL_IND_COEX_TABLE							= 0x3,$/;"	e	enum:_COL_IND_TYPE
-COL_IND_LIMITED_TX_RX	hal/btc/HalBtcOutSrc.h	/^	COL_IND_LIMITED_TX_RX						= 0x2,$/;"	e	enum:_COL_IND_TYPE
-COL_IND_MAX	hal/btc/HalBtcOutSrc.h	/^	COL_IND_MAX$/;"	e	enum:_COL_IND_TYPE
-COL_IND_PSTDMA	hal/btc/HalBtcOutSrc.h	/^	COL_IND_PSTDMA								= 0x1,$/;"	e	enum:_COL_IND_TYPE
-COL_IND_REQ	hal/btc/HalBtcOutSrc.h	/^	COL_IND_REQ									= 0x4,$/;"	e	enum:_COL_IND_TYPE
-COL_IND_TYPE	hal/btc/HalBtcOutSrc.h	/^} COL_IND_TYPE, *PCOL_IND_TYPE;$/;"	t	typeref:enum:_COL_IND_TYPE
-COL_MAX_H2C_REQ_NUM	hal/btc/HalBtcOutSrc.h	443;"	d
-COL_OPCODE	hal/btc/HalBtcOutSrc.h	/^} COL_OPCODE, *PCOL_OPCODE;$/;"	t	typeref:enum:_COL_OPCODE
-COL_OP_GET_CONTROL	hal/btc/HalBtcOutSrc.h	/^	COL_OP_GET_CONTROL							= 0x5,$/;"	e	enum:_COL_OPCODE
-COL_OP_SET_CONTROL	hal/btc/HalBtcOutSrc.h	/^	COL_OP_SET_CONTROL							= 0x4,$/;"	e	enum:_COL_OPCODE
-COL_OP_WIFI_INFO_NOTIFY	hal/btc/HalBtcOutSrc.h	/^	COL_OP_WIFI_INFO_NOTIFY						= 0x2,$/;"	e	enum:_COL_OPCODE
-COL_OP_WIFI_OPCODE_MAX	hal/btc/HalBtcOutSrc.h	/^	COL_OP_WIFI_OPCODE_MAX$/;"	e	enum:_COL_OPCODE
-COL_OP_WIFI_POWER_STATE_NOTIFY	hal/btc/HalBtcOutSrc.h	/^	COL_OP_WIFI_POWER_STATE_NOTIFY				= 0x3,$/;"	e	enum:_COL_OPCODE
-COL_OP_WIFI_PROGRESS_NOTIFY	hal/btc/HalBtcOutSrc.h	/^	COL_OP_WIFI_PROGRESS_NOTIFY					= 0x1,$/;"	e	enum:_COL_OPCODE
-COL_OP_WIFI_STATUS_NOTIFY	hal/btc/HalBtcOutSrc.h	/^	COL_OP_WIFI_STATUS_NOTIFY					= 0x0,$/;"	e	enum:_COL_OPCODE
-COL_SINGLE_C2H_IND_RECORD	hal/btc/HalBtcOutSrc.h	/^} COL_SINGLE_C2H_IND_RECORD, *PCOL_SINGLE_C2H_IND_RECORD;$/;"	t	typeref:struct:_COL_SINGLE_C2H_IND_RECORD
-COL_SINGLE_H2C_RECORD	hal/btc/HalBtcOutSrc.h	/^} COL_SINGLE_H2C_RECORD, *PCOL_SINGLE_H2C_RECORD;$/;"	t	typeref:struct:_COL_SINGLE_H2C_RECORD
-COL_STATUS_C2H_OK	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_C2H_OK								= 0x00, \/* Wifi received H2C request and check content ok. *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_C2H_OPCODE_VER_MISMATCH	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_C2H_OPCODE_VER_MISMATCH			= 0x03, \/* Wifi firmware and wifi driver mismatch, need to update wifi driver or wifi or. *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_C2H_PARAMETER_ERROR	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_C2H_PARAMETER_ERROR				= 0x04, \/* Error paraneter.(ex: parameters = NULL but it should have values) *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_C2H_PARAMETER_OUT_OF_RANGE	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_C2H_PARAMETER_OUT_OF_RANGE		= 0x05, \/* Wifi firmware needs to check the parameters from H2C request and return the status.(ex: ch = 500, it's wrong) *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_C2H_REQ_NUM_MISMATCH	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_C2H_REQ_NUM_MISMATCH			, \/* c2h req_num mismatch, means this c2h is not we expected. *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_C2H_UNKNOWN	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_C2H_UNKNOWN							= 0x01,	\/* Not handled routine *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_C2H_UNKNOWN_OPCODE	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_C2H_UNKNOWN_OPCODE					= 0x02,	\/* Invalid OP code, It means that wifi firmware received an undefiend OP code. *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_COEX_DATA_OVERFLOW	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_COEX_DATA_OVERFLOW				, \/* coex returned length over the c2h ack length. *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_H2C_HALMAC_FAIL	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_H2C_HALMAC_FAIL					, \/* HALMAC return fail. *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_H2C_TIMTOUT	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_H2C_TIMTOUT						, \/* not received the c2h response from fw *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_INVALID_C2H_LEN	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_INVALID_C2H_LEN					, \/* invalid coex offload c2h ack length, must >= 3 *\/$/;"	e	enum:_COL_H2C_STATUS
-COL_STATUS_MAX	hal/btc/HalBtcOutSrc.h	/^	COL_STATUS_MAX$/;"	e	enum:_COL_H2C_STATUS
-COMMIT_BY_8723D	hal/phydm/rtl8723d/version_rtl8723d.h	4;"	d
-COMP_COEX	hal/btc/Mp_Precomp.h	/^	COMP_COEX		= 0,$/;"	e	enum:_BTC_MSG_COMP_TYPE
-COMP_MAX	hal/btc/Mp_Precomp.h	/^	COMP_MAX$/;"	e	enum:_BTC_MSG_COMP_TYPE
-CONC_SCANNING_TIMEOUT_DUAL_BAND	include/rtw_mlme.h	35;"	d
-CONC_SCANNING_TIMEOUT_SINGLE_BAND	include/rtw_mlme.h	34;"	d
-COND_ELSE	hal/phydm/phydm_types.h	255;"	d
-COND_ENDIF	hal/phydm/phydm_types.h	256;"	d
-CONFIG_2G5G_CG_TRX_DIVERSITY	hal/phydm/phydm_features.h	83;"	d
-CONFIG_2G5G_SUPPORT_ANTDIV	hal/phydm/phydm_features.h	96;"	d
-CONFIG_2G_SUPPORT_ANTDIV	hal/phydm/phydm_features.h	92;"	d
-CONFIG_5G_CGCS_RX_DIVERSITY	hal/phydm/phydm_features.h	79;"	d
-CONFIG_5G_CG_TRX_DIVERSITY	hal/phydm/phydm_features.h	81;"	d
-CONFIG_5G_SUPPORT_ANTDIV	hal/phydm/phydm_features.h	94;"	d
-CONFIG_80211N_HT	include/autoconf.h	39;"	d
-CONFIG_80211W	Makefile	/^CONFIG_80211W = n$/;"	m
-CONFIG_ACTIVE_KEEP_ALIVE_CHECK	include/autoconf.h	122;"	d
-CONFIG_ANDROID	include/drv_conf.h	59;"	d
-CONFIG_ANTENNA_DIVERSITY	include/autoconf.h	172;"	d
-CONFIG_ANT_DETECTION	hal/phydm/phydm_features.h	44;"	d
-CONFIG_APPEND_VENDOR_IE_ENABLE	Makefile	/^CONFIG_APPEND_VENDOR_IE_ENABLE = n$/;"	m
-CONFIG_AP_MODE	include/autoconf.h	168;"	d
-CONFIG_AP_MODE	include/autoconf.h	59;"	d
-CONFIG_AP_WOWLAN	Makefile	/^CONFIG_AP_WOWLAN = n$/;"	m
-CONFIG_ARP_KEEP_ALIVE	include/autoconf.h	229;"	d
-CONFIG_ATTEMPT_TO_FIX_AP_BEACON_ERROR	include/autoconf.h	160;"	d
-CONFIG_AUTH_DIRECT_WITHOUT_BCN	include/autoconf.h	261;"	d
-CONFIG_AUTOCFG_CP	Makefile	/^CONFIG_AUTOCFG_CP = n$/;"	m
-CONFIG_AUTOSUSPEND	include/osdep_service_linux.h	128;"	d
-CONFIG_BB_POWER_SAVING	hal/phydm/phydm_features.h	131;"	d
-CONFIG_BB_POWER_SAVING	hal/phydm/phydm_features.h	48;"	d
-CONFIG_BB_TXBF_API	hal/phydm/phydm_features.h	132;"	d
-CONFIG_BB_TXBF_API	hal/phydm/phydm_features.h	49;"	d
-CONFIG_BB_TXBF_API	hal/phydm/phydm_features.h	63;"	d
-CONFIG_BR_EXT	Makefile	/^CONFIG_BR_EXT = y$/;"	m
-CONFIG_BT_COEXIST	Makefile	/^CONFIG_BT_COEXIST = y$/;"	m
-CONFIG_BT_COEXIST	include/autoconf.h	171;"	d
-CONFIG_C2H_WK	include/rtw_cmd.h	98;"	d
-CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY	include/drv_conf.h	292;"	d
-CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER	include/autoconf.h	52;"	d
-CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER	os_dep/linux/ioctl_cfg80211.h	25;"	d
-CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT	include/autoconf.h	80;"	d
-CONFIG_CHECK_BT_HANG	include/autoconf.h	275;"	d
-CONFIG_CHECK_LEAVE_LPS	include/autoconf.h	198;"	d
-CONFIG_DEBUG	include/autoconf.h	286;"	d
-CONFIG_DEFAULT_PATTERNS_EN	Makefile	/^CONFIG_DEFAULT_PATTERNS_EN = n$/;"	m
-CONFIG_DEFAULT_PATTERNS_EN	include/autoconf.h	231;"	d
-CONFIG_DETECT_CPWM_BY_POLLING	include/autoconf.h	205;"	d
-CONFIG_DFS_MASTER	include/drv_conf.h	105;"	d
-CONFIG_DRVEXT_MODULE	Makefile	/^CONFIG_DRVEXT_MODULE = n$/;"	m
-CONFIG_EFUSE_CONFIG_FILE	Makefile	/^CONFIG_EFUSE_CONFIG_FILE = y$/;"	m
-CONFIG_EMBEDDED_FWIMG	include/autoconf.h	150;"	d
-CONFIG_EXT_CLK	Makefile	/^CONFIG_EXT_CLK = n$/;"	m
-CONFIG_FAT_PATCH	hal/phydm/phydm_features.h	36;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	106;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	114;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	125;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	136;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	144;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	60;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	68;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	76;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	84;"	d
-CONFIG_FW_C2H_PKT	include/hal_ic_cfg.h	92;"	d
-CONFIG_GET_RAID_BY_DRV	include/hal_ic_cfg.h	53;"	d
-CONFIG_GPIO_WAKEUP	Makefile	/^CONFIG_GPIO_WAKEUP = n$/;"	m
-CONFIG_GSPI_HCI	Makefile	/^CONFIG_GSPI_HCI = n$/;"	m
-CONFIG_GTK_OL	include/autoconf.h	228;"	d
-CONFIG_HIGH_ACTIVE	Makefile	/^CONFIG_HIGH_ACTIVE = n$/;"	m
-CONFIG_HOSTAPD_MLME	include/autoconf.h	63;"	d
-CONFIG_HW_ANTENNA_DIVERSITY	include/autoconf.h	242;"	d
-CONFIG_HW_PWRP_DETECTION	Makefile	/^CONFIG_HW_PWRP_DETECTION = n$/;"	m
-CONFIG_IEEE80211_BAND_5GHZ	include/drv_conf.h	282;"	d
-CONFIG_IFACE_NUMBER	include/drv_conf.h	238;"	d
-CONFIG_IFACE_NUMBER	include/drv_conf.h	240;"	d
-CONFIG_INTEL_WIDI	Makefile	/^CONFIG_INTEL_WIDI = n$/;"	m
-CONFIG_IOCTL_CFG80211	include/autoconf.h	167;"	d
-CONFIG_IPS	include/autoconf.h	190;"	d
-CONFIG_IPS_CHECK_IN_WD	include/autoconf.h	214;"	d
-CONFIG_LAYER2_ROAMING	include/autoconf.h	105;"	d
-CONFIG_LAYER2_ROAMING_RESUME	include/autoconf.h	106;"	d
-CONFIG_LOAD_PHY_PARA_FROM_FILE	Makefile	/^CONFIG_LOAD_PHY_PARA_FROM_FILE = y$/;"	m
-CONFIG_LONG_DELAY_ISSUE	include/autoconf.h	158;"	d
-CONFIG_LOW_PWR_LPS	include/autoconf.h	264;"	d
-CONFIG_LPS	include/autoconf.h	191;"	d
-CONFIG_LPS	include/autoconf.h	223;"	d
-CONFIG_LPS_LCLK	include/autoconf.h	194;"	d
-CONFIG_LPS_LCLK_WD_TIMER	include/autoconf.h	210;"	d
-CONFIG_LPS_RPWM_TIMER	include/autoconf.h	206;"	d
-CONFIG_LPS_RPWM_TIMER	include/autoconf.h	272;"	d
-CONFIG_LPS_SLOW_TRANSITION	include/autoconf.h	200;"	d
-CONFIG_MBSSID_CAM	include/drv_conf.h	266;"	d
-CONFIG_MCC_MODE	Makefile	/^CONFIG_MCC_MODE = n$/;"	m
-CONFIG_MI_WITH_MBSSID_CAM	include/drv_conf.h	263;"	d
-CONFIG_MP_INCLUDED	Makefile	/^CONFIG_MP_INCLUDED = y$/;"	m
-CONFIG_MP_IWPRIV_SUPPORT	include/autoconf.h	178;"	d
-CONFIG_MP_IWPRIV_SUPPORT	include/autoconf.h	186;"	d
-CONFIG_MP_VHT_HW_TX_MODE	Makefile	/^CONFIG_MP_VHT_HW_TX_MODE = n$/;"	m
-CONFIG_MP_VHT_HW_TX_MODE	Makefile	/^CONFIG_MP_VHT_HW_TX_MODE = y$/;"	m
-CONFIG_MULTIDRV	Makefile	/^CONFIG_MULTIDRV = n$/;"	m
-CONFIG_NATIVEAP_MLME	include/autoconf.h	169;"	d
-CONFIG_NATIVEAP_MLME	include/autoconf.h	61;"	d
-CONFIG_NEW_SIGNAL_STAT_PROCESS	include/autoconf.h	148;"	d
-CONFIG_NOT_SUPPORT_ANTDIV	hal/phydm/phydm_features.h	90;"	d
-CONFIG_NO_2G_DIVERSITY	hal/phydm/phydm_features.h	73;"	d
-CONFIG_NO_5G_DIVERSITY	hal/phydm/phydm_features.h	77;"	d
-CONFIG_NO_5G_DIVERSITY	hal/phydm/phydm_features.h	86;"	d
-CONFIG_P2P	include/autoconf.h	69;"	d
-CONFIG_P2P_INVITE_IOT	include/autoconf.h	81;"	d
-CONFIG_P2P_OP_CHK_SOCIAL_CH	include/autoconf.h	79;"	d
-CONFIG_P2P_PS	include/autoconf.h	78;"	d
-CONFIG_P2P_REMOVE_GROUP_INFO	include/autoconf.h	75;"	d
-CONFIG_PCI_HCI	Makefile	/^CONFIG_PCI_HCI = n$/;"	m
-CONFIG_PHYDM_ANTENNA_DIVERSITY	hal/phydm/phydm_features.h	108;"	d
-CONFIG_PHYDM_ANTENNA_DIVERSITY	hal/phydm/phydm_features.h	27;"	d
-CONFIG_PHYDM_ANTENNA_DIVERSITY	hal/phydm/phydm_features.h	67;"	d
-CONFIG_PHYDM_DFS_MASTER	hal/phydm/phydm_features.h	123;"	d
-CONFIG_PHY_CAPABILITY_QUERY	include/hal_ic_cfg.h	150;"	d
-CONFIG_PLATFORM_ACTIONS_ATJ227X	Makefile	/^CONFIG_PLATFORM_ACTIONS_ATJ227X = n$/;"	m
-CONFIG_PLATFORM_ACTIONS_ATM702X	Makefile	/^CONFIG_PLATFORM_ACTIONS_ATM702X = n$/;"	m
-CONFIG_PLATFORM_ACTIONS_ATM705X	Makefile	/^CONFIG_PLATFORM_ACTIONS_ATM705X = n$/;"	m
-CONFIG_PLATFORM_ACTIONS_ATV5201	Makefile	/^CONFIG_PLATFORM_ACTIONS_ATV5201 = n$/;"	m
-CONFIG_PLATFORM_ANDROID_INTEL_X86	Makefile	/^CONFIG_PLATFORM_ANDROID_INTEL_X86 = n$/;"	m
-CONFIG_PLATFORM_ANDROID_X86	Makefile	/^CONFIG_PLATFORM_ANDROID_X86 = n$/;"	m
-CONFIG_PLATFORM_ARM_MX51_241H	Makefile	/^CONFIG_PLATFORM_ARM_MX51_241H = n$/;"	m
-CONFIG_PLATFORM_ARM_NV_TK1	Makefile	/^CONFIG_PLATFORM_ARM_NV_TK1 = n$/;"	m
-CONFIG_PLATFORM_ARM_PXA2XX	Makefile	/^CONFIG_PLATFORM_ARM_PXA2XX = n$/;"	m
-CONFIG_PLATFORM_ARM_RK2818	Makefile	/^CONFIG_PLATFORM_ARM_RK2818 = n$/;"	m
-CONFIG_PLATFORM_ARM_RK3066	Makefile	/^CONFIG_PLATFORM_ARM_RK3066 = n$/;"	m
-CONFIG_PLATFORM_ARM_RK3188	Makefile	/^CONFIG_PLATFORM_ARM_RK3188 = y$/;"	m
-CONFIG_PLATFORM_ARM_RTD299X	Makefile	/^CONFIG_PLATFORM_ARM_RTD299X = n$/;"	m
-CONFIG_PLATFORM_ARM_S3C2K4	Makefile	/^CONFIG_PLATFORM_ARM_S3C2K4 = n$/;"	m
-CONFIG_PLATFORM_ARM_S3C6K4	Makefile	/^CONFIG_PLATFORM_ARM_S3C6K4 = n$/;"	m
-CONFIG_PLATFORM_ARM_SPREADTRUM_6820	Makefile	/^CONFIG_PLATFORM_ARM_SPREADTRUM_6820 = n$/;"	m
-CONFIG_PLATFORM_ARM_SPREADTRUM_8810	Makefile	/^CONFIG_PLATFORM_ARM_SPREADTRUM_8810 = n$/;"	m
-CONFIG_PLATFORM_ARM_SUN50IW1P1	Makefile	/^CONFIG_PLATFORM_ARM_SUN50IW1P1 = n$/;"	m
-CONFIG_PLATFORM_ARM_SUN6I	Makefile	/^CONFIG_PLATFORM_ARM_SUN6I = n$/;"	m
-CONFIG_PLATFORM_ARM_SUN7I	Makefile	/^CONFIG_PLATFORM_ARM_SUN7I = n$/;"	m
-CONFIG_PLATFORM_ARM_SUN8I_W3P1	Makefile	/^CONFIG_PLATFORM_ARM_SUN8I_W3P1 = n$/;"	m
-CONFIG_PLATFORM_ARM_SUN8I_W5P1	Makefile	/^CONFIG_PLATFORM_ARM_SUN8I_W5P1 = n$/;"	m
-CONFIG_PLATFORM_ARM_SUNxI	Makefile	/^CONFIG_PLATFORM_ARM_SUNxI = n$/;"	m
-CONFIG_PLATFORM_ARM_TCC8900	Makefile	/^CONFIG_PLATFORM_ARM_TCC8900 = n$/;"	m
-CONFIG_PLATFORM_ARM_TCC8920	Makefile	/^CONFIG_PLATFORM_ARM_TCC8920 = n$/;"	m
-CONFIG_PLATFORM_ARM_TCC8920_JB42	Makefile	/^CONFIG_PLATFORM_ARM_TCC8920_JB42 = n$/;"	m
-CONFIG_PLATFORM_ARM_TCC8930_JB42	Makefile	/^CONFIG_PLATFORM_ARM_TCC8930_JB42 = n$/;"	m
-CONFIG_PLATFORM_ARM_TI_PANDA	Makefile	/^CONFIG_PLATFORM_ARM_TI_PANDA = n$/;"	m
-CONFIG_PLATFORM_ARM_URBETTER	Makefile	/^CONFIG_PLATFORM_ARM_URBETTER = n$/;"	m
-CONFIG_PLATFORM_ARM_WMT	Makefile	/^CONFIG_PLATFORM_ARM_WMT = n$/;"	m
-CONFIG_PLATFORM_DMP_PHILIPS	Makefile	/^CONFIG_PLATFORM_DMP_PHILIPS = n$/;"	m
-CONFIG_PLATFORM_FS_MX61	Makefile	/^CONFIG_PLATFORM_FS_MX61 = n$/;"	m
-CONFIG_PLATFORM_HISILICON	Makefile	/^CONFIG_PLATFORM_HISILICON = n$/;"	m
-CONFIG_PLATFORM_I386_PC	Makefile	/^CONFIG_PLATFORM_I386_PC = n$/;"	m
-CONFIG_PLATFORM_JB_X86	Makefile	/^CONFIG_PLATFORM_JB_X86 = n$/;"	m
-CONFIG_PLATFORM_MIPS_AR9132	Makefile	/^CONFIG_PLATFORM_MIPS_AR9132 = n$/;"	m
-CONFIG_PLATFORM_MIPS_JZ4760	Makefile	/^CONFIG_PLATFORM_MIPS_JZ4760 = n$/;"	m
-CONFIG_PLATFORM_MIPS_PLM	Makefile	/^CONFIG_PLATFORM_MIPS_PLM = n$/;"	m
-CONFIG_PLATFORM_MIPS_RMI	Makefile	/^CONFIG_PLATFORM_MIPS_RMI = n$/;"	m
-CONFIG_PLATFORM_MOZART	Makefile	/^CONFIG_PLATFORM_MOZART = n$/;"	m
-CONFIG_PLATFORM_MSTAR	Makefile	/^CONFIG_PLATFORM_MSTAR = n$/;"	m
-CONFIG_PLATFORM_MSTAR389	Makefile	/^CONFIG_PLATFORM_MSTAR389 = n$/;"	m
-CONFIG_PLATFORM_MSTAR_TITANIA12	Makefile	/^CONFIG_PLATFORM_MSTAR_TITANIA12 = n$/;"	m
-CONFIG_PLATFORM_MT53XX	Makefile	/^CONFIG_PLATFORM_MT53XX = n$/;"	m
-CONFIG_PLATFORM_NOVATEK_NT72668	Makefile	/^CONFIG_PLATFORM_NOVATEK_NT72668 = n$/;"	m
-CONFIG_PLATFORM_RTD2880B	Makefile	/^CONFIG_PLATFORM_RTD2880B = n$/;"	m
-CONFIG_PLATFORM_RTK119X	Makefile	/^CONFIG_PLATFORM_RTK119X = n$/;"	m
-CONFIG_PLATFORM_RTK129X	Makefile	/^CONFIG_PLATFORM_RTK129X = n$/;"	m
-CONFIG_PLATFORM_RTK_DMP	Makefile	/^CONFIG_PLATFORM_RTK_DMP = n$/;"	m
-CONFIG_PLATFORM_SZEBOOK	Makefile	/^CONFIG_PLATFORM_SZEBOOK = n$/;"	m
-CONFIG_PLATFORM_TEGRA3_CARDHU	Makefile	/^CONFIG_PLATFORM_TEGRA3_CARDHU = n$/;"	m
-CONFIG_PLATFORM_TEGRA4_DALMORE	Makefile	/^CONFIG_PLATFORM_TEGRA4_DALMORE = n$/;"	m
-CONFIG_PLATFORM_TI_DM365	Makefile	/^CONFIG_PLATFORM_TI_DM365 = n$/;"	m
-CONFIG_PNO_SET_DEBUG	Makefile	/^CONFIG_PNO_SET_DEBUG = n$/;"	m
-CONFIG_PNO_SUPPORT	Makefile	/^CONFIG_PNO_SUPPORT = n$/;"	m
-CONFIG_POWER_SAVING	Makefile	/^CONFIG_POWER_SAVING = y$/;"	m
-CONFIG_POWER_SAVING	include/autoconf.h	170;"	d
-CONFIG_PROC_DEBUG	include/autoconf.h	294;"	d
-CONFIG_RADIO_WORK	os_dep/linux/ioctl_cfg80211.h	47;"	d
-CONFIG_RA_DYNAMIC_RATE_ID	hal/phydm/phydm_features.h	61;"	d
-CONFIG_RA_FW_DBG_CODE	hal/phydm/phydm_features.h	127;"	d
-CONFIG_RA_FW_DBG_CODE	hal/phydm/phydm_features.h	46;"	d
-CONFIG_RA_FW_DBG_CODE	hal/phydm/phydm_features.h	57;"	d
-CONFIG_RECV_REORDERING_CTRL	include/autoconf.h	40;"	d
-CONFIG_REDUCE_TX_CPU_LOADING	Makefile	/^CONFIG_REDUCE_TX_CPU_LOADING = n$/;"	m
-CONFIG_RF_POWER_TRIM	include/autoconf.h	125;"	d
-CONFIG_RTL8188E	Makefile	/^CONFIG_RTL8188E = n$/;"	m
-CONFIG_RTL8188F	Makefile	/^CONFIG_RTL8188F = n$/;"	m
-CONFIG_RTL8192E	Makefile	/^CONFIG_RTL8192E = n$/;"	m
-CONFIG_RTL8723B	Makefile	/^CONFIG_RTL8723B = n$/;"	m
-CONFIG_RTL8723C	Makefile	/^CONFIG_RTL8723C = n$/;"	m
-CONFIG_RTL8723D	Makefile	/^CONFIG_RTL8723D = y$/;"	m
-CONFIG_RTL8723D	include/autoconf.h	29;"	d
-CONFIG_RTL8723DS	Makefile	/^export CONFIG_RTL8723DS = m$/;"	m
-CONFIG_RTL8812A	Makefile	/^CONFIG_RTL8812A = n$/;"	m
-CONFIG_RTL8814A	Makefile	/^CONFIG_RTL8814A = n$/;"	m
-CONFIG_RTL8821A	Makefile	/^CONFIG_RTL8821A = n$/;"	m
-CONFIG_RTL8821C	Makefile	/^CONFIG_RTL8821C = n$/;"	m
-CONFIG_RTL8822B	Makefile	/^CONFIG_RTL8822B = n$/;"	m
-CONFIG_RTW_ADAPTIVITY_DC_BACKOFF	include/drv_conf.h	133;"	d
-CONFIG_RTW_ADAPTIVITY_DML	include/drv_conf.h	129;"	d
-CONFIG_RTW_ADAPTIVITY_EN	Makefile	/^CONFIG_RTW_ADAPTIVITY_EN = disable$/;"	m
-CONFIG_RTW_ADAPTIVITY_EN	include/drv_conf.h	121;"	d
-CONFIG_RTW_ADAPTIVITY_MODE	Makefile	/^CONFIG_RTW_ADAPTIVITY_MODE = normal$/;"	m
-CONFIG_RTW_ADAPTIVITY_MODE	include/drv_conf.h	125;"	d
-CONFIG_RTW_ADAPTIVITY_TH_EDCCA_HL_DIFF	include/drv_conf.h	141;"	d
-CONFIG_RTW_ADAPTIVITY_TH_L2H_INI	include/drv_conf.h	137;"	d
-CONFIG_RTW_AMPLIFIER_TYPE_2G	include/drv_conf.h	217;"	d
-CONFIG_RTW_AMPLIFIER_TYPE_5G	include/drv_conf.h	221;"	d
-CONFIG_RTW_CUSTOMER_STR	include/hal_ic_cfg.h	98;"	d
-CONFIG_RTW_DEBUG	Makefile	/^CONFIG_RTW_DEBUG = y$/;"	m
-CONFIG_RTW_DFS_REGION_DOMAIN	include/drv_conf.h	149;"	d
-CONFIG_RTW_DYNAMIC_NDEV	os_dep/linux/ioctl_cfg80211.h	41;"	d
-CONFIG_RTW_EXCL_CHS	include/drv_conf.h	145;"	d
-CONFIG_RTW_FORCE_IGI_LB	include/drv_conf.h	117;"	d
-CONFIG_RTW_GLNA_TYPE	include/drv_conf.h	229;"	d
-CONFIG_RTW_GRO	Makefile	/^CONFIG_RTW_GRO = y$/;"	m
-CONFIG_RTW_HIQ_FILTER	include/drv_conf.h	113;"	d
-CONFIG_RTW_LOG_LEVEL	Makefile	/^CONFIG_RTW_LOG_LEVEL = 4$/;"	m
-CONFIG_RTW_MACADDR_ACL	include/sta_info.h	28;"	d
-CONFIG_RTW_MAC_HIDDEN_RPT	include/hal_ic_cfg.h	117;"	d
-CONFIG_RTW_MAC_HIDDEN_RPT	include/hal_ic_cfg.h	128;"	d
-CONFIG_RTW_MAC_HIDDEN_RPT	include/hal_ic_cfg.h	147;"	d
-CONFIG_RTW_MAC_HIDDEN_RPT	include/hal_ic_cfg.h	95;"	d
-CONFIG_RTW_NAPI	Makefile	/^CONFIG_RTW_NAPI = y$/;"	m
-CONFIG_RTW_PLL_REF_CLK_SEL	include/drv_conf.h	233;"	d
-CONFIG_RTW_RFE_TYPE	include/drv_conf.h	225;"	d
-CONFIG_RTW_SDIO_KEEP_IRQ	include/drv_conf.h	311;"	d
-CONFIG_RTW_SDIO_PM_KEEP_POWER	Makefile	/^CONFIG_RTW_SDIO_PM_KEEP_POWER = y$/;"	m
-CONFIG_RTW_TARGET_TX_PWR_2G_A	include/drv_conf.h	185;"	d
-CONFIG_RTW_TARGET_TX_PWR_2G_B	include/drv_conf.h	189;"	d
-CONFIG_RTW_TARGET_TX_PWR_2G_C	include/drv_conf.h	193;"	d
-CONFIG_RTW_TARGET_TX_PWR_2G_D	include/drv_conf.h	197;"	d
-CONFIG_RTW_TARGET_TX_PWR_5G_A	include/drv_conf.h	201;"	d
-CONFIG_RTW_TARGET_TX_PWR_5G_B	include/drv_conf.h	205;"	d
-CONFIG_RTW_TARGET_TX_PWR_5G_C	include/drv_conf.h	209;"	d
-CONFIG_RTW_TARGET_TX_PWR_5G_D	include/drv_conf.h	213;"	d
-CONFIG_RUNTIME_PORT_SWITCH	include/autoconf.h	97;"	d
-CONFIG_RUNTIME_PORT_SWITCH	include/drv_conf.h	268;"	d
-CONFIG_S0S1_SW_ANTENNA_DIVERSITY	hal/phydm/phydm_features.h	113;"	d
-CONFIG_S0S1_SW_ANTENNA_DIVERSITY	hal/phydm/phydm_features.h	31;"	d
-CONFIG_SCAN_BACKOP	include/autoconf.h	102;"	d
-CONFIG_SDIO_HCI	Makefile	/^CONFIG_SDIO_HCI = y$/;"	m
-CONFIG_SDIO_HCI	include/autoconf.h	31;"	d
-CONFIG_SDIO_RX_COPY	include/autoconf.h	136;"	d
-CONFIG_SDIO_RX_COPY	include/autoconf.h	250;"	d
-CONFIG_SDIO_RX_COPY	include/autoconf.h	254;"	d
-CONFIG_SET_SCAN_DENY_TIMER	include/autoconf.h	55;"	d
-CONFIG_SFW_SUPPORTED	hal/phydm/phydm_pre_define.h	300;"	d
-CONFIG_SHARED_BMC_MACID	core/rtw_wlan_util.c	3491;"	d	file:
-CONFIG_SIGNAL_DISPLAY_DBM	include/drv_conf.h	71;"	d
-CONFIG_SIGNAL_SCALE_MAPPING	Makefile	/^CONFIG_SIGNAL_SCALE_MAPPING = n$/;"	m
-CONFIG_SKB_COPY	include/autoconf.h	146;"	d
-CONFIG_SOFTAP_11N	include/autoconf.h	274;"	d
-CONFIG_SUPPORT_FW_MULTI_PORT	include/hal_ic_cfg.h	152;"	d
-CONFIG_SWTIMER_BASED_TXBCN	include/drv_conf.h	273;"	d
-CONFIG_TDLS	Makefile	/^CONFIG_TDLS = n$/;"	m
-CONFIG_TDLS_AUTOCHECKALIVE	include/autoconf.h	91;"	d
-CONFIG_TDLS_CH_SW	include/autoconf.h	92;"	d
-CONFIG_TDLS_DRIVER_SETUP	include/autoconf.h	86;"	d
-CONFIG_TRAFFIC_PROTECT	Makefile	/^CONFIG_TRAFFIC_PROTECT = y$/;"	m
-CONFIG_TSF_RESET_OFFLOAD	include/autoconf.h	99;"	d
-CONFIG_TXPWR_BY_RATE_EN	Makefile	/^CONFIG_TXPWR_BY_RATE_EN = y$/;"	m
-CONFIG_TXPWR_BY_RATE_EN	include/drv_conf.h	153;"	d
-CONFIG_TXPWR_BY_RATE_EN	include/drv_conf.h	161;"	d
-CONFIG_TXPWR_BY_RATE_EN	include/drv_conf.h	163;"	d
-CONFIG_TXPWR_BY_RATE_EN	include/drv_conf.h	166;"	d
-CONFIG_TXPWR_BY_RATE_EN	include/drv_conf.h	168;"	d
-CONFIG_TXPWR_BY_RATE_EN	include/drv_conf.h	178;"	d
-CONFIG_TXPWR_BY_RATE_EN	include/drv_conf.h	180;"	d
-CONFIG_TXPWR_LIMIT_EN	Makefile	/^CONFIG_TXPWR_LIMIT_EN = n$/;"	m
-CONFIG_TXPWR_LIMIT_EN	include/drv_conf.h	156;"	d
-CONFIG_TXPWR_LIMIT_EN	include/drv_conf.h	162;"	d
-CONFIG_TXPWR_LIMIT_EN	include/drv_conf.h	164;"	d
-CONFIG_TXPWR_LIMIT_EN	include/drv_conf.h	167;"	d
-CONFIG_TXPWR_LIMIT_EN	include/drv_conf.h	169;"	d
-CONFIG_TXPWR_LIMIT_EN	include/drv_conf.h	179;"	d
-CONFIG_TXPWR_LIMIT_EN	include/drv_conf.h	181;"	d
-CONFIG_TX_AGGREGATION	include/autoconf.h	135;"	d
-CONFIG_TX_MCAST2UNI	include/autoconf.h	66;"	d
-CONFIG_USB_AUTOSUSPEND	Makefile	/^CONFIG_USB_AUTOSUSPEND = n$/;"	m
-CONFIG_USB_HCI	Makefile	/^CONFIG_USB_HCI = n$/;"	m
-CONFIG_USB_VENDOR_REQ_MUTEX	include/drv_conf.h	100;"	d
-CONFIG_USB_VENDOR_REQ_MUTEX	include/drv_conf.h	96;"	d
-CONFIG_USE_VMALLOC	include/osdep_service.h	102;"	d
-CONFIG_WAIT_PS_ACK	include/autoconf.h	273;"	d
-CONFIG_WAKEUP_GPIO_IDX	Makefile	/^CONFIG_WAKEUP_GPIO_IDX = default$/;"	m
-CONFIG_WAPI_SUPPORT	Makefile	/^CONFIG_WAPI_SUPPORT = n$/;"	m
-CONFIG_WAPI_SW_SMS4	include/rtw_wapi.h	5;"	d
-CONFIG_WFD	include/autoconf.h	73;"	d
-CONFIG_WIFI_MONITOR	Makefile	/^CONFIG_WIFI_MONITOR = n$/;"	m
-CONFIG_WIFI_TEST	Makefile	/^CONFIG_WIFI_TEST = n$/;"	m
-CONFIG_WIRELESS_EXT	include/osdep_service_linux.h	79;"	d
-CONFIG_WOWLAN	Makefile	/^CONFIG_WOWLAN = n$/;"	m
-CONFIG_WOWLAN	include/autoconf.h	257;"	d
-CONFIG_WOWLAN_8723	include/autoconf.h	258;"	d
-CONFIG_XMIT_ACK	include/autoconf.h	120;"	d
-CONFIG_XMIT_THREAD_MODE	include/autoconf.h	137;"	d
-CONNECT_PORT	include/rtw_btcoex.h	71;"	d
-CONNECT_PORT_BT	include/rtw_btcoex.h	72;"	d
-CONTINUOUS_TX	include/rtw_mp.h	/^	CONTINUOUS_TX             ,$/;"	e	enum:_TEST_MODE
-COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS	core/rtw_rf.c	556;"	d	file:
-COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS	core/rtw_rf.c	558;"	d	file:
-COUNTRY_CHPLAN_ASSIGN_EN_11AC	core/rtw_rf.c	550;"	d	file:
-COUNTRY_CHPLAN_ASSIGN_EN_11AC	core/rtw_rf.c	552;"	d	file:
-COUNTRY_CHPLAN_DEF_MODULE_FALGS	include/rtw_rf.h	256;"	d
-COUNTRY_CHPLAN_DEF_MODULE_FALGS	include/rtw_rf.h	258;"	d
-COUNTRY_CHPLAN_ENT	core/rtw_rf.c	562;"	d	file:
-COUNTRY_CHPLAN_EN_11AC	include/rtw_rf.h	250;"	d
-COUNTRY_CHPLAN_EN_11AC	include/rtw_rf.h	252;"	d
-COUNTRY_CODE_MAX	include/rtw_wifi_regd.h	/^	COUNTRY_CODE_MAX$/;"	e	enum:country_code_type_t
-COUNTRY_CODE_USER	include/rtw_wifi_regd.h	/^	COUNTRY_CODE_USER = 0,$/;"	e	enum:country_code_type_t
-CPRST	include/hal_com_reg.h	1249;"	d
-CPU_CLK_SEL	include/rtl8814a_spec.h	508;"	d
-CPU_CLK_SWITCH_BUSY	include/rtl8814a_spec.h	507;"	d
-CPU_DL_READY	include/hal_com_reg.h	1247;"	d
-CRC16	include/rtw_mp.h	/^	u8			CRC16[2];$/;"	m	struct:_RT_PMAC_TX_INFO
-CRC16_generator	core/rtw_mp.c	/^void CRC16_generator($/;"	f
-CRC32_FAIL	hal/phydm/phydm_antdiv.h	94;"	d
-CRC32_Fail_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	CRC32_Fail_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-CRC32_METHOD	hal/phydm/phydm_antdiv.h	88;"	d
-CRC32_OK	hal/phydm/phydm_antdiv.h	95;"	d
-CRC32_Ok_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	CRC32_Ok_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-CRC32_POLY	core/rtw_security.c	112;"	d	file:
-CRC8_generator	core/rtw_mp.c	/^void CRC8_generator($/;"	f
-CRC_LENGTH	include/ieee80211.h	1355;"	d
-CROSS_COMPILE	Makefile	/^       CROSS_COMPILE = arm-hisiv200-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := $(CROSS)$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := $(R_CROSS_COMPILE)$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Allwinner\/a20\/kitkat-a20_v4.4\/lichee\/out\/android\/common\/buildroot\/external-toolchain\/bin\/arm-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Allwinner\/a23\/android-kk44\/lichee\/out\/android\/common\/buildroot\/external-toolchain\/bin\/arm-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Allwinner\/a31\/kitkat-a3x_v4.5\/lichee\/buildroot\/output\/external-toolchain\/bin\/arm-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Allwinner\/a33\/android-L\/lichee\/out\/sun8iw5p1\/android\/common\/buildroot\/external-toolchain\/bin\/arm-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Allwinner\/a64\/android-51\/lichee\/out\/sun50iw1p1\/android\/common\/buildroot\/external-toolchain\/bin\/aarch64-linux-gnu-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Rockchip\/rk3066_20130607\/prebuilts\/gcc\/linux-x86\/arm\/arm-linux-androideabi-4.6\/bin\/arm-linux-androideabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Telechips\/SDK_2304_20110613\/prebuilt\/linux-x86\/toolchain\/arm-eabi-4.4.3\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Telechips\/v12.06_r1-tcc-android-4.0.4\/prebuilt\/linux-x86\/toolchain\/arm-eabi-4.4.3\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Telechips\/v13.03_r1-tcc-android-4.2.2_ds_patched\/prebuilts\/gcc\/linux-x86\/arm\/arm-eabi-4.6\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/Telechips\/v13.05_r1-tcc-android-4.2.2_tcc893x-evm_build\/prebuilts\/gcc\/linux-x86\/arm\/arm-eabi-4.6\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/WonderMedia\/wm8880-android4.4\/toolchain\/arm_201103_gcc4.5.2\/mybin\/arm_1103_le-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/android-x86_JB\/prebuilts\/gcc\/linux-x86\/x86\/i686-linux-android-4.7\/bin\/i686-linux-android-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/nvidia\/tegra-16r3-partner-android-4.1_20120723\/prebuilt\/linux-x86\/toolchain\/arm-eabi-4.4.3\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/android_sdk\/nvidia\/tegra-17r9-partner-android-4.2-dalmore_20130131\/prebuilts\/gcc\/linux-x86\/arm\/arm-eabi-4.6\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/cnsd4\/project\/actions\/tools-2.6.27\/bin\/mipsel-linux-gnu-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/lspei\/work\/3399\/3399-7.1\/prebuilts\/gcc\/linux-x86\/aarch64\/aarch64-linux-android-4.9\/bin\/aarch64-linux-android-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/share\/CusEnv\/FreeScale\/arm-eabi-4.4.3\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/home\/vivotek\/lsp\/mozart3v2\/Mozart3e_Toolchain\/build_arm_nofpu\/usr\/bin\/arm-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/media\/DATA-1\/android-4.0\/prebuilt\/linux-x86\/toolchain\/arm-eabi-4.4.3\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/media\/DATA-1\/urbetter\/arm-2009q3\/bin\/arm-none-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/media\/DATA-2\/android-x86\/ics-x86_20120130\/prebuilt\/linux-x86\/toolchain\/i686-unknown-linux-gnu-4.2.1\/bin\/i686-unknown-linux-gnu-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/mnt\/newdisk\/isaac\/nvidia\/android_ara_5.1\/prebuilts\/gcc\/linux-x86\/arm\/arm-eabi-4.8\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/opt\/arm-2011.09\/bin\/arm-none-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/opt\/freescale\/usr\/local\/gcc-4.1.2-glibc-2.5-nptl-3\/arm-none-linux-gnueabi\/bin\/arm-none-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/opt\/montavista\/pro5.0\/devkit\/arm\/v5t_le\/bin\/arm-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := \/usr\/src\/release_fae_version\/toolchain\/arm-eabi-4.4.0\/bin\/arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := arm-eabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := arm-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := arm-linux-gnueabihf-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := arm-none-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := mips-openwrt-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := mipsel-linux-gnu-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE := mn10300-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE ?= \/mnt\/sdb5\/Ingenic\/Umido\/mips-4.3\/bin\/mips-linux-gnu-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE ?=$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:= \/usr\/src\/Mstar_kernel\/mips-4.3\/bin\/mips-linux-gnu-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:= \/usr\/src\/bin\/arm-none-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:= arm11_mtk_le-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:= mips-linux-gnu-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:=$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:=\/opt\/crosstool2\/bin\/armeb-unknown-linux-gnueabi-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:=\/usr\/local\/toolchain_mipsel\/bin\/mipsel-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:=mipsel-linux-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE:=mipsisa32r2-uclibc-$/;"	m
-CROSS_COMPILE	Makefile	/^CROSS_COMPILE=\/home\/android_sdk\/Allwinner\/a10\/android-jb42\/lichee-jb42\/buildroot\/output\/external-toolchain\/bin\/arm-none-linux-gnueabi-$/;"	m
-CSCAN_TLV_TYPE_SSID_IE	core/rtw_wlan_util.c	4516;"	d	file:
-CSIMatrix	hal/phydm/phydm_beamforming.h	/^	u1Byte	CSIMatrix[327];$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-CSIMatrix	include/rtw_beamforming.h	/^	u8 CSIMatrix[327];$/;"	m	struct:beamformee_entry
-CSIMatrixLen	hal/phydm/phydm_beamforming.h	/^	u2Byte	CSIMatrixLen;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-CSIMatrixLen	include/rtw_beamforming.h	/^	u16 CSIMatrixLen;$/;"	m	struct:beamformee_entry
-CSI_MASK_DISABLE	hal/phydm/phydm.h	93;"	d
-CSI_MASK_ENABLE	hal/phydm/phydm.h	92;"	d
-CSI_OFF	hal/phydm/phydm_antdiv.h	107;"	d
-CSI_ON	hal/phydm/phydm_antdiv.h	106;"	d
-CTA_TEST	include/rtw_mp.h	/^	CTA_TEST,$/;"	e	enum:__anon65
-CTS_2_SELF	include/rtl8188e_xmit.h	77;"	d
-CTS_2_SELF	include/rtl8192e_xmit.h	182;"	d
-CTS_2_SELF	include/rtl8812a_xmit.h	75;"	d
-CTS_TO_SELF	include/wlan_bssdef.h	/^	CTS_TO_SELF$/;"	e	enum:VCS_TYPE
-CTWPeriod	include/rtw_cmd.h	/^	u8 CTWPeriod;	\/* TU *\/$/;"	m	struct:P2P_PS_CTWPeriod_t
-CTWindow_En	include/rtw_cmd.h	/^	u8 CTWindow_En:1;$/;"	m	struct:P2P_PS_Offload_t
-CUSTOMER_STR_RPT_2_LEN	hal/hal_com_c2h.h	113;"	d
-CUSTOMER_STR_RPT_LEN	hal/hal_com_c2h.h	109;"	d
-CUSTOMER_STR_WK_CID	include/rtw_cmd.h	/^	CUSTOMER_STR_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-CUSTOMIZED_country_chplan_map	platform/custom_country_chplan.h	/^static const struct country_chplan CUSTOMIZED_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan
-CUSTOMIZED_country_chplan_map_sz	platform/custom_country_chplan.h	/^static const u16 CUSTOMIZED_country_chplan_map_sz = sizeof(CUSTOMIZED_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v
-CUTVersion	include/HalVerDef.h	/^	HAL_CUT_VERSION_E	CUTVersion;$/;"	m	struct:tag_HAL_VERSION
-CW	include/wifi.h	/^	unsigned char		CW;$/;"	m	struct:AC_param
-C_CUT_VERSION	include/HalVerDef.h	/^	C_CUT_VERSION		=	2,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-CacheLineSize	include/drv_types_pci.h	/^	u8	CacheLineSize;$/;"	m	struct:_PCI_COMMON_CONFIG
-CandidateList	include/wlan_bssdef.h	/^	PMKID_CANDIDATE CandidateList[1];$/;"	m	struct:_NDIS_802_11_PMKID_CANDIDATE_LIST
-Capabilities	include/wlan_bssdef.h	/^	USHORT  Capabilities;$/;"	m	struct:_NDIS_802_11_FIXED_IEs
-Capabilities	include/wlan_bssdef.h	/^	USHORT Capabilities;$/;"	m	struct:_NDIS_802_11_AI_REQFI
-Capabilities	include/wlan_bssdef.h	/^	USHORT Capabilities;$/;"	m	struct:_NDIS_802_11_AI_RESFI
-CapabilitiesPtr	include/drv_types_pci.h	/^			u8	CapabilitiesPtr;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-CapabilityID	include/drv_types_pci.h	/^	u8   CapabilityID;$/;"	m	struct:_RT_PCI_CAPABILITIES_HEADER
-CardDisableHWSM	hal/rtl8723d/rtl8723d_hal_init.c	/^s32 CardDisableHWSM(PADAPTER padapter, u8 resetMCU)$/;"	f
-CardDisableRTL8723DSdio	hal/rtl8723d/sdio/sdio_halinit.c	/^static void CardDisableRTL8723DSdio(PADAPTER padapter)$/;"	f	file:
-CardDisableWithoutHWSM	hal/rtl8723d/rtl8723d_hal_init.c	/^s32 CardDisableWithoutHWSM(PADAPTER padapter)$/;"	f
-CardEnable	hal/rtl8723d/sdio/sdio_halinit.c	/^static u8 CardEnable(PADAPTER padapter)$/;"	f	file:
-Carrier_Sense_enable	hal/phydm/phydm.h	/^	BOOLEAN			Carrier_Sense_enable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Category	include/rtl8188e_hal.h	/^	u8		Category;	\/* AP\/NIC and USB\/PCI *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Category	include/rtl8188f_hal.h	/^	u8		Category;	\/* AP\/NIC and USB\/PCI *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Category	include/rtl8703b_hal.h	/^	u8		Category;	\/* AP\/NIC and USB\/PCI *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Category	include/rtl8723b_hal.h	/^	u8		Category;	\/* AP\/NIC and USB\/PCI *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Category	include/rtl8723d_hal.h	/^	u8		Category;	\/* AP\/NIC and USB\/PCI *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Cfo_short	hal/phydm/phydm.h	/^	s2Byte		Cfo_short[4];				\/* per-path's Cfo_short *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-Cfo_short	include/rtw_recv.h	/^	s16			Cfo_short[4];				\/* per-path's Cfo_short *\/$/;"	m	struct:phy_info
-Cfo_tail	hal/phydm/phydm.h	/^	s2Byte		Cfo_tail[4];					\/* per-path's Cfo_tail *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-Cfo_tail	include/rtw_recv.h	/^	s16			Cfo_tail[4];					\/* per-path's Cfo_tail *\/$/;"	m	struct:phy_info
-Ch	include/rtw_security.h	436;"	d
-Channel	include/rtw_mlme_ext.h	/^	unsigned char	Channel[MAX_CHANNEL_NUM];$/;"	m	struct:_RT_CHANNEL_PLAN
-ChannelNum	include/rtw_mlme_ext.h	/^	u8				ChannelNum;		\/* The channel number. *\/$/;"	m	struct:_RT_CHANNEL_INFO
-ChannelPlan	include/rtw_mlme.h	/^	u8	ChannelPlan;$/;"	m	struct:mlme_priv
-Channel_Info_2G	hal/phydm/phydm_acs.h	/^	u2Byte		Channel_Info_2G[2][ODM_MAX_CHANNEL_2G];		\/\/Channel_Info[1]: Channel Score, Channel_Info[2]:Channel_Scan_Times$/;"	m	struct:_ACS_
-Channel_Info_5G	hal/phydm/phydm_acs.h	/^	u2Byte		Channel_Info_5G[2][ODM_MAX_CHANNEL_5G];	$/;"	m	struct:_ACS_
-CheckChnlIsSuit	include/rtw_btcoex.h	/^	BOOLEAN				CheckChnlIsSuit;$/;"	m	struct:_BT_MGNT
-CheckFwRsvdPageContent	hal/rtl8723d/rtl8723d_cmd.c	/^CheckFwRsvdPageContent($/;"	f
-CheckIPSStatus	hal/rtl8723d/sdio/sdio_ops.c	/^u8 CheckIPSStatus(PADAPTER padapter)$/;"	f
-CheckNegative	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^CheckNegative($/;"	f	file:
-CheckNegative	hal/phydm/rtl8723d/halhwimg8723d_mac.c	/^CheckNegative($/;"	f	file:
-CheckNegative	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^CheckNegative($/;"	f	file:
-CheckPositive	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^CheckPositive($/;"	f	file:
-CheckPositive	hal/phydm/rtl8723d/halhwimg8723d_mac.c	/^CheckPositive($/;"	f	file:
-CheckPositive	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^CheckPositive($/;"	f	file:
-ChipType	include/HalVerDef.h	/^	HAL_CHIP_TYPE_E		ChipType;$/;"	m	struct:tag_HAL_VERSION
-Chnl	hal/phydm/rtchnlplan.h	/^	RT_CHNL_PWR_LIMIT	Chnl[RT_MAX_BAND_NUM];$/;"	m	struct:_RT_CHANNEL_PLAN_MAXPWR
-Chnl2G	hal/phydm/rtchnlplan.h	/^	u1Byte	Chnl2G[MAX_CHANNEL_NUM];				\/\/ CHNL_RT_2G_WORLD$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Chnl2GScanTp	hal/phydm/rtchnlplan.h	/^	u1Byte	Chnl2GScanTp[MAX_CHANNEL_NUM];			\/\/ CHNL_RT_2G_WORLD_SCAN_TYPE$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Chnl5G	hal/phydm/rtchnlplan.h	/^	u1Byte	Chnl5G[MAX_CHANNEL_NUM];				$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Chnl5GScanTp	hal/phydm/rtchnlplan.h	/^	u1Byte	Chnl5GScanTp[MAX_CHANNEL_NUM];$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-ChnlMaxPwr	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_PLAN_MAXPWR	ChnlMaxPwr;$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-ChnlPlanPwrMax_2G	hal/phydm/rtchnlplan.c	/^static	RT_CHANNEL_PLAN_MAXPWR	ChnlPlanPwrMax_2G[] = {$/;"	v	file:
-ChnlSreq	hal/phydm/rtchnlplan.h	/^	RT_CHNLPLAN_SREQ		ChnlSreq;$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Chnl_Start	hal/phydm/rtchnlplan.h	/^	u2Byte	Chnl_Start;$/;"	m	struct:_RT_CHNL_PLAN_LIMIT
-Chnl_Start	hal/phydm/rtchnlplan.h	/^	u2Byte	Chnl_Start;$/;"	m	struct:_RT_CHNL_PLAN_PWR_LIMIT
-Chnl_end	hal/phydm/rtchnlplan.h	/^	u2Byte	Chnl_end;	$/;"	m	struct:_RT_CHNL_PLAN_LIMIT
-Chnl_end	hal/phydm/rtchnlplan.h	/^	u2Byte	Chnl_end;$/;"	m	struct:_RT_CHNL_PLAN_PWR_LIMIT
-CleanChannel_2G	hal/phydm/phydm_acs.h	/^	u1Byte		CleanChannel_2G;$/;"	m	struct:_ACS_
-CleanChannel_5G	hal/phydm/phydm_acs.h	/^	u1Byte		CleanChannel_5G;$/;"	m	struct:_ACS_
-ClearFrDs	include/wifi.h	292;"	d
-ClearInterrupt8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void ClearInterrupt8723DSdio(PADAPTER padapter)$/;"	f
-ClearMData	include/wifi.h	343;"	d
-ClearMFrag	include/wifi.h	307;"	d
-ClearPrivacy	include/wifi.h	355;"	d
-ClearPwrMgt	include/wifi.h	331;"	d
-ClearRetry	include/wifi.h	319;"	d
-ClearSysInterrupt8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void ClearSysInterrupt8723DSdio(PADAPTER padapter)$/;"	f
-ClearToDs	include/wifi.h	280;"	d
-ClockResetTimes	hal/phydm/phydm_beamforming.h	/^	u1Byte				ClockResetTimes;		\/*Modified by Jeffery @2015-04-10*\/$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-ClockResetTimes	include/rtw_beamforming.h	/^	u8				ClockResetTimes;			\/*Modified by Jeffery @2015-04-10*\/$/;"	m	struct:beamforming_entry
-Cmd9346CR_9356SEL	include/hal_com_reg.h	602;"	d
-CmdEEPROM_En	include/hal_com_reg.h	600;"	d
-CmdEERPOMSEL	include/hal_com_reg.h	601;"	d
-CmdID	include/hal_phy.h	/^	SwChnlCmdID	CmdID;$/;"	m	struct:_SwChnlCmd
-CmdID_BBRegWrite10	include/hal_phy.h	/^	CmdID_BBRegWrite10,$/;"	e	enum:_SwChnlCmdID
-CmdID_End	include/hal_phy.h	/^	CmdID_End,$/;"	e	enum:_SwChnlCmdID
-CmdID_RF_WriteReg	include/hal_phy.h	/^	CmdID_RF_WriteReg,$/;"	e	enum:_SwChnlCmdID
-CmdID_SetTxPowerLevel	include/hal_phy.h	/^	CmdID_SetTxPowerLevel,$/;"	e	enum:_SwChnlCmdID
-CmdID_WritePortUchar	include/hal_phy.h	/^	CmdID_WritePortUchar,$/;"	e	enum:_SwChnlCmdID
-CmdID_WritePortUlong	include/hal_phy.h	/^	CmdID_WritePortUlong,$/;"	e	enum:_SwChnlCmdID
-CmdID_WritePortUshort	include/hal_phy.h	/^	CmdID_WritePortUshort,$/;"	e	enum:_SwChnlCmdID
-Cnt_BW_LSC	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_BW_LSC;	\/\/Gary$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_BW_USC	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_BW_USC;	\/\/Gary$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_CCA_all	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_CCA_all;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_CCK_CCA	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_CCK_CCA;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Cck_fail	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Cck_fail;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Crc8_fail	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Crc8_fail;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Fast_Fsync	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Fast_Fsync;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Mcs_fail	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Mcs_fail;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_OFDM_CCA	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_OFDM_CCA;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Ofdm_fail	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Ofdm_fail;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Ofdm_fail_pre	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Ofdm_fail_pre;	\/\/For RTL8881A$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Parity_Fail	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Parity_Fail;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_Rate_Illegal	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_Rate_Illegal;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_SB_Search_fail	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_SB_Search_fail;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_all	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_all;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Cnt_all_pre	hal/phydm/phydm_dig.h	/^	u4Byte		Cnt_all_pre;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-Command	include/drv_types_pci.h	/^	u16	Command;$/;"	m	struct:_PCI_COMMON_CONFIG
-CompSteeringNumofBFer	hal/phydm/phydm_beamforming.h	/^	u1Byte	CompSteeringNumofBFer;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-CompSteeringNumofBFer	include/rtw_beamforming.h	/^	u8 CompSteeringNumofBFer;$/;"	m	struct:beamformee_entry
-Compare	include/hal_phy.h	/^	u8		Compare;$/;"	m	struct:RF_Shadow_Compare_Map
-ConfFileOffset	include/rtw_pwrctrl.h	/^	u32	ConfFileOffset;$/;"	m	struct:lps_poff_info
-ConfLenForGTK	include/rtw_pwrctrl.h	/^	u16	ConfLenForGTK;$/;"	m	struct:lps_poff_info
-ConfLenForPTK	include/rtw_pwrctrl.h	/^	u16	ConfLenForPTK;$/;"	m	struct:lps_poff_info
-ConfigBBRF	hal/phydm/phydm.h	/^	BOOLEAN			ConfigBBRF;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Configuration	include/wlan_bssdef.h	/^	NDIS_802_11_CONFIGURATION  Configuration;$/;"	m	struct:_WLAN_BSSID_EX
-ConfigureTxpowerTrack	hal/phydm/halphyrf_ap.c	/^void ConfigureTxpowerTrack($/;"	f
-ConfigureTxpowerTrack	hal/phydm/halphyrf_ce.c	/^void ConfigureTxpowerTrack($/;"	f
-ConfigureTxpowerTrack	hal/phydm/halphyrf_win.c	/^void ConfigureTxpowerTrack($/;"	f
-ConfigureTxpowerTrack_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^void ConfigureTxpowerTrack_8723D($/;"	f
-ConnectHandle	include/rtw_btcoex.h	/^	u2Byte					ConnectHandle;$/;"	m	struct:_HCI_LINK_INFO
-ConstructBeacon	hal/rtl8723d/rtl8723d_cmd.c	/^static void ConstructBeacon(_adapter *padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-ConstructBtNullFunctionData	hal/rtl8723d/rtl8723d_cmd.c	/^static void ConstructBtNullFunctionData($/;"	f	file:
-ConstructHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^ConstructHTNDPAPacket($/;"	f
-ConstructNullFunctionData	hal/rtl8723d/rtl8723d_cmd.c	/^static void ConstructNullFunctionData($/;"	f	file:
-ConstructPSPoll	hal/rtl8723d/rtl8723d_cmd.c	/^static void ConstructPSPoll(_adapter *padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-ConstructVHTBFReportPoll	hal/phydm/txbf/haltxbfinterface.c	/^ConstructVHTBFReportPoll($/;"	f
-ConstructVHTGIDMgntFrame	hal/phydm/txbf/haltxbfinterface.c	/^ConstructVHTGIDMgntFrame($/;"	f
-ConstructVHTMUNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^ConstructVHTMUNDPAPacket($/;"	f
-ConstructVHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^ConstructVHTNDPAPacket($/;"	f
-ControlChannel	hal/phydm/phydm.h	/^	u1Byte			ControlChannel;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Country_Enum	hal/phydm/rtchnlplan.h	/^	RT_COUNTRY_NAME		Country_Enum;$/;"	m	struct:_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-Country_Name	hal/phydm/rtchnlplan.h	/^	char				Country_Name[3];$/;"	m	struct:_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-CrystalCap	hal/phydm/phydm_cfotracking.h	/^	u1Byte			CrystalCap;$/;"	m	struct:_CFO_TRACKING_
-CrystalCap	include/hal_data.h	/^	u8	CrystalCap;$/;"	m	struct:hal_com_data
-CrystalCap	include/rtw_mp.h	/^	u32 CrystalCap;$/;"	m	struct:mp_priv
-CurAntenna	hal/phydm/phydm_antdiv.h	/^	u1Byte		CurAntenna;$/;"	m	struct:_SW_Antenna_Switch_
-CurBeamform	hal/phydm/phydm_beamforming.h	/^	u1Byte						CurBeamform; $/;"	m	struct:_RT_BEAMFORM_STAINFO
-CurBeamformVHT	hal/phydm/phydm_beamforming.h	/^	u2Byte						CurBeamformVHT;$/;"	m	struct:_RT_BEAMFORM_STAINFO
-CurCCAState	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u1Byte		CurCCAState;$/;"	m	struct:_Dynamic_Power_Saving_
-CurCCKPDState	hal/phydm/phydm_dig.h	/^	u1Byte		CurCCKPDState;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-CurCCK_CCAThres	hal/phydm/phydm_dig.h	/^	u1Byte		CurCCK_CCAThres;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-CurIGValue	hal/phydm/phydm_dig.h	/^	u1Byte		CurIGValue;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-CurMultiSTAConnectState	hal/phydm/phydm_dig.h	/^	u1Byte		CurMultiSTAConnectState;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-CurRFState	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u1Byte		CurRFState;$/;"	m	struct:_Dynamic_Power_Saving_
-CurSTAConnectState	hal/phydm/phydm_dig.h	/^	u1Byte		CurSTAConnectState;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-CurrLedState	include/hal_com_led.h	/^	LED_STATE			CurrLedState; \/* Current LED state. *\/$/;"	m	struct:_LED_SDIO
-CurrLedState	include/hal_com_led.h	/^	LED_STATE			CurrLedState; \/* Current LED state. *\/$/;"	m	struct:_LED_USB
-CurrLedState	include/hal_com_led.h	/^	LED_STATE		CurrLedState; \/* Current LED state. *\/$/;"	m	struct:_LED_PCIE
-CurrMptAct	include/rtw_mp.h	/^	MPT_WORK_ITEM_HANDLER	CurrMptAct;$/;"	m	struct:_MPT_CONTEXT
-CurrentAPAddress	include/wlan_bssdef.h	/^	NDIS_802_11_MAC_ADDRESS  CurrentAPAddress;$/;"	m	struct:_NDIS_802_11_AI_REQFI
-CurrentBTConnectionCnt	include/rtw_btcoex.h	/^	u1Byte				CurrentBTConnectionCnt;$/;"	m	struct:_BT_MGNT
-CurrentBTStatus	include/rtw_btcoex.h	/^	u1Byte					CurrentBTStatus;$/;"	m	struct:_HCI_EXT_CONFIG
-CurrentBandType	include/hal_data.h	/^	BAND_TYPE		CurrentBandType;	\/* 0:2.4G, 1:5G *\/$/;"	m	struct:hal_com_data
-CurrentCenterFrequencyIndex1	include/hal_data.h	/^	u8				CurrentCenterFrequencyIndex1;$/;"	m	struct:hal_com_data
-CurrentChannel	include/hal_data.h	/^	u8				CurrentChannel;$/;"	m	struct:hal_com_data
-CurrentChannelBW	include/hal_data.h	/^	CHANNEL_WIDTH	CurrentChannelBW;$/;"	m	struct:hal_com_data
-CurrentConnectEntryNum	include/rtw_btcoex.h	/^	u1Byte				CurrentConnectEntryNum;$/;"	m	struct:_BT_MGNT
-CurrentConnectHandle	include/rtw_btcoex.h	/^	u2Byte					CurrentConnectHandle;$/;"	m	struct:_HCI_EXT_CONFIG
-CurrentIncomingTrafficMode	include/rtw_btcoex.h	/^	u1Byte					CurrentIncomingTrafficMode;$/;"	m	struct:_HCI_EXT_CONFIG
-CurrentOutgoingTrafficMode	include/rtw_btcoex.h	/^	u1Byte					CurrentOutgoingTrafficMode;$/;"	m	struct:_HCI_EXT_CONFIG
-CurrentWirelessMode	include/hal_data.h	/^	WIRELESS_MODE	CurrentWirelessMode;$/;"	m	struct:hal_com_data
-CurrminRptTime	hal/phydm/phydm.h	/^	u2Byte 			CurrminRptTime;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-CustomerID	include/hal_data.h	/^	u16	CustomerID;$/;"	m	struct:hal_com_data
-CutVersion	hal/phydm/phydm.h	/^	u1Byte			CutVersion;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DATA_BW	include/rtl8188e_xmit.h	83;"	d
-DATA_BW	include/rtl8192e_xmit.h	188;"	d
-DATA_BW	include/rtl8812a_xmit.h	81;"	d
-DATA_FRAMETAG	include/rtw_xmit.h	457;"	d
-DATA_SC_SHT	include/rtl8188e_xmit.h	82;"	d
-DATA_SC_SHT	include/rtl8192e_xmit.h	187;"	d
-DATA_SC_SHT	include/rtl8812a_xmit.h	80;"	d
-DATA_SHORT	include/rtl8188e_xmit.h	80;"	d
-DATA_SHORT	include/rtl8192e_xmit.h	185;"	d
-DATA_SHORT	include/rtl8812a_xmit.h	78;"	d
-DBG	include/autoconf.h	289;"	d
-DBG	include/autoconf.h	291;"	d
-DBG_BSS_EX_DEL_P2P_ATTR	core/rtw_ieee80211.c	2068;"	d	file:
-DBG_BSS_EX_DEL_P2P_IE	core/rtw_ieee80211.c	2056;"	d	file:
-DBG_BSS_EX_DEL_WFD_ATTR	core/rtw_ieee80211.c	2394;"	d	file:
-DBG_BSS_EX_DEL_WFD_IE	core/rtw_ieee80211.c	2383;"	d	file:
-DBG_BT_INFO	hal/hal_btcoex.c	/^void DBG_BT_INFO(u8 *dbgmsg)$/;"	f
-DBG_BT_INFO_INIT	hal/hal_btcoex.c	/^static void DBG_BT_INFO_INIT(PBTCDBGINFO pinfo, u8 *pbuf, u32 size)$/;"	f	file:
-DBG_C2H_MAC_HIDDEN_RPT_HANDLE	hal/hal_com.c	1334;"	d	file:
-DBG_C2H_PKT_HDL	hal/hal_com.c	1215;"	d	file:
-DBG_C2H_PKT_PRE_HDL	hal/hal_com.c	1212;"	d	file:
-DBG_CHECK_FW_PS_STATE	include/autoconf.h	299;"	d
-DBG_CHOOSE_SHORTEST_WAITING_CH	core/rtw_mlme_ext.c	639;"	d	file:
-DBG_CMD_EXECUTE	core/rtw_cmd.c	26;"	d	file:
-DBG_CONFIG_ERROR_DETECT	include/autoconf.h	296;"	d
-DBG_COUNTER	include/rtw_debug.h	309;"	d
-DBG_COUNTER	include/rtw_debug.h	311;"	d
-DBG_CUSTOMER_STR_RPT_HANDLE	hal/hal_com.c	1542;"	d	file:
-DBG_ConstructVHTMUNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^DBG_ConstructVHTMUNDPAPacket($/;"	f
-DBG_DEL_P2P_ATTR	core/rtw_ieee80211.c	2009;"	d	file:
-DBG_DEL_P2P_IE	core/rtw_ieee80211.c	1968;"	d	file:
-DBG_DEL_WFD_ATTR	core/rtw_ieee80211.c	2336;"	d	file:
-DBG_DEL_WFD_IE	core/rtw_ieee80211.c	2295;"	d	file:
-DBG_DUMP_OS_QUEUE_CTL	os_dep/linux/xmit_linux.c	24;"	d	file:
-DBG_HIGHEST_RATE_BMP_BW_CHANGE	core/rtw_xmit.c	565;"	d	file:
-DBG_IFACE_STATUS_DUMP	include/rtw_mi.h	168;"	d
-DBG_LOUD	hal/btc/Mp_Precomp.h	54;"	d
-DBG_LPSPG_INFO_DUMP	hal/hal_com.c	7259;"	d	file:
-DBG_LPSPG_SEC_DUMP	hal/hal_com.c	7186;"	d	file:
-DBG_MBID_CAM_DUMP	include/hal_com.h	274;"	d
-DBG_MP_SDIO_INDIRECT_ACCESS	os_dep/linux/ioctl_linux.c	10578;"	d	file:
-DBG_OFF	hal/btc/Mp_Precomp.h	50;"	d
-DBG_PG_TXPWR_READ	hal/hal_com_phycfg.c	57;"	d	file:
-DBG_RFRAME_DEL_WFD_IE	core/rtw_recv.c	197;"	d	file:
-DBG_RX_PHYSTATUS_CHINFO	core/rtw_odm.c	388;"	d	file:
-DBG_SEC	hal/btc/Mp_Precomp.h	51;"	d
-DBG_SEC_CAM_ACCESS	hal/hal_com.c	1858;"	d	file:
-DBG_SERIOUS	hal/btc/Mp_Precomp.h	52;"	d
-DBG_SESSION_TRACKER	include/sta_info.h	120;"	d
-DBG_SKB_PROCESS	core/rtw_mi.c	1119;"	d	file:
-DBG_SW_SEC_CNT	include/rtw_security.h	223;"	d
-DBG_SendSWVHTMUNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^DBG_SendSWVHTMUNDPAPacket($/;"	f
-DBG_TRACE	hal/btc/Mp_Precomp.h	55;"	d
-DBG_TX_POWER_IDX	hal/hal_com_phycfg.c	2762;"	d	file:
-DBG_WARNING	hal/btc/Mp_Precomp.h	53;"	d
-DBG_XFRAME_DEL_WFD_IE	core/rtw_p2p.c	3672;"	d	file:
-DCAM	include/hal_com_reg.h	588;"	d
-DCMD_CHAR	hal/phydm/phydm_debug.h	244;"	d
-DCMD_DECIMAL	hal/phydm/phydm_debug.h	243;"	d
-DCMD_HEX	hal/phydm/phydm_debug.h	245;"	d
-DCMD_Printf	hal/btc/Mp_Precomp.h	34;"	d
-DCbackoff	hal/phydm/phydm.h	/^	u1Byte			DCbackoff;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DDMA_CHKSUM_EN	include/rtl8814a_spec.h	491;"	d
-DDMA_CHKSUM_FAIL	include/rtl8814a_spec.h	489;"	d
-DDMA_CH_CHKSUM_CNT	include/rtl8814a_spec.h	486;"	d
-DDMA_CH_OWN	include/rtl8814a_spec.h	492;"	d
-DDMA_DA_W_DISABLE	include/rtl8814a_spec.h	490;"	d
-DDMA_LEN_MASK	include/rtl8814a_spec.h	484;"	d
-DDMA_MODE_BLOCK_CPU	include/rtl8814a_spec.h	488;"	d
-DDMA_RST_CHKSUM_STS	include/rtl8814a_spec.h	487;"	d
-DEBUG_ERR	include/rtw_br_ext.h	30;"	d
-DEBUG_INFO	include/rtw_br_ext.h	29;"	d
-DEBUG_VERSION	hal/phydm/phydm_debug.h	27;"	d
-DEBUG_WARN	include/rtw_br_ext.h	28;"	d
-DECRYPT	core/rtw_wapi_sms4.c	14;"	d	file:
-DEFAULT_BCN_INTERVAL	include/ieee80211.h	40;"	d
-DEFAULT_FTS	include/ieee80211.h	1468;"	d
-DEFAULT_INDICATOR_TIMELMT	hal/hal_halmac.c	27;"	d	file:
-DEFAULT_MAX_SCAN_AGE	include/ieee80211.h	1467;"	d
-DEFAULT_PATTERN_NUM	include/rtw_pwrctrl.h	51;"	d
-DEFAULT_PATTERN_NUM	include/rtw_pwrctrl.h	54;"	d
-DEFAULT_PATTERN_NUM	include/rtw_pwrctrl.h	57;"	d
-DEFAULT_RANDOM_MACADDR	core/rtw_ieee80211.c	1382;"	d	file:
-DEFEATURE_DBG_LEN	hal/hal_com_c2h.h	104;"	d
-DEFUALT_OFFSET	include/gspi_ops.h	37;"	d
-DELTA_SWINGIDX_SIZE	hal/phydm/phydm_powertracking_ap.h	38;"	d
-DELTA_SWINGIDX_SIZE	hal/phydm/phydm_powertracking_ce.h	35;"	d
-DELTA_SWINGIDX_SIZE	hal/phydm/phydm_powertracking_win.h	31;"	d
-DELTA_SWINTSSI_SIZE	hal/phydm/phydm_powertracking_ap.h	39;"	d
-DELTA_SWINTSSI_SIZE	hal/phydm/phydm_powertracking_ce.h	36;"	d
-DELTA_SWINTSSI_SIZE	hal/phydm/phydm_powertracking_win.h	32;"	d
-DESC8188F_RATE11M	include/rtl8188f_xmit.h	233;"	d
-DESC8188F_RATE12M	include/rtl8188f_xmit.h	238;"	d
-DESC8188F_RATE18M	include/rtl8188f_xmit.h	239;"	d
-DESC8188F_RATE1M	include/rtl8188f_xmit.h	230;"	d
-DESC8188F_RATE24M	include/rtl8188f_xmit.h	240;"	d
-DESC8188F_RATE2M	include/rtl8188f_xmit.h	231;"	d
-DESC8188F_RATE36M	include/rtl8188f_xmit.h	241;"	d
-DESC8188F_RATE48M	include/rtl8188f_xmit.h	242;"	d
-DESC8188F_RATE54M	include/rtl8188f_xmit.h	243;"	d
-DESC8188F_RATE5_5M	include/rtl8188f_xmit.h	232;"	d
-DESC8188F_RATE6M	include/rtl8188f_xmit.h	236;"	d
-DESC8188F_RATE9M	include/rtl8188f_xmit.h	237;"	d
-DESC8188F_RATEMCS0	include/rtl8188f_xmit.h	246;"	d
-DESC8188F_RATEMCS1	include/rtl8188f_xmit.h	247;"	d
-DESC8188F_RATEMCS10	include/rtl8188f_xmit.h	256;"	d
-DESC8188F_RATEMCS11	include/rtl8188f_xmit.h	257;"	d
-DESC8188F_RATEMCS12	include/rtl8188f_xmit.h	258;"	d
-DESC8188F_RATEMCS13	include/rtl8188f_xmit.h	259;"	d
-DESC8188F_RATEMCS14	include/rtl8188f_xmit.h	260;"	d
-DESC8188F_RATEMCS15	include/rtl8188f_xmit.h	261;"	d
-DESC8188F_RATEMCS2	include/rtl8188f_xmit.h	248;"	d
-DESC8188F_RATEMCS3	include/rtl8188f_xmit.h	249;"	d
-DESC8188F_RATEMCS4	include/rtl8188f_xmit.h	250;"	d
-DESC8188F_RATEMCS5	include/rtl8188f_xmit.h	251;"	d
-DESC8188F_RATEMCS6	include/rtl8188f_xmit.h	252;"	d
-DESC8188F_RATEMCS7	include/rtl8188f_xmit.h	253;"	d
-DESC8188F_RATEMCS8	include/rtl8188f_xmit.h	254;"	d
-DESC8188F_RATEMCS9	include/rtl8188f_xmit.h	255;"	d
-DESC8188F_RATEVHTSS1MCS0	include/rtl8188f_xmit.h	262;"	d
-DESC8188F_RATEVHTSS1MCS1	include/rtl8188f_xmit.h	263;"	d
-DESC8188F_RATEVHTSS1MCS2	include/rtl8188f_xmit.h	264;"	d
-DESC8188F_RATEVHTSS1MCS3	include/rtl8188f_xmit.h	265;"	d
-DESC8188F_RATEVHTSS1MCS4	include/rtl8188f_xmit.h	266;"	d
-DESC8188F_RATEVHTSS1MCS5	include/rtl8188f_xmit.h	267;"	d
-DESC8188F_RATEVHTSS1MCS6	include/rtl8188f_xmit.h	268;"	d
-DESC8188F_RATEVHTSS1MCS7	include/rtl8188f_xmit.h	269;"	d
-DESC8188F_RATEVHTSS1MCS8	include/rtl8188f_xmit.h	270;"	d
-DESC8188F_RATEVHTSS1MCS9	include/rtl8188f_xmit.h	271;"	d
-DESC8188F_RATEVHTSS2MCS0	include/rtl8188f_xmit.h	272;"	d
-DESC8188F_RATEVHTSS2MCS1	include/rtl8188f_xmit.h	273;"	d
-DESC8188F_RATEVHTSS2MCS2	include/rtl8188f_xmit.h	274;"	d
-DESC8188F_RATEVHTSS2MCS3	include/rtl8188f_xmit.h	275;"	d
-DESC8188F_RATEVHTSS2MCS4	include/rtl8188f_xmit.h	276;"	d
-DESC8188F_RATEVHTSS2MCS5	include/rtl8188f_xmit.h	277;"	d
-DESC8188F_RATEVHTSS2MCS6	include/rtl8188f_xmit.h	278;"	d
-DESC8188F_RATEVHTSS2MCS7	include/rtl8188f_xmit.h	279;"	d
-DESC8188F_RATEVHTSS2MCS8	include/rtl8188f_xmit.h	280;"	d
-DESC8188F_RATEVHTSS2MCS9	include/rtl8188f_xmit.h	281;"	d
-DESC8703B_RATE11M	include/rtl8703b_xmit.h	233;"	d
-DESC8703B_RATE12M	include/rtl8703b_xmit.h	238;"	d
-DESC8703B_RATE18M	include/rtl8703b_xmit.h	239;"	d
-DESC8703B_RATE1M	include/rtl8703b_xmit.h	230;"	d
-DESC8703B_RATE24M	include/rtl8703b_xmit.h	240;"	d
-DESC8703B_RATE2M	include/rtl8703b_xmit.h	231;"	d
-DESC8703B_RATE36M	include/rtl8703b_xmit.h	241;"	d
-DESC8703B_RATE48M	include/rtl8703b_xmit.h	242;"	d
-DESC8703B_RATE54M	include/rtl8703b_xmit.h	243;"	d
-DESC8703B_RATE5_5M	include/rtl8703b_xmit.h	232;"	d
-DESC8703B_RATE6M	include/rtl8703b_xmit.h	236;"	d
-DESC8703B_RATE9M	include/rtl8703b_xmit.h	237;"	d
-DESC8703B_RATEMCS0	include/rtl8703b_xmit.h	246;"	d
-DESC8703B_RATEMCS1	include/rtl8703b_xmit.h	247;"	d
-DESC8703B_RATEMCS10	include/rtl8703b_xmit.h	256;"	d
-DESC8703B_RATEMCS11	include/rtl8703b_xmit.h	257;"	d
-DESC8703B_RATEMCS12	include/rtl8703b_xmit.h	258;"	d
-DESC8703B_RATEMCS13	include/rtl8703b_xmit.h	259;"	d
-DESC8703B_RATEMCS14	include/rtl8703b_xmit.h	260;"	d
-DESC8703B_RATEMCS15	include/rtl8703b_xmit.h	261;"	d
-DESC8703B_RATEMCS2	include/rtl8703b_xmit.h	248;"	d
-DESC8703B_RATEMCS3	include/rtl8703b_xmit.h	249;"	d
-DESC8703B_RATEMCS4	include/rtl8703b_xmit.h	250;"	d
-DESC8703B_RATEMCS5	include/rtl8703b_xmit.h	251;"	d
-DESC8703B_RATEMCS6	include/rtl8703b_xmit.h	252;"	d
-DESC8703B_RATEMCS7	include/rtl8703b_xmit.h	253;"	d
-DESC8703B_RATEMCS8	include/rtl8703b_xmit.h	254;"	d
-DESC8703B_RATEMCS9	include/rtl8703b_xmit.h	255;"	d
-DESC8703B_RATEVHTSS1MCS0	include/rtl8703b_xmit.h	262;"	d
-DESC8703B_RATEVHTSS1MCS1	include/rtl8703b_xmit.h	263;"	d
-DESC8703B_RATEVHTSS1MCS2	include/rtl8703b_xmit.h	264;"	d
-DESC8703B_RATEVHTSS1MCS3	include/rtl8703b_xmit.h	265;"	d
-DESC8703B_RATEVHTSS1MCS4	include/rtl8703b_xmit.h	266;"	d
-DESC8703B_RATEVHTSS1MCS5	include/rtl8703b_xmit.h	267;"	d
-DESC8703B_RATEVHTSS1MCS6	include/rtl8703b_xmit.h	268;"	d
-DESC8703B_RATEVHTSS1MCS7	include/rtl8703b_xmit.h	269;"	d
-DESC8703B_RATEVHTSS1MCS8	include/rtl8703b_xmit.h	270;"	d
-DESC8703B_RATEVHTSS1MCS9	include/rtl8703b_xmit.h	271;"	d
-DESC8703B_RATEVHTSS2MCS0	include/rtl8703b_xmit.h	272;"	d
-DESC8703B_RATEVHTSS2MCS1	include/rtl8703b_xmit.h	273;"	d
-DESC8703B_RATEVHTSS2MCS2	include/rtl8703b_xmit.h	274;"	d
-DESC8703B_RATEVHTSS2MCS3	include/rtl8703b_xmit.h	275;"	d
-DESC8703B_RATEVHTSS2MCS4	include/rtl8703b_xmit.h	276;"	d
-DESC8703B_RATEVHTSS2MCS5	include/rtl8703b_xmit.h	277;"	d
-DESC8703B_RATEVHTSS2MCS6	include/rtl8703b_xmit.h	278;"	d
-DESC8703B_RATEVHTSS2MCS7	include/rtl8703b_xmit.h	279;"	d
-DESC8703B_RATEVHTSS2MCS8	include/rtl8703b_xmit.h	280;"	d
-DESC8703B_RATEVHTSS2MCS9	include/rtl8703b_xmit.h	281;"	d
-DESC8723B_RATE11M	include/rtl8723b_xmit.h	233;"	d
-DESC8723B_RATE12M	include/rtl8723b_xmit.h	238;"	d
-DESC8723B_RATE18M	include/rtl8723b_xmit.h	239;"	d
-DESC8723B_RATE1M	include/rtl8723b_xmit.h	230;"	d
-DESC8723B_RATE24M	include/rtl8723b_xmit.h	240;"	d
-DESC8723B_RATE2M	include/rtl8723b_xmit.h	231;"	d
-DESC8723B_RATE36M	include/rtl8723b_xmit.h	241;"	d
-DESC8723B_RATE48M	include/rtl8723b_xmit.h	242;"	d
-DESC8723B_RATE54M	include/rtl8723b_xmit.h	243;"	d
-DESC8723B_RATE5_5M	include/rtl8723b_xmit.h	232;"	d
-DESC8723B_RATE6M	include/rtl8723b_xmit.h	236;"	d
-DESC8723B_RATE9M	include/rtl8723b_xmit.h	237;"	d
-DESC8723B_RATEMCS0	include/rtl8723b_xmit.h	246;"	d
-DESC8723B_RATEMCS1	include/rtl8723b_xmit.h	247;"	d
-DESC8723B_RATEMCS10	include/rtl8723b_xmit.h	256;"	d
-DESC8723B_RATEMCS11	include/rtl8723b_xmit.h	257;"	d
-DESC8723B_RATEMCS12	include/rtl8723b_xmit.h	258;"	d
-DESC8723B_RATEMCS13	include/rtl8723b_xmit.h	259;"	d
-DESC8723B_RATEMCS14	include/rtl8723b_xmit.h	260;"	d
-DESC8723B_RATEMCS15	include/rtl8723b_xmit.h	261;"	d
-DESC8723B_RATEMCS2	include/rtl8723b_xmit.h	248;"	d
-DESC8723B_RATEMCS3	include/rtl8723b_xmit.h	249;"	d
-DESC8723B_RATEMCS4	include/rtl8723b_xmit.h	250;"	d
-DESC8723B_RATEMCS5	include/rtl8723b_xmit.h	251;"	d
-DESC8723B_RATEMCS6	include/rtl8723b_xmit.h	252;"	d
-DESC8723B_RATEMCS7	include/rtl8723b_xmit.h	253;"	d
-DESC8723B_RATEMCS8	include/rtl8723b_xmit.h	254;"	d
-DESC8723B_RATEMCS9	include/rtl8723b_xmit.h	255;"	d
-DESC8723B_RATEVHTSS1MCS0	include/rtl8723b_xmit.h	262;"	d
-DESC8723B_RATEVHTSS1MCS1	include/rtl8723b_xmit.h	263;"	d
-DESC8723B_RATEVHTSS1MCS2	include/rtl8723b_xmit.h	264;"	d
-DESC8723B_RATEVHTSS1MCS3	include/rtl8723b_xmit.h	265;"	d
-DESC8723B_RATEVHTSS1MCS4	include/rtl8723b_xmit.h	266;"	d
-DESC8723B_RATEVHTSS1MCS5	include/rtl8723b_xmit.h	267;"	d
-DESC8723B_RATEVHTSS1MCS6	include/rtl8723b_xmit.h	268;"	d
-DESC8723B_RATEVHTSS1MCS7	include/rtl8723b_xmit.h	269;"	d
-DESC8723B_RATEVHTSS1MCS8	include/rtl8723b_xmit.h	270;"	d
-DESC8723B_RATEVHTSS1MCS9	include/rtl8723b_xmit.h	271;"	d
-DESC8723B_RATEVHTSS2MCS0	include/rtl8723b_xmit.h	272;"	d
-DESC8723B_RATEVHTSS2MCS1	include/rtl8723b_xmit.h	273;"	d
-DESC8723B_RATEVHTSS2MCS2	include/rtl8723b_xmit.h	274;"	d
-DESC8723B_RATEVHTSS2MCS3	include/rtl8723b_xmit.h	275;"	d
-DESC8723B_RATEVHTSS2MCS4	include/rtl8723b_xmit.h	276;"	d
-DESC8723B_RATEVHTSS2MCS5	include/rtl8723b_xmit.h	277;"	d
-DESC8723B_RATEVHTSS2MCS6	include/rtl8723b_xmit.h	278;"	d
-DESC8723B_RATEVHTSS2MCS7	include/rtl8723b_xmit.h	279;"	d
-DESC8723B_RATEVHTSS2MCS8	include/rtl8723b_xmit.h	280;"	d
-DESC8723B_RATEVHTSS2MCS9	include/rtl8723b_xmit.h	281;"	d
-DESC8723D_RATE11M	include/rtl8723d_xmit.h	412;"	d
-DESC8723D_RATE12M	include/rtl8723d_xmit.h	417;"	d
-DESC8723D_RATE18M	include/rtl8723d_xmit.h	418;"	d
-DESC8723D_RATE1M	include/rtl8723d_xmit.h	409;"	d
-DESC8723D_RATE24M	include/rtl8723d_xmit.h	419;"	d
-DESC8723D_RATE2M	include/rtl8723d_xmit.h	410;"	d
-DESC8723D_RATE36M	include/rtl8723d_xmit.h	420;"	d
-DESC8723D_RATE48M	include/rtl8723d_xmit.h	421;"	d
-DESC8723D_RATE54M	include/rtl8723d_xmit.h	422;"	d
-DESC8723D_RATE5_5M	include/rtl8723d_xmit.h	411;"	d
-DESC8723D_RATE6M	include/rtl8723d_xmit.h	415;"	d
-DESC8723D_RATE9M	include/rtl8723d_xmit.h	416;"	d
-DESC8723D_RATEMCS0	include/rtl8723d_xmit.h	425;"	d
-DESC8723D_RATEMCS1	include/rtl8723d_xmit.h	426;"	d
-DESC8723D_RATEMCS10	include/rtl8723d_xmit.h	435;"	d
-DESC8723D_RATEMCS11	include/rtl8723d_xmit.h	436;"	d
-DESC8723D_RATEMCS12	include/rtl8723d_xmit.h	437;"	d
-DESC8723D_RATEMCS13	include/rtl8723d_xmit.h	438;"	d
-DESC8723D_RATEMCS14	include/rtl8723d_xmit.h	439;"	d
-DESC8723D_RATEMCS15	include/rtl8723d_xmit.h	440;"	d
-DESC8723D_RATEMCS2	include/rtl8723d_xmit.h	427;"	d
-DESC8723D_RATEMCS3	include/rtl8723d_xmit.h	428;"	d
-DESC8723D_RATEMCS4	include/rtl8723d_xmit.h	429;"	d
-DESC8723D_RATEMCS5	include/rtl8723d_xmit.h	430;"	d
-DESC8723D_RATEMCS6	include/rtl8723d_xmit.h	431;"	d
-DESC8723D_RATEMCS7	include/rtl8723d_xmit.h	432;"	d
-DESC8723D_RATEMCS8	include/rtl8723d_xmit.h	433;"	d
-DESC8723D_RATEMCS9	include/rtl8723d_xmit.h	434;"	d
-DESC8723D_RATEVHTSS1MCS0	include/rtl8723d_xmit.h	441;"	d
-DESC8723D_RATEVHTSS1MCS1	include/rtl8723d_xmit.h	442;"	d
-DESC8723D_RATEVHTSS1MCS2	include/rtl8723d_xmit.h	443;"	d
-DESC8723D_RATEVHTSS1MCS3	include/rtl8723d_xmit.h	444;"	d
-DESC8723D_RATEVHTSS1MCS4	include/rtl8723d_xmit.h	445;"	d
-DESC8723D_RATEVHTSS1MCS5	include/rtl8723d_xmit.h	446;"	d
-DESC8723D_RATEVHTSS1MCS6	include/rtl8723d_xmit.h	447;"	d
-DESC8723D_RATEVHTSS1MCS7	include/rtl8723d_xmit.h	448;"	d
-DESC8723D_RATEVHTSS1MCS8	include/rtl8723d_xmit.h	449;"	d
-DESC8723D_RATEVHTSS1MCS9	include/rtl8723d_xmit.h	450;"	d
-DESC8723D_RATEVHTSS2MCS0	include/rtl8723d_xmit.h	451;"	d
-DESC8723D_RATEVHTSS2MCS1	include/rtl8723d_xmit.h	452;"	d
-DESC8723D_RATEVHTSS2MCS2	include/rtl8723d_xmit.h	453;"	d
-DESC8723D_RATEVHTSS2MCS3	include/rtl8723d_xmit.h	454;"	d
-DESC8723D_RATEVHTSS2MCS4	include/rtl8723d_xmit.h	455;"	d
-DESC8723D_RATEVHTSS2MCS5	include/rtl8723d_xmit.h	456;"	d
-DESC8723D_RATEVHTSS2MCS6	include/rtl8723d_xmit.h	457;"	d
-DESC8723D_RATEVHTSS2MCS7	include/rtl8723d_xmit.h	458;"	d
-DESC8723D_RATEVHTSS2MCS8	include/rtl8723d_xmit.h	459;"	d
-DESC8723D_RATEVHTSS2MCS9	include/rtl8723d_xmit.h	460;"	d
-DESC_RATE11M	include/hal_com.h	41;"	d
-DESC_RATE12M	include/hal_com.h	46;"	d
-DESC_RATE18M	include/hal_com.h	47;"	d
-DESC_RATE1M	include/hal_com.h	38;"	d
-DESC_RATE24M	include/hal_com.h	48;"	d
-DESC_RATE2M	include/hal_com.h	39;"	d
-DESC_RATE36M	include/hal_com.h	49;"	d
-DESC_RATE48M	include/hal_com.h	50;"	d
-DESC_RATE54M	include/hal_com.h	51;"	d
-DESC_RATE5_5M	include/hal_com.h	40;"	d
-DESC_RATE6M	include/hal_com.h	44;"	d
-DESC_RATE9M	include/hal_com.h	45;"	d
-DESC_RATEMCS0	include/hal_com.h	54;"	d
-DESC_RATEMCS1	include/hal_com.h	55;"	d
-DESC_RATEMCS10	include/hal_com.h	64;"	d
-DESC_RATEMCS11	include/hal_com.h	65;"	d
-DESC_RATEMCS12	include/hal_com.h	66;"	d
-DESC_RATEMCS13	include/hal_com.h	67;"	d
-DESC_RATEMCS14	include/hal_com.h	68;"	d
-DESC_RATEMCS15	include/hal_com.h	69;"	d
-DESC_RATEMCS16	include/hal_com.h	70;"	d
-DESC_RATEMCS17	include/hal_com.h	71;"	d
-DESC_RATEMCS18	include/hal_com.h	72;"	d
-DESC_RATEMCS19	include/hal_com.h	73;"	d
-DESC_RATEMCS2	include/hal_com.h	56;"	d
-DESC_RATEMCS20	include/hal_com.h	74;"	d
-DESC_RATEMCS21	include/hal_com.h	75;"	d
-DESC_RATEMCS22	include/hal_com.h	76;"	d
-DESC_RATEMCS23	include/hal_com.h	77;"	d
-DESC_RATEMCS24	include/hal_com.h	78;"	d
-DESC_RATEMCS25	include/hal_com.h	79;"	d
-DESC_RATEMCS26	include/hal_com.h	80;"	d
-DESC_RATEMCS27	include/hal_com.h	81;"	d
-DESC_RATEMCS28	include/hal_com.h	82;"	d
-DESC_RATEMCS29	include/hal_com.h	83;"	d
-DESC_RATEMCS3	include/hal_com.h	57;"	d
-DESC_RATEMCS30	include/hal_com.h	84;"	d
-DESC_RATEMCS31	include/hal_com.h	85;"	d
-DESC_RATEMCS4	include/hal_com.h	58;"	d
-DESC_RATEMCS5	include/hal_com.h	59;"	d
-DESC_RATEMCS6	include/hal_com.h	60;"	d
-DESC_RATEMCS7	include/hal_com.h	61;"	d
-DESC_RATEMCS8	include/hal_com.h	62;"	d
-DESC_RATEMCS9	include/hal_com.h	63;"	d
-DESC_RATEVHTSS1MCS0	include/hal_com.h	86;"	d
-DESC_RATEVHTSS1MCS1	include/hal_com.h	87;"	d
-DESC_RATEVHTSS1MCS2	include/hal_com.h	88;"	d
-DESC_RATEVHTSS1MCS3	include/hal_com.h	89;"	d
-DESC_RATEVHTSS1MCS4	include/hal_com.h	90;"	d
-DESC_RATEVHTSS1MCS5	include/hal_com.h	91;"	d
-DESC_RATEVHTSS1MCS6	include/hal_com.h	92;"	d
-DESC_RATEVHTSS1MCS7	include/hal_com.h	93;"	d
-DESC_RATEVHTSS1MCS8	include/hal_com.h	94;"	d
-DESC_RATEVHTSS1MCS9	include/hal_com.h	95;"	d
-DESC_RATEVHTSS2MCS0	include/hal_com.h	96;"	d
-DESC_RATEVHTSS2MCS1	include/hal_com.h	97;"	d
-DESC_RATEVHTSS2MCS2	include/hal_com.h	98;"	d
-DESC_RATEVHTSS2MCS3	include/hal_com.h	99;"	d
-DESC_RATEVHTSS2MCS4	include/hal_com.h	100;"	d
-DESC_RATEVHTSS2MCS5	include/hal_com.h	101;"	d
-DESC_RATEVHTSS2MCS6	include/hal_com.h	102;"	d
-DESC_RATEVHTSS2MCS7	include/hal_com.h	103;"	d
-DESC_RATEVHTSS2MCS8	include/hal_com.h	104;"	d
-DESC_RATEVHTSS2MCS9	include/hal_com.h	105;"	d
-DESC_RATEVHTSS3MCS0	include/hal_com.h	106;"	d
-DESC_RATEVHTSS3MCS1	include/hal_com.h	107;"	d
-DESC_RATEVHTSS3MCS2	include/hal_com.h	108;"	d
-DESC_RATEVHTSS3MCS3	include/hal_com.h	109;"	d
-DESC_RATEVHTSS3MCS4	include/hal_com.h	110;"	d
-DESC_RATEVHTSS3MCS5	include/hal_com.h	111;"	d
-DESC_RATEVHTSS3MCS6	include/hal_com.h	112;"	d
-DESC_RATEVHTSS3MCS7	include/hal_com.h	113;"	d
-DESC_RATEVHTSS3MCS8	include/hal_com.h	114;"	d
-DESC_RATEVHTSS3MCS9	include/hal_com.h	115;"	d
-DESC_RATEVHTSS4MCS0	include/hal_com.h	116;"	d
-DESC_RATEVHTSS4MCS1	include/hal_com.h	117;"	d
-DESC_RATEVHTSS4MCS2	include/hal_com.h	118;"	d
-DESC_RATEVHTSS4MCS3	include/hal_com.h	119;"	d
-DESC_RATEVHTSS4MCS4	include/hal_com.h	120;"	d
-DESC_RATEVHTSS4MCS5	include/hal_com.h	121;"	d
-DESC_RATEVHTSS4MCS6	include/hal_com.h	122;"	d
-DESC_RATEVHTSS4MCS7	include/hal_com.h	123;"	d
-DESC_RATEVHTSS4MCS8	include/hal_com.h	124;"	d
-DESC_RATEVHTSS4MCS9	include/hal_com.h	125;"	d
-DEV_ADHOC_LD_NUM	include/drv_types.h	1072;"	d
-DEV_ADHOC_NUM	include/drv_types.h	1071;"	d
-DEV_AP_LD_NUM	include/drv_types.h	1070;"	d
-DEV_AP_NUM	include/drv_types.h	1069;"	d
-DEV_BUS_TYPE	hal/phydm/phydm_types.h	160;"	d
-DEV_BUS_TYPE	hal/phydm/phydm_types.h	210;"	d
-DEV_BUS_TYPE	hal/phydm/phydm_types.h	212;"	d
-DEV_BUS_TYPE	hal/phydm/phydm_types.h	214;"	d
-DEV_BUS_TYPE	hal/phydm/phydm_types.h	216;"	d
-DEV_MGMT_TX_NUM	include/drv_types.h	1075;"	d
-DEV_ROCH_NUM	include/drv_types.h	1074;"	d
-DEV_STA_LD_NUM	include/drv_types.h	1067;"	d
-DEV_STA_LG_NUM	include/drv_types.h	1068;"	d
-DEV_STA_NUM	include/drv_types.h	1066;"	d
-DEV_U_BW	include/drv_types.h	1077;"	d
-DEV_U_CH	include/drv_types.h	1076;"	d
-DEV_U_OFFSET	include/drv_types.h	1078;"	d
-DEV_WPS_NUM	include/drv_types.h	1073;"	d
-DFIRloss	hal/phydm/phydm_adaptivity.h	28;"	d
-DFS_MASTER_TIMER_MS	include/rtw_mlme_ext.h	499;"	d
-DFS_MASTER_WK_CID	include/rtw_cmd.h	/^	DFS_MASTER_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-DFS_RegionDomain	hal/phydm/phydm.h	/^	u1Byte DFS_RegionDomain;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DFS_VERSION	hal/phydm/phydm_dfs.h	24;"	d
-DF_IO_BIT	include/drv_types.h	1504;"	d
-DF_RX_BIT	include/drv_types.h	1503;"	d
-DF_TX_BIT	include/drv_types.h	1502;"	d
-DHCP_MAGIC	core/rtw_br_ext.c	1497;"	d	file:
-DIG_Dynamic_MIN_0	hal/phydm/phydm_dig.h	/^	u1Byte		DIG_Dynamic_MIN_0;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-DIG_Dynamic_MIN_1	hal/phydm/phydm_dig.h	/^	u1Byte		DIG_Dynamic_MIN_1;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-DIG_GOUPCHECK_LEVEL	hal/phydm/phydm_dig.h	/^} DIG_GOUPCHECK_LEVEL;$/;"	t	typeref:enum:tag_DIG_GoUpCheck_Level
-DIG_GOUPCHECK_LEVEL_0	hal/phydm/phydm_dig.h	/^	DIG_GOUPCHECK_LEVEL_0,$/;"	e	enum:tag_DIG_GoUpCheck_Level
-DIG_GOUPCHECK_LEVEL_1	hal/phydm/phydm_dig.h	/^	DIG_GOUPCHECK_LEVEL_1,$/;"	e	enum:tag_DIG_GoUpCheck_Level
-DIG_GOUPCHECK_LEVEL_2	hal/phydm/phydm_dig.h	/^	DIG_GOUPCHECK_LEVEL_2$/;"	e	enum:tag_DIG_GoUpCheck_Level
-DIG_GoUpCheck_Level	hal/phydm/phydm_dig.h	/^	DIG_GOUPCHECK_LEVEL		DIG_GoUpCheck_Level;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-DIG_OP_TYPE_MAX	hal/phydm/phydm_dig.h	/^	DIG_OP_TYPE_MAX$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_T	hal/phydm/phydm_dig.h	/^}DIG_T,*pDIG_T;$/;"	t	typeref:struct:_Dynamic_Initial_Gain_Threshold_
-DIG_TYPE_BACKOFF	hal/phydm/phydm_dig.h	/^	DIG_TYPE_BACKOFF		= 2,$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_TYPE_DISABLE	hal/phydm/phydm_dig.h	/^	DIG_TYPE_DISABLE 		= 6,	$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_TYPE_ENABLE	hal/phydm/phydm_dig.h	/^	DIG_TYPE_ENABLE 		= 5,$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_TYPE_RX_GAIN_MAX	hal/phydm/phydm_dig.h	/^	DIG_TYPE_RX_GAIN_MAX	= 4,$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_TYPE_RX_GAIN_MIN	hal/phydm/phydm_dig.h	/^	DIG_TYPE_RX_GAIN_MIN	= 3,$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_TYPE_THRESH_HIGH	hal/phydm/phydm_dig.h	/^	DIG_TYPE_THRESH_HIGH	= 0,$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_TYPE_THRESH_LOW	hal/phydm/phydm_dig.h	/^	DIG_TYPE_THRESH_LOW	= 1,$/;"	e	enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DIG_VERSION	hal/phydm/phydm_dig.h	24;"	d
-DISABLE_BB_RF	include/autoconf.h	127;"	d
-DISABLE_TRXPKT_BUF_ACCESS	include/hal_com_reg.h	31;"	d
-DISABLE_VCS	include/wlan_bssdef.h	/^	DISABLE_VCS,$/;"	e	enum:VRTL_CARRIER_SENSE
-DISCONNECT_BY_CHK_BCN_FAIL_OBSERV_PERIOD_IN_MS	core/rtw_wlan_util.c	57;"	d	file:
-DISCONNECT_BY_CHK_BCN_FAIL_THRESHOLD	core/rtw_wlan_util.c	58;"	d	file:
-DISDATAFB	include/rtl8188e_xmit.h	76;"	d
-DISDATAFB	include/rtl8192e_xmit.h	181;"	d
-DISDATAFB	include/rtl8812a_xmit.h	74;"	d
-DIS_ATIM	include/hal_com_reg.h	1498;"	d
-DIS_BCNQ_SUB	include/hal_com_reg.h	1499;"	d
-DIS_GCLK	include/hal_com_reg.h	1534;"	d
-DIS_RX_BSSID_FIT	include/hal_com_reg.h	1496;"	d
-DIS_TSF_UDT	include/hal_com_reg.h	1500;"	d
-DIS_TSF_UDT0_NORMAL_CHIP	include/hal_com_reg.h	1503;"	d
-DIS_TSF_UDT0_TEST_CHIP	include/hal_com_reg.h	1504;"	d
-DIVOFF_CSION	hal/phydm/phydm_antdiv.h	110;"	d
-DIVON_CSIOFF	hal/phydm/phydm_antdiv.h	109;"	d
-DIV_pass	hal/phydm/phydm_antdiv.h	/^	BOOLEAN DIV_pass;	$/;"	m	struct:_BF_DIV_COEX_
-DL_FW_MAX	hal/rtl8723d/rtl8723d_hal_init.c	28;"	d	file:
-DMA_BIT_MASK	include/osdep_service_linux.h	184;"	d
-DMEM_CHKSUM_OK	include/rtl8814a_spec.h	502;"	d
-DMEM_DL_RDY	include/rtl8814a_spec.h	501;"	d
-DMP_P2P_DEVCAP_SUPPORT	include/wifi.h	1178;"	d
-DMP_P2P_GRPCAP_SUPPORT	include/wifi.h	1183;"	d
-DM_ACS	hal/phydm/phydm.h	/^	ACS							DM_ACS;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_BdcTable	hal/phydm/phydm.h	/^	BDC_T					DM_BdcTable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_CCX_INFO	hal/phydm/phydm.h	/^	CCX_INFO					DM_CCX_INFO;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_CTRL_WK_CID	include/rtw_cmd.h	/^	DM_CTRL_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-DM_CfoTrack	hal/phydm/phydm.h	/^	CFO_TRACKING    				DM_CfoTrack;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_DIG_BACKOFF_DEFAULT	hal/phydm/phydm_dig.h	268;"	d
-DM_DIG_BACKOFF_MAX	hal/phydm/phydm_dig.h	266;"	d
-DM_DIG_BACKOFF_MIN	hal/phydm/phydm_dig.h	267;"	d
-DM_DIG_FA_TH0	hal/phydm/phydm_dig.h	251;"	d
-DM_DIG_FA_TH0	hal/phydm/phydm_dig.h	253;"	d
-DM_DIG_FA_TH0	hal/phydm/phydm_dig.h	256;"	d
-DM_DIG_FA_TH0_92D	hal/phydm/phydm_dig.h	262;"	d
-DM_DIG_FA_TH0_LPS	hal/phydm/phydm_dig.h	270;"	d
-DM_DIG_FA_TH1	hal/phydm/phydm_dig.h	259;"	d
-DM_DIG_FA_TH1_92D	hal/phydm/phydm_dig.h	263;"	d
-DM_DIG_FA_TH1_LPS	hal/phydm/phydm_dig.h	271;"	d
-DM_DIG_FA_TH2	hal/phydm/phydm_dig.h	260;"	d
-DM_DIG_FA_TH2_92D	hal/phydm/phydm_dig.h	264;"	d
-DM_DIG_FA_TH2_LPS	hal/phydm/phydm_dig.h	272;"	d
-DM_DIG_MAX_AP	hal/phydm/phydm_dig.h	226;"	d
-DM_DIG_MAX_AP_COVERAGR	hal/phydm/phydm_dig.h	238;"	d
-DM_DIG_MAX_AP_HP	hal/phydm/phydm_dig.h	234;"	d
-DM_DIG_MAX_NIC	hal/phydm/phydm_dig.h	222;"	d
-DM_DIG_MAX_NIC_HP	hal/phydm/phydm_dig.h	231;"	d
-DM_DIG_MAX_OF_MIN	hal/phydm/phydm_dig.h	228;"	d
-DM_DIG_MAX_OF_MIN_COVERAGE	hal/phydm/phydm_dig.h	240;"	d
-DM_DIG_MAX_OF_MIN_NIC	hal/phydm/phydm_dig.h	224;"	d
-DM_DIG_MAX_PAUSE_TYPE	hal/phydm/phydm_dig.h	27;"	d
-DM_DIG_MIN_AP	hal/phydm/phydm_dig.h	227;"	d
-DM_DIG_MIN_AP_COVERAGE	hal/phydm/phydm_dig.h	239;"	d
-DM_DIG_MIN_AP_DFS	hal/phydm/phydm_dig.h	229;"	d
-DM_DIG_MIN_AP_HP	hal/phydm/phydm_dig.h	235;"	d
-DM_DIG_MIN_NIC	hal/phydm/phydm_dig.h	223;"	d
-DM_DIG_MIN_NIC_HP	hal/phydm/phydm_dig.h	232;"	d
-DM_DIG_OP_E	hal/phydm/phydm_dig.h	/^}DM_DIG_OP_E;$/;"	t	typeref:enum:tag_Dynamic_Init_Gain_Operation_Type_Definition
-DM_DIG_THRESH_HIGH	hal/phydm/phydm_dig.h	216;"	d
-DM_DIG_THRESH_LOW	hal/phydm/phydm_dig.h	217;"	d
-DM_DIG_TP_Target_TH0	hal/phydm/phydm_dig.h	242;"	d
-DM_DIG_TP_Target_TH1	hal/phydm/phydm_dig.h	243;"	d
-DM_DIG_TP_Training_Period	hal/phydm/phydm_dig.h	244;"	d
-DM_DigTable	hal/phydm/phydm.h	/^	DIG_T						DM_DigTable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_EDCA_Table	hal/phydm/phydm.h	/^	EDCA_T		DM_EDCA_Table;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_FALSEALARM_THRESH_HIGH	hal/phydm/phydm_dig.h	220;"	d
-DM_FALSEALARM_THRESH_LOW	hal/phydm/phydm_dig.h	219;"	d
-DM_FatTable	hal/phydm/phydm.h	/^	FAT_T						DM_FatTable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_IN_LPS_WK_CID	include/rtw_cmd.h	/^	DM_IN_LPS_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-DM_ODM_T	hal/phydm/phydm.h	/^} DM_ODM_T, *PDM_ODM_T;		\/*DM_Dynamic_Mechanism_Structure*\/$/;"	t	typeref:struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_Out_Source_Dynamic_Mechanism_Structure	hal/phydm/phydm.h	/^typedef  struct DM_Out_Source_Dynamic_Mechanism_Structure$/;"	s
-DM_PSTable	hal/phydm/phydm.h	/^	PS_T						DM_PSTable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_PathDiv	hal/phydm/phydm.h	/^	PATHDIV_T	DM_PathDiv;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_PriCCA	hal/phydm/phydm.h	/^	Pri_CCA_T					DM_PriCCA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_RATR_STA_HIGH	hal/phydm/phydm_rainfo.h	77;"	d
-DM_RATR_STA_INIT	hal/phydm/phydm_rainfo.h	76;"	d
-DM_RATR_STA_LOW	hal/phydm/phydm_rainfo.h	79;"	d
-DM_RATR_STA_MIDDLE	hal/phydm/phydm_rainfo.h	78;"	d
-DM_RATR_STA_ULTRA_LOW	hal/phydm/phydm_rainfo.h	80;"	d
-DM_RA_MSK_WK_CID	include/rtw_cmd.h	/^	DM_RA_MSK_WK_CID, \/* add for STA update RAMask when bandwith change. *\/$/;"	e	enum:rtw_drvextra_cmd_id
-DM_RA_Table	hal/phydm/phydm.h	/^	RA_T						DM_RA_Table;  $/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_SWAS_E	hal/phydm/phydm_antdect.h	/^}DM_SWAS_E;$/;"	t	typeref:enum:tag_SW_Antenna_Switch_Definition
-DM_SWAT_Table	hal/phydm/phydm.h	/^	SWAT_T						DM_SWAT_Table;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DM_Type	include/hal_data.h	/^	u8			DM_Type;$/;"	m	struct:hal_com_data
-DM_Type_ByDriver	hal/phydm/phydm.h	166;"	d
-DM_Type_ByFW	hal/phydm/phydm.h	165;"	d
-DOMAIN_ETSI	include/wifi.h	/^	DOMAIN_ETSI		= 3,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_FCC	include/wifi.h	/^	DOMAIN_FCC		= 1,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_FRANCE	include/wifi.h	/^	DOMAIN_FRANCE	= 5,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_IC	include/wifi.h	/^	DOMAIN_IC		= 2,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_ISRAEL	include/wifi.h	/^	DOMAIN_ISRAEL	= 7,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_MAX	include/wifi.h	/^	DOMAIN_MAX$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_MKK	include/wifi.h	/^	DOMAIN_MKK		= 6,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_MKK1	include/wifi.h	/^	DOMAIN_MKK1		= 8,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_MKK2	include/wifi.h	/^	DOMAIN_MKK2		= 9,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_MKK3	include/wifi.h	/^	DOMAIN_MKK3		= 10,$/;"	e	enum:WIFI_REG_DOMAIN
-DOMAIN_SPAIN	include/wifi.h	/^	DOMAIN_SPAIN	= 4,$/;"	e	enum:WIFI_REG_DOMAIN
-DOWN_LINK	include/hal_com.h	/^	DOWN_LINK,$/;"	e	enum:__anon2
-DPK_DELTA_MAPPING_NUM	hal/phydm/phydm_powertracking_ap.h	36;"	d
-DPK_DELTA_MAPPING_NUM	hal/phydm/phydm_powertracking_ce.h	26;"	d
-DPK_DELTA_MAPPING_NUM	hal/phydm/phydm_powertracking_win.h	26;"	d
-DPK_Done	hal/phydm/phydm.h	/^	BOOLEAN			DPK_Done;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DPK_THRESHOLD	hal/phydm/phydm.h	171;"	d
-DP_BB_REG_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	3042;"	d	file:
-DP_DPK_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	3046;"	d	file:
-DP_DPK_VALUE_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	3047;"	d	file:
-DP_PATH_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	3045;"	d	file:
-DP_RETRY_LIMIT	hal/phydm/rtl8723d/halphyrf_8723d.c	3044;"	d	file:
-DP_RF_REG_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	3043;"	d	file:
-DRIVERVERSION	include/rtw_version.h	1;"	d
-DRIVERVERSION	os_dep/linux/os_intfs.c	/^MODULE_VERSION(DRIVERVERSION);$/;"	v
-DRIVER_CFG80211	include/rtw_mlme.h	/^	DRIVER_CFG80211 = 2$/;"	e	enum:DriverInterface
-DRIVER_DISAPPEAR	include/drv_types.h	/^	DRIVER_DISAPPEAR = 1,$/;"	e	enum:_DRIVER_STATE
-DRIVER_EARLY_INT_TIME_8188E	include/rtl8188e_hal.h	113;"	d
-DRIVER_EARLY_INT_TIME_8188F	include/rtl8188f_hal.h	86;"	d
-DRIVER_EARLY_INT_TIME_8192E	include/rtl8192e_hal.h	112;"	d
-DRIVER_EARLY_INT_TIME_8703B	include/rtl8703b_hal.h	86;"	d
-DRIVER_EARLY_INT_TIME_8723B	include/rtl8723b_hal.h	86;"	d
-DRIVER_EARLY_INT_TIME_8723D	include/rtl8723d_hal.h	90;"	d
-DRIVER_EARLY_INT_TIME_8812	include/rtl8812a_hal.h	123;"	d
-DRIVER_EARLY_INT_TIME_8814	include/rtl8814a_hal.h	176;"	d
-DRIVER_NORMAL	include/drv_types.h	/^	DRIVER_NORMAL = 0,$/;"	e	enum:_DRIVER_STATE
-DRIVER_PREFIX	include/rtw_debug.h	34;"	d
-DRIVER_REPLACE_DONGLE	include/drv_types.h	/^	DRIVER_REPLACE_DONGLE = 2,$/;"	e	enum:_DRIVER_STATE
-DRIVER_STATE	include/drv_types.h	/^} DRIVER_STATE;$/;"	t	typeref:enum:_DRIVER_STATE
-DRIVER_WEXT	include/rtw_mlme.h	/^	DRIVER_WEXT =  1,$/;"	e	enum:DriverInterface
-DROP	hal/phydm/phydm_rainfo.h	/^	u2Byte DROP;$/;"	m	struct:_ODM_RA_Info_
-DROP_DATA_EN	include/hal_com_reg.h	1421;"	d
-DRVINFO_SZ	include/rtw_recv.h	64;"	d
-DRV_NAME	include/autoconf.h	26;"	d
-DR_VARIABLE_STRUCT	include/rtw_mp_ioctl.h	/^} DR_VARIABLE_STRUCT;$/;"	t	typeref:struct:_DR_VARIABLE_STRUCT_
-DSConfig	include/wlan_bssdef.h	/^	ULONG           DSConfig;           \/* channel number *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION
-DTC_BASE	hal/phydm/phydm.c	2459;"	d	file:
-DTC_DWN_BASE	hal/phydm/phydm.c	2460;"	d	file:
-DUAL_TSF_RST_P2P	include/hal_com_reg.h	1517;"	d
-DUMP_5G_BW40_BASE_SECTION_NUM	hal/hal_com_phycfg.c	1112;"	d	file:
-DUMP_ADAPTERS_STATUS	core/rtw_ap.c	1253;"	d	file:
-DUMP_ADAPTERS_STATUS	core/rtw_mlme_ext.c	15056;"	d	file:
-DUMP_DRV_RX_COUNTER	include/hal_com.h	298;"	d
-DUMP_DRV_TRX_COUNTER_DATA	include/hal_com.h	301;"	d
-DUMP_MAC_RX_COUNTER	include/hal_com.h	299;"	d
-DUMP_PHY_RX_COUNTER	include/hal_com.h	300;"	d
-DYNAMIC_BBPWRSAV_VERSION	hal/phydm/phydm_dynamicbbpowersaving.h	24;"	d
-DYNAMIC_CHK_WK_CID	include/rtw_cmd.h	/^	DYNAMIC_CHK_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-DYNAMIC_FUNC_DISABLE	include/hal_com.h	566;"	d
-DYNAMIC_TXPWR_VERSION	hal/phydm/phydm_dynamictxpower.h	26;"	d
-D_CUT_VERSION	include/HalVerDef.h	/^	D_CUT_VERSION		=	3,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-Data	include/rtw_btcoex.h	/^	u8		Data[1]; \/* byte1 is extension event code *\/$/;"	m	struct:_PACKET_IRP_HCIEVENT_DATA
-Data	include/rtw_mp_ioctl.h	/^	u8 Data[256];$/;"	m	struct:_BURST_RW_REG
-DataRate	hal/phydm/phydm.h	/^	u1Byte		DataRate;$/;"	m	struct:_ODM_Per_Pkt_Info_
-DataRetry	include/rtw_efuse.h	/^	const u16  DataRetry;$/;"	m	struct:_EFUSE_HAL
-Date	include/rtl8188e_hal.h	/^	u8		Date;	\/* Release time Date field *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Date	include/rtl8188f_hal.h	/^	u8		Date;	\/* Release time Date field *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Date	include/rtl8703b_hal.h	/^	u8		Date;	\/* Release time Date field *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Date	include/rtl8723b_hal.h	/^	u8		Date;	\/* Release time Date field *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Date	include/rtl8723d_hal.h	/^	u8		Date;	\/* Release time Date field *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-DbgPrint	hal/phydm/phydm_debug.h	136;"	d
-DbgPrint	hal/phydm/phydm_debug.h	140;"	d
-DeInitLed	hal/led/hal_sdio_led.c	/^DeInitLed($/;"	f
-DeInitSwLeds	include/hal_intf.h	/^	void	(*DeInitSwLeds)(_adapter *padapter);$/;"	m	struct:hal_ops
-DebugComponent_H32	include/rtw_mp_ioctl.h	/^	u32 DebugComponent_H32;$/;"	m	struct:CFG_DBG_MSG_STRUCT
-DebugComponent_L32	include/rtw_mp_ioctl.h	/^	u32 DebugComponent_L32;$/;"	m	struct:CFG_DBG_MSG_STRUCT
-DebugComponents	hal/phydm/phydm.h	/^	u4Byte			DebugComponents;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DebugLevel	hal/phydm/phydm.h	/^	u4Byte			DebugLevel;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-DebugLevel	include/rtw_mp_ioctl.h	/^	u32 DebugLevel;$/;"	m	struct:CFG_DBG_MSG_STRUCT
-DecisionRate	hal/phydm/phydm_rainfo.h	/^	u1Byte DecisionRate;$/;"	m	struct:_ODM_RA_Info_
-DefXCap	hal/phydm/phydm_cfotracking.h	/^	u1Byte			DefXCap;$/;"	m	struct:_CFO_TRACKING_
-Default	include/drv_types_ce.h	/^	u32			Default;		\/* default value to use *\/$/;"	m	struct:_MP_REG_ENTRY
-Default	include/drv_types_ce.h	/^	u64			Default;$/;"	m	struct:_MP_REG_ENTRY
-Default	include/drv_types_xp.h	/^	u32			Default;		\/* default value to use *\/$/;"	m	struct:_MP_REG_ENTRY
-Default	include/drv_types_xp.h	/^	u64			Default;$/;"	m	struct:_MP_REG_ENTRY
-DefaultBbSwingIndexFlag	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN		DefaultBbSwingIndexFlag;$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultBbSwingIndexFlag	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN		DefaultBbSwingIndexFlag;$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultCSICnt	hal/phydm/phydm_beamforming.h	/^	u2Byte	DefaultCSICnt:5;		\/\/ 0~21$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-DefaultCSICnt	include/rtw_beamforming.h	/^	u16 DefaultCSICnt:5; \/* 0~21 *\/$/;"	m	struct:beamformee_entry
-DefaultCckIndex	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			DefaultCckIndex;	$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultCckIndex	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			DefaultCckIndex;	$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultCckIndex	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			DefaultCckIndex;	$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultCsiCnt	include/rtw_beamforming.h	/^	u8	DefaultCsiCnt;$/;"	m	struct:beamforming_entry
-DefaultOfdmIndex	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			DefaultOfdmIndex;$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultOfdmIndex	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			DefaultOfdmIndex;$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultOfdmIndex	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			DefaultOfdmIndex;$/;"	m	struct:ODM_RF_Calibration_Structure
-DefaultS0S1	hal/phydm/phydm_antdiv.h	/^	u1Byte	DefaultS0S1;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-DelayLPSLastTimeStamp	include/rtw_pwrctrl.h	/^	u32	DelayLPSLastTimeStamp;$/;"	m	struct:pwrctrl_priv
-DeltaPowerIndex	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte	DeltaPowerIndex;$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaPowerIndex	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte	DeltaPowerIndex[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaPowerIndex	hal/phydm/phydm_powertracking_win.h	/^	s1Byte	DeltaPowerIndex[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaPowerIndexLast	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte	DeltaPowerIndexLast;	$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaPowerIndexLast	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte	DeltaPowerIndexLast[MAX_RF_PATH];	$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaPowerIndexLast	hal/phydm/phydm_powertracking_win.h	/^	s1Byte	DeltaPowerIndexLast[MAX_RF_PATH];	$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GA	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GA[DELTA_SWINTSSI_SIZE];                $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GA	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GA[DELTA_SWINTSSI_SIZE];                $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GA	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GA[DELTA_SWINTSSI_SIZE];                $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GB	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GB[DELTA_SWINTSSI_SIZE];              $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GB	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GB[DELTA_SWINTSSI_SIZE];              $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GB	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GB[DELTA_SWINTSSI_SIZE];              $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GC	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GC[DELTA_SWINTSSI_SIZE];                   $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GC	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GC[DELTA_SWINTSSI_SIZE];                   $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GC	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GC[DELTA_SWINTSSI_SIZE];                   $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKA	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKA[DELTA_SWINTSSI_SIZE];         $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKA	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKA[DELTA_SWINTSSI_SIZE];         $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKA	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKA[DELTA_SWINTSSI_SIZE];         $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKB	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKB[DELTA_SWINTSSI_SIZE];           $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKB	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKB[DELTA_SWINTSSI_SIZE];           $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKB	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKB[DELTA_SWINTSSI_SIZE];           $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKC	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKC[DELTA_SWINTSSI_SIZE];            $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKC	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKC[DELTA_SWINTSSI_SIZE];            $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKC	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKC[DELTA_SWINTSSI_SIZE];            $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKD	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKD[DELTA_SWINTSSI_SIZE];            $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKD	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKD[DELTA_SWINTSSI_SIZE];            $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GCCKD	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GCCKD[DELTA_SWINTSSI_SIZE];            $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GD	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_2GD[DELTA_SWINTSSI_SIZE];                $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GD	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_2GD[DELTA_SWINTSSI_SIZE];                $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_2GD	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_2GD[DELTA_SWINTSSI_SIZE];                $/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GA	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_5GA[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GA	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_5GA[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GA	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_5GA[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GB	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_5GB[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GB	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_5GB[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GB	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_5GB[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GC	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_5GC[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GC	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_5GC[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GC	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_5GC[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GD	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTSSITable_5GD[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GD	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTSSITable_5GD[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTSSITable_5GD	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTSSITable_5GD[BAND_NUM][DELTA_SWINTSSI_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GA_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GA_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GA_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_N_8188E	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GA_N_8188E[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_N_8188E	hal/phydm/phydm_powertracking_ap.h	/^static u1Byte DeltaSwingTableIdx_2GA_N_8188E[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11}; $/;"	v
-DeltaSwingTableIdx_2GA_N_8188E	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GA_N_8188E[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_N_8188E	hal/phydm/phydm_powertracking_ce.h	/^static u1Byte DeltaSwingTableIdx_2GA_N_8188E[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11}; $/;"	v
-DeltaSwingTableIdx_2GA_N_8188E	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GA_N_8188E[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_N_8188E	hal/phydm/phydm_powertracking_win.h	/^static u1Byte DeltaSwingTableIdx_2GA_N_8188E[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5,  6,  6,  7,  7,  7,  7,  8,  8,  9,  9, 10, 10, 10, 11, 11, 11, 11}; $/;"	v
-DeltaSwingTableIdx_2GA_N_DEFAULT	hal/phydm/phydm_powertracking_ap.c	/^u1Byte DeltaSwingTableIdx_2GA_N_DEFAULT[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4$/;"	v
-DeltaSwingTableIdx_2GA_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GA_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GA_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GA_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_P_8188E	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GA_P_8188E[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_P_8188E	hal/phydm/phydm_powertracking_ap.h	/^static u1Byte DeltaSwingTableIdx_2GA_P_8188E[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};$/;"	v
-DeltaSwingTableIdx_2GA_P_8188E	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GA_P_8188E[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_P_8188E	hal/phydm/phydm_powertracking_ce.h	/^static u1Byte DeltaSwingTableIdx_2GA_P_8188E[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};$/;"	v
-DeltaSwingTableIdx_2GA_P_8188E	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GA_P_8188E[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GA_P_8188E	hal/phydm/phydm_powertracking_win.h	/^static u1Byte DeltaSwingTableIdx_2GA_P_8188E[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4,  4,  4,  4,  4,  4,  5,  5,  7,  7,  8,  8,  8,  9,  9,  9,  9,  9};$/;"	v
-DeltaSwingTableIdx_2GA_P_DEFAULT	hal/phydm/phydm_powertracking_ap.c	/^u1Byte DeltaSwingTableIdx_2GA_P_DEFAULT[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3$/;"	v
-DeltaSwingTableIdx_2GB_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GB_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GB_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GB_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GB_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GB_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GB_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GB_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GB_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GB_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GB_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GB_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKA_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKA_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKA_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKA_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKA_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKA_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKA_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKA_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKA_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKA_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKA_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKA_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKB_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKB_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKB_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKB_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKB_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKB_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKB_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKB_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKB_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKB_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKB_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKB_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKC_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKC_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKC_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKC_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKC_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKC_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKC_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKC_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKC_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKC_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKC_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKC_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKD_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKD_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKD_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKD_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKD_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKD_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKD_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKD_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKD_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKD_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GCCKD_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GCCKD_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GC_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GC_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GC_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GC_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GC_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GC_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GC_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GC_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GC_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GC_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GC_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GC_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GD_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GD_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GD_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GD_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GD_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GD_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GD_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_2GD_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GD_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_2GD_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_2GD_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_2GD_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GA_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GA_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GA_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GA_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GA_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GA_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GA_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GA_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GA_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GA_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GA_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GA_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GB_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GB_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GB_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GB_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GB_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GB_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GB_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GB_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GB_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GB_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GB_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GB_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GC_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GC_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GC_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GC_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GC_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GC_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GC_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GC_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GC_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GC_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GC_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GC_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GD_N	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GD_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GD_N	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GD_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GD_N	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GD_N[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GD_P	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  DeltaSwingTableIdx_5GD_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GD_P	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  DeltaSwingTableIdx_5GD_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableIdx_5GD_P	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  DeltaSwingTableIdx_5GD_P[BAND_NUM][DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableXtal_N	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte  DeltaSwingTableXtal_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableXtal_N	hal/phydm/phydm_powertracking_win.h	/^	s1Byte  DeltaSwingTableXtal_N[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableXtal_P	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte  DeltaSwingTableXtal_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-DeltaSwingTableXtal_P	hal/phydm/phydm_powertracking_win.h	/^	s1Byte  DeltaSwingTableXtal_P[DELTA_SWINGIDX_SIZE];$/;"	m	struct:ODM_RF_Calibration_Structure
-Delta_IQK	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	Delta_IQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Delta_IQK	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	Delta_IQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Delta_IQK	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	Delta_IQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Delta_LCK	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	Delta_LCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Delta_LCK	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	Delta_LCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Delta_LCK	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	Delta_LCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-DeviceID	include/drv_types_pci.h	/^	u16	DeviceID;$/;"	m	struct:_PCI_COMMON_CONFIG
-DeviceSpecific	include/drv_types_pci.h	/^	u8	DeviceSpecific[108];$/;"	m	struct:_PCI_COMMON_CONFIG
-Dig_Enable_Flag	hal/phydm/phydm_dig.h	/^	u1Byte		Dig_Enable_Flag;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-Dig_Ext_Port_Stage	hal/phydm/phydm_dig.h	/^	u1Byte		Dig_Ext_Port_Stage;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-DisableInterrupt8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void DisableInterrupt8723DSdio(PADAPTER padapter)$/;"	f
-DisableInterruptButCpwm28723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void DisableInterruptButCpwm28723DSdio(PADAPTER padapter)$/;"	f
-DisconnectEntryNum	include/rtw_btcoex.h	/^	u1Byte				DisconnectEntryNum;$/;"	m	struct:_BT_MGNT
-Disconnect_Wkup_Drv	include/rtw_cmd.h	/^	u8 Disconnect_Wkup_Drv:1;$/;"	m	struct:P2P_WoWlan_Offload_t
-DoIQK	hal/phydm/halphyrf_ap.h	/^	FuncIQK 	DoIQK;$/;"	m	struct:_TXPWRTRACK_CFG
-DoIQK	hal/phydm/halphyrf_ce.h	/^	FuncIQK 	DoIQK;$/;"	m	struct:_TXPWRTRACK_CFG
-DoIQK	hal/phydm/halphyrf_win.h	/^	FuncIQK 	DoIQK;$/;"	m	struct:_TXPWRTRACK_CFG
-DoIQK_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^void DoIQK_8723D($/;"	f
-DoReserved	core/rtw_mlme_ext.c	/^unsigned int DoReserved(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-Domain_2G	hal/phydm/rtchnlplan.h	/^	RT_REGULATION_2G		Domain_2G;$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Domain_2G	hal/phydm/rtchnlplan.h	/^	RT_REGULATION_2G	Domain_2G;	$/;"	m	struct:_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-Domain_5G	hal/phydm/rtchnlplan.h	/^	RT_REGULATION_5G		Domain_5G;	$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Domain_5G	hal/phydm/rtchnlplan.h	/^	RT_REGULATION_5G	Domain_5G;	$/;"	m	struct:_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-Double_chk_flag	hal/phydm/phydm_antdiv.h	/^	u1Byte		Double_chk_flag;	\/*If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than check this antenna again*\/$/;"	m	struct:_SW_Antenna_Switch_
-DpkGain	hal/phydm/phydm_powertracking_ce.h	/^	s4Byte  DpkGain;$/;"	m	struct:ODM_RF_Calibration_Structure
-DpkGain	hal/phydm/phydm_powertracking_win.h	/^	s4Byte  DpkGain;$/;"	m	struct:ODM_RF_Calibration_Structure
-DpkThermal	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte  DpkThermal[4];$/;"	m	struct:ODM_RF_Calibration_Structure
-DpkThermal	hal/phydm/phydm_powertracking_win.h	/^	u4Byte  DpkThermal[4];	$/;"	m	struct:ODM_RF_Calibration_Structure
-DpkTxAGC	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte  DpkTxAGC;$/;"	m	struct:ODM_RF_Calibration_Structure
-DpkTxAGC	hal/phydm/phydm_powertracking_win.h	/^	u4Byte  DpkTxAGC;$/;"	m	struct:ODM_RF_Calibration_Structure
-DriverInterface	include/rtw_mlme.h	/^enum DriverInterface {$/;"	g
-DriverState	include/drv_types.h	/^	int	DriverState;\/* for disable driver using module, use dongle to replace module. *\/$/;"	m	struct:_ADAPTER
-Driver_Write	include/hal_phy.h	/^	u8		Driver_Write;$/;"	m	struct:RF_Shadow_Compare_Map
-DrvBcnEarly	include/rtw_mlme_ext.h	/^	u8 DrvBcnEarly;$/;"	m	struct:mlme_ext_priv
-DrvBcnTimeOut	include/rtw_mlme_ext.h	/^	u8 DrvBcnTimeOut;$/;"	m	struct:mlme_ext_priv
-Dual_Ant_Counter	hal/phydm/phydm_antdiv.h	/^	u2Byte		Dual_Ant_Counter;$/;"	m	struct:_SW_Antenna_Switch_
-DupRTS_flag	hal/phydm/phydm.h	/^	u1Byte	DupRTS_flag;$/;"	m	struct:_Dynamic_Primary_CCA
-DwellTime	include/wlan_bssdef.h	/^	ULONG           DwellTime;          \/* units are Kusec *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION_FH
-DynamicLinkAdaptivity	hal/phydm/phydm_adaptivity.h	/^	BOOLEAN			DynamicLinkAdaptivity;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-DynamicTxHighPowerLvl	hal/phydm/phydm.h	/^	u1Byte			DynamicTxHighPowerLvl;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-EAPOL_ENCAP_ASF_ALERT	include/ieee80211.h	/^	EAPOL_ENCAP_ASF_ALERT$/;"	e	enum:eap_type
-EAPOL_KEY	include/ieee80211.h	/^	EAPOL_KEY,$/;"	e	enum:eap_type
-EAPOL_LOGOFF	include/ieee80211.h	/^	EAPOL_LOGOFF,$/;"	e	enum:eap_type
-EAPOL_START	include/ieee80211.h	/^	EAPOL_START,$/;"	e	enum:eap_type
-EAP_PACKET	include/ieee80211.h	/^	EAP_PACKET = 0,$/;"	e	enum:eap_type
-EARLY_MODE_INFO_SIZE	include/rtw_xmit.h	189;"	d
-EDCATURBO_VERSION	hal/phydm/phydm_edcaturbocheck.h	25;"	d
-EDCA_T	hal/phydm/phydm_edcaturbocheck.h	/^}EDCA_T,*pEDCA_T;$/;"	t	typeref:struct:_EDCA_TURBO_
-EDCCA_enable	hal/phydm/phydm.h	/^	BOOLEAN			EDCCA_enable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-EEPROMBluetoothAntIsolation	include/hal_data.h	/^	u8	EEPROMBluetoothAntIsolation;$/;"	m	struct:hal_com_data
-EEPROMBluetoothAntNum	include/hal_data.h	/^	u8	EEPROMBluetoothAntNum;$/;"	m	struct:hal_com_data
-EEPROMBluetoothCoexist	include/hal_data.h	/^	u8	EEPROMBluetoothCoexist;$/;"	m	struct:hal_com_data
-EEPROMBluetoothRadioShared	include/hal_data.h	/^	u8	EEPROMBluetoothRadioShared;$/;"	m	struct:hal_com_data
-EEPROMBluetoothType	include/hal_data.h	/^	u8	EEPROMBluetoothType;$/;"	m	struct:hal_com_data
-EEPROMCustomerID	include/hal_data.h	/^	u8	EEPROMCustomerID;$/;"	m	struct:hal_com_data
-EEPROMDID	include/hal_data.h	/^	u16	EEPROMDID;$/;"	m	struct:hal_com_data
-EEPROMMACAddr	include/hal_data.h	/^	u8	EEPROMMACAddr[ETH_ALEN];$/;"	m	struct:hal_com_data
-EEPROMPID	include/hal_data.h	/^	u16	EEPROMPID;$/;"	m	struct:hal_com_data
-EEPROMRFGainOffset	include/hal_data.h	/^	u8	EEPROMRFGainOffset;$/;"	m	struct:hal_com_data
-EEPROMRFGainVal	include/hal_data.h	/^	u8	EEPROMRFGainVal;$/;"	m	struct:hal_com_data
-EEPROMRegulatory	include/hal_data.h	/^	u8	EEPROMRegulatory;$/;"	m	struct:hal_com_data
-EEPROMSDID	include/hal_data.h	/^	u16	EEPROMSDID;$/;"	m	struct:hal_com_data
-EEPROMSEL	include/hal_com_reg.h	1206;"	d
-EEPROMSMID	include/hal_data.h	/^	u16	EEPROMSMID;$/;"	m	struct:hal_com_data
-EEPROMSVID	include/hal_data.h	/^	u16	EEPROMSVID;$/;"	m	struct:hal_com_data
-EEPROMSubCustomerID	include/hal_data.h	/^	u8	EEPROMSubCustomerID;$/;"	m	struct:hal_com_data
-EEPROMThermalMeter	include/hal_data.h	/^	u8	EEPROMThermalMeter;$/;"	m	struct:hal_com_data
-EEPROMUsbSwitch	include/hal_data.h	/^	u8	EEPROMUsbSwitch;$/;"	m	struct:hal_com_data
-EEPROMVID	include/hal_data.h	/^	u16	EEPROMVID;$/;"	m	struct:hal_com_data
-EEPROMVersion	include/hal_data.h	/^	u8	EEPROMVersion;$/;"	m	struct:hal_com_data
-EEPROM_2G_5G_PA_TYPE_8188F	include/hal_pg.h	312;"	d
-EEPROM_2G_5G_PA_TYPE_8192E	include/hal_pg.h	84;"	d
-EEPROM_2G_5G_PA_TYPE_8703B	include/hal_pg.h	400;"	d
-EEPROM_2G_5G_PA_TYPE_8723B	include/hal_pg.h	351;"	d
-EEPROM_2G_5G_PA_TYPE_8723D	include/hal_pg.h	548;"	d
-EEPROM_2G_5G_PA_TYPE_8812	include/hal_pg.h	129;"	d
-EEPROM_2G_5G_PA_TYPE_8821C	include/hal_pg.h	494;"	d
-EEPROM_2G_5G_PA_TYPE_8822B	include/hal_pg.h	444;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_8188F	include/hal_pg.h	313;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_8192E	include/hal_pg.h	85;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_8703B	include/hal_pg.h	401;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_8723B	include/hal_pg.h	352;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_8723D	include/hal_pg.h	549;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_8812	include/hal_pg.h	130;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8821C	include/hal_pg.h	496;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_AB_8822B	include/hal_pg.h	446;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_CD_8821C	include/hal_pg.h	498;"	d
-EEPROM_2G_LNA_TYPE_GAIN_SEL_CD_8822B	include/hal_pg.h	448;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_8188F	include/hal_pg.h	314;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_8192E	include/hal_pg.h	86;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_8703B	include/hal_pg.h	402;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_8723B	include/hal_pg.h	353;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_8723D	include/hal_pg.h	550;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_8812	include/hal_pg.h	131;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8821C	include/hal_pg.h	500;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_AB_8822B	include/hal_pg.h	450;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_CD_8821C	include/hal_pg.h	502;"	d
-EEPROM_5G_LNA_TYPE_GAIN_SEL_CD_8822B	include/hal_pg.h	452;"	d
-EEPROM_93C46	include/hal_intf.h	/^	EEPROM_93C46,$/;"	e	enum:_RT_EEPROM_TYPE
-EEPROM_93C56	include/hal_intf.h	/^	EEPROM_93C56,$/;"	e	enum:_RT_EEPROM_TYPE
-EEPROM_BOOT_EFUSE	include/hal_intf.h	/^	EEPROM_BOOT_EFUSE,$/;"	e	enum:_RT_EEPROM_TYPE
-EEPROM_CHANNEL_PLAN_BY_HW_MASK	hal/hal_com.c	200;"	d	file:
-EEPROM_CHANNEL_PLAN_BY_HW_MASK	include/hal_pg.h	617;"	d
-EEPROM_CHANNEL_PLAN_CHIAN	include/hal_pg.h	606;"	d
-EEPROM_CHANNEL_PLAN_ETSI	include/hal_pg.h	596;"	d
-EEPROM_CHANNEL_PLAN_FCC	include/hal_pg.h	594;"	d
-EEPROM_CHANNEL_PLAN_FCC_NO_DFS	include/hal_pg.h	611;"	d
-EEPROM_CHANNEL_PLAN_FRANCE	include/hal_pg.h	598;"	d
-EEPROM_CHANNEL_PLAN_GLOBAL_DOMAIN	include/hal_pg.h	603;"	d
-EEPROM_CHANNEL_PLAN_IC	include/hal_pg.h	595;"	d
-EEPROM_CHANNEL_PLAN_ISRAEL	include/hal_pg.h	601;"	d
-EEPROM_CHANNEL_PLAN_JAPAN	include/hal_pg.h	610;"	d
-EEPROM_CHANNEL_PLAN_JAPAN_NO_DFS	include/hal_pg.h	612;"	d
-EEPROM_CHANNEL_PLAN_KOREA	include/hal_pg.h	608;"	d
-EEPROM_CHANNEL_PLAN_MKK	include/hal_pg.h	599;"	d
-EEPROM_CHANNEL_PLAN_MKK1	include/hal_pg.h	600;"	d
-EEPROM_CHANNEL_PLAN_NCC_TAIWAN	include/hal_pg.h	605;"	d
-EEPROM_CHANNEL_PLAN_SINGAPORE_INDIA_MEXICO	include/hal_pg.h	607;"	d
-EEPROM_CHANNEL_PLAN_SPAIN	include/hal_pg.h	597;"	d
-EEPROM_CHANNEL_PLAN_TAIWAN_NO_DFS	include/hal_pg.h	614;"	d
-EEPROM_CHANNEL_PLAN_TELEC	include/hal_pg.h	602;"	d
-EEPROM_CHANNEL_PLAN_TURKEY	include/hal_pg.h	609;"	d
-EEPROM_CHANNEL_PLAN_WORLD_WIDE_13	include/hal_pg.h	604;"	d
-EEPROM_CHANNEL_PLAN_WORLD_WIDE_5G	include/hal_pg.h	613;"	d
-EEPROM_CID_CCX	include/hal_pg.h	590;"	d
-EEPROM_CID_DEFAULT	include/hal_pg.h	587;"	d
-EEPROM_CID_DEFAULT_EXT	include/hal_pg.h	588;"	d
-EEPROM_CID_QMI	include/hal_pg.h	591;"	d
-EEPROM_CID_TOSHIBA	include/hal_pg.h	589;"	d
-EEPROM_CID_WHQL	include/hal_pg.h	592;"	d
-EEPROM_COUNTRY_CODE_8188F	include/hal_pg.h	325;"	d
-EEPROM_COUNTRY_CODE_8192E	include/hal_pg.h	99;"	d
-EEPROM_COUNTRY_CODE_8703B	include/hal_pg.h	413;"	d
-EEPROM_COUNTRY_CODE_8723B	include/hal_pg.h	364;"	d
-EEPROM_COUNTRY_CODE_8723D	include/hal_pg.h	561;"	d
-EEPROM_COUNTRY_CODE_8812	include/hal_pg.h	143;"	d
-EEPROM_COUNTRY_CODE_8814	include/hal_pg.h	209;"	d
-EEPROM_COUNTRY_CODE_8821C	include/hal_pg.h	513;"	d
-EEPROM_COUNTRY_CODE_8822B	include/hal_pg.h	463;"	d
-EEPROM_COUNTRY_CODE_88E	include/hal_pg.h	50;"	d
-EEPROM_CUSTOMER_ID_8188F	include/hal_pg.h	326;"	d
-EEPROM_ChannelPlan_8188F	include/hal_pg.h	308;"	d
-EEPROM_ChannelPlan_8192E	include/hal_pg.h	80;"	d
-EEPROM_ChannelPlan_8703B	include/hal_pg.h	396;"	d
-EEPROM_ChannelPlan_8723B	include/hal_pg.h	347;"	d
-EEPROM_ChannelPlan_8723D	include/hal_pg.h	544;"	d
-EEPROM_ChannelPlan_8812	include/hal_pg.h	125;"	d
-EEPROM_ChannelPlan_8814	include/hal_pg.h	190;"	d
-EEPROM_ChannelPlan_8821	include/hal_pg.h	238;"	d
-EEPROM_ChannelPlan_8821C	include/hal_pg.h	490;"	d
-EEPROM_ChannelPlan_8822B	include/hal_pg.h	440;"	d
-EEPROM_ChannelPlan_88E	include/hal_pg.h	39;"	d
-EEPROM_CustomID_8188F	include/hal_pg.h	320;"	d
-EEPROM_CustomID_8192E	include/hal_pg.h	92;"	d
-EEPROM_CustomID_8703B	include/hal_pg.h	408;"	d
-EEPROM_CustomID_8723B	include/hal_pg.h	359;"	d
-EEPROM_CustomID_8723D	include/hal_pg.h	556;"	d
-EEPROM_CustomID_8812	include/hal_pg.h	137;"	d
-EEPROM_CustomID_8814	include/hal_pg.h	204;"	d
-EEPROM_CustomID_8821	include/hal_pg.h	248;"	d
-EEPROM_CustomID_8821C	include/hal_pg.h	508;"	d
-EEPROM_CustomID_8822B	include/hal_pg.h	458;"	d
-EEPROM_CustomID_88E	include/hal_pg.h	48;"	d
-EEPROM_DEFAULT_BOARD_OPTION	include/hal_pg.h	679;"	d
-EEPROM_DEFAULT_BT_OPTION	include/hal_pg.h	684;"	d
-EEPROM_DEFAULT_CHANNEL_PLAN	include/hal_pg.h	678;"	d
-EEPROM_DEFAULT_FEATURE_OPTION	include/hal_pg.h	683;"	d
-EEPROM_DEFAULT_RFE_OPTION	include/hal_pg.h	682;"	d
-EEPROM_DEFAULT_RFE_OPTION_8188E	include/hal_pg.h	681;"	d
-EEPROM_DEFAULT_RFE_OPTION_8192E	include/hal_pg.h	680;"	d
-EEPROM_DEFAULT_TX_CALIBRATE_RATE	include/hal_pg.h	687;"	d
-EEPROM_DID_8192EE	include/hal_pg.h	104;"	d
-EEPROM_DID_8723BE	include/hal_pg.h	369;"	d
-EEPROM_DID_8723DE	include/hal_pg.h	566;"	d
-EEPROM_DID_8812AE	include/hal_pg.h	148;"	d
-EEPROM_DID_8814AE	include/hal_pg.h	171;"	d
-EEPROM_DID_8821AE	include/hal_pg.h	254;"	d
-EEPROM_DID_88EE	include/hal_pg.h	55;"	d
-EEPROM_DID_92SE	include/hal_pg.h	275;"	d
-EEPROM_Default_BoardType	include/hal_pg.h	621;"	d
-EEPROM_Default_CrystalCap	include/hal_pg.h	634;"	d
-EEPROM_Default_CrystalCap_8188F	include/hal_pg.h	643;"	d
-EEPROM_Default_CrystalCap_8192E	include/hal_pg.h	639;"	d
-EEPROM_Default_CrystalCap_8703B	include/hal_pg.h	641;"	d
-EEPROM_Default_CrystalCap_8723A	include/hal_pg.h	635;"	d
-EEPROM_Default_CrystalCap_8723B	include/hal_pg.h	640;"	d
-EEPROM_Default_CrystalCap_8723D	include/hal_pg.h	642;"	d
-EEPROM_Default_CrystalCap_8812	include/hal_pg.h	637;"	d
-EEPROM_Default_CrystalCap_8814	include/hal_pg.h	638;"	d
-EEPROM_Default_CrystalCap_88E	include/hal_pg.h	636;"	d
-EEPROM_Default_CrystalFreq	include/hal_pg.h	644;"	d
-EEPROM_Default_CustomerID	include/hal_pg.h	659;"	d
-EEPROM_Default_CustomerID_8188E	include/hal_pg.h	660;"	d
-EEPROM_Default_HT20_Diff	include/hal_pg.h	650;"	d
-EEPROM_Default_HT20_PwrMaxOffset	include/hal_pg.h	655;"	d
-EEPROM_Default_HT40_2SDiff	include/hal_pg.h	649;"	d
-EEPROM_Default_HT40_PwrMaxOffset	include/hal_pg.h	654;"	d
-EEPROM_Default_LNAType	include/hal_pg.h	675;"	d
-EEPROM_Default_LegacyHTTxPowerDiff	include/hal_pg.h	651;"	d
-EEPROM_Default_LegacyHTTxPowerDiff_92C	include/hal_pg.h	652;"	d
-EEPROM_Default_LegacyHTTxPowerDiff_92D	include/hal_pg.h	653;"	d
-EEPROM_Default_PAType	include/hal_pg.h	674;"	d
-EEPROM_Default_PID	include/hal_pg.h	657;"	d
-EEPROM_Default_SubCustomerID	include/hal_pg.h	661;"	d
-EEPROM_Default_TSSI	include/hal_pg.h	620;"	d
-EEPROM_Default_ThermalMeter	include/hal_pg.h	622;"	d
-EEPROM_Default_ThermalMeter_8188F	include/hal_pg.h	630;"	d
-EEPROM_Default_ThermalMeter_8192E	include/hal_pg.h	626;"	d
-EEPROM_Default_ThermalMeter_8703B	include/hal_pg.h	628;"	d
-EEPROM_Default_ThermalMeter_8723B	include/hal_pg.h	627;"	d
-EEPROM_Default_ThermalMeter_8723D	include/hal_pg.h	629;"	d
-EEPROM_Default_ThermalMeter_8812	include/hal_pg.h	625;"	d
-EEPROM_Default_ThermalMeter_8814A	include/hal_pg.h	631;"	d
-EEPROM_Default_ThermalMeter_88E	include/hal_pg.h	624;"	d
-EEPROM_Default_ThermalMeter_92SU	include/hal_pg.h	623;"	d
-EEPROM_Default_TxPowerLevel	include/hal_pg.h	648;"	d
-EEPROM_Default_TxPowerLevel_2G	include/hal_pg.h	646;"	d
-EEPROM_Default_TxPowerLevel_5G	include/hal_pg.h	647;"	d
-EEPROM_Default_TxPowerLevel_92C	include/hal_pg.h	645;"	d
-EEPROM_Default_VID	include/hal_pg.h	658;"	d
-EEPROM_Default_Version	include/hal_pg.h	662;"	d
-EEPROM_Default_externalPA_C9	include/hal_pg.h	664;"	d
-EEPROM_Default_externalPA_CC	include/hal_pg.h	665;"	d
-EEPROM_Default_internalPA_SP3T_C9	include/hal_pg.h	666;"	d
-EEPROM_Default_internalPA_SP3T_CC	include/hal_pg.h	667;"	d
-EEPROM_Default_internalPA_SPDT_C9	include/hal_pg.h	668;"	d
-EEPROM_Default_internalPA_SPDT_CC	include/hal_pg.h	670;"	d
-EEPROM_Default_internalPA_SPDT_CC	include/hal_pg.h	672;"	d
-EEPROM_EN	include/hal_com_reg.h	1207;"	d
-EEPROM_ERASE_OPCODE	include/rtw_eeprom.h	39;"	d
-EEPROM_EWDS_OPCODE	include/rtw_eeprom.h	41;"	d
-EEPROM_EWEN_OPCODE	include/rtw_eeprom.h	40;"	d
-EEPROM_FEATURE_OPTION_8188F	include/hal_pg.h	317;"	d
-EEPROM_FEATURE_OPTION_8703B	include/hal_pg.h	405;"	d
-EEPROM_FEATURE_OPTION_8723B	include/hal_pg.h	356;"	d
-EEPROM_FEATURE_OPTION_8723D	include/hal_pg.h	553;"	d
-EEPROM_FEATURE_OPTION_8821C	include/hal_pg.h	505;"	d
-EEPROM_FEATURE_OPTION_8822B	include/hal_pg.h	455;"	d
-EEPROM_IG_OFFSET_4_AB_2G_8814A	include/hal_pg.h	212;"	d
-EEPROM_IG_OFFSET_4_AB_5GH_8814A	include/hal_pg.h	218;"	d
-EEPROM_IG_OFFSET_4_AB_5GL_8814A	include/hal_pg.h	214;"	d
-EEPROM_IG_OFFSET_4_AB_5GM_8814A	include/hal_pg.h	216;"	d
-EEPROM_IG_OFFSET_4_CD_2G_8814A	include/hal_pg.h	213;"	d
-EEPROM_IG_OFFSET_4_CD_5GH_8814A	include/hal_pg.h	219;"	d
-EEPROM_IG_OFFSET_4_CD_5GL_8814A	include/hal_pg.h	215;"	d
-EEPROM_IG_OFFSET_4_CD_5GM_8814A	include/hal_pg.h	217;"	d
-EEPROM_IQK_LCK_8188F	include/hal_pg.h	311;"	d
-EEPROM_IQK_LCK_8192E	include/hal_pg.h	83;"	d
-EEPROM_IQK_LCK_8703B	include/hal_pg.h	399;"	d
-EEPROM_IQK_LCK_8723B	include/hal_pg.h	350;"	d
-EEPROM_IQK_LCK_8723D	include/hal_pg.h	547;"	d
-EEPROM_IQK_LCK_8812	include/hal_pg.h	128;"	d
-EEPROM_IQK_LCK_8814	include/hal_pg.h	193;"	d
-EEPROM_IQK_LCK_8821	include/hal_pg.h	241;"	d
-EEPROM_IQK_LCK_8821C	include/hal_pg.h	493;"	d
-EEPROM_IQK_LCK_8822B	include/hal_pg.h	443;"	d
-EEPROM_IQK_LCK_88E	include/hal_pg.h	42;"	d
-EEPROM_LNA_TYPE_2G_8188FU	include/hal_pg.h	334;"	d
-EEPROM_LNA_TYPE_2G_8192EU	include/hal_pg.h	113;"	d
-EEPROM_LNA_TYPE_2G_8703BU	include/hal_pg.h	421;"	d
-EEPROM_LNA_TYPE_2G_8723BU	include/hal_pg.h	378;"	d
-EEPROM_LNA_TYPE_2G_8812AU	include/hal_pg.h	157;"	d
-EEPROM_LNA_TYPE_2G_8814AU	include/hal_pg.h	165;"	d
-EEPROM_LNA_TYPE_5G_8192EU	include/hal_pg.h	114;"	d
-EEPROM_LNA_TYPE_5G_8812AU	include/hal_pg.h	158;"	d
-EEPROM_LNA_TYPE_5G_8814AU	include/hal_pg.h	166;"	d
-EEPROM_LNA_TYPE_8821AU	include/hal_pg.h	260;"	d
-EEPROM_LNA_TYPE_AB_2G_8814	include/hal_pg.h	197;"	d
-EEPROM_LNA_TYPE_AB_5G_8814	include/hal_pg.h	199;"	d
-EEPROM_LNA_TYPE_CD_2G_8814	include/hal_pg.h	198;"	d
-EEPROM_LNA_TYPE_CD_5G_8814	include/hal_pg.h	200;"	d
-EEPROM_MAC_ADDR_8188FS	include/hal_pg.h	338;"	d
-EEPROM_MAC_ADDR_8188FU	include/hal_pg.h	330;"	d
-EEPROM_MAC_ADDR_8192EE	include/hal_pg.h	102;"	d
-EEPROM_MAC_ADDR_8192ES	include/hal_pg.h	117;"	d
-EEPROM_MAC_ADDR_8192EU	include/hal_pg.h	109;"	d
-EEPROM_MAC_ADDR_8703BS	include/hal_pg.h	424;"	d
-EEPROM_MAC_ADDR_8703BU	include/hal_pg.h	416;"	d
-EEPROM_MAC_ADDR_8723BE	include/hal_pg.h	367;"	d
-EEPROM_MAC_ADDR_8723BS	include/hal_pg.h	382;"	d
-EEPROM_MAC_ADDR_8723BU	include/hal_pg.h	374;"	d
-EEPROM_MAC_ADDR_8723DE	include/hal_pg.h	564;"	d
-EEPROM_MAC_ADDR_8723DS	include/hal_pg.h	577;"	d
-EEPROM_MAC_ADDR_8723DU	include/hal_pg.h	571;"	d
-EEPROM_MAC_ADDR_8812AE	include/hal_pg.h	146;"	d
-EEPROM_MAC_ADDR_8812AU	include/hal_pg.h	153;"	d
-EEPROM_MAC_ADDR_8814AE	include/hal_pg.h	169;"	d
-EEPROM_MAC_ADDR_8814AU	include/hal_pg.h	161;"	d
-EEPROM_MAC_ADDR_8821AE	include/hal_pg.h	252;"	d
-EEPROM_MAC_ADDR_8821AS	include/hal_pg.h	263;"	d
-EEPROM_MAC_ADDR_8821AU	include/hal_pg.h	266;"	d
-EEPROM_MAC_ADDR_8821CE	include/hal_pg.h	526;"	d
-EEPROM_MAC_ADDR_8821CS	include/hal_pg.h	523;"	d
-EEPROM_MAC_ADDR_8821CU	include/hal_pg.h	516;"	d
-EEPROM_MAC_ADDR_8822BE	include/hal_pg.h	476;"	d
-EEPROM_MAC_ADDR_8822BS	include/hal_pg.h	473;"	d
-EEPROM_MAC_ADDR_8822BU	include/hal_pg.h	466;"	d
-EEPROM_MAC_ADDR_88EE	include/hal_pg.h	53;"	d
-EEPROM_MAC_ADDR_88ES	include/hal_pg.h	67;"	d
-EEPROM_MAC_ADDR_88EU	include/hal_pg.h	60;"	d
-EEPROM_MAC_ADDR_92S	include/hal_pg.h	279;"	d
-EEPROM_MAX_SIZE	include/rtw_eeprom.h	32;"	d
-EEPROM_PA_TYPE_8188FU	include/hal_pg.h	333;"	d
-EEPROM_PA_TYPE_8192EU	include/hal_pg.h	112;"	d
-EEPROM_PA_TYPE_8703BU	include/hal_pg.h	420;"	d
-EEPROM_PA_TYPE_8723BU	include/hal_pg.h	377;"	d
-EEPROM_PA_TYPE_8812AU	include/hal_pg.h	156;"	d
-EEPROM_PA_TYPE_8814	include/hal_pg.h	196;"	d
-EEPROM_PA_TYPE_8814AU	include/hal_pg.h	164;"	d
-EEPROM_PA_TYPE_8821AU	include/hal_pg.h	259;"	d
-EEPROM_PCIE_DEV_CAP_01	include/hal_pg.h	690;"	d
-EEPROM_PCIE_DEV_CAP_02	include/hal_pg.h	691;"	d
-EEPROM_PID_8188FU	include/hal_pg.h	332;"	d
-EEPROM_PID_8192EU	include/hal_pg.h	111;"	d
-EEPROM_PID_8703BU	include/hal_pg.h	418;"	d
-EEPROM_PID_8723BU	include/hal_pg.h	376;"	d
-EEPROM_PID_8723DU	include/hal_pg.h	573;"	d
-EEPROM_PID_8812AU	include/hal_pg.h	155;"	d
-EEPROM_PID_8814AU	include/hal_pg.h	163;"	d
-EEPROM_PID_8821AU	include/hal_pg.h	268;"	d
-EEPROM_PID_8821CU	include/hal_pg.h	518;"	d
-EEPROM_PID_8822BU	include/hal_pg.h	468;"	d
-EEPROM_PID_88EU	include/hal_pg.h	62;"	d
-EEPROM_PID_92SU	include/hal_pg.h	288;"	d
-EEPROM_READ_OPCODE	include/rtw_eeprom.h	37;"	d
-EEPROM_RFE_OPTION_8188E	include/hal_pg.h	98;"	d
-EEPROM_RFE_OPTION_8188F	include/hal_pg.h	324;"	d
-EEPROM_RFE_OPTION_8192E	include/hal_pg.h	97;"	d
-EEPROM_RFE_OPTION_8703B	include/hal_pg.h	412;"	d
-EEPROM_RFE_OPTION_8723B	include/hal_pg.h	363;"	d
-EEPROM_RFE_OPTION_8723D	include/hal_pg.h	560;"	d
-EEPROM_RFE_OPTION_8812	include/hal_pg.h	142;"	d
-EEPROM_RFE_OPTION_8814	include/hal_pg.h	208;"	d
-EEPROM_RFE_OPTION_8821C	include/hal_pg.h	512;"	d
-EEPROM_RFE_OPTION_8822B	include/hal_pg.h	462;"	d
-EEPROM_RF_ANTENNA_OPT_8188F	include/hal_pg.h	323;"	d
-EEPROM_RF_ANTENNA_OPT_8192E	include/hal_pg.h	96;"	d
-EEPROM_RF_ANTENNA_OPT_8703B	include/hal_pg.h	411;"	d
-EEPROM_RF_ANTENNA_OPT_8723B	include/hal_pg.h	362;"	d
-EEPROM_RF_ANTENNA_OPT_8723D	include/hal_pg.h	559;"	d
-EEPROM_RF_ANTENNA_OPT_8812	include/hal_pg.h	141;"	d
-EEPROM_RF_ANTENNA_OPT_8821	include/hal_pg.h	249;"	d
-EEPROM_RF_ANTENNA_OPT_8821C	include/hal_pg.h	511;"	d
-EEPROM_RF_ANTENNA_OPT_8822B	include/hal_pg.h	461;"	d
-EEPROM_RF_ANTENNA_OPT_88E	include/hal_pg.h	49;"	d
-EEPROM_RF_BOARD_OPTION_8188F	include/hal_pg.h	316;"	d
-EEPROM_RF_BOARD_OPTION_8192E	include/hal_pg.h	88;"	d
-EEPROM_RF_BOARD_OPTION_8703B	include/hal_pg.h	404;"	d
-EEPROM_RF_BOARD_OPTION_8723B	include/hal_pg.h	355;"	d
-EEPROM_RF_BOARD_OPTION_8723D	include/hal_pg.h	552;"	d
-EEPROM_RF_BOARD_OPTION_8812	include/hal_pg.h	133;"	d
-EEPROM_RF_BOARD_OPTION_8814	include/hal_pg.h	201;"	d
-EEPROM_RF_BOARD_OPTION_8821	include/hal_pg.h	244;"	d
-EEPROM_RF_BOARD_OPTION_8821C	include/hal_pg.h	504;"	d
-EEPROM_RF_BOARD_OPTION_8822B	include/hal_pg.h	454;"	d
-EEPROM_RF_BOARD_OPTION_88E	include/hal_pg.h	44;"	d
-EEPROM_RF_BT_SETTING_8188F	include/hal_pg.h	318;"	d
-EEPROM_RF_BT_SETTING_8192E	include/hal_pg.h	90;"	d
-EEPROM_RF_BT_SETTING_8703B	include/hal_pg.h	406;"	d
-EEPROM_RF_BT_SETTING_8723B	include/hal_pg.h	357;"	d
-EEPROM_RF_BT_SETTING_8723D	include/hal_pg.h	554;"	d
-EEPROM_RF_BT_SETTING_8812	include/hal_pg.h	135;"	d
-EEPROM_RF_BT_SETTING_8814	include/hal_pg.h	202;"	d
-EEPROM_RF_BT_SETTING_8821	include/hal_pg.h	246;"	d
-EEPROM_RF_BT_SETTING_8821C	include/hal_pg.h	506;"	d
-EEPROM_RF_BT_SETTING_8822B	include/hal_pg.h	456;"	d
-EEPROM_RF_BT_SETTING_88E	include/hal_pg.h	46;"	d
-EEPROM_RF_FEATURE_OPTION_8192E	include/hal_pg.h	89;"	d
-EEPROM_RF_FEATURE_OPTION_8812	include/hal_pg.h	134;"	d
-EEPROM_RF_FEATURE_OPTION_8821	include/hal_pg.h	245;"	d
-EEPROM_RF_FEATURE_OPTION_88E	include/hal_pg.h	45;"	d
-EEPROM_RF_GAIN_OFFSET	include/rtl8188e_spec.h	105;"	d
-EEPROM_RF_GAIN_OFFSET	include/rtl8703b_spec.h	401;"	d
-EEPROM_RF_GAIN_OFFSET	include/rtl8723b_spec.h	217;"	d
-EEPROM_RF_GAIN_OFFSET	include/rtl8723d_spec.h	430;"	d
-EEPROM_RF_GAIN_VAL	include/rtl8188e_spec.h	106;"	d
-EEPROM_RF_GAIN_VAL	include/rtl8703b_spec.h	404;"	d
-EEPROM_RF_GAIN_VAL	include/rtl8723b_spec.h	220;"	d
-EEPROM_RF_GAIN_VAL	include/rtl8723d_spec.h	433;"	d
-EEPROM_RWParam	include/rtw_mp_ioctl.h	/^} eeprom_rw_param, EEPROM_RWParam, *pEEPROM_RWParam;$/;"	t	typeref:struct:_EEPROM_RW_PARAM
-EEPROM_SMID_8192EE	include/hal_pg.h	106;"	d
-EEPROM_SMID_8723BE	include/hal_pg.h	371;"	d
-EEPROM_SMID_8723DE	include/hal_pg.h	568;"	d
-EEPROM_SMID_8812AE	include/hal_pg.h	150;"	d
-EEPROM_SMID_8814AE	include/hal_pg.h	173;"	d
-EEPROM_SMID_8821AE	include/hal_pg.h	256;"	d
-EEPROM_SMID_88EE	include/hal_pg.h	57;"	d
-EEPROM_SMID_92SE	include/hal_pg.h	277;"	d
-EEPROM_SUBCUSTOMER_ID_8188F	include/hal_pg.h	327;"	d
-EEPROM_SVID_8192EE	include/hal_pg.h	105;"	d
-EEPROM_SVID_8723BE	include/hal_pg.h	370;"	d
-EEPROM_SVID_8723DE	include/hal_pg.h	567;"	d
-EEPROM_SVID_8812AE	include/hal_pg.h	149;"	d
-EEPROM_SVID_8814AE	include/hal_pg.h	172;"	d
-EEPROM_SVID_8821AE	include/hal_pg.h	255;"	d
-EEPROM_SVID_88EE	include/hal_pg.h	56;"	d
-EEPROM_SVID_92SE	include/hal_pg.h	276;"	d
-EEPROM_THERMAL_METER_8188F	include/hal_pg.h	310;"	d
-EEPROM_THERMAL_METER_8192E	include/hal_pg.h	82;"	d
-EEPROM_THERMAL_METER_8703B	include/hal_pg.h	398;"	d
-EEPROM_THERMAL_METER_8723B	include/hal_pg.h	349;"	d
-EEPROM_THERMAL_METER_8723D	include/hal_pg.h	546;"	d
-EEPROM_THERMAL_METER_8812	include/hal_pg.h	127;"	d
-EEPROM_THERMAL_METER_8814	include/hal_pg.h	192;"	d
-EEPROM_THERMAL_METER_8821	include/hal_pg.h	240;"	d
-EEPROM_THERMAL_METER_8821C	include/hal_pg.h	492;"	d
-EEPROM_THERMAL_METER_8822B	include/hal_pg.h	442;"	d
-EEPROM_THERMAL_METER_88E	include/hal_pg.h	41;"	d
-EEPROM_THERMAL_OFFSET	include/rtl8188e_spec.h	107;"	d
-EEPROM_TRX_ANTENNA_OPTION_8814	include/hal_pg.h	207;"	d
-EEPROM_TSSI_A_92SE	include/hal_pg.h	281;"	d
-EEPROM_TSSI_A_92SU	include/hal_pg.h	291;"	d
-EEPROM_TSSI_B_92SE	include/hal_pg.h	282;"	d
-EEPROM_TSSI_B_92SU	include/hal_pg.h	292;"	d
-EEPROM_TX_BBSWING_2G_8188F	include/hal_pg.h	321;"	d
-EEPROM_TX_BBSWING_2G_8192E	include/hal_pg.h	93;"	d
-EEPROM_TX_BBSWING_2G_8703B	include/hal_pg.h	409;"	d
-EEPROM_TX_BBSWING_2G_8723B	include/hal_pg.h	360;"	d
-EEPROM_TX_BBSWING_2G_8723D	include/hal_pg.h	557;"	d
-EEPROM_TX_BBSWING_2G_8812	include/hal_pg.h	138;"	d
-EEPROM_TX_BBSWING_2G_8814	include/hal_pg.h	205;"	d
-EEPROM_TX_BBSWING_2G_8821C	include/hal_pg.h	509;"	d
-EEPROM_TX_BBSWING_2G_8822B	include/hal_pg.h	459;"	d
-EEPROM_TX_BBSWING_5G_8192E	include/hal_pg.h	94;"	d
-EEPROM_TX_BBSWING_5G_8812	include/hal_pg.h	139;"	d
-EEPROM_TX_BBSWING_5G_8814	include/hal_pg.h	206;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8188F	include/hal_pg.h	322;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8192E	include/hal_pg.h	95;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8703B	include/hal_pg.h	410;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8723B	include/hal_pg.h	361;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8723D	include/hal_pg.h	558;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8812	include/hal_pg.h	140;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8821C	include/hal_pg.h	510;"	d
-EEPROM_TX_PWR_CALIBRATE_RATE_8822B	include/hal_pg.h	460;"	d
-EEPROM_TX_PWR_INX_8188F	include/hal_pg.h	306;"	d
-EEPROM_TX_PWR_INX_8192E	include/hal_pg.h	78;"	d
-EEPROM_TX_PWR_INX_8703B	include/hal_pg.h	394;"	d
-EEPROM_TX_PWR_INX_8723B	include/hal_pg.h	345;"	d
-EEPROM_TX_PWR_INX_8723D	include/hal_pg.h	542;"	d
-EEPROM_TX_PWR_INX_8812	include/hal_pg.h	123;"	d
-EEPROM_TX_PWR_INX_8814	include/hal_pg.h	188;"	d
-EEPROM_TX_PWR_INX_8821	include/hal_pg.h	236;"	d
-EEPROM_TX_PWR_INX_8821C	include/hal_pg.h	488;"	d
-EEPROM_TX_PWR_INX_8822B	include/hal_pg.h	438;"	d
-EEPROM_TX_PWR_INX_88E	include/hal_pg.h	37;"	d
-EEPROM_USB_MODE_8812	include/hal_pg.h	122;"	d
-EEPROM_USB_MODE_8814A	include/hal_pg.h	189;"	d
-EEPROM_USB_MODE_8821CU	include/hal_pg.h	520;"	d
-EEPROM_USB_MODE_8822BU	include/hal_pg.h	470;"	d
-EEPROM_USB_OPTIONAL1	include/hal_pg.h	616;"	d
-EEPROM_USB_OPTIONAL_FUNCTION0	include/hal_pg.h	63;"	d
-EEPROM_USB_OPTIONAL_FUNCTION0_8188FU	include/hal_pg.h	335;"	d
-EEPROM_USB_OPTIONAL_FUNCTION0_8703BU	include/hal_pg.h	419;"	d
-EEPROM_USB_OPTIONAL_FUNCTION0_8723DU	include/hal_pg.h	574;"	d
-EEPROM_USB_OPTIONAL_FUNCTION0_8811AU	include/hal_pg.h	64;"	d
-EEPROM_USB_OPTIONAL_FUNCTION0_8821CU	include/hal_pg.h	519;"	d
-EEPROM_USB_OPTIONAL_FUNCTION0_8822BU	include/hal_pg.h	469;"	d
-EEPROM_VERSION_8188F	include/hal_pg.h	319;"	d
-EEPROM_VERSION_8192E	include/hal_pg.h	91;"	d
-EEPROM_VERSION_8703B	include/hal_pg.h	407;"	d
-EEPROM_VERSION_8723B	include/hal_pg.h	358;"	d
-EEPROM_VERSION_8723D	include/hal_pg.h	555;"	d
-EEPROM_VERSION_8812	include/hal_pg.h	136;"	d
-EEPROM_VERSION_8814	include/hal_pg.h	203;"	d
-EEPROM_VERSION_8821	include/hal_pg.h	247;"	d
-EEPROM_VERSION_8821C	include/hal_pg.h	507;"	d
-EEPROM_VERSION_8822B	include/hal_pg.h	457;"	d
-EEPROM_VERSION_88E	include/hal_pg.h	47;"	d
-EEPROM_VID_8188FU	include/hal_pg.h	331;"	d
-EEPROM_VID_8192EE	include/hal_pg.h	103;"	d
-EEPROM_VID_8192EU	include/hal_pg.h	110;"	d
-EEPROM_VID_8703BU	include/hal_pg.h	417;"	d
-EEPROM_VID_8723BE	include/hal_pg.h	368;"	d
-EEPROM_VID_8723BU	include/hal_pg.h	375;"	d
-EEPROM_VID_8723DE	include/hal_pg.h	565;"	d
-EEPROM_VID_8723DU	include/hal_pg.h	572;"	d
-EEPROM_VID_8812AE	include/hal_pg.h	147;"	d
-EEPROM_VID_8812AU	include/hal_pg.h	154;"	d
-EEPROM_VID_8814AE	include/hal_pg.h	170;"	d
-EEPROM_VID_8814AU	include/hal_pg.h	162;"	d
-EEPROM_VID_8821AE	include/hal_pg.h	253;"	d
-EEPROM_VID_8821AU	include/hal_pg.h	267;"	d
-EEPROM_VID_8821CU	include/hal_pg.h	517;"	d
-EEPROM_VID_8822BU	include/hal_pg.h	467;"	d
-EEPROM_VID_88EE	include/hal_pg.h	54;"	d
-EEPROM_VID_88EU	include/hal_pg.h	61;"	d
-EEPROM_VID_92SE	include/hal_pg.h	274;"	d
-EEPROM_VID_92SU	include/hal_pg.h	287;"	d
-EEPROM_Version_92SE	include/hal_pg.h	284;"	d
-EEPROM_Version_92SU	include/hal_pg.h	290;"	d
-EEPROM_Voltage_ADDR_8188F	include/hal_pg.h	339;"	d
-EEPROM_Voltage_ADDR_8703B	include/hal_pg.h	425;"	d
-EEPROM_Voltage_ADDR_8723B	include/hal_pg.h	383;"	d
-EEPROM_Voltage_ADDR_8723D	include/hal_pg.h	578;"	d
-EEPROM_WRITE_OPCODE	include/rtw_eeprom.h	38;"	d
-EEPROM_XTAL_8188F	include/hal_pg.h	309;"	d
-EEPROM_XTAL_8192E	include/hal_pg.h	81;"	d
-EEPROM_XTAL_8703B	include/hal_pg.h	397;"	d
-EEPROM_XTAL_8723B	include/hal_pg.h	348;"	d
-EEPROM_XTAL_8723D	include/hal_pg.h	545;"	d
-EEPROM_XTAL_8812	include/hal_pg.h	126;"	d
-EEPROM_XTAL_8814	include/hal_pg.h	191;"	d
-EEPROM_XTAL_8821	include/hal_pg.h	239;"	d
-EEPROM_XTAL_8821C	include/hal_pg.h	491;"	d
-EEPROM_XTAL_8822B	include/hal_pg.h	441;"	d
-EEPROM_XTAL_88E	include/hal_pg.h	40;"	d
-EETYPE_TX_PWR	include/hal_pg.h	583;"	d
-EF1Byte	include/basic_types.h	191;"	d
-EF2Byte	include/basic_types.h	192;"	d
-EF4Byte	include/basic_types.h	193;"	d
-EFS_HCI_SEL	include/hal_com_reg.h	1285;"	d
-EFUSEGetEfuseDefinition	include/hal_intf.h	/^	void (*EFUSEGetEfuseDefinition)(_adapter *padapter, u8 efuseType, u8 type, void *pOut, BOOLEAN bPseudoTest);$/;"	m	struct:hal_ops
-EFUSE_ACCESS_OFF	include/rtl8188e_spec.h	163;"	d
-EFUSE_ACCESS_OFF	include/rtl8188f_hal.h	176;"	d
-EFUSE_ACCESS_OFF	include/rtl8703b_hal.h	178;"	d
-EFUSE_ACCESS_OFF	include/rtl8723b_hal.h	178;"	d
-EFUSE_ACCESS_OFF	include/rtl8723d_hal.h	185;"	d
-EFUSE_ACCESS_OFF_8723	hal/rtl8723d/rtl8723d_hal_init.c	1468;"	d	file:
-EFUSE_ACCESS_ON	include/rtl8188e_spec.h	162;"	d
-EFUSE_ACCESS_ON	include/rtl8188f_hal.h	175;"	d
-EFUSE_ACCESS_ON	include/rtl8703b_hal.h	177;"	d
-EFUSE_ACCESS_ON	include/rtl8723b_hal.h	177;"	d
-EFUSE_ACCESS_ON	include/rtl8723d_hal.h	184;"	d
-EFUSE_ACCESS_ON_8723	hal/rtl8723d/rtl8723d_hal_init.c	1467;"	d	file:
-EFUSE_ACCESS_STRUCT	include/rtw_mp_ioctl.h	/^} EFUSE_ACCESS_STRUCT, *PEFUSE_ACCESS_STRUCT;$/;"	t	typeref:struct:_EFUSE_ACCESS_STRUCT_
-EFUSE_BT	include/rtw_efuse.h	39;"	d
-EFUSE_BT_MAP_LEN	include/rtl8188e_hal.h	225;"	d
-EFUSE_BT_MAP_LEN	include/rtl8188f_hal.h	183;"	d
-EFUSE_BT_MAP_LEN	include/rtl8703b_hal.h	186;"	d
-EFUSE_BT_MAP_LEN	include/rtl8723b_hal.h	185;"	d
-EFUSE_BT_MAP_LEN	include/rtl8723d_hal.h	194;"	d
-EFUSE_BT_MAP_LEN	include/rtw_efuse.h	61;"	d
-EFUSE_BT_MAP_LEN_8192E	include/rtl8192e_hal.h	219;"	d
-EFUSE_BT_MAX_MAP_LEN	include/rtw_efuse.h	88;"	d
-EFUSE_BT_MAX_SECTION	include/rtl8188e_hal.h	226;"	d
-EFUSE_BT_MAX_SECTION	include/rtl8188f_hal.h	184;"	d
-EFUSE_BT_MAX_SECTION	include/rtl8703b_hal.h	187;"	d
-EFUSE_BT_MAX_SECTION	include/rtl8723b_hal.h	186;"	d
-EFUSE_BT_MAX_SECTION	include/rtl8723d_hal.h	195;"	d
-EFUSE_BT_MAX_SECTION	include/rtw_efuse.h	62;"	d
-EFUSE_BT_MAX_SECTION_8192E	include/rtl8192e_hal.h	220;"	d
-EFUSE_BT_REAL_BANK_CONTENT_LEN	include/rtl8188f_hal.h	181;"	d
-EFUSE_BT_REAL_BANK_CONTENT_LEN	include/rtl8703b_hal.h	184;"	d
-EFUSE_BT_REAL_BANK_CONTENT_LEN	include/rtl8723b_hal.h	183;"	d
-EFUSE_BT_REAL_BANK_CONTENT_LEN	include/rtl8723d_hal.h	191;"	d
-EFUSE_BT_REAL_BANK_CONTENT_LEN	include/rtw_efuse.h	59;"	d
-EFUSE_BT_REAL_BANK_CONTENT_LEN_8192E	include/rtl8192e_hal.h	217;"	d
-EFUSE_BT_REAL_CONTENT_LEN	include/rtl8188e_hal.h	224;"	d
-EFUSE_BT_REAL_CONTENT_LEN	include/rtl8188f_hal.h	182;"	d
-EFUSE_BT_REAL_CONTENT_LEN	include/rtl8703b_hal.h	185;"	d
-EFUSE_BT_REAL_CONTENT_LEN	include/rtl8723b_hal.h	184;"	d
-EFUSE_BT_REAL_CONTENT_LEN	include/rtl8723d_hal.h	192;"	d
-EFUSE_BT_REAL_CONTENT_LEN	include/rtw_efuse.h	60;"	d
-EFUSE_BT_REAL_CONTENT_LEN_8192E	include/rtl8192e_hal.h	218;"	d
-EFUSE_BT_SEL_0	include/hal_com_reg.h	1232;"	d
-EFUSE_BT_SEL_1	include/hal_com_reg.h	1233;"	d
-EFUSE_BT_SEL_2	include/hal_com_reg.h	1234;"	d
-EFUSE_CTRL	core/efuse/rtw_efuse.c	1129;"	d	file:
-EFUSE_CTRL	include/hal_com_reg.h	561;"	d
-EFUSE_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	440;"	d
-EFUSE_CTRL_8814A	include/rtl8814a_spec.h	537;"	d
-EFUSE_ERROE_HANDLE	include/rtw_efuse.h	24;"	d
-EFUSE_FILE	include/rtw_mp.h	/^	EFUSE_FILE,$/;"	e	enum:__anon65
-EFUSE_FILE_COLUMN_NUM	include/hal_com.h	489;"	d
-EFUSE_FILE_FAILED	include/hal_data.h	221;"	d
-EFUSE_FILE_LOADED	include/hal_data.h	222;"	d
-EFUSE_FILE_UNUSED	include/hal_data.h	220;"	d
-EFUSE_GET	include/rtw_mp.h	/^	EFUSE_GET,$/;"	e	enum:__anon65
-EFUSE_GetArrayLen_MP_8723D_MPCIE	hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c	/^EFUSE_GetArrayLen_MP_8723D_MPCIE(VOID)$/;"	f
-EFUSE_GetArrayLen_MP_8723D_MSDIO	hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c	/^EFUSE_GetArrayLen_MP_8723D_MSDIO(VOID)$/;"	f
-EFUSE_GetArrayLen_MP_8723D_MUSB	hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c	/^EFUSE_GetArrayLen_MP_8723D_MUSB(VOID)$/;"	f
-EFUSE_GetEfuseDefinition	core/efuse/rtw_efuse.c	/^EFUSE_GetEfuseDefinition($/;"	f
-EFUSE_GetEfuseDefinition	core/efuse/rtw_efuse.c	/^void EFUSE_GetEfuseDefinition(PADAPTER adapter, u8 efusetype, u8 type, void *out, BOOLEAN test)$/;"	f
-EFUSE_GetMaskArray_MP_8723D_MPCIE	hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c	/^EFUSE_GetMaskArray_MP_8723D_MPCIE($/;"	f
-EFUSE_GetMaskArray_MP_8723D_MSDIO	hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c	/^EFUSE_GetMaskArray_MP_8723D_MSDIO($/;"	f
-EFUSE_GetMaskArray_MP_8723D_MUSB	hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c	/^EFUSE_GetMaskArray_MP_8723D_MUSB($/;"	f
-EFUSE_HAL	include/rtw_efuse.h	/^} EFUSE_HAL, *PEFUSE_HAL;$/;"	t	typeref:struct:_EFUSE_HAL
-EFUSE_HIDDEN_812AU	include/rtl8812a_hal.h	229;"	d
-EFUSE_HIDDEN_812AU_VL	include/rtl8812a_hal.h	231;"	d
-EFUSE_HIDDEN_812AU_VN	include/rtl8812a_hal.h	232;"	d
-EFUSE_HIDDEN_812AU_VS	include/rtl8812a_hal.h	230;"	d
-EFUSE_IC_ID_OFFSET	include/rtl8188e_hal.h	194;"	d
-EFUSE_IC_ID_OFFSET	include/rtl8188f_hal.h	172;"	d
-EFUSE_IC_ID_OFFSET	include/rtl8703b_hal.h	174;"	d
-EFUSE_IC_ID_OFFSET	include/rtl8723b_hal.h	174;"	d
-EFUSE_IC_ID_OFFSET	include/rtl8723d_hal.h	181;"	d
-EFUSE_IC_ID_OFFSET_8192E	include/rtl8192e_hal.h	201;"	d
-EFUSE_IC_ID_OFFSET_8814A	include/rtl8814a_hal.h	194;"	d
-EFUSE_IC_ID_OFFSET_88E	include/rtl8188e_hal.h	211;"	d
-EFUSE_IC_ID_OFFSET_JAGUAR	include/rtl8812a_hal.h	246;"	d
-EFUSE_IsAddressMasked_MP_8723D_MPCIE	hal/efuse/rtl8723d/HalEfuseMask8723D_PCIE.c	/^EFUSE_IsAddressMasked_MP_8723D_MPCIE($/;"	f
-EFUSE_IsAddressMasked_MP_8723D_MSDIO	hal/efuse/rtl8723d/HalEfuseMask8723D_SDIO.c	/^EFUSE_IsAddressMasked_MP_8723D_MSDIO($/;"	f
-EFUSE_IsAddressMasked_MP_8723D_MUSB	hal/efuse/rtl8723d/HalEfuseMask8723D_USB.c	/^EFUSE_IsAddressMasked_MP_8723D_MUSB($/;"	f
-EFUSE_MAP_LEN	include/rtl8188e_hal.h	192;"	d
-EFUSE_MAP_LEN_8188F	include/rtl8188f_hal.h	169;"	d
-EFUSE_MAP_LEN_8192E	include/rtl8192e_hal.h	198;"	d
-EFUSE_MAP_LEN_8703B	include/rtl8703b_hal.h	171;"	d
-EFUSE_MAP_LEN_8723B	include/rtl8723b_hal.h	171;"	d
-EFUSE_MAP_LEN_8723D	include/rtl8723d_hal.h	177;"	d
-EFUSE_MAP_LEN_8814A	include/rtl8814a_hal.h	189;"	d
-EFUSE_MAP_LEN_88E	include/rtl8188e_hal.h	208;"	d
-EFUSE_MAP_LEN_JAGUAR	include/rtl8812a_hal.h	243;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	128;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	131;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	134;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	137;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	140;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	143;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	146;"	d
-EFUSE_MAP_SIZE	include/hal_data.h	149;"	d
-EFUSE_MASK	include/rtw_mp.h	/^	EFUSE_MASK,$/;"	e	enum:__anon65
-EFUSE_MAX_BANK	include/rtw_efuse.h	89;"	d
-EFUSE_MAX_BANK_8192E	include/rtl8192e_hal.h	223;"	d
-EFUSE_MAX_BANK_8812A	include/rtl8812a_hal.h	242;"	d
-EFUSE_MAX_BANK_8814A	include/rtl8814a_hal.h	187;"	d
-EFUSE_MAX_BT_BANK	include/rtw_efuse.h	90;"	d
-EFUSE_MAX_HW_SIZE	include/rtw_efuse.h	53;"	d
-EFUSE_MAX_MAP_LEN	include/rtw_efuse.h	51;"	d
-EFUSE_MAX_SECTION	include/rtl8188e_hal.h	193;"	d
-EFUSE_MAX_SECTION_8188F	include/rtl8188f_hal.h	170;"	d
-EFUSE_MAX_SECTION_8192E	include/rtl8192e_hal.h	199;"	d
-EFUSE_MAX_SECTION_8703B	include/rtl8703b_hal.h	172;"	d
-EFUSE_MAX_SECTION_8723B	include/rtl8723b_hal.h	172;"	d
-EFUSE_MAX_SECTION_8723D	include/rtl8723d_hal.h	178;"	d
-EFUSE_MAX_SECTION_8814A	include/rtl8814a_hal.h	190;"	d
-EFUSE_MAX_SECTION_88E	include/rtl8188e_hal.h	209;"	d
-EFUSE_MAX_SECTION_BASE	include/rtw_efuse.h	54;"	d
-EFUSE_MAX_SECTION_JAGUAR	include/rtl8812a_hal.h	244;"	d
-EFUSE_MAX_SECTION_JAGUAR	include/rtl8814a_hal.h	182;"	d
-EFUSE_MAX_SIZE	include/hal_data.h	153;"	d
-EFUSE_MAX_SIZE	include/hal_data.h	155;"	d
-EFUSE_MAX_SIZE	include/hal_data.h	157;"	d
-EFUSE_MAX_WORD_UNIT	include/rtw_efuse.h	93;"	d
-EFUSE_MAX_WORD_UNIT_8192E	include/rtl8192e_hal.h	200;"	d
-EFUSE_MAX_WORD_UNIT_8814A	include/rtl8814a_hal.h	191;"	d
-EFUSE_MAX_WORD_UNIT_88E	include/rtl8188e_hal.h	210;"	d
-EFUSE_MAX_WORD_UNIT_JAGUAR	include/rtl8812a_hal.h	245;"	d
-EFUSE_OOB_PROTECT_BYTES	include/rtl8188e_hal.h	205;"	d
-EFUSE_OOB_PROTECT_BYTES	include/rtl8188f_hal.h	163;"	d
-EFUSE_OOB_PROTECT_BYTES	include/rtl8703b_hal.h	165;"	d
-EFUSE_OOB_PROTECT_BYTES	include/rtl8723b_hal.h	165;"	d
-EFUSE_OOB_PROTECT_BYTES	include/rtl8723d_hal.h	172;"	d
-EFUSE_OOB_PROTECT_BYTES	include/rtl8814a_hal.h	223;"	d
-EFUSE_OOB_PROTECT_BYTES_8192E	include/rtl8192e_hal.h	210;"	d
-EFUSE_OOB_PROTECT_BYTES_88E	include/rtl8188e_hal.h	217;"	d
-EFUSE_OOB_PROTECT_BYTES_JAGUAR	include/rtl8812a_hal.h	252;"	d
-EFUSE_PROTECT_BYTES_BANK	include/rtl8188e_hal.h	228;"	d
-EFUSE_PROTECT_BYTES_BANK	include/rtl8188f_hal.h	186;"	d
-EFUSE_PROTECT_BYTES_BANK	include/rtl8703b_hal.h	188;"	d
-EFUSE_PROTECT_BYTES_BANK	include/rtl8723b_hal.h	188;"	d
-EFUSE_PROTECT_BYTES_BANK	include/rtl8723d_hal.h	196;"	d
-EFUSE_PROTECT_BYTES_BANK	include/rtw_efuse.h	63;"	d
-EFUSE_PROTECT_BYTES_BANK_8192E	include/rtl8192e_hal.h	222;"	d
-EFUSE_PROTECT_BYTES_BANK_8814A	include/rtl8814a_hal.h	192;"	d
-EFUSE_PROTECT_BYTES_BANK_88E	include/rtl8188e_hal.h	218;"	d
-EFUSE_PROTECT_BYTES_BANK_JAGUAR	include/rtl8812a_hal.h	253;"	d
-EFUSE_REAL_CONTENT_LEN	include/rtl8188e_hal.h	191;"	d
-EFUSE_REAL_CONTENT_LEN_8188F	include/rtl8188f_hal.h	168;"	d
-EFUSE_REAL_CONTENT_LEN_8192E	include/rtl8192e_hal.h	196;"	d
-EFUSE_REAL_CONTENT_LEN_8703B	include/rtl8703b_hal.h	170;"	d
-EFUSE_REAL_CONTENT_LEN_8723B	include/rtl8723b_hal.h	170;"	d
-EFUSE_REAL_CONTENT_LEN_8723D	include/rtl8723d_hal.h	176;"	d
-EFUSE_REAL_CONTENT_LEN_8814A	include/rtl8814a_hal.h	186;"	d
-EFUSE_REAL_CONTENT_LEN_88E	include/rtl8188e_hal.h	207;"	d
-EFUSE_REAL_CONTENT_LEN_JAGUAR	include/rtl8812a_hal.h	238;"	d
-EFUSE_REPEAT_THRESHOLD_	include/rtw_efuse.h	71;"	d
-EFUSE_SEL	include/hal_com_reg.h	1229;"	d
-EFUSE_SEL_MASK	include/hal_com_reg.h	1230;"	d
-EFUSE_SET	include/rtw_mp.h	/^	EFUSE_SET,$/;"	e	enum:__anon65
-EFUSE_ShadowMapUpdate	core/efuse/rtw_efuse.c	/^void EFUSE_ShadowMapUpdate($/;"	f
-EFUSE_ShadowRead	core/efuse/rtw_efuse.c	/^EFUSE_ShadowRead($/;"	f
-EFUSE_ShadowWrite	core/efuse/rtw_efuse.c	/^EFUSE_ShadowWrite($/;"	f
-EFUSE_TEST	include/hal_com_reg.h	562;"	d
-EFUSE_TEST_8723D	hal/phydm/rtl8723d/hal8723dreg.h	441;"	d
-EFUSE_TEST_8814A	include/rtl8814a_spec.h	538;"	d
-EFUSE_WIFI	include/rtw_efuse.h	38;"	d
-EFUSE_WIFI_SEL_0	include/hal_com_reg.h	1231;"	d
-EF_CELL_SEL	include/hal_com_reg.h	1227;"	d
-EF_TRPT	include/hal_com_reg.h	1226;"	d
-EID_AID	include/wifi.h	/^	EID_AID						= 197, \/* Based on 802.11ac D4.0 *\/$/;"	e	enum:_ELEMENT_ID
-EID_Aironet	include/wifi.h	/^	EID_Aironet					= 133, \/* 0x85: Aironet Element for Cisco CCX *\/$/;"	e	enum:_ELEMENT_ID
-EID_BSSCoexistence	include/wifi.h	/^	EID_BSSCoexistence			= 72, \/* 20\/40 BSS Coexistence *\/$/;"	e	enum:_ELEMENT_ID
-EID_BSSIntolerantChlReport	include/wifi.h	/^	EID_BSSIntolerantChlReport	= 73,$/;"	e	enum:_ELEMENT_ID
-EID_CCKM	include/wifi.h	/^	EID_CCKM					= 156,$/;"	e	enum:_ELEMENT_ID
-EID_CFParms	include/wifi.h	/^	EID_CFParms				= 4, \/* CF parameter set (6) *\/$/;"	e	enum:_ELEMENT_ID
-EID_CellPwr	include/wifi.h	/^	EID_CellPwr					= 150, \/* 0x96: Cell Power Limit IE. Ref. 0x96. *\/$/;"	e	enum:_ELEMENT_ID
-EID_ChlSwitchAnnounce	include/wifi.h	/^	EID_ChlSwitchAnnounce		= 37,$/;"	e	enum:_ELEMENT_ID
-EID_ChnlSwitchTimeing	include/wifi.h	/^	EID_ChnlSwitchTimeing		= 104, \/* Defined in 802.11z *\/$/;"	e	enum:_ELEMENT_ID
-EID_CiscoIP	include/wifi.h	/^	EID_CiscoIP					= 149, \/* 0x95: IP Address IE for Cisco CCX *\/$/;"	e	enum:_ELEMENT_ID
-EID_Country	include/wifi.h	/^	EID_Country					= 7, \/* *\/$/;"	e	enum:_ELEMENT_ID
-EID_Ctext	include/wifi.h	/^	EID_Ctext					= 16, \/* challenge text*\/$/;"	e	enum:_ELEMENT_ID
-EID_DSParms	include/wifi.h	/^	EID_DSParms				= 3, \/* DS parameter set (1) *\/$/;"	e	enum:_ELEMENT_ID
-EID_EDCAParms	include/wifi.h	/^	EID_EDCAParms				= 12,$/;"	e	enum:_ELEMENT_ID
-EID_ERPInfo	include/wifi.h	/^	EID_ERPInfo				= 42,$/;"	e	enum:_ELEMENT_ID
-EID_EXTCapability	include/wifi.h	/^	EID_EXTCapability			= 127, \/* Extended Capabilities *\/$/;"	e	enum:_ELEMENT_ID
-EID_ExtSupRates	include/wifi.h	/^	EID_ExtSupRates			= 50,$/;"	e	enum:_ELEMENT_ID
-EID_FHParms	include/wifi.h	/^	EID_FHParms				= 2, \/* FH parameter set (5) *\/$/;"	e	enum:_ELEMENT_ID
-EID_FTIE	include/wifi.h	/^	EID_FTIE					= 55, \/* Defined in 802.11r *\/$/;"	e	enum:_ELEMENT_ID
-EID_HTCapability	include/wifi.h	/^	EID_HTCapability			= 45,$/;"	e	enum:_ELEMENT_ID
-EID_HTInfo	include/wifi.h	/^	EID_HTInfo					= 61,$/;"	e	enum:_ELEMENT_ID
-EID_IbssParms	include/wifi.h	/^	EID_IbssParms				= 6, \/* IBSS parameter set (2) *\/$/;"	e	enum:_ELEMENT_ID
-EID_LinkIdentifier	include/wifi.h	/^	EID_LinkIdentifier			= 101, \/* Defined in 802.11z *\/$/;"	e	enum:_ELEMENT_ID
-EID_MeasureReport	include/wifi.h	/^	EID_MeasureReport			= 39, \/* Measurement Report *\/$/;"	e	enum:_ELEMENT_ID
-EID_MeasureRequest	include/wifi.h	/^	EID_MeasureRequest			= 38, \/* Measurement Request *\/$/;"	e	enum:_ELEMENT_ID
-EID_OBSS	include/wifi.h	/^	EID_OBSS					= 74, \/* Overlapping BSS Scan Parameters *\/$/;"	e	enum:_ELEMENT_ID
-EID_OpModeNotification	include/wifi.h	/^	EID_OpModeNotification		= 199, \/* Based on 802.11ac D3.0 *\/$/;"	e	enum:_ELEMENT_ID
-EID_POWER_CONSTRAINT	include/wifi.h	/^	EID_POWER_CONSTRAINT		= 32, \/* Power Constraint*\/$/;"	e	enum:_ELEMENT_ID
-EID_PTIControl	include/wifi.h	/^	EID_PTIControl				= 105, \/* Defined in 802.11z *\/$/;"	e	enum:_ELEMENT_ID
-EID_PUBufferStatus	include/wifi.h	/^	EID_PUBufferStatus			= 106, \/* Defined in 802.11z *\/$/;"	e	enum:_ELEMENT_ID
-EID_PowerCap	include/wifi.h	/^	EID_PowerCap				= 33,$/;"	e	enum:_ELEMENT_ID
-EID_QBSSLoad	include/wifi.h	/^	EID_QBSSLoad				= 11,$/;"	e	enum:_ELEMENT_ID
-EID_QoSCap	include/wifi.h	/^	EID_QoSCap					= 46,$/;"	e	enum:_ELEMENT_ID
-EID_Schedule	include/wifi.h	/^	EID_Schedule				= 15,$/;"	e	enum:_ELEMENT_ID
-EID_SecondaryChnlOffset	include/wifi.h	/^	EID_SecondaryChnlOffset		= 62,$/;"	e	enum:_ELEMENT_ID
-EID_SsId	include/wifi.h	/^	EID_SsId					= 0, \/* service set identifier (0:32) *\/$/;"	e	enum:_ELEMENT_ID
-EID_SupRates	include/wifi.h	/^	EID_SupRates				= 1, \/* supported rates (1:8) *\/$/;"	e	enum:_ELEMENT_ID
-EID_SupRegulatory	include/wifi.h	/^	EID_SupRegulatory			= 59, \/* Supported Requlatory Classes 802.11y *\/$/;"	e	enum:_ELEMENT_ID
-EID_SupportedChannels	include/wifi.h	/^	EID_SupportedChannels		= 36,$/;"	e	enum:_ELEMENT_ID
-EID_TCLASProc	include/wifi.h	/^	EID_TCLASProc				= 44,$/;"	e	enum:_ELEMENT_ID
-EID_TClass	include/wifi.h	/^	EID_TClass					= 14,$/;"	e	enum:_ELEMENT_ID
-EID_TSDelay	include/wifi.h	/^	EID_TSDelay				= 43,$/;"	e	enum:_ELEMENT_ID
-EID_TSpec	include/wifi.h	/^	EID_TSpec					= 13,$/;"	e	enum:_ELEMENT_ID
-EID_Tim	include/wifi.h	/^	EID_Tim						= 5, \/* Traffic Information Map (4:254) *\/$/;"	e	enum:_ELEMENT_ID
-EID_Timeout	include/wifi.h	/^	EID_Timeout				= 56, \/* Defined in 802.11r *\/$/;"	e	enum:_ELEMENT_ID
-EID_VHTCapability	include/wifi.h	/^	EID_VHTCapability 			= 191, \/* Based on 802.11ac D2.0 *\/$/;"	e	enum:_ELEMENT_ID
-EID_VHTOperation	include/wifi.h	/^	EID_VHTOperation 			= 192, \/* Based on 802.11ac D2.0 *\/$/;"	e	enum:_ELEMENT_ID
-EID_Vendor	include/wifi.h	/^	EID_Vendor					= 221, \/* 0xDD: Vendor Specific *\/$/;"	e	enum:_ELEMENT_ID
-EID_WAPI	include/wifi.h	/^	EID_WAPI					= 68,$/;"	e	enum:_ELEMENT_ID
-EID_WPA2	include/wifi.h	/^	EID_WPA2					= 48,$/;"	e	enum:_ELEMENT_ID
-EID_WakeupSchedule	include/wifi.h	/^	EID_WakeupSchedule		= 102, \/* Defined in 802.11z *\/$/;"	e	enum:_ELEMENT_ID
-EII_FRAMETAG	include/rtw_xmit.h	462;"	d
-ELEMENT_ID	include/wifi.h	/^} ELEMENT_ID, *PELEMENT_ID;$/;"	t	typeref:enum:_ELEMENT_ID
-EMEM_CHKSUM_FAIL	include/rtl8814a_spec.h	504;"	d
-EMEM_DL_RDY	include/rtl8814a_spec.h	503;"	d
-EMEM_TXBUF_CHKSUM_FAIL	include/rtl8814a_spec.h	506;"	d
-EMEM_TXBUF_DL_RDY	include/rtl8814a_spec.h	505;"	d
-ENABLE_FAIL_DMA_IDLE	include/hal_com.h	/^	ENABLE_FAIL_DMA_IDLE			= 0x40,$/;"	e	enum:_WAKEUP_REASON
-ENABLE_FAIL_DMA_PAUSE	include/hal_com.h	/^	ENABLE_FAIL_DMA_PAUSE			= 0x41,$/;"	e	enum:_WAKEUP_REASON
-ENABLE_VCS	include/wlan_bssdef.h	/^	ENABLE_VCS,$/;"	e	enum:VRTL_CARRIER_SENSE
-ENCRYPT	core/rtw_wapi_sms4.c	13;"	d	file:
-ENCRYP_PROTOCOL_E	include/rtw_security.h	/^} ENCRYP_PROTOCOL_E;$/;"	t	typeref:enum:__anon59
-ENCRYP_PROTOCOL_MAX	include/rtw_security.h	/^	ENCRYP_PROTOCOL_MAX$/;"	e	enum:__anon59
-ENCRYP_PROTOCOL_OPENSYS	include/rtw_security.h	/^	ENCRYP_PROTOCOL_OPENSYS,   \/* open system *\/$/;"	e	enum:__anon59
-ENCRYP_PROTOCOL_WAPI	include/rtw_security.h	/^	ENCRYP_PROTOCOL_WAPI,      \/* WAPI: Not support in this version *\/$/;"	e	enum:__anon59
-ENCRYP_PROTOCOL_WEP	include/rtw_security.h	/^	ENCRYP_PROTOCOL_WEP,       \/* WEP *\/$/;"	e	enum:__anon59
-ENCRYP_PROTOCOL_WPA	include/rtw_security.h	/^	ENCRYP_PROTOCOL_WPA,       \/* WPA *\/$/;"	e	enum:__anon59
-ENCRYP_PROTOCOL_WPA2	include/rtw_security.h	/^	ENCRYP_PROTOCOL_WPA2,      \/* WPA2 *\/$/;"	e	enum:__anon59
-ENCRY_CTRL_STATE	include/rtw_mp.h	/^} ENCRY_CTRL_STATE;$/;"	t	typeref:enum:_ENCRY_CTRL_STATE_
-ENSEC	include/hal_com_reg.h	1324;"	d
-ENSWBCN	include/hal_com_reg.h	1323;"	d
-EN_AMPDU_RTY_NEW	include/hal_com_reg.h	1464;"	d
-EN_BCN_FUNCTION	include/hal_com_reg.h	1494;"	d
-EN_HWSEQ	include/rtl8188e_xmit.h	70;"	d
-EN_HWSEQ	include/rtl8192e_xmit.h	175;"	d
-EN_HWSEQ	include/rtl8812a_xmit.h	68;"	d
-EN_HW_UPDATE_TSF_WK_CID	include/rtw_cmd.h	/^	EN_HW_UPDATE_TSF_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-EN_TXBCN_RPT	include/hal_com_reg.h	1493;"	d
-EOR	include/rtw_recv.h	341;"	d
-EPQ_PGNUM_8814A	include/rtl8814a_hal.h	138;"	d
-EPQ_PGNUM_8814A	include/rtl8814a_hal.h	145;"	d
-ERP_IE	include/rtw_mlme_ext.h	/^	u8	ERP_IE;$/;"	m	struct:mlme_ext_info
-ERP_IE_handler	core/rtw_wlan_util.c	/^void ERP_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)$/;"	f
-ERP_enable	include/rtw_mlme_ext.h	/^	u8	ERP_enable;$/;"	m	struct:mlme_ext_info
-ERROR_CODE	include/rtw_efuse.h	/^} ERROR_CODE;$/;"	t	typeref:enum:__anon41
-ERR_BAD_FORMAT	include/rtw_efuse.h	/^	ERR_BAD_FORMAT,$/;"	e	enum:__anon41
-ERR_DRIVER_FAILURE	include/rtw_efuse.h	/^	ERR_DRIVER_FAILURE,$/;"	e	enum:__anon41
-ERR_INVALID_DATA	include/rtw_efuse.h	/^	ERR_INVALID_DATA,$/;"	e	enum:__anon41
-ERR_IO_FAILURE	include/rtw_efuse.h	/^	ERR_IO_FAILURE,$/;"	e	enum:__anon41
-ERR_NOT_ENOUGH_SPACE	include/rtw_efuse.h	/^	ERR_NOT_ENOUGH_SPACE,$/;"	e	enum:__anon41
-ERR_OUT_OF_RANGE	include/rtw_efuse.h	/^	ERR_OUT_OF_RANGE$/;"	e	enum:__anon41
-ERR_READ_BACK_FAIL	include/rtw_efuse.h	/^	ERR_READ_BACK_FAIL,$/;"	e	enum:__anon41
-ERR_SUCCESS	include/rtw_efuse.h	/^	ERR_SUCCESS = 0,$/;"	e	enum:__anon41
-ERR_WI_BUSY	include/rtw_efuse.h	/^	ERR_WI_BUSY,$/;"	e	enum:__anon41
-ERR_WI_TIMEOUT	include/rtw_efuse.h	/^	ERR_WI_TIMEOUT,$/;"	e	enum:__anon41
-ERR_WRITE_PROTECT	include/rtw_efuse.h	/^	ERR_WRITE_PROTECT,$/;"	e	enum:__anon41
-ETHERNET_ADDRESS_LENGTH	include/ethernet.h	24;"	d
-ETHERNET_HEADER_SIZE	include/ethernet.h	25;"	d
-ETH_ALEN	include/ieee80211.h	35;"	d
-ETH_ALEN	include/if_ether.h	29;"	d
-ETH_ALEN	include/xmit_osdep.h	49;"	d
-ETH_DATA_LEN	include/if_ether.h	32;"	d
-ETH_FRAME_LEN	include/if_ether.h	33;"	d
-ETH_HLEN	include/if_ether.h	30;"	d
-ETH_P_80211_RAW	include/ieee80211.h	547;"	d
-ETH_P_8021Q	include/if_ether.h	59;"	d
-ETH_P_802_2	include/if_ether.h	76;"	d
-ETH_P_802_3	include/if_ether.h	73;"	d
-ETH_P_AARP	include/if_ether.h	58;"	d
-ETH_P_ALL	include/if_ether.h	75;"	d
-ETH_P_ARP	include/if_ether.h	44;"	d
-ETH_P_ATALK	include/if_ether.h	57;"	d
-ETH_P_ATMFATE	include/if_ether.h	65;"	d
-ETH_P_ATMMPOA	include/if_ether.h	64;"	d
-ETH_P_AX25	include/if_ether.h	74;"	d
-ETH_P_BPQ	include/if_ether.h	45;"	d
-ETH_P_CONTROL	include/if_ether.h	85;"	d
-ETH_P_CUST	include/if_ether.h	54;"	d
-ETH_P_DDCMP	include/if_ether.h	78;"	d
-ETH_P_DEC	include/if_ether.h	48;"	d
-ETH_P_DIAG	include/if_ether.h	53;"	d
-ETH_P_DNA_DL	include/if_ether.h	49;"	d
-ETH_P_DNA_RC	include/if_ether.h	50;"	d
-ETH_P_DNA_RT	include/if_ether.h	51;"	d
-ETH_P_ECONET	include/ieee80211.h	544;"	d
-ETH_P_ECONET	include/if_ether.h	87;"	d
-ETH_P_IEEEPUP	include/if_ether.h	46;"	d
-ETH_P_IEEEPUPAT	include/if_ether.h	47;"	d
-ETH_P_IP	include/if_ether.h	42;"	d
-ETH_P_IPV6	include/if_ether.h	61;"	d
-ETH_P_IPX	include/if_ether.h	60;"	d
-ETH_P_IRDA	include/if_ether.h	86;"	d
-ETH_P_LAT	include/if_ether.h	52;"	d
-ETH_P_LOCALTALK	include/if_ether.h	81;"	d
-ETH_P_LOOP	include/if_ether.h	39;"	d
-ETH_P_MOBITEX	include/if_ether.h	84;"	d
-ETH_P_PAE	include/ieee80211.h	539;"	d
-ETH_P_PPPTALK	include/if_ether.h	82;"	d
-ETH_P_PPP_DISC	include/if_ether.h	62;"	d
-ETH_P_PPP_MP	include/if_ether.h	80;"	d
-ETH_P_PPP_SES	include/if_ether.h	63;"	d
-ETH_P_PREAUTH	include/ieee80211.h	542;"	d
-ETH_P_PUP	include/if_ether.h	40;"	d
-ETH_P_PUPAT	include/if_ether.h	41;"	d
-ETH_P_RARP	include/if_ether.h	56;"	d
-ETH_P_SCA	include/if_ether.h	55;"	d
-ETH_P_SNAP	include/if_ether.h	77;"	d
-ETH_P_TR_802_2	include/if_ether.h	83;"	d
-ETH_P_WAN_PPP	include/if_ether.h	79;"	d
-ETH_P_X25	include/if_ether.h	43;"	d
-ETH_TYPE_LEN	include/ieee80211.h	36;"	d
-ETH_TYPE_OFFSET	core/rtw_wlan_util.c	26;"	d	file:
-ETH_ZLEN	include/if_ether.h	31;"	d
-EUROPE	include/rtw_eeprom.h	45;"	d
-EUROPE	include/rtw_rf.h	84;"	d
-EVM_FastAntTrainingTimer	hal/phydm/phydm.h	/^	RT_TIMER 			EVM_FastAntTrainingTimer;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-EVM_METHOD	hal/phydm/phydm_antdiv.h	87;"	d
-EVM_method_enable	hal/phydm/phydm_antdiv.h	/^	BOOLEAN	EVM_method_enable;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-EVT_ALIVE	include/rtw_pwrctrl.h	42;"	d
-EXE_PWR_IPS	include/rtw_pwrctrl.h	187;"	d
-EXE_PWR_LPS	include/rtw_pwrctrl.h	188;"	d
-EXE_PWR_NONE	include/rtw_pwrctrl.h	186;"	d
-EXTCHNL_OFFSET	include/rtw_rf.h	/^} EXTCHNL_OFFSET, *PEXTCHNL_OFFSET;$/;"	t	typeref:enum:_EXTCHNL_OFFSET
-EXTCHNL_OFFSET_LOWER	include/rtw_rf.h	/^	EXTCHNL_OFFSET_LOWER = 3,$/;"	e	enum:_EXTCHNL_OFFSET
-EXTCHNL_OFFSET_NO_DEF	include/rtw_rf.h	/^	EXTCHNL_OFFSET_NO_DEF = 2,$/;"	e	enum:_EXTCHNL_OFFSET
-EXTCHNL_OFFSET_NO_EXT	include/rtw_rf.h	/^	EXTCHNL_OFFSET_NO_EXT = 0,$/;"	e	enum:_EXTCHNL_OFFSET
-EXTCHNL_OFFSET_UPPER	include/rtw_rf.h	/^	EXTCHNL_OFFSET_UPPER = 1,$/;"	e	enum:_EXTCHNL_OFFSET
-EXTEND_C2H_DBG_PRINT	hal/hal_com_c2h.h	/^	EXTEND_C2H_DBG_PRINT = 0$/;"	e	enum:_EXTEND_C2H_EVT
-EXTEND_C2H_EVT	hal/hal_com_c2h.h	/^} EXTEND_C2H_EVT;$/;"	t	typeref:enum:_EXTEND_C2H_EVT
-EXT_C2H_TRIG_BY_BT_FW	include/rtw_bt_mp.h	/^	EXT_C2H_TRIG_BY_BT_FW = 1,$/;"	e	enum:_RTL_EXT_C2H_EVT
-EXT_C2H_WIFI_FW_ACTIVE_RSP	include/rtw_bt_mp.h	/^	EXT_C2H_WIFI_FW_ACTIVE_RSP = 0,$/;"	e	enum:_RTL_EXT_C2H_EVT
-EXT_HEADER	include/rtw_efuse.h	67;"	d
-EXT_MP_IOCTL_HANDLER	include/rtw_mp_ioctl.h	520;"	d
-EXT_VENDOR_ID	include/hal_com_reg.h	1267;"	d
-EXT_VENDOR_ID_SHIFT	include/hal_com_reg.h	1282;"	d
-EX_MESSAGE_BOX_SIZE	hal/hal_halmac.h	37;"	d
-EXhalbtc8188c2ant_BtInfoNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_BtInfoNotify($/;"	f
-EXhalbtc8188c2ant_ConnectNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_ConnectNotify($/;"	f
-EXhalbtc8188c2ant_DisplayCoexInfo	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_DisplayCoexInfo($/;"	f
-EXhalbtc8188c2ant_HaltNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_HaltNotify($/;"	f
-EXhalbtc8188c2ant_InitCoexDm	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_InitCoexDm($/;"	f
-EXhalbtc8188c2ant_InitHwConfig	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_InitHwConfig($/;"	f
-EXhalbtc8188c2ant_IpsNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_IpsNotify($/;"	f
-EXhalbtc8188c2ant_LpsNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_LpsNotify($/;"	f
-EXhalbtc8188c2ant_MediaStatusNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_MediaStatusNotify($/;"	f
-EXhalbtc8188c2ant_Periodical	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_Periodical($/;"	f
-EXhalbtc8188c2ant_PowerOnSetting	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_PowerOnSetting($/;"	f
-EXhalbtc8188c2ant_ScanNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_ScanNotify($/;"	f
-EXhalbtc8188c2ant_SpecialPacketNotify	hal/btc/HalBtc8188c2Ant.c	/^EXhalbtc8188c2ant_SpecialPacketNotify($/;"	f
-EXhalbtc8192d2ant_BtInfoNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_BtInfoNotify($/;"	f
-EXhalbtc8192d2ant_ConnectNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_ConnectNotify($/;"	f
-EXhalbtc8192d2ant_DisplayCoexInfo	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_DisplayCoexInfo($/;"	f
-EXhalbtc8192d2ant_HaltNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_HaltNotify($/;"	f
-EXhalbtc8192d2ant_InitCoexDm	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_InitCoexDm($/;"	f
-EXhalbtc8192d2ant_InitHwConfig	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_InitHwConfig($/;"	f
-EXhalbtc8192d2ant_IpsNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_IpsNotify($/;"	f
-EXhalbtc8192d2ant_LpsNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_LpsNotify($/;"	f
-EXhalbtc8192d2ant_MediaStatusNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_MediaStatusNotify($/;"	f
-EXhalbtc8192d2ant_Periodical	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_Periodical($/;"	f
-EXhalbtc8192d2ant_PowerOnSetting	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_PowerOnSetting($/;"	f
-EXhalbtc8192d2ant_ScanNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_ScanNotify($/;"	f
-EXhalbtc8192d2ant_SpecialPacketNotify	hal/btc/HalBtc8192d2Ant.c	/^EXhalbtc8192d2ant_SpecialPacketNotify($/;"	f
-EXhalbtc8723a1ant_BtInfoNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_BtInfoNotify($/;"	f
-EXhalbtc8723a1ant_ConnectNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_ConnectNotify($/;"	f
-EXhalbtc8723a1ant_DisplayCoexInfo	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_DisplayCoexInfo($/;"	f
-EXhalbtc8723a1ant_HaltNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_HaltNotify($/;"	f
-EXhalbtc8723a1ant_InitCoexDm	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_InitCoexDm($/;"	f
-EXhalbtc8723a1ant_InitHwConfig	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_InitHwConfig($/;"	f
-EXhalbtc8723a1ant_IpsNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_IpsNotify($/;"	f
-EXhalbtc8723a1ant_LpsNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_LpsNotify($/;"	f
-EXhalbtc8723a1ant_MediaStatusNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_MediaStatusNotify($/;"	f
-EXhalbtc8723a1ant_Periodical	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_Periodical($/;"	f
-EXhalbtc8723a1ant_ScanNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_ScanNotify($/;"	f
-EXhalbtc8723a1ant_SpecialPacketNotify	hal/btc/HalBtc8723a1Ant.c	/^EXhalbtc8723a1ant_SpecialPacketNotify($/;"	f
-EXhalbtc8723a2ant_BtInfoNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_BtInfoNotify($/;"	f
-EXhalbtc8723a2ant_ConnectNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_ConnectNotify($/;"	f
-EXhalbtc8723a2ant_DisplayCoexInfo	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_DisplayCoexInfo($/;"	f
-EXhalbtc8723a2ant_HaltNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_HaltNotify($/;"	f
-EXhalbtc8723a2ant_InitCoexDm	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_InitCoexDm($/;"	f
-EXhalbtc8723a2ant_InitHwConfig	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_InitHwConfig($/;"	f
-EXhalbtc8723a2ant_IpsNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_IpsNotify($/;"	f
-EXhalbtc8723a2ant_LpsNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_LpsNotify($/;"	f
-EXhalbtc8723a2ant_MediaStatusNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_MediaStatusNotify($/;"	f
-EXhalbtc8723a2ant_Periodical	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_Periodical($/;"	f
-EXhalbtc8723a2ant_PowerOnSetting	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_PowerOnSetting($/;"	f
-EXhalbtc8723a2ant_ScanNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_ScanNotify($/;"	f
-EXhalbtc8723a2ant_SpecialPacketNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_SpecialPacketNotify($/;"	f
-EXhalbtc8723a2ant_StackOperationNotify	hal/btc/HalBtc8723a2Ant.c	/^EXhalbtc8723a2ant_StackOperationNotify($/;"	f
-EXhalbtcoutsrc_BTOffOnNotify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_BTOffOnNotify(PBTC_COEXIST pBtCoexist, u8 bBTON)$/;"	f
-EXhalbtcoutsrc_BindBtCoexWithAdapter	hal/hal_btcoex.c	/^u8 EXhalbtcoutsrc_BindBtCoexWithAdapter(void *padapter)$/;"	f
-EXhalbtcoutsrc_CoexDmSwitch	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_CoexDmSwitch(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_DisplayAntDetection	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_DisplayAntDetection(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_DisplayBtCoexInfo	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_DisplayBtCoexInfo(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_InitlizeVariables	hal/hal_btcoex.c	/^u8 EXhalbtcoutsrc_InitlizeVariables(void *padapter)$/;"	f
-EXhalbtcoutsrc_PowerOnSetting	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_PowerOnSetting(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_PreLoadFirmware	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_PreLoadFirmware(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_RfStatusNotify	hal/hal_btcoex.c	/^EXhalbtcoutsrc_RfStatusNotify($/;"	f
-EXhalbtcoutsrc_SetAntNum	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_SetAntNum(u8 type, u8 antNum)$/;"	f
-EXhalbtcoutsrc_SetAntennaPathNotify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_SetAntennaPathNotify(PBTC_COEXIST pBtCoexist, u8 type)$/;"	f
-EXhalbtcoutsrc_SetBtPatchVersion	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_SetBtPatchVersion(u16 btHciVersion, u16 btPatchVersion)$/;"	f
-EXhalbtcoutsrc_SetChipType	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_SetChipType(u8 chipType)$/;"	f
-EXhalbtcoutsrc_SetHciVersion	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_SetHciVersion(u16 hciVersion)$/;"	f
-EXhalbtcoutsrc_SetSingleAntPath	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_SetSingleAntPath(u8 singleAntPath)$/;"	f
-EXhalbtcoutsrc_StackOperationNotify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_StackOperationNotify(PBTC_COEXIST pBtCoexist, u8 type)$/;"	f
-EXhalbtcoutsrc_StackUpdateProfileInfo	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_StackUpdateProfileInfo(void)$/;"	f
-EXhalbtcoutsrc_SwitchBtTRxMask	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_SwitchBtTRxMask(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_UpdateMinBtRssi	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_UpdateMinBtRssi(s8 btRssi)$/;"	f
-EXhalbtcoutsrc_bt_info_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_bt_info_notify(PBTC_COEXIST pBtCoexist, u8 *tmpBuf, u8 length)$/;"	f
-EXhalbtcoutsrc_connect_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_connect_notify(PBTC_COEXIST pBtCoexist, u8 action)$/;"	f
-EXhalbtcoutsrc_dbg_control	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_dbg_control(PBTC_COEXIST pBtCoexist, u8 opCode, u8 opLen, u8 *pData)$/;"	f
-EXhalbtcoutsrc_halt_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_halt_notify(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_init_coex_dm	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_init_coex_dm(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_init_hw_config	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_init_hw_config(PBTC_COEXIST pBtCoexist, u8 bWifiOnly)$/;"	f
-EXhalbtcoutsrc_ips_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_ips_notify(PBTC_COEXIST pBtCoexist, u8 type)$/;"	f
-EXhalbtcoutsrc_lps_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_lps_notify(PBTC_COEXIST pBtCoexist, u8 type)$/;"	f
-EXhalbtcoutsrc_media_status_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_media_status_notify(PBTC_COEXIST pBtCoexist, RT_MEDIA_STATUS mediaStatus)$/;"	f
-EXhalbtcoutsrc_periodical	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_periodical(PBTC_COEXIST pBtCoexist)$/;"	f
-EXhalbtcoutsrc_pnp_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_pnp_notify(PBTC_COEXIST pBtCoexist, u8 pnpState)$/;"	f
-EXhalbtcoutsrc_scan_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_scan_notify(PBTC_COEXIST pBtCoexist, u8 type)$/;"	f
-EXhalbtcoutsrc_set_rfe_type	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_set_rfe_type(u8 type)$/;"	f
-EXhalbtcoutsrc_specific_packet_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_specific_packet_notify(PBTC_COEXIST pBtCoexist, u8 pktType)$/;"	f
-EXhalbtcoutsrc_switchband_notify	hal/hal_btcoex.c	/^void EXhalbtcoutsrc_switchband_notify(struct btc_coexist *pBtCoexist, u8 type)$/;"	f
-E_CUT_VERSION	include/HalVerDef.h	/^	E_CUT_VERSION		=	4,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-EepromAddressSize	include/drv_types.h	/^	u8	EepromAddressSize;$/;"	m	struct:_ADAPTER
-EepromOrEfuse	include/hal_data.h	/^	u8	EepromOrEfuse;$/;"	m	struct:hal_com_data
-EfuseGetCurrentSize	include/hal_intf.h	/^	u16(*EfuseGetCurrentSize)(_adapter *padapter, u8 efuseType, BOOLEAN bPseudoTest);$/;"	m	struct:hal_ops
-EfuseHal	include/hal_data.h	/^	EFUSE_HAL	EfuseHal;$/;"	m	struct:hal_com_data
-EfusePgPacketWrite_BT	core/efuse/rtw_efuse.c	/^u8 EfusePgPacketWrite_BT($/;"	f
-EfusePowerSwitch	include/hal_intf.h	/^	void (*EfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);$/;"	m	struct:hal_ops
-EfuseUsedBytes	include/hal_data.h	/^	u16	EfuseUsedBytes;$/;"	m	struct:hal_com_data
-EfuseUsedBytes	include/rtw_efuse.h	/^	u32	EfuseUsedBytes;$/;"	m	struct:_EFUSE_HAL
-EfuseUsedPercentage	include/hal_data.h	/^	u8	EfuseUsedPercentage;$/;"	m	struct:hal_com_data
-EfuseUsedPercentage	include/rtw_efuse.h	/^	u8	EfuseUsedPercentage;$/;"	m	struct:_EFUSE_HAL
-Efuse_CalculateWordCnts	core/efuse/rtw_efuse.c	/^Efuse_CalculateWordCnts(IN u8	word_en)$/;"	f
-Efuse_GetCurrentSize	core/efuse/rtw_efuse.c	/^Efuse_GetCurrentSize($/;"	f
-Efuse_InitSomeVar	core/efuse/rtw_efuse.c	/^Efuse_InitSomeVar($/;"	f
-Efuse_PgPacketRead	core/efuse/rtw_efuse.c	/^Efuse_PgPacketRead(IN	PADAPTER	pAdapter,$/;"	f
-Efuse_PgPacketRead	core/efuse/rtw_efuse.c	/^int Efuse_PgPacketRead(PADAPTER adapter, u8 offset, u8 *data, BOOLEAN test)$/;"	f
-Efuse_PgPacketRead	include/hal_intf.h	/^	int	(*Efuse_PgPacketRead)(_adapter *padapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);$/;"	m	struct:hal_ops
-Efuse_PgPacketWrite	core/efuse/rtw_efuse.c	/^Efuse_PgPacketWrite(IN	PADAPTER	pAdapter,$/;"	f
-Efuse_PgPacketWrite	core/efuse/rtw_efuse.c	/^int Efuse_PgPacketWrite(PADAPTER adapter, u8 offset, u8 word_en, u8 *data, BOOLEAN test)$/;"	f
-Efuse_PgPacketWrite	include/hal_intf.h	/^	int	(*Efuse_PgPacketWrite)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);$/;"	m	struct:hal_ops
-Efuse_PgPacketWrite_BT	core/efuse/rtw_efuse.c	/^Efuse_PgPacketWrite_BT(IN	PADAPTER	pAdapter,$/;"	f
-Efuse_PgPacketWrite_BT	include/hal_intf.h	/^	BOOLEAN(*Efuse_PgPacketWrite_BT)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);$/;"	m	struct:hal_ops
-Efuse_PowerSwitch	core/efuse/rtw_efuse.c	/^Efuse_PowerSwitch($/;"	f
-Efuse_PowerSwitch	core/efuse/rtw_efuse.c	/^void Efuse_PowerSwitch(PADAPTER adapter, u8 write, u8 pwrstate)$/;"	f
-Efuse_Read1ByteFromFakeContent	core/efuse/rtw_efuse.c	/^Efuse_Read1ByteFromFakeContent($/;"	f
-Efuse_ReadAllMap	core/efuse/rtw_efuse.c	/^Efuse_ReadAllMap($/;"	f
-Efuse_WordEnableDataWrite	core/efuse/rtw_efuse.c	/^Efuse_WordEnableDataWrite(IN	PADAPTER	pAdapter,$/;"	f
-Efuse_WordEnableDataWrite	include/hal_intf.h	/^	u8(*Efuse_WordEnableDataWrite)(_adapter *padapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);$/;"	m	struct:hal_ops
-Efuse_Write1ByteToFakeContent	core/efuse/rtw_efuse.c	/^Efuse_Write1ByteToFakeContent($/;"	f
-ElementID	include/wlan_bssdef.h	/^	UCHAR  ElementID;$/;"	m	struct:_NDIS_802_11_VARIABLE_IEs
-EnMBID	include/hal_com_reg.h	1563;"	d
-EnPDN	include/hal_com_reg.h	1174;"	d
-EnableInterrupt8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void EnableInterrupt8723DSdio(PADAPTER padapter)$/;"	f
-EncryptStatusSupported	include/wlan_bssdef.h	/^	NDIS_802_11_ENCRYPTION_STATUS EncryptStatusSupported;$/;"	m	struct:_NDIS_802_11_AUTHENTICATION_ENCRYPTION
-EntryMaxUndecoratedSmoothedPWDB	include/hal_data.h	/^	int			EntryMaxUndecoratedSmoothedPWDB;$/;"	m	struct:hal_com_data
-EntryMinUndecoratedSmoothedPWDB	include/hal_data.h	/^	int			EntryMinUndecoratedSmoothedPWDB;$/;"	m	struct:hal_com_data
-ErrorOrNot	include/hal_phy.h	/^	u8		ErrorOrNot;$/;"	m	struct:RF_Shadow_Compare_Map
-EventCode	include/rtw_btcoex.h	/^	u8		EventCode;$/;"	m	struct:_PACKET_IRP_HCIEVENT_DATA
-Evm_RSSI_TH_High	hal/phydm/phydm_antdiv.h	97;"	d
-Evm_RSSI_TH_Low	hal/phydm/phydm_antdiv.h	98;"	d
-ExtConfig	include/rtw_btcoex.h	/^	HCI_EXT_CONFIG		ExtConfig;$/;"	m	struct:_BT_MGNT
-ExtLNA	hal/phydm/phydm.h	/^	u1Byte			ExtLNA;		\/*2G*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ExtLNA5G	hal/phydm/phydm.h	/^	u1Byte			ExtLNA5G;	\/*5G*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ExtLNAGain	hal/phydm/phydm.h	/^	u1Byte			ExtLNAGain;	\/*2G*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ExtPA	hal/phydm/phydm.h	/^	u1Byte			ExtPA;		\/*2G*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ExtPA5G	hal/phydm/phydm.h	/^	u1Byte			ExtPA5G;	\/*5G*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ExtTRSW	hal/phydm/phydm.h	/^	u1Byte			ExtTRSW;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ExternalLNA_2G	include/hal_data.h	/^	u8	ExternalLNA_2G;$/;"	m	struct:hal_com_data
-ExternalLNA_5G	include/hal_data.h	/^	u8	ExternalLNA_5G;$/;"	m	struct:hal_com_data
-ExternalPA_2G	include/hal_data.h	/^	u8	ExternalPA_2G;$/;"	m	struct:hal_com_data
-ExternalPA_5G	include/hal_data.h	/^	u8	ExternalPA_5G;$/;"	m	struct:hal_com_data
-FAHighThresh	hal/phydm/phydm_dig.h	/^	u4Byte		FAHighThresh;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-FAIL	hal/phydm/phydm_types.h	125;"	d
-FAIL	include/basic_types.h	25;"	d
-FALSE	hal/phydm/phydm_types.h	234;"	d
-FALSE	include/HalVerDef.h	24;"	d
-FALSE_ALARM_STATISTICS	hal/phydm/phydm_dig.h	/^}FALSE_ALARM_STATISTICS, *PFALSE_ALARM_STATISTICS;$/;"	t	typeref:struct:_FALSE_ALARM_STATISTICS
-FALowThresh	hal/phydm/phydm_dig.h	/^	u4Byte		FALowThresh;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-FAT_BEFORE_LINK_STATE	hal/phydm/phydm_antdiv.h	/^	FAT_BEFORE_LINK_STATE	= 0,$/;"	e	enum:_FAT_STATE
-FAT_DECISION_STATE	hal/phydm/phydm_antdiv.h	/^	FAT_DECISION_STATE		= 3$/;"	e	enum:_FAT_STATE
-FAT_OFF	hal/phydm/phydm_antdiv.h	81;"	d
-FAT_ON	hal/phydm/phydm_antdiv.h	80;"	d
-FAT_PREPARE_STATE	hal/phydm/phydm_antdiv.h	/^	FAT_PREPARE_STATE			= 1,$/;"	e	enum:_FAT_STATE
-FAT_STATE_E	hal/phydm/phydm_antdiv.h	/^}FAT_STATE_E, *PFAT_STATE_E;$/;"	t	typeref:enum:_FAT_STATE
-FAT_State	hal/phydm/phydm_antdiv.h	/^	u1Byte	FAT_State;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-FAT_T	hal/phydm/phydm_antdiv.h	/^}FAT_T,*pFAT_T;$/;"	t	typeref:struct:_FAST_ANTENNA_TRAINNING_
-FAT_TRAINING_STATE	hal/phydm/phydm_antdiv.h	/^	FAT_TRAINING_STATE		= 2,$/;"	e	enum:_FAT_STATE
-FEN_BBRSTB	include/hal_com_reg.h	1152;"	d
-FEN_BB_GLB_RSTn	include/hal_com_reg.h	1153;"	d
-FEN_BT	include/hal_com_reg.h	1290;"	d
-FEN_CPUEN	include/hal_com_reg.h	1162;"	d
-FEN_DCORE	include/hal_com_reg.h	1163;"	d
-FEN_DIOE	include/hal_com_reg.h	1161;"	d
-FEN_DIO_PCIE	include/hal_com_reg.h	1157;"	d
-FEN_ELDR	include/hal_com_reg.h	1164;"	d
-FEN_EN_25_1	include/hal_com_reg.h	1165;"	d
-FEN_GPS	include/hal_com_reg.h	1289;"	d
-FEN_HWPDN	include/hal_com_reg.h	1166;"	d
-FEN_MREGEN	include/hal_com_reg.h	1167;"	d
-FEN_PCI	include/hal_com_reg.h	1292;"	d
-FEN_PCIEA	include/hal_com_reg.h	1158;"	d
-FEN_PCIED	include/hal_com_reg.h	1160;"	d
-FEN_PPLL	include/hal_com_reg.h	1159;"	d
-FEN_UPLL	include/hal_com_reg.h	1155;"	d
-FEN_USB	include/hal_com_reg.h	1293;"	d
-FEN_USBA	include/hal_com_reg.h	1154;"	d
-FEN_USBD	include/hal_com_reg.h	1156;"	d
-FEN_WL	include/hal_com_reg.h	1291;"	d
-FFT_128_TYPE	hal/phydm/phydm.h	97;"	d
-FFT_256_TYPE	hal/phydm/phydm.h	98;"	d
-FHConfig	include/wlan_bssdef.h	/^	NDIS_802_11_CONFIGURATION_FH    FHConfig;$/;"	m	struct:_NDIS_802_11_CONFIGURATION
-FIELD_OFFSET	include/basic_types.h	111;"	d
-FIELD_OFFSET	include/basic_types.h	156;"	d
-FIFO_DOMAIN_ID_FORMAT	include/gspi_ops.h	121;"	d
-FIFO_FUN_FORMAT	include/gspi_ops.h	122;"	d
-FIFO_LEN_FORMAT	include/gspi_ops.h	119;"	d
-FIFO_RW_FORMAT	include/gspi_ops.h	123;"	d
-FIRMWARE_FIFO_BASE	include/hal_com_reg.h	1604;"	d
-FIRMWARE_MAX_SIZE	hal/hal_halmac.c	28;"	d	file:
-FIRMWARE_SOURCE	include/hal_com.h	/^} FIRMWARE_SOURCE, *PFIRMWARE_SOURCE;$/;"	t	typeref:enum:_FIRMWARE_SOURCE
-FIXED_HW_ANTDIV	hal/phydm/phydm_antdiv.h	/^	FIXED_HW_ANTDIV		= 0x03,$/;"	e	enum:_ANT_DIV_TYPE
-FIX_AUX_AT_MAIN	hal/phydm/phydm_antdiv.h	56;"	d
-FIX_TX_AT_MAIN	hal/phydm/phydm_antdiv.h	55;"	d
-FORCEACK	include/hal_com_reg.h	1564;"	d
-FORCE_EXEC	hal/btc/HalBtcOutSrc.h	20;"	d
-FORCE_RSSI_DIFF	hal/phydm/phydm_antdiv.h	104;"	d
-FOR_BRAZIL_PRETEST	hal/phydm/phydm_types.h	243;"	d
-FOUR_MSDU	include/wlan_bssdef.h	/^	FOUR_MSDU,$/;"	e	enum:UAPSD_MAX_SP
-FPGA	include/HalVerDef.h	/^	FPGA			=	2,$/;"	e	enum:tag_HAL_CHIP_Type_Definition
-FPGA_TWO_MAC_VERIFICATION	hal/phydm/phydm_types.h	244;"	d
-FRAME_OFFSET_VHT_GID_MGNT_MEMBERSHIP_STATUS_ARRAY	core/rtw_beamforming.c	1775;"	d	file:
-FRAME_OFFSET_VHT_GID_MGNT_USER_POSITION_ARRAY	core/rtw_beamforming.c	1776;"	d	file:
-FREE_ASSOC_RESOURCES	include/rtw_cmd.h	/^	FREE_ASSOC_RESOURCES, \/* add for CONFIG_IEEE80211W, none 11w also can use *\/$/;"	e	enum:rtw_drvextra_cmd_id
-FREE_CMDOBJ_SZ	include/rtw_cmd.h	28;"	d
-FREQ_NEGATIVE	hal/phydm/phydm.h	105;"	d
-FREQ_POSITIVE	hal/phydm/phydm.h	104;"	d
-FREQ_RT_2G_EFSI1	hal/phydm/rtchnlplan.h	440;"	d
-FREQ_RT_2G_ETSI2	hal/phydm/rtchnlplan.h	446;"	d
-FREQ_RT_2G_FCC1	hal/phydm/rtchnlplan.h	442;"	d
-FREQ_RT_2G_MKK1	hal/phydm/rtchnlplan.h	444;"	d
-FREQ_RT_2G_NULL	hal/phydm/rtchnlplan.h	435;"	d
-FREQ_RT_2G_WORLD	hal/phydm/rtchnlplan.h	438;"	d
-FSG	include/rtl8188e_xmit.h	46;"	d
-FSG	include/rtl8192e_xmit.h	151;"	d
-FSG	include/rtl8812a_xmit.h	44;"	d
-FT_ACTION_REQ_LIMIT	include/rtw_mlme.h	526;"	d
-FUNC_ADPT_ARG	include/osdep_service_bsd.h	744;"	d
-FUNC_ADPT_ARG	include/osdep_service_ce.h	186;"	d
-FUNC_ADPT_ARG	include/osdep_service_linux.h	432;"	d
-FUNC_ADPT_ARG	include/osdep_service_xp.h	197;"	d
-FUNC_ADPT_FMT	include/osdep_service_bsd.h	743;"	d
-FUNC_ADPT_FMT	include/osdep_service_ce.h	185;"	d
-FUNC_ADPT_FMT	include/osdep_service_linux.h	431;"	d
-FUNC_ADPT_FMT	include/osdep_service_xp.h	196;"	d
-FUNC_NDEV_ARG	include/osdep_service_bsd.h	742;"	d
-FUNC_NDEV_ARG	include/osdep_service_ce.h	184;"	d
-FUNC_NDEV_ARG	include/osdep_service_linux.h	430;"	d
-FUNC_NDEV_ARG	include/osdep_service_xp.h	195;"	d
-FUNC_NDEV_FMT	include/osdep_service_bsd.h	741;"	d
-FUNC_NDEV_FMT	include/osdep_service_ce.h	183;"	d
-FUNC_NDEV_FMT	include/osdep_service_linux.h	429;"	d
-FUNC_NDEV_FMT	include/osdep_service_xp.h	194;"	d
-FUNC_WIPHY_ARG	os_dep/linux/ioctl_cfg80211.h	194;"	d
-FUNC_WIPHY_FMT	os_dep/linux/ioctl_cfg80211.h	193;"	d
-FWDL_ChkSum_rpt	include/hal_com_reg.h	1241;"	d
-FWDL_EN	include/rtl8814a_spec.h	496;"	d
-FWDL_OK	include/rtl8814a_spec.h	509;"	d
-FW_8188E_END_ADDRESS	include/rtl8188e_hal.h	62;"	d
-FW_8188E_SIZE	include/rtl8188e_hal.h	58;"	d
-FW_8188E_SIZE_2	include/rtl8188e_hal.h	59;"	d
-FW_8188E_START_ADDRESS	include/rtl8188e_hal.h	61;"	d
-FW_8188F_END_ADDRESS	include/rtl8188f_hal.h	41;"	d
-FW_8188F_SIZE	include/rtl8188f_hal.h	39;"	d
-FW_8188F_START_ADDRESS	include/rtl8188f_hal.h	40;"	d
-FW_8703B_END_ADDRESS	include/rtl8703b_hal.h	41;"	d
-FW_8703B_SIZE	include/rtl8703b_hal.h	39;"	d
-FW_8703B_START_ADDRESS	include/rtl8703b_hal.h	40;"	d
-FW_8723B_END_ADDRESS	include/rtl8723b_hal.h	41;"	d
-FW_8723B_SIZE	include/rtl8723b_hal.h	39;"	d
-FW_8723B_START_ADDRESS	include/rtl8723b_hal.h	40;"	d
-FW_8723D_END_ADDRESS	include/rtl8723d_hal.h	44;"	d
-FW_8723D_SIZE	include/rtl8723d_hal.h	42;"	d
-FW_8723D_START_ADDRESS	include/rtl8723d_hal.h	43;"	d
-FW_ADOPT_USER	include/hal_com_h2c.h	201;"	d
-FW_ARP_EN	include/hal_com_h2c.h	205;"	d
-FW_CHKSUM_DUMMY_SZ	include/rtl8814a_spec.h	485;"	d
-FW_DECISION_DISCONNECT	include/hal_com.h	/^	FW_DECISION_DISCONNECT			= 0x10,$/;"	e	enum:_WAKEUP_REASON
-FW_DOWNLOAD_SIZE_8723D	hal/rtl8723d/rtl8723d_hal_init.c	30;"	d	file:
-FW_END_ADDRESS	include/rtl8192e_hal.h	61;"	d
-FW_END_ADDRESS	include/rtl8812a_hal.h	72;"	d
-FW_FIFO_DOMAIN	include/gspi_ops.h	30;"	d
-FW_FIFO_OFFSET	include/gspi_ops.h	40;"	d
-FW_FW_PARSE_MAGIC_PKT	include/hal_com_h2c.h	195;"	d
-FW_INIT_RDY	include/rtl8814a_spec.h	510;"	d
-FW_NDPA_PAGE_NUM	include/rtl8812a_hal.h	155;"	d
-FW_NDPA_PAGE_NUM	include/rtl8812a_hal.h	157;"	d
-FW_PWR0	include/rtw_pwrctrl.h	24;"	d
-FW_PWR1	include/rtw_pwrctrl.h	25;"	d
-FW_PWR2	include/rtw_pwrctrl.h	26;"	d
-FW_PWR3	include/rtw_pwrctrl.h	27;"	d
-FW_PWRMSK	include/rtw_pwrctrl.h	36;"	d
-FW_REALWOWLAN_EN	include/hal_com_h2c.h	198;"	d
-FW_REALWOWLAN_EN	include/hal_com_h2c.h	206;"	d
-FW_REMOTE_WAKE_CTRL_EN	include/hal_com_h2c.h	197;"	d
-FW_REMOTE_WAKE_CTRL_EN	include/hal_com_h2c.h	204;"	d
-FW_SIZE	include/rtl8814a_hal.h	46;"	d
-FW_SIZE_8192E	include/rtl8192e_hal.h	59;"	d
-FW_SIZE_8812	include/rtl8812a_hal.h	70;"	d
-FW_SOURCE_HEADER_FILE	include/hal_com.h	/^	FW_SOURCE_HEADER_FILE = 1,		\/* from header file *\/$/;"	e	enum:_FIRMWARE_SOURCE
-FW_SOURCE_IMG_FILE	include/hal_com.h	/^	FW_SOURCE_IMG_FILE = 0,$/;"	e	enum:_FIRMWARE_SOURCE
-FW_START_ADDRESS	include/rtl8192e_hal.h	60;"	d
-FW_START_ADDRESS	include/rtl8812a_hal.h	71;"	d
-FW_START_ADDRESS	include/rtl8814a_hal.h	47;"	d
-FW_START_ADDRESS	include/usb_ops_linux.h	24;"	d
-FW_WOWLAN_ALL_PKT_DROP	include/hal_com_h2c.h	189;"	d
-FW_WOWLAN_DEAUTH_WAKEUP	include/hal_com_h2c.h	192;"	d
-FW_WOWLAN_FUN_EN	include/hal_com_h2c.h	185;"	d
-FW_WOWLAN_GPIO_ACTIVE	include/hal_com_h2c.h	190;"	d
-FW_WOWLAN_GPIO_WAKEUP_EN	include/hal_com_h2c.h	194;"	d
-FW_WOWLAN_KEEP_ALIVE_EN	include/hal_com_h2c.h	200;"	d
-FW_WOWLAN_KEEP_ALIVE_PKT_TYPE	include/hal_com_h2c.h	202;"	d
-FW_WOWLAN_MAGIC_PKT	include/hal_com_h2c.h	187;"	d
-FW_WOWLAN_PATTERN_MATCH	include/hal_com_h2c.h	186;"	d
-FW_WOWLAN_REKEY_WAKEUP	include/hal_com_h2c.h	191;"	d
-FW_WOWLAN_UNICAST	include/hal_com_h2c.h	188;"	d
-FW_WOW_FW_UNICAST_EN	include/hal_com_h2c.h	207;"	d
-F_CUT_VERSION	include/HalVerDef.h	/^	F_CUT_VERSION		=	5,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-F_RATE_AP_RPT	hal/phydm/phydm_debug.h	77;"	d
-FabVersion	hal/phydm/phydm.h	/^	u1Byte			FabVersion;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-FalseAlmCnt	hal/phydm/phydm.h	/^	FALSE_ALARM_STATISTICS		FalseAlmCnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-FastAntTrainingTimer	hal/phydm/phydm.h	/^	RT_TIMER 	FastAntTrainingTimer;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-FastAntTrainingWorkitem	hal/phydm/phydm.h	/^	RT_WORK_ITEM			FastAntTrainingWorkitem;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-FeedbackType	hal/phydm/phydm_beamforming.h	/^	u2Byte	FeedbackType:1;$/;"	m	struct:_RT_NDPA_STA_INFO
-FieldOffset	include/drv_types_ce.h	/^	uint			FieldOffset;	\/* offset to MP_ADAPTER field *\/$/;"	m	struct:_MP_REG_ENTRY
-FieldOffset	include/drv_types_xp.h	/^	uint			FieldOffset;	\/* offset to MP_ADAPTER field *\/$/;"	m	struct:_MP_REG_ENTRY
-FieldSize	include/drv_types_ce.h	/^	uint			FieldSize;	\/* size (in bytes) of the field *\/$/;"	m	struct:_MP_REG_ENTRY
-FieldSize	include/drv_types_xp.h	/^	uint			FieldSize;	\/* size (in bytes) of the field *\/$/;"	m	struct:_MP_REG_ENTRY
-FillH2CCmd8723D	hal/rtl8723d/rtl8723d_cmd.c	/^s32 FillH2CCmd8723D(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)$/;"	f
-FindMinimumRSSI	hal/phydm/phydm_rainfo.c	/^FindMinimumRSSI($/;"	f	file:
-FirmwareDownloadBT	hal/rtl8723d/rtl8723d_hal_init.c	/^s32 FirmwareDownloadBT(PADAPTER padapter, PRT_MP_FIRMWARE pFirmware)$/;"	f
-FirmwareSignature	include/hal_data.h	/^	u16	FirmwareSignature;$/;"	m	struct:hal_com_data
-FirmwareSubVersion	include/hal_data.h	/^	u16	FirmwareSubVersion;$/;"	m	struct:hal_com_data
-FirmwareVersion	include/hal_data.h	/^	u16	FirmwareVersion;$/;"	m	struct:hal_com_data
-FirmwareVersionRev	include/hal_data.h	/^	u16	FirmwareVersionRev;$/;"	m	struct:hal_com_data
-FirstMUBFeeIndex	hal/phydm/phydm_beamforming.h	/^	u1Byte					FirstMUBFeeIndex;$/;"	m	struct:_RT_BEAMFORMING_INFO
-FixOrContinuous	include/rtw_io.h	/^	u32		FixOrContinuous:1;	\/* 0:continuous, 1: Fix *\/$/;"	m	struct:reg_protocol_rd
-FixOrContinuous	include/rtw_io.h	/^	u32		FixOrContinuous:1;	\/* 0:continuous, 1: Fix *\/$/;"	m	struct:reg_protocol_wt
-Flags	include/wlan_bssdef.h	/^	ULONG Flags;$/;"	m	struct:_NDIS_802_11_AUTHENTICATION_REQUEST
-Flags	include/wlan_bssdef.h	/^	ULONG Flags;$/;"	m	struct:_PMKID_CANDIDATE
-FlaseAlmCntBuddyAdapter	hal/phydm/phydm.h	/^	FALSE_ALARM_STATISTICS		FlaseAlmCntBuddyAdapter;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ForbiddenIGI	hal/phydm/phydm_dig.h	/^	u1Byte		ForbiddenIGI;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-ForcePowerTrainingState	hal/phydm/phydm.h	/^	u1Byte			ForcePowerTrainingState;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ForceTxAntByDesc	hal/phydm/phydm_antdiv.h	/^	u1Byte	ForceTxAntByDesc; \/*A temp value, will hook to driver team's outer parameter later*\/$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-ForcedDataRate	include/hal_data.h	/^	u16	ForcedDataRate;	\/* Force Data Rate. 0: Auto, 0x02: 1M ~ 0x6C: 54M. *\/$/;"	m	struct:hal_com_data
-Foundry	include/rtl8188e_hal.h	/^	u8		Foundry;$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Freq_Start	hal/phydm/rtchnlplan.h	/^	u2Byte	Freq_Start;$/;"	m	struct:_RT_CHNL_PLAN_LIMIT
-Freq_end	hal/phydm/rtchnlplan.h	/^	u2Byte	Freq_end;	$/;"	m	struct:_RT_CHNL_PLAN_LIMIT
-FuncAllSwing	hal/phydm/halphyrf_ap.h	/^typedef VOID	(*FuncAllSwing)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncAllSwing	hal/phydm/halphyrf_win.h	/^typedef VOID(*FuncAllSwing)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncIQK	hal/phydm/halphyrf_ap.h	/^typedef VOID(*FuncIQK)(PVOID, u1Byte, u1Byte, u1Byte);$/;"	t
-FuncIQK	hal/phydm/halphyrf_ce.h	/^typedef VOID(*FuncIQK)(PVOID, u1Byte, u1Byte, u1Byte);$/;"	t
-FuncIQK	hal/phydm/halphyrf_win.h	/^typedef VOID(*FuncIQK)(PVOID, u1Byte, u1Byte, u1Byte);$/;"	t
-FuncLCK	hal/phydm/halphyrf_ap.h	/^typedef VOID 	(*FuncLCK)(PVOID);$/;"	t
-FuncLCK	hal/phydm/halphyrf_ce.h	/^typedef VOID 	(*FuncLCK)(PVOID);$/;"	t
-FuncLCK	hal/phydm/halphyrf_win.h	/^typedef VOID(*FuncLCK)(PVOID);$/;"	t
-FuncSetPwr	hal/phydm/halphyrf_ap.h	/^typedef VOID 	(*FuncSetPwr)(PVOID, PWRTRACK_METHOD, u1Byte, u1Byte);$/;"	t
-FuncSetPwr	hal/phydm/halphyrf_ce.h	/^typedef VOID 	(*FuncSetPwr)(PVOID, PWRTRACK_METHOD, u1Byte, u1Byte);$/;"	t
-FuncSetPwr	hal/phydm/halphyrf_win.h	/^typedef VOID(*FuncSetPwr)(PVOID, PWRTRACK_METHOD, u1Byte, u1Byte);$/;"	t
-FuncSetXtal	hal/phydm/halphyrf_ce.h	/^typedef VOID(*FuncSetXtal)(PVOID);$/;"	t
-FuncSetXtal	hal/phydm/halphyrf_win.h	/^typedef VOID (*FuncSetXtal)(PVOID);$/;"	t
-FuncSwing	hal/phydm/halphyrf_ap.h	/^typedef VOID  	(*FuncSwing)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncSwing	hal/phydm/halphyrf_ce.h	/^typedef VOID  	(*FuncSwing)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncSwing	hal/phydm/halphyrf_win.h	/^typedef VOID(*FuncSwing)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncSwing8814only	hal/phydm/halphyrf_ap.h	/^typedef VOID	(*FuncSwing8814only)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncSwing8814only	hal/phydm/halphyrf_ce.h	/^typedef VOID	(*FuncSwing8814only)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncSwing8814only	hal/phydm/halphyrf_win.h	/^typedef VOID(*FuncSwing8814only)(PVOID, pu1Byte*, pu1Byte*, pu1Byte*, pu1Byte*);$/;"	t
-FuncSwingXtal	hal/phydm/halphyrf_ce.h	/^typedef VOID(*FuncSwingXtal)(PVOID, ps1Byte*, ps1Byte*);$/;"	t
-FuncSwingXtal	hal/phydm/halphyrf_win.h	/^typedef VOID (*FuncSwingXtal)(PVOID, ps1Byte*, ps1Byte*);$/;"	t
-Function	include/rtl8188e_hal.h	/^	u8		Function;	\/* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Function	include/rtl8188f_hal.h	/^	u8		Function;	\/* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Function	include/rtl8703b_hal.h	/^	u8		Function;	\/* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Function	include/rtl8723b_hal.h	/^	u8		Function;	\/* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Function	include/rtl8723d_hal.h	/^	u8		Function;	\/* Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-FwBuffer	hal/rtl8723d/rtl8723d_hal_init.c	/^	u8 FwBuffer[FW_8723D_SIZE];$/;"	v
-FwRsvdPageStartOffset	include/hal_data.h	/^	u8	FwRsvdPageStartOffset; \/* 2010.06.23. Added by tynli. Reserve page start offset except beacon in TxQ.*\/$/;"	m	struct:hal_com_data
-GCC_VER_49	Makefile	/^GCC_VER_49 := $(shell echo `$(CC) -dumpversion | cut -f1-2 -d.` \\>= 4.9 | bc )$/;"	m
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_AddBAReq) , \/*45*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_AddBARsp) , \/*65*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_ChkBMCSleepq), \/*63*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_CreateBss) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_DelAssocSta) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_DisConnect) , \/*15*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetBasicRate) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetCCXReport), \/*40*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetDTMReport),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetDataRate) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetPhy) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetPhyInfo) ,	\/*30*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetRaTable) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_GetTXRateStatistics),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_JoinBss),   \/*14*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_JoinbssRpt),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_LedBlink), \/*60*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Read_BBREG) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Read_CAM) ,	\/*10*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Read_EEPROM) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Read_EFUSE) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Read_MACREG) ,	\/*0*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Read_RFREG) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_RunInThreadCMD), \/*64*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetAssocSta) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetAtim) , \/*35*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetAuth) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetBasicRate) , \/*25*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetCarrierSuppressionTx),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetChannel), \/*46*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetChannelPlan), \/*59*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetChannelSwitch), \/*61*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetContinuousTx),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetCrystalCap),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetDataRate) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetH2cLbk),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetKey) ,	\/*20*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetOpMode) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetPhy) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetPhyInfo) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetPwrMode) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetRaTable) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetSingleCarrierTx), \/*50*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetSingleToneTx),\/*51*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetStaKey) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetStaPwrState) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetTxPower),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SetUsbSuspend),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Set_Drv_Extra), \/*57*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Set_H2C_MSG), \/*58*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Set_MLME_EVT), \/*56*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SiteSurvey),  \/*18*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SwitchAntenna),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_SwitchBandwidth), \/*54*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_TDLS), \/*62*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_TX_Beacon), \/*55*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Write_BBREG) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Write_CAM) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Write_EEPROM) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Write_EFUSE) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Write_MACREG) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_Write_RFREG) , \/*5*\/$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_readGain) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_readRssi) ,$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_setBCNITV),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	/^	GEN_CMD_CODE(_setMBIDCFG),$/;"	e	enum:rtw_h2c_cmd
-GEN_CMD_CODE	include/rtw_cmd.h	989;"	d
-GEN_DRV_CMD_HANDLER	include/rtw_mlme_ext.h	1103;"	d
-GEN_EVT_CODE	include/rtw_event.h	99;"	d
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_ADDBA),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_AddSTA),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_AtimDone) ,$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_C2HBCN),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_C2HFEEDBACK),               \/*20*\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_C2HLBK),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_CCX_Report),			\/*15*\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_CloseRF),				\/* filen: only for PCIE, work around ASPM *\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_DTM_Report),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_DelSTA),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_FT_REASSOC),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_FWDBG),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Get_BasicRate),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Get_DataRate),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_JoinBss) , \/*10*\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Read_BBREG),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Read_CAM),			\/*5*\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Read_EEPROM),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Read_EFUSE),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Read_MACREG) = 0, \/*0*\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Read_RFREG),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_ReportPwrState),		\/* filen: only for PCIE, USB	 *\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Survey),	 \/*8*\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_SurveyDone),	 \/*9*\/$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_TX_Rate_Statistics),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_TX_Report),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_TimeoutSTA),$/;"	e	enum:rtw_c2h_event
-GEN_EVT_CODE	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_WMM),					\/*25*\/$/;"	e	enum:rtw_c2h_event
-GEN_MLME_EXT_HANDLER	include/rtw_mlme_ext.h	1104;"	d
-GEN_MP_IOCTL_HANDLER	include/rtw_mp_ioctl.h	518;"	d
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(CNTU_TX),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(CS_TX),			\/*15*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(DEL_BA),			\/*33*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(EFUSE),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(EFUSE_MAP),		\/*25*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(GET_EFUSE_CURRENT_SIZE),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(GET_EFUSE_MAX_SIZE),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_ERROR),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_RECV),	\/*20*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(GET_THERMAL_METER),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(GET_WIFI_STATUS),	\/*34*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(IOCTL_XMIT_PACKET),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(MP_START),			\/*0*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(MP_STOP),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(READ16_EEPROM),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(READ_BB_REG),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(READ_REG),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(READ_RF_REG),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(RESET_PHY_RX_PKT_CNT),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SC_TX),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_ANTENNA),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_BANDWIDTH),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_CHANNEL),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_DATARATE),		\/*10*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_DM_BT),		\/*32*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_POWER_DOWN),		\/*30*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_PTM),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_RX_PKT_TYPE),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(SET_TXPOWER),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(ST_TX),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(TRIGGER_GPIO),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(WRITE16_EEPROM),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(WRITE_BB_REG),		\/*5*\/$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(WRITE_REG),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	GEN_MP_IOCTL_SUBCODE(WRITE_RF_REG),$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-GEN_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	473;"	d
-GETU32	include/rtw_security.h	373;"	d
-GET_8188F_H2CCMD_PWRMODE_PARM_MODE	include/rtl8188f_cmd.h	123;"	d
-GET_8192E_C2H_TX_RPT_DATA_RETRY_CNT	include/rtl8192e_cmd.h	157;"	d
-GET_8192E_C2H_TX_RPT_FINAL_DATA_RATE	include/rtl8192e_cmd.h	159;"	d
-GET_8192E_C2H_TX_RPT_LIFE_TIME_OVER	include/rtl8192e_cmd.h	154;"	d
-GET_8192E_C2H_TX_RPT_MAC_ID	include/rtl8192e_cmd.h	156;"	d
-GET_8192E_C2H_TX_RPT_PKT_BROCAST	include/rtl8192e_cmd.h	153;"	d
-GET_8192E_C2H_TX_RPT_QUEUE_SELECT	include/rtl8192e_cmd.h	152;"	d
-GET_8192E_C2H_TX_RPT_QUEUE_TIME	include/rtl8192e_cmd.h	158;"	d
-GET_8192E_C2H_TX_RPT_RETRY_OVER	include/rtl8192e_cmd.h	155;"	d
-GET_8192E_H2CCMD_PWRMODE_PARM_MODE	include/rtl8192e_cmd.h	110;"	d
-GET_8703B_H2CCMD_PWRMODE_PARM_MODE	include/rtl8703b_cmd.h	123;"	d
-GET_8723B_H2CCMD_PWRMODE_PARM_MODE	include/rtl8723b_cmd.h	123;"	d
-GET_8723D_C2H_TX_RPT_LIFE_TIME_OVER	hal/rtl8723d/rtl8723d_hal_init.c	5143;"	d	file:
-GET_8723D_C2H_TX_RPT_RETRY_OVER	hal/rtl8723d/rtl8723d_hal_init.c	5144;"	d	file:
-GET_8723D_H2CCMD_PWRMODE_PARM_MODE	include/rtl8723d_cmd.h	122;"	d
-GET_8812_C2H_TXBF_MACID	include/rtl8812a_cmd.h	147;"	d
-GET_8812_C2H_TXBF_ORIGINATE	include/rtl8812a_cmd.h	146;"	d
-GET_8812_C2H_TX_RPT_DATA_RETRY_CNT	include/rtl8812a_cmd.h	159;"	d
-GET_8812_C2H_TX_RPT_FINAL_DATA_RATE	include/rtl8812a_cmd.h	161;"	d
-GET_8812_C2H_TX_RPT_LIFE_TIME_OVER	include/rtl8812a_cmd.h	156;"	d
-GET_8812_C2H_TX_RPT_MAC_ID	include/rtl8812a_cmd.h	158;"	d
-GET_8812_C2H_TX_RPT_PKT_BROCAST	include/rtl8812a_cmd.h	155;"	d
-GET_8812_C2H_TX_RPT_QUEUE_SELECT	include/rtl8812a_cmd.h	154;"	d
-GET_8812_C2H_TX_RPT_QUEUE_TIME	include/rtl8812a_cmd.h	160;"	d
-GET_8812_C2H_TX_RPT_RETRY_OVER	include/rtl8812a_cmd.h	157;"	d
-GET_8812_H2CCMD_PWRMODE_PARM_MODE	include/rtl8812a_cmd.h	94;"	d
-GET_8814A_C2H_TXBF_MACID	include/rtl8814a_cmd.h	93;"	d
-GET_8814A_C2H_TXBF_ORIGINATE	include/rtl8814a_cmd.h	92;"	d
-GET_8814A_C2H_TX_RPT_DATA_RETRY_CNT	include/rtl8814a_cmd.h	105;"	d
-GET_8814A_C2H_TX_RPT_FINAL_DATA_RATE	include/rtl8814a_cmd.h	107;"	d
-GET_8814A_C2H_TX_RPT_LIFE_TIME_OVER	include/rtl8814a_cmd.h	102;"	d
-GET_8814A_C2H_TX_RPT_MAC_ID	include/rtl8814a_cmd.h	104;"	d
-GET_8814A_C2H_TX_RPT_PKT_BROCAST	include/rtl8814a_cmd.h	101;"	d
-GET_8814A_C2H_TX_RPT_QUEUE_SELECT	include/rtl8814a_cmd.h	100;"	d
-GET_8814A_C2H_TX_RPT_QUEUE_TIME	include/rtl8814a_cmd.h	106;"	d
-GET_8814A_C2H_TX_RPT_RETRY_OVER	include/rtl8814a_cmd.h	103;"	d
-GET_8814A_H2CCMD_PWRMODE_PARM_MODE	include/rtl8814a_cmd.h	41;"	d
-GET_ACS_STATE	include/hal_data.h	761;"	d
-GET_ADAPTER	include/drv_types.h	473;"	d
-GET_ARP_PKT_LLC_TYPE	include/hal_com_h2c.h	166;"	d
-GET_ARP_PKT_OPERATION	include/hal_com_h2c.h	169;"	d
-GET_ARP_PKT_SENDER_IP_ADDR	include/hal_com_h2c.h	171;"	d
-GET_ARP_PKT_SENDER_MAC_ADDR	include/hal_com_h2c.h	170;"	d
-GET_ARP_PKT_TARGET_IP_ADDR	include/hal_com_h2c.h	173;"	d
-GET_ARP_PKT_TARGET_MAC_ADDR	include/hal_com_h2c.h	172;"	d
-GET_BEAMFORM_INFO	include/rtw_beamforming.h	37;"	d
-GET_BEAMFORM_INFO	include/rtw_beamforming.h	40;"	d
-GET_C2H_MAC_HIDDEN_RPT_80211_PROTOCOL	hal/hal_com.c	1330;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_ANT_NUM	hal/hal_com.c	1329;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_BW	hal/hal_com.c	1327;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_FAB	hal/hal_com.c	1328;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_HCI_TYPE	hal/hal_com.c	1322;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_HW_STYPE	hal/hal_com.c	1326;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_NIC_ROUTER	hal/hal_com.c	1331;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_PACKAGE_TYPE	hal/hal_com.c	1323;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_TR_SWITCH	hal/hal_com.c	1324;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_UUID_CRC	hal/hal_com.c	1321;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_UUID_X	hal/hal_com.c	1318;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_UUID_Y	hal/hal_com.c	1319;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_UUID_Z	hal/hal_com.c	1320;"	d	file:
-GET_C2H_MAC_HIDDEN_RPT_WL_FUNC	hal/hal_com.c	1325;"	d	file:
-GET_CFG80211_REPORT_MGMT	os_dep/linux/ioctl_cfg80211.h	197;"	d
-GET_CVID_CHIP_TYPE	include/HalVerDef.h	100;"	d
-GET_CVID_CUT_VERSION	include/HalVerDef.h	103;"	d
-GET_CVID_IC_TYPE	include/HalVerDef.h	99;"	d
-GET_CVID_MANUFACTUER	include/HalVerDef.h	102;"	d
-GET_CVID_RF_TYPE	include/HalVerDef.h	101;"	d
-GET_CVID_ROM_VERSION	include/HalVerDef.h	104;"	d
-GET_ENCRY_ALGO	include/rtw_security.h	254;"	d
-GET_EXT_CAPABILITY_ELE_BSS_COEXIST	include/rtw_ht.h	107;"	d
-GET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF	include/rtw_vht.h	108;"	d
-GET_FIRMWARE_HDR_BOOT_LOADER_SZ_3081	include/rtl8814a_hal.h	103;"	d
-GET_FIRMWARE_HDR_CATEGORY_3081	include/rtl8814a_hal.h	76;"	d
-GET_FIRMWARE_HDR_CATEGORY_8192E	include/rtl8192e_hal.h	88;"	d
-GET_FIRMWARE_HDR_CATEGORY_8812	include/rtl8812a_hal.h	98;"	d
-GET_FIRMWARE_HDR_DATE_3081	include/rtl8814a_hal.h	88;"	d
-GET_FIRMWARE_HDR_DATE_8192E	include/rtl8192e_hal.h	96;"	d
-GET_FIRMWARE_HDR_DATE_8812	include/rtl8812a_hal.h	106;"	d
-GET_FIRMWARE_HDR_ERAM_SZ_3081	include/rtl8814a_hal.h	117;"	d
-GET_FIRMWARE_HDR_EROM_3081	include/rtl8814a_hal.h	113;"	d
-GET_FIRMWARE_HDR_FOUNDRY_3081	include/rtl8814a_hal.h	92;"	d
-GET_FIRMWARE_HDR_FUNCTION_3081	include/rtl8814a_hal.h	77;"	d
-GET_FIRMWARE_HDR_FUNCTION_8192E	include/rtl8192e_hal.h	89;"	d
-GET_FIRMWARE_HDR_FUNCTION_8812	include/rtl8812a_hal.h	99;"	d
-GET_FIRMWARE_HDR_FW_ATTR_SZ_3081	include/rtl8814a_hal.h	109;"	d
-GET_FIRMWARE_HDR_FW_CFG_SZ_3081	include/rtl8814a_hal.h	108;"	d
-GET_FIRMWARE_HDR_HOUR_3081	include/rtl8814a_hal.h	89;"	d
-GET_FIRMWARE_HDR_HOUR_8192E	include/rtl8192e_hal.h	97;"	d
-GET_FIRMWARE_HDR_HOUR_8812	include/rtl8812a_hal.h	107;"	d
-GET_FIRMWARE_HDR_IRAM_SZ_3081	include/rtl8814a_hal.h	116;"	d
-GET_FIRMWARE_HDR_IROM_3081	include/rtl8814a_hal.h	112;"	d
-GET_FIRMWARE_HDR_MEM_UASGE_BOOT_FROM_3081	include/rtl8814a_hal.h	97;"	d
-GET_FIRMWARE_HDR_MEM_UASGE_BOOT_LOADER_3081	include/rtl8814a_hal.h	98;"	d
-GET_FIRMWARE_HDR_MEM_UASGE_DL_FROM_3081	include/rtl8814a_hal.h	96;"	d
-GET_FIRMWARE_HDR_MEM_UASGE_ERAM_3081	include/rtl8814a_hal.h	100;"	d
-GET_FIRMWARE_HDR_MEM_UASGE_IRAM_3081	include/rtl8814a_hal.h	99;"	d
-GET_FIRMWARE_HDR_MEM_UASGE_RSVD4_3081	include/rtl8814a_hal.h	101;"	d
-GET_FIRMWARE_HDR_MINUTE_3081	include/rtl8814a_hal.h	90;"	d
-GET_FIRMWARE_HDR_MINUTE_8192E	include/rtl8192e_hal.h	98;"	d
-GET_FIRMWARE_HDR_MINUTE_8812	include/rtl8812a_hal.h	108;"	d
-GET_FIRMWARE_HDR_MONTH_3081	include/rtl8814a_hal.h	87;"	d
-GET_FIRMWARE_HDR_MONTH_8192E	include/rtl8192e_hal.h	95;"	d
-GET_FIRMWARE_HDR_MONTH_8812	include/rtl8812a_hal.h	105;"	d
-GET_FIRMWARE_HDR_ROMCODE_SIZE_8192E	include/rtl8192e_hal.h	99;"	d
-GET_FIRMWARE_HDR_ROMCODE_SIZE_8812	include/rtl8812a_hal.h	109;"	d
-GET_FIRMWARE_HDR_RSVD1_3081	include/rtl8814a_hal.h	84;"	d
-GET_FIRMWARE_HDR_RSVD1_8192E	include/rtl8192e_hal.h	92;"	d
-GET_FIRMWARE_HDR_RSVD1_8812	include/rtl8812a_hal.h	102;"	d
-GET_FIRMWARE_HDR_RSVD2_3081	include/rtl8814a_hal.h	93;"	d
-GET_FIRMWARE_HDR_RSVD2_8192E	include/rtl8192e_hal.h	100;"	d
-GET_FIRMWARE_HDR_RSVD2_8812	include/rtl8812a_hal.h	110;"	d
-GET_FIRMWARE_HDR_RSVD3_3081	include/rtl8814a_hal.h	102;"	d
-GET_FIRMWARE_HDR_RSVD3_8192E	include/rtl8192e_hal.h	104;"	d
-GET_FIRMWARE_HDR_RSVD3_8812	include/rtl8812a_hal.h	114;"	d
-GET_FIRMWARE_HDR_RSVD4_8192E	include/rtl8192e_hal.h	107;"	d
-GET_FIRMWARE_HDR_RSVD4_8812	include/rtl8812a_hal.h	117;"	d
-GET_FIRMWARE_HDR_RSVD5_3081	include/rtl8814a_hal.h	104;"	d
-GET_FIRMWARE_HDR_RSVD5_8192E	include/rtl8192e_hal.h	108;"	d
-GET_FIRMWARE_HDR_RSVD5_8812	include/rtl8812a_hal.h	118;"	d
-GET_FIRMWARE_HDR_RSVD6_3081	include/rtl8814a_hal.h	120;"	d
-GET_FIRMWARE_HDR_RSVD7_3081	include/rtl8814a_hal.h	121;"	d
-GET_FIRMWARE_HDR_SIGNATURE_3081	include/rtl8814a_hal.h	75;"	d
-GET_FIRMWARE_HDR_SIGNATURE_8192E	include/rtl8192e_hal.h	87;"	d
-GET_FIRMWARE_HDR_SIGNATURE_8812	include/rtl8812a_hal.h	97;"	d
-GET_FIRMWARE_HDR_SUB_IDX_3081	include/rtl8814a_hal.h	80;"	d
-GET_FIRMWARE_HDR_SUB_VER_3081	include/rtl8814a_hal.h	79;"	d
-GET_FIRMWARE_HDR_SUB_VER_8192E	include/rtl8192e_hal.h	91;"	d
-GET_FIRMWARE_HDR_SUB_VER_8812	include/rtl8812a_hal.h	101;"	d
-GET_FIRMWARE_HDR_SVN_IDX_3081	include/rtl8814a_hal.h	83;"	d
-GET_FIRMWARE_HDR_SVN_IDX_8192E	include/rtl8192e_hal.h	103;"	d
-GET_FIRMWARE_HDR_SVN_IDX_8812	include/rtl8812a_hal.h	113;"	d
-GET_FIRMWARE_HDR_TOTAL_DMEM_SZ_3081	include/rtl8814a_hal.h	107;"	d
-GET_FIRMWARE_HDR_VERSION_3081	include/rtl8814a_hal.h	78;"	d
-GET_FIRMWARE_HDR_VERSION_8192E	include/rtl8192e_hal.h	90;"	d
-GET_FIRMWARE_HDR_VERSION_8812	include/rtl8812a_hal.h	100;"	d
-GET_FIRMWARE_HDR_YEAR_3081	include/rtl8814a_hal.h	91;"	d
-GET_H2CCMD_MSRRPT_PARM_MIRACAST	include/hal_com_h2c.h	228;"	d
-GET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK	include/hal_com_h2c.h	229;"	d
-GET_H2CCMD_MSRRPT_PARM_OPMODE	include/hal_com_h2c.h	227;"	d
-GET_H2CCMD_MSRRPT_PARM_ROLE	include/hal_com_h2c.h	230;"	d
-GET_HAL_DATA	include/hal_data.h	741;"	d
-GET_HAL_RFPATH_NUM	include/hal_data.h	745;"	d
-GET_HAL_SPEC	include/hal_data.h	742;"	d
-GET_HDR_OFFSET_2_0	include/rtw_efuse.h	69;"	d
-GET_HT_CAP_ELE_CHL_WIDTH	include/rtw_ht.h	112;"	d
-GET_HT_CAP_ELE_DELAYED_BA	include/rtw_ht.h	119;"	d
-GET_HT_CAP_ELE_DSSS_CCK_40M	include/rtw_ht.h	121;"	d
-GET_HT_CAP_ELE_FORTY_INTOLERANT	include/rtw_ht.h	122;"	d
-GET_HT_CAP_ELE_GREENFIELD	include/rtw_ht.h	114;"	d
-GET_HT_CAP_ELE_LDPC_CAP	include/rtw_ht.h	111;"	d
-GET_HT_CAP_ELE_LSIG_TXOP_PROTECT	include/rtw_ht.h	123;"	d
-GET_HT_CAP_ELE_MAX_AMPDU_LEN_EXP	include/rtw_ht.h	141;"	d
-GET_HT_CAP_ELE_MAX_AMSDU_LENGTH	include/rtw_ht.h	120;"	d
-GET_HT_CAP_ELE_MIN_MPDU_S_SPACE	include/rtw_ht.h	142;"	d
-GET_HT_CAP_ELE_RX_HIGHEST_DATA_RATE	include/rtw_ht.h	155;"	d
-GET_HT_CAP_ELE_RX_STBC	include/rtw_ht.h	118;"	d
-GET_HT_CAP_ELE_SHORT_GI20M	include/rtw_ht.h	115;"	d
-GET_HT_CAP_ELE_SHORT_GI40M	include/rtw_ht.h	116;"	d
-GET_HT_CAP_ELE_SM_PS	include/rtw_ht.h	113;"	d
-GET_HT_CAP_ELE_TRX_MCS_NEQ	include/rtw_ht.h	157;"	d
-GET_HT_CAP_ELE_TX_MAX_SS	include/rtw_ht.h	158;"	d
-GET_HT_CAP_ELE_TX_MCS_DEF	include/rtw_ht.h	156;"	d
-GET_HT_CAP_ELE_TX_STBC	include/rtw_ht.h	117;"	d
-GET_HT_CAP_ELE_TX_UEQM	include/rtw_ht.h	159;"	d
-GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS	include/rtw_ht.h	184;"	d
-GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS	include/rtw_ht.h	183;"	d
-GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP	include/rtw_ht.h	182;"	d
-GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP	include/rtw_ht.h	181;"	d
-GET_HT_CTRL_NDP_ANNOUNCEMENT	include/rtw_ht.h	103;"	d
-GET_HT_OP_ELE_2ND_CHL_OFFSET	include/rtw_ht.h	193;"	d
-GET_HT_OP_ELE_DUAL_BEACON	include/rtw_ht.h	199;"	d
-GET_HT_OP_ELE_DUAL_CTS	include/rtw_ht.h	200;"	d
-GET_HT_OP_ELE_HT_PROTECT	include/rtw_ht.h	196;"	d
-GET_HT_OP_ELE_LSIG_TXOP_PROTECT	include/rtw_ht.h	202;"	d
-GET_HT_OP_ELE_NON_GREEN_PRESENT	include/rtw_ht.h	197;"	d
-GET_HT_OP_ELE_OBSS_NON_HT_PRESENT	include/rtw_ht.h	198;"	d
-GET_HT_OP_ELE_PCO_ACTIVE	include/rtw_ht.h	203;"	d
-GET_HT_OP_ELE_PCO_PHASE	include/rtw_ht.h	204;"	d
-GET_HT_OP_ELE_PRI_CHL	include/rtw_ht.h	188;"	d
-GET_HT_OP_ELE_RIFS_MODE	include/rtw_ht.h	195;"	d
-GET_HT_OP_ELE_STA_CHL_WIDTH	include/rtw_ht.h	194;"	d
-GET_HT_OP_ELE_STBC_BEACON	include/rtw_ht.h	201;"	d
-GET_IFACE_NUMS	include/drv_types.h	472;"	d
-GET_INDIRECT_REG_RDY	include/rtl8188f_spec.h	165;"	d
-GET_IPV4_DST	include/rtw_mlme.h	1186;"	d
-GET_IPV4_IHL	include/rtw_mlme.h	1183;"	d
-GET_IPV4_PROTOCOL	include/rtw_mlme.h	1184;"	d
-GET_IPV4_SRC	include/rtw_mlme.h	1185;"	d
-GET_KFREE_DATA	include/hal_data.h	748;"	d
-GET_MASK_ARRAY	include/rtw_efuse.h	83;"	d
-GET_MASK_ARRAY_LEN	include/rtw_efuse.h	82;"	d
-GET_MASK_ARRAY_LEN_MP	include/rtw_efuse.h	75;"	d
-GET_MASK_ARRAY_LEN_TC	include/rtw_efuse.h	76;"	d
-GET_MASK_ARRAY_MP	include/rtw_efuse.h	77;"	d
-GET_MASK_ARRAY_TC	include/rtw_efuse.h	78;"	d
-GET_MY_HWADDR	include/rtw_br_ext.h	32;"	d
-GET_ODM	include/hal_data.h	743;"	d
-GET_OP_CODE_FROM_BT_MP_OPER_RET	include/rtw_btcoex.h	64;"	d
-GET_PDM_ODM	hal/phydm/phydm_types.h	36;"	d
-GET_PDM_ODM	hal/phydm/phydm_types.h	38;"	d
-GET_PG_KFREE_ON_8188F	include/hal_pg.h	299;"	d
-GET_PG_KFREE_ON_8192E	include/hal_pg.h	71;"	d
-GET_PG_KFREE_ON_8703B	include/hal_pg.h	388;"	d
-GET_PG_KFREE_ON_8723D	include/hal_pg.h	530;"	d
-GET_PG_KFREE_ON_8814A	include/hal_pg.h	178;"	d
-GET_PG_KFREE_ON_8821A	include/hal_pg.h	225;"	d
-GET_PG_KFREE_ON_8821C	include/hal_pg.h	482;"	d
-GET_PG_KFREE_ON_8822B	include/hal_pg.h	432;"	d
-GET_PG_KFREE_THERMAL_K_ON_8188F	include/hal_pg.h	300;"	d
-GET_PG_KFREE_THERMAL_K_ON_8192E	include/hal_pg.h	72;"	d
-GET_PG_KFREE_THERMAL_K_ON_8703B	include/hal_pg.h	389;"	d
-GET_PG_KFREE_THERMAL_K_ON_8723D	include/hal_pg.h	532;"	d
-GET_PG_KFREE_THERMAL_K_ON_8814A	include/hal_pg.h	179;"	d
-GET_PG_KFREE_THERMAL_K_ON_8821A	include/hal_pg.h	226;"	d
-GET_PG_KFREE_THERMAL_K_ON_8821C	include/hal_pg.h	483;"	d
-GET_PG_KFREE_THERMAL_K_ON_8822B	include/hal_pg.h	433;"	d
-GET_PG_TX_POWER_TRACKING_MODE_8814A	include/hal_pg.h	180;"	d
-GET_PRIMARY_ADAPTER	include/drv_types.h	471;"	d
-GET_PWR_CFG_BASE	include/HalPwrSeqCmd.h	119;"	d
-GET_PWR_CFG_CMD	include/HalPwrSeqCmd.h	120;"	d
-GET_PWR_CFG_CUT_MASK	include/HalPwrSeqCmd.h	116;"	d
-GET_PWR_CFG_FAB_MASK	include/HalPwrSeqCmd.h	117;"	d
-GET_PWR_CFG_INTF_MASK	include/HalPwrSeqCmd.h	118;"	d
-GET_PWR_CFG_MASK	include/HalPwrSeqCmd.h	121;"	d
-GET_PWR_CFG_OFFSET	include/HalPwrSeqCmd.h	115;"	d
-GET_PWR_CFG_VALUE	include/HalPwrSeqCmd.h	122;"	d
-GET_RF6052_REAL_MAX_REG	include/hal_phy.h	43;"	d
-GET_RF_TYPE	include/hal_data.h	747;"	d
-GET_RX_BUFFER_DESC_FS_8723D	include/rtl8723d_recv.h	84;"	d
-GET_RX_BUFFER_DESC_FS_8814A	include/rtl8814a_recv.h	75;"	d
-GET_RX_BUFFER_DESC_FS_92E	include/rtl8192e_recv.h	75;"	d
-GET_RX_BUFFER_DESC_LS_8723D	include/rtl8723d_recv.h	83;"	d
-GET_RX_BUFFER_DESC_LS_8814A	include/rtl8814a_recv.h	74;"	d
-GET_RX_BUFFER_DESC_LS_92E	include/rtl8192e_recv.h	74;"	d
-GET_RX_BUFFER_DESC_OWN_8723D	include/rtl8723d_recv.h	82;"	d
-GET_RX_BUFFER_DESC_OWN_8814A	include/rtl8814a_recv.h	73;"	d
-GET_RX_BUFFER_DESC_OWN_92E	include/rtl8192e_recv.h	73;"	d
-GET_RX_BUFFER_DESC_RX_TAG_8723D	include/rtl8723d_recv.h	86;"	d
-GET_RX_BUFFER_DESC_TOTAL_LENGTH_8723D	include/rtl8723d_recv.h	88;"	d
-GET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A	include/rtl8814a_recv.h	76;"	d
-GET_RX_BUFFER_DESC_TOTAL_LENGTH_92E	include/rtl8192e_recv.h	76;"	d
-GET_RX_BUFFER_PHYSICAL_LOW_8814A	include/rtl8814a_recv.h	80;"	d
-GET_RX_BUFFER_PHYSICAL_LOW_92E	include/rtl8192e_recv.h	81;"	d
-GET_RX_PAGE_SIZE	include/hal_com_reg.h	1336;"	d
-GET_RX_STATUS_C2H_8814A	include/rtl8814a_recv.h	142;"	d
-GET_RX_STATUS_DESC_A1_FITS_92E	include/rtl8192e_recv.h	113;"	d
-GET_RX_STATUS_DESC_A1_FIT_8188F	include/rtl8188f_xmit.h	59;"	d
-GET_RX_STATUS_DESC_A1_FIT_8703B	include/rtl8703b_xmit.h	59;"	d
-GET_RX_STATUS_DESC_A1_FIT_8723B	include/rtl8723b_xmit.h	59;"	d
-GET_RX_STATUS_DESC_A1_FIT_8723D	include/rtl8723d_xmit.h	76;"	d
-GET_RX_STATUS_DESC_A1_FIT_8812	include/rtl8812a_recv.h	93;"	d
-GET_RX_STATUS_DESC_A1_FIT_8814A	include/rtl8814a_recv.h	161;"	d
-GET_RX_STATUS_DESC_AMSDU_8188F	include/rtl8188f_xmit.h	56;"	d
-GET_RX_STATUS_DESC_AMSDU_8703B	include/rtl8703b_xmit.h	56;"	d
-GET_RX_STATUS_DESC_AMSDU_8723B	include/rtl8723b_xmit.h	56;"	d
-GET_RX_STATUS_DESC_AMSDU_8723D	include/rtl8723d_xmit.h	70;"	d
-GET_RX_STATUS_DESC_AMSDU_8812	include/rtl8812a_recv.h	90;"	d
-GET_RX_STATUS_DESC_AMSDU_8814A	include/rtl8814a_recv.h	115;"	d
-GET_RX_STATUS_DESC_AMSDU_92E	include/rtl8192e_recv.h	110;"	d
-GET_RX_STATUS_DESC_BC_8188F	include/rtl8188f_xmit.h	70;"	d
-GET_RX_STATUS_DESC_BC_8703B	include/rtl8703b_xmit.h	70;"	d
-GET_RX_STATUS_DESC_BC_8723B	include/rtl8723b_xmit.h	70;"	d
-GET_RX_STATUS_DESC_BC_8723D	include/rtl8723d_xmit.h	98;"	d
-GET_RX_STATUS_DESC_BC_8812	include/rtl8812a_recv.h	104;"	d
-GET_RX_STATUS_DESC_BC_8814A	include/rtl8814a_recv.h	130;"	d
-GET_RX_STATUS_DESC_BC_92E	include/rtl8192e_recv.h	124;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_8188F	include/rtl8188f_xmit.h	83;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_8703B	include/rtl8703b_xmit.h	83;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_8723B	include/rtl8723b_xmit.h	83;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_8723D	include/rtl8723d_xmit.h	122;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_8812	include/rtl8812a_recv.h	117;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_92E	include/rtl8192e_recv.h	140;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_H_8814A	include/rtl8814a_recv.h	147;"	d
-GET_RX_STATUS_DESC_BSSID_FIT_L_8814A	include/rtl8814a_recv.h	150;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR64_8188F	include/rtl8188f_xmit.h	101;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR64_8703B	include/rtl8703b_xmit.h	101;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR64_8723B	include/rtl8723b_xmit.h	101;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR64_8723D	include/rtl8723d_xmit.h	145;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR64_8812	include/rtl8812a_recv.h	135;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR64_92E	include/rtl8192e_recv.h	152;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR_8188F	include/rtl8188f_xmit.h	100;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR_8703B	include/rtl8703b_xmit.h	100;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR_8723B	include/rtl8723b_xmit.h	100;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR_8723D	include/rtl8723d_xmit.h	143;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR_8812	include/rtl8812a_recv.h	134;"	d
-GET_RX_STATUS_DESC_BUFF_ADDR_92E	include/rtl8192e_recv.h	151;"	d
-GET_RX_STATUS_DESC_BW_8188F	include/rtl8188f_xmit.h	95;"	d
-GET_RX_STATUS_DESC_BW_8703B	include/rtl8703b_xmit.h	95;"	d
-GET_RX_STATUS_DESC_BW_8723B	include/rtl8723b_xmit.h	95;"	d
-GET_RX_STATUS_DESC_BW_8812	include/rtl8812a_recv.h	129;"	d
-GET_RX_STATUS_DESC_CHKERR_8188F	include/rtl8188f_xmit.h	60;"	d
-GET_RX_STATUS_DESC_CHKERR_8703B	include/rtl8703b_xmit.h	60;"	d
-GET_RX_STATUS_DESC_CHKERR_8723B	include/rtl8723b_xmit.h	60;"	d
-GET_RX_STATUS_DESC_CHKERR_8723D	include/rtl8723d_xmit.h	78;"	d
-GET_RX_STATUS_DESC_CHKERR_8812	include/rtl8812a_recv.h	94;"	d
-GET_RX_STATUS_DESC_CHK_VLD_8188F	include/rtl8188f_xmit.h	63;"	d
-GET_RX_STATUS_DESC_CHK_VLD_8703B	include/rtl8703b_xmit.h	63;"	d
-GET_RX_STATUS_DESC_CHK_VLD_8723B	include/rtl8723b_xmit.h	63;"	d
-GET_RX_STATUS_DESC_CHK_VLD_8723D	include/rtl8723d_xmit.h	84;"	d
-GET_RX_STATUS_DESC_CHK_VLD_8812	include/rtl8812a_recv.h	97;"	d
-GET_RX_STATUS_DESC_CRC32_8188F	include/rtl8188f_xmit.h	40;"	d
-GET_RX_STATUS_DESC_CRC32_8703B	include/rtl8703b_xmit.h	40;"	d
-GET_RX_STATUS_DESC_CRC32_8723B	include/rtl8723b_xmit.h	40;"	d
-GET_RX_STATUS_DESC_CRC32_8723D	include/rtl8723d_xmit.h	44;"	d
-GET_RX_STATUS_DESC_CRC32_8812	include/rtl8812a_recv.h	74;"	d
-GET_RX_STATUS_DESC_CRC32_8814A	include/rtl8814a_recv.h	99;"	d
-GET_RX_STATUS_DESC_CRC32_92E	include/rtl8192e_recv.h	90;"	d
-GET_RX_STATUS_DESC_DMA_AGG_NUM_8814A	include/rtl8814a_recv.h	151;"	d
-GET_RX_STATUS_DESC_DMA_AGG_NUM_92E	include/rtl8192e_recv.h	141;"	d
-GET_RX_STATUS_DESC_DRVINFO_SIZE_8188F	include/rtl8188f_xmit.h	42;"	d
-GET_RX_STATUS_DESC_DRVINFO_SIZE_8703B	include/rtl8703b_xmit.h	42;"	d
-GET_RX_STATUS_DESC_DRVINFO_SIZE_8723B	include/rtl8723b_xmit.h	42;"	d
-GET_RX_STATUS_DESC_DRVINFO_SIZE_8723D	include/rtl8723d_xmit.h	48;"	d
-GET_RX_STATUS_DESC_DRVINFO_SIZE_8812	include/rtl8812a_recv.h	76;"	d
-GET_RX_STATUS_DESC_DRVINFO_SIZE_8814A	include/rtl8814a_recv.h	101;"	d
-GET_RX_STATUS_DESC_DRVINFO_SIZE_92E	include/rtl8192e_recv.h	92;"	d
-GET_RX_STATUS_DESC_EOR_8188F	include/rtl8188f_xmit.h	50;"	d
-GET_RX_STATUS_DESC_EOR_8703B	include/rtl8703b_xmit.h	50;"	d
-GET_RX_STATUS_DESC_EOR_8723B	include/rtl8723b_xmit.h	50;"	d
-GET_RX_STATUS_DESC_EOR_8723D	include/rtl8723d_xmit.h	60;"	d
-GET_RX_STATUS_DESC_EOR_8812	include/rtl8812a_recv.h	84;"	d
-GET_RX_STATUS_DESC_EOR_8814A	include/rtl8814a_recv.h	108;"	d
-GET_RX_STATUS_DESC_EOR_8814AE	include/rtl8814a_recv.h	128;"	d
-GET_RX_STATUS_DESC_EOR_92E	include/rtl8192e_recv.h	98;"	d
-GET_RX_STATUS_DESC_EOSP_8188F	include/rtl8188f_xmit.h	82;"	d
-GET_RX_STATUS_DESC_EOSP_8703B	include/rtl8703b_xmit.h	82;"	d
-GET_RX_STATUS_DESC_EOSP_8723B	include/rtl8723b_xmit.h	82;"	d
-GET_RX_STATUS_DESC_EOSP_8723D	include/rtl8723d_xmit.h	120;"	d
-GET_RX_STATUS_DESC_EOSP_8812	include/rtl8812a_recv.h	116;"	d
-GET_RX_STATUS_DESC_EOSP_8814A	include/rtl8814a_recv.h	149;"	d
-GET_RX_STATUS_DESC_EOSP_92E	include/rtl8192e_recv.h	139;"	d
-GET_RX_STATUS_DESC_EXT_SECTYPE_8814A	include/rtl8814a_recv.h	112;"	d
-GET_RX_STATUS_DESC_FCS_OK_8723D	include/rtl8723d_xmit.h	112;"	d
-GET_RX_STATUS_DESC_FCS_OK_8814A	include/rtl8814a_recv.h	143;"	d
-GET_RX_STATUS_DESC_FCS_OK_92E	include/rtl8192e_recv.h	133;"	d
-GET_RX_STATUS_DESC_FIRST_SEG_8188F	include/rtl8188f_xmit.h	49;"	d
-GET_RX_STATUS_DESC_FIRST_SEG_8703B	include/rtl8703b_xmit.h	49;"	d
-GET_RX_STATUS_DESC_FIRST_SEG_8723B	include/rtl8723b_xmit.h	49;"	d
-GET_RX_STATUS_DESC_FIRST_SEG_8812	include/rtl8812a_recv.h	83;"	d
-GET_RX_STATUS_DESC_FIRST_SEG_8814AE	include/rtl8814a_recv.h	127;"	d
-GET_RX_STATUS_DESC_FRAG_8188F	include/rtl8188f_xmit.h	74;"	d
-GET_RX_STATUS_DESC_FRAG_8703B	include/rtl8703b_xmit.h	74;"	d
-GET_RX_STATUS_DESC_FRAG_8723B	include/rtl8723b_xmit.h	74;"	d
-GET_RX_STATUS_DESC_FRAG_8723D	include/rtl8723d_xmit.h	104;"	d
-GET_RX_STATUS_DESC_FRAG_8812	include/rtl8812a_recv.h	108;"	d
-GET_RX_STATUS_DESC_FRAG_8814A	include/rtl8814a_recv.h	134;"	d
-GET_RX_STATUS_DESC_FRAG_92E	include/rtl8192e_recv.h	128;"	d
-GET_RX_STATUS_DESC_HTC_8188F	include/rtl8188f_xmit.h	81;"	d
-GET_RX_STATUS_DESC_HTC_8703B	include/rtl8703b_xmit.h	81;"	d
-GET_RX_STATUS_DESC_HTC_8723B	include/rtl8723b_xmit.h	81;"	d
-GET_RX_STATUS_DESC_HTC_8723D	include/rtl8723d_xmit.h	118;"	d
-GET_RX_STATUS_DESC_HTC_8812	include/rtl8812a_recv.h	115;"	d
-GET_RX_STATUS_DESC_HTC_8814A	include/rtl8814a_recv.h	148;"	d
-GET_RX_STATUS_DESC_HTC_92E	include/rtl8192e_recv.h	138;"	d
-GET_RX_STATUS_DESC_HWRSVD_8814A	include/rtl8814a_recv.h	141;"	d
-GET_RX_STATUS_DESC_HWRSVD_92E	include/rtl8192e_recv.h	132;"	d
-GET_RX_STATUS_DESC_ICVERR_92E	include/rtl8192e_recv.h	91;"	d
-GET_RX_STATUS_DESC_ICV_8188F	include/rtl8188f_xmit.h	41;"	d
-GET_RX_STATUS_DESC_ICV_8703B	include/rtl8703b_xmit.h	41;"	d
-GET_RX_STATUS_DESC_ICV_8723B	include/rtl8723b_xmit.h	41;"	d
-GET_RX_STATUS_DESC_ICV_8723D	include/rtl8723d_xmit.h	46;"	d
-GET_RX_STATUS_DESC_ICV_8812	include/rtl8812a_recv.h	75;"	d
-GET_RX_STATUS_DESC_ICV_8814A	include/rtl8814a_recv.h	100;"	d
-GET_RX_STATUS_DESC_IPVER_8188F	include/rtl8188f_xmit.h	61;"	d
-GET_RX_STATUS_DESC_IPVER_8703B	include/rtl8703b_xmit.h	61;"	d
-GET_RX_STATUS_DESC_IPVER_8723B	include/rtl8723b_xmit.h	61;"	d
-GET_RX_STATUS_DESC_IPVER_8723D	include/rtl8723d_xmit.h	80;"	d
-GET_RX_STATUS_DESC_IPVER_8812	include/rtl8812a_recv.h	95;"	d
-GET_RX_STATUS_DESC_IS_TCPUDP__8188F	include/rtl8188f_xmit.h	62;"	d
-GET_RX_STATUS_DESC_IS_TCPUDP__8703B	include/rtl8703b_xmit.h	62;"	d
-GET_RX_STATUS_DESC_IS_TCPUDP__8723B	include/rtl8723b_xmit.h	62;"	d
-GET_RX_STATUS_DESC_IS_TCPUDP__8723D	include/rtl8723d_xmit.h	82;"	d
-GET_RX_STATUS_DESC_IS_TCPUDP__8812	include/rtl8812a_recv.h	96;"	d
-GET_RX_STATUS_DESC_LAST_SEG_8188F	include/rtl8188f_xmit.h	48;"	d
-GET_RX_STATUS_DESC_LAST_SEG_8703B	include/rtl8703b_xmit.h	48;"	d
-GET_RX_STATUS_DESC_LAST_SEG_8723B	include/rtl8723b_xmit.h	48;"	d
-GET_RX_STATUS_DESC_LAST_SEG_8812	include/rtl8812a_recv.h	82;"	d
-GET_RX_STATUS_DESC_LAST_SEG_8814AE	include/rtl8814a_recv.h	107;"	d
-GET_RX_STATUS_DESC_LDPC_8188F	include/rtl8188f_xmit.h	93;"	d
-GET_RX_STATUS_DESC_LDPC_8703B	include/rtl8703b_xmit.h	93;"	d
-GET_RX_STATUS_DESC_LDPC_8723B	include/rtl8723b_xmit.h	93;"	d
-GET_RX_STATUS_DESC_LDPC_8812	include/rtl8812a_recv.h	127;"	d
-GET_RX_STATUS_DESC_MACID_8188F	include/rtl8188f_xmit.h	54;"	d
-GET_RX_STATUS_DESC_MACID_8703B	include/rtl8703b_xmit.h	54;"	d
-GET_RX_STATUS_DESC_MACID_8723B	include/rtl8723b_xmit.h	54;"	d
-GET_RX_STATUS_DESC_MACID_8723D	include/rtl8723d_xmit.h	66;"	d
-GET_RX_STATUS_DESC_MACID_8812	include/rtl8812a_recv.h	88;"	d
-GET_RX_STATUS_DESC_MACID_8814A	include/rtl8814a_recv.h	111;"	d
-GET_RX_STATUS_DESC_MACID_92E	include/rtl8192e_recv.h	107;"	d
-GET_RX_STATUS_DESC_MACID_VLD_8814A	include/rtl8814a_recv.h	114;"	d
-GET_RX_STATUS_DESC_MACID_VLD_92E	include/rtl8192e_recv.h	109;"	d
-GET_RX_STATUS_DESC_MAGIC_MATCH_8188F	include/rtl8188f_xmit.h	89;"	d
-GET_RX_STATUS_DESC_MAGIC_MATCH_8703B	include/rtl8703b_xmit.h	89;"	d
-GET_RX_STATUS_DESC_MAGIC_MATCH_8723B	include/rtl8723b_xmit.h	89;"	d
-GET_RX_STATUS_DESC_MAGIC_MATCH_8723D	include/rtl8723d_xmit.h	132;"	d
-GET_RX_STATUS_DESC_MAGIC_MATCH_8812	include/rtl8812a_recv.h	123;"	d
-GET_RX_STATUS_DESC_MAGIC_WAKE_8814A	include/rtl8814a_recv.h	154;"	d
-GET_RX_STATUS_DESC_MAGIC_WAKE_92E	include/rtl8192e_recv.h	145;"	d
-GET_RX_STATUS_DESC_MATCH_ID_8723D	include/rtl8723d_xmit.h	136;"	d
-GET_RX_STATUS_DESC_MC_8188F	include/rtl8188f_xmit.h	69;"	d
-GET_RX_STATUS_DESC_MC_8703B	include/rtl8703b_xmit.h	69;"	d
-GET_RX_STATUS_DESC_MC_8723B	include/rtl8723b_xmit.h	69;"	d
-GET_RX_STATUS_DESC_MC_8723D	include/rtl8723d_xmit.h	96;"	d
-GET_RX_STATUS_DESC_MC_8812	include/rtl8812a_recv.h	103;"	d
-GET_RX_STATUS_DESC_MC_8814A	include/rtl8814a_recv.h	129;"	d
-GET_RX_STATUS_DESC_MC_92E	include/rtl8192e_recv.h	123;"	d
-GET_RX_STATUS_DESC_MORE_DATA_8188F	include/rtl8188f_xmit.h	66;"	d
-GET_RX_STATUS_DESC_MORE_DATA_8703B	include/rtl8703b_xmit.h	66;"	d
-GET_RX_STATUS_DESC_MORE_DATA_8723B	include/rtl8723b_xmit.h	66;"	d
-GET_RX_STATUS_DESC_MORE_DATA_8723D	include/rtl8723d_xmit.h	90;"	d
-GET_RX_STATUS_DESC_MORE_DATA_8812	include/rtl8812a_recv.h	100;"	d
-GET_RX_STATUS_DESC_MORE_DATA_8814A	include/rtl8814a_recv.h	124;"	d
-GET_RX_STATUS_DESC_MORE_DATA_92E	include/rtl8192e_recv.h	120;"	d
-GET_RX_STATUS_DESC_MORE_FRAG_8188F	include/rtl8188f_xmit.h	67;"	d
-GET_RX_STATUS_DESC_MORE_FRAG_8703B	include/rtl8703b_xmit.h	67;"	d
-GET_RX_STATUS_DESC_MORE_FRAG_8723B	include/rtl8723b_xmit.h	67;"	d
-GET_RX_STATUS_DESC_MORE_FRAG_8723D	include/rtl8723d_xmit.h	92;"	d
-GET_RX_STATUS_DESC_MORE_FRAG_8812	include/rtl8812a_recv.h	101;"	d
-GET_RX_STATUS_DESC_MORE_FRAG_8814A	include/rtl8814a_recv.h	125;"	d
-GET_RX_STATUS_DESC_MORE_FRAG_92E	include/rtl8192e_recv.h	121;"	d
-GET_RX_STATUS_DESC_OWN_8188F	include/rtl8188f_xmit.h	51;"	d
-GET_RX_STATUS_DESC_OWN_8703B	include/rtl8703b_xmit.h	51;"	d
-GET_RX_STATUS_DESC_OWN_8723B	include/rtl8723b_xmit.h	51;"	d
-GET_RX_STATUS_DESC_OWN_8723D	include/rtl8723d_xmit.h	62;"	d
-GET_RX_STATUS_DESC_OWN_8812	include/rtl8812a_recv.h	85;"	d
-GET_RX_STATUS_DESC_OWN_92E	include/rtl8192e_recv.h	99;"	d
-GET_RX_STATUS_DESC_PAGGR_8188F	include/rtl8188f_xmit.h	58;"	d
-GET_RX_STATUS_DESC_PAGGR_8703B	include/rtl8703b_xmit.h	58;"	d
-GET_RX_STATUS_DESC_PAGGR_8723B	include/rtl8723b_xmit.h	58;"	d
-GET_RX_STATUS_DESC_PAGGR_8723D	include/rtl8723d_xmit.h	74;"	d
-GET_RX_STATUS_DESC_PAGGR_8812	include/rtl8812a_recv.h	92;"	d
-GET_RX_STATUS_DESC_PAGGR_8814A	include/rtl8814a_recv.h	117;"	d
-GET_RX_STATUS_DESC_PAGGR_92E	include/rtl8192e_recv.h	112;"	d
-GET_RX_STATUS_DESC_PAM_8188F	include/rtl8188f_xmit.h	64;"	d
-GET_RX_STATUS_DESC_PAM_8703B	include/rtl8703b_xmit.h	64;"	d
-GET_RX_STATUS_DESC_PAM_8723B	include/rtl8723b_xmit.h	64;"	d
-GET_RX_STATUS_DESC_PAM_8723D	include/rtl8723d_xmit.h	86;"	d
-GET_RX_STATUS_DESC_PAM_8812	include/rtl8812a_recv.h	98;"	d
-GET_RX_STATUS_DESC_PAM_8814A	include/rtl8814a_recv.h	122;"	d
-GET_RX_STATUS_DESC_PAM_92E	include/rtl8192e_recv.h	118;"	d
-GET_RX_STATUS_DESC_PATTERN_IDX_8814A	include/rtl8814a_recv.h	157;"	d
-GET_RX_STATUS_DESC_PATTERN_MATCH_8188F	include/rtl8188f_xmit.h	87;"	d
-GET_RX_STATUS_DESC_PATTERN_MATCH_8703B	include/rtl8703b_xmit.h	87;"	d
-GET_RX_STATUS_DESC_PATTERN_MATCH_8723B	include/rtl8723b_xmit.h	87;"	d
-GET_RX_STATUS_DESC_PATTERN_MATCH_8723D	include/rtl8723d_xmit.h	128;"	d
-GET_RX_STATUS_DESC_PATTERN_MATCH_8812	include/rtl8812a_recv.h	121;"	d
-GET_RX_STATUS_DESC_PATTERN_MATCH_8814A	include/rtl8814a_recv.h	152;"	d
-GET_RX_STATUS_DESC_PATTERN_MATCH_92E	include/rtl8192e_recv.h	143;"	d
-GET_RX_STATUS_DESC_PHY_STATUS_8188F	include/rtl8188f_xmit.h	46;"	d
-GET_RX_STATUS_DESC_PHY_STATUS_8703B	include/rtl8703b_xmit.h	46;"	d
-GET_RX_STATUS_DESC_PHY_STATUS_8723B	include/rtl8723b_xmit.h	46;"	d
-GET_RX_STATUS_DESC_PHY_STATUS_8723D	include/rtl8723d_xmit.h	56;"	d
-GET_RX_STATUS_DESC_PHY_STATUS_8812	include/rtl8812a_recv.h	80;"	d
-GET_RX_STATUS_DESC_PHY_STATUS_8814A	include/rtl8814a_recv.h	105;"	d
-GET_RX_STATUS_DESC_PHY_STATUS_92E	include/rtl8192e_recv.h	96;"	d
-GET_RX_STATUS_DESC_PKT_LEN_8188F	include/rtl8188f_xmit.h	39;"	d
-GET_RX_STATUS_DESC_PKT_LEN_8703B	include/rtl8703b_xmit.h	39;"	d
-GET_RX_STATUS_DESC_PKT_LEN_8723B	include/rtl8723b_xmit.h	39;"	d
-GET_RX_STATUS_DESC_PKT_LEN_8723D	include/rtl8723d_xmit.h	42;"	d
-GET_RX_STATUS_DESC_PKT_LEN_8812	include/rtl8812a_recv.h	73;"	d
-GET_RX_STATUS_DESC_PKT_LEN_8814A	include/rtl8814a_recv.h	98;"	d
-GET_RX_STATUS_DESC_PKT_LEN_92E	include/rtl8192e_recv.h	89;"	d
-GET_RX_STATUS_DESC_PWR_8188F	include/rtl8188f_xmit.h	65;"	d
-GET_RX_STATUS_DESC_PWR_8703B	include/rtl8703b_xmit.h	65;"	d
-GET_RX_STATUS_DESC_PWR_8723B	include/rtl8723b_xmit.h	65;"	d
-GET_RX_STATUS_DESC_PWR_8723D	include/rtl8723d_xmit.h	88;"	d
-GET_RX_STATUS_DESC_PWR_8812	include/rtl8812a_recv.h	99;"	d
-GET_RX_STATUS_DESC_PWR_8814A	include/rtl8814a_recv.h	123;"	d
-GET_RX_STATUS_DESC_PWR_92E	include/rtl8192e_recv.h	119;"	d
-GET_RX_STATUS_DESC_QOS_8188F	include/rtl8188f_xmit.h	44;"	d
-GET_RX_STATUS_DESC_QOS_8703B	include/rtl8703b_xmit.h	44;"	d
-GET_RX_STATUS_DESC_QOS_8723B	include/rtl8723b_xmit.h	44;"	d
-GET_RX_STATUS_DESC_QOS_8723D	include/rtl8723d_xmit.h	52;"	d
-GET_RX_STATUS_DESC_QOS_8812	include/rtl8812a_recv.h	78;"	d
-GET_RX_STATUS_DESC_QOS_8814A	include/rtl8814a_recv.h	103;"	d
-GET_RX_STATUS_DESC_QOS_92E	include/rtl8192e_recv.h	94;"	d
-GET_RX_STATUS_DESC_RPT_SEL_8188F	include/rtl8188f_xmit.h	77;"	d
-GET_RX_STATUS_DESC_RPT_SEL_8703B	include/rtl8703b_xmit.h	77;"	d
-GET_RX_STATUS_DESC_RPT_SEL_8723B	include/rtl8723b_xmit.h	77;"	d
-GET_RX_STATUS_DESC_RPT_SEL_8723D	include/rtl8723d_xmit.h	110;"	d
-GET_RX_STATUS_DESC_RPT_SEL_8812	include/rtl8812a_recv.h	111;"	d
-GET_RX_STATUS_DESC_RPT_SEL_8814A	include/rtl8814a_xmit.h	61;"	d
-GET_RX_STATUS_DESC_RPT_SEL_92E	include/rtl8192e_recv.h	134;"	d
-GET_RX_STATUS_DESC_RXID_MATCH_8188F	include/rtl8188f_xmit.h	57;"	d
-GET_RX_STATUS_DESC_RXID_MATCH_8703B	include/rtl8703b_xmit.h	57;"	d
-GET_RX_STATUS_DESC_RXID_MATCH_8723B	include/rtl8723b_xmit.h	57;"	d
-GET_RX_STATUS_DESC_RXID_MATCH_8723D	include/rtl8723d_xmit.h	72;"	d
-GET_RX_STATUS_DESC_RXID_MATCH_8812	include/rtl8812a_recv.h	91;"	d
-GET_RX_STATUS_DESC_RXID_MATCH_8814A	include/rtl8814a_recv.h	116;"	d
-GET_RX_STATUS_DESC_RXID_MATCH_92E	include/rtl8192e_recv.h	111;"	d
-GET_RX_STATUS_DESC_RX_EOF_8814A	include/rtl8814a_recv.h	158;"	d
-GET_RX_STATUS_DESC_RX_IS_QOS_8188F	include/rtl8188f_xmit.h	75;"	d
-GET_RX_STATUS_DESC_RX_IS_QOS_8703B	include/rtl8703b_xmit.h	75;"	d
-GET_RX_STATUS_DESC_RX_IS_QOS_8723B	include/rtl8723b_xmit.h	75;"	d
-GET_RX_STATUS_DESC_RX_IS_QOS_8723D	include/rtl8723d_xmit.h	106;"	d
-GET_RX_STATUS_DESC_RX_IS_QOS_8812	include/rtl8812a_recv.h	109;"	d
-GET_RX_STATUS_DESC_RX_IS_QOS_8814A	include/rtl8814a_recv.h	138;"	d
-GET_RX_STATUS_DESC_RX_IS_QOS_92E	include/rtl8192e_recv.h	129;"	d
-GET_RX_STATUS_DESC_RX_PRE_NDP_VLD_8814A	include/rtl8814a_recv.h	160;"	d
-GET_RX_STATUS_DESC_RX_RATE_8188F	include/rtl8188f_xmit.h	80;"	d
-GET_RX_STATUS_DESC_RX_RATE_8703B	include/rtl8703b_xmit.h	80;"	d
-GET_RX_STATUS_DESC_RX_RATE_8723B	include/rtl8723b_xmit.h	80;"	d
-GET_RX_STATUS_DESC_RX_RATE_8723D	include/rtl8723d_xmit.h	116;"	d
-GET_RX_STATUS_DESC_RX_RATE_8812	include/rtl8812a_recv.h	114;"	d
-GET_RX_STATUS_DESC_RX_RATE_8814A	include/rtl8814a_recv.h	146;"	d
-GET_RX_STATUS_DESC_RX_RATE_92E	include/rtl8192e_recv.h	137;"	d
-GET_RX_STATUS_DESC_RX_SCRAMBLER_8814A	include/rtl8814a_recv.h	159;"	d
-GET_RX_STATUS_DESC_SECURITY_8188F	include/rtl8188f_xmit.h	43;"	d
-GET_RX_STATUS_DESC_SECURITY_8703B	include/rtl8703b_xmit.h	43;"	d
-GET_RX_STATUS_DESC_SECURITY_8723B	include/rtl8723b_xmit.h	43;"	d
-GET_RX_STATUS_DESC_SECURITY_8723D	include/rtl8723d_xmit.h	50;"	d
-GET_RX_STATUS_DESC_SECURITY_8812	include/rtl8812a_recv.h	77;"	d
-GET_RX_STATUS_DESC_SECURITY_8814A	include/rtl8814a_recv.h	102;"	d
-GET_RX_STATUS_DESC_SECURITY_92E	include/rtl8192e_recv.h	93;"	d
-GET_RX_STATUS_DESC_SEQ_8188F	include/rtl8188f_xmit.h	73;"	d
-GET_RX_STATUS_DESC_SEQ_8703B	include/rtl8703b_xmit.h	73;"	d
-GET_RX_STATUS_DESC_SEQ_8723B	include/rtl8723b_xmit.h	73;"	d
-GET_RX_STATUS_DESC_SEQ_8723D	include/rtl8723d_xmit.h	102;"	d
-GET_RX_STATUS_DESC_SEQ_8812	include/rtl8812a_recv.h	107;"	d
-GET_RX_STATUS_DESC_SEQ_8814A	include/rtl8814a_recv.h	133;"	d
-GET_RX_STATUS_DESC_SEQ_92E	include/rtl8192e_recv.h	127;"	d
-GET_RX_STATUS_DESC_SHIFT_8188F	include/rtl8188f_xmit.h	45;"	d
-GET_RX_STATUS_DESC_SHIFT_8703B	include/rtl8703b_xmit.h	45;"	d
-GET_RX_STATUS_DESC_SHIFT_8723B	include/rtl8723b_xmit.h	45;"	d
-GET_RX_STATUS_DESC_SHIFT_8723D	include/rtl8723d_xmit.h	54;"	d
-GET_RX_STATUS_DESC_SHIFT_8812	include/rtl8812a_recv.h	79;"	d
-GET_RX_STATUS_DESC_SHIFT_8814A	include/rtl8814a_recv.h	104;"	d
-GET_RX_STATUS_DESC_SHIFT_92E	include/rtl8192e_recv.h	95;"	d
-GET_RX_STATUS_DESC_SPLCP_8188F	include/rtl8188f_xmit.h	92;"	d
-GET_RX_STATUS_DESC_SPLCP_8703B	include/rtl8703b_xmit.h	92;"	d
-GET_RX_STATUS_DESC_SPLCP_8723B	include/rtl8723b_xmit.h	92;"	d
-GET_RX_STATUS_DESC_SPLCP_8812	include/rtl8812a_recv.h	126;"	d
-GET_RX_STATUS_DESC_STBC_8188F	include/rtl8188f_xmit.h	94;"	d
-GET_RX_STATUS_DESC_STBC_8703B	include/rtl8703b_xmit.h	94;"	d
-GET_RX_STATUS_DESC_STBC_8723B	include/rtl8723b_xmit.h	94;"	d
-GET_RX_STATUS_DESC_STBC_8812	include/rtl8812a_recv.h	128;"	d
-GET_RX_STATUS_DESC_SWDEC_8188F	include/rtl8188f_xmit.h	47;"	d
-GET_RX_STATUS_DESC_SWDEC_8703B	include/rtl8703b_xmit.h	47;"	d
-GET_RX_STATUS_DESC_SWDEC_8723B	include/rtl8723b_xmit.h	47;"	d
-GET_RX_STATUS_DESC_SWDEC_8723D	include/rtl8723d_xmit.h	58;"	d
-GET_RX_STATUS_DESC_SWDEC_8812	include/rtl8812a_recv.h	81;"	d
-GET_RX_STATUS_DESC_SWDEC_8814A	include/rtl8814a_recv.h	106;"	d
-GET_RX_STATUS_DESC_SWDEC_92E	include/rtl8192e_recv.h	97;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_8814A	include/rtl8814a_recv.h	118;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_CHKERR_92E	include/rtl8192e_recv.h	114;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_8814A	include/rtl8814a_recv.h	121;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_CHK_VLD_92E	include/rtl8192e_recv.h	117;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_8814A	include/rtl8814a_recv.h	119;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_IPVER_92E	include/rtl8192e_recv.h	115;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_8814A	include/rtl8814a_recv.h	120;"	d
-GET_RX_STATUS_DESC_TCPOFFLOAD_IS_TCPUDP_92E	include/rtl8192e_recv.h	116;"	d
-GET_RX_STATUS_DESC_TID_8188F	include/rtl8188f_xmit.h	55;"	d
-GET_RX_STATUS_DESC_TID_8703B	include/rtl8703b_xmit.h	55;"	d
-GET_RX_STATUS_DESC_TID_8723B	include/rtl8723b_xmit.h	55;"	d
-GET_RX_STATUS_DESC_TID_8723D	include/rtl8723d_xmit.h	68;"	d
-GET_RX_STATUS_DESC_TID_8812	include/rtl8812a_recv.h	89;"	d
-GET_RX_STATUS_DESC_TID_8814A	include/rtl8814a_recv.h	113;"	d
-GET_RX_STATUS_DESC_TID_92E	include/rtl8192e_recv.h	108;"	d
-GET_RX_STATUS_DESC_TSFL_8188F	include/rtl8188f_xmit.h	98;"	d
-GET_RX_STATUS_DESC_TSFL_8703B	include/rtl8703b_xmit.h	98;"	d
-GET_RX_STATUS_DESC_TSFL_8723B	include/rtl8723b_xmit.h	98;"	d
-GET_RX_STATUS_DESC_TSFL_8723D	include/rtl8723d_xmit.h	140;"	d
-GET_RX_STATUS_DESC_TSFL_8812	include/rtl8812a_recv.h	132;"	d
-GET_RX_STATUS_DESC_TSFL_8814A	include/rtl8814a_recv.h	165;"	d
-GET_RX_STATUS_DESC_TSFL_92E	include/rtl8192e_recv.h	149;"	d
-GET_RX_STATUS_DESC_TYPE_8188F	include/rtl8188f_xmit.h	68;"	d
-GET_RX_STATUS_DESC_TYPE_8703B	include/rtl8703b_xmit.h	68;"	d
-GET_RX_STATUS_DESC_TYPE_8723B	include/rtl8723b_xmit.h	68;"	d
-GET_RX_STATUS_DESC_TYPE_8723D	include/rtl8723d_xmit.h	94;"	d
-GET_RX_STATUS_DESC_TYPE_8812	include/rtl8812a_recv.h	102;"	d
-GET_RX_STATUS_DESC_TYPE_8814A	include/rtl8814a_recv.h	126;"	d
-GET_RX_STATUS_DESC_TYPE_92E	include/rtl8192e_recv.h	122;"	d
-GET_RX_STATUS_DESC_UNICAST_8814A	include/rtl8814a_recv.h	153;"	d
-GET_RX_STATUS_DESC_UNICAST_92E	include/rtl8192e_recv.h	144;"	d
-GET_RX_STATUS_DESC_UNICAST_MATCH_8188F	include/rtl8188f_xmit.h	88;"	d
-GET_RX_STATUS_DESC_UNICAST_MATCH_8703B	include/rtl8703b_xmit.h	88;"	d
-GET_RX_STATUS_DESC_UNICAST_MATCH_8723B	include/rtl8723b_xmit.h	88;"	d
-GET_RX_STATUS_DESC_UNICAST_MATCH_8723D	include/rtl8723d_xmit.h	130;"	d
-GET_RX_STATUS_DESC_UNICAST_MATCH_8812	include/rtl8812a_recv.h	122;"	d
-GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8188F	include/rtl8188f_xmit.h	85;"	d
-GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8703B	include/rtl8703b_xmit.h	85;"	d
-GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8723B	include/rtl8723b_xmit.h	85;"	d
-GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8723D	include/rtl8723d_xmit.h	125;"	d
-GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8812	include/rtl8812a_recv.h	119;"	d
-GET_RX_STATUS_DESC_USB_AGG_PKTNUM_8814A	include/rtl8814a_recv.h	136;"	d
-GET_RX_STATUS_DESC_WLANHD_IV_LEN_8188F	include/rtl8188f_xmit.h	76;"	d
-GET_RX_STATUS_DESC_WLANHD_IV_LEN_8703B	include/rtl8703b_xmit.h	76;"	d
-GET_RX_STATUS_DESC_WLANHD_IV_LEN_8723B	include/rtl8723b_xmit.h	76;"	d
-GET_RX_STATUS_DESC_WLANHD_IV_LEN_8723D	include/rtl8723d_xmit.h	108;"	d
-GET_RX_STATUS_DESC_WLANHD_IV_LEN_8812	include/rtl8812a_recv.h	110;"	d
-GET_RX_STATUS_DESC_WLANHD_IV_LEN_8814A	include/rtl8814a_recv.h	140;"	d
-GET_RX_STATUS_DESC_WLANHD_IV_LEN_92E	include/rtl8192e_recv.h	131;"	d
-GET_STATUS_CODE_FROM_BT_MP_OPER_RET	include/rtw_btcoex.h	65;"	d
-GET_STATUS_ERROR	include/gspi_ops.h	136;"	d
-GET_STATUS_HISR_HI6BIT	include/gspi_ops.h	131;"	d
-GET_STATUS_HISR_LOW8BIT	include/gspi_ops.h	135;"	d
-GET_STATUS_HISR_MID8BIT	include/gspi_ops.h	134;"	d
-GET_STATUS_HI_PAGE_NUM	include/gspi_ops.h	128;"	d
-GET_STATUS_INT	include/gspi_ops.h	137;"	d
-GET_STATUS_LOW_PAGE_NUM	include/gspi_ops.h	130;"	d
-GET_STATUS_MID_PAGE_NUM	include/gspi_ops.h	129;"	d
-GET_STATUS_PUB_PAGE_NUM	include/gspi_ops.h	127;"	d
-GET_STATUS_RX_LENGTH	include/gspi_ops.h	138;"	d
-GET_TCP_ACK	include/rtw_mlme.h	1202;"	d
-GET_TCP_ACK_SEQ	include/rtw_mlme.h	1196;"	d
-GET_TCP_CWR	include/rtw_mlme.h	1205;"	d
-GET_TCP_DOFF	include/rtw_mlme.h	1197;"	d
-GET_TCP_DST	include/rtw_mlme.h	1194;"	d
-GET_TCP_ECE	include/rtw_mlme.h	1204;"	d
-GET_TCP_FIN	include/rtw_mlme.h	1198;"	d
-GET_TCP_PSH	include/rtw_mlme.h	1201;"	d
-GET_TCP_RST	include/rtw_mlme.h	1200;"	d
-GET_TCP_SEQ	include/rtw_mlme.h	1195;"	d
-GET_TCP_SRC	include/rtw_mlme.h	1193;"	d
-GET_TCP_SYN	include/rtw_mlme.h	1199;"	d
-GET_TCP_URG	include/rtw_mlme.h	1203;"	d
-GET_TKIP_PN	include/rtw_security.h	304;"	d
-GET_TX_BUFF_DESC_ADDR_HIGH_0_8723D	include/rtl8723d_xmit.h	367;"	d
-GET_TX_BUFF_DESC_ADDR_HIGH_0_8723D	include/rtl8723d_xmit.h	369;"	d
-GET_TX_BUFF_DESC_ADDR_HIGH_0_8814A	include/rtl8814a_xmit.h	91;"	d
-GET_TX_BUFF_DESC_ADDR_LOW_0_8723D	include/rtl8723d_xmit.h	363;"	d
-GET_TX_BUFF_DESC_ADDR_LOW_0_8814A	include/rtl8814a_xmit.h	88;"	d
-GET_TX_BUFF_DESC_OWN_8814A	include/rtl8814a_xmit.h	84;"	d
-GET_TX_DESC_MORE_FRAG_8814A	include/rtl8814a_xmit.h	162;"	d
-GET_TX_DESC_MORE_FRAG_92E	include/rtl8192e_xmit.h	267;"	d
-GET_TX_DESC_OFFSET_8814A	include/rtl8814a_xmit.h	128;"	d
-GET_TX_DESC_OWN_8188F	include/rtl8188f_xmit.h	107;"	d
-GET_TX_DESC_OWN_8703B	include/rtl8703b_xmit.h	107;"	d
-GET_TX_DESC_OWN_8723B	include/rtl8723b_xmit.h	107;"	d
-GET_TX_DESC_OWN_8723D	include/rtl8723d_xmit.h	153;"	d
-GET_TX_DESC_OWN_8812	include/rtl8812a_xmit.h	204;"	d
-GET_TX_DESC_OWN_92E	include/rtl8192e_xmit.h	240;"	d
-GET_TX_DESC_PKT_SIZE_8814A	include/rtl8814a_xmit.h	126;"	d
-GET_TX_DESC_TX_BUFFER_ADDRESS_8188F	include/rtl8188f_xmit.h	210;"	d
-GET_TX_DESC_TX_BUFFER_ADDRESS_8703B	include/rtl8703b_xmit.h	210;"	d
-GET_TX_DESC_TX_BUFFER_ADDRESS_8723B	include/rtl8723b_xmit.h	210;"	d
-GET_TX_DESC_TX_BUFFER_ADDRESS_8812	include/rtl8812a_xmit.h	300;"	d
-GET_TX_DESC_TX_BUFFER_ADDRESS_92E	include/rtl8192e_xmit.h	220;"	d
-GET_TX_PAGE_SIZE	include/hal_com_reg.h	1337;"	d
-GET_UDP_DST	include/rtw_mlme.h	1189;"	d
-GET_UDP_SRC	include/rtw_mlme.h	1188;"	d
-GET_VERSION	hal/phydm/phydm_hwconfig.c	62;"	d	file:
-GET_VERSION	hal/phydm/phydm_hwconfig.c	64;"	d	file:
-GET_VERSION_MP	hal/phydm/phydm_hwconfig.c	58;"	d	file:
-GET_VERSION_TC	hal/phydm/phydm_hwconfig.c	59;"	d	file:
-GET_VHT_CAPABILITY_ELE_CHL_WIDTH	include/rtw_vht.h	68;"	d
-GET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH	include/rtw_vht.h	67;"	d
-GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR	include/rtw_vht.h	82;"	d
-GET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE	include/rtw_vht.h	84;"	d
-GET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE	include/rtw_vht.h	86;"	d
-GET_VHT_CAPABILITY_ELE_MU_BFEE	include/rtw_vht.h	80;"	d
-GET_VHT_CAPABILITY_ELE_MU_BFER	include/rtw_vht.h	79;"	d
-GET_VHT_CAPABILITY_ELE_RX_LDPC	include/rtw_vht.h	69;"	d
-GET_VHT_CAPABILITY_ELE_RX_MCS	include/rtw_vht.h	83;"	d
-GET_VHT_CAPABILITY_ELE_RX_STBC	include/rtw_vht.h	73;"	d
-GET_VHT_CAPABILITY_ELE_SHORT_GI160M	include/rtw_vht.h	71;"	d
-GET_VHT_CAPABILITY_ELE_SHORT_GI80M	include/rtw_vht.h	70;"	d
-GET_VHT_CAPABILITY_ELE_SU_BFEE	include/rtw_vht.h	75;"	d
-GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP	include/rtw_vht.h	77;"	d
-GET_VHT_CAPABILITY_ELE_SU_BFER	include/rtw_vht.h	74;"	d
-GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM	include/rtw_vht.h	78;"	d
-GET_VHT_CAPABILITY_ELE_TXOP_PS	include/rtw_vht.h	81;"	d
-GET_VHT_CAPABILITY_ELE_TX_MCS	include/rtw_vht.h	85;"	d
-GET_VHT_CAPABILITY_ELE_TX_STBC	include/rtw_vht.h	72;"	d
-GET_VHT_GID_MGNT_INFO_MEMBERSHIP_STATUS	core/rtw_beamforming.c	1778;"	d	file:
-GET_VHT_GID_MGNT_INFO_USER_POSITION	core/rtw_beamforming.c	1779;"	d	file:
-GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH	include/rtw_vht.h	103;"	d
-GET_VHT_OPERATING_MODE_FIELD_RX_NSS	include/rtw_vht.h	104;"	d
-GET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE	include/rtw_vht.h	105;"	d
-GET_VHT_OPERATION_ELE_CENTER_FREQ1	include/rtw_vht.h	96;"	d
-GET_VHT_OPERATION_ELE_CENTER_FREQ2	include/rtw_vht.h	97;"	d
-GET_VHT_OPERATION_ELE_CHL_WIDTH	include/rtw_vht.h	95;"	d
-GFP_ATOMIC	include/osdep_service_bsd.h	591;"	d
-GFP_HIGHUSER	include/osdep_service_bsd.h	596;"	d
-GFP_KERNEL	include/osdep_service_bsd.h	594;"	d
-GFP_NOFS	include/osdep_service_bsd.h	593;"	d
-GFP_NOIO	include/osdep_service_bsd.h	592;"	d
-GFP_NOWAIT	include/osdep_service_bsd.h	589;"	d
-GFP_USER	include/osdep_service_bsd.h	595;"	d
-GLBtCoexist	hal/hal_btcoex.c	/^struct btc_coexist GLBtCoexist;$/;"	v	typeref:struct:btc_coexist
-GLBtInfoSrc8723a1Ant	hal/btc/HalBtc8723a1Ant.c	/^const char *const GLBtInfoSrc8723a1Ant[]={$/;"	v
-GLBtInfoSrc8723a2Ant	hal/btc/HalBtc8723a2Ant.c	/^const char *const GLBtInfoSrc8723a2Ant[]={$/;"	v
-GLBtcBtCoexAliveRegistered	hal/hal_btcoex.c	/^u8 GLBtcBtCoexAliveRegistered;$/;"	v
-GLBtcBtMpOperLock	hal/hal_btcoex.c	/^_mutex GLBtcBtMpOperLock;$/;"	v
-GLBtcBtMpOperSeq	hal/hal_btcoex.c	/^u8 GLBtcBtMpOperSeq;$/;"	v
-GLBtcBtMpOperTimer	hal/hal_btcoex.c	/^_timer GLBtcBtMpOperTimer;$/;"	v
-GLBtcBtMpRptBTOK	hal/hal_btcoex.c	/^u8 GLBtcBtMpRptBTOK;$/;"	v
-GLBtcBtMpRptRsp	hal/hal_btcoex.c	/^u8 GLBtcBtMpRptRsp[C2H_MAX_SIZE];$/;"	v
-GLBtcBtMpRptRspSize	hal/hal_btcoex.c	/^u8 GLBtcBtMpRptRspSize;$/;"	v
-GLBtcBtMpRptSema	hal/hal_btcoex.c	/^_sema GLBtcBtMpRptSema;$/;"	v
-GLBtcBtMpRptSeq	hal/hal_btcoex.c	/^u8 GLBtcBtMpRptSeq;$/;"	v
-GLBtcBtMpRptStatus	hal/hal_btcoex.c	/^u8 GLBtcBtMpRptStatus;$/;"	v
-GLBtcBtMpRptWait	hal/hal_btcoex.c	/^u8 GLBtcBtMpRptWait;$/;"	v
-GLBtcBtMpRptWiFiOK	hal/hal_btcoex.c	/^u8 GLBtcBtMpRptWiFiOK;$/;"	v
-GLBtcDbgBuf	hal/hal_btcoex.c	/^u8 GLBtcDbgBuf[BT_TMP_BUF_SIZE];$/;"	v
-GLBtcDbgInfo	hal/hal_btcoex.c	/^BTCDBGINFO GLBtcDbgInfo;$/;"	v
-GLBtcDbgType	hal/hal_btcoex.c	/^u32 GLBtcDbgType[COMP_MAX];$/;"	v
-GLBtcIotPeerString	hal/hal_btcoex.c	/^const char *const GLBtcIotPeerString[] = {$/;"	v
-GLBtcWiFiInIPS	hal/hal_btcoex.c	/^u8 GLBtcWiFiInIPS;$/;"	v
-GLBtcWiFiInIQKState	hal/hal_btcoex.c	/^u8 GLBtcWiFiInIQKState;$/;"	v
-GLBtcWiFiInLPS	hal/hal_btcoex.c	/^u8 GLBtcWiFiInLPS;$/;"	v
-GLBtcWiFiInScanState	hal/hal_btcoex.c	/^u8 GLBtcWiFiInScanState;$/;"	v
-GLBtcWifiBwString	hal/hal_btcoex.c	/^const char *const GLBtcWifiBwString[] = {$/;"	v
-GLBtcWifiFreqString	hal/hal_btcoex.c	/^const char *const GLBtcWifiFreqString[] = {$/;"	v
-GLCoexDm8188c2Ant	hal/btc/HalBtc8188c2Ant.c	/^static COEX_DM_8188C_2ANT	GLCoexDm8188c2Ant;$/;"	v	file:
-GLCoexDm8192d2Ant	hal/btc/HalBtc8192d2Ant.c	/^static COEX_DM_8192D_2ANT	GLCoexDm8192d2Ant;$/;"	v	file:
-GLCoexDm8723a1Ant	hal/btc/HalBtc8723a1Ant.c	/^static COEX_DM_8723A_1ANT	GLCoexDm8723a1Ant;$/;"	v	file:
-GLCoexDm8723a2Ant	hal/btc/HalBtc8723a2Ant.c	/^static COEX_DM_8723A_2ANT	GLCoexDm8723a2Ant;$/;"	v	file:
-GLCoexSta8188c2Ant	hal/btc/HalBtc8188c2Ant.c	/^static COEX_STA_8188C_2ANT	GLCoexSta8188c2Ant;$/;"	v	file:
-GLCoexSta8192d2Ant	hal/btc/HalBtc8192d2Ant.c	/^static COEX_STA_8192D_2ANT	GLCoexSta8192d2Ant;$/;"	v	file:
-GLCoexSta8723a1Ant	hal/btc/HalBtc8723a1Ant.c	/^static COEX_STA_8723A_1ANT	GLCoexSta8723a1Ant;$/;"	v	file:
-GLCoexSta8723a2Ant	hal/btc/HalBtc8723a2Ant.c	/^static COEX_STA_8723A_2ANT	GLCoexSta8723a2Ant;$/;"	v	file:
-GLNA_Type	include/drv_types.h	/^	u8	GLNA_Type;$/;"	m	struct:registry_priv
-GNT_BT_keep	hal/phydm/phydm_hwconfig.h	/^	u1Byte			GNT_BT_keep: 1;							\/*8812A: 1'b0		8814A: GNT_BT_keep*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-GNT_BT_keep	hal/phydm/phydm_hwconfig.h	/^	u1Byte			GNT_BT_keep: 1;$/;"	m	struct:_Phy_Status_Rpt_8812
-GOOGLE_GSCAN_BATCH_SCAN_EVENT	os_dep/linux/rtw_cfgvendor.h	/^	GOOGLE_GSCAN_BATCH_SCAN_EVENT,$/;"	e	enum:wl_vendor_event
-GOOGLE_GSCAN_GEOFENCE_FOUND_EVENT	os_dep/linux/rtw_cfgvendor.h	/^	GOOGLE_GSCAN_GEOFENCE_FOUND_EVENT,$/;"	e	enum:wl_vendor_event
-GOOGLE_GSCAN_GEOFENCE_LOST_EVENT	os_dep/linux/rtw_cfgvendor.h	/^	GOOGLE_GSCAN_GEOFENCE_LOST_EVENT$/;"	e	enum:wl_vendor_event
-GOOGLE_GSCAN_SIGNIFICANT_EVENT	os_dep/linux/rtw_cfgvendor.h	/^	GOOGLE_GSCAN_SIGNIFICANT_EVENT,$/;"	e	enum:wl_vendor_event
-GOOGLE_RTT_COMPLETE_EVENT	os_dep/linux/rtw_cfgvendor.h	/^	GOOGLE_RTT_COMPLETE_EVENT,$/;"	e	enum:wl_vendor_event
-GOOGLE_SCAN_COMPLETE_EVENT	os_dep/linux/rtw_cfgvendor.h	/^	GOOGLE_SCAN_COMPLETE_EVENT,$/;"	e	enum:wl_vendor_event
-GOOGLE_SCAN_FULL_RESULTS_EVENT	os_dep/linux/rtw_cfgvendor.h	/^	GOOGLE_SCAN_FULL_RESULTS_EVENT,$/;"	e	enum:wl_vendor_event
-GPIOSEL_ENBT	include/hal_com_reg.h	608;"	d
-GPIOSEL_GPIO	include/hal_com_reg.h	607;"	d
-GPIO_IN	include/hal_com_reg.h	613;"	d
-GPIO_IN_8811A	include/hal_com_reg.h	621;"	d
-GPIO_IO_SEL	include/hal_com_reg.h	615;"	d
-GPIO_IO_SEL_8811A	include/hal_com_reg.h	623;"	d
-GPIO_MOD	include/hal_com_reg.h	616;"	d
-GPIO_MOD_8811A	include/hal_com_reg.h	624;"	d
-GPIO_OUT	include/hal_com_reg.h	614;"	d
-GPIO_OUT_8811A	include/hal_com_reg.h	622;"	d
-GPIO_WIFI_IRQ	os_dep/linux/custom_gpio_linux.c	275;"	d	file:
-GPIO_WIFI_POWER	os_dep/linux/custom_gpio_linux.c	37;"	d	file:
-GPIO_WIFI_PWDN	os_dep/linux/custom_gpio_linux.c	45;"	d	file:
-GPIO_WIFI_RESET	os_dep/linux/custom_gpio_linux.c	41;"	d	file:
-GPS_CTL_HWPDN	include/hal_com_reg.h	1299;"	d
-GPS_FUNC_EN	include/hal_com_reg.h	1774;"	d
-GPS_HWPDN_EN	include/hal_com_reg.h	1772;"	d
-GPS_HWPDN_SL	include/hal_com_reg.h	1773;"	d
-GROUP_KEY	include/rtw_cmd.h	/^	GROUP_KEY		= 0,$/;"	e	enum:STAKEY_TYPE
-GSCAN_ATTRIBUTE_AP_FLAGS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_AP_FLAGS,                           \/* flags on significant change event *\/$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BAND	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BAND = GSCAN_ATTRIBUTE_BUCKETS_BAND,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BASE_PERIOD	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BASE_PERIOD,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BSSID	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BSSID,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BUCKETS_BAND	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BUCKETS_BAND,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BUCKET_CHANNELS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BUCKET_CHANNELS,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BUCKET_ID	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BUCKET_ID,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BUCKET_NUM_CHANNELS,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_BUCKET_PERIOD	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_BUCKET_PERIOD,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_CHANNEL	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CHANNEL,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_CHANNEL_LIST	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CHANNEL_LIST,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_CH_BUCKET_1	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_BUCKET_1,$/;"	e	enum:gscan_bucket_attributes
-GSCAN_ATTRIBUTE_CH_BUCKET_2	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_BUCKET_2,$/;"	e	enum:gscan_bucket_attributes
-GSCAN_ATTRIBUTE_CH_BUCKET_3	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_BUCKET_3,$/;"	e	enum:gscan_bucket_attributes
-GSCAN_ATTRIBUTE_CH_BUCKET_4	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_BUCKET_4,$/;"	e	enum:gscan_bucket_attributes
-GSCAN_ATTRIBUTE_CH_BUCKET_5	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_BUCKET_5,$/;"	e	enum:gscan_bucket_attributes
-GSCAN_ATTRIBUTE_CH_BUCKET_6	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_BUCKET_6,$/;"	e	enum:gscan_bucket_attributes
-GSCAN_ATTRIBUTE_CH_BUCKET_7	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_BUCKET_7$/;"	e	enum:gscan_bucket_attributes
-GSCAN_ATTRIBUTE_CH_ID_1	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_ID_1,$/;"	e	enum:gscan_ch_attributes
-GSCAN_ATTRIBUTE_CH_ID_2	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_ID_2,$/;"	e	enum:gscan_ch_attributes
-GSCAN_ATTRIBUTE_CH_ID_3	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_ID_3,$/;"	e	enum:gscan_ch_attributes
-GSCAN_ATTRIBUTE_CH_ID_4	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_ID_4,$/;"	e	enum:gscan_ch_attributes
-GSCAN_ATTRIBUTE_CH_ID_5	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_ID_5,$/;"	e	enum:gscan_ch_attributes
-GSCAN_ATTRIBUTE_CH_ID_6	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_ID_6,$/;"	e	enum:gscan_ch_attributes
-GSCAN_ATTRIBUTE_CH_ID_7	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_CH_ID_7$/;"	e	enum:gscan_ch_attributes
-GSCAN_ATTRIBUTE_ENABLE_FEATURE	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_ENABLE_FEATURE = 20,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_ENABLE_FULL_SCAN_RESULTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_ENABLE_FULL_SCAN_RESULTS,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_FLUSH_FEATURE	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_FLUSH_FEATURE,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_FLUSH_RESULTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_FLUSH_RESULTS,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_HOSTLIST_BSSID_ELEM	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_HOSTLIST_BSSID_ELEM,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_HOTLIST_BSSIDS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_HOTLIST_BSSIDS = 50,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_HOTLIST_FLUSH	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_HOTLIST_FLUSH,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_LOST_AP_SAMPLE_SIZE,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_MAX	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_MAX$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_MIN_BREACHING	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_MIN_BREACHING,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_NUM_AP_PER_SCAN,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_NUM_BUCKETS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_NUM_BUCKETS = 10,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_NUM_CHANNELS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_NUM_CHANNELS,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_NUM_OF_RESULTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_NUM_OF_RESULTS = 30,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_NUM_SCANS_TO_CACHE,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_REPORT_EVENTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_REPORT_EVENTS,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_REPORT_THRESHOLD	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_REPORT_THRESHOLD,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_RSSI	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_RSSI,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_RSSI_HIGH	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_RSSI_HIGH,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_RSSI_LOW	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_RSSI_LOW,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_RSSI_SAMPLE_SIZE = 60,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_RTT	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_RTT,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_RTTSD	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_RTTSD,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_SCAN_FLAGS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_SCAN_FLAGS,                         \/* indicates if scan was aborted *\/$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_SCAN_ID	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_SCAN_ID,                            \/* indicates scan number *\/$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_SCAN_RESULTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_SCAN_RESULTS,                       \/* flat array of wifi_scan_result *\/$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_SCAN_RESULTS_COMPLETE	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_SCAN_RESULTS_COMPLETE,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_BSSIDS,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_SIGNIFICANT_CHANGE_FLUSH,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_SSID	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_SSID = 40,$/;"	e	enum:gscan_attributes
-GSCAN_ATTRIBUTE_TIMESTAMP	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_ATTRIBUTE_TIMESTAMP,$/;"	e	enum:gscan_attributes
-GSCAN_BATCH_RESULT_HDR_LEN	os_dep/linux/rtw_cfgvendor.h	38;"	d
-GSCAN_NUM_RESULTS_HDR_LEN	os_dep/linux/rtw_cfgvendor.h	36;"	d
-GSCAN_RESULTS_HDR_LEN	os_dep/linux/rtw_cfgvendor.h	37;"	d
-GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_ENABLE_FULL_SCAN_RESULTS,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_ENABLE_GSCAN	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_ENABLE_GSCAN,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_GET_CAPABILITIES	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_GET_CAPABILITIES = ANDROID_NL80211_SUBCMD_GSCAN_RANGE_START,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_GET_CHANNEL_LIST	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_GET_CHANNEL_LIST,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_GET_SCAN_RESULTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_GET_SCAN_RESULTS,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_SCAN_RESULTS	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_SCAN_RESULTS,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_SET_CONFIG	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_SET_CONFIG,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_SET_HOTLIST	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_SET_HOTLIST,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_SET_SCAN_CONFIG	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_SET_SCAN_CONFIG,$/;"	e	enum:wl_vendor_subcmd
-GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG	os_dep/linux/rtw_cfgvendor.h	/^	GSCAN_SUBCMD_SET_SIGNIFICANT_CHANGE_CONFIG,$/;"	e	enum:wl_vendor_subcmd
-GSPI_DATA	include/drv_types_gspi.h	/^} GSPI_DATA, *PGSPI_DATA;$/;"	t	typeref:struct:gspi_data
-G_CUT_VERSION	include/HalVerDef.h	/^	G_CUT_VERSION		=	6,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-G_ID	hal/phydm/phydm_beamforming.h	/^	u2Byte				G_ID;$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-G_ID	hal/phydm/phydm_beamforming.h	/^	u2Byte	G_ID;				\/*Used to fill Tx DESC*\/$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-Gamma0	include/rtw_security.h	442;"	d
-Gamma1	include/rtw_security.h	443;"	d
-GetAMsdu	include/wifi.h	424;"	d
-GetAckpolicy	include/wifi.h	422;"	d
-GetAddr1Ptr	include/wifi.h	435;"	d
-GetAddr2Ptr	include/wifi.h	437;"	d
-GetAddr3Ptr	include/wifi.h	439;"	d
-GetAddr4Ptr	include/wifi.h	441;"	d
-GetAid	include/wifi.h	431;"	d
-GetDefaultAdapter	include/drv_types.h	475;"	d
-GetDeltaAllSwingTable	hal/phydm/halphyrf_ap.h	/^	FuncAllSwing	GetDeltaAllSwingTable;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaAllSwingTable	hal/phydm/halphyrf_win.h	/^	FuncAllSwing	GetDeltaAllSwingTable;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingTable	hal/phydm/halphyrf_ap.h	/^	FuncSwing	GetDeltaSwingTable;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingTable	hal/phydm/halphyrf_ce.h	/^	FuncSwing	GetDeltaSwingTable;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingTable	hal/phydm/halphyrf_win.h	/^	FuncSwing	GetDeltaSwingTable;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingTable8814only	hal/phydm/halphyrf_ap.h	/^	FuncSwing8814only	GetDeltaSwingTable8814only;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingTable8814only	hal/phydm/halphyrf_ce.h	/^	FuncSwing8814only	GetDeltaSwingTable8814only;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingTable8814only	hal/phydm/halphyrf_win.h	/^	FuncSwing8814only	GetDeltaSwingTable8814only;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingTable_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^GetDeltaSwingTable_8723D($/;"	f
-GetDeltaSwingXtalTable	hal/phydm/halphyrf_ce.h	/^	FuncSwingXtal			GetDeltaSwingXtalTable;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingXtalTable	hal/phydm/halphyrf_win.h	/^	FuncSwingXtal			GetDeltaSwingXtalTable;$/;"	m	struct:_TXPWRTRACK_CFG
-GetDeltaSwingXtalTable_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^GetDeltaSwingXtalTable_8723D($/;"	f
-GetEEPROMSize8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^u8 GetEEPROMSize8723D(PADAPTER padapter)$/;"	f
-GetFrDs	include/wifi.h	290;"	d
-GetFractionValueFromString	hal/hal_com.c	/^GetFractionValueFromString($/;"	f
-GetFragNum	include/wifi.h	381;"	d
-GetFrameSubType	include/wifi.h	371;"	d
-GetFrameType	include/wifi.h	363;"	d
-GetGatewayTryCnt	include/rtw_mlme.h	/^	u8	GetGatewayTryCnt;$/;"	m	struct:mlme_priv
-GetHalDefVar	hal/hal_com.c	/^GetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)$/;"	f
-GetHalDefVar8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^u8 GetHalDefVar8723D(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval)$/;"	f
-GetHalDefVar8723DSDIO	hal/rtl8723d/sdio/sdio_halinit.c	/^GetHalDefVar8723DSDIO($/;"	f
-GetHalDefVarHandler	include/hal_intf.h	/^	u8(*GetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);$/;"	m	struct:hal_ops
-GetHalODMVar	hal/hal_com.c	/^void GetHalODMVar($/;"	f
-GetHalODMVarHandler	include/hal_intf.h	/^	void	(*GetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, PVOID pValue2);$/;"	m	struct:hal_ops
-GetHexValueFromString	hal/hal_com.c	/^GetHexValueFromString($/;"	f
-GetHwReg	hal/hal_com.c	/^void GetHwReg(_adapter *adapter, u8 variable, u8 *val)$/;"	f
-GetHwReg8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^void GetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)$/;"	f
-GetHwReg8723DS	hal/rtl8723d/sdio/sdio_halinit.c	/^void GetHwReg8723DS(PADAPTER padapter, u8 variable, u8 *val)$/;"	f
-GetHwRegHandler	include/hal_intf.h	/^	void	(*GetHwRegHandler)(_adapter *padapter, u8	variable, u8 *val);$/;"	m	struct:hal_ops
-GetInitSoundCnt	include/rtw_beamforming.h	35;"	d
-GetLineFromBuffer	include/hal_com.h	602;"	d
-GetMData	include/wifi.h	341;"	d
-GetMFrag	include/wifi.h	305;"	d
-GetOrder	include/wifi.h	361;"	d
-GetOrderBit	include/wifi.h	762;"	d
-GetPSDData	hal/phydm/phydm.c	/^GetPSDData($/;"	f
-GetPhyRxPktCRC32Error	core/rtw_mp.c	/^u32 GetPhyRxPktCRC32Error(PADAPTER pAdapter)$/;"	f
-GetPhyRxPktCounts	core/rtw_mp.c	/^static u32 GetPhyRxPktCounts(PADAPTER pAdapter, u32 selbit)$/;"	f	file:
-GetPhyRxPktReceived	core/rtw_mp.c	/^u32 GetPhyRxPktReceived(PADAPTER pAdapter)$/;"	f
-GetPowerTracking	core/rtw_mp.c	/^void GetPowerTracking(PADAPTER padapter, u8 *enable)$/;"	f
-GetPriority	include/wifi.h	410;"	d
-GetPrivacy	include/wifi.h	353;"	d
-GetPwrMgt	include/wifi.h	329;"	d
-GetRegAmplifierType2G	include/drv_types.h	416;"	d
-GetRegAmplifierType5G	include/drv_types.h	417;"	d
-GetRegGLNAType	include/drv_types.h	424;"	d
-GetRegPowerTrackingType	include/drv_types.h	425;"	d
-GetRegRFEType	include/drv_types.h	423;"	d
-GetRegTxBBSwing_2G	include/drv_types.h	419;"	d
-GetRegTxBBSwing_5G	include/drv_types.h	420;"	d
-GetRegbENRFEType	include/drv_types.h	422;"	d
-GetRetry	include/wifi.h	317;"	d
-GetRightChnlPlaceforIQK	hal/phydm/phydm.c	/^u1Byte GetRightChnlPlaceforIQK(u1Byte chnl)$/;"	f
-GetSequence	include/wifi.h	379;"	d
-GetThermalMeter	core/rtw_mp.c	/^void GetThermalMeter(PADAPTER pAdapter, u8 *value)$/;"	f
-GetTid	include/wifi.h	433;"	d
-GetToDs	include/wifi.h	278;"	d
-GetTupleCache	include/wifi.h	383;"	d
-GetTxBufferRsvdPageNum8723D	hal/rtl8723d/rtl8723d_cmd.c	/^u8 GetTxBufferRsvdPageNum8723D(_adapter *padapter, bool wowlan)$/;"	f
-GetU1ByteIntegerFromStringInDecimal	hal/hal_com.c	/^GetU1ByteIntegerFromStringInDecimal($/;"	f
-GlobalDebugComponents	core/rtw_debug.c	/^	u64 GlobalDebugComponents = 0;$/;"	v
-H2CCMD_CUSTOMER_STR_W1_BYTE0	include/hal_com_h2c.h	282;"	d
-H2CCMD_CUSTOMER_STR_W2_BYTE6	include/hal_com_h2c.h	287;"	d
-H2CCMD_CUSTOMER_STR_W3_BYTE12	include/hal_com_h2c.h	292;"	d
-H2C_0X42_LENGTH	hal/phydm/phydm_rainfo.h	33;"	d
-H2C_8188F_ANT_SEL_RSV	include/rtl8188f_cmd.h	/^	H2C_8188F_ANT_SEL_RSV = 0x65,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_AOAC_GLOBAL_INFO	include/rtl8188f_cmd.h	/^	H2C_8188F_AOAC_GLOBAL_INFO = 0x82,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_AOAC_RSVD_PAGE	include/rtl8188f_cmd.h	/^	H2C_8188F_AOAC_RSVD_PAGE = 0x83,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_AOAC_RSVD_PAGE2	include/rtl8188f_cmd.h	/^	H2C_8188F_AOAC_RSVD_PAGE2 = 0x84,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_AP_OFFLOAD	include/rtl8188f_cmd.h	/^	H2C_8188F_AP_OFFLOAD = 0x08,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_AP_REQ_TXRPT	include/rtl8188f_cmd.h	/^	H2C_8188F_AP_REQ_TXRPT = 0x43,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_AP_WOW_GPIO_CTRL	include/rtl8188f_cmd.h	/^	H2C_8188F_AP_WOW_GPIO_CTRL = 0x13,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BCN_RSVDPAGE	include/rtl8188f_cmd.h	/^	H2C_8188F_BCN_RSVDPAGE = 0x09,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BT_CONTROL	include/rtl8188f_cmd.h	/^	H2C_8188F_BT_CONTROL = 0x68,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BT_FW_PATCH	include/rtl8188f_cmd.h	/^	H2C_8188F_BT_FW_PATCH = 0x6A,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BT_IGNORE_WLANACT	include/rtl8188f_cmd.h	/^	H2C_8188F_BT_IGNORE_WLANACT = 0x63,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BT_INFO	include/rtl8188f_cmd.h	/^	H2C_8188F_BT_INFO = 0x61,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BT_MP_OPER	include/rtl8188f_cmd.h	/^	H2C_8188F_BT_MP_OPER = 0x67,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BT_WIFI_CTRL	include/rtl8188f_cmd.h	/^	H2C_8188F_BT_WIFI_CTRL = 0x69,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_BT_WLAN_CALIBRATION	include/rtl8188f_cmd.h	/^	H2C_8188F_BT_WLAN_CALIBRATION = 0x6D,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_B_TYPE_TDMA	include/rtl8188f_cmd.h	/^	H2C_8188F_B_TYPE_TDMA = 0x60,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_CHNL_SWITCH_OFFLOAD	include/rtl8188f_cmd.h	/^	H2C_8188F_CHNL_SWITCH_OFFLOAD = 0x87,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_D0_SCAN_OFFLOAD_CTRL	include/rtl8188f_cmd.h	/^	H2C_8188F_D0_SCAN_OFFLOAD_CTRL = 0x85,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_D0_SCAN_OFFLOAD_INFO	include/rtl8188f_cmd.h	/^	H2C_8188F_D0_SCAN_OFFLOAD_INFO = 0x86,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_DAC_SWING_VALUE	include/rtl8188f_cmd.h	/^	H2C_8188F_DAC_SWING_VALUE = 0x64,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_DISCON_DECISION	include/rtl8188f_cmd.h	/^	H2C_8188F_DISCON_DECISION = 0x04,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_FCS_INFO	include/rtl8188f_cmd.h	/^	H2C_8188F_FCS_INFO = 0x11,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_FCS_RSVDPAGE	include/rtl8188f_cmd.h	/^	H2C_8188F_FCS_RSVDPAGE = 0x10,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_FORCE_BT_TXPWR	include/rtl8188f_cmd.h	/^	H2C_8188F_FORCE_BT_TXPWR = 0x62,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_FWLPS_IN_IPS_	include/rtl8188f_cmd.h	/^	H2C_8188F_FWLPS_IN_IPS_ = 0x28,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_INACTIVE_PS_	include/rtl8188f_cmd.h	/^	H2C_8188F_INACTIVE_PS_ = 0x27, \/* Inactive_PS *\/$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_INIT_RATE_COLLECT	include/rtl8188f_cmd.h	/^	H2C_8188F_INIT_RATE_COLLECT = 0x44,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_KEEP_ALIVE	include/rtl8188f_cmd.h	/^	H2C_8188F_KEEP_ALIVE = 0x03,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_MACID_CFG	include/rtl8188f_cmd.h	/^	H2C_8188F_MACID_CFG = 0x40,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_MAXID	include/rtl8188f_cmd.h	/^	H2C_8188F_MAXID,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_MEDIA_STATUS_RPT	include/rtl8188f_cmd.h	/^	H2C_8188F_MEDIA_STATUS_RPT = 0x01,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_P2P_LPS_PARAM	include/rtl8188f_cmd.h	/^	H2C_8188F_P2P_LPS_PARAM = 0x23,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_P2P_OFFLOAD	include/rtl8188f_cmd.h	/^	H2C_8188F_P2P_OFFLOAD = 0x8B,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_P2P_OFFLOAD_RSVD_PAGE	include/rtl8188f_cmd.h	/^	H2C_8188F_P2P_OFFLOAD_RSVD_PAGE = 0x8A,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_P2P_PS_OFFLOAD	include/rtl8188f_cmd.h	/^	H2C_8188F_P2P_PS_OFFLOAD = 0x24,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_PROBERSP_RSVDPAGE	include/rtl8188f_cmd.h	/^	H2C_8188F_PROBERSP_RSVDPAGE = 0x0A,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_PSD_OFFLOAD	include/rtl8188f_cmd.h	/^	H2C_8188F_PSD_OFFLOAD = 0x05,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_PS_SCAN_ENABLE	include/rtl8188f_cmd.h	/^	H2C_8188F_PS_SCAN_ENABLE = 0x25,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_PS_TUNING_PARA	include/rtl8188f_cmd.h	/^	H2C_8188F_PS_TUNING_PARA = 0x21,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_PS_TUNING_PARA2	include/rtl8188f_cmd.h	/^	H2C_8188F_PS_TUNING_PARA2 = 0x22,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_RA_PARA_ADJUST	include/rtl8188f_cmd.h	/^	H2C_8188F_RA_PARA_ADJUST = 0x46,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_REMOTE_WAKE_CTRL	include/rtl8188f_cmd.h	/^	H2C_8188F_REMOTE_WAKE_CTRL = 0x81,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_RESET_TSF	include/rtl8188f_cmd.h	/^	H2C_8188F_RESET_TSF = 0xC0,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_RSSI_SETTING	include/rtl8188f_cmd.h	/^	H2C_8188F_RSSI_SETTING = 0x42,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_RSVD_PAGE	include/rtl8188f_cmd.h	/^	H2C_8188F_RSVD_PAGE = 0x00,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_SAP_PS_	include/rtl8188f_cmd.h	/^	H2C_8188F_SAP_PS_ = 0x26,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_SCAN_ENABLE	include/rtl8188f_cmd.h	/^	H2C_8188F_SCAN_ENABLE = 0x02,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_SET_PWR_MODE	include/rtl8188f_cmd.h	/^	H2C_8188F_SET_PWR_MODE = 0x20,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_TXBF	include/rtl8188f_cmd.h	/^	H2C_8188F_TXBF = 0x41,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_WL_OPMODE	include/rtl8188f_cmd.h	/^	H2C_8188F_WL_OPMODE = 0x66,$/;"	e	enum:h2c_cmd_8188F
-H2C_8188F_WOWLAN	include/rtl8188f_cmd.h	/^	H2C_8188F_WOWLAN = 0x80,$/;"	e	enum:h2c_cmd_8188F
-H2C_8192E_AOAC_GLOBAL_INFO	include/rtl8192e_cmd.h	/^	H2C_8192E_AOAC_GLOBAL_INFO = 0x82,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_AOAC_RSVDPAGE	include/rtl8192e_cmd.h	/^	H2C_8192E_AOAC_RSVDPAGE = 0x83,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_AP_OFFLOAD	include/rtl8192e_cmd.h	/^	H2C_8192E_AP_OFFLOAD = 0x08,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_AP_WOW_GPIO_CTRL	include/rtl8192e_cmd.h	/^	H2C_8192E_AP_WOW_GPIO_CTRL = 0x13,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_BCN_RSVDPAGE	include/rtl8192e_cmd.h	/^	H2C_8192E_BCN_RSVDPAGE = 0x09,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_DISCONNECT_DECISION	include/rtl8192e_cmd.h	/^	H2C_8192E_DISCONNECT_DECISION = 0x04,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_INIT_OFFLOAD	include/rtl8192e_cmd.h	/^	H2C_8192E_INIT_OFFLOAD = 0x06,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_KEEP_ALIVE_CTRL	include/rtl8192e_cmd.h	/^	H2C_8192E_KEEP_ALIVE_CTRL = 0x03,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_MSRRPT	include/rtl8192e_cmd.h	/^	H2C_8192E_MSRRPT	= 0x01,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_P2P_PS_MODE	include/rtl8192e_cmd.h	/^	H2C_8192E_P2P_PS_MODE,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_P2P_PS_OFFLOAD	include/rtl8192e_cmd.h	/^	H2C_8192E_P2P_PS_OFFLOAD = 0x24,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_PROBERSP_RSVDPAGE	include/rtl8192e_cmd.h	/^	H2C_8192E_PROBERSP_RSVDPAGE = 0x0a,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_PSD_RESULT	include/rtl8192e_cmd.h	/^	H2C_8192E_PSD_RESULT,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_PS_LPS_PARA	include/rtl8192e_cmd.h	/^	H2C_8192E_PS_LPS_PARA = 0x23,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_PS_TUNING_PARA	include/rtl8192e_cmd.h	/^	H2C_8192E_PS_TUNING_PARA = 0x21,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_PS_TUNING_PARA2	include/rtl8192e_cmd.h	/^	H2C_8192E_PS_TUNING_PARA2 = 0x22,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_RA_MASK	include/rtl8192e_cmd.h	/^	H2C_8192E_RA_MASK = 0x40,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_RA_PARA_ADJUST	include/rtl8192e_cmd.h	/^	H2C_8192E_RA_PARA_ADJUST = 0x46,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_REMOTE_WAKE_CTRL	include/rtl8192e_cmd.h	/^	H2C_8192E_REMOTE_WAKE_CTRL = 0x81,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_RSSI_REPORT	include/rtl8192e_cmd.h	/^	H2C_8192E_RSSI_REPORT = 0x42,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_RSVDPAGE	include/rtl8192e_cmd.h	/^	H2C_8192E_RSVDPAGE	= 0x00,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_SAP_PS	include/rtl8192e_cmd.h	/^	H2C_8192E_SAP_PS = 0x26,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_SCAN	include/rtl8192e_cmd.h	/^	H2C_8192E_SCAN		= 0x02,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_SELECTIVE_SUSPEND_ROF_CMD	include/rtl8192e_cmd.h	/^	H2C_8192E_SELECTIVE_SUSPEND_ROF_CMD,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_SETPWRMODE	include/rtl8192e_cmd.h	/^	H2C_8192E_SETPWRMODE = 0x20,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8192E_WO_WLAN	include/rtl8192e_cmd.h	/^	H2C_8192E_WO_WLAN = 0x80,$/;"	e	enum:_RTL8192E_H2C_CMD
-H2C_8703B_ANT_SEL_RSV	include/rtl8703b_cmd.h	/^	H2C_8703B_ANT_SEL_RSV = 0x65,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_AOAC_GLOBAL_INFO	include/rtl8703b_cmd.h	/^	H2C_8703B_AOAC_GLOBAL_INFO = 0x82,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_AOAC_RSVD_PAGE	include/rtl8703b_cmd.h	/^	H2C_8703B_AOAC_RSVD_PAGE = 0x83,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_AOAC_RSVD_PAGE2	include/rtl8703b_cmd.h	/^	H2C_8703B_AOAC_RSVD_PAGE2 = 0x84,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_AP_OFFLOAD	include/rtl8703b_cmd.h	/^	H2C_8703B_AP_OFFLOAD = 0x08,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_AP_REQ_TXRPT	include/rtl8703b_cmd.h	/^	H2C_8703B_AP_REQ_TXRPT = 0x43,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_AP_WOW_GPIO_CTRL	include/rtl8703b_cmd.h	/^	H2C_8703B_AP_WOW_GPIO_CTRL = 0x13,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BCN_RSVDPAGE	include/rtl8703b_cmd.h	/^	H2C_8703B_BCN_RSVDPAGE = 0x09,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BT_CONTROL	include/rtl8703b_cmd.h	/^	H2C_8703B_BT_CONTROL = 0x68,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BT_FW_PATCH	include/rtl8703b_cmd.h	/^	H2C_8703B_BT_FW_PATCH = 0x6A,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BT_IGNORE_WLANACT	include/rtl8703b_cmd.h	/^	H2C_8703B_BT_IGNORE_WLANACT = 0x63,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BT_INFO	include/rtl8703b_cmd.h	/^	H2C_8703B_BT_INFO = 0x61,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BT_MP_OPER	include/rtl8703b_cmd.h	/^	H2C_8703B_BT_MP_OPER = 0x67,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BT_WIFI_CTRL	include/rtl8703b_cmd.h	/^	H2C_8703B_BT_WIFI_CTRL = 0x69,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_BT_WLAN_CALIBRATION	include/rtl8703b_cmd.h	/^	H2C_8703B_BT_WLAN_CALIBRATION = 0x6D,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_B_TYPE_TDMA	include/rtl8703b_cmd.h	/^	H2C_8703B_B_TYPE_TDMA = 0x60,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_CHNL_SWITCH_OFFLOAD	include/rtl8703b_cmd.h	/^	H2C_8703B_CHNL_SWITCH_OFFLOAD = 0x87,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_D0_SCAN_OFFLOAD_CTRL	include/rtl8703b_cmd.h	/^	H2C_8703B_D0_SCAN_OFFLOAD_CTRL = 0x85,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_D0_SCAN_OFFLOAD_INFO	include/rtl8703b_cmd.h	/^	H2C_8703B_D0_SCAN_OFFLOAD_INFO = 0x86,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_DAC_SWING_VALUE	include/rtl8703b_cmd.h	/^	H2C_8703B_DAC_SWING_VALUE = 0x64,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_DISCON_DECISION	include/rtl8703b_cmd.h	/^	H2C_8703B_DISCON_DECISION = 0x04,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_FCS_INFO	include/rtl8703b_cmd.h	/^	H2C_8703B_FCS_INFO = 0x11,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_FCS_RSVDPAGE	include/rtl8703b_cmd.h	/^	H2C_8703B_FCS_RSVDPAGE = 0x10,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_FORCE_BT_TXPWR	include/rtl8703b_cmd.h	/^	H2C_8703B_FORCE_BT_TXPWR = 0x62,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_FWLPS_IN_IPS_	include/rtl8703b_cmd.h	/^	H2C_8703B_FWLPS_IN_IPS_ = 0x28,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_INACTIVE_PS_	include/rtl8703b_cmd.h	/^	H2C_8703B_INACTIVE_PS_ = 0x27, \/* Inactive_PS *\/$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_INIT_RATE_COLLECT	include/rtl8703b_cmd.h	/^	H2C_8703B_INIT_RATE_COLLECT = 0x44,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_KEEP_ALIVE	include/rtl8703b_cmd.h	/^	H2C_8703B_KEEP_ALIVE = 0x03,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_MACID_CFG	include/rtl8703b_cmd.h	/^	H2C_8703B_MACID_CFG = 0x40,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_MAXID	include/rtl8703b_cmd.h	/^	H2C_8703B_MAXID,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_MEDIA_STATUS_RPT	include/rtl8703b_cmd.h	/^	H2C_8703B_MEDIA_STATUS_RPT = 0x01,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_P2P_LPS_PARAM	include/rtl8703b_cmd.h	/^	H2C_8703B_P2P_LPS_PARAM = 0x23,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_P2P_OFFLOAD	include/rtl8703b_cmd.h	/^	H2C_8703B_P2P_OFFLOAD = 0x8B,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_P2P_OFFLOAD_RSVD_PAGE	include/rtl8703b_cmd.h	/^	H2C_8703B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_P2P_PS_OFFLOAD	include/rtl8703b_cmd.h	/^	H2C_8703B_P2P_PS_OFFLOAD = 0x24,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_PROBERSP_RSVDPAGE	include/rtl8703b_cmd.h	/^	H2C_8703B_PROBERSP_RSVDPAGE = 0x0A,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_PSD_OFFLOAD	include/rtl8703b_cmd.h	/^	H2C_8703B_PSD_OFFLOAD = 0x05,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_PS_SCAN_ENABLE	include/rtl8703b_cmd.h	/^	H2C_8703B_PS_SCAN_ENABLE = 0x25,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_PS_TUNING_PARA	include/rtl8703b_cmd.h	/^	H2C_8703B_PS_TUNING_PARA = 0x21,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_PS_TUNING_PARA2	include/rtl8703b_cmd.h	/^	H2C_8703B_PS_TUNING_PARA2 = 0x22,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_RA_PARA_ADJUST	include/rtl8703b_cmd.h	/^	H2C_8703B_RA_PARA_ADJUST = 0x46,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_REMOTE_WAKE_CTRL	include/rtl8703b_cmd.h	/^	H2C_8703B_REMOTE_WAKE_CTRL = 0x81,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_RESET_TSF	include/rtl8703b_cmd.h	/^	H2C_8703B_RESET_TSF = 0xC0,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_RSSI_SETTING	include/rtl8703b_cmd.h	/^	H2C_8703B_RSSI_SETTING = 0x42,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_RSVD_PAGE	include/rtl8703b_cmd.h	/^	H2C_8703B_RSVD_PAGE = 0x00,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_SAP_PS_	include/rtl8703b_cmd.h	/^	H2C_8703B_SAP_PS_ = 0x26,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_SCAN_ENABLE	include/rtl8703b_cmd.h	/^	H2C_8703B_SCAN_ENABLE = 0x02,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_SET_PWR_MODE	include/rtl8703b_cmd.h	/^	H2C_8703B_SET_PWR_MODE = 0x20,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_TXBF	include/rtl8703b_cmd.h	/^	H2C_8703B_TXBF = 0x41,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_WL_OPMODE	include/rtl8703b_cmd.h	/^	H2C_8703B_WL_OPMODE = 0x66,$/;"	e	enum:h2c_cmd_8703B
-H2C_8703B_WOWLAN	include/rtl8703b_cmd.h	/^	H2C_8703B_WOWLAN = 0x80,$/;"	e	enum:h2c_cmd_8703B
-H2C_8723B_ANT_SEL_RSV	include/rtl8723b_cmd.h	/^	H2C_8723B_ANT_SEL_RSV = 0x65,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_AOAC_GLOBAL_INFO	include/rtl8723b_cmd.h	/^	H2C_8723B_AOAC_GLOBAL_INFO = 0x82,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_AOAC_RSVD_PAGE	include/rtl8723b_cmd.h	/^	H2C_8723B_AOAC_RSVD_PAGE = 0x83,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_AOAC_RSVD_PAGE2	include/rtl8723b_cmd.h	/^	H2C_8723B_AOAC_RSVD_PAGE2 = 0x84,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_AP_OFFLOAD	include/rtl8723b_cmd.h	/^	H2C_8723B_AP_OFFLOAD = 0x08,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_AP_REQ_TXRPT	include/rtl8723b_cmd.h	/^	H2C_8723B_AP_REQ_TXRPT = 0x43,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_AP_WOW_GPIO_CTRL	include/rtl8723b_cmd.h	/^	H2C_8723B_AP_WOW_GPIO_CTRL = 0x13,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BCN_RSVDPAGE	include/rtl8723b_cmd.h	/^	H2C_8723B_BCN_RSVDPAGE = 0x09,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BT_CONTROL	include/rtl8723b_cmd.h	/^	H2C_8723B_BT_CONTROL = 0x68,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BT_FW_PATCH	include/rtl8723b_cmd.h	/^	H2C_8723B_BT_FW_PATCH = 0x6A,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BT_IGNORE_WLANACT	include/rtl8723b_cmd.h	/^	H2C_8723B_BT_IGNORE_WLANACT = 0x63,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BT_INFO	include/rtl8723b_cmd.h	/^	H2C_8723B_BT_INFO = 0x61,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BT_MP_OPER	include/rtl8723b_cmd.h	/^	H2C_8723B_BT_MP_OPER = 0x67,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BT_WIFI_CTRL	include/rtl8723b_cmd.h	/^	H2C_8723B_BT_WIFI_CTRL = 0x69,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_BT_WLAN_CALIBRATION	include/rtl8723b_cmd.h	/^	H2C_8723B_BT_WLAN_CALIBRATION = 0x6D,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_B_TYPE_TDMA	include/rtl8723b_cmd.h	/^	H2C_8723B_B_TYPE_TDMA = 0x60,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_CHNL_SWITCH_OFFLOAD	include/rtl8723b_cmd.h	/^	H2C_8723B_CHNL_SWITCH_OFFLOAD = 0x87,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_D0_SCAN_OFFLOAD_CTRL	include/rtl8723b_cmd.h	/^	H2C_8723B_D0_SCAN_OFFLOAD_CTRL = 0x85,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_D0_SCAN_OFFLOAD_INFO	include/rtl8723b_cmd.h	/^	H2C_8723B_D0_SCAN_OFFLOAD_INFO = 0x86,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_DAC_SWING_VALUE	include/rtl8723b_cmd.h	/^	H2C_8723B_DAC_SWING_VALUE = 0x64,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_DISCON_DECISION	include/rtl8723b_cmd.h	/^	H2C_8723B_DISCON_DECISION = 0x04,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_FCS_INFO	include/rtl8723b_cmd.h	/^	H2C_8723B_FCS_INFO = 0x11,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_FCS_RSVDPAGE	include/rtl8723b_cmd.h	/^	H2C_8723B_FCS_RSVDPAGE = 0x10,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_FORCE_BT_TXPWR	include/rtl8723b_cmd.h	/^	H2C_8723B_FORCE_BT_TXPWR = 0x62,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_FWLPS_IN_IPS_	include/rtl8723b_cmd.h	/^	H2C_8723B_FWLPS_IN_IPS_ = 0x28,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_INACTIVE_PS_	include/rtl8723b_cmd.h	/^	H2C_8723B_INACTIVE_PS_ = 0x27, \/* Inactive_PS *\/$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_INIT_RATE_COLLECT	include/rtl8723b_cmd.h	/^	H2C_8723B_INIT_RATE_COLLECT = 0x44,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_KEEP_ALIVE	include/rtl8723b_cmd.h	/^	H2C_8723B_KEEP_ALIVE = 0x03,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_MACID_CFG	include/rtl8723b_cmd.h	/^	H2C_8723B_MACID_CFG = 0x40,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_MAXID	include/rtl8723b_cmd.h	/^	H2C_8723B_MAXID,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_MEDIA_STATUS_RPT	include/rtl8723b_cmd.h	/^	H2C_8723B_MEDIA_STATUS_RPT = 0x01,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_P2P_LPS_PARAM	include/rtl8723b_cmd.h	/^	H2C_8723B_P2P_LPS_PARAM = 0x23,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_P2P_OFFLOAD	include/rtl8723b_cmd.h	/^	H2C_8723B_P2P_OFFLOAD = 0x8B,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_P2P_OFFLOAD_RSVD_PAGE	include/rtl8723b_cmd.h	/^	H2C_8723B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_P2P_PS_OFFLOAD	include/rtl8723b_cmd.h	/^	H2C_8723B_P2P_PS_OFFLOAD = 0x24,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_PROBERSP_RSVDPAGE	include/rtl8723b_cmd.h	/^	H2C_8723B_PROBERSP_RSVDPAGE = 0x0A,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_PSD_OFFLOAD	include/rtl8723b_cmd.h	/^	H2C_8723B_PSD_OFFLOAD = 0x05,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_PS_SCAN_ENABLE	include/rtl8723b_cmd.h	/^	H2C_8723B_PS_SCAN_ENABLE = 0x25,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_PS_TUNING_PARA	include/rtl8723b_cmd.h	/^	H2C_8723B_PS_TUNING_PARA = 0x21,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_PS_TUNING_PARA2	include/rtl8723b_cmd.h	/^	H2C_8723B_PS_TUNING_PARA2 = 0x22,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_RA_PARA_ADJUST	include/rtl8723b_cmd.h	/^	H2C_8723B_RA_PARA_ADJUST = 0x46,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_REMOTE_WAKE_CTRL	include/rtl8723b_cmd.h	/^	H2C_8723B_REMOTE_WAKE_CTRL = 0x81,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_RESET_TSF	include/rtl8723b_cmd.h	/^	H2C_8723B_RESET_TSF = 0xC0,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_RSSI_SETTING	include/rtl8723b_cmd.h	/^	H2C_8723B_RSSI_SETTING = 0x42,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_RSVD_PAGE	include/rtl8723b_cmd.h	/^	H2C_8723B_RSVD_PAGE = 0x00,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_SAP_PS_	include/rtl8723b_cmd.h	/^	H2C_8723B_SAP_PS_ = 0x26,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_SCAN_ENABLE	include/rtl8723b_cmd.h	/^	H2C_8723B_SCAN_ENABLE = 0x02,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_SET_PWR_MODE	include/rtl8723b_cmd.h	/^	H2C_8723B_SET_PWR_MODE = 0x20,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_TXBF	include/rtl8723b_cmd.h	/^	H2C_8723B_TXBF = 0x41,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_WL_OPMODE	include/rtl8723b_cmd.h	/^	H2C_8723B_WL_OPMODE = 0x66,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723B_WOWLAN	include/rtl8723b_cmd.h	/^	H2C_8723B_WOWLAN = 0x80,$/;"	e	enum:h2c_cmd_8723B
-H2C_8723D_ANT_SEL_RSV	include/rtl8723d_cmd.h	/^	H2C_8723D_ANT_SEL_RSV = 0x65,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_AOAC_GLOBAL_INFO	include/rtl8723d_cmd.h	/^	H2C_8723D_AOAC_GLOBAL_INFO = 0x82,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_AOAC_RSVD_PAGE	include/rtl8723d_cmd.h	/^	H2C_8723D_AOAC_RSVD_PAGE = 0x83,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_AOAC_RSVD_PAGE2	include/rtl8723d_cmd.h	/^	H2C_8723D_AOAC_RSVD_PAGE2 = 0x84,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_AP_OFFLOAD	include/rtl8723d_cmd.h	/^	H2C_8723D_AP_OFFLOAD = 0x08,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_AP_REQ_TXRPT	include/rtl8723d_cmd.h	/^	H2C_8723D_AP_REQ_TXRPT = 0x43,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_AP_WOW_GPIO_CTRL	include/rtl8723d_cmd.h	/^	H2C_8723D_AP_WOW_GPIO_CTRL = 0x13,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BCN_RSVDPAGE	include/rtl8723d_cmd.h	/^	H2C_8723D_BCN_RSVDPAGE = 0x09,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BT_CONTROL	include/rtl8723d_cmd.h	/^	H2C_8723D_BT_CONTROL = 0x68,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BT_FW_PATCH	include/rtl8723d_cmd.h	/^	H2C_8723D_BT_FW_PATCH = 0x6A,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BT_IGNORE_WLANACT	include/rtl8723d_cmd.h	/^	H2C_8723D_BT_IGNORE_WLANACT = 0x63,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BT_INFO	include/rtl8723d_cmd.h	/^	H2C_8723D_BT_INFO = 0x61,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BT_MP_OPER	include/rtl8723d_cmd.h	/^	H2C_8723D_BT_MP_OPER = 0x67,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BT_WIFI_CTRL	include/rtl8723d_cmd.h	/^	H2C_8723D_BT_WIFI_CTRL = 0x69,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_BT_WLAN_CALIBRATION	include/rtl8723d_cmd.h	/^	H2C_8723D_BT_WLAN_CALIBRATION = 0x6D,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_B_TYPE_TDMA	include/rtl8723d_cmd.h	/^	H2C_8723D_B_TYPE_TDMA = 0x60,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_CHNL_SWITCH_OFFLOAD	include/rtl8723d_cmd.h	/^	H2C_8723D_CHNL_SWITCH_OFFLOAD = 0x87,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_D0_SCAN_OFFLOAD_CTRL	include/rtl8723d_cmd.h	/^	H2C_8723D_D0_SCAN_OFFLOAD_CTRL = 0x85,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_D0_SCAN_OFFLOAD_INFO	include/rtl8723d_cmd.h	/^	H2C_8723D_D0_SCAN_OFFLOAD_INFO = 0x86,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_DAC_SWING_VALUE	include/rtl8723d_cmd.h	/^	H2C_8723D_DAC_SWING_VALUE = 0x64,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_DISCON_DECISION	include/rtl8723d_cmd.h	/^	H2C_8723D_DISCON_DECISION = 0x04,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_FCS_INFO	include/rtl8723d_cmd.h	/^	H2C_8723D_FCS_INFO = 0x11,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_FCS_RSVDPAGE	include/rtl8723d_cmd.h	/^	H2C_8723D_FCS_RSVDPAGE = 0x10,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_FORCE_BT_TXPWR	include/rtl8723d_cmd.h	/^	H2C_8723D_FORCE_BT_TXPWR = 0x62,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_FWLPS_IN_IPS_	include/rtl8723d_cmd.h	/^	H2C_8723D_FWLPS_IN_IPS_ = 0x28,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_INACTIVE_PS_	include/rtl8723d_cmd.h	/^	H2C_8723D_INACTIVE_PS_ = 0x27, \/* Inactive_PS *\/$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_INIT_RATE_COLLECT	include/rtl8723d_cmd.h	/^	H2C_8723D_INIT_RATE_COLLECT = 0x44,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_KEEP_ALIVE	include/rtl8723d_cmd.h	/^	H2C_8723D_KEEP_ALIVE = 0x03,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_MACID_CFG	include/rtl8723d_cmd.h	/^	H2C_8723D_MACID_CFG = 0x40,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_MAXID	include/rtl8723d_cmd.h	/^	H2C_8723D_MAXID,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_MEDIA_STATUS_RPT	include/rtl8723d_cmd.h	/^	H2C_8723D_MEDIA_STATUS_RPT = 0x01,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_P2P_LPS_PARAM	include/rtl8723d_cmd.h	/^	H2C_8723D_P2P_LPS_PARAM = 0x23,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_P2P_OFFLOAD	include/rtl8723d_cmd.h	/^	H2C_8723D_P2P_OFFLOAD = 0x8B,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_P2P_OFFLOAD_RSVD_PAGE	include/rtl8723d_cmd.h	/^	H2C_8723D_P2P_OFFLOAD_RSVD_PAGE = 0x8A,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_P2P_PS_OFFLOAD	include/rtl8723d_cmd.h	/^	H2C_8723D_P2P_PS_OFFLOAD = 0x24,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_PROBERSP_RSVDPAGE	include/rtl8723d_cmd.h	/^	H2C_8723D_PROBERSP_RSVDPAGE = 0x0A,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_PSD_OFFLOAD	include/rtl8723d_cmd.h	/^	H2C_8723D_PSD_OFFLOAD = 0x05,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_PS_SCAN_ENABLE	include/rtl8723d_cmd.h	/^	H2C_8723D_PS_SCAN_ENABLE = 0x25,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_PS_TUNING_PARA	include/rtl8723d_cmd.h	/^	H2C_8723D_PS_TUNING_PARA = 0x21,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_PS_TUNING_PARA2	include/rtl8723d_cmd.h	/^	H2C_8723D_PS_TUNING_PARA2 = 0x22,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_RA_PARA_ADJUST	include/rtl8723d_cmd.h	/^	H2C_8723D_RA_PARA_ADJUST = 0x46,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_REMOTE_WAKE_CTRL	include/rtl8723d_cmd.h	/^	H2C_8723D_REMOTE_WAKE_CTRL = 0x81,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_RESET_TSF	include/rtl8723d_cmd.h	/^	H2C_8723D_RESET_TSF = 0xC0,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_RSSI_SETTING	include/rtl8723d_cmd.h	/^	H2C_8723D_RSSI_SETTING = 0x42,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_RSVD_PAGE	include/rtl8723d_cmd.h	/^	H2C_8723D_RSVD_PAGE = 0x00,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_SAP_PS_	include/rtl8723d_cmd.h	/^	H2C_8723D_SAP_PS_ = 0x26,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_SCAN_ENABLE	include/rtl8723d_cmd.h	/^	H2C_8723D_SCAN_ENABLE = 0x02,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_SET_PWR_MODE	include/rtl8723d_cmd.h	/^	H2C_8723D_SET_PWR_MODE = 0x20,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_TXBF	include/rtl8723d_cmd.h	/^	H2C_8723D_TXBF = 0x41,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_WL_OPMODE	include/rtl8723d_cmd.h	/^	H2C_8723D_WL_OPMODE = 0x66,$/;"	e	enum:h2c_cmd_8723D
-H2C_8723D_WOWLAN	include/rtl8723d_cmd.h	/^	H2C_8723D_WOWLAN = 0x80,$/;"	e	enum:h2c_cmd_8723D
-H2C_8812_AOAC_GLOBAL_INFO	include/rtl8812a_cmd.h	/^	H2C_8812_AOAC_GLOBAL_INFO = 0x82,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_AOAC_RSVDPAGE	include/rtl8812a_cmd.h	/^	H2C_8812_AOAC_RSVDPAGE = 0x83,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_AP_OFFLOAD	include/rtl8812a_cmd.h	/^	H2C_8812_AP_OFFLOAD = 8,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_BCN_RSVDPAGE	include/rtl8812a_cmd.h	/^	H2C_8812_BCN_RSVDPAGE = 9,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_BT_FW_PATCH	include/rtl8812a_cmd.h	/^	H2C_8812_BT_FW_PATCH = 0x6a,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_DISCONNECT_DECISION	include/rtl8812a_cmd.h	/^	H2C_8812_DISCONNECT_DECISION = 4,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_FW_SWCHANNL	include/rtl8812a_cmd.h	/^	H2C_8812_FW_SWCHANNL = 0x87,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_INACTIVE_PS	include/rtl8812a_cmd.h	/^	H2C_8812_INACTIVE_PS = 0x27,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_INIT_OFFLOAD	include/rtl8812a_cmd.h	/^	H2C_8812_INIT_OFFLOAD = 6,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_IQ_CALIBRATION	include/rtl8812a_cmd.h	/^	H2C_8812_IQ_CALIBRATION = 0x45,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_KEEP_ALIVE_CTRL	include/rtl8812a_cmd.h	/^	H2C_8812_KEEP_ALIVE_CTRL = 3,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_MSRRPT	include/rtl8812a_cmd.h	/^	H2C_8812_MSRRPT = 1,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_P2P_PS_OFFLOAD	include/rtl8812a_cmd.h	/^	H2C_8812_P2P_PS_OFFLOAD = 0x24,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_PROBERSP_RSVDPAGE	include/rtl8812a_cmd.h	/^	H2C_8812_PROBERSP_RSVDPAGE = 10,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_PS_LPS_PARA	include/rtl8812a_cmd.h	/^	H2C_8812_PS_LPS_PARA = 0x23,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_PS_TUNING_PARA	include/rtl8812a_cmd.h	/^	H2C_8812_PS_TUNING_PARA = 0x21,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_PS_TUNING_PARA2	include/rtl8812a_cmd.h	/^	H2C_8812_PS_TUNING_PARA2 = 0x22,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_RA_MASK	include/rtl8812a_cmd.h	/^	H2C_8812_RA_MASK = 0x40,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_RA_PARA_ADJUST	include/rtl8812a_cmd.h	/^	H2C_8812_RA_PARA_ADJUST = 0x46,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_REMOTE_WAKE_CTRL	include/rtl8812a_cmd.h	/^	H2C_8812_REMOTE_WAKE_CTRL = 0x81,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_RSSI_REPORT	include/rtl8812a_cmd.h	/^	H2C_8812_RSSI_REPORT = 0x42,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_RSVDPAGE	include/rtl8812a_cmd.h	/^	H2C_8812_RSVDPAGE = 0,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_SCAN	include/rtl8812a_cmd.h	/^	H2C_8812_SCAN = 2,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_SETPWRMODE	include/rtl8812a_cmd.h	/^	H2C_8812_SETPWRMODE = 0x20,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_TSF_RESET	include/rtl8812a_cmd.h	/^	H2C_8812_TSF_RESET = 0xC0,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_TxBF	include/rtl8812a_cmd.h	/^	H2C_8812_TxBF = 0x41,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_8812_WO_WLAN	include/rtl8812a_cmd.h	/^	H2C_8812_WO_WLAN = 0x80,$/;"	e	enum:_RTL8812_H2C_CMD
-H2C_ANT_SEL_RSV	include/hal_com_h2c.h	/^	H2C_ANT_SEL_RSV = 0x65,$/;"	e	enum:h2c_cmd
-H2C_AOAC_GLOBAL_INFO	include/hal_com_h2c.h	/^	H2C_AOAC_GLOBAL_INFO = 0x82,$/;"	e	enum:h2c_cmd
-H2C_AOAC_GLOBAL_INFO_LEN	include/hal_com_h2c.h	130;"	d
-H2C_AOAC_RSVDPAGE3	include/hal_com_h2c.h	/^	H2C_AOAC_RSVDPAGE3 = 0x88,$/;"	e	enum:h2c_cmd
-H2C_AOAC_RSVDPAGE_LOC_LEN	include/hal_com_h2c.h	131;"	d
-H2C_AOAC_RSVD_PAGE	include/hal_com_h2c.h	/^	H2C_AOAC_RSVD_PAGE = 0x83,$/;"	e	enum:h2c_cmd
-H2C_AOAC_RSVD_PAGE2	include/hal_com_h2c.h	/^	H2C_AOAC_RSVD_PAGE2 = 0x84,$/;"	e	enum:h2c_cmd
-H2C_AP_OFFLOAD	include/hal_com_h2c.h	/^	H2C_AP_OFFLOAD = 0x08,$/;"	e	enum:h2c_cmd
-H2C_AP_OFFLOAD_LEN	include/hal_com_h2c.h	121;"	d
-H2C_AP_PS_LEN	include/hal_com_h2c.h	123;"	d
-H2C_AP_REQ_TXRPT	include/hal_com_h2c.h	/^	H2C_AP_REQ_TXRPT = 0x43,$/;"	e	enum:h2c_cmd
-H2C_AP_REQ_TXRPT_LEN	include/hal_com_h2c.h	135;"	d
-H2C_AP_WOW_GPIO_CTRL	include/hal_com_h2c.h	/^	H2C_AP_WOW_GPIO_CTRL = 0x13,$/;"	e	enum:h2c_cmd
-H2C_AP_WOW_GPIO_CTRL_LEN	include/hal_com_h2c.h	122;"	d
-H2C_BCNHWSEQ	include/hal_com_h2c.h	/^	H2C_BCNHWSEQ = 0xC5,$/;"	e	enum:h2c_cmd
-H2C_BCN_RSVDPAGE	include/hal_com_h2c.h	/^	H2C_BCN_RSVDPAGE = 0x09,$/;"	e	enum:h2c_cmd
-H2C_BCN_RSVDPAGE_LEN	include/hal_com_h2c.h	137;"	d
-H2C_BTMP_OPER_LEN	include/hal_com_h2c.h	127;"	d
-H2C_BT_COEX_GPIO_MODE	include/rtl8188e_cmd.h	/^	H2C_BT_COEX_GPIO_MODE		= 0x61,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_BT_COEX_MASK	include/rtl8188e_cmd.h	/^	H2C_BT_COEX_MASK				= 0x60,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_BT_CONTROL	include/hal_com_h2c.h	/^	H2C_BT_CONTROL = 0x68,$/;"	e	enum:h2c_cmd
-H2C_BT_DAC_SWING_VAL	include/rtl8188e_cmd.h	/^	H2C_BT_DAC_SWING_VAL			= 0x62,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_BT_FW_PATCH	include/hal_com_h2c.h	/^	H2C_BT_FW_PATCH = 0x6A,$/;"	e	enum:h2c_cmd
-H2C_BT_FW_PATCH_LEN	include/hal_com_h2c.h	133;"	d
-H2C_BT_IGNORE_WLANACT	include/hal_com_h2c.h	/^	H2C_BT_IGNORE_WLANACT = 0x63,$/;"	e	enum:h2c_cmd
-H2C_BT_INFO	include/hal_com_h2c.h	/^	H2C_BT_INFO = 0x61,$/;"	e	enum:h2c_cmd
-H2C_BT_MP_OPER	include/hal_com_h2c.h	/^	H2C_BT_MP_OPER = 0x67,$/;"	e	enum:h2c_cmd
-H2C_BT_PSD_RST	include/rtl8188e_cmd.h	/^	H2C_BT_PSD_RST				= 0x63,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_BT_WIFI_CTRL	include/hal_com_h2c.h	/^	H2C_BT_WIFI_CTRL = 0x69,$/;"	e	enum:h2c_cmd
-H2C_B_TYPE_TDMA	include/hal_com_h2c.h	/^	H2C_B_TYPE_TDMA = 0x60,$/;"	e	enum:h2c_cmd
-H2C_CHNL_SWITCH_OFFLOAD	include/hal_com_h2c.h	/^	H2C_CHNL_SWITCH_OFFLOAD = 0x87,$/;"	e	enum:h2c_cmd
-H2C_CHNL_SWITCH_OPER_OFFLOAD	include/hal_com_h2c.h	/^	H2C_CHNL_SWITCH_OPER_OFFLOAD = 0x1C,$/;"	e	enum:h2c_cmd
-H2C_CMD_OVERFLOW	include/rtw_cmd.h	1011;"	d
-H2C_COM_AOAC_GLOBAL_INFO	include/rtl8188e_cmd.h	/^	H2C_COM_AOAC_GLOBAL_INFO	= 0x82,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_AOAC_RSVD_PAGE	include/rtl8188e_cmd.h	/^	H2C_COM_AOAC_RSVD_PAGE		= 0x83,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_AP_OFFLOAD	include/rtl8188e_cmd.h	/^	H2C_COM_AP_OFFLOAD			= 0x08,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_BCN_RSVD_PAGE	include/rtl8188e_cmd.h	/^	H2C_COM_BCN_RSVD_PAGE		= 0x09,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_DISCNT_DECISION	include/rtl8188e_cmd.h	/^	H2C_COM_DISCNT_DECISION		= 0x04,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_INIT_OFFLOAD	include/rtl8188e_cmd.h	/^	H2C_COM_INIT_OFFLOAD			= 0x06,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_KEEP_ALIVE	include/rtl8188e_cmd.h	/^	H2C_COM_KEEP_ALIVE			= 0x03,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_MEDIA_STATUS_RPT	include/rtl8188e_cmd.h	/^	H2C_COM_MEDIA_STATUS_RPT	= 0x01,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_PROB_RSP_RSVD_PAGE	include/rtl8188e_cmd.h	/^	H2C_COM_PROB_RSP_RSVD_PAGE	= 0x0A,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_REMOTE_WAKE_CTL	include/rtl8188e_cmd.h	/^	H2C_COM_REMOTE_WAKE_CTL	= 0x07,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_REMOTE_WAKE_CTRL	include/rtl8188e_cmd.h	/^	H2C_COM_REMOTE_WAKE_CTRL	= 0x81,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_RSVD_PAGE	include/rtl8188e_cmd.h	/^	H2C_COM_RSVD_PAGE			= 0x00,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_SCAN	include/rtl8188e_cmd.h	/^	H2C_COM_SCAN					= 0x02,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_WWLAN	include/rtl8188e_cmd.h	/^	H2C_COM_WWLAN				= 0x05,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_COM_WWLAN	include/rtl8188e_cmd.h	/^	H2C_COM_WWLAN				= 0x80,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_CUSTOMER_STR_REQ	include/hal_com_h2c.h	/^	H2C_CUSTOMER_STR_REQ = 0x06,$/;"	e	enum:h2c_cmd
-H2C_CUSTOMER_STR_REQ_LEN	include/hal_com_h2c.h	274;"	d
-H2C_CUSTOMER_STR_W1	include/hal_com_h2c.h	/^	H2C_CUSTOMER_STR_W1 = 0xC6,$/;"	e	enum:h2c_cmd
-H2C_CUSTOMER_STR_W1_LEN	include/hal_com_h2c.h	280;"	d
-H2C_CUSTOMER_STR_W2	include/hal_com_h2c.h	/^	H2C_CUSTOMER_STR_W2 = 0xC7,$/;"	e	enum:h2c_cmd
-H2C_CUSTOMER_STR_W2_LEN	include/hal_com_h2c.h	285;"	d
-H2C_CUSTOMER_STR_W3	include/hal_com_h2c.h	/^	H2C_CUSTOMER_STR_W3 = 0xC8,$/;"	e	enum:h2c_cmd
-H2C_CUSTOMER_STR_W3_LEN	include/hal_com_h2c.h	290;"	d
-H2C_D0_SCAN_OFFLOAD_CTRL	include/hal_com_h2c.h	/^	H2C_D0_SCAN_OFFLOAD_CTRL = 0x85,$/;"	e	enum:h2c_cmd
-H2C_D0_SCAN_OFFLOAD_INFO	include/hal_com_h2c.h	/^	H2C_D0_SCAN_OFFLOAD_INFO = 0x86,$/;"	e	enum:h2c_cmd
-H2C_DAC_SWING_VALUE	include/hal_com_h2c.h	/^	H2C_DAC_SWING_VALUE = 0x64,$/;"	e	enum:h2c_cmd
-H2C_DISCON_DECISION	include/hal_com_h2c.h	/^	H2C_DISCON_DECISION = 0x04,$/;"	e	enum:h2c_cmd
-H2C_DISCON_DECISION_LEN	include/hal_com_h2c.h	120;"	d
-H2C_DM_MACID_CFG	include/rtl8188e_cmd.h	/^	H2C_DM_MACID_CFG				= 0x40,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_DM_TXBF	include/rtl8188e_cmd.h	/^	H2C_DM_TXBF					= 0x41,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_DROPPED	include/rtw_cmd.h	1008;"	d
-H2C_DUPLICATED	include/rtw_cmd.h	1007;"	d
-H2C_DYNAMIC_TX_PATH	include/hal_com_h2c.h	/^	H2C_DYNAMIC_TX_PATH = 0x48,\/* for 8814A *\/$/;"	e	enum:h2c_cmd
-H2C_ENQ_HEAD	include/rtw_cmd.h	1013;"	d
-H2C_ENQ_HEAD_FAIL	include/rtw_cmd.h	1014;"	d
-H2C_FCS_INFO	include/hal_com_h2c.h	/^	H2C_FCS_INFO = 0x11,$/;"	e	enum:h2c_cmd
-H2C_FCS_RSVDPAGE	include/hal_com_h2c.h	/^	H2C_FCS_RSVDPAGE = 0x10,$/;"	e	enum:h2c_cmd
-H2C_FORCE_BT_TXPWR	include/hal_com_h2c.h	/^	H2C_FORCE_BT_TXPWR = 0x62,$/;"	e	enum:h2c_cmd
-H2C_FORCE_BT_TXPWR_LEN	include/hal_com_h2c.h	136;"	d
-H2C_FWLPS_IN_IPS_	include/hal_com_h2c.h	/^	H2C_FWLPS_IN_IPS_ = 0x28,$/;"	e	enum:h2c_cmd
-H2C_FW_TRACE_EN	include/hal_com_h2c.h	/^	H2C_FW_TRACE_EN = 0x49,$/;"	e	enum:h2c_cmd
-H2C_INACTIVE_PS_	include/hal_com_h2c.h	/^	H2C_INACTIVE_PS_ = 0x27, \/* Inactive_PS *\/$/;"	e	enum:h2c_cmd
-H2C_INACTIVE_PS_LEN	include/hal_com_h2c.h	141;"	d
-H2C_INIT_RATE_COLLECT	include/hal_com_h2c.h	/^	H2C_INIT_RATE_COLLECT = 0x44,$/;"	e	enum:h2c_cmd
-H2C_IQ_CALIBRATION	include/hal_com_h2c.h	/^	H2C_IQ_CALIBRATION	= 0x45,$/;"	e	enum:h2c_cmd
-H2C_KEEP_ALIVE	include/hal_com_h2c.h	/^	H2C_KEEP_ALIVE = 0x03,$/;"	e	enum:h2c_cmd
-H2C_KEEP_ALIVE_CTRL_LEN	include/hal_com_h2c.h	119;"	d
-H2C_LPSPG_LEN	include/hal_com_h2c.h	152;"	d
-H2C_LPS_PG_INFO	include/hal_com_h2c.h	/^	H2C_LPS_PG_INFO = 0x2B,$/;"	e	enum:h2c_cmd
-H2C_LPS_PG_INFO_LEN	include/hal_com_h2c.h	151;"	d
-H2C_LPS_POFF_CTRL	include/hal_com_h2c.h	/^	H2C_LPS_POFF_CTRL = 0x29,$/;"	e	enum:h2c_cmd
-H2C_LPS_POFF_CTRL_LEN	include/hal_com_h2c.h	155;"	d
-H2C_LPS_POFF_PARAM	include/hal_com_h2c.h	/^	H2C_LPS_POFF_PARAM = 0x2A,$/;"	e	enum:h2c_cmd
-H2C_LPS_POFF_PARAM_LEN	include/hal_com_h2c.h	156;"	d
-H2C_MACID_CFG	include/hal_com_h2c.h	/^	H2C_MACID_CFG = 0x40,$/;"	e	enum:h2c_cmd
-H2C_MACID_CFG_LEN	include/hal_com_h2c.h	126;"	d
-H2C_MAXID	include/hal_com_h2c.h	/^	H2C_MAXID,$/;"	e	enum:h2c_cmd
-H2C_MAX_LENGTH	hal/phydm/phydm_rainfo.h	34;"	d
-H2C_MCC_INFO	include/hal_com_h2c.h	/^	H2C_MCC_INFO = 0x18,$/;"	e	enum:h2c_cmd
-H2C_MCC_INFO_LEN	include/hal_com_h2c.h	143;"	d
-H2C_MCC_IQK_PARAM	include/hal_com_h2c.h	/^	H2C_MCC_IQK_PARAM = 0x1A,$/;"	e	enum:h2c_cmd
-H2C_MCC_IQK_PARAM_LEN	include/hal_com_h2c.h	148;"	d
-H2C_MCC_LOCATION	include/hal_com_h2c.h	/^	H2C_MCC_LOCATION = 0x10,$/;"	e	enum:h2c_cmd
-H2C_MCC_LOCATION_LEN	include/hal_com_h2c.h	144;"	d
-H2C_MCC_MACID_BITMAP	include/hal_com_h2c.h	/^	H2C_MCC_MACID_BITMAP = 0x16,$/;"	e	enum:h2c_cmd
-H2C_MCC_MACID_BITMAP_LEN	include/hal_com_h2c.h	145;"	d
-H2C_MCC_NOA_PARAM	include/hal_com_h2c.h	/^	H2C_MCC_NOA_PARAM = 0x19,$/;"	e	enum:h2c_cmd
-H2C_MCC_NOA_PARAM_LEN	include/hal_com_h2c.h	147;"	d
-H2C_MCC_UPDATE_INFO_LEN	include/hal_com_h2c.h	146;"	d
-H2C_MCC_UPDATE_PARAM	include/hal_com_h2c.h	/^	H2C_MCC_UPDATE_PARAM = 0x15,$/;"	e	enum:h2c_cmd
-H2C_MEDIA_STATUS_RPT	include/hal_com_h2c.h	/^	H2C_MEDIA_STATUS_RPT = 0x01,$/;"	e	enum:h2c_cmd
-H2C_MEDIA_STATUS_RPT_LEN	include/hal_com_h2c.h	118;"	d
-H2C_MSR_ARG	include/hal_com_h2c.h	245;"	d
-H2C_MSR_FMT	include/hal_com_h2c.h	244;"	d
-H2C_MSR_ROLE_ADHOC	include/hal_com_h2c.h	238;"	d
-H2C_MSR_ROLE_AP	include/hal_com_h2c.h	234;"	d
-H2C_MSR_ROLE_GC	include/hal_com_h2c.h	235;"	d
-H2C_MSR_ROLE_GO	include/hal_com_h2c.h	236;"	d
-H2C_MSR_ROLE_MAX	include/hal_com_h2c.h	239;"	d
-H2C_MSR_ROLE_RSVD	include/hal_com_h2c.h	232;"	d
-H2C_MSR_ROLE_STA	include/hal_com_h2c.h	233;"	d
-H2C_MSR_ROLE_TDLS	include/hal_com_h2c.h	237;"	d
-H2C_P2PRSVDPAGE_LOC_LEN	include/hal_com_h2c.h	139;"	d
-H2C_P2P_LPS_PARAM	include/hal_com_h2c.h	/^	H2C_P2P_LPS_PARAM = 0x23,$/;"	e	enum:h2c_cmd
-H2C_P2P_OFFLOAD	include/hal_com_h2c.h	/^	H2C_P2P_OFFLOAD = 0x8B,$/;"	e	enum:h2c_cmd
-H2C_P2P_OFFLOAD_LEN	include/hal_com_h2c.h	140;"	d
-H2C_P2P_OFFLOAD_RSVD_PAGE	include/hal_com_h2c.h	/^	H2C_P2P_OFFLOAD_RSVD_PAGE = 0x8A,$/;"	e	enum:h2c_cmd
-H2C_P2P_PS_OFFLOAD	include/hal_com_h2c.h	/^	H2C_P2P_PS_OFFLOAD = 0x24,$/;"	e	enum:h2c_cmd
-H2C_PARAMETERS_ERROR	include/rtw_cmd.h	1009;"	d
-H2C_PROBERSP_RSVDPAGE	include/hal_com_h2c.h	/^	H2C_PROBERSP_RSVDPAGE = 0x0A,$/;"	e	enum:h2c_cmd
-H2C_PROBERSP_RSVDPAGE_LEN	include/hal_com_h2c.h	138;"	d
-H2C_PSD_OFFLOAD	include/hal_com_h2c.h	/^	H2C_PSD_OFFLOAD = 0x05,$/;"	e	enum:h2c_cmd
-H2C_PSTUNEPARAM_LEN	include/hal_com_h2c.h	125;"	d
-H2C_PS_LPS_PARA	include/rtl8188e_cmd.h	/^	H2C_PS_LPS_PARA				= 0x23,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_PS_P2P_OFFLOAD	include/rtl8188e_cmd.h	/^	H2C_PS_P2P_OFFLOAD			= 0x24,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_PS_PWR_MODE	include/rtl8188e_cmd.h	/^	H2C_PS_PWR_MODE				= 0x20,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_PS_SCAN_ENABLE	include/hal_com_h2c.h	/^	H2C_PS_SCAN_ENABLE = 0x25,$/;"	e	enum:h2c_cmd
-H2C_PS_TUNE_PARA	include/rtl8188e_cmd.h	/^	H2C_PS_TUNE_PARA				= 0x21,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_PS_TUNE_PARA_2	include/rtl8188e_cmd.h	/^	H2C_PS_TUNE_PARA_2			= 0x22,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_PS_TUNING_PARA	include/hal_com_h2c.h	/^	H2C_PS_TUNING_PARA = 0x21,$/;"	e	enum:h2c_cmd
-H2C_PS_TUNING_PARA2	include/hal_com_h2c.h	/^	H2C_PS_TUNING_PARA2 = 0x22,$/;"	e	enum:h2c_cmd
-H2C_PWRMODE_LEN	include/hal_com_h2c.h	124;"	d
-H2C_RARpt_connect	hal/phydm/phydm.h	/^	BOOLEAN			H2C_RARpt_connect;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-H2C_RA_MASK_3SS	include/hal_com_h2c.h	/^	H2C_RA_MASK_3SS = 0x46,\/* for 8814A *\/$/;"	e	enum:h2c_cmd
-H2C_RA_PARA_ADJUST	include/hal_com_h2c.h	/^	H2C_RA_PARA_ADJUST = 0x47,\/* CONFIG_RA_DBG_CMD *\/$/;"	e	enum:h2c_cmd
-H2C_REJECTED	include/rtw_cmd.h	1010;"	d
-H2C_REMOTE_WAKE_CTRL	include/hal_com_h2c.h	/^	H2C_REMOTE_WAKE_CTRL = 0x81,$/;"	e	enum:h2c_cmd
-H2C_REMOTE_WAKE_CTRL_LEN	include/hal_com_h2c.h	129;"	d
-H2C_RESERVED	include/rtw_cmd.h	1012;"	d
-H2C_RESET_TSF	include/hal_com_h2c.h	/^	H2C_RESET_TSF = 0xC0,$/;"	e	enum:h2c_cmd
-H2C_RSP_OFFSET	include/rtw_cmd.h	1003;"	d
-H2C_RSSI_REPORT	include/rtl8188e_cmd.h	/^	H2C_RSSI_REPORT				= 0x42,$/;"	e	enum:_RTL8188E_H2C_CMD_ID
-H2C_RSSI_SETTING	include/hal_com_h2c.h	/^	H2C_RSSI_SETTING = 0x42,$/;"	e	enum:h2c_cmd
-H2C_RSSI_SETTING_LEN	include/hal_com_h2c.h	134;"	d
-H2C_RSVDPAGE_LOC_LEN	include/hal_com_h2c.h	117;"	d
-H2C_RSVD_PAGE	include/hal_com_h2c.h	/^	H2C_RSVD_PAGE = 0x00,$/;"	e	enum:h2c_cmd
-H2C_SAP_PS_	include/hal_com_h2c.h	/^	H2C_SAP_PS_ = 0x26,$/;"	e	enum:h2c_cmd
-H2C_SCAN_ENABLE	include/hal_com_h2c.h	/^	H2C_SCAN_ENABLE = 0x02,$/;"	e	enum:h2c_cmd
-H2C_SCAN_OFFLOAD_CTRL_LEN	include/hal_com_h2c.h	132;"	d
-H2C_SET_PWR_MODE	include/hal_com_h2c.h	/^	H2C_SET_PWR_MODE = 0x20,$/;"	e	enum:h2c_cmd
-H2C_SS_RFOFF_PARAM	include/rtl8188e_cmd.h	/^struct H2C_SS_RFOFF_PARAM {$/;"	s
-H2C_SS_RFOFF_PARAM	include/rtl8192e_cmd.h	/^struct H2C_SS_RFOFF_PARAM {$/;"	s
-H2C_SS_RFOFF_PARAM	include/rtl8812a_cmd.h	/^struct H2C_SS_RFOFF_PARAM {$/;"	s
-H2C_SUCCESS	include/rtw_cmd.h	1005;"	d
-H2C_SUCCESS_RSP	include/rtw_cmd.h	1006;"	d
-H2C_TXBF	include/hal_com_h2c.h	/^	H2C_TXBF = 0x41,$/;"	e	enum:h2c_cmd
-H2C_WL_OPMODE	include/hal_com_h2c.h	/^	H2C_WL_OPMODE = 0x66,$/;"	e	enum:h2c_cmd
-H2C_WOWLAN	include/hal_com_h2c.h	/^	H2C_WOWLAN = 0x80,$/;"	e	enum:h2c_cmd
-H2C_WOWLAN_LEN	include/hal_com_h2c.h	128;"	d
-H2L_lb	hal/phydm/phydm_adaptivity.h	/^	s1Byte			H2L_lb;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-HAL92C_EN_PKT_LIFE_TIME_BE	include/hal_com_reg.h	1778;"	d
-HAL92C_EN_PKT_LIFE_TIME_BK	include/hal_com_reg.h	1777;"	d
-HAL92C_EN_PKT_LIFE_TIME_VI	include/hal_com_reg.h	1779;"	d
-HAL92C_EN_PKT_LIFE_TIME_VO	include/hal_com_reg.h	1780;"	d
-HAL92C_MSDU_LIFE_TIME_UNIT	include/hal_com_reg.h	1782;"	d
-HAL92C_WOL_DEAUTH_EVENT	include/hal_com_reg.h	705;"	d
-HAL92C_WOL_DISASSOC_EVENT	include/hal_com_reg.h	704;"	d
-HAL92C_WOL_FW_DISCONNECT_EVENT	include/hal_com_reg.h	706;"	d
-HAL92C_WOL_GTK_UPDATE_EVENT	include/hal_com_reg.h	703;"	d
-HAL92C_WOL_PTK_UPDATE_EVENT	include/hal_com_reg.h	702;"	d
-HALBTCOUTSRC_AGG_CHK_WINDOW_IN_MS	hal/hal_btcoex.c	140;"	d	file:
-HALF_CAM_ENTRY	include/hal_com_reg.h	824;"	d
-HALMAC_PWR_TRACKING_INFO	hal/phydm/phydm_powertracking_win.h	/^	HALMAC_PWR_TRACKING_OPTION	HALMAC_PWR_TRACKING_INFO;$/;"	m	struct:ODM_RF_Calibration_Structure
-HAL_8188E_HW_GPIO_WPS_BIT	include/hal_com_reg.h	1817;"	d
-HAL_8192C_HW_GPIO_WPS_BIT	include/hal_com_reg.h	1815;"	d
-HAL_8192EU_HW_GPIO_WPS_BIT	include/hal_com_reg.h	1816;"	d
-HAL_8812A_HW_GPIO_WPS_BIT	include/hal_com_reg.h	1814;"	d
-HAL_BB_ENABLE	include/hal_phy.h	27;"	d
-HAL_BB_ENABLE	include/hal_phy.h	32;"	d
-HAL_CHIP_TYPE_E	include/HalVerDef.h	/^} HAL_CHIP_TYPE_E;$/;"	t	typeref:enum:tag_HAL_CHIP_Type_Definition
-HAL_CUT_VERSION_E	include/HalVerDef.h	/^} HAL_CUT_VERSION_E;$/;"	t	typeref:enum:tag_HAL_Cut_Version_Definition
-HAL_DATA_COMMON	include/hal_data.h	/^} HAL_DATA_COMMON, *PHAL_DATA_COMMON;$/;"	t	typeref:struct:hal_com_data
-HAL_DATA_TYPE	include/hal_data.h	/^typedef struct hal_com_data HAL_DATA_TYPE, *PHAL_DATA_TYPE;$/;"	t	typeref:struct:hal_com_data
-HAL_DEF_ANT_DETECT	include/hal_intf.h	/^	HAL_DEF_ANT_DETECT,\/* to do for 8723a *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_BEAMFORMEE_CAP	include/hal_intf.h	/^	HAL_DEF_BEAMFORMEE_CAP,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_BEAMFORMER_CAP	include/hal_intf.h	/^	HAL_DEF_BEAMFORMER_CAP,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_DBG_DIS_PWT	include/hal_intf.h	/^	HAL_DEF_DBG_DIS_PWT, \/* disable Tx power training or not. *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_DBG_DUMP_RXPKT	include/hal_intf.h	/^	HAL_DEF_DBG_DUMP_RXPKT,\/* for dbg *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_DBG_DUMP_TXPKT	include/hal_intf.h	/^	HAL_DEF_DBG_DUMP_TXPKT,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_DRVINFO_SZ	include/hal_intf.h	/^	HAL_DEF_DRVINFO_SZ,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_EFUSE_BYTES	include/hal_intf.h	/^	HAL_DEF_EFUSE_BYTES,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_EFUSE_USAGE	include/hal_intf.h	/^	HAL_DEF_EFUSE_USAGE,	\/* Get current EFUSE utilization. 2008.12.19. Added by Roger. *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_EXPLICIT_BEAMFORMEE	include/hal_intf.h	/^	HAL_DEF_EXPLICIT_BEAMFORMEE,\/* Explicit Compressed Beamforming Feedback Capable *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_EXPLICIT_BEAMFORMER	include/hal_intf.h	/^	HAL_DEF_EXPLICIT_BEAMFORMER,\/* Explicit  Compressed Steering Capable *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_IS_SUPPORT_ANT_DIV	include/hal_intf.h	/^	HAL_DEF_IS_SUPPORT_ANT_DIV,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_MACID_SLEEP	include/hal_intf.h	/^	HAL_DEF_MACID_SLEEP, \/* Support for MACID sleep *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_MAX_RECVBUF_SZ	include/hal_intf.h	/^	HAL_DEF_MAX_RECVBUF_SZ,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_PCI_AMD_L1_SUPPORT	include/hal_intf.h	/^	HAL_DEF_PCI_AMD_L1_SUPPORT,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_PCI_ASPM_OSC	include/hal_intf.h	/^	HAL_DEF_PCI_ASPM_OSC, \/* Support for ASPM OSC, added by Roger, 2013.03.27. *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_PCI_SUUPORT_L1_BACKDOOR	include/hal_intf.h	/^	HAL_DEF_PCI_SUUPORT_L1_BACKDOOR, \/* Determine if the L1 Backdoor setting is turned on. *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_PT_PWR_STATUS	include/hal_intf.h	/^	HAL_DEF_PT_PWR_STATUS,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RA_DECISION_RATE	include/hal_intf.h	/^	HAL_DEF_RA_DECISION_RATE,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RA_SGI	include/hal_intf.h	/^	HAL_DEF_RA_SGI,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RX_DMA_SZ	include/hal_intf.h	/^	HAL_DEF_RX_DMA_SZ,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RX_DMA_SZ_WOW	include/hal_intf.h	/^	HAL_DEF_RX_DMA_SZ_WOW,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RX_LDPC	include/hal_intf.h	/^	HAL_DEF_RX_LDPC,				\/* LDPC support *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RX_PACKET_OFFSET	include/hal_intf.h	/^	HAL_DEF_RX_PACKET_OFFSET,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RX_PAGE_SIZE	include/hal_intf.h	/^	HAL_DEF_RX_PAGE_SIZE,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_RX_STBC	include/hal_intf.h	/^	HAL_DEF_RX_STBC,				\/* RX STBC support *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_TX_LDPC	include/hal_intf.h	/^	HAL_DEF_TX_LDPC,				\/* LDPC support *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_TX_PAGE_BOUNDARY	include/hal_intf.h	/^	HAL_DEF_TX_PAGE_BOUNDARY,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN	include/hal_intf.h	/^	HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_TX_PAGE_SIZE	include/hal_intf.h	/^	HAL_DEF_TX_PAGE_SIZE,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_TX_STBC	include/hal_intf.h	/^	HAL_DEF_TX_STBC,				\/* TX STBC support *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_UNDERCORATEDSMOOTHEDPWDB	include/hal_intf.h	/^	HAL_DEF_UNDERCORATEDSMOOTHEDPWDB,$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_VARIABLE	include/hal_intf.h	/^} HAL_DEF_VARIABLE;$/;"	t	typeref:enum:_HAL_DEF_VARIABLE
-HAL_DEF_VHT_MU_BEAMFORMEE	include/hal_intf.h	/^	HAL_DEF_VHT_MU_BEAMFORMEE,	\/* VHT MU Beamformee support *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_DEF_VHT_MU_BEAMFORMER	include/hal_intf.h	/^	HAL_DEF_VHT_MU_BEAMFORMER,	\/* VHT MU Beamformer support *\/$/;"	e	enum:_HAL_DEF_VARIABLE
-HAL_EFUSE_MEMORY	include/rtl8188f_hal.h	165;"	d
-HAL_EFUSE_MEMORY	include/rtl8703b_hal.h	167;"	d
-HAL_EFUSE_MEMORY	include/rtl8723b_hal.h	167;"	d
-HAL_EFUSE_MEMORY	include/rtl8723d_hal.h	174;"	d
-HAL_FW_ENABLE	include/hal_phy.h	25;"	d
-HAL_FW_ENABLE	include/hal_phy.h	30;"	d
-HAL_HW_PCI_0044_DEVICE_ID	include/drv_types_pci.h	67;"	d
-HAL_HW_PCI_0045_DEVICE_ID	include/drv_types_pci.h	65;"	d
-HAL_HW_PCI_0046_DEVICE_ID	include/drv_types_pci.h	66;"	d
-HAL_HW_PCI_0047_DEVICE_ID	include/drv_types_pci.h	68;"	d
-HAL_HW_PCI_700F_DEVICE_ID	include/drv_types_pci.h	69;"	d
-HAL_HW_PCI_701F_DEVICE_ID	include/drv_types_pci.h	70;"	d
-HAL_HW_PCI_8171_DEVICE_ID	include/drv_types_pci.h	64;"	d
-HAL_HW_PCI_8172_DEVICE_ID	include/drv_types_pci.h	63;"	d
-HAL_HW_PCI_8173_DEVICE_ID	include/drv_types_pci.h	62;"	d
-HAL_HW_PCI_8174_DEVICE_ID	include/drv_types_pci.h	61;"	d
-HAL_HW_PCI_8180_DEVICE_ID	include/drv_types_pci.h	53;"	d
-HAL_HW_PCI_8185_DEVICE_ID	include/drv_types_pci.h	54;"	d
-HAL_HW_PCI_8188EE_DEVICE_ID	include/drv_types_pci.h	72;"	d
-HAL_HW_PCI_8188_DEVICE_ID	include/drv_types_pci.h	55;"	d
-HAL_HW_PCI_8190_DEVICE_ID	include/drv_types_pci.h	57;"	d
-HAL_HW_PCI_8192SE_DEVICE_ID	include/drv_types_pci.h	60;"	d
-HAL_HW_PCI_8192_DEVICE_ID	include/drv_types_pci.h	59;"	d
-HAL_HW_PCI_8198_DEVICE_ID	include/drv_types_pci.h	56;"	d
-HAL_HW_PCI_8723E_DEVICE_ID	include/drv_types_pci.h	58;"	d
-HAL_HW_PCI_DLINK_DEVICE_ID	include/drv_types_pci.h	71;"	d
-HAL_HW_PCI_REVISION_ID_8190PCI	include/drv_types_pci.h	75;"	d
-HAL_HW_PCI_REVISION_ID_8192CE	include/drv_types_pci.h	80;"	d
-HAL_HW_PCI_REVISION_ID_8192DE	include/drv_types_pci.h	82;"	d
-HAL_HW_PCI_REVISION_ID_8192PCIE	include/drv_types_pci.h	77;"	d
-HAL_HW_PCI_REVISION_ID_8192SE	include/drv_types_pci.h	79;"	d
-HAL_HW_TIMER_TYPE	include/hal_intf.h	/^} HAL_HW_TIMER_TYPE, *PHAL_HW_TIMER_TYPE;$/;"	t	typeref:enum:_HAL_HW_TIMER_TYPE
-HAL_IC_TYPE_E	include/HalVerDef.h	/^} HAL_IC_TYPE_E;$/;"	t	typeref:enum:tag_HAL_IC_Type_Definition
-HAL_INTF_PS_FUNC	include/hal_intf.h	/^} HAL_INTF_PS_FUNC;$/;"	t	typeref:enum:_HAL_INTF_PS_FUNC
-HAL_IsLegalChannel	hal/hal_com.c	/^HAL_IsLegalChannel($/;"	f
-HAL_MAC_ENABLE	include/hal_phy.h	26;"	d
-HAL_MAC_ENABLE	include/hal_phy.h	31;"	d
-HAL_MAX_ID	include/hal_intf.h	/^	HAL_MAX_ID,$/;"	e	enum:_HAL_INTF_PS_FUNC
-HAL_MEMORY_MAPPED_IO_RANGE_8190PCI	include/drv_types_pci.h	74;"	d
-HAL_MEMORY_MAPPED_IO_RANGE_8192CE	include/drv_types_pci.h	81;"	d
-HAL_MEMORY_MAPPED_IO_RANGE_8192DE	include/drv_types_pci.h	83;"	d
-HAL_MEMORY_MAPPED_IO_RANGE_8192PCIE	include/drv_types_pci.h	76;"	d
-HAL_MEMORY_MAPPED_IO_RANGE_8192SE	include/drv_types_pci.h	78;"	d
-HAL_NAV_UPPER_UNIT	include/hal_com_reg.h	26;"	d
-HAL_NAV_UPPER_UNIT_8188F	include/rtl8188f_spec.h	25;"	d
-HAL_NAV_UPPER_UNIT_8192E	include/rtl8192e_spec.h	24;"	d
-HAL_NAV_UPPER_UNIT_8703B	include/rtl8703b_spec.h	25;"	d
-HAL_NAV_UPPER_UNIT_8723B	include/rtl8723b_spec.h	25;"	d
-HAL_NAV_UPPER_UNIT_8723D	include/rtl8723d_spec.h	25;"	d
-HAL_NIC_UNPLUG_ISR	include/hal_com_reg.h	1003;"	d
-HAL_NIC_UNPLUG_PCI_ISR	include/hal_com_reg.h	1004;"	d
-HAL_ODM_ANTDIV_SELECT	include/hal_intf.h	/^	HAL_ODM_ANTDIV_SELECT$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_AUTO_CHNL_SEL	include/hal_intf.h	/^	HAL_ODM_AUTO_CHNL_SEL,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_DBG_FLAG	include/hal_intf.h	/^	HAL_ODM_DBG_FLAG,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_DBG_LEVEL	include/hal_intf.h	/^	HAL_ODM_DBG_LEVEL,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_FA_CNT_DUMP	include/hal_intf.h	/^	HAL_ODM_FA_CNT_DUMP,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_INITIAL_GAIN	include/hal_intf.h	/^	HAL_ODM_INITIAL_GAIN,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_NOISE_MONITOR	include/hal_intf.h	/^	HAL_ODM_NOISE_MONITOR,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_P2P_STATE	include/hal_intf.h	/^	HAL_ODM_P2P_STATE,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_REGULATION	include/hal_intf.h	/^	HAL_ODM_REGULATION,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_RX_Dframe_INFO	include/hal_intf.h	/^	HAL_ODM_RX_Dframe_INFO,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_RX_INFO_DUMP	include/hal_intf.h	/^	HAL_ODM_RX_INFO_DUMP,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_STA_INFO	include/hal_intf.h	/^	HAL_ODM_STA_INFO,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_ODM_VARIABLE	include/hal_intf.h	/^} HAL_ODM_VARIABLE;$/;"	t	typeref:enum:_HAL_ODM_VARIABLE
-HAL_ODM_WIFI_DISPLAY_STATE	include/hal_intf.h	/^	HAL_ODM_WIFI_DISPLAY_STATE,$/;"	e	enum:_HAL_ODM_VARIABLE
-HAL_PHYDM_ABILITY_BK	include/hal_com.h	/^	HAL_PHYDM_ABILITY_BK,$/;"	e	enum:_HAL_PHYDM_OPS
-HAL_PHYDM_ABILITY_GET	include/hal_com.h	/^	HAL_PHYDM_ABILITY_GET,$/;"	e	enum:_HAL_PHYDM_OPS
-HAL_PHYDM_ABILITY_RESTORE	include/hal_com.h	/^	HAL_PHYDM_ABILITY_RESTORE,$/;"	e	enum:_HAL_PHYDM_OPS
-HAL_PHYDM_ABILITY_SET	include/hal_com.h	/^	HAL_PHYDM_ABILITY_SET,$/;"	e	enum:_HAL_PHYDM_OPS
-HAL_PHYDM_DIS_ALL_FUNC	include/hal_com.h	/^	HAL_PHYDM_DIS_ALL_FUNC,$/;"	e	enum:_HAL_PHYDM_OPS
-HAL_PHYDM_FUNC_CLR	include/hal_com.h	/^	HAL_PHYDM_FUNC_CLR,$/;"	e	enum:_HAL_PHYDM_OPS
-HAL_PHYDM_FUNC_SET	include/hal_com.h	/^	HAL_PHYDM_FUNC_SET,$/;"	e	enum:_HAL_PHYDM_OPS
-HAL_PHYDM_OPS	include/hal_com.h	/^} HAL_PHYDM_OPS;$/;"	t	typeref:enum:_HAL_PHYDM_OPS
-HAL_PRIME_CHNL_OFFSET_DONT_CARE	include/rtw_rf.h	144;"	d
-HAL_PRIME_CHNL_OFFSET_LOWER	include/rtw_rf.h	145;"	d
-HAL_PRIME_CHNL_OFFSET_UPPER	include/rtw_rf.h	146;"	d
-HAL_RF_ENABLE	include/hal_phy.h	28;"	d
-HAL_RF_ENABLE	include/hal_phy.h	33;"	d
-HAL_RF_TYPE_E	include/HalVerDef.h	/^} HAL_RF_TYPE_E;$/;"	t	typeref:enum:tag_HAL_RF_Type_Definition
-HAL_SPEC_CHK_RF_PATH	include/hal_data.h	268;"	d
-HAL_SPEC_CHK_RF_PATH_2G	include/hal_data.h	266;"	d
-HAL_SPEC_CHK_RF_PATH_5G	include/hal_data.h	267;"	d
-HAL_SPEC_CHK_TX_CNT	include/hal_data.h	272;"	d
-HAL_STATUS	hal/phydm/phydm_types.h	/^}HAL_STATUS,*PHAL_STATUS;$/;"	t	typeref:enum:_HAL_STATUS
-HAL_STATUS_FAILURE	hal/phydm/phydm_types.h	/^	HAL_STATUS_FAILURE,$/;"	e	enum:_HAL_STATUS
-HAL_STATUS_SUCCESS	hal/phydm/phydm_types.h	/^	HAL_STATUS_SUCCESS,$/;"	e	enum:_HAL_STATUS
-HAL_TIMER_EARLYMODE	include/hal_intf.h	/^	HAL_TIMER_EARLYMODE = 2,$/;"	e	enum:_HAL_HW_TIMER_TYPE
-HAL_TIMER_NONE	include/hal_intf.h	/^	HAL_TIMER_NONE = 0,$/;"	e	enum:_HAL_HW_TIMER_TYPE
-HAL_TIMER_TXBF	include/hal_intf.h	/^	HAL_TIMER_TXBF = 1,$/;"	e	enum:_HAL_HW_TIMER_TYPE
-HAL_TXBF_INFO	hal/phydm/txbf/halcomtxbf.h	/^} HAL_TXBF_INFO, *PHAL_TXBF_INFO;$/;"	t	typeref:struct:_HAL_TXBF_INFO
-HAL_USB_SELECT_SUSPEND	include/hal_intf.h	/^	HAL_USB_SELECT_SUSPEND,$/;"	e	enum:_HAL_INTF_PS_FUNC
-HAL_VENDOR_E	include/HalVerDef.h	/^} HAL_VENDOR_E;$/;"	t	typeref:enum:tag_HAL_Manufacturer_Version_Definition
-HAL_VERSION	include/HalVerDef.h	/^} HAL_VERSION, *PHAL_VERSION;$/;"	t	typeref:struct:tag_HAL_VERSION
-HARDWARE_TYPE	include/hal_intf.h	/^} HARDWARE_TYPE;$/;"	t	typeref:enum:_HARDWARE_TYPE
-HARDWARE_TYPE_MAX	include/hal_intf.h	/^	HARDWARE_TYPE_MAX,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8188EE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8188EE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8188ES	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8188ES,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8188EU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8188EU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8188FE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8188FE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8188FS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8188FS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8188FU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8188FU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8192EE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8192EE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8192ES	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8192ES,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8192EU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8192EU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8703BE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8703BE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8703BS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8703BS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8703BU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8703BU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8723BE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8723BE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8723BS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8723BS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8723BU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8723BU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8723DE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8723DE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8723DS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8723DS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8723DU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8723DU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8811AU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8811AU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8812AU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8812AU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8812E	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8812E,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8814AE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8814AE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8814AS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8814AS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8814AU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8814AU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821BE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821BE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821BS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821BS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821BU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821BU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821CE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821CE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821CS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821CS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821CU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821CU,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821E	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821E,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821S	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821S,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8821U	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8821U,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8822BE	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8822BE,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8822BS	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8822BS,$/;"	e	enum:_HARDWARE_TYPE
-HARDWARE_TYPE_RTL8822BU	include/hal_intf.h	/^	HARDWARE_TYPE_RTL8822BU,$/;"	e	enum:_HARDWARE_TYPE
-HCIExtensionVer	include/rtw_btcoex.h	/^	u2Byte					HCIExtensionVer;$/;"	m	struct:_HCI_EXT_CONFIG
-HCIOPCODE	include/rtw_btcoex.h	181;"	d
-HCIOPCODEHIGHT	include/rtw_btcoex.h	183;"	d
-HCIOPCODELOW	include/rtw_btcoex.h	182;"	d
-HCI_BT_ABNORMAL_NOTIFY	include/rtw_btcoex.h	/^	HCI_BT_ABNORMAL_NOTIFY							= 0x0105,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_BT_AFH_MAP_NOTIFY	include/rtw_btcoex.h	/^	HCI_BT_AFH_MAP_NOTIFY							= 0x0109,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_BT_COEX_NOTIFY	include/rtw_btcoex.h	/^	HCI_BT_COEX_NOTIFY								= 0x0107,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_BT_INFO_NOTIFY	include/rtw_btcoex.h	/^	HCI_BT_INFO_NOTIFY								= 0x0106,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_BT_OPERATION_NOTIFY	include/rtw_btcoex.h	/^	HCI_BT_OPERATION_NOTIFY							= 0x0102,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_BT_OP_BT_DEV_DISABLE	include/rtw_btcoex.h	/^	HCI_BT_OP_BT_DEV_DISABLE		= 0x9,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_BT_DEV_ENABLE	include/rtw_btcoex.h	/^	HCI_BT_OP_BT_DEV_ENABLE		= 0x8,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_INQUIRY_FINISH	include/rtw_btcoex.h	/^	HCI_BT_OP_INQUIRY_FINISH		= 0x2,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_INQUIRY_START	include/rtw_btcoex.h	/^	HCI_BT_OP_INQUIRY_START		= 0x1,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_MAX	include/rtw_btcoex.h	/^	HCI_BT_OP_MAX$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_NONE	include/rtw_btcoex.h	/^	HCI_BT_OP_NONE				= 0x0,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_PAGING_START	include/rtw_btcoex.h	/^	HCI_BT_OP_PAGING_START		= 0x3,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_PAGING_SUCCESS	include/rtw_btcoex.h	/^	HCI_BT_OP_PAGING_SUCCESS		= 0x4,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_PAGING_UNSUCCESS	include/rtw_btcoex.h	/^	HCI_BT_OP_PAGING_UNSUCCESS	= 0x5,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_PAIRING_FINISH	include/rtw_btcoex.h	/^	HCI_BT_OP_PAIRING_FINISH		= 0x7,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_OP_PAIRING_START	include/rtw_btcoex.h	/^	HCI_BT_OP_PAIRING_START		= 0x6,$/;"	e	enum:_HCI_EXT_BT_OPERATION
-HCI_BT_PATCH_VERSION_NOTIFY	include/rtw_btcoex.h	/^	HCI_BT_PATCH_VERSION_NOTIFY						= 0x0108,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_BT_REGISTER_VALUE_NOTIFY	include/rtw_btcoex.h	/^	HCI_BT_REGISTER_VALUE_NOTIFY					= 0x010a,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_ENABLE_WIFI_SCAN_NOTIFY	include/rtw_btcoex.h	/^	HCI_ENABLE_WIFI_SCAN_NOTIFY						= 0x0103,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_EVENT_COMMAND_COMPLETE	include/rtw_btcoex.h	250;"	d
-HCI_EVENT_EXTENSION_RTK	include/rtw_btcoex.h	279;"	d
-HCI_EVENT_EXT_BT_COEX_CONTROL	include/rtw_btcoex.h	/^	HCI_EVENT_EXT_BT_COEX_CONTROL								= 0x04$/;"	e	enum:HCI_EXTENSION_EVENT_RTK
-HCI_EVENT_EXT_BT_INFO_CONTROL	include/rtw_btcoex.h	/^	HCI_EVENT_EXT_BT_INFO_CONTROL								= 0x03,$/;"	e	enum:HCI_EXTENSION_EVENT_RTK
-HCI_EVENT_EXT_WIFI_RF_STATUS_NOTIFY	include/rtw_btcoex.h	/^	HCI_EVENT_EXT_WIFI_RF_STATUS_NOTIFY						= 0x02,$/;"	e	enum:HCI_EXTENSION_EVENT_RTK
-HCI_EVENT_EXT_WIFI_SCAN_NOTIFY	include/rtw_btcoex.h	/^	HCI_EVENT_EXT_WIFI_SCAN_NOTIFY								= 0x01,$/;"	e	enum:HCI_EXTENSION_EVENT_RTK
-HCI_EXTENSION_COMMANDS	include/rtw_btcoex.h	/^typedef enum HCI_EXTENSION_COMMANDS {$/;"	g
-HCI_EXTENSION_EVENT_RTK	include/rtw_btcoex.h	/^typedef enum HCI_EXTENSION_EVENT_RTK {$/;"	g
-HCI_EXTENSION_VERSION_NOTIFY	include/rtw_btcoex.h	/^	HCI_EXTENSION_VERSION_NOTIFY					= 0x0100,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_EXT_BT_OPERATION	include/rtw_btcoex.h	/^} HCI_EXT_BT_OPERATION, *PHCI_EXT_BT_OPERATION;$/;"	t	typeref:enum:_HCI_EXT_BT_OPERATION
-HCI_EXT_CONFIG	include/rtw_btcoex.h	/^} HCI_EXT_CONFIG, *PHCI_EXT_CONFIG;$/;"	t	typeref:struct:_HCI_EXT_CONFIG
-HCI_LINK_INFO	include/rtw_btcoex.h	/^} HCI_LINK_INFO, *PHCI_LINK_INFO;$/;"	t	typeref:struct:_HCI_LINK_INFO
-HCI_LINK_STATUS_NOTIFY	include/rtw_btcoex.h	/^	HCI_LINK_STATUS_NOTIFY							= 0x0101,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_NAME	Makefile	/^HCI_NAME = gspi$/;"	m
-HCI_NAME	Makefile	/^HCI_NAME = pci$/;"	m
-HCI_NAME	Makefile	/^HCI_NAME = sdio$/;"	m
-HCI_NAME	Makefile	/^HCI_NAME = usb$/;"	m
-HCI_OCF	include/rtw_btcoex.h	185;"	d
-HCI_OGF	include/rtw_btcoex.h	184;"	d
-HCI_PHY_LINK_BSS_INFO	include/rtw_btcoex.h	/^} HCI_PHY_LINK_BSS_INFO, *PHCI_PHY_LINK_BSS_INFO;$/;"	t	typeref:struct:_HCI_PHY_LINK_BSS_INFO
-HCI_QUERY_RF_STATUS	include/rtw_btcoex.h	/^	HCI_QUERY_RF_STATUS								= 0x0104,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_RESUME_PWR_RDY	include/hal_com_reg.h	1723;"	d
-HCI_RXDMA_EN	include/hal_com_reg.h	1316;"	d
-HCI_SEL	include/hal_com_reg.h	1287;"	d
-HCI_SET_ACL_LINK_DATA_FLOW_MODE	include/rtw_btcoex.h	/^	HCI_SET_ACL_LINK_DATA_FLOW_MODE				= 0x0010,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_SET_ACL_LINK_STATUS	include/rtw_btcoex.h	/^	HCI_SET_ACL_LINK_STATUS							= 0x0020,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_SET_CURRENT_BLUETOOTH_STATUS	include/rtw_btcoex.h	/^	HCI_SET_CURRENT_BLUETOOTH_STATUS				= 0x0041,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_SET_RSSI_VALUE	include/rtw_btcoex.h	/^	HCI_SET_RSSI_VALUE								= 0x0040,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_SET_SCO_LINK_STATUS	include/rtw_btcoex.h	/^	HCI_SET_SCO_LINK_STATUS							= 0x0030,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_STATUS_ACL_CONNECT_EXISTS	include/rtw_btcoex.h	/^	HCI_STATUS_ACL_CONNECT_EXISTS							= 0X0b, \/* ACL Connection Already Exists *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_AUTH_FAIL	include/rtw_btcoex.h	/^	HCI_STATUS_AUTH_FAIL										= 0X05, \/* Authentication Failure *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CHNL_CLASSIFICATION_NOT_SUPPORT	include/rtw_btcoex.h	/^	HCI_STATUS_CHNL_CLASSIFICATION_NOT_SUPPORT				= 0X2e, \/* Channel Classification Not Supported *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CMD_DISALLOW	include/rtw_btcoex.h	/^	HCI_STATUS_CMD_DISALLOW									= 0X0c, \/* Command Disallowed *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_ACCEPT_TIMEOUT	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_ACCEPT_TIMEOUT						= 0X10, \/* Connection Accept Timeout Exceeded *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_LIMIT	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_LIMIT									= 0X09, \/* Connection Limit Exceeded *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_REJ_NOT_SUIT_CHNL_FOUND	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_REJ_NOT_SUIT_CHNL_FOUND			= 0X39, \/* Connection Rejected due to No Suitable Channel Found *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_RJT_LIMIT_RESOURCE	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_RJT_LIMIT_RESOURCE					= 0X0d, \/* Connection Rejected due to Limited Resources *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_RJT_SEC_REASON	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_RJT_SEC_REASON						= 0X0e, \/* Connection Rejected Due To Security Reasons *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_RJT_UNACCEPT_BD_ADDR	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_RJT_UNACCEPT_BD_ADDR				= 0X0f, \/* Connection Rejected due to Unacceptable BD_ADDR *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_TERMINATE_LOCAL_HOST	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_TERMINATE_LOCAL_HOST				= 0X16, \/* Connection Terminated By Local Host *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONNECT_TIMEOUT	include/rtw_btcoex.h	/^	HCI_STATUS_CONNECT_TIMEOUT								= 0X08, \/* Connection Timeout *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_CONTROLLER_BUSY	include/rtw_btcoex.h	/^	HCI_STATUS_CONTROLLER_BUSY								= 0X3a \/* CONTROLLER BUSY *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_DIFFERENT_TRANSACTION_COLLISION	include/rtw_btcoex.h	/^	HCI_STATUS_DIFFERENT_TRANSACTION_COLLISION				= 0X2a, \/* Different Transaction Collision *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_ENCRYPTION_MODE_NOT_ALLOW	include/rtw_btcoex.h	/^	HCI_STATUS_ENCRYPTION_MODE_NOT_ALLOW					= 0X25, \/* Encryption Mode Not Acceptable *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_EXTEND_INQUIRY_RSP_TOO_LARGE	include/rtw_btcoex.h	/^	HCI_STATUS_EXTEND_INQUIRY_RSP_TOO_LARGE				= 0X36, \/* Extended Inquiry Response Too Large *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_HOST_BUSY_PAIRING	include/rtw_btcoex.h	/^	HCI_STATUS_HOST_BUSY_PAIRING								= 0X38, \/* Host Busy - Pairing *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_HW_FAIL	include/rtw_btcoex.h	/^	HCI_STATUS_HW_FAIL										= 0X03, \/* Hardware Failure *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_INSTANT_PASSED	include/rtw_btcoex.h	/^	HCI_STATUS_INSTANT_PASSED								= 0X28, \/* Instant Passed *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_INSUFFICIENT_SECURITY	include/rtw_btcoex.h	/^	HCI_STATUS_INSUFFICIENT_SECURITY							= 0X2f, \/* Insufficient Security *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE	include/rtw_btcoex.h	/^	HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE					= 0X12, \/* Invalid HCI Command Parameters *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_INVALID_LMP_PARA	include/rtw_btcoex.h	/^	HCI_STATUS_INVALID_LMP_PARA								= 0X1e, \/* Invalid LMP Parameters *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_LINK_KEY_CAN_NOT_CHANGE	include/rtw_btcoex.h	/^	HCI_STATUS_LINK_KEY_CAN_NOT_CHANGE						= 0X26, \/* Link Key Can Not be Changed *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_LMP_ERROR_TRANSACTION_COLLISION	include/rtw_btcoex.h	/^	HCI_STATUS_LMP_ERROR_TRANSACTION_COLLISION				= 0X23, \/* LMP Error Transaction Collision *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_LMP_PDU_NOT_ALLOW	include/rtw_btcoex.h	/^	HCI_STATUS_LMP_PDU_NOT_ALLOW							= 0X24, \/* LMP PDU Not Allowed *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_LMP_RESPONSE_TIMEOUT	include/rtw_btcoex.h	/^	HCI_STATUS_LMP_RESPONSE_TIMEOUT							= 0X22, \/* LMP Response Timeout *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_MEM_CAP_EXCEED	include/rtw_btcoex.h	/^	HCI_STATUS_MEM_CAP_EXCEED								= 0X07, \/* Memory Capacity Exceeded *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_PAGE_TIMEOUT	include/rtw_btcoex.h	/^	HCI_STATUS_PAGE_TIMEOUT									= 0X04, \/* Page Timeout *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_PAIRING_UNIT_KEY_NOT_SUPPORT	include/rtw_btcoex.h	/^	HCI_STATUS_PAIRING_UNIT_KEY_NOT_SUPPORT					= 0X29, \/* Pairing With Unit Key Not Supported *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_PAIR_NOT_ALLOW	include/rtw_btcoex.h	/^	HCI_STATUS_PAIR_NOT_ALLOW								= 0X18, \/* Pairing Not Allowed *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_PARA_OUT_OF_RANGE	include/rtw_btcoex.h	/^	HCI_STATUS_PARA_OUT_OF_RANGE							= 0x30, \/* Parameter Out Of Mandatory Range *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_PIN_OR_KEY_MISSING	include/rtw_btcoex.h	/^	HCI_STATUS_PIN_OR_KEY_MISSING							= 0X06, \/* PIN or Key Missing *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_QOS_REJECT	include/rtw_btcoex.h	/^	HCI_STATUS_QOS_REJECT										= 0X2d, \/* QoS Rejected *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_QOS_UNACCEPT_PARA	include/rtw_btcoex.h	/^	HCI_STATUS_QOS_UNACCEPT_PARA							= 0X2c, \/* QoS Unacceptable Parameter *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_REMOTE_DEV_TERMINATE_CONNECT_POWER_OFF	include/rtw_btcoex.h	/^	HCI_STATUS_REMOTE_DEV_TERMINATE_CONNECT_POWER_OFF	= 0X15, \/* Remote Device Terminated Connection due to Power Off *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_REMOTE_DEV_TERMINATE_LOW_RESOURCE	include/rtw_btcoex.h	/^	HCI_STATUS_REMOTE_DEV_TERMINATE_LOW_RESOURCE			= 0X14, \/* Remote Device Terminated Connection due to Low Resources *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_REMOTE_USER_TERMINATE_CONNECT	include/rtw_btcoex.h	/^	HCI_STATUS_REMOTE_USER_TERMINATE_CONNECT				= 0X13, \/* Remote User Terminated Connection *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_REPEATE_ATTEMPT	include/rtw_btcoex.h	/^	HCI_STATUS_REPEATE_ATTEMPT								= 0X17, \/* Repeated Attempts *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_REQUEST_QOS_NOT_SUPPORT	include/rtw_btcoex.h	/^	HCI_STATUS_REQUEST_QOS_NOT_SUPPORT						= 0X27, \/* Requested QoS Not Supported *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_RESERVE_1	include/rtw_btcoex.h	/^	HCI_STATUS_RESERVE_1										= 0X2b, \/* Reserved *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_RESERVE_2	include/rtw_btcoex.h	/^	HCI_STATUS_RESERVE_2										= 0X31, \/* Reserved *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_RESERVE_3	include/rtw_btcoex.h	/^	HCI_STATUS_RESERVE_3										= 0X33, \/* Reserved *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_RESERVE_SOLT_VIOLATION	include/rtw_btcoex.h	/^	HCI_STATUS_RESERVE_SOLT_VIOLATION						= 0X34, \/* Reserved Slot Violation *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_ROLE_CHANGE_NOT_ALLOW	include/rtw_btcoex.h	/^	HCI_STATUS_ROLE_CHANGE_NOT_ALLOW						= 0X21, \/* Role Change Not Allowed *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_ROLE_SWITCH_FAIL	include/rtw_btcoex.h	/^	HCI_STATUS_ROLE_SWITCH_FAIL								= 0X35, \/* Role Switch Failed *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_ROLE_SWITCH_PENDING	include/rtw_btcoex.h	/^	HCI_STATUS_ROLE_SWITCH_PENDING							= 0X32, \/* Role Switch Pending *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_SEC_SIMPLE_PAIRING_NOT_SUPPORT	include/rtw_btcoex.h	/^	HCI_STATUS_SEC_SIMPLE_PAIRING_NOT_SUPPORT				= 0X37, \/* Secure Simple Pairing Not Supported By Host. *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_SOC_AIR_MODE_REJECT	include/rtw_btcoex.h	/^	HCI_STATUS_SOC_AIR_MODE_REJECT							= 0X1d, \/* SCO Air Mode Rejected *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_SOC_INTERVAL_REJECT	include/rtw_btcoex.h	/^	HCI_STATUS_SOC_INTERVAL_REJECT							= 0X1c, \/* SCO Interval Rejected *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_SOC_OFFSET_REJECT	include/rtw_btcoex.h	/^	HCI_STATUS_SOC_OFFSET_REJECT								= 0X1b, \/* SCO Offset Rejected *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_SUCCESS	include/rtw_btcoex.h	/^	HCI_STATUS_SUCCESS										= 0x00, \/* Success *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_SYN_CONNECT_LIMIT	include/rtw_btcoex.h	/^	HCI_STATUS_SYN_CONNECT_LIMIT								= 0X0a, \/* Synchronous Connection Limit To A Device Exceeded *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_UNKNOW_CONNECT_ID	include/rtw_btcoex.h	/^	HCI_STATUS_UNKNOW_CONNECT_ID							= 0X02, \/* Unknown Connection Identifier *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_UNKNOW_HCI_CMD	include/rtw_btcoex.h	/^	HCI_STATUS_UNKNOW_HCI_CMD								= 0x01, \/* Unknown HCI Command *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_UNKNOW_LMP_PDU	include/rtw_btcoex.h	/^	HCI_STATUS_UNKNOW_LMP_PDU								= 0X19, \/* Unknown LMP PDU *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_UNSPECIFIC_ERROR	include/rtw_btcoex.h	/^	HCI_STATUS_UNSPECIFIC_ERROR								= 0X1f, \/* Unspecified Error *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_UNSUPPORT_FEATURE_PARA_VALUE	include/rtw_btcoex.h	/^	HCI_STATUS_UNSUPPORT_FEATURE_PARA_VALUE				= 0X11, \/* Unsupported Feature or Parameter Value *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_UNSUPPORT_LMP_PARA_VALUE	include/rtw_btcoex.h	/^	HCI_STATUS_UNSUPPORT_LMP_PARA_VALUE					= 0X20, \/* Unsupported LMP Parameter Value *\/$/;"	e	enum:_HCI_STATUS
-HCI_STATUS_UNSUPPORT_REMOTE_LMP_FEATURE	include/rtw_btcoex.h	/^	HCI_STATUS_UNSUPPORT_REMOTE_LMP_FEATURE				= 0X1a, \/* Unsupported Remote Feature \/ Unsupported LMP Feature *\/$/;"	e	enum:_HCI_STATUS
-HCI_SUS_CTRL	include/hal_com_reg.h	1724;"	d
-HCI_SUS_ENTER	include/hal_data.h	196;"	d
-HCI_SUS_ENTERING	include/hal_data.h	199;"	d
-HCI_SUS_ERR	include/hal_data.h	200;"	d
-HCI_SUS_LEAVE	include/hal_data.h	198;"	d
-HCI_SUS_LEAVING	include/hal_data.h	197;"	d
-HCI_TXDMA_EN	include/hal_com_reg.h	1315;"	d
-HCI_WIFI_CONNECTION_STATUS	include/rtw_btcoex.h	/^	HCI_WIFI_CONNECTION_STATUS						= 0x0302$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_WIFI_CURRENT_BANDWIDTH	include/rtw_btcoex.h	/^	HCI_WIFI_CURRENT_BANDWIDTH						= 0x0301,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HCI_WIFI_CURRENT_CHANNEL	include/rtw_btcoex.h	/^	HCI_WIFI_CURRENT_CHANNEL						= 0x0300,$/;"	e	enum:HCI_EXTENSION_COMMANDS
-HDATA_RATE	include/hal_com.h	127;"	d
-HIGH_QUEUE_INX	include/rtw_xmit.h	108;"	d
-HIQ_XMIT_COUNTS	core/rtw_ap.c	2277;"	d	file:
-HIS_REPORT	include/rtw_recv.h	/^	HIS_REPORT,\/* USB HISR RPT *\/$/;"	e	enum:_RX_PACKET_TYPE
-HI_QUEUE_IDX	include/hal_com_reg.h	1627;"	d
-HL_SMTANT_2WIRE_DATA_LEN	hal/phydm/phydm_antdiv.h	133;"	d
-HL_SW_SMART_ANT_TYPE1	hal/phydm/phydm_antdiv.h	/^	HL_SW_SMART_ANT_TYPE1	= 0x10 \/*Hong-Lin Smart antenna use for 8821AE which is a 2 Ant. entitys, and each Ant. is equipped with 4 antenna patterns*\/$/;"	e	enum:_ANT_DIV_TYPE
-HPQ_PGNUM_8814A	include/rtl8814a_hal.h	135;"	d
-HPQ_PGNUM_8814A	include/rtl8814a_hal.h	142;"	d
-HPQ_PUBLIC_DIS	include/hal_com_reg.h	1410;"	d
-HP_THERMAL_NUM	hal/phydm/phydm_powertracking_ap.h	51;"	d
-HP_THERMAL_NUM	hal/phydm/phydm_powertracking_ce.h	40;"	d
-HP_THERMAL_NUM	hal/phydm/phydm_powertracking_win.h	42;"	d
-HQSEL_BEQ	include/hal_com_reg.h	1363;"	d
-HQSEL_BKQ	include/hal_com_reg.h	1364;"	d
-HQSEL_HIQ	include/hal_com_reg.h	1366;"	d
-HQSEL_MGTQ	include/hal_com_reg.h	1365;"	d
-HQSEL_VIQ	include/hal_com_reg.h	1362;"	d
-HQSEL_VOQ	include/hal_com_reg.h	1361;"	d
-HSIMR_GPIO12_0_INT_EN	include/hal_com_reg.h	629;"	d
-HSIMR_GPIO9_INT_EN	include/hal_com_reg.h	633;"	d
-HSIMR_PDN_INT_EN	include/hal_com_reg.h	632;"	d
-HSIMR_RON_INT_EN	include/hal_com_reg.h	631;"	d
-HSIMR_SPS_OCP_INT_EN	include/hal_com_reg.h	630;"	d
-HSISR_GPIO12_0_INT	include/hal_com_reg.h	638;"	d
-HSISR_GPIO9_INT	include/hal_com_reg.h	642;"	d
-HSISR_PDNINT	include/hal_com_reg.h	641;"	d
-HSISR_RON_INT	include/hal_com_reg.h	640;"	d
-HSISR_SPS_OCP_INT	include/hal_com_reg.h	639;"	d
-HS_SUPPORT	hal/btc/Mp_Precomp.h	60;"	d
-HS_SUPPORT	hal/btc/Mp_Precomp.h	64;"	d
-HTC_LOC_CTRL	include/hal_com_reg.h	1558;"	d
-HTOnAssocRsp	core/rtw_wlan_util.c	/^void HTOnAssocRsp(_adapter *padapter)$/;"	f
-HT_1SS	include/ieee80211.h	/^	HT_1SS = HT_MCS0_MCS7,$/;"	e	enum:_RATE_SECTION
-HT_2SS	include/ieee80211.h	/^	HT_2SS = HT_MCS8_MCS15,$/;"	e	enum:_RATE_SECTION
-HT_3SS	include/ieee80211.h	/^	HT_3SS = HT_MCS16_MCS23,$/;"	e	enum:_RATE_SECTION
-HT_4SS	include/ieee80211.h	/^	HT_4SS = HT_MCS24_MCS31,$/;"	e	enum:_RATE_SECTION
-HT_AGG_SIZE_16K	include/rtw_ht.h	/^	HT_AGG_SIZE_16K = 1,$/;"	e	enum:AGGRE_SIZE
-HT_AGG_SIZE_32K	include/rtw_ht.h	/^	HT_AGG_SIZE_32K = 2,$/;"	e	enum:AGGRE_SIZE
-HT_AGG_SIZE_64K	include/rtw_ht.h	/^	HT_AGG_SIZE_64K = 3,$/;"	e	enum:AGGRE_SIZE
-HT_AGG_SIZE_8K	include/rtw_ht.h	/^	HT_AGG_SIZE_8K = 0,$/;"	e	enum:AGGRE_SIZE
-HT_AMPDU_PARA_ARG	include/rtw_ht.h	147;"	d
-HT_AMPDU_PARA_FMT	include/rtw_ht.h	144;"	d
-HT_CAP_AMPDU_DENSITY	include/wifi.h	/^} HT_CAP_AMPDU_DENSITY;$/;"	t	typeref:enum:_HT_CAP_AMPDU_DENSITY
-HT_CAP_AMPDU_FACTOR	include/wifi.h	/^} HT_CAP_AMPDU_FACTOR;$/;"	t	typeref:enum:_HT_CAP_AMPDU_FACTOR
-HT_CAP_ELE_AMPDU_PARA	include/rtw_ht.h	140;"	d
-HT_CAP_ELE_CAP_INFO	include/rtw_ht.h	110;"	d
-HT_CAP_ELE_RX_MCS_MAP	include/rtw_ht.h	154;"	d
-HT_CAP_ELE_SUP_MCS_SET	include/rtw_ht.h	153;"	d
-HT_INFO_HT_PARAM_CTRL_ACCESS_ONLY	include/wifi.h	1026;"	d
-HT_INFO_HT_PARAM_REC_TRANS_CHNL_WIDTH	include/wifi.h	1024;"	d
-HT_INFO_HT_PARAM_RIFS_MODE	include/wifi.h	1025;"	d
-HT_INFO_HT_PARAM_SECONDARY_CHNL_ABOVE	include/wifi.h	1022;"	d
-HT_INFO_HT_PARAM_SECONDARY_CHNL_BELOW	include/wifi.h	1023;"	d
-HT_INFO_HT_PARAM_SECONDARY_CHNL_OFF_MASK	include/wifi.h	1021;"	d
-HT_INFO_HT_PARAM_SRV_INTERVAL_GRANULARITY	include/wifi.h	1027;"	d
-HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT	include/wifi.h	1032;"	d
-HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT	include/wifi.h	1034;"	d
-HT_INFO_OPERATION_MODE_OP_MODE_MASK	include/wifi.h	1029;"	d
-HT_INFO_OPERATION_MODE_OP_MODE_OFFSET	include/wifi.h	1031;"	d
-HT_INFO_OPERATION_MODE_TRANSMIT_BURST_LIMIT	include/wifi.h	1033;"	d
-HT_INFO_STBC_PARAM_DUAL_BEACON	include/wifi.h	1036;"	d
-HT_INFO_STBC_PARAM_DUAL_STBC_PROTECT	include/wifi.h	1037;"	d
-HT_INFO_STBC_PARAM_LSIG_TXOP_PROTECT_ALLOWED	include/wifi.h	1039;"	d
-HT_INFO_STBC_PARAM_PCO_ACTIVE	include/wifi.h	1040;"	d
-HT_INFO_STBC_PARAM_PCO_PHASE	include/wifi.h	1041;"	d
-HT_INFO_STBC_PARAM_SECONDARY_BCN	include/wifi.h	1038;"	d
-HT_IOT_PEER_AIRGO	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_AIRGO				= 11,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_ATHEROS	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_ATHEROS			= 5,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_BROADCOM	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_BROADCOM		= 3,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_CISCO	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_CISCO				= 6,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_E	include/rtw_mlme_ext.h	/^} HT_IOT_PEER_E, *PHTIOT_PEER_E;$/;"	t	typeref:enum:_HT_IOT_PEER
-HT_IOT_PEER_INTEL	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_INTEL				= 12,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_MARVELL	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_MARVELL			= 8,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_MAX	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_MAX				= 18$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_MERU	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_MERU				= 7,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_RALINK	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_RALINK			= 4,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_REALTEK	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_REALTEK			= 1,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_REALTEK_81XX	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_REALTEK_81XX		= 14,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_REALTEK_92SE	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_REALTEK_92SE		= 2,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_REALTEK_JAGUAR_BCUTAP	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_REALTEK_JAGUAR_BCUTAP = 16,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_REALTEK_SOFTAP	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_REALTEK_SOFTAP 	= 9,\/* peer is RealTek SOFT_AP, by Bohn, 2009.12.17 *\/$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_REALTEK_WOW	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_REALTEK_WOW		= 15,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_RTK_APCLIENT	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_RTK_APCLIENT		= 13,$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_SELF_SOFTAP	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_SELF_SOFTAP 		= 10, \/* Self is SoftAP *\/$/;"	e	enum:_HT_IOT_PEER
-HT_IOT_PEER_UNKNOWN	include/rtw_mlme_ext.h	/^	HT_IOT_PEER_UNKNOWN			= 0,$/;"	e	enum:_HT_IOT_PEER
-HT_MCS0_MCS7	include/ieee80211.h	/^	HT_MCS0_MCS7 = 2,$/;"	e	enum:_RATE_SECTION
-HT_MCS16_MCS23	include/ieee80211.h	/^	HT_MCS16_MCS23 = 4,$/;"	e	enum:_RATE_SECTION
-HT_MCS24_MCS31	include/ieee80211.h	/^	HT_MCS24_MCS31 = 5,$/;"	e	enum:_RATE_SECTION
-HT_MCS8_MCS15	include/ieee80211.h	/^	HT_MCS8_MCS15 = 3,$/;"	e	enum:_RATE_SECTION
-HT_OP_ELE_OP_INFO	include/rtw_ht.h	192;"	d
-HT_SIG	include/rtw_mp.h	/^	u8			HT_SIG[6];$/;"	m	struct:_RT_PMAC_TX_INFO
-HT_SIG_generator	core/rtw_mp.c	/^void HT_SIG_generator($/;"	f
-HT_SUP_MCS_SET_ARG	include/rtw_ht.h	164;"	d
-HT_SUP_MCS_SET_FMT	include/rtw_ht.h	161;"	d
-HT_cap	include/wifi.h	/^		unsigned char HT_cap[26];$/;"	m	union:HT_caps_element::__anon54
-HT_cap	include/wifi.h	/^		unsigned char HT_cap[26];$/;"	m	union:HT_caps_element::__anon56
-HT_cap_element	include/wifi.h	/^		} HT_cap_element;$/;"	m	union:HT_caps_element::__anon54	typeref:struct:HT_caps_element::__anon54::__anon55
-HT_cap_element	include/wifi.h	/^		} HT_cap_element;$/;"	m	union:HT_caps_element::__anon56	typeref:struct:HT_caps_element::__anon56::__anon57
-HT_caps	include/rtw_mlme_ext.h	/^	struct HT_caps_element	HT_caps;$/;"	m	struct:mlme_ext_info	typeref:struct:mlme_ext_info::HT_caps_element
-HT_caps_element	include/wifi.h	/^struct HT_caps_element {$/;"	s
-HT_caps_enable	include/rtw_mlme_ext.h	/^	u8	HT_caps_enable;$/;"	m	struct:mlme_ext_info
-HT_caps_handler	core/rtw_wlan_util.c	/^void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)$/;"	f
-HT_caps_info	include/wifi.h	/^			unsigned short	HT_caps_info;$/;"	m	struct:HT_caps_element::__anon54::__anon55
-HT_caps_info	include/wifi.h	/^			unsigned short	HT_caps_info;$/;"	m	struct:HT_caps_element::__anon56::__anon57
-HT_enable	include/rtw_mlme_ext.h	/^	u8	HT_enable;$/;"	m	struct:mlme_ext_info
-HT_ext_caps	include/wifi.h	/^			unsigned short	HT_ext_caps;$/;"	m	struct:HT_caps_element::__anon54::__anon55
-HT_ext_caps	include/wifi.h	/^			unsigned short	HT_ext_caps;$/;"	m	struct:HT_caps_element::__anon56::__anon57
-HT_info	include/rtw_mlme_ext.h	/^	struct HT_info_element		HT_info;$/;"	m	struct:mlme_ext_info	typeref:struct:mlme_ext_info::HT_info_element
-HT_info_element	include/wifi.h	/^struct HT_info_element {$/;"	s
-HT_info_enable	include/rtw_mlme_ext.h	/^	u8	HT_info_enable;$/;"	m	struct:mlme_ext_info
-HT_info_handler	core/rtw_wlan_util.c	/^void HT_info_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)$/;"	f
-HT_protection	include/rtw_mlme_ext.h	/^	u8	HT_protection;$/;"	m	struct:mlme_ext_info
-HWPI	include/rtw_cmd.h	/^	HWPI,$/;"	e	enum:RFINTFS
-HWSET_MAX_SIZE	include/hal_com.h	487;"	d
-HWSET_MAX_SIZE_1024	include/rtw_eeprom.h	30;"	d
-HWSET_MAX_SIZE_128	include/rtw_eeprom.h	27;"	d
-HWSET_MAX_SIZE_256	include/rtw_eeprom.h	28;"	d
-HWSET_MAX_SIZE_512	include/rtw_eeprom.h	29;"	d
-HWSET_MAX_SIZE_8188F	include/rtl8188f_hal.h	167;"	d
-HWSET_MAX_SIZE_8192E	include/rtl8192e_hal.h	194;"	d
-HWSET_MAX_SIZE_8703B	include/rtl8703b_hal.h	169;"	d
-HWSET_MAX_SIZE_8723B	include/rtl8723b_hal.h	169;"	d
-HWSET_MAX_SIZE_8723D	include/rtl8723d_hal.h	175;"	d
-HWSET_MAX_SIZE_8814A	include/rtl8814a_hal.h	184;"	d
-HWSET_MAX_SIZE_JAGUAR	include/rtl8812a_hal.h	239;"	d
-HWSI	include/rtw_cmd.h	/^	HWSI,$/;"	e	enum:RFINTFS
-HWTxmode	include/rtw_mp.h	/^	u8 HWTxmode;$/;"	m	struct:_MPT_CONTEXT
-HWXMIT_ENTRY	include/rtw_xmit.h	162;"	d
-HW_BLOCK_E	include/hal_phy.h	/^} HW_BLOCK_E, *PHW_BLOCK_E;$/;"	t	typeref:enum:_HW_BLOCK
-HW_BLOCK_MAC	include/hal_phy.h	/^	HW_BLOCK_MAC = 0,$/;"	e	enum:_HW_BLOCK
-HW_BLOCK_MAXIMUM	include/hal_phy.h	/^	HW_BLOCK_MAXIMUM = 4, \/* Never use this *\/$/;"	e	enum:_HW_BLOCK
-HW_BLOCK_PHY0	include/hal_phy.h	/^	HW_BLOCK_PHY0 = 1,$/;"	e	enum:_HW_BLOCK
-HW_BLOCK_PHY1	include/hal_phy.h	/^	HW_BLOCK_PHY1 = 2,$/;"	e	enum:_HW_BLOCK
-HW_BLOCK_RF	include/hal_phy.h	/^	HW_BLOCK_RF = 3,$/;"	e	enum:_HW_BLOCK
-HW_CONTROL	include/rtw_mp.h	/^	HW_CONTROL,		\/* hw encryption& decryption *\/$/;"	e	enum:_ENCRY_CTRL_STATE_
-HW_DEF_RA_INFO_DUMP	include/hal_intf.h	/^	HW_DEF_RA_INFO_DUMP,$/;"	e	enum:_HAL_DEF_VARIABLE
-HW_ENCRY_SW_DECRY	include/rtw_mp.h	/^	HW_ENCRY_SW_DECRY,	\/* hw encryption & sw decryption *\/$/;"	e	enum:_ENCRY_CTRL_STATE_
-HW_LED	include/hal_com_led.h	/^	HW_LED, \/* HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes) *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-HW_LED	include/hal_com_led.h	/^	HW_LED, \/* HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes, see MAC.CONFIG1 for details.) *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-HW_LED	include/hal_com_led.h	/^	HW_LED, \/* HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes, see MAC.CONFIG1 for details.) *\/$/;"	e	enum:_LED_STRATEGY_USB
-HW_PORT0	include/drv_types.h	/^	HW_PORT0,$/;"	e	enum:_hw_port
-HW_PORT1	include/drv_types.h	/^	HW_PORT1,$/;"	e	enum:_hw_port
-HW_PORT2	include/drv_types.h	/^	HW_PORT2,$/;"	e	enum:_hw_port
-HW_PORT3	include/drv_types.h	/^	HW_PORT3,$/;"	e	enum:_hw_port
-HW_PORT4	include/drv_types.h	/^	HW_PORT4,$/;"	e	enum:_hw_port
-HW_PORT_NUM_8188F	include/rtl8188f_spec.h	297;"	d
-HW_PORT_NUM_8192E	include/rtl8192e_spec.h	323;"	d
-HW_PORT_NUM_8703B	include/rtl8703b_spec.h	474;"	d
-HW_PORT_NUM_8723B	include/rtl8723b_spec.h	290;"	d
-HW_PORT_NUM_8723D	include/rtl8723d_spec.h	451;"	d
-HW_PORT_NUM_8812A	include/rtl8812a_spec.h	266;"	d
-HW_PORT_NUM_8814A	include/rtl8814a_spec.h	645;"	d
-HW_PORT_NUM_8821A	include/rtl8821a_spec.h	102;"	d
-HW_PORT_NUM_88E	include/rtl8188e_spec.h	152;"	d
-HW_PWR0	include/rtw_pwrctrl.h	30;"	d
-HW_PWR1	include/rtw_pwrctrl.h	31;"	d
-HW_PWR2	include/rtw_pwrctrl.h	32;"	d
-HW_PWR3	include/rtw_pwrctrl.h	33;"	d
-HW_PWR4	include/rtw_pwrctrl.h	34;"	d
-HW_QUEUE_ENTRY	include/rtw_xmit.h	111;"	d
-HW_RTS_EN	include/rtl8188e_xmit.h	79;"	d
-HW_RTS_EN	include/rtl8192e_xmit.h	184;"	d
-HW_RTS_EN	include/rtl8812a_xmit.h	77;"	d
-HW_SET_GPIO_WL_CTRL	include/hal_intf.h	/^	HW_SET_GPIO_WL_CTRL,$/;"	e	enum:_HW_VARIABLES
-HW_SSN	include/rtl8188e_xmit.h	74;"	d
-HW_SSN	include/rtl8192e_xmit.h	179;"	d
-HW_SSN	include/rtl8812a_xmit.h	72;"	d
-HW_VARIABLES	include/hal_intf.h	/^} HW_VARIABLES;$/;"	t	typeref:enum:_HW_VARIABLES
-HW_VAR_ACK_PREAMBLE	include/hal_intf.h	/^	HW_VAR_ACK_PREAMBLE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_ACM_CTRL	include/hal_intf.h	/^	HW_VAR_ACM_CTRL,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_AC_PARAM_BE	include/hal_intf.h	/^	HW_VAR_AC_PARAM_BE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_AC_PARAM_BK	include/hal_intf.h	/^	HW_VAR_AC_PARAM_BK,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_AC_PARAM_VI	include/hal_intf.h	/^	HW_VAR_AC_PARAM_VI,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_AC_PARAM_VO	include/hal_intf.h	/^	HW_VAR_AC_PARAM_VO,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_AMPDU_FACTOR	include/hal_intf.h	/^	HW_VAR_AMPDU_FACTOR,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_AMPDU_MAX_TIME	include/hal_intf.h	/^	HW_VAR_AMPDU_MAX_TIME,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_AMPDU_MIN_SPACE	include/hal_intf.h	/^	HW_VAR_AMPDU_MIN_SPACE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_APFM_ON_MAC	include/hal_intf.h	/^	HW_VAR_APFM_ON_MAC, \/* Auto FSM to Turn On, include clock, isolation, power control for MAC only *\/$/;"	e	enum:_HW_VARIABLES
-HW_VAR_ASIX_IOT	include/hal_intf.h	/^	HW_VAR_ASIX_IOT,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_BASIC_RATE	include/hal_intf.h	/^	HW_VAR_BASIC_RATE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_BCN_FUNC	include/hal_intf.h	/^	HW_VAR_BCN_FUNC,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_BCN_VALID	include/hal_intf.h	/^	HW_VAR_BCN_VALID,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_BEACON_INTERVAL	include/hal_intf.h	/^	HW_VAR_BEACON_INTERVAL,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_BEST_AMPDU_DENSITY	include/hal_intf.h	/^	HW_VAR_BEST_AMPDU_DENSITY,$/;"	e	enum:_HAL_DEF_VARIABLE
-HW_VAR_BSSID	include/hal_intf.h	/^	HW_VAR_BSSID,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_BT_ISSUE_DELBA	include/hal_intf.h	/^	HW_VAR_BT_ISSUE_DELBA,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_BT_SET_COEXIST	include/hal_intf.h	/^	HW_VAR_BT_SET_COEXIST,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CAM_EMPTY_ENTRY	include/hal_intf.h	/^	HW_VAR_CAM_EMPTY_ENTRY,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CAM_INVALID_ALL	include/hal_intf.h	/^	HW_VAR_CAM_INVALID_ALL,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CHECK_BSSID	include/hal_intf.h	/^	HW_VAR_CHECK_BSSID,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CHECK_TXBUF	include/hal_intf.h	/^	HW_VAR_CHECK_TXBUF,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CHK_HI_QUEUE_EMPTY	include/hal_intf.h	/^	HW_VAR_CHK_HI_QUEUE_EMPTY,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CH_SW_IQK_INFO_BACKUP	include/hal_intf.h	/^	HW_VAR_CH_SW_IQK_INFO_BACKUP,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CH_SW_IQK_INFO_RESTORE	include/hal_intf.h	/^	HW_VAR_CH_SW_IQK_INFO_RESTORE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO	include/hal_intf.h	/^	HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CORRECT_TSF	include/hal_intf.h	/^	HW_VAR_CORRECT_TSF,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_CPWM	include/hal_intf.h	/^	HW_VAR_CPWM,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_DL_BCN_SEL	include/hal_intf.h	/^	HW_VAR_DL_BCN_SEL,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_DL_RSVD_PAGE	include/hal_intf.h	/^	HW_VAR_DL_RSVD_PAGE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_DM_IN_LPS	include/hal_intf.h	/^	HW_VAR_DM_IN_LPS,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_DO_IQK	include/hal_intf.h	/^	HW_VAR_DO_IQK,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_DUMP_MAC_QUEUE_INFO	include/hal_intf.h	/^	HW_VAR_DUMP_MAC_QUEUE_INFO,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_EFUSE_BT_BYTES	include/hal_intf.h	/^	HW_VAR_EFUSE_BT_BYTES,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_EFUSE_BT_USAGE	include/hal_intf.h	/^	HW_VAR_EFUSE_BT_USAGE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_EFUSE_BYTES	include/hal_intf.h	/^	HW_VAR_EFUSE_BYTES,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_EFUSE_USAGE	include/hal_intf.h	/^	HW_VAR_EFUSE_USAGE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_EN_HW_UPDATE_TSF	include/hal_intf.h	/^	HW_VAR_EN_HW_UPDATE_TSF,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_FIFO_CLEARN_UP	include/hal_intf.h	/^	HW_VAR_FIFO_CLEARN_UP,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_FWLPS_RF_ON	include/hal_intf.h	/^	HW_VAR_FWLPS_RF_ON,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_FW_PS_STATE	include/hal_intf.h	/^	HW_VAR_FW_PS_STATE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_H2C_FW_JOINBSSRPT	include/hal_intf.h	/^	HW_VAR_H2C_FW_JOINBSSRPT,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_H2C_FW_P2P_PS_OFFLOAD	include/hal_intf.h	/^	HW_VAR_H2C_FW_P2P_PS_OFFLOAD,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_H2C_FW_PWRMODE	include/hal_intf.h	/^	HW_VAR_H2C_FW_PWRMODE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_H2C_PS_TUNE_PARAM	include/hal_intf.h	/^	HW_VAR_H2C_PS_TUNE_PARAM,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_HCI_SUS_STATE	include/hal_intf.h	/^	HW_VAR_HCI_SUS_STATE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_HW_REG_TIMER_INIT	include/hal_intf.h	/^	HW_VAR_HW_REG_TIMER_INIT,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_HW_REG_TIMER_RESTART	include/hal_intf.h	/^	HW_VAR_HW_REG_TIMER_RESTART,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_HW_REG_TIMER_START	include/hal_intf.h	/^	HW_VAR_HW_REG_TIMER_START,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_HW_REG_TIMER_STOP	include/hal_intf.h	/^	HW_VAR_HW_REG_TIMER_STOP,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_INIT_RTS_RATE	include/hal_intf.h	/^	HW_VAR_INIT_RTS_RATE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_LPS_POFF_DEINIT	include/hal_intf.h	/^	HW_VAR_LPS_POFF_DEINIT,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_LPS_POFF_INIT	include/hal_intf.h	/^	HW_VAR_LPS_POFF_INIT,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_LPS_POFF_SET_MODE	include/hal_intf.h	/^	HW_VAR_LPS_POFF_SET_MODE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_LPS_POFF_WOW_EN	include/hal_intf.h	/^	HW_VAR_LPS_POFF_WOW_EN,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MACID_LINK	include/hal_intf.h	/^	HW_VAR_MACID_LINK,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MACID_NOLINK	include/hal_intf.h	/^	HW_VAR_MACID_NOLINK,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MACID_SLEEP	include/hal_intf.h	/^	HW_VAR_MACID_SLEEP,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MACID_WAKEUP	include/hal_intf.h	/^	HW_VAR_MACID_WAKEUP,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MAC_ADDR	include/hal_intf.h	/^	HW_VAR_MAC_ADDR,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MAX_RX_AMPDU_FACTOR	include/hal_intf.h	/^	HW_VAR_MAX_RX_AMPDU_FACTOR,$/;"	e	enum:_HAL_DEF_VARIABLE
-HW_VAR_MBSSID_CAM_CLEAR	include/hal_intf.h	/^	HW_VAR_MBSSID_CAM_CLEAR,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MBSSID_CAM_WRITE	include/hal_intf.h	/^	HW_VAR_MBSSID_CAM_WRITE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MEDIA_STATUS	include/hal_intf.h	/^	HW_VAR_MEDIA_STATUS,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MLME_DISCONNECT	include/hal_intf.h	/^	HW_VAR_MLME_DISCONNECT,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MLME_JOIN	include/hal_intf.h	/^	HW_VAR_MLME_JOIN,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_MLME_SITESURVEY	include/hal_intf.h	/^	HW_VAR_MLME_SITESURVEY,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_NAV_UPPER	include/hal_intf.h	/^	HW_VAR_NAV_UPPER,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_OFF_RCR_AM	include/hal_intf.h	/^	HW_VAR_OFF_RCR_AM,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_ON_RCR_AM	include/hal_intf.h	/^	HW_VAR_ON_RCR_AM,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_PCIE_STOP_TX_DMA	include/hal_intf.h	/^	HW_VAR_PCIE_STOP_TX_DMA,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_PORT_SWITCH	include/hal_intf.h	/^	HW_VAR_PORT_SWITCH,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_RCR_MBSSID_EN	include/hal_intf.h	/^	HW_VAR_RCR_MBSSID_EN,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_RESP_SIFS	include/hal_intf.h	/^	HW_VAR_RESP_SIFS,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_RESTORE_HW_SEQ	include/hal_intf.h	/^	HW_VAR_RESTORE_HW_SEQ,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_RF_TYPE	include/hal_intf.h	/^	HW_VAR_RF_TYPE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_RPT_TIMER_SETTING	include/hal_intf.h	/^	HW_VAR_RPT_TIMER_SETTING,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_RPWM_TOG	include/hal_intf.h	/^	HW_VAR_RPWM_TOG,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_RXDMA_AGG_PG_TH	include/hal_intf.h	/^	HW_VAR_RXDMA_AGG_PG_TH,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SEC_CFG	include/hal_intf.h	/^	HW_VAR_SEC_CFG,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SEC_DK_CFG	include/hal_intf.h	/^	HW_VAR_SEC_DK_CFG,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SET_OPMODE	include/hal_intf.h	/^	HW_VAR_SET_OPMODE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SET_REQ_FW_PS	include/hal_intf.h	/^	HW_VAR_SET_REQ_FW_PS,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SET_RPWM	include/hal_intf.h	/^	HW_VAR_SET_RPWM,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SLOT_TIME	include/hal_intf.h	/^	HW_VAR_SLOT_TIME,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SOUNDING_CLK	include/hal_intf.h	/^	HW_VAR_SOUNDING_CLK,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SOUNDING_ENTER	include/hal_intf.h	/^	HW_VAR_SOUNDING_ENTER,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SOUNDING_FW_NDPA	include/hal_intf.h	/^	HW_VAR_SOUNDING_FW_NDPA,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SOUNDING_LEAVE	include/hal_intf.h	/^	HW_VAR_SOUNDING_LEAVE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SOUNDING_RATE	include/hal_intf.h	/^	HW_VAR_SOUNDING_RATE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SOUNDING_SET_GID_TABLE	include/hal_intf.h	/^	HW_VAR_SOUNDING_SET_GID_TABLE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SOUNDING_STATUS	include/hal_intf.h	/^	HW_VAR_SOUNDING_STATUS,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SWITCH_EPHY_WoWLAN	include/hal_intf.h	/^	HW_VAR_SWITCH_EPHY_WoWLAN,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_SYS_CLKR	include/hal_intf.h	/^	HW_VAR_SYS_CLKR,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_TDLS_BCN_EARLY_C2H_RPT	include/hal_intf.h	/^	HW_VAR_TDLS_BCN_EARLY_C2H_RPT$/;"	e	enum:_HW_VARIABLES
-HW_VAR_TDLS_RS_RCR	include/hal_intf.h	/^	HW_VAR_TDLS_RS_RCR,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_TDLS_WRCR	include/hal_intf.h	/^	HW_VAR_TDLS_WRCR,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_TRIGGER_GPIO_0	include/hal_intf.h	/^	HW_VAR_TRIGGER_GPIO_0,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_TXPAUSE	include/hal_intf.h	/^	HW_VAR_TXPAUSE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_TX_RPT_MAX_MACID	include/hal_intf.h	/^	HW_VAR_TX_RPT_MAX_MACID,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_USB_MODE	include/hal_intf.h	/^	HW_VAR_USB_MODE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_WAKEUP_REASON	include/hal_intf.h	/^	HW_VAR_WAKEUP_REASON,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_WIRELESS_MODE	include/hal_intf.h	/^	HW_VAR_WIRELESS_MODE,$/;"	e	enum:_HW_VARIABLES
-HW_VAR_WOWLAN	include/hal_intf.h	/^	HW_VAR_WOWLAN,$/;"	e	enum:_HW_VARIABLES
-HZ	include/osdep_service_bsd.h	123;"	d
-HZ	include/osdep_service_xp.h	68;"	d
-H_CUT_VERSION	include/HalVerDef.h	/^	H_CUT_VERSION		=	7,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-HalComTxbf_Get	hal/phydm/txbf/halcomtxbf.c	/^HalComTxbf_Get($/;"	f
-HalComTxbf_Get	hal/phydm/txbf/halcomtxbf.h	175;"	d
-HalComTxbf_Set	hal/phydm/txbf/halcomtxbf.c	/^HalComTxbf_Set($/;"	f
-HalData	include/drv_types.h	/^	PVOID			HalData;$/;"	m	struct:_ADAPTER
-HalDetectPwrDownMode	hal/rtl8723d/sdio/sdio_halinit.c	/^static BOOLEAN HalDetectPwrDownMode(PADAPTER Adapter)$/;"	f	file:
-HalFunc	include/drv_types.h	/^	struct hal_ops	HalFunc;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::hal_ops
-HalPwrSeqCmdParsing	hal/HalPwrSeqCmd.c	/^u8 HalPwrSeqCmdParsing($/;"	f
-HalQueryTxBufferStatus8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^u8 HalQueryTxBufferStatus8723DSdio(PADAPTER padapter)$/;"	f
-HalQueryTxOQTBufferStatus8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^u8 HalQueryTxOQTBufferStatus8723DSdio(PADAPTER padapter)$/;"	f
-HalRxAggr8723DSdio	hal/rtl8723d/sdio/sdio_halinit.c	/^static void HalRxAggr8723DSdio(PADAPTER padapter)$/;"	f	file:
-HalSdioGetCmdAddr8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^static void HalSdioGetCmdAddr8723DSdio($/;"	f	file:
-HalSetBrateCfg	hal/hal_com.c	/^void	HalSetBrateCfg($/;"	f
-HalTxbf8192E_Enter	hal/phydm/txbf/haltxbf8192e.c	/^HalTxbf8192E_Enter($/;"	f
-HalTxbf8192E_Enter	hal/phydm/txbf/haltxbf8192e.h	43;"	d
-HalTxbf8192E_Enter	hal/phydm/txbf/haltxbf8192e.h	53;"	d
-HalTxbf8192E_FwTxBF	hal/phydm/txbf/haltxbf8192e.c	/^HalTxbf8192E_FwTxBF($/;"	f
-HalTxbf8192E_FwTxBF	hal/phydm/txbf/haltxbf8192e.h	46;"	d
-HalTxbf8192E_FwTxBF	hal/phydm/txbf/haltxbf8192e.h	56;"	d
-HalTxbf8192E_Leave	hal/phydm/txbf/haltxbf8192e.c	/^HalTxbf8192E_Leave($/;"	f
-HalTxbf8192E_Leave	hal/phydm/txbf/haltxbf8192e.h	44;"	d
-HalTxbf8192E_Leave	hal/phydm/txbf/haltxbf8192e.h	54;"	d
-HalTxbf8192E_Status	hal/phydm/txbf/haltxbf8192e.c	/^HalTxbf8192E_Status($/;"	f
-HalTxbf8192E_Status	hal/phydm/txbf/haltxbf8192e.h	45;"	d
-HalTxbf8192E_Status	hal/phydm/txbf/haltxbf8192e.h	55;"	d
-HalTxbf8192E_setNDPArate	hal/phydm/txbf/haltxbf8192e.c	/^HalTxbf8192E_setNDPArate($/;"	f
-HalTxbf8192E_setNDPArate	hal/phydm/txbf/haltxbf8192e.h	42;"	d
-HalTxbf8192E_setNDPArate	hal/phydm/txbf/haltxbf8192e.h	52;"	d
-HalTxbf8812A_setNDPArate	hal/phydm/txbf/haltxbfjaguar.c	/^HalTxbf8812A_setNDPArate($/;"	f
-HalTxbf8812A_setNDPArate	hal/phydm/txbf/haltxbfjaguar.h	55;"	d
-HalTxbf8812A_setNDPArate	hal/phydm/txbf/haltxbfjaguar.h	65;"	d
-HalTxbf8814A_Enter	hal/phydm/txbf/haltxbf8814a.c	/^HalTxbf8814A_Enter($/;"	f
-HalTxbf8814A_Enter	hal/phydm/txbf/haltxbf8814a.h	61;"	d
-HalTxbf8814A_Enter	hal/phydm/txbf/haltxbf8814a.h	74;"	d
-HalTxbf8814A_FwTxBF	hal/phydm/txbf/haltxbf8814a.c	/^HalTxbf8814A_FwTxBF($/;"	f
-HalTxbf8814A_FwTxBF	hal/phydm/txbf/haltxbf8814a.h	66;"	d
-HalTxbf8814A_FwTxBF	hal/phydm/txbf/haltxbf8814a.h	79;"	d
-HalTxbf8814A_GetTxRate	hal/phydm/txbf/haltxbf8814a.c	/^HalTxbf8814A_GetTxRate($/;"	f
-HalTxbf8814A_GetTxRate	hal/phydm/txbf/haltxbf8814a.h	65;"	d
-HalTxbf8814A_GetTxRate	hal/phydm/txbf/haltxbf8814a.h	78;"	d
-HalTxbf8814A_Leave	hal/phydm/txbf/haltxbf8814a.c	/^HalTxbf8814A_Leave($/;"	f
-HalTxbf8814A_Leave	hal/phydm/txbf/haltxbf8814a.h	62;"	d
-HalTxbf8814A_Leave	hal/phydm/txbf/haltxbf8814a.h	75;"	d
-HalTxbf8814A_ResetTxPath	hal/phydm/txbf/haltxbf8814a.c	/^HalTxbf8814A_ResetTxPath($/;"	f
-HalTxbf8814A_ResetTxPath	hal/phydm/txbf/haltxbf8814a.h	64;"	d
-HalTxbf8814A_ResetTxPath	hal/phydm/txbf/haltxbf8814a.h	77;"	d
-HalTxbf8814A_Status	hal/phydm/txbf/haltxbf8814a.c	/^HalTxbf8814A_Status($/;"	f
-HalTxbf8814A_Status	hal/phydm/txbf/haltxbf8814a.h	63;"	d
-HalTxbf8814A_Status	hal/phydm/txbf/haltxbf8814a.h	76;"	d
-HalTxbf8814A_setNDPArate	hal/phydm/txbf/haltxbf8814a.c	/^HalTxbf8814A_setNDPArate($/;"	f
-HalTxbf8814A_setNDPArate	hal/phydm/txbf/haltxbf8814a.h	59;"	d
-HalTxbf8814A_setNDPArate	hal/phydm/txbf/haltxbf8814a.h	72;"	d
-HalTxbf8822B_ConfigGtab	hal/phydm/txbf/haltxbf8822b.c	/^HalTxbf8822B_ConfigGtab($/;"	f
-HalTxbf8822B_ConfigGtab	hal/phydm/txbf/haltxbf8822b.h	48;"	d
-HalTxbf8822B_ConfigGtab	hal/phydm/txbf/haltxbf8822b.h	83;"	d
-HalTxbf8822B_Enter	hal/phydm/txbf/haltxbf8822b.c	/^HalTxbf8822B_Enter($/;"	f
-HalTxbf8822B_Enter	hal/phydm/txbf/haltxbf8822b.h	44;"	d
-HalTxbf8822B_Enter	hal/phydm/txbf/haltxbf8822b.h	79;"	d
-HalTxbf8822B_FwTxBF	hal/phydm/txbf/haltxbf8822b.c	/^HalTxbf8822B_FwTxBF($/;"	f
-HalTxbf8822B_FwTxBF	hal/phydm/txbf/haltxbf8822b.h	47;"	d
-HalTxbf8822B_FwTxBF	hal/phydm/txbf/haltxbf8822b.h	82;"	d
-HalTxbf8822B_Init	hal/phydm/txbf/haltxbf8822b.c	/^HalTxbf8822B_Init($/;"	f
-HalTxbf8822B_Init	hal/phydm/txbf/haltxbf8822b.h	43;"	d
-HalTxbf8822B_Init	hal/phydm/txbf/haltxbf8822b.h	78;"	d
-HalTxbf8822B_Leave	hal/phydm/txbf/haltxbf8822b.c	/^HalTxbf8822B_Leave($/;"	f
-HalTxbf8822B_Leave	hal/phydm/txbf/haltxbf8822b.h	45;"	d
-HalTxbf8822B_Leave	hal/phydm/txbf/haltxbf8822b.h	80;"	d
-HalTxbf8822B_Status	hal/phydm/txbf/haltxbf8822b.c	/^HalTxbf8822B_Status($/;"	f
-HalTxbf8822B_Status	hal/phydm/txbf/haltxbf8822b.h	46;"	d
-HalTxbf8822B_Status	hal/phydm/txbf/haltxbf8822b.h	81;"	d
-HalTxbfJaguar_Clk_8812A	hal/phydm/txbf/haltxbfjaguar.c	/^HalTxbfJaguar_Clk_8812A($/;"	f
-HalTxbfJaguar_Clk_8812A	hal/phydm/txbf/haltxbfjaguar.h	61;"	d
-HalTxbfJaguar_Clk_8812A	hal/phydm/txbf/haltxbfjaguar.h	71;"	d
-HalTxbfJaguar_Enter	hal/phydm/txbf/haltxbfjaguar.c	/^HalTxbfJaguar_Enter($/;"	f
-HalTxbfJaguar_Enter	hal/phydm/txbf/haltxbfjaguar.h	56;"	d
-HalTxbfJaguar_Enter	hal/phydm/txbf/haltxbfjaguar.h	66;"	d
-HalTxbfJaguar_FwTxBF	hal/phydm/txbf/haltxbfjaguar.c	/^HalTxbfJaguar_FwTxBF($/;"	f
-HalTxbfJaguar_FwTxBF	hal/phydm/txbf/haltxbfjaguar.h	59;"	d
-HalTxbfJaguar_FwTxBF	hal/phydm/txbf/haltxbfjaguar.h	69;"	d
-HalTxbfJaguar_Leave	hal/phydm/txbf/haltxbfjaguar.c	/^HalTxbfJaguar_Leave($/;"	f
-HalTxbfJaguar_Leave	hal/phydm/txbf/haltxbfjaguar.h	57;"	d
-HalTxbfJaguar_Leave	hal/phydm/txbf/haltxbfjaguar.h	67;"	d
-HalTxbfJaguar_Patch	hal/phydm/txbf/haltxbfjaguar.c	/^HalTxbfJaguar_Patch($/;"	f
-HalTxbfJaguar_Patch	hal/phydm/txbf/haltxbfjaguar.h	60;"	d
-HalTxbfJaguar_Patch	hal/phydm/txbf/haltxbfjaguar.h	70;"	d
-HalTxbfJaguar_Status	hal/phydm/txbf/haltxbfjaguar.c	/^HalTxbfJaguar_Status($/;"	f
-HalTxbfJaguar_Status	hal/phydm/txbf/haltxbfjaguar.h	58;"	d
-HalTxbfJaguar_Status	hal/phydm/txbf/haltxbfjaguar.h	68;"	d
-Hal_BT_EfusePowerSwitch	hal/rtl8723d/rtl8723d_hal_init.c	/^static void Hal_BT_EfusePowerSwitch($/;"	f	file:
-Hal_DetectWoWMode	hal/rtl8723d/rtl8723d_hal_init.c	/^void Hal_DetectWoWMode(PADAPTER pAdapter)$/;"	f
-Hal_EEValueCheck	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EEValueCheck($/;"	f	file:
-Hal_EfuseGetCurrentSize	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseGetCurrentSize($/;"	f	file:
-Hal_EfuseParseAntennaDiversity_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseAntennaDiversity_8723D($/;"	f
-Hal_EfuseParseBTCoexistInfo_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseBTCoexistInfo_8723D($/;"	f
-Hal_EfuseParseBoardType_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseBoardType_8723D($/;"	f
-Hal_EfuseParseChnlPlan_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseChnlPlan_8723D($/;"	f
-Hal_EfuseParseCustomerID_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseCustomerID_8723D($/;"	f
-Hal_EfuseParseEEPROMVer_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseEEPROMVer_8723D($/;"	f
-Hal_EfuseParseIDCode	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseIDCode($/;"	f
-Hal_EfuseParsePackageType_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParsePackageType_8723D($/;"	f
-Hal_EfuseParseThermalMeter_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseThermalMeter_8723D($/;"	f
-Hal_EfuseParseTxPowerInfo_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseTxPowerInfo_8723D($/;"	f
-Hal_EfuseParseVoltage_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseVoltage_8723D($/;"	f
-Hal_EfuseParseXtal_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseParseXtal_8723D($/;"	f
-Hal_EfusePgPacketRead	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfusePgPacketRead($/;"	f	file:
-Hal_EfusePgPacketWrite	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfusePgPacketWrite($/;"	f	file:
-Hal_EfusePgPacketWrite_BT	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfusePgPacketWrite_BT($/;"	f	file:
-Hal_EfusePowerSwitch	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfusePowerSwitch($/;"	f	file:
-Hal_EfuseWordEnableDataWrite	core/efuse/rtw_efuse.c	/^Hal_EfuseWordEnableDataWrite($/;"	f	file:
-Hal_EfuseWordEnableDataWrite	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_EfuseWordEnableDataWrite($/;"	f	file:
-Hal_GetEfuseDefinition	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_GetEfuseDefinition($/;"	f	file:
-Hal_GetPhyEfuseMACAddr	hal/hal_com.c	/^int Hal_GetPhyEfuseMACAddr(PADAPTER padapter, u8 *mac_addr)$/;"	f
-Hal_InitPGData	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_InitPGData($/;"	f
-Hal_MappingOutPipe	hal/hal_com.c	/^Hal_MappingOutPipe($/;"	f
-Hal_ReadEFuse	hal/rtl8723d/rtl8723d_hal_init.c	/^Hal_ReadEFuse($/;"	f	file:
-Hal_ReadMACAddrFromFile	hal/hal_com.c	/^u32 Hal_ReadMACAddrFromFile(PADAPTER padapter, u8 *mac_addr)$/;"	f
-Hal_ReadRFGainOffset	hal/rtl8723d/rtl8723d_hal_init.c	/^void Hal_ReadRFGainOffset($/;"	f
-Hal_readPGDataFromConfigFile	hal/hal_com.c	/^u32 Hal_readPGDataFromConfigFile(PADAPTER padapter)$/;"	f
-HardwareType	include/drv_types.h	/^	u8	HardwareType;$/;"	m	struct:dvobj_priv
-HeaderRetry	include/rtw_efuse.h	/^	const u16  HeaderRetry;$/;"	m	struct:_EFUSE_HAL
-HeaderType	include/drv_types_pci.h	/^	u8	HeaderType;$/;"	m	struct:_PCI_COMMON_CONFIG
-Hi16	core/rtw_security.c	480;"	d	file:
-Hi8	core/rtw_security.c	478;"	d	file:
-HighRSSIThresh	hal/phydm/phydm_rainfo.h	/^	u1Byte				HighRSSIThresh;		\/\/ if RSSI > HighRSSIThresh	=> RATRState is DM_RATR_STA_HIGH$/;"	m	struct:_ODM_RATE_ADAPTIVE
-HighestRate	hal/phydm/phydm_rainfo.h	/^	u1Byte HighestRate;$/;"	m	struct:_ODM_RA_Info_
-HopPattern	include/wlan_bssdef.h	/^	ULONG           HopPattern;         \/* As defined by 802.11, MSB set *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION_FH
-HopSet	include/wlan_bssdef.h	/^	ULONG           HopSet;             \/* to one if non-802.11 *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION_FH
-Hour	include/rtl8188e_hal.h	/^	u8		Hour;	\/* Release time Hour field *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Hour	include/rtl8188f_hal.h	/^	u8		Hour;	\/* Release time Hour field *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Hour	include/rtl8703b_hal.h	/^	u8		Hour;	\/* Release time Hour field *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Hour	include/rtl8723b_hal.h	/^	u8		Hour;	\/* Release time Hour field *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Hour	include/rtl8723d_hal.h	/^	u8		Hour;	\/* Release time Hour field *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-HtBeamformCap	hal/phydm/phydm_beamforming.h	/^	u1Byte						HtBeamformCap;$/;"	m	struct:_RT_BEAMFORM_STAINFO
-HubUsbMode	hal/phydm/phydm.h	/^	pu1Byte			HubUsbMode;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-HwRateToMPTRate	core/rtw_mp.c	/^u8 HwRateToMPTRate(u8 rate)$/;"	f
-HwRateToMRate	hal/hal_com.c	/^u8	HwRateToMRate(u8 rate)$/;"	f
-HwRxPageSize	include/hal_data.h	/^	u16			HwRxPageSize;				\/* Hardware setting *\/$/;"	m	struct:hal_com_data
-IBSS_START_MAC_ID	include/sta_info.h	24;"	d
-ICMPV6_MCAST_MAC	include/wifi.h	1353;"	d
-ICType	include/HalVerDef.h	/^	HAL_IC_TYPE_E		ICType;$/;"	m	struct:tag_HAL_VERSION
-ICV	include/hal_com_reg.h	1540;"	d
-IC_MACPHY_MODE	include/hal_com_reg.h	1263;"	d
-ID	include/rtw_mlme_ext.h	/^	unsigned int ID:8;$/;"	m	struct:C2HEvent_Header
-IDR0	include/hal_com_reg.h	573;"	d
-IDR0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	447;"	d
-IDR0_8814A	include/rtl8814a_spec.h	546;"	d
-IDR4	include/hal_com_reg.h	574;"	d
-IDR4_8723D	hal/phydm/rtl8723d/hal8723dreg.h	448;"	d
-IDR4_8814A	include/rtl8814a_spec.h	547;"	d
-IDX_0xC14	hal/phydm/rtl8723d/halphyrf_8723d.c	39;"	d	file:
-IDX_0xC4C	hal/phydm/rtl8723d/halphyrf_8723d.c	37;"	d	file:
-IDX_0xC80	hal/phydm/rtl8723d/halphyrf_8723d.c	36;"	d	file:
-IDX_0xC94	hal/phydm/rtl8723d/halphyrf_8723d.c	35;"	d	file:
-IDX_0xCA0	hal/phydm/rtl8723d/halphyrf_8723d.c	40;"	d	file:
-IDX_0xCD0	hal/phydm/rtl8723d/halphyrf_8723d.c	44;"	d	file:
-IDX_0xCD4	hal/phydm/rtl8723d/halphyrf_8723d.c	45;"	d	file:
-IDX_0xCD8	hal/phydm/rtl8723d/halphyrf_8723d.c	47;"	d	file:
-IDX_0xCDC	hal/phydm/rtl8723d/halphyrf_8723d.c	48;"	d	file:
-IEEE80211A	include/rtw_mlme_ext.h	/^	enum hw_mode {IEEE80211G, IEEE80211A} mode;$/;"	e	enum:p2p_oper_class_map::hw_mode
-IEEE80211G	include/rtw_mlme_ext.h	/^	enum hw_mode {IEEE80211G, IEEE80211A} mode;$/;"	e	enum:p2p_oper_class_map::hw_mode
-IEEE80211W_NO_KEY	include/rtw_security.h	38;"	d
-IEEE80211W_RIGHT_KEY	include/rtw_security.h	36;"	d
-IEEE80211W_WRONG_KEY	include/rtw_security.h	37;"	d
-IEEE80211_24GHZ_BAND	include/ieee80211.h	696;"	d
-IEEE80211_3ADDR_LEN	include/ieee80211.h	454;"	d
-IEEE80211_4ADDR_LEN	include/ieee80211.h	455;"	d
-IEEE80211_52GHZ_BAND	include/ieee80211.h	697;"	d
-IEEE80211_ADDBA_PARAM_POLICY_MASK	include/wifi.h	995;"	d
-IEEE80211_ADDBA_PARAM_TID_MASK	include/wifi.h	996;"	d
-IEEE80211_ASSOCIATING	include/ieee80211.h	/^	IEEE80211_ASSOCIATING,$/;"	e	enum:ieee80211_state
-IEEE80211_ASSOCIATING_AUTHENTICATED	include/ieee80211.h	/^	IEEE80211_ASSOCIATING_AUTHENTICATED,$/;"	e	enum:ieee80211_state
-IEEE80211_ASSOCIATING_AUTHENTICATING	include/ieee80211.h	/^	IEEE80211_ASSOCIATING_AUTHENTICATING,$/;"	e	enum:ieee80211_state
-IEEE80211_ASSOCIATING_RETRY	include/ieee80211.h	/^	IEEE80211_ASSOCIATING_RETRY,$/;"	e	enum:ieee80211_state
-IEEE80211_BAR_CTRL_ACK_POLICY_NORMAL	include/wifi.h	784;"	d
-IEEE80211_BAR_CTRL_CBMTID_COMPRESSED_BA	include/wifi.h	785;"	d
-IEEE80211_BASIC_RATE_MASK	include/ieee80211.h	716;"	d
-IEEE80211_CCK_BASIC_RATES_MASK	include/ieee80211.h	732;"	d
-IEEE80211_CCK_DEFAULT_RATES_MASK	include/ieee80211.h	734;"	d
-IEEE80211_CCK_MODULATION	include/ieee80211.h	693;"	d
-IEEE80211_CCK_RATES_MASK	include/ieee80211.h	731;"	d
-IEEE80211_CCK_RATE_11MB	include/ieee80211.h	706;"	d
-IEEE80211_CCK_RATE_11MB_MASK	include/ieee80211.h	721;"	d
-IEEE80211_CCK_RATE_1MB	include/ieee80211.h	703;"	d
-IEEE80211_CCK_RATE_1MB_MASK	include/ieee80211.h	718;"	d
-IEEE80211_CCK_RATE_2MB	include/ieee80211.h	704;"	d
-IEEE80211_CCK_RATE_2MB_MASK	include/ieee80211.h	719;"	d
-IEEE80211_CCK_RATE_5MB	include/ieee80211.h	705;"	d
-IEEE80211_CCK_RATE_5MB_MASK	include/ieee80211.h	720;"	d
-IEEE80211_CCK_RATE_LEN	include/ieee80211.h	699;"	d
-IEEE80211_DATA_HDR3_LEN	include/ieee80211.h	682;"	d
-IEEE80211_DATA_HDR4_LEN	include/ieee80211.h	683;"	d
-IEEE80211_DATA_LEN	include/ieee80211.h	320;"	d
-IEEE80211_DEFAULT_BASIC_RATE	include/ieee80211.h	1234;"	d
-IEEE80211_DEFAULT_RATES_MASK	include/ieee80211.h	748;"	d
-IEEE80211_DEFAULT_TX_ESSID	include/ieee80211.h	1233;"	d
-IEEE80211_DELBA_PARAM_INITIATOR_MASK	include/wifi.h	999;"	d
-IEEE80211_DELBA_PARAM_TID_MASK	include/wifi.h	998;"	d
-IEEE80211_DTIM_INVALID	include/ieee80211.h	1369;"	d
-IEEE80211_DTIM_MBCAST	include/ieee80211.h	1366;"	d
-IEEE80211_DTIM_UCAST	include/ieee80211.h	1367;"	d
-IEEE80211_DTIM_VALID	include/ieee80211.h	1368;"	d
-IEEE80211_FCS_LEN	include/ieee80211.h	456;"	d
-IEEE80211_FRAG_CACHE_LEN	include/ieee80211.h	1028;"	d
-IEEE80211_FRAME_LEN	include/ieee80211.h	331;"	d
-IEEE80211_HLEN	include/ieee80211.h	330;"	d
-IEEE80211_HT_CAP_AMPDU_DENSITY	include/wifi.h	969;"	d
-IEEE80211_HT_CAP_AMPDU_FACTOR	include/wifi.h	968;"	d
-IEEE80211_HT_CAP_DELAY_BA	include/wifi.h	963;"	d
-IEEE80211_HT_CAP_DSSSCCK40	include/wifi.h	965;"	d
-IEEE80211_HT_CAP_GRN_FLD	include/wifi.h	956;"	d
-IEEE80211_HT_CAP_LDPC_CODING	include/wifi.h	953;"	d
-IEEE80211_HT_CAP_MAX_AMSDU	include/wifi.h	964;"	d
-IEEE80211_HT_CAP_MAX_STREAMS	include/wifi.h	972;"	d
-IEEE80211_HT_CAP_MCS_TX_DEFINED	include/wifi.h	975;"	d
-IEEE80211_HT_CAP_MCS_TX_RX_DIFF	include/wifi.h	976;"	d
-IEEE80211_HT_CAP_MCS_TX_STREAMS	include/wifi.h	977;"	d
-IEEE80211_HT_CAP_MCS_TX_UEQM	include/wifi.h	978;"	d
-IEEE80211_HT_CAP_RX_STBC_1R	include/wifi.h	960;"	d
-IEEE80211_HT_CAP_RX_STBC_2R	include/wifi.h	961;"	d
-IEEE80211_HT_CAP_RX_STBC_3R	include/wifi.h	962;"	d
-IEEE80211_HT_CAP_SGI_20	include/wifi.h	957;"	d
-IEEE80211_HT_CAP_SGI_40	include/wifi.h	958;"	d
-IEEE80211_HT_CAP_SM_PS	include/wifi.h	955;"	d
-IEEE80211_HT_CAP_SUP_WIDTH	include/wifi.h	954;"	d
-IEEE80211_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP	include/wifi.h	982;"	d
-IEEE80211_HT_CAP_TXBF_RX_NDP	include/wifi.h	980;"	d
-IEEE80211_HT_CAP_TXBF_TX_NDP	include/wifi.h	981;"	d
-IEEE80211_HT_CAP_TX_STBC	include/wifi.h	959;"	d
-IEEE80211_HT_IE_CHA_SEC_ABOVE	include/wifi.h	987;"	d
-IEEE80211_HT_IE_CHA_SEC_BELOW	include/wifi.h	988;"	d
-IEEE80211_HT_IE_CHA_SEC_NONE	include/wifi.h	986;"	d
-IEEE80211_HT_IE_CHA_SEC_OFFSET	include/wifi.h	985;"	d
-IEEE80211_HT_IE_CHA_WIDTH	include/wifi.h	989;"	d
-IEEE80211_HT_IE_HT_PROTECTION	include/wifi.h	990;"	d
-IEEE80211_HT_IE_NON_GF_STA_PRSNT	include/wifi.h	991;"	d
-IEEE80211_HT_IE_NON_HT_STA_PRSNT	include/wifi.h	992;"	d
-IEEE80211_LINKED	include/ieee80211.h	/^	IEEE80211_LINKED,$/;"	e	enum:ieee80211_state
-IEEE80211_LINKED_SCANNING	include/ieee80211.h	/^	IEEE80211_LINKED_SCANNING,$/;"	e	enum:ieee80211_state
-IEEE80211_MAX_AMPDU_BUF	include/wifi.h	1006;"	d
-IEEE80211_MGMT_HDR_LEN	include/ieee80211.h	681;"	d
-IEEE80211_MIN_ACTION_SIZE	include/ieee80211_ext.h	472;"	d
-IEEE80211_MIN_AMPDU_BUF	include/wifi.h	1005;"	d
-IEEE80211_NOLINK	include/ieee80211.h	/^	IEEE80211_NOLINK = 0,$/;"	e	enum:ieee80211_state
-IEEE80211_NUM_CCK_RATES	include/ieee80211.h	752;"	d
-IEEE80211_NUM_OFDM_RATES	include/ieee80211.h	751;"	d
-IEEE80211_NUM_OFDM_RATESLEN	include/ieee80211.h	700;"	d
-IEEE80211_OFDM_BASIC_RATES_MASK	include/ieee80211.h	739;"	d
-IEEE80211_OFDM_DEFAULT_RATES_MASK	include/ieee80211.h	742;"	d
-IEEE80211_OFDM_MODULATION	include/ieee80211.h	694;"	d
-IEEE80211_OFDM_RATES_MASK	include/ieee80211.h	738;"	d
-IEEE80211_OFDM_RATE_12MB	include/ieee80211.h	710;"	d
-IEEE80211_OFDM_RATE_12MB_MASK	include/ieee80211.h	724;"	d
-IEEE80211_OFDM_RATE_18MB	include/ieee80211.h	711;"	d
-IEEE80211_OFDM_RATE_18MB_MASK	include/ieee80211.h	725;"	d
-IEEE80211_OFDM_RATE_24MB	include/ieee80211.h	712;"	d
-IEEE80211_OFDM_RATE_24MB_MASK	include/ieee80211.h	726;"	d
-IEEE80211_OFDM_RATE_36MB	include/ieee80211.h	713;"	d
-IEEE80211_OFDM_RATE_36MB_MASK	include/ieee80211.h	727;"	d
-IEEE80211_OFDM_RATE_48MB	include/ieee80211.h	714;"	d
-IEEE80211_OFDM_RATE_48MB_MASK	include/ieee80211.h	728;"	d
-IEEE80211_OFDM_RATE_54MB	include/ieee80211.h	715;"	d
-IEEE80211_OFDM_RATE_54MB_MASK	include/ieee80211.h	729;"	d
-IEEE80211_OFDM_RATE_6MB	include/ieee80211.h	708;"	d
-IEEE80211_OFDM_RATE_6MB_MASK	include/ieee80211.h	722;"	d
-IEEE80211_OFDM_RATE_9MB	include/ieee80211.h	709;"	d
-IEEE80211_OFDM_RATE_9MB_MASK	include/ieee80211.h	723;"	d
-IEEE80211_OFDM_RATE_LEN	include/ieee80211.h	707;"	d
-IEEE80211_OFDM_SHIFT_MASK_A	include/ieee80211.h	753;"	d
-IEEE80211_PS_DISABLED	include/ieee80211.h	1371;"	d
-IEEE80211_PS_MBCAST	include/ieee80211.h	1373;"	d
-IEEE80211_PS_UNICAST	include/ieee80211.h	1372;"	d
-IEEE80211_RADIOTAP_F_BADFCS	core/rtw_recv.c	3606;"	d	file:
-IEEE80211_RADIOTAP_MCS	core/rtw_recv.c	3599;"	d	file:
-IEEE80211_RADIOTAP_RX_FLAGS	core/rtw_recv.c	3595;"	d	file:
-IEEE80211_RADIOTAP_VHT	core/rtw_recv.c	3602;"	d	file:
-IEEE80211_SOFTMAC_ASSOC_RETRY_TIME	include/ieee80211.h	1353;"	d
-IEEE80211_SOFTMAC_SCAN_TIME	include/ieee80211.h	1351;"	d
-IEEE80211_STATMASK_NOISE	include/ieee80211.h	688;"	d
-IEEE80211_STATMASK_RATE	include/ieee80211.h	689;"	d
-IEEE80211_STATMASK_RSSI	include/ieee80211.h	687;"	d
-IEEE80211_STATMASK_SIGNAL	include/ieee80211.h	686;"	d
-IEEE80211_STATMASK_WEMASK	include/ieee80211.h	690;"	d
-IEEE80211_SUPP_MCS_SET_LEN	include/wifi.h	973;"	d
-IEEE80211_SUPP_MCS_SET_UEQM	include/wifi.h	971;"	d
-IEEE8023_FRAMETAG	include/rtw_xmit.h	463;"	d
-IEEE_A	include/ieee80211.h	1514;"	d
-IEEE_B	include/ieee80211.h	1515;"	d
-IEEE_CMD_MLME	include/ieee80211.h	97;"	d
-IEEE_CMD_SET_ENCRYPTION	include/ieee80211.h	96;"	d
-IEEE_CMD_SET_WPA_IE	include/ieee80211.h	95;"	d
-IEEE_CMD_SET_WPA_PARAM	include/ieee80211.h	94;"	d
-IEEE_CRYPT_ALG_NAME_LEN	include/ieee80211.h	122;"	d
-IEEE_CRYPT_ERR_CARD_CONF_FAILED	include/ieee80211.h	119;"	d
-IEEE_CRYPT_ERR_CRYPT_INIT_FAILED	include/ieee80211.h	116;"	d
-IEEE_CRYPT_ERR_KEY_SET_FAILED	include/ieee80211.h	117;"	d
-IEEE_CRYPT_ERR_TX_KEY_SET_FAILED	include/ieee80211.h	118;"	d
-IEEE_CRYPT_ERR_UNKNOWN_ADDR	include/ieee80211.h	115;"	d
-IEEE_CRYPT_ERR_UNKNOWN_ALG	include/ieee80211.h	114;"	d
-IEEE_G	include/ieee80211.h	1516;"	d
-IEEE_IBSS_MAC_HASH_SIZE	include/ieee80211.h	335;"	d
-IEEE_MLME_STA_DEAUTH	include/ieee80211.h	111;"	d
-IEEE_MLME_STA_DISASSOC	include/ieee80211.h	112;"	d
-IEEE_MODE_MASK	include/ieee80211.h	1517;"	d
-IEEE_PARAM_AUTH_ALGS	include/ieee80211.h	103;"	d
-IEEE_PARAM_DROP_UNENCRYPTED	include/ieee80211.h	101;"	d
-IEEE_PARAM_IEEE_802_1X	include/ieee80211.h	104;"	d
-IEEE_PARAM_PRIVACY_INVOKED	include/ieee80211.h	102;"	d
-IEEE_PARAM_TKIP_COUNTERMEASURES	include/ieee80211.h	100;"	d
-IEEE_PARAM_WPAX_SELECT	include/ieee80211.h	105;"	d
-IEEE_PARAM_WPA_ENABLED	include/ieee80211.h	99;"	d
-IELength	include/wlan_bssdef.h	/^	ULONG  IELength;$/;"	m	struct:_WLAN_BSSID_EX
-IEs	include/wlan_bssdef.h	/^	UCHAR  IEs[MAX_IE_SZ];	\/* (timestamp, beacon interval, and capability information) *\/$/;"	m	struct:_WLAN_BSSID_EX
-IFACE_ID0	include/drv_types.h	/^	IFACE_ID0, \/*PRIMARY_ADAPTER*\/$/;"	e	enum:_IFACE_ID
-IFACE_ID1	include/drv_types.h	/^	IFACE_ID1,$/;"	e	enum:_IFACE_ID
-IFACE_ID2	include/drv_types.h	/^	IFACE_ID2,$/;"	e	enum:_IFACE_ID
-IFACE_ID3	include/drv_types.h	/^	IFACE_ID3,$/;"	e	enum:_IFACE_ID
-IFACE_ID4	include/drv_types.h	/^	IFACE_ID4,$/;"	e	enum:_IFACE_ID
-IFACE_ID5	include/drv_types.h	/^	IFACE_ID5,$/;"	e	enum:_IFACE_ID
-IFACE_ID6	include/drv_types.h	/^	IFACE_ID6,$/;"	e	enum:_IFACE_ID
-IFACE_ID7	include/drv_types.h	/^	IFACE_ID7,$/;"	e	enum:_IFACE_ID
-IFACE_ID_MAX	include/drv_types.h	/^	IFACE_ID_MAX,$/;"	e	enum:_IFACE_ID
-IGIBackup	hal/phydm/phydm_dig.h	/^	u1Byte		IGIBackup;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-IGIOffset_A	hal/phydm/phydm_dig.h	/^	u1Byte					IGIOffset_A;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-IGIOffset_B	hal/phydm/phydm_dig.h	/^	u1Byte					IGIOffset_B;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-IGIValue	include/hal_com.h	/^	u8		IGIValue;$/;"	m	struct:noise_info
-IGI_Base	hal/phydm/phydm_adaptivity.h	/^	s1Byte			IGI_Base;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-IGI_LowerBound	hal/phydm/phydm.h	/^	u1Byte			IGI_LowerBound;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IGI_UpperBound	hal/phydm/phydm.h	/^	u1Byte			IGI_UpperBound;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IGI_target	hal/phydm/phydm_adaptivity.h	/^	u1Byte			IGI_target;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-IMEM_BOOT_CHKSUM_FAIL	include/rtl8814a_spec.h	498;"	d
-IMEM_BOOT_DL_RDY	include/rtl8814a_spec.h	497;"	d
-IMEM_CHKSUM_OK	include/rtl8814a_spec.h	500;"	d
-IMEM_DL_RDY	include/rtl8814a_spec.h	499;"	d
-IMR8190_DISABLED	include/hal_com_reg.h	847;"	d
-IMR_ATIMEND	include/hal_com_reg.h	871;"	d
-IMR_ATIMEND_8188F	include/rtl8188f_spec.h	248;"	d
-IMR_ATIMEND_8192E	include/rtl8192e_spec.h	247;"	d
-IMR_ATIMEND_8703B	include/rtl8703b_spec.h	425;"	d
-IMR_ATIMEND_8723B	include/rtl8723b_spec.h	241;"	d
-IMR_ATIMEND_8723D	hal/phydm/rtl8723d/hal8723dreg.h	478;"	d
-IMR_ATIMEND_8812	include/rtl8812a_spec.h	202;"	d
-IMR_ATIMEND_8814A	include/rtl8814a_spec.h	577;"	d
-IMR_ATIMEND_88E	include/hal_com_reg.h	1022;"	d
-IMR_ATIMEND_E_8188F	include/rtl8188f_spec.h	276;"	d
-IMR_ATIMEND_E_8192E	include/rtl8192e_spec.h	275;"	d
-IMR_ATIMEND_E_8703B	include/rtl8703b_spec.h	453;"	d
-IMR_ATIMEND_E_8723B	include/rtl8723b_spec.h	269;"	d
-IMR_ATIMEND_E_8723D	hal/phydm/rtl8723d/hal8723dreg.h	506;"	d
-IMR_ATIMEND_E_8812	include/rtl8812a_spec.h	230;"	d
-IMR_ATIMEND_E_8814A	include/rtl8814a_spec.h	606;"	d
-IMR_ATIMEND_E_88E	include/hal_com_reg.h	1051;"	d
-IMR_BCNDERR0_8188F	include/rtl8188f_spec.h	245;"	d
-IMR_BCNDERR0_8192E	include/rtl8192e_spec.h	244;"	d
-IMR_BCNDERR0_8703B	include/rtl8703b_spec.h	422;"	d
-IMR_BCNDERR0_8723B	include/rtl8723b_spec.h	238;"	d
-IMR_BCNDERR0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	475;"	d
-IMR_BCNDERR0_8812	include/rtl8812a_spec.h	199;"	d
-IMR_BCNDERR0_8814A	include/rtl8814a_spec.h	574;"	d
-IMR_BCNDERR0_88E	include/hal_com_reg.h	1019;"	d
-IMR_BCNDMAINT0_8188F	include/rtl8188f_spec.h	244;"	d
-IMR_BCNDMAINT0_8192E	include/rtl8192e_spec.h	243;"	d
-IMR_BCNDMAINT0_8703B	include/rtl8703b_spec.h	421;"	d
-IMR_BCNDMAINT0_8723B	include/rtl8723b_spec.h	237;"	d
-IMR_BCNDMAINT0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	474;"	d
-IMR_BCNDMAINT0_8812	include/rtl8812a_spec.h	198;"	d
-IMR_BCNDMAINT0_8814A	include/rtl8814a_spec.h	573;"	d
-IMR_BCNDMAINT0_88E	include/hal_com_reg.h	1018;"	d
-IMR_BCNDMAINT1	include/hal_com_reg.h	855;"	d
-IMR_BCNDMAINT1_8188F	include/rtl8188f_spec.h	268;"	d
-IMR_BCNDMAINT1_8192E	include/rtl8192e_spec.h	267;"	d
-IMR_BCNDMAINT1_8703B	include/rtl8703b_spec.h	445;"	d
-IMR_BCNDMAINT1_8723B	include/rtl8723b_spec.h	261;"	d
-IMR_BCNDMAINT1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	498;"	d
-IMR_BCNDMAINT1_8812	include/rtl8812a_spec.h	222;"	d
-IMR_BCNDMAINT1_8814A	include/rtl8814a_spec.h	598;"	d
-IMR_BCNDMAINT1_88E	include/hal_com_reg.h	1043;"	d
-IMR_BCNDMAINT2	include/hal_com_reg.h	854;"	d
-IMR_BCNDMAINT2_8188F	include/rtl8188f_spec.h	267;"	d
-IMR_BCNDMAINT2_8192E	include/rtl8192e_spec.h	266;"	d
-IMR_BCNDMAINT2_8703B	include/rtl8703b_spec.h	444;"	d
-IMR_BCNDMAINT2_8723B	include/rtl8723b_spec.h	260;"	d
-IMR_BCNDMAINT2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	497;"	d
-IMR_BCNDMAINT2_8812	include/rtl8812a_spec.h	221;"	d
-IMR_BCNDMAINT2_8814A	include/rtl8814a_spec.h	597;"	d
-IMR_BCNDMAINT2_88E	include/hal_com_reg.h	1042;"	d
-IMR_BCNDMAINT3	include/hal_com_reg.h	853;"	d
-IMR_BCNDMAINT3_8188F	include/rtl8188f_spec.h	266;"	d
-IMR_BCNDMAINT3_8192E	include/rtl8192e_spec.h	265;"	d
-IMR_BCNDMAINT3_8703B	include/rtl8703b_spec.h	443;"	d
-IMR_BCNDMAINT3_8723B	include/rtl8723b_spec.h	259;"	d
-IMR_BCNDMAINT3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	496;"	d
-IMR_BCNDMAINT3_8812	include/rtl8812a_spec.h	220;"	d
-IMR_BCNDMAINT3_8814A	include/rtl8814a_spec.h	596;"	d
-IMR_BCNDMAINT3_88E	include/hal_com_reg.h	1041;"	d
-IMR_BCNDMAINT4	include/hal_com_reg.h	852;"	d
-IMR_BCNDMAINT4_8188F	include/rtl8188f_spec.h	265;"	d
-IMR_BCNDMAINT4_8192E	include/rtl8192e_spec.h	264;"	d
-IMR_BCNDMAINT4_8703B	include/rtl8703b_spec.h	442;"	d
-IMR_BCNDMAINT4_8723B	include/rtl8723b_spec.h	258;"	d
-IMR_BCNDMAINT4_8723D	hal/phydm/rtl8723d/hal8723dreg.h	495;"	d
-IMR_BCNDMAINT4_8812	include/rtl8812a_spec.h	219;"	d
-IMR_BCNDMAINT4_8814A	include/rtl8814a_spec.h	595;"	d
-IMR_BCNDMAINT4_88E	include/hal_com_reg.h	1040;"	d
-IMR_BCNDMAINT5	include/hal_com_reg.h	851;"	d
-IMR_BCNDMAINT5_8188F	include/rtl8188f_spec.h	264;"	d
-IMR_BCNDMAINT5_8192E	include/rtl8192e_spec.h	263;"	d
-IMR_BCNDMAINT5_8703B	include/rtl8703b_spec.h	441;"	d
-IMR_BCNDMAINT5_8723B	include/rtl8723b_spec.h	257;"	d
-IMR_BCNDMAINT5_8723D	hal/phydm/rtl8723d/hal8723dreg.h	494;"	d
-IMR_BCNDMAINT5_8812	include/rtl8812a_spec.h	218;"	d
-IMR_BCNDMAINT5_8814A	include/rtl8814a_spec.h	594;"	d
-IMR_BCNDMAINT5_88E	include/hal_com_reg.h	1039;"	d
-IMR_BCNDMAINT6	include/hal_com_reg.h	850;"	d
-IMR_BCNDMAINT6_8188F	include/rtl8188f_spec.h	263;"	d
-IMR_BCNDMAINT6_8192E	include/rtl8192e_spec.h	262;"	d
-IMR_BCNDMAINT6_8703B	include/rtl8703b_spec.h	440;"	d
-IMR_BCNDMAINT6_8723B	include/rtl8723b_spec.h	256;"	d
-IMR_BCNDMAINT6_8723D	hal/phydm/rtl8723d/hal8723dreg.h	493;"	d
-IMR_BCNDMAINT6_8812	include/rtl8812a_spec.h	217;"	d
-IMR_BCNDMAINT6_8814A	include/rtl8814a_spec.h	593;"	d
-IMR_BCNDMAINT6_88E	include/hal_com_reg.h	1038;"	d
-IMR_BCNDMAINT7_8188F	include/rtl8188f_spec.h	262;"	d
-IMR_BCNDMAINT7_8192E	include/rtl8192e_spec.h	261;"	d
-IMR_BCNDMAINT7_8703B	include/rtl8703b_spec.h	439;"	d
-IMR_BCNDMAINT7_8723B	include/rtl8723b_spec.h	255;"	d
-IMR_BCNDMAINT7_8723D	hal/phydm/rtl8723d/hal8723dreg.h	492;"	d
-IMR_BCNDMAINT7_8812	include/rtl8812a_spec.h	216;"	d
-IMR_BCNDMAINT7_8814A	include/rtl8814a_spec.h	592;"	d
-IMR_BCNDMAINT7_88E	include/hal_com_reg.h	1037;"	d
-IMR_BCNDMAINT_E_8188F	include/rtl8188f_spec.h	247;"	d
-IMR_BCNDMAINT_E_8192E	include/rtl8192e_spec.h	246;"	d
-IMR_BCNDMAINT_E_8703B	include/rtl8703b_spec.h	424;"	d
-IMR_BCNDMAINT_E_8723B	include/rtl8723b_spec.h	240;"	d
-IMR_BCNDMAINT_E_8723D	hal/phydm/rtl8723d/hal8723dreg.h	477;"	d
-IMR_BCNDMAINT_E_8812	include/rtl8812a_spec.h	201;"	d
-IMR_BCNDMAINT_E_8814A	include/rtl8814a_spec.h	576;"	d
-IMR_BCNDMAINT_E_88E	include/hal_com_reg.h	1021;"	d
-IMR_BCNDOK1	include/hal_com_reg.h	863;"	d
-IMR_BCNDOK1_8188F	include/rtl8188f_spec.h	275;"	d
-IMR_BCNDOK1_8192E	include/rtl8192e_spec.h	274;"	d
-IMR_BCNDOK1_8703B	include/rtl8703b_spec.h	452;"	d
-IMR_BCNDOK1_8723B	include/rtl8723b_spec.h	268;"	d
-IMR_BCNDOK1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	505;"	d
-IMR_BCNDOK1_8812	include/rtl8812a_spec.h	229;"	d
-IMR_BCNDOK1_8814A	include/rtl8814a_spec.h	605;"	d
-IMR_BCNDOK1_88E	include/hal_com_reg.h	1050;"	d
-IMR_BCNDOK2	include/hal_com_reg.h	862;"	d
-IMR_BCNDOK2_8188F	include/rtl8188f_spec.h	274;"	d
-IMR_BCNDOK2_8192E	include/rtl8192e_spec.h	273;"	d
-IMR_BCNDOK2_8703B	include/rtl8703b_spec.h	451;"	d
-IMR_BCNDOK2_8723B	include/rtl8723b_spec.h	267;"	d
-IMR_BCNDOK2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	504;"	d
-IMR_BCNDOK2_8812	include/rtl8812a_spec.h	228;"	d
-IMR_BCNDOK2_8814A	include/rtl8814a_spec.h	604;"	d
-IMR_BCNDOK2_88E	include/hal_com_reg.h	1049;"	d
-IMR_BCNDOK3	include/hal_com_reg.h	861;"	d
-IMR_BCNDOK3_8188F	include/rtl8188f_spec.h	273;"	d
-IMR_BCNDOK3_8192E	include/rtl8192e_spec.h	272;"	d
-IMR_BCNDOK3_8703B	include/rtl8703b_spec.h	450;"	d
-IMR_BCNDOK3_8723B	include/rtl8723b_spec.h	266;"	d
-IMR_BCNDOK3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	503;"	d
-IMR_BCNDOK3_8812	include/rtl8812a_spec.h	227;"	d
-IMR_BCNDOK3_8814A	include/rtl8814a_spec.h	603;"	d
-IMR_BCNDOK3_88E	include/hal_com_reg.h	1048;"	d
-IMR_BCNDOK4	include/hal_com_reg.h	860;"	d
-IMR_BCNDOK4_8188F	include/rtl8188f_spec.h	272;"	d
-IMR_BCNDOK4_8192E	include/rtl8192e_spec.h	271;"	d
-IMR_BCNDOK4_8703B	include/rtl8703b_spec.h	449;"	d
-IMR_BCNDOK4_8723B	include/rtl8723b_spec.h	265;"	d
-IMR_BCNDOK4_8723D	hal/phydm/rtl8723d/hal8723dreg.h	502;"	d
-IMR_BCNDOK4_8812	include/rtl8812a_spec.h	226;"	d
-IMR_BCNDOK4_8814A	include/rtl8814a_spec.h	602;"	d
-IMR_BCNDOK4_88E	include/hal_com_reg.h	1047;"	d
-IMR_BCNDOK5	include/hal_com_reg.h	859;"	d
-IMR_BCNDOK5_8188F	include/rtl8188f_spec.h	271;"	d
-IMR_BCNDOK5_8192E	include/rtl8192e_spec.h	270;"	d
-IMR_BCNDOK5_8703B	include/rtl8703b_spec.h	448;"	d
-IMR_BCNDOK5_8723B	include/rtl8723b_spec.h	264;"	d
-IMR_BCNDOK5_8723D	hal/phydm/rtl8723d/hal8723dreg.h	501;"	d
-IMR_BCNDOK5_8812	include/rtl8812a_spec.h	225;"	d
-IMR_BCNDOK5_8814A	include/rtl8814a_spec.h	601;"	d
-IMR_BCNDOK5_88E	include/hal_com_reg.h	1046;"	d
-IMR_BCNDOK6	include/hal_com_reg.h	858;"	d
-IMR_BCNDOK6_8188F	include/rtl8188f_spec.h	270;"	d
-IMR_BCNDOK6_8192E	include/rtl8192e_spec.h	269;"	d
-IMR_BCNDOK6_8703B	include/rtl8703b_spec.h	447;"	d
-IMR_BCNDOK6_8723B	include/rtl8723b_spec.h	263;"	d
-IMR_BCNDOK6_8723D	hal/phydm/rtl8723d/hal8723dreg.h	500;"	d
-IMR_BCNDOK6_8812	include/rtl8812a_spec.h	224;"	d
-IMR_BCNDOK6_8814A	include/rtl8814a_spec.h	600;"	d
-IMR_BCNDOK6_88E	include/hal_com_reg.h	1045;"	d
-IMR_BCNDOK7	include/hal_com_reg.h	857;"	d
-IMR_BCNDOK7_8188F	include/rtl8188f_spec.h	269;"	d
-IMR_BCNDOK7_8192E	include/rtl8192e_spec.h	268;"	d
-IMR_BCNDOK7_8703B	include/rtl8703b_spec.h	446;"	d
-IMR_BCNDOK7_8723B	include/rtl8723b_spec.h	262;"	d
-IMR_BCNDOK7_8723D	hal/phydm/rtl8723d/hal8723dreg.h	499;"	d
-IMR_BCNDOK7_8812	include/rtl8812a_spec.h	223;"	d
-IMR_BCNDOK7_8814A	include/rtl8814a_spec.h	599;"	d
-IMR_BCNDOK7_88E	include/hal_com_reg.h	1044;"	d
-IMR_BCNDOK8	include/hal_com_reg.h	856;"	d
-IMR_BDOK	include/hal_com_reg.h	872;"	d
-IMR_BEDOK	include/hal_com_reg.h	878;"	d
-IMR_BEDOK_8188F	include/rtl8188f_spec.h	255;"	d
-IMR_BEDOK_8192E	include/rtl8192e_spec.h	254;"	d
-IMR_BEDOK_8703B	include/rtl8703b_spec.h	432;"	d
-IMR_BEDOK_8723B	include/rtl8723b_spec.h	248;"	d
-IMR_BEDOK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	485;"	d
-IMR_BEDOK_8812	include/rtl8812a_spec.h	209;"	d
-IMR_BEDOK_8814A	include/rtl8814a_spec.h	584;"	d
-IMR_BEDOK_88E	include/hal_com_reg.h	1030;"	d
-IMR_BKDOK	include/hal_com_reg.h	877;"	d
-IMR_BKDOK_8188F	include/rtl8188f_spec.h	254;"	d
-IMR_BKDOK_8192E	include/rtl8192e_spec.h	253;"	d
-IMR_BKDOK_8703B	include/rtl8703b_spec.h	431;"	d
-IMR_BKDOK_8723B	include/rtl8723b_spec.h	247;"	d
-IMR_BKDOK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	484;"	d
-IMR_BKDOK_8812	include/rtl8812a_spec.h	208;"	d
-IMR_BKDOK_8814A	include/rtl8814a_spec.h	583;"	d
-IMR_BKDOK_88E	include/hal_com_reg.h	1029;"	d
-IMR_BcnInt	include/hal_com_reg.h	868;"	d
-IMR_BcnInt_E	include/hal_com_reg.h	885;"	d
-IMR_C2HCMD	include/hal_com_reg.h	888;"	d
-IMR_C2HCMD_8188F	include/rtl8188f_spec.h	249;"	d
-IMR_C2HCMD_8192E	include/rtl8192e_spec.h	248;"	d
-IMR_C2HCMD_8703B	include/rtl8703b_spec.h	426;"	d
-IMR_C2HCMD_8723B	include/rtl8723b_spec.h	242;"	d
-IMR_C2HCMD_8723D	hal/phydm/rtl8723d/hal8723dreg.h	479;"	d
-IMR_C2HCMD_8812	include/rtl8812a_spec.h	203;"	d
-IMR_C2HCMD_8814A	include/rtl8814a_spec.h	578;"	d
-IMR_C2HCMD_88E	include/hal_com_reg.h	1024;"	d
-IMR_CPWM	include/hal_com_reg.h	889;"	d
-IMR_CPWM2_8188F	include/rtl8188f_spec.h	250;"	d
-IMR_CPWM2_8192E	include/rtl8192e_spec.h	249;"	d
-IMR_CPWM2_8703B	include/rtl8703b_spec.h	427;"	d
-IMR_CPWM2_8723B	include/rtl8723b_spec.h	243;"	d
-IMR_CPWM2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	480;"	d
-IMR_CPWM2_8812	include/rtl8812a_spec.h	204;"	d
-IMR_CPWM2_8814A	include/rtl8814a_spec.h	579;"	d
-IMR_CPWM2_88E	include/hal_com_reg.h	1025;"	d
-IMR_CPWM_8188F	include/rtl8188f_spec.h	251;"	d
-IMR_CPWM_8192E	include/rtl8192e_spec.h	250;"	d
-IMR_CPWM_8703B	include/rtl8703b_spec.h	428;"	d
-IMR_CPWM_8723B	include/rtl8723b_spec.h	244;"	d
-IMR_CPWM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	481;"	d
-IMR_CPWM_8812	include/rtl8812a_spec.h	205;"	d
-IMR_CPWM_8814A	include/rtl8814a_spec.h	580;"	d
-IMR_CPWM_88E	include/hal_com_reg.h	1026;"	d
-IMR_DISABLED	include/hal_com_reg.h	848;"	d
-IMR_DISABLED_8188F	include/rtl8188f_spec.h	234;"	d
-IMR_DISABLED_8192E	include/rtl8192e_spec.h	233;"	d
-IMR_DISABLED_8703B	include/rtl8703b_spec.h	411;"	d
-IMR_DISABLED_8723B	include/rtl8723b_spec.h	227;"	d
-IMR_DISABLED_8723D	hal/phydm/rtl8723d/hal8723dreg.h	464;"	d
-IMR_DISABLED_8812	include/rtl8812a_spec.h	188;"	d
-IMR_DISABLED_8814A	include/rtl8814a_spec.h	563;"	d
-IMR_DISABLED_88E	include/hal_com_reg.h	1009;"	d
-IMR_GTINT3_8188F	include/rtl8188f_spec.h	240;"	d
-IMR_GTINT3_8192E	include/rtl8192e_spec.h	239;"	d
-IMR_GTINT3_8703B	include/rtl8703b_spec.h	417;"	d
-IMR_GTINT3_8723B	include/rtl8723b_spec.h	233;"	d
-IMR_GTINT3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	470;"	d
-IMR_GTINT3_8812	include/rtl8812a_spec.h	194;"	d
-IMR_GTINT3_8814A	include/rtl8814a_spec.h	569;"	d
-IMR_GTINT3_88E	include/hal_com_reg.h	1014;"	d
-IMR_GTINT4_8188F	include/rtl8188f_spec.h	239;"	d
-IMR_GTINT4_8192E	include/rtl8192e_spec.h	238;"	d
-IMR_GTINT4_8703B	include/rtl8703b_spec.h	416;"	d
-IMR_GTINT4_8723B	include/rtl8723b_spec.h	232;"	d
-IMR_GTINT4_8723D	hal/phydm/rtl8723d/hal8723dreg.h	469;"	d
-IMR_GTINT4_8812	include/rtl8812a_spec.h	193;"	d
-IMR_GTINT4_8814A	include/rtl8814a_spec.h	568;"	d
-IMR_GTINT4_88E	include/hal_com_reg.h	1013;"	d
-IMR_HIGHDOK	include/hal_com_reg.h	873;"	d
-IMR_HIGHDOK_8188F	include/rtl8188f_spec.h	252;"	d
-IMR_HIGHDOK_8192E	include/rtl8192e_spec.h	251;"	d
-IMR_HIGHDOK_8703B	include/rtl8703b_spec.h	429;"	d
-IMR_HIGHDOK_8723B	include/rtl8723b_spec.h	245;"	d
-IMR_HIGHDOK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	482;"	d
-IMR_HIGHDOK_8812	include/rtl8812a_spec.h	206;"	d
-IMR_HIGHDOK_8814A	include/rtl8814a_spec.h	581;"	d
-IMR_HIGHDOK_88E	include/hal_com_reg.h	1027;"	d
-IMR_HISR1_IND_INT_88E	include/hal_com_reg.h	1023;"	d
-IMR_HSISR_IND_ON_INT_8188F	include/rtl8188f_spec.h	246;"	d
-IMR_HSISR_IND_ON_INT_8192E	include/rtl8192e_spec.h	245;"	d
-IMR_HSISR_IND_ON_INT_8703B	include/rtl8703b_spec.h	423;"	d
-IMR_HSISR_IND_ON_INT_8723B	include/rtl8723b_spec.h	239;"	d
-IMR_HSISR_IND_ON_INT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	476;"	d
-IMR_HSISR_IND_ON_INT_8812	include/rtl8812a_spec.h	200;"	d
-IMR_HSISR_IND_ON_INT_8814A	include/rtl8814a_spec.h	575;"	d
-IMR_HSISR_IND_ON_INT_88E	include/hal_com_reg.h	1020;"	d
-IMR_MCUERR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	514;"	d
-IMR_MCUERR_8814A	include/rtl8814a_spec.h	591;"	d
-IMR_MGNTDOK	include/hal_com_reg.h	875;"	d
-IMR_MGNTDOK_8188F	include/rtl8188f_spec.h	253;"	d
-IMR_MGNTDOK_8192E	include/rtl8192e_spec.h	252;"	d
-IMR_MGNTDOK_8703B	include/rtl8703b_spec.h	430;"	d
-IMR_MGNTDOK_8723B	include/rtl8723b_spec.h	246;"	d
-IMR_MGNTDOK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	483;"	d
-IMR_MGNTDOK_8812	include/rtl8812a_spec.h	207;"	d
-IMR_MGNTDOK_8814A	include/rtl8814a_spec.h	582;"	d
-IMR_MGNTDOK_88E	include/hal_com_reg.h	1028;"	d
-IMR_OCPINT	include/hal_com_reg.h	891;"	d
-IMR_PSTIMEOUT	include/hal_com_reg.h	867;"	d
-IMR_PSTIMEOUT_8188F	include/rtl8188f_spec.h	238;"	d
-IMR_PSTIMEOUT_8192E	include/rtl8192e_spec.h	237;"	d
-IMR_PSTIMEOUT_8703B	include/rtl8703b_spec.h	415;"	d
-IMR_PSTIMEOUT_8723B	include/rtl8723b_spec.h	231;"	d
-IMR_PSTIMEOUT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	468;"	d
-IMR_PSTIMEOUT_8812	include/rtl8812a_spec.h	192;"	d
-IMR_PSTIMEOUT_8814A	include/rtl8814a_spec.h	567;"	d
-IMR_PSTIMEOUT_88E	include/hal_com_reg.h	1012;"	d
-IMR_RDU	include/hal_com_reg.h	870;"	d
-IMR_RDU_8188F	include/rtl8188f_spec.h	258;"	d
-IMR_RDU_8192E	include/rtl8192e_spec.h	257;"	d
-IMR_RDU_8703B	include/rtl8703b_spec.h	435;"	d
-IMR_RDU_8723B	include/rtl8723b_spec.h	251;"	d
-IMR_RDU_8723D	hal/phydm/rtl8723d/hal8723dreg.h	488;"	d
-IMR_RDU_8812	include/rtl8812a_spec.h	212;"	d
-IMR_RDU_8814A	include/rtl8814a_spec.h	587;"	d
-IMR_RDU_88E	include/hal_com_reg.h	1033;"	d
-IMR_ROK	include/hal_com_reg.h	881;"	d
-IMR_ROK_8188F	include/rtl8188f_spec.h	259;"	d
-IMR_ROK_8192E	include/rtl8192e_spec.h	258;"	d
-IMR_ROK_8703B	include/rtl8703b_spec.h	436;"	d
-IMR_ROK_8723B	include/rtl8723b_spec.h	252;"	d
-IMR_ROK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	489;"	d
-IMR_ROK_8812	include/rtl8812a_spec.h	213;"	d
-IMR_ROK_8814A	include/rtl8814a_spec.h	588;"	d
-IMR_ROK_88E	include/hal_com_reg.h	1034;"	d
-IMR_RXERR	include/hal_com_reg.h	887;"	d
-IMR_RXERR_8188F	include/rtl8188f_spec.h	278;"	d
-IMR_RXERR_8192E	include/rtl8192e_spec.h	277;"	d
-IMR_RXERR_8703B	include/rtl8703b_spec.h	455;"	d
-IMR_RXERR_8723B	include/rtl8723b_spec.h	271;"	d
-IMR_RXERR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	508;"	d
-IMR_RXERR_8812	include/rtl8812a_spec.h	232;"	d
-IMR_RXERR_8814A	include/rtl8814a_spec.h	608;"	d
-IMR_RXERR_88E	include/hal_com_reg.h	1053;"	d
-IMR_RXFOVW	include/hal_com_reg.h	869;"	d
-IMR_RXFOVW_8188F	include/rtl8188f_spec.h	280;"	d
-IMR_RXFOVW_8192E	include/rtl8192e_spec.h	279;"	d
-IMR_RXFOVW_8703B	include/rtl8703b_spec.h	457;"	d
-IMR_RXFOVW_8723B	include/rtl8723b_spec.h	273;"	d
-IMR_RXFOVW_8723D	hal/phydm/rtl8723d/hal8723dreg.h	510;"	d
-IMR_RXFOVW_8812	include/rtl8812a_spec.h	234;"	d
-IMR_RXFOVW_8814A	include/rtl8814a_spec.h	610;"	d
-IMR_RXFOVW_88E	include/hal_com_reg.h	1055;"	d
-IMR_TBDER	include/hal_com_reg.h	876;"	d
-IMR_TBDER_88E	include/hal_com_reg.h	1015;"	d
-IMR_TBDOK	include/hal_com_reg.h	874;"	d
-IMR_TBDOK_88E	include/hal_com_reg.h	1016;"	d
-IMR_TIMEOUT1	include/hal_com_reg.h	865;"	d
-IMR_TIMEOUT2	include/hal_com_reg.h	864;"	d
-IMR_TIMER1_8188F	include/rtl8188f_spec.h	237;"	d
-IMR_TIMER1_8192E	include/rtl8192e_spec.h	236;"	d
-IMR_TIMER1_8703B	include/rtl8703b_spec.h	414;"	d
-IMR_TIMER1_8723B	include/rtl8723b_spec.h	230;"	d
-IMR_TIMER1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	467;"	d
-IMR_TIMER1_8812	include/rtl8812a_spec.h	191;"	d
-IMR_TIMER1_8814A	include/rtl8814a_spec.h	566;"	d
-IMR_TIMER2_8188F	include/rtl8188f_spec.h	236;"	d
-IMR_TIMER2_8192E	include/rtl8192e_spec.h	235;"	d
-IMR_TIMER2_8703B	include/rtl8703b_spec.h	413;"	d
-IMR_TIMER2_8723B	include/rtl8723b_spec.h	229;"	d
-IMR_TIMER2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	466;"	d
-IMR_TIMER2_8812	include/rtl8812a_spec.h	190;"	d
-IMR_TIMER2_8814A	include/rtl8814a_spec.h	565;"	d
-IMR_TSF_BIT32_TOGGLE	include/hal_com_reg.h	884;"	d
-IMR_TSF_BIT32_TOGGLE_8188F	include/rtl8188f_spec.h	243;"	d
-IMR_TSF_BIT32_TOGGLE_8192E	include/rtl8192e_spec.h	242;"	d
-IMR_TSF_BIT32_TOGGLE_8703B	include/rtl8703b_spec.h	420;"	d
-IMR_TSF_BIT32_TOGGLE_8723B	include/rtl8723b_spec.h	236;"	d
-IMR_TSF_BIT32_TOGGLE_8723D	hal/phydm/rtl8723d/hal8723dreg.h	473;"	d
-IMR_TSF_BIT32_TOGGLE_8812	include/rtl8812a_spec.h	197;"	d
-IMR_TSF_BIT32_TOGGLE_8814A	include/rtl8814a_spec.h	572;"	d
-IMR_TSF_BIT32_TOGGLE_88E	include/hal_com_reg.h	1017;"	d
-IMR_TXBCN0ERR_8188F	include/rtl8188f_spec.h	241;"	d
-IMR_TXBCN0ERR_8192E	include/rtl8192e_spec.h	240;"	d
-IMR_TXBCN0ERR_8703B	include/rtl8703b_spec.h	418;"	d
-IMR_TXBCN0ERR_8723B	include/rtl8723b_spec.h	234;"	d
-IMR_TXBCN0ERR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	471;"	d
-IMR_TXBCN0ERR_8812	include/rtl8812a_spec.h	195;"	d
-IMR_TXBCN0ERR_8814A	include/rtl8814a_spec.h	570;"	d
-IMR_TXBCN0OK_8188F	include/rtl8188f_spec.h	242;"	d
-IMR_TXBCN0OK_8192E	include/rtl8192e_spec.h	241;"	d
-IMR_TXBCN0OK_8703B	include/rtl8703b_spec.h	419;"	d
-IMR_TXBCN0OK_8723B	include/rtl8723b_spec.h	235;"	d
-IMR_TXBCN0OK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	472;"	d
-IMR_TXBCN0OK_8812	include/rtl8812a_spec.h	196;"	d
-IMR_TXBCN0OK_8814A	include/rtl8814a_spec.h	571;"	d
-IMR_TXCCK_88E	include/hal_com_reg.h	1011;"	d
-IMR_TXERR	include/hal_com_reg.h	886;"	d
-IMR_TXERR_8188F	include/rtl8188f_spec.h	277;"	d
-IMR_TXERR_8192E	include/rtl8192e_spec.h	276;"	d
-IMR_TXERR_8703B	include/rtl8703b_spec.h	454;"	d
-IMR_TXERR_8723B	include/rtl8723b_spec.h	270;"	d
-IMR_TXERR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	507;"	d
-IMR_TXERR_8812	include/rtl8812a_spec.h	231;"	d
-IMR_TXERR_8814A	include/rtl8814a_spec.h	607;"	d
-IMR_TXERR_88E	include/hal_com_reg.h	1052;"	d
-IMR_TXFOVW	include/hal_com_reg.h	866;"	d
-IMR_TXFOVW_8188F	include/rtl8188f_spec.h	279;"	d
-IMR_TXFOVW_8192E	include/rtl8192e_spec.h	278;"	d
-IMR_TXFOVW_8703B	include/rtl8703b_spec.h	456;"	d
-IMR_TXFOVW_8723B	include/rtl8723b_spec.h	272;"	d
-IMR_TXFOVW_8723D	hal/phydm/rtl8723d/hal8723dreg.h	509;"	d
-IMR_TXFOVW_8812	include/rtl8812a_spec.h	233;"	d
-IMR_TXFOVW_8814A	include/rtl8814a_spec.h	609;"	d
-IMR_TXFOVW_88E	include/hal_com_reg.h	1054;"	d
-IMR_TX_MASK	include/rtl8188e_spec.h	134;"	d
-IMR_TX_MASK	include/rtl8188f_spec.h	284;"	d
-IMR_TX_MASK	include/rtl8703b_spec.h	461;"	d
-IMR_TX_MASK	include/rtl8723b_spec.h	277;"	d
-IMR_TX_MASK	include/rtl8723d_spec.h	438;"	d
-IMR_TX_MASK	include/rtl8812a_spec.h	239;"	d
-IMR_TX_MASK	include/rtl8814a_spec.h	614;"	d
-IMR_VIDOK	include/hal_com_reg.h	879;"	d
-IMR_VIDOK_8188F	include/rtl8188f_spec.h	256;"	d
-IMR_VIDOK_8192E	include/rtl8192e_spec.h	255;"	d
-IMR_VIDOK_8703B	include/rtl8703b_spec.h	433;"	d
-IMR_VIDOK_8723B	include/rtl8723b_spec.h	249;"	d
-IMR_VIDOK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	486;"	d
-IMR_VIDOK_8812	include/rtl8812a_spec.h	210;"	d
-IMR_VIDOK_8814A	include/rtl8814a_spec.h	585;"	d
-IMR_VIDOK_88E	include/hal_com_reg.h	1031;"	d
-IMR_VODOK	include/hal_com_reg.h	880;"	d
-IMR_VODOK_8188F	include/rtl8188f_spec.h	257;"	d
-IMR_VODOK_8192E	include/rtl8192e_spec.h	256;"	d
-IMR_VODOK_8703B	include/rtl8703b_spec.h	434;"	d
-IMR_VODOK_8723B	include/rtl8723b_spec.h	250;"	d
-IMR_VODOK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	487;"	d
-IMR_VODOK_8812	include/rtl8812a_spec.h	211;"	d
-IMR_VODOK_8814A	include/rtl8814a_spec.h	586;"	d
-IMR_VODOK_88E	include/hal_com_reg.h	1032;"	d
-IMR_WLANOFF	include/hal_com_reg.h	892;"	d
-IN	include/basic_types.h	133;"	d
-IN	include/basic_types.h	85;"	d
-INCLUDE_MULTI_FUNC_BT	include/rtl8188e_hal.h	230;"	d
-INCLUDE_MULTI_FUNC_BT	include/rtl8188f_hal.h	188;"	d
-INCLUDE_MULTI_FUNC_BT	include/rtl8192e_hal.h	226;"	d
-INCLUDE_MULTI_FUNC_BT	include/rtl8703b_hal.h	198;"	d
-INCLUDE_MULTI_FUNC_BT	include/rtl8723b_hal.h	198;"	d
-INCLUDE_MULTI_FUNC_BT	include/rtl8723d_hal.h	206;"	d
-INCLUDE_MULTI_FUNC_BT	include/rtl8812a_hal.h	255;"	d
-INCLUDE_MULTI_FUNC_GPS	include/rtl8188e_hal.h	231;"	d
-INCLUDE_MULTI_FUNC_GPS	include/rtl8188f_hal.h	189;"	d
-INCLUDE_MULTI_FUNC_GPS	include/rtl8192e_hal.h	227;"	d
-INCLUDE_MULTI_FUNC_GPS	include/rtl8703b_hal.h	199;"	d
-INCLUDE_MULTI_FUNC_GPS	include/rtl8723b_hal.h	199;"	d
-INCLUDE_MULTI_FUNC_GPS	include/rtl8723d_hal.h	208;"	d
-INCLUDE_MULTI_FUNC_GPS	include/rtl8812a_hal.h	256;"	d
-INIDATA_RATE	include/hal_data.h	/^	u8			INIDATA_RATE[MACID_NUM_SW_LIMIT];$/;"	m	struct:hal_com_data
-INIT_ANTDIV_TIMMER	hal/phydm/phydm_antdiv.h	90;"	d
-INIT_LIST_HEAD	include/osdep_service_bsd.h	/^static inline void INIT_LIST_HEAD(struct list_head *list)$/;"	f
-INIT_RA_TABLE	hal/phydm/phydm_debug.h	72;"	d
-INSTALL_PREFIX	Makefile	/^INSTALL_PREFIX :=$/;"	m
-INTEL_VENDOR_ID	include/drv_types_pci.h	29;"	d
-INTERFACE_SELECT_PCIE	include/hal_data.h	/^} INTERFACE_SELECT_PCIE, *PINTERFACE_SELECT_PCIE;$/;"	t	typeref:enum:_INTERFACE_SELECT_PCIE
-INTERFACE_SELECT_USB	include/hal_data.h	/^} INTERFACE_SELECT_USB, *PINTERFACE_SELECT_USB;$/;"	t	typeref:enum:_INTERFACE_SELECT_USB
-INTERFACE_VERSION	hal/phydm/phydm_interface.h	25;"	d
-INTERRUPT_MSG_FORMAT_LEN	include/usb_ops_linux.h	32;"	d
-INTEl_WIDI_WK_CID	include/rtw_cmd.h	/^	INTEl_WIDI_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-INTF_DATA	include/drv_types.h	453;"	d
-INTF_DATA	include/drv_types.h	457;"	d
-INTF_OPS	include/drv_types.h	454;"	d
-INTF_SEL0_SOLO_MINICARD	include/hal_data.h	/^	INTF_SEL0_SOLO_MINICARD			= 0,		\/* WiFi solo-mCard *\/$/;"	e	enum:_INTERFACE_SELECT_PCIE
-INTF_SEL0_USB	include/hal_data.h	/^	INTF_SEL0_USB 				= 0,		\/* USB *\/$/;"	e	enum:_INTERFACE_SELECT_USB
-INTF_SEL1_BT_COMBO_MINICARD	include/hal_data.h	/^	INTF_SEL1_BT_COMBO_MINICARD		= 1,		\/* WiFi+BT combo-mCard *\/$/;"	e	enum:_INTERFACE_SELECT_PCIE
-INTF_SEL1_USB_High_Power	include/hal_data.h	/^	INTF_SEL1_USB_High_Power  	= 1,		\/* USB with high power PA *\/$/;"	e	enum:_INTERFACE_SELECT_USB
-INTF_SEL2_MINICARD	include/hal_data.h	/^	INTF_SEL2_MINICARD		  	= 2,		\/* Minicard *\/$/;"	e	enum:_INTERFACE_SELECT_USB
-INTF_SEL2_PCIe	include/hal_data.h	/^	INTF_SEL2_PCIe						= 2,		\/* PCIe Card *\/$/;"	e	enum:_INTERFACE_SELECT_PCIE
-INTF_SEL3_USB_Solo	include/hal_data.h	/^	INTF_SEL3_USB_Solo 		= 3,		\/* USB solo-Slim module *\/$/;"	e	enum:_INTERFACE_SELECT_USB
-INTF_SEL4_USB_Combo	include/hal_data.h	/^	INTF_SEL4_USB_Combo		= 4,		\/* USB Combo-Slim module *\/$/;"	e	enum:_INTERFACE_SELECT_USB
-INTF_SEL5_USB_Combo_MF	include/hal_data.h	/^	INTF_SEL5_USB_Combo_MF	= 5,		\/* USB WiFi+BT Multi-Function Combo, i.e., Proprietary layout(AS-VAU) which is the same as SDIO card *\/$/;"	e	enum:_INTERFACE_SELECT_USB
-INT_BULK_SEL	include/hal_com_reg.h	1756;"	d
-INVALID_CAM_ID	include/drv_types.h	814;"	d
-INVALID_SEC_MAC_CAM_ID	include/rtw_security.h	56;"	d
-IOCMD_STRUCT	include/rtw_mp.h	/^} IOCMD_STRUCT;$/;"	t	typeref:struct:_IOCMD_STRUCT_
-IOL_CMD	include/rtw_iol.h	/^} IO_OFFLOAD_CMD, IOL_CMD;$/;"	t	typeref:struct:_io_offload_cmd
-IOL_CMD_DELAY_MS	include/rtw_iol.h	93;"	d
-IOL_CMD_DELAY_US	include/rtw_iol.h	92;"	d
-IOL_CMD_END	include/rtw_iol.h	95;"	d
-IOL_CMD_LLT	include/rtw_iol.h	86;"	d
-IOL_CMD_WB_REG	include/rtw_iol.h	88;"	d
-IOL_CMD_WD_REG	include/rtw_iol.h	90;"	d
-IOL_CMD_WW_REG	include/rtw_iol.h	89;"	d
-IOL_exec_cmds_sync	include/hal_intf.h	/^	int (*IOL_exec_cmds_sync)(_adapter *padapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);$/;"	m	struct:hal_ops
-IOREG_CMD_DELAY_MS	include/rtw_iol.h	/^	IOREG_CMD_DELAY_MS	= 0x11,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_DELAY_US	include/rtw_iol.h	/^	IOREG_CMD_DELAY_US	= 0x10,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_EFUSE_PATH	include/rtw_iol.h	/^	IOREG_CMD_EFUSE_PATH = 0x03,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_END	include/rtw_iol.h	/^	IOREG_CMD_END		= 0xFF,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_END_LEN	include/rtw_iol.h	35;"	d
-IOREG_CMD_LLT	include/rtw_iol.h	/^	IOREG_CMD_LLT			= 0x01,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_REFUSE	include/rtw_iol.h	/^	IOREG_CMD_REFUSE		= 0x02,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_WB_REG	include/rtw_iol.h	/^	IOREG_CMD_WB_REG		= 0x04,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_WD_REG	include/rtw_iol.h	/^	IOREG_CMD_WD_REG	= 0x06,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_WW_REG	include/rtw_iol.h	/^	IOREG_CMD_WW_REG	= 0x05,$/;"	e	enum:ioreg_cmd
-IOREG_CMD_W_RF	include/rtw_iol.h	/^	IOREG_CMD_W_RF		= 0x07,$/;"	e	enum:ioreg_cmd
-IOTPeer	hal/phydm/phydm.h	/^	u1Byte		IOTPeer;		\/*Enum value.	HT_IOT_PEER_E*\/$/;"	m	struct:_ODM_STA_INFO
-IOTPeer	include/sta_info.h	/^	u8		IOTPeer;			\/* Enum value.	HT_IOT_PEER_E *\/$/;"	m	struct:sta_info
-IO_OFFLOAD_CMD	include/rtw_iol.h	/^} IO_OFFLOAD_CMD, IOL_CMD;$/;"	t	typeref:struct:_io_offload_cmd
-IO_RD16	include/rtw_io.h	63;"	d
-IO_RD16_ASYNC	include/rtw_io.h	67;"	d
-IO_RD32	include/rtw_io.h	62;"	d
-IO_RD32_ASYNC	include/rtw_io.h	66;"	d
-IO_RD8	include/rtw_io.h	64;"	d
-IO_RD8_ASYNC	include/rtw_io.h	68;"	d
-IO_RD_BURST	include/rtw_io.h	85;"	d
-IO_WR16	include/rtw_io.h	71;"	d
-IO_WR16_ASYNC	include/rtw_io.h	75;"	d
-IO_WR32	include/rtw_io.h	70;"	d
-IO_WR32_ASYNC	include/rtw_io.h	74;"	d
-IO_WR8	include/rtw_io.h	72;"	d
-IO_WR8_ASYNC	include/rtw_io.h	76;"	d
-IO_WR_BURST	include/rtw_io.h	84;"	d
-IPDEFTTL	include/ip.h	70;"	d
-IPOPT_CLASS	include/ip.h	50;"	d
-IPOPT_CLASS_MASK	include/ip.h	46;"	d
-IPOPT_CONTROL	include/ip.h	53;"	d
-IPOPT_COPIED	include/ip.h	49;"	d
-IPOPT_COPY	include/ip.h	45;"	d
-IPOPT_END	include/ip.h	58;"	d
-IPOPT_EOL	include/ip.h	86;"	d
-IPOPT_LSRR	include/ip.h	61;"	d
-IPOPT_MEASUREMENT	include/ip.h	55;"	d
-IPOPT_MINOFF	include/ip.h	83;"	d
-IPOPT_NOOP	include/ip.h	59;"	d
-IPOPT_NOP	include/ip.h	85;"	d
-IPOPT_NUMBER	include/ip.h	51;"	d
-IPOPT_NUMBER_MASK	include/ip.h	47;"	d
-IPOPT_OFFSET	include/ip.h	82;"	d
-IPOPT_OLEN	include/ip.h	81;"	d
-IPOPT_OPTVAL	include/ip.h	80;"	d
-IPOPT_RA	include/ip.h	66;"	d
-IPOPT_RESERVED1	include/ip.h	54;"	d
-IPOPT_RESERVED2	include/ip.h	56;"	d
-IPOPT_RR	include/ip.h	63;"	d
-IPOPT_SEC	include/ip.h	60;"	d
-IPOPT_SID	include/ip.h	64;"	d
-IPOPT_SSRR	include/ip.h	65;"	d
-IPOPT_TIMESTAMP	include/ip.h	62;"	d
-IPOPT_TS	include/ip.h	87;"	d
-IPOPT_TS_PRESPEC	include/ip.h	91;"	d
-IPOPT_TS_TSANDADDR	include/ip.h	90;"	d
-IPOPT_TS_TSONLY	include/ip.h	89;"	d
-IPS_LEVEL_2	include/rtw_pwrctrl.h	/^	IPS_LEVEL_2,$/;"	e	enum:__anon64
-IPS_NONE	include/rtw_pwrctrl.h	/^	IPS_NONE = 0,$/;"	e	enum:__anon64
-IPS_NORMAL	include/rtw_pwrctrl.h	/^	IPS_NORMAL,$/;"	e	enum:__anon64
-IPS_NUM	include/rtw_pwrctrl.h	/^	IPS_NUM$/;"	e	enum:__anon64
-IPTOS_LOWDELAY	include/ip.h	27;"	d
-IPTOS_MINCOST	include/ip.h	30;"	d
-IPTOS_PREC	include/ip.h	33;"	d
-IPTOS_PREC_CRITIC_ECP	include/ip.h	36;"	d
-IPTOS_PREC_FLASH	include/ip.h	38;"	d
-IPTOS_PREC_FLASHOVERRIDE	include/ip.h	37;"	d
-IPTOS_PREC_IMMEDIATE	include/ip.h	39;"	d
-IPTOS_PREC_INTERNETCONTROL	include/ip.h	35;"	d
-IPTOS_PREC_MASK	include/ip.h	32;"	d
-IPTOS_PREC_NETCONTROL	include/ip.h	34;"	d
-IPTOS_PREC_PRIORITY	include/ip.h	40;"	d
-IPTOS_PREC_ROUTINE	include/ip.h	41;"	d
-IPTOS_RELIABILITY	include/ip.h	29;"	d
-IPTOS_THROUGHPUT	include/ip.h	28;"	d
-IPTOS_TOS	include/ip.h	26;"	d
-IPTOS_TOS_MASK	include/ip.h	25;"	d
-IPV4_DST	include/rtw_mlme.h	1182;"	d
-IPV4_SRC	include/rtw_mlme.h	1181;"	d
-IPVERSION	include/ip.h	68;"	d
-IP_ARG	include/ieee80211.h	1474;"	d
-IP_FMT	include/ieee80211.h	1473;"	d
-IP_MCAST_MAC	include/wifi.h	1352;"	d
-IP_OFFSET	core/rtw_wlan_util.c	28;"	d	file:
-IQC_Matrix	hal/phydm/phydm_iqk.h	/^	u4Byte		IQC_Matrix[2][NUM];$/;"	m	struct:_IQK_INFORMATION
-IQKFWOffload	hal/phydm/phydm.h	/^	u1Byte			IQKFWOffload;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IQKMatrixRegSetting	hal/phydm/phydm_powertracking_ap.h	/^	IQK_MATRIX_REGS_SETTING IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQKMatrixRegSetting	hal/phydm/phydm_powertracking_ce.h	/^	IQK_MATRIX_REGS_SETTING IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQKMatrixRegSetting	hal/phydm/phydm_powertracking_win.h	/^	IQK_MATRIX_REGS_SETTING IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQKSpinLock	include/hal_data.h	/^	_lock		IQKSpinLock;$/;"	m	struct:hal_com_data
-IQK_ADDA_REG_NUM	hal/phydm/phydm_powertracking_ap.h	46;"	d
-IQK_ADDA_REG_NUM	hal/phydm/phydm_powertracking_ce.h	42;"	d
-IQK_ADDA_REG_NUM	hal/phydm/phydm_powertracking_win.h	45;"	d
-IQK_BB_REG_NUM	hal/phydm/phydm_powertracking_ap.h	49;"	d
-IQK_BB_REG_NUM	hal/phydm/phydm_powertracking_ce.h	45;"	d
-IQK_BB_REG_NUM	hal/phydm/phydm_powertracking_win.h	47;"	d
-IQK_BB_REG_NUM_92C	include/hal_data.h	105;"	d
-IQK_BB_REG_NUM_92D	include/hal_data.h	106;"	d
-IQK_BB_REG_NUM_MAX	hal/phydm/phydm_powertracking_ap.h	47;"	d
-IQK_BB_REG_NUM_MAX	hal/phydm/phydm_powertracking_ce.h	43;"	d
-IQK_BB_REG_NUM_test	include/hal_data.h	107;"	d
-IQK_BB_backup	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	IQK_BB_backup[IQK_BB_REG_NUM];	$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_BB_backup	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	IQK_BB_backup[IQK_BB_REG_NUM];	$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_BB_backup	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	IQK_BB_backup[IQK_BB_REG_NUM];	$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_BB_backup_recover	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	IQK_BB_backup_recover[9];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_BB_backup_recover	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	IQK_BB_backup_recover[9];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_BB_backup_recover	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	IQK_BB_backup_recover[9];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_CFIR_imag	hal/phydm/phydm_iqk.h	/^	u4Byte		IQK_CFIR_imag[2][4][2][8]; \/*channel \/ path \/ TRX(TX:0, RX:1) \/ CFIR_imag*\/$/;"	m	struct:_IQK_INFORMATION
-IQK_CFIR_real	hal/phydm/phydm_iqk.h	/^	u4Byte		IQK_CFIR_real[2][4][2][8]; \/*channel \/ path \/ TRX(TX:0, RX:1) \/ CFIR_real*\/$/;"	m	struct:_IQK_INFORMATION
-IQK_Channel	hal/phydm/phydm_iqk.h	/^	u4Byte		IQK_Channel[2];$/;"	m	struct:_IQK_INFORMATION
-IQK_DELAY_TIME	hal/phydm/halphyrf_ap.h	133;"	d
-IQK_DELAY_TIME	hal/phydm/phydm.h	161;"	d
-IQK_DELAY_TIME	hal/phydm/rtl8723d/halphyrf_8723d.c	815;"	d	file:
-IQK_DELAY_TIME_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	29;"	d	file:
-IQK_DELAY_TIME_8723D	hal/phydm/rtl8723d/halphyrf_8723d.h	25;"	d
-IQK_INFO	hal/phydm/phydm_iqk.h	/^} IQK_INFO, *PIQK_INFO;$/;"	t	typeref:struct:_IQK_INFORMATION
-IQK_MAC_REG_NUM	hal/phydm/phydm_powertracking_ap.h	45;"	d
-IQK_MAC_REG_NUM	hal/phydm/phydm_powertracking_ce.h	41;"	d
-IQK_MAC_REG_NUM	hal/phydm/phydm_powertracking_win.h	44;"	d
-IQK_MAC_backup	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	IQK_MAC_backup[IQK_MAC_REG_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_MAC_backup	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	IQK_MAC_backup[IQK_MAC_REG_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_MAC_backup	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	IQK_MAC_backup[IQK_MAC_REG_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_ap.h	/^}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;$/;"	t	typeref:struct:_IQK_MATRIX_REGS_SETTING
-IQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_ce.h	/^}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;$/;"	t	typeref:struct:_IQK_MATRIX_REGS_SETTING
-IQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_win.h	/^}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;$/;"	t	typeref:struct:_IQK_MATRIX_REGS_SETTING
-IQK_MP_Switch	include/hal_data.h	/^	u8		IQK_MP_Switch;$/;"	m	struct:hal_com_data
-IQK_Matrix_REG_NUM	hal/phydm/phydm_powertracking_ap.h	54;"	d
-IQK_Matrix_REG_NUM	hal/phydm/phydm_powertracking_ce.h	49;"	d
-IQK_Matrix_REG_NUM	hal/phydm/phydm_powertracking_win.h	43;"	d
-IQK_Matrix_Settings_NUM	hal/phydm/phydm_powertracking_ap.h	56;"	d
-IQK_Matrix_Settings_NUM	hal/phydm/phydm_powertracking_ce.h	50;"	d
-IQK_Matrix_Settings_NUM	hal/phydm/phydm_powertracking_win.h	40;"	d
-IQK_Matrix_Settings_NUM_92D	include/hal_data.h	109;"	d
-IQK_OFFLOAD_LEN	hal/hal_com_c2h.h	87;"	d
-IQK_ProgressingTime	hal/phydm/phydm_powertracking_ap.h	/^	u8Byte	IQK_ProgressingTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_ProgressingTime	hal/phydm/phydm_powertracking_ce.h	/^	u8Byte	IQK_ProgressingTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_ProgressingTime	hal/phydm/phydm_powertracking_win.h	/^	u8Byte	IQK_ProgressingTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_StartTime	hal/phydm/phydm_powertracking_ap.h	/^	u8Byte	IQK_StartTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_StartTime	hal/phydm/phydm_powertracking_ce.h	/^	u8Byte	IQK_StartTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_StartTime	hal/phydm/phydm_powertracking_win.h	/^	u8Byte	IQK_StartTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_THRESHOLD	hal/phydm/phydm.h	170;"	d
-IQK_TotalProgressingTime	hal/phydm/phydm_powertracking_ap.h	/^	u8Byte	IQK_TotalProgressingTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_TotalProgressingTime	hal/phydm/phydm_powertracking_ce.h	/^	u8Byte	IQK_TotalProgressingTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_TotalProgressingTime	hal/phydm/phydm_powertracking_win.h	/^	u8Byte	IQK_TotalProgressingTime;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQK_fail	hal/phydm/phydm_iqk.h	/^	BOOLEAN		IQK_fail[2][NUM];$/;"	m	struct:_IQK_INFORMATION
-IQK_fail_report	hal/phydm/phydm_iqk.h	/^	BOOLEAN		IQK_fail_report[2][4][2]; \/*channel\/path\/TRX(TX:0, RX:1)*\/$/;"	m	struct:_IQK_INFORMATION
-IQK_info	hal/phydm/phydm.h	/^	IQK_INFO	IQK_info;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IQKstep	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	IQKstep;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQKstep	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	IQKstep;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQKstep	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	IQKstep;$/;"	m	struct:ODM_RF_Calibration_Structure
-IQKtimes	hal/phydm/phydm_iqk.h	/^	u1Byte      IQKtimes;$/;"	m	struct:_IQK_INFORMATION
-ISO_DIOE	include/hal_com_reg.h	1145;"	d
-ISO_DIOP	include/hal_com_reg.h	1144;"	d
-ISO_DIOR	include/hal_com_reg.h	1147;"	d
-ISO_EB2CORE	include/hal_com_reg.h	1146;"	d
-ISO_IP2MAC	include/hal_com_reg.h	1143;"	d
-ISO_MD2PP	include/hal_com_reg.h	1138;"	d
-ISO_PA2PCIE	include/hal_com_reg.h	1141;"	d
-ISO_PD2CORE	include/hal_com_reg.h	1142;"	d
-ISO_UA2USB	include/hal_com_reg.h	1139;"	d
-ISO_UD2CORE	include/hal_com_reg.h	1140;"	d
-ISR_8192E	include/rtl8192e_spec.h	228;"	d
-ISR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	443;"	d
-ISR_8812	include/rtl8812a_spec.h	183;"	d
-ISR_8814A	include/rtl8814a_spec.h	540;"	d
-ISR_88E	include/rtl8188e_spec.h	130;"	d
-IS_1T1R	include/HalVerDef.h	151;"	d
-IS_1T2R	include/HalVerDef.h	152;"	d
-IS_1T_RATE	include/ieee80211.h	860;"	d
-IS_1T_RATE_SECTION	include/ieee80211.h	981;"	d
-IS_2T2R	include/HalVerDef.h	153;"	d
-IS_2T_RATE	include/ieee80211.h	861;"	d
-IS_2T_RATE_SECTION	include/ieee80211.h	982;"	d
-IS_3T3R	include/HalVerDef.h	154;"	d
-IS_3T4R	include/HalVerDef.h	155;"	d
-IS_3T_RATE	include/ieee80211.h	862;"	d
-IS_3T_RATE_SECTION	include/ieee80211.h	983;"	d
-IS_4T4R	include/HalVerDef.h	156;"	d
-IS_4T_RATE	include/ieee80211.h	863;"	d
-IS_4T_RATE_SECTION	include/ieee80211.h	984;"	d
-IS_8188E	include/HalVerDef.h	118;"	d
-IS_8188F	include/HalVerDef.h	119;"	d
-IS_8192E	include/HalVerDef.h	120;"	d
-IS_8703B_SERIES	include/HalVerDef.h	125;"	d
-IS_8723B_SERIES	include/HalVerDef.h	124;"	d
-IS_8723D_SERIES	include/HalVerDef.h	128;"	d
-IS_8812_SERIES	include/HalVerDef.h	121;"	d
-IS_8814A_SERIES	include/HalVerDef.h	123;"	d
-IS_8821C_SERIES	include/HalVerDef.h	127;"	d
-IS_8821_SERIES	include/HalVerDef.h	122;"	d
-IS_8822B_SERIES	include/HalVerDef.h	126;"	d
-IS_ALPHA2_NO_SPECIFIED	include/rtw_rf.h	236;"	d
-IS_ANT_DETECT_SUPPORT_RSSI	include/hal_phy.h	55;"	d
-IS_ANT_DETECT_SUPPORT_SINGLE_TONE	include/hal_phy.h	54;"	d
-IS_A_CUT	include/HalVerDef.h	135;"	d
-IS_BB_REG_OFFSET_92S	include/Hal8188EPhyReg.h	501;"	d
-IS_BB_REG_OFFSET_92S	include/Hal8188FPhyReg.h	509;"	d
-IS_BB_REG_OFFSET_92S	include/Hal8192EPhyReg.h	510;"	d
-IS_BB_REG_OFFSET_92S	include/Hal8703BPhyReg.h	537;"	d
-IS_BB_REG_OFFSET_92S	include/Hal8723BPhyReg.h	536;"	d
-IS_BB_REG_OFFSET_92S	include/Hal8723DPhyReg.h	538;"	d
-IS_BB_REG_OFFSET_92S	include/rtw_mp_phy_regdef.h	453;"	d
-IS_B_CUT	include/HalVerDef.h	136;"	d
-IS_CAC_STOPPED	include/drv_types.h	808;"	d
-IS_CCK_RATE	hal/phydm/halphyrf_ap.h	128;"	d
-IS_CCK_RATE	include/ieee80211.h	847;"	d
-IS_CCK_RATE_SECTION	include/ieee80211.h	976;"	d
-IS_CHIP_VENDOR_SMIC	include/HalVerDef.h	148;"	d
-IS_CHIP_VENDOR_TSMC	include/HalVerDef.h	146;"	d
-IS_CHIP_VENDOR_UMC	include/HalVerDef.h	147;"	d
-IS_CH_WAITING	include/drv_types.h	809;"	d
-IS_C_CUT	include/HalVerDef.h	137;"	d
-IS_D_CUT	include/HalVerDef.h	138;"	d
-IS_E_CUT	include/HalVerDef.h	139;"	d
-IS_E_CUT	include/rtl8723b_spec.h	167;"	d
-IS_E_CUT	include/rtl8723b_spec.h	168;"	d
-IS_FULL_SPEED_USB	include/usb_ops.h	111;"	d
-IS_FW_81xxC	hal/rtl8723d/rtl8723d_hal_init.c	367;"	d	file:
-IS_FW_HEADER_EXIST_8188F	include/rtl8188f_hal.h	43;"	d
-IS_FW_HEADER_EXIST_8192E	include/rtl8192e_hal.h	64;"	d
-IS_FW_HEADER_EXIST_8703B	include/rtl8703b_hal.h	43;"	d
-IS_FW_HEADER_EXIST_8723B	include/rtl8723b_hal.h	43;"	d
-IS_FW_HEADER_EXIST_8723D	include/rtl8723d_hal.h	46;"	d
-IS_FW_HEADER_EXIST_8812	include/rtl8812a_hal.h	90;"	d
-IS_FW_HEADER_EXIST_8821	include/rtl8812a_hal.h	92;"	d
-IS_FW_HEADER_EXIST_88E	include/rtl8188e_hal.h	65;"	d
-IS_F_CUT	include/HalVerDef.h	140;"	d
-IS_F_CUT	include/rtl8723b_spec.h	169;"	d
-IS_F_CUT	include/rtl8723b_spec.h	170;"	d
-IS_HARDWARE_TYPE_8188E	include/hal_intf.h	458;"	d
-IS_HARDWARE_TYPE_8188EE	include/hal_intf.h	455;"	d
-IS_HARDWARE_TYPE_8188ES	include/hal_intf.h	457;"	d
-IS_HARDWARE_TYPE_8188EU	include/hal_intf.h	456;"	d
-IS_HARDWARE_TYPE_8188F	include/hal_intf.h	525;"	d
-IS_HARDWARE_TYPE_8188FE	include/hal_intf.h	522;"	d
-IS_HARDWARE_TYPE_8188FS	include/hal_intf.h	523;"	d
-IS_HARDWARE_TYPE_8188FU	include/hal_intf.h	524;"	d
-IS_HARDWARE_TYPE_8192E	include/hal_intf.h	484;"	d
-IS_HARDWARE_TYPE_8192EE	include/hal_intf.h	480;"	d
-IS_HARDWARE_TYPE_8192ES	include/hal_intf.h	482;"	d
-IS_HARDWARE_TYPE_8192EU	include/hal_intf.h	481;"	d
-IS_HARDWARE_TYPE_8703B	include/hal_intf.h	506;"	d
-IS_HARDWARE_TYPE_8703BE	include/hal_intf.h	503;"	d
-IS_HARDWARE_TYPE_8703BS	include/hal_intf.h	504;"	d
-IS_HARDWARE_TYPE_8703BU	include/hal_intf.h	505;"	d
-IS_HARDWARE_TYPE_8723B	include/hal_intf.h	491;"	d
-IS_HARDWARE_TYPE_8723BE	include/hal_intf.h	487;"	d
-IS_HARDWARE_TYPE_8723BS	include/hal_intf.h	489;"	d
-IS_HARDWARE_TYPE_8723BU	include/hal_intf.h	488;"	d
-IS_HARDWARE_TYPE_8723D	include/hal_intf.h	516;"	d
-IS_HARDWARE_TYPE_8723DE	include/hal_intf.h	510;"	d
-IS_HARDWARE_TYPE_8723DS	include/hal_intf.h	512;"	d
-IS_HARDWARE_TYPE_8723DU	include/hal_intf.h	514;"	d
-IS_HARDWARE_TYPE_8811AU	include/hal_intf.h	469;"	d
-IS_HARDWARE_TYPE_8812	include/hal_intf.h	464;"	d
-IS_HARDWARE_TYPE_8812AU	include/hal_intf.h	463;"	d
-IS_HARDWARE_TYPE_8812E	include/hal_intf.h	462;"	d
-IS_HARDWARE_TYPE_8814A	include/hal_intf.h	499;"	d
-IS_HARDWARE_TYPE_8814AE	include/hal_intf.h	495;"	d
-IS_HARDWARE_TYPE_8814AS	include/hal_intf.h	497;"	d
-IS_HARDWARE_TYPE_8814AU	include/hal_intf.h	496;"	d
-IS_HARDWARE_TYPE_8821	include/hal_intf.h	473;"	d
-IS_HARDWARE_TYPE_8821B	include/hal_intf.h	532;"	d
-IS_HARDWARE_TYPE_8821BE	include/hal_intf.h	528;"	d
-IS_HARDWARE_TYPE_8821BS	include/hal_intf.h	530;"	d
-IS_HARDWARE_TYPE_8821BU	include/hal_intf.h	529;"	d
-IS_HARDWARE_TYPE_8821C	include/hal_intf.h	544;"	d
-IS_HARDWARE_TYPE_8821CE	include/hal_intf.h	541;"	d
-IS_HARDWARE_TYPE_8821CS	include/hal_intf.h	543;"	d
-IS_HARDWARE_TYPE_8821CU	include/hal_intf.h	542;"	d
-IS_HARDWARE_TYPE_8821E	include/hal_intf.h	468;"	d
-IS_HARDWARE_TYPE_8821S	include/hal_intf.h	472;"	d
-IS_HARDWARE_TYPE_8821U	include/hal_intf.h	470;"	d
-IS_HARDWARE_TYPE_8822B	include/hal_intf.h	538;"	d
-IS_HARDWARE_TYPE_8822BE	include/hal_intf.h	535;"	d
-IS_HARDWARE_TYPE_8822BS	include/hal_intf.h	537;"	d
-IS_HARDWARE_TYPE_8822BU	include/hal_intf.h	536;"	d
-IS_HARDWARE_TYPE_JAGUAR	include/hal_intf.h	476;"	d
-IS_HARDWARE_TYPE_JAGUAR2	include/hal_intf.h	547;"	d
-IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2	include/hal_intf.h	550;"	d
-IS_HIGH_SPEED_USB	include/usb_ops.h	112;"	d
-IS_HT1SS_RATE	include/ieee80211.h	850;"	d
-IS_HT2SS_RATE	include/ieee80211.h	851;"	d
-IS_HT3SS_RATE	include/ieee80211.h	852;"	d
-IS_HT4SS_RATE	include/ieee80211.h	853;"	d
-IS_HT_RATE	include/ieee80211.h	845;"	d
-IS_HT_RATE_SECTION	include/ieee80211.h	978;"	d
-IS_I_CUT	include/HalVerDef.h	141;"	d
-IS_J_CUT	include/HalVerDef.h	142;"	d
-IS_K_CUT	include/HalVerDef.h	143;"	d
-IS_LED_BLINKING	include/hal_com_led.h	218;"	d
-IS_LED_BLINKING	include/hal_com_led.h	289;"	d
-IS_LED_WPS_BLINKING	include/hal_com_led.h	214;"	d
-IS_LED_WPS_BLINKING	include/hal_com_led.h	285;"	d
-IS_MAC_ADDRESS_BROADCAST	core/rtw_ioctl_set.c	28;"	d	file:
-IS_MASKED	include/rtw_efuse.h	81;"	d
-IS_MASKED_MP	include/rtw_efuse.h	73;"	d
-IS_MASKED_TC	include/rtw_efuse.h	74;"	d
-IS_MCAST	include/wifi.h	/^__inline static int IS_MCAST(unsigned char *da)$/;"	f
-IS_MPT_CCK_RATE	include/rtw_mp.h	699;"	d
-IS_MPT_HT_RATE	include/rtw_mp.h	697;"	d
-IS_MPT_OFDM_RATE	include/rtw_mp.h	700;"	d
-IS_MPT_VHT_RATE	include/rtw_mp.h	698;"	d
-IS_NEW_GENERATION_IC	include/hal_intf.h	451;"	d
-IS_NORMAL_CHIP	include/HalVerDef.h	132;"	d
-IS_OFDM_RATE	include/ieee80211.h	848;"	d
-IS_OFDM_RATE_SECTION	include/ieee80211.h	977;"	d
-IS_PG_TXPWR_BASE_INVALID	hal/hal_com_phycfg.c	29;"	d	file:
-IS_PG_TXPWR_DIFF_INVALID	hal/hal_com_phycfg.c	30;"	d	file:
-IS_SUPER_SPEED_USB	include/usb_ops.h	113;"	d
-IS_TEST_CHIP	include/HalVerDef.h	131;"	d
-IS_UNDER_CAC	include/drv_types.h	810;"	d
-IS_VENDOR_8188E_I_CUT_SERIES	include/HalVerDef.h	182;"	d
-IS_VENDOR_8192E_B_CUT	include/HalVerDef.h	191;"	d
-IS_VENDOR_8703B_MP_CHIP	include/HalVerDef.h	197;"	d
-IS_VENDOR_8703B_TEST_CHIP	include/HalVerDef.h	196;"	d
-IS_VENDOR_8723B_MP_CHIP	include/HalVerDef.h	194;"	d
-IS_VENDOR_8723B_TEST_CHIP	include/HalVerDef.h	193;"	d
-IS_VENDOR_8812A_C_CUT	include/HalVerDef.h	186;"	d
-IS_VENDOR_8812A_MP_CHIP	include/HalVerDef.h	185;"	d
-IS_VENDOR_8812A_TEST_CHIP	include/HalVerDef.h	184;"	d
-IS_VENDOR_8814A_MP_CHIP	include/HalVerDef.h	199;"	d
-IS_VENDOR_8814A_TEST_CHIP	include/HalVerDef.h	198;"	d
-IS_VENDOR_8821A_MP_CHIP	include/HalVerDef.h	189;"	d
-IS_VENDOR_8821A_TEST_CHIP	include/HalVerDef.h	188;"	d
-IS_VHT1SS_RATE	include/ieee80211.h	855;"	d
-IS_VHT2SS_RATE	include/ieee80211.h	856;"	d
-IS_VHT3SS_RATE	include/ieee80211.h	857;"	d
-IS_VHT4SS_RATE	include/ieee80211.h	858;"	d
-IS_VHT_RATE	include/ieee80211.h	846;"	d
-IS_VHT_RATE_SECTION	include/ieee80211.h	979;"	d
-IW_AUTH_KEY_MGMT_WAPI_PSK	include/wifi.h	1381;"	d
-IW_AUTH_WAPI_ENABLED	include/wifi.h	1384;"	d
-IW_AUTH_WAPI_VERSION_1	include/wifi.h	1378;"	d
-IW_ENCODE_ALG_SM4	include/wifi.h	1387;"	d
-IW_ESSID_MAX_SIZE	include/ieee80211.h	1374;"	d
-IW_QUAL_LEVEL_INVALID	include/ieee80211.h	313;"	d
-IW_QUAL_LEVEL_UPDATED	include/ieee80211.h	316;"	d
-IW_QUAL_NOISE_INVALID	include/ieee80211.h	314;"	d
-IW_QUAL_NOISE_UPDATED	include/ieee80211.h	317;"	d
-IW_QUAL_QUAL_INVALID	include/ieee80211.h	312;"	d
-IW_QUAL_QUAL_UPDATED	include/ieee80211.h	315;"	d
-I_CUT_VERSION	include/HalVerDef.h	/^	I_CUT_VERSION		=	8,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-ImrContent	include/drv_types.h	/^	u32	ImrContent;$/;"	m	struct:_ADAPTER
-IncomingTrafficMode	include/rtw_btcoex.h	/^	u1Byte					IncomingTrafficMode;$/;"	m	struct:_HCI_LINK_INFO
-Index24G_BW40_Base	include/hal_data.h	/^	u8	Index24G_BW40_Base[MAX_RF_PATH][CENTER_CH_2G_NUM];$/;"	m	struct:hal_com_data
-Index24G_CCK_Base	include/hal_data.h	/^	u8	Index24G_CCK_Base[MAX_RF_PATH][CENTER_CH_2G_NUM];$/;"	m	struct:hal_com_data
-Index2G	include/rtw_mlme_ext.h	/^	u8 Index2G;$/;"	m	struct:_RT_CHANNEL_PLAN_MAP
-Index5G	include/rtw_mlme_ext.h	/^	u8 Index5G;$/;"	m	struct:_RT_CHANNEL_PLAN_MAP
-Index5G_BW40_Base	include/hal_data.h	/^	u8	Index5G_BW40_Base[MAX_RF_PATH][CENTER_CH_5G_ALL_NUM];$/;"	m	struct:hal_com_data
-Index5G_BW80_Base	include/hal_data.h	/^	u8	Index5G_BW80_Base[MAX_RF_PATH][CENTER_CH_5G_80M_NUM];$/;"	m	struct:hal_com_data
-IndexBW40_Base	include/hal_pg.h	/^	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];$/;"	m	struct:_TxPowerInfo24G
-IndexBW40_Base	include/hal_pg.h	/^	u8 IndexBW40_Base[MAX_RF_PATH][MAX_CHNL_GROUP_5G];$/;"	m	struct:_TxPowerInfo5G
-IndexCCK_Base	include/hal_pg.h	/^	u8 IndexCCK_Base[MAX_RF_PATH][MAX_CHNL_GROUP_24G];$/;"	m	struct:_TxPowerInfo24G
-InfrastructureMode	include/wlan_bssdef.h	/^	NDIS_802_11_NETWORK_INFRASTRUCTURE  InfrastructureMode;$/;"	m	struct:_WLAN_BSSID_EX
-InitInterrupt8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void InitInterrupt8723DSdio(PADAPTER padapter)$/;"	f
-InitLed	hal/led/hal_sdio_led.c	/^InitLed($/;"	f
-InitSwLeds	include/hal_intf.h	/^	void	(*InitSwLeds)(_adapter *padapter);$/;"	m	struct:hal_ops
-InitSysInterrupt8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void InitSysInterrupt8723DSdio(PADAPTER padapter)$/;"	f
-Init_ODM_ComInfo	hal/hal_dm.c	/^void Init_ODM_ComInfo(_adapter *adapter)$/;"	f
-Init_ODM_ComInfo_8723d	hal/rtl8723d/rtl8723d_dm.c	/^static void Init_ODM_ComInfo_8723d(PADAPTER	Adapter)$/;"	f	file:
-IntArray	include/drv_types_pci.h	/^		u32			IntArray[2];$/;"	m	union:_RT_ISR_CONTENT::__anon67
-IntArray	include/hal_data.h	/^	u32			IntArray[3];\/* HISR0,HISR1,HSISR *\/$/;"	m	struct:hal_com_data
-IntArray	include/hal_data.h	/^	u32			IntArray[4];$/;"	m	struct:hal_com_data
-IntReg2Byte	include/drv_types_pci.h	/^		u16			IntReg2Byte;$/;"	m	union:_RT_ISR_CONTENT::__anon67
-IntReg4Byte	include/drv_types_pci.h	/^		u32			IntReg4Byte;$/;"	m	union:_RT_ISR_CONTENT::__anon67
-InterfaceIndex	hal/phydm/phydm.h	/^	u1Byte			InterfaceIndex;		\/*Add for 92D  dual MAC: 0--Mac0 1--Mac1*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-InterfaceNumber	include/drv_types.h	/^	u8	InterfaceNumber;$/;"	m	struct:dvobj_priv
-InterfaceSel	include/hal_data.h	/^	u8	InterfaceSel; \/* board type kept in eFuse *\/$/;"	m	struct:hal_com_data
-InternalPA5G	hal/phydm/phydm_powertracking_ap.h	/^    	u1Byte  	InternalPA5G[2];	\/\/pathA \/ pathB$/;"	m	struct:ODM_RF_Calibration_Structure
-InternalPA5G	hal/phydm/phydm_powertracking_ce.h	/^    	u1Byte  	InternalPA5G[2];	\/\/pathA \/ pathB$/;"	m	struct:ODM_RF_Calibration_Structure
-InternalPA5G	hal/phydm/phydm_powertracking_win.h	/^    	u1Byte  	InternalPA5G[2];	\/\/pathA \/ pathB$/;"	m	struct:ODM_RF_Calibration_Structure
-InterruptLine	include/drv_types_pci.h	/^			u8	InterruptLine;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-InterruptPin	include/drv_types_pci.h	/^			u8	InterruptPin;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-IntrMask	include/hal_data.h	/^	u32			IntrMask[3];$/;"	m	struct:hal_com_data
-IntrMask	include/hal_data.h	/^	u32			IntrMask[4];$/;"	m	struct:hal_com_data
-IntrMaskDefault	include/hal_data.h	/^	u32			IntrMaskDefault[4];$/;"	m	struct:hal_com_data
-IntrMaskReg	include/hal_data.h	/^	u32			IntrMaskReg[2];$/;"	m	struct:hal_com_data
-IntrMaskToSet	include/hal_data.h	/^	u32			IntrMaskToSet[2];$/;"	m	struct:hal_com_data
-IsBbSwingOffsetPositiveA	hal/phydm/phydm.h	/^	BOOLEAN			IsBbSwingOffsetPositiveA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IsBbSwingOffsetPositiveB	hal/phydm/phydm.h	/^	BOOLEAN			IsBbSwingOffsetPositiveB;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IsCommentString	hal/hal_com.c	/^IsCommentString($/;"	f
-IsEnableHWCCK	include/ieee80211.h	229;"	d
-IsEnableHWOFDM	include/ieee80211.h	230;"	d
-IsFrameTypeCtrl	include/wifi.h	/^__inline static int IsFrameTypeCtrl(unsigned char *pframe)$/;"	f
-IsHexDigit	os_dep/osdep_service.c	/^inline BOOLEAN IsHexDigit(char chTmp)$/;"	f
-IsLegacyOnly	include/ieee80211.h	224;"	d
-IsLegal5GChannel	core/rtw_mlme_ext.c	/^BOOLEAN IsLegal5GChannel($/;"	f
-IsSupported24G	include/ieee80211.h	226;"	d
-IsSupported5G	include/ieee80211.h	227;"	d
-IsSupportedHT	include/ieee80211.h	238;"	d
-IsSupportedRxCCK	include/ieee80211.h	232;"	d
-IsSupportedRxHT	include/ieee80211.h	234;"	d
-IsSupportedRxOFDM	include/ieee80211.h	233;"	d
-IsSupportedTxCCK	include/ieee80211.h	236;"	d
-IsSupportedTxOFDM	include/ieee80211.h	237;"	d
-IsSupportedVHT	include/ieee80211.h	240;"	d
-IsTxagcOffsetPositiveA	hal/phydm/phydm.h	/^	BOOLEAN			IsTxagcOffsetPositiveA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IsTxagcOffsetPositiveB	hal/phydm/phydm.h	/^	BOOLEAN			IsTxagcOffsetPositiveB;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-IsUsed	include/rtw_wapi.h	/^	u8			IsUsed;$/;"	m	struct:_RT_WAPI_CAM_ENTRY
-IsrContent	include/drv_types.h	/^	u32	IsrContent;$/;"	m	struct:_ADAPTER
-JAPAN	include/rtw_eeprom.h	46;"	d
-JAPAN	include/rtw_rf.h	85;"	d
-JOINBSSRPT_PARM_88E	include/rtl8188e_cmd.h	/^typedef struct JOINBSSRPT_PARM_88E {$/;"	s
-JOINBSSRPT_PARM_88E	include/rtl8188e_cmd.h	/^} JOINBSSRPT_PARM_88E, *PJOINBSSRPT_PARM_88E;$/;"	t	typeref:struct:JOINBSSRPT_PARM_88E
-JOINBSSRPT_PARM_92E	include/rtl8192e_cmd.h	/^typedef struct JOINBSSRPT_PARM_92E {$/;"	s
-JOINBSSRPT_PARM_92E	include/rtl8192e_cmd.h	/^} JOINBSSRPT_PARM_92E, *PJOINBSSRPT_PARM_92E;$/;"	t	typeref:struct:JOINBSSRPT_PARM_92E
-J_CUT_VERSION	include/HalVerDef.h	/^	J_CUT_VERSION		=	9,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-JoinerNeedSendAuth	include/rtw_btcoex.h	/^	BOOLEAN				JoinerNeedSendAuth;$/;"	m	struct:_BT_MGNT
-K	include/rtw_security.h	/^static const unsigned long K[64] = {$/;"	v
-K0	include/rtw_security.h	/^	u32  K0, K1;         \/* Key *\/$/;"	m	struct:mic_data
-K1	include/rtw_security.h	/^	u32  K0, K1;         \/* Key *\/$/;"	m	struct:mic_data
-KEEP_ALIVE_TRYCNT	core/rtw_ap.c	444;"	d	file:
-KERNELOUTPUT	Makefile	/^KERNELOUTPUT := ${PRODUCTDIR}\/tmp$/;"	m
-KERNELOUTPUT	Makefile	/^KERNELOUTPUT := \/home\/pink\/sample\/ODM\/IP8136W-VINT\/tmp\/kernel$/;"	m
-KERNEL_SOCKET_OK	include/rtw_btcoex.h	73;"	d
-KERNEL_VERSION	include/osdep_service_bsd.h	118;"	d
-KEY	hal/phydm/rtl8723d/halphyrf_8723d.c	50;"	d	file:
-KEY_ARG	include/drv_types.h	711;"	d
-KEY_FMT	include/drv_types.h	710;"	d
-KFREE_BB_GAIN_2G_TXB_OFFSET	include/hal_pg.h	30;"	d
-KFREE_BB_GAIN_2G_TX_OFFSET	include/hal_pg.h	29;"	d
-KFREE_BB_GAIN_5G_TX_OFFSET	include/hal_pg.h	31;"	d
-KFREE_FLAG_ON	include/hal_data.h	228;"	d
-KFREE_FLAG_THERMAL_K_ON	include/hal_data.h	229;"	d
-KFREE_GAIN_DATA_LENGTH_8814A	include/hal_pg.h	182;"	d
-KFREE_THERMAL_OFFSET	include/hal_pg.h	32;"	d
-KFREE_VERSION	hal/phydm/phydm_kfree.h	25;"	d
-KSRC	Makefile	/^       KSRC := ..\/..\/..\/..\/..\/..\/kernel\/linux-3.4.y$/;"	m
-KSRC	Makefile	/^KSRC := $(KERNEL_BUILD_PATH)$/;"	m
-KSRC	Makefile	/^KSRC := $(LINUX_KERNEL_PATH)$/;"	m
-KSRC	Makefile	/^KSRC := $(shell pwd)\/..\/..\/..\/Android\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/Custom\/Novatek\/TCL\/linux-3.8_header$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/alex\/test_openwrt\/tmp\/linux-2.6.30.9$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/Action-semi\/705a_android_L\/android\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/Allwinner\/a20\/kitkat-a20_v4.4\/lichee\/linux-3.4$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/Rockchip\/Rk3066sdk\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/Telechips\/SDK_2304_20110613\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/Telechips\/v12.06_r1-tcc-android-4.0.4\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/Telechips\/v13.03_r1-tcc-android-4.2.2_ds_patched\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/Telechips\/v13.05_r1-tcc-android-4.2.2_tcc893x-evm_build\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/WonderMedia\/wm8880-android4.4\/kernel4.4\/$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/android-x86_JB\/out\/target\/product\/x86\/obj\/kernel\/$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/nvidia\/tegra-16r3-partner-android-4.1_20120723\/out\/target\/product\/cardhu\/obj\/KERNEL$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/android_sdk\/nvidia\/tegra-17r9-partner-android-4.2-dalmore_20130131\/out\/target\/product\/dalmore\/obj\/KERNEL$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/cnsd4\/project\/actions\/linux-2.6.27.28$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/lspei\/work\/3399\/3399-7.1\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/home\/winuser\/work\/Plat_sLD2T_V3010\/usr\/src\/linux-2.6.32.2$/;"	m
-KSRC	Makefile	/^KSRC := \/lib\/modules\/$(KVER)\/build$/;"	m
-KSRC	Makefile	/^KSRC := \/media\/DATA-1\/android-4.0\/panda_kernel\/omap$/;"	m
-KSRC	Makefile	/^KSRC := \/media\/DATA-1\/urbetter\/ics-urbetter\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/media\/DATA-2\/android-x86\/ics-x86_20120130\/out\/target\/product\/generic_x86\/obj\/kernel$/;"	m
-KSRC	Makefile	/^KSRC := \/usr\/src\/kernels\/linux-$(KVER)$/;"	m
-KSRC	Makefile	/^KSRC := \/usr\/src\/release_fae_version\/kernel25_A7_281x$/;"	m
-KSRC	Makefile	/^KSRC :=\/home\/android_sdk\/Allwinner\/a23\/android-kk44\/lichee\/linux-3.4$/;"	m
-KSRC	Makefile	/^KSRC :=\/home\/android_sdk\/Allwinner\/a31\/kitkat-a3x_v4.5\/lichee\/linux-3.3$/;"	m
-KSRC	Makefile	/^KSRC :=\/home\/android_sdk\/Allwinner\/a33\/android-L\/lichee\/linux-3.4$/;"	m
-KSRC	Makefile	/^KSRC :=\/home\/android_sdk\/Allwinner\/a64\/android-51\/lichee\/linux-3.10\/$/;"	m
-KSRC	Makefile	/^KSRC :=\/mnt\/newdisk\/isaac\/nvidia\/android_ara_5.1\/out\/target\/product\/jetson\/obj\/kernel\/$/;"	m
-KSRC	Makefile	/^KSRC ?= \/home\/share\/CusEnv\/FreeScale\/FS_kernel_env$/;"	m
-KSRC	Makefile	/^KSRC ?= \/lib\/modules\/2.6.31-770-g0e46b52\/source$/;"	m
-KSRC	Makefile	/^KSRC ?= \/mnt\/sdb5\/Ingenic\/Umido\/kernel$/;"	m
-KSRC	Makefile	/^KSRC ?= \/usr\/src\/DMP_Kernel\/jupiter\/linux-2.6.12$/;"	m
-KSRC	Makefile	/^KSRC ?= \/usr\/src\/linux-2.6.34.1$/;"	m
-KSRC	Makefile	/^KSRC ?=\/usr\/local\/Jupiter\/linux-2.6.12$/;"	m
-KSRC	Makefile	/^KSRC:= $(CFGDIR)\/..\/..\/kernel\/linux-$(KERNEL_VER)$/;"	m
-KSRC	Makefile	/^KSRC:= ..\/code\/linux-2.6.31.6-2020\/$/;"	m
-KSRC	Makefile	/^KSRC:= \/home\/mstar\/mstar_linux\/2.6.28.9\/$/;"	m
-KSRC	Makefile	/^KSRC:= \/home\/vivotek\/lsp\/DM365\/kernel_platform\/kernel\/linux-2.6.18$/;"	m
-KSRC	Makefile	/^KSRC:= \/opt\/Vivotek\/lsp\/mozart3v2\/kernel_platform\/kernel\/mozart_kernel-1.17$/;"	m
-KSRC	Makefile	/^KSRC:= \/root\/work\/kernel_realtek$/;"	m
-KSRC	Makefile	/^KSRC:= \/usr\/src\/Mstar_kernel\/2.6.28.9\/$/;"	m
-KSRC	Makefile	/^KSRC:= \/usr\/src\/Mstar_kernel\/3.1.10\/$/;"	m
-KSRC	Makefile	/^KSRC:=$/;"	m
-KSRC	Makefile	/^KSRC=\/home\/android_sdk\/Allwinner\/a10\/android-jb42\/lichee-jb42\/linux-3.0$/;"	m
-KSRC	Makefile	/^KSRC?= \/proj\/mtk00802\/BD_Compare\/BDP\/Dev\/BDP_V301\/BDP_Linux\/linux-2.6.27$/;"	m
-KVER	Makefile	/^KVER  := $(KERNEL_VER)$/;"	m
-KVER	Makefile	/^KVER  := $(shell uname -r)$/;"	m
-KVER	Makefile	/^KVER  := 2.6.18$/;"	m
-KVER	Makefile	/^KVER  := 2.6.24.7_$(ARCH)$/;"	m
-KVER	Makefile	/^KVER  := 2.6.27$/;"	m
-KVER	Makefile	/^KVER  := 2.6.31$/;"	m
-KVER	Makefile	/^KVER  := 2.6.34.1$/;"	m
-KVER	Makefile	/^KVER  := 3.0.8$/;"	m
-KVER	Makefile	/^KVER  := 3.10.24$/;"	m
-KVER	Makefile	/^KVER  := 4.1.10$/;"	m
-KVER	Makefile	/^KVER := 2.6.32.2$/;"	m
-KVER	Makefile	/^KVER := 3.8.0$/;"	m
-KVER	Makefile	/^KVER:= 2.6.27$/;"	m
-KVER	Makefile	/^KVER:= 2.6.28.10$/;"	m
-KVER	Makefile	/^KVER:= 2.6.28.9$/;"	m
-KVER	Makefile	/^KVER:= 2.6.31.6$/;"	m
-KVER	Makefile	/^KVER:= 3.1.10$/;"	m
-KVER	Makefile	/^KVER:= 3.4.0$/;"	m
-KVER	Makefile	/^KVER:=$/;"	m
-K_CUT_VERSION	include/HalVerDef.h	/^	K_CUT_VERSION		=	10,$/;"	e	enum:tag_HAL_Cut_Version_Definition
-Kcount	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	Kcount;$/;"	m	struct:ODM_RF_Calibration_Structure
-Kcount	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	Kcount;$/;"	m	struct:ODM_RF_Calibration_Structure
-Kcount	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	Kcount;$/;"	m	struct:ODM_RF_Calibration_Structure
-KeyIdx	include/rtw_wapi.h	/^	u8      KeyIdx;$/;"	m	struct:_WLAN_HEADER_WAPI_EXTENSION
-KeyIndex	include/wlan_bssdef.h	/^	ULONG                   KeyIndex;$/;"	m	struct:_NDIS_802_11_REMOVE_KEY
-KeyIndex	include/wlan_bssdef.h	/^	ULONG           KeyIndex;$/;"	m	struct:_NDIS_802_11_KEY
-KeyIndex	include/wlan_bssdef.h	/^	ULONG     KeyIndex;      \/* 0 is the per-client key, 1-N are the global keys *\/$/;"	m	struct:_NDIS_802_11_WEP
-KeyLength	include/wlan_bssdef.h	/^	ULONG           KeyLength;          \/* length of key in bytes *\/$/;"	m	struct:_NDIS_802_11_KEY
-KeyLength	include/wlan_bssdef.h	/^	ULONG     KeyLength;     \/* length of key in bytes *\/$/;"	m	struct:_NDIS_802_11_WEP
-KeyMaterial	include/rtw_security.h	/^	u8 KeyMaterial[16];\/* variable length depending on above field. *\/$/;"	m	struct:security_priv
-KeyMaterial	include/wlan_bssdef.h	/^	UCHAR           KeyMaterial[32];     \/* variable length depending on above field *\/$/;"	m	struct:_NDIS_802_11_KEY
-KeyMaterial	include/wlan_bssdef.h	/^	UCHAR     KeyMaterial[16];\/* variable length depending on above field *\/$/;"	m	struct:_NDIS_802_11_WEP
-KeyRSC	include/wlan_bssdef.h	/^	NDIS_802_11_KEY_RSC KeyRSC;$/;"	m	struct:_NDIS_802_11_KEY
-Keytype	include/rtw_security.h	/^union Keytype {$/;"	u
-KfreeOffset	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte			KfreeOffset[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-KfreeOffset	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte			KfreeOffset[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-KfreeOffset	hal/phydm/phydm_powertracking_win.h	/^	s1Byte			KfreeOffset[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-L	include/rtw_security.h	/^	u32  L, R;           \/* Current state *\/$/;"	m	struct:mic_data
-L1	core/rtw_wapi_sms4.c	56;"	d	file:
-L2	core/rtw_wapi_sms4.c	57;"	d	file:
-L2H_lb	hal/phydm/phydm_adaptivity.h	/^	s1Byte			L2H_lb;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-L2_FRAMETAG	include/rtw_xmit.h	458;"	d
-LARGE_FA_TIMEOUT	hal/phydm/phydm_dig.h	274;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8188E	include/hal_com_reg.h	1796;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8188F	include/hal_com_reg.h	1802;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8192C	include/hal_com_reg.h	1799;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8703B	include/hal_com_reg.h	1800;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8723B	include/hal_com_reg.h	1798;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8723D	include/hal_com_reg.h	1803;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8812	include/hal_com_reg.h	1797;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_8814A	include/rtl8814a_spec.h	641;"	d
-LAST_ENTRY_OF_TX_PKT_BUFFER_DUAL_MAC	include/hal_com_reg.h	1801;"	d
-LDOE25_EN	include/hal_com_reg.h	1228;"	d
-LDOE25_SHIFT	hal/rtl8723d/rtl8723d_hal_init.c	1461;"	d	file:
-LDOE25_SHIFT	include/rtl8814a_hal.h	/^	LDOE25_SHIFT					= 28 ,$/;"	e	enum:__anon58
-LDPC_HT_CAP_TX	include/rtw_ht.h	85;"	d
-LDPC_HT_ENABLE_RX	include/rtw_ht.h	82;"	d
-LDPC_HT_ENABLE_TX	include/rtw_ht.h	83;"	d
-LDPC_HT_TEST_TX_ENABLE	include/rtw_ht.h	84;"	d
-LDPC_VHT_CAP_TX	include/rtw_vht.h	26;"	d
-LDPC_VHT_ENABLE_RX	include/rtw_vht.h	23;"	d
-LDPC_VHT_ENABLE_TX	include/rtw_vht.h	24;"	d
-LDPC_VHT_TEST_TX_ENABLE	include/rtw_vht.h	25;"	d
-LDPC_parameter_generator	core/rtw_mp.c	/^UINT LDPC_parameter_generator($/;"	f
-LDV12_EN	include/hal_com_reg.h	1217;"	d
-LDV12_SDBY	include/hal_com_reg.h	1218;"	d
-LD_RQPN	include/hal_com_reg.h	1412;"	d
-LED_BLINK_ALWAYS_ON	include/hal_com_led.h	/^	LED_BLINK_ALWAYS_ON = 16,$/;"	e	enum:_LED_STATE
-LED_BLINK_AUTH_ERROR	include/hal_com_led.h	/^	LED_BLINK_AUTH_ERROR = 18,  \/* Customized for Belkin AC950 *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_Azurewave_10Mbps	include/hal_com_led.h	/^	LED_BLINK_Azurewave_10Mbps = 20,$/;"	e	enum:_LED_STATE
-LED_BLINK_Azurewave_20Mbps	include/hal_com_led.h	/^	LED_BLINK_Azurewave_20Mbps = 21,$/;"	e	enum:_LED_STATE
-LED_BLINK_Azurewave_40Mbps	include/hal_com_led.h	/^	LED_BLINK_Azurewave_40Mbps = 22,$/;"	e	enum:_LED_STATE
-LED_BLINK_Azurewave_5Mbps	include/hal_com_led.h	/^	LED_BLINK_Azurewave_5Mbps = 19,$/;"	e	enum:_LED_STATE
-LED_BLINK_Azurewave_80Mbps	include/hal_com_led.h	/^	LED_BLINK_Azurewave_80Mbps = 23,$/;"	e	enum:_LED_STATE
-LED_BLINK_Azurewave_MAXMbps	include/hal_com_led.h	/^	LED_BLINK_Azurewave_MAXMbps = 24,$/;"	e	enum:_LED_STATE
-LED_BLINK_CAMEO	include/hal_com_led.h	/^	LED_BLINK_CAMEO = 14,$/;"	e	enum:_LED_STATE
-LED_BLINK_ERROR_INTERVAL_BELKIN	include/hal_com_led.h	77;"	d
-LED_BLINK_FASTER_INTERVAL_ALPHA	include/hal_com_led.h	60;"	d
-LED_BLINK_FAST_INTERVAL_BITLAND	include/hal_com_led.h	45;"	d
-LED_BLINK_LINK_IDEL	include/hal_com_led.h	/^	LED_BLINK_LINK_IDEL = 25,$/;"	e	enum:_LED_STATE
-LED_BLINK_LINK_IDEL_INTERVAL	include/hal_com_led.h	89;"	d
-LED_BLINK_LINK_INTERVAL_ALPHA	include/hal_com_led.h	58;"	d
-LED_BLINK_LINK_INTERVAL_NETGEAR	include/hal_com_led.h	68;"	d
-LED_BLINK_LINK_INTERVAL_OFF_BELKIN	include/hal_com_led.h	76;"	d
-LED_BLINK_LINK_INTERVAL_ON_BELKIN	include/hal_com_led.h	75;"	d
-LED_BLINK_LINK_IN_PROCESS	include/hal_com_led.h	/^	LED_BLINK_LINK_IN_PROCESS = 17,  \/* Customized for Belkin AC950 *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_LINK_SLOWLY_INTERVAL_NETGEAR	include/hal_com_led.h	69;"	d
-LED_BLINK_LONG_INTERVAL	include/hal_com_led.h	33;"	d
-LED_BLINK_NORMAL	include/hal_com_led.h	/^	LED_BLINK_NORMAL = 3,$/;"	e	enum:_LED_STATE
-LED_BLINK_NORMAL_INTERVAL	include/hal_com_led.h	31;"	d
-LED_BLINK_NORMAL_INTERVAL_NETTRONIX	include/hal_com_led.h	39;"	d
-LED_BLINK_NORMAL_INTERVAL_PORNET	include/hal_com_led.h	44;"	d
-LED_BLINK_NO_LINK	include/hal_com_led.h	/^	LED_BLINK_NO_LINK = 7, \/* LED is blinking during no link state. *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_NO_LINK_INTERVAL	include/hal_com_led.h	88;"	d
-LED_BLINK_NO_LINK_INTERVAL_ALPHA	include/hal_com_led.h	56;"	d
-LED_BLINK_NO_LINK_INTERVAL_ALPHA_500MS	include/hal_com_led.h	57;"	d
-LED_BLINK_POWER_ON	include/hal_com_led.h	/^	LED_BLINK_POWER_ON = 5,$/;"	e	enum:_LED_STATE
-LED_BLINK_RUNTOP	include/hal_com_led.h	/^	LED_BLINK_RUNTOP = 13,	\/* Customized for RunTop *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_SCAN	include/hal_com_led.h	/^	LED_BLINK_SCAN = 6,	\/* LED is blinking during scanning period, the # of times to blink is depend on time for scanning. *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_SCAN_INTERVAL_ALPHA	include/hal_com_led.h	59;"	d
-LED_BLINK_SCAN_OFF_INTERVAL	include/hal_com_led.h	92;"	d
-LED_BLINK_SCAN_ON_INTERVAL	include/hal_com_led.h	91;"	d
-LED_BLINK_SLOWLY	include/hal_com_led.h	/^	LED_BLINK_SLOWLY = 4,$/;"	e	enum:_LED_STATE
-LED_BLINK_SLOWLY_INTERVAL	include/hal_com_led.h	32;"	d
-LED_BLINK_SLOWLY_INTERVAL_NETTRONIX	include/hal_com_led.h	40;"	d
-LED_BLINK_SLOWLY_INTERVAL_PORNET	include/hal_com_led.h	43;"	d
-LED_BLINK_StartToBlink	include/hal_com_led.h	/^	LED_BLINK_StartToBlink = 8, \/* Customzied for Sercomm Printer Server case *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_TXRX	include/hal_com_led.h	/^	LED_BLINK_TXRX = 9,$/;"	e	enum:_LED_STATE
-LED_BLINK_WPS	include/hal_com_led.h	/^	LED_BLINK_WPS = 10,	\/* LED is blinkg during WPS communication *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_WPS_LINKED	include/hal_com_led.h	/^	LED_BLINK_WPS_LINKED = 26,$/;"	e	enum:_LED_STATE
-LED_BLINK_WPS_STOP	include/hal_com_led.h	/^	LED_BLINK_WPS_STOP = 11,	\/* for ALPHA *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_WPS_STOP_OVERLAP	include/hal_com_led.h	/^	LED_BLINK_WPS_STOP_OVERLAP = 12,	\/* for BELKIN *\/$/;"	e	enum:_LED_STATE
-LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA	include/hal_com_led.h	61;"	d
-LED_BLINK_XAVI	include/hal_com_led.h	/^	LED_BLINK_XAVI = 15,$/;"	e	enum:_LED_STATE
-LED_CM11_BLINK_INTERVAL	include/hal_com_led.h	64;"	d
-LED_CM11_LINK_ON_INTERVEL	include/hal_com_led.h	65;"	d
-LED_CM12_BLINK_INTERVAL_10Mbps	include/hal_com_led.h	81;"	d
-LED_CM12_BLINK_INTERVAL_20Mbps	include/hal_com_led.h	82;"	d
-LED_CM12_BLINK_INTERVAL_40Mbps	include/hal_com_led.h	83;"	d
-LED_CM12_BLINK_INTERVAL_5Mbps	include/hal_com_led.h	80;"	d
-LED_CM12_BLINK_INTERVAL_80Mbps	include/hal_com_led.h	84;"	d
-LED_CM12_BLINK_INTERVAL_MAXMbps	include/hal_com_led.h	85;"	d
-LED_CM2_BLINK_OFF_INTERVAL	include/hal_com_led.h	49;"	d
-LED_CM2_BLINK_ON_INTERVAL	include/hal_com_led.h	48;"	d
-LED_CM8_BLINK_OFF_INTERVAL	include/hal_com_led.h	50;"	d
-LED_CTL_CONNECTION_NO_TRANSFER	include/hal_com_led.h	/^	LED_CTL_CONNECTION_NO_TRANSFER = 14,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_LINK	include/hal_com_led.h	/^	LED_CTL_LINK = 2,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_MODE	include/hal_com_led.h	/^} LED_CTL_MODE;$/;"	t	typeref:enum:_LED_CTL_MODE
-LED_CTL_NO_LINK	include/hal_com_led.h	/^	LED_CTL_NO_LINK = 3,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_POWER_OFF	include/hal_com_led.h	/^	LED_CTL_POWER_OFF = 7,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_POWER_ON	include/hal_com_led.h	/^	LED_CTL_POWER_ON = 1,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_RX	include/hal_com_led.h	/^	LED_CTL_RX = 5,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_SITE_SURVEY	include/hal_com_led.h	/^	LED_CTL_SITE_SURVEY = 6,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_START_TO_LINK	include/hal_com_led.h	/^	LED_CTL_START_TO_LINK = 8,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_START_WPS	include/hal_com_led.h	/^	LED_CTL_START_WPS = 9,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_START_WPS_BOTTON	include/hal_com_led.h	/^	LED_CTL_START_WPS_BOTTON = 11, \/* added for runtop *\/$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_STOP_WPS	include/hal_com_led.h	/^	LED_CTL_STOP_WPS = 10,$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_STOP_WPS_FAIL	include/hal_com_led.h	/^	LED_CTL_STOP_WPS_FAIL = 12, \/* added for ALPHA	 *\/$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_STOP_WPS_FAIL_OVERLAP	include/hal_com_led.h	/^	LED_CTL_STOP_WPS_FAIL_OVERLAP = 13, \/* added for BELKIN *\/$/;"	e	enum:_LED_CTL_MODE
-LED_CTL_TX	include/hal_com_led.h	/^	LED_CTL_TX = 4,$/;"	e	enum:_LED_CTL_MODE
-LED_DATA	include/hal_com_led.h	/^typedef struct _LED_PCIE	LED_DATA, *PLED_DATA;$/;"	t	typeref:struct:_LED_PCIE
-LED_DATA	include/hal_com_led.h	/^typedef struct _LED_SDIO	LED_DATA, *PLED_DATA;$/;"	t	typeref:struct:_LED_SDIO
-LED_DATA	include/hal_com_led.h	/^typedef struct _LED_USB	LED_DATA, *PLED_DATA;$/;"	t	typeref:struct:_LED_USB
-LED_INITIAL_INTERVAL	include/hal_com_led.h	34;"	d
-LED_PCIE	include/hal_com_led.h	/^} LED_PCIE, *PLED_PCIE;$/;"	t	typeref:struct:_LED_PCIE
-LED_PIN	include/hal_com_led.h	/^} LED_PIN;$/;"	t	typeref:enum:_LED_PIN
-LED_PIN_GPIO0	include/hal_com_led.h	/^	LED_PIN_GPIO0,$/;"	e	enum:_LED_PIN
-LED_PIN_LED0	include/hal_com_led.h	/^	LED_PIN_LED0,$/;"	e	enum:_LED_PIN
-LED_PIN_LED1	include/hal_com_led.h	/^	LED_PIN_LED1,$/;"	e	enum:_LED_PIN
-LED_PIN_LED2	include/hal_com_led.h	/^	LED_PIN_LED2$/;"	e	enum:_LED_PIN
-LED_RunTop_BLINK_INTERVAL	include/hal_com_led.h	53;"	d
-LED_SDIO	include/hal_com_led.h	/^} LED_SDIO, *PLED_SDIO;$/;"	t	typeref:struct:_LED_SDIO
-LED_STATE	include/hal_com_led.h	/^} LED_STATE;$/;"	t	typeref:enum:_LED_STATE
-LED_STRATEGY	include/hal_com_led.h	/^typedef enum _LED_STRATEGY_PCIE	LED_STRATEGY, *PLED_STRATEGY;$/;"	t	typeref:enum:_LED_STRATEGY_PCIE
-LED_STRATEGY	include/hal_com_led.h	/^typedef enum _LED_STRATEGY_SDIO	LED_STRATEGY, *PLED_STRATEGY;$/;"	t	typeref:enum:_LED_STRATEGY_SDIO
-LED_STRATEGY	include/hal_com_led.h	/^typedef enum _LED_STRATEGY_USB	LED_STRATEGY, *PLED_STRATEGY;$/;"	t	typeref:enum:_LED_STRATEGY_USB
-LED_STRATEGY_PCIE	include/hal_com_led.h	/^} LED_STRATEGY_PCIE, *PLED_STRATEGY_PCIE;$/;"	t	typeref:enum:_LED_STRATEGY_PCIE
-LED_STRATEGY_SDIO	include/hal_com_led.h	/^} LED_STRATEGY_SDIO, *PLED_STRATEGY_SDIO;$/;"	t	typeref:enum:_LED_STRATEGY_SDIO
-LED_STRATEGY_USB	include/hal_com_led.h	/^} LED_STRATEGY_USB, *PLED_STRATEGY_USB;$/;"	t	typeref:enum:_LED_STRATEGY_USB
-LED_UNKNOWN	include/hal_com_led.h	/^	LED_UNKNOWN = 0,$/;"	e	enum:_LED_STATE
-LED_USB	include/hal_com_led.h	/^} LED_USB, *PLED_USB;$/;"	t	typeref:struct:_LED_USB
-LED_WPS_BLINK_LINKED_ON_INTERVAL_DLINK	include/hal_com_led.h	96;"	d
-LED_WPS_BLINK_OFF_INTERVAL_DLINK	include/hal_com_led.h	95;"	d
-LED_WPS_BLINK_OFF_INTERVAL_NETGEAR	include/hal_com_led.h	71;"	d
-LED_WPS_BLINK_ON_INTERVAL_DLINK	include/hal_com_led.h	94;"	d
-LED_WPS_BLINK_ON_INTERVAL_NETGEAR	include/hal_com_led.h	72;"	d
-LENGTH	include/rtw_mp.h	/^	USHORT			LENGTH;$/;"	m	struct:_RT_PMAC_TX_INFO
-LE_BITS_CLEARED_TO_1BYTE	include/basic_types.h	273;"	d
-LE_BITS_CLEARED_TO_2BYTE	include/basic_types.h	270;"	d
-LE_BITS_CLEARED_TO_4BYTE	include/basic_types.h	267;"	d
-LE_BITS_TO_1BYTE	include/basic_types.h	247;"	d
-LE_BITS_TO_2BYTE	include/basic_types.h	244;"	d
-LE_BITS_TO_4BYTE	include/basic_types.h	241;"	d
-LE_P1BYTE_TO_HOST_1BYTE	include/basic_types.h	228;"	d
-LE_P2BYTE_TO_HOST_2BYTE	include/basic_types.h	227;"	d
-LE_P4BYTE_TO_HOST_4BYTE	include/basic_types.h	226;"	d
-LINKED_TO	include/rtw_mlme_ext.h	36;"	d
-LINUX_VERSION_CODE	include/osdep_service_bsd.h	120;"	d
-LIST_CONTAINOR	include/osdep_service_bsd.h	129;"	d
-LIST_CONTAINOR	include/osdep_service_bsd.h	613;"	d
-LIST_CONTAINOR	include/osdep_service_ce.h	85;"	d
-LIST_CONTAINOR	include/osdep_service_linux.h	221;"	d
-LIST_CONTAINOR	include/osdep_service_xp.h	82;"	d
-LLC_HEADER_SIZE	include/ethernet.h	26;"	d
-LNAType_2G	include/hal_data.h	/^	u8	LNAType_2G;$/;"	m	struct:hal_com_data
-LNAType_5G	include/hal_data.h	/^	u8	LNAType_5G;$/;"	m	struct:hal_com_data
-LOADER_CLK_EN	include/hal_com_reg.h	1201;"	d
-LOAD_BB_MP_PARA_FILE	include/hal_com_phycfg.h	332;"	d
-LOAD_BB_PARA_FILE	include/hal_com_phycfg.h	330;"	d
-LOAD_BB_PG_PARA_FILE	include/hal_com_phycfg.h	331;"	d
-LOAD_FW_HEADER_FROM_DRIVER	include/autoconf.h	152;"	d
-LOAD_FW_HEADER_FROM_DRIVER	include/hal_ic_cfg.h	149;"	d
-LOAD_MAC_PARA_FILE	include/hal_com_phycfg.h	329;"	d
-LOAD_PG_TXPWR_WARN_COND	hal/hal_com_phycfg.c	568;"	d	file:
-LOAD_PG_TXPWR_WARN_COND	hal/hal_com_phycfg.c	570;"	d	file:
-LOAD_RF_PARA_FILE	include/hal_com_phycfg.h	333;"	d
-LOAD_RF_TXPWR_LMT_PARA_FILE	include/hal_com_phycfg.h	335;"	d
-LOAD_RF_TXPWR_TRACK_PARA_FILE	include/hal_com_phycfg.h	334;"	d
-LOK_IDAC	hal/phydm/phydm_iqk.h	/^	u4Byte		LOK_IDAC[2][4];		\/*channel \/ path*\/$/;"	m	struct:_IQK_INFORMATION
-LOK_Result	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte  LOK_Result;$/;"	m	struct:ODM_RF_Calibration_Structure
-LOK_Result	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte  LOK_Result;$/;"	m	struct:ODM_RF_Calibration_Structure
-LOK_Result	hal/phydm/phydm_powertracking_win.h	/^	u4Byte  LOK_Result;$/;"	m	struct:ODM_RF_Calibration_Structure
-LOK_delay	hal/phydm/phydm_iqk.h	25;"	d
-LOK_fail	hal/phydm/phydm_iqk.h	/^	BOOLEAN		LOK_fail[NUM];$/;"	m	struct:_IQK_INFORMATION
-LOOPBACKDATA	include/drv_types.h	/^} LOOPBACKDATA, *PLOOPBACKDATA;$/;"	t	typeref:struct:loopbackdata
-LOOP_LIMIT	include/Hal8188EPhyCfg.h	25;"	d
-LOOP_LIMIT	include/Hal8188FPhyCfg.h	24;"	d
-LOOP_LIMIT	include/Hal8192EPhyCfg.h	25;"	d
-LOOP_LIMIT	include/Hal8703BPhyCfg.h	24;"	d
-LOOP_LIMIT	include/Hal8723BPhyCfg.h	24;"	d
-LOOP_LIMIT	include/Hal8723DPhyCfg.h	24;"	d
-LOOP_LIMIT	include/Hal8812PhyCfg.h	25;"	d
-LOOP_LIMIT	include/Hal8814PhyCfg.h	25;"	d
-LOWER	include/rtw_mp.h	475;"	d
-LOW_QUEUE_IDX	include/hal_com_reg.h	1629;"	d
-LPLDO_HSM	include/hal_com_reg.h	1219;"	d
-LPLDO_LSM_DIS	include/hal_com_reg.h	1220;"	d
-LPQ_PGNUM_8814A	include/rtl8814a_hal.h	136;"	d
-LPQ_PGNUM_8814A	include/rtl8814a_hal.h	144;"	d
-LPQ_PUBLIC_DIS	include/hal_com_reg.h	1411;"	d
-LPSPG_RSVD_PAGE_SET_MACID	hal/hal_com.c	7169;"	d	file:
-LPSPG_RSVD_PAGE_SET_MBSSCAMID	hal/hal_com.c	7170;"	d	file:
-LPSPG_RSVD_PAGE_SET_MU_RAID_GID	hal/hal_com.c	7172;"	d	file:
-LPSPG_RSVD_PAGE_SET_PMC_NUM	hal/hal_com.c	7171;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID1	hal/hal_com.c	7174;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID2	hal/hal_com.c	7175;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID3	hal/hal_com.c	7176;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID4	hal/hal_com.c	7177;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID5	hal/hal_com.c	7178;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID6	hal/hal_com.c	7179;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID7	hal/hal_com.c	7180;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_ID8	hal/hal_com.c	7181;"	d	file:
-LPSPG_RSVD_PAGE_SET_SEC_CAM_NUM	hal/hal_com.c	7173;"	d	file:
-LPS_CHANGE_DTIM_CID	include/rtw_cmd.h	/^	LPS_CHANGE_DTIM_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-LPS_CTRL_CONNECT	include/rtw_cmd.h	/^	LPS_CTRL_CONNECT = 2,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_DISCONNECT	include/rtw_cmd.h	/^	LPS_CTRL_DISCONNECT = 3,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_ENTER	include/rtw_cmd.h	/^	LPS_CTRL_ENTER = 9,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_JOINBSS	include/rtw_cmd.h	/^	LPS_CTRL_JOINBSS = 1,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_LEAVE	include/rtw_cmd.h	/^	LPS_CTRL_LEAVE = 5,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_LEAVE_CFG80211_PWRMGMT	include/rtw_cmd.h	/^	LPS_CTRL_LEAVE_CFG80211_PWRMGMT = 10,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_RX_TRAFFIC_LEAVE	include/rtw_cmd.h	/^	LPS_CTRL_RX_TRAFFIC_LEAVE = 8,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_SCAN	include/rtw_cmd.h	/^	LPS_CTRL_SCAN = 0,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_SPECIAL_PACKET	include/rtw_cmd.h	/^	LPS_CTRL_SPECIAL_PACKET = 4,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_TRAFFIC_BUSY	include/rtw_cmd.h	/^	LPS_CTRL_TRAFFIC_BUSY = 6,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_TX_TRAFFIC_LEAVE	include/rtw_cmd.h	/^	LPS_CTRL_TX_TRAFFIC_LEAVE = 7,$/;"	e	enum:LPS_CTRL_TYPE
-LPS_CTRL_TYPE	include/rtw_cmd.h	/^enum LPS_CTRL_TYPE {$/;"	g
-LPS_CTRL_WK_CID	include/rtw_cmd.h	/^	LPS_CTRL_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-LPS_DELAY_TIME	include/rtw_pwrctrl.h	184;"	d
-LPS_Enter	core/rtw_pwrctrl.c	/^void LPS_Enter(PADAPTER padapter, const char *msg)$/;"	f
-LPS_LEAVE_TIMEOUT_MS	core/rtw_pwrctrl.c	1070;"	d	file:
-LPS_Leave	core/rtw_pwrctrl.c	/^void LPS_Leave(PADAPTER padapter, const char *msg)$/;"	f
-LPS_Leave_check	core/rtw_pwrctrl.c	/^void LPS_Leave_check($/;"	f
-LPS_PG_INFO_RSVD_LEN	hal/hal_com.c	7187;"	d	file:
-LPS_POFF_DYNAMIC_FILE_LEN	include/rtl8723d_lps_poff.h	26;"	d
-LPS_POFF_STATIC_FILE_LEN	include/rtl8723d_lps_poff.h	25;"	d
-LPS_RF_ON_check	core/rtw_pwrctrl.c	/^s32 LPS_RF_ON_check(PADAPTER padapter, u32 delay_ms)$/;"	f
-LPS_RPWM_WAIT_MS	include/autoconf.h	208;"	d
-LSG	include/rtl8188e_xmit.h	45;"	d
-LSG	include/rtl8192e_xmit.h	150;"	d
-LSG	include/rtl8812a_xmit.h	43;"	d
-LSIG	include/rtw_mp.h	/^	u8			LSIG[3];$/;"	m	struct:_RT_PMAC_TX_INFO
-LSIGEN	include/hal_com_reg.h	1562;"	d
-L_SIG_generator	core/rtw_mp.c	/^void L_SIG_generator($/;"	f
-LargeFAHit	hal/phydm/phydm_dig.h	/^	u1Byte		LargeFAHit;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-LargeFA_Timeout	hal/phydm/phydm_dig.h	/^	u1Byte		LargeFA_Timeout;		\/*if (LargeFAHit), monitor "LargeFA_Timeout" sec, if timeout, LargeFAHit=0*\/$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-LastDTPLvl	hal/phydm/phydm.h	/^	u1Byte			LastDTPLvl;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-LastError	include/drv_types.h	/^	ERROR_CODE		LastError; \/* <20130613, Kordan> Only the functions associated with MP records the error code by now. *\/$/;"	m	struct:_ADAPTER
-LastHMEBoxNum	include/hal_data.h	/^	u8	LastHMEBoxNum;	\/* H2C - for host message to fw *\/$/;"	m	struct:hal_com_data
-LastNumQryPhyStatusAll	hal/phydm/phydm.h	/^	u4Byte			LastNumQryPhyStatusAll; $/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-LastRATR	hal/phydm/phydm_rainfo.h	/^	u4Byte				LastRATR;			\/\/ RATR Register Content$/;"	m	struct:_ODM_RATE_ADAPTIVE
-LastUSBHub	hal/phydm/phydm.h	/^	u1Byte			LastUSBHub;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-LatencyTimer	include/drv_types_pci.h	/^	u8	LatencyTimer;$/;"	m	struct:_PCI_COMMON_CONFIG
-LdpcThres	hal/phydm/phydm_rainfo.h	/^	u1Byte				LdpcThres;			\/\/ if RSSI > LdpcThres => switch from LPDC to BCC$/;"	m	struct:_ODM_RATE_ADAPTIVE
-LeaveAllPowerSaveMode	core/rtw_pwrctrl.c	/^void LeaveAllPowerSaveMode(IN PADAPTER Adapter)$/;"	f
-LeaveAllPowerSaveModeDirect	core/rtw_pwrctrl.c	/^void LeaveAllPowerSaveModeDirect(PADAPTER Adapter)$/;"	f
-LedBlink_param	include/rtw_cmd.h	/^struct LedBlink_param {$/;"	s
-LedControlHandler	include/hal_com_led.h	/^	void (*LedControlHandler)(_adapter *padapter, LED_CTL_MODE LedAction);$/;"	m	struct:led_priv
-LedControlSDIO	hal/led/hal_sdio_led.c	/^LedControlSDIO($/;"	f
-LedPin	include/hal_com_led.h	/^	LED_PIN				LedPin;	\/* Identify how to implement this SW led. *\/$/;"	m	struct:_LED_SDIO
-LedPin	include/hal_com_led.h	/^	LED_PIN				LedPin;	\/* Identify how to implement this SW led. *\/$/;"	m	struct:_LED_USB
-LedPin	include/hal_com_led.h	/^	LED_PIN			LedPin;	\/* Identify how to implement this SW led. *\/$/;"	m	struct:_LED_PCIE
-LedStrategy	include/hal_com_led.h	/^	LED_STRATEGY		LedStrategy;$/;"	m	struct:led_priv
-LeftAntenna	include/Hal8188EPhyReg.h	1068;"	d
-LeftAntenna	include/Hal8188FPhyReg.h	1075;"	d
-LeftAntenna	include/Hal8192EPhyReg.h	1082;"	d
-LeftAntenna	include/Hal8703BPhyReg.h	1104;"	d
-LeftAntenna	include/Hal8723BPhyReg.h	1102;"	d
-LeftAntenna	include/Hal8723DPhyReg.h	1105;"	d
-LeftAntenna	include/rtw_mp_phy_regdef.h	1039;"	d
-Len	include/rtw_mlme_ext.h	/^	unsigned char	Len;$/;"	m	struct:_RT_CHANNEL_PLAN
-Len2G	hal/phydm/rtchnlplan.h	/^	u1Byte	Len2G;$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Len5G	hal/phydm/rtchnlplan.h	/^	u1Byte	Len5G;$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-Length	hal/phydm/phydm_adc_sampling.h	/^	u4Byte		Length;$/;"	m	struct:_RT_ADCSMP_STRING
-Length	include/drv_types_ce.h	/^	u16      Length;$/;"	m	struct:_OCTET_STRING
-Length	include/drv_types_xp.h	/^	u16      Length;$/;"	m	struct:_OCTET_STRING
-Length	include/rtw_btcoex.h	/^	u8		Length; \/* total cmd length = extension event length+1(extension event code length) *\/$/;"	m	struct:_PACKET_IRP_HCIEVENT_DATA
-Length	include/rtw_ioctl_set.h	/^	u32	Length;$/;"	m	struct:_NDIS_802_11_PMKID
-Length	include/wlan_bssdef.h	/^	UCHAR  Length;$/;"	m	struct:_NDIS_802_11_VARIABLE_IEs
-Length	include/wlan_bssdef.h	/^	ULONG                   Length;        \/* Length of this structure *\/$/;"	m	struct:_NDIS_802_11_REMOVE_KEY
-Length	include/wlan_bssdef.h	/^	ULONG                   Length;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-Length	include/wlan_bssdef.h	/^	ULONG           Length;             \/* Length of structure *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION
-Length	include/wlan_bssdef.h	/^	ULONG           Length;             \/* Length of structure *\/$/;"	m	struct:_NDIS_802_11_CONFIGURATION_FH
-Length	include/wlan_bssdef.h	/^	ULONG           Length;             \/* Length of this structure *\/$/;"	m	struct:_NDIS_802_11_KEY
-Length	include/wlan_bssdef.h	/^	ULONG     Length;        \/* Length of this structure *\/$/;"	m	struct:_NDIS_802_11_WEP
-Length	include/wlan_bssdef.h	/^	ULONG  Length;$/;"	m	struct:_NDIS_802_11_CAPABILITY
-Length	include/wlan_bssdef.h	/^	ULONG  Length;$/;"	m	struct:_WLAN_BSSID_EX
-Length	include/wlan_bssdef.h	/^	ULONG Length;            \/* Length of structure *\/$/;"	m	struct:_NDIS_802_11_AUTHENTICATION_REQUEST
-Length	include/wlan_bssdef.h	/^	ULONG Length;$/;"	m	struct:_NDIS_802_11_TEST
-LinkDetectInfo	include/rtw_mlme.h	/^	RT_LINK_DETECT_T	LinkDetectInfo;$/;"	m	struct:mlme_priv
-Linkdown_workitem	include/rtw_mlme.h	/^	_workitem	Linkdown_workitem;$/;"	m	struct:mlme_priv
-Linkdown_workitem_callback	os_dep/linux/mlme_linux.c	/^void Linkdown_workitem_callback(struct work_struct *work)$/;"	f
-LinkedInterval	hal/phydm/phydm.h	/^	u1Byte			LinkedInterval;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Linkup_workitem	include/rtw_mlme.h	/^	_workitem	Linkup_workitem;$/;"	m	struct:mlme_priv
-Linkup_workitem_callback	os_dep/linux/mlme_linux.c	/^void Linkup_workitem_callback(struct work_struct *work)$/;"	f
-ListenInterval	include/wlan_bssdef.h	/^	USHORT ListenInterval;$/;"	m	struct:_NDIS_802_11_AI_REQFI
-Lo16	core/rtw_security.c	479;"	d	file:
-Lo8	core/rtw_security.c	477;"	d	file:
-LocAOACReport	include/hal_com_h2c.h	/^	u8 LocAOACReport;$/;"	m	struct:_RSVDPAGE_LOC
-LocApOffloadBCN	include/hal_com_h2c.h	/^	u8 LocApOffloadBCN;$/;"	m	struct:_RSVDPAGE_LOC
-LocArpRsp	include/hal_com_h2c.h	/^	u8 LocArpRsp;$/;"	m	struct:_RSVDPAGE_LOC
-LocBTQosNull	include/hal_com_h2c.h	/^	u8 LocBTQosNull;$/;"	m	struct:_RSVDPAGE_LOC
-LocGTKEXTMEM	include/hal_com_h2c.h	/^	u8 LocGTKEXTMEM;$/;"	m	struct:_RSVDPAGE_LOC
-LocGTKInfo	include/hal_com_h2c.h	/^	u8 LocGTKInfo;$/;"	m	struct:_RSVDPAGE_LOC
-LocGTKRsp	include/hal_com_h2c.h	/^	u8 LocGTKRsp;$/;"	m	struct:_RSVDPAGE_LOC
-LocInviteRsp	include/hal_com_h2c.h	/^	u8 LocInviteRsp;$/;"	m	struct:_RSVDPAGE_LOC
-LocNbrAdv	include/hal_com_h2c.h	/^	u8 LocNbrAdv;$/;"	m	struct:_RSVDPAGE_LOC
-LocNegoRsp	include/hal_com_h2c.h	/^	u8 LocNegoRsp;$/;"	m	struct:_RSVDPAGE_LOC
-LocNetList	include/hal_com_h2c.h	/^	u8 LocNetList;$/;"	m	struct:_RSVDPAGE_LOC
-LocNullData	include/hal_com_h2c.h	/^	u8 LocNullData;$/;"	m	struct:_RSVDPAGE_LOC
-LocP2PBeacon	include/hal_com_h2c.h	/^	u8 LocP2PBeacon;$/;"	m	struct:_RSVDPAGE_LOC
-LocP2PProbeRsp	include/hal_com_h2c.h	/^	u8 LocP2PProbeRsp;$/;"	m	struct:_RSVDPAGE_LOC
-LocPDRsp	include/hal_com_h2c.h	/^	u8 LocPDRsp;$/;"	m	struct:_RSVDPAGE_LOC
-LocPNOInfo	include/hal_com_h2c.h	/^	u8 LocPNOInfo;$/;"	m	struct:_RSVDPAGE_LOC
-LocProbePacket	include/hal_com_h2c.h	/^	u8 LocProbePacket;$/;"	m	struct:_RSVDPAGE_LOC
-LocProbeReq	include/hal_com_h2c.h	/^	u8 LocProbeReq;$/;"	m	struct:_RSVDPAGE_LOC
-LocProbeRsp	include/hal_com_h2c.h	/^	u8 LocProbeRsp;$/;"	m	struct:_RSVDPAGE_LOC
-LocPsPoll	include/hal_com_h2c.h	/^	u8 LocPsPoll;$/;"	m	struct:_RSVDPAGE_LOC
-LocQosNull	include/hal_com_h2c.h	/^	u8 LocQosNull;$/;"	m	struct:_RSVDPAGE_LOC
-LocRemoteCtrlInfo	include/hal_com_h2c.h	/^	u8 LocRemoteCtrlInfo;$/;"	m	struct:_RSVDPAGE_LOC
-LocSSIDInfo	include/hal_com_h2c.h	/^	u8 LocSSIDInfo;$/;"	m	struct:_RSVDPAGE_LOC
-LocScanInfo	include/hal_com_h2c.h	/^	u8 LocScanInfo;$/;"	m	struct:_RSVDPAGE_LOC
-LogRetryCnt	hal/phydm/phydm_beamforming.h	/^	u2Byte				LogRetryCnt:3;			\/*Modified by Jeffery @2014-10-29*\/$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-LogRetryCnt	include/rtw_beamforming.h	/^	u16				LogRetryCnt:3;			\/*Modified by Jeffery @2014-10-29*\/$/;"	m	struct:beamforming_entry
-LogSeq	hal/phydm/phydm_beamforming.h	/^	u1Byte				LogSeq;					\/*Modified by Jeffery @2014-10-29*\/$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-LogSeq	include/rtw_beamforming.h	/^	u8				LogSeq;					\/*Modified by Jeffery @2014-10-29*\/$/;"	m	struct:beamforming_entry
-LogStatusFailCnt	hal/phydm/phydm_beamforming.h	/^	u2Byte	LogStatusFailCnt:5;	\/\/ 0~21$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-LogStatusFailCnt	include/rtw_beamforming.h	/^	u16 LogStatusFailCnt:5;	\/* 0~21 *\/$/;"	m	struct:beamformee_entry
-LogStatusFailCnt	include/rtw_beamforming.h	/^	u8	LogStatusFailCnt;$/;"	m	struct:beamforming_entry
-LogSuccess	hal/phydm/phydm_beamforming.h	/^	u2Byte				LogSuccess:2;			\/*Modified by Jeffery @2014-10-29*\/$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-LogSuccess	include/rtw_beamforming.h	/^	u16				LogSuccess:2;			\/*Modified by Jeffery @2014-10-29*\/$/;"	m	struct:beamforming_entry
-LogicalLen_BT	include/rtw_efuse.h	/^	const u16  LogicalLen_BT;$/;"	m	struct:_EFUSE_HAL
-LogicalLen_WiFi	include/rtw_efuse.h	/^	const u16  LogicalLen_WiFi;$/;"	m	struct:_EFUSE_HAL
-LowPowerTransitionCount	include/rtw_mlme.h	/^	u32 LowPowerTransitionCount;$/;"	m	struct:_RT_LINK_DETECT_T
-LowRSSIThresh	hal/phydm/phydm_rainfo.h	/^	u1Byte				LowRSSIThresh;		\/\/ if RSSI <= LowRSSIThresh	=> RATRState is DM_RATR_STA_LOW$/;"	m	struct:_ODM_RATE_ADAPTIVE
-LowestRate	hal/phydm/phydm_rainfo.h	/^	u1Byte LowestRate;$/;"	m	struct:_ODM_RA_Info_
-LpsIdleCount	include/rtw_pwrctrl.h	/^	u8	LpsIdleCount;$/;"	m	struct:pwrctrl_priv
-M	include/rtw_security.h	/^	u32  M;              \/* Message accumulator (single word) *\/$/;"	m	struct:mic_data
-MACADDRLEN	include/rtw_br_ext.h	25;"	d
-MACADDR_FILE_FAILED	include/hal_data.h	225;"	d
-MACADDR_FILE_LOADED	include/hal_data.h	226;"	d
-MACADDR_FILE_UNUSED	include/hal_data.h	224;"	d
-MACID_NUM_8188F	include/rtl8188f_spec.h	295;"	d
-MACID_NUM_8192E	include/rtl8192e_spec.h	321;"	d
-MACID_NUM_8703B	include/rtl8703b_spec.h	472;"	d
-MACID_NUM_8723B	include/rtl8723b_spec.h	288;"	d
-MACID_NUM_8723D	include/rtl8723d_spec.h	449;"	d
-MACID_NUM_8812A	include/rtl8812a_spec.h	264;"	d
-MACID_NUM_8814A	include/rtl8814a_spec.h	643;"	d
-MACID_NUM_8821A	include/rtl8821a_spec.h	100;"	d
-MACID_NUM_88E	include/rtl8188e_spec.h	150;"	d
-MACID_NUM_SW_LIMIT	include/drv_conf.h	278;"	d
-MACINI_RDY	include/hal_com_reg.h	1242;"	d
-MACRXEN	include/hal_com_reg.h	1322;"	d
-MACSLP	include/hal_com_reg.h	1200;"	d
-MACTXEN	include/hal_com_reg.h	1321;"	d
-MAC_ADDRESS_LEN	core/rtw_ieee80211.c	1299;"	d	file:
-MAC_ADDR_LEN	include/hal_com_reg.h	24;"	d
-MAC_ARG	include/ieee80211.h	1470;"	d
-MAC_ARG	include/osdep_service.h	521;"	d
-MAC_CRC32	hal/phydm/phydm.h	/^	u1Byte		MAC_CRC32;	$/;"	m	struct:_ODM_Phy_Status_Info_Append_
-MAC_FILE_FW_NIC	include/hal_com_phycfg.h	309;"	d
-MAC_FILE_FW_WW_IMG	include/hal_com_phycfg.h	310;"	d
-MAC_FMT	include/ieee80211.h	1469;"	d
-MAC_FMT	include/osdep_service.h	518;"	d
-MAC_HIDDEN_MAX_BW_NUM	include/rtw_efuse.h	226;"	d
-MAC_HIDDEN_PROTOCOL_NUM	include/rtw_efuse.h	230;"	d
-MAC_HIDDEN_RPT_2_LEN	hal/hal_com_c2h.h	98;"	d
-MAC_HIDDEN_RPT_LEN	hal/hal_com_c2h.h	94;"	d
-MAC_SARG	include/ieee80211.h	1472;"	d
-MAC_SFMT	include/ieee80211.h	1471;"	d
-MAGIC_CODE	core/rtw_br_ext.c	72;"	d	file:
-MAGIC_CODE_LEN	core/rtw_br_ext.c	73;"	d	file:
-MAIN_ANT	hal/phydm/phydm_antdiv.h	43;"	d
-MAKE_DRIVER_VERSION	include/drv_types_ce.h	35;"	d
-MAKE_DRIVER_VERSION	include/drv_types_xp.h	33;"	d
-MAPSEG_ARRAY_ENT	include/osdep_service.h	664;"	d
-MAPSEG_PTR_ENT	include/osdep_service.h	667;"	d
-MAP_ENT	include/osdep_service.h	670;"	d
-MARVELL_OUI	core/rtw_wlan_util.c	/^unsigned char MARVELL_OUI[] = {0x00, 0x50, 0x43};$/;"	v
-MASK12BITS	hal/btc/HalBtcOutSrc.h	995;"	d
-MASKBYTE0	hal/btc/HalBtcOutSrc.h	988;"	d
-MASKBYTE1	hal/btc/HalBtcOutSrc.h	989;"	d
-MASKBYTE2	hal/btc/HalBtcOutSrc.h	990;"	d
-MASKBYTE3	hal/btc/HalBtcOutSrc.h	991;"	d
-MASKCCK	hal/btc/HalBtcOutSrc.h	998;"	d
-MASKDWORD	hal/btc/HalBtcOutSrc.h	994;"	d
-MASKH4BITS	hal/btc/HalBtcOutSrc.h	996;"	d
-MASKHWORD	hal/btc/HalBtcOutSrc.h	992;"	d
-MASKLWORD	hal/btc/HalBtcOutSrc.h	993;"	d
-MASKOFDM_D	hal/btc/HalBtcOutSrc.h	997;"	d
-MASK_HSISR_CLEAR	include/rtl8188f_spec.h	175;"	d
-MASK_HSISR_CLEAR	include/rtl8703b_spec.h	386;"	d
-MASK_HSISR_CLEAR	include/rtl8723b_spec.h	156;"	d
-MASK_HSISR_CLEAR	include/rtl8723d_spec.h	422;"	d
-MASK_NETTYPE	include/hal_com_reg.h	1329;"	d
-MASK_SDIO_HISR_CLEAR	include/hal_com_reg.h	1707;"	d
-MASK_SPI_HISR_CLEAR	include/gspi_ops.h	98;"	d
-MAXIMUM_ETHERNET_PACKET_SIZE	include/ethernet.h	29;"	d
-MAXTTL	include/ip.h	69;"	d
-MAX_2_4G_BANDWIDTH_NUM	include/hal_data.h	92;"	d
-MAX_5G_BANDWIDTH_NUM	include/hal_data.h	94;"	d
-MAX_8192E_H2CCMD	include/rtl8192e_cmd.h	/^	MAX_8192E_H2CCMD$/;"	e	enum:_RTL8192E_H2C_CMD
-MAX_8812_H2CCMD	include/rtl8812a_cmd.h	/^	MAX_8812_H2CCMD$/;"	e	enum:_RTL8812_H2C_CMD
-MAX_ACTIVE_REG_PATH	include/drv_types_ce.h	28;"	d
-MAX_ADAPTER	include/drv_types.h	/^	MAX_ADAPTER = 0xFF,$/;"	e	enum:_ADAPTER_TYPE
-MAX_AGGR_NUM	include/Hal8188EPhyCfg.h	32;"	d
-MAX_AGGR_NUM	include/Hal8188EPhyCfg.h	34;"	d
-MAX_AGGR_NUM	include/Hal8188FPhyCfg.h	31;"	d
-MAX_AGGR_NUM	include/Hal8188FPhyCfg.h	33;"	d
-MAX_AGGR_NUM	include/Hal8192EPhyCfg.h	32;"	d
-MAX_AGGR_NUM	include/Hal8192EPhyCfg.h	34;"	d
-MAX_AGGR_NUM	include/Hal8703BPhyCfg.h	31;"	d
-MAX_AGGR_NUM	include/Hal8703BPhyCfg.h	33;"	d
-MAX_AGGR_NUM	include/Hal8723BPhyCfg.h	31;"	d
-MAX_AGGR_NUM	include/Hal8723BPhyCfg.h	33;"	d
-MAX_AGGR_NUM	include/Hal8723DPhyCfg.h	31;"	d
-MAX_AGGR_NUM	include/Hal8723DPhyCfg.h	33;"	d
-MAX_AGGR_NUM	include/Hal8812PhyCfg.h	33;"	d
-MAX_AGGR_NUM	include/Hal8812PhyCfg.h	35;"	d
-MAX_AGGR_NUM	include/Hal8814PhyCfg.h	33;"	d
-MAX_AGGR_NUM	include/Hal8814PhyCfg.h	35;"	d
-MAX_AGG_PKT_NUM	include/rtw_xmit.h	792;"	d
-MAX_AGG_PKT_NUM	include/rtw_xmit.h	794;"	d
-MAX_ALLOWED_TDLS_STA_NUM	include/sta_info.h	42;"	d
-MAX_AMPDU_FACTOR_16K	include/wifi.h	/^	MAX_AMPDU_FACTOR_16K	= 1,$/;"	e	enum:_HT_CAP_AMPDU_FACTOR
-MAX_AMPDU_FACTOR_32K	include/wifi.h	/^	MAX_AMPDU_FACTOR_32K	= 2,$/;"	e	enum:_HT_CAP_AMPDU_FACTOR
-MAX_AMPDU_FACTOR_64K	include/wifi.h	/^	MAX_AMPDU_FACTOR_64K	= 3,$/;"	e	enum:_HT_CAP_AMPDU_FACTOR
-MAX_AMPDU_FACTOR_8K	include/wifi.h	/^	MAX_AMPDU_FACTOR_8K		= 0,$/;"	e	enum:_HT_CAP_AMPDU_FACTOR
-MAX_ANT	hal/phydm/phydm_antdiv.h	45;"	d
-MAX_ANTENNA_DETECTION_CNT	hal/phydm/phydm_antdect.h	33;"	d
-MAX_ARGC	hal/phydm/phydm_debug.h	241;"	d
-MAX_ARGV	hal/phydm/phydm_debug.h	242;"	d
-MAX_BASE_NUM_IN_PHY_REG_PG_2_4G	include/hal_data.h	96;"	d
-MAX_BASE_NUM_IN_PHY_REG_PG_5G	include/hal_data.h	97;"	d
-MAX_BEAMFORMEE_ENTRY_NUM	include/rtw_beamforming.h	32;"	d
-MAX_BEAMFORMEE_MU	hal/phydm/phydm_beamforming.h	21;"	d
-MAX_BEAMFORMEE_MU	hal/phydm/phydm_beamforming.h	24;"	d
-MAX_BEAMFORMEE_SU	hal/phydm/phydm_beamforming.h	18;"	d
-MAX_BEAMFORMER_ENTRY_NUM	include/rtw_beamforming.h	33;"	d
-MAX_BEAMFORMER_MU	hal/phydm/phydm_beamforming.h	22;"	d
-MAX_BEAMFORMER_MU	hal/phydm/phydm_beamforming.h	25;"	d
-MAX_BEAMFORMER_SU	hal/phydm/phydm_beamforming.h	19;"	d
-MAX_BIT_RATE_40MHZ_MCS15	os_dep/linux/ioctl_cfg80211.c	6500;"	d	file:
-MAX_BIT_RATE_40MHZ_MCS23	os_dep/linux/ioctl_cfg80211.c	6499;"	d	file:
-MAX_BIT_RATE_40MHZ_MCS7	os_dep/linux/ioctl_cfg80211.c	6501;"	d	file:
-MAX_BSSINFO_LEN	os_dep/linux/ioctl_cfg80211.c	384;"	d	file:
-MAX_BSS_CNT	include/rtw_mlme.h	24;"	d
-MAX_BT_ACL_LINK_NUM	include/rtw_btcoex.h	106;"	d
-MAX_C2HEVT	include/rtw_mlme_ext.h	/^	MAX_C2HEVT$/;"	e	enum:rtw_c2h_event
-MAX_CHANNEL_NUM	include/rtw_rf.h	48;"	d
-MAX_CHANNEL_NUMBER	include/ieee80211.h	1350;"	d
-MAX_CHANNEL_NUM_2G	include/rtw_rf.h	46;"	d
-MAX_CHANNEL_NUM_5G	include/rtw_rf.h	47;"	d
-MAX_CHIP_TYPE	include/hal_intf.h	/^	MAX_CHIP_TYPE$/;"	e	enum:_CHIP_TYPE
-MAX_CHNL_GROUP_24G	include/hal_pg.h	743;"	d
-MAX_CHNL_GROUP_5G	include/hal_pg.h	744;"	d
-MAX_CMDBUF_SZ	include/rtw_xmit.h	88;"	d
-MAX_CMDBUF_SZ	include/rtw_xmit.h	90;"	d
-MAX_CMDBUF_SZ	include/rtw_xmit.h	92;"	d
-MAX_CMDSZ	include/rtw_cmd.h	30;"	d
-MAX_CONTINUAL_IO_ERR	include/rtw_io.h	310;"	d
-MAX_CONTINUAL_IO_ERR	include/rtw_io.h	314;"	d
-MAX_CONTINUAL_IO_ERR	include/rtw_io.h	319;"	d
-MAX_CONTINUAL_IO_ERR	include/rtw_io.h	324;"	d
-MAX_CONTINUAL_NORXPACKET_COUNT	include/rtw_recv.h	69;"	d
-MAX_CUSTOM_LEN	os_dep/linux/ioctl_linux.c	40;"	d	file:
-MAX_DLFW_PAGE_SIZE	include/hal_com.h	204;"	d
-MAX_DOZE_WAITING_TIMES_9x	hal/rtl8723d/rtl8723d_phycfg.c	31;"	d	file:
-MAX_EVTSZ	include/rtw_cmd.h	32;"	d
-MAX_EXT_C2HEVENT	include/rtw_bt_mp.h	/^	MAX_EXT_C2HEVENT$/;"	e	enum:_RTL_EXT_C2H_EVT
-MAX_FEATURE_SET_CONCURRRENT_GROUPS	os_dep/linux/rtw_cfgvendor.c	234;"	d	file:
-MAX_FRAG_THRESHOLD	include/ieee80211.h	459;"	d
-MAX_FW_8188E_SIZE	include/rtl8188e_hal.h	56;"	d
-MAX_H2CCMD	include/rtw_cmd.h	/^	MAX_H2CCMD$/;"	e	enum:rtw_h2c_cmd
-MAX_H2C_BOX_NUMS	hal/hal_halmac.h	35;"	d
-MAX_H2C_BOX_NUMS	hal/rtl8723d/rtl8723d_cmd.c	25;"	d	file:
-MAX_HIDDEN_AP	include/rtw_pwrctrl.h	112;"	d
-MAX_HW_PORT	include/drv_types.h	/^	MAX_HW_PORT,$/;"	e	enum:_hw_port
-MAX_IE_SZ	include/wlan_bssdef.h	24;"	d
-MAX_IPOPTLEN	include/ip.h	84;"	d
-MAX_IQK_INFO_BACKUP_CHNL_NUM	include/hal_data.h	231;"	d
-MAX_IQK_INFO_BACKUP_REG_NUM	include/hal_data.h	232;"	d
-MAX_JOIN_TIMEOUT	include/rtw_mlme.h	27;"	d
-MAX_MCAST_LIST_NUM	include/drv_types_ce.h	30;"	d
-MAX_MCAST_LIST_NUM	include/drv_types_xp.h	28;"	d
-MAX_MCC_NUM	include/rtw_mcc.h	60;"	d
-MAX_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^	MAX_MP_IOCTL_SUBCODE,$/;"	e	enum:RTL871X_MP_IOCTL_SUBCODE
-MAX_MP_XMITBUF_SZ	include/rtw_mp.h	25;"	d
-MAX_MSG_SIZE	core/rtw_security.c	912;"	d	file:
-MAX_MSS_DENSITY_1T	include/hal_com_reg.h	595;"	d
-MAX_MSS_DENSITY_2T	include/hal_com_reg.h	594;"	d
-MAX_NETWORK_ADDR_LEN	include/rtw_br_ext.h	40;"	d
-MAX_NETWORK_ADDR_LEN	include/rtw_br_ext.h	42;"	d
-MAX_NETWORK_COUNT	include/ieee80211.h	1349;"	d
-MAX_NUMBLKS	include/rtw_xmit.h	95;"	d
-MAX_NUM_BEAMFORMEE_MU	include/rtw_beamforming.h	29;"	d
-MAX_NUM_BEAMFORMEE_SU	include/rtw_beamforming.h	27;"	d
-MAX_NUM_BEAMFORMER_MU	include/rtw_beamforming.h	30;"	d
-MAX_NUM_BEAMFORMER_SU	include/rtw_beamforming.h	28;"	d
-MAX_P2P_IE_LEN	include/ieee80211.h	1359;"	d
-MAX_PAGE_SIZE	include/rtl8814a_hal.h	180;"	d
-MAX_PARA_FILE_BUF_LEN	include/hal_com_phycfg.h	327;"	d
-MAX_PATH_NUM_8188E	hal/phydm/phydm_pre_define.h	33;"	d
-MAX_PATH_NUM_8188F	hal/phydm/phydm_pre_define.h	42;"	d
-MAX_PATH_NUM_8192E	hal/phydm/phydm_pre_define.h	34;"	d
-MAX_PATH_NUM_8197F	hal/phydm/phydm_pre_define.h	44;"	d
-MAX_PATH_NUM_8703B	hal/phydm/phydm_pre_define.h	41;"	d
-MAX_PATH_NUM_8723B	hal/phydm/phydm_pre_define.h	35;"	d
-MAX_PATH_NUM_8723D	hal/phydm/phydm_pre_define.h	43;"	d
-MAX_PATH_NUM_8812A	hal/phydm/phydm_pre_define.h	36;"	d
-MAX_PATH_NUM_8814A	hal/phydm/phydm_pre_define.h	38;"	d
-MAX_PATH_NUM_8821A	hal/phydm/phydm_pre_define.h	37;"	d
-MAX_PATH_NUM_8821B	hal/phydm/phydm_pre_define.h	40;"	d
-MAX_PATH_NUM_8821C	hal/phydm/phydm_pre_define.h	45;"	d
-MAX_PATH_NUM_8822B	hal/phydm/phydm_pre_define.h	39;"	d
-MAX_PNO_LIST_COUNT	include/rtw_pwrctrl.h	110;"	d
-MAX_POSTCMD_CNT	hal/rtl8723d/rtl8723d_phycfg.c	29;"	d	file:
-MAX_POWER_INDEX	include/hal_com_phycfg.h	37;"	d
-MAX_PRECMD_CNT	hal/rtl8723d/rtl8723d_phycfg.c	27;"	d	file:
-MAX_PROT_SZ	include/rtw_io.h	27;"	d
-MAX_PROT_SZ	include/rtw_io.h	30;"	d
-MAX_RATES_EX_LENGTH	include/ieee80211.h	1348;"	d
-MAX_RATES_LENGTH	include/ieee80211.h	1347;"	d
-MAX_RATE_SECTION_NUM	include/hal_data.h	93;"	d
-MAX_RECVBUF_SZ	include/rtl8188e_recv.h	31;"	d
-MAX_RECVBUF_SZ	include/rtl8188e_recv.h	38;"	d
-MAX_RECVBUF_SZ	include/rtl8188e_recv.h	40;"	d
-MAX_RECVBUF_SZ	include/rtl8188e_recv.h	44;"	d
-MAX_RECVBUF_SZ	include/rtl8188e_recv.h	53;"	d
-MAX_RECVBUF_SZ	include/rtl8188e_recv.h	59;"	d
-MAX_RECVBUF_SZ	include/rtl8188f_recv.h	26;"	d
-MAX_RECVBUF_SZ	include/rtl8188f_recv.h	29;"	d
-MAX_RECVBUF_SZ	include/rtl8188f_recv.h	32;"	d
-MAX_RECVBUF_SZ	include/rtl8188f_recv.h	34;"	d
-MAX_RECVBUF_SZ	include/rtl8188f_recv.h	36;"	d
-MAX_RECVBUF_SZ	include/rtl8188f_recv.h	46;"	d
-MAX_RECVBUF_SZ	include/rtl8188f_recv.h	48;"	d
-MAX_RECVBUF_SZ	include/rtl8192e_recv.h	27;"	d
-MAX_RECVBUF_SZ	include/rtl8192e_recv.h	30;"	d
-MAX_RECVBUF_SZ	include/rtl8192e_recv.h	33;"	d
-MAX_RECVBUF_SZ	include/rtl8192e_recv.h	35;"	d
-MAX_RECVBUF_SZ	include/rtl8192e_recv.h	37;"	d
-MAX_RECVBUF_SZ	include/rtl8192e_recv.h	51;"	d
-MAX_RECVBUF_SZ	include/rtl8192e_recv.h	57;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	31;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	38;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	40;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	44;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	53;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	59;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	68;"	d
-MAX_RECVBUF_SZ	include/rtl8703b_recv.h	69;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	31;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	38;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	40;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	44;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	53;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	59;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	68;"	d
-MAX_RECVBUF_SZ	include/rtl8723b_recv.h	69;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	31;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	38;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	40;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	44;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	53;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	59;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	68;"	d
-MAX_RECVBUF_SZ	include/rtl8723d_recv.h	69;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	27;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	31;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	33;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	41;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	42;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	45;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	54;"	d
-MAX_RECVBUF_SZ	include/rtl8812a_recv.h	60;"	d
-MAX_RECVBUF_SZ	include/rtl8814a_recv.h	27;"	d
-MAX_RECVBUF_SZ	include/rtl8814a_recv.h	31;"	d
-MAX_RECVBUF_SZ	include/rtl8814a_recv.h	33;"	d
-MAX_RECVBUF_SZ	include/rtl8814a_recv.h	41;"	d
-MAX_RECVBUF_SZ	include/rtl8814a_recv.h	50;"	d
-MAX_RECVBUF_SZ	include/rtl8821c_hal.h	32;"	d
-MAX_RECVBUF_SZ	include/rtl8821c_hal.h	35;"	d
-MAX_RECVBUF_SZ	include/rtl8821c_hal.h	43;"	d
-MAX_RECVBUF_SZ	include/rtl8821c_hal.h	51;"	d
-MAX_RECVBUF_SZ	include/rtl8821c_hal.h	56;"	d
-MAX_RECVBUF_SZ	include/rtl8822b_hal.h	28;"	d
-MAX_RECVBUF_SZ	include/rtl8822bu_hal.h	38;"	d
-MAX_RECVBUF_SZ	include/rtl8822bu_hal.h	41;"	d
-MAX_RECVBUF_SZ	include/rtl8822bu_hal.h	43;"	d
-MAX_REGULATION_NUM	hal/phydm/phydm_adaptivity.h	/^	MAX_REGULATION_NUM = 4$/;"	e	enum:_tag_PhyDM_REGULATION_Type
-MAX_REGULATION_NUM	include/hal_data.h	90;"	d
-MAX_RFDEPENDCMD_CNT	hal/rtl8723d/rtl8723d_phycfg.c	28;"	d	file:
-MAX_RF_PATH	hal/phydm/phydm_powertracking_ap.h	41;"	d
-MAX_RF_PATH	hal/phydm/phydm_powertracking_win.h	34;"	d
-MAX_RF_PATH	include/hal_pg.h	741;"	d
-MAX_RF_PATH_NUMS	include/rtw_mp.h	540;"	d
-MAX_RF_PATH_NUM_IN_POWER_LIMIT_TABLE	include/hal_data.h	91;"	d
-MAX_RSPSZ	include/rtw_cmd.h	31;"	d
-MAX_RTKM_NR_PREALLOC_RECV_SKB	include/rtw_mem.h	32;"	d
-MAX_RTKM_RECVBUF_SZ	include/rtw_mem.h	28;"	d
-MAX_RTKM_RECVBUF_SZ	include/rtw_mem.h	30;"	d
-MAX_RXFRAME_CNT	include/rtw_recv.h	66;"	d
-MAX_RX_DMA_BUFFER_SIZE_8192E	include/rtl8192e_hal.h	127;"	d
-MAX_RX_DMA_BUFFER_SIZE_8812	include/rtl8812a_hal.h	128;"	d
-MAX_RX_DMA_BUFFER_SIZE_8814A	include/rtl8814a_hal.h	157;"	d
-MAX_RX_DMA_BUFFER_SIZE_8821	include/rtl8812a_hal.h	184;"	d
-MAX_RX_DMA_BUFFER_SIZE_88E	include/rtl8188e_hal.h	132;"	d
-MAX_RX_NUMBLKS	include/rtw_recv.h	67;"	d
-MAX_SCAN_LIST_COUNT	include/rtw_pwrctrl.h	111;"	d
-MAX_STALL_TIME	include/Hal8188EPhyCfg.h	26;"	d
-MAX_STALL_TIME	include/Hal8188FPhyCfg.h	25;"	d
-MAX_STALL_TIME	include/Hal8192EPhyCfg.h	26;"	d
-MAX_STALL_TIME	include/Hal8703BPhyCfg.h	25;"	d
-MAX_STALL_TIME	include/Hal8723BPhyCfg.h	25;"	d
-MAX_STALL_TIME	include/Hal8723DPhyCfg.h	25;"	d
-MAX_STALL_TIME	include/Hal8812PhyCfg.h	26;"	d
-MAX_STALL_TIME	include/Hal8814PhyCfg.h	26;"	d
-MAX_STALL_TIME	include/rtl8822b_hal.h	181;"	d
-MAX_SUBFRAME_COUNT	include/rtw_recv.h	91;"	d
-MAX_SWEEP_TAB_ENTRIES	include/ieee80211.h	1341;"	d
-MAX_SWEEP_TAB_ENTRIES_PER_PACKET	include/ieee80211.h	1342;"	d
-MAX_TID	include/rtl8188e_xmit.h	39;"	d
-MAX_TID	include/rtl8188f_xmit.h	24;"	d
-MAX_TID	include/rtl8192e_xmit.h	144;"	d
-MAX_TID	include/rtl8703b_xmit.h	24;"	d
-MAX_TID	include/rtl8723b_xmit.h	24;"	d
-MAX_TID	include/rtl8723d_xmit.h	24;"	d
-MAX_TID	include/rtl8812a_xmit.h	37;"	d
-MAX_TOLERANCE	hal/phydm/halphyrf_ap.h	132;"	d
-MAX_TOLERANCE	hal/phydm/phydm.h	160;"	d
-MAX_TOLERANCE	hal/phydm/rtl8723d/halphyrf_8723d.c	814;"	d	file:
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8188EPhyCfg.h	28;"	d
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8188FPhyCfg.h	27;"	d
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8192EPhyCfg.h	28;"	d
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8703BPhyCfg.h	27;"	d
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8723BPhyCfg.h	27;"	d
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8723DPhyCfg.h	27;"	d
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8812PhyCfg.h	28;"	d
-MAX_TXPWR_IDX_NMODE_92S	include/Hal8814PhyCfg.h	28;"	d
-MAX_TX_AGG_PACKET_NUMBER	include/hal_com_reg.h	1731;"	d
-MAX_TX_AGG_PACKET_NUMBER	include/hal_com_reg.h	1733;"	d
-MAX_TX_AGG_PACKET_NUMBER_8812	include/hal_com_reg.h	1734;"	d
-MAX_TX_COUNT	include/hal_pg.h	747;"	d
-MAX_TX_COUNT_8188E	include/Hal8188EPhyCfg.h	43;"	d
-MAX_TX_PWR_INDEX_N_MODE	include/rtw_mp.h	640;"	d
-MAX_TX_REPORT_BUFFER_SIZE	include/rtl8188e_hal.h	134;"	d
-MAX_USBCTRL_VENDORREQ_TIMES	include/usb_ops_linux.h	36;"	d
-MAX_USBCTRL_VENDORREQ_TIMES	include/usb_ops_linux.h	38;"	d
-MAX_USB_IO_CTL_SIZE	include/usb_ops.h	36;"	d
-MAX_VENDOR_REQ_CMD_SIZE	include/usb_ops.h	35;"	d
-MAX_WAPI_IE_LEN	include/rtw_wapi.h	10;"	d
-MAX_WFD_IE_LEN	include/ieee80211.h	1360;"	d
-MAX_WKFM_NUM	include/rtw_pwrctrl.h	60;"	d
-MAX_WKFM_PATTERN_SIZE	include/rtw_pwrctrl.h	62;"	d
-MAX_WKFM_SIZE	include/rtw_pwrctrl.h	61;"	d
-MAX_WK_CID	include/rtw_cmd.h	/^	MAX_WK_CID$/;"	e	enum:rtw_drvextra_cmd_id
-MAX_WPA_IE_LEN	include/ieee80211.h	1357;"	d
-MAX_WPS_IE_LEN	include/ieee80211.h	1358;"	d
-MAX_XMITBUF_SZ	include/rtw_xmit.h	26;"	d
-MAX_XMITBUF_SZ	include/rtw_xmit.h	29;"	d
-MAX_XMITBUF_SZ	include/rtw_xmit.h	44;"	d
-MAX_XMITBUF_SZ	include/rtw_xmit.h	46;"	d
-MAX_XMITBUF_SZ	include/rtw_xmit.h	48;"	d
-MAX_XMITBUF_SZ	include/rtw_xmit.h	51;"	d
-MAX_XMITBUF_SZ	include/rtw_xmit.h	60;"	d
-MAX_XMIT_EXTBUF_SZ	include/rtw_xmit.h	79;"	d
-MA_rx_TP	hal/phydm/phydm_antdiv.h	/^	u4Byte	MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_BF_DIV_COEX_
-MA_rx_TP_DIV	hal/phydm/phydm_antdiv.h	/^	u4Byte	MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_BF_DIV_COEX_
-MBIDCAM_ADDR_MASK	include/hal_com_reg.h	1588;"	d
-MBIDCAM_ADDR_SHIFT	include/hal_com_reg.h	1589;"	d
-MCAddrCount	include/drv_types.h	/^	u32	MCAddrCount;$/;"	m	struct:_ADAPTER
-MCC_AP_BW20_TARGET_TX_TP	include/rtw_mcc.h	52;"	d
-MCC_AP_BW40_TARGET_TX_TP	include/rtw_mcc.h	53;"	d
-MCC_AP_BW80_TARGET_TX_TP	include/rtw_mcc.h	54;"	d
-MCC_C2H_REPORT_ALL_STATUS	include/rtw_mcc.h	/^	MCC_C2H_REPORT_ALL_STATUS = 2,$/;"	e	enum:mcc_c2h_report
-MCC_C2H_REPORT_DISABLE	include/rtw_mcc.h	/^	MCC_C2H_REPORT_DISABLE = 0,$/;"	e	enum:mcc_c2h_report
-MCC_C2H_REPORT_FAIL_STATUS	include/rtw_mcc.h	/^	MCC_C2H_REPORT_FAIL_STATUS = 1,$/;"	e	enum:mcc_c2h_report
-MCC_CHIDX	include/rtw_mcc.h	/^	MCC_CHIDX = 0,$/;"	e	enum:mcc_channel_scan
-MCC_DISABLE_TX_NULL	include/rtw_mcc.h	/^	MCC_DISABLE_TX_NULL = 1,$/;"	e	enum:mcc_channel_tx_null
-MCC_DURATION	include/rtw_mcc.h	32;"	d
-MCC_EN	include/rtw_mcc.h	63;"	d
-MCC_ENABLE_TX_NULL	include/rtw_mcc.h	/^	MCC_ENABLE_TX_NULL = 0,$/;"	e	enum:mcc_channel_tx_null
-MCC_EXPIRE_TIME	include/rtw_mcc.h	34;"	d
-MCC_NORMAL_PAGE_NUM_HPQ_8821	include/rtl8812a_hal.h	225;"	d
-MCC_NORMAL_PAGE_NUM_LPQ_8821	include/rtl8812a_hal.h	226;"	d
-MCC_NORMAL_PAGE_NUM_NPQ_8821	include/rtl8812a_hal.h	227;"	d
-MCC_ROLE	include/rtw_mcc.h	/^enum MCC_ROLE {$/;"	g
-MCC_ROLE_AP	include/rtw_mcc.h	/^	MCC_ROLE_AP = 1,$/;"	e	enum:MCC_ROLE
-MCC_ROLE_GC	include/rtw_mcc.h	/^	MCC_ROLE_GC = 2,$/;"	e	enum:MCC_ROLE
-MCC_ROLE_GO	include/rtw_mcc.h	/^	MCC_ROLE_GO = 3,$/;"	e	enum:MCC_ROLE
-MCC_ROLE_MAX	include/rtw_mcc.h	/^	MCC_ROLE_MAX,$/;"	e	enum:MCC_ROLE
-MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID	include/rtw_mcc.h	38;"	d
-MCC_ROLE_STA	include/rtw_mcc.h	/^	MCC_ROLE_STA = 0,$/;"	e	enum:MCC_ROLE
-MCC_ROLE_STA_GC_MGMT_QUEUE_MACID	include/rtw_mcc.h	37;"	d
-MCC_RPT_MAX	include/rtw_mcc.h	/^	MCC_RPT_MAX,$/;"	e	enum:mcc_status_rpt
-MCC_RPT_READY	include/rtw_mcc.h	/^	MCC_RPT_READY = 3,$/;"	e	enum:mcc_status_rpt
-MCC_RPT_STOPMCC	include/rtw_mcc.h	/^	MCC_RPT_STOPMCC = 2,$/;"	e	enum:mcc_status_rpt
-MCC_RPT_SUCCESS	include/rtw_mcc.h	/^	MCC_RPT_SUCCESS = 0,$/;"	e	enum:mcc_status_rpt
-MCC_RPT_SWICH_CHANNEL_NOTIFY	include/rtw_mcc.h	/^	MCC_RPT_SWICH_CHANNEL_NOTIFY = 7,$/;"	e	enum:mcc_status_rpt
-MCC_RPT_TXNULL_FAIL	include/rtw_mcc.h	/^	MCC_RPT_TXNULL_FAIL = 1,$/;"	e	enum:mcc_status_rpt
-MCC_SCANCH_RSVD_LOC	include/rtw_mcc.h	/^	MCC_SCANCH_RSVD_LOC = 1,$/;"	e	enum:mcc_channel_scan
-MCC_SETCMD_STATUS_START_CONNECT	include/rtw_mcc.h	43;"	d
-MCC_SETCMD_STATUS_START_SCAN_DONE	include/rtw_mcc.h	44;"	d
-MCC_SETCMD_STATUS_STOP_DISCONNECT	include/rtw_mcc.h	41;"	d
-MCC_SETCMD_STATUS_STOP_SCAN_START	include/rtw_mcc.h	42;"	d
-MCC_SINGLE_TX_CRITERIA	include/rtw_mcc.h	58;"	d
-MCC_STATUS_DOING_MCC	include/rtw_mcc.h	29;"	d
-MCC_STATUS_NEED_MCC	include/rtw_mcc.h	28;"	d
-MCC_STATUS_PROCESS_MCC_START_SETTING	include/rtw_mcc.h	26;"	d
-MCC_STATUS_PROCESS_MCC_STOP_SETTING	include/rtw_mcc.h	27;"	d
-MCC_STA_BW20_TARGET_TX_TP	include/rtw_mcc.h	55;"	d
-MCC_STA_BW40_TARGET_TX_TP	include/rtw_mcc.h	56;"	d
-MCC_STA_BW80_TARGET_TX_TP	include/rtw_mcc.h	57;"	d
-MCC_STOP	include/rtw_mcc.h	62;"	d
-MCC_SWCH_FW_EARLY_TIME	include/rtw_mcc.h	33;"	d
-MCC_TOLERANCE_TIME	include/rtw_mcc.h	35;"	d
-MCList	include/drv_types.h	/^	u8	MCList[MAX_MCAST_LIST_NUM][6];$/;"	m	struct:_ADAPTER
-MCS	include/rtw_mp.h	/^	UCHAR			MCS;$/;"	m	struct:_RT_PMAC_PKT_INFO
-MCS_RATE_1R	include/rtw_mlme_ext.h	80;"	d
-MCS_RATE_2R	include/rtw_mlme_ext.h	81;"	d
-MCS_RATE_2R_13TO15_OFF	include/rtw_mlme_ext.h	84;"	d
-MCS_RATE_3R	include/rtw_mlme_ext.h	82;"	d
-MCS_RATE_4R	include/rtw_mlme_ext.h	83;"	d
-MCS_rate	include/wifi.h	/^			unsigned char	MCS_rate[16];$/;"	m	struct:HT_caps_element::__anon54::__anon55
-MCS_rate	include/wifi.h	/^			unsigned char	MCS_rate[16];$/;"	m	struct:HT_caps_element::__anon56::__anon57
-MCS_rate	include/wifi.h	/^	unsigned char	MCS_rate[16];$/;"	m	struct:HT_info_element
-MCUFWDL_EN	include/hal_com_reg.h	1239;"	d
-MCUFWDL_RDY	include/hal_com_reg.h	1240;"	d
-MEM_ALIGNMENT_OFFSET	include/basic_types.h	160;"	d
-MEM_ALIGNMENT_PADDING	include/basic_types.h	161;"	d
-MESSAGE_BOX_SIZE	hal/hal_halmac.h	36;"	d
-MESSAGE_BOX_SIZE	hal/rtl8723d/rtl8723d_cmd.c	26;"	d	file:
-MFBEN	include/hal_com_reg.h	1561;"	d
-MFIE_TYPE_CF_SET	include/ieee80211.h	1175;"	d
-MFIE_TYPE_CHALLENGE	include/ieee80211.h	1178;"	d
-MFIE_TYPE_DS_SET	include/ieee80211.h	1174;"	d
-MFIE_TYPE_ERP	include/ieee80211.h	1179;"	d
-MFIE_TYPE_FH_SET	include/ieee80211.h	1173;"	d
-MFIE_TYPE_GENERIC	include/ieee80211.h	1182;"	d
-MFIE_TYPE_IBSS_SET	include/ieee80211.h	1177;"	d
-MFIE_TYPE_RATES	include/ieee80211.h	1172;"	d
-MFIE_TYPE_RATES_EX	include/ieee80211.h	1181;"	d
-MFIE_TYPE_RSN	include/ieee80211.h	1180;"	d
-MFIE_TYPE_SSID	include/ieee80211.h	1171;"	d
-MFIE_TYPE_TIM	include/ieee80211.h	1176;"	d
-MF_state	hal/phydm/phydm.h	/^	u1Byte  	MF_state;$/;"	m	struct:_Dynamic_Primary_CCA
-MGMT_QUEUE_NUM	include/ieee80211.h	33;"	d
-MGNT_FRAMETAG	include/rtw_xmit.h	459;"	d
-MGN_11M	include/ieee80211.h	/^	MGN_11M	= 0x16,$/;"	e	enum:MGN_RATE
-MGN_12M	include/ieee80211.h	/^	MGN_12M	= 0x18,$/;"	e	enum:MGN_RATE
-MGN_18M	include/ieee80211.h	/^	MGN_18M	= 0x24,$/;"	e	enum:MGN_RATE
-MGN_1M	include/ieee80211.h	/^	MGN_1M		= 0x02,$/;"	e	enum:MGN_RATE
-MGN_24M	include/ieee80211.h	/^	MGN_24M	= 0x30,$/;"	e	enum:MGN_RATE
-MGN_2M	include/ieee80211.h	/^	MGN_2M		= 0x04,$/;"	e	enum:MGN_RATE
-MGN_36M	include/ieee80211.h	/^	MGN_36M	= 0x48,$/;"	e	enum:MGN_RATE
-MGN_48M	include/ieee80211.h	/^	MGN_48M	= 0x60,$/;"	e	enum:MGN_RATE
-MGN_54M	include/ieee80211.h	/^	MGN_54M	= 0x6C,$/;"	e	enum:MGN_RATE
-MGN_5_5M	include/ieee80211.h	/^	MGN_5_5M	= 0x0B,$/;"	e	enum:MGN_RATE
-MGN_6M	include/ieee80211.h	/^	MGN_6M		= 0x0C,$/;"	e	enum:MGN_RATE
-MGN_9M	include/ieee80211.h	/^	MGN_9M		= 0x12,$/;"	e	enum:MGN_RATE
-MGN_MCS0	include/ieee80211.h	/^	MGN_MCS0,$/;"	e	enum:MGN_RATE
-MGN_MCS1	include/ieee80211.h	/^	MGN_MCS1,$/;"	e	enum:MGN_RATE
-MGN_MCS10	include/ieee80211.h	/^	MGN_MCS10,$/;"	e	enum:MGN_RATE
-MGN_MCS11	include/ieee80211.h	/^	MGN_MCS11,$/;"	e	enum:MGN_RATE
-MGN_MCS12	include/ieee80211.h	/^	MGN_MCS12,$/;"	e	enum:MGN_RATE
-MGN_MCS13	include/ieee80211.h	/^	MGN_MCS13,$/;"	e	enum:MGN_RATE
-MGN_MCS14	include/ieee80211.h	/^	MGN_MCS14,$/;"	e	enum:MGN_RATE
-MGN_MCS15	include/ieee80211.h	/^	MGN_MCS15,$/;"	e	enum:MGN_RATE
-MGN_MCS16	include/ieee80211.h	/^	MGN_MCS16,$/;"	e	enum:MGN_RATE
-MGN_MCS17	include/ieee80211.h	/^	MGN_MCS17,$/;"	e	enum:MGN_RATE
-MGN_MCS18	include/ieee80211.h	/^	MGN_MCS18,$/;"	e	enum:MGN_RATE
-MGN_MCS19	include/ieee80211.h	/^	MGN_MCS19,$/;"	e	enum:MGN_RATE
-MGN_MCS2	include/ieee80211.h	/^	MGN_MCS2,$/;"	e	enum:MGN_RATE
-MGN_MCS20	include/ieee80211.h	/^	MGN_MCS20,$/;"	e	enum:MGN_RATE
-MGN_MCS21	include/ieee80211.h	/^	MGN_MCS21,$/;"	e	enum:MGN_RATE
-MGN_MCS22	include/ieee80211.h	/^	MGN_MCS22,$/;"	e	enum:MGN_RATE
-MGN_MCS23	include/ieee80211.h	/^	MGN_MCS23,$/;"	e	enum:MGN_RATE
-MGN_MCS24	include/ieee80211.h	/^	MGN_MCS24,$/;"	e	enum:MGN_RATE
-MGN_MCS25	include/ieee80211.h	/^	MGN_MCS25,$/;"	e	enum:MGN_RATE
-MGN_MCS26	include/ieee80211.h	/^	MGN_MCS26,$/;"	e	enum:MGN_RATE
-MGN_MCS27	include/ieee80211.h	/^	MGN_MCS27,$/;"	e	enum:MGN_RATE
-MGN_MCS28	include/ieee80211.h	/^	MGN_MCS28,$/;"	e	enum:MGN_RATE
-MGN_MCS29	include/ieee80211.h	/^	MGN_MCS29,$/;"	e	enum:MGN_RATE
-MGN_MCS3	include/ieee80211.h	/^	MGN_MCS3,$/;"	e	enum:MGN_RATE
-MGN_MCS30	include/ieee80211.h	/^	MGN_MCS30,$/;"	e	enum:MGN_RATE
-MGN_MCS31	include/ieee80211.h	/^	MGN_MCS31,$/;"	e	enum:MGN_RATE
-MGN_MCS32	include/ieee80211.h	/^	MGN_MCS32	= 0x7F,$/;"	e	enum:MGN_RATE
-MGN_MCS4	include/ieee80211.h	/^	MGN_MCS4,$/;"	e	enum:MGN_RATE
-MGN_MCS5	include/ieee80211.h	/^	MGN_MCS5,$/;"	e	enum:MGN_RATE
-MGN_MCS6	include/ieee80211.h	/^	MGN_MCS6,$/;"	e	enum:MGN_RATE
-MGN_MCS7	include/ieee80211.h	/^	MGN_MCS7,$/;"	e	enum:MGN_RATE
-MGN_MCS8	include/ieee80211.h	/^	MGN_MCS8,$/;"	e	enum:MGN_RATE
-MGN_MCS9	include/ieee80211.h	/^	MGN_MCS9,$/;"	e	enum:MGN_RATE
-MGN_RATE	include/ieee80211.h	/^enum MGN_RATE {$/;"	g
-MGN_RATE_STR	include/ieee80211.h	865;"	d
-MGN_UNKNOWN	include/ieee80211.h	/^	MGN_UNKNOWN$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS0	include/ieee80211.h	/^	MGN_VHT1SS_MCS0,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS1	include/ieee80211.h	/^	MGN_VHT1SS_MCS1,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS2	include/ieee80211.h	/^	MGN_VHT1SS_MCS2,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS3	include/ieee80211.h	/^	MGN_VHT1SS_MCS3,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS4	include/ieee80211.h	/^	MGN_VHT1SS_MCS4,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS5	include/ieee80211.h	/^	MGN_VHT1SS_MCS5,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS6	include/ieee80211.h	/^	MGN_VHT1SS_MCS6,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS7	include/ieee80211.h	/^	MGN_VHT1SS_MCS7,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS8	include/ieee80211.h	/^	MGN_VHT1SS_MCS8,$/;"	e	enum:MGN_RATE
-MGN_VHT1SS_MCS9	include/ieee80211.h	/^	MGN_VHT1SS_MCS9,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS0	include/ieee80211.h	/^	MGN_VHT2SS_MCS0,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS1	include/ieee80211.h	/^	MGN_VHT2SS_MCS1,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS2	include/ieee80211.h	/^	MGN_VHT2SS_MCS2,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS3	include/ieee80211.h	/^	MGN_VHT2SS_MCS3,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS4	include/ieee80211.h	/^	MGN_VHT2SS_MCS4,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS5	include/ieee80211.h	/^	MGN_VHT2SS_MCS5,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS6	include/ieee80211.h	/^	MGN_VHT2SS_MCS6,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS7	include/ieee80211.h	/^	MGN_VHT2SS_MCS7,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS8	include/ieee80211.h	/^	MGN_VHT2SS_MCS8,$/;"	e	enum:MGN_RATE
-MGN_VHT2SS_MCS9	include/ieee80211.h	/^	MGN_VHT2SS_MCS9,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS0	include/ieee80211.h	/^	MGN_VHT3SS_MCS0,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS1	include/ieee80211.h	/^	MGN_VHT3SS_MCS1,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS2	include/ieee80211.h	/^	MGN_VHT3SS_MCS2,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS3	include/ieee80211.h	/^	MGN_VHT3SS_MCS3,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS4	include/ieee80211.h	/^	MGN_VHT3SS_MCS4,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS5	include/ieee80211.h	/^	MGN_VHT3SS_MCS5,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS6	include/ieee80211.h	/^	MGN_VHT3SS_MCS6,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS7	include/ieee80211.h	/^	MGN_VHT3SS_MCS7,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS8	include/ieee80211.h	/^	MGN_VHT3SS_MCS8,$/;"	e	enum:MGN_RATE
-MGN_VHT3SS_MCS9	include/ieee80211.h	/^	MGN_VHT3SS_MCS9,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS0	include/ieee80211.h	/^	MGN_VHT4SS_MCS0,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS1	include/ieee80211.h	/^	MGN_VHT4SS_MCS1,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS2	include/ieee80211.h	/^	MGN_VHT4SS_MCS2,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS3	include/ieee80211.h	/^	MGN_VHT4SS_MCS3,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS4	include/ieee80211.h	/^	MGN_VHT4SS_MCS4,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS5	include/ieee80211.h	/^	MGN_VHT4SS_MCS5,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS6	include/ieee80211.h	/^	MGN_VHT4SS_MCS6,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS7	include/ieee80211.h	/^	MGN_VHT4SS_MCS7,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS8	include/ieee80211.h	/^	MGN_VHT4SS_MCS8,$/;"	e	enum:MGN_RATE
-MGN_VHT4SS_MCS9	include/ieee80211.h	/^	MGN_VHT4SS_MCS9,$/;"	e	enum:MGN_RATE
-MGT_QUEUE_INX	include/rtw_xmit.h	107;"	d
-MIC_CHECK_TIME	include/wlan_bssdef.h	257;"	d
-MIC_CHECK_TIME	include/wlan_bssdef.h	503;"	d
-MID_QUEUE_IDX	include/hal_com_reg.h	1628;"	d
-MIN	include/rtw_security.h	445;"	d
-MINIMUM_ETHERNET_PACKET_SIZE	include/ethernet.h	28;"	d
-MIN_FRAG_THRESHOLD	include/ieee80211.h	458;"	d
-MIRACAST_DISABLED	include/rtw_mlme.h	78;"	d
-MIRACAST_MODE_REVERSE	include/rtw_mlme.h	82;"	d
-MIRACAST_SINK	include/rtw_mlme.h	80;"	d
-MIRACAST_SOURCE	include/rtw_mlme.h	79;"	d
-MIXED_PHY	include/rtw_rf.h	25;"	d
-MIX_2G_TSSI_5G_MODE	hal/phydm/halphyrf_ce.h	/^	MIX_2G_TSSI_5G_MODE,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-MIX_2G_TSSI_5G_MODE	hal/phydm/halphyrf_win.h	/^	MIX_2G_TSSI_5G_MODE,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-MIX_5G_TSSI_2G_MODE	hal/phydm/halphyrf_ce.h	/^	MIX_5G_TSSI_2G_MODE$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-MIX_5G_TSSI_2G_MODE	hal/phydm/halphyrf_win.h	/^	MIX_5G_TSSI_2G_MODE$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-MIX_MODE	hal/phydm/halphyrf_ap.h	/^	MIX_MODE,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-MIX_MODE	hal/phydm/halphyrf_ce.h	/^	MIX_MODE,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-MIX_MODE	hal/phydm/halphyrf_win.h	/^	MIX_MODE,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-MI_ADHOC	include/rtw_mi.h	/^	MI_ADHOC,$/;"	e	enum:__anon7
-MI_ADHOC_ASSOC	include/rtw_mi.h	/^	MI_ADHOC_ASSOC,$/;"	e	enum:__anon7
-MI_AP_ASSOC	include/rtw_mi.h	/^	MI_AP_ASSOC,$/;"	e	enum:__anon7
-MI_AP_MODE	include/rtw_mi.h	/^	MI_AP_MODE,$/;"	e	enum:__anon7
-MI_ASSOC	include/rtw_mi.h	/^	MI_ASSOC,$/;"	e	enum:__anon7
-MI_LINKED	include/rtw_mi.h	/^	MI_LINKED,$/;"	e	enum:__anon7
-MI_STA_LINKED	include/rtw_mi.h	/^	MI_STA_LINKED,$/;"	e	enum:__anon7
-MI_STA_LINKING	include/rtw_mi.h	/^	MI_STA_LINKING,$/;"	e	enum:__anon7
-MI_STA_NOLINK	include/rtw_mi.h	/^	MI_STA_NOLINK, \/* this is misleading, but not used now *\/$/;"	e	enum:__anon7
-MI_UNDER_WPS	include/rtw_mi.h	/^	MI_UNDER_WPS,$/;"	e	enum:__anon7
-MLME_AP_STARTED	include/rtw_cmd.h	/^	MLME_AP_STARTED,$/;"	e	enum:__anon4
-MLME_AP_STOPPED	include/rtw_cmd.h	/^	MLME_AP_STOPPED,$/;"	e	enum:__anon4
-MLME_ASSOC_REQ_IE	include/rtw_mlme.h	1080;"	d
-MLME_ASSOC_RESP_IE	include/rtw_mlme.h	1081;"	d
-MLME_BEACON_IE	include/rtw_mlme.h	1076;"	d
-MLME_GO_PROBE_RESP_IE	include/rtw_mlme.h	1079;"	d
-MLME_IS_ADHOC	include/rtw_mlme.h	94;"	d
-MLME_IS_ADHOC_MASTER	include/rtw_mlme.h	95;"	d
-MLME_IS_AP	include/rtw_mlme.h	93;"	d
-MLME_IS_GC	include/rtw_mlme.h	100;"	d
-MLME_IS_GC	include/rtw_mlme.h	104;"	d
-MLME_IS_GO	include/rtw_mlme.h	101;"	d
-MLME_IS_GO	include/rtw_mlme.h	105;"	d
-MLME_IS_MGMT_TX	include/rtw_mlme.h	118;"	d
-MLME_IS_MGMT_TX	include/rtw_mlme.h	120;"	d
-MLME_IS_MONITOR	include/rtw_mlme.h	96;"	d
-MLME_IS_MP	include/rtw_mlme.h	97;"	d
-MLME_IS_MSINK	include/rtw_mlme.h	115;"	d
-MLME_IS_MSRC	include/rtw_mlme.h	114;"	d
-MLME_IS_PD	include/rtw_mlme.h	103;"	d
-MLME_IS_PD	include/rtw_mlme.h	99;"	d
-MLME_IS_ROCH	include/rtw_mlme.h	109;"	d
-MLME_IS_ROCH	include/rtw_mlme.h	111;"	d
-MLME_IS_STA	include/rtw_mlme.h	92;"	d
-MLME_PROBE_REQ_IE	include/rtw_mlme.h	1077;"	d
-MLME_PROBE_RESP_IE	include/rtw_mlme.h	1078;"	d
-MLME_STATE	include/rtw_mlme.h	90;"	d
-MLME_STATE_ARG	include/rtw_mlme.h	124;"	d
-MLME_STATE_FMT	include/rtw_mlme.h	123;"	d
-MLME_STA_CONNECTED	include/rtw_cmd.h	/^	MLME_STA_CONNECTED,$/;"	e	enum:__anon4
-MLME_STA_CONNECTING	include/rtw_cmd.h	/^	MLME_STA_CONNECTING,$/;"	e	enum:__anon4
-MLME_STA_DISCONNECTED	include/rtw_cmd.h	/^	MLME_STA_DISCONNECTED,$/;"	e	enum:__anon4
-MODDESTDIR	Makefile	/^MODDESTDIR := \/lib\/modules\/$(KVER)\/kernel\/drivers\/net\/wireless\/$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := $(USER_MODULE_NAME)$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := 8192eu$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := 8723ds$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := 8811au$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := 8821ae$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := 8821as$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := 8821au$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := 8822be$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := rtl8192eu$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := rtw_pci$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := rtw_sdio$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := rtw_usb$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME := wlan$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME :=8189es_kk$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME :=wlan$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8188ee$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8188eu$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8188fe$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8188fu$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8189es$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8189fs$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8192ee$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8192es$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8192eu$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723be$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723bs$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723bu$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723ce$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723cs$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723cu$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723de$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723ds$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8723du$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8812ae$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8812as$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8812au$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8814ae$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8814as$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = 8814au$/;"	m
-MODULE_NAME	Makefile	/^MODULE_NAME = wlan$/;"	m
-MODULE_SUB_NAME	Makefile	/^MODULE_SUB_NAME = 8703be$/;"	m
-MODULE_SUB_NAME	Makefile	/^MODULE_SUB_NAME = 8703bs$/;"	m
-MODULE_SUB_NAME	Makefile	/^MODULE_SUB_NAME = 8703bu$/;"	m
-MODULE_SUB_NAME	Makefile	/^MODULE_SUB_NAME = 8723de$/;"	m
-MODULE_SUB_NAME	Makefile	/^MODULE_SUB_NAME = 8723ds$/;"	m
-MODULE_SUB_NAME	Makefile	/^MODULE_SUB_NAME = 8723du$/;"	m
-MPDIG_2G	hal/phydm/phydm.h	/^	BOOLEAN			MPDIG_2G;				\/*off MPDIG*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-MPTBT_FwC2hBtMpCtrl	core/rtw_bt_mp.c	/^MPTBT_FwC2hBtMpCtrl($/;"	f
-MPT_BANDWIDTHE	include/rtw_mp.h	/^} MPT_BANDWIDTHE, *PMPT_BANDWIDTH;$/;"	t	typeref:enum:_MPT_BANDWIDTH
-MPT_BW_20MHZ	include/rtw_mp.h	/^	MPT_BW_20MHZ = 0,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_40MHZ	include/rtw_mp.h	/^	MPT_BW_40MHZ = 4,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_40MHZ_ABOVE	include/rtw_mp.h	/^	MPT_BW_40MHZ_ABOVE = 2,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_40MHZ_BELOW	include/rtw_mp.h	/^	MPT_BW_40MHZ_BELOW = 3,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_40MHZ_DUPLICATE	include/rtw_mp.h	/^	MPT_BW_40MHZ_DUPLICATE = 1,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_80MHZ	include/rtw_mp.h	/^	MPT_BW_80MHZ = 5,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_80MHZ_20_ABOVE	include/rtw_mp.h	/^	MPT_BW_80MHZ_20_ABOVE = 6,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_80MHZ_20_BELOW	include/rtw_mp.h	/^	MPT_BW_80MHZ_20_BELOW = 7,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_80MHZ_20_BOTTOM	include/rtw_mp.h	/^	MPT_BW_80MHZ_20_BOTTOM = 8,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_80MHZ_20_TOP	include/rtw_mp.h	/^	MPT_BW_80MHZ_20_TOP = 9,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_80MHZ_40_ABOVE	include/rtw_mp.h	/^	MPT_BW_80MHZ_40_ABOVE = 10,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_BW_80MHZ_40_BELOW	include/rtw_mp.h	/^	MPT_BW_80MHZ_40_BELOW = 11,$/;"	e	enum:_MPT_BANDWIDTH
-MPT_CCK	include/rtw_mp.h	/^	MPT_CCK,$/;"	e	enum:_MPT_TXPWR_DEF
-MPT_CCKTxPowerAdjust	core/rtw_mp.c	/^static void MPT_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)$/;"	f	file:
-MPT_CONTEXT	include/rtw_mp.h	/^} MPT_CONTEXT, *PMPT_CONTEXT;$/;"	t	typeref:struct:_MPT_CONTEXT
-MPT_DIGTimer	hal/phydm/phydm.h	/^	RT_TIMER 		MPT_DIGTimer;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-MPT_DIGWorkitem	hal/phydm/phydm.h	/^	RT_WORK_ITEM			MPT_DIGWorkitem;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-MPT_DeInitAdapter	core/rtw_mp.c	/^MPT_DeInitAdapter($/;"	f
-MPT_HT	include/rtw_mp.h	/^	MPT_HT,$/;"	e	enum:_MPT_TXPWR_DEF
-MPT_IS_2SS_RATE	include/rtw_mp.h	656;"	d
-MPT_IS_3SS_RATE	include/rtw_mp.h	658;"	d
-MPT_IS_4SS_RATE	include/rtw_mp.h	660;"	d
-MPT_IS_CCK_RATE	include/rtw_mp.h	642;"	d
-MPT_IS_HT_1S_RATE	include/rtw_mp.h	645;"	d
-MPT_IS_HT_2S_RATE	include/rtw_mp.h	646;"	d
-MPT_IS_HT_3S_RATE	include/rtw_mp.h	647;"	d
-MPT_IS_HT_4S_RATE	include/rtw_mp.h	648;"	d
-MPT_IS_HT_RATE	include/rtw_mp.h	644;"	d
-MPT_IS_OFDM_RATE	include/rtw_mp.h	643;"	d
-MPT_IS_VHT_1S_RATE	include/rtw_mp.h	651;"	d
-MPT_IS_VHT_2S_RATE	include/rtw_mp.h	652;"	d
-MPT_IS_VHT_3S_RATE	include/rtw_mp.h	653;"	d
-MPT_IS_VHT_4S_RATE	include/rtw_mp.h	654;"	d
-MPT_IS_VHT_RATE	include/rtw_mp.h	650;"	d
-MPT_InitializeAdapter	core/rtw_mp.c	/^MPT_InitializeAdapter($/;"	f
-MPT_OFDM	include/rtw_mp.h	/^	MPT_OFDM, \/* L and HT OFDM *\/$/;"	e	enum:_MPT_TXPWR_DEF
-MPT_OFDM_AND_HT	include/rtw_mp.h	/^	MPT_OFDM_AND_HT,$/;"	e	enum:_MPT_TXPWR_DEF
-MPT_PwrCtlDM	core/rtw_mp.c	/^void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart)$/;"	f
-MPT_RATE_11M	include/rtw_mp.h	/^	MPT_RATE_11M,	\/* 3 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_12M	include/rtw_mp.h	/^	MPT_RATE_12M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_18M	include/rtw_mp.h	/^	MPT_RATE_18M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_1M	include/rtw_mp.h	/^	MPT_RATE_1M = 1 ,	\/* 0 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_24M	include/rtw_mp.h	/^	MPT_RATE_24M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_2M	include/rtw_mp.h	/^	MPT_RATE_2M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_36M	include/rtw_mp.h	/^	MPT_RATE_36M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_48M	include/rtw_mp.h	/^	MPT_RATE_48M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_54M	include/rtw_mp.h	/^	MPT_RATE_54M,	\/* 11 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_55M	include/rtw_mp.h	/^	MPT_RATE_55M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_6M	include/rtw_mp.h	/^	MPT_RATE_6M,	\/* 4 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_9M	include/rtw_mp.h	/^	MPT_RATE_9M,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_E	include/rtw_mp.h	/^} MPT_RATE_E, *PMPT_RATE_E;$/;"	t	typeref:enum:_MPT_RATE_INDEX
-MPT_RATE_LAST	include/rtw_mp.h	/^	MPT_RATE_LAST$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS0	include/rtw_mp.h	/^	MPT_RATE_MCS0,	\/* 12 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS1	include/rtw_mp.h	/^	MPT_RATE_MCS1,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS10	include/rtw_mp.h	/^	MPT_RATE_MCS10,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS11	include/rtw_mp.h	/^	MPT_RATE_MCS11,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS12	include/rtw_mp.h	/^	MPT_RATE_MCS12,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS13	include/rtw_mp.h	/^	MPT_RATE_MCS13,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS14	include/rtw_mp.h	/^	MPT_RATE_MCS14,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS15	include/rtw_mp.h	/^	MPT_RATE_MCS15,	\/* 27 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS16	include/rtw_mp.h	/^	MPT_RATE_MCS16,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS17	include/rtw_mp.h	/^	MPT_RATE_MCS17, \/*  #29 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS18	include/rtw_mp.h	/^	MPT_RATE_MCS18,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS19	include/rtw_mp.h	/^	MPT_RATE_MCS19,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS2	include/rtw_mp.h	/^	MPT_RATE_MCS2,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS20	include/rtw_mp.h	/^	MPT_RATE_MCS20,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS21	include/rtw_mp.h	/^	MPT_RATE_MCS21,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS22	include/rtw_mp.h	/^	MPT_RATE_MCS22, \/*  #34 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS23	include/rtw_mp.h	/^	MPT_RATE_MCS23,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS24	include/rtw_mp.h	/^	MPT_RATE_MCS24,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS25	include/rtw_mp.h	/^	MPT_RATE_MCS25,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS26	include/rtw_mp.h	/^	MPT_RATE_MCS26,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS27	include/rtw_mp.h	/^	MPT_RATE_MCS27, \/*  #39 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS28	include/rtw_mp.h	/^	MPT_RATE_MCS28, \/*  #40 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS29	include/rtw_mp.h	/^	MPT_RATE_MCS29, \/*  #41 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS3	include/rtw_mp.h	/^	MPT_RATE_MCS3,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS30	include/rtw_mp.h	/^	MPT_RATE_MCS30, \/*  #42 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS31	include/rtw_mp.h	/^	MPT_RATE_MCS31, \/*  #43 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS4	include/rtw_mp.h	/^	MPT_RATE_MCS4,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS5	include/rtw_mp.h	/^	MPT_RATE_MCS5,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS6	include/rtw_mp.h	/^	MPT_RATE_MCS6,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS7	include/rtw_mp.h	/^	MPT_RATE_MCS7,	\/* 19 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS8	include/rtw_mp.h	/^	MPT_RATE_MCS8,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_MCS9	include/rtw_mp.h	/^	MPT_RATE_MCS9,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS0	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS0 = 100,\/*  #44*\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS1	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS1, \/*  # *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS2	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS2,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS3	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS3,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS4	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS4,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS5	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS5,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS6	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS6, \/*  # *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS7	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS7,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS8	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS8,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT1SS_MCS9	include/rtw_mp.h	/^	MPT_RATE_VHT1SS_MCS9, \/* #53 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS0	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS0, \/* #54 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS1	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS1,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS2	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS2,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS3	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS3,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS4	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS4,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS5	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS5,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS6	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS6,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS7	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS7,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS8	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS8,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT2SS_MCS9	include/rtw_mp.h	/^	MPT_RATE_VHT2SS_MCS9, \/* #63 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS0	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS0,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS1	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS1,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS2	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS2,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS3	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS3,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS4	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS4,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS5	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS5,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS6	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS6, \/*  #126 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS7	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS7,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS8	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS8,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT3SS_MCS9	include/rtw_mp.h	/^	MPT_RATE_VHT3SS_MCS9,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS0	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS0,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS1	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS1, \/*  #131 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS2	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS2,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS3	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS3,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS4	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS4,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS5	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS5,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS6	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS6, \/*  #136 *\/$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS7	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS7,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS8	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS8,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_RATE_VHT4SS_MCS9	include/rtw_mp.h	/^	MPT_RATE_VHT4SS_MCS9,$/;"	e	enum:_MPT_RATE_INDEX
-MPT_TXPWR_DEF	include/rtw_mp.h	/^} MPT_TXPWR_DEF;$/;"	t	typeref:enum:_MPT_TXPWR_DEF
-MPT_VHT	include/rtw_mp.h	/^	MPT_VHT$/;"	e	enum:_MPT_TXPWR_DEF
-MPT_WORK_ITEM_HANDLER	include/rtw_mp.h	/^typedef VOID (*MPT_WORK_ITEM_HANDLER)(IN PVOID Adapter);$/;"	t
-MP_ANT_RX	include/rtw_mp.h	/^	MP_ANT_RX,$/;"	e	enum:__anon65
-MP_ANT_TX	include/rtw_mp.h	/^	MP_ANT_TX,$/;"	e	enum:__anon65
-MP_AP_WOW_ENABLE	include/rtw_mp.h	/^	MP_AP_WOW_ENABLE,$/;"	e	enum:__anon65
-MP_ARX	include/rtw_mp.h	/^	MP_ARX,$/;"	e	enum:__anon65
-MP_BANDWIDTH	include/rtw_mp.h	/^	MP_BANDWIDTH,$/;"	e	enum:__anon65
-MP_BT_MODE	include/rtw_bt_mp.h	/^} MP_BT_MODE, *PMP_BT_MODE;$/;"	t	typeref:enum:_MP_BT_MODE
-MP_BT_MODE_BT20_DUT_TEST_MODE	include/rtw_bt_mp.h	/^	MP_BT_MODE_BT20_DUT_TEST_MODE							= 1,$/;"	e	enum:_MP_BT_MODE
-MP_BT_MODE_BT40_DIRECT_TEST_MODE	include/rtw_bt_mp.h	/^	MP_BT_MODE_BT40_DIRECT_TEST_MODE						= 2,$/;"	e	enum:_MP_BT_MODE
-MP_BT_MODE_CONNECT_TEST_MODE	include/rtw_bt_mp.h	/^	MP_BT_MODE_CONNECT_TEST_MODE							= 3,$/;"	e	enum:_MP_BT_MODE
-MP_BT_MODE_MAX	include/rtw_bt_mp.h	/^	MP_BT_MODE_MAX$/;"	e	enum:_MP_BT_MODE
-MP_BT_MODE_RF_TXRX_TEST_MODE	include/rtw_bt_mp.h	/^	MP_BT_MODE_RF_TXRX_TEST_MODE							= 0,$/;"	e	enum:_MP_BT_MODE
-MP_BT_NOT_READY	include/rtw_bt_mp.h	30;"	d
-MP_BT_PAYLOAD_01010101	include/rtw_bt_mp.h	/^	MP_BT_PAYLOAD_01010101					= 0,$/;"	e	enum:_MP_BT_PAYLOAD_TYPE
-MP_BT_PAYLOAD_11110000	include/rtw_bt_mp.h	/^	MP_BT_PAYLOAD_11110000					= 3,$/;"	e	enum:_MP_BT_PAYLOAD_TYPE
-MP_BT_PAYLOAD_ALL_0	include/rtw_bt_mp.h	/^	MP_BT_PAYLOAD_ALL_0						= 2,$/;"	e	enum:_MP_BT_PAYLOAD_TYPE
-MP_BT_PAYLOAD_ALL_1	include/rtw_bt_mp.h	/^	MP_BT_PAYLOAD_ALL_1						= 1,$/;"	e	enum:_MP_BT_PAYLOAD_TYPE
-MP_BT_PAYLOAD_MAX	include/rtw_bt_mp.h	/^	MP_BT_PAYLOAD_MAX						= 8,$/;"	e	enum:_MP_BT_PAYLOAD_TYPE
-MP_BT_PAYLOAD_PRBS9	include/rtw_bt_mp.h	/^	MP_BT_PAYLOAD_PRBS9						= 4,$/;"	e	enum:_MP_BT_PAYLOAD_TYPE
-MP_BT_PAYLOAD_TYPE	include/rtw_bt_mp.h	/^} MP_BT_PAYLOAD_TYPE, *PMP_BT_PAYLOAD_TYPE;$/;"	t	typeref:enum:_MP_BT_PAYLOAD_TYPE
-MP_BT_PKT_2DH1	include/rtw_bt_mp.h	/^	MP_BT_PKT_2DH1							= 3,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_2DH3	include/rtw_bt_mp.h	/^	MP_BT_PKT_2DH3							= 4,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_2DH5	include/rtw_bt_mp.h	/^	MP_BT_PKT_2DH5							= 5,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_3DH1	include/rtw_bt_mp.h	/^	MP_BT_PKT_3DH1							= 6,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_3DH3	include/rtw_bt_mp.h	/^	MP_BT_PKT_3DH3							= 7,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_3DH5	include/rtw_bt_mp.h	/^	MP_BT_PKT_3DH5							= 8,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_DH1	include/rtw_bt_mp.h	/^	MP_BT_PKT_DH1							= 0,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_DH3	include/rtw_bt_mp.h	/^	MP_BT_PKT_DH3							= 1,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_DH5	include/rtw_bt_mp.h	/^	MP_BT_PKT_DH5							= 2,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_LE	include/rtw_bt_mp.h	/^	MP_BT_PKT_LE							= 9,$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_MAX	include/rtw_bt_mp.h	/^	MP_BT_PKT_MAX$/;"	e	enum:_MP_BT_PKT_TYPE
-MP_BT_PKT_TYPE	include/rtw_bt_mp.h	/^} MP_BT_PKT_TYPE, *PMP_BT_PKT_TYPE;$/;"	t	typeref:enum:_MP_BT_PKT_TYPE
-MP_BT_READY	include/rtw_bt_mp.h	31;"	d
-MP_BT_TEST_CTRL	include/rtw_bt_mp.h	/^} MP_BT_TEST_CTRL, *PMP_BT_TEST_CTRL;$/;"	t	typeref:enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_MAX	include/rtw_bt_mp.h	/^	MP_BT_TEST_MAX$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_CONTINUOUS_TX_TEST	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_CONTINUOUS_TX_TEST			= 3,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_INQUIRY_PAGE_SCAN_TEST	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_INQUIRY_PAGE_SCAN_TEST			= 6,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_INQUIRY_SCAN_TEST	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_INQUIRY_SCAN_TEST				= 4,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_LEGACY_CONNECT_TEST	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_LEGACY_CONNECT_TEST			= 7,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_LE_CONNECT_TEST_ADVERTISER	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_LE_CONNECT_TEST_ADVERTISER	= 9,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_LE_CONNECT_TEST_INITIATOR	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_LE_CONNECT_TEST_INITIATOR		= 8,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_PACKET_TX_TEST	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_PACKET_TX_TEST					= 2,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_PAGE_SCAN_TEST	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_PAGE_SCAN_TEST					= 5,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_START_RX_TEST	include/rtw_bt_mp.h	/^	MP_BT_TEST_START_RX_TEST						= 1,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_BT_TEST_STOP_ALL_TESTS	include/rtw_bt_mp.h	/^	MP_BT_TEST_STOP_ALL_TESTS						= 0,$/;"	e	enum:_MP_BT_TEST_CTRL
-MP_CARRIER_SUPPRISSION_TX	include/rtw_mp.h	/^	MP_CARRIER_SUPPRISSION_TX,$/;"	e	enum:_MP_MODE_
-MP_CHANNEL	include/rtw_mp.h	/^	MP_CHANNEL,$/;"	e	enum:__anon65
-MP_CONTINUOUS_TX	include/rtw_mp.h	/^	MP_CONTINUOUS_TX,$/;"	e	enum:_MP_MODE_
-MP_CTX	include/rtw_mp.h	/^	MP_CTX,$/;"	e	enum:__anon65
-MP_CUSTOMER_STR	include/rtw_mp.h	/^	MP_CUSTOMER_STR,$/;"	e	enum:__anon65
-MP_DISABLE_BT_COEXIST	include/rtw_mp.h	/^	MP_DISABLE_BT_COEXIST,$/;"	e	enum:__anon65
-MP_DRIVER	hal/phydm/phydm_types.h	59;"	d
-MP_DRIVER	include/autoconf.h	177;"	d
-MP_DRIVER	include/autoconf.h	185;"	d
-MP_DUMP	include/rtw_mp.h	/^	MP_DUMP,$/;"	e	enum:__anon65
-MP_ERR	include/rtw_mp.h	/^	MP_ERR,$/;"	e	enum:_MP_MODE_
-MP_FRAMETAG	include/rtw_xmit.h	465;"	d
-MP_GETVER	include/rtw_mp.h	/^	MP_GETVER,$/;"	e	enum:__anon65
-MP_GET_TXPOWER_INX	include/rtw_mp.h	/^	MP_GET_TXPOWER_INX,$/;"	e	enum:__anon65
-MP_HW_TX_MODE	include/rtw_mp.h	/^	MP_HW_TX_MODE,$/;"	e	enum:__anon65
-MP_IOCTL	include/rtw_mp.h	/^	MP_IOCTL,$/;"	e	enum:__anon65
-MP_IQK	include/rtw_mp.h	/^	MP_IQK,$/;"	e	enum:__anon65
-MP_LCK	include/rtw_mp.h	/^	MP_LCK,$/;"	e	enum:__anon65
-MP_MAX_LINES	include/rtw_mp.h	103;"	d
-MP_MAX_LINES_BYTES	include/rtw_mp.h	104;"	d
-MP_MODE	include/rtw_mp.h	/^} MP_MODE;$/;"	t	typeref:enum:_MP_MODE_
-MP_MON	include/rtw_mp.h	/^	MP_MON,$/;"	e	enum:__anon65
-MP_NULL	include/rtw_mp.h	/^	MP_NULL,$/;"	e	enum:__anon65
-MP_OFF	include/rtw_mp.h	/^	MP_OFF,$/;"	e	enum:_MP_MODE_
-MP_ON	include/rtw_mp.h	/^	MP_ON,$/;"	e	enum:_MP_MODE_
-MP_PACKET_RX	include/rtw_mp.h	/^	MP_PACKET_RX$/;"	e	enum:_MP_MODE_
-MP_PACKET_TX	include/rtw_mp.h	/^	MP_PACKET_TX,$/;"	e	enum:_MP_MODE_
-MP_PHYPARA	include/rtw_mp.h	/^	MP_PHYPARA,$/;"	e	enum:__anon65
-MP_PHY_SetRFPathSwitch	core/rtw_mp.c	/^void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter , BOOLEAN bMain)$/;"	f
-MP_PSD	include/rtw_mp.h	/^	MP_PSD,$/;"	e	enum:__anon65
-MP_PWRTRK	include/rtw_mp.h	/^	MP_PWRTRK,$/;"	e	enum:__anon65
-MP_PwrCtlDM	include/rtw_mp.h	/^	MP_PwrCtlDM,$/;"	e	enum:__anon65
-MP_QUERY	include/rtw_mp.h	/^	MP_QUERY,$/;"	e	enum:__anon65
-MP_QueryDrvStats	include/rtw_mp.h	/^	MP_QueryDrvStats,$/;"	e	enum:__anon65
-MP_RATE	include/rtw_mp.h	/^	MP_RATE,$/;"	e	enum:__anon65
-MP_REG_ENTRY	include/drv_types_ce.h	/^} MP_REG_ENTRY, *PMP_REG_ENTRY;$/;"	t	typeref:struct:_MP_REG_ENTRY
-MP_REG_ENTRY	include/drv_types_xp.h	/^} MP_REG_ENTRY, *PMP_REG_ENTRY;$/;"	t	typeref:struct:_MP_REG_ENTRY
-MP_RESET_STATS	include/rtw_mp.h	/^	MP_RESET_STATS,$/;"	e	enum:__anon65
-MP_RX	include/rtw_mp.h	/^	MP_RX,$/;"	e	enum:__anon65
-MP_SD_IREAD	include/rtw_mp.h	/^	MP_SD_IREAD,$/;"	e	enum:__anon65
-MP_SD_IWRITE	include/rtw_mp.h	/^	MP_SD_IWRITE,$/;"	e	enum:__anon65
-MP_SINGLE_CARRIER_TX	include/rtw_mp.h	/^	MP_SINGLE_CARRIER_TX,$/;"	e	enum:_MP_MODE_
-MP_SINGLE_TONE_TX	include/rtw_mp.h	/^	MP_SINGLE_TONE_TX,$/;"	e	enum:_MP_MODE_
-MP_START	include/rtw_mp.h	/^	MP_START,$/;"	e	enum:__anon65
-MP_STOP	include/rtw_mp.h	/^	MP_STOP,$/;"	e	enum:__anon65
-MP_SetBT	include/rtw_mp.h	/^	MP_SetBT,$/;"	e	enum:__anon65
-MP_SetRFPathSwh	include/rtw_mp.h	/^	MP_SetRFPathSwh,$/;"	e	enum:__anon65
-MP_THER	include/rtw_mp.h	/^	MP_THER,$/;"	e	enum:__anon65
-MP_TX	include/rtw_mp.h	/^	MP_TX,$/;"	e	enum:__anon65
-MP_TXPOWER	include/rtw_mp.h	/^	MP_TXPOWER,$/;"	e	enum:__anon65
-MP_WOW_ENABLE	include/rtw_mp.h	/^	MP_WOW_ENABLE,$/;"	e	enum:__anon65
-MP_WOW_SET_PATTERN	include/rtw_mp.h	/^	MP_WOW_SET_PATTERN,$/;"	e	enum:__anon65
-MP_XMIT_PARM	include/rtw_mp_ioctl.h	/^} MP_XMIT_PARM, *PMP_XMIT_PARM;$/;"	t	typeref:struct:_mp_xmit_parm_
-MPh2c_Sema	include/rtw_mp.h	/^	_sema			MPh2c_Sema;$/;"	m	struct:_MPT_CONTEXT
-MPh2c_timeout_handle	core/rtw_bt_mp.c	/^void MPh2c_timeout_handle(void *FunctionContext)$/;"	f
-MPh2c_timeout_timer	include/rtw_mp.h	/^	_timer			MPh2c_timeout_timer;$/;"	m	struct:_MPT_CONTEXT
-MPwlanhdr_to_ethhdr	core/rtw_recv.c	/^static sint MPwlanhdr_to_ethhdr(union recv_frame *precvframe)$/;"	f	file:
-MRateToHwRate	hal/hal_com.c	/^u8	MRateToHwRate(u8 rate)$/;"	f
-MSECS	include/hal_com_led.h	24;"	d
-MSG_LEN	hal/hal_halmac.c	386;"	d	file:
-MSG_PREFIX	hal/hal_halmac.c	387;"	d	file:
-MSG_PREFIX	hal/hal_halmac.c	424;"	d	file:
-MSR	include/hal_com_reg.h	563;"	d
-MSR	include/rtl8822b_hal.h	37;"	d
-MSR1	include/hal_com_reg.h	565;"	d
-MSR1	include/rtl8822b_hal.h	38;"	d
-MSR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	442;"	d
-MSR_8814A	include/rtl8814a_spec.h	539;"	d
-MSR_ADHOC	include/hal_com_reg.h	656;"	d
-MSR_AP	include/hal_com_reg.h	658;"	d
-MSR_INFRA	include/hal_com_reg.h	657;"	d
-MSR_NOLINK	include/hal_com_reg.h	655;"	d
-MSTATE_ADHOC_LD_NUM	include/rtw_mi.h	55;"	d
-MSTATE_ADHOC_NUM	include/rtw_mi.h	54;"	d
-MSTATE_AP_LD_NUM	include/rtw_mi.h	53;"	d
-MSTATE_AP_NUM	include/rtw_mi.h	52;"	d
-MSTATE_MGMT_TX_NUM	include/rtw_mi.h	65;"	d
-MSTATE_MGMT_TX_NUM	include/rtw_mi.h	67;"	d
-MSTATE_ROCH_NUM	include/rtw_mi.h	59;"	d
-MSTATE_ROCH_NUM	include/rtw_mi.h	61;"	d
-MSTATE_STA_LD_NUM	include/rtw_mi.h	50;"	d
-MSTATE_STA_LG_NUM	include/rtw_mi.h	51;"	d
-MSTATE_STA_NUM	include/rtw_mi.h	49;"	d
-MSTATE_U_BW	include/rtw_mi.h	71;"	d
-MSTATE_U_CH	include/rtw_mi.h	70;"	d
-MSTATE_U_OFFSET	include/rtw_mi.h	72;"	d
-MSTATE_WPS_NUM	include/rtw_mi.h	56;"	d
-MSTAT_ALLOC_FAIL	include/osdep_service.h	/^	MSTAT_ALLOC_FAIL,$/;"	e	enum:mstat_status
-MSTAT_ALLOC_SUCCESS	include/osdep_service.h	/^	MSTAT_ALLOC_SUCCESS = 0,$/;"	e	enum:mstat_status
-MSTAT_FREE	include/osdep_service.h	/^	MSTAT_FREE$/;"	e	enum:mstat_status
-MSTAT_FUNC_CFG_VENDOR	include/osdep_service.h	/^	MSTAT_FUNC_CFG_VENDOR = 0x06 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_IO	include/osdep_service.h	/^	MSTAT_FUNC_IO = 0x01 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_MAX	include/osdep_service.h	/^	MSTAT_FUNC_MAX = 0x07 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_RX	include/osdep_service.h	/^	MSTAT_FUNC_RX = 0x05 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_RX_IO	include/osdep_service.h	/^	MSTAT_FUNC_RX_IO = 0x03 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_TX	include/osdep_service.h	/^	MSTAT_FUNC_TX = 0x04 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_TX_IO	include/osdep_service.h	/^	MSTAT_FUNC_TX_IO = 0x02 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_UNSPECIFIED	include/osdep_service.h	/^	MSTAT_FUNC_UNSPECIFIED = 0x00 << 8,$/;"	e	enum:mstat_f
-MSTAT_FUNC_str	os_dep/osdep_service.c	/^char *MSTAT_FUNC_str[] = {$/;"	v
-MSTAT_STATUS	include/osdep_service.h	/^} MSTAT_STATUS;$/;"	t	typeref:enum:mstat_status
-MSTAT_TYPE_MAX	include/osdep_service.h	/^	MSTAT_TYPE_MAX = 0x04,$/;"	e	enum:mstat_f
-MSTAT_TYPE_PHY	include/osdep_service.h	/^	MSTAT_TYPE_PHY = 0x01,$/;"	e	enum:mstat_f
-MSTAT_TYPE_SKB	include/osdep_service.h	/^	MSTAT_TYPE_SKB = 0x02,$/;"	e	enum:mstat_f
-MSTAT_TYPE_USB	include/osdep_service.h	/^	MSTAT_TYPE_USB = 0x03,$/;"	e	enum:mstat_f
-MSTAT_TYPE_VIR	include/osdep_service.h	/^	MSTAT_TYPE_VIR = 0x00,$/;"	e	enum:mstat_f
-MSTAT_TYPE_str	os_dep/osdep_service.c	/^char *MSTAT_TYPE_str[] = {$/;"	v
-MacAddr	hal/phydm/phydm_beamforming.h	/^	u1Byte				MacAddr[6];$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-MacAddr	hal/phydm/phydm_beamforming.h	/^	u1Byte	MacAddr[6];			\/*Used to fill Reg6E4 to fill Mac address of CSI report frame.*\/$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-MacAddr_isBcst	include/wifi.h	443;"	d
-MacAddress	include/rtw_mp.h	/^	u8			MacAddress[6];$/;"	m	struct:_RT_PMAC_TX_INFO
-MacAddress	include/wlan_bssdef.h	/^	NDIS_802_11_MAC_ADDRESS  MacAddress;$/;"	m	struct:_WLAN_BSSID_EX
-MacID	hal/phydm/phydm_beamforming.h	/^	u2Byte						MacID;$/;"	m	struct:_RT_BEAMFORM_STAINFO
-MacID	include/rtl8188e_cmd.h	/^	u8 MacID;       \/* MACID *\/$/;"	m	struct:JOINBSSRPT_PARM_88E
-MacID	include/rtl8192e_cmd.h	/^	u8 MacID;       \/* MACID *\/$/;"	m	struct:JOINBSSRPT_PARM_92E
-MacIDValidEntry	include/rtw_recv.h	/^	u32	MacIDValidEntry[2];	\/* 64 bits present 64 entry. *\/$/;"	m	struct:rx_pkt_attrib
-MacId	hal/phydm/phydm_beamforming.h	/^	u2Byte	MacId;				\/*Used to Set Reg42C in IBSS mode. *\/$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-Mac_CCK_Fail	include/hal_data.h	165;"	d
-Mac_CCK_FasleAlarm	include/hal_data.h	166;"	d
-Mac_CCK_OK	include/hal_data.h	164;"	d
-Mac_DropPacket	include/hal_data.h	170;"	d
-Mac_HT_Fail	include/hal_data.h	168;"	d
-Mac_HT_FasleAlarm	include/hal_data.h	169;"	d
-Mac_HT_OK	include/hal_data.h	167;"	d
-Mac_OFDM_Fail	include/hal_data.h	162;"	d
-Mac_OFDM_FasleAlarm	include/hal_data.h	163;"	d
-Mac_OFDM_OK	include/hal_data.h	161;"	d
-MainAntEVM_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	MainAntEVM_Cnt[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainAntEVM_Sum	hal/phydm/phydm_antdiv.h	/^	u4Byte	MainAntEVM_Sum[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainAnt_Cnt	hal/phydm/phydm_antdiv.h	/^	u2Byte	MainAnt_Cnt[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainAnt_Cnt_cck	hal/phydm/phydm_antdiv.h	/^	u2Byte	MainAnt_Cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainAnt_CtrlFrame_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	MainAnt_CtrlFrame_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainAnt_CtrlFrame_Sum	hal/phydm/phydm_antdiv.h	/^	u4Byte	MainAnt_CtrlFrame_Sum;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainAnt_Sum	hal/phydm/phydm_antdiv.h	/^	u2Byte	MainAnt_Sum[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainAnt_Sum_cck	hal/phydm/phydm_antdiv.h	/^	u2Byte	MainAnt_Sum_cck[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainCRC32_Fail_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	MainCRC32_Fail_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MainCRC32_Ok_Cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	MainCRC32_Ok_Cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-Main_MPDU_OK_cnt	hal/phydm/phydm_antdiv.h	/^	u2Byte	Main_MPDU_OK_cnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-Maj	include/rtw_security.h	437;"	d
-MapCharToHexDigit	hal/hal_com.c	/^MapCharToHexDigit($/;"	f
-Master_Slave	core/rtw_cmd.c	/^	u8 Master_Slave:1;$/;"	m	struct:btinfo	file:
-Master_Slave	include/rtw_btcoex.h	/^	u8 Master_Slave:1;$/;"	m	struct:btinfo_8761ATV
-Max	include/drv_types_ce.h	/^	u32			Max;		\/* maximum value allowed *\/$/;"	m	struct:_MP_REG_ENTRY
-Max	include/drv_types_xp.h	/^	u32			Max;		\/* maximum value allowed *\/$/;"	m	struct:_MP_REG_ENTRY
-MaxPower	include/rtw_btcoex.h	/^	u8 MaxPower:1;$/;"	m	struct:btinfo_8761ATV
-MaxSecNum_BT	include/rtw_efuse.h	/^	const u16  MaxSecNum_BT;$/;"	m	struct:_EFUSE_HAL
-MaxSecNum_WiFi	include/rtw_efuse.h	/^	const u16  MaxSecNum_WiFi;$/;"	m	struct:_EFUSE_HAL
-MaximumLatency	include/drv_types_pci.h	/^			u8	MaximumLatency;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-MgntQuery_NssTxRate	hal/hal_mp.c	/^u8 MgntQuery_NssTxRate(u16 Rate)$/;"	f
-Min	include/drv_types_ce.h	/^	u32			Min;			\/* minimum value allowed *\/$/;"	m	struct:_MP_REG_ENTRY
-Min	include/drv_types_xp.h	/^	u32			Min;			\/* minimum value allowed *\/$/;"	m	struct:_MP_REG_ENTRY
-MinMaxRSSI	hal/phydm/phydm_antdiv.h	/^	u4Byte	MinMaxRSSI;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-MinUndecoratedPWDBForDM	include/hal_data.h	/^	int			MinUndecoratedPWDBForDM;$/;"	m	struct:hal_com_data
-MinimumGrant	include/drv_types_pci.h	/^			u8	MinimumGrant;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-Minute	include/rtl8188e_hal.h	/^	u8		Minute;	\/* Release time Minute field *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Minute	include/rtl8188f_hal.h	/^	u8		Minute;	\/* Release time Minute field *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Minute	include/rtl8703b_hal.h	/^	u8		Minute;	\/* Release time Minute field *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Minute	include/rtl8723b_hal.h	/^	u8		Minute;	\/* Release time Minute field *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Minute	include/rtl8723d_hal.h	/^	u8		Minute;	\/* Release time Minute field *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Mk16	core/rtw_security.c	481;"	d	file:
-Mode	include/rtl8188e_cmd.h	/^	u8 Mode;\/* 0:Active,1:LPS,2:WMMPS *\/$/;"	m	struct:_SETPWRMODE_PARM
-Mode	include/rtl8192e_cmd.h	/^	u8 Mode;\/* 0:Active,1:LPS,2:WMMPS *\/$/;"	m	struct:_SETPWRMODE_PARM
-Mode	include/rtw_mp.h	/^	u8			Mode:3;				\/* 0: Packet TX 3:Continuous TX *\/$/;"	m	struct:_RT_PMAC_TX_INFO
-Modify_TxAGC_Flag_PathA	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathA;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathA	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathA;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathA	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathA;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathA_CCK	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathA_CCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathA_CCK	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathA_CCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathA_CCK	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathA_CCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathB	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathB;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathB	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathB;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathB	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathB;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathC	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathC;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathC	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathC;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathC	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathC;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathD	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathD;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathD	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathD;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Flag_PathD	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN			Modify_TxAGC_Flag_PathD;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Value	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte			Modify_TxAGC_Value;       \/*Remnat compensate value at TxAGC *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Value	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte			Modify_TxAGC_Value;       \/*Remnat compensate value at TxAGC *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Value	hal/phydm/phydm_powertracking_win.h	/^	s1Byte			Modify_TxAGC_Value;       \/*Remnat compensate value at TxAGC *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Value_CCK	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte Modify_TxAGC_Value_CCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Value_CCK	hal/phydm/phydm_powertracking_win.h	/^	s1Byte Modify_TxAGC_Value_CCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Value_OFDM	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte Modify_TxAGC_Value_OFDM;$/;"	m	struct:ODM_RF_Calibration_Structure
-Modify_TxAGC_Value_OFDM	hal/phydm/phydm_powertracking_win.h	/^	s1Byte Modify_TxAGC_Value_OFDM;$/;"	m	struct:ODM_RF_Calibration_Structure
-Monitor_flag	hal/phydm/phydm.h	/^	u1Byte	Monitor_flag;$/;"	m	struct:_Dynamic_Primary_CCA
-Month	include/rtl8188e_hal.h	/^	u8		Month;	\/* Release time Month field *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Month	include/rtl8188f_hal.h	/^	u8		Month;	\/* Release time Month field *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Month	include/rtl8703b_hal.h	/^	u8		Month;	\/* Release time Month field *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Month	include/rtl8723b_hal.h	/^	u8		Month;	\/* Release time Month field *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Month	include/rtl8723d_hal.h	/^	u8		Month;	\/* Release time Month field *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-MptAckCounter	include/rtw_mp.h	/^	ULONG			MptAckCounter;$/;"	m	struct:_MPT_CONTEXT
-MptActType	include/rtw_mp.h	/^	ULONG			MptActType;	\/* Type of action performed in CurrMptAct. *\/$/;"	m	struct:_MPT_CONTEXT
-MptBandWidth	include/rtw_mp.h	/^	ULONG			MptBandWidth;		\/* bandwidth to switch. *\/$/;"	m	struct:_MPT_CONTEXT
-MptBtC2hEvent	include/rtw_mp.h	/^	BOOLEAN		MptBtC2hEvent;$/;"	m	struct:_MPT_CONTEXT
-MptChannelToSw	include/rtw_mp.h	/^	u8			MptChannelToSw;	\/* Channel to switch. *\/$/;"	m	struct:_MPT_CONTEXT
-MptCtx	include/rtw_mp.h	/^	MPT_CONTEXT MptCtx;$/;"	m	struct:mp_priv
-MptH2cRspEvent	include/rtw_mp.h	/^	BOOLEAN		MptH2cRspEvent;$/;"	m	struct:_MPT_CONTEXT
-MptInitGainToSet	include/rtw_mp.h	/^	u8			MptInitGainToSet;	\/* Initial gain to set. *\/$/;"	m	struct:_MPT_CONTEXT
-MptIoOffset	include/rtw_mp.h	/^	ULONG			MptIoOffset;$/;"	m	struct:_MPT_CONTEXT
-MptIoValue	include/rtw_mp.h	/^	ULONG			MptIoValue;$/;"	m	struct:_MPT_CONTEXT
-MptRCR	include/rtw_mp.h	/^	ULONG			MptRCR;$/;"	m	struct:_MPT_CONTEXT
-MptRateIndex	include/rtw_mp.h	/^	ULONG			MptRateIndex;		\/* rate index. *\/$/;"	m	struct:_MPT_CONTEXT
-MptRfPath	include/rtw_mp.h	/^	ULONG			MptRfPath;$/;"	m	struct:_MPT_CONTEXT
-MptRxCrcErrCnt	include/rtw_mp.h	/^	ULONG			MptRxCrcErrCnt;$/;"	m	struct:_MPT_CONTEXT
-MptRxOkCnt	include/rtw_mp.h	/^	ULONG			MptRxOkCnt;$/;"	m	struct:_MPT_CONTEXT
-MptTestItem	include/rtw_mp.h	/^	ULONG			MptTestItem;$/;"	m	struct:_MPT_CONTEXT
-MptTestStart	include/rtw_mp.h	/^	ULONG			MptTestStart;$/;"	m	struct:_MPT_CONTEXT
-MptToMgntRate	core/rtw_mp.c	/^MptToMgntRate($/;"	f
-MptWirelessModeToSw	include/rtw_mp.h	/^	WIRELESS_MODE		MptWirelessModeToSw;	\/* Wireless mode to switch. *\/$/;"	m	struct:_MPT_CONTEXT
-MultiFunc	include/hal_data.h	/^	RT_MULTI_FUNC		MultiFunc; \/* For multi-function consideration. *\/$/;"	m	struct:hal_com_data
-MyMacAddr	hal/phydm/phydm_beamforming.h	/^	u1Byte						MyMacAddr[6];$/;"	m	struct:_RT_BEAMFORM_STAINFO
-MyMacAddr	hal/phydm/phydm_beamforming.h	/^	u1Byte				MyMacAddr[6];$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-MyMacAddr	hal/phydm/phydm_beamforming.h	/^	u1Byte	MyMacAddr[6];$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-NAPI_DISABLE	include/drv_types.h	/^	NAPI_DISABLE = 0,$/;"	e	enum:_NAPI_STATE
-NAPI_ENABLE	include/drv_types.h	/^	NAPI_ENABLE = 1,$/;"	e	enum:_NAPI_STATE
-NAT25_AGEING_TIME	include/rtw_br_ext.h	37;"	d
-NAT25_APPLE	core/rtw_br_ext.c	66;"	d	file:
-NAT25_CHECK	include/rtw_br_ext.h	/^	NAT25_CHECK,$/;"	e	enum:NAT25_METHOD
-NAT25_HASH_BITS	include/rtw_br_ext.h	35;"	d
-NAT25_HASH_SIZE	include/rtw_br_ext.h	36;"	d
-NAT25_INSERT	include/rtw_br_ext.h	/^	NAT25_INSERT,$/;"	e	enum:NAT25_METHOD
-NAT25_IPV4	core/rtw_br_ext.c	63;"	d	file:
-NAT25_IPV6	core/rtw_br_ext.c	64;"	d	file:
-NAT25_IPX	core/rtw_br_ext.c	65;"	d	file:
-NAT25_LOOKUP	include/rtw_br_ext.h	/^	NAT25_LOOKUP,$/;"	e	enum:NAT25_METHOD
-NAT25_MAX	include/rtw_br_ext.h	/^	NAT25_MAX$/;"	e	enum:NAT25_METHOD
-NAT25_METHOD	include/rtw_br_ext.h	/^enum NAT25_METHOD {$/;"	g
-NAT25_MIN	include/rtw_br_ext.h	/^	NAT25_MIN,$/;"	e	enum:NAT25_METHOD
-NAT25_PARSE	include/rtw_br_ext.h	/^	NAT25_PARSE,$/;"	e	enum:NAT25_METHOD
-NAT25_PPPOE	core/rtw_br_ext.c	67;"	d	file:
-NAVUSEHDR	include/rtl8188e_xmit.h	54;"	d
-NAVUSEHDR	include/rtl8192e_xmit.h	159;"	d
-NAVUSEHDR	include/rtl8812a_xmit.h	52;"	d
-NBI_DISABLE	hal/phydm/phydm.h	80;"	d
-NBI_ENABLE	hal/phydm/phydm.h	79;"	d
-NBI_TABLE_SIZE_128	hal/phydm/phydm.h	82;"	d
-NBI_TABLE_SIZE_256	hal/phydm/phydm.h	83;"	d
-NDEV_ARG	include/osdep_service_bsd.h	738;"	d
-NDEV_ARG	include/osdep_service_ce.h	180;"	d
-NDEV_ARG	include/osdep_service_linux.h	426;"	d
-NDEV_ARG	include/osdep_service_xp.h	191;"	d
-NDEV_FMT	include/osdep_service_bsd.h	737;"	d
-NDEV_FMT	include/osdep_service_ce.h	179;"	d
-NDEV_FMT	include/osdep_service_linux.h	425;"	d
-NDEV_FMT	include/osdep_service_xp.h	190;"	d
-NDIS_802_11_AI_REQFI	include/wlan_bssdef.h	/^} NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;$/;"	t	typeref:struct:_NDIS_802_11_AI_REQFI
-NDIS_802_11_AI_REQFI_CAPABILITIES	include/wlan_bssdef.h	172;"	d
-NDIS_802_11_AI_REQFI_CAPABILITIES	include/wlan_bssdef.h	418;"	d
-NDIS_802_11_AI_REQFI_CURRENTAPADDRESS	include/wlan_bssdef.h	174;"	d
-NDIS_802_11_AI_REQFI_CURRENTAPADDRESS	include/wlan_bssdef.h	420;"	d
-NDIS_802_11_AI_REQFI_LISTENINTERVAL	include/wlan_bssdef.h	173;"	d
-NDIS_802_11_AI_REQFI_LISTENINTERVAL	include/wlan_bssdef.h	419;"	d
-NDIS_802_11_AI_RESFI	include/wlan_bssdef.h	/^} NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;$/;"	t	typeref:struct:_NDIS_802_11_AI_RESFI
-NDIS_802_11_AI_RESFI_ASSOCIATIONID	include/wlan_bssdef.h	178;"	d
-NDIS_802_11_AI_RESFI_ASSOCIATIONID	include/wlan_bssdef.h	424;"	d
-NDIS_802_11_AI_RESFI_CAPABILITIES	include/wlan_bssdef.h	176;"	d
-NDIS_802_11_AI_RESFI_CAPABILITIES	include/wlan_bssdef.h	422;"	d
-NDIS_802_11_AI_RESFI_STATUSCODE	include/wlan_bssdef.h	177;"	d
-NDIS_802_11_AI_RESFI_STATUSCODE	include/wlan_bssdef.h	423;"	d
-NDIS_802_11_ASSOCIATION_INFORMATION	include/wlan_bssdef.h	/^} NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;$/;"	t	typeref:struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-NDIS_802_11_AUTHENTICATION_ENCRYPTION	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_ENCRYPTION, *PNDIS_802_11_AUTHENTICATION_ENCRYPTION;$/;"	t	typeref:struct:_NDIS_802_11_AUTHENTICATION_ENCRYPTION
-NDIS_802_11_AUTHENTICATION_EVENT	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_EVENT, *PNDIS_802_11_AUTHENTICATION_EVENT;$/;"	t	typeref:struct:_NDIS_802_11_AUTHENTICATION_EVENT
-NDIS_802_11_AUTHENTICATION_MODE	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_MODE, *PNDIS_802_11_AUTHENTICATION_MODE;$/;"	t	typeref:enum:_NDIS_802_11_AUTHENTICATION_MODE
-NDIS_802_11_AUTHENTICATION_REQUEST	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_REQUEST, *PNDIS_802_11_AUTHENTICATION_REQUEST;$/;"	t	typeref:struct:_NDIS_802_11_AUTHENTICATION_REQUEST
-NDIS_802_11_AUTH_REQUEST_AUTH_FIELDS	include/wlan_bssdef.h	250;"	d
-NDIS_802_11_AUTH_REQUEST_AUTH_FIELDS	include/wlan_bssdef.h	496;"	d
-NDIS_802_11_AUTH_REQUEST_GROUP_ERROR	include/wlan_bssdef.h	254;"	d
-NDIS_802_11_AUTH_REQUEST_GROUP_ERROR	include/wlan_bssdef.h	500;"	d
-NDIS_802_11_AUTH_REQUEST_KEYUPDATE	include/wlan_bssdef.h	252;"	d
-NDIS_802_11_AUTH_REQUEST_KEYUPDATE	include/wlan_bssdef.h	498;"	d
-NDIS_802_11_AUTH_REQUEST_PAIRWISE_ERROR	include/wlan_bssdef.h	253;"	d
-NDIS_802_11_AUTH_REQUEST_PAIRWISE_ERROR	include/wlan_bssdef.h	499;"	d
-NDIS_802_11_AUTH_REQUEST_REAUTH	include/wlan_bssdef.h	251;"	d
-NDIS_802_11_AUTH_REQUEST_REAUTH	include/wlan_bssdef.h	497;"	d
-NDIS_802_11_CAPABILITY	include/wlan_bssdef.h	/^} NDIS_802_11_CAPABILITY, *PNDIS_802_11_CAPABILITY;$/;"	t	typeref:struct:_NDIS_802_11_CAPABILITY
-NDIS_802_11_CONFIGURATION	include/wlan_bssdef.h	/^} NDIS_802_11_CONFIGURATION, *PNDIS_802_11_CONFIGURATION;$/;"	t	typeref:struct:_NDIS_802_11_CONFIGURATION
-NDIS_802_11_CONFIGURATION_FH	include/wlan_bssdef.h	/^} NDIS_802_11_CONFIGURATION_FH, *PNDIS_802_11_CONFIGURATION_FH;$/;"	t	typeref:struct:_NDIS_802_11_CONFIGURATION_FH
-NDIS_802_11_ENCRYPTION_STATUS	include/wlan_bssdef.h	/^NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;$/;"	t	typeref:enum:_NDIS_802_11_WEP_STATUS
-NDIS_802_11_FIXED_IEs	include/wlan_bssdef.h	/^} NDIS_802_11_FIXED_IEs, *PNDIS_802_11_FIXED_IEs;$/;"	t	typeref:struct:_NDIS_802_11_FIXED_IEs
-NDIS_802_11_KEY	include/wlan_bssdef.h	/^} NDIS_802_11_KEY, *PNDIS_802_11_KEY;$/;"	t	typeref:struct:_NDIS_802_11_KEY
-NDIS_802_11_KEY_INDEX	include/wlan_bssdef.h	/^typedef  ULONG  NDIS_802_11_KEY_INDEX;$/;"	t
-NDIS_802_11_KEY_RSC	include/wlan_bssdef.h	/^typedef unsigned long long NDIS_802_11_KEY_RSC;$/;"	t
-NDIS_802_11_LENGTH_RATES	include/wlan_bssdef.h	279;"	d
-NDIS_802_11_LENGTH_RATES	include/wlan_bssdef.h	30;"	d
-NDIS_802_11_LENGTH_RATES_EX	include/wlan_bssdef.h	280;"	d
-NDIS_802_11_LENGTH_RATES_EX	include/wlan_bssdef.h	31;"	d
-NDIS_802_11_LENGTH_SSID	include/wlan_bssdef.h	278;"	d
-NDIS_802_11_LENGTH_SSID	include/wlan_bssdef.h	29;"	d
-NDIS_802_11_MAC_ADDRESS	include/wlan_bssdef.h	/^typedef unsigned char   NDIS_802_11_MAC_ADDRESS[6];$/;"	t
-NDIS_802_11_NETWORK_INFRASTRUCTURE	include/wlan_bssdef.h	/^} NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;$/;"	t	typeref:enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-NDIS_802_11_NETWORK_TYPE	include/wlan_bssdef.h	/^} NDIS_802_11_NETWORK_TYPE, *PNDIS_802_11_NETWORK_TYPE;$/;"	t	typeref:enum:_NDIS_802_11_NETWORK_TYPE
-NDIS_802_11_PMKID	include/rtw_ioctl_set.h	/^} NDIS_802_11_PMKID, *PNDIS_802_11_PMKID;$/;"	t	typeref:struct:_NDIS_802_11_PMKID
-NDIS_802_11_PMKID_CANDIDATE_LIST	include/wlan_bssdef.h	/^} NDIS_802_11_PMKID_CANDIDATE_LIST, *PNDIS_802_11_PMKID_CANDIDATE_LIST;$/;"	t	typeref:struct:_NDIS_802_11_PMKID_CANDIDATE_LIST
-NDIS_802_11_PMKID_VALUE	include/rtw_ioctl_set.h	/^typedef u8 NDIS_802_11_PMKID_VALUE[16];$/;"	t
-NDIS_802_11_RATES	include/wlan_bssdef.h	/^typedef unsigned char   NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES];        \/* Set of 8 data rates *\/$/;"	t
-NDIS_802_11_RATES_EX	include/wlan_bssdef.h	/^typedef unsigned char   NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX];  \/* Set of 16 data rates *\/$/;"	t
-NDIS_802_11_RELOAD_DEFAULTS	include/wlan_bssdef.h	/^} NDIS_802_11_RELOAD_DEFAULTS, *PNDIS_802_11_RELOAD_DEFAULTS;$/;"	t	typeref:enum:_NDIS_802_11_RELOAD_DEFAULTS
-NDIS_802_11_REMOVE_KEY	include/wlan_bssdef.h	/^} NDIS_802_11_REMOVE_KEY, *PNDIS_802_11_REMOVE_KEY;$/;"	t	typeref:struct:_NDIS_802_11_REMOVE_KEY
-NDIS_802_11_RSSI	include/wlan_bssdef.h	/^typedef long    		NDIS_802_11_RSSI;           \/* in dBm *\/$/;"	t
-NDIS_802_11_SSID	include/wlan_bssdef.h	/^} NDIS_802_11_SSID, *PNDIS_802_11_SSID;$/;"	t	typeref:struct:_NDIS_802_11_SSID
-NDIS_802_11_STATUS_INDICATION	include/wlan_bssdef.h	/^} NDIS_802_11_STATUS_INDICATION, *PNDIS_802_11_STATUS_INDICATION;$/;"	t	typeref:struct:_NDIS_802_11_STATUS_INDICATION
-NDIS_802_11_STATUS_TYPE	include/wlan_bssdef.h	/^} NDIS_802_11_STATUS_TYPE, *PNDIS_802_11_STATUS_TYPE;$/;"	t	typeref:enum:_NDIS_802_11_STATUS_TYPE
-NDIS_802_11_TEST	include/wlan_bssdef.h	/^} NDIS_802_11_TEST, *PNDIS_802_11_TEST;$/;"	t	typeref:struct:_NDIS_802_11_TEST
-NDIS_802_11_VARIABLE_IEs	include/wlan_bssdef.h	/^} NDIS_802_11_VARIABLE_IEs, *PNDIS_802_11_VARIABLE_IEs;$/;"	t	typeref:struct:_NDIS_802_11_VARIABLE_IEs
-NDIS_802_11_WEP	include/wlan_bssdef.h	/^} NDIS_802_11_WEP, *PNDIS_802_11_WEP;$/;"	t	typeref:struct:_NDIS_802_11_WEP
-NDIS_802_11_WEP_STATUS	include/wlan_bssdef.h	/^} NDIS_802_11_WEP_STATUS, *PNDIS_802_11_WEP_STATUS,$/;"	t	typeref:enum:_NDIS_802_11_WEP_STATUS
-NDIS_MAJOR_VERSION	include/basic_types.h	59;"	d
-NDIS_MAJOR_VERSION	include/basic_types.h	66;"	d
-NDIS_MINOR_VERSION	include/basic_types.h	60;"	d
-NDIS_MINOR_VERSION	include/basic_types.h	67;"	d
-NDIS_OID	include/basic_types.h	136;"	d
-NDIS_OID	include/basic_types.h	88;"	d
-NDIS_STATUS	include/basic_types.h	137;"	d
-NDIS_STATUS	include/basic_types.h	89;"	d
-NDIS_STATUS_AAL_PARAMS_UNSUPPORTED	include/rtw_ioctl.h	81;"	d
-NDIS_STATUS_ADAPTER_NOT_FOUND	include/rtw_ioctl.h	45;"	d
-NDIS_STATUS_ADAPTER_NOT_OPEN	include/rtw_ioctl.h	58;"	d
-NDIS_STATUS_ADAPTER_NOT_READY	include/rtw_ioctl.h	57;"	d
-NDIS_STATUS_ADAPTER_REMOVED	include/rtw_ioctl.h	64;"	d
-NDIS_STATUS_ALREADY_MAPPED	include/rtw_ioctl.h	69;"	d
-NDIS_STATUS_BAD_CHARACTERISTICS	include/rtw_ioctl.h	44;"	d
-NDIS_STATUS_BAD_VERSION	include/rtw_ioctl.h	43;"	d
-NDIS_STATUS_BUFFER_TOO_SHORT	include/rtw_ioctl.h	62;"	d
-NDIS_STATUS_CALL_ACTIVE	include/rtw_ioctl.h	38;"	d
-NDIS_STATUS_CELLRATE_NOT_AVAILABLE	include/rtw_ioctl.h	79;"	d
-NDIS_STATUS_CLOSING	include/rtw_ioctl.h	42;"	d
-NDIS_STATUS_CLOSING_INDICATING	include/rtw_ioctl.h	53;"	d
-NDIS_STATUS_DEST_OUT_OF_ORDER	include/rtw_ioctl.h	77;"	d
-NDIS_STATUS_DEVICE_FAILED	include/rtw_ioctl.h	47;"	d
-NDIS_STATUS_ERROR_READING_FILE	include/rtw_ioctl.h	68;"	d
-NDIS_STATUS_FAILURE	include/rtw_ioctl.h	40;"	d
-NDIS_STATUS_FILE_NOT_FOUND	include/rtw_ioctl.h	67;"	d
-NDIS_STATUS_GROUP_ADDRESS_IN_USE	include/rtw_ioctl.h	66;"	d
-NDIS_STATUS_INCOMPATABLE_QOS	include/rtw_ioctl.h	80;"	d
-NDIS_STATUS_INVALID_ADDRESS	include/rtw_ioctl.h	75;"	d
-NDIS_STATUS_INVALID_DATA	include/rtw_ioctl.h	61;"	d
-NDIS_STATUS_INVALID_LENGTH	include/rtw_ioctl.h	60;"	d
-NDIS_STATUS_INVALID_OID	include/rtw_ioctl.h	63;"	d
-NDIS_STATUS_INVALID_PACKET	include/rtw_ioctl.h	55;"	d
-NDIS_STATUS_INVALID_SAP	include/rtw_ioctl.h	73;"	d
-NDIS_STATUS_MULTICAST_EXISTS	include/rtw_ioctl.h	49;"	d
-NDIS_STATUS_MULTICAST_FULL	include/rtw_ioctl.h	48;"	d
-NDIS_STATUS_MULTICAST_NOT_FOUND	include/rtw_ioctl.h	50;"	d
-NDIS_STATUS_NOT_ACCEPTED	include/rtw_ioctl.h	37;"	d
-NDIS_STATUS_NOT_COPIED	include/rtw_ioctl.h	36;"	d
-NDIS_STATUS_NOT_INDICATING	include/rtw_ioctl.h	59;"	d
-NDIS_STATUS_NOT_RECOGNIZED	include/rtw_ioctl.h	35;"	d
-NDIS_STATUS_NOT_SUPPORTED	include/rtw_ioctl.h	54;"	d
-NDIS_STATUS_NO_CABLE	include/rtw_ioctl.h	71;"	d
-NDIS_STATUS_NO_ROUTE_TO_DESTINATION	include/rtw_ioctl.h	82;"	d
-NDIS_STATUS_OPEN_FAILED	include/rtw_ioctl.h	46;"	d
-NDIS_STATUS_OPEN_LIST_FULL	include/rtw_ioctl.h	56;"	d
-NDIS_STATUS_PENDING	include/rtw_ioctl.h	34;"	d
-NDIS_STATUS_REQUEST_ABORTED	include/rtw_ioctl.h	51;"	d
-NDIS_STATUS_RESET_IN_PROGRESS	include/rtw_ioctl.h	52;"	d
-NDIS_STATUS_RESOURCES	include/rtw_ioctl.h	41;"	d
-NDIS_STATUS_RESOURCE_CONFLICT	include/rtw_ioctl.h	70;"	d
-NDIS_STATUS_SAP_IN_USE	include/rtw_ioctl.h	74;"	d
-NDIS_STATUS_SUCCESS	include/rtw_ioctl.h	33;"	d
-NDIS_STATUS_UNSUPPORTED_MEDIA	include/rtw_ioctl.h	65;"	d
-NDIS_STATUS_VC_NOT_ACTIVATED	include/rtw_ioctl.h	76;"	d
-NDIS_STATUS_VC_NOT_AVAILABLE	include/rtw_ioctl.h	78;"	d
-NDP_sound	include/rtw_mp.h	/^	u8			NDP_sound:1;$/;"	m	struct:_RT_PMAC_TX_INFO
-NET80211_TU_TO_US	include/ieee80211.h	39;"	d
-NETLINK_SOCKET_OK	include/rtw_btcoex.h	74;"	d
-NETLINK_USER	include/rtw_btcoex.h	70;"	d
-NETWORK_EMPTY_ESSID	include/ieee80211.h	1362;"	d
-NETWORK_HAS_CCK	include/ieee80211.h	1364;"	d
-NETWORK_HAS_OFDM	include/ieee80211.h	1363;"	d
-NETWORK_QUEUE_SZ	include/rtw_event.h	126;"	d
-NETWORK_TYPE	include/ieee80211.h	/^enum NETWORK_TYPE {$/;"	g
-NHMWait	hal/phydm/phydm_adaptivity.h	/^	u1Byte			NHMWait;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-NHM_Cnt	hal/phydm/phydm_acs.h	/^    u1Byte              NHM_Cnt[14][11];$/;"	m	struct:_ACS_
-NHM_EXCLUDE_CCA	hal/phydm/phydm_ccx.h	/^	NHM_EXCLUDE_CCA,$/;"	e	enum:NHM_inexclude_cca
-NHM_EXCLUDE_TXON	hal/phydm/phydm_ccx.h	/^	NHM_EXCLUDE_TXON,$/;"	e	enum:NHM_inexclude_txon
-NHM_INCLUDE_CCA	hal/phydm/phydm_ccx.h	/^	NHM_INCLUDE_CCA$/;"	e	enum:NHM_inexclude_cca
-NHM_INCLUDE_TXON	hal/phydm/phydm_ccx.h	/^	NHM_INCLUDE_TXON$/;"	e	enum:NHM_inexclude_txon
-NHM_INEXCLUDE_CCA	hal/phydm/phydm_ccx.h	/^}NHM_INEXCLUDE_CCA;$/;"	t	typeref:enum:NHM_inexclude_cca
-NHM_INEXCLUDE_TXON	hal/phydm/phydm_ccx.h	/^}NHM_INEXCLUDE_TXON;$/;"	t	typeref:enum:NHM_inexclude_txon
-NHM_cnt_0	hal/phydm/phydm.h	/^	u2Byte			NHM_cnt_0;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-NHM_cnt_1	hal/phydm/phydm.h	/^	u2Byte			NHM_cnt_1;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-NHM_duration	hal/phydm/phydm_ccx.h	/^	u2Byte		NHM_duration;$/;"	m	struct:_CCX_INFO
-NHM_inexclude_cca	hal/phydm/phydm_ccx.h	/^	NHM_INEXCLUDE_CCA		NHM_inexclude_cca;$/;"	m	struct:_CCX_INFO
-NHM_inexclude_cca	hal/phydm/phydm_ccx.h	/^typedef enum NHM_inexclude_cca {$/;"	g
-NHM_inexclude_cca_restore	hal/phydm/phydm_ccx.h	/^	NHM_INEXCLUDE_CCA		NHM_inexclude_cca_restore;$/;"	m	struct:_CCX_INFO
-NHM_inexclude_txon	hal/phydm/phydm_ccx.h	/^	NHM_INEXCLUDE_TXON		NHM_inexclude_txon;$/;"	m	struct:_CCX_INFO
-NHM_inexclude_txon	hal/phydm/phydm_ccx.h	/^typedef enum NHM_inexclude_txon {$/;"	g
-NHM_inexclude_txon_restore	hal/phydm/phydm_ccx.h	/^	NHM_INEXCLUDE_TXON		NHM_inexclude_txon_restore;$/;"	m	struct:_CCX_INFO
-NHM_period	hal/phydm/phydm_ccx.h	/^	u2Byte					NHM_period;				\/* 4us per unit *\/$/;"	m	struct:_CCX_INFO
-NHM_period_restore	hal/phydm/phydm_ccx.h	/^	u2Byte					NHM_period_restore;				\/* 4us per unit *\/$/;"	m	struct:_CCX_INFO
-NHM_result	hal/phydm/phydm_ccx.h	/^	u1Byte		NHM_result[12];$/;"	m	struct:_CCX_INFO
-NHM_th	hal/phydm/phydm_ccx.h	/^	u1Byte					NHM_th[11];$/;"	m	struct:_CCX_INFO
-NHM_th_restore	hal/phydm/phydm_ccx.h	/^	u1Byte					NHM_th_restore[11];$/;"	m	struct:_CCX_INFO
-NIC_HEADER_SIZE	include/drv_types_ce.h	37;"	d
-NIC_HEADER_SIZE	include/drv_types_xp.h	35;"	d
-NIC_MAX_PACKET_SIZE	include/drv_types_ce.h	38;"	d
-NIC_MAX_PACKET_SIZE	include/drv_types_ce.h	41;"	d
-NIC_MAX_PACKET_SIZE	include/drv_types_xp.h	36;"	d
-NIC_MAX_PACKET_SIZE	include/drv_types_xp.h	39;"	d
-NIC_MAX_SEND_PACKETS	include/drv_types_ce.h	39;"	d
-NIC_MAX_SEND_PACKETS	include/drv_types_xp.h	37;"	d
-NIC_VENDOR_DRIVER_VERSION	include/drv_types_ce.h	40;"	d
-NIC_VENDOR_DRIVER_VERSION	include/drv_types_xp.h	38;"	d
-NL80211_WAPI_VERSION_1	os_dep/linux/ioctl_cfg80211.c	60;"	d	file:
-NOA_DESC_SEL_0	include/hal_com_reg.h	1520;"	d
-NOA_DESC_SEL_1	include/hal_com_reg.h	1521;"	d
-NOISY_AP_NUM_THRESH_8192E	hal/btc/HalBtc8192e2Ant.h	20;"	d
-NONE	hal/phydm/phydm.h	76;"	d
-NONE_VCS	include/wlan_bssdef.h	/^	NONE_VCS,$/;"	e	enum:VCS_TYPE
-NONE_WK_CID	include/rtw_cmd.h	/^	NONE_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-NON_EXPLICIT_ACK	include/ieee80211.h	535;"	d
-NON_OCP_TIME_MS	include/rtw_mlme_ext.h	502;"	d
-NON_SHORT_SLOT_TIME	include/rtw_rf.h	34;"	d
-NORMAL_ACK	include/ieee80211.h	533;"	d
-NORMAL_CHIP	include/HalVerDef.h	/^	NORMAL_CHIP	=	1,$/;"	e	enum:tag_HAL_CHIP_Type_Definition
-NORMAL_EXEC	hal/btc/HalBtcOutSrc.h	19;"	d
-NORMAL_PAGE_NUM_EPQ_8192E	include/rtl8192e_hal.h	172;"	d
-NORMAL_PAGE_NUM_HPQ_8188F	include/rtl8188f_hal.h	150;"	d
-NORMAL_PAGE_NUM_HPQ_8192E	include/rtl8192e_hal.h	169;"	d
-NORMAL_PAGE_NUM_HPQ_8703B	include/rtl8703b_hal.h	152;"	d
-NORMAL_PAGE_NUM_HPQ_8723B	include/rtl8723b_hal.h	152;"	d
-NORMAL_PAGE_NUM_HPQ_8723D	include/rtl8723d_hal.h	159;"	d
-NORMAL_PAGE_NUM_HPQ_8812	include/rtl8812a_hal.h	171;"	d
-NORMAL_PAGE_NUM_HPQ_8821	include/rtl8812a_hal.h	218;"	d
-NORMAL_PAGE_NUM_HPQ_88E	include/rtl8188e_hal.h	168;"	d
-NORMAL_PAGE_NUM_LPQ_8188F	include/rtl8188f_hal.h	151;"	d
-NORMAL_PAGE_NUM_LPQ_8192E	include/rtl8192e_hal.h	170;"	d
-NORMAL_PAGE_NUM_LPQ_8703B	include/rtl8703b_hal.h	153;"	d
-NORMAL_PAGE_NUM_LPQ_8723B	include/rtl8723b_hal.h	153;"	d
-NORMAL_PAGE_NUM_LPQ_8723D	include/rtl8723d_hal.h	160;"	d
-NORMAL_PAGE_NUM_LPQ_8812	include/rtl8812a_hal.h	170;"	d
-NORMAL_PAGE_NUM_LPQ_8821	include/rtl8812a_hal.h	217;"	d
-NORMAL_PAGE_NUM_LPQ_88E	include/rtl8188e_hal.h	169;"	d
-NORMAL_PAGE_NUM_NPQ_8188F	include/rtl8188f_hal.h	152;"	d
-NORMAL_PAGE_NUM_NPQ_8192E	include/rtl8192e_hal.h	171;"	d
-NORMAL_PAGE_NUM_NPQ_8703B	include/rtl8703b_hal.h	154;"	d
-NORMAL_PAGE_NUM_NPQ_8723B	include/rtl8723b_hal.h	154;"	d
-NORMAL_PAGE_NUM_NPQ_8723D	include/rtl8723d_hal.h	161;"	d
-NORMAL_PAGE_NUM_NPQ_8812	include/rtl8812a_hal.h	172;"	d
-NORMAL_PAGE_NUM_NPQ_8821	include/rtl8812a_hal.h	219;"	d
-NORMAL_PAGE_NUM_NPQ_88E	include/rtl8188e_hal.h	170;"	d
-NORMAL_QUEUE	hal/phydm/phydm_beamforming.h	34;"	d
-NORMAL_RX	include/rtw_recv.h	/^	NORMAL_RX,\/* Normal rx packet *\/$/;"	e	enum:_RX_PACKET_TYPE
-NORMAL_STATE_AUX	hal/phydm/phydm_antdiv.h	101;"	d
-NORMAL_STATE_MIAN	hal/phydm/phydm_antdiv.h	100;"	d
-NOTASSOCIATED	core/rtw_ioctl_rtl.c	/^	NOTASSOCIATED$/;"	e	enum:_CONNECT_STATE_	file:
-NO_ACK	include/ieee80211.h	534;"	d
-NO_ANTDIV	hal/phydm/phydm_antdiv.h	/^	NO_ANTDIV			= 0xFF,	$/;"	e	enum:_ANT_DIV_TYPE
-NO_FIX_TX_ANT	hal/phydm/phydm_antdiv.h	54;"	d
-NO_LIMIT	include/wlan_bssdef.h	/^	NO_LIMIT,$/;"	e	enum:UAPSD_MAX_SP
-NPQ_PGNUM_8814A	include/rtl8814a_hal.h	137;"	d
-NPQ_PGNUM_8814A	include/rtl8814a_hal.h	143;"	d
-NR_MP_XMITFRAME	include/rtw_mp.h	26;"	d
-NR_PREALLOC_RECV_SKB	include/rtw_recv.h	49;"	d
-NR_PREALLOC_RECV_SKB	include/rtw_recv.h	51;"	d
-NR_RECVBUFF	include/rtw_recv.h	25;"	d
-NR_RECVBUFF	include/rtw_recv.h	27;"	d
-NR_RECVBUFF	include/rtw_recv.h	31;"	d
-NR_RECVBUFF	include/rtw_recv.h	33;"	d
-NR_RECVBUFF	include/rtw_recv.h	38;"	d
-NR_RECVBUFF	include/rtw_recv.h	41;"	d
-NR_RECVBUFF	include/rtw_recv.h	43;"	d
-NR_RECVBUFF	include/rtw_recv.h	45;"	d
-NR_RECVFRAME	include/rtw_recv.h	59;"	d
-NR_XMITBUFF	include/rtw_xmit.h	34;"	d
-NR_XMITBUFF	include/rtw_xmit.h	37;"	d
-NR_XMITBUFF	include/rtw_xmit.h	55;"	d
-NR_XMITBUFF	include/rtw_xmit.h	57;"	d
-NR_XMITBUFF	include/rtw_xmit.h	61;"	d
-NR_XMITFRAME	include/xmit_osdep.h	44;"	d
-NR_XMITFRAME	include/xmit_osdep.h	46;"	d
-NR_XMITFRAME	include/xmit_osdep.h	60;"	d
-NR_XMITFRAME	include/xmit_osdep.h	67;"	d
-NR_XMIT_EXTBUFF	include/rtw_xmit.h	82;"	d
-NR_XMIT_EXTBUFF	include/rtw_xmit.h	84;"	d
-NSS_NUM_8188F	include/rtl8188f_spec.h	298;"	d
-NSS_NUM_8192E	include/rtl8192e_spec.h	324;"	d
-NSS_NUM_8703B	include/rtl8703b_spec.h	475;"	d
-NSS_NUM_8723B	include/rtl8723b_spec.h	291;"	d
-NSS_NUM_8723D	include/rtl8723d_spec.h	452;"	d
-NSS_NUM_8812A	include/rtl8812a_spec.h	267;"	d
-NSS_NUM_8814A	include/rtl8814a_spec.h	646;"	d
-NSS_NUM_8821A	include/rtl8821a_spec.h	103;"	d
-NSS_NUM_88E	include/rtl8188e_spec.h	153;"	d
-NT_AS_AP	include/hal_com_reg.h	1333;"	d
-NT_LINK_AD_HOC	include/hal_com_reg.h	1331;"	d
-NT_LINK_AP	include/hal_com_reg.h	1332;"	d
-NT_NO_LINK	include/hal_com_reg.h	1330;"	d
-NULL_CHIP_TYPE	include/hal_intf.h	/^	NULL_CHIP_TYPE,$/;"	e	enum:_CHIP_TYPE
-NULL_FRAMETAG	include/rtw_xmit.h	456;"	d
-NULL_hdl	core/rtw_mlme_ext.c	/^u8 NULL_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-NUM	hal/phydm/phydm_iqk.h	33;"	d
-NUM_ACL	include/sta_info.h	30;"	d
-NUM_ANTENNA_8821A	hal/phydm/phydm_antdiv.h	52;"	d
-NUM_CHOOSE2_FROM4	hal/phydm/phydm_pathdiv.h	40;"	d
-NUM_CHOOSE3_FROM4	hal/phydm/phydm_pathdiv.h	41;"	d
-NUM_IOREQ	include/rtw_io.h	24;"	d
-NUM_OF_REGISTER_BANK	include/rtl8723d_lps_poff.h	22;"	d
-NUM_OF_TOTAL_DWORD	include/rtl8723d_lps_poff.h	23;"	d
-NUM_PMKID_CACHE	include/wlan_bssdef.h	654;"	d
-NUM_PRE_AUTH_KEY	include/wlan_bssdef.h	653;"	d
-NUM_RA_PARA	hal/phydm/phydm_rainfo.h	/^	NUM_RA_PARA$/;"	e	enum:_Phydm_ra_dbg_para
-NUM_REGULATORYS	include/rtw_rf.h	80;"	d
-NUM_RESET_DTP_PERIOD	hal/phydm/phydm_pathdiv.h	29;"	d
-NUM_STA	include/sta_info.h	25;"	d
-NUM_START_CH_40M	hal/phydm/phydm.h	86;"	d
-NUM_START_CH_80M	hal/phydm/phydm.h	85;"	d
-N_BYTE_ALIGMENT	include/basic_types.h	374;"	d
-N_sym	include/rtw_mp.h	/^	UINT			N_sym;$/;"	m	struct:_RT_PMAC_PKT_INFO
-NcIndex	hal/phydm/phydm_beamforming.h	/^	u2Byte	NcIndex:3;	$/;"	m	struct:_RT_NDPA_STA_INFO
-Ndis802_11APMode	include/wlan_bssdef.h	/^	Ndis802_11APMode$/;"	e	enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-Ndis802_11APMode	include/wlan_bssdef.h	/^	Ndis802_11APMode,$/;"	e	enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-Ndis802_11APMode	include/wlan_bssdef.h	522;"	d
-Ndis802_11AuthModeAutoSwitch	include/wlan_bssdef.h	/^	Ndis802_11AuthModeAutoSwitch,$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AuthModeMax	include/wlan_bssdef.h	/^	Ndis802_11AuthModeMax               \/* Not a real mode, defined as upper bound *\/$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AuthModeOpen	include/wlan_bssdef.h	/^	Ndis802_11AuthModeOpen,$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AuthModeShared	include/wlan_bssdef.h	/^	Ndis802_11AuthModeShared,$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AuthModeWAPI	include/wlan_bssdef.h	/^	Ndis802_11AuthModeWAPI,$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AuthModeWPA	include/wlan_bssdef.h	/^	Ndis802_11AuthModeWPA,$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AuthModeWPA2	include/rtw_security.h	69;"	d
-Ndis802_11AuthModeWPA2PSK	include/rtw_security.h	73;"	d
-Ndis802_11AuthModeWPANone	include/wlan_bssdef.h	/^	Ndis802_11AuthModeWPANone,$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AuthModeWPAPSK	include/wlan_bssdef.h	/^	Ndis802_11AuthModeWPAPSK,$/;"	e	enum:_NDIS_802_11_AUTHENTICATION_MODE
-Ndis802_11AutoUnknown	include/wlan_bssdef.h	/^	Ndis802_11AutoUnknown,$/;"	e	enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-Ndis802_11DS	include/wlan_bssdef.h	/^	Ndis802_11DS,$/;"	e	enum:_NDIS_802_11_NETWORK_TYPE
-Ndis802_11Encryption1Enabled	include/wlan_bssdef.h	/^	Ndis802_11Encryption1Enabled = Ndis802_11WEPEnabled,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11Encryption1KeyAbsent	include/wlan_bssdef.h	/^	Ndis802_11Encryption1KeyAbsent = Ndis802_11WEPKeyAbsent,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11Encryption2Enabled	include/wlan_bssdef.h	/^	Ndis802_11Encryption2Enabled,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11Encryption2KeyAbsent	include/wlan_bssdef.h	/^	Ndis802_11Encryption2KeyAbsent,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11Encryption3Enabled	include/wlan_bssdef.h	/^	Ndis802_11Encryption3Enabled,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11Encryption3KeyAbsent	include/wlan_bssdef.h	/^	Ndis802_11Encryption3KeyAbsent$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11Encryption3KeyAbsent	include/wlan_bssdef.h	/^	Ndis802_11Encryption3KeyAbsent,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11EncryptionDisabled	include/wlan_bssdef.h	/^	Ndis802_11EncryptionDisabled = Ndis802_11WEPDisabled,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11EncryptionNotSupported	include/wlan_bssdef.h	/^	Ndis802_11EncryptionNotSupported = Ndis802_11WEPNotSupported,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11FH	include/wlan_bssdef.h	/^	Ndis802_11FH,$/;"	e	enum:_NDIS_802_11_NETWORK_TYPE
-Ndis802_11IBSS	include/wlan_bssdef.h	/^	Ndis802_11IBSS,$/;"	e	enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-Ndis802_11Infrastructure	include/wlan_bssdef.h	/^	Ndis802_11Infrastructure,$/;"	e	enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-Ndis802_11InfrastructureMax	include/wlan_bssdef.h	/^	Ndis802_11InfrastructureMax,     \/* Not a real value, defined as upper bound *\/$/;"	e	enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-Ndis802_11Monitor	include/wlan_bssdef.h	/^	Ndis802_11Monitor,$/;"	e	enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-Ndis802_11NetworkTypeMax	include/wlan_bssdef.h	/^	Ndis802_11NetworkTypeMax    \/* not a real type, defined as an upper bound *\/$/;"	e	enum:_NDIS_802_11_NETWORK_TYPE
-Ndis802_11OFDM24	include/wlan_bssdef.h	/^	Ndis802_11OFDM24,$/;"	e	enum:_NDIS_802_11_NETWORK_TYPE
-Ndis802_11OFDM5	include/wlan_bssdef.h	/^	Ndis802_11OFDM5,$/;"	e	enum:_NDIS_802_11_NETWORK_TYPE
-Ndis802_11ReloadWEPKeys	include/wlan_bssdef.h	/^	Ndis802_11ReloadWEPKeys$/;"	e	enum:_NDIS_802_11_RELOAD_DEFAULTS
-Ndis802_11StatusTypeMax	include/wlan_bssdef.h	/^	Ndis802_11StatusTypeMax    \/* not a real type, defined as an upper bound *\/$/;"	e	enum:_NDIS_802_11_STATUS_TYPE
-Ndis802_11StatusType_Authentication	include/wlan_bssdef.h	/^	Ndis802_11StatusType_Authentication,$/;"	e	enum:_NDIS_802_11_STATUS_TYPE
-Ndis802_11StatusType_MediaStreamMode	include/wlan_bssdef.h	/^	Ndis802_11StatusType_MediaStreamMode,$/;"	e	enum:_NDIS_802_11_STATUS_TYPE
-Ndis802_11StatusType_PMKID_CandidateList	include/wlan_bssdef.h	/^	Ndis802_11StatusType_PMKID_CandidateList,$/;"	e	enum:_NDIS_802_11_STATUS_TYPE
-Ndis802_11WEPDisabled	include/wlan_bssdef.h	/^	Ndis802_11WEPDisabled,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11WEPEnabled	include/wlan_bssdef.h	/^	Ndis802_11WEPEnabled,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11WEPKeyAbsent	include/wlan_bssdef.h	/^	Ndis802_11WEPKeyAbsent,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11WEPNotSupported	include/wlan_bssdef.h	/^	Ndis802_11WEPNotSupported,$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-Ndis802_11_EncrypteionWAPI	include/wlan_bssdef.h	/^	Ndis802_11_EncrypteionWAPI$/;"	e	enum:_NDIS_802_11_WEP_STATUS
-NdisPacketFilter	include/drv_types.h	/^	u32	NdisPacketFilter;$/;"	m	struct:_ADAPTER
-NdisRawReadPortUchar	include/drv_types_pci.h	/^static inline void NdisRawReadPortUchar(u32 port, u8 *pval)$/;"	f
-NdisRawReadPortUlong	include/drv_types_pci.h	/^static inline void NdisRawReadPortUlong(u32 port, u32 *pval)$/;"	f
-NdisRawReadPortUshort	include/drv_types_pci.h	/^static inline void NdisRawReadPortUshort(u32 port, u16 *pval)$/;"	f
-NdisRawWritePortUchar	include/drv_types_pci.h	/^static inline void NdisRawWritePortUchar(u32 port,  u8 val)$/;"	f
-NdisRawWritePortUlong	include/drv_types_pci.h	/^static inline void NdisRawWritePortUlong(u32 port,  u32 val)$/;"	f
-NdpaIdx	hal/phydm/txbf/halcomtxbf.h	/^	u1Byte				NdpaIdx;$/;"	m	struct:_HAL_TXBF_INFO
-NdpaPeriod	hal/phydm/phydm.h	/^	u1Byte			NdpaPeriod;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-NetworkTypeInUse	include/wlan_bssdef.h	/^	NDIS_802_11_NETWORK_TYPE  NetworkTypeInUse;$/;"	m	struct:_WLAN_BSSID_EX
-Next	include/drv_types_pci.h	/^	u8   Next;$/;"	m	struct:_RT_PCI_CAPABILITIES_HEADER
-NoA0_En	include/rtw_cmd.h	/^	u8 NoA0_En:1;$/;"	m	struct:P2P_PS_Offload_t
-NoA1_En	include/rtw_cmd.h	/^	u8 NoA1_En:1;$/;"	m	struct:P2P_PS_Offload_t
-NoOfAuthEncryptPairsSupported	include/wlan_bssdef.h	/^	ULONG  NoOfAuthEncryptPairsSupported;$/;"	m	struct:_NDIS_802_11_CAPABILITY
-NoOfPMKIDs	include/wlan_bssdef.h	/^	ULONG  NoOfPMKIDs;$/;"	m	struct:_NDIS_802_11_CAPABILITY
-NoisyDecision	hal/phydm/phydm.h	/^	BOOLEAN			NoisyDecision; \/*b_noisy*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-NoisyDecision_Smooth	hal/phydm/phydm.h	/^	u4Byte			NoisyDecision_Smooth;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Normalrxpath	hal/phydm/phydm.h	/^	u1Byte			Normalrxpath;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-NscDown	hal/phydm/phydm_rainfo.h	/^	u4Byte NscDown;$/;"	m	struct:_ODM_RA_Info_
-NscUp	hal/phydm/phydm_rainfo.h	/^	u4Byte NscUp;$/;"	m	struct:_ODM_RA_Info_
-Nss	include/rtw_mp.h	/^	UCHAR			Nss;$/;"	m	struct:_RT_PMAC_PKT_INFO
-Nsts	include/rtw_mp.h	/^	UCHAR			Nsts;$/;"	m	struct:_RT_PMAC_PKT_INFO
-Ntx	include/rtw_mp.h	/^	u8			Ntx:4;				\/* 0-7 *\/$/;"	m	struct:_RT_PMAC_TX_INFO
-NumCandidates	include/wlan_bssdef.h	/^	ULONG NumCandidates; \/* No. of pmkid candidates *\/$/;"	m	struct:_NDIS_802_11_PMKID_CANDIDATE_LIST
-NumInterfaces	include/drv_types.h	/^	u8	NumInterfaces;$/;"	m	struct:dvobj_priv
-NumOfTrans	include/rtw_io.h	/^	u32		NumOfTrans:4;$/;"	m	struct:reg_protocol_rd
-NumOfTrans	include/rtw_io.h	/^	u32		NumOfTrans:4;$/;"	m	struct:reg_protocol_wt
-NumQryBeaconPkt	hal/phydm/phydm.h	/^	u1Byte		NumQryBeaconPkt;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumQryBfPkt	hal/phydm/phydm.h	/^	u4Byte		NumQryBfPkt;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumQryMuPkt	hal/phydm/phydm.h	/^	u4Byte		NumQryMuPkt;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumQryMuVhtPkt	hal/phydm/phydm.h	/^	u4Byte		NumQryMuVhtPkt[40];$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumQryPhyStatus	hal/phydm/phydm.h	/^	u4Byte		NumQryPhyStatus;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumQryPhyStatusAll	hal/phydm/phydm.h	/^	u4Byte			NumQryPhyStatusAll;		\/*CCK + OFDM*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-NumQryPhyStatusCCK	hal/phydm/phydm.h	/^	u4Byte		NumQryPhyStatusCCK;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumQryPhyStatusOFDM	hal/phydm/phydm.h	/^	u4Byte		NumQryPhyStatusOFDM;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumQryVhtPkt	hal/phydm/phydm.h	/^	u4Byte		NumQryVhtPkt[40];$/;"	m	struct:_ODM_Phy_Dbg_Info_
-NumRates	include/rtw_rf.h	30;"	d
-NumRxOkInPeriod	include/rtw_mlme.h	/^	u32				NumRxOkInPeriod;$/;"	m	struct:_RT_LINK_DETECT_T
-NumRxUnicastOkInPeriod	include/rtw_mlme.h	/^	u32				NumRxUnicastOkInPeriod;$/;"	m	struct:_RT_LINK_DETECT_T
-NumTotalRFPath	include/hal_data.h	/^	u8	NumTotalRFPath;$/;"	m	struct:hal_com_data
-NumTxOkInPeriod	include/rtw_mlme.h	/^	u32				NumTxOkInPeriod;$/;"	m	struct:_RT_LINK_DETECT_T
-NumberOfACL	include/rtw_btcoex.h	/^	u1Byte					NumberOfACL;$/;"	m	struct:_HCI_EXT_CONFIG
-NumberOfSCO	include/rtw_btcoex.h	/^	u1Byte					NumberOfSCO;$/;"	m	struct:_HCI_EXT_CONFIG
-NumofSoundingDim	hal/phydm/phydm_beamforming.h	/^	u1Byte				NumofSoundingDim;$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-NumofSoundingDim	hal/phydm/phydm_beamforming.h	/^	u1Byte	NumofSoundingDim;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-NumofSoundingDim	include/rtw_beamforming.h	/^	u8 NumofSoundingDim;$/;"	m	struct:beamformee_entry
-NumofSoundingDim	include/rtw_beamforming.h	/^	u8 NumofSoundingDim;$/;"	m	struct:beamformer_entry
-OCPBASE_DMEM_3081	include/rtl8814a_spec.h	514;"	d
-OCPBASE_IMEM_3081	include/rtl8814a_spec.h	513;"	d
-OCPBASE_RPTBUF_3081	include/rtl8814a_spec.h	515;"	d
-OCPBASE_RXBUF2_3081	include/rtl8814a_spec.h	516;"	d
-OCPBASE_RXBUF_3081	include/rtl8814a_spec.h	517;"	d
-OCPBASE_TXBUF_3081	include/rtl8814a_spec.h	518;"	d
-OCTET_STRING	include/drv_types_ce.h	/^} OCTET_STRING, *POCTET_STRING;$/;"	t	typeref:struct:_OCTET_STRING
-OCTET_STRING	include/drv_types_xp.h	/^} OCTET_STRING, *POCTET_STRING;$/;"	t	typeref:struct:_OCTET_STRING
-ODM_1T	hal/phydm/phydm_pre_define.h	/^	ODM_1T	=	1,$/;"	e	enum:tag_PHYDM_RF_TX_NUM
-ODM_1T1R	hal/phydm/phydm_pre_define.h	/^	ODM_1T1R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_1T2R	hal/phydm/phydm_pre_define.h	/^	ODM_1T2R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_2T	hal/phydm/phydm_pre_define.h	/^	ODM_2T	=	2,$/;"	e	enum:tag_PHYDM_RF_TX_NUM
-ODM_2T2R	hal/phydm/phydm_pre_define.h	/^	ODM_2T2R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_2T2R_GREEN	hal/phydm/phydm_pre_define.h	/^	ODM_2T2R_GREEN,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_2T3R	hal/phydm/phydm_pre_define.h	/^	ODM_2T3R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_2T4R	hal/phydm/phydm_pre_define.h	/^	ODM_2T4R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_3T	hal/phydm/phydm_pre_define.h	/^	ODM_3T	=	3,$/;"	e	enum:tag_PHYDM_RF_TX_NUM
-ODM_3T3R	hal/phydm/phydm_pre_define.h	/^	ODM_3T3R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_3T4R	hal/phydm/phydm_pre_define.h	/^	ODM_3T4R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_4T	hal/phydm/phydm_pre_define.h	/^	ODM_4T	=	4,$/;"	e	enum:tag_PHYDM_RF_TX_NUM
-ODM_4T4R	hal/phydm/phydm_pre_define.h	/^	ODM_4T4R,$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_ABILITY_E	hal/phydm/phydm.h	/^}ODM_ABILITY_E;$/;"	t	typeref:enum:_ODM_Support_Ability_Definition
-ODM_AC_ANTDIV_SUPPORT	hal/phydm/phydm_antdiv.h	64;"	d
-ODM_ADC_TRIGGER_Jaguar2	hal/phydm/phydm_regdefine11ac.h	39;"	d
-ODM_ADSL	hal/phydm/phydm_types.h	28;"	d
-ODM_AD_DA_LSB_MASK	hal/phydm/phydm_reg.h	68;"	d
-ODM_AD_HOC	hal/phydm/phydm_pre_define.h	/^	ODM_AD_HOC 		= BIT6,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_AFE_SETTING	hal/phydm/phydm_reg.h	57;"	d
-ODM_ANALOG_REGISTER	hal/phydm/phydm_reg.h	64;"	d
-ODM_ANTDIV_2G	hal/phydm/phydm_antdiv.h	74;"	d
-ODM_ANTDIV_2G_SUPPORT_IC	hal/phydm/phydm_antdiv.h	69;"	d
-ODM_ANTDIV_5G	hal/phydm/phydm_antdiv.h	75;"	d
-ODM_ANTDIV_5G_SUPPORT_IC	hal/phydm/phydm_antdiv.h	70;"	d
-ODM_ANTDIV_SUPPORT	hal/phydm/phydm_antdiv.h	65;"	d
-ODM_AP	hal/phydm/phydm_types.h	25;"	d
-ODM_AP_MODE	hal/phydm/phydm_pre_define.h	/^	ODM_AP_MODE 		= BIT4,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_ASSOCIATE_ENTRY_NUM	hal/phydm/phydm_pre_define.h	71;"	d
-ODM_ASSOCIATE_ENTRY_NUM	hal/phydm/phydm_pre_define.h	74;"	d
-ODM_ASSOCIATE_ENTRY_NUM	hal/phydm/phydm_pre_define.h	76;"	d
-ODM_AUTO_ANT	hal/phydm/phydm_antdiv.h	59;"	d
-ODM_AcquireSpinLock	hal/phydm/phydm_interface.c	/^ODM_AcquireSpinLock(	$/;"	f
-ODM_AllocateMemory	hal/phydm/phydm_interface.c	/^ODM_AllocateMemory(	$/;"	f
-ODM_AntDiv	hal/phydm/phydm_antdiv.c	/^ODM_AntDiv($/;"	f
-ODM_AntDivInit	hal/phydm/phydm_antdiv.c	/^ODM_AntDivInit($/;"	f
-ODM_AntDivReset	hal/phydm/phydm_antdiv.c	/^ODM_AntDivReset($/;"	f
-ODM_AntDivTimers	hal/phydm/phydm_antdiv.c	/^ODM_AntDivTimers($/;"	f
-ODM_AntDiv_Config	hal/phydm/phydm_antdiv.c	/^ODM_AntDiv_Config($/;"	f
-ODM_AsocEntry_Init	hal/phydm/phydm.c	/^ODM_AsocEntry_Init($/;"	f
-ODM_BAND_2_4G	hal/phydm/phydm_pre_define.h	/^	ODM_BAND_2_4G 	= BIT0,$/;"	e	enum:tag_Band_Type_Definition
-ODM_BAND_5G	hal/phydm/phydm_pre_define.h	/^	ODM_BAND_5G 		= BIT1,$/;"	e	enum:tag_Band_Type_Definition
-ODM_BAND_TYPE_E	hal/phydm/phydm_pre_define.h	/^}ODM_BAND_TYPE_E;$/;"	t	typeref:enum:tag_Band_Type_Definition
-ODM_BB_ADAPTIVITY	hal/phydm/phydm.h	/^	ODM_BB_ADAPTIVITY				= BIT13,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_ANT_DIV	hal/phydm/phydm.h	/^	ODM_BB_ANT_DIV				= BIT6,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_CCK_PD	hal/phydm/phydm.h	/^	ODM_BB_CCK_PD					= BIT5,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_CFO_TRACKING	hal/phydm/phydm.h	/^	ODM_BB_CFO_TRACKING			= BIT14,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_DIG	hal/phydm/phydm.h	/^	ODM_BB_DIG					= BIT0,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_DYNAMIC_ARFR	hal/phydm/phydm.h	/^	ODM_BB_DYNAMIC_ARFR			= BIT18,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_DYNAMIC_TXPWR	hal/phydm/phydm.h	/^	ODM_BB_DYNAMIC_TXPWR		= BIT2,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_FA_CNT	hal/phydm/phydm.h	/^	ODM_BB_FA_CNT					= BIT3,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_NHM_CNT	hal/phydm/phydm.h	/^	ODM_BB_NHM_CNT				= BIT15,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_PATH_DIV	hal/phydm/phydm.h	/^	ODM_BB_PATH_DIV				= BIT10,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_PRIMARY_CCA	hal/phydm/phydm.h	/^	ODM_BB_PRIMARY_CCA			= BIT16,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_PWR_TRAIN	hal/phydm/phydm.h	/^	ODM_BB_PWR_TRAIN				= BIT8,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_RATE_ADAPTIVE	hal/phydm/phydm.h	/^	ODM_BB_RATE_ADAPTIVE			= BIT9,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_RA_MASK	hal/phydm/phydm.h	/^	ODM_BB_RA_MASK				= BIT1,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_RESET	hal/phydm/phydm_reg.h	37;"	d
-ODM_BB_RSSI_MONITOR	hal/phydm/phydm.h	/^	ODM_BB_RSSI_MONITOR			= BIT4,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BB_TXBF	hal/phydm/phydm.h	/^	ODM_BB_TXBF					= BIT17,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_BIT	hal/phydm/phydm_interface.h	91;"	d
-ODM_BIT	hal/phydm/phydm_interface.h	94;"	d
-ODM_BIT_BB_ATC_11AC	hal/phydm/phydm_regdefine11ac.h	91;"	d
-ODM_BIT_BB_ATC_11N	hal/phydm/phydm_regdefine11n.h	210;"	d
-ODM_BIT_BB_RX_PATH_11AC	hal/phydm/phydm_regdefine11ac.h	89;"	d
-ODM_BIT_BB_RX_PATH_11N	hal/phydm/phydm_regdefine11n.h	208;"	d
-ODM_BIT_BB_TX_PATH_11AC	hal/phydm/phydm_regdefine11ac.h	90;"	d
-ODM_BIT_BB_TX_PATH_11N	hal/phydm/phydm_regdefine11n.h	209;"	d
-ODM_BIT_CCK_RPT_FORMAT_11AC	hal/phydm/phydm_regdefine11ac.h	88;"	d
-ODM_BIT_CCK_RPT_FORMAT_11N	hal/phydm/phydm_regdefine11n.h	207;"	d
-ODM_BIT_IGI_11AC	hal/phydm/phydm_regdefine11ac.h	87;"	d
-ODM_BIT_IGI_11N	hal/phydm/phydm_regdefine11n.h	206;"	d
-ODM_BOARD_BT	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_BT        = BIT(2), \/\/ 0 = without BT card, 1 = with BT$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_DEFAULT	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_DEFAULT  	= 0, 	  \/\/ The DEFAULT case.$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_EXT_LNA	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_EXT_LNA   = BIT(4), \/\/ 0 = no 2G ext-LNA, 1 = existing 2G ext-LNA$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_EXT_LNA_5G	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_EXT_LNA_5G= BIT(7), \/\/ 0 = no 5G ext-LNA, 1 = existing 5G ext-LNA$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_EXT_PA	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_EXT_PA    = BIT(3), \/\/ 0 = no 2G ext-PA, 1 = existing 2G ext-PA$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_EXT_PA_5G	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_EXT_PA_5G	= BIT(6), \/\/ 0 = no 5G ext-PA, 1 = existing 5G ext-PA$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_EXT_TRSW	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_EXT_TRSW  = BIT(5), \/\/ 0 = no ext-TRSW, 1 = existing ext-TRSW$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_MINICARD	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_MINICARD  = BIT(0), \/\/ 0 = non-mini card, 1= mini card.$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_SLIM	hal/phydm/phydm_pre_define.h	/^    ODM_BOARD_SLIM      = BIT(1), \/\/ 0 = non-slim card, 1 = slim card$/;"	e	enum:tag_Board_Definition
-ODM_BOARD_TYPE_E	hal/phydm/phydm_pre_define.h	/^}ODM_BOARD_TYPE_E;$/;"	t	typeref:enum:tag_Board_Definition
-ODM_BT_BUSY	hal/phydm/phydm_pre_define.h	/^	ODM_BT_BUSY 		= 1,$/;"	e	enum:tag_BT_Coexist_Definition
-ODM_BT_COEXIST_E	hal/phydm/phydm_pre_define.h	/^}ODM_BT_COEXIST_E;$/;"	t	typeref:enum:tag_BT_Coexist_Definition
-ODM_BT_NONE	hal/phydm/phydm_pre_define.h	/^	ODM_BT_NONE 		= 4,$/;"	e	enum:tag_BT_Coexist_Definition
-ODM_BT_OFF	hal/phydm/phydm_pre_define.h	/^	ODM_BT_OFF 		= 3,$/;"	e	enum:tag_BT_Coexist_Definition
-ODM_BT_ON	hal/phydm/phydm_pre_define.h	/^	ODM_BT_ON 			= 2,$/;"	e	enum:tag_BT_Coexist_Definition
-ODM_BW10M	hal/phydm/phydm_pre_define.h	/^	ODM_BW10M			= 5,$/;"	e	enum:tag_Bandwidth_Definition
-ODM_BW160M	hal/phydm/phydm_pre_define.h	/^	ODM_BW160M 		= 3,$/;"	e	enum:tag_Bandwidth_Definition
-ODM_BW20M	hal/phydm/phydm_pre_define.h	/^	ODM_BW20M 		= 0,$/;"	e	enum:tag_Bandwidth_Definition
-ODM_BW40M	hal/phydm/phydm_pre_define.h	/^	ODM_BW40M 		= 1,$/;"	e	enum:tag_Bandwidth_Definition
-ODM_BW5M	hal/phydm/phydm_pre_define.h	/^	ODM_BW5M			= 4,$/;"	e	enum:tag_Bandwidth_Definition
-ODM_BW80M	hal/phydm/phydm_pre_define.h	/^	ODM_BW80M 		= 2,$/;"	e	enum:tag_Bandwidth_Definition
-ODM_BW_E	hal/phydm/phydm_pre_define.h	/^}ODM_BW_E;$/;"	t	typeref:enum:tag_Bandwidth_Definition
-ODM_BW_MAX	hal/phydm/phydm_pre_define.h	/^	ODM_BW_MAX		= 6$/;"	e	enum:tag_Bandwidth_Definition
-ODM_C2HRaParaReportHandler	hal/phydm/phydm_rainfo.c	/^ODM_C2HRaParaReportHandler($/;"	f
-ODM_CCA_1R_A	hal/phydm/phydm.h	/^	ODM_CCA_1R_A		= 1,$/;"	e	enum:tag_CCA_Path
-ODM_CCA_1R_B	hal/phydm/phydm.h	/^	ODM_CCA_1R_B		= 2,$/;"	e	enum:tag_CCA_Path
-ODM_CCA_2R	hal/phydm/phydm.h	/^	ODM_CCA_2R		= 0,$/;"	e	enum:tag_CCA_Path
-ODM_CCA_PATH_E	hal/phydm/phydm.h	/^} ODM_CCA_PATH_E;$/;"	t	typeref:enum:tag_CCA_Path
-ODM_CCK_ANT_SELECT	hal/phydm/phydm_reg.h	72;"	d
-ODM_CCK_CNT_RESET	hal/phydm/phydm_reg.h	77;"	d
-ODM_CCK_FA_CNT_LSB	hal/phydm/phydm_reg.h	80;"	d
-ODM_CCK_FA_CNT_MSB	hal/phydm/phydm_reg.h	79;"	d
-ODM_CCK_MATCH_FILTER	hal/phydm/phydm_reg.h	75;"	d
-ODM_CCK_NEW_FUNCTION	hal/phydm/phydm_reg.h	81;"	d
-ODM_CCK_PD_THRESH	hal/phydm/phydm_reg.h	73;"	d
-ODM_CCK_RAKE_MAC	hal/phydm/phydm_reg.h	76;"	d
-ODM_CCK_RF_REG1	hal/phydm/phydm_reg.h	74;"	d
-ODM_CCK_TABLE_SIZE	hal/phydm/phydm_powertracking_ap.h	83;"	d
-ODM_CCK_TX_DIVERSITY	hal/phydm/phydm_reg.h	78;"	d
-ODM_CE	hal/phydm/phydm_types.h	26;"	d
-ODM_CHANNEL	hal/phydm/phydm_reg.h	107;"	d
-ODM_CLIENT_MODE	hal/phydm/phydm_pre_define.h	/^	ODM_CLIENT_MODE	= BIT5,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_CMNINFO_5G_EXT_LNA	hal/phydm/phydm.h	/^	ODM_CMNINFO_5G_EXT_LNA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_5G_EXT_PA	hal/phydm/phydm.h	/^	ODM_CMNINFO_5G_EXT_PA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_ABILITY	hal/phydm/phydm.h	/^	ODM_CMNINFO_ABILITY,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_ADAPTIVITY	hal/phydm/phydm.h	/^	ODM_CMNINFO_ADAPTIVITY,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_ALNA	hal/phydm/phydm.h	/^	ODM_CMNINFO_ALNA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_ANT_DIV	hal/phydm/phydm.h	/^	ODM_CMNINFO_ANT_DIV,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_ANT_TEST	hal/phydm/phydm.h	/^	ODM_CMNINFO_ANT_TEST,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_APA	hal/phydm/phydm.h	/^	ODM_CMNINFO_APA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_AP_TOTAL_NUM	hal/phydm/phydm.h	/^	ODM_CMNINFO_AP_TOTAL_NUM,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BAND	hal/phydm/phydm.h	/^	ODM_CMNINFO_BAND,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BE_FIX_TX_ANT	hal/phydm/phydm.h	/^	ODM_CMNINFO_BE_FIX_TX_ANT,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BINHCT_TEST	hal/phydm/phydm.h	/^	ODM_CMNINFO_BINHCT_TEST,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BOARD_TYPE	hal/phydm/phydm.h	/^	ODM_CMNINFO_BOARD_TYPE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_BUSY	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_BUSY,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_DIG	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_DIG,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_DISABLE_EDCA	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_DISABLE_EDCA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_ENABLED	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_ENABLED,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_HS_CONNECT_PROCESS	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_HS_CONNECT_PROCESS,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_HS_RSSI	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_HS_RSSI,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_LIMITED_DIG	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_LIMITED_DIG,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BT_OPERATION	hal/phydm/phydm.h	/^	ODM_CMNINFO_BT_OPERATION,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BUDDY_ADAPTOR	hal/phydm/phydm.h	/^	ODM_CMNINFO_BUDDY_ADAPTOR,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BW	hal/phydm/phydm.h	/^	ODM_CMNINFO_BW,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_BWIFI_TEST	hal/phydm/phydm.h	/^	ODM_CMNINFO_BWIFI_TEST,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_CHNL	hal/phydm/phydm.h	/^	ODM_CMNINFO_CHNL,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_CONFIG_BB_RF	hal/phydm/phydm.h	/^	ODM_CMNINFO_CONFIG_BB_RF,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_CUT_VER	hal/phydm/phydm.h	/^	ODM_CMNINFO_CUT_VER,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DBG_COMP	hal/phydm/phydm.h	/^	ODM_CMNINFO_DBG_COMP,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DBG_LEVEL	hal/phydm/phydm.h	/^	ODM_CMNINFO_DBG_LEVEL,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DFS_MASTER_ENABLE	hal/phydm/phydm.h	/^	ODM_CMNINFO_DFS_MASTER_ENABLE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DFS_REGION_DOMAIN	hal/phydm/phydm.h	/^	ODM_CMNINFO_DFS_REGION_DOMAIN,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DMSP_GET_VALUE	hal/phydm/phydm.h	/^	ODM_CMNINFO_DMSP_GET_VALUE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DMSP_IS_MASTER	hal/phydm/phydm.h	/^	ODM_CMNINFO_DMSP_IS_MASTER,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DOMAIN_CODE_2G	hal/phydm/phydm.h	/^	ODM_CMNINFO_DOMAIN_CODE_2G,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DOMAIN_CODE_5G	hal/phydm/phydm.h	/^	ODM_CMNINFO_DOMAIN_CODE_5G,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_DRV_STOP	hal/phydm/phydm.h	/^	ODM_CMNINFO_DRV_STOP,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_E	hal/phydm/phydm.h	/^}ODM_CMNINFO_E;$/;"	t	typeref:enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_EXT_LNA	hal/phydm/phydm.h	/^	ODM_CMNINFO_EXT_LNA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_EXT_LNA_GAIN	hal/phydm/phydm.h	/^	ODM_CMNINFO_EXT_LNA_GAIN,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_EXT_PA	hal/phydm/phydm.h	/^	ODM_CMNINFO_EXT_PA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_EXT_TRSW	hal/phydm/phydm.h	/^	ODM_CMNINFO_EXT_TRSW,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_FAB_VER	hal/phydm/phydm.h	/^	ODM_CMNINFO_FAB_VER,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_FCS_MODE	hal/phydm/phydm.h	/^	ODM_CMNINFO_FCS_MODE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_FORCED_IGI_LB	hal/phydm/phydm.h	/^	ODM_CMNINFO_FORCED_IGI_LB,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_FORCED_RATE	hal/phydm/phydm.h	/^	ODM_CMNINFO_FORCED_RATE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC	hal/phydm/phydm.h	/^	ODM_CMNINFO_FORCE_TX_ANT_BY_TXDESC,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS	hal/phydm/phydm.h	/^	ODM_CMNINFO_FWDWRSVDPAGEINPROGRESS,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_GLNA	hal/phydm/phydm.h	/^	ODM_CMNINFO_GLNA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_GPA	hal/phydm/phydm.h	/^	ODM_CMNINFO_GPA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_HUBUSBMODE	hal/phydm/phydm.h	/^	ODM_CMNINFO_HUBUSBMODE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_IC_TYPE	hal/phydm/phydm.h	/^	ODM_CMNINFO_IC_TYPE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_INIT_ON	hal/phydm/phydm.h	/^	ODM_CMNINFO_INIT_ON,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_INTERFACE	hal/phydm/phydm.h	/^	ODM_CMNINFO_INTERFACE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_IQKFWOFFLOAD	hal/phydm/phydm.h	/^	ODM_CMNINFO_IQKFWOFFLOAD,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_IQKPAOFF	hal/phydm/phydm.h	/^	ODM_CMNINFO_IQKPAOFF,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_IS1ANTENNA	hal/phydm/phydm.h	/^	ODM_CMNINFO_IS1ANTENNA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_LINK	hal/phydm/phydm.h	/^	ODM_CMNINFO_LINK,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_LINK_IN_PROGRESS	hal/phydm/phydm.h	/^	ODM_CMNINFO_LINK_IN_PROGRESS,			$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_MAC_PHY_MODE	hal/phydm/phydm.h	/^	ODM_CMNINFO_MAC_PHY_MODE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_MAX	hal/phydm/phydm.h	/^	ODM_CMNINFO_MAX,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_MP_TEST_CHIP	hal/phydm/phydm.h	/^	ODM_CMNINFO_MP_TEST_CHIP,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_NET_CLOSED	hal/phydm/phydm.h	/^	ODM_CMNINFO_NET_CLOSED,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_NORMAL_RX_PATH_CHANGE	hal/phydm/phydm.h	/^	ODM_CMNINFO_NORMAL_RX_PATH_CHANGE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_ONE_PATH_CCA	hal/phydm/phydm.h	/^	ODM_CMNINFO_ONE_PATH_CCA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_P2P_LINK	hal/phydm/phydm.h	/^	ODM_CMNINFO_P2P_LINK,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_PACKAGE_TYPE	hal/phydm/phydm.h	/^	ODM_CMNINFO_PACKAGE_TYPE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_PATCH_ID	hal/phydm/phydm.h	/^	ODM_CMNINFO_PATCH_ID,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_PLATFORM	hal/phydm/phydm.h	/^	ODM_CMNINFO_PLATFORM = 0,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_PNP_IN	hal/phydm/phydm.h	/^	ODM_CMNINFO_PNP_IN,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_POWER_SAVING	hal/phydm/phydm.h	/^	ODM_CMNINFO_POWER_SAVING,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_POWER_TRAINING	hal/phydm/phydm.h	/^	ODM_CMNINFO_POWER_TRAINING,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RA_THRESHOLD_HIGH	hal/phydm/phydm.h	/^	ODM_CMNINFO_RA_THRESHOLD_HIGH,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RA_THRESHOLD_LOW	hal/phydm/phydm.h	/^	ODM_CMNINFO_RA_THRESHOLD_LOW,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_REGRFKFREEENABLE	hal/phydm/phydm.h	/^	ODM_CMNINFO_REGRFKFREEENABLE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RFDEFAULTPATH	hal/phydm/phydm.h	/^	ODM_CMNINFO_RFDEFAULTPATH,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RFE_TYPE	hal/phydm/phydm.h	/^	ODM_CMNINFO_RFE_TYPE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RFKFREEENABLE	hal/phydm/phydm.h	/^	ODM_CMNINFO_RFKFREEENABLE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RF_ANTENNA_TYPE	hal/phydm/phydm.h	/^	ODM_CMNINFO_RF_ANTENNA_TYPE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RF_TYPE	hal/phydm/phydm.h	/^	ODM_CMNINFO_RF_TYPE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RSSI_MIN	hal/phydm/phydm.h	/^	ODM_CMNINFO_RSSI_MIN,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RX_TP	hal/phydm/phydm.h	/^	ODM_CMNINFO_RX_TP,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_RX_UNI	hal/phydm/phydm.h	/^	ODM_CMNINFO_RX_UNI,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_SCAN	hal/phydm/phydm.h	/^	ODM_CMNINFO_SCAN,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_SEC_CHNL_OFFSET	hal/phydm/phydm.h	/^	ODM_CMNINFO_SEC_CHNL_OFFSET,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_SEC_MODE	hal/phydm/phydm.h	/^	ODM_CMNINFO_SEC_MODE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA	hal/phydm/phydm.h	/^	ODM_CMNINFO_SET_S0S1_DEFAULT_ANTENNA,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_SMART_CONCURRENT	hal/phydm/phydm.h	/^	ODM_CMNINFO_SMART_CONCURRENT,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_SOUNDING_SEQ	hal/phydm/phydm.h	/^	ODM_CMNINFO_SOUNDING_SEQ,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_STATION_STATE	hal/phydm/phydm.h	/^	ODM_CMNINFO_STATION_STATE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_STA_STATUS	hal/phydm/phydm.h	/^	ODM_CMNINFO_STA_STATUS,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_TX_TP	hal/phydm/phydm.h	/^	ODM_CMNINFO_TX_TP,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_TX_UNI	hal/phydm/phydm.h	/^	ODM_CMNINFO_TX_UNI,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_VXD_LINK	hal/phydm/phydm.h	/^	ODM_CMNINFO_VXD_LINK,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_WIFI_DIRECT	hal/phydm/phydm.h	/^	ODM_CMNINFO_WIFI_DIRECT,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_WIFI_DISPLAY	hal/phydm/phydm.h	/^	ODM_CMNINFO_WIFI_DISPLAY,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH	hal/phydm/phydm.h	/^	ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_CMNINFO_WM_MODE	hal/phydm/phydm.h	/^	ODM_CMNINFO_WM_MODE,$/;"	e	enum:_ODM_Common_Info_Definition
-ODM_COMP_ACS	hal/phydm/phydm_debug.h	108;"	d
-ODM_COMP_ANT_DIV	hal/phydm/phydm_debug.h	97;"	d
-ODM_COMP_API	hal/phydm/phydm_debug.h	126;"	d
-ODM_COMP_CALIBRATION	hal/phydm/phydm_debug.h	120;"	d
-ODM_COMP_CCX	hal/phydm/phydm_debug.h	102;"	d
-ODM_COMP_CFO_TRACKING	hal/phydm/phydm_debug.h	107;"	d
-ODM_COMP_COMMON	hal/phydm/phydm_debug.h	125;"	d
-ODM_COMP_DFS	hal/phydm/phydm_debug.h	98;"	d
-ODM_COMP_DIG	hal/phydm/phydm_debug.h	91;"	d
-ODM_COMP_DYNAMIC_PRICCA	hal/phydm/phydm_debug.h	104;"	d
-ODM_COMP_DYNAMIC_TXPWR	hal/phydm/phydm_debug.h	93;"	d
-ODM_COMP_EDCA_TURBO	hal/phydm/phydm_debug.h	113;"	d
-ODM_COMP_FA_CNT	hal/phydm/phydm_debug.h	94;"	d
-ODM_COMP_INIT	hal/phydm/phydm_debug.h	124;"	d
-ODM_COMP_MP	hal/phydm/phydm_debug.h	106;"	d
-ODM_COMP_NOISY_DETECT	hal/phydm/phydm_debug.h	99;"	d
-ODM_COMP_PATH_DIV	hal/phydm/phydm_debug.h	101;"	d
-ODM_COMP_RATE_ADAPTIVE	hal/phydm/phydm_debug.h	100;"	d
-ODM_COMP_RA_MASK	hal/phydm/phydm_debug.h	92;"	d
-ODM_COMP_RSSI_MONITOR	hal/phydm/phydm_debug.h	95;"	d
-ODM_COMP_SNIFFER	hal/phydm/phydm_debug.h	96;"	d
-ODM_COMP_TX_PWR_TRACK	hal/phydm/phydm_debug.h	118;"	d
-ODM_CONFIG_BT_COEXIST	hal/phydm/phydm_pre_define.h	368;"	d
-ODM_CONFIG_BT_COEXIST	hal/phydm/phydm_pre_define.h	374;"	d
-ODM_CONFIG_BT_COEXIST	hal/phydm/phydm_pre_define.h	389;"	d
-ODM_CONFIG_BT_COEXIST	hal/phydm/phydm_pre_define.h	391;"	d
-ODM_CUT_A	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_A 		=	0,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_B	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_B 		=	1,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_C	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_C 		=	2,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_D	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_D 		=	3,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_E	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_E 		=	4,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_F	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_F 		=	5,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_I	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_I 		=	8,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_J	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_J 		=	9,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_K	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_K 		=	10,	$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_TEST	hal/phydm/phydm_pre_define.h	/^	ODM_CUT_TEST 	=	15,$/;"	e	enum:tag_ODM_Cut_Version_Definition
-ODM_CUT_VERSION_E	hal/phydm/phydm_pre_define.h	/^}ODM_CUT_VERSION_E;$/;"	t	typeref:enum:tag_ODM_Cut_Version_Definition
-ODM_CancelAllTimers	hal/phydm/phydm.c	/^ODM_CancelAllTimers($/;"	f
-ODM_CancelTimer	hal/phydm/phydm_interface.c	/^ODM_CancelTimer($/;"	f
-ODM_CfoTracking	hal/phydm/phydm_cfotracking.c	/^ODM_CfoTracking($/;"	f
-ODM_CfoTrackingInit	hal/phydm/phydm_cfotracking.c	/^ODM_CfoTrackingInit($/;"	f
-ODM_CfoTrackingReset	hal/phydm/phydm_cfotracking.c	/^ODM_CfoTrackingReset($/;"	f
-ODM_ChangeDynamicInitGainThresh	hal/phydm/phydm_dig.c	/^ODM_ChangeDynamicInitGainThresh($/;"	f
-ODM_CheckPowerStatus	hal/phydm/phydm.c	/^ODM_CheckPowerStatus($/;"	f
-ODM_CheckPowerStatus	hal/phydm/rtl8723d/halphyrf_8723d.c	/^ODM_CheckPowerStatus($/;"	f
-ODM_ClearTxPowerTrackingState	hal/phydm/halphyrf_ce.c	/^ODM_ClearTxPowerTrackingState($/;"	f
-ODM_ClearTxPowerTrackingState	hal/phydm/halphyrf_win.c	/^ODM_ClearTxPowerTrackingState($/;"	f
-ODM_CmnInfoHook	hal/phydm/phydm.c	/^ODM_CmnInfoHook($/;"	f
-ODM_CmnInfoInit	hal/phydm/phydm.c	/^ODM_CmnInfoInit($/;"	f
-ODM_CmnInfoPtrArrayHook	hal/phydm/phydm.c	/^ODM_CmnInfoPtrArrayHook($/;"	f
-ODM_CmnInfoUpdate	hal/phydm/phydm.c	/^ODM_CmnInfoUpdate($/;"	f
-ODM_CompareMemory	hal/phydm/phydm_interface.c	/^s4Byte ODM_CompareMemory($/;"	f
-ODM_ConfigBBWithHeaderFile	hal/phydm/phydm_hwconfig.c	/^ODM_ConfigBBWithHeaderFile($/;"	f
-ODM_ConfigFWWithHeaderFile	hal/phydm/phydm_hwconfig.c	/^ODM_ConfigFWWithHeaderFile($/;"	f
-ODM_ConfigMACWithHeaderFile	hal/phydm/phydm_hwconfig.c	/^ODM_ConfigMACWithHeaderFile($/;"	f
-ODM_ConfigRFWithHeaderFile	hal/phydm/phydm_hwconfig.c	/^ODM_ConfigRFWithHeaderFile($/;"	f
-ODM_ConfigRFWithTxPwrTrackHeaderFile	hal/phydm/phydm_hwconfig.c	/^ODM_ConfigRFWithTxPwrTrackHeaderFile($/;"	f
-ODM_DBG_LOUD	hal/phydm/phydm_debug.h	63;"	d
-ODM_DBG_OFF	hal/phydm/phydm_debug.h	43;"	d
-ODM_DBG_SERIOUS	hal/phydm/phydm_debug.h	50;"	d
-ODM_DBG_TRACE	hal/phydm/phydm_debug.h	68;"	d
-ODM_DBG_WARNING	hal/phydm/phydm_debug.h	56;"	d
-ODM_DMDP	hal/phydm/phydm_pre_define.h	/^	ODM_DMDP	= 2,$/;"	e	enum:tag_ODM_MAC_PHY_Mode_Definition
-ODM_DMInit	hal/phydm/phydm.c	/^ODM_DMInit($/;"	f
-ODM_DMReset	hal/phydm/phydm.c	/^ODM_DMReset($/;"	f
-ODM_DMSP	hal/phydm/phydm_pre_define.h	/^	ODM_DMSP	= 1,$/;"	e	enum:tag_ODM_MAC_PHY_Mode_Definition
-ODM_DMWatchdog	hal/phydm/phydm.c	/^ODM_DMWatchdog($/;"	f
-ODM_DMWatchdog_LPS	hal/phydm/phydm.c	/^ODM_DMWatchdog_LPS($/;"	f
-ODM_DPDT	hal/phydm/phydm_reg.h	116;"	d
-ODM_DUMMY	hal/phydm/phydm_reg.h	38;"	d
-ODM_EDCA_BE_PARAM	hal/phydm/phydm_reg.h	44;"	d
-ODM_EDCA_BK_PARAM	hal/phydm/phydm_reg.h	45;"	d
-ODM_EDCA_VI_PARAM	hal/phydm/phydm_reg.h	43;"	d
-ODM_EDCA_VO_PARAM	hal/phydm/phydm_reg.h	42;"	d
-ODM_ENABLE_3_WIRE	hal/phydm/phydm_reg.h	69;"	d
-ODM_ENDIAN_BIG	hal/phydm/phydm_types.h	32;"	d
-ODM_ENDIAN_LITTLE	hal/phydm/phydm_types.h	33;"	d
-ODM_ENDIAN_TYPE	hal/phydm/phydm_precomp.h	41;"	d
-ODM_ENDIAN_TYPE	hal/phydm/phydm_precomp.h	43;"	d
-ODM_ENDIAN_TYPE	hal/phydm/phydm_precomp.h	56;"	d
-ODM_ENDIAN_TYPE	hal/phydm/phydm_types.h	221;"	d
-ODM_ENDIAN_TYPE	hal/phydm/phydm_types.h	223;"	d
-ODM_EVM_ENHANCE_ANTDIV	hal/phydm/phydm_features.h	68;"	d
-ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC	hal/phydm/phydm_antdiv.h	72;"	d
-ODM_EdcaParaSelByIot	hal/phydm/phydm_edcaturbocheck.c	/^ODM_EdcaParaSelByIot($/;"	f
-ODM_EdcaTurboInit	hal/phydm/phydm_edcaturbocheck.c	/^ODM_EdcaTurboInit($/;"	f
-ODM_FAB_E	hal/phydm/phydm_pre_define.h	/^}ODM_FAB_E;$/;"	t	typeref:enum:tag_ODM_Fab_Version_Definition
-ODM_FIX_AUX_ANT	hal/phydm/phydm_antdiv.h	61;"	d
-ODM_FIX_MAIN_ANT	hal/phydm/phydm_antdiv.h	60;"	d
-ODM_FPGA_PHY0_PAGE8	hal/phydm/phydm_reg.h	55;"	d
-ODM_FW_DEBUG_TRACE	hal/phydm/phydm_debug.h	115;"	d
-ODM_FillH2CCmd	hal/phydm/phydm_interface.c	/^ODM_FillH2CCmd($/;"	f
-ODM_FreeAllWorkItems	hal/phydm/phydm.c	/^ODM_FreeAllWorkItems(IN PDM_ODM_T	pDM_Odm )$/;"	f
-ODM_FreeMemory	hal/phydm/phydm_interface.c	/^ODM_FreeMemory(	$/;"	f
-ODM_FreeWorkItem	hal/phydm/phydm_interface.c	/^ODM_FreeWorkItem(	$/;"	f
-ODM_GAIN_SETTING	hal/phydm/phydm_reg.h	106;"	d
-ODM_GetAutoChannelSelectResult	hal/phydm/phydm_acs.c	/^ODM_GetAutoChannelSelectResult($/;"	f
-ODM_GetBBReg	hal/phydm/phydm_interface.c	/^ODM_GetBBReg(	$/;"	f
-ODM_GetCurrentTime	hal/phydm/phydm_interface.c	/^ODM_GetCurrentTime(	$/;"	f
-ODM_GetHWImgVersion	hal/phydm/phydm_hwconfig.c	/^ODM_GetHWImgVersion($/;"	f
-ODM_GetMACReg	hal/phydm/phydm_interface.c	/^ODM_GetMACReg(	$/;"	f
-ODM_GetProgressingTime	hal/phydm/phydm_interface.c	/^ODM_GetProgressingTime(	$/;"	f
-ODM_GetRFReg	hal/phydm/phydm_interface.c	/^ODM_GetRFReg(	$/;"	f
-ODM_GetRightChnlPlaceforIQK	hal/phydm/halphyrf_ap.c	/^u1Byte ODM_GetRightChnlPlaceforIQK(u1Byte chnl)$/;"	f
-ODM_GetRightChnlPlaceforIQK	hal/phydm/halphyrf_ce.c	/^u1Byte ODM_GetRightChnlPlaceforIQK(u1Byte chnl)$/;"	f
-ODM_GetRightChnlPlaceforIQK	hal/phydm/halphyrf_win.c	/^u1Byte ODM_GetRightChnlPlaceforIQK(u1Byte chnl)$/;"	f
-ODM_GetVersion_MP_8723D_AGC_TAB	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^ODM_GetVersion_MP_8723D_AGC_TAB(void)$/;"	f
-ODM_GetVersion_MP_8723D_MAC_REG	hal/phydm/rtl8723d/halhwimg8723d_mac.c	/^ODM_GetVersion_MP_8723D_MAC_REG(void)$/;"	f
-ODM_GetVersion_MP_8723D_PHY_REG	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^ODM_GetVersion_MP_8723D_PHY_REG(void)$/;"	f
-ODM_GetVersion_MP_8723D_RadioA	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^ODM_GetVersion_MP_8723D_RadioA(void)$/;"	f
-ODM_Get_Rate_Bitmap	hal/phydm/phydm_rainfo.c	/^ODM_Get_Rate_Bitmap($/;"	f
-ODM_H2C_IQ_CALIBRATION	hal/phydm/phydm_interface.h	/^	ODM_H2C_IQ_CALIBRATION	= 0x45,$/;"	e	enum:_PHYDM_H2C_CMD
-ODM_H2C_RA_PARA_ADJUST	hal/phydm/phydm_interface.h	/^	ODM_H2C_RA_PARA_ADJUST	= 0x47,$/;"	e	enum:_PHYDM_H2C_CMD
-ODM_H2C_RSSI_REPORT	hal/phydm/phydm_interface.h	/^	ODM_H2C_RSSI_REPORT		= 0x42,$/;"	e	enum:_PHYDM_H2C_CMD
-ODM_H2C_WIFI_CALIBRATION	hal/phydm/phydm_interface.h	/^	ODM_H2C_WIFI_CALIBRATION	= 0x6d,$/;"	e	enum:_PHYDM_H2C_CMD
-ODM_HL_SMART_ANT_TYPE1_SUPPORT	hal/phydm/phydm_antdiv.h	67;"	d
-ODM_IC_11AC_1_SERIES	hal/phydm/phydm_pre_define.h	347;"	d
-ODM_IC_11AC_2_SERIES	hal/phydm/phydm_pre_define.h	348;"	d
-ODM_IC_11AC_GAIN_IDX_EDCCA	hal/phydm/phydm_pre_define.h	351;"	d
-ODM_IC_11AC_SERIES	hal/phydm/phydm_pre_define.h	346;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_powertracking_ap.h	28;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_powertracking_ap.h	30;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_powertracking_ap.h	33;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	362;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	364;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	372;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	382;"	d
-ODM_IC_11AC_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	385;"	d
-ODM_IC_11N_GAIN_IDX_EDCCA	hal/phydm/phydm_pre_define.h	350;"	d
-ODM_IC_11N_SERIES	hal/phydm/phydm_pre_define.h	345;"	d
-ODM_IC_11N_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	367;"	d
-ODM_IC_11N_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	373;"	d
-ODM_IC_11N_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	381;"	d
-ODM_IC_11N_SERIES_SUPPORT	hal/phydm/phydm_pre_define.h	384;"	d
-ODM_IC_1SS	hal/phydm/phydm_pre_define.h	339;"	d
-ODM_IC_2SS	hal/phydm/phydm_pre_define.h	340;"	d
-ODM_IC_3SS	hal/phydm/phydm_pre_define.h	341;"	d
-ODM_IC_4SS	hal/phydm/phydm_pre_define.h	342;"	d
-ODM_IC_PHY_STATUE_NEW_TYPE	hal/phydm/phydm_pre_define.h	352;"	d
-ODM_IC_TXBF_SUPPORT	hal/phydm/phydm_pre_define.h	349;"	d
-ODM_IC_TYPE_E	hal/phydm/phydm_pre_define.h	/^}ODM_IC_TYPE_E;$/;"	t	typeref:enum:tag_ODM_Support_IC_Type_Definition
-ODM_INTERFACE_E	hal/phydm/phydm_pre_define.h	/^}ODM_INTERFACE_E;$/;"	t	typeref:enum:tag_ODM_Support_Interface_Definition
-ODM_IOT	hal/phydm/phydm_types.h	29;"	d
-ODM_ITRF_ALL	hal/phydm/phydm_pre_define.h	/^	ODM_ITRF_ALL 	=	0x7,$/;"	e	enum:tag_ODM_Support_Interface_Definition
-ODM_ITRF_PCIE	hal/phydm/phydm_pre_define.h	/^	ODM_ITRF_PCIE 	=	0x1,$/;"	e	enum:tag_ODM_Support_Interface_Definition
-ODM_ITRF_SDIO	hal/phydm/phydm_pre_define.h	/^	ODM_ITRF_SDIO 	=	0x4,$/;"	e	enum:tag_ODM_Support_Interface_Definition
-ODM_ITRF_USB	hal/phydm/phydm_pre_define.h	/^	ODM_ITRF_USB 	=	0x2,$/;"	e	enum:tag_ODM_Support_Interface_Definition
-ODM_InbandNoise_Monitor	hal/phydm/phydm_noisemonitor.c	/^ODM_InbandNoise_Monitor(PVOID pDM_VOID, u8 bPauseDIG, u8 IGIValue, u32 max_time)$/;"	f
-ODM_InitAllThreads	hal/phydm/phydm.c	/^ODM_InitAllThreads($/;"	f
-ODM_InitAllTimers	hal/phydm/phydm.c	/^ODM_InitAllTimers($/;"	f
-ODM_InitAllWorkItems	hal/phydm/phydm.c	/^ODM_InitAllWorkItems(IN PDM_ODM_T	pDM_Odm )$/;"	f
-ODM_InitMpDriverStatus	hal/phydm/phydm.c	/^ODM_InitMpDriverStatus($/;"	f
-ODM_InitializeTimer	hal/phydm/phydm_interface.c	/^ODM_InitializeTimer($/;"	f
-ODM_InitializeWorkItem	hal/phydm/phydm_interface.c	/^ODM_InitializeWorkItem(	$/;"	f
-ODM_IsWorkItemScheduled	hal/phydm/phydm_interface.c	/^ODM_IsWorkItemScheduled(	$/;"	f
-ODM_LINK	hal/phydm/phydm_pre_define.h	/^	ODM_LINK 			= BIT1,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_MAC_EARLY_MODE	hal/phydm/phydm.h	/^	ODM_MAC_EARLY_MODE			= BIT21,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_MAC_EDCA_TURBO	hal/phydm/phydm.h	/^	ODM_MAC_EDCA_TURBO			= BIT20,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_MAC_PHY_MODE_E	hal/phydm/phydm_pre_define.h	/^}ODM_MAC_PHY_MODE_E;$/;"	t	typeref:enum:tag_ODM_MAC_PHY_Mode_Definition
-ODM_MAX_CHANNEL_2G	hal/phydm/phydm_acs.h	27;"	d
-ODM_MAX_CHANNEL_5G	hal/phydm/phydm_acs.h	28;"	d
-ODM_MAX_CHANNEL_NUM	hal/phydm/phydm_noisemonitor.h	23;"	d
-ODM_MAX_H2CCMD	hal/phydm/phydm_interface.h	/^	ODM_MAX_H2CCMD$/;"	e	enum:_PHYDM_H2C_CMD
-ODM_MGN_11M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_11M	= 0x16,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_12M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_12M	= 0x18,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_18M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_18M	= 0x24,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_1M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_1M		= 0x02,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_24M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_24M	= 0x30,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_2M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_2M		= 0x04,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_36M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_36M	= 0x48,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_48M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_48M	= 0x60,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_54M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_54M	= 0x6C,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_5_5M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_5_5M	= 0x0B,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_6M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_6M		= 0x0C,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_9M	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_9M		= 0x12,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS0	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS0,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS0_SG	hal/phydm/phydm_pre_define.h	170;"	d
-ODM_MGN_MCS1	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS1,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS10	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS10,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS10_SG	hal/phydm/phydm_pre_define.h	180;"	d
-ODM_MGN_MCS11	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS11,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS11_SG	hal/phydm/phydm_pre_define.h	181;"	d
-ODM_MGN_MCS12	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS12,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS12_SG	hal/phydm/phydm_pre_define.h	182;"	d
-ODM_MGN_MCS13	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS13,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS13_SG	hal/phydm/phydm_pre_define.h	183;"	d
-ODM_MGN_MCS14	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS14,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS14_SG	hal/phydm/phydm_pre_define.h	184;"	d
-ODM_MGN_MCS15	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS15,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS15_SG	hal/phydm/phydm_pre_define.h	185;"	d
-ODM_MGN_MCS16	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS16,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS17	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS17,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS18	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS18,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS19	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS19,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS1_SG	hal/phydm/phydm_pre_define.h	171;"	d
-ODM_MGN_MCS2	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS2,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS20	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS20,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS21	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS21,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS22	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS22,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS23	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS23,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS24	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS24,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS25	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS25,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS26	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS26,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS27	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS27,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS28	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS28,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS29	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS29,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS2_SG	hal/phydm/phydm_pre_define.h	172;"	d
-ODM_MGN_MCS3	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS3,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS30	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS30,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS31	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS31,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS32	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS32	= 0x7F,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS3_SG	hal/phydm/phydm_pre_define.h	173;"	d
-ODM_MGN_MCS4	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS4,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS4_SG	hal/phydm/phydm_pre_define.h	174;"	d
-ODM_MGN_MCS5	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS5,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS5_SG	hal/phydm/phydm_pre_define.h	175;"	d
-ODM_MGN_MCS6	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS6,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS6_SG	hal/phydm/phydm_pre_define.h	176;"	d
-ODM_MGN_MCS7	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS7,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS7_SG	hal/phydm/phydm_pre_define.h	177;"	d
-ODM_MGN_MCS8	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS8,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS8_SG	hal/phydm/phydm_pre_define.h	178;"	d
-ODM_MGN_MCS9	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_MCS9,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_MCS9_SG	hal/phydm/phydm_pre_define.h	179;"	d
-ODM_MGN_RATE	hal/phydm/phydm_pre_define.h	/^enum ODM_MGN_RATE {$/;"	g
-ODM_MGN_UNKNOWN	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_UNKNOWN$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS0	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS0,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS1	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS1,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS2	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS2,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS3	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS3,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS4	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS4,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS5	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS5,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS6	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS6,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS7	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS7,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS8	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS8,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT1SS_MCS9	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT1SS_MCS9,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS0	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS0,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS1	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS1,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS2	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS2,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS3	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS3,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS4	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS4,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS5	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS5,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS6	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS6,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS7	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS7,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS8	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS8,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT2SS_MCS9	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT2SS_MCS9,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS0	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS0,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS1	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS1,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS2	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS2,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS3	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS3,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS4	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS4,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS5	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS5,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS6	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS6,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS7	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS7,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS8	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS8,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT3SS_MCS9	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT3SS_MCS9,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS0	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS0,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS1	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS1,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS2	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS2,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS3	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS3,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS4	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS4,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS5	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS5,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS6	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS6,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS7	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS7,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS8	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS8,$/;"	e	enum:ODM_MGN_RATE
-ODM_MGN_VHT4SS_MCS9	hal/phydm/phydm_pre_define.h	/^	ODM_MGN_VHT4SS_MCS9,$/;"	e	enum:ODM_MGN_RATE
-ODM_MPT_DIG	hal/phydm/phydm_dig.c	/^ODM_MPT_DIG($/;"	f
-ODM_MacStatusQuery	hal/phydm/phydm_hwconfig.c	/^ODM_MacStatusQuery($/;"	f
-ODM_Memory_Set	hal/phydm/phydm_interface.c	/^void ODM_Memory_Set($/;"	f
-ODM_MoveMemory	hal/phydm/phydm_interface.c	/^ODM_MoveMemory(	$/;"	f
-ODM_NOISE_MONITOR	hal/phydm/phydm_noisemonitor.h	/^}ODM_NOISE_MONITOR;$/;"	t	typeref:struct:_ODM_NOISE_MONITOR_
-ODM_NO_LINK	hal/phydm/phydm_pre_define.h	/^	ODM_NO_LINK 		= BIT0,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_NUM_RATE_IDX	hal/phydm/phydm_pre_define.h	282;"	d
-ODM_NUM_RATE_IDX	hal/phydm/phydm_pre_define.h	285;"	d
-ODM_NUM_RATE_IDX	hal/phydm/phydm_pre_define.h	287;"	d
-ODM_NUM_RATE_IDX	hal/phydm/phydm_pre_define.h	289;"	d
-ODM_NUM_RATE_IDX	hal/phydm/phydm_pre_define.h	291;"	d
-ODM_NUM_RATE_IDX	hal/phydm/phydm_pre_define.h	293;"	d
-ODM_NUM_RATE_IDX	hal/phydm/phydm_pre_define.h	295;"	d
-ODM_N_ANTDIV_SUPPORT	hal/phydm/phydm_antdiv.h	63;"	d
-ODM_OFDM_FA_CNT1	hal/phydm/phydm_reg.h	92;"	d
-ODM_OFDM_FA_CNT2	hal/phydm/phydm_reg.h	94;"	d
-ODM_OFDM_FA_CNT3	hal/phydm/phydm_reg.h	95;"	d
-ODM_OFDM_FA_CNT4	hal/phydm/phydm_reg.h	96;"	d
-ODM_OFDM_PHY0_PAGE_C	hal/phydm/phydm_reg.h	82;"	d
-ODM_OFDM_PHY0_PAGE_D	hal/phydm/phydm_reg.h	93;"	d
-ODM_OFDM_RX_ANT	hal/phydm/phydm_reg.h	83;"	d
-ODM_OFDM_TABLE_SIZE	hal/phydm/phydm_powertracking_ap.h	82;"	d
-ODM_OPERATION_MODE_E	hal/phydm/phydm_pre_define.h	/^}ODM_OPERATION_MODE_E;$/;"	t	typeref:enum:tag_Operation_Mode_Definition
-ODM_PACKAGE_DEFAULT	hal/phydm/phydm_pre_define.h	/^    ODM_PACKAGE_DEFAULT  	 = 0, 	  $/;"	e	enum:tag_ODM_Package_Definition
-ODM_PACKAGE_QFN68	hal/phydm/phydm_pre_define.h	/^    ODM_PACKAGE_QFN68        = BIT(0), $/;"	e	enum:tag_ODM_Package_Definition
-ODM_PACKAGE_TFBGA79	hal/phydm/phydm_pre_define.h	/^    ODM_PACKAGE_TFBGA79      = BIT(2),	$/;"	e	enum:tag_ODM_Package_Definition
-ODM_PACKAGE_TFBGA90	hal/phydm/phydm_pre_define.h	/^    ODM_PACKAGE_TFBGA90      = BIT(1), $/;"	e	enum:tag_ODM_Package_Definition
-ODM_PACKET_INFO_T	hal/phydm/phydm.h	/^} ODM_PACKET_INFO_T, *PODM_PACKET_INFO_T;$/;"	t	typeref:struct:_ODM_Per_Pkt_Info_
-ODM_PARAMETER_INIT_E	hal/phydm/phydm_pre_define.h	/^} ODM_PARAMETER_INIT_E;$/;"	t	typeref:enum:_ODM_PARAMETER_INIT
-ODM_PHY_CONFIG	hal/phydm/phydm_debug.h	123;"	d
-ODM_PHY_DBG_INFO_T	hal/phydm/phydm.h	/^} ODM_PHY_DBG_INFO_T;$/;"	t	typeref:struct:_ODM_Phy_Dbg_Info_
-ODM_PHY_INFO_Append_T	hal/phydm/phydm.h	/^}ODM_PHY_INFO_Append_T,*PODM_PHY_INFO_Append_T;$/;"	t	typeref:struct:_ODM_Phy_Status_Info_Append_
-ODM_PHY_INFO_T	hal/phydm/phydm.h	/^} ODM_PHY_INFO_T, *PODM_PHY_INFO_T;$/;"	t	typeref:struct:_ODM_Phy_Status_Info_
-ODM_PHY_INFO_T	hal/phydm/phydm.h	/^} __WLAN_ATTRIB_PACK__ ODM_PHY_INFO_T, *PODM_PHY_INFO_T;$/;"	t	typeref:struct:_ODM_Phy_Status_Info_
-ODM_PHY_STATUS_NEW_TYPE_SUPPORT	hal/phydm/phydm_pre_define.h	403;"	d
-ODM_PHY_STATUS_NEW_TYPE_SUPPORT	hal/phydm/phydm_pre_define.h	405;"	d
-ODM_POST_SETTING	hal/phydm/phydm_pre_define.h	/^	ODM_POST_SETTING = 1,$/;"	e	enum:_ODM_PARAMETER_INIT
-ODM_POWERSAVE	hal/phydm/phydm_pre_define.h	/^	ODM_POWERSAVE 	= BIT3,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_PRE_SETTING	hal/phydm/phydm_pre_define.h	/^	ODM_PRE_SETTING = 0,$/;"	e	enum:_ODM_PARAMETER_INIT
-ODM_PRINT_ADDR	hal/phydm/phydm_debug.h	190;"	d
-ODM_PRINT_ADDR	hal/phydm/phydm_debug.h	209;"	d
-ODM_PSDREG	hal/phydm/phydm_reg.h	119;"	d
-ODM_PSD_REPORT	hal/phydm/phydm_reg.h	70;"	d
-ODM_PSD_SETTING	hal/phydm/phydm_reg.h	56;"	d
-ODM_PWdB_Conversion	hal/phydm/phydm.c	/^ODM_PWdB_Conversion($/;"	f
-ODM_Package_TYPE_E	hal/phydm/phydm_pre_define.h	/^}ODM_Package_TYPE_E;$/;"	t	typeref:enum:tag_ODM_Package_Definition
-ODM_ParsingCFO	hal/phydm/phydm_cfotracking.c	/^ODM_ParsingCFO($/;"	f
-ODM_PhyStatusQuery	hal/phydm/phydm_hwconfig.c	/^ODM_PhyStatusQuery($/;"	f
-ODM_PhyStatusQuery_92CSeries	hal/phydm/phydm_hwconfig.c	/^ODM_PhyStatusQuery_92CSeries($/;"	f
-ODM_PhyStatusQuery_JaguarSeries	hal/phydm/phydm_hwconfig.c	/^ODM_PhyStatusQuery_JaguarSeries($/;"	f
-ODM_Process_RSSIForAntDiv	hal/phydm/phydm_antdiv.c	/^ODM_Process_RSSIForAntDiv(	$/;"	f
-ODM_RAPostActionOnAssoc	hal/phydm/phydm_rainfo.c	/^ODM_RAPostActionOnAssoc($/;"	f
-ODM_RAStateCheck	hal/phydm/phydm_rainfo.c	/^ODM_RAStateCheck($/;"	f
-ODM_RATE11M	hal/phydm/phydm_pre_define.h	197;"	d
-ODM_RATE12M	hal/phydm/phydm_pre_define.h	201;"	d
-ODM_RATE18M	hal/phydm/phydm_pre_define.h	202;"	d
-ODM_RATE1M	hal/phydm/phydm_pre_define.h	194;"	d
-ODM_RATE24M	hal/phydm/phydm_pre_define.h	203;"	d
-ODM_RATE2M	hal/phydm/phydm_pre_define.h	195;"	d
-ODM_RATE36M	hal/phydm/phydm_pre_define.h	204;"	d
-ODM_RATE48M	hal/phydm/phydm_pre_define.h	205;"	d
-ODM_RATE54M	hal/phydm/phydm_pre_define.h	206;"	d
-ODM_RATE5_5M	hal/phydm/phydm_pre_define.h	196;"	d
-ODM_RATE6M	hal/phydm/phydm_pre_define.h	199;"	d
-ODM_RATE9M	hal/phydm/phydm_pre_define.h	200;"	d
-ODM_RATEMCS0	hal/phydm/phydm_pre_define.h	208;"	d
-ODM_RATEMCS1	hal/phydm/phydm_pre_define.h	209;"	d
-ODM_RATEMCS10	hal/phydm/phydm_pre_define.h	218;"	d
-ODM_RATEMCS11	hal/phydm/phydm_pre_define.h	219;"	d
-ODM_RATEMCS12	hal/phydm/phydm_pre_define.h	220;"	d
-ODM_RATEMCS13	hal/phydm/phydm_pre_define.h	221;"	d
-ODM_RATEMCS14	hal/phydm/phydm_pre_define.h	222;"	d
-ODM_RATEMCS15	hal/phydm/phydm_pre_define.h	223;"	d
-ODM_RATEMCS15_SG	hal/phydm/phydm_pre_define.h	189;"	d
-ODM_RATEMCS16	hal/phydm/phydm_pre_define.h	224;"	d
-ODM_RATEMCS17	hal/phydm/phydm_pre_define.h	225;"	d
-ODM_RATEMCS18	hal/phydm/phydm_pre_define.h	226;"	d
-ODM_RATEMCS19	hal/phydm/phydm_pre_define.h	227;"	d
-ODM_RATEMCS2	hal/phydm/phydm_pre_define.h	210;"	d
-ODM_RATEMCS20	hal/phydm/phydm_pre_define.h	228;"	d
-ODM_RATEMCS21	hal/phydm/phydm_pre_define.h	229;"	d
-ODM_RATEMCS22	hal/phydm/phydm_pre_define.h	230;"	d
-ODM_RATEMCS23	hal/phydm/phydm_pre_define.h	231;"	d
-ODM_RATEMCS24	hal/phydm/phydm_pre_define.h	232;"	d
-ODM_RATEMCS25	hal/phydm/phydm_pre_define.h	233;"	d
-ODM_RATEMCS26	hal/phydm/phydm_pre_define.h	234;"	d
-ODM_RATEMCS27	hal/phydm/phydm_pre_define.h	235;"	d
-ODM_RATEMCS28	hal/phydm/phydm_pre_define.h	236;"	d
-ODM_RATEMCS29	hal/phydm/phydm_pre_define.h	237;"	d
-ODM_RATEMCS3	hal/phydm/phydm_pre_define.h	211;"	d
-ODM_RATEMCS30	hal/phydm/phydm_pre_define.h	238;"	d
-ODM_RATEMCS31	hal/phydm/phydm_pre_define.h	239;"	d
-ODM_RATEMCS32	hal/phydm/phydm_pre_define.h	190;"	d
-ODM_RATEMCS4	hal/phydm/phydm_pre_define.h	212;"	d
-ODM_RATEMCS5	hal/phydm/phydm_pre_define.h	213;"	d
-ODM_RATEMCS6	hal/phydm/phydm_pre_define.h	214;"	d
-ODM_RATEMCS7	hal/phydm/phydm_pre_define.h	215;"	d
-ODM_RATEMCS8	hal/phydm/phydm_pre_define.h	216;"	d
-ODM_RATEMCS9	hal/phydm/phydm_pre_define.h	217;"	d
-ODM_RATEVHTSS1MCS0	hal/phydm/phydm_pre_define.h	240;"	d
-ODM_RATEVHTSS1MCS1	hal/phydm/phydm_pre_define.h	241;"	d
-ODM_RATEVHTSS1MCS2	hal/phydm/phydm_pre_define.h	242;"	d
-ODM_RATEVHTSS1MCS3	hal/phydm/phydm_pre_define.h	243;"	d
-ODM_RATEVHTSS1MCS4	hal/phydm/phydm_pre_define.h	244;"	d
-ODM_RATEVHTSS1MCS5	hal/phydm/phydm_pre_define.h	245;"	d
-ODM_RATEVHTSS1MCS6	hal/phydm/phydm_pre_define.h	246;"	d
-ODM_RATEVHTSS1MCS7	hal/phydm/phydm_pre_define.h	247;"	d
-ODM_RATEVHTSS1MCS8	hal/phydm/phydm_pre_define.h	248;"	d
-ODM_RATEVHTSS1MCS9	hal/phydm/phydm_pre_define.h	249;"	d
-ODM_RATEVHTSS2MCS0	hal/phydm/phydm_pre_define.h	250;"	d
-ODM_RATEVHTSS2MCS1	hal/phydm/phydm_pre_define.h	251;"	d
-ODM_RATEVHTSS2MCS2	hal/phydm/phydm_pre_define.h	252;"	d
-ODM_RATEVHTSS2MCS3	hal/phydm/phydm_pre_define.h	253;"	d
-ODM_RATEVHTSS2MCS4	hal/phydm/phydm_pre_define.h	254;"	d
-ODM_RATEVHTSS2MCS5	hal/phydm/phydm_pre_define.h	255;"	d
-ODM_RATEVHTSS2MCS6	hal/phydm/phydm_pre_define.h	256;"	d
-ODM_RATEVHTSS2MCS7	hal/phydm/phydm_pre_define.h	257;"	d
-ODM_RATEVHTSS2MCS8	hal/phydm/phydm_pre_define.h	258;"	d
-ODM_RATEVHTSS2MCS9	hal/phydm/phydm_pre_define.h	259;"	d
-ODM_RATEVHTSS3MCS0	hal/phydm/phydm_pre_define.h	260;"	d
-ODM_RATEVHTSS3MCS1	hal/phydm/phydm_pre_define.h	261;"	d
-ODM_RATEVHTSS3MCS2	hal/phydm/phydm_pre_define.h	262;"	d
-ODM_RATEVHTSS3MCS3	hal/phydm/phydm_pre_define.h	263;"	d
-ODM_RATEVHTSS3MCS4	hal/phydm/phydm_pre_define.h	264;"	d
-ODM_RATEVHTSS3MCS5	hal/phydm/phydm_pre_define.h	265;"	d
-ODM_RATEVHTSS3MCS6	hal/phydm/phydm_pre_define.h	266;"	d
-ODM_RATEVHTSS3MCS7	hal/phydm/phydm_pre_define.h	267;"	d
-ODM_RATEVHTSS3MCS8	hal/phydm/phydm_pre_define.h	268;"	d
-ODM_RATEVHTSS3MCS9	hal/phydm/phydm_pre_define.h	269;"	d
-ODM_RATEVHTSS4MCS0	hal/phydm/phydm_pre_define.h	270;"	d
-ODM_RATEVHTSS4MCS1	hal/phydm/phydm_pre_define.h	271;"	d
-ODM_RATEVHTSS4MCS2	hal/phydm/phydm_pre_define.h	272;"	d
-ODM_RATEVHTSS4MCS3	hal/phydm/phydm_pre_define.h	273;"	d
-ODM_RATEVHTSS4MCS4	hal/phydm/phydm_pre_define.h	274;"	d
-ODM_RATEVHTSS4MCS5	hal/phydm/phydm_pre_define.h	275;"	d
-ODM_RATEVHTSS4MCS6	hal/phydm/phydm_pre_define.h	276;"	d
-ODM_RATEVHTSS4MCS7	hal/phydm/phydm_pre_define.h	277;"	d
-ODM_RATEVHTSS4MCS8	hal/phydm/phydm_pre_define.h	278;"	d
-ODM_RATEVHTSS4MCS9	hal/phydm/phydm_pre_define.h	279;"	d
-ODM_RATE_ADAPTIVE	hal/phydm/phydm_rainfo.h	/^} ODM_RATE_ADAPTIVE, *PODM_RATE_ADAPTIVE;$/;"	t	typeref:struct:_ODM_RATE_ADAPTIVE
-ODM_RA_INFO_T	hal/phydm/phydm_rainfo.h	/^} ODM_RA_INFO_T, *PODM_RA_INFO_T;$/;"	t	typeref:struct:_ODM_RA_Info_
-ODM_REG	hal/phydm/phydm_interface.h	90;"	d
-ODM_REG	hal/phydm/phydm_interface.h	93;"	d
-ODM_REG_ACBB_EDCCA_ENHANCE	hal/phydm/phydm_regdefine11ac.h	38;"	d
-ODM_REG_ANTDIV_PARA1_11N	hal/phydm/phydm_regdefine11n.h	135;"	d
-ODM_REG_ANTDIV_PARA2_11N	hal/phydm/phydm_regdefine11n.h	123;"	d
-ODM_REG_ANTDIV_PARA3_11N	hal/phydm/phydm_regdefine11n.h	125;"	d
-ODM_REG_ANTSEL_CTRL_11N	hal/phydm/phydm_regdefine11n.h	53;"	d
-ODM_REG_ANTSEL_PATH_11N	hal/phydm/phydm_regdefine11n.h	57;"	d
-ODM_REG_ANTSEL_PIN_11N	hal/phydm/phydm_regdefine11n.h	192;"	d
-ODM_REG_ANT_MAPPING1_11N	hal/phydm/phydm_regdefine11n.h	80;"	d
-ODM_REG_ANT_MAPPING2_11N	hal/phydm/phydm_regdefine11n.h	81;"	d
-ODM_REG_ANT_TRAIN_PARA1_11N	hal/phydm/phydm_regdefine11n.h	201;"	d
-ODM_REG_ANT_TRAIN_PARA2_11N	hal/phydm/phydm_regdefine11n.h	202;"	d
-ODM_REG_BB_3WIRE_11N	hal/phydm/phydm_regdefine11n.h	58;"	d
-ODM_REG_BB_AGC_SET_2_11N	hal/phydm/phydm_regdefine11n.h	128;"	d
-ODM_REG_BB_ATC_11AC	hal/phydm/phydm_regdefine11ac.h	33;"	d
-ODM_REG_BB_ATC_11N	hal/phydm/phydm_regdefine11n.h	141;"	d
-ODM_REG_BB_CTRL_11N	hal/phydm/phydm_regdefine11n.h	43;"	d
-ODM_REG_BB_CTRL_PAGE9_11N	hal/phydm/phydm_regdefine11n.h	77;"	d
-ODM_REG_BB_PWR_SAV1_11N	hal/phydm/phydm_regdefine11n.h	56;"	d
-ODM_REG_BB_PWR_SAV2_11N	hal/phydm/phydm_regdefine11n.h	127;"	d
-ODM_REG_BB_PWR_SAV3_11N	hal/phydm/phydm_regdefine11n.h	52;"	d
-ODM_REG_BB_PWR_SAV4_11N	hal/phydm/phydm_regdefine11n.h	104;"	d
-ODM_REG_BB_PWR_SAV5_11N	hal/phydm/phydm_regdefine11n.h	47;"	d
-ODM_REG_BB_RST_11N	hal/phydm/phydm_regdefine11n.h	191;"	d
-ODM_REG_BB_RX_ANT_11N	hal/phydm/phydm_regdefine11n.h	140;"	d
-ODM_REG_BB_RX_PATH_11AC	hal/phydm/phydm_regdefine11ac.h	31;"	d
-ODM_REG_BB_RX_PATH_11N	hal/phydm/phydm_regdefine11n.h	116;"	d
-ODM_REG_BB_TX_PATH_11AC	hal/phydm/phydm_regdefine11ac.h	32;"	d
-ODM_REG_BB_TX_PATH_11N	hal/phydm/phydm_regdefine11n.h	79;"	d
-ODM_REG_BLUETOOTH_11N	hal/phydm/phydm_regdefine11n.h	166;"	d
-ODM_REG_CCK_ANTDIV_PARA1_11N	hal/phydm/phydm_regdefine11n.h	86;"	d
-ODM_REG_CCK_ANTDIV_PARA2_11N	hal/phydm/phydm_regdefine11n.h	89;"	d
-ODM_REG_CCK_ANTDIV_PARA3_11N	hal/phydm/phydm_regdefine11n.h	90;"	d
-ODM_REG_CCK_ANTDIV_PARA4_11N	hal/phydm/phydm_regdefine11n.h	91;"	d
-ODM_REG_CCK_ANT_SEL_11N	hal/phydm/phydm_regdefine11n.h	87;"	d
-ODM_REG_CCK_CCA_11AC	hal/phydm/phydm_regdefine11ac.h	50;"	d
-ODM_REG_CCK_CCA_11N	hal/phydm/phydm_regdefine11n.h	88;"	d
-ODM_REG_CCK_CCA_CNT_11AC	hal/phydm/phydm_regdefine11ac.h	63;"	d
-ODM_REG_CCK_CCA_CNT_11N	hal/phydm/phydm_regdefine11n.h	103;"	d
-ODM_REG_CCK_CRC32_CNT_11AC	hal/phydm/phydm_regdefine11ac.h	62;"	d
-ODM_REG_CCK_CRC32_ERROR_CNT_11N	hal/phydm/phydm_regdefine11n.h	185;"	d
-ODM_REG_CCK_CRC32_OK_CNT_11N	hal/phydm/phydm_regdefine11n.h	186;"	d
-ODM_REG_CCK_FA_11AC	hal/phydm/phydm_regdefine11ac.h	52;"	d
-ODM_REG_CCK_FA_LSB_11N	hal/phydm/phydm_regdefine11n.h	102;"	d
-ODM_REG_CCK_FA_MSB_11N	hal/phydm/phydm_regdefine11n.h	101;"	d
-ODM_REG_CCK_FA_RST_11AC	hal/phydm/phydm_regdefine11ac.h	51;"	d
-ODM_REG_CCK_FA_RST_11N	hal/phydm/phydm_regdefine11n.h	100;"	d
-ODM_REG_CCK_FILTER_PARA1_11N	hal/phydm/phydm_regdefine11n.h	92;"	d
-ODM_REG_CCK_FILTER_PARA2_11N	hal/phydm/phydm_regdefine11n.h	93;"	d
-ODM_REG_CCK_FILTER_PARA3_11N	hal/phydm/phydm_regdefine11n.h	94;"	d
-ODM_REG_CCK_FILTER_PARA4_11N	hal/phydm/phydm_regdefine11n.h	95;"	d
-ODM_REG_CCK_FILTER_PARA5_11N	hal/phydm/phydm_regdefine11n.h	96;"	d
-ODM_REG_CCK_FILTER_PARA6_11N	hal/phydm/phydm_regdefine11n.h	97;"	d
-ODM_REG_CCK_FILTER_PARA7_11N	hal/phydm/phydm_regdefine11n.h	98;"	d
-ODM_REG_CCK_FILTER_PARA8_11N	hal/phydm/phydm_regdefine11n.h	99;"	d
-ODM_REG_CCK_RPT_FORMAT_11AC	hal/phydm/phydm_regdefine11ac.h	30;"	d
-ODM_REG_CCK_RPT_FORMAT_11N	hal/phydm/phydm_regdefine11n.h	48;"	d
-ODM_REG_CCK_RPT_FORMAT_11N_B	hal/phydm/phydm_regdefine11n.h	49;"	d
-ODM_REG_CCX_PERIOD_11AC	hal/phydm/phydm_regdefine11ac.h	41;"	d
-ODM_REG_CCX_PERIOD_11N	hal/phydm/phydm_regdefine11n.h	61;"	d
-ODM_REG_CHNBW_11N	hal/phydm/phydm_regdefine11n.h	28;"	d
-ODM_REG_CLM_11AC	hal/phydm/phydm_regdefine11ac.h	43;"	d
-ODM_REG_CLM_11N	hal/phydm/phydm_regdefine11n.h	63;"	d
-ODM_REG_CLM_READY_11N	hal/phydm/phydm_regdefine11n.h	67;"	d
-ODM_REG_CLM_RESULT_11AC	hal/phydm/phydm_regdefine11ac.h	69;"	d
-ODM_REG_CLM_RESULT_11N	hal/phydm/phydm_regdefine11n.h	68;"	d
-ODM_REG_CONFIG_ANTA_11N	hal/phydm/phydm_regdefine11n.h	109;"	d
-ODM_REG_CSI_CONTENT_VALUE	hal/phydm/phydm_regdefine11ac.h	48;"	d
-ODM_REG_DBG_RPT_11AC	hal/phydm/phydm_regdefine11ac.h	35;"	d
-ODM_REG_DBG_RPT_11N	hal/phydm/phydm_regdefine11n.h	78;"	d
-ODM_REG_DOWNSAM_FACTOR_11N	hal/phydm/phydm_regdefine11n.h	119;"	d
-ODM_REG_EARLY_MODE_11N	hal/phydm/phydm_regdefine11n.h	193;"	d
-ODM_REG_EDCA_BE_11N	hal/phydm/phydm_regdefine11n.h	197;"	d
-ODM_REG_EDCA_BK_11N	hal/phydm/phydm_regdefine11n.h	198;"	d
-ODM_REG_EDCA_VI_11N	hal/phydm/phydm_regdefine11n.h	196;"	d
-ODM_REG_EDCA_VO_11N	hal/phydm/phydm_regdefine11n.h	195;"	d
-ODM_REG_EDCCA_DCNF_11N	hal/phydm/phydm_regdefine11n.h	154;"	d
-ODM_REG_EDCCA_DCNF_97F	hal/phydm/phydm_regdefine11n.h	112;"	d
-ODM_REG_EDCCA_DOWN_OPT	hal/phydm/phydm_regdefine11ac.h	37;"	d
-ODM_REG_EDCCA_DOWN_OPT_11N	hal/phydm/phydm_regdefine11n.h	82;"	d
-ODM_REG_EDCCA_POWER_CAL	hal/phydm/phydm_regdefine11ac.h	34;"	d
-ODM_REG_FPGA0_IQK_11N	hal/phydm/phydm_regdefine11n.h	156;"	d
-ODM_REG_HT_CRC32_CNT_11AC	hal/phydm/phydm_regdefine11ac.h	65;"	d
-ODM_REG_HT_CRC32_CNT_11N	hal/phydm/phydm_regdefine11n.h	187;"	d
-ODM_REG_IGI_A_11AC	hal/phydm/phydm_regdefine11ac.h	57;"	d
-ODM_REG_IGI_A_11N	hal/phydm/phydm_regdefine11n.h	122;"	d
-ODM_REG_IGI_B_11AC	hal/phydm/phydm_regdefine11ac.h	59;"	d
-ODM_REG_IGI_B_11N	hal/phydm/phydm_regdefine11n.h	124;"	d
-ODM_REG_IGI_C_11AC	hal/phydm/phydm_regdefine11ac.h	77;"	d
-ODM_REG_IGI_C_11N	hal/phydm/phydm_regdefine11n.h	183;"	d
-ODM_REG_IGI_D_11AC	hal/phydm/phydm_regdefine11ac.h	79;"	d
-ODM_REG_IGI_D_11N	hal/phydm/phydm_regdefine11n.h	184;"	d
-ODM_REG_IQK_AGC_PTS_11N	hal/phydm/phydm_regdefine11n.h	164;"	d
-ODM_REG_IQK_AGC_RSP_11N	hal/phydm/phydm_regdefine11n.h	165;"	d
-ODM_REG_L1SBD_PD_CH_11N	hal/phydm/phydm_regdefine11n.h	126;"	d
-ODM_REG_LNA_SWITCH_11N	hal/phydm/phydm_regdefine11n.h	106;"	d
-ODM_REG_NHM_9E8_11AC	hal/phydm/phydm_regdefine11ac.h	47;"	d
-ODM_REG_NHM_CNT10_TO_CNT11_11N	hal/phydm/phydm_regdefine11n.h	74;"	d
-ODM_REG_NHM_CNT11_TO_CNT8_11AC	hal/phydm/phydm_regdefine11ac.h	74;"	d
-ODM_REG_NHM_CNT7_TO_CNT4_11AC	hal/phydm/phydm_regdefine11ac.h	73;"	d
-ODM_REG_NHM_CNT7_TO_CNT4_11N	hal/phydm/phydm_regdefine11n.h	72;"	d
-ODM_REG_NHM_CNT9_TO_CNT8_11N	hal/phydm/phydm_regdefine11n.h	73;"	d
-ODM_REG_NHM_CNT_11AC	hal/phydm/phydm_regdefine11ac.h	70;"	d
-ODM_REG_NHM_CNT_11N	hal/phydm/phydm_regdefine11n.h	69;"	d
-ODM_REG_NHM_DUR_READY_11AC	hal/phydm/phydm_regdefine11ac.h	71;"	d
-ODM_REG_NHM_TH3_TO_TH0_11AC	hal/phydm/phydm_regdefine11ac.h	44;"	d
-ODM_REG_NHM_TH3_TO_TH0_11N	hal/phydm/phydm_regdefine11n.h	64;"	d
-ODM_REG_NHM_TH7_TO_TH4_11AC	hal/phydm/phydm_regdefine11ac.h	45;"	d
-ODM_REG_NHM_TH7_TO_TH4_11N	hal/phydm/phydm_regdefine11n.h	65;"	d
-ODM_REG_NHM_TH8_11AC	hal/phydm/phydm_regdefine11ac.h	46;"	d
-ODM_REG_NHM_TH8_11N	hal/phydm/phydm_regdefine11n.h	66;"	d
-ODM_REG_NHM_TH9_TH10_11AC	hal/phydm/phydm_regdefine11ac.h	42;"	d
-ODM_REG_NHM_TH9_TH10_11N	hal/phydm/phydm_regdefine11n.h	62;"	d
-ODM_REG_OFDM_BBON_11N	hal/phydm/phydm_regdefine11n.h	171;"	d
-ODM_REG_OFDM_CRC32_CNT_11AC	hal/phydm/phydm_regdefine11ac.h	66;"	d
-ODM_REG_OFDM_CRC32_CNT_11N	hal/phydm/phydm_regdefine11n.h	188;"	d
-ODM_REG_OFDM_FA_11AC	hal/phydm/phydm_regdefine11ac.h	67;"	d
-ODM_REG_OFDM_FA_HOLDC_11N	hal/phydm/phydm_regdefine11n.h	115;"	d
-ODM_REG_OFDM_FA_RSTC_11N	hal/phydm/phydm_regdefine11n.h	118;"	d
-ODM_REG_OFDM_FA_RSTD_11N	hal/phydm/phydm_regdefine11n.h	139;"	d
-ODM_REG_OFDM_FA_RST_11AC	hal/phydm/phydm_regdefine11ac.h	40;"	d
-ODM_REG_OFDM_FA_TYPE1_11N	hal/phydm/phydm_regdefine11n.h	137;"	d
-ODM_REG_OFDM_FA_TYPE2_11AC	hal/phydm/phydm_regdefine11ac.h	75;"	d
-ODM_REG_OFDM_FA_TYPE2_11N	hal/phydm/phydm_regdefine11n.h	142;"	d
-ODM_REG_OFDM_FA_TYPE3_11N	hal/phydm/phydm_regdefine11n.h	143;"	d
-ODM_REG_OFDM_FA_TYPE4_11N	hal/phydm/phydm_regdefine11n.h	144;"	d
-ODM_REG_OFDM_RFON_11N	hal/phydm/phydm_regdefine11n.h	170;"	d
-ODM_REG_PAGE_B1_97F	hal/phydm/phydm_regdefine11n.h	157;"	d
-ODM_REG_PAGE_F_RST_11N	hal/phydm/phydm_regdefine11n.h	182;"	d
-ODM_REG_PATH_SWITCH_11N	hal/phydm/phydm_regdefine11n.h	107;"	d
-ODM_REG_PIN_CTRL_11N	hal/phydm/phydm_regdefine11n.h	55;"	d
-ODM_REG_PMPD_ANAEN_11N	hal/phydm/phydm_regdefine11n.h	180;"	d
-ODM_REG_PSD_CTRL_11N	hal/phydm/phydm_regdefine11n.h	45;"	d
-ODM_REG_PSD_DATA_11N	hal/phydm/phydm_regdefine11n.h	60;"	d
-ODM_REG_RESP_TX_11AC	hal/phydm/phydm_regdefine11ac.h	82;"	d
-ODM_REG_RESP_TX_11N	hal/phydm/phydm_regdefine11n.h	200;"	d
-ODM_REG_RF_0B_11N	hal/phydm/phydm_regdefine11n.h	27;"	d
-ODM_REG_RF_25_11N	hal/phydm/phydm_regdefine11n.h	30;"	d
-ODM_REG_RF_26_11N	hal/phydm/phydm_regdefine11n.h	31;"	d
-ODM_REG_RF_27_11N	hal/phydm/phydm_regdefine11n.h	32;"	d
-ODM_REG_RF_2B_11N	hal/phydm/phydm_regdefine11n.h	33;"	d
-ODM_REG_RF_2C_11N	hal/phydm/phydm_regdefine11n.h	34;"	d
-ODM_REG_RF_MODE_11N	hal/phydm/phydm_regdefine11n.h	26;"	d
-ODM_REG_RF_PIN_11N	hal/phydm/phydm_regdefine11n.h	44;"	d
-ODM_REG_RPT_11AC	hal/phydm/phydm_regdefine11ac.h	68;"	d
-ODM_REG_RPT_11N	hal/phydm/phydm_regdefine11n.h	145;"	d
-ODM_REG_RSSI_BT_11N	hal/phydm/phydm_regdefine11n.h	110;"	d
-ODM_REG_RSSI_CTRL_11N	hal/phydm/phydm_regdefine11n.h	108;"	d
-ODM_REG_RSSI_MONITOR_11N	hal/phydm/phydm_regdefine11n.h	194;"	d
-ODM_REG_RST_RPT_11AC	hal/phydm/phydm_regdefine11ac.h	54;"	d
-ODM_REG_RX2RX_11N	hal/phydm/phydm_regdefine11n.h	177;"	d
-ODM_REG_RXCK_RFMOD	hal/phydm/phydm_regdefine11n.h	111;"	d
-ODM_REG_RXIQI_MATRIX_11N	hal/phydm/phydm_regdefine11n.h	120;"	d
-ODM_REG_RXIQK_11N	hal/phydm/phydm_regdefine11n.h	163;"	d
-ODM_REG_RXIQK_MATRIX_LSB_11N	hal/phydm/phydm_regdefine11n.h	134;"	d
-ODM_REG_RXIQK_PI_A_11N	hal/phydm/phydm_regdefine11n.h	161;"	d
-ODM_REG_RXIQK_TONE_A_11N	hal/phydm/phydm_regdefine11n.h	159;"	d
-ODM_REG_RXRF_A3_11N	hal/phydm/phydm_regdefine11n.h	35;"	d
-ODM_REG_RX_ANT_CTRL_11N	hal/phydm/phydm_regdefine11n.h	54;"	d
-ODM_REG_RX_CCK_11N	hal/phydm/phydm_regdefine11n.h	174;"	d
-ODM_REG_RX_DEFUALT_A_11N	hal/phydm/phydm_regdefine11n.h	50;"	d
-ODM_REG_RX_DEFUALT_B_11N	hal/phydm/phydm_regdefine11n.h	51;"	d
-ODM_REG_RX_DFIR_MOD_97F	hal/phydm/phydm_regdefine11n.h	83;"	d
-ODM_REG_RX_OFDM_11N	hal/phydm/phydm_regdefine11n.h	175;"	d
-ODM_REG_RX_OFF_11N	hal/phydm/phydm_regdefine11n.h	129;"	d
-ODM_REG_RX_WAIT_CCA_11N	hal/phydm/phydm_regdefine11n.h	167;"	d
-ODM_REG_RX_WAIT_RIFS_11N	hal/phydm/phydm_regdefine11n.h	176;"	d
-ODM_REG_SC_CNT_11N	hal/phydm/phydm_regdefine11n.h	59;"	d
-ODM_REG_SLEEP_11N	hal/phydm/phydm_regdefine11n.h	179;"	d
-ODM_REG_SMALL_BANDWIDTH_11N	hal/phydm/phydm_regdefine11n.h	136;"	d
-ODM_REG_STANDBY_11N	hal/phydm/phydm_regdefine11n.h	178;"	d
-ODM_REG_TAP_UPD_97F	hal/phydm/phydm_regdefine11n.h	155;"	d
-ODM_REG_TRMUX_11AC	hal/phydm/phydm_regdefine11ac.h	56;"	d
-ODM_REG_TRMUX_11AC_B	hal/phydm/phydm_regdefine11ac.h	60;"	d
-ODM_REG_TRMUX_11N	hal/phydm/phydm_regdefine11n.h	117;"	d
-ODM_REG_TX2RX_11N	hal/phydm/phydm_regdefine11n.h	172;"	d
-ODM_REG_TX2TX_11N	hal/phydm/phydm_regdefine11n.h	173;"	d
-ODM_REG_TXAGC_A_1_MCS32_11N	hal/phydm/phydm_regdefine11n.h	149;"	d
-ODM_REG_TXAGC_A_24_54_11N	hal/phydm/phydm_regdefine11n.h	148;"	d
-ODM_REG_TXAGC_A_6_18_11N	hal/phydm/phydm_regdefine11n.h	147;"	d
-ODM_REG_TXAGC_A_MCS0_3_11N	hal/phydm/phydm_regdefine11n.h	150;"	d
-ODM_REG_TXAGC_A_MCS12_15_11N	hal/phydm/phydm_regdefine11n.h	153;"	d
-ODM_REG_TXAGC_A_MCS4_7_11N	hal/phydm/phydm_regdefine11n.h	151;"	d
-ODM_REG_TXAGC_A_MCS8_11_11N	hal/phydm/phydm_regdefine11n.h	152;"	d
-ODM_REG_TXIQK_11N	hal/phydm/phydm_regdefine11n.h	162;"	d
-ODM_REG_TXIQK_MATRIXA_11N	hal/phydm/phydm_regdefine11n.h	130;"	d
-ODM_REG_TXIQK_MATRIXA_LSB2_11N	hal/phydm/phydm_regdefine11n.h	132;"	d
-ODM_REG_TXIQK_MATRIXB_11N	hal/phydm/phydm_regdefine11n.h	131;"	d
-ODM_REG_TXIQK_MATRIXB_LSB2_11N	hal/phydm/phydm_regdefine11n.h	133;"	d
-ODM_REG_TXIQK_MATRIX_LSB1_11N	hal/phydm/phydm_regdefine11n.h	121;"	d
-ODM_REG_TXIQK_PI_A_11N	hal/phydm/phydm_regdefine11n.h	160;"	d
-ODM_REG_TXIQK_TONE_A_11N	hal/phydm/phydm_regdefine11n.h	158;"	d
-ODM_REG_TXPAUSE_11N	hal/phydm/phydm_regdefine11n.h	199;"	d
-ODM_REG_TX_ANT_CTRL_11N	hal/phydm/phydm_regdefine11n.h	46;"	d
-ODM_REG_TX_CCK_BBON_11N	hal/phydm/phydm_regdefine11n.h	169;"	d
-ODM_REG_TX_CCK_RFON_11N	hal/phydm/phydm_regdefine11n.h	168;"	d
-ODM_REG_T_METER_11N	hal/phydm/phydm_regdefine11n.h	29;"	d
-ODM_REG_T_METER_88E_11N	hal/phydm/phydm_regdefine11n.h	37;"	d
-ODM_REG_T_METER_92D_11N	hal/phydm/phydm_regdefine11n.h	36;"	d
-ODM_REG_VHT_CRC32_CNT_11AC	hal/phydm/phydm_regdefine11ac.h	64;"	d
-ODM_RF_A	hal/phydm/phydm_pre_define.h	/^	ODM_RF_A = BIT0,$/;"	e	enum:tag_ODM_RF_Path_Bit_Definition
-ODM_RF_B	hal/phydm/phydm_pre_define.h	/^	ODM_RF_B = BIT1,$/;"	e	enum:tag_ODM_RF_Path_Bit_Definition
-ODM_RF_C	hal/phydm/phydm_pre_define.h	/^	ODM_RF_C = BIT2,$/;"	e	enum:tag_ODM_RF_Path_Bit_Definition
-ODM_RF_CALIBRATION	hal/phydm/phydm.h	/^	ODM_RF_CALIBRATION			= BIT26,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_RF_CAL_T	hal/phydm/phydm_powertracking_ap.h	/^}ODM_RF_CAL_T,*PODM_RF_CAL_T;$/;"	t	typeref:struct:ODM_RF_Calibration_Structure
-ODM_RF_CAL_T	hal/phydm/phydm_powertracking_ce.h	/^}ODM_RF_CAL_T,*PODM_RF_CAL_T;$/;"	t	typeref:struct:ODM_RF_Calibration_Structure
-ODM_RF_CAL_T	hal/phydm/phydm_powertracking_win.h	/^}ODM_RF_CAL_T,*PODM_RF_CAL_T;$/;"	t	typeref:struct:ODM_RF_Calibration_Structure
-ODM_RF_Calibration_Structure	hal/phydm/phydm_powertracking_ap.h	/^typedef struct ODM_RF_Calibration_Structure$/;"	s
-ODM_RF_Calibration_Structure	hal/phydm/phydm_powertracking_ce.h	/^typedef struct ODM_RF_Calibration_Structure$/;"	s
-ODM_RF_Calibration_Structure	hal/phydm/phydm_powertracking_win.h	/^typedef struct ODM_RF_Calibration_Structure$/;"	s
-ODM_RF_D	hal/phydm/phydm_pre_define.h	/^	ODM_RF_D = BIT3,$/;"	e	enum:tag_ODM_RF_Path_Bit_Definition
-ODM_RF_INTERFACE_OUTPUT	hal/phydm/phydm_reg.h	65;"	d
-ODM_RF_PATH_A	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_A = 0,   \/\/Radio Path A$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_AB	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_AB,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_ABC	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_ABC,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_ABCD	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_ABCD,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_AC	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_AC,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_ACD	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_ACD,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_AD	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_AD,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_B	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_B = 1,   \/\/Radio Path B$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_BC	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_BC,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_BCD	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_BCD,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_BD	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_BD,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_C	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_C = 2,   \/\/Radio Path C$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_CD	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_CD,$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_D	hal/phydm/phydm_pre_define.h	/^    ODM_RF_PATH_D = 3,   \/\/Radio Path D$/;"	e	enum:_ODM_RF_RADIO_PATH
-ODM_RF_PATH_E	hal/phydm/phydm_pre_define.h	/^}ODM_RF_PATH_E;$/;"	t	typeref:enum:tag_ODM_RF_Path_Bit_Definition
-ODM_RF_PATH_MAX	hal/phydm/phydm_pre_define.h	48;"	d
-ODM_RF_PATH_MAX_JAGUAR	hal/phydm/phydm_pre_define.h	49;"	d
-ODM_RF_RADIO_PATH_E	hal/phydm/phydm_pre_define.h	/^} ODM_RF_RADIO_PATH_E, *PODM_RF_RADIO_PATH_E;$/;"	t	typeref:enum:_ODM_RF_RADIO_PATH
-ODM_RF_RX_GAIN_TRACK	hal/phydm/phydm.h	/^	ODM_RF_RX_GAIN_TRACK			= BIT25,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_RF_Saving	hal/phydm/phydm_dynamicbbpowersaving.c	/^ODM_RF_Saving($/;"	f
-ODM_RF_TX_NUM_E	hal/phydm/phydm_pre_define.h	/^} ODM_RF_TX_NUM_E;$/;"	t	typeref:enum:tag_PHYDM_RF_TX_NUM
-ODM_RF_TX_PWR_TRACK	hal/phydm/phydm.h	/^	ODM_RF_TX_PWR_TRACK			= BIT24,$/;"	e	enum:_ODM_Support_Ability_Definition
-ODM_RF_TYPE_E	hal/phydm/phydm_pre_define.h	/^}ODM_RF_TYPE_E;$/;"	t	typeref:enum:tag_ODM_RF_Type_Definition
-ODM_RF_T_METER	hal/phydm/phydm_reg.h	108;"	d
-ODM_RF_T_METER_8812	hal/phydm/phydm_reg.h	112;"	d
-ODM_RF_T_METER_88E	hal/phydm/phydm_reg.h	110;"	d
-ODM_RF_T_METER_92D	hal/phydm/phydm_reg.h	109;"	d
-ODM_RF_T_METER_92E	hal/phydm/phydm_reg.h	111;"	d
-ODM_RTL8188E	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8188E	=	BIT0,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8188F	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8188F	=	BIT10,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8192E	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8192E	=	BIT3,	$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8195A	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8195A	=	BIT9,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8197F	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8197F	=	BIT12,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8198F	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8198F	=	BIT15	$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8703B	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8703B	=	BIT8,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8723B	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8723B	=	BIT4,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8723D	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8723D	=	BIT11,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8812	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8812	=	BIT1,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8814A	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8814A	=	BIT5,	$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8814B	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8814B	=	BIT14,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8821	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8821	=	BIT2,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8821C	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8821C	=	BIT13,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8822B	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8822B	=	BIT7,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RTL8881A	hal/phydm/phydm_pre_define.h	/^	ODM_RTL8881A	=	BIT6,$/;"	e	enum:tag_ODM_Support_IC_Type_Definition
-ODM_RT_ASSERT	hal/phydm/phydm_debug.h	179;"	d
-ODM_RT_ASSERT	hal/phydm/phydm_debug.h	205;"	d
-ODM_RT_TRACE	hal/phydm/phydm_debug.h	149;"	d
-ODM_RT_TRACE	hal/phydm/phydm_debug.h	203;"	d
-ODM_RT_TRACE_F	hal/phydm/phydm_debug.h	173;"	d
-ODM_RT_TRACE_F	hal/phydm/phydm_debug.h	204;"	d
-ODM_R_AGC_PAR	hal/phydm/phydm_reg.h	88;"	d
-ODM_R_ANT_SELECT	hal/phydm/phydm_reg.h	71;"	d
-ODM_R_A_AGC_CORE1	hal/phydm/phydm_reg.h	85;"	d
-ODM_R_A_AGC_CORE2	hal/phydm/phydm_reg.h	86;"	d
-ODM_R_A_RXIQI	hal/phydm/phydm_reg.h	84;"	d
-ODM_R_B_AGC_CORE1	hal/phydm/phydm_reg.h	87;"	d
-ODM_R_HTSTF_AGC_PAR	hal/phydm/phydm_reg.h	89;"	d
-ODM_RateAdaptiveStateApInit	hal/phydm/phydm_rainfo.c	/^ODM_RateAdaptiveStateApInit($/;"	f
-ODM_Read1Byte	hal/phydm/phydm_interface.c	/^ODM_Read1Byte($/;"	f
-ODM_Read2Byte	hal/phydm/phydm_interface.c	/^ODM_Read2Byte($/;"	f
-ODM_Read4Byte	hal/phydm/phydm_interface.c	/^ODM_Read4Byte($/;"	f
-ODM_ReadAndConfig_MP_8723D_AGC_TAB	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^ODM_ReadAndConfig_MP_8723D_AGC_TAB($/;"	f
-ODM_ReadAndConfig_MP_8723D_MAC_REG	hal/phydm/rtl8723d/halhwimg8723d_mac.c	/^ODM_ReadAndConfig_MP_8723D_MAC_REG($/;"	f
-ODM_ReadAndConfig_MP_8723D_PHY_REG	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^ODM_ReadAndConfig_MP_8723D_PHY_REG($/;"	f
-ODM_ReadAndConfig_MP_8723D_PHY_REG_PG	hal/phydm/rtl8723d/halhwimg8723d_bb.c	/^ODM_ReadAndConfig_MP_8723D_PHY_REG_PG($/;"	f
-ODM_ReadAndConfig_MP_8723D_RadioA	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^ODM_ReadAndConfig_MP_8723D_RadioA($/;"	f
-ODM_ReadAndConfig_MP_8723D_TXPWR_LMT	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^ODM_ReadAndConfig_MP_8723D_TXPWR_LMT($/;"	f
-ODM_ReadAndConfig_MP_8723D_TxPowerTrack_PCIE	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^ODM_ReadAndConfig_MP_8723D_TxPowerTrack_PCIE($/;"	f
-ODM_ReadAndConfig_MP_8723D_TxPowerTrack_SDIO	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^ODM_ReadAndConfig_MP_8723D_TxPowerTrack_SDIO($/;"	f
-ODM_ReadAndConfig_MP_8723D_TxPowerTrack_USB	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^ODM_ReadAndConfig_MP_8723D_TxPowerTrack_USB($/;"	f
-ODM_ReadAndConfig_MP_8723D_TxXtalTrack	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^ODM_ReadAndConfig_MP_8723D_TxXtalTrack($/;"	f
-ODM_ReadFirmware_MP_8723D_FW_AP	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^ODM_ReadFirmware_MP_8723D_FW_AP($/;"	f
-ODM_ReadFirmware_MP_8723D_FW_NIC	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^ODM_ReadFirmware_MP_8723D_FW_NIC($/;"	f
-ODM_ReadFirmware_MP_8723D_FW_WoWLAN	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^ODM_ReadFirmware_MP_8723D_FW_WoWLAN($/;"	f
-ODM_ReleaseAllTimers	hal/phydm/phydm.c	/^ODM_ReleaseAllTimers($/;"	f
-ODM_ReleaseSpinLock	hal/phydm/phydm_interface.c	/^ODM_ReleaseSpinLock(	$/;"	f
-ODM_ReleaseTimer	hal/phydm/phydm_interface.c	/^ODM_ReleaseTimer($/;"	f
-ODM_ResetIQKResult	hal/phydm/halphyrf_ap.c	/^ODM_ResetIQKResult($/;"	f
-ODM_ResetIQKResult	hal/phydm/halphyrf_ce.c	/^ODM_ResetIQKResult($/;"	f
-ODM_ResetIQKResult	hal/phydm/halphyrf_win.c	/^ODM_ResetIQKResult($/;"	f
-ODM_SCAN	hal/phydm/phydm_pre_define.h	/^	ODM_SCAN 			= BIT2,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_SECURITY_E	hal/phydm/phydm_pre_define.h	/^}ODM_SECURITY_E;$/;"	t	typeref:enum:tag_Security_Definition
-ODM_SEC_AESCCMP	hal/phydm/phydm_pre_define.h	/^	ODM_SEC_AESCCMP 		= 4,$/;"	e	enum:tag_Security_Definition
-ODM_SEC_OPEN	hal/phydm/phydm_pre_define.h	/^	ODM_SEC_OPEN 			= 0,$/;"	e	enum:tag_Security_Definition
-ODM_SEC_RESERVE	hal/phydm/phydm_pre_define.h	/^	ODM_SEC_RESERVE 		= 3,$/;"	e	enum:tag_Security_Definition
-ODM_SEC_SMS4	hal/phydm/phydm_pre_define.h	/^	ODM_SEC_SMS4 			= 7,$/;"	e	enum:tag_Security_Definition
-ODM_SEC_TKIP	hal/phydm/phydm_pre_define.h	/^	ODM_SEC_TKIP 			= 2,$/;"	e	enum:tag_Security_Definition
-ODM_SEC_WEP104	hal/phydm/phydm_pre_define.h	/^	ODM_SEC_WEP104 		= 5,$/;"	e	enum:tag_Security_Definition
-ODM_SEC_WEP40	hal/phydm/phydm_pre_define.h	/^	ODM_SEC_WEP40 		= 1,$/;"	e	enum:tag_Security_Definition
-ODM_SMART_ANT_SUPPORT	hal/phydm/phydm_antdiv.h	66;"	d
-ODM_SMSP	hal/phydm/phydm_pre_define.h	/^	ODM_SMSP	= 0,$/;"	e	enum:tag_ODM_MAC_PHY_Mode_Definition
-ODM_STA_INFO_T	hal/phydm/phydm.h	/^} ODM_STA_INFO_T, *PODM_STA_INFO_T;$/;"	t	typeref:struct:_ODM_STA_INFO
-ODM_SW_AntDiv_Callback	hal/phydm/phydm_antdiv.c	/^ODM_SW_AntDiv_Callback($/;"	f
-ODM_SW_AntDiv_Callback	hal/phydm/phydm_antdiv.c	/^ODM_SW_AntDiv_Callback(void *FunctionContext)$/;"	f
-ODM_SW_AntDiv_WorkitemCallback	hal/phydm/phydm_antdiv.c	/^ODM_SW_AntDiv_WorkitemCallback($/;"	f
-ODM_ScheduleWorkItem	hal/phydm/phydm_interface.c	/^ODM_ScheduleWorkItem(	$/;"	f
-ODM_SetAntConfig	hal/phydm/phydm_antdiv.c	/^ODM_SetAntConfig($/;"	f
-ODM_SetBBReg	hal/phydm/phydm_interface.c	/^ODM_SetBBReg(	$/;"	f
-ODM_SetMACReg	hal/phydm/phydm_interface.c	/^ODM_SetMACReg(	$/;"	f
-ODM_SetRFReg	hal/phydm/phydm_interface.c	/^ODM_SetRFReg(	$/;"	f
-ODM_SetTimer	hal/phydm/phydm_interface.c	/^ODM_SetTimer(	$/;"	f
-ODM_SetTxAntByTxInfo	hal/phydm/phydm_antdiv.c	/^ODM_SetTxAntByTxInfo($/;"	f
-ODM_SetTxAntByTxInfo_HAL	hal/phydm/phydm_antdiv.c	/^ODM_SetTxAntByTxInfo_HAL($/;"	f
-ODM_SignConversion	hal/phydm/phydm.c	/^ODM_SignConversion($/;"	f
-ODM_SingleDualAntennaDefaultSetting	hal/phydm/phydm_antdect.c	/^ODM_SingleDualAntennaDefaultSetting($/;"	f
-ODM_SingleDualAntennaDetection	hal/phydm/phydm_antdect.c	/^ODM_SingleDualAntennaDetection($/;"	f
-ODM_SingleDualAntennaDetection_PSD	hal/phydm/phydm_antdect.c	/^ODM_SingleDualAntennaDetection_PSD($/;"	f
-ODM_StallExecution	hal/phydm/phydm_interface.c	/^ODM_StallExecution(	$/;"	f
-ODM_StartWorkItem	hal/phydm/phydm_interface.c	/^ODM_StartWorkItem(	$/;"	f
-ODM_StopAllThreads	hal/phydm/phydm.c	/^ODM_StopAllThreads($/;"	f
-ODM_StopAntennaSwitchDm	hal/phydm/phydm_antdiv.c	/^ODM_StopAntennaSwitchDm($/;"	f
-ODM_StopWorkItem	hal/phydm/phydm_interface.c	/^ODM_StopWorkItem(	$/;"	f
-ODM_SwAntDivCheckBeforeLink	hal/phydm/phydm_antdect.c	/^ODM_SwAntDivCheckBeforeLink($/;"	f
-ODM_SwAntDivRestAfterLink	hal/phydm/phydm_antdiv.c	/^ODM_SwAntDivRestAfterLink($/;"	f
-ODM_TARGET_CHNL_NUM_2G_5G	hal/phydm/halphyrf_ap.h	163;"	d
-ODM_TARGET_CHNL_NUM_2G_5G	hal/phydm/halphyrf_ce.h	102;"	d
-ODM_TARGET_CHNL_NUM_2G_5G	hal/phydm/halphyrf_win.h	103;"	d
-ODM_TSMC	hal/phydm/phydm_pre_define.h	/^	ODM_TSMC 	=	0,$/;"	e	enum:tag_ODM_Fab_Version_Definition
-ODM_TXAGC_A_1_MCS32	hal/phydm/phydm_reg.h	99;"	d
-ODM_TXAGC_A_24_54	hal/phydm/phydm_reg.h	98;"	d
-ODM_TXAGC_A_6_18	hal/phydm/phydm_reg.h	97;"	d
-ODM_TXAGC_A_MCS0_MCS3	hal/phydm/phydm_reg.h	100;"	d
-ODM_TXAGC_A_MCS12_MCS15	hal/phydm/phydm_reg.h	103;"	d
-ODM_TXAGC_A_MCS4_MCS7	hal/phydm/phydm_reg.h	101;"	d
-ODM_TXAGC_A_MCS8_MCS11	hal/phydm/phydm_reg.h	102;"	d
-ODM_TXAGC_B_11_A_2_11	hal/phydm/phydm_reg.h	67;"	d
-ODM_TXAGC_B_24_54	hal/phydm/phydm_reg.h	59;"	d
-ODM_TXAGC_B_6_18	hal/phydm/phydm_reg.h	58;"	d
-ODM_TXAGC_B_MCS0_MCS3	hal/phydm/phydm_reg.h	61;"	d
-ODM_TXAGC_B_MCS12_MCS15	hal/phydm/phydm_reg.h	66;"	d
-ODM_TXAGC_B_MCS32_5	hal/phydm/phydm_reg.h	60;"	d
-ODM_TXAGC_B_MCS4_MCS7	hal/phydm/phydm_reg.h	62;"	d
-ODM_TXAGC_B_MCS8_MCS11	hal/phydm/phydm_reg.h	63;"	d
-ODM_TXPAUSE	hal/phydm/phydm_reg.h	46;"	d
-ODM_TXPWRTRACK_MAX_IDX_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	32;"	d	file:
-ODM_TXPowerTrackingCallback_ThermalMeter	hal/phydm/halphyrf_ap.c	/^ODM_TXPowerTrackingCallback_ThermalMeter($/;"	f
-ODM_TXPowerTrackingCallback_ThermalMeter	hal/phydm/halphyrf_ce.c	/^ODM_TXPowerTrackingCallback_ThermalMeter($/;"	f
-ODM_TXPowerTrackingCallback_ThermalMeter	hal/phydm/halphyrf_win.c	/^ODM_TXPowerTrackingCallback_ThermalMeter($/;"	f
-ODM_TXPowerTrackingCallback_ThermalMeter_92E	hal/phydm/halphyrf_ap.c	/^ODM_TXPowerTrackingCallback_ThermalMeter_92E($/;"	f
-ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries	hal/phydm/halphyrf_ap.c	/^ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries($/;"	f
-ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries2	hal/phydm/halphyrf_ap.c	/^ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries2($/;"	f
-ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries3	hal/phydm/halphyrf_ap.c	/^ODM_TXPowerTrackingCallback_ThermalMeter_JaguarSeries3($/;"	f
-ODM_TXPowerTrackingCheck	hal/phydm/phydm_powertracking_ap.c	/^ODM_TXPowerTrackingCheck($/;"	f
-ODM_TXPowerTrackingCheck	hal/phydm/phydm_powertracking_ce.c	/^ODM_TXPowerTrackingCheck($/;"	f
-ODM_TXPowerTrackingCheck	hal/phydm/phydm_powertracking_win.c	/^ODM_TXPowerTrackingCheck($/;"	f
-ODM_TX_PWR_TRAINING_A	hal/phydm/phydm_reg.h	90;"	d
-ODM_TX_PWR_TRAINING_B	hal/phydm/phydm_reg.h	91;"	d
-ODM_TYPE_ALNA_E	hal/phydm/phydm_pre_define.h	/^}ODM_TYPE_ALNA_E;$/;"	t	typeref:enum:tag_ODM_TYPE_ALNA_Definition
-ODM_TYPE_APA_E	hal/phydm/phydm_pre_define.h	/^}ODM_TYPE_APA_E;$/;"	t	typeref:enum:tag_ODM_TYPE_APA_Definition
-ODM_TYPE_GLNA_E	hal/phydm/phydm_pre_define.h	/^}ODM_TYPE_GLNA_E;$/;"	t	typeref:enum:tag_ODM_TYPE_GLNA_Definition
-ODM_TYPE_GPA_E	hal/phydm/phydm_pre_define.h	/^}ODM_TYPE_GPA_E;$/;"	t	typeref:enum:tag_ODM_TYPE_GPA_Definition
-ODM_TxPwrTrackSetPwr	hal/phydm/halphyrf_ap.h	/^	FuncSetPwr 	ODM_TxPwrTrackSetPwr;$/;"	m	struct:_TXPWRTRACK_CFG
-ODM_TxPwrTrackSetPwr	hal/phydm/halphyrf_ce.h	/^	FuncSetPwr 	ODM_TxPwrTrackSetPwr;$/;"	m	struct:_TXPWRTRACK_CFG
-ODM_TxPwrTrackSetPwr	hal/phydm/halphyrf_win.h	/^	FuncSetPwr 	ODM_TxPwrTrackSetPwr;$/;"	m	struct:_TXPWRTRACK_CFG
-ODM_TxPwrTrackSetPwr_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^ODM_TxPwrTrackSetPwr_8723D($/;"	f
-ODM_TxXtalTrackSetXtal	hal/phydm/halphyrf_ce.h	/^	FuncSetXtal			ODM_TxXtalTrackSetXtal;$/;"	m	struct:_TXPWRTRACK_CFG
-ODM_TxXtalTrackSetXtal	hal/phydm/halphyrf_win.h	/^	FuncSetXtal			ODM_TxXtalTrackSetXtal;$/;"	m	struct:_TXPWRTRACK_CFG
-ODM_TxXtalTrackSetXtal_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^ODM_TxXtalTrackSetXtal_8723D($/;"	f
-ODM_UMC	hal/phydm/phydm_pre_define.h	/^	ODM_UMC 	=	1,$/;"	e	enum:tag_ODM_Fab_Version_Definition
-ODM_UpdateInitRateWorkItemCallback	hal/phydm/phydm_rainfo.c	/^ODM_UpdateInitRateWorkItemCallback($/;"	f
-ODM_UpdateMpDriverStatus	hal/phydm/phydm.c	/^ODM_UpdateMpDriverStatus($/;"	f
-ODM_UpdateNoisyState	hal/phydm/phydm_rainfo.c	/^ODM_UpdateNoisyState($/;"	f
-ODM_UpdateRxIdleAnt	hal/phydm/phydm_antdiv.c	/^ODM_UpdateRxIdleAnt($/;"	f
-ODM_UpdateRxIdleAnt_8723B	hal/phydm/phydm_antdiv.c	/^ODM_UpdateRxIdleAnt_8723B($/;"	f
-ODM_WEP_WPA_MIXED	hal/phydm/phydm_pre_define.h	/^	ODM_WEP_WPA_MIXED    = 6, \/\/ WEP + WPA$/;"	e	enum:tag_Security_Definition
-ODM_WIFI_DIRECT	hal/phydm/phydm_pre_define.h	/^	ODM_WIFI_DIRECT	= BIT7,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_WIFI_DISPLAY	hal/phydm/phydm_pre_define.h	/^	ODM_WIFI_DISPLAY	= BIT8,$/;"	e	enum:tag_Operation_Mode_Definition
-ODM_WIN	hal/phydm/phydm_types.h	27;"	d
-ODM_WIRELESS_MODE_E	hal/phydm/phydm_pre_define.h	/^}ODM_WIRELESS_MODE_E;$/;"	t	typeref:enum:tag_Wireless_Mode_Definition
-ODM_WM_A	hal/phydm/phydm_pre_define.h	/^	ODM_WM_A			= BIT0, \/* 0x1*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_A	hal/phydm/phydm_pre_define.h	/^	ODM_WM_A			= BIT2,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_AC	hal/phydm/phydm_pre_define.h	/^	ODM_WM_AC		= BIT6,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_AC_24G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_AC_24G	= BIT7,\/* 0x80*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_AC_5G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_AC_5G		= BIT6,\/* 0x40*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_AC_ONLY	hal/phydm/phydm_pre_define.h	/^	ODM_WM_AC_ONLY	= BIT8,\/* 0x100*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_AUTO	hal/phydm/phydm_pre_define.h	/^	ODM_WM_AUTO		= BIT3,\/* 0x8*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_AUTO	hal/phydm/phydm_pre_define.h	/^	ODM_WM_AUTO		= BIT5,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_B	hal/phydm/phydm_pre_define.h	/^	ODM_WM_B			= BIT0,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_B	hal/phydm/phydm_pre_define.h	/^	ODM_WM_B			= BIT1, \/* 0x2*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_G			= BIT1,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_G			= BIT2,\/* 0x4*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_MAX	hal/phydm/phydm_pre_define.h	/^	ODM_WM_MAX		= BIT11\/* 0x800*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_N24G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_N24G		= BIT3,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_N24G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_N24G		= BIT4,\/* 0x10*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_N5G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_N5G		= BIT4,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_N5G	hal/phydm/phydm_pre_define.h	/^	ODM_WM_N5G		= BIT5,\/* 0x20*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_UNKNOW	hal/phydm/phydm_pre_define.h	/^	ODM_WM_UNKNOW	= 0x0,$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_WM_UNKNOWN	hal/phydm/phydm_pre_define.h	/^	ODM_WM_UNKNOWN	= 0x00,\/*0x0*\/$/;"	e	enum:tag_Wireless_Mode_Definition
-ODM_Write1Byte	hal/phydm/phydm_interface.c	/^ODM_Write1Byte($/;"	f
-ODM_Write2Byte	hal/phydm/phydm_interface.c	/^ODM_Write2Byte($/;"	f
-ODM_Write4Byte	hal/phydm/phydm_interface.c	/^ODM_Write4Byte($/;"	f
-ODM_Write_CCK_CCA_Thres	hal/phydm/phydm_dig.c	/^ODM_Write_CCK_CCA_Thres($/;"	f
-ODM_Write_DIG	hal/phydm/phydm_dig.c	/^ODM_Write_DIG($/;"	f
-ODM_XTXR	hal/phydm/phydm_pre_define.h	/^	ODM_XTXR$/;"	e	enum:tag_ODM_RF_Type_Definition
-ODM_dbg_enter	hal/phydm/phydm_debug.h	186;"	d
-ODM_dbg_enter	hal/phydm/phydm_debug.h	206;"	d
-ODM_dbg_exit	hal/phydm/phydm_debug.h	187;"	d
-ODM_dbg_exit	hal/phydm/phydm_debug.h	207;"	d
-ODM_dbg_trace	hal/phydm/phydm_debug.h	188;"	d
-ODM_dbg_trace	hal/phydm/phydm_debug.h	208;"	d
-ODM_delay_ms	hal/phydm/phydm_interface.c	/^ODM_delay_ms(IN u4Byte	ms)$/;"	f
-ODM_delay_us	hal/phydm/phydm_interface.c	/^ODM_delay_us(IN u4Byte	us)$/;"	f
-ODM_sleep_ms	hal/phydm/phydm_interface.c	/^ODM_sleep_ms(IN u4Byte	ms)$/;"	f
-ODM_sleep_us	hal/phydm/phydm_interface.c	/^ODM_sleep_us(IN u4Byte	us)$/;"	f
-OFDM	include/ieee80211.h	/^	OFDM = 1,$/;"	e	enum:_RATE_SECTION
-OFDMSwingTable	hal/phydm/phydm_powertracking_ap.c	/^u4Byte OFDMSwingTable[OFDM_TABLE_SIZE_92D] = {$/;"	v
-OFDMSwingTable	hal/phydm/phydm_powertracking_ce.c	/^u4Byte	OFDMSwingTable[OFDM_TABLE_SIZE] = {$/;"	v
-OFDMSwingTable	hal/phydm/phydm_powertracking_win.c	/^u4Byte	OFDMSwingTable[OFDM_TABLE_SIZE] = {$/;"	v
-OFDMSwingTable_8812	hal/phydm/phydm_powertracking_ap.c	/^u4Byte OFDMSwingTable_8812[OFDM_TABLE_SIZE_8812] = {	$/;"	v
-OFDMSwingTable_92E	hal/phydm/phydm_powertracking_ap.c	/^u4Byte OFDMSwingTable_92E[OFDM_TABLE_SIZE_92E] = {$/;"	v
-OFDMSwingTable_New	hal/phydm/phydm_powertracking_ap.c	/^u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE_92D] = {$/;"	v
-OFDMSwingTable_New	hal/phydm/phydm_powertracking_ce.c	/^u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE] = {$/;"	v
-OFDMSwingTable_New	hal/phydm/phydm_powertracking_win.c	/^u4Byte OFDMSwingTable_New[OFDM_TABLE_SIZE] = {$/;"	v
-OFDM_24G_Diff	include/hal_data.h	/^	s8	OFDM_24G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-OFDM_5G_Diff	include/hal_data.h	/^	s8	OFDM_5G_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:hal_com_data
-OFDM_ALL_OFF	include/rtw_mp.h	/^	OFDM_ALL_OFF		= 0,$/;"	e	enum:_OFDM_TX_MODE
-OFDM_ContinuousTx	include/rtw_mp.h	/^	OFDM_ContinuousTx	= 1,$/;"	e	enum:_OFDM_TX_MODE
-OFDM_CtrlFrame_Cnt_aux	hal/phydm/phydm_antdiv.h	/^	u4Byte    OFDM_CtrlFrame_Cnt_aux;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-OFDM_CtrlFrame_Cnt_main	hal/phydm/phydm_antdiv.h	/^	u4Byte    OFDM_CtrlFrame_Cnt_main;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-OFDM_Diff	include/hal_pg.h	/^	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo24G
-OFDM_Diff	include/hal_pg.h	/^	s8 OFDM_Diff[MAX_RF_PATH][MAX_TX_COUNT];$/;"	m	struct:_TxPowerInfo5G
-OFDM_PHY	include/rtw_rf.h	24;"	d
-OFDM_RX_Cnt	hal/phydm/phydm.h	/^	u8Byte			OFDM_RX_Cnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-OFDM_SingleCarrier	include/rtw_mp.h	/^	OFDM_SingleCarrier	= 2,$/;"	e	enum:_OFDM_TX_MODE
-OFDM_SingleTone	include/rtw_mp.h	/^	OFDM_SingleTone	= 4,$/;"	e	enum:_OFDM_TX_MODE
-OFDM_Single_Tone_TX	include/rtw_mp.h	/^	OFDM_Single_Tone_TX       ,$/;"	e	enum:_TEST_MODE
-OFDM_TABLE_SIZE	hal/phydm/phydm_powertracking_ap.h	60;"	d
-OFDM_TABLE_SIZE	hal/phydm/phydm_powertracking_ce.h	28;"	d
-OFDM_TABLE_SIZE_8812	hal/phydm/phydm_powertracking_ap.h	103;"	d
-OFDM_TABLE_SIZE_92D	hal/phydm/phydm_powertracking_ap.h	59;"	d
-OFDM_TABLE_SIZE_92E	hal/phydm/phydm_powertracking_ap.h	96;"	d
-OFDM_TXSC	include/hal_phy.h	/^	u32			OFDM_TXSC:2;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-OFDM_TX_MODE	include/rtw_mp.h	/^} OFDM_TX_MODE;$/;"	t	typeref:enum:_OFDM_TX_MODE
-OFDM_counter_aux	hal/phydm/phydm_antdiv.h	/^	u4Byte    OFDM_counter_aux;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-OFDM_counter_main	hal/phydm/phydm_antdiv.h	/^	u4Byte    OFDM_counter_main;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-OFDM_index	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	OFDM_index[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-OFDM_index	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	OFDM_index[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-OFDM_index	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	OFDM_index[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-OFDM_pkt	include/sta_info.h	/^	u8	OFDM_pkt;$/;"	m	struct:_RSSI_STA
-OFFSET_SHT	include/rtl8188e_xmit.h	43;"	d
-OFFSET_SHT	include/rtl8192e_xmit.h	148;"	d
-OFFSET_SHT	include/rtl8812a_xmit.h	41;"	d
-OFFSET_SHT	include/rtl8814a_xmit.h	34;"	d
-OFFSET_SZ	include/rtl8188e_xmit.h	42;"	d
-OFFSET_SZ	include/rtl8192e_xmit.h	147;"	d
-OFFSET_SZ	include/rtl8812a_xmit.h	40;"	d
-OFFSET_SZ	include/rtl8814a_xmit.h	33;"	d
-OGF_EXTENSION	include/rtw_btcoex.h	252;"	d
-OID_802_11_CAPABILITY	include/rtw_ioctl.h	87;"	d
-OID_802_11_PMKID	include/rtw_ioctl.h	91;"	d
-OID_CE_USB_READ_REGISTRY	include/mp_custom_oid.h	206;"	d
-OID_CE_USB_WRITE_REGISTRY	include/mp_custom_oid.h	205;"	d
-OID_MP_SEG1	include/rtw_ioctl.h	119;"	d
-OID_MP_SEG2	include/rtw_ioctl.h	120;"	d
-OID_MP_SEG3	include/rtw_ioctl.h	122;"	d
-OID_MP_SEG4	include/rtw_ioctl.h	123;"	d
-OID_NDIS_SEG1	include/rtw_ioctl.h	96;"	d
-OID_NDIS_SEG10	include/rtw_ioctl.h	105;"	d
-OID_NDIS_SEG2	include/rtw_ioctl.h	97;"	d
-OID_NDIS_SEG3	include/rtw_ioctl.h	98;"	d
-OID_NDIS_SEG4	include/rtw_ioctl.h	99;"	d
-OID_NDIS_SEG5	include/rtw_ioctl.h	100;"	d
-OID_NDIS_SEG6	include/rtw_ioctl.h	101;"	d
-OID_NDIS_SEG7	include/rtw_ioctl.h	102;"	d
-OID_NDIS_SEG8	include/rtw_ioctl.h	103;"	d
-OID_NDIS_SEG9	include/rtw_ioctl.h	104;"	d
-OID_RT_AP_GET_ASSOCIATED_STATION_LIST	include/mp_custom_oid.h	219;"	d
-OID_RT_AP_GET_CURRENT_TIME_STAMP	include/mp_custom_oid.h	220;"	d
-OID_RT_AP_SET_DTIM_PERIOD	include/mp_custom_oid.h	222;"	d
-OID_RT_AP_SET_PASSPHRASE	include/mp_custom_oid.h	224;"	d
-OID_RT_AP_SUPPORTED	include/mp_custom_oid.h	223;"	d
-OID_RT_AP_SWITCH_INTO_AP_MODE	include/mp_custom_oid.h	221;"	d
-OID_RT_AUTH_STATUS	include/mp_custom_oid.h	90;"	d
-OID_RT_CHANNELPLAN_BY_COUNTRY	include/mp_custom_oid.h	172;"	d
-OID_RT_CURRENT_TX_POWER_LEVEL	include/mp_custom_oid.h	165;"	d
-OID_RT_DEDICATE_PROBE	include/mp_custom_oid.h	146;"	d
-OID_RT_DESIRED_RATES	include/mp_custom_oid.h	113;"	d
-OID_RT_DRIVER_OPTION	include/mp_custom_oid.h	88;"	d
-OID_RT_FORCED_DATA_RATE	include/mp_custom_oid.h	192;"	d
-OID_RT_GET_AP_IP	include/mp_custom_oid.h	141;"	d
-OID_RT_GET_BSS_WIRELESS_MODE	include/mp_custom_oid.h	195;"	d
-OID_RT_GET_CCA_ERR	include/mp_custom_oid.h	151;"	d
-OID_RT_GET_CCA_FALLBACK_EVALUATE_TIMES	include/mp_custom_oid.h	156;"	d
-OID_RT_GET_CCA_FALLBACK_THRESHOLD	include/mp_custom_oid.h	153;"	d
-OID_RT_GET_CCA_UPGRADE_EVALUATE_TIMES	include/mp_custom_oid.h	155;"	d
-OID_RT_GET_CCA_UPGRADE_THRESHOLD	include/mp_custom_oid.h	152;"	d
-OID_RT_GET_CHANNEL	include/mp_custom_oid.h	168;"	d
-OID_RT_GET_CHANNELPLAN	include/mp_custom_oid.h	142;"	d
-OID_RT_GET_CHANNEL_LIST	include/mp_custom_oid.h	185;"	d
-OID_RT_GET_CONNECT_STATE	include/mp_custom_oid.h	117;"	d
-OID_RT_GET_DCST_CURRENT_THRESHOLD	include/mp_custom_oid.h	149;"	d
-OID_RT_GET_DCST_EVALUATE_PERIOD	include/mp_custom_oid.h	161;"	d
-OID_RT_GET_DCST_TIME_UNIT_INDEX	include/mp_custom_oid.h	162;"	d
-OID_RT_GET_DRIVER_UP_DELTA_TIME	include/mp_custom_oid.h	140;"	d
-OID_RT_GET_EFUSE_CURRENT_SIZE	include/mp_custom_oid.h	325;"	d
-OID_RT_GET_EFUSE_MAX_SIZE	include/mp_custom_oid.h	332;"	d
-OID_RT_GET_ENC_KEY_MATCH_COUNT	include/mp_custom_oid.h	167;"	d
-OID_RT_GET_ENC_KEY_MISMATCH_COUNT	include/mp_custom_oid.h	166;"	d
-OID_RT_GET_HARDWARE_RADIO_OFF	include/mp_custom_oid.h	171;"	d
-OID_RT_GET_HARDWARE_VERSION	include/mp_custom_oid.h	174;"	d
-OID_RT_GET_HEADER_FAIL	include/mp_custom_oid.h	183;"	d
-OID_RT_GET_IS_PRIVACY	include/mp_custom_oid.h	176;"	d
-OID_RT_GET_IS_ROAMING	include/mp_custom_oid.h	175;"	d
-OID_RT_GET_KEY_MISMATCH	include/mp_custom_oid.h	177;"	d
-OID_RT_GET_LARGE_PACKET_CRC	include/mp_custom_oid.h	127;"	d
-OID_RT_GET_LOG	include/mp_custom_oid.h	181;"	d
-OID_RT_GET_MIDDLE_PACKET_CRC	include/mp_custom_oid.h	126;"	d
-OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR	include/mp_custom_oid.h	344;"	d
-OID_RT_GET_PHY_RX_PACKET_RECEIVED	include/mp_custom_oid.h	343;"	d
-OID_RT_GET_POWER_MODE	include/mp_custom_oid.h	348;"	d
-OID_RT_GET_PREAMBLE_MODE	include/mp_custom_oid.h	139;"	d
-OID_RT_GET_RF_VENDER	include/mp_custom_oid.h	145;"	d
-OID_RT_GET_RX_ICV_ERR	include/mp_custom_oid.h	136;"	d
-OID_RT_GET_RX_RETRY	include/mp_custom_oid.h	129;"	d
-OID_RT_GET_RX_TOTAL_PACKET	include/mp_custom_oid.h	133;"	d
-OID_RT_GET_SCAN_IN_PROGRESS	include/mp_custom_oid.h	186;"	d
-OID_RT_GET_SIGNAL_QUALITY	include/mp_custom_oid.h	124;"	d
-OID_RT_GET_SMALL_PACKET_CRC	include/mp_custom_oid.h	125;"	d
-OID_RT_GET_TOTAL_RX_BYTES	include/mp_custom_oid.h	164;"	d
-OID_RT_GET_TOTAL_TX_BYTES	include/mp_custom_oid.h	163;"	d
-OID_RT_GET_TX_BEACON_ERR	include/mp_custom_oid.h	135;"	d
-OID_RT_GET_TX_BEACON_OK	include/mp_custom_oid.h	134;"	d
-OID_RT_GET_TX_INFO	include/mp_custom_oid.h	187;"	d
-OID_RT_GET_TX_RETRY	include/mp_custom_oid.h	128;"	d
-OID_RT_MH_VENDER_ID	include/mp_custom_oid.h	234;"	d
-OID_RT_POLL_RX_STATUS	include/mp_custom_oid.h	278;"	d
-OID_RT_PRO8187_WI_POLL	include/mp_custom_oid.h	227;"	d
-OID_RT_PRO8711_JOIN_BSS	include/mp_custom_oid.h	237;"	d
-OID_RT_PRO8711_PKT_LOSS	include/mp_custom_oid.h	254;"	d
-OID_RT_PRO8711_WI_POLL	include/mp_custom_oid.h	253;"	d
-OID_RT_PRO_871X_DRV_EXT	include/mp_custom_oid.h	302;"	d
-OID_RT_PRO_ADD_STA_INFO	include/mp_custom_oid.h	316;"	d
-OID_RT_PRO_BURST_READ_REGISTER	include/mp_custom_oid.h	242;"	d
-OID_RT_PRO_BURST_WRITE_REGISTER	include/mp_custom_oid.h	243;"	d
-OID_RT_PRO_CFG_DEBUG_MESSAGE	include/mp_custom_oid.h	280;"	d
-OID_RT_PRO_DELE_STA_INFO	include/mp_custom_oid.h	317;"	d
-OID_RT_PRO_EFUSE	include/mp_custom_oid.h	350;"	d
-OID_RT_PRO_EFUSE_MAP	include/mp_custom_oid.h	351;"	d
-OID_RT_PRO_ENCRYPTION_CTRL	include/mp_custom_oid.h	315;"	d
-OID_RT_PRO_FOR_EVM_TEST_SETTING	include/mp_custom_oid.h	338;"	d
-OID_RT_PRO_GET_CR_SIGNAL_QUALITY	include/mp_custom_oid.h	57;"	d
-OID_RT_PRO_GET_INTEGRATOR	include/mp_custom_oid.h	61;"	d
-OID_RT_PRO_GET_SIGNAL_QUALITY	include/mp_custom_oid.h	62;"	d
-OID_RT_PRO_GET_THERMAL_METER	include/mp_custom_oid.h	340;"	d
-OID_RT_PRO_GET_TX_POWER_CONTROL	include/mp_custom_oid.h	56;"	d
-OID_RT_PRO_H2C_C2H_LBK_TEST	include/mp_custom_oid.h	313;"	d
-OID_RT_PRO_H2C_CMD_EVENT_MODE	include/mp_custom_oid.h	262;"	d
-OID_RT_PRO_H2C_CMD_MODE	include/mp_custom_oid.h	260;"	d
-OID_RT_PRO_H2C_CMD_RSP_MODE	include/mp_custom_oid.h	261;"	d
-OID_RT_PRO_H2C_GET_RATE_TABLE	include/mp_custom_oid.h	312;"	d
-OID_RT_PRO_H2C_QUERY_RESULT	include/mp_custom_oid.h	251;"	d
-OID_RT_PRO_H2C_SET_COMMAND	include/mp_custom_oid.h	250;"	d
-OID_RT_PRO_H2C_SET_RATE_TABLE	include/mp_custom_oid.h	311;"	d
-OID_RT_PRO_QRY_PWRMGT_TEST	include/mp_custom_oid.h	274;"	d
-OID_RT_PRO_QRY_PWRSTATE	include/mp_custom_oid.h	287;"	d
-OID_RT_PRO_QUERY_CURRENT_ADDRESS	include/mp_custom_oid.h	77;"	d
-OID_RT_PRO_QUERY_DR_VARIABLE	include/mp_custom_oid.h	318;"	d
-OID_RT_PRO_QUERY_EEPROM_TYPE	include/mp_custom_oid.h	63;"	d
-OID_RT_PRO_QUERY_PERMANENT_ADDRESS	include/mp_custom_oid.h	78;"	d
-OID_RT_PRO_QUERY_RF_TYPE	include/mp_custom_oid.h	216;"	d
-OID_RT_PRO_QUERY_RX_PACKET_CRC32_ERROR	include/mp_custom_oid.h	76;"	d
-OID_RT_PRO_QUERY_RX_PACKET_RECEIVED	include/mp_custom_oid.h	75;"	d
-OID_RT_PRO_QUERY_TX_PACKET_SENT	include/mp_custom_oid.h	73;"	d
-OID_RT_PRO_READ16_EEPROM	include/mp_custom_oid.h	247;"	d
-OID_RT_PRO_READ_BB_REG	include/mp_custom_oid.h	229;"	d
-OID_RT_PRO_READ_CIS_DATA	include/mp_custom_oid.h	67;"	d
-OID_RT_PRO_READ_EEPROM	include/mp_custom_oid.h	71;"	d
-OID_RT_PRO_READ_EEPROM_BYTE	include/mp_custom_oid.h	83;"	d
-OID_RT_PRO_READ_EFUSE	include/mp_custom_oid.h	322;"	d
-OID_RT_PRO_READ_MAC_ADDRESS	include/mp_custom_oid.h	65;"	d
-OID_RT_PRO_READ_POWER_CONTROL	include/mp_custom_oid.h	69;"	d
-OID_RT_PRO_READ_REGISTER	include/mp_custom_oid.h	239;"	d
-OID_RT_PRO_READ_RF_REG	include/mp_custom_oid.h	231;"	d
-OID_RT_PRO_READ_TSSI	include/mp_custom_oid.h	283;"	d
-OID_RT_PRO_RECEIVE_PACKET	include/mp_custom_oid.h	80;"	d
-OID_RT_PRO_RESET_DUT	include/mp_custom_oid.h	38;"	d
-OID_RT_PRO_RESET_RX_PACKET_RECEIVED	include/mp_custom_oid.h	74;"	d
-OID_RT_PRO_RESET_TX_PACKET_SENT	include/mp_custom_oid.h	72;"	d
-OID_RT_PRO_RF_READ_REGISTRY	include/mp_custom_oid.h	215;"	d
-OID_RT_PRO_RF_WRITE_REGISTRY	include/mp_custom_oid.h	214;"	d
-OID_RT_PRO_RW_ACCESS_PROTOCOL_TEST	include/mp_custom_oid.h	264;"	d
-OID_RT_PRO_RW_EFUSE_PGPKT	include/mp_custom_oid.h	324;"	d
-OID_RT_PRO_RX_FILTER	include/mp_custom_oid.h	200;"	d
-OID_RT_PRO_RX_FILTER_PATTERN	include/mp_custom_oid.h	147;"	d
-OID_RT_PRO_RX_PACKET_TYPE	include/mp_custom_oid.h	320;"	d
-OID_RT_PRO_SCSI_ACCESS_TEST	include/mp_custom_oid.h	266;"	d
-OID_RT_PRO_SCSI_AUTO_TEST	include/mp_custom_oid.h	306;"	d
-OID_RT_PRO_SCSI_TCPIPOFFLOAD_IN	include/mp_custom_oid.h	269;"	d
-OID_RT_PRO_SCSI_TCPIPOFFLOAD_OUT	include/mp_custom_oid.h	268;"	d
-OID_RT_PRO_SET_ANTENNA_BB	include/mp_custom_oid.h	51;"	d
-OID_RT_PRO_SET_BASIC_RATE	include/mp_custom_oid.h	282;"	d
-OID_RT_PRO_SET_BB_RF_SHUTDOWN_MODE	include/mp_custom_oid.h	211;"	d
-OID_RT_PRO_SET_BB_RF_STANDBY_MODE	include/mp_custom_oid.h	210;"	d
-OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX	include/mp_custom_oid.h	95;"	d
-OID_RT_PRO_SET_CHANNEL_DIRECT_CALL	include/mp_custom_oid.h	46;"	d
-OID_RT_PRO_SET_CONTINUOUS_TX	include/mp_custom_oid.h	93;"	d
-OID_RT_PRO_SET_CR_NEW_FILTER	include/mp_custom_oid.h	53;"	d
-OID_RT_PRO_SET_CR_SCRAMBLER	include/mp_custom_oid.h	52;"	d
-OID_RT_PRO_SET_CR_SETPOINT	include/mp_custom_oid.h	58;"	d
-OID_RT_PRO_SET_CR_TX_CONFIG	include/mp_custom_oid.h	55;"	d
-OID_RT_PRO_SET_DATA_RATE	include/mp_custom_oid.h	39;"	d
-OID_RT_PRO_SET_DATA_RATE_EX	include/mp_custom_oid.h	281;"	d
-OID_RT_PRO_SET_FILTER_BB	include/mp_custom_oid.h	44;"	d
-OID_RT_PRO_SET_FW_DIG_STATE	include/mp_custom_oid.h	130;"	d
-OID_RT_PRO_SET_FW_RA_STATE	include/mp_custom_oid.h	131;"	d
-OID_RT_PRO_SET_INITIAL_GAIN	include/mp_custom_oid.h	209;"	d
-OID_RT_PRO_SET_INTEGRATOR	include/mp_custom_oid.h	59;"	d
-OID_RT_PRO_SET_MANUAL_DIVERSITY_BB	include/mp_custom_oid.h	45;"	d
-OID_RT_PRO_SET_MODULATION	include/mp_custom_oid.h	84;"	d
-OID_RT_PRO_SET_PHILIPS_RF_PARAMETERS	include/mp_custom_oid.h	79;"	d
-OID_RT_PRO_SET_PKT_TEST_MODE	include/mp_custom_oid.h	336;"	d
-OID_RT_PRO_SET_POWER_TRACKING	include/mp_custom_oid.h	284;"	d
-OID_RT_PRO_SET_PREAMBLE	include/mp_custom_oid.h	42;"	d
-OID_RT_PRO_SET_PWRSTATE	include/mp_custom_oid.h	288;"	d
-OID_RT_PRO_SET_RF_INTFS	include/mp_custom_oid.h	277;"	d
-OID_RT_PRO_SET_RX_CHARGE_PUMP	include/mp_custom_oid.h	213;"	d
-OID_RT_PRO_SET_SCRAMBLER	include/mp_custom_oid.h	43;"	d
-OID_RT_PRO_SET_SIGNAL_QUALITY	include/mp_custom_oid.h	60;"	d
-OID_RT_PRO_SET_SINGLE_CARRIER_TX	include/mp_custom_oid.h	94;"	d
-OID_RT_PRO_SET_SINGLE_TONE_TX	include/mp_custom_oid.h	96;"	d
-OID_RT_PRO_SET_SLEEP_MODE_DIRECT_CALL	include/mp_custom_oid.h	47;"	d
-OID_RT_PRO_SET_TX_AGC_OFFSET	include/mp_custom_oid.h	334;"	d
-OID_RT_PRO_SET_TX_ANTENNA_BB	include/mp_custom_oid.h	50;"	d
-OID_RT_PRO_SET_TX_CHARGE_PUMP	include/mp_custom_oid.h	212;"	d
-OID_RT_PRO_SET_TX_POWER_CONTROL	include/mp_custom_oid.h	54;"	d
-OID_RT_PRO_SET_WAKE_MODE_DIRECT_CALL	include/mp_custom_oid.h	48;"	d
-OID_RT_PRO_START_TEST	include/mp_custom_oid.h	40;"	d
-OID_RT_PRO_STOP_TEST	include/mp_custom_oid.h	41;"	d
-OID_RT_PRO_SYNCPAGERW_SRAM	include/mp_custom_oid.h	301;"	d
-OID_RT_PRO_USB_MAC_AC_FIFO_WRITE	include/mp_custom_oid.h	307;"	d
-OID_RT_PRO_USB_MAC_RX_FIFO_POLLING	include/mp_custom_oid.h	309;"	d
-OID_RT_PRO_USB_MAC_RX_FIFO_READ	include/mp_custom_oid.h	308;"	d
-OID_RT_PRO_USB_VENDOR_REQ	include/mp_custom_oid.h	305;"	d
-OID_RT_PRO_WAIT_C2H_EVENT	include/mp_custom_oid.h	263;"	d
-OID_RT_PRO_WRITE16_EEPROM	include/mp_custom_oid.h	248;"	d
-OID_RT_PRO_WRITE_BB_REG	include/mp_custom_oid.h	228;"	d
-OID_RT_PRO_WRITE_CIS_DATA	include/mp_custom_oid.h	66;"	d
-OID_RT_PRO_WRITE_EEPROM	include/mp_custom_oid.h	70;"	d
-OID_RT_PRO_WRITE_EEPROM_BYTE	include/mp_custom_oid.h	82;"	d
-OID_RT_PRO_WRITE_EFUSE	include/mp_custom_oid.h	323;"	d
-OID_RT_PRO_WRITE_MAC_ADDRESS	include/mp_custom_oid.h	64;"	d
-OID_RT_PRO_WRITE_POWER_CONTROL	include/mp_custom_oid.h	68;"	d
-OID_RT_PRO_WRITE_REGISTER	include/mp_custom_oid.h	240;"	d
-OID_RT_PRO_WRITE_RF_REG	include/mp_custom_oid.h	230;"	d
-OID_RT_PRO_WRITE_TXCMD	include/mp_custom_oid.h	245;"	d
-OID_RT_QRY_POLL_WKITEM	include/mp_custom_oid.h	298;"	d
-OID_RT_RD_ATTRIB_MEM	include/mp_custom_oid.h	255;"	d
-OID_RT_RESCAN	include/mp_custom_oid.h	118;"	d
-OID_RT_RESET_LOG	include/mp_custom_oid.h	180;"	d
-OID_RT_RESET_PHY_RX_PACKET_COUNT	include/mp_custom_oid.h	342;"	d
-OID_RT_RF_OFF	include/mp_custom_oid.h	89;"	d
-OID_RT_RF_READ_WRITE	include/mp_custom_oid.h	189;"	d
-OID_RT_RF_READ_WRITE_OFFSET	include/mp_custom_oid.h	188;"	d
-OID_RT_RPO_ASYNC_RWIO_POLL	include/mp_custom_oid.h	276;"	d
-OID_RT_RPO_ASYNC_RWIO_TEST	include/mp_custom_oid.h	275;"	d
-OID_RT_RPO_SET_PWRMGT_TEST	include/mp_custom_oid.h	273;"	d
-OID_RT_RRO_RX_PKTARRAY_VIA_IOCTRL	include/mp_custom_oid.h	271;"	d
-OID_RT_RRO_RX_PKT_VIA_IOCTRL	include/mp_custom_oid.h	270;"	d
-OID_RT_SCAN_AVAILABLE_BSSID	include/mp_custom_oid.h	173;"	d
-OID_RT_SCAN_WITH_MAGIC_PACKET	include/mp_custom_oid.h	197;"	d
-OID_RT_SET_BANDWIDTH	include/mp_custom_oid.h	327;"	d
-OID_RT_SET_BCN_INTVL	include/mp_custom_oid.h	144;"	d
-OID_RT_SET_BURST_READ_REG	include/mp_custom_oid.h	293;"	d
-OID_RT_SET_BURST_WRITE_REG	include/mp_custom_oid.h	294;"	d
-OID_RT_SET_CHANNEL	include/mp_custom_oid.h	122;"	d
-OID_RT_SET_CHANNELPLAN	include/mp_custom_oid.h	170;"	d
-OID_RT_SET_CRYSTAL_CAP	include/mp_custom_oid.h	328;"	d
-OID_RT_SET_DEFAULT_KEY_ID	include/mp_custom_oid.h	120;"	d
-OID_RT_SET_ENCRYPTION_ALGORITHM	include/mp_custom_oid.h	137;"	d
-OID_RT_SET_INDICATE_HIDDEN_AP	include/mp_custom_oid.h	182;"	d
-OID_RT_SET_KEY_LENGTH	include/mp_custom_oid.h	119;"	d
-OID_RT_SET_NO_AUTO_RESCAN	include/mp_custom_oid.h	138;"	d
-OID_RT_SET_POWER_DOWN	include/mp_custom_oid.h	346;"	d
-OID_RT_SET_PREAMBLE_MODE	include/mp_custom_oid.h	143;"	d
-OID_RT_SET_RATE_ADAPTIVE	include/mp_custom_oid.h	159;"	d
-OID_RT_SET_READ16_EEPROM	include/mp_custom_oid.h	296;"	d
-OID_RT_SET_READ_REG	include/mp_custom_oid.h	291;"	d
-OID_RT_SET_RSSI_ROAM_SIGNAL_TH	include/mp_custom_oid.h	179;"	d
-OID_RT_SET_RSSI_ROAM_TRAFFIC_TH	include/mp_custom_oid.h	178;"	d
-OID_RT_SET_RX_PACKET_TYPE	include/mp_custom_oid.h	330;"	d
-OID_RT_SET_SNIFFER_MODE	include/mp_custom_oid.h	123;"	d
-OID_RT_SET_WRITE16_EEPROM	include/mp_custom_oid.h	297;"	d
-OID_RT_SET_WRITE_REG	include/mp_custom_oid.h	292;"	d
-OID_RT_SET_WRITE_TXCMD	include/mp_custom_oid.h	295;"	d
-OID_RT_SUPPORTED_RATES	include/mp_custom_oid.h	112;"	d
-OID_RT_SUPPORTED_WIRELESS_MODE	include/mp_custom_oid.h	184;"	d
-OID_RT_UTILITY_FALSE_ALARM_COUNTERS	include/mp_custom_oid.h	101;"	d
-OID_RT_UTILITY_GET_AGC_AND_FREQUENCY_OFFSET_ESTIMATION_STATUS	include/mp_custom_oid.h	106;"	d
-OID_RT_UTILITY_GET_CHANNEL_ESTIMATION_STATUS	include/mp_custom_oid.h	107;"	d
-OID_RT_UTILITY_GET_FRAME_DETECTION_STATUS	include/mp_custom_oid.h	105;"	d
-OID_RT_UTILITY_GET_RSSI_STATUS	include/mp_custom_oid.h	104;"	d
-OID_RT_UTILITY_SELECT_DEBUG_MODE	include/mp_custom_oid.h	102;"	d
-OID_RT_UTILITY_SELECT_SUBCARRIER_NUMBER	include/mp_custom_oid.h	103;"	d
-OID_RT_WIRELESS_MODE	include/mp_custom_oid.h	111;"	d
-OID_RT_WIRELESS_MODE_FOR_SCAN_LIST	include/mp_custom_oid.h	193;"	d
-OID_RT_WIRELESS_MODE_STARTING_ADHOC	include/mp_custom_oid.h	114;"	d
-OID_RT_WR_ATTRIB_MEM	include/mp_custom_oid.h	256;"	d
-ONERCCA_LOW_DIFF	hal/phydm/phydm_dig.c	78;"	d	file:
-ONERCCA_LOW_TH	hal/phydm/phydm_dig.c	77;"	d	file:
-ONE_SEC	core/rtw_tdls.c	26;"	d	file:
-ON_VISTA	include/drv_types_xp.h	42;"	d
-OOBProtectBytes	include/rtw_efuse.h	/^	const u16  OOBProtectBytes;$/;"	m	struct:_EFUSE_HAL
-OP_MODE_20MHZ_HT_STA_ASSOCED	include/wifi.h	1018;"	d
-OP_MODE_MAY_BE_LEGACY_STAS	include/wifi.h	1017;"	d
-OP_MODE_MIXED	include/wifi.h	1019;"	d
-OP_MODE_PURE	include/wifi.h	1016;"	d
-OTHER	include/rtw_btcoex.h	76;"	d
-OUI_BRCM	os_dep/linux/rtw_cfgvendor.h	24;"	d
-OUI_BROADCOM	include/ieee80211.h	1681;"	d
-OUI_GOOGLE	os_dep/linux/rtw_cfgvendor.h	25;"	d
-OUI_MICROSOFT	include/ieee80211.h	1658;"	d
-OUT	include/basic_types.h	134;"	d
-OUT	include/basic_types.h	86;"	d
-OWN	include/rtl8188e_xmit.h	47;"	d
-OWN	include/rtl8192e_xmit.h	152;"	d
-OWN	include/rtl8812a_xmit.h	45;"	d
-Octet	hal/phydm/phydm_adc_sampling.h	/^	pu4Byte		Octet;$/;"	m	struct:_RT_ADCSMP_STRING
-Octet	include/drv_types_ce.h	/^	u8      *Octet;$/;"	m	struct:_OCTET_STRING
-Octet	include/drv_types_xp.h	/^	u8      *Octet;$/;"	m	struct:_OCTET_STRING
-Offload_En	include/rtw_cmd.h	/^	u8 Offload_En:1;$/;"	m	struct:P2P_PS_Offload_t
-OffsetRequestIEs	include/wlan_bssdef.h	/^	ULONG                   OffsetRequestIEs;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-OffsetResponseIEs	include/wlan_bssdef.h	/^	ULONG                   OffsetResponseIEs;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-OnAction	core/rtw_mlme_ext.c	/^unsigned int OnAction(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_back	core/rtw_mlme_ext.c	/^unsigned int OnAction_back(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_dls	core/rtw_mlme_ext.c	/^unsigned int OnAction_dls(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_ft	core/rtw_mlme_ext.c	/^unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_ht	core/rtw_mlme_ext.c	/^unsigned int OnAction_ht(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_p2p	core/rtw_mlme_ext.c	/^unsigned int OnAction_p2p(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_qos	core/rtw_mlme_ext.c	/^unsigned int OnAction_qos(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_sa_query	core/rtw_mlme_ext.c	/^unsigned int OnAction_sa_query(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_tbl	core/rtw_mlme_ext.c	/^struct action_handler OnAction_tbl[] = {$/;"	v	typeref:struct:action_handler
-OnAction_vht	core/rtw_mlme_ext.c	/^unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAction_wmm	core/rtw_mlme_ext.c	/^unsigned int OnAction_wmm(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAssocReq	core/rtw_mlme_ext.c	/^unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAssocRsp	core/rtw_mlme_ext.c	/^unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAtim	core/rtw_mlme_ext.c	/^unsigned int OnAtim(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAuth	core/rtw_mlme_ext.c	/^unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnAuthClient	core/rtw_mlme_ext.c	/^unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnBeacon	core/rtw_mlme_ext.c	/^unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnDeAuth	core/rtw_mlme_ext.c	/^unsigned int OnDeAuth(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnDisassoc	core/rtw_mlme_ext.c	/^unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnProbeReq	core/rtw_mlme_ext.c	/^unsigned int OnProbeReq(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnProbeRsp	core/rtw_mlme_ext.c	/^unsigned int OnProbeRsp(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OnTDLS	core/rtw_recv.c	/^sint OnTDLS(_adapter *adapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Ch_Switch_Req	core/rtw_tdls.c	/^sint On_TDLS_Ch_Switch_Req(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Ch_Switch_Rsp	core/rtw_tdls.c	/^sint On_TDLS_Ch_Switch_Rsp(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Dis_Req	core/rtw_tdls.c	/^int On_TDLS_Dis_Req(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Dis_Rsp	core/rtw_tdls.c	/^int On_TDLS_Dis_Rsp(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Peer_Traffic_Indication	core/rtw_tdls.c	/^int On_TDLS_Peer_Traffic_Indication(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Peer_Traffic_Rsp	core/rtw_tdls.c	/^int On_TDLS_Peer_Traffic_Rsp(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Setup_Cfm	core/rtw_tdls.c	/^int On_TDLS_Setup_Cfm(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Setup_Req	core/rtw_tdls.c	/^sint On_TDLS_Setup_Req(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Setup_Rsp	core/rtw_tdls.c	/^int On_TDLS_Setup_Rsp(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-On_TDLS_Teardown	core/rtw_tdls.c	/^int On_TDLS_Teardown(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-OneEntry_MACID	hal/phydm/phydm.h	/^	u4Byte			OneEntry_MACID;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-OpCode	include/rtw_bt_mp.h	/^	UCHAR       OpCode;$/;"	m	struct:_BT_REQ_CMD
-OpMode	include/rtl8188e_cmd.h	/^	u8 OpMode;	\/* RT_MEDIA_STATUS *\/$/;"	m	struct:JOINBSSRPT_PARM_88E
-OpMode	include/rtl8192e_cmd.h	/^	u8 OpMode;	\/* RT_MEDIA_STATUS *\/$/;"	m	struct:JOINBSSRPT_PARM_92E
-Optimum_antenna	include/wlan_bssdef.h	/^	u8	Optimum_antenna;  \/* for Antenna diversity *\/$/;"	m	struct:_WLAN_PHY_INFO
-OutEpNumber	include/hal_data.h	/^	u8	OutEpNumber;$/;"	m	struct:hal_com_data
-OutEpQueueSel	include/hal_data.h	/^	u8	OutEpQueueSel;$/;"	m	struct:hal_com_data
-OutgoingTrafficMode	include/rtw_btcoex.h	/^	u1Byte					OutgoingTrafficMode;$/;"	m	struct:_HCI_LINK_INFO
-P1K_SIZE	core/rtw_security.c	493;"	d	file:
-P2POUI	include/wifi.h	1138;"	d
-P2P_AP_P2P_CH_SWITCH_PROCESS_WK	include/wifi.h	/^	P2P_AP_P2P_CH_SWITCH_PROCESS_WK = 5,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_ATTR_CAPABILITY	include/wifi.h	1143;"	d
-P2P_ATTR_CH_LIST	include/wifi.h	1152;"	d
-P2P_ATTR_CONF_TIMEOUT	include/wifi.h	1146;"	d
-P2P_ATTR_DEVICE_ID	include/wifi.h	1144;"	d
-P2P_ATTR_DEVICE_INFO	include/wifi.h	1154;"	d
-P2P_ATTR_EX_LISTEN_TIMING	include/wifi.h	1149;"	d
-P2P_ATTR_GO_INTENT	include/wifi.h	1145;"	d
-P2P_ATTR_GROUP_BSSID	include/wifi.h	1148;"	d
-P2P_ATTR_GROUP_ID	include/wifi.h	1156;"	d
-P2P_ATTR_GROUP_INFO	include/wifi.h	1155;"	d
-P2P_ATTR_INTENDED_IF_ADDR	include/wifi.h	1150;"	d
-P2P_ATTR_INTERFACE	include/wifi.h	1157;"	d
-P2P_ATTR_INVITATION_FLAGS	include/wifi.h	1159;"	d
-P2P_ATTR_LISTEN_CH	include/wifi.h	1147;"	d
-P2P_ATTR_MANAGEABILITY	include/wifi.h	1151;"	d
-P2P_ATTR_MINOR_REASON_CODE	include/wifi.h	1142;"	d
-P2P_ATTR_NOA	include/wifi.h	1153;"	d
-P2P_ATTR_OPERATING_CH	include/wifi.h	1158;"	d
-P2P_ATTR_STATUS	include/wifi.h	1141;"	d
-P2P_CANCEL_RO_CH_WK	include/wifi.h	/^	P2P_CANCEL_RO_CH_WK = 7,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_CONCURRENT_GO_NEGO_TIMEOUT	include/wifi.h	1238;"	d
-P2P_CONCURRENT_INVITE_TIMEOUT	include/wifi.h	1241;"	d
-P2P_CONCURRENT_PROVISION_TIMEOUT	include/wifi.h	1236;"	d
-P2P_DEVCAP_CLIENT_DISCOVERABILITY	include/wifi.h	1187;"	d
-P2P_DEVCAP_CONCURRENT_OPERATION	include/wifi.h	1188;"	d
-P2P_DEVCAP_DEVICE_LIMIT	include/wifi.h	1190;"	d
-P2P_DEVCAP_INFRA_MANAGED	include/wifi.h	1189;"	d
-P2P_DEVCAP_INVITATION_PROC	include/wifi.h	1191;"	d
-P2P_DEVCAP_SERVICE_DISCOVERY	include/wifi.h	1186;"	d
-P2P_DEVDISC_REQ	include/wifi.h	1211;"	d
-P2P_DEVDISC_RESP	include/wifi.h	1212;"	d
-P2P_FINDPHASE_EX_FULL	include/wifi.h	1230;"	d
-P2P_FINDPHASE_EX_MAX	include/wifi.h	1232;"	d
-P2P_FINDPHASE_EX_NONE	include/wifi.h	1229;"	d
-P2P_FINDPHASE_EX_SOCIAL_FIRST	include/wifi.h	1231;"	d
-P2P_FINDPHASE_EX_SOCIAL_LAST	include/wifi.h	1233;"	d
-P2P_FIND_PHASE_WK	include/wifi.h	/^	P2P_FIND_PHASE_WK = 0,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_GOT_WPSINFO_PBC	include/wifi.h	/^	P2P_GOT_WPSINFO_PBC					= 3,$/;"	e	enum:P2P_WPSINFO
-P2P_GOT_WPSINFO_PEER_DISPLAY_PIN	include/wifi.h	/^	P2P_GOT_WPSINFO_PEER_DISPLAY_PIN	= 1,$/;"	e	enum:P2P_WPSINFO
-P2P_GOT_WPSINFO_SELF_DISPLAY_PIN	include/wifi.h	/^	P2P_GOT_WPSINFO_SELF_DISPLAY_PIN	= 2,$/;"	e	enum:P2P_WPSINFO
-P2P_GO_DISC_REQUEST	include/wifi.h	1220;"	d
-P2P_GO_NEGO_CONF	include/wifi.h	1208;"	d
-P2P_GO_NEGO_REQ	include/wifi.h	1206;"	d
-P2P_GO_NEGO_RESP	include/wifi.h	1207;"	d
-P2P_GO_NEGO_TIMEOUT	include/wifi.h	1237;"	d
-P2P_GRPCAP_CROSS_CONN	include/wifi.h	1198;"	d
-P2P_GRPCAP_GO	include/wifi.h	1194;"	d
-P2P_GRPCAP_GROUP_FORMATION	include/wifi.h	1200;"	d
-P2P_GRPCAP_GROUP_LIMIT	include/wifi.h	1196;"	d
-P2P_GRPCAP_INTRABSS	include/wifi.h	1197;"	d
-P2P_GRPCAP_PERSISTENT_GROUP	include/wifi.h	1195;"	d
-P2P_GRPCAP_PERSISTENT_RECONN	include/wifi.h	1199;"	d
-P2P_INFO_DASH	core/rtw_debug.c	448;"	d	file:
-P2P_INFO_TITLE_ARG	core/rtw_debug.c	440;"	d	file:
-P2P_INFO_TITLE_FMT	core/rtw_debug.c	439;"	d	file:
-P2P_INFO_VALUE_ARG	core/rtw_debug.c	443;"	d	file:
-P2P_INFO_VALUE_FMT	core/rtw_debug.c	442;"	d	file:
-P2P_INVITATION_FLAGS_PERSISTENT	include/wifi.h	1176;"	d
-P2P_INVITE_TIMEOUT	include/wifi.h	1240;"	d
-P2P_INVIT_REQ	include/wifi.h	1209;"	d
-P2P_INVIT_RESP	include/wifi.h	1210;"	d
-P2P_MAX_INTENT	include/wifi.h	1243;"	d
-P2P_MAX_NOA_NUM	include/wifi.h	1245;"	d
-P2P_MAX_PERSISTENT_GROUP_NUM	include/wifi.h	1223;"	d
-P2P_MAX_REG_CLASSES	include/rtw_mlme_ext.h	558;"	d
-P2P_MAX_REG_CLASS_CHANNELS	include/rtw_mlme_ext.h	561;"	d
-P2P_NOTICE_OF_ABSENCE	include/wifi.h	1217;"	d
-P2P_NO_WPSINFO	include/wifi.h	/^	P2P_NO_WPSINFO						= 0,$/;"	e	enum:P2P_WPSINFO
-P2P_OUI	core/rtw_mlme_ext.c	/^unsigned char	P2P_OUI[] = {0x50, 0x6F, 0x9A, 0x09};$/;"	v
-P2P_PRESENCE_REQUEST	include/wifi.h	1218;"	d
-P2P_PRESENCE_RESPONSE	include/wifi.h	1219;"	d
-P2P_PRE_TX_INVITEREQ_PROCESS_WK	include/wifi.h	/^	P2P_PRE_TX_INVITEREQ_PROCESS_WK = 4,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_PRE_TX_NEGOREQ_PROCESS_WK	include/wifi.h	/^	P2P_PRE_TX_NEGOREQ_PROCESS_WK = 3,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_PRE_TX_PROVDISC_PROCESS_WK	include/wifi.h	/^	P2P_PRE_TX_PROVDISC_PROCESS_WK = 2,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_PRIVATE_IOCTL_SET_LEN	include/wifi.h	1301;"	d
-P2P_PROTO_WK_CID	include/rtw_cmd.h	/^	P2P_PROTO_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-P2P_PROTO_WK_ID	include/wifi.h	/^enum P2P_PROTO_WK_ID {$/;"	g
-P2P_PROVISIONING_SCAN_CNT	include/wifi.h	1225;"	d
-P2P_PROVISION_DISC_REQ	include/wifi.h	1213;"	d
-P2P_PROVISION_DISC_RESP	include/wifi.h	1214;"	d
-P2P_PROVISION_TIMEOUT	include/wifi.h	1235;"	d
-P2P_PS_ALLSTASLEEP	include/wifi.h	/^	P2P_PS_ALLSTASLEEP = 4, \/* for P2P GO *\/$/;"	e	enum:P2P_PS_STATE
-P2P_PS_CTWINDOW	include/wifi.h	/^	P2P_PS_CTWINDOW = 1,$/;"	e	enum:P2P_PS_MODE
-P2P_PS_CTWPeriod_t	include/rtw_cmd.h	/^struct P2P_PS_CTWPeriod_t {$/;"	s
-P2P_PS_DISABLE	include/wifi.h	/^	P2P_PS_DISABLE = 0,$/;"	e	enum:P2P_PS_STATE
-P2P_PS_ENABLE	include/wifi.h	/^	P2P_PS_ENABLE = 1,$/;"	e	enum:P2P_PS_STATE
-P2P_PS_MIX	include/wifi.h	/^	P2P_PS_MIX = 3, \/* CTWindow and NoA *\/$/;"	e	enum:P2P_PS_MODE
-P2P_PS_MODE	include/wifi.h	/^enum P2P_PS_MODE {$/;"	g
-P2P_PS_NOA	include/wifi.h	/^	P2P_PS_NOA	 = 2,$/;"	e	enum:P2P_PS_MODE
-P2P_PS_NONE	include/wifi.h	/^	P2P_PS_NONE = 0,$/;"	e	enum:P2P_PS_MODE
-P2P_PS_Offload_t	include/rtw_cmd.h	/^struct P2P_PS_Offload_t {$/;"	s
-P2P_PS_SCAN	include/wifi.h	/^	P2P_PS_SCAN = 2,$/;"	e	enum:P2P_PS_STATE
-P2P_PS_SCAN_DONE	include/wifi.h	/^	P2P_PS_SCAN_DONE = 3,$/;"	e	enum:P2P_PS_STATE
-P2P_PS_STATE	include/wifi.h	/^enum P2P_PS_STATE {$/;"	g
-P2P_PS_WK_CID	include/rtw_cmd.h	/^	P2P_PS_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-P2P_PUB_ACTION_ACTION	include/wifi.h	1203;"	d
-P2P_RESET_SCAN_CH	include/wifi.h	1242;"	d
-P2P_RESTORE_STATE_WK	include/wifi.h	/^	P2P_RESTORE_STATE_WK = 1,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_ROLE	include/wifi.h	/^enum P2P_ROLE {$/;"	g
-P2P_ROLE_CLIENT	include/wifi.h	/^	P2P_ROLE_CLIENT = 2,$/;"	e	enum:P2P_ROLE
-P2P_ROLE_DEVICE	include/wifi.h	/^	P2P_ROLE_DEVICE = 1,$/;"	e	enum:P2P_ROLE
-P2P_ROLE_DISABLE	include/wifi.h	/^	P2P_ROLE_DISABLE = 0,$/;"	e	enum:P2P_ROLE
-P2P_ROLE_GO	include/wifi.h	/^	P2P_ROLE_GO = 3$/;"	e	enum:P2P_ROLE
-P2P_RO_CH_WK	include/wifi.h	/^	P2P_RO_CH_WK = 6,$/;"	e	enum:P2P_PROTO_WK_ID
-P2P_STATE	include/wifi.h	/^enum P2P_STATE {$/;"	g
-P2P_STATE_FIND_PHASE_LISTEN	include/wifi.h	/^	P2P_STATE_FIND_PHASE_LISTEN = 4,				\/*	In the listen state of find phase *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_FIND_PHASE_SEARCH	include/wifi.h	/^	P2P_STATE_FIND_PHASE_SEARCH = 5,				\/*	In the search state of find phase *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_GONEGO_FAIL	include/wifi.h	/^	P2P_STATE_GONEGO_FAIL = 11,					\/*	finish the group negoitation handshake with failure *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_GONEGO_ING	include/wifi.h	/^	P2P_STATE_GONEGO_ING = 9,						\/*	Doing the group owner negoitation handshake *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_GONEGO_OK	include/wifi.h	/^	P2P_STATE_GONEGO_OK = 10,						\/*	finish the group negoitation handshake with success *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_IDLE	include/wifi.h	/^	P2P_STATE_IDLE = 1,								\/*	P2P had enabled and do nothing ,  buddy adapters is linked *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_LISTEN	include/wifi.h	/^	P2P_STATE_LISTEN = 2,							\/*	In pure listen state *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_NONE	include/wifi.h	/^	P2P_STATE_NONE = 0,							\/*	P2P disable *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_PROVISIONING_DONE	include/wifi.h	/^	P2P_STATE_PROVISIONING_DONE = 14,			\/*	Finish the P2P WPS *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_PROVISIONING_ING	include/wifi.h	/^	P2P_STATE_PROVISIONING_ING = 13,				\/*	Doing the P2P WPS *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RECV_INVITE_REQ_DISMATCH	include/wifi.h	/^	P2P_STATE_RECV_INVITE_REQ_DISMATCH = 17,	\/*	receiving the P2P Inviation request and dismatch with the profile. *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RECV_INVITE_REQ_GO	include/wifi.h	/^	P2P_STATE_RECV_INVITE_REQ_GO = 18,			\/*	receiving the P2P Inviation request and this wifi is GO. *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RECV_INVITE_REQ_JOIN	include/wifi.h	/^	P2P_STATE_RECV_INVITE_REQ_JOIN = 19,			\/*	receiving the P2P Inviation request to join an existing P2P Group. *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RECV_INVITE_REQ_MATCH	include/wifi.h	/^	P2P_STATE_RECV_INVITE_REQ_MATCH = 12,		\/*	receiving the P2P Inviation request and match with the profile. *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RX_INFOR_NOREADY	include/wifi.h	/^	P2P_STATE_RX_INFOR_NOREADY = 21,			\/* receiving p2p negoitation response with information is not available *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RX_INVITE_RESP_FAIL	include/wifi.h	/^	P2P_STATE_RX_INVITE_RESP_FAIL = 20,			\/*	recveing the P2P Inviation response with failure *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RX_INVITE_RESP_OK	include/wifi.h	/^	P2P_STATE_RX_INVITE_RESP_OK = 16,				\/*	Receiving the P2P Invitation response *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_RX_PROVISION_DIS_REQ	include/wifi.h	/^	P2P_STATE_RX_PROVISION_DIS_REQ = 8,$/;"	e	enum:P2P_STATE
-P2P_STATE_RX_PROVISION_DIS_RSP	include/wifi.h	/^	P2P_STATE_RX_PROVISION_DIS_RSP = 7,$/;"	e	enum:P2P_STATE
-P2P_STATE_SCAN	include/wifi.h	/^	P2P_STATE_SCAN = 3,							\/*	In scan phase *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_TX_INFOR_NOREADY	include/wifi.h	/^	P2P_STATE_TX_INFOR_NOREADY = 22,			\/* sending p2p negoitation response with information is not available *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_TX_INVITE_REQ	include/wifi.h	/^	P2P_STATE_TX_INVITE_REQ = 15,					\/*	Transmit the P2P Invitation request *\/$/;"	e	enum:P2P_STATE
-P2P_STATE_TX_PROVISION_DIS_REQ	include/wifi.h	/^	P2P_STATE_TX_PROVISION_DIS_REQ = 6,			\/*	In P2P provisioning discovery *\/$/;"	e	enum:P2P_STATE
-P2P_STATUS_FAIL_BOTH_GOINTENT_15	include/wifi.h	1171;"	d
-P2P_STATUS_FAIL_INCOMPATIBLE_PARAM	include/wifi.h	1164;"	d
-P2P_STATUS_FAIL_INCOMPATIBLE_PROVSION	include/wifi.h	1172;"	d
-P2P_STATUS_FAIL_INFO_UNAVAILABLE	include/wifi.h	1163;"	d
-P2P_STATUS_FAIL_INVALID_PARAM	include/wifi.h	1166;"	d
-P2P_STATUS_FAIL_LIMIT_REACHED	include/wifi.h	1165;"	d
-P2P_STATUS_FAIL_NO_COMMON_CH	include/wifi.h	1169;"	d
-P2P_STATUS_FAIL_PREVOUS_PROTO_ERR	include/wifi.h	1168;"	d
-P2P_STATUS_FAIL_REQUEST_UNABLE	include/wifi.h	1167;"	d
-P2P_STATUS_FAIL_UNKNOWN_P2PGROUP	include/wifi.h	1170;"	d
-P2P_STATUS_FAIL_USER_REJECT	include/wifi.h	1173;"	d
-P2P_STATUS_SUCCESS	include/wifi.h	1162;"	d
-P2P_TX_PRESCAN_TIMEOUT	include/wifi.h	1239;"	d
-P2P_WILDCARD_SSID_LEN	include/wifi.h	1227;"	d
-P2P_WOWLAN_RECV_FRAME_TYPE	include/rtw_mlme.h	/^enum P2P_WOWLAN_RECV_FRAME_TYPE {$/;"	g
-P2P_WOWLAN_RECV_INVITE_REQ	include/rtw_mlme.h	/^	P2P_WOWLAN_RECV_INVITE_REQ = 1,$/;"	e	enum:P2P_WOWLAN_RECV_FRAME_TYPE
-P2P_WOWLAN_RECV_NEGO_REQ	include/rtw_mlme.h	/^	P2P_WOWLAN_RECV_NEGO_REQ = 0,$/;"	e	enum:P2P_WOWLAN_RECV_FRAME_TYPE
-P2P_WOWLAN_RECV_PROVISION_REQ	include/rtw_mlme.h	/^	P2P_WOWLAN_RECV_PROVISION_REQ = 2,$/;"	e	enum:P2P_WOWLAN_RECV_FRAME_TYPE
-P2P_WPSINFO	include/wifi.h	/^enum P2P_WPSINFO {$/;"	g
-P2P_WoWlan_Offload_t	include/rtw_cmd.h	/^struct P2P_WoWlan_Offload_t {$/;"	s
-P80211CAPTURE_VERSION	include/wifi.h	63;"	d
-P80211_OUI_LEN	include/ieee80211.h	552;"	d
-P802_1H_OUI	core/rtw_xmit.c	/^static u8 P802_1H_OUI[P80211_OUI_LEN] = { 0x00, 0x00, 0xf8 };$/;"	v	file:
-PACKAGE_DEFAULT	include/rtl8703b_hal.h	/^	PACKAGE_DEFAULT,$/;"	e	enum:tag_Package_Definition
-PACKAGE_DEFAULT	include/rtl8723b_hal.h	/^	PACKAGE_DEFAULT,$/;"	e	enum:tag_Package_Definition
-PACKAGE_DEFAULT	include/rtl8723d_hal.h	/^	PACKAGE_DEFAULT,$/;"	e	enum:tag_Package_Definition
-PACKAGE_QFN68	include/rtl8703b_hal.h	/^	PACKAGE_QFN68,$/;"	e	enum:tag_Package_Definition
-PACKAGE_QFN68	include/rtl8723b_hal.h	/^	PACKAGE_QFN68,$/;"	e	enum:tag_Package_Definition
-PACKAGE_QFN68	include/rtl8723d_hal.h	/^	PACKAGE_QFN68,$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA79	include/rtl8703b_hal.h	/^	PACKAGE_TFBGA79$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA79	include/rtl8723b_hal.h	/^	PACKAGE_TFBGA79$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA79	include/rtl8723d_hal.h	/^	PACKAGE_TFBGA79$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA80	include/rtl8703b_hal.h	/^	PACKAGE_TFBGA80,$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA80	include/rtl8723b_hal.h	/^	PACKAGE_TFBGA80,$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA80	include/rtl8723d_hal.h	/^	PACKAGE_TFBGA80,$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA90	include/rtl8703b_hal.h	/^	PACKAGE_TFBGA90,$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA90	include/rtl8723b_hal.h	/^	PACKAGE_TFBGA90,$/;"	e	enum:tag_Package_Definition
-PACKAGE_TFBGA90	include/rtl8723d_hal.h	/^	PACKAGE_TFBGA90,$/;"	e	enum:tag_Package_Definition
-PACKAGE_TYPE_E	include/rtl8703b_hal.h	/^} PACKAGE_TYPE_E;$/;"	t	typeref:enum:tag_Package_Definition
-PACKAGE_TYPE_E	include/rtl8723b_hal.h	/^} PACKAGE_TYPE_E;$/;"	t	typeref:enum:tag_Package_Definition
-PACKAGE_TYPE_E	include/rtl8723d_hal.h	/^} PACKAGE_TYPE_E;$/;"	t	typeref:enum:tag_Package_Definition
-PACKETS_RX	include/rtw_mp.h	/^	PACKETS_RX                ,$/;"	e	enum:_TEST_MODE
-PACKETS_TX	include/rtw_mp.h	/^	PACKETS_TX                ,$/;"	e	enum:_TEST_MODE
-PACKET_ARP	include/rtw_btcoex.h	367;"	d
-PACKET_DHCP	include/rtw_btcoex.h	366;"	d
-PACKET_EAPOL	include/rtw_btcoex.h	368;"	d
-PACKET_NORMAL	include/rtw_btcoex.h	365;"	d
-PACKET_OFFSET_SZ	include/rtl8822bu_hal.h	28;"	d
-PACKET_OFFSET_SZ	include/rtl8822bu_hal.h	30;"	d
-PACKET_OFFSET_SZ	include/rtw_xmit.h	199;"	d
-PACKET_OFFSET_SZ	include/rtw_xmit.h	201;"	d
-PACS	hal/phydm/phydm_acs.h	/^}ACS, *PACS;$/;"	t	typeref:struct:_ACS_
-PADAPTER	hal/phydm/phydm.h	/^} ADAPTER, *PADAPTER;$/;"	t	typeref:struct:_ADAPTER
-PADAPTER	include/drv_types.h	/^typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;$/;"	t	typeref:struct:
-PADAPTER_temp	hal/phydm/phydm.h	/^	PADAPTER		PADAPTER_temp;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PADAPTIVITY_STATISTICS	hal/phydm/phydm_adaptivity.h	/^} ADAPTIVITY_STATISTICS, *PADAPTIVITY_STATISTICS;$/;"	t	typeref:struct:_ADAPTIVITY_STATISTICS
-PAD_HCI_SEL	include/hal_com_reg.h	1286;"	d
-PAD_HWPD_IDN	include/hal_com_reg.h	1268;"	d
-PAD_SEL	include/hal_com_reg.h	1535;"	d
-PAGE_SIZE_128	include/hal_data.h	192;"	d
-PAGE_SIZE_256	include/hal_data.h	193;"	d
-PAGE_SIZE_512	include/hal_data.h	194;"	d
-PAGE_SIZE_8814A	include/rtl8814a_hal.h	156;"	d
-PAGE_SIZE_RX_8188F	include/rtl8188f_hal.h	92;"	d
-PAGE_SIZE_RX_8703B	include/rtl8703b_hal.h	92;"	d
-PAGE_SIZE_RX_8723B	include/rtl8723b_hal.h	92;"	d
-PAGE_SIZE_RX_8723D	include/rtl8723d_hal.h	96;"	d
-PAGE_SIZE_RX_8821A	include/rtl8812a_hal.h	182;"	d
-PAGE_SIZE_TX_8188F	include/rtl8188f_hal.h	91;"	d
-PAGE_SIZE_TX_8703B	include/rtl8703b_hal.h	91;"	d
-PAGE_SIZE_TX_8723B	include/rtl8723b_hal.h	91;"	d
-PAGE_SIZE_TX_8723D	include/rtl8723d_hal.h	95;"	d
-PAGE_SIZE_TX_8814	include/rtl8814a_hal.h	58;"	d
-PAGE_SIZE_TX_8821A	include/rtl8812a_hal.h	181;"	d
-PAGE_SIZE_TX_92E	include/rtl8192e_hal.h	160;"	d
-PAGGRE_SIZE_E	include/rtw_ht.h	/^} AGGRE_SIZE_E, *PAGGRE_SIZE_E;$/;"	t	typeref:enum:AGGRE_SIZE
-PANT_DETECTED_INFO	hal/phydm/phydm_antdect.h	/^}ANT_DETECTED_INFO, *PANT_DETECTED_INFO;$/;"	t	typeref:struct:_ANT_DETECTED_INFO
-PANT_DIV_TYPE_E	hal/phydm/phydm_antdiv.h	/^}ANT_DIV_TYPE_E, *PANT_DIV_TYPE_E;$/;"	t	typeref:enum:_ANT_DIV_TYPE
-PARTNO_92D_NIC	include/hal_com_reg.h	1785;"	d
-PARTNO_92D_NIC_REMARK	include/hal_com_reg.h	1786;"	d
-PARTNO_CONCURRENT_BAND_VC	include/hal_com_reg.h	1789;"	d
-PARTNO_CONCURRENT_BAND_VC_REMARK	include/hal_com_reg.h	1790;"	d
-PARTNO_SINGLE_BAND_VS	include/hal_com_reg.h	1787;"	d
-PARTNO_SINGLE_BAND_VS_REMARK	include/hal_com_reg.h	1788;"	d
-PATHDIV_PARA	hal/phydm/phydm_pathdiv.h	/^}PATHDIV_PARA,*pPATHDIV_PARA;$/;"	t	typeref:struct:_PathDiv_Parameter_define_
-PATHDIV_REG	hal/phydm/phydm_reg.h	122;"	d
-PATHDIV_T	hal/phydm/phydm_pathdiv.h	/^}PATHDIV_T, *pPATHDIV_T;$/;"	t	typeref:struct:_ODM_PATH_DIVERSITY_
-PATHDIV_TRI	hal/phydm/phydm_reg.h	123;"	d
-PATHDIV_VERSION	hal/phydm/phydm_pathdiv.h	24;"	d
-PATH_A	hal/phydm/phydm_pathdiv.h	32;"	d
-PATH_B	hal/phydm/phydm_pathdiv.h	33;"	d
-PATH_C	hal/phydm/phydm_pathdiv.h	34;"	d
-PATH_D	hal/phydm/phydm_pathdiv.h	35;"	d
-PATH_LENGTH_MAX	include/osdep_service_ce.h	174;"	d
-PATH_LENGTH_MAX	include/osdep_service_linux.h	418;"	d
-PATH_LENGTH_MAX	include/osdep_service_xp.h	184;"	d
-PATH_NUM	hal/phydm/halphyrf_ap.c	1975;"	d	file:
-PATH_NUM	hal/phydm/rtl8723d/halphyrf_8723d.c	2595;"	d	file:
-PATH_S0	hal/phydm/rtl8723d/halphyrf_8723d.c	43;"	d	file:
-PATH_S1	hal/phydm/rtl8723d/halphyrf_8723d.c	34;"	d	file:
-PATTERN_BROADCAST	include/rtw_pwrctrl.h	/^	PATTERN_BROADCAST = 0,$/;"	e	enum:pattern_type
-PATTERN_INVALID	include/rtw_pwrctrl.h	/^	PATTERN_INVALID,$/;"	e	enum:pattern_type
-PATTERN_MULTICAST	include/rtw_pwrctrl.h	/^	PATTERN_MULTICAST,$/;"	e	enum:pattern_type
-PATTERN_UNICAST	include/rtw_pwrctrl.h	/^	PATTERN_UNICAST,$/;"	e	enum:pattern_type
-PATTERN_VALID	include/rtw_pwrctrl.h	/^	PATTERN_VALID,$/;"	e	enum:pattern_type
-PAType_2G	include/hal_data.h	/^	u8	PAType_2G;$/;"	m	struct:hal_com_data
-PAType_5G	include/hal_data.h	/^	u8	PAType_5G;$/;"	m	struct:hal_com_data
-PAYLOAD_LEN_LOC_OF_IP_HDR	os_dep/linux/recv_linux.c	404;"	d	file:
-PAYLOAD_TYPE_LEN	include/ieee80211.h	37;"	d
-PBAND_TYPE	include/rtw_rf.h	/^} BAND_TYPE, *PBAND_TYPE;$/;"	t	typeref:enum:_BAND_TYPE
-PBB_INIT_REGISTER	include/hal_data.h	/^} BB_INIT_REGISTER, *PBB_INIT_REGISTER;$/;"	t	typeref:struct:_BB_INIT_REGISTER
-PBB_REGISTER_DEFINITION_T	include/hal_com_phycfg.h	/^} BB_REGISTER_DEFINITION_T, *PBB_REGISTER_DEFINITION_T;$/;"	t	typeref:struct:_BB_REGISTER_DEFINITION
-PBC_POLLING_WK_CID	include/rtw_cmd.h	/^	PBC_POLLING_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-PBEAMFORMING_CAP	hal/phydm/phydm_beamforming.h	/^}BEAMFORMING_CAP, *PBEAMFORMING_CAP;$/;"	t	typeref:enum:_BEAMFORMING_CAP
-PBEAMFORMING_CAP	include/rtw_beamforming.h	/^} BEAMFORMING_CAP, *PBEAMFORMING_CAP;$/;"	t	typeref:enum:_BEAMFORMING_CAP
-PBEAMFORMING_ENTRY_STATE	hal/phydm/phydm_beamforming.h	/^} BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;$/;"	t	typeref:enum:_BEAMFORMING_ENTRY_STATE
-PBEAMFORMING_ENTRY_STATE	include/rtw_beamforming.h	/^} BEAMFORMING_ENTRY_STATE, *PBEAMFORMING_ENTRY_STATE;$/;"	t	typeref:enum:_BEAMFORMING_ENTRY_STATE
-PBEAMFORMING_NOTIFY_STATE	hal/phydm/phydm_beamforming.h	/^} BEAMFORMING_NOTIFY_STATE, *PBEAMFORMING_NOTIFY_STATE;$/;"	t	typeref:enum:_BEAMFORMING_NOTIFY_STATE
-PBEAMFORMING_STATE	include/rtw_beamforming.h	/^} BEAMFORMING_STATE, *PBEAMFORMING_STATE;$/;"	t	typeref:enum:_BEAMFORMING_STATE
-PBOOLEAN	hal/phydm/phydm_types.h	/^	typedef unsigned char			BOOLEAN,*PBOOLEAN;$/;"	t
-PBOOLEAN	include/basic_types.h	/^typedef unsigned char	BOOLEAN, *PBOOLEAN, boolean;$/;"	t
-PBP	include/hal_com_reg.h	570;"	d
-PBP_1024	include/hal_com_reg.h	1347;"	d
-PBP_128	include/hal_com_reg.h	1344;"	d
-PBP_256	include/hal_com_reg.h	1345;"	d
-PBP_512	include/hal_com_reg.h	1346;"	d
-PBP_64	include/hal_com_reg.h	1343;"	d
-PBP_8814A	include/rtl8814a_spec.h	543;"	d
-PBSSIDInfo	include/rtw_ioctl_set.h	/^} BSSIDInfo, *PBSSIDInfo;$/;"	t	typeref:struct:_BSSIDInfo
-PBTCDBGINFO	hal/hal_btcoex.c	/^} BTCDBGINFO, *PBTCDBGINFO;$/;"	t	typeref:struct:_btcoexdbginfo	file:
-PBTCOEX_SUSPEND_STATE	include/rtw_btcoex.h	/^} BTCOEX_SUSPEND_STATE, *PBTCOEX_SUSPEND_STATE;$/;"	t	typeref:enum:_BTCOEX_SUSPEND_STATE
-PBTC_ANTENNA_POS	hal/btc/HalBtcOutSrc.h	/^} BTC_ANTENNA_POS, *PBTC_ANTENNA_POS;$/;"	t	typeref:enum:_BTC_ANTENNA_POS
-PBTC_ANT_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_ANT_TYPE, *PBTC_ANT_TYPE;$/;"	t	typeref:enum:_BTC_ANT_TYPE
-PBTC_BT_OFFON	hal/btc/HalBtcOutSrc.h	/^} BTC_BTOFFON, *PBTC_BT_OFFON;$/;"	t	typeref:enum:_BTC_BT_OFFON
-PBTC_BT_REG_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_BT_REG_TYPE, *PBTC_BT_REG_TYPE;$/;"	t	typeref:enum:_BTC_BT_REG_TYPE
-PBTC_CHIP_INTERFACE	hal/btc/HalBtcOutSrc.h	/^} BTC_CHIP_INTERFACE, *PBTC_CHIP_INTERFACE;$/;"	t	typeref:enum:_BTC_CHIP_INTERFACE
-PBTC_CHIP_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_CHIP_TYPE, *PBTC_CHIP_TYPE;$/;"	t	typeref:enum:_BTC_CHIP_TYPE
-PBTC_COEXIST	hal/btc/HalBtcOutSrc.h	/^typedef struct btc_coexist *PBTC_COEXIST;$/;"	t	typeref:struct:btc_coexist
-PBTC_DBG_DISP_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_DBG_DISP_TYPE, *PBTC_DBG_DISP_TYPE;$/;"	t	typeref:enum:_BTC_DBG_DISP_TYPE
-PBTC_DBG_OPCODE	hal/btc/HalBtcOutSrc.h	/^} BTC_DBG_OPCODE, *PBTC_DBG_OPCODE;$/;"	t	typeref:enum:_BTC_DBG_OPCODE
-PBTC_GET_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_GET_TYPE, *PBTC_GET_TYPE;$/;"	t	typeref:enum:_BTC_GET_TYPE
-PBTC_IOT_PEER	hal/btc/HalBtcOutSrc.h	/^} BTC_IOT_PEER, *PBTC_IOT_PEER;$/;"	t	typeref:enum:_BTC_IOT_PEER
-PBTC_NOTIFY_TYPE_ASSOCIATE	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_ASSOCIATE, *PBTC_NOTIFY_TYPE_ASSOCIATE;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_ASSOCIATE
-PBTC_NOTIFY_TYPE_IPS	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_IPS, *PBTC_NOTIFY_TYPE_IPS;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_IPS
-PBTC_NOTIFY_TYPE_LPS	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_LPS, *PBTC_NOTIFY_TYPE_LPS;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_LPS
-PBTC_NOTIFY_TYPE_MEDIA_STATUS	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_MEDIA_STATUS, *PBTC_NOTIFY_TYPE_MEDIA_STATUS;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_MEDIA_STATUS
-PBTC_NOTIFY_TYPE_SCAN	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_SCAN, *PBTC_NOTIFY_TYPE_SCAN;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_SCAN
-PBTC_NOTIFY_TYPE_SPECIFIC_PACKET	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_SPECIFIC_PACKET, *PBTC_NOTIFY_TYPE_SPECIFIC_PACKET;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_SPECIFIC_PACKET
-PBTC_NOTIFY_TYPE_STACK_OPERATION	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_STACK_OPERATION, *PBTC_NOTIFY_TYPE_STACK_OPERATION;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_STACK_OPERATION
-PBTC_NOTIFY_TYPE_SWITCHBAND	hal/btc/HalBtcOutSrc.h	/^} BTC_NOTIFY_TYPE_SWITCHBAND, *PBTC_NOTIFY_TYPE_SWITCHBAND;$/;"	t	typeref:enum:_BTC_NOTIFY_TYPE_SWITCHBAND
-PBTC_OFFLOAD	hal/btc/HalBtcOutSrc.h	/^} BTC_OFFLOAD, *PBTC_OFFLOAD;$/;"	t	typeref:struct:_BTC_OFFLOAD
-PBTC_POWERSAVE_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_POWERSAVE_TYPE, *PBTC_POWERSAVE_TYPE;$/;"	t	typeref:enum:_BTC_POWERSAVE_TYPE
-PBTC_RSSI_STATE	hal/btc/HalBtcOutSrc.h	/^} BTC_RSSI_STATE, *PBTC_RSSI_STATE;$/;"	t	typeref:enum:_BTC_RSSI_STATE
-PBTC_SET_TYPE	hal/btc/HalBtcOutSrc.h	/^} BTC_SET_TYPE, *PBTC_SET_TYPE;$/;"	t	typeref:enum:_BTC_SET_TYPE
-PBTC_VENDOR	hal/btc/HalBtcOutSrc.h	/^} BTC_VENDOR, *PBTC_VENDOR;$/;"	t	typeref:enum:_BTC_VENDOR
-PBTC_WIFI_BW_MODE	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_BW_MODE, *PBTC_WIFI_BW_MODE;$/;"	t	typeref:enum:_BTC_WIFI_BW_MODE
-PBTC_WIFI_COEX_STATE	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_COEX_STATE, *PBTC_WIFI_COEX_STATE;$/;"	t	typeref:enum:_BTC_WIFI_COEX_STATE
-PBTC_WIFI_PNP	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_PNP, *PBTC_WIFI_PNP;$/;"	t	typeref:enum:_BTC_WIFI_PNP
-PBTC_WIFI_ROLE	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_ROLE, *PBTC_WIFI_ROLE;$/;"	t	typeref:enum:_BTC_WIFI_ROLE
-PBTC_WIFI_TRAFFIC_DIR	hal/btc/HalBtcOutSrc.h	/^} BTC_WIFI_TRAFFIC_DIR, *PBTC_WIFI_TRAFFIC_DIR;$/;"	t	typeref:enum:_BTC_WIFI_TRAFFIC_DIR
-PBTC_WIRELESS_FREQ	hal/btc/HalBtcOutSrc.h	/^} BTC_WIRELESS_FREQ, *PBTC_WIRELESS_FREQ;$/;"	t	typeref:enum:_BTC_WIRELESS_FREQ
-PBT_8188C_2ANT_BT_STATUS	hal/btc/HalBtc8188c2Ant.h	/^}BT_8188C_2ANT_BT_STATUS,*PBT_8188C_2ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8188C_2ANT_BT_STATUS
-PBT_8188C_2ANT_COEX_ALGO	hal/btc/HalBtc8188c2Ant.h	/^}BT_8188C_2ANT_COEX_ALGO,*PBT_8188C_2ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8188C_2ANT_COEX_ALGO
-PBT_8192D_2ANT_BT_STATUS	hal/btc/HalBtc8192d2Ant.h	/^}BT_8192D_2ANT_BT_STATUS,*PBT_8192D_2ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8192D_2ANT_BT_STATUS
-PBT_8192D_2ANT_COEX_ALGO	hal/btc/HalBtc8192d2Ant.h	/^}BT_8192D_2ANT_COEX_ALGO,*PBT_8192D_2ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8192D_2ANT_COEX_ALGO
-PBT_8723A_1ANT_BT_STATUS	hal/btc/HalBtc8723a1Ant.h	/^}BT_8723A_1ANT_BT_STATUS,*PBT_8723A_1ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8723A_1ANT_BT_STATUS
-PBT_8723A_1ANT_COEX_ALGO	hal/btc/HalBtc8723a1Ant.h	/^}BT_8723A_1ANT_COEX_ALGO,*PBT_8723A_1ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8723A_1ANT_COEX_ALGO
-PBT_8723A_2ANT_BT_STATUS	hal/btc/HalBtc8723a2Ant.h	/^}BT_8723A_2ANT_BT_STATUS,*PBT_8723A_2ANT_BT_STATUS;$/;"	t	typeref:enum:_BT_8723A_2ANT_BT_STATUS
-PBT_8723A_2ANT_COEX_ALGO	hal/btc/HalBtc8723a2Ant.h	/^}BT_8723A_2ANT_COEX_ALGO,*PBT_8723A_2ANT_COEX_ALGO;$/;"	t	typeref:enum:_BT_8723A_2ANT_COEX_ALGO
-PBT_AFH_MAP_TYPE	include/rtw_bt_mp.h	/^} BT_AFH_MAP_TYPE, *PBT_AFH_MAP_TYPE;$/;"	t	typeref:enum:_BT_AFH_MAP_TYPE
-PBT_Ant_NUM	include/hal_pg.h	/^} BT_Ant_NUM, *PBT_Ant_NUM;$/;"	t	typeref:enum:_BT_Ant_NUM
-PBT_COEXIST	include/hal_btcoex.h	/^} BT_COEXIST, *PBT_COEXIST;$/;"	t	typeref:struct:_BT_COEXIST
-PBT_CONNECT_TYPE	include/rtw_btcoex.h	/^} BT_CONNECT_TYPE, *PBT_CONNECT_TYPE;$/;"	t	typeref:enum:_BT_CONNECT_TYPE
-PBT_CTRL_OPCODE_LOWER	include/rtw_bt_mp.h	/^} BT_CTRL_OPCODE_LOWER, *PBT_CTRL_OPCODE_LOWER;$/;"	t	typeref:enum:_BT_CTRL_OPCODE_LOWER
-PBT_CTRL_OPCODE_UPPER	include/rtw_bt_mp.h	/^} BT_CTRL_OPCODE_UPPER, *PBT_CTRL_OPCODE_UPPER;$/;"	t	typeref:enum:_BT_CTRL_OPCODE_UPPER
-PBT_CTRL_STATUS	include/rtw_btcoex.h	/^} BT_CTRL_STATUS, *PBT_CTRL_STATUS;$/;"	t	typeref:enum:_BT_CTRL_STATUS
-PBT_CoType	include/hal_pg.h	/^} BT_CoType, *PBT_CoType;$/;"	t	typeref:enum:_BT_CoType
-PBT_EXT_C2H	include/rtw_bt_mp.h	/^} BT_EXT_C2H, *PBT_EXT_C2H;$/;"	t	typeref:struct:_BT_EXT_C2H
-PBT_GET_GENERAL	include/rtw_bt_mp.h	/^} BT_GET_GENERAL, *PBT_GET_GENERAL;$/;"	t	typeref:enum:_BT_GET_GENERAL
-PBT_H2C	include/rtw_bt_mp.h	/^} BT_H2C, *PBT_H2C;$/;"	t	typeref:struct:_BT_H2C
-PBT_INFO_SRC_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^}BT_INFO_SRC_8188C_2ANT,*PBT_INFO_SRC_8188C_2ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8188C_2ANT
-PBT_INFO_SRC_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^}BT_INFO_SRC_8192D_2ANT,*PBT_INFO_SRC_8192D_2ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8192D_2ANT
-PBT_INFO_SRC_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^}BT_INFO_SRC_8723A_1ANT,*PBT_INFO_SRC_8723A_1ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8723A_1ANT
-PBT_INFO_SRC_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^}BT_INFO_SRC_8723A_2ANT,*PBT_INFO_SRC_8723A_2ANT;$/;"	t	typeref:enum:_BT_INFO_SRC_8723A_2ANT
-PBT_MGNT	include/rtw_btcoex.h	/^} BT_MGNT, *PBT_MGNT;$/;"	t	typeref:struct:_BT_MGNT
-PBT_OPCODE_STATUS	include/rtw_bt_mp.h	/^} BT_OPCODE_STATUS, *PBT_OPCODE_STATUS;$/;"	t	typeref:enum:_BT_OPCODE_STATUS
-PBT_REG_TYPE	include/rtw_bt_mp.h	/^} BT_REG_TYPE, *PBT_REG_TYPE;$/;"	t	typeref:enum:_BT_REG_TYPE
-PBT_REPORT_TYPE	include/rtw_bt_mp.h	/^} BT_REPORT_TYPE, *PBT_REPORT_TYPE;$/;"	t	typeref:enum:_BT_REPORT_TYPE
-PBT_REQ_CMD	include/rtw_bt_mp.h	/^} BT_REQ_CMD, *PBT_REQ_CMD;$/;"	t	typeref:struct:_BT_REQ_CMD
-PBT_RSP_CMD	include/rtw_bt_mp.h	/^} BT_RSP_CMD, *PBT_RSP_CMD;$/;"	t	typeref:struct:_BT_RSP_CMD
-PBT_RadioShared	include/hal_pg.h	/^} BT_RadioShared, *PBT_RadioShared;$/;"	t	typeref:enum:_BT_RadioShared
-PBT_SET_GENERAL	include/rtw_bt_mp.h	/^} BT_SET_GENERAL, *PBT_SET_GENERAL;$/;"	t	typeref:enum:_BT_SET_GENERAL
-PBT_STATE_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^}BT_STATE_8723A_1ANT, *PBT_STATE_8723A_1ANT;$/;"	t	typeref:enum:_BT_STATE_8723A_1ANT
-PBT_TXRX_PARAMETERS	include/rtw_bt_mp.h	/^} BT_TXRX_PARAMETERS, *PBT_TXRX_PARAMETERS;$/;"	t	typeref:struct:_BT_TXRX_PARAMETERS
-PBaseBand_Config_Type	include/hal_phy.h	/^} BaseBand_Config_Type, *PBaseBand_Config_Type;$/;"	t	typeref:enum:_BaseBand_Config_Type
-PCAPABILITY	include/rtw_rf.h	/^} CAPABILITY, *PCAPABILITY;$/;"	t	typeref:enum:_CAPABILITY
-PCCX_INFO	hal/phydm/phydm_ccx.h	/^}CCX_INFO, *PCCX_INFO;$/;"	t	typeref:struct:_CCX_INFO
-PCFG_DBG_MSG_STRUCT	include/rtw_mp_ioctl.h	/^} CFG_DBG_MSG_STRUCT, *PCFG_DBG_MSG_STRUCT;$/;"	t	typeref:struct:CFG_DBG_MSG_STRUCT
-PCFO_TRACKING	hal/phydm/phydm_cfotracking.h	/^}CFO_TRACKING, *PCFO_TRACKING;$/;"	t	typeref:struct:_CFO_TRACKING_
-PCHANNEL_WIDTH	include/rtw_rf.h	/^} CHANNEL_WIDTH, *PCHANNEL_WIDTH;$/;"	t	typeref:enum:_CHANNEL_WIDTH
-PCIE_SLOT1_MASK	include/pci_osintf.h	26;"	d
-PCIE_SLOT1_MEM_LEN	include/pci_osintf.h	25;"	d
-PCIE_SLOT1_MEM_START	include/pci_osintf.h	24;"	d
-PCIE_SLOT2_MASK	include/pci_osintf.h	30;"	d
-PCIE_SLOT2_MEM_LEN	include/pci_osintf.h	29;"	d
-PCIE_SLOT2_MEM_START	include/pci_osintf.h	28;"	d
-PCIE_TRANSLATE_OFFSET	include/pci_osintf.h	32;"	d
-PCIRSTB	include/hal_com_reg.h	1257;"	d
-PCI_BRIDGE_VENDOR_AMD	include/drv_types_pci.h	/^	PCI_BRIDGE_VENDOR_AMD, \/* = 0x04, *\/ \/* 0b'0000,0100 *\/$/;"	e	enum:pci_bridge_vendor
-PCI_BRIDGE_VENDOR_ATI	include/drv_types_pci.h	/^	PCI_BRIDGE_VENDOR_ATI, \/* = 0x02, *\/ \/* 0b'0000,0010 *\/$/;"	e	enum:pci_bridge_vendor
-PCI_BRIDGE_VENDOR_INTEL	include/drv_types_pci.h	/^	PCI_BRIDGE_VENDOR_INTEL = 0x0,\/* 0b'0000,0001 *\/$/;"	e	enum:pci_bridge_vendor
-PCI_BRIDGE_VENDOR_MAX	include/drv_types_pci.h	/^	PCI_BRIDGE_VENDOR_MAX ,\/* = 0x80 *\/$/;"	e	enum:pci_bridge_vendor
-PCI_BRIDGE_VENDOR_SIS	include/drv_types_pci.h	/^	PCI_BRIDGE_VENDOR_SIS ,\/* = 0x08, *\/ \/* 0b'0000,1000 *\/$/;"	e	enum:pci_bridge_vendor
-PCI_BRIDGE_VENDOR_UNKNOWN	include/drv_types_pci.h	/^	PCI_BRIDGE_VENDOR_UNKNOWN, \/* = 0x40, *\/ \/* 0b'0100,0000 *\/$/;"	e	enum:pci_bridge_vendor
-PCI_CAPABILITY_ID_PCI_EXPRESS	include/drv_types_pci.h	45;"	d
-PCI_CLASS_BRIDGE_DEV	include/drv_types_pci.h	42;"	d
-PCI_COMMON_CONFIG	include/drv_types_pci.h	/^} PCI_COMMON_CONFIG , *PPCI_COMMON_CONFIG;$/;"	t	typeref:struct:_PCI_COMMON_CONFIG
-PCI_CONF_ADDRESS	include/drv_types_pci.h	39;"	d
-PCI_CONF_DATA	include/drv_types_pci.h	40;"	d
-PCI_MAX_BRIDGE_NUMBER	include/drv_types_pci.h	35;"	d
-PCI_MAX_DEVICES	include/drv_types_pci.h	36;"	d
-PCI_MAX_FUNCTION	include/drv_types_pci.h	37;"	d
-PCI_MAX_RX_COUNT	include/rtw_recv.h	345;"	d
-PCI_MAX_RX_QUEUE	include/rtw_recv.h	344;"	d
-PCI_MAX_TX_QUEUE_COUNT	include/rtw_xmit.h	297;"	d
-PCI_SUBCLASS_BR_PCI_TO_PCI	include/drv_types_pci.h	43;"	d
-PCI_SUSEN	include/hal_com_reg.h	1302;"	d
-PCI_VENDER_ID_REALTEK	include/drv_types_pci.h	51;"	d
-PCLK_VLD	include/hal_com_reg.h	1256;"	d
-PCOEX_DM_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^} COEX_DM_8188C_2ANT, *PCOEX_DM_8188C_2ANT;$/;"	t	typeref:struct:_COEX_DM_8188C_2ANT
-PCOEX_DM_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^} COEX_DM_8192D_2ANT, *PCOEX_DM_8192D_2ANT;$/;"	t	typeref:struct:_COEX_DM_8192D_2ANT
-PCOEX_DM_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^} COEX_DM_8723A_1ANT, *PCOEX_DM_8723A_1ANT;$/;"	t	typeref:struct:_COEX_DM_8723A_1ANT
-PCOEX_DM_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^} COEX_DM_8723A_2ANT, *PCOEX_DM_8723A_2ANT;$/;"	t	typeref:struct:_COEX_DM_8723A_2ANT
-PCOEX_STA_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^}COEX_STA_8188C_2ANT, *PCOEX_STA_8188C_2ANT;$/;"	t	typeref:struct:_COEX_STA_8188C_2ANT
-PCOEX_STA_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^}COEX_STA_8192D_2ANT, *PCOEX_STA_8192D_2ANT;$/;"	t	typeref:struct:_COEX_STA_8192D_2ANT
-PCOEX_STA_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^}COEX_STA_8723A_1ANT, *PCOEX_STA_8723A_1ANT;$/;"	t	typeref:struct:_COEX_STA_8723A_1ANT
-PCOEX_STA_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^}COEX_STA_8723A_2ANT, *PCOEX_STA_8723A_2ANT;$/;"	t	typeref:struct:_COEX_STA_8723A_2ANT
-PCOL_C2H_ACK	hal/btc/HalBtcOutSrc.h	/^} COL_C2H_ACK, *PCOL_C2H_ACK;$/;"	t	typeref:struct:_COL_C2H_ACK
-PCOL_C2H_IND	hal/btc/HalBtcOutSrc.h	/^} COL_C2H_IND, *PCOL_C2H_IND;$/;"	t	typeref:struct:_COL_C2H_IND
-PCOL_H2C	hal/btc/HalBtcOutSrc.h	/^} COL_H2C, *PCOL_H2C;$/;"	t	typeref:struct:_COL_H2C
-PCOL_H2C_STATUS	hal/btc/HalBtcOutSrc.h	/^} COL_H2C_STATUS, *PCOL_H2C_STATUS;$/;"	t	typeref:enum:_COL_H2C_STATUS
-PCOL_IND_TYPE	hal/btc/HalBtcOutSrc.h	/^} COL_IND_TYPE, *PCOL_IND_TYPE;$/;"	t	typeref:enum:_COL_IND_TYPE
-PCOL_OPCODE	hal/btc/HalBtcOutSrc.h	/^} COL_OPCODE, *PCOL_OPCODE;$/;"	t	typeref:enum:_COL_OPCODE
-PCOL_SINGLE_C2H_IND_RECORD	hal/btc/HalBtcOutSrc.h	/^} COL_SINGLE_C2H_IND_RECORD, *PCOL_SINGLE_C2H_IND_RECORD;$/;"	t	typeref:struct:_COL_SINGLE_C2H_IND_RECORD
-PCOL_SINGLE_H2C_RECORD	hal/btc/HalBtcOutSrc.h	/^} COL_SINGLE_H2C_RECORD, *PCOL_SINGLE_H2C_RECORD;$/;"	t	typeref:struct:_COL_SINGLE_H2C_RECORD
-PCTS_MSK_RPT_0	hal/phydm/phydm_hwconfig.h	/^	u1Byte			PCTS_MSK_RPT_0;						\/*PCTS mask report[7:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-PCTS_MSK_RPT_1	hal/phydm/phydm_hwconfig.h	/^	u1Byte			PCTS_MSK_RPT_1;						\/*PCTS mask report[15:8]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-PCTS_MSK_RPT_2	hal/phydm/phydm_hwconfig.h	/^	u1Byte			PCTS_MSK_RPT_2;						\/*PCTS mask report[23:16]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-PCTS_MSK_RPT_3	hal/phydm/phydm_hwconfig.h	/^	u1Byte			PCTS_MSK_RPT_3: 6;						\/*PCTS mask report[29:24]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-PCTS_MSK_RPT_3	hal/phydm/phydm_hwconfig.h	/^	u1Byte			PCTS_MSK_RPT_3: 6;$/;"	m	struct:_Phy_Status_Rpt_8812
-PDE_DATA	os_dep/linux/rtw_proc.c	45;"	d	file:
-PDM_ODM_T	hal/phydm/phydm.h	/^} DM_ODM_T, *PDM_ODM_T;		\/*DM_Dynamic_Mechanism_Structure*\/$/;"	t	typeref:struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PDN_BT_N	include/hal_com_reg.h	1296;"	d
-PDN_GPS_N	include/hal_com_reg.h	1297;"	d
-PDN_PL	include/hal_com_reg.h	1175;"	d
-PEFUSE_ACCESS_STRUCT	include/rtw_mp_ioctl.h	/^} EFUSE_ACCESS_STRUCT, *PEFUSE_ACCESS_STRUCT;$/;"	t	typeref:struct:_EFUSE_ACCESS_STRUCT_
-PEFUSE_HAL	include/rtw_efuse.h	/^} EFUSE_HAL, *PEFUSE_HAL;$/;"	t	typeref:struct:_EFUSE_HAL
-PELEMENT_ID	include/wifi.h	/^} ELEMENT_ID, *PELEMENT_ID;$/;"	t	typeref:enum:_ELEMENT_ID
-PEXTCHNL_OFFSET	include/rtw_rf.h	/^} EXTCHNL_OFFSET, *PEXTCHNL_OFFSET;$/;"	t	typeref:enum:_EXTCHNL_OFFSET
-PFALSE_ALARM_STATISTICS	hal/phydm/phydm_dig.h	/^}FALSE_ALARM_STATISTICS, *PFALSE_ALARM_STATISTICS;$/;"	t	typeref:struct:_FALSE_ALARM_STATISTICS
-PFAT_STATE_E	hal/phydm/phydm_antdiv.h	/^}FAT_STATE_E, *PFAT_STATE_E;$/;"	t	typeref:enum:_FAT_STATE
-PFIRMWARE_SOURCE	include/hal_com.h	/^} FIRMWARE_SOURCE, *PFIRMWARE_SOURCE;$/;"	t	typeref:enum:_FIRMWARE_SOURCE
-PFM_ALDN	include/hal_com_reg.h	1171;"	d
-PFM_LDALL	include/hal_com_reg.h	1170;"	d
-PFM_LDKP	include/hal_com_reg.h	1172;"	d
-PFM_WOWL	include/hal_com_reg.h	1173;"	d
-PGPKT_DATA_SIZE	include/rtw_efuse.h	36;"	d
-PGPKT_STRUCT	include/rtw_efuse.h	/^} PGPKT_STRUCT, *PPGPKT_STRUCT;$/;"	t	typeref:struct:PG_PKT_STRUCT_A
-PGSPI_DATA	include/drv_types_gspi.h	/^} GSPI_DATA, *PGSPI_DATA;$/;"	t	typeref:struct:gspi_data
-PG_PKT_STRUCT_A	include/rtw_efuse.h	/^typedef struct PG_PKT_STRUCT_A {$/;"	s
-PG_STATE_DATA	include/rtw_efuse.h	31;"	d
-PG_STATE_HEADER	include/rtw_efuse.h	26;"	d
-PG_STATE_WORD_0	include/rtw_efuse.h	27;"	d
-PG_STATE_WORD_1	include/rtw_efuse.h	28;"	d
-PG_STATE_WORD_2	include/rtw_efuse.h	29;"	d
-PG_STATE_WORD_3	include/rtw_efuse.h	30;"	d
-PG_SWBYTE_H	include/rtw_efuse.h	33;"	d
-PG_SWBYTE_L	include/rtw_efuse.h	34;"	d
-PG_TXPWR_1PATH_BYTE_NUM_2G	hal/hal_com_phycfg.c	581;"	d	file:
-PG_TXPWR_1PATH_BYTE_NUM_5G	hal/hal_com_phycfg.c	711;"	d	file:
-PG_TXPWR_INVALID_BASE	hal/hal_com_phycfg.c	31;"	d	file:
-PG_TXPWR_INVALID_DIFF	hal/hal_com_phycfg.c	32;"	d	file:
-PG_TXPWR_LSB_DIFF_S4BIT	hal/hal_com_phycfg.c	26;"	d	file:
-PG_TXPWR_LSB_DIFF_TO_S8BIT	hal/hal_com_phycfg.c	28;"	d	file:
-PG_TXPWR_MSB_DIFF_S4BIT	hal/hal_com_phycfg.c	25;"	d	file:
-PG_TXPWR_MSB_DIFF_TO_S8BIT	hal/hal_com_phycfg.c	27;"	d	file:
-PG_TXPWR_SRC_DEF	hal/hal_com_phycfg.c	44;"	d	file:
-PG_TXPWR_SRC_IC_DEF	hal/hal_com_phycfg.c	43;"	d	file:
-PG_TXPWR_SRC_NUM	hal/hal_com_phycfg.c	45;"	d	file:
-PG_TXPWR_SRC_PG_DATA	hal/hal_com_phycfg.c	42;"	d	file:
-PHAL_DATA_COMMON	include/hal_data.h	/^} HAL_DATA_COMMON, *PHAL_DATA_COMMON;$/;"	t	typeref:struct:hal_com_data
-PHAL_DATA_TYPE	include/hal_data.h	/^typedef struct hal_com_data HAL_DATA_TYPE, *PHAL_DATA_TYPE;$/;"	t	typeref:struct:
-PHAL_HW_TIMER_TYPE	include/hal_intf.h	/^} HAL_HW_TIMER_TYPE, *PHAL_HW_TIMER_TYPE;$/;"	t	typeref:enum:_HAL_HW_TIMER_TYPE
-PHAL_STATUS	hal/phydm/phydm_types.h	/^}HAL_STATUS,*PHAL_STATUS;$/;"	t	typeref:enum:_HAL_STATUS
-PHAL_TXBF_INFO	hal/phydm/txbf/halcomtxbf.h	/^} HAL_TXBF_INFO, *PHAL_TXBF_INFO;$/;"	t	typeref:struct:_HAL_TXBF_INFO
-PHAL_VERSION	include/HalVerDef.h	/^} HAL_VERSION, *PHAL_VERSION;$/;"	t	typeref:struct:tag_HAL_VERSION
-PHASE1_LOOP_CNT	core/rtw_security.c	490;"	d	file:
-PHCI_EXT_BT_OPERATION	include/rtw_btcoex.h	/^} HCI_EXT_BT_OPERATION, *PHCI_EXT_BT_OPERATION;$/;"	t	typeref:enum:_HCI_EXT_BT_OPERATION
-PHCI_EXT_CONFIG	include/rtw_btcoex.h	/^} HCI_EXT_CONFIG, *PHCI_EXT_CONFIG;$/;"	t	typeref:struct:_HCI_EXT_CONFIG
-PHCI_LINK_INFO	include/rtw_btcoex.h	/^} HCI_LINK_INFO, *PHCI_LINK_INFO;$/;"	t	typeref:struct:_HCI_LINK_INFO
-PHCI_PHY_LINK_BSS_INFO	include/rtw_btcoex.h	/^} HCI_PHY_LINK_BSS_INFO, *PHCI_PHY_LINK_BSS_INFO;$/;"	t	typeref:struct:_HCI_PHY_LINK_BSS_INFO
-PHIMR_ATIMEND_E	include/hal_com_reg.h	916;"	d
-PHIMR_ATIM_CTW_END	include/hal_com_reg.h	917;"	d
-PHIMR_BCNDMAINT0	include/hal_com_reg.h	909;"	d
-PHIMR_BCNDMAINT1	include/hal_com_reg.h	908;"	d
-PHIMR_BCNDMAINT2	include/hal_com_reg.h	907;"	d
-PHIMR_BCNDMAINT3	include/hal_com_reg.h	906;"	d
-PHIMR_BCNDMAINT4	include/hal_com_reg.h	935;"	d
-PHIMR_BCNDMAINT5	include/hal_com_reg.h	934;"	d
-PHIMR_BCNDMAINT6	include/hal_com_reg.h	933;"	d
-PHIMR_BCNDMAINT7	include/hal_com_reg.h	932;"	d
-PHIMR_BCNDMAINT_E	include/hal_com_reg.h	915;"	d
-PHIMR_BCNDOK0	include/hal_com_reg.h	913;"	d
-PHIMR_BCNDOK1	include/hal_com_reg.h	912;"	d
-PHIMR_BCNDOK2	include/hal_com_reg.h	911;"	d
-PHIMR_BCNDOK3	include/hal_com_reg.h	910;"	d
-PHIMR_BCNDOK4	include/hal_com_reg.h	939;"	d
-PHIMR_BCNDOK5	include/hal_com_reg.h	938;"	d
-PHIMR_BCNDOK6	include/hal_com_reg.h	937;"	d
-PHIMR_BCNDOK7	include/hal_com_reg.h	936;"	d
-PHIMR_BEDOK	include/hal_com_reg.h	925;"	d
-PHIMR_BKDOK	include/hal_com_reg.h	924;"	d
-PHIMR_C2HCMD	include/hal_com_reg.h	919;"	d
-PHIMR_CPWM	include/hal_com_reg.h	921;"	d
-PHIMR_CPWM2	include/hal_com_reg.h	920;"	d
-PHIMR_GTINT3	include/hal_com_reg.h	902;"	d
-PHIMR_GTINT4	include/hal_com_reg.h	901;"	d
-PHIMR_HIGHDOK	include/hal_com_reg.h	922;"	d
-PHIMR_HISRE_IND	include/hal_com_reg.h	918;"	d
-PHIMR_HSISR_IND_ON	include/hal_com_reg.h	914;"	d
-PHIMR_MGNTDOK	include/hal_com_reg.h	923;"	d
-PHIMR_OCPINT	include/hal_com_reg.h	946;"	d
-PHIMR_PSTIMEOUT	include/hal_com_reg.h	900;"	d
-PHIMR_RDU	include/hal_com_reg.h	928;"	d
-PHIMR_ROK	include/hal_com_reg.h	929;"	d
-PHIMR_RXERR	include/hal_com_reg.h	942;"	d
-PHIMR_RXFOVW	include/hal_com_reg.h	944;"	d
-PHIMR_TIMEOUT1	include/hal_com_reg.h	899;"	d
-PHIMR_TIMEOUT2	include/hal_com_reg.h	898;"	d
-PHIMR_TSF_BIT32_TOGGLE	include/hal_com_reg.h	905;"	d
-PHIMR_TXBCNERR	include/hal_com_reg.h	903;"	d
-PHIMR_TXBCNOK	include/hal_com_reg.h	904;"	d
-PHIMR_TXERR	include/hal_com_reg.h	941;"	d
-PHIMR_TXFOVW	include/hal_com_reg.h	943;"	d
-PHIMR_VIDOK	include/hal_com_reg.h	926;"	d
-PHIMR_VODOK	include/hal_com_reg.h	927;"	d
-PHTIOT_PEER_E	include/rtw_mlme_ext.h	/^} HT_IOT_PEER_E, *PHTIOT_PEER_E;$/;"	t	typeref:enum:_HT_IOT_PEER
-PHW_BLOCK_E	include/hal_phy.h	/^} HW_BLOCK_E, *PHW_BLOCK_E;$/;"	t	typeref:enum:_HW_BLOCK
-PHYDM_2G	hal/phydm/phydm_kfree.h	/^	PHYDM_2G = 0,$/;"	e	enum:tag_phydm_kfree_channeltosw
-PHYDM_2R_PATH_DIV	hal/phydm/phydm_pathdiv.h	/^	PHYDM_2R_PATH_DIV = 1,$/;"	e	enum:path_div_type
-PHYDM_4R_PATH_DIV	hal/phydm/phydm_pathdiv.h	/^	PHYDM_4R_PATH_DIV = 2$/;"	e	enum:path_div_type
-PHYDM_5GHB	hal/phydm/phydm_kfree.h	/^	PHYDM_5GHB = 5,$/;"	e	enum:tag_phydm_kfree_channeltosw
-PHYDM_5GLB1	hal/phydm/phydm_kfree.h	/^	PHYDM_5GLB1 = 1,$/;"	e	enum:tag_phydm_kfree_channeltosw
-PHYDM_5GLB2	hal/phydm/phydm_kfree.h	/^	PHYDM_5GLB2 = 2,$/;"	e	enum:tag_phydm_kfree_channeltosw
-PHYDM_5GMB1	hal/phydm/phydm_kfree.h	/^	PHYDM_5GMB1 = 3,$/;"	e	enum:tag_phydm_kfree_channeltosw
-PHYDM_5GMB2	hal/phydm/phydm_kfree.h	/^	PHYDM_5GMB2 = 4,$/;"	e	enum:tag_phydm_kfree_channeltosw
-PHYDM_A	hal/phydm/phydm_pathdiv.h	44;"	d
-PHYDM_A	hal/phydm/phydm_pre_define.h	52;"	d
-PHYDM_AB	hal/phydm/phydm_pathdiv.h	48;"	d
-PHYDM_AB	hal/phydm/phydm_pre_define.h	56;"	d
-PHYDM_ABC	hal/phydm/phydm_pathdiv.h	55;"	d
-PHYDM_ABC	hal/phydm/phydm_pre_define.h	62;"	d
-PHYDM_ABCD	hal/phydm/phydm_pathdiv.h	60;"	d
-PHYDM_ABCD	hal/phydm/phydm_pre_define.h	66;"	d
-PHYDM_ABD	hal/phydm/phydm_pathdiv.h	56;"	d
-PHYDM_ABD	hal/phydm/phydm_pre_define.h	63;"	d
-PHYDM_ABOVE	hal/phydm/phydm_pre_define.h	/^	PHYDM_ABOVE		= 2$/;"	e	enum:tag_Secondary_Channel_Offset_Definition
-PHYDM_AC	hal/phydm/phydm_pathdiv.h	49;"	d
-PHYDM_AC	hal/phydm/phydm_pre_define.h	57;"	d
-PHYDM_ACD	hal/phydm/phydm_pathdiv.h	57;"	d
-PHYDM_ACD	hal/phydm/phydm_pre_define.h	64;"	d
-PHYDM_ACTING_TYPE	hal/phydm/phydm_beamforming.h	/^} PHYDM_ACTING_TYPE;$/;"	t	typeref:enum:_PHYDM_ACTING_TYPE
-PHYDM_AD	hal/phydm/phydm_pathdiv.h	50;"	d
-PHYDM_AD	hal/phydm/phydm_pre_define.h	58;"	d
-PHYDM_ADAPINFO_AP_NUM_TH	hal/phydm/phydm_adaptivity.h	/^	PHYDM_ADAPINFO_AP_NUM_TH$/;"	e	enum:_PHYDM_ADAPTIVITY_Info_Definition
-PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE	hal/phydm/phydm_adaptivity.h	/^	PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE = 0,$/;"	e	enum:_PHYDM_ADAPTIVITY_Info_Definition
-PHYDM_ADAPINFO_DCBACKOFF	hal/phydm/phydm_adaptivity.h	/^	PHYDM_ADAPINFO_DCBACKOFF,$/;"	e	enum:_PHYDM_ADAPTIVITY_Info_Definition
-PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY	hal/phydm/phydm_adaptivity.h	/^	PHYDM_ADAPINFO_DYNAMICLINKADAPTIVITY,$/;"	e	enum:_PHYDM_ADAPTIVITY_Info_Definition
-PHYDM_ADAPINFO_E	hal/phydm/phydm_adaptivity.h	/^} PHYDM_ADAPINFO_E;$/;"	t	typeref:enum:_PHYDM_ADAPTIVITY_Info_Definition
-PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF	hal/phydm/phydm_adaptivity.h	/^	PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF,$/;"	e	enum:_PHYDM_ADAPTIVITY_Info_Definition
-PHYDM_ADAPINFO_TH_L2H_INI	hal/phydm/phydm_adaptivity.h	/^	PHYDM_ADAPINFO_TH_L2H_INI,$/;"	e	enum:_PHYDM_ADAPTIVITY_Info_Definition
-PHYDM_ANTDIV	hal/phydm/phydm_debug.c	/^	PHYDM_ANTDIV,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_ANT_SWITCH	hal/phydm/phydm_debug.c	/^	PHYDM_ANT_SWITCH$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_API	hal/phydm/phydm_debug.c	/^	PHYDM_API,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_API_CSI_MASK	hal/phydm/phydm.h	/^	PHYDM_API_CSI_MASK,$/;"	e	enum:_PHYDM_API_Definition
-PHYDM_API_E	hal/phydm/phydm.h	/^} PHYDM_API_E;$/;"	t	typeref:enum:_PHYDM_API_Definition
-PHYDM_API_NBI	hal/phydm/phydm.h	/^	PHYDM_API_NBI			= 1,$/;"	e	enum:_PHYDM_API_Definition
-PHYDM_ARFR0_AC_2SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_ARFR0_AC_2SS	= 9,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_ARFR1_AC_1SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_ARFR1_AC_1SS	= 10,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_ARFR2_AC_2G_1SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_ARFR2_AC_2G_1SS	= 11,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_ARFR3_AC_2G_2SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_ARFR3_AC_2G_2SS	= 12,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_ARFR4_AC_3SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_ARFR4_AC_3SS	= 13,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_ARFR5_N_3SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_ARFR5_N_3SS		= 14$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_AUTO_PATH	hal/phydm/phydm_pathdiv.h	37;"	d
-PHYDM_B	hal/phydm/phydm_pathdiv.h	45;"	d
-PHYDM_B	hal/phydm/phydm_pre_define.h	53;"	d
-PHYDM_BB_INFO	hal/phydm/phydm_debug.c	/^	PHYDM_BB_INFO,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_BC	hal/phydm/phydm_pathdiv.h	51;"	d
-PHYDM_BC	hal/phydm/phydm_pre_define.h	59;"	d
-PHYDM_BCD	hal/phydm/phydm_pathdiv.h	58;"	d
-PHYDM_BCD	hal/phydm/phydm_pre_define.h	65;"	d
-PHYDM_BD	hal/phydm/phydm_pathdiv.h	52;"	d
-PHYDM_BD	hal/phydm/phydm_pre_define.h	60;"	d
-PHYDM_BELOW	hal/phydm/phydm_pre_define.h	/^	PHYDM_BELOW		= 1,$/;"	e	enum:tag_Secondary_Channel_Offset_Definition
-PHYDM_BG	hal/phydm/phydm_rainfo.h	/^	PHYDM_BG				= 6,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_BGN_20M_1SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_BGN_20M_1SS	= 3,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_BGN_20M_2SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_BGN_20M_2SS	= 2,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_BGN_40M_1SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_BGN_40M_1SS	= 1,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_BGN_40M_2SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_BGN_40M_2SS	= 0,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_BIG_JUMP	hal/phydm/phydm_debug.c	/^	PHYDM_BIG_JUMP,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_BW_10	hal/phydm/phydm_rainfo.h	/^	PHYDM_BW_10,$/;"	e	enum:_PHYDM_BW
-PHYDM_BW_160	hal/phydm/phydm_rainfo.h	/^	PHYDM_BW_160,$/;"	e	enum:_PHYDM_BW
-PHYDM_BW_20	hal/phydm/phydm_rainfo.h	/^	PHYDM_BW_20	= 0,$/;"	e	enum:_PHYDM_BW
-PHYDM_BW_40	hal/phydm/phydm_rainfo.h	/^	PHYDM_BW_40,$/;"	e	enum:_PHYDM_BW
-PHYDM_BW_5	hal/phydm/phydm_rainfo.h	/^	PHYDM_BW_5$/;"	e	enum:_PHYDM_BW
-PHYDM_BW_80	hal/phydm/phydm_rainfo.h	/^	PHYDM_BW_80,$/;"	e	enum:_PHYDM_BW
-PHYDM_BW_80_80	hal/phydm/phydm_rainfo.h	/^	PHYDM_BW_80_80,	$/;"	e	enum:_PHYDM_BW
-PHYDM_BW_E	hal/phydm/phydm_rainfo.h	/^} PHYDM_BW_E;$/;"	t	typeref:enum:_PHYDM_BW
-PHYDM_B_20M	hal/phydm/phydm_rainfo.h	/^	PHYDM_B_20M			= 8,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_C	hal/phydm/phydm_pathdiv.h	46;"	d
-PHYDM_C	hal/phydm/phydm_pre_define.h	54;"	d
-PHYDM_C2H_BT_MP	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_BT_MP = 11,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_DBG	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_DBG = 0,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_DBG_CODE	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_DBG_CODE = 0xFE,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_DYNAMIC_TX_PATH_RPT	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_DYNAMIC_TX_PATH_RPT = 15,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_EVT	hal/phydm/phydm_interface.h	/^}PHYDM_C2H_EVT;$/;"	t	typeref:enum:_PHYDM_C2H_EVT
-PHYDM_C2H_EXTEND	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_EXTEND = 0xFF,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_INFO	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_INFO = 9,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_IQK_FINISH	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_IQK_FINISH = 17, \/*0x11*\/$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_LB	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_LB = 1,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_RA_PARA_RPT	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_RA_PARA_RPT=14,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_RA_RPT	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_RA_RPT = 12,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_TX_REPORT	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_TX_REPORT = 3,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_C2H_XBF	hal/phydm/phydm_interface.h	/^	PHYDM_C2H_XBF = 2,$/;"	e	enum:_PHYDM_C2H_EVT
-PHYDM_CD	hal/phydm/phydm_pathdiv.h	53;"	d
-PHYDM_CD	hal/phydm/phydm_pre_define.h	61;"	d
-PHYDM_CLM	hal/phydm/phydm_debug.c	/^	PHYDM_CLM,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_CMD_ID	hal/phydm/phydm_debug.c	/^enum PHYDM_CMD_ID {$/;"	g	file:
-PHYDM_CODE_BASE	hal/phydm/phydm_pre_define.h	29;"	d
-PHYDM_COMP_ADAPTIVITY	hal/phydm/phydm_debug.h	109;"	d
-PHYDM_COMP_RA_DBG	hal/phydm/phydm_debug.h	110;"	d
-PHYDM_COMP_TXBF	hal/phydm/phydm_debug.h	111;"	d
-PHYDM_CSI_MASK_EN	hal/phydm/phydm_debug.c	/^	PHYDM_CSI_MASK_EN,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_CTRL_INFO_PAGE	hal/phydm/txbf/haltxbf8814a.c	29;"	d	file:
-PHYDM_CmnInfoQuery	hal/phydm/phydm.c	/^PHYDM_CmnInfoQuery($/;"	f
-PHYDM_D	hal/phydm/phydm_pathdiv.h	47;"	d
-PHYDM_D	hal/phydm/phydm_pre_define.h	55;"	d
-PHYDM_DBGPRINT	hal/phydm/phydm_debug.h	219;"	d
-PHYDM_DBGPRINT	hal/phydm/phydm_debug.h	237;"	d
-PHYDM_DBGPRINT	hal/phydm/phydm_debug.h	239;"	d
-PHYDM_DEBUG	hal/phydm/phydm_debug.c	/^	PHYDM_DEBUG,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_DEMO	hal/phydm/phydm_debug.c	/^	PHYDM_DEMO,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_DFS	hal/phydm/phydm_debug.c	/^	PHYDM_DFS,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_DFS_DOMAIN_ETSI	hal/phydm/phydm_dfs.h	/^	PHYDM_DFS_DOMAIN_ETSI = 3,$/;"	e	enum:_tag_PhyDM_DFS_REGION_DOMAIN
-PHYDM_DFS_DOMAIN_FCC	hal/phydm/phydm_dfs.h	/^	PHYDM_DFS_DOMAIN_FCC = 1,$/;"	e	enum:_tag_PhyDM_DFS_REGION_DOMAIN
-PHYDM_DFS_DOMAIN_MKK	hal/phydm/phydm_dfs.h	/^	PHYDM_DFS_DOMAIN_MKK = 2,$/;"	e	enum:_tag_PhyDM_DFS_REGION_DOMAIN
-PHYDM_DFS_DOMAIN_UNKNOWN	hal/phydm/phydm_dfs.h	/^	PHYDM_DFS_DOMAIN_UNKNOWN = 0,$/;"	e	enum:_tag_PhyDM_DFS_REGION_DOMAIN
-PHYDM_DFS_REGION_DOMAIN	hal/phydm/phydm_dfs.h	/^} PHYDM_DFS_REGION_DOMAIN;$/;"	t	typeref:enum:_tag_PhyDM_DFS_REGION_DOMAIN
-PHYDM_DONT_CARE	hal/phydm/phydm_pre_define.h	/^	PHYDM_DONT_CARE	= 0,$/;"	e	enum:tag_Secondary_Channel_Offset_Definition
-PHYDM_DTP_INIT	hal/phydm/phydm_pathdiv.h	/^	PHYDM_DTP_INIT=1,$/;"	e	enum:dtp_state
-PHYDM_DTP_RUNNING_1	hal/phydm/phydm_pathdiv.h	/^	PHYDM_DTP_RUNNING_1$/;"	e	enum:dtp_state
-PHYDM_DTP_STATE	hal/phydm/phydm_pathdiv.h	/^}PHYDM_DTP_STATE;$/;"	t	typeref:enum:dtp_state
-PHYDM_DUMP_REG	hal/phydm/phydm_debug.c	/^	PHYDM_DUMP_REG,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_EXTEND_C2H_DBG_PRINT	hal/phydm/phydm_interface.h	/^	PHYDM_EXTEND_C2H_DBG_PRINT = 0$/;"	e	enum:_PHYDM_EXTEND_C2H_EVT
-PHYDM_EXTEND_C2H_EVT	hal/phydm/phydm_interface.h	/^}PHYDM_EXTEND_C2H_EVT;$/;"	t	typeref:enum:_PHYDM_EXTEND_C2H_EVT
-PHYDM_FIX_PATH	hal/phydm/phydm_pathdiv.h	38;"	d
-PHYDM_FW_COMP_MU	hal/phydm/phydm_debug.h	85;"	d
-PHYDM_FW_COMP_PATH_DIV	hal/phydm/phydm_debug.h	86;"	d
-PHYDM_FW_COMP_PHY_CONFIG	hal/phydm/phydm_debug.h	87;"	d
-PHYDM_FW_COMP_RA	hal/phydm/phydm_debug.h	84;"	d
-PHYDM_FW_DEBUG	hal/phydm/phydm_debug.c	/^	PHYDM_FW_DEBUG,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_G	hal/phydm/phydm_rainfo.h	/^	PHYDM_G				= 7,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_GET_TXAGC	hal/phydm/phydm_debug.c	/^	PHYDM_GET_TXAGC,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_GN_N1SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_GN_N1SS			= 5,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_GN_N2SS	hal/phydm/phydm_rainfo.h	/^	PHYDM_GN_N2SS			= 4,$/;"	e	enum:PHYDM_RATEID_IDX_
-PHYDM_H2C	hal/phydm/phydm_debug.c	/^	PHYDM_H2C,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_H2C_CMD	hal/phydm/phydm_interface.h	/^}PHYDM_H2C_CMD;$/;"	t	typeref:enum:_PHYDM_H2C_CMD
-PHYDM_H2C_DYNAMIC_TX_PATH	hal/phydm/phydm_interface.h	/^	PHYDM_H2C_DYNAMIC_TX_PATH = 0x48,$/;"	e	enum:_PHYDM_H2C_CMD
-PHYDM_H2C_FW_TRACE_EN	hal/phydm/phydm_interface.h	/^	PHYDM_H2C_FW_TRACE_EN	= 0x49,$/;"	e	enum:_PHYDM_H2C_CMD
-PHYDM_H2C_MU	hal/phydm/phydm_interface.h	/^	PHYDM_H2C_MU				= 0x4a,$/;"	e	enum:_PHYDM_H2C_CMD
-PHYDM_H2C_TXBF	hal/phydm/phydm_interface.h	/^	PHYDM_H2C_TXBF			= 0x41,$/;"	e	enum:_PHYDM_H2C_CMD
-PHYDM_HANG	hal/phydm/phydm_debug.c	/^	PHYDM_HANG,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_HELP	hal/phydm/phydm_debug.c	/^	PHYDM_HELP,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_IC_3081_SERIES	hal/phydm/phydm_pre_define.h	355;"	d
-PHYDM_IC_8051_SERIES	hal/phydm/phydm_pre_define.h	354;"	d
-PHYDM_IC_SUPPORT_LA_MODE	hal/phydm/phydm_pre_define.h	357;"	d
-PHYDM_INFO_CCA_ALL	hal/phydm/phydm.h	/^	PHYDM_INFO_CCA_ALL,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CCA_CCK	hal/phydm/phydm.h	/^	PHYDM_INFO_CCA_CCK,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CCA_OFDM	hal/phydm/phydm.h	/^	PHYDM_INFO_CCA_OFDM,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CCK_ENABLE	hal/phydm/phydm.h	/^	PHYDM_INFO_CCK_ENABLE,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_ERROR_CCK	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_ERROR_CCK,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_ERROR_HT	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_ERROR_HT,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_ERROR_LEGACY	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_ERROR_LEGACY,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_ERROR_VHT	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_ERROR_VHT,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_OK_CCK	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_OK_CCK,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_OK_HT	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_OK_HT,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_OK_LEGACY	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_OK_LEGACY,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_CRC32_OK_VHT	hal/phydm/phydm.h	/^	PHYDM_INFO_CRC32_OK_VHT,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_DBG_PORT_0	hal/phydm/phydm.h	/^	PHYDM_INFO_DBG_PORT_0$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_EDCCA_FLAG	hal/phydm/phydm.h	/^	PHYDM_INFO_EDCCA_FLAG,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_FA_CCK	hal/phydm/phydm.h	/^	PHYDM_INFO_FA_CCK,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_FA_OFDM	hal/phydm/phydm.h	/^	PHYDM_INFO_FA_OFDM,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_FA_TOTAL	hal/phydm/phydm.h	/^	PHYDM_INFO_FA_TOTAL,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_OFDM_ENABLE	hal/phydm/phydm.h	/^	PHYDM_INFO_OFDM_ENABLE,$/;"	e	enum:_PHYDM_Info_query_type
-PHYDM_INFO_QUERY_E	hal/phydm/phydm.h	/^} PHYDM_INFO_QUERY_E;$/;"	t	typeref:enum:_PHYDM_Info_query_type
-PHYDM_IQK	hal/phydm/phydm_debug.c	/^	PHYDM_IQK,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_InitDebugSetting	hal/phydm/phydm_debug.c	/^PHYDM_InitDebugSetting($/;"	f
-PHYDM_InitHwInfoByRfe	hal/phydm/phydm.c	/^PHYDM_InitHwInfoByRfe($/;"	f
-PHYDM_InitSoftMLSetting	hal/phydm/phydm.c	/^PHYDM_InitSoftMLSetting($/;"	f
-PHYDM_InitTRXAntennaSetting	hal/phydm/phydm.c	/^PHYDM_InitTRXAntennaSetting($/;"	f
-PHYDM_KFREE_CHANNELTOSW	hal/phydm/phydm_kfree.h	/^} PHYDM_KFREE_CHANNELTOSW;$/;"	t	typeref:enum:tag_phydm_kfree_channeltosw
-PHYDM_LA_MODE	hal/phydm/phydm_debug.c	/^	PHYDM_LA_MODE,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_LA_MODE_SUPPORT	hal/phydm/phydm_pre_define.h	397;"	d
-PHYDM_LA_MODE_SUPPORT	hal/phydm/phydm_pre_define.h	399;"	d
-PHYDM_MEMORY_MAP_BUF_READ	hal/phydm/txbf/haltxbf8814a.c	28;"	d	file:
-PHYDM_MSG_LEN	os_dep/linux/rtw_proc.c	2549;"	d	file:
-PHYDM_MU_MIMO	hal/phydm/phydm_debug.c	/^	PHYDM_MU_MIMO,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_NBI_EN	hal/phydm/phydm_debug.c	/^	PHYDM_NBI_EN,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_NHM	hal/phydm/phydm_debug.c	/^	PHYDM_NHM,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_PATHDIV	hal/phydm/phydm_debug.c	/^	PHYDM_PATHDIV,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_PATH_DIV_TYPE	hal/phydm/phydm_pathdiv.h	/^}PHYDM_PATH_DIV_TYPE;$/;"	t	typeref:enum:path_div_type
-PHYDM_PAUSE	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE = BIT0,$/;"	e	enum:tag_PHYDM_Pause_Type
-PHYDM_PAUSE_DIG_EN	hal/phydm/phydm_debug.c	/^	PHYDM_PAUSE_DIG_EN,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_PAUSE_LEVEL	hal/phydm/phydm_dig.h	/^} PHYDM_PAUSE_LEVEL;$/;"	t	typeref:enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_0	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_0 = 0,$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_1	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_1 = 1,$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_2	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_2 = 2,$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_3	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_3 = 3,$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_4	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_4 = 4,$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_5	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_5 = 5,$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_6	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_6 = 6,$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_LEVEL_7	hal/phydm/phydm_dig.h	/^	PHYDM_PAUSE_LEVEL_7 = DM_DIG_MAX_PAUSE_TYPE		\/* maximum level *\/$/;"	e	enum:tag_PHYDM_Pause_Level
-PHYDM_PAUSE_TYPE	hal/phydm/phydm_dig.h	/^} PHYDM_PAUSE_TYPE;$/;"	t	typeref:enum:tag_PHYDM_Pause_Type
-PHYDM_PROFILE	hal/phydm/phydm_debug.c	/^	PHYDM_PROFILE,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_RA	hal/phydm/phydm_debug.c	/^	PHYDM_RA,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_RATEID_IDX_	hal/phydm/phydm_rainfo.h	/^typedef enum PHYDM_RATEID_IDX_ {$/;"	g
-PHYDM_RATEID_IDX_E	hal/phydm/phydm_rainfo.h	/^} PHYDM_RATEID_IDX_E;$/;"	t	typeref:enum:PHYDM_RATEID_IDX_
-PHYDM_RA_ARFR_NUM_E	hal/phydm/phydm_rainfo.h	/^} PHYDM_RA_ARFR_NUM_E;$/;"	t	typeref:enum:_phydm_arfr_num
-PHYDM_RA_DBG_PARA_E	hal/phydm/phydm_rainfo.h	/^} PHYDM_RA_DBG_PARA_E;$/;"	t	typeref:enum:_Phydm_ra_dbg_para
-PHYDM_RELEASE_DATE	hal/phydm/phydm_pre_define.h	30;"	d
-PHYDM_RESUME	hal/phydm/phydm_dig.h	/^	PHYDM_RESUME = BIT1$/;"	e	enum:tag_PHYDM_Pause_Type
-PHYDM_RF_1T1R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_1T1R = 0,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_1T2R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_1T2R,			$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_2T2R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_2T2R,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_2T2R_GREEN	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_2T2R_GREEN,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_2T3R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_2T3R,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_2T4R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_2T4R,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_3T3R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_3T3R,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_3T4R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_3T4R,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_4T4R	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_4T4R,$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_MAX_TYPE	hal/phydm/phydm_rainfo.h	/^	PHYDM_RF_MAX_TYPE$/;"	e	enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_RF_TYPE_DEF_E	hal/phydm/phydm_rainfo.h	/^} PHYDM_RF_TYPE_DEF_E;$/;"	t	typeref:enum:_PHYDM_RF_TYPE_DEFINITION
-PHYDM_SEC_CHNL_OFFSET_E	hal/phydm/phydm_pre_define.h	/^} PHYDM_SEC_CHNL_OFFSET_E;$/;"	t	typeref:enum:tag_Secondary_Channel_Offset_Definition
-PHYDM_SET_TXAGC	hal/phydm/phydm_debug.c	/^	PHYDM_SET_TXAGC,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_SHOW_RXRATE	hal/phydm/phydm_debug.c	/^	PHYDM_SHOW_RXRATE,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_SMART_ANT	hal/phydm/phydm_debug.c	/^	PHYDM_SMART_ANT,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_SNPRINTF	hal/phydm/phydm_debug.h	223;"	d
-PHYDM_SNPRINTF	hal/phydm/phydm_debug.h	229;"	d
-PHYDM_SNPRINTF	hal/phydm/phydm_debug.h	256;"	d
-PHYDM_SNPRINTF	hal/phydm/phydm_debug.h	262;"	d
-PHYDM_SSCANF	hal/phydm/phydm_debug.h	220;"	d
-PHYDM_SSCANF	hal/phydm/phydm_debug.h	247;"	d
-PHYDM_SUPPORT_ABILITY	hal/phydm/phydm_debug.c	/^	PHYDM_SUPPORT_ABILITY,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_TESTCHIP_SUPPORT	hal/phydm/phydm_types.h	122;"	d
-PHYDM_TESTCHIP_SUPPORT	hal/phydm/phydm_types.h	167;"	d
-PHYDM_TESTCHIP_SUPPORT	hal/phydm/phydm_types.h	169;"	d
-PHYDM_TESTCHIP_SUPPORT	hal/phydm/phydm_types.h	248;"	d
-PHYDM_TESTCHIP_SUPPORT	hal/phydm/phydm_types.h	250;"	d
-PHYDM_TRX_PATH	hal/phydm/phydm_debug.c	/^	PHYDM_TRX_PATH,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_TXBF	hal/phydm/phydm_debug.c	/^	PHYDM_TXBF,$/;"	e	enum:PHYDM_CMD_ID	file:
-PHYDM_VAST_INFO_SNPRINTF	hal/phydm/phydm_debug.h	221;"	d
-PHYDM_VAST_INFO_SNPRINTF	hal/phydm/phydm_debug.h	249;"	d
-PHYDM_WATCH_DOG_PERIOD	hal/phydm/phydm.h	109;"	d
-PHYDM_WATCH_DOG_PERIOD	hal/phydm/phydm.h	111;"	d
-PHYDM_WIRELESS_MODE	hal/phydm/phydm_rainfo.h	/^typedef enum PHYDM_WIRELESS_MODE {$/;"	g
-PHYDM_WIRELESS_MODE_A	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_A		= 0x01,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_AC_24G	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_AC_24G	= 0x80,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_AC_5G	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_AC_5G	= 0x40,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_AC_ONLY	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_AC_ONLY	= 0x100,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_ALL	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_ALL		= 0xFFFF$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_AUTO	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_AUTO	= 0x08,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_B	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_B		= 0x02,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_E	hal/phydm/phydm_rainfo.h	/^} PHYDM_WIRELESS_MODE_E;$/;"	t	typeref:enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_G	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_G		= 0x04,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_MAX	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_MAX		= 0x800,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_N_24G	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_N_24G	= 0x10,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_N_5G	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_N_5G	= 0x20,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYDM_WIRELESS_MODE_UNKNOWN	hal/phydm/phydm_rainfo.h	/^	PHYDM_WIRELESS_MODE_UNKNOWN = 0x00,$/;"	e	enum:PHYDM_WIRELESS_MODE
-PHYRegDef	include/hal_data.h	/^	BB_REGISTER_DEFINITION_T	PHYRegDef[MAX_RF_PATH];	\/* Radio A\/B\/C\/D *\/$/;"	m	struct:hal_com_data
-PHY_APCalibrate_8192C	hal/phydm/halphyrf_ap.c	/^PHY_APCalibrate_8192C($/;"	f
-PHY_APCalibrate_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^PHY_APCalibrate_8723D($/;"	f
-PHY_BBConfig8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_BBConfig8723D($/;"	f
-PHY_CalculateBitShift	hal/hal_phy.c	/^PHY_CalculateBitShift($/;"	f
-PHY_ConfigRFWithParaFile	hal/hal_com_phycfg.c	/^PHY_ConfigRFWithParaFile($/;"	f
-PHY_ConfigRFWithParaFile_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_ConfigRFWithParaFile_8723D($/;"	f
-PHY_ConfigRFWithPowerLimitTableParaFile	hal/hal_com_phycfg.c	/^PHY_ConfigRFWithPowerLimitTableParaFile($/;"	f
-PHY_ConfigRFWithTxPwrTrackParaFile	hal/hal_com_phycfg.c	/^PHY_ConfigRFWithTxPwrTrackParaFile($/;"	f
-PHY_ConvertTxPowerLimitToPowerIndex	hal/hal_com_phycfg.c	/^PHY_ConvertTxPowerLimitToPowerIndex($/;"	f
-PHY_DigitalPredistortion_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^PHY_DigitalPredistortion_8723D($/;"	f
-PHY_FILE_AGC_TAB	include/hal_com_phycfg.h	313;"	d
-PHY_FILE_MAC_REG	include/hal_com_phycfg.h	311;"	d
-PHY_FILE_PHY_REG	include/hal_com_phycfg.h	314;"	d
-PHY_FILE_PHY_REG_MP	include/hal_com_phycfg.h	315;"	d
-PHY_FILE_PHY_REG_PG	include/hal_com_phycfg.h	316;"	d
-PHY_FILE_RADIO_A	include/hal_com_phycfg.h	318;"	d
-PHY_FILE_RADIO_B	include/hal_com_phycfg.h	319;"	d
-PHY_FILE_RADIO_C	include/hal_com_phycfg.h	320;"	d
-PHY_FILE_RADIO_D	include/hal_com_phycfg.h	321;"	d
-PHY_FILE_TXPWR_LMT	include/hal_com_phycfg.h	323;"	d
-PHY_FILE_TXPWR_TRACK	include/hal_com_phycfg.h	322;"	d
-PHY_FILE_WIFI_ANT_ISOLATION	include/hal_com_phycfg.h	325;"	d
-PHY_GetRateIndexOfTxPowerByRate	hal/hal_com_phycfg.c	/^PHY_GetRateIndexOfTxPowerByRate($/;"	f
-PHY_GetRateValuesOfTxPowerByRate	hal/hal_com_phycfg.c	/^PHY_GetRateValuesOfTxPowerByRate($/;"	f
-PHY_GetTxPowerByRate	hal/hal_com_phycfg.c	/^PHY_GetTxPowerByRate($/;"	f
-PHY_GetTxPowerByRateBase	hal/hal_com_phycfg.c	/^PHY_GetTxPowerByRateBase($/;"	f
-PHY_GetTxPowerByRateOriginal	hal/hal_com_phycfg.c	/^PHY_GetTxPowerByRateOriginal($/;"	f
-PHY_GetTxPowerIndex	hal/hal_com_phycfg.c	/^PHY_GetTxPowerIndex($/;"	f
-PHY_GetTxPowerIndexBase	hal/hal_com_phycfg.c	/^PHY_GetTxPowerIndexBase($/;"	f
-PHY_GetTxPowerIndex_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_GetTxPowerIndex_8723D($/;"	f
-PHY_GetTxPowerLevel8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_GetTxPowerLevel8723D($/;"	f
-PHY_GetTxPowerLimit	hal/hal_com_phycfg.c	/^PHY_GetTxPowerLimit($/;"	f
-PHY_GetTxPowerLimitOriginal	hal/hal_com_phycfg.c	/^PHY_GetTxPowerLimitOriginal($/;"	f
-PHY_GetTxPowerLimit_no_sc	hal/hal_com_phycfg.c	/^PHY_GetTxPowerLimit_no_sc($/;"	f
-PHY_GetTxPowerTrackingOffset	hal/hal_com_phycfg.c	/^PHY_GetTxPowerTrackingOffset($/;"	f
-PHY_HandleSwChnlAndSetBW8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_HandleSwChnlAndSetBW8723D($/;"	f
-PHY_IQCalibrate	core/rtw_mp.c	/^static void PHY_IQCalibrate(PADAPTER padapter, u8 bReCovery)$/;"	f	file:
-PHY_IQCalibrate	core/rtw_mp.c	440;"	d	file:
-PHY_IQCalibrate	core/rtw_mp.c	446;"	d	file:
-PHY_IQCalibrate	core/rtw_mp.c	452;"	d	file:
-PHY_IQCalibrate	core/rtw_mp.c	458;"	d	file:
-PHY_IQCalibrate	core/rtw_mp.c	464;"	d	file:
-PHY_IQCalibrate	core/rtw_mp.c	510;"	d	file:
-PHY_IQCalibrate	core/rtw_mp.c	516;"	d	file:
-PHY_IQCalibrate	core/rtw_mp.c	522;"	d	file:
-PHY_IQCalibrate_8192C	hal/phydm/halphyrf_ap.c	/^PHY_IQCalibrate_8192C($/;"	f
-PHY_IQCalibrate_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^PHY_IQCalibrate_8723D($/;"	f
-PHY_IQCalibrate_default	core/rtw_mp.c	/^static VOID PHY_IQCalibrate_default($/;"	f	file:
-PHY_InitTxPowerByRate	hal/hal_com_phycfg.c	/^PHY_InitTxPowerByRate($/;"	f
-PHY_InitTxPowerLimit	hal/hal_com_phycfg.c	/^PHY_InitTxPowerLimit($/;"	f
-PHY_LCCalibrate	core/rtw_mp.c	441;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	447;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	453;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	459;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	465;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	483;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	494;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	505;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	511;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	517;"	d	file:
-PHY_LCCalibrate	core/rtw_mp.c	523;"	d	file:
-PHY_LCCalibrate	hal/phydm/halphyrf_ap.h	/^	FuncLCK		PHY_LCCalibrate;$/;"	m	struct:_TXPWRTRACK_CFG
-PHY_LCCalibrate	hal/phydm/halphyrf_ce.h	/^	FuncLCK		PHY_LCCalibrate;$/;"	m	struct:_TXPWRTRACK_CFG
-PHY_LCCalibrate	hal/phydm/halphyrf_win.h	/^	FuncLCK		PHY_LCCalibrate;$/;"	m	struct:_TXPWRTRACK_CFG
-PHY_LCCalibrate_8192C	hal/phydm/halphyrf_ap.c	/^PHY_LCCalibrate_8192C($/;"	f
-PHY_LCCalibrate_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^PHY_LCCalibrate_8723D($/;"	f
-PHY_LCCalibrate_default	core/rtw_mp.c	/^static VOID PHY_LCCalibrate_default($/;"	f	file:
-PHY_LINKQUALITY_SLID_WIN_MAX	include/rtw_recv.h	72;"	d
-PHY_MACConfig8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^s32 PHY_MACConfig8723D(PADAPTER Adapter)$/;"	f
-PHY_QueryBBReg	include/hal_intf.h	639;"	d
-PHY_QueryBBReg_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_QueryBBReg_8723D($/;"	f
-PHY_QueryMacReg	include/hal_intf.h	645;"	d
-PHY_QueryRFPathSwitch_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^BOOLEAN PHY_QueryRFPathSwitch_8723D(	$/;"	f
-PHY_QueryRFReg	include/hal_intf.h	641;"	d
-PHY_QueryRFReg_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_QueryRFReg_8723D($/;"	f
-PHY_REG_PG_EXACT_VALUE	hal/phydm/phydm.h	/^	PHY_REG_PG_EXACT_VALUE = 1$/;"	e	enum:_BASEBAND_CONFIG_PHY_REG_PG_VALUE_TYPE
-PHY_REG_PG_RELATIVE_VALUE	hal/phydm/phydm.h	/^	PHY_REG_PG_RELATIVE_VALUE = 0,$/;"	e	enum:_BASEBAND_CONFIG_PHY_REG_PG_VALUE_TYPE
-PHY_REG_PG_TYPE	hal/phydm/phydm.h	/^} PHY_REG_PG_TYPE;$/;"	t	typeref:enum:_BASEBAND_CONFIG_PHY_REG_PG_VALUE_TYPE
-PHY_RF6052SetBandwidth8723D	hal/rtl8723d/rtl8723d_rf6052.c	/^PHY_RF6052SetBandwidth8723D($/;"	f
-PHY_RF6052_Config8723D	hal/rtl8723d/rtl8723d_rf6052.c	/^PHY_RF6052_Config8723D($/;"	f
-PHY_RFConfig8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_RFConfig8723D($/;"	f
-PHY_RFShadowCompare	hal/hal_phy.c	/^PHY_RFShadowCompare($/;"	f
-PHY_RFShadowCompareAll	hal/hal_phy.c	/^PHY_RFShadowCompareAll($/;"	f
-PHY_RFShadowCompareFlagSet	hal/hal_phy.c	/^PHY_RFShadowCompareFlagSet($/;"	f
-PHY_RFShadowCompareFlagSetAll	hal/hal_phy.c	/^PHY_RFShadowCompareFlagSetAll($/;"	f
-PHY_RFShadowRead	hal/hal_phy.c	/^PHY_RFShadowRead($/;"	f
-PHY_RFShadowRecorver	hal/hal_phy.c	/^PHY_RFShadowRecorver($/;"	f
-PHY_RFShadowRecorverAll	hal/hal_phy.c	/^PHY_RFShadowRecorverAll($/;"	f
-PHY_RFShadowRecorverFlagSet	hal/hal_phy.c	/^PHY_RFShadowRecorverFlagSet($/;"	f
-PHY_RFShadowRecorverFlagSetAll	hal/hal_phy.c	/^PHY_RFShadowRecorverFlagSetAll($/;"	f
-PHY_RFShadowRefresh	hal/hal_phy.c	/^PHY_RFShadowRefresh($/;"	f
-PHY_RFShadowWrite	hal/hal_phy.c	/^PHY_RFShadowWrite($/;"	f
-PHY_RSSI_SLID_WIN_MAX	include/rtw_recv.h	71;"	d
-PHY_RX_AGC_INFO_T	hal/phydm/phydm_hwconfig.h	/^} __WLAN_ATTRIB_PACK__ PHY_RX_AGC_INFO_T, *pPHY_RX_AGC_INFO_T;$/;"	t	typeref:struct:_Phy_Rx_AGC_Info
-PHY_STATUS_RPT_8192CD_T	hal/phydm/phydm_hwconfig.h	/^} __WLAN_ATTRIB_PACK__ PHY_STATUS_RPT_8192CD_T, *PPHY_STATUS_RPT_8192CD_T;$/;"	t	typeref:struct:_Phy_Status_Rpt_8192cd
-PHY_STATUS_RPT_8812_T	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_8812_T, *PPHY_STATUS_RPT_8812_T;$/;"	t	typeref:struct:_Phy_Status_Rpt_8812
-PHY_STATUS_RPT_JAGUAR2_TYPE0	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_JAGUAR2_TYPE0, *PPHY_STATUS_RPT_JAGUAR2_TYPE0;$/;"	t	typeref:struct:_Phy_Status_Rpt_Jaguar2_Type0
-PHY_STATUS_RPT_JAGUAR2_TYPE1	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_JAGUAR2_TYPE1, *PPHY_STATUS_RPT_JAGUAR2_TYPE1;$/;"	t	typeref:struct:_Phy_Status_Rpt_Jaguar2_Type1
-PHY_STATUS_RPT_JAGUAR2_TYPE2	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_JAGUAR2_TYPE2, *PPHY_STATUS_RPT_JAGUAR2_TYPE2;$/;"	t	typeref:struct:_Phy_Status_Rpt_Jaguar2_Type2
-PHY_SetBBReg	include/hal_intf.h	640;"	d
-PHY_SetBBReg_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_SetBBReg_8723D($/;"	f
-PHY_SetMacReg	include/hal_intf.h	644;"	d
-PHY_SetRFPathSwitch	core/rtw_mp.c	442;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	448;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	454;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	460;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	466;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	484;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	495;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	506;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	512;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	518;"	d	file:
-PHY_SetRFPathSwitch	core/rtw_mp.c	524;"	d	file:
-PHY_SetRFPathSwitch_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^VOID PHY_SetRFPathSwitch_8723D($/;"	f
-PHY_SetRFPathSwitch_default	core/rtw_mp.c	/^static VOID PHY_SetRFPathSwitch_default($/;"	f	file:
-PHY_SetRFReg	include/hal_intf.h	642;"	d
-PHY_SetRFReg_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_SetRFReg_8723D($/;"	f
-PHY_SetSwChnlBWMode8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_SetSwChnlBWMode8723D($/;"	f
-PHY_SetTxPowerByRate	hal/hal_com_phycfg.c	/^PHY_SetTxPowerByRate($/;"	f
-PHY_SetTxPowerIndex	hal/hal_com_phycfg.c	/^PHY_SetTxPowerIndex($/;"	f
-PHY_SetTxPowerIndexByRateArray	hal/hal_com_phycfg.c	/^PHY_SetTxPowerIndexByRateArray($/;"	f
-PHY_SetTxPowerIndexByRateSection	hal/hal_com_phycfg.c	/^PHY_SetTxPowerIndexByRateSection($/;"	f
-PHY_SetTxPowerIndex_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_SetTxPowerIndex_8723D($/;"	f
-PHY_SetTxPowerLevel8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^PHY_SetTxPowerLevel8723D($/;"	f
-PHY_SetTxPowerLevelByPath	hal/hal_com_phycfg.c	/^PHY_SetTxPowerLevelByPath($/;"	f
-PHY_SetTxPowerLimit	hal/hal_com_phycfg.c	/^PHY_SetTxPowerLimit($/;"	f
-PHY_StoreTxPowerByRate	hal/hal_com_phycfg.c	/^PHY_StoreTxPowerByRate($/;"	f
-PHY_StoreTxPowerByRateNew	hal/hal_com_phycfg.c	/^PHY_StoreTxPowerByRateNew($/;"	f
-PHY_TxPowerByRateConfiguration	hal/hal_com_phycfg.c	/^PHY_TxPowerByRateConfiguration($/;"	f
-PINTERFACE_SELECT_PCIE	include/hal_data.h	/^} INTERFACE_SELECT_PCIE, *PINTERFACE_SELECT_PCIE;$/;"	t	typeref:enum:_INTERFACE_SELECT_PCIE
-PINTERFACE_SELECT_USB	include/hal_data.h	/^} INTERFACE_SELECT_USB, *PINTERFACE_SELECT_USB;$/;"	t	typeref:enum:_INTERFACE_SELECT_USB
-PIQK_INFO	hal/phydm/phydm_iqk.h	/^} IQK_INFO, *PIQK_INFO;$/;"	t	typeref:struct:_IQK_INFORMATION
-PIQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_ap.h	/^}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;$/;"	t	typeref:struct:_IQK_MATRIX_REGS_SETTING
-PIQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_ce.h	/^}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;$/;"	t	typeref:struct:_IQK_MATRIX_REGS_SETTING
-PIQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_win.h	/^}IQK_MATRIX_REGS_SETTING,*PIQK_MATRIX_REGS_SETTING;$/;"	t	typeref:struct:_IQK_MATRIX_REGS_SETTING
-PJOINBSSRPT_PARM_88E	include/rtl8188e_cmd.h	/^} JOINBSSRPT_PARM_88E, *PJOINBSSRPT_PARM_88E;$/;"	t	typeref:struct:JOINBSSRPT_PARM_88E
-PJOINBSSRPT_PARM_92E	include/rtl8192e_cmd.h	/^} JOINBSSRPT_PARM_92E, *PJOINBSSRPT_PARM_92E;$/;"	t	typeref:struct:JOINBSSRPT_PARM_92E
-PKG_SEL_HCI	include/hal_com_reg.h	1288;"	d
-PKT_OFFSET_SHT	include/rtl8188e_xmit.h	56;"	d
-PKT_OFFSET_SHT	include/rtl8192e_xmit.h	161;"	d
-PKT_OFFSET_SHT	include/rtl8812a_xmit.h	54;"	d
-PKT_OFFSET_SZ	include/rtl8188e_xmit.h	51;"	d
-PKT_OFFSET_SZ	include/rtl8192e_xmit.h	156;"	d
-PKT_OFFSET_SZ	include/rtl8812a_xmit.h	49;"	d
-PLATFORM_LINUX	include/autoconf.h	33;"	d
-PLED_DATA	include/hal_com_led.h	/^typedef struct _LED_PCIE	LED_DATA, *PLED_DATA;$/;"	t	typeref:struct:
-PLED_DATA	include/hal_com_led.h	/^typedef struct _LED_SDIO	LED_DATA, *PLED_DATA;$/;"	t	typeref:struct:
-PLED_DATA	include/hal_com_led.h	/^typedef struct _LED_USB	LED_DATA, *PLED_DATA;$/;"	t	typeref:struct:
-PLED_PCIE	include/hal_com_led.h	/^} LED_PCIE, *PLED_PCIE;$/;"	t	typeref:struct:_LED_PCIE
-PLED_SDIO	include/hal_com_led.h	/^} LED_SDIO, *PLED_SDIO;$/;"	t	typeref:struct:_LED_SDIO
-PLED_STRATEGY	include/hal_com_led.h	/^typedef enum _LED_STRATEGY_PCIE	LED_STRATEGY, *PLED_STRATEGY;$/;"	t	typeref:enum:
-PLED_STRATEGY	include/hal_com_led.h	/^typedef enum _LED_STRATEGY_SDIO	LED_STRATEGY, *PLED_STRATEGY;$/;"	t	typeref:enum:
-PLED_STRATEGY	include/hal_com_led.h	/^typedef enum _LED_STRATEGY_USB	LED_STRATEGY, *PLED_STRATEGY;$/;"	t	typeref:enum:
-PLED_STRATEGY_PCIE	include/hal_com_led.h	/^} LED_STRATEGY_PCIE, *PLED_STRATEGY_PCIE;$/;"	t	typeref:enum:_LED_STRATEGY_PCIE
-PLED_STRATEGY_SDIO	include/hal_com_led.h	/^} LED_STRATEGY_SDIO, *PLED_STRATEGY_SDIO;$/;"	t	typeref:enum:_LED_STRATEGY_SDIO
-PLED_STRATEGY_USB	include/hal_com_led.h	/^} LED_STRATEGY_USB, *PLED_STRATEGY_USB;$/;"	t	typeref:enum:_LED_STRATEGY_USB
-PLED_USB	include/hal_com_led.h	/^} LED_USB, *PLED_USB;$/;"	t	typeref:struct:_LED_USB
-PLL_RESET	hal/phydm/halphyrf_ce.h	/^	PLL_RESET,$/;"	e	enum:_SPUR_CAL_METHOD
-PLL_RESET	hal/phydm/halphyrf_win.h	/^	PLL_RESET,$/;"	e	enum:_SPUR_CAL_METHOD
-PLOOPBACKDATA	include/drv_types.h	/^} LOOPBACKDATA, *PLOOPBACKDATA;$/;"	t	typeref:struct:loopbackdata
-PMAC_Get_Pkt_Param	core/rtw_mp.c	/^void PMAC_Get_Pkt_Param($/;"	f
-PMAC_Nsym_generator	core/rtw_mp.c	/^void PMAC_Nsym_generator($/;"	f
-PMKID	include/rtw_ioctl_set.h	/^	NDIS_802_11_PMKID_VALUE  PMKID;$/;"	m	struct:_BSSIDInfo
-PMKID	include/rtw_security.h	/^	u8						PMKID[16];$/;"	m	struct:_RT_PMKID_LIST
-PMKIDIndex	include/rtw_security.h	/^	u8				PMKIDIndex;$/;"	m	struct:security_priv
-PMKIDList	include/rtw_security.h	/^	RT_PMKID_LIST		PMKIDList[NUM_PMKID_CACHE];	\/* Renamed from PreAuthKey[NUM_PRE_AUTH_KEY]. Annie, 2006-10-13. *\/$/;"	m	struct:security_priv
-PMKID_CANDIDATE	include/wlan_bssdef.h	/^} PMKID_CANDIDATE, *PPMKID_CANDIDATE;$/;"	t	typeref:struct:_PMKID_CANDIDATE
-PMKID_LEN	include/ieee80211_ext.h	48;"	d
-PMPT_BANDWIDTH	include/rtw_mp.h	/^} MPT_BANDWIDTHE, *PMPT_BANDWIDTH;$/;"	t	typeref:enum:_MPT_BANDWIDTH
-PMPT_CONTEXT	include/rtw_mp.h	/^} MPT_CONTEXT, *PMPT_CONTEXT;$/;"	t	typeref:struct:_MPT_CONTEXT
-PMPT_RATE_E	include/rtw_mp.h	/^} MPT_RATE_E, *PMPT_RATE_E;$/;"	t	typeref:enum:_MPT_RATE_INDEX
-PMP_BT_MODE	include/rtw_bt_mp.h	/^} MP_BT_MODE, *PMP_BT_MODE;$/;"	t	typeref:enum:_MP_BT_MODE
-PMP_BT_PAYLOAD_TYPE	include/rtw_bt_mp.h	/^} MP_BT_PAYLOAD_TYPE, *PMP_BT_PAYLOAD_TYPE;$/;"	t	typeref:enum:_MP_BT_PAYLOAD_TYPE
-PMP_BT_PKT_TYPE	include/rtw_bt_mp.h	/^} MP_BT_PKT_TYPE, *PMP_BT_PKT_TYPE;$/;"	t	typeref:enum:_MP_BT_PKT_TYPE
-PMP_BT_TEST_CTRL	include/rtw_bt_mp.h	/^} MP_BT_TEST_CTRL, *PMP_BT_TEST_CTRL;$/;"	t	typeref:enum:_MP_BT_TEST_CTRL
-PMP_REG_ENTRY	include/drv_types_ce.h	/^} MP_REG_ENTRY, *PMP_REG_ENTRY;$/;"	t	typeref:struct:_MP_REG_ENTRY
-PMP_REG_ENTRY	include/drv_types_xp.h	/^} MP_REG_ENTRY, *PMP_REG_ENTRY;$/;"	t	typeref:struct:_MP_REG_ENTRY
-PMP_XMIT_PARM	include/rtw_mp_ioctl.h	/^} MP_XMIT_PARM, *PMP_XMIT_PARM;$/;"	t	typeref:struct:_mp_xmit_parm_
-PM_Card_Disable	include/rtw_pwrctrl.h	/^	PM_Card_Disable		,$/;"	e	enum:Power_Mgnt
-PM_Radio_Off	include/rtw_pwrctrl.h	/^	PM_Radio_Off			,$/;"	e	enum:Power_Mgnt
-PMacPktInfo	include/rtw_mp.h	/^	RT_PMAC_PKT_INFO	PMacPktInfo;$/;"	m	struct:_MPT_CONTEXT
-PMacTxInfo	include/rtw_mp.h	/^	RT_PMAC_TX_INFO	PMacTxInfo;$/;"	m	struct:_MPT_CONTEXT
-PN	include/rtw_wapi.h	/^	u8      PN[16];$/;"	m	struct:_WLAN_HEADER_WAPI_EXTENSION
-PNDIS_802_11_AI_REQFI	include/wlan_bssdef.h	/^} NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;$/;"	t	typeref:struct:_NDIS_802_11_AI_REQFI
-PNDIS_802_11_AI_RESFI	include/wlan_bssdef.h	/^} NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;$/;"	t	typeref:struct:_NDIS_802_11_AI_RESFI
-PNDIS_802_11_ASSOCIATION_INFORMATION	include/wlan_bssdef.h	/^} NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;$/;"	t	typeref:struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-PNDIS_802_11_AUTHENTICATION_ENCRYPTION	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_ENCRYPTION, *PNDIS_802_11_AUTHENTICATION_ENCRYPTION;$/;"	t	typeref:struct:_NDIS_802_11_AUTHENTICATION_ENCRYPTION
-PNDIS_802_11_AUTHENTICATION_EVENT	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_EVENT, *PNDIS_802_11_AUTHENTICATION_EVENT;$/;"	t	typeref:struct:_NDIS_802_11_AUTHENTICATION_EVENT
-PNDIS_802_11_AUTHENTICATION_MODE	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_MODE, *PNDIS_802_11_AUTHENTICATION_MODE;$/;"	t	typeref:enum:_NDIS_802_11_AUTHENTICATION_MODE
-PNDIS_802_11_AUTHENTICATION_REQUEST	include/wlan_bssdef.h	/^} NDIS_802_11_AUTHENTICATION_REQUEST, *PNDIS_802_11_AUTHENTICATION_REQUEST;$/;"	t	typeref:struct:_NDIS_802_11_AUTHENTICATION_REQUEST
-PNDIS_802_11_CAPABILITY	include/wlan_bssdef.h	/^} NDIS_802_11_CAPABILITY, *PNDIS_802_11_CAPABILITY;$/;"	t	typeref:struct:_NDIS_802_11_CAPABILITY
-PNDIS_802_11_CONFIGURATION	include/wlan_bssdef.h	/^} NDIS_802_11_CONFIGURATION, *PNDIS_802_11_CONFIGURATION;$/;"	t	typeref:struct:_NDIS_802_11_CONFIGURATION
-PNDIS_802_11_CONFIGURATION_FH	include/wlan_bssdef.h	/^} NDIS_802_11_CONFIGURATION_FH, *PNDIS_802_11_CONFIGURATION_FH;$/;"	t	typeref:struct:_NDIS_802_11_CONFIGURATION_FH
-PNDIS_802_11_ENCRYPTION_STATUS	include/wlan_bssdef.h	/^NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;$/;"	t	typeref:enum:_NDIS_802_11_WEP_STATUS
-PNDIS_802_11_FIXED_IEs	include/wlan_bssdef.h	/^} NDIS_802_11_FIXED_IEs, *PNDIS_802_11_FIXED_IEs;$/;"	t	typeref:struct:_NDIS_802_11_FIXED_IEs
-PNDIS_802_11_KEY	include/wlan_bssdef.h	/^} NDIS_802_11_KEY, *PNDIS_802_11_KEY;$/;"	t	typeref:struct:_NDIS_802_11_KEY
-PNDIS_802_11_NETWORK_INFRASTRUCTURE	include/wlan_bssdef.h	/^} NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;$/;"	t	typeref:enum:_NDIS_802_11_NETWORK_INFRASTRUCTURE
-PNDIS_802_11_NETWORK_TYPE	include/wlan_bssdef.h	/^} NDIS_802_11_NETWORK_TYPE, *PNDIS_802_11_NETWORK_TYPE;$/;"	t	typeref:enum:_NDIS_802_11_NETWORK_TYPE
-PNDIS_802_11_PMKID	include/rtw_ioctl_set.h	/^} NDIS_802_11_PMKID, *PNDIS_802_11_PMKID;$/;"	t	typeref:struct:_NDIS_802_11_PMKID
-PNDIS_802_11_PMKID_CANDIDATE_LIST	include/wlan_bssdef.h	/^} NDIS_802_11_PMKID_CANDIDATE_LIST, *PNDIS_802_11_PMKID_CANDIDATE_LIST;$/;"	t	typeref:struct:_NDIS_802_11_PMKID_CANDIDATE_LIST
-PNDIS_802_11_RELOAD_DEFAULTS	include/wlan_bssdef.h	/^} NDIS_802_11_RELOAD_DEFAULTS, *PNDIS_802_11_RELOAD_DEFAULTS;$/;"	t	typeref:enum:_NDIS_802_11_RELOAD_DEFAULTS
-PNDIS_802_11_REMOVE_KEY	include/wlan_bssdef.h	/^} NDIS_802_11_REMOVE_KEY, *PNDIS_802_11_REMOVE_KEY;$/;"	t	typeref:struct:_NDIS_802_11_REMOVE_KEY
-PNDIS_802_11_SSID	include/wlan_bssdef.h	/^} NDIS_802_11_SSID, *PNDIS_802_11_SSID;$/;"	t	typeref:struct:_NDIS_802_11_SSID
-PNDIS_802_11_STATUS_INDICATION	include/wlan_bssdef.h	/^} NDIS_802_11_STATUS_INDICATION, *PNDIS_802_11_STATUS_INDICATION;$/;"	t	typeref:struct:_NDIS_802_11_STATUS_INDICATION
-PNDIS_802_11_STATUS_TYPE	include/wlan_bssdef.h	/^} NDIS_802_11_STATUS_TYPE, *PNDIS_802_11_STATUS_TYPE;$/;"	t	typeref:enum:_NDIS_802_11_STATUS_TYPE
-PNDIS_802_11_TEST	include/wlan_bssdef.h	/^} NDIS_802_11_TEST, *PNDIS_802_11_TEST;$/;"	t	typeref:struct:_NDIS_802_11_TEST
-PNDIS_802_11_VARIABLE_IEs	include/wlan_bssdef.h	/^} NDIS_802_11_VARIABLE_IEs, *PNDIS_802_11_VARIABLE_IEs;$/;"	t	typeref:struct:_NDIS_802_11_VARIABLE_IEs
-PNDIS_802_11_WEP	include/wlan_bssdef.h	/^} NDIS_802_11_WEP, *PNDIS_802_11_WEP;$/;"	t	typeref:struct:_NDIS_802_11_WEP
-PNDIS_802_11_WEP_STATUS	include/wlan_bssdef.h	/^} NDIS_802_11_WEP_STATUS, *PNDIS_802_11_WEP_STATUS,$/;"	t	typeref:enum:_NDIS_802_11_WEP_STATUS
-PNO_TLV_FREQ_EXPO_MAX	os_dep/linux/rtw_android.c	112;"	d	file:
-PNO_TLV_FREQ_REPEAT	os_dep/linux/rtw_android.c	111;"	d	file:
-PNO_TLV_PREFIX	os_dep/linux/rtw_android.c	105;"	d	file:
-PNO_TLV_RESERVED	os_dep/linux/rtw_android.c	108;"	d	file:
-PNO_TLV_SUBVERSION	os_dep/linux/rtw_android.c	107;"	d	file:
-PNO_TLV_TYPE_SSID_IE	os_dep/linux/rtw_android.c	109;"	d	file:
-PNO_TLV_TYPE_TIME	os_dep/linux/rtw_android.c	110;"	d	file:
-PNO_TLV_VERSION	os_dep/linux/rtw_android.c	106;"	d	file:
-POCTET_STRING	include/drv_types_ce.h	/^} OCTET_STRING, *POCTET_STRING;$/;"	t	typeref:struct:_OCTET_STRING
-POCTET_STRING	include/drv_types_xp.h	/^} OCTET_STRING, *POCTET_STRING;$/;"	t	typeref:struct:_OCTET_STRING
-PODM_PACKET_INFO_T	hal/phydm/phydm.h	/^} ODM_PACKET_INFO_T, *PODM_PACKET_INFO_T;$/;"	t	typeref:struct:_ODM_Per_Pkt_Info_
-PODM_PHY_INFO_Append_T	hal/phydm/phydm.h	/^}ODM_PHY_INFO_Append_T,*PODM_PHY_INFO_Append_T;$/;"	t	typeref:struct:_ODM_Phy_Status_Info_Append_
-PODM_PHY_INFO_T	hal/phydm/phydm.h	/^} ODM_PHY_INFO_T, *PODM_PHY_INFO_T;$/;"	t	typeref:struct:_ODM_Phy_Status_Info_
-PODM_PHY_INFO_T	hal/phydm/phydm.h	/^} __WLAN_ATTRIB_PACK__ ODM_PHY_INFO_T, *PODM_PHY_INFO_T;$/;"	t	typeref:struct:_ODM_Phy_Status_Info_
-PODM_RATE_ADAPTIVE	hal/phydm/phydm_rainfo.h	/^} ODM_RATE_ADAPTIVE, *PODM_RATE_ADAPTIVE;$/;"	t	typeref:struct:_ODM_RATE_ADAPTIVE
-PODM_RA_INFO_T	hal/phydm/phydm_rainfo.h	/^} ODM_RA_INFO_T, *PODM_RA_INFO_T;$/;"	t	typeref:struct:_ODM_RA_Info_
-PODM_RF_CAL_T	hal/phydm/phydm_powertracking_ap.h	/^}ODM_RF_CAL_T,*PODM_RF_CAL_T;$/;"	t	typeref:struct:ODM_RF_Calibration_Structure
-PODM_RF_CAL_T	hal/phydm/phydm_powertracking_ce.h	/^}ODM_RF_CAL_T,*PODM_RF_CAL_T;$/;"	t	typeref:struct:ODM_RF_Calibration_Structure
-PODM_RF_CAL_T	hal/phydm/phydm_powertracking_win.h	/^}ODM_RF_CAL_T,*PODM_RF_CAL_T;$/;"	t	typeref:struct:ODM_RF_Calibration_Structure
-PODM_RF_RADIO_PATH_E	hal/phydm/phydm_pre_define.h	/^} ODM_RF_RADIO_PATH_E, *PODM_RF_RADIO_PATH_E;$/;"	t	typeref:enum:_ODM_RF_RADIO_PATH
-PODM_STA_INFO_T	hal/phydm/phydm.h	/^} ODM_STA_INFO_T, *PODM_STA_INFO_T;$/;"	t	typeref:struct:_ODM_STA_INFO
-POLLING_LLT_THRESHOLD	include/hal_com_reg.h	1805;"	d
-POLLING_READY_TIMEOUT_COUNT	include/hal_com_reg.h	1807;"	d
-POLLING_READY_TIMEOUT_COUNT	include/hal_com_reg.h	1809;"	d
-PORT_ARG	include/ieee80211.h	1476;"	d
-PORT_FMT	include/ieee80211.h	1475;"	d
-POWER_LOW	include/rtw_mp.h	/^	POWER_LOW = 0,$/;"	e	enum:_POWER_MODE_
-POWER_MODE	include/rtw_mp.h	/^} POWER_MODE;$/;"	t	typeref:enum:_POWER_MODE_
-POWER_NORMAL	include/rtw_mp.h	/^	POWER_NORMAL$/;"	e	enum:_POWER_MODE_
-POWER_SAVING_CTRL_WK_CID	include/rtw_cmd.h	/^	POWER_SAVING_CTRL_WK_CID,\/* IPS,AUTOSuspend *\/$/;"	e	enum:rtw_drvextra_cmd_id
-POWER_TRAINING_ACTIVE	include/hal_ic_cfg.h	40;"	d
-POWER_TRAINING_ACTIVE	include/hal_ic_cfg.h	48;"	d
-POWER_TRAINING_ACTIVE	include/hal_ic_cfg.h	52;"	d
-POWRTRACKING_VERSION	hal/phydm/phydm_powertracking_ap.h	24;"	d
-POWRTRACKING_VERSION	hal/phydm/phydm_powertracking_ce.h	24;"	d
-POWRTRACKING_VERSION	hal/phydm/phydm_powertracking_win.h	24;"	d
-PPCI_COMMON_CONFIG	include/drv_types_pci.h	/^} PCI_COMMON_CONFIG , *PPCI_COMMON_CONFIG;$/;"	t	typeref:struct:_PCI_COMMON_CONFIG
-PPGPKT_STRUCT	include/rtw_efuse.h	/^} PGPKT_STRUCT, *PPGPKT_STRUCT;$/;"	t	typeref:struct:PG_PKT_STRUCT_A
-PPG_8723D_S0	include/hal_pg.h	536;"	d
-PPG_8723D_S1	include/hal_pg.h	535;"	d
-PPG_BB_GAIN_2G_TXA_OFFSET_8188F	include/hal_pg.h	302;"	d
-PPG_BB_GAIN_2G_TXA_OFFSET_8192E	include/hal_pg.h	74;"	d
-PPG_BB_GAIN_2G_TXA_OFFSET_8703B	include/hal_pg.h	391;"	d
-PPG_BB_GAIN_2G_TXA_OFFSET_8723D	include/hal_pg.h	538;"	d
-PPG_BB_GAIN_2G_TXA_OFFSET_8821A	include/hal_pg.h	228;"	d
-PPG_BB_GAIN_2G_TXA_OFFSET_8821C	include/hal_pg.h	485;"	d
-PPG_BB_GAIN_2G_TXA_OFFSET_8822B	include/hal_pg.h	435;"	d
-PPG_BB_GAIN_2G_TXBA_OFFSET_8814A	include/hal_pg.h	184;"	d
-PPG_BB_GAIN_2G_TXB_OFFSET_MASK	include/hal_pg.h	25;"	d
-PPG_BB_GAIN_2G_TX_OFFSET_8723D	include/hal_pg.h	539;"	d
-PPG_BB_GAIN_2G_TX_OFFSET_MASK	include/hal_pg.h	24;"	d
-PPG_BB_GAIN_5GHB_TXA_OFFSET_8821A	include/hal_pg.h	234;"	d
-PPG_BB_GAIN_5GLB1_TXA_OFFSET_8821A	include/hal_pg.h	230;"	d
-PPG_BB_GAIN_5GLB2_TXA_OFFSET_8821A	include/hal_pg.h	231;"	d
-PPG_BB_GAIN_5GMB1_TXA_OFFSET_8821A	include/hal_pg.h	232;"	d
-PPG_BB_GAIN_5GMB2_TXA_OFFSET_8821A	include/hal_pg.h	233;"	d
-PPG_BB_GAIN_5G_TX_OFFSET_MASK	include/hal_pg.h	27;"	d
-PPG_THERMAL_OFFSET_8188F	include/hal_pg.h	303;"	d
-PPG_THERMAL_OFFSET_8192E	include/hal_pg.h	75;"	d
-PPG_THERMAL_OFFSET_8703B	include/hal_pg.h	392;"	d
-PPG_THERMAL_OFFSET_8723D	include/hal_pg.h	540;"	d
-PPG_THERMAL_OFFSET_8814A	include/hal_pg.h	186;"	d
-PPG_THERMAL_OFFSET_8821A	include/hal_pg.h	229;"	d
-PPG_THERMAL_OFFSET_8821C	include/hal_pg.h	486;"	d
-PPG_THERMAL_OFFSET_8822B	include/hal_pg.h	436;"	d
-PPG_THERMAL_OFFSET_MASK	include/hal_pg.h	28;"	d
-PPHY_STATUS_RPT_8192CD_T	hal/phydm/phydm_hwconfig.h	/^} __WLAN_ATTRIB_PACK__ PHY_STATUS_RPT_8192CD_T, *PPHY_STATUS_RPT_8192CD_T;$/;"	t	typeref:struct:_Phy_Status_Rpt_8192cd
-PPHY_STATUS_RPT_8812_T	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_8812_T, *PPHY_STATUS_RPT_8812_T;$/;"	t	typeref:struct:_Phy_Status_Rpt_8812
-PPHY_STATUS_RPT_JAGUAR2_TYPE0	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_JAGUAR2_TYPE0, *PPHY_STATUS_RPT_JAGUAR2_TYPE0;$/;"	t	typeref:struct:_Phy_Status_Rpt_Jaguar2_Type0
-PPHY_STATUS_RPT_JAGUAR2_TYPE1	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_JAGUAR2_TYPE1, *PPHY_STATUS_RPT_JAGUAR2_TYPE1;$/;"	t	typeref:struct:_Phy_Status_Rpt_Jaguar2_Type1
-PPHY_STATUS_RPT_JAGUAR2_TYPE2	hal/phydm/phydm_hwconfig.h	/^} PHY_STATUS_RPT_JAGUAR2_TYPE2, *PPHY_STATUS_RPT_JAGUAR2_TYPE2;$/;"	t	typeref:struct:_Phy_Status_Rpt_Jaguar2_Type2
-PPHY_SUSB	include/hal_com_reg.h	1300;"	d
-PPMKID_CANDIDATE	include/wlan_bssdef.h	/^} PMKID_CANDIDATE, *PPMKID_CANDIDATE;$/;"	t	typeref:struct:_PMKID_CANDIDATE
-PPROTECTION_MODE	include/rtw_rf.h	/^} PROTECTION_MODE, *PPROTECTION_MODE;$/;"	t	typeref:enum:_PROTECTION_MODE
-PRATEID_IDX	include/ieee80211.h	/^} RATEID_IDX, *PRATEID_IDX;$/;"	t	typeref:enum:_RATEID_IDX_
-PRATR_TABLE_MODE	include/ieee80211.h	/^} RATR_TABLE_MODE, *PRATR_TABLE_MODE;$/;"	t	typeref:enum:_RATR_TABLE_MODE
-PREAMBLE_AUTO	include/rtw_rf.h	/^	PREAMBLE_AUTO	= 2,$/;"	e	enum:_REG_PREAMBLE_MODE
-PREAMBLE_LONG	include/rtw_rf.h	/^	PREAMBLE_LONG	= 1,$/;"	e	enum:_REG_PREAMBLE_MODE
-PREAMBLE_SHORT	include/rtw_rf.h	/^	PREAMBLE_SHORT	= 3,$/;"	e	enum:_REG_PREAMBLE_MODE
-PRF_PATH	include/rtw_rf.h	/^} RF_PATH, *PRF_PATH;$/;"	t	typeref:enum:_RF_PATH
-PRF_TYPE_E	include/hal_phy.h	/^} RF_TYPE_E, *PRF_TYPE_E;$/;"	t	typeref:enum:_RF_TYPE
-PRIMARY_ADAPTER	include/drv_types.h	/^	PRIMARY_ADAPTER,$/;"	e	enum:_ADAPTER_TYPE
-PROTECTION_MODE	include/rtw_rf.h	/^} PROTECTION_MODE, *PPROTECTION_MODE;$/;"	t	typeref:enum:_PROTECTION_MODE
-PROTECTION_MODE_AUTO	include/rtw_rf.h	/^	PROTECTION_MODE_AUTO = 0,$/;"	e	enum:_PROTECTION_MODE
-PROTECTION_MODE_FORCE_DISABLE	include/rtw_rf.h	/^	PROTECTION_MODE_FORCE_DISABLE = 2,$/;"	e	enum:_PROTECTION_MODE
-PROTECTION_MODE_FORCE_ENABLE	include/rtw_rf.h	/^	PROTECTION_MODE_FORCE_ENABLE = 1,$/;"	e	enum:_PROTECTION_MODE
-PROTOCOL_EN	include/hal_com_reg.h	1319;"	d
-PROTOCOL_OFFSET	core/rtw_wlan_util.c	27;"	d	file:
-PROTO_CAP_11AC	include/hal_com.h	326;"	d
-PROTO_CAP_11B	include/hal_com.h	323;"	d
-PROTO_CAP_11G	include/hal_com.h	324;"	d
-PROTO_CAP_11N	include/hal_com.h	325;"	d
-PROTO_CAP_8188F	include/rtl8188f_spec.h	301;"	d
-PROTO_CAP_8192E	include/rtl8192e_spec.h	327;"	d
-PROTO_CAP_8703B	include/rtl8703b_spec.h	478;"	d
-PROTO_CAP_8723B	include/rtl8723b_spec.h	294;"	d
-PROTO_CAP_8723D	include/rtl8723d_spec.h	455;"	d
-PROTO_CAP_8812A	include/rtl8812a_spec.h	270;"	d
-PROTO_CAP_8814A	include/rtl8814a_spec.h	649;"	d
-PROTO_CAP_8821A	include/rtl8821a_spec.h	106;"	d
-PROTO_CAP_88E	include/rtl8188e_spec.h	156;"	d
-PROTO_CAP_BIT_NUM	include/hal_com.h	327;"	d
-PRSSI_STA	include/sta_info.h	/^} RSSI_STA, *PRSSI_STA;$/;"	t	typeref:struct:_RSSI_STA
-PRSVDPAGE_LOC	include/hal_com_h2c.h	/^} RSVDPAGE_LOC, *PRSVDPAGE_LOC;$/;"	t	typeref:struct:_RSVDPAGE_LOC
-PRTW_IF_OPS	include/drv_types.h	/^} RTW_IF_OPS, *PRTW_IF_OPS;$/;"	t	typeref:struct:rtw_if_operations
-PRT_8188E_FIRMWARE_HDR	include/rtl8188e_hal.h	/^} RT_8188E_FIRMWARE_HDR, *PRT_8188E_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8188E_FIRMWARE_HDR
-PRT_8188F_FIRMWARE_HDR	include/rtl8188f_hal.h	/^} RT_8188F_FIRMWARE_HDR, *PRT_8188F_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8188F_FIRMWARE_HDR
-PRT_8703B_FIRMWARE_HDR	include/rtl8703b_hal.h	/^} RT_8703B_FIRMWARE_HDR, *PRT_8703B_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8703B_FIRMWARE_HDR
-PRT_8723B_FIRMWARE_HDR	include/rtl8723b_hal.h	/^} RT_8723B_FIRMWARE_HDR, *PRT_8723B_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8723B_FIRMWARE_HDR
-PRT_8723D_FIRMWARE_HDR	include/rtl8723d_hal.h	/^} RT_8723D_FIRMWARE_HDR, *PRT_8723D_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8723D_FIRMWARE_HDR
-PRT_ADCSMP	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP, *PRT_ADCSMP;$/;"	t	typeref:struct:_RT_ADCSMP
-PRT_ADCSMP_STATE	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_STATE, *PRT_ADCSMP_STATE;$/;"	t	typeref:enum:_RT_ADCSMP_STATE
-PRT_ADCSMP_STRING	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_STRING, *PRT_ADCSMP_STRING;$/;"	t	typeref:struct:_RT_ADCSMP_STRING
-PRT_ADCSMP_TRIG_SEL	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_TRIG_SEL, *PRT_ADCSMP_TRIG_SEL;$/;"	t	typeref:enum:_RT_ADCSMP_TRIG_SEL
-PRT_ADCSMP_TRIG_SIG_SEL	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_TRIG_SIG_SEL, *PRT_ADCSMP_TRIG_SIG_SEL;$/;"	t	typeref:enum:_RT_ADCSMP_TRIG_SIG_SEL
-PRT_AMPDU_BRUST_MODE	include/hal_data.h	/^} RT_AMPDU_BRUST, *PRT_AMPDU_BRUST_MODE;$/;"	t	typeref:enum:_RT_AMPDU_BRUST_MODE
-PRT_BEAMFORMEE_ENTRY	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMEE_ENTRY, *PRT_BEAMFORMEE_ENTRY;$/;"	t	typeref:struct:_RT_BEAMFORMEE_ENTRY
-PRT_BEAMFORMER_ENTRY	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMER_ENTRY, *PRT_BEAMFORMER_ENTRY;$/;"	t	typeref:struct:_RT_BEAMFORMER_ENTRY
-PRT_BEAMFORMING_INFO	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMING_INFO, *PRT_BEAMFORMING_INFO;$/;"	t	typeref:struct:_RT_BEAMFORMING_INFO
-PRT_BEAMFORMING_OID_INFO	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMING_OID_INFO, *PRT_BEAMFORMING_OID_INFO;$/;"	t	typeref:struct:_RT_BEAMFORMING_OID_INFO
-PRT_BEAMFORM_STAINFO	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORM_STAINFO, *PRT_BEAMFORM_STAINFO;$/;"	t	typeref:struct:_RT_BEAMFORM_STAINFO
-PRT_CHANNEL_DOMAIN	include/rtw_mlme_ext.h	/^} RT_CHANNEL_DOMAIN, *PRT_CHANNEL_DOMAIN;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN
-PRT_CHANNEL_DOMAIN_2G	include/rtw_mlme_ext.h	/^} RT_CHANNEL_DOMAIN_2G, *PRT_CHANNEL_DOMAIN_2G;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN_2G
-PRT_CHANNEL_DOMAIN_5G	include/rtw_mlme_ext.h	/^} RT_CHANNEL_DOMAIN_5G, *PRT_CHANNEL_DOMAIN_5G;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN_5G
-PRT_CHANNEL_DOMAIN_NEW	hal/phydm/rtchnlplan.h	/^}RT_CHANNEL_DOMAIN_NEW, *PRT_CHANNEL_DOMAIN_NEW;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN_NEW
-PRT_CHANNEL_INFO	include/rtw_mlme_ext.h	/^} RT_CHANNEL_INFO, *PRT_CHANNEL_INFO;$/;"	t	typeref:struct:_RT_CHANNEL_INFO
-PRT_CHANNEL_PLAN	include/rtw_mlme_ext.h	/^} RT_CHANNEL_PLAN, *PRT_CHANNEL_PLAN;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN
-PRT_CHANNEL_PLAN_MAP	include/rtw_mlme_ext.h	/^} RT_CHANNEL_PLAN_MAP, *PRT_CHANNEL_PLAN_MAP;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_MAP
-PRT_CHANNEL_PLAN_MAXPWR	hal/phydm/rtchnlplan.h	/^}RT_CHANNEL_PLAN_MAXPWR, *PRT_CHANNEL_PLAN_MAXPWR;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_MAXPWR
-PRT_CHANNEL_PLAN_NEW	hal/phydm/rtchnlplan.h	/^}RT_CHANNEL_PLAN_NEW, *PRT_CHANNEL_PLAN_NEW;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_NEW
-PRT_CHNLPLAN_SREQ	hal/phydm/rtchnlplan.h	/^}RT_CHNLPLAN_SREQ, *PRT_CHNLPLAN_SREQ;$/;"	t	typeref:enum:_RT_CHNLPLAN_SREQ
-PRT_CHNL_CTRY_TBL	hal/phydm/rtchnlplan.h	/^}RT_CHNL_CTRY_TBL, *PRT_CHNL_CTRY_TBL;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-PRT_CHNL_PLAN_LIMIT	hal/phydm/rtchnlplan.h	/^}RT_CHNL_PLAN_LIMIT, *PRT_CHNL_PLAN_LIMIT;$/;"	t	typeref:struct:_RT_CHNL_PLAN_LIMIT
-PRT_CHNL_PWR_LIMIT	hal/phydm/rtchnlplan.h	/^}RT_CHNL_PWR_LIMIT, *PRT_CHNL_PWR_LIMIT;$/;"	t	typeref:struct:_RT_CHNL_PLAN_PWR_LIMIT
-PRT_COUNTRY_NAME	hal/phydm/rtchnlplan.h	/^}RT_COUNTRY_NAME, *PRT_COUNTRY_NAME;$/;"	t	typeref:enum:_RT_COUNTRY_DEFINE_NUM
-PRT_CUSTOMER_ID	include/rtw_eeprom.h	/^} RT_CUSTOMER_ID, *PRT_CUSTOMER_ID;$/;"	t	typeref:enum:_RT_CUSTOMER_ID
-PRT_EEPROM_TYPE	include/hal_intf.h	/^} RT_EEPROM_TYPE, *PRT_EEPROM_TYPE;$/;"	t	typeref:enum:_RT_EEPROM_TYPE
-PRT_FIRMWARE_8188E	include/rtl8188e_hal.h	/^} RT_FIRMWARE_8188E, *PRT_FIRMWARE_8188E;$/;"	t	typeref:struct:_RT_FIRMWARE_8188E
-PRT_FIRMWARE_8188F	include/rtl8188f_hal.h	/^} RT_FIRMWARE_8188F, *PRT_FIRMWARE_8188F;$/;"	t	typeref:struct:_RT_FIRMWARE
-PRT_FIRMWARE_8192E	include/rtl8192e_hal.h	/^} RT_FIRMWARE_8192E, *PRT_FIRMWARE_8192E;$/;"	t	typeref:struct:_RT_FIRMWARE_8192E
-PRT_FIRMWARE_8703B	include/rtl8703b_hal.h	/^} RT_FIRMWARE_8703B, *PRT_FIRMWARE_8703B;$/;"	t	typeref:struct:_RT_FIRMWARE
-PRT_FIRMWARE_8723B	include/rtl8723b_hal.h	/^} RT_FIRMWARE_8723B, *PRT_FIRMWARE_8723B;$/;"	t	typeref:struct:_RT_FIRMWARE
-PRT_FIRMWARE_8723D	include/rtl8723d_hal.h	/^} RT_FIRMWARE_8723D, *PRT_FIRMWARE_8723D;$/;"	t	typeref:struct:_RT_FIRMWARE
-PRT_FIRMWARE_8812	include/rtl8812a_hal.h	/^} RT_FIRMWARE_8812, *PRT_FIRMWARE_8812;$/;"	t	typeref:struct:_RT_FIRMWARE_8812
-PRT_FIRMWARE_8814	include/rtl8814a_hal.h	/^} RT_FIRMWARE_8814, *PRT_FIRMWARE_8814;$/;"	t	typeref:struct:_RT_FIRMWARE_8814
-PRT_HT_INF0_CAPBILITY	include/rtw_ht.h	/^} RT_HT_INF0_CAPBILITY, *PRT_HT_INF0_CAPBILITY;$/;"	t	typeref:enum:_RT_HT_INF0_CAP
-PRT_HT_INF1_CAPBILITY	include/rtw_ht.h	/^} RT_HT_INF1_CAPBILITY, *PRT_HT_INF1_CAPBILITY;$/;"	t	typeref:enum:_RT_HT_INF1_CAP
-PRT_ISR_CONTENT	include/drv_types_pci.h	/^} RT_ISR_CONTENT, *PRT_ISR_CONTENT;$/;"	t	typeref:struct:_RT_ISR_CONTENT
-PRT_LINK_DETECT_T	include/rtw_mlme.h	/^} RT_LINK_DETECT_T, *PRT_LINK_DETECT_T;$/;"	t	typeref:struct:_RT_LINK_DETECT_T
-PRT_MP_FIRMWARE	include/rtw_mp.h	/^} RT_MP_FIRMWARE, *PRT_MP_FIRMWARE;$/;"	t	typeref:struct:_MP_FIRMWARE
-PRT_MULTI_FUNC	include/hal_data.h	/^} RT_MULTI_FUNC, *PRT_MULTI_FUNC;$/;"	t	typeref:enum:_RT_MULTI_FUNC
-PRT_NDPA_STA_INFO	hal/phydm/phydm_beamforming.h	/^} RT_NDPA_STA_INFO, *PRT_NDPA_STA_INFO;$/;"	t	typeref:struct:_RT_NDPA_STA_INFO
-PRT_PCI_CAPABILITIES_HEADER	include/drv_types_pci.h	/^} RT_PCI_CAPABILITIES_HEADER, *PRT_PCI_CAPABILITIES_HEADER;$/;"	t	typeref:struct:_RT_PCI_CAPABILITIES_HEADER
-PRT_PMAC_PKT_INFO	include/rtw_mp.h	/^} RT_PMAC_PKT_INFO, *PRT_PMAC_PKT_INFO;$/;"	t	typeref:struct:_RT_PMAC_PKT_INFO
-PRT_PMAC_TX_INFO	include/rtw_mp.h	/^} RT_PMAC_TX_INFO, *PRT_PMAC_TX_INFO;$/;"	t	typeref:struct:_RT_PMAC_TX_INFO
-PRT_PMKID_LIST	include/rtw_security.h	/^} RT_PMKID_LIST, *PRT_PMKID_LIST;$/;"	t	typeref:struct:_RT_PMKID_LIST
-PRT_POLARITY_CTL	include/hal_data.h	/^} RT_POLARITY_CTL, *PRT_POLARITY_CTL;$/;"	t	typeref:enum:_RT_POLARITY_CTL
-PRT_REGULATION_2G	hal/phydm/rtchnlplan.h	/^}RT_REGULATION_2G, *PRT_REGULATION_2G;$/;"	t	typeref:enum:_RT_REGULATION_DOMAIN_2G
-PRT_REGULATION_5G	hal/phydm/rtchnlplan.h	/^}RT_REGULATION_5G, *PRT_REGULATION_5G;$/;"	t	typeref:enum:_RT_REGULATION_DOMAIN_5G
-PRT_REGULATION_CMN	hal/phydm/rtchnlplan.h	/^}RT_REGULATION_CMN, *PRT_REGULATION_CMN;$/;"	t	typeref:enum:_RT_REGULATION_COMMON
-PRT_REGULATOR_MODE	include/hal_data.h	/^} RT_REGULATOR_MODE, *PRT_REGULATOR_MODE;$/;"	t	typeref:enum:_RT_REGULATOR_MODE
-PRT_SCAN_TYPE	include/rtw_mlme.h	/^} RT_SCAN_TYPE, *PRT_SCAN_TYPE;$/;"	t	typeref:enum:_RT_SCAN_TYPE
-PRT_SCAN_TYPE_NEW	hal/phydm/rtchnlplan.h	/^}RT_SCAN_TYPE_NEW, *PRT_SCAN_TYPE_NEW;$/;"	t	typeref:enum:_RT_SCAN_TYPE_NEW
-PRT_SOUNDING_INFO	hal/phydm/phydm_beamforming.h	/^} RT_SOUNDING_INFO, *PRT_SOUNDING_INFO;$/;"	t	typeref:struct:_RT_SOUNDING_INFO
-PRT_TIMER	hal/phydm/phydm_types.h	/^	typedef struct timer_list		RT_TIMER, *PRT_TIMER;$/;"	t	typeref:struct:
-PRT_WAPI_BKID	include/rtw_wapi.h	/^} RT_WAPI_BKID, *PRT_WAPI_BKID;$/;"	t	typeref:struct:_RT_WAPI_BKID
-PRT_WAPI_CAM_ENTRY	include/rtw_wapi.h	/^} RT_WAPI_CAM_ENTRY, *PRT_WAPI_CAM_ENTRY;$/;"	t	typeref:struct:_RT_WAPI_CAM_ENTRY
-PRT_WAPI_KEY	include/rtw_wapi.h	/^} RT_WAPI_KEY, *PRT_WAPI_KEY;$/;"	t	typeref:struct:_RT_WAPI_KEY
-PRT_WAPI_STA_INFO	include/rtw_wapi.h	/^} RT_WAPI_STA_INFO, *PRT_WAPI_STA_INFO;$/;"	t	typeref:struct:_RT_WAPI_STA_INFO
-PRT_WAPI_T	include/rtw_wapi.h	/^} RT_WAPI_T, *PRT_WAPI_T;$/;"	t	typeref:struct:_RT_WAPI_T
-PRT_WLAN_STA	hal/phydm/phydm.h	/^} WLAN_STA, *PRT_WLAN_STA;$/;"	t	typeref:struct:_WLAN_STA
-PRT_WORKITEM_HANDLE	hal/phydm/phydm_interface.h	/^typedef  void RT_WORKITEM_HANDLE,*PRT_WORKITEM_HANDLE;$/;"	t
-PRT_WORK_ITEM	hal/phydm/phydm_interface.h	/^typedef  void *PRT_WORK_ITEM ;$/;"	t
-PRXREPORT	include/rtl8188e_recv.h	/^} RXREPORT, *PRXREPORT;$/;"	t	typeref:struct:rxreport_8188e
-PRX_PACKET_TYPE	include/rtw_recv.h	/^} RX_PACKET_TYPE, *PRX_PACKET_TYPE;$/;"	t	typeref:enum:_RX_PACKET_TYPE
-PSBBREG_AFE0	include/rtw_pwrctrl.h	/^	PSBBREG_AFE0,$/;"	e	enum:_PS_BBRegBackup_
-PSBBREG_RF0	include/rtw_pwrctrl.h	/^	PSBBREG_RF0 = 0,$/;"	e	enum:_PS_BBRegBackup_
-PSBBREG_RF1	include/rtw_pwrctrl.h	/^	PSBBREG_RF1,$/;"	e	enum:_PS_BBRegBackup_
-PSBBREG_RF2	include/rtw_pwrctrl.h	/^	PSBBREG_RF2,$/;"	e	enum:_PS_BBRegBackup_
-PSBBREG_TOTALCNT	include/rtw_pwrctrl.h	/^	PSBBREG_TOTALCNT$/;"	e	enum:_PS_BBRegBackup_
-PSDIO_DATA	include/drv_types_sdio.h	/^} SDIO_DATA, *PSDIO_DATA;$/;"	t	typeref:struct:sdio_data
-PSETPWRMODE_PARM	include/rtl8188e_cmd.h	/^} SETPWRMODE_PARM, *PSETPWRMODE_PARM;$/;"	t	typeref:struct:_SETPWRMODE_PARM
-PSETPWRMODE_PARM	include/rtl8192e_cmd.h	/^} SETPWRMODE_PARM, *PSETPWRMODE_PARM;$/;"	t	typeref:struct:_SETPWRMODE_PARM
-PSOUNDING_MODE	hal/phydm/phydm_beamforming.h	/^}SOUNDING_MODE, *PSOUNDING_MODE;$/;"	t	typeref:enum:_SOUNDING_MODE
-PSOUNDING_MODE	include/rtw_beamforming.h	/^} SOUNDING_MODE, *PSOUNDING_MODE;$/;"	t	typeref:enum:_SOUNDING_MODE
-PSR	include/hal_com_reg.h	589;"	d
-PSTA_INFO_T	hal/phydm/phydm_types.h	/^	typedef struct stat_info		STA_INFO_T,*PSTA_INFO_T;$/;"	t	typeref:struct:
-PSTA_INFO_T	hal/phydm/phydm_types.h	120;"	d
-PSTA_INFO_T	hal/phydm/phydm_types.h	229;"	d
-PS_ACK	include/rtw_pwrctrl.h	129;"	d
-PS_ALL_ON	include/rtw_pwrctrl.h	124;"	d
-PS_BBRegBackup	include/rtw_pwrctrl.h	/^	unsigned long PS_BBRegBackup[PSBBREG_TOTALCNT];$/;"	m	struct:pwrctrl_priv
-PS_DENY_DISCONNECT	include/rtw_pwrctrl.h	/^	PS_DENY_DISCONNECT,$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_DRV_INITIAL	include/rtw_pwrctrl.h	/^	PS_DENY_DRV_INITIAL = 0,$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_DRV_REMOVE	include/rtw_pwrctrl.h	/^	PS_DENY_DRV_REMOVE = 30,$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_IOCTL	include/rtw_pwrctrl.h	/^	PS_DENY_IOCTL,$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_JOIN	include/rtw_pwrctrl.h	/^	PS_DENY_JOIN,$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_MGNT_TX	include/rtw_pwrctrl.h	/^	PS_DENY_MGNT_TX,$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_OTHERS	include/rtw_pwrctrl.h	/^	PS_DENY_OTHERS = 31$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_REASON	include/rtw_pwrctrl.h	/^} PS_DENY_REASON;$/;"	t	typeref:enum:_PS_DENY_REASON
-PS_DENY_SCAN	include/rtw_pwrctrl.h	/^	PS_DENY_SCAN,$/;"	e	enum:_PS_DENY_REASON
-PS_DENY_SUSPEND	include/rtw_pwrctrl.h	/^	PS_DENY_SUSPEND,$/;"	e	enum:_PS_DENY_REASON
-PS_DPS	include/rtw_pwrctrl.h	121;"	d
-PS_IMR_ENABLE	include/rtw_pwrctrl.h	128;"	d
-PS_ISR_ENABLE	include/rtw_pwrctrl.h	127;"	d
-PS_IS_ACTIVE	include/rtw_pwrctrl.h	148;"	d
-PS_IS_RF_ON	include/rtw_pwrctrl.h	147;"	d
-PS_LCLK	include/rtw_pwrctrl.h	122;"	d
-PS_MODE_ACTIVE	include/rtw_pwrctrl.h	/^	PS_MODE_ACTIVE	= 0	,$/;"	e	enum:Power_Mgnt
-PS_MODE_DTIM	include/rtw_pwrctrl.h	/^	PS_MODE_DTIM			,	\/* PS_MODE_SELF_DEFINED *\/$/;"	e	enum:Power_Mgnt
-PS_MODE_IBSS	include/rtw_pwrctrl.h	/^	PS_MODE_IBSS			,$/;"	e	enum:Power_Mgnt
-PS_MODE_MAX	include/rtw_pwrctrl.h	/^	PS_MODE_MAX			,$/;"	e	enum:Power_Mgnt
-PS_MODE_MIN	include/rtw_pwrctrl.h	/^	PS_MODE_MIN			,$/;"	e	enum:Power_Mgnt
-PS_MODE_NUM	include/rtw_pwrctrl.h	/^	PS_MODE_NUM,$/;"	e	enum:Power_Mgnt
-PS_MODE_UAPSD	include/rtw_pwrctrl.h	/^	PS_MODE_UAPSD			,$/;"	e	enum:Power_Mgnt
-PS_MODE_UAPSD_WMM	include/rtw_pwrctrl.h	/^	PS_MODE_UAPSD_WMM	,$/;"	e	enum:Power_Mgnt
-PS_MODE_VOIP	include/rtw_pwrctrl.h	/^	PS_MODE_VOIP			,$/;"	e	enum:Power_Mgnt
-PS_MODE_WWLAN	include/rtw_pwrctrl.h	/^	PS_MODE_WWLAN		,$/;"	e	enum:Power_Mgnt
-PS_RDY_CHECK	core/rtw_pwrctrl.c	/^u8 PS_RDY_CHECK(_adapter *padapter)$/;"	f
-PS_RF_OFF	include/rtw_pwrctrl.h	123;"	d
-PS_SEQ	include/rtw_pwrctrl.h	138;"	d
-PS_SEQ_MASK	include/rtw_pwrctrl.h	134;"	d
-PS_STATE	include/rtw_pwrctrl.h	136;"	d
-PS_STATE_HW	include/rtw_pwrctrl.h	137;"	d
-PS_STATE_HW_MASK	include/rtw_pwrctrl.h	133;"	d
-PS_STATE_MASK	include/rtw_pwrctrl.h	132;"	d
-PS_STATE_S0	include/rtw_pwrctrl.h	140;"	d
-PS_STATE_S1	include/rtw_pwrctrl.h	141;"	d
-PS_STATE_S2	include/rtw_pwrctrl.h	142;"	d
-PS_STATE_S3	include/rtw_pwrctrl.h	143;"	d
-PS_STATE_S4	include/rtw_pwrctrl.h	144;"	d
-PS_ST_ACTIVE	include/rtw_pwrctrl.h	125;"	d
-PS_T	hal/phydm/phydm_dynamicbbpowersaving.h	/^}PS_T,*pPS_T;$/;"	t	typeref:struct:_Dynamic_Power_Saving_
-PS_TOGGLE	include/rtw_pwrctrl.h	130;"	d
-PTActive	hal/phydm/phydm_rainfo.h	/^	u1Byte PTActive;  \/\/ on or off$/;"	m	struct:_ODM_RA_Info_
-PTModeSS	hal/phydm/phydm_rainfo.h	/^	u1Byte PTModeSS;  \/\/ decide whitch rate should do PT$/;"	m	struct:_ODM_RA_Info_
-PTPreRate	hal/phydm/phydm_rainfo.h	/^	u1Byte PTPreRate;  \/\/ if rate change do PT$/;"	m	struct:_ODM_RA_Info_
-PTPreRssi	hal/phydm/phydm_rainfo.h	/^	u1Byte PTPreRssi; \/\/ if RSSI change 5% do PT$/;"	m	struct:_ODM_RA_Info_
-PTSmoothFactor	hal/phydm/phydm_rainfo.h	/^	u1Byte PTSmoothFactor;$/;"	m	struct:_ODM_RA_Info_
-PTStage	hal/phydm/phydm_rainfo.h	/^	u1Byte PTStage;  \/\/ 0~6$/;"	m	struct:_ODM_RA_Info_
-PTStopCount	hal/phydm/phydm_rainfo.h	/^	u1Byte PTStopCount; \/\/Stop PT counter$/;"	m	struct:_ODM_RA_Info_
-PTTryState	hal/phydm/phydm_rainfo.h	/^	u1Byte PTTryState;  \/\/ 0 trying state, 1 for decision state$/;"	m	struct:_ODM_RA_Info_
-PTXBF_GET_TYPE	hal/phydm/txbf/halcomtxbf.h	/^}TXBF_GET_TYPE,*PTXBF_GET_TYPE;$/;"	t	typeref:enum:_TXBF_GET_TYPE
-PTXBF_SET_TYPE	hal/phydm/txbf/halcomtxbf.h	/^}TXBF_SET_TYPE,*PTXBF_SET_TYPE;$/;"	t	typeref:enum:_TXBF_SET_TYPE
-PTXDESC_8188E	include/rtl8188e_xmit.h	/^} TXDESC_8188E, *PTXDESC_8188E;$/;"	t	typeref:struct:txdesc_88e
-PTXDESC_8192E	include/rtl8192e_xmit.h	/^} TXDESC_8192E, *PTXDESC_8192E;$/;"	t	typeref:struct:txdescriptor_8192e
-PTXDESC_8812	include/rtl8812a_xmit.h	/^} TXDESC_8812, *PTXDESC_8812;$/;"	t	typeref:struct:txdescriptor_8812
-PTXDESC_8814	include/rtl8814a_xmit.h	/^} TXDESC_8814, *PTXDESC_8814;$/;"	t	typeref:struct:txdescriptor_8814
-PTXDESC_8821A	include/rtl8821a_xmit.h	/^} TXDESC_8821A, *PTXDESC_8821A;$/;"	t	typeref:struct:txdescriptor_8821a
-PTXPWRTRACK_CFG	hal/phydm/halphyrf_ap.h	/^} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;$/;"	t	typeref:struct:_TXPWRTRACK_CFG
-PTXPWRTRACK_CFG	hal/phydm/halphyrf_ce.h	/^} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;$/;"	t	typeref:struct:_TXPWRTRACK_CFG
-PTXPWRTRACK_CFG	hal/phydm/halphyrf_win.h	/^} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;$/;"	t	typeref:struct:_TXPWRTRACK_CFG
-PT_collision_pre	hal/phydm/phydm_rainfo.h	/^	BOOLEAN		PT_collision_pre;$/;"	m	struct:_Rate_Adaptive_Table_
-PT_score	hal/phydm/phydm.h	/^	u4Byte			PT_score;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PTxPowerInfo24G	include/hal_pg.h	/^} TxPowerInfo24G, *PTxPowerInfo24G;$/;"	t	typeref:struct:_TxPowerInfo24G
-PTxPowerInfo5G	include/hal_pg.h	/^} TxPowerInfo5G, *PTxPowerInfo5G;$/;"	t	typeref:struct:_TxPowerInfo5G
-PUBLIC_QUEUE_IDX	include/hal_com_reg.h	1630;"	d
-PUB_PGNUM_8814A	include/rtl8814a_hal.h	170;"	d
-PULONG	include/rtw_mp.h	137;"	d
-PURB	include/osdep_service_bsd.h	/^typedef struct urb *  PURB;$/;"	t	typeref:struct:urb
-PURB	include/osdep_service_linux.h	/^	typedef struct urb   *PURB;$/;"	t	typeref:struct:urb
-PUSB_EXTENSION	include/drv_types_ce.h	/^} USB_EXTENSION, *PUSB_EXTENSION;$/;"	t	typeref:struct:_USB_EXTENSION
-PUTU32	include/rtw_security.h	376;"	d
-PVHT_DATA_SC_E	include/rtw_rf.h	/^} VHT_DATA_SC, *PVHT_DATA_SC_E;$/;"	t	typeref:enum:_VHT_DATA_SC
-PVOID	hal/phydm/phydm_types.h	/^	typedef void					VOID,*PVOID;$/;"	t
-PVOID	include/basic_types.h	/^		typedef void *PVOID;$/;"	t
-PWC_EV12V	include/hal_com_reg.h	1148;"	d
-PWLAN_BCN_INFO	include/wlan_bssdef.h	/^} WLAN_BCN_INFO, *PWLAN_BCN_INFO;$/;"	t	typeref:struct:_WLAN_BCN_INFO
-PWLAN_BSSID_EX	include/wlan_bssdef.h	/^WLAN_BSSID_EX, *PWLAN_BSSID_EX;$/;"	t	typeref:struct:_WLAN_BSSID_EX
-PWLAN_HEADER_WAPI_EXTENSION	include/rtw_wapi.h	/^} WLAN_HEADER_WAPI_EXTENSION, *PWLAN_HEADER_WAPI_EXTENSION;$/;"	t	typeref:struct:_WLAN_HEADER_WAPI_EXTENSION
-PWLAN_PHY_INFO	include/wlan_bssdef.h	/^} WLAN_PHY_INFO, *PWLAN_PHY_INFO;$/;"	t	typeref:struct:_WLAN_PHY_INFO
-PWLAN_PWR_CFG	include/HalPwrSeqCmd.h	/^} WLAN_PWR_CFG, *PWLAN_PWR_CFG;$/;"	t	typeref:struct:_WL_PWR_CFG_
-PWRBIT_OW_EN	include/hal_com_reg.h	1537;"	d
-PWRS	include/rtl8188e_cmd.h	/^	PWRS$/;"	e	enum:__anon63
-PWRS	include/rtl8192e_cmd.h	/^	PWRS$/;"	e	enum:__anon45
-PWRS	include/rtl8812a_cmd.h	/^	PWRS$/;"	e	enum:__anon44
-PWRSEQ_DELAY_MS	include/HalPwrSeqCmd.h	/^	PWRSEQ_DELAY_MS,$/;"	e	enum:_PWRSEQ_CMD_DELAY_UNIT_
-PWRSEQ_DELAY_UNIT	include/HalPwrSeqCmd.h	/^} PWRSEQ_DELAY_UNIT;$/;"	t	typeref:enum:_PWRSEQ_CMD_DELAY_UNIT_
-PWRSEQ_DELAY_US	include/HalPwrSeqCmd.h	/^	PWRSEQ_DELAY_US,$/;"	e	enum:_PWRSEQ_CMD_DELAY_UNIT_
-PWRTRACK_METHOD	hal/phydm/halphyrf_ap.h	/^} PWRTRACK_METHOD;$/;"	t	typeref:enum:_PWRTRACK_CONTROL_METHOD
-PWRTRACK_METHOD	hal/phydm/halphyrf_ce.h	/^} PWRTRACK_METHOD;$/;"	t	typeref:enum:_PWRTRACK_CONTROL_METHOD
-PWRTRACK_METHOD	hal/phydm/halphyrf_win.h	/^} PWRTRACK_METHOD;$/;"	t	typeref:enum:_PWRTRACK_CONTROL_METHOD
-PWR_BASEADDR_MAC	include/HalPwrSeqCmd.h	64;"	d
-PWR_BASEADDR_PCIE	include/HalPwrSeqCmd.h	66;"	d
-PWR_BASEADDR_SDIO	include/HalPwrSeqCmd.h	67;"	d
-PWR_BASEADDR_USB	include/HalPwrSeqCmd.h	65;"	d
-PWR_CAM	include/wlan_bssdef.h	637;"	d
-PWR_CMD_DELAY	include/HalPwrSeqCmd.h	50;"	d
-PWR_CMD_END	include/HalPwrSeqCmd.h	55;"	d
-PWR_CMD_POLLING	include/HalPwrSeqCmd.h	40;"	d
-PWR_CMD_READ	include/HalPwrSeqCmd.h	28;"	d
-PWR_CMD_WRITE	include/HalPwrSeqCmd.h	34;"	d
-PWR_CUT_ALL_MSK	include/HalPwrSeqCmd.h	95;"	d
-PWR_CUT_A_MSK	include/HalPwrSeqCmd.h	88;"	d
-PWR_CUT_B_MSK	include/HalPwrSeqCmd.h	89;"	d
-PWR_CUT_C_MSK	include/HalPwrSeqCmd.h	90;"	d
-PWR_CUT_D_MSK	include/HalPwrSeqCmd.h	91;"	d
-PWR_CUT_E_MSK	include/HalPwrSeqCmd.h	92;"	d
-PWR_CUT_F_MSK	include/HalPwrSeqCmd.h	93;"	d
-PWR_CUT_G_MSK	include/HalPwrSeqCmd.h	94;"	d
-PWR_CUT_TESTCHIP_MSK	include/HalPwrSeqCmd.h	87;"	d
-PWR_FAB_ALL_MSK	include/HalPwrSeqCmd.h	82;"	d
-PWR_FAB_TSMC_MSK	include/HalPwrSeqCmd.h	80;"	d
-PWR_FAB_UMC_MSK	include/HalPwrSeqCmd.h	81;"	d
-PWR_INTF_ALL_MSK	include/HalPwrSeqCmd.h	75;"	d
-PWR_INTF_PCI_MSK	include/HalPwrSeqCmd.h	74;"	d
-PWR_INTF_SDIO_MSK	include/HalPwrSeqCmd.h	72;"	d
-PWR_INTF_USB_MSK	include/HalPwrSeqCmd.h	73;"	d
-PWR_MAXPS	include/wlan_bssdef.h	639;"	d
-PWR_MINPS	include/wlan_bssdef.h	638;"	d
-PWR_ST	include/hal_com_reg.h	1536;"	d
-PWR_STATUS_SHT	include/rtl8188e_xmit.h	81;"	d
-PWR_STATUS_SHT	include/rtl8192e_xmit.h	186;"	d
-PWR_STATUS_SHT	include/rtl8812a_xmit.h	79;"	d
-PWR_UAPSD	include/wlan_bssdef.h	640;"	d
-PWR_VOIP	include/wlan_bssdef.h	641;"	d
-P_AID	hal/phydm/phydm_beamforming.h	/^	u2Byte				P_AID;					\/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. *\/$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-P_AID	hal/phydm/phydm_beamforming.h	/^	u2Byte	P_AID;				\/*Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. *\/$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-PackageType	hal/phydm/phydm.h	/^	u1Byte			PackageType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PackageType	include/hal_data.h	/^	u8	PackageType;$/;"	m	struct:hal_com_data
-PacketCount	include/rtw_mp.h	/^	UINT		PacketCount;$/;"	m	struct:_RT_PMAC_TX_INFO
-PacketLength	include/rtw_mp.h	/^	UINT		PacketLength;$/;"	m	struct:_RT_PMAC_TX_INFO
-PacketMap	include/sta_info.h	/^	u64	PacketMap;$/;"	m	struct:_RSSI_STA
-PacketPattern	include/rtw_mp.h	/^	u8			PacketPattern;$/;"	m	struct:_RT_PMAC_TX_INFO
-PacketPeriod	include/rtw_mp.h	/^	USHORT			PacketPeriod;$/;"	m	struct:_RT_PMAC_TX_INFO
-PageNum	include/hal_com.h	262;"	d
-PageNum_128	include/hal_com.h	259;"	d
-PageNum_256	include/hal_com.h	260;"	d
-PageNum_512	include/hal_com.h	261;"	d
-Para1	include/hal_phy.h	/^	u32				Para1;$/;"	m	struct:_SwChnlCmd
-Para2	include/hal_phy.h	/^	u32				Para2;$/;"	m	struct:_SwChnlCmd
-ParseFailed	include/ieee80211.h	/^typedef enum { ParseOK = 0, ParseUnknown = 1, ParseFailed = -1 } ParseRes;$/;"	e	enum:__anon80
-ParseOK	include/ieee80211.h	/^typedef enum { ParseOK = 0, ParseUnknown = 1, ParseFailed = -1 } ParseRes;$/;"	e	enum:__anon80
-ParseQualifiedString	hal/hal_com.c	/^ParseQualifiedString($/;"	f
-ParseRes	include/ieee80211.h	/^typedef enum { ParseOK = 0, ParseUnknown = 1, ParseFailed = -1 } ParseRes;$/;"	t	typeref:enum:__anon80
-ParseUnknown	include/ieee80211.h	/^typedef enum { ParseOK = 0, ParseUnknown = 1, ParseFailed = -1 } ParseRes;$/;"	e	enum:__anon80
-PatchID	hal/phydm/phydm.h	/^	u1Byte			PatchID;	\/*Customer ID*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PathA	include/Hal8188EPhyReg.h	1097;"	d
-PathA	include/Hal8188FPhyReg.h	1104;"	d
-PathA	include/Hal8192EPhyReg.h	1111;"	d
-PathA	include/Hal8703BPhyReg.h	1133;"	d
-PathA	include/Hal8723BPhyReg.h	1131;"	d
-PathA	include/Hal8723DPhyReg.h	1134;"	d
-PathA	include/hal_com_phycfg.h	23;"	d
-PathA_Cnt	hal/phydm/phydm_pathdiv.h	/^	u2Byte	PathA_Cnt[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_ODM_PATH_DIVERSITY_
-PathA_Sum	hal/phydm/phydm_pathdiv.h	/^	u4Byte	PathA_Sum[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_ODM_PATH_DIVERSITY_
-PathB	include/Hal8188EPhyReg.h	1098;"	d
-PathB	include/Hal8188FPhyReg.h	1105;"	d
-PathB	include/Hal8192EPhyReg.h	1112;"	d
-PathB	include/Hal8703BPhyReg.h	1134;"	d
-PathB	include/Hal8723BPhyReg.h	1132;"	d
-PathB	include/Hal8723DPhyReg.h	1135;"	d
-PathB	include/hal_com_phycfg.h	24;"	d
-PathB_Cnt	hal/phydm/phydm_pathdiv.h	/^	u2Byte	PathB_Cnt[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_ODM_PATH_DIVERSITY_
-PathB_Sum	hal/phydm/phydm_pathdiv.h	/^	u4Byte	PathB_Sum[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_ODM_PATH_DIVERSITY_
-PathC	include/Hal8188EPhyReg.h	1099;"	d
-PathC	include/Hal8188FPhyReg.h	1106;"	d
-PathC	include/Hal8192EPhyReg.h	1113;"	d
-PathC	include/Hal8703BPhyReg.h	1135;"	d
-PathC	include/Hal8723BPhyReg.h	1133;"	d
-PathC	include/Hal8723DPhyReg.h	1136;"	d
-PathC	include/hal_com_phycfg.h	25;"	d
-PathD	include/Hal8188EPhyReg.h	1100;"	d
-PathD	include/Hal8188FPhyReg.h	1107;"	d
-PathD	include/Hal8192EPhyReg.h	1114;"	d
-PathD	include/Hal8703BPhyReg.h	1136;"	d
-PathD	include/Hal8723BPhyReg.h	1134;"	d
-PathD	include/Hal8723DPhyReg.h	1137;"	d
-PathD	include/hal_com_phycfg.h	26;"	d
-PathDivCheckBeforeLink8192C	hal/phydm/phydm_pathdiv.h	168;"	d
-PathDivSwitchTimer	hal/phydm/phydm.h	/^	RT_TIMER	PathDivSwitchTimer;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PathDivSwitchWorkitem	hal/phydm/phydm.h	/^	RT_WORK_ITEM			PathDivSwitchWorkitem;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PathSel	hal/phydm/phydm_pathdiv.h	/^	u1Byte	PathSel[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_ODM_PATH_DIVERSITY_
-PeerMacAddr	include/rtw_wapi.h	/^	u8					PeerMacAddr[6];$/;"	m	struct:_RT_WAPI_STA_INFO
-PeerMacAddr	include/rtw_wapi.h	/^	u8			PeerMacAddr[6];$/;"	m	struct:_RT_WAPI_CAM_ENTRY
-PhyDM_ACTING_AS_AP	hal/phydm/phydm_beamforming.h	/^	PhyDM_ACTING_AS_AP = 1$/;"	e	enum:_PHYDM_ACTING_TYPE
-PhyDM_ACTING_AS_IBSS	hal/phydm/phydm_beamforming.h	/^	PhyDM_ACTING_AS_IBSS = 0,$/;"	e	enum:_PHYDM_ACTING_TYPE
-PhyDM_DONT_IGNORE_EDCCA	hal/phydm/phydm_adaptivity.h	/^	PhyDM_DONT_IGNORE_EDCCA	= 1$/;"	e	enum:tag_PhyDM_MACEDCCA_Type
-PhyDM_Get_Rate_Bitmap_Ex	hal/phydm/phydm_rainfo.c	/^PhyDM_Get_Rate_Bitmap_Ex($/;"	f
-PhyDM_Get_Structure	hal/phydm/phydm.c	/^PhyDM_Get_Structure($/;"	f
-PhyDM_IGNORE_EDCCA	hal/phydm/phydm_adaptivity.h	/^	PhyDM_IGNORE_EDCCA			= 0,$/;"	e	enum:tag_PhyDM_MACEDCCA_Type
-PhyDM_MACEDCCA_Type	hal/phydm/phydm_adaptivity.h	/^}PhyDM_MACEDCCA_Type;$/;"	t	typeref:enum:tag_PhyDM_MACEDCCA_Type
-PhyDM_REGULATION_TYPE	hal/phydm/phydm_adaptivity.h	/^} PhyDM_REGULATION_TYPE;$/;"	t	typeref:enum:_tag_PhyDM_REGULATION_Type
-PhyDM_RX_MODE	hal/phydm/phydm_adaptivity.h	/^	PhyDM_RX_MODE			= 3$/;"	e	enum:tag_PhyDM_TRx_MUX_Type
-PhyDM_SHUTDOWN	hal/phydm/phydm_adaptivity.h	/^	PhyDM_SHUTDOWN			= 0,$/;"	e	enum:tag_PhyDM_TRx_MUX_Type
-PhyDM_STANDBY_MODE	hal/phydm/phydm_adaptivity.h	/^	PhyDM_STANDBY_MODE		= 1,$/;"	e	enum:tag_PhyDM_TRx_MUX_Type
-PhyDM_TX_MODE	hal/phydm/phydm_adaptivity.h	/^	PhyDM_TX_MODE			= 2,$/;"	e	enum:tag_PhyDM_TRx_MUX_Type
-PhyDM_Trx_MUX_Type	hal/phydm/phydm_adaptivity.h	/^}PhyDM_Trx_MUX_Type;$/;"	t	typeref:enum:tag_PhyDM_TRx_MUX_Type
-PhyDM_disable_LNA	hal/phydm/phydm_adaptivity.h	/^	PhyDM_disable_LNA		= 0,$/;"	e	enum:tag_PhyDM_set_LNA
-PhyDM_enable_LNA	hal/phydm/phydm_adaptivity.h	/^	PhyDM_enable_LNA		= 1,$/;"	e	enum:tag_PhyDM_set_LNA
-PhyDM_set_LNA	hal/phydm/phydm_adaptivity.h	/^} PhyDM_set_LNA;$/;"	t	typeref:enum:tag_PhyDM_set_LNA
-PhyDataR	include/hal_com_reg.h	591;"	d
-PhyDbgInfo	hal/phydm/phydm.h	/^	ODM_PHY_DBG_INFO_T	 PhyDbgInfo;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PhyInfo	include/wlan_bssdef.h	/^	WLAN_PHY_INFO	PhyInfo;$/;"	m	struct:_WLAN_BSSID_EX
-PhyRegPgValueType	hal/phydm/phydm.h	/^	PHY_REG_PG_TYPE		PhyRegPgValueType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PhyRegPgVersion	hal/phydm/phydm.h	/^	u1Byte				PhyRegPgVersion;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-PhySetTxPowerLevel	core/rtw_mp.c	/^void PhySetTxPowerLevel(PADAPTER pAdapter)$/;"	f
-Phydm_Adaptivity	hal/phydm/phydm_adaptivity.c	/^Phydm_Adaptivity($/;"	f
-Phydm_AdaptivityBSOD	hal/phydm/phydm_adaptivity.c	/^Phydm_AdaptivityBSOD($/;"	f
-Phydm_AdaptivityInit	hal/phydm/phydm_adaptivity.c	/^Phydm_AdaptivityInit($/;"	f
-Phydm_CalNHMcnt	hal/phydm/phydm_adaptivity.c	/^Phydm_CalNHMcnt($/;"	f
-Phydm_CheckAdaptivity	hal/phydm/phydm_adaptivity.c	/^Phydm_CheckAdaptivity($/;"	f
-Phydm_CheckChannelPlan	hal/phydm/phydm_adaptivity.c	/^Phydm_CheckChannelPlan($/;"	f
-Phydm_CheckEnvironment	hal/phydm/phydm_adaptivity.c	/^Phydm_CheckEnvironment($/;"	f
-Phydm_GetNHMCounterStatistics	hal/phydm/phydm_adaptivity.c	/^Phydm_GetNHMCounterStatistics($/;"	f
-Phydm_MACEDCCAState	hal/phydm/phydm_adaptivity.c	/^Phydm_MACEDCCAState($/;"	f
-Phydm_NHMCounterStatistics	hal/phydm/phydm_adaptivity.c	/^Phydm_NHMCounterStatistics($/;"	f
-Phydm_NHMCounterStatisticsInit	hal/phydm/phydm_adaptivity.c	/^Phydm_NHMCounterStatisticsInit($/;"	f
-Phydm_NHMCounterStatisticsReset	hal/phydm/phydm_adaptivity.c	/^Phydm_NHMCounterStatisticsReset($/;"	f
-Phydm_SearchPwdBLowerBound	hal/phydm/phydm_adaptivity.c	/^Phydm_SearchPwdBLowerBound($/;"	f
-Phydm_SetEDCCAThreshold	hal/phydm/phydm_adaptivity.c	/^Phydm_SetEDCCAThreshold($/;"	f
-Phydm_SetLNA	hal/phydm/phydm_adaptivity.c	/^Phydm_SetLNA($/;"	f
-Phydm_SetTRxMux	hal/phydm/phydm_adaptivity.c	/^Phydm_SetTRxMux($/;"	f
-PhysicalLen_BT	include/rtw_efuse.h	/^	const u16  PhysicalLen_BT;$/;"	m	struct:_EFUSE_HAL
-PhysicalLen_WiFi	include/rtw_efuse.h	/^	const u16  PhysicalLen_WiFi;$/;"	m	struct:_EFUSE_HAL
-PktCnt_SWAntDivByCtrlFrame	hal/phydm/phydm_antdiv.h	/^	u4Byte		PktCnt_SWAntDivByCtrlFrame;$/;"	m	struct:_SW_Antenna_Switch_
-PktTxThread	include/rtw_mp.h	/^	_thread_hdl_ PktTxThread;$/;"	m	struct:mp_tx
-PlatformEFIORead1Byte	include/rtw_io.h	569;"	d
-PlatformEFIORead2Byte	include/rtw_io.h	571;"	d
-PlatformEFIORead4Byte	include/rtw_io.h	573;"	d
-PlatformEFIOWrite1Byte	include/rtw_io.h	562;"	d
-PlatformEFIOWrite2Byte	include/rtw_io.h	564;"	d
-PlatformEFIOWrite4Byte	include/rtw_io.h	566;"	d
-PolarityCtl	include/hal_data.h	/^	RT_POLARITY_CTL		PolarityCtl; \/* For Wifi PDn Polarity control. *\/$/;"	m	struct:hal_com_data
-PowerIndexOffset	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte	PowerIndexOffset;$/;"	m	struct:ODM_RF_Calibration_Structure
-PowerIndexOffset	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte	PowerIndexOffset[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-PowerIndexOffset	hal/phydm/phydm_powertracking_win.h	/^	s1Byte	PowerIndexOffset[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-PowerTracking_Type	include/drv_types.h	/^	u8	PowerTracking_Type;$/;"	m	struct:registry_priv
-Power_Mgnt	include/rtw_pwrctrl.h	/^enum Power_Mgnt {$/;"	g
-PreAntenna	hal/phydm/phydm_antdiv.h	/^	u1Byte		PreAntenna;$/;"	m	struct:_SW_Antenna_Switch_
-PreCCAState	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u1Byte		PreCCAState;$/;"	m	struct:_Dynamic_Power_Saving_
-PreCCKPDState	hal/phydm/phydm_dig.h	/^	u1Byte		PreCCKPDState;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-PreCCK_CCAThres	hal/phydm/phydm_dig.h	/^	u1Byte		PreCCK_CCAThres;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-PreCsiReport	include/rtw_beamforming.h	/^	u8	PreCsiReport[327];$/;"	m	struct:beamforming_entry
-PreIGValue	hal/phydm/phydm_dig.h	/^	u1Byte		PreIGValue;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-PreLogSeq	hal/phydm/phydm_beamforming.h	/^	u1Byte				PreLogSeq;				\/*Modified by Jeffery @2015-03-30*\/$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-PreLogSeq	include/rtw_beamforming.h	/^	u8				PreLogSeq;				\/*Modified by Jeffery @2015-03-30*\/$/;"	m	struct:beamforming_entry
-PreRFState	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u1Byte		PreRFState;$/;"	m	struct:_Dynamic_Power_Saving_
-PreRSSI	hal/phydm/phydm_antdiv.h	/^	s4Byte		PreRSSI;$/;"	m	struct:_SW_Antenna_Switch_
-PreRate	hal/phydm/phydm_rainfo.h	/^	u1Byte PreRate;$/;"	m	struct:_ODM_RA_Info_
-PreRssiStaRA	hal/phydm/phydm_rainfo.h	/^	u1Byte PreRssiStaRA;$/;"	m	struct:_ODM_RA_Info_
-PreSTAConnectState	hal/phydm/phydm_dig.h	/^	u1Byte		PreSTAConnectState;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-Pre_Aux_FailDetec	hal/phydm/phydm_antdiv.h	/^	BOOLEAN		Pre_Aux_FailDetec;$/;"	m	struct:_SW_Antenna_Switch_
-PriCCA_flag	hal/phydm/phydm.h	/^	u1Byte	PriCCA_flag;$/;"	m	struct:_Dynamic_Primary_CCA
-Pri_CCA_T	hal/phydm/phydm.h	/^} Pri_CCA_T, *pPri_CCA_T;$/;"	t	typeref:struct:_Dynamic_Primary_CCA
-Privacy	include/wlan_bssdef.h	/^	ULONG  Privacy;$/;"	m	struct:_WLAN_BSSID_EX
-ProgIf	include/drv_types_pci.h	/^	u8	ProgIf;$/;"	m	struct:_PCI_COMMON_CONFIG
-ProtectBytes	include/rtw_efuse.h	/^	const u16  ProtectBytes;$/;"	m	struct:_EFUSE_HAL
-PwdBUpperBound	hal/phydm/phydm_adaptivity.h	27;"	d
-PwrState	include/rtl8188e_cmd.h	/^	u8 PwrState;\/* AllON(0x0c),RFON(0x04),RFOFF(0x00) *\/$/;"	m	struct:_SETPWRMODE_PARM
-PwrState	include/rtl8192e_cmd.h	/^	u8 PwrState;\/* AllON(0x0c),RFON(0x04),RFOFF(0x00) *\/$/;"	m	struct:_SETPWRMODE_PARM
-QOS	include/rtl8188e_xmit.h	73;"	d
-QOS	include/rtl8192e_xmit.h	178;"	d
-QOS	include/rtl8812a_xmit.h	71;"	d
-QSEL_SHT	include/rtl8188e_xmit.h	52;"	d
-QSEL_SHT	include/rtl8192e_xmit.h	157;"	d
-QSEL_SHT	include/rtl8812a_xmit.h	50;"	d
-QSLT_BE	include/hal_com.h	243;"	d
-QSLT_BEACON	include/hal_com.h	246;"	d
-QSLT_BK	include/hal_com.h	242;"	d
-QSLT_CMD	include/hal_com.h	249;"	d
-QSLT_HIGH	include/hal_com.h	247;"	d
-QSLT_MGNT	include/hal_com.h	248;"	d
-QSLT_VI	include/hal_com.h	244;"	d
-QSLT_VO	include/hal_com.h	245;"	d
-QS_BE_QUEUE	include/hal_com_reg.h	1356;"	d
-QS_BK_QUEUE	include/hal_com_reg.h	1357;"	d
-QS_HIGH_QUEUE	include/hal_com_reg.h	1359;"	d
-QS_MANAGER_QUEUE	include/hal_com_reg.h	1358;"	d
-QS_VI_QUEUE	include/hal_com_reg.h	1355;"	d
-QS_VO_QUEUE	include/hal_com_reg.h	1354;"	d
-QUERY_OID	include/rtw_ioctl.h	/^	QUERY_OID,$/;"	e	enum:oid_type
-QUEUE_EXTRA	include/hal_com_reg.h	1377;"	d
-QUEUE_HIGH	include/hal_com_reg.h	1380;"	d
-QUEUE_LOW	include/hal_com_reg.h	1378;"	d
-QUEUE_NORMAL	include/hal_com_reg.h	1379;"	d
-QoS_info	include/wifi.h	/^	unsigned char		QoS_info;$/;"	m	struct:WMM_para_element
-Queue2Pipe	include/drv_types.h	/^	u8	Queue2Pipe[HW_QUEUE_ENTRY];\/* for out pipe mapping *\/$/;"	m	struct:dvobj_priv
-R	include/rtw_security.h	/^	u32  L, R;           \/* Current state *\/$/;"	m	struct:mic_data
-R	include/rtw_security.h	439;"	d
-R2T_PHY_DELAY	core/rtw_wlan_util.c	51;"	d	file:
-RA	hal/phydm/phydm_beamforming.h	/^	pu1Byte						RA; $/;"	m	struct:_RT_BEAMFORM_STAINFO
-RADBG_DEBUG_MONITOR1	hal/phydm/phydm_rainfo.h	/^	RADBG_DEBUG_MONITOR1 = 0xc,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_DEBUG_MONITOR2	hal/phydm/phydm_rainfo.h	/^	RADBG_DEBUG_MONITOR2 = 0xd,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_DEBUG_MONITOR3	hal/phydm/phydm_rainfo.h	/^	RADBG_DEBUG_MONITOR3 = 0xe,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_DEBUG_MONITOR4	hal/phydm/phydm_rainfo.h	/^	RADBG_DEBUG_MONITOR4 = 0xf,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_DEBUG_MONITOR5	hal/phydm/phydm_rainfo.h	/^	RADBG_DEBUG_MONITOR5 = 0x10,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_N_HIGH	hal/phydm/phydm_rainfo.h	/^	RADBG_N_HIGH 				=	2,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_N_LOW	hal/phydm/phydm_rainfo.h	/^	RADBG_N_LOW				=	3,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_PCR_TH_OFFSET	hal/phydm/phydm_rainfo.h	/^	RADBG_PCR_TH_OFFSET		=	0,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_RATE_DOWN_RTY_RATIO	hal/phydm/phydm_rainfo.h	/^	RADBG_RATE_DOWN_RTY_RATIO =	9, \/\/u8$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_RATE_UP_RTY_RATIO	hal/phydm/phydm_rainfo.h	/^	RADBG_RATE_UP_RTY_RATIO	=	8,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_RTY_PENALTY	hal/phydm/phydm_rainfo.h	/^	RADBG_RTY_PENALTY		=	1,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_TDROPING_NECESSARY	hal/phydm/phydm_rainfo.h	/^	RADBG_TDROPING_NECESSARY =	7,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_TRATE_DOWN_TABLE	hal/phydm/phydm_rainfo.h	/^	RADBG_TRATE_DOWN_TABLE	=	5,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_TRATE_UP_TABLE	hal/phydm/phydm_rainfo.h	/^	RADBG_TRATE_UP_TABLE		=	4,$/;"	e	enum:_Phydm_ra_dbg_para
-RADBG_TRYING_NECESSARY	hal/phydm/phydm_rainfo.h	/^	RADBG_TRYING_NECESSARY	=	6,$/;"	e	enum:_Phydm_ra_dbg_para
-RADropAfterDown	hal/phydm/phydm_rainfo.h	/^	u1Byte RADropAfterDown;$/;"	m	struct:_ODM_RA_Info_
-RAINFO_BE_RX_STATE	hal/phydm/phydm_rainfo.h	44;"	d
-RAINFO_BE_TX_STATE	hal/phydm/phydm_rainfo.h	52;"	d
-RAINFO_BF_STATE	hal/phydm/phydm_rainfo.h	51;"	d
-RAINFO_INIT_RSSI_RATE_STATE	hal/phydm/phydm_rainfo.h	50;"	d
-RAINFO_NOISY_STATE	hal/phydm/phydm_rainfo.h	47;"	d
-RAINFO_SHURTCUT_FLAG	hal/phydm/phydm_rainfo.h	49;"	d
-RAINFO_SHURTCUT_STATE	hal/phydm/phydm_rainfo.h	48;"	d
-RAINFO_STBC_STATE	hal/phydm/phydm_rainfo.h	45;"	d
-RAINFO_VERSION	hal/phydm/phydm_rainfo.h	31;"	d
-RAISE	include/rtw_mp.h	476;"	d
-RAInfo	hal/phydm/phydm.h	/^	ODM_RA_INFO_T   RAInfo[ODM_ASSOCIATE_ENTRY_NUM]; $/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RALINK_OUI	core/rtw_wlan_util.c	/^unsigned char RALINK_OUI[] = {0x00, 0x0c, 0x43};$/;"	v
-RAM_DL_SEL	include/hal_com_reg.h	1246;"	d
-RAPendingCounter	hal/phydm/phydm_rainfo.h	/^	u1Byte RAPendingCounter;$/;"	m	struct:_ODM_RA_Info_
-RATEID_IDX	include/ieee80211.h	/^} RATEID_IDX, *PRATEID_IDX;$/;"	t	typeref:enum:_RATEID_IDX_
-RATEID_IDX_B	include/ieee80211.h	/^	RATEID_IDX_B = 8,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_BG	include/ieee80211.h	/^	RATEID_IDX_BG = 6,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_BGN_20M_1SS_BN	include/ieee80211.h	/^	RATEID_IDX_BGN_20M_1SS_BN = 3,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_BGN_20M_2SS_BN	include/ieee80211.h	/^	RATEID_IDX_BGN_20M_2SS_BN = 2,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_BGN_3SS	include/ieee80211.h	/^	RATEID_IDX_BGN_3SS = 14,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_BGN_40M_1SS	include/ieee80211.h	/^	RATEID_IDX_BGN_40M_1SS = 1,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_BGN_40M_2SS	include/ieee80211.h	/^	RATEID_IDX_BGN_40M_2SS = 0,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_G	include/ieee80211.h	/^	RATEID_IDX_G = 7,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_GN_N1SS	include/ieee80211.h	/^	RATEID_IDX_GN_N1SS = 5,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_GN_N2SS	include/ieee80211.h	/^	RATEID_IDX_GN_N2SS = 4,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_MIX1	include/ieee80211.h	/^	RATEID_IDX_MIX1 = 11,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_MIX2	include/ieee80211.h	/^	RATEID_IDX_MIX2 = 12,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_VHT_1SS	include/ieee80211.h	/^	RATEID_IDX_VHT_1SS = 10,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_VHT_2SS	include/ieee80211.h	/^	RATEID_IDX_VHT_2SS = 9,$/;"	e	enum:_RATEID_IDX_
-RATEID_IDX_VHT_3SS	include/ieee80211.h	/^	RATEID_IDX_VHT_3SS = 13,$/;"	e	enum:_RATEID_IDX_
-RATETAB_ENT	os_dep/linux/ioctl_cfg80211.c	83;"	d	file:
-RATE_11M	include/hal_com_reg.h	756;"	d
-RATE_12M	include/hal_com_reg.h	760;"	d
-RATE_18M	include/hal_com_reg.h	761;"	d
-RATE_1M	include/hal_com_reg.h	753;"	d
-RATE_24M	include/hal_com_reg.h	762;"	d
-RATE_2M	include/hal_com_reg.h	754;"	d
-RATE_36M	include/hal_com_reg.h	763;"	d
-RATE_48M	include/hal_com_reg.h	764;"	d
-RATE_54M	include/hal_com_reg.h	765;"	d
-RATE_5_5M	include/hal_com_reg.h	755;"	d
-RATE_6M	include/hal_com_reg.h	758;"	d
-RATE_9M	include/hal_com_reg.h	759;"	d
-RATE_ADAPTIVE_SUPPORT	include/hal_ic_cfg.h	39;"	d
-RATE_ADAPTIVE_SUPPORT	include/hal_ic_cfg.h	47;"	d
-RATE_ADAPTIVE_SUPPORT	include/hal_ic_cfg.h	51;"	d
-RATE_ALL_CCK	include/hal_com_reg.h	787;"	d
-RATE_ALL_OFDM_1SS	include/hal_com_reg.h	790;"	d
-RATE_ALL_OFDM_2SS	include/hal_com_reg.h	792;"	d
-RATE_ALL_OFDM_AG	include/hal_com_reg.h	788;"	d
-RATE_BITMAP_ALL	include/hal_com_reg.h	795;"	d
-RATE_BMP_CCK	include/drv_types.h	745;"	d
-RATE_BMP_GET_CCK	include/drv_types.h	749;"	d
-RATE_BMP_GET_HT_1SS	include/drv_types.h	761;"	d
-RATE_BMP_GET_HT_2SS	include/drv_types.h	762;"	d
-RATE_BMP_GET_HT_3SS	include/drv_types.h	763;"	d
-RATE_BMP_GET_HT_4SS	include/drv_types.h	764;"	d
-RATE_BMP_GET_OFDM	include/drv_types.h	750;"	d
-RATE_BMP_GET_VHT_1SS	include/drv_types.h	773;"	d
-RATE_BMP_GET_VHT_2SS	include/drv_types.h	774;"	d
-RATE_BMP_GET_VHT_3SS	include/drv_types.h	775;"	d
-RATE_BMP_HAS_CCK	include/drv_types.h	747;"	d
-RATE_BMP_HAS_HT_1SS	include/drv_types.h	757;"	d
-RATE_BMP_HAS_HT_2SS	include/drv_types.h	758;"	d
-RATE_BMP_HAS_HT_3SS	include/drv_types.h	759;"	d
-RATE_BMP_HAS_HT_4SS	include/drv_types.h	760;"	d
-RATE_BMP_HAS_OFDM	include/drv_types.h	748;"	d
-RATE_BMP_HAS_VHT_1SS	include/drv_types.h	770;"	d
-RATE_BMP_HAS_VHT_2SS	include/drv_types.h	771;"	d
-RATE_BMP_HAS_VHT_3SS	include/drv_types.h	772;"	d
-RATE_BMP_HT_1SS	include/drv_types.h	753;"	d
-RATE_BMP_HT_2SS	include/drv_types.h	754;"	d
-RATE_BMP_HT_3SS	include/drv_types.h	755;"	d
-RATE_BMP_HT_4SS	include/drv_types.h	756;"	d
-RATE_BMP_OFDM	include/drv_types.h	746;"	d
-RATE_BMP_VHT_1SS	include/drv_types.h	767;"	d
-RATE_BMP_VHT_2SS	include/drv_types.h	768;"	d
-RATE_BMP_VHT_3SS	include/drv_types.h	769;"	d
-RATE_COUNT	os_dep/linux/ioctl_linux.c	41;"	d	file:
-RATE_DECISION	hal/phydm/phydm_debug.h	71;"	d
-RATE_DOWN	hal/phydm/phydm_debug.h	74;"	d
-RATE_DOWN_RTY_RATIO	hal/phydm/phydm_rainfo.h	/^	u1Byte	RATE_DOWN_RTY_RATIO[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RATE_DOWN_RTY_RATIO_default	hal/phydm/phydm_rainfo.h	/^	u1Byte	RATE_DOWN_RTY_RATIO_default[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RATE_DOWN_RTY_RATIO_modify_note	hal/phydm/phydm_rainfo.h	/^	BOOLEAN	RATE_DOWN_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RATE_ID_SHT	include/rtl8188e_xmit.h	53;"	d
-RATE_ID_SHT	include/rtl8192e_xmit.h	158;"	d
-RATE_ID_SHT	include/rtl8812a_xmit.h	51;"	d
-RATE_MCS0	include/hal_com_reg.h	767;"	d
-RATE_MCS1	include/hal_com_reg.h	768;"	d
-RATE_MCS10	include/hal_com_reg.h	778;"	d
-RATE_MCS11	include/hal_com_reg.h	779;"	d
-RATE_MCS12	include/hal_com_reg.h	780;"	d
-RATE_MCS13	include/hal_com_reg.h	781;"	d
-RATE_MCS14	include/hal_com_reg.h	782;"	d
-RATE_MCS15	include/hal_com_reg.h	783;"	d
-RATE_MCS2	include/hal_com_reg.h	769;"	d
-RATE_MCS3	include/hal_com_reg.h	770;"	d
-RATE_MCS4	include/hal_com_reg.h	771;"	d
-RATE_MCS5	include/hal_com_reg.h	772;"	d
-RATE_MCS6	include/hal_com_reg.h	773;"	d
-RATE_MCS7	include/hal_com_reg.h	774;"	d
-RATE_MCS8	include/hal_com_reg.h	776;"	d
-RATE_MCS9	include/hal_com_reg.h	777;"	d
-RATE_RRSR_CCK_ONLY_1M	include/hal_com_reg.h	798;"	d
-RATE_RRSR_WITHOUT_CCK	include/hal_com_reg.h	799;"	d
-RATE_SECTION	include/ieee80211.h	/^} RATE_SECTION;$/;"	t	typeref:enum:_RATE_SECTION
-RATE_SECTION_NUM	include/ieee80211.h	/^	RATE_SECTION_NUM,$/;"	e	enum:_RATE_SECTION
-RATE_UP	hal/phydm/phydm_debug.h	73;"	d
-RATE_UP_RTY_RATIO	hal/phydm/phydm_rainfo.h	/^	u1Byte	RATE_UP_RTY_RATIO[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RATE_UP_RTY_RATIO_default	hal/phydm/phydm_rainfo.h	/^	u1Byte	RATE_UP_RTY_RATIO_default[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RATE_UP_RTY_RATIO_modify_note	hal/phydm/phydm_rainfo.h	/^	BOOLEAN	RATE_UP_RTY_RATIO_modify_note[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RATRState	hal/phydm/phydm_rainfo.h	/^	u1Byte				RATRState;			\/\/ Current RSSI level, DM_RATR_STA_HIGH\/DM_RATR_STA_MIDDLE\/DM_RATR_STA_LOW$/;"	m	struct:_ODM_RATE_ADAPTIVE
-RATR_11M	include/hal_com_reg.h	723;"	d
-RATR_12M	include/hal_com_reg.h	727;"	d
-RATR_18M	include/hal_com_reg.h	728;"	d
-RATR_1M	include/hal_com_reg.h	720;"	d
-RATR_24M	include/hal_com_reg.h	729;"	d
-RATR_2M	include/hal_com_reg.h	721;"	d
-RATR_36M	include/hal_com_reg.h	730;"	d
-RATR_48M	include/hal_com_reg.h	731;"	d
-RATR_54M	include/hal_com_reg.h	732;"	d
-RATR_55M	include/hal_com_reg.h	722;"	d
-RATR_6M	include/hal_com_reg.h	725;"	d
-RATR_9M	include/hal_com_reg.h	726;"	d
-RATR_INX_WIRELESS_AC_N	include/ieee80211.h	/^	RATR_INX_WIRELESS_AC_N = 8,$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_B	include/ieee80211.h	/^	RATR_INX_WIRELESS_B = 6,$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_G	include/ieee80211.h	/^	RATR_INX_WIRELESS_G = 5,$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_GB	include/ieee80211.h	/^	RATR_INX_WIRELESS_GB = 4,$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_MC	include/ieee80211.h	/^	RATR_INX_WIRELESS_MC = 7,$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_N	include/ieee80211.h	/^	RATR_INX_WIRELESS_N = 3,$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_NB	include/ieee80211.h	/^	RATR_INX_WIRELESS_NB = 2,		\/* BGN 20 Mhz 2SS 1SS  or BN *\/$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_NG	include/ieee80211.h	/^	RATR_INX_WIRELESS_NG = 1,		\/* GN or N *\/$/;"	e	enum:_RATR_TABLE_MODE
-RATR_INX_WIRELESS_NGB	include/ieee80211.h	/^	RATR_INX_WIRELESS_NGB = 0,	\/* BGN 40 Mhz 2SS 1SS *\/$/;"	e	enum:_RATR_TABLE_MODE
-RATR_MCS0	include/hal_com_reg.h	734;"	d
-RATR_MCS1	include/hal_com_reg.h	735;"	d
-RATR_MCS10	include/hal_com_reg.h	745;"	d
-RATR_MCS11	include/hal_com_reg.h	746;"	d
-RATR_MCS12	include/hal_com_reg.h	747;"	d
-RATR_MCS13	include/hal_com_reg.h	748;"	d
-RATR_MCS14	include/hal_com_reg.h	749;"	d
-RATR_MCS15	include/hal_com_reg.h	750;"	d
-RATR_MCS2	include/hal_com_reg.h	736;"	d
-RATR_MCS3	include/hal_com_reg.h	737;"	d
-RATR_MCS4	include/hal_com_reg.h	738;"	d
-RATR_MCS5	include/hal_com_reg.h	739;"	d
-RATR_MCS6	include/hal_com_reg.h	740;"	d
-RATR_MCS7	include/hal_com_reg.h	741;"	d
-RATR_MCS8	include/hal_com_reg.h	743;"	d
-RATR_MCS9	include/hal_com_reg.h	744;"	d
-RATR_TABLE_MODE	include/ieee80211.h	/^} RATR_TABLE_MODE, *PRATR_TABLE_MODE;$/;"	t	typeref:enum:_RATR_TABLE_MODE
-RAUseRate	hal/phydm/phydm_rainfo.h	/^	u4Byte RAUseRate;$/;"	m	struct:_ODM_RA_Info_
-RAWaitingCounter	hal/phydm/phydm_rainfo.h	/^	u1Byte RAWaitingCounter;$/;"	m	struct:_ODM_RA_Info_
-RA_FIRST_MACID	hal/phydm/phydm_rainfo.h	64;"	d
-RA_FIRST_MACID	hal/phydm/phydm_rainfo.h	66;"	d
-RA_FIRST_MACID	hal/phydm/phydm_rainfo.h	70;"	d
-RA_FLOOR_TABLE_SIZE	hal/phydm/phydm_rainfo.h	37;"	d
-RA_FLOOR_UP_GAP	hal/phydm/phydm_rainfo.h	36;"	d
-RA_H2C	hal/phydm/phydm_debug.h	76;"	d
-RA_MASK_CCK	hal/phydm/phydm_rainfo.h	54;"	d
-RA_MASK_HT1SS	hal/phydm/phydm_rainfo.h	56;"	d
-RA_MASK_HT2SS	hal/phydm/phydm_rainfo.h	57;"	d
-RA_MASK_HT4SS	hal/phydm/phydm_rainfo.h	59;"	d
-RA_MASK_OFDM	hal/phydm/phydm_rainfo.h	55;"	d
-RA_MASK_PHYDMLIZE_AP	hal/phydm/phydm_features.h	54;"	d
-RA_MASK_PHYDMLIZE_CE	hal/phydm/phydm_features.h	104;"	d
-RA_MASK_PHYDMLIZE_WIN	hal/phydm/phydm_features.h	41;"	d
-RA_MASK_VHT1SS	hal/phydm/phydm_rainfo.h	60;"	d
-RA_MASK_VHT2SS	hal/phydm/phydm_rainfo.h	61;"	d
-RA_Para_feedback_req	hal/phydm/phydm_rainfo.h	/^	BOOLEAN RA_Para_feedback_req;$/;"	m	struct:_Rate_Adaptive_Table_
-RA_RETRY_DESCEND_NUM	hal/phydm/phydm_rainfo.h	40;"	d
-RA_RETRY_LIMIT_HIGH	hal/phydm/phydm_rainfo.h	42;"	d
-RA_RETRY_LIMIT_LOW	hal/phydm/phydm_rainfo.h	41;"	d
-RA_RSSI_STATE_HOLD	hal/phydm/phydm_hwconfig.h	31;"	d
-RA_RSSI_STATE_INIT	hal/phydm/phydm_hwconfig.h	29;"	d
-RA_RSSI_STATE_SEND	hal/phydm/phydm_hwconfig.h	30;"	d
-RA_T	hal/phydm/phydm_rainfo.h	/^} RA_T, *pRA_T;$/;"	t	typeref:struct:_Rate_Adaptive_Table_
-RA_offset_direction	hal/phydm/phydm_rainfo.h	/^	u1Byte	RA_offset_direction;$/;"	m	struct:_Rate_Adaptive_Table_
-RA_threshold_offset	hal/phydm/phydm_rainfo.h	/^	u1Byte	RA_threshold_offset;$/;"	m	struct:_Rate_Adaptive_Table_
-RAstage	hal/phydm/phydm_rainfo.h	/^	u1Byte RAstage;  \/\/ StageRA, decide how many times RA will be done between PT$/;"	m	struct:_ODM_RA_Info_
-RC4_KEY_SIZE	core/rtw_security.c	494;"	d	file:
-RCAMO	include/hal_com_reg.h	582;"	d
-RCAMO_8723D	hal/phydm/rtl8723d/hal8723dreg.h	456;"	d
-RCAMO_8814A	include/rtl8814a_spec.h	555;"	d
-RCON	include/rtw_security.h	339;"	d
-RCR_9356SEL	include/rtw_mp_phy_regdef.h	1082;"	d
-RCR_AAP	include/hal_com_reg.h	1128;"	d
-RCR_AAP	include/rtw_mp_phy_regdef.h	1077;"	d
-RCR_AB	include/hal_com_reg.h	1125;"	d
-RCR_AB	include/rtw_mp_phy_regdef.h	1080;"	d
-RCR_ACF	include/hal_com_reg.h	1116;"	d
-RCR_ACF	include/rtw_mp_phy_regdef.h	1086;"	d
-RCR_ACRC32	include/hal_com_reg.h	1120;"	d
-RCR_ACRC32	include/rtw_mp_phy_regdef.h	1081;"	d
-RCR_ADD3	include/hal_com_reg.h	1124;"	d
-RCR_ADD3	include/rtw_mp_phy_regdef.h	1088;"	d
-RCR_ADF	include/hal_com_reg.h	1117;"	d
-RCR_ADF	include/rtw_mp_phy_regdef.h	1085;"	d
-RCR_AICV	include/hal_com_reg.h	1119;"	d
-RCR_AICV	include/rtw_mp_phy_regdef.h	1083;"	d
-RCR_AM	include/hal_com_reg.h	1126;"	d
-RCR_AM	include/rtw_mp_phy_regdef.h	1079;"	d
-RCR_AMF	include/hal_com_reg.h	1115;"	d
-RCR_AMF	include/rtw_mp_phy_regdef.h	1087;"	d
-RCR_APM	include/hal_com_reg.h	1127;"	d
-RCR_APM	include/rtw_mp_phy_regdef.h	1078;"	d
-RCR_APPFCS	include/hal_com_reg.h	1097;"	d
-RCR_APP_BA_SSN	include/hal_com_reg.h	1101;"	d
-RCR_APP_ICV	include/hal_com_reg.h	1099;"	d
-RCR_APP_MIC	include/hal_com_reg.h	1098;"	d
-RCR_APP_PHYST_RXFF	include/hal_com_reg.h	1100;"	d
-RCR_APWRMGT	include/hal_com_reg.h	1123;"	d
-RCR_APWRMGT	include/rtw_mp_phy_regdef.h	1089;"	d
-RCR_BC_MD_EN	include/hal_com_reg.h	1111;"	d
-RCR_CBSSID	include/rtw_mp_phy_regdef.h	1090;"	d
-RCR_CBSSID_BCN	include/hal_com_reg.h	1121;"	d
-RCR_CBSSID_DATA	include/hal_com_reg.h	1122;"	d
-RCR_DISCHKPPDLLEN	include/hal_com_reg.h	1107;"	d
-RCR_DISDECMYPKT	include/hal_com_reg.h	1118;"	d
-RCR_DISGCLK	include/hal_com_reg.h	1109;"	d
-RCR_ENMARP	include/rtw_mp_phy_regdef.h	1091;"	d
-RCR_ENMBID	include/hal_com_reg.h	1104;"	d
-RCR_EnCS1	include/rtw_mp_phy_regdef.h	1092;"	d
-RCR_EnCS2	include/rtw_mp_phy_regdef.h	1093;"	d
-RCR_HTC_LOC_CTRL	include/hal_com_reg.h	1114;"	d
-RCR_LSIGEN	include/hal_com_reg.h	1105;"	d
-RCR_MFBEN	include/hal_com_reg.h	1106;"	d
-RCR_OnlyErlPkt	include/rtw_mp_phy_regdef.h	1094;"	d
-RCR_PKTCTL_DLEN	include/hal_com_reg.h	1108;"	d
-RCR_RXFTH0	include/rtw_mp_phy_regdef.h	1084;"	d
-RCR_RXSK_PERPKT	include/hal_com_reg.h	1113;"	d
-RCR_TCPOFLD_EN	hal/phydm/rtl8723d/hal8723dreg.h	920;"	d
-RCR_TCPOFLD_EN	include/hal_com_reg.h	1103;"	d
-RCR_TIM_PARSER_EN	include/hal_com_reg.h	1110;"	d
-RCR_UC_MD_EN	include/hal_com_reg.h	1112;"	d
-RCR_VHT_DACK	include/hal_com_reg.h	1102;"	d
-RDY_MACON	include/hal_com_reg.h	1184;"	d
-READDBA_LIMIT	include/rtw_mlme_ext.h	40;"	d
-READ_AND_CONFIG	hal/phydm/phydm_hwconfig.c	33;"	d	file:
-READ_AND_CONFIG	hal/phydm/phydm_hwconfig.c	40;"	d	file:
-READ_AND_CONFIG_MP	hal/phydm/phydm_hwconfig.c	28;"	d	file:
-READ_AND_CONFIG_TC	hal/phydm/phydm_hwconfig.c	29;"	d	file:
-READ_FIRMWARE	hal/phydm/phydm_hwconfig.c	48;"	d	file:
-READ_FIRMWARE	hal/phydm/phydm_hwconfig.c	55;"	d	file:
-READ_FIRMWARE_MP	hal/phydm/phydm_hwconfig.c	44;"	d	file:
-READ_FIRMWARE_TC	hal/phydm/phydm_hwconfig.c	45;"	d	file:
-READ_NEXT_PAIR	hal/phydm/phydm_types.h	254;"	d
-READ_REG	include/rtw_mp.h	/^	READ_REG,$/;"	e	enum:__anon65
-READ_RF	include/rtw_mp.h	/^	READ_RF,$/;"	e	enum:__anon65
-REALTEK_96B_IE	core/rtw_wlan_util.c	/^unsigned char REALTEK_96B_IE[] = {0x00, 0xe0, 0x4c, 0x02, 0x01, 0x20};$/;"	v
-REALTEK_OUI	core/rtw_wlan_util.c	/^unsigned char REALTEK_OUI[] = {0x00, 0xe0, 0x4c};$/;"	v
-REALTEK_POWER_SEQUENCE_8188F	include/Hal8188FPwrSeq.h	2;"	d
-REALTEK_POWER_SEQUENCE_8192E	include/Hal8192EPwrSeq.h	2;"	d
-REALTEK_POWER_SEQUENCE_8703B	include/Hal8703BPwrSeq.h	2;"	d
-REALTEK_POWER_SEQUENCE_8723B	include/Hal8723BPwrSeq.h	2;"	d
-REALTEK_POWER_SEQUENCE_8723D	include/Hal8723DPwrSeq.h	2;"	d
-REALTEK_POWER_SEQUENCE_8821	include/Hal8821APwrSeq.h	2;"	d
-REALTEK_USB_IN_INT_EP_IDX	include/usb_ops.h	28;"	d
-REALTEK_USB_VENQT_CMD_IDX	include/usb_ops.h	27;"	d
-REALTEK_USB_VENQT_CMD_REQ	include/usb_ops.h	26;"	d
-REALTEK_USB_VENQT_READ	include/usb_ops.h	24;"	d
-REALTEK_USB_VENQT_WRITE	include/usb_ops.h	25;"	d
-REASSOC_LIMIT	include/rtw_mlme_ext.h	39;"	d
-REASSOC_TO	include/rtw_mlme_ext.h	32;"	d
-REAUTH_LIMIT	include/rtw_mlme_ext.h	38;"	d
-REAUTH_TO	include/rtw_mlme_ext.h	31;"	d
-RECVBUFF_ALIGN_SZ	include/rtw_recv.h	291;"	d
-RECVFRAME_HDR_ALIGN	include/rtw_recv.h	68;"	d
-RECV_ALIVE	include/rtw_pwrctrl.h	40;"	d
-RECV_BLK_CNT	include/rtl8188e_recv.h	24;"	d
-RECV_BLK_CNT	include/rtl8703b_recv.h	24;"	d
-RECV_BLK_CNT	include/rtl8723b_recv.h	24;"	d
-RECV_BLK_CNT	include/rtl8723d_recv.h	24;"	d
-RECV_BLK_SZ	include/rtl8188e_recv.h	23;"	d
-RECV_BLK_SZ	include/rtl8703b_recv.h	23;"	d
-RECV_BLK_SZ	include/rtl8723b_recv.h	23;"	d
-RECV_BLK_SZ	include/rtl8723d_recv.h	23;"	d
-RECV_BLK_TH	include/rtl8188e_recv.h	25;"	d
-RECV_BLK_TH	include/rtl8703b_recv.h	25;"	d
-RECV_BLK_TH	include/rtl8723b_recv.h	25;"	d
-RECV_BLK_TH	include/rtl8723d_recv.h	25;"	d
-RECV_BULK_IN_ADDR	include/usb_ops_linux.h	29;"	d
-RECV_INT_IN_ADDR	include/usb_ops_linux.h	30;"	d
-REGSTY_BW_2G	include/drv_types.h	433;"	d
-REGSTY_BW_5G	include/drv_types.h	434;"	d
-REGSTY_IS_11AC_AUTO	include/drv_types.h	441;"	d
-REGSTY_IS_11AC_ENABLE	include/drv_types.h	440;"	d
-REGSTY_IS_BW_2G_SUPPORT	include/drv_types.h	435;"	d
-REGSTY_IS_BW_5G_SUPPORT	include/drv_types.h	436;"	d
-REGULATION_ETSI	hal/phydm/phydm_adaptivity.h	/^	REGULATION_ETSI = 2,$/;"	e	enum:_tag_PhyDM_REGULATION_Type
-REGULATION_FCC	hal/phydm/phydm_adaptivity.h	/^	REGULATION_FCC = 0,$/;"	e	enum:_tag_PhyDM_REGULATION_Type
-REGULATION_MKK	hal/phydm/phydm_adaptivity.h	/^	REGULATION_MKK = 1,$/;"	e	enum:_tag_PhyDM_REGULATION_Type
-REGULATION_TXPWR_LMT	include/hal_com_phycfg.h	/^} REGULATION_TXPWR_LMT;$/;"	t	typeref:enum:_REGULATION_TXPWR_LMT
-REGULATION_WW	hal/phydm/phydm_adaptivity.h	/^	REGULATION_WW = 3,	$/;"	e	enum:_tag_PhyDM_REGULATION_Type
-REG_32K_CTRL	include/hal_com_reg.h	151;"	d
-REG_8051FW_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	69;"	d
-REG_8051FW_CTRL_8723D	include/rtl8723d_spec.h	73;"	d
-REG_8051FW_CTRL_8814A	include/rtl8814a_spec.h	75;"	d
-REG_9346CR	include/hal_com_reg.h	48;"	d
-REG_9346CR_8703B	include/rtl8703b_spec.h	36;"	d
-REG_9346CR_8723D	include/rtl8723d_spec.h	36;"	d
-REG_ACKTO	include/hal_com_reg.h	428;"	d
-REG_ACKTO_8703B	include/rtl8703b_spec.h	309;"	d
-REG_ACKTO_8723D	hal/phydm/rtl8723d/hal8723dreg.h	396;"	d
-REG_ACKTO_8723D	include/rtl8723d_spec.h	345;"	d
-REG_ACKTO_8814A	include/rtl8814a_spec.h	405;"	d
-REG_ACLK_MON	include/hal_com_reg.h	71;"	d
-REG_ACLK_MON_8703B	include/rtl8703b_spec.h	51;"	d
-REG_ACLK_MON_8723D	hal/phydm/rtl8723d/hal8723dreg.h	50;"	d
-REG_ACLK_MON_8723D	include/rtl8723d_spec.h	51;"	d
-REG_ACLK_MON_8814A	include/rtl8814a_spec.h	55;"	d
-REG_ACMHWCTRL	include/hal_com_reg.h	388;"	d
-REG_ACMHWCTRL_8703B	include/rtl8703b_spec.h	283;"	d
-REG_ACMHWCTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	360;"	d
-REG_ACMHWCTRL_8723D	include/rtl8723d_spec.h	319;"	d
-REG_ACMHWCTRL_8814A	include/rtl8814a_spec.h	381;"	d
-REG_ACQ_STOP_8814A	include/rtl8814a_spec.h	268;"	d
-REG_ADDR_FORMAT	include/gspi_ops.h	114;"	d
-REG_AFE_CTRL1_8192E	include/rtl8192e_spec.h	41;"	d
-REG_AFE_CTRL1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	43;"	d
-REG_AFE_CTRL1_8814A	include/rtl8814a_spec.h	48;"	d
-REG_AFE_CTRL2_8192E	include/rtl8192e_spec.h	42;"	d
-REG_AFE_CTRL2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	44;"	d
-REG_AFE_CTRL2_8814A	include/rtl8814a_spec.h	49;"	d
-REG_AFE_CTRL3_8192E	include/rtl8192e_spec.h	43;"	d
-REG_AFE_CTRL3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	45;"	d
-REG_AFE_CTRL3_8814A	include/rtl8814a_spec.h	50;"	d
-REG_AFE_CTRL4_8192E	include/rtl8192e_spec.h	49;"	d
-REG_AFE_CTRL4_8723D	hal/phydm/rtl8723d/hal8723dreg.h	67;"	d
-REG_AFE_CTRL4_8814A	include/rtl8814a_spec.h	74;"	d
-REG_AFE_CTRL_4_8188F	include/rtl8188f_spec.h	36;"	d
-REG_AFE_CTRL_4_8703B	include/rtl8703b_spec.h	71;"	d
-REG_AFE_CTRL_4_8723B	include/rtl8723b_spec.h	36;"	d
-REG_AFE_CTRL_4_8723D	include/rtl8723d_spec.h	71;"	d
-REG_AFE_LDO_CTRL	include/hal_com_reg.h	63;"	d
-REG_AFE_MISC	include/hal_com_reg.h	51;"	d
-REG_AFE_MISC_8703B	include/rtl8703b_spec.h	38;"	d
-REG_AFE_MISC_8723D	include/rtl8723d_spec.h	38;"	d
-REG_AFE_PLL_CTRL	include/hal_com_reg.h	64;"	d
-REG_AFE_PLL_CTRL	include/rtl8822b_hal.h	34;"	d
-REG_AFE_PLL_CTRL_8703B	include/rtl8703b_spec.h	45;"	d
-REG_AFE_PLL_CTRL_8723D	include/rtl8723d_spec.h	45;"	d
-REG_AFE_PLL_CTRL_8812A	include/rtl8812a_spec.h	39;"	d
-REG_AFE_XTAL_CTRL	include/hal_com_reg.h	62;"	d
-REG_AFE_XTAL_CTRL	include/rtl8822b_hal.h	33;"	d
-REG_AFE_XTAL_CTRL_8703B	include/rtl8703b_spec.h	44;"	d
-REG_AFE_XTAL_CTRL_8723D	include/rtl8723d_spec.h	44;"	d
-REG_AFE_XTAL_CTRL_EXT	include/hal_com_reg.h	90;"	d
-REG_AGGLEN_LMT	include/hal_com_reg.h	277;"	d
-REG_AGGR_BREAK_TIME	include/hal_com_reg.h	345;"	d
-REG_AGGR_BREAK_TIME_8703B	include/rtl8703b_spec.h	241;"	d
-REG_AGGR_BREAK_TIME_8723D	hal/phydm/rtl8723d/hal8723dreg.h	315;"	d
-REG_AGGR_BREAK_TIME_8723D	include/rtl8723d_spec.h	277;"	d
-REG_AGGR_BREAK_TIME_8814A	include/rtl8814a_spec.h	338;"	d
-REG_AMPDU_BURST_MODE_8188F	include/rtl8188f_spec.h	116;"	d
-REG_AMPDU_BURST_MODE_8192E	include/rtl8192e_spec.h	186;"	d
-REG_AMPDU_BURST_MODE_8703B	include/rtl8703b_spec.h	214;"	d
-REG_AMPDU_BURST_MODE_8723B	include/rtl8723b_spec.h	116;"	d
-REG_AMPDU_BURST_MODE_8723D	include/rtl8723d_spec.h	250;"	d
-REG_AMPDU_BURST_MODE_8812	include/rtl8812a_spec.h	140;"	d
-REG_AMPDU_MAX_LENGTH_8192E	include/rtl8192e_spec.h	175;"	d
-REG_AMPDU_MAX_LENGTH_8703B	include/rtl8703b_spec.h	201;"	d
-REG_AMPDU_MAX_LENGTH_8723D	hal/phydm/rtl8723d/hal8723dreg.h	249;"	d
-REG_AMPDU_MAX_LENGTH_8723D	include/rtl8723d_spec.h	237;"	d
-REG_AMPDU_MAX_LENGTH_8812	include/rtl8812a_spec.h	129;"	d
-REG_AMPDU_MAX_LENGTH_8814A	include/rtl8814a_spec.h	267;"	d
-REG_AMPDU_MAX_TIME_8192E	include/rtl8192e_spec.h	172;"	d
-REG_AMPDU_MAX_TIME_8703B	include/rtl8703b_spec.h	198;"	d
-REG_AMPDU_MAX_TIME_8723D	hal/phydm/rtl8723d/hal8723dreg.h	247;"	d
-REG_AMPDU_MAX_TIME_8723D	include/rtl8723d_spec.h	234;"	d
-REG_AMPDU_MAX_TIME_8812	include/rtl8812a_spec.h	126;"	d
-REG_AMPDU_MAX_TIME_8814A	include/rtl8814a_spec.h	265;"	d
-REG_AMPDU_MIN_SPACE	include/hal_com_reg.h	278;"	d
-REG_APE_PLL_CTRL_EXT	include/hal_com_reg.h	66;"	d
-REG_APSD_CTRL	include/hal_com_reg.h	407;"	d
-REG_APS_FSMCO	include/hal_com_reg.h	45;"	d
-REG_APS_FSMCO_8703B	include/rtl8703b_spec.h	34;"	d
-REG_APS_FSMCO_8723D	include/rtl8723d_spec.h	34;"	d
-REG_ARFR0	include/hal_com_reg.h	270;"	d
-REG_ARFR0_8192E	include/rtl8192e_spec.h	169;"	d
-REG_ARFR0_8703B	include/rtl8703b_spec.h	195;"	d
-REG_ARFR0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	243;"	d
-REG_ARFR0_8723D	include/rtl8723d_spec.h	231;"	d
-REG_ARFR0_8812	include/rtl8812a_spec.h	123;"	d
-REG_ARFR0_8814A	include/rtl8814a_spec.h	262;"	d
-REG_ARFR1	include/hal_com_reg.h	271;"	d
-REG_ARFR1_8192E	include/rtl8192e_spec.h	170;"	d
-REG_ARFR1_8703B	include/rtl8703b_spec.h	196;"	d
-REG_ARFR1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	244;"	d
-REG_ARFR1_8723D	include/rtl8723d_spec.h	232;"	d
-REG_ARFR1_8812	include/rtl8812a_spec.h	124;"	d
-REG_ARFR1_8814A	include/rtl8814a_spec.h	263;"	d
-REG_ARFR2	include/hal_com_reg.h	272;"	d
-REG_ARFR2_8192E	include/rtl8192e_spec.h	183;"	d
-REG_ARFR2_8812	include/rtl8812a_spec.h	137;"	d
-REG_ARFR2_8814A	include/rtl8814a_spec.h	291;"	d
-REG_ARFR3	include/hal_com_reg.h	273;"	d
-REG_ARFR3_8192E	include/rtl8192e_spec.h	184;"	d
-REG_ARFR3_8812	include/rtl8812a_spec.h	138;"	d
-REG_ARFR3_8814A	include/rtl8814a_spec.h	292;"	d
-REG_ARFR4_8814A	include/rtl8814a_spec.h	293;"	d
-REG_ARFR5_8814A	include/rtl8814a_spec.h	294;"	d
-REG_ASSOCIATED_BFMEE_SEL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	429;"	d
-REG_ASSOCIATED_BFMEE_SEL_8814A	include/rtl8814a_spec.h	449;"	d
-REG_ASSOCIATED_BFMER0_INFO_8723D	hal/phydm/rtl8723d/hal8723dreg.h	420;"	d
-REG_ASSOCIATED_BFMER0_INFO_8814A	include/rtl8814a_spec.h	430;"	d
-REG_ASSOCIATED_BFMER1_INFO_8723D	hal/phydm/rtl8723d/hal8723dreg.h	421;"	d
-REG_ASSOCIATED_BFMER1_INFO_8814A	include/rtl8814a_spec.h	431;"	d
-REG_ATIMWND	include/hal_com_reg.h	376;"	d
-REG_ATIMWND_1	include/hal_com_reg.h	383;"	d
-REG_ATIMWND_8703B	include/rtl8703b_spec.h	272;"	d
-REG_ATIMWND_8723D	hal/phydm/rtl8723d/hal8723dreg.h	346;"	d
-REG_ATIMWND_8723D	include/rtl8723d_spec.h	308;"	d
-REG_ATIMWND_8814A	include/rtl8814a_spec.h	369;"	d
-REG_AUTO_LLT	include/hal_com_reg.h	180;"	d
-REG_AUTO_LLT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	143;"	d
-REG_AUTO_LLT_8814A	include/rtl8814a_spec.h	138;"	d
-REG_BACAMCMD	include/hal_com_reg.h	466;"	d
-REG_BACAMCONTENT	include/hal_com_reg.h	467;"	d
-REG_BAR_MODE_CTRL	include/hal_com_reg.h	306;"	d
-REG_BAR_MODE_CTRL_8703B	include/rtl8703b_spec.h	222;"	d
-REG_BAR_MODE_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	268;"	d
-REG_BAR_MODE_CTRL_8723D	include/rtl8723d_spec.h	258;"	d
-REG_BAR_MODE_CTRL_8814A	include/rtl8814a_spec.h	309;"	d
-REG_BASIC_CFEND_RATE_8814A	include/rtl8814a_spec.h	282;"	d
-REG_BB_PAD_CTRL	include/rtl8188e_spec.h	37;"	d
-REG_BB_TXBF_ANT_SET_BF0	include/rtl8814a_spec.h	456;"	d
-REG_BB_TXBF_ANT_SET_BF0_8814A	include/Hal8814PhyReg.h	560;"	d
-REG_BB_TXBF_ANT_SET_BF0_8822B	include/rtl8822b_hal.h	107;"	d
-REG_BB_TXBF_ANT_SET_BF1	include/rtl8814a_spec.h	455;"	d
-REG_BB_TXBF_ANT_SET_BF1_8814A	include/Hal8814PhyReg.h	559;"	d
-REG_BB_TXBF_ANT_SET_BF1_8822B	include/rtl8822b_hal.h	106;"	d
-REG_BB_TX_PATH_SEL_1_8814A	include/Hal8814PhyReg.h	553;"	d
-REG_BB_TX_PATH_SEL_1_8822B	include/rtl8822b_hal.h	102;"	d
-REG_BB_TX_PATH_SEL_2_8814A	include/Hal8814PhyReg.h	554;"	d
-REG_BB_TX_PATH_SEL_2_8822B	include/rtl8822b_hal.h	103;"	d
-REG_BCNDMATIM	include/hal_com_reg.h	375;"	d
-REG_BCNDMATIM_8703B	include/rtl8703b_spec.h	271;"	d
-REG_BCNDMATIM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	345;"	d
-REG_BCNDMATIM_8723D	include/rtl8723d_spec.h	307;"	d
-REG_BCNDMATIM_8814A	include/rtl8814a_spec.h	368;"	d
-REG_BCNQ1_BDNY	include/hal_com_reg.h	275;"	d
-REG_BCNQ1_BDNY_8192E	include/rtl8192e_spec.h	173;"	d
-REG_BCNQ1_BDNY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	248;"	d
-REG_BCNQ2_BDNY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	246;"	d
-REG_BCNQ_BDNY	include/hal_com_reg.h	261;"	d
-REG_BCNQ_BDNY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	233;"	d
-REG_BCNQ_DESA	include/hal_com_reg.h	201;"	d
-REG_BCNQ_DESA_8188F	include/rtl8188f_spec.h	84;"	d
-REG_BCNQ_DESA_8703B	include/rtl8703b_spec.h	149;"	d
-REG_BCNQ_DESA_8723B	include/rtl8723b_spec.h	84;"	d
-REG_BCNQ_INFO	include/hal_com_reg.h	256;"	d
-REG_BCNQ_INFORMATION_8703B	include/rtl8703b_spec.h	180;"	d
-REG_BCNQ_INFORMATION_8723D	include/rtl8723d_spec.h	216;"	d
-REG_BCNQ_INFORMATION_8814A	include/rtl8814a_spec.h	247;"	d
-REG_BCNQ_TXBD_DESA_8192E	include/rtl8192e_spec.h	108;"	d
-REG_BCNQ_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	168;"	d
-REG_BCNQ_TXBD_DESA_8723D	include/rtl8723d_spec.h	148;"	d
-REG_BCNQ_TXBD_DESA_8814A	include/rtl8814a_spec.h	176;"	d
-REG_BCNTCFG	include/hal_com_reg.h	339;"	d
-REG_BCNTCFG_8703B	include/rtl8703b_spec.h	236;"	d
-REG_BCNTCFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	310;"	d
-REG_BCNTCFG_8723D	include/rtl8723d_spec.h	272;"	d
-REG_BCNTCFG_8814A	include/rtl8814a_spec.h	333;"	d
-REG_BCN_CTRL	include/hal_com_reg.h	369;"	d
-REG_BCN_CTRL_1	include/hal_com_reg.h	370;"	d
-REG_BCN_CTRL_1	include/rtl8822b_hal.h	41;"	d
-REG_BCN_CTRL_1_8703B	include/rtl8703b_spec.h	266;"	d
-REG_BCN_CTRL_1_8723D	include/rtl8723d_spec.h	302;"	d
-REG_BCN_CTRL_1_8814A	include/rtl8814a_spec.h	363;"	d
-REG_BCN_CTRL_8703B	include/rtl8703b_spec.h	265;"	d
-REG_BCN_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	339;"	d
-REG_BCN_CTRL_8723D	include/rtl8723d_spec.h	301;"	d
-REG_BCN_CTRL_8814A	include/rtl8814a_spec.h	362;"	d
-REG_BCN_INTERVAL	include/hal_com_reg.h	373;"	d
-REG_BCN_INTERVAL_8703B	include/rtl8703b_spec.h	269;"	d
-REG_BCN_INTERVAL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	343;"	d
-REG_BCN_INTERVAL_8723D	include/rtl8723d_spec.h	305;"	d
-REG_BCN_MAX_ERR	include/hal_com_reg.h	378;"	d
-REG_BCN_MAX_ERR_8703B	include/rtl8703b_spec.h	274;"	d
-REG_BCN_MAX_ERR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	348;"	d
-REG_BCN_MAX_ERR_8723D	include/rtl8723d_spec.h	310;"	d
-REG_BCN_MAX_ERR_8814A	include/rtl8814a_spec.h	371;"	d
-REG_BCN_PREDL_ITV_8814A	include/rtl8814a_spec.h	380;"	d
-REG_BCN_PSR_RPT	include/hal_com_reg.h	490;"	d
-REG_BCN_PSR_RPT_8703B	include/rtl8703b_spec.h	333;"	d
-REG_BCN_PSR_RPT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	418;"	d
-REG_BCN_PSR_RPT_8723D	include/rtl8723d_spec.h	369;"	d
-REG_BCN_PSR_RPT_8814A	include/rtl8814a_spec.h	427;"	d
-REG_BD_RW_PTR_CLR_8723D	include/rtl8723d_spec.h	178;"	d
-REG_BEQ_DESA	include/hal_com_reg.h	206;"	d
-REG_BEQ_DESA_8188F	include/rtl8188f_spec.h	89;"	d
-REG_BEQ_DESA_8703B	include/rtl8703b_spec.h	154;"	d
-REG_BEQ_DESA_8723B	include/rtl8723b_spec.h	89;"	d
-REG_BEQ_INFO	include/hal_com_reg.h	245;"	d
-REG_BEQ_INFORMATION_8703B	include/rtl8703b_spec.h	176;"	d
-REG_BEQ_INFORMATION_8723D	include/rtl8723d_spec.h	212;"	d
-REG_BEQ_INFORMATION_8814A	include/rtl8814a_spec.h	243;"	d
-REG_BEQ_TXBD_DESA_8192E	include/rtl8192e_spec.h	112;"	d
-REG_BEQ_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	172;"	d
-REG_BEQ_TXBD_DESA_8723D	include/rtl8723d_spec.h	152;"	d
-REG_BEQ_TXBD_DESA_8814A	include/rtl8814a_spec.h	180;"	d
-REG_BEQ_TXBD_IDX_8192E	include/rtl8192e_spec.h	142;"	d
-REG_BEQ_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	202;"	d
-REG_BEQ_TXBD_IDX_8723D	include/rtl8723d_spec.h	183;"	d
-REG_BEQ_TXBD_IDX_8814A	include/rtl8814a_spec.h	210;"	d
-REG_BEQ_TXBD_NUM_8192E	include/rtl8192e_spec.h	127;"	d
-REG_BEQ_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	187;"	d
-REG_BEQ_TXBD_NUM_8723D	include/rtl8723d_spec.h	167;"	d
-REG_BEQ_TXBD_NUM_8814A	include/rtl8814a_spec.h	195;"	d
-REG_BFMEE_SEL_8192E	include/rtl8192e_spec.h	216;"	d
-REG_BFMEE_SEL_8703B	include/rtl8703b_spec.h	344;"	d
-REG_BFMEE_SEL_8723D	include/rtl8723d_spec.h	380;"	d
-REG_BFMEE_SEL_8812A	include/rtl8812a_spec.h	171;"	d
-REG_BFMER0_INFO_8192E	include/rtl8192e_spec.h	209;"	d
-REG_BFMER0_INFO_8703B	include/rtl8703b_spec.h	335;"	d
-REG_BFMER0_INFO_8723D	include/rtl8723d_spec.h	371;"	d
-REG_BFMER0_INFO_8812A	include/rtl8812a_spec.h	164;"	d
-REG_BFMER1_INFO_8192E	include/rtl8192e_spec.h	210;"	d
-REG_BFMER1_INFO_8703B	include/rtl8703b_spec.h	336;"	d
-REG_BFMER1_INFO_8723D	include/rtl8723d_spec.h	372;"	d
-REG_BFMER1_INFO_8812A	include/rtl8812a_spec.h	165;"	d
-REG_BIST_ROM_RPT	include/hal_com_reg.h	101;"	d
-REG_BIST_RPT	include/hal_com_reg.h	100;"	d
-REG_BIST_SCAN	include/hal_com_reg.h	99;"	d
-REG_BKQ_DESA	include/hal_com_reg.h	207;"	d
-REG_BKQ_DESA_8188F	include/rtl8188f_spec.h	90;"	d
-REG_BKQ_DESA_8703B	include/rtl8703b_spec.h	155;"	d
-REG_BKQ_DESA_8723B	include/rtl8723b_spec.h	90;"	d
-REG_BKQ_INFO	include/hal_com_reg.h	246;"	d
-REG_BKQ_INFORMATION_8703B	include/rtl8703b_spec.h	177;"	d
-REG_BKQ_INFORMATION_8723D	include/rtl8723d_spec.h	213;"	d
-REG_BKQ_INFORMATION_8814A	include/rtl8814a_spec.h	244;"	d
-REG_BKQ_TXBD_DESA_8192E	include/rtl8192e_spec.h	113;"	d
-REG_BKQ_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	173;"	d
-REG_BKQ_TXBD_DESA_8723D	include/rtl8723d_spec.h	153;"	d
-REG_BKQ_TXBD_DESA_8814A	include/rtl8814a_spec.h	181;"	d
-REG_BKQ_TXBD_IDX_8192E	include/rtl8192e_spec.h	143;"	d
-REG_BKQ_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	203;"	d
-REG_BKQ_TXBD_IDX_8723D	include/rtl8723d_spec.h	184;"	d
-REG_BKQ_TXBD_IDX_8814A	include/rtl8814a_spec.h	211;"	d
-REG_BKQ_TXBD_NUM_8192E	include/rtl8192e_spec.h	128;"	d
-REG_BKQ_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	188;"	d
-REG_BKQ_TXBD_NUM_8723D	include/rtl8723d_spec.h	168;"	d
-REG_BKQ_TXBD_NUM_8814A	include/rtl8814a_spec.h	196;"	d
-REG_BSSID	include/hal_com_reg.h	416;"	d
-REG_BSSID1	include/hal_com_reg.h	495;"	d
-REG_BSSID1_8703B	include/rtl8703b_spec.h	343;"	d
-REG_BSSID1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	428;"	d
-REG_BSSID1_8723D	include/rtl8723d_spec.h	379;"	d
-REG_BSSID1_8814A	include/rtl8814a_spec.h	438;"	d
-REG_BSSID2	include/hal_com_reg.h	498;"	d
-REG_BSSID2_8814A	include/rtl8814a_spec.h	441;"	d
-REG_BSSID3	include/hal_com_reg.h	501;"	d
-REG_BSSID3_8814A	include/rtl8814a_spec.h	444;"	d
-REG_BSSID4	include/hal_com_reg.h	504;"	d
-REG_BSSID4_8814A	include/rtl8814a_spec.h	447;"	d
-REG_BSSID_8703B	include/rtl8703b_spec.h	299;"	d
-REG_BSSID_8723D	hal/phydm/rtl8723d/hal8723dreg.h	388;"	d
-REG_BSSID_8723D	include/rtl8723d_spec.h	335;"	d
-REG_BSSID_8814A	include/rtl8814a_spec.h	397;"	d
-REG_BT_COEX_TABLE	include/hal_com_reg.h	491;"	d
-REG_BT_COEX_TABLE_8703B	include/rtl8703b_spec.h	334;"	d
-REG_BT_COEX_TABLE_8723D	hal/phydm/rtl8723d/hal8723dreg.h	419;"	d
-REG_BT_COEX_TABLE_8723D	include/rtl8723d_spec.h	370;"	d
-REG_BT_COEX_TABLE_8814A	include/rtl8814a_spec.h	428;"	d
-REG_BT_WIFI_ANTENNA_SWITCH_8188F	include/rtl8188f_spec.h	33;"	d
-REG_BT_WIFI_ANTENNA_SWITCH_8723B	include/rtl8723b_spec.h	33;"	d
-REG_BWOPMODE	include/hal_com_reg.h	408;"	d
-REG_C2HEVT_CLEAR	include/hal_com_reg.h	153;"	d
-REG_C2HEVT_CLEAR	include/rtl8822b_hal.h	40;"	d
-REG_C2HEVT_CLEAR_8703B	include/rtl8703b_spec.h	98;"	d
-REG_C2HEVT_CLEAR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	116;"	d
-REG_C2HEVT_CLEAR_8723D	include/rtl8723d_spec.h	98;"	d
-REG_C2HEVT_CLEAR_8814A	include/rtl8814a_spec.h	115;"	d
-REG_C2HEVT_CMD_ID_8188F	include/rtl8188f_spec.h	52;"	d
-REG_C2HEVT_CMD_ID_8703B	include/rtl8703b_spec.h	93;"	d
-REG_C2HEVT_CMD_ID_8723B	include/rtl8723b_spec.h	52;"	d
-REG_C2HEVT_CMD_ID_8723D	include/rtl8723d_spec.h	94;"	d
-REG_C2HEVT_CMD_LEN_8188F	include/rtl8188f_spec.h	53;"	d
-REG_C2HEVT_CMD_LEN_8703B	include/rtl8703b_spec.h	96;"	d
-REG_C2HEVT_CMD_LEN_8723B	include/rtl8723b_spec.h	53;"	d
-REG_C2HEVT_CMD_LEN_8723D	include/rtl8723d_spec.h	97;"	d
-REG_C2HEVT_CMD_LEN_88XX	hal/phydm/rtl8723d/hal8723dreg.h	115;"	d
-REG_C2HEVT_CMD_LEN_88XX	include/rtl8192e_spec.h	73;"	d
-REG_C2HEVT_CMD_LEN_88XX	include/rtl8703b_spec.h	97;"	d
-REG_C2HEVT_CMD_LEN_88XX	include/rtl8812a_spec.h	70;"	d
-REG_C2HEVT_CMD_SEQ_88XX	hal/phydm/rtl8723d/hal8723dreg.h	113;"	d
-REG_C2HEVT_CMD_SEQ_88XX	include/rtl8192e_spec.h	71;"	d
-REG_C2HEVT_CMD_SEQ_88XX	include/rtl8703b_spec.h	94;"	d
-REG_C2HEVT_CMD_SEQ_88XX	include/rtl8723d_spec.h	95;"	d
-REG_C2HEVT_CMD_SEQ_88XX	include/rtl8812a_spec.h	68;"	d
-REG_C2HEVT_MSG_NORMAL	include/hal_com_reg.h	152;"	d
-REG_C2HEVT_MSG_NORMAL	include/rtl8822b_hal.h	39;"	d
-REG_C2HEVT_MSG_NORMAL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	112;"	d
-REG_C2HEVT_MSG_NORMAL_8814A	include/rtl8814a_spec.h	114;"	d
-REG_C2hEVT_CMD_CONTENT_88XX	hal/phydm/rtl8723d/hal8723dreg.h	114;"	d
-REG_C2hEVT_CMD_CONTENT_88XX	include/rtl8192e_spec.h	72;"	d
-REG_C2hEVT_CMD_CONTENT_88XX	include/rtl8703b_spec.h	95;"	d
-REG_C2hEVT_CMD_CONTENT_88XX	include/rtl8723d_spec.h	96;"	d
-REG_C2hEVT_CMD_CONTENT_88XX	include/rtl8812a_spec.h	69;"	d
-REG_CAL_TIMER	include/hal_com_reg.h	70;"	d
-REG_CAL_TIMER_8703B	include/rtl8703b_spec.h	50;"	d
-REG_CAL_TIMER_8723D	hal/phydm/rtl8723d/hal8723dreg.h	49;"	d
-REG_CAL_TIMER_8723D	include/rtl8723d_spec.h	50;"	d
-REG_CAL_TIMER_8814A	include/rtl8814a_spec.h	54;"	d
-REG_CAMCMD	include/hal_com_reg.h	474;"	d
-REG_CAMCMD_8703B	include/rtl8703b_spec.h	317;"	d
-REG_CAMCMD_8723D	hal/phydm/rtl8723d/hal8723dreg.h	404;"	d
-REG_CAMCMD_8723D	include/rtl8723d_spec.h	353;"	d
-REG_CAMCMD_8814A	include/rtl8814a_spec.h	413;"	d
-REG_CAMDBG	include/hal_com_reg.h	477;"	d
-REG_CAMDBG_8703B	include/rtl8703b_spec.h	320;"	d
-REG_CAMDBG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	407;"	d
-REG_CAMDBG_8723D	include/rtl8723d_spec.h	356;"	d
-REG_CAMDBG_8814A	include/rtl8814a_spec.h	416;"	d
-REG_CAMREAD	include/hal_com_reg.h	476;"	d
-REG_CAMREAD_8703B	include/rtl8703b_spec.h	319;"	d
-REG_CAMREAD_8723D	hal/phydm/rtl8723d/hal8723dreg.h	406;"	d
-REG_CAMREAD_8723D	include/rtl8723d_spec.h	355;"	d
-REG_CAMREAD_8814A	include/rtl8814a_spec.h	415;"	d
-REG_CAMWRITE	include/hal_com_reg.h	475;"	d
-REG_CAMWRITE_8703B	include/rtl8703b_spec.h	318;"	d
-REG_CAMWRITE_8723D	hal/phydm/rtl8723d/hal8723dreg.h	405;"	d
-REG_CAMWRITE_8723D	include/rtl8723d_spec.h	354;"	d
-REG_CAMWRITE_8814A	include/rtl8814a_spec.h	414;"	d
-REG_CCK_CHECK	include/hal_com_reg.h	274;"	d
-REG_CCK_CHECK_8192E	include/rtl8192e_spec.h	171;"	d
-REG_CCK_CHECK_8703B	include/rtl8703b_spec.h	197;"	d
-REG_CCK_CHECK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	245;"	d
-REG_CCK_CHECK_8723D	include/rtl8723d_spec.h	233;"	d
-REG_CCK_CHECK_8812	include/rtl8812a_spec.h	125;"	d
-REG_CCK_CHECK_8814A	include/rtl8814a_spec.h	264;"	d
-REG_CMDQ_INFO_8814A	include/rtl8814a_spec.h	274;"	d
-REG_CPU_MGQ_INFORMATION	include/hal_com_reg.h	258;"	d
-REG_CPU_MGQ_INFORMATION_8814A	include/rtl8814a_spec.h	249;"	d
-REG_CPWM	include/hal_com_reg.h	132;"	d
-REG_CPWM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	95;"	d
-REG_CPWM_8814A	include/rtl8814a_spec.h	96;"	d
-REG_CR	include/hal_com_reg.h	121;"	d
-REG_CR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	89;"	d
-REG_CR_8812A	include/rtl8812a_spec.h	61;"	d
-REG_CR_8814A	include/rtl8814a_spec.h	89;"	d
-REG_CR_EXT	include/hal_com_reg.h	507;"	d
-REG_CSI_RPT_PARAM_BW20_8192E	include/rtl8192e_spec.h	211;"	d
-REG_CSI_RPT_PARAM_BW20_8703B	include/rtl8703b_spec.h	337;"	d
-REG_CSI_RPT_PARAM_BW20_8723D	hal/phydm/rtl8723d/hal8723dreg.h	422;"	d
-REG_CSI_RPT_PARAM_BW20_8723D	include/rtl8723d_spec.h	373;"	d
-REG_CSI_RPT_PARAM_BW20_8812A	include/rtl8812a_spec.h	166;"	d
-REG_CSI_RPT_PARAM_BW20_8814A	include/rtl8814a_spec.h	432;"	d
-REG_CSI_RPT_PARAM_BW40_8192E	include/rtl8192e_spec.h	212;"	d
-REG_CSI_RPT_PARAM_BW40_8703B	include/rtl8703b_spec.h	338;"	d
-REG_CSI_RPT_PARAM_BW40_8723D	hal/phydm/rtl8723d/hal8723dreg.h	423;"	d
-REG_CSI_RPT_PARAM_BW40_8723D	include/rtl8723d_spec.h	374;"	d
-REG_CSI_RPT_PARAM_BW40_8812A	include/rtl8812a_spec.h	167;"	d
-REG_CSI_RPT_PARAM_BW40_8814A	include/rtl8814a_spec.h	433;"	d
-REG_CSI_RPT_PARAM_BW80_8192E	include/rtl8192e_spec.h	213;"	d
-REG_CSI_RPT_PARAM_BW80_8703B	include/rtl8703b_spec.h	339;"	d
-REG_CSI_RPT_PARAM_BW80_8723D	hal/phydm/rtl8723d/hal8723dreg.h	424;"	d
-REG_CSI_RPT_PARAM_BW80_8723D	include/rtl8723d_spec.h	375;"	d
-REG_CSI_RPT_PARAM_BW80_8812A	include/rtl8812a_spec.h	168;"	d
-REG_CSI_RPT_PARAM_BW80_8814A	include/rtl8814a_spec.h	434;"	d
-REG_CTS2TO	include/hal_com_reg.h	429;"	d
-REG_CTS2TO_8703B	include/rtl8703b_spec.h	310;"	d
-REG_CTS2TO_8723D	hal/phydm/rtl8723d/hal8723dreg.h	397;"	d
-REG_CTS2TO_8723D	include/rtl8723d_spec.h	346;"	d
-REG_CTS2TO_8814A	include/rtl8814a_spec.h	406;"	d
-REG_CTWND_8192E	include/rtl8192e_spec.h	195;"	d
-REG_CTWND_8703B	include/rtl8703b_spec.h	278;"	d
-REG_CTWND_8723D	hal/phydm/rtl8723d/hal8723dreg.h	352;"	d
-REG_CTWND_8723D	include/rtl8723d_spec.h	314;"	d
-REG_CTWND_8812	include/rtl8812a_spec.h	150;"	d
-REG_CTWND_8814A	include/rtl8814a_spec.h	375;"	d
-REG_DARFRC	include/hal_com_reg.h	267;"	d
-REG_DARFRC_8703B	include/rtl8703b_spec.h	192;"	d
-REG_DARFRC_8723D	hal/phydm/rtl8723d/hal8723dreg.h	240;"	d
-REG_DARFRC_8723D	include/rtl8723d_spec.h	228;"	d
-REG_DARFRC_8814A	include/rtl8814a_spec.h	259;"	d
-REG_DATA_SC_8192E	include/rtl8192e_spec.h	178;"	d
-REG_DATA_SC_8703B	include/rtl8703b_spec.h	206;"	d
-REG_DATA_SC_8723D	hal/phydm/rtl8723d/hal8723dreg.h	254;"	d
-REG_DATA_SC_8723D	include/rtl8723d_spec.h	242;"	d
-REG_DATA_SC_8812	include/rtl8812a_spec.h	132;"	d
-REG_DATA_SC_8814A	include/rtl8814a_spec.h	284;"	d
-REG_DBG_8814A	include/rtl8814a_spec.h	235;"	d
-REG_DBG_SEL	include/hal_com_reg.h	215;"	d
-REG_DBG_SEL_8188F	include/rtl8188f_spec.h	99;"	d
-REG_DBG_SEL_8703B	include/rtl8703b_spec.h	164;"	d
-REG_DBG_SEL_8723B	include/rtl8723b_spec.h	99;"	d
-REG_DBG_SEL_V1_8814A	include/rtl8814a_spec.h	222;"	d
-REG_DBI_ADDR_8188F	include/rtl8188f_spec.h	94;"	d
-REG_DBI_ADDR_8703B	include/rtl8703b_spec.h	159;"	d
-REG_DBI_ADDR_8723B	include/rtl8723b_spec.h	94;"	d
-REG_DBI_ADDR_8812	include/rtl8812a_spec.h	108;"	d
-REG_DBI_CTRL	include/hal_com_reg.h	212;"	d
-REG_DBI_FLAG	include/hal_com_reg.h	213;"	d
-REG_DBI_FLAG_8188F	include/rtl8188f_spec.h	95;"	d
-REG_DBI_FLAG_8703B	include/rtl8703b_spec.h	160;"	d
-REG_DBI_FLAG_8723B	include/rtl8723b_spec.h	95;"	d
-REG_DBI_FLAG_8812	include/rtl8812a_spec.h	109;"	d
-REG_DBI_FLAG_V1_8192E	include/rtl8192e_spec.h	159;"	d
-REG_DBI_FLAG_V1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	219;"	d
-REG_DBI_FLAG_V1_8723D	include/rtl8723d_spec.h	200;"	d
-REG_DBI_FLAG_V1_8814A	include/rtl8814a_spec.h	232;"	d
-REG_DBI_RDATA	include/hal_com_reg.h	211;"	d
-REG_DBI_RDATA_8188F	include/rtl8188f_spec.h	93;"	d
-REG_DBI_RDATA_8703B	include/rtl8703b_spec.h	158;"	d
-REG_DBI_RDATA_8723B	include/rtl8723b_spec.h	93;"	d
-REG_DBI_RDATA_8812	include/rtl8812a_spec.h	107;"	d
-REG_DBI_RDATA_V1_8192E	include/rtl8192e_spec.h	158;"	d
-REG_DBI_RDATA_V1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	218;"	d
-REG_DBI_RDATA_V1_8723D	include/rtl8723d_spec.h	199;"	d
-REG_DBI_RDATA_V1_8814A	include/rtl8814a_spec.h	231;"	d
-REG_DBI_WDATA	include/hal_com_reg.h	210;"	d
-REG_DBI_WDATA_8188F	include/rtl8188f_spec.h	92;"	d
-REG_DBI_WDATA_8703B	include/rtl8703b_spec.h	157;"	d
-REG_DBI_WDATA_8723B	include/rtl8723b_spec.h	92;"	d
-REG_DBI_WDATA_8812	include/rtl8812a_spec.h	106;"	d
-REG_DBI_WDATA_V1_8192E	include/rtl8192e_spec.h	157;"	d
-REG_DBI_WDATA_V1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	217;"	d
-REG_DBI_WDATA_V1_8723D	include/rtl8723d_spec.h	198;"	d
-REG_DBI_WDATA_V1_8814A	include/rtl8814a_spec.h	230;"	d
-REG_DDMA_CH0CTRL	include/rtl8814a_spec.h	463;"	d
-REG_DDMA_CH0DA	include/rtl8814a_spec.h	462;"	d
-REG_DDMA_CH0SA	include/rtl8814a_spec.h	461;"	d
-REG_DDMA_CH1CTRL	include/rtl8814a_spec.h	466;"	d
-REG_DDMA_CH1DA	include/rtl8814a_spec.h	465;"	d
-REG_DDMA_CH1SA	include/rtl8814a_spec.h	464;"	d
-REG_DDMA_CH2CTRL	include/rtl8814a_spec.h	469;"	d
-REG_DDMA_CH2DA	include/rtl8814a_spec.h	468;"	d
-REG_DDMA_CH2SA	include/rtl8814a_spec.h	467;"	d
-REG_DDMA_CH3CTRL	include/rtl8814a_spec.h	472;"	d
-REG_DDMA_CH3DA	include/rtl8814a_spec.h	471;"	d
-REG_DDMA_CH3SA	include/rtl8814a_spec.h	470;"	d
-REG_DDMA_CH4CTRL	include/rtl8814a_spec.h	475;"	d
-REG_DDMA_CH4DA	include/rtl8814a_spec.h	474;"	d
-REG_DDMA_CH4SA	include/rtl8814a_spec.h	473;"	d
-REG_DDMA_CH5CTRL	include/rtl8814a_spec.h	478;"	d
-REG_DDMA_CH5DA	include/rtl8814a_spec.h	477;"	d
-REG_DDMA_CH5SA	include/rtl8814a_spec.h	476;"	d
-REG_DDMA_CHKSUM	include/rtl8814a_spec.h	481;"	d
-REG_DDMA_CHSTATUS	include/rtl8814a_spec.h	480;"	d
-REG_DDMA_INT_MSK	include/rtl8814a_spec.h	479;"	d
-REG_DDMA_MONITER	include/rtl8814a_spec.h	482;"	d
-REG_DIS_TXREQ_CLR	include/hal_com_reg.h	349;"	d
-REG_DIS_TXREQ_CLR_8703B	include/rtl8703b_spec.h	245;"	d
-REG_DIS_TXREQ_CLR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	319;"	d
-REG_DIS_TXREQ_CLR_8723D	include/rtl8723d_spec.h	281;"	d
-REG_DIS_TXREQ_CLR_8814A	include/rtl8814a_spec.h	342;"	d
-REG_DMC	include/hal_com_reg.h	395;"	d
-REG_DOMAIN_ID_FORMAT	include/gspi_ops.h	115;"	d
-REG_DROP_PKT_NUM_8814A	include/rtl8814a_spec.h	319;"	d
-REG_DRVERLYINT	include/hal_com_reg.h	374;"	d
-REG_DRVERLYINT_8703B	include/rtl8703b_spec.h	270;"	d
-REG_DRVERLYINT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	344;"	d
-REG_DRVERLYINT_8723D	include/rtl8723d_spec.h	306;"	d
-REG_DRVERLYINT_8814A	include/rtl8814a_spec.h	367;"	d
-REG_DUAL_TSF_RST	include/hal_com_reg.h	372;"	d
-REG_DUAL_TSF_RST_8703B	include/rtl8703b_spec.h	268;"	d
-REG_DUAL_TSF_RST_8723D	hal/phydm/rtl8723d/hal8723dreg.h	342;"	d
-REG_DUAL_TSF_RST_8723D	include/rtl8723d_spec.h	304;"	d
-REG_DUAL_TSF_RST_8814A	include/rtl8814a_spec.h	365;"	d
-REG_DUMMY	include/hal_com_reg.h	328;"	d
-REG_DWBCN0_CTRL	include/rtl8192e_spec.h	85;"	d
-REG_DWBCN0_CTRL_8703B	include/rtl8703b_spec.h	120;"	d
-REG_DWBCN0_CTRL_8723D	include/rtl8723d_spec.h	120;"	d
-REG_DWBCN0_CTRL_8812	include/rtl8812a_spec.h	82;"	d
-REG_DWBCN1_CTRL	include/rtl8192e_spec.h	86;"	d
-REG_DWBCN1_CTRL_8703B	include/rtl8703b_spec.h	124;"	d
-REG_DWBCN1_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	144;"	d
-REG_DWBCN1_CTRL_8723D	include/rtl8723d_spec.h	124;"	d
-REG_DWBCN1_CTRL_8812	include/rtl8812a_spec.h	83;"	d
-REG_Dummy_8814A	include/rtl8814a_spec.h	321;"	d
-REG_EARLY_MODE_CONTROL	include/hal_com_reg.h	313;"	d
-REG_EARLY_MODE_CONTROL_8192E	include/rtl8192e_spec.h	94;"	d
-REG_EARLY_MODE_CONTROL_8703B	include/rtl8703b_spec.h	138;"	d
-REG_EARLY_MODE_CONTROL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	157;"	d
-REG_EARLY_MODE_CONTROL_8723D	include/rtl8723d_spec.h	137;"	d
-REG_EARLY_MODE_CONTROL_8812	include/rtl8812a_spec.h	93;"	d
-REG_EARLY_MODE_CONTROL_8814A	include/rtl8814a_spec.h	165;"	d
-REG_EDCA_BCNCTRL1_IOREG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	340;"	d
-REG_EDCA_BCNCTRL2_IOREG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	364;"	d
-REG_EDCA_BCNSPACE3_IOREG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	366;"	d
-REG_EDCA_BCNSPACE4_IOREG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	367;"	d
-REG_EDCA_BE_PARAM	include/hal_com_reg.h	337;"	d
-REG_EDCA_BE_PARAM_8703B	include/rtl8703b_spec.h	234;"	d
-REG_EDCA_BE_PARAM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	308;"	d
-REG_EDCA_BE_PARAM_8723D	include/rtl8723d_spec.h	270;"	d
-REG_EDCA_BE_PARAM_8814A	include/rtl8814a_spec.h	331;"	d
-REG_EDCA_BK_PARAM	include/hal_com_reg.h	338;"	d
-REG_EDCA_BK_PARAM_8703B	include/rtl8703b_spec.h	235;"	d
-REG_EDCA_BK_PARAM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	309;"	d
-REG_EDCA_BK_PARAM_8723D	include/rtl8723d_spec.h	271;"	d
-REG_EDCA_BK_PARAM_8814A	include/rtl8814a_spec.h	332;"	d
-REG_EDCA_DRVERLYINT1_IOREG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	365;"	d
-REG_EDCA_VI_PARAM	include/hal_com_reg.h	336;"	d
-REG_EDCA_VI_PARAM_8703B	include/rtl8703b_spec.h	233;"	d
-REG_EDCA_VI_PARAM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	307;"	d
-REG_EDCA_VI_PARAM_8723D	include/rtl8723d_spec.h	269;"	d
-REG_EDCA_VI_PARAM_8814A	include/rtl8814a_spec.h	330;"	d
-REG_EDCA_VO_PARAM	include/hal_com_reg.h	335;"	d
-REG_EDCA_VO_PARAM_8703B	include/rtl8703b_spec.h	232;"	d
-REG_EDCA_VO_PARAM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	306;"	d
-REG_EDCA_VO_PARAM_8723D	include/rtl8723d_spec.h	268;"	d
-REG_EDCA_VO_PARAM_8814A	include/rtl8814a_spec.h	329;"	d
-REG_EE_VPD	include/hal_com_reg.h	50;"	d
-REG_EE_VPD_8703B	include/rtl8703b_spec.h	37;"	d
-REG_EE_VPD_8723D	hal/phydm/rtl8723d/hal8723dreg.h	37;"	d
-REG_EE_VPD_8723D	include/rtl8723d_spec.h	37;"	d
-REG_EE_VPD_8814A	include/rtl8814a_spec.h	39;"	d
-REG_EFUSE_ACCESS	include/hal_com_reg.h	98;"	d
-REG_EFUSE_ACCESS_8723	hal/rtl8723d/rtl8723d_hal_init.c	1469;"	d	file:
-REG_EFUSE_BURN_GNT_8703B	include/rtl8703b_spec.h	82;"	d
-REG_EFUSE_BURN_GNT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	78;"	d
-REG_EFUSE_BURN_GNT_8723D	include/rtl8723d_spec.h	84;"	d
-REG_EFUSE_BURN_GNT_8812	include/rtl8812a_spec.h	53;"	d
-REG_EFUSE_CTRL	core/efuse/rtw_efuse.c	1128;"	d	file:
-REG_EFUSE_CTRL	include/hal_com_reg.h	67;"	d
-REG_EFUSE_CTRL_8703B	include/rtl8703b_spec.h	47;"	d
-REG_EFUSE_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	46;"	d
-REG_EFUSE_CTRL_8723D	include/rtl8723d_spec.h	47;"	d
-REG_EFUSE_CTRL_8814A	include/rtl8814a_spec.h	51;"	d
-REG_EFUSE_TEST	include/hal_com_reg.h	68;"	d
-REG_EFUSE_TEST_8703B	include/rtl8703b_spec.h	48;"	d
-REG_EFUSE_TEST_8723D	include/rtl8723d_spec.h	48;"	d
-REG_EIFS	include/hal_com_reg.h	430;"	d
-REG_EIFS_8703B	include/rtl8703b_spec.h	311;"	d
-REG_EIFS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	398;"	d
-REG_EIFS_8723D	include/rtl8723d_spec.h	347;"	d
-REG_EIFS_8814A	include/rtl8814a_spec.h	407;"	d
-REG_EVTQ_BNDY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	259;"	d
-REG_FAST_EDCA_BEBK_SETTING_8814A	include/rtl8814a_spec.h	522;"	d
-REG_FAST_EDCA_CTRL	include/hal_com_reg.h	280;"	d
-REG_FAST_EDCA_CTRL_8703B	include/rtl8703b_spec.h	204;"	d
-REG_FAST_EDCA_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	252;"	d
-REG_FAST_EDCA_CTRL_8723D	include/rtl8723d_spec.h	240;"	d
-REG_FAST_EDCA_CTRL_8814A	include/rtl8814a_spec.h	272;"	d
-REG_FAST_EDCA_VOVI_SETTING_8814A	include/rtl8814a_spec.h	521;"	d
-REG_FDHM0	include/hal_com_reg.h	95;"	d
-REG_FIFOPAGE	include/hal_com_reg.h	175;"	d
-REG_FIFOPAGE_8703B	include/rtl8703b_spec.h	119;"	d
-REG_FIFOPAGE_8723D	hal/phydm/rtl8723d/hal8723dreg.h	138;"	d
-REG_FIFOPAGE_8723D	include/rtl8723d_spec.h	119;"	d
-REG_FIFOPAGE_CTRL_1_8814A	include/rtl8814a_spec.h	136;"	d
-REG_FIFOPAGE_CTRL_2_8814A	include/rtl8814a_spec.h	137;"	d
-REG_FIFOPAGE_INFO_1_8814A	include/rtl8814a_spec.h	148;"	d
-REG_FIFOPAGE_INFO_2_8814A	include/rtl8814a_spec.h	149;"	d
-REG_FIFOPAGE_INFO_3_8814A	include/rtl8814a_spec.h	150;"	d
-REG_FIFOPAGE_INFO_4_8814A	include/rtl8814a_spec.h	151;"	d
-REG_FIFOPAGE_INFO_5_8814A	include/rtl8814a_spec.h	152;"	d
-REG_FMETHR	include/hal_com_reg.h	156;"	d
-REG_FMETHR_8703B	include/rtl8703b_spec.h	101;"	d
-REG_FMETHR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	120;"	d
-REG_FMETHR_8723D	include/rtl8723d_spec.h	101;"	d
-REG_FMETHR_8814A	include/rtl8814a_spec.h	118;"	d
-REG_FSIMR	include/hal_com_reg.h	81;"	d
-REG_FSIMR_8703B	include/rtl8703b_spec.h	61;"	d
-REG_FSIMR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	58;"	d
-REG_FSIMR_8723D	include/rtl8723d_spec.h	61;"	d
-REG_FSIMR_8814A	include/rtl8814a_spec.h	65;"	d
-REG_FSISR	include/hal_com_reg.h	82;"	d
-REG_FSISR_8703B	include/rtl8703b_spec.h	62;"	d
-REG_FSISR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	59;"	d
-REG_FSISR_8723D	include/rtl8723d_spec.h	62;"	d
-REG_FSISR_8814A	include/rtl8814a_spec.h	66;"	d
-REG_FTIMR	include/hal_com_reg.h	135;"	d
-REG_FTIMR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	98;"	d
-REG_FTIMR_8814A	include/rtl8814a_spec.h	99;"	d
-REG_FTISR	include/hal_com_reg.h	136;"	d
-REG_FUN_FORMAT	include/gspi_ops.h	116;"	d
-REG_FWDLY	include/hal_com_reg.h	469;"	d
-REG_FWHW_TXQ_CTRL	include/hal_com_reg.h	259;"	d
-REG_FWHW_TXQ_CTRL_8703B	include/rtl8703b_spec.h	183;"	d
-REG_FWHW_TXQ_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	231;"	d
-REG_FWHW_TXQ_CTRL_8723D	include/rtl8723d_spec.h	219;"	d
-REG_FWHW_TXQ_CTRL_8812A	include/rtl8812a_spec.h	121;"	d
-REG_FWHW_TXQ_CTRL_8814A	include/rtl8814a_spec.h	250;"	d
-REG_FWIMR	include/hal_com_reg.h	133;"	d
-REG_FWIMR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	96;"	d
-REG_FWIMR_8814A	include/rtl8814a_spec.h	97;"	d
-REG_FWISR	include/hal_com_reg.h	134;"	d
-REG_FWISR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	97;"	d
-REG_FWISR_8814A	include/rtl8814a_spec.h	98;"	d
-REG_FW_BCN_DIS_CNT	include/hal_com_reg.h	400;"	d
-REG_FW_DBG_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	71;"	d
-REG_FW_DBG_STATUS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	70;"	d
-REG_FW_DRV_MSG_8192E	include/rtl8192e_spec.h	51;"	d
-REG_FW_DRV_MSG_8812	include/rtl8812a_spec.h	47;"	d
-REG_FW_FREE_TAIL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	236;"	d
-REG_FW_RESET_TSF_CNT_0	include/hal_com_reg.h	399;"	d
-REG_FW_RESET_TSF_CNT_1	include/hal_com_reg.h	398;"	d
-REG_FW_UPD_RDPTR_8703B	include/rtl8703b_spec.h	133;"	d
-REG_FW_UPD_RDPTR_8723D	include/rtl8723d_spec.h	133;"	d
-REG_GPIO_EXT_CTRL	include/rtl8703b_spec.h	65;"	d
-REG_GPIO_EXT_CTRL	include/rtl8723d_spec.h	65;"	d
-REG_GPIO_EXT_CTRL	include/rtl8812a_spec.h	42;"	d
-REG_GPIO_EXT_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	62;"	d
-REG_GPIO_EXT_CTRL_8814A	include/rtl8814a_spec.h	69;"	d
-REG_GPIO_INTM	include/hal_com_reg.h	76;"	d
-REG_GPIO_INTM_8703B	include/rtl8703b_spec.h	56;"	d
-REG_GPIO_INTM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	55;"	d
-REG_GPIO_INTM_8723D	include/rtl8723d_spec.h	56;"	d
-REG_GPIO_INTM_8814A	include/rtl8814a_spec.h	60;"	d
-REG_GPIO_IO_SEL	include/hal_com_reg.h	73;"	d
-REG_GPIO_IO_SEL_2	include/hal_com_reg.h	86;"	d
-REG_GPIO_IO_SEL_8703B	include/rtl8703b_spec.h	53;"	d
-REG_GPIO_IO_SEL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	52;"	d
-REG_GPIO_IO_SEL_8723D	include/rtl8723d_spec.h	53;"	d
-REG_GPIO_IO_SEL_8814A	include/rtl8814a_spec.h	57;"	d
-REG_GPIO_MUXCFG	include/hal_com_reg.h	72;"	d
-REG_GPIO_MUXCFG_8703B	include/rtl8703b_spec.h	52;"	d
-REG_GPIO_MUXCFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	51;"	d
-REG_GPIO_MUXCFG_8723D	include/rtl8723d_spec.h	52;"	d
-REG_GPIO_MUXCFG_8814A	include/rtl8814a_spec.h	56;"	d
-REG_GPIO_OUTSTS	include/hal_com_reg.h	107;"	d
-REG_GPIO_PIN_CTRL	include/hal_com_reg.h	75;"	d
-REG_GPIO_PIN_CTRL_2	include/hal_com_reg.h	85;"	d
-REG_GPIO_PIN_CTRL_8703B	include/rtl8703b_spec.h	55;"	d
-REG_GPIO_PIN_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	54;"	d
-REG_GPIO_PIN_CTRL_8723D	include/rtl8723d_spec.h	55;"	d
-REG_GPIO_PIN_CTRL_8814A	include/rtl8814a_spec.h	59;"	d
-REG_GPIO_STATUS_8703B	include/rtl8703b_spec.h	68;"	d
-REG_GPIO_STATUS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	64;"	d
-REG_GPIO_STATUS_8723D	include/rtl8723d_spec.h	68;"	d
-REG_GPIO_STATUS_8812	include/rtl8812a_spec.h	43;"	d
-REG_GPIO_STATUS_8814A	include/rtl8814a_spec.h	70;"	d
-REG_GSSR	include/hal_com_reg.h	89;"	d
-REG_HCI_MIX_CFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	222;"	d
-REG_HCI_MIX_CFG_8723D	include/rtl8723d_spec.h	203;"	d
-REG_HCI_OPT_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	66;"	d
-REG_HCI_OPT_CTRL_8814A	include/rtl8814a_spec.h	72;"	d
-REG_HGQ_INFO	include/hal_com_reg.h	255;"	d
-REG_HGQ_INFORMATION_8703B	include/rtl8703b_spec.h	179;"	d
-REG_HGQ_INFORMATION_8723D	include/rtl8723d_spec.h	215;"	d
-REG_HGQ_INFORMATION_8814A	include/rtl8814a_spec.h	246;"	d
-REG_HI0Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	115;"	d
-REG_HI0Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	175;"	d
-REG_HI0Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	155;"	d
-REG_HI0Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	183;"	d
-REG_HI0Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	146;"	d
-REG_HI0Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	206;"	d
-REG_HI0Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	187;"	d
-REG_HI0Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	214;"	d
-REG_HI0Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	129;"	d
-REG_HI0Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	189;"	d
-REG_HI0Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	169;"	d
-REG_HI0Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	197;"	d
-REG_HI1Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	116;"	d
-REG_HI1Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	176;"	d
-REG_HI1Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	156;"	d
-REG_HI1Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	184;"	d
-REG_HI1Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	147;"	d
-REG_HI1Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	207;"	d
-REG_HI1Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	188;"	d
-REG_HI1Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	215;"	d
-REG_HI1Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	130;"	d
-REG_HI1Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	190;"	d
-REG_HI1Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	170;"	d
-REG_HI1Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	198;"	d
-REG_HI2Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	117;"	d
-REG_HI2Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	177;"	d
-REG_HI2Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	157;"	d
-REG_HI2Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	185;"	d
-REG_HI2Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	148;"	d
-REG_HI2Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	208;"	d
-REG_HI2Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	189;"	d
-REG_HI2Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	216;"	d
-REG_HI2Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	131;"	d
-REG_HI2Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	191;"	d
-REG_HI2Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	171;"	d
-REG_HI2Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	199;"	d
-REG_HI3Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	118;"	d
-REG_HI3Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	178;"	d
-REG_HI3Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	158;"	d
-REG_HI3Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	186;"	d
-REG_HI3Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	149;"	d
-REG_HI3Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	209;"	d
-REG_HI3Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	190;"	d
-REG_HI3Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	217;"	d
-REG_HI3Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	132;"	d
-REG_HI3Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	192;"	d
-REG_HI3Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	172;"	d
-REG_HI3Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	200;"	d
-REG_HI4Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	119;"	d
-REG_HI4Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	179;"	d
-REG_HI4Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	159;"	d
-REG_HI4Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	187;"	d
-REG_HI4Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	150;"	d
-REG_HI4Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	210;"	d
-REG_HI4Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	191;"	d
-REG_HI4Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	218;"	d
-REG_HI4Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	133;"	d
-REG_HI4Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	193;"	d
-REG_HI4Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	173;"	d
-REG_HI4Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	201;"	d
-REG_HI5Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	120;"	d
-REG_HI5Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	180;"	d
-REG_HI5Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	160;"	d
-REG_HI5Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	188;"	d
-REG_HI5Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	151;"	d
-REG_HI5Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	211;"	d
-REG_HI5Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	192;"	d
-REG_HI5Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	219;"	d
-REG_HI5Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	134;"	d
-REG_HI5Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	194;"	d
-REG_HI5Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	174;"	d
-REG_HI5Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	202;"	d
-REG_HI6Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	121;"	d
-REG_HI6Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	181;"	d
-REG_HI6Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	161;"	d
-REG_HI6Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	189;"	d
-REG_HI6Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	152;"	d
-REG_HI6Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	212;"	d
-REG_HI6Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	193;"	d
-REG_HI6Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	220;"	d
-REG_HI6Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	135;"	d
-REG_HI6Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	195;"	d
-REG_HI6Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	175;"	d
-REG_HI6Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	203;"	d
-REG_HI7Q_TXBD_DESA_8192E	include/rtl8192e_spec.h	122;"	d
-REG_HI7Q_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	182;"	d
-REG_HI7Q_TXBD_DESA_8723D	include/rtl8723d_spec.h	162;"	d
-REG_HI7Q_TXBD_DESA_8814A	include/rtl8814a_spec.h	190;"	d
-REG_HI7Q_TXBD_IDX_8192E	include/rtl8192e_spec.h	153;"	d
-REG_HI7Q_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	213;"	d
-REG_HI7Q_TXBD_IDX_8723D	include/rtl8723d_spec.h	194;"	d
-REG_HI7Q_TXBD_IDX_8814A	include/rtl8814a_spec.h	221;"	d
-REG_HI7Q_TXBD_NUM_8192E	include/rtl8192e_spec.h	136;"	d
-REG_HI7Q_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	196;"	d
-REG_HI7Q_TXBD_NUM_8723D	include/rtl8723d_spec.h	176;"	d
-REG_HI7Q_TXBD_NUM_8814A	include/rtl8814a_spec.h	204;"	d
-REG_HIMR	include/hal_com_reg.h	128;"	d
-REG_HIMR0_8188F	include/rtl8188f_spec.h	41;"	d
-REG_HIMR0_8192E	include/rtl8192e_spec.h	53;"	d
-REG_HIMR0_8703B	include/rtl8703b_spec.h	77;"	d
-REG_HIMR0_8723B	include/rtl8723b_spec.h	41;"	d
-REG_HIMR0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	73;"	d
-REG_HIMR0_8723D	include/rtl8723d_spec.h	79;"	d
-REG_HIMR0_8812	include/rtl8812a_spec.h	49;"	d
-REG_HIMR0_8814A	include/rtl8814a_spec.h	76;"	d
-REG_HIMR1_8188F	include/rtl8188f_spec.h	43;"	d
-REG_HIMR1_8192E	include/rtl8192e_spec.h	55;"	d
-REG_HIMR1_8703B	include/rtl8703b_spec.h	79;"	d
-REG_HIMR1_8723B	include/rtl8723b_spec.h	43;"	d
-REG_HIMR1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	75;"	d
-REG_HIMR1_8723D	include/rtl8723d_spec.h	81;"	d
-REG_HIMR1_8812	include/rtl8812a_spec.h	51;"	d
-REG_HIMR1_8814A	include/rtl8814a_spec.h	78;"	d
-REG_HIMRE	include/hal_com_reg.h	130;"	d
-REG_HIMRE_88E	include/rtl8188e_spec.h	48;"	d
-REG_HIMR_88E	include/rtl8188e_spec.h	46;"	d
-REG_HISR	include/hal_com_reg.h	129;"	d
-REG_HISR0_8188F	include/rtl8188f_spec.h	42;"	d
-REG_HISR0_8192E	include/rtl8192e_spec.h	54;"	d
-REG_HISR0_8703B	include/rtl8703b_spec.h	78;"	d
-REG_HISR0_8723B	include/rtl8723b_spec.h	42;"	d
-REG_HISR0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	74;"	d
-REG_HISR0_8723D	include/rtl8723d_spec.h	80;"	d
-REG_HISR0_8812	include/rtl8812a_spec.h	50;"	d
-REG_HISR0_8814A	include/rtl8814a_spec.h	77;"	d
-REG_HISR1_8188F	include/rtl8188f_spec.h	44;"	d
-REG_HISR1_8192E	include/rtl8192e_spec.h	56;"	d
-REG_HISR1_8703B	include/rtl8703b_spec.h	80;"	d
-REG_HISR1_8723B	include/rtl8723b_spec.h	44;"	d
-REG_HISR1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	76;"	d
-REG_HISR1_8723D	include/rtl8723d_spec.h	82;"	d
-REG_HISR1_8812	include/rtl8812a_spec.h	52;"	d
-REG_HISR1_8814A	include/rtl8814a_spec.h	79;"	d
-REG_HISRE	include/hal_com_reg.h	131;"	d
-REG_HISRE_88E	include/rtl8188e_spec.h	49;"	d
-REG_HISR_88E	include/rtl8188e_spec.h	47;"	d
-REG_HMEBOX_0	include/hal_com_reg.h	158;"	d
-REG_HMEBOX_0_8703B	include/rtl8703b_spec.h	103;"	d
-REG_HMEBOX_0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	122;"	d
-REG_HMEBOX_0_8723D	include/rtl8723d_spec.h	103;"	d
-REG_HMEBOX_0_8814A	include/rtl8814a_spec.h	120;"	d
-REG_HMEBOX_1	include/hal_com_reg.h	159;"	d
-REG_HMEBOX_1_8703B	include/rtl8703b_spec.h	104;"	d
-REG_HMEBOX_1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	123;"	d
-REG_HMEBOX_1_8723D	include/rtl8723d_spec.h	104;"	d
-REG_HMEBOX_1_8814A	include/rtl8814a_spec.h	121;"	d
-REG_HMEBOX_2	include/hal_com_reg.h	160;"	d
-REG_HMEBOX_2_8703B	include/rtl8703b_spec.h	105;"	d
-REG_HMEBOX_2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	124;"	d
-REG_HMEBOX_2_8723D	include/rtl8723d_spec.h	105;"	d
-REG_HMEBOX_2_8814A	include/rtl8814a_spec.h	122;"	d
-REG_HMEBOX_3	include/hal_com_reg.h	161;"	d
-REG_HMEBOX_3_8703B	include/rtl8703b_spec.h	106;"	d
-REG_HMEBOX_3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	125;"	d
-REG_HMEBOX_3_8723D	include/rtl8723d_spec.h	106;"	d
-REG_HMEBOX_3_8814A	include/rtl8814a_spec.h	123;"	d
-REG_HMEBOX_DBG_0_8188F	include/rtl8188f_spec.h	37;"	d
-REG_HMEBOX_DBG_0_8703B	include/rtl8703b_spec.h	73;"	d
-REG_HMEBOX_DBG_0_8723B	include/rtl8723b_spec.h	37;"	d
-REG_HMEBOX_DBG_0_8723D	include/rtl8723d_spec.h	74;"	d
-REG_HMEBOX_DBG_1_8188F	include/rtl8188f_spec.h	38;"	d
-REG_HMEBOX_DBG_1_8703B	include/rtl8703b_spec.h	74;"	d
-REG_HMEBOX_DBG_1_8723B	include/rtl8723b_spec.h	38;"	d
-REG_HMEBOX_DBG_1_8723D	include/rtl8723d_spec.h	75;"	d
-REG_HMEBOX_DBG_2_8188F	include/rtl8188f_spec.h	39;"	d
-REG_HMEBOX_DBG_2_8703B	include/rtl8703b_spec.h	75;"	d
-REG_HMEBOX_DBG_2_8723B	include/rtl8723b_spec.h	39;"	d
-REG_HMEBOX_DBG_2_8723D	include/rtl8723d_spec.h	76;"	d
-REG_HMEBOX_DBG_3_8188F	include/rtl8188f_spec.h	40;"	d
-REG_HMEBOX_DBG_3_8703B	include/rtl8703b_spec.h	76;"	d
-REG_HMEBOX_DBG_3_8723B	include/rtl8723b_spec.h	40;"	d
-REG_HMEBOX_DBG_3_8723D	include/rtl8723d_spec.h	77;"	d
-REG_HMEBOX_E0	include/rtl8188e_spec.h	38;"	d
-REG_HMEBOX_E1	include/rtl8188e_spec.h	39;"	d
-REG_HMEBOX_E2	include/rtl8188e_spec.h	40;"	d
-REG_HMEBOX_E2_E3_8192E	include/rtl8192e_spec.h	52;"	d
-REG_HMEBOX_E2_E3_8812	include/rtl8812a_spec.h	48;"	d
-REG_HMEBOX_E3	include/rtl8188e_spec.h	41;"	d
-REG_HMEBOX_EXT0_8188F	include/rtl8188f_spec.h	58;"	d
-REG_HMEBOX_EXT0_8192E	include/rtl8192e_spec.h	75;"	d
-REG_HMEBOX_EXT0_8703B	include/rtl8703b_spec.h	108;"	d
-REG_HMEBOX_EXT0_8723B	include/rtl8723b_spec.h	58;"	d
-REG_HMEBOX_EXT0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	127;"	d
-REG_HMEBOX_EXT0_8723D	include/rtl8723d_spec.h	108;"	d
-REG_HMEBOX_EXT0_8812	include/rtl8812a_spec.h	72;"	d
-REG_HMEBOX_EXT0_8814A	include/rtl8814a_spec.h	126;"	d
-REG_HMEBOX_EXT1_8188F	include/rtl8188f_spec.h	59;"	d
-REG_HMEBOX_EXT1_8192E	include/rtl8192e_spec.h	76;"	d
-REG_HMEBOX_EXT1_8703B	include/rtl8703b_spec.h	109;"	d
-REG_HMEBOX_EXT1_8723B	include/rtl8723b_spec.h	59;"	d
-REG_HMEBOX_EXT1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	128;"	d
-REG_HMEBOX_EXT1_8723D	include/rtl8723d_spec.h	109;"	d
-REG_HMEBOX_EXT1_8812	include/rtl8812a_spec.h	73;"	d
-REG_HMEBOX_EXT1_8814A	include/rtl8814a_spec.h	127;"	d
-REG_HMEBOX_EXT2_8188F	include/rtl8188f_spec.h	60;"	d
-REG_HMEBOX_EXT2_8192E	include/rtl8192e_spec.h	77;"	d
-REG_HMEBOX_EXT2_8703B	include/rtl8703b_spec.h	110;"	d
-REG_HMEBOX_EXT2_8723B	include/rtl8723b_spec.h	60;"	d
-REG_HMEBOX_EXT2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	129;"	d
-REG_HMEBOX_EXT2_8723D	include/rtl8723d_spec.h	110;"	d
-REG_HMEBOX_EXT2_8812	include/rtl8812a_spec.h	74;"	d
-REG_HMEBOX_EXT2_8814A	include/rtl8814a_spec.h	128;"	d
-REG_HMEBOX_EXT3_8188F	include/rtl8188f_spec.h	61;"	d
-REG_HMEBOX_EXT3_8192E	include/rtl8192e_spec.h	78;"	d
-REG_HMEBOX_EXT3_8703B	include/rtl8703b_spec.h	111;"	d
-REG_HMEBOX_EXT3_8723B	include/rtl8723b_spec.h	61;"	d
-REG_HMEBOX_EXT3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	130;"	d
-REG_HMEBOX_EXT3_8723D	include/rtl8723d_spec.h	111;"	d
-REG_HMEBOX_EXT3_8812	include/rtl8812a_spec.h	75;"	d
-REG_HMEBOX_EXT3_8814A	include/rtl8814a_spec.h	129;"	d
-REG_HMEBOX_EXT_0	include/hal_com_reg.h	163;"	d
-REG_HMEBOX_EXT_0	include/rtl8188e_spec.h	42;"	d
-REG_HMEBOX_EXT_1	include/hal_com_reg.h	164;"	d
-REG_HMEBOX_EXT_1	include/rtl8188e_spec.h	43;"	d
-REG_HMEBOX_EXT_2	include/hal_com_reg.h	165;"	d
-REG_HMEBOX_EXT_2	include/rtl8188e_spec.h	44;"	d
-REG_HMEBOX_EXT_3	include/hal_com_reg.h	166;"	d
-REG_HMEBOX_EXT_3	include/rtl8188e_spec.h	45;"	d
-REG_HMETFR	include/hal_com_reg.h	157;"	d
-REG_HMETFR_8703B	include/rtl8703b_spec.h	102;"	d
-REG_HMETFR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	121;"	d
-REG_HMETFR_8723D	include/rtl8723d_spec.h	102;"	d
-REG_HMETFR_8814A	include/rtl8814a_spec.h	119;"	d
-REG_HOP_CNT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	368;"	d
-REG_HOST_SUSP_CNT	include/hal_com_reg.h	96;"	d
-REG_HPON_FSM	include/hal_com_reg.h	105;"	d
-REG_HPON_FSM_8703B	include/rtl8703b_spec.h	83;"	d
-REG_HPON_FSM_8723D	include/rtl8723d_spec.h	85;"	d
-REG_HQ_DESA	include/hal_com_reg.h	202;"	d
-REG_HQ_DESA_8188F	include/rtl8188f_spec.h	85;"	d
-REG_HQ_DESA_8703B	include/rtl8703b_spec.h	150;"	d
-REG_HQ_DESA_8723B	include/rtl8723b_spec.h	85;"	d
-REG_HSIMR	include/hal_com_reg.h	83;"	d
-REG_HSIMR_8703B	include/rtl8703b_spec.h	63;"	d
-REG_HSIMR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	60;"	d
-REG_HSIMR_8723D	include/rtl8723d_spec.h	63;"	d
-REG_HSIMR_8812	include/rtl8812a_spec.h	40;"	d
-REG_HSIMR_8814A	include/rtl8814a_spec.h	67;"	d
-REG_HSISR	include/hal_com_reg.h	84;"	d
-REG_HSISR_8188F	include/rtl8188f_spec.h	34;"	d
-REG_HSISR_8703B	include/rtl8703b_spec.h	64;"	d
-REG_HSISR_8723B	include/rtl8723b_spec.h	34;"	d
-REG_HSISR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	61;"	d
-REG_HSISR_8723D	include/rtl8723d_spec.h	64;"	d
-REG_HSISR_8812	include/rtl8812a_spec.h	41;"	d
-REG_HSISR_8814A	include/rtl8814a_spec.h	68;"	d
-REG_HT_SINGLE_AMPDU_8192E	include/rtl8192e_spec.h	187;"	d
-REG_HT_SINGLE_AMPDU_8703B	include/rtl8703b_spec.h	218;"	d
-REG_HT_SINGLE_AMPDU_8723D	hal/phydm/rtl8723d/hal8723dreg.h	264;"	d
-REG_HT_SINGLE_AMPDU_8723D	include/rtl8723d_spec.h	254;"	d
-REG_HT_SINGLE_AMPDU_8812	include/rtl8812a_spec.h	141;"	d
-REG_HWSEQ_CTRL	include/hal_com_reg.h	260;"	d
-REG_HWSEQ_CTRL_8703B	include/rtl8703b_spec.h	184;"	d
-REG_HWSEQ_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	232;"	d
-REG_HWSEQ_CTRL_8723D	include/rtl8723d_spec.h	220;"	d
-REG_HWSEQ_CTRL_8814A	include/rtl8814a_spec.h	251;"	d
-REG_HW_SEQ0_8814A	include/rtl8814a_spec.h	313;"	d
-REG_HW_SEQ1_8814A	include/rtl8814a_spec.h	314;"	d
-REG_HW_SEQ2_8814A	include/rtl8814a_spec.h	315;"	d
-REG_HW_SEQ3_8814A	include/rtl8814a_spec.h	316;"	d
-REG_INIDATA_RATE_SEL	include/hal_com_reg.h	290;"	d
-REG_INIRTS_RATE_SEL	include/hal_com_reg.h	289;"	d
-REG_INIRTS_RATE_SEL_8814A	include/rtl8814a_spec.h	281;"	d
-REG_INT_MIG	include/hal_com_reg.h	200;"	d
-REG_INT_MIG_8188F	include/rtl8188f_spec.h	83;"	d
-REG_INT_MIG_8192E	include/rtl8192e_spec.h	107;"	d
-REG_INT_MIG_8703B	include/rtl8703b_spec.h	148;"	d
-REG_INT_MIG_8723B	include/rtl8723b_spec.h	83;"	d
-REG_INT_MIG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	167;"	d
-REG_INT_MIG_8723D	include/rtl8723d_spec.h	147;"	d
-REG_INT_MIG_8814A	include/rtl8814a_spec.h	175;"	d
-REG_IQ_DUMP_8814A	include/rtl8814a_spec.h	451;"	d
-REG_LBDLY	include/hal_com_reg.h	468;"	d
-REG_LDOA15_CTRL	include/hal_com_reg.h	58;"	d
-REG_LDOHCI12_CTRL	include/hal_com_reg.h	60;"	d
-REG_LDOV12D_CTRL	include/hal_com_reg.h	59;"	d
-REG_LDO_EFUSE_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	47;"	d
-REG_LDO_EFUSE_CTRL_8814A	include/rtl8814a_spec.h	52;"	d
-REG_LDO_SWR_CTRL	include/rtl8192e_spec.h	50;"	d
-REG_LDO_SWR_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	68;"	d
-REG_LEDCFG0	include/hal_com_reg.h	77;"	d
-REG_LEDCFG0	include/rtl8822b_hal.h	36;"	d
-REG_LEDCFG0_8703B	include/rtl8703b_spec.h	57;"	d
-REG_LEDCFG0_8723D	include/rtl8723d_spec.h	57;"	d
-REG_LEDCFG0_8814A	include/rtl8814a_spec.h	61;"	d
-REG_LEDCFG1	include/hal_com_reg.h	78;"	d
-REG_LEDCFG1_8703B	include/rtl8703b_spec.h	58;"	d
-REG_LEDCFG1_8723D	include/rtl8723d_spec.h	58;"	d
-REG_LEDCFG1_8814A	include/rtl8814a_spec.h	62;"	d
-REG_LEDCFG2	include/hal_com_reg.h	79;"	d
-REG_LEDCFG2_8703B	include/rtl8703b_spec.h	59;"	d
-REG_LEDCFG2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	57;"	d
-REG_LEDCFG2_8723D	include/rtl8723d_spec.h	59;"	d
-REG_LEDCFG2_8814A	include/rtl8814a_spec.h	63;"	d
-REG_LEDCFG3	include/hal_com_reg.h	80;"	d
-REG_LEDCFG3_8703B	include/rtl8703b_spec.h	60;"	d
-REG_LEDCFG3_8723D	include/rtl8723d_spec.h	60;"	d
-REG_LEDCFG3_8814A	include/rtl8814a_spec.h	64;"	d
-REG_LEN_FORMAT	include/gspi_ops.h	113;"	d
-REG_LIFECTRL_CTRL_8703B	include/rtl8703b_spec.h	187;"	d
-REG_LIFECTRL_CTRL_8723D	include/rtl8723d_spec.h	223;"	d
-REG_LIFETIME_CTRL	include/hal_com_reg.h	263;"	d
-REG_LIFETIME_EN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	235;"	d
-REG_LIFETIME_EN_8814A	include/rtl8814a_spec.h	254;"	d
-REG_LLT_ADDR_8814A	include/rtl8814a_spec.h	125;"	d
-REG_LLT_INIT	include/hal_com_reg.h	162;"	d
-REG_LLT_INIT_8703B	include/rtl8703b_spec.h	107;"	d
-REG_LLT_INIT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	126;"	d
-REG_LLT_INIT_8723D	include/rtl8723d_spec.h	107;"	d
-REG_LLT_INIT_8814A	include/rtl8814a_spec.h	124;"	d
-REG_LPLDO_CTRL	include/hal_com_reg.h	61;"	d
-REG_LPLDO_CTRL_8703B	include/rtl8703b_spec.h	43;"	d
-REG_LPLDO_CTRL_8723D	include/rtl8723d_spec.h	43;"	d
-REG_LPLDO_CTRL_8814A	include/rtl8814a_spec.h	47;"	d
-REG_LTECOEX_CTRL	hal/phydm/phydm_reg.h	49;"	d
-REG_LTECOEX_CTRL	include/rtl8703b_spec.h	348;"	d
-REG_LTECOEX_CTRL	include/rtl8723d_spec.h	384;"	d
-REG_LTECOEX_PATH_CONTROL	hal/phydm/phydm_reg.h	52;"	d
-REG_LTECOEX_PATH_CONTROL	include/rtl8703b_spec.h	351;"	d
-REG_LTECOEX_PATH_CONTROL	include/rtl8723d_spec.h	387;"	d
-REG_LTECOEX_READ_DATA	hal/phydm/phydm_reg.h	51;"	d
-REG_LTECOEX_READ_DATA	include/rtl8703b_spec.h	350;"	d
-REG_LTECOEX_READ_DATA	include/rtl8723d_spec.h	386;"	d
-REG_LTECOEX_WRITE_DATA	hal/phydm/phydm_reg.h	50;"	d
-REG_LTECOEX_WRITE_DATA	include/rtl8703b_spec.h	349;"	d
-REG_LTECOEX_WRITE_DATA	include/rtl8723d_spec.h	385;"	d
-REG_MACID	include/hal_com_reg.h	415;"	d
-REG_MACID1	include/hal_com_reg.h	494;"	d
-REG_MACID1_8703B	include/rtl8703b_spec.h	342;"	d
-REG_MACID1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	427;"	d
-REG_MACID1_8723D	include/rtl8723d_spec.h	378;"	d
-REG_MACID1_8814A	include/rtl8814a_spec.h	437;"	d
-REG_MACID2	include/hal_com_reg.h	497;"	d
-REG_MACID2_8814A	include/rtl8814a_spec.h	440;"	d
-REG_MACID3	include/hal_com_reg.h	500;"	d
-REG_MACID3_8814A	include/rtl8814a_spec.h	443;"	d
-REG_MACID4	include/hal_com_reg.h	503;"	d
-REG_MACID4_8814A	include/rtl8814a_spec.h	446;"	d
-REG_MACID_8703B	include/rtl8703b_spec.h	298;"	d
-REG_MACID_8723D	hal/phydm/rtl8723d/hal8723dreg.h	387;"	d
-REG_MACID_8723D	include/rtl8723d_spec.h	334;"	d
-REG_MACID_8814A	include/rtl8814a_spec.h	396;"	d
-REG_MACID_DROP	include/hal_com_reg.h	310;"	d
-REG_MACID_NO_LINK_0	include/rtl8188e_spec.h	50;"	d
-REG_MACID_NO_LINK_1	include/rtl8188e_spec.h	51;"	d
-REG_MACID_PAUSE_0	include/rtl8188e_spec.h	52;"	d
-REG_MACID_PAUSE_1	include/rtl8188e_spec.h	53;"	d
-REG_MACID_PKT_DROP0_8192E	include/rtl8192e_spec.h	188;"	d
-REG_MACID_PKT_DROP0_8703B	include/rtl8703b_spec.h	224;"	d
-REG_MACID_PKT_DROP0_8723D	include/rtl8723d_spec.h	260;"	d
-REG_MACID_PKT_DROP0_8812	include/rtl8812a_spec.h	142;"	d
-REG_MACID_PKT_SLEEP_8703B	include/rtl8703b_spec.h	225;"	d
-REG_MACID_PKT_SLEEP_8723D	include/rtl8723d_spec.h	261;"	d
-REG_MACID_SLEEP	include/hal_com_reg.h	319;"	d
-REG_MACID_SLEEP0_8814A	include/rtl8814a_spec.h	312;"	d
-REG_MACID_SLEEP1_8814A	include/rtl8814a_spec.h	286;"	d
-REG_MACID_SLEEP2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	270;"	d
-REG_MACID_SLEEP2_8814A	include/rtl8814a_spec.h	311;"	d
-REG_MACID_SLEEP3_8814A	include/rtl8814a_spec.h	285;"	d
-REG_MACID_SLEEP_1	include/hal_com_reg.h	294;"	d
-REG_MACID_SLEEP_2	include/hal_com_reg.h	316;"	d
-REG_MACID_SLEEP_3	include/hal_com_reg.h	293;"	d
-REG_MAC_CR_8192E	include/rtl8192e_spec.h	204;"	d
-REG_MAC_CR_8703B	include/rtl8703b_spec.h	291;"	d
-REG_MAC_CR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	380;"	d
-REG_MAC_CR_8723D	include/rtl8723d_spec.h	327;"	d
-REG_MAC_CR_8812	include/rtl8812a_spec.h	159;"	d
-REG_MAC_CR_8814A	include/rtl8814a_spec.h	389;"	d
-REG_MAC_PHY_CTRL	include/hal_com_reg.h	65;"	d
-REG_MAC_PHY_CTRL	include/rtl8822b_hal.h	35;"	d
-REG_MAC_PHY_CTRL_NORMAL	include/hal_com_reg.h	113;"	d
-REG_MAC_PINMUX_CFG	include/hal_com_reg.h	74;"	d
-REG_MAC_PINMUX_CFG_8703B	include/rtl8703b_spec.h	54;"	d
-REG_MAC_PINMUX_CFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	53;"	d
-REG_MAC_PINMUX_CFG_8723D	include/rtl8723d_spec.h	54;"	d
-REG_MAC_PINMUX_CFG_8814A	include/rtl8814a_spec.h	58;"	d
-REG_MAC_PLL_CTRL_EXT_8703B	include/rtl8703b_spec.h	46;"	d
-REG_MAC_PLL_CTRL_EXT_8723D	include/rtl8723d_spec.h	46;"	d
-REG_MAC_SPEC_SIFS	include/hal_com_reg.h	423;"	d
-REG_MAC_SPEC_SIFS_8703B	include/rtl8703b_spec.h	306;"	d
-REG_MAC_SPEC_SIFS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	393;"	d
-REG_MAC_SPEC_SIFS_8723D	include/rtl8723d_spec.h	342;"	d
-REG_MAC_SPEC_SIFS_8814A	include/rtl8814a_spec.h	402;"	d
-REG_MAC_TX_SM_STATE_8192E	include/rtl8192e_spec.h	206;"	d
-REG_MAC_TX_SM_STATE_8812	include/rtl8812a_spec.h	161;"	d
-REG_MAR	include/hal_com_reg.h	417;"	d
-REG_MAR_8703B	include/rtl8703b_spec.h	300;"	d
-REG_MAR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	389;"	d
-REG_MAR_8723D	include/rtl8723d_spec.h	336;"	d
-REG_MAR_8814A	include/rtl8814a_spec.h	398;"	d
-REG_MAX_AGGR_NUM	include/hal_com_reg.h	304;"	d
-REG_MAX_AGGR_NUM_8703B	include/rtl8703b_spec.h	220;"	d
-REG_MAX_AGGR_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	266;"	d
-REG_MAX_AGGR_NUM_8723D	include/rtl8723d_spec.h	256;"	d
-REG_MAX_AGGR_NUM_8814A	include/rtl8814a_spec.h	307;"	d
-REG_MBIDCAMCFG_1	include/hal_com_reg.h	418;"	d
-REG_MBIDCAMCFG_2	include/hal_com_reg.h	419;"	d
-REG_MBIDCAMCFG_8703B	include/rtl8703b_spec.h	301;"	d
-REG_MBIDCAMCFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	390;"	d
-REG_MBIDCAMCFG_8723D	include/rtl8723d_spec.h	337;"	d
-REG_MBIDCAMCFG_8814A	include/rtl8814a_spec.h	399;"	d
-REG_MBID_NUM	include/hal_com_reg.h	371;"	d
-REG_MBID_NUM_8703B	include/rtl8703b_spec.h	267;"	d
-REG_MBID_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	341;"	d
-REG_MBID_NUM_8723D	include/rtl8723d_spec.h	303;"	d
-REG_MBID_NUM_8814A	include/rtl8814a_spec.h	364;"	d
-REG_MBIST_DONE	include/hal_com_reg.h	149;"	d
-REG_MBIST_FAIL	include/hal_com_reg.h	150;"	d
-REG_MBIST_START	include/hal_com_reg.h	148;"	d
-REG_MBSSID_BCN_SPACE_8814A	include/rtl8814a_spec.h	366;"	d
-REG_MCUFWDL	include/hal_com_reg.h	92;"	d
-REG_MCUFWDL_8703B	include/rtl8703b_spec.h	72;"	d
-REG_MCUFWDL_8723D	include/rtl8723d_spec.h	72;"	d
-REG_MCUTSTCFG	include/hal_com_reg.h	94;"	d
-REG_MCUTST_1	include/hal_com_reg.h	154;"	d
-REG_MCUTST_1_8703B	include/rtl8703b_spec.h	99;"	d
-REG_MCUTST_1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	117;"	d
-REG_MCUTST_1_8723D	include/rtl8723d_spec.h	99;"	d
-REG_MCUTST_1_8814A	include/rtl8814a_spec.h	116;"	d
-REG_MCUTST_2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	118;"	d
-REG_MCUTST_WOWLAN	include/hal_com_reg.h	155;"	d
-REG_MCUTST_WOWLAN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	119;"	d
-REG_MCUTST_WOWLAN_8814A	include/rtl8814a_spec.h	117;"	d
-REG_MDIO	include/hal_com_reg.h	214;"	d
-REG_MDIO_CTL_8188F	include/rtl8188f_spec.h	98;"	d
-REG_MDIO_CTL_8703B	include/rtl8703b_spec.h	163;"	d
-REG_MDIO_CTL_8723B	include/rtl8723b_spec.h	98;"	d
-REG_MDIO_CTL_8812	include/rtl8812a_spec.h	112;"	d
-REG_MDIO_RDATA_8188F	include/rtl8188f_spec.h	97;"	d
-REG_MDIO_RDATA_8703B	include/rtl8703b_spec.h	162;"	d
-REG_MDIO_RDATA_8723B	include/rtl8723b_spec.h	97;"	d
-REG_MDIO_RDATA_8812	include/rtl8812a_spec.h	111;"	d
-REG_MDIO_V1_8192E	include/rtl8192e_spec.h	160;"	d
-REG_MDIO_V1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	220;"	d
-REG_MDIO_V1_8723D	include/rtl8723d_spec.h	201;"	d
-REG_MDIO_V1_8814A	include/rtl8814a_spec.h	233;"	d
-REG_MDIO_WDATA_8188F	include/rtl8188f_spec.h	96;"	d
-REG_MDIO_WDATA_8703B	include/rtl8703b_spec.h	161;"	d
-REG_MDIO_WDATA_8723B	include/rtl8723b_spec.h	96;"	d
-REG_MDIO_WDATA_8812	include/rtl8812a_spec.h	110;"	d
-REG_MGQ_BDNY	include/hal_com_reg.h	262;"	d
-REG_MGQ_BDNY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	234;"	d
-REG_MGQ_DESA	include/hal_com_reg.h	203;"	d
-REG_MGQ_DESA_8188F	include/rtl8188f_spec.h	86;"	d
-REG_MGQ_DESA_8703B	include/rtl8703b_spec.h	151;"	d
-REG_MGQ_DESA_8723B	include/rtl8723b_spec.h	86;"	d
-REG_MGQ_INFO	include/hal_com_reg.h	254;"	d
-REG_MGQ_INFORMATION_8703B	include/rtl8703b_spec.h	178;"	d
-REG_MGQ_INFORMATION_8723D	include/rtl8723d_spec.h	214;"	d
-REG_MGQ_INFORMATION_8814A	include/rtl8814a_spec.h	245;"	d
-REG_MGQ_PGBNDY_8814A	include/rtl8814a_spec.h	280;"	d
-REG_MGQ_TXBD_DESA_8192E	include/rtl8192e_spec.h	109;"	d
-REG_MGQ_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	169;"	d
-REG_MGQ_TXBD_DESA_8723D	include/rtl8723d_spec.h	149;"	d
-REG_MGQ_TXBD_DESA_8814A	include/rtl8814a_spec.h	177;"	d
-REG_MGQ_TXBD_IDX_8192E	include/rtl8192e_spec.h	144;"	d
-REG_MGQ_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	204;"	d
-REG_MGQ_TXBD_IDX_8723D	include/rtl8723d_spec.h	185;"	d
-REG_MGQ_TXBD_IDX_8814A	include/rtl8814a_spec.h	212;"	d
-REG_MGQ_TXBD_NUM_8192E	include/rtl8192e_spec.h	123;"	d
-REG_MGQ_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	183;"	d
-REG_MGQ_TXBD_NUM_8723D	include/rtl8723d_spec.h	163;"	d
-REG_MGQ_TXBD_NUM_8814A	include/rtl8814a_spec.h	191;"	d
-REG_MULTI_BCNQ_OFFSET	include/hal_com_reg.h	264;"	d
-REG_MULTI_BCNQ_OFFSET_8703B	include/rtl8703b_spec.h	188;"	d
-REG_MULTI_BCNQ_OFFSET_8723D	include/rtl8723d_spec.h	224;"	d
-REG_MULTI_FUNC_CTRL	include/hal_com_reg.h	88;"	d
-REG_MULTI_FUNC_CTRL_8703B	include/rtl8703b_spec.h	67;"	d
-REG_MULTI_FUNC_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	63;"	d
-REG_MULTI_FUNC_CTRL_8723D	include/rtl8723d_spec.h	67;"	d
-REG_NAN_CAMR_AMBTT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	287;"	d
-REG_NAN_CAMR_H_8723D	hal/phydm/rtl8723d/hal8723dreg.h	285;"	d
-REG_NAN_CAMR_L_8723D	hal/phydm/rtl8723d/hal8723dreg.h	284;"	d
-REG_NAN_INTERFACE_ADDR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	277;"	d
-REG_NAN_LAMR_AMBTT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	292;"	d
-REG_NAN_LAMR_H_8723D	hal/phydm/rtl8723d/hal8723dreg.h	291;"	d
-REG_NAN_LAMR_L_8723D	hal/phydm/rtl8723d/hal8723dreg.h	290;"	d
-REG_NAN_MASTER_PREF_8723D	hal/phydm/rtl8723d/hal8723dreg.h	279;"	d
-REG_NAN_RANDOM_FACTOR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	278;"	d
-REG_NAN_STATUS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	296;"	d
-REG_NAV_CTRL	include/hal_com_reg.h	465;"	d
-REG_NAV_PROT_LEN	include/hal_com_reg.h	368;"	d
-REG_NAV_PROT_LEN_8703B	include/rtl8703b_spec.h	264;"	d
-REG_NAV_PROT_LEN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	338;"	d
-REG_NAV_PROT_LEN_8723D	include/rtl8723d_spec.h	300;"	d
-REG_NAV_PROT_LEN_8814A	include/rtl8814a_spec.h	361;"	d
-REG_NAV_UPPER	include/hal_com_reg.h	462;"	d
-REG_NAV_UPPER_8703B	include/rtl8703b_spec.h	313;"	d
-REG_NAV_UPPER_8723D	hal/phydm/rtl8723d/hal8723dreg.h	400;"	d
-REG_NAV_UPPER_8723D	include/rtl8723d_spec.h	349;"	d
-REG_NAV_UPPER_8814A	include/rtl8814a_spec.h	409;"	d
-REG_NDPA_OPT_CTRL_8192E	include/rtl8192e_spec.h	177;"	d
-REG_NDPA_OPT_CTRL_8703B	include/rtl8703b_spec.h	203;"	d
-REG_NDPA_OPT_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	251;"	d
-REG_NDPA_OPT_CTRL_8723D	include/rtl8723d_spec.h	239;"	d
-REG_NDPA_OPT_CTRL_8812A	include/rtl8812a_spec.h	131;"	d
-REG_NDPA_OPT_CTRL_8814A	include/rtl8814a_spec.h	271;"	d
-REG_NDPA_RATE_8814A	include/rtl8814a_spec.h	269;"	d
-REG_NEED_CPU_HANDLE	include/hal_com_reg.h	323;"	d
-REG_NOA_DESC_COUNT	include/hal_com_reg.h	393;"	d
-REG_NOA_DESC_DURATION	include/hal_com_reg.h	390;"	d
-REG_NOA_DESC_INTERVAL	include/hal_com_reg.h	391;"	d
-REG_NOA_DESC_SEL	include/hal_com_reg.h	389;"	d
-REG_NOA_DESC_START	include/hal_com_reg.h	392;"	d
-REG_NORMAL_SIE_EP	include/hal_com_reg.h	544;"	d
-REG_NORMAL_SIE_GPS_EP	include/hal_com_reg.h	547;"	d
-REG_NORMAL_SIE_MAC_ADDR	include/hal_com_reg.h	548;"	d
-REG_NORMAL_SIE_OPTIONAL	include/hal_com_reg.h	543;"	d
-REG_NORMAL_SIE_OPTIONAL2	include/hal_com_reg.h	546;"	d
-REG_NORMAL_SIE_PHY	include/hal_com_reg.h	545;"	d
-REG_NORMAL_SIE_PID	include/hal_com_reg.h	542;"	d
-REG_NORMAL_SIE_STRING	include/hal_com_reg.h	549;"	d
-REG_NORMAL_SIE_VID	include/hal_com_reg.h	541;"	d
-REG_NQOS_SEQ	include/hal_com_reg.h	321;"	d
-REG_NULL_PKT_STATUS_8814A	include/rtl8814a_spec.h	317;"	d
-REG_OPT_CTRL_8192E	include/rtl8192e_spec.h	47;"	d
-REG_OPT_CTRL_8703B	include/rtl8703b_spec.h	70;"	d
-REG_OPT_CTRL_8723D	include/rtl8723d_spec.h	70;"	d
-REG_OPT_CTRL_8812	include/rtl8812a_spec.h	45;"	d
-REG_P2P_CTWIN	include/hal_com_reg.h	384;"	d
-REG_P2P_RST_8814A	include/rtl8814a_spec.h	382;"	d
-REG_PAD_CTRL1_8188F	include/rtl8188f_spec.h	35;"	d
-REG_PAD_CTRL1_8192E	include/rtl8192e_spec.h	45;"	d
-REG_PAD_CTRL1_8703B	include/rtl8703b_spec.h	66;"	d
-REG_PAD_CTRL1_8723B	include/rtl8723b_spec.h	35;"	d
-REG_PAD_CTRL1_8723D	include/rtl8723d_spec.h	66;"	d
-REG_PAD_CTRL_1	include/hal_com_reg.h	87;"	d
-REG_PBP	include/hal_com_reg.h	122;"	d
-REG_PBP_8723D	hal/phydm/rtl8723d/hal8723dreg.h	90;"	d
-REG_PBP_8814A	include/rtl8814a_spec.h	90;"	d
-REG_PCIE_C2H_MSG_V1_8814A	include/rtl8814a_spec.h	229;"	d
-REG_PCIE_CTRL2_8814A	include/rtl8814a_spec.h	225;"	d
-REG_PCIE_CTRL_REG	include/hal_com_reg.h	199;"	d
-REG_PCIE_CTRL_REG_8188F	include/rtl8188f_spec.h	82;"	d
-REG_PCIE_CTRL_REG_8192E	include/rtl8192e_spec.h	106;"	d
-REG_PCIE_CTRL_REG_8703B	include/rtl8703b_spec.h	147;"	d
-REG_PCIE_CTRL_REG_8723B	include/rtl8723b_spec.h	82;"	d
-REG_PCIE_CTRL_REG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	166;"	d
-REG_PCIE_CTRL_REG_8723D	include/rtl8723d_spec.h	146;"	d
-REG_PCIE_CTRL_REG_8812A	include/rtl8812a_spec.h	105;"	d
-REG_PCIE_CTRL_REG_8814A	include/rtl8814a_spec.h	174;"	d
-REG_PCIE_H2C_MSG_V1_8814A	include/rtl8814a_spec.h	228;"	d
-REG_PCIE_HCPWM	include/hal_com_reg.h	217;"	d
-REG_PCIE_HCPWM1_V1_8814A	include/rtl8814a_spec.h	224;"	d
-REG_PCIE_HCPWM2_V1_8814A	include/rtl8814a_spec.h	227;"	d
-REG_PCIE_HCPWM_8188F	include/rtl8188f_spec.h	101;"	d
-REG_PCIE_HCPWM_8192EE	include/rtl8192e_spec.h	155;"	d
-REG_PCIE_HCPWM_8703B	include/rtl8703b_spec.h	166;"	d
-REG_PCIE_HCPWM_8723B	include/rtl8723b_spec.h	101;"	d
-REG_PCIE_HCPWM_8723DE	hal/phydm/rtl8723d/hal8723dreg.h	215;"	d
-REG_PCIE_HCPWM_8723DE	include/rtl8723d_spec.h	196;"	d
-REG_PCIE_HIMR	include/hal_com_reg.h	225;"	d
-REG_PCIE_HIMRE	include/hal_com_reg.h	226;"	d
-REG_PCIE_HISR	include/hal_com_reg.h	223;"	d
-REG_PCIE_HISRE	include/hal_com_reg.h	224;"	d
-REG_PCIE_HISR_EN	include/hal_com_reg.h	222;"	d
-REG_PCIE_HRPWM	include/hal_com_reg.h	216;"	d
-REG_PCIE_HRPWM1_V1_8814A	include/rtl8814a_spec.h	223;"	d
-REG_PCIE_HRPWM2_V1_8814A	include/rtl8814a_spec.h	226;"	d
-REG_PCIE_HRPWM_8188F	include/rtl8188f_spec.h	100;"	d
-REG_PCIE_HRPWM_8192EE	include/rtl8192e_spec.h	156;"	d
-REG_PCIE_HRPWM_8703B	include/rtl8703b_spec.h	165;"	d
-REG_PCIE_HRPWM_8723B	include/rtl8723b_spec.h	100;"	d
-REG_PCIE_HRPWM_8723DE	hal/phydm/rtl8723d/hal8723dreg.h	216;"	d
-REG_PCIE_HRPWM_8723DE	include/rtl8723d_spec.h	197;"	d
-REG_PCIE_MIO_INTD	include/hal_com_reg.h	104;"	d
-REG_PCIE_MIO_INTF	include/hal_com_reg.h	103;"	d
-REG_PCIE_MIX_CFG_8192E	include/rtl8192e_spec.h	161;"	d
-REG_PCIE_MIX_CFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	221;"	d
-REG_PCIE_MIX_CFG_8723D	include/rtl8723d_spec.h	202;"	d
-REG_PCIE_MIX_CFG_8814A	include/rtl8814a_spec.h	234;"	d
-REG_PCIE_MULTIFET_CTRL_8188F	include/rtl8188f_spec.h	102;"	d
-REG_PCIE_MULTIFET_CTRL_8703B	include/rtl8703b_spec.h	167;"	d
-REG_PCIE_MULTIFET_CTRL_8723B	include/rtl8723b_spec.h	102;"	d
-REG_PCIE_MULTIFET_CTRL_8812	include/rtl8812a_spec.h	113;"	d
-REG_PIFS	include/hal_com_reg.h	340;"	d
-REG_PIFS_8703B	include/rtl8703b_spec.h	237;"	d
-REG_PIFS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	311;"	d
-REG_PIFS_8723D	include/rtl8723d_spec.h	273;"	d
-REG_PIFS_8814A	include/rtl8814a_spec.h	334;"	d
-REG_PKTBUF_DBG_ADDR	include/rtl8188e_spec.h	60;"	d
-REG_PKTBUF_DBG_ADDR	include/rtl8192e_spec.h	65;"	d
-REG_PKTBUF_DBG_ADDR	include/rtl8812a_spec.h	62;"	d
-REG_PKTBUF_DBG_CTRL	include/hal_com_reg.h	137;"	d
-REG_PKTBUF_DBG_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	99;"	d
-REG_PKTBUF_DBG_CTRL_8814A	include/rtl8814a_spec.h	100;"	d
-REG_PKTBUF_DBG_DATA_H	include/hal_com_reg.h	140;"	d
-REG_PKTBUF_DBG_DATA_H_8723D	hal/phydm/rtl8723d/hal8723dreg.h	102;"	d
-REG_PKTBUF_DBG_DATA_H_8814A	include/rtl8814a_spec.h	103;"	d
-REG_PKTBUF_DBG_DATA_L	include/hal_com_reg.h	139;"	d
-REG_PKTBUF_DBG_DATA_L_8723D	hal/phydm/rtl8723d/hal8723dreg.h	101;"	d
-REG_PKTBUF_DBG_DATA_L_8814A	include/rtl8814a_spec.h	102;"	d
-REG_PKT_BE_BK_LIFE_TIME	include/hal_com_reg.h	299;"	d
-REG_PKT_BE_BK_LIFE_TIME_8703B	include/rtl8703b_spec.h	216;"	d
-REG_PKT_BE_BK_LIFE_TIME_8723D	hal/phydm/rtl8723d/hal8723dreg.h	261;"	d
-REG_PKT_BE_BK_LIFE_TIME_8723D	include/rtl8723d_spec.h	252;"	d
-REG_PKT_BE_BK_LIFE_TIME_8814A	include/rtl8814a_spec.h	301;"	d
-REG_PKT_BUFF_ACCESS_CTRL	include/hal_com_reg.h	123;"	d
-REG_PKT_BUFF_ACCESS_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	91;"	d
-REG_PKT_BUFF_ACCESS_CTRL_8814A	include/rtl8814a_spec.h	91;"	d
-REG_PKT_LIFE_TIME_8723D	hal/phydm/rtl8723d/hal8723dreg.h	260;"	d
-REG_PKT_LIFE_TIME_8814A	include/rtl8814a_spec.h	300;"	d
-REG_PKT_LOSE_RPT	include/hal_com_reg.h	324;"	d
-REG_PKT_VO_VI_LIFE_TIME	include/hal_com_reg.h	298;"	d
-REG_PKT_VO_VI_LIFE_TIME_8703B	include/rtl8703b_spec.h	215;"	d
-REG_PKT_VO_VI_LIFE_TIME_8723D	include/rtl8723d_spec.h	251;"	d
-REG_PMC_DBG_CTRL2_8188F	include/rtl8188f_spec.h	45;"	d
-REG_PMC_DBG_CTRL2_8703B	include/rtl8703b_spec.h	81;"	d
-REG_PMC_DBG_CTRL2_8723B	include/rtl8723b_spec.h	45;"	d
-REG_PMC_DBG_CTRL2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	77;"	d
-REG_PMC_DBG_CTRL2_8723D	include/rtl8723d_spec.h	83;"	d
-REG_PNO_STATUS	include/hal_com_reg.h	421;"	d
-REG_POWER_OFF_IN_PROCESS	include/hal_com_reg.h	54;"	d
-REG_POWER_STAGE1	include/hal_com_reg.h	296;"	d
-REG_POWER_STAGE1_8703B	include/rtl8703b_spec.h	212;"	d
-REG_POWER_STAGE1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	256;"	d
-REG_POWER_STAGE1_8723D	include/rtl8723d_spec.h	248;"	d
-REG_POWER_STAGE1_8814A	include/rtl8814a_spec.h	297;"	d
-REG_POWER_STAGE2	include/hal_com_reg.h	297;"	d
-REG_POWER_STAGE2_8703B	include/rtl8703b_spec.h	213;"	d
-REG_POWER_STAGE2_8723D	include/rtl8723d_spec.h	249;"	d
-REG_POWER_STAGE2_8814A	include/rtl8814a_spec.h	298;"	d
-REG_PROT_MODE_CTRL	include/hal_com_reg.h	303;"	d
-REG_PROT_MODE_CTRL_8703B	include/rtl8703b_spec.h	219;"	d
-REG_PROT_MODE_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	265;"	d
-REG_PROT_MODE_CTRL_8723D	include/rtl8723d_spec.h	255;"	d
-REG_PROT_MODE_CTRL_8814A	include/rtl8814a_spec.h	306;"	d
-REG_PSTIMER	include/hal_com_reg.h	385;"	d
-REG_PSTIMER_8703B	include/rtl8703b_spec.h	280;"	d
-REG_PSTIMER_8723D	hal/phydm/rtl8723d/hal8723dreg.h	355;"	d
-REG_PSTIMER_8723D	include/rtl8723d_spec.h	316;"	d
-REG_PSTIMER_8814A	include/rtl8814a_spec.h	377;"	d
-REG_PS_RX_INFO	include/hal_com_reg.h	482;"	d
-REG_PS_RX_INFO_8703B	include/rtl8703b_spec.h	325;"	d
-REG_PS_RX_INFO_8723D	hal/phydm/rtl8723d/hal8723dreg.h	412;"	d
-REG_PS_RX_INFO_8723D	include/rtl8723d_spec.h	361;"	d
-REG_PS_RX_INFO_8814A	include/rtl8814a_spec.h	421;"	d
-REG_PTCL_ERR_STATUS	include/hal_com_reg.h	325;"	d
-REG_PTCL_ERR_STATUS_8814A	include/rtl8814a_spec.h	318;"	d
-REG_PTCL_HWSSN0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	271;"	d
-REG_PTCL_POLL_MGN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	230;"	d
-REG_PTCL_SDF_STATUS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	257;"	d
-REG_PTCL_TX_RPT_8814A	include/rtl8814a_spec.h	320;"	d
-REG_PWR_DATA	include/hal_com_reg.h	69;"	d
-REG_PWR_DATA_8703B	include/rtl8703b_spec.h	49;"	d
-REG_PWR_DATA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	48;"	d
-REG_PWR_DATA_8723D	include/rtl8723d_spec.h	49;"	d
-REG_PWR_DATA_8814A	include/rtl8814a_spec.h	53;"	d
-REG_Q0_INFO	include/hal_com_reg.h	249;"	d
-REG_Q1_INFO	include/hal_com_reg.h	250;"	d
-REG_Q2_INFO	include/hal_com_reg.h	251;"	d
-REG_Q3_INFO	include/hal_com_reg.h	252;"	d
-REG_Q4_INFO	include/hal_com_reg.h	284;"	d
-REG_Q4_INFO_8814A	include/rtl8814a_spec.h	275;"	d
-REG_Q5_INFO	include/hal_com_reg.h	285;"	d
-REG_Q5_INFO_8814A	include/rtl8814a_spec.h	276;"	d
-REG_Q6_INFO	include/hal_com_reg.h	286;"	d
-REG_Q6_INFO_8814A	include/rtl8814a_spec.h	277;"	d
-REG_Q7_INFO	include/hal_com_reg.h	287;"	d
-REG_Q7_INFO_8814A	include/rtl8814a_spec.h	278;"	d
-REG_QOS_SEQ	include/hal_com_reg.h	322;"	d
-REG_QUEUE_CTRL	include/hal_com_reg.h	301;"	d
-REG_QUEUE_CTRL_8814A	include/rtl8814a_spec.h	304;"	d
-REG_RARFRC	include/hal_com_reg.h	268;"	d
-REG_RARFRC_8703B	include/rtl8703b_spec.h	193;"	d
-REG_RARFRC_8723D	hal/phydm/rtl8723d/hal8723dreg.h	241;"	d
-REG_RARFRC_8723D	include/rtl8723d_spec.h	229;"	d
-REG_RARFRC_8814A	include/rtl8814a_spec.h	260;"	d
-REG_RA_TRY_RATE_AGG_LMT	include/hal_com_reg.h	307;"	d
-REG_RA_TRY_RATE_AGG_LMT_8703B	include/rtl8703b_spec.h	223;"	d
-REG_RA_TRY_RATE_AGG_LMT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	269;"	d
-REG_RA_TRY_RATE_AGG_LMT_8723D	include/rtl8723d_spec.h	259;"	d
-REG_RA_TRY_RATE_AGG_LMT_8814A	include/rtl8814a_spec.h	310;"	d
-REG_RCR	include/hal_com_reg.h	410;"	d
-REG_RCR_8703B	include/rtl8703b_spec.h	293;"	d
-REG_RCR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	382;"	d
-REG_RCR_8723D	include/rtl8723d_spec.h	329;"	d
-REG_RCR_8814A	include/rtl8814a_spec.h	391;"	d
-REG_RDG_PIFS	include/hal_com_reg.h	341;"	d
-REG_RDG_PIFS_8703B	include/rtl8703b_spec.h	238;"	d
-REG_RDG_PIFS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	312;"	d
-REG_RDG_PIFS_8723D	include/rtl8723d_spec.h	274;"	d
-REG_RDG_PIFS_8814A	include/rtl8814a_spec.h	335;"	d
-REG_RD_CTRL	include/hal_com_reg.h	350;"	d
-REG_RD_CTRL_8703B	include/rtl8703b_spec.h	246;"	d
-REG_RD_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	320;"	d
-REG_RD_CTRL_8723D	include/rtl8723d_spec.h	282;"	d
-REG_RD_CTRL_8814A	include/rtl8814a_spec.h	343;"	d
-REG_RD_NAV_NXT	include/hal_com_reg.h	367;"	d
-REG_RD_NAV_NXT_8703B	include/rtl8703b_spec.h	263;"	d
-REG_RD_NAV_NXT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	337;"	d
-REG_RD_NAV_NXT_8723D	include/rtl8723d_spec.h	299;"	d
-REG_RD_NAV_NXT_8814A	include/rtl8814a_spec.h	360;"	d
-REG_RD_RESP_PKT_TH	include/hal_com_reg.h	281;"	d
-REG_RD_RESP_PKT_TH_8703B	include/rtl8703b_spec.h	205;"	d
-REG_RD_RESP_PKT_TH_8723D	hal/phydm/rtl8723d/hal8723dreg.h	253;"	d
-REG_RD_RESP_PKT_TH_8723D	include/rtl8723d_spec.h	241;"	d
-REG_RD_RESP_PKT_TH_8814A	include/rtl8814a_spec.h	273;"	d
-REG_RESP_SIFP_CCK_8703B	include/rtl8703b_spec.h	307;"	d
-REG_RESP_SIFP_CCK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	394;"	d
-REG_RESP_SIFP_CCK_8723D	include/rtl8723d_spec.h	343;"	d
-REG_RESP_SIFP_CCK_8814A	include/rtl8814a_spec.h	403;"	d
-REG_RESP_SIFS_CCK	include/hal_com_reg.h	425;"	d
-REG_RESP_SIFS_OFDM	include/hal_com_reg.h	426;"	d
-REG_RESP_SIFS_OFDM_8703B	include/rtl8703b_spec.h	308;"	d
-REG_RESP_SIFS_OFDM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	395;"	d
-REG_RESP_SIFS_OFDM_8723D	include/rtl8723d_spec.h	344;"	d
-REG_RESP_SIFS_OFDM_8814A	include/rtl8814a_spec.h	404;"	d
-REG_RETRY_LIMIT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	238;"	d
-REG_RETRY_LIMIT_8814A	include/rtl8814a_spec.h	257;"	d
-REG_RF_BB_GAIN_OFFSET	include/hal_data.h	174;"	d
-REG_RF_BB_GAIN_OFFSET	include/hal_data.h	177;"	d
-REG_RF_BB_GAIN_OFFSET	include/hal_data.h	180;"	d
-REG_RF_B_CTRL_8192E	include/rtl8192e_spec.h	48;"	d
-REG_RF_B_CTRL_8812	include/rtl8812a_spec.h	46;"	d
-REG_RF_CTRL	include/hal_com_reg.h	57;"	d
-REG_RF_CTRL0_8814A	include/rtl8814a_spec.h	44;"	d
-REG_RF_CTRL1_8814A	include/rtl8814a_spec.h	45;"	d
-REG_RF_CTRL2_8814A	include/rtl8814a_spec.h	46;"	d
-REG_RF_CTRL3_8814A	include/rtl8814a_spec.h	73;"	d
-REG_RF_CTRL_8703B	include/rtl8703b_spec.h	42;"	d
-REG_RF_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	42;"	d
-REG_RF_CTRL_8723D	include/rtl8723d_spec.h	42;"	d
-REG_RL	include/hal_com_reg.h	266;"	d
-REG_RL_8703B	include/rtl8703b_spec.h	190;"	d
-REG_RL_8723D	include/rtl8723d_spec.h	226;"	d
-REG_ROM_VERSION	hal/phydm/rtl8723d/hal8723dreg.h	82;"	d
-REG_ROM_VERSION	include/rtl8703b_spec.h	86;"	d
-REG_ROM_VERSION	include/rtl8723d_spec.h	87;"	d
-REG_RQPN	include/hal_com_reg.h	174;"	d
-REG_RQPN_8703B	include/rtl8703b_spec.h	118;"	d
-REG_RQPN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	137;"	d
-REG_RQPN_8723D	include/rtl8723d_spec.h	118;"	d
-REG_RQPN_CTRL_1_8814A	include/rtl8814a_spec.h	146;"	d
-REG_RQPN_CTRL_2_8814A	include/rtl8814a_spec.h	147;"	d
-REG_RQPN_NPQ	include/hal_com_reg.h	179;"	d
-REG_RQPN_NPQ_8703B	include/rtl8703b_spec.h	123;"	d
-REG_RQPN_NPQ_8723D	hal/phydm/rtl8723d/hal8723dreg.h	142;"	d
-REG_RQPN_NPQ_8723D	include/rtl8723d_spec.h	123;"	d
-REG_RQPN_NPQ_8814A	include/rtl8814a_spec.h	141;"	d
-REG_RRSR	include/hal_com_reg.h	269;"	d
-REG_RRSR_8703B	include/rtl8703b_spec.h	194;"	d
-REG_RRSR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	242;"	d
-REG_RRSR_8723D	include/rtl8723d_spec.h	230;"	d
-REG_RRSR_8814A	include/rtl8814a_spec.h	261;"	d
-REG_RSVD3_8192E	include/rtl8192e_spec.h	70;"	d
-REG_RSVD3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	110;"	d
-REG_RSVD3_8812	include/rtl8812a_spec.h	67;"	d
-REG_RSVD3_8814A	include/rtl8814a_spec.h	113;"	d
-REG_RSVD5_8192E	include/rtl8192e_spec.h	96;"	d
-REG_RSVD5_8703B	include/rtl8703b_spec.h	139;"	d
-REG_RSVD5_8723D	hal/phydm/rtl8723d/hal8723dreg.h	158;"	d
-REG_RSVD5_8723D	include/rtl8723d_spec.h	138;"	d
-REG_RSVD5_8812	include/rtl8812a_spec.h	94;"	d
-REG_RSVD5_8814A	include/rtl8814a_spec.h	166;"	d
-REG_RSVD6_8192E	include/rtl8192e_spec.h	97;"	d
-REG_RSVD6_8703B	include/rtl8703b_spec.h	140;"	d
-REG_RSVD6_8723D	include/rtl8723d_spec.h	139;"	d
-REG_RSVD6_8812	include/rtl8812a_spec.h	95;"	d
-REG_RSVD7_8192E	include/rtl8192e_spec.h	98;"	d
-REG_RSVD7_8812	include/rtl8812a_spec.h	96;"	d
-REG_RSVD8_8192E	include/rtl8192e_spec.h	99;"	d
-REG_RSVD8_8812	include/rtl8812a_spec.h	97;"	d
-REG_RSV_CTRL	include/hal_com_reg.h	56;"	d
-REG_RSV_CTRL_8188F	include/rtl8188f_spec.h	32;"	d
-REG_RSV_CTRL_8703B	include/rtl8703b_spec.h	41;"	d
-REG_RSV_CTRL_8723B	include/rtl8723b_spec.h	32;"	d
-REG_RSV_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	41;"	d
-REG_RSV_CTRL_8723D	include/rtl8723d_spec.h	41;"	d
-REG_RSV_CTRL_8814A	include/rtl8814a_spec.h	43;"	d
-REG_RTS_MAX_AGGR_NUM	include/hal_com_reg.h	305;"	d
-REG_RTS_MAX_AGGR_NUM_8703B	include/rtl8703b_spec.h	221;"	d
-REG_RTS_MAX_AGGR_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	267;"	d
-REG_RTS_MAX_AGGR_NUM_8723D	include/rtl8723d_spec.h	257;"	d
-REG_RTS_MAX_AGGR_NUM_8814A	include/rtl8814a_spec.h	308;"	d
-REG_RW_FORMAT	include/gspi_ops.h	117;"	d
-REG_RXDMA_8192E	include/rtl8192e_spec.h	93;"	d
-REG_RXDMA_AGG_PG_TH	include/hal_com_reg.h	188;"	d
-REG_RXDMA_AGG_PG_TH_8703B	include/rtl8703b_spec.h	132;"	d
-REG_RXDMA_AGG_PG_TH_8723D	hal/phydm/rtl8723d/hal8723dreg.h	152;"	d
-REG_RXDMA_AGG_PG_TH_8723D	include/rtl8723d_spec.h	132;"	d
-REG_RXDMA_AGG_PG_TH_8814A	include/rtl8814a_spec.h	160;"	d
-REG_RXDMA_CONTROL_8188F	include/rtl8188f_spec.h	74;"	d
-REG_RXDMA_CONTROL_8703B	include/rtl8703b_spec.h	134;"	d
-REG_RXDMA_CONTROL_8723B	include/rtl8723b_spec.h	74;"	d
-REG_RXDMA_CONTROL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	154;"	d
-REG_RXDMA_CONTROL_8723D	include/rtl8723d_spec.h	134;"	d
-REG_RXDMA_CONTROL_8812A	include/rtl8812a_spec.h	91;"	d
-REG_RXDMA_CONTROL_8814A	include/rtl8814a_spec.h	162;"	d
-REG_RXDMA_MODE_8814A	include/rtl8814a_spec.h	164;"	d
-REG_RXDMA_MODE_CTRL_8188F	include/rtl8188f_spec.h	75;"	d
-REG_RXDMA_MODE_CTRL_8703B	include/rtl8703b_spec.h	137;"	d
-REG_RXDMA_MODE_CTRL_8723B	include/rtl8723b_spec.h	75;"	d
-REG_RXDMA_MODE_CTRL_8723D	include/rtl8723d_spec.h	136;"	d
-REG_RXDMA_PRO_8723D	hal/phydm/rtl8723d/hal8723dreg.h	156;"	d
-REG_RXDMA_PRO_8812	include/rtl8812a_spec.h	92;"	d
-REG_RXDMA_STATUS	include/hal_com_reg.h	190;"	d
-REG_RXDMA_STATUS_8703B	include/rtl8703b_spec.h	136;"	d
-REG_RXDMA_STATUS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	155;"	d
-REG_RXDMA_STATUS_8723D	include/rtl8723d_spec.h	135;"	d
-REG_RXDMA_STATUS_8814A	include/rtl8814a_spec.h	163;"	d
-REG_RXERR_RPT	include/hal_com_reg.h	470;"	d
-REG_RXFF_PTR	include/hal_com_reg.h	127;"	d
-REG_RXFF_PTR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	94;"	d
-REG_RXFF_PTR_8814A	include/rtl8814a_spec.h	95;"	d
-REG_RXFLTMAP0	include/hal_com_reg.h	487;"	d
-REG_RXFLTMAP0_8703B	include/rtl8703b_spec.h	330;"	d
-REG_RXFLTMAP0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	415;"	d
-REG_RXFLTMAP0_8723D	include/rtl8723d_spec.h	366;"	d
-REG_RXFLTMAP0_8814A	include/rtl8814a_spec.h	424;"	d
-REG_RXFLTMAP1	include/hal_com_reg.h	488;"	d
-REG_RXFLTMAP1_8703B	include/rtl8703b_spec.h	331;"	d
-REG_RXFLTMAP1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	416;"	d
-REG_RXFLTMAP1_8723D	include/rtl8723d_spec.h	367;"	d
-REG_RXFLTMAP1_8814A	include/rtl8814a_spec.h	425;"	d
-REG_RXFLTMAP2	include/hal_com_reg.h	489;"	d
-REG_RXFLTMAP2	include/rtl8822b_hal.h	43;"	d
-REG_RXFLTMAP2_8703B	include/rtl8703b_spec.h	332;"	d
-REG_RXFLTMAP2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	417;"	d
-REG_RXFLTMAP2_8723D	include/rtl8723d_spec.h	368;"	d
-REG_RXFLTMAP2_8814A	include/rtl8814a_spec.h	426;"	d
-REG_RXPKTBUF_CTRL	include/hal_com_reg.h	138;"	d
-REG_RXPKTBUF_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	100;"	d
-REG_RXPKTBUF_CTRL_8814A	include/rtl8814a_spec.h	101;"	d
-REG_RXPKTBUF_DBG	include/rtl8188e_spec.h	61;"	d
-REG_RXPKTBUF_DBG	include/rtl8192e_spec.h	66;"	d
-REG_RXPKTBUF_DBG	include/rtl8812a_spec.h	63;"	d
-REG_RXPKT_NUM	include/hal_com_reg.h	189;"	d
-REG_RXPKT_NUM_8703B	include/rtl8703b_spec.h	135;"	d
-REG_RXPKT_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	153;"	d
-REG_RXPKT_NUM_8814A	include/rtl8814a_spec.h	161;"	d
-REG_RXQ_RXBD_DESA_8192E	include/rtl8192e_spec.h	114;"	d
-REG_RXQ_RXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	174;"	d
-REG_RXQ_RXBD_DESA_8723D	include/rtl8723d_spec.h	154;"	d
-REG_RXQ_RXBD_DESA_8814A	include/rtl8814a_spec.h	182;"	d
-REG_RXQ_TXBD_IDX_8192E	include/rtl8192e_spec.h	145;"	d
-REG_RXQ_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	205;"	d
-REG_RXQ_TXBD_IDX_8723D	include/rtl8723d_spec.h	186;"	d
-REG_RXQ_TXBD_IDX_8814A	include/rtl8814a_spec.h	213;"	d
-REG_RXTSF_OFFSET_CCK	include/hal_com_reg.h	379;"	d
-REG_RXTSF_OFFSET_CCK_8703B	include/rtl8703b_spec.h	275;"	d
-REG_RXTSF_OFFSET_CCK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	349;"	d
-REG_RXTSF_OFFSET_CCK_8723D	include/rtl8723d_spec.h	311;"	d
-REG_RXTSF_OFFSET_CCK_8814A	include/rtl8814a_spec.h	372;"	d
-REG_RXTSF_OFFSET_OFDM	include/hal_com_reg.h	380;"	d
-REG_RXTSF_OFFSET_OFDM_8703B	include/rtl8703b_spec.h	276;"	d
-REG_RXTSF_OFFSET_OFDM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	350;"	d
-REG_RXTSF_OFFSET_OFDM_8723D	include/rtl8723d_spec.h	312;"	d
-REG_RXTSF_OFFSET_OFDM_8814A	include/rtl8814a_spec.h	373;"	d
-REG_RX_DESA	include/hal_com_reg.h	208;"	d
-REG_RX_DESA_8188F	include/rtl8188f_spec.h	91;"	d
-REG_RX_DESA_8703B	include/rtl8703b_spec.h	156;"	d
-REG_RX_DESA_8723B	include/rtl8723b_spec.h	91;"	d
-REG_RX_DLK_TIME	include/hal_com_reg.h	412;"	d
-REG_RX_DLK_TIME_8703B	include/rtl8703b_spec.h	295;"	d
-REG_RX_DLK_TIME_8723D	hal/phydm/rtl8723d/hal8723dreg.h	384;"	d
-REG_RX_DLK_TIME_8723D	include/rtl8723d_spec.h	331;"	d
-REG_RX_DLK_TIME_8814A	include/rtl8814a_spec.h	393;"	d
-REG_RX_DRVINFO_SZ	include/hal_com_reg.h	413;"	d
-REG_RX_DRVINFO_SZ_8703B	include/rtl8703b_spec.h	296;"	d
-REG_RX_DRVINFO_SZ_8723D	hal/phydm/rtl8723d/hal8723dreg.h	385;"	d
-REG_RX_DRVINFO_SZ_8723D	include/rtl8723d_spec.h	332;"	d
-REG_RX_DRVINFO_SZ_8814A	include/rtl8814a_spec.h	394;"	d
-REG_RX_PKT_LIMIT	include/hal_com_reg.h	411;"	d
-REG_RX_PKT_LIMIT_8703B	include/rtl8703b_spec.h	294;"	d
-REG_RX_PKT_LIMIT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	383;"	d
-REG_RX_PKT_LIMIT_8723D	include/rtl8723d_spec.h	330;"	d
-REG_RX_PKT_LIMIT_8814A	include/rtl8814a_spec.h	392;"	d
-REG_RX_RXBD_NUM	include/hal_com_reg.h	219;"	d
-REG_RX_RXBD_NUM_8192E	include/rtl8192e_spec.h	124;"	d
-REG_RX_RXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	184;"	d
-REG_RX_RXBD_NUM_8723D	include/rtl8723d_spec.h	164;"	d
-REG_RX_RXBD_NUM_8814A	include/rtl8814a_spec.h	192;"	d
-REG_SCH_CURRENT_BCN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	359;"	d
-REG_SCH_EARLY_DWEND_8723D	hal/phydm/rtl8723d/hal8723dreg.h	371;"	d
-REG_SCH_MULTI_BCN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	358;"	d
-REG_SCH_M_DW_8723D	hal/phydm/rtl8723d/hal8723dreg.h	369;"	d
-REG_SCH_M_SLOT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	370;"	d
-REG_SCH_PORT2_EARLY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	362;"	d
-REG_SCH_SDFX_EARLY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	361;"	d
-REG_SCH_TSFT_DIFF_8723D	hal/phydm/rtl8723d/hal8723dreg.h	363;"	d
-REG_SCH_TXCMD_8192E	include/rtl8192e_spec.h	197;"	d
-REG_SCH_TXCMD_8703B	include/rtl8703b_spec.h	284;"	d
-REG_SCH_TXCMD_8723D	hal/phydm/rtl8723d/hal8723dreg.h	372;"	d
-REG_SCH_TXCMD_8723D	include/rtl8723d_spec.h	320;"	d
-REG_SCH_TXCMD_8812A	include/rtl8812a_spec.h	152;"	d
-REG_SCH_TX_CMD	include/hal_com_reg.h	396;"	d
-REG_SDIO_CTRL_8192E	include/rtl8192e_spec.h	46;"	d
-REG_SDIO_CTRL_8703B	include/rtl8703b_spec.h	69;"	d
-REG_SDIO_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	65;"	d
-REG_SDIO_CTRL_8723D	include/rtl8723d_spec.h	69;"	d
-REG_SDIO_CTRL_8812	include/rtl8812a_spec.h	44;"	d
-REG_SDIO_CTRL_8814A	include/rtl8814a_spec.h	71;"	d
-REG_SECCFG	include/hal_com_reg.h	478;"	d
-REG_SECCFG_8703B	include/rtl8703b_spec.h	321;"	d
-REG_SECCFG_8723D	hal/phydm/rtl8723d/hal8723dreg.h	408;"	d
-REG_SECCFG_8723D	include/rtl8723d_spec.h	357;"	d
-REG_SECCFG_8814A	include/rtl8814a_spec.h	417;"	d
-REG_SECONDARY_CCA_CTRL_8188F	include/rtl8188f_spec.h	123;"	d
-REG_SECONDARY_CCA_CTRL_8192E	include/rtl8192e_spec.h	196;"	d
-REG_SECONDARY_CCA_CTRL_8703B	include/rtl8703b_spec.h	279;"	d
-REG_SECONDARY_CCA_CTRL_8723B	include/rtl8723b_spec.h	123;"	d
-REG_SECONDARY_CCA_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	353;"	d
-REG_SECONDARY_CCA_CTRL_8723D	include/rtl8723d_spec.h	315;"	d
-REG_SECONDARY_CCA_CTRL_8812	include/rtl8812a_spec.h	151;"	d
-REG_SECONDARY_CCA_CTRL_8814A	include/rtl8814a_spec.h	376;"	d
-REG_SIFS_CTX	include/hal_com_reg.h	342;"	d
-REG_SIFS_CTX_8703B	include/rtl8703b_spec.h	239;"	d
-REG_SIFS_CTX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	313;"	d
-REG_SIFS_CTX_8723D	include/rtl8723d_spec.h	275;"	d
-REG_SIFS_CTX_8814A	include/rtl8814a_spec.h	336;"	d
-REG_SIFS_TRX	include/hal_com_reg.h	343;"	d
-REG_SIFS_TRX_8703B	include/rtl8703b_spec.h	240;"	d
-REG_SIFS_TRX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	314;"	d
-REG_SIFS_TRX_8723D	include/rtl8723d_spec.h	276;"	d
-REG_SIFS_TRX_8814A	include/rtl8814a_spec.h	337;"	d
-REG_SINGLE_AMPDU_CTRL	include/hal_com_reg.h	302;"	d
-REG_SINGLE_AMPDU_CTRL_8814A	include/rtl8814a_spec.h	305;"	d
-REG_SLOT	include/hal_com_reg.h	346;"	d
-REG_SLOT_8703B	include/rtl8703b_spec.h	242;"	d
-REG_SLOT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	316;"	d
-REG_SLOT_8723D	include/rtl8723d_spec.h	278;"	d
-REG_SLOT_8814A	include/rtl8814a_spec.h	339;"	d
-REG_SND_PTCL_CTRL_8192E	include/rtl8192e_spec.h	217;"	d
-REG_SND_PTCL_CTRL_8703B	include/rtl8703b_spec.h	345;"	d
-REG_SND_PTCL_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	430;"	d
-REG_SND_PTCL_CTRL_8723D	include/rtl8723d_spec.h	381;"	d
-REG_SND_PTCL_CTRL_8812A	include/rtl8812a_spec.h	172;"	d
-REG_SND_PTCL_CTRL_8814A	include/rtl8814a_spec.h	450;"	d
-REG_SPEC_SIFS	include/hal_com_reg.h	265;"	d
-REG_SPEC_SIFS_8703B	include/rtl8703b_spec.h	189;"	d
-REG_SPEC_SIFS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	237;"	d
-REG_SPEC_SIFS_8723D	include/rtl8723d_spec.h	225;"	d
-REG_SPEC_SIFS_8814A	include/rtl8814a_spec.h	256;"	d
-REG_SPS0_CTRL	include/hal_com_reg.h	52;"	d
-REG_SPS0_CTRL_6	include/hal_com_reg.h	53;"	d
-REG_SPS0_CTRL_8703B	include/rtl8703b_spec.h	39;"	d
-REG_SPS0_CTRL_8723D	include/rtl8723d_spec.h	39;"	d
-REG_SPS0_CTRL_8814A	include/rtl8814a_spec.h	41;"	d
-REG_SPS_OCP_CFG	include/hal_com_reg.h	55;"	d
-REG_SPS_OCP_CFG_8703B	include/rtl8703b_spec.h	40;"	d
-REG_SPS_OCP_CFG_8723D	include/rtl8723d_spec.h	40;"	d
-REG_STBC_8814A	include/rtl8814a_spec.h	303;"	d
-REG_STBC_CFEND_RATE_8814A	include/rtl8814a_spec.h	283;"	d
-REG_STBC_SETTING	include/hal_com_reg.h	300;"	d
-REG_STBC_SETTING_8703B	include/rtl8703b_spec.h	217;"	d
-REG_STBC_SETTING_8723D	hal/phydm/rtl8723d/hal8723dreg.h	263;"	d
-REG_STBC_SETTING_8723D	include/rtl8723d_spec.h	253;"	d
-REG_STBC_SETTING_8814A	include/rtl8814a_spec.h	302;"	d
-REG_SW_AMPDU_BURST_MODE_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	258;"	d
-REG_SW_AMPDU_BURST_MODE_CTRL_8814A	include/rtl8814a_spec.h	299;"	d
-REG_SYSTEM_ON_CTRL	include/hal_com_reg.h	97;"	d
-REG_SYS_CFG	include/hal_com_reg.h	106;"	d
-REG_SYS_CFG1_8192E	include/rtl8192e_spec.h	58;"	d
-REG_SYS_CFG1_8703B	include/rtl8703b_spec.h	85;"	d
-REG_SYS_CFG1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	80;"	d
-REG_SYS_CFG1_8812	include/rtl8812a_spec.h	54;"	d
-REG_SYS_CFG1_8814A	include/rtl8814a_spec.h	80;"	d
-REG_SYS_CFG2_8192E	include/rtl8192e_spec.h	59;"	d
-REG_SYS_CFG2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	81;"	d
-REG_SYS_CFG2_8814A	include/rtl8814a_spec.h	81;"	d
-REG_SYS_CFG3_8814A	include/rtl8814a_spec.h	82;"	d
-REG_SYS_CFG_8703B	include/rtl8703b_spec.h	84;"	d
-REG_SYS_CFG_8723D	include/rtl8723d_spec.h	86;"	d
-REG_SYS_CLKR	include/hal_com_reg.h	46;"	d
-REG_SYS_CLKR_8703B	include/rtl8703b_spec.h	35;"	d
-REG_SYS_CLKR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	35;"	d
-REG_SYS_CLKR_8723D	include/rtl8723d_spec.h	35;"	d
-REG_SYS_CLKR_8812A	include/rtl8812a_spec.h	38;"	d
-REG_SYS_CLKR_8814A	include/rtl8814a_spec.h	37;"	d
-REG_SYS_CLK_CTRL	include/hal_com_reg.h	47;"	d
-REG_SYS_EEPROM_CTRL	include/hal_com_reg.h	49;"	d
-REG_SYS_EEPROM_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	36;"	d
-REG_SYS_EEPROM_CTRL_8814A	include/rtl8814a_spec.h	38;"	d
-REG_SYS_FUNC_EN	include/hal_com_reg.h	44;"	d
-REG_SYS_FUNC_EN_8703B	include/rtl8703b_spec.h	33;"	d
-REG_SYS_FUNC_EN_8723D	hal/phydm/rtl8723d/hal8723dreg.h	33;"	d
-REG_SYS_FUNC_EN_8723D	include/rtl8723d_spec.h	33;"	d
-REG_SYS_FUNC_EN_8814A	include/rtl8814a_spec.h	35;"	d
-REG_SYS_ISO_CTRL	include/hal_com_reg.h	43;"	d
-REG_SYS_ISO_CTRL_8703B	include/rtl8703b_spec.h	32;"	d
-REG_SYS_ISO_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	32;"	d
-REG_SYS_ISO_CTRL_8723D	include/rtl8723d_spec.h	32;"	d
-REG_SYS_ISO_CTRL_8814A	include/rtl8814a_spec.h	34;"	d
-REG_SYS_PW_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	34;"	d
-REG_SYS_PW_CTRL_8814A	include/rtl8814a_spec.h	36;"	d
-REG_SYS_SWR_CTRL1_8192E	include/rtl8192e_spec.h	39;"	d
-REG_SYS_SWR_CTRL1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	38;"	d
-REG_SYS_SWR_CTRL1_8814A	include/rtl8814a_spec.h	40;"	d
-REG_SYS_SWR_CTRL2_8192E	include/rtl8192e_spec.h	40;"	d
-REG_SYS_SWR_CTRL2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	39;"	d
-REG_SYS_SWR_CTRL3_8723D	hal/phydm/rtl8723d/hal8723dreg.h	40;"	d
-REG_SYS_SWR_CTRL3_8814A	include/rtl8814a_spec.h	42;"	d
-REG_TBTT_PROHIBIT	include/hal_com_reg.h	366;"	d
-REG_TBTT_PROHIBIT_8703B	include/rtl8703b_spec.h	262;"	d
-REG_TBTT_PROHIBIT_8723D	hal/phydm/rtl8723d/hal8723dreg.h	336;"	d
-REG_TBTT_PROHIBIT_8723D	include/rtl8723d_spec.h	298;"	d
-REG_TBTT_PROHIBIT_8814A	include/rtl8814a_spec.h	359;"	d
-REG_TC0_CTRL	include/hal_com_reg.h	142;"	d
-REG_TC0_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	104;"	d
-REG_TC0_CTRL_8814A	include/rtl8814a_spec.h	107;"	d
-REG_TC1_CTRL	include/hal_com_reg.h	143;"	d
-REG_TC1_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	105;"	d
-REG_TC1_CTRL_8814A	include/rtl8814a_spec.h	108;"	d
-REG_TC2_CTRL	include/hal_com_reg.h	144;"	d
-REG_TC2_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	106;"	d
-REG_TC2_CTRL_8814A	include/rtl8814a_spec.h	109;"	d
-REG_TC3_CTRL	include/hal_com_reg.h	145;"	d
-REG_TC3_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	107;"	d
-REG_TC3_CTRL_8814A	include/rtl8814a_spec.h	110;"	d
-REG_TC4_CTRL	include/hal_com_reg.h	146;"	d
-REG_TC4_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	108;"	d
-REG_TC4_CTRL_8814A	include/rtl8814a_spec.h	111;"	d
-REG_TCR	include/hal_com_reg.h	409;"	d
-REG_TCR_8703B	include/rtl8703b_spec.h	292;"	d
-REG_TCR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	381;"	d
-REG_TCR_8723D	include/rtl8723d_spec.h	328;"	d
-REG_TCR_8814A	include/rtl8814a_spec.h	390;"	d
-REG_TCUNIT_BASE	include/hal_com_reg.h	147;"	d
-REG_TCUNIT_BASE_8723D	hal/phydm/rtl8723d/hal8723dreg.h	109;"	d
-REG_TCUNIT_BASE_8814A	include/rtl8814a_spec.h	112;"	d
-REG_TDECTRL	include/hal_com_reg.h	176;"	d
-REG_TDECTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	139;"	d
-REG_TDECTRL_8812A	include/rtl8812a_spec.h	90;"	d
-REG_TEST_SIE_CHIRP_K	include/hal_com_reg.h	534;"	d
-REG_TEST_SIE_MAC_ADDR	include/hal_com_reg.h	536;"	d
-REG_TEST_SIE_OPTIONAL	include/hal_com_reg.h	533;"	d
-REG_TEST_SIE_PHY	include/hal_com_reg.h	535;"	d
-REG_TEST_SIE_PID	include/hal_com_reg.h	532;"	d
-REG_TEST_SIE_STRING	include/hal_com_reg.h	537;"	d
-REG_TEST_SIE_VID	include/hal_com_reg.h	531;"	d
-REG_TEST_USB_TXQS	include/hal_com_reg.h	530;"	d
-REG_TIMER0	include/hal_com_reg.h	386;"	d
-REG_TIMER0_8703B	include/rtl8703b_spec.h	281;"	d
-REG_TIMER0_8723D	hal/phydm/rtl8723d/hal8723dreg.h	356;"	d
-REG_TIMER0_8723D	include/rtl8723d_spec.h	317;"	d
-REG_TIMER0_8814A	include/rtl8814a_spec.h	378;"	d
-REG_TIMER1	include/hal_com_reg.h	387;"	d
-REG_TIMER1_8703B	include/rtl8703b_spec.h	282;"	d
-REG_TIMER1_8723D	hal/phydm/rtl8723d/hal8723dreg.h	357;"	d
-REG_TIMER1_8723D	include/rtl8723d_spec.h	318;"	d
-REG_TIMER1_8814A	include/rtl8814a_spec.h	379;"	d
-REG_TQPNT1_8814A	include/rtl8814a_spec.h	142;"	d
-REG_TQPNT2_8814A	include/rtl8814a_spec.h	143;"	d
-REG_TQPNT3_8814A	include/rtl8814a_spec.h	144;"	d
-REG_TQPNT4_8814A	include/rtl8814a_spec.h	145;"	d
-REG_TRXDMA_CTRL	include/hal_com_reg.h	124;"	d
-REG_TRXDMA_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	92;"	d
-REG_TRXDMA_CTRL_8814A	include/rtl8814a_spec.h	92;"	d
-REG_TRXFF_BNDY	include/hal_com_reg.h	125;"	d
-REG_TRXFF_BNDY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	93;"	d
-REG_TRXFF_BNDY_8814A	include/rtl8814a_spec.h	93;"	d
-REG_TRXFF_STATUS	include/hal_com_reg.h	126;"	d
-REG_TRXFF_STATUS_8814A	include/rtl8814a_spec.h	94;"	d
-REG_TRXPTCL_CTL_8703B	include/rtl8703b_spec.h	314;"	d
-REG_TRXPTCL_CTL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	401;"	d
-REG_TRXPTCL_CTL_8723D	include/rtl8723d_spec.h	350;"	d
-REG_TRXPTCL_CTL_8814A	include/rtl8814a_spec.h	410;"	d
-REG_TRYING_CNT_TH_8814A	include/rtl8814a_spec.h	296;"	d
-REG_TSFTIMER_HCI_8192E	include/rtl8192e_spec.h	137;"	d
-REG_TSFTIMER_HCI_8723D	hal/phydm/rtl8723d/hal8723dreg.h	197;"	d
-REG_TSFTIMER_HCI_8723D	include/rtl8723d_spec.h	177;"	d
-REG_TSFTIMER_HCI_8814A	include/rtl8814a_spec.h	205;"	d
-REG_TSFTR	include/hal_com_reg.h	381;"	d
-REG_TSFTR1	include/hal_com_reg.h	382;"	d
-REG_TSFTR1	include/rtl8822b_hal.h	42;"	d
-REG_TSFTR2_8723D	hal/phydm/rtl8723d/hal8723dreg.h	354;"	d
-REG_TSFTR_8703B	include/rtl8703b_spec.h	277;"	d
-REG_TSFTR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	351;"	d
-REG_TSFTR_8723D	include/rtl8723d_spec.h	313;"	d
-REG_TSFTR_8814A	include/rtl8814a_spec.h	374;"	d
-REG_TSFTR_SYN_OFFSET	include/hal_com_reg.h	344;"	d
-REG_TXBF_CTRL_8192E	include/rtl8192e_spec.h	168;"	d
-REG_TXBF_CTRL_8703B	include/rtl8703b_spec.h	191;"	d
-REG_TXBF_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	239;"	d
-REG_TXBF_CTRL_8723D	include/rtl8723d_spec.h	227;"	d
-REG_TXBF_CTRL_8812A	include/rtl8812a_spec.h	122;"	d
-REG_TXBF_CTRL_8814A	include/rtl8814a_spec.h	258;"	d
-REG_TXDMA_OFFSET_CHK	include/hal_com_reg.h	177;"	d
-REG_TXDMA_OFFSET_CHK_8703B	include/rtl8703b_spec.h	121;"	d
-REG_TXDMA_OFFSET_CHK_8723D	hal/phydm/rtl8723d/hal8723dreg.h	140;"	d
-REG_TXDMA_OFFSET_CHK_8723D	include/rtl8723d_spec.h	121;"	d
-REG_TXDMA_OFFSET_CHK_8814A	include/rtl8814a_spec.h	139;"	d
-REG_TXDMA_STATUS	include/hal_com_reg.h	178;"	d
-REG_TXDMA_STATUS_8703B	include/rtl8703b_spec.h	122;"	d
-REG_TXDMA_STATUS_8723D	hal/phydm/rtl8723d/hal8723dreg.h	141;"	d
-REG_TXDMA_STATUS_8723D	include/rtl8723d_spec.h	122;"	d
-REG_TXDMA_STATUS_8814A	include/rtl8814a_spec.h	140;"	d
-REG_TXPAUSE	include/hal_com_reg.h	348;"	d
-REG_TXPAUSE_8703B	include/rtl8703b_spec.h	244;"	d
-REG_TXPAUSE_8723D	hal/phydm/rtl8723d/hal8723dreg.h	318;"	d
-REG_TXPAUSE_8723D	include/rtl8723d_spec.h	280;"	d
-REG_TXPAUSE_8812A	include/rtl8812a_spec.h	149;"	d
-REG_TXPAUSE_8814A	include/rtl8814a_spec.h	341;"	d
-REG_TXPKTBUF_BCNQ1_BDNY_8814A	include/rtl8814a_spec.h	266;"	d
-REG_TXPKTBUF_BCNQ_BDNY1_8703B	include/rtl8703b_spec.h	199;"	d
-REG_TXPKTBUF_BCNQ_BDNY1_8723D	include/rtl8723d_spec.h	235;"	d
-REG_TXPKTBUF_BCNQ_BDNY1_8812	include/rtl8812a_spec.h	127;"	d
-REG_TXPKTBUF_BCNQ_BDNY_8188F	include/rtl8188f_spec.h	109;"	d
-REG_TXPKTBUF_BCNQ_BDNY_8703B	include/rtl8703b_spec.h	185;"	d
-REG_TXPKTBUF_BCNQ_BDNY_8723B	include/rtl8723b_spec.h	109;"	d
-REG_TXPKTBUF_BCNQ_BDNY_8723D	include/rtl8723d_spec.h	221;"	d
-REG_TXPKTBUF_BCNQ_BDNY_8814A	include/rtl8814a_spec.h	252;"	d
-REG_TXPKTBUF_DBG	include/rtl8188e_spec.h	62;"	d
-REG_TXPKTBUF_DBG	include/rtl8192e_spec.h	67;"	d
-REG_TXPKTBUF_DBG	include/rtl8812a_spec.h	64;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8188e_spec.h	90;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8188f_spec.h	114;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8192e_spec.h	181;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8703b_spec.h	209;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8723b_spec.h	114;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8723d_spec.h	245;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8812a_spec.h	135;"	d
-REG_TXPKTBUF_IV_HIGH	include/rtl8814a_spec.h	289;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8188e_spec.h	89;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8188f_spec.h	113;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8192e_spec.h	180;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8703b_spec.h	208;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8723b_spec.h	113;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8723d_spec.h	244;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8812a_spec.h	134;"	d
-REG_TXPKTBUF_IV_LOW	include/rtl8814a_spec.h	288;"	d
-REG_TXPKTBUF_MGQ_BDNY_8188F	include/rtl8188f_spec.h	110;"	d
-REG_TXPKTBUF_MGQ_BDNY_8703B	include/rtl8703b_spec.h	186;"	d
-REG_TXPKTBUF_MGQ_BDNY_8723B	include/rtl8723b_spec.h	110;"	d
-REG_TXPKTBUF_MGQ_BDNY_8723D	include/rtl8723d_spec.h	222;"	d
-REG_TXPKTBUF_WMAC_LBK_BF_HD_8188F	include/rtl8188f_spec.h	111;"	d
-REG_TXPKTBUF_WMAC_LBK_BF_HD_8703B	include/rtl8703b_spec.h	202;"	d
-REG_TXPKTBUF_WMAC_LBK_BF_HD_8723B	include/rtl8723b_spec.h	111;"	d
-REG_TXPKTBUF_WMAC_LBK_BF_HD_8723D	hal/phydm/rtl8723d/hal8723dreg.h	272;"	d
-REG_TXPKTBUF_WMAC_LBK_BF_HD_8723D	include/rtl8723d_spec.h	238;"	d
-REG_TXPKTBUF_WMAC_LBK_BF_HD_8812	include/rtl8812a_spec.h	130;"	d
-REG_TXPKT_EMPTY	include/hal_com_reg.h	257;"	d
-REG_TXPKT_EMPTY_8703B	include/rtl8703b_spec.h	181;"	d
-REG_TXPKT_EMPTY_8723D	hal/phydm/rtl8723d/hal8723dreg.h	229;"	d
-REG_TXPKT_EMPTY_8723D	include/rtl8723d_spec.h	217;"	d
-REG_TXPKT_EMPTY_8812A	include/rtl8812a_spec.h	120;"	d
-REG_TXPKT_EMPTY_8814A	include/rtl8814a_spec.h	248;"	d
-REG_TXRPT_START_OFFSET	hal/phydm/rtl8723d/hal8723dreg.h	255;"	d
-REG_TXRPT_START_OFFSET	include/rtl8192e_spec.h	185;"	d
-REG_TXRPT_START_OFFSET	include/rtl8703b_spec.h	211;"	d
-REG_TXRPT_START_OFFSET	include/rtl8723d_spec.h	247;"	d
-REG_TXRPT_START_OFFSET	include/rtl8812a_spec.h	139;"	d
-REG_TXRPT_START_OFFSET_8814A	include/rtl8814a_spec.h	295;"	d
-REG_TX_DATA_RSP_RATE_8814A	include/rtl8814a_spec.h	429;"	d
-REG_TX_HANG_CTRL_8814A	include/rtl8814a_spec.h	270;"	d
-REG_TX_PTCL_CTRL	include/hal_com_reg.h	347;"	d
-REG_TX_PTCL_CTRL_8703B	include/rtl8703b_spec.h	243;"	d
-REG_TX_PTCL_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	317;"	d
-REG_TX_PTCL_CTRL_8723D	include/rtl8723d_spec.h	279;"	d
-REG_TX_PTCL_CTRL_8814A	include/rtl8814a_spec.h	340;"	d
-REG_TX_RPT_CTRL	include/hal_com_reg.h	326;"	d
-REG_TX_RPT_TIME	include/hal_com_reg.h	327;"	d
-REG_TYPE_ID	include/hal_com_reg.h	108;"	d
-REG_UAPSD_TID	include/hal_com_reg.h	483;"	d
-REG_UAPSD_TID_8703B	include/rtl8703b_spec.h	326;"	d
-REG_UAPSD_TID_8723D	hal/phydm/rtl8723d/hal8723dreg.h	413;"	d
-REG_UAPSD_TID_8723D	include/rtl8723d_spec.h	362;"	d
-REG_UAPSD_TID_8814A	include/rtl8814a_spec.h	422;"	d
-REG_USB_AGG_TH	include/hal_com_reg.h	518;"	d
-REG_USB_AGG_TO	include/hal_com_reg.h	517;"	d
-REG_USB_DMA_AGG_TO	include/hal_com_reg.h	516;"	d
-REG_USB_HCPWM	include/hal_com_reg.h	521;"	d
-REG_USB_HIMR	include/hal_com_reg.h	230;"	d
-REG_USB_HIMRE	include/hal_com_reg.h	231;"	d
-REG_USB_HISR	include/hal_com_reg.h	232;"	d
-REG_USB_HISRE	include/hal_com_reg.h	233;"	d
-REG_USB_HRPWM	include/hal_com_reg.h	520;"	d
-REG_USB_HRPWM_U3	include/rtl8814a_spec.h	639;"	d
-REG_USB_High_NORMAL_Queue_Select_MAC0	include/hal_com_reg.h	524;"	d
-REG_USB_High_NORMAL_Queue_Select_MAC1	include/hal_com_reg.h	526;"	d
-REG_USB_INFO	include/hal_com_reg.h	514;"	d
-REG_USB_SIE_INTF	include/hal_com_reg.h	102;"	d
-REG_USB_SPECIAL_OPTION	include/hal_com_reg.h	515;"	d
-REG_USTIME_EDCA	include/hal_com_reg.h	422;"	d
-REG_USTIME_EDCA_8703B	include/rtl8703b_spec.h	305;"	d
-REG_USTIME_EDCA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	392;"	d
-REG_USTIME_EDCA_8723D	include/rtl8723d_spec.h	341;"	d
-REG_USTIME_EDCA_8814A	include/rtl8814a_spec.h	401;"	d
-REG_USTIME_TSF	include/hal_com_reg.h	377;"	d
-REG_USTIME_TSF_8703B	include/rtl8703b_spec.h	273;"	d
-REG_USTIME_TSF_8723D	hal/phydm/rtl8723d/hal8723dreg.h	347;"	d
-REG_USTIME_TSF_8723D	include/rtl8723d_spec.h	309;"	d
-REG_USTIME_TSF_8814A	include/rtl8814a_spec.h	370;"	d
-REG_VIQ_DESA	include/hal_com_reg.h	205;"	d
-REG_VIQ_DESA_8188F	include/rtl8188f_spec.h	88;"	d
-REG_VIQ_DESA_8703B	include/rtl8703b_spec.h	153;"	d
-REG_VIQ_DESA_8723B	include/rtl8723b_spec.h	88;"	d
-REG_VIQ_INFO	include/hal_com_reg.h	244;"	d
-REG_VIQ_INFORMATION_8703B	include/rtl8703b_spec.h	175;"	d
-REG_VIQ_INFORMATION_8723D	include/rtl8723d_spec.h	211;"	d
-REG_VIQ_INFORMATION_8814A	include/rtl8814a_spec.h	242;"	d
-REG_VIQ_TXBD_DESA_8192E	include/rtl8192e_spec.h	111;"	d
-REG_VIQ_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	171;"	d
-REG_VIQ_TXBD_DESA_8723D	include/rtl8723d_spec.h	151;"	d
-REG_VIQ_TXBD_DESA_8814A	include/rtl8814a_spec.h	179;"	d
-REG_VIQ_TXBD_IDX_8192E	include/rtl8192e_spec.h	141;"	d
-REG_VIQ_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	201;"	d
-REG_VIQ_TXBD_IDX_8723D	include/rtl8723d_spec.h	182;"	d
-REG_VIQ_TXBD_IDX_8814A	include/rtl8814a_spec.h	209;"	d
-REG_VIQ_TXBD_NUM_8192E	include/rtl8192e_spec.h	126;"	d
-REG_VIQ_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	186;"	d
-REG_VIQ_TXBD_NUM_8723D	include/rtl8723d_spec.h	166;"	d
-REG_VIQ_TXBD_NUM_8814A	include/rtl8814a_spec.h	194;"	d
-REG_VOQ_DESA	include/hal_com_reg.h	204;"	d
-REG_VOQ_DESA_8188F	include/rtl8188f_spec.h	87;"	d
-REG_VOQ_DESA_8703B	include/rtl8703b_spec.h	152;"	d
-REG_VOQ_DESA_8723B	include/rtl8723b_spec.h	87;"	d
-REG_VOQ_INFO	include/hal_com_reg.h	243;"	d
-REG_VOQ_INFORMATION_8703B	include/rtl8703b_spec.h	174;"	d
-REG_VOQ_INFORMATION_8723D	include/rtl8723d_spec.h	210;"	d
-REG_VOQ_INFORMATION_8814A	include/rtl8814a_spec.h	241;"	d
-REG_VOQ_TXBD_DESA_8192E	include/rtl8192e_spec.h	110;"	d
-REG_VOQ_TXBD_DESA_8723D	hal/phydm/rtl8723d/hal8723dreg.h	170;"	d
-REG_VOQ_TXBD_DESA_8723D	include/rtl8723d_spec.h	150;"	d
-REG_VOQ_TXBD_DESA_8814A	include/rtl8814a_spec.h	178;"	d
-REG_VOQ_TXBD_IDX_8192E	include/rtl8192e_spec.h	140;"	d
-REG_VOQ_TXBD_IDX_8723D	hal/phydm/rtl8723d/hal8723dreg.h	200;"	d
-REG_VOQ_TXBD_IDX_8723D	include/rtl8723d_spec.h	181;"	d
-REG_VOQ_TXBD_IDX_8814A	include/rtl8814a_spec.h	208;"	d
-REG_VOQ_TXBD_NUM_8192E	include/rtl8192e_spec.h	125;"	d
-REG_VOQ_TXBD_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	185;"	d
-REG_VOQ_TXBD_NUM_8723D	include/rtl8723d_spec.h	165;"	d
-REG_VOQ_TXBD_NUM_8814A	include/rtl8814a_spec.h	193;"	d
-REG_WATCH_DOG	include/hal_com_reg.h	218;"	d
-REG_WKFMCAM_CMD	include/hal_com_reg.h	484;"	d
-REG_WKFMCAM_CMD_8703B	include/rtl8703b_spec.h	327;"	d
-REG_WKFMCAM_CMD_8723D	include/rtl8723d_spec.h	363;"	d
-REG_WKFMCAM_NUM	include/hal_com_reg.h	485;"	d
-REG_WKFMCAM_NUM_8703B	include/rtl8703b_spec.h	328;"	d
-REG_WKFMCAM_NUM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	414;"	d
-REG_WKFMCAM_NUM_8723D	include/rtl8723d_spec.h	364;"	d
-REG_WKFMCAM_NUM_8814A	include/rtl8814a_spec.h	423;"	d
-REG_WKFMCAM_RWD	include/hal_com_reg.h	486;"	d
-REG_WKFMCAM_RWD_8703B	include/rtl8703b_spec.h	329;"	d
-REG_WKFMCAM_RWD_8723D	include/rtl8723d_spec.h	365;"	d
-REG_WLLPS_CTRL	include/rtl8723d_spec.h	78;"	d
-REG_WLLPS_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	72;"	d
-REG_WMAC_LBK_BF_HD	include/hal_com_reg.h	279;"	d
-REG_WMAC_LBK_BUF_HD_8192E	include/rtl8192e_spec.h	176;"	d
-REG_WMAC_LBK_BUF_HD_8723D	hal/phydm/rtl8723d/hal8723dreg.h	250;"	d
-REG_WMAC_LBK_BUF_HD_8814A	include/rtl8814a_spec.h	279;"	d
-REG_WMAC_TRXPTCL_CTL	include/hal_com_reg.h	471;"	d
-REG_WOL_EVENT	include/hal_com_reg.h	93;"	d
-REG_WOWLAN_GTK_DBG1	include/rtl8188f_spec.h	55;"	d
-REG_WOWLAN_GTK_DBG1	include/rtl8703b_spec.h	302;"	d
-REG_WOWLAN_GTK_DBG1	include/rtl8723b_spec.h	55;"	d
-REG_WOWLAN_GTK_DBG1	include/rtl8723d_spec.h	338;"	d
-REG_WOWLAN_GTK_DBG2	include/rtl8188f_spec.h	56;"	d
-REG_WOWLAN_GTK_DBG2	include/rtl8703b_spec.h	303;"	d
-REG_WOWLAN_GTK_DBG2	include/rtl8723b_spec.h	56;"	d
-REG_WOWLAN_GTK_DBG2	include/rtl8723d_spec.h	339;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8188e_spec.h	63;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8188f_spec.h	54;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8192e_spec.h	68;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8703b_spec.h	100;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8723b_spec.h	54;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8723d_spec.h	100;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8812a_spec.h	65;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8814a_spec.h	105;"	d
-REG_WOWLAN_WAKE_REASON	include/rtl8821a_spec.h	45;"	d
-REG_WOW_CTRL	include/hal_com_reg.h	481;"	d
-REG_WOW_CTRL_8703B	include/rtl8703b_spec.h	324;"	d
-REG_WOW_CTRL_8723D	hal/phydm/rtl8723d/hal8723dreg.h	411;"	d
-REG_WOW_CTRL_8723D	include/rtl8723d_spec.h	360;"	d
-REG_WOW_CTRL_8814A	include/rtl8814a_spec.h	420;"	d
-REG_XCK_OUT_CTRL	include/hal_com_reg.h	91;"	d
-REG_XTAL_AAC_8723D	hal/phydm/rtl8723d/hal8723dreg.h	79;"	d
-RELEASE_ANTDIV_TIMMER	hal/phydm/phydm_antdiv.h	92;"	d
-RELEASE_DATE_8723D	hal/phydm/rtl8723d/version_rtl8723d.h	3;"	d
-RELEASE_GLOBAL_MUTEX	include/osdep_service_bsd.h	722;"	d
-RELEASE_GLOBAL_MUTEX	include/osdep_service_ce.h	168;"	d
-RELEASE_GLOBAL_MUTEX	include/osdep_service_linux.h	346;"	d
-RELEASE_GLOBAL_MUTEX	include/osdep_service_xp.h	178;"	d
-RELEASE_VERSION_8723D	hal/phydm/rtl8723d/version_rtl8723d.h	5;"	d
-REORDER_WAIT_TIME	include/rtw_recv.h	289;"	d
-RESET_SECURITYPRIV	include/rtw_cmd.h	/^	RESET_SECURITYPRIV, \/* add for CONFIG_IEEE80211W, none 11w also can use *\/$/;"	e	enum:rtw_drvextra_cmd_id
-RESTORE_DEFAULT_NHM_SETTING	hal/phydm/phydm_acs.h	32;"	d
-RESTORE_NHM_SETTING	hal/phydm/phydm_ccx.h	8;"	d
-RESV_FMWF	include/rtl8188e_hal.h	125;"	d
-RESV_FMWF	include/rtl8188e_hal.h	127;"	d
-RESV_FMWF	include/rtl8188f_hal.h	102;"	d
-RESV_FMWF	include/rtl8188f_hal.h	104;"	d
-RESV_FMWF	include/rtl8192e_hal.h	117;"	d
-RESV_FMWF	include/rtl8192e_hal.h	119;"	d
-RESV_FMWF	include/rtl8703b_hal.h	100;"	d
-RESV_FMWF	include/rtl8703b_hal.h	98;"	d
-RESV_FMWF	include/rtl8723b_hal.h	100;"	d
-RESV_FMWF	include/rtl8723b_hal.h	98;"	d
-RESV_FMWF	include/rtl8723d_hal.h	102;"	d
-RESV_FMWF	include/rtl8723d_hal.h	104;"	d
-RESV_FMWF	include/rtl8812a_hal.h	131;"	d
-RESV_FMWF	include/rtl8812a_hal.h	133;"	d
-RETRY_LIMIT_LONG_SHIFT	include/hal_com_reg.h	1473;"	d
-RETRY_LIMIT_SHORT_SHIFT	include/hal_com_reg.h	1472;"	d
-RF6052_MAX_PATH	include/hal_phy.h	46;"	d
-RF6052_MAX_REG	include/hal_phy.h	40;"	d
-RF6052_MAX_REG_88E	include/hal_phy.h	37;"	d
-RF6052_MAX_REG_92C	include/hal_phy.h	38;"	d
-RF6052_MAX_TX_PWR	include/hal_phy.h	36;"	d
-RFC1042_OUI	core/rtw_xmit.c	/^static u8 RFC1042_OUI[P80211_OUI_LEN] = { 0x00, 0x00, 0x00 };$/;"	v	file:
-RFCalibrateInfo	hal/phydm/phydm.h	/^	ODM_RF_CAL_T	RFCalibrateInfo;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RFEType	hal/phydm/phydm.h	/^	u1Byte			RFEType;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RFEType	include/hal_data.h	/^	u16	RFEType;$/;"	m	struct:hal_com_data
-RFE_Type	include/drv_types.h	/^	u8	RFE_Type;$/;"	m	struct:registry_priv
-RFINI_RDY	include/hal_com_reg.h	1244;"	d
-RFINTFS	include/rtw_cmd.h	/^enum RFINTFS {$/;"	g
-RFPathRxEnable	hal/phydm/phydm.h	/^	u1Byte			RFPathRxEnable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RFReg18	hal/phydm/phydm_iqk.h	/^	u4Byte		RFReg18;$/;"	m	struct:_IQK_INFORMATION
-RFType	hal/phydm/phydm.h	/^	u1Byte			RFType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RFType	include/HalVerDef.h	/^	HAL_RF_TYPE_E		RFType;$/;"	m	struct:tag_HAL_VERSION
-RF_0x52	include/Hal8188EPhyReg.h	448;"	d
-RF_0x52	include/Hal8188FPhyReg.h	452;"	d
-RF_0x52	include/Hal8192EPhyReg.h	456;"	d
-RF_0x52	include/Hal8703BPhyReg.h	484;"	d
-RF_0x52	include/Hal8723BPhyReg.h	483;"	d
-RF_0x52	include/Hal8723DPhyReg.h	485;"	d
-RF_0x52	include/Hal8812PhyReg.h	313;"	d
-RF_0x52	include/Hal8814PhyReg.h	423;"	d
-RF_0x52	include/rtl8822b_hal.h	194;"	d
-RF_1T1R	include/rtw_rf.h	/^	RF_1T1R = 3,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_1T2R	include/rtw_rf.h	/^	RF_1T2R = 0,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_1TX	include/hal_com_phycfg.h	/^	RF_1TX = 0,$/;"	e	enum:_RF_TX_NUM
-RF_2T2R	include/rtw_rf.h	/^	RF_2T2R = 2,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_2T2R_GREEN	include/rtw_rf.h	/^	RF_2T2R_GREEN = 4,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_2T3R	include/rtw_rf.h	/^	RF_2T3R = 5,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_2T4R	include/rtw_rf.h	/^	RF_2T4R = 1,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_2TX	include/hal_com_phycfg.h	/^	RF_2TX,$/;"	e	enum:_RF_TX_NUM
-RF_3T3R	include/rtw_rf.h	/^	RF_3T3R = 6,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_3T4R	include/rtw_rf.h	/^	RF_3T4R	= 7,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_3TX	include/hal_com_phycfg.h	/^	RF_3TX,$/;"	e	enum:_RF_TX_NUM
-RF_4T4R	include/rtw_rf.h	/^	RF_4T4R	= 8,$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_4TX	include/hal_com_phycfg.h	/^	RF_4TX,$/;"	e	enum:_RF_TX_NUM
-RF_6052	include/hal_phy.h	/^	RF_6052 = 4,			\/* 4 11b\/g\/n RF *\/$/;"	e	enum:_RF_TYPE
-RF_8225	include/hal_phy.h	/^	RF_8225 = 1,			\/* 1 11b\/g RF for verification only *\/$/;"	e	enum:_RF_TYPE
-RF_8256	include/hal_phy.h	/^	RF_8256 = 2,			\/* 2 11b\/g\/n *\/$/;"	e	enum:_RF_TYPE
-RF_8258	include/hal_phy.h	/^	RF_8258 = 3,			\/* 3 11a\/b\/g\/n RF *\/$/;"	e	enum:_RF_TYPE
-RF_AC	include/Hal8188EPhyReg.h	377;"	d
-RF_AC	include/Hal8188FPhyReg.h	378;"	d
-RF_AC	include/Hal8192EPhyReg.h	382;"	d
-RF_AC	include/Hal8703BPhyReg.h	410;"	d
-RF_AC	include/Hal8723BPhyReg.h	409;"	d
-RF_AC	include/Hal8723DPhyReg.h	410;"	d
-RF_AC	include/Hal8812PhyReg.h	302;"	d
-RF_AC	include/Hal8814PhyReg.h	412;"	d
-RF_AC	include/rtl8822b_hal.h	188;"	d
-RF_AC	include/rtw_mp_phy_regdef.h	346;"	d
-RF_AC_Jaguar	include/Hal8812PhyReg.h	279;"	d
-RF_AC_Jaguar	include/Hal8814PhyReg.h	389;"	d
-RF_AC_Jaguar	include/rtl8822b_hal.h	189;"	d
-RF_APK_Jaguar	include/Hal8812PhyReg.h	291;"	d
-RF_APK_Jaguar	include/Hal8814PhyReg.h	401;"	d
-RF_BB_CMD_ADDR	include/Hal8188EPhyReg.h	69;"	d
-RF_BB_CMD_ADDR	include/Hal8188FPhyReg.h	75;"	d
-RF_BB_CMD_ADDR	include/Hal8703BPhyReg.h	70;"	d
-RF_BB_CMD_ADDR	include/Hal8723BPhyReg.h	70;"	d
-RF_BB_CMD_ADDR	include/Hal8723DPhyReg.h	70;"	d
-RF_BB_CMD_DATA	include/Hal8188EPhyReg.h	70;"	d
-RF_BB_CMD_DATA	include/Hal8188FPhyReg.h	76;"	d
-RF_BB_CMD_DATA	include/Hal8703BPhyReg.h	71;"	d
-RF_BB_CMD_DATA	include/Hal8723BPhyReg.h	71;"	d
-RF_BB_CMD_DATA	include/Hal8723DPhyReg.h	71;"	d
-RF_BIAS	include/Hal8188EPhyReg.h	401;"	d
-RF_BIAS	include/Hal8188FPhyReg.h	403;"	d
-RF_BIAS	include/Hal8192EPhyReg.h	406;"	d
-RF_BIAS	include/Hal8703BPhyReg.h	435;"	d
-RF_BIAS	include/Hal8723BPhyReg.h	434;"	d
-RF_BIAS	include/Hal8723DPhyReg.h	435;"	d
-RF_BIAS	include/rtw_mp_phy_regdef.h	363;"	d
-RF_BS_IQGEN	include/Hal8188EPhyReg.h	394;"	d
-RF_BS_IQGEN	include/Hal8188FPhyReg.h	396;"	d
-RF_BS_IQGEN	include/Hal8192EPhyReg.h	399;"	d
-RF_BS_IQGEN	include/Hal8703BPhyReg.h	428;"	d
-RF_BS_IQGEN	include/Hal8723BPhyReg.h	427;"	d
-RF_BS_IQGEN	include/Hal8723DPhyReg.h	428;"	d
-RF_BS_IQGEN	include/rtw_mp_phy_regdef.h	356;"	d
-RF_BS_PA_APSET_G1_G4	include/Hal8188FPhyReg.h	382;"	d
-RF_BS_PA_APSET_G1_G4	include/Hal8703BPhyReg.h	414;"	d
-RF_BS_PA_APSET_G1_G4	include/Hal8723BPhyReg.h	413;"	d
-RF_BS_PA_APSET_G1_G4	include/Hal8723DPhyReg.h	414;"	d
-RF_BS_PA_APSET_G5_G8	include/Hal8188FPhyReg.h	383;"	d
-RF_BS_PA_APSET_G5_G8	include/Hal8703BPhyReg.h	415;"	d
-RF_BS_PA_APSET_G5_G8	include/Hal8723BPhyReg.h	414;"	d
-RF_BS_PA_APSET_G5_G8	include/Hal8723DPhyReg.h	415;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8188EPhyReg.h	393;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8188FPhyReg.h	395;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8192EPhyReg.h	398;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8703BPhyReg.h	427;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8723BPhyReg.h	426;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8723DPhyReg.h	427;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8812PhyReg.h	305;"	d
-RF_BS_PA_APSET_G9_G11	include/Hal8814PhyReg.h	415;"	d
-RF_CHANGE_BY_HW	include/hal_intf.h	407;"	d
-RF_CHANGE_BY_INIT	include/hal_intf.h	404;"	d
-RF_CHANGE_BY_IPS	include/hal_intf.h	405;"	d
-RF_CHANGE_BY_PS	include/hal_intf.h	406;"	d
-RF_CHANGE_BY_SW	include/hal_intf.h	408;"	d
-RF_CHNLBW	include/Hal8188EPhyReg.h	405;"	d
-RF_CHNLBW	include/Hal8188FPhyReg.h	409;"	d
-RF_CHNLBW	include/Hal8192EPhyReg.h	410;"	d
-RF_CHNLBW	include/Hal8703BPhyReg.h	441;"	d
-RF_CHNLBW	include/Hal8723BPhyReg.h	440;"	d
-RF_CHNLBW	include/Hal8723DPhyReg.h	441;"	d
-RF_CHNLBW	include/Hal8812PhyReg.h	308;"	d
-RF_CHNLBW	include/Hal8814PhyReg.h	418;"	d
-RF_CHNLBW	include/rtl8822b_hal.h	190;"	d
-RF_CHNLBW	include/rtw_mp_phy_regdef.h	369;"	d
-RF_CHNLBW_Jaguar	include/Hal8812PhyReg.h	283;"	d
-RF_CHNLBW_Jaguar	include/Hal8814PhyReg.h	393;"	d
-RF_CONTENT	include/hal_phy.h	/^} RF_CONTENT;$/;"	t	typeref:enum:_RF_CONTENT
-RF_DBG_LP_RX2	include/Hal8188FPhyReg.h	454;"	d
-RF_EN	include/hal_com_reg.h	1211;"	d
-RF_GAIN_OFFSET_MASK	include/hal_data.h	175;"	d
-RF_GAIN_OFFSET_MASK	include/hal_data.h	178;"	d
-RF_GAIN_OFFSET_MASK	include/hal_data.h	181;"	d
-RF_GAIN_RX	include/Hal8188EPhyReg.h	384;"	d
-RF_GAIN_RX	include/Hal8188FPhyReg.h	386;"	d
-RF_GAIN_RX	include/Hal8192EPhyReg.h	389;"	d
-RF_GAIN_RX	include/Hal8703BPhyReg.h	418;"	d
-RF_GAIN_RX	include/Hal8723BPhyReg.h	417;"	d
-RF_GAIN_RX	include/Hal8723DPhyReg.h	418;"	d
-RF_GAIN_RX	include/rtw_mp_phy_regdef.h	352;"	d
-RF_GAIN_TX	include/Hal8188EPhyReg.h	385;"	d
-RF_GAIN_TX	include/Hal8188FPhyReg.h	387;"	d
-RF_GAIN_TX	include/Hal8192EPhyReg.h	390;"	d
-RF_GAIN_TX	include/Hal8703BPhyReg.h	419;"	d
-RF_GAIN_TX	include/Hal8723BPhyReg.h	418;"	d
-RF_GAIN_TX	include/Hal8723DPhyReg.h	419;"	d
-RF_GAIN_TX	include/rtw_mp_phy_regdef.h	353;"	d
-RF_IPA	include/Hal8188EPhyReg.h	402;"	d
-RF_IPA	include/Hal8188FPhyReg.h	404;"	d
-RF_IPA	include/Hal8192EPhyReg.h	407;"	d
-RF_IPA	include/Hal8703BPhyReg.h	436;"	d
-RF_IPA	include/Hal8723BPhyReg.h	435;"	d
-RF_IPA	include/Hal8723DPhyReg.h	436;"	d
-RF_IPA	include/rtw_mp_phy_regdef.h	364;"	d
-RF_IPA_A	include/Hal8188EPhyReg.h	391;"	d
-RF_IPA_A	include/Hal8188FPhyReg.h	393;"	d
-RF_IPA_A	include/Hal8192EPhyReg.h	396;"	d
-RF_IPA_A	include/Hal8703BPhyReg.h	425;"	d
-RF_IPA_A	include/Hal8723BPhyReg.h	424;"	d
-RF_IPA_A	include/Hal8723DPhyReg.h	425;"	d
-RF_IPA_A	include/Hal8812PhyReg.h	303;"	d
-RF_IPA_A	include/Hal8814PhyReg.h	413;"	d
-RF_IPA_G	include/Hal8188EPhyReg.h	388;"	d
-RF_IPA_G	include/Hal8188FPhyReg.h	390;"	d
-RF_IPA_G	include/Hal8192EPhyReg.h	393;"	d
-RF_IPA_G	include/Hal8703BPhyReg.h	422;"	d
-RF_IPA_G	include/Hal8723BPhyReg.h	421;"	d
-RF_IPA_G	include/Hal8723DPhyReg.h	422;"	d
-RF_IQADJ_G1	include/Hal8188EPhyReg.h	379;"	d
-RF_IQADJ_G1	include/Hal8188FPhyReg.h	380;"	d
-RF_IQADJ_G1	include/Hal8192EPhyReg.h	384;"	d
-RF_IQADJ_G1	include/Hal8703BPhyReg.h	412;"	d
-RF_IQADJ_G1	include/Hal8723BPhyReg.h	411;"	d
-RF_IQADJ_G1	include/Hal8723DPhyReg.h	412;"	d
-RF_IQADJ_G1	include/rtw_mp_phy_regdef.h	348;"	d
-RF_IQADJ_G2	include/Hal8188EPhyReg.h	380;"	d
-RF_IQADJ_G2	include/Hal8188FPhyReg.h	381;"	d
-RF_IQADJ_G2	include/Hal8192EPhyReg.h	385;"	d
-RF_IQADJ_G2	include/Hal8703BPhyReg.h	413;"	d
-RF_IQADJ_G2	include/Hal8723BPhyReg.h	412;"	d
-RF_IQADJ_G2	include/Hal8723DPhyReg.h	413;"	d
-RF_IQADJ_G2	include/rtw_mp_phy_regdef.h	349;"	d
-RF_LCK	include/Hal8812PhyReg.h	292;"	d
-RF_LCK	include/Hal8814PhyReg.h	402;"	d
-RF_LDO	include/Hal8192EPhyReg.h	457;"	d
-RF_LOBF_9	include/Hal8188EPhyReg.h	441;"	d
-RF_LOBF_9	include/Hal8188FPhyReg.h	445;"	d
-RF_LOBF_9	include/Hal8192EPhyReg.h	449;"	d
-RF_LOBF_9	include/Hal8703BPhyReg.h	477;"	d
-RF_LOBF_9	include/Hal8723BPhyReg.h	476;"	d
-RF_LOBF_9	include/Hal8723DPhyReg.h	477;"	d
-RF_MAX_TX_NUM	include/hal_com_phycfg.h	/^	RF_MAX_TX_NUM,$/;"	e	enum:_RF_TX_NUM
-RF_MAX_TYPE	include/rtw_rf.h	/^	RF_MAX_TYPE = 0xF, \/* u1Byte *\/$/;"	e	enum:_RT_RF_TYPE_DEFINITION
-RF_MODE1	include/Hal8188EPhyReg.h	396;"	d
-RF_MODE1	include/Hal8188FPhyReg.h	398;"	d
-RF_MODE1	include/Hal8192EPhyReg.h	401;"	d
-RF_MODE1	include/Hal8703BPhyReg.h	430;"	d
-RF_MODE1	include/Hal8723BPhyReg.h	429;"	d
-RF_MODE1	include/Hal8723DPhyReg.h	430;"	d
-RF_MODE1	include/Hal8812PhyReg.h	306;"	d
-RF_MODE1	include/Hal8814PhyReg.h	416;"	d
-RF_MODE1	include/rtw_mp_phy_regdef.h	358;"	d
-RF_MODE2	include/Hal8188EPhyReg.h	397;"	d
-RF_MODE2	include/Hal8188FPhyReg.h	399;"	d
-RF_MODE2	include/Hal8192EPhyReg.h	402;"	d
-RF_MODE2	include/Hal8703BPhyReg.h	431;"	d
-RF_MODE2	include/Hal8723BPhyReg.h	430;"	d
-RF_MODE2	include/Hal8723DPhyReg.h	431;"	d
-RF_MODE2	include/Hal8812PhyReg.h	307;"	d
-RF_MODE2	include/Hal8814PhyReg.h	417;"	d
-RF_MODE2	include/rtw_mp_phy_regdef.h	359;"	d
-RF_MODE_AG	include/Hal8188FPhyReg.h	407;"	d
-RF_MODE_AG	include/Hal8703BPhyReg.h	439;"	d
-RF_MODE_AG	include/Hal8723BPhyReg.h	438;"	d
-RF_MODE_AG	include/Hal8723DPhyReg.h	439;"	d
-RF_MODE_AG	include/rtw_mp_phy_regdef.h	367;"	d
-RF_ModeTableAddr	include/Hal8812PhyReg.h	287;"	d
-RF_ModeTableAddr	include/Hal8814PhyReg.h	397;"	d
-RF_ModeTableAddr	include/rtl8822b_hal.h	191;"	d
-RF_ModeTableData0	include/Hal8812PhyReg.h	288;"	d
-RF_ModeTableData0	include/Hal8814PhyReg.h	398;"	d
-RF_ModeTableData0	include/rtl8822b_hal.h	192;"	d
-RF_ModeTableData1	include/Hal8812PhyReg.h	289;"	d
-RF_ModeTableData1	include/Hal8814PhyReg.h	399;"	d
-RF_ModeTableData1	include/rtl8822b_hal.h	193;"	d
-RF_PATH	include/rtw_rf.h	/^} RF_PATH, *PRF_PATH;$/;"	t	typeref:enum:_RF_PATH
-RF_PATH_A	include/rtw_rf.h	/^	RF_PATH_A = 0,$/;"	e	enum:_RF_PATH
-RF_PATH_AB	hal/hal_mp.c	520;"	d	file:
-RF_PATH_B	include/rtw_rf.h	/^	RF_PATH_B = 1,$/;"	e	enum:_RF_PATH
-RF_PATH_C	include/rtw_rf.h	/^	RF_PATH_C = 2,$/;"	e	enum:_RF_PATH
-RF_PATH_D	include/rtw_rf.h	/^	RF_PATH_D = 3,$/;"	e	enum:_RF_PATH
-RF_PATH_MAX	include/hal_pg.h	742;"	d
-RF_POW_ABILITY	include/Hal8188EPhyReg.h	404;"	d
-RF_POW_ABILITY	include/Hal8188FPhyReg.h	406;"	d
-RF_POW_ABILITY	include/Hal8192EPhyReg.h	409;"	d
-RF_POW_ABILITY	include/Hal8703BPhyReg.h	438;"	d
-RF_POW_ABILITY	include/Hal8723BPhyReg.h	437;"	d
-RF_POW_ABILITY	include/Hal8723DPhyReg.h	438;"	d
-RF_POW_ABILITY	include/rtw_mp_phy_regdef.h	366;"	d
-RF_POW_TRSW	include/Hal8188EPhyReg.h	382;"	d
-RF_POW_TRSW	include/Hal8188FPhyReg.h	384;"	d
-RF_POW_TRSW	include/Hal8192EPhyReg.h	387;"	d
-RF_POW_TRSW	include/Hal8703BPhyReg.h	416;"	d
-RF_POW_TRSW	include/Hal8723BPhyReg.h	415;"	d
-RF_POW_TRSW	include/Hal8723DPhyReg.h	416;"	d
-RF_POW_TRSW	include/rtw_mp_phy_regdef.h	350;"	d
-RF_PSEUDO_11N	include/hal_phy.h	/^	RF_PSEUDO_11N = 5,	\/* 5, It is a temporality RF. *\/$/;"	e	enum:_RF_TYPE
-RF_RCK1	include/Hal8188EPhyReg.h	414;"	d
-RF_RCK1	include/Hal8188FPhyReg.h	418;"	d
-RF_RCK1	include/Hal8192EPhyReg.h	419;"	d
-RF_RCK1	include/Hal8703BPhyReg.h	450;"	d
-RF_RCK1	include/Hal8723BPhyReg.h	449;"	d
-RF_RCK1	include/Hal8723DPhyReg.h	450;"	d
-RF_RCK1	include/rtw_mp_phy_regdef.h	378;"	d
-RF_RCK1_Jaguar	include/Hal8812PhyReg.h	284;"	d
-RF_RCK1_Jaguar	include/Hal8814PhyReg.h	394;"	d
-RF_RCK2	include/Hal8188EPhyReg.h	415;"	d
-RF_RCK2	include/Hal8188FPhyReg.h	419;"	d
-RF_RCK2	include/Hal8192EPhyReg.h	420;"	d
-RF_RCK2	include/Hal8703BPhyReg.h	451;"	d
-RF_RCK2	include/Hal8723BPhyReg.h	450;"	d
-RF_RCK2	include/Hal8723DPhyReg.h	451;"	d
-RF_RCK2	include/rtw_mp_phy_regdef.h	379;"	d
-RF_RCK2_Jaguar	include/Hal8812PhyReg.h	285;"	d
-RF_RCK2_Jaguar	include/Hal8814PhyReg.h	395;"	d
-RF_RCK3_Jaguar	include/Hal8812PhyReg.h	286;"	d
-RF_RCK3_Jaguar	include/Hal8814PhyReg.h	396;"	d
-RF_RCK_OS	include/Hal8188EPhyReg.h	435;"	d
-RF_RCK_OS	include/Hal8188FPhyReg.h	438;"	d
-RF_RCK_OS	include/Hal8192EPhyReg.h	443;"	d
-RF_RCK_OS	include/Hal8703BPhyReg.h	470;"	d
-RF_RCK_OS	include/Hal8723BPhyReg.h	469;"	d
-RF_RCK_OS	include/Hal8723DPhyReg.h	470;"	d
-RF_RCK_OS	include/Hal8812PhyReg.h	309;"	d
-RF_RCK_OS	include/Hal8814PhyReg.h	419;"	d
-RF_RCK_OS	include/rtw_mp_phy_regdef.h	398;"	d
-RF_RF_Top_Jaguar	include/Hal8812PhyReg.h	280;"	d
-RF_RF_Top_Jaguar	include/Hal8814PhyReg.h	390;"	d
-RF_RL_ID	include/hal_com_reg.h	1304;"	d
-RF_RSTB	include/hal_com_reg.h	1212;"	d
-RF_RXG_MIX_SWBW	include/Hal8188FPhyReg.h	453;"	d
-RF_RXRF_A3	include/Hal8188EPhyReg.h	442;"	d
-RF_RXRF_A3	include/Hal8188FPhyReg.h	446;"	d
-RF_RXRF_A3	include/Hal8192EPhyReg.h	450;"	d
-RF_RXRF_A3	include/Hal8703BPhyReg.h	478;"	d
-RF_RXRF_A3	include/Hal8723BPhyReg.h	477;"	d
-RF_RXRF_A3	include/Hal8723DPhyReg.h	478;"	d
-RF_RX_AGC_HP	include/Hal8188EPhyReg.h	399;"	d
-RF_RX_AGC_HP	include/Hal8188FPhyReg.h	401;"	d
-RF_RX_AGC_HP	include/Hal8192EPhyReg.h	404;"	d
-RF_RX_AGC_HP	include/Hal8703BPhyReg.h	433;"	d
-RF_RX_AGC_HP	include/Hal8723BPhyReg.h	432;"	d
-RF_RX_AGC_HP	include/Hal8723DPhyReg.h	433;"	d
-RF_RX_AGC_HP	include/rtw_mp_phy_regdef.h	361;"	d
-RF_RX_BB1	include/Hal8188EPhyReg.h	412;"	d
-RF_RX_BB1	include/Hal8188FPhyReg.h	416;"	d
-RF_RX_BB1	include/Hal8192EPhyReg.h	417;"	d
-RF_RX_BB1	include/Hal8703BPhyReg.h	448;"	d
-RF_RX_BB1	include/Hal8723BPhyReg.h	447;"	d
-RF_RX_BB1	include/Hal8723DPhyReg.h	448;"	d
-RF_RX_BB1	include/rtw_mp_phy_regdef.h	376;"	d
-RF_RX_BB2	include/Hal8188EPhyReg.h	411;"	d
-RF_RX_BB2	include/Hal8188FPhyReg.h	415;"	d
-RF_RX_BB2	include/Hal8192EPhyReg.h	416;"	d
-RF_RX_BB2	include/Hal8703BPhyReg.h	447;"	d
-RF_RX_BB2	include/Hal8723BPhyReg.h	446;"	d
-RF_RX_BB2	include/Hal8723DPhyReg.h	447;"	d
-RF_RX_BB2	include/rtw_mp_phy_regdef.h	375;"	d
-RF_RX_G1	include/Hal8188EPhyReg.h	408;"	d
-RF_RX_G1	include/Hal8188FPhyReg.h	412;"	d
-RF_RX_G1	include/Hal8192EPhyReg.h	413;"	d
-RF_RX_G1	include/Hal8703BPhyReg.h	444;"	d
-RF_RX_G1	include/Hal8723BPhyReg.h	443;"	d
-RF_RX_G1	include/Hal8723DPhyReg.h	444;"	d
-RF_RX_G1	include/rtw_mp_phy_regdef.h	372;"	d
-RF_RX_G2	include/Hal8188EPhyReg.h	409;"	d
-RF_RX_G2	include/Hal8188FPhyReg.h	413;"	d
-RF_RX_G2	include/Hal8192EPhyReg.h	414;"	d
-RF_RX_G2	include/Hal8703BPhyReg.h	445;"	d
-RF_RX_G2	include/Hal8723BPhyReg.h	444;"	d
-RF_RX_G2	include/Hal8723DPhyReg.h	445;"	d
-RF_RX_G2	include/rtw_mp_phy_regdef.h	373;"	d
-RF_S0S1	include/Hal8188FPhyReg.h	456;"	d
-RF_S0S1	include/Hal8703BPhyReg.h	486;"	d
-RF_S0S1	include/Hal8723BPhyReg.h	485;"	d
-RF_S0S1	include/Hal8723DPhyReg.h	487;"	d
-RF_SDMRSTB	include/hal_com_reg.h	1213;"	d
-RF_SHADOW_T	include/hal_phy.h	/^} RF_SHADOW_T;$/;"	t	typeref:struct:RF_Shadow_Compare_Map
-RF_SYN_G1	include/Hal8188EPhyReg.h	426;"	d
-RF_SYN_G1	include/Hal8188FPhyReg.h	429;"	d
-RF_SYN_G1	include/Hal8192EPhyReg.h	434;"	d
-RF_SYN_G1	include/Hal8703BPhyReg.h	461;"	d
-RF_SYN_G1	include/Hal8723BPhyReg.h	460;"	d
-RF_SYN_G1	include/Hal8723DPhyReg.h	461;"	d
-RF_SYN_G1	include/rtw_mp_phy_regdef.h	389;"	d
-RF_SYN_G2	include/Hal8188EPhyReg.h	427;"	d
-RF_SYN_G2	include/Hal8188FPhyReg.h	430;"	d
-RF_SYN_G2	include/Hal8192EPhyReg.h	435;"	d
-RF_SYN_G2	include/Hal8703BPhyReg.h	462;"	d
-RF_SYN_G2	include/Hal8723BPhyReg.h	461;"	d
-RF_SYN_G2	include/Hal8723DPhyReg.h	462;"	d
-RF_SYN_G2	include/rtw_mp_phy_regdef.h	390;"	d
-RF_SYN_G3	include/Hal8188EPhyReg.h	428;"	d
-RF_SYN_G3	include/Hal8188FPhyReg.h	431;"	d
-RF_SYN_G3	include/Hal8192EPhyReg.h	436;"	d
-RF_SYN_G3	include/Hal8703BPhyReg.h	463;"	d
-RF_SYN_G3	include/Hal8723BPhyReg.h	462;"	d
-RF_SYN_G3	include/Hal8723DPhyReg.h	463;"	d
-RF_SYN_G3	include/rtw_mp_phy_regdef.h	391;"	d
-RF_SYN_G4	include/Hal8188EPhyReg.h	429;"	d
-RF_SYN_G4	include/Hal8188FPhyReg.h	432;"	d
-RF_SYN_G4	include/Hal8192EPhyReg.h	437;"	d
-RF_SYN_G4	include/Hal8703BPhyReg.h	464;"	d
-RF_SYN_G4	include/Hal8723BPhyReg.h	463;"	d
-RF_SYN_G4	include/Hal8723DPhyReg.h	464;"	d
-RF_SYN_G4	include/rtw_mp_phy_regdef.h	392;"	d
-RF_SYN_G5	include/Hal8188EPhyReg.h	430;"	d
-RF_SYN_G5	include/Hal8188FPhyReg.h	433;"	d
-RF_SYN_G5	include/Hal8192EPhyReg.h	438;"	d
-RF_SYN_G5	include/Hal8703BPhyReg.h	465;"	d
-RF_SYN_G5	include/Hal8723BPhyReg.h	464;"	d
-RF_SYN_G5	include/Hal8723DPhyReg.h	465;"	d
-RF_SYN_G5	include/rtw_mp_phy_regdef.h	393;"	d
-RF_SYN_G6	include/Hal8188EPhyReg.h	431;"	d
-RF_SYN_G6	include/Hal8188FPhyReg.h	434;"	d
-RF_SYN_G6	include/Hal8192EPhyReg.h	439;"	d
-RF_SYN_G6	include/Hal8703BPhyReg.h	466;"	d
-RF_SYN_G6	include/Hal8723BPhyReg.h	465;"	d
-RF_SYN_G6	include/Hal8723DPhyReg.h	466;"	d
-RF_SYN_G6	include/rtw_mp_phy_regdef.h	394;"	d
-RF_SYN_G7	include/Hal8188EPhyReg.h	432;"	d
-RF_SYN_G7	include/Hal8188FPhyReg.h	435;"	d
-RF_SYN_G7	include/Hal8192EPhyReg.h	440;"	d
-RF_SYN_G7	include/Hal8703BPhyReg.h	467;"	d
-RF_SYN_G7	include/Hal8723BPhyReg.h	466;"	d
-RF_SYN_G7	include/Hal8723DPhyReg.h	467;"	d
-RF_SYN_G7	include/rtw_mp_phy_regdef.h	395;"	d
-RF_SYN_G8	include/Hal8188EPhyReg.h	433;"	d
-RF_SYN_G8	include/Hal8188FPhyReg.h	436;"	d
-RF_SYN_G8	include/Hal8192EPhyReg.h	441;"	d
-RF_SYN_G8	include/Hal8703BPhyReg.h	468;"	d
-RF_SYN_G8	include/Hal8723BPhyReg.h	467;"	d
-RF_SYN_G8	include/Hal8723DPhyReg.h	468;"	d
-RF_SYN_G8	include/rtw_mp_phy_regdef.h	396;"	d
-RF_Shadow	hal/hal_phy.c	/^static RF_SHADOW_T RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];$/;"	v	file:
-RF_Shadow	hal/rtl8723d/rtl8723d_rf6052.c	/^static	RF_SHADOW_T	RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];$/;"	v	file:
-RF_Shadow_Compare_Map	include/hal_phy.h	/^typedef struct RF_Shadow_Compare_Map {$/;"	s
-RF_TOP	include/Hal8188EPhyReg.h	406;"	d
-RF_TOP	include/Hal8188FPhyReg.h	410;"	d
-RF_TOP	include/Hal8192EPhyReg.h	411;"	d
-RF_TOP	include/Hal8703BPhyReg.h	442;"	d
-RF_TOP	include/Hal8723BPhyReg.h	441;"	d
-RF_TOP	include/Hal8723DPhyReg.h	442;"	d
-RF_TOP	include/rtw_mp_phy_regdef.h	370;"	d
-RF_TRSW	include/Hal8188EPhyReg.h	443;"	d
-RF_TRSW	include/Hal8188FPhyReg.h	447;"	d
-RF_TRSW	include/Hal8192EPhyReg.h	451;"	d
-RF_TRSW	include/Hal8703BPhyReg.h	479;"	d
-RF_TRSW	include/Hal8723BPhyReg.h	478;"	d
-RF_TRSW	include/Hal8723DPhyReg.h	479;"	d
-RF_TXAPK_Jaguar	include/Hal8812PhyReg.h	282;"	d
-RF_TXAPK_Jaguar	include/Hal8814PhyReg.h	392;"	d
-RF_TXBIAS	include/Hal8188EPhyReg.h	403;"	d
-RF_TXBIAS	include/Hal8188FPhyReg.h	405;"	d
-RF_TXBIAS	include/Hal8192EPhyReg.h	408;"	d
-RF_TXBIAS	include/Hal8703BPhyReg.h	437;"	d
-RF_TXBIAS	include/Hal8723BPhyReg.h	436;"	d
-RF_TXBIAS	include/Hal8723DPhyReg.h	437;"	d
-RF_TXBIAS	include/rtw_mp_phy_regdef.h	365;"	d
-RF_TXBIAS_A	include/Hal8188EPhyReg.h	392;"	d
-RF_TXBIAS_A	include/Hal8188FPhyReg.h	394;"	d
-RF_TXBIAS_A	include/Hal8192EPhyReg.h	397;"	d
-RF_TXBIAS_A	include/Hal8703BPhyReg.h	426;"	d
-RF_TXBIAS_A	include/Hal8723BPhyReg.h	425;"	d
-RF_TXBIAS_A	include/Hal8723DPhyReg.h	426;"	d
-RF_TXBIAS_A	include/Hal8812PhyReg.h	304;"	d
-RF_TXBIAS_A	include/Hal8814PhyReg.h	414;"	d
-RF_TXBIAS_G	include/Hal8188EPhyReg.h	389;"	d
-RF_TXBIAS_G	include/Hal8188FPhyReg.h	391;"	d
-RF_TXBIAS_G	include/Hal8192EPhyReg.h	394;"	d
-RF_TXBIAS_G	include/Hal8703BPhyReg.h	423;"	d
-RF_TXBIAS_G	include/Hal8723BPhyReg.h	422;"	d
-RF_TXBIAS_G	include/Hal8723DPhyReg.h	423;"	d
-RF_TXLOK_Jaguar	include/Hal8812PhyReg.h	281;"	d
-RF_TXLOK_Jaguar	include/Hal8814PhyReg.h	391;"	d
-RF_TXM_IDAC	include/Hal8188EPhyReg.h	387;"	d
-RF_TXM_IDAC	include/Hal8188FPhyReg.h	389;"	d
-RF_TXM_IDAC	include/Hal8192EPhyReg.h	392;"	d
-RF_TXM_IDAC	include/Hal8703BPhyReg.h	421;"	d
-RF_TXM_IDAC	include/Hal8723BPhyReg.h	420;"	d
-RF_TXM_IDAC	include/Hal8723DPhyReg.h	421;"	d
-RF_TXM_IDAC	include/rtw_mp_phy_regdef.h	355;"	d
-RF_TXPA_A4	include/Hal8188EPhyReg.h	447;"	d
-RF_TXPA_A4	include/Hal8188FPhyReg.h	451;"	d
-RF_TXPA_A4	include/Hal8192EPhyReg.h	455;"	d
-RF_TXPA_A4	include/Hal8703BPhyReg.h	483;"	d
-RF_TXPA_A4	include/Hal8723BPhyReg.h	482;"	d
-RF_TXPA_A4	include/Hal8723DPhyReg.h	484;"	d
-RF_TXPA_AG	include/Hal8188EPhyReg.h	390;"	d
-RF_TXPA_AG	include/Hal8188FPhyReg.h	392;"	d
-RF_TXPA_AG	include/Hal8192EPhyReg.h	395;"	d
-RF_TXPA_AG	include/Hal8703BPhyReg.h	424;"	d
-RF_TXPA_AG	include/Hal8723BPhyReg.h	423;"	d
-RF_TXPA_AG	include/Hal8723DPhyReg.h	424;"	d
-RF_TXPA_G1	include/Hal8188EPhyReg.h	436;"	d
-RF_TXPA_G1	include/Hal8188FPhyReg.h	440;"	d
-RF_TXPA_G1	include/Hal8192EPhyReg.h	444;"	d
-RF_TXPA_G1	include/Hal8703BPhyReg.h	472;"	d
-RF_TXPA_G1	include/Hal8723BPhyReg.h	471;"	d
-RF_TXPA_G1	include/Hal8723DPhyReg.h	472;"	d
-RF_TXPA_G1	include/Hal8812PhyReg.h	310;"	d
-RF_TXPA_G1	include/Hal8814PhyReg.h	420;"	d
-RF_TXPA_G1	include/rtw_mp_phy_regdef.h	400;"	d
-RF_TXPA_G2	include/Hal8188EPhyReg.h	437;"	d
-RF_TXPA_G2	include/Hal8188FPhyReg.h	441;"	d
-RF_TXPA_G2	include/Hal8192EPhyReg.h	445;"	d
-RF_TXPA_G2	include/Hal8703BPhyReg.h	473;"	d
-RF_TXPA_G2	include/Hal8723BPhyReg.h	472;"	d
-RF_TXPA_G2	include/Hal8723DPhyReg.h	473;"	d
-RF_TXPA_G2	include/Hal8812PhyReg.h	311;"	d
-RF_TXPA_G2	include/Hal8814PhyReg.h	421;"	d
-RF_TXPA_G2	include/rtw_mp_phy_regdef.h	401;"	d
-RF_TXPA_G3	include/Hal8188EPhyReg.h	438;"	d
-RF_TXPA_G3	include/Hal8188FPhyReg.h	442;"	d
-RF_TXPA_G3	include/Hal8192EPhyReg.h	446;"	d
-RF_TXPA_G3	include/Hal8703BPhyReg.h	474;"	d
-RF_TXPA_G3	include/Hal8723BPhyReg.h	473;"	d
-RF_TXPA_G3	include/Hal8723DPhyReg.h	474;"	d
-RF_TXPA_G3	include/Hal8812PhyReg.h	312;"	d
-RF_TXPA_G3	include/Hal8814PhyReg.h	422;"	d
-RF_TXPA_G3	include/rtw_mp_phy_regdef.h	402;"	d
-RF_TXPA_G4	include/Hal8188EPhyReg.h	446;"	d
-RF_TXPA_G4	include/Hal8188FPhyReg.h	450;"	d
-RF_TXPA_G4	include/Hal8192EPhyReg.h	454;"	d
-RF_TXPA_G4	include/Hal8703BPhyReg.h	482;"	d
-RF_TXPA_G4	include/Hal8723BPhyReg.h	481;"	d
-RF_TXPA_G4	include/Hal8723DPhyReg.h	483;"	d
-RF_TXRF_A2	include/Hal8188EPhyReg.h	445;"	d
-RF_TXRF_A2	include/Hal8188FPhyReg.h	449;"	d
-RF_TXRF_A2	include/Hal8192EPhyReg.h	453;"	d
-RF_TXRF_A2	include/Hal8703BPhyReg.h	481;"	d
-RF_TXRF_A2	include/Hal8723BPhyReg.h	480;"	d
-RF_TXRF_A2	include/Hal8723DPhyReg.h	481;"	d
-RF_TX_AGC	include/Hal8188EPhyReg.h	400;"	d
-RF_TX_AGC	include/Hal8188FPhyReg.h	402;"	d
-RF_TX_AGC	include/Hal8192EPhyReg.h	405;"	d
-RF_TX_AGC	include/Hal8703BPhyReg.h	434;"	d
-RF_TX_AGC	include/Hal8723BPhyReg.h	433;"	d
-RF_TX_AGC	include/Hal8723DPhyReg.h	434;"	d
-RF_TX_AGC	include/rtw_mp_phy_regdef.h	362;"	d
-RF_TX_BB1	include/Hal8188EPhyReg.h	421;"	d
-RF_TX_BB1	include/Hal8188FPhyReg.h	425;"	d
-RF_TX_BB1	include/Hal8192EPhyReg.h	426;"	d
-RF_TX_BB1	include/Hal8703BPhyReg.h	457;"	d
-RF_TX_BB1	include/Hal8723BPhyReg.h	456;"	d
-RF_TX_BB1	include/Hal8723DPhyReg.h	457;"	d
-RF_TX_BB1	include/rtw_mp_phy_regdef.h	385;"	d
-RF_TX_BIAS_A	include/Hal8188EPhyReg.h	439;"	d
-RF_TX_BIAS_A	include/Hal8188FPhyReg.h	443;"	d
-RF_TX_BIAS_A	include/Hal8192EPhyReg.h	447;"	d
-RF_TX_BIAS_A	include/Hal8703BPhyReg.h	475;"	d
-RF_TX_BIAS_A	include/Hal8723BPhyReg.h	474;"	d
-RF_TX_BIAS_A	include/Hal8723DPhyReg.h	475;"	d
-RF_TX_BIAS_D	include/Hal8188EPhyReg.h	440;"	d
-RF_TX_BIAS_D	include/Hal8188FPhyReg.h	444;"	d
-RF_TX_BIAS_D	include/Hal8192EPhyReg.h	448;"	d
-RF_TX_BIAS_D	include/Hal8703BPhyReg.h	476;"	d
-RF_TX_BIAS_D	include/Hal8723BPhyReg.h	475;"	d
-RF_TX_BIAS_D	include/Hal8723DPhyReg.h	476;"	d
-RF_TX_G1	include/Hal8188EPhyReg.h	417;"	d
-RF_TX_G1	include/Hal8188FPhyReg.h	421;"	d
-RF_TX_G1	include/Hal8192EPhyReg.h	422;"	d
-RF_TX_G1	include/Hal8703BPhyReg.h	453;"	d
-RF_TX_G1	include/Hal8723BPhyReg.h	452;"	d
-RF_TX_G1	include/Hal8723DPhyReg.h	453;"	d
-RF_TX_G1	include/rtw_mp_phy_regdef.h	381;"	d
-RF_TX_G2	include/Hal8188EPhyReg.h	418;"	d
-RF_TX_G2	include/Hal8188FPhyReg.h	422;"	d
-RF_TX_G2	include/Hal8192EPhyReg.h	423;"	d
-RF_TX_G2	include/Hal8703BPhyReg.h	454;"	d
-RF_TX_G2	include/Hal8723BPhyReg.h	453;"	d
-RF_TX_G2	include/Hal8723DPhyReg.h	454;"	d
-RF_TX_G2	include/rtw_mp_phy_regdef.h	382;"	d
-RF_TX_G3	include/Hal8188EPhyReg.h	419;"	d
-RF_TX_G3	include/Hal8188FPhyReg.h	423;"	d
-RF_TX_G3	include/Hal8192EPhyReg.h	424;"	d
-RF_TX_G3	include/Hal8703BPhyReg.h	455;"	d
-RF_TX_G3	include/Hal8723BPhyReg.h	454;"	d
-RF_TX_G3	include/Hal8723DPhyReg.h	455;"	d
-RF_TX_G3	include/rtw_mp_phy_regdef.h	383;"	d
-RF_TX_GAIN_OFFSET_8188F	include/Hal8188FPhyReg.h	458;"	d
-RF_TX_GAIN_OFFSET_8192E	include/Hal8192EPhyReg.h	511;"	d
-RF_TX_GAIN_OFFSET_8703B	include/Hal8703BPhyReg.h	538;"	d
-RF_TX_GAIN_OFFSET_8723D	include/Hal8723DPhyReg.h	539;"	d
-RF_TX_GAIN_OFFSET_8812A	include/Hal8812PhyReg.h	316;"	d
-RF_TX_GAIN_OFFSET_8821A	include/Hal8812PhyReg.h	317;"	d
-RF_TX_NUM	include/hal_com_phycfg.h	/^} RF_TX_NUM;$/;"	t	typeref:enum:_RF_TX_NUM
-RF_TX_NUM_NONIMPLEMENT	include/hal_com_phycfg.h	/^	RF_TX_NUM_NONIMPLEMENT,$/;"	e	enum:_RF_TX_NUM
-RF_TYPE_1T1R	include/HalVerDef.h	/^	RF_TYPE_1T1R	=	0,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_1T2R	include/HalVerDef.h	/^	RF_TYPE_1T2R	=	1,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_2T2R	include/HalVerDef.h	/^	RF_TYPE_2T2R	=	2,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_2T3R	include/HalVerDef.h	/^	RF_TYPE_2T3R	=	3,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_2T4R	include/HalVerDef.h	/^	RF_TYPE_2T4R	=	4,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_3T3R	include/HalVerDef.h	/^	RF_TYPE_3T3R	=	5,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_3T4R	include/HalVerDef.h	/^	RF_TYPE_3T4R	=	6,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_4T4R	include/HalVerDef.h	/^	RF_TYPE_4T4R	=	7,$/;"	e	enum:tag_HAL_RF_Type_Definition
-RF_TYPE_E	include/hal_phy.h	/^} RF_TYPE_E, *PRF_TYPE_E;$/;"	t	typeref:enum:_RF_TYPE
-RF_TYPE_ID	include/hal_com_reg.h	1274;"	d
-RF_TYPE_MAX	include/hal_phy.h	/^	RF_TYPE_MAX$/;"	e	enum:_RF_TYPE
-RF_TYPE_MIN	include/hal_phy.h	/^	RF_TYPE_MIN = 0,	\/* 0 *\/$/;"	e	enum:_RF_TYPE
-RF_T_METER	include/Hal8188EPhyReg.h	424;"	d
-RF_T_METER	include/Hal8188FPhyReg.h	427;"	d
-RF_T_METER	include/Hal8192EPhyReg.h	430;"	d
-RF_T_METER	include/Hal8703BPhyReg.h	459;"	d
-RF_T_METER	include/Hal8723BPhyReg.h	458;"	d
-RF_T_METER	include/Hal8723DPhyReg.h	459;"	d
-RF_T_METER	include/rtw_mp_phy_regdef.h	387;"	d
-RF_T_METER_8192E	include/Hal8192EPhyReg.h	428;"	d
-RF_T_METER_8723D	hal/phydm/rtl8723d/halphyrf_8723d.h	28;"	d
-RF_T_METER_88E	include/Hal8188EPhyReg.h	423;"	d
-RF_T_METER_88E	include/Hal8192EPhyReg.h	429;"	d
-RF_T_METER_88E	include/Hal8723DPhyReg.h	482;"	d
-RF_T_METER_88E	include/Hal8814PhyReg.h	815;"	d
-RF_T_METER_NEW	hal/phydm/phydm_reg.h	40;"	d
-RF_T_METER_OLD	hal/phydm/phydm_reg.h	39;"	d
-RF_TxLCTank_Jaguar	include/Hal8812PhyReg.h	290;"	d
-RF_TxLCTank_Jaguar	include/Hal8814PhyReg.h	400;"	d
-RF_WE_LUT	include/Hal8188EPhyReg.h	449;"	d
-RF_WE_LUT	include/Hal8188FPhyReg.h	455;"	d
-RF_WE_LUT	include/Hal8192EPhyReg.h	458;"	d
-RF_WE_LUT	include/Hal8703BPhyReg.h	485;"	d
-RF_WE_LUT	include/Hal8723BPhyReg.h	484;"	d
-RF_WE_LUT	include/Hal8723DPhyReg.h	486;"	d
-RF_WE_LUT	include/Hal8812PhyReg.h	314;"	d
-RF_WE_LUT	include/Hal8814PhyReg.h	424;"	d
-RF_WeLut_Jaguar	include/Hal8812PhyReg.h	293;"	d
-RF_WeLut_Jaguar	include/Hal8814PhyReg.h	403;"	d
-RF_WeLut_Jaguar	include/rtl8822b_hal.h	195;"	d
-RGTRY_OFT	include/drv_types.h	413;"	d
-RGTRY_SZ	include/drv_types.h	414;"	d
-RND	core/rtw_security.c	2159;"	d	file:
-RND4	include/osdep_service.h	434;"	d
-ROAMING_LIMIT	include/rtw_mlme_ext.h	43;"	d
-ROAMING_LIMIT	include/rtw_mlme_ext.h	45;"	d
-ROFOn	include/rtl8188e_cmd.h	/^	u8 ROFOn; \/* 1: on, 0:off *\/$/;"	m	struct:H2C_SS_RFOFF_PARAM
-ROFOn	include/rtl8192e_cmd.h	/^	u8 ROFOn; \/* 1: on, 0:off *\/$/;"	m	struct:H2C_SS_RFOFF_PARAM
-ROFOn	include/rtl8812a_cmd.h	/^	u8 ROFOn; \/* 1: on, 0:off *\/$/;"	m	struct:H2C_SS_RFOFF_PARAM
-ROL32	include/rtw_security.h	315;"	d
-ROMBaseAddress	include/drv_types_pci.h	/^			u32	ROMBaseAddress;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-ROMVer	include/HalVerDef.h	/^	u8					ROMVer;$/;"	m	struct:tag_HAL_VERSION
-ROM_DLEN	include/hal_com_reg.h	1248;"	d
-ROP_ALD	include/hal_com_reg.h	1186;"	d
-ROP_PWR	include/hal_com_reg.h	1187;"	d
-ROP_SPS	include/hal_com_reg.h	1188;"	d
-ROR32	include/rtw_security.h	316;"	d
-RORc	include/rtw_security.h	433;"	d
-ROUND	core/rtw_security.c	2675;"	d	file:
-ROUND	core/rtw_security.c	2710;"	d	file:
-RRSR_11M	include/hal_com_reg.h	680;"	d
-RRSR_12M	include/hal_com_reg.h	683;"	d
-RRSR_18M	include/hal_com_reg.h	684;"	d
-RRSR_1M	include/hal_com_reg.h	677;"	d
-RRSR_24M	include/hal_com_reg.h	685;"	d
-RRSR_2M	include/hal_com_reg.h	678;"	d
-RRSR_36M	include/hal_com_reg.h	686;"	d
-RRSR_48M	include/hal_com_reg.h	687;"	d
-RRSR_54M	include/hal_com_reg.h	688;"	d
-RRSR_5_5M	include/hal_com_reg.h	679;"	d
-RRSR_6M	include/hal_com_reg.h	681;"	d
-RRSR_9M	include/hal_com_reg.h	682;"	d
-RRSR_CCK_RATES	include/hal_com_reg.h	698;"	d
-RRSR_MCS0	include/hal_com_reg.h	689;"	d
-RRSR_MCS1	include/hal_com_reg.h	690;"	d
-RRSR_MCS2	include/hal_com_reg.h	691;"	d
-RRSR_MCS3	include/hal_com_reg.h	692;"	d
-RRSR_MCS4	include/hal_com_reg.h	693;"	d
-RRSR_MCS5	include/hal_com_reg.h	694;"	d
-RRSR_MCS6	include/hal_com_reg.h	695;"	d
-RRSR_MCS7	include/hal_com_reg.h	696;"	d
-RRSR_OFDM_RATES	include/hal_com_reg.h	699;"	d
-RSN_AUTH_KEY_MGMT_PSK_OVER_802_1X	core/rtw_ieee80211.c	/^u8 RSN_AUTH_KEY_MGMT_PSK_OVER_802_1X[] = { 0x00, 0x0f, 0xac, 2 };$/;"	v
-RSN_AUTH_KEY_MGMT_UNSPEC_802_1X	core/rtw_ieee80211.c	/^u8 RSN_AUTH_KEY_MGMT_UNSPEC_802_1X[] = { 0x00, 0x0f, 0xac, 1 };$/;"	v
-RSN_CIPHER_SUITE_CCMP	core/rtw_ieee80211.c	/^u8 RSN_CIPHER_SUITE_CCMP[] = { 0x00, 0x0f, 0xac, 4 };$/;"	v
-RSN_CIPHER_SUITE_NONE	core/rtw_ieee80211.c	/^u8 RSN_CIPHER_SUITE_NONE[] = { 0x00, 0x0f, 0xac, 0 };$/;"	v
-RSN_CIPHER_SUITE_TKIP	core/rtw_ieee80211.c	/^u8 RSN_CIPHER_SUITE_TKIP[] = { 0x00, 0x0f, 0xac, 2 };$/;"	v
-RSN_CIPHER_SUITE_WEP104	core/rtw_ieee80211.c	/^u8 RSN_CIPHER_SUITE_WEP104[] = { 0x00, 0x0f, 0xac, 5 };$/;"	v
-RSN_CIPHER_SUITE_WEP40	core/rtw_ieee80211.c	/^u8 RSN_CIPHER_SUITE_WEP40[] = { 0x00, 0x0f, 0xac, 1 };$/;"	v
-RSN_CIPHER_SUITE_WRAP	core/rtw_ieee80211.c	/^u8 RSN_CIPHER_SUITE_WRAP[] = { 0x00, 0x0f, 0xac, 3 };$/;"	v
-RSN_HEADER_LEN	include/ieee80211.h	146;"	d
-RSN_SELECTOR_LEN	include/ieee80211.h	147;"	d
-RSN_SELECTOR_PUT	include/ieee80211_ext.h	151;"	d
-RSN_TKIP_CIPHER	core/rtw_mlme_ext.c	/^unsigned char RSN_TKIP_CIPHER[4] = {0x00, 0x0f, 0xac, 0x02};$/;"	v
-RSN_VERSION_BSD	core/rtw_ieee80211.c	/^u16 RSN_VERSION_BSD = 1;$/;"	v
-RSSI_A	hal/phydm/phydm.h	/^	u1Byte			RSSI_A;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_AntDect_bResult	hal/phydm/phydm_antdiv.h	/^	BOOLEAN		RSSI_AntDect_bResult;	$/;"	m	struct:_SW_Antenna_Switch_
-RSSI_Ave	hal/phydm/phydm.h	/^	u1Byte		RSSI_Ave;$/;"	m	struct:_ODM_STA_INFO
-RSSI_Ave	include/sta_info.h	/^	u8		RSSI_Ave;$/;"	m	struct:sta_info
-RSSI_B	hal/phydm/phydm.h	/^	u1Byte			RSSI_B;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_BT	hal/phydm/phydm.h	/^	u1Byte			RSSI_BT;				\/*come from BT*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_C	hal/phydm/phydm.h	/^	u1Byte			RSSI_C;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_CHECK_RESET_PERIOD	hal/phydm/phydm_antdiv.h	129;"	d
-RSSI_CHECK_THRESHOLD	hal/phydm/phydm_antdiv.h	130;"	d
-RSSI_D	hal/phydm/phydm.h	/^	u1Byte			RSSI_D;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_METHOD	hal/phydm/phydm_antdiv.h	86;"	d
-RSSI_Min	hal/phydm/phydm.h	/^	u1Byte			RSSI_Min;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_OFFSET_DIG	hal/phydm/phydm_dig.h	273;"	d
-RSSI_Path	hal/phydm/phydm.h	/^	u1Byte		RSSI_Path[4];$/;"	m	struct:_ODM_STA_INFO
-RSSI_Path	include/sta_info.h	/^	u8		RSSI_Path[4];		\/*  *\/$/;"	m	struct:sta_info
-RSSI_STA	include/sta_info.h	/^} RSSI_STA, *PRSSI_STA;$/;"	t	typeref:struct:_RSSI_STA
-RSSI_TRSW	hal/phydm/phydm.h	/^	u8Byte			RSSI_TRSW;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_TRSW_H	hal/phydm/phydm.h	/^	u8Byte			RSSI_TRSW_H;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_TRSW_L	hal/phydm/phydm.h	/^	u8Byte			RSSI_TRSW_L;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_TRSW_iso	hal/phydm/phydm.h	/^	u8Byte			RSSI_TRSW_iso;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RSSI_Trying	hal/phydm/phydm_antdiv.h	/^	u1Byte		RSSI_Trying;$/;"	m	struct:_SW_Antenna_Switch_
-RSSI_max	hal/phydm/phydm_dig.h	/^	u4Byte		RSSI_max;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-RSVDPAGE_LOC	include/hal_com_h2c.h	/^} RSVDPAGE_LOC, *PRSVDPAGE_LOC;$/;"	t	typeref:struct:_RSVDPAGE_LOC
-RSVD_PAGE_NUM_8192E	include/rtl8192e_hal.h	132;"	d
-RSVD_PKT_LEN_92E	include/rtl8192e_hal.h	161;"	d
-RTD3_SSID_MATCH	include/hal_com.h	/^	RTD3_SSID_MATCH					= 0x24,$/;"	e	enum:_WAKEUP_REASON
-RTIME_FAIL_DMA_IDLE	include/hal_com.h	/^	RTIME_FAIL_DMA_IDLE				= 0x42,$/;"	e	enum:_WAKEUP_REASON
-RTIME_FAIL_DMA_PAUSE	include/hal_com.h	/^	RTIME_FAIL_DMA_PAUSE			= 0x43,$/;"	e	enum:_WAKEUP_REASON
-RTL8188E	include/hal_intf.h	/^	RTL8188E,$/;"	e	enum:_CHIP_TYPE
-RTL8188EE_HMC_M2_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8188EE_HMC_M2_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8188EE_HMC_M2_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8188EE_HMC_M2_country_chplan_map_sz = sizeof(RTL8188EE_HMC_M2_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8188EE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	101;"	d
-RTL8188EE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	116;"	d
-RTL8188EE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	29;"	d
-RTL8188EE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	52;"	d
-RTL8188EE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	75;"	d
-RTL8188ES_HWIMG_SUPPORT	hal/phydm/halhwimg.h	103;"	d
-RTL8188ES_HWIMG_SUPPORT	hal/phydm/halhwimg.h	118;"	d
-RTL8188ES_HWIMG_SUPPORT	hal/phydm/halhwimg.h	31;"	d
-RTL8188ES_HWIMG_SUPPORT	hal/phydm/halhwimg.h	54;"	d
-RTL8188ES_HWIMG_SUPPORT	hal/phydm/halhwimg.h	77;"	d
-RTL8188EU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	102;"	d
-RTL8188EU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	117;"	d
-RTL8188EU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	30;"	d
-RTL8188EU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	53;"	d
-RTL8188EU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	76;"	d
-RTL8188E_H2C_CMD_ID	include/rtl8188e_cmd.h	/^} RTL8188E_H2C_CMD_ID;$/;"	t	typeref:enum:_RTL8188E_H2C_CMD_ID
-RTL8188E_SUPPORT	include/hal_ic_cfg.h	23;"	d
-RTL8188E_SUPPORT	include/hal_ic_cfg.h	46;"	d
-RTL8188E_SUPPORT	include/hal_ic_cfg.h	50;"	d
-RTL8188E_S_SUPPORT	hal/phydm/phydm_precomp.h	97;"	d
-RTL8188E_S_SUPPORT	hal/phydm/phydm_precomp.h	99;"	d
-RTL8188E_TRANS_ACT_TO_CARDEMU	include/Hal8188EPwrSeq.h	73;"	d
-RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8188EPwrSeq.h	51;"	d
-RTL8188E_TRANS_ACT_TO_LPS	include/Hal8188EPwrSeq.h	129;"	d
-RTL8188E_TRANS_ACT_TO_LPS_STEPS	include/Hal8188EPwrSeq.h	56;"	d
-RTL8188E_TRANS_CARDDIS_TO_CARDEMU	include/Hal8188EPwrSeq.h	110;"	d
-RTL8188E_TRANS_CARDEMU_TO_ACT	include/Hal8188EPwrSeq.h	61;"	d
-RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8188EPwrSeq.h	50;"	d
-RTL8188E_TRANS_CARDEMU_TO_CARDDIS	include/Hal8188EPwrSeq.h	99;"	d
-RTL8188E_TRANS_CARDEMU_TO_PDN	include/Hal8188EPwrSeq.h	117;"	d
-RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8188EPwrSeq.h	54;"	d
-RTL8188E_TRANS_CARDEMU_TO_SUS	include/Hal8188EPwrSeq.h	81;"	d
-RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8188EPwrSeq.h	52;"	d
-RTL8188E_TRANS_END	include/Hal8188EPwrSeq.h	159;"	d
-RTL8188E_TRANS_END_STEPS	include/Hal8188EPwrSeq.h	58;"	d
-RTL8188E_TRANS_LPS_TO_ACT	include/Hal8188EPwrSeq.h	144;"	d
-RTL8188E_TRANS_LPS_TO_ACT_STEPS	include/Hal8188EPwrSeq.h	57;"	d
-RTL8188E_TRANS_PDN_TO_CARDEMU	include/Hal8188EPwrSeq.h	123;"	d
-RTL8188E_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8188EPwrSeq.h	55;"	d
-RTL8188E_TRANS_SUS_TO_CARDEMU	include/Hal8188EPwrSeq.h	92;"	d
-RTL8188E_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8188EPwrSeq.h	53;"	d
-RTL8188E_T_SUPPORT	hal/phydm/phydm_precomp.h	95;"	d
-RTL8188F	include/hal_intf.h	/^	RTL8188F,$/;"	e	enum:_CHIP_TYPE
-RTL8188F_SUPPORT	hal/phydm/phydm_precomp.h	90;"	d
-RTL8188F_SUPPORT	include/hal_ic_cfg.h	122;"	d
-RTL8188F_SUPPORT	include/hal_ic_cfg.h	123;"	d
-RTL8188F_SUPPORT	include/hal_ic_cfg.h	33;"	d
-RTL8188F_TRANS_ACT_TO_CARDEMU	include/Hal8188FPwrSeq.h	51;"	d
-RTL8188F_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8188FPwrSeq.h	28;"	d
-RTL8188F_TRANS_ACT_TO_LPS	include/Hal8188FPwrSeq.h	106;"	d
-RTL8188F_TRANS_ACT_TO_LPS_STEPS	include/Hal8188FPwrSeq.h	33;"	d
-RTL8188F_TRANS_ACT_TO_SWLPS	include/Hal8188FPwrSeq.h	138;"	d
-RTL8188F_TRANS_ACT_TO_SWLPS_STEPS	include/Hal8188FPwrSeq.h	35;"	d
-RTL8188F_TRANS_CARDDIS_TO_CARDEMU	include/Hal8188FPwrSeq.h	86;"	d
-RTL8188F_TRANS_CARDEMU_TO_ACT	include/Hal8188FPwrSeq.h	40;"	d
-RTL8188F_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8188FPwrSeq.h	27;"	d
-RTL8188F_TRANS_CARDEMU_TO_CARDDIS	include/Hal8188FPwrSeq.h	77;"	d
-RTL8188F_TRANS_CARDEMU_TO_PDN	include/Hal8188FPwrSeq.h	95;"	d
-RTL8188F_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8188FPwrSeq.h	31;"	d
-RTL8188F_TRANS_CARDEMU_TO_SUS	include/Hal8188FPwrSeq.h	60;"	d
-RTL8188F_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8188FPwrSeq.h	29;"	d
-RTL8188F_TRANS_END	include/Hal8188FPwrSeq.h	181;"	d
-RTL8188F_TRANS_END_STEPS	include/Hal8188FPwrSeq.h	37;"	d
-RTL8188F_TRANS_LPS_TO_ACT	include/Hal8188FPwrSeq.h	122;"	d
-RTL8188F_TRANS_LPS_TO_ACT_STEPS	include/Hal8188FPwrSeq.h	34;"	d
-RTL8188F_TRANS_PDN_TO_CARDEMU	include/Hal8188FPwrSeq.h	101;"	d
-RTL8188F_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8188FPwrSeq.h	32;"	d
-RTL8188F_TRANS_SUS_TO_CARDEMU	include/Hal8188FPwrSeq.h	69;"	d
-RTL8188F_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8188FPwrSeq.h	30;"	d
-RTL8188F_TRANS_SWLPS_TO_ACT	include/Hal8188FPwrSeq.h	163;"	d
-RTL8188F_TRANS_SWLPS_TO_ACT_STEPS	include/Hal8188FPwrSeq.h	36;"	d
-RTL8192CE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	12;"	d
-RTL8192CE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	35;"	d
-RTL8192CE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	58;"	d
-RTL8192CE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	83;"	d
-RTL8192CE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	13;"	d
-RTL8192CE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	36;"	d
-RTL8192CE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	59;"	d
-RTL8192CE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	84;"	d
-RTL8192CU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	14;"	d
-RTL8192CU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	37;"	d
-RTL8192CU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	60;"	d
-RTL8192CU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	85;"	d
-RTL8192CU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	15;"	d
-RTL8192CU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	38;"	d
-RTL8192CU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	61;"	d
-RTL8192CU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	86;"	d
-RTL8192DE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	18;"	d
-RTL8192DE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	41;"	d
-RTL8192DE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	64;"	d
-RTL8192DE_HWIMG_SUPPORT	hal/phydm/halhwimg.h	89;"	d
-RTL8192DE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	19;"	d
-RTL8192DE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	42;"	d
-RTL8192DE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	65;"	d
-RTL8192DE_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	90;"	d
-RTL8192DU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	20;"	d
-RTL8192DU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	43;"	d
-RTL8192DU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	66;"	d
-RTL8192DU_HWIMG_SUPPORT	hal/phydm/halhwimg.h	91;"	d
-RTL8192DU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	21;"	d
-RTL8192DU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	44;"	d
-RTL8192DU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	67;"	d
-RTL8192DU_TEST_HWIMG_SUPPORT	hal/phydm/halhwimg.h	92;"	d
-RTL8192E	include/hal_intf.h	/^	RTL8192E,$/;"	e	enum:_CHIP_TYPE
-RTL8192EEBT_HMC_M2_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8192EEBT_HMC_M2_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8192EEBT_HMC_M2_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8192EEBT_HMC_M2_country_chplan_map_sz = sizeof(RTL8192EEBT_HMC_M2_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8192EE_SEG_NUM	include/rtl8192e_hal.h	186;"	d
-RTL8192E_H2C_CMD	include/rtl8192e_cmd.h	/^} RTL8192E_H2C_CMD;$/;"	t	typeref:enum:_RTL8192E_H2C_CMD
-RTL8192E_SUPPORT	include/hal_ic_cfg.h	28;"	d
-RTL8192E_SUPPORT	include/hal_ic_cfg.h	73;"	d
-RTL8192E_SUPPORT	include/hal_ic_cfg.h	74;"	d
-RTL8192E_TRANS_ACT_TO_CARDEMU	include/Hal8192EPwrSeq.h	49;"	d
-RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8192EPwrSeq.h	27;"	d
-RTL8192E_TRANS_ACT_TO_LPS	include/Hal8192EPwrSeq.h	106;"	d
-RTL8192E_TRANS_ACT_TO_LPS_STEPS	include/Hal8192EPwrSeq.h	32;"	d
-RTL8192E_TRANS_CARDDIS_TO_CARDEMU	include/Hal8192EPwrSeq.h	85;"	d
-RTL8192E_TRANS_CARDEMU_TO_ACT	include/Hal8192EPwrSeq.h	37;"	d
-RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8192EPwrSeq.h	26;"	d
-RTL8192E_TRANS_CARDEMU_TO_CARDDIS	include/Hal8192EPwrSeq.h	74;"	d
-RTL8192E_TRANS_CARDEMU_TO_PDN	include/Hal8192EPwrSeq.h	95;"	d
-RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8192EPwrSeq.h	30;"	d
-RTL8192E_TRANS_CARDEMU_TO_SUS	include/Hal8192EPwrSeq.h	58;"	d
-RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8192EPwrSeq.h	28;"	d
-RTL8192E_TRANS_END	include/Hal8192EPwrSeq.h	139;"	d
-RTL8192E_TRANS_END_STEPS	include/Hal8192EPwrSeq.h	34;"	d
-RTL8192E_TRANS_LPS_TO_ACT	include/Hal8192EPwrSeq.h	124;"	d
-RTL8192E_TRANS_LPS_TO_ACT_STEPS	include/Hal8192EPwrSeq.h	33;"	d
-RTL8192E_TRANS_PDN_TO_CARDEMU	include/Hal8192EPwrSeq.h	101;"	d
-RTL8192E_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8192EPwrSeq.h	31;"	d
-RTL8192E_TRANS_SUS_TO_CARDEMU	include/Hal8192EPwrSeq.h	67;"	d
-RTL8192E_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8192EPwrSeq.h	29;"	d
-RTL8195A_SUPPORT	include/hal_ic_cfg.h	30;"	d
-RTL8197F_SUPPORT	include/hal_ic_cfg.h	31;"	d
-RTL8703B	include/hal_intf.h	/^	RTL8703B,$/;"	e	enum:_CHIP_TYPE
-RTL8703B_SUPPORT	hal/phydm/phydm_precomp.h	89;"	d
-RTL8703B_SUPPORT	include/hal_ic_cfg.h	111;"	d
-RTL8703B_SUPPORT	include/hal_ic_cfg.h	112;"	d
-RTL8703B_SUPPORT	include/hal_ic_cfg.h	32;"	d
-RTL8703B_TRANS_ACT_TO_CARDEMU	include/Hal8703BPwrSeq.h	66;"	d
-RTL8703B_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8703BPwrSeq.h	28;"	d
-RTL8703B_TRANS_ACT_TO_LPS	include/Hal8703BPwrSeq.h	135;"	d
-RTL8703B_TRANS_ACT_TO_LPS_STEPS	include/Hal8703BPwrSeq.h	33;"	d
-RTL8703B_TRANS_CARDDIS_TO_CARDEMU	include/Hal8703BPwrSeq.h	110;"	d
-RTL8703B_TRANS_CARDEMU_TO_ACT	include/Hal8703BPwrSeq.h	38;"	d
-RTL8703B_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8703BPwrSeq.h	27;"	d
-RTL8703B_TRANS_CARDEMU_TO_CARDDIS	include/Hal8703BPwrSeq.h	99;"	d
-RTL8703B_TRANS_CARDEMU_TO_PDN	include/Hal8703BPwrSeq.h	122;"	d
-RTL8703B_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8703BPwrSeq.h	31;"	d
-RTL8703B_TRANS_CARDEMU_TO_SUS	include/Hal8703BPwrSeq.h	79;"	d
-RTL8703B_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8703BPwrSeq.h	29;"	d
-RTL8703B_TRANS_END	include/Hal8703BPwrSeq.h	168;"	d
-RTL8703B_TRANS_END_STEPS	include/Hal8703BPwrSeq.h	35;"	d
-RTL8703B_TRANS_LPS_TO_ACT	include/Hal8703BPwrSeq.h	153;"	d
-RTL8703B_TRANS_LPS_TO_ACT_STEPS	include/Hal8703BPwrSeq.h	34;"	d
-RTL8703B_TRANS_PDN_TO_CARDEMU	include/Hal8703BPwrSeq.h	130;"	d
-RTL8703B_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8703BPwrSeq.h	32;"	d
-RTL8703B_TRANS_SUS_TO_CARDEMU	include/Hal8703BPwrSeq.h	90;"	d
-RTL8703B_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8703BPwrSeq.h	30;"	d
-RTL8711_FINT_	include/nic_spec.h	30;"	d
-RTL8711_GPIO_	include/nic_spec.h	32;"	d
-RTL8711_HCICTRL_	include/nic_spec.h	35;"	d
-RTL8711_HINT_	include/nic_spec.h	31;"	d
-RTL8711_MCCTRL_	include/nic_spec.h	38;"	d
-RTL8711_MCTRL_	include/nic_spec.h	27;"	d
-RTL8711_NIC	include/drv_types.h	/^	RTL8711_NIC,$/;"	e	enum:_NIC_VERSION
-RTL8711_RF_DEF_SENS	include/rtw_rf.h	37;"	d
-RTL8711_RF_MAX_SENS	include/rtw_rf.h	36;"	d
-RTL8711_SYSCFG_	include/nic_spec.h	36;"	d
-RTL8711_SYSCTRL_	include/nic_spec.h	37;"	d
-RTL8711_TIMER_	include/nic_spec.h	29;"	d
-RTL8711_UART_	include/nic_spec.h	28;"	d
-RTL8711_WLANCTRL_	include/nic_spec.h	33;"	d
-RTL8711_WLANFF_	include/nic_spec.h	34;"	d
-RTL8712_EEPROM_ID	include/rtw_eeprom.h	24;"	d
-RTL8712_NIC	include/drv_types.h	/^	RTL8712_NIC,$/;"	e	enum:_NIC_VERSION
-RTL8712_RFCONFIG_1R	include/rtw_rf.h	/^	RTL8712_RFCONFIG_1R = 0x01,$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8712_RFCONFIG_1T	include/rtw_rf.h	/^	RTL8712_RFCONFIG_1T = 0x10,$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8712_RFCONFIG_1T1R	include/rtw_rf.h	/^	RTL8712_RFCONFIG_1T1R = 0x11,$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8712_RFCONFIG_1T2R	include/rtw_rf.h	/^	RTL8712_RFCONFIG_1T2R = 0x12,$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8712_RFCONFIG_2R	include/rtw_rf.h	/^	RTL8712_RFCONFIG_2R = 0x02,$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8712_RFCONFIG_2T	include/rtw_rf.h	/^	RTL8712_RFCONFIG_2T = 0x20,$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8712_RFCONFIG_2T2R	include/rtw_rf.h	/^	RTL8712_RFCONFIG_2T2R = 0x22$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8712_RFCONFIG_TURBO	include/rtw_rf.h	/^	RTL8712_RFCONFIG_TURBO = 0x92,$/;"	e	enum:_RTL8712_RF_MIMO_CONFIG_
-RTL8713_NIC	include/drv_types.h	/^	RTL8713_NIC,$/;"	e	enum:_NIC_VERSION
-RTL8716_NIC	include/drv_types.h	/^	RTL8716_NIC$/;"	e	enum:_NIC_VERSION
-RTL871X	Makefile	/^RTL871X = rtl8188e$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8188f$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8192e$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8703b$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8723b$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8723d$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8812a$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8814a$/;"	m
-RTL871X	Makefile	/^RTL871X = rtl8821a$/;"	m
-RTL871X_GET_ENCRYPTION	include/ieee80211.h	/^	RTL871X_GET_ENCRYPTION = 7,$/;"	e	enum:__anon72
-RTL871X_HCI_TYPE	include/hal_intf.h	/^enum RTL871X_HCI_TYPE {$/;"	g
-RTL871X_HOSTAPD_ACL_ADD_STA	include/ieee80211.h	/^	RTL871X_HOSTAPD_ACL_ADD_STA = 22,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_ACL_REMOVE_STA	include/ieee80211.h	/^	RTL871X_HOSTAPD_ACL_REMOVE_STA = 23,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_ADD_STA	include/ieee80211.h	/^	RTL871X_HOSTAPD_ADD_STA = 2,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_FLUSH	include/ieee80211.h	/^	RTL871X_HOSTAPD_FLUSH = 1,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_GET_INFO_STA	include/ieee80211.h	/^	RTL871X_HOSTAPD_GET_INFO_STA = 4,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_GET_RID	include/ieee80211.h	/^	RTL871X_HOSTAPD_GET_RID = 9,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_GET_WPAIE_STA	include/ieee80211.h	/^	RTL871X_HOSTAPD_GET_WPAIE_STA = 5,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_MLME	include/ieee80211.h	/^	RTL871X_HOSTAPD_MLME = 13,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_REMOVE_STA	include/ieee80211.h	/^	RTL871X_HOSTAPD_REMOVE_STA = 3,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SCAN_REQ	include/ieee80211.h	/^	RTL871X_HOSTAPD_SCAN_REQ = 14,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_ASSOC_AP_ADDR	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_ASSOC_AP_ADDR = 11,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_BEACON	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_BEACON = 16,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_FLAGS_STA	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_FLAGS_STA = 8,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_GENERIC_ELEMENT	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_GENERIC_ELEMENT = 12,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_HIDDEN_SSID	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_HIDDEN_SSID = 20,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_MACADDR_ACL	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_MACADDR_ACL = 21,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_RID	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_RID = 10,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_WPS_ASSOC_RESP	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_WPS_ASSOC_RESP = 19,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_WPS_BEACON	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_WPS_BEACON = 17,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_SET_WPS_PROBE_RESP	include/ieee80211.h	/^	RTL871X_HOSTAPD_SET_WPS_PROBE_RESP = 18,$/;"	e	enum:__anon72
-RTL871X_HOSTAPD_STA_CLEAR_STATS	include/ieee80211.h	/^	RTL871X_HOSTAPD_STA_CLEAR_STATS = 15,$/;"	e	enum:__anon72
-RTL871X_MODULE_NAME	include/autoconf.h	25;"	d
-RTL871X_MP_IOCTL_SUBCODE	include/rtw_mp_ioctl.h	/^enum RTL871X_MP_IOCTL_SUBCODE {$/;"	g
-RTL871X_SET_ENCRYPTION	include/ieee80211.h	/^	RTL871X_SET_ENCRYPTION = 6,$/;"	e	enum:__anon72
-RTL8723A_TRANS_ACT_TO_CARDEMU	include/Hal8723PwrSeq.h	53;"	d
-RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8723PwrSeq.h	27;"	d
-RTL8723A_TRANS_ACT_TO_LPS	include/Hal8723PwrSeq.h	120;"	d
-RTL8723A_TRANS_ACT_TO_LPS_STEPS	include/Hal8723PwrSeq.h	32;"	d
-RTL8723A_TRANS_CARDDIS_TO_CARDEMU	include/Hal8723PwrSeq.h	95;"	d
-RTL8723A_TRANS_CARDEMU_TO_ACT	include/Hal8723PwrSeq.h	37;"	d
-RTL8723A_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8723PwrSeq.h	26;"	d
-RTL8723A_TRANS_CARDEMU_TO_CARDDIS	include/Hal8723PwrSeq.h	84;"	d
-RTL8723A_TRANS_CARDEMU_TO_PDN	include/Hal8723PwrSeq.h	107;"	d
-RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8723PwrSeq.h	30;"	d
-RTL8723A_TRANS_CARDEMU_TO_SUS	include/Hal8723PwrSeq.h	64;"	d
-RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8723PwrSeq.h	28;"	d
-RTL8723A_TRANS_END	include/Hal8723PwrSeq.h	153;"	d
-RTL8723A_TRANS_END_STEPS	include/Hal8723PwrSeq.h	34;"	d
-RTL8723A_TRANS_LPS_TO_ACT	include/Hal8723PwrSeq.h	138;"	d
-RTL8723A_TRANS_LPS_TO_ACT_STEPS	include/Hal8723PwrSeq.h	33;"	d
-RTL8723A_TRANS_PDN_TO_CARDEMU	include/Hal8723PwrSeq.h	115;"	d
-RTL8723A_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8723PwrSeq.h	31;"	d
-RTL8723A_TRANS_SUS_TO_CARDEMU	include/Hal8723PwrSeq.h	75;"	d
-RTL8723A_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8723PwrSeq.h	29;"	d
-RTL8723B	include/hal_intf.h	/^	RTL8723B,$/;"	e	enum:_CHIP_TYPE
-RTL8723BE_HMC_M2_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8723BE_HMC_M2_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8723BE_HMC_M2_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8723BE_HMC_M2_country_chplan_map_sz = sizeof(RTL8723BE_HMC_M2_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8723BS_NGFF1216_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8723BS_NGFF1216_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8723BS_NGFF1216_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8723BS_NGFF1216_country_chplan_map_sz = sizeof(RTL8723BS_NGFF1216_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8723B_SUPPORT	include/hal_ic_cfg.h	26;"	d
-RTL8723B_SUPPORT	include/hal_ic_cfg.h	81;"	d
-RTL8723B_SUPPORT	include/hal_ic_cfg.h	82;"	d
-RTL8723B_TRANS_ACT_TO_CARDEMU	include/Hal8723BPwrSeq.h	66;"	d
-RTL8723B_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8723BPwrSeq.h	28;"	d
-RTL8723B_TRANS_ACT_TO_LPS	include/Hal8723BPwrSeq.h	135;"	d
-RTL8723B_TRANS_ACT_TO_LPS_STEPS	include/Hal8723BPwrSeq.h	33;"	d
-RTL8723B_TRANS_ACT_TO_SWLPS	include/Hal8723BPwrSeq.h	169;"	d
-RTL8723B_TRANS_ACT_TO_SWLPS_STEPS	include/Hal8723BPwrSeq.h	35;"	d
-RTL8723B_TRANS_CARDDIS_TO_CARDEMU	include/Hal8723BPwrSeq.h	110;"	d
-RTL8723B_TRANS_CARDEMU_TO_ACT	include/Hal8723BPwrSeq.h	40;"	d
-RTL8723B_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8723BPwrSeq.h	27;"	d
-RTL8723B_TRANS_CARDEMU_TO_CARDDIS	include/Hal8723BPwrSeq.h	99;"	d
-RTL8723B_TRANS_CARDEMU_TO_PDN	include/Hal8723BPwrSeq.h	122;"	d
-RTL8723B_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8723BPwrSeq.h	31;"	d
-RTL8723B_TRANS_CARDEMU_TO_SUS	include/Hal8723BPwrSeq.h	79;"	d
-RTL8723B_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8723BPwrSeq.h	29;"	d
-RTL8723B_TRANS_END	include/Hal8723BPwrSeq.h	215;"	d
-RTL8723B_TRANS_END_STEPS	include/Hal8723BPwrSeq.h	37;"	d
-RTL8723B_TRANS_LPS_TO_ACT	include/Hal8723BPwrSeq.h	153;"	d
-RTL8723B_TRANS_LPS_TO_ACT_STEPS	include/Hal8723BPwrSeq.h	34;"	d
-RTL8723B_TRANS_PDN_TO_CARDEMU	include/Hal8723BPwrSeq.h	130;"	d
-RTL8723B_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8723BPwrSeq.h	32;"	d
-RTL8723B_TRANS_SUS_TO_CARDEMU	include/Hal8723BPwrSeq.h	90;"	d
-RTL8723B_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8723BPwrSeq.h	30;"	d
-RTL8723B_TRANS_SWLPS_TO_ACT	include/Hal8723BPwrSeq.h	196;"	d
-RTL8723B_TRANS_SWLPS_TO_ACT_STEPS	include/Hal8723BPwrSeq.h	36;"	d
-RTL8723D	include/hal_intf.h	/^	RTL8723D,$/;"	e	enum:_CHIP_TYPE
-RTL8723D_EX_MESSAGE_BOX_SIZE	hal/rtl8723d/rtl8723d_cmd.c	29;"	d	file:
-RTL8723D_MAX_CMD_LEN	hal/rtl8723d/rtl8723d_cmd.c	28;"	d	file:
-RTL8723D_SUPPORT	hal/phydm/phydm_precomp.h	91;"	d
-RTL8723D_SUPPORT	include/hal_ic_cfg.h	27;"	d
-RTL8723D_SUPPORT	include/hal_ic_cfg.h	89;"	d
-RTL8723D_SUPPORT	include/hal_ic_cfg.h	90;"	d
-RTL8723D_TRANS_ACT_TO_CARDEMU	include/Hal8723DPwrSeq.h	72;"	d
-RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8723DPwrSeq.h	29;"	d
-RTL8723D_TRANS_ACT_TO_LPS	include/Hal8723DPwrSeq.h	144;"	d
-RTL8723D_TRANS_ACT_TO_LPS_STEPS	include/Hal8723DPwrSeq.h	36;"	d
-RTL8723D_TRANS_CARDDIS_TO_CARDEMU	include/Hal8723DPwrSeq.h	119;"	d
-RTL8723D_TRANS_CARDDIS_TO_CARDEMU_STEPS	include/Hal8723DPwrSeq.h	33;"	d
-RTL8723D_TRANS_CARDEMU_TO_ACT	include/Hal8723DPwrSeq.h	41;"	d
-RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8723DPwrSeq.h	28;"	d
-RTL8723D_TRANS_CARDEMU_TO_CARDDIS	include/Hal8723DPwrSeq.h	107;"	d
-RTL8723D_TRANS_CARDEMU_TO_CARDDIS_STEPS	include/Hal8723DPwrSeq.h	32;"	d
-RTL8723D_TRANS_CARDEMU_TO_PDN	include/Hal8723DPwrSeq.h	131;"	d
-RTL8723D_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8723DPwrSeq.h	34;"	d
-RTL8723D_TRANS_CARDEMU_TO_SUS	include/Hal8723DPwrSeq.h	86;"	d
-RTL8723D_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8723DPwrSeq.h	30;"	d
-RTL8723D_TRANS_END	include/Hal8723DPwrSeq.h	177;"	d
-RTL8723D_TRANS_END_STEPS	include/Hal8723DPwrSeq.h	38;"	d
-RTL8723D_TRANS_LPS_TO_ACT	include/Hal8723DPwrSeq.h	162;"	d
-RTL8723D_TRANS_LPS_TO_ACT_STEPS	include/Hal8723DPwrSeq.h	37;"	d
-RTL8723D_TRANS_PDN_TO_CARDEMU	include/Hal8723DPwrSeq.h	139;"	d
-RTL8723D_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8723DPwrSeq.h	35;"	d
-RTL8723D_TRANS_SUS_TO_CARDEMU	include/Hal8723DPwrSeq.h	97;"	d
-RTL8723D_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8723DPwrSeq.h	31;"	d
-RTL8723E_HWIMG_SUPPORT	hal/phydm/halhwimg.h	108;"	d
-RTL8723E_HWIMG_SUPPORT	hal/phydm/halhwimg.h	24;"	d
-RTL8723E_HWIMG_SUPPORT	hal/phydm/halhwimg.h	47;"	d
-RTL8723E_HWIMG_SUPPORT	hal/phydm/halhwimg.h	70;"	d
-RTL8723E_HWIMG_SUPPORT	hal/phydm/halhwimg.h	96;"	d
-RTL8723S_HWIMG_SUPPORT	hal/phydm/halhwimg.h	112;"	d
-RTL8723S_HWIMG_SUPPORT	hal/phydm/halhwimg.h	26;"	d
-RTL8723S_HWIMG_SUPPORT	hal/phydm/halhwimg.h	49;"	d
-RTL8723S_HWIMG_SUPPORT	hal/phydm/halhwimg.h	72;"	d
-RTL8723S_HWIMG_SUPPORT	hal/phydm/halhwimg.h	98;"	d
-RTL8723U_HWIMG_SUPPORT	hal/phydm/halhwimg.h	110;"	d
-RTL8723U_HWIMG_SUPPORT	hal/phydm/halhwimg.h	25;"	d
-RTL8723U_HWIMG_SUPPORT	hal/phydm/halhwimg.h	48;"	d
-RTL8723U_HWIMG_SUPPORT	hal/phydm/halhwimg.h	71;"	d
-RTL8723U_HWIMG_SUPPORT	hal/phydm/halhwimg.h	97;"	d
-RTL8812	include/hal_intf.h	/^	RTL8812,$/;"	e	enum:_CHIP_TYPE
-RTL8812AEBT_HMC_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8812AEBT_HMC_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8812AEBT_HMC_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8812AEBT_HMC_country_chplan_map_sz = sizeof(RTL8812AEBT_HMC_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8812AENF_NGFF_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8812AENF_NGFF_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8812AENF_NGFF_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8812AENF_NGFF_country_chplan_map_sz = sizeof(RTL8812AENF_NGFF_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8812A_SUPPORT	include/hal_ic_cfg.h	24;"	d
-RTL8812A_SUPPORT	include/hal_ic_cfg.h	57;"	d
-RTL8812A_SUPPORT	include/hal_ic_cfg.h	58;"	d
-RTL8812_H2C_CMD	include/rtl8812a_cmd.h	/^} RTL8812_H2C_CMD;$/;"	t	typeref:enum:_RTL8812_H2C_CMD
-RTL8812_TRANS_ACT_TO_CARDEMU	include/Hal8812PwrSeq.h	69;"	d
-RTL8812_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8812PwrSeq.h	49;"	d
-RTL8812_TRANS_ACT_TO_LPS	include/Hal8812PwrSeq.h	159;"	d
-RTL8812_TRANS_ACT_TO_LPS_STEPS	include/Hal8812PwrSeq.h	54;"	d
-RTL8812_TRANS_CARDDIS_TO_CARDEMU	include/Hal8812PwrSeq.h	134;"	d
-RTL8812_TRANS_CARDEMU_TO_ACT	include/Hal8812PwrSeq.h	59;"	d
-RTL8812_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8812PwrSeq.h	48;"	d
-RTL8812_TRANS_CARDEMU_TO_CARDDIS	include/Hal8812PwrSeq.h	111;"	d
-RTL8812_TRANS_CARDEMU_TO_PDN	include/Hal8812PwrSeq.h	149;"	d
-RTL8812_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8812PwrSeq.h	52;"	d
-RTL8812_TRANS_CARDEMU_TO_SUS	include/Hal8812PwrSeq.h	85;"	d
-RTL8812_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8812PwrSeq.h	50;"	d
-RTL8812_TRANS_END	include/Hal8812PwrSeq.h	193;"	d
-RTL8812_TRANS_END_STEPS	include/Hal8812PwrSeq.h	56;"	d
-RTL8812_TRANS_LPS_TO_ACT	include/Hal8812PwrSeq.h	178;"	d
-RTL8812_TRANS_LPS_TO_ACT_STEPS	include/Hal8812PwrSeq.h	55;"	d
-RTL8812_TRANS_PDN_TO_CARDEMU	include/Hal8812PwrSeq.h	154;"	d
-RTL8812_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8812PwrSeq.h	53;"	d
-RTL8812_TRANS_SUS_TO_CARDEMU	include/Hal8812PwrSeq.h	101;"	d
-RTL8812_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8812PwrSeq.h	51;"	d
-RTL8814A	include/hal_intf.h	/^	RTL8814A,$/;"	e	enum:_CHIP_TYPE
-RTL8814AE_SEG_NUM	include/rtl8814a_hal.h	203;"	d
-RTL8814AE_SEG_NUM	include/rtl8814a_hal.h	212;"	d
-RTL8814A_SUPPORT	include/hal_ic_cfg.h	103;"	d
-RTL8814A_SUPPORT	include/hal_ic_cfg.h	104;"	d
-RTL8814A_SUPPORT	include/hal_ic_cfg.h	29;"	d
-RTL8814A_TRANS_ACT_TO_CARDEMU	include/Hal8814PwrSeq.h	76;"	d
-RTL8814A_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8814PwrSeq.h	49;"	d
-RTL8814A_TRANS_ACT_TO_LPS	include/Hal8814PwrSeq.h	182;"	d
-RTL8814A_TRANS_ACT_TO_LPS_STEPS	include/Hal8814PwrSeq.h	54;"	d
-RTL8814A_TRANS_CARDDIS_TO_CARDEMU	include/Hal8814PwrSeq.h	156;"	d
-RTL8814A_TRANS_CARDEMU_TO_ACT	include/Hal8814PwrSeq.h	59;"	d
-RTL8814A_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8814PwrSeq.h	48;"	d
-RTL8814A_TRANS_CARDEMU_TO_CARDDIS	include/Hal8814PwrSeq.h	128;"	d
-RTL8814A_TRANS_CARDEMU_TO_PDN	include/Hal8814PwrSeq.h	172;"	d
-RTL8814A_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8814PwrSeq.h	52;"	d
-RTL8814A_TRANS_CARDEMU_TO_SUS	include/Hal8814PwrSeq.h	100;"	d
-RTL8814A_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8814PwrSeq.h	50;"	d
-RTL8814A_TRANS_END	include/Hal8814PwrSeq.h	220;"	d
-RTL8814A_TRANS_END_STEPS	include/Hal8814PwrSeq.h	56;"	d
-RTL8814A_TRANS_LPS_TO_ACT	include/Hal8814PwrSeq.h	204;"	d
-RTL8814A_TRANS_LPS_TO_ACT_STEPS	include/Hal8814PwrSeq.h	55;"	d
-RTL8814A_TRANS_PDN_TO_CARDEMU	include/Hal8814PwrSeq.h	177;"	d
-RTL8814A_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8814PwrSeq.h	53;"	d
-RTL8814A_TRANS_SUS_TO_CARDEMU	include/Hal8814PwrSeq.h	118;"	d
-RTL8814A_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8814PwrSeq.h	51;"	d
-RTL8821	include/hal_intf.h	/^	RTL8821, \/* RTL8811 *\/$/;"	e	enum:_CHIP_TYPE
-RTL8821AE_HMC_M2_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8821AE_HMC_M2_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8821AE_HMC_M2_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8821AE_HMC_M2_country_chplan_map_sz = sizeof(RTL8821AE_HMC_M2_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8821AU_country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan RTL8821AU_country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-RTL8821AU_country_chplan_map_sz	core/rtw_rf.c	/^static const u16 RTL8821AU_country_chplan_map_sz = sizeof(RTL8821AU_country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v	file:
-RTL8821A_SUPPORT	include/hal_ic_cfg.h	25;"	d
-RTL8821A_SUPPORT	include/hal_ic_cfg.h	65;"	d
-RTL8821A_SUPPORT	include/hal_ic_cfg.h	66;"	d
-RTL8821A_TRANS_ACT_TO_CARDEMU	include/Hal8821APwrSeq.h	68;"	d
-RTL8821A_TRANS_ACT_TO_CARDEMU_STEPS	include/Hal8821APwrSeq.h	28;"	d
-RTL8821A_TRANS_ACT_TO_LPS	include/Hal8821APwrSeq.h	137;"	d
-RTL8821A_TRANS_ACT_TO_LPS_STEPS	include/Hal8821APwrSeq.h	34;"	d
-RTL8821A_TRANS_CARDDIS_TO_CARDEMU	include/Hal8821APwrSeq.h	112;"	d
-RTL8821A_TRANS_CARDDIS_TO_CARDEMU_STEPS	include/Hal8821APwrSeq.h	31;"	d
-RTL8821A_TRANS_CARDEMU_TO_ACT	include/Hal8821APwrSeq.h	39;"	d
-RTL8821A_TRANS_CARDEMU_TO_ACT_STEPS	include/Hal8821APwrSeq.h	27;"	d
-RTL8821A_TRANS_CARDEMU_TO_CARDDIS	include/Hal8821APwrSeq.h	101;"	d
-RTL8821A_TRANS_CARDEMU_TO_PDN	include/Hal8821APwrSeq.h	124;"	d
-RTL8821A_TRANS_CARDEMU_TO_PDN_STEPS	include/Hal8821APwrSeq.h	32;"	d
-RTL8821A_TRANS_CARDEMU_TO_SUS	include/Hal8821APwrSeq.h	81;"	d
-RTL8821A_TRANS_CARDEMU_TO_SUS_STEPS	include/Hal8821APwrSeq.h	29;"	d
-RTL8821A_TRANS_END	include/Hal8821APwrSeq.h	170;"	d
-RTL8821A_TRANS_END_STEPS	include/Hal8821APwrSeq.h	36;"	d
-RTL8821A_TRANS_LPS_TO_ACT	include/Hal8821APwrSeq.h	155;"	d
-RTL8821A_TRANS_LPS_TO_ACT_STEPS	include/Hal8821APwrSeq.h	35;"	d
-RTL8821A_TRANS_PDN_TO_CARDEMU	include/Hal8821APwrSeq.h	132;"	d
-RTL8821A_TRANS_PDN_TO_CARDEMU_STEPS	include/Hal8821APwrSeq.h	33;"	d
-RTL8821A_TRANS_SUS_TO_CARDEMU	include/Hal8821APwrSeq.h	92;"	d
-RTL8821A_TRANS_SUS_TO_CARDEMU_STEPS	include/Hal8821APwrSeq.h	30;"	d
-RTL8821B_SUPPORT	include/hal_ic_cfg.h	35;"	d
-RTL8821C	include/hal_intf.h	/^	RTL8821C,$/;"	e	enum:_CHIP_TYPE
-RTL8821C_SUPPORT	include/hal_ic_cfg.h	141;"	d
-RTL8821C_SUPPORT	include/hal_ic_cfg.h	142;"	d
-RTL8821C_SUPPORT	include/hal_ic_cfg.h	36;"	d
-RTL8822B	include/hal_intf.h	/^	RTL8822B,$/;"	e	enum:_CHIP_TYPE
-RTL8822B_SUPPORT	include/hal_ic_cfg.h	133;"	d
-RTL8822B_SUPPORT	include/hal_ic_cfg.h	134;"	d
-RTL8822B_SUPPORT	include/hal_ic_cfg.h	34;"	d
-RTL8881A_SUPPORT	hal/phydm/phydm_types.h	245;"	d
-RTL92SE_FPGA_VERIFY	include/rtw_mp_phy_regdef.h	317;"	d
-RTL_EEPROM_ID	include/hal_pg.h	619;"	d
-RTL_EXT_C2H_EVT	include/rtw_bt_mp.h	/^} RTL_EXT_C2H_EVT;$/;"	t	typeref:enum:_RTL_EXT_C2H_EVT
-RTL_ID	include/hal_com_reg.h	1276;"	d
-RTL_IOCTL_HOSTAPD	include/ieee80211.h	44;"	d
-RTL_IOCTL_WPA_SUPPLICANT	os_dep/linux/ioctl_linux.c	37;"	d	file:
-RTL_NAPI_WEIGHT	include/rtw_recv.h	55;"	d
-RTL_RELAY_TAG_LEN	core/rtw_br_ext.c	69;"	d	file:
-RTP_TIMER_CFG_WK_CID	include/rtw_cmd.h	/^	RTP_TIMER_CFG_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-RTS_CTS	include/wlan_bssdef.h	/^	RTS_CTS,$/;"	e	enum:VCS_TYPE
-RTS_EN	include/rtl8188e_xmit.h	78;"	d
-RTS_EN	include/rtl8192e_xmit.h	183;"	d
-RTS_EN	include/rtl8812a_xmit.h	76;"	d
-RTT_ATTRIBUTE_TARGET_CHAN	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_CHAN,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_CNT	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_CNT,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_INFO	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_INFO,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_INTERVAL	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_INTERVAL,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_MAC	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_MAC,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_MODE	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_MODE,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_NUM_MEASUREMENT	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_NUM_MEASUREMENT,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_NUM_PKT	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_NUM_PKT,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_NUM_RETRY	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_NUM_RETRY$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_PEER	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_PEER,$/;"	e	enum:rtt_attributes
-RTT_ATTRIBUTE_TARGET_TYPE	os_dep/linux/rtw_cfgvendor.h	/^	RTT_ATTRIBUTE_TARGET_TYPE,$/;"	e	enum:rtt_attributes
-RTT_SUBCMD_CANCEL_CONFIG	os_dep/linux/rtw_cfgvendor.h	/^	RTT_SUBCMD_CANCEL_CONFIG,$/;"	e	enum:wl_vendor_subcmd
-RTT_SUBCMD_GETCAPABILITY	os_dep/linux/rtw_cfgvendor.h	/^	RTT_SUBCMD_GETCAPABILITY,$/;"	e	enum:wl_vendor_subcmd
-RTT_SUBCMD_SET_CONFIG	os_dep/linux/rtw_cfgvendor.h	/^	RTT_SUBCMD_SET_CONFIG = ANDROID_NL80211_SUBCMD_RTT_RANGE_START,$/;"	e	enum:wl_vendor_subcmd
-RTWPRIV_VER_INFO	include/rtw_mp.h	23;"	d
-RTW_2GHZ_CH01_11	os_dep/linux/wifi_regd.c	27;"	d	file:
-RTW_2GHZ_CH12_13	os_dep/linux/wifi_regd.c	36;"	d	file:
-RTW_2GHZ_CH14	os_dep/linux/wifi_regd.c	41;"	d	file:
-RTW_2G_CHANNELS_NUM	os_dep/linux/ioctl_cfg80211.c	145;"	d	file:
-RTW_5GHZ_5150_5350	os_dep/linux/wifi_regd.c	46;"	d	file:
-RTW_5GHZ_5150_5850	os_dep/linux/wifi_regd.c	61;"	d	file:
-RTW_5GHZ_5470_5850	os_dep/linux/wifi_regd.c	51;"	d	file:
-RTW_5GHZ_5725_5850	os_dep/linux/wifi_regd.c	56;"	d	file:
-RTW_5G_CHANNELS_NUM	os_dep/linux/ioctl_cfg80211.c	146;"	d	file:
-RTW_ACL_MODE_ACCEPT_UNLESS_LISTED	include/sta_info.h	32;"	d
-RTW_ACL_MODE_DENY_UNLESS_LISTED	include/sta_info.h	33;"	d
-RTW_ACL_MODE_DISABLED	include/sta_info.h	31;"	d
-RTW_ACL_MODE_MAX	include/sta_info.h	34;"	d
-RTW_ADAPTIVITY_DML_DISABLE	core/rtw_odm.c	237;"	d	file:
-RTW_ADAPTIVITY_DML_ENABLE	core/rtw_odm.c	238;"	d	file:
-RTW_ADAPTIVITY_EN_DISABLE	core/rtw_odm.c	200;"	d	file:
-RTW_ADAPTIVITY_EN_ENABLE	core/rtw_odm.c	201;"	d	file:
-RTW_ADAPTIVITY_MODE_CARRIER_SENSE	core/rtw_odm.c	221;"	d	file:
-RTW_ADAPTIVITY_MODE_NORMAL	core/rtw_odm.c	220;"	d	file:
-RTW_AUTO_SCAN_REASON_2040_BSS	include/rtw_mlme.h	866;"	d
-RTW_AUTO_SCAN_REASON_ACS	include/rtw_mlme.h	867;"	d
-RTW_AUTO_SCAN_REASON_ROAM	include/rtw_mlme.h	868;"	d
-RTW_AUTO_SCAN_REASON_UNSPECIFIED	include/rtw_mlme.h	865;"	d
-RTW_A_RATES_NUM	os_dep/linux/ioctl_cfg80211.c	141;"	d	file:
-RTW_BACK_OP_CH_MS	include/rtw_mlme_ext.h	430;"	d
-RTW_BACK_OP_CH_MS	include/rtw_mlme_ext.h	433;"	d
-RTW_CAC_STOPPED	include/drv_types.h	807;"	d
-RTW_CANNOT_IO	include/drv_types.h	1528;"	d
-RTW_CANNOT_RUN	include/drv_types.h	1522;"	d
-RTW_CANNOT_RX	include/drv_types.h	1532;"	d
-RTW_CANNOT_TX	include/drv_types.h	1536;"	d
-RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE	core/rtw_mlme_ext.c	/^static RT_CHANNEL_PLAN_MAP RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE =$/;"	v	file:
-RTW_CHANNEL_SCAN_AMOUNT	include/rtw_cmd.h	366;"	d
-RTW_CHF_2G	include/rtw_mlme_ext.h	/^	RTW_CHF_2G = BIT0,$/;"	e	enum:__anon51
-RTW_CHF_5G	include/rtw_mlme_ext.h	/^	RTW_CHF_5G = BIT1,$/;"	e	enum:__anon51
-RTW_CHF_DFS	include/rtw_mlme_ext.h	/^	RTW_CHF_DFS = BIT2,$/;"	e	enum:__anon51
-RTW_CHF_LONG_CAC	include/rtw_mlme_ext.h	/^	RTW_CHF_LONG_CAC = BIT3,$/;"	e	enum:__anon51
-RTW_CHF_NON_DFS	include/rtw_mlme_ext.h	/^	RTW_CHF_NON_DFS = BIT4,$/;"	e	enum:__anon51
-RTW_CHF_NON_LONG_CAC	include/rtw_mlme_ext.h	/^	RTW_CHF_NON_LONG_CAC = BIT5,$/;"	e	enum:__anon51
-RTW_CHF_NON_OCP	include/rtw_mlme_ext.h	/^	RTW_CHF_NON_OCP = BIT6,$/;"	e	enum:__anon51
-RTW_CHPLAN_CHINA	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_CHINA = 0x0C,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_ETSI	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_ETSI = 0x02,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_ETSI1_ETSI4	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_ETSI1_ETSI4 = 0x42,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_ETSI1_NULL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_ETSI1_NULL = 0x21,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_ETSI2_NULL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_ETSI2_NULL = 0x24,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC = 0x00,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_FCC1	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_FCC1 = 0x25,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_FCC10	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_FCC10 = 0x57,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_FCC2	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_FCC2 = 0x43,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_FCC5	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_FCC5 = 0x60,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_FCC7	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_FCC7 = 0x34,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_FCC8	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_FCC8 = 0x46,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_FCC9	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_FCC9 = 0x55,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_NCC1	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_NCC1 = 0x39,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_NCC2	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_NCC2 = 0x40,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_NCC3	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_NCC3 = 0x44,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_NCC4	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_NCC4 = 0x53,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC1_NULL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC1_NULL = 0x22,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC2_FCC1	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC2_FCC1 = 0x62,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC2_FCC7	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC2_FCC7 = 0x61,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC2_NULL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC2_NULL = 0x2A,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FCC_NO_DFS	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FCC_NO_DFS = 0x11,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_FRANCE	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_FRANCE = 0x04,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_GLOBAL_DOAMIN	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_GLOBAL_DOAMIN = 0x09,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_GLOBAL_NULL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_GLOBAL_NULL = 0x41,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_IC	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_IC = 0x01,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_ISRAEL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_ISRAEL = 0x07,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_JAPAN	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_JAPAN = 0x10,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_JAPAN_NO_DFS	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_JAPAN_NO_DFS = 0x12,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_KOREA	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_KOREA = 0x0E,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MAX	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MAX,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MKK	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MKK = 0x05,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MKK1	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MKK1 = 0x06,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MKK1_MKK1	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MKK1_MKK1 = 0x27,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MKK1_MKK2	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MKK1_MKK2 = 0x37,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MKK1_MKK3	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MKK1_MKK3 = 0x38,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MKK1_NULL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MKK1_NULL = 0x23,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_MKK2_MKK4	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_MKK2_MKK4 = 0x58,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_REALTEK_DEFINE	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_REALTEK_DEFINE = 0x7F,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_SINGAPORE_INDIA_MEXICO	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_SINGAPORE_INDIA_MEXICO = 0x0D,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_SPAIN	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_SPAIN = 0x03,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_TAIWAN	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_TAIWAN = 0x0B,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_TAIWAN_NO_DFS	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_TAIWAN_NO_DFS = 0x14,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_TELEC	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_TELEC = 0x08,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_TURKEY	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_TURKEY = 0x0F,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI1	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI1 = 0x26,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI10	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI10 = 0x51,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI11	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI11 = 0x52,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI12	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI12 = 0x54,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI13	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI13 = 0x56,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI14	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI14 = 0x59,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI2	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI2 = 0x35,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI3	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI3 = 0x36,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI5	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI5 = 0x45,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI6	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI6 = 0x47,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI7	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI7 = 0x48,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI8	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI8 = 0x49,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_ETSI9	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_ETSI9 = 0x50,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_FCC2	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_FCC2 = 0x29,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_FCC3	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_FCC3 = 0x30,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_FCC4	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_FCC4 = 0x31,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_FCC5	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_FCC5 = 0x32,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_FCC6	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_FCC6 = 0x33,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_KCC1	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_KCC1 = 0x28,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_NULL	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_NULL = 0x20,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_WIDE_13	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_WIDE_13 = 0x0A,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CHPLAN_WORLD_WIDE_5G	include/rtw_mlme_ext.h	/^	RTW_CHPLAN_WORLD_WIDE_5G = 0x13,$/;"	e	enum:_RT_CHANNEL_DOMAIN
-RTW_CH_MAX_2G_CHANNEL	os_dep/linux/ioctl_cfg80211.c	43;"	d	file:
-RTW_CLR_SCAN_BAND_SKIP	core/rtw_mlme_ext.c	/^inline void RTW_CLR_SCAN_BAND_SKIP(_adapter *padapter, int skip_band)$/;"	f
-RTW_CMDF_DIRECTLY	include/rtw_cmd.h	/^	RTW_CMDF_DIRECTLY = BIT0,$/;"	e	enum:__anon3
-RTW_CMDF_WAIT_ACK	include/rtw_cmd.h	/^	RTW_CMDF_WAIT_ACK = BIT1,$/;"	e	enum:__anon3
-RTW_CUSTOMER_STR_ARG	include/hal_com_h2c.h	269;"	d
-RTW_CUSTOMER_STR_FMT	include/hal_com_h2c.h	268;"	d
-RTW_CUSTOMER_STR_LEN	include/hal_com_h2c.h	267;"	d
-RTW_ChannelPlan2G	core/rtw_mlme_ext.c	/^static struct ch_list_t RTW_ChannelPlan2G[] = {$/;"	v	typeref:struct:ch_list_t	file:
-RTW_ChannelPlan5G	core/rtw_mlme_ext.c	/^static struct ch_list_t RTW_ChannelPlan5G[] = {$/;"	v	typeref:struct:ch_list_t	file:
-RTW_ChannelPlanMap	core/rtw_mlme_ext.c	/^static RT_CHANNEL_PLAN_MAP	RTW_ChannelPlanMap[] = {$/;"	v	file:
-RTW_DBG	include/rtw_debug.h	142;"	d
-RTW_DBG	include/rtw_debug.h	143;"	d
-RTW_DBG	include/rtw_debug.h	45;"	d
-RTW_DBG	include/rtw_debug.h	58;"	d
-RTW_DBGDUMP	include/rtw_debug.h	76;"	d
-RTW_DBG_DUMP	include/rtw_debug.h	168;"	d
-RTW_DBG_DUMP	include/rtw_debug.h	169;"	d
-RTW_DBG_DUMP	include/rtw_debug.h	69;"	d
-RTW_DBG_EXPR	include/rtw_debug.h	275;"	d
-RTW_DBG_EXPR	include/rtw_debug.h	276;"	d
-RTW_DBG_EXPR	include/rtw_debug.h	74;"	d
-RTW_DECLARE_TIMER_HDL	include/osdep_service.h	53;"	d
-RTW_DEDICATED_P2P_DEVICE	os_dep/linux/ioctl_cfg80211.h	50;"	d
-RTW_DEF_MODULE_REGULATORY_CERT	include/drv_conf.h	173;"	d
-RTW_DEF_MODULE_REGULATORY_CERT	include/drv_conf.h	286;"	d
-RTW_DISABLE_FUNC	include/drv_types.h	/^__inline static void RTW_DISABLE_FUNC(_adapter *padapter, int func_bit)$/;"	f
-RTW_ENABLE_FUNC	include/drv_types.h	/^__inline static void RTW_ENABLE_FUNC(_adapter *padapter, int func_bit)$/;"	f
-RTW_ERP_INFO_BARKER_PREAMBLE_MODE	include/ieee80211.h	530;"	d
-RTW_ERP_INFO_NON_ERP_PRESENT	include/ieee80211.h	528;"	d
-RTW_ERP_INFO_USE_PROTECTION	include/ieee80211.h	529;"	d
-RTW_ERR	include/rtw_debug.h	116;"	d
-RTW_ERR	include/rtw_debug.h	117;"	d
-RTW_ERR	include/rtw_debug.h	42;"	d
-RTW_ERR	include/rtw_debug.h	55;"	d
-RTW_FT_ASSOCIATED_STA	include/rtw_mlme.h	/^	RTW_FT_ASSOCIATED_STA,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_ASSOCIATING_STA	include/rtw_mlme.h	/^	RTW_FT_ASSOCIATING_STA,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_AUTHENTICATED_STA	include/rtw_mlme.h	/^	RTW_FT_AUTHENTICATED_STA,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_AUTHENTICATING_STA	include/rtw_mlme.h	/^	RTW_FT_AUTHENTICATING_STA,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_CONFIRMED_STA	include/rtw_mlme.h	/^	RTW_FT_CONFIRMED_STA,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_OVER_DS_SUPPORTED	include/rtw_mlme.h	/^	RTW_FT_OVER_DS_SUPPORTED = BIT3,$/;"	e	enum:_RTW_WIFI_FT_CAPABILITY
-RTW_FT_REQUESTED_STA	include/rtw_mlme.h	/^	RTW_FT_REQUESTED_STA,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_REQUESTING_STA	include/rtw_mlme.h	/^	RTW_FT_REQUESTING_STA,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_STA_OVER_DS_SUPPORTED	include/rtw_mlme.h	/^	RTW_FT_STA_OVER_DS_SUPPORTED = BIT1,$/;"	e	enum:_RTW_WIFI_FT_CAPABILITY
-RTW_FT_STA_SUPPORTED	include/rtw_mlme.h	/^	RTW_FT_STA_SUPPORTED = BIT0,$/;"	e	enum:_RTW_WIFI_FT_CAPABILITY
-RTW_FT_SUPPORTED	include/rtw_mlme.h	/^	RTW_FT_SUPPORTED = BIT2,$/;"	e	enum:_RTW_WIFI_FT_CAPABILITY
-RTW_FT_UNASSOCIATED_STA	include/rtw_mlme.h	/^	RTW_FT_UNASSOCIATED_STA = 0,$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_FT_UNSPECIFIED_STA	include/rtw_mlme.h	/^	RTW_FT_UNSPECIFIED_STA$/;"	e	enum:_RTW_WIFI_FT_STA_STATUS
-RTW_GET_BE16	include/osdep_service.h	570;"	d
-RTW_GET_BE24	include/osdep_service.h	584;"	d
-RTW_GET_BE32	include/osdep_service.h	593;"	d
-RTW_GET_BE64	include/osdep_service.h	613;"	d
-RTW_GET_LE16	include/osdep_service.h	577;"	d
-RTW_GET_LE32	include/osdep_service.h	603;"	d
-RTW_GET_LE64	include/osdep_service.h	629;"	d
-RTW_GET_SCAN_BAND_SKIP	core/rtw_mlme_ext.c	/^inline int RTW_GET_SCAN_BAND_SKIP(_adapter *padapter)$/;"	f
-RTW_GSPI	include/hal_intf.h	/^	RTW_GSPI	= BIT3,$/;"	e	enum:RTL871X_HCI_TYPE
-RTW_G_RATES_NUM	os_dep/linux/ioctl_cfg80211.c	143;"	d	file:
-RTW_HALMAC_BA_SSN_RPT_SIZE	hal/hal_halmac.h	28;"	d
-RTW_HALMAC_FEATURE_NAME	hal/hal_halmac.c	/^const char *const RTW_HALMAC_FEATURE_NAME[] = {$/;"	v
-RTW_HALMAC_H2C_MAX_SIZE	hal/hal_halmac.h	27;"	d
-RTW_HALMAC_MODE	hal/hal_halmac.h	/^} RTW_HALMAC_MODE;$/;"	t	typeref:enum:_RTW_HALMAC_MODE
-RTW_HALMAC_MODE_NORMAL	hal/hal_halmac.h	/^	RTW_HALMAC_MODE_NORMAL,$/;"	e	enum:_RTW_HALMAC_MODE
-RTW_HALMAC_MODE_WIFI_TEST	hal/hal_halmac.h	/^	RTW_HALMAC_MODE_WIFI_TEST,$/;"	e	enum:_RTW_HALMAC_MODE
-RTW_HCI_EXT_CMD	include/rtw_btcoex.h	/^} RTW_HCI_EXT_CMD;$/;"	t	typeref:enum:HCI_EXTENSION_COMMANDS
-RTW_HCI_EXT_EVENT	include/rtw_btcoex.h	/^} RTW_HCI_EXT_EVENT;$/;"	t	typeref:enum:HCI_EXTENSION_EVENT_RTK
-RTW_HCI_STATUS	include/rtw_btcoex.h	/^} RTW_HCI_STATUS;$/;"	t	typeref:enum:_HCI_STATUS
-RTW_HIQ_FILTER_ALLOW_ALL	core/rtw_xmit.c	4136;"	d	file:
-RTW_HIQ_FILTER_ALLOW_SPECIAL	core/rtw_xmit.c	4137;"	d	file:
-RTW_HIQ_FILTER_DENY_ALL	core/rtw_xmit.c	4138;"	d	file:
-RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK	include/wifi.h	997;"	d
-RTW_IEEE80211_CHAN_DISABLED	include/ieee80211.h	/^	RTW_IEEE80211_CHAN_DISABLED         = 1 << 0,$/;"	e	enum:rtw_ieee80211_channel_flags
-RTW_IEEE80211_CHAN_NO_HT40	include/ieee80211.h	1709;"	d
-RTW_IEEE80211_CHAN_NO_HT40MINUS	include/ieee80211.h	/^	RTW_IEEE80211_CHAN_NO_HT40MINUS     = 1 << 5,$/;"	e	enum:rtw_ieee80211_channel_flags
-RTW_IEEE80211_CHAN_NO_HT40PLUS	include/ieee80211.h	/^	RTW_IEEE80211_CHAN_NO_HT40PLUS      = 1 << 4,$/;"	e	enum:rtw_ieee80211_channel_flags
-RTW_IEEE80211_CHAN_NO_IBSS	include/ieee80211.h	/^	RTW_IEEE80211_CHAN_NO_IBSS          = 1 << 2,$/;"	e	enum:rtw_ieee80211_channel_flags
-RTW_IEEE80211_CHAN_PASSIVE_SCAN	include/ieee80211.h	/^	RTW_IEEE80211_CHAN_PASSIVE_SCAN     = 1 << 1,$/;"	e	enum:rtw_ieee80211_channel_flags
-RTW_IEEE80211_CHAN_RADAR	include/ieee80211.h	/^	RTW_IEEE80211_CHAN_RADAR            = 1 << 3,$/;"	e	enum:rtw_ieee80211_channel_flags
-RTW_IEEE80211_FCTL_CTL_EXT	include/ieee80211.h	473;"	d
-RTW_IEEE80211_FCTL_FROMDS	include/ieee80211.h	466;"	d
-RTW_IEEE80211_FCTL_FTYPE	include/ieee80211.h	463;"	d
-RTW_IEEE80211_FCTL_MOREDATA	include/ieee80211.h	470;"	d
-RTW_IEEE80211_FCTL_MOREFRAGS	include/ieee80211.h	467;"	d
-RTW_IEEE80211_FCTL_ORDER	include/ieee80211.h	472;"	d
-RTW_IEEE80211_FCTL_PM	include/ieee80211.h	469;"	d
-RTW_IEEE80211_FCTL_PROTECTED	include/ieee80211.h	471;"	d
-RTW_IEEE80211_FCTL_RETRY	include/ieee80211.h	468;"	d
-RTW_IEEE80211_FCTL_STYPE	include/ieee80211.h	464;"	d
-RTW_IEEE80211_FCTL_TODS	include/ieee80211.h	465;"	d
-RTW_IEEE80211_FCTL_VERS	include/ieee80211.h	462;"	d
-RTW_IEEE80211_FTYPE_CTL	include/ieee80211.h	476;"	d
-RTW_IEEE80211_FTYPE_DATA	include/ieee80211.h	477;"	d
-RTW_IEEE80211_FTYPE_EXT	include/ieee80211.h	478;"	d
-RTW_IEEE80211_FTYPE_MGMT	include/ieee80211.h	475;"	d
-RTW_IEEE80211_HT_CAP_40MHZ_INTOLERANT	include/wifi.h	966;"	d
-RTW_IEEE80211_SCTL_FRAG	include/ieee80211.h	524;"	d
-RTW_IEEE80211_SCTL_SEQ	include/ieee80211.h	525;"	d
-RTW_IEEE80211_STYPE_ACK	include/ieee80211.h	501;"	d
-RTW_IEEE80211_STYPE_ACTION	include/ieee80211.h	492;"	d
-RTW_IEEE80211_STYPE_ASSOC_REQ	include/ieee80211.h	481;"	d
-RTW_IEEE80211_STYPE_ASSOC_RESP	include/ieee80211.h	482;"	d
-RTW_IEEE80211_STYPE_ATIM	include/ieee80211.h	488;"	d
-RTW_IEEE80211_STYPE_AUTH	include/ieee80211.h	490;"	d
-RTW_IEEE80211_STYPE_BACK	include/ieee80211.h	497;"	d
-RTW_IEEE80211_STYPE_BACK_REQ	include/ieee80211.h	496;"	d
-RTW_IEEE80211_STYPE_BEACON	include/ieee80211.h	487;"	d
-RTW_IEEE80211_STYPE_CFACK	include/ieee80211.h	511;"	d
-RTW_IEEE80211_STYPE_CFACKPOLL	include/ieee80211.h	513;"	d
-RTW_IEEE80211_STYPE_CFEND	include/ieee80211.h	502;"	d
-RTW_IEEE80211_STYPE_CFENDACK	include/ieee80211.h	503;"	d
-RTW_IEEE80211_STYPE_CFPOLL	include/ieee80211.h	512;"	d
-RTW_IEEE80211_STYPE_CTL_EXT	include/ieee80211.h	495;"	d
-RTW_IEEE80211_STYPE_CTS	include/ieee80211.h	500;"	d
-RTW_IEEE80211_STYPE_DATA	include/ieee80211.h	506;"	d
-RTW_IEEE80211_STYPE_DATA_CFACK	include/ieee80211.h	507;"	d
-RTW_IEEE80211_STYPE_DATA_CFACKPOLL	include/ieee80211.h	509;"	d
-RTW_IEEE80211_STYPE_DATA_CFPOLL	include/ieee80211.h	508;"	d
-RTW_IEEE80211_STYPE_DEAUTH	include/ieee80211.h	491;"	d
-RTW_IEEE80211_STYPE_DISASSOC	include/ieee80211.h	489;"	d
-RTW_IEEE80211_STYPE_NULLFUNC	include/ieee80211.h	510;"	d
-RTW_IEEE80211_STYPE_PROBE_REQ	include/ieee80211.h	485;"	d
-RTW_IEEE80211_STYPE_PROBE_RESP	include/ieee80211.h	486;"	d
-RTW_IEEE80211_STYPE_PSPOLL	include/ieee80211.h	498;"	d
-RTW_IEEE80211_STYPE_QOS_CFACK	include/ieee80211.h	519;"	d
-RTW_IEEE80211_STYPE_QOS_CFACKPOLL	include/ieee80211.h	521;"	d
-RTW_IEEE80211_STYPE_QOS_CFPOLL	include/ieee80211.h	520;"	d
-RTW_IEEE80211_STYPE_QOS_DATA	include/ieee80211.h	514;"	d
-RTW_IEEE80211_STYPE_QOS_DATA_CFACK	include/ieee80211.h	515;"	d
-RTW_IEEE80211_STYPE_QOS_DATA_CFACKPOLL	include/ieee80211.h	517;"	d
-RTW_IEEE80211_STYPE_QOS_DATA_CFPOLL	include/ieee80211.h	516;"	d
-RTW_IEEE80211_STYPE_QOS_NULLFUNC	include/ieee80211.h	518;"	d
-RTW_IEEE80211_STYPE_REASSOC_REQ	include/ieee80211.h	483;"	d
-RTW_IEEE80211_STYPE_REASSOC_RESP	include/ieee80211.h	484;"	d
-RTW_IEEE80211_STYPE_RTS	include/ieee80211.h	499;"	d
-RTW_IF_OPS	include/drv_types.h	/^} RTW_IF_OPS, *PRTW_IF_OPS;$/;"	t	typeref:struct:rtw_if_operations
-RTW_INFO	include/rtw_debug.h	133;"	d
-RTW_INFO	include/rtw_debug.h	134;"	d
-RTW_INFO	include/rtw_debug.h	44;"	d
-RTW_INFO	include/rtw_debug.h	57;"	d
-RTW_INFO_DUMP	include/rtw_debug.h	151;"	d
-RTW_INFO_DUMP	include/rtw_debug.h	152;"	d
-RTW_INFO_DUMP	include/rtw_debug.h	68;"	d
-RTW_IS_FUNC_DISABLED	include/drv_types.h	1526;"	d
-RTW_IS_SCAN_BAND_SKIP	core/rtw_mlme_ext.c	957;"	d	file:
-RTW_KCK_LEN	include/rtw_security.h	52;"	d
-RTW_KEK_LEN	include/rtw_security.h	51;"	d
-RTW_LED_OFF	include/hal_com_led.h	/^	RTW_LED_OFF = 2,$/;"	e	enum:_LED_STATE
-RTW_LED_ON	include/hal_com_led.h	/^	RTW_LED_ON = 1,$/;"	e	enum:_LED_STATE
-RTW_MAX_FTIE_SZ	include/rtw_mlme.h	569;"	d
-RTW_MAX_MGMT_TX_CNT	os_dep/linux/ioctl_cfg80211.c	36;"	d	file:
-RTW_MAX_MGMT_TX_MS_GAS	os_dep/linux/ioctl_cfg80211.c	37;"	d	file:
-RTW_MAX_NUM_PMKIDS	os_dep/linux/ioctl_cfg80211.c	41;"	d	file:
-RTW_MAX_REMAIN_ON_CHANNEL_DURATION	os_dep/linux/ioctl_cfg80211.c	40;"	d	file:
-RTW_MODULE_RTL8188EE_HMC_M2	include/rtw_rf.h	231;"	d
-RTW_MODULE_RTL8192EEBT_HMC_M2	include/rtw_rf.h	234;"	d
-RTW_MODULE_RTL8723BE_HMC_M2	include/rtw_rf.h	232;"	d
-RTW_MODULE_RTL8723BS_NGFF1216	include/rtw_rf.h	233;"	d
-RTW_MODULE_RTL8812AEBT_HMC	include/rtw_rf.h	230;"	d
-RTW_MODULE_RTL8812AENF_NGFF	include/rtw_rf.h	229;"	d
-RTW_MODULE_RTL8821AE_HMC_M2	include/rtw_rf.h	227;"	d
-RTW_MODULE_RTL8821AU	include/rtw_rf.h	228;"	d
-RTW_NOTCH_FILTER	include/autoconf.h	129;"	d
-RTW_ODM_ABILITY_MAX	core/rtw_odm.c	90;"	d	file:
-RTW_ODM_COMP_MAX	core/rtw_odm.c	58;"	d	file:
-RTW_ODM_DBG_LEVEL_NUM	core/rtw_odm.c	101;"	d	file:
-RTW_P2P_GROUP_INTERFACE	os_dep/linux/ioctl_cfg80211.h	29;"	d
-RTW_PCIE	include/hal_intf.h	/^	RTW_PCIE	= BIT0,$/;"	e	enum:RTL871X_HCI_TYPE
-RTW_PRINT	include/rtw_debug.h	108;"	d
-RTW_PRINT	include/rtw_debug.h	109;"	d
-RTW_PRINT	include/rtw_debug.h	41;"	d
-RTW_PRINT	include/rtw_debug.h	54;"	d
-RTW_PRINT_DUMP	include/rtw_debug.h	186;"	d
-RTW_PRINT_DUMP	include/rtw_debug.h	187;"	d
-RTW_PRINT_DUMP	include/rtw_debug.h	70;"	d
-RTW_PRINT_SEL	include/rtw_debug.h	284;"	d
-RTW_PRINT_SEL	include/rtw_debug.h	285;"	d
-RTW_PRINT_SEL	include/rtw_debug.h	46;"	d
-RTW_PRINT_SEL	include/rtw_debug.h	59;"	d
-RTW_PROC_HDL_SEQ	os_dep/linux/rtw_proc.h	39;"	d
-RTW_PROC_HDL_SSEQ	os_dep/linux/rtw_proc.h	42;"	d
-RTW_PROC_HDL_TYPE_SEQ	os_dep/linux/rtw_proc.h	26;"	d
-RTW_PROC_HDL_TYPE_SSEQ	os_dep/linux/rtw_proc.h	27;"	d
-RTW_PROC_NAME	os_dep/linux/rtw_proc.c	38;"	d	file:
-RTW_PUT_BE16	include/osdep_service.h	571;"	d
-RTW_PUT_BE24	include/osdep_service.h	586;"	d
-RTW_PUT_BE32	include/osdep_service.h	595;"	d
-RTW_PUT_BE64	include/osdep_service.h	617;"	d
-RTW_PUT_LE16	include/osdep_service.h	578;"	d
-RTW_PUT_LE32	include/osdep_service.h	605;"	d
-RTW_PWR_STATE_CHK_INTERVAL	include/rtw_pwrctrl.h	452;"	d
-RTW_RD_2G_ETSI1	include/rtw_mlme_ext.h	/^	RTW_RD_2G_ETSI1 = 2,	\/* Europe *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_ETSI2	include/rtw_mlme_ext.h	/^	RTW_RD_2G_ETSI2 = 5,	\/* France *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_FCC1	include/rtw_mlme_ext.h	/^	RTW_RD_2G_FCC1 = 3,		\/* US *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_FCC2	include/rtw_mlme_ext.h	/^	RTW_RD_2G_FCC2 = 8,		\/* US *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_GLOBAL	include/rtw_mlme_ext.h	/^	RTW_RD_2G_GLOBAL = 6,	\/* Global domain *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_MAX	include/rtw_mlme_ext.h	/^	RTW_RD_2G_MAX,$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_MKK1	include/rtw_mlme_ext.h	/^	RTW_RD_2G_MKK1 = 4,		\/* Japan *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_MKK2	include/rtw_mlme_ext.h	/^	RTW_RD_2G_MKK2 = 7,		\/* Japan *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_NULL	include/rtw_mlme_ext.h	/^	RTW_RD_2G_NULL = 0,$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_2G_WORLD	include/rtw_mlme_ext.h	/^	RTW_RD_2G_WORLD = 1,	\/* Worldwird 13 *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_2G
-RTW_RD_5G_ETSI1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI1 = 1,	\/* Europe *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI10	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI10 = 25,	\/* Qatar *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI11	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI11 = 26,	\/* Russia *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI12	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI12 = 28,	\/* Indonesia *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI13	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI13 = 30,	\/* (w\/o Weather radar) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI14	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI14 = 33,	\/* Russia *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI2	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI2 = 2,	\/* Australia, New Zealand *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI3	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI3 = 3,	\/* Russia *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI4	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI4 = 18,	\/* Europe w\/o DFS, Band1 only *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI5	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI5 = 19,	\/* Australia, New Zealand(w\/o Weather radar) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI6	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI6 = 21,	\/* Israel, Bahrain, Egypt, India, China, Malaysia *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI7	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI7 = 22,	\/* China *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI8	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI8 = 23,	\/* Jordan *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_ETSI9	include/rtw_mlme_ext.h	/^	RTW_RD_5G_ETSI9 = 24,	\/* Lebanon *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC1 = 4,		\/* US *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC10	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC10 = 31,	\/* Argentina(w\/o Weather radar) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC11	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC11 = 34,	\/* US(include CH144) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC2	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC2 = 5,		\/* FCC w\/o DFS Channels *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC3	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC3 = 6,		\/* Bolivia, Chile, El Salvador, Venezuela *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC4	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC4 = 7,		\/* Venezuela *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC5	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC5 = 8,		\/* China *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC6	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC6 = 9,		\/*	*\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC7	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC7 = 10,	\/* US Canada(w\/o Weather radar) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC8	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC8 = 20,	\/* Latin America *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_FCC9	include/rtw_mlme_ext.h	/^	RTW_RD_5G_FCC9 = 29,	\/* (w\/o Weather radar) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_KCC1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_KCC1 = 11,	\/* Korea *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_MAX	include/rtw_mlme_ext.h	/^	RTW_RD_5G_MAX,$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_MKK1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_MKK1 = 12,	\/* Japan *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_MKK2	include/rtw_mlme_ext.h	/^	RTW_RD_5G_MKK2 = 13,	\/* Japan (W52, W53) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_MKK3	include/rtw_mlme_ext.h	/^	RTW_RD_5G_MKK3 = 14,	\/* Japan (W56) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_MKK4	include/rtw_mlme_ext.h	/^	RTW_RD_5G_MKK4 = 32,	\/* Japan (W52) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_NCC1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_NCC1 = 15,	\/* Taiwan, (w\/o Weather radar) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_NCC2	include/rtw_mlme_ext.h	/^	RTW_RD_5G_NCC2 = 16,	\/* Taiwan, Band2, Band4 *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_NCC3	include/rtw_mlme_ext.h	/^	RTW_RD_5G_NCC3 = 17,	\/* Taiwan w\/o DFS, Band4 only *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_NCC4	include/rtw_mlme_ext.h	/^	RTW_RD_5G_NCC4 = 27,	\/* Taiwan, (w\/o Weather radar) *\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_NULL	include/rtw_mlme_ext.h	/^	RTW_RD_5G_NULL = 0,		\/*	*\/$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_OLD_FCC1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_OLD_FCC1,$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_OLD_KCC1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_OLD_KCC1,$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_RD_5G_OLD_NCC1	include/rtw_mlme_ext.h	/^	RTW_RD_5G_OLD_NCC1,$/;"	e	enum:_RT_CHANNEL_DOMAIN_5G
-RTW_REPLAY_CTR_LEN	include/rtw_security.h	54;"	d
-RTW_RESUME_SCAN_LOCK_NAME	os_dep/osdep_service.c	1661;"	d	file:
-RTW_ROAM_ACTIVE	include/rtw_mlme.h	/^	RTW_ROAM_ACTIVE = BIT2,$/;"	e	enum:__anon43
-RTW_ROAM_ON_EXPIRED	include/rtw_mlme.h	/^	RTW_ROAM_ON_EXPIRED = BIT0,$/;"	e	enum:__anon43
-RTW_ROAM_ON_RESUME	include/rtw_mlme.h	/^	RTW_ROAM_ON_RESUME = BIT1,$/;"	e	enum:__anon43
-RTW_ROAM_RSSI_DIFF_TH	core/rtw_mlme.c	96;"	d	file:
-RTW_ROAM_RSSI_THRESHOLD	core/rtw_mlme.c	98;"	d	file:
-RTW_ROAM_SCAN_INTERVAL_MS	core/rtw_mlme.c	97;"	d	file:
-RTW_ROAM_SCAN_RESULT_EXP_MS	core/rtw_mlme.c	95;"	d	file:
-RTW_ROCH_BACK_OP	os_dep/linux/ioctl_cfg80211.c	5019;"	d	file:
-RTW_ROCH_DURATION_ENLARGE	os_dep/linux/ioctl_cfg80211.c	5018;"	d	file:
-RTW_RX_AGGREGATION	include/drv_conf.h	319;"	d
-RTW_RX_HANDLED	include/osdep_service.h	26;"	d
-RTW_SCAN_IE_LEN_MAX	os_dep/linux/ioctl_cfg80211.c	39;"	d	file:
-RTW_SCAN_NUM_OF_CH	include/rtw_mlme_ext.h	429;"	d
-RTW_SCAN_NUM_OF_CH	include/rtw_mlme_ext.h	432;"	d
-RTW_SCAN_SPARSE_BG	include/drv_conf.h	109;"	d
-RTW_SCAN_SPARSE_BG_INTERVAL_MS	core/rtw_mlme_ext.c	13513;"	d	file:
-RTW_SCAN_SPARSE_CH_NUM_BG	core/rtw_mlme_ext.c	13520;"	d	file:
-RTW_SCAN_SPARSE_CH_NUM_MIRACAST	core/rtw_mlme_ext.c	13517;"	d	file:
-RTW_SCAN_SPARSE_CH_NUM_ROAMING_ACTIVE	core/rtw_mlme_ext.c	13524;"	d	file:
-RTW_SCAN_SPARSE_MIRACAST	include/drv_conf.h	108;"	d
-RTW_SCAN_SPARSE_ROAMING_ACTIVE	include/drv_conf.h	110;"	d
-RTW_SCTX_DONE_BUF_ALLOC	include/rtw_xmit.h	/^	RTW_SCTX_DONE_BUF_ALLOC,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_BUF_FREE	include/rtw_xmit.h	/^	RTW_SCTX_DONE_BUF_FREE,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_CCX_PKT_FAIL	include/rtw_xmit.h	/^	RTW_SCTX_DONE_CCX_PKT_FAIL,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_CMD_ERROR	include/rtw_xmit.h	/^	RTW_SCTX_DONE_CMD_ERROR,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_DEV_REMOVE	include/rtw_xmit.h	/^	RTW_SCTX_DONE_DEV_REMOVE,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_DRV_STOP	include/rtw_xmit.h	/^	RTW_SCTX_DONE_DRV_STOP,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_SUCCESS	include/rtw_xmit.h	/^	RTW_SCTX_DONE_SUCCESS = 0,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_TIMEOUT	include/rtw_xmit.h	/^	RTW_SCTX_DONE_TIMEOUT,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_TX_DENY	include/rtw_xmit.h	/^	RTW_SCTX_DONE_TX_DENY,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_TX_DESC_NA	include/rtw_xmit.h	/^	RTW_SCTX_DONE_TX_DESC_NA,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_UNKNOWN	include/rtw_xmit.h	/^	RTW_SCTX_DONE_UNKNOWN,$/;"	e	enum:__anon6
-RTW_SCTX_DONE_WRITE_PORT_ERR	include/rtw_xmit.h	/^	RTW_SCTX_DONE_WRITE_PORT_ERR,$/;"	e	enum:__anon6
-RTW_SCTX_SUBMITTED	include/rtw_xmit.h	/^	RTW_SCTX_SUBMITTED = -1,$/;"	e	enum:__anon6
-RTW_SDIO	include/hal_intf.h	/^	RTW_SDIO	= BIT2,$/;"	e	enum:RTL871X_HCI_TYPE
-RTW_SDIO_ADDR_CMD52_BIT	include/drv_types_sdio.h	79;"	d
-RTW_SDIO_ADDR_CMD52_CHK	include/drv_types_sdio.h	82;"	d
-RTW_SDIO_ADDR_CMD52_CLR	include/drv_types_sdio.h	81;"	d
-RTW_SDIO_ADDR_CMD52_GEN	include/drv_types_sdio.h	80;"	d
-RTW_SDIO_ADDR_F0_BIT	include/drv_types_sdio.h	84;"	d
-RTW_SDIO_ADDR_F0_CHK	include/drv_types_sdio.h	87;"	d
-RTW_SDIO_ADDR_F0_CLR	include/drv_types_sdio.h	86;"	d
-RTW_SDIO_ADDR_F0_GEN	include/drv_types_sdio.h	85;"	d
-RTW_SDIO_ADDR_RX_RX0FF_GEN	hal/hal_halmac.c	2314;"	d	file:
-RTW_SDIO_ADDR_RX_RX0FF_PRFIX	hal/hal_halmac.c	2313;"	d	file:
-RTW_SDIO_CLK_40M	include/drv_types_sdio.h	89;"	d
-RTW_SEQ_FILE_TEST	os_dep/linux/rtw_proc.c	293;"	d	file:
-RTW_SEQ_FILE_TEST_SHOW_LIMIT	os_dep/linux/rtw_proc.c	297;"	d	file:
-RTW_SET_SCAN_BAND_SKIP	core/rtw_mlme_ext.c	/^inline void RTW_SET_SCAN_BAND_SKIP(_adapter *padapter, int skip_band)$/;"	f
-RTW_SIGNAL_STATE_CALC_PROFILE	core/rtw_recv.c	47;"	d	file:
-RTW_SINGLE_WIPHY	os_dep/linux/ioctl_cfg80211.h	44;"	d
-RTW_SSID_SCAN_AMOUNT	include/rtw_cmd.h	365;"	d
-RTW_STATUS_CODE	os_dep/osdep_service.c	/^inline int RTW_STATUS_CODE(int error_code)$/;"	f
-RTW_SUSPEND_EXT_LOCK_NAME	os_dep/osdep_service.c	1657;"	d	file:
-RTW_SUSPEND_LOCK_NAME	os_dep/osdep_service.c	1656;"	d	file:
-RTW_SUSPEND_RESUME_LOCK_NAME	os_dep/osdep_service.c	1660;"	d	file:
-RTW_SUSPEND_RX_LOCK_NAME	os_dep/osdep_service.c	1658;"	d	file:
-RTW_SUSPEND_TRAFFIC_LOCK_NAME	os_dep/osdep_service.c	1659;"	d	file:
-RTW_TIMER_HDL_ARGS	include/osdep_service_ce.h	125;"	d
-RTW_TIMER_HDL_ARGS	include/osdep_service_linux.h	282;"	d
-RTW_TIMER_HDL_ARGS	include/osdep_service_xp.h	134;"	d
-RTW_TIMER_HDL_NAME	include/osdep_service.h	52;"	d
-RTW_TKIP_MIC_LEN	include/rtw_security.h	53;"	d
-RTW_USB	include/hal_intf.h	/^	RTW_USB	= BIT1,$/;"	e	enum:RTL871X_HCI_TYPE
-RTW_USB_BULKOUT_TIMEOUT	include/usb_ops_linux.h	41;"	d
-RTW_USB_CONTROL_MSG_TIMEOUT	include/usb_ops_linux.h	27;"	d
-RTW_USB_CONTROL_MSG_TIMEOUT_TEST	include/usb_ops_linux.h	26;"	d
-RTW_USB_SPEED	include/usb_ops.h	/^enum RTW_USB_SPEED {$/;"	g
-RTW_USB_SPEED_1_1	include/usb_ops.h	/^	RTW_USB_SPEED_1_1	= 1,$/;"	e	enum:RTW_USB_SPEED
-RTW_USB_SPEED_2	include/usb_ops.h	/^	RTW_USB_SPEED_2		= 2,$/;"	e	enum:RTW_USB_SPEED
-RTW_USB_SPEED_3	include/usb_ops.h	/^	RTW_USB_SPEED_3		= 3,$/;"	e	enum:RTW_USB_SPEED
-RTW_USB_SPEED_UNKNOWN	include/usb_ops.h	/^	RTW_USB_SPEED_UNKNOWN	= 0,$/;"	e	enum:RTW_USB_SPEED
-RTW_WARN	include/rtw_debug.h	125;"	d
-RTW_WARN	include/rtw_debug.h	126;"	d
-RTW_WARN	include/rtw_debug.h	43;"	d
-RTW_WARN	include/rtw_debug.h	56;"	d
-RTW_WIFI_FT_CAPABILITY	include/rtw_mlme.h	/^} RTW_WIFI_FT_CAPABILITY;$/;"	t	typeref:enum:_RTW_WIFI_FT_CAPABILITY
-RTW_WIFI_FT_STA_STATUS	include/rtw_mlme.h	/^} RTW_WIFI_FT_STA_STATUS;$/;"	t	typeref:enum:_RTW_WIFI_FT_STA_STATUS
-RTW_WLAN_20_40_BSS_COEX_20MHZ_WIDTH_REQ	include/ieee80211.h	1635;"	d
-RTW_WLAN_20_40_BSS_COEX_40MHZ_INTOL	include/ieee80211.h	1634;"	d
-RTW_WLAN_20_40_BSS_COEX_INFO_REQ	include/ieee80211.h	1633;"	d
-RTW_WLAN_20_40_BSS_COEX_OBSS_EXEMPT_GRNT	include/ieee80211.h	1637;"	d
-RTW_WLAN_20_40_BSS_COEX_OBSS_EXEMPT_REQ	include/ieee80211.h	1636;"	d
-RTW_WLAN_ACTION_ADDBA_REQ	include/ieee80211.h	/^	RTW_WLAN_ACTION_ADDBA_REQ = 0,$/;"	e	enum:rtw_ieee80211_back_actioncode
-RTW_WLAN_ACTION_ADDBA_RESP	include/ieee80211.h	/^	RTW_WLAN_ACTION_ADDBA_RESP = 1,$/;"	e	enum:rtw_ieee80211_back_actioncode
-RTW_WLAN_ACTION_DELBA	include/ieee80211.h	/^	RTW_WLAN_ACTION_DELBA = 2,$/;"	e	enum:rtw_ieee80211_back_actioncode
-RTW_WLAN_ACTION_FT_ACK	include/ieee80211.h	/^	RTW_WLAN_ACTION_FT_ACK,$/;"	e	enum:rtw_ieee80211_ft_actioncode
-RTW_WLAN_ACTION_FT_CONFIRM	include/ieee80211.h	/^	RTW_WLAN_ACTION_FT_CONFIRM,$/;"	e	enum:rtw_ieee80211_ft_actioncode
-RTW_WLAN_ACTION_FT_MAX	include/ieee80211.h	/^	RTW_WLAN_ACTION_FT_MAX,$/;"	e	enum:rtw_ieee80211_ft_actioncode
-RTW_WLAN_ACTION_FT_REQUEST	include/ieee80211.h	/^	RTW_WLAN_ACTION_FT_REQUEST,$/;"	e	enum:rtw_ieee80211_ft_actioncode
-RTW_WLAN_ACTION_FT_RESPONSE	include/ieee80211.h	/^	RTW_WLAN_ACTION_FT_RESPONSE,$/;"	e	enum:rtw_ieee80211_ft_actioncode
-RTW_WLAN_ACTION_FT_RESV	include/ieee80211.h	/^	RTW_WLAN_ACTION_FT_RESV,$/;"	e	enum:rtw_ieee80211_ft_actioncode
-RTW_WLAN_ACTION_HT_ASEL_FEEDBACK	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_ASEL_FEEDBACK = 7,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING = 6,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_HT_CSI	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_CSI = 4,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_HT_NON_COMPRESS_BEAMFORMING	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_NON_COMPRESS_BEAMFORMING = 5,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_HT_NOTI_CHNL_WIDTH	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_NOTI_CHNL_WIDTH = 0,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_HT_PSMP	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_PSMP = 2,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_HT_SET_PCO_PHASE	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_SET_PCO_PHASE = 3,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_HT_SM_PS	include/ieee80211.h	/^	RTW_WLAN_ACTION_HT_SM_PS = 1,$/;"	e	enum:rtw_ieee80211_ht_actioncode
-RTW_WLAN_ACTION_SPCT_CHL_SWITCH	include/ieee80211.h	/^	RTW_WLAN_ACTION_SPCT_CHL_SWITCH = 4,$/;"	e	enum:rtw_ieee80211_spectrum_mgmt_actioncode
-RTW_WLAN_ACTION_SPCT_EXT_CHL_SWITCH	include/ieee80211.h	/^	RTW_WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,$/;"	e	enum:rtw_ieee80211_spectrum_mgmt_actioncode
-RTW_WLAN_ACTION_SPCT_MSR_REQ	include/ieee80211.h	/^	RTW_WLAN_ACTION_SPCT_MSR_REQ = 0,$/;"	e	enum:rtw_ieee80211_spectrum_mgmt_actioncode
-RTW_WLAN_ACTION_SPCT_MSR_RPRT	include/ieee80211.h	/^	RTW_WLAN_ACTION_SPCT_MSR_RPRT = 1,$/;"	e	enum:rtw_ieee80211_spectrum_mgmt_actioncode
-RTW_WLAN_ACTION_SPCT_TPC_REQ	include/ieee80211.h	/^	RTW_WLAN_ACTION_SPCT_TPC_REQ = 2,$/;"	e	enum:rtw_ieee80211_spectrum_mgmt_actioncode
-RTW_WLAN_ACTION_SPCT_TPC_RPRT	include/ieee80211.h	/^	RTW_WLAN_ACTION_SPCT_TPC_RPRT = 3,$/;"	e	enum:rtw_ieee80211_spectrum_mgmt_actioncode
-RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING	include/ieee80211.h	/^	RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING = 0,$/;"	e	enum:rtw_ieee80211_vht_actioncode
-RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT	include/ieee80211.h	/^	RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT = 1,$/;"	e	enum:rtw_ieee80211_vht_actioncode
-RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION	include/ieee80211.h	/^	RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION = 2,$/;"	e	enum:rtw_ieee80211_vht_actioncode
-RTW_WLAN_BACK_INITIATOR	include/ieee80211.h	/^	RTW_WLAN_BACK_INITIATOR = 1,$/;"	e	enum:rtw_ieee80211_back_parties
-RTW_WLAN_BACK_RECIPIENT	include/ieee80211.h	/^	RTW_WLAN_BACK_RECIPIENT = 0,$/;"	e	enum:rtw_ieee80211_back_parties
-RTW_WLAN_BACK_TIMER	include/ieee80211.h	/^	RTW_WLAN_BACK_TIMER = 2,$/;"	e	enum:rtw_ieee80211_back_parties
-RTW_WLAN_CATEGORY_BACK	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_BACK = 3,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_DLS	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_DLS = 2,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_FT	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_FT = 6,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_HT	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_HT = 7,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_P2P	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_P2P = 0x7f,\/* P2P action frames *\/$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_PUBLIC	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_PUBLIC = 4, \/* IEEE 802.11 public action frames *\/$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_QOS	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_QOS = 1,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_RADIO_MEASUREMENT	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_RADIO_MEASUREMENT  = 5,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_SA_QUERY	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_SA_QUERY = 8,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_SELF_PROTECTED	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_SELF_PROTECTED = 15, \/* add for CONFIG_IEEE80211W, none 11w also can use *\/$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_SPECTRUM_MGMT	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_SPECTRUM_MGMT = 0,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_TDLS	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_TDLS = 12,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_UNPROTECTED_WNM	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_UNPROTECTED_WNM = 11, \/* add for CONFIG_IEEE80211W, none 11w also can use *\/$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_VHT	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_VHT = 21,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_WMM	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_WMM = 17,$/;"	e	enum:rtw_ieee80211_category
-RTW_WLAN_CATEGORY_WNM	include/ieee80211.h	/^	RTW_WLAN_CATEGORY_WNM = 10,$/;"	e	enum:rtw_ieee80211_category
-RTW_WPA_OUI	core/rtw_mlme_ext.c	/^unsigned char	RTW_WPA_OUI[] = {0x00, 0x50, 0xf2, 0x01};$/;"	v
-RTW_WPA_OUI_TYPE	core/rtw_ieee80211.c	/^u8 RTW_WPA_OUI_TYPE[] = { 0x00, 0x50, 0xf2, 1 };$/;"	v
-RTW_WPA_VERSION	core/rtw_ieee80211.c	/^u16 RTW_WPA_VERSION = 1;$/;"	v
-RTX_SCTX_CSTR_WAIT_RPT2	include/rtw_xmit.h	/^	RTX_SCTX_CSTR_WAIT_RPT2,$/;"	e	enum:__anon6
-RTY	hal/phydm/phydm_rainfo.h	/^	u2Byte RTY[5];$/;"	m	struct:_ODM_RA_Info_
-RTY_LMT_EN	include/rtl8188e_xmit.h	86;"	d
-RTY_LMT_EN	include/rtl8192e_xmit.h	191;"	d
-RTY_LMT_EN	include/rtl8812a_xmit.h	84;"	d
-RTY_P	hal/phydm/phydm_rainfo.h	/^	u1Byte	RTY_P[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RTY_P_default	hal/phydm/phydm_rainfo.h	/^	u1Byte	RTY_P_default[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RTY_P_modify_note	hal/phydm/phydm_rainfo.h	/^	BOOLEAN	RTY_P_modify_note[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-RT_2G_ETSI1	hal/phydm/rtchnlplan.h	/^	RT_2G_ETSI1,$/;"	e	enum:_RT_REGULATION_DOMAIN_2G
-RT_2G_ETSI2	hal/phydm/rtchnlplan.h	/^	RT_2G_ETSI2	$/;"	e	enum:_RT_REGULATION_DOMAIN_2G
-RT_2G_FCC1	hal/phydm/rtchnlplan.h	/^	RT_2G_FCC1,$/;"	e	enum:_RT_REGULATION_DOMAIN_2G
-RT_2G_MKK1	hal/phydm/rtchnlplan.h	/^	RT_2G_MKK1,$/;"	e	enum:_RT_REGULATION_DOMAIN_2G
-RT_2G_NULL	hal/phydm/rtchnlplan.h	/^	RT_2G_NULL,   $/;"	e	enum:_RT_REGULATION_DOMAIN_2G
-RT_2G_WORLD	hal/phydm/rtchnlplan.h	/^	RT_2G_WORLD,$/;"	e	enum:_RT_REGULATION_DOMAIN_2G
-RT_5G_ETSI1	hal/phydm/rtchnlplan.h	/^	RT_5G_ETSI1,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_ETSI2	hal/phydm/rtchnlplan.h	/^	RT_5G_ETSI2,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_ETSI3	hal/phydm/rtchnlplan.h	/^	RT_5G_ETSI3,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_FCC1	hal/phydm/rtchnlplan.h	/^	RT_5G_FCC1,	$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_FCC2	hal/phydm/rtchnlplan.h	/^	RT_5G_FCC2,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_FCC3	hal/phydm/rtchnlplan.h	/^	RT_5G_FCC3,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_FCC4	hal/phydm/rtchnlplan.h	/^	RT_5G_FCC4,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_FCC5	hal/phydm/rtchnlplan.h	/^	RT_5G_FCC5,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_FCC6	hal/phydm/rtchnlplan.h	/^	RT_5G_FCC6,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_FCC7	hal/phydm/rtchnlplan.h	/^	RT_5G_FCC7,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_IC1	hal/phydm/rtchnlplan.h	/^	RT_5G_IC1,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_KCC1	hal/phydm/rtchnlplan.h	/^	RT_5G_KCC1,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_MKK1	hal/phydm/rtchnlplan.h	/^	RT_5G_MKK1,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_MKK2	hal/phydm/rtchnlplan.h	/^	RT_5G_MKK2,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_MKK3	hal/phydm/rtchnlplan.h	/^	RT_5G_MKK3,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_NCC1	hal/phydm/rtchnlplan.h	/^	RT_5G_NCC1,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_NULL	hal/phydm/rtchnlplan.h	/^	RT_5G_NULL,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_5G_WORLD	hal/phydm/rtchnlplan.h	/^	RT_5G_WORLD,$/;"	e	enum:_RT_REGULATION_DOMAIN_5G
-RT_8188E_FIRMWARE_HDR	include/rtl8188e_hal.h	/^} RT_8188E_FIRMWARE_HDR, *PRT_8188E_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8188E_FIRMWARE_HDR
-RT_8188F_FIRMWARE_HDR	include/rtl8188f_hal.h	/^} RT_8188F_FIRMWARE_HDR, *PRT_8188F_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8188F_FIRMWARE_HDR
-RT_8703B_FIRMWARE_HDR	include/rtl8703b_hal.h	/^} RT_8703B_FIRMWARE_HDR, *PRT_8703B_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8703B_FIRMWARE_HDR
-RT_8723B_FIRMWARE_HDR	include/rtl8723b_hal.h	/^} RT_8723B_FIRMWARE_HDR, *PRT_8723B_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8723B_FIRMWARE_HDR
-RT_8723D_FIRMWARE_HDR	include/rtl8723d_hal.h	/^} RT_8723D_FIRMWARE_HDR, *PRT_8723D_FIRMWARE_HDR;$/;"	t	typeref:struct:_RT_8723D_FIRMWARE_HDR
-RT_AC_INT_MASKS	include/rtl8188e_spec.h	142;"	d
-RT_AC_INT_MASKS	include/rtl8188f_spec.h	288;"	d
-RT_AC_INT_MASKS	include/rtl8703b_spec.h	465;"	d
-RT_AC_INT_MASKS	include/rtl8723b_spec.h	281;"	d
-RT_AC_INT_MASKS	include/rtl8723d_spec.h	442;"	d
-RT_AC_INT_MASKS	include/rtl8812a_spec.h	243;"	d
-RT_AC_INT_MASKS	include/rtl8814a_spec.h	618;"	d
-RT_ADCSMP	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP, *PRT_ADCSMP;$/;"	t	typeref:struct:_RT_ADCSMP
-RT_ADCSMP_STATE	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_STATE, *PRT_ADCSMP_STATE;$/;"	t	typeref:enum:_RT_ADCSMP_STATE
-RT_ADCSMP_STRING	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_STRING, *PRT_ADCSMP_STRING;$/;"	t	typeref:struct:_RT_ADCSMP_STRING
-RT_ADCSMP_TRIG_SEL	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_TRIG_SEL, *PRT_ADCSMP_TRIG_SEL;$/;"	t	typeref:enum:_RT_ADCSMP_TRIG_SEL
-RT_ADCSMP_TRIG_SIG_SEL	hal/phydm/phydm_adc_sampling.h	/^} RT_ADCSMP_TRIG_SIG_SEL, *PRT_ADCSMP_TRIG_SIG_SEL;$/;"	t	typeref:enum:_RT_ADCSMP_TRIG_SIG_SEL
-RT_AMPDU_BRUST	include/hal_data.h	/^} RT_AMPDU_BRUST, *PRT_AMPDU_BRUST_MODE;$/;"	t	typeref:enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_8723B	include/hal_data.h	/^	RT_AMPDU_BRUST_8723B		= 7,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_8812_12	include/hal_data.h	/^	RT_AMPDU_BRUST_8812_12	= 5,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_8812_15	include/hal_data.h	/^	RT_AMPDU_BRUST_8812_15	= 6,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_8812_4	include/hal_data.h	/^	RT_AMPDU_BRUST_8812_4	= 3,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_8812_8	include/hal_data.h	/^	RT_AMPDU_BRUST_8812_8	= 4,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_88E	include/hal_data.h	/^	RT_AMPDU_BRUST_88E		= 2,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_92D	include/hal_data.h	/^	RT_AMPDU_BRUST_92D		= 1,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_AMPDU_BRUST_NONE	include/hal_data.h	/^	RT_AMPDU_BRUST_NONE		= 0,$/;"	e	enum:_RT_AMPDU_BRUST_MODE
-RT_ASSERT_RET	core/efuse/rtw_efuse.c	1665;"	d	file:
-RT_ASSERT_RET	core/efuse/rtw_efuse.c	1832;"	d	file:
-RT_ASSERT_RET	core/efuse/rtw_efuse.c	633;"	d	file:
-RT_ASSERT_RET	include/rtw_wapi.h	39;"	d
-RT_ASSERT_RET	include/rtw_wapi.h	55;"	d
-RT_ASSERT_RET_VALUE	include/rtw_wapi.h	46;"	d
-RT_ASSERT_RET_VALUE	include/rtw_wapi.h	56;"	d
-RT_AWB_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_AWB_SPINLOCK = 32,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_BCN_INT_MASKS	include/rtl8188e_spec.h	137;"	d
-RT_BCN_INT_MASKS	include/rtl8188e_spec.h	139;"	d
-RT_BCN_INT_MASKS	include/rtl8188f_spec.h	286;"	d
-RT_BCN_INT_MASKS	include/rtl8703b_spec.h	463;"	d
-RT_BCN_INT_MASKS	include/rtl8723b_spec.h	279;"	d
-RT_BCN_INT_MASKS	include/rtl8723d_spec.h	440;"	d
-RT_BCN_INT_MASKS	include/rtl8812a_spec.h	241;"	d
-RT_BCN_INT_MASKS	include/rtl8814a_spec.h	616;"	d
-RT_BCN_INT_MASKS	include/rtl8822be_hal.h	25;"	d
-RT_BEAMFORMEE_ENTRY	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMEE_ENTRY, *PRT_BEAMFORMEE_ENTRY;$/;"	t	typeref:struct:_RT_BEAMFORMEE_ENTRY
-RT_BEAMFORMER_ENTRY	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMER_ENTRY, *PRT_BEAMFORMER_ENTRY;$/;"	t	typeref:struct:_RT_BEAMFORMER_ENTRY
-RT_BEAMFORMING_INFO	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMING_INFO, *PRT_BEAMFORMING_INFO;$/;"	t	typeref:struct:_RT_BEAMFORMING_INFO
-RT_BEAMFORMING_OID_INFO	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORMING_OID_INFO, *PRT_BEAMFORMING_OID_INFO;$/;"	t	typeref:struct:_RT_BEAMFORMING_OID_INFO
-RT_BEAMFORM_STAINFO	hal/phydm/phydm_beamforming.h	/^} RT_BEAMFORM_STAINFO, *PRT_BEAMFORM_STAINFO;$/;"	t	typeref:struct:_RT_BEAMFORM_STAINFO
-RT_BTData_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_BTData_SPINLOCK=25,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_BUFFER_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_BUFFER_SPINLOCK = 29,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_BW_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_BW_SPINLOCK = 8,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_CAM_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_CAM_SPINLOCK = 4,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_CCK_PAGEA_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_CCK_PAGEA_SPINLOCK = 28,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_CE	hal/phydm/rtchnlplan.h	/^	RT_CE,$/;"	e	enum:_RT_REGULATION_COMMON
-RT_CHANNEL_AND_BANDWIDTH_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_CHANNEL_AND_BANDWIDTH_SPINLOCK = 30,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_CHANNEL_DOMAIN	include/rtw_mlme_ext.h	/^} RT_CHANNEL_DOMAIN, *PRT_CHANNEL_DOMAIN;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN
-RT_CHANNEL_DOMAIN_2G	include/rtw_mlme_ext.h	/^} RT_CHANNEL_DOMAIN_2G, *PRT_CHANNEL_DOMAIN_2G;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN_2G
-RT_CHANNEL_DOMAIN_2G_ETSI1_5G_NULL	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_2G_ETSI1_5G_NULL				= 0x21,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_2G_ETSI2_5G_NULL	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_2G_ETSI2_5G_NULL				= 0x24,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_2G_FCC1_5G_FCC1	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_2G_FCC1_5G_FCC1				= 0x25,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_2G_FCC1_5G_NULL	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_2G_FCC1_5G_NULL				= 0x22,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_2G_MKK1_5G_NULL	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_2G_MKK1_5G_NULL				= 0x23,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_2G_WORLD_5G_ETSI1	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_2G_WORLD_5G_ETSI1				= 0x26,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_2G_WORLD_5G_NULL	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_2G_WORLD_5G_NULL				= 0x20,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_5G	include/rtw_mlme_ext.h	/^} RT_CHANNEL_DOMAIN_5G, *PRT_CHANNEL_DOMAIN_5G;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN_5G
-RT_CHANNEL_DOMAIN_MAX_NEW	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN_MAX_NEW,$/;"	e	enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_DOMAIN_NEW	hal/phydm/rtchnlplan.h	/^}RT_CHANNEL_DOMAIN_NEW, *PRT_CHANNEL_DOMAIN_NEW;$/;"	t	typeref:enum:_RT_CHANNEL_DOMAIN_NEW
-RT_CHANNEL_INFO	include/rtw_mlme_ext.h	/^} RT_CHANNEL_INFO, *PRT_CHANNEL_INFO;$/;"	t	typeref:struct:_RT_CHANNEL_INFO
-RT_CHANNEL_PLAN	include/rtw_mlme_ext.h	/^} RT_CHANNEL_PLAN, *PRT_CHANNEL_PLAN;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN
-RT_CHANNEL_PLAN_MAP	include/rtw_mlme_ext.h	/^} RT_CHANNEL_PLAN_MAP, *PRT_CHANNEL_PLAN_MAP;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_MAP
-RT_CHANNEL_PLAN_MAXPWR	hal/phydm/rtchnlplan.h	/^}RT_CHANNEL_PLAN_MAXPWR, *PRT_CHANNEL_PLAN_MAXPWR;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_MAXPWR
-RT_CHANNEL_PLAN_NEW	hal/phydm/rtchnlplan.h	/^}RT_CHANNEL_PLAN_NEW, *PRT_CHANNEL_PLAN_NEW;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_NEW
-RT_CHNLLIST_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_CHNLLIST_SPINLOCK = 40,	$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_CHNLOP_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_CHNLOP_SPINLOCK = 9,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_CHNLPLAN_SREQ	hal/phydm/rtchnlplan.h	/^}RT_CHNLPLAN_SREQ, *PRT_CHNLPLAN_SREQ;$/;"	t	typeref:enum:_RT_CHNLPLAN_SREQ
-RT_CHNL_CTRY_TBL	hal/phydm/rtchnlplan.h	/^}RT_CHNL_CTRY_TBL, *PRT_CHNL_CTRY_TBL;$/;"	t	typeref:struct:_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-RT_CHNL_PLAN_LIMIT	hal/phydm/rtchnlplan.h	/^}RT_CHNL_PLAN_LIMIT, *PRT_CHNL_PLAN_LIMIT;$/;"	t	typeref:struct:_RT_CHNL_PLAN_LIMIT
-RT_CHNL_PWR_LIMIT	hal/phydm/rtchnlplan.h	/^}RT_CHNL_PWR_LIMIT, *PRT_CHNL_PWR_LIMIT;$/;"	t	typeref:struct:_RT_CHNL_PLAN_PWR_LIMIT
-RT_CID_8187_ALPHA0	include/rtw_eeprom.h	/^	RT_CID_8187_ALPHA0 = 1,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_8187_HW_LED	include/rtw_eeprom.h	/^	RT_CID_8187_HW_LED = 3,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_8187_NETGEAR	include/rtw_eeprom.h	/^	RT_CID_8187_NETGEAR = 4,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_8187_SERCOMM_PS	include/rtw_eeprom.h	/^	RT_CID_8187_SERCOMM_PS = 2,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_ALPHA	include/rtw_eeprom.h	/^	RT_CID_819x_ALPHA = 16,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_ALPHA_Dlink	include/rtw_eeprom.h	/^	RT_CID_819x_ALPHA_Dlink = 44,\/* add by ylb 20121012 for customer led for alpha *\/$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Acer	include/rtw_eeprom.h	/^	RT_CID_819x_Acer = 25,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Arcadyan_Belkin	include/rtw_eeprom.h	/^	RT_CID_819x_Arcadyan_Belkin = 30,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_AzWave	include/rtw_eeprom.h	/^	RT_CID_819x_AzWave = 27, \/* For AzWave in PCIe, The ID is AzWave use and not only Asus *\/$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_AzWave_ASUS	include/rtw_eeprom.h	/^	RT_CID_819x_AzWave_ASUS = 26,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_CAMEO	include/rtw_eeprom.h	/^	RT_CID_819x_CAMEO  = 6,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_CAMEO1	include/rtw_eeprom.h	/^	RT_CID_819x_CAMEO1 = 23,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_CLEVO	include/rtw_eeprom.h	/^	RT_CID_819x_CLEVO = 32,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_DELL	include/rtw_eeprom.h	/^	RT_CID_819x_DELL = 33,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Edimax_ASUS	include/rtw_eeprom.h	/^	RT_CID_819x_Edimax_ASUS = 35,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Edimax_Belkin	include/rtw_eeprom.h	/^	RT_CID_819x_Edimax_Belkin = 21,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_HP	include/rtw_eeprom.h	/^	RT_CID_819x_HP = 28,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Lenovo	include/rtw_eeprom.h	/^	RT_CID_819x_Lenovo = 19,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_MSI	include/rtw_eeprom.h	/^	RT_CID_819x_MSI = 24,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Netcore	include/rtw_eeprom.h	/^	RT_CID_819x_Netcore = 10,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_PRONETS	include/rtw_eeprom.h	/^	RT_CID_819x_PRONETS = 34,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_QMI	include/rtw_eeprom.h	/^	RT_CID_819x_QMI = 20,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_RUNTOP	include/rtw_eeprom.h	/^	RT_CID_819x_RUNTOP = 7,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_SAMSUNG	include/rtw_eeprom.h	/^	RT_CID_819x_SAMSUNG = 31,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Senao	include/rtw_eeprom.h	/^	RT_CID_819x_Senao = 8,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Sercomm_Belkin	include/rtw_eeprom.h	/^	RT_CID_819x_Sercomm_Belkin = 22,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Sercomm_Netgear	include/rtw_eeprom.h	/^	RT_CID_819x_Sercomm_Netgear = 43,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Sitecom	include/rtw_eeprom.h	/^	RT_CID_819x_Sitecom = 17,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_WNC_COREGA	include/rtw_eeprom.h	/^	RT_CID_819x_WNC_COREGA = 29,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_819x_Xavi	include/rtw_eeprom.h	/^	RT_CID_819x_Xavi = 39,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_CCX	include/rtw_eeprom.h	/^	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. *\/$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_CC_C	include/rtw_eeprom.h	/^	RT_CID_CC_C = 38,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_CHINA_MOBILE	include/rtw_eeprom.h	/^	RT_CID_CHINA_MOBILE = 15,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_COREGA	include/rtw_eeprom.h	/^	RT_CID_COREGA = 14,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_DEFAULT	include/rtw_eeprom.h	/^	RT_CID_DEFAULT = 0,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_DLINK	include/rtw_eeprom.h	/^	RT_CID_DLINK = 12,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_DNI_BUFFALO	include/rtw_eeprom.h	/^	RT_CID_DNI_BUFFALO = 46,\/* add by page for NEC *\/$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_INTEL_CHINA	include/rtw_eeprom.h	/^	RT_CID_INTEL_CHINA = 41,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_LENOVO_CHINA	include/rtw_eeprom.h	/^	RT_CID_LENOVO_CHINA = 40,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_NETGEAR	include/rtw_eeprom.h	/^	RT_CID_NETGEAR = 36,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_Nettronix	include/rtw_eeprom.h	/^	RT_CID_Nettronix = 11,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_PLANEX	include/rtw_eeprom.h	/^	RT_CID_PLANEX = 37,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_PRONET	include/rtw_eeprom.h	/^	RT_CID_PRONET = 13,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_TOSHIBA	include/rtw_eeprom.h	/^	RT_CID_TOSHIBA = 9,	\/* Merge by Jacken, 2008\/01\/31. *\/$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_TPLINK_HPWR	include/rtw_eeprom.h	/^	RT_CID_TPLINK_HPWR = 42,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_WHQL	include/rtw_eeprom.h	/^	RT_CID_WHQL = 5,$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CID_WNC_NEC	include/rtw_eeprom.h	/^	RT_CID_WNC_NEC = 45,\/* add by page for NEC *\/$/;"	e	enum:_RT_CUSTOMER_ID
-RT_CLEAR_PS_LEVEL	include/rtw_pwrctrl.h	211;"	d
-RT_COUNTRY_NAME	hal/phydm/rtchnlplan.h	/^}RT_COUNTRY_NAME, *PRT_COUNTRY_NAME;$/;"	t	typeref:enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AG	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AG,             \/\/  "Antigua & Barbuda安提瓜島&巴布達"	$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AL	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AL,				\/\/	"Albania阿爾巴尼亞"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AM	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AM,             \/\/  "Armenia亞美尼亞"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AR	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AR,             \/\/  "Argentina阿根廷"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AT	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AT,             \/\/  "Austria奧地利"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AU	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AU,             \/\/  "Australia澳洲"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AW	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AW,             \/\/  "Aruba阿魯巴島"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_AZ	hal/phydm/rtchnlplan.h	/^	RT_CTRY_AZ,             \/\/  "Azerbaijan阿塞拜彊"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_BB	hal/phydm/rtchnlplan.h	/^	RT_CTRY_BB,             \/\/  "Barbados巴巴多斯"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_BE	hal/phydm/rtchnlplan.h	/^	RT_CTRY_BE,             \/\/  "Belgium比利時"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_BG	hal/phydm/rtchnlplan.h	/^	RT_CTRY_BG,             \/\/  "Bulgaria保加利亞"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_BM	hal/phydm/rtchnlplan.h	/^	RT_CTRY_BM,             \/\/  "Bermuda百慕達"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_BR	hal/phydm/rtchnlplan.h	/^	RT_CTRY_BR,             \/\/  "Brazil巴西"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_BS	hal/phydm/rtchnlplan.h	/^	RT_CTRY_BS,             \/\/  "Bahamas巴哈馬"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CA	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CA,             \/\/  "Canada加拿大"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CE	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CE,             \/\/  "Egypt埃及"	EG	2G_WORLD			$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CH	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CH,             \/\/  "Switzerland瑞士"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CL	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CL,             \/\/  "Chile智利"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CN	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CN,             \/\/  "China中國"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CO	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CO,             \/\/  "Columbia哥倫比亞"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CR	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CR,             \/\/  "Costa Rica哥斯達黎加"			$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CY	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CY,             \/\/  "Cyprus塞浦路斯"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_CZ	hal/phydm/rtchnlplan.h	/^	RT_CTRY_CZ,             \/\/  "Czech 捷克"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_DE	hal/phydm/rtchnlplan.h	/^	RT_CTRY_DE,             \/\/  "Germany德國"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_DK	hal/phydm/rtchnlplan.h	/^	RT_CTRY_DK,             \/\/  "Denmark丹麥"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_DO	hal/phydm/rtchnlplan.h	/^	RT_CTRY_DO,             \/\/  "Dominican Republic多明尼加共和國"	$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_DZ	hal/phydm/rtchnlplan.h	/^	RT_CTRY_DZ,             \/\/  "Algeria阿爾及利亞"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_EE	hal/phydm/rtchnlplan.h	/^	RT_CTRY_EE,             \/\/  "Estonia愛沙尼亞"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_ES	hal/phydm/rtchnlplan.h	/^	RT_CTRY_ES,             \/\/  "Spain西班牙"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_FI	hal/phydm/rtchnlplan.h	/^	RT_CTRY_FI,             \/\/  "Finland芬蘭"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_FR	hal/phydm/rtchnlplan.h	/^	RT_CTRY_FR,             \/\/  "France法國"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_GB	hal/phydm/rtchnlplan.h	/^	RT_CTRY_GB,             \/\/  "United Kingdom英國"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_GR	hal/phydm/rtchnlplan.h	/^	RT_CTRY_GR,             \/\/  "Greece 希臘"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_GT	hal/phydm/rtchnlplan.h	/^	RT_CTRY_GT,             \/\/  "Guatemala瓜地馬拉"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_GU	hal/phydm/rtchnlplan.h	/^	RT_CTRY_GU,             \/\/  "Guam關島"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_HN	hal/phydm/rtchnlplan.h	/^	RT_CTRY_HN,             \/\/  "Honduras宏都拉斯"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_HT	hal/phydm/rtchnlplan.h	/^	RT_CTRY_HT,             \/\/  "Haiti海地"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_HU	hal/phydm/rtchnlplan.h	/^	RT_CTRY_HU,             \/\/  "Hungary匈牙利"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_IE	hal/phydm/rtchnlplan.h	/^	RT_CTRY_IE,             \/\/  "Ireland愛爾蘭"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_IL	hal/phydm/rtchnlplan.h	/^	RT_CTRY_IL,             \/\/  "Israel以色列"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_IN	hal/phydm/rtchnlplan.h	/^	RT_CTRY_IN,             \/\/  "India印度"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_IS	hal/phydm/rtchnlplan.h	/^	RT_CTRY_IS,             \/\/  "Iceland冰島"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_IT	hal/phydm/rtchnlplan.h	/^	RT_CTRY_IT,             \/\/  "Italy義大利"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_JP	hal/phydm/rtchnlplan.h	/^	RT_CTRY_JP,             \/\/  "Japan日本"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_KR	hal/phydm/rtchnlplan.h	/^	RT_CTRY_KR,             \/\/  "Korea韓國"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_KY	hal/phydm/rtchnlplan.h	/^	RT_CTRY_KY,             \/\/  "Cayman Islands開曼群島"			$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_LT	hal/phydm/rtchnlplan.h	/^	RT_CTRY_LT,             \/\/  "Lithuania立陶宛"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_LU	hal/phydm/rtchnlplan.h	/^	RT_CTRY_LU,             \/\/  "Luxembourg盧森堡"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_LV	hal/phydm/rtchnlplan.h	/^	RT_CTRY_LV,             \/\/  "Latvia拉脫維亞"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_MA	hal/phydm/rtchnlplan.h	/^	RT_CTRY_MA,             \/\/  "Morocco摩洛哥"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_MAX	hal/phydm/rtchnlplan.h	/^	RT_CTRY_MAX,            \/\/  $/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_MT	hal/phydm/rtchnlplan.h	/^	RT_CTRY_MT,             \/\/  "Malta馬爾他"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_MX	hal/phydm/rtchnlplan.h	/^	RT_CTRY_MX,             \/\/  "Mexico墨西哥"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_MY	hal/phydm/rtchnlplan.h	/^	RT_CTRY_MY,             \/\/  "Malaysia馬來西亞"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_NL	hal/phydm/rtchnlplan.h	/^	RT_CTRY_NL,             \/\/  "Netherlands荷蘭"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_NO	hal/phydm/rtchnlplan.h	/^	RT_CTRY_NO,             \/\/  "Norway挪威"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_NZ	hal/phydm/rtchnlplan.h	/^	RT_CTRY_NZ,             \/\/  "New Zealand紐西蘭"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_PA	hal/phydm/rtchnlplan.h	/^	RT_CTRY_PA,             \/\/  "Panama巴拿馬 "					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_PH	hal/phydm/rtchnlplan.h	/^	RT_CTRY_PH,             \/\/  "Philippines菲律賓"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_PL	hal/phydm/rtchnlplan.h	/^	RT_CTRY_PL,             \/\/  "Poland波蘭"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_PT	hal/phydm/rtchnlplan.h	/^	RT_CTRY_PT,             \/\/  "Portugal葡萄牙"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_RO	hal/phydm/rtchnlplan.h	/^	RT_CTRY_RO,             \/\/  "Romania羅馬尼亞"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_RU	hal/phydm/rtchnlplan.h	/^	RT_CTRY_RU,             \/\/  "Russia俄羅斯"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_SA	hal/phydm/rtchnlplan.h	/^	RT_CTRY_SA,             \/\/  "Saudi Arabia沙地阿拉伯"			$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_SE	hal/phydm/rtchnlplan.h	/^	RT_CTRY_SE,             \/\/  "Sweden瑞典"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_SG	hal/phydm/rtchnlplan.h	/^	RT_CTRY_SG,             \/\/  "Singapore新加坡"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_SI	hal/phydm/rtchnlplan.h	/^	RT_CTRY_SI,             \/\/  "Slovenia斯洛維尼亞"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_SK	hal/phydm/rtchnlplan.h	/^	RT_CTRY_SK,             \/\/  "Slovakia斯洛伐克"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_SV	hal/phydm/rtchnlplan.h	/^	RT_CTRY_SV,             \/\/  "El Salvador薩爾瓦多"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_TH	hal/phydm/rtchnlplan.h	/^	RT_CTRY_TH,             \/\/  "Thailand泰國"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_TR	hal/phydm/rtchnlplan.h	/^	RT_CTRY_TR,             \/\/  "Turkey土耳其"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_TW	hal/phydm/rtchnlplan.h	/^	RT_CTRY_TW,             \/\/  "Taiwan臺灣"						$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_UA	hal/phydm/rtchnlplan.h	/^	RT_CTRY_UA,             \/\/  "Ukraine烏克蘭"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_US	hal/phydm/rtchnlplan.h	/^	RT_CTRY_US,             \/\/  "United States美國"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_VE	hal/phydm/rtchnlplan.h	/^	RT_CTRY_VE,             \/\/  "Venezuela委內瑞拉"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_VN	hal/phydm/rtchnlplan.h	/^	RT_CTRY_VN,             \/\/  "Vietnam越南"					$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CTRY_ZA	hal/phydm/rtchnlplan.h	/^	RT_CTRY_ZA,             \/\/  "South Africa南非"				$/;"	e	enum:_RT_COUNTRY_DEFINE_NUM
-RT_CUSTOMER_ID	include/rtw_eeprom.h	/^} RT_CUSTOMER_ID, *PRT_CUSTOMER_ID;$/;"	t	typeref:enum:_RT_CUSTOMER_ID
-RT_DBG_SPIN_LOCK	hal/phydm/phydm_types.h	/^	RT_DBG_SPIN_LOCK = 37,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_DISABLE_FUNC	hal/phydm/phydm_beamforming.h	35;"	d
-RT_DISP	hal/phydm/phydm_debug.h	138;"	d
-RT_EEPROM_TYPE	include/hal_intf.h	/^} RT_EEPROM_TYPE, *PRT_EEPROM_TYPE;$/;"	t	typeref:enum:_RT_EEPROM_TYPE
-RT_ENABLE_FUNC	hal/phydm/phydm_beamforming.h	36;"	d
-RT_ETH_IS_BROADCAST	include/ethernet.h	32;"	d
-RT_ETH_IS_MULTICAST	include/ethernet.h	31;"	d
-RT_ETSI	hal/phydm/rtchnlplan.h	/^	RT_ETSI,$/;"	e	enum:_RT_REGULATION_COMMON
-RT_FCC	hal/phydm/rtchnlplan.h	/^	RT_FCC,   $/;"	e	enum:_RT_REGULATION_COMMON
-RT_FIRMWARE_8188E	include/rtl8188e_hal.h	/^} RT_FIRMWARE_8188E, *PRT_FIRMWARE_8188E;$/;"	t	typeref:struct:_RT_FIRMWARE_8188E
-RT_FIRMWARE_8188F	include/rtl8188f_hal.h	/^} RT_FIRMWARE_8188F, *PRT_FIRMWARE_8188F;$/;"	t	typeref:struct:_RT_FIRMWARE
-RT_FIRMWARE_8192E	include/rtl8192e_hal.h	/^} RT_FIRMWARE_8192E, *PRT_FIRMWARE_8192E;$/;"	t	typeref:struct:_RT_FIRMWARE_8192E
-RT_FIRMWARE_8703B	include/rtl8703b_hal.h	/^} RT_FIRMWARE_8703B, *PRT_FIRMWARE_8703B;$/;"	t	typeref:struct:_RT_FIRMWARE
-RT_FIRMWARE_8723B	include/rtl8723b_hal.h	/^} RT_FIRMWARE_8723B, *PRT_FIRMWARE_8723B;$/;"	t	typeref:struct:_RT_FIRMWARE
-RT_FIRMWARE_8723D	include/rtl8723d_hal.h	/^} RT_FIRMWARE_8723D, *PRT_FIRMWARE_8723D;$/;"	t	typeref:struct:_RT_FIRMWARE
-RT_FIRMWARE_8812	include/rtl8812a_hal.h	/^} RT_FIRMWARE_8812, *PRT_FIRMWARE_8812;$/;"	t	typeref:struct:_RT_FIRMWARE_8812
-RT_FIRMWARE_8814	include/rtl8814a_hal.h	/^} RT_FIRMWARE_8814, *PRT_FIRMWARE_8814;$/;"	t	typeref:struct:_RT_FIRMWARE_8814
-RT_FW_PS_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_FW_PS_SPINLOCK = 33,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_GEN_TEMP_BUF_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_GEN_TEMP_BUF_SPINLOCK = 31,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_GetInterfaceSelection	include/hal_data.h	746;"	d
-RT_H2C_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_H2C_SPINLOCK = 20, \/\/ For H2C cmd. Added by tynli. 2009.11.09.$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_HT_CAP_USE_88C_92C	include/rtw_ht.h	/^	RT_HT_CAP_USE_88C_92C = 0x40,$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_CAP_USE_92SE	include/rtw_ht.h	/^	RT_HT_CAP_USE_92SE = 0x20,$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_CAP_USE_AMPDU	include/rtw_ht.h	/^	RT_HT_CAP_USE_AMPDU = 0x04,$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_CAP_USE_AP_CLIENT_MODE	include/rtw_ht.h	/^	RT_HT_CAP_USE_AP_CLIENT_MODE = 0x80,	\/* AP team request to reserve this bit, by Emily *\/$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_CAP_USE_JAGUAR_BCUT	include/rtw_ht.h	/^	RT_HT_CAP_USE_JAGUAR_BCUT = 0x02,$/;"	e	enum:_RT_HT_INF1_CAP
-RT_HT_CAP_USE_JAGUAR_CCUT	include/rtw_ht.h	/^	RT_HT_CAP_USE_JAGUAR_CCUT = 0x04,$/;"	e	enum:_RT_HT_INF1_CAP
-RT_HT_CAP_USE_LONG_PREAMBLE	include/rtw_ht.h	/^	RT_HT_CAP_USE_LONG_PREAMBLE = 0x02,$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_CAP_USE_SOFTAP	include/rtw_ht.h	/^	RT_HT_CAP_USE_SOFTAP = 0x10,$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_CAP_USE_TURBO_AGGR	include/rtw_ht.h	/^	RT_HT_CAP_USE_TURBO_AGGR = 0x01,$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_CAP_USE_VIDEO_CLIENT	include/rtw_ht.h	/^	RT_HT_CAP_USE_VIDEO_CLIENT = 0x01,$/;"	e	enum:_RT_HT_INF1_CAP
-RT_HT_CAP_USE_WOW	include/rtw_ht.h	/^	RT_HT_CAP_USE_WOW = 0x8,$/;"	e	enum:_RT_HT_INF0_CAP
-RT_HT_INF0_CAPBILITY	include/rtw_ht.h	/^} RT_HT_INF0_CAPBILITY, *PRT_HT_INF0_CAPBILITY;$/;"	t	typeref:enum:_RT_HT_INF0_CAP
-RT_HT_INF1_CAPBILITY	include/rtw_ht.h	/^} RT_HT_INF1_CAPBILITY, *PRT_HT_INF1_CAPBILITY;$/;"	t	typeref:enum:_RT_HT_INF1_CAP
-RT_HVL_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_HVL_SPINLOCK=18,	$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_HW_TIMER_SPIN_LOCK	hal/phydm/phydm_types.h	/^	RT_HW_TIMER_SPIN_LOCK = 34,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_IC	hal/phydm/rtchnlplan.h	/^	RT_IC,$/;"	e	enum:_RT_REGULATION_COMMON
-RT_INDIC_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_INDIC_SPINLOCK = 41,	\/\/protect indication	$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_INITIAL_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_INITIAL_SPINLOCK = 11,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_IN_PS_LEVEL	include/rtw_pwrctrl.h	210;"	d
-RT_IQK_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_IQK_SPINLOCK = 38,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_ISR_CONTENT	include/drv_types_pci.h	/^} RT_ISR_CONTENT, *PRT_ISR_CONTENT;$/;"	t	typeref:struct:_RT_ISR_CONTENT
-RT_LAST_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_LAST_SPINLOCK,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_LDO_REGULATOR	include/hal_data.h	/^	RT_LDO_REGULATOR			= 1,$/;"	e	enum:_RT_REGULATOR_MODE
-RT_LINK_DETECT_T	include/rtw_mlme.h	/^} RT_LINK_DETECT_T, *PRT_LINK_DETECT_T;$/;"	t	typeref:struct:_RT_LINK_DETECT_T
-RT_LOG_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_LOG_SPINLOCK = 7, $/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_MAX_BAND_NUM	hal/phydm/rtchnlplan.h	635;"	d
-RT_MAX_CHNL_NUM_2G	hal/phydm/rtchnlplan.h	621;"	d
-RT_MAX_CHNL_NUM_5G	hal/phydm/rtchnlplan.h	622;"	d
-RT_MEDIA_CONNECT	include/hal_com.h	/^	RT_MEDIA_CONNECT       = 1$/;"	e	enum:_RT_MEDIA_STATUS
-RT_MEDIA_DISCONNECT	include/hal_com.h	/^	RT_MEDIA_DISCONNECT = 0,$/;"	e	enum:_RT_MEDIA_STATUS
-RT_MEDIA_STATUS	include/hal_com.h	/^} RT_MEDIA_STATUS;$/;"	t	typeref:enum:_RT_MEDIA_STATUS
-RT_MKK	hal/phydm/rtchnlplan.h	/^	RT_MKK,$/;"	e	enum:_RT_REGULATION_COMMON
-RT_MPT_WI_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_MPT_WI_SPINLOCK = 35,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_MP_FIRMWARE	include/rtw_mp.h	/^} RT_MP_FIRMWARE, *PRT_MP_FIRMWARE;$/;"	t	typeref:struct:_MP_FIRMWARE
-RT_MULTI_FUNC	include/hal_data.h	/^} RT_MULTI_FUNC, *PRT_MULTI_FUNC;$/;"	t	typeref:enum:_RT_MULTI_FUNC
-RT_MULTI_FUNC_BT	include/hal_data.h	/^	RT_MULTI_FUNC_BT		= 0x02,$/;"	e	enum:_RT_MULTI_FUNC
-RT_MULTI_FUNC_GPS	include/hal_data.h	/^	RT_MULTI_FUNC_GPS	= 0x04,$/;"	e	enum:_RT_MULTI_FUNC
-RT_MULTI_FUNC_NONE	include/hal_data.h	/^	RT_MULTI_FUNC_NONE	= 0x00,$/;"	e	enum:_RT_MULTI_FUNC
-RT_MULTI_FUNC_WIFI	include/hal_data.h	/^	RT_MULTI_FUNC_WIFI	= 0x01,$/;"	e	enum:_RT_MULTI_FUNC
-RT_NCC	hal/phydm/rtchnlplan.h	/^	RT_NCC,$/;"	e	enum:_RT_REGULATION_COMMON
-RT_NDPA_STA_INFO	hal/phydm/phydm_beamforming.h	/^} RT_NDPA_STA_INFO, *PRT_NDPA_STA_INFO;$/;"	t	typeref:struct:_RT_NDPA_STA_INFO
-RT_P2P_SPIN_LOCK	hal/phydm/phydm_types.h	/^	RT_P2P_SPIN_LOCK = 36,	\/\/ Protect P2P context$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_PCI_ASPM_OSC_DISABLE	include/rtw_pwrctrl.h	217;"	d
-RT_PCI_ASPM_OSC_ENABLE	include/rtw_pwrctrl.h	216;"	d
-RT_PCI_ASPM_OSC_IGNORE	include/rtw_pwrctrl.h	215;"	d
-RT_PCI_CAPABILITIES_HEADER	include/drv_types_pci.h	/^} RT_PCI_CAPABILITIES_HEADER, *PRT_PCI_CAPABILITIES_HEADER;$/;"	t	typeref:struct:_RT_PCI_CAPABILITIES_HEADER
-RT_PCI_INTERFACE	hal/phydm/phydm_types.h	42;"	d
-RT_PENDED_OID_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_PENDED_OID_SPINLOCK = 39,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_PMAC_PKT_INFO	include/rtw_mp.h	/^} RT_PMAC_PKT_INFO, *PRT_PMAC_PKT_INFO;$/;"	t	typeref:struct:_RT_PMAC_PKT_INFO
-RT_PMAC_TX_INFO	include/rtw_mp.h	/^} RT_PMAC_TX_INFO, *PRT_PMAC_TX_INFO;$/;"	t	typeref:struct:_RT_PMAC_TX_INFO
-RT_PMKID_LIST	include/rtw_security.h	/^} RT_PMKID_LIST, *PRT_PMKID_LIST;$/;"	t	typeref:struct:_RT_PMKID_LIST
-RT_POLARITY_CTL	include/hal_data.h	/^} RT_POLARITY_CTL, *PRT_POLARITY_CTL;$/;"	t	typeref:enum:_RT_POLARITY_CTL
-RT_POLARITY_HIGH_ACT	include/hal_data.h	/^	RT_POLARITY_HIGH_ACT	= 1,$/;"	e	enum:_RT_POLARITY_CTL
-RT_POLARITY_LOW_ACT	include/hal_data.h	/^	RT_POLARITY_LOW_ACT	= 0,$/;"	e	enum:_RT_POLARITY_CTL
-RT_PORT_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_PORT_SPINLOCK=16,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_PRINTK	hal/phydm/phydm_debug.h	134;"	d
-RT_PRINTK	hal/phydm/phydm_debug.h	137;"	d
-RT_PRINTK	hal/phydm/phydm_debug.h	141;"	d
-RT_REGULATION_2G	hal/phydm/rtchnlplan.h	/^}RT_REGULATION_2G, *PRT_REGULATION_2G;$/;"	t	typeref:enum:_RT_REGULATION_DOMAIN_2G
-RT_REGULATION_5G	hal/phydm/rtchnlplan.h	/^}RT_REGULATION_5G, *PRT_REGULATION_5G;$/;"	t	typeref:enum:_RT_REGULATION_DOMAIN_5G
-RT_REGULATION_CMN	hal/phydm/rtchnlplan.h	/^}RT_REGULATION_CMN, *PRT_REGULATION_CMN;$/;"	t	typeref:enum:_RT_REGULATION_COMMON
-RT_REGULATOR_MODE	include/hal_data.h	/^} RT_REGULATOR_MODE, *PRT_REGULATOR_MODE;$/;"	t	typeref:enum:_RT_REGULATOR_MODE
-RT_RFD_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_RFD_SPINLOCK = 42,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_RF_LPS_DISALBE_2R	include/rtw_pwrctrl.h	207;"	d
-RT_RF_LPS_LEVEL_ASPM	include/rtw_pwrctrl.h	208;"	d
-RT_RF_OFF_LEVL_ASPM	include/rtw_pwrctrl.h	200;"	d
-RT_RF_OFF_LEVL_CLK_REQ	include/rtw_pwrctrl.h	201;"	d
-RT_RF_OFF_LEVL_FREE_FW	include/rtw_pwrctrl.h	204;"	d
-RT_RF_OFF_LEVL_FW_32K	include/rtw_pwrctrl.h	205;"	d
-RT_RF_OFF_LEVL_HALT_NIC	include/rtw_pwrctrl.h	203;"	d
-RT_RF_OFF_LEVL_PCI_D3	include/rtw_pwrctrl.h	202;"	d
-RT_RF_OPERATE_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_RF_OPERATE_SPINLOCK = 10,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_RF_PS_LEVEL_ALWAYS_ASPM	include/rtw_pwrctrl.h	206;"	d
-RT_RF_STATE_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_RF_STATE_SPINLOCK = 12, \/\/ For RF state. Added by Bruce, 2007-10-30.$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_RF_TYPE_DEF_E	include/rtw_rf.h	/^} RT_RF_TYPE_DEF_E;$/;"	t	typeref:enum:_RT_RF_TYPE_DEFINITION
-RT_RM_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_RM_SPINLOCK = 3,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_RX_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_RX_SPINLOCK = 2,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_SCAN_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_SCAN_SPINLOCK = 5,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_SCAN_TYPE	include/rtw_mlme.h	/^} RT_SCAN_TYPE, *PRT_SCAN_TYPE;$/;"	t	typeref:enum:_RT_SCAN_TYPE
-RT_SCAN_TYPE_NEW	hal/phydm/rtchnlplan.h	/^}RT_SCAN_TYPE_NEW, *PRT_SCAN_TYPE_NEW;$/;"	t	typeref:enum:_RT_SCAN_TYPE_NEW
-RT_SDIO_INTERFACE	hal/phydm/phydm_types.h	44;"	d
-RT_SET_PS_LEVEL	include/rtw_pwrctrl.h	212;"	d
-RT_SOUNDING_INFO	hal/phydm/phydm_beamforming.h	/^} RT_SOUNDING_INFO, *PRT_SOUNDING_INFO;$/;"	t	typeref:struct:_RT_SOUNDING_INFO
-RT_SPINLOCK_TYPE	hal/phydm/phydm_types.h	/^}RT_SPINLOCK_TYPE;$/;"	t	typeref:enum:_RT_SPINLOCK_TYPE
-RT_SREQ_2G_ADHOC_11B	hal/phydm/rtchnlplan.h	/^	RT_SREQ_2G_ADHOC_11B			= 0x00000002,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_2G_ADHOC_11N	hal/phydm/rtchnlplan.h	/^	RT_SREQ_2G_ADHOC_11N			= 0x00000001,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_2G_ALL_ACT	hal/phydm/rtchnlplan.h	/^	RT_SREQ_2G_ALL_ACT				= 0x00000008,	$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_2G_ALL_PASS	hal/phydm/rtchnlplan.h	/^	RT_SREQ_2G_ALL_PASS				= 0x00000004,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_5G_ADHOC_11AC	hal/phydm/rtchnlplan.h	/^	RT_SREQ_5G_ADHOC_11AC			= 0x00000020,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_5G_ADHOC_11N	hal/phydm/rtchnlplan.h	/^	RT_SREQ_5G_ADHOC_11N			= 0x00000010,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_5G_ALL_ACT	hal/phydm/rtchnlplan.h	/^	RT_SREQ_5G_ALL_ACT				= 0x00000080,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_5G_ALL_PASS	hal/phydm/rtchnlplan.h	/^	RT_SREQ_5G_ALL_PASS				= 0x00000040,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_C1_PLAN	hal/phydm/rtchnlplan.h	/^	RT_SREQ_C1_PLAN					= 0x00000100,	$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_C2_PLAN	hal/phydm/rtchnlplan.h	/^	RT_SREQ_C2_PLAN					= 0x00000200,	$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_C3_PLAN	hal/phydm/rtchnlplan.h	/^	RT_SREQ_C3_PLAN					= 0x00000400,	$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_C4_PLAN	hal/phydm/rtchnlplan.h	/^	RT_SREQ_C4_PLAN					= 0x00000800,	$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_MASK	hal/phydm/rtchnlplan.h	/^	RT_SREQ_MASK					= 0x0000FFFF,   \/* Requirements bit mask *\/$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_NA	hal/phydm/rtchnlplan.h	/^	RT_SREQ_NA						= 0x0,$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SREQ_NFC_ON	hal/phydm/rtchnlplan.h	/^	RT_SREQ_NFC_ON					= 0x00001000,	$/;"	e	enum:_RT_CHNLPLAN_SREQ
-RT_SWITCHING_REGULATOR	include/hal_data.h	/^	RT_SWITCHING_REGULATOR	= 0,$/;"	e	enum:_RT_REGULATOR_MODE
-RT_SYNC_IO_CNT_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_SYNC_IO_CNT_SPINLOCK = 43,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_TAG	os_dep/osdep_service.c	26;"	d	file:
-RT_TIMER	hal/phydm/phydm_types.h	/^	typedef struct timer_list		RT_TIMER, *PRT_TIMER;$/;"	t	typeref:struct:timer_list
-RT_TIMER_CALL_BACK	hal/phydm/phydm_types.h	/^	typedef  void *				RT_TIMER_CALL_BACK;$/;"	t
-RT_TRACE	include/rtw_debug.h	79;"	d
-RT_TX_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_TX_SPINLOCK = 1,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_USBRX_CONTEXT_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_USBRX_CONTEXT_SPINLOCK = 13,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_USBRX_POSTPROC_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_USBRX_POSTPROC_SPINLOCK = 14, \/\/ protect data of Adapter->IndicateW\/ IndicateR$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_USB_BOOT_TYPE	include/usb_vendor_req.h	/^	RT_USB_BOOT_TYPE	=	5$/;"	e	enum:_RT_USB_WVALUE
-RT_USB_BREQUEST	include/usb_vendor_req.h	/^} RT_USB_BREQUEST;$/;"	t	typeref:enum:_RT_USB_BREQUEST
-RT_USB_GET_REGISTER	include/usb_vendor_req.h	/^	RT_USB_GET_REGISTER		= 4$/;"	e	enum:_RT_USB_BREQUEST
-RT_USB_GET_SYSCLK	include/usb_vendor_req.h	/^	RT_USB_GET_SYSCLK		= 3,$/;"	e	enum:_RT_USB_BREQUEST
-RT_USB_INTERFACE	hal/phydm/phydm_types.h	43;"	d
-RT_USB_LDO	include/usb_vendor_req.h	/^	RT_USB_LDO			=	4,$/;"	e	enum:_RT_USB_WVALUE
-RT_USB_LDO_OFF	include/usb_vendor_req.h	29;"	d
-RT_USB_LDO_ON	include/usb_vendor_req.h	28;"	d
-RT_USB_RESET_MASK	include/usb_vendor_req.h	/^	RT_USB_RESET_MASK	=	1,$/;"	e	enum:_RT_USB_WVALUE
-RT_USB_RESET_MASK_OFF	include/usb_vendor_req.h	24;"	d
-RT_USB_RESET_MASK_ON	include/usb_vendor_req.h	25;"	d
-RT_USB_SET_REGISTER	include/usb_vendor_req.h	/^	RT_USB_SET_REGISTER		= 1,$/;"	e	enum:_RT_USB_BREQUEST
-RT_USB_SET_SYSCLK	include/usb_vendor_req.h	/^	RT_USB_SET_SYSCLK		= 2,$/;"	e	enum:_RT_USB_BREQUEST
-RT_USB_SLEEP_MASK	include/usb_vendor_req.h	/^	RT_USB_SLEEP_MASK	=	2,$/;"	e	enum:_RT_USB_WVALUE
-RT_USB_SLEEP_MASK_OFF	include/usb_vendor_req.h	26;"	d
-RT_USB_SLEEP_MASK_ON	include/usb_vendor_req.h	27;"	d
-RT_USB_SYSCLK_32KHZ	include/usb_vendor_req.h	32;"	d
-RT_USB_SYSCLK_40MHZ	include/usb_vendor_req.h	33;"	d
-RT_USB_SYSCLK_60MHZ	include/usb_vendor_req.h	34;"	d
-RT_USB_USB_HRCPWM	include/usb_vendor_req.h	/^	RT_USB_USB_HRCPWM	=	3,$/;"	e	enum:_RT_USB_WVALUE
-RT_USB_WVALUE	include/usb_vendor_req.h	/^} RT_USB_WVALUE;$/;"	t	typeref:enum:_RT_USB_WVALUE
-RT_VNIC_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_VNIC_SPINLOCK=17,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_WAPI_BKID	include/rtw_wapi.h	/^} RT_WAPI_BKID, *PRT_WAPI_BKID;$/;"	t	typeref:struct:_RT_WAPI_BKID
-RT_WAPI_CAM_ENTRY	include/rtw_wapi.h	/^} RT_WAPI_CAM_ENTRY, *PRT_WAPI_CAM_ENTRY;$/;"	t	typeref:struct:_RT_WAPI_CAM_ENTRY
-RT_WAPI_KEY	include/rtw_wapi.h	/^} RT_WAPI_KEY, *PRT_WAPI_KEY;$/;"	t	typeref:struct:_RT_WAPI_KEY
-RT_WAPI_OPTION_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_WAPI_OPTION_SPINLOCK=26,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_WAPI_PACKET_TYPE	include/rtw_wapi.h	/^} RT_WAPI_PACKET_TYPE;$/;"	t	typeref:enum:_RT_WAPI_PACKET_TYPE
-RT_WAPI_RX_SPINLOCK	hal/phydm/phydm_types.h	/^	RT_WAPI_RX_SPINLOCK=27,$/;"	e	enum:_RT_SPINLOCK_TYPE
-RT_WAPI_STA_INFO	include/rtw_wapi.h	/^} RT_WAPI_STA_INFO, *PRT_WAPI_STA_INFO;$/;"	t	typeref:struct:_RT_WAPI_STA_INFO
-RT_WAPI_T	include/rtw_wapi.h	/^} RT_WAPI_T, *PRT_WAPI_T;$/;"	t	typeref:struct:_RT_WAPI_T
-RT_WORKITEM_CALL_BACK	hal/phydm/phydm_interface.h	/^typedef VOID (*RT_WORKITEM_CALL_BACK)(PVOID pContext);$/;"	t
-RT_WORKITEM_HANDLE	hal/phydm/phydm_interface.h	/^typedef  void RT_WORKITEM_HANDLE,*PRT_WORKITEM_HANDLE;$/;"	t
-RT_WORLD	hal/phydm/rtchnlplan.h	/^	RT_WORLD,   $/;"	e	enum:_RT_REGULATION_COMMON
-RWCAM	include/hal_com_reg.h	580;"	d
-RWCAM_8723D	hal/phydm/rtl8723d/hal8723dreg.h	454;"	d
-RWCAM_8814A	include/rtl8814a_spec.h	553;"	d
-RW_RELEASE_EN	hal/rtl8723d/rtl8723d_hal_init.c	5511;"	d	file:
-RW_RELEASE_EN	include/hal_com_reg.h	1456;"	d
-RW_RELEASE_EN	include/rtl8188f_spec.h	205;"	d
-RW_RELEASE_EN	include/rtl8703b_spec.h	381;"	d
-RW_RELEASE_EN	include/rtl8723b_spec.h	189;"	d
-RW_RELEASE_EN	include/rtl8723d_spec.h	417;"	d
-RW_Reg	include/rtw_mp_ioctl.h	/^} mp_rw_reg, RW_Reg, *pRW_Reg;$/;"	t	typeref:struct:_RW_REG
-RXAntStatus	hal/phydm/phydm.h	/^	u1Byte			RXAntStatus;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RXBD_SIZE	include/rtw_recv.h	296;"	d
-RXDESC_OFFSET	include/rtw_recv.h	300;"	d
-RXDESC_SIZE	include/gspi_ops.h	141;"	d
-RXDESC_SIZE	include/rtw_recv.h	299;"	d
-RXDMA_AGG_EN	include/hal_com_reg.h	1353;"	d
-RXDMA_AGG_MODE_EN	include/rtl8188f_spec.h	200;"	d
-RXDMA_AGG_MODE_EN	include/rtl8703b_spec.h	376;"	d
-RXDMA_AGG_MODE_EN	include/rtl8723b_spec.h	184;"	d
-RXDMA_AGG_MODE_EN	include/rtl8723d_spec.h	412;"	d
-RXDMA_ARBBW_EN	include/hal_com_reg.h	1351;"	d
-RXDMA_EN	include/hal_com_reg.h	1318;"	d
-RXDMA_IDLE	hal/rtl8723d/rtl8723d_hal_init.c	5512;"	d	file:
-RXDMA_IDLE	include/hal_com_reg.h	1455;"	d
-RXDMA_IDLE	include/rtl8188f_spec.h	204;"	d
-RXDMA_IDLE	include/rtl8703b_spec.h	380;"	d
-RXDMA_IDLE	include/rtl8723b_spec.h	188;"	d
-RXDMA_IDLE	include/rtl8723d_spec.h	416;"	d
-RXERR_COUNTER_MASK	include/hal_com_reg.h	449;"	d
-RXERR_COUNTER_MASK	include/rtl8822b_hal.h	61;"	d
-RXERR_RPT_RST	include/hal_com_reg.h	450;"	d
-RXERR_RPT_RST	include/rtl8822b_hal.h	62;"	d
-RXERR_TYPE_CCK_FALSE_ALARM	include/hal_com_reg.h	439;"	d
-RXERR_TYPE_CCK_FALSE_ALARM	include/rtl8822b_hal.h	51;"	d
-RXERR_TYPE_CCK_MPDU_FAIL	include/hal_com_reg.h	441;"	d
-RXERR_TYPE_CCK_MPDU_FAIL	include/rtl8822b_hal.h	53;"	d
-RXERR_TYPE_CCK_MPDU_OK	include/hal_com_reg.h	440;"	d
-RXERR_TYPE_CCK_MPDU_OK	include/rtl8822b_hal.h	52;"	d
-RXERR_TYPE_CCK_PPDU	include/hal_com_reg.h	438;"	d
-RXERR_TYPE_CCK_PPDU	include/rtl8822b_hal.h	50;"	d
-RXERR_TYPE_HT_FALSE_ALARM	include/hal_com_reg.h	443;"	d
-RXERR_TYPE_HT_FALSE_ALARM	include/rtl8822b_hal.h	55;"	d
-RXERR_TYPE_HT_MPDU_FAIL	include/hal_com_reg.h	446;"	d
-RXERR_TYPE_HT_MPDU_FAIL	include/rtl8822b_hal.h	58;"	d
-RXERR_TYPE_HT_MPDU_OK	include/hal_com_reg.h	445;"	d
-RXERR_TYPE_HT_MPDU_OK	include/rtl8822b_hal.h	57;"	d
-RXERR_TYPE_HT_MPDU_TOTAL	include/hal_com_reg.h	444;"	d
-RXERR_TYPE_HT_MPDU_TOTAL	include/rtl8822b_hal.h	56;"	d
-RXERR_TYPE_HT_PPDU	include/hal_com_reg.h	442;"	d
-RXERR_TYPE_HT_PPDU	include/rtl8822b_hal.h	54;"	d
-RXERR_TYPE_OFDM_FALSE_ALARM	include/hal_com_reg.h	435;"	d
-RXERR_TYPE_OFDM_FALSE_ALARM	include/rtl8822b_hal.h	47;"	d
-RXERR_TYPE_OFDM_MPDU_FAIL	include/hal_com_reg.h	437;"	d
-RXERR_TYPE_OFDM_MPDU_FAIL	include/rtl8822b_hal.h	49;"	d
-RXERR_TYPE_OFDM_MPDU_OK	include/hal_com_reg.h	436;"	d
-RXERR_TYPE_OFDM_MPDU_OK	include/rtl8822b_hal.h	48;"	d
-RXERR_TYPE_OFDM_PPDU	include/hal_com_reg.h	434;"	d
-RXERR_TYPE_OFDM_PPDU	include/rtl8822b_hal.h	46;"	d
-RXERR_TYPE_RX_FULL_DROP	include/hal_com_reg.h	447;"	d
-RXERR_TYPE_RX_FULL_DROP	include/rtl8822b_hal.h	59;"	d
-RXEVM	hal/phydm/phydm.h	/^	u1Byte		RXEVM[4];$/;"	m	struct:_ODM_STA_INFO
-RXEVM	include/sta_info.h	/^	u8		RXEVM[4];$/;"	m	struct:sta_info
-RXFRAME_ALIGN	include/rtw_recv.h	61;"	d
-RXFRAME_ALIGN_SZ	include/rtw_recv.h	62;"	d
-RXIQK1	hal/phydm/phydm_iqk.h	30;"	d
-RXIQK2	hal/phydm/phydm_iqk.h	31;"	d
-RXIQK_AGC	hal/phydm/phydm_iqk.h	/^	u4Byte		RXIQK_AGC[2][4];	 \/*channel \/ path*\/$/;"	m	struct:_IQK_INFORMATION
-RXIQK_fail_code	hal/phydm/phydm_iqk.h	/^	u1Byte		RXIQK_fail_code[2][4]; \/*channel \/ path 0:SRXK1 fail, 1:RXK1 fail 2:RXK2 fail*\/	$/;"	m	struct:_IQK_INFORMATION
-RXPKT_BUF_SELECT	include/hal_com_reg.h	30;"	d
-RXPKT_RELEASE_POLL	include/hal_com_reg.h	1454;"	d
-RXPKT_RELEASE_POLL	include/rtl8188f_spec.h	203;"	d
-RXPKT_RELEASE_POLL	include/rtl8703b_spec.h	379;"	d
-RXPKT_RELEASE_POLL	include/rtl8723b_spec.h	187;"	d
-RXPKT_RELEASE_POLL	include/rtl8723d_spec.h	415;"	d
-RXREPORT	include/rtl8188e_recv.h	/^} RXREPORT, *PRXREPORT;$/;"	t	typeref:struct:rxreport_8188e
-RXSC_40M	core/rtw_odm.c	451;"	d	file:
-RXSC_DUP	core/rtw_odm.c	448;"	d	file:
-RXSC_DUP	core/rtw_odm.c	476;"	d	file:
-RXSC_L20M_OF_160M	core/rtw_odm.c	479;"	d	file:
-RXSC_L20M_OF_40M	core/rtw_odm.c	481;"	d	file:
-RXSC_L20M_OF_80M	core/rtw_odm.c	480;"	d	file:
-RXSC_L40M_OF_160M	core/rtw_odm.c	487;"	d	file:
-RXSC_L40M_OF_80M	core/rtw_odm.c	488;"	d	file:
-RXSC_L80M_OF_160M	core/rtw_odm.c	492;"	d	file:
-RXSC_LL20M_OF_160M	core/rtw_odm.c	478;"	d	file:
-RXSC_LSC	core/rtw_odm.c	449;"	d	file:
-RXSC_U20M_OF_160M	core/rtw_odm.c	484;"	d	file:
-RXSC_U20M_OF_40M	core/rtw_odm.c	482;"	d	file:
-RXSC_U20M_OF_80M	core/rtw_odm.c	483;"	d	file:
-RXSC_U40M_OF_160M	core/rtw_odm.c	490;"	d	file:
-RXSC_U40M_OF_80M	core/rtw_odm.c	489;"	d	file:
-RXSC_U80M_OF_160M	core/rtw_odm.c	493;"	d	file:
-RXSC_USC	core/rtw_odm.c	450;"	d	file:
-RXSC_UU20M_OF_160M	core/rtw_odm.c	485;"	d	file:
-RXSHFT_EN	include/hal_com_reg.h	1352;"	d
-RXSNR	hal/phydm/phydm.h	/^	u1Byte		RXSNR[4];$/;"	m	struct:_ODM_STA_INFO
-RXSNR	include/sta_info.h	/^	u8		RXSNR[4];$/;"	m	struct:sta_info
-RX_ACTIVE_TH	core/rtw_cmd.c	2455;"	d	file:
-RX_AGG_DISABLE	include/hal_data.h	/^	RX_AGG_DISABLE,$/;"	e	enum:_RX_AGG_MODE
-RX_AGG_DMA	include/hal_data.h	/^	RX_AGG_DMA,$/;"	e	enum:_RX_AGG_MODE
-RX_AGG_MIX	include/hal_data.h	/^	RX_AGG_MIX$/;"	e	enum:_RX_AGG_MODE
-RX_AGG_MODE	include/hal_data.h	/^} RX_AGG_MODE;$/;"	t	typeref:enum:_RX_AGG_MODE
-RX_AGG_USB	include/hal_data.h	/^	RX_AGG_USB,$/;"	e	enum:_RX_AGG_MODE
-RX_AMPDU_ACCEPT_INVALID	include/rtw_mlme_ext.h	974;"	d
-RX_AMPDU_BTCOEX	include/rtw_mlme_ext.h	/^	RX_AMPDU_BTCOEX = 2, \/* not used, because BTCOEX has its own variable management *\/$/;"	e	enum:rx_ampdu_reason
-RX_AMPDU_DRV_FIXED	include/rtw_mlme_ext.h	/^	RX_AMPDU_DRV_FIXED = 1,$/;"	e	enum:rx_ampdu_reason
-RX_AMPDU_DRV_SCAN	include/rtw_mlme_ext.h	/^	RX_AMPDU_DRV_SCAN = 3,$/;"	e	enum:rx_ampdu_reason
-RX_AMPDU_SIZE_INVALID	include/rtw_mlme_ext.h	975;"	d
-RX_ARP_REQUEST	include/hal_com.h	/^	RX_ARP_REQUEST					= 0x09,$/;"	e	enum:_WAKEUP_REASON
-RX_ATTEND_ACK	include/rtw_btcoex.h	77;"	d
-RX_ATTEND_REQ	include/rtw_btcoex.h	81;"	d
-RX_BD_NUM	include/rtw_recv.h	347;"	d
-RX_BT_LEAVE	include/rtw_btcoex.h	79;"	d
-RX_CMD_QUEUE	include/rtw_recv.h	78;"	d
-RX_DEAUTH	include/hal_com.h	/^	RX_DEAUTH						= 0x08,$/;"	e	enum:_WAKEUP_REASON
-RX_DESC_NUM_8814A	include/rtl8814a_hal.h	205;"	d
-RX_DESC_NUM_8814A	include/rtl8814a_hal.h	214;"	d
-RX_DESC_NUM_92E	include/rtl8192e_hal.h	188;"	d
-RX_DISASSOC	include/hal_com.h	/^	RX_DISASSOC						= 0x04,$/;"	e	enum:_WAKEUP_REASON
-RX_DMA_BOUNDARY_8188F	include/rtl8188f_hal.h	107;"	d
-RX_DMA_BOUNDARY_8703B	include/rtl8703b_hal.h	108;"	d
-RX_DMA_BOUNDARY_8723B	include/rtl8723b_hal.h	108;"	d
-RX_DMA_BOUNDARY_8723D	include/rtl8723d_hal.h	112;"	d
-RX_DMA_BOUNDARY_8812	include/rtl8812a_hal.h	141;"	d
-RX_DMA_BOUNDARY_8814A	include/rtl8814a_hal.h	166;"	d
-RX_DMA_BOUNDARY_8821	include/rtl8812a_hal.h	191;"	d
-RX_DMA_RESERVD_FW_FEATURE	include/rtl8188e_hal.h	130;"	d
-RX_DMA_RESERVED_SIZE_8188F	include/rtl8188f_hal.h	96;"	d
-RX_DMA_RESERVED_SIZE_8188F	include/rtl8188f_hal.h	98;"	d
-RX_DMA_RESERVED_SIZE_8192E	include/rtl8192e_hal.h	123;"	d
-RX_DMA_RESERVED_SIZE_8192E	include/rtl8192e_hal.h	125;"	d
-RX_DMA_RESERVED_SIZE_8703B	include/rtl8703b_hal.h	104;"	d
-RX_DMA_RESERVED_SIZE_8703B	include/rtl8703b_hal.h	106;"	d
-RX_DMA_RESERVED_SIZE_8723B	include/rtl8723b_hal.h	104;"	d
-RX_DMA_RESERVED_SIZE_8723B	include/rtl8723b_hal.h	106;"	d
-RX_DMA_RESERVED_SIZE_8723D	include/rtl8723d_hal.h	108;"	d
-RX_DMA_RESERVED_SIZE_8723D	include/rtl8723d_hal.h	110;"	d
-RX_DMA_RESERVED_SIZE_8812	include/rtl8812a_hal.h	137;"	d
-RX_DMA_RESERVED_SIZE_8812	include/rtl8812a_hal.h	139;"	d
-RX_DMA_RESERVED_SIZE_8814A	include/rtl8814a_hal.h	162;"	d
-RX_DMA_RESERVED_SIZE_8814A	include/rtl8814a_hal.h	164;"	d
-RX_DMA_RESERVED_SIZE_8821	include/rtl8812a_hal.h	187;"	d
-RX_DMA_RESERVED_SIZE_8821	include/rtl8812a_hal.h	189;"	d
-RX_DMA_SIZE_8188F	include/rtl8188f_hal.h	94;"	d
-RX_DMA_SIZE_8192E	include/rtl8192e_hal.h	114;"	d
-RX_DMA_SIZE_8703B	include/rtl8703b_hal.h	95;"	d
-RX_DMA_SIZE_8723B	include/rtl8723b_hal.h	95;"	d
-RX_DMA_SIZE_8723D	include/rtl8723d_hal.h	99;"	d
-RX_DMA_SIZE_88E	include/rtl8188e_hal.h	119;"	d
-RX_DMA_SIZE_88E	include/rtl8188e_hal.h	121;"	d
-RX_DRV_INFO_SIZE_UNIT_8188F	include/rtl8188f_xmit.h	31;"	d
-RX_DRV_INFO_SIZE_UNIT_8703B	include/rtl8703b_xmit.h	31;"	d
-RX_DRV_INFO_SIZE_UNIT_8723B	include/rtl8723b_xmit.h	31;"	d
-RX_DRV_INFO_SIZE_UNIT_8723D	include/rtl8723d_xmit.h	31;"	d
-RX_FOURWAY_HANDSHAKE	include/hal_com.h	/^	RX_FOURWAY_HANDSHAKE			= 0x03,$/;"	e	enum:_WAKEUP_REASON
-RX_GTK	include/hal_com.h	/^	RX_GTK							= 0x02,$/;"	e	enum:_WAKEUP_REASON
-RX_HAL_IS_CCK_RATE_8188F	include/rtl8188f_xmit.h	284;"	d
-RX_HAL_IS_CCK_RATE_8703B	include/rtl8703b_xmit.h	284;"	d
-RX_HAL_IS_CCK_RATE_8723B	include/rtl8723b_xmit.h	284;"	d
-RX_HAL_IS_CCK_RATE_8723D	include/rtl8723d_xmit.h	463;"	d
-RX_INVITE_REQ	include/rtw_btcoex.h	80;"	d
-RX_INVITE_RSP	include/rtw_btcoex.h	82;"	d
-RX_IQK	hal/phydm/phydm_iqk.h	28;"	d
-RX_LEAVE_ACK	include/rtw_btcoex.h	78;"	d
-RX_MAGIC_PKT	include/hal_com.h	/^	RX_MAGIC_PKT					= 0x21,$/;"	e	enum:_WAKEUP_REASON
-RX_MAX_QUEUE	include/rtw_recv.h	79;"	d
-RX_MPDU_QUEUE	include/rtw_recv.h	77;"	d
-RX_PACKET_TYPE	include/rtw_recv.h	/^} RX_PACKET_TYPE, *PRX_PACKET_TYPE;$/;"	t	typeref:enum:_RX_PACKET_TYPE
-RX_PAIRWISEKEY	include/hal_com.h	/^	RX_PAIRWISEKEY					= 0x01,$/;"	e	enum:_WAKEUP_REASON
-RX_PATTERN_PKT	include/hal_com.h	/^	RX_PATTERN_PKT					= 0x23,$/;"	e	enum:_WAKEUP_REASON
-RX_PKT_BROADCAST	include/rtw_mp.h	677;"	d
-RX_PKT_DEST_ADDR	include/rtw_mp.h	678;"	d
-RX_PKT_PHY_MATCH	include/rtw_mp.h	679;"	d
-RX_PNO	include/hal_com.h	/^	RX_PNO							= 0x55,$/;"	e	enum:_WAKEUP_REASON
-RX_REALWOW_V2_ACK_LOST	include/hal_com.h	/^	RX_REALWOW_V2_ACK_LOST			= 0x31,$/;"	e	enum:_WAKEUP_REASON
-RX_REALWOW_V2_WAKEUP_PKT	include/hal_com.h	/^	RX_REALWOW_V2_WAKEUP_PKT		= 0x30,$/;"	e	enum:_WAKEUP_REASON
-RX_RX0FF_BASE	include/hal_com_reg.h	1609;"	d
-RX_RXFIFO_DOMAIN	include/gspi_ops.h	34;"	d
-RX_RXOFF_OFFSET	include/gspi_ops.h	44;"	d
-RX_STATUS_DESC_SIZE_8188F	include/rtl8188f_xmit.h	30;"	d
-RX_STATUS_DESC_SIZE_8703B	include/rtl8703b_xmit.h	30;"	d
-RX_STATUS_DESC_SIZE_8723B	include/rtl8723b_xmit.h	30;"	d
-RX_STATUS_DESC_SIZE_8723D	include/rtl8723d_xmit.h	30;"	d
-RX_UNICAST_PKT	include/hal_com.h	/^	RX_UNICAST_PKT					= 0x22,$/;"	e	enum:_WAKEUP_REASON
-RX_WIFI_INFO_SIZE	include/rtw_recv.h	294;"	d
-RX_X	include/rtw_mcc.h	/^	u16 RX_X;$/;"	m	struct:mcc_iqk_backup
-RX_Y	include/rtw_mcc.h	/^	u16 RX_Y;$/;"	m	struct:mcc_iqk_backup
-R_ANTENNA_SELECT_CCK	include/hal_phy.h	/^} R_ANTENNA_SELECT_CCK;$/;"	t	typeref:struct:_R_ANTENNA_SELECT_CCK
-R_ANTENNA_SELECT_OFDM	include/hal_phy.h	/^} R_ANTENNA_SELECT_OFDM;$/;"	t	typeref:struct:_R_ANTENNA_SELECT_OFDM
-R_EN_BOOT_FLASH	include/rtl8814a_spec.h	511;"	d
-RaRptWorkitem	hal/phydm/phydm.h	/^	RT_WORK_ITEM			RaRptWorkitem;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RaSupport88E	hal/phydm/phydm.h	/^	BOOLEAN				RaSupport88E;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RamCodeSize	include/rtl8188e_hal.h	/^	u16		RamCodeSize;	\/* The size of RAM code *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-RamCodeSize	include/rtl8188f_hal.h	/^	u16		RamCodeSize;	\/* The size of RAM code *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-RamCodeSize	include/rtl8703b_hal.h	/^	u16		RamCodeSize;	\/* The size of RAM code *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-RamCodeSize	include/rtl8723b_hal.h	/^	u16		RamCodeSize;	\/* The size of RAM code *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-RamCodeSize	include/rtl8723d_hal.h	/^	u16		RamCodeSize;	\/* The size of RAM code *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Rate	hal/phydm/txbf/halcomtxbf.h	/^	u1Byte				Rate;$/;"	m	struct:_HAL_TXBF_INFO
-RateAdaptive	hal/phydm/phydm.h	/^	ODM_RATE_ADAPTIVE	RateAdaptive;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RateDirection	hal/phydm/phydm_rainfo.h	/^	u1Byte RateDirection;$/;"	m	struct:_ODM_RA_Info_
-RateDownCounter	hal/phydm/phydm_rainfo.h	/^	u1Byte RateDownCounter;$/;"	m	struct:_ODM_RA_Info_
-RateDownStartTime	hal/phydm/phydm_rainfo.h	/^	u1Byte RateDownStartTime;$/;"	m	struct:_ODM_RA_Info_
-RateID	hal/phydm/phydm_rainfo.h	/^	u1Byte RateID;$/;"	m	struct:_ODM_RA_Info_
-RateMask	hal/phydm/phydm_rainfo.h	/^	u4Byte RateMask;$/;"	m	struct:_ODM_RA_Info_
-RateSGI	hal/phydm/phydm_rainfo.h	/^	u1Byte RateSGI;$/;"	m	struct:_ODM_RA_Info_
-RateUpCounter	hal/phydm/phydm_rainfo.h	/^	u1Byte RateUpCounter;$/;"	m	struct:_ODM_RA_Info_
-ReInit	include/rtw_btcoex.h	/^	u8 ReInit:1;$/;"	m	struct:btinfo_8761ATV
-ReadAdapterInfo8723DS	hal/rtl8723d/sdio/sdio_halinit.c	/^static void ReadAdapterInfo8723DS(PADAPTER padapter)$/;"	f	file:
-ReadBE1Byte	include/basic_types.h	207;"	d
-ReadBE2Byte	include/basic_types.h	206;"	d
-ReadBEE4Byte	include/basic_types.h	205;"	d
-ReadEFuse	include/hal_intf.h	/^	void (*ReadEFuse)(_adapter *padapter, u8 efuseType, u16 _offset, u16 _size_byte, u8 *pbuf, BOOLEAN bPseudoTest);$/;"	m	struct:hal_ops
-ReadEFuseByte	core/efuse/rtw_efuse.c	/^ReadEFuseByte($/;"	f
-ReadInterrupt8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^static s32 ReadInterrupt8723DSdio(PADAPTER padapter, u32 *phisr)$/;"	f	file:
-ReadLE1Byte	include/basic_types.h	200;"	d
-ReadLE2Byte	include/basic_types.h	199;"	d
-ReadLE4Byte	include/basic_types.h	198;"	d
-ReadRFThermalMeter	core/rtw_mp.c	/^static u8 ReadRFThermalMeter(PADAPTER pAdapter)$/;"	f	file:
-ReceiveConfig	include/hal_data.h	/^	u32				ReceiveConfig;$/;"	m	struct:hal_com_data
-Recorver	include/hal_phy.h	/^	u8		Recorver;$/;"	m	struct:RF_Shadow_Compare_Map
-Recover_cnt	hal/phydm/phydm_dig.h	/^	u4Byte		Recover_cnt;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-RecvOnePkt	hal/rtl8723d/sdio/sdio_ops.c	/^u8 RecvOnePkt(PADAPTER padapter, u32 size)$/;"	f
-RecvSignalPower	hal/phydm/phydm.h	/^	s1Byte		RecvSignalPower;			\/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RecvSignalPower	include/rtw_recv.h	/^	s8			RecvSignalPower;			\/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. *\/$/;"	m	struct:phy_info
-Reg0x890	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x890; $/;"	m	struct:_ACS_
-Reg0x894	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x894;$/;"	m	struct:_ACS_
-Reg0x898	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x898;$/;"	m	struct:_ACS_
-Reg0x89C	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x89C;$/;"	m	struct:_ACS_
-Reg0x990	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x990; $/;"	m	struct:_ACS_
-Reg0x994	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x994;$/;"	m	struct:_ACS_
-Reg0x998	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x998;$/;"	m	struct:_ACS_
-Reg0x99C	hal/phydm/phydm_acs.h	/^    u4Byte              Reg0x99C;$/;"	m	struct:_ACS_
-Reg0x9A0	hal/phydm/phydm_acs.h	/^    u1Byte              Reg0x9A0;   \/\/ u1Byte$/;"	m	struct:_ACS_
-Reg0xE28	hal/phydm/phydm_acs.h	/^    u1Byte              Reg0xE28;   \/\/ u1Byte$/;"	m	struct:_ACS_
-Reg837	include/hal_data.h	/^	u8	Reg837;$/;"	m	struct:hal_com_data
-Reg85C	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u4Byte		Reg874,RegC70,Reg85C,RegA74;$/;"	m	struct:_Dynamic_Power_Saving_
-Reg860	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	Reg860;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg860	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	Reg860;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg860	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	Reg860;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg864	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	Reg864;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg864	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	Reg864;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg864	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	Reg864;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg870	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	Reg870;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg870	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	Reg870;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg870	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	Reg870;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg874	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u4Byte		Reg874,RegC70,Reg85C,RegA74;$/;"	m	struct:_Dynamic_Power_Saving_
-Reg874	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	Reg874;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg874	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	Reg874;$/;"	m	struct:ODM_RF_Calibration_Structure
-Reg874	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	Reg874;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegA24	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	RegA24; \/\/ for TempCCK$/;"	m	struct:ODM_RF_Calibration_Structure
-RegA24	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	RegA24; \/\/ for TempCCK$/;"	m	struct:ODM_RF_Calibration_Structure
-RegA24	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	RegA24; \/\/ for TempCCK$/;"	m	struct:ODM_RF_Calibration_Structure
-RegA74	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u4Byte		Reg874,RegC70,Reg85C,RegA74;$/;"	m	struct:_Dynamic_Power_Saving_
-RegB68	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	RegB68;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegB68	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	RegB68;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegB68	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	RegB68;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegB6C	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	RegB6C;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegB6C	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	RegB6C;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegB6C	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	RegB6C;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegBcnCtrlVal	include/hal_data.h	/^	u8	RegBcnCtrlVal;$/;"	m	struct:hal_com_data
-RegC04	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	RegC04;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegC04	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	RegC04;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegC04	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	RegC04;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegC08	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	RegC08;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegC08	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	RegC08;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegC08	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	RegC08;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegC70	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u4Byte		Reg874,RegC70,Reg85C,RegA74;$/;"	m	struct:_Dynamic_Power_Saving_
-RegCR_1	include/hal_data.h	/^	u8	RegCR_1;$/;"	m	struct:hal_com_data
-RegDecryptCustomFile	include/drv_types.h	/^	u8	RegDecryptCustomFile;$/;"	m	struct:registry_priv
-RegE94	hal/phydm/phydm_powertracking_ap.h	/^	s4Byte	RegE94;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegE94	hal/phydm/phydm_powertracking_ce.h	/^	s4Byte	RegE94;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegE94	hal/phydm/phydm_powertracking_win.h	/^	s4Byte	RegE94;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegE9C	hal/phydm/phydm_powertracking_ap.h	/^	s4Byte 	RegE9C;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegE9C	hal/phydm/phydm_powertracking_ce.h	/^	s4Byte 	RegE9C;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegE9C	hal/phydm/phydm_powertracking_win.h	/^	s4Byte 	RegE9C;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegEB4	hal/phydm/phydm_powertracking_ap.h	/^	s4Byte	RegEB4;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegEB4	hal/phydm/phydm_powertracking_ce.h	/^	s4Byte	RegEB4;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegEB4	hal/phydm/phydm_powertracking_win.h	/^	s4Byte	RegEB4;$/;"	m	struct:ODM_RF_Calibration_Structure
-RegEBC	hal/phydm/phydm_powertracking_ap.h	/^	s4Byte	RegEBC;	$/;"	m	struct:ODM_RF_Calibration_Structure
-RegEBC	hal/phydm/phydm_powertracking_ce.h	/^	s4Byte	RegEBC;	$/;"	m	struct:ODM_RF_Calibration_Structure
-RegEBC	hal/phydm/phydm_powertracking_win.h	/^	s4Byte	RegEBC;	$/;"	m	struct:ODM_RF_Calibration_Structure
-RegEnableTxPowerByRate	include/drv_types.h	/^	u8	RegEnableTxPowerByRate;$/;"	m	struct:registry_priv
-RegEnableTxPowerLimit	include/drv_types.h	/^	u8	RegEnableTxPowerLimit;$/;"	m	struct:registry_priv
-RegFWOffload	include/hal_data.h	/^	u8	RegFWOffload;$/;"	m	struct:hal_com_data
-RegForRecover	include/hal_data.h	/^	BB_INIT_REGISTER	RegForRecover[5];$/;"	m	struct:hal_com_data
-RegFwHwTxQCtrl	include/hal_data.h	/^	u8	RegFwHwTxQCtrl;$/;"	m	struct:hal_com_data
-RegIQKFWOffload	include/hal_data.h	/^	u8	RegIQKFWOffload;$/;"	m	struct:hal_com_data
-RegMUTxCtrl	hal/phydm/phydm_beamforming.h	/^	u4Byte					RegMUTxCtrl;		\/* For USB\/SDIO interfaces aync I\/O  *\/$/;"	m	struct:_RT_BEAMFORMING_INFO
-RegName	include/drv_types_ce.h	/^	NDIS_STRING		RegName;	\/* variable name text *\/$/;"	m	struct:_MP_REG_ENTRY
-RegName	include/drv_types_xp.h	/^	NDIS_STRING		RegName;	\/* variable name text *\/$/;"	m	struct:_MP_REG_ENTRY
-RegPowerBase	include/drv_types.h	/^	u8	RegPowerBase;$/;"	m	struct:registry_priv
-RegPwrTblSel	include/drv_types.h	/^	u8	RegPwrTblSel;$/;"	m	struct:registry_priv
-RegPwrTrimEnable	include/drv_types.h	/^	u8	RegPwrTrimEnable;$/;"	m	struct:registry_priv
-RegRRSR	include/hal_data.h	/^	u16	RegRRSR;$/;"	m	struct:hal_com_data
-RegReg542	include/hal_data.h	/^	u8	RegReg542;$/;"	m	struct:hal_com_data
-RegRfKFreeEnable	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			RegRfKFreeEnable;	\/*for registry*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RegRfKFreeEnable	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			RegRfKFreeEnable;	\/*for registry*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RegRfKFreeEnable	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			RegRfKFreeEnable;	\/*for registry*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RegTxPause	include/hal_data.h	/^	u8	RegTxPause;$/;"	m	struct:hal_com_data
-RegTxPwrLimit	include/rtw_mp.h	/^	u32			RegTxPwrLimit;$/;"	m	struct:_MPT_CONTEXT
-RegUsbSS	include/drv_types.h	/^	int	RegUsbSS;$/;"	m	struct:dvobj_priv
-Regulation2_4G	include/hal_data.h	/^	u8	Regulation2_4G;$/;"	m	struct:hal_com_data
-Regulation5G	include/hal_data.h	/^	u8	Regulation5G;$/;"	m	struct:hal_com_data
-Regulator	hal/phydm/rtchnlplan.h	/^	RT_REGULATION_CMN		Regulator;$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-RegulatorMode	include/hal_data.h	/^	RT_REGULATOR_MODE	RegulatorMode; \/* switching regulator or LDO *\/$/;"	m	struct:hal_com_data
-Remnant_CCKSwingIdx	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte			Remnant_CCKSwingIdx;$/;"	m	struct:ODM_RF_Calibration_Structure
-Remnant_CCKSwingIdx	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte			Remnant_CCKSwingIdx;$/;"	m	struct:ODM_RF_Calibration_Structure
-Remnant_CCKSwingIdx	hal/phydm/phydm_powertracking_win.h	/^	s1Byte			Remnant_CCKSwingIdx;$/;"	m	struct:ODM_RF_Calibration_Structure
-Remnant_OFDMSwingIdx	hal/phydm/phydm_powertracking_ap.h	/^	s1Byte			Remnant_OFDMSwingIdx[MAX_RF_PATH];   $/;"	m	struct:ODM_RF_Calibration_Structure
-Remnant_OFDMSwingIdx	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte			Remnant_OFDMSwingIdx[MAX_RF_PATH];   $/;"	m	struct:ODM_RF_Calibration_Structure
-Remnant_OFDMSwingIdx	hal/phydm/phydm_powertracking_win.h	/^	s1Byte			Remnant_OFDMSwingIdx[MAX_RF_PATH];$/;"	m	struct:ODM_RF_Calibration_Structure
-Request	include/wlan_bssdef.h	/^	NDIS_802_11_AUTHENTICATION_REQUEST  Request[1];$/;"	m	struct:_NDIS_802_11_AUTHENTICATION_EVENT
-RequestFixedIEs	include/wlan_bssdef.h	/^	NDIS_802_11_AI_REQFI    RequestFixedIEs;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-RequestIELength	include/wlan_bssdef.h	/^	ULONG                   RequestIELength;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-Reserved	include/hal_phy.h	/^	u32			Reserved:2;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-Reserved	include/rtw_wapi.h	/^	u8      Reserved;$/;"	m	struct:_WLAN_HEADER_WAPI_EXTENSION
-Reserved	include/wlan_bssdef.h	/^	UCHAR  Reserved[2];\/* [0]: IS beacon frame *\/$/;"	m	struct:_WLAN_BSSID_EX
-Reserved1	include/drv_types_pci.h	/^			u8	Reserved1[3];$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-Reserved1	include/rtw_io.h	/^	u32		Reserved1:4;$/;"	m	struct:reg_protocol_rd
-Reserved1	include/rtw_io.h	/^	u32		Reserved1:4;$/;"	m	struct:reg_protocol_wt
-Reserved2	include/drv_types_pci.h	/^			u32	Reserved2;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-Reserved2	include/rtw_io.h	/^	u32		Reserved2:24;$/;"	m	struct:reg_protocol_rd
-Reserved2	include/rtw_io.h	/^	u32		Reserved2:24;$/;"	m	struct:reg_protocol_wt
-Reserved3	include/rtw_io.h	/^	u32		Reserved3:3;$/;"	m	struct:reg_protocol_rd
-Reserved3	include/rtw_io.h	/^	u32		Reserved3:3;$/;"	m	struct:reg_protocol_wt
-Reserved4	include/rtw_io.h	/^	u32		Reserved4:16;$/;"	m	struct:reg_protocol_rd
-Reserved4	include/rtw_io.h	/^	u32		Reserved4:16;$/;"	m	struct:reg_protocol_wt
-ReservedPage_Compare	hal/rtl8723d/rtl8723d_hal_init.c	/^int ReservedPage_Compare(PADAPTER Adapter, PRT_MP_FIRMWARE pFirmware, u32 BTPatchSize)$/;"	f
-Reserved_0	include/wlan_bssdef.h	/^	u8	Reserved_0;$/;"	m	struct:_WLAN_PHY_INFO
-ResetLedStatus	hal/led/hal_sdio_led.c	/^void ResetLedStatus(PLED_SDIO pLed)$/;"	f
-ResetPhyRxPktCount	core/rtw_mp.c	/^void ResetPhyRxPktCount(PADAPTER pAdapter)$/;"	f
-Reset_Cnt_Limit	include/Hal8188EPhyCfg.h	29;"	d
-Reset_Cnt_Limit	include/Hal8188FPhyCfg.h	28;"	d
-Reset_Cnt_Limit	include/Hal8192EPhyCfg.h	29;"	d
-Reset_Cnt_Limit	include/Hal8703BPhyCfg.h	28;"	d
-Reset_Cnt_Limit	include/Hal8723BPhyCfg.h	28;"	d
-Reset_Cnt_Limit	include/Hal8723DPhyCfg.h	28;"	d
-Reset_Cnt_Limit	include/Hal8812PhyCfg.h	29;"	d
-Reset_Cnt_Limit	include/Hal8814PhyCfg.h	29;"	d
-RespTxPath	hal/phydm/phydm_pathdiv.h	/^	u1Byte	RespTxPath;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-ResponseFixedIEs	include/wlan_bssdef.h	/^	NDIS_802_11_AI_RESFI    ResponseFixedIEs;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-ResponseIELength	include/wlan_bssdef.h	/^	ULONG                   ResponseIELength;$/;"	m	struct:_NDIS_802_11_ASSOCIATION_INFORMATION
-ResumeTxBeacon	hal/hal_com.c	/^void ResumeTxBeacon(_adapter *padapter)$/;"	f
-Retry_Counter	hal/phydm/phydm_antdiv.h	/^	u2Byte		Retry_Counter;	$/;"	m	struct:_SW_Antenna_Switch_
-RevisionID	include/drv_types_pci.h	/^	u8	RevisionID;$/;"	m	struct:_PCI_COMMON_CONFIG
-RfKFreeEnable	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte			RfKFreeEnable;		\/*for efuse enable check*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RfKFreeEnable	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte			RfKFreeEnable;		\/*for efuse enable check*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RfKFreeEnable	hal/phydm/phydm_powertracking_win.h	/^	u1Byte			RfKFreeEnable;		\/*for efuse enable check*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RfKFreeEnable	include/hal_data.h	/^	u8	RfKFreeEnable;$/;"	m	struct:hal_com_data
-RfKFree_ch_group	include/hal_data.h	/^	u8	RfKFree_ch_group;$/;"	m	struct:hal_com_data
-RfPathCount	hal/phydm/halphyrf_ap.h	/^	u1Byte 		RfPathCount;$/;"	m	struct:_TXPWRTRACK_CFG
-RfPathCount	hal/phydm/halphyrf_ce.h	/^	u1Byte 		RfPathCount;$/;"	m	struct:_TXPWRTRACK_CFG
-RfPathCount	hal/phydm/halphyrf_win.h	/^	u1Byte 		RfPathCount;$/;"	m	struct:_TXPWRTRACK_CFG
-RfPowerTrackingType	include/hal_data.h	/^	u8	RfPowerTrackingType;$/;"	m	struct:hal_com_data
-RfRegChnlVal	include/hal_data.h	/^	u32	RfRegChnlVal[MAX_RF_PATH];$/;"	m	struct:hal_com_data
-RightAntenna	include/Hal8188EPhyReg.h	1069;"	d
-RightAntenna	include/Hal8188FPhyReg.h	1076;"	d
-RightAntenna	include/Hal8192EPhyReg.h	1083;"	d
-RightAntenna	include/Hal8703BPhyReg.h	1105;"	d
-RightAntenna	include/Hal8723BPhyReg.h	1103;"	d
-RightAntenna	include/Hal8723DPhyReg.h	1106;"	d
-RightAntenna	include/rtw_mp_phy_regdef.h	1040;"	d
-RotR1	core/rtw_security.c	476;"	d	file:
-Rotl	core/rtw_wapi_sms4.c	49;"	d	file:
-RptTime	hal/phydm/phydm_rainfo.h	/^	u2Byte RptTime;$/;"	m	struct:_ODM_RA_Info_
-Rssi	include/wlan_bssdef.h	/^	NDIS_802_11_RSSI  Rssi;\/* (in dBM,raw data ,get from PHY) *\/$/;"	m	struct:_WLAN_BSSID_EX
-RssiHighThresh	hal/phydm/phydm_dig.h	/^	int		    	RssiHighThresh;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-RssiLowThresh	hal/phydm/phydm_dig.h	/^	int		   	RssiLowThresh;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-RssiStaRA	hal/phydm/phydm_rainfo.h	/^	u1Byte RssiStaRA;$/;"	m	struct:_ODM_RA_Info_
-RssiTrigger	include/wlan_bssdef.h	/^		NDIS_802_11_RSSI RssiTrigger;$/;"	m	union:_NDIS_802_11_TEST::__anon70
-RssiTrigger	include/wlan_bssdef.h	/^		NDIS_802_11_RSSI RssiTrigger;$/;"	m	union:_NDIS_802_11_TEST::__anon71
-Rssi_val_min	hal/phydm/phydm_dig.h	/^	u1Byte		Rssi_val_min;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-Rssi_val_min	hal/phydm/phydm_dynamicbbpowersaving.h	/^	int		    Rssi_val_min;$/;"	m	struct:_Dynamic_Power_Saving_
-Rsvd1	include/rtl8188e_hal.h	/^	u16		Rsvd1;$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Rsvd2	include/rtl8188e_hal.h	/^	u8		Rsvd2;$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Rsvd2	include/rtl8188f_hal.h	/^	u16		Rsvd2;$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Rsvd2	include/rtl8703b_hal.h	/^	u16		Rsvd2;$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Rsvd2	include/rtl8723b_hal.h	/^	u16		Rsvd2;$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Rsvd2	include/rtl8723d_hal.h	/^	u16		Rsvd2;$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Rsvd3	include/rtl8188e_hal.h	/^	u32		Rsvd3;$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Rsvd3	include/rtl8188f_hal.h	/^	u32		Rsvd3;$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Rsvd3	include/rtl8703b_hal.h	/^	u32		Rsvd3;$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Rsvd3	include/rtl8723b_hal.h	/^	u32		Rsvd3;$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Rsvd3	include/rtl8723d_hal.h	/^	u32		Rsvd3;$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Rsvd4	include/rtl8188e_hal.h	/^	u32		Rsvd4;$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Rsvd4	include/rtl8188f_hal.h	/^	u32		Rsvd4;$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Rsvd4	include/rtl8703b_hal.h	/^	u32		Rsvd4;$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Rsvd4	include/rtl8723b_hal.h	/^	u32		Rsvd4;$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Rsvd4	include/rtl8723d_hal.h	/^	u32		Rsvd4;$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Rsvd5	include/rtl8188e_hal.h	/^	u32		Rsvd5;$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Rsvd5	include/rtl8188f_hal.h	/^	u32		Rsvd5;$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Rsvd5	include/rtl8703b_hal.h	/^	u32		Rsvd5;$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Rsvd5	include/rtl8723b_hal.h	/^	u32		Rsvd5;$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Rsvd5	include/rtl8723d_hal.h	/^	u32		Rsvd5;$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-RtChDomain	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN		RtChDomain;	$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-RtChDomain	hal/phydm/rtchnlplan.h	/^	RT_CHANNEL_DOMAIN	RtChDomain;$/;"	m	struct:_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE
-RtCtryChnlTbl	hal/phydm/rtchnlplan.c	/^RT_CHNL_CTRY_TBL	RtCtryChnlTbl[] = $/;"	v
-RtInPipe	include/drv_types.h	/^	int	RtInPipe[2];$/;"	m	struct:dvobj_priv
-RtNumInPipes	include/drv_types.h	/^	u8	RtNumInPipes;$/;"	m	struct:dvobj_priv
-RtNumOutPipes	include/drv_types.h	/^	u8	RtNumOutPipes;$/;"	m	struct:dvobj_priv
-RtOutPipe	include/drv_types.h	/^	int	RtOutPipe[4];$/;"	m	struct:dvobj_priv
-Rtl8188E_NIC_DISABLE_FLOW	include/rtl8188e_hal.h	46;"	d
-Rtl8188E_NIC_ENABLE_FLOW	include/rtl8188e_hal.h	47;"	d
-Rtl8188E_NIC_LPS_ENTER_FLOW	include/rtl8188e_hal.h	51;"	d
-Rtl8188E_NIC_LPS_LEAVE_FLOW	include/rtl8188e_hal.h	52;"	d
-Rtl8188E_NIC_PDN_FLOW	include/rtl8188e_hal.h	50;"	d
-Rtl8188E_NIC_PWR_ON_FLOW	include/rtl8188e_hal.h	44;"	d
-Rtl8188E_NIC_RESUME_FLOW	include/rtl8188e_hal.h	49;"	d
-Rtl8188E_NIC_RF_OFF_FLOW	include/rtl8188e_hal.h	45;"	d
-Rtl8188E_NIC_SUSPEND_FLOW	include/rtl8188e_hal.h	48;"	d
-Rtl8192E_NIC_DISABLE_FLOW	include/rtl8192e_hal.h	49;"	d
-Rtl8192E_NIC_ENABLE_FLOW	include/rtl8192e_hal.h	50;"	d
-Rtl8192E_NIC_LPS_ENTER_FLOW	include/rtl8192e_hal.h	54;"	d
-Rtl8192E_NIC_LPS_LEAVE_FLOW	include/rtl8192e_hal.h	55;"	d
-Rtl8192E_NIC_PDN_FLOW	include/rtl8192e_hal.h	53;"	d
-Rtl8192E_NIC_PWR_ON_FLOW	include/rtl8192e_hal.h	47;"	d
-Rtl8192E_NIC_RESUME_FLOW	include/rtl8192e_hal.h	52;"	d
-Rtl8192E_NIC_RF_OFF_FLOW	include/rtl8192e_hal.h	48;"	d
-Rtl8192E_NIC_SUSPEND_FLOW	include/rtl8192e_hal.h	51;"	d
-Rtl8812_NIC_DISABLE_FLOW	include/rtl8812a_hal.h	47;"	d
-Rtl8812_NIC_ENABLE_FLOW	include/rtl8812a_hal.h	48;"	d
-Rtl8812_NIC_LPS_ENTER_FLOW	include/rtl8812a_hal.h	52;"	d
-Rtl8812_NIC_LPS_LEAVE_FLOW	include/rtl8812a_hal.h	53;"	d
-Rtl8812_NIC_PDN_FLOW	include/rtl8812a_hal.h	51;"	d
-Rtl8812_NIC_PWR_ON_FLOW	include/rtl8812a_hal.h	45;"	d
-Rtl8812_NIC_RESUME_FLOW	include/rtl8812a_hal.h	50;"	d
-Rtl8812_NIC_RF_OFF_FLOW	include/rtl8812a_hal.h	46;"	d
-Rtl8812_NIC_SUSPEND_FLOW	include/rtl8812a_hal.h	49;"	d
-Rtl8814A_NIC_DISABLE_FLOW	include/rtl8814a_hal.h	63;"	d
-Rtl8814A_NIC_ENABLE_FLOW	include/rtl8814a_hal.h	64;"	d
-Rtl8814A_NIC_LPS_ENTER_FLOW	include/rtl8814a_hal.h	68;"	d
-Rtl8814A_NIC_LPS_LEAVE_FLOW	include/rtl8814a_hal.h	69;"	d
-Rtl8814A_NIC_PDN_FLOW	include/rtl8814a_hal.h	67;"	d
-Rtl8814A_NIC_PWR_ON_FLOW	include/rtl8814a_hal.h	61;"	d
-Rtl8814A_NIC_RESUME_FLOW	include/rtl8814a_hal.h	66;"	d
-Rtl8814A_NIC_RF_OFF_FLOW	include/rtl8814a_hal.h	62;"	d
-Rtl8814A_NIC_SUSPEND_FLOW	include/rtl8814a_hal.h	65;"	d
-Rtl8821A_NIC_DISABLE_FLOW	include/rtl8812a_hal.h	60;"	d
-Rtl8821A_NIC_ENABLE_FLOW	include/rtl8812a_hal.h	61;"	d
-Rtl8821A_NIC_LPS_ENTER_FLOW	include/rtl8812a_hal.h	65;"	d
-Rtl8821A_NIC_LPS_LEAVE_FLOW	include/rtl8812a_hal.h	66;"	d
-Rtl8821A_NIC_PDN_FLOW	include/rtl8812a_hal.h	64;"	d
-Rtl8821A_NIC_PWR_ON_FLOW	include/rtl8812a_hal.h	58;"	d
-Rtl8821A_NIC_RESUME_FLOW	include/rtl8812a_hal.h	63;"	d
-Rtl8821A_NIC_RF_OFF_FLOW	include/rtl8812a_hal.h	59;"	d
-Rtl8821A_NIC_SUSPEND_FLOW	include/rtl8812a_hal.h	62;"	d
-RtsThres	hal/phydm/phydm_rainfo.h	/^	u1Byte				RtsThres;$/;"	m	struct:_ODM_RATE_ADAPTIVE
-Rtw_MPSetMacTxEDCA	core/rtw_mp.c	/^static void Rtw_MPSetMacTxEDCA(PADAPTER padapter)$/;"	f	file:
-RunInThread_param	include/rtw_cmd.h	/^struct RunInThread_param {$/;"	s
-RxBufPoolHdl	include/rtw_recv.h	/^	_nic_hdl  RxBufPoolHdl;$/;"	m	struct:recv_priv
-RxCount	hal/phydm/phydm.h	/^	u1Byte		RxCount:2;					\/* RX path counter---*\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxCount	include/rtw_recv.h	/^	u8			RxCount:2;$/;"	m	struct:phy_info
-RxEVM	hal/phydm/phydm.h	/^	s4Byte		RxEVM[4];	$/;"	m	struct:_ODM_Phy_Dbg_Info_
-RxGainOffset	include/hal_data.h	/^	u32 RxGainOffset[4]; \/*{2G, 5G_Low, 5G_Middle, G_High}*\/$/;"	m	struct:hal_com_data
-RxIQC_8703B	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	RxIQC_8703B[2][2];	\/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIQC_8703B	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	RxIQC_8703B[2][2];	\/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIQC_8703B	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	RxIQC_8703B[2][2];	\/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIQC_8723B	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	RxIQC_8723B[2][2][2]; \/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIQC_8723B	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	RxIQC_8723B[2][2][2]; \/\/ { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIQC_8723B	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	RxIQC_8723B[2][2][2]; \/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}} *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIQC_8723D	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	RxIQC_8723D[2][2][2];	\/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIQC_8723D	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	RxIQC_8723D[2][2][2];	\/* { {S1: 0xc14, 0xca0} ,           {S0: 0xc14, 0xca0}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-RxIdleAnt	hal/phydm/phydm_antdiv.h	/^	u1Byte	RxIdleAnt;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-RxMIMOEVMdbm	hal/phydm/phydm.h	/^	u1Byte		RxMIMOEVMdbm[4];			\/* per-path's EVM dbm *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxMIMOEVMdbm	include/rtw_recv.h	/^	u8			RxMIMOEVMdbm[4];			\/* per-path's EVM dbm *\/$/;"	m	struct:phy_info
-RxMIMOSignalQuality	hal/phydm/phydm.h	/^	s1Byte		RxMIMOSignalQuality[4];		\/* EVM *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxMIMOSignalQuality	hal/phydm/phydm.h	/^	s1Byte		RxMIMOSignalQuality[4];		\/* per-path's EVM *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxMIMOSignalQuality	include/rtw_recv.h	/^	s8			RxMIMOSignalQuality[4];		\/* per-path's EVM *\/$/;"	m	struct:phy_info
-RxMIMOSignalStrength	hal/phydm/phydm.h	/^	u1Byte		RxMIMOSignalStrength[4];		\/* in 0~100 index *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxMIMOSignalStrength	hal/phydm/phydm.h	/^	u1Byte		RxMIMOSignalStrength[4];	\/* in 0~100 index *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxMIMOSignalStrength	include/rtw_recv.h	/^	u8			RxMIMOSignalStrength[4];	\/* in 0~100 index *\/$/;"	m	struct:phy_info
-RxMgmtFrameSeqNum	include/sta_info.h	/^	u16 RxMgmtFrameSeqNum;$/;"	m	struct:sta_info
-RxPWDBAll	hal/phydm/phydm.h	/^	u1Byte		RxPWDBAll;$/;"	m	struct:_ODM_Phy_Status_Info_
-RxPWDBAll	hal/phydm/phydm.h	/^	u4Byte		RxPWDBAll;	$/;"	m	struct:_ODM_Phy_Status_Info_
-RxPWDBAll	include/rtw_mlme.h	/^	u8		RxPWDBAll;$/;"	m	struct:tdls_ss_record
-RxPWDBAll	include/rtw_recv.h	/^	u8			RxPWDBAll;$/;"	m	struct:phy_info
-RxPWDBAve	hal/phydm/phydm.h	/^	u4Byte			RxPWDBAve;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RxPktPoolHdl	include/rtw_recv.h	/^	_nic_hdl  RxPktPoolHdl;$/;"	m	struct:recv_priv
-RxPower	hal/phydm/phydm.h	/^	s1Byte		RxPower;					\/* in dBm Translate from PWdB *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxPower	include/rtw_recv.h	/^	s8			RxPower;					\/* in dBm Translate from PWdB *\/$/;"	m	struct:phy_info
-RxPwr	hal/phydm/phydm.h	/^	s1Byte		RxPwr[4];					\/* per-path's pwdb *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxPwr	include/rtw_recv.h	/^	s8			RxPwr[4];					\/* per-path's pwdb *\/$/;"	m	struct:phy_info
-RxRate	hal/phydm/phydm.h	/^	u1Byte			RxRate;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-RxSNR	hal/phydm/phydm.h	/^	s1Byte		RxSNR[4];					\/* per-path's SNR	*\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxSNR	hal/phydm/phydm.h	/^	s1Byte		RxSNR[4];					\/* per-path's SNR *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-RxSNR	include/rtw_recv.h	/^	s8			RxSNR[4];$/;"	m	struct:phy_info
-RxSNRdB	hal/phydm/phydm.h	/^	s1Byte		RxSNRdB[4];$/;"	m	struct:_ODM_Phy_Dbg_Info_
-RxTag	include/hal_data.h	/^	u16			RxTag;$/;"	m	struct:hal_com_data
-Rx_Smooth_Factor	include/rtl8188e_recv.h	64;"	d
-Rx_Smooth_Factor	include/rtl8188f_recv.h	52;"	d
-Rx_Smooth_Factor	include/rtl8192e_recv.h	63;"	d
-Rx_Smooth_Factor	include/rtl8703b_recv.h	64;"	d
-Rx_Smooth_Factor	include/rtl8723b_recv.h	64;"	d
-Rx_Smooth_Factor	include/rtl8723d_recv.h	64;"	d
-Rx_Smooth_Factor	include/rtl8812a_recv.h	66;"	d
-Rx_Smooth_Factor	include/rtl8814a_recv.h	169;"	d
-Rx_Smooth_Factor	include/rtl8822b_hal.h	183;"	d
-S	include/rtw_security.h	438;"	d
-S0S1_SW_ANTDIV	hal/phydm/phydm_antdiv.h	/^	S0S1_SW_ANTDIV          = 0x06, \/*8723B intrnal switch S0 S1*\/$/;"	e	enum:_ANT_DIV_TYPE
-S0S1_TRX_HW_ANTDIV	hal/phydm/phydm_antdiv.h	/^	S0S1_TRX_HW_ANTDIV     = 0x07, \/*TRX S0S1 diversity for 8723D*\/$/;"	e	enum:_ANT_DIV_TYPE
-SAT_T	hal/phydm/phydm_antdiv.h	/^} SAT_T, *pSAT_T;$/;"	t	typeref:struct:_SMART_ANTENNA_TRAINNING_
-SCA	include/ieee80211.h	/^	SCA = 1, \/* secondary channel above *\/$/;"	e	enum:secondary_ch_offset
-SCANNING_TIMEOUT	include/rtw_mlme.h	32;"	d
-SCANQUEUE_LIFETIME	include/rtw_mlme.h	39;"	d
-SCANQUEUE_LIFETIME	include/rtw_mlme.h	41;"	d
-SCAN_ACT	hal/phydm/rtchnlplan.h	/^	SCAN_ACT,$/;"	e	enum:_RT_SCAN_TYPE_NEW
-SCAN_ACTIVE	include/rtw_mlme.h	/^	SCAN_ACTIVE,$/;"	e	enum:_RT_SCAN_TYPE
-SCAN_BACKING_OP	include/rtw_mlme_ext.h	/^	SCAN_BACKING_OP = 5,$/;"	e	enum:SCAN_STATE
-SCAN_BACK_OP	include/rtw_mlme_ext.h	/^	SCAN_BACK_OP = 6,$/;"	e	enum:SCAN_STATE
-SCAN_BOTH	hal/phydm/rtchnlplan.h	/^	SCAN_BOTH,$/;"	e	enum:_RT_SCAN_TYPE_NEW
-SCAN_COMPLETE	include/rtw_mlme_ext.h	/^	SCAN_COMPLETE = 12,$/;"	e	enum:SCAN_STATE
-SCAN_DISABLE	include/rtw_mlme_ext.h	/^	SCAN_DISABLE = 0,$/;"	e	enum:SCAN_STATE
-SCAN_ENTER	include/rtw_mlme_ext.h	/^	SCAN_ENTER = 3,$/;"	e	enum:SCAN_STATE
-SCAN_FLAGS_HDR_LEN	os_dep/linux/rtw_cfgvendor.h	35;"	d
-SCAN_ID_HDR_LEN	os_dep/linux/rtw_cfgvendor.h	34;"	d
-SCAN_INDEX_HDR_LEN	os_dep/linux/rtw_cfgvendor.h	33;"	d
-SCAN_ITEM_SIZE	os_dep/linux/ioctl_linux.c	39;"	d	file:
-SCAN_LEAVE_OP	include/rtw_mlme_ext.h	/^	SCAN_LEAVE_OP = 8,$/;"	e	enum:SCAN_STATE
-SCAN_LEAVING_OP	include/rtw_mlme_ext.h	/^	SCAN_LEAVING_OP = 7,$/;"	e	enum:SCAN_STATE
-SCAN_MIX	include/rtw_mlme.h	/^	SCAN_MIX,$/;"	e	enum:_RT_SCAN_TYPE
-SCAN_NULL	hal/phydm/rtchnlplan.h	/^	SCAN_NULL,$/;"	e	enum:_RT_SCAN_TYPE_NEW
-SCAN_P2P_LISTEN	include/rtw_mlme_ext.h	/^	SCAN_P2P_LISTEN = 11,$/;"	e	enum:SCAN_STATE
-SCAN_PARAM_INPUT_ARG	core/rtw_debug.c	1055;"	d	file:
-SCAN_PARAM_INPUT_ARG_BACKOP	core/rtw_debug.c	1069;"	d	file:
-SCAN_PARAM_INPUT_ARG_HT	core/rtw_debug.c	1060;"	d	file:
-SCAN_PARAM_INPUT_FMT	core/rtw_debug.c	1054;"	d	file:
-SCAN_PARAM_INPUT_FMT_BACKOP	core/rtw_debug.c	1068;"	d	file:
-SCAN_PARAM_INPUT_FMT_HT	core/rtw_debug.c	1059;"	d	file:
-SCAN_PARAM_TITLE_ARG	core/rtw_debug.c	996;"	d	file:
-SCAN_PARAM_TITLE_ARG_BACKOP	core/rtw_debug.c	1012;"	d	file:
-SCAN_PARAM_TITLE_ARG_HT	core/rtw_debug.c	1001;"	d	file:
-SCAN_PARAM_TITLE_FMT	core/rtw_debug.c	994;"	d	file:
-SCAN_PARAM_TITLE_FMT_BACKOP	core/rtw_debug.c	1010;"	d	file:
-SCAN_PARAM_TITLE_FMT_HT	core/rtw_debug.c	999;"	d	file:
-SCAN_PARAM_VALUE_ARG	core/rtw_debug.c	997;"	d	file:
-SCAN_PARAM_VALUE_ARG_BACKOP	core/rtw_debug.c	1013;"	d	file:
-SCAN_PARAM_VALUE_ARG_HT	core/rtw_debug.c	1002;"	d	file:
-SCAN_PARAM_VALUE_FMT	core/rtw_debug.c	995;"	d	file:
-SCAN_PARAM_VALUE_FMT_BACKOP	core/rtw_debug.c	1011;"	d	file:
-SCAN_PARAM_VALUE_FMT_HT	core/rtw_debug.c	1000;"	d	file:
-SCAN_PAS	hal/phydm/rtchnlplan.h	/^	SCAN_PAS,$/;"	e	enum:_RT_SCAN_TYPE_NEW
-SCAN_PASSIVE	include/rtw_mlme.h	/^	SCAN_PASSIVE,$/;"	e	enum:_RT_SCAN_TYPE
-SCAN_PROCESS	include/rtw_mlme_ext.h	/^	SCAN_PROCESS = 4,$/;"	e	enum:SCAN_STATE
-SCAN_PS_ANNC_WAIT	include/rtw_mlme_ext.h	/^	SCAN_PS_ANNC_WAIT = 2,$/;"	e	enum:SCAN_STATE
-SCAN_RESULTS_COMPLETE_FLAG_LEN	os_dep/linux/rtw_cfgvendor.h	32;"	d
-SCAN_RESULT_ALL	include/rtw_mlme.h	/^	SCAN_RESULT_ALL = 1,			\/*	Will return all the scanned device, include AP. *\/$/;"	e	enum:SCAN_RESULT_TYPE
-SCAN_RESULT_P2P_ONLY	include/rtw_mlme.h	/^	SCAN_RESULT_P2P_ONLY = 0,		\/*	Will return all the P2P devices. *\/$/;"	e	enum:SCAN_RESULT_TYPE
-SCAN_RESULT_TYPE	include/rtw_mlme.h	/^enum SCAN_RESULT_TYPE {$/;"	g
-SCAN_RESULT_WFD_TYPE	include/rtw_mlme.h	/^	SCAN_RESULT_WFD_TYPE = 2		\/*	Will just return the correct WFD device. *\/$/;"	e	enum:SCAN_RESULT_TYPE
-SCAN_SPARSE_CH_NUM_INVALID	core/rtw_mlme_ext.c	13528;"	d	file:
-SCAN_START	include/rtw_mlme_ext.h	/^	SCAN_START = 1,$/;"	e	enum:SCAN_STATE
-SCAN_STATE	include/rtw_mlme_ext.h	/^enum SCAN_STATE {$/;"	g
-SCAN_STATE_MAX	include/rtw_mlme_ext.h	/^	SCAN_STATE_MAX,$/;"	e	enum:SCAN_STATE
-SCAN_SW_ANTDIV_BL	include/rtw_mlme_ext.h	/^	SCAN_SW_ANTDIV_BL = 9,$/;"	e	enum:SCAN_STATE
-SCAN_TO_P2P_LISTEN	include/rtw_mlme_ext.h	/^	SCAN_TO_P2P_LISTEN = 10,$/;"	e	enum:SCAN_STATE
-SCB	include/ieee80211.h	/^	SCB = 3,  \/* secondary channel below *\/$/;"	e	enum:secondary_ch_offset
-SCHEDULE_EN	include/hal_com_reg.h	1320;"	d
-SCMapping_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^u8	SCMapping_8723D(PADAPTER Adapter, struct pkt_attrib *pattrib)$/;"	f
-SCN	include/ieee80211.h	/^	SCN = 0, \/* no secondary channel *\/$/;"	e	enum:secondary_ch_offset
-SCR_CHK_BMC	include/hal_com_reg.h	1582;"	d
-SCR_CHK_KEYID	include/hal_com_reg.h	1581;"	d
-SCR_NoSKMC	include/hal_com_reg.h	1578;"	d
-SCR_RXBCUSEDK	include/hal_com_reg.h	1580;"	d
-SCR_RxDecEnable	include/hal_com_reg.h	1576;"	d
-SCR_RxUseDK	include/hal_com_reg.h	1574;"	d
-SCR_SKByA2	include/hal_com_reg.h	1577;"	d
-SCR_TXBCUSEDK	include/hal_com_reg.h	1579;"	d
-SCR_TxEncEnable	include/hal_com_reg.h	1575;"	d
-SCR_TxUseDK	include/hal_com_reg.h	1573;"	d
-SC_DONT_CARE	include/rtw_xmit.h	/^	SC_DONT_CARE = 0x00,$/;"	e	enum:TXDESC_SC
-SC_DUPLICATE	include/rtw_xmit.h	/^	SC_DUPLICATE = 0x03$/;"	e	enum:TXDESC_SC
-SC_LOWER	include/rtw_xmit.h	/^	SC_LOWER = 0x02,$/;"	e	enum:TXDESC_SC
-SC_UPPER	include/rtw_xmit.h	/^	SC_UPPER = 0x01,$/;"	e	enum:TXDESC_SC
-SDBUS_DRIVER_VERSION_1	include/drv_types_xp.h	49;"	d
-SDBUS_DRIVER_VERSION_2	include/drv_types_xp.h	50;"	d
-SDIOID	platform/platform_ARM_SUNxI_sdio.c	24;"	d	file:
-SDIOID	platform/platform_ARM_SUNxI_sdio.c	26;"	d	file:
-SDIO_DATA	include/drv_types_sdio.h	/^} SDIO_DATA, *PSDIO_DATA;$/;"	t	typeref:struct:sdio_data
-SDIO_ERR_VAL16	include/sdio_ops.h	26;"	d
-SDIO_ERR_VAL32	include/sdio_ops.h	27;"	d
-SDIO_ERR_VAL8	include/sdio_ops.h	25;"	d
-SDIO_HIMR_ATIMEND_E_MSK	include/hal_com_reg.h	1674;"	d
-SDIO_HIMR_ATIMEND_MSK	include/hal_com_reg.h	1673;"	d
-SDIO_HIMR_AVAL_MSK	include/hal_com_reg.h	1657;"	d
-SDIO_HIMR_BCNERLY_INT_MSK	include/hal_com_reg.h	1664;"	d
-SDIO_HIMR_C2HCMD_MSK	include/hal_com_reg.h	1665;"	d
-SDIO_HIMR_CPWM1_MSK	include/hal_com_reg.h	1666;"	d
-SDIO_HIMR_CPWM2_MSK	include/hal_com_reg.h	1667;"	d
-SDIO_HIMR_CTWEND_MSK	include/hal_com_reg.h	1675;"	d
-SDIO_HIMR_DISABLED	include/hal_com_reg.h	1653;"	d
-SDIO_HIMR_GTINT3_IND_MSK	include/hal_com_reg.h	1669;"	d
-SDIO_HIMR_GTINT4_IND_MSK	include/hal_com_reg.h	1670;"	d
-SDIO_HIMR_HSISR_IND_MSK	include/hal_com_reg.h	1668;"	d
-SDIO_HIMR_MCU_ERR_MSK	include/hal_com_reg.h	1678;"	d
-SDIO_HIMR_OCPINT_MSK	include/hal_com_reg.h	1672;"	d
-SDIO_HIMR_PSTIMEOUT_MSK	include/hal_com_reg.h	1671;"	d
-SDIO_HIMR_RXERR_MSK	include/hal_com_reg.h	1659;"	d
-SDIO_HIMR_RXFOVW_MSK	include/hal_com_reg.h	1661;"	d
-SDIO_HIMR_RX_REQUEST_MSK	include/hal_com_reg.h	1656;"	d
-SDIO_HIMR_TSF_BIT32_TOGGLE_MSK	include/hal_com_reg.h	1679;"	d
-SDIO_HIMR_TXBCNERR_MSK	include/hal_com_reg.h	1663;"	d
-SDIO_HIMR_TXBCNOK_MSK	include/hal_com_reg.h	1662;"	d
-SDIO_HIMR_TXERR_MSK	include/hal_com_reg.h	1658;"	d
-SDIO_HIMR_TXFOVW_MSK	include/hal_com_reg.h	1660;"	d
-SDIO_HISR_ATIMEND	include/hal_com_reg.h	1699;"	d
-SDIO_HISR_ATIMEND_E	include/hal_com_reg.h	1700;"	d
-SDIO_HISR_AVAL	include/hal_com_reg.h	1683;"	d
-SDIO_HISR_BCNERLY_INT	include/hal_com_reg.h	1690;"	d
-SDIO_HISR_C2HCMD	include/hal_com_reg.h	1691;"	d
-SDIO_HISR_CPWM1	include/hal_com_reg.h	1692;"	d
-SDIO_HISR_CPWM2	include/hal_com_reg.h	1693;"	d
-SDIO_HISR_CTWEND	include/hal_com_reg.h	1701;"	d
-SDIO_HISR_GTINT3_IND	include/hal_com_reg.h	1695;"	d
-SDIO_HISR_GTINT4_IND	include/hal_com_reg.h	1696;"	d
-SDIO_HISR_HSISR_IND	include/hal_com_reg.h	1694;"	d
-SDIO_HISR_MCU_ERR	include/hal_com_reg.h	1704;"	d
-SDIO_HISR_OCPINT	include/hal_com_reg.h	1698;"	d
-SDIO_HISR_PSTIMEOUT	include/hal_com_reg.h	1697;"	d
-SDIO_HISR_RXERR	include/hal_com_reg.h	1685;"	d
-SDIO_HISR_RXFOVW	include/hal_com_reg.h	1687;"	d
-SDIO_HISR_RX_REQUEST	include/hal_com_reg.h	1682;"	d
-SDIO_HISR_TSF_BIT32_TOGGLE	include/hal_com_reg.h	1705;"	d
-SDIO_HISR_TXBCNERR	include/hal_com_reg.h	1689;"	d
-SDIO_HISR_TXBCNOK	include/hal_com_reg.h	1688;"	d
-SDIO_HISR_TXERR	include/hal_com_reg.h	1684;"	d
-SDIO_HISR_TXFOVW	include/hal_com_reg.h	1686;"	d
-SDIO_LOCAL_BASE	include/hal_com_reg.h	1602;"	d
-SDIO_LOCAL_DEVICE_ID	include/hal_com_reg.h	1618;"	d
-SDIO_LOCAL_MSK	include/hal_com_reg.h	1612;"	d
-SDIO_MAX_RX_QUEUE	include/hal_com_reg.h	1633;"	d
-SDIO_MAX_TX_QUEUE	include/hal_com_reg.h	1632;"	d
-SDIO_REG_AC_OQT_FREEPG_8188F	include/rtl8188f_spec.h	152;"	d
-SDIO_REG_EXQ_FREEPG_8188F	include/rtl8188f_spec.h	151;"	d
-SDIO_REG_FREE_TXPG	include/hal_com_reg.h	1641;"	d
-SDIO_REG_FREE_TXPG2	include/rtl8821a_spec.h	88;"	d
-SDIO_REG_FREE_TXPG_SEQ	include/hal_com_reg.h	1644;"	d
-SDIO_REG_HCPWM	include/hal_com_reg.h	1638;"	d
-SDIO_REG_HCPWM1	include/hal_com_reg.h	1642;"	d
-SDIO_REG_HCPWM1	include/rtl8821a_spec.h	87;"	d
-SDIO_REG_HCPWM1	include/rtl8821a_spec.h	89;"	d
-SDIO_REG_HCPWM1_8188F	include/rtl8188f_spec.h	155;"	d
-SDIO_REG_HCPWM1_8703B	include/rtl8703b_spec.h	368;"	d
-SDIO_REG_HCPWM1_8723B	include/rtl8723b_spec.h	147;"	d
-SDIO_REG_HCPWM1_8723D	include/rtl8723d_spec.h	404;"	d
-SDIO_REG_HCPWM2	include/hal_com_reg.h	1643;"	d
-SDIO_REG_HIMR	include/hal_com_reg.h	1636;"	d
-SDIO_REG_HIMR_ON	include/hal_com_reg.h	1650;"	d
-SDIO_REG_HIQ_FREEPG_8188F	include/rtl8188f_spec.h	147;"	d
-SDIO_REG_HISR	include/hal_com_reg.h	1637;"	d
-SDIO_REG_HISR_ON	include/hal_com_reg.h	1651;"	d
-SDIO_REG_HPS_CLKR	include/hal_com_reg.h	1648;"	d
-SDIO_REG_HRPWM1	include/hal_com_reg.h	1646;"	d
-SDIO_REG_HRPWM2	include/hal_com_reg.h	1647;"	d
-SDIO_REG_HSUS_CTRL	include/hal_com_reg.h	1649;"	d
-SDIO_REG_HTSFR_INFO	include/hal_com_reg.h	1645;"	d
-SDIO_REG_INDIRECT_REG_CFG_8188F	include/rtl8188f_spec.h	158;"	d
-SDIO_REG_INDIRECT_REG_DATA_8188F	include/rtl8188f_spec.h	167;"	d
-SDIO_REG_LOW_FREEPG_8188F	include/rtl8188f_spec.h	149;"	d
-SDIO_REG_MID_FREEPG_8188F	include/rtl8188f_spec.h	148;"	d
-SDIO_REG_NOAC_OQT_FREEPG_8188F	include/rtl8188f_spec.h	153;"	d
-SDIO_REG_OQT_FREE_PG	include/hal_com_reg.h	1640;"	d
-SDIO_REG_PUB_FREEPG_8188F	include/rtl8188f_spec.h	150;"	d
-SDIO_REG_RX0_REQ_LEN	include/hal_com_reg.h	1639;"	d
-SDIO_REG_TX_CTRL	include/hal_com_reg.h	1635;"	d
-SDIO_TX_AGG_MAX	include/rtw_xmit.h	30;"	d
-SDIO_TX_FIFO_PAGE_SZ	include/hal_com_reg.h	1728;"	d
-SDIO_TX_FREE_PG_QUEUE	include/hal_com_reg.h	1727;"	d
-SDIO_WITHOUT_REF_DEVICE_ID	include/hal_com_reg.h	1617;"	d
-SDP_BUS_CLOCK	include/drv_types_xp.h	55;"	d
-SDP_BUS_DRIVER_VERSION	include/drv_types_xp.h	53;"	d
-SDP_BUS_INTERFACE_CONTROL	include/drv_types_xp.h	56;"	d
-SDP_BUS_WIDTH	include/drv_types_xp.h	54;"	d
-SDP_FN0_BLOCK_LENGTH	include/drv_types_xp.h	59;"	d
-SDP_FUNCTION_BLOCK_LENGTH	include/drv_types_xp.h	58;"	d
-SDP_FUNCTION_INT_ENABLE	include/drv_types_xp.h	60;"	d
-SDP_FUNCTION_TYPE	include/drv_types_xp.h	52;"	d
-SDP_HOST_BLOCK_LENGTH	include/drv_types_xp.h	57;"	d
-SD_IO_TRY_CNT	include/rtw_io.h	318;"	d
-SD_IO_TRY_CNT	include/rtw_io.h	323;"	d
-SECR	include/hal_com_reg.h	584;"	d
-SECR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	458;"	d
-SECR_8814A	include/rtl8814a_spec.h	557;"	d
-SEC_ACTIVE_KEY	include/ieee80211.h	1090;"	d
-SEC_AUTH_MODE	include/ieee80211.h	1091;"	d
-SEC_CAM_ACCESS_TIMEOUT_MS	hal/hal_com.c	1854;"	d	file:
-SEC_CAM_ENT_ID_TITLE_ARG	core/rtw_debug.c	553;"	d	file:
-SEC_CAM_ENT_ID_TITLE_FMT	core/rtw_debug.c	552;"	d	file:
-SEC_CAM_ENT_ID_VALUE_ARG	core/rtw_debug.c	555;"	d	file:
-SEC_CAM_ENT_ID_VALUE_FMT	core/rtw_debug.c	554;"	d	file:
-SEC_CAM_ENT_NUM_8188F	include/rtl8188f_spec.h	296;"	d
-SEC_CAM_ENT_NUM_8192E	include/rtl8192e_spec.h	322;"	d
-SEC_CAM_ENT_NUM_8703B	include/rtl8703b_spec.h	473;"	d
-SEC_CAM_ENT_NUM_8723B	include/rtl8723b_spec.h	289;"	d
-SEC_CAM_ENT_NUM_8723D	include/rtl8723d_spec.h	450;"	d
-SEC_CAM_ENT_NUM_8812A	include/rtl8812a_spec.h	265;"	d
-SEC_CAM_ENT_NUM_8814A	include/rtl8814a_spec.h	644;"	d
-SEC_CAM_ENT_NUM_8821A	include/rtl8821a_spec.h	101;"	d
-SEC_CAM_ENT_NUM_88E	include/rtl8188e_spec.h	151;"	d
-SEC_CAM_ENT_NUM_SW_LIMIT	include/drv_conf.h	279;"	d
-SEC_CAM_ENT_TITLE_ARG	core/rtw_debug.c	558;"	d	file:
-SEC_CAM_ENT_TITLE_FMT	core/rtw_debug.c	557;"	d	file:
-SEC_CAM_ENT_VALUE_ARG	core/rtw_debug.c	560;"	d	file:
-SEC_CAM_ENT_VALUE_FMT	core/rtw_debug.c	559;"	d	file:
-SEC_CAP_CHK_BMC	include/drv_types.h	675;"	d
-SEC_ENABLED	include/ieee80211.h	1094;"	d
-SEC_KEY_1	include/ieee80211.h	1086;"	d
-SEC_KEY_2	include/ieee80211.h	1087;"	d
-SEC_KEY_3	include/ieee80211.h	1088;"	d
-SEC_KEY_4	include/ieee80211.h	1089;"	d
-SEC_LEVEL	include/ieee80211.h	1093;"	d
-SEC_LEVEL_0	include/ieee80211.h	1096;"	d
-SEC_LEVEL_1	include/ieee80211.h	1097;"	d
-SEC_LEVEL_2	include/ieee80211.h	1098;"	d
-SEC_LEVEL_2_CKIP	include/ieee80211.h	1099;"	d
-SEC_LEVEL_3	include/ieee80211.h	1100;"	d
-SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH	include/drv_types.h	677;"	d
-SEC_TYPE_SHT	include/rtl8188e_xmit.h	55;"	d
-SEC_TYPE_SHT	include/rtl8192e_xmit.h	160;"	d
-SEC_TYPE_SHT	include/rtl8812a_xmit.h	53;"	d
-SEC_UNICAST_GROUP	include/ieee80211.h	1092;"	d
-SEMA_UPBND	include/osdep_service_ce.h	68;"	d
-SEMA_UPBND	include/osdep_service_xp.h	69;"	d
-SEQ_SHT	include/rtl8188e_xmit.h	69;"	d
-SEQ_SHT	include/rtl8192e_xmit.h	174;"	d
-SEQ_SHT	include/rtl8812a_xmit.h	67;"	d
-SERVER_PORT	core/rtw_br_ext.c	1495;"	d	file:
-SESSION_TRACKER_ARG	core/rtw_sta_mgt.c	137;"	d	file:
-SESSION_TRACKER_FMT	core/rtw_sta_mgt.c	136;"	d	file:
-SESSION_TRACKER_REG_ID_NUM	include/sta_info.h	163;"	d
-SESSION_TRACKER_REG_ID_WFD	include/sta_info.h	162;"	d
-SESSION_TRACKER_WK_CID	include/rtw_cmd.h	/^	SESSION_TRACKER_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-SETPWRMODE_PARM	include/rtl8188e_cmd.h	/^} SETPWRMODE_PARM, *PSETPWRMODE_PARM;$/;"	t	typeref:struct:_SETPWRMODE_PARM
-SETPWRMODE_PARM	include/rtl8192e_cmd.h	/^} SETPWRMODE_PARM, *PSETPWRMODE_PARM;$/;"	t	typeref:struct:_SETPWRMODE_PARM
-SET_8188F_H2CCMD_APREQRPT_PARM_MACID1	include/rtl8188f_cmd.h	152;"	d
-SET_8188F_H2CCMD_APREQRPT_PARM_MACID2	include/rtl8188f_cmd.h	153;"	d
-SET_8188F_H2CCMD_BT_FW_PATCH_ADDR0	include/rtl8188f_cmd.h	168;"	d
-SET_8188F_H2CCMD_BT_FW_PATCH_ADDR1	include/rtl8188f_cmd.h	169;"	d
-SET_8188F_H2CCMD_BT_FW_PATCH_ADDR2	include/rtl8188f_cmd.h	170;"	d
-SET_8188F_H2CCMD_BT_FW_PATCH_ADDR3	include/rtl8188f_cmd.h	171;"	d
-SET_8188F_H2CCMD_BT_FW_PATCH_SIZE	include/rtl8188f_cmd.h	167;"	d
-SET_8188F_H2CCMD_BT_MPOPER_IDX	include/rtl8188f_cmd.h	161;"	d
-SET_8188F_H2CCMD_BT_MPOPER_PARAM1	include/rtl8188f_cmd.h	162;"	d
-SET_8188F_H2CCMD_BT_MPOPER_PARAM2	include/rtl8188f_cmd.h	163;"	d
-SET_8188F_H2CCMD_BT_MPOPER_PARAM3	include/rtl8188f_cmd.h	164;"	d
-SET_8188F_H2CCMD_BT_MPOPER_REQNUM	include/rtl8188f_cmd.h	160;"	d
-SET_8188F_H2CCMD_BT_MPOPER_VER	include/rtl8188f_cmd.h	159;"	d
-SET_8188F_H2CCMD_BT_PWR_IDX	include/rtl8188f_cmd.h	156;"	d
-SET_8188F_H2CCMD_DISCONDECISION_PARM_ADOPT	include/rtl8188f_cmd.h	109;"	d
-SET_8188F_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD	include/rtl8188f_cmd.h	110;"	d
-SET_8188F_H2CCMD_DISCONDECISION_PARM_ENABLE	include/rtl8188f_cmd.h	108;"	d
-SET_8188F_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM	include/rtl8188f_cmd.h	111;"	d
-SET_8188F_H2CCMD_KEEPALIVE_PARM_ADOPT	include/rtl8188f_cmd.h	103;"	d
-SET_8188F_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD	include/rtl8188f_cmd.h	105;"	d
-SET_8188F_H2CCMD_KEEPALIVE_PARM_ENABLE	include/rtl8188f_cmd.h	102;"	d
-SET_8188F_H2CCMD_KEEPALIVE_PARM_PKT_TYPE	include/rtl8188f_cmd.h	104;"	d
-SET_8188F_H2CCMD_MACID_CFG_BW	include/rtl8188f_cmd.h	136;"	d
-SET_8188F_H2CCMD_MACID_CFG_DISPT	include/rtl8188f_cmd.h	139;"	d
-SET_8188F_H2CCMD_MACID_CFG_DISRA	include/rtl8188f_cmd.h	140;"	d
-SET_8188F_H2CCMD_MACID_CFG_MACID	include/rtl8188f_cmd.h	133;"	d
-SET_8188F_H2CCMD_MACID_CFG_NO_UPDATE	include/rtl8188f_cmd.h	137;"	d
-SET_8188F_H2CCMD_MACID_CFG_RAID	include/rtl8188f_cmd.h	134;"	d
-SET_8188F_H2CCMD_MACID_CFG_RATE_MASK0	include/rtl8188f_cmd.h	141;"	d
-SET_8188F_H2CCMD_MACID_CFG_RATE_MASK1	include/rtl8188f_cmd.h	142;"	d
-SET_8188F_H2CCMD_MACID_CFG_RATE_MASK2	include/rtl8188f_cmd.h	143;"	d
-SET_8188F_H2CCMD_MACID_CFG_RATE_MASK3	include/rtl8188f_cmd.h	144;"	d
-SET_8188F_H2CCMD_MACID_CFG_SGI_EN	include/rtl8188f_cmd.h	135;"	d
-SET_8188F_H2CCMD_MACID_CFG_VHT_EN	include/rtl8188f_cmd.h	138;"	d
-SET_8188F_H2CCMD_PSTUNE_PARM_ADOPT	include/rtl8188f_cmd.h	128;"	d
-SET_8188F_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT	include/rtl8188f_cmd.h	126;"	d
-SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_PERIOD	include/rtl8188f_cmd.h	130;"	d
-SET_8188F_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT	include/rtl8188f_cmd.h	127;"	d
-SET_8188F_H2CCMD_PSTUNE_PARM_PS_TIMEOUT	include/rtl8188f_cmd.h	129;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8188f_cmd.h	118;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT	include/rtl8188f_cmd.h	119;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8188f_cmd.h	117;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_BYTE5	include/rtl8188f_cmd.h	121;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_MODE	include/rtl8188f_cmd.h	114;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8188f_cmd.h	120;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8188f_cmd.h	115;"	d
-SET_8188F_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8188f_cmd.h	116;"	d
-SET_8188F_H2CCMD_RSSI_SETTING_MACID	include/rtl8188f_cmd.h	147;"	d
-SET_8188F_H2CCMD_RSSI_SETTING_RSSI	include/rtl8188f_cmd.h	148;"	d
-SET_8188F_H2CCMD_RSSI_SETTING_ULDL_STATE	include/rtl8188f_cmd.h	149;"	d
-SET_8188F_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA	include/rtl8188f_cmd.h	99;"	d
-SET_8188F_H2CCMD_RSVDPAGE_LOC_NULL_DATA	include/rtl8188f_cmd.h	97;"	d
-SET_8188F_H2CCMD_RSVDPAGE_LOC_PROBE_RSP	include/rtl8188f_cmd.h	95;"	d
-SET_8188F_H2CCMD_RSVDPAGE_LOC_PSPOLL	include/rtl8188f_cmd.h	96;"	d
-SET_8188F_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA	include/rtl8188f_cmd.h	98;"	d
-SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP	include/rtl8192e_cmd.h	118;"	d
-SET_8192E_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN	include/rtl8192e_cmd.h	115;"	d
-SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ENABLE	include/rtl8192e_cmd.h	113;"	d
-SET_8192E_H2CCMD_P2P_PS_OFFLOAD_NOA0_EN	include/rtl8192e_cmd.h	116;"	d
-SET_8192E_H2CCMD_P2P_PS_OFFLOAD_NOA1_EN	include/rtl8192e_cmd.h	117;"	d
-SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ROLE	include/rtl8192e_cmd.h	114;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8192e_cmd.h	106;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT	include/rtl8192e_cmd.h	107;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8192e_cmd.h	105;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_BYTE5	include/rtl8192e_cmd.h	109;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_MODE	include/rtl8192e_cmd.h	102;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8192e_cmd.h	108;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8192e_cmd.h	103;"	d
-SET_8192E_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8192e_cmd.h	104;"	d
-SET_8703B_H2CCMD_APREQRPT_PARM_MACID1	include/rtl8703b_cmd.h	152;"	d
-SET_8703B_H2CCMD_APREQRPT_PARM_MACID2	include/rtl8703b_cmd.h	153;"	d
-SET_8703B_H2CCMD_BT_FW_PATCH_ADDR0	include/rtl8703b_cmd.h	168;"	d
-SET_8703B_H2CCMD_BT_FW_PATCH_ADDR1	include/rtl8703b_cmd.h	169;"	d
-SET_8703B_H2CCMD_BT_FW_PATCH_ADDR2	include/rtl8703b_cmd.h	170;"	d
-SET_8703B_H2CCMD_BT_FW_PATCH_ADDR3	include/rtl8703b_cmd.h	171;"	d
-SET_8703B_H2CCMD_BT_FW_PATCH_SIZE	include/rtl8703b_cmd.h	167;"	d
-SET_8703B_H2CCMD_BT_MPOPER_IDX	include/rtl8703b_cmd.h	161;"	d
-SET_8703B_H2CCMD_BT_MPOPER_PARAM1	include/rtl8703b_cmd.h	162;"	d
-SET_8703B_H2CCMD_BT_MPOPER_PARAM2	include/rtl8703b_cmd.h	163;"	d
-SET_8703B_H2CCMD_BT_MPOPER_PARAM3	include/rtl8703b_cmd.h	164;"	d
-SET_8703B_H2CCMD_BT_MPOPER_REQNUM	include/rtl8703b_cmd.h	160;"	d
-SET_8703B_H2CCMD_BT_MPOPER_VER	include/rtl8703b_cmd.h	159;"	d
-SET_8703B_H2CCMD_BT_PWR_IDX	include/rtl8703b_cmd.h	156;"	d
-SET_8703B_H2CCMD_DISCONDECISION_PARM_ADOPT	include/rtl8703b_cmd.h	109;"	d
-SET_8703B_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD	include/rtl8703b_cmd.h	110;"	d
-SET_8703B_H2CCMD_DISCONDECISION_PARM_ENABLE	include/rtl8703b_cmd.h	108;"	d
-SET_8703B_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM	include/rtl8703b_cmd.h	111;"	d
-SET_8703B_H2CCMD_KEEPALIVE_PARM_ADOPT	include/rtl8703b_cmd.h	103;"	d
-SET_8703B_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD	include/rtl8703b_cmd.h	105;"	d
-SET_8703B_H2CCMD_KEEPALIVE_PARM_ENABLE	include/rtl8703b_cmd.h	102;"	d
-SET_8703B_H2CCMD_KEEPALIVE_PARM_PKT_TYPE	include/rtl8703b_cmd.h	104;"	d
-SET_8703B_H2CCMD_MACID_CFG_BW	include/rtl8703b_cmd.h	136;"	d
-SET_8703B_H2CCMD_MACID_CFG_DISPT	include/rtl8703b_cmd.h	139;"	d
-SET_8703B_H2CCMD_MACID_CFG_DISRA	include/rtl8703b_cmd.h	140;"	d
-SET_8703B_H2CCMD_MACID_CFG_MACID	include/rtl8703b_cmd.h	133;"	d
-SET_8703B_H2CCMD_MACID_CFG_NO_UPDATE	include/rtl8703b_cmd.h	137;"	d
-SET_8703B_H2CCMD_MACID_CFG_RAID	include/rtl8703b_cmd.h	134;"	d
-SET_8703B_H2CCMD_MACID_CFG_RATE_MASK0	include/rtl8703b_cmd.h	141;"	d
-SET_8703B_H2CCMD_MACID_CFG_RATE_MASK1	include/rtl8703b_cmd.h	142;"	d
-SET_8703B_H2CCMD_MACID_CFG_RATE_MASK2	include/rtl8703b_cmd.h	143;"	d
-SET_8703B_H2CCMD_MACID_CFG_RATE_MASK3	include/rtl8703b_cmd.h	144;"	d
-SET_8703B_H2CCMD_MACID_CFG_SGI_EN	include/rtl8703b_cmd.h	135;"	d
-SET_8703B_H2CCMD_MACID_CFG_VHT_EN	include/rtl8703b_cmd.h	138;"	d
-SET_8703B_H2CCMD_PSTUNE_PARM_ADOPT	include/rtl8703b_cmd.h	128;"	d
-SET_8703B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT	include/rtl8703b_cmd.h	126;"	d
-SET_8703B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD	include/rtl8703b_cmd.h	130;"	d
-SET_8703B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT	include/rtl8703b_cmd.h	127;"	d
-SET_8703B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT	include/rtl8703b_cmd.h	129;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8703b_cmd.h	118;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT	include/rtl8703b_cmd.h	119;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8703b_cmd.h	117;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_BYTE5	include/rtl8703b_cmd.h	121;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_MODE	include/rtl8703b_cmd.h	114;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8703b_cmd.h	120;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8703b_cmd.h	115;"	d
-SET_8703B_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8703b_cmd.h	116;"	d
-SET_8703B_H2CCMD_RSSI_SETTING_MACID	include/rtl8703b_cmd.h	147;"	d
-SET_8703B_H2CCMD_RSSI_SETTING_RSSI	include/rtl8703b_cmd.h	148;"	d
-SET_8703B_H2CCMD_RSSI_SETTING_ULDL_STATE	include/rtl8703b_cmd.h	149;"	d
-SET_8703B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA	include/rtl8703b_cmd.h	99;"	d
-SET_8703B_H2CCMD_RSVDPAGE_LOC_NULL_DATA	include/rtl8703b_cmd.h	97;"	d
-SET_8703B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP	include/rtl8703b_cmd.h	95;"	d
-SET_8703B_H2CCMD_RSVDPAGE_LOC_PSPOLL	include/rtl8703b_cmd.h	96;"	d
-SET_8703B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA	include/rtl8703b_cmd.h	98;"	d
-SET_8723B_H2CCMD_APREQRPT_PARM_MACID1	include/rtl8723b_cmd.h	152;"	d
-SET_8723B_H2CCMD_APREQRPT_PARM_MACID2	include/rtl8723b_cmd.h	153;"	d
-SET_8723B_H2CCMD_BT_FW_PATCH_ADDR0	include/rtl8723b_cmd.h	168;"	d
-SET_8723B_H2CCMD_BT_FW_PATCH_ADDR1	include/rtl8723b_cmd.h	169;"	d
-SET_8723B_H2CCMD_BT_FW_PATCH_ADDR2	include/rtl8723b_cmd.h	170;"	d
-SET_8723B_H2CCMD_BT_FW_PATCH_ADDR3	include/rtl8723b_cmd.h	171;"	d
-SET_8723B_H2CCMD_BT_FW_PATCH_SIZE	include/rtl8723b_cmd.h	167;"	d
-SET_8723B_H2CCMD_BT_MPOPER_IDX	include/rtl8723b_cmd.h	161;"	d
-SET_8723B_H2CCMD_BT_MPOPER_PARAM1	include/rtl8723b_cmd.h	162;"	d
-SET_8723B_H2CCMD_BT_MPOPER_PARAM2	include/rtl8723b_cmd.h	163;"	d
-SET_8723B_H2CCMD_BT_MPOPER_PARAM3	include/rtl8723b_cmd.h	164;"	d
-SET_8723B_H2CCMD_BT_MPOPER_REQNUM	include/rtl8723b_cmd.h	160;"	d
-SET_8723B_H2CCMD_BT_MPOPER_VER	include/rtl8723b_cmd.h	159;"	d
-SET_8723B_H2CCMD_BT_PWR_IDX	include/rtl8723b_cmd.h	156;"	d
-SET_8723B_H2CCMD_DISCONDECISION_PARM_ADOPT	include/rtl8723b_cmd.h	109;"	d
-SET_8723B_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD	include/rtl8723b_cmd.h	110;"	d
-SET_8723B_H2CCMD_DISCONDECISION_PARM_ENABLE	include/rtl8723b_cmd.h	108;"	d
-SET_8723B_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM	include/rtl8723b_cmd.h	111;"	d
-SET_8723B_H2CCMD_KEEPALIVE_PARM_ADOPT	include/rtl8723b_cmd.h	103;"	d
-SET_8723B_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD	include/rtl8723b_cmd.h	105;"	d
-SET_8723B_H2CCMD_KEEPALIVE_PARM_ENABLE	include/rtl8723b_cmd.h	102;"	d
-SET_8723B_H2CCMD_KEEPALIVE_PARM_PKT_TYPE	include/rtl8723b_cmd.h	104;"	d
-SET_8723B_H2CCMD_MACID_CFG_BW	include/rtl8723b_cmd.h	136;"	d
-SET_8723B_H2CCMD_MACID_CFG_DISPT	include/rtl8723b_cmd.h	139;"	d
-SET_8723B_H2CCMD_MACID_CFG_DISRA	include/rtl8723b_cmd.h	140;"	d
-SET_8723B_H2CCMD_MACID_CFG_MACID	include/rtl8723b_cmd.h	133;"	d
-SET_8723B_H2CCMD_MACID_CFG_NO_UPDATE	include/rtl8723b_cmd.h	137;"	d
-SET_8723B_H2CCMD_MACID_CFG_RAID	include/rtl8723b_cmd.h	134;"	d
-SET_8723B_H2CCMD_MACID_CFG_RATE_MASK0	include/rtl8723b_cmd.h	141;"	d
-SET_8723B_H2CCMD_MACID_CFG_RATE_MASK1	include/rtl8723b_cmd.h	142;"	d
-SET_8723B_H2CCMD_MACID_CFG_RATE_MASK2	include/rtl8723b_cmd.h	143;"	d
-SET_8723B_H2CCMD_MACID_CFG_RATE_MASK3	include/rtl8723b_cmd.h	144;"	d
-SET_8723B_H2CCMD_MACID_CFG_SGI_EN	include/rtl8723b_cmd.h	135;"	d
-SET_8723B_H2CCMD_MACID_CFG_VHT_EN	include/rtl8723b_cmd.h	138;"	d
-SET_8723B_H2CCMD_PSTUNE_PARM_ADOPT	include/rtl8723b_cmd.h	128;"	d
-SET_8723B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT	include/rtl8723b_cmd.h	126;"	d
-SET_8723B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD	include/rtl8723b_cmd.h	130;"	d
-SET_8723B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT	include/rtl8723b_cmd.h	127;"	d
-SET_8723B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT	include/rtl8723b_cmd.h	129;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8723b_cmd.h	118;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT	include/rtl8723b_cmd.h	119;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8723b_cmd.h	117;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_BYTE5	include/rtl8723b_cmd.h	121;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_MODE	include/rtl8723b_cmd.h	114;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8723b_cmd.h	120;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8723b_cmd.h	115;"	d
-SET_8723B_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8723b_cmd.h	116;"	d
-SET_8723B_H2CCMD_RSSI_SETTING_MACID	include/rtl8723b_cmd.h	147;"	d
-SET_8723B_H2CCMD_RSSI_SETTING_RSSI	include/rtl8723b_cmd.h	148;"	d
-SET_8723B_H2CCMD_RSSI_SETTING_ULDL_STATE	include/rtl8723b_cmd.h	149;"	d
-SET_8723B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA	include/rtl8723b_cmd.h	99;"	d
-SET_8723B_H2CCMD_RSVDPAGE_LOC_NULL_DATA	include/rtl8723b_cmd.h	97;"	d
-SET_8723B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP	include/rtl8723b_cmd.h	95;"	d
-SET_8723B_H2CCMD_RSVDPAGE_LOC_PSPOLL	include/rtl8723b_cmd.h	96;"	d
-SET_8723B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA	include/rtl8723b_cmd.h	98;"	d
-SET_8723D_H2CCMD_APREQRPT_PARM_MACID1	include/rtl8723d_cmd.h	151;"	d
-SET_8723D_H2CCMD_APREQRPT_PARM_MACID2	include/rtl8723d_cmd.h	152;"	d
-SET_8723D_H2CCMD_BT_FW_PATCH_ADDR0	include/rtl8723d_cmd.h	167;"	d
-SET_8723D_H2CCMD_BT_FW_PATCH_ADDR1	include/rtl8723d_cmd.h	168;"	d
-SET_8723D_H2CCMD_BT_FW_PATCH_ADDR2	include/rtl8723d_cmd.h	169;"	d
-SET_8723D_H2CCMD_BT_FW_PATCH_ADDR3	include/rtl8723d_cmd.h	170;"	d
-SET_8723D_H2CCMD_BT_FW_PATCH_SIZE	include/rtl8723d_cmd.h	166;"	d
-SET_8723D_H2CCMD_BT_MPOPER_IDX	include/rtl8723d_cmd.h	160;"	d
-SET_8723D_H2CCMD_BT_MPOPER_PARAM1	include/rtl8723d_cmd.h	161;"	d
-SET_8723D_H2CCMD_BT_MPOPER_PARAM2	include/rtl8723d_cmd.h	162;"	d
-SET_8723D_H2CCMD_BT_MPOPER_PARAM3	include/rtl8723d_cmd.h	163;"	d
-SET_8723D_H2CCMD_BT_MPOPER_REQNUM	include/rtl8723d_cmd.h	159;"	d
-SET_8723D_H2CCMD_BT_MPOPER_VER	include/rtl8723d_cmd.h	158;"	d
-SET_8723D_H2CCMD_BT_PWR_IDX	include/rtl8723d_cmd.h	155;"	d
-SET_8723D_H2CCMD_DISCONDECISION_PARM_ADOPT	include/rtl8723d_cmd.h	109;"	d
-SET_8723D_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD	include/rtl8723d_cmd.h	110;"	d
-SET_8723D_H2CCMD_DISCONDECISION_PARM_ENABLE	include/rtl8723d_cmd.h	108;"	d
-SET_8723D_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM	include/rtl8723d_cmd.h	111;"	d
-SET_8723D_H2CCMD_KEEPALIVE_PARM_ADOPT	include/rtl8723d_cmd.h	103;"	d
-SET_8723D_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD	include/rtl8723d_cmd.h	105;"	d
-SET_8723D_H2CCMD_KEEPALIVE_PARM_ENABLE	include/rtl8723d_cmd.h	102;"	d
-SET_8723D_H2CCMD_KEEPALIVE_PARM_PKT_TYPE	include/rtl8723d_cmd.h	104;"	d
-SET_8723D_H2CCMD_MACID_CFG_BW	include/rtl8723d_cmd.h	135;"	d
-SET_8723D_H2CCMD_MACID_CFG_DISPT	include/rtl8723d_cmd.h	138;"	d
-SET_8723D_H2CCMD_MACID_CFG_DISRA	include/rtl8723d_cmd.h	139;"	d
-SET_8723D_H2CCMD_MACID_CFG_MACID	include/rtl8723d_cmd.h	132;"	d
-SET_8723D_H2CCMD_MACID_CFG_NO_UPDATE	include/rtl8723d_cmd.h	136;"	d
-SET_8723D_H2CCMD_MACID_CFG_RAID	include/rtl8723d_cmd.h	133;"	d
-SET_8723D_H2CCMD_MACID_CFG_RATE_MASK0	include/rtl8723d_cmd.h	140;"	d
-SET_8723D_H2CCMD_MACID_CFG_RATE_MASK1	include/rtl8723d_cmd.h	141;"	d
-SET_8723D_H2CCMD_MACID_CFG_RATE_MASK2	include/rtl8723d_cmd.h	142;"	d
-SET_8723D_H2CCMD_MACID_CFG_RATE_MASK3	include/rtl8723d_cmd.h	143;"	d
-SET_8723D_H2CCMD_MACID_CFG_SGI_EN	include/rtl8723d_cmd.h	134;"	d
-SET_8723D_H2CCMD_MACID_CFG_VHT_EN	include/rtl8723d_cmd.h	137;"	d
-SET_8723D_H2CCMD_PSTUNE_PARM_ADOPT	include/rtl8723d_cmd.h	127;"	d
-SET_8723D_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT	include/rtl8723d_cmd.h	125;"	d
-SET_8723D_H2CCMD_PSTUNE_PARM_DTIM_PERIOD	include/rtl8723d_cmd.h	129;"	d
-SET_8723D_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT	include/rtl8723d_cmd.h	126;"	d
-SET_8723D_H2CCMD_PSTUNE_PARM_PS_TIMEOUT	include/rtl8723d_cmd.h	128;"	d
-SET_8723D_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8723d_cmd.h	118;"	d
-SET_8723D_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8723d_cmd.h	117;"	d
-SET_8723D_H2CCMD_PWRMODE_PARM_BYTE5	include/rtl8723d_cmd.h	120;"	d
-SET_8723D_H2CCMD_PWRMODE_PARM_MODE	include/rtl8723d_cmd.h	114;"	d
-SET_8723D_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8723d_cmd.h	119;"	d
-SET_8723D_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8723d_cmd.h	115;"	d
-SET_8723D_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8723d_cmd.h	116;"	d
-SET_8723D_H2CCMD_RSSI_SETTING_MACID	include/rtl8723d_cmd.h	146;"	d
-SET_8723D_H2CCMD_RSSI_SETTING_RSSI	include/rtl8723d_cmd.h	147;"	d
-SET_8723D_H2CCMD_RSSI_SETTING_ULDL_STATE	include/rtl8723d_cmd.h	148;"	d
-SET_8723D_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA	include/rtl8723d_cmd.h	99;"	d
-SET_8723D_H2CCMD_RSVDPAGE_LOC_NULL_DATA	include/rtl8723d_cmd.h	97;"	d
-SET_8723D_H2CCMD_RSVDPAGE_LOC_PROBE_RSP	include/rtl8723d_cmd.h	95;"	d
-SET_8723D_H2CCMD_RSVDPAGE_LOC_PSPOLL	include/rtl8723d_cmd.h	96;"	d
-SET_8723D_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA	include/rtl8723d_cmd.h	98;"	d
-SET_8812_H2CCMD_BT_FW_PATCH_ADDR0	include/rtl8812a_cmd.h	165;"	d
-SET_8812_H2CCMD_BT_FW_PATCH_ADDR1	include/rtl8812a_cmd.h	166;"	d
-SET_8812_H2CCMD_BT_FW_PATCH_ADDR2	include/rtl8812a_cmd.h	167;"	d
-SET_8812_H2CCMD_BT_FW_PATCH_ADDR3	include/rtl8812a_cmd.h	168;"	d
-SET_8812_H2CCMD_BT_FW_PATCH_SIZE	include/rtl8812a_cmd.h	164;"	d
-SET_8812_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP	include/rtl8812a_cmd.h	102;"	d
-SET_8812_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN	include/rtl8812a_cmd.h	99;"	d
-SET_8812_H2CCMD_P2P_PS_OFFLOAD_DISCOVERY	include/rtl8812a_cmd.h	103;"	d
-SET_8812_H2CCMD_P2P_PS_OFFLOAD_ENABLE	include/rtl8812a_cmd.h	97;"	d
-SET_8812_H2CCMD_P2P_PS_OFFLOAD_NOA0_EN	include/rtl8812a_cmd.h	100;"	d
-SET_8812_H2CCMD_P2P_PS_OFFLOAD_NOA1_EN	include/rtl8812a_cmd.h	101;"	d
-SET_8812_H2CCMD_P2P_PS_OFFLOAD_ROLE	include/rtl8812a_cmd.h	98;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8812a_cmd.h	89;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT	include/rtl8812a_cmd.h	90;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8812a_cmd.h	88;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_BYTE5	include/rtl8812a_cmd.h	92;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_MODE	include/rtl8812a_cmd.h	85;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8812a_cmd.h	91;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8812a_cmd.h	86;"	d
-SET_8812_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8812a_cmd.h	87;"	d
-SET_8812_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA	include/rtl8812a_cmd.h	82;"	d
-SET_8812_H2CCMD_RSVDPAGE_LOC_NULL_DATA	include/rtl8812a_cmd.h	80;"	d
-SET_8812_H2CCMD_RSVDPAGE_LOC_PROBE_RSP	include/rtl8812a_cmd.h	78;"	d
-SET_8812_H2CCMD_RSVDPAGE_LOC_PSPOLL	include/rtl8812a_cmd.h	79;"	d
-SET_8812_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA	include/rtl8812a_cmd.h	81;"	d
-SET_8814A_H2CCMD_AP_OFFLOAD_DENYANY	include/rtl8814a_cmd.h	72;"	d
-SET_8814A_H2CCMD_AP_OFFLOAD_HIDDEN	include/rtl8814a_cmd.h	71;"	d
-SET_8814A_H2CCMD_AP_OFFLOAD_ON	include/rtl8814a_cmd.h	70;"	d
-SET_8814A_H2CCMD_AP_OFFLOAD_WAKEUP_EVT_RPT	include/rtl8814a_cmd.h	73;"	d
-SET_8814A_H2CCMD_BCNHWSEQ_BCN_NUMBER	include/rtl8814a_cmd.h	85;"	d
-SET_8814A_H2CCMD_BCNHWSEQ_EN	include/rtl8814a_cmd.h	84;"	d
-SET_8814A_H2CCMD_BCNHWSEQ_EXHWSEQ	include/rtl8814a_cmd.h	87;"	d
-SET_8814A_H2CCMD_BCNHWSEQ_HWSEQ	include/rtl8814a_cmd.h	86;"	d
-SET_8814A_H2CCMD_BCNHWSEQ_PAGE	include/rtl8814a_cmd.h	88;"	d
-SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP	include/rtl8814a_cmd.h	116;"	d
-SET_8814A_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN	include/rtl8814a_cmd.h	113;"	d
-SET_8814A_H2CCMD_P2P_PS_OFFLOAD_DISCOVERY	include/rtl8814a_cmd.h	117;"	d
-SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ENABLE	include/rtl8814a_cmd.h	111;"	d
-SET_8814A_H2CCMD_P2P_PS_OFFLOAD_NOA0_EN	include/rtl8814a_cmd.h	114;"	d
-SET_8814A_H2CCMD_P2P_PS_OFFLOAD_NOA1_EN	include/rtl8814a_cmd.h	115;"	d
-SET_8814A_H2CCMD_P2P_PS_OFFLOAD_ROLE	include/rtl8814a_cmd.h	112;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8814a_cmd.h	36;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT	include/rtl8814a_cmd.h	37;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8814a_cmd.h	35;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_BYTE5	include/rtl8814a_cmd.h	39;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_MODE	include/rtl8814a_cmd.h	32;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8814a_cmd.h	38;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8814a_cmd.h	33;"	d
-SET_8814A_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8814a_cmd.h	34;"	d
-SET_8814A_H2CCMD_REMOTE_WAKECTRL_ENABLE	include/rtl8814a_cmd.h	63;"	d
-SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN	include/rtl8814a_cmd.h	64;"	d
-SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN	include/rtl8814a_cmd.h	66;"	d
-SET_8814A_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN	include/rtl8814a_cmd.h	65;"	d
-SET_8814A_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA	include/rtl8814a_cmd.h	29;"	d
-SET_8814A_H2CCMD_RSVDPAGE_LOC_NULL_DATA	include/rtl8814a_cmd.h	27;"	d
-SET_8814A_H2CCMD_RSVDPAGE_LOC_PROBE_RSP	include/rtl8814a_cmd.h	25;"	d
-SET_8814A_H2CCMD_RSVDPAGE_LOC_PSPOLL	include/rtl8814a_cmd.h	26;"	d
-SET_8814A_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA	include/rtl8814a_cmd.h	28;"	d
-SET_8814A_H2CCMD_WLANINFO_PARM_BW40MHZ	include/rtl8814a_cmd.h	60;"	d
-SET_8814A_H2CCMD_WLANINFO_PARM_CHANNEL	include/rtl8814a_cmd.h	59;"	d
-SET_8814A_H2CCMD_WLANINFO_PARM_OPMODE	include/rtl8814a_cmd.h	58;"	d
-SET_8814A_H2CCMD_WOWLAN_ALL_PKT_DROP	include/rtl8814a_cmd.h	49;"	d
-SET_8814A_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP	include/rtl8814a_cmd.h	52;"	d
-SET_8814A_H2CCMD_WOWLAN_FUNC_ENABLE	include/rtl8814a_cmd.h	45;"	d
-SET_8814A_H2CCMD_WOWLAN_GPIONUM	include/rtl8814a_cmd.h	53;"	d
-SET_8814A_H2CCMD_WOWLAN_GPIO_ACTIVE	include/rtl8814a_cmd.h	50;"	d
-SET_8814A_H2CCMD_WOWLAN_GPIO_DURATION	include/rtl8814a_cmd.h	54;"	d
-SET_8814A_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE	include/rtl8814a_cmd.h	47;"	d
-SET_8814A_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE	include/rtl8814a_cmd.h	46;"	d
-SET_8814A_H2CCMD_WOWLAN_REKEY_WAKE_UP	include/rtl8814a_cmd.h	51;"	d
-SET_8814A_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE	include/rtl8814a_cmd.h	48;"	d
-SET_88E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD	include/rtl8814a_cmd.h	80;"	d
-SET_88E_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME	include/rtl8814a_cmd.h	79;"	d
-SET_88E_H2CCMD_PWRMODE_PARM_MODE	include/rtl8814a_cmd.h	76;"	d
-SET_88E_H2CCMD_PWRMODE_PARM_PWR_STATE	include/rtl8814a_cmd.h	81;"	d
-SET_88E_H2CCMD_PWRMODE_PARM_RLBM	include/rtl8814a_cmd.h	77;"	d
-SET_88E_H2CCMD_PWRMODE_PARM_SMART_PS	include/rtl8814a_cmd.h	78;"	d
-SET_ACS_STATE	include/hal_data.h	762;"	d
-SET_ARP_PKT_HW	include/hal_com_h2c.h	175;"	d
-SET_ARP_PKT_HW_ADDR_LEN	include/hal_com_h2c.h	177;"	d
-SET_ARP_PKT_OPERATION	include/hal_com_h2c.h	179;"	d
-SET_ARP_PKT_PROTOCOL	include/hal_com_h2c.h	176;"	d
-SET_ARP_PKT_PROTOCOL_ADDR_LEN	include/hal_com_h2c.h	178;"	d
-SET_ARP_PKT_SENDER_IP_ADDR	include/hal_com_h2c.h	181;"	d
-SET_ARP_PKT_SENDER_MAC_ADDR	include/hal_com_h2c.h	180;"	d
-SET_ARP_PKT_TARGET_IP_ADDR	include/hal_com_h2c.h	183;"	d
-SET_ARP_PKT_TARGET_MAC_ADDR	include/hal_com_h2c.h	182;"	d
-SET_BITS_TO_BE_1BYTE	include/basic_types.h	360;"	d
-SET_BITS_TO_BE_2BYTE	include/basic_types.h	347;"	d
-SET_BITS_TO_BE_4BYTE	include/basic_types.h	334;"	d
-SET_BITS_TO_LE_1BYTE	include/basic_types.h	318;"	d
-SET_BITS_TO_LE_2BYTE	include/basic_types.h	305;"	d
-SET_BITS_TO_LE_4BYTE	include/basic_types.h	292;"	d
-SET_BT_MP_OPER_RET	include/rtw_btcoex.h	63;"	d
-SET_C2H_ID	hal/hal_com_c2h.h	36;"	d
-SET_C2H_ID_88XX	hal/hal_com_c2h.h	51;"	d
-SET_C2H_PLEN	hal/hal_com_c2h.h	37;"	d
-SET_C2H_PLEN_88XX	hal/hal_com_c2h.h	53;"	d
-SET_C2H_SEQ	hal/hal_com_c2h.h	38;"	d
-SET_C2H_SEQ_88XX	hal/hal_com_c2h.h	52;"	d
-SET_CFG80211_REPORT_MGMT	os_dep/linux/ioctl_cfg80211.h	196;"	d
-SET_DEF_KEY_PARAM_ARG	os_dep/linux/ioctl_cfg80211.c	1567;"	d	file:
-SET_DEF_KEY_PARAM_ARG_2_6_38	os_dep/linux/ioctl_cfg80211.c	1570;"	d	file:
-SET_DEF_KEY_PARAM_FMT	os_dep/linux/ioctl_cfg80211.c	1566;"	d	file:
-SET_DEF_KEY_PARAM_FMT_2_6_38	os_dep/linux/ioctl_cfg80211.c	1569;"	d	file:
-SET_EARLYMODE_LEN0	include/rtl8188e_xmit.h	28;"	d
-SET_EARLYMODE_LEN0	include/rtl8192e_xmit.h	133;"	d
-SET_EARLYMODE_LEN0	include/rtl8812a_xmit.h	26;"	d
-SET_EARLYMODE_LEN0_8188F	include/rtl8188f_xmit.h	217;"	d
-SET_EARLYMODE_LEN0_8703B	include/rtl8703b_xmit.h	217;"	d
-SET_EARLYMODE_LEN0_8723B	include/rtl8723b_xmit.h	217;"	d
-SET_EARLYMODE_LEN0_8723D	include/rtl8723d_xmit.h	331;"	d
-SET_EARLYMODE_LEN0_8812	include/rtl8812a_xmit.h	307;"	d
-SET_EARLYMODE_LEN0_8814A	include/rtl8814a_xmit.h	258;"	d
-SET_EARLYMODE_LEN0_92E	include/rtl8192e_xmit.h	351;"	d
-SET_EARLYMODE_LEN1	include/rtl8188e_xmit.h	29;"	d
-SET_EARLYMODE_LEN1	include/rtl8192e_xmit.h	134;"	d
-SET_EARLYMODE_LEN1	include/rtl8812a_xmit.h	27;"	d
-SET_EARLYMODE_LEN1_1_8188F	include/rtl8188f_xmit.h	218;"	d
-SET_EARLYMODE_LEN1_1_8703B	include/rtl8703b_xmit.h	218;"	d
-SET_EARLYMODE_LEN1_1_8723B	include/rtl8723b_xmit.h	218;"	d
-SET_EARLYMODE_LEN1_1_8723D	include/rtl8723d_xmit.h	332;"	d
-SET_EARLYMODE_LEN1_1_8812	include/rtl8812a_xmit.h	308;"	d
-SET_EARLYMODE_LEN1_1_8814A	include/rtl8814a_xmit.h	259;"	d
-SET_EARLYMODE_LEN1_1_92E	include/rtl8192e_xmit.h	352;"	d
-SET_EARLYMODE_LEN1_2_8188F	include/rtl8188f_xmit.h	219;"	d
-SET_EARLYMODE_LEN1_2_8703B	include/rtl8703b_xmit.h	219;"	d
-SET_EARLYMODE_LEN1_2_8723B	include/rtl8723b_xmit.h	219;"	d
-SET_EARLYMODE_LEN1_2_8723D	include/rtl8723d_xmit.h	333;"	d
-SET_EARLYMODE_LEN1_2_8812	include/rtl8812a_xmit.h	309;"	d
-SET_EARLYMODE_LEN1_2_8814A	include/rtl8814a_xmit.h	260;"	d
-SET_EARLYMODE_LEN1_2_92E	include/rtl8192e_xmit.h	353;"	d
-SET_EARLYMODE_LEN2_1	include/rtl8188e_xmit.h	30;"	d
-SET_EARLYMODE_LEN2_1	include/rtl8192e_xmit.h	135;"	d
-SET_EARLYMODE_LEN2_1	include/rtl8812a_xmit.h	28;"	d
-SET_EARLYMODE_LEN2_2	include/rtl8188e_xmit.h	31;"	d
-SET_EARLYMODE_LEN2_2	include/rtl8192e_xmit.h	136;"	d
-SET_EARLYMODE_LEN2_2	include/rtl8812a_xmit.h	29;"	d
-SET_EARLYMODE_LEN2_8188F	include/rtl8188f_xmit.h	220;"	d
-SET_EARLYMODE_LEN2_8703B	include/rtl8703b_xmit.h	220;"	d
-SET_EARLYMODE_LEN2_8723B	include/rtl8723b_xmit.h	220;"	d
-SET_EARLYMODE_LEN2_8723D	include/rtl8723d_xmit.h	334;"	d
-SET_EARLYMODE_LEN2_8812	include/rtl8812a_xmit.h	310;"	d
-SET_EARLYMODE_LEN2_8814A	include/rtl8814a_xmit.h	261;"	d
-SET_EARLYMODE_LEN2_92E	include/rtl8192e_xmit.h	354;"	d
-SET_EARLYMODE_LEN3	include/rtl8188e_xmit.h	32;"	d
-SET_EARLYMODE_LEN3	include/rtl8192e_xmit.h	137;"	d
-SET_EARLYMODE_LEN3	include/rtl8812a_xmit.h	30;"	d
-SET_EARLYMODE_LEN3_8188F	include/rtl8188f_xmit.h	221;"	d
-SET_EARLYMODE_LEN3_8703B	include/rtl8703b_xmit.h	221;"	d
-SET_EARLYMODE_LEN3_8723B	include/rtl8723b_xmit.h	221;"	d
-SET_EARLYMODE_LEN3_8723D	include/rtl8723d_xmit.h	335;"	d
-SET_EARLYMODE_LEN3_8812	include/rtl8812a_xmit.h	311;"	d
-SET_EARLYMODE_LEN3_8814A	include/rtl8814a_xmit.h	262;"	d
-SET_EARLYMODE_LEN3_92E	include/rtl8192e_xmit.h	355;"	d
-SET_EARLYMODE_LEN4	include/rtl8188e_xmit.h	33;"	d
-SET_EARLYMODE_LEN4	include/rtl8192e_xmit.h	138;"	d
-SET_EARLYMODE_LEN4	include/rtl8812a_xmit.h	31;"	d
-SET_EARLYMODE_PKTNUM	include/rtl8188e_xmit.h	27;"	d
-SET_EARLYMODE_PKTNUM	include/rtl8192e_xmit.h	132;"	d
-SET_EARLYMODE_PKTNUM	include/rtl8812a_xmit.h	25;"	d
-SET_EARLYMODE_PKTNUM_8188F	include/rtl8188f_xmit.h	216;"	d
-SET_EARLYMODE_PKTNUM_8703B	include/rtl8703b_xmit.h	216;"	d
-SET_EARLYMODE_PKTNUM_8723B	include/rtl8723b_xmit.h	216;"	d
-SET_EARLYMODE_PKTNUM_8723D	include/rtl8723d_xmit.h	330;"	d
-SET_EARLYMODE_PKTNUM_8812	include/rtl8812a_xmit.h	306;"	d
-SET_EARLYMODE_PKTNUM_8814A	include/rtl8814a_xmit.h	257;"	d
-SET_EARLYMODE_PKTNUM_92E	include/rtl8192e_xmit.h	350;"	d
-SET_ERROR	hal/phydm/phydm.h	101;"	d
-SET_EXT_CAPABILITY_ELE_BSS_COEXIST	include/rtw_ht.h	106;"	d
-SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF	include/rtw_vht.h	107;"	d
-SET_FLAG	include/basic_types.h	379;"	d
-SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG	include/hal_com_h2c.h	433;"	d
-SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG	include/hal_com_h2c.h	432;"	d
-SET_H2CCMD_AOAC_NLO_FUN_EN	include/hal_com_h2c.h	452;"	d
-SET_H2CCMD_AOAC_NLO_IPS_EN	include/hal_com_h2c.h	453;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_AOAC_REPORT	include/hal_com_h2c.h	447;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP	include/hal_com_h2c.h	437;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM	include/hal_com_h2c.h	442;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO	include/hal_com_h2c.h	440;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP	include/hal_com_h2c.h	439;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV	include/hal_com_h2c.h	438;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO	include/hal_com_h2c.h	445;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET	include/hal_com_h2c.h	454;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO	include/hal_com_h2c.h	436;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO	include/hal_com_h2c.h	455;"	d
-SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO	include/hal_com_h2c.h	456;"	d
-SET_H2CCMD_AP_WOWLAN_EN	include/hal_com_h2c.h	298;"	d
-SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN	include/hal_com_h2c.h	300;"	d
-SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp	include/hal_com_h2c.h	302;"	d
-SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_DURATION	include/hal_com_h2c.h	310;"	d
-SET_H2CCMD_AP_WOW_GPIO_CTRL_C2H_EN	include/hal_com_h2c.h	305;"	d
-SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION	include/hal_com_h2c.h	309;"	d
-SET_H2CCMD_AP_WOW_GPIO_CTRL_EN	include/hal_com_h2c.h	308;"	d
-SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE	include/hal_com_h2c.h	307;"	d
-SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX	include/hal_com_h2c.h	304;"	d
-SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS	include/hal_com_h2c.h	306;"	d
-SET_H2CCMD_AP_WOW_PS_32K_EN	include/hal_com_h2c.h	313;"	d
-SET_H2CCMD_AP_WOW_PS_DURATION	include/hal_com_h2c.h	315;"	d
-SET_H2CCMD_AP_WOW_PS_EN	include/hal_com_h2c.h	312;"	d
-SET_H2CCMD_AP_WOW_PS_RF	include/hal_com_h2c.h	314;"	d
-SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC	include/hal_com_h2c.h	398;"	d
-SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC	include/hal_com_h2c.h	399;"	d
-SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE	include/hal_com_h2c.h	397;"	d
-SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM	include/hal_com_h2c.h	396;"	d
-SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE	include/hal_com_h2c.h	400;"	d
-SET_H2CCMD_CUSTOMER_STR_REQ_EN	include/hal_com_h2c.h	275;"	d
-SET_H2CCMD_CUSTOMER_STR_W1_EN	include/hal_com_h2c.h	281;"	d
-SET_H2CCMD_CUSTOMER_STR_W2_EN	include/hal_com_h2c.h	286;"	d
-SET_H2CCMD_CUSTOMER_STR_W3_EN	include/hal_com_h2c.h	291;"	d
-SET_H2CCMD_DISCONDECISION_PARM_ADOPT	include/hal_com_h2c.h	262;"	d
-SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD	include/hal_com_h2c.h	263;"	d
-SET_H2CCMD_DISCONDECISION_PARM_ENABLE	include/hal_com_h2c.h	261;"	d
-SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM	include/hal_com_h2c.h	264;"	d
-SET_H2CCMD_INACTIVE_PS_DURATION	include/hal_com_h2c.h	326;"	d
-SET_H2CCMD_INACTIVE_PS_EN	include/hal_com_h2c.h	318;"	d
-SET_H2CCMD_INACTIVE_PS_FREQ	include/hal_com_h2c.h	324;"	d
-SET_H2CCMD_INACTIVE_PS_IGNORE_PS	include/hal_com_h2c.h	320;"	d
-SET_H2CCMD_INACTIVE_PS_PERIOD_SCAN_EN	include/hal_com_h2c.h	322;"	d
-SET_H2CCMD_INACTIVE_PS_PERIOD_SCAN_TIME	include/hal_com_h2c.h	328;"	d
-SET_H2CCMD_KEEPALIVE_PARM_ADOPT	include/hal_com_h2c.h	256;"	d
-SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD	include/hal_com_h2c.h	258;"	d
-SET_H2CCMD_KEEPALIVE_PARM_ENABLE	include/hal_com_h2c.h	255;"	d
-SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE	include/hal_com_h2c.h	257;"	d
-SET_H2CCMD_LPSPG_LOC	include/hal_com_h2c.h	475;"	d
-SET_H2CCMD_LPSPG_MACID_SEARCH_EN	include/hal_com_h2c.h	472;"	d
-SET_H2CCMD_LPSPG_MBID_CAM_EN	include/hal_com_h2c.h	470;"	d
-SET_H2CCMD_LPSPG_MU_RATE_TB_EN	include/hal_com_h2c.h	474;"	d
-SET_H2CCMD_LPSPG_PMC_CAM_EN	include/hal_com_h2c.h	471;"	d
-SET_H2CCMD_LPSPG_SEC_CAM_EN	include/hal_com_h2c.h	469;"	d
-SET_H2CCMD_LPSPG_TXSC_EN	include/hal_com_h2c.h	473;"	d
-SET_H2CCMD_LPS_POFF_CTRL_EN	include/hal_com_h2c.h	333;"	d
-SET_H2CCMD_LPS_POFF_PARAM_ENDADDH	include/hal_com_h2c.h	346;"	d
-SET_H2CCMD_LPS_POFF_PARAM_ENDADDL	include/hal_com_h2c.h	344;"	d
-SET_H2CCMD_LPS_POFF_PARAM_RDVLD	include/hal_com_h2c.h	336;"	d
-SET_H2CCMD_LPS_POFF_PARAM_STARTADDH	include/hal_com_h2c.h	342;"	d
-SET_H2CCMD_LPS_POFF_PARAM_STARTADDL	include/hal_com_h2c.h	340;"	d
-SET_H2CCMD_LPS_POFF_PARAM_WRVLD	include/hal_com_h2c.h	338;"	d
-SET_H2CCMD_MCC_EARLY_TIME	include/hal_com_h2c.h	380;"	d
-SET_H2CCMD_MCC_INFO_BW	include/hal_com_h2c.h	362;"	d
-SET_H2CCMD_MCC_INFO_BW40SC	include/hal_com_h2c.h	363;"	d
-SET_H2CCMD_MCC_INFO_BW80SC	include/hal_com_h2c.h	364;"	d
-SET_H2CCMD_MCC_INFO_C2HRPT	include/hal_com_h2c.h	372;"	d
-SET_H2CCMD_MCC_INFO_CHIDX	include/hal_com_h2c.h	361;"	d
-SET_H2CCMD_MCC_INFO_CHSCAN	include/hal_com_h2c.h	373;"	d
-SET_H2CCMD_MCC_INFO_DISTXNULL	include/hal_com_h2c.h	371;"	d
-SET_H2CCMD_MCC_INFO_DURATION	include/hal_com_h2c.h	365;"	d
-SET_H2CCMD_MCC_INFO_INCURCH	include/hal_com_h2c.h	367;"	d
-SET_H2CCMD_MCC_INFO_ORDER	include/hal_com_h2c.h	359;"	d
-SET_H2CCMD_MCC_INFO_RFETYPE	include/hal_com_h2c.h	370;"	d
-SET_H2CCMD_MCC_INFO_ROLE	include/hal_com_h2c.h	366;"	d
-SET_H2CCMD_MCC_INFO_RSVD0	include/hal_com_h2c.h	368;"	d
-SET_H2CCMD_MCC_INFO_RSVD1	include/hal_com_h2c.h	369;"	d
-SET_H2CCMD_MCC_INFO_TOTALNUM	include/hal_com_h2c.h	360;"	d
-SET_H2CCMD_MCC_IQK_ORDER	include/hal_com_h2c.h	384;"	d
-SET_H2CCMD_MCC_IQK_READY	include/hal_com_h2c.h	383;"	d
-SET_H2CCMD_MCC_IQK_RX_H	include/hal_com_h2c.h	388;"	d
-SET_H2CCMD_MCC_IQK_RX_L	include/hal_com_h2c.h	385;"	d
-SET_H2CCMD_MCC_IQK_RX_M1	include/hal_com_h2c.h	386;"	d
-SET_H2CCMD_MCC_IQK_RX_M2	include/hal_com_h2c.h	387;"	d
-SET_H2CCMD_MCC_IQK_TX_H	include/hal_com_h2c.h	392;"	d
-SET_H2CCMD_MCC_IQK_TX_L	include/hal_com_h2c.h	389;"	d
-SET_H2CCMD_MCC_IQK_TX_M1	include/hal_com_h2c.h	390;"	d
-SET_H2CCMD_MCC_IQK_TX_M2	include/hal_com_h2c.h	391;"	d
-SET_H2CCMD_MCC_MACID_BITMAP_H	include/hal_com_h2c.h	356;"	d
-SET_H2CCMD_MCC_MACID_BITMAP_L	include/hal_com_h2c.h	355;"	d
-SET_H2CCMD_MCC_NOA_FW_EN	include/hal_com_h2c.h	376;"	d
-SET_H2CCMD_MCC_NOA_INTERVAL	include/hal_com_h2c.h	379;"	d
-SET_H2CCMD_MCC_NOA_START_TIME	include/hal_com_h2c.h	378;"	d
-SET_H2CCMD_MCC_NOA_TSF_SYNC_OFFSET	include/hal_com_h2c.h	377;"	d
-SET_H2CCMD_MCC_RSVDPAGE_LOC	include/hal_com_h2c.h	352;"	d
-SET_H2CCMD_MSRRPT_PARM_MACID	include/hal_com_h2c.h	224;"	d
-SET_H2CCMD_MSRRPT_PARM_MACID_END	include/hal_com_h2c.h	225;"	d
-SET_H2CCMD_MSRRPT_PARM_MACID_IND	include/hal_com_h2c.h	220;"	d
-SET_H2CCMD_MSRRPT_PARM_MIRACAST	include/hal_com_h2c.h	221;"	d
-SET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK	include/hal_com_h2c.h	222;"	d
-SET_H2CCMD_MSRRPT_PARM_OPMODE	include/hal_com_h2c.h	219;"	d
-SET_H2CCMD_MSRRPT_PARM_ROLE	include/hal_com_h2c.h	223;"	d
-SET_H2CCMD_REMOTE_WAKECTRL_ENABLE	include/hal_com_h2c.h	419;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION	include/hal_com_h2c.h	428;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN	include/hal_com_h2c.h	420;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP	include/hal_com_h2c.h	429;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN	include/hal_com_h2c.h	424;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN	include/hal_com_h2c.h	422;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN	include/hal_com_h2c.h	426;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN	include/hal_com_h2c.h	421;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN	include/hal_com_h2c.h	423;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN	include/hal_com_h2c.h	425;"	d
-SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN	include/hal_com_h2c.h	427;"	d
-SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA	include/hal_com_h2c.h	216;"	d
-SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA	include/hal_com_h2c.h	214;"	d
-SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN	include/hal_com_h2c.h	461;"	d
-SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP	include/hal_com_h2c.h	464;"	d
-SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP	include/hal_com_h2c.h	463;"	d
-SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP	include/hal_com_h2c.h	465;"	d
-SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP	include/hal_com_h2c.h	462;"	d
-SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP	include/hal_com_h2c.h	212;"	d
-SET_H2CCMD_RSVDPAGE_LOC_PSPOLL	include/hal_com_h2c.h	213;"	d
-SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA	include/hal_com_h2c.h	215;"	d
-SET_H2CCMD_WOWLAN_ALL_PKT_DROP	include/hal_com_h2c.h	407;"	d
-SET_H2CCMD_WOWLAN_CHANGE_UNIT	include/hal_com_h2c.h	417;"	d
-SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP	include/hal_com_h2c.h	412;"	d
-SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP	include/hal_com_h2c.h	410;"	d
-SET_H2CCMD_WOWLAN_FUNC_ENABLE	include/hal_com_h2c.h	403;"	d
-SET_H2CCMD_WOWLAN_GPIONUM	include/hal_com_h2c.h	411;"	d
-SET_H2CCMD_WOWLAN_GPIO_ACTIVE	include/hal_com_h2c.h	408;"	d
-SET_H2CCMD_WOWLAN_GPIO_DURATION	include/hal_com_h2c.h	413;"	d
-SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT	include/hal_com_h2c.h	415;"	d
-SET_H2CCMD_WOWLAN_GPIO_PULSE_EN	include/hal_com_h2c.h	414;"	d
-SET_H2CCMD_WOWLAN_LOWPR_RX	include/hal_com_h2c.h	416;"	d
-SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE	include/hal_com_h2c.h	405;"	d
-SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE	include/hal_com_h2c.h	404;"	d
-SET_H2CCMD_WOWLAN_REKEY_WAKE_UP	include/hal_com_h2c.h	409;"	d
-SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE	include/hal_com_h2c.h	406;"	d
-SET_HOIE_ENTRY_ADDRESS	include/rtl8723d_lps_poff.h	37;"	d
-SET_HOIE_ENTRY_BYTE_MASK	include/rtl8723d_lps_poff.h	39;"	d
-SET_HOIE_ENTRY_HIGH_DATA	include/rtl8723d_lps_poff.h	33;"	d
-SET_HOIE_ENTRY_IO_DELAY	include/rtl8723d_lps_poff.h	51;"	d
-SET_HOIE_ENTRY_IO_LOCK	include/rtl8723d_lps_poff.h	41;"	d
-SET_HOIE_ENTRY_LOW_DATA	include/rtl8723d_lps_poff.h	31;"	d
-SET_HOIE_ENTRY_MODE_SELECT	include/rtl8723d_lps_poff.h	35;"	d
-SET_HOIE_ENTRY_RAW	include/rtl8723d_lps_poff.h	49;"	d
-SET_HOIE_ENTRY_RAW_RW	include/rtl8723d_lps_poff.h	47;"	d
-SET_HOIE_ENTRY_RD_EN	include/rtl8723d_lps_poff.h	43;"	d
-SET_HOIE_ENTRY_WR_EN	include/rtl8723d_lps_poff.h	45;"	d
-SET_HT_CAP_ELE_CHL_WIDTH	include/rtw_ht.h	126;"	d
-SET_HT_CAP_ELE_DELAYED_BA	include/rtw_ht.h	133;"	d
-SET_HT_CAP_ELE_DSSS_CCK_40M	include/rtw_ht.h	135;"	d
-SET_HT_CAP_ELE_FORTY_INTOLERANT	include/rtw_ht.h	136;"	d
-SET_HT_CAP_ELE_GREENFIELD	include/rtw_ht.h	128;"	d
-SET_HT_CAP_ELE_LDPC_CAP	include/rtw_ht.h	125;"	d
-SET_HT_CAP_ELE_LSIG_TXOP_PROTECT	include/rtw_ht.h	137;"	d
-SET_HT_CAP_ELE_MAX_AMSDU_LENGTH	include/rtw_ht.h	134;"	d
-SET_HT_CAP_ELE_RX_STBC	include/rtw_ht.h	132;"	d
-SET_HT_CAP_ELE_SHORT_GI20M	include/rtw_ht.h	129;"	d
-SET_HT_CAP_ELE_SHORT_GI40M	include/rtw_ht.h	130;"	d
-SET_HT_CAP_ELE_SM_PS	include/rtw_ht.h	127;"	d
-SET_HT_CAP_ELE_TX_STBC	include/rtw_ht.h	131;"	d
-SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS	include/rtw_ht.h	178;"	d
-SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS	include/rtw_ht.h	177;"	d
-SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP	include/rtw_ht.h	176;"	d
-SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP	include/rtw_ht.h	175;"	d
-SET_HT_CAP_TXBF_RECEIVE_NDP_CAP	include/rtw_ht.h	173;"	d
-SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP	include/rtw_ht.h	174;"	d
-SET_HT_CTRL_CSI_STEERING	include/rtw_ht.h	101;"	d
-SET_HT_CTRL_NDP_ANNOUNCEMENT	include/rtw_ht.h	102;"	d
-SET_HT_OP_ELE_2ND_CHL_OFFSET	include/rtw_ht.h	206;"	d
-SET_HT_OP_ELE_DUAL_BEACON	include/rtw_ht.h	212;"	d
-SET_HT_OP_ELE_DUAL_CTS	include/rtw_ht.h	213;"	d
-SET_HT_OP_ELE_HT_PROTECT	include/rtw_ht.h	209;"	d
-SET_HT_OP_ELE_LSIG_TXOP_PROTECT	include/rtw_ht.h	215;"	d
-SET_HT_OP_ELE_NON_GREEN_PRESENT	include/rtw_ht.h	210;"	d
-SET_HT_OP_ELE_OBSS_NON_HT_PRESENT	include/rtw_ht.h	211;"	d
-SET_HT_OP_ELE_PCO_ACTIVE	include/rtw_ht.h	216;"	d
-SET_HT_OP_ELE_PCO_PHASE	include/rtw_ht.h	217;"	d
-SET_HT_OP_ELE_PRI_CHL	include/rtw_ht.h	189;"	d
-SET_HT_OP_ELE_RIFS_MODE	include/rtw_ht.h	208;"	d
-SET_HT_OP_ELE_STA_CHL_WIDTH	include/rtw_ht.h	207;"	d
-SET_HT_OP_ELE_STBC_BEACON	include/rtw_ht.h	214;"	d
-SET_ICE_IV_LEN	include/rtw_security.h	276;"	d
-SET_INDIRECT_REG_ADDR	include/rtl8188f_spec.h	159;"	d
-SET_INDIRECT_REG_READ	include/rtl8188f_spec.h	164;"	d
-SET_INDIRECT_REG_SIZE_1BYTE	include/rtl8188f_spec.h	160;"	d
-SET_INDIRECT_REG_SIZE_2BYTE	include/rtl8188f_spec.h	161;"	d
-SET_INDIRECT_REG_SIZE_4BYTE	include/rtl8188f_spec.h	162;"	d
-SET_INDIRECT_REG_WRITE	include/rtl8188f_spec.h	163;"	d
-SET_NHM_SETTING	hal/phydm/phydm_ccx.h	6;"	d
-SET_NO_NEED	hal/phydm/phydm.h	102;"	d
-SET_OID	include/rtw_ioctl.h	/^	SET_OID$/;"	e	enum:oid_type
-SET_RX_BUFFER_DESC_DATA_LENGTH_8723D	include/rtl8723d_recv.h	77;"	d
-SET_RX_BUFFER_DESC_DATA_LENGTH_8814A	include/rtl8814a_recv.h	68;"	d
-SET_RX_BUFFER_DESC_DATA_LENGTH_92E	include/rtl8192e_recv.h	68;"	d
-SET_RX_BUFFER_DESC_FS_8723D	include/rtl8723d_recv.h	79;"	d
-SET_RX_BUFFER_DESC_FS_8814A	include/rtl8814a_recv.h	70;"	d
-SET_RX_BUFFER_DESC_FS_92E	include/rtl8192e_recv.h	70;"	d
-SET_RX_BUFFER_DESC_LS_8723D	include/rtl8723d_recv.h	78;"	d
-SET_RX_BUFFER_DESC_LS_8814A	include/rtl8814a_recv.h	69;"	d
-SET_RX_BUFFER_DESC_LS_92E	include/rtl8192e_recv.h	69;"	d
-SET_RX_BUFFER_DESC_TOTAL_LENGTH_8723D	include/rtl8723d_recv.h	80;"	d
-SET_RX_BUFFER_DESC_TOTAL_LENGTH_8814A	include/rtl8814a_recv.h	71;"	d
-SET_RX_BUFFER_DESC_TOTAL_LENGTH_92E	include/rtl8192e_recv.h	71;"	d
-SET_RX_BUFFER_PHYSICAL_HIGH_8723D	include/rtl8723d_recv.h	96;"	d
-SET_RX_BUFFER_PHYSICAL_HIGH_8723D	include/rtl8723d_recv.h	98;"	d
-SET_RX_BUFFER_PHYSICAL_HIGH_8814A	include/rtl8814a_recv.h	83;"	d
-SET_RX_BUFFER_PHYSICAL_HIGH_92E	include/rtl8192e_recv.h	84;"	d
-SET_RX_BUFFER_PHYSICAL_LOW_8723D	include/rtl8723d_recv.h	92;"	d
-SET_RX_BUFFER_PHYSICAL_LOW_8814A	include/rtl8814a_recv.h	79;"	d
-SET_RX_BUFFER_PHYSICAL_LOW_92E	include/rtl8192e_recv.h	80;"	d
-SET_RX_STATUS_DESC_BUFF_ADDR_8188F	include/rtl8188f_xmit.h	103;"	d
-SET_RX_STATUS_DESC_BUFF_ADDR_8703B	include/rtl8703b_xmit.h	103;"	d
-SET_RX_STATUS_DESC_BUFF_ADDR_8723B	include/rtl8723b_xmit.h	103;"	d
-SET_RX_STATUS_DESC_BUFF_ADDR_8723D	include/rtl8723d_xmit.h	148;"	d
-SET_RX_STATUS_DESC_BUFF_ADDR_8812	include/rtl8812a_recv.h	137;"	d
-SET_RX_STATUS_DESC_EOR_8188F	include/rtl8188f_xmit.h	36;"	d
-SET_RX_STATUS_DESC_EOR_8703B	include/rtl8703b_xmit.h	36;"	d
-SET_RX_STATUS_DESC_EOR_8723B	include/rtl8723b_xmit.h	36;"	d
-SET_RX_STATUS_DESC_EOR_8723D	include/rtl8723d_xmit.h	37;"	d
-SET_RX_STATUS_DESC_EOR_8812	include/rtl8812a_recv.h	70;"	d
-SET_RX_STATUS_DESC_EOR_8814A	include/rtl8814a_recv.h	95;"	d
-SET_RX_STATUS_DESC_EOR_92E	include/rtl8192e_recv.h	103;"	d
-SET_RX_STATUS_DESC_OWN_8188F	include/rtl8188f_xmit.h	37;"	d
-SET_RX_STATUS_DESC_OWN_8703B	include/rtl8703b_xmit.h	37;"	d
-SET_RX_STATUS_DESC_OWN_8723B	include/rtl8723b_xmit.h	37;"	d
-SET_RX_STATUS_DESC_OWN_8723D	include/rtl8723d_xmit.h	39;"	d
-SET_RX_STATUS_DESC_OWN_8812	include/rtl8812a_recv.h	71;"	d
-SET_RX_STATUS_DESC_OWN_8814AE	include/rtl8814a_recv.h	96;"	d
-SET_RX_STATUS_DESC_OWN_92E	include/rtl8192e_recv.h	104;"	d
-SET_RX_STATUS_DESC_PKT_LEN_8188F	include/rtl8188f_xmit.h	35;"	d
-SET_RX_STATUS_DESC_PKT_LEN_8703B	include/rtl8703b_xmit.h	35;"	d
-SET_RX_STATUS_DESC_PKT_LEN_8723B	include/rtl8723b_xmit.h	35;"	d
-SET_RX_STATUS_DESC_PKT_LEN_8723D	include/rtl8723d_xmit.h	35;"	d
-SET_RX_STATUS_DESC_PKT_LEN_8812	include/rtl8812a_recv.h	69;"	d
-SET_RX_STATUS_DESC_PKT_LEN_8814A	include/rtl8814a_recv.h	94;"	d
-SET_RX_STATUS_DESC_PKT_LEN_92E	include/rtl8192e_recv.h	102;"	d
-SET_SUCCESS	hal/phydm/phydm.h	100;"	d
-SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET	include/rtl8192e_xmit.h	211;"	d
-SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET	include/rtl8723d_xmit.h	345;"	d
-SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET	include/rtl8723d_xmit.h	350;"	d
-SET_TXBUFFER_DESC_ADD_HIGT_WITH_OFFSET	include/rtl8814a_xmit.h	74;"	d
-SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET	include/rtl8192e_xmit.h	210;"	d
-SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET	include/rtl8723d_xmit.h	344;"	d
-SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET	include/rtl8723d_xmit.h	349;"	d
-SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET	include/rtl8814a_xmit.h	68;"	d
-SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET	include/rtl8814a_xmit.h	72;"	d
-SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET	include/rtl8192e_xmit.h	209;"	d
-SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET	include/rtl8723d_xmit.h	343;"	d
-SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET	include/rtl8723d_xmit.h	348;"	d
-SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET	include/rtl8814a_xmit.h	67;"	d
-SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET	include/rtl8814a_xmit.h	71;"	d
-SET_TXBUFFER_DESC_LEN_WITH_OFFSET	include/rtl8192e_xmit.h	208;"	d
-SET_TXBUFFER_DESC_LEN_WITH_OFFSET	include/rtl8723d_xmit.h	342;"	d
-SET_TXBUFFER_DESC_LEN_WITH_OFFSET	include/rtl8723d_xmit.h	347;"	d
-SET_TXBUFFER_DESC_LEN_WITH_OFFSET	include/rtl8814a_xmit.h	66;"	d
-SET_TXBUFFER_DESC_LEN_WITH_OFFSET	include/rtl8814a_xmit.h	70;"	d
-SET_TX_BUFF_DESC_ADDR_HIGH_0_8723D	include/rtl8723d_xmit.h	365;"	d
-SET_TX_BUFF_DESC_ADDR_HIGH_0_8814A	include/rtl8814a_xmit.h	90;"	d
-SET_TX_BUFF_DESC_ADDR_HIGH_0_92E	include/rtl8192e_xmit.h	224;"	d
-SET_TX_BUFF_DESC_ADDR_HIGH_1_8723D	include/rtl8723d_xmit.h	379;"	d
-SET_TX_BUFF_DESC_ADDR_HIGH_2_8723D	include/rtl8723d_xmit.h	388;"	d
-SET_TX_BUFF_DESC_ADDR_HIGH_3_8723D	include/rtl8723d_xmit.h	397;"	d
-SET_TX_BUFF_DESC_ADDR_LOW_0_8723D	include/rtl8723d_xmit.h	362;"	d
-SET_TX_BUFF_DESC_ADDR_LOW_0_8814A	include/rtl8814a_xmit.h	87;"	d
-SET_TX_BUFF_DESC_ADDR_LOW_0_92E	include/rtl8192e_xmit.h	219;"	d
-SET_TX_BUFF_DESC_ADDR_LOW_1_8723D	include/rtl8723d_xmit.h	377;"	d
-SET_TX_BUFF_DESC_ADDR_LOW_2_8723D	include/rtl8723d_xmit.h	386;"	d
-SET_TX_BUFF_DESC_ADDR_LOW_3_8723D	include/rtl8723d_xmit.h	395;"	d
-SET_TX_BUFF_DESC_AMSDU_1_8723D	include/rtl8723d_xmit.h	375;"	d
-SET_TX_BUFF_DESC_AMSDU_2_8723D	include/rtl8723d_xmit.h	384;"	d
-SET_TX_BUFF_DESC_AMSDU_3_8723D	include/rtl8723d_xmit.h	393;"	d
-SET_TX_BUFF_DESC_LEN_0_8723D	include/rtl8723d_xmit.h	357;"	d
-SET_TX_BUFF_DESC_LEN_0_8814A	include/rtl8814a_xmit.h	81;"	d
-SET_TX_BUFF_DESC_LEN_0_92E	include/rtl8192e_xmit.h	215;"	d
-SET_TX_BUFF_DESC_LEN_1_8723D	include/rtl8723d_xmit.h	374;"	d
-SET_TX_BUFF_DESC_LEN_2_8723D	include/rtl8723d_xmit.h	383;"	d
-SET_TX_BUFF_DESC_LEN_3_8723D	include/rtl8723d_xmit.h	392;"	d
-SET_TX_BUFF_DESC_OWN_8723D	include/rtl8723d_xmit.h	359;"	d
-SET_TX_BUFF_DESC_OWN_8814A	include/rtl8814a_xmit.h	83;"	d
-SET_TX_BUFF_DESC_OWN_92E	include/rtl8192e_xmit.h	217;"	d
-SET_TX_BUFF_DESC_PSB_8723D	include/rtl8723d_xmit.h	358;"	d
-SET_TX_BUFF_DESC_PSB_8814A	include/rtl8814a_xmit.h	82;"	d
-SET_TX_BUFF_DESC_PSB_92E	include/rtl8192e_xmit.h	216;"	d
-SET_TX_DESC_AGG_BREAK_8188F	include/rtl8188f_xmit.h	137;"	d
-SET_TX_DESC_AGG_BREAK_8703B	include/rtl8703b_xmit.h	137;"	d
-SET_TX_DESC_AGG_BREAK_8723B	include/rtl8723b_xmit.h	137;"	d
-SET_TX_DESC_AGG_BREAK_8812	include/rtl8812a_xmit.h	232;"	d
-SET_TX_DESC_AGG_ENABLE_8188F	include/rtl8188f_xmit.h	135;"	d
-SET_TX_DESC_AGG_ENABLE_8703B	include/rtl8703b_xmit.h	135;"	d
-SET_TX_DESC_AGG_ENABLE_8723B	include/rtl8723b_xmit.h	135;"	d
-SET_TX_DESC_AGG_ENABLE_8723D	include/rtl8723d_xmit.h	196;"	d
-SET_TX_DESC_AGG_ENABLE_8812	include/rtl8812a_xmit.h	230;"	d
-SET_TX_DESC_AGG_ENABLE_8814A	include/rtl8814a_xmit.h	156;"	d
-SET_TX_DESC_AGG_ENABLE_92E	include/rtl8192e_xmit.h	260;"	d
-SET_TX_DESC_AMPDU_DENSITY_8188F	include/rtl8188f_xmit.h	141;"	d
-SET_TX_DESC_AMPDU_DENSITY_8703B	include/rtl8703b_xmit.h	141;"	d
-SET_TX_DESC_AMPDU_DENSITY_8723B	include/rtl8723b_xmit.h	141;"	d
-SET_TX_DESC_AMPDU_DENSITY_8723D	include/rtl8723d_xmit.h	212;"	d
-SET_TX_DESC_AMPDU_DENSITY_8812	include/rtl8812a_xmit.h	236;"	d
-SET_TX_DESC_AMPDU_DENSITY_8814A	include/rtl8814a_xmit.h	165;"	d
-SET_TX_DESC_AMPDU_DENSITY_92E	include/rtl8192e_xmit.h	269;"	d
-SET_TX_DESC_AMPDU_MAX_TIME_8188F	include/rtl8188f_xmit.h	161;"	d
-SET_TX_DESC_AMPDU_MAX_TIME_8703B	include/rtl8703b_xmit.h	161;"	d
-SET_TX_DESC_AMPDU_MAX_TIME_8723B	include/rtl8723b_xmit.h	161;"	d
-SET_TX_DESC_AMPDU_MAX_TIME_8723D	include/rtl8723d_xmit.h	241;"	d
-SET_TX_DESC_AMPDU_MAX_TIME_8812	include/rtl8812a_xmit.h	255;"	d
-SET_TX_DESC_AMPDU_MAX_TIME_8814A	include/rtl8814a_xmit.h	186;"	d
-SET_TX_DESC_AMPDU_MAX_TIME_92E	include/rtl8192e_xmit.h	290;"	d
-SET_TX_DESC_AMSDU_PAD_EN_8723D	include/rtl8723d_xmit.h	164;"	d
-SET_TX_DESC_AMSDU_PAD_EN_8814A	include/rtl8814a_xmit.h	133;"	d
-SET_TX_DESC_ANTSEL_A_8188F	include/rtl8188f_xmit.h	186;"	d
-SET_TX_DESC_ANTSEL_A_8703B	include/rtl8703b_xmit.h	186;"	d
-SET_TX_DESC_ANTSEL_A_8723B	include/rtl8723b_xmit.h	186;"	d
-SET_TX_DESC_ANTSEL_A_8812	include/rtl8812a_xmit.h	278;"	d
-SET_TX_DESC_ANTSEL_A_8814A	include/rtl8814a_xmit.h	217;"	d
-SET_TX_DESC_ANTSEL_A_88E	hal/phydm/phydm_types.h	237;"	d
-SET_TX_DESC_ANTSEL_A_92E	include/rtl8192e_xmit.h	319;"	d
-SET_TX_DESC_ANTSEL_B_8188F	include/rtl8188f_xmit.h	187;"	d
-SET_TX_DESC_ANTSEL_B_8703B	include/rtl8703b_xmit.h	187;"	d
-SET_TX_DESC_ANTSEL_B_8723B	include/rtl8723b_xmit.h	187;"	d
-SET_TX_DESC_ANTSEL_B_8812	include/rtl8812a_xmit.h	279;"	d
-SET_TX_DESC_ANTSEL_B_8814A	include/rtl8814a_xmit.h	218;"	d
-SET_TX_DESC_ANTSEL_B_88E	hal/phydm/phydm_types.h	238;"	d
-SET_TX_DESC_ANTSEL_B_92E	include/rtl8192e_xmit.h	320;"	d
-SET_TX_DESC_ANTSEL_C_8188F	include/rtl8188f_xmit.h	188;"	d
-SET_TX_DESC_ANTSEL_C_8703B	include/rtl8703b_xmit.h	188;"	d
-SET_TX_DESC_ANTSEL_C_8723B	include/rtl8723b_xmit.h	188;"	d
-SET_TX_DESC_ANTSEL_C_8812	include/rtl8812a_xmit.h	280;"	d
-SET_TX_DESC_ANTSEL_C_88E	hal/phydm/phydm_types.h	239;"	d
-SET_TX_DESC_ANTSEL_C_92E	include/rtl8192e_xmit.h	321;"	d
-SET_TX_DESC_ANTSEL_D_8188F	include/rtl8188f_xmit.h	189;"	d
-SET_TX_DESC_ANTSEL_D_8703B	include/rtl8703b_xmit.h	189;"	d
-SET_TX_DESC_ANTSEL_D_8723B	include/rtl8723b_xmit.h	189;"	d
-SET_TX_DESC_ANTSEL_D_8812	include/rtl8812a_xmit.h	281;"	d
-SET_TX_DESC_ANTSEL_D_92E	include/rtl8192e_xmit.h	322;"	d
-SET_TX_DESC_ANT_MAPA_8814A	include/rtl8814a_xmit.h	219;"	d
-SET_TX_DESC_ANT_MAPB_8814A	include/rtl8814a_xmit.h	220;"	d
-SET_TX_DESC_ANT_MAPC_8814A	include/rtl8814a_xmit.h	221;"	d
-SET_TX_DESC_ANT_MAPD_8814A	include/rtl8814a_xmit.h	222;"	d
-SET_TX_DESC_BAR_RC_8723D	include/rtl8723d_xmit.h	310;"	d
-SET_TX_DESC_BAR_RTY_TH_8814A	include/rtl8814a_xmit.h	237;"	d
-SET_TX_DESC_BAR_RTY_TH_92E	include/rtl8192e_xmit.h	337;"	d
-SET_TX_DESC_BK_8723D	include/rtl8723d_xmit.h	204;"	d
-SET_TX_DESC_BK_8814A	include/rtl8814a_xmit.h	160;"	d
-SET_TX_DESC_BK_92E	include/rtl8192e_xmit.h	264;"	d
-SET_TX_DESC_BMC_8188F	include/rtl8188f_xmit.h	111;"	d
-SET_TX_DESC_BMC_8703B	include/rtl8703b_xmit.h	111;"	d
-SET_TX_DESC_BMC_8723B	include/rtl8723b_xmit.h	111;"	d
-SET_TX_DESC_BMC_8723D	include/rtl8723d_xmit.h	160;"	d
-SET_TX_DESC_BMC_8812	include/rtl8812a_xmit.h	207;"	d
-SET_TX_DESC_BMC_8814A	include/rtl8814a_xmit.h	129;"	d
-SET_TX_DESC_BMC_92E	include/rtl8192e_xmit.h	232;"	d
-SET_TX_DESC_BT_INT_8188F	include/rtl8188f_xmit.h	142;"	d
-SET_TX_DESC_BT_INT_8703B	include/rtl8703b_xmit.h	142;"	d
-SET_TX_DESC_BT_INT_8723B	include/rtl8723b_xmit.h	142;"	d
-SET_TX_DESC_BT_INT_8723D	include/rtl8723d_xmit.h	214;"	d
-SET_TX_DESC_BT_INT_8812	include/rtl8812a_xmit.h	237;"	d
-SET_TX_DESC_BT_NULL_8814A	include/rtl8814a_xmit.h	166;"	d
-SET_TX_DESC_BT_NULL_92E	include/rtl8192e_xmit.h	270;"	d
-SET_TX_DESC_CCA_RTS_8188F	include/rtl8188f_xmit.h	134;"	d
-SET_TX_DESC_CCA_RTS_8703B	include/rtl8703b_xmit.h	134;"	d
-SET_TX_DESC_CCA_RTS_8723B	include/rtl8723b_xmit.h	134;"	d
-SET_TX_DESC_CCA_RTS_8723D	include/rtl8723d_xmit.h	194;"	d
-SET_TX_DESC_CCA_RTS_8812	include/rtl8812a_xmit.h	229;"	d
-SET_TX_DESC_CCA_RTS_8814A	include/rtl8814a_xmit.h	155;"	d
-SET_TX_DESC_CCA_RTS_92E	include/rtl8192e_xmit.h	259;"	d
-SET_TX_DESC_CCX_8723D	include/rtl8723d_xmit.h	210;"	d
-SET_TX_DESC_CHECK_EN_8814A	include/rtl8814a_xmit.h	181;"	d
-SET_TX_DESC_CHK_EN_8188F	include/rtl8188f_xmit.h	148;"	d
-SET_TX_DESC_CHK_EN_8703B	include/rtl8703b_xmit.h	148;"	d
-SET_TX_DESC_CHK_EN_8723B	include/rtl8723b_xmit.h	148;"	d
-SET_TX_DESC_CHK_EN_8812	include/rtl8812a_xmit.h	242;"	d
-SET_TX_DESC_CHK_EN_92E	include/rtl8192e_xmit.h	276;"	d
-SET_TX_DESC_CTROL_STBC_8188F	include/rtl8188f_xmit.h	178;"	d
-SET_TX_DESC_CTROL_STBC_8703B	include/rtl8703b_xmit.h	178;"	d
-SET_TX_DESC_CTROL_STBC_8723B	include/rtl8723b_xmit.h	178;"	d
-SET_TX_DESC_CTROL_STBC_8812	include/rtl8812a_xmit.h	271;"	d
-SET_TX_DESC_CTROL_STBC_8814A	include/rtl8814a_xmit.h	206;"	d
-SET_TX_DESC_CTS2SELF_8188F	include/rtl8188f_xmit.h	154;"	d
-SET_TX_DESC_CTS2SELF_8703B	include/rtl8703b_xmit.h	154;"	d
-SET_TX_DESC_CTS2SELF_8723B	include/rtl8723b_xmit.h	154;"	d
-SET_TX_DESC_CTS2SELF_8723D	include/rtl8723d_xmit.h	229;"	d
-SET_TX_DESC_CTS2SELF_8812	include/rtl8812a_xmit.h	248;"	d
-SET_TX_DESC_CTS2SELF_8814A	include/rtl8814a_xmit.h	178;"	d
-SET_TX_DESC_CTS2SELF_92E	include/rtl8192e_xmit.h	282;"	d
-SET_TX_DESC_DATA_BW_8188F	include/rtl8188f_xmit.h	175;"	d
-SET_TX_DESC_DATA_BW_8703B	include/rtl8703b_xmit.h	175;"	d
-SET_TX_DESC_DATA_BW_8723B	include/rtl8723b_xmit.h	175;"	d
-SET_TX_DESC_DATA_BW_8723D	include/rtl8723d_xmit.h	269;"	d
-SET_TX_DESC_DATA_BW_8812	include/rtl8812a_xmit.h	268;"	d
-SET_TX_DESC_DATA_BW_8814A	include/rtl8814a_xmit.h	203;"	d
-SET_TX_DESC_DATA_BW_92E	include/rtl8192e_xmit.h	307;"	d
-SET_TX_DESC_DATA_LDPC_8188F	include/rtl8188f_xmit.h	176;"	d
-SET_TX_DESC_DATA_LDPC_8703B	include/rtl8703b_xmit.h	176;"	d
-SET_TX_DESC_DATA_LDPC_8723B	include/rtl8723b_xmit.h	176;"	d
-SET_TX_DESC_DATA_LDPC_8812	include/rtl8812a_xmit.h	269;"	d
-SET_TX_DESC_DATA_LDPC_8814A	include/rtl8814a_xmit.h	204;"	d
-SET_TX_DESC_DATA_LDPC_92E	include/rtl8192e_xmit.h	308;"	d
-SET_TX_DESC_DATA_RATE_FB_LIMIT_8188F	include/rtl8188f_xmit.h	165;"	d
-SET_TX_DESC_DATA_RATE_FB_LIMIT_8703B	include/rtl8703b_xmit.h	165;"	d
-SET_TX_DESC_DATA_RATE_FB_LIMIT_8723B	include/rtl8723b_xmit.h	165;"	d
-SET_TX_DESC_DATA_RATE_FB_LIMIT_8723D	include/rtl8723d_xmit.h	249;"	d
-SET_TX_DESC_DATA_RATE_FB_LIMIT_8812	include/rtl8812a_xmit.h	259;"	d
-SET_TX_DESC_DATA_RATE_FB_LIMIT_8814A	include/rtl8814a_xmit.h	191;"	d
-SET_TX_DESC_DATA_RATE_FB_LIMIT_92E	include/rtl8192e_xmit.h	295;"	d
-SET_TX_DESC_DATA_RC_8723D	include/rtl8723d_xmit.h	312;"	d
-SET_TX_DESC_DATA_RC_8814A	include/rtl8814a_xmit.h	238;"	d
-SET_TX_DESC_DATA_RC_92E	include/rtl8192e_xmit.h	338;"	d
-SET_TX_DESC_DATA_RETRY_LIMIT_8188F	include/rtl8188f_xmit.h	168;"	d
-SET_TX_DESC_DATA_RETRY_LIMIT_8703B	include/rtl8703b_xmit.h	168;"	d
-SET_TX_DESC_DATA_RETRY_LIMIT_8723B	include/rtl8723b_xmit.h	168;"	d
-SET_TX_DESC_DATA_RETRY_LIMIT_8723D	include/rtl8723d_xmit.h	255;"	d
-SET_TX_DESC_DATA_RETRY_LIMIT_8812	include/rtl8812a_xmit.h	262;"	d
-SET_TX_DESC_DATA_RETRY_LIMIT_8814A	include/rtl8814a_xmit.h	194;"	d
-SET_TX_DESC_DATA_RETRY_LIMIT_92E	include/rtl8192e_xmit.h	298;"	d
-SET_TX_DESC_DATA_SC_8188F	include/rtl8188f_xmit.h	173;"	d
-SET_TX_DESC_DATA_SC_8703B	include/rtl8703b_xmit.h	173;"	d
-SET_TX_DESC_DATA_SC_8723B	include/rtl8723b_xmit.h	173;"	d
-SET_TX_DESC_DATA_SC_8723D	include/rtl8723d_xmit.h	265;"	d
-SET_TX_DESC_DATA_SC_8812	include/rtl8812a_xmit.h	266;"	d
-SET_TX_DESC_DATA_SC_8814A	include/rtl8814a_xmit.h	201;"	d
-SET_TX_DESC_DATA_SC_92E	include/rtl8192e_xmit.h	305;"	d
-SET_TX_DESC_DATA_SHORT_8188F	include/rtl8188f_xmit.h	174;"	d
-SET_TX_DESC_DATA_SHORT_8703B	include/rtl8703b_xmit.h	174;"	d
-SET_TX_DESC_DATA_SHORT_8723B	include/rtl8723b_xmit.h	174;"	d
-SET_TX_DESC_DATA_SHORT_8723D	include/rtl8723d_xmit.h	267;"	d
-SET_TX_DESC_DATA_SHORT_8812	include/rtl8812a_xmit.h	267;"	d
-SET_TX_DESC_DATA_SHORT_8814A	include/rtl8814a_xmit.h	202;"	d
-SET_TX_DESC_DATA_SHORT_92E	include/rtl8192e_xmit.h	306;"	d
-SET_TX_DESC_DATA_STBC_8188F	include/rtl8188f_xmit.h	177;"	d
-SET_TX_DESC_DATA_STBC_8703B	include/rtl8703b_xmit.h	177;"	d
-SET_TX_DESC_DATA_STBC_8723B	include/rtl8723b_xmit.h	177;"	d
-SET_TX_DESC_DATA_STBC_8723D	include/rtl8723d_xmit.h	271;"	d
-SET_TX_DESC_DATA_STBC_8812	include/rtl8812a_xmit.h	270;"	d
-SET_TX_DESC_DATA_STBC_8814A	include/rtl8814a_xmit.h	205;"	d
-SET_TX_DESC_DATA_STBC_92E	include/rtl8192e_xmit.h	309;"	d
-SET_TX_DESC_DISABLE_FB_8188F	include/rtl8188f_xmit.h	153;"	d
-SET_TX_DESC_DISABLE_FB_8703B	include/rtl8703b_xmit.h	153;"	d
-SET_TX_DESC_DISABLE_FB_8723B	include/rtl8723b_xmit.h	153;"	d
-SET_TX_DESC_DISABLE_FB_8723D	include/rtl8723d_xmit.h	227;"	d
-SET_TX_DESC_DISABLE_FB_8812	include/rtl8812a_xmit.h	247;"	d
-SET_TX_DESC_DISABLE_FB_8814A	include/rtl8814a_xmit.h	177;"	d
-SET_TX_DESC_DISABLE_FB_92E	include/rtl8192e_xmit.h	281;"	d
-SET_TX_DESC_DISABLE_RTS_FB_8188F	include/rtl8188f_xmit.h	152;"	d
-SET_TX_DESC_DISABLE_RTS_FB_8703B	include/rtl8703b_xmit.h	152;"	d
-SET_TX_DESC_DISABLE_RTS_FB_8723B	include/rtl8723b_xmit.h	152;"	d
-SET_TX_DESC_DISABLE_RTS_FB_8723D	include/rtl8723d_xmit.h	225;"	d
-SET_TX_DESC_DISABLE_RTS_FB_8812	include/rtl8812a_xmit.h	246;"	d
-SET_TX_DESC_DISABLE_RTS_FB_8814A	include/rtl8814a_xmit.h	176;"	d
-SET_TX_DESC_DISABLE_RTS_FB_92E	include/rtl8192e_xmit.h	280;"	d
-SET_TX_DESC_DISQSELSEQ_8814A	include/rtl8814a_xmit.h	136;"	d
-SET_TX_DESC_EARLY_MODE_8188F	include/rtl8188f_xmit.h	149;"	d
-SET_TX_DESC_EARLY_MODE_8703B	include/rtl8703b_xmit.h	149;"	d
-SET_TX_DESC_EARLY_MODE_8723B	include/rtl8723b_xmit.h	149;"	d
-SET_TX_DESC_EARLY_MODE_8812	include/rtl8812a_xmit.h	243;"	d
-SET_TX_DESC_EARLY_RATE_8814A	include/rtl8814a_xmit.h	173;"	d
-SET_TX_DESC_EARLY_RATE_92E	include/rtl8192e_xmit.h	277;"	d
-SET_TX_DESC_EN_DESC_ID_8188F	include/rtl8188f_xmit.h	127;"	d
-SET_TX_DESC_EN_DESC_ID_8703B	include/rtl8703b_xmit.h	127;"	d
-SET_TX_DESC_EN_DESC_ID_8723B	include/rtl8723b_xmit.h	127;"	d
-SET_TX_DESC_EN_DESC_ID_8723D	include/rtl8723d_xmit.h	184;"	d
-SET_TX_DESC_EN_DESC_ID_8812	include/rtl8812a_xmit.h	223;"	d
-SET_TX_DESC_EN_DESC_ID_8814A	include/rtl8814a_xmit.h	145;"	d
-SET_TX_DESC_EN_DESC_ID_92E	include/rtl8192e_xmit.h	249;"	d
-SET_TX_DESC_EN_HWEXSEQ_8814A	include/rtl8814a_xmit.h	239;"	d
-SET_TX_DESC_EN_HWSEQ_92E	include/rtl8192e_xmit.h	339;"	d
-SET_TX_DESC_FINAL_DATA_RATE_8723D	include/rtl8723d_xmit.h	326;"	d
-SET_TX_DESC_FINAL_DATA_RATE_92E	include/rtl8192e_xmit.h	347;"	d
-SET_TX_DESC_FIRST_SEG_8188F	include/rtl8188f_xmit.h	114;"	d
-SET_TX_DESC_FIRST_SEG_8703B	include/rtl8703b_xmit.h	114;"	d
-SET_TX_DESC_FIRST_SEG_8723B	include/rtl8723b_xmit.h	114;"	d
-SET_TX_DESC_FIRST_SEG_8812	include/rtl8812a_xmit.h	210;"	d
-SET_TX_DESC_FIRST_SEG_92E	include/rtl8192e_xmit.h	235;"	d
-SET_TX_DESC_FTM_EN_8723D	include/rtl8723d_xmit.h	216;"	d
-SET_TX_DESC_GF_8188F	include/rtl8188f_xmit.h	117;"	d
-SET_TX_DESC_GF_8703B	include/rtl8703b_xmit.h	117;"	d
-SET_TX_DESC_GF_8723B	include/rtl8723b_xmit.h	117;"	d
-SET_TX_DESC_GF_8723D	include/rtl8723d_xmit.h	168;"	d
-SET_TX_DESC_GF_8812	include/rtl8812a_xmit.h	213;"	d
-SET_TX_DESC_GF_8814A	include/rtl8814a_xmit.h	135;"	d
-SET_TX_DESC_GF_92E	include/rtl8192e_xmit.h	238;"	d
-SET_TX_DESC_GID_8188F	include/rtl8188f_xmit.h	143;"	d
-SET_TX_DESC_GID_8703B	include/rtl8703b_xmit.h	143;"	d
-SET_TX_DESC_GID_8723B	include/rtl8723b_xmit.h	143;"	d
-SET_TX_DESC_GID_8812	include/rtl8812a_xmit.h	238;"	d
-SET_TX_DESC_GID_8814A	include/rtl8814a_xmit.h	167;"	d
-SET_TX_DESC_GID_92E	include/rtl8192e_xmit.h	271;"	d
-SET_TX_DESC_HTC_8188F	include/rtl8188f_xmit.h	112;"	d
-SET_TX_DESC_HTC_8703B	include/rtl8703b_xmit.h	112;"	d
-SET_TX_DESC_HTC_8723B	include/rtl8723b_xmit.h	112;"	d
-SET_TX_DESC_HTC_8723D	include/rtl8723d_xmit.h	162;"	d
-SET_TX_DESC_HTC_8812	include/rtl8812a_xmit.h	208;"	d
-SET_TX_DESC_HTC_8814A	include/rtl8814a_xmit.h	130;"	d
-SET_TX_DESC_HTC_92E	include/rtl8192e_xmit.h	233;"	d
-SET_TX_DESC_HWSEQ_EN_8188F	include/rtl8188f_xmit.h	203;"	d
-SET_TX_DESC_HWSEQ_EN_8703B	include/rtl8703b_xmit.h	203;"	d
-SET_TX_DESC_HWSEQ_EN_8723B	include/rtl8723b_xmit.h	203;"	d
-SET_TX_DESC_HWSEQ_EN_8723D	include/rtl8723d_xmit.h	314;"	d
-SET_TX_DESC_HWSEQ_EN_8812	include/rtl8812a_xmit.h	293;"	d
-SET_TX_DESC_HWSEQ_EN_8814A	include/rtl8814a_xmit.h	240;"	d
-SET_TX_DESC_HWSEQ_SEL_8188F	include/rtl8188f_xmit.h	150;"	d
-SET_TX_DESC_HWSEQ_SEL_8703B	include/rtl8703b_xmit.h	150;"	d
-SET_TX_DESC_HWSEQ_SEL_8723B	include/rtl8723b_xmit.h	150;"	d
-SET_TX_DESC_HWSEQ_SEL_8723D	include/rtl8723d_xmit.h	222;"	d
-SET_TX_DESC_HWSEQ_SEL_8812	include/rtl8812a_xmit.h	244;"	d
-SET_TX_DESC_HWSEQ_SEL_92E	include/rtl8192e_xmit.h	278;"	d
-SET_TX_DESC_HW_AES_IV_8814A	include/rtl8814a_xmit.h	168;"	d
-SET_TX_DESC_HW_PORT_ID_92E	include/rtl8192e_xmit.h	285;"	d
-SET_TX_DESC_HW_RTS_ENABLE_8188F	include/rtl8188f_xmit.h	156;"	d
-SET_TX_DESC_HW_RTS_ENABLE_8703B	include/rtl8703b_xmit.h	156;"	d
-SET_TX_DESC_HW_RTS_ENABLE_8723B	include/rtl8723b_xmit.h	156;"	d
-SET_TX_DESC_HW_RTS_ENABLE_8723D	include/rtl8723d_xmit.h	233;"	d
-SET_TX_DESC_HW_RTS_ENABLE_8812	include/rtl8812a_xmit.h	250;"	d
-SET_TX_DESC_HW_RTS_ENABLE_8814A	include/rtl8814a_xmit.h	180;"	d
-SET_TX_DESC_HW_RTS_ENABLE_92E	include/rtl8192e_xmit.h	284;"	d
-SET_TX_DESC_HW_SSN_SEL_8814A	include/rtl8814a_xmit.h	174;"	d
-SET_TX_DESC_LAST_SEG_8188F	include/rtl8188f_xmit.h	113;"	d
-SET_TX_DESC_LAST_SEG_8703B	include/rtl8703b_xmit.h	113;"	d
-SET_TX_DESC_LAST_SEG_8723B	include/rtl8723b_xmit.h	113;"	d
-SET_TX_DESC_LAST_SEG_8812	include/rtl8812a_xmit.h	209;"	d
-SET_TX_DESC_LAST_SEG_8814A	include/rtl8814a_xmit.h	131;"	d
-SET_TX_DESC_LAST_SEG_92E	include/rtl8192e_xmit.h	234;"	d
-SET_TX_DESC_LINIP_8188F	include/rtl8188f_xmit.h	115;"	d
-SET_TX_DESC_LINIP_8703B	include/rtl8703b_xmit.h	115;"	d
-SET_TX_DESC_LINIP_8723B	include/rtl8723b_xmit.h	115;"	d
-SET_TX_DESC_LINIP_8812	include/rtl8812a_xmit.h	211;"	d
-SET_TX_DESC_LINIP_8814A	include/rtl8814a_xmit.h	132;"	d
-SET_TX_DESC_LINIP_92E	include/rtl8192e_xmit.h	236;"	d
-SET_TX_DESC_LSIG_TXOP_EN_8188F	include/rtl8188f_xmit.h	124;"	d
-SET_TX_DESC_LSIG_TXOP_EN_8703B	include/rtl8703b_xmit.h	124;"	d
-SET_TX_DESC_LSIG_TXOP_EN_8723B	include/rtl8723b_xmit.h	124;"	d
-SET_TX_DESC_LSIG_TXOP_EN_8723D	include/rtl8723d_xmit.h	178;"	d
-SET_TX_DESC_LSIG_TXOP_EN_8812	include/rtl8812a_xmit.h	220;"	d
-SET_TX_DESC_LSIG_TXOP_EN_8814A	include/rtl8814a_xmit.h	142;"	d
-SET_TX_DESC_LSIG_TXOP_EN_92E	include/rtl8192e_xmit.h	246;"	d
-SET_TX_DESC_MACID_8188F	include/rtl8188f_xmit.h	121;"	d
-SET_TX_DESC_MACID_8703B	include/rtl8703b_xmit.h	121;"	d
-SET_TX_DESC_MACID_8723B	include/rtl8723b_xmit.h	121;"	d
-SET_TX_DESC_MACID_8723D	include/rtl8723d_xmit.h	172;"	d
-SET_TX_DESC_MACID_8812	include/rtl8812a_xmit.h	217;"	d
-SET_TX_DESC_MACID_8814A	include/rtl8814a_xmit.h	139;"	d
-SET_TX_DESC_MACID_92E	include/rtl8192e_xmit.h	243;"	d
-SET_TX_DESC_MAX_AGG_NUM_8188F	include/rtl8188f_xmit.h	159;"	d
-SET_TX_DESC_MAX_AGG_NUM_8703B	include/rtl8703b_xmit.h	159;"	d
-SET_TX_DESC_MAX_AGG_NUM_8723B	include/rtl8723b_xmit.h	159;"	d
-SET_TX_DESC_MAX_AGG_NUM_8723D	include/rtl8723d_xmit.h	239;"	d
-SET_TX_DESC_MAX_AGG_NUM_8812	include/rtl8812a_xmit.h	253;"	d
-SET_TX_DESC_MAX_AGG_NUM_8814A	include/rtl8814a_xmit.h	184;"	d
-SET_TX_DESC_MAX_AGG_NUM_92E	include/rtl8192e_xmit.h	288;"	d
-SET_TX_DESC_MBSSID_8188F	include/rtl8188f_xmit.h	185;"	d
-SET_TX_DESC_MBSSID_8703B	include/rtl8703b_xmit.h	185;"	d
-SET_TX_DESC_MBSSID_8723B	include/rtl8723b_xmit.h	185;"	d
-SET_TX_DESC_MBSSID_8723D	include/rtl8723d_xmit.h	287;"	d
-SET_TX_DESC_MBSSID_8814A	include/rtl8814a_xmit.h	216;"	d
-SET_TX_DESC_MBSSID_8821	include/rtl8812a_xmit.h	282;"	d
-SET_TX_DESC_MBSSID_92E	include/rtl8192e_xmit.h	318;"	d
-SET_TX_DESC_MORE_DATA_8723D	include/rtl8723d_xmit.h	190;"	d
-SET_TX_DESC_MORE_DATA_8814A	include/rtl8814a_xmit.h	148;"	d
-SET_TX_DESC_MORE_DATA_92E	include/rtl8192e_xmit.h	252;"	d
-SET_TX_DESC_MORE_FRAG_8188F	include/rtl8188f_xmit.h	138;"	d
-SET_TX_DESC_MORE_FRAG_8703B	include/rtl8703b_xmit.h	138;"	d
-SET_TX_DESC_MORE_FRAG_8723B	include/rtl8723b_xmit.h	138;"	d
-SET_TX_DESC_MORE_FRAG_8723D	include/rtl8723d_xmit.h	206;"	d
-SET_TX_DESC_MORE_FRAG_8812	include/rtl8812a_xmit.h	233;"	d
-SET_TX_DESC_MORE_FRAG_8814A	include/rtl8814a_xmit.h	161;"	d
-SET_TX_DESC_MORE_FRAG_92E	include/rtl8192e_xmit.h	265;"	d
-SET_TX_DESC_NAV_USE_HDR_8188F	include/rtl8188f_xmit.h	157;"	d
-SET_TX_DESC_NAV_USE_HDR_8703B	include/rtl8703b_xmit.h	157;"	d
-SET_TX_DESC_NAV_USE_HDR_8723B	include/rtl8723b_xmit.h	157;"	d
-SET_TX_DESC_NAV_USE_HDR_8723D	include/rtl8723d_xmit.h	220;"	d
-SET_TX_DESC_NAV_USE_HDR_8812	include/rtl8812a_xmit.h	251;"	d
-SET_TX_DESC_NAV_USE_HDR_8814A	include/rtl8814a_xmit.h	182;"	d
-SET_TX_DESC_NAV_USE_HDR_92E	include/rtl8192e_xmit.h	286;"	d
-SET_TX_DESC_NDPA_8188F	include/rtl8188f_xmit.h	160;"	d
-SET_TX_DESC_NDPA_8703B	include/rtl8703b_xmit.h	160;"	d
-SET_TX_DESC_NDPA_8723B	include/rtl8723b_xmit.h	160;"	d
-SET_TX_DESC_NDPA_8812	include/rtl8812a_xmit.h	254;"	d
-SET_TX_DESC_NDPA_8814A	include/rtl8814a_xmit.h	185;"	d
-SET_TX_DESC_NDPA_92E	include/rtl8192e_xmit.h	289;"	d
-SET_TX_DESC_NEXTHEADPAGE_8723D	include/rtl8723d_xmit.h	316;"	d
-SET_TX_DESC_NEXT_DESC_ADDRESS_8188F	include/rtl8188f_xmit.h	213;"	d
-SET_TX_DESC_NEXT_DESC_ADDRESS_8703B	include/rtl8703b_xmit.h	213;"	d
-SET_TX_DESC_NEXT_DESC_ADDRESS_8723B	include/rtl8723b_xmit.h	213;"	d
-SET_TX_DESC_NEXT_DESC_ADDRESS_8812	include/rtl8812a_xmit.h	303;"	d
-SET_TX_DESC_NEXT_HEAD_PAGE_92E	include/rtl8192e_xmit.h	340;"	d
-SET_TX_DESC_NEXT_HEAD_PAGE_H_8814A	include/rtl8814a_xmit.h	252;"	d
-SET_TX_DESC_NEXT_HEAD_PAGE_L_8814A	include/rtl8814a_xmit.h	242;"	d
-SET_TX_DESC_NO_ACM_8188F	include/rtl8188f_xmit.h	116;"	d
-SET_TX_DESC_NO_ACM_8703B	include/rtl8703b_xmit.h	116;"	d
-SET_TX_DESC_NO_ACM_8723B	include/rtl8723b_xmit.h	116;"	d
-SET_TX_DESC_NO_ACM_8723D	include/rtl8723d_xmit.h	166;"	d
-SET_TX_DESC_NO_ACM_8812	include/rtl8812a_xmit.h	212;"	d
-SET_TX_DESC_NO_ACM_8814A	include/rtl8814a_xmit.h	134;"	d
-SET_TX_DESC_NO_ACM_92E	include/rtl8192e_xmit.h	237;"	d
-SET_TX_DESC_NTX_MAP_8814A	include/rtl8814a_xmit.h	231;"	d
-SET_TX_DESC_NULL0_8723D	include/rtl8723d_xmit.h	200;"	d
-SET_TX_DESC_NULL1_8723D	include/rtl8723d_xmit.h	202;"	d
-SET_TX_DESC_NULL_0_8814A	include/rtl8814a_xmit.h	158;"	d
-SET_TX_DESC_NULL_0_92E	include/rtl8192e_xmit.h	262;"	d
-SET_TX_DESC_NULL_1_8814A	include/rtl8814a_xmit.h	159;"	d
-SET_TX_DESC_NULL_1_92E	include/rtl8192e_xmit.h	263;"	d
-SET_TX_DESC_OFFSET_8188F	include/rtl8188f_xmit.h	110;"	d
-SET_TX_DESC_OFFSET_8703B	include/rtl8703b_xmit.h	110;"	d
-SET_TX_DESC_OFFSET_8723B	include/rtl8723b_xmit.h	110;"	d
-SET_TX_DESC_OFFSET_8723D	include/rtl8723d_xmit.h	158;"	d
-SET_TX_DESC_OFFSET_8812	include/rtl8812a_xmit.h	206;"	d
-SET_TX_DESC_OFFSET_8814A	include/rtl8814a_xmit.h	127;"	d
-SET_TX_DESC_OFFSET_92E	include/rtl8192e_xmit.h	231;"	d
-SET_TX_DESC_OWN_8188F	include/rtl8188f_xmit.h	118;"	d
-SET_TX_DESC_OWN_8703B	include/rtl8703b_xmit.h	118;"	d
-SET_TX_DESC_OWN_8723B	include/rtl8723b_xmit.h	118;"	d
-SET_TX_DESC_OWN_8812	include/rtl8812a_xmit.h	214;"	d
-SET_TX_DESC_OWN_92E	include/rtl8192e_xmit.h	239;"	d
-SET_TX_DESC_PADDING_LENGTH_8814A	include/rtl8814a_xmit.h	249;"	d
-SET_TX_DESC_PADDING_LENGTH_92E	include/rtl8192e_xmit.h	344;"	d
-SET_TX_DESC_PADDING_LEN_8723D	include/rtl8723d_xmit.h	322;"	d
-SET_TX_DESC_PAID_8188F	include/rtl8188f_xmit.h	133;"	d
-SET_TX_DESC_PAID_8703B	include/rtl8703b_xmit.h	133;"	d
-SET_TX_DESC_PAID_8723B	include/rtl8723b_xmit.h	133;"	d
-SET_TX_DESC_PAID_8812	include/rtl8812a_xmit.h	228;"	d
-SET_TX_DESC_PAID_8814A	include/rtl8814a_xmit.h	154;"	d
-SET_TX_DESC_PAID_92E	include/rtl8192e_xmit.h	258;"	d
-SET_TX_DESC_PATH_A_EN_8723D	include/rtl8723d_xmit.h	279;"	d
-SET_TX_DESC_PCTS_ENABLE_8814A	include/rtl8814a_xmit.h	196;"	d
-SET_TX_DESC_PCTS_ENABLE_92E	include/rtl8192e_xmit.h	300;"	d
-SET_TX_DESC_PCTS_EN_8723D	include/rtl8723d_xmit.h	259;"	d
-SET_TX_DESC_PCTS_MASK_IDX_8723D	include/rtl8723d_xmit.h	261;"	d
-SET_TX_DESC_PCTS_MASK_IDX_8814A	include/rtl8814a_xmit.h	197;"	d
-SET_TX_DESC_PCTS_MASK_IDX_92E	include/rtl8192e_xmit.h	301;"	d
-SET_TX_DESC_PIFS_8188F	include/rtl8188f_xmit.h	125;"	d
-SET_TX_DESC_PIFS_8703B	include/rtl8703b_xmit.h	125;"	d
-SET_TX_DESC_PIFS_8723B	include/rtl8723b_xmit.h	125;"	d
-SET_TX_DESC_PIFS_8723D	include/rtl8723d_xmit.h	180;"	d
-SET_TX_DESC_PIFS_8812	include/rtl8812a_xmit.h	221;"	d
-SET_TX_DESC_PIFS_8814A	include/rtl8814a_xmit.h	143;"	d
-SET_TX_DESC_PIFS_92E	include/rtl8192e_xmit.h	247;"	d
-SET_TX_DESC_PKT_OFFSET_8188F	include/rtl8188f_xmit.h	129;"	d
-SET_TX_DESC_PKT_OFFSET_8703B	include/rtl8703b_xmit.h	129;"	d
-SET_TX_DESC_PKT_OFFSET_8723B	include/rtl8723b_xmit.h	129;"	d
-SET_TX_DESC_PKT_OFFSET_8723D	include/rtl8723d_xmit.h	188;"	d
-SET_TX_DESC_PKT_OFFSET_8812	include/rtl8812a_xmit.h	225;"	d
-SET_TX_DESC_PKT_OFFSET_8814A	include/rtl8814a_xmit.h	147;"	d
-SET_TX_DESC_PKT_OFFSET_92E	include/rtl8192e_xmit.h	251;"	d
-SET_TX_DESC_PKT_SIZE_8188F	include/rtl8188f_xmit.h	109;"	d
-SET_TX_DESC_PKT_SIZE_8703B	include/rtl8703b_xmit.h	109;"	d
-SET_TX_DESC_PKT_SIZE_8723B	include/rtl8723b_xmit.h	109;"	d
-SET_TX_DESC_PKT_SIZE_8723D	include/rtl8723d_xmit.h	156;"	d
-SET_TX_DESC_PKT_SIZE_8812	include/rtl8812a_xmit.h	205;"	d
-SET_TX_DESC_PKT_SIZE_8814A	include/rtl8814a_xmit.h	125;"	d
-SET_TX_DESC_PKT_SIZE_92E	include/rtl8192e_xmit.h	230;"	d
-SET_TX_DESC_PORT_ID_8723D	include/rtl8723d_xmit.h	235;"	d
-SET_TX_DESC_PORT_ID_8814A	include/rtl8814a_xmit.h	210;"	d
-SET_TX_DESC_QUEUE_SEL_8188F	include/rtl8188f_xmit.h	122;"	d
-SET_TX_DESC_QUEUE_SEL_8703B	include/rtl8703b_xmit.h	122;"	d
-SET_TX_DESC_QUEUE_SEL_8723B	include/rtl8723b_xmit.h	122;"	d
-SET_TX_DESC_QUEUE_SEL_8723D	include/rtl8723d_xmit.h	174;"	d
-SET_TX_DESC_QUEUE_SEL_8812	include/rtl8812a_xmit.h	218;"	d
-SET_TX_DESC_QUEUE_SEL_8814A	include/rtl8814a_xmit.h	140;"	d
-SET_TX_DESC_QUEUE_SEL_92E	include/rtl8192e_xmit.h	244;"	d
-SET_TX_DESC_RATE_ID_8188F	include/rtl8188f_xmit.h	126;"	d
-SET_TX_DESC_RATE_ID_8703B	include/rtl8703b_xmit.h	126;"	d
-SET_TX_DESC_RATE_ID_8723B	include/rtl8723b_xmit.h	126;"	d
-SET_TX_DESC_RATE_ID_8723D	include/rtl8723d_xmit.h	182;"	d
-SET_TX_DESC_RATE_ID_8812	include/rtl8812a_xmit.h	222;"	d
-SET_TX_DESC_RATE_ID_8814A	include/rtl8814a_xmit.h	144;"	d
-SET_TX_DESC_RATE_ID_92E	include/rtl8192e_xmit.h	248;"	d
-SET_TX_DESC_RAW_8188F	include/rtl8188f_xmit.h	139;"	d
-SET_TX_DESC_RAW_8703B	include/rtl8703b_xmit.h	139;"	d
-SET_TX_DESC_RAW_8723B	include/rtl8723b_xmit.h	139;"	d
-SET_TX_DESC_RAW_8723D	include/rtl8723d_xmit.h	208;"	d
-SET_TX_DESC_RAW_8812	include/rtl8812a_xmit.h	234;"	d
-SET_TX_DESC_RAW_8814A	include/rtl8814a_xmit.h	163;"	d
-SET_TX_DESC_RAW_92E	include/rtl8192e_xmit.h	266;"	d
-SET_TX_DESC_RDG_ENABLE_8188F	include/rtl8188f_xmit.h	136;"	d
-SET_TX_DESC_RDG_ENABLE_8703B	include/rtl8703b_xmit.h	136;"	d
-SET_TX_DESC_RDG_ENABLE_8723B	include/rtl8723b_xmit.h	136;"	d
-SET_TX_DESC_RDG_ENABLE_8723D	include/rtl8723d_xmit.h	198;"	d
-SET_TX_DESC_RDG_ENABLE_8812	include/rtl8812a_xmit.h	231;"	d
-SET_TX_DESC_RDG_ENABLE_8814A	include/rtl8814a_xmit.h	157;"	d
-SET_TX_DESC_RDG_ENABLE_92E	include/rtl8192e_xmit.h	261;"	d
-SET_TX_DESC_RDG_NAV_EXT_8188F	include/rtl8188f_xmit.h	123;"	d
-SET_TX_DESC_RDG_NAV_EXT_8703B	include/rtl8703b_xmit.h	123;"	d
-SET_TX_DESC_RDG_NAV_EXT_8723B	include/rtl8723b_xmit.h	123;"	d
-SET_TX_DESC_RDG_NAV_EXT_8723D	include/rtl8723d_xmit.h	176;"	d
-SET_TX_DESC_RDG_NAV_EXT_8812	include/rtl8812a_xmit.h	219;"	d
-SET_TX_DESC_RDG_NAV_EXT_8814A	include/rtl8814a_xmit.h	141;"	d
-SET_TX_DESC_RDG_NAV_EXT_92E	include/rtl8192e_xmit.h	245;"	d
-SET_TX_DESC_RETRY_LIMIT_ENABLE_8188F	include/rtl8188f_xmit.h	167;"	d
-SET_TX_DESC_RETRY_LIMIT_ENABLE_8703B	include/rtl8703b_xmit.h	167;"	d
-SET_TX_DESC_RETRY_LIMIT_ENABLE_8723B	include/rtl8723b_xmit.h	167;"	d
-SET_TX_DESC_RETRY_LIMIT_ENABLE_8723D	include/rtl8723d_xmit.h	253;"	d
-SET_TX_DESC_RETRY_LIMIT_ENABLE_8812	include/rtl8812a_xmit.h	261;"	d
-SET_TX_DESC_RETRY_LIMIT_ENABLE_8814A	include/rtl8814a_xmit.h	193;"	d
-SET_TX_DESC_RETRY_LIMIT_ENABLE_92E	include/rtl8192e_xmit.h	297;"	d
-SET_TX_DESC_RF_SEL_8723D	include/rtl8723d_xmit.h	289;"	d
-SET_TX_DESC_RTS_ENABLE_8188F	include/rtl8188f_xmit.h	155;"	d
-SET_TX_DESC_RTS_ENABLE_8703B	include/rtl8703b_xmit.h	155;"	d
-SET_TX_DESC_RTS_ENABLE_8723B	include/rtl8723b_xmit.h	155;"	d
-SET_TX_DESC_RTS_ENABLE_8723D	include/rtl8723d_xmit.h	231;"	d
-SET_TX_DESC_RTS_ENABLE_8812	include/rtl8812a_xmit.h	249;"	d
-SET_TX_DESC_RTS_ENABLE_8814A	include/rtl8814a_xmit.h	179;"	d
-SET_TX_DESC_RTS_ENABLE_92E	include/rtl8192e_xmit.h	283;"	d
-SET_TX_DESC_RTS_RATE_8188F	include/rtl8188f_xmit.h	169;"	d
-SET_TX_DESC_RTS_RATE_8703B	include/rtl8703b_xmit.h	169;"	d
-SET_TX_DESC_RTS_RATE_8723B	include/rtl8723b_xmit.h	169;"	d
-SET_TX_DESC_RTS_RATE_8723D	include/rtl8723d_xmit.h	257;"	d
-SET_TX_DESC_RTS_RATE_8812	include/rtl8812a_xmit.h	263;"	d
-SET_TX_DESC_RTS_RATE_8814A	include/rtl8814a_xmit.h	195;"	d
-SET_TX_DESC_RTS_RATE_92E	include/rtl8192e_xmit.h	299;"	d
-SET_TX_DESC_RTS_RATE_FB_LIMIT_8188F	include/rtl8188f_xmit.h	166;"	d
-SET_TX_DESC_RTS_RATE_FB_LIMIT_8703B	include/rtl8703b_xmit.h	166;"	d
-SET_TX_DESC_RTS_RATE_FB_LIMIT_8723B	include/rtl8723b_xmit.h	166;"	d
-SET_TX_DESC_RTS_RATE_FB_LIMIT_8723D	include/rtl8723d_xmit.h	251;"	d
-SET_TX_DESC_RTS_RATE_FB_LIMIT_8812	include/rtl8812a_xmit.h	260;"	d
-SET_TX_DESC_RTS_RATE_FB_LIMIT_8814A	include/rtl8814a_xmit.h	192;"	d
-SET_TX_DESC_RTS_RATE_FB_LIMIT_92E	include/rtl8192e_xmit.h	296;"	d
-SET_TX_DESC_RTS_RC_8723D	include/rtl8723d_xmit.h	308;"	d
-SET_TX_DESC_RTS_RC_8814A	include/rtl8814a_xmit.h	236;"	d
-SET_TX_DESC_RTS_RC_92E	include/rtl8192e_xmit.h	336;"	d
-SET_TX_DESC_RTS_SC_8188F	include/rtl8188f_xmit.h	180;"	d
-SET_TX_DESC_RTS_SC_8703B	include/rtl8703b_xmit.h	180;"	d
-SET_TX_DESC_RTS_SC_8723B	include/rtl8723b_xmit.h	180;"	d
-SET_TX_DESC_RTS_SC_8723D	include/rtl8723d_xmit.h	277;"	d
-SET_TX_DESC_RTS_SC_8812	include/rtl8812a_xmit.h	273;"	d
-SET_TX_DESC_RTS_SC_8814A	include/rtl8814a_xmit.h	208;"	d
-SET_TX_DESC_RTS_SC_92E	include/rtl8192e_xmit.h	312;"	d
-SET_TX_DESC_RTS_SHORT_8188F	include/rtl8188f_xmit.h	179;"	d
-SET_TX_DESC_RTS_SHORT_8703B	include/rtl8703b_xmit.h	179;"	d
-SET_TX_DESC_RTS_SHORT_8723B	include/rtl8723b_xmit.h	179;"	d
-SET_TX_DESC_RTS_SHORT_8723D	include/rtl8723d_xmit.h	275;"	d
-SET_TX_DESC_RTS_SHORT_8812	include/rtl8812a_xmit.h	272;"	d
-SET_TX_DESC_RTS_SHORT_8814A	include/rtl8814a_xmit.h	207;"	d
-SET_TX_DESC_RTS_SHORT_92E	include/rtl8192e_xmit.h	311;"	d
-SET_TX_DESC_RTS_STBC_8723D	include/rtl8723d_xmit.h	273;"	d
-SET_TX_DESC_SDIO_SEQ_8814A	include/rtl8814a_xmit.h	244;"	d
-SET_TX_DESC_SDIO_TXSEQ_8188F	include/rtl8188f_xmit.h	199;"	d
-SET_TX_DESC_SDIO_TXSEQ_8703B	include/rtl8703b_xmit.h	199;"	d
-SET_TX_DESC_SDIO_TXSEQ_8723B	include/rtl8723b_xmit.h	199;"	d
-SET_TX_DESC_SDIO_TXSEQ_8812	include/rtl8812a_xmit.h	289;"	d
-SET_TX_DESC_SDIO_TXSEQ_8814A	include/rtl8814a_xmit.h	39;"	d
-SET_TX_DESC_SEC_TYPE_8188E	include/rtl8188e_xmit.h	241;"	d
-SET_TX_DESC_SEC_TYPE_8188F	include/rtl8188f_xmit.h	128;"	d
-SET_TX_DESC_SEC_TYPE_8703B	include/rtl8703b_xmit.h	128;"	d
-SET_TX_DESC_SEC_TYPE_8723B	include/rtl8723b_xmit.h	128;"	d
-SET_TX_DESC_SEC_TYPE_8723D	include/rtl8723d_xmit.h	186;"	d
-SET_TX_DESC_SEC_TYPE_8812	include/rtl8812a_xmit.h	224;"	d
-SET_TX_DESC_SEC_TYPE_8814A	include/rtl8814a_xmit.h	146;"	d
-SET_TX_DESC_SEC_TYPE_92E	include/rtl8192e_xmit.h	250;"	d
-SET_TX_DESC_SEQ_8188F	include/rtl8188f_xmit.h	206;"	d
-SET_TX_DESC_SEQ_8703B	include/rtl8703b_xmit.h	206;"	d
-SET_TX_DESC_SEQ_8723B	include/rtl8723b_xmit.h	206;"	d
-SET_TX_DESC_SEQ_8723D	include/rtl8723d_xmit.h	324;"	d
-SET_TX_DESC_SEQ_8812	include/rtl8812a_xmit.h	296;"	d
-SET_TX_DESC_SEQ_8814A	include/rtl8814a_xmit.h	251;"	d
-SET_TX_DESC_SEQ_92E	include/rtl8192e_xmit.h	346;"	d
-SET_TX_DESC_SIGNALING_TA_PKT_8814A	include/rtl8814a_xmit.h	209;"	d
-SET_TX_DESC_SPE_RPT_8188F	include/rtl8188f_xmit.h	140;"	d
-SET_TX_DESC_SPE_RPT_8703B	include/rtl8703b_xmit.h	140;"	d
-SET_TX_DESC_SPE_RPT_8723B	include/rtl8723b_xmit.h	140;"	d
-SET_TX_DESC_SPE_RPT_8812	include/rtl8812a_xmit.h	235;"	d
-SET_TX_DESC_SPE_RPT_8814A	include/rtl8814a_xmit.h	164;"	d
-SET_TX_DESC_SPE_RPT_92E	include/rtl8192e_xmit.h	268;"	d
-SET_TX_DESC_SW_DEFINE_8188F	include/rtl8188f_xmit.h	184;"	d
-SET_TX_DESC_SW_DEFINE_8703B	include/rtl8703b_xmit.h	184;"	d
-SET_TX_DESC_SW_DEFINE_8723B	include/rtl8723b_xmit.h	184;"	d
-SET_TX_DESC_SW_DEFINE_8723D	include/rtl8723d_xmit.h	285;"	d
-SET_TX_DESC_SW_DEFINE_8812	include/rtl8812a_xmit.h	277;"	d
-SET_TX_DESC_SW_DEFINE_8814A	include/rtl8814a_xmit.h	215;"	d
-SET_TX_DESC_SW_DEFINE_92E	include/rtl8192e_xmit.h	317;"	d
-SET_TX_DESC_TAILPAGE_8723D	include/rtl8723d_xmit.h	318;"	d
-SET_TX_DESC_TAIL_PAGE_92E	include/rtl8192e_xmit.h	341;"	d
-SET_TX_DESC_TAIL_PAGE_H_8814A	include/rtl8814a_xmit.h	253;"	d
-SET_TX_DESC_TAIL_PAGE_L_8814A	include/rtl8814a_xmit.h	246;"	d
-SET_TX_DESC_TRY_RATE_8814A	include/rtl8814a_xmit.h	190;"	d
-SET_TX_DESC_TRY_RATE_92E	include/rtl8192e_xmit.h	294;"	d
-SET_TX_DESC_TXBF_PATH_8814A	include/rtl8814a_xmit.h	250;"	d
-SET_TX_DESC_TXBF_PATH_92E	include/rtl8192e_xmit.h	345;"	d
-SET_TX_DESC_TXOP_PS_CAP_8814A	include/rtl8814a_xmit.h	149;"	d
-SET_TX_DESC_TXOP_PS_CAP_92E	include/rtl8192e_xmit.h	253;"	d
-SET_TX_DESC_TXOP_PS_MODE_8814A	include/rtl8814a_xmit.h	150;"	d
-SET_TX_DESC_TXOP_PS_MODE_92E	include/rtl8192e_xmit.h	254;"	d
-SET_TX_DESC_TXPWR_OF_SET_8723D	include/rtl8723d_xmit.h	281;"	d
-SET_TX_DESC_TX_ANT_8812	include/rtl8812a_xmit.h	274;"	d
-SET_TX_DESC_TX_ANT_8814A	include/rtl8814a_xmit.h	211;"	d
-SET_TX_DESC_TX_ANT_92E	include/rtl8192e_xmit.h	313;"	d
-SET_TX_DESC_TX_BUFFER_ADDRESS_8188F	include/rtl8188f_xmit.h	209;"	d
-SET_TX_DESC_TX_BUFFER_ADDRESS_8703B	include/rtl8703b_xmit.h	209;"	d
-SET_TX_DESC_TX_BUFFER_ADDRESS_8723B	include/rtl8723b_xmit.h	209;"	d
-SET_TX_DESC_TX_BUFFER_ADDRESS_8812	include/rtl8812a_xmit.h	299;"	d
-SET_TX_DESC_TX_BUFFER_SIZE_8188F	include/rtl8188f_xmit.h	193;"	d
-SET_TX_DESC_TX_BUFFER_SIZE_8703B	include/rtl8703b_xmit.h	193;"	d
-SET_TX_DESC_TX_BUFFER_SIZE_8723B	include/rtl8723b_xmit.h	193;"	d
-SET_TX_DESC_TX_BUFFER_SIZE_8723D	include/rtl8723d_xmit.h	294;"	d
-SET_TX_DESC_TX_BUFFER_SIZE_8812	include/rtl8812a_xmit.h	285;"	d
-SET_TX_DESC_TX_BUFFER_SIZE_8814A	include/rtl8814a_xmit.h	227;"	d
-SET_TX_DESC_TX_BUFFER_SIZE_92E	include/rtl8192e_xmit.h	326;"	d
-SET_TX_DESC_TX_DESC_CHECKSUM_8188F	include/rtl8188f_xmit.h	195;"	d
-SET_TX_DESC_TX_DESC_CHECKSUM_8703B	include/rtl8703b_xmit.h	195;"	d
-SET_TX_DESC_TX_DESC_CHECKSUM_8723B	include/rtl8723b_xmit.h	195;"	d
-SET_TX_DESC_TX_DESC_CHECKSUM_8723D	include/rtl8723d_xmit.h	297;"	d
-SET_TX_DESC_TX_DESC_CHECKSUM_8812	include/rtl8812a_xmit.h	286;"	d
-SET_TX_DESC_TX_DESC_CHECKSUM_8814A	include/rtl8814a_xmit.h	229;"	d
-SET_TX_DESC_TX_DESC_CHECKSUM_92E	include/rtl8192e_xmit.h	328;"	d
-SET_TX_DESC_TX_POWER_0_PSET_92E	include/rtl8192e_xmit.h	314;"	d
-SET_TX_DESC_TX_POWER_OFFSET_8814A	include/rtl8814a_xmit.h	212;"	d
-SET_TX_DESC_TX_RATE_8188F	include/rtl8188f_xmit.h	164;"	d
-SET_TX_DESC_TX_RATE_8703B	include/rtl8703b_xmit.h	164;"	d
-SET_TX_DESC_TX_RATE_8723B	include/rtl8723b_xmit.h	164;"	d
-SET_TX_DESC_TX_RATE_8723D	include/rtl8723d_xmit.h	245;"	d
-SET_TX_DESC_TX_RATE_8812	include/rtl8812a_xmit.h	258;"	d
-SET_TX_DESC_TX_RATE_8814A	include/rtl8814a_xmit.h	189;"	d
-SET_TX_DESC_TX_RATE_92E	include/rtl8192e_xmit.h	293;"	d
-SET_TX_DESC_TX_TIMESTAMP_8723D	include/rtl8723d_xmit.h	300;"	d
-SET_TX_DESC_TX_TRY_RATE_8723D	include/rtl8723d_xmit.h	247;"	d
-SET_TX_DESC_USB_TXAGG_NUM_8188F	include/rtl8188f_xmit.h	197;"	d
-SET_TX_DESC_USB_TXAGG_NUM_8703B	include/rtl8703b_xmit.h	197;"	d
-SET_TX_DESC_USB_TXAGG_NUM_8723B	include/rtl8723b_xmit.h	197;"	d
-SET_TX_DESC_USB_TXAGG_NUM_8723D	include/rtl8723d_xmit.h	304;"	d
-SET_TX_DESC_USB_TXAGG_NUM_8812	include/rtl8812a_xmit.h	287;"	d
-SET_TX_DESC_USB_TXAGG_NUM_8814A	include/rtl8814a_xmit.h	232;"	d
-SET_TX_DESC_USB_TXAGG_NUM_92E	include/rtl8192e_xmit.h	330;"	d
-SET_TX_DESC_USE_MAX_LEN_8188F	include/rtl8188f_xmit.h	158;"	d
-SET_TX_DESC_USE_MAX_LEN_8703B	include/rtl8703b_xmit.h	158;"	d
-SET_TX_DESC_USE_MAX_LEN_8723B	include/rtl8723b_xmit.h	158;"	d
-SET_TX_DESC_USE_MAX_LEN_8723D	include/rtl8723d_xmit.h	237;"	d
-SET_TX_DESC_USE_MAX_LEN_8812	include/rtl8812a_xmit.h	252;"	d
-SET_TX_DESC_USE_MAX_LEN_8814A	include/rtl8814a_xmit.h	183;"	d
-SET_TX_DESC_USE_MAX_LEN_92E	include/rtl8192e_xmit.h	287;"	d
-SET_TX_DESC_USE_RATE_8188F	include/rtl8188f_xmit.h	151;"	d
-SET_TX_DESC_USE_RATE_8703B	include/rtl8703b_xmit.h	151;"	d
-SET_TX_DESC_USE_RATE_8723B	include/rtl8723b_xmit.h	151;"	d
-SET_TX_DESC_USE_RATE_8723D	include/rtl8723d_xmit.h	223;"	d
-SET_TX_DESC_USE_RATE_8812	include/rtl8812a_xmit.h	245;"	d
-SET_TX_DESC_USE_RATE_8814A	include/rtl8814a_xmit.h	175;"	d
-SET_TX_DESC_USE_RATE_92E	include/rtl8192e_xmit.h	279;"	d
-SET_TX_DESC_VCS_STBC_92E	include/rtl8192e_xmit.h	310;"	d
-SET_TX_DESC_WHEADER_LEN_8188F	include/rtl8188f_xmit.h	147;"	d
-SET_TX_DESC_WHEADER_LEN_8703B	include/rtl8703b_xmit.h	147;"	d
-SET_TX_DESC_WHEADER_LEN_8723B	include/rtl8723b_xmit.h	147;"	d
-SET_TX_DESC_WHEADER_LEN_8812	include/rtl8812a_xmit.h	241;"	d
-SET_TX_DESC_WHEADER_LEN_8814A	include/rtl8814a_xmit.h	172;"	d
-SET_TX_DESC_WHEADER_LEN_92E	include/rtl8192e_xmit.h	275;"	d
-SET_VHT_CAPABILITY_ELE_BFER_ANT_SUPP	include/rtw_vht.h	52;"	d
-SET_VHT_CAPABILITY_ELE_CHL_WIDTH	include/rtw_vht.h	44;"	d
-SET_VHT_CAPABILITY_ELE_HTC_VHT	include/rtw_vht.h	58;"	d
-SET_VHT_CAPABILITY_ELE_LINK_ADAPTION	include/rtw_vht.h	60;"	d
-SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH	include/rtw_vht.h	43;"	d
-SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR	include/rtw_vht.h	59;"	d
-SET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE	include/rtw_vht.h	62;"	d
-SET_VHT_CAPABILITY_ELE_MCS_RX_MAP	include/rtw_vht.h	61;"	d
-SET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE	include/rtw_vht.h	64;"	d
-SET_VHT_CAPABILITY_ELE_MCS_TX_MAP	include/rtw_vht.h	63;"	d
-SET_VHT_CAPABILITY_ELE_MU_BFEE	include/rtw_vht.h	56;"	d
-SET_VHT_CAPABILITY_ELE_MU_BFER	include/rtw_vht.h	55;"	d
-SET_VHT_CAPABILITY_ELE_RX_LDPC	include/rtw_vht.h	45;"	d
-SET_VHT_CAPABILITY_ELE_RX_STBC	include/rtw_vht.h	49;"	d
-SET_VHT_CAPABILITY_ELE_SHORT_GI160M	include/rtw_vht.h	47;"	d
-SET_VHT_CAPABILITY_ELE_SHORT_GI80M	include/rtw_vht.h	46;"	d
-SET_VHT_CAPABILITY_ELE_SOUNDING_DIMENSIONS	include/rtw_vht.h	53;"	d
-SET_VHT_CAPABILITY_ELE_SU_BFEE	include/rtw_vht.h	51;"	d
-SET_VHT_CAPABILITY_ELE_SU_BFER	include/rtw_vht.h	50;"	d
-SET_VHT_CAPABILITY_ELE_TXOP_PS	include/rtw_vht.h	57;"	d
-SET_VHT_CAPABILITY_ELE_TX_STBC	include/rtw_vht.h	48;"	d
-SET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH	include/rtw_vht.h	100;"	d
-SET_VHT_OPERATING_MODE_FIELD_RX_NSS	include/rtw_vht.h	101;"	d
-SET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE	include/rtw_vht.h	102;"	d
-SET_VHT_OPERATION_ELE_BASIC_MCS_SET	include/rtw_vht.h	93;"	d
-SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1	include/rtw_vht.h	91;"	d
-SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2	include/rtw_vht.h	92;"	d
-SET_VHT_OPERATION_ELE_CHL_WIDTH	include/rtw_vht.h	90;"	d
-SFD	include/rtw_mp.h	/^	USHORT			SFD;$/;"	m	struct:_RT_PMAC_TX_INFO
-SGI	include/rtl8188e_xmit.h	90;"	d
-SGI	include/rtl8192e_xmit.h	195;"	d
-SGI	include/rtl8812a_xmit.h	87;"	d
-SGIEnable	hal/phydm/phydm_rainfo.h	/^	u1Byte SGIEnable;$/;"	m	struct:_ODM_RA_Info_
-SHA256_MAC_LEN	include/rtw_security.h	47;"	d
-SHORT_SLOT_TIME	include/rtw_rf.h	33;"	d
-SIC_ADDR_REG	include/Hal8188EPhyCfg.h	230;"	d
-SIC_ADDR_REG	include/Hal8188EPhyCfg.h	241;"	d
-SIC_ADDR_REG	include/Hal8188EPhyCfg.h	251;"	d
-SIC_ADDR_REG	include/Hal8188EPhyCfg.h	255;"	d
-SIC_CMD_INIT	include/Hal8188EPhyCfg.h	225;"	d
-SIC_CMD_INIT	include/Hal8188EPhyCfg.h	236;"	d
-SIC_CMD_PREREAD	include/Hal8188EPhyCfg.h	223;"	d
-SIC_CMD_PREREAD	include/Hal8188EPhyCfg.h	234;"	d
-SIC_CMD_PREWRITE	include/Hal8188EPhyCfg.h	220;"	d
-SIC_CMD_READ	include/Hal8188EPhyCfg.h	224;"	d
-SIC_CMD_READ	include/Hal8188EPhyCfg.h	235;"	d
-SIC_CMD_READ	include/Hal8188EPhyCfg.h	247;"	d
-SIC_CMD_READY	include/Hal8188EPhyCfg.h	219;"	d
-SIC_CMD_READY	include/Hal8188EPhyCfg.h	245;"	d
-SIC_CMD_REG	include/Hal8188EPhyCfg.h	229;"	d
-SIC_CMD_REG	include/Hal8188EPhyCfg.h	240;"	d
-SIC_CMD_REG	include/Hal8188EPhyCfg.h	250;"	d
-SIC_CMD_REG	include/Hal8188EPhyCfg.h	254;"	d
-SIC_CMD_WRITE	include/Hal8188EPhyCfg.h	222;"	d
-SIC_CMD_WRITE	include/Hal8188EPhyCfg.h	233;"	d
-SIC_CMD_WRITE	include/Hal8188EPhyCfg.h	246;"	d
-SIC_DATA_REG	include/Hal8188EPhyCfg.h	231;"	d
-SIC_DATA_REG	include/Hal8188EPhyCfg.h	242;"	d
-SIC_DATA_REG	include/Hal8188EPhyCfg.h	252;"	d
-SIC_DATA_REG	include/Hal8188EPhyCfg.h	256;"	d
-SIC_ENABLE	include/Hal8188EPhyCfg.h	207;"	d
-SIC_ENABLE	include/Hal8188EPhyCfg.h	210;"	d
-SIC_ENABLE	include/Hal8814PhyCfg.h	46;"	d
-SIC_HW_SUPPORT	include/Hal8188EPhyCfg.h	208;"	d
-SIC_HW_SUPPORT	include/Hal8188EPhyCfg.h	211;"	d
-SIC_IDLE	include/hal_com_reg.h	1260;"	d
-SIC_INIT_REG	include/Hal8188EPhyCfg.h	228;"	d
-SIC_INIT_REG	include/Hal8188EPhyCfg.h	239;"	d
-SIC_INIT_VAL	include/Hal8188EPhyCfg.h	226;"	d
-SIC_INIT_VAL	include/Hal8188EPhyCfg.h	237;"	d
-SIC_MAX_POLL_CNT	include/Hal8188EPhyCfg.h	216;"	d
-SIGA2B3	include/rtw_mp.h	/^	UCHAR			SIGA2B3;$/;"	m	struct:_RT_PMAC_PKT_INFO
-SIGNAL_STAT_CALC_PROFILE_0	core/rtw_recv.c	/^	SIGNAL_STAT_CALC_PROFILE_0 = 0,$/;"	e	enum:__anon1	file:
-SIGNAL_STAT_CALC_PROFILE_1	core/rtw_recv.c	/^	SIGNAL_STAT_CALC_PROFILE_1,$/;"	e	enum:__anon1	file:
-SIGNAL_STAT_CALC_PROFILE_MAX	core/rtw_recv.c	/^	SIGNAL_STAT_CALC_PROFILE_MAX$/;"	e	enum:__anon1	file:
-SIS_VENDOR_ID	include/drv_types_pci.h	30;"	d
-SIX_MSDU	include/wlan_bssdef.h	/^	SIX_MSDU$/;"	e	enum:UAPSD_MAX_SP
-SIZE_MAX	os_dep/osdep_service.c	549;"	d	file:
-SIZE_PTR	include/basic_types.h	163;"	d
-SIZE_T	include/basic_types.h	/^	typedef	__kernel_size_t	SIZE_T;$/;"	t
-SMS4Crypt	core/rtw_wapi_sms4.c	/^void SMS4Crypt(u8 *Input, u8 *Output, u32 *rk)$/;"	f
-SMS4KeyExt	core/rtw_wapi_sms4.c	/^void SMS4KeyExt(u8 *Key, u32 *rk, u32 CryptFlag)$/;"	f
-SMS4_MIC_LEN	include/rtw_wapi.h	8;"	d
-SM_PS	include/rtw_mlme_ext.h	/^	u8	SM_PS;$/;"	m	struct:mlme_ext_info
-SNAP_ETH_TYPE_APPLETALK_AARP	include/rtw_recv.h	/^static u8 SNAP_ETH_TYPE_APPLETALK_AARP[2] = {0x80, 0xf3};$/;"	v
-SNAP_ETH_TYPE_APPLETALK_DDP	include/rtw_recv.h	/^static u8 SNAP_ETH_TYPE_APPLETALK_DDP[2] = {0x80, 0x9b};$/;"	v
-SNAP_ETH_TYPE_IPX	include/rtw_recv.h	/^static u8 SNAP_ETH_TYPE_IPX[2] = {0x81, 0x37};$/;"	v
-SNAP_ETH_TYPE_TDLS	include/rtw_recv.h	/^static u8 SNAP_ETH_TYPE_TDLS[2] = {0x89, 0x0d};$/;"	v
-SNAP_HDR_APPLETALK_DDP	include/rtw_recv.h	/^static u8 SNAP_HDR_APPLETALK_DDP[3] = {0x08, 0x00, 0x07}; \/* Datagram Delivery Protocol *\/$/;"	v
-SNAP_SIZE	include/ieee80211.h	583;"	d
-SNAP_SIZE	include/rtw_recv.h	75;"	d
-SN_EQUAL	include/rtw_recv.h	286;"	d
-SN_LESS	include/rtw_recv.h	285;"	d
-SNonce	include/sta_info.h	/^	u8	SNonce[32];$/;"	m	struct:sta_info
-SOP_A8M	include/hal_com_reg.h	1194;"	d
-SOP_ABG	include/hal_com_reg.h	1191;"	d
-SOP_AMB	include/hal_com_reg.h	1192;"	d
-SOP_FUSE	include/hal_com_reg.h	1190;"	d
-SOP_MRST	include/hal_com_reg.h	1189;"	d
-SOP_RCK	include/hal_com_reg.h	1193;"	d
-SOUNDING_AUTO_HT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_AUTO_HT_TIMER = 0x7,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_AUTO_HT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_AUTO_HT_TIMER = 0x7,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_AUTO_VHT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_AUTO_VHT_TIMER = 0x6,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_AUTO_VHT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_AUTO_VHT_TIMER = 0x6,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_FW_HT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_FW_HT_TIMER = 0x9,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_FW_HT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_FW_HT_TIMER = 0x9,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_FW_VHT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_FW_VHT_TIMER = 0x8,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_FW_VHT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_FW_VHT_TIMER = 0x8,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_HW_HT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_HW_HT_TIMER = 0x4,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_HW_HT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_HW_HT_TIMER = 0x4,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_HW_VHT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_HW_VHT_TIMER = 0x3,			$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_HW_VHT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_HW_VHT_TIMER = 0x3,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_MODE	hal/phydm/phydm_beamforming.h	/^}SOUNDING_MODE, *PSOUNDING_MODE;$/;"	t	typeref:enum:_SOUNDING_MODE
-SOUNDING_MODE	include/rtw_beamforming.h	/^} SOUNDING_MODE, *PSOUNDING_MODE;$/;"	t	typeref:enum:_SOUNDING_MODE
-SOUNDING_STATE_INIT	include/rtw_beamforming.h	/^	SOUNDING_STATE_INIT		= 1,$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STATE_MAX	include/rtw_beamforming.h	/^	SOUNDING_STATE_MAX$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STATE_MU_SOUNDDOWN	include/rtw_beamforming.h	/^	SOUNDING_STATE_MU_SOUNDDOWN	= 5,$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STATE_MU_START	include/rtw_beamforming.h	/^	SOUNDING_STATE_MU_START		= 4,$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STATE_NONE	include/rtw_beamforming.h	/^	SOUNDING_STATE_NONE		= 0,$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STATE_SOUNDING_TIMEOUT	include/rtw_beamforming.h	/^	SOUNDING_STATE_SOUNDING_TIMEOUT	= 6,$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STATE_SU_SOUNDDOWN	include/rtw_beamforming.h	/^	SOUNDING_STATE_SU_SOUNDDOWN	= 3,$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STATE_SU_START	include/rtw_beamforming.h	/^	SOUNDING_STATE_SU_START		= 2,$/;"	e	enum:_SOUNDING_STATE
-SOUNDING_STOP_All_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_STOP_All_TIMER = 0x2, $/;"	e	enum:_SOUNDING_MODE
-SOUNDING_STOP_All_TIMER	include/rtw_beamforming.h	/^	SOUNDING_STOP_All_TIMER = 0x2,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_STOP_OID_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_STOP_OID_TIMER = 0x5, $/;"	e	enum:_SOUNDING_MODE
-SOUNDING_STOP_OID_TIMER	include/rtw_beamforming.h	/^	SOUNDING_STOP_OID_TIMER = 0x5,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_SW_HT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_SW_HT_TIMER = 0x1, $/;"	e	enum:_SOUNDING_MODE
-SOUNDING_SW_HT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_SW_HT_TIMER = 0x1,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_SW_VHT_TIMER	hal/phydm/phydm_beamforming.h	/^	SOUNDING_SW_VHT_TIMER = 0x0,$/;"	e	enum:_SOUNDING_MODE
-SOUNDING_SW_VHT_TIMER	include/rtw_beamforming.h	/^	SOUNDING_SW_VHT_TIMER = 0x0,$/;"	e	enum:_SOUNDING_MODE
-SPEC_DEV_ID_ASSIGN_IFNAME	include/drv_types.h	169;"	d
-SPEC_DEV_ID_DISABLE_HT	include/drv_types.h	165;"	d
-SPEC_DEV_ID_ENABLE_PS	include/drv_types.h	166;"	d
-SPEC_DEV_ID_NONE	include/drv_types.h	164;"	d
-SPEC_DEV_ID_RF_CONFIG_1T1R	include/drv_types.h	167;"	d
-SPEC_DEV_ID_RF_CONFIG_2T2R	include/drv_types.h	168;"	d
-SPI_FREE_TXPG	include/gspi_ops.h	71;"	d
-SPI_HIMR	include/gspi_ops.h	68;"	d
-SPI_HIMR_DISABLED	include/gspi_ops.h	73;"	d
-SPI_HISR	include/gspi_ops.h	69;"	d
-SPI_HISR_ATIMEND	include/gspi_ops.h	85;"	d
-SPI_HISR_ATIMEND_E	include/gspi_ops.h	86;"	d
-SPI_HISR_AVAL	include/gspi_ops.h	77;"	d
-SPI_HISR_BCNERLY_INT	include/gspi_ops.h	84;"	d
-SPI_HISR_C2HCMD	include/gspi_ops.h	88;"	d
-SPI_HISR_CPWM1	include/gspi_ops.h	89;"	d
-SPI_HISR_CPWM2	include/gspi_ops.h	90;"	d
-SPI_HISR_CTWEND	include/gspi_ops.h	87;"	d
-SPI_HISR_GTINT3_IND	include/gspi_ops.h	92;"	d
-SPI_HISR_GTINT4_IND	include/gspi_ops.h	93;"	d
-SPI_HISR_HSISR_IND	include/gspi_ops.h	91;"	d
-SPI_HISR_OCPINT	include/gspi_ops.h	95;"	d
-SPI_HISR_PSTIMEOUT	include/gspi_ops.h	94;"	d
-SPI_HISR_RXERR	include/gspi_ops.h	79;"	d
-SPI_HISR_RXFOVW	include/gspi_ops.h	81;"	d
-SPI_HISR_RX_REQUEST	include/gspi_ops.h	76;"	d
-SPI_HISR_TSF_BIT32_TOGGLE	include/gspi_ops.h	96;"	d
-SPI_HISR_TXBCNERR	include/gspi_ops.h	83;"	d
-SPI_HISR_TXBCNOK	include/gspi_ops.h	82;"	d
-SPI_HISR_TXERR	include/gspi_ops.h	78;"	d
-SPI_HISR_TXFOVW	include/gspi_ops.h	80;"	d
-SPI_INT_TIMEOUT	include/gspi_ops.h	67;"	d
-SPI_LOCAL_DOMAIN	include/gspi_ops.h	28;"	d
-SPI_LOCAL_OFFSET	include/gspi_ops.h	38;"	d
-SPI_REG_CFG	include/gspi_ops.h	63;"	d
-SPI_REG_FREE_TXPG	include/gspi_ops.h	53;"	d
-SPI_REG_HCPWM1	include/gspi_ops.h	54;"	d
-SPI_REG_HCPWM2	include/gspi_ops.h	55;"	d
-SPI_REG_HIMR	include/gspi_ops.h	50;"	d
-SPI_REG_HIMR_ON	include/gspi_ops.h	61;"	d
-SPI_REG_HISR	include/gspi_ops.h	51;"	d
-SPI_REG_HISR_ON	include/gspi_ops.h	62;"	d
-SPI_REG_HPS_CLKR	include/gspi_ops.h	59;"	d
-SPI_REG_HRPWM1	include/gspi_ops.h	57;"	d
-SPI_REG_HRPWM2	include/gspi_ops.h	58;"	d
-SPI_REG_HSUS_CTRL	include/gspi_ops.h	60;"	d
-SPI_REG_HTSFR_INFO	include/gspi_ops.h	56;"	d
-SPI_REG_INT_TIMEOUT	include/gspi_ops.h	49;"	d
-SPI_REG_RX0_REQ_LEN	include/gspi_ops.h	52;"	d
-SPI_REG_STATUS_RECOVERY	include/gspi_ops.h	48;"	d
-SPI_REG_TX_CTRL	include/gspi_ops.h	47;"	d
-SPI_RX0_REQ_LEN_1_BYTE	include/gspi_ops.h	70;"	d
-SPI_STATUS_RECOVERY	include/gspi_ops.h	66;"	d
-SPI_TX_CTRL	include/gspi_ops.h	65;"	d
-SPS_SEL	include/hal_com_reg.h	1277;"	d
-SPUR_CAL_METHOD	hal/phydm/halphyrf_ce.h	/^} SPUR_CAL_METHOD;$/;"	t	typeref:enum:_SPUR_CAL_METHOD
-SPUR_CAL_METHOD	hal/phydm/halphyrf_win.h	/^} SPUR_CAL_METHOD;$/;"	t	typeref:enum:_SPUR_CAL_METHOD
-SRESET_TGP_LINK_STATUS	include/rtw_sreset.h	/^	SRESET_TGP_LINK_STATUS = 2,$/;"	e	enum:__anon50
-SRESET_TGP_NULL	include/rtw_sreset.h	/^	SRESET_TGP_NULL = 0,$/;"	e	enum:__anon50
-SRESET_TGP_XMIT_STATUS	include/rtw_sreset.h	/^	SRESET_TGP_XMIT_STATUS = 1,$/;"	e	enum:__anon50
-SSID	include/rtw_pwrctrl.h	/^	u8		SSID[32];$/;"	m	struct:pno_ssid
-SSID_len	include/rtw_pwrctrl.h	/^	u32		SSID_len;$/;"	m	struct:pno_ssid
-SSIZE_PTR	include/basic_types.h	164;"	d
-SSIZE_T	include/basic_types.h	/^	typedef	__kernel_ssize_t	SSIZE_T;$/;"	t
-SS_BACKOP_EN	include/rtw_mlme_ext.h	/^	SS_BACKOP_EN = BIT0, \/* backop when linked *\/$/;"	e	enum:ss_backop_flag
-SS_BACKOP_EN_NL	include/rtw_mlme_ext.h	/^	SS_BACKOP_EN_NL = BIT1, \/* backop even when no linked *\/$/;"	e	enum:ss_backop_flag
-SS_BACKOP_PS_ANNC	include/rtw_mlme_ext.h	/^	SS_BACKOP_PS_ANNC = BIT4,$/;"	e	enum:ss_backop_flag
-SS_BACKOP_TX_RESUME	include/rtw_mlme_ext.h	/^	SS_BACKOP_TX_RESUME = BIT5,$/;"	e	enum:ss_backop_flag
-STAKEY_TYPE	include/rtw_cmd.h	/^enum STAKEY_TYPE {$/;"	g
-STATION_INFO_ASSOC_REQ_IES	os_dep/linux/ioctl_cfg80211.c	31;"	d	file:
-STATION_INFO_RX_PACKETS	os_dep/linux/ioctl_cfg80211.c	29;"	d	file:
-STATION_INFO_SIGNAL	os_dep/linux/ioctl_cfg80211.c	27;"	d	file:
-STATION_INFO_TX_BITRATE	os_dep/linux/ioctl_cfg80211.c	28;"	d	file:
-STATION_INFO_TX_PACKETS	os_dep/linux/ioctl_cfg80211.c	30;"	d	file:
-STATUS_INSUFFICIENT_RESOURCES	include/rtw_ioctl.h	30;"	d
-STATUS_NOT_SUPPORTED	include/rtw_ioctl.h	31;"	d
-STATUS_PENDING	include/rtw_ioctl.h	27;"	d
-STATUS_SUCCESS	include/rtw_ioctl.h	26;"	d
-STATUS_UNSUCCESSFUL	include/rtw_ioctl.h	29;"	d
-STA_INFO_T	hal/phydm/phydm_types.h	/^	typedef struct stat_info		STA_INFO_T,*PSTA_INFO_T;$/;"	t	typeref:struct:stat_info
-STA_INFO_T	hal/phydm/phydm_types.h	119;"	d
-STA_INFO_T	hal/phydm/phydm_types.h	228;"	d
-STA_INFO_UPDATE_ALL	include/sta_info.h	/^	STA_INFO_UPDATE_ALL = STA_INFO_UPDATE_BW$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_BW	include/sta_info.h	/^	STA_INFO_UPDATE_BW = BIT(0),$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_CAP	include/sta_info.h	/^	STA_INFO_UPDATE_CAP = BIT(3),$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_HT_CAP	include/sta_info.h	/^	STA_INFO_UPDATE_HT_CAP = BIT(4),$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_MAX	include/sta_info.h	/^	STA_INFO_UPDATE_MAX$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_NONE	include/sta_info.h	/^	STA_INFO_UPDATE_NONE = 0,$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_PROTECTION_MODE	include/sta_info.h	/^	STA_INFO_UPDATE_PROTECTION_MODE = BIT(2),$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_RATE	include/sta_info.h	/^	STA_INFO_UPDATE_RATE = BIT(1),$/;"	e	enum:sta_info_update_type
-STA_INFO_UPDATE_VHT_CAP	include/sta_info.h	/^	STA_INFO_UPDATE_VHT_CAP = BIT(5),$/;"	e	enum:sta_info_update_type
-STA_LAST_RX_PKTS_ARG	include/sta_info.h	519;"	d
-STA_MSTATUS_RPT_WK_CID	include/rtw_cmd.h	/^	STA_MSTATUS_RPT_WK_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-STA_OP_WFD_MODE	include/sta_info.h	532;"	d
-STA_OP_WFD_MODE	include/sta_info.h	535;"	d
-STA_PKTS_FMT	include/sta_info.h	529;"	d
-STA_RX_PKTS_ARG	include/sta_info.h	514;"	d
-STA_RX_PKTS_DIFF_ARG	include/sta_info.h	524;"	d
-STA_SET_OP_WFD_MODE	include/sta_info.h	533;"	d
-STA_SET_OP_WFD_MODE	include/sta_info.h	536;"	d
-STBC_HT_CAP_TX	include/rtw_ht.h	90;"	d
-STBC_HT_ENABLE_RX	include/rtw_ht.h	87;"	d
-STBC_HT_ENABLE_TX	include/rtw_ht.h	88;"	d
-STBC_HT_TEST_TX_ENABLE	include/rtw_ht.h	89;"	d
-STBC_VHT_CAP_TX	include/rtw_vht.h	31;"	d
-STBC_VHT_ENABLE_RX	include/rtw_vht.h	28;"	d
-STBC_VHT_ENABLE_TX	include/rtw_vht.h	29;"	d
-STBC_VHT_TEST_TX_ENABLE	include/rtw_vht.h	30;"	d
-STOP_BCNQ	include/hal_com_reg.h	1495;"	d
-STORE_DEFAULT_NHM_SETTING	hal/phydm/phydm_acs.h	31;"	d
-STORE_NHM_SETTING	hal/phydm/phydm_ccx.h	7;"	d
-STORE_SWING_TABLE	hal/hal_com_phycfg.c	4944;"	d	file:
-STRUCT_PACKED	include/osdep_service_bsd.h	746;"	d
-STRUCT_PACKED	include/osdep_service_ce.h	188;"	d
-STRUCT_PACKED	include/osdep_service_linux.h	441;"	d
-STRUCT_PACKED	include/osdep_service_xp.h	199;"	d
-STR_EQUAL_2G	hal/hal_com_phycfg.c	4939;"	d	file:
-STR_EQUAL_5G	hal/hal_com_phycfg.c	4935;"	d	file:
-ST_CMD_ADD	include/sta_info.h	142;"	d
-ST_CMD_CHK	include/sta_info.h	144;"	d
-ST_CMD_DEL	include/sta_info.h	143;"	d
-ST_EXPIRE_MS	include/sta_info.h	129;"	d
-ST_STATUS_CHECK	include/sta_info.h	125;"	d
-ST_STATUS_ESTABLISH	include/sta_info.h	126;"	d
-ST_STATUS_EXPIRE	include/sta_info.h	127;"	d
-ST_STATUS_NONE	include/sta_info.h	124;"	d
-SUBARCH	Makefile	/^SUBARCH := $(shell uname -m | sed -e s\/i.86\/i386\/)$/;"	m
-SUCCESS	hal/phydm/phydm_types.h	124;"	d
-SUCCESS	include/basic_types.h	24;"	d
-SUNXI_SDIO_WIFI_NUM_RTL8189ES	platform/platform_ARM_SUNxI_sdio.c	29;"	d	file:
-SUPPORTABLITY_PHYDMLIZE	hal/phydm/phydm_features.h	103;"	d
-SUPPORTABLITY_PHYDMLIZE	hal/phydm/phydm_features.h	40;"	d
-SUPPORTABLITY_PHYDMLIZE	hal/phydm/phydm_features.h	53;"	d
-SUPPORTED_24G_NETTYPE_MSK	include/ieee80211.h	221;"	d
-SUPPORTED_5G_NETTYPE_MSK	include/ieee80211.h	222;"	d
-SUPPORT_BEAM_PATTERN_NUM	hal/phydm/phydm_antdiv.h	51;"	d
-SUPPORT_HW_RADIO_DETECT	include/hal_data.h	750;"	d
-SUPPORT_HW_RFOFF_DETECTED	include/autoconf.h	173;"	d
-SUPPORT_RF_PATH_NUM	hal/phydm/phydm_antdiv.h	50;"	d
-SURVEY_TO	include/rtw_mlme_ext.h	30;"	d
-SUS_HOST	include/hal_com_reg.h	1185;"	d
-SVN_COMMIT_VERSION_8723D	hal/phydm/rtl8723d/version_rtl8723d.h	2;"	d
-SWAS_NoLink_BK_Reg948	hal/phydm/phydm_antdiv.h	/^	u4Byte		SWAS_NoLink_BK_Reg948;$/;"	m	struct:_SW_Antenna_Switch_
-SWAS_NoLink_State	hal/phydm/phydm_antdiv.h	/^	u1Byte		SWAS_NoLink_State;$/;"	m	struct:_SW_Antenna_Switch_
-SWAT_T	hal/phydm/phydm_antdiv.h	/^}SWAT_T, *pSWAT_T;$/;"	t	typeref:struct:_SW_Antenna_Switch_
-SWAW_STEP_DETERMINE	hal/phydm/phydm_antdiv.h	127;"	d
-SWAW_STEP_INIT	hal/phydm/phydm_antdiv.h	125;"	d
-SWAW_STEP_PEEK	hal/phydm/phydm_antdiv.h	126;"	d
-SWSI	include/rtw_cmd.h	/^	SWSI,$/;"	e	enum:RFINTFS
-SW_CONTROL	include/rtw_mp.h	/^	SW_CONTROL,		\/* sw encryption& decryption *\/$/;"	e	enum:_ENCRY_CTRL_STATE_
-SW_ENCRY_HW_DECRY	include/rtw_mp.h	/^	SW_ENCRY_HW_DECRY	\/* sw encryption & hw decryption *\/$/;"	e	enum:_ENCRY_CTRL_STATE_
-SW_LED_MODE0	include/hal_com_led.h	/^	SW_LED_MODE0, \/* SW control 1 LED via GPIO0. It is default option. *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE0	include/hal_com_led.h	/^	SW_LED_MODE0, \/* SW control 1 LED via GPIO0. It is default option. *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-SW_LED_MODE0	include/hal_com_led.h	/^	SW_LED_MODE0, \/* SW control 1 LED via GPIO0. It is default option. *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE1	include/hal_com_led.h	/^	SW_LED_MODE1, \/* 2 LEDs, through LED0 and LED1. For ALPHA. *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-SW_LED_MODE1	include/hal_com_led.h	/^	SW_LED_MODE1, \/* 2 LEDs, through LED0 and LED1. For ALPHA. *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE1	include/hal_com_led.h	/^	SW_LED_MODE1, \/* SW control for PCI Express *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE10	include/hal_com_led.h	/^	SW_LED_MODE10, \/* added by chiyokolin, for Edimax-ASUS *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE10	include/hal_com_led.h	/^	SW_LED_MODE10, \/* for Netgear A6200V2 *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE11	include/hal_com_led.h	/^	SW_LED_MODE11,	\/* added by hpfan, for Xavi *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE11	include/hal_com_led.h	/^	SW_LED_MODE11, \/* for Edimax \/ ASUS *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE12	include/hal_com_led.h	/^	SW_LED_MODE12,	\/* added by chiyokolin, for Azurewave *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE12	include/hal_com_led.h	/^	SW_LED_MODE12, \/* for WNC\/NEC *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE13	include/hal_com_led.h	/^	SW_LED_MODE13, \/* for Netgear A6100, 8811Au *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE14	include/hal_com_led.h	/^	SW_LED_MODE14, \/* for Buffalo, DNI, 8811Au *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE15	include/hal_com_led.h	/^	SW_LED_MODE15, \/* for DLINK,  8811Au\/8812AU	 *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE2	include/hal_com_led.h	/^	SW_LED_MODE2, \/* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-SW_LED_MODE2	include/hal_com_led.h	/^	SW_LED_MODE2, \/* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE2	include/hal_com_led.h	/^	SW_LED_MODE2, \/* SW control for Cameo. *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE3	include/hal_com_led.h	/^	SW_LED_MODE3, \/* SW contorl for RunTop. *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE3	include/hal_com_led.h	/^	SW_LED_MODE3, \/* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-SW_LED_MODE3	include/hal_com_led.h	/^	SW_LED_MODE3, \/* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE4	include/hal_com_led.h	/^	SW_LED_MODE4, \/* SW control for Netcore *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE4	include/hal_com_led.h	/^	SW_LED_MODE4, \/* for Edimax \/ Belkin *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-SW_LED_MODE4	include/hal_com_led.h	/^	SW_LED_MODE4, \/* for Edimax \/ Belkin *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE5	include/hal_com_led.h	/^	SW_LED_MODE5, \/* added by vivi, for led new mode, DLINK *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE5	include/hal_com_led.h	/^	SW_LED_MODE5, \/* for Sercomm \/ Belkin	 *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-SW_LED_MODE5	include/hal_com_led.h	/^	SW_LED_MODE5, \/* for Sercomm \/ Belkin	 *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE6	include/hal_com_led.h	/^	SW_LED_MODE6,	\/* for 88CU minicard, porting from ce SW_LED_MODE7 *\/$/;"	e	enum:_LED_STRATEGY_SDIO
-SW_LED_MODE6	include/hal_com_led.h	/^	SW_LED_MODE6,	\/* for 88CU minicard, porting from ce SW_LED_MODE7 *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE6	include/hal_com_led.h	/^	SW_LED_MODE6, \/* added by vivi, for led new mode, PRONET *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE7	include/hal_com_led.h	/^	SW_LED_MODE7,	\/* for Netgear special requirement *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE7	include/hal_com_led.h	/^	SW_LED_MODE7, \/* added by chiyokolin, for Lenovo, PCI Express Minicard Spec Rev.1.2 spec *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE8	include/hal_com_led.h	/^	SW_LED_MODE8, \/* added by chiyokolin, for QMI *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE8	include/hal_com_led.h	/^	SW_LED_MODE8, \/* for LC *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_LED_MODE9	include/hal_com_led.h	/^	SW_LED_MODE9, \/* added by chiyokolin, for BITLAND-LENOVO, PCI Express Minicard Spec Rev.1.1	 *\/$/;"	e	enum:_LED_STRATEGY_PCIE
-SW_LED_MODE9	include/hal_com_led.h	/^	SW_LED_MODE9, \/* for Belkin AC950 *\/$/;"	e	enum:_LED_STRATEGY_USB
-SW_OFFLOAD_EN	include/hal_com_reg.h	1259;"	d
-SZ_OID_NDIS_SEG1	include/rtw_ioctl.h	107;"	d
-SZ_OID_NDIS_SEG10	include/rtw_ioctl.h	116;"	d
-SZ_OID_NDIS_SEG2	include/rtw_ioctl.h	108;"	d
-SZ_OID_NDIS_SEG3	include/rtw_ioctl.h	109;"	d
-SZ_OID_NDIS_SEG4	include/rtw_ioctl.h	110;"	d
-SZ_OID_NDIS_SEG5	include/rtw_ioctl.h	111;"	d
-SZ_OID_NDIS_SEG6	include/rtw_ioctl.h	112;"	d
-SZ_OID_NDIS_SEG7	include/rtw_ioctl.h	113;"	d
-SZ_OID_NDIS_SEG8	include/rtw_ioctl.h	114;"	d
-SZ_OID_NDIS_SEG9	include/rtw_ioctl.h	115;"	d
-Sbox	core/rtw_wapi_sms4.c	/^const u8 Sbox[256] = {$/;"	v
-Sbox1	core/rtw_security.c	/^static const unsigned short Sbox1[2][256] =      \/* Sbox for hash (can be in ROM)    *\/$/;"	v	file:
-ScanType	include/rtw_mlme_ext.h	/^	RT_SCAN_TYPE	ScanType;		\/* Scan type such as passive or active scan. *\/$/;"	m	struct:_RT_CHANNEL_INFO
-SdioLocalCmd52Read1Byte	hal/rtl8723d/sdio/sdio_ops.c	/^u8 SdioLocalCmd52Read1Byte(PADAPTER padapter, u32 addr)$/;"	f
-SdioLocalCmd52Read2Byte	hal/rtl8723d/sdio/sdio_ops.c	/^u16 SdioLocalCmd52Read2Byte(PADAPTER padapter, u32 addr)$/;"	f
-SdioLocalCmd52Read4Byte	hal/rtl8723d/sdio/sdio_ops.c	/^u32 SdioLocalCmd52Read4Byte(PADAPTER padapter, u32 addr)$/;"	f
-SdioLocalCmd52Write1Byte	hal/rtl8723d/sdio/sdio_ops.c	/^void SdioLocalCmd52Write1Byte(PADAPTER padapter, u32 addr, u8 v)$/;"	f
-SdioLocalCmd52Write2Byte	hal/rtl8723d/sdio/sdio_ops.c	/^void SdioLocalCmd52Write2Byte(PADAPTER padapter, u32 addr, u16 v)$/;"	f
-SdioLocalCmd52Write4Byte	hal/rtl8723d/sdio/sdio_ops.c	/^void SdioLocalCmd52Write4Byte(PADAPTER padapter, u32 addr, u32 v)$/;"	f
-SdioLocalCmd53Read4Byte	hal/rtl8723d/sdio/sdio_ops.c	/^u32 SdioLocalCmd53Read4Byte(PADAPTER padapter, u32 addr)$/;"	f
-SdioRxFIFOCnt	include/hal_data.h	/^	u8			SdioRxFIFOCnt;$/;"	m	struct:hal_com_data
-SdioRxFIFOSize	include/hal_data.h	/^	u16			SdioRxFIFOSize;$/;"	m	struct:hal_com_data
-SdioTxFIFOFreePage	include/hal_data.h	/^	u8			SdioTxFIFOFreePage[SDIO_TX_FREE_PG_QUEUE];$/;"	m	struct:hal_com_data
-SdioTxFIFOFreePageLock	include/hal_data.h	/^	_lock		SdioTxFIFOFreePageLock;$/;"	m	struct:hal_com_data
-SdioTxOQTFreeSpace	include/hal_data.h	/^	u16			SdioTxOQTFreeSpace;$/;"	m	struct:hal_com_data
-SdioTxOQTFreeSpace	include/hal_data.h	/^	u8			SdioTxOQTFreeSpace;$/;"	m	struct:hal_com_data
-SdioTxOQTMaxFreeSpace	include/hal_data.h	/^	u8			SdioTxOQTMaxFreeSpace;$/;"	m	struct:hal_com_data
-SdioXmitSema	include/rtw_xmit.h	/^	_sema		SdioXmitSema;$/;"	m	struct:xmit_priv
-SdioXmitTerminateSema	include/rtw_xmit.h	/^	_sema		SdioXmitTerminateSema;$/;"	m	struct:xmit_priv
-SdioXmitThread	include/rtw_xmit.h	/^	_thread_hdl_	SdioXmitThread;$/;"	m	struct:xmit_priv
-SecCalculateMicSMS4	core/rtw_wapi_sms4.c	/^void SecCalculateMicSMS4($/;"	f
-SecIsInPMKIDList	core/rtw_mlme.c	/^static int SecIsInPMKIDList(_adapter *Adapter, u8 *bssid)$/;"	f	file:
-SecSMS4HeaderFillIV	core/rtw_wapi_sms4.c	/^int SecSMS4HeaderFillIV(_adapter *padapter, u8 *pxmitframe)$/;"	f
-SecSWSMS4Decryption	core/rtw_wapi_sms4.c	/^u8 SecSWSMS4Decryption($/;"	f
-SecSWSMS4Encryption	core/rtw_wapi_sms4.c	/^void SecSWSMS4Encryption($/;"	f
-SendFWHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^SendFWHTNDPAPacket($/;"	f
-SendFWHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.h	153;"	d
-SendFWVHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^SendFWVHTNDPAPacket($/;"	f
-SendFWVHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.h	155;"	d
-SendSWHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^SendSWHTNDPAPacket($/;"	f
-SendSWHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.h	154;"	d
-SendSWVHTBFReportPoll	hal/phydm/txbf/haltxbfinterface.c	/^SendSWVHTBFReportPoll($/;"	f
-SendSWVHTBFReportPoll	hal/phydm/txbf/haltxbfinterface.h	158;"	d
-SendSWVHTBFReportPoll	hal/phydm/txbf/haltxbfinterface.h	85;"	d
-SendSWVHTGIDMgntFrame	hal/phydm/txbf/haltxbfinterface.c	/^SendSWVHTGIDMgntFrame($/;"	f
-SendSWVHTGIDMgntFrame	hal/phydm/txbf/haltxbfinterface.h	157;"	d
-SendSWVHTGIDMgntFrame	hal/phydm/txbf/haltxbfinterface.h	84;"	d
-SendSWVHTMUNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^SendSWVHTMUNDPAPacket($/;"	f
-SendSWVHTMUNDPAPacket	hal/phydm/txbf/haltxbfinterface.h	159;"	d
-SendSWVHTMUNDPAPacket	hal/phydm/txbf/haltxbfinterface.h	86;"	d
-SendSWVHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.c	/^SendSWVHTNDPAPacket($/;"	f
-SendSWVHTNDPAPacket	hal/phydm/txbf/haltxbfinterface.h	156;"	d
-ServiceField	include/rtw_mp.h	/^	u8			ServiceField;$/;"	m	struct:_RT_PMAC_TX_INFO
-SetAMsdu	include/wifi.h	426;"	d
-SetAckpolicy	include/wifi.h	417;"	d
-SetAntenna	core/rtw_mp.c	/^void SetAntenna(PADAPTER pAdapter)$/;"	f
-SetBandwidth	core/rtw_mp.c	/^void SetBandwidth(PADAPTER pAdapter)$/;"	f
-SetBeaconRelatedRegistersHandler	include/hal_intf.h	/^	void	(*SetBeaconRelatedRegistersHandler)(_adapter *padapter);$/;"	m	struct:hal_ops
-SetCCKContinuousTx	core/rtw_mp.c	/^void SetCCKContinuousTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-SetCarrierSuppressionTx	core/rtw_mp.c	/^void SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-SetCarrierSuppressionTx_parm	include/rtw_cmd.h	/^struct SetCarrierSuppressionTx_parm {$/;"	s
-SetChannel	core/rtw_mp.c	/^void SetChannel(PADAPTER pAdapter)$/;"	f
-SetChannelPlan_param	include/rtw_cmd.h	/^struct SetChannelPlan_param {$/;"	s
-SetChannelSwitch_param	include/rtw_cmd.h	/^struct SetChannelSwitch_param {$/;"	s
-SetContinuousTx	core/rtw_mp.c	/^void SetContinuousTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-SetContinuousTx_parm	include/rtw_cmd.h	/^struct SetContinuousTx_parm {$/;"	s
-SetCrystalCap_parm	include/rtw_cmd.h	/^struct SetCrystalCap_parm {$/;"	s
-SetDataRate	core/rtw_mp.c	/^void SetDataRate(PADAPTER pAdapter)$/;"	f
-SetDuration	include/wifi.h	399;"	d
-SetEOSP	include/wifi.h	412;"	d
-SetFrDs	include/wifi.h	285;"	d
-SetFragNum	include/wifi.h	385;"	d
-SetFrameSubType	include/wifi.h	373;"	d
-SetFrameType	include/wifi.h	365;"	d
-SetFwBTFwPatchCmd	hal/rtl8723d/rtl8723d_hal_init.c	/^SetFwBTFwPatchCmd($/;"	f
-SetFwBTPwrCmd	hal/rtl8723d/rtl8723d_hal_init.c	/^SetFwBTPwrCmd($/;"	f
-SetFwRsvdPagePkt_BTCoex	hal/rtl8723d/rtl8723d_cmd.c	/^static void SetFwRsvdPagePkt_BTCoex(PADAPTER padapter)$/;"	f	file:
-SetHalBFEnterOnDemandCnt	include/rtw_beamforming.h	/^	u8			SetHalBFEnterOnDemandCnt;$/;"	m	struct:beamforming_info
-SetHalBFLeaveOnDemandCnt	include/rtw_beamforming.h	/^	u8			SetHalBFLeaveOnDemandCnt;$/;"	m	struct:beamforming_info
-SetHalDefVar	hal/hal_com.c	/^SetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)$/;"	f
-SetHalDefVar8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^u8 SetHalDefVar8723D(PADAPTER padapter, HAL_DEF_VARIABLE variable, void *pval)$/;"	f
-SetHalDefVar8723DSDIO	hal/rtl8723d/sdio/sdio_halinit.c	/^SetHalDefVar8723DSDIO($/;"	f
-SetHalDefVarHandler	include/hal_intf.h	/^	u8(*SetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);$/;"	m	struct:hal_ops
-SetHalODMVar	hal/hal_com.c	/^void SetHalODMVar($/;"	f
-SetHalODMVarHandler	include/hal_intf.h	/^	void	(*SetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, BOOLEAN bSet);$/;"	m	struct:hal_ops
-SetHalSoundownOnDemandCnt	include/rtw_beamforming.h	/^	u8			SetHalSoundownOnDemandCnt;$/;"	m	struct:beamforming_info
-SetHwReg	hal/hal_com.c	/^void SetHwReg(_adapter *adapter, u8 variable, u8 *val)$/;"	f
-SetHwReg8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^void SetHwReg8723D(PADAPTER padapter, u8 variable, u8 *val)$/;"	f
-SetHwReg8723DS	hal/rtl8723d/sdio/sdio_halinit.c	/^void SetHwReg8723DS(PADAPTER padapter, u8 variable, u8 *val)$/;"	f
-SetHwRegHandler	include/hal_intf.h	/^	void	(*SetHwRegHandler)(_adapter *padapter, u8	variable, u8 *val);$/;"	m	struct:hal_ops
-SetMData	include/wifi.h	336;"	d
-SetMFrag	include/wifi.h	300;"	d
-SetOFDMContinuousTx	core/rtw_mp.c	/^void SetOFDMContinuousTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-SetOrderBit	include/wifi.h	757;"	d
-SetPacketRx	core/rtw_mp.c	/^void SetPacketRx(PADAPTER pAdapter, u8 bStartRx, u8 bAB)$/;"	f
-SetPacketTx	core/rtw_mp.c	/^void SetPacketTx(PADAPTER padapter)$/;"	f
-SetPowerTracking	core/rtw_mp.c	/^s32 SetPowerTracking(PADAPTER padapter, u8 enable)$/;"	f
-SetPriority	include/wifi.h	405;"	d
-SetPrivacy	include/wifi.h	348;"	d
-SetPwrMgt	include/wifi.h	324;"	d
-SetRetry	include/wifi.h	312;"	d
-SetSeqNum	include/wifi.h	392;"	d
-SetSingleCarrierTx	core/rtw_mp.c	/^void SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-SetSingleCarrierTx_parm	include/rtw_cmd.h	/^struct SetSingleCarrierTx_parm {$/;"	s
-SetSingleToneTx	core/rtw_mp.c	/^void SetSingleToneTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-SetSingleToneTx_parm	include/rtw_cmd.h	/^struct SetSingleToneTx_parm {$/;"	s
-SetThermalMeter	core/rtw_mp.c	/^s32 SetThermalMeter(PADAPTER pAdapter, u8 target_ther)$/;"	f
-SetToDs	include/wifi.h	273;"	d
-SetTxAGCOffset	core/rtw_mp.c	/^void SetTxAGCOffset(PADAPTER pAdapter, u32 ulTxAGCOffset)$/;"	f
-SetTxPower	core/rtw_mp.c	/^int SetTxPower(PADAPTER pAdapter)$/;"	f
-SetTxPower_parm	include/rtw_cmd.h	/^struct SetTxPower_parm {$/;"	s
-Set_MSR	core/rtw_wlan_util.c	/^void Set_MSR(_adapter *padapter, u8 type)$/;"	f
-Sigma0	include/rtw_security.h	440;"	d
-Sigma1	include/rtw_security.h	441;"	d
-SignalField	include/rtw_mp.h	/^	u8			SignalField;$/;"	m	struct:_RT_PMAC_TX_INFO
-SignalQuality	hal/phydm/phydm.h	/^	u1Byte		SignalQuality;					\/* in 0-100 index. *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-SignalQuality	hal/phydm/phydm.h	/^	u1Byte		SignalQuality;				\/* in 0-100 index. *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-SignalQuality	include/rtw_recv.h	/^	u8			SignalQuality;				\/* in 0-100 index. *\/$/;"	m	struct:phy_info
-SignalQuality	include/wlan_bssdef.h	/^	u8	SignalQuality;\/* (in percentage) *\/$/;"	m	struct:_WLAN_PHY_INFO
-SignalStrength	hal/phydm/phydm.h	/^	u1Byte		SignalStrength;				\/* in 0-100 index. *\/$/;"	m	struct:_ODM_Phy_Status_Info_
-SignalStrength	include/rtw_recv.h	/^	u8			SignalStrength;				\/* in 0-100 index. *\/$/;"	m	struct:phy_info
-SignalStrength	include/wlan_bssdef.h	/^	u8	SignalStrength;\/* (in percentage) *\/$/;"	m	struct:_WLAN_PHY_INFO
-Signature	include/rtl8188e_hal.h	/^	u16		Signature;	\/* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Signature	include/rtl8188f_hal.h	/^	u16		Signature;	\/* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Signature	include/rtl8703b_hal.h	/^	u16		Signature;	\/* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Signature	include/rtl8723b_hal.h	/^	u16		Signature;	\/* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Signature	include/rtl8723d_hal.h	/^	u16		Signature;	\/* 92C0: test chip; 92C, 88C0: test chip; 88C1: MP A-cut; 92C1: MP A-cut *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Single_Ant_Counter	hal/phydm/phydm_antdiv.h	/^	u2Byte		Single_Ant_Counter;$/;"	m	struct:_SW_Antenna_Switch_
-SmartPS_RLBM	include/rtl8188e_cmd.h	/^	u8 SmartPS_RLBM;\/* LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData *\/$/;"	m	struct:_SETPWRMODE_PARM
-SmartPS_RLBM	include/rtl8192e_cmd.h	/^	u8 SmartPS_RLBM;\/* LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData *\/$/;"	m	struct:_SETPWRMODE_PARM
-Sniff_attempt	include/rtw_btcoex.h	/^	u8 Sniff_attempt:1;$/;"	m	struct:btinfo_8761ATV
-Snonce	include/rtw_tdls.h	/^	u8 Snonce[WPA_NONCE_LEN]; \/* Initiator Nonce in TDLS *\/$/;"	m	struct:wpa_tdls_ftie
-SoundBW	hal/phydm/phydm_beamforming.h	/^	CHANNEL_WIDTH			SoundBW;		\/*Sounding BandWidth*\/$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-SoundBW	hal/phydm/phydm_beamforming.h	/^	CHANNEL_WIDTH	SoundBW;$/;"	m	struct:_RT_SOUNDING_INFO
-SoundCnt	include/rtw_beamforming.h	/^	u8 SoundCnt;$/;"	m	struct:beamformee_entry
-SoundIdx	hal/phydm/phydm_beamforming.h	/^	u1Byte			SoundIdx;$/;"	m	struct:_RT_SOUNDING_INFO
-SoundMode	hal/phydm/phydm_beamforming.h	/^	SOUNDING_MODE	SoundMode; $/;"	m	struct:_RT_SOUNDING_INFO
-SoundOidBW	hal/phydm/phydm_beamforming.h	/^	CHANNEL_WIDTH	SoundOidBW;	$/;"	m	struct:_RT_BEAMFORMING_OID_INFO
-SoundOidIdx	hal/phydm/phydm_beamforming.h	/^	u1Byte			SoundOidIdx;$/;"	m	struct:_RT_BEAMFORMING_OID_INFO
-SoundOidMode	hal/phydm/phydm_beamforming.h	/^	SOUNDING_MODE	SoundOidMode;$/;"	m	struct:_RT_BEAMFORMING_OID_INFO
-SoundOidPeriod	hal/phydm/phydm_beamforming.h	/^	u2Byte			SoundOidPeriod;$/;"	m	struct:_RT_BEAMFORMING_OID_INFO
-SoundPeriod	hal/phydm/phydm_beamforming.h	/^	u2Byte					SoundPeriod;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-SoundPeriod	hal/phydm/phydm_beamforming.h	/^	u2Byte			SoundPeriod;$/;"	m	struct:_RT_SOUNDING_INFO
-SoundingInfo	hal/phydm/phydm_beamforming.h	/^	RT_SOUNDING_INFO			SoundingInfo;$/;"	m	struct:_RT_BEAMFORMING_INFO
-SoundingSequence	hal/phydm/phydm_beamforming.h	/^	u1Byte					SoundingSequence;$/;"	m	struct:_RT_BEAMFORMING_INFO
-SourceAdapter	hal/phydm/phydm_beamforming.h	/^	PADAPTER				SourceAdapter;$/;"	m	struct:_RT_BEAMFORMING_INFO
-Ssid	include/wlan_bssdef.h	/^	NDIS_802_11_SSID  Ssid;$/;"	m	struct:_WLAN_BSSID_EX
-Ssid	include/wlan_bssdef.h	/^	UCHAR  Ssid[32];$/;"	m	struct:_NDIS_802_11_SSID
-SsidBuf	include/rtw_security.h	/^	u8						SsidBuf[33];$/;"	m	struct:_RT_PMKID_LIST
-SsidLength	include/wlan_bssdef.h	/^	ULONG  SsidLength;$/;"	m	struct:_NDIS_802_11_SSID
-StationID	hal/phydm/phydm.h	/^	u1Byte		StationID;$/;"	m	struct:_ODM_Per_Pkt_Info_
-Status	include/drv_types_pci.h	/^	u16	Status;$/;"	m	struct:_PCI_COMMON_CONFIG
-Status	include/rtw_efuse.h	/^	ERROR_CODE	  Status;$/;"	m	struct:_EFUSE_HAL
-Status	include/wlan_bssdef.h	/^	NDIS_802_11_STATUS_INDICATION       Status;$/;"	m	struct:_NDIS_802_11_AUTHENTICATION_EVENT
-StatusCode	include/wlan_bssdef.h	/^	USHORT StatusCode;$/;"	m	struct:_NDIS_802_11_AI_RESFI
-StatusType	include/wlan_bssdef.h	/^	NDIS_802_11_STATUS_TYPE StatusType;$/;"	m	struct:_NDIS_802_11_STATUS_INDICATION
-StopBE	include/hal_com_reg.h	1090;"	d
-StopBK	include/hal_com_reg.h	1089;"	d
-StopBecon	include/hal_com_reg.h	1086;"	d
-StopHigh	include/hal_com_reg.h	1087;"	d
-StopMgt	include/hal_com_reg.h	1088;"	d
-StopTxBeacon	hal/hal_com.c	/^void StopTxBeacon(_adapter *padapter)$/;"	f
-StopVI	include/hal_com_reg.h	1091;"	d
-StopVO	include/hal_com_reg.h	1092;"	d
-SubClass	include/drv_types_pci.h	/^	u8	SubClass;$/;"	m	struct:_PCI_COMMON_CONFIG
-SubSystemID	include/drv_types_pci.h	/^			u16	SubSystemID;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-SubVendorID	include/drv_types_pci.h	/^			u16	SubVendorID;$/;"	m	struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-Subversion	include/rtl8188e_hal.h	/^	u8		Subversion;	\/* FW Subversion, default 0x00 *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Subversion	include/rtl8188f_hal.h	/^	u16		Subversion;	\/* FW Subversion, default 0x00 *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Subversion	include/rtl8703b_hal.h	/^	u16		Subversion;	\/* FW Subversion, default 0x00 *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Subversion	include/rtl8723b_hal.h	/^	u16		Subversion;	\/* FW Subversion, default 0x00 *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Subversion	include/rtl8723d_hal.h	/^	u16		Subversion;	\/* FW Subversion, default 0x00 *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-SupportAbility	hal/phydm/phydm.h	/^	u4Byte			SupportAbility;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-SupportICType	hal/phydm/phydm.h	/^	u4Byte			SupportICType;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-SupportInterface	hal/phydm/phydm.h	/^	u1Byte			SupportInterface;			$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-SupportPlatform	hal/phydm/phydm.h	/^	u1Byte			SupportPlatform;		$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-SupportedRates	include/wlan_bssdef.h	/^	NDIS_802_11_RATES_EX  SupportedRates;$/;"	m	struct:_WLAN_BSSID_EX
-SvnIdx	include/rtl8188e_hal.h	/^	u32		SvnIdx;	\/* The SVN entry index *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-SvnIdx	include/rtl8188f_hal.h	/^	u32		SvnIdx;	\/* The SVN entry index *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-SvnIdx	include/rtl8703b_hal.h	/^	u32		SvnIdx;	\/* The SVN entry index *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-SvnIdx	include/rtl8723b_hal.h	/^	u32		SvnIdx;	\/* The SVN entry index *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-SvnIdx	include/rtl8723d_hal.h	/^	u32		SvnIdx;	\/* The SVN entry index *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-SwAntDivCheckBeforeLink	hal/phydm/phydm_antdect.h	70;"	d
-SwAntDivRestAfterLink	hal/phydm/phydm_antdiv.h	378;"	d
-SwChnlCmd	include/hal_phy.h	/^} SwChnlCmd;$/;"	t	typeref:struct:_SwChnlCmd
-SwChnlCmdID	include/hal_phy.h	/^} SwChnlCmdID;$/;"	t	typeref:enum:_SwChnlCmdID
-SwLed0	include/hal_com_led.h	/^	LED_DATA			SwLed0;$/;"	m	struct:led_priv
-SwLed1	include/hal_com_led.h	/^	LED_DATA			SwLed1;$/;"	m	struct:led_priv
-SwLed2	include/hal_com_led.h	/^	LED_DATA			SwLed2;$/;"	m	struct:led_priv
-SwLedBlink	hal/led/hal_sdio_led.c	/^SwLedBlink($/;"	f
-SwLedBlink1	hal/led/hal_sdio_led.c	/^SwLedBlink1($/;"	f
-SwLedBlink2	hal/led/hal_sdio_led.c	/^SwLedBlink2($/;"	f
-SwLedBlink3	hal/led/hal_sdio_led.c	/^SwLedBlink3($/;"	f
-SwLedBlink4	hal/led/hal_sdio_led.c	/^SwLedBlink4($/;"	f
-SwLedBlink5	hal/led/hal_sdio_led.c	/^SwLedBlink5($/;"	f
-SwLedBlink6	hal/led/hal_sdio_led.c	/^SwLedBlink6($/;"	f
-SwLedControlMode0	hal/led/hal_sdio_led.c	/^SwLedControlMode0($/;"	f	file:
-SwLedControlMode1	hal/led/hal_sdio_led.c	/^SwLedControlMode1($/;"	f	file:
-SwLedControlMode2	hal/led/hal_sdio_led.c	/^SwLedControlMode2($/;"	f	file:
-SwLedControlMode3	hal/led/hal_sdio_led.c	/^SwLedControlMode3($/;"	f	file:
-SwLedControlMode4	hal/led/hal_sdio_led.c	/^SwLedControlMode4($/;"	f	file:
-SwLedControlMode5	hal/led/hal_sdio_led.c	/^SwLedControlMode5($/;"	f	file:
-SwLedControlMode6	hal/led/hal_sdio_led.c	/^SwLedControlMode6($/;"	f	file:
-SwLedOff	include/hal_com_led.h	/^	void (*SwLedOff)(_adapter *padapter, PLED_DATA pLed);$/;"	m	struct:led_priv
-SwLedOff	include/hal_com_led.h	370;"	d
-SwLedOff_8723DS	hal/rtl8723d/sdio/rtl8723ds_led.c	/^SwLedOff_8723DS($/;"	f
-SwLedOn	include/hal_com_led.h	/^	void (*SwLedOn)(_adapter *padapter, PLED_DATA pLed);$/;"	m	struct:led_priv
-SwLedOn	include/hal_com_led.h	364;"	d
-SwLedOn_8723DS	hal/rtl8723d/sdio/rtl8723ds_led.c	/^SwLedOn_8723DS($/;"	f
-SwingTableSize_CCK	hal/phydm/halphyrf_ap.h	/^	u1Byte 		SwingTableSize_CCK;	$/;"	m	struct:_TXPWRTRACK_CFG
-SwingTableSize_CCK	hal/phydm/halphyrf_ce.h	/^	u1Byte 		SwingTableSize_CCK;	$/;"	m	struct:_TXPWRTRACK_CFG
-SwingTableSize_CCK	hal/phydm/halphyrf_win.h	/^	u1Byte 		SwingTableSize_CCK;	$/;"	m	struct:_TXPWRTRACK_CFG
-SwingTableSize_OFDM	hal/phydm/halphyrf_ap.h	/^	u1Byte 		SwingTableSize_OFDM;$/;"	m	struct:_TXPWRTRACK_CFG
-SwingTableSize_OFDM	hal/phydm/halphyrf_ce.h	/^	u1Byte 		SwingTableSize_OFDM;$/;"	m	struct:_TXPWRTRACK_CFG
-SwingTableSize_OFDM	hal/phydm/halphyrf_win.h	/^	u1Byte 		SwingTableSize_OFDM;$/;"	m	struct:_TXPWRTRACK_CFG
-SwitchAntenna_parm	include/rtw_cmd.h	/^struct SwitchAntenna_parm {$/;"	s
-SwitchBandwidth_parm	include/rtw_cmd.h	/^struct SwitchBandwidth_parm {$/;"	s
-SysIntArray	include/hal_data.h	/^	u32			SysIntArray[1];$/;"	m	struct:hal_com_data
-SysIntrMask	include/hal_data.h	/^	u32			SysIntrMask;$/;"	m	struct:hal_com_data
-SysIntrMask	include/hal_data.h	/^	u32			SysIntrMask[1];$/;"	m	struct:hal_com_data
-SysIntrStatus	include/hal_data.h	/^	u32			SysIntrStatus;$/;"	m	struct:hal_com_data
-TAG_HDR_LEN	core/rtw_br_ext.c	70;"	d	file:
-TA_SIZE	core/rtw_security.c	491;"	d	file:
-TCP_DST	include/rtw_mlme.h	1192;"	d
-TCP_SRC	include/rtw_mlme.h	1191;"	d
-TD0	include/rtw_security.h	360;"	d
-TD0_	include/rtw_security.h	368;"	d
-TD1	include/rtw_security.h	361;"	d
-TD1_	include/rtw_security.h	369;"	d
-TD2	include/rtw_security.h	362;"	d
-TD2_	include/rtw_security.h	370;"	d
-TD3	include/rtw_security.h	363;"	d
-TD3_	include/rtw_security.h	371;"	d
-TD41	include/rtw_security.h	364;"	d
-TD42	include/rtw_security.h	365;"	d
-TD43	include/rtw_security.h	366;"	d
-TD44	include/rtw_security.h	367;"	d
-TDLS_ACTION_FIELD	include/ieee80211.h	/^enum TDLS_ACTION_FIELD {$/;"	g
-TDLS_ALIVE_STATE	include/rtw_tdls.h	36;"	d
-TDLS_CHANNEL_SWITCH_REQUEST	include/ieee80211.h	/^	TDLS_CHANNEL_SWITCH_REQUEST = 5,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_CHANNEL_SWITCH_RESPONSE	include/ieee80211.h	/^	TDLS_CHANNEL_SWITCH_RESPONSE = 6,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_CH_SWITCH_ON_STATE	include/rtw_tdls.h	39;"	d
-TDLS_CH_SWITCH_OPER_OFFLOAD_TIMEOUT	include/rtw_tdls.h	48;"	d
-TDLS_CH_SWITCH_PREPARE_STATE	include/rtw_tdls.h	38;"	d
-TDLS_CH_SWITCH_TIME	include/rtw_tdls.h	46;"	d
-TDLS_CH_SWITCH_TIMEOUT	include/rtw_tdls.h	47;"	d
-TDLS_CH_SW_BASE_CHNL	include/rtw_tdls.h	/^	TDLS_CH_SW_BASE_CHNL = 0,$/;"	e	enum:TDLS_CH_SW_CHNL
-TDLS_CH_SW_CHNL	include/rtw_tdls.h	/^enum TDLS_CH_SW_CHNL {$/;"	g
-TDLS_CH_SW_END	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_END,$/;"	e	enum:TDLS_option
-TDLS_CH_SW_END_TO_BASE_CHNL	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_END_TO_BASE_CHNL,$/;"	e	enum:TDLS_option
-TDLS_CH_SW_INITIATOR_STATE	include/rtw_tdls.h	41;"	d
-TDLS_CH_SW_MONITOR_TIMEOUT	include/rtw_tdls.h	55;"	d
-TDLS_CH_SW_OFF_CHNL	include/rtw_tdls.h	/^	TDLS_CH_SW_OFF_CHNL$/;"	e	enum:TDLS_CH_SW_CHNL
-TDLS_CH_SW_PREPARE	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_PREPARE,$/;"	e	enum:TDLS_option
-TDLS_CH_SW_RESP	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_RESP,$/;"	e	enum:TDLS_option
-TDLS_CH_SW_START	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_START,$/;"	e	enum:TDLS_option
-TDLS_CH_SW_STAY_ON_BASE_CHNL_TIMEOUT	include/rtw_tdls.h	54;"	d
-TDLS_CH_SW_TO_BASE_CHNL	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_TO_BASE_CHNL,$/;"	e	enum:TDLS_option
-TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED,$/;"	e	enum:TDLS_option
-TDLS_CH_SW_TO_OFF_CHNL	include/rtw_mlme_ext.h	/^	TDLS_CH_SW_TO_OFF_CHNL,$/;"	e	enum:TDLS_option
-TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE	core/rtw_debug.c	44;"	d	file:
-TDLS_DISCOVERY_REQUEST	include/ieee80211.h	/^	TDLS_DISCOVERY_REQUEST = 10,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_DISCOVERY_RESPONSE	include/ieee80211.h	/^	TDLS_DISCOVERY_RESPONSE = 14,	\/* it's used in public action frame *\/$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_ESTABLISHED	include/rtw_mlme_ext.h	/^	TDLS_ESTABLISHED = 1,$/;"	e	enum:TDLS_option
-TDLS_EXT_CAPIE	include/rtw_tdls.h	/^static u8 TDLS_EXT_CAPIE[] = {0x00, 0x00, 0x00, 0x50, 0x20, 0x00, 0x00, 0x00};	\/* bit(28), bit(30), bit(37) *\/$/;"	v
-TDLS_HANDSHAKE_TIME	include/rtw_tdls.h	51;"	d
-TDLS_INITIATOR_STATE	include/rtw_tdls.h	30;"	d
-TDLS_ISSUE_PTI	include/rtw_mlme_ext.h	/^	TDLS_ISSUE_PTI,$/;"	e	enum:TDLS_option
-TDLS_KEY	include/rtw_cmd.h	/^	TDLS_KEY		= 2,$/;"	e	enum:STAKEY_TYPE
-TDLS_LINKED_STATE	include/rtw_tdls.h	32;"	d
-TDLS_MIC_LEN	include/rtw_tdls.h	57;"	d
-TDLS_PEER_AT_OFF_STATE	include/rtw_tdls.h	40;"	d
-TDLS_PEER_PSM_REQUEST	include/ieee80211.h	/^	TDLS_PEER_PSM_REQUEST = 7,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_PEER_PSM_RESPONSE	include/ieee80211.h	/^	TDLS_PEER_PSM_RESPONSE = 8,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_PEER_TRAFFIC_INDICATION	include/ieee80211.h	/^	TDLS_PEER_TRAFFIC_INDICATION = 4,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_PEER_TRAFFIC_RESPONSE	include/ieee80211.h	/^	TDLS_PEER_TRAFFIC_RESPONSE = 9,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_PTI_TIME	include/rtw_tdls.h	52;"	d
-TDLS_PeerKey	include/sta_info.h	/^struct TDLS_PeerKey {$/;"	s
-TDLS_PeerKey_Lifetime	include/sta_info.h	/^	u32	TDLS_PeerKey_Lifetime;$/;"	m	struct:sta_info
-TDLS_RESPONDER_STATE	include/rtw_tdls.h	31;"	d
-TDLS_RSNIE	include/rtw_tdls.h	/^static u8 TDLS_RSNIE[20] = {	0x01, 0x00,	\/* Version shall be set to 1 *\/$/;"	v
-TDLS_RSNIE	include/sta_info.h	/^	u8	TDLS_RSNIE[20];	\/* Save peer's RSNIE, used for sending TDLS_SETUP_RSP *\/$/;"	m	struct:sta_info
-TDLS_RS_RCR	include/rtw_mlme_ext.h	/^	TDLS_RS_RCR,$/;"	e	enum:TDLS_option
-TDLS_SETUP_CONFIRM	include/ieee80211.h	/^	TDLS_SETUP_CONFIRM = 2,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_SETUP_REQUEST	include/ieee80211.h	/^	TDLS_SETUP_REQUEST = 0,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_SETUP_RESPONSE	include/ieee80211.h	/^	TDLS_SETUP_RESPONSE = 1,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_SIGNAL_THRESH	include/rtw_tdls.h	49;"	d
-TDLS_SRC	include/rtw_tdls.h	/^static u8 TDLS_SRC[] = { 0x01, 0x01, 0x02, 0x03, 0x04, 0x0c, 0x16, 0x17, 0x18, 0x19, 0x1b, 0x1c, 0x1d, 0x1e, 0x20, 0x21 };$/;"	v
-TDLS_STATE_NONE	include/rtw_tdls.h	29;"	d
-TDLS_TEARDOWN	include/ieee80211.h	/^	TDLS_TEARDOWN = 3,$/;"	e	enum:TDLS_ACTION_FIELD
-TDLS_TEARDOWN_STA	include/rtw_mlme_ext.h	/^	TDLS_TEARDOWN_STA,$/;"	e	enum:TDLS_option
-TDLS_TEARDOWN_STA_LOCALLY	include/rtw_mlme_ext.h	/^	TDLS_TEARDOWN_STA_LOCALLY,$/;"	e	enum:TDLS_option
-TDLS_TIMEOUT_LEN	include/rtw_tdls.h	59;"	d
-TDLS_TPK_RESEND_COUNT	include/rtw_tdls.h	45;"	d
-TDLS_WAIT_CH_RSP_STATE	include/rtw_tdls.h	42;"	d
-TDLS_WAIT_PTR_STATE	include/rtw_tdls.h	34;"	d
-TDLS_WATCHDOG_PERIOD	include/rtw_tdls.h	50;"	d
-TDLS_WMMIE	include/rtw_tdls.h	/^static u8 TDLS_WMMIE[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01, 0x00};	\/* Qos info all set zero *\/$/;"	v
-TDLS_WMM_PARAM_IE	include/rtw_tdls.h	/^static u8 TDLS_WMM_PARAM_IE[] = {0x00, 0x00, 0x03, 0xa4, 0x00, 0x00, 0x27, 0xa4, 0x00, 0x00, 0x42, 0x43, 0x5e, 0x00, 0x62, 0x32, 0x2f, 0x00};$/;"	v
-TDLS_option	include/rtw_mlme_ext.h	/^enum TDLS_option {$/;"	g
-TDLSoption_param	include/rtw_cmd.h	/^struct TDLSoption_param {$/;"	s
-TE0	include/rtw_security.h	346;"	d
-TE1	include/rtw_security.h	347;"	d
-TE2	include/rtw_security.h	348;"	d
-TE3	include/rtw_security.h	349;"	d
-TE4	include/rtw_security.h	358;"	d
-TE41	include/rtw_security.h	350;"	d
-TE414	include/rtw_security.h	357;"	d
-TE42	include/rtw_security.h	351;"	d
-TE421	include/rtw_security.h	354;"	d
-TE43	include/rtw_security.h	352;"	d
-TE432	include/rtw_security.h	355;"	d
-TE44	include/rtw_security.h	353;"	d
-TE443	include/rtw_security.h	356;"	d
-TEST_CHIP	include/HalVerDef.h	/^	TEST_CHIP		=	0,$/;"	e	enum:tag_HAL_CHIP_Type_Definition
-TEST_FALG___	hal/phydm/phydm_precomp.h	29;"	d
-TEST_FLAG	include/basic_types.h	378;"	d
-TEST_FLAGS	include/basic_types.h	382;"	d
-TEST_H2C_CID	include/rtw_cmd.h	/^	TEST_H2C_CID,$/;"	e	enum:rtw_drvextra_cmd_id
-TEST_MODE	include/rtw_mp.h	/^} TEST_MODE;$/;"	t	typeref:enum:_TEST_MODE
-TEST_NONE	include/rtw_mp.h	/^	TEST_NONE                 ,$/;"	e	enum:_TEST_MODE
-TH_EDCCA_HL_diff	hal/phydm/phydm.h	/^	s1Byte			TH_EDCCA_HL_diff;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TH_EDCCA_HL_diff_backup	hal/phydm/phydm_adaptivity.h	/^	s1Byte			TH_EDCCA_HL_diff_backup;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-TH_EDCCA_HL_diff_default	hal/phydm/phydm.h	/^	s1Byte			TH_EDCCA_HL_diff_default;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TH_EDCCA_HL_diff_mode2	hal/phydm/phydm.h	/^	s1Byte			TH_EDCCA_HL_diff_mode2;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TH_L2H_default	hal/phydm/phydm.h	/^	s1Byte			TH_L2H_default;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TH_L2H_ini	hal/phydm/phydm.h	/^	s1Byte			TH_L2H_ini;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TH_L2H_ini_backup	hal/phydm/phydm_adaptivity.h	/^	s1Byte			TH_L2H_ini_backup;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-TH_L2H_ini_mode2	hal/phydm/phydm.h	/^	s1Byte			TH_L2H_ini_mode2;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TID	include/rtw_mp.h	/^	u8 TID;$/;"	m	struct:mp_priv
-TID_NUM	include/ieee80211.h	1512;"	d
-TK16	core/rtw_security.c	484;"	d	file:
-TKIP_IV	include/rtw_xmit.h	135;"	d
-TKIP_SW_DEC_CNT_INC	core/rtw_security.c	105;"	d	file:
-TKIP_SW_DEC_CNT_INC	core/rtw_security.c	75;"	d	file:
-TKIP_SW_ENC_CNT_INC	core/rtw_security.c	104;"	d	file:
-TKIP_SW_ENC_CNT_INC	core/rtw_security.c	66;"	d	file:
-TK_SIZE	core/rtw_security.c	492;"	d	file:
-TM_Trigger	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  	TM_Trigger;$/;"	m	struct:ODM_RF_Calibration_Structure
-TM_Trigger	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  	TM_Trigger;$/;"	m	struct:ODM_RF_Calibration_Structure
-TM_Trigger	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  	TM_Trigger;$/;"	m	struct:ODM_RF_Calibration_Structure
-TOTAL	hal/phydm/phydm_rainfo.h	/^	u4Byte TOTAL;$/;"	m	struct:_ODM_RA_Info_
-TOTAL_CAM_ENTRY	include/hal_com_reg.h	823;"	d
-TOTAL_LEN_FOR_HIOE	include/rtl8723d_lps_poff.h	24;"	d
-TOTAL_MBID_CAM_NUM	include/drv_types.h	813;"	d
-TOTAL_PAGE_NUMBER_8192E	include/rtl8192e_hal.h	154;"	d
-TOTAL_PAGE_NUMBER_88E	include/rtl8188e_hal.h	156;"	d
-TOTAL_PAGE_NUMBER_88E	include/rtl8188e_hal.h	158;"	d
-TOTAL_PGNUM_8814A	include/rtl8814a_hal.h	168;"	d
-TOTAL_RSVD_PAGE_NUMBER_8192E	include/rtl8192e_hal.h	152;"	d
-TPK_count	include/sta_info.h	/^	u32	TPK_count;$/;"	m	struct:sta_info
-TPK_timer	include/sta_info.h	/^	_timer	TPK_timer;$/;"	m	struct:sta_info
-TRAFFIC_HIGH	hal/phydm/phydm.h	74;"	d
-TRAFFIC_LOW	hal/phydm/phydm.h	72;"	d
-TRAFFIC_MID	hal/phydm/phydm.h	73;"	d
-TRAFFIC_PROTECT_PERIOD_MS	core/rtw_cmd.c	2456;"	d	file:
-TRAFFIC_ULTRA_LOW	hal/phydm/phydm.h	71;"	d
-TRAINING_STATE	hal/phydm/phydm_antdiv.h	102;"	d
-TRP_BT_EN	include/hal_com_reg.h	1270;"	d
-TRP_VAUX_EN	include/hal_com_reg.h	1269;"	d
-TRUE	hal/phydm/phydm_types.h	233;"	d
-TRUE	include/HalVerDef.h	23;"	d
-TRX_SHARE_BUFF_UNIT_8814A	include/rtl8814a_hal.h	131;"	d
-TRX_SHARE_BUFF_UNIT_PAGE_8814A	include/rtl8814a_hal.h	132;"	d
-TRX_SHARE_MODE_8814A	include/rtl8814a_hal.h	129;"	d
-TRY_DONE	hal/phydm/phydm_debug.h	75;"	d
-TRxAntDivType	include/hal_data.h	/^	u8	TRxAntDivType;$/;"	m	struct:hal_com_data
-TRxMask	include/rtw_btcoex.h	/^	u8 TRxMask:1;$/;"	m	struct:btinfo_8761ATV
-TSC0	include/rtw_security.h	/^	u8 TSC0;$/;"	m	struct:pn48::__anon60
-TSC0	include/rtw_security.h	/^	u8 TSC0;$/;"	m	struct:pn48::__anon61
-TSC1	include/rtw_security.h	/^	u8 TSC1;$/;"	m	struct:pn48::__anon60
-TSC1	include/rtw_security.h	/^	u8 TSC1;$/;"	m	struct:pn48::__anon61
-TSC2	include/rtw_security.h	/^	u8 TSC2;$/;"	m	struct:pn48::__anon60
-TSC2	include/rtw_security.h	/^	u8 TSC2;$/;"	m	struct:pn48::__anon61
-TSC3	include/rtw_security.h	/^	u8 TSC3;$/;"	m	struct:pn48::__anon60
-TSC3	include/rtw_security.h	/^	u8 TSC3;$/;"	m	struct:pn48::__anon61
-TSC4	include/rtw_security.h	/^	u8 TSC4;$/;"	m	struct:pn48::__anon60
-TSC4	include/rtw_security.h	/^	u8 TSC4;$/;"	m	struct:pn48::__anon61
-TSC5	include/rtw_security.h	/^	u8 TSC5;$/;"	m	struct:pn48::__anon60
-TSC5	include/rtw_security.h	/^	u8 TSC5;$/;"	m	struct:pn48::__anon61
-TSC6	include/rtw_security.h	/^	u8 TSC6;$/;"	m	struct:pn48::__anon60
-TSC6	include/rtw_security.h	/^	u8 TSC6;$/;"	m	struct:pn48::__anon61
-TSC7	include/rtw_security.h	/^	u8 TSC7;$/;"	m	struct:pn48::__anon60
-TSC7	include/rtw_security.h	/^	u8 TSC7;$/;"	m	struct:pn48::__anon61
-TSFR	include/hal_com_reg.h	567;"	d
-TSFR1	include/hal_com_reg.h	568;"	d
-TSFRST	include/hal_com_reg.h	1533;"	d
-TSFR_8723D	hal/phydm/rtl8723d/hal8723dreg.h	444;"	d
-TSFR_8814A	include/rtl8814a_spec.h	541;"	d
-TSFValue	include/rtw_mlme_ext.h	/^	u64 TSFValue;$/;"	m	struct:mlme_ext_priv
-TSSI_MODE	hal/phydm/halphyrf_ap.h	/^	TSSI_MODE$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-TSSI_MODE	hal/phydm/halphyrf_ce.h	/^	TSSI_MODE,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-TSSI_MODE	hal/phydm/halphyrf_win.h	/^	TSSI_MODE,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-TUNNELED_PROBE_REQ	include/ieee80211.h	1602;"	d
-TUNNELED_PROBE_RSP	include/ieee80211.h	1603;"	d
-TWO_MSDU	include/wlan_bssdef.h	/^	TWO_MSDU,$/;"	e	enum:UAPSD_MAX_SP
-TXAGC	hal/phydm/halphyrf_ap.h	/^	TXAGC,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-TXAGC	hal/phydm/halphyrf_ce.h	/^	TXAGC,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-TXAGC	hal/phydm/halphyrf_win.h	/^	TXAGC,$/;"	e	enum:_PWRTRACK_CONTROL_METHOD
-TXAGG_FRAMETAG	include/rtw_xmit.h	467;"	d
-TXAntStatus	hal/phydm/phydm.h	/^	u1Byte			TXAntStatus;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TXBD_NUM	include/rtw_xmit.h	119;"	d
-TXBD_NUM_RSVD	include/rtw_xmit.h	121;"	d
-TXBFIdx	hal/phydm/txbf/halcomtxbf.h	/^	u1Byte				TXBFIdx;$/;"	m	struct:_HAL_TXBF_INFO
-TXBF_GET_EXPLICIT_BEAMFORMEE	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_GET_EXPLICIT_BEAMFORMEE,$/;"	e	enum:_TXBF_GET_TYPE
-TXBF_GET_EXPLICIT_BEAMFORMER	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_GET_EXPLICIT_BEAMFORMER,$/;"	e	enum:_TXBF_GET_TYPE
-TXBF_GET_MU_MIMO_AP	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_GET_MU_MIMO_AP$/;"	e	enum:_TXBF_GET_TYPE
-TXBF_GET_MU_MIMO_STA	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_GET_MU_MIMO_STA,$/;"	e	enum:_TXBF_GET_TYPE
-TXBF_GET_TYPE	hal/phydm/txbf/halcomtxbf.h	/^}TXBF_GET_TYPE,*PTXBF_GET_TYPE;$/;"	t	typeref:enum:_TXBF_GET_TYPE
-TXBF_SET_GET_TX_RATE	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_GET_TX_RATE$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_SOUNDING_CLK	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_SOUNDING_CLK,$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_SOUNDING_ENTER	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_SOUNDING_ENTER,$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_SOUNDING_FW_NDPA	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_SOUNDING_FW_NDPA,$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_SOUNDING_LEAVE	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_SOUNDING_LEAVE,$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_SOUNDING_RATE	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_SOUNDING_RATE,$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_SOUNDING_STATUS	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_SOUNDING_STATUS,$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_TX_PATH_RESET	hal/phydm/txbf/halcomtxbf.h	/^	TXBF_SET_TX_PATH_RESET,$/;"	e	enum:_TXBF_SET_TYPE
-TXBF_SET_TYPE	hal/phydm/txbf/halcomtxbf.h	/^}TXBF_SET_TYPE,*PTXBF_SET_TYPE;$/;"	t	typeref:enum:_TXBF_SET_TYPE
-TXCMD_QUEUE_INX	include/rtw_xmit.h	109;"	d
-TXDESC_40_BYTES	include/rtw_xmit.h	233;"	d
-TXDESC_64_BYTES	include/rtw_xmit.h	229;"	d
-TXDESC_8188E	include/rtl8188e_xmit.h	/^} TXDESC_8188E, *PTXDESC_8188E;$/;"	t	typeref:struct:txdesc_88e
-TXDESC_8192E	include/rtl8192e_xmit.h	/^} TXDESC_8192E, *PTXDESC_8192E;$/;"	t	typeref:struct:txdescriptor_8192e
-TXDESC_8812	include/rtl8812a_xmit.h	/^} TXDESC_8812, *PTXDESC_8812;$/;"	t	typeref:struct:txdescriptor_8812
-TXDESC_8814	include/rtl8814a_xmit.h	/^} TXDESC_8814, *PTXDESC_8814;$/;"	t	typeref:struct:txdescriptor_8814
-TXDESC_8821A	include/rtl8821a_xmit.h	/^} TXDESC_8821A, *PTXDESC_8821A;$/;"	t	typeref:struct:txdescriptor_8821a
-TXDESC_NUM	include/rtw_xmit.h	118;"	d
-TXDESC_NUM_BE_QUEUE	include/rtw_xmit.h	120;"	d
-TXDESC_OFFSET	include/rtl8822bu_hal.h	32;"	d
-TXDESC_OFFSET	include/rtw_xmit.h	194;"	d
-TXDESC_OFFSET	include/rtw_xmit.h	203;"	d
-TXDESC_OFFSET	include/rtw_xmit.h	211;"	d
-TXDESC_OFFSET	include/rtw_xmit.h	214;"	d
-TXDESC_SC	include/rtw_xmit.h	/^enum TXDESC_SC {$/;"	g
-TXDESC_SIZE	include/rtw_xmit.h	179;"	d
-TXDESC_SIZE	include/rtw_xmit.h	181;"	d
-TXDESC_SIZE	include/rtw_xmit.h	183;"	d
-TXDESC_SIZE	include/rtw_xmit.h	185;"	d
-TXDMA_EN	include/hal_com_reg.h	1317;"	d
-TXIQK	hal/phydm/phydm_iqk.h	29;"	d
-TXOP_limit	include/wifi.h	/^	unsigned short	TXOP_limit;$/;"	m	struct:AC_param
-TXPKT_BUF_SELECT	include/hal_com_reg.h	29;"	d
-TXPKT_PGNUM_8814A	include/rtl8814a_hal.h	169;"	d
-TXPWRTRACK_CFG	hal/phydm/halphyrf_ap.h	/^} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;$/;"	t	typeref:struct:_TXPWRTRACK_CFG
-TXPWRTRACK_CFG	hal/phydm/halphyrf_ce.h	/^} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;$/;"	t	typeref:struct:_TXPWRTRACK_CFG
-TXPWRTRACK_CFG	hal/phydm/halphyrf_win.h	/^} TXPWRTRACK_CFG, *PTXPWRTRACK_CFG;$/;"	t	typeref:struct:_TXPWRTRACK_CFG
-TXPWR_LMT_ETSI	include/hal_com_phycfg.h	/^	TXPWR_LMT_ETSI = 2,$/;"	e	enum:_REGULATION_TXPWR_LMT
-TXPWR_LMT_FCC	include/hal_com_phycfg.h	/^	TXPWR_LMT_FCC = 0,$/;"	e	enum:_REGULATION_TXPWR_LMT
-TXPWR_LMT_MAX_REGULATION_NUM	include/hal_com_phycfg.h	/^	TXPWR_LMT_MAX_REGULATION_NUM = 4$/;"	e	enum:_REGULATION_TXPWR_LMT
-TXPWR_LMT_MAX_RF	include/hal_pg.h	705;"	d
-TXPWR_LMT_MKK	include/hal_com_phycfg.h	/^	TXPWR_LMT_MKK = 1,$/;"	e	enum:_REGULATION_TXPWR_LMT
-TXPWR_LMT_WW	include/hal_com_phycfg.h	/^	TXPWR_LMT_WW = 3,$/;"	e	enum:_REGULATION_TXPWR_LMT
-TXPWR_TRACK_TABLE_SIZE	hal/phydm/phydm_powertracking_ce.h	34;"	d
-TXPWR_TRACK_TABLE_SIZE	hal/phydm/phydm_powertracking_win.h	30;"	d
-TXPowerTrackingCallbackCnt	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte 	TXPowerTrackingCallbackCnt; \/\/cosa add for debug$/;"	m	struct:ODM_RF_Calibration_Structure
-TXPowerTrackingCallbackCnt	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	TXPowerTrackingCallbackCnt; \/\/cosa add for debug$/;"	m	struct:ODM_RF_Calibration_Structure
-TXPowerTrackingCallbackCnt	hal/phydm/phydm_powertracking_win.h	/^	u4Byte 	TXPowerTrackingCallbackCnt; \/\/cosa add for debug$/;"	m	struct:ODM_RF_Calibration_Structure
-TXPowercount	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  	TXPowercount;$/;"	m	struct:ODM_RF_Calibration_Structure
-TXPowercount	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  	TXPowercount;$/;"	m	struct:ODM_RF_Calibration_Structure
-TXPowercount	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  	TXPowercount;$/;"	m	struct:ODM_RF_Calibration_Structure
-TXSCALE_TABLE_SIZE	hal/phydm/phydm_powertracking_ap.h	42;"	d
-TXSCALE_TABLE_SIZE	hal/phydm/phydm_powertracking_ce.h	31;"	d
-TXSCALE_TABLE_SIZE	hal/phydm/phydm_powertracking_win.h	28;"	d
-TX_1S	include/hal_phy.h	69;"	d
-TX_2S	include/hal_phy.h	70;"	d
-TX_3S	include/hal_phy.h	71;"	d
-TX_4S	include/hal_phy.h	72;"	d
-TX_ACTIVE_TH	core/rtw_cmd.c	2454;"	d	file:
-TX_ANTL_SHT	include/rtl8188e_xmit.h	65;"	d
-TX_ANTL_SHT	include/rtl8192e_xmit.h	170;"	d
-TX_ANTL_SHT	include/rtl8812a_xmit.h	63;"	d
-TX_ANT_CCK_SHT	include/rtl8188e_xmit.h	64;"	d
-TX_ANT_CCK_SHT	include/rtl8192e_xmit.h	169;"	d
-TX_ANT_CCK_SHT	include/rtl8812a_xmit.h	62;"	d
-TX_ANT_HT_SHT	include/rtl8188e_xmit.h	66;"	d
-TX_ANT_HT_SHT	include/rtl8192e_xmit.h	171;"	d
-TX_ANT_HT_SHT	include/rtl8812a_xmit.h	64;"	d
-TX_BD_NUM	include/rtw_xmit.h	115;"	d
-TX_BUFFER_SEG_NUM	include/rtw_xmit.h	167;"	d
-TX_BUFFER_SEG_NUM	include/rtw_xmit.h	169;"	d
-TX_BUFFER_SEG_NUM	include/rtw_xmit.h	171;"	d
-TX_BUFFER_SEG_SIZE	include/rtw_xmit.h	239;"	d
-TX_BY_DESC	hal/phydm/phydm_antdiv.h	83;"	d
-TX_BY_REG	hal/phydm/phydm_antdiv.h	84;"	d
-TX_DESC_NEXT_DESC_OFFSET	include/rtw_xmit.h	216;"	d
-TX_DESC_NUM_8188EE	include/rtl8188e_hal.h	239;"	d
-TX_DESC_NUM_8814A	include/rtl8814a_hal.h	204;"	d
-TX_DESC_NUM_8814A	include/rtl8814a_hal.h	213;"	d
-TX_DESC_NUM_92E	include/rtl8192e_hal.h	187;"	d
-TX_DMA_SIZE_8703B	include/rtl8703b_hal.h	94;"	d
-TX_DMA_SIZE_8723B	include/rtl8723b_hal.h	94;"	d
-TX_DMA_SIZE_8723D	include/rtl8723d_hal.h	98;"	d
-TX_EPQ_BASE	include/hal_com_reg.h	1608;"	d
-TX_HIQ_BASE	include/hal_com_reg.h	1605;"	d
-TX_HIQ_DOMAIN	include/gspi_ops.h	31;"	d
-TX_HIQ_OFFSET	include/gspi_ops.h	41;"	d
-TX_IQK	hal/phydm/phydm_iqk.h	27;"	d
-TX_LOQ_BASE	include/hal_com_reg.h	1607;"	d
-TX_LOQ_DOMAIN	include/gspi_ops.h	33;"	d
-TX_LOQ_OFFSET	include/gspi_ops.h	43;"	d
-TX_MIQ_BASE	include/hal_com_reg.h	1606;"	d
-TX_MIQ_DOMAIN	include/gspi_ops.h	32;"	d
-TX_MIQ_OFFSET	include/gspi_ops.h	42;"	d
-TX_PAGE_BOUNDARY_8188F	include/rtl8188f_hal.h	143;"	d
-TX_PAGE_BOUNDARY_8192E	include/rtl8192e_hal.h	157;"	d
-TX_PAGE_BOUNDARY_8703B	include/rtl8703b_hal.h	145;"	d
-TX_PAGE_BOUNDARY_8723B	include/rtl8723b_hal.h	145;"	d
-TX_PAGE_BOUNDARY_8723D	include/rtl8723d_hal.h	151;"	d
-TX_PAGE_BOUNDARY_8812	include/rtl8812a_hal.h	161;"	d
-TX_PAGE_BOUNDARY_8814A	include/rtl8814a_hal.h	158;"	d
-TX_PAGE_BOUNDARY_8821	include/rtl8812a_hal.h	209;"	d
-TX_PAGE_BOUNDARY_88E	include/rtl8188e_hal.h	161;"	d
-TX_PAGE_BOUNDARY_WOWLAN_8192E	include/rtl8192e_hal.h	164;"	d
-TX_PAGE_BOUNDARY_WOWLAN_8812	include/rtl8812a_hal.h	163;"	d
-TX_PAGE_BOUNDARY_WOWLAN_8814A	include/rtl8814a_hal.h	159;"	d
-TX_PAGE_LOAD_FW_BOUNDARY_8192E	include/rtl8192e_hal.h	163;"	d
-TX_POWER_NEAR_FIELD_THRESH_AP	hal/phydm/phydm_dynamictxpower.h	31;"	d
-TX_POWER_NEAR_FIELD_THRESH_LVL1	hal/phydm/phydm_dynamictxpower.h	30;"	d
-TX_POWER_NEAR_FIELD_THRESH_LVL1	hal/phydm/phydm_dynamictxpower.h	34;"	d
-TX_POWER_NEAR_FIELD_THRESH_LVL1	hal/phydm/phydm_dynamictxpower.h	37;"	d
-TX_POWER_NEAR_FIELD_THRESH_LVL2	hal/phydm/phydm_dynamictxpower.h	29;"	d
-TX_POWER_NEAR_FIELD_THRESH_LVL2	hal/phydm/phydm_dynamictxpower.h	33;"	d
-TX_POWER_NEAR_FIELD_THRESH_LVL2	hal/phydm/phydm_dynamictxpower.h	36;"	d
-TX_PWR_BY_RATE_NUM_BAND	include/hal_pg.h	701;"	d
-TX_PWR_BY_RATE_NUM_RATE	include/hal_pg.h	703;"	d
-TX_PWR_BY_RATE_NUM_RF	include/hal_pg.h	702;"	d
-TX_PWR_LMT_REF_HT_FROM_VHT	include/hal_com_phycfg.h	49;"	d
-TX_PWR_LMT_REF_VHT_FROM_HT	include/hal_com_phycfg.h	48;"	d
-TX_RATE	include/rtw_mp.h	/^	u8			TX_RATE;			\/* MPT_RATE_E *\/$/;"	m	struct:_RT_PMAC_TX_INFO
-TX_RATE_HEX	include/rtw_mp.h	/^	u8			TX_RATE_HEX;$/;"	m	struct:_RT_PMAC_TX_INFO
-TX_REPORT1	include/rtw_recv.h	/^	TX_REPORT1,\/* CCX *\/$/;"	e	enum:_RX_PACKET_TYPE
-TX_REPORT2	include/rtw_recv.h	/^	TX_REPORT2,\/* TX RPT *\/$/;"	e	enum:_RX_PACKET_TYPE
-TX_RPT1_PKT_LEN	include/rtl8188e_recv.h	66;"	d
-TX_SC	include/rtw_mp.h	/^	u8			TX_SC;$/;"	m	struct:_RT_PMAC_TX_INFO
-TX_SELE_EQ	include/hal_com.h	257;"	d
-TX_SELE_HQ	include/hal_com.h	254;"	d
-TX_SELE_LQ	include/hal_com.h	255;"	d
-TX_SELE_NQ	include/hal_com.h	256;"	d
-TX_TOTAL_PAGE_NUMBER_8188F	include/rtl8188f_hal.h	142;"	d
-TX_TOTAL_PAGE_NUMBER_8192E	include/rtl8192e_hal.h	155;"	d
-TX_TOTAL_PAGE_NUMBER_8703B	include/rtl8703b_hal.h	144;"	d
-TX_TOTAL_PAGE_NUMBER_8723B	include/rtl8723b_hal.h	144;"	d
-TX_TOTAL_PAGE_NUMBER_8723D	include/rtl8723d_hal.h	149;"	d
-TX_TOTAL_PAGE_NUMBER_8812	include/rtl8812a_hal.h	160;"	d
-TX_TOTAL_PAGE_NUMBER_8821	include/rtl8812a_hal.h	208;"	d
-TX_TOTAL_PAGE_NUMBER_88E	include/rtl8188e_hal.h	160;"	d
-TX_WIFI_INFO_SIZE	include/rtw_xmit.h	209;"	d
-TX_X	include/rtw_mcc.h	/^	u16 TX_X;$/;"	m	struct:mcc_iqk_backup
-TX_Y	include/rtw_mcc.h	/^	u16 TX_Y;$/;"	m	struct:mcc_iqk_backup
-TXradomBuffer	include/rtw_mp.h	/^	u8		*TXradomBuffer;$/;"	m	struct:mp_priv
-TYPE_ALNA0	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA0 = 0x0000,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA1	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA1 = 0x0055,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA10	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA10 = 0xAAAA,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA11	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA11 = 0xAAFF,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA12	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA12 = 0xFF00,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA13	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA13 = 0xFF55,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA14	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA14 = 0xFFAA,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA15	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA15 = 0xFFFF,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA2	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA2 = 0x00AA,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA3	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA3 = 0x00FF,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA4	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA4 = 0x5500,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA5	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA5 = 0x5555,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA6	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA6 = 0x55AA,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA7	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA7 = 0x55FF,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA8	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA8 = 0xAA00,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_ALNA9	hal/phydm/phydm_pre_define.h	/^	TYPE_ALNA9 = 0xAA55,$/;"	e	enum:tag_ODM_TYPE_ALNA_Definition
-TYPE_APA0	hal/phydm/phydm_pre_define.h	/^	TYPE_APA0 = 0x0000,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA1	hal/phydm/phydm_pre_define.h	/^	TYPE_APA1 = 0x0055,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA10	hal/phydm/phydm_pre_define.h	/^	TYPE_APA10 = 0xAAAA,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA11	hal/phydm/phydm_pre_define.h	/^	TYPE_APA11 = 0xAAFF,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA12	hal/phydm/phydm_pre_define.h	/^	TYPE_APA12 = 0xFF00,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA13	hal/phydm/phydm_pre_define.h	/^	TYPE_APA13 = 0xFF55,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA14	hal/phydm/phydm_pre_define.h	/^	TYPE_APA14 = 0xFFAA,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA15	hal/phydm/phydm_pre_define.h	/^	TYPE_APA15 = 0xFFFF,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA2	hal/phydm/phydm_pre_define.h	/^	TYPE_APA2 = 0x00AA,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA3	hal/phydm/phydm_pre_define.h	/^	TYPE_APA3 = 0x00FF,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA4	hal/phydm/phydm_pre_define.h	/^	TYPE_APA4 = 0x5500,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA5	hal/phydm/phydm_pre_define.h	/^	TYPE_APA5 = 0x5555,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA6	hal/phydm/phydm_pre_define.h	/^	TYPE_APA6 = 0x55AA,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA7	hal/phydm/phydm_pre_define.h	/^	TYPE_APA7 = 0x55FF,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA8	hal/phydm/phydm_pre_define.h	/^	TYPE_APA8 = 0xAA00,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_APA9	hal/phydm/phydm_pre_define.h	/^	TYPE_APA9 = 0xAA55,$/;"	e	enum:tag_ODM_TYPE_APA_Definition
-TYPE_AVAILABLE_EFUSE_BYTES_BANK	include/rtw_efuse.h	/^	TYPE_AVAILABLE_EFUSE_BYTES_BANK		= 2,$/;"	e	enum:_EFUSE_DEF_TYPE
-TYPE_AVAILABLE_EFUSE_BYTES_TOTAL	include/rtw_efuse.h	/^	TYPE_AVAILABLE_EFUSE_BYTES_TOTAL	= 3,$/;"	e	enum:_EFUSE_DEF_TYPE
-TYPE_EFUSE_CONTENT_LEN_BANK	include/rtw_efuse.h	/^	TYPE_EFUSE_CONTENT_LEN_BANK			= 6,$/;"	e	enum:_EFUSE_DEF_TYPE
-TYPE_EFUSE_MAP_LEN	include/rtw_efuse.h	/^	TYPE_EFUSE_MAP_LEN					= 4,$/;"	e	enum:_EFUSE_DEF_TYPE
-TYPE_EFUSE_MAX_SECTION	include/rtw_efuse.h	/^	TYPE_EFUSE_MAX_SECTION				= 0,$/;"	e	enum:_EFUSE_DEF_TYPE
-TYPE_EFUSE_PROTECT_BYTES_BANK	include/rtw_efuse.h	/^	TYPE_EFUSE_PROTECT_BYTES_BANK		= 5,$/;"	e	enum:_EFUSE_DEF_TYPE
-TYPE_EFUSE_REAL_CONTENT_LEN	include/rtw_efuse.h	/^	TYPE_EFUSE_REAL_CONTENT_LEN			= 1,$/;"	e	enum:_EFUSE_DEF_TYPE
-TYPE_GLNA0	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA0 = 0x0000,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA1	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA1 = 0x0055,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA10	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA10 = 0xAAAA,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA11	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA11 = 0xAAFF,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA12	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA12 = 0xFF00,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA13	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA13 = 0xFF55,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA14	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA14 = 0xFFAA,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA15	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA15 = 0xFFFF,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA2	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA2 = 0x00AA,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA3	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA3 = 0x00FF,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA4	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA4 = 0x5500,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA5	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA5 = 0x5555,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA6	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA6 = 0x55AA,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA7	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA7 = 0x55FF,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA8	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA8 = 0xAA00,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GLNA9	hal/phydm/phydm_pre_define.h	/^	TYPE_GLNA9 = 0xAA55,$/;"	e	enum:tag_ODM_TYPE_GLNA_Definition
-TYPE_GPA0	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA0 = 0x0000,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA1	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA1 = 0x0055,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA10	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA10 = 0xAAAA,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA11	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA11 = 0xAAFF,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA12	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA12 = 0xFF00,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA13	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA13 = 0xFF55,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA14	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA14 = 0xFFAA,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA15	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA15 = 0xFFFF,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA2	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA2 = 0x00AA,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA3	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA3 = 0x00FF,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA4	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA4 = 0x5500,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA5	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA5 = 0x5555,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA6	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA6 = 0x55AA,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA7	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA7 = 0x55FF,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA8	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA8 = 0xAA00,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_GPA9	hal/phydm/phydm_pre_define.h	/^	TYPE_GPA9 = 0xAA55,$/;"	e	enum:tag_ODM_TYPE_GPA_Definition
-TYPE_ID	include/hal_com_reg.h	1273;"	d
-TYPE_LENGTH_FIELD_SIZE	include/ethernet.h	27;"	d
-TargetAnt_CRC32	hal/phydm/phydm_antdiv.h	/^	u1Byte	TargetAnt_CRC32;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-TargetAnt_EVM	hal/phydm/phydm_antdiv.h	/^	u1Byte	TargetAnt_EVM;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-TargetAnt_enhance	hal/phydm/phydm_antdiv.h	/^	u1Byte	TargetAnt_enhance;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-Td0	core/rtw_security.c	/^const u32 Td0[256] = {$/;"	v
-Td4s	core/rtw_security.c	/^const u8 Td4s[256] = {$/;"	v
-Te0	core/rtw_security.c	/^const u32 Te0[256] = {$/;"	v
-ThermalMeter	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  	ThermalMeter[2];    \/\/ ThermalMeter, index 0 for RFIC0, and 1 for RFIC1$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalMeter	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  	ThermalMeter[2];    \/\/ ThermalMeter, index 0 for RFIC0, and 1 for RFIC1$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalMeter	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  	ThermalMeter[2];    \/\/ ThermalMeter, index 0 for RFIC0, and 1 for RFIC1$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalRegAddr	hal/phydm/halphyrf_ap.h	/^	u4Byte 		ThermalRegAddr;	$/;"	m	struct:_TXPWRTRACK_CFG
-ThermalRegAddr	hal/phydm/halphyrf_ce.h	/^	u4Byte 		ThermalRegAddr;	$/;"	m	struct:_TXPWRTRACK_CFG
-ThermalRegAddr	hal/phydm/halphyrf_win.h	/^	u4Byte 		ThermalRegAddr;	$/;"	m	struct:_TXPWRTRACK_CFG
-ThermalValue	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  	ThermalValue;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  	ThermalValue;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  	ThermalValue;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_AVG	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	ThermalValue_AVG[AVG_THERMAL_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_AVG	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	ThermalValue_AVG[AVG_THERMAL_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_AVG	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	ThermalValue_AVG[AVG_THERMAL_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_AVG_index	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	ThermalValue_AVG_index;		$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_AVG_index	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	ThermalValue_AVG_index;		$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_AVG_index	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	ThermalValue_AVG_index;		$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_Crystal	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	ThermalValue_Crystal;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_Crystal	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	ThermalValue_Crystal;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_DPK	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	ThermalValue_DPK;		$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_DPK	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	ThermalValue_DPK;		$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_DPKstore	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	ThermalValue_DPKstore;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_DPKstore	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	ThermalValue_DPKstore;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_DPKtrack	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	ThermalValue_DPKtrack;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_DPKtrack	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	ThermalValue_DPKtrack;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_HP	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	ThermalValue_HP[HP_THERMAL_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_HP	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	ThermalValue_HP[HP_THERMAL_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_HP	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	ThermalValue_HP[HP_THERMAL_NUM];$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_HP_index	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	ThermalValue_HP_index;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_HP_index	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	ThermalValue_HP_index;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_HP_index	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	ThermalValue_HP_index;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_IQK	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  	ThermalValue_IQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_IQK	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  	ThermalValue_IQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_IQK	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  	ThermalValue_IQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_LCK	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  	ThermalValue_LCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_LCK	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  	ThermalValue_LCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_LCK	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  	ThermalValue_LCK;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_RxGain	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	ThermalValue_RxGain;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_RxGain	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	ThermalValue_RxGain;$/;"	m	struct:ODM_RF_Calibration_Structure
-ThermalValue_RxGain	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	ThermalValue_RxGain;$/;"	m	struct:ODM_RF_Calibration_Structure
-Threshold_DPK	hal/phydm/halphyrf_ap.h	/^	u1Byte 		Threshold_DPK;	$/;"	m	struct:_TXPWRTRACK_CFG
-Threshold_DPK	hal/phydm/halphyrf_ce.h	/^	u1Byte		Threshold_DPK;$/;"	m	struct:_TXPWRTRACK_CFG
-Threshold_DPK	hal/phydm/halphyrf_win.h	/^	u1Byte		Threshold_DPK;$/;"	m	struct:_TXPWRTRACK_CFG
-Threshold_IQK	hal/phydm/halphyrf_ap.h	/^	u1Byte 		Threshold_IQK;$/;"	m	struct:_TXPWRTRACK_CFG
-Threshold_IQK	hal/phydm/halphyrf_ce.h	/^	u1Byte		Threshold_IQK;$/;"	m	struct:_TXPWRTRACK_CFG
-Threshold_IQK	hal/phydm/halphyrf_win.h	/^	u1Byte		Threshold_IQK;$/;"	m	struct:_TXPWRTRACK_CFG
-Times_2G	hal/phydm/phydm.h	/^	u1Byte			Times_2G;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-Timestamp	include/wlan_bssdef.h	/^	UCHAR  Timestamp[8];$/;"	m	struct:_NDIS_802_11_FIXED_IEs
-TopDIR	Makefile	/^export TopDIR ?= $(shell pwd)$/;"	m
-TotalAvailBytes_BT	include/rtw_efuse.h	/^	const u16  TotalAvailBytes_BT;$/;"	m	struct:_EFUSE_HAL
-TotalAvailBytes_WiFi	include/rtw_efuse.h	/^	const u16  TotalAvailBytes_WiFi;$/;"	m	struct:_EFUSE_HAL
-TotalBankNum	include/rtw_efuse.h	/^	const u16  TotalBankNum;$/;"	m	struct:_EFUSE_HAL
-TpTrainTH_min	hal/phydm/phydm_dig.h	/^	u4Byte					TpTrainTH_min;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-TrafficLoad	hal/phydm/phydm.h	/^	u1Byte			TrafficLoad;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TrafficProfile	include/rtw_btcoex.h	/^	u1Byte					TrafficProfile;$/;"	m	struct:_HCI_LINK_INFO
-TrafficTransitionCount	include/rtw_mlme.h	/^	u8 TrafficTransitionCount;$/;"	m	struct:_RT_LINK_DETECT_T
-TrainIdx	hal/phydm/phydm_antdiv.h	/^	u4Byte	TrainIdx;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-Train_time	hal/phydm/phydm_antdiv.h	/^	u1Byte		Train_time;$/;"	m	struct:_SW_Antenna_Switch_
-Train_time_flag	hal/phydm/phydm_antdiv.h	/^	u1Byte		Train_time_flag; \/*base on RSSI difference between two antennas*\/$/;"	m	struct:_SW_Antenna_Switch_
-TransceiverA_HSPI_Readback	include/Hal8188EPhyReg.h	119;"	d
-TransceiverA_HSPI_Readback	include/Hal8188FPhyReg.h	135;"	d
-TransceiverA_HSPI_Readback	include/Hal8192EPhyReg.h	126;"	d
-TransceiverA_HSPI_Readback	include/Hal8703BPhyReg.h	130;"	d
-TransceiverA_HSPI_Readback	include/Hal8723BPhyReg.h	130;"	d
-TransceiverA_HSPI_Readback	include/Hal8723DPhyReg.h	130;"	d
-TransceiverA_HSPI_Readback	include/Hal8814PhyReg.h	544;"	d
-TransceiverB_HSPI_Readback	include/Hal8188EPhyReg.h	120;"	d
-TransceiverB_HSPI_Readback	include/Hal8188FPhyReg.h	136;"	d
-TransceiverB_HSPI_Readback	include/Hal8192EPhyReg.h	127;"	d
-TransceiverB_HSPI_Readback	include/Hal8703BPhyReg.h	131;"	d
-TransceiverB_HSPI_Readback	include/Hal8723BPhyReg.h	131;"	d
-TransceiverB_HSPI_Readback	include/Hal8723DPhyReg.h	131;"	d
-TransceiverB_HSPI_Readback	include/Hal8814PhyReg.h	545;"	d
-TransmitConfig	include/hal_data.h	/^	u32			TransmitConfig;$/;"	m	struct:hal_com_data
-TriggerRFThermalMeter	core/rtw_mp.c	/^static void TriggerRFThermalMeter(PADAPTER pAdapter)$/;"	f	file:
-TxBBSwing_2G	include/drv_types.h	/^	s8	TxBBSwing_2G;$/;"	m	struct:registry_priv
-TxBBSwing_5G	include/drv_types.h	/^	s8	TxBBSwing_5G;$/;"	m	struct:registry_priv
-TxBF_Nr	hal/phydm/txbf/phydm_hal_txbf_api.h	25;"	d
-TxBfDataRate	hal/phydm/phydm.h	/^	u1Byte			TxBfDataRate;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TxHighPwrLevel_100	hal/phydm/phydm_dynamictxpower.h	50;"	d
-TxHighPwrLevel_15	hal/phydm/phydm_dynamictxpower.h	46;"	d
-TxHighPwrLevel_35	hal/phydm/phydm_dynamictxpower.h	47;"	d
-TxHighPwrLevel_50	hal/phydm/phydm_dynamictxpower.h	48;"	d
-TxHighPwrLevel_70	hal/phydm/phydm_dynamictxpower.h	49;"	d
-TxHighPwrLevel_BT1	hal/phydm/phydm_dynamictxpower.h	44;"	d
-TxHighPwrLevel_BT2	hal/phydm/phydm_dynamictxpower.h	45;"	d
-TxHighPwrLevel_Level1	hal/phydm/phydm_dynamictxpower.h	41;"	d
-TxHighPwrLevel_Level2	hal/phydm/phydm_dynamictxpower.h	42;"	d
-TxHighPwrLevel_Normal	hal/phydm/phydm_dynamictxpower.h	40;"	d
-TxIQC_8703B	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	TxIQC_8703B[3][2];	\/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-TxIQC_8703B	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	TxIQC_8703B[3][2];	\/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-TxIQC_8703B	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	TxIQC_8703B[3][2];	\/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-TxIQC_8723B	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	TxIQC_8723B[2][3][2]; \/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-TxIQC_8723B	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte 	TxIQC_8723B[2][3][2]; \/\/ { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}$/;"	m	struct:ODM_RF_Calibration_Structure
-TxIQC_8723B	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	TxIQC_8723B[2][3][2]; \/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-TxIQC_8723D	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	TxIQC_8723D[2][3][2];	\/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-TxIQC_8723D	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	TxIQC_8723D[2][3][2];	\/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*\/$/;"	m	struct:ODM_RF_Calibration_Structure
-TxLOK	hal/phydm/phydm_powertracking_ap.h	/^	u4Byte	TxLOK[2];$/;"	m	struct:ODM_RF_Calibration_Structure
-TxLOK	hal/phydm/phydm_powertracking_ce.h	/^	u4Byte	TxLOK[2];$/;"	m	struct:ODM_RF_Calibration_Structure
-TxLOK	hal/phydm/phydm_powertracking_win.h	/^	u4Byte	TxLOK[2];$/;"	m	struct:ODM_RF_Calibration_Structure
-TxPower	include/rtw_cmd.h	/^	u8 TxPower;$/;"	m	struct:SetTxPower_parm
-TxPowerHigh	include/rtw_btcoex.h	/^	u8 TxPowerHigh:1;$/;"	m	struct:btinfo_8761ATV
-TxPowerInfo24G	include/hal_pg.h	/^} TxPowerInfo24G, *PTxPowerInfo24G;$/;"	t	typeref:struct:_TxPowerInfo24G
-TxPowerInfo5G	include/hal_pg.h	/^} TxPowerInfo5G, *PTxPowerInfo5G;$/;"	t	typeref:struct:_TxPowerInfo5G
-TxPowerLow	include/rtw_btcoex.h	/^	u8 TxPowerLow:1;$/;"	m	struct:btinfo_8761ATV
-TxPowerTrackControl	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte  	TxPowerTrackControl; \/\/for mp mode, turn off txpwrtracking as default$/;"	m	struct:ODM_RF_Calibration_Structure
-TxPowerTrackControl	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte  	TxPowerTrackControl; \/\/for mp mode, turn off txpwrtracking as default$/;"	m	struct:ODM_RF_Calibration_Structure
-TxPowerTrackControl	hal/phydm/phydm_powertracking_win.h	/^	u1Byte  	TxPowerTrackControl; \/\/for mp mode, turn off txpwrtracking as default$/;"	m	struct:ODM_RF_Calibration_Structure
-TxPowerTrackingInProgress	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	TxPowerTrackingInProgress;$/;"	m	struct:ODM_RF_Calibration_Structure
-TxPowerTrackingInProgress	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN	TxPowerTrackingInProgress;$/;"	m	struct:ODM_RF_Calibration_Structure
-TxPwrByRate	include/hal_data.h	/^	s8	TxPwrByRate[TX_PWR_BY_RATE_NUM_BAND]$/;"	m	struct:hal_com_data
-TxPwrByRateBase2_4G	include/hal_data.h	/^	u8	TxPwrByRateBase2_4G[TX_PWR_BY_RATE_NUM_RF]$/;"	m	struct:hal_com_data
-TxPwrByRateBase5G	include/hal_data.h	/^	u8	TxPwrByRateBase5G[TX_PWR_BY_RATE_NUM_RF]$/;"	m	struct:hal_com_data
-TxPwrByRateOffset	include/hal_data.h	/^	s8	TxPwrByRateOffset[TX_PWR_BY_RATE_NUM_BAND]$/;"	m	struct:hal_com_data
-TxPwrLevel	include/rtw_mp.h	/^	u8			TxPwrLevel[4];	\/* rf-A, rf-B*\/$/;"	m	struct:_MPT_CONTEXT
-TxPwrLimit_2_4G	include/hal_data.h	/^	s8	TxPwrLimit_2_4G[MAX_REGULATION_NUM]$/;"	m	struct:hal_com_data
-TxPwrLimit_2_4G_Original	include/hal_data.h	/^	s8	TxPwrLimit_2_4G_Original[MAX_REGULATION_NUM]$/;"	m	struct:hal_com_data
-TxPwrLimit_5G	include/hal_data.h	/^	s8	TxPwrLimit_5G[MAX_REGULATION_NUM]$/;"	m	struct:hal_com_data
-TxPwrLimit_5G_Original	include/hal_data.h	/^	s8	TxPwrLimit_5G_Original[MAX_REGULATION_NUM]$/;"	m	struct:hal_com_data
-TxPwrTrk_OFDM_SwingTbl	hal/phydm/phydm_powertracking_ap.c	/^unsigned int TxPwrTrk_OFDM_SwingTbl[TxPwrTrk_OFDM_SwingTbl_Len] = {$/;"	v
-TxPwrTrk_OFDM_SwingTbl	hal/phydm/phydm_powertracking_ce.c	/^unsigned int TxPwrTrk_OFDM_SwingTbl[TxPwrTrk_OFDM_SwingTbl_Len] = {$/;"	v
-TxPwrTrk_OFDM_SwingTbl	hal/phydm/phydm_powertracking_win.c	/^unsigned int TxPwrTrk_OFDM_SwingTbl[TxPwrTrk_OFDM_SwingTbl_Len] = {$/;"	v
-TxRate	hal/phydm/phydm.h	/^	u1Byte			TxRate;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TxScalingTable_Jaguar	hal/phydm/phydm_powertracking_ap.c	/^u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE] =$/;"	v
-TxScalingTable_Jaguar	hal/phydm/phydm_powertracking_ce.c	/^u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE] =$/;"	v
-TxScalingTable_Jaguar	hal/phydm/phydm_powertracking_win.c	/^u4Byte TxScalingTable_Jaguar[TXSCALE_TABLE_SIZE] =$/;"	v
-Tx_Beacon_param	include/rtw_cmd.h	/^struct Tx_Beacon_param {$/;"	s
-TxagcOffsetValueA	hal/phydm/phydm.h	/^	u4Byte			TxagcOffsetValueA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TxagcOffsetValueB	hal/phydm/phydm.h	/^	u4Byte			TxagcOffsetValueB;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TxbfInfo	hal/phydm/phydm_beamforming.h	/^	HAL_TXBF_INFO			TxbfInfo;$/;"	m	struct:_RT_BEAMFORMING_INFO
-Txbf_ClkWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_ClkWorkItem;$/;"	m	struct:_HAL_TXBF_INFO
-Txbf_EnterWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_EnterWorkItem;  $/;"	m	struct:_HAL_TXBF_INFO
-Txbf_FwNdpaTimer	hal/phydm/txbf/halcomtxbf.h	/^	RT_TIMER			Txbf_FwNdpaTimer;$/;"	m	struct:_HAL_TXBF_INFO
-Txbf_FwNdpaWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_FwNdpaWorkItem;$/;"	m	struct:_HAL_TXBF_INFO
-Txbf_GetTxRateWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_GetTxRateWorkItem;$/;"	m	struct:_HAL_TXBF_INFO
-Txbf_LeaveWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_LeaveWorkItem;$/;"	m	struct:_HAL_TXBF_INFO
-Txbf_RateWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_RateWorkItem;$/;"	m	struct:_HAL_TXBF_INFO
-Txbf_ResetTxPathWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_ResetTxPathWorkItem;$/;"	m	struct:_HAL_TXBF_INFO
-Txbf_StatusWorkItem	hal/phydm/txbf/halcomtxbf.h	/^	RT_WORK_ITEM		Txbf_StatusWorkItem;$/;"	m	struct:_HAL_TXBF_INFO
-Type	hal/phydm/phydm_rainfo.h	/^	u1Byte				Type;				\/\/ DM_Type_ByFW\/DM_Type_ByDriver$/;"	m	struct:_ODM_RATE_ADAPTIVE
-Type	include/drv_types_ce.h	/^	u8			Type;		\/* NdisParameterInteger\/NdisParameterHexInteger\/NdisParameterStringle\/NdisParameterMultiString *\/$/;"	m	struct:_MP_REG_ENTRY
-Type	include/drv_types_xp.h	/^	u8			Type;		\/* NdisParameterInteger\/NdisParameterHexInteger\/NdisParameterStringle\/NdisParameterMultiString *\/$/;"	m	struct:_MP_REG_ENTRY
-Type	include/wlan_bssdef.h	/^	ULONG Type;$/;"	m	struct:_NDIS_802_11_TEST
-TypeALNA	hal/phydm/phydm.h	/^	u2Byte			TypeALNA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TypeALNA	include/hal_data.h	/^	u16	TypeALNA;$/;"	m	struct:hal_com_data
-TypeAPA	hal/phydm/phydm.h	/^	u2Byte			TypeAPA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TypeAPA	include/hal_data.h	/^	u16	TypeAPA;$/;"	m	struct:hal_com_data
-TypeGLNA	hal/phydm/phydm.h	/^	u2Byte			TypeGLNA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TypeGLNA	include/hal_data.h	/^	u16	TypeGLNA;$/;"	m	struct:hal_com_data
-TypeGPA	hal/phydm/phydm.h	/^	u2Byte			TypeGPA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-TypeGPA	include/hal_data.h	/^	u16	TypeGPA;$/;"	m	struct:hal_com_data
-U1DONTCARE	include/drv_types_pci.h	47;"	d
-U2DONTCARE	include/drv_types_pci.h	48;"	d
-U4DONTCARE	include/drv_types_pci.h	49;"	d
-UAPSD_MAX_SP	include/wlan_bssdef.h	/^enum UAPSD_MAX_SP {$/;"	g
-UCHAR	include/basic_types.h	144;"	d
-UCHAR	include/basic_types.h	98;"	d
-UCHAR	include/rtw_mp.h	133;"	d
-UCLK_VLD	include/hal_com_reg.h	1255;"	d
-UC_DATA_EN	include/hal_com_reg.h	1559;"	d
-UHIMR_ATIMEND	include/hal_com_reg.h	993;"	d
-UHIMR_ATIMEND_E	include/hal_com_reg.h	992;"	d
-UHIMR_BCNDMAINT0	include/hal_com_reg.h	960;"	d
-UHIMR_BCNDMAINT1	include/hal_com_reg.h	959;"	d
-UHIMR_BCNDMAINT2	include/hal_com_reg.h	958;"	d
-UHIMR_BCNDMAINT3	include/hal_com_reg.h	957;"	d
-UHIMR_BCNDMAINT4	include/hal_com_reg.h	986;"	d
-UHIMR_BCNDMAINT5	include/hal_com_reg.h	985;"	d
-UHIMR_BCNDMAINT6	include/hal_com_reg.h	984;"	d
-UHIMR_BCNDMAINT7	include/hal_com_reg.h	983;"	d
-UHIMR_BCNDMAINT_E	include/hal_com_reg.h	966;"	d
-UHIMR_BCNDOK0	include/hal_com_reg.h	964;"	d
-UHIMR_BCNDOK1	include/hal_com_reg.h	963;"	d
-UHIMR_BCNDOK2	include/hal_com_reg.h	962;"	d
-UHIMR_BCNDOK3	include/hal_com_reg.h	961;"	d
-UHIMR_BCNDOK4	include/hal_com_reg.h	990;"	d
-UHIMR_BCNDOK5	include/hal_com_reg.h	989;"	d
-UHIMR_BCNDOK6	include/hal_com_reg.h	988;"	d
-UHIMR_BCNDOK7	include/hal_com_reg.h	987;"	d
-UHIMR_BEDOK	include/hal_com_reg.h	976;"	d
-UHIMR_BKDOK	include/hal_com_reg.h	975;"	d
-UHIMR_C2HCMD	include/hal_com_reg.h	970;"	d
-UHIMR_CPWM	include/hal_com_reg.h	972;"	d
-UHIMR_CPWM2	include/hal_com_reg.h	971;"	d
-UHIMR_CTW_END	include/hal_com_reg.h	968;"	d
-UHIMR_GTINT3	include/hal_com_reg.h	953;"	d
-UHIMR_GTINT4	include/hal_com_reg.h	952;"	d
-UHIMR_HIGHDOK	include/hal_com_reg.h	973;"	d
-UHIMR_HSISR_IND	include/hal_com_reg.h	965;"	d
-UHIMR_MGNTDOK	include/hal_com_reg.h	974;"	d
-UHIMR_OCPINT	include/hal_com_reg.h	999;"	d
-UHIMR_PSTIMEOUT	include/hal_com_reg.h	951;"	d
-UHIMR_RDU	include/hal_com_reg.h	979;"	d
-UHIMR_ROK	include/hal_com_reg.h	980;"	d
-UHIMR_RXERR	include/hal_com_reg.h	995;"	d
-UHIMR_RXFOVW	include/hal_com_reg.h	997;"	d
-UHIMR_TIMEOUT1	include/hal_com_reg.h	950;"	d
-UHIMR_TIMEOUT2	include/hal_com_reg.h	949;"	d
-UHIMR_TSF_BIT32_TOGGLE	include/hal_com_reg.h	956;"	d
-UHIMR_TXBCNERR	include/hal_com_reg.h	954;"	d
-UHIMR_TXBCNOK	include/hal_com_reg.h	955;"	d
-UHIMR_TXERR	include/hal_com_reg.h	994;"	d
-UHIMR_TXFOVW	include/hal_com_reg.h	996;"	d
-UHIMR_VIDOK	include/hal_com_reg.h	977;"	d
-UHIMR_VODOK	include/hal_com_reg.h	978;"	d
-UINT	include/basic_types.h	100;"	d
-UINT	include/basic_types.h	146;"	d
-UINT	include/rtw_mp.h	135;"	d
-ULONG	include/basic_types.h	101;"	d
-ULONG	include/basic_types.h	147;"	d
-ULONG	include/rtw_mp.h	136;"	d
-UNICAST_KEY	include/rtw_cmd.h	/^	UNICAST_KEY		= 1,$/;"	e	enum:STAKEY_TYPE
-UPDATE_HT_CAP	core/rtw_ap.c	3655;"	d	file:
-UPDATE_VHT_CAP	core/rtw_ap.c	3654;"	d	file:
-UPHY_SUSB	include/hal_com_reg.h	1301;"	d
-UP_LINK	include/hal_com.h	/^	UP_LINK,$/;"	e	enum:__anon2
-USA	include/rtw_eeprom.h	44;"	d
-USA	include/rtw_rf.h	83;"	d
-USBD_HALTED	include/usb_osintf.h	25;"	d
-USB_AGG_EN	include/hal_com_reg.h	1752;"	d
-USB_AGG_EN_8814A	include/rtl8814a_spec.h	638;"	d
-USB_C2H_CMDID_OFFSET	include/hal_com_reg.h	663;"	d
-USB_C2H_EVENT_OFFSET	include/hal_com_reg.h	665;"	d
-USB_C2H_SEQ_OFFSET	include/hal_com_reg.h	664;"	d
-USB_DEBUG_VAR	include/osdep_service_bsd.h	74;"	d
-USB_DUMMY_LENGTH	include/rtl8812a_xmit.h	318;"	d
-USB_DUMMY_OFFSET	include/rtl8812a_xmit.h	314;"	d
-USB_DUMMY_OFFSET	include/rtl8812a_xmit.h	316;"	d
-USB_EXTENSION	include/drv_types_ce.h	/^} USB_EXTENSION, *PUSB_EXTENSION;$/;"	t	typeref:struct:_USB_EXTENSION
-USB_FULL_SPEED_BULK_SIZE	include/usb_ops.h	117;"	d
-USB_HIGH_SPEED_BULK_SIZE	include/usb_ops.h	116;"	d
-USB_INTR_CONTENT_C2H_OFFSET	include/hal_com_reg.h	667;"	d
-USB_INTR_CONTENT_CPWM1_OFFSET	include/hal_com_reg.h	668;"	d
-USB_INTR_CONTENT_CPWM2_OFFSET	include/hal_com_reg.h	669;"	d
-USB_INTR_CONTENT_HISRE_OFFSET	include/hal_com_reg.h	671;"	d
-USB_INTR_CONTENT_HISR_OFFSET	include/hal_com_reg.h	670;"	d
-USB_INTR_CONTENT_LENGTH	include/hal_com_reg.h	672;"	d
-USB_INTR_CPWM_OFFSET	include/hal_com_reg.h	666;"	d
-USB_IS_FULL_SPEED	include/hal_com_reg.h	1745;"	d
-USB_IS_HIGH_SPEED	include/hal_com_reg.h	1744;"	d
-USB_NORMAL_SIE_EP_MASK	include/hal_com_reg.h	1748;"	d
-USB_NORMAL_SIE_EP_SHIFT	include/hal_com_reg.h	1749;"	d
-USB_READ_PORT_FAIL	include/rtw_sreset.h	45;"	d
-USB_SPEED_MASK	include/hal_com_reg.h	1746;"	d
-USB_SUPER_SPEED_BULK_SIZE	include/usb_ops.h	115;"	d
-USB_SUSEN	include/hal_com_reg.h	1303;"	d
-USB_TXAGG_NUM_SHT	include/rtl8188e_xmit.h	91;"	d
-USB_TXAGG_NUM_SHT	include/rtl8192e_xmit.h	196;"	d
-USB_TXAGG_NUM_SHT	include/rtl8812a_xmit.h	88;"	d
-USB_VEN_REQ_CMD_FAIL	include/rtw_sreset.h	44;"	d
-USB_VendorReq	include/rtw_mp_ioctl.h	/^} usb_vendor_req, USB_VendorReq, *pUSB_VendorReq;$/;"	t	typeref:struct:_USB_VendorReq
-USB_WRITE_PORT_FAIL	include/rtw_sreset.h	46;"	d
-USEC_UNIT_FOR_8192E_C2H_TX_RPT_QUEUE_TIME	include/rtl8192e_cmd.h	150;"	d
-USEC_UNIT_FOR_8812_C2H_TX_RPT_QUEUE_TIME	include/rtl8812a_cmd.h	152;"	d
-USEC_UNIT_FOR_8814A_C2H_TX_RPT_QUEUE_TIME	include/rtl8814a_cmd.h	98;"	d
-USERATE	include/rtl8188e_xmit.h	75;"	d
-USERATE	include/rtl8192e_xmit.h	180;"	d
-USERATE	include/rtl8812a_xmit.h	73;"	d
-USER_EFUSE_MAP_PATH	Makefile	/^USER_EFUSE_MAP_PATH ?=$/;"	m
-USER_MODULE_NAME	Makefile	/^USER_MODULE_NAME ?=$/;"	m
-USER_WIFIMAC_PATH	Makefile	/^USER_WIFIMAC_PATH ?=$/;"	m
-USE_PATH_A_AS_DEFAULT_ANT	hal/phydm/phydm_pathdiv.h	27;"	d
-USE_WORKITEM	hal/phydm/phydm_types.h	242;"	d
-USHORT	include/basic_types.h	145;"	d
-USHORT	include/basic_types.h	99;"	d
-USHORT	include/rtw_mp.h	134;"	d
-UltraLowRSSIThresh	hal/phydm/phydm_rainfo.h	/^	u1Byte				UltraLowRSSIThresh;$/;"	m	struct:_ODM_RATE_ADAPTIVE
-UndecoratedSmoothedCCK	include/sta_info.h	/^	s32	UndecoratedSmoothedCCK;$/;"	m	struct:_RSSI_STA
-UndecoratedSmoothedOFDM	include/sta_info.h	/^	s32	UndecoratedSmoothedOFDM;$/;"	m	struct:_RSSI_STA
-UndecoratedSmoothedPWDB	include/sta_info.h	/^	s32	UndecoratedSmoothedPWDB;$/;"	m	struct:_RSSI_STA
-UnusedRegister	include/hal_com_reg.h	587;"	d
-UpdateBrateTbl	core/rtw_wlan_util.c	/^void UpdateBrateTbl($/;"	f
-UpdateBrateTblForSoftAP	core/rtw_wlan_util.c	/^void UpdateBrateTblForSoftAP(u8 *bssrateset, u32 bssratelen)$/;"	f
-UpdateHalRAMask8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^void UpdateHalRAMask8723D(PADAPTER padapter, struct sta_info *psta, u32 mac_id, u8 rssi_level)$/;"	f
-UpdateInterruptMask8723DSdio	hal/rtl8723d/sdio/sdio_ops.c	/^void UpdateInterruptMask8723DSdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR)$/;"	f
-UpdateRAMaskHandler	include/hal_intf.h	/^	void	(*UpdateRAMaskHandler)(_adapter *padapter, struct sta_info *psta, u32 mac_id, u8 rssi_level);$/;"	m	struct:hal_ops
-Update_ODM_ComInfo_8723d	hal/rtl8723d/rtl8723d_dm.c	/^static void Update_ODM_ComInfo_8723d(PADAPTER	Adapter)$/;"	f	file:
-Update_RA_Entry	core/rtw_wlan_util.c	/^void Update_RA_Entry(_adapter *padapter, struct sta_info *psta)$/;"	f
-UsbBulkOutSize	include/hal_data.h	/^	u32			UsbBulkOutSize;$/;"	m	struct:hal_com_data
-UsbRxHighSpeedMode	include/hal_data.h	/^	BOOLEAN		UsbRxHighSpeedMode;$/;"	m	struct:hal_com_data
-UsbTxAggDescNum	include/hal_data.h	/^	u8			UsbTxAggDescNum;$/;"	m	struct:hal_com_data
-UsbTxAggMode	include/hal_data.h	/^	u8			UsbTxAggMode;$/;"	m	struct:hal_com_data
-UsbTxVeryHighSpeedMode	include/hal_data.h	/^	BOOLEAN		UsbTxVeryHighSpeedMode;$/;"	m	struct:hal_com_data
-UserPriority	include/rtw_recv.h	/^	u8 UserPriority;$/;"	m	struct:recv_frame_hdr
-V15_VLD	include/hal_com_reg.h	1258;"	d
-VAL	hal/phydm/rtl8723d/halphyrf_8723d.c	51;"	d	file:
-VCS_TYPE	include/wlan_bssdef.h	/^enum VCS_TYPE {$/;"	g
-VCS_update	core/rtw_wlan_util.c	/^void VCS_update(_adapter *padapter, struct sta_info *psta)$/;"	f
-VENDOR_CMD_MAX_DATA_LEN	include/usb_ops_linux.h	23;"	d
-VENDOR_DATA_OVERHEAD	os_dep/linux/rtw_cfgvendor.h	30;"	d
-VENDOR_HT_CAPAB_OUI_TYPE	include/ieee80211.h	1683;"	d
-VENDOR_ID	include/hal_com_reg.h	1266;"	d
-VENDOR_ID_OVERHEAD	os_dep/linux/rtw_cfgvendor.h	28;"	d
-VENDOR_IE_GET	include/rtw_mp.h	/^	VENDOR_IE_GET ,$/;"	e	enum:__anon65
-VENDOR_IE_SET	include/rtw_mp.h	/^	VENDOR_IE_SET ,$/;"	e	enum:__anon65
-VENDOR_NL80211_SUBCMD_RANGE_END	os_dep/linux/rtw_cfgvendor.h	/^	VENDOR_NL80211_SUBCMD_RANGE_END   = 0x0FFF,$/;"	e	enum:__anon82
-VENDOR_NL80211_SUBCMD_RANGE_START	os_dep/linux/rtw_cfgvendor.h	/^	VENDOR_NL80211_SUBCMD_RANGE_START = 0x0001,$/;"	e	enum:__anon82
-VENDOR_NL80211_SUBCMD_UNSPECIFIED	os_dep/linux/rtw_cfgvendor.h	/^	VENDOR_NL80211_SUBCMD_UNSPECIFIED,$/;"	e	enum:__anon82
-VENDOR_READ	include/usb_ops.h	/^	VENDOR_READ = 0x01,$/;"	e	enum:__anon42
-VENDOR_REPLY_OVERHEAD	os_dep/linux/rtw_cfgvendor.h	43;"	d
-VENDOR_SUBCMD_MAX	os_dep/linux/rtw_cfgvendor.h	/^	VENDOR_SUBCMD_MAX$/;"	e	enum:wl_vendor_subcmd
-VENDOR_SUBCMD_OVERHEAD	os_dep/linux/rtw_cfgvendor.h	29;"	d
-VENDOR_WRITE	include/usb_ops.h	/^	VENDOR_WRITE = 0x00,$/;"	e	enum:__anon42
-VHTOnAssocRsp	core/rtw_vht.c	/^void VHTOnAssocRsp(_adapter *padapter)$/;"	f
-VHT_1SS	include/ieee80211.h	/^	VHT_1SS = VHT_1SSMCS0_1SSMCS9,$/;"	e	enum:_RATE_SECTION
-VHT_1SSMCS0_1SSMCS9	include/ieee80211.h	/^	VHT_1SSMCS0_1SSMCS9 = 6,$/;"	e	enum:_RATE_SECTION
-VHT_2SS	include/ieee80211.h	/^	VHT_2SS = VHT_2SSMCS0_2SSMCS9,$/;"	e	enum:_RATE_SECTION
-VHT_2SSMCS0_2SSMCS9	include/ieee80211.h	/^	VHT_2SSMCS0_2SSMCS9 = 7,$/;"	e	enum:_RATE_SECTION
-VHT_3SS	include/ieee80211.h	/^	VHT_3SS = VHT_3SSMCS0_3SSMCS9,$/;"	e	enum:_RATE_SECTION
-VHT_3SSMCS0_3SSMCS9	include/ieee80211.h	/^	VHT_3SSMCS0_3SSMCS9 = 8,$/;"	e	enum:_RATE_SECTION
-VHT_4SS	include/ieee80211.h	/^	VHT_4SS = VHT_4SSMCS0_4SSMCS9,$/;"	e	enum:_RATE_SECTION
-VHT_4SSMCS0_4SSMCS9	include/ieee80211.h	/^	VHT_4SSMCS0_4SSMCS9 = 9,$/;"	e	enum:_RATE_SECTION
-VHT_AGG_SIZE_1024K	include/rtw_ht.h	/^	VHT_AGG_SIZE_1024K = 7,$/;"	e	enum:AGGRE_SIZE
-VHT_AGG_SIZE_128K	include/rtw_ht.h	/^	VHT_AGG_SIZE_128K = 4,$/;"	e	enum:AGGRE_SIZE
-VHT_AGG_SIZE_256K	include/rtw_ht.h	/^	VHT_AGG_SIZE_256K = 5,$/;"	e	enum:AGGRE_SIZE
-VHT_AGG_SIZE_512K	include/rtw_ht.h	/^	VHT_AGG_SIZE_512K = 6,$/;"	e	enum:AGGRE_SIZE
-VHT_DATA_SC	include/rtw_rf.h	/^} VHT_DATA_SC, *PVHT_DATA_SC_E;$/;"	t	typeref:enum:_VHT_DATA_SC
-VHT_DATA_SC_20_LOWER_OF_80MHZ	include/rtw_rf.h	/^	VHT_DATA_SC_20_LOWER_OF_80MHZ = 2,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_20_LOWEST_OF_80MHZ	include/rtw_rf.h	/^	VHT_DATA_SC_20_LOWEST_OF_80MHZ = 4,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_20_RECV1	include/rtw_rf.h	/^	VHT_DATA_SC_20_RECV1 = 5,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_20_RECV2	include/rtw_rf.h	/^	VHT_DATA_SC_20_RECV2 = 6,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_20_RECV3	include/rtw_rf.h	/^	VHT_DATA_SC_20_RECV3 = 7,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_20_RECV4	include/rtw_rf.h	/^	VHT_DATA_SC_20_RECV4 = 8,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_20_UPPERST_OF_80MHZ	include/rtw_rf.h	/^	VHT_DATA_SC_20_UPPERST_OF_80MHZ = 3,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_20_UPPER_OF_80MHZ	include/rtw_rf.h	/^	VHT_DATA_SC_20_UPPER_OF_80MHZ = 1,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_40_LOWER_OF_80MHZ	include/rtw_rf.h	/^	VHT_DATA_SC_40_LOWER_OF_80MHZ = 10,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_40_UPPER_OF_80MHZ	include/rtw_rf.h	/^	VHT_DATA_SC_40_UPPER_OF_80MHZ = 9,$/;"	e	enum:_VHT_DATA_SC
-VHT_DATA_SC_DONOT_CARE	include/rtw_rf.h	/^	VHT_DATA_SC_DONOT_CARE = 0,$/;"	e	enum:_VHT_DATA_SC
-VHT_Delimiter	include/rtw_mp.h	/^	u8			VHT_Delimiter[4];$/;"	m	struct:_RT_PMAC_TX_INFO
-VHT_Delimiter_generator	core/rtw_mp.c	/^void VHT_Delimiter_generator($/;"	f
-VHT_MCS_DATA_RATE	core/rtw_vht.c	/^const u16 VHT_MCS_DATA_RATE[3][2][30] = {$/;"	v
-VHT_SIG_A	include/rtw_mp.h	/^	u8			VHT_SIG_A[6];$/;"	m	struct:_RT_PMAC_TX_INFO
-VHT_SIG_A_generator	core/rtw_mp.c	/^void VHT_SIG_A_generator($/;"	f
-VHT_SIG_B	include/rtw_mp.h	/^	u8			VHT_SIG_B[4];$/;"	m	struct:_RT_PMAC_TX_INFO
-VHT_SIG_B_CRC	include/rtw_mp.h	/^	u8			VHT_SIG_B_CRC;$/;"	m	struct:_RT_PMAC_TX_INFO
-VHT_SIG_B_generator	core/rtw_mp.c	/^void VHT_SIG_B_generator($/;"	f
-VHT_caps_handler	core/rtw_vht.c	/^void VHT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)$/;"	f
-VHT_enable	include/rtw_mlme_ext.h	/^	u8	VHT_enable;$/;"	m	struct:mlme_ext_info
-VHT_operation_handler	core/rtw_vht.c	/^void VHT_operation_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)$/;"	f
-VIF_START_ID	include/drv_types.h	489;"	d
-VIRTUAL_ADAPTER	include/drv_types.h	/^	VIRTUAL_ADAPTER,$/;"	e	enum:_ADAPTER_TYPE
-VISTA_USB_RX_REVISE	hal/phydm/phydm_types.h	63;"	d
-VI_QUEUE_INX	include/rtw_xmit.h	103;"	d
-VOID	hal/phydm/phydm_types.h	/^	typedef void					VOID,*PVOID;$/;"	t
-VOID	include/basic_types.h	135;"	d
-VOID	include/basic_types.h	87;"	d
-VOLTAGE_V25	hal/rtl8723d/rtl8723d_hal_init.c	1460;"	d	file:
-VOLTAGE_V25	include/rtl8814a_hal.h	/^	VOLTAGE_V25						= 0x03,$/;"	e	enum:__anon58
-VO_QUEUE_INX	include/rtw_xmit.h	102;"	d
-VRTL_CARRIER_SENSE	include/wlan_bssdef.h	/^enum VRTL_CARRIER_SENSE {$/;"	g
-VXD_bLinked	hal/phydm/phydm.h	/^	BOOLEAN			VXD_bLinked;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ValidBit	include/sta_info.h	/^	u8	ValidBit;$/;"	m	struct:_RSSI_STA
-ValidCnt	hal/phydm/phydm_noisemonitor.c	40;"	d	file:
-Valid_Max	hal/phydm/phydm_noisemonitor.c	39;"	d	file:
-Valid_Min	hal/phydm/phydm_noisemonitor.c	38;"	d	file:
-Value	hal/phydm/phydm_powertracking_ap.h	/^	s4Byte		Value[1][IQK_Matrix_REG_NUM];$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-Value	hal/phydm/phydm_powertracking_ce.h	/^	s4Byte		Value[3][IQK_Matrix_REG_NUM];$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-Value	hal/phydm/phydm_powertracking_win.h	/^	s4Byte		Value[3][IQK_Matrix_REG_NUM];$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-Value	include/hal_phy.h	/^	u32		Value;$/;"	m	struct:RF_Shadow_Compare_Map
-Value	include/rtw_io.h	/^	u32		Value;$/;"	m	struct:reg_protocol_wt
-VendorID	include/drv_types_pci.h	/^	u16	VendorID;$/;"	m	struct:_PCI_COMMON_CONFIG
-VendorType	include/HalVerDef.h	/^	HAL_VENDOR_E		VendorType;$/;"	m	struct:tag_HAL_VERSION
-Version	include/rtl8188e_hal.h	/^	u16		Version;		\/* FW Version *\/$/;"	m	struct:_RT_8188E_FIRMWARE_HDR
-Version	include/rtl8188f_hal.h	/^	u16		Version;		\/* FW Version *\/$/;"	m	struct:_RT_8188F_FIRMWARE_HDR
-Version	include/rtl8703b_hal.h	/^	u16		Version;		\/* FW Version *\/$/;"	m	struct:_RT_8703B_FIRMWARE_HDR
-Version	include/rtl8723b_hal.h	/^	u16		Version;		\/* FW Version *\/$/;"	m	struct:_RT_8723B_FIRMWARE_HDR
-Version	include/rtl8723d_hal.h	/^	u16		Version;		\/* FW Version *\/$/;"	m	struct:_RT_8723D_FIRMWARE_HDR
-Version	include/wlan_bssdef.h	/^	ULONG  Version;$/;"	m	struct:_NDIS_802_11_CAPABILITY
-Version	include/wlan_bssdef.h	/^	ULONG Version;       \/* Version of the structure *\/$/;"	m	struct:_NDIS_802_11_PMKID_CANDIDATE_LIST
-VersionID	include/hal_data.h	/^	HAL_VERSION			VersionID;$/;"	m	struct:hal_com_data
-VhtBeamformCap	hal/phydm/phydm_beamforming.h	/^	u2Byte						VhtBeamformCap;$/;"	m	struct:_RT_BEAMFORM_STAINFO
-WAIT_FOR_BCN_TO_MAX	core/rtw_wlan_util.c	55;"	d	file:
-WAIT_FOR_BCN_TO_MIN	core/rtw_wlan_util.c	54;"	d	file:
-WAIT_TIME_PPPOE	core/rtw_br_ext.c	74;"	d	file:
-WAKEUP_GPIO_IDX	include/autoconf.h	237;"	d
-WAKEUP_REASON	include/hal_com.h	/^}WAKEUP_REASON;$/;"	t	typeref:enum:_WAKEUP_REASON
-WAPI_ACCESS_AUTHENTICATE_REQUEST	include/rtw_wapi.h	/^	WAPI_ACCESS_AUTHENTICATE_REQUEST = 4,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_ACCESS_AUTHENTICATE_RESPONSE	include/rtw_wapi.h	/^	WAPI_ACCESS_AUTHENTICATE_RESPONSE = 5,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_API	include/rtw_wapi.h	/^	WAPI_API				= 1 << 1,$/;"	e	enum:WAPI_DEBUG
-WAPI_AUTHENTICATE_ACTIVE	include/rtw_wapi.h	/^	WAPI_AUTHENTICATE_ACTIVE = 3,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_CAM_ENTRY_NUM	include/rtw_wapi.h	74;"	d
-WAPI_CERTIFICATE_AUTHENTICATE_REQUEST	include/rtw_wapi.h	/^	WAPI_CERTIFICATE_AUTHENTICATE_REQUEST = 6,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_CERTIFICATE_AUTHENTICATE_RESPONSE	include/rtw_wapi.h	/^	WAPI_CERTIFICATE_AUTHENTICATE_RESPONSE = 7,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_DATA	include/rtw_wapi.h	33;"	d
-WAPI_DATA	include/rtw_wapi.h	58;"	d
-WAPI_DEBUG	include/rtw_wapi.h	/^enum WAPI_DEBUG {$/;"	g
-WAPI_DEBUG	include/rtw_wapi.h	6;"	d
-WAPI_ERR	include/rtw_wapi.h	/^	WAPI_ERR			= 1 << 31$/;"	e	enum:WAPI_DEBUG
-WAPI_EXT_LEN	include/rtw_wapi.h	9;"	d
-WAPI_INIT	include/rtw_wapi.h	/^	WAPI_INIT				= 1,$/;"	e	enum:WAPI_DEBUG
-WAPI_IOCTL	include/rtw_wapi.h	/^	WAPI_IOCTL				= 1 << 5,$/;"	e	enum:WAPI_DEBUG
-WAPI_LITTLE_ENDIAN	core/rtw_wapi_sms4.c	11;"	d	file:
-WAPI_MAX_BKID_NUM	include/rtw_wapi.h	72;"	d
-WAPI_MAX_STAINFO_NUM	include/rtw_wapi.h	73;"	d
-WAPI_MLME	include/rtw_wapi.h	/^	WAPI_MLME				= 1 << 4,$/;"	e	enum:WAPI_DEBUG
-WAPI_MSK_NOTIFICATION	include/rtw_wapi.h	/^	WAPI_MSK_NOTIFICATION = 11,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_MSK_RESPONSE	include/rtw_wapi.h	/^	WAPI_MSK_RESPONSE = 12$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_NONE	include/rtw_wapi.h	/^	WAPI_NONE = 0,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_PREAUTHENTICATE	include/rtw_wapi.h	/^	WAPI_PREAUTHENTICATE = 1,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_RX	include/rtw_wapi.h	/^	WAPI_RX				= 1 << 3,$/;"	e	enum:WAPI_DEBUG
-WAPI_STAKEY_REQUEST	include/rtw_wapi.h	/^	WAPI_STAKEY_REQUEST = 2,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_TRACE	include/rtw_wapi.h	27;"	d
-WAPI_TRACE	include/rtw_wapi.h	57;"	d
-WAPI_TX	include/rtw_wapi.h	/^	WAPI_TX				= 1 << 2,$/;"	e	enum:WAPI_DEBUG
-WAPI_USK_CONFIRM	include/rtw_wapi.h	/^	WAPI_USK_CONFIRM = 10,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_USK_REQUEST	include/rtw_wapi.h	/^	WAPI_USK_REQUEST = 8,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WAPI_USK_RESPONSE	include/rtw_wapi.h	/^	WAPI_USK_RESPONSE = 9,$/;"	e	enum:_RT_WAPI_PACKET_TYPE
-WBIQK_delay	hal/phydm/phydm_iqk.h	26;"	d
-WCAMI	include/hal_com_reg.h	581;"	d
-WCAMI_8723D	hal/phydm/rtl8723d/hal8723dreg.h	455;"	d
-WCAMI_8814A	include/rtl8814a_spec.h	554;"	d
-WEP_IV	include/rtw_xmit.h	125;"	d
-WEP_KEYS	include/ieee80211.h	1102;"	d
-WEP_KEY_LEN	include/ieee80211.h	1103;"	d
-WEP_SW_DEC_CNT_INC	core/rtw_security.c	103;"	d	file:
-WEP_SW_DEC_CNT_INC	core/rtw_security.c	57;"	d	file:
-WEP_SW_ENC_CNT_INC	core/rtw_security.c	102;"	d	file:
-WEP_SW_ENC_CNT_INC	core/rtw_security.c	48;"	d	file:
-WEXT_CSCAN_ACTV_DWELL_SECTION	os_dep/linux/ioctl_linux.c	55;"	d	file:
-WEXT_CSCAN_AMOUNT	os_dep/linux/ioctl_linux.c	48;"	d	file:
-WEXT_CSCAN_BUF_LEN	os_dep/linux/ioctl_linux.c	49;"	d	file:
-WEXT_CSCAN_CHANNEL_SECTION	os_dep/linux/ioctl_linux.c	53;"	d	file:
-WEXT_CSCAN_HEADER	os_dep/linux/ioctl_linux.c	50;"	d	file:
-WEXT_CSCAN_HEADER_SIZE	os_dep/linux/ioctl_linux.c	51;"	d	file:
-WEXT_CSCAN_HOME_DWELL_SECTION	os_dep/linux/ioctl_linux.c	57;"	d	file:
-WEXT_CSCAN_NPROBE_SECTION	os_dep/linux/ioctl_linux.c	54;"	d	file:
-WEXT_CSCAN_PASV_DWELL_SECTION	os_dep/linux/ioctl_linux.c	56;"	d	file:
-WEXT_CSCAN_SSID_SECTION	os_dep/linux/ioctl_linux.c	52;"	d	file:
-WEXT_CSCAN_TYPE_SECTION	os_dep/linux/ioctl_linux.c	58;"	d	file:
-WFD_ATTR_ALTER_MAC	include/wifi.h	1338;"	d
-WFD_ATTR_ASSOC_BSSID	include/wifi.h	1334;"	d
-WFD_ATTR_COUPLED_SINK_INFO	include/wifi.h	1335;"	d
-WFD_ATTR_DEVICE_INFO	include/wifi.h	1333;"	d
-WFD_ATTR_LOCAL_IP_ADDR	include/wifi.h	1336;"	d
-WFD_ATTR_SESSION_INFO	include/wifi.h	1337;"	d
-WFD_DEVINFO_DUAL	include/wifi.h	1344;"	d
-WFD_DEVINFO_HDCP_SUPPORT	include/wifi.h	1349;"	d
-WFD_DEVINFO_PC_TDLS	include/wifi.h	1348;"	d
-WFD_DEVINFO_PSINK	include/wifi.h	1342;"	d
-WFD_DEVINFO_SESSION_AVAIL	include/wifi.h	1346;"	d
-WFD_DEVINFO_SOURCE	include/wifi.h	1341;"	d
-WFD_DEVINFO_SSINK	include/wifi.h	1343;"	d
-WFD_DEVINFO_WSD	include/wifi.h	1347;"	d
-WFD_OUI	core/rtw_mlme_ext.c	/^unsigned char	WFD_OUI[] = {0x50, 0x6F, 0x9A, 0x0A};$/;"	v
-WIFITest	hal/phydm/phydm.h	/^	u1Byte			WIFITest;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-WIFI_ACK	include/wifi.h	/^	WIFI_ACK            = (BIT(7) | BIT(6) | BIT(4) | WIFI_CTRL_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_ACTION	include/wifi.h	/^	WIFI_ACTION         = (BIT(7) | BIT(6) | BIT(4) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_ACTION_NOACK	include/wifi.h	/^	WIFI_ACTION_NOACK = (BIT(7) | BIT(6) | BIT(5) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_ADHOC_MASTER_STATE	include/rtw_mlme.h	51;"	d
-WIFI_ADHOC_STATE	include/rtw_mlme.h	50;"	d
-WIFI_AP_CONNECTED	hal/btc/HalBtcOutSrc.h	95;"	d
-WIFI_AP_STATE	include/rtw_mlme.h	49;"	d
-WIFI_ASOC_STATE	include/rtw_mlme.h	45;"	d
-WIFI_ASSOCREQ	include/wifi.h	/^	WIFI_ASSOCREQ       = (0 | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_ASSOCREQ_VENDOR_IE_BIT	include/wifi.h	59;"	d
-WIFI_ASSOCRESP_VENDOR_IE_BIT	include/wifi.h	60;"	d
-WIFI_ASSOCRSP	include/wifi.h	/^	WIFI_ASSOCRSP       = (BIT(4) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_ATIM	include/wifi.h	/^	WIFI_ATIM           = (BIT(7) | BIT(4) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_AUTH	include/wifi.h	/^	WIFI_AUTH           = (BIT(7) | BIT(5) | BIT(4) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_AUTOCONF	include/rtw_mlme.h	59;"	d
-WIFI_AUTOCONF_IND	include/rtw_mlme.h	60;"	d
-WIFI_BEACON	include/wifi.h	/^	WIFI_BEACON         = (BIT(7) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_BEACON_VENDOR_IE_BIT	include/wifi.h	56;"	d
-WIFI_CCKRATES	core/rtw_ieee80211.c	/^static u8	WIFI_CCKRATES[] = {$/;"	v	file:
-WIFI_CFEND	include/wifi.h	/^	WIFI_CFEND          = (BIT(7) | BIT(6) | BIT(5) | WIFI_CTRL_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_CFEND_CFACK	include/wifi.h	/^	WIFI_CFEND_CFACK    = (BIT(7) | BIT(6) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_CF_ACK	include/wifi.h	/^	WIFI_CF_ACK         = (BIT(6) | BIT(4) | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_CF_ACKPOLL	include/wifi.h	/^	WIFI_CF_ACKPOLL     = (BIT(6) | BIT(5) | BIT(4) | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_CF_POLL	include/wifi.h	/^	WIFI_CF_POLL        = (BIT(6) | BIT(5) | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_CTRL_TYPE	include/wifi.h	/^	WIFI_CTRL_TYPE =	(BIT(2)),$/;"	e	enum:WIFI_FRAME_TYPE
-WIFI_CTS	include/wifi.h	/^	WIFI_CTS            = (BIT(7) | BIT(6) | WIFI_CTRL_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_DATA	include/wifi.h	/^	WIFI_DATA           = (0 | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_DATA_CFACK	include/wifi.h	/^	WIFI_DATA_CFACK     = (BIT(4) | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_DATA_CFACKPOLL	include/wifi.h	/^	WIFI_DATA_CFACKPOLL = (BIT(5) | BIT(4) | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_DATA_CFPOLL	include/wifi.h	/^	WIFI_DATA_CFPOLL    = (BIT(5) | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_DATA_NULL	include/wifi.h	/^	WIFI_DATA_NULL      = (BIT(6) | WIFI_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_DATA_TYPE	include/wifi.h	/^	WIFI_DATA_TYPE =	(BIT(3)),$/;"	e	enum:WIFI_FRAME_TYPE
-WIFI_DEAUTH	include/wifi.h	/^	WIFI_DEAUTH         = (BIT(7) | BIT(6) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_DISASSOC	include/wifi.h	/^	WIFI_DISASSOC       = (BIT(7) | BIT(5) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_FEATURE_ADDITIONAL_STA	os_dep/linux/rtw_cfgvendor.c	228;"	d	file:
-WIFI_FEATURE_AP_STA	os_dep/linux/rtw_cfgvendor.c	232;"	d	file:
-WIFI_FEATURE_BATCH_SCAN	os_dep/linux/rtw_cfgvendor.c	226;"	d	file:
-WIFI_FEATURE_D2AP_RTT	os_dep/linux/rtw_cfgvendor.c	225;"	d	file:
-WIFI_FEATURE_D2D_RTT	os_dep/linux/rtw_cfgvendor.c	224;"	d	file:
-WIFI_FEATURE_EPR	os_dep/linux/rtw_cfgvendor.c	231;"	d	file:
-WIFI_FEATURE_GSCAN	os_dep/linux/rtw_cfgvendor.c	222;"	d	file:
-WIFI_FEATURE_HOTSPOT	os_dep/linux/rtw_cfgvendor.c	219;"	d	file:
-WIFI_FEATURE_INFRA	os_dep/linux/rtw_cfgvendor.c	217;"	d	file:
-WIFI_FEATURE_INFRA_5G	os_dep/linux/rtw_cfgvendor.c	218;"	d	file:
-WIFI_FEATURE_NAN	os_dep/linux/rtw_cfgvendor.c	223;"	d	file:
-WIFI_FEATURE_P2P	os_dep/linux/rtw_cfgvendor.c	220;"	d	file:
-WIFI_FEATURE_PNO	os_dep/linux/rtw_cfgvendor.c	227;"	d	file:
-WIFI_FEATURE_SOFT_AP	os_dep/linux/rtw_cfgvendor.c	221;"	d	file:
-WIFI_FEATURE_TDLS	os_dep/linux/rtw_cfgvendor.c	229;"	d	file:
-WIFI_FEATURE_TDLS_OFFCHANNEL	os_dep/linux/rtw_cfgvendor.c	230;"	d	file:
-WIFI_FRAME_SUBTYPE	include/wifi.h	/^enum WIFI_FRAME_SUBTYPE {$/;"	g
-WIFI_FRAME_TYPE	include/wifi.h	/^enum WIFI_FRAME_TYPE {$/;"	g
-WIFI_FREQUENCY_BAND_2GHZ	include/rtw_mlme.h	166;"	d
-WIFI_FREQUENCY_BAND_5GHZ	include/rtw_mlme.h	165;"	d
-WIFI_FREQUENCY_BAND_AUTO	include/rtw_mlme.h	164;"	d
-WIFI_FW_ADHOC_STATE	include/rtw_mlme_ext.h	379;"	d
-WIFI_FW_AP_STATE	include/rtw_mlme_ext.h	378;"	d
-WIFI_FW_ASSOC_STATE	include/rtw_mlme_ext.h	385;"	d
-WIFI_FW_ASSOC_SUCCESS	include/rtw_mlme_ext.h	386;"	d
-WIFI_FW_AUTH_NULL	include/rtw_mlme_ext.h	381;"	d
-WIFI_FW_AUTH_STATE	include/rtw_mlme_ext.h	382;"	d
-WIFI_FW_AUTH_SUCCESS	include/rtw_mlme_ext.h	383;"	d
-WIFI_FW_LINKING_STATE	include/rtw_mlme_ext.h	388;"	d
-WIFI_FW_NULL_STATE	include/rtw_mlme_ext.h	376;"	d
-WIFI_FW_STATION_STATE	include/rtw_mlme_ext.h	377;"	d
-WIFI_HS_CONNECTED	hal/btc/HalBtcOutSrc.h	96;"	d
-WIFI_IF_NOT_EXIST	include/rtw_sreset.h	50;"	d
-WIFI_MAC_TXDMA_ERROR	include/rtw_sreset.h	47;"	d
-WIFI_MGT_TYPE	include/wifi.h	/^	WIFI_MGT_TYPE  =	(0),$/;"	e	enum:WIFI_FRAME_TYPE
-WIFI_MONITOR_STATE	include/rtw_mlme.h	76;"	d
-WIFI_MP_CTX_BACKGROUND	include/rtw_mlme.h	62;"	d
-WIFI_MP_CTX_BACKGROUND_PENDING	include/rtw_mlme.h	64;"	d
-WIFI_MP_CTX_CCK_CS	include/rtw_mlme.h	66;"	d
-WIFI_MP_CTX_CCK_HW	include/rtw_mlme.h	65;"	d
-WIFI_MP_CTX_ST	include/rtw_mlme.h	63;"	d
-WIFI_MP_LPBK_STATE	include/rtw_mlme.h	67;"	d
-WIFI_MP_STATE	include/rtw_mlme.h	61;"	d
-WIFI_NDPA	include/wifi.h	/^	WIFI_NDPA         = (BIT(6) | BIT(4) | WIFI_CTRL_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_NULL_STATE	include/rtw_mlme.h	44;"	d
-WIFI_OFDMRATES	core/rtw_ieee80211.c	/^static u8	WIFI_OFDMRATES[] = {$/;"	v	file:
-WIFI_OP_CH_SWITCHING	include/rtw_mlme.h	68;"	d
-WIFI_P2P_GC_CONNECTED	hal/btc/HalBtcOutSrc.h	98;"	d
-WIFI_P2P_GO_CONNECTED	hal/btc/HalBtcOutSrc.h	97;"	d
-WIFI_PROBEREQ	include/wifi.h	/^	WIFI_PROBEREQ       = (BIT(6) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_PROBEREQ_VENDOR_IE_BIT	include/wifi.h	57;"	d
-WIFI_PROBERESP_VENDOR_IE_BIT	include/wifi.h	58;"	d
-WIFI_PROBERSP	include/wifi.h	/^	WIFI_PROBERSP       = (BIT(6) | BIT(4) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_PSPOLL	include/wifi.h	/^	WIFI_PSPOLL         = (BIT(7) | BIT(5) | WIFI_CTRL_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_QOS_DATA_NULL	include/wifi.h	/^	WIFI_QOS_DATA_NULL	= (BIT(6) | WIFI_QOS_DATA_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_QOS_DATA_TYPE	include/wifi.h	/^	WIFI_QOS_DATA_TYPE	= (BIT(7) | BIT(3)),	\/* !< QoS Data	 *\/$/;"	e	enum:WIFI_FRAME_TYPE
-WIFI_REASOC_STATE	include/rtw_mlme.h	46;"	d
-WIFI_REASON_CODE	include/wifi.h	/^enum WIFI_REASON_CODE	{$/;"	g
-WIFI_REASSOCREQ	include/wifi.h	/^	WIFI_REASSOCREQ     = (BIT(5) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_REASSOCRSP	include/wifi.h	/^	WIFI_REASSOCRSP     = (BIT(5) | BIT(4) | WIFI_MGT_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_REG_DOMAIN	include/wifi.h	/^enum WIFI_REG_DOMAIN {$/;"	g
-WIFI_RTS	include/wifi.h	/^	WIFI_RTS            = (BIT(7) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),$/;"	e	enum:WIFI_FRAME_SUBTYPE
-WIFI_RX_HANG	include/rtw_sreset.h	49;"	d
-WIFI_SCAN_BUFFER_FULL	os_dep/linux/rtw_cfgvendor.h	/^	WIFI_SCAN_BUFFER_FULL,$/;"	e	enum:gscan_complete_event
-WIFI_SCAN_COMPLETE	os_dep/linux/rtw_cfgvendor.h	/^	WIFI_SCAN_COMPLETE$/;"	e	enum:gscan_complete_event
-WIFI_SITE_MONITOR	include/rtw_mlme.h	56;"	d
-WIFI_SLEEP_STATE	include/rtw_mlme.h	47;"	d
-WIFI_STATION_STATE	include/rtw_mlme.h	48;"	d
-WIFI_STATUS_CODE	include/wifi.h	/^enum WIFI_STATUS_CODE {$/;"	g
-WIFI_STATUS_SUCCESS	include/rtw_sreset.h	43;"	d
-WIFI_STA_ALIVE_CHK_STATE	include/rtw_mlme.h	55;"	d
-WIFI_STA_CONNECTED	hal/btc/HalBtcOutSrc.h	94;"	d
-WIFI_TX_HANG	include/rtw_sreset.h	48;"	d
-WIFI_UNDER_LINKING	include/rtw_mlme.h	52;"	d
-WIFI_UNDER_WPS	include/rtw_mlme.h	53;"	d
-WIFI_WDS	include/rtw_mlme.h	57;"	d
-WIFI_WDS_RX_BEACON	include/rtw_mlme.h	58;"	d
-WINTINI_RDY	include/hal_com_reg.h	1245;"	d
-WIN_BT_PORT_MACID	hal/phydm/phydm_rainfo.h	68;"	d
-WIN_DEFAULT_PORT_MACID	hal/phydm/phydm_rainfo.h	67;"	d
-WIPHY_ARG	os_dep/linux/ioctl_cfg80211.h	192;"	d
-WIPHY_FMT	os_dep/linux/ioctl_cfg80211.h	191;"	d
-WIRELESS_11A	include/ieee80211.h	/^	WIRELESS_11A = BIT(2), \/* tx: ofdm only, rx: ofdm only, hw: ofdm only *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11ABGN	include/ieee80211.h	/^	WIRELESS_11ABGN = (WIRELESS_11A | WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11AC	include/ieee80211.h	/^	WIRELESS_11AC = BIT(6),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11AGN	include/ieee80211.h	/^	WIRELESS_11AGN = (WIRELESS_11A | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N), \/* tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11A_5N	include/ieee80211.h	/^	WIRELESS_11A_5N = (WIRELESS_11A | WIRELESS_11_5N), \/* tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11B	include/ieee80211.h	/^	WIRELESS_11B = BIT(0), \/* tx: cck only , rx: cck only, hw: cck *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11BG	include/ieee80211.h	/^	WIRELESS_11BG = (WIRELESS_11B | WIRELESS_11G), \/* tx: cck & ofdm, rx: cck & ofdm & MCS, hw: cck & ofdm *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11BG_24N	include/ieee80211.h	/^	WIRELESS_11BG_24N = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N), \/* tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11B_24N	include/ieee80211.h	/^	WIRELESS_11B_24N = (WIRELESS_11B | WIRELESS_11_24N), \/* tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11G	include/ieee80211.h	/^	WIRELESS_11G = BIT(1), \/* tx: ofdm only, rx: ofdm & cck, hw: cck & ofdm *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11G_24N	include/ieee80211.h	/^	WIRELESS_11G_24N = (WIRELESS_11G | WIRELESS_11_24N), \/* tx: ofdm & MCS, rx: ofdm & cck & MCS, hw: cck & ofdm *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11_24AC	include/ieee80211.h	/^	WIRELESS_11_24AC = (WIRELESS_11G | WIRELESS_11AC),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11_24N	include/ieee80211.h	/^	WIRELESS_11_24N = BIT(3), \/* tx: MCS only, rx: MCS & cck, hw: MCS & cck *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11_5AC	include/ieee80211.h	/^	WIRELESS_11_5AC = (WIRELESS_11A | WIRELESS_11AC),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_11_5N	include/ieee80211.h	/^	WIRELESS_11_5N = BIT(4), \/* tx: MCS only, rx: MCS & ofdm, hw: ofdm only *\/$/;"	e	enum:NETWORK_TYPE
-WIRELESS_AUTO	include/ieee80211.h	/^	WIRELESS_AUTO = BIT(5),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_EXT	include/osdep_service_bsd.h	122;"	d
-WIRELESS_INVALID	include/ieee80211.h	/^	WIRELESS_INVALID = 0,$/;"	e	enum:NETWORK_TYPE
-WIRELESS_MODE	include/hal_phy.h	/^} WIRELESS_MODE;$/;"	t	typeref:enum:_WIRELESS_MODE
-WIRELESS_MODE_24G	include/ieee80211.h	/^	WIRELESS_MODE_24G = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_MODE_5G	include/ieee80211.h	/^	WIRELESS_MODE_5G = (WIRELESS_11A | WIRELESS_11_5N | WIRELESS_11AC),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_MODE_A	include/hal_phy.h	/^	WIRELESS_MODE_A = 0x01,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_AC_24G	include/hal_phy.h	/^	WIRELESS_MODE_AC_24G  = 0x80,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_AC_5G	include/hal_phy.h	/^	WIRELESS_MODE_AC_5G = 0x40,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_AC_ONLY	include/hal_phy.h	/^	WIRELESS_MODE_AC_ONLY  = 0x100,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_AUTO	include/hal_phy.h	/^	WIRELESS_MODE_AUTO = 0x08,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_B	include/hal_phy.h	/^	WIRELESS_MODE_B = 0x02,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_G	include/hal_phy.h	/^	WIRELESS_MODE_G = 0x04,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_MAX	include/ieee80211.h	/^	WIRELESS_MODE_MAX = (WIRELESS_11A | WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N | WIRELESS_11_5N | WIRELESS_11AC),$/;"	e	enum:NETWORK_TYPE
-WIRELESS_MODE_N_24G	include/hal_phy.h	/^	WIRELESS_MODE_N_24G = 0x10,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_N_5G	include/hal_phy.h	/^	WIRELESS_MODE_N_5G = 0x20,$/;"	e	enum:_WIRELESS_MODE
-WIRELESS_MODE_UNKNOWN	include/hal_phy.h	/^	WIRELESS_MODE_UNKNOWN = 0x00,$/;"	e	enum:_WIRELESS_MODE
-WKFMCAM_ADDR_NUM	include/rtw_pwrctrl.h	63;"	d
-WKFMCAM_SIZE	include/rtw_pwrctrl.h	64;"	d
-WLANHDR_OFFSET	include/rtw_xmit.h	454;"	d
-WLAN_A3_PN_OFFSET	include/wifi.h	45;"	d
-WLAN_A4_PN_OFFSET	include/wifi.h	46;"	d
-WLAN_ACTION_ADDBA_REQ	include/ieee80211_ext.h	/^	WLAN_ACTION_ADDBA_REQ = 0,$/;"	e	enum:ieee80211_back_actioncode
-WLAN_ACTION_ADDBA_RESP	include/ieee80211_ext.h	/^	WLAN_ACTION_ADDBA_RESP = 1,$/;"	e	enum:ieee80211_back_actioncode
-WLAN_ACTION_ASEL_INDICATES_FB	include/ieee80211_ext.h	/^	WLAN_ACTION_ASEL_INDICATES_FB = 7,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_DELBA	include/ieee80211_ext.h	/^	WLAN_ACTION_DELBA = 2,$/;"	e	enum:ieee80211_back_actioncode
-WLAN_ACTION_HI_INFO_EXCHG	include/ieee80211_ext.h	/^	WLAN_ACTION_HI_INFO_EXCHG = 8,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_MIMO_CSI_MX	include/ieee80211_ext.h	/^	WLAN_ACTION_MIMO_CSI_MX = 4,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_MIMO_NONCP_BF	include/ieee80211_ext.h	/^	WLAN_ACTION_MIMO_NONCP_BF = 5,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_MIMP_CP_BF	include/ieee80211_ext.h	/^	WLAN_ACTION_MIMP_CP_BF = 6,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_NOTIFY_CH_WIDTH	include/ieee80211_ext.h	/^	WLAN_ACTION_NOTIFY_CH_WIDTH = 0,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_PCO_PHASE	include/ieee80211_ext.h	/^	WLAN_ACTION_PCO_PHASE = 3,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_PSPM	include/ieee80211_ext.h	/^	WLAN_ACTION_PSPM = 2,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_SM_PS	include/ieee80211_ext.h	/^	WLAN_ACTION_SM_PS = 1,$/;"	e	enum:ieee80211_ht_actioncode
-WLAN_ACTION_SPCT_CHL_SWITCH	include/ieee80211_ext.h	/^	WLAN_ACTION_SPCT_CHL_SWITCH = 4,$/;"	e	enum:ieee80211_spectrum_mgmt_actioncode
-WLAN_ACTION_SPCT_EXT_CHL_SWITCH	include/ieee80211_ext.h	/^	WLAN_ACTION_SPCT_EXT_CHL_SWITCH = 5,$/;"	e	enum:ieee80211_spectrum_mgmt_actioncode
-WLAN_ACTION_SPCT_MSR_REQ	include/ieee80211_ext.h	/^	WLAN_ACTION_SPCT_MSR_REQ = 0,$/;"	e	enum:ieee80211_spectrum_mgmt_actioncode
-WLAN_ACTION_SPCT_MSR_RPRT	include/ieee80211_ext.h	/^	WLAN_ACTION_SPCT_MSR_RPRT = 1,$/;"	e	enum:ieee80211_spectrum_mgmt_actioncode
-WLAN_ACTION_SPCT_TPC_REQ	include/ieee80211_ext.h	/^	WLAN_ACTION_SPCT_TPC_REQ = 2,$/;"	e	enum:ieee80211_spectrum_mgmt_actioncode
-WLAN_ACTION_SPCT_TPC_RPRT	include/ieee80211_ext.h	/^	WLAN_ACTION_SPCT_TPC_RPRT = 3,$/;"	e	enum:ieee80211_spectrum_mgmt_actioncode
-WLAN_ADDR_LEN	include/wifi.h	34;"	d
-WLAN_AKM_SUITE_FT_8021X	os_dep/linux/ioctl_cfg80211.c	66;"	d	file:
-WLAN_AKM_SUITE_FT_PSK	os_dep/linux/ioctl_cfg80211.c	67;"	d	file:
-WLAN_AKM_SUITE_WAPI_CERT	os_dep/linux/ioctl_cfg80211.c	56;"	d	file:
-WLAN_AKM_SUITE_WAPI_PSK	os_dep/linux/ioctl_cfg80211.c	52;"	d	file:
-WLAN_AUTH_CHALLENGE_LEN	include/ieee80211.h	597;"	d
-WLAN_AUTH_OPEN	include/ieee80211.h	594;"	d
-WLAN_AUTH_SHARED_KEY	include/ieee80211.h	595;"	d
-WLAN_BACK_INITIATOR	include/ieee80211_ext.h	/^	WLAN_BACK_INITIATOR = 1,$/;"	e	enum:ieee80211_back_parties
-WLAN_BACK_RECIPIENT	include/ieee80211_ext.h	/^	WLAN_BACK_RECIPIENT = 0,$/;"	e	enum:ieee80211_back_parties
-WLAN_BACK_TIMER	include/ieee80211_ext.h	/^	WLAN_BACK_TIMER = 2,$/;"	e	enum:ieee80211_back_parties
-WLAN_BCN_INFO	include/wlan_bssdef.h	/^} WLAN_BCN_INFO, *PWLAN_BCN_INFO;$/;"	t	typeref:struct:_WLAN_BCN_INFO
-WLAN_BSSID_EX	include/wlan_bssdef.h	/^WLAN_BSSID_EX, *PWLAN_BSSID_EX;$/;"	t	typeref:struct:_WLAN_BSSID_EX
-WLAN_BSSID_LEN	include/wifi.h	36;"	d
-WLAN_BSS_TS_LEN	include/wifi.h	37;"	d
-WLAN_BT_PWDN_OFF	include/custom_gpio.h	/^	WLAN_BT_PWDN_OFF$/;"	e	enum:cust_gpio_modes
-WLAN_BT_PWDN_ON	include/custom_gpio.h	/^	WLAN_BT_PWDN_ON,$/;"	e	enum:cust_gpio_modes
-WLAN_CAPABILITY_BSS	include/ieee80211.h	599;"	d
-WLAN_CAPABILITY_CF_POLLABLE	include/ieee80211.h	601;"	d
-WLAN_CAPABILITY_CF_POLL_REQUEST	include/ieee80211.h	602;"	d
-WLAN_CAPABILITY_CHANNEL_AGILITY	include/ieee80211.h	606;"	d
-WLAN_CAPABILITY_IBSS	include/ieee80211.h	600;"	d
-WLAN_CAPABILITY_PBCC	include/ieee80211.h	605;"	d
-WLAN_CAPABILITY_PRIVACY	include/ieee80211.h	603;"	d
-WLAN_CAPABILITY_SHORT_PREAMBLE	include/ieee80211.h	604;"	d
-WLAN_CAPABILITY_SHORT_SLOT	include/ieee80211.h	607;"	d
-WLAN_CATEGORY_BACK	include/ieee80211_ext.h	/^	WLAN_CATEGORY_BACK = 3,$/;"	e	enum:ieee80211_category
-WLAN_CATEGORY_DLS	include/ieee80211_ext.h	/^	WLAN_CATEGORY_DLS = 2,$/;"	e	enum:ieee80211_category
-WLAN_CATEGORY_HT	include/ieee80211_ext.h	/^	WLAN_CATEGORY_HT = 7,$/;"	e	enum:ieee80211_category
-WLAN_CATEGORY_QOS	include/ieee80211_ext.h	/^	WLAN_CATEGORY_QOS = 1,$/;"	e	enum:ieee80211_category
-WLAN_CATEGORY_SPECTRUM_MGMT	include/ieee80211_ext.h	/^	WLAN_CATEGORY_SPECTRUM_MGMT = 0,$/;"	e	enum:ieee80211_category
-WLAN_CATEGORY_WMM	include/ieee80211_ext.h	/^	WLAN_CATEGORY_WMM = 17,$/;"	e	enum:ieee80211_category
-WLAN_CIPHER_SUITE_SMS4	os_dep/linux/ioctl_cfg80211.c	48;"	d	file:
-WLAN_CRC_LEN	include/wifi.h	35;"	d
-WLAN_DATA_MAXLEN	include/wifi.h	43;"	d
-WLAN_EID_20_40_BSS_COEXISTENCE	include/ieee80211.h	671;"	d
-WLAN_EID_20_40_BSS_INTOLERANT	include/ieee80211.h	672;"	d
-WLAN_EID_CF_PARAMS	include/ieee80211.h	645;"	d
-WLAN_EID_CHALLENGE	include/ieee80211.h	648;"	d
-WLAN_EID_CHANNEL_SWITCH	include/ieee80211.h	655;"	d
-WLAN_EID_DS_PARAMS	include/ieee80211.h	644;"	d
-WLAN_EID_ERP_INFO	include/ieee80211.h	661;"	d
-WLAN_EID_EXT_SUPP_RATES	include/ieee80211.h	664;"	d
-WLAN_EID_FAST_BSS_TRANSITION	include/ieee80211.h	666;"	d
-WLAN_EID_FH_PARAMS	include/ieee80211.h	643;"	d
-WLAN_EID_GENERIC	include/ieee80211.h	676;"	d
-WLAN_EID_HT_CAP	include/ieee80211.h	662;"	d
-WLAN_EID_HT_OPERATION	include/ieee80211.h	669;"	d
-WLAN_EID_IBSS_DFS	include/ieee80211.h	659;"	d
-WLAN_EID_IBSS_PARAMS	include/ieee80211.h	647;"	d
-WLAN_EID_MEASURE_REPORT	include/ieee80211.h	657;"	d
-WLAN_EID_MEASURE_REQUEST	include/ieee80211.h	656;"	d
-WLAN_EID_MMIE	include/ieee80211.h	674;"	d
-WLAN_EID_MOBILITY_DOMAIN	include/ieee80211.h	665;"	d
-WLAN_EID_OVERLAPPING_BSS_SCAN_PARAMS	include/ieee80211.h	673;"	d
-WLAN_EID_PWR_CAPABILITY	include/ieee80211.h	651;"	d
-WLAN_EID_PWR_CONSTRAINT	include/ieee80211.h	650;"	d
-WLAN_EID_QUITE	include/ieee80211.h	658;"	d
-WLAN_EID_RIC_DATA	include/ieee80211.h	668;"	d
-WLAN_EID_RSN	include/ieee80211.h	663;"	d
-WLAN_EID_SECONDARY_CHANNEL_OFFSET	include/ieee80211.h	670;"	d
-WLAN_EID_SSID	include/ieee80211.h	641;"	d
-WLAN_EID_SUPPORTED_CHANNELS	include/ieee80211.h	654;"	d
-WLAN_EID_SUPP_RATES	include/ieee80211.h	642;"	d
-WLAN_EID_TIM	include/ieee80211.h	646;"	d
-WLAN_EID_TIMEOUT_INTERVAL	include/ieee80211.h	667;"	d
-WLAN_EID_TPC_REPORT	include/ieee80211.h	653;"	d
-WLAN_EID_TPC_REQUEST	include/ieee80211.h	652;"	d
-WLAN_EID_VENDOR_SPECIFIC	include/ieee80211.h	675;"	d
-WLAN_EID_VHT_CAPABILITY	include/ieee80211.h	677;"	d
-WLAN_EID_VHT_OPERATION	include/ieee80211.h	678;"	d
-WLAN_EID_VHT_OP_MODE_NOTIFY	include/ieee80211.h	679;"	d
-WLAN_ETHADDR_LEN	include/wifi.h	32;"	d
-WLAN_ETHCONV_8021h	include/wifi.h	711;"	d
-WLAN_ETHCONV_ENCAP	include/wifi.h	709;"	d
-WLAN_ETHCONV_RFC1042	include/wifi.h	710;"	d
-WLAN_ETHHDR_LEN	include/wifi.h	31;"	d
-WLAN_ETHHDR_LEN	include/wifi.h	50;"	d
-WLAN_FC_GET_STYPE	include/ieee80211.h	586;"	d
-WLAN_FC_GET_TYPE	include/ieee80211.h	585;"	d
-WLAN_FIFO_MSK	include/hal_com_reg.h	1614;"	d
-WLAN_GET_SEQ_FRAG	include/ieee80211.h	590;"	d
-WLAN_GET_SEQ_SEQ	include/ieee80211.h	591;"	d
-WLAN_HDR_A3_LEN	include/wifi.h	38;"	d
-WLAN_HDR_A3_QOS_LEN	include/wifi.h	40;"	d
-WLAN_HDR_A4_LEN	include/wifi.h	39;"	d
-WLAN_HDR_A4_QOS_LEN	include/wifi.h	41;"	d
-WLAN_HEADER_WAPI_EXTENSION	include/rtw_wapi.h	/^} WLAN_HEADER_WAPI_EXTENSION, *PWLAN_HEADER_WAPI_EXTENSION;$/;"	t	typeref:struct:_WLAN_HEADER_WAPI_EXTENSION
-WLAN_HT_CAP_SM_PS_DISABLED	include/wifi.h	1013;"	d
-WLAN_HT_CAP_SM_PS_DYNAMIC	include/wifi.h	1011;"	d
-WLAN_HT_CAP_SM_PS_INVALID	include/wifi.h	1012;"	d
-WLAN_HT_CAP_SM_PS_STATIC	include/wifi.h	1010;"	d
-WLAN_IEEE_OUI_LEN	include/wifi.h	33;"	d
-WLAN_IOREG_BASE	include/hal_com_reg.h	1603;"	d
-WLAN_IOREG_DEVICE_ID	include/hal_com_reg.h	1624;"	d
-WLAN_IOREG_DOMAIN	include/gspi_ops.h	29;"	d
-WLAN_IOREG_MSK	include/hal_com_reg.h	1613;"	d
-WLAN_IOREG_OFFSET	include/gspi_ops.h	39;"	d
-WLAN_MAX_ETHFRM_LEN	include/wifi.h	49;"	d
-WLAN_MAX_VENDOR_IE_LEN	include/wifi.h	54;"	d
-WLAN_MAX_VENDOR_IE_NUM	include/wifi.h	55;"	d
-WLAN_MIN_ETHFRM_LEN	include/wifi.h	48;"	d
-WLAN_PHY_INFO	include/wlan_bssdef.h	/^} WLAN_PHY_INFO, *PWLAN_PHY_INFO;$/;"	t	typeref:struct:_WLAN_PHY_INFO
-WLAN_POWER_OFF	include/custom_gpio.h	/^	WLAN_POWER_OFF,$/;"	e	enum:cust_gpio_modes
-WLAN_POWER_ON	include/custom_gpio.h	/^	WLAN_POWER_ON,$/;"	e	enum:cust_gpio_modes
-WLAN_PWDN_OFF	include/custom_gpio.h	/^	WLAN_PWDN_OFF,$/;"	e	enum:cust_gpio_modes
-WLAN_PWDN_ON	include/custom_gpio.h	/^	WLAN_PWDN_ON,$/;"	e	enum:cust_gpio_modes
-WLAN_PWR_CFG	include/HalPwrSeqCmd.h	/^} WLAN_PWR_CFG, *PWLAN_PWR_CFG;$/;"	t	typeref:struct:_WL_PWR_CFG_
-WLAN_QC_GET_TID	include/ieee80211.h	588;"	d
-WLAN_REASON_ACTIVE_ROAM	include/ieee80211.h	636;"	d
-WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA	include/ieee80211.h	632;"	d
-WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA	include/ieee80211.h	633;"	d
-WLAN_REASON_DEAUTH_LEAVING	include/ieee80211.h	629;"	d
-WLAN_REASON_DISASSOC_AP_BUSY	include/ieee80211.h	631;"	d
-WLAN_REASON_DISASSOC_DUE_TO_INACTIVITY	include/ieee80211.h	630;"	d
-WLAN_REASON_DISASSOC_STA_HAS_LEFT	include/ieee80211.h	634;"	d
-WLAN_REASON_EXPIRATION_CHK	include/ieee80211.h	638;"	d
-WLAN_REASON_JOIN_WRONG_CHANNEL	include/ieee80211.h	637;"	d
-WLAN_REASON_PREV_AUTH_NOT_VALID	include/ieee80211.h	628;"	d
-WLAN_REASON_PWR_CAPABILITY_NOT_VALID	include/wifi.h	162;"	d
-WLAN_REASON_STA_REQ_ASSOC_WITHOUT_AUTH	include/ieee80211.h	635;"	d
-WLAN_REASON_SUPPORTED_CHANNEL_NOT_VALID	include/wifi.h	163;"	d
-WLAN_REASON_UNSPECIFIED	include/ieee80211.h	627;"	d
-WLAN_RX0FF_DEVICE_ID	include/hal_com_reg.h	1623;"	d
-WLAN_RX0FF_MSK	include/hal_com_reg.h	1615;"	d
-WLAN_SSID_MAXLEN	include/wifi.h	42;"	d
-WLAN_STA	hal/phydm/phydm.h	/^} WLAN_STA, *PRT_WLAN_STA;$/;"	t	typeref:struct:_WLAN_STA
-WLAN_STATUS_AKMP_NOT_VALID	include/wifi.h	234;"	d
-WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA	include/ieee80211.h	619;"	d
-WLAN_STATUS_ASSOC_DENIED_LISTEN_INT_TOO_LARGE	include/wifi.h	242;"	d
-WLAN_STATUS_ASSOC_DENIED_NOAGILITY	include/ieee80211.h	624;"	d
-WLAN_STATUS_ASSOC_DENIED_NOAGILITY	include/wifi.h	218;"	d
-WLAN_STATUS_ASSOC_DENIED_NOPBCC	include/ieee80211.h	623;"	d
-WLAN_STATUS_ASSOC_DENIED_NOPBCC	include/wifi.h	217;"	d
-WLAN_STATUS_ASSOC_DENIED_NOSHORT	include/ieee80211.h	622;"	d
-WLAN_STATUS_ASSOC_DENIED_NOSHORT	include/wifi.h	216;"	d
-WLAN_STATUS_ASSOC_DENIED_NO_DSSS_OFDM	include/wifi.h	226;"	d
-WLAN_STATUS_ASSOC_DENIED_NO_ER_PBCC	include/wifi.h	225;"	d
-WLAN_STATUS_ASSOC_DENIED_NO_SHORT_SLOT_TIME	include/wifi.h	224;"	d
-WLAN_STATUS_ASSOC_DENIED_RATES	include/ieee80211.h	620;"	d
-WLAN_STATUS_ASSOC_DENIED_UNSPEC	include/ieee80211.h	614;"	d
-WLAN_STATUS_ASSOC_REJECTED_TEMPORARILY	include/wifi.h	228;"	d
-WLAN_STATUS_AUTH_TIMEOUT	include/ieee80211.h	618;"	d
-WLAN_STATUS_CAPS_UNSUPPORTED	include/ieee80211.h	612;"	d
-WLAN_STATUS_CHALLENGE_FAIL	include/ieee80211.h	617;"	d
-WLAN_STATUS_CIPHER_REJECTED_PER_POLICY	include/wifi.h	237;"	d
-WLAN_STATUS_DEST_STA_NOT_PRESENT	include/wifi.h	240;"	d
-WLAN_STATUS_DEST_STA_NOT_QOS_STA	include/wifi.h	241;"	d
-WLAN_STATUS_DIRECT_LINK_NOT_ALLOWED	include/wifi.h	239;"	d
-WLAN_STATUS_GROUP_CIPHER_NOT_VALID	include/wifi.h	232;"	d
-WLAN_STATUS_INVALID_FTIE	include/wifi.h	247;"	d
-WLAN_STATUS_INVALID_FT_ACTION_FRAME_COUNT	include/wifi.h	244;"	d
-WLAN_STATUS_INVALID_IE	include/wifi.h	231;"	d
-WLAN_STATUS_INVALID_MDIE	include/wifi.h	246;"	d
-WLAN_STATUS_INVALID_PMKID	include/wifi.h	245;"	d
-WLAN_STATUS_INVALID_RSN_IE_CAPAB	include/wifi.h	236;"	d
-WLAN_STATUS_NOT_SUPPORTED_AUTH_ALG	include/ieee80211.h	615;"	d
-WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID	include/wifi.h	233;"	d
-WLAN_STATUS_PWR_CAPABILITY_NOT_VALID	include/wifi.h	221;"	d
-WLAN_STATUS_REASSOC_NO_ASSOC	include/ieee80211.h	613;"	d
-WLAN_STATUS_ROBUST_MGMT_FRAME_POLICY_VIOLATION	include/wifi.h	229;"	d
-WLAN_STATUS_SPEC_MGMT_REQUIRED	include/wifi.h	220;"	d
-WLAN_STATUS_SUCCESS	include/ieee80211.h	610;"	d
-WLAN_STATUS_SUPPORTED_CHANNEL_NOT_VALID	include/wifi.h	222;"	d
-WLAN_STATUS_TS_NOT_CREATED	include/wifi.h	238;"	d
-WLAN_STATUS_UNKNOWN_AUTH_TRANSACTION	include/ieee80211.h	616;"	d
-WLAN_STATUS_UNSPECIFIED_FAILURE	include/ieee80211.h	611;"	d
-WLAN_STATUS_UNSUPPORTED_RSN_IE_VERSION	include/wifi.h	235;"	d
-WLAN_STA_ASSOC	include/ieee80211.h	76;"	d
-WLAN_STA_AUTH	include/ieee80211.h	75;"	d
-WLAN_STA_AUTHORIZED	include/ieee80211.h	80;"	d
-WLAN_STA_HT	include/ieee80211.h	86;"	d
-WLAN_STA_MAYBE_WPS	include/ieee80211.h	88;"	d
-WLAN_STA_MFP	include/ieee80211.h	85;"	d
-WLAN_STA_NONERP	include/ieee80211.h	90;"	d
-WLAN_STA_PENDING_POLL	include/ieee80211.h	81;"	d
-WLAN_STA_PERM	include/ieee80211.h	79;"	d
-WLAN_STA_PREAUTH	include/ieee80211.h	83;"	d
-WLAN_STA_PS	include/ieee80211.h	77;"	d
-WLAN_STA_SHORT_PREAMBLE	include/ieee80211.h	82;"	d
-WLAN_STA_TIM	include/ieee80211.h	78;"	d
-WLAN_STA_VHT	include/ieee80211.h	89;"	d
-WLAN_STA_WME	include/ieee80211.h	84;"	d
-WLAN_STA_WPS	include/ieee80211.h	87;"	d
-WLAN_TX_EXQ_DEVICE_ID	include/hal_com_reg.h	1622;"	d
-WLAN_TX_HIQ_DEVICE_ID	include/hal_com_reg.h	1619;"	d
-WLAN_TX_LOQ_DEVICE_ID	include/hal_com_reg.h	1621;"	d
-WLAN_TX_MIQ_DEVICE_ID	include/hal_com_reg.h	1620;"	d
-WLAN_WMM_LEN	include/wifi.h	51;"	d
-WLRF_HWPDN_N	include/hal_com_reg.h	1295;"	d
-WL_FUNC_BIT_NUM	include/hal_com.h	333;"	d
-WL_FUNC_EN	include/hal_com_reg.h	1766;"	d
-WL_FUNC_FTM	include/hal_com.h	332;"	d
-WL_FUNC_MIRACAST	include/hal_com.h	330;"	d
-WL_FUNC_P2P	include/hal_com.h	329;"	d
-WL_FUNC_TDLS	include/hal_com.h	331;"	d
-WL_HWPDN_EN	include/hal_com_reg.h	1764;"	d
-WL_HWPDN_SL	include/hal_com_reg.h	1765;"	d
-WL_HWROF_EN	include/hal_com_reg.h	1767;"	d
-WME_ACTION_CODE_SETUP_REQUEST	include/ieee80211.h	1668;"	d
-WME_ACTION_CODE_SETUP_RESPONSE	include/ieee80211.h	1669;"	d
-WME_ACTION_CODE_TEARDOWN	include/ieee80211.h	1670;"	d
-WME_OUI_SUBTYPE_INFORMATION_ELEMENT	include/ieee80211.h	1663;"	d
-WME_OUI_SUBTYPE_PARAMETER_ELEMENT	include/ieee80211.h	1664;"	d
-WME_OUI_SUBTYPE_TSPEC_ELEMENT	include/ieee80211.h	1665;"	d
-WME_OUI_TYPE	include/ieee80211.h	1661;"	d
-WME_SETUP_RESPONSE_STATUS_ADMISSION_ACCEPTED	include/ieee80211.h	1672;"	d
-WME_SETUP_RESPONSE_STATUS_INVALID_PARAMETERS	include/ieee80211.h	1673;"	d
-WME_SETUP_RESPONSE_STATUS_REFUSED	include/ieee80211.h	1674;"	d
-WME_TSPEC_DIRECTION_BI_DIRECTIONAL	include/ieee80211.h	1678;"	d
-WME_TSPEC_DIRECTION_DOWNLINK	include/ieee80211.h	1677;"	d
-WME_TSPEC_DIRECTION_UPLINK	include/ieee80211.h	1676;"	d
-WME_VERSION	include/ieee80211.h	1666;"	d
-WMMEDCA_BE	hal/phydm/phydm.h	/^	u4Byte		WMMEDCA_BE;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-WMMOnAssocRsp	core/rtw_wlan_util.c	/^void WMMOnAssocRsp(_adapter *padapter)$/;"	f
-WMM_INFO_OUI	core/rtw_mlme_ext.c	/^unsigned char	WMM_INFO_OUI[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01};$/;"	v
-WMM_NORMAL_PAGE_NUM_HPQ_8188F	include/rtl8188f_hal.h	155;"	d
-WMM_NORMAL_PAGE_NUM_HPQ_8192E	include/rtl8192e_hal.h	176;"	d
-WMM_NORMAL_PAGE_NUM_HPQ_8703B	include/rtl8703b_hal.h	157;"	d
-WMM_NORMAL_PAGE_NUM_HPQ_8723B	include/rtl8723b_hal.h	157;"	d
-WMM_NORMAL_PAGE_NUM_HPQ_8723D	include/rtl8723d_hal.h	164;"	d
-WMM_NORMAL_PAGE_NUM_HPQ_8812	include/rtl8812a_hal.h	174;"	d
-WMM_NORMAL_PAGE_NUM_HPQ_8821	include/rtl8812a_hal.h	221;"	d
-WMM_NORMAL_PAGE_NUM_HPQ_88E	include/rtl8188e_hal.h	173;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_8188F	include/rtl8188f_hal.h	156;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_8192E	include/rtl8192e_hal.h	177;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_8703B	include/rtl8703b_hal.h	158;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_8723B	include/rtl8723b_hal.h	158;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_8723D	include/rtl8723d_hal.h	165;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_8812	include/rtl8812a_hal.h	175;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_8821	include/rtl8812a_hal.h	222;"	d
-WMM_NORMAL_PAGE_NUM_LPQ_88E	include/rtl8188e_hal.h	174;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_8188F	include/rtl8188f_hal.h	157;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_8192E	include/rtl8192e_hal.h	178;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_8703B	include/rtl8703b_hal.h	159;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_8723B	include/rtl8723b_hal.h	159;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_8723D	include/rtl8723d_hal.h	166;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_8812	include/rtl8812a_hal.h	176;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_8821	include/rtl8812a_hal.h	223;"	d
-WMM_NORMAL_PAGE_NUM_NPQ_88E	include/rtl8188e_hal.h	175;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_8188F	include/rtl8188f_hal.h	146;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_8703B	include/rtl8703b_hal.h	148;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_8723B	include/rtl8723b_hal.h	148;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_8723D	include/rtl8723d_hal.h	154;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_8812	include/rtl8812a_hal.h	166;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_8814A	include/rtl8814a_hal.h	174;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_8821	include/rtl8812a_hal.h	213;"	d
-WMM_NORMAL_TX_PAGE_BOUNDARY_88E	include/rtl8188e_hal.h	164;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8188F	include/rtl8188f_hal.h	145;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8703B	include/rtl8703b_hal.h	147;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723B	include/rtl8723b_hal.h	147;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8723D	include/rtl8723d_hal.h	153;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8812	include/rtl8812a_hal.h	165;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8814A	include/rtl8814a_hal.h	173;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_8821	include/rtl8812a_hal.h	212;"	d
-WMM_NORMAL_TX_TOTAL_PAGE_NUMBER_88E	include/rtl8188e_hal.h	163;"	d
-WMM_OUI	core/rtw_mlme_ext.c	/^unsigned char WMM_OUI[] = {0x00, 0x50, 0xf2, 0x02};$/;"	v
-WMM_OUI_SUBTYPE_INFORMATION_ELEMENT	include/ieee80211_ext.h	28;"	d
-WMM_OUI_SUBTYPE_PARAMETER_ELEMENT	include/ieee80211_ext.h	29;"	d
-WMM_OUI_SUBTYPE_TSPEC_ELEMENT	include/ieee80211_ext.h	30;"	d
-WMM_OUI_TYPE	include/ieee80211_ext.h	27;"	d
-WMM_PARA_OUI	core/rtw_mlme_ext.c	/^unsigned char	WMM_PARA_OUI[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};$/;"	v
-WMM_VERSION	include/ieee80211_ext.h	31;"	d
-WMM_XMIT_THRESHOLD	os_dep/linux/xmit_linux.c	193;"	d	file:
-WMM_enable	include/rtw_mlme_ext.h	/^	u8	WMM_enable;$/;"	m	struct:mlme_ext_info
-WMM_para_element	include/wifi.h	/^struct WMM_para_element {$/;"	s
-WMM_param	include/rtw_mlme_ext.h	/^	struct WMM_para_element	WMM_param;$/;"	m	struct:mlme_ext_info	typeref:struct:mlme_ext_info::WMM_para_element
-WMM_param_handler	core/rtw_wlan_util.c	/^int WMM_param_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs	pIE)$/;"	f
-WORK_STATE_CALLOUT_PENDING	include/osdep_service_bsd.h	/^        WORK_STATE_CALLOUT_PENDING = 1,$/;"	e	enum:work_state
-WORK_STATE_TASK_PENDING	include/osdep_service_bsd.h	/^        WORK_STATE_TASK_PENDING = 2,$/;"	e	enum:work_state
-WORK_STATE_UNSET	include/osdep_service_bsd.h	/^        WORK_STATE_UNSET = 0,$/;"	e	enum:work_state
-WORK_STATE_WORK_CANCELLED	include/osdep_service_bsd.h	/^        WORK_STATE_WORK_CANCELLED = 3        $/;"	e	enum:work_state
-WOWLAN_AP_DISABLE	include/hal_intf.h	/^	WOWLAN_AP_DISABLE		= 3,$/;"	e	enum:_wowlan_subcode
-WOWLAN_AP_ENABLE	include/hal_intf.h	/^	WOWLAN_AP_ENABLE		= 2,$/;"	e	enum:_wowlan_subcode
-WOWLAN_DISABLE	include/hal_intf.h	/^	WOWLAN_DISABLE			= 1,$/;"	e	enum:_wowlan_subcode
-WOWLAN_ENABLE	include/hal_intf.h	/^	WOWLAN_ENABLE			= 0,$/;"	e	enum:_wowlan_subcode
-WOWLAN_PAGE_NUM_8188F	include/rtl8188f_hal.h	128;"	d
-WOWLAN_PAGE_NUM_8188F	include/rtl8188f_hal.h	130;"	d
-WOWLAN_PAGE_NUM_8188F	include/rtl8188f_hal.h	134;"	d
-WOWLAN_PAGE_NUM_8188F	include/rtl8188f_hal.h	135;"	d
-WOWLAN_PAGE_NUM_8192E	include/rtl8192e_hal.h	136;"	d
-WOWLAN_PAGE_NUM_8192E	include/rtl8192e_hal.h	138;"	d
-WOWLAN_PAGE_NUM_8192E	include/rtl8192e_hal.h	142;"	d
-WOWLAN_PAGE_NUM_8192E	include/rtl8192e_hal.h	143;"	d
-WOWLAN_PAGE_NUM_8703B	include/rtl8703b_hal.h	130;"	d
-WOWLAN_PAGE_NUM_8703B	include/rtl8703b_hal.h	132;"	d
-WOWLAN_PAGE_NUM_8703B	include/rtl8703b_hal.h	136;"	d
-WOWLAN_PAGE_NUM_8703B	include/rtl8703b_hal.h	137;"	d
-WOWLAN_PAGE_NUM_8723B	include/rtl8723b_hal.h	130;"	d
-WOWLAN_PAGE_NUM_8723B	include/rtl8723b_hal.h	132;"	d
-WOWLAN_PAGE_NUM_8723B	include/rtl8723b_hal.h	136;"	d
-WOWLAN_PAGE_NUM_8723B	include/rtl8723b_hal.h	137;"	d
-WOWLAN_PAGE_NUM_8723D	include/rtl8723d_hal.h	135;"	d
-WOWLAN_PAGE_NUM_8723D	include/rtl8723d_hal.h	137;"	d
-WOWLAN_PAGE_NUM_8723D	include/rtl8723d_hal.h	141;"	d
-WOWLAN_PAGE_NUM_8723D	include/rtl8723d_hal.h	142;"	d
-WOWLAN_PAGE_NUM_8812	include/rtl8812a_hal.h	148;"	d
-WOWLAN_PAGE_NUM_8812	include/rtl8812a_hal.h	150;"	d
-WOWLAN_PAGE_NUM_8814	include/rtl8814a_hal.h	151;"	d
-WOWLAN_PAGE_NUM_8814	include/rtl8814a_hal.h	153;"	d
-WOWLAN_PAGE_NUM_8821	include/rtl8812a_hal.h	203;"	d
-WOWLAN_PAGE_NUM_8821	include/rtl8812a_hal.h	205;"	d
-WOWLAN_PAGE_NUM_88E	include/rtl8188e_hal.h	145;"	d
-WOWLAN_PAGE_NUM_88E	include/rtl8188e_hal.h	147;"	d
-WOWLAN_PATTERN_CLEAN	include/hal_intf.h	/^	WOWLAN_PATTERN_CLEAN		= 4$/;"	e	enum:_wowlan_subcode
-WOW_MAGIC	include/hal_com_reg.h	838;"	d
-WOW_PMEN	include/hal_com_reg.h	836;"	d
-WOW_UWF	include/hal_com_reg.h	839;"	d
-WOW_WOMEN	include/hal_com_reg.h	837;"	d
-WPA_AUTH_KEY_MGMT_NONE	core/rtw_ieee80211.c	/^u8 WPA_AUTH_KEY_MGMT_NONE[] = { 0x00, 0x50, 0xf2, 0 };$/;"	v
-WPA_AUTH_KEY_MGMT_PSK_OVER_802_1X	core/rtw_ieee80211.c	/^u8 WPA_AUTH_KEY_MGMT_PSK_OVER_802_1X[] = { 0x00, 0x50, 0xf2, 2 };$/;"	v
-WPA_AUTH_KEY_MGMT_UNSPEC_802_1X	core/rtw_ieee80211.c	/^u8 WPA_AUTH_KEY_MGMT_UNSPEC_802_1X[] = { 0x00, 0x50, 0xf2, 1 };$/;"	v
-WPA_CAPABILITY_MGMT_FRAME_PROTECTION	include/ieee80211_ext.h	44;"	d
-WPA_CAPABILITY_PEERKEY_ENABLED	include/ieee80211_ext.h	45;"	d
-WPA_CAPABILITY_PREAUTH	include/ieee80211_ext.h	43;"	d
-WPA_CIPHER_CCMP	include/ieee80211.h	128;"	d
-WPA_CIPHER_NONE	include/ieee80211.h	124;"	d
-WPA_CIPHER_SUITE_CCMP	core/rtw_ieee80211.c	/^u8 WPA_CIPHER_SUITE_CCMP[] = { 0x00, 0x50, 0xf2, 4 };$/;"	v
-WPA_CIPHER_SUITE_NONE	core/rtw_ieee80211.c	/^u8 WPA_CIPHER_SUITE_NONE[] = { 0x00, 0x50, 0xf2, 0 };$/;"	v
-WPA_CIPHER_SUITE_TKIP	core/rtw_ieee80211.c	/^u8 WPA_CIPHER_SUITE_TKIP[] = { 0x00, 0x50, 0xf2, 2 };$/;"	v
-WPA_CIPHER_SUITE_WEP104	core/rtw_ieee80211.c	/^u8 WPA_CIPHER_SUITE_WEP104[] = { 0x00, 0x50, 0xf2, 5 };$/;"	v
-WPA_CIPHER_SUITE_WEP40	core/rtw_ieee80211.c	/^u8 WPA_CIPHER_SUITE_WEP40[] = { 0x00, 0x50, 0xf2, 1 };$/;"	v
-WPA_CIPHER_SUITE_WRAP	core/rtw_ieee80211.c	/^u8 WPA_CIPHER_SUITE_WRAP[] = { 0x00, 0x50, 0xf2, 3 };$/;"	v
-WPA_CIPHER_TKIP	include/ieee80211.h	127;"	d
-WPA_CIPHER_WEP104	include/ieee80211.h	126;"	d
-WPA_CIPHER_WEP40	include/ieee80211.h	125;"	d
-WPA_GET_BE32	include/rtw_security.h	380;"	d
-WPA_KEY_MGMT_IEEE8021X	include/ieee80211_ext.h	36;"	d
-WPA_KEY_MGMT_IEEE8021X_NO_WPA	include/ieee80211_ext.h	39;"	d
-WPA_KEY_MGMT_NONE	include/ieee80211_ext.h	38;"	d
-WPA_KEY_MGMT_PSK	include/ieee80211_ext.h	37;"	d
-WPA_KEY_MGMT_WPA_NONE	include/ieee80211_ext.h	40;"	d
-WPA_NONCE_LEN	include/rtw_tdls.h	58;"	d
-WPA_PROTO_RSN	include/ieee80211_ext.h	34;"	d
-WPA_PROTO_WPA	include/ieee80211_ext.h	33;"	d
-WPA_PUT_BE32	include/ieee80211_ext.h	135;"	d
-WPA_PUT_BE32	include/rtw_security.h	389;"	d
-WPA_PUT_BE64	include/rtw_security.h	397;"	d
-WPA_PUT_LE16	include/ieee80211_ext.h	129;"	d
-WPA_PUT_LE16	include/rtw_security.h	383;"	d
-WPA_PUT_LE32	include/ieee80211_ext.h	143;"	d
-WPA_SELECTOR_LEN	include/ieee80211.h	132;"	d
-WPA_TKIP_CIPHER	core/rtw_mlme_ext.c	/^unsigned char WPA_TKIP_CIPHER[4] = {0x00, 0x50, 0xf2, 0x02};$/;"	v
-WPP_SOFTWARE_TRACE	hal/btc/Mp_Precomp.h	42;"	d
-WPSOUI	include/wifi.h	1049;"	d
-WPS_ASSOC_STATE_ASSOCIATION_FAILURE	include/wifi.h	1133;"	d
-WPS_ASSOC_STATE_CONFIGURATION_FAILURE	include/wifi.h	1132;"	d
-WPS_ASSOC_STATE_CONNECTION_SUCCESS	include/wifi.h	1131;"	d
-WPS_ASSOC_STATE_IP_FAILURE	include/wifi.h	1134;"	d
-WPS_ASSOC_STATE_NOT_ASSOCIATED	include/wifi.h	1130;"	d
-WPS_ATTR_ASSOCIATION_STATE	include/wifi.h	1066;"	d
-WPS_ATTR_CONFIG_ERROR	include/wifi.h	1067;"	d
-WPS_ATTR_CONF_METHOD	include/wifi.h	1062;"	d
-WPS_ATTR_DEVICE_NAME	include/wifi.h	1061;"	d
-WPS_ATTR_DEVICE_PWID	include/wifi.h	1064;"	d
-WPS_ATTR_MANUFACTURER	include/wifi.h	1055;"	d
-WPS_ATTR_MODEL_NAME	include/wifi.h	1056;"	d
-WPS_ATTR_MODEL_NUMBER	include/wifi.h	1057;"	d
-WPS_ATTR_PRIMARY_DEV_TYPE	include/wifi.h	1059;"	d
-WPS_ATTR_REQUEST_TYPE	include/wifi.h	1065;"	d
-WPS_ATTR_RESP_TYPE	include/wifi.h	1053;"	d
-WPS_ATTR_RF_BANDS	include/wifi.h	1063;"	d
-WPS_ATTR_SEC_DEV_TYPE_LIST	include/wifi.h	1060;"	d
-WPS_ATTR_SELECTED_REGISTRAR	include/wifi.h	1069;"	d
-WPS_ATTR_SERIAL_NUMBER	include/wifi.h	1058;"	d
-WPS_ATTR_SIMPLE_CONF_STATE	include/wifi.h	1052;"	d
-WPS_ATTR_UUID_E	include/wifi.h	1054;"	d
-WPS_ATTR_VENDOR_EXT	include/wifi.h	1068;"	d
-WPS_ATTR_VER1	include/wifi.h	1051;"	d
-WPS_CM_DISPLYA	include/wifi.h	1250;"	d
-WPS_CM_EXTERNAL_NFC_TOKEN	include/wifi.h	1251;"	d
-WPS_CM_HW_PUHS_BUTTON	include/wifi.h	1257;"	d
-WPS_CM_INTEGRATED_NFC_TOKEN	include/wifi.h	1252;"	d
-WPS_CM_KEYPAD	include/wifi.h	1255;"	d
-WPS_CM_LABEL	include/wifi.h	1249;"	d
-WPS_CM_LCD_DISPLAY_PIN	include/wifi.h	1259;"	d
-WPS_CM_NFC_INTERFACE	include/wifi.h	1253;"	d
-WPS_CM_NONE	include/wifi.h	1248;"	d
-WPS_CM_PUSH_BUTTON	include/wifi.h	1254;"	d
-WPS_CM_SW_DISPLAY_PIN	include/wifi.h	1258;"	d
-WPS_CM_SW_PUHS_BUTTON	include/wifi.h	1256;"	d
-WPS_CONFIG_METHOD_DISPLAY	include/wifi.h	1097;"	d
-WPS_CONFIG_METHOD_ETHERNET	include/wifi.h	1095;"	d
-WPS_CONFIG_METHOD_E_NFC	include/wifi.h	1098;"	d
-WPS_CONFIG_METHOD_FLASH	include/wifi.h	1094;"	d
-WPS_CONFIG_METHOD_I_NFC	include/wifi.h	1099;"	d
-WPS_CONFIG_METHOD_KEYPAD	include/wifi.h	1102;"	d
-WPS_CONFIG_METHOD_LABEL	include/wifi.h	1096;"	d
-WPS_CONFIG_METHOD_NFC	include/wifi.h	1100;"	d
-WPS_CONFIG_METHOD_PBC	include/wifi.h	1101;"	d
-WPS_CONFIG_METHOD_PDISPLAY	include/wifi.h	1106;"	d
-WPS_CONFIG_METHOD_PPBC	include/wifi.h	1104;"	d
-WPS_CONFIG_METHOD_VDISPLAY	include/wifi.h	1105;"	d
-WPS_CONFIG_METHOD_VPBC	include/wifi.h	1103;"	d
-WPS_DPID_MACHINE_SPEC	include/wifi.h	1120;"	d
-WPS_DPID_PBC	include/wifi.h	1122;"	d
-WPS_DPID_PIN	include/wifi.h	1118;"	d
-WPS_DPID_REGISTRAR_SPEC	include/wifi.h	1123;"	d
-WPS_DPID_REKEY	include/wifi.h	1121;"	d
-WPS_DPID_USER_SPEC	include/wifi.h	1119;"	d
-WPS_MAX_DEVICE_NAME_LEN	include/wifi.h	1072;"	d
-WPS_OUI	core/rtw_mlme_ext.c	/^unsigned char	WPS_OUI[] = {0x00, 0x50, 0xf2, 0x04};$/;"	v
-WPS_PDT_CID_DISPLAYS	include/wifi.h	1109;"	d
-WPS_PDT_CID_MULIT_MEDIA	include/wifi.h	1110;"	d
-WPS_PDT_CID_RTK_WIDI	include/wifi.h	1111;"	d
-WPS_PDT_SCID_MEDIA_SERVER	include/wifi.h	1114;"	d
-WPS_PDT_SCID_RTK_DMP	include/wifi.h	1115;"	d
-WPS_REQ_TYPE_ENROLLEE_INFO_ONLY	include/wifi.h	1075;"	d
-WPS_REQ_TYPE_ENROLLEE_OPEN_8021X	include/wifi.h	1076;"	d
-WPS_REQ_TYPE_REGISTRAR	include/wifi.h	1077;"	d
-WPS_REQ_TYPE_WLAN_MANAGER_REGISTRAR	include/wifi.h	1078;"	d
-WPS_RESPONSE_TYPE_8021X	include/wifi.h	1082;"	d
-WPS_RESPONSE_TYPE_AP	include/wifi.h	1084;"	d
-WPS_RESPONSE_TYPE_INFO_ONLY	include/wifi.h	1081;"	d
-WPS_RESPONSE_TYPE_REGISTRAR	include/wifi.h	1083;"	d
-WPS_RF_BANDS_2_4_GHZ	include/wifi.h	1126;"	d
-WPS_RF_BANDS_5_GHZ	include/wifi.h	1127;"	d
-WPS_VERSION_1	include/wifi.h	1091;"	d
-WPS_WSC_STATE_CONFIG	include/wifi.h	1088;"	d
-WPS_WSC_STATE_NOT_CONFIG	include/wifi.h	1087;"	d
-WRITE_REG	include/rtw_mp.h	/^	WRITE_REG = 1,$/;"	e	enum:__anon65
-WRITE_RF	include/rtw_mp.h	/^	WRITE_RF,$/;"	e	enum:__anon65
-WaitC2Hevent	core/rtw_bt_mp.c	/^u32 WaitC2Hevent(PADAPTER pAdapter, u8 *C2H_event, u32 delay_time)$/;"	f
-WapiCheckPnInSwDecrypt	core/rtw_wapi_sms4.c	/^u8 WapiCheckPnInSwDecrypt($/;"	f
-WapiComparePN	core/rtw_wapi.c	/^u32 WapiComparePN(u8 *PN1, u8 *PN2)$/;"	f
-WapiFreeAllStaInfo	core/rtw_wapi.c	/^void WapiFreeAllStaInfo(_adapter *padapter)$/;"	f
-WapiGetEntryForCamClear	core/rtw_wapi.c	/^u8 WapiGetEntryForCamClear(_adapter *padapter, u8 *pPeerMac, u8 keyid, u8 IsMsk)$/;"	f
-WapiGetEntryForCamWrite	core/rtw_wapi.c	/^WapiGetEntryForCamWrite(_adapter *padapter, u8 *pMacAddr, u8 KID, BOOLEAN IsMsk)$/;"	f
-WapiGetLastRxUnicastPNForQoSData	core/rtw_wapi_sms4.c	/^void WapiGetLastRxUnicastPNForQoSData($/;"	f
-WapiIncreasePN	core/rtw_wapi_sms4.c	/^u8 WapiIncreasePN(u8 *PN, u8 AddCount)$/;"	f
-WapiResetAllCamEntry	core/rtw_wapi.c	/^WapiResetAllCamEntry(_adapter *padapter)$/;"	f
-WapiSMS4CalculateMic	core/rtw_wapi_sms4.c	/^void WapiSMS4CalculateMic(u8 *Key, u8 *IV, u8 *Input1, u8 Input1Length,$/;"	f
-WapiSMS4Cryption	core/rtw_wapi_sms4.c	/^void WapiSMS4Cryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,$/;"	f
-WapiSMS4Decryption	core/rtw_wapi_sms4.c	/^void WapiSMS4Decryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,$/;"	f
-WapiSMS4Encryption	core/rtw_wapi_sms4.c	/^void WapiSMS4Encryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,$/;"	f
-WapiSetIE	core/rtw_wapi.c	/^void WapiSetIE(_adapter *padapter)$/;"	f
-WapiSetLastRxUnicastPNForQoSData	core/rtw_wapi_sms4.c	/^void WapiSetLastRxUnicastPNForQoSData($/;"	f
-WapiSrcAddr	include/rtw_recv.h	/^	u8 WapiSrcAddr[6];$/;"	m	struct:recv_frame_hdr
-WapiSupport	include/drv_types.h	/^	u8	WapiSupport;$/;"	m	struct:_ADAPTER
-WapiTempPN	include/rtw_recv.h	/^	u8 WapiTempPN[16];$/;"	m	struct:recv_frame_hdr
-WapiWriteOneCamEntry	core/rtw_wapi.c	/^u8 WapiWriteOneCamEntry($/;"	f
-WiFiNavUpperUs	include/wifi.h	67;"	d
-Wifi_Error_Status	include/rtw_sreset.h	/^	u8	Wifi_Error_Status;$/;"	m	struct:sreset_priv
-WirelessMode	hal/phydm/phydm_beamforming.h	/^	WIRELESS_MODE				WirelessMode;$/;"	m	struct:_RT_BEAMFORM_STAINFO
-WordUnit	include/rtw_efuse.h	/^	const u16  WordUnit;$/;"	m	struct:_EFUSE_HAL
-Wps_Config	include/rtw_cmd.h	/^	u8 Wps_Config[2];$/;"	m	struct:P2P_WoWlan_Offload_t
-WriteBE1Byte	include/basic_types.h	221;"	d
-WriteBE2Byte	include/basic_types.h	220;"	d
-WriteBE4Byte	include/basic_types.h	219;"	d
-WriteEnable	include/rtw_io.h	/^	u32		WriteEnable:1;		\/* 0:read, 1:write *\/$/;"	m	struct:reg_protocol_rd
-WriteEnable	include/rtw_io.h	/^	u32		WriteEnable:1;		\/* 0:read, 1:write *\/$/;"	m	struct:reg_protocol_wt
-WriteLE1Byte	include/basic_types.h	214;"	d
-WriteLE2Byte	include/basic_types.h	213;"	d
-WriteLE4Byte	include/basic_types.h	212;"	d
-XCLK_VLD	include/hal_com_reg.h	1253;"	d
-XMITBUF_ALIGN_SZ	include/rtw_xmit.h	65;"	d
-XMITBUF_ALIGN_SZ	include/rtw_xmit.h	68;"	d
-XMITBUF_ALIGN_SZ	include/rtw_xmit.h	71;"	d
-XMITBUF_ALIGN_SZ	include/rtw_xmit.h	73;"	d
-XMITBUF_CMD	include/rtw_xmit.h	/^	XMITBUF_CMD = 2,$/;"	e	enum:__anon5
-XMITBUF_DATA	include/rtw_xmit.h	/^	XMITBUF_DATA = 0,$/;"	e	enum:__anon5
-XMITBUF_MGNT	include/rtw_xmit.h	/^	XMITBUF_MGNT = 1,$/;"	e	enum:__anon5
-XMIT_ALIVE	include/rtw_pwrctrl.h	39;"	d
-XMIT_BE_QUEUE	include/rtw_xmit.h	99;"	d
-XMIT_BK_QUEUE	include/rtw_xmit.h	100;"	d
-XMIT_VI_QUEUE	include/rtw_xmit.h	98;"	d
-XMIT_VO_QUEUE	include/rtw_xmit.h	97;"	d
-XOP_BTCK	include/hal_com_reg.h	1195;"	d
-XtalOffset	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte	XtalOffset;$/;"	m	struct:ODM_RF_Calibration_Structure
-XtalOffset	hal/phydm/phydm_powertracking_win.h	/^	s1Byte	XtalOffset;$/;"	m	struct:ODM_RF_Calibration_Structure
-XtalOffsetLast	hal/phydm/phydm_powertracking_ce.h	/^	s1Byte	XtalOffsetLast;$/;"	m	struct:ODM_RF_Calibration_Structure
-XtalOffsetLast	hal/phydm/phydm_powertracking_win.h	/^	s1Byte	XtalOffsetLast;$/;"	m	struct:ODM_RF_Calibration_Structure
-_11M_RATE_	include/rtw_mlme_ext.h	67;"	d
-_12M_RATE_	include/rtw_mlme_ext.h	70;"	d
-_18M_RATE_	include/rtw_mlme_ext.h	71;"	d
-_1M_RATE_	include/rtw_mlme_ext.h	64;"	d
-_1x	include/rtw_cmd.h	/^	u8 _1x;   \/* 0: PSK, 1: TLS *\/$/;"	m	struct:setauth_parm
-_24M_RATE_	include/rtw_mlme_ext.h	72;"	d
-_2M_RATE_	include/rtw_mlme_ext.h	65;"	d
-_36M_RATE_	include/rtw_mlme_ext.h	73;"	d
-_48M_RATE_	include/rtw_mlme_ext.h	74;"	d
-_54M_RATE_	include/rtw_mlme_ext.h	75;"	d
-_5M_RATE_	include/rtw_mlme_ext.h	66;"	d
-_6M_RATE_	include/rtw_mlme_ext.h	68;"	d
-_8051Reset8723	hal/rtl8723d/rtl8723d_hal_init.c	/^void _8051Reset8723(PADAPTER padapter)$/;"	f
-_9M_RATE_	include/rtw_mlme_ext.h	69;"	d
-_ACKCTSLNG_	include/wifi.h	561;"	d
-_ACS_	hal/phydm/phydm_acs.h	/^typedef struct _ACS_$/;"	s
-_ACS_OP	include/hal_data.h	/^typedef enum _ACS_OP {$/;"	g
-_ACS_STATE	include/hal_data.h	/^typedef enum _ACS_STATE {$/;"	g
-_ADAPTER	hal/phydm/phydm.h	/^typedef	struct _ADAPTER {$/;"	s
-_ADAPTER	include/drv_types.h	/^struct _ADAPTER {$/;"	s
-_ADAPTER_TYPE	include/drv_types.h	/^enum _ADAPTER_TYPE {$/;"	g
-_ADAPTIVITY_STATISTICS	hal/phydm/phydm_adaptivity.h	/^typedef struct _ADAPTIVITY_STATISTICS {$/;"	s
-_AES_	include/rtw_security.h	28;"	d
-_AES_IV_LEN_	include/rtw_security.h	274;"	d
-_ANTENNA_PATH	include/hal_phy.h	/^typedef enum _ANTENNA_PATH {$/;"	g
-_ANT_DETECTED_INFO	hal/phydm/phydm_antdect.h	/^typedef struct _ANT_DETECTED_INFO{$/;"	s
-_ANT_DIV_TYPE	hal/phydm/phydm_antdiv.h	/^typedef enum _ANT_DIV_TYPE$/;"	g
-_ASOCREQ_IE_OFFSET_	include/wifi.h	564;"	d
-_ASOCRSP_IE_OFFSET_	include/wifi.h	565;"	d
-_ASOC_ID_	include/wifi.h	702;"	d
-_AUTH_ALGM_NUM_	include/wifi.h	695;"	d
-_AUTH_IE_OFFSET_	include/wifi.h	570;"	d
-_AUTH_SEQ_NUM_	include/wifi.h	696;"	d
-_BAND_TYPE	include/rtw_rf.h	/^typedef enum _BAND_TYPE {$/;"	g
-_BASEBAND_CONFIG_PHY_REG_PG_VALUE_TYPE	hal/phydm/phydm.h	/^typedef enum _BASEBAND_CONFIG_PHY_REG_PG_VALUE_TYPE {$/;"	g
-_BBTurnOnBlock	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _BBTurnOnBlock(PADAPTER padapter)$/;"	f	file:
-_BB_INIT_REGISTER	include/hal_data.h	/^typedef struct _BB_INIT_REGISTER {$/;"	s
-_BB_REGISTER_DEFINITION	include/hal_com_phycfg.h	/^typedef struct _BB_REGISTER_DEFINITION {$/;"	s
-_BEACON_IE_OFFSET_	include/wifi.h	572;"	d
-_BEACON_ITERVAL_	include/wifi.h	697;"	d
-_BEAMFORMING_CAP	hal/phydm/phydm_beamforming.h	/^typedef enum _BEAMFORMING_CAP {$/;"	g
-_BEAMFORMING_CAP	include/rtw_beamforming.h	/^typedef enum _BEAMFORMING_CAP {$/;"	g
-_BEAMFORMING_ENTRY_STATE	hal/phydm/phydm_beamforming.h	/^typedef enum _BEAMFORMING_ENTRY_STATE {$/;"	g
-_BEAMFORMING_ENTRY_STATE	include/rtw_beamforming.h	/^typedef enum _BEAMFORMING_ENTRY_STATE {$/;"	g
-_BEAMFORMING_NOTIFY_STATE	hal/phydm/phydm_beamforming.h	/^typedef enum _BEAMFORMING_NOTIFY_STATE {$/;"	g
-_BEAMFORMING_STATE	include/rtw_beamforming.h	/^typedef enum _BEAMFORMING_STATE {$/;"	g
-_BEAMFORM_ENTRY_HW_STATE	include/rtw_beamforming.h	/^enum _BEAMFORM_ENTRY_HW_STATE {$/;"	g
-_BF_DIV_COEX_	hal/phydm/phydm_antdiv.h	/^typedef struct _BF_DIV_COEX_$/;"	s
-_BIP_	include/rtw_security.h	33;"	d
-_BSSIDInfo	include/rtw_ioctl_set.h	/^typedef struct _BSSIDInfo {$/;"	s
-_BTCOEX_CSR	hal/btc/HalBtc8821aCsr2Ant.c	21;"	d	file:
-_BTCOEX_SUSPEND_STATE	include/rtw_btcoex.h	/^typedef enum _BTCOEX_SUSPEND_STATE {$/;"	g
-_BTC_ANTENNA_POS	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_ANTENNA_POS {$/;"	g
-_BTC_ANT_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_ANT_TYPE {$/;"	g
-_BTC_BT_OFFON	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_BT_OFFON {$/;"	g
-_BTC_BT_REG_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_BT_REG_TYPE {$/;"	g
-_BTC_CHIP_INTERFACE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_CHIP_INTERFACE {$/;"	g
-_BTC_CHIP_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_CHIP_TYPE {$/;"	g
-_BTC_DBG_DISP_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_DBG_DISP_TYPE {$/;"	g
-_BTC_DBG_OPCODE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_DBG_OPCODE {$/;"	g
-_BTC_GET_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_GET_TYPE {$/;"	g
-_BTC_IOT_PEER	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_IOT_PEER {$/;"	g
-_BTC_MSG_COMP_TYPE	hal/btc/Mp_Precomp.h	/^typedef enum _BTC_MSG_COMP_TYPE{$/;"	g
-_BTC_NOTIFY_TYPE_ASSOCIATE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_ASSOCIATE {$/;"	g
-_BTC_NOTIFY_TYPE_IPS	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_IPS {$/;"	g
-_BTC_NOTIFY_TYPE_LPS	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_LPS {$/;"	g
-_BTC_NOTIFY_TYPE_MEDIA_STATUS	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_MEDIA_STATUS {$/;"	g
-_BTC_NOTIFY_TYPE_SCAN	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_SCAN {$/;"	g
-_BTC_NOTIFY_TYPE_SPECIFIC_PACKET	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_SPECIFIC_PACKET {$/;"	g
-_BTC_NOTIFY_TYPE_STACK_OPERATION	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_STACK_OPERATION {$/;"	g
-_BTC_NOTIFY_TYPE_SWITCHBAND	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_NOTIFY_TYPE_SWITCHBAND {$/;"	g
-_BTC_OFFLOAD	hal/btc/HalBtcOutSrc.h	/^typedef struct _BTC_OFFLOAD {$/;"	s
-_BTC_POWERSAVE_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_POWERSAVE_TYPE {$/;"	g
-_BTC_RSSI_STATE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_RSSI_STATE {$/;"	g
-_BTC_SET_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_SET_TYPE {$/;"	g
-_BTC_VENDOR	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_VENDOR {$/;"	g
-_BTC_WIFI_BW_MODE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_WIFI_BW_MODE {$/;"	g
-_BTC_WIFI_COEX_STATE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_WIFI_COEX_STATE {$/;"	g
-_BTC_WIFI_PNP	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_WIFI_PNP {$/;"	g
-_BTC_WIFI_ROLE	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_WIFI_ROLE {$/;"	g
-_BTC_WIFI_TRAFFIC_DIR	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_WIFI_TRAFFIC_DIR {$/;"	g
-_BTC_WIRELESS_FREQ	hal/btc/HalBtcOutSrc.h	/^typedef enum _BTC_WIRELESS_FREQ {$/;"	g
-_BT_8188C_2ANT_BT_STATUS	hal/btc/HalBtc8188c2Ant.h	/^typedef enum _BT_8188C_2ANT_BT_STATUS{$/;"	g
-_BT_8188C_2ANT_COEX_ALGO	hal/btc/HalBtc8188c2Ant.h	/^typedef enum _BT_8188C_2ANT_COEX_ALGO{$/;"	g
-_BT_8192D_2ANT_BT_STATUS	hal/btc/HalBtc8192d2Ant.h	/^typedef enum _BT_8192D_2ANT_BT_STATUS{$/;"	g
-_BT_8192D_2ANT_COEX_ALGO	hal/btc/HalBtc8192d2Ant.h	/^typedef enum _BT_8192D_2ANT_COEX_ALGO{$/;"	g
-_BT_8723A_1ANT_BT_STATUS	hal/btc/HalBtc8723a1Ant.h	/^typedef enum _BT_8723A_1ANT_BT_STATUS{$/;"	g
-_BT_8723A_1ANT_COEX_ALGO	hal/btc/HalBtc8723a1Ant.h	/^typedef enum _BT_8723A_1ANT_COEX_ALGO{$/;"	g
-_BT_8723A_2ANT_BT_STATUS	hal/btc/HalBtc8723a2Ant.h	/^typedef enum _BT_8723A_2ANT_BT_STATUS{$/;"	g
-_BT_8723A_2ANT_COEX_ALGO	hal/btc/HalBtc8723a2Ant.h	/^typedef enum _BT_8723A_2ANT_COEX_ALGO{$/;"	g
-_BT_AFH_MAP_TYPE	include/rtw_bt_mp.h	/^typedef enum _BT_AFH_MAP_TYPE {$/;"	g
-_BT_Ant_NUM	include/hal_pg.h	/^typedef	enum _BT_Ant_NUM {$/;"	g
-_BT_COEXIST	include/hal_btcoex.h	/^typedef struct _BT_COEXIST {$/;"	s
-_BT_CONNECT_TYPE	include/rtw_btcoex.h	/^typedef enum _BT_CONNECT_TYPE {$/;"	g
-_BT_CTRL_OPCODE_LOWER	include/rtw_bt_mp.h	/^typedef enum _BT_CTRL_OPCODE_LOWER {$/;"	g
-_BT_CTRL_OPCODE_UPPER	include/rtw_bt_mp.h	/^typedef enum _BT_CTRL_OPCODE_UPPER {$/;"	g
-_BT_CTRL_STATUS	include/rtw_btcoex.h	/^typedef enum _BT_CTRL_STATUS {$/;"	g
-_BT_CoType	include/hal_pg.h	/^typedef	enum _BT_CoType {$/;"	g
-_BT_EXT_C2H	include/rtw_bt_mp.h	/^typedef struct _BT_EXT_C2H {$/;"	s
-_BT_GET_GENERAL	include/rtw_bt_mp.h	/^typedef enum _BT_GET_GENERAL {$/;"	g
-_BT_H2C	include/rtw_bt_mp.h	/^typedef struct _BT_H2C {$/;"	s
-_BT_INFO_SRC_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^typedef enum _BT_INFO_SRC_8188C_2ANT{$/;"	g
-_BT_INFO_SRC_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^typedef enum _BT_INFO_SRC_8192D_2ANT{$/;"	g
-_BT_INFO_SRC_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^typedef enum _BT_INFO_SRC_8723A_1ANT{$/;"	g
-_BT_INFO_SRC_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^typedef enum _BT_INFO_SRC_8723A_2ANT{$/;"	g
-_BT_MGNT	include/rtw_btcoex.h	/^typedef struct _BT_MGNT {$/;"	s
-_BT_OPCODE_STATUS	include/rtw_bt_mp.h	/^typedef enum _BT_OPCODE_STATUS {$/;"	g
-_BT_REG_TYPE	include/rtw_bt_mp.h	/^typedef enum _BT_REG_TYPE {$/;"	g
-_BT_REPORT_TYPE	include/rtw_bt_mp.h	/^typedef enum _BT_REPORT_TYPE {$/;"	g
-_BT_REQ_CMD	include/rtw_bt_mp.h	/^typedef struct _BT_REQ_CMD {$/;"	s
-_BT_RSP_CMD	include/rtw_bt_mp.h	/^typedef struct _BT_RSP_CMD {$/;"	s
-_BT_RadioShared	include/hal_pg.h	/^typedef	enum _BT_RadioShared {$/;"	g
-_BT_SET_GENERAL	include/rtw_bt_mp.h	/^typedef enum _BT_SET_GENERAL {$/;"	g
-_BT_STATE_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^typedef enum _BT_STATE_8723A_1ANT{$/;"	g
-_BT_TRAFFIC_MODE	include/rtw_btcoex.h	/^typedef enum _BT_TRAFFIC_MODE {$/;"	g
-_BT_TRAFFIC_MODE_PROFILE	include/rtw_btcoex.h	/^typedef enum _BT_TRAFFIC_MODE_PROFILE {$/;"	g
-_BT_TXRX_PARAMETERS	include/rtw_bt_mp.h	/^typedef struct _BT_TXRX_PARAMETERS {$/;"	s
-_BURST_RW_REG	include/rtw_mp_ioctl.h	/^typedef struct _BURST_RW_REG {$/;"	s
-_BaseBand_Config_Type	include/hal_phy.h	/^typedef enum _BaseBand_Config_Type {$/;"	g
-_BeaconFunctionEnable	hal/rtl8723d/rtl8723d_hal_init.c	/^static void _BeaconFunctionEnable(PADAPTER padapter, u8 Enable, u8 Linked)$/;"	f	file:
-_BlockWrite	hal/rtl8723d/rtl8723d_hal_init.c	/^_BlockWrite($/;"	f	file:
-_C2H_EVT	hal/hal_com_c2h.h	/^typedef enum _C2H_EVT {$/;"	g
-_CAPABILITY	include/rtw_rf.h	/^typedef enum _CAPABILITY {$/;"	g
-_CAPABILITY_	include/wifi.h	698;"	d
-_CCX_INFO	hal/phydm/phydm_ccx.h	/^typedef struct _CCX_INFO{$/;"	s
-_CFO_TRACKING_	hal/phydm/phydm_cfotracking.h	/^typedef struct _CFO_TRACKING_$/;"	s
-_CHANNEL_WIDTH	include/rtw_rf.h	/^typedef enum _CHANNEL_WIDTH {$/;"	g
-_CHIP_TYPE	include/hal_intf.h	/^enum _CHIP_TYPE {$/;"	g
-_CHLGETXT_IE_	include/wifi.h	583;"	d
-_CH_SWITCH_TIMING_	include/wifi.h	608;"	d
-_CH_SWTICH_ANNOUNCE_	include/wifi.h	585;"	d
-_CH_SW_USE_CASE	include/hal_com.h	/^typedef enum _CH_SW_USE_CASE {$/;"	g
-_COEX_DM_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^typedef struct _COEX_DM_8188C_2ANT{$/;"	s
-_COEX_DM_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^typedef struct _COEX_DM_8192D_2ANT{$/;"	s
-_COEX_DM_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^typedef struct _COEX_DM_8723A_1ANT{$/;"	s
-_COEX_DM_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^typedef struct _COEX_DM_8723A_2ANT{$/;"	s
-_COEX_STA_8188C_2ANT	hal/btc/HalBtc8188c2Ant.h	/^typedef struct _COEX_STA_8188C_2ANT{$/;"	s
-_COEX_STA_8192D_2ANT	hal/btc/HalBtc8192d2Ant.h	/^typedef struct _COEX_STA_8192D_2ANT{$/;"	s
-_COEX_STA_8723A_1ANT	hal/btc/HalBtc8723a1Ant.h	/^typedef struct _COEX_STA_8723A_1ANT{$/;"	s
-_COEX_STA_8723A_2ANT	hal/btc/HalBtc8723a2Ant.h	/^typedef struct _COEX_STA_8723A_2ANT{$/;"	s
-_COL_C2H_ACK	hal/btc/HalBtcOutSrc.h	/^typedef struct _COL_C2H_ACK {$/;"	s
-_COL_C2H_IND	hal/btc/HalBtcOutSrc.h	/^typedef struct _COL_C2H_IND {$/;"	s
-_COL_H2C	hal/btc/HalBtcOutSrc.h	/^typedef struct _COL_H2C {$/;"	s
-_COL_H2C_STATUS	hal/btc/HalBtcOutSrc.h	/^typedef enum _COL_H2C_STATUS {$/;"	g
-_COL_IND_TYPE	hal/btc/HalBtcOutSrc.h	/^typedef enum _COL_IND_TYPE {$/;"	g
-_COL_OPCODE	hal/btc/HalBtcOutSrc.h	/^typedef enum _COL_OPCODE {$/;"	g
-_COL_SINGLE_C2H_IND_RECORD	hal/btc/HalBtcOutSrc.h	/^typedef struct _COL_SINGLE_C2H_IND_RECORD {$/;"	s
-_COL_SINGLE_H2C_RECORD	hal/btc/HalBtcOutSrc.h	/^typedef struct _COL_SINGLE_H2C_RECORD {$/;"	s
-_CONNECT_STATE_	core/rtw_ioctl_rtl.c	/^enum _CONNECT_STATE_ {$/;"	g	file:
-_COUNTRY_IE_	include/wifi.h	582;"	d
-_CRCLNG_	include/wifi.h	562;"	d
-_CURRENT_APADDR_	include/wifi.h	699;"	d
-_CheckWLANFwPatchBTFwReady	hal/rtl8723d/rtl8723d_hal_init.c	/^_CheckWLANFwPatchBTFwReady($/;"	f
-_DEAUTH_IE_OFFSET_	include/wifi.h	571;"	d
-_DEBUG_ERR	include/rtw_br_ext.h	26;"	d
-_DEBUG_INFO	include/rtw_br_ext.h	27;"	d
-_DRIVER_STATE	include/drv_types.h	/^typedef enum _DRIVER_STATE {$/;"	g
-_DRV_ALWAYS_	include/rtw_debug.h	/^	_DRV_ALWAYS_ = 1,$/;"	e	enum:__anon69
-_DRV_DEBUG_	include/rtw_debug.h	/^	_DRV_DEBUG_ = 5,$/;"	e	enum:__anon69
-_DRV_ERR_	include/rtw_debug.h	/^	_DRV_ERR_ = 2,$/;"	e	enum:__anon69
-_DRV_INFO_	include/rtw_debug.h	/^	_DRV_INFO_ = 4,$/;"	e	enum:__anon69
-_DRV_MAX_	include/rtw_debug.h	/^	_DRV_MAX_ = 6$/;"	e	enum:__anon69
-_DRV_NONE_	include/rtw_debug.h	/^	_DRV_NONE_ = 0,$/;"	e	enum:__anon69
-_DRV_WARNING_	include/rtw_debug.h	/^	_DRV_WARNING_ = 3,$/;"	e	enum:__anon69
-_DR_VARIABLE_STRUCT_	include/rtw_mp_ioctl.h	/^typedef struct _DR_VARIABLE_STRUCT_ {$/;"	s
-_DSSET_IE_	include/wifi.h	579;"	d
-_DisableAnalog	hal/rtl8723d/rtl8723d_hal_init.c	/^void _DisableAnalog(PADAPTER padapter, BOOLEAN bWithoutHWSM)$/;"	f
-_DisableGPIO	hal/rtl8723d/rtl8723d_hal_init.c	/^void _DisableGPIO(PADAPTER	padapter)$/;"	f
-_DisableRFAFEAndResetBB	hal/rtl8723d/rtl8723d_hal_init.c	/^void _DisableRFAFEAndResetBB(PADAPTER padapter)$/;"	f
-_DisableRFAFEAndResetBB8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^void _DisableRFAFEAndResetBB8723D(PADAPTER padapter)$/;"	f
-_Dynamic_Initial_Gain_Threshold_	hal/phydm/phydm_dig.h	/^typedef struct _Dynamic_Initial_Gain_Threshold_$/;"	s
-_Dynamic_Power_Saving_	hal/phydm/phydm_dynamicbbpowersaving.h	/^typedef struct _Dynamic_Power_Saving_$/;"	s
-_Dynamic_Primary_CCA	hal/phydm/phydm.h	/^typedef struct _Dynamic_Primary_CCA {$/;"	s
-_EDCA_TURBO_	hal/phydm/phydm_edcaturbocheck.h	/^typedef struct _EDCA_TURBO_$/;"	s
-_EEPROM_RW_PARAM	include/rtw_mp_ioctl.h	/^typedef struct _EEPROM_RW_PARAM {$/;"	s
-_EFUSE_ACCESS_STRUCT_	include/rtw_mp_ioctl.h	/^typedef struct _EFUSE_ACCESS_STRUCT_ {$/;"	s
-_EFUSE_DEF_TYPE	include/rtw_efuse.h	/^enum _EFUSE_DEF_TYPE {$/;"	g
-_EFUSE_HAL	include/rtw_efuse.h	/^typedef struct _EFUSE_HAL {$/;"	s
-_ELEMENT_ID	include/wifi.h	/^typedef	enum _ELEMENT_ID {$/;"	g
-_ENCRY_CTRL_STATE_	include/rtw_mp.h	/^typedef enum _ENCRY_CTRL_STATE_ {$/;"	g
-_EPQ	include/hal_com_reg.h	1407;"	d
-_ERPINFO_IE_	include/wifi.h	588;"	d
-_EXTCHNL_OFFSET	include/rtw_rf.h	/^typedef enum _EXTCHNL_OFFSET {$/;"	g
-_EXTEND_C2H_EVT	hal/hal_com_c2h.h	/^typedef enum _EXTEND_C2H_EVT {$/;"	g
-_EXT_CAP_IE_	include/wifi.h	610;"	d
-_EXT_SUPPORTEDRATES_IE_	include/wifi.h	589;"	d
-_EfuseCellSel	hal/rtl8723d/sdio/sdio_halinit.c	/^_EfuseCellSel($/;"	f	file:
-_FAIL	include/osdep_service.h	24;"	d
-_FALSE	hal/phydm/phydm_types.h	164;"	d
-_FALSE	include/basic_types.h	34;"	d
-_FALSE	include/basic_types.h	36;"	d
-_FALSE	include/osdep_service.h	32;"	d
-_FALSE	include/osdep_service.h	33;"	d
-_FALSE_ALARM_STATISTICS	hal/phydm/phydm_dig.h	/^typedef struct _FALSE_ALARM_STATISTICS{$/;"	s
-_FAST_ANTENNA_TRAINNING_	hal/phydm/phydm_antdiv.h	/^typedef struct _FAST_ANTENNA_TRAINNING_$/;"	s
-_FAT_STATE	hal/phydm/phydm_antdiv.h	/^typedef enum _FAT_STATE \/*Fast antenna training*\/$/;"	g
-_FIRMWARE_SOURCE	include/hal_com.h	/^typedef enum _FIRMWARE_SOURCE {$/;"	g
-_FIXED_IE_LENGTH_	include/wifi.h	575;"	d
-_FROM_DS_	include/wifi.h	265;"	d
-_FTIE_	include/wifi.h	593;"	d
-_FWDownloadEnable	hal/rtl8723d/rtl8723d_hal_init.c	/^_FWDownloadEnable($/;"	f	file:
-_FWFreeToGo	hal/rtl8723d/rtl8723d_hal_init.c	/^static s32 _FWFreeToGo(_adapter *adapter, u32 min_cnt, u32 timeout_ms)$/;"	f	file:
-_FW_HEADER_8723D_H	hal/rtl8723d/hal8723d_fw.h	24;"	d
-_FW_LINKED	include/rtw_mlme.h	144;"	d
-_FW_UNDER_LINKING	include/rtw_mlme.h	143;"	d
-_FW_UNDER_SURVEY	include/rtw_mlme.h	145;"	d
-_FillDummy	hal/rtl8723d/rtl8723d_hal_init.c	/^_FillDummy($/;"	f	file:
-_FourOutPipeMapping	hal/hal_com.c	/^static VOID _FourOutPipeMapping($/;"	f	file:
-_GetBBReg_CMD_	include/rtw_cmd.h	1227;"	d
-_GetMACReg_CMD_	include/rtw_cmd.h	1225;"	d
-_GetRFReg_CMD_	include/rtw_cmd.h	1229;"	d
-_H2CLBK_H_	include/h2clbk.h	22;"	d
-_HAL_COM_C_	hal/hal_com.c	20;"	d	file:
-_HAL_COM_PHYCFG_C_	hal/hal_com_phycfg.c	20;"	d	file:
-_HAL_DEF_VARIABLE	include/hal_intf.h	/^typedef enum _HAL_DEF_VARIABLE {$/;"	g
-_HAL_HALMAC_C_	hal/hal_halmac.c	20;"	d	file:
-_HAL_HALMAC_H_	hal/hal_halmac.h	21;"	d
-_HAL_HW_TIMER_TYPE	include/hal_intf.h	/^typedef enum _HAL_HW_TIMER_TYPE {$/;"	g
-_HAL_INIT_C_	hal/rtl8723d/rtl8723d_hal_init.c	20;"	d	file:
-_HAL_INTFS_FILES	Makefile	/^_HAL_INTFS_FILES :=	hal\/hal_intf.o \\$/;"	m
-_HAL_INTF_C_	hal/hal_intf.c	21;"	d	file:
-_HAL_INTF_PS_FUNC	include/hal_intf.h	/^typedef enum _HAL_INTF_PS_FUNC {$/;"	g
-_HAL_MCC_C_	hal/hal_mcc.c	20;"	d	file:
-_HAL_MP_C_	hal/hal_mp.c	20;"	d	file:
-_HAL_ODM_VARIABLE	include/hal_intf.h	/^typedef enum _HAL_ODM_VARIABLE {$/;"	g
-_HAL_PHYDM_OPS	include/hal_com.h	/^typedef enum _HAL_PHYDM_OPS {$/;"	g
-_HAL_PHY_C_	hal/hal_phy.c	20;"	d	file:
-_HAL_SDIO_C_	hal/hal_hci/hal_sdio.c	20;"	d	file:
-_HAL_STATUS	hal/phydm/phydm_types.h	/^typedef enum _HAL_STATUS{$/;"	g
-_HAL_TXBF_INFO	hal/phydm/txbf/halcomtxbf.h	/^typedef struct _HAL_TXBF_INFO {$/;"	s
-_HARDWARE_TYPE	include/hal_intf.h	/^typedef enum _HARDWARE_TYPE {$/;"	g
-_HCI_EXT_BT_OPERATION	include/rtw_btcoex.h	/^typedef enum _HCI_EXT_BT_OPERATION {$/;"	g
-_HCI_EXT_CONFIG	include/rtw_btcoex.h	/^typedef struct _HCI_EXT_CONFIG {$/;"	s
-_HCI_INTF_C_	os_dep/linux/sdio_intf.c	20;"	d	file:
-_HCI_LINK_INFO	include/rtw_btcoex.h	/^typedef struct _HCI_LINK_INFO {$/;"	s
-_HCI_PHY_LINK_BSS_INFO	include/rtw_btcoex.h	/^typedef struct _HCI_PHY_LINK_BSS_INFO {$/;"	s
-_HCI_STATUS	include/rtw_btcoex.h	/^typedef enum _HCI_STATUS {$/;"	g
-_HPQ	include/hal_com_reg.h	1403;"	d
-_HT_ADD_INFO_IE_	include/wifi.h	597;"	d
-_HT_CAPABILITY_IE_	include/wifi.h	591;"	d
-_HT_CAP_AMPDU_DENSITY	include/wifi.h	/^typedef enum _HT_CAP_AMPDU_DENSITY {$/;"	g
-_HT_CAP_AMPDU_FACTOR	include/wifi.h	/^typedef enum _HT_CAP_AMPDU_FACTOR {$/;"	g
-_HT_EXTRA_INFO_IE_	include/wifi.h	596;"	d
-_HT_IOT_PEER	include/rtw_mlme_ext.h	/^typedef enum _HT_IOT_PEER {$/;"	g
-_HW_BLOCK	include/hal_phy.h	/^typedef enum _HW_BLOCK {$/;"	g
-_HW_STATE_ADHOC_	include/rtw_mlme_ext.h	58;"	d
-_HW_STATE_AP_	include/rtw_mlme_ext.h	60;"	d
-_HW_STATE_MONITOR_	include/rtw_mlme_ext.h	61;"	d
-_HW_STATE_NOLINK_	include/rtw_mlme_ext.h	57;"	d
-_HW_STATE_STATION_	include/rtw_mlme_ext.h	59;"	d
-_HW_VARIABLES	include/hal_intf.h	/^typedef enum _HW_VARIABLES {$/;"	g
-_IBSS_PARA_IE_	include/wifi.h	581;"	d
-_IEEE80211_C	core/rtw_ieee80211.c	20;"	d	file:
-_IEEE8021X_MGT_	include/wifi.h	728;"	d
-_IEEE8021X_PSK_	include/wifi.h	729;"	d
-_IFACE_ID	include/drv_types.h	/^enum _IFACE_ID {$/;"	g
-_INTERFACE_SELECT_PCIE	include/hal_data.h	/^typedef	enum _INTERFACE_SELECT_PCIE {$/;"	g
-_INTERFACE_SELECT_USB	include/hal_data.h	/^typedef	enum _INTERFACE_SELECT_USB {$/;"	g
-_INTF_ASYNC_	include/rtw_io.h	91;"	d
-_IOCMD_STRUCT_	include/rtw_mp.h	/^typedef struct _IOCMD_STRUCT_ {$/;"	s
-_IOCTL_CFG80211_C_	os_dep/linux/ioctl_cfg80211.c	20;"	d	file:
-_IOCTL_LINUX_C_	os_dep/linux/ioctl_linux.c	20;"	d	file:
-_IOREADY	include/rtw_io.h	33;"	d
-_IOSZ_MASK_	include/rtw_io.h	38;"	d
-_IO_BURST_	include/rtw_io.h	41;"	d
-_IO_BYTE_	include/rtw_io.h	42;"	d
-_IO_CMDMASK_	include/rtw_io.h	46;"	d
-_IO_DONE_	include/rtw_io.h	59;"	d
-_IO_ERR_	include/rtw_io.h	57;"	d
-_IO_FIXED_	include/rtw_io.h	40;"	d
-_IO_HW_	include/rtw_io.h	43;"	d
-_IO_SUCCESS_	include/rtw_io.h	58;"	d
-_IO_SYNC_	include/rtw_io.h	45;"	d
-_IO_WAIT_COMPLETE	include/rtw_io.h	34;"	d
-_IO_WAIT_RSP	include/rtw_io.h	35;"	d
-_IO_WORD_	include/rtw_io.h	44;"	d
-_IO_WRITE_	include/rtw_io.h	39;"	d
-_IQK_INFORMATION	hal/phydm/phydm_iqk.h	/^typedef struct _IQK_INFORMATION {$/;"	s
-_IQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_ap.h	/^typedef struct _IQK_MATRIX_REGS_SETTING{$/;"	s
-_IQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_ce.h	/^typedef struct _IQK_MATRIX_REGS_SETTING{$/;"	s
-_IQK_MATRIX_REGS_SETTING	hal/phydm/phydm_powertracking_win.h	/^typedef struct _IQK_MATRIX_REGS_SETTING{$/;"	s
-_InitAdaptiveCtrl	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitAdaptiveCtrl(PADAPTER padapter)$/;"	f
-_InitAntenna_Selection	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitAntenna_Selection(PADAPTER padapter)$/;"	f	file:
-_InitBBRegBackup_8723DS	hal/rtl8723d/sdio/sdio_halinit.c	/^VOID _InitBBRegBackup_8723DS(PADAPTER	Adapter)$/;"	f
-_InitBurstPktLen_8723DS	hal/rtl8723d/rtl8723d_hal_init.c	/^void	_InitBurstPktLen_8723DS(PADAPTER Adapter)$/;"	f
-_InitDriverInfoSize	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitDriverInfoSize(PADAPTER padapter, u8 drvInfoSize)$/;"	f
-_InitEDCA	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitEDCA(PADAPTER padapter)$/;"	f
-_InitInterrupt	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitInterrupt(PADAPTER padapter)$/;"	f
-_InitLTECoex_8723DS	hal/rtl8723d/rtl8723d_hal_init.c	/^void _InitLTECoex_8723DS(PADAPTER Adapter)$/;"	f
-_InitMacAPLLSetting_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^void _InitMacAPLLSetting_8723D(PADAPTER Adapter)$/;"	f
-_InitNetworkType	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitNetworkType(PADAPTER padapter)$/;"	f
-_InitNormalChipOneOutEpPriority	hal/rtl8723d/sdio/sdio_halinit.c	/^_InitNormalChipOneOutEpPriority($/;"	f	file:
-_InitNormalChipQueuePriority	hal/rtl8723d/sdio/sdio_halinit.c	/^_InitNormalChipQueuePriority($/;"	f	file:
-_InitNormalChipRegPriority	hal/rtl8723d/sdio/sdio_halinit.c	/^_InitNormalChipRegPriority($/;"	f	file:
-_InitNormalChipThreeOutEpPriority	hal/rtl8723d/sdio/sdio_halinit.c	/^_InitNormalChipThreeOutEpPriority($/;"	f	file:
-_InitNormalChipTwoOutEpPriority	hal/rtl8723d/sdio/sdio_halinit.c	/^_InitNormalChipTwoOutEpPriority($/;"	f	file:
-_InitOperationMode	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitOperationMode(PADAPTER padapter)$/;"	f
-_InitOtherVariable	hal/rtl8723d/sdio/sdio_halinit.c	/^_InitOtherVariable($/;"	f	file:
-_InitPABias	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitPABias(PADAPTER padapter)$/;"	f	file:
-_InitPageBoundary	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitPageBoundary(PADAPTER padapter)$/;"	f	file:
-_InitPowerOn_8723DS	hal/rtl8723d/sdio/sdio_halinit.c	/^u32 _InitPowerOn_8723DS(PADAPTER padapter)$/;"	f
-_InitQueuePriority	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitQueuePriority(PADAPTER padapter)$/;"	f	file:
-_InitQueueReservedPage	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitQueueReservedPage(PADAPTER padapter)$/;"	f	file:
-_InitRDGSetting	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitRDGSetting(PADAPTER padapter)$/;"	f
-_InitRFType	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitRFType(PADAPTER padapter)$/;"	f	file:
-_InitRateFallback	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitRateFallback(PADAPTER padapter)$/;"	f
-_InitRetryFunction	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitRetryFunction(PADAPTER padapter)$/;"	f
-_InitTransferPageSize	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitTransferPageSize(PADAPTER padapter)$/;"	f	file:
-_InitTxBufferBoundary	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _InitTxBufferBoundary(PADAPTER padapter)$/;"	f	file:
-_InitWMACSetting	hal/rtl8723d/sdio/sdio_halinit.c	/^void _InitWMACSetting(PADAPTER padapter)$/;"	f
-_LDV12_VADJ	include/hal_com_reg.h	1221;"	d
-_LED_CTL_MODE	include/hal_com_led.h	/^typedef enum _LED_CTL_MODE {$/;"	g
-_LED_PCIE	include/hal_com_led.h	/^typedef struct _LED_PCIE {$/;"	s
-_LED_PIN	include/hal_com_led.h	/^typedef enum _LED_PIN {$/;"	g
-_LED_SDIO	include/hal_com_led.h	/^typedef struct _LED_SDIO {$/;"	s
-_LED_STATE	include/hal_com_led.h	/^typedef	enum _LED_STATE {$/;"	g
-_LED_STRATEGY_PCIE	include/hal_com_led.h	/^typedef	enum _LED_STRATEGY_PCIE {$/;"	g
-_LED_STRATEGY_SDIO	include/hal_com_led.h	/^typedef	enum _LED_STRATEGY_SDIO {$/;"	g
-_LED_STRATEGY_USB	include/hal_com_led.h	/^typedef	enum _LED_STRATEGY_USB {$/;"	g
-_LED_USB	include/hal_com_led.h	/^typedef struct _LED_USB {$/;"	s
-_LINK_ID_IE_	include/wifi.h	607;"	d
-_LINUX_BYTEORDER_BIG_ENDIAN_H	include/byteorder/big_endian.h	21;"	d
-_LINUX_BYTEORDER_GENERIC_H	include/byteorder/generic.h	21;"	d
-_LINUX_BYTEORDER_LITTLE_ENDIAN_H	include/byteorder/little_endian.h	21;"	d
-_LINUX_BYTEORDER_SWABB_H	include/byteorder/swabb.h	21;"	d
-_LINUX_BYTEORDER_SWAB_H	include/byteorder/swab.h	21;"	d
-_LINUX_IF_ETHER_H	include/if_ether.h	22;"	d
-_LINUX_IP_H	include/ip.h	21;"	d
-_LINUX_WIRELESS_H	include/linux/wireless.h	22;"	d
-_LISTEN_INTERVAL_	include/wifi.h	700;"	d
-_LLT_INIT_ADDR	include/hal_com_reg.h	1392;"	d
-_LLT_INIT_DATA	include/hal_com_reg.h	1391;"	d
-_LLT_NO_ACTIVE	include/hal_com_reg.h	1387;"	d
-_LLT_OP	include/hal_com_reg.h	1393;"	d
-_LLT_OP_VALUE	include/hal_com_reg.h	1394;"	d
-_LLT_READ_ACCESS	include/hal_com_reg.h	1389;"	d
-_LLT_WRITE_ACCESS	include/hal_com_reg.h	1388;"	d
-_LPQ	include/hal_com_reg.h	1404;"	d
-_LRL	include/hal_com_reg.h	1488;"	d
-_MDIE_	include/wifi.h	592;"	d
-_MLME_OSDEP_C_	os_dep/linux/mlme_linux.c	22;"	d	file:
-_MME_IE_	include/wifi.h	605;"	d
-_MME_IE_LENGTH_	include/wifi.h	742;"	d
-_MORE_DATA_	include/wifi.h	269;"	d
-_MORE_FRAG_	include/wifi.h	266;"	d
-_MPT_BANDWIDTH	include/rtw_mp.h	/^typedef enum _MPT_BANDWIDTH {$/;"	g
-_MPT_CONTEXT	include/rtw_mp.h	/^typedef struct _MPT_CONTEXT {$/;"	s
-_MPT_RATE_INDEX	include/rtw_mp.h	/^typedef enum _MPT_RATE_INDEX {$/;"	g
-_MPT_TXPWR_DEF	include/rtw_mp.h	/^typedef enum	_MPT_TXPWR_DEF {$/;"	g
-_MP_BT_MODE	include/rtw_bt_mp.h	/^typedef enum _MP_BT_MODE {$/;"	g
-_MP_BT_PAYLOAD_TYPE	include/rtw_bt_mp.h	/^typedef enum _MP_BT_PAYLOAD_TYPE {$/;"	g
-_MP_BT_PKT_TYPE	include/rtw_bt_mp.h	/^typedef enum _MP_BT_PKT_TYPE {$/;"	g
-_MP_BT_TEST_CTRL	include/rtw_bt_mp.h	/^typedef enum _MP_BT_TEST_CTRL {$/;"	g
-_MP_FIRMWARE	include/rtw_mp.h	/^typedef struct _MP_FIRMWARE {$/;"	s
-_MP_MODE_	include/rtw_mp.h	/^typedef enum _MP_MODE_ {$/;"	g
-_MP_REG_ENTRY	include/drv_types_ce.h	/^typedef struct _MP_REG_ENTRY {$/;"	s
-_MP_REG_ENTRY	include/drv_types_xp.h	/^typedef struct _MP_REG_ENTRY {$/;"	s
-_NAPI_STATE	include/drv_types.h	/^enum _NAPI_STATE {$/;"	g
-_NDIS_802_11_AI_REQFI	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_AI_REQFI {$/;"	s
-_NDIS_802_11_AI_RESFI	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_AI_RESFI {$/;"	s
-_NDIS_802_11_ASSOCIATION_INFORMATION	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION {$/;"	s
-_NDIS_802_11_AUTHENTICATION_ENCRYPTION	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_AUTHENTICATION_ENCRYPTION {$/;"	s
-_NDIS_802_11_AUTHENTICATION_EVENT	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_AUTHENTICATION_EVENT {$/;"	s
-_NDIS_802_11_AUTHENTICATION_MODE	include/wlan_bssdef.h	/^typedef enum _NDIS_802_11_AUTHENTICATION_MODE {$/;"	g
-_NDIS_802_11_AUTHENTICATION_REQUEST	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST {$/;"	s
-_NDIS_802_11_CAPABILITY	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_CAPABILITY {$/;"	s
-_NDIS_802_11_CONFIGURATION	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_CONFIGURATION {$/;"	s
-_NDIS_802_11_CONFIGURATION_FH	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_CONFIGURATION_FH {$/;"	s
-_NDIS_802_11_FIXED_IEs	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_FIXED_IEs {$/;"	s
-_NDIS_802_11_KEY	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_KEY {$/;"	s
-_NDIS_802_11_NETWORK_INFRASTRUCTURE	include/wlan_bssdef.h	/^typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE {$/;"	g
-_NDIS_802_11_NETWORK_TYPE	include/wlan_bssdef.h	/^typedef enum _NDIS_802_11_NETWORK_TYPE {$/;"	g
-_NDIS_802_11_PMKID	include/rtw_ioctl_set.h	/^typedef struct _NDIS_802_11_PMKID {$/;"	s
-_NDIS_802_11_PMKID_CANDIDATE_LIST	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_PMKID_CANDIDATE_LIST {$/;"	s
-_NDIS_802_11_RELOAD_DEFAULTS	include/wlan_bssdef.h	/^typedef enum _NDIS_802_11_RELOAD_DEFAULTS {$/;"	g
-_NDIS_802_11_REMOVE_KEY	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_REMOVE_KEY {$/;"	s
-_NDIS_802_11_SSID	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_SSID {$/;"	s
-_NDIS_802_11_STATUS_INDICATION	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_STATUS_INDICATION {$/;"	s
-_NDIS_802_11_STATUS_TYPE	include/wlan_bssdef.h	/^typedef enum _NDIS_802_11_STATUS_TYPE {$/;"	g
-_NDIS_802_11_TEST	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_TEST {$/;"	s
-_NDIS_802_11_VARIABLE_IEs	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_VARIABLE_IEs {$/;"	s
-_NDIS_802_11_WEP	include/wlan_bssdef.h	/^typedef struct _NDIS_802_11_WEP {$/;"	s
-_NDIS_802_11_WEP_STATUS	include/wlan_bssdef.h	/^typedef enum _NDIS_802_11_WEP_STATUS {$/;"	g
-_NETTYPE	include/hal_com_reg.h	1328;"	d
-_NIC_VERSION	include/drv_types.h	/^enum _NIC_VERSION {$/;"	g
-_NO_PRIVACY_	include/rtw_security.h	24;"	d
-_NPQ	include/hal_com_reg.h	1406;"	d
-_OCTET_STRING	include/drv_types_ce.h	/^typedef struct _OCTET_STRING {$/;"	s
-_OCTET_STRING	include/drv_types_xp.h	/^typedef struct _OCTET_STRING {$/;"	s
-_ODM_Common_Info_Definition	hal/phydm/phydm.h	/^typedef enum _ODM_Common_Info_Definition {$/;"	g
-_ODM_NOISE_MONITOR_	hal/phydm/phydm_noisemonitor.h	/^typedef struct _ODM_NOISE_MONITOR_$/;"	s
-_ODM_PARAMETER_INIT	hal/phydm/phydm_pre_define.h	/^typedef enum _ODM_PARAMETER_INIT {$/;"	g
-_ODM_PATH_DIVERSITY_	hal/phydm/phydm_pathdiv.h	/^typedef struct _ODM_PATH_DIVERSITY_$/;"	s
-_ODM_Per_Pkt_Info_	hal/phydm/phydm.h	/^typedef struct _ODM_Per_Pkt_Info_ {$/;"	s
-_ODM_Phy_Dbg_Info_	hal/phydm/phydm.h	/^typedef struct _ODM_Phy_Dbg_Info_ {$/;"	s
-_ODM_Phy_Status_Info_	hal/phydm/phydm.h	/^__PACK typedef struct _ODM_Phy_Status_Info_$/;"	s
-_ODM_Phy_Status_Info_	hal/phydm/phydm.h	/^typedef struct _ODM_Phy_Status_Info_ {$/;"	s
-_ODM_Phy_Status_Info_Append_	hal/phydm/phydm.h	/^typedef struct _ODM_Phy_Status_Info_Append_ {$/;"	s
-_ODM_RATE_ADAPTIVE	hal/phydm/phydm_rainfo.h	/^typedef struct _ODM_RATE_ADAPTIVE {$/;"	s
-_ODM_RA_Info_	hal/phydm/phydm_rainfo.h	/^typedef struct _ODM_RA_Info_ {$/;"	s
-_ODM_RF_RADIO_PATH	hal/phydm/phydm_pre_define.h	/^typedef enum _ODM_RF_RADIO_PATH {$/;"	g
-_ODM_STA_INFO	hal/phydm/phydm.h	/^typedef	struct _ODM_STA_INFO {$/;"	s
-_ODM_Support_Ability_Definition	hal/phydm/phydm.h	/^typedef enum _ODM_Support_Ability_Definition {$/;"	g
-_OFDM_TX_MODE	include/rtw_mp.h	/^typedef enum _OFDM_TX_MODE {$/;"	g
-_ORDER_	include/wifi.h	271;"	d
-_OSDEP_SERVICE_C_	os_dep/osdep_service.c	22;"	d	file:
-_OS_INTFS_C_	os_dep/linux/os_intfs.c	20;"	d	file:
-_OS_INTFS_FILES	Makefile	/^_OS_INTFS_FILES :=	os_dep\/osdep_service.o \\$/;"	m
-_OS_STATUS	include/osdep_service_bsd.h	/^	typedef	int	_OS_STATUS;$/;"	t
-_OS_STATUS	include/osdep_service_ce.h	/^typedef NDIS_STATUS _OS_STATUS;$/;"	t
-_OS_STATUS	include/osdep_service_linux.h	/^typedef	int	_OS_STATUS;$/;"	t
-_OS_STATUS	include/osdep_service_xp.h	/^	typedef NDIS_STATUS _OS_STATUS;$/;"	t
-_OUTSRC_FILES	Makefile	/^_OUTSRC_FILES := hal\/phydm\/phydm_debug.o	\\$/;"	m
-_OneOutPipeMapping	hal/hal_com.c	/^_OneOutPipeMapping($/;"	f	file:
-_PACKET_IRP_HCIEVENT_DATA	include/rtw_btcoex.h	/^typedef struct _PACKET_IRP_HCIEVENT_DATA {$/;"	s
-_PCI_COMMON_CONFIG	include/drv_types_pci.h	/^typedef struct _PCI_COMMON_CONFIG {$/;"	s
-_PCI_HEADER_TYPE_0	include/drv_types_pci.h	/^		struct _PCI_HEADER_TYPE_0 {$/;"	s	union:_PCI_COMMON_CONFIG::__anon66
-_PHYDM_ACTING_TYPE	hal/phydm/phydm_beamforming.h	/^typedef enum _PHYDM_ACTING_TYPE {$/;"	g
-_PHYDM_ADAPTIVITY_Info_Definition	hal/phydm/phydm_adaptivity.h	/^typedef enum _PHYDM_ADAPTIVITY_Info_Definition {$/;"	g
-_PHYDM_API_Definition	hal/phydm/phydm.h	/^typedef enum _PHYDM_API_Definition {$/;"	g
-_PHYDM_BW	hal/phydm/phydm_rainfo.h	/^typedef	enum _PHYDM_BW {$/;"	g
-_PHYDM_C2H_EVT	hal/phydm/phydm_interface.h	/^typedef enum _PHYDM_C2H_EVT {$/;"	g
-_PHYDM_COMMAND	hal/phydm/phydm_debug.c	/^struct _PHYDM_COMMAND {$/;"	s	file:
-_PHYDM_EXTEND_C2H_EVT	hal/phydm/phydm_interface.h	/^typedef enum _PHYDM_EXTEND_C2H_EVT {$/;"	g
-_PHYDM_H2C_CMD	hal/phydm/phydm_interface.h	/^typedef enum _PHYDM_H2C_CMD {$/;"	g
-_PHYDM_Info_query_type	hal/phydm/phydm.h	/^typedef enum _PHYDM_Info_query_type {$/;"	g
-_PHYDM_RF_TYPE_DEFINITION	hal/phydm/phydm_rainfo.h	/^typedef	enum _PHYDM_RF_TYPE_DEFINITION {$/;"	g
-_PHY_DumpRFReg_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^_PHY_DumpRFReg_8723D(IN	PADAPTER	pAdapter)$/;"	f	file:
-_PHY_GetTxPowerByRate	hal/hal_com_phycfg.c	/^_PHY_GetTxPowerByRate($/;"	f
-_PHY_MACSettingCalibration_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_MACSettingCalibration_8723D($/;"	f
-_PHY_PIModeSwitch_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_PIModeSwitch_8723D($/;"	f
-_PHY_PathADDAOn_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_PathADDAOn_8723D($/;"	f
-_PHY_PathAStandBy_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_PathAStandBy_8723D($/;"	f
-_PHY_PathBStandBy_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_PathBStandBy_8723D($/;"	f
-_PHY_PathS0FillIQKMatrix_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_PathS0FillIQKMatrix_8723D($/;"	f
-_PHY_PathS1FillIQKMatrix_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_PathS1FillIQKMatrix_8723D($/;"	f
-_PHY_ReloadADDARegisters_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_ReloadADDARegisters_8723D($/;"	f
-_PHY_ReloadMACRegisters_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_ReloadMACRegisters_8723D($/;"	f
-_PHY_SaveADDARegisters_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_SaveADDARegisters_8723D($/;"	f
-_PHY_SaveMACRegisters_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^_PHY_SaveMACRegisters_8723D($/;"	f
-_PLATFORM_FILES	Makefile	/^_PLATFORM_FILES := platform\/platform_ops.o$/;"	m
-_PMKID_CANDIDATE	include/wlan_bssdef.h	/^typedef struct _PMKID_CANDIDATE {$/;"	s
-_POWER_MODE_	include/rtw_mp.h	/^typedef enum _POWER_MODE_ {$/;"	g
-_PRE_ALLOCHDR_	include/wifi.h	555;"	d
-_PRE_ALLOCICVHDR_	include/wifi.h	557;"	d
-_PRE_ALLOCLLCHDR_	include/wifi.h	556;"	d
-_PRE_ALLOCMEM_	include/wifi.h	554;"	d
-_PRE_ALLOCMICHDR_	include/wifi.h	558;"	d
-_PRIVACY_	include/wifi.h	270;"	d
-_PROBEREQ_IE_OFFSET_	include/wifi.h	568;"	d
-_PROBERSP_IE_OFFSET_	include/wifi.h	569;"	d
-_PROTECTION_MODE	include/rtw_rf.h	/^typedef enum _PROTECTION_MODE {$/;"	g
-_PSRX	include/hal_com_reg.h	1340;"	d
-_PSRX_MASK	include/hal_com_reg.h	1338;"	d
-_PSTX	include/hal_com_reg.h	1341;"	d
-_PSTX_MASK	include/hal_com_reg.h	1339;"	d
-_PS_BBRegBackup_	include/rtw_pwrctrl.h	/^enum _PS_BBRegBackup_ {$/;"	g
-_PS_DENY_REASON	include/rtw_pwrctrl.h	/^typedef enum _PS_DENY_REASON {$/;"	g
-_PTI_BUFFER_STATUS_	include/wifi.h	609;"	d
-_PUBLIC_ACTION	include/ieee80211.h	/^enum _PUBLIC_ACTION {$/;"	g
-_PUBLIC_ACTION_IE_OFFSET_	include/wifi.h	573;"	d
-_PUBQ	include/hal_com_reg.h	1405;"	d
-_PWRMGT_	include/wifi.h	268;"	d
-_PWRSEQ_CMD_DELAY_UNIT_	include/HalPwrSeqCmd.h	/^typedef enum _PWRSEQ_CMD_DELAY_UNIT_ {$/;"	g
-_PWRTRACK_CONTROL_METHOD	hal/phydm/halphyrf_ap.h	/^typedef enum _PWRTRACK_CONTROL_METHOD {$/;"	g
-_PWRTRACK_CONTROL_METHOD	hal/phydm/halphyrf_ce.h	/^typedef enum _PWRTRACK_CONTROL_METHOD {$/;"	g
-_PWRTRACK_CONTROL_METHOD	hal/phydm/halphyrf_win.h	/^typedef enum _PWRTRACK_CONTROL_METHOD {$/;"	g
-_PageWrite	hal/rtl8723d/rtl8723d_hal_init.c	/^_PageWrite($/;"	f	file:
-_PathDiv_Parameter_define_	hal/phydm/phydm_pathdiv.h	/^typedef struct _PathDiv_Parameter_define_$/;"	s
-_Phy_Rx_AGC_Info	hal/phydm/phydm_hwconfig.h	/^__PACK typedef struct _Phy_Rx_AGC_Info$/;"	s
-_Phy_Status_Rpt_8192cd	hal/phydm/phydm_hwconfig.h	/^__PACK typedef struct _Phy_Status_Rpt_8192cd {$/;"	s
-_Phy_Status_Rpt_8812	hal/phydm/phydm_hwconfig.h	/^typedef struct _Phy_Status_Rpt_8812 {$/;"	s
-_Phy_Status_Rpt_Jaguar2_Type0	hal/phydm/phydm_hwconfig.h	/^typedef struct _Phy_Status_Rpt_Jaguar2_Type0 {$/;"	s
-_Phy_Status_Rpt_Jaguar2_Type1	hal/phydm/phydm_hwconfig.h	/^typedef struct _Phy_Status_Rpt_Jaguar2_Type1 {$/;"	s
-_Phy_Status_Rpt_Jaguar2_Type2	hal/phydm/phydm_hwconfig.h	/^typedef struct _Phy_Status_Rpt_Jaguar2_Type2 {$/;"	s
-_Phydm_ra_dbg_para	hal/phydm/phydm_rainfo.h	/^typedef enum _Phydm_ra_dbg_para {$/;"	g
-_RATEID_IDX_	include/ieee80211.h	/^typedef enum _RATEID_IDX_ {$/;"	g
-_RATE_SECTION	include/ieee80211.h	/^typedef enum _RATE_SECTION {$/;"	g
-_RATR_TABLE_MODE	include/ieee80211.h	/^typedef enum _RATR_TABLE_MODE {$/;"	g
-_REASOCREQ_IE_OFFSET_	include/wifi.h	566;"	d
-_REASOCRSP_IE_OFFSET_	include/wifi.h	567;"	d
-_RECV_OSDEP_C_	os_dep/linux/recv_linux.c	20;"	d	file:
-_REGULATION_TXPWR_LMT	include/hal_com_phycfg.h	/^typedef enum _REGULATION_TXPWR_LMT {$/;"	g
-_REG_PREAMBLE_MODE	include/rtw_rf.h	/^enum	_REG_PREAMBLE_MODE {$/;"	g
-_RESERVED47_	include/wifi.h	613;"	d
-_RESERVED_FRAME_TYPE_	include/wifi.h	552;"	d
-_RETRY_	include/wifi.h	267;"	d
-_RF_CONTENT	include/hal_phy.h	/^typedef enum _RF_CONTENT {$/;"	g
-_RF_PATH	include/rtw_rf.h	/^typedef enum _RF_PATH {$/;"	g
-_RF_TX_NUM	include/hal_com_phycfg.h	/^typedef enum _RF_TX_NUM {$/;"	g
-_RF_TYPE	include/hal_phy.h	/^typedef	enum _RF_TYPE {$/;"	g
-_RIC_Descriptor_IE_	include/wifi.h	603;"	d
-_RND	include/osdep_service.h	433;"	d
-_RND128	include/osdep_service.h	/^__inline static u32 _RND128(u32 sz)$/;"	f
-_RND256	include/osdep_service.h	/^__inline static u32 _RND256(u32 sz)$/;"	f
-_RND4	include/osdep_service.h	/^__inline static u32 _RND4(u32 sz)$/;"	f
-_RND512	include/osdep_service.h	/^__inline static u32 _RND512(u32 sz)$/;"	f
-_RND8	include/osdep_service.h	/^__inline static u32 _RND8(u32 sz)$/;"	f
-_RSN_IE_2_	include/wifi.h	586;"	d
-_RSON_4WAY_HNDSHK_TIMEOUT_	include/wifi.h	/^	_RSON_4WAY_HNDSHK_TIMEOUT_		= 15,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_AKMP_NOT_VALID_	include/wifi.h	/^	_RSON_AKMP_NOT_VALID_			= 20,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_ASOC_NOT_AUTH_	include/wifi.h	/^	_RSON_ASOC_NOT_AUTH_			= 9,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_AUTH_NO_LONGER_VALID_	include/wifi.h	/^	_RSON_AUTH_NO_LONGER_VALID_		= 2,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_CLS2_	include/wifi.h	/^	_RSON_CLS2_						= 6,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_CLS3_	include/wifi.h	/^	_RSON_CLS3_						= 7,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_CODE_	include/wifi.h	701;"	d
-_RSON_DEAUTH_STA_LEAVING_	include/wifi.h	/^	_RSON_DEAUTH_STA_LEAVING_		= 3,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_DIFF_IE_	include/wifi.h	/^	_RSON_DIFF_IE_					= 17,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_DISAOC_STA_LEAVING_	include/wifi.h	/^	_RSON_DISAOC_STA_LEAVING_		= 8,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_GROUP_KEY_UPDATE_TIMEOUT_	include/wifi.h	/^	_RSON_GROUP_KEY_UPDATE_TIMEOUT_	= 16,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_IEEE_802DOT1X_AUTH_FAIL_	include/wifi.h	/^	_RSON_IEEE_802DOT1X_AUTH_FAIL_	= 23,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_INACTIVITY_	include/wifi.h	/^	_RSON_INACTIVITY_				= 4,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_INVALID_IE_	include/wifi.h	/^	_RSON_INVALID_IE_				= 13,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_INVALID_RSNE_CAP_	include/wifi.h	/^	_RSON_INVALID_RSNE_CAP_			= 22,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_MIC_FAILURE_	include/wifi.h	/^	_RSON_MIC_FAILURE_				= 14,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_MLTCST_CIPHER_NOT_VALID_	include/wifi.h	/^	_RSON_MLTCST_CIPHER_NOT_VALID_	= 18,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_PMK_NOT_AVAILABLE_	include/wifi.h	/^	_RSON_PMK_NOT_AVAILABLE_		= 24,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_RESERVED_	include/wifi.h	/^	_RSON_RESERVED_					= 0,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_TDLS_TEAR_TOOFAR_	include/wifi.h	/^	_RSON_TDLS_TEAR_TOOFAR_			= 25,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_TDLS_TEAR_UN_RSN_	include/wifi.h	/^	_RSON_TDLS_TEAR_UN_RSN_			= 26,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_UNABLE_HANDLE_	include/wifi.h	/^	_RSON_UNABLE_HANDLE_			= 5,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_UNICST_CIPHER_NOT_VALID_	include/wifi.h	/^	_RSON_UNICST_CIPHER_NOT_VALID_	= 19,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_UNSPECIFIED_	include/wifi.h	/^	_RSON_UNSPECIFIED_				= 1,$/;"	e	enum:WIFI_REASON_CODE
-_RSON_UNSUPPORT_RSNE_VER_	include/wifi.h	/^	_RSON_UNSUPPORT_RSNE_VER_		= 21,$/;"	e	enum:WIFI_REASON_CODE
-_RSSI_STA	include/sta_info.h	/^typedef struct _RSSI_STA {$/;"	s
-_RSVDPAGE_LOC	include/hal_com_h2c.h	/^typedef struct _RSVDPAGE_LOC {$/;"	s
-_RTL8188E_H2C_CMD_ID	include/rtl8188e_cmd.h	/^typedef enum _RTL8188E_H2C_CMD_ID {$/;"	g
-_RTL8188E_SRESET_H_	include/rtl8188e_sreset.h	21;"	d
-_RTL8188F_SRESET_H_	include/rtl8188f_sreset.h	21;"	d
-_RTL8192E_H2C_CMD	include/rtl8192e_cmd.h	/^typedef enum _RTL8192E_H2C_CMD {$/;"	g
-_RTL8703B_SRESET_H_	include/rtl8703b_sreset.h	21;"	d
-_RTL8712_RF_MIMO_CONFIG_	include/rtw_rf.h	/^enum _RTL8712_RF_MIMO_CONFIG_ {$/;"	g
-_RTL871X_BYTEORDER_H_	include/rtw_byteorder.h	21;"	d
-_RTL8723B_SRESET_H_	include/rtl8723b_sreset.h	21;"	d
-_RTL8723DS_LED_C_	hal/rtl8723d/sdio/rtl8723ds_led.c	20;"	d	file:
-_RTL8723DS_RECV_C_	hal/rtl8723d/sdio/rtl8723ds_recv.c	20;"	d	file:
-_RTL8723DS_XMIT_C_	hal/rtl8723d/sdio/rtl8723ds_xmit.c	20;"	d	file:
-_RTL8723D_CMD_C_	hal/rtl8723d/rtl8723d_cmd.c	20;"	d	file:
-_RTL8723D_DM_C_	hal/rtl8723d/rtl8723d_dm.c	27;"	d	file:
-_RTL8723D_PHYCFG_C_	hal/rtl8723d/rtl8723d_phycfg.c	20;"	d	file:
-_RTL8723D_REDESC_C_	hal/rtl8723d/rtl8723d_rxdesc.c	20;"	d	file:
-_RTL8723D_SRESET_C_	hal/rtl8723d/rtl8723d_sreset.c	20;"	d	file:
-_RTL8723D_SRESET_H_	include/rtl8723d_sreset.h	21;"	d
-_RTL8812A_SRESET_H_	include/rtl8192e_sreset.h	21;"	d
-_RTL8812A_SRESET_H_	include/rtl8812a_sreset.h	21;"	d
-_RTL8812_H2C_CMD	include/rtl8812a_cmd.h	/^typedef enum _RTL8812_H2C_CMD {$/;"	g
-_RTL8814A_SRESET_H_	include/rtl8814a_sreset.h	21;"	d
-_RTL8821CS_HAL_H_	include/rtl8821cs_hal.h	21;"	d
-_RTL8821CU_HAL_H_	include/rtl8821cu_hal.h	21;"	d
-_RTL8821C_HAL_H_	include/rtl8821c_hal.h	21;"	d
-_RTL8822BE_HAL_H_	include/rtl8822be_hal.h	21;"	d
-_RTL8822BS_HAL_H_	include/rtl8822bs_hal.h	21;"	d
-_RTL8822BU_HAL_H_	include/rtl8822bu_hal.h	21;"	d
-_RTL8822B_HAL_H_	include/rtl8822b_hal.h	21;"	d
-_RTL_EXT_C2H_EVT	include/rtw_bt_mp.h	/^typedef enum _RTL_EXT_C2H_EVT {$/;"	g
-_RTW_AP_C_	core/rtw_ap.c	20;"	d	file:
-_RTW_BEAMFORMING_C_	core/rtw_beamforming.c	20;"	d	file:
-_RTW_BR_EXT_C_	core/rtw_br_ext.c	20;"	d	file:
-_RTW_BR_EXT_H_	include/rtw_br_ext.h	21;"	d
-_RTW_CFGVENDOR_H_	os_dep/linux/rtw_cfgvendor.h	22;"	d
-_RTW_CMD_C_	core/rtw_cmd.c	20;"	d	file:
-_RTW_DBG	include/rtw_debug.h	237;"	d
-_RTW_DBG	include/rtw_debug.h	238;"	d
-_RTW_DBG	include/rtw_debug.h	51;"	d
-_RTW_DBG	include/rtw_debug.h	64;"	d
-_RTW_DBG_DUMP	include/rtw_debug.h	260;"	d
-_RTW_DBG_DUMP	include/rtw_debug.h	261;"	d
-_RTW_DBG_DUMP	include/rtw_debug.h	72;"	d
-_RTW_DEBUG_C_	core/rtw_debug.c	20;"	d	file:
-_RTW_EEPROM_C_	core/rtw_eeprom.c	20;"	d	file:
-_RTW_EFUSE_C_	core/efuse/rtw_efuse.c	20;"	d	file:
-_RTW_ERR	include/rtw_debug.h	212;"	d
-_RTW_ERR	include/rtw_debug.h	213;"	d
-_RTW_ERR	include/rtw_debug.h	48;"	d
-_RTW_ERR	include/rtw_debug.h	61;"	d
-_RTW_EVENT_H_	include/rtw_event.h	21;"	d
-_RTW_HALMAC_MODE	hal/hal_halmac.h	/^typedef enum _RTW_HALMAC_MODE {$/;"	g
-_RTW_HT_H_	include/rtw_ht.h	21;"	d
-_RTW_INFO	include/rtw_debug.h	229;"	d
-_RTW_INFO	include/rtw_debug.h	230;"	d
-_RTW_INFO	include/rtw_debug.h	50;"	d
-_RTW_INFO	include/rtw_debug.h	63;"	d
-_RTW_INFO_DUMP	include/rtw_debug.h	246;"	d
-_RTW_INFO_DUMP	include/rtw_debug.h	247;"	d
-_RTW_INFO_DUMP	include/rtw_debug.h	71;"	d
-_RTW_IOCTL_H_	include/rtw_ioctl.h	21;"	d
-_RTW_IOCTL_QUERY_C_	core/rtw_ioctl_query.c	20;"	d	file:
-_RTW_IOCTL_QUERY_H_	include/rtw_ioctl_query.h	21;"	d
-_RTW_IOCTL_RTL_C_	core/rtw_ioctl_rtl.c	20;"	d	file:
-_RTW_IOCTL_RTL_H_	include/rtw_ioctl_rtl.h	21;"	d
-_RTW_IOCTL_SET_C_	core/rtw_ioctl_set.c	20;"	d	file:
-_RTW_IO_C_	core/rtw_io.c	50;"	d	file:
-_RTW_IO_H_	include/rtw_io.h	22;"	d
-_RTW_MCC_H_	include/rtw_mcc.h	22;"	d
-_RTW_MI_C_	core/rtw_mi.c	20;"	d	file:
-_RTW_MLME_C_	core/rtw_mlme.c	20;"	d	file:
-_RTW_MLME_EXT_C_	core/rtw_mlme_ext.c	20;"	d	file:
-_RTW_MP_C_	core/rtw_mp.c	20;"	d	file:
-_RTW_MP_H_	include/rtw_mp.h	21;"	d
-_RTW_MP_IOCTL_C_	core/rtw_mp_ioctl.c	20;"	d	file:
-_RTW_MP_IOCTL_H_	include/rtw_mp_ioctl.h	21;"	d
-_RTW_P2P_C_	core/rtw_p2p.c	20;"	d	file:
-_RTW_PRINT	include/rtw_debug.h	204;"	d
-_RTW_PRINT	include/rtw_debug.h	205;"	d
-_RTW_PRINT	include/rtw_debug.h	47;"	d
-_RTW_PRINT	include/rtw_debug.h	60;"	d
-_RTW_PRINT_SEL	include/rtw_debug.h	295;"	d
-_RTW_PRINT_SEL	include/rtw_debug.h	296;"	d
-_RTW_PRINT_SEL	include/rtw_debug.h	52;"	d
-_RTW_PRINT_SEL	include/rtw_debug.h	65;"	d
-_RTW_PWRCTRL_C_	core/rtw_pwrctrl.c	20;"	d	file:
-_RTW_QOS_H_	include/rtw_qos.h	23;"	d
-_RTW_RECV_C_	core/rtw_recv.c	20;"	d	file:
-_RTW_RECV_H_	include/rtw_recv.h	21;"	d
-_RTW_RF_C_	core/rtw_rf.c	20;"	d	file:
-_RTW_SDIO_C_	core/rtw_sdio.c	19;"	d	file:
-_RTW_SDIO_H_	include/rtw_sdio.h	20;"	d
-_RTW_SECURITY_C_	core/rtw_security.c	20;"	d	file:
-_RTW_SRESET_H_	include/rtw_sreset.h	21;"	d
-_RTW_STA_MGT_C_	core/rtw_sta_mgt.c	20;"	d	file:
-_RTW_TDLS_C_	core/rtw_tdls.c	20;"	d	file:
-_RTW_VHT_C	core/rtw_vht.c	20;"	d	file:
-_RTW_VHT_H_	include/rtw_vht.h	21;"	d
-_RTW_WARN	include/rtw_debug.h	221;"	d
-_RTW_WARN	include/rtw_debug.h	222;"	d
-_RTW_WARN	include/rtw_debug.h	49;"	d
-_RTW_WARN	include/rtw_debug.h	62;"	d
-_RTW_WIFI_FT_CAPABILITY	include/rtw_mlme.h	/^typedef enum _RTW_WIFI_FT_CAPABILITY {$/;"	g
-_RTW_WIFI_FT_STA_STATUS	include/rtw_mlme.h	/^typedef enum _RTW_WIFI_FT_STA_STATUS {$/;"	g
-_RTW_WLAN_UTIL_C_	core/rtw_wlan_util.c	20;"	d	file:
-_RTW_XMIT_C_	core/rtw_xmit.c	20;"	d	file:
-_RTW_XMIT_H_	include/rtw_xmit.h	21;"	d
-_RT_8188E_FIRMWARE_HDR	include/rtl8188e_hal.h	/^typedef struct _RT_8188E_FIRMWARE_HDR {$/;"	s
-_RT_8188F_FIRMWARE_HDR	include/rtl8188f_hal.h	/^typedef struct _RT_8188F_FIRMWARE_HDR {$/;"	s
-_RT_8703B_FIRMWARE_HDR	include/rtl8703b_hal.h	/^typedef struct _RT_8703B_FIRMWARE_HDR {$/;"	s
-_RT_8723B_FIRMWARE_HDR	include/rtl8723b_hal.h	/^typedef struct _RT_8723B_FIRMWARE_HDR {$/;"	s
-_RT_8723D_FIRMWARE_HDR	include/rtl8723d_hal.h	/^typedef struct _RT_8723D_FIRMWARE_HDR {$/;"	s
-_RT_ADCSMP	hal/phydm/phydm_adc_sampling.h	/^typedef struct _RT_ADCSMP {$/;"	s
-_RT_ADCSMP_STATE	hal/phydm/phydm_adc_sampling.h	/^typedef enum _RT_ADCSMP_STATE {$/;"	g
-_RT_ADCSMP_STRING	hal/phydm/phydm_adc_sampling.h	/^typedef struct _RT_ADCSMP_STRING {$/;"	s
-_RT_ADCSMP_TRIG_SEL	hal/phydm/phydm_adc_sampling.h	/^typedef enum _RT_ADCSMP_TRIG_SEL {$/;"	g
-_RT_ADCSMP_TRIG_SIG_SEL	hal/phydm/phydm_adc_sampling.h	/^typedef enum _RT_ADCSMP_TRIG_SIG_SEL {$/;"	g
-_RT_AMPDU_BRUST_MODE	include/hal_data.h	/^typedef enum _RT_AMPDU_BRUST_MODE {$/;"	g
-_RT_BEAMFORMEE_ENTRY	hal/phydm/phydm_beamforming.h	/^typedef struct _RT_BEAMFORMEE_ENTRY {$/;"	s
-_RT_BEAMFORMER_ENTRY	hal/phydm/phydm_beamforming.h	/^typedef struct _RT_BEAMFORMER_ENTRY {$/;"	s
-_RT_BEAMFORMING_INFO	hal/phydm/phydm_beamforming.h	/^typedef struct _RT_BEAMFORMING_INFO {$/;"	s
-_RT_BEAMFORMING_OID_INFO	hal/phydm/phydm_beamforming.h	/^typedef struct _RT_BEAMFORMING_OID_INFO {$/;"	s
-_RT_BEAMFORM_STAINFO	hal/phydm/phydm_beamforming.h	/^typedef struct _RT_BEAMFORM_STAINFO {$/;"	s
-_RT_CHANNEL_DOMAIN	include/rtw_mlme_ext.h	/^typedef enum _RT_CHANNEL_DOMAIN {$/;"	g
-_RT_CHANNEL_DOMAIN_2G	include/rtw_mlme_ext.h	/^typedef enum _RT_CHANNEL_DOMAIN_2G {$/;"	g
-_RT_CHANNEL_DOMAIN_5G	include/rtw_mlme_ext.h	/^typedef enum _RT_CHANNEL_DOMAIN_5G {$/;"	g
-_RT_CHANNEL_DOMAIN_NEW	hal/phydm/rtchnlplan.h	/^typedef enum _RT_CHANNEL_DOMAIN_NEW$/;"	g
-_RT_CHANNEL_INFO	include/rtw_mlme_ext.h	/^typedef struct _RT_CHANNEL_INFO {$/;"	s
-_RT_CHANNEL_PLAN	include/rtw_mlme_ext.h	/^typedef struct _RT_CHANNEL_PLAN {$/;"	s
-_RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE	hal/phydm/rtchnlplan.h	/^typedef struct _RT_CHANNEL_PLAN_COUNTRY_TRANSFER_TABLE$/;"	s
-_RT_CHANNEL_PLAN_MAP	include/rtw_mlme_ext.h	/^typedef struct _RT_CHANNEL_PLAN_MAP {$/;"	s
-_RT_CHANNEL_PLAN_MAXPWR	hal/phydm/rtchnlplan.h	/^typedef struct _RT_CHANNEL_PLAN_MAXPWR$/;"	s
-_RT_CHANNEL_PLAN_NEW	hal/phydm/rtchnlplan.h	/^typedef struct _RT_CHANNEL_PLAN_NEW$/;"	s
-_RT_CHNLPLAN_SREQ	hal/phydm/rtchnlplan.h	/^typedef enum _RT_CHNLPLAN_SREQ$/;"	g
-_RT_CHNL_PLAN_LIMIT	hal/phydm/rtchnlplan.h	/^typedef struct _RT_CHNL_PLAN_LIMIT$/;"	s
-_RT_CHNL_PLAN_PWR_LIMIT	hal/phydm/rtchnlplan.h	/^typedef struct _RT_CHNL_PLAN_PWR_LIMIT$/;"	s
-_RT_COUNTRY_DEFINE_NUM	hal/phydm/rtchnlplan.h	/^typedef enum _RT_COUNTRY_DEFINE_NUM$/;"	g
-_RT_CUSTOMER_ID	include/rtw_eeprom.h	/^typedef enum _RT_CUSTOMER_ID {$/;"	g
-_RT_EEPROM_TYPE	include/hal_intf.h	/^typedef	enum _RT_EEPROM_TYPE {$/;"	g
-_RT_FIRMWARE	include/rtl8188f_hal.h	/^typedef struct _RT_FIRMWARE {$/;"	s
-_RT_FIRMWARE	include/rtl8703b_hal.h	/^typedef struct _RT_FIRMWARE {$/;"	s
-_RT_FIRMWARE	include/rtl8723b_hal.h	/^typedef struct _RT_FIRMWARE {$/;"	s
-_RT_FIRMWARE	include/rtl8723d_hal.h	/^typedef struct _RT_FIRMWARE {$/;"	s
-_RT_FIRMWARE_8188E	include/rtl8188e_hal.h	/^typedef struct _RT_FIRMWARE_8188E {$/;"	s
-_RT_FIRMWARE_8192E	include/rtl8192e_hal.h	/^typedef struct _RT_FIRMWARE_8192E {$/;"	s
-_RT_FIRMWARE_8812	include/rtl8812a_hal.h	/^typedef struct _RT_FIRMWARE_8812 {$/;"	s
-_RT_FIRMWARE_8814	include/rtl8814a_hal.h	/^typedef struct _RT_FIRMWARE_8814 {$/;"	s
-_RT_HT_INF0_CAP	include/rtw_ht.h	/^typedef enum _RT_HT_INF0_CAP {$/;"	g
-_RT_HT_INF1_CAP	include/rtw_ht.h	/^typedef enum _RT_HT_INF1_CAP {$/;"	g
-_RT_ISR_CONTENT	include/drv_types_pci.h	/^typedef struct _RT_ISR_CONTENT {$/;"	s
-_RT_LINK_DETECT_T	include/rtw_mlme.h	/^typedef struct _RT_LINK_DETECT_T {$/;"	s
-_RT_MEDIA_STATUS	include/hal_com.h	/^typedef enum _RT_MEDIA_STATUS {$/;"	g
-_RT_MULTI_FUNC	include/hal_data.h	/^typedef enum _RT_MULTI_FUNC {$/;"	g
-_RT_NDPA_STA_INFO	hal/phydm/phydm_beamforming.h	/^typedef struct _RT_NDPA_STA_INFO {$/;"	s
-_RT_PCI_CAPABILITIES_HEADER	include/drv_types_pci.h	/^typedef struct _RT_PCI_CAPABILITIES_HEADER {$/;"	s
-_RT_PMAC_PKT_INFO	include/rtw_mp.h	/^typedef struct _RT_PMAC_PKT_INFO {$/;"	s
-_RT_PMAC_TX_INFO	include/rtw_mp.h	/^typedef struct _RT_PMAC_TX_INFO {$/;"	s
-_RT_PMKID_LIST	include/rtw_security.h	/^typedef struct _RT_PMKID_LIST {$/;"	s
-_RT_POLARITY_CTL	include/hal_data.h	/^typedef enum _RT_POLARITY_CTL {$/;"	g
-_RT_REGULATION_COMMON	hal/phydm/rtchnlplan.h	/^typedef enum _RT_REGULATION_COMMON$/;"	g
-_RT_REGULATION_DOMAIN_2G	hal/phydm/rtchnlplan.h	/^typedef enum _RT_REGULATION_DOMAIN_2G$/;"	g
-_RT_REGULATION_DOMAIN_5G	hal/phydm/rtchnlplan.h	/^typedef enum _RT_REGULATION_DOMAIN_5G$/;"	g
-_RT_REGULATOR_MODE	include/hal_data.h	/^typedef enum _RT_REGULATOR_MODE {$/;"	g
-_RT_RF_TYPE_DEFINITION	include/rtw_rf.h	/^typedef	enum _RT_RF_TYPE_DEFINITION {$/;"	g
-_RT_SCAN_TYPE	include/rtw_mlme.h	/^typedef enum _RT_SCAN_TYPE {$/;"	g
-_RT_SCAN_TYPE_NEW	hal/phydm/rtchnlplan.h	/^typedef enum _RT_SCAN_TYPE_NEW$/;"	g
-_RT_SOUNDING_INFO	hal/phydm/phydm_beamforming.h	/^typedef struct _RT_SOUNDING_INFO {$/;"	s
-_RT_SPINLOCK_TYPE	hal/phydm/phydm_types.h	/^typedef enum _RT_SPINLOCK_TYPE{$/;"	g
-_RT_USB_BREQUEST	include/usb_vendor_req.h	/^typedef enum _RT_USB_BREQUEST {$/;"	g
-_RT_USB_WVALUE	include/usb_vendor_req.h	/^typedef enum _RT_USB_WVALUE {$/;"	g
-_RT_WAPI_BKID	include/rtw_wapi.h	/^typedef struct  _RT_WAPI_BKID {$/;"	s
-_RT_WAPI_CAM_ENTRY	include/rtw_wapi.h	/^typedef struct _RT_WAPI_CAM_ENTRY {$/;"	s
-_RT_WAPI_KEY	include/rtw_wapi.h	/^typedef struct  _RT_WAPI_KEY {$/;"	s
-_RT_WAPI_PACKET_TYPE	include/rtw_wapi.h	/^typedef enum _RT_WAPI_PACKET_TYPE {$/;"	g
-_RT_WAPI_STA_INFO	include/rtw_wapi.h	/^typedef struct	_RT_WAPI_STA_INFO {$/;"	s
-_RT_WAPI_T	include/rtw_wapi.h	/^typedef struct _RT_WAPI_T {$/;"	s
-_RW_REG	include/rtw_mp_ioctl.h	/^typedef struct _RW_REG {$/;"	s
-_RXAggrSwitch	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _RXAggrSwitch(PADAPTER padapter, u8 enable)$/;"	f	file:
-_RXERR_RPT_SEL	include/hal_com_reg.h	451;"	d
-_RXERR_RPT_SEL	include/rtl8822b_hal.h	63;"	d
-_RX_AGG_MODE	include/hal_data.h	/^typedef enum _RX_AGG_MODE {$/;"	g
-_RX_PACKET_TYPE	include/rtw_recv.h	/^typedef enum _RX_PACKET_TYPE {$/;"	g
-_R_ANTENNA_SELECT_CCK	include/hal_phy.h	/^typedef struct _R_ANTENNA_SELECT_CCK {$/;"	s
-_R_ANTENNA_SELECT_OFDM	include/hal_phy.h	/^typedef struct _R_ANTENNA_SELECT_OFDM {$/;"	s
-_Rate_Adaptive_Table_	hal/phydm/phydm_rainfo.h	/^typedef struct _Rate_Adaptive_Table_ {$/;"	s
-_ReadEfuseInfo8723DS	hal/rtl8723d/sdio/sdio_halinit.c	/^_ReadEfuseInfo8723DS($/;"	f	file:
-_ReadPROMContent	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _ReadPROMContent($/;"	f	file:
-_ReadRFType	hal/rtl8723d/sdio/sdio_halinit.c	/^_ReadRFType($/;"	f	file:
-_Read_MACREG	include/rtw_mlme_ext.h	/^	GEN_EVT_CODE(_Read_MACREG) = 0, \/*0*\/$/;"	e	enum:rtw_c2h_event
-_ResetDigitalProcedure1	hal/rtl8723d/rtl8723d_hal_init.c	/^void _ResetDigitalProcedure1(PADAPTER padapter, BOOLEAN bWithoutHWSM)$/;"	f
-_ResetDigitalProcedure1_8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^void _ResetDigitalProcedure1_8723D(PADAPTER padapter, BOOLEAN bWithoutHWSM)$/;"	f
-_ResetDigitalProcedure2	hal/rtl8723d/rtl8723d_hal_init.c	/^void _ResetDigitalProcedure2(PADAPTER padapter)$/;"	f
-_RfPowerSave	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _RfPowerSave(PADAPTER padapter)$/;"	f	file:
-_SDIO_HALINIT_C_	hal/rtl8723d/sdio/sdio_halinit.c	20;"	d	file:
-_SDIO_OPS_C_	hal/rtl8723d/sdio/sdio_ops.c	19;"	d	file:
-_SDIO_OPS_LINUX_C_	os_dep/linux/sdio_ops_linux.c	19;"	d	file:
-_SDIO_OPS_WINCE_H_	include/sdio_ops_ce.h	21;"	d
-_SDIO_OPS_XP_H_	include/sdio_ops_xp.h	21;"	d
-_SETPWRMODE_PARM	include/rtl8188e_cmd.h	/^typedef struct _SETPWRMODE_PARM {$/;"	s
-_SETPWRMODE_PARM	include/rtl8192e_cmd.h	/^typedef struct _SETPWRMODE_PARM {$/;"	s
-_SIFSTIME_	include/wifi.h	560;"	d
-_SKB_FRAME_TYPE_	include/wifi.h	553;"	d
-_SMART_ANTENNA_TRAINNING_	hal/phydm/phydm_antdiv.h	/^typedef struct _SMART_ANTENNA_TRAINNING_ {$/;"	s
-_SMS4_	include/rtw_security.h	31;"	d
-_SOUNDING_MODE	hal/phydm/phydm_beamforming.h	/^typedef enum _SOUNDING_MODE {$/;"	g
-_SOUNDING_MODE	include/rtw_beamforming.h	/^typedef enum _SOUNDING_MODE {$/;"	g
-_SOUNDING_STATE	include/rtw_beamforming.h	/^enum _SOUNDING_STATE {$/;"	g
-_SPEC_SIFS_CCK	include/hal_com_reg.h	1468;"	d
-_SPEC_SIFS_OFDM	include/hal_com_reg.h	1469;"	d
-_SPUR_CAL_METHOD	hal/phydm/halphyrf_ce.h	/^typedef enum _SPUR_CAL_METHOD {$/;"	g
-_SPUR_CAL_METHOD	hal/phydm/halphyrf_win.h	/^typedef enum _SPUR_CAL_METHOD {$/;"	g
-_SRC_IE_	include/wifi.h	595;"	d
-_SRL	include/hal_com_reg.h	1489;"	d
-_SSID_IE_	include/wifi.h	577;"	d
-_SSN_IE_1_	include/wifi.h	587;"	d
-_STATS_AUTH_TIMEOUT_	include/wifi.h	/^	_STATS_AUTH_TIMEOUT_		= 16,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_CAP_FAIL_	include/wifi.h	/^	_STATS_CAP_FAIL_			= 10,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_CHALLENGE_FAIL_	include/wifi.h	/^	_STATS_CHALLENGE_FAIL_		= 15,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_DECLINE_REQ_	include/wifi.h	/^	_STATS_DECLINE_REQ_			= 37,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_FAILURE_	include/wifi.h	/^	_STATS_FAILURE_				= 1,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_INVALID_PARAMETERS_	include/wifi.h	/^	_STATS_INVALID_PARAMETERS_	= 38,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_INVALID_RSNIE_	include/wifi.h	/^	_STATS_INVALID_RSNIE_			= 72,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_NOT_IN_SAME_BSS_	include/wifi.h	/^	_STATS_NOT_IN_SAME_BSS_		= 7,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_NO_ASOC_	include/wifi.h	/^	_STATS_NO_ASOC_				= 11,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_NO_SUPP_ALG_	include/wifi.h	/^	_STATS_NO_SUPP_ALG_			= 13,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_OTHER_	include/wifi.h	/^	_STATS_OTHER_				= 12,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_OUT_OF_AUTH_SEQ_	include/wifi.h	/^	_STATS_OUT_OF_AUTH_SEQ_		= 14,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_RATE_FAIL_	include/wifi.h	/^	_STATS_RATE_FAIL_			= 18,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_REFUSED_TEMPORARILY_	include/wifi.h	/^	_STATS_REFUSED_TEMPORARILY_ = 30,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_SEC_DISABLED_	include/wifi.h	/^	_STATS_SEC_DISABLED_			= 5,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_SUCCESSFUL_	include/wifi.h	/^	_STATS_SUCCESSFUL_			= 0,$/;"	e	enum:WIFI_STATUS_CODE
-_STATS_UNABLE_HANDLE_STA_	include/wifi.h	/^	_STATS_UNABLE_HANDLE_STA_	= 17,$/;"	e	enum:WIFI_STATUS_CODE
-_STATUS_CODE_	include/wifi.h	703;"	d
-_SUCCESS	include/osdep_service.h	25;"	d
-_SUPPORTEDRATES_IE_	include/wifi.h	578;"	d
-_SUPPORTED_CH_IE_	include/wifi.h	584;"	d
-_SW_Antenna_Switch_	hal/phydm/phydm_antdiv.h	/^typedef struct _SW_Antenna_Switch_$/;"	s
-_S_	core/rtw_security.c	487;"	d	file:
-_SetBBReg_CMD_	include/rtw_cmd.h	1228;"	d
-_SetMACReg_CMD_	include/rtw_cmd.h	1226;"	d
-_SetRFReg_CMD_	include/rtw_cmd.h	1230;"	d
-_SwChnlCmd	include/hal_phy.h	/^typedef struct _SwChnlCmd {$/;"	s
-_SwChnlCmdID	include/hal_phy.h	/^typedef enum _SwChnlCmdID {$/;"	g
-_TEST_MODE	include/rtw_mp.h	/^typedef enum _TEST_MODE {$/;"	g
-_TIMEOUT_ITVL_IE_	include/wifi.h	594;"	d
-_TIMESTAMP_	include/wifi.h	704;"	d
-_TIM_IE_	include/wifi.h	580;"	d
-_TKIP_	include/rtw_security.h	26;"	d
-_TKIP_WTMIC_	include/rtw_security.h	27;"	d
-_TO_DS_	include/wifi.h	264;"	d
-_TRUE	hal/phydm/phydm_types.h	163;"	d
-_TRUE	include/basic_types.h	28;"	d
-_TRUE	include/basic_types.h	30;"	d
-_TRUE	include/osdep_service.h	29;"	d
-_TRUE	include/osdep_service.h	30;"	d
-_TXBF_GET_TYPE	hal/phydm/txbf/halcomtxbf.h	/^typedef enum _TXBF_GET_TYPE{$/;"	g
-_TXBF_SET_TYPE	hal/phydm/txbf/halcomtxbf.h	/^typedef enum _TXBF_SET_TYPE{$/;"	g
-_TXDMA_BEQ_MAP	include/hal_com_reg.h	1373;"	d
-_TXDMA_BKQ_MAP	include/hal_com_reg.h	1372;"	d
-_TXDMA_CMQ_MAP	include/hal_com_reg.h	1369;"	d
-_TXDMA_HIQ_MAP	include/hal_com_reg.h	1370;"	d
-_TXDMA_MGQ_MAP	include/hal_com_reg.h	1371;"	d
-_TXDMA_VIQ_MAP	include/hal_com_reg.h	1374;"	d
-_TXDMA_VOQ_MAP	include/hal_com_reg.h	1375;"	d
-_TXPWRTRACK_CFG	hal/phydm/halphyrf_ap.h	/^typedef struct _TXPWRTRACK_CFG {$/;"	s
-_TXPWRTRACK_CFG	hal/phydm/halphyrf_ce.h	/^typedef struct _TXPWRTRACK_CFG {$/;"	s
-_TXPWRTRACK_CFG	hal/phydm/halphyrf_win.h	/^typedef struct _TXPWRTRACK_CFG {$/;"	s
-_ThreeOutPipeMapping	hal/hal_com.c	/^static VOID _ThreeOutPipeMapping($/;"	f	file:
-_TwoOutPipeMapping	hal/hal_com.c	/^_TwoOutPipeMapping($/;"	f	file:
-_TxPowerInfo24G	include/hal_pg.h	/^typedef struct _TxPowerInfo24G {$/;"	s
-_TxPowerInfo5G	include/hal_pg.h	/^typedef struct _TxPowerInfo5G {$/;"	s
-_USB_EXTENSION	include/drv_types_ce.h	/^typedef struct _USB_EXTENSION {$/;"	s
-_USB_VENDOR_REQUEST_H_	include/usb_vendor_req.h	21;"	d
-_USB_VendorReq	include/rtw_mp_ioctl.h	/^typedef struct _USB_VendorReq {$/;"	s
-_VENDOR_SPECIFIC_IE_	include/wifi.h	611;"	d
-_VHT_DATA_SC	include/rtw_rf.h	/^typedef enum _VHT_DATA_SC {$/;"	g
-_WAKEUP_REASON	include/hal_com.h	/^typedef enum _WAKEUP_REASON{$/;"	g
-_WAPI_IE_	include/wifi.h	598;"	d
-_WEP104_	include/rtw_security.h	29;"	d
-_WEP40_	include/rtw_security.h	25;"	d
-_WEP_WPA_MIXED_	include/rtw_security.h	30;"	d
-_WIFI_H_	include/wifi.h	21;"	d
-_WIRELESS_MODE	include/hal_phy.h	/^typedef enum _WIRELESS_MODE {$/;"	g
-_WLAN_BCN_INFO	include/wlan_bssdef.h	/^typedef struct _WLAN_BCN_INFO {$/;"	s
-_WLAN_BSSID_EX	include/wlan_bssdef.h	/^typedef struct _WLAN_BSSID_EX {$/;"	s
-_WLAN_HEADER_WAPI_EXTENSION	include/rtw_wapi.h	/^typedef struct _WLAN_HEADER_WAPI_EXTENSION {$/;"	s
-_WLAN_PHY_INFO	include/wlan_bssdef.h	/^typedef struct _WLAN_PHY_INFO {$/;"	s
-_WLAN_STA	hal/phydm/phydm.h	/^typedef	struct _WLAN_STA {$/;"	s
-_WL_PWR_CFG_	include/HalPwrSeqCmd.h	/^typedef struct _WL_PWR_CFG_ {$/;"	s
-_WMM_IE_Length_	include/wifi.h	747;"	d
-_WMM_Para_Element_Length_	include/wifi.h	748;"	d
-_WPA2_IE_ID_	include/rtw_security.h	45;"	d
-_WPA_IE_ID_	include/rtw_security.h	44;"	d
-_WriteBTFWtoTxPktBuf8723D	hal/rtl8723d/rtl8723d_hal_init.c	/^int _WriteBTFWtoTxPktBuf8723D($/;"	f
-_WriteFW	hal/rtl8723d/rtl8723d_hal_init.c	/^_WriteFW($/;"	f	file:
-_XMIT_OSDEP_C_	os_dep/linux/xmit_linux.c	20;"	d	file:
-__BASIC_TYPES_H__	include/basic_types.h	21;"	d
-__BIG_ENDIAN	include/byteorder/big_endian.h	24;"	d
-__BIG_ENDIAN_BITFIELD	include/byteorder/big_endian.h	27;"	d
-__CIRC_BUF_H_	include/circ_buf.h	21;"	d
-__CMD_OSDEP_H_	include/cmd_osdep.h	21;"	d
-__COMMON_C2H_H__	hal/hal_com_c2h.h	21;"	d
-__COMMON_H2C_H__	include/hal_com_h2c.h	21;"	d
-__CUSTOM_GPIO_H___	include/custom_gpio.h	2;"	d
-__CUSTOM_OID_H	include/mp_custom_oid.h	21;"	d
-__DRV_CONF_H__	include/drv_conf.h	21;"	d
-__DRV_TYPES_CE_H__	include/drv_types_ce.h	21;"	d
-__DRV_TYPES_GSPI_H__	include/drv_types_gspi.h	21;"	d
-__DRV_TYPES_H__	include/drv_types.h	28;"	d
-__DRV_TYPES_LINUX_H__	include/drv_types_linux.h	21;"	d
-__DRV_TYPES_PCI_H__	include/drv_types_pci.h	21;"	d
-__DRV_TYPES_SDIO_H__	include/drv_types_sdio.h	21;"	d
-__DRV_TYPES_XP_H__	include/drv_types_xp.h	21;"	d
-__GFP_COLD	include/osdep_service_bsd.h	577;"	d
-__GFP_COMP	include/osdep_service_bsd.h	583;"	d
-__GFP_FS	include/osdep_service_bsd.h	576;"	d
-__GFP_HARDWALL	include/osdep_service_bsd.h	586;"	d
-__GFP_HIGH	include/osdep_service_bsd.h	574;"	d
-__GFP_IO	include/osdep_service_bsd.h	575;"	d
-__GFP_NOFAIL	include/osdep_service_bsd.h	580;"	d
-__GFP_NOMEMALLOC	include/osdep_service_bsd.h	585;"	d
-__GFP_NORETRY	include/osdep_service_bsd.h	581;"	d
-__GFP_NOWARN	include/osdep_service_bsd.h	578;"	d
-__GFP_NO_GROW	include/osdep_service_bsd.h	582;"	d
-__GFP_REPEAT	include/osdep_service_bsd.h	579;"	d
-__GFP_WAIT	include/osdep_service_bsd.h	573;"	d
-__GFP_ZERO	include/osdep_service_bsd.h	584;"	d
-__GSPI_HAL_H__	include/gspi_hal.h	21;"	d
-__GSPI_OPS_H__	include/gspi_ops.h	21;"	d
-__HAL8188EPWRSEQ_H__	include/Hal8188EPwrSeq.h	23;"	d
-__HAL8723PWRSEQ_H__	include/Hal8723PwrSeq.h	2;"	d
-__HAL8812PWRSEQ_H__	include/Hal8812PwrSeq.h	23;"	d
-__HAL8814PWRSEQ_H__	include/Hal8814PwrSeq.h	23;"	d
-__HALBTC_OUT_SRC_H__	hal/btc/HalBtcOutSrc.h	2;"	d
-__HALDMOUTSRC_H__	hal/phydm/phydm.h	23;"	d
-__HALHWOUTSRC_H__	hal/phydm/phydm_hwconfig.h	23;"	d
-__HALPWRSEQCMD_H__	include/HalPwrSeqCmd.h	21;"	d
-__HAL_BTCOEX_C__	hal/hal_btcoex.c	20;"	d	file:
-__HAL_BTCOEX_H__	include/hal_btcoex.h	21;"	d
-__HAL_COMMON_H__	include/hal_com.h	21;"	d
-__HAL_COMMON_LED_H_	include/hal_com_led.h	21;"	d
-__HAL_COMMON_REG_H__	include/hal_com_reg.h	21;"	d
-__HAL_COM_PHYCFG_H__	include/hal_com_phycfg.h	21;"	d
-__HAL_COM_TXBF_H__	hal/phydm/txbf/halcomtxbf.h	2;"	d
-__HAL_DATA_H__	include/hal_data.h	21;"	d
-__HAL_DM_H__	hal/hal_dm.h	21;"	d
-__HAL_GSPI_H_	include/hal_gspi.h	21;"	d
-__HAL_IC_CFG_H__	include/hal_ic_cfg.h	21;"	d
-__HAL_INTF_H__	include/hal_intf.h	21;"	d
-__HAL_ODM_REG_H__	hal/phydm/phydm_reg.h	30;"	d
-__HAL_PG_H__	include/hal_pg.h	22;"	d
-__HAL_PHY_H__	include/hal_phy.h	21;"	d
-__HAL_PHY_REG_H__	include/hal_phy_reg.h	21;"	d
-__HAL_PHY_RF_8723D_H__	hal/phydm/rtl8723d/halphyrf_8723d.h	22;"	d
-__HAL_PHY_RF_H__	hal/phydm/halphyrf_ap.h	22;"	d
-__HAL_PHY_RF_H__	hal/phydm/halphyrf_ce.h	22;"	d
-__HAL_PHY_RF_H__	hal/phydm/halphyrf_win.h	22;"	d
-__HAL_SDIO_H_	include/hal_sdio.h	21;"	d
-__HAL_TXBF_8192E_H__	hal/phydm/txbf/haltxbf8192e.h	2;"	d
-__HAL_TXBF_8814A_H__	hal/phydm/txbf/haltxbf8814a.h	2;"	d
-__HAL_TXBF_8822B_H__	hal/phydm/txbf/haltxbf8822b.h	2;"	d
-__HAL_TXBF_INTERFACE_H__	hal/phydm/txbf/haltxbfinterface.h	2;"	d
-__HAL_TXBF_JAGUAR_H__	hal/phydm/txbf/haltxbfjaguar.h	2;"	d
-__HAL_VERSION_DEF_H__	include/HalVerDef.h	21;"	d
-__IEEE80211_EXT_H	include/ieee80211_ext.h	21;"	d
-__IEEE80211_H	include/ieee80211.h	21;"	d
-__INC_ADCSMP_H	hal/phydm/phydm_adc_sampling.h	2;"	d
-__INC_ETHERNET_H	include/ethernet.h	22;"	d
-__INC_HAL8188EPHYCFG_H__	include/Hal8188EPhyCfg.h	21;"	d
-__INC_HAL8188EPHYREG_H__	include/Hal8188EPhyReg.h	21;"	d
-__INC_HAL8188FDESC_H	include/rtl8188f_xmit.h	28;"	d
-__INC_HAL8188FPHYCFG_H__	include/Hal8188FPhyCfg.h	21;"	d
-__INC_HAL8188FPHYREG_H__	include/Hal8188FPhyReg.h	21;"	d
-__INC_HAL8192EPHYCFG_H__	include/Hal8192EPhyCfg.h	21;"	d
-__INC_HAL8192EPHYREG_H	include/Hal8192EPhyReg.h	26;"	d
-__INC_HAL8703BDESC_H	include/rtl8703b_xmit.h	28;"	d
-__INC_HAL8703BPHYCFG_H__	include/Hal8703BPhyCfg.h	21;"	d
-__INC_HAL8703BPHYREG_H__	include/Hal8703BPhyReg.h	21;"	d
-__INC_HAL8723BDESC_H	include/rtl8723b_xmit.h	28;"	d
-__INC_HAL8723BPHYCFG_H__	include/Hal8723BPhyCfg.h	21;"	d
-__INC_HAL8723BPHYREG_H__	include/Hal8723BPhyReg.h	21;"	d
-__INC_HAL8723DDESC_H	include/rtl8723d_xmit.h	28;"	d
-__INC_HAL8723DPHYCFG_H__	include/Hal8723DPhyCfg.h	21;"	d
-__INC_HAL8723DPHYREG_H__	include/Hal8723DPhyReg.h	21;"	d
-__INC_HAL8723DREG_H	hal/phydm/rtl8723d/hal8723dreg.h	19;"	d
-__INC_HAL8812PHYCFG_H__	include/Hal8812PhyCfg.h	21;"	d
-__INC_HAL8812PHYREG_H__	include/Hal8812PhyReg.h	21;"	d
-__INC_HAL8814PHYCFG_H__	include/Hal8814PhyCfg.h	21;"	d
-__INC_HAL8814PHYREG_H__	include/Hal8814PhyReg.h	21;"	d
-__INC_HW_IMG_H	hal/phydm/halhwimg.h	3;"	d
-__INC_MP_BB_HW_IMG_8723D_H	hal/phydm/rtl8723d/halhwimg8723d_bb.h	24;"	d
-__INC_MP_FW_HW_IMG_8723D_H	hal/phydm/rtl8723d/halhwimg8723d_fw.h	24;"	d
-__INC_MP_MAC_HW_IMG_8723D_H	hal/phydm/rtl8723d/halhwimg8723d_mac.h	24;"	d
-__INC_MP_RF_HW_IMG_8723D_H	hal/phydm/rtl8723d/halhwimg8723d_rf.h	24;"	d
-__INC_ODM_REGCONFIG_H_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.h	21;"	d
-__INC_PHYDM_BEAMFORMING_H	hal/phydm/phydm_beamforming.h	2;"	d
-__INC_WAPI_H	include/rtw_wapi.h	2;"	d
-__IOCTL_CFG80211_H__	os_dep/linux/ioctl_cfg80211.h	21;"	d
-__LITTLE_ENDIAN	include/byteorder/little_endian.h	24;"	d
-__LITTLE_ENDIAN_BITFIELD	include/byteorder/little_endian.h	27;"	d
-__MLME_OSDEP_H_	include/mlme_osdep.h	21;"	d
-__MP_PRECOMP_H__	hal/btc/Mp_Precomp.h	21;"	d
-__NIC_SPEC_H__	include/nic_spec.h	23;"	d
-__ODMNOISEMONITOR_H__	hal/phydm/phydm_noisemonitor.h	21;"	d
-__ODM_DBG_H__	hal/phydm/phydm_debug.h	23;"	d
-__ODM_INTERFACE_H__	hal/phydm/phydm_interface.h	23;"	d
-__ODM_PRECOMP_H__	hal/phydm/phydm_precomp.h	22;"	d
-__ODM_REGDEFINE11AC_H__	hal/phydm/phydm_regdefine11ac.h	22;"	d
-__ODM_REGDEFINE11N_H__	hal/phydm/phydm_regdefine11n.h	22;"	d
-__ODM_RTL8723D_H__	hal/phydm/rtl8723d/phydm_rtl8723d.h	21;"	d
-__ODM_TYPES_H__	hal/phydm/phydm_types.h	21;"	d
-__OSDEP_BSD_SERVICE_H_	include/osdep_service_bsd.h	21;"	d
-__OSDEP_CE_SERVICE_H_	include/osdep_service_ce.h	22;"	d
-__OSDEP_INTF_H_	include/osdep_intf.h	22;"	d
-__OSDEP_LINUX_SERVICE_H_	include/osdep_service_linux.h	21;"	d
-__OSDEP_LINUX_SERVICE_H_	include/osdep_service_xp.h	21;"	d
-__OSDEP_SERVICE_H_	include/osdep_service.h	21;"	d
-__PACK	hal/phydm/phydm_precomp.h	52;"	d
-__PACK	hal/phydm/phydm_precomp.h	57;"	d
-__PCI_HAL_H__	include/pci_hal.h	21;"	d
-__PCI_OPS_H_	include/pci_ops.h	21;"	d
-__PCI_OSINTF_H	include/pci_osintf.h	21;"	d
-__PHYDKFREE_H__	hal/phydm/phydm_kfree.h	23;"	d
-__PHYDMACS_H__	hal/phydm/phydm_acs.h	22;"	d
-__PHYDMADAPTIVITY_H__	hal/phydm/phydm_adaptivity.h	23;"	d
-__PHYDMANTDECT_H__	hal/phydm/phydm_antdect.h	22;"	d
-__PHYDMANTDIV_H__	hal/phydm/phydm_antdiv.h	22;"	d
-__PHYDMCCX_H__	hal/phydm/phydm_ccx.h	2;"	d
-__PHYDMCFOTRACK_H__	hal/phydm/phydm_cfotracking.h	22;"	d
-__PHYDMDIG_H__	hal/phydm/phydm_dig.h	22;"	d
-__PHYDMDYNAMICBBPOWERSAVING_H__	hal/phydm/phydm_dynamicbbpowersaving.h	22;"	d
-__PHYDMDYNAMICTXPOWER_H__	hal/phydm/phydm_dynamictxpower.h	22;"	d
-__PHYDMEDCATURBOCHECK_H__	hal/phydm/phydm_edcaturbocheck.h	22;"	d
-__PHYDMIQK_H__	hal/phydm/phydm_iqk.h	22;"	d
-__PHYDMPATHDIV_H__	hal/phydm/phydm_pathdiv.h	22;"	d
-__PHYDMPOWERTRACKING_H__	hal/phydm/phydm_powertracking_ap.h	22;"	d
-__PHYDMPOWERTRACKING_H__	hal/phydm/phydm_powertracking_ce.h	22;"	d
-__PHYDMPOWERTRACKING_H__	hal/phydm/phydm_powertracking_win.h	22;"	d
-__PHYDMPREDEFINE_H__	hal/phydm/phydm_pre_define.h	23;"	d
-__PHYDMRAINFO_H__	hal/phydm/phydm_rainfo.h	22;"	d
-__PHYDM_DFS_H__	hal/phydm/phydm_dfs.h	22;"	d
-__PHYDM_FEATURES	hal/phydm/phydm_features.h	22;"	d
-__PHYDM_HAL_TXBF_API_H__	hal/phydm/txbf/phydm_hal_txbf_api.h	20;"	d
-__PLATFORM_OPS_H__	platform/platform_ops.h	21;"	d
-__RECV_OSDEP_H_	include/recv_osdep.h	21;"	d
-__RTL8188E_CMD_H__	include/rtl8188e_cmd.h	21;"	d
-__RTL8188E_DM_H__	include/rtl8188e_dm.h	21;"	d
-__RTL8188E_HAL_H__	include/rtl8188e_hal.h	21;"	d
-__RTL8188E_LED_H__	include/rtl8188e_led.h	21;"	d
-__RTL8188E_RECV_H__	include/rtl8188e_recv.h	21;"	d
-__RTL8188E_RF_H__	include/rtl8188e_rf.h	21;"	d
-__RTL8188E_SPEC_H__	include/rtl8188e_spec.h	20;"	d
-__RTL8188E_XMIT_H__	include/rtl8188e_xmit.h	21;"	d
-__RTL8188F_CMD_H__	include/rtl8188f_cmd.h	21;"	d
-__RTL8188F_DM_H__	include/rtl8188f_dm.h	21;"	d
-__RTL8188F_HAL_H__	include/rtl8188f_hal.h	21;"	d
-__RTL8188F_LED_H__	include/rtl8188f_led.h	21;"	d
-__RTL8188F_RECV_H__	include/rtl8188f_recv.h	21;"	d
-__RTL8188F_RF_H__	include/rtl8188f_rf.h	21;"	d
-__RTL8188F_SPEC_H__	include/rtl8188f_spec.h	20;"	d
-__RTL8188F_XMIT_H__	include/rtl8188f_xmit.h	21;"	d
-__RTL8192E_CMD_H__	include/rtl8192e_cmd.h	21;"	d
-__RTL8192E_DM_H__	include/rtl8192e_dm.h	21;"	d
-__RTL8192E_HAL_H__	include/rtl8192e_hal.h	21;"	d
-__RTL8192E_LED_H__	include/rtl8192e_led.h	21;"	d
-__RTL8192E_RECV_H__	include/rtl8192e_recv.h	21;"	d
-__RTL8192E_RF_H__	include/rtl8192e_rf.h	21;"	d
-__RTL8192E_SPEC_H__	include/rtl8192e_spec.h	20;"	d
-__RTL8192E_XMIT_H__	include/rtl8192e_xmit.h	21;"	d
-__RTL8703B_CMD_H__	include/rtl8703b_cmd.h	21;"	d
-__RTL8703B_DM_H__	include/rtl8703b_dm.h	21;"	d
-__RTL8703B_HAL_H__	include/rtl8703b_hal.h	21;"	d
-__RTL8703B_LED_H__	include/rtl8703b_led.h	21;"	d
-__RTL8703B_RECV_H__	include/rtl8703b_recv.h	21;"	d
-__RTL8703B_RF_H__	include/rtl8703b_rf.h	21;"	d
-__RTL8703B_SPEC_H__	include/rtl8703b_spec.h	20;"	d
-__RTL8703B_XMIT_H__	include/rtl8703b_xmit.h	21;"	d
-__RTL8723B_CMD_H__	include/rtl8723b_cmd.h	21;"	d
-__RTL8723B_DM_H__	include/rtl8723b_dm.h	21;"	d
-__RTL8723B_HAL_H__	include/rtl8723b_hal.h	21;"	d
-__RTL8723B_LED_H__	include/rtl8723b_led.h	21;"	d
-__RTL8723B_RECV_H__	include/rtl8723b_recv.h	21;"	d
-__RTL8723B_RF_H__	include/rtl8723b_rf.h	21;"	d
-__RTL8723B_SPEC_H__	include/rtl8723b_spec.h	20;"	d
-__RTL8723B_XMIT_H__	include/rtl8723b_xmit.h	21;"	d
-__RTL8723D_CMD_H__	include/rtl8723d_cmd.h	21;"	d
-__RTL8723D_DM_H__	include/rtl8723d_dm.h	21;"	d
-__RTL8723D_HAL_H__	include/rtl8723d_hal.h	21;"	d
-__RTL8723D_LED_H__	include/rtl8723d_led.h	21;"	d
-__RTL8723D_RECV_H__	include/rtl8723d_recv.h	21;"	d
-__RTL8723D_RF_H__	include/rtl8723d_rf.h	21;"	d
-__RTL8723D_SPEC_H__	include/rtl8723d_spec.h	20;"	d
-__RTL8723D_XMIT_H__	include/rtl8723d_xmit.h	21;"	d
-__RTL8812A_CMD_H__	include/rtl8812a_cmd.h	21;"	d
-__RTL8812A_DM_H__	include/rtl8812a_dm.h	21;"	d
-__RTL8812A_HAL_H__	include/rtl8812a_hal.h	21;"	d
-__RTL8812A_LED_H__	include/rtl8812a_led.h	21;"	d
-__RTL8812A_RECV_H__	include/rtl8812a_recv.h	21;"	d
-__RTL8812A_RF_H__	include/rtl8812a_rf.h	21;"	d
-__RTL8812A_SPEC_H__	include/rtl8812a_spec.h	20;"	d
-__RTL8812A_XMIT_H__	include/rtl8812a_xmit.h	21;"	d
-__RTL8814A_CMD_H__	include/rtl8814a_cmd.h	21;"	d
-__RTL8814A_DM_H__	include/rtl8814a_dm.h	21;"	d
-__RTL8814A_HAL_H__	include/rtl8814a_hal.h	21;"	d
-__RTL8814A_LED_H__	include/rtl8814a_led.h	21;"	d
-__RTL8814A_RECV_H__	include/rtl8814a_recv.h	21;"	d
-__RTL8814A_RF_H__	include/rtl8814a_rf.h	21;"	d
-__RTL8814A_SPEC_H__	include/rtl8814a_spec.h	20;"	d
-__RTL8814A_XMIT_H__	include/rtl8814a_xmit.h	21;"	d
-__RTL8821A_SPEC_H__	include/rtl8821a_spec.h	20;"	d
-__RTL8821A_XMIT_H__	include/rtl8821a_xmit.h	21;"	d
-__RTW_ANDROID_H__	include/rtw_android.h	22;"	d
-__RTW_AP_H_	include/rtw_ap.h	21;"	d
-__RTW_BEAMFORMING_H_	include/rtw_beamforming.h	21;"	d
-__RTW_BTCOEX_H__	include/rtw_btcoex.h	21;"	d
-__RTW_BT_MP_H	include/rtw_bt_mp.h	22;"	d
-__RTW_CMD_H_	include/rtw_cmd.h	21;"	d
-__RTW_DEBUG_H__	include/rtw_debug.h	21;"	d
-__RTW_EEPROM_H__	include/rtw_eeprom.h	21;"	d
-__RTW_EFUSE_H__	include/rtw_efuse.h	21;"	d
-__RTW_IOCTL_SET_H_	include/rtw_ioctl_set.h	21;"	d
-__RTW_IOL_H_	include/rtw_iol.h	21;"	d
-__RTW_MEM_H__	include/rtw_mem.h	21;"	d
-__RTW_MI_H_	include/rtw_mi.h	21;"	d
-__RTW_MLME_EXT_H_	include/rtw_mlme_ext.h	21;"	d
-__RTW_MLME_H_	include/rtw_mlme.h	21;"	d
-__RTW_MP_PHY_REGDEF_H_	include/rtw_mp_phy_regdef.h	44;"	d
-__RTW_ODM_H__	include/rtw_odm.h	21;"	d
-__RTW_P2P_H_	include/rtw_p2p.h	21;"	d
-__RTW_PROC_H__	os_dep/linux/rtw_proc.h	21;"	d
-__RTW_PWRCTRL_H_	include/rtw_pwrctrl.h	21;"	d
-__RTW_RF_H_	include/rtw_rf.h	21;"	d
-__RTW_SECURITY_H_	include/rtw_security.h	21;"	d
-__RTW_TDLS_H_	include/rtw_tdls.h	21;"	d
-__RTW_WIFI_REGD_H__	include/rtw_wifi_regd.h	8;"	d
-__RT_CHANNELPLAN_H__	hal/phydm/rtchnlplan.h	23;"	d
-__SDIO_HAL_H__	include/sdio_hal.h	21;"	d
-__SDIO_OPS_H__	include/sdio_ops.h	21;"	d
-__SDIO_OPS_LINUX_H__	include/gspi_ops_linux.h	21;"	d
-__SDIO_OPS_LINUX_H__	include/sdio_ops_linux.h	21;"	d
-__SDIO_OSINTF_H__	include/gspi_osintf.h	21;"	d
-__SDIO_OSINTF_H__	include/sdio_osintf.h	21;"	d
-__STA_INFO_H_	include/sta_info.h	21;"	d
-__USB_HAL_H__	include/usb_hal.h	21;"	d
-__USB_OPS_H_	include/usb_ops.h	21;"	d
-__USB_OPS_LINUX_H__	include/usb_ops_linux.h	21;"	d
-__USB_OSINTF_H	include/usb_osintf.h	21;"	d
-__WLAN_ATTRIB_PACK__	hal/phydm/phydm_precomp.h	53;"	d
-__WLAN_ATTRIB_PACK__	hal/phydm/phydm_precomp.h	58;"	d
-__WLAN_BSSDEF_H__	include/wlan_bssdef.h	21;"	d
-__XMIT_OSDEP_H_	include/xmit_osdep.h	21;"	d
-___constant_swahb32	include/byteorder/swabb.h	66;"	d
-___constant_swahw32	include/byteorder/swabb.h	62;"	d
-___htonl	include/byteorder/generic.h	184;"	d
-___htons	include/byteorder/generic.h	185;"	d
-___ntohl	include/byteorder/generic.h	186;"	d
-___ntohs	include/byteorder/generic.h	187;"	d
-___swab16	include/byteorder/swab.h	/^__inline static __u16  ___swab16(__u16 x)$/;"	f
-___swab32	include/byteorder/swab.h	/^__inline static __u32  ___swab32(__u32 x)$/;"	f
-___swab64	include/byteorder/swab.h	/^__inline static __u64  ___swab64(__u64 x)$/;"	f
-___swahb32	include/byteorder/swabb.h	54;"	d
-___swahw32	include/byteorder/swabb.h	47;"	d
-__arch__swab16	include/byteorder/swab.h	/^__inline static __u16 __arch__swab16(__u16 x)$/;"	f
-__arch__swab32	include/byteorder/swab.h	/^__inline static __u32 __arch__swab32(__u32 x)$/;"	f
-__arch__swab64	include/byteorder/swab.h	/^__inline static __u64 __arch__swab64(__u64 x)$/;"	f
-__arch__swahb32	include/byteorder/swabb.h	78;"	d
-__arch__swahb32p	include/byteorder/swabb.h	85;"	d
-__arch__swahb32s	include/byteorder/swabb.h	92;"	d
-__arch__swahw32	include/byteorder/swabb.h	75;"	d
-__arch__swahw32p	include/byteorder/swabb.h	82;"	d
-__arch__swahw32s	include/byteorder/swabb.h	89;"	d
-__be16_to_cpu	include/byteorder/big_endian.h	59;"	d
-__be16_to_cpu	include/byteorder/little_endian.h	60;"	d
-__be16_to_cpup	include/byteorder/big_endian.h	71;"	d
-__be16_to_cpup	include/byteorder/little_endian.h	72;"	d
-__be16_to_cpus	include/byteorder/big_endian.h	83;"	d
-__be16_to_cpus	include/byteorder/little_endian.h	84;"	d
-__be32_to_cpu	include/byteorder/big_endian.h	57;"	d
-__be32_to_cpu	include/byteorder/little_endian.h	58;"	d
-__be32_to_cpup	include/byteorder/big_endian.h	69;"	d
-__be32_to_cpup	include/byteorder/little_endian.h	70;"	d
-__be32_to_cpus	include/byteorder/big_endian.h	81;"	d
-__be32_to_cpus	include/byteorder/little_endian.h	82;"	d
-__be64_to_cpu	include/byteorder/big_endian.h	55;"	d
-__be64_to_cpu	include/byteorder/little_endian.h	56;"	d
-__be64_to_cpup	include/byteorder/big_endian.h	67;"	d
-__be64_to_cpup	include/byteorder/little_endian.h	68;"	d
-__be64_to_cpus	include/byteorder/big_endian.h	79;"	d
-__be64_to_cpus	include/byteorder/little_endian.h	80;"	d
-__constant_be16_to_cpu	include/byteorder/big_endian.h	47;"	d
-__constant_be16_to_cpu	include/byteorder/little_endian.h	48;"	d
-__constant_be32_to_cpu	include/byteorder/big_endian.h	45;"	d
-__constant_be32_to_cpu	include/byteorder/little_endian.h	46;"	d
-__constant_be64_to_cpu	include/byteorder/big_endian.h	43;"	d
-__constant_be64_to_cpu	include/byteorder/little_endian.h	44;"	d
-__constant_cpu_to_be16	include/byteorder/big_endian.h	46;"	d
-__constant_cpu_to_be16	include/byteorder/little_endian.h	47;"	d
-__constant_cpu_to_be32	include/byteorder/big_endian.h	44;"	d
-__constant_cpu_to_be32	include/byteorder/little_endian.h	45;"	d
-__constant_cpu_to_be64	include/byteorder/big_endian.h	42;"	d
-__constant_cpu_to_be64	include/byteorder/little_endian.h	43;"	d
-__constant_cpu_to_le16	include/byteorder/big_endian.h	40;"	d
-__constant_cpu_to_le16	include/byteorder/little_endian.h	41;"	d
-__constant_cpu_to_le32	include/byteorder/big_endian.h	38;"	d
-__constant_cpu_to_le32	include/byteorder/little_endian.h	39;"	d
-__constant_cpu_to_le64	include/byteorder/big_endian.h	36;"	d
-__constant_cpu_to_le64	include/byteorder/little_endian.h	37;"	d
-__constant_htonl	include/byteorder/big_endian.h	32;"	d
-__constant_htonl	include/byteorder/little_endian.h	33;"	d
-__constant_htons	include/byteorder/big_endian.h	34;"	d
-__constant_htons	include/byteorder/little_endian.h	35;"	d
-__constant_le16_to_cpu	include/byteorder/big_endian.h	41;"	d
-__constant_le16_to_cpu	include/byteorder/little_endian.h	42;"	d
-__constant_le32_to_cpu	include/byteorder/big_endian.h	39;"	d
-__constant_le32_to_cpu	include/byteorder/little_endian.h	40;"	d
-__constant_le64_to_cpu	include/byteorder/big_endian.h	37;"	d
-__constant_le64_to_cpu	include/byteorder/little_endian.h	38;"	d
-__constant_ntohl	include/byteorder/big_endian.h	33;"	d
-__constant_ntohl	include/byteorder/little_endian.h	34;"	d
-__constant_ntohs	include/byteorder/big_endian.h	35;"	d
-__constant_ntohs	include/byteorder/little_endian.h	36;"	d
-__cpu_to_be16	include/byteorder/big_endian.h	58;"	d
-__cpu_to_be16	include/byteorder/little_endian.h	59;"	d
-__cpu_to_be16p	include/byteorder/big_endian.h	70;"	d
-__cpu_to_be16p	include/byteorder/little_endian.h	71;"	d
-__cpu_to_be16s	include/byteorder/big_endian.h	82;"	d
-__cpu_to_be16s	include/byteorder/little_endian.h	83;"	d
-__cpu_to_be32	include/byteorder/big_endian.h	56;"	d
-__cpu_to_be32	include/byteorder/little_endian.h	57;"	d
-__cpu_to_be32p	include/byteorder/big_endian.h	68;"	d
-__cpu_to_be32p	include/byteorder/little_endian.h	69;"	d
-__cpu_to_be32s	include/byteorder/big_endian.h	80;"	d
-__cpu_to_be32s	include/byteorder/little_endian.h	81;"	d
-__cpu_to_be64	include/byteorder/big_endian.h	54;"	d
-__cpu_to_be64	include/byteorder/little_endian.h	55;"	d
-__cpu_to_be64p	include/byteorder/big_endian.h	66;"	d
-__cpu_to_be64p	include/byteorder/little_endian.h	67;"	d
-__cpu_to_be64s	include/byteorder/big_endian.h	78;"	d
-__cpu_to_be64s	include/byteorder/little_endian.h	79;"	d
-__cpu_to_le16	include/byteorder/big_endian.h	52;"	d
-__cpu_to_le16	include/byteorder/little_endian.h	53;"	d
-__cpu_to_le16p	include/byteorder/big_endian.h	64;"	d
-__cpu_to_le16p	include/byteorder/little_endian.h	65;"	d
-__cpu_to_le16s	include/byteorder/big_endian.h	76;"	d
-__cpu_to_le16s	include/byteorder/little_endian.h	77;"	d
-__cpu_to_le32	include/byteorder/big_endian.h	50;"	d
-__cpu_to_le32	include/byteorder/little_endian.h	51;"	d
-__cpu_to_le32p	include/byteorder/big_endian.h	62;"	d
-__cpu_to_le32p	include/byteorder/little_endian.h	63;"	d
-__cpu_to_le32s	include/byteorder/big_endian.h	74;"	d
-__cpu_to_le32s	include/byteorder/little_endian.h	75;"	d
-__cpu_to_le64	include/byteorder/big_endian.h	48;"	d
-__cpu_to_le64	include/byteorder/little_endian.h	49;"	d
-__cpu_to_le64p	include/byteorder/big_endian.h	60;"	d
-__cpu_to_le64p	include/byteorder/little_endian.h	61;"	d
-__cpu_to_le64s	include/byteorder/big_endian.h	72;"	d
-__cpu_to_le64s	include/byteorder/little_endian.h	73;"	d
-__data	include/ip.h	/^	unsigned char __data[0];$/;"	m	struct:ip_options
-__exit	include/osdep_service_bsd.h	482;"	d
-__fswab16	include/byteorder/swab.h	/^	__inline static __u16 __fswab16(__u16 x)$/;"	f
-__fswab32	include/byteorder/swab.h	/^	__inline static __u32 __fswab32(__u32 x)$/;"	f
-__fswahb32	include/byteorder/swabb.h	/^__inline static__ __const__ __u32 __fswahb32(__u32 x)$/;"	f
-__fswahw32	include/byteorder/swabb.h	/^__inline static__ __const__ __u32 __fswahw32(__u32 x)$/;"	f
-__func__	hal/phydm/phydm_types.h	121;"	d
-__init	include/osdep_service_bsd.h	481;"	d
-__kernel_size_t	include/basic_types.h	/^	typedef unsigned int __kernel_size_t;$/;"	t
-__kernel_ssize_t	include/basic_types.h	/^	typedef int __kernel_ssize_t;$/;"	t
-__le16_to_cpu	include/byteorder/big_endian.h	53;"	d
-__le16_to_cpu	include/byteorder/little_endian.h	54;"	d
-__le16_to_cpup	include/byteorder/big_endian.h	65;"	d
-__le16_to_cpup	include/byteorder/little_endian.h	66;"	d
-__le16_to_cpus	include/byteorder/big_endian.h	77;"	d
-__le16_to_cpus	include/byteorder/little_endian.h	78;"	d
-__le32_to_cpu	include/byteorder/big_endian.h	51;"	d
-__le32_to_cpu	include/byteorder/little_endian.h	52;"	d
-__le32_to_cpup	include/byteorder/big_endian.h	63;"	d
-__le32_to_cpup	include/byteorder/little_endian.h	64;"	d
-__le32_to_cpus	include/byteorder/big_endian.h	75;"	d
-__le32_to_cpus	include/byteorder/little_endian.h	76;"	d
-__le64_to_cpu	include/byteorder/big_endian.h	49;"	d
-__le64_to_cpu	include/byteorder/little_endian.h	50;"	d
-__le64_to_cpup	include/byteorder/big_endian.h	61;"	d
-__le64_to_cpup	include/byteorder/little_endian.h	62;"	d
-__le64_to_cpus	include/byteorder/big_endian.h	73;"	d
-__le64_to_cpus	include/byteorder/little_endian.h	74;"	d
-__list_add	os_dep/osdep_service.c	/^static inline void __list_add(_list *pnew, _list *pprev, _list *pnext)$/;"	f	file:
-__list_del	include/osdep_service_bsd.h	/^static inline void __list_del(struct list_head * prev, struct list_head * next)$/;"	f
-__nat25_add_pppoe_tag	core/rtw_br_ext.c	/^static __inline__ int __nat25_add_pppoe_tag(struct sk_buff *skb, struct pppoe_tag *tag)$/;"	f	file:
-__nat25_db_network_insert	core/rtw_br_ext.c	/^static void __nat25_db_network_insert(_adapter *priv,$/;"	f	file:
-__nat25_db_network_lookup_and_replace	core/rtw_br_ext.c	/^static int __nat25_db_network_lookup_and_replace(_adapter *priv,$/;"	f	file:
-__nat25_db_print	core/rtw_br_ext.c	/^static void __nat25_db_print(_adapter *priv)$/;"	f	file:
-__nat25_find_pppoe_tag	core/rtw_br_ext.c	/^static __inline__ unsigned char *__nat25_find_pppoe_tag(struct pppoe_hdr *ph, unsigned short type)$/;"	f	file:
-__nat25_generate_apple_network_addr	core/rtw_br_ext.c	/^static __inline__ void __nat25_generate_apple_network_addr(unsigned char *networkAddr,$/;"	f	file:
-__nat25_generate_ipv4_network_addr	core/rtw_br_ext.c	/^static __inline__ void __nat25_generate_ipv4_network_addr(unsigned char *networkAddr,$/;"	f	file:
-__nat25_generate_ipv6_network_addr	core/rtw_br_ext.c	/^static  void __nat25_generate_ipv6_network_addr(unsigned char *networkAddr,$/;"	f	file:
-__nat25_generate_ipx_network_addr_with_node	core/rtw_br_ext.c	/^static __inline__ void __nat25_generate_ipx_network_addr_with_node(unsigned char *networkAddr,$/;"	f	file:
-__nat25_generate_ipx_network_addr_with_socket	core/rtw_br_ext.c	/^static __inline__ void __nat25_generate_ipx_network_addr_with_socket(unsigned char *networkAddr,$/;"	f	file:
-__nat25_generate_pppoe_network_addr	core/rtw_br_ext.c	/^static __inline__ void __nat25_generate_pppoe_network_addr(unsigned char *networkAddr,$/;"	f	file:
-__nat25_has_expired	core/rtw_br_ext.c	/^static __inline__ int  __nat25_has_expired(_adapter *priv,$/;"	f	file:
-__nat25_network_hash	core/rtw_br_ext.c	/^static __inline__ int __nat25_network_hash(unsigned char *networkAddr)$/;"	f	file:
-__nat25_timeout	core/rtw_br_ext.c	/^static __inline__ unsigned long __nat25_timeout(_adapter *priv)$/;"	f	file:
-__network_hash_link	core/rtw_br_ext.c	/^static __inline__ void __network_hash_link(_adapter *priv,$/;"	f	file:
-__network_hash_unlink	core/rtw_br_ext.c	/^static __inline__ void __network_hash_unlink(struct nat25_network_db_entry *ent)$/;"	f	file:
-__packed	include/rtw_xmit.h	/^} __packed;$/;"	v	typeref:struct:tx_buf_desc
-__pad1	include/ip.h	/^	unsigned char __pad1;$/;"	m	struct:ip_options
-__pad2	include/ip.h	/^	unsigned char __pad2;$/;"	m	struct:ip_options
-__queue	include/osdep_service_bsd.h	/^	struct	__queue	{$/;"	s
-__queue	include/osdep_service_ce.h	/^struct	__queue	{$/;"	s
-__queue	include/osdep_service_linux.h	/^struct	__queue	{$/;"	s
-__queue	include/osdep_service_xp.h	/^	struct	__queue	{$/;"	s
-__rtw_alloc_cmd_xmitbuf	core/rtw_xmit.c	/^static struct xmit_buf *__rtw_alloc_cmd_xmitbuf(struct xmit_priv *pxmitpriv,$/;"	f	file:
-__rtw_alloc_cmdxmitframe	core/rtw_xmit.c	/^struct xmit_frame *__rtw_alloc_cmdxmitframe(struct xmit_priv *pxmitpriv,$/;"	f
-__skb_insert	include/osdep_service_bsd.h	/^static inline void __skb_insert(struct sk_buff *newsk,$/;"	f
-__skb_pull	include/osdep_service_bsd.h	/^static inline unsigned char *__skb_pull(struct sk_buff *skb, unsigned int len)$/;"	f
-__skb_queue_before	include/osdep_service_bsd.h	/^static inline void __skb_queue_before(struct sk_buff_head *list,$/;"	f
-__skb_queue_head_init	include/osdep_service_bsd.h	/^static inline void __skb_queue_head_init(struct sk_buff_head *list)$/;"	f
-__skb_unlink	include/osdep_service_bsd.h	/^static inline void __skb_unlink(struct sk_buff *skb, struct sk_buff_head *list)$/;"	f
-__swab16	include/byteorder/swab.h	107;"	d
-__swab32	include/byteorder/swab.h	108;"	d
-__swab64	include/byteorder/swab.h	109;"	d
-__swahb32	include/byteorder/swabb.h	104;"	d
-__swahb32	include/byteorder/swabb.h	110;"	d
-__swahb32p	include/byteorder/swabb.h	/^__inline static__ __u32 __swahb32p(__u32 *x)$/;"	f
-__swahb32s	include/byteorder/swabb.h	/^__inline static__ void __swahb32s(__u32 *addr)$/;"	f
-__swahw32	include/byteorder/swabb.h	100;"	d
-__swahw32	include/byteorder/swabb.h	109;"	d
-__swahw32p	include/byteorder/swabb.h	/^__inline static__ __u32 __swahw32p(__u32 *x)$/;"	f
-__swahw32s	include/byteorder/swabb.h	/^__inline static__ void __swahw32s(__u32 *addr)$/;"	f
-__u16	include/byteorder/swab.h	/^	typedef unsigned short __u16;$/;"	t
-__u32	include/byteorder/swab.h	/^	typedef unsigned int	__u32;$/;"	t
-__u64	include/byteorder/swab.h	/^	typedef unsigned long long	__u64;$/;"	t
-__u8	include/byteorder/swab.h	/^	typedef unsigned char __u8;$/;"	t
-__user	include/linux/wireless.h	31;"	d
-_acl_mode_str	core/rtw_sta_mgt.c	/^const char *const _acl_mode_str[] = {$/;"	v
-_action_public_str	core/rtw_ieee80211.c	/^static const char *_action_public_str[] = {$/;"	v	file:
-_adapter	include/drv_types.h	/^typedef struct _ADAPTER _adapter, ADAPTER, *PADAPTER;$/;"	t	typeref:struct:_ADAPTER
-_add_bfee_entry	core/rtw_beamforming.c	/^static struct beamformee_entry *_add_bfee_entry(PADAPTER adapter,$/;"	f	file:
-_add_bfer_entry	core/rtw_beamforming.c	/^static struct beamformer_entry *_add_bfer_entry(PADAPTER adapter,$/;"	f	file:
-_addba_timer_hdl	os_dep/linux/mlme_linux.c	/^void _addba_timer_hdl(void *FunctionContext)$/;"	f
-_alloc_mgtxmitframe	core/rtw_mlme_ext.c	/^struct xmit_frame *_alloc_mgtxmitframe(struct xmit_priv *pxmitpriv, bool once)$/;"	f
-_async_io_callback	include/rtw_io.h	/^	void (*_async_io_callback)(_adapter *padater, struct io_req *pio_req, u8 *cnxt);$/;"	m	struct:io_req
-_band_cap_str	hal/hal_com.c	/^static const char *const _band_cap_str[] = {$/;"	v	file:
-_band_str	core/rtw_rf.c	/^const char *const _band_str[] = {$/;"	v
-_band_to_band_cap	core/rtw_rf.c	/^const u8 _band_to_band_cap[] = {$/;"	v
-_beamforming_reset	core/rtw_beamforming.c	/^void _beamforming_reset(PADAPTER adapter)$/;"	f
-_bit_11AC	hal/phydm/phydm_interface.h	61;"	d
-_bit_11N	hal/phydm/phydm_interface.h	60;"	d
-_bit_all	hal/phydm/phydm_interface.h	39;"	d
-_bit_ic	hal/phydm/phydm_interface.h	40;"	d
-_bt_c2h_status	hal/hal_btcoex.c	/^typedef enum _bt_c2h_status {$/;"	g	file:
-_bt_ext_eid	hal/hal_btcoex.c	/^typedef enum _bt_ext_eid {$/;"	g	file:
-_bt_op_code	hal/hal_btcoex.c	/^typedef enum _bt_op_code {$/;"	g	file:
-_btcoexdbginfo	hal/hal_btcoex.c	/^typedef struct _btcoexdbginfo {$/;"	s	file:
-_btmpoper_cmd	hal/hal_btcoex.c	/^static u8 _btmpoper_cmd(PBTC_COEXIST pBtCoexist, u8 opcode, u8 opcodever, u8 *cmd, u8 size)$/;"	f	file:
-_btmpoper_timer_hdl	hal/hal_btcoex.c	/^static void _btmpoper_timer_hdl(void *p)$/;"	f	file:
-_buffer	include/osdep_service_bsd.h	/^	typedef struct mbuf	_buffer;$/;"	t	typeref:struct:mbuf
-_buffer	include/osdep_service_ce.h	/^typedef NDIS_BUFFER	_buffer;$/;"	t
-_buffer	include/osdep_service_linux.h	/^typedef unsigned char	_buffer;$/;"	t
-_buffer	include/osdep_service_xp.h	/^	typedef NDIS_BUFFER	_buffer;$/;"	t
-_bus_io	include/osdep_intf.h	/^	void (*_bus_io)(u8 *priv);$/;"	m	struct:intf_priv
-_bw_cap_str	hal/hal_com.c	/^static const char *const _bw_cap_str[] = {$/;"	v	file:
-_byte_	include/rtw_security.h	/^} _byte_;$/;"	m	union:pn48	typeref:struct:pn48::__anon60
-_byte_	include/rtw_security.h	/^} _byte_;$/;"	m	union:pn48	typeref:struct:pn48::__anon61
-_cancel_timer	include/osdep_service_bsd.h	/^__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)$/;"	f
-_cancel_timer	include/osdep_service_ce.h	/^__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)$/;"	f
-_cancel_timer	include/osdep_service_linux.h	/^__inline static void _cancel_timer(_timer *ptimer, u8 *bcancelled)$/;"	f
-_cancel_timer	include/osdep_service_xp.h	/^__inline static void _cancel_timer(_timer *ptimer,u8 *bcancelled)$/;"	f
-_cancel_timer_ex	include/osdep_service.h	/^__inline static unsigned char _cancel_timer_ex(_timer *ptimer)$/;"	f
-_cancel_workitem_sync	include/osdep_service_linux.h	/^__inline static void _cancel_workitem_sync(_workitem *pwork)$/;"	f
-_cat	hal/phydm/phydm_interface.h	71;"	d
-_cfg80211_rtw_mgmt_tx	os_dep/linux/ioctl_cfg80211.c	/^static int _cfg80211_rtw_mgmt_tx(_adapter *padapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack)$/;"	f	file:
-_ch_width_str	core/rtw_rf.c	/^const char *const _ch_width_str[] = {$/;"	v
-_ch_width_to_bw_cap	core/rtw_rf.c	/^const u8 _ch_width_to_bw_cap[] = {$/;"	v
-_chip_type_to_odm_ic_type	hal/hal_intf.c	/^const u32 _chip_type_to_odm_ic_type[] = {$/;"	v
-_clear_cam_entry	core/rtw_wlan_util.c	/^void _clear_cam_entry(_adapter *padapter, u8 entry)$/;"	f
-_clr_fwstate_	include/rtw_mlme.h	/^static inline void _clr_fwstate_(struct mlme_priv *pmlmepriv, sint state)$/;"	f
-_cmd_callback	include/rtw_cmd.h	/^struct _cmd_callback {$/;"	s
-_cvrt2ftaddr	hal/rtl8723d/sdio/sdio_ops.c	/^static u32 _cvrt2ftaddr(const u32 addr, u8 *pdeviceId, u16 *poffset)$/;"	f	file:
-_dbgdump	include/rtw_debug.h	82;"	d
-_dbgdump	include/rtw_debug.h	86;"	d
-_dbgdump	include/rtw_debug.h	89;"	d
-_dbgdump	include/rtw_debug.h	92;"	d
-_dbgdump	include/rtw_debug.h	95;"	d
-_deinit_entry	core/rtw_beamforming.c	/^static void _deinit_entry(PADAPTER adapter, u8 *ra)$/;"	f	file:
-_dequeue_writeport	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^s32 _dequeue_writeport(PADAPTER padapter)$/;"	f
-_dequeue_writeport	include/rtl8822bs_hal.h	30;"	d
-_drv_alert_	include/rtw_debug.h	556;"	d
-_drv_always_	include/rtw_debug.h	554;"	d
-_drv_crit_	include/rtw_debug.h	557;"	d
-_drv_debug_	include/rtw_debug.h	563;"	d
-_drv_dump_	include/rtw_debug.h	562;"	d
-_drv_emerg_	include/rtw_debug.h	555;"	d
-_drv_err_	include/rtw_debug.h	558;"	d
-_drv_info_	include/rtw_debug.h	561;"	d
-_drv_notice_	include/rtw_debug.h	560;"	d
-_drv_warning_	include/rtw_debug.h	559;"	d
-_dynamic_check_timer_handlder	os_dep/linux/mlme_linux.c	/^void _dynamic_check_timer_handlder(void *FunctionContext)$/;"	f
-_enter_critical	include/osdep_service_bsd.h	/^__inline static void _enter_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical	include/osdep_service_ce.h	/^__inline static void _enter_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical	include/osdep_service_linux.h	/^__inline static void _enter_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical	include/osdep_service_xp.h	/^__inline static _enter_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_bh	include/osdep_service_bsd.h	/^__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_bh	include/osdep_service_linux.h	/^__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_bh	include/osdep_service_xp.h	/^__inline static void _enter_critical_bh(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_ex	include/osdep_service_bsd.h	/^__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_ex	include/osdep_service_ce.h	/^__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_ex	include/osdep_service_linux.h	/^__inline static void _enter_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_ex	include/osdep_service_xp.h	/^__inline static _enter_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_enter_critical_mutex	include/osdep_service_bsd.h	/^__inline static void _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)$/;"	f
-_enter_critical_mutex	include/osdep_service_linux.h	/^__inline static int _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)$/;"	f
-_enter_critical_mutex	include/osdep_service_xp.h	/^__inline static _enter_critical_mutex(_mutex *pmutex, _irqL *pirqL)$/;"	f
-_enter_hwio_critical	include/osdep_service_ce.h	/^__inline static void _enter_hwio_critical(_rwlock *prwlock, _irqL *pirqL)$/;"	f
-_enter_pwrlock	include/rtw_pwrctrl.h	/^__inline static void _enter_pwrlock(_pwrlock *plock)$/;"	f
-_exit_critical	include/osdep_service_bsd.h	/^__inline static void _exit_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical	include/osdep_service_ce.h	/^__inline static void _exit_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical	include/osdep_service_linux.h	/^__inline static void _exit_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical	include/osdep_service_xp.h	/^__inline static _exit_critical(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_bh	include/osdep_service_bsd.h	/^__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_bh	include/osdep_service_linux.h	/^__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_bh	include/osdep_service_xp.h	/^__inline static void _exit_critical_bh(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_ex	include/osdep_service_bsd.h	/^__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_ex	include/osdep_service_ce.h	/^__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_ex	include/osdep_service_linux.h	/^__inline static void _exit_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_ex	include/osdep_service_xp.h	/^__inline static _exit_critical_ex(_lock *plock, _irqL *pirqL)$/;"	f
-_exit_critical_mutex	include/osdep_service_bsd.h	/^__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)$/;"	f
-_exit_critical_mutex	include/osdep_service_linux.h	/^__inline static void _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)$/;"	f
-_exit_critical_mutex	include/osdep_service_xp.h	/^__inline static _exit_critical_mutex(_mutex *pmutex, _irqL *pirqL)$/;"	f
-_exit_hwio_critical	include/osdep_service_ce.h	/^__inline static void _exit_hwio_critical(_rwlock *prwlock, _irqL *pirqL)$/;"	f
-_exit_pwrlock	include/rtw_pwrctrl.h	/^__inline static void _exit_pwrlock(_pwrlock *plock)$/;"	f
-_free_pwrlock	include/rtw_pwrctrl.h	/^__inline static void _free_pwrlock(_pwrlock *plock)$/;"	f
-_ft_link_timer_hdl	os_dep/linux/mlme_linux.c	/^void _ft_link_timer_hdl(void *FunctionContext)$/;"	f
-_ft_priv	include/rtw_mlme.h	/^typedef struct _ft_priv {$/;"	s
-_ft_roam_timer_hdl	os_dep/linux/mlme_linux.c	/^void _ft_roam_timer_hdl(void *FunctionContext)$/;"	f
-_get_bfee_free_entry	core/rtw_beamforming.c	/^static struct beamformee_entry *_get_bfee_free_entry(PADAPTER adapter)$/;"	f	file:
-_get_bfer_free_entry	core/rtw_beamforming.c	/^static struct beamformer_entry *_get_bfer_free_entry(PADAPTER adapter)$/;"	f	file:
-_get_first_mu_bfee_entry_idx	core/rtw_beamforming.c	/^static u8 _get_first_mu_bfee_entry_idx(PADAPTER adapter, struct beamformee_entry *ignore)$/;"	f	file:
-_get_sta_beamform_cap	core/rtw_beamforming.c	/^static void _get_sta_beamform_cap(PADAPTER adapter, struct sta_info *sta,$/;"	f	file:
-_h2c_msr_role_str	hal/hal_com.c	/^const char *const _h2c_msr_role_str[] = {$/;"	v
-_hDevice	include/drv_types_ce.h	/^	USB_HANDLE	    _hDevice;$/;"	m	struct:_USB_EXTENSION
-_halbtcoutsrc_GetWifiLinkStatus	hal/hal_btcoex.c	/^static u32 _halbtcoutsrc_GetWifiLinkStatus(PADAPTER padapter)$/;"	f	file:
-_halmac_buff_print	hal/hal_halmac.c	/^static u8 _halmac_buff_print(void *p, u32 msg_type, u8 msg_level, s8 *buf, u32 size)$/;"	f	file:
-_halmac_event_indication	hal/hal_halmac.c	/^static u8 _halmac_event_indication(void *p, HALMAC_FEATURE_ID feature_id, HALMAC_CMD_PROCESS_STATUS process_status, u8 *buf, u32 size)$/;"	f	file:
-_halmac_init_hal	hal/hal_halmac.c	/^static int _halmac_init_hal(struct dvobj_priv *d, u8 *fw, u32 fwsize)$/;"	f	file:
-_halmac_malloc	hal/hal_halmac.c	/^static void *_halmac_malloc(void *p, u32 size)$/;"	f	file:
-_halmac_memcpy	hal/hal_halmac.c	/^static u8 _halmac_memcpy(void *p, void *dest, void *src, u32 size)$/;"	f	file:
-_halmac_memset	hal/hal_halmac.c	/^static u8 _halmac_memset(void *p, void *addr, u8 value, u32 size)$/;"	f	file:
-_halmac_mfree	hal/hal_halmac.c	/^static u8 _halmac_mfree(void *p, void *buffer, u32 size)$/;"	f	file:
-_halmac_msg_print	hal/hal_halmac.c	/^static u8 _halmac_msg_print(void *p, u32 msg_type, u8 msg_level, s8 *fmt, ...)$/;"	f	file:
-_halmac_mutex_deinit	hal/hal_halmac.c	/^static u8 _halmac_mutex_deinit(void *p, HALMAC_MUTEX *pMutex)$/;"	f	file:
-_halmac_mutex_init	hal/hal_halmac.c	/^static u8 _halmac_mutex_init(void *p, HALMAC_MUTEX *pMutex)$/;"	f	file:
-_halmac_mutex_lock	hal/hal_halmac.c	/^static u8 _halmac_mutex_lock(void *p, HALMAC_MUTEX *pMutex)$/;"	f	file:
-_halmac_mutex_unlock	hal/hal_halmac.c	/^static u8 _halmac_mutex_unlock(void *p, HALMAC_MUTEX *pMutex)$/;"	f	file:
-_halmac_reg_read_16	hal/hal_halmac.c	/^static u16 _halmac_reg_read_16(void *p, u32 offset)$/;"	f	file:
-_halmac_reg_read_32	hal/hal_halmac.c	/^static u32 _halmac_reg_read_32(void *p, u32 offset)$/;"	f	file:
-_halmac_reg_read_8	hal/hal_halmac.c	/^static u8 _halmac_reg_read_8(void *p, u32 offset)$/;"	f	file:
-_halmac_reg_write_16	hal/hal_halmac.c	/^static void _halmac_reg_write_16(void *p, u32 offset, u16 val)$/;"	f	file:
-_halmac_reg_write_32	hal/hal_halmac.c	/^static void _halmac_reg_write_32(void *p, u32 offset, u32 val)$/;"	f	file:
-_halmac_reg_write_8	hal/hal_halmac.c	/^static void _halmac_reg_write_8(void *p, u32 offset, u8 val)$/;"	f	file:
-_halmac_sdio_cmd52_read	hal/hal_halmac.c	/^static u8 _halmac_sdio_cmd52_read(void *p, u32 offset)$/;"	f	file:
-_halmac_sdio_cmd52_write	hal/hal_halmac.c	/^static void _halmac_sdio_cmd52_write(void *p, u32 offset, u8 val)$/;"	f	file:
-_halmac_sdio_reg_read_16	hal/hal_halmac.c	/^static u16 _halmac_sdio_reg_read_16(void *p, u32 offset)$/;"	f	file:
-_halmac_sdio_reg_read_32	hal/hal_halmac.c	/^static u32 _halmac_sdio_reg_read_32(void *p, u32 offset)$/;"	f	file:
-_halmac_sdio_reg_read_8	hal/hal_halmac.c	/^static u8 _halmac_sdio_reg_read_8(void *p, u32 offset)$/;"	f	file:
-_halmac_sdio_reg_read_n	hal/hal_halmac.c	/^static u8 _halmac_sdio_reg_read_n(void *p, u32 offset, u32 size, u8 *data)$/;"	f	file:
-_halmac_sdio_reg_write_16	hal/hal_halmac.c	/^static void _halmac_sdio_reg_write_16(void *p, u32 offset, u16 val)$/;"	f	file:
-_halmac_sdio_reg_write_32	hal/hal_halmac.c	/^static void _halmac_sdio_reg_write_32(void *p, u32 offset, u32 val)$/;"	f	file:
-_halmac_sdio_reg_write_8	hal/hal_halmac.c	/^static void _halmac_sdio_reg_write_8(void *p, u32 offset, u8 val)$/;"	f	file:
-_halmac_udelay	hal/hal_halmac.c	/^static void _halmac_udelay(void *p, u32 us)$/;"	f	file:
-_hw_port	include/drv_types.h	/^enum _hw_port {$/;"	g
-_hw_port_drv2halmac	hal/hal_halmac.c	/^static inline u8 _hw_port_drv2halmac(enum _hw_port hwport)$/;"	f	file:
-_initSdioAggregationSetting	hal/rtl8723d/sdio/sdio_halinit.c	/^void _initSdioAggregationSetting(PADAPTER padapter)$/;"	f
-_init_available_page_threshold	hal/rtl8723d/sdio/sdio_halinit.c	/^static void _init_available_page_threshold(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ)$/;"	f	file:
-_init_entry	core/rtw_beamforming.c	/^static u8 _init_entry(PADAPTER adapter, struct sta_info *sta)$/;"	f	file:
-_init_mp_priv_	core/rtw_mp.c	/^static void _init_mp_priv_(struct mp_priv *pmp_priv)$/;"	f	file:
-_init_pwrlock	include/rtw_pwrctrl.h	/^__inline static void _init_pwrlock(_pwrlock *plock)$/;"	f
-_init_timer	include/osdep_service_bsd.h	/^__inline static void _init_timer(_timer *ptimer,_nic_hdl padapter,void *pfunc,void* cntx)$/;"	f
-_init_timer	include/osdep_service_ce.h	/^__inline static void _init_timer(_timer *ptimer,_nic_hdl nic_hdl,void *pfunc,PVOID cntx)$/;"	f
-_init_timer	include/osdep_service_linux.h	/^__inline static void _init_timer(_timer *ptimer, _nic_hdl nic_hdl, void *pfunc, void *cntx)$/;"	f
-_init_timer	include/osdep_service_xp.h	/^__inline static void _init_timer(_timer *ptimer,_nic_hdl nic_hdl,void *pfunc,PVOID cntx)$/;"	f
-_init_txservq	core/rtw_xmit.c	/^static void _init_txservq(struct tx_servq *ptxservq)$/;"	f	file:
-_init_workitem	include/osdep_service_bsd.h	/^__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)$/;"	f
-_init_workitem	include/osdep_service_ce.h	/^__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)$/;"	f
-_init_workitem	include/osdep_service_linux.h	/^static inline void _init_workitem(_workitem *pwork, void *pfunc, void *cntx)$/;"	f
-_init_workitem	include/osdep_service_xp.h	/^__inline static void _init_workitem(_workitem *pwork, void *pfunc, PVOID cntx)$/;"	f
-_io_offload_cmd	include/rtw_iol.h	/^typedef struct _io_offload_cmd {$/;"	s
-_io_ops	include/rtw_io.h	/^struct _io_ops {$/;"	s
-_ips_enter	core/rtw_pwrctrl.c	/^void _ips_enter(_adapter *padapter)$/;"	f
-_ips_leave	core/rtw_pwrctrl.c	/^int _ips_leave(_adapter *padapter)$/;"	f
-_irqL	include/osdep_service_bsd.h	/^	typedef unsigned long _irqL;$/;"	t
-_irqL	include/osdep_service_ce.h	/^typedef u32	_irqL;$/;"	t
-_irqL	include/osdep_service_linux.h	/^typedef unsigned long _irqL;$/;"	t
-_irqL	include/osdep_service_xp.h	/^	typedef KIRQL	_irqL;$/;"	t
-_irqlevel_changed_	include/rtw_mp_ioctl.h	/^static void _irqlevel_changed_(_irqL *irqlevel, u8 bLower)$/;"	f
-_irqlevel_changed_	include/rtw_mp_ioctl.h	97;"	d
-_is_fw_read_cmd_down	hal/hal_halmac.c	/^static u8 _is_fw_read_cmd_down(PADAPTER adapter, u8 msgbox_num)$/;"	f	file:
-_is_fw_read_cmd_down	hal/rtl8723d/rtl8723d_cmd.c	/^static u8 _is_fw_read_cmd_down(_adapter *padapter, u8 msgbox_num)$/;"	f	file:
-_issue_action_SM_PS	core/rtw_mlme_ext.c	/^int _issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode ,  u8 wait_ack)$/;"	f
-_issue_assocreq	core/rtw_mlme_ext.c	/^void _issue_assocreq(_adapter *padapter, u8 is_reassoc)$/;"	f
-_issue_deauth	core/rtw_mlme_ext.c	/^static int _issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason, u8 wait_ack, u8 key_type)$/;"	f	file:
-_issue_nulldata	core/rtw_mlme_ext.c	/^static int _issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int wait_ack)$/;"	f	file:
-_issue_nulldata_to_TDLS_peer_STA	core/rtw_tdls.c	/^int _issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int wait_ack)$/;"	f
-_issue_probereq	core/rtw_mlme_ext.c	/^int _issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch, bool append_wps, int wait_ack)$/;"	f
-_issue_probereq_p2p	core/rtw_mlme_ext.c	/^int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)$/;"	f
-_issue_qos_nulldata	core/rtw_mlme_ext.c	/^static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int wait_ack)$/;"	f	file:
-_issue_tdls_teardown	core/rtw_tdls.c	/^int _issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)$/;"	f
-_link_timer_hdl	os_dep/linux/mlme_linux.c	/^void _link_timer_hdl(void *FunctionContext)$/;"	f
-_linked_info_dump	core/rtw_mlme_ext.c	/^void _linked_info_dump(_adapter *padapter)$/;"	f
-_list	include/osdep_service_bsd.h	/^	typedef struct	list_head	_list;$/;"	t	typeref:struct:list_head
-_list	include/osdep_service_ce.h	/^typedef	LIST_ENTRY	_list;$/;"	t
-_list	include/osdep_service_linux.h	/^typedef struct	list_head	_list;$/;"	t	typeref:struct:list_head
-_list	include/osdep_service_xp.h	/^	typedef	LIST_ENTRY	_list;$/;"	t
-_lock	include/osdep_service_bsd.h	/^	typedef	struct mtx	_lock;$/;"	t	typeref:struct:mtx
-_lock	include/osdep_service_ce.h	/^typedef NDIS_SPIN_LOCK	_lock;$/;"	t
-_lock	include/osdep_service_linux.h	/^typedef	spinlock_t	_lock;$/;"	t
-_lock	include/osdep_service_xp.h	/^	typedef NDIS_SPIN_LOCK	_lock;$/;"	t
-_lpUsbFuncs	include/drv_types_ce.h	/^	LPCUSB_FUNCS    _lpUsbFuncs;$/;"	m	struct:_USB_EXTENSION
-_mac_hidden_max_bw_to_hal_bw_cap	core/efuse/rtw_efuse.c	/^const u8 _mac_hidden_max_bw_to_hal_bw_cap[MAC_HIDDEN_MAX_BW_NUM] = {$/;"	v
-_mac_hidden_proto_to_hal_proto_cap	core/efuse/rtw_efuse.c	/^const u8 _mac_hidden_proto_to_hal_proto_cap[MAC_HIDDEN_PROTOCOL_NUM] = {$/;"	v
-_malloc_cnt	os_dep/osdep_service.c	/^atomic_t _malloc_cnt = ATOMIC_INIT(0);$/;"	v
-_malloc_size	os_dep/osdep_service.c	/^atomic_t _malloc_size = ATOMIC_INIT(0);$/;"	v
-_mgt_dispatcher	core/rtw_mlme_ext.c	/^static void _mgt_dispatcher(_adapter *padapter, struct mlme_handler *ptable, union recv_frame *precv_frame)$/;"	f	file:
-_module_cmd_osdep_c_	include/rtw_debug.h	573;"	d
-_module_efuse_	include/rtw_debug.h	595;"	d
-_module_hal_init_c_	include/rtw_debug.h	579;"	d
-_module_hal_xmit_c_	include/rtw_debug.h	594;"	d
-_module_hci_hal_init_c_	include/rtw_debug.h	580;"	d
-_module_hci_intfs_c_	include/rtw_debug.h	585;"	d
-_module_hci_ops_c_	include/rtw_debug.h	586;"	d
-_module_hci_ops_os_c_	include/rtw_debug.h	589;"	d
-_module_io_osdep_c_	include/rtw_debug.h	575;"	d
-_module_mlme_osdep_c_	include/rtw_debug.h	570;"	d
-_module_mp_	include/rtw_debug.h	588;"	d
-_module_os_intfs_c_	include/rtw_debug.h	576;"	d
-_module_osdep_service_c_	include/rtw_debug.h	587;"	d
-_module_recv_osdep_c_	include/rtw_debug.h	568;"	d
-_module_rtl8192c_xmit_c_	include/rtw_debug.h	593;"	d
-_module_rtl8712_cmd_c_	include/rtw_debug.h	591;"	d
-_module_rtl8712_led_c_	include/rtw_debug.h	597;"	d
-_module_rtl8712_recv_c_	include/rtw_debug.h	596;"	d
-_module_rtl871x_cmd_c_	include/rtw_debug.h	572;"	d
-_module_rtl871x_eeprom_c_	include/rtw_debug.h	578;"	d
-_module_rtl871x_io_c_	include/rtw_debug.h	574;"	d
-_module_rtl871x_ioctl_c_	include/rtw_debug.h	581;"	d
-_module_rtl871x_ioctl_os_c	include/rtw_debug.h	590;"	d
-_module_rtl871x_ioctl_query_c_	include/rtw_debug.h	583;"	d
-_module_rtl871x_ioctl_set_c_	include/rtw_debug.h	582;"	d
-_module_rtl871x_mlme_c_	include/rtw_debug.h	569;"	d
-_module_rtl871x_pwrctrl_c_	include/rtw_debug.h	584;"	d
-_module_rtl871x_recv_c_	include/rtw_debug.h	567;"	d
-_module_rtl871x_security_c_	include/rtw_debug.h	577;"	d
-_module_rtl871x_sta_mgt_c_	include/rtw_debug.h	571;"	d
-_module_rtl871x_xmit_c_	include/rtw_debug.h	565;"	d
-_module_xmit_osdep_c_	include/rtw_debug.h	566;"	d
-_mp_xmit_parm_	include/rtw_mp_ioctl.h	/^typedef struct _mp_xmit_parm_ {$/;"	s
-_mutex	include/osdep_service_bsd.h	/^	typedef struct mtx 		_mutex;$/;"	t	typeref:struct:mtx
-_mutex	include/osdep_service_linux.h	/^	typedef struct mutex		_mutex;$/;"	t	typeref:struct:mutex
-_mutex	include/osdep_service_linux.h	/^	typedef struct semaphore	_mutex;$/;"	t	typeref:struct:semaphore
-_mutex	include/osdep_service_xp.h	/^	typedef KMUTEX 			_mutex;$/;"	t
-_netdev_open	os_dep/linux/os_intfs.c	/^int _netdev_open(struct net_device *pnetdev)$/;"	f
-_netdev_vir_if_open	os_dep/linux/os_intfs.c	/^int _netdev_vir_if_open(struct net_device *pnetdev)$/;"	f
-_nic_hdl	include/osdep_service_bsd.h	/^	typedef	struct	ifnet * _nic_hdl;$/;"	t	typeref:struct:ifnet
-_nic_hdl	include/osdep_service_ce.h	/^typedef NDIS_HANDLE  _nic_hdl;$/;"	t
-_nic_hdl	include/osdep_service_linux.h	/^typedef	struct	net_device *_nic_hdl;$/;"	t	typeref:struct:net_device
-_nic_hdl	include/osdep_service_xp.h	/^	typedef NDIS_HANDLE  _nic_hdl;$/;"	t
-_p2p_roch_cmd	core/rtw_cmd.c	/^static u8 _p2p_roch_cmd(_adapter *adapter$/;"	f	file:
-_pg_txpwr_src_str	hal/hal_com_phycfg.c	/^const char *const _pg_txpwr_src_str[] = {$/;"	v
-_phy_get_txpwr_lmt	hal/hal_com_phycfg.c	/^static s8 _phy_get_txpwr_lmt($/;"	f	file:
-_phydm_arfr_num	hal/phydm/phydm_rainfo.h	/^typedef enum _phydm_arfr_num {$/;"	g
-_pkt	include/osdep_service_bsd.h	/^	typedef	struct mbuf	_pkt;$/;"	t	typeref:struct:mbuf
-_pkt	include/osdep_service_ce.h	/^typedef	NDIS_PACKET	_pkt;$/;"	t
-_pkt	include/osdep_service_linux.h	/^typedef	struct sk_buff	_pkt;$/;"	t	typeref:struct:sk_buff
-_pkt	include/osdep_service_xp.h	/^	typedef	NDIS_PACKET	_pkt;$/;"	t
-_proto_cap_str	hal/hal_com.c	/^static const char *const _proto_cap_str[] = {$/;"	v	file:
-_pwrlock	include/rtw_pwrctrl.h	/^typedef _sema _pwrlock;$/;"	t
-_queue	include/osdep_service_bsd.h	/^	typedef struct	__queue	_queue;$/;"	t	typeref:struct:__queue
-_queue	include/osdep_service_ce.h	/^typedef struct	__queue	_queue;$/;"	t	typeref:struct:__queue
-_queue	include/osdep_service_linux.h	/^typedef struct	__queue	_queue;$/;"	t	typeref:struct:__queue
-_queue	include/osdep_service_xp.h	/^	typedef struct	__queue	_queue;$/;"	t	typeref:struct:__queue
-_rate_section_str	core/rtw_ieee80211.c	/^static const char *const _rate_section_str[] = {$/;"	v	file:
-_read16	include/rtw_io.h	/^	u16(*_read16)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_read32	include/rtw_io.h	/^	u32(*_read32)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_read8	include/rtw_io.h	/^	u8(*_read8)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_read_interrupt	include/rtw_io.h	/^	u32(*_read_interrupt)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_read_mem	include/rtw_io.h	/^	void (*_read_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);$/;"	m	struct:_io_ops
-_read_port	include/rtw_io.h	/^	u32(*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);$/;"	m	struct:_io_ops
-_read_port_cancel	include/rtw_io.h	/^	void (*_read_port_cancel)(struct intf_hdl *pintfhdl);$/;"	m	struct:_io_ops
-_read_rfreg	core/rtw_mp.c	/^u32 _read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask)$/;"	f
-_reg_11AC	hal/phydm/phydm_interface.h	59;"	d
-_reg_11N	hal/phydm/phydm_interface.h	58;"	d
-_reg_all	hal/phydm/phydm_interface.h	37;"	d
-_reg_ic	hal/phydm/phydm_interface.h	38;"	d
-_remove_bfee_entry	core/rtw_beamforming.c	/^static void _remove_bfee_entry(PADAPTER adapter, struct beamformee_entry *entry)$/;"	f	file:
-_remove_bfer_entry	core/rtw_beamforming.c	/^static void _remove_bfer_entry(PADAPTER adapter, struct beamformer_entry *entry)$/;"	f	file:
-_rf_type_drv2halmac	hal/hal_halmac.c	/^static inline HALMAC_RF_TYPE _rf_type_drv2halmac(RT_RF_TYPE_DEF_E rf_drv)$/;"	f	file:
-_rt_rf_power_state	include/rtw_pwrctrl.h	/^typedef enum _rt_rf_power_state {$/;"	g
-_rtk_cat	hal/phydm/phydm_interface.h	64;"	d
-_rtw_IOL_append_WB_cmd	core/rtw_iol.c	/^int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value)$/;"	f
-_rtw_IOL_append_WB_cmd	core/rtw_iol.c	/^int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, u8 mask)$/;"	f
-_rtw_IOL_append_WD_cmd	core/rtw_iol.c	/^int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value)$/;"	f
-_rtw_IOL_append_WD_cmd	core/rtw_iol.c	/^int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, u32 mask)$/;"	f
-_rtw_IOL_append_WRF_cmd	core/rtw_iol.c	/^int _rtw_IOL_append_WRF_cmd(struct xmit_frame *xmit_frame, u8 rf_path, u16 addr, u32 value, u32 mask)$/;"	f
-_rtw_IOL_append_WW_cmd	core/rtw_iol.c	/^int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value)$/;"	f
-_rtw_IOL_append_WW_cmd	core/rtw_iol.c	/^int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, u16 mask)$/;"	f
-_rtw_alloc_network	core/rtw_mlme.c	/^struct	wlan_network *_rtw_alloc_network(struct	mlme_priv *pmlmepriv) \/* (_queue *free_queue) *\/$/;"	f
-_rtw_alloc_recvframe	core/rtw_recv.c	/^union recv_frame *_rtw_alloc_recvframe(_queue *pfree_recv_queue)$/;"	f
-_rtw_camctl_chk_cap	core/rtw_wlan_util.c	/^inline bool _rtw_camctl_chk_cap(_adapter *adapter, u8 cap)$/;"	f
-_rtw_camctl_chk_flags	core/rtw_wlan_util.c	/^inline bool _rtw_camctl_chk_flags(_adapter *adapter, u32 flags)$/;"	f
-_rtw_camctl_clr_flags	core/rtw_wlan_util.c	/^inline void _rtw_camctl_clr_flags(_adapter *adapter, u32 flags)$/;"	f
-_rtw_camctl_set_flags	core/rtw_wlan_util.c	/^inline void _rtw_camctl_set_flags(_adapter *adapter, u32 flags)$/;"	f
-_rtw_camid_is_gk	core/rtw_wlan_util.c	/^inline bool _rtw_camid_is_gk(_adapter *adapter, u8 cam_id)$/;"	f
-_rtw_camid_search	core/rtw_wlan_util.c	/^s16 _rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk)$/;"	f
-_rtw_cfg80211_surveydone_event_callback	os_dep/linux/ioctl_cfg80211.c	/^static void _rtw_cfg80211_surveydone_event_callback(_adapter *padapter, struct cfg80211_scan_request *scan_req)$/;"	f	file:
-_rtw_chset_update_non_ocp	core/rtw_mlme_ext.c	/^static void _rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms)$/;"	f	file:
-_rtw_deinit_queue	os_dep/osdep_service.c	/^void _rtw_deinit_queue(_queue *pqueue)$/;"	f
-_rtw_dequeue_cmd	core/rtw_cmd.c	/^struct	cmd_obj	*_rtw_dequeue_cmd(_queue *queue)$/;"	f
-_rtw_down_sema	os_dep/osdep_service.c	/^u32 _rtw_down_sema(_sema *sema)$/;"	f
-_rtw_enqueue_cmd	core/rtw_cmd.c	/^sint _rtw_enqueue_cmd(_queue *queue, struct cmd_obj *obj, bool to_head)$/;"	f
-_rtw_enqueue_network	core/rtw_mlme.c	/^sint	_rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork)$/;"	f
-_rtw_enqueue_recvframe	core/rtw_recv.c	/^sint _rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue)$/;"	f
-_rtw_find_network	core/rtw_mlme.c	/^struct wlan_network *_rtw_find_network(_queue *scanned_queue, u8 *addr)$/;"	f
-_rtw_find_same_network	core/rtw_mlme.c	/^struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network)$/;"	f
-_rtw_free_cmd_priv	core/rtw_cmd.c	/^void _rtw_free_cmd_priv(struct	cmd_priv *pcmdpriv)$/;"	f
-_rtw_free_evt_priv	core/rtw_cmd.c	/^void _rtw_free_evt_priv(struct	evt_priv *pevtpriv)$/;"	f
-_rtw_free_mlme_priv	core/rtw_mlme.c	/^void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)$/;"	f
-_rtw_free_network	core/rtw_mlme.c	/^void _rtw_free_network(struct	mlme_priv *pmlmepriv , struct wlan_network *pnetwork, u8 isfreeall)$/;"	f
-_rtw_free_network_nolock	core/rtw_mlme.c	/^void _rtw_free_network_nolock(struct	mlme_priv *pmlmepriv, struct wlan_network *pnetwork)$/;"	f
-_rtw_free_network_queue	core/rtw_mlme.c	/^void _rtw_free_network_queue(_adapter *padapter, u8 isfreeall)$/;"	f
-_rtw_free_recv_priv	core/rtw_recv.c	/^void _rtw_free_recv_priv(struct recv_priv *precvpriv)$/;"	f
-_rtw_free_sema	os_dep/osdep_service.c	/^void _rtw_free_sema(_sema	*sema)$/;"	f
-_rtw_free_sta_priv	core/rtw_sta_mgt.c	/^u32	_rtw_free_sta_priv(struct	sta_priv *pstapriv)$/;"	f
-_rtw_free_sta_recv_priv_lock	core/rtw_sta_mgt.c	/^static void	_rtw_free_sta_recv_priv_lock(struct sta_recv_priv *psta_recvpriv)$/;"	f	file:
-_rtw_free_sta_xmit_priv_lock	core/rtw_sta_mgt.c	/^void	_rtw_free_sta_xmit_priv_lock(struct sta_xmit_priv *psta_xmitpriv)$/;"	f
-_rtw_free_xmit_priv	core/rtw_xmit.c	/^void _rtw_free_xmit_priv(struct xmit_priv *pxmitpriv)$/;"	f
-_rtw_get_trx_share_mode	hal/hal_halmac.c	/^static HALMAC_RX_FIFO_EXPANDING_MODE _rtw_get_trx_share_mode(_adapter *adapter)$/;"	f	file:
-_rtw_init_cmd_priv	core/rtw_cmd.c	/^sint	_rtw_init_cmd_priv(struct	cmd_priv *pcmdpriv)$/;"	f
-_rtw_init_evt_priv	core/rtw_cmd.c	/^sint _rtw_init_evt_priv(struct evt_priv *pevtpriv)$/;"	f
-_rtw_init_listhead	os_dep/osdep_service.c	/^void _rtw_init_listhead(_list *list)$/;"	f
-_rtw_init_mlme_priv	core/rtw_mlme.c	/^sint	_rtw_init_mlme_priv(_adapter *padapter)$/;"	f
-_rtw_init_queue	os_dep/osdep_service.c	/^void _rtw_init_queue(_queue *pqueue)$/;"	f
-_rtw_init_recv_priv	core/rtw_recv.c	/^sint _rtw_init_recv_priv(struct recv_priv *precvpriv, _adapter *padapter)$/;"	f
-_rtw_init_sema	os_dep/osdep_service.c	/^void _rtw_init_sema(_sema	*sema, int init_val)$/;"	f
-_rtw_init_sta_priv	core/rtw_sta_mgt.c	/^u32	_rtw_init_sta_priv(struct	sta_priv *pstapriv)$/;"	f
-_rtw_init_sta_recv_priv	core/rtw_recv.c	/^void _rtw_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv)$/;"	f
-_rtw_init_sta_xmit_priv	core/rtw_xmit.c	/^void	_rtw_init_sta_xmit_priv(struct sta_xmit_priv *psta_xmitpriv)$/;"	f
-_rtw_init_stainfo	core/rtw_sta_mgt.c	/^void _rtw_init_stainfo(struct sta_info *psta)$/;"	f
-_rtw_init_xmit_priv	core/rtw_xmit.c	/^s32	_rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, _adapter *padapter)$/;"	f
-_rtw_ioctl_wext_private	os_dep/linux/ioctl_linux.c	/^static int _rtw_ioctl_wext_private(struct net_device *dev, union iwreq_data *wrq_data)$/;"	f	file:
-_rtw_is_radar_freq	os_dep/linux/wifi_regd.c	/^static bool _rtw_is_radar_freq(u16 center_freq)$/;"	f	file:
-_rtw_join_timeout_handler	core/rtw_mlme.c	/^void _rtw_join_timeout_handler(_adapter *adapter)$/;"	f
-_rtw_malloc	os_dep/osdep_service.c	/^u8 *_rtw_malloc(u32 sz)$/;"	f
-_rtw_mbid_cam_search_by_ifaceid	hal/hal_com.c	/^static u8 _rtw_mbid_cam_search_by_ifaceid(_adapter *adapter, u8 iface_id)$/;"	f	file:
-_rtw_mbid_cam_search_by_macaddr	hal/hal_com.c	/^static u8 _rtw_mbid_cam_search_by_macaddr(_adapter *adapter, u8 *mac_addr)$/;"	f	file:
-_rtw_mdelay_os	os_dep/osdep_service.c	/^void _rtw_mdelay_os(int ms, const char *func, const int line)$/;"	f
-_rtw_memcmp	os_dep/osdep_service.c	/^int	_rtw_memcmp(const void *dst, const void *src, u32 sz)$/;"	f
-_rtw_memcpy	os_dep/osdep_service.c	/^void _rtw_memcpy(void *dst, const void *src, u32 sz)$/;"	f
-_rtw_memmove	os_dep/osdep_service.c	/^inline void _rtw_memmove(void *dst, const void *src, u32 sz)$/;"	f
-_rtw_memset	os_dep/osdep_service.c	/^void _rtw_memset(void *pbuf, int c, u32 sz)$/;"	f
-_rtw_mfree	os_dep/osdep_service.c	/^void	_rtw_mfree(u8 *pbuf, u32 sz)$/;"	f
-_rtw_mi_adapter_reset	core/rtw_mi.c	/^static void _rtw_mi_adapter_reset(_adapter *padapter , u8 exclude_self)$/;"	f	file:
-_rtw_mi_beacon_update	core/rtw_mi.c	/^static u8 _rtw_mi_beacon_update(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_buddy_clone_bcmc_packet	core/rtw_mi.c	/^static s32 _rtw_mi_buddy_clone_bcmc_packet(_adapter *adapter, union recv_frame *precvframe, u8 *pphy_status, union recv_frame *pcloneframe)$/;"	f	file:
-_rtw_mi_busy_traffic_check	core/rtw_mi.c	/^u8 _rtw_mi_busy_traffic_check(_adapter *padapter, void *data)$/;"	f
-_rtw_mi_cancel_all_timer	core/rtw_mi.c	/^static u8 _rtw_mi_cancel_all_timer(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_check_fwstate	core/rtw_mi.c	/^static u8 _rtw_mi_check_fwstate(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_check_miracast_enabled	core/rtw_mi.c	/^static u8 _rtw_mi_check_miracast_enabled(_adapter *padapter , void *data)$/;"	f	file:
-_rtw_mi_check_mlmeinfo_state	core/rtw_mi.c	/^static u8 _rtw_mi_check_mlmeinfo_state(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_check_pending_xmitbuf	core/rtw_mi.c	/^static u8 _rtw_mi_check_pending_xmitbuf(_adapter *padapter , void *data)$/;"	f	file:
-_rtw_mi_dequeue_writeport	core/rtw_mi.c	/^static u8 _rtw_mi_dequeue_writeport(_adapter *padapter , bool exclude_self)$/;"	f	file:
-_rtw_mi_dev_unload	core/rtw_mi.c	/^static u8 _rtw_mi_dev_unload(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_dynamic_check_timer_handlder	core/rtw_mi.c	/^static u8 _rtw_mi_dynamic_check_timer_handlder(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_dynamic_chk_wk_hdl	core/rtw_mi.c	/^static u8 _rtw_mi_dynamic_chk_wk_hdl(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_get_ch_setting_union	core/rtw_mi.c	/^int _rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset, bool include_self)$/;"	f
-_rtw_mi_hal_dump_macaddr	core/rtw_mi.c	/^static u8 _rtw_mi_hal_dump_macaddr(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_intf_start	core/rtw_mi.c	/^static u8 _rtw_mi_intf_start(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_intf_stop	core/rtw_mi.c	/^static u8 _rtw_mi_intf_stop(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_is_scan_deny	core/rtw_mi.c	/^static u8 _rtw_mi_is_scan_deny(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_issue_nulldata	core/rtw_mi.c	/^static u8 _rtw_mi_issue_nulldata(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_netif_carrier_on	core/rtw_mi.c	/^static u8 _rtw_mi_netif_carrier_on(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_netif_stop_queue	core/rtw_mi.c	/^static u8 _rtw_mi_netif_stop_queue(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_netif_wake_queue	core/rtw_mi.c	/^static u8 _rtw_mi_netif_wake_queue(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_os_xmit_schedule	core/rtw_mi.c	/^static u8 _rtw_mi_os_xmit_schedule(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_p2p_chk_state	core/rtw_mi.c	/^static u8 _rtw_mi_p2p_chk_state(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_process	core/rtw_mi.c	/^static u8 _rtw_mi_process(_adapter *padapter, bool exclude_self,$/;"	f	file:
-_rtw_mi_report_survey_event	core/rtw_mi.c	/^static u8 _rtw_mi_report_survey_event(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_reset_drv_sw	core/rtw_mi.c	/^static u8 _rtw_mi_reset_drv_sw(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_scan_abort	core/rtw_mi.c	/^static u8 _rtw_mi_scan_abort(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_set_scan_deny	core/rtw_mi.c	/^static u8 _rtw_mi_set_scan_deny(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_set_tx_beacon_cmd	core/rtw_mi.c	/^static u8 _rtw_mi_set_tx_beacon_cmd(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_sreset_adapter_hdl	core/rtw_mi.c	/^static u8 _rtw_mi_sreset_adapter_hdl(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_start_drv_threads	core/rtw_mi.c	/^static u8 _rtw_mi_start_drv_threads(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_status	core/rtw_mi.c	/^void _rtw_mi_status(_adapter *adapter, struct mi_state *mstate, bool include_self)$/;"	f
-_rtw_mi_stay_in_p2p_mode	core/rtw_mi.c	/^static u8 _rtw_mi_stay_in_p2p_mode(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_stop_drv_threads	core/rtw_mi.c	/^static u8 _rtw_mi_stop_drv_threads(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_suspend_free_assoc_resource	core/rtw_mi.c	/^static u8 _rtw_mi_suspend_free_assoc_resource(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mi_traffic_statistics	core/rtw_mi.c	/^static u8 _rtw_mi_traffic_statistics(_adapter *padapter , void *data)$/;"	f	file:
-_rtw_mi_tx_beacon_hdl	core/rtw_mi.c	/^static u8 _rtw_mi_tx_beacon_hdl(_adapter *adapter, void *data)$/;"	f	file:
-_rtw_mi_xmit_tasklet_schedule	core/rtw_mi.c	/^static u8 _rtw_mi_xmit_tasklet_schedule(_adapter *padapter, void *data)$/;"	f	file:
-_rtw_mutex_free	os_dep/osdep_service.c	/^void	_rtw_mutex_free(_mutex *pmutex)$/;"	f
-_rtw_mutex_init	os_dep/osdep_service.c	/^void	_rtw_mutex_init(_mutex *pmutex)$/;"	f
-_rtw_napi_gro_receive	os_dep/osdep_service.c	/^inline gro_result_t _rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb)$/;"	f
-_rtw_netif_receive_skb	os_dep/osdep_service.c	/^inline int _rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb)$/;"	f
-_rtw_netif_rx	os_dep/osdep_service.c	/^inline int _rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb)$/;"	f
-_rtw_open_pktfile	os_dep/linux/xmit_linux.c	/^void _rtw_open_pktfile(_pkt *pktptr, struct pkt_file *pfile)$/;"	f
-_rtw_p2p_chk_role	include/rtw_p2p.h	/^static inline bool _rtw_p2p_chk_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)$/;"	f
-_rtw_p2p_chk_state	include/rtw_p2p.h	/^static inline bool _rtw_p2p_chk_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)$/;"	f
-_rtw_p2p_pre_state	include/rtw_p2p.h	/^static inline int _rtw_p2p_pre_state(struct wifidirect_info *wdinfo)$/;"	f
-_rtw_p2p_role	include/rtw_p2p.h	/^static inline int _rtw_p2p_role(struct wifidirect_info *wdinfo)$/;"	f
-_rtw_p2p_set_pre_state	include/rtw_p2p.h	/^static inline void _rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)$/;"	f
-_rtw_p2p_set_role	include/rtw_p2p.h	/^static inline void _rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)$/;"	f
-_rtw_p2p_set_state	include/rtw_p2p.h	/^static inline void _rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state)$/;"	f
-_rtw_p2p_state	include/rtw_p2p.h	/^static inline int _rtw_p2p_state(struct wifidirect_info *wdinfo)$/;"	f
-_rtw_pktfile_read	os_dep/linux/xmit_linux.c	/^uint _rtw_pktfile_read(struct pkt_file *pfile, u8 *rmem, uint rlen)$/;"	f
-_rtw_pskb_copy	os_dep/osdep_service.c	/^inline struct sk_buff *_rtw_pskb_copy(struct sk_buff *skb)$/;"	f
-_rtw_pwr_wakeup	core/rtw_pwrctrl.c	/^int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)$/;"	f
-_rtw_queue_empty	os_dep/osdep_service.c	/^u32	  _rtw_queue_empty(_queue	*pqueue)$/;"	f
-_rtw_read16	core/rtw_io.c	/^u16 _rtw_read16(_adapter *adapter, u32 addr)$/;"	f
-_rtw_read32	core/rtw_io.c	/^u32 _rtw_read32(_adapter *adapter, u32 addr)$/;"	f
-_rtw_read8	core/rtw_io.c	/^u8 _rtw_read8(_adapter *adapter, u32 addr)$/;"	f
-_rtw_read_mem	core/rtw_io.c	/^void _rtw_read_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)$/;"	f
-_rtw_read_port	core/rtw_io.c	/^void _rtw_read_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)$/;"	f
-_rtw_read_port_cancel	core/rtw_io.c	/^void _rtw_read_port_cancel(_adapter *adapter)$/;"	f
-_rtw_reg_apply_flags	os_dep/linux/wifi_regd.c	/^static void _rtw_reg_apply_flags(struct wiphy *wiphy)$/;"	f	file:
-_rtw_reg_apply_radar_flags	os_dep/linux/wifi_regd.c	/^static void _rtw_reg_apply_radar_flags(struct wiphy *wiphy)$/;"	f	file:
-_rtw_reg_apply_world_flags	os_dep/linux/wifi_regd.c	/^static void _rtw_reg_apply_world_flags(struct wiphy *wiphy,$/;"	f	file:
-_rtw_reg_notifier	os_dep/linux/wifi_regd.c	/^void _rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)$/;"	f
-_rtw_reg_notifier_apply	os_dep/linux/wifi_regd.c	/^static int _rtw_reg_notifier_apply(struct wiphy *wiphy,$/;"	f	file:
-_rtw_regd_find_country	os_dep/linux/wifi_regd.c	/^static struct country_code_to_enum_rd *_rtw_regd_find_country(u16 countrycode)$/;"	f	file:
-_rtw_regd_init_wiphy	os_dep/linux/wifi_regd.c	/^static void _rtw_regd_init_wiphy(struct rtw_regulatory *reg, struct wiphy *wiphy)$/;"	f	file:
-_rtw_regdomain_select	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain *_rtw_regdomain_select(struct$/;"	f	file:
-_rtw_reordering_ctrl_timeout_handler	os_dep/linux/recv_linux.c	/^void _rtw_reordering_ctrl_timeout_handler(void *FunctionContext)$/;"	f
-_rtw_rfctl_overlap_radar_detect_ch	core/rtw_mlme_ext.c	/^bool _rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset)$/;"	f
-_rtw_roaming	core/rtw_mlme.c	/^void _rtw_roaming(_adapter *padapter, struct wlan_network *tgt_network)$/;"	f
-_rtw_roaming	include/rtw_mlme.h	1154;"	d
-_rtw_scan_timeout_handler	os_dep/linux/mlme_linux.c	/^void _rtw_scan_timeout_handler(void *FunctionContext)$/;"	f
-_rtw_sd_f0_read8	core/rtw_io.c	/^u8 _rtw_sd_f0_read8(_adapter *adapter, u32 addr)$/;"	f
-_rtw_sd_iread16	core/rtw_io.c	/^u16 _rtw_sd_iread16(_adapter *adapter, u32 addr)$/;"	f
-_rtw_sd_iread32	core/rtw_io.c	/^u32 _rtw_sd_iread32(_adapter *adapter, u32 addr)$/;"	f
-_rtw_sd_iread8	core/rtw_io.c	/^u8 _rtw_sd_iread8(_adapter *adapter, u32 addr)$/;"	f
-_rtw_sd_iwrite16	core/rtw_io.c	/^int _rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val)$/;"	f
-_rtw_sd_iwrite32	core/rtw_io.c	/^int _rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val)$/;"	f
-_rtw_sd_iwrite8	core/rtw_io.c	/^int _rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val)$/;"	f
-_rtw_sec_camid_is_used	core/rtw_wlan_util.c	/^bool _rtw_sec_camid_is_used(struct cam_ctl_t *cam_ctl, u8 id)$/;"	f
-_rtw_set_chplan_cmd	core/rtw_cmd.c	/^u8 _rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, const struct country_chplan *country_ent, u8 swconfig)$/;"	f
-_rtw_set_pwr_state_check_timer	include/rtw_pwrctrl.h	454;"	d
-_rtw_set_scan_deny_timer_hdl	os_dep/linux/mlme_linux.c	/^void _rtw_set_scan_deny_timer_hdl(void *FunctionContext)$/;"	f
-_rtw_skb_alloc	os_dep/osdep_service.c	/^inline struct sk_buff *_rtw_skb_alloc(u32 sz)$/;"	f
-_rtw_skb_clone	os_dep/osdep_service.c	/^inline struct sk_buff *_rtw_skb_clone(struct sk_buff *skb)$/;"	f
-_rtw_skb_copy	os_dep/osdep_service.c	/^inline struct sk_buff *_rtw_skb_copy(const struct sk_buff *skb)$/;"	f
-_rtw_skb_free	os_dep/osdep_service.c	/^inline void _rtw_skb_free(struct sk_buff *skb)$/;"	f
-_rtw_skb_queue_purge	os_dep/osdep_service.c	/^void _rtw_skb_queue_purge(struct sk_buff_head *list)$/;"	f
-_rtw_spinlock	os_dep/osdep_service.c	/^void	_rtw_spinlock(_lock	*plock)$/;"	f
-_rtw_spinlock_ex	os_dep/osdep_service.c	/^void	_rtw_spinlock_ex(_lock	*plock)$/;"	f
-_rtw_spinlock_free	os_dep/osdep_service.c	/^void	_rtw_spinlock_free(_lock *plock)$/;"	f
-_rtw_spinlock_init	os_dep/osdep_service.c	/^void	_rtw_spinlock_init(_lock *plock)$/;"	f
-_rtw_spinunlock	os_dep/osdep_service.c	/^void	_rtw_spinunlock(_lock *plock)$/;"	f
-_rtw_spinunlock_ex	os_dep/osdep_service.c	/^void	_rtw_spinunlock_ex(_lock *plock)$/;"	f
-_rtw_udelay_os	os_dep/osdep_service.c	/^void _rtw_udelay_os(int us, const char *func, const int line)$/;"	f
-_rtw_up_sema	os_dep/osdep_service.c	/^void _rtw_up_sema(_sema	*sema)$/;"	f
-_rtw_usb_buffer_alloc	os_dep/osdep_service.c	/^inline void *_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma)$/;"	f
-_rtw_usb_buffer_free	os_dep/osdep_service.c	/^inline void _rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma)$/;"	f
-_rtw_vmalloc	os_dep/osdep_service.c	/^inline u8 *_rtw_vmalloc(u32 sz)$/;"	f
-_rtw_vmfree	os_dep/osdep_service.c	/^inline void _rtw_vmfree(u8 *pbuf, u32 sz)$/;"	f
-_rtw_wait_scan_done	core/rtw_mlme.c	/^static u32 _rtw_wait_scan_done(_adapter *adapter, u8 abort, u32 timeout_ms)$/;"	f	file:
-_rtw_write16	core/rtw_io.c	/^int _rtw_write16(_adapter *adapter, u32 addr, u16 val)$/;"	f
-_rtw_write16_async	core/rtw_io.c	/^int _rtw_write16_async(_adapter *adapter, u32 addr, u16 val)$/;"	f
-_rtw_write32	core/rtw_io.c	/^int _rtw_write32(_adapter *adapter, u32 addr, u32 val)$/;"	f
-_rtw_write32_async	core/rtw_io.c	/^int _rtw_write32_async(_adapter *adapter, u32 addr, u32 val)$/;"	f
-_rtw_write8	core/rtw_io.c	/^int _rtw_write8(_adapter *adapter, u32 addr, u8 val)$/;"	f
-_rtw_write8_async	core/rtw_io.c	/^int _rtw_write8_async(_adapter *adapter, u32 addr, u8 val)$/;"	f
-_rtw_writeN	core/rtw_io.c	/^int _rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *pdata)$/;"	f
-_rtw_write_mem	core/rtw_io.c	/^void _rtw_write_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)$/;"	f
-_rtw_write_port	core/rtw_io.c	/^u32 _rtw_write_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)$/;"	f
-_rtw_write_port_and_wait	core/rtw_io.c	/^u32 _rtw_write_port_and_wait(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem, int timeout_ms)$/;"	f
-_rtw_write_port_cancel	core/rtw_io.c	/^void _rtw_write_port_cancel(_adapter *adapter)$/;"	f
-_rtw_xmit_entry	os_dep/linux/xmit_linux.c	/^int _rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)$/;"	f
-_rtw_zmalloc	os_dep/osdep_service.c	/^u8 *_rtw_zmalloc(u32 sz)$/;"	f
-_rtw_zvmalloc	os_dep/osdep_service.c	/^inline u8 *_rtw_zvmalloc(u32 sz)$/;"	f
-_rwlock	include/osdep_service_ce.h	/^typedef HANDLE 		_rwlock; \/\/Mutex$/;"	t
-_sa_query_timer_hdl	os_dep/linux/mlme_linux.c	/^void _sa_query_timer_hdl(void *FunctionContext)$/;"	f
-_scan_state_str	core/rtw_mlme_ext.c	/^static const char *const _scan_state_str[] = {$/;"	v	file:
-_sd_cmd52_read	os_dep/linux/sdio_ops_linux.c	/^s32 _sd_cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)$/;"	f
-_sd_cmd52_write	os_dep/linux/sdio_ops_linux.c	/^s32 _sd_cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)$/;"	f
-_sd_f0_read8	include/rtw_io.h	/^	u8(*_sd_f0_read8)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_sd_iread16	include/rtw_io.h	/^	u16(*_sd_iread16)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_sd_iread32	include/rtw_io.h	/^	u32(*_sd_iread32)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_sd_iread8	include/rtw_io.h	/^	u8(*_sd_iread8)(struct intf_hdl *pintfhdl, u32 addr);$/;"	m	struct:_io_ops
-_sd_iwrite16	include/rtw_io.h	/^	int (*_sd_iwrite16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);$/;"	m	struct:_io_ops
-_sd_iwrite32	include/rtw_io.h	/^	int (*_sd_iwrite32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);$/;"	m	struct:_io_ops
-_sd_iwrite8	include/rtw_io.h	/^	int (*_sd_iwrite8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);$/;"	m	struct:_io_ops
-_sd_read	os_dep/linux/sdio_ops_linux.c	/^s32 _sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)$/;"	f
-_sd_read32	os_dep/linux/sdio_ops_linux.c	/^u32 _sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err)$/;"	f
-_sd_read8	os_dep/linux/sdio_ops_linux.c	/^u8 _sd_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err)$/;"	f
-_sd_write	os_dep/linux/sdio_ops_linux.c	/^s32 _sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)$/;"	f
-_sd_write32	os_dep/linux/sdio_ops_linux.c	/^void _sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err)$/;"	f
-_sdio_local_read	hal/rtl8723d/sdio/sdio_ops.c	/^s32 _sdio_local_read($/;"	f
-_sdio_local_write	hal/rtl8723d/sdio/sdio_ops.c	/^s32 _sdio_local_write($/;"	f
-_security_type_str	core/rtw_security.c	/^static const char *_security_type_str[] = {$/;"	v	file:
-_sema	include/osdep_service_bsd.h	/^	typedef struct 	sema _sema;$/;"	t	typeref:struct:sema
-_sema	include/osdep_service_ce.h	/^typedef HANDLE 	_sema;$/;"	t
-_sema	include/osdep_service_linux.h	/^typedef struct	semaphore _sema;$/;"	t	typeref:struct:semaphore
-_sema	include/osdep_service_xp.h	/^	typedef KSEMAPHORE 	_sema;$/;"	t
-_send_delba_sta_tid	core/rtw_mlme_ext.c	/^static unsigned int _send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid$/;"	f	file:
-_send_general_info	hal/hal_halmac.c	/^static int _send_general_info(struct dvobj_priv *d)$/;"	f	file:
-_seqdump	include/rtw_debug.h	83;"	d
-_seqdump	include/rtw_debug.h	87;"	d
-_seqdump	include/rtw_debug.h	90;"	d
-_seqdump	include/rtw_debug.h	93;"	d
-_seqdump	include/rtw_debug.h	96;"	d
-_set_timer	include/osdep_service_bsd.h	/^__inline static void _set_timer(_timer *ptimer,u32 delay_time)$/;"	f
-_set_timer	include/osdep_service_ce.h	/^__inline static void _set_timer(_timer *ptimer,u32 delay_time)$/;"	f
-_set_timer	include/osdep_service_linux.h	/^__inline static void _set_timer(_timer *ptimer, u32 delay_time)$/;"	f
-_set_timer	include/osdep_service_xp.h	/^__inline static void _set_timer(_timer *ptimer,u32 delay_time)$/;"	f
-_set_workitem	include/osdep_service_bsd.h	/^__inline static void _set_workitem(_workitem *pwork)$/;"	f
-_set_workitem	include/osdep_service_ce.h	/^__inline static void _set_workitem(_workitem *pwork)$/;"	f
-_set_workitem	include/osdep_service_linux.h	/^__inline static void _set_workitem(_workitem *pwork)$/;"	f
-_set_workitem	include/osdep_service_xp.h	/^__inline static void _set_workitem(_workitem *pwork)$/;"	f
-_skb_refdst	include/osdep_service_bsd.h	/^	unsigned long		_skb_refdst;$/;"	m	struct:sk_buff
-_survey_timer_hdl	os_dep/linux/mlme_linux.c	/^void _survey_timer_hdl(void *FunctionContext)$/;"	f
-_sync_irp_protocol_rw	include/rtw_io.h	/^	void (*_sync_irp_protocol_rw)(struct io_queue *pio_q);$/;"	m	struct:_io_ops
-_tag_PhyDM_DFS_REGION_DOMAIN	hal/phydm/phydm_dfs.h	/^typedef enum _tag_PhyDM_DFS_REGION_DOMAIN {$/;"	g
-_tag_PhyDM_REGULATION_Type	hal/phydm/phydm_adaptivity.h	/^typedef enum _tag_PhyDM_REGULATION_Type {$/;"	g
-_tdls_ch_switch_monitor_timer_hdl	core/rtw_tdls.c	/^void _tdls_ch_switch_monitor_timer_hdl(void *FunctionContext)$/;"	f
-_tdls_ch_switch_timer_hdl	core/rtw_tdls.c	/^void _tdls_ch_switch_timer_hdl(void *FunctionContext)$/;"	f
-_tdls_delay_timer_hdl	core/rtw_tdls.c	/^void _tdls_delay_timer_hdl(void *FunctionContext)$/;"	f
-_tdls_handshake_timer_hdl	core/rtw_tdls.c	/^void _tdls_handshake_timer_hdl(void *FunctionContext)$/;"	f
-_tdls_pti_timer_hdl	core/rtw_tdls.c	/^void _tdls_pti_timer_hdl(void *FunctionContext)$/;"	f
-_tdls_stay_on_base_chnl_timer_hdl	core/rtw_tdls.c	/^void _tdls_stay_on_base_chnl_timer_hdl(void *FunctionContext)$/;"	f
-_tdls_tpk_timer_hdl	core/rtw_tdls.c	/^void _tdls_tpk_timer_hdl(void *FunctionContext)$/;"	f
-_thread_hdl_	include/osdep_service_bsd.h	/^	typedef pid_t		_thread_hdl_;$/;"	t
-_thread_hdl_	include/osdep_service_ce.h	/^typedef HANDLE 	_thread_hdl_;$/;"	t
-_thread_hdl_	include/osdep_service_linux.h	/^typedef void		*_thread_hdl_;$/;"	t
-_thread_hdl_	include/osdep_service_xp.h	/^	typedef PKTHREAD _thread_hdl_;$/;"	t
-_timer	include/osdep_service_bsd.h	/^	typedef struct timer_list _timer;$/;"	t	typeref:struct:timer_list
-_timer	include/osdep_service_ce.h	/^typedef NDIS_MINIPORT_TIMER    _timer;$/;"	t
-_timer	include/osdep_service_linux.h	/^typedef struct timer_list _timer;$/;"	t	typeref:struct:timer_list
-_timer	include/osdep_service_xp.h	/^	typedef NDIS_MINIPORT_TIMER    _timer;$/;"	t
-_trx_share_mode_drv2halmac	hal/hal_halmac.c	/^static inline HALMAC_RX_FIFO_EXPANDING_MODE _trx_share_mode_drv2halmac(u8 trx_share_mode)$/;"	f	file:
-_tx_beacon_timer_handlder	os_dep/linux/os_intfs.c	/^void _tx_beacon_timer_handlder(void *FunctionContext)$/;"	f
-_update_beacon	core/rtw_ap.c	/^void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, const char *tag)$/;"	f
-_update_min_sounding_period	core/rtw_beamforming.c	/^static void _update_min_sounding_period(PADAPTER adapter, u16 period, u8 leave)$/;"	f	file:
-_usb_mode_drv2halmac	hal/hal_halmac.c	/^static inline HALMAC_USB_MODE _usb_mode_drv2halmac(enum RTW_USB_SPEED usb_mode)$/;"	f	file:
-_usbctrl_vendorreq_async_callback	include/usb_ops_linux.h	44;"	d
-_vlan	include/if_ether.h	/^struct _vlan {$/;"	s
-_wl_func_str	hal/hal_com.c	/^static const char *const _wl_func_str[] = {$/;"	v	file:
-_workitem	include/osdep_service_bsd.h	/^	typedef struct work_struct _workitem;$/;"	t	typeref:struct:work_struct
-_workitem	include/osdep_service_ce.h	/^typedef NDIS_WORK_ITEM _workitem;$/;"	t
-_workitem	include/osdep_service_linux.h	/^	typedef struct tq_struct _workitem;$/;"	t	typeref:struct:tq_struct
-_workitem	include/osdep_service_linux.h	/^	typedef struct work_struct _workitem;$/;"	t	typeref:struct:work_struct
-_workitem	include/osdep_service_xp.h	/^	typedef NDIS_WORK_ITEM _workitem;$/;"	t
-_wowlan_subcode	include/hal_intf.h	/^typedef enum _wowlan_subcode {$/;"	g
-_write16	include/rtw_io.h	/^	int (*_write16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);$/;"	m	struct:_io_ops
-_write16_async	include/rtw_io.h	/^	int (*_write16_async)(struct intf_hdl *pintfhdl, u32 addr, u16 val);$/;"	m	struct:_io_ops
-_write32	include/rtw_io.h	/^	int (*_write32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);$/;"	m	struct:_io_ops
-_write32_async	include/rtw_io.h	/^	int (*_write32_async)(struct intf_hdl *pintfhdl, u32 addr, u32 val);$/;"	m	struct:_io_ops
-_write8	include/rtw_io.h	/^	int (*_write8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);$/;"	m	struct:_io_ops
-_write8_async	include/rtw_io.h	/^	int (*_write8_async)(struct intf_hdl *pintfhdl, u32 addr, u8 val);$/;"	m	struct:_io_ops
-_writeN	include/rtw_io.h	/^	int (*_writeN)(struct intf_hdl *pintfhdl, u32 addr, u32 length, u8 *pdata);$/;"	m	struct:_io_ops
-_write_mem	include/rtw_io.h	/^	void (*_write_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);$/;"	m	struct:_io_ops
-_write_port	include/rtw_io.h	/^	u32(*_write_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);$/;"	m	struct:_io_ops
-_write_port_cancel	include/rtw_io.h	/^	void (*_write_port_cancel)(struct intf_hdl *pintfhdl);$/;"	m	struct:_io_ops
-_write_rfreg	core/rtw_mp.c	/^void _write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask, u32 val)$/;"	f
-_write_scsi	include/rtw_io.h	/^	u32(*_write_scsi)(struct intf_hdl *pintfhdl, u32 cnt, u8 *pmem);$/;"	m	struct:_io_ops
-a1fit	include/rtl8188e_recv.h	/^	u32 a1fit:4;$/;"	m	struct:rxreport_8188e
-a2dp_bit_pool	hal/btc/HalBtc8703b1Ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8703b_1ant
-a2dp_bit_pool	hal/btc/HalBtc8723b1Ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8723b_1ant
-a2dp_bit_pool	hal/btc/HalBtc8723b2Ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8723b_2ant
-a2dp_bit_pool	hal/btc/HalBtc8822b1Ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8822b_1ant
-a2dp_bit_pool	hal/btc/halbtc8723d1ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8723d_1ant
-a2dp_bit_pool	hal/btc/halbtc8723d2ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8723d_2ant
-a2dp_bit_pool	hal/btc/halbtc8821c1ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8821c_1ant
-a2dp_bit_pool	hal/btc/halbtc8821c2ant.h	/^	u8					a2dp_bit_pool;$/;"	m	struct:coex_sta_8821c_2ant
-a2dp_exist	hal/btc/HalBtc8192e1Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8192e_1ant
-a2dp_exist	hal/btc/HalBtc8192e2Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8192e_2ant
-a2dp_exist	hal/btc/HalBtc8703b1Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8703b_1ant
-a2dp_exist	hal/btc/HalBtc8723b1Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8723b_1ant
-a2dp_exist	hal/btc/HalBtc8723b2Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8723b_2ant
-a2dp_exist	hal/btc/HalBtc8812a1Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8812a_1ant
-a2dp_exist	hal/btc/HalBtc8812a2Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8812a_2ant
-a2dp_exist	hal/btc/HalBtc8821a1Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8821a_1ant
-a2dp_exist	hal/btc/HalBtc8821a2Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8821a_2ant
-a2dp_exist	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8821a_csr_2ant
-a2dp_exist	hal/btc/HalBtc8822b1Ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8822b_1ant
-a2dp_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					a2dp_exist;$/;"	m	struct:btc_bt_link_info
-a2dp_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					a2dp_exist;$/;"	m	struct:btc_stack_info
-a2dp_exist	hal/btc/halbtc8723d1ant.h	/^	boolean				a2dp_exist;$/;"	m	struct:coex_sta_8723d_1ant
-a2dp_exist	hal/btc/halbtc8723d2ant.h	/^	boolean				a2dp_exist;$/;"	m	struct:coex_sta_8723d_2ant
-a2dp_exist	hal/btc/halbtc8821c1ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8821c_1ant
-a2dp_exist	hal/btc/halbtc8821c2ant.h	/^	boolean					a2dp_exist;$/;"	m	struct:coex_sta_8821c_2ant
-a2dp_only	hal/btc/HalBtcOutSrc.h	/^	boolean					a2dp_only;$/;"	m	struct:btc_bt_link_info
-a2fit	include/rtl8188e_recv.h	/^	u32 a2fit:4;$/;"	m	struct:rxreport_8188e
-aagc_step_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte		aagc_step_a: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-aagc_step_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte		aagc_step_b: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-aagc_step_c	hal/phydm/phydm_hwconfig.h	/^	u1Byte		aagc_step_c: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-aagc_step_d	hal/phydm/phydm_hwconfig.h	/^	u1Byte		aagc_step_d: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-ac	hal/rtl8723d/rtl8723d_hal_init.c	/^	u32 ac:2;$/;"	m	struct:qinfo_8723d	file:
-ac	include/ieee80211_ext.h	/^	struct wme_ac_parameter ac[4];$/;"	m	struct:wme_parameter_element	typeref:struct:wme_parameter_element::wme_ac_parameter
-acInfo	include/ieee80211_ext.h	/^	u8 acInfo;$/;"	m	struct:wme_parameter_element
-ac_param	include/wifi.h	/^	struct AC_param	ac_param[4];$/;"	m	struct:WMM_para_element	typeref:struct:WMM_para_element::AC_param
-ac_tag	include/rtw_mp.h	/^	sint ac_tag[8];$/;"	m	struct:mp_xmit_frame
-ac_tag	include/rtw_xmit.h	/^	sint	ac_tag;$/;"	m	struct:hw_txqueue
-accnt	include/rtw_xmit.h	/^	int	accnt;$/;"	m	struct:hw_xmit
-aci	include/ieee80211_ext.h	/^	     aci:2,$/;"	m	struct:wme_ac_parameter
-ack_policy	include/drv_types.h	/^	u8	ack_policy;$/;"	m	struct:registry_priv
-ack_policy	include/rtw_recv.h	/^	u8	ack_policy;$/;"	m	struct:rx_pkt_attrib
-ack_policy	include/rtw_xmit.h	/^	u8	ack_policy;$/;"	m	struct:pkt_attrib
-ack_report	include/rtw_xmit.h	/^	u8 ack_report;$/;"	m	struct:xmit_frame
-ack_tx	include/rtw_xmit.h	/^	int	ack_tx;$/;"	m	struct:xmit_priv
-ack_tx_mutex	include/rtw_xmit.h	/^	_mutex ack_tx_mutex;$/;"	m	struct:xmit_priv
-ack_tx_ops	include/rtw_xmit.h	/^	struct submit_ctx ack_tx_ops;$/;"	m	struct:xmit_priv	typeref:struct:xmit_priv::submit_ctx
-aclLink	include/rtw_btcoex.h	/^	HCI_LINK_INFO				aclLink[MAX_BT_ACL_LINK_NUM];$/;"	m	struct:_HCI_EXT_CONFIG
-acl_busy	hal/btc/HalBtc8703b1Ant.h	/^	boolean				acl_busy;$/;"	m	struct:coex_sta_8703b_1ant
-acl_busy	hal/btc/HalBtc8812a2Ant.h	/^	boolean					acl_busy;$/;"	m	struct:coex_sta_8812a_2ant
-acl_busy	hal/btc/HalBtc8822b1Ant.h	/^	boolean				acl_busy;$/;"	m	struct:coex_sta_8822b_1ant
-acl_busy	hal/btc/HalBtcOutSrc.h	/^	boolean					acl_busy;$/;"	m	struct:btc_bt_link_info
-acl_busy	hal/btc/halbtc8723d1ant.h	/^	boolean				acl_busy;$/;"	m	struct:coex_sta_8723d_1ant
-acl_busy	hal/btc/halbtc8723d2ant.h	/^	boolean				acl_busy;$/;"	m	struct:coex_sta_8723d_2ant
-acl_busy	hal/btc/halbtc8821c1ant.h	/^	boolean				acl_busy;$/;"	m	struct:coex_sta_8821c_1ant
-acl_busy	hal/btc/halbtc8821c2ant.h	/^	boolean				acl_busy;$/;"	m	struct:coex_sta_8821c_2ant
-acl_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					acl_exist;$/;"	m	struct:btc_stack_info
-acl_list	include/sta_info.h	/^	struct wlan_acl_pool acl_list;$/;"	m	struct:sta_priv	typeref:struct:sta_priv::wlan_acl_pool
-acl_mode_str	include/sta_info.h	38;"	d
-acl_node_q	include/sta_info.h	/^	_queue	acl_node_q;$/;"	m	struct:wlan_acl_pool
-aclnode	include/sta_info.h	/^	struct rtw_wlan_acl_node aclnode[NUM_ACL];$/;"	m	struct:wlan_acl_pool	typeref:struct:wlan_acl_pool::rtw_wlan_acl_node
-acm	include/ieee80211_ext.h	/^	     acm:1,$/;"	m	struct:wme_ac_parameter
-acm_mask	include/rtw_mlme.h	/^	u8	acm_mask; \/* for wmm acm mask *\/$/;"	m	struct:mlme_priv
-acm_method	include/drv_types.h	/^	u8	acm_method;$/;"	m	struct:registry_priv
-acs	include/hal_data.h	/^	struct auto_chan_sel acs;$/;"	m	struct:hal_com_data	typeref:struct:hal_com_data::auto_chan_sel
-acs_auto_scan	include/drv_types.h	/^	u8 acs_auto_scan;$/;"	m	struct:registry_priv
-acs_mode	include/drv_types.h	/^	u8 acs_mode;$/;"	m	struct:registry_priv
-act_type	include/rtw_mp.h	/^	u32 act_type;$/;"	m	struct:mp_wiparam
-action	include/ieee80211_ext.h	/^		}  __attribute__((packed)) action;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon18
-action	include/ieee80211_ext.h	/^		}  action;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon33
-action	include/rtw_cmd.h	/^	u32 action;\/* 1: sleep, 0:resume *\/$/;"	m	struct:usb_suspend_parm
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon35
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon36
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon37
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon38
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon39
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon40
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon20
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon21
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon22
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon23
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon24
-action_code	include/ieee80211_ext.h	/^					u8 action_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon25
-action_code	include/rtw_mlme.h	/^	u8 action_code;$/;"	m	struct:tdls_txmgmt
-action_handler	include/rtw_mlme_ext.h	/^struct action_handler {$/;"	s
-action_public_dialog_token	include/rtw_mlme_ext.h	/^	u8 action_public_dialog_token;$/;"	m	struct:mlme_ext_priv
-action_public_rxseq	include/rtw_mlme_ext.h	/^	u16	 action_public_rxseq;$/;"	m	struct:mlme_ext_priv
-action_public_str	core/rtw_ieee80211.c	/^const char *action_public_str(u8 action)$/;"	f
-active	include/rtw_pwrctrl.h	/^	u8	active;				\/* set 1 means active scan, or pasivite scan. *\/$/;"	m	struct:pno_scan_channel_info
-active	os_dep/linux/ioctl_cfg80211.h	/^	u8 active;$/;"	m	struct:rtw_wdev_invit_info
-active	os_dep/linux/ioctl_cfg80211.h	/^	u8 active;$/;"	m	struct:rtw_wdev_nego_info
-active_keep_alive_check	include/rtw_mlme_ext.h	/^	u8 active_keep_alive_check;$/;"	m	struct:mlme_ext_priv
-active_key	include/ieee80211.h	/^	u16 active_key:2,$/;"	m	struct:ieee80211_security
-active_path	include/drv_types.h	/^	WCHAR			active_path[MAX_ACTIVE_REG_PATH];	\/* adapter regpath *\/$/;"	m	struct:dvobj_priv
-active_path	include/drv_types_sdio.h	/^	WCHAR						active_path[MAX_ACTIVE_REG_PATH];$/;"	m	struct:sdio_data
-adapter	include/rtw_recv.h	/^	PADAPTER adapter;$/;"	m	struct:recv_buf
-adapter	include/rtw_recv.h	/^	_adapter	*adapter;$/;"	m	struct:recv_priv
-adapter	include/rtw_recv.h	/^	_adapter  *adapter;$/;"	m	struct:recv_frame_hdr
-adapter	include/rtw_xmit.h	/^	_adapter	*adapter;$/;"	m	struct:xmit_priv
-adapter	os_dep/linux/ioctl_cfg80211.h	/^	_adapter *adapter;$/;"	m	struct:rtw_wiphy_data
-adapter_context	include/rtw_ioctl.h	/^	void		*adapter_context;$/;"	m	struct:oid_par_priv
-adapter_mac_addr	include/drv_types.h	1469;"	d
-adapter_proc_hdls	os_dep/linux/rtw_proc.c	/^const struct rtw_proc_hdl adapter_proc_hdls[] = {$/;"	v	typeref:struct:rtw_proc_hdl
-adapter_proc_hdls_num	os_dep/linux/rtw_proc.c	/^const int adapter_proc_hdls_num = sizeof(adapter_proc_hdls) \/ sizeof(struct rtw_proc_hdl);$/;"	v
-adapter_to_dvobj	include/drv_types.h	1457;"	d
-adapter_to_halmac	hal/hal_halmac.h	32;"	d
-adapter_to_pwrctl	include/drv_types.h	1459;"	d
-adapter_to_regsty	include/drv_types.h	1458;"	d
-adapter_to_rfctl	include/drv_types.h	1467;"	d
-adapter_to_wiphy	include/drv_types.h	1462;"	d
-adapter_to_wiphy	include/drv_types.h	1464;"	d
-adapter_type	include/drv_types.h	/^	u8 adapter_type;\/*be used in  Multi-interface to recognize whether is PRIMARY_ADAPTER  or not(PRIMARY_ADAPTER\/VIRTUAL_ADAPTER) .*\/$/;"	m	struct:_ADAPTER
-adapter_wdev_data	include/drv_types.h	1460;"	d
-adaptive_early_32k	core/rtw_wlan_util.c	/^void adaptive_early_32k(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)$/;"	f
-adaptive_tsf_done	include/rtw_mlme_ext.h	/^	u8 adaptive_tsf_done;$/;"	m	struct:mlme_ext_priv
-adaptivity_dc_backoff	include/drv_types.h	/^	u8 adaptivity_dc_backoff;$/;"	m	struct:registry_priv
-adaptivity_dml	include/drv_types.h	/^	u8 adaptivity_dml;$/;"	m	struct:registry_priv
-adaptivity_en	include/drv_types.h	/^	u8 adaptivity_en;$/;"	m	struct:registry_priv
-adaptivity_flag	hal/phydm/phydm.h	/^	BOOLEAN			adaptivity_flag;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-adaptivity_mode	include/drv_types.h	/^	u8 adaptivity_mode;$/;"	m	struct:registry_priv
-adaptivity_th_edcca_hl_diff	include/drv_types.h	/^	s8 adaptivity_th_edcca_hl_diff;$/;"	m	struct:registry_priv
-adaptivity_th_l2h_ini	include/drv_types.h	/^	s8 adaptivity_th_l2h_ini;$/;"	m	struct:registry_priv
-adaptor_info_caching_file_path	include/drv_types.h	/^	char	adaptor_info_caching_file_path[PATH_LENGTH_MAX];$/;"	m	struct:registry_priv
-adcsmp	hal/phydm/phydm.h	/^	RT_ADCSMP					adcsmp;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-addBaReq_parm	include/rtw_cmd.h	/^struct addBaReq_parm {$/;"	s
-addBaRsp_parm	include/rtw_cmd.h	/^struct addBaRsp_parm {$/;"	s
-addPPPoETag	include/rtw_br_ext.h	/^	int		addPPPoETag;		\/* 1: Add PPPoE relay-SID, 0: disable *\/$/;"	m	struct:br_ext_info
-add_RATid	core/rtw_ap.c	/^void add_RATid(_adapter *padapter, struct sta_info *psta, u8 rssi_level)$/;"	f
-add_ba_hdl	core/rtw_mlme_ext.c	/^u8 add_ba_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-add_ba_rsp_hdl	core/rtw_mlme_ext.c	/^u8 add_ba_rsp_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-add_sta	include/ieee80211.h	/^		} add_sta;$/;"	m	union:ieee_param::__anon73	typeref:struct:ieee_param::__anon73::__anon78
-addba_event	include/rtw_event.h	/^struct addba_event {$/;"	s
-addba_req	include/ieee80211_ext.h	/^				}  __attribute__((packed)) addba_req;$/;"	m	union:ieee80211_mgmt::__anon8::__anon18::__anon19	typeref:struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon21
-addba_req	include/ieee80211_ext.h	/^				}  addba_req;$/;"	m	union:ieee80211_mgmt::__anon26::__anon33::__anon34	typeref:struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon36
-addba_resp	include/ieee80211_ext.h	/^				}  __attribute__((packed)) addba_resp;$/;"	m	union:ieee80211_mgmt::__anon8::__anon18::__anon19	typeref:struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon22
-addba_resp	include/ieee80211_ext.h	/^				}  addba_resp;$/;"	m	union:ieee80211_mgmt::__anon26::__anon33::__anon34	typeref:struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon37
-addba_retry_timer	include/sta_info.h	/^	_timer addba_retry_timer;$/;"	m	struct:sta_info
-addba_timer_hdl	core/rtw_mlme_ext.c	/^void addba_timer_hdl(struct sta_info *psta)$/;"	f
-addr	include/rtw_cmd.h	/^	u32	addr;$/;"	m	struct:readMAC_parm
-addr	include/rtw_cmd.h	/^	u8	addr[ETH_ALEN];$/;"	m	struct:addBaReq_parm
-addr	include/rtw_cmd.h	/^	u8	addr[ETH_ALEN];$/;"	m	struct:del_assocsta_parm
-addr	include/rtw_cmd.h	/^	u8	addr[ETH_ALEN];$/;"	m	struct:set_assocsta_parm
-addr	include/rtw_cmd.h	/^	u8	addr[ETH_ALEN];$/;"	m	struct:set_stakey_parm
-addr	include/rtw_cmd.h	/^	u8	addr[ETH_ALEN];$/;"	m	struct:set_stakey_rsp
-addr	include/rtw_cmd.h	/^	u8 addr[ETH_ALEN];$/;"	m	struct:TDLSoption_param
-addr	include/rtw_cmd.h	/^	u8 addr[ETH_ALEN];$/;"	m	struct:addBaRsp_parm
-addr	include/rtw_io.h	/^	u32	addr;$/;"	m	struct:io_req
-addr	include/rtw_iol.h	/^	u16 addr;$/;"	m	struct:cmd_cmp
-addr	include/rtw_mlme.h	/^	u8	addr[ETH_ALEN];$/;"	m	struct:tdls_ch_switch
-addr	include/sta_info.h	/^	u8       addr[ETH_ALEN];$/;"	m	struct:rtw_wlan_acl_node
-addr1	include/ieee80211.h	/^	u8 addr1[6];$/;"	m	struct:ieee80211_header_data
-addr1	include/ieee80211.h	/^	u8 addr1[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr
-addr1	include/ieee80211.h	/^	u8 addr1[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_3addr
-addr1	include/ieee80211.h	/^	u8 addr1[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos
-addr1	include/ieee80211.h	/^	u8 addr1[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_qos
-addr2	include/ieee80211.h	/^	u8 addr2[6];$/;"	m	struct:ieee80211_header_data
-addr2	include/ieee80211.h	/^	u8 addr2[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr
-addr2	include/ieee80211.h	/^	u8 addr2[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_3addr
-addr2	include/ieee80211.h	/^	u8 addr2[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos
-addr2	include/ieee80211.h	/^	u8 addr2[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_qos
-addr3	include/ieee80211.h	/^	u8 addr3[6];$/;"	m	struct:ieee80211_header_data
-addr3	include/ieee80211.h	/^	u8 addr3[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr
-addr3	include/ieee80211.h	/^	u8 addr3[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_3addr
-addr3	include/ieee80211.h	/^	u8 addr3[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos
-addr3	include/ieee80211.h	/^	u8 addr3[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_qos
-addr4	include/ieee80211.h	/^	u8 addr4[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr
-addr4	include/ieee80211.h	/^	u8 addr4[ETH_ALEN];$/;"	m	struct:rtw_ieee80211_hdr_qos
-address	include/rtw_iol.h	/^	u16	address;$/;"	m	struct:ioreg_cfg
-address	include/rtw_iol.h	/^	u16 address;$/;"	m	struct:_io_offload_cmd
-adhoc	include/rtw_cmd.h	/^	bool adhoc;$/;"	m	struct:createbss_parm
-adhoc_expire_to	include/sta_info.h	/^	u32 adhoc_expire_to;$/;"	m	struct:sta_priv
-adhoc_num	include/rtw_mi.h	/^	u8 adhoc_num;		\/* WIFI_FW_ADHOC_STATE *\/$/;"	m	struct:mi_state
-adhoc_tx_pwr	include/drv_types.h	/^	u8	adhoc_tx_pwr;$/;"	m	struct:registry_priv
-adjuseVoltageVal	include/hal_data.h	/^	u8	adjuseVoltageVal;$/;"	m	struct:hal_com_data
-aes128k128d	core/rtw_security.c	/^static void aes128k128d(u8 *key, u8 *data, u8 *ciphertext)$/;"	f	file:
-aes_128_encrypt	core/rtw_security.c	/^static void aes_128_encrypt(void *ctx, u8 *plain, u8 *crypt)$/;"	f	file:
-aes_cipher	core/rtw_security.c	/^static sint aes_cipher(u8 *key, uint	hdrlen,$/;"	f	file:
-aes_decipher	core/rtw_security.c	/^static sint aes_decipher(u8 *key, uint	hdrlen,$/;"	f	file:
-aes_encrypt_deinit	core/rtw_security.c	/^static void aes_encrypt_deinit(void *ctx)$/;"	f	file:
-aes_encrypt_init	core/rtw_security.c	/^static void *aes_encrypt_init(u8 *key, size_t len)$/;"	f	file:
-aes_sw_dec_cnt_bc	include/rtw_security.h	/^	u64 aes_sw_dec_cnt_bc;$/;"	m	struct:security_priv
-aes_sw_dec_cnt_mc	include/rtw_security.h	/^	u64 aes_sw_dec_cnt_mc;$/;"	m	struct:security_priv
-aes_sw_dec_cnt_uc	include/rtw_security.h	/^	u64 aes_sw_dec_cnt_uc;$/;"	m	struct:security_priv
-aes_sw_enc_cnt_bc	include/rtw_security.h	/^	u64 aes_sw_enc_cnt_bc;$/;"	m	struct:security_priv
-aes_sw_enc_cnt_mc	include/rtw_security.h	/^	u64 aes_sw_enc_cnt_mc;$/;"	m	struct:security_priv
-aes_sw_enc_cnt_uc	include/rtw_security.h	/^	u64 aes_sw_enc_cnt_uc;$/;"	m	struct:security_priv
-agcTableIdx	hal/phydm/phydm_dig.h	/^	u1Byte		agcTableIdx;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-agc_table	hal/phydm/phydm_hwconfig.h	/^	u1Byte		agc_table: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-agc_table_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte		agc_table_a: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-agc_table_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte		agc_table_b: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-agc_table_c	hal/phydm/phydm_hwconfig.h	/^	u1Byte		agc_table_c: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-agc_table_d	hal/phydm/phydm_hwconfig.h	/^	u1Byte		agc_table_d: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-agcctrl	include/rtw_cmd.h	/^	u32	agcctrl;		\/* 0: pure hw, 1: fw *\/$/;"	m	struct:setagcctrl_parm
-ageing_timer	include/rtw_br_ext.h	/^	unsigned long					ageing_timer;$/;"	m	struct:nat25_network_db_entry
-agg_buf_size	hal/btc/HalBtcOutSrc.h	/^	u8					agg_buf_size;$/;"	m	struct:btc_bt_info
-agg_en	include/rtl8188e_xmit.h	/^	u32 agg_en:1;$/;"	m	struct:txdesc_88e
-agg_en	include/rtl8192e_xmit.h	/^	u32 agg_en:1;$/;"	m	struct:txdescriptor_8192e
-agg_en	include/rtl8812a_xmit.h	/^	u32 agg_en:1;$/;"	m	struct:txdescriptor_8812
-agg_en	include/rtl8821a_xmit.h	/^	u32 agg_en:1;$/;"	m	struct:txdescriptor_8821a
-agg_enable_bitmap	include/rtw_ht.h	/^	u8	agg_enable_bitmap;$/;"	m	struct:ht_priv
-agg_enable_bitmap	include/rtw_mlme_ext.h	/^	u8	agg_enable_bitmap;$/;"	m	struct:mlme_ext_info
-agg_num	include/rtw_xmit.h	/^	u8	agg_num;$/;"	m	struct:xmit_buf
-agg_num	include/rtw_xmit.h	/^	u8	agg_num;$/;"	m	struct:xmit_frame
-agg_pkt	include/rtw_xmit.h	/^	struct agg_pkt_info agg_pkt[MAX_AGG_PKT_NUM];$/;"	m	struct:xmit_priv	typeref:struct:xmit_priv::agg_pkt_info
-agg_pkt_info	include/rtw_xmit.h	/^struct agg_pkt_info {$/;"	s
-aid	include/ieee80211.h	/^			u16 aid;$/;"	m	struct:ieee_param::__anon73::__anon78
-aid	include/ieee80211.h	/^	u16 aid;$/;"	m	struct:ieee80211_assoc_response_frame
-aid	include/ieee80211.h	/^	u16 aid;$/;"	m	struct:sta_data
-aid	include/ieee80211_ext.h	/^			u16 aid;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon30
-aid	include/ieee80211_ext.h	/^			u16 aid;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon12
-aid	include/rtw_beamforming.h	/^	u16	aid:12;$/;"	m	struct:rtw_ndpa_sta_info
-aid	include/rtw_beamforming.h	/^	u16	aid;			\/* Used to construct AID field of NDPA packet. *\/$/;"	m	struct:beamforming_entry
-aid	include/rtw_beamforming.h	/^	u16 aid;$/;"	m	struct:beamformee_entry
-aid	include/rtw_beamforming.h	/^	u16 aid;$/;"	m	struct:beamformer_entry
-aid	include/rtw_mlme_ext.h	/^	u16	aid;$/;"	m	struct:mlme_ext_info
-aid	include/sta_info.h	/^	uint aid;$/;"	m	struct:sta_info
-aid	include/wlan_bssdef.h	/^	int	aid;			\/* will only be valid when a BSS is joinned. *\/$/;"	m	struct:wlan_network
-aifsn	include/ieee80211_ext.h	/^	u8	aifsn:4,$/;"	m	struct:wme_ac_parameter
-airgocapAP	include/rtw_mlme_ext.h	/^	airgocapAP	= 6,$/;"	e	enum:Associated_AP
-alg	include/ieee80211.h	/^			u8 alg[IEEE_CRYPT_ALG_NAME_LEN];$/;"	m	struct:ieee_param::__anon73::__anon77
-algorithm	include/ieee80211.h	/^	u16 algorithm;$/;"	m	struct:ieee80211_authentication
-algorithm	include/rtw_cmd.h	/^	u8	algorithm;	\/* encryption algorithm, could be none, wep40, TKIP, CCMP, wep104 *\/$/;"	m	struct:setkey_parm
-algorithm	include/rtw_cmd.h	/^	u8	algorithm;$/;"	m	struct:set_stakey_parm
-alive_count	include/sta_info.h	/^	u8 alive_count;$/;"	m	struct:sta_info
-alives	include/rtw_pwrctrl.h	/^	u32	alives;$/;"	m	struct:pwrctrl_priv
-all	include/drv_types.h	/^	u32 all;$/;"	m	struct:int_logs
-allCountries	os_dep/linux/wifi_regd.c	/^static struct country_code_to_enum_rd allCountries[] = {$/;"	v	typeref:struct:country_code_to_enum_rd	file:
-alloc	os_dep/osdep_service.c	/^	ATOMIC_T alloc; \/* the memory bytes we allocate currently *\/$/;"	m	struct:rtw_mem_stat	file:
-alloc_addr	include/rtw_xmit.h	/^	u8 *alloc_addr; \/* the actual address this xmitframe allocated *\/$/;"	m	struct:xmit_frame
-alloc_cnt	os_dep/osdep_service.c	/^	ATOMIC_T alloc_cnt; \/* the alloc count for alloc currently *\/$/;"	m	struct:rtw_mem_stat	file:
-alloc_err_cnt	os_dep/osdep_service.c	/^	ATOMIC_T alloc_err_cnt; \/* the error times we fail to allocate memory *\/$/;"	m	struct:rtw_mem_stat	file:
-alloc_mgtxmitframe	core/rtw_mlme_ext.c	/^inline struct xmit_frame *alloc_mgtxmitframe(struct xmit_priv *pxmitpriv)$/;"	f
-alloc_mgtxmitframe_once	core/rtw_mlme_ext.c	/^inline struct xmit_frame *alloc_mgtxmitframe_once(struct xmit_priv *pxmitpriv)$/;"	f
-alloc_mp_xmitframe	core/rtw_mp.c	/^static struct xmit_frame *alloc_mp_xmitframe(struct xmit_priv *pxmitpriv)$/;"	f	file:
-alloc_sz	include/rtw_recv.h	/^	u32 alloc_sz;$/;"	m	struct:recv_buf
-alloc_sz	include/rtw_xmit.h	/^	u32 alloc_sz;$/;"	m	struct:xmit_buf
-allocated_c2h_mem	include/rtw_cmd.h	/^	u8	*allocated_c2h_mem;$/;"	m	struct:evt_priv
-allocated_io_rwmem	include/osdep_intf.h	/^	volatile u8 *allocated_io_rwmem;$/;"	m	struct:intf_priv
-allrxreturnevt	include/rtw_recv.h	/^	_sema allrxreturnevt;$/;"	m	struct:recv_priv
-alpha2	include/drv_types.h	/^	char alpha2[2];$/;"	m	struct:registry_priv
-alpha2	include/rtw_rf.h	/^	char alpha2[2];$/;"	m	struct:country_chplan
-alpha2	include/wifi.h	/^	char alpha2[2];$/;"	m	struct:rtw_regulatory
-alpha_to_upper	os_dep/osdep_service.c	/^inline char alpha_to_upper(char c)$/;"	f
-amd_l1_patch	include/drv_types_pci.h	/^	u8	amd_l1_patch;$/;"	m	struct:pci_priv
-ampdu_amsdu	include/drv_types.h	/^	u8	ampdu_amsdu;\/* A-MPDU Supports A-MSDU is permitted *\/$/;"	m	struct:registry_priv
-ampdu_density	include/rtl8188e_xmit.h	/^	u32 ampdu_density:3;$/;"	m	struct:txdesc_88e
-ampdu_density	include/rtl8192e_xmit.h	/^	u32 ampdu_density:3;$/;"	m	struct:txdescriptor_8192e
-ampdu_density	include/rtl8812a_xmit.h	/^	u32 ampdu_density:3;$/;"	m	struct:txdescriptor_8812
-ampdu_density	include/rtl8821a_xmit.h	/^	u32 ampdu_density:3;$/;"	m	struct:txdescriptor_8821a
-ampdu_en	include/rtw_xmit.h	/^	u8	ampdu_en;\/* tx ampdu enable *\/$/;"	m	struct:pkt_attrib
-ampdu_enable	include/drv_types.h	/^	u8	ampdu_enable;\/* for tx *\/$/;"	m	struct:registry_priv
-ampdu_enable	include/rtw_ht.h	/^	u8	ampdu_enable;\/* for enable Tx A-MPDU *\/$/;"	m	struct:ht_priv
-ampdu_factor	include/drv_types.h	/^	u8	ampdu_factor;$/;"	m	struct:registry_priv
-ampdu_len	include/rtw_vht.h	/^	u8	ampdu_len;$/;"	m	struct:vht_priv
-ampdu_max_time	include/rtl8821a_xmit.h	/^	u32 ampdu_max_time:8;$/;"	m	struct:txdescriptor_8821a
-ampdu_params_info	include/wifi.h	/^	unsigned char	ampdu_params_info;$/;"	m	struct:rtw_ieee80211_ht_cap
-ampdu_size	include/rtw_recv.h	/^	u8 ampdu_size;$/;"	m	struct:recv_reorder_ctrl
-ampdu_spacing	include/rtw_xmit.h	/^	u8	ampdu_spacing; \/* ampdu_min_spacing for peer sta's rx *\/$/;"	m	struct:pkt_attrib
-amsdu	include/rtl8188e_recv.h	/^	u32 amsdu:1;$/;"	m	struct:rxreport_8188e
-amsdu	include/rtw_recv.h	/^	u8	amsdu;$/;"	m	struct:rx_pkt_attrib
-amsdu_to_msdu	core/rtw_recv.c	/^int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)$/;"	f
-anchored	include/rtw_mlme.h	/^	struct usb_anchor anchored;$/;"	m	struct:hostapd_priv	typeref:struct:hostapd_priv::usb_anchor
-andr_wifi_feature_set_attr	os_dep/linux/rtw_cfgvendor.h	/^enum andr_wifi_feature_set_attr {$/;"	g
-android_wifi_cmd_str	os_dep/linux/rtw_android.c	/^const char *android_wifi_cmd_str[ANDROID_WIFI_CMD_MAX] = {$/;"	v
-android_wifi_priv_cmd	os_dep/linux/rtw_android.c	/^typedef struct android_wifi_priv_cmd {$/;"	s	file:
-android_wifi_priv_cmd	os_dep/linux/rtw_android.c	/^} android_wifi_priv_cmd;$/;"	t	typeref:struct:android_wifi_priv_cmd	file:
-antAveRSSI	hal/phydm/phydm_antdiv.h	/^	u4Byte	antAveRSSI[7];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antRSSIcnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	antRSSIcnt[7];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antSumRSSI	hal/phydm/phydm_antdiv.h	/^	u4Byte	antSumRSSI[7];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-ant_candidate_1	hal/phydm/phydm_pathdiv.h	/^	u1Byte	ant_candidate_1;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-ant_candidate_2	hal/phydm/phydm_pathdiv.h	/^	u1Byte	ant_candidate_2;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-ant_candidate_3	hal/phydm/phydm_pathdiv.h	/^	u1Byte	ant_candidate_3;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-ant_det_bt_le_channel	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_bt_le_channel;  \/* BT LE Channel ex:2412 *\/$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_bt_le_channel	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_bt_le_channel;  \/* BT LE Channel ex:2412 *\/$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_bt_le_channel	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_bt_le_channel;  \/* BT LE Channel ex:2412 *\/$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_bt_le_channel	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_bt_le_channel;  \/* BT LE Channel ex:2412 *\/$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_bt_le_channel	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_bt_le_channel;  \/* BT LE Channel ex:2412 *\/$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_bt_le_channel	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_bt_le_channel;  \/* BT LE Channel ex:2412 *\/$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_bt_le_channel	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_bt_le_channel;  \/* BT LE Channel ex:2412 *\/$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_bt_tx_time	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_bt_tx_time;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_bt_tx_time	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_bt_tx_time;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_bt_tx_time	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_bt_tx_time;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_bt_tx_time	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_bt_tx_time;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_bt_tx_time	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_bt_tx_time;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_bt_tx_time	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_bt_tx_time;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_bt_tx_time	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_bt_tx_time;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_fail_count	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_fail_count;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_fail_count	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_fail_count;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_fail_count	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_fail_count;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_fail_count	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_fail_count;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_fail_count	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_fail_count;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_fail_count	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_fail_count;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_fail_count	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_fail_count;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_inteval_count	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_inteval_count;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_inteval_count	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_inteval_count;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_inteval_count	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_inteval_count;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_inteval_count	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_inteval_count;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_inteval_count	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_inteval_count;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_inteval_count	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_inteval_count;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_inteval_count	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_inteval_count;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_is_ant_det_available	hal/btc/HalBtc8703b1Ant.h	/^	boolean			ant_det_is_ant_det_available;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_is_ant_det_available	hal/btc/HalBtc8723b1Ant.h	/^	boolean			ant_det_is_ant_det_available;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_is_ant_det_available	hal/btc/HalBtc8822b1Ant.h	/^	boolean			ant_det_is_ant_det_available;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_is_ant_det_available	hal/btc/halbtc8723d1ant.h	/^	boolean			ant_det_is_ant_det_available;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_is_ant_det_available	hal/btc/halbtc8723d2ant.h	/^	boolean			ant_det_is_ant_det_available;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_is_ant_det_available	hal/btc/halbtc8821c1ant.h	/^	boolean			ant_det_is_ant_det_available;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_is_ant_det_available	hal/btc/halbtc8821c2ant.h	/^	boolean			ant_det_is_ant_det_available;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_is_btreply_available	hal/btc/HalBtc8703b1Ant.h	/^	boolean			ant_det_is_btreply_available;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_is_btreply_available	hal/btc/HalBtc8723b1Ant.h	/^	boolean			ant_det_is_btreply_available;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_is_btreply_available	hal/btc/HalBtc8822b1Ant.h	/^	boolean			ant_det_is_btreply_available;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_is_btreply_available	hal/btc/halbtc8723d1ant.h	/^	boolean			ant_det_is_btreply_available;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_is_btreply_available	hal/btc/halbtc8723d2ant.h	/^	boolean			ant_det_is_btreply_available;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_is_btreply_available	hal/btc/halbtc8821c1ant.h	/^	boolean			ant_det_is_btreply_available;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_is_btreply_available	hal/btc/halbtc8821c2ant.h	/^	boolean			ant_det_is_btreply_available;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_peak_freq	hal/btc/HalBtc8703b1Ant.h	/^	u8			ant_det_peak_freq[BT_8703B_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_peak_freq	hal/btc/HalBtc8723b1Ant.h	/^	u8			ant_det_peak_freq[BT_8723B_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_peak_freq	hal/btc/HalBtc8822b1Ant.h	/^	u8			ant_det_peak_freq[BT_8822B_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_peak_freq	hal/btc/halbtc8723d1ant.h	/^	u8			ant_det_peak_freq[BT_8723D_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_peak_freq	hal/btc/halbtc8723d2ant.h	/^	u8			ant_det_peak_freq[BT_8723D_2ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_peak_freq	hal/btc/halbtc8821c1ant.h	/^	u8			ant_det_peak_freq[BT_8821C_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_peak_freq	hal/btc/halbtc8821c2ant.h	/^	u8			ant_det_peak_freq[BT_8821C_2ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_peak_val	hal/btc/HalBtc8703b1Ant.h	/^	u8			ant_det_peak_val[BT_8703B_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_peak_val	hal/btc/HalBtc8723b1Ant.h	/^	u8			ant_det_peak_val[BT_8723B_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_peak_val	hal/btc/HalBtc8822b1Ant.h	/^	u8			ant_det_peak_val[BT_8822B_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_peak_val	hal/btc/halbtc8723d1ant.h	/^	u8			ant_det_peak_val[BT_8723D_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_peak_val	hal/btc/halbtc8723d2ant.h	/^	u8			ant_det_peak_val[BT_8723D_2ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_peak_val	hal/btc/halbtc8821c1ant.h	/^	u8			ant_det_peak_val[BT_8821C_1ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_peak_val	hal/btc/halbtc8821c2ant.h	/^	u8			ant_det_peak_val[BT_8821C_2ANT_ANTDET_BUF_LEN];$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_pre_psdscan_peak_val	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_pre_psdscan_peak_val;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_pre_psdscan_peak_val	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_pre_psdscan_peak_val;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_pre_psdscan_peak_val	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_pre_psdscan_peak_val;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_pre_psdscan_peak_val	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_pre_psdscan_peak_val;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_pre_psdscan_peak_val	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_pre_psdscan_peak_val;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_pre_psdscan_peak_val	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_pre_psdscan_peak_val;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_pre_psdscan_peak_val	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_pre_psdscan_peak_val;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_psd_scan_peak_freq	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_psd_scan_peak_freq;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_psd_scan_peak_freq	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_psd_scan_peak_freq;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_psd_scan_peak_freq	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_psd_scan_peak_freq;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_psd_scan_peak_freq	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_psd_scan_peak_freq;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_psd_scan_peak_freq	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_psd_scan_peak_freq;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_psd_scan_peak_freq	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_psd_scan_peak_freq;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_psd_scan_peak_freq	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_psd_scan_peak_freq;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_psd_scan_peak_val	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_psd_scan_peak_val;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_psd_scan_peak_val	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_psd_scan_peak_val;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_psd_scan_peak_val	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_psd_scan_peak_val;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_psd_scan_peak_val	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_psd_scan_peak_val;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_psd_scan_peak_val	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_psd_scan_peak_val;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_psd_scan_peak_val	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_psd_scan_peak_val;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_psd_scan_peak_val	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_psd_scan_peak_val;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_result	hal/btc/HalBtc8703b1Ant.h	/^	u8			ant_det_result;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_result	hal/btc/HalBtc8723b1Ant.h	/^	u8			ant_det_result;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_result	hal/btc/HalBtc8822b1Ant.h	/^	u8			ant_det_result;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_result	hal/btc/HalBtcOutSrc.h	/^	u8				ant_det_result;$/;"	m	struct:btc_board_info
-ant_det_result	hal/btc/halbtc8723d1ant.h	/^	u8			ant_det_result;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_result	hal/btc/halbtc8723d2ant.h	/^	u8			ant_det_result;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_result	hal/btc/halbtc8821c1ant.h	/^	u8			ant_det_result;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_result	hal/btc/halbtc8821c2ant.h	/^	u8			ant_det_result;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_result_five_complete	hal/btc/HalBtcOutSrc.h	/^	boolean			ant_det_result_five_complete;$/;"	m	struct:btc_board_info
-ant_det_thres_offset	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_thres_offset;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_thres_offset	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_thres_offset;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_thres_offset	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_thres_offset;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_thres_offset	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_thres_offset;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_thres_offset	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_thres_offset;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_thres_offset	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_thres_offset;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_thres_offset	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_thres_offset;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_det_try_count	hal/btc/HalBtc8703b1Ant.h	/^	u32			ant_det_try_count;$/;"	m	struct:psdscan_sta_8703b_1ant
-ant_det_try_count	hal/btc/HalBtc8723b1Ant.h	/^	u32			ant_det_try_count;$/;"	m	struct:psdscan_sta_8723b_1ant
-ant_det_try_count	hal/btc/HalBtc8822b1Ant.h	/^	u32			ant_det_try_count;$/;"	m	struct:psdscan_sta_8822b_1ant
-ant_det_try_count	hal/btc/halbtc8723d1ant.h	/^	u32			ant_det_try_count;$/;"	m	struct:psdscan_sta_8723d_1ant
-ant_det_try_count	hal/btc/halbtc8723d2ant.h	/^	u32			ant_det_try_count;$/;"	m	struct:psdscan_sta_8723d_2ant
-ant_det_try_count	hal/btc/halbtc8821c1ant.h	/^	u32			ant_det_try_count;$/;"	m	struct:psdscan_sta_8821c_1ant
-ant_det_try_count	hal/btc/halbtc8821c2ant.h	/^	u32			ant_det_try_count;$/;"	m	struct:psdscan_sta_8821c_2ant
-ant_div_cfg	hal/btc/HalBtcOutSrc.h	/^	u8				ant_div_cfg;$/;"	m	struct:btc_board_info
-ant_div_sw_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte			ant_div_sw_a: 1;							\/*8812A: ant_div_sw_a    8814A: 1'b0*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-ant_div_sw_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte			ant_div_sw_a: 1;$/;"	m	struct:_Phy_Status_Rpt_8812
-ant_div_sw_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte			ant_div_sw_b: 1;							\/*8812A: ant_div_sw_b    8814A: 1'b0*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-ant_div_sw_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte			ant_div_sw_b: 1;$/;"	m	struct:_Phy_Status_Rpt_8812
-ant_num	hal/phydm/phydm_antdiv.h	/^	u4Byte	ant_num; \/*number of used smart beam antenna*\/$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-ant_num	include/drv_types.h	/^	u8	ant_num;$/;"	m	struct:registry_priv
-ant_num_total	hal/phydm/phydm_antdiv.h	/^	u4Byte	ant_num_total;\/*number of total smart beam antenna*\/$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-ant_path	include/hal_data.h	/^	u8	ant_path; \/* for 8723B s0\/s1 selection	 *\/$/;"	m	struct:hal_com_data
-ant_sel	hal/phydm/phydm_hwconfig.h	/^	u1Byte	ant_sel: 1;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-ant_sel_a	include/rtl8188e_xmit.h	/^	u32 ant_sel_a:1;$/;"	m	struct:txdesc_88e
-ant_sel_a	include/rtl8192e_xmit.h	/^	u32 ant_sel_a:1;$/;"	m	struct:txdescriptor_8192e
-ant_sel_a	include/rtl8812a_xmit.h	/^	u32 ant_sel_a:1;$/;"	m	struct:txdescriptor_8812
-ant_sel_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte	ant_sel_b: 1;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-ant_sel_b	include/rtl8188e_xmit.h	/^	u32 ant_sel_b:1;$/;"	m	struct:txdesc_88e
-ant_sel_b	include/rtl8192e_xmit.h	/^	u32 ant_sel_b:1;$/;"	m	struct:txdescriptor_8192e
-ant_sel_b	include/rtl8812a_xmit.h	/^	u32 ant_sel_b:1;$/;"	m	struct:txdescriptor_8812
-ant_type	hal/btc/HalBtcOutSrc.h	/^	u8				ant_type;$/;"	m	struct:btc_board_info
-antdetval	hal/btc/HalBtcOutSrc.h	/^	u32				antdetval;$/;"	m	struct:btc_board_info
-antdiv_cfg	include/drv_types.h	/^	u8	antdiv_cfg;$/;"	m	struct:registry_priv
-antdiv_evm_en	hal/phydm/phydm.h	/^	u1Byte			antdiv_evm_en;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-antdiv_intvl	hal/phydm/phydm.h	/^	u1Byte			antdiv_intvl;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-antdiv_period	hal/phydm/phydm.h	/^	u1Byte			antdiv_period;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-antdiv_rssi	hal/phydm/phydm.h	/^	u1Byte			antdiv_rssi;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-antdiv_select	hal/phydm/phydm.h	/^	u1Byte			antdiv_select;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-antdiv_type	include/drv_types.h	/^	u8	antdiv_type;$/;"	m	struct:registry_priv
-antenna_rx	include/rtw_cmd.h	/^	u16 antenna_rx;$/;"	m	struct:SwitchAntenna_parm
-antenna_rx	include/rtw_mp.h	/^	u16 antenna_rx;$/;"	m	struct:mp_priv
-antenna_select_wk_hdl	core/rtw_cmd.c	/^void antenna_select_wk_hdl(_adapter *padapter, u8 antenna)$/;"	f
-antenna_selection_info	include/wifi.h	/^	unsigned char	       antenna_selection_info;$/;"	m	struct:rtw_ieee80211_ht_cap
-antenna_tx	include/rtw_cmd.h	/^	u16 antenna_tx;$/;"	m	struct:SwitchAntenna_parm
-antenna_tx	include/rtw_mp.h	/^	u16 antenna_tx;$/;"	m	struct:mp_priv
-antidx_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_a: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-antidx_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_a: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-antidx_anta	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_anta: 3;							\/*antidx_anta[2:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_anta	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_anta: 3;$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_antb	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_antb: 3;							\/*antidx_antb[2:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_antb	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_antb: 3;$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_antc	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_antc: 3;							\/*8812A: 3'b0		8814A: antidx_antc[2:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_antc	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_antc: 3;$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_antd	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_antd: 3;							\/*8812A: 3'b0		8814A: antidx_antd[2:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_antd	hal/phydm/phydm_hwconfig.h	/^	u1Byte			antidx_antd: 3;$/;"	m	struct:_Phy_Status_Rpt_8812
-antidx_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_b: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-antidx_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_b: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-antidx_c	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_c: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-antidx_c	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_c: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-antidx_d	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_d: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-antidx_d	hal/phydm/phydm_hwconfig.h	/^	u1Byte		antidx_d: 3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-antsel_A	include/rtl8821a_xmit.h	/^	u32 antsel_A:3;$/;"	m	struct:txdescriptor_8821a
-antsel_B	include/rtl8821a_xmit.h	/^	u32 antsel_B:3;$/;"	m	struct:txdescriptor_8821a
-antsel_C	include/rtl8821a_xmit.h	/^	u32 antsel_C:3;$/;"	m	struct:txdescriptor_8821a
-antsel_D	include/rtl8821a_xmit.h	/^	u32 antsel_D:3;$/;"	m	struct:txdescriptor_8821a
-antsel_a	hal/phydm/phydm_antdiv.h	/^	u1Byte	antsel_a[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antsel_b	hal/phydm/phydm_antdiv.h	/^	u1Byte	antsel_b[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antsel_c	hal/phydm/phydm_antdiv.h	/^	u1Byte	antsel_c[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antsel_rx_keep_0	hal/phydm/phydm_antdiv.h	/^	u1Byte	antsel_rx_keep_0;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antsel_rx_keep_1	hal/phydm/phydm_antdiv.h	/^	u1Byte	antsel_rx_keep_1;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antsel_rx_keep_2	hal/phydm/phydm_antdiv.h	/^	u1Byte	antsel_rx_keep_2;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-antsel_rx_keep_2	hal/phydm/phydm_hwconfig.h	/^	u1Byte	antsel_rx_keep_2: 1;	\/*ex_intf_flg:1;*\/$/;"	m	struct:_Phy_Status_Rpt_8192cd
-antsel_rx_keep_2	hal/phydm/phydm_hwconfig.h	/^	u1Byte	antsel_rx_keep_2: 1;\/*ex_intf_flg:1;*\/$/;"	m	struct:_Phy_Status_Rpt_8192cd
-antsel_rx_keep_3	hal/phydm/phydm_antdiv.h	/^	u1Byte	antsel_rx_keep_3;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-aoac_report	include/rtw_pwrctrl.h	/^struct aoac_report {$/;"	s
-ap2sta_data_frame	core/rtw_recv.c	/^sint ap2sta_data_frame($/;"	f
-ap_dcfe	include/rtl8188e_xmit.h	/^	u32 ap_dcfe:1;$/;"	m	struct:txdesc_88e
-ap_dcfe	include/rtl8192e_xmit.h	/^	u32 ap_dcfe:1;$/;"	m	struct:txdescriptor_8192e
-ap_dcfe	include/rtl8812a_xmit.h	/^	u32 ap_dcfe:1;$/;"	m	struct:txdescriptor_8812
-ap_free_sta	core/rtw_ap.c	/^u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reason, bool enqueue)$/;"	f
-ap_if_q	include/drv_types.h	/^	_queue	ap_if_q;$/;"	m	struct:dvobj_priv
-ap_num	include/rtw_mi.h	/^	u8 ap_num;			\/*WIFI_FW_AP_STATE|_FW_LINKED*\/$/;"	m	struct:mi_state
-ap_p2p_switch_timer	include/rtw_mlme.h	/^	_timer					ap_p2p_switch_timer;$/;"	m	struct:wifidirect_info
-ap_p2p_switch_timer_process	core/rtw_p2p.c	/^void ap_p2p_switch_timer_process(void *FunctionContext)$/;"	f
-ap_prohibited	include/rtw_mlme.h	/^	u8					ap_prohibited;$/;"	m	struct:tdls_info
-ap_sta_info_defer_update	core/rtw_ap.c	/^void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta)$/;"	f
-applyVmatrix	hal/phydm/phydm_beamforming.h	/^	BOOLEAN					applyVmatrix;$/;"	m	struct:_RT_BEAMFORMING_INFO
-apsd	include/rtw_xmit.h	/^	_list  apsd;$/;"	m	struct:sta_xmit_priv
-apsd_setting	include/rtw_xmit.h	/^	sint	apsd_setting;	\/* When bit mask is on, the associated edca queue supports APSD. *\/$/;"	m	struct:sta_xmit_priv
-arc4context	core/rtw_security.c	/^struct arc4context {$/;"	s	file:
-arcfour_byte	core/rtw_security.c	/^static u32 arcfour_byte(struct arc4context	*parc4ctx)$/;"	f	file:
-arcfour_encrypt	core/rtw_security.c	/^static void arcfour_encrypt(struct arc4context	*parc4ctx,$/;"	f	file:
-arcfour_init	core/rtw_security.c	/^static void arcfour_init(struct arc4context	*parc4ctx, u8 *key, u32	key_len)$/;"	f	file:
-arg	include/osdep_service_bsd.h	/^	 void *arg;$/;"	m	struct:timer_list
-arp_cnt	hal/btc/HalBtc8192e1Ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8192e_1ant
-arp_cnt	hal/btc/HalBtc8703b1Ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8703b_1ant
-arp_cnt	hal/btc/HalBtc8723b1Ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8723b_1ant
-arp_cnt	hal/btc/HalBtc8812a1Ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8812a_1ant
-arp_cnt	hal/btc/HalBtc8821a1Ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8821a_1ant
-arp_cnt	hal/btc/HalBtc8822b1Ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8822b_1ant
-arp_cnt	hal/btc/halbtc8723d1ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8723d_1ant
-arp_cnt	hal/btc/halbtc8723d2ant.h	/^	u32					arp_cnt;$/;"	m	struct:coex_dm_8723d_2ant
-arp_cnt	hal/btc/halbtc8821c1ant.h	/^	u32		arp_cnt;$/;"	m	struct:coex_dm_8821c_1ant
-arp_cnt	hal/btc/halbtc8821c2ant.h	/^	u32					arp_cnt;$/;"	m	struct:coex_dm_8821c_2ant
-arp_query	os_dep/linux/os_intfs.c	/^static int arp_query(unsigned char *haddr, u32 paddr,$/;"	f	file:
-array_length_mp_8723d_fw_ap	hal/rtl8723d/hal8723d_fw.c	/^u32 array_length_mp_8723d_fw_ap = 23862;$/;"	v
-array_length_mp_8723d_fw_nic	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^u32 array_length_mp_8723d_fw_nic = 25650;$/;"	v
-array_length_mp_8723d_fw_nic	hal/rtl8723d/hal8723d_fw.c	/^u32 array_length_mp_8723d_fw_nic = 27506;$/;"	v
-array_length_mp_8723d_fw_wowlan	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^u32 array_length_mp_8723d_fw_wowlan = 28778;$/;"	v
-array_length_mp_8723d_fw_wowlan	hal/rtl8723d/hal8723d_fw.c	/^u32 array_length_mp_8723d_fw_wowlan = 32334;$/;"	v
-array_mp_8723d_fw_ap	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^u8 array_mp_8723d_fw_ap[] = {$/;"	v
-array_mp_8723d_fw_ap	hal/rtl8723d/hal8723d_fw.c	/^u8 array_mp_8723d_fw_ap[] = {$/;"	v
-array_mp_8723d_fw_nic	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^u8 array_mp_8723d_fw_nic[] = {$/;"	v
-array_mp_8723d_fw_nic	hal/rtl8723d/hal8723d_fw.c	/^u8 array_mp_8723d_fw_nic[] = {$/;"	v
-array_mp_8723d_fw_wowlan	hal/phydm/rtl8723d/halhwimg8723d_fw.c	/^u8 array_mp_8723d_fw_wowlan[] = {$/;"	v
-array_mp_8723d_fw_wowlan	hal/rtl8723d/hal8723d_fw.c	/^u8 array_mp_8723d_fw_wowlan[] = {$/;"	v
-array_sz	include/rtw_ioctl.h	/^	unsigned int array_sz; \/* the size of node_array *\/$/;"	m	struct:oid_funs_node
-asoc_list	include/sta_info.h	/^	_list asoc_list;$/;"	m	struct:sta_info
-asoc_list	include/sta_info.h	/^	_list asoc_list;$/;"	m	struct:sta_priv
-asoc_list_cnt	include/sta_info.h	/^	u8 asoc_list_cnt;$/;"	m	struct:sta_priv
-asoc_list_lock	include/sta_info.h	/^	_lock asoc_list_lock;$/;"	m	struct:sta_priv
-asoc_sta_count	include/sta_info.h	/^	int asoc_sta_count;$/;"	m	struct:sta_priv
-assoc_AP_vendor	include/rtw_mlme_ext.h	/^	u8	assoc_AP_vendor;$/;"	m	struct:mlme_ext_info
-assoc_bssid	include/rtw_mlme.h	/^	u8	assoc_bssid[6];$/;"	m	struct:mlme_priv
-assoc_by_bssid	include/rtw_mlme.h	/^	uint assoc_by_bssid;$/;"	m	struct:mlme_priv
-assoc_by_rssi	include/rtw_mlme.h	/^	uint assoc_by_rssi;$/;"	m	struct:mlme_priv
-assoc_info	include/rtw_security.h	/^	u8 assoc_info[600];$/;"	m	struct:security_priv
-assoc_req	include/ieee80211_ext.h	/^		}  __attribute__((packed)) assoc_req;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon11
-assoc_req	include/ieee80211_ext.h	/^		}  assoc_req;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon29
-assoc_req	include/rtw_mlme.h	/^	u8 *assoc_req;$/;"	m	struct:mlme_priv
-assoc_req_len	include/rtw_mlme.h	/^	u32 assoc_req_len;$/;"	m	struct:mlme_priv
-assoc_req_len	include/sta_info.h	/^	u32 assoc_req_len;$/;"	m	struct:sta_info
-assoc_resp	include/ieee80211_ext.h	/^		}  __attribute__((packed)) assoc_resp, reassoc_resp;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon12
-assoc_resp	include/ieee80211_ext.h	/^		}  assoc_resp, reassoc_resp;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon30
-assoc_rsp	include/rtw_mlme.h	/^	u8 *assoc_rsp;$/;"	m	struct:mlme_priv
-assoc_rsp_len	include/rtw_mlme.h	/^	u32 assoc_rsp_len;$/;"	m	struct:mlme_priv
-assoc_ssid	include/rtw_mlme.h	/^	NDIS_802_11_SSID	assoc_ssid;$/;"	m	struct:mlme_priv
-assoc_timer	include/rtw_mlme.h	/^	_timer assoc_timer;$/;"	m	struct:mlme_priv
-assoc_to	include/sta_info.h	/^	unsigned int assoc_to; \/* sec, time to expire before associating. *\/$/;"	m	struct:sta_priv
-associated_clients_update	core/rtw_ap.c	/^void associated_clients_update(_adapter *padapter, u8 updated, u32 sta_info_type)$/;"	f
-associated_stainfo_update	core/rtw_ap.c	/^static void associated_stainfo_update(_adapter *padapter, struct sta_info *psta, u32 sta_info_type)$/;"	f	file:
-async_context	include/sdio_ops.h	/^struct async_context {$/;"	s
-atherosAP	include/rtw_mlme_ext.h	/^	atherosAP	= 0,$/;"	e	enum:Associated_AP
-atmel_rc_pattern	include/sta_info.h	/^	u8 atmel_rc_pattern[6];$/;"	m	struct:sta_priv
-atomic_t	include/basic_types.h	/^	typedef LONG atomic_t;$/;"	t
-atomic_t	include/basic_types.h	/^	typedef long atomic_t;$/;"	t
-attend_ack	include/rtw_btcoex.h	87;"	d
-attend_req	include/rtw_btcoex.h	86;"	d
-attrib	include/rtw_mp.h	/^	struct pkt_attrib attrib;$/;"	m	struct:mp_tx	typeref:struct:mp_tx::pkt_attrib
-attrib	include/rtw_mp.h	/^	struct pkt_attrib attrib;$/;"	m	struct:mp_xmit_frame	typeref:struct:mp_xmit_frame::pkt_attrib
-attrib	include/rtw_recv.h	/^	struct rx_pkt_attrib attrib;$/;"	m	struct:recv_frame_hdr	typeref:struct:recv_frame_hdr::rx_pkt_attrib
-attrib	include/rtw_xmit.h	/^	struct pkt_attrib attrib;$/;"	m	struct:xmit_frame	typeref:struct:xmit_frame::pkt_attrib
-auth	include/ieee80211_ext.h	/^		}  __attribute__((packed)) auth;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon9
-auth	include/ieee80211_ext.h	/^		}  auth;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon27
-authModeToggle	include/rtw_mlme_ext.h	/^	u32	authModeToggle;$/;"	m	struct:mlme_ext_info
-auth_alg	include/ieee80211_ext.h	/^			u16 auth_alg;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon27
-auth_alg	include/ieee80211_ext.h	/^			u16 auth_alg;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon9
-auth_algo	include/ieee80211.h	/^	    auth_algo:4,$/;"	m	struct:ieee80211_security
-auth_algo	include/rtw_mlme_ext.h	/^	u32	auth_algo;	\/* 802.11 auth, could be open, shared, auto *\/$/;"	m	struct:mlme_ext_info
-auth_list	include/sta_info.h	/^	_list auth_list;$/;"	m	struct:sta_info
-auth_list	include/sta_info.h	/^	_list auth_list;$/;"	m	struct:sta_priv
-auth_list_cnt	include/sta_info.h	/^	u8 auth_list_cnt;$/;"	m	struct:sta_priv
-auth_list_lock	include/sta_info.h	/^	_lock auth_list_lock;$/;"	m	struct:sta_priv
-auth_mode	include/ieee80211.h	/^	    auth_mode:2,$/;"	m	struct:ieee80211_security
-auth_rsp	include/rtw_mlme.h	/^	u8 *auth_rsp;$/;"	m	struct:mlme_priv
-auth_rsp_len	include/rtw_mlme.h	/^	u32 auth_rsp_len;$/;"	m	struct:mlme_priv
-auth_seq	include/rtw_mlme_ext.h	/^	u32	auth_seq;$/;"	m	struct:mlme_ext_info
-auth_seq	include/sta_info.h	/^	unsigned int auth_seq;$/;"	m	struct:sta_info
-auth_to	include/sta_info.h	/^	unsigned int auth_to;  \/* sec, time to expire in authenticating. *\/$/;"	m	struct:sta_priv
-auth_transaction	include/ieee80211_ext.h	/^			u16 auth_transaction;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon27
-auth_transaction	include/ieee80211_ext.h	/^			u16 auth_transaction;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon9
-authalg	include/sta_info.h	/^	unsigned int authalg;$/;"	m	struct:sta_info
-authenticator_ie	include/rtw_security.h	/^	u8 authenticator_ie[256];  \/* store ap security information element *\/$/;"	m	struct:security_priv
-auto_chan_sel	include/hal_data.h	/^struct auto_chan_sel {$/;"	s
-auto_scan_int_ms	include/rtw_mlme.h	/^	u32	auto_scan_int_ms;$/;"	m	struct:mlme_priv
-auto_tdma_adjust	hal/btc/HalBtc8192e1Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8192e_1ant
-auto_tdma_adjust	hal/btc/HalBtc8192e2Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8192e_2ant
-auto_tdma_adjust	hal/btc/HalBtc8703b1Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8703b_1ant
-auto_tdma_adjust	hal/btc/HalBtc8723b1Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8723b_1ant
-auto_tdma_adjust	hal/btc/HalBtc8723b2Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8723b_2ant
-auto_tdma_adjust	hal/btc/HalBtc8812a1Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8812a_1ant
-auto_tdma_adjust	hal/btc/HalBtc8812a2Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8812a_2ant
-auto_tdma_adjust	hal/btc/HalBtc8821a1Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8821a_1ant
-auto_tdma_adjust	hal/btc/HalBtc8821a2Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8821a_2ant
-auto_tdma_adjust	hal/btc/HalBtc8822b1Ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8822b_1ant
-auto_tdma_adjust	hal/btc/halbtc8821c1ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8821c_1ant
-auto_tdma_adjust	hal/btc/halbtc8821c2ant.h	/^	boolean		auto_tdma_adjust;$/;"	m	struct:coex_dm_8821c_2ant
-auto_tdma_adjust_low_rssi	hal/btc/HalBtc8192e2Ant.h	/^	boolean		auto_tdma_adjust_low_rssi;$/;"	m	struct:coex_dm_8192e_2ant
-auto_tdma_adjust_low_rssi	hal/btc/HalBtc8812a2Ant.h	/^	boolean		auto_tdma_adjust_low_rssi;$/;"	m	struct:coex_dm_8812a_2ant
-autopm_cnt	include/rtw_pwrctrl.h	/^	u8		autopm_cnt;$/;"	m	struct:pwrctrl_priv
-aux	include/ieee80211_ext.h	/^					u16 aux;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon39
-aux	include/ieee80211_ext.h	/^					u16 aux;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon24
-avg_val	include/rtw_recv.h	/^	u8	avg_val;		\/* avg of valid elements *\/$/;"	m	struct:signal_stat
-b0	include/rtw_cmd.h	/^	u8	b0;$/;"	m	struct:geth2clbk_rsp
-b0	include/rtw_cmd.h	/^	u8	b0;$/;"	m	struct:seth2clbk_parm
-b0	include/rtw_event.h	/^	unsigned char	b0;$/;"	m	struct:c2hlbk_event
-b1	include/rtw_cmd.h	/^	u8	b1;$/;"	m	struct:geth2clbk_rsp
-b1	include/rtw_cmd.h	/^	u8	b1;$/;"	m	struct:seth2clbk_parm
-b1	include/rtw_event.h	/^	unsigned char	b1;$/;"	m	struct:c2hlbk_event
-b2GPAPEPolarity	include/Hal8188EPhyReg.h	547;"	d
-b2GPAPEPolarity	include/Hal8188FPhyReg.h	555;"	d
-b2GPAPEPolarity	include/Hal8192EPhyReg.h	558;"	d
-b2GPAPEPolarity	include/Hal8703BPhyReg.h	584;"	d
-b2GPAPEPolarity	include/Hal8723BPhyReg.h	582;"	d
-b2GPAPEPolarity	include/Hal8723DPhyReg.h	585;"	d
-b2GPAPEPolarity	include/rtw_mp_phy_regdef.h	497;"	d
-b3WireAddressLength	include/Hal8188EPhyReg.h	542;"	d
-b3WireAddressLength	include/Hal8188FPhyReg.h	550;"	d
-b3WireAddressLength	include/Hal8192EPhyReg.h	553;"	d
-b3WireAddressLength	include/Hal8703BPhyReg.h	579;"	d
-b3WireAddressLength	include/Hal8723BPhyReg.h	577;"	d
-b3WireAddressLength	include/Hal8723DPhyReg.h	580;"	d
-b3WireAddressLength	include/rtw_mp_phy_regdef.h	492;"	d
-b3WireDataLength	include/Hal8188EPhyReg.h	541;"	d
-b3WireDataLength	include/Hal8188FPhyReg.h	549;"	d
-b3WireDataLength	include/Hal8192EPhyReg.h	552;"	d
-b3WireDataLength	include/Hal8703BPhyReg.h	578;"	d
-b3WireDataLength	include/Hal8723BPhyReg.h	576;"	d
-b3WireDataLength	include/Hal8723DPhyReg.h	579;"	d
-b3WireDataLength	include/rtw_mp_phy_regdef.h	491;"	d
-b3WireRFPowerDown	include/Hal8188EPhyReg.h	544;"	d
-b3WireRFPowerDown	include/Hal8188FPhyReg.h	552;"	d
-b3WireRFPowerDown	include/Hal8192EPhyReg.h	555;"	d
-b3WireRFPowerDown	include/Hal8703BPhyReg.h	581;"	d
-b3WireRFPowerDown	include/Hal8723BPhyReg.h	579;"	d
-b3WireRFPowerDown	include/Hal8723DPhyReg.h	582;"	d
-b3WireRFPowerDown	include/rtw_mp_phy_regdef.h	494;"	d
-b40MDClkPowerUP	include/Hal8188EPhyReg.h	601;"	d
-b40MDClkPowerUP	include/Hal8188FPhyReg.h	609;"	d
-b40MDClkPowerUP	include/Hal8192EPhyReg.h	612;"	d
-b40MDClkPowerUP	include/Hal8703BPhyReg.h	638;"	d
-b40MDClkPowerUP	include/Hal8723BPhyReg.h	636;"	d
-b40MDClkPowerUP	include/Hal8723DPhyReg.h	639;"	d
-b40MDClkPowerUP	include/rtw_mp_phy_regdef.h	555;"	d
-b5GPAPEPolarity	include/Hal8188EPhyReg.h	546;"	d
-b5GPAPEPolarity	include/Hal8188FPhyReg.h	554;"	d
-b5GPAPEPolarity	include/Hal8192EPhyReg.h	557;"	d
-b5GPAPEPolarity	include/Hal8703BPhyReg.h	583;"	d
-b5GPAPEPolarity	include/Hal8723BPhyReg.h	581;"	d
-b5GPAPEPolarity	include/Hal8723DPhyReg.h	584;"	d
-b5GPAPEPolarity	include/rtw_mp_phy_regdef.h	496;"	d
-b80MClkDelay	include/Hal8188EPhyReg.h	607;"	d
-b80MClkDelay	include/Hal8188FPhyReg.h	615;"	d
-b80MClkDelay	include/Hal8192EPhyReg.h	618;"	d
-b80MClkDelay	include/Hal8703BPhyReg.h	644;"	d
-b80MClkDelay	include/Hal8723BPhyReg.h	642;"	d
-b80MClkDelay	include/Hal8723DPhyReg.h	645;"	d
-b80MClkDelay	include/rtw_mp_phy_regdef.h	561;"	d
-bA2DP	core/rtw_cmd.c	/^	u8 bA2DP:1;$/;"	m	struct:btinfo	file:
-bA2DP	include/rtw_btcoex.h	/^	u8 bA2DP:1;$/;"	m	struct:btinfo_8761ATV
-bA2dpBusy	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN					bA2dpBusy;$/;"	m	struct:_COEX_STA_8188C_2ANT
-bA2dpBusy	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN					bA2dpBusy;$/;"	m	struct:_COEX_STA_8192D_2ANT
-bACLBusy	core/rtw_cmd.c	/^	u8 bACLBusy:1;$/;"	m	struct:btinfo	file:
-bACLBusy	include/rtw_btcoex.h	/^	u8 bACLBusy:1;$/;"	m	struct:btinfo_8761ATV
-bAD11InputRange	include/Hal8188EPhyReg.h	619;"	d
-bAD11InputRange	include/Hal8188FPhyReg.h	627;"	d
-bAD11InputRange	include/Hal8192EPhyReg.h	630;"	d
-bAD11InputRange	include/Hal8703BPhyReg.h	656;"	d
-bAD11InputRange	include/Hal8723BPhyReg.h	654;"	d
-bAD11InputRange	include/Hal8723DPhyReg.h	657;"	d
-bAD11InputRange	include/rtw_mp_phy_regdef.h	573;"	d
-bAD11OPCurrent	include/Hal8188EPhyReg.h	620;"	d
-bAD11OPCurrent	include/Hal8188FPhyReg.h	628;"	d
-bAD11OPCurrent	include/Hal8192EPhyReg.h	631;"	d
-bAD11OPCurrent	include/Hal8703BPhyReg.h	657;"	d
-bAD11OPCurrent	include/Hal8723BPhyReg.h	655;"	d
-bAD11OPCurrent	include/Hal8723DPhyReg.h	658;"	d
-bAD11OPCurrent	include/rtw_mp_phy_regdef.h	574;"	d
-bAD11PowerUpAtRx	include/Hal8188EPhyReg.h	635;"	d
-bAD11PowerUpAtRx	include/Hal8188FPhyReg.h	643;"	d
-bAD11PowerUpAtRx	include/Hal8192EPhyReg.h	646;"	d
-bAD11PowerUpAtRx	include/Hal8703BPhyReg.h	672;"	d
-bAD11PowerUpAtRx	include/Hal8723BPhyReg.h	670;"	d
-bAD11PowerUpAtRx	include/Hal8723DPhyReg.h	673;"	d
-bAD11PowerUpAtRx	include/rtw_mp_phy_regdef.h	589;"	d
-bAD11PowerUpAtTx	include/Hal8188EPhyReg.h	633;"	d
-bAD11PowerUpAtTx	include/Hal8188FPhyReg.h	641;"	d
-bAD11PowerUpAtTx	include/Hal8192EPhyReg.h	644;"	d
-bAD11PowerUpAtTx	include/Hal8703BPhyReg.h	670;"	d
-bAD11PowerUpAtTx	include/Hal8723BPhyReg.h	668;"	d
-bAD11PowerUpAtTx	include/Hal8723DPhyReg.h	671;"	d
-bAD11PowerUpAtTx	include/rtw_mp_phy_regdef.h	587;"	d
-bAD11SHGain	include/Hal8188EPhyReg.h	618;"	d
-bAD11SHGain	include/Hal8188FPhyReg.h	626;"	d
-bAD11SHGain	include/Hal8192EPhyReg.h	629;"	d
-bAD11SHGain	include/Hal8703BPhyReg.h	655;"	d
-bAD11SHGain	include/Hal8723BPhyReg.h	653;"	d
-bAD11SHGain	include/Hal8723DPhyReg.h	656;"	d
-bAD11SHGain	include/rtw_mp_phy_regdef.h	572;"	d
-bAD7Current	include/Hal8188EPhyReg.h	631;"	d
-bAD7Current	include/Hal8188FPhyReg.h	639;"	d
-bAD7Current	include/Hal8192EPhyReg.h	642;"	d
-bAD7Current	include/Hal8703BPhyReg.h	668;"	d
-bAD7Current	include/Hal8723BPhyReg.h	666;"	d
-bAD7Current	include/Hal8723DPhyReg.h	669;"	d
-bAD7Current	include/rtw_mp_phy_regdef.h	585;"	d
-bAD7Gain	include/Hal8188EPhyReg.h	628;"	d
-bAD7Gain	include/Hal8188FPhyReg.h	636;"	d
-bAD7Gain	include/Hal8192EPhyReg.h	639;"	d
-bAD7Gain	include/Hal8703BPhyReg.h	665;"	d
-bAD7Gain	include/Hal8723BPhyReg.h	663;"	d
-bAD7Gain	include/Hal8723DPhyReg.h	666;"	d
-bAD7Gain	include/rtw_mp_phy_regdef.h	582;"	d
-bAD7InputCMMode	include/Hal8188EPhyReg.h	630;"	d
-bAD7InputCMMode	include/Hal8188FPhyReg.h	638;"	d
-bAD7InputCMMode	include/Hal8192EPhyReg.h	641;"	d
-bAD7InputCMMode	include/Hal8703BPhyReg.h	667;"	d
-bAD7InputCMMode	include/Hal8723BPhyReg.h	665;"	d
-bAD7InputCMMode	include/Hal8723DPhyReg.h	668;"	d
-bAD7InputCMMode	include/rtw_mp_phy_regdef.h	584;"	d
-bAD7InputRange	include/Hal8188EPhyReg.h	627;"	d
-bAD7InputRange	include/Hal8188FPhyReg.h	635;"	d
-bAD7InputRange	include/Hal8192EPhyReg.h	638;"	d
-bAD7InputRange	include/Hal8703BPhyReg.h	664;"	d
-bAD7InputRange	include/Hal8723BPhyReg.h	662;"	d
-bAD7InputRange	include/Hal8723DPhyReg.h	665;"	d
-bAD7InputRange	include/rtw_mp_phy_regdef.h	581;"	d
-bAD7OutputCMMode	include/Hal8188EPhyReg.h	629;"	d
-bAD7OutputCMMode	include/Hal8188FPhyReg.h	637;"	d
-bAD7OutputCMMode	include/Hal8192EPhyReg.h	640;"	d
-bAD7OutputCMMode	include/Hal8703BPhyReg.h	666;"	d
-bAD7OutputCMMode	include/Hal8723BPhyReg.h	664;"	d
-bAD7OutputCMMode	include/Hal8723DPhyReg.h	667;"	d
-bAD7OutputCMMode	include/rtw_mp_phy_regdef.h	583;"	d
-bAD7PowerUp	include/Hal8188EPhyReg.h	598;"	d
-bAD7PowerUp	include/Hal8188FPhyReg.h	606;"	d
-bAD7PowerUp	include/Hal8192EPhyReg.h	609;"	d
-bAD7PowerUp	include/Hal8703BPhyReg.h	635;"	d
-bAD7PowerUp	include/Hal8723BPhyReg.h	633;"	d
-bAD7PowerUp	include/Hal8723DPhyReg.h	636;"	d
-bAD7PowerUp	include/rtw_mp_phy_regdef.h	552;"	d
-bADCBackoff	include/Hal8188EPhyReg.h	756;"	d
-bADCBackoff	include/Hal8188FPhyReg.h	764;"	d
-bADCBackoff	include/Hal8192EPhyReg.h	767;"	d
-bADCBackoff	include/Hal8703BPhyReg.h	793;"	d
-bADCBackoff	include/Hal8723BPhyReg.h	791;"	d
-bADCBackoff	include/Hal8723DPhyReg.h	794;"	d
-bADCBackoff	include/rtw_mp_phy_regdef.h	710;"	d
-bADClkPhase	include/Hal8188EPhyReg.h	605;"	d
-bADClkPhase	include/Hal8188FPhyReg.h	613;"	d
-bADClkPhase	include/Hal8192EPhyReg.h	616;"	d
-bADClkPhase	include/Hal8703BPhyReg.h	642;"	d
-bADClkPhase	include/Hal8723BPhyReg.h	640;"	d
-bADClkPhase	include/Hal8723DPhyReg.h	643;"	d
-bADClkPhase	include/rtw_mp_phy_regdef.h	559;"	d
-bAFELoopback	include/Hal8188EPhyReg.h	623;"	d
-bAFELoopback	include/Hal8188FPhyReg.h	631;"	d
-bAFELoopback	include/Hal8192EPhyReg.h	634;"	d
-bAFELoopback	include/Hal8703BPhyReg.h	660;"	d
-bAFELoopback	include/Hal8723BPhyReg.h	658;"	d
-bAFELoopback	include/Hal8723DPhyReg.h	661;"	d
-bAFELoopback	include/rtw_mp_phy_regdef.h	577;"	d
-bAFEWatchDogEnable	include/Hal8188EPhyReg.h	608;"	d
-bAFEWatchDogEnable	include/Hal8188FPhyReg.h	616;"	d
-bAFEWatchDogEnable	include/Hal8192EPhyReg.h	619;"	d
-bAFEWatchDogEnable	include/Hal8703BPhyReg.h	645;"	d
-bAFEWatchDogEnable	include/Hal8723BPhyReg.h	643;"	d
-bAFEWatchDogEnable	include/Hal8723DPhyReg.h	646;"	d
-bAFEWatchDogEnable	include/rtw_mp_phy_regdef.h	562;"	d
-bAGCAddress	include/Hal8188EPhyReg.h	534;"	d
-bAGCAddress	include/Hal8188FPhyReg.h	542;"	d
-bAGCAddress	include/Hal8192EPhyReg.h	545;"	d
-bAGCAddress	include/Hal8703BPhyReg.h	571;"	d
-bAGCAddress	include/Hal8723BPhyReg.h	569;"	d
-bAGCAddress	include/Hal8723DPhyReg.h	572;"	d
-bAGCAddress	include/rtw_mp_phy_regdef.h	484;"	d
-bAGCRxCode	include/Hal8188EPhyReg.h	539;"	d
-bAGCRxCode	include/Hal8188FPhyReg.h	547;"	d
-bAGCRxCode	include/Hal8192EPhyReg.h	550;"	d
-bAGCRxCode	include/Hal8703BPhyReg.h	576;"	d
-bAGCRxCode	include/Hal8723BPhyReg.h	574;"	d
-bAGCRxCode	include/Hal8723DPhyReg.h	577;"	d
-bAGCRxCode	include/rtw_mp_phy_regdef.h	489;"	d
-bAGCTxCode	include/Hal8188EPhyReg.h	538;"	d
-bAGCTxCode	include/Hal8188FPhyReg.h	546;"	d
-bAGCTxCode	include/Hal8192EPhyReg.h	549;"	d
-bAGCTxCode	include/Hal8703BPhyReg.h	575;"	d
-bAGCTxCode	include/Hal8723BPhyReg.h	573;"	d
-bAGCTxCode	include/Hal8723DPhyReg.h	576;"	d
-bAGCTxCode	include/rtw_mp_phy_regdef.h	488;"	d
-bAGC_table_Jaguar	include/Hal8812PhyReg.h	157;"	d
-bAGC_table_Jaguar	include/Hal8814PhyReg.h	187;"	d
-bAPKThermalMeterIgnore	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	bAPKThermalMeterIgnore;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAPKThermalMeterIgnore	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	bAPKThermalMeterIgnore;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAPKThermalMeterIgnore	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	bAPKThermalMeterIgnore;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAPKdone	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	bAPKdone;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAPKdone	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	bAPKdone;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAPKdone	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	bAPKdone;$/;"	m	struct:ODM_RF_Calibration_Structure
-bATCStatus	hal/phydm/phydm_cfotracking.h	/^	BOOLEAN			bATCStatus;$/;"	m	struct:_CFO_TRACKING_
-bAcceptAddbaReq	include/drv_types.h	/^	BOOLEAN	bAcceptAddbaReq;$/;"	m	struct:registry_priv
-bAcceptAddbaReq	include/rtw_mlme_ext.h	/^	BOOLEAN bAcceptAddbaReq;$/;"	m	struct:mlme_ext_info
-bAdjust	hal/phydm/phydm_cfotracking.h	/^	BOOLEAN			bAdjust;$/;"	m	struct:_CFO_TRACKING_
-bAdvTimeCtrl	include/Hal8188EPhyReg.h	989;"	d
-bAdvTimeCtrl	include/Hal8188FPhyReg.h	997;"	d
-bAdvTimeCtrl	include/Hal8192EPhyReg.h	1000;"	d
-bAdvTimeCtrl	include/Hal8703BPhyReg.h	1026;"	d
-bAdvTimeCtrl	include/Hal8723BPhyReg.h	1024;"	d
-bAdvTimeCtrl	include/Hal8723DPhyReg.h	1027;"	d
-bAdvTimeCtrl	include/rtw_mp_phy_regdef.h	943;"	d
-bAdvUpdCFO	include/Hal8188EPhyReg.h	988;"	d
-bAdvUpdCFO	include/Hal8188FPhyReg.h	996;"	d
-bAdvUpdCFO	include/Hal8192EPhyReg.h	999;"	d
-bAdvUpdCFO	include/Hal8703BPhyReg.h	1025;"	d
-bAdvUpdCFO	include/Hal8723BPhyReg.h	1023;"	d
-bAdvUpdCFO	include/Hal8723DPhyReg.h	1026;"	d
-bAdvUpdCFO	include/rtw_mp_phy_regdef.h	942;"	d
-bAdvUpdEqz	include/Hal8188EPhyReg.h	997;"	d
-bAdvUpdEqz	include/Hal8188FPhyReg.h	1005;"	d
-bAdvUpdEqz	include/Hal8192EPhyReg.h	1008;"	d
-bAdvUpdEqz	include/Hal8703BPhyReg.h	1034;"	d
-bAdvUpdEqz	include/Hal8723BPhyReg.h	1032;"	d
-bAdvUpdEqz	include/Hal8723DPhyReg.h	1035;"	d
-bAdvUpdEqz	include/rtw_mp_phy_regdef.h	951;"	d
-bAllQueueUAPSD	include/rtl8188e_cmd.h	/^	u8 bAllQueueUAPSD;$/;"	m	struct:_SETPWRMODE_PARM
-bAllQueueUAPSD	include/rtl8192e_cmd.h	/^	u8 bAllQueueUAPSD;$/;"	m	struct:_SETPWRMODE_PARM
-bAll_BFSta_Idle	hal/phydm/phydm_antdiv.h	/^	BOOLEAN bAll_BFSta_Idle;$/;"	m	struct:_BF_DIV_COEX_
-bAll_DivSta_Idle	hal/phydm/phydm_antdiv.h	/^	BOOLEAN bAll_DivSta_Idle;$/;"	m	struct:_BF_DIV_COEX_
-bAntDetected	hal/phydm/phydm_antdect.h	/^	BOOLEAN			bAntDetected;$/;"	m	struct:_ANT_DETECTED_INFO
-bAntHT1	include/Hal8188EPhyReg.h	657;"	d
-bAntHT1	include/Hal8188FPhyReg.h	665;"	d
-bAntHT1	include/Hal8192EPhyReg.h	668;"	d
-bAntHT1	include/Hal8703BPhyReg.h	694;"	d
-bAntHT1	include/Hal8723BPhyReg.h	692;"	d
-bAntHT1	include/Hal8723DPhyReg.h	695;"	d
-bAntHT1	include/rtw_mp_phy_regdef.h	611;"	d
-bAntHT1S1	include/Hal8188EPhyReg.h	659;"	d
-bAntHT1S1	include/Hal8188FPhyReg.h	667;"	d
-bAntHT1S1	include/Hal8192EPhyReg.h	670;"	d
-bAntHT1S1	include/Hal8703BPhyReg.h	696;"	d
-bAntHT1S1	include/Hal8723BPhyReg.h	694;"	d
-bAntHT1S1	include/Hal8723DPhyReg.h	697;"	d
-bAntHT1S1	include/rtw_mp_phy_regdef.h	613;"	d
-bAntHT2	include/Hal8188EPhyReg.h	658;"	d
-bAntHT2	include/Hal8188FPhyReg.h	666;"	d
-bAntHT2	include/Hal8192EPhyReg.h	669;"	d
-bAntHT2	include/Hal8703BPhyReg.h	695;"	d
-bAntHT2	include/Hal8723BPhyReg.h	693;"	d
-bAntHT2	include/Hal8723DPhyReg.h	696;"	d
-bAntHT2	include/rtw_mp_phy_regdef.h	612;"	d
-bAntL	include/Hal8188EPhyReg.h	655;"	d
-bAntL	include/Hal8188FPhyReg.h	663;"	d
-bAntL	include/Hal8192EPhyReg.h	666;"	d
-bAntL	include/Hal8703BPhyReg.h	692;"	d
-bAntL	include/Hal8723BPhyReg.h	690;"	d
-bAntL	include/Hal8723DPhyReg.h	693;"	d
-bAntL	include/rtw_mp_phy_regdef.h	609;"	d
-bAntNonHT	include/Hal8188EPhyReg.h	656;"	d
-bAntNonHT	include/Hal8188FPhyReg.h	664;"	d
-bAntNonHT	include/Hal8192EPhyReg.h	667;"	d
-bAntNonHT	include/Hal8703BPhyReg.h	693;"	d
-bAntNonHT	include/Hal8723BPhyReg.h	691;"	d
-bAntNonHT	include/Hal8723DPhyReg.h	694;"	d
-bAntNonHT	include/rtw_mp_phy_regdef.h	610;"	d
-bAntNonHTS1	include/Hal8188EPhyReg.h	660;"	d
-bAntNonHTS1	include/Hal8188FPhyReg.h	668;"	d
-bAntNonHTS1	include/Hal8192EPhyReg.h	671;"	d
-bAntNonHTS1	include/Hal8703BPhyReg.h	697;"	d
-bAntNonHTS1	include/Hal8723BPhyReg.h	695;"	d
-bAntNonHTS1	include/Hal8723DPhyReg.h	698;"	d
-bAntNonHTS1	include/rtw_mp_phy_regdef.h	614;"	d
-bAntennaDetected	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	bAntennaDetected;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAntennaDetected	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN	bAntennaDetected;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAntennaDetected	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN	bAntennaDetected;$/;"	m	struct:ODM_RF_Calibration_Structure
-bAntennaMapping	include/Hal8188EPhyReg.h	903;"	d
-bAntennaMapping	include/Hal8188FPhyReg.h	911;"	d
-bAntennaMapping	include/Hal8192EPhyReg.h	914;"	d
-bAntennaMapping	include/Hal8703BPhyReg.h	940;"	d
-bAntennaMapping	include/Hal8723BPhyReg.h	938;"	d
-bAntennaMapping	include/Hal8723DPhyReg.h	941;"	d
-bAntennaMapping	include/Hal8812PhyReg.h	694;"	d
-bAntennaMapping	include/Hal8814PhyReg.h	819;"	d
-bAntennaMapping	include/rtw_mp_phy_regdef.h	857;"	d
-bAntennaSelect	include/Hal8188EPhyReg.h	514;"	d
-bAntennaSelect	include/Hal8188FPhyReg.h	522;"	d
-bAntennaSelect	include/Hal8192EPhyReg.h	525;"	d
-bAntennaSelect	include/Hal8703BPhyReg.h	551;"	d
-bAntennaSelect	include/Hal8723BPhyReg.h	549;"	d
-bAntennaSelect	include/Hal8723DPhyReg.h	552;"	d
-bAuthenticateInProgress	include/rtw_wapi.h	/^	bool					bAuthenticateInProgress;$/;"	m	struct:_RT_WAPI_STA_INFO
-bAuthenticatorInUpdata	include/rtw_wapi.h	/^	bool					bAuthenticatorInUpdata;$/;"	m	struct:_RT_WAPI_STA_INFO
-bAutoResume	include/rtw_pwrctrl.h	/^	u8		bAutoResume;$/;"	m	struct:pwrctrl_priv
-bBBCCKStart	include/Hal8188EPhyReg.h	524;"	d
-bBBCCKStart	include/Hal8188FPhyReg.h	532;"	d
-bBBCCKStart	include/Hal8192EPhyReg.h	535;"	d
-bBBCCKStart	include/Hal8703BPhyReg.h	561;"	d
-bBBCCKStart	include/Hal8723BPhyReg.h	559;"	d
-bBBCCKStart	include/Hal8723DPhyReg.h	562;"	d
-bBBCCKStart	include/rtw_mp_phy_regdef.h	474;"	d
-bBBResetB	include/Hal8188EPhyReg.h	456;"	d
-bBBResetB	include/Hal8188FPhyReg.h	464;"	d
-bBBResetB	include/Hal8192EPhyReg.h	465;"	d
-bBBResetB	include/Hal8703BPhyReg.h	492;"	d
-bBBResetB	include/Hal8723BPhyReg.h	491;"	d
-bBBResetB	include/Hal8723DPhyReg.h	493;"	d
-bBBResetB	include/Hal8812PhyReg.h	323;"	d
-bBBResetB	include/Hal8814PhyReg.h	430;"	d
-bBBResetB	include/rtl8822b_hal.h	153;"	d
-bBBResetB	include/rtw_mp_phy_regdef.h	408;"	d
-bBBStart	include/Hal8188EPhyReg.h	523;"	d
-bBBStart	include/Hal8188FPhyReg.h	531;"	d
-bBBStart	include/Hal8192EPhyReg.h	534;"	d
-bBBStart	include/Hal8703BPhyReg.h	560;"	d
-bBBStart	include/Hal8723BPhyReg.h	558;"	d
-bBBStart	include/Hal8723DPhyReg.h	561;"	d
-bBBStart	include/rtw_mp_phy_regdef.h	473;"	d
-bBTConnectInProgress	include/rtw_btcoex.h	/^	BOOLEAN				bBTConnectInProgress;$/;"	m	struct:_BT_MGNT
-bBTFWReady	include/drv_types.h	/^	u8 bBTFWReady;$/;"	m	struct:_ADAPTER
-bBWIqkResultSaved	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN 	bBWIqkResultSaved[3];	$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-bBWIqkResultSaved	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN 	bBWIqkResultSaved[3];	$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-bBW_Search_L	include/Hal8188EPhyReg.h	775;"	d
-bBW_Search_L	include/Hal8188FPhyReg.h	783;"	d
-bBW_Search_L	include/Hal8192EPhyReg.h	786;"	d
-bBW_Search_L	include/Hal8703BPhyReg.h	812;"	d
-bBW_Search_L	include/Hal8723BPhyReg.h	810;"	d
-bBW_Search_L	include/Hal8723DPhyReg.h	813;"	d
-bBW_Search_L	include/rtw_mp_phy_regdef.h	729;"	d
-bBW_TH	include/Hal8188EPhyReg.h	777;"	d
-bBW_TH	include/Hal8188FPhyReg.h	785;"	d
-bBW_TH	include/Hal8192EPhyReg.h	788;"	d
-bBW_TH	include/Hal8703BPhyReg.h	814;"	d
-bBW_TH	include/Hal8723BPhyReg.h	812;"	d
-bBW_TH	include/Hal8723DPhyReg.h	815;"	d
-bBW_TH	include/rtw_mp_phy_regdef.h	731;"	d
-bBW_option	include/Hal8188EPhyReg.h	779;"	d
-bBW_option	include/Hal8188FPhyReg.h	787;"	d
-bBW_option	include/Hal8192EPhyReg.h	790;"	d
-bBW_option	include/Hal8703BPhyReg.h	816;"	d
-bBW_option	include/Hal8723BPhyReg.h	814;"	d
-bBW_option	include/Hal8723DPhyReg.h	817;"	d
-bBW_option	include/rtw_mp_phy_regdef.h	733;"	d
-bBandSelect	include/Hal8188EPhyReg.h	566;"	d
-bBandSelect	include/Hal8188FPhyReg.h	574;"	d
-bBandSelect	include/Hal8192EPhyReg.h	577;"	d
-bBandSelect	include/Hal8703BPhyReg.h	603;"	d
-bBandSelect	include/Hal8723BPhyReg.h	601;"	d
-bBandSelect	include/Hal8723DPhyReg.h	604;"	d
-bBandSelect	include/rtw_mp_phy_regdef.h	516;"	d
-bBandgapMbiasPowerUp	include/Hal8188EPhyReg.h	617;"	d
-bBandgapMbiasPowerUp	include/Hal8188FPhyReg.h	625;"	d
-bBandgapMbiasPowerUp	include/Hal8192EPhyReg.h	628;"	d
-bBandgapMbiasPowerUp	include/Hal8703BPhyReg.h	654;"	d
-bBandgapMbiasPowerUp	include/Hal8723BPhyReg.h	652;"	d
-bBandgapMbiasPowerUp	include/Hal8723DPhyReg.h	655;"	d
-bBandgapMbiasPowerUp	include/rtw_mp_phy_regdef.h	571;"	d
-bBeamformed	hal/phydm/phydm.h	/^	BOOLEAN		bBeamformed;				\/* BF packet---*\/$/;"	m	struct:_ODM_Phy_Status_Info_
-bBeamformed	include/rtw_recv.h	/^	BOOLEAN		bBeamformed;$/;"	m	struct:phy_info
-bBeamformingInProgress	hal/phydm/phydm_beamforming.h	/^	BOOLEAN						bBeamformingInProgress;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-bBecomeLinked	hal/phydm/phydm_antdiv.h	/^	BOOLEAN	bBecomeLinked;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-bBecomeLinked	hal/phydm/phydm_pathdiv.h	/^	BOOLEAN	bBecomeLinked;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-bBinded	hal/btc/HalBtcOutSrc.h	/^	BOOLEAN				bBinded;		\/*make sure only one adapter can bind the data context*\/$/;"	m	struct:btc_coexist
-bBtBusy	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN					bBtBusy;$/;"	m	struct:_COEX_STA_8188C_2ANT
-bBtBusy	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN					bBtBusy;$/;"	m	struct:_COEX_STA_8192D_2ANT
-bBtBusy	hal/phydm/phydm.h	/^	BOOLEAN			bBtBusy;			\/*BT is busy.*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bBtConnectProcess	hal/phydm/phydm.h	/^	BOOLEAN			bBtConnectProcess;	\/*BT HS is under connection progress.*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bBtDisableEdcaTurbo	hal/phydm/phydm.h	/^	BOOLEAN			bBtDisableEdcaTurbo;	\/*Under some condition, don't enable the EDCA Turbo*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bBtDownLink	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN					bBtDownLink;$/;"	m	struct:_COEX_STA_8188C_2ANT
-bBtDownLink	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN					bBtDownLink;$/;"	m	struct:_COEX_STA_8192D_2ANT
-bBtEnabled	hal/phydm/phydm.h	/^	BOOLEAN			bBtEnabled;			\/*BT is enabled*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bBtExist	include/hal_btcoex.h	/^	u8 bBtExist;$/;"	m	struct:_BT_COEXIST
-bBtHsOperation	hal/phydm/phydm.h	/^	BOOLEAN			bBtHsOperation;		\/*BT HS mode is under progress*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bBtLimitedDig	hal/phydm/phydm.h	/^	BOOLEAN			bBtLimitedDig;		\/*BT is busy.*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bBtRsvedPageDownload	include/rtw_btcoex.h	/^	BOOLEAN				bBtRsvedPageDownload;$/;"	m	struct:_BT_MGNT
-bBtScan	include/rtw_btcoex.h	/^	BOOLEAN				bBtScan;$/;"	m	struct:_BT_MGNT
-bBtUplink	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN					bBtUplink;$/;"	m	struct:_COEX_STA_8188C_2ANT
-bBtUplink	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN					bBtUplink;$/;"	m	struct:_COEX_STA_8192D_2ANT
-bBusyTraffic	include/rtw_mlme.h	/^	BOOLEAN			bBusyTraffic;$/;"	m	struct:_RT_LINK_DETECT_T
-bByte0	include/Hal8188EPhyReg.h	1041;"	d
-bByte0	include/Hal8188FPhyReg.h	1049;"	d
-bByte0	include/Hal8192EPhyReg.h	1052;"	d
-bByte0	include/Hal8703BPhyReg.h	1078;"	d
-bByte0	include/Hal8723BPhyReg.h	1076;"	d
-bByte0	include/Hal8723DPhyReg.h	1079;"	d
-bByte0	include/Hal8812PhyReg.h	712;"	d
-bByte0	include/Hal8814PhyReg.h	837;"	d
-bByte0	include/rtw_mp_phy_regdef.h	1004;"	d
-bByte1	include/Hal8188EPhyReg.h	1042;"	d
-bByte1	include/Hal8188FPhyReg.h	1050;"	d
-bByte1	include/Hal8192EPhyReg.h	1053;"	d
-bByte1	include/Hal8703BPhyReg.h	1079;"	d
-bByte1	include/Hal8723BPhyReg.h	1077;"	d
-bByte1	include/Hal8723DPhyReg.h	1080;"	d
-bByte1	include/Hal8812PhyReg.h	713;"	d
-bByte1	include/Hal8814PhyReg.h	838;"	d
-bByte1	include/rtw_mp_phy_regdef.h	1005;"	d
-bByte2	include/Hal8188EPhyReg.h	1043;"	d
-bByte2	include/Hal8188FPhyReg.h	1051;"	d
-bByte2	include/Hal8192EPhyReg.h	1054;"	d
-bByte2	include/Hal8703BPhyReg.h	1080;"	d
-bByte2	include/Hal8723BPhyReg.h	1078;"	d
-bByte2	include/Hal8723DPhyReg.h	1081;"	d
-bByte2	include/Hal8812PhyReg.h	714;"	d
-bByte2	include/Hal8814PhyReg.h	839;"	d
-bByte2	include/rtw_mp_phy_regdef.h	1006;"	d
-bByte3	include/Hal8188EPhyReg.h	1044;"	d
-bByte3	include/Hal8188FPhyReg.h	1052;"	d
-bByte3	include/Hal8192EPhyReg.h	1055;"	d
-bByte3	include/Hal8703BPhyReg.h	1081;"	d
-bByte3	include/Hal8723BPhyReg.h	1079;"	d
-bByte3	include/Hal8723DPhyReg.h	1082;"	d
-bByte3	include/Hal8812PhyReg.h	715;"	d
-bByte3	include/Hal8814PhyReg.h	840;"	d
-bByte3	include/rtw_mp_phy_regdef.h	1007;"	d
-bC2hBtInfoReqSent	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN					bC2hBtInfoReqSent;$/;"	m	struct:_COEX_STA_8723A_1ANT
-bC2hBtInfoReqSent	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN					bC2hBtInfoReqSent;$/;"	m	struct:_COEX_STA_8723A_2ANT
-bC2hBtInquiryPage	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN					bC2hBtInquiryPage;$/;"	m	struct:_COEX_STA_8723A_1ANT
-bC2hBtInquiryPage	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN					bC2hBtInquiryPage;$/;"	m	struct:_COEX_STA_8723A_2ANT
-bCCADropOption	include/Hal8188EPhyReg.h	815;"	d
-bCCADropOption	include/Hal8188FPhyReg.h	823;"	d
-bCCADropOption	include/Hal8192EPhyReg.h	826;"	d
-bCCADropOption	include/Hal8703BPhyReg.h	852;"	d
-bCCADropOption	include/Hal8723BPhyReg.h	850;"	d
-bCCADropOption	include/Hal8723DPhyReg.h	853;"	d
-bCCADropOption	include/rtw_mp_phy_regdef.h	769;"	d
-bCCADropThres	include/Hal8188EPhyReg.h	816;"	d
-bCCADropThres	include/Hal8188FPhyReg.h	824;"	d
-bCCADropThres	include/Hal8192EPhyReg.h	827;"	d
-bCCADropThres	include/Hal8703BPhyReg.h	853;"	d
-bCCADropThres	include/Hal8723BPhyReg.h	851;"	d
-bCCADropThres	include/Hal8723DPhyReg.h	854;"	d
-bCCADropThres	include/rtw_mp_phy_regdef.h	770;"	d
-bCCAMask	include/Hal8188EPhyReg.h	528;"	d
-bCCAMask	include/Hal8188FPhyReg.h	536;"	d
-bCCAMask	include/Hal8192EPhyReg.h	539;"	d
-bCCAMask	include/Hal8703BPhyReg.h	565;"	d
-bCCAMask	include/Hal8723BPhyReg.h	563;"	d
-bCCAMask	include/Hal8723DPhyReg.h	566;"	d
-bCCAMask	include/rtw_mp_phy_regdef.h	478;"	d
-bCCKAntDiversity	include/Hal8188EPhyReg.h	670;"	d
-bCCKAntDiversity	include/Hal8188FPhyReg.h	678;"	d
-bCCKAntDiversity	include/Hal8192EPhyReg.h	681;"	d
-bCCKAntDiversity	include/Hal8703BPhyReg.h	707;"	d
-bCCKAntDiversity	include/Hal8723BPhyReg.h	705;"	d
-bCCKAntDiversity	include/Hal8723DPhyReg.h	708;"	d
-bCCKAntDiversity	include/Hal8812PhyReg.h	619;"	d
-bCCKAntDiversity	include/Hal8814PhyReg.h	742;"	d
-bCCKAntDiversity	include/rtw_mp_phy_regdef.h	624;"	d
-bCCKAntennaPolarity	include/Hal8188EPhyReg.h	705;"	d
-bCCKAntennaPolarity	include/Hal8188FPhyReg.h	713;"	d
-bCCKAntennaPolarity	include/Hal8192EPhyReg.h	716;"	d
-bCCKAntennaPolarity	include/Hal8703BPhyReg.h	742;"	d
-bCCKAntennaPolarity	include/Hal8723BPhyReg.h	740;"	d
-bCCKAntennaPolarity	include/Hal8723DPhyReg.h	743;"	d
-bCCKAntennaPolarity	include/Hal8812PhyReg.h	654;"	d
-bCCKAntennaPolarity	include/Hal8814PhyReg.h	777;"	d
-bCCKAntennaPolarity	include/rtw_mp_phy_regdef.h	659;"	d
-bCCKBBMode	include/Hal8188EPhyReg.h	663;"	d
-bCCKBBMode	include/Hal8188FPhyReg.h	671;"	d
-bCCKBBMode	include/Hal8192EPhyReg.h	674;"	d
-bCCKBBMode	include/Hal8703BPhyReg.h	700;"	d
-bCCKBBMode	include/Hal8723BPhyReg.h	698;"	d
-bCCKBBMode	include/Hal8723DPhyReg.h	701;"	d
-bCCKBBMode	include/Hal8812PhyReg.h	612;"	d
-bCCKBBMode	include/Hal8814PhyReg.h	735;"	d
-bCCKBBMode	include/rtl8822b_hal.h	164;"	d
-bCCKBBMode	include/rtw_mp_phy_regdef.h	617;"	d
-bCCKBistMode	include/Hal8188EPhyReg.h	682;"	d
-bCCKBistMode	include/Hal8188FPhyReg.h	690;"	d
-bCCKBistMode	include/Hal8192EPhyReg.h	693;"	d
-bCCKBistMode	include/Hal8703BPhyReg.h	719;"	d
-bCCKBistMode	include/Hal8723BPhyReg.h	717;"	d
-bCCKBistMode	include/Hal8723DPhyReg.h	720;"	d
-bCCKBistMode	include/Hal8812PhyReg.h	631;"	d
-bCCKBistMode	include/Hal8814PhyReg.h	754;"	d
-bCCKBistMode	include/rtw_mp_phy_regdef.h	636;"	d
-bCCKCCACount	include/Hal8188EPhyReg.h	680;"	d
-bCCKCCACount	include/Hal8188FPhyReg.h	688;"	d
-bCCKCCACount	include/Hal8192EPhyReg.h	691;"	d
-bCCKCCACount	include/Hal8703BPhyReg.h	717;"	d
-bCCKCCACount	include/Hal8723BPhyReg.h	715;"	d
-bCCKCCACount	include/Hal8723DPhyReg.h	718;"	d
-bCCKCCACount	include/Hal8812PhyReg.h	629;"	d
-bCCKCCACount	include/Hal8814PhyReg.h	752;"	d
-bCCKCCACount	include/rtw_mp_phy_regdef.h	634;"	d
-bCCKCCAMask	include/Hal8188EPhyReg.h	683;"	d
-bCCKCCAMask	include/Hal8188FPhyReg.h	691;"	d
-bCCKCCAMask	include/Hal8192EPhyReg.h	694;"	d
-bCCKCCAMask	include/Hal8703BPhyReg.h	720;"	d
-bCCKCCAMask	include/Hal8723BPhyReg.h	718;"	d
-bCCKCCAMask	include/Hal8723DPhyReg.h	721;"	d
-bCCKCCAMask	include/Hal8812PhyReg.h	632;"	d
-bCCKCCAMask	include/Hal8814PhyReg.h	755;"	d
-bCCKCCAMask	include/rtw_mp_phy_regdef.h	637;"	d
-bCCKCCAMode	include/Hal8188EPhyReg.h	689;"	d
-bCCKCCAMode	include/Hal8188FPhyReg.h	697;"	d
-bCCKCCAMode	include/Hal8192EPhyReg.h	700;"	d
-bCCKCCAMode	include/Hal8703BPhyReg.h	726;"	d
-bCCKCCAMode	include/Hal8723BPhyReg.h	724;"	d
-bCCKCCAMode	include/Hal8723DPhyReg.h	727;"	d
-bCCKCCAMode	include/Hal8812PhyReg.h	638;"	d
-bCCKCCAMode	include/Hal8814PhyReg.h	761;"	d
-bCCKCCAMode	include/rtw_mp_phy_regdef.h	643;"	d
-bCCKCS_ratio	include/Hal8188EPhyReg.h	691;"	d
-bCCKCS_ratio	include/Hal8188FPhyReg.h	699;"	d
-bCCKCS_ratio	include/Hal8192EPhyReg.h	702;"	d
-bCCKCS_ratio	include/Hal8703BPhyReg.h	728;"	d
-bCCKCS_ratio	include/Hal8723BPhyReg.h	726;"	d
-bCCKCS_ratio	include/Hal8723DPhyReg.h	729;"	d
-bCCKCS_ratio	include/Hal8812PhyReg.h	640;"	d
-bCCKCS_ratio	include/Hal8814PhyReg.h	763;"	d
-bCCKCS_ratio	include/rtw_mp_phy_regdef.h	645;"	d
-bCCKCarrierRecovery	include/Hal8188EPhyReg.h	671;"	d
-bCCKCarrierRecovery	include/Hal8188FPhyReg.h	679;"	d
-bCCKCarrierRecovery	include/Hal8192EPhyReg.h	682;"	d
-bCCKCarrierRecovery	include/Hal8703BPhyReg.h	708;"	d
-bCCKCarrierRecovery	include/Hal8723BPhyReg.h	706;"	d
-bCCKCarrierRecovery	include/Hal8723DPhyReg.h	709;"	d
-bCCKCarrierRecovery	include/Hal8812PhyReg.h	620;"	d
-bCCKCarrierRecovery	include/Hal8814PhyReg.h	743;"	d
-bCCKCarrierRecovery	include/rtw_mp_phy_regdef.h	625;"	d
-bCCKChEstStart	include/Hal8188EPhyReg.h	679;"	d
-bCCKChEstStart	include/Hal8188FPhyReg.h	687;"	d
-bCCKChEstStart	include/Hal8192EPhyReg.h	690;"	d
-bCCKChEstStart	include/Hal8703BPhyReg.h	716;"	d
-bCCKChEstStart	include/Hal8723BPhyReg.h	714;"	d
-bCCKChEstStart	include/Hal8723DPhyReg.h	717;"	d
-bCCKChEstStart	include/Hal8812PhyReg.h	628;"	d
-bCCKChEstStart	include/Hal8814PhyReg.h	751;"	d
-bCCKChEstStart	include/rtw_mp_phy_regdef.h	633;"	d
-bCCKCorgBit_sel	include/Hal8188EPhyReg.h	692;"	d
-bCCKCorgBit_sel	include/Hal8188FPhyReg.h	700;"	d
-bCCKCorgBit_sel	include/Hal8192EPhyReg.h	703;"	d
-bCCKCorgBit_sel	include/Hal8703BPhyReg.h	729;"	d
-bCCKCorgBit_sel	include/Hal8723BPhyReg.h	727;"	d
-bCCKCorgBit_sel	include/Hal8723DPhyReg.h	730;"	d
-bCCKCorgBit_sel	include/Hal8812PhyReg.h	641;"	d
-bCCKCorgBit_sel	include/Hal8814PhyReg.h	764;"	d
-bCCKCorgBit_sel	include/rtw_mp_phy_regdef.h	646;"	d
-bCCKDACDebug	include/Hal8188EPhyReg.h	721;"	d
-bCCKDACDebug	include/Hal8188FPhyReg.h	729;"	d
-bCCKDACDebug	include/Hal8192EPhyReg.h	732;"	d
-bCCKDACDebug	include/Hal8703BPhyReg.h	758;"	d
-bCCKDACDebug	include/Hal8723BPhyReg.h	756;"	d
-bCCKDACDebug	include/Hal8723DPhyReg.h	759;"	d
-bCCKDACDebug	include/Hal8812PhyReg.h	670;"	d
-bCCKDACDebug	include/Hal8814PhyReg.h	793;"	d
-bCCKDACDebug	include/rtw_mp_phy_regdef.h	675;"	d
-bCCKDCCancel	include/Hal8188EPhyReg.h	673;"	d
-bCCKDCCancel	include/Hal8188FPhyReg.h	681;"	d
-bCCKDCCancel	include/Hal8192EPhyReg.h	684;"	d
-bCCKDCCancel	include/Hal8703BPhyReg.h	710;"	d
-bCCKDCCancel	include/Hal8723BPhyReg.h	708;"	d
-bCCKDCCancel	include/Hal8723DPhyReg.h	711;"	d
-bCCKDCCancel	include/Hal8812PhyReg.h	622;"	d
-bCCKDCCancel	include/Hal8814PhyReg.h	745;"	d
-bCCKDCCancel	include/rtw_mp_phy_regdef.h	627;"	d
-bCCKDebugPort	include/Hal8188EPhyReg.h	720;"	d
-bCCKDebugPort	include/Hal8188FPhyReg.h	728;"	d
-bCCKDebugPort	include/Hal8192EPhyReg.h	731;"	d
-bCCKDebugPort	include/Hal8703BPhyReg.h	757;"	d
-bCCKDebugPort	include/Hal8723BPhyReg.h	755;"	d
-bCCKDebugPort	include/Hal8723DPhyReg.h	758;"	d
-bCCKDebugPort	include/Hal8812PhyReg.h	669;"	d
-bCCKDebugPort	include/Hal8814PhyReg.h	792;"	d
-bCCKDebugPort	include/rtw_mp_phy_regdef.h	674;"	d
-bCCKDefaultRxPath	include/Hal8188EPhyReg.h	740;"	d
-bCCKDefaultRxPath	include/Hal8188FPhyReg.h	748;"	d
-bCCKDefaultRxPath	include/Hal8192EPhyReg.h	751;"	d
-bCCKDefaultRxPath	include/Hal8703BPhyReg.h	777;"	d
-bCCKDefaultRxPath	include/Hal8723BPhyReg.h	775;"	d
-bCCKDefaultRxPath	include/Hal8723DPhyReg.h	778;"	d
-bCCKDefaultRxPath	include/Hal8812PhyReg.h	689;"	d
-bCCKDefaultRxPath	include/Hal8814PhyReg.h	812;"	d
-bCCKDefaultRxPath	include/rtw_mp_phy_regdef.h	694;"	d
-bCCKEN_Jaguar	include/Hal8812PhyReg.h	52;"	d
-bCCKEN_Jaguar	include/Hal8814PhyReg.h	54;"	d
-bCCKEn	include/Hal8188EPhyReg.h	507;"	d
-bCCKEn	include/Hal8188FPhyReg.h	515;"	d
-bCCKEn	include/Hal8192EPhyReg.h	518;"	d
-bCCKEn	include/Hal8703BPhyReg.h	544;"	d
-bCCKEn	include/Hal8723BPhyReg.h	542;"	d
-bCCKEn	include/Hal8723DPhyReg.h	545;"	d
-bCCKEn	include/Hal8812PhyReg.h	605;"	d
-bCCKEn	include/Hal8814PhyReg.h	728;"	d
-bCCKEn	include/rtl8822b_hal.h	156;"	d
-bCCKEn	include/rtw_mp_phy_regdef.h	459;"	d
-bCCKEqualizer	include/Hal8188EPhyReg.h	676;"	d
-bCCKEqualizer	include/Hal8188FPhyReg.h	684;"	d
-bCCKEqualizer	include/Hal8192EPhyReg.h	687;"	d
-bCCKEqualizer	include/Hal8703BPhyReg.h	713;"	d
-bCCKEqualizer	include/Hal8723BPhyReg.h	711;"	d
-bCCKEqualizer	include/Hal8723DPhyReg.h	714;"	d
-bCCKEqualizer	include/Hal8812PhyReg.h	625;"	d
-bCCKEqualizer	include/Hal8814PhyReg.h	748;"	d
-bCCKEqualizer	include/rtw_mp_phy_regdef.h	630;"	d
-bCCKFACounterFreeze	include/Hal8188EPhyReg.h	738;"	d
-bCCKFACounterFreeze	include/Hal8188FPhyReg.h	746;"	d
-bCCKFACounterFreeze	include/Hal8192EPhyReg.h	749;"	d
-bCCKFACounterFreeze	include/Hal8703BPhyReg.h	775;"	d
-bCCKFACounterFreeze	include/Hal8723BPhyReg.h	773;"	d
-bCCKFACounterFreeze	include/Hal8723DPhyReg.h	776;"	d
-bCCKFACounterFreeze	include/Hal8812PhyReg.h	687;"	d
-bCCKFACounterFreeze	include/Hal8814PhyReg.h	810;"	d
-bCCKFACounterFreeze	include/rtw_mp_phy_regdef.h	692;"	d
-bCCKFalseAlarmEnable	include/Hal8188EPhyReg.h	722;"	d
-bCCKFalseAlarmEnable	include/Hal8188FPhyReg.h	730;"	d
-bCCKFalseAlarmEnable	include/Hal8192EPhyReg.h	733;"	d
-bCCKFalseAlarmEnable	include/Hal8703BPhyReg.h	759;"	d
-bCCKFalseAlarmEnable	include/Hal8723BPhyReg.h	757;"	d
-bCCKFalseAlarmEnable	include/Hal8723DPhyReg.h	760;"	d
-bCCKFalseAlarmEnable	include/Hal8812PhyReg.h	671;"	d
-bCCKFalseAlarmEnable	include/Hal8814PhyReg.h	794;"	d
-bCCKFalseAlarmEnable	include/rtw_mp_phy_regdef.h	676;"	d
-bCCKFalseAlarmRead	include/Hal8188EPhyReg.h	723;"	d
-bCCKFalseAlarmRead	include/Hal8188FPhyReg.h	731;"	d
-bCCKFalseAlarmRead	include/Hal8192EPhyReg.h	734;"	d
-bCCKFalseAlarmRead	include/Hal8703BPhyReg.h	760;"	d
-bCCKFalseAlarmRead	include/Hal8723BPhyReg.h	758;"	d
-bCCKFalseAlarmRead	include/Hal8723DPhyReg.h	761;"	d
-bCCKFalseAlarmRead	include/Hal8812PhyReg.h	672;"	d
-bCCKFalseAlarmRead	include/Hal8814PhyReg.h	795;"	d
-bCCKFalseAlarmRead	include/rtw_mp_phy_regdef.h	677;"	d
-bCCKFalseCS_lim	include/Hal8188EPhyReg.h	690;"	d
-bCCKFalseCS_lim	include/Hal8188FPhyReg.h	698;"	d
-bCCKFalseCS_lim	include/Hal8192EPhyReg.h	701;"	d
-bCCKFalseCS_lim	include/Hal8703BPhyReg.h	727;"	d
-bCCKFalseCS_lim	include/Hal8723BPhyReg.h	725;"	d
-bCCKFalseCS_lim	include/Hal8723DPhyReg.h	728;"	d
-bCCKFalseCS_lim	include/Hal8812PhyReg.h	639;"	d
-bCCKFalseCS_lim	include/Hal8814PhyReg.h	762;"	d
-bCCKFalseCS_lim	include/rtw_mp_phy_regdef.h	644;"	d
-bCCKFastFalseCCA	include/Hal8188EPhyReg.h	678;"	d
-bCCKFastFalseCCA	include/Hal8188FPhyReg.h	686;"	d
-bCCKFastFalseCCA	include/Hal8192EPhyReg.h	689;"	d
-bCCKFastFalseCCA	include/Hal8703BPhyReg.h	715;"	d
-bCCKFastFalseCCA	include/Hal8723BPhyReg.h	713;"	d
-bCCKFastFalseCCA	include/Hal8723DPhyReg.h	716;"	d
-bCCKFastFalseCCA	include/Hal8812PhyReg.h	627;"	d
-bCCKFastFalseCCA	include/Hal8814PhyReg.h	750;"	d
-bCCKFastFalseCCA	include/rtw_mp_phy_regdef.h	632;"	d
-bCCKFixedRxAGC	include/Hal8188EPhyReg.h	703;"	d
-bCCKFixedRxAGC	include/Hal8188FPhyReg.h	711;"	d
-bCCKFixedRxAGC	include/Hal8192EPhyReg.h	714;"	d
-bCCKFixedRxAGC	include/Hal8703BPhyReg.h	740;"	d
-bCCKFixedRxAGC	include/Hal8723BPhyReg.h	738;"	d
-bCCKFixedRxAGC	include/Hal8723DPhyReg.h	741;"	d
-bCCKFixedRxAGC	include/Hal8812PhyReg.h	652;"	d
-bCCKFixedRxAGC	include/Hal8814PhyReg.h	775;"	d
-bCCKFixedRxAGC	include/rtw_mp_phy_regdef.h	657;"	d
-bCCKISICancel	include/Hal8188EPhyReg.h	674;"	d
-bCCKISICancel	include/Hal8188FPhyReg.h	682;"	d
-bCCKISICancel	include/Hal8192EPhyReg.h	685;"	d
-bCCKISICancel	include/Hal8703BPhyReg.h	711;"	d
-bCCKISICancel	include/Hal8723BPhyReg.h	709;"	d
-bCCKISICancel	include/Hal8723DPhyReg.h	712;"	d
-bCCKISICancel	include/Hal8812PhyReg.h	623;"	d
-bCCKISICancel	include/Hal8814PhyReg.h	746;"	d
-bCCKISICancel	include/rtw_mp_phy_regdef.h	628;"	d
-bCCKLNAPolarity	include/Hal8188EPhyReg.h	697;"	d
-bCCKLNAPolarity	include/Hal8188FPhyReg.h	705;"	d
-bCCKLNAPolarity	include/Hal8192EPhyReg.h	708;"	d
-bCCKLNAPolarity	include/Hal8703BPhyReg.h	734;"	d
-bCCKLNAPolarity	include/Hal8723BPhyReg.h	732;"	d
-bCCKLNAPolarity	include/Hal8723DPhyReg.h	735;"	d
-bCCKLNAPolarity	include/Hal8812PhyReg.h	646;"	d
-bCCKLNAPolarity	include/Hal8814PhyReg.h	769;"	d
-bCCKLNAPolarity	include/rtw_mp_phy_regdef.h	651;"	d
-bCCKLengthExt	include/Hal8188EPhyReg.h	495;"	d
-bCCKLengthExt	include/Hal8188FPhyReg.h	503;"	d
-bCCKLengthExt	include/Hal8192EPhyReg.h	504;"	d
-bCCKLengthExt	include/Hal8703BPhyReg.h	531;"	d
-bCCKLengthExt	include/Hal8723BPhyReg.h	530;"	d
-bCCKLengthExt	include/Hal8723DPhyReg.h	532;"	d
-bCCKLengthExt	include/Hal8812PhyReg.h	362;"	d
-bCCKLengthExt	include/Hal8814PhyReg.h	469;"	d
-bCCKLengthExt	include/rtw_mp_phy_regdef.h	447;"	d
-bCCKMatchFilter	include/Hal8188EPhyReg.h	675;"	d
-bCCKMatchFilter	include/Hal8188FPhyReg.h	683;"	d
-bCCKMatchFilter	include/Hal8192EPhyReg.h	686;"	d
-bCCKMatchFilter	include/Hal8703BPhyReg.h	712;"	d
-bCCKMatchFilter	include/Hal8723BPhyReg.h	710;"	d
-bCCKMatchFilter	include/Hal8723DPhyReg.h	713;"	d
-bCCKMatchFilter	include/Hal8812PhyReg.h	624;"	d
-bCCKMatchFilter	include/Hal8814PhyReg.h	747;"	d
-bCCKMatchFilter	include/rtw_mp_phy_regdef.h	629;"	d
-bCCKNewCCA	include/Hal8188EPhyReg.h	694;"	d
-bCCKNewCCA	include/Hal8188FPhyReg.h	702;"	d
-bCCKNewCCA	include/Hal8192EPhyReg.h	705;"	d
-bCCKNewCCA	include/Hal8703BPhyReg.h	731;"	d
-bCCKNewCCA	include/Hal8723BPhyReg.h	729;"	d
-bCCKNewCCA	include/Hal8723DPhyReg.h	732;"	d
-bCCKNewCCA	include/Hal8812PhyReg.h	643;"	d
-bCCKNewCCA	include/Hal8814PhyReg.h	766;"	d
-bCCKNewCCA	include/rtw_mp_phy_regdef.h	648;"	d
-bCCKOptionRxPath	include/Hal8188EPhyReg.h	741;"	d
-bCCKOptionRxPath	include/Hal8188FPhyReg.h	749;"	d
-bCCKOptionRxPath	include/Hal8192EPhyReg.h	752;"	d
-bCCKOptionRxPath	include/Hal8703BPhyReg.h	778;"	d
-bCCKOptionRxPath	include/Hal8723BPhyReg.h	776;"	d
-bCCKOptionRxPath	include/Hal8723DPhyReg.h	779;"	d
-bCCKOptionRxPath	include/Hal8812PhyReg.h	690;"	d
-bCCKOptionRxPath	include/Hal8814PhyReg.h	813;"	d
-bCCKOptionRxPath	include/rtw_mp_phy_regdef.h	695;"	d
-bCCKPD_lim	include/Hal8188EPhyReg.h	693;"	d
-bCCKPD_lim	include/Hal8188FPhyReg.h	701;"	d
-bCCKPD_lim	include/Hal8192EPhyReg.h	704;"	d
-bCCKPD_lim	include/Hal8703BPhyReg.h	730;"	d
-bCCKPD_lim	include/Hal8723BPhyReg.h	728;"	d
-bCCKPD_lim	include/Hal8723DPhyReg.h	731;"	d
-bCCKPD_lim	include/Hal8812PhyReg.h	642;"	d
-bCCKPD_lim	include/Hal8814PhyReg.h	765;"	d
-bCCKPD_lim	include/rtw_mp_phy_regdef.h	647;"	d
-bCCKPHY0_End	include/Hal8188EPhyReg.h	1082;"	d
-bCCKPHY0_End	include/Hal8188FPhyReg.h	1089;"	d
-bCCKPHY0_End	include/Hal8192EPhyReg.h	1096;"	d
-bCCKPHY0_End	include/Hal8703BPhyReg.h	1118;"	d
-bCCKPHY0_End	include/Hal8723BPhyReg.h	1116;"	d
-bCCKPHY0_End	include/Hal8723DPhyReg.h	1119;"	d
-bCCKPHY0_End	include/rtw_mp_phy_regdef.h	1053;"	d
-bCCKPreambleDetect	include/Hal8188EPhyReg.h	677;"	d
-bCCKPreambleDetect	include/Hal8188FPhyReg.h	685;"	d
-bCCKPreambleDetect	include/Hal8192EPhyReg.h	688;"	d
-bCCKPreambleDetect	include/Hal8703BPhyReg.h	714;"	d
-bCCKPreambleDetect	include/Hal8723BPhyReg.h	712;"	d
-bCCKPreambleDetect	include/Hal8723DPhyReg.h	715;"	d
-bCCKPreambleDetect	include/Hal8812PhyReg.h	626;"	d
-bCCKPreambleDetect	include/Hal8814PhyReg.h	749;"	d
-bCCKPreambleDetect	include/rtw_mp_phy_regdef.h	631;"	d
-bCCKRFExtend	include/Hal8188EPhyReg.h	699;"	d
-bCCKRFExtend	include/Hal8188FPhyReg.h	707;"	d
-bCCKRFExtend	include/Hal8192EPhyReg.h	710;"	d
-bCCKRFExtend	include/Hal8703BPhyReg.h	736;"	d
-bCCKRFExtend	include/Hal8723BPhyReg.h	734;"	d
-bCCKRFExtend	include/Hal8723DPhyReg.h	737;"	d
-bCCKRFExtend	include/Hal8812PhyReg.h	648;"	d
-bCCKRFExtend	include/Hal8814PhyReg.h	771;"	d
-bCCKRFExtend	include/rtw_mp_phy_regdef.h	653;"	d
-bCCKRx1stGain	include/Hal8188EPhyReg.h	698;"	d
-bCCKRx1stGain	include/Hal8188FPhyReg.h	706;"	d
-bCCKRx1stGain	include/Hal8192EPhyReg.h	709;"	d
-bCCKRx1stGain	include/Hal8703BPhyReg.h	735;"	d
-bCCKRx1stGain	include/Hal8723BPhyReg.h	733;"	d
-bCCKRx1stGain	include/Hal8723DPhyReg.h	736;"	d
-bCCKRx1stGain	include/Hal8812PhyReg.h	647;"	d
-bCCKRx1stGain	include/Hal8814PhyReg.h	770;"	d
-bCCKRx1stGain	include/rtw_mp_phy_regdef.h	652;"	d
-bCCKRxADCPhase	include/Hal8188EPhyReg.h	685;"	d
-bCCKRxADCPhase	include/Hal8188FPhyReg.h	693;"	d
-bCCKRxADCPhase	include/Hal8192EPhyReg.h	696;"	d
-bCCKRxADCPhase	include/Hal8703BPhyReg.h	722;"	d
-bCCKRxADCPhase	include/Hal8723BPhyReg.h	720;"	d
-bCCKRxADCPhase	include/Hal8723DPhyReg.h	723;"	d
-bCCKRxADCPhase	include/Hal8812PhyReg.h	634;"	d
-bCCKRxADCPhase	include/Hal8814PhyReg.h	757;"	d
-bCCKRxADCPhase	include/rtw_mp_phy_regdef.h	639;"	d
-bCCKRxAGCFormat	include/Hal8188EPhyReg.h	637;"	d
-bCCKRxAGCFormat	include/Hal8188FPhyReg.h	645;"	d
-bCCKRxAGCFormat	include/Hal8192EPhyReg.h	648;"	d
-bCCKRxAGCFormat	include/Hal8703BPhyReg.h	674;"	d
-bCCKRxAGCFormat	include/Hal8723BPhyReg.h	672;"	d
-bCCKRxAGCFormat	include/Hal8723DPhyReg.h	675;"	d
-bCCKRxAGCFormat	include/rtw_mp_phy_regdef.h	591;"	d
-bCCKRxAGCReport	include/Hal8188EPhyReg.h	725;"	d
-bCCKRxAGCReport	include/Hal8188FPhyReg.h	733;"	d
-bCCKRxAGCReport	include/Hal8192EPhyReg.h	736;"	d
-bCCKRxAGCReport	include/Hal8703BPhyReg.h	762;"	d
-bCCKRxAGCReport	include/Hal8723BPhyReg.h	760;"	d
-bCCKRxAGCReport	include/Hal8723DPhyReg.h	763;"	d
-bCCKRxAGCReport	include/Hal8812PhyReg.h	674;"	d
-bCCKRxAGCReport	include/Hal8814PhyReg.h	797;"	d
-bCCKRxAGCReport	include/rtw_mp_phy_regdef.h	679;"	d
-bCCKRxAGCReportType	include/Hal8188EPhyReg.h	707;"	d
-bCCKRxAGCReportType	include/Hal8188FPhyReg.h	715;"	d
-bCCKRxAGCReportType	include/Hal8192EPhyReg.h	718;"	d
-bCCKRxAGCReportType	include/Hal8703BPhyReg.h	744;"	d
-bCCKRxAGCReportType	include/Hal8723BPhyReg.h	742;"	d
-bCCKRxAGCReportType	include/Hal8723DPhyReg.h	745;"	d
-bCCKRxAGCReportType	include/Hal8812PhyReg.h	656;"	d
-bCCKRxAGCReportType	include/Hal8814PhyReg.h	779;"	d
-bCCKRxAGCReportType	include/rtw_mp_phy_regdef.h	661;"	d
-bCCKRxAGCSatCount	include/Hal8188EPhyReg.h	701;"	d
-bCCKRxAGCSatCount	include/Hal8188FPhyReg.h	709;"	d
-bCCKRxAGCSatCount	include/Hal8192EPhyReg.h	712;"	d
-bCCKRxAGCSatCount	include/Hal8703BPhyReg.h	738;"	d
-bCCKRxAGCSatCount	include/Hal8723BPhyReg.h	736;"	d
-bCCKRxAGCSatCount	include/Hal8723DPhyReg.h	739;"	d
-bCCKRxAGCSatCount	include/Hal8812PhyReg.h	650;"	d
-bCCKRxAGCSatCount	include/Hal8814PhyReg.h	773;"	d
-bCCKRxAGCSatCount	include/rtw_mp_phy_regdef.h	655;"	d
-bCCKRxAGCSatLevel	include/Hal8188EPhyReg.h	700;"	d
-bCCKRxAGCSatLevel	include/Hal8188FPhyReg.h	708;"	d
-bCCKRxAGCSatLevel	include/Hal8192EPhyReg.h	711;"	d
-bCCKRxAGCSatLevel	include/Hal8703BPhyReg.h	737;"	d
-bCCKRxAGCSatLevel	include/Hal8723BPhyReg.h	735;"	d
-bCCKRxAGCSatLevel	include/Hal8723DPhyReg.h	738;"	d
-bCCKRxAGCSatLevel	include/Hal8812PhyReg.h	649;"	d
-bCCKRxAGCSatLevel	include/Hal8814PhyReg.h	772;"	d
-bCCKRxAGCSatLevel	include/rtw_mp_phy_regdef.h	654;"	d
-bCCKRxDAGCEn	include/Hal8188EPhyReg.h	708;"	d
-bCCKRxDAGCEn	include/Hal8188FPhyReg.h	716;"	d
-bCCKRxDAGCEn	include/Hal8192EPhyReg.h	719;"	d
-bCCKRxDAGCEn	include/Hal8703BPhyReg.h	745;"	d
-bCCKRxDAGCEn	include/Hal8723BPhyReg.h	743;"	d
-bCCKRxDAGCEn	include/Hal8723DPhyReg.h	746;"	d
-bCCKRxDAGCEn	include/Hal8812PhyReg.h	657;"	d
-bCCKRxDAGCEn	include/Hal8814PhyReg.h	780;"	d
-bCCKRxDAGCEn	include/rtw_mp_phy_regdef.h	662;"	d
-bCCKRxDAGCPeriod	include/Hal8188EPhyReg.h	709;"	d
-bCCKRxDAGCPeriod	include/Hal8188FPhyReg.h	717;"	d
-bCCKRxDAGCPeriod	include/Hal8192EPhyReg.h	720;"	d
-bCCKRxDAGCPeriod	include/Hal8703BPhyReg.h	746;"	d
-bCCKRxDAGCPeriod	include/Hal8723BPhyReg.h	744;"	d
-bCCKRxDAGCPeriod	include/Hal8723DPhyReg.h	747;"	d
-bCCKRxDAGCPeriod	include/Hal8812PhyReg.h	658;"	d
-bCCKRxDAGCPeriod	include/Hal8814PhyReg.h	781;"	d
-bCCKRxDAGCPeriod	include/rtw_mp_phy_regdef.h	663;"	d
-bCCKRxDAGCSatLevel	include/Hal8188EPhyReg.h	710;"	d
-bCCKRxDAGCSatLevel	include/Hal8188FPhyReg.h	718;"	d
-bCCKRxDAGCSatLevel	include/Hal8192EPhyReg.h	721;"	d
-bCCKRxDAGCSatLevel	include/Hal8703BPhyReg.h	747;"	d
-bCCKRxDAGCSatLevel	include/Hal8723BPhyReg.h	745;"	d
-bCCKRxDAGCSatLevel	include/Hal8723DPhyReg.h	748;"	d
-bCCKRxDAGCSatLevel	include/Hal8812PhyReg.h	659;"	d
-bCCKRxDAGCSatLevel	include/Hal8814PhyReg.h	782;"	d
-bCCKRxDAGCSatLevel	include/rtw_mp_phy_regdef.h	664;"	d
-bCCKRxDCOffset	include/Hal8188EPhyReg.h	688;"	d
-bCCKRxDCOffset	include/Hal8188FPhyReg.h	696;"	d
-bCCKRxDCOffset	include/Hal8192EPhyReg.h	699;"	d
-bCCKRxDCOffset	include/Hal8703BPhyReg.h	725;"	d
-bCCKRxDCOffset	include/Hal8723BPhyReg.h	723;"	d
-bCCKRxDCOffset	include/Hal8723DPhyReg.h	726;"	d
-bCCKRxDCOffset	include/Hal8812PhyReg.h	637;"	d
-bCCKRxDCOffset	include/Hal8814PhyReg.h	760;"	d
-bCCKRxDCOffset	include/rtw_mp_phy_regdef.h	642;"	d
-bCCKRxFACounterLower	include/Hal8188EPhyReg.h	733;"	d
-bCCKRxFACounterLower	include/Hal8188FPhyReg.h	741;"	d
-bCCKRxFACounterLower	include/Hal8192EPhyReg.h	744;"	d
-bCCKRxFACounterLower	include/Hal8703BPhyReg.h	770;"	d
-bCCKRxFACounterLower	include/Hal8723BPhyReg.h	768;"	d
-bCCKRxFACounterLower	include/Hal8723DPhyReg.h	771;"	d
-bCCKRxFACounterLower	include/Hal8812PhyReg.h	682;"	d
-bCCKRxFACounterLower	include/Hal8814PhyReg.h	805;"	d
-bCCKRxFACounterLower	include/rtw_mp_phy_regdef.h	687;"	d
-bCCKRxFACounterUpper	include/Hal8188EPhyReg.h	734;"	d
-bCCKRxFACounterUpper	include/Hal8188FPhyReg.h	742;"	d
-bCCKRxFACounterUpper	include/Hal8192EPhyReg.h	745;"	d
-bCCKRxFACounterUpper	include/Hal8703BPhyReg.h	771;"	d
-bCCKRxFACounterUpper	include/Hal8723BPhyReg.h	769;"	d
-bCCKRxFACounterUpper	include/Hal8723DPhyReg.h	772;"	d
-bCCKRxFACounterUpper	include/Hal8812PhyReg.h	683;"	d
-bCCKRxFACounterUpper	include/Hal8814PhyReg.h	806;"	d
-bCCKRxFACounterUpper	include/rtw_mp_phy_regdef.h	688;"	d
-bCCKRxFalseAlarmEnable	include/Hal8188EPhyReg.h	737;"	d
-bCCKRxFalseAlarmEnable	include/Hal8188FPhyReg.h	745;"	d
-bCCKRxFalseAlarmEnable	include/Hal8192EPhyReg.h	748;"	d
-bCCKRxFalseAlarmEnable	include/Hal8703BPhyReg.h	774;"	d
-bCCKRxFalseAlarmEnable	include/Hal8723BPhyReg.h	772;"	d
-bCCKRxFalseAlarmEnable	include/Hal8723DPhyReg.h	775;"	d
-bCCKRxFalseAlarmEnable	include/Hal8812PhyReg.h	686;"	d
-bCCKRxFalseAlarmEnable	include/Hal8814PhyReg.h	809;"	d
-bCCKRxFalseAlarmEnable	include/rtw_mp_phy_regdef.h	691;"	d
-bCCKRxHPAGCFinal	include/Hal8188EPhyReg.h	736;"	d
-bCCKRxHPAGCFinal	include/Hal8188FPhyReg.h	744;"	d
-bCCKRxHPAGCFinal	include/Hal8192EPhyReg.h	747;"	d
-bCCKRxHPAGCFinal	include/Hal8703BPhyReg.h	773;"	d
-bCCKRxHPAGCFinal	include/Hal8723BPhyReg.h	771;"	d
-bCCKRxHPAGCFinal	include/Hal8723DPhyReg.h	774;"	d
-bCCKRxHPAGCFinal	include/Hal8812PhyReg.h	685;"	d
-bCCKRxHPAGCFinal	include/Hal8814PhyReg.h	808;"	d
-bCCKRxHPAGCFinal	include/rtw_mp_phy_regdef.h	690;"	d
-bCCKRxHPAGCStart	include/Hal8188EPhyReg.h	735;"	d
-bCCKRxHPAGCStart	include/Hal8188FPhyReg.h	743;"	d
-bCCKRxHPAGCStart	include/Hal8192EPhyReg.h	746;"	d
-bCCKRxHPAGCStart	include/Hal8703BPhyReg.h	772;"	d
-bCCKRxHPAGCStart	include/Hal8723BPhyReg.h	770;"	d
-bCCKRxHPAGCStart	include/Hal8723DPhyReg.h	773;"	d
-bCCKRxHPAGCStart	include/Hal8812PhyReg.h	684;"	d
-bCCKRxHPAGCStart	include/Hal8814PhyReg.h	807;"	d
-bCCKRxHPAGCStart	include/rtw_mp_phy_regdef.h	689;"	d
-bCCKRxHPofIG	include/Hal8188EPhyReg.h	695;"	d
-bCCKRxHPofIG	include/Hal8188FPhyReg.h	703;"	d
-bCCKRxHPofIG	include/Hal8192EPhyReg.h	706;"	d
-bCCKRxHPofIG	include/Hal8703BPhyReg.h	732;"	d
-bCCKRxHPofIG	include/Hal8723BPhyReg.h	730;"	d
-bCCKRxHPofIG	include/Hal8723DPhyReg.h	733;"	d
-bCCKRxHPofIG	include/Hal8812PhyReg.h	644;"	d
-bCCKRxHPofIG	include/Hal8814PhyReg.h	767;"	d
-bCCKRxHPofIG	include/rtw_mp_phy_regdef.h	649;"	d
-bCCKRxIG	include/Hal8188EPhyReg.h	696;"	d
-bCCKRxIG	include/Hal8188FPhyReg.h	704;"	d
-bCCKRxIG	include/Hal8192EPhyReg.h	707;"	d
-bCCKRxIG	include/Hal8703BPhyReg.h	733;"	d
-bCCKRxIG	include/Hal8723BPhyReg.h	731;"	d
-bCCKRxIG	include/Hal8723DPhyReg.h	734;"	d
-bCCKRxIG	include/Hal8812PhyReg.h	645;"	d
-bCCKRxIG	include/Hal8814PhyReg.h	768;"	d
-bCCKRxIG	include/rtw_mp_phy_regdef.h	650;"	d
-bCCKRxPhase	include/Hal8188EPhyReg.h	582;"	d
-bCCKRxPhase	include/Hal8188FPhyReg.h	590;"	d
-bCCKRxPhase	include/Hal8192EPhyReg.h	593;"	d
-bCCKRxPhase	include/Hal8703BPhyReg.h	619;"	d
-bCCKRxPhase	include/Hal8723BPhyReg.h	617;"	d
-bCCKRxPhase	include/Hal8723DPhyReg.h	620;"	d
-bCCKRxPhase	include/rtw_mp_phy_regdef.h	532;"	d
-bCCKRxPowerSaving	include/Hal8188EPhyReg.h	665;"	d
-bCCKRxPowerSaving	include/Hal8188FPhyReg.h	673;"	d
-bCCKRxPowerSaving	include/Hal8192EPhyReg.h	676;"	d
-bCCKRxPowerSaving	include/Hal8703BPhyReg.h	702;"	d
-bCCKRxPowerSaving	include/Hal8723BPhyReg.h	700;"	d
-bCCKRxPowerSaving	include/Hal8723DPhyReg.h	703;"	d
-bCCKRxPowerSaving	include/Hal8812PhyReg.h	614;"	d
-bCCKRxPowerSaving	include/Hal8814PhyReg.h	737;"	d
-bCCKRxPowerSaving	include/rtw_mp_phy_regdef.h	619;"	d
-bCCKRxRFSettle	include/Hal8188EPhyReg.h	702;"	d
-bCCKRxRFSettle	include/Hal8188FPhyReg.h	710;"	d
-bCCKRxRFSettle	include/Hal8192EPhyReg.h	713;"	d
-bCCKRxRFSettle	include/Hal8703BPhyReg.h	739;"	d
-bCCKRxRFSettle	include/Hal8723BPhyReg.h	737;"	d
-bCCKRxRFSettle	include/Hal8723DPhyReg.h	740;"	d
-bCCKRxRFSettle	include/Hal8812PhyReg.h	651;"	d
-bCCKRxRFSettle	include/Hal8814PhyReg.h	774;"	d
-bCCKRxRFSettle	include/rtw_mp_phy_regdef.h	656;"	d
-bCCKRxReport_AntSel	include/Hal8188EPhyReg.h	726;"	d
-bCCKRxReport_AntSel	include/Hal8188FPhyReg.h	734;"	d
-bCCKRxReport_AntSel	include/Hal8192EPhyReg.h	737;"	d
-bCCKRxReport_AntSel	include/Hal8703BPhyReg.h	763;"	d
-bCCKRxReport_AntSel	include/Hal8723BPhyReg.h	761;"	d
-bCCKRxReport_AntSel	include/Hal8723DPhyReg.h	764;"	d
-bCCKRxReport_AntSel	include/Hal8812PhyReg.h	675;"	d
-bCCKRxReport_AntSel	include/Hal8814PhyReg.h	798;"	d
-bCCKRxReport_AntSel	include/rtw_mp_phy_regdef.h	680;"	d
-bCCKRxReport_Lockedbit	include/Hal8188EPhyReg.h	730;"	d
-bCCKRxReport_Lockedbit	include/Hal8188FPhyReg.h	738;"	d
-bCCKRxReport_Lockedbit	include/Hal8192EPhyReg.h	741;"	d
-bCCKRxReport_Lockedbit	include/Hal8703BPhyReg.h	767;"	d
-bCCKRxReport_Lockedbit	include/Hal8723BPhyReg.h	765;"	d
-bCCKRxReport_Lockedbit	include/Hal8723DPhyReg.h	768;"	d
-bCCKRxReport_Lockedbit	include/Hal8812PhyReg.h	679;"	d
-bCCKRxReport_Lockedbit	include/Hal8814PhyReg.h	802;"	d
-bCCKRxReport_Lockedbit	include/rtw_mp_phy_regdef.h	684;"	d
-bCCKRxReport_MFOff	include/Hal8188EPhyReg.h	727;"	d
-bCCKRxReport_MFOff	include/Hal8188FPhyReg.h	735;"	d
-bCCKRxReport_MFOff	include/Hal8192EPhyReg.h	738;"	d
-bCCKRxReport_MFOff	include/Hal8703BPhyReg.h	764;"	d
-bCCKRxReport_MFOff	include/Hal8723BPhyReg.h	762;"	d
-bCCKRxReport_MFOff	include/Hal8723DPhyReg.h	765;"	d
-bCCKRxReport_MFOff	include/Hal8812PhyReg.h	676;"	d
-bCCKRxReport_MFOff	include/Hal8814PhyReg.h	799;"	d
-bCCKRxReport_MFOff	include/rtw_mp_phy_regdef.h	681;"	d
-bCCKRxReport_Pktloss	include/Hal8188EPhyReg.h	729;"	d
-bCCKRxReport_Pktloss	include/Hal8188FPhyReg.h	737;"	d
-bCCKRxReport_Pktloss	include/Hal8192EPhyReg.h	740;"	d
-bCCKRxReport_Pktloss	include/Hal8703BPhyReg.h	766;"	d
-bCCKRxReport_Pktloss	include/Hal8723BPhyReg.h	764;"	d
-bCCKRxReport_Pktloss	include/Hal8723DPhyReg.h	767;"	d
-bCCKRxReport_Pktloss	include/Hal8812PhyReg.h	678;"	d
-bCCKRxReport_Pktloss	include/Hal8814PhyReg.h	801;"	d
-bCCKRxReport_Pktloss	include/rtw_mp_phy_regdef.h	683;"	d
-bCCKRxReport_RateError	include/Hal8188EPhyReg.h	731;"	d
-bCCKRxReport_RateError	include/Hal8188FPhyReg.h	739;"	d
-bCCKRxReport_RateError	include/Hal8192EPhyReg.h	742;"	d
-bCCKRxReport_RateError	include/Hal8703BPhyReg.h	768;"	d
-bCCKRxReport_RateError	include/Hal8723BPhyReg.h	766;"	d
-bCCKRxReport_RateError	include/Hal8723DPhyReg.h	769;"	d
-bCCKRxReport_RateError	include/Hal8812PhyReg.h	680;"	d
-bCCKRxReport_RateError	include/Hal8814PhyReg.h	803;"	d
-bCCKRxReport_RateError	include/rtw_mp_phy_regdef.h	685;"	d
-bCCKRxReport_RxRate	include/Hal8188EPhyReg.h	732;"	d
-bCCKRxReport_RxRate	include/Hal8188FPhyReg.h	740;"	d
-bCCKRxReport_RxRate	include/Hal8192EPhyReg.h	743;"	d
-bCCKRxReport_RxRate	include/Hal8703BPhyReg.h	769;"	d
-bCCKRxReport_RxRate	include/Hal8723BPhyReg.h	767;"	d
-bCCKRxReport_RxRate	include/Hal8723DPhyReg.h	770;"	d
-bCCKRxReport_RxRate	include/Hal8812PhyReg.h	681;"	d
-bCCKRxReport_RxRate	include/Hal8814PhyReg.h	804;"	d
-bCCKRxReport_RxRate	include/rtw_mp_phy_regdef.h	686;"	d
-bCCKRxRxReport_SQLoss	include/Hal8188EPhyReg.h	728;"	d
-bCCKRxRxReport_SQLoss	include/Hal8188FPhyReg.h	736;"	d
-bCCKRxRxReport_SQLoss	include/Hal8192EPhyReg.h	739;"	d
-bCCKRxRxReport_SQLoss	include/Hal8703BPhyReg.h	765;"	d
-bCCKRxRxReport_SQLoss	include/Hal8723BPhyReg.h	763;"	d
-bCCKRxRxReport_SQLoss	include/Hal8723DPhyReg.h	766;"	d
-bCCKRxRxReport_SQLoss	include/Hal8812PhyReg.h	677;"	d
-bCCKRxRxReport_SQLoss	include/Hal8814PhyReg.h	800;"	d
-bCCKRxRxReport_SQLoss	include/rtw_mp_phy_regdef.h	682;"	d
-bCCKSampleRate	include/Hal8188EPhyReg.h	591;"	d
-bCCKSampleRate	include/Hal8188FPhyReg.h	599;"	d
-bCCKSampleRate	include/Hal8192EPhyReg.h	602;"	d
-bCCKSampleRate	include/Hal8703BPhyReg.h	628;"	d
-bCCKSampleRate	include/Hal8723BPhyReg.h	626;"	d
-bCCKSampleRate	include/Hal8723DPhyReg.h	629;"	d
-bCCKSampleRate	include/rtw_mp_phy_regdef.h	545;"	d
-bCCKScramble	include/Hal8188EPhyReg.h	669;"	d
-bCCKScramble	include/Hal8188FPhyReg.h	677;"	d
-bCCKScramble	include/Hal8192EPhyReg.h	680;"	d
-bCCKScramble	include/Hal8703BPhyReg.h	706;"	d
-bCCKScramble	include/Hal8723BPhyReg.h	704;"	d
-bCCKScramble	include/Hal8723DPhyReg.h	707;"	d
-bCCKScramble	include/Hal8812PhyReg.h	618;"	d
-bCCKScramble	include/Hal8814PhyReg.h	741;"	d
-bCCKScramble	include/rtl8822b_hal.h	166;"	d
-bCCKScramble	include/rtw_mp_phy_regdef.h	623;"	d
-bCCKSideBand	include/Hal8188EPhyReg.h	667;"	d
-bCCKSideBand	include/Hal8188FPhyReg.h	675;"	d
-bCCKSideBand	include/Hal8192EPhyReg.h	678;"	d
-bCCKSideBand	include/Hal8703BPhyReg.h	704;"	d
-bCCKSideBand	include/Hal8723BPhyReg.h	702;"	d
-bCCKSideBand	include/Hal8723DPhyReg.h	705;"	d
-bCCKSideBand	include/Hal8812PhyReg.h	616;"	d
-bCCKSideBand	include/Hal8814PhyReg.h	739;"	d
-bCCKSideBand	include/rtw_mp_phy_regdef.h	621;"	d
-bCCKTRSSI	include/Hal8188EPhyReg.h	724;"	d
-bCCKTRSSI	include/Hal8188FPhyReg.h	732;"	d
-bCCKTRSSI	include/Hal8192EPhyReg.h	735;"	d
-bCCKTRSSI	include/Hal8703BPhyReg.h	761;"	d
-bCCKTRSSI	include/Hal8723BPhyReg.h	759;"	d
-bCCKTRSSI	include/Hal8723DPhyReg.h	762;"	d
-bCCKTRSSI	include/Hal8812PhyReg.h	673;"	d
-bCCKTRSSI	include/Hal8814PhyReg.h	796;"	d
-bCCKTRSSI	include/rtw_mp_phy_regdef.h	678;"	d
-bCCKTimingRecovery	include/Hal8188EPhyReg.h	711;"	d
-bCCKTimingRecovery	include/Hal8188FPhyReg.h	719;"	d
-bCCKTimingRecovery	include/Hal8192EPhyReg.h	722;"	d
-bCCKTimingRecovery	include/Hal8703BPhyReg.h	748;"	d
-bCCKTimingRecovery	include/Hal8723BPhyReg.h	746;"	d
-bCCKTimingRecovery	include/Hal8723DPhyReg.h	749;"	d
-bCCKTimingRecovery	include/Hal8812PhyReg.h	660;"	d
-bCCKTimingRecovery	include/Hal8814PhyReg.h	783;"	d
-bCCKTimingRecovery	include/rtw_mp_phy_regdef.h	665;"	d
-bCCKTxC0	include/Hal8188EPhyReg.h	712;"	d
-bCCKTxC0	include/Hal8188FPhyReg.h	720;"	d
-bCCKTxC0	include/Hal8192EPhyReg.h	723;"	d
-bCCKTxC0	include/Hal8703BPhyReg.h	749;"	d
-bCCKTxC0	include/Hal8723BPhyReg.h	747;"	d
-bCCKTxC0	include/Hal8723DPhyReg.h	750;"	d
-bCCKTxC0	include/Hal8812PhyReg.h	661;"	d
-bCCKTxC0	include/Hal8814PhyReg.h	784;"	d
-bCCKTxC0	include/rtw_mp_phy_regdef.h	666;"	d
-bCCKTxC1	include/Hal8188EPhyReg.h	713;"	d
-bCCKTxC1	include/Hal8188FPhyReg.h	721;"	d
-bCCKTxC1	include/Hal8192EPhyReg.h	724;"	d
-bCCKTxC1	include/Hal8703BPhyReg.h	750;"	d
-bCCKTxC1	include/Hal8723BPhyReg.h	748;"	d
-bCCKTxC1	include/Hal8723DPhyReg.h	751;"	d
-bCCKTxC1	include/Hal8812PhyReg.h	662;"	d
-bCCKTxC1	include/Hal8814PhyReg.h	785;"	d
-bCCKTxC1	include/rtw_mp_phy_regdef.h	667;"	d
-bCCKTxC2	include/Hal8188EPhyReg.h	714;"	d
-bCCKTxC2	include/Hal8188FPhyReg.h	722;"	d
-bCCKTxC2	include/Hal8192EPhyReg.h	725;"	d
-bCCKTxC2	include/Hal8703BPhyReg.h	751;"	d
-bCCKTxC2	include/Hal8723BPhyReg.h	749;"	d
-bCCKTxC2	include/Hal8723DPhyReg.h	752;"	d
-bCCKTxC2	include/Hal8812PhyReg.h	663;"	d
-bCCKTxC2	include/Hal8814PhyReg.h	786;"	d
-bCCKTxC2	include/rtw_mp_phy_regdef.h	668;"	d
-bCCKTxC3	include/Hal8188EPhyReg.h	715;"	d
-bCCKTxC3	include/Hal8188FPhyReg.h	723;"	d
-bCCKTxC3	include/Hal8192EPhyReg.h	726;"	d
-bCCKTxC3	include/Hal8703BPhyReg.h	752;"	d
-bCCKTxC3	include/Hal8723BPhyReg.h	750;"	d
-bCCKTxC3	include/Hal8723DPhyReg.h	753;"	d
-bCCKTxC3	include/Hal8812PhyReg.h	664;"	d
-bCCKTxC3	include/Hal8814PhyReg.h	787;"	d
-bCCKTxC3	include/rtw_mp_phy_regdef.h	669;"	d
-bCCKTxC4	include/Hal8188EPhyReg.h	716;"	d
-bCCKTxC4	include/Hal8188FPhyReg.h	724;"	d
-bCCKTxC4	include/Hal8192EPhyReg.h	727;"	d
-bCCKTxC4	include/Hal8703BPhyReg.h	753;"	d
-bCCKTxC4	include/Hal8723BPhyReg.h	751;"	d
-bCCKTxC4	include/Hal8723DPhyReg.h	754;"	d
-bCCKTxC4	include/Hal8812PhyReg.h	665;"	d
-bCCKTxC4	include/Hal8814PhyReg.h	788;"	d
-bCCKTxC4	include/rtw_mp_phy_regdef.h	670;"	d
-bCCKTxC5	include/Hal8188EPhyReg.h	717;"	d
-bCCKTxC5	include/Hal8188FPhyReg.h	725;"	d
-bCCKTxC5	include/Hal8192EPhyReg.h	728;"	d
-bCCKTxC5	include/Hal8703BPhyReg.h	754;"	d
-bCCKTxC5	include/Hal8723BPhyReg.h	752;"	d
-bCCKTxC5	include/Hal8723DPhyReg.h	755;"	d
-bCCKTxC5	include/Hal8812PhyReg.h	666;"	d
-bCCKTxC5	include/Hal8814PhyReg.h	789;"	d
-bCCKTxC5	include/rtw_mp_phy_regdef.h	671;"	d
-bCCKTxC6	include/Hal8188EPhyReg.h	718;"	d
-bCCKTxC6	include/Hal8188FPhyReg.h	726;"	d
-bCCKTxC6	include/Hal8192EPhyReg.h	729;"	d
-bCCKTxC6	include/Hal8703BPhyReg.h	755;"	d
-bCCKTxC6	include/Hal8723BPhyReg.h	753;"	d
-bCCKTxC6	include/Hal8723DPhyReg.h	756;"	d
-bCCKTxC6	include/Hal8812PhyReg.h	667;"	d
-bCCKTxC6	include/Hal8814PhyReg.h	790;"	d
-bCCKTxC6	include/rtw_mp_phy_regdef.h	672;"	d
-bCCKTxC7	include/Hal8188EPhyReg.h	719;"	d
-bCCKTxC7	include/Hal8188FPhyReg.h	727;"	d
-bCCKTxC7	include/Hal8192EPhyReg.h	730;"	d
-bCCKTxC7	include/Hal8703BPhyReg.h	756;"	d
-bCCKTxC7	include/Hal8723BPhyReg.h	754;"	d
-bCCKTxC7	include/Hal8723DPhyReg.h	757;"	d
-bCCKTxC7	include/Hal8812PhyReg.h	668;"	d
-bCCKTxC7	include/Hal8814PhyReg.h	791;"	d
-bCCKTxC7	include/rtw_mp_phy_regdef.h	673;"	d
-bCCKTxCRC16	include/Hal8188EPhyReg.h	497;"	d
-bCCKTxCRC16	include/Hal8188FPhyReg.h	505;"	d
-bCCKTxCRC16	include/Hal8192EPhyReg.h	506;"	d
-bCCKTxCRC16	include/Hal8703BPhyReg.h	533;"	d
-bCCKTxCRC16	include/Hal8723BPhyReg.h	532;"	d
-bCCKTxCRC16	include/Hal8723DPhyReg.h	534;"	d
-bCCKTxCRC16	include/Hal8812PhyReg.h	364;"	d
-bCCKTxCRC16	include/Hal8814PhyReg.h	471;"	d
-bCCKTxCRC16	include/rtw_mp_phy_regdef.h	449;"	d
-bCCKTxDACPhase	include/Hal8188EPhyReg.h	684;"	d
-bCCKTxDACPhase	include/Hal8188FPhyReg.h	692;"	d
-bCCKTxDACPhase	include/Hal8192EPhyReg.h	695;"	d
-bCCKTxDACPhase	include/Hal8703BPhyReg.h	721;"	d
-bCCKTxDACPhase	include/Hal8723BPhyReg.h	719;"	d
-bCCKTxDACPhase	include/Hal8723DPhyReg.h	722;"	d
-bCCKTxDACPhase	include/Hal8812PhyReg.h	633;"	d
-bCCKTxDACPhase	include/Hal8814PhyReg.h	756;"	d
-bCCKTxDACPhase	include/rtw_mp_phy_regdef.h	638;"	d
-bCCKTxDCOffset	include/Hal8188EPhyReg.h	687;"	d
-bCCKTxDCOffset	include/Hal8188FPhyReg.h	695;"	d
-bCCKTxDCOffset	include/Hal8192EPhyReg.h	698;"	d
-bCCKTxDCOffset	include/Hal8703BPhyReg.h	724;"	d
-bCCKTxDCOffset	include/Hal8723BPhyReg.h	722;"	d
-bCCKTxDCOffset	include/Hal8723DPhyReg.h	725;"	d
-bCCKTxDCOffset	include/Hal8812PhyReg.h	636;"	d
-bCCKTxDCOffset	include/Hal8814PhyReg.h	759;"	d
-bCCKTxDCOffset	include/rtw_mp_phy_regdef.h	641;"	d
-bCCKTxFilterType	include/Hal8188EPhyReg.h	706;"	d
-bCCKTxFilterType	include/Hal8188FPhyReg.h	714;"	d
-bCCKTxFilterType	include/Hal8192EPhyReg.h	717;"	d
-bCCKTxFilterType	include/Hal8703BPhyReg.h	743;"	d
-bCCKTxFilterType	include/Hal8723BPhyReg.h	741;"	d
-bCCKTxFilterType	include/Hal8723DPhyReg.h	744;"	d
-bCCKTxFilterType	include/Hal8812PhyReg.h	655;"	d
-bCCKTxFilterType	include/Hal8814PhyReg.h	778;"	d
-bCCKTxFilterType	include/rtw_mp_phy_regdef.h	660;"	d
-bCCKTxLength	include/Hal8188EPhyReg.h	496;"	d
-bCCKTxLength	include/Hal8188FPhyReg.h	504;"	d
-bCCKTxLength	include/Hal8192EPhyReg.h	505;"	d
-bCCKTxLength	include/Hal8703BPhyReg.h	532;"	d
-bCCKTxLength	include/Hal8723BPhyReg.h	531;"	d
-bCCKTxLength	include/Hal8723DPhyReg.h	533;"	d
-bCCKTxLength	include/Hal8812PhyReg.h	363;"	d
-bCCKTxLength	include/Hal8814PhyReg.h	470;"	d
-bCCKTxLength	include/rtw_mp_phy_regdef.h	448;"	d
-bCCKTxOn	include/Hal8188EPhyReg.h	651;"	d
-bCCKTxOn	include/Hal8188FPhyReg.h	659;"	d
-bCCKTxOn	include/Hal8192EPhyReg.h	662;"	d
-bCCKTxOn	include/Hal8703BPhyReg.h	688;"	d
-bCCKTxOn	include/Hal8723BPhyReg.h	686;"	d
-bCCKTxOn	include/Hal8723DPhyReg.h	689;"	d
-bCCKTxOn	include/rtw_mp_phy_regdef.h	605;"	d
-bCCKTxPathSel	include/Hal8188EPhyReg.h	739;"	d
-bCCKTxPathSel	include/Hal8188FPhyReg.h	747;"	d
-bCCKTxPathSel	include/Hal8192EPhyReg.h	750;"	d
-bCCKTxPathSel	include/Hal8703BPhyReg.h	776;"	d
-bCCKTxPathSel	include/Hal8723BPhyReg.h	774;"	d
-bCCKTxPathSel	include/Hal8723DPhyReg.h	777;"	d
-bCCKTxPathSel	include/Hal8812PhyReg.h	688;"	d
-bCCKTxPathSel	include/Hal8814PhyReg.h	811;"	d
-bCCKTxPathSel	include/rtw_mp_phy_regdef.h	693;"	d
-bCCKTxPowerSaving	include/Hal8188EPhyReg.h	664;"	d
-bCCKTxPowerSaving	include/Hal8188FPhyReg.h	672;"	d
-bCCKTxPowerSaving	include/Hal8192EPhyReg.h	675;"	d
-bCCKTxPowerSaving	include/Hal8703BPhyReg.h	701;"	d
-bCCKTxPowerSaving	include/Hal8723BPhyReg.h	699;"	d
-bCCKTxPowerSaving	include/Hal8723DPhyReg.h	702;"	d
-bCCKTxPowerSaving	include/Hal8812PhyReg.h	613;"	d
-bCCKTxPowerSaving	include/Hal8814PhyReg.h	736;"	d
-bCCKTxPowerSaving	include/rtw_mp_phy_regdef.h	618;"	d
-bCCKTxPreamble	include/Hal8188EPhyReg.h	491;"	d
-bCCKTxPreamble	include/Hal8188FPhyReg.h	499;"	d
-bCCKTxPreamble	include/Hal8192EPhyReg.h	500;"	d
-bCCKTxPreamble	include/Hal8703BPhyReg.h	527;"	d
-bCCKTxPreamble	include/Hal8723BPhyReg.h	526;"	d
-bCCKTxPreamble	include/Hal8723DPhyReg.h	528;"	d
-bCCKTxPreamble	include/Hal8812PhyReg.h	358;"	d
-bCCKTxPreamble	include/Hal8814PhyReg.h	465;"	d
-bCCKTxPreamble	include/rtw_mp_phy_regdef.h	443;"	d
-bCCKTxRate	include/Hal8188EPhyReg.h	672;"	d
-bCCKTxRate	include/Hal8188FPhyReg.h	680;"	d
-bCCKTxRate	include/Hal8192EPhyReg.h	683;"	d
-bCCKTxRate	include/Hal8703BPhyReg.h	709;"	d
-bCCKTxRate	include/Hal8723BPhyReg.h	707;"	d
-bCCKTxRate	include/Hal8723DPhyReg.h	710;"	d
-bCCKTxRate	include/Hal8812PhyReg.h	621;"	d
-bCCKTxRate	include/Hal8814PhyReg.h	744;"	d
-bCCKTxRate	include/rtl8822b_hal.h	167;"	d
-bCCKTxRate	include/rtw_mp_phy_regdef.h	626;"	d
-bCCKTxSC	include/Hal8188EPhyReg.h	506;"	d
-bCCKTxSC	include/Hal8188FPhyReg.h	514;"	d
-bCCKTxSC	include/Hal8192EPhyReg.h	517;"	d
-bCCKTxSC	include/Hal8703BPhyReg.h	543;"	d
-bCCKTxSC	include/Hal8723BPhyReg.h	541;"	d
-bCCKTxSC	include/Hal8723DPhyReg.h	544;"	d
-bCCKTxSC	include/Hal8812PhyReg.h	604;"	d
-bCCKTxSC	include/Hal8814PhyReg.h	727;"	d
-bCCKTxSC	include/rtw_mp_phy_regdef.h	458;"	d
-bCCKTxSFD	include/Hal8188EPhyReg.h	492;"	d
-bCCKTxSFD	include/Hal8188FPhyReg.h	500;"	d
-bCCKTxSFD	include/Hal8192EPhyReg.h	501;"	d
-bCCKTxSFD	include/Hal8703BPhyReg.h	528;"	d
-bCCKTxSFD	include/Hal8723BPhyReg.h	527;"	d
-bCCKTxSFD	include/Hal8723DPhyReg.h	529;"	d
-bCCKTxSFD	include/Hal8812PhyReg.h	359;"	d
-bCCKTxSFD	include/Hal8814PhyReg.h	466;"	d
-bCCKTxSFD	include/rtw_mp_phy_regdef.h	444;"	d
-bCCKTxSIG	include/Hal8188EPhyReg.h	493;"	d
-bCCKTxSIG	include/Hal8188FPhyReg.h	501;"	d
-bCCKTxSIG	include/Hal8192EPhyReg.h	502;"	d
-bCCKTxSIG	include/Hal8703BPhyReg.h	529;"	d
-bCCKTxSIG	include/Hal8723BPhyReg.h	528;"	d
-bCCKTxSIG	include/Hal8723DPhyReg.h	530;"	d
-bCCKTxSIG	include/Hal8812PhyReg.h	360;"	d
-bCCKTxSIG	include/Hal8814PhyReg.h	467;"	d
-bCCKTxSIG	include/rtw_mp_phy_regdef.h	445;"	d
-bCCKTxService	include/Hal8188EPhyReg.h	494;"	d
-bCCKTxService	include/Hal8188FPhyReg.h	502;"	d
-bCCKTxService	include/Hal8192EPhyReg.h	503;"	d
-bCCKTxService	include/Hal8703BPhyReg.h	530;"	d
-bCCKTxService	include/Hal8723BPhyReg.h	529;"	d
-bCCKTxService	include/Hal8723DPhyReg.h	531;"	d
-bCCKTxService	include/Hal8812PhyReg.h	361;"	d
-bCCKTxService	include/Hal8814PhyReg.h	468;"	d
-bCCKTxService	include/rtw_mp_phy_regdef.h	446;"	d
-bCCKTxStart	include/Hal8188EPhyReg.h	459;"	d
-bCCKTxStart	include/Hal8188FPhyReg.h	467;"	d
-bCCKTxStart	include/Hal8192EPhyReg.h	468;"	d
-bCCKTxStart	include/Hal8703BPhyReg.h	495;"	d
-bCCKTxStart	include/Hal8723BPhyReg.h	494;"	d
-bCCKTxStart	include/Hal8723DPhyReg.h	496;"	d
-bCCKTxStart	include/Hal8812PhyReg.h	326;"	d
-bCCKTxStart	include/Hal8814PhyReg.h	433;"	d
-bCCKTxStart	include/rtw_mp_phy_regdef.h	411;"	d
-bCCKTxStatus	include/Hal8188EPhyReg.h	498;"	d
-bCCKTxStatus	include/Hal8188FPhyReg.h	506;"	d
-bCCKTxStatus	include/Hal8192EPhyReg.h	507;"	d
-bCCKTxStatus	include/Hal8703BPhyReg.h	534;"	d
-bCCKTxStatus	include/Hal8723BPhyReg.h	533;"	d
-bCCKTxStatus	include/Hal8723DPhyReg.h	535;"	d
-bCCKTxStatus	include/Hal8812PhyReg.h	365;"	d
-bCCKTxStatus	include/Hal8814PhyReg.h	472;"	d
-bCCKTxStatus	include/rtw_mp_phy_regdef.h	450;"	d
-bCCK_CCA_Jaguar	include/Hal8812PhyReg.h	138;"	d
-bCCK_CCA_Jaguar	include/Hal8814PhyReg.h	168;"	d
-bCCK_RX_Jaguar	include/Hal8812PhyReg.h	58;"	d
-bCCK_RX_Jaguar	include/Hal8814PhyReg.h	60;"	d
-bCCK_System_Jaguar	include/Hal8812PhyReg.h	47;"	d
-bCCK_System_Jaguar	include/Hal8814PhyReg.h	49;"	d
-bCCK_TxFilter1_C0_Jaguar	include/Hal8812PhyReg.h	96;"	d
-bCCK_TxFilter1_C0_Jaguar	include/Hal8814PhyReg.h	109;"	d
-bCCK_TxFilter1_C1_Jaguar	include/Hal8812PhyReg.h	97;"	d
-bCCK_TxFilter1_C1_Jaguar	include/Hal8814PhyReg.h	110;"	d
-bCCK_TxFilter2_C2_Jaguar	include/Hal8812PhyReg.h	99;"	d
-bCCK_TxFilter2_C2_Jaguar	include/Hal8814PhyReg.h	112;"	d
-bCCK_TxFilter2_C3_Jaguar	include/Hal8812PhyReg.h	100;"	d
-bCCK_TxFilter2_C3_Jaguar	include/Hal8814PhyReg.h	113;"	d
-bCCK_TxFilter2_C4_Jaguar	include/Hal8812PhyReg.h	101;"	d
-bCCK_TxFilter2_C4_Jaguar	include/Hal8814PhyReg.h	114;"	d
-bCCK_TxFilter2_C5_Jaguar	include/Hal8812PhyReg.h	102;"	d
-bCCK_TxFilter2_C5_Jaguar	include/Hal8814PhyReg.h	115;"	d
-bCCK_TxFilter3_C6_Jaguar	include/Hal8812PhyReg.h	104;"	d
-bCCK_TxFilter3_C6_Jaguar	include/Hal8814PhyReg.h	117;"	d
-bCCK_TxFilter3_C7_Jaguar	include/Hal8812PhyReg.h	105;"	d
-bCCK_TxFilter3_C7_Jaguar	include/Hal8814PhyReg.h	118;"	d
-bCCKcs_lim	include/Hal8188EPhyReg.h	681;"	d
-bCCKcs_lim	include/Hal8188FPhyReg.h	689;"	d
-bCCKcs_lim	include/Hal8192EPhyReg.h	692;"	d
-bCCKcs_lim	include/Hal8703BPhyReg.h	718;"	d
-bCCKcs_lim	include/Hal8723BPhyReg.h	716;"	d
-bCCKcs_lim	include/Hal8723DPhyReg.h	719;"	d
-bCCKcs_lim	include/Hal8812PhyReg.h	630;"	d
-bCCKcs_lim	include/Hal8814PhyReg.h	753;"	d
-bCCKcs_lim	include/rtw_mp_phy_regdef.h	635;"	d
-bCCKinCH14	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	bCCKinCH14;$/;"	m	struct:ODM_RF_Calibration_Structure
-bCCKinCH14	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	bCCKinCH14;$/;"	m	struct:ODM_RF_Calibration_Structure
-bCCKinCH14	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	bCCKinCH14;$/;"	m	struct:ODM_RF_Calibration_Structure
-bCCKinCH14	include/hal_data.h	/^	BOOLEAN				bCCKinCH14;$/;"	m	struct:hal_com_data
-bCCKr_cp_mode0	include/Hal8188EPhyReg.h	686;"	d
-bCCKr_cp_mode0	include/Hal8188FPhyReg.h	694;"	d
-bCCKr_cp_mode0	include/Hal8192EPhyReg.h	697;"	d
-bCCKr_cp_mode0	include/Hal8703BPhyReg.h	723;"	d
-bCCKr_cp_mode0	include/Hal8723BPhyReg.h	721;"	d
-bCCKr_cp_mode0	include/Hal8723DPhyReg.h	724;"	d
-bCCKr_cp_mode0	include/Hal8812PhyReg.h	635;"	d
-bCCKr_cp_mode0	include/Hal8814PhyReg.h	758;"	d
-bCCKr_cp_mode0	include/rtw_mp_phy_regdef.h	640;"	d
-bCC_power_dB	include/Hal8188EPhyReg.h	938;"	d
-bCC_power_dB	include/Hal8188FPhyReg.h	946;"	d
-bCC_power_dB	include/Hal8192EPhyReg.h	949;"	d
-bCC_power_dB	include/Hal8703BPhyReg.h	975;"	d
-bCC_power_dB	include/Hal8723BPhyReg.h	973;"	d
-bCC_power_dB	include/Hal8723DPhyReg.h	976;"	d
-bCC_power_dB	include/rtw_mp_phy_regdef.h	892;"	d
-bCFOAcc	include/Hal8188EPhyReg.h	798;"	d
-bCFOAcc	include/Hal8188FPhyReg.h	806;"	d
-bCFOAcc	include/Hal8192EPhyReg.h	809;"	d
-bCFOAcc	include/Hal8703BPhyReg.h	835;"	d
-bCFOAcc	include/Hal8723BPhyReg.h	833;"	d
-bCFOAcc	include/Hal8723DPhyReg.h	836;"	d
-bCFOAcc	include/rtw_mp_phy_regdef.h	752;"	d
-bCFOAntSum	include/Hal8188EPhyReg.h	797;"	d
-bCFOAntSum	include/Hal8188FPhyReg.h	805;"	d
-bCFOAntSum	include/Hal8192EPhyReg.h	808;"	d
-bCFOAntSum	include/Hal8703BPhyReg.h	834;"	d
-bCFOAntSum	include/Hal8723BPhyReg.h	832;"	d
-bCFOAntSum	include/Hal8723DPhyReg.h	835;"	d
-bCFOAntSum	include/rtw_mp_phy_regdef.h	751;"	d
-bCFOAntSumD	include/Hal8188EPhyReg.h	905;"	d
-bCFOAntSumD	include/Hal8188FPhyReg.h	913;"	d
-bCFOAntSumD	include/Hal8192EPhyReg.h	916;"	d
-bCFOAntSumD	include/Hal8703BPhyReg.h	942;"	d
-bCFOAntSumD	include/Hal8723BPhyReg.h	940;"	d
-bCFOAntSumD	include/Hal8723DPhyReg.h	943;"	d
-bCFOAntSumD	include/Hal8812PhyReg.h	696;"	d
-bCFOAntSumD	include/Hal8814PhyReg.h	821;"	d
-bCFOAntSumD	include/rtw_mp_phy_regdef.h	859;"	d
-bCFOEn	include/Hal8188EPhyReg.h	918;"	d
-bCFOEn	include/Hal8188FPhyReg.h	926;"	d
-bCFOEn	include/Hal8192EPhyReg.h	929;"	d
-bCFOEn	include/Hal8703BPhyReg.h	955;"	d
-bCFOEn	include/Hal8723BPhyReg.h	953;"	d
-bCFOEn	include/Hal8723DPhyReg.h	956;"	d
-bCFOEn	include/rtw_mp_phy_regdef.h	872;"	d
-bCFOLookBack	include/Hal8188EPhyReg.h	800;"	d
-bCFOLookBack	include/Hal8188FPhyReg.h	808;"	d
-bCFOLookBack	include/Hal8192EPhyReg.h	811;"	d
-bCFOLookBack	include/Hal8703BPhyReg.h	837;"	d
-bCFOLookBack	include/Hal8723BPhyReg.h	835;"	d
-bCFOLookBack	include/Hal8723DPhyReg.h	838;"	d
-bCFOLookBack	include/rtw_mp_phy_regdef.h	754;"	d
-bCFOReportGet	include/Hal8188EPhyReg.h	907;"	d
-bCFOReportGet	include/Hal8188FPhyReg.h	915;"	d
-bCFOReportGet	include/Hal8192EPhyReg.h	918;"	d
-bCFOReportGet	include/Hal8703BPhyReg.h	944;"	d
-bCFOReportGet	include/Hal8723BPhyReg.h	942;"	d
-bCFOReportGet	include/Hal8723DPhyReg.h	945;"	d
-bCFOReportGet	include/Hal8812PhyReg.h	698;"	d
-bCFOReportGet	include/Hal8814PhyReg.h	823;"	d
-bCFOReportGet	include/rtw_mp_phy_regdef.h	861;"	d
-bCFOStartOffset	include/Hal8188EPhyReg.h	799;"	d
-bCFOStartOffset	include/Hal8188FPhyReg.h	807;"	d
-bCFOStartOffset	include/Hal8192EPhyReg.h	810;"	d
-bCFOStartOffset	include/Hal8703BPhyReg.h	836;"	d
-bCFOStartOffset	include/Hal8723BPhyReg.h	834;"	d
-bCFOStartOffset	include/Hal8723DPhyReg.h	837;"	d
-bCFOStartOffset	include/rtw_mp_phy_regdef.h	753;"	d
-bCFOSumWeight	include/Hal8188EPhyReg.h	801;"	d
-bCFOSumWeight	include/Hal8188FPhyReg.h	809;"	d
-bCFOSumWeight	include/Hal8192EPhyReg.h	812;"	d
-bCFOSumWeight	include/Hal8703BPhyReg.h	838;"	d
-bCFOSumWeight	include/Hal8723BPhyReg.h	836;"	d
-bCFOSumWeight	include/Hal8723DPhyReg.h	839;"	d
-bCFOSumWeight	include/rtw_mp_phy_regdef.h	755;"	d
-bCFOValue	include/Hal8188EPhyReg.h	919;"	d
-bCFOValue	include/Hal8188FPhyReg.h	927;"	d
-bCFOValue	include/Hal8192EPhyReg.h	930;"	d
-bCFOValue	include/Hal8703BPhyReg.h	956;"	d
-bCFOValue	include/Hal8723BPhyReg.h	954;"	d
-bCFOValue	include/Hal8723DPhyReg.h	957;"	d
-bCFOValue	include/rtw_mp_phy_regdef.h	873;"	d
-bCRC32Debug	include/Hal8188EPhyReg.h	460;"	d
-bCRC32Debug	include/Hal8188FPhyReg.h	468;"	d
-bCRC32Debug	include/Hal8192EPhyReg.h	469;"	d
-bCRC32Debug	include/Hal8703BPhyReg.h	496;"	d
-bCRC32Debug	include/Hal8723BPhyReg.h	495;"	d
-bCRC32Debug	include/Hal8723DPhyReg.h	497;"	d
-bCRC32Debug	include/Hal8812PhyReg.h	327;"	d
-bCRC32Debug	include/Hal8814PhyReg.h	434;"	d
-bCRC32Debug	include/rtw_mp_phy_regdef.h	412;"	d
-bCSI1st	include/Hal8188EPhyReg.h	957;"	d
-bCSI1st	include/Hal8188FPhyReg.h	965;"	d
-bCSI1st	include/Hal8192EPhyReg.h	968;"	d
-bCSI1st	include/Hal8703BPhyReg.h	994;"	d
-bCSI1st	include/Hal8723BPhyReg.h	992;"	d
-bCSI1st	include/Hal8723DPhyReg.h	995;"	d
-bCSI1st	include/rtw_mp_phy_regdef.h	911;"	d
-bCSI2nd	include/Hal8188EPhyReg.h	958;"	d
-bCSI2nd	include/Hal8188FPhyReg.h	966;"	d
-bCSI2nd	include/Hal8192EPhyReg.h	969;"	d
-bCSI2nd	include/Hal8703BPhyReg.h	995;"	d
-bCSI2nd	include/Hal8723BPhyReg.h	993;"	d
-bCSI2nd	include/Hal8723DPhyReg.h	996;"	d
-bCSI2nd	include/rtw_mp_phy_regdef.h	912;"	d
-bCSIEstiMode	include/Hal8188EPhyReg.h	996;"	d
-bCSIEstiMode	include/Hal8188FPhyReg.h	1004;"	d
-bCSIEstiMode	include/Hal8192EPhyReg.h	1007;"	d
-bCSIEstiMode	include/Hal8703BPhyReg.h	1033;"	d
-bCSIEstiMode	include/Hal8723BPhyReg.h	1031;"	d
-bCSIEstiMode	include/Hal8723DPhyReg.h	1034;"	d
-bCSIEstiMode	include/rtw_mp_phy_regdef.h	950;"	d
-bCSIScheme	include/Hal8188EPhyReg.h	974;"	d
-bCSIScheme	include/Hal8188FPhyReg.h	982;"	d
-bCSIScheme	include/Hal8192EPhyReg.h	985;"	d
-bCSIScheme	include/Hal8703BPhyReg.h	1011;"	d
-bCSIScheme	include/Hal8723BPhyReg.h	1009;"	d
-bCSIScheme	include/Hal8723DPhyReg.h	1012;"	d
-bCSIScheme	include/rtw_mp_phy_regdef.h	928;"	d
-bCandidateSoundingPeer	include/rtw_beamforming.h	/^	u8 bCandidateSoundingPeer;$/;"	m	struct:beamformee_entry
-bCarrierSuppression	include/rtw_mp.h	/^	BOOLEAN			bCarrierSuppression;$/;"	m	struct:_MPT_CONTEXT
-bCckContTx	include/rtw_mp.h	/^	BOOLEAN			bCckContTx;	\/* TRUE if we are in CCK Continuous Tx test. *\/$/;"	m	struct:_MPT_CONTEXT
-bCckHighPower	hal/phydm/phydm.h	/^	BOOLEAN			bCckHighPower; $/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bChSmooth	include/Hal8188EPhyReg.h	977;"	d
-bChSmooth	include/Hal8188FPhyReg.h	985;"	d
-bChSmooth	include/Hal8192EPhyReg.h	988;"	d
-bChSmooth	include/Hal8703BPhyReg.h	1014;"	d
-bChSmooth	include/Hal8723BPhyReg.h	1012;"	d
-bChSmooth	include/Hal8723DPhyReg.h	1015;"	d
-bChSmooth	include/rtw_mp_phy_regdef.h	931;"	d
-bChSmoothCfg1	include/Hal8188EPhyReg.h	978;"	d
-bChSmoothCfg1	include/Hal8188FPhyReg.h	986;"	d
-bChSmoothCfg1	include/Hal8192EPhyReg.h	989;"	d
-bChSmoothCfg1	include/Hal8703BPhyReg.h	1015;"	d
-bChSmoothCfg1	include/Hal8723BPhyReg.h	1013;"	d
-bChSmoothCfg1	include/Hal8723DPhyReg.h	1016;"	d
-bChSmoothCfg1	include/rtw_mp_phy_regdef.h	932;"	d
-bChSmoothCfg2	include/Hal8188EPhyReg.h	979;"	d
-bChSmoothCfg2	include/Hal8188FPhyReg.h	987;"	d
-bChSmoothCfg2	include/Hal8192EPhyReg.h	990;"	d
-bChSmoothCfg2	include/Hal8703BPhyReg.h	1016;"	d
-bChSmoothCfg2	include/Hal8723BPhyReg.h	1014;"	d
-bChSmoothCfg2	include/Hal8723DPhyReg.h	1017;"	d
-bChSmoothCfg2	include/rtw_mp_phy_regdef.h	933;"	d
-bChSmoothCfg3	include/Hal8188EPhyReg.h	980;"	d
-bChSmoothCfg3	include/Hal8188FPhyReg.h	988;"	d
-bChSmoothCfg3	include/Hal8192EPhyReg.h	991;"	d
-bChSmoothCfg3	include/Hal8703BPhyReg.h	1017;"	d
-bChSmoothCfg3	include/Hal8723BPhyReg.h	1015;"	d
-bChSmoothCfg3	include/Hal8723DPhyReg.h	1018;"	d
-bChSmoothCfg3	include/rtw_mp_phy_regdef.h	934;"	d
-bChSmoothCfg4	include/Hal8188EPhyReg.h	981;"	d
-bChSmoothCfg4	include/Hal8188FPhyReg.h	989;"	d
-bChSmoothCfg4	include/Hal8192EPhyReg.h	992;"	d
-bChSmoothCfg4	include/Hal8703BPhyReg.h	1018;"	d
-bChSmoothCfg4	include/Hal8723BPhyReg.h	1016;"	d
-bChSmoothCfg4	include/Hal8723DPhyReg.h	1019;"	d
-bChSmoothCfg4	include/rtw_mp_phy_regdef.h	935;"	d
-bChangeState	hal/phydm/phydm.h	/^	BOOLEAN			bChangeState;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bCheck	hal/phydm/phydm_adaptivity.h	/^	BOOLEAN			bCheck;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-bChnlBWInitialized	include/hal_data.h	/^	BOOLEAN			bChnlBWInitialized;$/;"	m	struct:hal_com_data
-bComChCFO	include/Hal8188EPhyReg.h	995;"	d
-bComChCFO	include/Hal8188FPhyReg.h	1003;"	d
-bComChCFO	include/Hal8192EPhyReg.h	1006;"	d
-bComChCFO	include/Hal8703BPhyReg.h	1032;"	d
-bComChCFO	include/Hal8723BPhyReg.h	1030;"	d
-bComChCFO	include/Hal8723DPhyReg.h	1033;"	d
-bComChCFO	include/rtw_mp_phy_regdef.h	949;"	d
-bConnection	core/rtw_cmd.c	/^	u8 bConnection:1;$/;"	m	struct:btinfo	file:
-bConnection	include/rtw_btcoex.h	/^	u8 bConnection:1;$/;"	m	struct:btinfo_8761ATV
-bContTxHSSI	include/Hal8188EPhyReg.h	532;"	d
-bContTxHSSI	include/Hal8188FPhyReg.h	540;"	d
-bContTxHSSI	include/Hal8192EPhyReg.h	543;"	d
-bContTxHSSI	include/Hal8703BPhyReg.h	569;"	d
-bContTxHSSI	include/Hal8723BPhyReg.h	567;"	d
-bContTxHSSI	include/Hal8723DPhyReg.h	570;"	d
-bContTxHSSI	include/rtw_mp_phy_regdef.h	482;"	d
-bCorrectBCN	include/hal_data.h	/^	BOOLEAN bCorrectBCN;$/;"	m	struct:hal_com_data
-bCounterReset	include/Hal8188EPhyReg.h	481;"	d
-bCounterReset	include/Hal8188FPhyReg.h	489;"	d
-bCounterReset	include/Hal8192EPhyReg.h	490;"	d
-bCounterReset	include/Hal8703BPhyReg.h	517;"	d
-bCounterReset	include/Hal8723BPhyReg.h	516;"	d
-bCounterReset	include/Hal8723DPhyReg.h	518;"	d
-bCounterReset	include/Hal8812PhyReg.h	348;"	d
-bCounterReset	include/Hal8814PhyReg.h	455;"	d
-bCounterReset	include/rtw_mp_phy_regdef.h	433;"	d
-bCounter_CCA	include/Hal8188EPhyReg.h	922;"	d
-bCounter_CCA	include/Hal8188FPhyReg.h	930;"	d
-bCounter_CCA	include/Hal8192EPhyReg.h	933;"	d
-bCounter_CCA	include/Hal8703BPhyReg.h	959;"	d
-bCounter_CCA	include/Hal8723BPhyReg.h	957;"	d
-bCounter_CCA	include/Hal8723DPhyReg.h	960;"	d
-bCounter_CCA	include/rtw_mp_phy_regdef.h	876;"	d
-bCounter_CRC8Fail	include/Hal8188EPhyReg.h	925;"	d
-bCounter_CRC8Fail	include/Hal8188FPhyReg.h	933;"	d
-bCounter_CRC8Fail	include/Hal8192EPhyReg.h	936;"	d
-bCounter_CRC8Fail	include/Hal8703BPhyReg.h	962;"	d
-bCounter_CRC8Fail	include/Hal8723BPhyReg.h	960;"	d
-bCounter_CRC8Fail	include/Hal8723DPhyReg.h	963;"	d
-bCounter_CRC8Fail	include/rtw_mp_phy_regdef.h	879;"	d
-bCounter_FastSync	include/Hal8188EPhyReg.h	927;"	d
-bCounter_FastSync	include/Hal8188FPhyReg.h	935;"	d
-bCounter_FastSync	include/Hal8192EPhyReg.h	938;"	d
-bCounter_FastSync	include/Hal8703BPhyReg.h	964;"	d
-bCounter_FastSync	include/Hal8723BPhyReg.h	962;"	d
-bCounter_FastSync	include/Hal8723DPhyReg.h	965;"	d
-bCounter_FastSync	include/rtw_mp_phy_regdef.h	881;"	d
-bCounter_MCSNoSupport	include/Hal8188EPhyReg.h	926;"	d
-bCounter_MCSNoSupport	include/Hal8188FPhyReg.h	934;"	d
-bCounter_MCSNoSupport	include/Hal8192EPhyReg.h	937;"	d
-bCounter_MCSNoSupport	include/Hal8703BPhyReg.h	963;"	d
-bCounter_MCSNoSupport	include/Hal8723BPhyReg.h	961;"	d
-bCounter_MCSNoSupport	include/Hal8723DPhyReg.h	964;"	d
-bCounter_MCSNoSupport	include/rtw_mp_phy_regdef.h	880;"	d
-bCounter_ParityFail	include/Hal8188EPhyReg.h	923;"	d
-bCounter_ParityFail	include/Hal8188FPhyReg.h	931;"	d
-bCounter_ParityFail	include/Hal8192EPhyReg.h	934;"	d
-bCounter_ParityFail	include/Hal8703BPhyReg.h	960;"	d
-bCounter_ParityFail	include/Hal8723BPhyReg.h	958;"	d
-bCounter_ParityFail	include/Hal8723DPhyReg.h	961;"	d
-bCounter_ParityFail	include/rtw_mp_phy_regdef.h	877;"	d
-bCounter_RateIllegal	include/Hal8188EPhyReg.h	924;"	d
-bCounter_RateIllegal	include/Hal8188FPhyReg.h	932;"	d
-bCounter_RateIllegal	include/Hal8192EPhyReg.h	935;"	d
-bCounter_RateIllegal	include/Hal8703BPhyReg.h	961;"	d
-bCounter_RateIllegal	include/Hal8723BPhyReg.h	959;"	d
-bCounter_RateIllegal	include/Hal8723DPhyReg.h	962;"	d
-bCounter_RateIllegal	include/rtw_mp_phy_regdef.h	878;"	d
-bCreateSpportQos	include/rtw_btcoex.h	/^	BOOLEAN				bCreateSpportQos;$/;"	m	struct:_BT_MGNT
-bCurAdcBackOff	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurAdcBackOff;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurAdcBackOff	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurAdcBackOff;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurAdcBackOff	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurAdcBackOff;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurAgcTableEn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurAgcTableEn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurAgcTableEn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurAgcTableEn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurAgcTableEn	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurAgcTableEn;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurBalanceOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurBalanceOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurBalanceOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurBalanceOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurDacOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurDacOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurDacOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurDacOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurDacSwingOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurDacSwingOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurDacSwingOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurDacSwingOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurDacSwingOn	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurDacSwingOn;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurDecBtPwr	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurDecBtPwr;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurIgnoreWlanAct	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bCurIgnoreWlanAct;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bCurIgnoreWlanAct	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurIgnoreWlanAct;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurInterruptOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurInterruptOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurInterruptOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurInterruptOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurLowPenaltyRa	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurLowPenaltyRa;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurLowPenaltyRa	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurLowPenaltyRa;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurLowPenaltyRa	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bCurLowPenaltyRa;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bCurLowPenaltyRa	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurLowPenaltyRa;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurNavOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurNavOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurNavOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurNavOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurPsTdmaOn	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bCurPsTdmaOn;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bCurPsTdmaOn	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurPsTdmaOn;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurRfRxLpfShrink	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bCurRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bCurRfRxLpfShrink	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bCurRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bCurRfRxLpfShrink	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bCurRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bCurRfRxLpfShrink	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bCurRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bCurrentTurboEDCA	hal/phydm/phydm_edcaturbocheck.h	/^	BOOLEAN bCurrentTurboEDCA;$/;"	m	struct:_EDCA_TURBO_
-bDA10PSAtRx	include/Hal8188EPhyReg.h	636;"	d
-bDA10PSAtRx	include/Hal8188FPhyReg.h	644;"	d
-bDA10PSAtRx	include/Hal8192EPhyReg.h	647;"	d
-bDA10PSAtRx	include/Hal8703BPhyReg.h	673;"	d
-bDA10PSAtRx	include/Hal8723BPhyReg.h	671;"	d
-bDA10PSAtRx	include/Hal8723DPhyReg.h	674;"	d
-bDA10PSAtRx	include/rtw_mp_phy_regdef.h	590;"	d
-bDA10PSAtTx	include/Hal8188EPhyReg.h	634;"	d
-bDA10PSAtTx	include/Hal8188FPhyReg.h	642;"	d
-bDA10PSAtTx	include/Hal8192EPhyReg.h	645;"	d
-bDA10PSAtTx	include/Hal8703BPhyReg.h	671;"	d
-bDA10PSAtTx	include/Hal8723BPhyReg.h	669;"	d
-bDA10PSAtTx	include/Hal8723DPhyReg.h	672;"	d
-bDA10PSAtTx	include/rtw_mp_phy_regdef.h	588;"	d
-bDA10PowerUp	include/Hal8188EPhyReg.h	597;"	d
-bDA10PowerUp	include/Hal8188FPhyReg.h	605;"	d
-bDA10PowerUp	include/Hal8192EPhyReg.h	608;"	d
-bDA10PowerUp	include/Hal8703BPhyReg.h	634;"	d
-bDA10PowerUp	include/Hal8723BPhyReg.h	632;"	d
-bDA10PowerUp	include/Hal8723DPhyReg.h	635;"	d
-bDA10PowerUp	include/rtw_mp_phy_regdef.h	551;"	d
-bDA10Reverse	include/Hal8188EPhyReg.h	625;"	d
-bDA10Reverse	include/Hal8188FPhyReg.h	633;"	d
-bDA10Reverse	include/Hal8192EPhyReg.h	636;"	d
-bDA10Reverse	include/Hal8703BPhyReg.h	662;"	d
-bDA10Reverse	include/Hal8723BPhyReg.h	660;"	d
-bDA10Reverse	include/Hal8723DPhyReg.h	663;"	d
-bDA10Reverse	include/rtw_mp_phy_regdef.h	579;"	d
-bDA10Swing	include/Hal8188EPhyReg.h	624;"	d
-bDA10Swing	include/Hal8188FPhyReg.h	632;"	d
-bDA10Swing	include/Hal8192EPhyReg.h	635;"	d
-bDA10Swing	include/Hal8703BPhyReg.h	661;"	d
-bDA10Swing	include/Hal8723BPhyReg.h	659;"	d
-bDA10Swing	include/Hal8723DPhyReg.h	662;"	d
-bDA10Swing	include/rtw_mp_phy_regdef.h	578;"	d
-bDA6DebugMode	include/Hal8188EPhyReg.h	602;"	d
-bDA6DebugMode	include/Hal8188FPhyReg.h	610;"	d
-bDA6DebugMode	include/Hal8192EPhyReg.h	613;"	d
-bDA6DebugMode	include/Hal8703BPhyReg.h	639;"	d
-bDA6DebugMode	include/Hal8723BPhyReg.h	637;"	d
-bDA6DebugMode	include/Hal8723DPhyReg.h	640;"	d
-bDA6DebugMode	include/rtw_mp_phy_regdef.h	556;"	d
-bDA6PowerUp	include/Hal8188EPhyReg.h	599;"	d
-bDA6PowerUp	include/Hal8188FPhyReg.h	607;"	d
-bDA6PowerUp	include/Hal8192EPhyReg.h	610;"	d
-bDA6PowerUp	include/Hal8703BPhyReg.h	636;"	d
-bDA6PowerUp	include/Hal8723BPhyReg.h	634;"	d
-bDA6PowerUp	include/Hal8723DPhyReg.h	637;"	d
-bDA6PowerUp	include/rtw_mp_phy_regdef.h	553;"	d
-bDA6Swing	include/Hal8188EPhyReg.h	603;"	d
-bDA6Swing	include/Hal8188FPhyReg.h	611;"	d
-bDA6Swing	include/Hal8192EPhyReg.h	614;"	d
-bDA6Swing	include/Hal8703BPhyReg.h	640;"	d
-bDA6Swing	include/Hal8723BPhyReg.h	638;"	d
-bDA6Swing	include/Hal8723DPhyReg.h	641;"	d
-bDA6Swing	include/rtw_mp_phy_regdef.h	557;"	d
-bDAClkSource	include/Hal8188EPhyReg.h	626;"	d
-bDAClkSource	include/Hal8188FPhyReg.h	634;"	d
-bDAClkSource	include/Hal8192EPhyReg.h	637;"	d
-bDAClkSource	include/Hal8703BPhyReg.h	663;"	d
-bDAClkSource	include/Hal8723BPhyReg.h	661;"	d
-bDAClkSource	include/Hal8723DPhyReg.h	664;"	d
-bDAClkSource	include/rtw_mp_phy_regdef.h	580;"	d
-bDAFormat	include/Hal8188EPhyReg.h	893;"	d
-bDAFormat	include/Hal8188FPhyReg.h	901;"	d
-bDAFormat	include/Hal8192EPhyReg.h	904;"	d
-bDAFormat	include/Hal8703BPhyReg.h	930;"	d
-bDAFormat	include/Hal8723BPhyReg.h	928;"	d
-bDAFormat	include/Hal8723DPhyReg.h	931;"	d
-bDAFormat	include/rtw_mp_phy_regdef.h	847;"	d
-bDAGCEnable	include/Hal8188EPhyReg.h	802;"	d
-bDAGCEnable	include/Hal8188FPhyReg.h	810;"	d
-bDAGCEnable	include/Hal8192EPhyReg.h	813;"	d
-bDAGCEnable	include/Hal8703BPhyReg.h	839;"	d
-bDAGCEnable	include/Hal8723BPhyReg.h	837;"	d
-bDAGCEnable	include/Hal8723DPhyReg.h	840;"	d
-bDAGCEnable	include/rtw_mp_phy_regdef.h	756;"	d
-bDC_Slope_check	include/Hal8188EPhyReg.h	785;"	d
-bDC_Slope_check	include/Hal8188FPhyReg.h	793;"	d
-bDC_Slope_check	include/Hal8192EPhyReg.h	796;"	d
-bDC_Slope_check	include/Hal8703BPhyReg.h	822;"	d
-bDC_Slope_check	include/Hal8723BPhyReg.h	820;"	d
-bDC_Slope_check	include/Hal8723DPhyReg.h	823;"	d
-bDC_Slope_check	include/rtw_mp_phy_regdef.h	739;"	d
-bDC_dc_Notch	include/Hal8188EPhyReg.h	767;"	d
-bDC_dc_Notch	include/Hal8188FPhyReg.h	775;"	d
-bDC_dc_Notch	include/Hal8192EPhyReg.h	778;"	d
-bDC_dc_Notch	include/Hal8703BPhyReg.h	804;"	d
-bDC_dc_Notch	include/Hal8723BPhyReg.h	802;"	d
-bDC_dc_Notch	include/Hal8723DPhyReg.h	805;"	d
-bDC_dc_Notch	include/rtw_mp_phy_regdef.h	721;"	d
-bDFIRBackoff	include/Hal8188EPhyReg.h	757;"	d
-bDFIRBackoff	include/Hal8188FPhyReg.h	765;"	d
-bDFIRBackoff	include/Hal8192EPhyReg.h	768;"	d
-bDFIRBackoff	include/Hal8703BPhyReg.h	794;"	d
-bDFIRBackoff	include/Hal8723BPhyReg.h	792;"	d
-bDFIRBackoff	include/Hal8723DPhyReg.h	795;"	d
-bDFIRBackoff	include/rtw_mp_phy_regdef.h	711;"	d
-bDFSCnt0	include/Hal8188EPhyReg.h	888;"	d
-bDFSCnt0	include/Hal8188FPhyReg.h	896;"	d
-bDFSCnt0	include/Hal8192EPhyReg.h	899;"	d
-bDFSCnt0	include/Hal8703BPhyReg.h	925;"	d
-bDFSCnt0	include/Hal8723BPhyReg.h	923;"	d
-bDFSCnt0	include/Hal8723DPhyReg.h	926;"	d
-bDFSCnt0	include/rtw_mp_phy_regdef.h	842;"	d
-bDFSCnt1	include/Hal8188EPhyReg.h	889;"	d
-bDFSCnt1	include/Hal8188FPhyReg.h	897;"	d
-bDFSCnt1	include/Hal8192EPhyReg.h	900;"	d
-bDFSCnt1	include/Hal8703BPhyReg.h	926;"	d
-bDFSCnt1	include/Hal8723BPhyReg.h	924;"	d
-bDFSCnt1	include/Hal8723DPhyReg.h	927;"	d
-bDFSCnt1	include/rtw_mp_phy_regdef.h	843;"	d
-bDFSFlag	include/Hal8188EPhyReg.h	890;"	d
-bDFSFlag	include/Hal8188FPhyReg.h	898;"	d
-bDFSFlag	include/Hal8192EPhyReg.h	901;"	d
-bDFSFlag	include/Hal8703BPhyReg.h	927;"	d
-bDFSFlag	include/Hal8723BPhyReg.h	925;"	d
-bDFSFlag	include/Hal8723DPhyReg.h	928;"	d
-bDFSFlag	include/rtw_mp_phy_regdef.h	844;"	d
-bDMInitialGainEnable	hal/phydm/phydm.h	/^	BOOLEAN			bDMInitialGainEnable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bDPKFail	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN bDPKFail;	$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPKFail	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN bDPKFail;	$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPKenable	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	bDPKenable;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPLLPowerUp	include/Hal8188EPhyReg.h	596;"	d
-bDPLLPowerUp	include/Hal8188FPhyReg.h	604;"	d
-bDPLLPowerUp	include/Hal8192EPhyReg.h	607;"	d
-bDPLLPowerUp	include/Hal8703BPhyReg.h	633;"	d
-bDPLLPowerUp	include/Hal8723BPhyReg.h	631;"	d
-bDPLLPowerUp	include/Hal8723DPhyReg.h	634;"	d
-bDPLLPowerUp	include/rtw_mp_phy_regdef.h	550;"	d
-bDPPathAOK	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	bDPPathAOK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPPathAOK	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	bDPPathAOK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPPathAOK	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	bDPPathAOK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPPathBOK	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	bDPPathBOK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPPathBOK	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	bDPPathBOK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPPathBOK	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	bDPPathBOK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPdone	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	bDPdone;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPdone	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	bDPdone;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDPdone	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	bDPdone;$/;"	m	struct:ODM_RF_Calibration_Structure
-bDWord	include/Hal8188EPhyReg.h	1047;"	d
-bDWord	include/Hal8188FPhyReg.h	1055;"	d
-bDWord	include/Hal8192EPhyReg.h	1058;"	d
-bDWord	include/Hal8703BPhyReg.h	1084;"	d
-bDWord	include/Hal8723BPhyReg.h	1082;"	d
-bDWord	include/Hal8723DPhyReg.h	1085;"	d
-bDWord	include/Hal8812PhyReg.h	718;"	d
-bDWord	include/Hal8814PhyReg.h	843;"	d
-bDWord	include/rtw_mp_phy_regdef.h	1010;"	d
-bDebugItem	include/Hal8188EPhyReg.h	654;"	d
-bDebugItem	include/Hal8188FPhyReg.h	662;"	d
-bDebugItem	include/Hal8192EPhyReg.h	665;"	d
-bDebugItem	include/Hal8703BPhyReg.h	691;"	d
-bDebugItem	include/Hal8723BPhyReg.h	689;"	d
-bDebugItem	include/Hal8723DPhyReg.h	692;"	d
-bDebugItem	include/rtw_mp_phy_regdef.h	608;"	d
-bDebugPage	include/Hal8188EPhyReg.h	653;"	d
-bDebugPage	include/Hal8188FPhyReg.h	661;"	d
-bDebugPage	include/Hal8192EPhyReg.h	664;"	d
-bDebugPage	include/Hal8703BPhyReg.h	690;"	d
-bDebugPage	include/Hal8723BPhyReg.h	688;"	d
-bDebugPage	include/Hal8723DPhyReg.h	691;"	d
-bDebugPage	include/rtw_mp_phy_regdef.h	607;"	d
-bDefaultAntenna	include/hal_data.h	/^	u8			bDefaultAntenna;$/;"	m	struct:hal_com_data
-bDefaultCSI	include/rtw_beamforming.h	/^	BOOLEAN	bDefaultCSI;$/;"	m	struct:beamforming_entry
-bDeleteSounding	include/rtw_beamforming.h	/^	u8 bDeleteSounding;$/;"	m	struct:beamformee_entry
-bDisable	include/Hal8188EPhyReg.h	1066;"	d
-bDisable	include/Hal8188FPhyReg.h	1073;"	d
-bDisable	include/Hal8192EPhyReg.h	1080;"	d
-bDisable	include/Hal8703BPhyReg.h	1102;"	d
-bDisable	include/Hal8723BPhyReg.h	1100;"	d
-bDisable	include/Hal8723DPhyReg.h	1103;"	d
-bDisable	include/Hal8812PhyReg.h	709;"	d
-bDisable	include/Hal8814PhyReg.h	834;"	d
-bDisable	include/rtl8822b_hal.h	179;"	d
-bDisable	include/rtw_mp_phy_regdef.h	1037;"	d
-bDisableAutosuspend	include/drv_types.h	/^	u8	bDisableAutosuspend;$/;"	m	struct:_ADAPTER
-bDisablePhyApi	hal/phydm/phydm.h	/^	BOOLEAN			bDisablePhyApi;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bDisablePowerTraining	hal/phydm/phydm.h	/^	BOOLEAN			bDisablePowerTraining;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bDisableSWChannelPlan	include/hal_data.h	/^	u8				bDisableSWChannelPlan; \/* flag of disable software change channel plan	 *\/$/;"	m	struct:hal_com_data
-bDisableTXPowerTraining	include/hal_data.h	/^	u8	bDisableTXPowerTraining;$/;"	m	struct:hal_com_data
-bDisableTxInt	include/hal_data.h	/^	u8			bDisableTxInt;$/;"	m	struct:hal_com_data
-bDongle	include/drv_types.h	/^	int	bDongle;\/* build-in module or external dongle *\/$/;"	m	struct:_ADAPTER
-bDriverIsGoingToUnload	include/drv_types.h	/^	u8	bDriverIsGoingToUnload;$/;"	m	struct:_ADAPTER
-bDriverStopped	include/drv_types.h	/^	ATOMIC_T	bDriverStopped;$/;"	m	struct:dvobj_priv
-bDualMacSmartConcurrent	hal/phydm/phydm.h	/^	BOOLEAN			bDualMacSmartConcurrent;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bDumpRxPkt	include/hal_data.h	/^	u8	bDumpRxPkt;$/;"	m	struct:hal_com_data
-bDumpTxPkt	include/hal_data.h	/^	u8	bDumpTxPkt;$/;"	m	struct:hal_com_data
-bEDCCA_H	include/Hal8188EPhyReg.h	817;"	d
-bEDCCA_H	include/Hal8188FPhyReg.h	825;"	d
-bEDCCA_H	include/Hal8192EPhyReg.h	828;"	d
-bEDCCA_H	include/Hal8703BPhyReg.h	854;"	d
-bEDCCA_H	include/Hal8723BPhyReg.h	852;"	d
-bEDCCA_H	include/Hal8723DPhyReg.h	855;"	d
-bEDCCA_H	include/rtw_mp_phy_regdef.h	771;"	d
-bEDCCA_Jaguar	include/Hal8812PhyReg.h	155;"	d
-bEDCCA_Jaguar	include/Hal8814PhyReg.h	185;"	d
-bEDCCA_L	include/Hal8188EPhyReg.h	818;"	d
-bEDCCA_L	include/Hal8188FPhyReg.h	826;"	d
-bEDCCA_L	include/Hal8192EPhyReg.h	829;"	d
-bEDCCA_L	include/Hal8703BPhyReg.h	855;"	d
-bEDCCA_L	include/Hal8723BPhyReg.h	853;"	d
-bEDCCA_L	include/Hal8723DPhyReg.h	856;"	d
-bEDCCA_L	include/rtw_mp_phy_regdef.h	772;"	d
-bED_TH2	include/Hal8188EPhyReg.h	778;"	d
-bED_TH2	include/Hal8188FPhyReg.h	786;"	d
-bED_TH2	include/Hal8192EPhyReg.h	789;"	d
-bED_TH2	include/Hal8703BPhyReg.h	815;"	d
-bED_TH2	include/Hal8723BPhyReg.h	813;"	d
-bED_TH2	include/Hal8723DPhyReg.h	816;"	d
-bED_TH2	include/rtw_mp_phy_regdef.h	732;"	d
-bEn	include/rtw_pwrctrl.h	/^	bool	bEn;$/;"	m	struct:lps_poff_info
-bEnIgnoreWlanAct	include/rtw_btcoex.h	/^	u8 bEnIgnoreWlanAct:1;$/;"	m	struct:btinfo_8761ATV
-bEnPMacTx	include/rtw_mp.h	/^	u8			bEnPMacTx:1;		\/* 0: Disable PMac 1: Enable PMac *\/$/;"	m	struct:_RT_PMAC_TX_INFO
-bEn_RFE	include/drv_types.h	/^	u8	bEn_RFE;$/;"	m	struct:registry_priv
-bEnable	hal/btc/Mp_Precomp.h	39;"	d
-bEnable	include/Hal8188EPhyReg.h	1065;"	d
-bEnable	include/Hal8188FPhyReg.h	1072;"	d
-bEnable	include/Hal8192EPhyReg.h	1079;"	d
-bEnable	include/Hal8703BPhyReg.h	1101;"	d
-bEnable	include/Hal8723BPhyReg.h	1099;"	d
-bEnable	include/Hal8723DPhyReg.h	1102;"	d
-bEnable	include/Hal8812PhyReg.h	708;"	d
-bEnable	include/Hal8814PhyReg.h	833;"	d
-bEnable	include/rtl8822b_hal.h	178;"	d
-bEnable	include/rtw_mp_phy_regdef.h	1036;"	d
-bEnableWifiScanNotify	include/rtw_btcoex.h	/^	BOOLEAN					bEnableWifiScanNotify;$/;"	m	struct:_HCI_EXT_CONFIG
-bEnterPOFF	include/rtw_pwrctrl.h	/^	ATOMIC_T bEnterPOFF;$/;"	m	struct:lps_poff_info
-bExtLNAGain	include/Hal8188EPhyReg.h	899;"	d
-bExtLNAGain	include/Hal8188FPhyReg.h	907;"	d
-bExtLNAGain	include/Hal8192EPhyReg.h	910;"	d
-bExtLNAGain	include/Hal8703BPhyReg.h	936;"	d
-bExtLNAGain	include/Hal8723BPhyReg.h	934;"	d
-bExtLNAGain	include/Hal8723DPhyReg.h	937;"	d
-bExtLNAGain	include/rtw_mp_phy_regdef.h	853;"	d
-bExtSigClkEnable	include/Hal8188EPhyReg.h	616;"	d
-bExtSigClkEnable	include/Hal8188FPhyReg.h	624;"	d
-bExtSigClkEnable	include/Hal8192EPhyReg.h	627;"	d
-bExtSigClkEnable	include/Hal8703BPhyReg.h	653;"	d
-bExtSigClkEnable	include/Hal8723BPhyReg.h	651;"	d
-bExtSigClkEnable	include/Hal8723DPhyReg.h	654;"	d
-bExtSigClkEnable	include/rtw_mp_phy_regdef.h	570;"	d
-bFC	include/Hal8188EPhyReg.h	991;"	d
-bFC	include/Hal8188FPhyReg.h	999;"	d
-bFC	include/Hal8192EPhyReg.h	1002;"	d
-bFC	include/Hal8703BPhyReg.h	1028;"	d
-bFC	include/Hal8723BPhyReg.h	1026;"	d
-bFC	include/Hal8723DPhyReg.h	1029;"	d
-bFC	include/rtw_mp_phy_regdef.h	945;"	d
-bFGuard_Counter_DC_L	include/Hal8188EPhyReg.h	786;"	d
-bFGuard_Counter_DC_L	include/Hal8188FPhyReg.h	794;"	d
-bFGuard_Counter_DC_L	include/Hal8192EPhyReg.h	797;"	d
-bFGuard_Counter_DC_L	include/Hal8703BPhyReg.h	823;"	d
-bFGuard_Counter_DC_L	include/Hal8723BPhyReg.h	821;"	d
-bFGuard_Counter_DC_L	include/Hal8723DPhyReg.h	824;"	d
-bFGuard_Counter_DC_L	include/rtw_mp_phy_regdef.h	740;"	d
-bFPGAPHY0_End	include/Hal8188EPhyReg.h	1080;"	d
-bFPGAPHY0_End	include/Hal8188FPhyReg.h	1087;"	d
-bFPGAPHY0_End	include/Hal8192EPhyReg.h	1094;"	d
-bFPGAPHY0_End	include/Hal8703BPhyReg.h	1116;"	d
-bFPGAPHY0_End	include/Hal8723BPhyReg.h	1114;"	d
-bFPGAPHY0_End	include/Hal8723DPhyReg.h	1117;"	d
-bFPGAPHY0_End	include/rtw_mp_phy_regdef.h	1051;"	d
-bFPGAPHY1_End	include/Hal8188EPhyReg.h	1081;"	d
-bFPGAPHY1_End	include/Hal8188FPhyReg.h	1088;"	d
-bFPGAPHY1_End	include/Hal8192EPhyReg.h	1095;"	d
-bFPGAPHY1_End	include/Hal8703BPhyReg.h	1117;"	d
-bFPGAPHY1_End	include/Hal8723BPhyReg.h	1115;"	d
-bFPGAPHY1_End	include/Hal8723DPhyReg.h	1118;"	d
-bFPGAPHY1_End	include/rtw_mp_phy_regdef.h	1052;"	d
-bFS_Option	include/Hal8188EPhyReg.h	784;"	d
-bFS_Option	include/Hal8188FPhyReg.h	792;"	d
-bFS_Option	include/Hal8192EPhyReg.h	795;"	d
-bFS_Option	include/Hal8703BPhyReg.h	821;"	d
-bFS_Option	include/Hal8723BPhyReg.h	819;"	d
-bFS_Option	include/Hal8723DPhyReg.h	822;"	d
-bFS_Option	include/rtw_mp_phy_regdef.h	738;"	d
-bFTP	core/rtw_cmd.c	/^	u8 bFTP:1;$/;"	m	struct:btinfo	file:
-bFTP	include/rtw_btcoex.h	/^	u8 bFTP:1;$/;"	m	struct:btinfo_8761ATV
-bFWReady	include/drv_types.h	/^	u8 bFWReady;$/;"	m	struct:_ADAPTER
-bFc_area_Jaguar	include/Hal8812PhyReg.h	161;"	d
-bFc_area_Jaguar	include/Hal8814PhyReg.h	191;"	d
-bFileMaskEfuse	include/drv_types.h	/^	BOOLEAN bFileMaskEfuse;$/;"	m	struct:registry_priv
-bFirstLink	hal/phydm/phydm_adaptivity.h	/^	BOOLEAN			bFirstLink;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-bForceACSResult	hal/phydm/phydm_acs.h	/^	BOOLEAN		bForceACSResult;$/;"	m	struct:_ACS_
-bForceXtalCap	hal/phydm/phydm_cfotracking.h	/^	BOOLEAN			bForceXtalCap;$/;"	m	struct:_CFO_TRACKING_
-bFrame_DC_Length	include/Hal8188EPhyReg.h	789;"	d
-bFrame_DC_Length	include/Hal8188FPhyReg.h	797;"	d
-bFrame_DC_Length	include/Hal8192EPhyReg.h	800;"	d
-bFrame_DC_Length	include/Hal8703BPhyReg.h	826;"	d
-bFrame_DC_Length	include/Hal8723BPhyReg.h	824;"	d
-bFrame_DC_Length	include/Hal8723DPhyReg.h	827;"	d
-bFrame_DC_Length	include/rtw_mp_phy_regdef.h	743;"	d
-bFrame_GI2_TH	include/Hal8188EPhyReg.h	792;"	d
-bFrame_GI2_TH	include/Hal8188FPhyReg.h	800;"	d
-bFrame_GI2_TH	include/Hal8192EPhyReg.h	803;"	d
-bFrame_GI2_TH	include/Hal8703BPhyReg.h	829;"	d
-bFrame_GI2_TH	include/Hal8723BPhyReg.h	827;"	d
-bFrame_GI2_TH	include/Hal8723DPhyReg.h	830;"	d
-bFrame_GI2_TH	include/rtw_mp_phy_regdef.h	746;"	d
-bFrame_TH	include/Hal8188EPhyReg.h	783;"	d
-bFrame_TH	include/Hal8188FPhyReg.h	791;"	d
-bFrame_TH	include/Hal8192EPhyReg.h	794;"	d
-bFrame_TH	include/Hal8703BPhyReg.h	820;"	d
-bFrame_TH	include/Hal8723BPhyReg.h	818;"	d
-bFrame_TH	include/Hal8723DPhyReg.h	821;"	d
-bFrame_TH	include/rtw_mp_phy_regdef.h	737;"	d
-bFrame_TH_2	include/Hal8188EPhyReg.h	791;"	d
-bFrame_TH_2	include/Hal8188FPhyReg.h	799;"	d
-bFrame_TH_2	include/Hal8192EPhyReg.h	802;"	d
-bFrame_TH_2	include/Hal8703BPhyReg.h	828;"	d
-bFrame_TH_2	include/Hal8723BPhyReg.h	826;"	d
-bFrame_TH_2	include/Hal8723DPhyReg.h	829;"	d
-bFrame_TH_2	include/rtw_mp_phy_regdef.h	745;"	d
-bFrame_Weight_Short	include/Hal8188EPhyReg.h	787;"	d
-bFrame_Weight_Short	include/Hal8188FPhyReg.h	795;"	d
-bFrame_Weight_Short	include/Hal8192EPhyReg.h	798;"	d
-bFrame_Weight_Short	include/Hal8703BPhyReg.h	824;"	d
-bFrame_Weight_Short	include/Hal8723BPhyReg.h	822;"	d
-bFrame_Weight_Short	include/Hal8723DPhyReg.h	825;"	d
-bFrame_Weight_Short	include/rtw_mp_phy_regdef.h	741;"	d
-bFwCurrentInPSMode	include/rtw_pwrctrl.h	/^	u8	bFwCurrentInPSMode;$/;"	m	struct:pwrctrl_priv
-bGI2_Sync_en	include/Hal8188EPhyReg.h	793;"	d
-bGI2_Sync_en	include/Hal8188FPhyReg.h	801;"	d
-bGI2_Sync_en	include/Hal8192EPhyReg.h	804;"	d
-bGI2_Sync_en	include/Hal8703BPhyReg.h	830;"	d
-bGI2_Sync_en	include/Hal8723BPhyReg.h	828;"	d
-bGI2_Sync_en	include/Hal8723DPhyReg.h	831;"	d
-bGI2_Sync_en	include/rtw_mp_phy_regdef.h	747;"	d
-bGI_TH	include/Hal8188EPhyReg.h	746;"	d
-bGI_TH	include/Hal8188FPhyReg.h	754;"	d
-bGI_TH	include/Hal8192EPhyReg.h	757;"	d
-bGI_TH	include/Hal8703BPhyReg.h	783;"	d
-bGI_TH	include/Hal8723BPhyReg.h	781;"	d
-bGI_TH	include/Hal8723DPhyReg.h	784;"	d
-bGI_TH	include/rtw_mp_phy_regdef.h	700;"	d
-bGetGateway	include/rtw_mlme.h	/^	u8 bGetGateway;$/;"	m	struct:mlme_priv
-bGlobalResetB	include/Hal8188EPhyReg.h	457;"	d
-bGlobalResetB	include/Hal8188FPhyReg.h	465;"	d
-bGlobalResetB	include/Hal8192EPhyReg.h	466;"	d
-bGlobalResetB	include/Hal8703BPhyReg.h	493;"	d
-bGlobalResetB	include/Hal8723BPhyReg.h	492;"	d
-bGlobalResetB	include/Hal8723DPhyReg.h	494;"	d
-bGlobalResetB	include/Hal8812PhyReg.h	324;"	d
-bGlobalResetB	include/Hal8814PhyReg.h	431;"	d
-bGlobalResetB	include/rtw_mp_phy_regdef.h	409;"	d
-bHID	core/rtw_cmd.c	/^	u8 bHID:1;$/;"	m	struct:btinfo	file:
-bHID	include/rtw_btcoex.h	/^	u8 bHID:1;$/;"	m	struct:btinfo_8761ATV
-bHSSIRead_addr_Jaguar	include/Hal8812PhyReg.h	63;"	d
-bHSSIRead_addr_Jaguar	include/Hal8814PhyReg.h	70;"	d
-bHSSIRead_trigger_Jaguar	include/Hal8812PhyReg.h	64;"	d
-bHSSIRead_trigger_Jaguar	include/Hal8814PhyReg.h	71;"	d
-bHSSI_R2TDelay	include/Hal8188EPhyReg.h	530;"	d
-bHSSI_R2TDelay	include/Hal8188FPhyReg.h	538;"	d
-bHSSI_R2TDelay	include/Hal8192EPhyReg.h	541;"	d
-bHSSI_R2TDelay	include/Hal8703BPhyReg.h	567;"	d
-bHSSI_R2TDelay	include/Hal8723BPhyReg.h	565;"	d
-bHSSI_R2TDelay	include/Hal8723DPhyReg.h	568;"	d
-bHSSI_R2TDelay	include/rtw_mp_phy_regdef.h	480;"	d
-bHSSI_T2RDelay	include/Hal8188EPhyReg.h	531;"	d
-bHSSI_T2RDelay	include/Hal8188FPhyReg.h	539;"	d
-bHSSI_T2RDelay	include/Hal8192EPhyReg.h	542;"	d
-bHSSI_T2RDelay	include/Hal8703BPhyReg.h	568;"	d
-bHSSI_T2RDelay	include/Hal8723BPhyReg.h	566;"	d
-bHSSI_T2RDelay	include/Hal8723DPhyReg.h	569;"	d
-bHSSI_T2RDelay	include/rtw_mp_phy_regdef.h	481;"	d
-bHTDetect	include/Hal8188EPhyReg.h	917;"	d
-bHTDetect	include/Hal8188FPhyReg.h	925;"	d
-bHTDetect	include/Hal8192EPhyReg.h	928;"	d
-bHTDetect	include/Hal8703BPhyReg.h	954;"	d
-bHTDetect	include/Hal8723BPhyReg.h	952;"	d
-bHTDetect	include/Hal8723DPhyReg.h	955;"	d
-bHTDetect	include/rtw_mp_phy_regdef.h	871;"	d
-bHTSIG1_BandWidth	include/Hal8188EPhyReg.h	576;"	d
-bHTSIG1_BandWidth	include/Hal8188FPhyReg.h	584;"	d
-bHTSIG1_BandWidth	include/Hal8192EPhyReg.h	587;"	d
-bHTSIG1_BandWidth	include/Hal8703BPhyReg.h	613;"	d
-bHTSIG1_BandWidth	include/Hal8723BPhyReg.h	611;"	d
-bHTSIG1_BandWidth	include/Hal8723DPhyReg.h	614;"	d
-bHTSIG1_BandWidth	include/rtw_mp_phy_regdef.h	526;"	d
-bHTSIG1_HTLength	include/Hal8188EPhyReg.h	577;"	d
-bHTSIG1_HTLength	include/Hal8188FPhyReg.h	585;"	d
-bHTSIG1_HTLength	include/Hal8192EPhyReg.h	588;"	d
-bHTSIG1_HTLength	include/Hal8703BPhyReg.h	614;"	d
-bHTSIG1_HTLength	include/Hal8723BPhyReg.h	612;"	d
-bHTSIG1_HTLength	include/Hal8723DPhyReg.h	615;"	d
-bHTSIG1_HTLength	include/rtw_mp_phy_regdef.h	527;"	d
-bHTSIG1_MCS	include/Hal8188EPhyReg.h	575;"	d
-bHTSIG1_MCS	include/Hal8188FPhyReg.h	583;"	d
-bHTSIG1_MCS	include/Hal8192EPhyReg.h	586;"	d
-bHTSIG1_MCS	include/Hal8703BPhyReg.h	612;"	d
-bHTSIG1_MCS	include/Hal8723BPhyReg.h	610;"	d
-bHTSIG1_MCS	include/Hal8723DPhyReg.h	613;"	d
-bHTSIG1_MCS	include/rtw_mp_phy_regdef.h	525;"	d
-bHTSIG2_AdvCoding	include/Hal8188EPhyReg.h	572;"	d
-bHTSIG2_AdvCoding	include/Hal8188FPhyReg.h	580;"	d
-bHTSIG2_AdvCoding	include/Hal8192EPhyReg.h	583;"	d
-bHTSIG2_AdvCoding	include/Hal8703BPhyReg.h	609;"	d
-bHTSIG2_AdvCoding	include/Hal8723BPhyReg.h	607;"	d
-bHTSIG2_AdvCoding	include/Hal8723DPhyReg.h	610;"	d
-bHTSIG2_AdvCoding	include/rtw_mp_phy_regdef.h	522;"	d
-bHTSIG2_Aggreaton	include/Hal8188EPhyReg.h	570;"	d
-bHTSIG2_Aggreaton	include/Hal8188FPhyReg.h	578;"	d
-bHTSIG2_Aggreaton	include/Hal8192EPhyReg.h	581;"	d
-bHTSIG2_Aggreaton	include/Hal8703BPhyReg.h	607;"	d
-bHTSIG2_Aggreaton	include/Hal8723BPhyReg.h	605;"	d
-bHTSIG2_Aggreaton	include/Hal8723DPhyReg.h	608;"	d
-bHTSIG2_Aggreaton	include/rtw_mp_phy_regdef.h	520;"	d
-bHTSIG2_CRC8	include/Hal8188EPhyReg.h	574;"	d
-bHTSIG2_CRC8	include/Hal8188FPhyReg.h	582;"	d
-bHTSIG2_CRC8	include/Hal8192EPhyReg.h	585;"	d
-bHTSIG2_CRC8	include/Hal8703BPhyReg.h	611;"	d
-bHTSIG2_CRC8	include/Hal8723BPhyReg.h	609;"	d
-bHTSIG2_CRC8	include/Hal8723DPhyReg.h	612;"	d
-bHTSIG2_CRC8	include/rtw_mp_phy_regdef.h	524;"	d
-bHTSIG2_GI	include/Hal8188EPhyReg.h	567;"	d
-bHTSIG2_GI	include/Hal8188FPhyReg.h	575;"	d
-bHTSIG2_GI	include/Hal8192EPhyReg.h	578;"	d
-bHTSIG2_GI	include/Hal8703BPhyReg.h	604;"	d
-bHTSIG2_GI	include/Hal8723BPhyReg.h	602;"	d
-bHTSIG2_GI	include/Hal8723DPhyReg.h	605;"	d
-bHTSIG2_GI	include/rtw_mp_phy_regdef.h	517;"	d
-bHTSIG2_NumOfHTLTF	include/Hal8188EPhyReg.h	573;"	d
-bHTSIG2_NumOfHTLTF	include/Hal8188FPhyReg.h	581;"	d
-bHTSIG2_NumOfHTLTF	include/Hal8192EPhyReg.h	584;"	d
-bHTSIG2_NumOfHTLTF	include/Hal8703BPhyReg.h	610;"	d
-bHTSIG2_NumOfHTLTF	include/Hal8723BPhyReg.h	608;"	d
-bHTSIG2_NumOfHTLTF	include/Hal8723DPhyReg.h	611;"	d
-bHTSIG2_NumOfHTLTF	include/rtw_mp_phy_regdef.h	523;"	d
-bHTSIG2_STBC	include/Hal8188EPhyReg.h	571;"	d
-bHTSIG2_STBC	include/Hal8188FPhyReg.h	579;"	d
-bHTSIG2_STBC	include/Hal8192EPhyReg.h	582;"	d
-bHTSIG2_STBC	include/Hal8703BPhyReg.h	608;"	d
-bHTSIG2_STBC	include/Hal8723BPhyReg.h	606;"	d
-bHTSIG2_STBC	include/Hal8723DPhyReg.h	609;"	d
-bHTSIG2_STBC	include/rtw_mp_phy_regdef.h	521;"	d
-bHTSIG2_Smoothing	include/Hal8188EPhyReg.h	568;"	d
-bHTSIG2_Smoothing	include/Hal8188FPhyReg.h	576;"	d
-bHTSIG2_Smoothing	include/Hal8192EPhyReg.h	579;"	d
-bHTSIG2_Smoothing	include/Hal8703BPhyReg.h	605;"	d
-bHTSIG2_Smoothing	include/Hal8723BPhyReg.h	603;"	d
-bHTSIG2_Smoothing	include/Hal8723DPhyReg.h	606;"	d
-bHTSIG2_Smoothing	include/rtw_mp_phy_regdef.h	518;"	d
-bHTSIG2_Sounding	include/Hal8188EPhyReg.h	569;"	d
-bHTSIG2_Sounding	include/Hal8188FPhyReg.h	577;"	d
-bHTSIG2_Sounding	include/Hal8192EPhyReg.h	580;"	d
-bHTSIG2_Sounding	include/Hal8703BPhyReg.h	606;"	d
-bHTSIG2_Sounding	include/Hal8723BPhyReg.h	604;"	d
-bHTSIG2_Sounding	include/Hal8723DPhyReg.h	607;"	d
-bHTSIG2_Sounding	include/rtw_mp_phy_regdef.h	519;"	d
-bHWPowerdown	include/rtw_pwrctrl.h	/^	u8		bHWPowerdown; \/* power down mode selection. 0:radio off, 1:power down *\/$/;"	m	struct:pwrctrl_priv
-bHWPwrPindetect	include/rtw_pwrctrl.h	/^	u8		bHWPwrPindetect; \/* come from registrypriv.hwpwrp_detect. enable power down function. 0:disable, 1:enable *\/$/;"	m	struct:pwrctrl_priv
-bHaltInProgress	include/drv_types.h	/^	u8	bHaltInProgress;$/;"	m	struct:_ADAPTER
-bHigherBusyRxTraffic	include/rtw_mlme.h	/^	BOOLEAN			bHigherBusyRxTraffic; \/* We may disable Tx interrupt according as Rx traffic. *\/$/;"	m	struct:_RT_LINK_DETECT_T
-bHigherBusyTraffic	include/rtw_mlme.h	/^	BOOLEAN			bHigherBusyTraffic; \/* For interrupt migration purpose. *\/$/;"	m	struct:_RT_LINK_DETECT_T
-bHigherBusyTxTraffic	include/rtw_mlme.h	/^	BOOLEAN			bHigherBusyTxTraffic; \/* We may disable Tx interrupt according as Tx traffic. *\/$/;"	m	struct:_RT_LINK_DETECT_T
-bHoldForStackOperation	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN					bHoldForStackOperation;$/;"	m	struct:_COEX_STA_8723A_2ANT
-bHoldPeriodCnt	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					bHoldPeriodCnt;$/;"	m	struct:_COEX_STA_8723A_2ANT
-bIGFromCCK	include/Hal8188EPhyReg.h	533;"	d
-bIGFromCCK	include/Hal8188FPhyReg.h	541;"	d
-bIGFromCCK	include/Hal8192EPhyReg.h	544;"	d
-bIGFromCCK	include/Hal8703BPhyReg.h	570;"	d
-bIGFromCCK	include/Hal8723BPhyReg.h	568;"	d
-bIGFromCCK	include/Hal8723DPhyReg.h	571;"	d
-bIGFromCCK	include/rtw_mp_phy_regdef.h	483;"	d
-bIPathLoopback	include/Hal8188EPhyReg.h	621;"	d
-bIPathLoopback	include/Hal8188FPhyReg.h	629;"	d
-bIPathLoopback	include/Hal8192EPhyReg.h	632;"	d
-bIPathLoopback	include/Hal8703BPhyReg.h	658;"	d
-bIPathLoopback	include/Hal8723BPhyReg.h	656;"	d
-bIPathLoopback	include/Hal8723DPhyReg.h	659;"	d
-bIPathLoopback	include/rtw_mp_phy_regdef.h	575;"	d
-bIQKDone	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN 	bIQKDone;$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-bIQKDone	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN 	bIQKDone;$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-bIQKDone	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN 	bIQKDone;$/;"	m	struct:_IQK_MATRIX_REGS_SETTING
-bIQKInProgress	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	bIQKInProgress;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKInProgress	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN	bIQKInProgress;	$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKInProgress	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN	bIQKInProgress;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKInitialized	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	bIQKInitialized;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKInitialized	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN	bIQKInitialized;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKInitialized	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN	bIQKInitialized;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKInitialized	include/hal_data.h	/^	u8			bIQKInitialized;$/;"	m	struct:hal_com_data
-bIQKPAoff	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	bIQKPAoff;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKPAoff	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN bIQKPAoff;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQKPAoff	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN	bIQKPAoff;$/;"	m	struct:ODM_RF_Calibration_Structure
-bIQPathControl	include/Hal8188EPhyReg.h	640;"	d
-bIQPathControl	include/Hal8188FPhyReg.h	648;"	d
-bIQPathControl	include/Hal8192EPhyReg.h	651;"	d
-bIQPathControl	include/Hal8703BPhyReg.h	677;"	d
-bIQPathControl	include/Hal8723BPhyReg.h	675;"	d
-bIQPathControl	include/Hal8723DPhyReg.h	678;"	d
-bIQPathControl	include/rtw_mp_phy_regdef.h	594;"	d
-bIfMF_Win_L	include/Hal8188EPhyReg.h	772;"	d
-bIfMF_Win_L	include/Hal8188FPhyReg.h	780;"	d
-bIfMF_Win_L	include/Hal8192EPhyReg.h	783;"	d
-bIfMF_Win_L	include/Hal8703BPhyReg.h	809;"	d
-bIfMF_Win_L	include/Hal8723BPhyReg.h	807;"	d
-bIfMF_Win_L	include/Hal8723DPhyReg.h	810;"	d
-bIfMF_Win_L	include/rtw_mp_phy_regdef.h	726;"	d
-bIgnoreDIG	hal/phydm/phydm_dig.h	/^	BOOLEAN		bIgnoreDIG;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bInHctTest	hal/phydm/phydm.h	/^	BOOLEAN			bInHctTest;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bInQPage	core/rtw_cmd.c	/^	u8 bInQPage:1;$/;"	m	struct:btinfo	file:
-bInQPage	include/rtw_btcoex.h	/^	u8 bInQPage:1;$/;"	m	struct:btinfo_8761ATV
-bInSuspend	include/rtw_pwrctrl.h	/^	u8		bInSuspend;$/;"	m	struct:pwrctrl_priv
-bInitHwInfoByRfe	hal/phydm/phydm.h	/^	BOOLEAN			bInitHwInfoByRfe;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bInitlized	include/hal_btcoex.h	/^	u8 bInitlized;$/;"	m	struct:_BT_COEXIST
-bIntDifClkEnable	include/Hal8188EPhyReg.h	615;"	d
-bIntDifClkEnable	include/Hal8188FPhyReg.h	623;"	d
-bIntDifClkEnable	include/Hal8192EPhyReg.h	626;"	d
-bIntDifClkEnable	include/Hal8703BPhyReg.h	652;"	d
-bIntDifClkEnable	include/Hal8723BPhyReg.h	650;"	d
-bIntDifClkEnable	include/Hal8723DPhyReg.h	653;"	d
-bIntDifClkEnable	include/rtw_mp_phy_regdef.h	569;"	d
-bInternalAutoSuspend	include/rtw_pwrctrl.h	/^	u8		bInternalAutoSuspend;$/;"	m	struct:pwrctrl_priv
-bInterruptMigration	include/hal_data.h	/^	u8			bInterruptMigration;$/;"	m	struct:hal_com_data
-bIntf_win_len_cfg	include/Hal8188EPhyReg.h	946;"	d
-bIntf_win_len_cfg	include/Hal8188FPhyReg.h	954;"	d
-bIntf_win_len_cfg	include/Hal8192EPhyReg.h	957;"	d
-bIntf_win_len_cfg	include/Hal8703BPhyReg.h	983;"	d
-bIntf_win_len_cfg	include/Hal8723BPhyReg.h	981;"	d
-bIntf_win_len_cfg	include/Hal8723DPhyReg.h	984;"	d
-bIntf_win_len_cfg	include/rtw_mp_phy_regdef.h	900;"	d
-bIsAnyNonBEPkts	include/rtw_recv.h	/^	u32	bIsAnyNonBEPkts;$/;"	m	struct:recv_priv
-bIsCurRDLState	hal/phydm/phydm_edcaturbocheck.h	/^	BOOLEAN bIsCurRDLState;$/;"	m	struct:_EDCA_TURBO_
-bIsMPChip	hal/phydm/phydm.h	/^	BOOLEAN			bIsMPChip;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bIsWaiPacket	include/rtw_recv.h	/^	u8 bIsWaiPacket;$/;"	m	struct:recv_frame_hdr
-bJapanMode	include/Hal8188EPhyReg.h	505;"	d
-bJapanMode	include/Hal8188FPhyReg.h	513;"	d
-bJapanMode	include/Hal8192EPhyReg.h	516;"	d
-bJapanMode	include/Hal8703BPhyReg.h	542;"	d
-bJapanMode	include/Hal8723BPhyReg.h	540;"	d
-bJapanMode	include/Hal8723DPhyReg.h	543;"	d
-bJapanMode	include/Hal8812PhyReg.h	603;"	d
-bJapanMode	include/Hal8814PhyReg.h	726;"	d
-bJapanMode	include/rtw_mp_phy_regdef.h	457;"	d
-bL1OffSupport	include/hal_data.h	/^	BOOLEAN		bL1OffSupport;$/;"	m	struct:hal_com_data
-bLCKInProgress	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN bLCKInProgress;$/;"	m	struct:ODM_RF_Calibration_Structure
-bLCKInProgress	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN bLCKInProgress;$/;"	m	struct:ODM_RF_Calibration_Structure
-bLCKInProgress	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN bLCKInProgress;$/;"	m	struct:ODM_RF_Calibration_Structure
-bLDPC	include/rtw_mp.h	/^	u8			bLDPC:1;$/;"	m	struct:_RT_PMAC_TX_INFO
-bLSIG_Length	include/Hal8188EPhyReg.h	580;"	d
-bLSIG_Length	include/Hal8188FPhyReg.h	588;"	d
-bLSIG_Length	include/Hal8192EPhyReg.h	591;"	d
-bLSIG_Length	include/Hal8703BPhyReg.h	617;"	d
-bLSIG_Length	include/Hal8723BPhyReg.h	615;"	d
-bLSIG_Length	include/Hal8723DPhyReg.h	618;"	d
-bLSIG_Length	include/rtw_mp_phy_regdef.h	530;"	d
-bLSIG_Parity	include/Hal8188EPhyReg.h	581;"	d
-bLSIG_Parity	include/Hal8188FPhyReg.h	589;"	d
-bLSIG_Parity	include/Hal8192EPhyReg.h	592;"	d
-bLSIG_Parity	include/Hal8703BPhyReg.h	618;"	d
-bLSIG_Parity	include/Hal8723BPhyReg.h	616;"	d
-bLSIG_Parity	include/Hal8723DPhyReg.h	619;"	d
-bLSIG_Parity	include/rtw_mp_phy_regdef.h	531;"	d
-bLSIG_Rate	include/Hal8188EPhyReg.h	578;"	d
-bLSIG_Rate	include/Hal8188FPhyReg.h	586;"	d
-bLSIG_Rate	include/Hal8192EPhyReg.h	589;"	d
-bLSIG_Rate	include/Hal8703BPhyReg.h	615;"	d
-bLSIG_Rate	include/Hal8723BPhyReg.h	613;"	d
-bLSIG_Rate	include/Hal8723DPhyReg.h	616;"	d
-bLSIG_Rate	include/rtw_mp_phy_regdef.h	528;"	d
-bLSIG_Reserved	include/Hal8188EPhyReg.h	579;"	d
-bLSIG_Reserved	include/Hal8188FPhyReg.h	587;"	d
-bLSIG_Reserved	include/Hal8192EPhyReg.h	590;"	d
-bLSIG_Reserved	include/Hal8703BPhyReg.h	616;"	d
-bLSIG_Reserved	include/Hal8723BPhyReg.h	614;"	d
-bLSIG_Reserved	include/Hal8723DPhyReg.h	617;"	d
-bLSIG_Reserved	include/rtw_mp_phy_regdef.h	529;"	d
-bLSSIReadAddress	include/Hal8188EPhyReg.h	584;"	d
-bLSSIReadAddress	include/Hal8188FPhyReg.h	592;"	d
-bLSSIReadAddress	include/Hal8192EPhyReg.h	595;"	d
-bLSSIReadAddress	include/Hal8703BPhyReg.h	621;"	d
-bLSSIReadAddress	include/Hal8723BPhyReg.h	619;"	d
-bLSSIReadAddress	include/Hal8723DPhyReg.h	622;"	d
-bLSSIReadAddress	include/rtw_mp_phy_regdef.h	534;"	d
-bLSSIReadAddress	include/rtw_mp_phy_regdef.h	536;"	d
-bLSSIReadBackData	include/Hal8188EPhyReg.h	588;"	d
-bLSSIReadBackData	include/Hal8188FPhyReg.h	596;"	d
-bLSSIReadBackData	include/Hal8192EPhyReg.h	599;"	d
-bLSSIReadBackData	include/Hal8703BPhyReg.h	625;"	d
-bLSSIReadBackData	include/Hal8723BPhyReg.h	623;"	d
-bLSSIReadBackData	include/Hal8723DPhyReg.h	626;"	d
-bLSSIReadBackData	include/rtw_mp_phy_regdef.h	540;"	d
-bLSSIReadBackData	include/rtw_mp_phy_regdef.h	542;"	d
-bLSSIReadEdge	include/Hal8188EPhyReg.h	586;"	d
-bLSSIReadEdge	include/Hal8188FPhyReg.h	594;"	d
-bLSSIReadEdge	include/Hal8192EPhyReg.h	597;"	d
-bLSSIReadEdge	include/Hal8703BPhyReg.h	623;"	d
-bLSSIReadEdge	include/Hal8723BPhyReg.h	621;"	d
-bLSSIReadEdge	include/Hal8723DPhyReg.h	624;"	d
-bLSSIReadEdge	include/rtw_mp_phy_regdef.h	538;"	d
-bLSSIReadOKFlag	include/Hal8188EPhyReg.h	590;"	d
-bLSSIReadOKFlag	include/Hal8188FPhyReg.h	598;"	d
-bLSSIReadOKFlag	include/Hal8192EPhyReg.h	601;"	d
-bLSSIReadOKFlag	include/Hal8703BPhyReg.h	627;"	d
-bLSSIReadOKFlag	include/Hal8723BPhyReg.h	625;"	d
-bLSSIReadOKFlag	include/Hal8723DPhyReg.h	628;"	d
-bLSSIReadOKFlag	include/rtw_mp_phy_regdef.h	544;"	d
-bLSSIWrite_addr_Jaguar	include/Hal8812PhyReg.h	73;"	d
-bLSSIWrite_addr_Jaguar	include/Hal8814PhyReg.h	80;"	d
-bLSSIWrite_data_Jaguar	include/Hal8812PhyReg.h	72;"	d
-bLSSIWrite_data_Jaguar	include/Hal8814PhyReg.h	79;"	d
-bLambda_ED	include/Hal8188EPhyReg.h	819;"	d
-bLambda_ED	include/Hal8188FPhyReg.h	827;"	d
-bLambda_ED	include/Hal8192EPhyReg.h	830;"	d
-bLambda_ED	include/Hal8703BPhyReg.h	856;"	d
-bLambda_ED	include/Hal8723BPhyReg.h	854;"	d
-bLambda_ED	include/Hal8723DPhyReg.h	857;"	d
-bLambda_ED	include/rtw_mp_phy_regdef.h	773;"	d
-bLdpcPkt	hal/phydm/phydm.h	/^	BOOLEAN		bLdpcPkt;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-bLedBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedBlinkInProgress; \/* TRUE if it is blinking, FALSE o.w.. *\/$/;"	m	struct:_LED_SDIO
-bLedBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedBlinkInProgress; \/* TRUE if it is blinking, FALSE o.w.. *\/$/;"	m	struct:_LED_USB
-bLedBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN			bLedBlinkInProgress; \/* TRUE if it is blinking, FALSE o.w.. *\/$/;"	m	struct:_LED_PCIE
-bLedLinkBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedLinkBlinkInProgress;$/;"	m	struct:_LED_SDIO
-bLedLinkBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedLinkBlinkInProgress;$/;"	m	struct:_LED_USB
-bLedNoLinkBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedNoLinkBlinkInProgress;$/;"	m	struct:_LED_SDIO
-bLedNoLinkBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedNoLinkBlinkInProgress;$/;"	m	struct:_LED_USB
-bLedOn	include/hal_com_led.h	/^	BOOLEAN				bLedOn; \/* TRUE if LED is ON, FALSE if LED is OFF. *\/$/;"	m	struct:_LED_SDIO
-bLedOn	include/hal_com_led.h	/^	BOOLEAN				bLedOn; \/* TRUE if LED is ON, FALSE if LED is OFF. *\/$/;"	m	struct:_LED_USB
-bLedOn	include/hal_com_led.h	/^	BOOLEAN			bLedOn; \/* TRUE if LED is ON, FALSE if LED is OFF. *\/$/;"	m	struct:_LED_PCIE
-bLedOpenDrain	include/hal_data.h	/^	u8	bLedOpenDrain; \/* Support Open-drain arrangement for controlling the LED. Added by Roger, 2009.10.16. *\/$/;"	m	struct:hal_com_data
-bLedScanBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedScanBlinkInProgress;$/;"	m	struct:_LED_SDIO
-bLedScanBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedScanBlinkInProgress;$/;"	m	struct:_LED_USB
-bLedSlowBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN			bLedSlowBlinkInProgress;\/* added by vivi, for led new mode *\/$/;"	m	struct:_LED_PCIE
-bLedStartToLinkBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedStartToLinkBlinkInProgress;$/;"	m	struct:_LED_SDIO
-bLedStartToLinkBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedStartToLinkBlinkInProgress;$/;"	m	struct:_LED_USB
-bLedWPSBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedWPSBlinkInProgress;$/;"	m	struct:_LED_SDIO
-bLedWPSBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN				bLedWPSBlinkInProgress;$/;"	m	struct:_LED_USB
-bLedWPSBlinkInProgress	include/hal_com_led.h	/^	BOOLEAN			bLedWPSBlinkInProgress; \/* TRUE if it is blinking, FALSE o.w.. *\/$/;"	m	struct:_LED_PCIE
-bLeisurePs	include/rtw_pwrctrl.h	/^	u8	bLeisurePs;$/;"	m	struct:pwrctrl_priv
-bLimitedDig	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bLimitedDig;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bLimitedDig	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bLimitedDig;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bLinkInProcess	hal/phydm/phydm.h	/^	BOOLEAN			bLinkInProcess;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bLinkInfoDump	include/drv_types.h	/^	u8 bLinkInfoDump;$/;"	m	struct:_ADAPTER
-bLinked	hal/phydm/phydm.h	/^	BOOLEAN			bLinked;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bLogLinkInProgress	include/rtw_btcoex.h	/^	BOOLEAN				bLogLinkInProgress;$/;"	m	struct:_BT_MGNT
-bLongCFO	include/Hal8188EPhyReg.h	931;"	d
-bLongCFO	include/Hal8188FPhyReg.h	939;"	d
-bLongCFO	include/Hal8192EPhyReg.h	942;"	d
-bLongCFO	include/Hal8703BPhyReg.h	968;"	d
-bLongCFO	include/Hal8723BPhyReg.h	966;"	d
-bLongCFO	include/Hal8723DPhyReg.h	969;"	d
-bLongCFO	include/rtw_mp_phy_regdef.h	885;"	d
-bLongCFOFLength	include/Hal8188EPhyReg.h	933;"	d
-bLongCFOFLength	include/Hal8188FPhyReg.h	941;"	d
-bLongCFOFLength	include/Hal8192EPhyReg.h	944;"	d
-bLongCFOFLength	include/Hal8703BPhyReg.h	970;"	d
-bLongCFOFLength	include/Hal8723BPhyReg.h	968;"	d
-bLongCFOFLength	include/Hal8723DPhyReg.h	971;"	d
-bLongCFOFLength	include/rtw_mp_phy_regdef.h	887;"	d
-bLongCFOTLength	include/Hal8188EPhyReg.h	932;"	d
-bLongCFOTLength	include/Hal8188FPhyReg.h	940;"	d
-bLongCFOTLength	include/Hal8192EPhyReg.h	943;"	d
-bLongCFOTLength	include/Hal8703BPhyReg.h	969;"	d
-bLongCFOTLength	include/Hal8723BPhyReg.h	967;"	d
-bLongCFOTLength	include/Hal8723DPhyReg.h	970;"	d
-bLongCFOTLength	include/rtw_mp_phy_regdef.h	886;"	d
-bLoopFitType	include/Hal8188EPhyReg.h	985;"	d
-bLoopFitType	include/Hal8188FPhyReg.h	993;"	d
-bLoopFitType	include/Hal8192EPhyReg.h	996;"	d
-bLoopFitType	include/Hal8703BPhyReg.h	1022;"	d
-bLoopFitType	include/Hal8723BPhyReg.h	1020;"	d
-bLoopFitType	include/Hal8723DPhyReg.h	1023;"	d
-bLoopFitType	include/rtw_mp_phy_regdef.h	939;"	d
-bLowerRtsRate	hal/phydm/phydm_rainfo.h	/^	BOOLEAN				bLowerRtsRate;$/;"	m	struct:_ODM_RATE_ADAPTIVE
-bMFWeightSum	include/Hal8188EPhyReg.h	891;"	d
-bMFWeightSum	include/Hal8188FPhyReg.h	899;"	d
-bMFWeightSum	include/Hal8192EPhyReg.h	902;"	d
-bMFWeightSum	include/Hal8703BPhyReg.h	928;"	d
-bMFWeightSum	include/Hal8723BPhyReg.h	926;"	d
-bMFWeightSum	include/Hal8723DPhyReg.h	929;"	d
-bMFWeightSum	include/rtw_mp_phy_regdef.h	845;"	d
-bMF_Win_L	include/Hal8188EPhyReg.h	774;"	d
-bMF_Win_L	include/Hal8188FPhyReg.h	782;"	d
-bMF_Win_L	include/Hal8192EPhyReg.h	785;"	d
-bMF_Win_L	include/Hal8703BPhyReg.h	811;"	d
-bMF_Win_L	include/Hal8723BPhyReg.h	809;"	d
-bMF_Win_L	include/Hal8723DPhyReg.h	812;"	d
-bMF_Win_L	include/rtw_mp_phy_regdef.h	728;"	d
-bMPh2c_timeout	include/rtw_mp.h	/^	BOOLEAN		bMPh2c_timeout;$/;"	m	struct:_MPT_CONTEXT
-bMRCMode	include/Hal8188EPhyReg.h	982;"	d
-bMRCMode	include/Hal8188FPhyReg.h	990;"	d
-bMRCMode	include/Hal8192EPhyReg.h	993;"	d
-bMRCMode	include/Hal8703BPhyReg.h	1019;"	d
-bMRCMode	include/Hal8723BPhyReg.h	1017;"	d
-bMRCMode	include/Hal8723DPhyReg.h	1020;"	d
-bMRCMode	include/rtw_mp_phy_regdef.h	936;"	d
-bMacPwrCtrlOn	include/hal_data.h	/^	u8	bMacPwrCtrlOn;$/;"	m	struct:hal_com_data
-bMask12Bits	include/Hal8188EPhyReg.h	1058;"	d
-bMask12Bits	include/Hal8188FPhyReg.h	1066;"	d
-bMask12Bits	include/Hal8192EPhyReg.h	1069;"	d
-bMask12Bits	include/Hal8703BPhyReg.h	1095;"	d
-bMask12Bits	include/Hal8723BPhyReg.h	1093;"	d
-bMask12Bits	include/Hal8723DPhyReg.h	1096;"	d
-bMask12Bits	include/Hal8812PhyReg.h	729;"	d
-bMask12Bits	include/Hal8814PhyReg.h	854;"	d
-bMask12Bits	include/rtw_mp_phy_regdef.h	1024;"	d
-bMask7bits	include/Hal8814PhyReg.h	858;"	d
-bMaskByte0	include/Hal8188EPhyReg.h	1050;"	d
-bMaskByte0	include/Hal8188FPhyReg.h	1058;"	d
-bMaskByte0	include/Hal8192EPhyReg.h	1061;"	d
-bMaskByte0	include/Hal8703BPhyReg.h	1087;"	d
-bMaskByte0	include/Hal8723BPhyReg.h	1085;"	d
-bMaskByte0	include/Hal8723DPhyReg.h	1088;"	d
-bMaskByte0	include/Hal8812PhyReg.h	721;"	d
-bMaskByte0	include/Hal8814PhyReg.h	846;"	d
-bMaskByte0	include/rtl8822b_hal.h	170;"	d
-bMaskByte0	include/rtw_mp_phy_regdef.h	1013;"	d
-bMaskByte1	include/Hal8188EPhyReg.h	1051;"	d
-bMaskByte1	include/Hal8188FPhyReg.h	1059;"	d
-bMaskByte1	include/Hal8192EPhyReg.h	1062;"	d
-bMaskByte1	include/Hal8703BPhyReg.h	1088;"	d
-bMaskByte1	include/Hal8723BPhyReg.h	1086;"	d
-bMaskByte1	include/Hal8723DPhyReg.h	1089;"	d
-bMaskByte1	include/Hal8812PhyReg.h	722;"	d
-bMaskByte1	include/Hal8814PhyReg.h	847;"	d
-bMaskByte1	include/rtl8822b_hal.h	171;"	d
-bMaskByte1	include/rtw_mp_phy_regdef.h	1014;"	d
-bMaskByte2	include/Hal8188EPhyReg.h	1052;"	d
-bMaskByte2	include/Hal8188FPhyReg.h	1060;"	d
-bMaskByte2	include/Hal8192EPhyReg.h	1063;"	d
-bMaskByte2	include/Hal8703BPhyReg.h	1089;"	d
-bMaskByte2	include/Hal8723BPhyReg.h	1087;"	d
-bMaskByte2	include/Hal8723DPhyReg.h	1090;"	d
-bMaskByte2	include/Hal8812PhyReg.h	723;"	d
-bMaskByte2	include/Hal8814PhyReg.h	848;"	d
-bMaskByte2	include/rtl8822b_hal.h	172;"	d
-bMaskByte2	include/rtw_mp_phy_regdef.h	1015;"	d
-bMaskByte2HighNibble	include/Hal8814PhyReg.h	859;"	d
-bMaskByte3	include/Hal8188EPhyReg.h	1053;"	d
-bMaskByte3	include/Hal8188FPhyReg.h	1061;"	d
-bMaskByte3	include/Hal8192EPhyReg.h	1064;"	d
-bMaskByte3	include/Hal8703BPhyReg.h	1090;"	d
-bMaskByte3	include/Hal8723BPhyReg.h	1088;"	d
-bMaskByte3	include/Hal8723DPhyReg.h	1091;"	d
-bMaskByte3	include/Hal8812PhyReg.h	724;"	d
-bMaskByte3	include/Hal8814PhyReg.h	849;"	d
-bMaskByte3	include/rtl8822b_hal.h	173;"	d
-bMaskByte3	include/rtw_mp_phy_regdef.h	1016;"	d
-bMaskByte3LowNibble	include/Hal8814PhyReg.h	860;"	d
-bMaskCCK	include/Hal8188EPhyReg.h	1061;"	d
-bMaskCCK	include/Hal8188FPhyReg.h	1069;"	d
-bMaskCCK	include/Hal8192EPhyReg.h	1072;"	d
-bMaskCCK	include/Hal8703BPhyReg.h	1098;"	d
-bMaskCCK	include/Hal8723BPhyReg.h	1096;"	d
-bMaskCCK	include/Hal8723DPhyReg.h	1099;"	d
-bMaskCCK	include/Hal8812PhyReg.h	732;"	d
-bMaskCCK	include/Hal8814PhyReg.h	857;"	d
-bMaskCCK	include/rtw_mp_phy_regdef.h	1023;"	d
-bMaskDWord	include/Hal8188EPhyReg.h	1056;"	d
-bMaskDWord	include/Hal8188FPhyReg.h	1064;"	d
-bMaskDWord	include/Hal8192EPhyReg.h	1067;"	d
-bMaskDWord	include/Hal8703BPhyReg.h	1093;"	d
-bMaskDWord	include/Hal8723BPhyReg.h	1091;"	d
-bMaskDWord	include/Hal8723DPhyReg.h	1094;"	d
-bMaskDWord	include/Hal8812PhyReg.h	727;"	d
-bMaskDWord	include/Hal8814PhyReg.h	852;"	d
-bMaskDWord	include/rtl8822b_hal.h	176;"	d
-bMaskDWord	include/rtw_mp_phy_regdef.h	1019;"	d
-bMaskH3Bytes	hal/phydm/phydm_types.h	123;"	d
-bMaskH3Bytes	include/Hal8188EPhyReg.h	1057;"	d
-bMaskH3Bytes	include/Hal8188FPhyReg.h	1065;"	d
-bMaskH3Bytes	include/Hal8192EPhyReg.h	1068;"	d
-bMaskH3Bytes	include/Hal8703BPhyReg.h	1094;"	d
-bMaskH3Bytes	include/Hal8723BPhyReg.h	1092;"	d
-bMaskH3Bytes	include/Hal8723DPhyReg.h	1095;"	d
-bMaskH3Bytes	include/Hal8812PhyReg.h	728;"	d
-bMaskH3Bytes	include/Hal8814PhyReg.h	853;"	d
-bMaskH3Bytes	include/rtw_mp_phy_regdef.h	1021;"	d
-bMaskH4Bits	include/Hal8188EPhyReg.h	1059;"	d
-bMaskH4Bits	include/Hal8188FPhyReg.h	1067;"	d
-bMaskH4Bits	include/Hal8192EPhyReg.h	1070;"	d
-bMaskH4Bits	include/Hal8703BPhyReg.h	1096;"	d
-bMaskH4Bits	include/Hal8723BPhyReg.h	1094;"	d
-bMaskH4Bits	include/Hal8723DPhyReg.h	1097;"	d
-bMaskH4Bits	include/Hal8812PhyReg.h	730;"	d
-bMaskH4Bits	include/Hal8814PhyReg.h	855;"	d
-bMaskH4Bits	include/rtw_mp_phy_regdef.h	1020;"	d
-bMaskHWord	include/Hal8188EPhyReg.h	1054;"	d
-bMaskHWord	include/Hal8188FPhyReg.h	1062;"	d
-bMaskHWord	include/Hal8192EPhyReg.h	1065;"	d
-bMaskHWord	include/Hal8703BPhyReg.h	1091;"	d
-bMaskHWord	include/Hal8723BPhyReg.h	1089;"	d
-bMaskHWord	include/Hal8723DPhyReg.h	1092;"	d
-bMaskHWord	include/Hal8812PhyReg.h	725;"	d
-bMaskHWord	include/Hal8814PhyReg.h	850;"	d
-bMaskHWord	include/rtl8822b_hal.h	174;"	d
-bMaskHWord	include/rtw_mp_phy_regdef.h	1017;"	d
-bMaskL3Bytes	include/Hal8814PhyReg.h	861;"	d
-bMaskLWord	include/Hal8188EPhyReg.h	1055;"	d
-bMaskLWord	include/Hal8188FPhyReg.h	1063;"	d
-bMaskLWord	include/Hal8192EPhyReg.h	1066;"	d
-bMaskLWord	include/Hal8703BPhyReg.h	1092;"	d
-bMaskLWord	include/Hal8723BPhyReg.h	1090;"	d
-bMaskLWord	include/Hal8723DPhyReg.h	1093;"	d
-bMaskLWord	include/Hal8812PhyReg.h	726;"	d
-bMaskLWord	include/Hal8814PhyReg.h	851;"	d
-bMaskLWord	include/rtl8822b_hal.h	175;"	d
-bMaskLWord	include/rtw_mp_phy_regdef.h	1018;"	d
-bMaskOFDM_D	include/Hal8188EPhyReg.h	1060;"	d
-bMaskOFDM_D	include/Hal8188FPhyReg.h	1068;"	d
-bMaskOFDM_D	include/Hal8192EPhyReg.h	1071;"	d
-bMaskOFDM_D	include/Hal8703BPhyReg.h	1097;"	d
-bMaskOFDM_D	include/Hal8723BPhyReg.h	1095;"	d
-bMaskOFDM_D	include/Hal8723DPhyReg.h	1098;"	d
-bMaskOFDM_D	include/Hal8812PhyReg.h	731;"	d
-bMaskOFDM_D	include/Hal8814PhyReg.h	856;"	d
-bMaskOFDM_D	include/rtw_mp_phy_regdef.h	1022;"	d
-bMask_AntselPathFollow_Jaguar	include/Hal8812PhyReg.h	173;"	d
-bMask_AntselPathFollow_Jaguar	include/Hal8814PhyReg.h	207;"	d
-bMask_RFEInv_Jaguar	include/Hal8812PhyReg.h	172;"	d
-bMask_RFEInv_Jaguar	include/Hal8814PhyReg.h	206;"	d
-bMassProdTest	include/rtw_mp.h	/^	BOOLEAN			bMassProdTest;$/;"	m	struct:_MPT_CONTEXT
-bMediaConnect_0	hal/phydm/phydm_dig.h	/^	BOOLEAN		bMediaConnect_0;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bMediaConnect_1	hal/phydm/phydm_dig.h	/^	BOOLEAN		bMediaConnect_1;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bMinIdxTH	include/Hal8188EPhyReg.h	892;"	d
-bMinIdxTH	include/Hal8188FPhyReg.h	900;"	d
-bMinIdxTH	include/Hal8192EPhyReg.h	903;"	d
-bMinIdxTH	include/Hal8703BPhyReg.h	929;"	d
-bMinIdxTH	include/Hal8723BPhyReg.h	927;"	d
-bMinIdxTH	include/Hal8723DPhyReg.h	930;"	d
-bMinIdxTH	include/rtw_mp_phy_regdef.h	846;"	d
-bMptDrvUnload	include/rtw_mp.h	/^	BOOLEAN			bMptDrvUnload;$/;"	m	struct:_MPT_CONTEXT
-bMptEnableAckCounter	include/rtw_mp.h	/^	BOOLEAN			bMptEnableAckCounter;$/;"	m	struct:_MPT_CONTEXT
-bMptFilterPattern	include/rtw_mp.h	/^	BOOLEAN			bMptFilterPattern;$/;"	m	struct:_MPT_CONTEXT
-bMptIndexEven	include/rtw_mp.h	/^	BOOLEAN		bMptIndexEven;$/;"	m	struct:_MPT_CONTEXT
-bMptWorkItemInProgress	include/rtw_mp.h	/^	BOOLEAN			bMptWorkItemInProgress;$/;"	m	struct:_MPT_CONTEXT
-bMuPacket	hal/phydm/phydm.h	/^	BOOLEAN		bMuPacket;					\/* is MU packet or not---*\/$/;"	m	struct:_ODM_Phy_Status_Info_
-bMuPacket	include/rtw_recv.h	/^	BOOLEAN		bMuPacket;					\/* is MU packet or not---*\/$/;"	m	struct:phy_info
-bNB_Intf_TH_cfg	include/Hal8188EPhyReg.h	947;"	d
-bNB_Intf_TH_cfg	include/Hal8188FPhyReg.h	955;"	d
-bNB_Intf_TH_cfg	include/Hal8192EPhyReg.h	958;"	d
-bNB_Intf_TH_cfg	include/Hal8703BPhyReg.h	984;"	d
-bNB_Intf_TH_cfg	include/Hal8723BPhyReg.h	982;"	d
-bNB_Intf_TH_cfg	include/Hal8723DPhyReg.h	985;"	d
-bNB_Intf_TH_cfg	include/rtw_mp_phy_regdef.h	901;"	d
-bNB_intf_det_on	include/Hal8188EPhyReg.h	945;"	d
-bNB_intf_det_on	include/Hal8188FPhyReg.h	953;"	d
-bNB_intf_det_on	include/Hal8192EPhyReg.h	956;"	d
-bNB_intf_det_on	include/Hal8703BPhyReg.h	982;"	d
-bNB_intf_det_on	include/Hal8723BPhyReg.h	980;"	d
-bNB_intf_det_on	include/Hal8723DPhyReg.h	983;"	d
-bNB_intf_det_on	include/rtw_mp_phy_regdef.h	899;"	d
-bNeedIQK	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	bNeedIQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bNeedIQK	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN	bNeedIQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bNeedIQK	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN	bNeedIQK;$/;"	m	struct:ODM_RF_Calibration_Structure
-bNeedIQK	include/hal_data.h	/^	u8			bNeedIQK;$/;"	m	struct:hal_com_data
-bNeedNotifyAMPNoCap	include/rtw_btcoex.h	/^	BOOLEAN				bNeedNotifyAMPNoCap;$/;"	m	struct:_BT_MGNT
-bNoiseEst	hal/phydm/phydm_dig.h	/^	BOOLEAN					bNoiseEst;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bNoiseLvlTopSet	include/Hal8188EPhyReg.h	976;"	d
-bNoiseLvlTopSet	include/Hal8188FPhyReg.h	984;"	d
-bNoiseLvlTopSet	include/Hal8192EPhyReg.h	987;"	d
-bNoiseLvlTopSet	include/Hal8703BPhyReg.h	1013;"	d
-bNoiseLvlTopSet	include/Hal8723BPhyReg.h	1011;"	d
-bNoiseLvlTopSet	include/Hal8723DPhyReg.h	1014;"	d
-bNoiseLvlTopSet	include/rtw_mp_phy_regdef.h	930;"	d
-bNoisyState	hal/phydm/phydm.h	/^	BOOLEAN			bNoisyState;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bNotifyChannelChange	include/drv_types.h	/^	u8 bNotifyChannelChange;$/;"	m	struct:_ADAPTER
-bNss	include/Hal8188EPhyReg.h	904;"	d
-bNss	include/Hal8188FPhyReg.h	912;"	d
-bNss	include/Hal8192EPhyReg.h	915;"	d
-bNss	include/Hal8703BPhyReg.h	941;"	d
-bNss	include/Hal8723BPhyReg.h	939;"	d
-bNss	include/Hal8723DPhyReg.h	942;"	d
-bNss	include/Hal8812PhyReg.h	695;"	d
-bNss	include/Hal8814PhyReg.h	820;"	d
-bNss	include/rtw_mp_phy_regdef.h	858;"	d
-bNumOfCCKTx	include/Hal8188EPhyReg.h	483;"	d
-bNumOfCCKTx	include/Hal8188FPhyReg.h	491;"	d
-bNumOfCCKTx	include/Hal8192EPhyReg.h	492;"	d
-bNumOfCCKTx	include/Hal8703BPhyReg.h	519;"	d
-bNumOfCCKTx	include/Hal8723BPhyReg.h	518;"	d
-bNumOfCCKTx	include/Hal8723DPhyReg.h	520;"	d
-bNumOfCCKTx	include/Hal8812PhyReg.h	350;"	d
-bNumOfCCKTx	include/Hal8814PhyReg.h	457;"	d
-bNumOfCCKTx	include/rtw_mp_phy_regdef.h	435;"	d
-bNumOfOFDMTx	include/Hal8188EPhyReg.h	482;"	d
-bNumOfOFDMTx	include/Hal8188FPhyReg.h	490;"	d
-bNumOfOFDMTx	include/Hal8192EPhyReg.h	491;"	d
-bNumOfOFDMTx	include/Hal8703BPhyReg.h	518;"	d
-bNumOfOFDMTx	include/Hal8723BPhyReg.h	517;"	d
-bNumOfOFDMTx	include/Hal8723DPhyReg.h	519;"	d
-bNumOfOFDMTx	include/Hal8812PhyReg.h	349;"	d
-bNumOfOFDMTx	include/Hal8814PhyReg.h	456;"	d
-bNumOfOFDMTx	include/rtw_mp_phy_regdef.h	434;"	d
-bNumOfSTF	include/Hal8188EPhyReg.h	744;"	d
-bNumOfSTF	include/Hal8188FPhyReg.h	752;"	d
-bNumOfSTF	include/Hal8192EPhyReg.h	755;"	d
-bNumOfSTF	include/Hal8703BPhyReg.h	781;"	d
-bNumOfSTF	include/Hal8723BPhyReg.h	779;"	d
-bNumOfSTF	include/Hal8723DPhyReg.h	782;"	d
-bNumOfSTF	include/rtw_mp_phy_regdef.h	698;"	d
-bOFDMContinueTx	include/Hal8188EPhyReg.h	908;"	d
-bOFDMContinueTx	include/Hal8188FPhyReg.h	916;"	d
-bOFDMContinueTx	include/Hal8192EPhyReg.h	919;"	d
-bOFDMContinueTx	include/Hal8703BPhyReg.h	945;"	d
-bOFDMContinueTx	include/Hal8723BPhyReg.h	943;"	d
-bOFDMContinueTx	include/Hal8723DPhyReg.h	946;"	d
-bOFDMContinueTx	include/Hal8812PhyReg.h	699;"	d
-bOFDMContinueTx	include/Hal8814PhyReg.h	824;"	d
-bOFDMContinueTx	include/rtw_mp_phy_regdef.h	862;"	d
-bOFDMEN_Jaguar	include/Hal8812PhyReg.h	51;"	d
-bOFDMEN_Jaguar	include/Hal8814PhyReg.h	53;"	d
-bOFDMEn	include/Hal8188EPhyReg.h	508;"	d
-bOFDMEn	include/Hal8188FPhyReg.h	516;"	d
-bOFDMEn	include/Hal8192EPhyReg.h	519;"	d
-bOFDMEn	include/Hal8703BPhyReg.h	545;"	d
-bOFDMEn	include/Hal8723BPhyReg.h	543;"	d
-bOFDMEn	include/Hal8723DPhyReg.h	546;"	d
-bOFDMEn	include/Hal8812PhyReg.h	606;"	d
-bOFDMEn	include/Hal8814PhyReg.h	729;"	d
-bOFDMEn	include/rtl8822b_hal.h	157;"	d
-bOFDMEn	include/rtw_mp_phy_regdef.h	460;"	d
-bOFDMPHY0_End	include/Hal8188EPhyReg.h	1083;"	d
-bOFDMPHY0_End	include/Hal8188FPhyReg.h	1090;"	d
-bOFDMPHY0_End	include/Hal8192EPhyReg.h	1097;"	d
-bOFDMPHY0_End	include/Hal8703BPhyReg.h	1119;"	d
-bOFDMPHY0_End	include/Hal8723BPhyReg.h	1117;"	d
-bOFDMPHY0_End	include/Hal8723DPhyReg.h	1120;"	d
-bOFDMPHY0_End	include/rtw_mp_phy_regdef.h	1054;"	d
-bOFDMPHY1_End	include/Hal8188EPhyReg.h	1084;"	d
-bOFDMPHY1_End	include/Hal8188FPhyReg.h	1091;"	d
-bOFDMPHY1_End	include/Hal8192EPhyReg.h	1098;"	d
-bOFDMPHY1_End	include/Hal8703BPhyReg.h	1120;"	d
-bOFDMPHY1_End	include/Hal8723BPhyReg.h	1118;"	d
-bOFDMPHY1_End	include/Hal8723DPhyReg.h	1121;"	d
-bOFDMPHY1_End	include/rtw_mp_phy_regdef.h	1055;"	d
-bOFDMRxADCPhase	include/Hal8188EPhyReg.h	510;"	d
-bOFDMRxADCPhase	include/Hal8188FPhyReg.h	518;"	d
-bOFDMRxADCPhase	include/Hal8192EPhyReg.h	521;"	d
-bOFDMRxADCPhase	include/Hal8703BPhyReg.h	547;"	d
-bOFDMRxADCPhase	include/Hal8723BPhyReg.h	545;"	d
-bOFDMRxADCPhase	include/Hal8723DPhyReg.h	548;"	d
-bOFDMRxADCPhase	include/rtw_mp_phy_regdef.h	462;"	d
-bOFDMService	include/Hal8188EPhyReg.h	485;"	d
-bOFDMService	include/Hal8188FPhyReg.h	493;"	d
-bOFDMService	include/Hal8192EPhyReg.h	494;"	d
-bOFDMService	include/Hal8703BPhyReg.h	521;"	d
-bOFDMService	include/Hal8723BPhyReg.h	520;"	d
-bOFDMService	include/Hal8723DPhyReg.h	522;"	d
-bOFDMService	include/Hal8812PhyReg.h	352;"	d
-bOFDMService	include/Hal8814PhyReg.h	459;"	d
-bOFDMService	include/rtw_mp_phy_regdef.h	437;"	d
-bOFDMSingleCarrier	include/Hal8188EPhyReg.h	909;"	d
-bOFDMSingleCarrier	include/Hal8188FPhyReg.h	917;"	d
-bOFDMSingleCarrier	include/Hal8192EPhyReg.h	920;"	d
-bOFDMSingleCarrier	include/Hal8703BPhyReg.h	946;"	d
-bOFDMSingleCarrier	include/Hal8723BPhyReg.h	944;"	d
-bOFDMSingleCarrier	include/Hal8723DPhyReg.h	947;"	d
-bOFDMSingleCarrier	include/Hal8812PhyReg.h	700;"	d
-bOFDMSingleCarrier	include/Hal8814PhyReg.h	825;"	d
-bOFDMSingleCarrier	include/rtw_mp_phy_regdef.h	863;"	d
-bOFDMSingleTone	include/Hal8188EPhyReg.h	910;"	d
-bOFDMSingleTone	include/Hal8188FPhyReg.h	918;"	d
-bOFDMSingleTone	include/Hal8192EPhyReg.h	921;"	d
-bOFDMSingleTone	include/Hal8703BPhyReg.h	947;"	d
-bOFDMSingleTone	include/Hal8723BPhyReg.h	945;"	d
-bOFDMSingleTone	include/Hal8723DPhyReg.h	948;"	d
-bOFDMSingleTone	include/Hal8812PhyReg.h	701;"	d
-bOFDMSingleTone	include/Hal8814PhyReg.h	826;"	d
-bOFDMSingleTone	include/rtw_mp_phy_regdef.h	864;"	d
-bOFDMTxDACPhase	include/Hal8188EPhyReg.h	511;"	d
-bOFDMTxDACPhase	include/Hal8188FPhyReg.h	519;"	d
-bOFDMTxDACPhase	include/Hal8192EPhyReg.h	522;"	d
-bOFDMTxDACPhase	include/Hal8703BPhyReg.h	548;"	d
-bOFDMTxDACPhase	include/Hal8723BPhyReg.h	546;"	d
-bOFDMTxDACPhase	include/Hal8723DPhyReg.h	549;"	d
-bOFDMTxDACPhase	include/rtw_mp_phy_regdef.h	463;"	d
-bOFDMTxLength	include/Hal8188EPhyReg.h	465;"	d
-bOFDMTxLength	include/Hal8188FPhyReg.h	473;"	d
-bOFDMTxLength	include/Hal8192EPhyReg.h	474;"	d
-bOFDMTxLength	include/Hal8703BPhyReg.h	501;"	d
-bOFDMTxLength	include/Hal8723BPhyReg.h	500;"	d
-bOFDMTxLength	include/Hal8723DPhyReg.h	502;"	d
-bOFDMTxLength	include/Hal8812PhyReg.h	332;"	d
-bOFDMTxLength	include/Hal8814PhyReg.h	439;"	d
-bOFDMTxLength	include/rtw_mp_phy_regdef.h	417;"	d
-bOFDMTxOn	include/Hal8188EPhyReg.h	652;"	d
-bOFDMTxOn	include/Hal8188FPhyReg.h	660;"	d
-bOFDMTxOn	include/Hal8192EPhyReg.h	663;"	d
-bOFDMTxOn	include/Hal8703BPhyReg.h	689;"	d
-bOFDMTxOn	include/Hal8723BPhyReg.h	687;"	d
-bOFDMTxOn	include/Hal8723DPhyReg.h	690;"	d
-bOFDMTxOn	include/rtw_mp_phy_regdef.h	606;"	d
-bOFDMTxParity	include/Hal8188EPhyReg.h	466;"	d
-bOFDMTxParity	include/Hal8188FPhyReg.h	474;"	d
-bOFDMTxParity	include/Hal8192EPhyReg.h	475;"	d
-bOFDMTxParity	include/Hal8703BPhyReg.h	502;"	d
-bOFDMTxParity	include/Hal8723BPhyReg.h	501;"	d
-bOFDMTxParity	include/Hal8723DPhyReg.h	503;"	d
-bOFDMTxParity	include/Hal8812PhyReg.h	333;"	d
-bOFDMTxParity	include/Hal8814PhyReg.h	440;"	d
-bOFDMTxParity	include/rtw_mp_phy_regdef.h	418;"	d
-bOFDMTxRate	include/Hal8188EPhyReg.h	463;"	d
-bOFDMTxRate	include/Hal8188FPhyReg.h	471;"	d
-bOFDMTxRate	include/Hal8192EPhyReg.h	472;"	d
-bOFDMTxRate	include/Hal8703BPhyReg.h	499;"	d
-bOFDMTxRate	include/Hal8723BPhyReg.h	498;"	d
-bOFDMTxRate	include/Hal8723DPhyReg.h	500;"	d
-bOFDMTxRate	include/Hal8812PhyReg.h	330;"	d
-bOFDMTxRate	include/Hal8814PhyReg.h	437;"	d
-bOFDMTxRate	include/rtw_mp_phy_regdef.h	415;"	d
-bOFDMTxReserved	include/Hal8188EPhyReg.h	464;"	d
-bOFDMTxReserved	include/Hal8188FPhyReg.h	472;"	d
-bOFDMTxReserved	include/Hal8192EPhyReg.h	473;"	d
-bOFDMTxReserved	include/Hal8703BPhyReg.h	500;"	d
-bOFDMTxReserved	include/Hal8723BPhyReg.h	499;"	d
-bOFDMTxReserved	include/Hal8723DPhyReg.h	501;"	d
-bOFDMTxReserved	include/Hal8812PhyReg.h	331;"	d
-bOFDMTxReserved	include/Hal8814PhyReg.h	438;"	d
-bOFDMTxReserved	include/rtw_mp_phy_regdef.h	416;"	d
-bOFDMTxSC	include/Hal8188EPhyReg.h	650;"	d
-bOFDMTxSC	include/Hal8188FPhyReg.h	658;"	d
-bOFDMTxSC	include/Hal8192EPhyReg.h	661;"	d
-bOFDMTxSC	include/Hal8703BPhyReg.h	687;"	d
-bOFDMTxSC	include/Hal8723BPhyReg.h	685;"	d
-bOFDMTxSC	include/Hal8723DPhyReg.h	688;"	d
-bOFDMTxSC	include/rtw_mp_phy_regdef.h	604;"	d
-bOFDMTxStart	include/Hal8188EPhyReg.h	458;"	d
-bOFDMTxStart	include/Hal8188FPhyReg.h	466;"	d
-bOFDMTxStart	include/Hal8192EPhyReg.h	467;"	d
-bOFDMTxStart	include/Hal8703BPhyReg.h	494;"	d
-bOFDMTxStart	include/Hal8723BPhyReg.h	493;"	d
-bOFDMTxStart	include/Hal8723DPhyReg.h	495;"	d
-bOFDMTxStart	include/Hal8812PhyReg.h	325;"	d
-bOFDMTxStart	include/Hal8814PhyReg.h	432;"	d
-bOFDMTxStart	include/rtw_mp_phy_regdef.h	410;"	d
-bOFDMTxStatus	include/Hal8188EPhyReg.h	499;"	d
-bOFDMTxStatus	include/Hal8188FPhyReg.h	507;"	d
-bOFDMTxStatus	include/Hal8192EPhyReg.h	508;"	d
-bOFDMTxStatus	include/Hal8703BPhyReg.h	535;"	d
-bOFDMTxStatus	include/Hal8723BPhyReg.h	534;"	d
-bOFDMTxStatus	include/Hal8723DPhyReg.h	536;"	d
-bOFDMTxStatus	include/Hal8812PhyReg.h	366;"	d
-bOFDMTxStatus	include/Hal8814PhyReg.h	473;"	d
-bOFDMTxStatus	include/rtw_mp_phy_regdef.h	451;"	d
-bOfdmContTx	include/rtw_mp.h	/^	BOOLEAN			bOfdmContTx;	\/* TRUE if we are in OFDM Continuous Tx test. *\/$/;"	m	struct:_MPT_CONTEXT
-bOneEntryOnly	hal/phydm/phydm.h	/^	BOOLEAN			bOneEntryOnly;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bP2PInProcess	hal/phydm/phydm_dig.h	/^	u1Byte		*bP2PInProcess;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bPAEnd	include/Hal8188EPhyReg.h	525;"	d
-bPAEnd	include/Hal8188FPhyReg.h	533;"	d
-bPAEnd	include/Hal8192EPhyReg.h	536;"	d
-bPAEnd	include/Hal8703BPhyReg.h	562;"	d
-bPAEnd	include/Hal8723BPhyReg.h	560;"	d
-bPAEnd	include/Hal8723DPhyReg.h	563;"	d
-bPAEnd	include/rtw_mp_phy_regdef.h	475;"	d
-bPAStart	include/Hal8188EPhyReg.h	520;"	d
-bPAStart	include/Hal8188FPhyReg.h	528;"	d
-bPAStart	include/Hal8192EPhyReg.h	531;"	d
-bPAStart	include/Hal8703BPhyReg.h	557;"	d
-bPAStart	include/Hal8723BPhyReg.h	555;"	d
-bPAStart	include/Hal8723DPhyReg.h	558;"	d
-bPAStart	include/rtw_mp_phy_regdef.h	470;"	d
-bPD_Option	include/Hal8188EPhyReg.h	773;"	d
-bPD_Option	include/Hal8188FPhyReg.h	781;"	d
-bPD_Option	include/Hal8192EPhyReg.h	784;"	d
-bPD_Option	include/Hal8703BPhyReg.h	810;"	d
-bPD_Option	include/Hal8723BPhyReg.h	808;"	d
-bPD_Option	include/Hal8723DPhyReg.h	811;"	d
-bPD_Option	include/rtw_mp_phy_regdef.h	727;"	d
-bPD_TH	include/Hal8188EPhyReg.h	769;"	d
-bPD_TH	include/Hal8188FPhyReg.h	777;"	d
-bPD_TH	include/Hal8192EPhyReg.h	780;"	d
-bPD_TH	include/Hal8703BPhyReg.h	806;"	d
-bPD_TH	include/Hal8723BPhyReg.h	804;"	d
-bPD_TH	include/Hal8723DPhyReg.h	807;"	d
-bPD_TH	include/rtw_mp_phy_regdef.h	723;"	d
-bPD_TH_Opt2	include/Hal8188EPhyReg.h	770;"	d
-bPD_TH_Opt2	include/Hal8188FPhyReg.h	778;"	d
-bPD_TH_Opt2	include/Hal8192EPhyReg.h	781;"	d
-bPD_TH_Opt2	include/Hal8703BPhyReg.h	807;"	d
-bPD_TH_Opt2	include/Hal8723BPhyReg.h	805;"	d
-bPD_TH_Opt2	include/Hal8723DPhyReg.h	808;"	d
-bPD_TH_Opt2	include/rtw_mp_phy_regdef.h	724;"	d
-bPHYCounterReset	include/Hal8188EPhyReg.h	906;"	d
-bPHYCounterReset	include/Hal8188FPhyReg.h	914;"	d
-bPHYCounterReset	include/Hal8192EPhyReg.h	917;"	d
-bPHYCounterReset	include/Hal8703BPhyReg.h	943;"	d
-bPHYCounterReset	include/Hal8723BPhyReg.h	941;"	d
-bPHYCounterReset	include/Hal8723DPhyReg.h	944;"	d
-bPHYCounterReset	include/Hal8812PhyReg.h	697;"	d
-bPHYCounterReset	include/Hal8814PhyReg.h	822;"	d
-bPHYCounterReset	include/rtw_mp_phy_regdef.h	860;"	d
-bPLLPowerUp	include/Hal8188EPhyReg.h	595;"	d
-bPLLPowerUp	include/Hal8188FPhyReg.h	603;"	d
-bPLLPowerUp	include/Hal8192EPhyReg.h	606;"	d
-bPLLPowerUp	include/Hal8703BPhyReg.h	632;"	d
-bPLLPowerUp	include/Hal8723BPhyReg.h	630;"	d
-bPLLPowerUp	include/Hal8723DPhyReg.h	633;"	d
-bPLLPowerUp	include/rtw_mp_phy_regdef.h	549;"	d
-bPMACControl	include/Hal8188EPhyReg.h	1093;"	d
-bPMACControl	include/Hal8188FPhyReg.h	1100;"	d
-bPMACControl	include/Hal8192EPhyReg.h	1107;"	d
-bPMACControl	include/Hal8703BPhyReg.h	1129;"	d
-bPMACControl	include/Hal8723BPhyReg.h	1127;"	d
-bPMACControl	include/Hal8723DPhyReg.h	1130;"	d
-bPMACControl	include/rtw_mp_phy_regdef.h	1064;"	d
-bPMACLoopback	include/Hal8188EPhyReg.h	461;"	d
-bPMACLoopback	include/Hal8188FPhyReg.h	469;"	d
-bPMACLoopback	include/Hal8192EPhyReg.h	470;"	d
-bPMACLoopback	include/Hal8703BPhyReg.h	497;"	d
-bPMACLoopback	include/Hal8723BPhyReg.h	496;"	d
-bPMACLoopback	include/Hal8723DPhyReg.h	498;"	d
-bPMACLoopback	include/Hal8812PhyReg.h	328;"	d
-bPMACLoopback	include/Hal8814PhyReg.h	435;"	d
-bPMACLoopback	include/rtw_mp_phy_regdef.h	413;"	d
-bPMAC_End	include/Hal8188EPhyReg.h	1079;"	d
-bPMAC_End	include/Hal8188FPhyReg.h	1086;"	d
-bPMAC_End	include/Hal8192EPhyReg.h	1093;"	d
-bPMAC_End	include/Hal8703BPhyReg.h	1115;"	d
-bPMAC_End	include/Hal8723BPhyReg.h	1113;"	d
-bPMAC_End	include/Hal8723DPhyReg.h	1116;"	d
-bPMAC_End	include/rtw_mp_phy_regdef.h	1050;"	d
-bPSDAntennaPath	include/Hal8188EPhyReg.h	642;"	d
-bPSDAntennaPath	include/Hal8188FPhyReg.h	650;"	d
-bPSDAntennaPath	include/Hal8192EPhyReg.h	653;"	d
-bPSDAntennaPath	include/Hal8703BPhyReg.h	679;"	d
-bPSDAntennaPath	include/Hal8723BPhyReg.h	677;"	d
-bPSDAntennaPath	include/Hal8723DPhyReg.h	680;"	d
-bPSDAntennaPath	include/rtw_mp_phy_regdef.h	596;"	d
-bPSDAverageNum	include/Hal8188EPhyReg.h	639;"	d
-bPSDAverageNum	include/Hal8188FPhyReg.h	647;"	d
-bPSDAverageNum	include/Hal8192EPhyReg.h	650;"	d
-bPSDAverageNum	include/Hal8703BPhyReg.h	676;"	d
-bPSDAverageNum	include/Hal8723BPhyReg.h	674;"	d
-bPSDAverageNum	include/Hal8723DPhyReg.h	677;"	d
-bPSDAverageNum	include/rtw_mp_phy_regdef.h	593;"	d
-bPSDFFTSamplepPoint	include/Hal8188EPhyReg.h	638;"	d
-bPSDFFTSamplepPoint	include/Hal8188FPhyReg.h	646;"	d
-bPSDFFTSamplepPoint	include/Hal8192EPhyReg.h	649;"	d
-bPSDFFTSamplepPoint	include/Hal8703BPhyReg.h	675;"	d
-bPSDFFTSamplepPoint	include/Hal8723BPhyReg.h	673;"	d
-bPSDFFTSamplepPoint	include/Hal8723DPhyReg.h	676;"	d
-bPSDFFTSamplepPoint	include/rtw_mp_phy_regdef.h	592;"	d
-bPSDFreq	include/Hal8188EPhyReg.h	641;"	d
-bPSDFreq	include/Hal8188FPhyReg.h	649;"	d
-bPSDFreq	include/Hal8192EPhyReg.h	652;"	d
-bPSDFreq	include/Hal8703BPhyReg.h	678;"	d
-bPSDFreq	include/Hal8723BPhyReg.h	676;"	d
-bPSDFreq	include/Hal8723DPhyReg.h	679;"	d
-bPSDFreq	include/rtw_mp_phy_regdef.h	595;"	d
-bPSDIQSwitch	include/Hal8188EPhyReg.h	643;"	d
-bPSDIQSwitch	include/Hal8188FPhyReg.h	651;"	d
-bPSDIQSwitch	include/Hal8192EPhyReg.h	654;"	d
-bPSDIQSwitch	include/Hal8703BPhyReg.h	680;"	d
-bPSDIQSwitch	include/Hal8723BPhyReg.h	678;"	d
-bPSDIQSwitch	include/Hal8723DPhyReg.h	681;"	d
-bPSDIQSwitch	include/rtw_mp_phy_regdef.h	597;"	d
-bPSDInProgress	hal/phydm/phydm_dig.h	/^	BOOLEAN		bPSDInProgress;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bPSDReport	include/Hal8188EPhyReg.h	647;"	d
-bPSDReport	include/Hal8188FPhyReg.h	655;"	d
-bPSDReport	include/Hal8192EPhyReg.h	658;"	d
-bPSDReport	include/Hal8703BPhyReg.h	684;"	d
-bPSDReport	include/Hal8723BPhyReg.h	682;"	d
-bPSDReport	include/Hal8723DPhyReg.h	685;"	d
-bPSDReport	include/rtw_mp_phy_regdef.h	601;"	d
-bPSDRxTrigger	include/Hal8188EPhyReg.h	644;"	d
-bPSDRxTrigger	include/Hal8188FPhyReg.h	652;"	d
-bPSDRxTrigger	include/Hal8192EPhyReg.h	655;"	d
-bPSDRxTrigger	include/Hal8703BPhyReg.h	681;"	d
-bPSDRxTrigger	include/Hal8723BPhyReg.h	679;"	d
-bPSDRxTrigger	include/Hal8723DPhyReg.h	682;"	d
-bPSDRxTrigger	include/rtw_mp_phy_regdef.h	598;"	d
-bPSDSineToneScale	include/Hal8188EPhyReg.h	646;"	d
-bPSDSineToneScale	include/Hal8188FPhyReg.h	654;"	d
-bPSDSineToneScale	include/Hal8192EPhyReg.h	657;"	d
-bPSDSineToneScale	include/Hal8703BPhyReg.h	683;"	d
-bPSDSineToneScale	include/Hal8723BPhyReg.h	681;"	d
-bPSDSineToneScale	include/Hal8723DPhyReg.h	684;"	d
-bPSDSineToneScale	include/rtw_mp_phy_regdef.h	600;"	d
-bPSDTxTrigger	include/Hal8188EPhyReg.h	645;"	d
-bPSDTxTrigger	include/Hal8188FPhyReg.h	653;"	d
-bPSDTxTrigger	include/Hal8192EPhyReg.h	656;"	d
-bPSDTxTrigger	include/Hal8703BPhyReg.h	682;"	d
-bPSDTxTrigger	include/Hal8723BPhyReg.h	680;"	d
-bPSDTxTrigger	include/Hal8723DPhyReg.h	683;"	d
-bPSDTxTrigger	include/rtw_mp_phy_regdef.h	599;"	d
-bPSDactive	hal/phydm/phydm.h	/^	BOOLEAN			bPSDactive;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bPSDinProcess	hal/phydm/phydm.h	/^	BOOLEAN			bPSDinProcess;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bPWDB	include/Hal8188EPhyReg.h	962;"	d
-bPWDB	include/Hal8188FPhyReg.h	970;"	d
-bPWDB	include/Hal8192EPhyReg.h	973;"	d
-bPWDB	include/Hal8703BPhyReg.h	999;"	d
-bPWDB	include/Hal8723BPhyReg.h	997;"	d
-bPWDB	include/Hal8723DPhyReg.h	1000;"	d
-bPWDB	include/rtw_mp_phy_regdef.h	916;"	d
-bPWED_TH	include/Hal8188EPhyReg.h	771;"	d
-bPWED_TH	include/Hal8188FPhyReg.h	779;"	d
-bPWED_TH	include/Hal8192EPhyReg.h	782;"	d
-bPWED_TH	include/Hal8703BPhyReg.h	808;"	d
-bPWED_TH	include/Hal8723BPhyReg.h	806;"	d
-bPWED_TH	include/Hal8723DPhyReg.h	809;"	d
-bPWED_TH	include/rtw_mp_phy_regdef.h	725;"	d
-bPacketBeacon	hal/phydm/phydm.h	/^	BOOLEAN		bPacketBeacon;$/;"	m	struct:_ODM_Per_Pkt_Info_
-bPacketMatchBSSID	hal/phydm/phydm.h	/^	BOOLEAN		bPacketMatchBSSID;$/;"	m	struct:_ODM_Per_Pkt_Info_
-bPacketToSelf	hal/phydm/phydm.h	/^	BOOLEAN		bPacketToSelf;$/;"	m	struct:_ODM_Per_Pkt_Info_
-bPage	include/rtw_btcoex.h	/^	u8 bPage:1;$/;"	m	struct:btinfo_8761ATV
-bPauseDIG	include/hal_com.h	/^	u8		bPauseDIG;$/;"	m	struct:noise_info
-bPesudoNoiseState_A	include/Hal8188EPhyReg.h	1007;"	d
-bPesudoNoiseState_A	include/Hal8188FPhyReg.h	1015;"	d
-bPesudoNoiseState_A	include/Hal8192EPhyReg.h	1018;"	d
-bPesudoNoiseState_A	include/Hal8703BPhyReg.h	1044;"	d
-bPesudoNoiseState_A	include/Hal8723BPhyReg.h	1042;"	d
-bPesudoNoiseState_A	include/Hal8723DPhyReg.h	1045;"	d
-bPesudoNoiseState_A	include/rtw_mp_phy_regdef.h	970;"	d
-bPesudoNoiseState_B	include/Hal8188EPhyReg.h	1008;"	d
-bPesudoNoiseState_B	include/Hal8188FPhyReg.h	1016;"	d
-bPesudoNoiseState_B	include/Hal8192EPhyReg.h	1019;"	d
-bPesudoNoiseState_B	include/Hal8703BPhyReg.h	1045;"	d
-bPesudoNoiseState_B	include/Hal8723BPhyReg.h	1043;"	d
-bPesudoNoiseState_B	include/Hal8723DPhyReg.h	1046;"	d
-bPesudoNoiseState_B	include/rtw_mp_phy_regdef.h	971;"	d
-bPesudoNoiseState_C	include/Hal8188EPhyReg.h	1009;"	d
-bPesudoNoiseState_C	include/Hal8188FPhyReg.h	1017;"	d
-bPesudoNoiseState_C	include/Hal8192EPhyReg.h	1020;"	d
-bPesudoNoiseState_C	include/Hal8703BPhyReg.h	1046;"	d
-bPesudoNoiseState_C	include/Hal8723BPhyReg.h	1044;"	d
-bPesudoNoiseState_C	include/Hal8723DPhyReg.h	1047;"	d
-bPesudoNoiseState_C	include/rtw_mp_phy_regdef.h	972;"	d
-bPesudoNoiseState_D	include/Hal8188EPhyReg.h	1010;"	d
-bPesudoNoiseState_D	include/Hal8188FPhyReg.h	1018;"	d
-bPesudoNoiseState_D	include/Hal8192EPhyReg.h	1021;"	d
-bPesudoNoiseState_D	include/Hal8703BPhyReg.h	1047;"	d
-bPesudoNoiseState_D	include/Hal8723BPhyReg.h	1045;"	d
-bPesudoNoiseState_D	include/Hal8723DPhyReg.h	1048;"	d
-bPesudoNoiseState_D	include/rtw_mp_phy_regdef.h	973;"	d
-bPhCmpEnable	include/Hal8188EPhyReg.h	993;"	d
-bPhCmpEnable	include/Hal8188FPhyReg.h	1001;"	d
-bPhCmpEnable	include/Hal8192EPhyReg.h	1004;"	d
-bPhCmpEnable	include/Hal8703BPhyReg.h	1030;"	d
-bPhCmpEnable	include/Hal8723BPhyReg.h	1028;"	d
-bPhCmpEnable	include/Hal8723DPhyReg.h	1031;"	d
-bPhCmpEnable	include/rtw_mp_phy_regdef.h	947;"	d
-bPhyLinkInProgress	include/rtw_btcoex.h	/^	BOOLEAN				bPhyLinkInProgress;$/;"	m	struct:_BT_MGNT
-bPhyLinkInProgressStartLL	include/rtw_btcoex.h	/^	BOOLEAN				bPhyLinkInProgressStartLL;$/;"	m	struct:_BT_MGNT
-bPowerMeasFLength	include/Hal8188EPhyReg.h	941;"	d
-bPowerMeasFLength	include/Hal8188FPhyReg.h	949;"	d
-bPowerMeasFLength	include/Hal8192EPhyReg.h	952;"	d
-bPowerMeasFLength	include/Hal8703BPhyReg.h	978;"	d
-bPowerMeasFLength	include/Hal8723BPhyReg.h	976;"	d
-bPowerMeasFLength	include/Hal8723DPhyReg.h	979;"	d
-bPowerMeasFLength	include/rtw_mp_phy_regdef.h	895;"	d
-bPowerMeasTLength	include/Hal8188EPhyReg.h	940;"	d
-bPowerMeasTLength	include/Hal8188FPhyReg.h	948;"	d
-bPowerMeasTLength	include/Hal8192EPhyReg.h	951;"	d
-bPowerMeasTLength	include/Hal8703BPhyReg.h	977;"	d
-bPowerMeasTLength	include/Hal8723BPhyReg.h	975;"	d
-bPowerMeasTLength	include/Hal8723DPhyReg.h	978;"	d
-bPowerMeasTLength	include/rtw_mp_phy_regdef.h	894;"	d
-bPowerThres	include/Hal8188EPhyReg.h	835;"	d
-bPowerThres	include/Hal8188FPhyReg.h	843;"	d
-bPowerThres	include/Hal8192EPhyReg.h	846;"	d
-bPowerThres	include/Hal8703BPhyReg.h	872;"	d
-bPowerThres	include/Hal8723BPhyReg.h	870;"	d
-bPowerThres	include/Hal8723DPhyReg.h	873;"	d
-bPowerThres	include/rtw_mp_phy_regdef.h	789;"	d
-bPreAdcBackOff	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bPreAdcBackOff;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreAdcBackOff	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bPreAdcBackOff;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreAdcBackOff	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bPreAdcBackOff;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bPreAgcTableEn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN 	bPreAgcTableEn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreAgcTableEn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN 	bPreAgcTableEn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreAgcTableEn	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN 	bPreAgcTableEn;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bPreBalanceOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bPreBalanceOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreBalanceOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bPreBalanceOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreDacOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bPreDacOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreDacOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bPreDacOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreDacSwingOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bPreDacSwingOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreDacSwingOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bPreDacSwingOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreDacSwingOn	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bPreDacSwingOn;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bPreDecBtPwr	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bPreDecBtPwr;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bPreIgnoreWlanAct	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bPreIgnoreWlanAct;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bPreIgnoreWlanAct	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bPreIgnoreWlanAct;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bPreInterruptOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN 	bPreInterruptOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreInterruptOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN 	bPreInterruptOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreLowPenaltyRa	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN 	bPreLowPenaltyRa;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreLowPenaltyRa	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN 	bPreLowPenaltyRa;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreLowPenaltyRa	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN 	bPreLowPenaltyRa;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bPreLowPenaltyRa	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN 	bPreLowPenaltyRa;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bPreNavOn	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN 	bPreNavOn;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreNavOn	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN 	bPreNavOn;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPrePsTdmaOn	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bPrePsTdmaOn;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bPrePsTdmaOn	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bPrePsTdmaOn;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bPreRfRxLpfShrink	hal/btc/HalBtc8188c2Ant.h	/^	BOOLEAN		bPreRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8188C_2ANT
-bPreRfRxLpfShrink	hal/btc/HalBtc8192d2Ant.h	/^	BOOLEAN		bPreRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8192D_2ANT
-bPreRfRxLpfShrink	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bPreRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bPreRfRxLpfShrink	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bPreRfRxLpfShrink;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bQPathLoopback	include/Hal8188EPhyReg.h	622;"	d
-bQPathLoopback	include/Hal8188FPhyReg.h	630;"	d
-bQPathLoopback	include/Hal8192EPhyReg.h	633;"	d
-bQPathLoopback	include/Hal8703BPhyReg.h	659;"	d
-bQPathLoopback	include/Hal8723BPhyReg.h	657;"	d
-bQPathLoopback	include/Hal8723DPhyReg.h	660;"	d
-bQPathLoopback	include/rtw_mp_phy_regdef.h	576;"	d
-bR2RCCAMask	include/Hal8188EPhyReg.h	529;"	d
-bR2RCCAMask	include/Hal8188FPhyReg.h	537;"	d
-bR2RCCAMask	include/Hal8192EPhyReg.h	540;"	d
-bR2RCCAMask	include/Hal8703BPhyReg.h	566;"	d
-bR2RCCAMask	include/Hal8723BPhyReg.h	564;"	d
-bR2RCCAMask	include/Hal8723DPhyReg.h	567;"	d
-bR2RCCAMask	include/rtw_mp_phy_regdef.h	479;"	d
-bRDGEnable	include/hal_data.h	/^	BOOLEAN	 bRDGEnable;$/;"	m	struct:hal_com_data
-bRFEnd	include/Hal8188EPhyReg.h	527;"	d
-bRFEnd	include/Hal8188FPhyReg.h	535;"	d
-bRFEnd	include/Hal8192EPhyReg.h	538;"	d
-bRFEnd	include/Hal8703BPhyReg.h	564;"	d
-bRFEnd	include/Hal8723BPhyReg.h	562;"	d
-bRFEnd	include/Hal8723DPhyReg.h	565;"	d
-bRFEnd	include/rtw_mp_phy_regdef.h	477;"	d
-bRFGain	include/Hal8188EPhyReg.h	948;"	d
-bRFGain	include/Hal8188FPhyReg.h	956;"	d
-bRFGain	include/Hal8192EPhyReg.h	959;"	d
-bRFGain	include/Hal8703BPhyReg.h	985;"	d
-bRFGain	include/Hal8723BPhyReg.h	983;"	d
-bRFGain	include/Hal8723DPhyReg.h	986;"	d
-bRFGain	include/rtw_mp_phy_regdef.h	902;"	d
-bRFMOD	include/Hal8188EPhyReg.h	504;"	d
-bRFMOD	include/Hal8188FPhyReg.h	512;"	d
-bRFMOD	include/Hal8192EPhyReg.h	515;"	d
-bRFMOD	include/Hal8703BPhyReg.h	541;"	d
-bRFMOD	include/Hal8723BPhyReg.h	539;"	d
-bRFMOD	include/Hal8723DPhyReg.h	542;"	d
-bRFMOD	include/Hal8812PhyReg.h	602;"	d
-bRFMOD	include/Hal8814PhyReg.h	725;"	d
-bRFMOD	include/rtw_mp_phy_regdef.h	456;"	d
-bRFMOD_Jaguar	include/Hal8812PhyReg.h	45;"	d
-bRFMOD_Jaguar	include/Hal8814PhyReg.h	47;"	d
-bRFRegOffsetMask	include/Hal8192EPhyReg.h	1077;"	d
-bRFRegOffsetMask	include/hal_phy_reg.h	27;"	d
-bRFRegOffsetMask	include/rtw_mp_phy_regdef.h	1030;"	d
-bRFRegOffsetMask	include/rtw_mp_phy_regdef.h	1034;"	d
-bRFSI_3Wire	include/Hal8188EPhyReg.h	556;"	d
-bRFSI_3Wire	include/Hal8188FPhyReg.h	564;"	d
-bRFSI_3Wire	include/Hal8192EPhyReg.h	567;"	d
-bRFSI_3Wire	include/Hal8703BPhyReg.h	593;"	d
-bRFSI_3Wire	include/Hal8723BPhyReg.h	591;"	d
-bRFSI_3Wire	include/Hal8723DPhyReg.h	594;"	d
-bRFSI_3Wire	include/rtw_mp_phy_regdef.h	506;"	d
-bRFSI_3WireClock	include/Hal8188EPhyReg.h	553;"	d
-bRFSI_3WireClock	include/Hal8188FPhyReg.h	561;"	d
-bRFSI_3WireClock	include/Hal8192EPhyReg.h	564;"	d
-bRFSI_3WireClock	include/Hal8703BPhyReg.h	590;"	d
-bRFSI_3WireClock	include/Hal8723BPhyReg.h	588;"	d
-bRFSI_3WireClock	include/Hal8723DPhyReg.h	591;"	d
-bRFSI_3WireClock	include/rtw_mp_phy_regdef.h	503;"	d
-bRFSI_3WireData	include/Hal8188EPhyReg.h	552;"	d
-bRFSI_3WireData	include/Hal8188FPhyReg.h	560;"	d
-bRFSI_3WireData	include/Hal8192EPhyReg.h	563;"	d
-bRFSI_3WireData	include/Hal8703BPhyReg.h	589;"	d
-bRFSI_3WireData	include/Hal8723BPhyReg.h	587;"	d
-bRFSI_3WireData	include/Hal8723DPhyReg.h	590;"	d
-bRFSI_3WireData	include/rtw_mp_phy_regdef.h	502;"	d
-bRFSI_3WireLoad	include/Hal8188EPhyReg.h	554;"	d
-bRFSI_3WireLoad	include/Hal8188FPhyReg.h	562;"	d
-bRFSI_3WireLoad	include/Hal8192EPhyReg.h	565;"	d
-bRFSI_3WireLoad	include/Hal8703BPhyReg.h	591;"	d
-bRFSI_3WireLoad	include/Hal8723BPhyReg.h	589;"	d
-bRFSI_3WireLoad	include/Hal8723DPhyReg.h	592;"	d
-bRFSI_3WireLoad	include/rtw_mp_phy_regdef.h	504;"	d
-bRFSI_3WireRW	include/Hal8188EPhyReg.h	555;"	d
-bRFSI_3WireRW	include/Hal8188FPhyReg.h	563;"	d
-bRFSI_3WireRW	include/Hal8192EPhyReg.h	566;"	d
-bRFSI_3WireRW	include/Hal8703BPhyReg.h	592;"	d
-bRFSI_3WireRW	include/Hal8723BPhyReg.h	590;"	d
-bRFSI_3WireRW	include/Hal8723DPhyReg.h	593;"	d
-bRFSI_3WireRW	include/rtw_mp_phy_regdef.h	505;"	d
-bRFSI_ANTSW	include/Hal8188EPhyReg.h	562;"	d
-bRFSI_ANTSW	include/Hal8188FPhyReg.h	570;"	d
-bRFSI_ANTSW	include/Hal8192EPhyReg.h	573;"	d
-bRFSI_ANTSW	include/Hal8703BPhyReg.h	599;"	d
-bRFSI_ANTSW	include/Hal8723BPhyReg.h	597;"	d
-bRFSI_ANTSW	include/Hal8723DPhyReg.h	600;"	d
-bRFSI_ANTSW	include/rtw_mp_phy_regdef.h	512;"	d
-bRFSI_ANTSWB	include/Hal8188EPhyReg.h	563;"	d
-bRFSI_ANTSWB	include/Hal8188FPhyReg.h	571;"	d
-bRFSI_ANTSWB	include/Hal8192EPhyReg.h	574;"	d
-bRFSI_ANTSWB	include/Hal8703BPhyReg.h	600;"	d
-bRFSI_ANTSWB	include/Hal8723BPhyReg.h	598;"	d
-bRFSI_ANTSWB	include/Hal8723DPhyReg.h	601;"	d
-bRFSI_ANTSWB	include/rtw_mp_phy_regdef.h	513;"	d
-bRFSI_PAPE	include/Hal8188EPhyReg.h	564;"	d
-bRFSI_PAPE	include/Hal8188FPhyReg.h	572;"	d
-bRFSI_PAPE	include/Hal8192EPhyReg.h	575;"	d
-bRFSI_PAPE	include/Hal8703BPhyReg.h	601;"	d
-bRFSI_PAPE	include/Hal8723BPhyReg.h	599;"	d
-bRFSI_PAPE	include/Hal8723DPhyReg.h	602;"	d
-bRFSI_PAPE	include/rtw_mp_phy_regdef.h	514;"	d
-bRFSI_PAPE5G	include/Hal8188EPhyReg.h	565;"	d
-bRFSI_PAPE5G	include/Hal8188FPhyReg.h	573;"	d
-bRFSI_PAPE5G	include/Hal8192EPhyReg.h	576;"	d
-bRFSI_PAPE5G	include/Hal8703BPhyReg.h	602;"	d
-bRFSI_PAPE5G	include/Hal8723BPhyReg.h	600;"	d
-bRFSI_PAPE5G	include/Hal8723DPhyReg.h	603;"	d
-bRFSI_PAPE5G	include/rtw_mp_phy_regdef.h	515;"	d
-bRFSI_RFENV	include/Hal8188EPhyReg.h	558;"	d
-bRFSI_RFENV	include/Hal8188FPhyReg.h	566;"	d
-bRFSI_RFENV	include/Hal8192EPhyReg.h	569;"	d
-bRFSI_RFENV	include/Hal8703BPhyReg.h	595;"	d
-bRFSI_RFENV	include/Hal8723BPhyReg.h	593;"	d
-bRFSI_RFENV	include/Hal8723DPhyReg.h	596;"	d
-bRFSI_RFENV	include/rtw_mp_phy_regdef.h	508;"	d
-bRFSI_TRSW	include/Hal8188EPhyReg.h	560;"	d
-bRFSI_TRSW	include/Hal8188FPhyReg.h	568;"	d
-bRFSI_TRSW	include/Hal8192EPhyReg.h	571;"	d
-bRFSI_TRSW	include/Hal8703BPhyReg.h	597;"	d
-bRFSI_TRSW	include/Hal8723BPhyReg.h	595;"	d
-bRFSI_TRSW	include/Hal8723DPhyReg.h	598;"	d
-bRFSI_TRSW	include/rtw_mp_phy_regdef.h	510;"	d
-bRFSI_TRSWB	include/Hal8188EPhyReg.h	561;"	d
-bRFSI_TRSWB	include/Hal8188FPhyReg.h	569;"	d
-bRFSI_TRSWB	include/Hal8192EPhyReg.h	572;"	d
-bRFSI_TRSWB	include/Hal8703BPhyReg.h	598;"	d
-bRFSI_TRSWB	include/Hal8723BPhyReg.h	596;"	d
-bRFSI_TRSWB	include/Hal8723DPhyReg.h	599;"	d
-bRFSI_TRSWB	include/rtw_mp_phy_regdef.h	511;"	d
-bRFSW_RxDefaultAnt	include/Hal8188EPhyReg.h	550;"	d
-bRFSW_RxDefaultAnt	include/Hal8188FPhyReg.h	558;"	d
-bRFSW_RxDefaultAnt	include/Hal8192EPhyReg.h	561;"	d
-bRFSW_RxDefaultAnt	include/Hal8703BPhyReg.h	587;"	d
-bRFSW_RxDefaultAnt	include/Hal8723BPhyReg.h	585;"	d
-bRFSW_RxDefaultAnt	include/Hal8723DPhyReg.h	588;"	d
-bRFSW_RxDefaultAnt	include/rtw_mp_phy_regdef.h	500;"	d
-bRFSW_RxOptionAnt	include/Hal8188EPhyReg.h	551;"	d
-bRFSW_RxOptionAnt	include/Hal8188FPhyReg.h	559;"	d
-bRFSW_RxOptionAnt	include/Hal8192EPhyReg.h	562;"	d
-bRFSW_RxOptionAnt	include/Hal8703BPhyReg.h	588;"	d
-bRFSW_RxOptionAnt	include/Hal8723BPhyReg.h	586;"	d
-bRFSW_RxOptionAnt	include/Hal8723DPhyReg.h	589;"	d
-bRFSW_RxOptionAnt	include/rtw_mp_phy_regdef.h	501;"	d
-bRFSW_TxDefaultAnt	include/Hal8188EPhyReg.h	548;"	d
-bRFSW_TxDefaultAnt	include/Hal8188FPhyReg.h	556;"	d
-bRFSW_TxDefaultAnt	include/Hal8192EPhyReg.h	559;"	d
-bRFSW_TxDefaultAnt	include/Hal8703BPhyReg.h	585;"	d
-bRFSW_TxDefaultAnt	include/Hal8723BPhyReg.h	583;"	d
-bRFSW_TxDefaultAnt	include/Hal8723DPhyReg.h	586;"	d
-bRFSW_TxDefaultAnt	include/rtw_mp_phy_regdef.h	498;"	d
-bRFSW_TxOptionAnt	include/Hal8188EPhyReg.h	549;"	d
-bRFSW_TxOptionAnt	include/Hal8188FPhyReg.h	557;"	d
-bRFSW_TxOptionAnt	include/Hal8192EPhyReg.h	560;"	d
-bRFSW_TxOptionAnt	include/Hal8703BPhyReg.h	586;"	d
-bRFSW_TxOptionAnt	include/Hal8723BPhyReg.h	584;"	d
-bRFSW_TxOptionAnt	include/Hal8723DPhyReg.h	587;"	d
-bRFSW_TxOptionAnt	include/rtw_mp_phy_regdef.h	499;"	d
-bRFStart	include/Hal8188EPhyReg.h	522;"	d
-bRFStart	include/Hal8188FPhyReg.h	530;"	d
-bRFStart	include/Hal8192EPhyReg.h	533;"	d
-bRFStart	include/Hal8703BPhyReg.h	559;"	d
-bRFStart	include/Hal8723BPhyReg.h	557;"	d
-bRFStart	include/Hal8723DPhyReg.h	560;"	d
-bRFStart	include/rtw_mp_phy_regdef.h	472;"	d
-bRF_CHNLBW_BW	include/Hal8812PhyReg.h	296;"	d
-bRF_CHNLBW_BW	include/Hal8814PhyReg.h	406;"	d
-bRF_CHNLBW_MOD_AG_Jaguar	include/Hal8812PhyReg.h	295;"	d
-bRF_CHNLBW_MOD_AG_Jaguar	include/Hal8814PhyReg.h	405;"	d
-bRSSITableSelect	include/Hal8188EPhyReg.h	858;"	d
-bRSSITableSelect	include/Hal8188FPhyReg.h	866;"	d
-bRSSITableSelect	include/Hal8192EPhyReg.h	869;"	d
-bRSSITableSelect	include/Hal8703BPhyReg.h	895;"	d
-bRSSITableSelect	include/Hal8723BPhyReg.h	893;"	d
-bRSSITableSelect	include/Hal8723DPhyReg.h	896;"	d
-bRSSITableSelect	include/rtw_mp_phy_regdef.h	812;"	d
-bRSSI_Gen	include/Hal8188EPhyReg.h	846;"	d
-bRSSI_Gen	include/Hal8188FPhyReg.h	854;"	d
-bRSSI_Gen	include/Hal8192EPhyReg.h	857;"	d
-bRSSI_Gen	include/Hal8703BPhyReg.h	883;"	d
-bRSSI_Gen	include/Hal8723BPhyReg.h	881;"	d
-bRSSI_Gen	include/Hal8723DPhyReg.h	884;"	d
-bRSSI_Gen	include/rtw_mp_phy_regdef.h	800;"	d
-bRSSI_H	include/Hal8188EPhyReg.h	845;"	d
-bRSSI_H	include/Hal8188FPhyReg.h	853;"	d
-bRSSI_H	include/Hal8192EPhyReg.h	856;"	d
-bRSSI_H	include/Hal8703BPhyReg.h	882;"	d
-bRSSI_H	include/Hal8723BPhyReg.h	880;"	d
-bRSSI_H	include/Hal8723DPhyReg.h	883;"	d
-bRSSI_H	include/rtw_mp_phy_regdef.h	799;"	d
-bRTL8256RegModeCtrl0	include/Hal8188EPhyReg.h	1026;"	d
-bRTL8256RegModeCtrl0	include/Hal8188FPhyReg.h	1034;"	d
-bRTL8256RegModeCtrl0	include/Hal8192EPhyReg.h	1037;"	d
-bRTL8256RegModeCtrl0	include/Hal8703BPhyReg.h	1063;"	d
-bRTL8256RegModeCtrl0	include/Hal8723BPhyReg.h	1061;"	d
-bRTL8256RegModeCtrl0	include/Hal8723DPhyReg.h	1064;"	d
-bRTL8256RegModeCtrl0	include/rtw_mp_phy_regdef.h	989;"	d
-bRTL8256RegModeCtrl1	include/Hal8188EPhyReg.h	1025;"	d
-bRTL8256RegModeCtrl1	include/Hal8188FPhyReg.h	1033;"	d
-bRTL8256RegModeCtrl1	include/Hal8192EPhyReg.h	1036;"	d
-bRTL8256RegModeCtrl1	include/Hal8703BPhyReg.h	1062;"	d
-bRTL8256RegModeCtrl1	include/Hal8723BPhyReg.h	1060;"	d
-bRTL8256RegModeCtrl1	include/Hal8723DPhyReg.h	1063;"	d
-bRTL8256RegModeCtrl1	include/rtw_mp_phy_regdef.h	988;"	d
-bRTL8256_RxLPFBW	include/Hal8188EPhyReg.h	1028;"	d
-bRTL8256_RxLPFBW	include/Hal8188FPhyReg.h	1036;"	d
-bRTL8256_RxLPFBW	include/Hal8192EPhyReg.h	1039;"	d
-bRTL8256_RxLPFBW	include/Hal8703BPhyReg.h	1065;"	d
-bRTL8256_RxLPFBW	include/Hal8723BPhyReg.h	1063;"	d
-bRTL8256_RxLPFBW	include/Hal8723DPhyReg.h	1066;"	d
-bRTL8256_RxLPFBW	include/rtw_mp_phy_regdef.h	991;"	d
-bRTL8256_TxLPFBW	include/Hal8188EPhyReg.h	1027;"	d
-bRTL8256_TxLPFBW	include/Hal8188FPhyReg.h	1035;"	d
-bRTL8256_TxLPFBW	include/Hal8192EPhyReg.h	1038;"	d
-bRTL8256_TxLPFBW	include/Hal8703BPhyReg.h	1064;"	d
-bRTL8256_TxLPFBW	include/Hal8723BPhyReg.h	1062;"	d
-bRTL8256_TxLPFBW	include/Hal8723DPhyReg.h	1065;"	d
-bRTL8256_TxLPFBW	include/rtw_mp_phy_regdef.h	990;"	d
-bRTL8258_RSSILPFBW	include/Hal8188EPhyReg.h	1033;"	d
-bRTL8258_RSSILPFBW	include/Hal8188FPhyReg.h	1041;"	d
-bRTL8258_RSSILPFBW	include/Hal8192EPhyReg.h	1044;"	d
-bRTL8258_RSSILPFBW	include/Hal8703BPhyReg.h	1070;"	d
-bRTL8258_RSSILPFBW	include/Hal8723BPhyReg.h	1068;"	d
-bRTL8258_RSSILPFBW	include/Hal8723DPhyReg.h	1071;"	d
-bRTL8258_RSSILPFBW	include/rtw_mp_phy_regdef.h	996;"	d
-bRTL8258_RxLPFBW	include/Hal8188EPhyReg.h	1032;"	d
-bRTL8258_RxLPFBW	include/Hal8188FPhyReg.h	1040;"	d
-bRTL8258_RxLPFBW	include/Hal8192EPhyReg.h	1043;"	d
-bRTL8258_RxLPFBW	include/Hal8703BPhyReg.h	1069;"	d
-bRTL8258_RxLPFBW	include/Hal8723BPhyReg.h	1067;"	d
-bRTL8258_RxLPFBW	include/Hal8723DPhyReg.h	1070;"	d
-bRTL8258_RxLPFBW	include/rtw_mp_phy_regdef.h	995;"	d
-bRTL8258_TxLPFBW	include/Hal8188EPhyReg.h	1031;"	d
-bRTL8258_TxLPFBW	include/Hal8188FPhyReg.h	1039;"	d
-bRTL8258_TxLPFBW	include/Hal8192EPhyReg.h	1042;"	d
-bRTL8258_TxLPFBW	include/Hal8703BPhyReg.h	1068;"	d
-bRTL8258_TxLPFBW	include/Hal8723BPhyReg.h	1066;"	d
-bRTL8258_TxLPFBW	include/Hal8723DPhyReg.h	1069;"	d
-bRTL8258_TxLPFBW	include/rtw_mp_phy_regdef.h	994;"	d
-bRTWSmbCfg	include/rtw_mp.h	/^	BOOLEAN bRTWSmbCfg;$/;"	m	struct:mp_priv
-bRXIQImb_A	include/Hal8188EPhyReg.h	763;"	d
-bRXIQImb_A	include/Hal8188FPhyReg.h	771;"	d
-bRXIQImb_A	include/Hal8192EPhyReg.h	774;"	d
-bRXIQImb_A	include/Hal8703BPhyReg.h	800;"	d
-bRXIQImb_A	include/Hal8723BPhyReg.h	798;"	d
-bRXIQImb_A	include/Hal8723DPhyReg.h	801;"	d
-bRXIQImb_A	include/rtw_mp_phy_regdef.h	717;"	d
-bRXIQImb_B	include/Hal8188EPhyReg.h	764;"	d
-bRXIQImb_B	include/Hal8188FPhyReg.h	772;"	d
-bRXIQImb_B	include/Hal8192EPhyReg.h	775;"	d
-bRXIQImb_B	include/Hal8703BPhyReg.h	801;"	d
-bRXIQImb_B	include/Hal8723BPhyReg.h	799;"	d
-bRXIQImb_B	include/Hal8723DPhyReg.h	802;"	d
-bRXIQImb_B	include/rtw_mp_phy_regdef.h	718;"	d
-bRXIQImb_C	include/Hal8188EPhyReg.h	765;"	d
-bRXIQImb_C	include/Hal8188FPhyReg.h	773;"	d
-bRXIQImb_C	include/Hal8192EPhyReg.h	776;"	d
-bRXIQImb_C	include/Hal8703BPhyReg.h	802;"	d
-bRXIQImb_C	include/Hal8723BPhyReg.h	800;"	d
-bRXIQImb_C	include/Hal8723DPhyReg.h	803;"	d
-bRXIQImb_C	include/rtw_mp_phy_regdef.h	719;"	d
-bRXIQImb_D	include/Hal8188EPhyReg.h	766;"	d
-bRXIQImb_D	include/Hal8188FPhyReg.h	774;"	d
-bRXIQImb_D	include/Hal8192EPhyReg.h	777;"	d
-bRXIQImb_D	include/Hal8703BPhyReg.h	803;"	d
-bRXIQImb_D	include/Hal8723BPhyReg.h	801;"	d
-bRXIQImb_D	include/Hal8723DPhyReg.h	804;"	d
-bRXIQImb_D	include/rtw_mp_phy_regdef.h	720;"	d
-bRatio_TH	include/Hal8188EPhyReg.h	780;"	d
-bRatio_TH	include/Hal8188FPhyReg.h	788;"	d
-bRatio_TH	include/Hal8192EPhyReg.h	791;"	d
-bRatio_TH	include/Hal8703BPhyReg.h	817;"	d
-bRatio_TH	include/Hal8723BPhyReg.h	815;"	d
-bRatio_TH	include/Hal8723DPhyReg.h	818;"	d
-bRatio_TH	include/rtw_mp_phy_regdef.h	734;"	d
-bRegUseLed	include/hal_com_led.h	/^	u8					bRegUseLed;$/;"	m	struct:led_priv
-bRegulator0Standby	include/Hal8188EPhyReg.h	592;"	d
-bRegulator0Standby	include/Hal8188FPhyReg.h	600;"	d
-bRegulator0Standby	include/Hal8192EPhyReg.h	603;"	d
-bRegulator0Standby	include/Hal8703BPhyReg.h	629;"	d
-bRegulator0Standby	include/Hal8723BPhyReg.h	627;"	d
-bRegulator0Standby	include/Hal8723DPhyReg.h	630;"	d
-bRegulator0Standby	include/rtw_mp_phy_regdef.h	546;"	d
-bRegulator1Standby	include/Hal8188EPhyReg.h	594;"	d
-bRegulator1Standby	include/Hal8188FPhyReg.h	602;"	d
-bRegulator1Standby	include/Hal8192EPhyReg.h	605;"	d
-bRegulator1Standby	include/Hal8703BPhyReg.h	631;"	d
-bRegulator1Standby	include/Hal8723BPhyReg.h	629;"	d
-bRegulator1Standby	include/Hal8723DPhyReg.h	632;"	d
-bRegulator1Standby	include/rtw_mp_phy_regdef.h	548;"	d
-bRegulatorAdjust	include/Hal8188EPhyReg.h	632;"	d
-bRegulatorAdjust	include/Hal8188FPhyReg.h	640;"	d
-bRegulatorAdjust	include/Hal8192EPhyReg.h	643;"	d
-bRegulatorAdjust	include/Hal8703BPhyReg.h	669;"	d
-bRegulatorAdjust	include/Hal8723BPhyReg.h	667;"	d
-bRegulatorAdjust	include/Hal8723DPhyReg.h	670;"	d
-bRegulatorAdjust	include/rtw_mp_phy_regdef.h	586;"	d
-bRegulatorPLLStandby	include/Hal8188EPhyReg.h	593;"	d
-bRegulatorPLLStandby	include/Hal8188FPhyReg.h	601;"	d
-bRegulatorPLLStandby	include/Hal8192EPhyReg.h	604;"	d
-bRegulatorPLLStandby	include/Hal8703BPhyReg.h	630;"	d
-bRegulatorPLLStandby	include/Hal8723BPhyReg.h	628;"	d
-bRegulatorPLLStandby	include/Hal8723DPhyReg.h	631;"	d
-bRegulatorPLLStandby	include/rtw_mp_phy_regdef.h	547;"	d
-bReloadtxpowerindex	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	bReloadtxpowerindex;	$/;"	m	struct:ODM_RF_Calibration_Structure
-bReloadtxpowerindex	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN	bReloadtxpowerindex;	$/;"	m	struct:ODM_RF_Calibration_Structure
-bReloadtxpowerindex	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN	bReloadtxpowerindex;	$/;"	m	struct:ODM_RF_Calibration_Structure
-bReorderWaiting	include/rtw_recv.h	/^	u8 bReorderWaiting;$/;"	m	struct:recv_reorder_ctrl
-bRequest	include/rtw_mp_ioctl.h	/^	u8	bRequest;$/;"	m	struct:_USB_VendorReq
-bRequired	include/drv_types_ce.h	/^	BOOLEAN			bRequired;	\/* 1->required, 0->optional *\/$/;"	m	struct:_MP_REG_ENTRY
-bRequired	include/drv_types_xp.h	/^	BOOLEAN			bRequired;	\/* 1->required, 0->optional *\/$/;"	m	struct:_MP_REG_ENTRY
-bReset	hal/phydm/phydm_cfotracking.h	/^	BOOLEAN			bReset;$/;"	m	struct:_CFO_TRACKING_
-bResetTdmaAdjust	hal/btc/HalBtc8723a1Ant.h	/^	BOOLEAN		bResetTdmaAdjust;$/;"	m	struct:_COEX_DM_8723A_1ANT
-bResetTdmaAdjust	hal/btc/HalBtc8723a2Ant.h	/^	BOOLEAN		bResetTdmaAdjust;$/;"	m	struct:_COEX_DM_8723A_2ANT
-bRfPiEnable	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte 	bRfPiEnable;$/;"	m	struct:ODM_RF_Calibration_Structure
-bRfPiEnable	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte 	bRfPiEnable;$/;"	m	struct:ODM_RF_Calibration_Structure
-bRfPiEnable	hal/phydm/phydm_powertracking_win.h	/^	u1Byte 	bRfPiEnable;$/;"	m	struct:ODM_RF_Calibration_Structure
-bRfStatusNotified	include/rtw_btcoex.h	/^	BOOLEAN				bRfStatusNotified;$/;"	m	struct:_BT_MGNT
-bRxAGCAddressForLNA	include/Hal8188EPhyReg.h	822;"	d
-bRxAGCAddressForLNA	include/Hal8188FPhyReg.h	830;"	d
-bRxAGCAddressForLNA	include/Hal8192EPhyReg.h	833;"	d
-bRxAGCAddressForLNA	include/Hal8703BPhyReg.h	859;"	d
-bRxAGCAddressForLNA	include/Hal8723BPhyReg.h	857;"	d
-bRxAGCAddressForLNA	include/Hal8723DPhyReg.h	860;"	d
-bRxAGCAddressForLNA	include/rtw_mp_phy_regdef.h	776;"	d
-bRxAGCEn	include/Hal8188EPhyReg.h	836;"	d
-bRxAGCEn	include/Hal8188FPhyReg.h	844;"	d
-bRxAGCEn	include/Hal8192EPhyReg.h	847;"	d
-bRxAGCEn	include/Hal8703BPhyReg.h	873;"	d
-bRxAGCEn	include/Hal8723BPhyReg.h	871;"	d
-bRxAGCEn	include/Hal8723DPhyReg.h	874;"	d
-bRxAGCEn	include/rtw_mp_phy_regdef.h	790;"	d
-bRxAGCFreezeThres	include/Hal8188EPhyReg.h	824;"	d
-bRxAGCFreezeThres	include/Hal8188FPhyReg.h	832;"	d
-bRxAGCFreezeThres	include/Hal8192EPhyReg.h	835;"	d
-bRxAGCFreezeThres	include/Hal8703BPhyReg.h	861;"	d
-bRxAGCFreezeThres	include/Hal8723BPhyReg.h	859;"	d
-bRxAGCFreezeThres	include/Hal8723DPhyReg.h	862;"	d
-bRxAGCFreezeThres	include/rtw_mp_phy_regdef.h	778;"	d
-bRxAGCFreezeThresMode	include/Hal8188EPhyReg.h	831;"	d
-bRxAGCFreezeThresMode	include/Hal8188FPhyReg.h	839;"	d
-bRxAGCFreezeThresMode	include/Hal8192EPhyReg.h	842;"	d
-bRxAGCFreezeThresMode	include/Hal8703BPhyReg.h	868;"	d
-bRxAGCFreezeThresMode	include/Hal8723BPhyReg.h	866;"	d
-bRxAGCFreezeThresMode	include/Hal8723DPhyReg.h	869;"	d
-bRxAGCFreezeThresMode	include/rtw_mp_phy_regdef.h	785;"	d
-bRxAGCMin	include/Hal8188EPhyReg.h	838;"	d
-bRxAGCMin	include/Hal8188FPhyReg.h	846;"	d
-bRxAGCMin	include/Hal8192EPhyReg.h	849;"	d
-bRxAGCMin	include/Hal8703BPhyReg.h	875;"	d
-bRxAGCMin	include/Hal8723BPhyReg.h	873;"	d
-bRxAGCMin	include/Hal8723DPhyReg.h	876;"	d
-bRxAGCMin	include/rtw_mp_phy_regdef.h	792;"	d
-bRxAGCShift	include/Hal8188EPhyReg.h	833;"	d
-bRxAGCShift	include/Hal8188FPhyReg.h	841;"	d
-bRxAGCShift	include/Hal8192EPhyReg.h	844;"	d
-bRxAGCShift	include/Hal8703BPhyReg.h	870;"	d
-bRxAGCShift	include/Hal8723BPhyReg.h	868;"	d
-bRxAGCShift	include/Hal8723DPhyReg.h	871;"	d
-bRxAGCShift	include/rtw_mp_phy_regdef.h	787;"	d
-bRxAGCTogetherEn	include/Hal8188EPhyReg.h	837;"	d
-bRxAGCTogetherEn	include/Hal8188FPhyReg.h	845;"	d
-bRxAGCTogetherEn	include/Hal8192EPhyReg.h	848;"	d
-bRxAGCTogetherEn	include/Hal8703BPhyReg.h	874;"	d
-bRxAGCTogetherEn	include/Hal8723BPhyReg.h	872;"	d
-bRxAGCTogetherEn	include/Hal8723DPhyReg.h	875;"	d
-bRxAGCTogetherEn	include/rtw_mp_phy_regdef.h	791;"	d
-bRxAntDivEn	include/Hal8188EPhyReg.h	821;"	d
-bRxAntDivEn	include/Hal8188FPhyReg.h	829;"	d
-bRxAntDivEn	include/Hal8192EPhyReg.h	832;"	d
-bRxAntDivEn	include/Hal8703BPhyReg.h	858;"	d
-bRxAntDivEn	include/Hal8723BPhyReg.h	856;"	d
-bRxAntDivEn	include/Hal8723DPhyReg.h	859;"	d
-bRxAntDivEn	include/rtw_mp_phy_regdef.h	775;"	d
-bRxAntennaPowerShift	include/Hal8188EPhyReg.h	857;"	d
-bRxAntennaPowerShift	include/Hal8188FPhyReg.h	865;"	d
-bRxAntennaPowerShift	include/Hal8192EPhyReg.h	868;"	d
-bRxAntennaPowerShift	include/Hal8703BPhyReg.h	894;"	d
-bRxAntennaPowerShift	include/Hal8723BPhyReg.h	892;"	d
-bRxAntennaPowerShift	include/Hal8723DPhyReg.h	895;"	d
-bRxAntennaPowerShift	include/rtw_mp_phy_regdef.h	811;"	d
-bRxBusyTraffic	include/rtw_mlme.h	/^	BOOLEAN			bRxBusyTraffic;$/;"	m	struct:_RT_LINK_DETECT_T
-bRxDCNFType	include/Hal8188EPhyReg.h	762;"	d
-bRxDCNFType	include/Hal8188FPhyReg.h	770;"	d
-bRxDCNFType	include/Hal8192EPhyReg.h	773;"	d
-bRxDCNFType	include/Hal8703BPhyReg.h	799;"	d
-bRxDCNFType	include/Hal8723BPhyReg.h	797;"	d
-bRxDCNFType	include/Hal8723DPhyReg.h	800;"	d
-bRxDCNFType	include/rtw_mp_phy_regdef.h	716;"	d
-bRxDFIRMode	include/Hal8188EPhyReg.h	761;"	d
-bRxDFIRMode	include/Hal8188FPhyReg.h	769;"	d
-bRxDFIRMode	include/Hal8192EPhyReg.h	772;"	d
-bRxDFIRMode	include/Hal8703BPhyReg.h	798;"	d
-bRxDFIRMode	include/Hal8723BPhyReg.h	796;"	d
-bRxDFIRMode	include/Hal8723DPhyReg.h	799;"	d
-bRxDFIRMode	include/rtw_mp_phy_regdef.h	715;"	d
-bRxEVM1st	include/Hal8188EPhyReg.h	959;"	d
-bRxEVM1st	include/Hal8188FPhyReg.h	967;"	d
-bRxEVM1st	include/Hal8192EPhyReg.h	970;"	d
-bRxEVM1st	include/Hal8703BPhyReg.h	996;"	d
-bRxEVM1st	include/Hal8723BPhyReg.h	994;"	d
-bRxEVM1st	include/Hal8723DPhyReg.h	997;"	d
-bRxEVM1st	include/rtw_mp_phy_regdef.h	913;"	d
-bRxEVM2nd	include/Hal8188EPhyReg.h	960;"	d
-bRxEVM2nd	include/Hal8188FPhyReg.h	968;"	d
-bRxEVM2nd	include/Hal8192EPhyReg.h	971;"	d
-bRxEVM2nd	include/Hal8703BPhyReg.h	997;"	d
-bRxEVM2nd	include/Hal8723BPhyReg.h	995;"	d
-bRxEVM2nd	include/Hal8723DPhyReg.h	998;"	d
-bRxEVM2nd	include/rtw_mp_phy_regdef.h	914;"	d
-bRxFrame_Guard_Counter_L	include/Hal8188EPhyReg.h	884;"	d
-bRxFrame_Guard_Counter_L	include/Hal8188FPhyReg.h	892;"	d
-bRxFrame_Guard_Counter_L	include/Hal8192EPhyReg.h	895;"	d
-bRxFrame_Guard_Counter_L	include/Hal8703BPhyReg.h	921;"	d
-bRxFrame_Guard_Counter_L	include/Hal8723BPhyReg.h	919;"	d
-bRxFrame_Guard_Counter_L	include/Hal8723DPhyReg.h	922;"	d
-bRxFrame_Guard_Counter_L	include/rtw_mp_phy_regdef.h	838;"	d
-bRxFreezeStep_AGC0	include/Hal8188EPhyReg.h	828;"	d
-bRxFreezeStep_AGC0	include/Hal8188FPhyReg.h	836;"	d
-bRxFreezeStep_AGC0	include/Hal8192EPhyReg.h	839;"	d
-bRxFreezeStep_AGC0	include/Hal8703BPhyReg.h	865;"	d
-bRxFreezeStep_AGC0	include/Hal8723BPhyReg.h	863;"	d
-bRxFreezeStep_AGC0	include/Hal8723DPhyReg.h	866;"	d
-bRxFreezeStep_AGC0	include/rtw_mp_phy_regdef.h	782;"	d
-bRxFreezeStep_AGC1	include/Hal8188EPhyReg.h	825;"	d
-bRxFreezeStep_AGC1	include/Hal8188FPhyReg.h	833;"	d
-bRxFreezeStep_AGC1	include/Hal8192EPhyReg.h	836;"	d
-bRxFreezeStep_AGC1	include/Hal8703BPhyReg.h	862;"	d
-bRxFreezeStep_AGC1	include/Hal8723BPhyReg.h	860;"	d
-bRxFreezeStep_AGC1	include/Hal8723DPhyReg.h	863;"	d
-bRxFreezeStep_AGC1	include/rtw_mp_phy_regdef.h	779;"	d
-bRxFreezeStep_AGC2	include/Hal8188EPhyReg.h	826;"	d
-bRxFreezeStep_AGC2	include/Hal8188FPhyReg.h	834;"	d
-bRxFreezeStep_AGC2	include/Hal8192EPhyReg.h	837;"	d
-bRxFreezeStep_AGC2	include/Hal8703BPhyReg.h	863;"	d
-bRxFreezeStep_AGC2	include/Hal8723BPhyReg.h	861;"	d
-bRxFreezeStep_AGC2	include/Hal8723DPhyReg.h	864;"	d
-bRxFreezeStep_AGC2	include/rtw_mp_phy_regdef.h	780;"	d
-bRxFreezeStep_AGC3	include/Hal8188EPhyReg.h	827;"	d
-bRxFreezeStep_AGC3	include/Hal8188FPhyReg.h	835;"	d
-bRxFreezeStep_AGC3	include/Hal8192EPhyReg.h	838;"	d
-bRxFreezeStep_AGC3	include/Hal8703BPhyReg.h	864;"	d
-bRxFreezeStep_AGC3	include/Hal8723BPhyReg.h	862;"	d
-bRxFreezeStep_AGC3	include/Hal8723DPhyReg.h	865;"	d
-bRxFreezeStep_AGC3	include/rtw_mp_phy_regdef.h	781;"	d
-bRxHPCCKIni	include/Hal8188EPhyReg.h	537;"	d
-bRxHPCCKIni	include/Hal8188FPhyReg.h	545;"	d
-bRxHPCCKIni	include/Hal8192EPhyReg.h	548;"	d
-bRxHPCCKIni	include/Hal8703BPhyReg.h	574;"	d
-bRxHPCCKIni	include/Hal8723BPhyReg.h	572;"	d
-bRxHPCCKIni	include/Hal8723DPhyReg.h	575;"	d
-bRxHPCCKIni	include/rtw_mp_phy_regdef.h	487;"	d
-bRxHPT2R	include/Hal8188EPhyReg.h	536;"	d
-bRxHPT2R	include/Hal8188FPhyReg.h	544;"	d
-bRxHPT2R	include/Hal8192EPhyReg.h	547;"	d
-bRxHPT2R	include/Hal8703BPhyReg.h	573;"	d
-bRxHPT2R	include/Hal8723BPhyReg.h	571;"	d
-bRxHPT2R	include/Hal8723DPhyReg.h	574;"	d
-bRxHPT2R	include/rtw_mp_phy_regdef.h	486;"	d
-bRxHPTx	include/Hal8188EPhyReg.h	535;"	d
-bRxHPTx	include/Hal8188FPhyReg.h	543;"	d
-bRxHPTx	include/Hal8192EPhyReg.h	546;"	d
-bRxHPTx	include/Hal8703BPhyReg.h	572;"	d
-bRxHPTx	include/Hal8723BPhyReg.h	570;"	d
-bRxHPTx	include/Hal8723DPhyReg.h	573;"	d
-bRxHPTx	include/rtw_mp_phy_regdef.h	485;"	d
-bRxHP_BBP1	include/Hal8188EPhyReg.h	842;"	d
-bRxHP_BBP1	include/Hal8188FPhyReg.h	850;"	d
-bRxHP_BBP1	include/Hal8192EPhyReg.h	853;"	d
-bRxHP_BBP1	include/Hal8703BPhyReg.h	879;"	d
-bRxHP_BBP1	include/Hal8723BPhyReg.h	877;"	d
-bRxHP_BBP1	include/Hal8723DPhyReg.h	880;"	d
-bRxHP_BBP1	include/rtw_mp_phy_regdef.h	796;"	d
-bRxHP_BBP2	include/Hal8188EPhyReg.h	843;"	d
-bRxHP_BBP2	include/Hal8188FPhyReg.h	851;"	d
-bRxHP_BBP2	include/Hal8192EPhyReg.h	854;"	d
-bRxHP_BBP2	include/Hal8703BPhyReg.h	880;"	d
-bRxHP_BBP2	include/Hal8723BPhyReg.h	878;"	d
-bRxHP_BBP2	include/Hal8723DPhyReg.h	881;"	d
-bRxHP_BBP2	include/rtw_mp_phy_regdef.h	797;"	d
-bRxHP_BBP3	include/Hal8188EPhyReg.h	844;"	d
-bRxHP_BBP3	include/Hal8188FPhyReg.h	852;"	d
-bRxHP_BBP3	include/Hal8192EPhyReg.h	855;"	d
-bRxHP_BBP3	include/Hal8703BPhyReg.h	881;"	d
-bRxHP_BBP3	include/Hal8723BPhyReg.h	879;"	d
-bRxHP_BBP3	include/Hal8723DPhyReg.h	882;"	d
-bRxHP_BBP3	include/rtw_mp_phy_regdef.h	798;"	d
-bRxHP_Final	include/Hal8188EPhyReg.h	859;"	d
-bRxHP_Final	include/Hal8188FPhyReg.h	867;"	d
-bRxHP_Final	include/Hal8192EPhyReg.h	870;"	d
-bRxHP_Final	include/Hal8703BPhyReg.h	896;"	d
-bRxHP_Final	include/Hal8723BPhyReg.h	894;"	d
-bRxHP_Final	include/Hal8723DPhyReg.h	897;"	d
-bRxHP_Final	include/rtw_mp_phy_regdef.h	813;"	d
-bRxHP_Ini	include/Hal8188EPhyReg.h	839;"	d
-bRxHP_Ini	include/Hal8188FPhyReg.h	847;"	d
-bRxHP_Ini	include/Hal8192EPhyReg.h	850;"	d
-bRxHP_Ini	include/Hal8703BPhyReg.h	876;"	d
-bRxHP_Ini	include/Hal8723BPhyReg.h	874;"	d
-bRxHP_Ini	include/Hal8723DPhyReg.h	877;"	d
-bRxHP_Ini	include/rtw_mp_phy_regdef.h	793;"	d
-bRxHP_RSSI	include/Hal8188EPhyReg.h	841;"	d
-bRxHP_RSSI	include/Hal8188FPhyReg.h	849;"	d
-bRxHP_RSSI	include/Hal8192EPhyReg.h	852;"	d
-bRxHP_RSSI	include/Hal8703BPhyReg.h	878;"	d
-bRxHP_RSSI	include/Hal8723BPhyReg.h	876;"	d
-bRxHP_RSSI	include/Hal8723DPhyReg.h	879;"	d
-bRxHP_RSSI	include/rtw_mp_phy_regdef.h	795;"	d
-bRxHP_TRLNA	include/Hal8188EPhyReg.h	840;"	d
-bRxHP_TRLNA	include/Hal8188FPhyReg.h	848;"	d
-bRxHP_TRLNA	include/Hal8192EPhyReg.h	851;"	d
-bRxHP_TRLNA	include/Hal8703BPhyReg.h	877;"	d
-bRxHP_TRLNA	include/Hal8723BPhyReg.h	875;"	d
-bRxHP_TRLNA	include/Hal8723DPhyReg.h	878;"	d
-bRxHP_TRLNA	include/rtw_mp_phy_regdef.h	794;"	d
-bRxHTAGCEn	include/Hal8188EPhyReg.h	870;"	d
-bRxHTAGCEn	include/Hal8188FPhyReg.h	878;"	d
-bRxHTAGCEn	include/Hal8192EPhyReg.h	881;"	d
-bRxHTAGCEn	include/Hal8703BPhyReg.h	907;"	d
-bRxHTAGCEn	include/Hal8723BPhyReg.h	905;"	d
-bRxHTAGCEn	include/Hal8723DPhyReg.h	908;"	d
-bRxHTAGCEn	include/rtw_mp_phy_regdef.h	824;"	d
-bRxHTAGCFreezeThres	include/Hal8188EPhyReg.h	867;"	d
-bRxHTAGCFreezeThres	include/Hal8188FPhyReg.h	875;"	d
-bRxHTAGCFreezeThres	include/Hal8192EPhyReg.h	878;"	d
-bRxHTAGCFreezeThres	include/Hal8703BPhyReg.h	904;"	d
-bRxHTAGCFreezeThres	include/Hal8723BPhyReg.h	902;"	d
-bRxHTAGCFreezeThres	include/Hal8723DPhyReg.h	905;"	d
-bRxHTAGCFreezeThres	include/rtw_mp_phy_regdef.h	821;"	d
-bRxHTAGCMin	include/Hal8188EPhyReg.h	869;"	d
-bRxHTAGCMin	include/Hal8188FPhyReg.h	877;"	d
-bRxHTAGCMin	include/Hal8192EPhyReg.h	880;"	d
-bRxHTAGCMin	include/Hal8703BPhyReg.h	906;"	d
-bRxHTAGCMin	include/Hal8723BPhyReg.h	904;"	d
-bRxHTAGCMin	include/Hal8723DPhyReg.h	907;"	d
-bRxHTAGCMin	include/rtw_mp_phy_regdef.h	823;"	d
-bRxHTAGCTogetherEn	include/Hal8188EPhyReg.h	868;"	d
-bRxHTAGCTogetherEn	include/Hal8188FPhyReg.h	876;"	d
-bRxHTAGCTogetherEn	include/Hal8192EPhyReg.h	879;"	d
-bRxHTAGCTogetherEn	include/Hal8703BPhyReg.h	905;"	d
-bRxHTAGCTogetherEn	include/Hal8723BPhyReg.h	903;"	d
-bRxHTAGCTogetherEn	include/Hal8723DPhyReg.h	906;"	d
-bRxHTAGCTogetherEn	include/rtw_mp_phy_regdef.h	822;"	d
-bRxHTDAGCEn	include/Hal8188EPhyReg.h	871;"	d
-bRxHTDAGCEn	include/Hal8188FPhyReg.h	879;"	d
-bRxHTDAGCEn	include/Hal8192EPhyReg.h	882;"	d
-bRxHTDAGCEn	include/Hal8703BPhyReg.h	908;"	d
-bRxHTDAGCEn	include/Hal8723BPhyReg.h	906;"	d
-bRxHTDAGCEn	include/Hal8723DPhyReg.h	909;"	d
-bRxHTDAGCEn	include/rtw_mp_phy_regdef.h	825;"	d
-bRxHTRxHPEn	include/Hal8188EPhyReg.h	866;"	d
-bRxHTRxHPEn	include/Hal8188FPhyReg.h	874;"	d
-bRxHTRxHPEn	include/Hal8192EPhyReg.h	877;"	d
-bRxHTRxHPEn	include/Hal8703BPhyReg.h	903;"	d
-bRxHTRxHPEn	include/Hal8723BPhyReg.h	901;"	d
-bRxHTRxHPEn	include/Hal8723DPhyReg.h	904;"	d
-bRxHTRxHPEn	include/rtw_mp_phy_regdef.h	820;"	d
-bRxHTRxHP_BBP	include/Hal8188EPhyReg.h	872;"	d
-bRxHTRxHP_BBP	include/Hal8188FPhyReg.h	880;"	d
-bRxHTRxHP_BBP	include/Hal8192EPhyReg.h	883;"	d
-bRxHTRxHP_BBP	include/Hal8703BPhyReg.h	909;"	d
-bRxHTRxHP_BBP	include/Hal8723BPhyReg.h	907;"	d
-bRxHTRxHP_BBP	include/Hal8723DPhyReg.h	910;"	d
-bRxHTRxHP_BBP	include/rtw_mp_phy_regdef.h	826;"	d
-bRxHTRxHP_Final	include/Hal8188EPhyReg.h	873;"	d
-bRxHTRxHP_Final	include/Hal8188FPhyReg.h	881;"	d
-bRxHTRxHP_Final	include/Hal8192EPhyReg.h	884;"	d
-bRxHTRxHP_Final	include/Hal8703BPhyReg.h	910;"	d
-bRxHTRxHP_Final	include/Hal8723BPhyReg.h	908;"	d
-bRxHTRxHP_Final	include/Hal8723DPhyReg.h	911;"	d
-bRxHTRxHP_Final	include/rtw_mp_phy_regdef.h	827;"	d
-bRxHTSettle_BBP	include/Hal8188EPhyReg.h	860;"	d
-bRxHTSettle_BBP	include/Hal8188FPhyReg.h	868;"	d
-bRxHTSettle_BBP	include/Hal8192EPhyReg.h	871;"	d
-bRxHTSettle_BBP	include/Hal8703BPhyReg.h	897;"	d
-bRxHTSettle_BBP	include/Hal8723BPhyReg.h	895;"	d
-bRxHTSettle_BBP	include/Hal8723DPhyReg.h	898;"	d
-bRxHTSettle_BBP	include/rtw_mp_phy_regdef.h	814;"	d
-bRxHTSettle_BBPPW	include/Hal8188EPhyReg.h	863;"	d
-bRxHTSettle_BBPPW	include/Hal8188FPhyReg.h	871;"	d
-bRxHTSettle_BBPPW	include/Hal8192EPhyReg.h	874;"	d
-bRxHTSettle_BBPPW	include/Hal8703BPhyReg.h	900;"	d
-bRxHTSettle_BBPPW	include/Hal8723BPhyReg.h	898;"	d
-bRxHTSettle_BBPPW	include/Hal8723DPhyReg.h	901;"	d
-bRxHTSettle_BBPPW	include/rtw_mp_phy_regdef.h	817;"	d
-bRxHTSettle_HSSI	include/Hal8188EPhyReg.h	861;"	d
-bRxHTSettle_HSSI	include/Hal8188FPhyReg.h	869;"	d
-bRxHTSettle_HSSI	include/Hal8192EPhyReg.h	872;"	d
-bRxHTSettle_HSSI	include/Hal8703BPhyReg.h	898;"	d
-bRxHTSettle_HSSI	include/Hal8723BPhyReg.h	896;"	d
-bRxHTSettle_HSSI	include/Hal8723DPhyReg.h	899;"	d
-bRxHTSettle_HSSI	include/rtw_mp_phy_regdef.h	815;"	d
-bRxHTSettle_Idle	include/Hal8188EPhyReg.h	864;"	d
-bRxHTSettle_Idle	include/Hal8188FPhyReg.h	872;"	d
-bRxHTSettle_Idle	include/Hal8192EPhyReg.h	875;"	d
-bRxHTSettle_Idle	include/Hal8703BPhyReg.h	901;"	d
-bRxHTSettle_Idle	include/Hal8723BPhyReg.h	899;"	d
-bRxHTSettle_Idle	include/Hal8723DPhyReg.h	902;"	d
-bRxHTSettle_Idle	include/rtw_mp_phy_regdef.h	818;"	d
-bRxHTSettle_Reserved	include/Hal8188EPhyReg.h	865;"	d
-bRxHTSettle_Reserved	include/Hal8188FPhyReg.h	873;"	d
-bRxHTSettle_Reserved	include/Hal8192EPhyReg.h	876;"	d
-bRxHTSettle_Reserved	include/Hal8703BPhyReg.h	902;"	d
-bRxHTSettle_Reserved	include/Hal8723BPhyReg.h	900;"	d
-bRxHTSettle_Reserved	include/Hal8723DPhyReg.h	903;"	d
-bRxHTSettle_Reserved	include/rtw_mp_phy_regdef.h	819;"	d
-bRxHTSettle_RxHP	include/Hal8188EPhyReg.h	862;"	d
-bRxHTSettle_RxHP	include/Hal8188FPhyReg.h	870;"	d
-bRxHTSettle_RxHP	include/Hal8192EPhyReg.h	873;"	d
-bRxHTSettle_RxHP	include/Hal8703BPhyReg.h	899;"	d
-bRxHTSettle_RxHP	include/Hal8723BPhyReg.h	897;"	d
-bRxHTSettle_RxHP	include/Hal8723DPhyReg.h	900;"	d
-bRxHTSettle_RxHP	include/rtw_mp_phy_regdef.h	816;"	d
-bRxHighPowerFlow	include/Hal8188EPhyReg.h	823;"	d
-bRxHighPowerFlow	include/Hal8188FPhyReg.h	831;"	d
-bRxHighPowerFlow	include/Hal8192EPhyReg.h	834;"	d
-bRxHighPowerFlow	include/Hal8703BPhyReg.h	860;"	d
-bRxHighPowerFlow	include/Hal8723BPhyReg.h	858;"	d
-bRxHighPowerFlow	include/Hal8723DPhyReg.h	861;"	d
-bRxHighPowerFlow	include/rtw_mp_phy_regdef.h	777;"	d
-bRxIDCOffset	include/Hal8188EPhyReg.h	759;"	d
-bRxIDCOffset	include/Hal8188FPhyReg.h	767;"	d
-bRxIDCOffset	include/Hal8192EPhyReg.h	770;"	d
-bRxIDCOffset	include/Hal8703BPhyReg.h	796;"	d
-bRxIDCOffset	include/Hal8723BPhyReg.h	794;"	d
-bRxIDCOffset	include/Hal8723DPhyReg.h	797;"	d
-bRxIDCOffset	include/rtw_mp_phy_regdef.h	713;"	d
-bRxInitialGain	include/Hal8188EPhyReg.h	820;"	d
-bRxInitialGain	include/Hal8188FPhyReg.h	828;"	d
-bRxInitialGain	include/Hal8192EPhyReg.h	831;"	d
-bRxInitialGain	include/Hal8703BPhyReg.h	857;"	d
-bRxInitialGain	include/Hal8723BPhyReg.h	855;"	d
-bRxInitialGain	include/Hal8723DPhyReg.h	858;"	d
-bRxInitialGain	include/rtw_mp_phy_regdef.h	774;"	d
-bRxMFHold	include/Hal8188EPhyReg.h	876;"	d
-bRxMFHold	include/Hal8188FPhyReg.h	884;"	d
-bRxMFHold	include/Hal8192EPhyReg.h	887;"	d
-bRxMFHold	include/Hal8703BPhyReg.h	913;"	d
-bRxMFHold	include/Hal8723BPhyReg.h	911;"	d
-bRxMFHold	include/Hal8723DPhyReg.h	914;"	d
-bRxMFHold	include/rtw_mp_phy_regdef.h	830;"	d
-bRxNBINotch	include/Hal8188EPhyReg.h	768;"	d
-bRxNBINotch	include/Hal8188FPhyReg.h	776;"	d
-bRxNBINotch	include/Hal8192EPhyReg.h	779;"	d
-bRxNBINotch	include/Hal8703BPhyReg.h	805;"	d
-bRxNBINotch	include/Hal8723BPhyReg.h	803;"	d
-bRxNBINotch	include/Hal8723DPhyReg.h	806;"	d
-bRxNBINotch	include/rtw_mp_phy_regdef.h	722;"	d
-bRxOverFlowCheckType	include/Hal8188EPhyReg.h	832;"	d
-bRxOverFlowCheckType	include/Hal8188FPhyReg.h	840;"	d
-bRxOverFlowCheckType	include/Hal8192EPhyReg.h	843;"	d
-bRxOverFlowCheckType	include/Hal8703BPhyReg.h	869;"	d
-bRxOverFlowCheckType	include/Hal8723BPhyReg.h	867;"	d
-bRxOverFlowCheckType	include/Hal8723DPhyReg.h	870;"	d
-bRxOverFlowCheckType	include/rtw_mp_phy_regdef.h	786;"	d
-bRxPD_DC_COUNT_MAX	include/Hal8188EPhyReg.h	879;"	d
-bRxPD_DC_COUNT_MAX	include/Hal8188FPhyReg.h	887;"	d
-bRxPD_DC_COUNT_MAX	include/Hal8192EPhyReg.h	890;"	d
-bRxPD_DC_COUNT_MAX	include/Hal8703BPhyReg.h	916;"	d
-bRxPD_DC_COUNT_MAX	include/Hal8723BPhyReg.h	914;"	d
-bRxPD_DC_COUNT_MAX	include/Hal8723DPhyReg.h	917;"	d
-bRxPD_DC_COUNT_MAX	include/rtw_mp_phy_regdef.h	833;"	d
-bRxPD_Delay_TH	include/Hal8188EPhyReg.h	881;"	d
-bRxPD_Delay_TH	include/Hal8188FPhyReg.h	889;"	d
-bRxPD_Delay_TH	include/Hal8192EPhyReg.h	892;"	d
-bRxPD_Delay_TH	include/Hal8703BPhyReg.h	918;"	d
-bRxPD_Delay_TH	include/Hal8723BPhyReg.h	916;"	d
-bRxPD_Delay_TH	include/Hal8723DPhyReg.h	919;"	d
-bRxPD_Delay_TH	include/rtw_mp_phy_regdef.h	835;"	d
-bRxPD_Delay_TH1	include/Hal8188EPhyReg.h	877;"	d
-bRxPD_Delay_TH1	include/Hal8188FPhyReg.h	885;"	d
-bRxPD_Delay_TH1	include/Hal8192EPhyReg.h	888;"	d
-bRxPD_Delay_TH1	include/Hal8703BPhyReg.h	914;"	d
-bRxPD_Delay_TH1	include/Hal8723BPhyReg.h	912;"	d
-bRxPD_Delay_TH1	include/Hal8723DPhyReg.h	915;"	d
-bRxPD_Delay_TH1	include/rtw_mp_phy_regdef.h	831;"	d
-bRxPD_Delay_TH2	include/Hal8188EPhyReg.h	878;"	d
-bRxPD_Delay_TH2	include/Hal8188FPhyReg.h	886;"	d
-bRxPD_Delay_TH2	include/Hal8192EPhyReg.h	889;"	d
-bRxPD_Delay_TH2	include/Hal8703BPhyReg.h	915;"	d
-bRxPD_Delay_TH2	include/Hal8723BPhyReg.h	913;"	d
-bRxPD_Delay_TH2	include/Hal8723DPhyReg.h	916;"	d
-bRxPD_Delay_TH2	include/rtw_mp_phy_regdef.h	832;"	d
-bRxPWRatioEn	include/Hal8188EPhyReg.h	875;"	d
-bRxPWRatioEn	include/Hal8188FPhyReg.h	883;"	d
-bRxPWRatioEn	include/Hal8192EPhyReg.h	886;"	d
-bRxPWRatioEn	include/Hal8703BPhyReg.h	912;"	d
-bRxPWRatioEn	include/Hal8723BPhyReg.h	910;"	d
-bRxPWRatioEn	include/Hal8723DPhyReg.h	913;"	d
-bRxPWRatioEn	include/rtw_mp_phy_regdef.h	829;"	d
-bRxPWRatioTH	include/Hal8188EPhyReg.h	874;"	d
-bRxPWRatioTH	include/Hal8188FPhyReg.h	882;"	d
-bRxPWRatioTH	include/Hal8192EPhyReg.h	885;"	d
-bRxPWRatioTH	include/Hal8703BPhyReg.h	911;"	d
-bRxPWRatioTH	include/Hal8723BPhyReg.h	909;"	d
-bRxPWRatioTH	include/Hal8723DPhyReg.h	912;"	d
-bRxPWRatioTH	include/rtw_mp_phy_regdef.h	828;"	d
-bRxPathA	include/Hal8188EPhyReg.h	747;"	d
-bRxPathA	include/Hal8188FPhyReg.h	755;"	d
-bRxPathA	include/Hal8192EPhyReg.h	758;"	d
-bRxPathA	include/Hal8703BPhyReg.h	784;"	d
-bRxPathA	include/Hal8723BPhyReg.h	782;"	d
-bRxPathA	include/Hal8723DPhyReg.h	785;"	d
-bRxPathA	include/rtw_mp_phy_regdef.h	701;"	d
-bRxPathB	include/Hal8188EPhyReg.h	748;"	d
-bRxPathB	include/Hal8188FPhyReg.h	756;"	d
-bRxPathB	include/Hal8192EPhyReg.h	759;"	d
-bRxPathB	include/Hal8703BPhyReg.h	785;"	d
-bRxPathB	include/Hal8723BPhyReg.h	783;"	d
-bRxPathB	include/Hal8723DPhyReg.h	786;"	d
-bRxPathB	include/rtw_mp_phy_regdef.h	702;"	d
-bRxPathC	include/Hal8188EPhyReg.h	749;"	d
-bRxPathC	include/Hal8188FPhyReg.h	757;"	d
-bRxPathC	include/Hal8192EPhyReg.h	760;"	d
-bRxPathC	include/Hal8703BPhyReg.h	786;"	d
-bRxPathC	include/Hal8723BPhyReg.h	784;"	d
-bRxPathC	include/Hal8723DPhyReg.h	787;"	d
-bRxPathC	include/rtw_mp_phy_regdef.h	703;"	d
-bRxPathD	include/Hal8188EPhyReg.h	750;"	d
-bRxPathD	include/Hal8188FPhyReg.h	758;"	d
-bRxPathD	include/Hal8192EPhyReg.h	761;"	d
-bRxPathD	include/Hal8703BPhyReg.h	787;"	d
-bRxPathD	include/Hal8723BPhyReg.h	785;"	d
-bRxPathD	include/Hal8723DPhyReg.h	788;"	d
-bRxPathD	include/rtw_mp_phy_regdef.h	704;"	d
-bRxPath_Jaguar	include/Hal8812PhyReg.h	54;"	d
-bRxPath_Jaguar	include/Hal8814PhyReg.h	56;"	d
-bRxPesudoNoiseOn	include/Hal8188EPhyReg.h	1002;"	d
-bRxPesudoNoiseOn	include/Hal8188FPhyReg.h	1010;"	d
-bRxPesudoNoiseOn	include/Hal8192EPhyReg.h	1013;"	d
-bRxPesudoNoiseOn	include/Hal8703BPhyReg.h	1039;"	d
-bRxPesudoNoiseOn	include/Hal8723BPhyReg.h	1037;"	d
-bRxPesudoNoiseOn	include/Hal8723DPhyReg.h	1040;"	d
-bRxPesudoNoiseOn	include/rtw_mp_phy_regdef.h	965;"	d
-bRxPesudoNoise_A	include/Hal8188EPhyReg.h	1003;"	d
-bRxPesudoNoise_A	include/Hal8188FPhyReg.h	1011;"	d
-bRxPesudoNoise_A	include/Hal8192EPhyReg.h	1014;"	d
-bRxPesudoNoise_A	include/Hal8703BPhyReg.h	1040;"	d
-bRxPesudoNoise_A	include/Hal8723BPhyReg.h	1038;"	d
-bRxPesudoNoise_A	include/Hal8723DPhyReg.h	1041;"	d
-bRxPesudoNoise_A	include/rtw_mp_phy_regdef.h	966;"	d
-bRxPesudoNoise_B	include/Hal8188EPhyReg.h	1004;"	d
-bRxPesudoNoise_B	include/Hal8188FPhyReg.h	1012;"	d
-bRxPesudoNoise_B	include/Hal8192EPhyReg.h	1015;"	d
-bRxPesudoNoise_B	include/Hal8703BPhyReg.h	1041;"	d
-bRxPesudoNoise_B	include/Hal8723BPhyReg.h	1039;"	d
-bRxPesudoNoise_B	include/Hal8723DPhyReg.h	1042;"	d
-bRxPesudoNoise_B	include/rtw_mp_phy_regdef.h	967;"	d
-bRxPesudoNoise_C	include/Hal8188EPhyReg.h	1005;"	d
-bRxPesudoNoise_C	include/Hal8188FPhyReg.h	1013;"	d
-bRxPesudoNoise_C	include/Hal8192EPhyReg.h	1016;"	d
-bRxPesudoNoise_C	include/Hal8703BPhyReg.h	1042;"	d
-bRxPesudoNoise_C	include/Hal8723BPhyReg.h	1040;"	d
-bRxPesudoNoise_C	include/Hal8723DPhyReg.h	1043;"	d
-bRxPesudoNoise_C	include/rtw_mp_phy_regdef.h	968;"	d
-bRxPesudoNoise_D	include/Hal8188EPhyReg.h	1006;"	d
-bRxPesudoNoise_D	include/Hal8188FPhyReg.h	1014;"	d
-bRxPesudoNoise_D	include/Hal8192EPhyReg.h	1017;"	d
-bRxPesudoNoise_D	include/Hal8703BPhyReg.h	1043;"	d
-bRxPesudoNoise_D	include/Hal8723BPhyReg.h	1041;"	d
-bRxPesudoNoise_D	include/Hal8723DPhyReg.h	1044;"	d
-bRxPesudoNoise_D	include/rtw_mp_phy_regdef.h	969;"	d
-bRxProcessTime_BBPPW	include/Hal8188EPhyReg.h	856;"	d
-bRxProcessTime_BBPPW	include/Hal8188FPhyReg.h	864;"	d
-bRxProcessTime_BBPPW	include/Hal8192EPhyReg.h	867;"	d
-bRxProcessTime_BBPPW	include/Hal8703BPhyReg.h	893;"	d
-bRxProcessTime_BBPPW	include/Hal8723BPhyReg.h	891;"	d
-bRxProcessTime_BBPPW	include/Hal8723DPhyReg.h	894;"	d
-bRxProcessTime_BBPPW	include/rtw_mp_phy_regdef.h	810;"	d
-bRxProcessTime_DAGC	include/Hal8188EPhyReg.h	854;"	d
-bRxProcessTime_DAGC	include/Hal8188FPhyReg.h	862;"	d
-bRxProcessTime_DAGC	include/Hal8192EPhyReg.h	865;"	d
-bRxProcessTime_DAGC	include/Hal8703BPhyReg.h	891;"	d
-bRxProcessTime_DAGC	include/Hal8723BPhyReg.h	889;"	d
-bRxProcessTime_DAGC	include/Hal8723DPhyReg.h	892;"	d
-bRxProcessTime_DAGC	include/rtw_mp_phy_regdef.h	808;"	d
-bRxProcess_Delay	include/Hal8188EPhyReg.h	882;"	d
-bRxProcess_Delay	include/Hal8188FPhyReg.h	890;"	d
-bRxProcess_Delay	include/Hal8192EPhyReg.h	893;"	d
-bRxProcess_Delay	include/Hal8703BPhyReg.h	919;"	d
-bRxProcess_Delay	include/Hal8723BPhyReg.h	917;"	d
-bRxProcess_Delay	include/Hal8723DPhyReg.h	920;"	d
-bRxProcess_Delay	include/rtw_mp_phy_regdef.h	836;"	d
-bRxQDCOffset	include/Hal8188EPhyReg.h	760;"	d
-bRxQDCOffset	include/Hal8188FPhyReg.h	768;"	d
-bRxQDCOffset	include/Hal8192EPhyReg.h	771;"	d
-bRxQDCOffset	include/Hal8703BPhyReg.h	797;"	d
-bRxQDCOffset	include/Hal8723BPhyReg.h	795;"	d
-bRxQDCOffset	include/Hal8723DPhyReg.h	798;"	d
-bRxQDCOffset	include/rtw_mp_phy_regdef.h	714;"	d
-bRxQuickAGCEn	include/Hal8188EPhyReg.h	830;"	d
-bRxQuickAGCEn	include/Hal8188FPhyReg.h	838;"	d
-bRxQuickAGCEn	include/Hal8192EPhyReg.h	841;"	d
-bRxQuickAGCEn	include/Hal8703BPhyReg.h	867;"	d
-bRxQuickAGCEn	include/Hal8723BPhyReg.h	865;"	d
-bRxQuickAGCEn	include/Hal8723DPhyReg.h	868;"	d
-bRxQuickAGCEn	include/rtw_mp_phy_regdef.h	784;"	d
-bRxRSSIDisplay	include/drv_types.h	/^	u8 bRxRSSIDisplay;$/;"	m	struct:_ADAPTER
-bRxRssi_Cmp_En	include/Hal8188EPhyReg.h	829;"	d
-bRxRssi_Cmp_En	include/Hal8188FPhyReg.h	837;"	d
-bRxRssi_Cmp_En	include/Hal8192EPhyReg.h	840;"	d
-bRxRssi_Cmp_En	include/Hal8703BPhyReg.h	866;"	d
-bRxRssi_Cmp_En	include/Hal8723BPhyReg.h	864;"	d
-bRxRssi_Cmp_En	include/Hal8723DPhyReg.h	867;"	d
-bRxRssi_Cmp_En	include/rtw_mp_phy_regdef.h	783;"	d
-bRxSC	include/Hal8188EPhyReg.h	943;"	d
-bRxSC	include/Hal8188FPhyReg.h	951;"	d
-bRxSC	include/Hal8192EPhyReg.h	954;"	d
-bRxSC	include/Hal8703BPhyReg.h	980;"	d
-bRxSC	include/Hal8723BPhyReg.h	978;"	d
-bRxSC	include/Hal8723DPhyReg.h	981;"	d
-bRxSC	include/rtw_mp_phy_regdef.h	897;"	d
-bRxSGI_Guard_L	include/Hal8188EPhyReg.h	885;"	d
-bRxSGI_Guard_L	include/Hal8188FPhyReg.h	893;"	d
-bRxSGI_Guard_L	include/Hal8192EPhyReg.h	896;"	d
-bRxSGI_Guard_L	include/Hal8703BPhyReg.h	922;"	d
-bRxSGI_Guard_L	include/Hal8723BPhyReg.h	920;"	d
-bRxSGI_Guard_L	include/Hal8723DPhyReg.h	923;"	d
-bRxSGI_Guard_L	include/rtw_mp_phy_regdef.h	839;"	d
-bRxSGI_Search_L	include/Hal8188EPhyReg.h	886;"	d
-bRxSGI_Search_L	include/Hal8188FPhyReg.h	894;"	d
-bRxSGI_Search_L	include/Hal8192EPhyReg.h	897;"	d
-bRxSGI_Search_L	include/Hal8703BPhyReg.h	923;"	d
-bRxSGI_Search_L	include/Hal8723BPhyReg.h	921;"	d
-bRxSGI_Search_L	include/Hal8723DPhyReg.h	924;"	d
-bRxSGI_Search_L	include/rtw_mp_phy_regdef.h	840;"	d
-bRxSGI_TH	include/Hal8188EPhyReg.h	887;"	d
-bRxSGI_TH	include/Hal8188FPhyReg.h	895;"	d
-bRxSGI_TH	include/Hal8192EPhyReg.h	898;"	d
-bRxSGI_TH	include/Hal8703BPhyReg.h	924;"	d
-bRxSGI_TH	include/Hal8723BPhyReg.h	922;"	d
-bRxSGI_TH	include/Hal8723DPhyReg.h	925;"	d
-bRxSGI_TH	include/rtw_mp_phy_regdef.h	841;"	d
-bRxSNR_A	include/Hal8188EPhyReg.h	951;"	d
-bRxSNR_A	include/Hal8188FPhyReg.h	959;"	d
-bRxSNR_A	include/Hal8192EPhyReg.h	962;"	d
-bRxSNR_A	include/Hal8703BPhyReg.h	988;"	d
-bRxSNR_A	include/Hal8723BPhyReg.h	986;"	d
-bRxSNR_A	include/Hal8723DPhyReg.h	989;"	d
-bRxSNR_A	include/rtw_mp_phy_regdef.h	905;"	d
-bRxSNR_B	include/Hal8188EPhyReg.h	952;"	d
-bRxSNR_B	include/Hal8188FPhyReg.h	960;"	d
-bRxSNR_B	include/Hal8192EPhyReg.h	963;"	d
-bRxSNR_B	include/Hal8703BPhyReg.h	989;"	d
-bRxSNR_B	include/Hal8723BPhyReg.h	987;"	d
-bRxSNR_B	include/Hal8723DPhyReg.h	990;"	d
-bRxSNR_B	include/rtw_mp_phy_regdef.h	906;"	d
-bRxSNR_C	include/Hal8188EPhyReg.h	953;"	d
-bRxSNR_C	include/Hal8188FPhyReg.h	961;"	d
-bRxSNR_C	include/Hal8192EPhyReg.h	964;"	d
-bRxSNR_C	include/Hal8703BPhyReg.h	990;"	d
-bRxSNR_C	include/Hal8723BPhyReg.h	988;"	d
-bRxSNR_C	include/Hal8723DPhyReg.h	991;"	d
-bRxSNR_C	include/rtw_mp_phy_regdef.h	907;"	d
-bRxSNR_D	include/Hal8188EPhyReg.h	954;"	d
-bRxSNR_D	include/Hal8188FPhyReg.h	962;"	d
-bRxSNR_D	include/Hal8192EPhyReg.h	965;"	d
-bRxSNR_D	include/Hal8703BPhyReg.h	991;"	d
-bRxSNR_D	include/Hal8723BPhyReg.h	989;"	d
-bRxSNR_D	include/Hal8723DPhyReg.h	992;"	d
-bRxSNR_D	include/rtw_mp_phy_regdef.h	908;"	d
-bRxSearchrange_GI2_Early	include/Hal8188EPhyReg.h	883;"	d
-bRxSearchrange_GI2_Early	include/Hal8188FPhyReg.h	891;"	d
-bRxSearchrange_GI2_Early	include/Hal8192EPhyReg.h	894;"	d
-bRxSearchrange_GI2_Early	include/Hal8703BPhyReg.h	920;"	d
-bRxSearchrange_GI2_Early	include/Hal8723BPhyReg.h	918;"	d
-bRxSearchrange_GI2_Early	include/Hal8723DPhyReg.h	921;"	d
-bRxSearchrange_GI2_Early	include/rtw_mp_phy_regdef.h	837;"	d
-bRxSettle_AntSW	include/Hal8188EPhyReg.h	853;"	d
-bRxSettle_AntSW	include/Hal8188FPhyReg.h	861;"	d
-bRxSettle_AntSW	include/Hal8192EPhyReg.h	864;"	d
-bRxSettle_AntSW	include/Hal8703BPhyReg.h	890;"	d
-bRxSettle_AntSW	include/Hal8723BPhyReg.h	888;"	d
-bRxSettle_AntSW	include/Hal8723DPhyReg.h	891;"	d
-bRxSettle_AntSW	include/rtw_mp_phy_regdef.h	807;"	d
-bRxSettle_AntSW_RSSI	include/Hal8188EPhyReg.h	852;"	d
-bRxSettle_AntSW_RSSI	include/Hal8188FPhyReg.h	860;"	d
-bRxSettle_AntSW_RSSI	include/Hal8192EPhyReg.h	863;"	d
-bRxSettle_AntSW_RSSI	include/Hal8703BPhyReg.h	889;"	d
-bRxSettle_AntSW_RSSI	include/Hal8723BPhyReg.h	887;"	d
-bRxSettle_AntSW_RSSI	include/Hal8723DPhyReg.h	890;"	d
-bRxSettle_AntSW_RSSI	include/rtw_mp_phy_regdef.h	806;"	d
-bRxSettle_BBP	include/Hal8188EPhyReg.h	850;"	d
-bRxSettle_BBP	include/Hal8188FPhyReg.h	858;"	d
-bRxSettle_BBP	include/Hal8192EPhyReg.h	861;"	d
-bRxSettle_BBP	include/Hal8703BPhyReg.h	887;"	d
-bRxSettle_BBP	include/Hal8723BPhyReg.h	885;"	d
-bRxSettle_BBP	include/Hal8723DPhyReg.h	888;"	d
-bRxSettle_BBP	include/rtw_mp_phy_regdef.h	804;"	d
-bRxSettle_HSSI	include/Hal8188EPhyReg.h	855;"	d
-bRxSettle_HSSI	include/Hal8188FPhyReg.h	863;"	d
-bRxSettle_HSSI	include/Hal8192EPhyReg.h	866;"	d
-bRxSettle_HSSI	include/Hal8703BPhyReg.h	892;"	d
-bRxSettle_HSSI	include/Hal8723BPhyReg.h	890;"	d
-bRxSettle_HSSI	include/Hal8723DPhyReg.h	893;"	d
-bRxSettle_HSSI	include/rtw_mp_phy_regdef.h	809;"	d
-bRxSettle_LNA	include/Hal8188EPhyReg.h	848;"	d
-bRxSettle_LNA	include/Hal8188FPhyReg.h	856;"	d
-bRxSettle_LNA	include/Hal8192EPhyReg.h	859;"	d
-bRxSettle_LNA	include/Hal8703BPhyReg.h	885;"	d
-bRxSettle_LNA	include/Hal8723BPhyReg.h	883;"	d
-bRxSettle_LNA	include/Hal8723DPhyReg.h	886;"	d
-bRxSettle_LNA	include/rtw_mp_phy_regdef.h	802;"	d
-bRxSettle_RSSI	include/Hal8188EPhyReg.h	849;"	d
-bRxSettle_RSSI	include/Hal8188FPhyReg.h	857;"	d
-bRxSettle_RSSI	include/Hal8192EPhyReg.h	860;"	d
-bRxSettle_RSSI	include/Hal8703BPhyReg.h	886;"	d
-bRxSettle_RSSI	include/Hal8723BPhyReg.h	884;"	d
-bRxSettle_RSSI	include/Hal8723DPhyReg.h	887;"	d
-bRxSettle_RSSI	include/rtw_mp_phy_regdef.h	803;"	d
-bRxSettle_RxHP	include/Hal8188EPhyReg.h	851;"	d
-bRxSettle_RxHP	include/Hal8188FPhyReg.h	859;"	d
-bRxSettle_RxHP	include/Hal8192EPhyReg.h	862;"	d
-bRxSettle_RxHP	include/Hal8703BPhyReg.h	888;"	d
-bRxSettle_RxHP	include/Hal8723BPhyReg.h	886;"	d
-bRxSettle_RxHP	include/Hal8723DPhyReg.h	889;"	d
-bRxSettle_RxHP	include/rtw_mp_phy_regdef.h	805;"	d
-bRxSettle_TRSW	include/Hal8188EPhyReg.h	847;"	d
-bRxSettle_TRSW	include/Hal8188FPhyReg.h	855;"	d
-bRxSettle_TRSW	include/Hal8192EPhyReg.h	858;"	d
-bRxSettle_TRSW	include/Hal8703BPhyReg.h	884;"	d
-bRxSettle_TRSW	include/Hal8723BPhyReg.h	882;"	d
-bRxSettle_TRSW	include/Hal8723DPhyReg.h	885;"	d
-bRxSettle_TRSW	include/rtw_mp_phy_regdef.h	801;"	d
-bRx_HT	include/Hal8188EPhyReg.h	944;"	d
-bRx_HT	include/Hal8188FPhyReg.h	952;"	d
-bRx_HT	include/Hal8192EPhyReg.h	955;"	d
-bRx_HT	include/Hal8703BPhyReg.h	981;"	d
-bRx_HT	include/Hal8723BPhyReg.h	979;"	d
-bRx_HT	include/Hal8723DPhyReg.h	982;"	d
-bRx_HT	include/rtw_mp_phy_regdef.h	898;"	d
-bRx_HT_BW	include/Hal8188EPhyReg.h	942;"	d
-bRx_HT_BW	include/Hal8188FPhyReg.h	950;"	d
-bRx_HT_BW	include/Hal8192EPhyReg.h	953;"	d
-bRx_HT_BW	include/Hal8703BPhyReg.h	979;"	d
-bRx_HT_BW	include/Hal8723BPhyReg.h	977;"	d
-bRx_HT_BW	include/Hal8723DPhyReg.h	980;"	d
-bRx_HT_BW	include/rtw_mp_phy_regdef.h	896;"	d
-bSBD_Option	include/Hal8188EPhyReg.h	782;"	d
-bSBD_Option	include/Hal8188FPhyReg.h	790;"	d
-bSBD_Option	include/Hal8192EPhyReg.h	793;"	d
-bSBD_Option	include/Hal8703BPhyReg.h	819;"	d
-bSBD_Option	include/Hal8723BPhyReg.h	817;"	d
-bSBD_Option	include/Hal8723DPhyReg.h	820;"	d
-bSBD_Option	include/rtw_mp_phy_regdef.h	736;"	d
-bSBD_start_offset	include/Hal8188EPhyReg.h	790;"	d
-bSBD_start_offset	include/Hal8188FPhyReg.h	798;"	d
-bSBD_start_offset	include/Hal8192EPhyReg.h	801;"	d
-bSBD_start_offset	include/Hal8703BPhyReg.h	827;"	d
-bSBD_start_offset	include/Hal8723BPhyReg.h	825;"	d
-bSBD_start_offset	include/Hal8723DPhyReg.h	828;"	d
-bSBD_start_offset	include/rtw_mp_phy_regdef.h	744;"	d
-bSCOBusy	core/rtw_cmd.c	/^	u8 bSCOBusy:1;$/;"	m	struct:btinfo	file:
-bSCOBusy	include/rtw_btcoex.h	/^	u8 bSCOBusy:1;$/;"	m	struct:btinfo_8761ATV
-bSCOeSCO	core/rtw_cmd.c	/^	u8 bSCOeSCO:1;$/;"	m	struct:btinfo	file:
-bSCOeSCO	include/rtw_btcoex.h	/^	u8 bSCOeSCO:1;$/;"	m	struct:btinfo_8761ATV
-bSFactorQAM1	include/Hal8188EPhyReg.h	965;"	d
-bSFactorQAM1	include/Hal8188FPhyReg.h	973;"	d
-bSFactorQAM1	include/Hal8192EPhyReg.h	976;"	d
-bSFactorQAM1	include/Hal8703BPhyReg.h	1002;"	d
-bSFactorQAM1	include/Hal8723BPhyReg.h	1000;"	d
-bSFactorQAM1	include/Hal8723DPhyReg.h	1003;"	d
-bSFactorQAM1	include/rtw_mp_phy_regdef.h	919;"	d
-bSFactorQAM2	include/Hal8188EPhyReg.h	966;"	d
-bSFactorQAM2	include/Hal8188FPhyReg.h	974;"	d
-bSFactorQAM2	include/Hal8192EPhyReg.h	977;"	d
-bSFactorQAM2	include/Hal8703BPhyReg.h	1003;"	d
-bSFactorQAM2	include/Hal8723BPhyReg.h	1001;"	d
-bSFactorQAM2	include/Hal8723DPhyReg.h	1004;"	d
-bSFactorQAM2	include/rtw_mp_phy_regdef.h	920;"	d
-bSFactorQAM3	include/Hal8188EPhyReg.h	967;"	d
-bSFactorQAM3	include/Hal8188FPhyReg.h	975;"	d
-bSFactorQAM3	include/Hal8192EPhyReg.h	978;"	d
-bSFactorQAM3	include/Hal8703BPhyReg.h	1004;"	d
-bSFactorQAM3	include/Hal8723BPhyReg.h	1002;"	d
-bSFactorQAM3	include/Hal8723DPhyReg.h	1005;"	d
-bSFactorQAM3	include/rtw_mp_phy_regdef.h	921;"	d
-bSFactorQAM4	include/Hal8188EPhyReg.h	968;"	d
-bSFactorQAM4	include/Hal8188FPhyReg.h	976;"	d
-bSFactorQAM4	include/Hal8192EPhyReg.h	979;"	d
-bSFactorQAM4	include/Hal8703BPhyReg.h	1005;"	d
-bSFactorQAM4	include/Hal8723BPhyReg.h	1003;"	d
-bSFactorQAM4	include/Hal8723DPhyReg.h	1006;"	d
-bSFactorQAM4	include/rtw_mp_phy_regdef.h	922;"	d
-bSFactorQAM5	include/Hal8188EPhyReg.h	969;"	d
-bSFactorQAM5	include/Hal8188FPhyReg.h	977;"	d
-bSFactorQAM5	include/Hal8192EPhyReg.h	980;"	d
-bSFactorQAM5	include/Hal8703BPhyReg.h	1006;"	d
-bSFactorQAM5	include/Hal8723BPhyReg.h	1004;"	d
-bSFactorQAM5	include/Hal8723DPhyReg.h	1007;"	d
-bSFactorQAM5	include/rtw_mp_phy_regdef.h	923;"	d
-bSFactorQAM6	include/Hal8188EPhyReg.h	970;"	d
-bSFactorQAM6	include/Hal8188FPhyReg.h	978;"	d
-bSFactorQAM6	include/Hal8192EPhyReg.h	981;"	d
-bSFactorQAM6	include/Hal8703BPhyReg.h	1007;"	d
-bSFactorQAM6	include/Hal8723BPhyReg.h	1005;"	d
-bSFactorQAM6	include/Hal8723DPhyReg.h	1008;"	d
-bSFactorQAM6	include/rtw_mp_phy_regdef.h	924;"	d
-bSFactorQAM7	include/Hal8188EPhyReg.h	971;"	d
-bSFactorQAM7	include/Hal8188FPhyReg.h	979;"	d
-bSFactorQAM7	include/Hal8192EPhyReg.h	982;"	d
-bSFactorQAM7	include/Hal8703BPhyReg.h	1008;"	d
-bSFactorQAM7	include/Hal8723BPhyReg.h	1006;"	d
-bSFactorQAM7	include/Hal8723DPhyReg.h	1009;"	d
-bSFactorQAM7	include/rtw_mp_phy_regdef.h	925;"	d
-bSFactorQAM8	include/Hal8188EPhyReg.h	972;"	d
-bSFactorQAM8	include/Hal8188FPhyReg.h	980;"	d
-bSFactorQAM8	include/Hal8192EPhyReg.h	983;"	d
-bSFactorQAM8	include/Hal8703BPhyReg.h	1009;"	d
-bSFactorQAM8	include/Hal8723BPhyReg.h	1007;"	d
-bSFactorQAM8	include/Hal8723DPhyReg.h	1010;"	d
-bSFactorQAM8	include/rtw_mp_phy_regdef.h	926;"	d
-bSFactorQAM9	include/Hal8188EPhyReg.h	973;"	d
-bSFactorQAM9	include/Hal8188FPhyReg.h	981;"	d
-bSFactorQAM9	include/Hal8192EPhyReg.h	984;"	d
-bSFactorQAM9	include/Hal8703BPhyReg.h	1010;"	d
-bSFactorQAM9	include/Hal8723BPhyReg.h	1008;"	d
-bSFactorQAM9	include/Hal8723DPhyReg.h	1011;"	d
-bSFactorQAM9	include/rtw_mp_phy_regdef.h	927;"	d
-bSGI	include/rtw_mp.h	/^	u8			bSGI:1;$/;"	m	struct:_RT_PMAC_TX_INFO
-bSGIEN	include/Hal8188EPhyReg.h	963;"	d
-bSGIEN	include/Hal8188FPhyReg.h	971;"	d
-bSGIEN	include/Hal8192EPhyReg.h	974;"	d
-bSGIEN	include/Hal8703BPhyReg.h	1000;"	d
-bSGIEN	include/Hal8723BPhyReg.h	998;"	d
-bSGIEN	include/Hal8723DPhyReg.h	1001;"	d
-bSGIEN	include/rtw_mp_phy_regdef.h	917;"	d
-bSIGEVM	include/Hal8188EPhyReg.h	961;"	d
-bSIGEVM	include/Hal8188FPhyReg.h	969;"	d
-bSIGEVM	include/Hal8192EPhyReg.h	972;"	d
-bSIGEVM	include/Hal8703BPhyReg.h	998;"	d
-bSIGEVM	include/Hal8723BPhyReg.h	996;"	d
-bSIGEVM	include/Hal8723DPhyReg.h	999;"	d
-bSIGEVM	include/rtw_mp_phy_regdef.h	915;"	d
-bSNREVMFLength	include/Hal8188EPhyReg.h	956;"	d
-bSNREVMFLength	include/Hal8188FPhyReg.h	964;"	d
-bSNREVMFLength	include/Hal8192EPhyReg.h	967;"	d
-bSNREVMFLength	include/Hal8703BPhyReg.h	993;"	d
-bSNREVMFLength	include/Hal8723BPhyReg.h	991;"	d
-bSNREVMFLength	include/Hal8723DPhyReg.h	994;"	d
-bSNREVMFLength	include/rtw_mp_phy_regdef.h	910;"	d
-bSNREVMTLength	include/Hal8188EPhyReg.h	955;"	d
-bSNREVMTLength	include/Hal8188FPhyReg.h	963;"	d
-bSNREVMTLength	include/Hal8192EPhyReg.h	966;"	d
-bSNREVMTLength	include/Hal8703BPhyReg.h	992;"	d
-bSNREVMTLength	include/Hal8723BPhyReg.h	990;"	d
-bSNREVMTLength	include/Hal8723DPhyReg.h	993;"	d
-bSNREVMTLength	include/rtw_mp_phy_regdef.h	909;"	d
-bSPreamble	include/rtw_mp.h	/^	u8			bSPreamble:1;$/;"	m	struct:_RT_PMAC_TX_INFO
-bSTBC	include/rtw_mp.h	/^	u8			bSTBC:1;$/;"	m	struct:_RT_PMAC_TX_INFO
-bSTBCEn	include/Hal8188EPhyReg.h	902;"	d
-bSTBCEn	include/Hal8188FPhyReg.h	910;"	d
-bSTBCEn	include/Hal8192EPhyReg.h	913;"	d
-bSTBCEn	include/Hal8703BPhyReg.h	939;"	d
-bSTBCEn	include/Hal8723BPhyReg.h	937;"	d
-bSTBCEn	include/Hal8723DPhyReg.h	940;"	d
-bSTBCEn	include/Hal8812PhyReg.h	693;"	d
-bSTBCEn	include/Hal8814PhyReg.h	818;"	d
-bSTBCEn	include/rtw_mp_phy_regdef.h	856;"	d
-bSWAntDivByCtrlFrame	hal/phydm/phydm_antdiv.h	/^	BOOLEAN		bSWAntDivByCtrlFrame;$/;"	m	struct:_SW_Antenna_Switch_
-bSWLedCtrl	include/hal_com_led.h	/^	BOOLEAN				bSWLedCtrl;$/;"	m	struct:_LED_SDIO
-bSWLedCtrl	include/hal_com_led.h	/^	BOOLEAN				bSWLedCtrl;$/;"	m	struct:_LED_USB
-bSWToBW40M	include/hal_data.h	/^	BOOLEAN			bSWToBW40M;$/;"	m	struct:hal_com_data
-bSWToBW80M	include/hal_data.h	/^	BOOLEAN			bSWToBW80M;$/;"	m	struct:hal_com_data
-bSarch_GI2_Late	include/Hal8188EPhyReg.h	796;"	d
-bSarch_GI2_Late	include/Hal8188FPhyReg.h	804;"	d
-bSarch_GI2_Late	include/Hal8192EPhyReg.h	807;"	d
-bSarch_GI2_Late	include/Hal8703BPhyReg.h	833;"	d
-bSarch_GI2_Late	include/Hal8723BPhyReg.h	831;"	d
-bSarch_GI2_Late	include/Hal8723DPhyReg.h	834;"	d
-bSarch_GI2_Late	include/rtw_mp_phy_regdef.h	750;"	d
-bSarch_Short_Early	include/Hal8188EPhyReg.h	794;"	d
-bSarch_Short_Early	include/Hal8188FPhyReg.h	802;"	d
-bSarch_Short_Early	include/Hal8192EPhyReg.h	805;"	d
-bSarch_Short_Early	include/Hal8703BPhyReg.h	831;"	d
-bSarch_Short_Early	include/Hal8723BPhyReg.h	829;"	d
-bSarch_Short_Early	include/Hal8723DPhyReg.h	832;"	d
-bSarch_Short_Early	include/rtw_mp_phy_regdef.h	748;"	d
-bSarch_Short_Late	include/Hal8188EPhyReg.h	795;"	d
-bSarch_Short_Late	include/Hal8188FPhyReg.h	803;"	d
-bSarch_Short_Late	include/Hal8192EPhyReg.h	806;"	d
-bSarch_Short_Late	include/Hal8703BPhyReg.h	832;"	d
-bSarch_Short_Late	include/Hal8723BPhyReg.h	830;"	d
-bSarch_Short_Late	include/Hal8723DPhyReg.h	833;"	d
-bSarch_Short_Late	include/rtw_mp_phy_regdef.h	749;"	d
-bScanInProcess	include/rtw_mlme.h	/^	u8 bScanInProcess;$/;"	m	struct:mlme_priv
-bSet	include/rtw_wapi.h	/^	bool			bSet;$/;"	m	struct:_RT_WAPI_KEY
-bSetChnlBW	include/hal_data.h	/^	BOOLEAN			bSetChnlBW;$/;"	m	struct:hal_com_data
-bSetPOFFParm	include/rtw_pwrctrl.h	/^	ATOMIC_T bSetPOFFParm;$/;"	m	struct:lps_poff_info
-bSetRxBssid	include/rtw_mp.h	/^	BOOLEAN bSetRxBssid;$/;"	m	struct:mp_priv
-bSetTxPower	include/rtw_mp.h	/^	u8 bSetTxPower;$/;"	m	struct:mp_priv
-bSetkeyOk	include/rtw_wapi.h	/^	bool					bSetkeyOk;$/;"	m	struct:_RT_WAPI_STA_INFO
-bShift_L	include/Hal8188EPhyReg.h	745;"	d
-bShift_L	include/Hal8188FPhyReg.h	753;"	d
-bShift_L	include/Hal8192EPhyReg.h	756;"	d
-bShift_L	include/Hal8703BPhyReg.h	782;"	d
-bShift_L	include/Hal8723BPhyReg.h	780;"	d
-bShift_L	include/Hal8723DPhyReg.h	783;"	d
-bShift_L	include/rtw_mp_phy_regdef.h	699;"	d
-bShortCFO	include/Hal8188EPhyReg.h	928;"	d
-bShortCFO	include/Hal8188FPhyReg.h	936;"	d
-bShortCFO	include/Hal8192EPhyReg.h	939;"	d
-bShortCFO	include/Hal8703BPhyReg.h	965;"	d
-bShortCFO	include/Hal8723BPhyReg.h	963;"	d
-bShortCFO	include/Hal8723DPhyReg.h	966;"	d
-bShortCFO	include/rtw_mp_phy_regdef.h	882;"	d
-bShortCFOFLength	include/Hal8188EPhyReg.h	930;"	d
-bShortCFOFLength	include/Hal8188FPhyReg.h	938;"	d
-bShortCFOFLength	include/Hal8192EPhyReg.h	941;"	d
-bShortCFOFLength	include/Hal8703BPhyReg.h	967;"	d
-bShortCFOFLength	include/Hal8723BPhyReg.h	965;"	d
-bShortCFOFLength	include/Hal8723DPhyReg.h	968;"	d
-bShortCFOFLength	include/rtw_mp_phy_regdef.h	884;"	d
-bShortCFOTLength	include/Hal8188EPhyReg.h	929;"	d
-bShortCFOTLength	include/Hal8188FPhyReg.h	937;"	d
-bShortCFOTLength	include/Hal8192EPhyReg.h	940;"	d
-bShortCFOTLength	include/Hal8703BPhyReg.h	966;"	d
-bShortCFOTLength	include/Hal8723BPhyReg.h	964;"	d
-bShortCFOTLength	include/Hal8723DPhyReg.h	967;"	d
-bShortCFOTLength	include/rtw_mp_phy_regdef.h	883;"	d
-bShowGetP2PState	include/drv_types.h	/^	u8 bShowGetP2PState;$/;"	m	struct:_ADAPTER
-bSigTone_Im	include/Hal8188EPhyReg.h	921;"	d
-bSigTone_Im	include/Hal8188FPhyReg.h	929;"	d
-bSigTone_Im	include/Hal8192EPhyReg.h	932;"	d
-bSigTone_Im	include/Hal8703BPhyReg.h	958;"	d
-bSigTone_Im	include/Hal8723BPhyReg.h	956;"	d
-bSigTone_Im	include/Hal8723DPhyReg.h	959;"	d
-bSigTone_Im	include/rtw_mp_phy_regdef.h	875;"	d
-bSigTone_Re	include/Hal8188EPhyReg.h	920;"	d
-bSigTone_Re	include/Hal8188FPhyReg.h	928;"	d
-bSigTone_Re	include/Hal8192EPhyReg.h	931;"	d
-bSigTone_Re	include/Hal8703BPhyReg.h	957;"	d
-bSigTone_Re	include/Hal8723BPhyReg.h	955;"	d
-bSigTone_Re	include/Hal8723DPhyReg.h	958;"	d
-bSigTone_Re	include/rtw_mp_phy_regdef.h	874;"	d
-bSingleCarrier	include/rtw_mp.h	/^	BOOLEAN			bSingleCarrier;$/;"	m	struct:_MPT_CONTEXT
-bSingleTone	include/rtw_mp.h	/^	BOOLEAN			bSingleTone;$/;"	m	struct:_MPT_CONTEXT
-bSound	hal/phydm/phydm_beamforming.h	/^	BOOLEAN bSound;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-bSound	include/rtw_beamforming.h	/^	BOOLEAN	bSound;$/;"	m	struct:beamforming_entry
-bSoundingTimeout	include/rtw_beamforming.h	/^	u8 bSoundingTimeout;$/;"	m	struct:beamformee_entry
-bStart	include/rtw_cmd.h	/^	u8 bStart;$/;"	m	struct:SetCarrierSuppressionTx_parm
-bStart	include/rtw_cmd.h	/^	u8 bStart;$/;"	m	struct:SetContinuousTx_parm
-bStart	include/rtw_cmd.h	/^	u8 bStart;$/;"	m	struct:SetSingleCarrierTx_parm
-bStart	include/rtw_cmd.h	/^	u8 bStart;$/;"	m	struct:SetSingleToneTx_parm
-bStartContTx	include/rtw_mp.h	/^	BOOLEAN			bStartContTx;	\/* TRUE if we have start Continuous Tx test. *\/$/;"	m	struct:_MPT_CONTEXT
-bStartSendSupervisionPkt	include/rtw_btcoex.h	/^	BOOLEAN				bStartSendSupervisionPkt;$/;"	m	struct:_BT_MGNT
-bStbcPkt	hal/phydm/phydm.h	/^	BOOLEAN		bStbcPkt;$/;"	m	struct:_ODM_Phy_Dbg_Info_
-bStopDIG	hal/phydm/phydm_dig.h	/^	BOOLEAN		bStopDIG;		\/\/ for debug$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bStopEDCCA	hal/phydm/phydm_adaptivity.h	/^	BOOLEAN			bStopEDCCA;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-bSub_Tune	include/Hal8188EPhyReg.h	788;"	d
-bSub_Tune	include/Hal8188FPhyReg.h	796;"	d
-bSub_Tune	include/Hal8192EPhyReg.h	799;"	d
-bSub_Tune	include/Hal8703BPhyReg.h	825;"	d
-bSub_Tune	include/Hal8723BPhyReg.h	823;"	d
-bSub_Tune	include/Hal8723DPhyReg.h	826;"	d
-bSub_Tune	include/rtw_mp_phy_regdef.h	742;"	d
-bSupportBackDoor	include/hal_data.h	/^	BOOLEAN	bSupportBackDoor;$/;"	m	struct:hal_com_data
-bSupportProfile	include/rtw_btcoex.h	/^	BOOLEAN				bSupportProfile;$/;"	m	struct:_BT_MGNT
-bSupportRemoteWakeup	include/rtw_pwrctrl.h	/^	u8		bSupportRemoteWakeup;$/;"	m	struct:pwrctrl_priv
-bSupportUSB3	include/hal_data.h	/^	BOOLEAN		bSupportUSB3;$/;"	m	struct:hal_com_data
-bSurpriseRemoved	include/drv_types.h	/^	ATOMIC_T	bSurpriseRemoved;$/;"	m	struct:dvobj_priv
-bSwChnl	include/hal_data.h	/^	BOOLEAN			bSwChnl;$/;"	m	struct:hal_com_data
-bSwChnlAndSetBWInProgress	include/hal_data.h	/^	BOOLEAN		bSwChnlAndSetBWInProgress;$/;"	m	struct:hal_com_data
-bTHEVMCfg	include/Hal8188EPhyReg.h	983;"	d
-bTHEVMCfg	include/Hal8188FPhyReg.h	991;"	d
-bTHEVMCfg	include/Hal8192EPhyReg.h	994;"	d
-bTHEVMCfg	include/Hal8703BPhyReg.h	1020;"	d
-bTHEVMCfg	include/Hal8723BPhyReg.h	1018;"	d
-bTHEVMCfg	include/Hal8723DPhyReg.h	1021;"	d
-bTHEVMCfg	include/rtw_mp_phy_regdef.h	937;"	d
-bTREnd	include/Hal8188EPhyReg.h	526;"	d
-bTREnd	include/Hal8188FPhyReg.h	534;"	d
-bTREnd	include/Hal8192EPhyReg.h	537;"	d
-bTREnd	include/Hal8703BPhyReg.h	563;"	d
-bTREnd	include/Hal8723BPhyReg.h	561;"	d
-bTREnd	include/Hal8723DPhyReg.h	564;"	d
-bTREnd	include/rtw_mp_phy_regdef.h	476;"	d
-bTRSSIFreq	include/Hal8188EPhyReg.h	755;"	d
-bTRSSIFreq	include/Hal8188FPhyReg.h	763;"	d
-bTRSSIFreq	include/Hal8192EPhyReg.h	766;"	d
-bTRSSIFreq	include/Hal8703BPhyReg.h	792;"	d
-bTRSSIFreq	include/Hal8723BPhyReg.h	790;"	d
-bTRSSIFreq	include/Hal8723DPhyReg.h	793;"	d
-bTRSSIFreq	include/rtw_mp_phy_regdef.h	709;"	d
-bTRSSILatchPhase	include/Hal8188EPhyReg.h	758;"	d
-bTRSSILatchPhase	include/Hal8188FPhyReg.h	766;"	d
-bTRSSILatchPhase	include/Hal8192EPhyReg.h	769;"	d
-bTRSSILatchPhase	include/Hal8703BPhyReg.h	795;"	d
-bTRSSILatchPhase	include/Hal8723BPhyReg.h	793;"	d
-bTRSSILatchPhase	include/Hal8723DPhyReg.h	796;"	d
-bTRSSILatchPhase	include/rtw_mp_phy_regdef.h	712;"	d
-bTRSW	include/Hal8188EPhyReg.h	950;"	d
-bTRSW	include/Hal8188FPhyReg.h	958;"	d
-bTRSW	include/Hal8192EPhyReg.h	961;"	d
-bTRSW	include/Hal8703BPhyReg.h	987;"	d
-bTRSW	include/Hal8723BPhyReg.h	985;"	d
-bTRSW	include/Hal8723DPhyReg.h	988;"	d
-bTRSW	include/rtw_mp_phy_regdef.h	904;"	d
-bTRSWIsolation_A	include/Hal8188EPhyReg.h	895;"	d
-bTRSWIsolation_A	include/Hal8188FPhyReg.h	903;"	d
-bTRSWIsolation_A	include/Hal8192EPhyReg.h	906;"	d
-bTRSWIsolation_A	include/Hal8703BPhyReg.h	932;"	d
-bTRSWIsolation_A	include/Hal8723BPhyReg.h	930;"	d
-bTRSWIsolation_A	include/Hal8723DPhyReg.h	933;"	d
-bTRSWIsolation_A	include/rtw_mp_phy_regdef.h	849;"	d
-bTRSWIsolation_B	include/Hal8188EPhyReg.h	896;"	d
-bTRSWIsolation_B	include/Hal8188FPhyReg.h	904;"	d
-bTRSWIsolation_B	include/Hal8192EPhyReg.h	907;"	d
-bTRSWIsolation_B	include/Hal8703BPhyReg.h	933;"	d
-bTRSWIsolation_B	include/Hal8723BPhyReg.h	931;"	d
-bTRSWIsolation_B	include/Hal8723DPhyReg.h	934;"	d
-bTRSWIsolation_B	include/rtw_mp_phy_regdef.h	850;"	d
-bTRSWIsolation_C	include/Hal8188EPhyReg.h	897;"	d
-bTRSWIsolation_C	include/Hal8188FPhyReg.h	905;"	d
-bTRSWIsolation_C	include/Hal8192EPhyReg.h	908;"	d
-bTRSWIsolation_C	include/Hal8703BPhyReg.h	934;"	d
-bTRSWIsolation_C	include/Hal8723BPhyReg.h	932;"	d
-bTRSWIsolation_C	include/Hal8723DPhyReg.h	935;"	d
-bTRSWIsolation_C	include/rtw_mp_phy_regdef.h	851;"	d
-bTRSWIsolation_D	include/Hal8188EPhyReg.h	898;"	d
-bTRSWIsolation_D	include/Hal8188FPhyReg.h	906;"	d
-bTRSWIsolation_D	include/Hal8192EPhyReg.h	909;"	d
-bTRSWIsolation_D	include/Hal8703BPhyReg.h	935;"	d
-bTRSWIsolation_D	include/Hal8723BPhyReg.h	933;"	d
-bTRSWIsolation_D	include/Hal8723DPhyReg.h	936;"	d
-bTRSWIsolation_D	include/rtw_mp_phy_regdef.h	852;"	d
-bTRSW_Tri_Only	include/Hal8188EPhyReg.h	834;"	d
-bTRSW_Tri_Only	include/Hal8188FPhyReg.h	842;"	d
-bTRSW_Tri_Only	include/Hal8192EPhyReg.h	845;"	d
-bTRSW_Tri_Only	include/Hal8703BPhyReg.h	871;"	d
-bTRSW_Tri_Only	include/Hal8723BPhyReg.h	869;"	d
-bTRSW_Tri_Only	include/Hal8723DPhyReg.h	872;"	d
-bTRSW_Tri_Only	include/rtw_mp_phy_regdef.h	788;"	d
-bTRStart	include/Hal8188EPhyReg.h	521;"	d
-bTRStart	include/Hal8188FPhyReg.h	529;"	d
-bTRStart	include/Hal8192EPhyReg.h	532;"	d
-bTRStart	include/Hal8703BPhyReg.h	558;"	d
-bTRStart	include/Hal8723BPhyReg.h	556;"	d
-bTRStart	include/Hal8723DPhyReg.h	559;"	d
-bTRStart	include/rtw_mp_phy_regdef.h	471;"	d
-bTXIQImb_A	include/Hal8188EPhyReg.h	803;"	d
-bTXIQImb_A	include/Hal8188FPhyReg.h	811;"	d
-bTXIQImb_A	include/Hal8192EPhyReg.h	814;"	d
-bTXIQImb_A	include/Hal8703BPhyReg.h	840;"	d
-bTXIQImb_A	include/Hal8723BPhyReg.h	838;"	d
-bTXIQImb_A	include/Hal8723DPhyReg.h	841;"	d
-bTXIQImb_A	include/rtw_mp_phy_regdef.h	757;"	d
-bTXIQImb_B	include/Hal8188EPhyReg.h	804;"	d
-bTXIQImb_B	include/Hal8188FPhyReg.h	812;"	d
-bTXIQImb_B	include/Hal8192EPhyReg.h	815;"	d
-bTXIQImb_B	include/Hal8703BPhyReg.h	841;"	d
-bTXIQImb_B	include/Hal8723BPhyReg.h	839;"	d
-bTXIQImb_B	include/Hal8723DPhyReg.h	842;"	d
-bTXIQImb_B	include/rtw_mp_phy_regdef.h	758;"	d
-bTXIQImb_C	include/Hal8188EPhyReg.h	805;"	d
-bTXIQImb_C	include/Hal8188FPhyReg.h	813;"	d
-bTXIQImb_C	include/Hal8192EPhyReg.h	816;"	d
-bTXIQImb_C	include/Hal8703BPhyReg.h	842;"	d
-bTXIQImb_C	include/Hal8723BPhyReg.h	840;"	d
-bTXIQImb_C	include/Hal8723DPhyReg.h	843;"	d
-bTXIQImb_C	include/rtw_mp_phy_regdef.h	759;"	d
-bTXIQImb_D	include/Hal8188EPhyReg.h	806;"	d
-bTXIQImb_D	include/Hal8188FPhyReg.h	814;"	d
-bTXIQImb_D	include/Hal8192EPhyReg.h	817;"	d
-bTXIQImb_D	include/Hal8703BPhyReg.h	843;"	d
-bTXIQImb_D	include/Hal8723BPhyReg.h	841;"	d
-bTXIQImb_D	include/Hal8723DPhyReg.h	844;"	d
-bTXIQImb_D	include/rtw_mp_phy_regdef.h	760;"	d
-bTXPowerTracking	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN bTXPowerTracking;$/;"	m	struct:ODM_RF_Calibration_Structure
-bTXPowerTracking	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN bTXPowerTracking;$/;"	m	struct:ODM_RF_Calibration_Structure
-bTXPowerTracking	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN bTXPowerTracking;$/;"	m	struct:ODM_RF_Calibration_Structure
-bTXPowerTrackingInit	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN bTXPowerTrackingInit; $/;"	m	struct:ODM_RF_Calibration_Structure
-bTXPowerTrackingInit	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN bTXPowerTrackingInit; $/;"	m	struct:ODM_RF_Calibration_Structure
-bTXPowerTrackingInit	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN bTXPowerTrackingInit; $/;"	m	struct:ODM_RF_Calibration_Structure
-bTableSel	include/Hal8188EPhyReg.h	949;"	d
-bTableSel	include/Hal8188FPhyReg.h	957;"	d
-bTableSel	include/Hal8192EPhyReg.h	960;"	d
-bTableSel	include/Hal8703BPhyReg.h	986;"	d
-bTableSel	include/Hal8723BPhyReg.h	984;"	d
-bTableSel	include/Hal8723DPhyReg.h	987;"	d
-bTableSel	include/rtw_mp_phy_regdef.h	903;"	d
-bTailCFO	include/Hal8188EPhyReg.h	934;"	d
-bTailCFO	include/Hal8188FPhyReg.h	942;"	d
-bTailCFO	include/Hal8192EPhyReg.h	945;"	d
-bTailCFO	include/Hal8703BPhyReg.h	971;"	d
-bTailCFO	include/Hal8723BPhyReg.h	969;"	d
-bTailCFO	include/Hal8723DPhyReg.h	972;"	d
-bTailCFO	include/rtw_mp_phy_regdef.h	888;"	d
-bTailCFOFLength	include/Hal8188EPhyReg.h	936;"	d
-bTailCFOFLength	include/Hal8188FPhyReg.h	944;"	d
-bTailCFOFLength	include/Hal8192EPhyReg.h	947;"	d
-bTailCFOFLength	include/Hal8703BPhyReg.h	973;"	d
-bTailCFOFLength	include/Hal8723BPhyReg.h	971;"	d
-bTailCFOFLength	include/Hal8723DPhyReg.h	974;"	d
-bTailCFOFLength	include/rtw_mp_phy_regdef.h	890;"	d
-bTailCFOTLength	include/Hal8188EPhyReg.h	935;"	d
-bTailCFOTLength	include/Hal8188FPhyReg.h	943;"	d
-bTailCFOTLength	include/Hal8192EPhyReg.h	946;"	d
-bTailCFOTLength	include/Hal8703BPhyReg.h	972;"	d
-bTailCFOTLength	include/Hal8723BPhyReg.h	970;"	d
-bTailCFOTLength	include/Hal8723DPhyReg.h	973;"	d
-bTailCFOTLength	include/rtw_mp_phy_regdef.h	889;"	d
-bToSelf	hal/phydm/phydm.h	/^	BOOLEAN		bToSelf;$/;"	m	struct:_ODM_Per_Pkt_Info_
-bTpTarget	hal/phydm/phydm_dig.h	/^	BOOLEAN					bTpTarget;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bTrackingMode	include/Hal8188EPhyReg.h	992;"	d
-bTrackingMode	include/Hal8188FPhyReg.h	1000;"	d
-bTrackingMode	include/Hal8192EPhyReg.h	1003;"	d
-bTrackingMode	include/Hal8703BPhyReg.h	1029;"	d
-bTrackingMode	include/Hal8723BPhyReg.h	1027;"	d
-bTrackingMode	include/Hal8723DPhyReg.h	1030;"	d
-bTrackingMode	include/rtw_mp_phy_regdef.h	946;"	d
-bTxAGCRate18_06	include/rtw_mp_phy_regdef.h	955;"	d
-bTxAGCRate54_24	include/rtw_mp_phy_regdef.h	956;"	d
-bTxAGCRateCCK	include/rtw_mp_phy_regdef.h	958;"	d
-bTxAGCRateMCS11_MCS8	include/rtw_mp_phy_regdef.h	961;"	d
-bTxAGCRateMCS15_MCS12	include/rtw_mp_phy_regdef.h	962;"	d
-bTxAGCRateMCS32	include/rtw_mp_phy_regdef.h	957;"	d
-bTxAGCRateMCS3_MCS0	include/rtw_mp_phy_regdef.h	959;"	d
-bTxAGCRateMCS7_MCS4	include/rtw_mp_phy_regdef.h	960;"	d
-bTxAGC_byte0_Jaguar	hal/phydm/phydm_reg.h	204;"	d
-bTxAGC_byte0_Jaguar	include/Hal8812PhyReg.h	200;"	d
-bTxAGC_byte0_Jaguar	include/Hal8814PhyReg.h	240;"	d
-bTxAGC_byte1_Jaguar	hal/phydm/phydm_reg.h	205;"	d
-bTxAGC_byte1_Jaguar	include/Hal8812PhyReg.h	201;"	d
-bTxAGC_byte1_Jaguar	include/Hal8814PhyReg.h	241;"	d
-bTxAGC_byte2_Jaguar	hal/phydm/phydm_reg.h	206;"	d
-bTxAGC_byte2_Jaguar	include/Hal8812PhyReg.h	202;"	d
-bTxAGC_byte2_Jaguar	include/Hal8814PhyReg.h	242;"	d
-bTxAGC_byte3_Jaguar	hal/phydm/phydm_reg.h	207;"	d
-bTxAGC_byte3_Jaguar	include/Hal8812PhyReg.h	203;"	d
-bTxAGC_byte3_Jaguar	include/Hal8814PhyReg.h	243;"	d
-bTxBF	hal/phydm/phydm_beamforming.h	/^	BOOLEAN	bTxBF;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-bTxBoundInProgress	include/rtw_pwrctrl.h	/^	ATOMIC_T bTxBoundInProgress;$/;"	m	struct:lps_poff_info
-bTxBufCkFail	include/rtw_mp.h	/^	BOOLEAN bTxBufCkFail;$/;"	m	struct:mp_priv
-bTxBusyTraffic	include/rtw_mlme.h	/^	BOOLEAN			bTxBusyTraffic;$/;"	m	struct:_RT_LINK_DETECT_T
-bTxChEmuEnable	include/Hal8188EPhyReg.h	894;"	d
-bTxChEmuEnable	include/Hal8188FPhyReg.h	902;"	d
-bTxChEmuEnable	include/Hal8192EPhyReg.h	905;"	d
-bTxChEmuEnable	include/Hal8703BPhyReg.h	931;"	d
-bTxChEmuEnable	include/Hal8723BPhyReg.h	929;"	d
-bTxChEmuEnable	include/Hal8723DPhyReg.h	932;"	d
-bTxChEmuEnable	include/rtw_mp_phy_regdef.h	848;"	d
-bTxDFIRMode	include/Hal8188EPhyReg.h	809;"	d
-bTxDFIRMode	include/Hal8188FPhyReg.h	817;"	d
-bTxDFIRMode	include/Hal8192EPhyReg.h	820;"	d
-bTxDFIRMode	include/Hal8703BPhyReg.h	846;"	d
-bTxDFIRMode	include/Hal8723BPhyReg.h	844;"	d
-bTxDFIRMode	include/Hal8723DPhyReg.h	847;"	d
-bTxDFIRMode	include/rtw_mp_phy_regdef.h	763;"	d
-bTxDataInit	include/Hal8188EPhyReg.h	487;"	d
-bTxDataInit	include/Hal8188FPhyReg.h	495;"	d
-bTxDataInit	include/Hal8192EPhyReg.h	496;"	d
-bTxDataInit	include/Hal8703BPhyReg.h	523;"	d
-bTxDataInit	include/Hal8723BPhyReg.h	522;"	d
-bTxDataInit	include/Hal8723DPhyReg.h	524;"	d
-bTxDataInit	include/Hal8812PhyReg.h	354;"	d
-bTxDataInit	include/Hal8814PhyReg.h	461;"	d
-bTxDataInit	include/rtw_mp_phy_regdef.h	439;"	d
-bTxDataType	include/Hal8188EPhyReg.h	489;"	d
-bTxDataType	include/Hal8188FPhyReg.h	497;"	d
-bTxDataType	include/Hal8192EPhyReg.h	498;"	d
-bTxDataType	include/Hal8703BPhyReg.h	525;"	d
-bTxDataType	include/Hal8723BPhyReg.h	524;"	d
-bTxDataType	include/Hal8723DPhyReg.h	526;"	d
-bTxDataType	include/Hal8812PhyReg.h	356;"	d
-bTxDataType	include/Hal8814PhyReg.h	463;"	d
-bTxDataType	include/rtw_mp_phy_regdef.h	441;"	d
-bTxEnable	include/rtw_wapi.h	/^	bool             bTxEnable;$/;"	m	struct:_RT_WAPI_KEY
-bTxHTAdvanceCoding	include/Hal8188EPhyReg.h	477;"	d
-bTxHTAdvanceCoding	include/Hal8188FPhyReg.h	485;"	d
-bTxHTAdvanceCoding	include/Hal8192EPhyReg.h	486;"	d
-bTxHTAdvanceCoding	include/Hal8703BPhyReg.h	513;"	d
-bTxHTAdvanceCoding	include/Hal8723BPhyReg.h	512;"	d
-bTxHTAdvanceCoding	include/Hal8723DPhyReg.h	514;"	d
-bTxHTAdvanceCoding	include/Hal8812PhyReg.h	344;"	d
-bTxHTAdvanceCoding	include/Hal8814PhyReg.h	451;"	d
-bTxHTAdvanceCoding	include/rtw_mp_phy_regdef.h	429;"	d
-bTxHTAggreation	include/Hal8188EPhyReg.h	475;"	d
-bTxHTAggreation	include/Hal8188FPhyReg.h	483;"	d
-bTxHTAggreation	include/Hal8192EPhyReg.h	484;"	d
-bTxHTAggreation	include/Hal8703BPhyReg.h	511;"	d
-bTxHTAggreation	include/Hal8723BPhyReg.h	510;"	d
-bTxHTAggreation	include/Hal8723DPhyReg.h	512;"	d
-bTxHTAggreation	include/Hal8812PhyReg.h	342;"	d
-bTxHTAggreation	include/Hal8814PhyReg.h	449;"	d
-bTxHTAggreation	include/rtw_mp_phy_regdef.h	427;"	d
-bTxHTBW	include/Hal8188EPhyReg.h	469;"	d
-bTxHTBW	include/Hal8188FPhyReg.h	477;"	d
-bTxHTBW	include/Hal8192EPhyReg.h	478;"	d
-bTxHTBW	include/Hal8703BPhyReg.h	505;"	d
-bTxHTBW	include/Hal8723BPhyReg.h	504;"	d
-bTxHTBW	include/Hal8723DPhyReg.h	506;"	d
-bTxHTBW	include/Hal8812PhyReg.h	336;"	d
-bTxHTBW	include/Hal8814PhyReg.h	443;"	d
-bTxHTBW	include/rtw_mp_phy_regdef.h	421;"	d
-bTxHTCRC8	include/Hal8188EPhyReg.h	480;"	d
-bTxHTCRC8	include/Hal8188FPhyReg.h	488;"	d
-bTxHTCRC8	include/Hal8192EPhyReg.h	489;"	d
-bTxHTCRC8	include/Hal8703BPhyReg.h	516;"	d
-bTxHTCRC8	include/Hal8723BPhyReg.h	515;"	d
-bTxHTCRC8	include/Hal8723DPhyReg.h	517;"	d
-bTxHTCRC8	include/Hal8812PhyReg.h	347;"	d
-bTxHTCRC8	include/Hal8814PhyReg.h	454;"	d
-bTxHTCRC8	include/rtw_mp_phy_regdef.h	432;"	d
-bTxHTLength	include/Hal8188EPhyReg.h	470;"	d
-bTxHTLength	include/Hal8188FPhyReg.h	478;"	d
-bTxHTLength	include/Hal8192EPhyReg.h	479;"	d
-bTxHTLength	include/Hal8703BPhyReg.h	506;"	d
-bTxHTLength	include/Hal8723BPhyReg.h	505;"	d
-bTxHTLength	include/Hal8723DPhyReg.h	507;"	d
-bTxHTLength	include/Hal8812PhyReg.h	337;"	d
-bTxHTLength	include/Hal8814PhyReg.h	444;"	d
-bTxHTLength	include/rtw_mp_phy_regdef.h	422;"	d
-bTxHTMCSRate	include/Hal8188EPhyReg.h	468;"	d
-bTxHTMCSRate	include/Hal8188FPhyReg.h	476;"	d
-bTxHTMCSRate	include/Hal8192EPhyReg.h	477;"	d
-bTxHTMCSRate	include/Hal8703BPhyReg.h	504;"	d
-bTxHTMCSRate	include/Hal8723BPhyReg.h	503;"	d
-bTxHTMCSRate	include/Hal8723DPhyReg.h	505;"	d
-bTxHTMCSRate	include/Hal8812PhyReg.h	335;"	d
-bTxHTMCSRate	include/Hal8814PhyReg.h	442;"	d
-bTxHTMCSRate	include/rtw_mp_phy_regdef.h	420;"	d
-bTxHTMode	include/Hal8188EPhyReg.h	488;"	d
-bTxHTMode	include/Hal8188FPhyReg.h	496;"	d
-bTxHTMode	include/Hal8192EPhyReg.h	497;"	d
-bTxHTMode	include/Hal8703BPhyReg.h	524;"	d
-bTxHTMode	include/Hal8723BPhyReg.h	523;"	d
-bTxHTMode	include/Hal8723DPhyReg.h	525;"	d
-bTxHTMode	include/Hal8812PhyReg.h	355;"	d
-bTxHTMode	include/Hal8814PhyReg.h	462;"	d
-bTxHTMode	include/rtw_mp_phy_regdef.h	440;"	d
-bTxHTNumberHT_LTF	include/Hal8188EPhyReg.h	479;"	d
-bTxHTNumberHT_LTF	include/Hal8188FPhyReg.h	487;"	d
-bTxHTNumberHT_LTF	include/Hal8192EPhyReg.h	488;"	d
-bTxHTNumberHT_LTF	include/Hal8703BPhyReg.h	515;"	d
-bTxHTNumberHT_LTF	include/Hal8723BPhyReg.h	514;"	d
-bTxHTNumberHT_LTF	include/Hal8723DPhyReg.h	516;"	d
-bTxHTNumberHT_LTF	include/Hal8812PhyReg.h	346;"	d
-bTxHTNumberHT_LTF	include/Hal8814PhyReg.h	453;"	d
-bTxHTNumberHT_LTF	include/rtw_mp_phy_regdef.h	431;"	d
-bTxHTReserved	include/Hal8188EPhyReg.h	474;"	d
-bTxHTReserved	include/Hal8188FPhyReg.h	482;"	d
-bTxHTReserved	include/Hal8192EPhyReg.h	483;"	d
-bTxHTReserved	include/Hal8703BPhyReg.h	510;"	d
-bTxHTReserved	include/Hal8723BPhyReg.h	509;"	d
-bTxHTReserved	include/Hal8723DPhyReg.h	511;"	d
-bTxHTReserved	include/Hal8812PhyReg.h	341;"	d
-bTxHTReserved	include/Hal8814PhyReg.h	448;"	d
-bTxHTReserved	include/rtw_mp_phy_regdef.h	426;"	d
-bTxHTSIG1	include/Hal8188EPhyReg.h	467;"	d
-bTxHTSIG1	include/Hal8188FPhyReg.h	475;"	d
-bTxHTSIG1	include/Hal8192EPhyReg.h	476;"	d
-bTxHTSIG1	include/Hal8703BPhyReg.h	503;"	d
-bTxHTSIG1	include/Hal8723BPhyReg.h	502;"	d
-bTxHTSIG1	include/Hal8723DPhyReg.h	504;"	d
-bTxHTSIG1	include/Hal8812PhyReg.h	334;"	d
-bTxHTSIG1	include/Hal8814PhyReg.h	441;"	d
-bTxHTSIG1	include/rtw_mp_phy_regdef.h	419;"	d
-bTxHTSIG2	include/Hal8188EPhyReg.h	471;"	d
-bTxHTSIG2	include/Hal8188FPhyReg.h	479;"	d
-bTxHTSIG2	include/Hal8192EPhyReg.h	480;"	d
-bTxHTSIG2	include/Hal8703BPhyReg.h	507;"	d
-bTxHTSIG2	include/Hal8723BPhyReg.h	506;"	d
-bTxHTSIG2	include/Hal8723DPhyReg.h	508;"	d
-bTxHTSIG2	include/Hal8812PhyReg.h	338;"	d
-bTxHTSIG2	include/Hal8814PhyReg.h	445;"	d
-bTxHTSIG2	include/rtw_mp_phy_regdef.h	423;"	d
-bTxHTSTBC	include/Hal8188EPhyReg.h	476;"	d
-bTxHTSTBC	include/Hal8188FPhyReg.h	484;"	d
-bTxHTSTBC	include/Hal8192EPhyReg.h	485;"	d
-bTxHTSTBC	include/Hal8703BPhyReg.h	512;"	d
-bTxHTSTBC	include/Hal8723BPhyReg.h	511;"	d
-bTxHTSTBC	include/Hal8723DPhyReg.h	513;"	d
-bTxHTSTBC	include/Hal8812PhyReg.h	343;"	d
-bTxHTSTBC	include/Hal8814PhyReg.h	450;"	d
-bTxHTSTBC	include/rtw_mp_phy_regdef.h	428;"	d
-bTxHTShortGI	include/Hal8188EPhyReg.h	478;"	d
-bTxHTShortGI	include/Hal8188FPhyReg.h	486;"	d
-bTxHTShortGI	include/Hal8192EPhyReg.h	487;"	d
-bTxHTShortGI	include/Hal8703BPhyReg.h	514;"	d
-bTxHTShortGI	include/Hal8723BPhyReg.h	513;"	d
-bTxHTShortGI	include/Hal8723DPhyReg.h	515;"	d
-bTxHTShortGI	include/Hal8812PhyReg.h	345;"	d
-bTxHTShortGI	include/Hal8814PhyReg.h	452;"	d
-bTxHTShortGI	include/rtw_mp_phy_regdef.h	430;"	d
-bTxHTSmoothing	include/Hal8188EPhyReg.h	472;"	d
-bTxHTSmoothing	include/Hal8188FPhyReg.h	480;"	d
-bTxHTSmoothing	include/Hal8192EPhyReg.h	481;"	d
-bTxHTSmoothing	include/Hal8703BPhyReg.h	508;"	d
-bTxHTSmoothing	include/Hal8723BPhyReg.h	507;"	d
-bTxHTSmoothing	include/Hal8723DPhyReg.h	509;"	d
-bTxHTSmoothing	include/Hal8812PhyReg.h	339;"	d
-bTxHTSmoothing	include/Hal8814PhyReg.h	446;"	d
-bTxHTSmoothing	include/rtw_mp_phy_regdef.h	424;"	d
-bTxHTSounding	include/Hal8188EPhyReg.h	473;"	d
-bTxHTSounding	include/Hal8188FPhyReg.h	481;"	d
-bTxHTSounding	include/Hal8192EPhyReg.h	482;"	d
-bTxHTSounding	include/Hal8703BPhyReg.h	509;"	d
-bTxHTSounding	include/Hal8723BPhyReg.h	508;"	d
-bTxHTSounding	include/Hal8723DPhyReg.h	510;"	d
-bTxHTSounding	include/Hal8812PhyReg.h	340;"	d
-bTxHTSounding	include/Hal8814PhyReg.h	447;"	d
-bTxHTSounding	include/rtw_mp_phy_regdef.h	425;"	d
-bTxIDCOffset	include/Hal8188EPhyReg.h	807;"	d
-bTxIDCOffset	include/Hal8188FPhyReg.h	815;"	d
-bTxIDCOffset	include/Hal8192EPhyReg.h	818;"	d
-bTxIDCOffset	include/Hal8703BPhyReg.h	844;"	d
-bTxIDCOffset	include/Hal8723BPhyReg.h	842;"	d
-bTxIDCOffset	include/Hal8723DPhyReg.h	845;"	d
-bTxIDCOffset	include/rtw_mp_phy_regdef.h	761;"	d
-bTxIdleInterval	include/Hal8188EPhyReg.h	484;"	d
-bTxIdleInterval	include/Hal8188FPhyReg.h	492;"	d
-bTxIdleInterval	include/Hal8192EPhyReg.h	493;"	d
-bTxIdleInterval	include/Hal8703BPhyReg.h	520;"	d
-bTxIdleInterval	include/Hal8723BPhyReg.h	519;"	d
-bTxIdleInterval	include/Hal8723DPhyReg.h	521;"	d
-bTxIdleInterval	include/Hal8812PhyReg.h	351;"	d
-bTxIdleInterval	include/Hal8814PhyReg.h	458;"	d
-bTxIdleInterval	include/rtw_mp_phy_regdef.h	436;"	d
-bTxLSIG	include/Hal8188EPhyReg.h	462;"	d
-bTxLSIG	include/Hal8188FPhyReg.h	470;"	d
-bTxLSIG	include/Hal8192EPhyReg.h	471;"	d
-bTxLSIG	include/Hal8703BPhyReg.h	498;"	d
-bTxLSIG	include/Hal8723BPhyReg.h	497;"	d
-bTxLSIG	include/Hal8723DPhyReg.h	499;"	d
-bTxLSIG	include/Hal8812PhyReg.h	329;"	d
-bTxLSIG	include/Hal8814PhyReg.h	436;"	d
-bTxLSIG	include/rtw_mp_phy_regdef.h	414;"	d
-bTxMACHeader	include/Hal8188EPhyReg.h	486;"	d
-bTxMACHeader	include/Hal8188FPhyReg.h	494;"	d
-bTxMACHeader	include/Hal8192EPhyReg.h	495;"	d
-bTxMACHeader	include/Hal8703BPhyReg.h	522;"	d
-bTxMACHeader	include/Hal8723BPhyReg.h	521;"	d
-bTxMACHeader	include/Hal8723DPhyReg.h	523;"	d
-bTxMACHeader	include/Hal8812PhyReg.h	353;"	d
-bTxMACHeader	include/Hal8814PhyReg.h	460;"	d
-bTxMACHeader	include/rtw_mp_phy_regdef.h	438;"	d
-bTxPathA	include/Hal8188EPhyReg.h	751;"	d
-bTxPathA	include/Hal8188FPhyReg.h	759;"	d
-bTxPathA	include/Hal8192EPhyReg.h	762;"	d
-bTxPathA	include/Hal8703BPhyReg.h	788;"	d
-bTxPathA	include/Hal8723BPhyReg.h	786;"	d
-bTxPathA	include/Hal8723DPhyReg.h	789;"	d
-bTxPathA	include/rtw_mp_phy_regdef.h	705;"	d
-bTxPathB	include/Hal8188EPhyReg.h	752;"	d
-bTxPathB	include/Hal8188FPhyReg.h	760;"	d
-bTxPathB	include/Hal8192EPhyReg.h	763;"	d
-bTxPathB	include/Hal8703BPhyReg.h	789;"	d
-bTxPathB	include/Hal8723BPhyReg.h	787;"	d
-bTxPathB	include/Hal8723DPhyReg.h	790;"	d
-bTxPathB	include/rtw_mp_phy_regdef.h	706;"	d
-bTxPathC	include/Hal8188EPhyReg.h	753;"	d
-bTxPathC	include/Hal8188FPhyReg.h	761;"	d
-bTxPathC	include/Hal8192EPhyReg.h	764;"	d
-bTxPathC	include/Hal8703BPhyReg.h	790;"	d
-bTxPathC	include/Hal8723BPhyReg.h	788;"	d
-bTxPathC	include/Hal8723DPhyReg.h	791;"	d
-bTxPathC	include/rtw_mp_phy_regdef.h	707;"	d
-bTxPathD	include/Hal8188EPhyReg.h	754;"	d
-bTxPathD	include/Hal8188FPhyReg.h	762;"	d
-bTxPathD	include/Hal8192EPhyReg.h	765;"	d
-bTxPathD	include/Hal8703BPhyReg.h	791;"	d
-bTxPathD	include/Hal8723BPhyReg.h	789;"	d
-bTxPathD	include/Hal8723DPhyReg.h	792;"	d
-bTxPathD	include/rtw_mp_phy_regdef.h	708;"	d
-bTxPath_Jaguar	include/Hal8812PhyReg.h	56;"	d
-bTxPath_Jaguar	include/Hal8814PhyReg.h	58;"	d
-bTxPesudoNoiseOn	include/Hal8188EPhyReg.h	810;"	d
-bTxPesudoNoiseOn	include/Hal8188FPhyReg.h	818;"	d
-bTxPesudoNoiseOn	include/Hal8192EPhyReg.h	821;"	d
-bTxPesudoNoiseOn	include/Hal8703BPhyReg.h	847;"	d
-bTxPesudoNoiseOn	include/Hal8723BPhyReg.h	845;"	d
-bTxPesudoNoiseOn	include/Hal8723DPhyReg.h	848;"	d
-bTxPesudoNoiseOn	include/rtw_mp_phy_regdef.h	764;"	d
-bTxPesudoNoise_A	include/Hal8188EPhyReg.h	811;"	d
-bTxPesudoNoise_A	include/Hal8188FPhyReg.h	819;"	d
-bTxPesudoNoise_A	include/Hal8192EPhyReg.h	822;"	d
-bTxPesudoNoise_A	include/Hal8703BPhyReg.h	848;"	d
-bTxPesudoNoise_A	include/Hal8723BPhyReg.h	846;"	d
-bTxPesudoNoise_A	include/Hal8723DPhyReg.h	849;"	d
-bTxPesudoNoise_A	include/rtw_mp_phy_regdef.h	765;"	d
-bTxPesudoNoise_B	include/Hal8188EPhyReg.h	812;"	d
-bTxPesudoNoise_B	include/Hal8188FPhyReg.h	820;"	d
-bTxPesudoNoise_B	include/Hal8192EPhyReg.h	823;"	d
-bTxPesudoNoise_B	include/Hal8703BPhyReg.h	849;"	d
-bTxPesudoNoise_B	include/Hal8723BPhyReg.h	847;"	d
-bTxPesudoNoise_B	include/Hal8723DPhyReg.h	850;"	d
-bTxPesudoNoise_B	include/rtw_mp_phy_regdef.h	766;"	d
-bTxPesudoNoise_C	include/Hal8188EPhyReg.h	813;"	d
-bTxPesudoNoise_C	include/Hal8188FPhyReg.h	821;"	d
-bTxPesudoNoise_C	include/Hal8192EPhyReg.h	824;"	d
-bTxPesudoNoise_C	include/Hal8703BPhyReg.h	850;"	d
-bTxPesudoNoise_C	include/Hal8723BPhyReg.h	848;"	d
-bTxPesudoNoise_C	include/Hal8723DPhyReg.h	851;"	d
-bTxPesudoNoise_C	include/rtw_mp_phy_regdef.h	767;"	d
-bTxPesudoNoise_D	include/Hal8188EPhyReg.h	814;"	d
-bTxPesudoNoise_D	include/Hal8188FPhyReg.h	822;"	d
-bTxPesudoNoise_D	include/Hal8192EPhyReg.h	825;"	d
-bTxPesudoNoise_D	include/Hal8703BPhyReg.h	851;"	d
-bTxPesudoNoise_D	include/Hal8723BPhyReg.h	849;"	d
-bTxPesudoNoise_D	include/Hal8723DPhyReg.h	852;"	d
-bTxPesudoNoise_D	include/rtw_mp_phy_regdef.h	768;"	d
-bTxPowerChanged	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN bTxPowerChanged;$/;"	m	struct:ODM_RF_Calibration_Structure
-bTxPowerChanged	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN bTxPowerChanged;$/;"	m	struct:ODM_RF_Calibration_Structure
-bTxPowerChanged	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN bTxPowerChanged;$/;"	m	struct:ODM_RF_Calibration_Structure
-bTxQDCOffset	include/Hal8188EPhyReg.h	808;"	d
-bTxQDCOffset	include/Hal8188FPhyReg.h	816;"	d
-bTxQDCOffset	include/Hal8192EPhyReg.h	819;"	d
-bTxQDCOffset	include/Hal8703BPhyReg.h	845;"	d
-bTxQDCOffset	include/Hal8723BPhyReg.h	843;"	d
-bTxQDCOffset	include/Hal8723DPhyReg.h	846;"	d
-bTxQDCOffset	include/rtw_mp_phy_regdef.h	762;"	d
-bTxRandomSeed	include/Hal8188EPhyReg.h	490;"	d
-bTxRandomSeed	include/Hal8188FPhyReg.h	498;"	d
-bTxRandomSeed	include/Hal8192EPhyReg.h	499;"	d
-bTxRandomSeed	include/Hal8703BPhyReg.h	526;"	d
-bTxRandomSeed	include/Hal8723BPhyReg.h	525;"	d
-bTxRandomSeed	include/Hal8723DPhyReg.h	527;"	d
-bTxRandomSeed	include/Hal8812PhyReg.h	357;"	d
-bTxRandomSeed	include/Hal8814PhyReg.h	464;"	d
-bTxRandomSeed	include/rtw_mp_phy_regdef.h	442;"	d
-bUChCfg	include/Hal8188EPhyReg.h	998;"	d
-bUChCfg	include/Hal8188FPhyReg.h	1006;"	d
-bUChCfg	include/Hal8192EPhyReg.h	1009;"	d
-bUChCfg	include/Hal8703BPhyReg.h	1035;"	d
-bUChCfg	include/Hal8723BPhyReg.h	1033;"	d
-bUChCfg	include/Hal8723DPhyReg.h	1036;"	d
-bUChCfg	include/rtw_mp_phy_regdef.h	952;"	d
-bUpdCFO	include/Hal8188EPhyReg.h	986;"	d
-bUpdCFO	include/Hal8188FPhyReg.h	994;"	d
-bUpdCFO	include/Hal8192EPhyReg.h	997;"	d
-bUpdCFO	include/Hal8703BPhyReg.h	1023;"	d
-bUpdCFO	include/Hal8723BPhyReg.h	1021;"	d
-bUpdCFO	include/Hal8723DPhyReg.h	1024;"	d
-bUpdCFO	include/rtw_mp_phy_regdef.h	940;"	d
-bUpdCFOOffData	include/Hal8188EPhyReg.h	987;"	d
-bUpdCFOOffData	include/Hal8188FPhyReg.h	995;"	d
-bUpdCFOOffData	include/Hal8192EPhyReg.h	998;"	d
-bUpdCFOOffData	include/Hal8703BPhyReg.h	1024;"	d
-bUpdCFOOffData	include/Hal8723BPhyReg.h	1022;"	d
-bUpdCFOOffData	include/Hal8723DPhyReg.h	1025;"	d
-bUpdCFOOffData	include/rtw_mp_phy_regdef.h	941;"	d
-bUpdClko	include/Hal8188EPhyReg.h	990;"	d
-bUpdClko	include/Hal8188FPhyReg.h	998;"	d
-bUpdClko	include/Hal8192EPhyReg.h	1001;"	d
-bUpdClko	include/Hal8703BPhyReg.h	1027;"	d
-bUpdClko	include/Hal8723BPhyReg.h	1025;"	d
-bUpdClko	include/Hal8723DPhyReg.h	1028;"	d
-bUpdClko	include/rtw_mp_phy_regdef.h	944;"	d
-bUpdClkoLTF	include/Hal8188EPhyReg.h	994;"	d
-bUpdClkoLTF	include/Hal8188FPhyReg.h	1002;"	d
-bUpdClkoLTF	include/Hal8192EPhyReg.h	1005;"	d
-bUpdClkoLTF	include/Hal8703BPhyReg.h	1031;"	d
-bUpdClkoLTF	include/Hal8723BPhyReg.h	1029;"	d
-bUpdClkoLTF	include/Hal8723DPhyReg.h	1032;"	d
-bUpdClkoLTF	include/rtw_mp_phy_regdef.h	948;"	d
-bUpdEqz	include/Hal8188EPhyReg.h	999;"	d
-bUpdEqz	include/Hal8188FPhyReg.h	1007;"	d
-bUpdEqz	include/Hal8192EPhyReg.h	1010;"	d
-bUpdEqz	include/Hal8703BPhyReg.h	1036;"	d
-bUpdEqz	include/Hal8723BPhyReg.h	1034;"	d
-bUpdEqz	include/Hal8723DPhyReg.h	1037;"	d
-bUpdEqz	include/rtw_mp_phy_regdef.h	953;"	d
-bUseLdpc	hal/phydm/phydm_rainfo.h	/^	BOOLEAN				bUseLdpc;$/;"	m	struct:_ODM_RATE_ADAPTIVE
-bUseRAMask	hal/phydm/phydm.h	/^	u1Byte			bUseRAMask;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bUsed	hal/phydm/phydm.h	/^	BOOLEAN		bUsed;			\/*record the sta status link or not?*\/$/;"	m	struct:_ODM_STA_INFO
-bUsed	hal/phydm/phydm_beamforming.h	/^	BOOLEAN 			bUsed;$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-bUsed	hal/phydm/phydm_beamforming.h	/^	BOOLEAN bUsed;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-bUsed	include/rtw_beamforming.h	/^	BOOLEAN	bUsed;$/;"	m	struct:beamforming_entry
-bUsed	include/rtw_security.h	/^	u8						bUsed;$/;"	m	struct:_RT_PMKID_LIST
-bUserAssignLevel	hal/phydm/phydm.h	/^	BOOLEAN			bUserAssignLevel;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bValid	include/sta_info.h	/^	u8		bValid;				\/* record the sta status link or not? *\/$/;"	m	struct:sta_info
-bWIFI_Direct	hal/phydm/phydm.h	/^	BOOLEAN			bWIFI_Direct;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bWIFI_Display	hal/phydm/phydm.h	/^	BOOLEAN			bWIFI_Display;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bWMACControl	include/Hal8188EPhyReg.h	1094;"	d
-bWMACControl	include/Hal8188FPhyReg.h	1101;"	d
-bWMACControl	include/Hal8192EPhyReg.h	1108;"	d
-bWMACControl	include/Hal8703BPhyReg.h	1130;"	d
-bWMACControl	include/Hal8723BPhyReg.h	1128;"	d
-bWMACControl	include/Hal8723DPhyReg.h	1131;"	d
-bWMACControl	include/rtw_mp_phy_regdef.h	1065;"	d
-bWNICControl	include/Hal8188EPhyReg.h	1095;"	d
-bWNICControl	include/Hal8188FPhyReg.h	1102;"	d
-bWNICControl	include/Hal8192EPhyReg.h	1109;"	d
-bWNICControl	include/Hal8703BPhyReg.h	1131;"	d
-bWNICControl	include/Hal8723BPhyReg.h	1129;"	d
-bWNICControl	include/Hal8723DPhyReg.h	1132;"	d
-bWNICControl	include/rtw_mp_phy_regdef.h	1066;"	d
-bWapiCheckPNInDecrypt	include/rtw_recv.h	/^	u8 bWapiCheckPNInDecrypt;$/;"	m	struct:recv_frame_hdr
-bWapiEnable	include/rtw_wapi.h	/^	bool				bWapiEnable;$/;"	m	struct:_RT_WAPI_T
-bWapiPSK	include/rtw_wapi.h	/^	bool				bWapiPSK;$/;"	m	struct:_RT_WAPI_T
-bWepDefaultKeyIdxSet	include/rtw_security.h	/^	u8 bWepDefaultKeyIdxSet;$/;"	m	struct:security_priv
-bWindow_L	include/Hal8188EPhyReg.h	781;"	d
-bWindow_L	include/Hal8188FPhyReg.h	789;"	d
-bWindow_L	include/Hal8192EPhyReg.h	792;"	d
-bWindow_L	include/Hal8703BPhyReg.h	818;"	d
-bWindow_L	include/Hal8723BPhyReg.h	816;"	d
-bWindow_L	include/Hal8723DPhyReg.h	819;"	d
-bWindow_L	include/rtw_mp_phy_regdef.h	735;"	d
-bWord0	include/Hal8188EPhyReg.h	1045;"	d
-bWord0	include/Hal8188FPhyReg.h	1053;"	d
-bWord0	include/Hal8192EPhyReg.h	1056;"	d
-bWord0	include/Hal8703BPhyReg.h	1082;"	d
-bWord0	include/Hal8723BPhyReg.h	1080;"	d
-bWord0	include/Hal8723DPhyReg.h	1083;"	d
-bWord0	include/Hal8812PhyReg.h	716;"	d
-bWord0	include/Hal8814PhyReg.h	841;"	d
-bWord0	include/rtw_mp_phy_regdef.h	1008;"	d
-bWord1	include/Hal8188EPhyReg.h	1046;"	d
-bWord1	include/Hal8188FPhyReg.h	1054;"	d
-bWord1	include/Hal8192EPhyReg.h	1057;"	d
-bWord1	include/Hal8703BPhyReg.h	1083;"	d
-bWord1	include/Hal8723BPhyReg.h	1081;"	d
-bWord1	include/Hal8723DPhyReg.h	1084;"	d
-bWord1	include/Hal8812PhyReg.h	717;"	d
-bWord1	include/Hal8814PhyReg.h	842;"	d
-bWord1	include/rtw_mp_phy_regdef.h	1009;"	d
-bXATxAGC	include/Hal8188EPhyReg.h	512;"	d
-bXATxAGC	include/Hal8188FPhyReg.h	520;"	d
-bXATxAGC	include/Hal8192EPhyReg.h	523;"	d
-bXATxAGC	include/Hal8703BPhyReg.h	549;"	d
-bXATxAGC	include/Hal8723BPhyReg.h	547;"	d
-bXATxAGC	include/Hal8723DPhyReg.h	550;"	d
-bXATxAGC	include/rtw_mp_phy_regdef.h	464;"	d
-bXBTxAGC	include/Hal8188EPhyReg.h	516;"	d
-bXBTxAGC	include/Hal8188FPhyReg.h	524;"	d
-bXBTxAGC	include/Hal8192EPhyReg.h	527;"	d
-bXBTxAGC	include/Hal8703BPhyReg.h	553;"	d
-bXBTxAGC	include/Hal8723BPhyReg.h	551;"	d
-bXBTxAGC	include/Hal8723DPhyReg.h	554;"	d
-bXBTxAGC	include/Hal8812PhyReg.h	607;"	d
-bXBTxAGC	include/Hal8814PhyReg.h	730;"	d
-bXBTxAGC	include/rtl8822b_hal.h	159;"	d
-bXBTxAGC	include/rtw_mp_phy_regdef.h	466;"	d
-bXCTxAGC	include/Hal8188EPhyReg.h	517;"	d
-bXCTxAGC	include/Hal8188FPhyReg.h	525;"	d
-bXCTxAGC	include/Hal8192EPhyReg.h	528;"	d
-bXCTxAGC	include/Hal8703BPhyReg.h	554;"	d
-bXCTxAGC	include/Hal8723BPhyReg.h	552;"	d
-bXCTxAGC	include/Hal8723DPhyReg.h	555;"	d
-bXCTxAGC	include/Hal8812PhyReg.h	608;"	d
-bXCTxAGC	include/Hal8814PhyReg.h	731;"	d
-bXCTxAGC	include/rtl8822b_hal.h	160;"	d
-bXCTxAGC	include/rtw_mp_phy_regdef.h	467;"	d
-bXDTxAGC	include/Hal8188EPhyReg.h	518;"	d
-bXDTxAGC	include/Hal8188FPhyReg.h	526;"	d
-bXDTxAGC	include/Hal8192EPhyReg.h	529;"	d
-bXDTxAGC	include/Hal8703BPhyReg.h	555;"	d
-bXDTxAGC	include/Hal8723BPhyReg.h	553;"	d
-bXDTxAGC	include/Hal8723DPhyReg.h	556;"	d
-bXDTxAGC	include/Hal8812PhyReg.h	609;"	d
-bXDTxAGC	include/Hal8814PhyReg.h	732;"	d
-bXDTxAGC	include/rtl8822b_hal.h	161;"	d
-bXDTxAGC	include/rtw_mp_phy_regdef.h	468;"	d
-bXtalCap	include/Hal8188EPhyReg.h	613;"	d
-bXtalCap	include/Hal8188FPhyReg.h	621;"	d
-bXtalCap	include/Hal8192EPhyReg.h	624;"	d
-bXtalCap	include/Hal8703BPhyReg.h	650;"	d
-bXtalCap	include/Hal8723BPhyReg.h	648;"	d
-bXtalCap	include/Hal8723DPhyReg.h	651;"	d
-bXtalCap	include/rtw_mp_phy_regdef.h	567;"	d
-bXtalCap01	include/Hal8188EPhyReg.h	610;"	d
-bXtalCap01	include/Hal8188FPhyReg.h	618;"	d
-bXtalCap01	include/Hal8192EPhyReg.h	621;"	d
-bXtalCap01	include/Hal8703BPhyReg.h	647;"	d
-bXtalCap01	include/Hal8723BPhyReg.h	645;"	d
-bXtalCap01	include/Hal8723DPhyReg.h	648;"	d
-bXtalCap01	include/rtw_mp_phy_regdef.h	564;"	d
-bXtalCap23	include/Hal8188EPhyReg.h	611;"	d
-bXtalCap23	include/Hal8188FPhyReg.h	619;"	d
-bXtalCap23	include/Hal8192EPhyReg.h	622;"	d
-bXtalCap23	include/Hal8703BPhyReg.h	648;"	d
-bXtalCap23	include/Hal8723BPhyReg.h	646;"	d
-bXtalCap23	include/Hal8723DPhyReg.h	649;"	d
-bXtalCap23	include/rtw_mp_phy_regdef.h	565;"	d
-bXtalCap92x	include/Hal8188EPhyReg.h	612;"	d
-bXtalCap92x	include/Hal8188FPhyReg.h	620;"	d
-bXtalCap92x	include/Hal8192EPhyReg.h	623;"	d
-bXtalCap92x	include/Hal8703BPhyReg.h	649;"	d
-bXtalCap92x	include/Hal8723BPhyReg.h	647;"	d
-bXtalCap92x	include/Hal8723DPhyReg.h	650;"	d
-bXtalCap92x	include/rtw_mp_phy_regdef.h	566;"	d
-bXtalPowerUp	include/Hal8188EPhyReg.h	600;"	d
-bXtalPowerUp	include/Hal8188FPhyReg.h	608;"	d
-bXtalPowerUp	include/Hal8192EPhyReg.h	611;"	d
-bXtalPowerUp	include/Hal8703BPhyReg.h	637;"	d
-bXtalPowerUp	include/Hal8723BPhyReg.h	635;"	d
-bXtalPowerUp	include/Hal8723DPhyReg.h	638;"	d
-bXtalPowerUp	include/rtw_mp_phy_regdef.h	554;"	d
-bZebra1_ChannelNum	include/Hal8188EPhyReg.h	1020;"	d
-bZebra1_ChannelNum	include/Hal8188FPhyReg.h	1028;"	d
-bZebra1_ChannelNum	include/Hal8192EPhyReg.h	1031;"	d
-bZebra1_ChannelNum	include/Hal8703BPhyReg.h	1057;"	d
-bZebra1_ChannelNum	include/Hal8723BPhyReg.h	1055;"	d
-bZebra1_ChannelNum	include/Hal8723DPhyReg.h	1058;"	d
-bZebra1_ChannelNum	include/rtw_mp_phy_regdef.h	983;"	d
-bZebra1_HSSIEnable	include/Hal8188EPhyReg.h	1014;"	d
-bZebra1_HSSIEnable	include/Hal8188FPhyReg.h	1022;"	d
-bZebra1_HSSIEnable	include/Hal8192EPhyReg.h	1025;"	d
-bZebra1_HSSIEnable	include/Hal8703BPhyReg.h	1051;"	d
-bZebra1_HSSIEnable	include/Hal8723BPhyReg.h	1049;"	d
-bZebra1_HSSIEnable	include/Hal8723DPhyReg.h	1052;"	d
-bZebra1_HSSIEnable	include/rtw_mp_phy_regdef.h	977;"	d
-bZebra1_RxChargePump	include/Hal8188EPhyReg.h	1019;"	d
-bZebra1_RxChargePump	include/Hal8188FPhyReg.h	1027;"	d
-bZebra1_RxChargePump	include/Hal8192EPhyReg.h	1030;"	d
-bZebra1_RxChargePump	include/Hal8703BPhyReg.h	1056;"	d
-bZebra1_RxChargePump	include/Hal8723BPhyReg.h	1054;"	d
-bZebra1_RxChargePump	include/Hal8723DPhyReg.h	1057;"	d
-bZebra1_RxChargePump	include/rtw_mp_phy_regdef.h	982;"	d
-bZebra1_RxCorner	include/Hal8188EPhyReg.h	1017;"	d
-bZebra1_RxCorner	include/Hal8188FPhyReg.h	1025;"	d
-bZebra1_RxCorner	include/Hal8192EPhyReg.h	1028;"	d
-bZebra1_RxCorner	include/Hal8703BPhyReg.h	1054;"	d
-bZebra1_RxCorner	include/Hal8723BPhyReg.h	1052;"	d
-bZebra1_RxCorner	include/Hal8723DPhyReg.h	1055;"	d
-bZebra1_RxCorner	include/rtw_mp_phy_regdef.h	980;"	d
-bZebra1_RxLPFBW	include/Hal8188EPhyReg.h	1022;"	d
-bZebra1_RxLPFBW	include/Hal8188FPhyReg.h	1030;"	d
-bZebra1_RxLPFBW	include/Hal8192EPhyReg.h	1033;"	d
-bZebra1_RxLPFBW	include/Hal8703BPhyReg.h	1059;"	d
-bZebra1_RxLPFBW	include/Hal8723BPhyReg.h	1057;"	d
-bZebra1_RxLPFBW	include/Hal8723DPhyReg.h	1060;"	d
-bZebra1_RxLPFBW	include/rtw_mp_phy_regdef.h	985;"	d
-bZebra1_TRxControl	include/Hal8188EPhyReg.h	1015;"	d
-bZebra1_TRxControl	include/Hal8188FPhyReg.h	1023;"	d
-bZebra1_TRxControl	include/Hal8192EPhyReg.h	1026;"	d
-bZebra1_TRxControl	include/Hal8703BPhyReg.h	1052;"	d
-bZebra1_TRxControl	include/Hal8723BPhyReg.h	1050;"	d
-bZebra1_TRxControl	include/Hal8723DPhyReg.h	1053;"	d
-bZebra1_TRxControl	include/rtw_mp_phy_regdef.h	978;"	d
-bZebra1_TRxGainSetting	include/Hal8188EPhyReg.h	1016;"	d
-bZebra1_TRxGainSetting	include/Hal8188FPhyReg.h	1024;"	d
-bZebra1_TRxGainSetting	include/Hal8192EPhyReg.h	1027;"	d
-bZebra1_TRxGainSetting	include/Hal8703BPhyReg.h	1053;"	d
-bZebra1_TRxGainSetting	include/Hal8723BPhyReg.h	1051;"	d
-bZebra1_TRxGainSetting	include/Hal8723DPhyReg.h	1054;"	d
-bZebra1_TRxGainSetting	include/rtw_mp_phy_regdef.h	979;"	d
-bZebra1_TxChargePump	include/Hal8188EPhyReg.h	1018;"	d
-bZebra1_TxChargePump	include/Hal8188FPhyReg.h	1026;"	d
-bZebra1_TxChargePump	include/Hal8192EPhyReg.h	1029;"	d
-bZebra1_TxChargePump	include/Hal8703BPhyReg.h	1055;"	d
-bZebra1_TxChargePump	include/Hal8723BPhyReg.h	1053;"	d
-bZebra1_TxChargePump	include/Hal8723DPhyReg.h	1056;"	d
-bZebra1_TxChargePump	include/rtw_mp_phy_regdef.h	981;"	d
-bZebra1_TxLPFBW	include/Hal8188EPhyReg.h	1021;"	d
-bZebra1_TxLPFBW	include/Hal8188FPhyReg.h	1029;"	d
-bZebra1_TxLPFBW	include/Hal8192EPhyReg.h	1032;"	d
-bZebra1_TxLPFBW	include/Hal8703BPhyReg.h	1058;"	d
-bZebra1_TxLPFBW	include/Hal8723BPhyReg.h	1056;"	d
-bZebra1_TxLPFBW	include/Hal8723DPhyReg.h	1059;"	d
-bZebra1_TxLPFBW	include/rtw_mp_phy_regdef.h	984;"	d
-b_FalseAlarm_Jaguar	include/Hal8812PhyReg.h	136;"	d
-b_FalseAlarm_Jaguar	include/Hal8814PhyReg.h	166;"	d
-b_LNA_sw_Jaguar	include/Hal8812PhyReg.h	159;"	d
-b_LNA_sw_Jaguar	include/Hal8814PhyReg.h	189;"	d
-b_RxIQC_AC_Jaguar	include/Hal8812PhyReg.h	126;"	d
-b_RxIQC_AC_Jaguar	include/Hal8814PhyReg.h	150;"	d
-b_RxIQC_BD_Jaguar	include/Hal8812PhyReg.h	127;"	d
-b_RxIQC_BD_Jaguar	include/Hal8814PhyReg.h	151;"	d
-b_fix_tx_ant	hal/phydm/phydm_antdiv.h	/^	u1Byte	b_fix_tx_ant;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-b_fix_tx_ant	include/hal_data.h	/^	u8	b_fix_tx_ant;$/;"	m	struct:hal_com_data
-b_hw_radio_off	include/rtw_pwrctrl.h	/^	u8	b_hw_radio_off;$/;"	m	struct:pwrctrl_priv
-b_mode_rate_num	include/rtw_rf.h	28;"	d
-b_sel5g_Jaguar	include/Hal8812PhyReg.h	158;"	d
-b_sel5g_Jaguar	include/Hal8814PhyReg.h	188;"	d
-b_support_aspm	include/drv_types.h	/^	u8	b_support_aspm; \/* If it supports ASPM, Offset[560h] = 0x40, otherwise Offset[560h] = 0x00. *\/$/;"	m	struct:dvobj_priv
-b_support_backdoor	include/drv_types.h	/^	u8	b_support_backdoor;$/;"	m	struct:dvobj_priv
-backop_flags	include/rtw_mlme_ext.h	/^	u8 backop_flags; \/* per backop runtime decision *\/$/;"	m	struct:ss_res
-backop_flags_ap	include/rtw_mlme_ext.h	/^	u8 backop_flags_ap; \/* policy for ap mode *\/$/;"	m	struct:ss_res
-backop_flags_sta	include/rtw_mlme_ext.h	/^	u8 backop_flags_sta; \/* policy for station mode*\/$/;"	m	struct:ss_res
-backop_ms	include/rtw_mlme_ext.h	/^	u16 backop_ms;$/;"	m	struct:ss_res
-backop_time	include/rtw_mlme_ext.h	/^	u32 backop_time; \/* the start time of backop *\/$/;"	m	struct:ss_res
-backup0x52_RF_A	include/rtw_mp.h	/^	u8		backup0x52_RF_A;$/;"	m	struct:_MPT_CONTEXT
-backup0x52_RF_B	include/rtw_mp.h	/^	u8		backup0x52_RF_B;$/;"	m	struct:_MPT_CONTEXT
-backup0x58_RF_A	include/rtw_mp.h	/^	u4Byte			backup0x58_RF_A;$/;"	m	struct:_MPT_CONTEXT
-backup0x58_RF_B	include/rtw_mp.h	/^	u4Byte			backup0x58_RF_B;$/;"	m	struct:_MPT_CONTEXT
-backup0x948	hal/btc/HalBtc8723b2Ant.h	/^	u32		backup0x948;$/;"	m	struct:coex_dm_8723b_2ant
-backup0x948	hal/btc/HalBtc8821a2Ant.h	/^	u32		backup0x948;$/;"	m	struct:coex_dm_8821a_2ant
-backup0x948	hal/btc/halbtc8723d2ant.h	/^	u32		backup0x948;$/;"	m	struct:coex_dm_8723d_2ant
-backup0x948	hal/btc/halbtc8821c2ant.h	/^	u32		backup0x948;$/;"	m	struct:coex_dm_8821c_2ant
-backup0xc30	include/rtw_mp.h	/^	u8		backup0xc30;$/;"	m	struct:_MPT_CONTEXT
-backup0xc50	include/rtw_mp.h	/^	u8		backup0xc50;$/;"	m	struct:_MPT_CONTEXT
-backup0xc58	include/rtw_mp.h	/^	u8		backup0xc58;$/;"	m	struct:_MPT_CONTEXT
-backupH2L	hal/phydm/phydm_adaptivity.h	/^	s1Byte			backupH2L;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-backupL2H	hal/phydm/phydm_adaptivity.h	/^	s1Byte			backupL2H;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-backupPMKIDList	os_dep/linux/mlme_linux.c	/^static RT_PMKID_LIST   backupPMKIDList[NUM_PMKID_CACHE];$/;"	v	file:
-backup_ampdu_max_num	hal/btc/HalBtc8821aCsr2Ant.h	/^	u16 backup_ampdu_max_num;$/;"	m	struct:coex_dm_8821a_csr_2ant
-backup_ampdu_max_time	hal/btc/HalBtc8192e1Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8192e_1ant
-backup_ampdu_max_time	hal/btc/HalBtc8192e2Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8192e_2ant
-backup_ampdu_max_time	hal/btc/HalBtc8703b1Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8703b_1ant
-backup_ampdu_max_time	hal/btc/HalBtc8723b1Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8723b_1ant
-backup_ampdu_max_time	hal/btc/HalBtc8812a1Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8812a_1ant
-backup_ampdu_max_time	hal/btc/HalBtc8812a2Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8812a_2ant
-backup_ampdu_max_time	hal/btc/HalBtc8821a1Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8821a_1ant
-backup_ampdu_max_time	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8 backup_ampdu_max_time;$/;"	m	struct:coex_dm_8821a_csr_2ant
-backup_ampdu_max_time	hal/btc/HalBtc8822b1Ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8822b_1ant
-backup_ampdu_max_time	hal/btc/halbtc8723d1ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8723d_1ant
-backup_ampdu_max_time	hal/btc/halbtc8821c1ant.h	/^	u8		backup_ampdu_max_time;$/;"	m	struct:coex_dm_8821c_1ant
-backup_arfr_cnt1	hal/btc/HalBtc8192e1Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8192e_1ant
-backup_arfr_cnt1	hal/btc/HalBtc8192e2Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8192e_2ant
-backup_arfr_cnt1	hal/btc/HalBtc8703b1Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8703b_1ant
-backup_arfr_cnt1	hal/btc/HalBtc8723b1Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8723b_1ant
-backup_arfr_cnt1	hal/btc/HalBtc8812a1Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8812a_1ant
-backup_arfr_cnt1	hal/btc/HalBtc8812a2Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8812a_2ant
-backup_arfr_cnt1	hal/btc/HalBtc8821a1Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8821a_1ant
-backup_arfr_cnt1	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		backup_arfr_cnt1;$/;"	m	struct:coex_dm_8821a_csr_2ant
-backup_arfr_cnt1	hal/btc/HalBtc8822b1Ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8822b_1ant
-backup_arfr_cnt1	hal/btc/halbtc8723d1ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8723d_1ant
-backup_arfr_cnt1	hal/btc/halbtc8821c1ant.h	/^	u32		backup_arfr_cnt1;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8821c_1ant
-backup_arfr_cnt2	hal/btc/HalBtc8192e1Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8192e_1ant
-backup_arfr_cnt2	hal/btc/HalBtc8192e2Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8192e_2ant
-backup_arfr_cnt2	hal/btc/HalBtc8703b1Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8703b_1ant
-backup_arfr_cnt2	hal/btc/HalBtc8723b1Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8723b_1ant
-backup_arfr_cnt2	hal/btc/HalBtc8812a1Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8812a_1ant
-backup_arfr_cnt2	hal/btc/HalBtc8812a2Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8812a_2ant
-backup_arfr_cnt2	hal/btc/HalBtc8821a1Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8821a_1ant
-backup_arfr_cnt2	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		backup_arfr_cnt2;$/;"	m	struct:coex_dm_8821a_csr_2ant
-backup_arfr_cnt2	hal/btc/HalBtc8822b1Ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8822b_1ant
-backup_arfr_cnt2	hal/btc/halbtc8723d1ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8723d_1ant
-backup_arfr_cnt2	hal/btc/halbtc8821c1ant.h	/^	u32		backup_arfr_cnt2;	\/* Auto Rate Fallback Retry cnt *\/$/;"	m	struct:coex_dm_8821c_1ant
-backup_retry_limit	hal/btc/HalBtc8192e1Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8192e_1ant
-backup_retry_limit	hal/btc/HalBtc8192e2Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8192e_2ant
-backup_retry_limit	hal/btc/HalBtc8703b1Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8703b_1ant
-backup_retry_limit	hal/btc/HalBtc8723b1Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8723b_1ant
-backup_retry_limit	hal/btc/HalBtc8812a1Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8812a_1ant
-backup_retry_limit	hal/btc/HalBtc8812a2Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8812a_2ant
-backup_retry_limit	hal/btc/HalBtc8821a1Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8821a_1ant
-backup_retry_limit	hal/btc/HalBtc8821aCsr2Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8821a_csr_2ant
-backup_retry_limit	hal/btc/HalBtc8822b1Ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8822b_1ant
-backup_retry_limit	hal/btc/halbtc8723d1ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8723d_1ant
-backup_retry_limit	hal/btc/halbtc8821c1ant.h	/^	u16		backup_retry_limit;$/;"	m	struct:coex_dm_8821c_1ant
-band	hal/phydm/phydm_hwconfig.h	/^	u1Byte		band: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-band	hal/phydm/phydm_hwconfig.h	/^	u1Byte		band: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-band	hal/phydm/phydm_hwconfig.h	/^	u1Byte		band;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-band_cap	include/hal_data.h	/^	u8 band_cap;	\/* value of BAND_CAP_XXX *\/$/;"	m	struct:hal_spec_t
-band_str	include/rtw_rf.h	156;"	d
-band_to_band_cap	include/rtw_rf.h	159;"	d
-bandroid_scan	os_dep/linux/ioctl_cfg80211.h	/^	u8 bandroid_scan;$/;"	m	struct:rtw_wdev_priv
-bandskip	include/drv_types.h	/^	ATOMIC_T bandskip;$/;"	m	struct:_ADAPTER
-bandwidth	include/rtw_mp.h	/^	u8 bandwidth;$/;"	m	struct:mp_priv
-bar_rty_th	include/rtl8188e_xmit.h	/^	u32 bar_rty_th:2;$/;"	m	struct:txdesc_88e
-bar_rty_th	include/rtl8192e_xmit.h	/^	u32 bar_rty_th:2;$/;"	m	struct:txdescriptor_8192e
-bar_rty_th	include/rtl8812a_xmit.h	/^	u32 bar_rty_th:2;$/;"	m	struct:txdescriptor_8812
-bar_rty_th	include/rtl8821a_xmit.h	/^	u32 bar_rty_th:2;$/;"	m	struct:txdescriptor_8821a
-base	include/HalPwrSeqCmd.h	/^	u8 base:4;$/;"	m	struct:_WL_PWR_CFG_
-base	include/hal_com_phycfg.h	/^	u8 base;$/;"	m	struct:txpwr_idx_comp
-basic_set	include/wifi.h	/^	unsigned char		basic_set[16];$/;"	m	struct:ieee80211_ht_addt_info
-basicrate	include/rtw_mlme_ext.h	/^	unsigned char	basicrate[NumRates];$/;"	m	struct:mlme_ext_priv
-basicrates	include/rtw_cmd.h	/^	u8	basicrates[NumRates];$/;"	m	struct:setbasicrate_parm
-basicrates	include/rtw_cmd.h	/^	u8 basicrates[NumRates];$/;"	m	struct:getbasicrate_rsp
-bassn	include/rtl8188e_recv.h	/^	u32 bassn:12;$/;"	m	struct:rxreport_8188e
-bautoload_fail_flag	include/hal_data.h	/^	u8	bautoload_fail_flag;$/;"	m	struct:hal_com_data
-bavld	include/rtl8188e_recv.h	/^	u32 bavld:1;$/;"	m	struct:rxreport_8188e
-bb_agc_tab	include/hal_data.h	/^	char *bb_agc_tab;$/;"	m	struct:hal_com_data
-bb_agc_tab_len	include/hal_data.h	/^	u32	bb_agc_tab_len;$/;"	m	struct:hal_com_data
-bb_gain	include/hal_data.h	/^	s8 bb_gain[BB_GAIN_NUM][RF_PATH_MAX];$/;"	m	struct:kfree_data_t
-bb_phy_reg	include/hal_data.h	/^	char *bb_phy_reg;$/;"	m	struct:hal_com_data
-bb_phy_reg_len	include/hal_data.h	/^	u32	bb_phy_reg_len;$/;"	m	struct:hal_com_data
-bb_phy_reg_mp	include/hal_data.h	/^	char *bb_phy_reg_mp;$/;"	m	struct:hal_com_data
-bb_phy_reg_mp_len	include/hal_data.h	/^	u32	bb_phy_reg_mp_len;$/;"	m	struct:hal_com_data
-bb_phy_reg_pg	include/hal_data.h	/^	char *bb_phy_reg_pg;$/;"	m	struct:hal_com_data
-bb_phy_reg_pg_len	include/hal_data.h	/^	u32	bb_phy_reg_pg_len;$/;"	m	struct:hal_com_data
-bb_power	hal/phydm/phydm_hwconfig.h	/^	u1Byte		bb_power:6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-bb_reg_dump	core/rtw_debug.c	/^void bb_reg_dump(void *sel, _adapter *adapter)$/;"	f
-bb_reg_param	include/rtw_mp.h	/^struct bb_reg_param {$/;"	s
-bbreg_param	include/rtw_mp_ioctl.h	/^struct bbreg_param {$/;"	s
-bc	include/rtl8188e_recv.h	/^	u32 bc:1;$/;"	m	struct:rxreport_8188e
-bcheck_grpkey	include/rtw_security.h	/^	u8	bcheck_grpkey;$/;"	m	struct:security_priv
-bcn_ant_mode	include/rtw_pwrctrl.h	/^	u8	bcn_ant_mode;$/;"	m	struct:pwrctrl_priv
-bcn_channel	include/rtw_mlme.h	/^	u8 bcn_channel;$/;"	m	struct:beacon_keys
-bcn_cnt	include/rtw_mlme_ext.h	/^	u32 bcn_cnt;$/;"	m	struct:mlme_ext_priv
-bcn_delay_cnt	include/rtw_mlme_ext.h	/^	u32 bcn_delay_cnt[9];$/;"	m	struct:mlme_ext_priv
-bcn_delay_ratio	include/rtw_mlme_ext.h	/^	u32 bcn_delay_ratio[9];$/;"	m	struct:mlme_ext_priv
-bcn_ie	include/ieee80211.h	/^		} bcn_ie;$/;"	m	union:ieee_param::__anon73	typeref:struct:ieee_param::__anon73::__anon79
-bcn_interval	include/rtw_mlme_ext.h	/^	u16	bcn_interval;$/;"	m	struct:mlme_ext_info
-bcn_qinfo_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^struct bcn_qinfo_8723d {$/;"	s	file:
-bcn_update_lock	include/rtw_mlme.h	/^	_lock	bcn_update_lock;$/;"	m	struct:mlme_priv
-bcnderr	include/drv_types.h	/^	u32 bcnderr;$/;"	m	struct:int_logs
-bcndma	include/drv_types.h	/^	u32 bcndma;$/;"	m	struct:int_logs
-bcndma_e	include/drv_types.h	/^	u32 bcndma_e;$/;"	m	struct:int_logs
-bcnerrcnt	include/rtw_cmd.h	/^	unsigned long bcnerrcnt;$/;"	m	struct:getbcnerrcnt_rsp
-bcnokcnt	include/rtw_cmd.h	/^	unsigned long  bcnokcnt;$/;"	m	struct:getbcnokcnt_rsp
-bcompleted	include/rtw_mp.h	/^	u32 bcompleted;$/;"	m	struct:mp_wiparam
-bcrc32initialized	core/rtw_security.c	/^static sint bcrc32initialized = 0;$/;"	v	file:
-bdCap	include/rtw_btcoex.h	/^	u2Byte						bdCap;			\/* capability information *\/$/;"	m	struct:_HCI_PHY_LINK_BSS_INFO
-bdc_holdstate	hal/phydm/phydm.h	/^	u1Byte			bdc_holdstate;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bdecrypted	include/rtw_recv.h	/^	u8	bdecrypted;$/;"	m	struct:rx_pkt_attrib
-bdma64	include/drv_types.h	/^	u8	bdma64;$/;"	m	struct:dvobj_priv
-bdontenterLPS	hal/btc/HalBtcOutSrc.h	/^	BOOLEAN					bdontenterLPS;$/;"	m	struct:btc_coexist
-be16_to_cpu	include/byteorder/generic.h	117;"	d
-be16_to_cpup	include/byteorder/generic.h	129;"	d
-be16_to_cpus	include/byteorder/generic.h	141;"	d
-be32_to_cpu	include/byteorder/generic.h	115;"	d
-be32_to_cpup	include/byteorder/generic.h	127;"	d
-be32_to_cpus	include/byteorder/generic.h	139;"	d
-be64_to_cpu	include/byteorder/generic.h	113;"	d
-be64_to_cpup	include/byteorder/generic.h	125;"	d
-be64_to_cpus	include/byteorder/generic.h	137;"	d
-be_pending	include/rtw_xmit.h	/^	_queue	be_pending;$/;"	m	struct:xmit_priv
-be_q	include/rtw_xmit.h	/^	struct tx_servq	be_q;			\/* priority == 0,3 *\/$/;"	m	struct:sta_xmit_priv	typeref:struct:sta_xmit_priv::tx_servq
-beacon	include/ieee80211_ext.h	/^		}  __attribute__((packed)) beacon;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon15
-beaconDMAing	include/rtw_xmit.h	/^	u8 	beaconDMAing;		\/* flag of indicating beacon is transmiting to HW by DMA *\/$/;"	m	struct:xmit_priv
-beacon_counter	hal/phydm/phydm_antdiv.h	/^	u4Byte	beacon_counter;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-beacon_int	include/ieee80211_ext.h	/^			u16 beacon_int;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon15
-beacon_int	include/ieee80211_ext.h	/^			u16 beacon_int;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon17
-beacon_interval	include/ieee80211.h	/^	u16 beacon_interval;$/;"	m	struct:ieee80211_probe_response
-beacon_keys	include/rtw_mlme.h	/^struct beacon_keys {$/;"	s
-beacon_timing_control	core/rtw_wlan_util.c	/^void beacon_timing_control(_adapter *padapter)$/;"	f
-beam_patten_num_each_ant	hal/phydm/phydm_antdiv.h	/^	u4Byte	beam_patten_num_each_ant;\/*number of  beam can be switched in each antenna*\/$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-beam_train_cnt	hal/phydm/phydm_antdiv.h	/^	u1Byte	beam_train_cnt[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-beam_train_rssi_diff	hal/phydm/phydm_antdiv.h	/^	u1Byte	beam_train_rssi_diff[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-beamfomring_bSounding	core/rtw_beamforming.c	/^BOOLEAN	beamfomring_bSounding(struct beamforming_info *pBeamInfo)$/;"	f
-beamform_cap	include/drv_types.h	/^	u8	beamform_cap;$/;"	m	struct:registry_priv
-beamform_cap	include/rtw_ht.h	/^	u8	beamform_cap;$/;"	m	struct:ht_priv
-beamform_cap	include/rtw_vht.h	/^	u16	beamform_cap;$/;"	m	struct:vht_priv
-beamformed	hal/phydm/phydm_hwconfig.h	/^	u1Byte		beamformed: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-beamformed	hal/phydm/phydm_hwconfig.h	/^	u1Byte		beamformed: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-beamformee_entry	include/rtw_beamforming.h	/^struct beamformee_entry {$/;"	s
-beamformee_mu_cnt	hal/phydm/phydm_beamforming.h	/^	u1Byte					beamformee_mu_cnt;$/;"	m	struct:_RT_BEAMFORMING_INFO
-beamformee_mu_cnt	include/rtw_beamforming.h	/^	u8			beamformee_mu_cnt;$/;"	m	struct:beamforming_info
-beamformee_mu_reg_maping	hal/phydm/phydm_beamforming.h	/^	u4Byte					beamformee_mu_reg_maping;$/;"	m	struct:_RT_BEAMFORMING_INFO
-beamformee_mu_reg_maping	include/rtw_beamforming.h	/^	u32			beamformee_mu_reg_maping;$/;"	m	struct:beamforming_info
-beamformee_rf_num	include/drv_types.h	/^	u8	beamformee_rf_num;$/;"	m	struct:registry_priv
-beamformee_su_cnt	hal/phydm/phydm_beamforming.h	/^	u1Byte					beamformee_su_cnt;$/;"	m	struct:_RT_BEAMFORMING_INFO
-beamformee_su_cnt	include/rtw_beamforming.h	/^	u8			beamformee_su_cnt;$/;"	m	struct:beamforming_info
-beamformee_su_reg_maping	hal/phydm/phydm_beamforming.h	/^	u4Byte					beamformee_su_reg_maping;$/;"	m	struct:_RT_BEAMFORMING_INFO
-beamformee_su_reg_maping	include/rtw_beamforming.h	/^	u32			beamformee_su_reg_maping;$/;"	m	struct:beamforming_info
-beamformer_entry	include/rtw_beamforming.h	/^struct beamformer_entry {$/;"	s
-beamformer_mu_cnt	hal/phydm/phydm_beamforming.h	/^	u1Byte					beamformer_mu_cnt;$/;"	m	struct:_RT_BEAMFORMING_INFO
-beamformer_mu_cnt	include/rtw_beamforming.h	/^	u8			beamformer_mu_cnt;$/;"	m	struct:beamforming_info
-beamformer_rf_num	include/drv_types.h	/^	u8	beamformer_rf_num;$/;"	m	struct:registry_priv
-beamformer_su_cnt	hal/phydm/phydm_beamforming.h	/^	u1Byte					beamformer_su_cnt;$/;"	m	struct:_RT_BEAMFORMING_INFO
-beamformer_su_cnt	include/rtw_beamforming.h	/^	u8			beamformer_su_cnt;$/;"	m	struct:beamforming_info
-beamformer_su_reg_maping	hal/phydm/phydm_beamforming.h	/^	u4Byte					beamformer_su_reg_maping;$/;"	m	struct:_RT_BEAMFORMING_INFO
-beamformer_su_reg_maping	include/rtw_beamforming.h	/^	u32			beamformer_su_reg_maping;$/;"	m	struct:beamforming_info
-beamforming_add_entry	core/rtw_beamforming.c	/^struct beamforming_entry	*beamforming_add_entry(PADAPTER adapter, u8 *ra, u16 aid,$/;"	f
-beamforming_cap	include/rtw_beamforming.h	/^	BEAMFORMING_CAP		beamforming_cap;$/;"	m	struct:beamforming_info
-beamforming_check_sounding_success	core/rtw_beamforming.c	/^void	beamforming_check_sounding_success(PADAPTER Adapter, BOOLEAN status)$/;"	f
-beamforming_cur_idx	include/rtw_beamforming.h	/^	u8						beamforming_cur_idx;$/;"	m	struct:beamforming_info
-beamforming_deinit_entry	core/rtw_beamforming.c	/^void	beamforming_deinit_entry(PADAPTER adapter, u8 *ra)$/;"	f
-beamforming_dym_ndpa_rate	core/rtw_beamforming.c	/^void	beamforming_dym_ndpa_rate(PADAPTER adapter)$/;"	f
-beamforming_dym_period	core/rtw_beamforming.c	/^void beamforming_dym_period(PADAPTER Adapter)$/;"	f
-beamforming_end_fw	core/rtw_beamforming.c	/^void	beamforming_end_fw(PADAPTER adapter)$/;"	f
-beamforming_end_period	core/rtw_beamforming.c	/^void	beamforming_end_period(PADAPTER adapter)$/;"	f
-beamforming_enter	core/rtw_beamforming.c	/^void	beamforming_enter(PADAPTER adapter, PVOID psta)$/;"	f
-beamforming_enter	core/rtw_beamforming.c	/^void beamforming_enter(PADAPTER adapter, void *sta)$/;"	f
-beamforming_entry	include/rtw_beamforming.h	/^	struct beamforming_entry	beamforming_entry[BEAMFORMING_ENTRY_NUM];$/;"	m	struct:beamforming_info	typeref:struct:beamforming_info::beamforming_entry
-beamforming_entry	include/rtw_beamforming.h	/^struct beamforming_entry {$/;"	s
-beamforming_entry_cap	include/rtw_beamforming.h	/^	BEAMFORMING_CAP	beamforming_entry_cap;$/;"	m	struct:beamforming_entry
-beamforming_entry_state	include/rtw_beamforming.h	/^	BEAMFORMING_ENTRY_STATE	beamforming_entry_state;$/;"	m	struct:beamforming_entry
-beamforming_get_beamform_cap	core/rtw_beamforming.c	/^BEAMFORMING_CAP beamforming_get_beamform_cap(struct beamforming_info	*pBeamInfo)$/;"	f
-beamforming_get_bfee_entry_by_addr	core/rtw_beamforming.c	/^struct beamformee_entry *beamforming_get_bfee_entry_by_addr(PADAPTER adapter, u8 *ra)$/;"	f
-beamforming_get_bfer_entry_by_addr	core/rtw_beamforming.c	/^struct beamformer_entry *beamforming_get_bfer_entry_by_addr(PADAPTER adapter, u8 *ra)$/;"	f
-beamforming_get_entry_beam_cap_by_mac_id	core/rtw_beamforming.c	/^BEAMFORMING_CAP beamforming_get_entry_beam_cap_by_mac_id(PVOID pmlmepriv , u8 mac_id)$/;"	f
-beamforming_get_entry_beam_cap_by_mac_id	core/rtw_beamforming.c	/^BEAMFORMING_CAP beamforming_get_entry_beam_cap_by_mac_id(void *mlme, u8 mac_id)$/;"	f
-beamforming_get_entry_by_addr	core/rtw_beamforming.c	/^struct beamforming_entry	*beamforming_get_entry_by_addr(struct mlme_priv *pmlmepriv, u8 *ra, u8 *idx)$/;"	f
-beamforming_get_free_entry	core/rtw_beamforming.c	/^struct beamforming_entry	*beamforming_get_free_entry(struct mlme_priv *pmlmepriv, u8 *idx)$/;"	f
-beamforming_get_ndpa_frame	core/rtw_beamforming.c	/^void	beamforming_get_ndpa_frame(PADAPTER	 Adapter, union recv_frame *precv_frame)$/;"	f
-beamforming_get_report_frame	core/rtw_beamforming.c	/^u32	beamforming_get_report_frame(PADAPTER	 Adapter, union recv_frame *precv_frame)$/;"	f
-beamforming_get_vht_gid_mgnt_frame	core/rtw_beamforming.c	/^u32 beamforming_get_vht_gid_mgnt_frame(PADAPTER adapter, union recv_frame *precv_frame)$/;"	f
-beamforming_in_progress	include/rtw_beamforming.h	/^	u8						beamforming_in_progress;$/;"	m	struct:beamforming_info
-beamforming_info	include/hal_data.h	/^	struct beamforming_info beamforming_info;$/;"	m	struct:hal_com_data	typeref:struct:hal_com_data::beamforming_info
-beamforming_info	include/rtw_beamforming.h	/^struct beamforming_info {$/;"	s
-beamforming_info	include/rtw_mlme.h	/^	struct beamforming_info	beamforming_info;$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::beamforming_info
-beamforming_init_entry	core/rtw_beamforming.c	/^BOOLEAN	beamforming_init_entry(PADAPTER	adapter, struct sta_info *psta, u8 *idx)$/;"	f
-beamforming_leave	core/rtw_beamforming.c	/^void	beamforming_leave(PADAPTER adapter, u8 *ra)$/;"	f
-beamforming_leave	core/rtw_beamforming.c	/^void beamforming_leave(PADAPTER adapter, u8 *ra)$/;"	f
-beamforming_notify	core/rtw_beamforming.c	/^void	beamforming_notify(PADAPTER adapter)$/;"	f
-beamforming_remove_entry	core/rtw_beamforming.c	/^BOOLEAN	beamforming_remove_entry(struct mlme_priv *pmlmepriv, u8 *ra, u8 *idx)$/;"	f
-beamforming_reset	core/rtw_beamforming.c	/^void	beamforming_reset(PADAPTER adapter)$/;"	f
-beamforming_select_beam_entry	core/rtw_beamforming.c	/^BOOLEAN	beamforming_select_beam_entry(struct beamforming_info *pBeamInfo)$/;"	f
-beamforming_send_ht_ndpa_packet	core/rtw_beamforming.c	/^BOOLEAN	beamforming_send_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, CHANNEL_WIDTH bw, u8 qidx)$/;"	f
-beamforming_send_vht_gid_mgnt_packet	core/rtw_beamforming.c	/^u8 beamforming_send_vht_gid_mgnt_packet(PADAPTER adapter, struct beamformee_entry *entry)$/;"	f
-beamforming_send_vht_ndpa_packet	core/rtw_beamforming.c	/^BOOLEAN	beamforming_send_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, CHANNEL_WIDTH bw, u8 qidx)$/;"	f
-beamforming_sounding_bw	core/rtw_beamforming.c	/^CHANNEL_WIDTH	beamforming_sounding_bw(struct beamforming_info *pBeamInfo, SOUNDING_MODE mode, u8 idx)$/;"	f
-beamforming_sounding_fail	core/rtw_beamforming.c	/^void beamforming_sounding_fail(PADAPTER Adapter)$/;"	f
-beamforming_sounding_fail	core/rtw_beamforming.c	/^void beamforming_sounding_fail(PADAPTER adapter)$/;"	f
-beamforming_sounding_idx	core/rtw_beamforming.c	/^u8	beamforming_sounding_idx(struct beamforming_info *pBeamInfo)$/;"	f
-beamforming_sounding_mode	core/rtw_beamforming.c	/^SOUNDING_MODE	beamforming_sounding_mode(struct beamforming_info *pBeamInfo, u8 idx)$/;"	f
-beamforming_sounding_time	core/rtw_beamforming.c	/^u16	beamforming_sounding_time(struct beamforming_info *pBeamInfo, SOUNDING_MODE mode, u8 idx)$/;"	f
-beamforming_start_fw	core/rtw_beamforming.c	/^BOOLEAN	beamforming_start_fw(PADAPTER adapter, u8 idx)$/;"	f
-beamforming_start_period	core/rtw_beamforming.c	/^BOOLEAN	beamforming_start_period(PADAPTER adapter)$/;"	f
-beamforming_state	include/rtw_beamforming.h	/^	BEAMFORMING_STATE		beamforming_state;$/;"	m	struct:beamforming_info
-beamforming_state	include/rtw_beamforming.h	/^	BEAMFORMING_STATE	beamforming_state;$/;"	m	struct:beamforming_info
-beamforming_watchdog	core/rtw_beamforming.c	/^void	beamforming_watchdog(PADAPTER Adapter)$/;"	f
-beamforming_watchdog	core/rtw_beamforming.c	/^void beamforming_watchdog(PADAPTER adapter)$/;"	f
-beamforming_wk_cmd	core/rtw_beamforming.c	/^u8	beamforming_wk_cmd(_adapter *padapter, s32 type, u8 *pbuf, s32 size, u8 enqueue)$/;"	f
-beamforming_wk_hdl	core/rtw_beamforming.c	/^void	beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf)$/;"	f
-bedok	include/drv_types.h	/^	u32 bedok;$/;"	m	struct:int_logs
-benable	include/rtw_mlme.h	/^	u8					benable;					\/*	This negoitation request frame is trigger to send or not *\/$/;"	m	struct:tx_nego_req_info
-benable	include/rtw_mlme.h	/^	u8					benable;					\/*	This provision discovery request frame is trigger to send or not *\/$/;"	m	struct:tx_provdisc_req_info
-benable	include/rtw_mlme.h	/^	u8					benable;$/;"	m	struct:tx_invite_req_info
-beq_cnt	include/rtw_xmit.h	/^	int beq_cnt;$/;"	m	struct:xmit_priv
-bfee_entry	include/rtw_beamforming.h	/^	struct beamformee_entry	bfee_entry[MAX_BEAMFORMEE_ENTRY_NUM];$/;"	m	struct:beamforming_info	typeref:struct:beamforming_info::beamformee_entry
-bfer_entry	include/rtw_beamforming.h	/^	struct beamformer_entry	bfer_entry[MAX_BEAMFORMER_ENTRY_NUM];$/;"	m	struct:beamforming_info	typeref:struct:beamforming_info::beamformer_entry
-bgrpkey_handshake	include/rtw_security.h	/^	u8	bgrpkey_handshake;$/;"	m	struct:security_priv
-bigJumpLmt	hal/phydm/phydm_dig.h	/^	u1Byte		bigJumpLmt[16];$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bigJumpStep1	hal/phydm/phydm_dig.h	/^	u1Byte		bigJumpStep1:3;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bigJumpStep2	hal/phydm/phydm_dig.h	/^	u1Byte		bigJumpStep2:2;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-bigJumpStep3	hal/phydm/phydm_dig.h	/^	u1Byte		bigJumpStep3:2;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-binstallBIPkey	include/rtw_security.h	/^	u8	binstallBIPkey;$/;"	m	struct:security_priv
-binstallGrpkey	include/rtw_security.h	/^	u8	binstallGrpkey;$/;"	m	struct:security_priv
-binstallKCK_KEK	include/rtw_security.h	/^	u8	binstallKCK_KEK;$/;"	m	struct:security_priv
-bio_irp_pending	include/osdep_intf.h	/^	u8 bio_irp_pending;$/;"	m	struct:intf_priv
-bio_irp_timeout	include/osdep_intf.h	/^	u8 bio_irp_timeout;$/;"	m	struct:intf_priv
-bio_timer_cancel	include/osdep_intf.h	/^	u8 bio_timer_cancel;$/;"	m	struct:intf_priv
-bips_processing	include/rtw_pwrctrl.h	/^	uint bips_processing;$/;"	m	struct:pwrctrl_priv
-bitmap	include/drv_types.h	/^	u8 bitmap;$/;"	m	struct:mbid_cam_ctl_t
-bitshift	include/osdep_service.h	/^__inline static u32 bitshift(u32 bitmask)$/;"	f
-bitwise_xor	core/rtw_security.c	/^static void bitwise_xor(u8 *ina, u8 *inb, u8 *out)$/;"	f	file:
-bk	include/rtl8188e_xmit.h	/^	u32 bk:1;$/;"	m	struct:txdesc_88e
-bk	include/rtl8192e_xmit.h	/^	u32 bk:1;$/;"	m	struct:txdescriptor_8192e
-bk	include/rtl8812a_xmit.h	/^	u32 bk:1;$/;"	m	struct:txdescriptor_8812
-bk	include/rtl8821a_xmit.h	/^	u32 bk:1;$/;"	m	struct:txdescriptor_8821a
-bk_pending	include/rtw_xmit.h	/^	_queue	bk_pending;$/;"	m	struct:xmit_priv
-bk_q	include/rtw_xmit.h	/^	struct tx_servq	bk_q;			\/* priority == 1,2 *\/$/;"	m	struct:sta_xmit_priv	typeref:struct:sta_xmit_priv::tx_servq
-bkdok	include/drv_types.h	/^	u32 bkdok;$/;"	m	struct:int_logs
-bkeepfwalive	include/rtw_pwrctrl.h	/^	u8		bkeepfwalive;$/;"	m	struct:pwrctrl_priv
-bkid	include/rtw_wapi.h	/^	u8				bkid[16];$/;"	m	struct:_RT_WAPI_BKID
-bkq_cnt	include/rtw_xmit.h	/^	int bkq_cnt;$/;"	m	struct:xmit_priv
-bldpc	include/rtw_mp.h	/^	BOOLEAN			bldpc;$/;"	m	struct:_MPT_CONTEXT
-bloadefusemap	include/rtw_mp.h	/^	BOOLEAN bloadefusemap;$/;"	m	struct:mp_priv
-block	os_dep/linux/ioctl_cfg80211.h	/^	bool block;$/;"	m	struct:rtw_wdev_priv
-block_scan	os_dep/linux/ioctl_cfg80211.h	/^	bool block_scan;$/;"	m	struct:rtw_wdev_priv
-block_size	core/rtw_security.c	2211;"	d	file:
-block_transfer_len	include/drv_types_gspi.h	/^	u32 block_transfer_len;$/;"	m	struct:gspi_data
-block_transfer_len	include/drv_types_sdio.h	/^	u32 block_transfer_len;$/;"	m	struct:sdio_data
-bloopback	include/rtw_mp.h	/^	BOOLEAN bloopback;$/;"	m	struct:mp_priv
-blpspg_info_up	include/rtw_pwrctrl.h	/^	u8 blpspg_info_up;$/;"	m	struct:pwrctrl_priv
-bm_pending	include/rtw_xmit.h	/^	_queue	bm_pending;$/;"	m	struct:xmit_priv
-bmac_filter	include/rtw_mp.h	/^	u8 bmac_filter;$/;"	m	struct:mp_priv
-bmax_en_pwdB	include/Hal8188EPhyReg.h	937;"	d
-bmax_en_pwdB	include/Hal8188FPhyReg.h	945;"	d
-bmax_en_pwdB	include/Hal8192EPhyReg.h	948;"	d
-bmax_en_pwdB	include/Hal8703BPhyReg.h	974;"	d
-bmax_en_pwdB	include/Hal8723BPhyReg.h	972;"	d
-bmax_en_pwdB	include/Hal8723DPhyReg.h	975;"	d
-bmax_en_pwdB	include/rtw_mp_phy_regdef.h	891;"	d
-bmc	include/drv_types.h	/^	struct macid_bmp bmc;$/;"	m	struct:macid_ctl_t	typeref:struct:macid_ctl_t::macid_bmp
-bmc	include/rtl8188e_xmit.h	/^	u32 bmc:1;$/;"	m	struct:txdesc_88e
-bmc	include/rtl8188e_xmit.h	/^	u8 bmc:1;$/;"	m	struct:txrpt_ccx_88e
-bmc	include/rtl8192e_xmit.h	/^	u32 bmc:1;$/;"	m	struct:txdescriptor_8192e
-bmc	include/rtl8192e_xmit.h	/^	u8 bmc:1;$/;"	m	struct:txrpt_ccx_92e
-bmc	include/rtl8812a_xmit.h	/^	u32 bmc:1;$/;"	m	struct:txdescriptor_8812
-bmc	include/rtl8814a_xmit.h	/^	u32 bmc:1;$/;"	m	struct:txdescriptor_8814
-bmc	include/rtl8821a_xmit.h	/^	u32 bmc:1;$/;"	m	struct:txdescriptor_8821a
-bmc_camid	include/rtw_xmit.h	/^	u8	bmc_camid;$/;"	m	struct:pkt_attrib
-bmp_wi_progress	include/rtw_mp.h	/^	u8 bmp_wi_progress;$/;"	m	struct:mp_wi_cntx
-bmpdrv_unload	include/rtw_mp.h	/^	u8 bmpdrv_unload;$/;"	m	struct:mp_wi_cntx
-bnoise_pwdB	include/Hal8188EPhyReg.h	939;"	d
-bnoise_pwdB	include/Hal8188FPhyReg.h	947;"	d
-bnoise_pwdB	include/Hal8192EPhyReg.h	950;"	d
-bnoise_pwdB	include/Hal8703BPhyReg.h	976;"	d
-bnoise_pwdB	include/Hal8723BPhyReg.h	974;"	d
-bnoise_pwdB	include/Hal8723DPhyReg.h	977;"	d
-bnoise_pwdB	include/rtw_mp_phy_regdef.h	893;"	d
-boardType	hal/hal_dm.c	/^ODM_BOARD_TYPE_E boardType(u8 InterfaceSel)$/;"	f
-board_info	hal/btc/HalBtcOutSrc.h	/^	struct  btc_board_info		board_info;$/;"	m	struct:btc_coexist	typeref:struct:btc_coexist::btc_board_info
-boffefusemask	include/drv_types.h	/^	u8 boffefusemask;$/;"	m	struct:registry_priv
-bool	include/basic_types.h	/^		typedef _Bool bool;$/;"	t
-boolean	include/basic_types.h	/^typedef unsigned char	BOOLEAN, *PBOOLEAN, boolean;$/;"	t
-bpairwise_key_installed	include/sta_info.h	/^	u8 bpairwise_key_installed;$/;"	m	struct:sta_info
-bpending	include/rtw_mp.h	/^	u8 bpending[8];$/;"	m	struct:mp_xmit_frame
-bpending	include/rtw_xmit.h	/^	u8 bpending[8];$/;"	m	struct:xmit_buf
-bpower_saving	include/rtw_pwrctrl.h	/^	u8	bpower_saving; \/* for LPS\/IPS *\/$/;"	m	struct:pwrctrl_priv
-br_ext_info	include/rtw_br_ext.h	/^struct br_ext_info {$/;"	s
-br_ext_lock	include/drv_types.h	/^	_lock					br_ext_lock;$/;"	m	struct:_ADAPTER
-br_ip	include/drv_types.h	/^	unsigned char			br_ip[4];$/;"	m	struct:_ADAPTER
-br_mac	include/drv_types.h	/^	unsigned char			br_mac[MACADDRLEN];$/;"	m	struct:_ADAPTER
-brfoffbyhw	include/rtw_pwrctrl.h	/^	u8		brfoffbyhw;$/;"	m	struct:pwrctrl_priv
-broadcomAP	include/rtw_mlme_ext.h	/^	broadcomAP	= 1,$/;"	e	enum:Associated_AP
-brpwmtimeout	include/rtw_pwrctrl.h	/^	u8 brpwmtimeout;$/;"	m	struct:pwrctrl_priv
-bsend_rssi	include/sta_info.h	/^	u8	bsend_rssi;$/;"	m	struct:_RSSI_STA
-bss	include/rtw_event.h	/^	WLAN_BSSID_EX bss;$/;"	m	struct:survey_event
-bssDesc	include/rtw_btcoex.h	/^	HCI_PHY_LINK_BSS_INFO	bssDesc;$/;"	m	struct:_BT_MGNT
-bss_cap_update_on_sta_join	core/rtw_ap.c	/^void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta)$/;"	f
-bss_cap_update_on_sta_leave	core/rtw_ap.c	/^u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta)$/;"	f
-bss_cnt	include/rtw_event.h	/^	unsigned int	bss_cnt;$/;"	m	struct:surveydone_event
-bss_cnt	include/rtw_mlme_ext.h	/^	int	bss_cnt;$/;"	m	struct:ss_res
-bss_coexist	include/rtw_ht.h	/^	u8	bss_coexist;\/* for 20\/40 Bss coexist *\/$/;"	m	struct:ht_priv
-bssid	include/ieee80211_ext.h	/^	u8 bssid[6];$/;"	m	struct:ieee80211_mgmt
-bssid	include/rtw_recv.h	/^	u8	bssid[ETH_ALEN];$/;"	m	struct:rx_pkt_attrib
-bssid	include/rtw_tdls.h	/^	u8 bssid[ETH_ALEN];$/;"	m	struct:wpa_tdls_lnkid
-bssidfit	include/rtl8188e_recv.h	/^	u32 bssidfit:2;$/;"	m	struct:rxreport_8188e
-bssratelen	include/sta_info.h	/^	u32	bssratelen;$/;"	m	struct:sta_info
-bssrateset	include/sta_info.h	/^	u8	bssrateset[16];$/;"	m	struct:sta_info
-bsta_state	hal/phydm/phydm.h	/^	BOOLEAN			bsta_state;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-bstart_bss	include/rtw_mlme_ext.h	/^	unsigned char bstart_bss;$/;"	m	struct:mlme_ext_priv
-bstbc	include/rtw_mp.h	/^	BOOLEAN			bstbc;$/;"	m	struct:_MPT_CONTEXT
-bstop	include/drv_types.h	/^	u8 bstop;$/;"	m	struct:loopbackdata
-bswenc	include/rtw_xmit.h	/^	u8	bswenc;$/;"	m	struct:pkt_attrib
-btAntisolation	include/hal_btcoex.h	/^	u8 btAntisolation;$/;"	m	struct:_BT_COEXIST
-btChipType	include/hal_btcoex.h	/^	u8 btChipType;$/;"	m	struct:_BT_COEXIST
-btCoexPwrAdjust	hal/phydm/phydm.h	/^	u1Byte		btCoexPwrAdjust;$/;"	m	struct:_ODM_Phy_Status_Info_
-btCoexPwrAdjust	include/rtw_recv.h	/^	u8			btCoexPwrAdjust;$/;"	m	struct:phy_info
-btHsDigVal	hal/phydm/phydm.h	/^	u1Byte			btHsDigVal;			\/*use BT rssi to decide the DIG value*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-btHsRssi	hal/phydm/phydm.h	/^	u1Byte			btHsRssi;			\/*BT HS mode wifi rssi value.*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-btInBuf	include/rtw_mp.h	/^	u1Byte          btInBuf[100];$/;"	m	struct:_MPT_CONTEXT
-btInfoC2h	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte					btInfoC2h[BT_INFO_SRC_8723A_1ANT_MAX][10];$/;"	m	struct:_COEX_STA_8723A_1ANT
-btInfoC2h	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					btInfoC2h[BT_INFO_SRC_8723A_2ANT_MAX][10];$/;"	m	struct:_COEX_STA_8723A_2ANT
-btInfoC2hCnt	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8723A_1ANT_MAX];$/;"	m	struct:_COEX_STA_8723A_1ANT
-btInfoC2hCnt	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte					btInfoC2hCnt[BT_INFO_SRC_8723A_2ANT_MAX];$/;"	m	struct:_COEX_STA_8723A_2ANT
-btInfoExt	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte					btInfoExt;$/;"	m	struct:_COEX_STA_8723A_1ANT
-btInfoExt	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					btInfoExt;$/;"	m	struct:_COEX_STA_8723A_2ANT
-btLogoTest	include/rtw_btcoex.h	/^	BOOLEAN				btLogoTest;$/;"	m	struct:_BT_MGNT
-btMpCckTxPower	include/rtw_mp.h	/^	u8			btMpCckTxPower;$/;"	m	struct:_MPT_CONTEXT
-btMpOfdmTxPower	include/rtw_mp.h	/^	u8			btMpOfdmTxPower;$/;"	m	struct:_MPT_CONTEXT
-btOperationCode	include/rtw_btcoex.h	/^	u1Byte					btOperationCode;$/;"	m	struct:_HCI_EXT_CONFIG
-btRetryCnt	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte					btRetryCnt;$/;"	m	struct:_COEX_STA_8723A_1ANT
-btRetryCnt	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					btRetryCnt;$/;"	m	struct:_COEX_STA_8723A_2ANT
-btRf0x1eBackup	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		btRf0x1eBackup;$/;"	m	struct:_COEX_DM_8188C_2ANT
-btRf0x1eBackup	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		btRf0x1eBackup;$/;"	m	struct:_COEX_DM_8192D_2ANT
-btRf0x1eBackup	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte		btRf0x1eBackup;$/;"	m	struct:_COEX_DM_8723A_1ANT
-btRf0x1eBackup	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte		btRf0x1eBackup;$/;"	m	struct:_COEX_DM_8723A_2ANT
-btRssi	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte					btRssi;$/;"	m	struct:_COEX_STA_8723A_1ANT
-btRssi	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					btRssi;$/;"	m	struct:_COEX_STA_8723A_2ANT
-btStatus	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		btStatus;$/;"	m	struct:_COEX_DM_8723A_1ANT
-btStatus	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		btStatus;$/;"	m	struct:_COEX_DM_8723A_2ANT
-btTotalAntNum	include/hal_btcoex.h	/^	u8 btTotalAntNum;$/;"	m	struct:_BT_COEXIST
-bt_8192e_1ant_bt_status	hal/btc/HalBtc8192e1Ant.h	/^enum bt_8192e_1ant_bt_status {$/;"	g
-bt_8192e_1ant_coex_algo	hal/btc/HalBtc8192e1Ant.h	/^enum bt_8192e_1ant_coex_algo {$/;"	g
-bt_8192e_1ant_wifi_status	hal/btc/HalBtc8192e1Ant.h	/^enum bt_8192e_1ant_wifi_status {$/;"	g
-bt_8192e_2ant_bt_status	hal/btc/HalBtc8192e2Ant.h	/^enum bt_8192e_2ant_bt_status {$/;"	g
-bt_8192e_2ant_coex_algo	hal/btc/HalBtc8192e2Ant.h	/^enum bt_8192e_2ant_coex_algo {$/;"	g
-bt_8703b_1ant_bt_status	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_bt_status {$/;"	g
-bt_8703b_1ant_coex_algo	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_coex_algo {$/;"	g
-bt_8703b_1ant_gnt_ctrl_block	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_gnt_ctrl_block {$/;"	g
-bt_8703b_1ant_gnt_ctrl_type	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_gnt_ctrl_type {$/;"	g
-bt_8703b_1ant_lte_break_table_type	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_lte_break_table_type {$/;"	g
-bt_8703b_1ant_lte_coex_table_type	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_lte_coex_table_type {$/;"	g
-bt_8703b_1ant_path_ctrl_owner	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_path_ctrl_owner {$/;"	g
-bt_8703b_1ant_signal_state	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_signal_state {$/;"	g
-bt_8703b_1ant_wifi_status	hal/btc/HalBtc8703b1Ant.h	/^enum bt_8703b_1ant_wifi_status {$/;"	g
-bt_8723b_1ant_bt_status	hal/btc/HalBtc8723b1Ant.h	/^enum bt_8723b_1ant_bt_status {$/;"	g
-bt_8723b_1ant_coex_algo	hal/btc/HalBtc8723b1Ant.h	/^enum bt_8723b_1ant_coex_algo {$/;"	g
-bt_8723b_1ant_wifi_status	hal/btc/HalBtc8723b1Ant.h	/^enum bt_8723b_1ant_wifi_status {$/;"	g
-bt_8723b_2ant_bt_status	hal/btc/HalBtc8723b2Ant.h	/^enum bt_8723b_2ant_bt_status {$/;"	g
-bt_8723b_2ant_coex_algo	hal/btc/HalBtc8723b2Ant.h	/^enum bt_8723b_2ant_coex_algo {$/;"	g
-bt_8723d_1ant_Scoreboard	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_Scoreboard {$/;"	g
-bt_8723d_1ant_bt_status	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_bt_status {$/;"	g
-bt_8723d_1ant_coex_algo	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_coex_algo {$/;"	g
-bt_8723d_1ant_gnt_ctrl_block	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_gnt_ctrl_block {$/;"	g
-bt_8723d_1ant_gnt_ctrl_type	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_gnt_ctrl_type {$/;"	g
-bt_8723d_1ant_lte_break_table_type	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_lte_break_table_type {$/;"	g
-bt_8723d_1ant_lte_coex_table_type	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_lte_coex_table_type {$/;"	g
-bt_8723d_1ant_path_ctrl_owner	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_path_ctrl_owner {$/;"	g
-bt_8723d_1ant_phase	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_phase {$/;"	g
-bt_8723d_1ant_signal_state	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_signal_state {$/;"	g
-bt_8723d_1ant_wifi_status	hal/btc/halbtc8723d1ant.h	/^enum bt_8723d_1ant_wifi_status {$/;"	g
-bt_8723d_2ant_Scoreboard	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_Scoreboard {$/;"	g
-bt_8723d_2ant_bt_status	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_bt_status {$/;"	g
-bt_8723d_2ant_coex_algo	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_coex_algo {$/;"	g
-bt_8723d_2ant_gnt_ctrl_block	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_gnt_ctrl_block {$/;"	g
-bt_8723d_2ant_gnt_ctrl_type	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_gnt_ctrl_type {$/;"	g
-bt_8723d_2ant_lte_break_table_type	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_lte_break_table_type {$/;"	g
-bt_8723d_2ant_lte_coex_table_type	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_lte_coex_table_type {$/;"	g
-bt_8723d_2ant_path_ctrl_owner	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_path_ctrl_owner {$/;"	g
-bt_8723d_2ant_phase	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_phase {$/;"	g
-bt_8723d_2ant_signal_state	hal/btc/halbtc8723d2ant.h	/^enum bt_8723d_2ant_signal_state {$/;"	g
-bt_8812a_1ant_bt_status	hal/btc/HalBtc8812a1Ant.h	/^enum bt_8812a_1ant_bt_status {$/;"	g
-bt_8812a_1ant_coex_algo	hal/btc/HalBtc8812a1Ant.h	/^enum bt_8812a_1ant_coex_algo {$/;"	g
-bt_8812a_1ant_wifi_status	hal/btc/HalBtc8812a1Ant.h	/^enum bt_8812a_1ant_wifi_status {$/;"	g
-bt_8812a_2ant_bt_status	hal/btc/HalBtc8812a2Ant.h	/^enum bt_8812a_2ant_bt_status {$/;"	g
-bt_8812a_2ant_coex_algo	hal/btc/HalBtc8812a2Ant.h	/^enum bt_8812a_2ant_coex_algo {$/;"	g
-bt_8821a_1ant_bt_status	hal/btc/HalBtc8821a1Ant.h	/^enum bt_8821a_1ant_bt_status {$/;"	g
-bt_8821a_1ant_coex_algo	hal/btc/HalBtc8821a1Ant.h	/^enum bt_8821a_1ant_coex_algo {$/;"	g
-bt_8821a_1ant_wifi_status	hal/btc/HalBtc8821a1Ant.h	/^enum bt_8821a_1ant_wifi_status {$/;"	g
-bt_8821a_2ant_bt_status	hal/btc/HalBtc8821a2Ant.h	/^enum bt_8821a_2ant_bt_status {$/;"	g
-bt_8821a_2ant_coex_algo	hal/btc/HalBtc8821a2Ant.h	/^enum bt_8821a_2ant_coex_algo {$/;"	g
-bt_8821a_csr_2ant_bt_status	hal/btc/HalBtc8821aCsr2Ant.h	/^enum bt_8821a_csr_2ant_bt_status {$/;"	g
-bt_8821a_csr_2ant_coex_algo	hal/btc/HalBtc8821aCsr2Ant.h	/^enum bt_8821a_csr_2ant_coex_algo {$/;"	g
-bt_8821c_1ant_bt_status	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_bt_status {$/;"	g
-bt_8821c_1ant_coex_algo	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_coex_algo {$/;"	g
-bt_8821c_1ant_ext_ant_switch_ctrl_type	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_ext_ant_switch_ctrl_type {$/;"	g
-bt_8821c_1ant_ext_ant_switch_pos_type	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_ext_ant_switch_pos_type {$/;"	g
-bt_8821c_1ant_ext_ant_switch_type	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_ext_ant_switch_type {$/;"	g
-bt_8821c_1ant_ext_band_switch_pos_type	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_ext_band_switch_pos_type {$/;"	g
-bt_8821c_1ant_gnt_ctrl_block	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_gnt_ctrl_block {$/;"	g
-bt_8821c_1ant_gnt_ctrl_type	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_gnt_ctrl_type {$/;"	g
-bt_8821c_1ant_int_block	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_int_block{$/;"	g
-bt_8821c_1ant_lte_break_table_type	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_lte_break_table_type {$/;"	g
-bt_8821c_1ant_lte_coex_table_type	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_lte_coex_table_type {$/;"	g
-bt_8821c_1ant_path_ctrl_owner	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_path_ctrl_owner {$/;"	g
-bt_8821c_1ant_phase	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_phase{$/;"	g
-bt_8821c_1ant_signal_state	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_signal_state {$/;"	g
-bt_8821c_1ant_wifi_status	hal/btc/halbtc8821c1ant.h	/^enum bt_8821c_1ant_wifi_status {$/;"	g
-bt_8821c_2ant_bt_status	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_bt_status {$/;"	g
-bt_8821c_2ant_coex_algo	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_coex_algo {$/;"	g
-bt_8821c_2ant_ext_ant_switch_ctrl_type	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_ext_ant_switch_ctrl_type {$/;"	g
-bt_8821c_2ant_ext_ant_switch_pos_type	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_ext_ant_switch_pos_type {$/;"	g
-bt_8821c_2ant_ext_band_switch_pos_type	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_ext_band_switch_pos_type {$/;"	g
-bt_8821c_2ant_gnt_ctrl_block	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_gnt_ctrl_block {$/;"	g
-bt_8821c_2ant_gnt_ctrl_type	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_gnt_ctrl_type {$/;"	g
-bt_8821c_2ant_int_block	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_int_block{$/;"	g
-bt_8821c_2ant_lte_break_table_type	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_lte_break_table_type {$/;"	g
-bt_8821c_2ant_lte_coex_table_type	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_lte_coex_table_type {$/;"	g
-bt_8821c_2ant_path_ctrl_owner	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_path_ctrl_owner {$/;"	g
-bt_8821c_2ant_phase	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_phase{$/;"	g
-bt_8821c_2ant_signal_state	hal/btc/halbtc8821c2ant.h	/^enum bt_8821c_2ant_signal_state {$/;"	g
-bt_8822b_1ant_bt_status	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_bt_status {$/;"	g
-bt_8822b_1ant_coex_algo	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_coex_algo {$/;"	g
-bt_8822b_1ant_ext_ant_switch_ctrl_type	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_ext_ant_switch_ctrl_type {$/;"	g
-bt_8822b_1ant_ext_ant_switch_pos_type	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_ext_ant_switch_pos_type {$/;"	g
-bt_8822b_1ant_ext_ant_switch_type	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_ext_ant_switch_type {$/;"	g
-bt_8822b_1ant_gnt_ctrl_block	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_gnt_ctrl_block {$/;"	g
-bt_8822b_1ant_gnt_ctrl_type	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_gnt_ctrl_type {$/;"	g
-bt_8822b_1ant_lte_break_table_type	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_lte_break_table_type {$/;"	g
-bt_8822b_1ant_lte_coex_table_type	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_lte_coex_table_type {$/;"	g
-bt_8822b_1ant_path_ctrl_owner	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_path_ctrl_owner {$/;"	g
-bt_8822b_1ant_phase	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_phase{$/;"	g
-bt_8822b_1ant_signal_state	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_signal_state {$/;"	g
-bt_8822b_1ant_wifi_status	hal/btc/HalBtc8822b1Ant.h	/^enum bt_8822b_1ant_wifi_status {$/;"	g
-bt_RF_ch_LSB	hal/phydm/phydm_hwconfig.h	/^	u1Byte			bt_RF_ch_LSB: 6;						\/*8812A: 6'b0                   8814A: bt rf channel keep[5:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-bt_RF_ch_LSB	hal/phydm/phydm_hwconfig.h	/^	u1Byte			bt_RF_ch_LSB: 6;$/;"	m	struct:_Phy_Status_Rpt_8812
-bt_RF_ch_MSB	hal/phydm/phydm_hwconfig.h	/^	u1Byte			bt_RF_ch_MSB: 2;						\/*8812A:2'b0			8814A: bt rf channel keep[7:6]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-bt_RF_ch_MSB	hal/phydm/phydm_hwconfig.h	/^	u1Byte			bt_RF_ch_MSB: 2;$/;"	m	struct:_Phy_Status_Rpt_8812
-bt_abnormal_scan	hal/btc/HalBtc8723b1Ant.h	/^	boolean					bt_abnormal_scan;$/;"	m	struct:coex_sta_8723b_1ant
-bt_abnormal_scan	hal/btc/HalBtc8723b2Ant.h	/^	boolean					bt_abnormal_scan;$/;"	m	struct:coex_sta_8723b_2ant
-bt_afh_map	hal/btc/halbtc8723d1ant.h	/^	u8					bt_afh_map[10];$/;"	m	struct:coex_sta_8723d_1ant
-bt_afh_map	hal/btc/halbtc8723d2ant.h	/^	u8					bt_afh_map[10];$/;"	m	struct:coex_sta_8723d_2ant
-bt_ampdu	include/drv_types.h	/^	u8	bt_ampdu;$/;"	m	struct:registry_priv
-bt_ble_scan_para	hal/btc/halbtc8723d1ant.h	/^	u32					bt_ble_scan_para[3];$/;"	m	struct:coex_sta_8723d_1ant
-bt_ble_scan_para	hal/btc/halbtc8723d2ant.h	/^	u32					bt_ble_scan_para[3];$/;"	m	struct:coex_sta_8723d_2ant
-bt_ble_scan_type	hal/btc/halbtc8723d1ant.h	/^	u8					bt_ble_scan_type;$/;"	m	struct:coex_sta_8723d_1ant
-bt_ble_scan_type	hal/btc/halbtc8723d2ant.h	/^	u8					bt_ble_scan_type;$/;"	m	struct:coex_sta_8723d_2ant
-bt_busy	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_busy;$/;"	m	struct:btc_bt_info
-bt_chip_type	hal/btc/HalBtcOutSrc.h	/^	u8				bt_chip_type;$/;"	m	struct:btc_board_info
-bt_coex_info	include/rtw_btcoex.h	/^struct bt_coex_info {$/;"	s
-bt_coex_supported_feature	hal/btc/HalBtc8822b1Ant.h	/^	u32					bt_coex_supported_feature;$/;"	m	struct:coex_sta_8822b_1ant
-bt_coex_supported_feature	hal/btc/halbtc8723d1ant.h	/^	u32					bt_coex_supported_feature;$/;"	m	struct:coex_sta_8723d_1ant
-bt_coex_supported_feature	hal/btc/halbtc8723d2ant.h	/^	u32					bt_coex_supported_feature;$/;"	m	struct:coex_sta_8723d_2ant
-bt_coex_supported_feature	hal/btc/halbtc8821c1ant.h	/^	u32					bt_coex_supported_feature;$/;"	m	struct:coex_sta_8821c_1ant
-bt_coex_supported_feature	hal/btc/halbtc8821c2ant.h	/^	u32					bt_coex_supported_feature;$/;"	m	struct:coex_sta_8821c_2ant
-bt_coex_supported_version	hal/btc/HalBtc8822b1Ant.h	/^	u32					bt_coex_supported_version;$/;"	m	struct:coex_sta_8822b_1ant
-bt_coex_supported_version	hal/btc/halbtc8723d1ant.h	/^	u32					bt_coex_supported_version;$/;"	m	struct:coex_sta_8723d_1ant
-bt_coex_supported_version	hal/btc/halbtc8723d2ant.h	/^	u32					bt_coex_supported_version;$/;"	m	struct:coex_sta_8723d_2ant
-bt_coex_supported_version	hal/btc/halbtc8821c1ant.h	/^	u32					bt_coex_supported_version;$/;"	m	struct:coex_sta_8821c_1ant
-bt_coex_supported_version	hal/btc/halbtc8821c2ant.h	/^	u32					bt_coex_supported_version;$/;"	m	struct:coex_sta_8821c_2ant
-bt_coex_thres	hal/btc/halbtc8723d2ant.h	/^	u8					bt_coex_thres;$/;"	m	struct:coex_sta_8723d_2ant
-bt_coex_thres	hal/btc/halbtc8821c2ant.h	/^	u8					bt_coex_thres;$/;"	m	struct:coex_sta_8821c_2ant
-bt_coex_thres2	hal/btc/halbtc8723d2ant.h	/^	u8					bt_coex_thres2;$/;"	m	struct:coex_sta_8723d_2ant
-bt_coex_thres2	hal/btc/halbtc8821c2ant.h	/^	u8					bt_coex_thres2;$/;"	m	struct:coex_sta_8821c_2ant
-bt_coexist	include/hal_data.h	/^	BT_COEXIST		bt_coexist;$/;"	m	struct:hal_com_data
-bt_create_connection	hal/btc/HalBtc8703b1Ant.h	/^	boolean				bt_create_connection;$/;"	m	struct:coex_sta_8703b_1ant
-bt_create_connection	hal/btc/HalBtc8822b1Ant.h	/^	boolean				bt_create_connection;$/;"	m	struct:coex_sta_8822b_1ant
-bt_create_connection	hal/btc/halbtc8723d1ant.h	/^	boolean				bt_create_connection;$/;"	m	struct:coex_sta_8723d_1ant
-bt_create_connection	hal/btc/halbtc8723d2ant.h	/^	boolean				bt_create_connection;$/;"	m	struct:coex_sta_8723d_2ant
-bt_create_connection	hal/btc/halbtc8821c1ant.h	/^	boolean				bt_create_connection;$/;"	m	struct:coex_sta_8821c_1ant
-bt_create_connection	hal/btc/halbtc8821c2ant.h	/^	boolean				bt_create_connection;$/;"	m	struct:coex_sta_8821c_2ant
-bt_ctrl_agg_buf_size	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_ctrl_agg_buf_size;$/;"	m	struct:btc_bt_info
-bt_ctrl_lps	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_ctrl_lps;$/;"	m	struct:btc_bt_info
-bt_disable_low_pwr	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_disable_low_pwr;$/;"	m	struct:btc_bt_info
-bt_disabled	hal/btc/HalBtc8192e1Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8192e_1ant
-bt_disabled	hal/btc/HalBtc8192e2Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8192e_2ant
-bt_disabled	hal/btc/HalBtc8703b1Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8703b_1ant
-bt_disabled	hal/btc/HalBtc8723b1Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8723b_1ant
-bt_disabled	hal/btc/HalBtc8723b2Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8723b_2ant
-bt_disabled	hal/btc/HalBtc8812a1Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8812a_1ant
-bt_disabled	hal/btc/HalBtc8812a2Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8812a_2ant
-bt_disabled	hal/btc/HalBtc8821a1Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8821a_1ant
-bt_disabled	hal/btc/HalBtc8821a2Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8821a_2ant
-bt_disabled	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8821a_csr_2ant
-bt_disabled	hal/btc/HalBtc8822b1Ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8822b_1ant
-bt_disabled	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_disabled;$/;"	m	struct:btc_bt_info
-bt_disabled	hal/btc/halbtc8723d1ant.h	/^	boolean				bt_disabled;$/;"	m	struct:coex_sta_8723d_1ant
-bt_disabled	hal/btc/halbtc8723d2ant.h	/^	boolean				bt_disabled;$/;"	m	struct:coex_sta_8723d_2ant
-bt_disabled	hal/btc/halbtc8821c1ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8821c_1ant
-bt_disabled	hal/btc/halbtc8821c2ant.h	/^	boolean					bt_disabled;$/;"	m	struct:coex_sta_8821c_2ant
-bt_enable_disable_change	hal/btc/HalBtcOutSrc.h	/^	boolean				bt_enable_disable_change;$/;"	m	struct:btc_bt_info
-bt_fw_ver	hal/btc/HalBtcOutSrc.h	/^	u8					bt_fw_ver;$/;"	m	struct:btc_bt_info
-bt_get_fw_ver	hal/btc/HalBtcOutSrc.h	/^	u32					bt_get_fw_ver;$/;"	m	struct:btc_bt_info
-bt_hci_ver	hal/btc/HalBtcOutSrc.h	/^	u16					bt_hci_ver;$/;"	m	struct:btc_bt_info
-bt_hi_pri_link_exist	hal/btc/HalBtc8703b1Ant.h	/^	boolean					bt_hi_pri_link_exist;$/;"	m	struct:coex_sta_8703b_1ant
-bt_hi_pri_link_exist	hal/btc/HalBtc8723b1Ant.h	/^	boolean					bt_hi_pri_link_exist;$/;"	m	struct:coex_sta_8723b_1ant
-bt_hi_pri_link_exist	hal/btc/HalBtc8822b1Ant.h	/^	boolean					bt_hi_pri_link_exist;$/;"	m	struct:coex_sta_8822b_1ant
-bt_hi_pri_link_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_hi_pri_link_exist;$/;"	m	struct:btc_bt_link_info
-bt_hi_pri_link_exist	hal/btc/halbtc8723d1ant.h	/^	boolean				bt_hi_pri_link_exist;$/;"	m	struct:coex_sta_8723d_1ant
-bt_hi_pri_link_exist	hal/btc/halbtc8821c1ant.h	/^	boolean					bt_hi_pri_link_exist;$/;"	m	struct:coex_sta_8821c_1ant
-bt_info	hal/btc/HalBtcOutSrc.h	/^	struct  btc_bt_info			bt_info;		\/*some bt info referenced by non-bt module*\/$/;"	m	struct:btc_coexist	typeref:struct:btc_coexist::btc_bt_info
-bt_info	hal/btc/halbtc8723d1ant.h	/^	u8                  bt_info;$/;"	m	struct:coex_sta_8723d_1ant
-bt_info	hal/btc/halbtc8723d2ant.h	/^	u8                  bt_info;$/;"	m	struct:coex_sta_8723d_2ant
-bt_info_c2h	hal/btc/HalBtc8192e1Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8192E_1ANT_MAX][10];$/;"	m	struct:coex_sta_8192e_1ant
-bt_info_c2h	hal/btc/HalBtc8192e2Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8192E_2ANT_MAX][10];$/;"	m	struct:coex_sta_8192e_2ant
-bt_info_c2h	hal/btc/HalBtc8703b1Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8703B_1ANT_MAX][10];$/;"	m	struct:coex_sta_8703b_1ant
-bt_info_c2h	hal/btc/HalBtc8723b1Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8723B_1ANT_MAX][10];$/;"	m	struct:coex_sta_8723b_1ant
-bt_info_c2h	hal/btc/HalBtc8723b2Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8723B_2ANT_MAX][10];$/;"	m	struct:coex_sta_8723b_2ant
-bt_info_c2h	hal/btc/HalBtc8812a1Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8812A_1ANT_MAX][10];$/;"	m	struct:coex_sta_8812a_1ant
-bt_info_c2h	hal/btc/HalBtc8812a2Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8812A_2ANT_MAX][10];$/;"	m	struct:coex_sta_8812a_2ant
-bt_info_c2h	hal/btc/HalBtc8821a1Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8821A_1ANT_MAX][10];$/;"	m	struct:coex_sta_8821a_1ant
-bt_info_c2h	hal/btc/HalBtc8821a2Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8821A_2ANT_MAX][10];$/;"	m	struct:coex_sta_8821a_2ant
-bt_info_c2h	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8821A_CSR_2ANT_MAX][10];$/;"	m	struct:coex_sta_8821a_csr_2ant
-bt_info_c2h	hal/btc/HalBtc8822b1Ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8822B_1ANT_MAX][10];$/;"	m	struct:coex_sta_8822b_1ant
-bt_info_c2h	hal/btc/halbtc8723d1ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8723D_1ANT_MAX][10];$/;"	m	struct:coex_sta_8723d_1ant
-bt_info_c2h	hal/btc/halbtc8723d2ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8723D_2ANT_MAX][10];$/;"	m	struct:coex_sta_8723d_2ant
-bt_info_c2h	hal/btc/halbtc8821c1ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8821C_1ANT_MAX][10];$/;"	m	struct:coex_sta_8821c_1ant
-bt_info_c2h	hal/btc/halbtc8821c2ant.h	/^	u8					bt_info_c2h[BT_INFO_SRC_8821C_2ANT_MAX][10];$/;"	m	struct:coex_sta_8821c_2ant
-bt_info_c2h_cnt	hal/btc/HalBtc8192e1Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8192E_1ANT_MAX];$/;"	m	struct:coex_sta_8192e_1ant
-bt_info_c2h_cnt	hal/btc/HalBtc8192e2Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8192E_2ANT_MAX];$/;"	m	struct:coex_sta_8192e_2ant
-bt_info_c2h_cnt	hal/btc/HalBtc8703b1Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8703B_1ANT_MAX];$/;"	m	struct:coex_sta_8703b_1ant
-bt_info_c2h_cnt	hal/btc/HalBtc8723b1Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723B_1ANT_MAX];$/;"	m	struct:coex_sta_8723b_1ant
-bt_info_c2h_cnt	hal/btc/HalBtc8723b2Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723B_2ANT_MAX];$/;"	m	struct:coex_sta_8723b_2ant
-bt_info_c2h_cnt	hal/btc/HalBtc8812a1Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8812A_1ANT_MAX];$/;"	m	struct:coex_sta_8812a_1ant
-bt_info_c2h_cnt	hal/btc/HalBtc8812a2Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8812A_2ANT_MAX];$/;"	m	struct:coex_sta_8812a_2ant
-bt_info_c2h_cnt	hal/btc/HalBtc8821a1Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821A_1ANT_MAX];$/;"	m	struct:coex_sta_8821a_1ant
-bt_info_c2h_cnt	hal/btc/HalBtc8821a2Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821A_2ANT_MAX];$/;"	m	struct:coex_sta_8821a_2ant
-bt_info_c2h_cnt	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821A_CSR_2ANT_MAX];$/;"	m	struct:coex_sta_8821a_csr_2ant
-bt_info_c2h_cnt	hal/btc/HalBtc8822b1Ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8822B_1ANT_MAX];$/;"	m	struct:coex_sta_8822b_1ant
-bt_info_c2h_cnt	hal/btc/halbtc8723d1ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723D_1ANT_MAX];$/;"	m	struct:coex_sta_8723d_1ant
-bt_info_c2h_cnt	hal/btc/halbtc8723d2ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8723D_2ANT_MAX];$/;"	m	struct:coex_sta_8723d_2ant
-bt_info_c2h_cnt	hal/btc/halbtc8821c1ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821C_1ANT_MAX];$/;"	m	struct:coex_sta_8821c_1ant
-bt_info_c2h_cnt	hal/btc/halbtc8821c2ant.h	/^	u32					bt_info_c2h_cnt[BT_INFO_SRC_8821C_2ANT_MAX];$/;"	m	struct:coex_sta_8821c_2ant
-bt_info_ext	hal/btc/HalBtc8192e1Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8192e_1ant
-bt_info_ext	hal/btc/HalBtc8192e2Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8192e_2ant
-bt_info_ext	hal/btc/HalBtc8703b1Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8703b_1ant
-bt_info_ext	hal/btc/HalBtc8723b1Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8723b_1ant
-bt_info_ext	hal/btc/HalBtc8723b2Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8723b_2ant
-bt_info_ext	hal/btc/HalBtc8812a1Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8812a_1ant
-bt_info_ext	hal/btc/HalBtc8812a2Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8812a_2ant
-bt_info_ext	hal/btc/HalBtc8821a1Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8821a_1ant
-bt_info_ext	hal/btc/HalBtc8821a2Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8821a_2ant
-bt_info_ext	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8821a_csr_2ant
-bt_info_ext	hal/btc/HalBtc8822b1Ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8822b_1ant
-bt_info_ext	hal/btc/halbtc8723d1ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8723d_1ant
-bt_info_ext	hal/btc/halbtc8723d2ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8723d_2ant
-bt_info_ext	hal/btc/halbtc8821c1ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8821c_1ant
-bt_info_ext	hal/btc/halbtc8821c2ant.h	/^	u8					bt_info_ext;$/;"	m	struct:coex_sta_8821c_2ant
-bt_info_ext2	hal/btc/halbtc8723d1ant.h	/^	u8					bt_info_ext2;$/;"	m	struct:coex_sta_8723d_1ant
-bt_info_ext2	hal/btc/halbtc8723d2ant.h	/^	u8					bt_info_ext2;$/;"	m	struct:coex_sta_8723d_2ant
-bt_info_query_cnt	hal/btc/HalBtc8812a1Ant.h	/^	u32					bt_info_query_cnt;$/;"	m	struct:coex_sta_8812a_1ant
-bt_info_query_cnt	hal/btc/HalBtc8812a2Ant.h	/^	u32					bt_info_query_cnt;$/;"	m	struct:coex_sta_8812a_2ant
-bt_info_src_8192e_1ant	hal/btc/HalBtc8192e1Ant.h	/^enum bt_info_src_8192e_1ant {$/;"	g
-bt_info_src_8192e_2ant	hal/btc/HalBtc8192e2Ant.h	/^enum bt_info_src_8192e_2ant {$/;"	g
-bt_info_src_8703b_1ant	hal/btc/HalBtc8703b1Ant.h	/^enum bt_info_src_8703b_1ant {$/;"	g
-bt_info_src_8723b_1ant	hal/btc/HalBtc8723b1Ant.h	/^enum bt_info_src_8723b_1ant {$/;"	g
-bt_info_src_8723b_2ant	hal/btc/HalBtc8723b2Ant.h	/^enum bt_info_src_8723b_2ant {$/;"	g
-bt_info_src_8723d_1ant	hal/btc/halbtc8723d1ant.h	/^enum bt_info_src_8723d_1ant {$/;"	g
-bt_info_src_8723d_2ant	hal/btc/halbtc8723d2ant.h	/^enum bt_info_src_8723d_2ant {$/;"	g
-bt_info_src_8812a_1ant	hal/btc/HalBtc8812a1Ant.h	/^enum bt_info_src_8812a_1ant {$/;"	g
-bt_info_src_8812a_2ant	hal/btc/HalBtc8812a2Ant.h	/^enum bt_info_src_8812a_2ant {$/;"	g
-bt_info_src_8821a_1ant	hal/btc/HalBtc8821a1Ant.h	/^enum bt_info_src_8821a_1ant {$/;"	g
-bt_info_src_8821a_2ant	hal/btc/HalBtc8821a2Ant.h	/^enum bt_info_src_8821a_2ant {$/;"	g
-bt_info_src_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.h	/^enum bt_info_src_8821a_csr_2ant {$/;"	g
-bt_info_src_8821c_1ant	hal/btc/halbtc8821c1ant.h	/^enum bt_info_src_8821c_1ant {$/;"	g
-bt_info_src_8821c_2ant	hal/btc/halbtc8821c2ant.h	/^enum bt_info_src_8821c_2ant {$/;"	g
-bt_info_src_8822b_1ant	hal/btc/HalBtc8822b1Ant.h	/^enum bt_info_src_8822b_1ant {$/;"	g
-bt_iso	include/drv_types.h	/^	u8	bt_iso;$/;"	m	struct:registry_priv
-bt_leave	include/rtw_btcoex.h	90;"	d
-bt_link_exist	hal/btc/HalBtc8192e1Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8192e_1ant
-bt_link_exist	hal/btc/HalBtc8192e2Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8192e_2ant
-bt_link_exist	hal/btc/HalBtc8703b1Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8703b_1ant
-bt_link_exist	hal/btc/HalBtc8723b1Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8723b_1ant
-bt_link_exist	hal/btc/HalBtc8723b2Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8723b_2ant
-bt_link_exist	hal/btc/HalBtc8812a1Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8812a_1ant
-bt_link_exist	hal/btc/HalBtc8812a2Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8812a_2ant
-bt_link_exist	hal/btc/HalBtc8821a1Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8821a_1ant
-bt_link_exist	hal/btc/HalBtc8821a2Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8821a_2ant
-bt_link_exist	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8821a_csr_2ant
-bt_link_exist	hal/btc/HalBtc8822b1Ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8822b_1ant
-bt_link_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_link_exist;$/;"	m	struct:btc_bt_link_info
-bt_link_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_link_exist;$/;"	m	struct:btc_stack_info
-bt_link_exist	hal/btc/halbtc8723d1ant.h	/^	boolean				bt_link_exist;$/;"	m	struct:coex_sta_8723d_1ant
-bt_link_exist	hal/btc/halbtc8723d2ant.h	/^	boolean				bt_link_exist;$/;"	m	struct:coex_sta_8723d_2ant
-bt_link_exist	hal/btc/halbtc8821c1ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8821c_1ant
-bt_link_exist	hal/btc/halbtc8821c2ant.h	/^	boolean					bt_link_exist;$/;"	m	struct:coex_sta_8821c_2ant
-bt_link_info	hal/btc/HalBtcOutSrc.h	/^	struct  btc_bt_link_info		bt_link_info;$/;"	m	struct:btc_coexist	typeref:struct:btc_coexist::btc_bt_link_info
-bt_lps_on	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_lps_on;$/;"	m	struct:btc_bt_info
-bt_null	include/rtl8188e_xmit.h	/^	u32 bt_null:1;$/;"	m	struct:txdesc_88e
-bt_null	include/rtl8192e_xmit.h	/^	u32 bt_null:1;$/;"	m	struct:txdescriptor_8192e
-bt_null	include/rtl8812a_xmit.h	/^	u32 bt_null:1;$/;"	m	struct:txdescriptor_8812
-bt_null	include/rtl8821a_xmit.h	/^	u32 bt_null:1;$/;"	m	struct:txdescriptor_8821a
-bt_real_fw_ver	hal/btc/HalBtcOutSrc.h	/^	u16					bt_real_fw_ver;$/;"	m	struct:btc_bt_info
-bt_reg_vendor_ac	hal/btc/halbtc8723d1ant.h	/^	u16					bt_reg_vendor_ac;$/;"	m	struct:coex_sta_8723d_1ant
-bt_reg_vendor_ac	hal/btc/halbtc8723d2ant.h	/^	u16					bt_reg_vendor_ac;$/;"	m	struct:coex_sta_8723d_2ant
-bt_reg_vendor_ae	hal/btc/halbtc8723d1ant.h	/^	u16					bt_reg_vendor_ae;$/;"	m	struct:coex_sta_8723d_1ant
-bt_reg_vendor_ae	hal/btc/halbtc8723d2ant.h	/^	u16					bt_reg_vendor_ae;$/;"	m	struct:coex_sta_8723d_2ant
-bt_relink_downcount	hal/btc/halbtc8723d1ant.h	/^	u8					bt_relink_downcount;$/;"	m	struct:coex_sta_8723d_1ant
-bt_relink_downcount	hal/btc/halbtc8723d2ant.h	/^	u8					bt_relink_downcount;$/;"	m	struct:coex_sta_8723d_2ant
-bt_retry_cnt	hal/btc/HalBtc8192e1Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8192e_1ant
-bt_retry_cnt	hal/btc/HalBtc8192e2Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8192e_2ant
-bt_retry_cnt	hal/btc/HalBtc8703b1Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8703b_1ant
-bt_retry_cnt	hal/btc/HalBtc8723b1Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8723b_1ant
-bt_retry_cnt	hal/btc/HalBtc8723b2Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8723b_2ant
-bt_retry_cnt	hal/btc/HalBtc8812a1Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8812a_1ant
-bt_retry_cnt	hal/btc/HalBtc8812a2Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8812a_2ant
-bt_retry_cnt	hal/btc/HalBtc8821a1Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8821a_1ant
-bt_retry_cnt	hal/btc/HalBtc8821a2Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8821a_2ant
-bt_retry_cnt	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8821a_csr_2ant
-bt_retry_cnt	hal/btc/HalBtc8822b1Ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8822b_1ant
-bt_retry_cnt	hal/btc/halbtc8723d1ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8723d_1ant
-bt_retry_cnt	hal/btc/halbtc8723d2ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8723d_2ant
-bt_retry_cnt	hal/btc/halbtc8821c1ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8821c_1ant
-bt_retry_cnt	hal/btc/halbtc8821c2ant.h	/^	u8					bt_retry_cnt;$/;"	m	struct:coex_sta_8821c_2ant
-bt_rf_0x1e_backup	hal/btc/HalBtc8192e2Ant.h	/^	u32		bt_rf_0x1e_backup;$/;"	m	struct:coex_dm_8192e_2ant
-bt_rf_0x1e_backup	hal/btc/HalBtc8723b2Ant.h	/^	u32		bt_rf_0x1e_backup;$/;"	m	struct:coex_dm_8723b_2ant
-bt_rf_0x1e_backup	hal/btc/HalBtc8812a2Ant.h	/^	u32		bt_rf_0x1e_backup;$/;"	m	struct:coex_dm_8812a_2ant
-bt_rf_0x1e_backup	hal/btc/HalBtc8821a2Ant.h	/^	u32		bt_rf_0x1e_backup;$/;"	m	struct:coex_dm_8821a_2ant
-bt_rf_0x1e_backup	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		bt_rf_0x1e_backup;$/;"	m	struct:coex_dm_8821a_csr_2ant
-bt_rf_0x1e_backup	hal/btc/halbtc8723d2ant.h	/^	u32		bt_rf_0x1e_backup;$/;"	m	struct:coex_dm_8723d_2ant
-bt_rf_0x1e_backup	hal/btc/halbtc8821c2ant.h	/^	u32		bt_rf_0x1e_backup;$/;"	m	struct:coex_dm_8821c_2ant
-bt_rssi	hal/btc/HalBtc8192e1Ant.h	/^	s8					bt_rssi;$/;"	m	struct:coex_sta_8192e_1ant
-bt_rssi	hal/btc/HalBtc8192e2Ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8192e_2ant
-bt_rssi	hal/btc/HalBtc8703b1Ant.h	/^	s8					bt_rssi;$/;"	m	struct:coex_sta_8703b_1ant
-bt_rssi	hal/btc/HalBtc8723b1Ant.h	/^	s8					bt_rssi;$/;"	m	struct:coex_sta_8723b_1ant
-bt_rssi	hal/btc/HalBtc8723b2Ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8723b_2ant
-bt_rssi	hal/btc/HalBtc8812a1Ant.h	/^	s8					bt_rssi;$/;"	m	struct:coex_sta_8812a_1ant
-bt_rssi	hal/btc/HalBtc8812a2Ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8812a_2ant
-bt_rssi	hal/btc/HalBtc8821a1Ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8821a_1ant
-bt_rssi	hal/btc/HalBtc8821a2Ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8821a_2ant
-bt_rssi	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8821a_csr_2ant
-bt_rssi	hal/btc/HalBtc8822b1Ant.h	/^	s8					bt_rssi;$/;"	m	struct:coex_sta_8822b_1ant
-bt_rssi	hal/btc/halbtc8723d1ant.h	/^	s8					bt_rssi;$/;"	m	struct:coex_sta_8723d_1ant
-bt_rssi	hal/btc/halbtc8723d2ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8723d_2ant
-bt_rssi	hal/btc/halbtc8821c1ant.h	/^	s8					bt_rssi;$/;"	m	struct:coex_sta_8821c_1ant
-bt_rssi	hal/btc/halbtc8821c2ant.h	/^	u8					bt_rssi;$/;"	m	struct:coex_sta_8821c_2ant
-bt_sco	include/drv_types.h	/^	u8	bt_sco;$/;"	m	struct:registry_priv
-bt_sockaddr	include/rtw_btcoex.h	/^	struct sockaddr_in bt_sockaddr;\/* BT socket *\/$/;"	m	struct:bt_coex_info	typeref:struct:bt_coex_info::sockaddr_in
-bt_status	hal/btc/HalBtc8192e1Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8192e_1ant
-bt_status	hal/btc/HalBtc8192e2Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8192e_2ant
-bt_status	hal/btc/HalBtc8703b1Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8703b_1ant
-bt_status	hal/btc/HalBtc8723b1Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8723b_1ant
-bt_status	hal/btc/HalBtc8723b2Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8723b_2ant
-bt_status	hal/btc/HalBtc8812a1Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8812a_1ant
-bt_status	hal/btc/HalBtc8812a2Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8812a_2ant
-bt_status	hal/btc/HalBtc8821a1Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8821a_1ant
-bt_status	hal/btc/HalBtc8821a2Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8821a_2ant
-bt_status	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8821a_csr_2ant
-bt_status	hal/btc/HalBtc8822b1Ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8822b_1ant
-bt_status	hal/btc/halbtc8723d1ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8723d_1ant
-bt_status	hal/btc/halbtc8723d2ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8723d_2ant
-bt_status	hal/btc/halbtc8821c1ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8821c_1ant
-bt_status	hal/btc/halbtc8821c2ant.h	/^	u8		bt_status;$/;"	m	struct:coex_dm_8821c_2ant
-bt_tx_rx_mask	hal/btc/HalBtc8192e1Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8192e_1ant
-bt_tx_rx_mask	hal/btc/HalBtc8703b1Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8703b_1ant
-bt_tx_rx_mask	hal/btc/HalBtc8723b1Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8723b_1ant
-bt_tx_rx_mask	hal/btc/HalBtc8723b2Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8723b_2ant
-bt_tx_rx_mask	hal/btc/HalBtc8812a1Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8812a_1ant
-bt_tx_rx_mask	hal/btc/HalBtc8821a1Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8821a_1ant
-bt_tx_rx_mask	hal/btc/HalBtc8821a2Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8821a_2ant
-bt_tx_rx_mask	hal/btc/HalBtc8822b1Ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8822b_1ant
-bt_tx_rx_mask	hal/btc/HalBtcOutSrc.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:btc_bt_info
-bt_tx_rx_mask	hal/btc/halbtc8723d1ant.h	/^	boolean				bt_tx_rx_mask;$/;"	m	struct:coex_sta_8723d_1ant
-bt_tx_rx_mask	hal/btc/halbtc8723d2ant.h	/^	boolean				bt_tx_rx_mask;$/;"	m	struct:coex_sta_8723d_2ant
-bt_tx_rx_mask	hal/btc/halbtc8821c1ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8821c_1ant
-bt_tx_rx_mask	hal/btc/halbtc8821c2ant.h	/^	boolean					bt_tx_rx_mask;$/;"	m	struct:coex_sta_8821c_2ant
-bt_whck_test	hal/btc/HalBtc8703b1Ant.h	/^	boolean					bt_whck_test;$/;"	m	struct:coex_sta_8703b_1ant
-bt_whck_test	hal/btc/HalBtc8723b1Ant.h	/^	boolean					bt_whck_test;$/;"	m	struct:coex_sta_8723b_1ant
-bt_whck_test	hal/btc/HalBtc8723b2Ant.h	/^	boolean				bt_whck_test;$/;"	m	struct:coex_sta_8723b_2ant
-bt_whck_test	hal/btc/HalBtc8821a1Ant.h	/^	bt_whck_test;                        \/* Add for ASUS WHQL TEST that enable wifi test bt *\/$/;"	m	struct:coex_sta_8821a_1ant
-bt_whck_test	hal/btc/HalBtc8821a2Ant.h	/^	boolean				bt_whck_test;$/;"	m	struct:coex_sta_8821a_2ant
-bt_whck_test	hal/btc/HalBtc8822b1Ant.h	/^	boolean					bt_whck_test;$/;"	m	struct:coex_sta_8822b_1ant
-bt_whck_test	hal/btc/halbtc8723d1ant.h	/^	boolean				bt_whck_test;$/;"	m	struct:coex_sta_8723d_1ant
-bt_whck_test	hal/btc/halbtc8723d2ant.h	/^	boolean				bt_whck_test;$/;"	m	struct:coex_sta_8723d_2ant
-bt_whck_test	hal/btc/halbtc8821c1ant.h	/^	boolean					bt_whck_test;$/;"	m	struct:coex_sta_8821c_1ant
-bt_whck_test	hal/btc/halbtc8821c2ant.h	/^	boolean				bt_whck_test;$/;"	m	struct:coex_sta_8821c_2ant
-btc_board_info	hal/btc/HalBtcOutSrc.h	/^struct btc_board_info {$/;"	s
-btc_bt_info	hal/btc/HalBtcOutSrc.h	/^struct  btc_bt_info {$/;"	s
-btc_bt_link_info	hal/btc/HalBtcOutSrc.h	/^struct btc_bt_link_info {$/;"	s
-btc_coex_h2c_process	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_COEX_H2C_PROCESS	btc_coex_h2c_process;$/;"	m	struct:btc_coexist
-btc_coexist	hal/btc/HalBtcOutSrc.h	/^struct btc_coexist {$/;"	s
-btc_disp_dbg_msg	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_DISP_DBG_MSG	btc_disp_dbg_msg;$/;"	m	struct:btc_coexist
-btc_fill_h2c	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_FILL_H2C		btc_fill_h2c;$/;"	m	struct:btc_coexist
-btc_get	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET			btc_get;$/;"	m	struct:btc_coexist
-btc_get_ant_det_val_from_bt	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_ANT_DET_VAL_FROM_BT		btc_get_ant_det_val_from_bt;$/;"	m	struct:btc_coexist
-btc_get_bb_reg	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_BB_REG	btc_get_bb_reg;$/;"	m	struct:btc_coexist
-btc_get_ble_scan_para_from_bt	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT	btc_get_ble_scan_para_from_bt;$/;"	m	struct:btc_coexist
-btc_get_ble_scan_type_from_bt	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT	btc_get_ble_scan_type_from_bt;$/;"	m	struct:btc_coexist
-btc_get_bt_afh_map_from_bt	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_BT_AFH_MAP_FROM_BT		btc_get_bt_afh_map_from_bt;$/;"	m	struct:btc_coexist
-btc_get_bt_coex_supported_feature	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE btc_get_bt_coex_supported_feature;$/;"	m	struct:btc_coexist
-btc_get_bt_coex_supported_version	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION btc_get_bt_coex_supported_version;$/;"	m	struct:btc_coexist
-btc_get_bt_phydm_version	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_PHYDM_VERSION		btc_get_bt_phydm_version;$/;"	m	struct:btc_coexist
-btc_get_bt_reg	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_BT_REG	btc_get_bt_reg;$/;"	m	struct:btc_coexist
-btc_get_rf_reg	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_GET_RF_REG	btc_get_rf_reg;$/;"	m	struct:btc_coexist
-btc_phydm_modify_RA_PCR_threshold	hal/btc/HalBtcOutSrc.h	/^	BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD	btc_phydm_modify_RA_PCR_threshold;$/;"	m	struct:btc_coexist
-btc_phydm_query_PHY_counter	hal/btc/HalBtcOutSrc.h	/^	BTC_PHYDM_CMNINFOQUERY				btc_phydm_query_PHY_counter;$/;"	m	struct:btc_coexist
-btc_read_1byte	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_R1			btc_read_1byte;$/;"	m	struct:btc_coexist
-btc_read_2byte	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_R2			btc_read_2byte;$/;"	m	struct:btc_coexist
-btc_read_4byte	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_R4			btc_read_4byte;$/;"	m	struct:btc_coexist
-btc_set	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_SET			btc_set;$/;"	m	struct:btc_coexist
-btc_set_bb_reg	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_SET_BB_REG	btc_set_bb_reg;$/;"	m	struct:btc_coexist
-btc_set_bt_ant_detection	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_SET_BT_ANT_DETECTION	btc_set_bt_ant_detection;$/;"	m	struct:btc_coexist
-btc_set_bt_reg	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_SET_BT_REG	btc_set_bt_reg;$/;"	m	struct:btc_coexist
-btc_set_bt_trx_mask	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_SET_BT_TRX_MASK		btc_set_bt_trx_mask;$/;"	m	struct:btc_coexist
-btc_set_rf_reg	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_SET_RF_REG	btc_set_rf_reg;$/;"	m	struct:btc_coexist
-btc_stack_info	hal/btc/HalBtcOutSrc.h	/^struct btc_stack_info {$/;"	s
-btc_statistics	hal/btc/HalBtcOutSrc.h	/^struct btc_statistics {$/;"	s
-btc_write_1byte	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_W1			btc_write_1byte;$/;"	m	struct:btc_coexist
-btc_write_1byte_bitmask	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_W1_BIT_MASK	btc_write_1byte_bitmask;$/;"	m	struct:btc_coexist
-btc_write_2byte	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_W2			btc_write_2byte;$/;"	m	struct:btc_coexist
-btc_write_4byte	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_W4			btc_write_4byte;$/;"	m	struct:btc_coexist
-btc_write_local_reg_1byte	hal/btc/HalBtcOutSrc.h	/^	BFP_BTC_LOCAL_REG_W1	btc_write_local_reg_1byte;$/;"	m	struct:btc_coexist
-btcoex	include/drv_types.h	/^	u8	btcoex;$/;"	m	struct:registry_priv
-btcoex_wq	include/rtw_btcoex.h	/^	struct workqueue_struct *btcoex_wq;$/;"	m	struct:bt_coex_info	typeref:struct:bt_coex_info::workqueue_struct
-btdm_ant_det_complete_fail	hal/btc/HalBtcOutSrc.h	/^	boolean			btdm_ant_det_complete_fail;$/;"	m	struct:btc_board_info
-btdm_ant_det_finish	hal/btc/HalBtcOutSrc.h	/^	boolean			btdm_ant_det_finish;$/;"	m	struct:btc_board_info
-btdm_ant_num	hal/btc/HalBtcOutSrc.h	/^	u8				btdm_ant_num;	\/* ant number for btdm *\/$/;"	m	struct:btc_board_info
-btdm_ant_num_by_ant_det	hal/btc/HalBtcOutSrc.h	/^	u8				btdm_ant_num_by_ant_det;	\/* ant number for btdm after antenna detection *\/$/;"	m	struct:btc_board_info
-btdm_ant_pos	hal/btc/HalBtcOutSrc.h	/^	u8				btdm_ant_pos;		\/* Bryant Add to indicate Antenna Position for (pg_ant_num = 2) && (btdm_ant_num =1)  (DPDT+1Ant case) *\/$/;"	m	struct:btc_board_info
-btinfo	core/rtw_cmd.c	/^struct btinfo {$/;"	s	file:
-btinfo_8761ATV	include/rtw_btcoex.h	/^struct btinfo_8761ATV {$/;"	s
-btinfo_evt_dump	core/rtw_cmd.c	/^void btinfo_evt_dump(void *sel, void *buf)$/;"	f
-btkip_countermeasure	include/rtw_security.h	/^	u8	btkip_countermeasure;$/;"	m	struct:security_priv
-btkip_countermeasure_time	include/rtw_security.h	/^	u32 btkip_countermeasure_time;$/;"	m	struct:security_priv
-btkip_wait_report	include/rtw_security.h	/^	u8	btkip_wait_report;$/;"	m	struct:security_priv
-btreg_parse_str	os_dep/linux/rtw_proc.c	/^static int btreg_parse_str(char const *input, u8 *type, u16 *addr, u16 *val)$/;"	f	file:
-btreg_read_addr	os_dep/linux/rtw_proc.c	/^static u16 btreg_read_addr = 0;$/;"	v	file:
-btreg_read_error	os_dep/linux/rtw_proc.c	/^static int btreg_read_error = 0;$/;"	v	file:
-btreg_read_type	os_dep/linux/rtw_proc.c	/^static u8 btreg_read_type = 0;$/;"	v	file:
-btreg_type	os_dep/linux/rtw_proc.c	/^static u8 *btreg_type[] = {$/;"	v	file:
-btreg_write_addr	os_dep/linux/rtw_proc.c	/^static u16 btreg_write_addr = 0;$/;"	v	file:
-btreg_write_error	os_dep/linux/rtw_proc.c	/^static int btreg_write_error = 0;$/;"	v	file:
-btreg_write_type	os_dep/linux/rtw_proc.c	/^static u8 btreg_write_type = 0;$/;"	v	file:
-buf	hal/btc/HalBtcOutSrc.h	/^	u1Byte	buf[1];$/;"	m	struct:_COL_C2H_ACK
-buf	hal/btc/HalBtcOutSrc.h	/^	u1Byte	buf[1];$/;"	m	struct:_COL_H2C
-buf	include/ieee80211.h	/^			u8	buf[0];$/;"	m	struct:ieee_param::__anon73::__anon79
-buf	include/rtl8188e_cmd.h	/^	u8 buf[6];$/;"	m	struct:cmd_msg_parm
-buf	include/rtl8192e_cmd.h	/^	u8 buf[6];$/;"	m	struct:cmd_msg_parm
-buf	include/rtl8812a_cmd.h	/^	u8 buf[6];$/;"	m	struct:cmd_msg_parm
-buf	include/rtw_bt_mp.h	/^	u1Byte	buf[100];$/;"	m	struct:_BT_EXT_C2H
-buf	include/rtw_bt_mp.h	/^	u1Byte	buf[100];$/;"	m	struct:_BT_H2C
-buf	include/rtw_mlme.h	/^	u8 *buf;$/;"	m	struct:tdls_txmgmt
-buf	include/rtw_mp.h	/^	u8 *buf;$/;"	m	struct:mp_tx
-buf	include/rtw_security.h	/^	u8 buf[64];$/;"	m	struct:sha256_state
-buf	os_dep/linux/rtw_android.c	/^	char *buf;$/;"	m	struct:android_wifi_priv_cmd	file:
-buf	os_dep/linux/rtw_android.c	/^	compat_uptr_t buf;$/;"	m	struct:compat_android_wifi_priv_cmd	file:
-buf_addr	include/rtw_xmit.h	/^	u8	*buf_addr;$/;"	m	struct:xmit_frame
-buf_desc	include/rtw_recv.h	/^	struct rx_buf_desc	*buf_desc;$/;"	m	struct:rtw_rx_ring	typeref:struct:rtw_rx_ring::rx_buf_desc
-buf_desc	include/rtw_xmit.h	/^	struct tx_buf_desc	*buf_desc;$/;"	m	struct:rtw_tx_ring	typeref:struct:rtw_tx_ring::tx_buf_desc
-buf_len	include/xmit_osdep.h	/^	SIZE_T buf_len;$/;"	m	struct:pkt_file
-buf_size	include/drv_types.h	/^	u32 buf_size;$/;"	m	struct:halmac_indicator
-buf_size	include/rtw_mp.h	/^	u32 buf_size, write_size;$/;"	m	struct:mp_tx
-buf_start	include/xmit_osdep.h	/^	u8 *buf_start;$/;"	m	struct:pkt_file
-buf_tag	include/rtw_xmit.h	/^	u16 buf_tag; \/* 0: Normal xmitbuf, 1: extension xmitbuf, 2:cmd xmitbuf *\/$/;"	m	struct:xmit_buf
-buffer	include/drv_types.h	/^	u8 *buffer;$/;"	m	struct:halmac_indicator
-buffer_size	hal/phydm/phydm_adc_sampling.h	/^	u4Byte		buffer_size;$/;"	m	struct:_RT_ADCSMP_STRING
-bufs	include/osdep_service.h	/^	void *bufs[0];$/;"	m	struct:rtw_cbuf
-build_assoc_req_wfd_ie	core/rtw_p2p.c	/^u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_assoc_resp_p2p_ie	core/rtw_p2p.c	/^u32 build_assoc_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 status_code)$/;"	f
-build_assoc_resp_wfd_ie	core/rtw_p2p.c	/^u32 build_assoc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_beacon_p2p_ie	core/rtw_p2p.c	/^u32 build_beacon_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_beacon_wfd_ie	core/rtw_p2p.c	/^u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_deauth_p2p_ie	core/rtw_p2p.c	/^u32 build_deauth_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_invitation_req_wfd_ie	core/rtw_p2p.c	/^u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_invitation_resp_wfd_ie	core/rtw_p2p.c	/^u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_nego_confirm_wfd_ie	core/rtw_p2p.c	/^u32 build_nego_confirm_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_nego_req_wfd_ie	core/rtw_p2p.c	/^u32 build_nego_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_nego_resp_wfd_ie	core/rtw_p2p.c	/^u32 build_nego_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_probe_req_wfd_ie	core/rtw_p2p.c	/^u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_probe_resp_p2p_ie	core/rtw_p2p.c	/^u32 build_probe_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_probe_resp_wfd_ie	core/rtw_p2p.c	/^u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunneled)$/;"	f
-build_prov_disc_request_p2p_ie	core/rtw_p2p.c	/^u32 build_prov_disc_request_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 *pssid, u8 ussidlen, u8 *pdev_raddr)$/;"	f
-build_provdisc_req_wfd_ie	core/rtw_p2p.c	/^u32 build_provdisc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-build_provdisc_resp_wfd_ie	core/rtw_p2p.c	/^u32 build_provdisc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f
-bulkout_id	include/rtw_xmit.h	/^	u8 bulkout_id; \/* for halmac *\/$/;"	m	struct:xmit_buf
-bup	include/drv_types.h	/^	int bup;$/;"	m	struct:_ADAPTER
-burst_rw_reg	include/rtw_mp_ioctl.h	/^} burst_rw_reg, Burst_RW_Reg, *pBurst_RW_Reg;$/;"	t	typeref:struct:_BURST_RW_REG
-busetkipkey	include/rtw_security.h	/^	u8	busetkipkey;$/;"	m	struct:security_priv
-busnumber	include/drv_types_pci.h	/^	u8	busnumber;$/;"	m	struct:pci_priv
-busy_thresh	include/drv_types.h	/^	u16	busy_thresh;$/;"	m	struct:registry_priv
-bw	include/drv_types.h	/^	u8 bw[MACID_NUM_SW_LIMIT];$/;"	m	struct:macid_ctl_t
-bw	include/rtl8188e_recv.h	/^	u32 bw:1;$/;"	m	struct:rxreport_8188e
-bw	include/rtw_cmd.h	/^	u8 bw;$/;"	m	struct:set_ch_parm
-bw	include/rtw_mlme_ext.h	/^	enum { BW20, BW40PLUS, BW40MINUS } bw;$/;"	m	struct:p2p_oper_class_map	typeref:enum:p2p_oper_class_map::__anon53
-bw	include/rtw_recv.h	/^	u8	bw;$/;"	m	struct:rx_pkt_attrib
-bw_cap	include/hal_data.h	/^	u8 bw_cap;		\/* value of BW_CAP_XXX *\/$/;"	m	struct:hal_spec_t
-bw_mode	include/drv_types.h	/^	u8	bw_mode;$/;"	m	struct:registry_priv
-bw_mode	include/hal_data.h	/^	u8 bw_mode;$/;"	m	struct:hal_iqk_reg_backup
-bw_mode	include/sta_info.h	/^	u8	bw_mode;$/;"	m	struct:sta_info
-bwin_enh_L	include/Hal8188EPhyReg.h	776;"	d
-bwin_enh_L	include/Hal8188FPhyReg.h	784;"	d
-bwin_enh_L	include/Hal8192EPhyReg.h	787;"	d
-bwin_enh_L	include/Hal8703BPhyReg.h	813;"	d
-bwin_enh_L	include/Hal8723BPhyReg.h	811;"	d
-bwin_enh_L	include/Hal8723DPhyReg.h	814;"	d
-bwin_enh_L	include/rtw_mp_phy_regdef.h	730;"	d
-bwmode	include/rtw_xmit.h	/^	u8	bwmode;$/;"	m	struct:pkt_attrib
-bwmode_update_check	core/rtw_wlan_util.c	/^static void bwmode_update_check(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)$/;"	f	file:
-bwmode_updated	include/rtw_mlme_ext.h	/^	u8	bwmode_updated;$/;"	m	struct:mlme_ext_info
-by_rate	include/hal_com_phycfg.h	/^	s8 by_rate;$/;"	m	struct:txpwr_idx_comp
-bypassIQK	hal/phydm/phydm_iqk.h	/^	u4Byte		bypassIQK[2][4];	\/*channel \/ 0xc94\/0xe94*\/$/;"	m	struct:_IQK_INFORMATION
-byte_sub	core/rtw_security.c	/^static void byte_sub(u8 *in, u8 *out)$/;"	f	file:
-bytes_needed	include/rtw_ioctl.h	/^	u32		*bytes_needed;$/;"	m	struct:oid_par_priv
-bytes_rw	include/rtw_ioctl.h	/^	u32		*bytes_rw;$/;"	m	struct:oid_par_priv
-c	include/osdep_service.h	/^	u8 *c;$/;"	m	struct:map_seg_t
-c2hBuf	include/rtw_mp.h	/^	u1Byte			c2hBuf[32];$/;"	m	struct:_MPT_CONTEXT
-c2hHangDetectCnt	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte					c2hHangDetectCnt;$/;"	m	struct:_COEX_STA_8723A_1ANT
-c2hHangDetectCnt	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte					c2hHangDetectCnt;$/;"	m	struct:_COEX_STA_8723A_2ANT
-c2h_ack_buf	hal/btc/HalBtcOutSrc.h	/^	u1Byte					c2h_ack_buf[COL_H2C_BUF_LEN];	\/* the latest received c2h buffer *\/$/;"	m	struct:_COL_SINGLE_H2C_RECORD
-c2h_ack_buf	hal/btc/HalBtcOutSrc.h	/^	u1Byte					c2h_ack_buf[COL_MAX_H2C_REQ_NUM][COL_H2C_BUF_LEN];$/;"	m	struct:_BTC_OFFLOAD
-c2h_ack_len	hal/btc/HalBtcOutSrc.h	/^	u1Byte					c2h_ack_len[COL_MAX_H2C_REQ_NUM];$/;"	m	struct:_BTC_OFFLOAD
-c2h_ack_len	hal/btc/HalBtcOutSrc.h	/^	u4Byte					c2h_ack_len;$/;"	m	struct:_COL_SINGLE_H2C_RECORD
-c2h_bt_info_req_sent	hal/btc/HalBtc8192e1Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8192e_1ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8192e2Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8192e_2ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8703b1Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8703b_1ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8723b1Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8723b_1ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8723b2Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8723b_2ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8812a1Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8812a_1ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8812a2Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8812a_2ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8821a1Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8821a_1ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8821a2Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8821a_2ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8821a_csr_2ant
-c2h_bt_info_req_sent	hal/btc/HalBtc8822b1Ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8822b_1ant
-c2h_bt_info_req_sent	hal/btc/halbtc8821c1ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8821c_1ant
-c2h_bt_info_req_sent	hal/btc/halbtc8821c2ant.h	/^	boolean					c2h_bt_info_req_sent;$/;"	m	struct:coex_sta_8821c_2ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8192e1Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8192e_1ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8192e2Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8192e_2ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8703b1Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8703b_1ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8723b1Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8723b_1ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8723b2Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8723b_2ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8812a1Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8812a_1ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8812a2Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8812a_2ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8821a1Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8821a_1ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8821a2Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8821a_2ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8821a_csr_2ant
-c2h_bt_inquiry_page	hal/btc/HalBtc8822b1Ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8822b_1ant
-c2h_bt_inquiry_page	hal/btc/halbtc8723d1ant.h	/^	boolean				c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8723d_1ant
-c2h_bt_inquiry_page	hal/btc/halbtc8723d2ant.h	/^	boolean				c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8723d_2ant
-c2h_bt_inquiry_page	hal/btc/halbtc8821c1ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8821c_1ant
-c2h_bt_inquiry_page	hal/btc/halbtc8821c2ant.h	/^	boolean					c2h_bt_inquiry_page;$/;"	m	struct:coex_sta_8821c_2ant
-c2h_bt_page	hal/btc/HalBtc8192e1Ant.h	/^	boolean					c2h_bt_page;				\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8192e_1ant
-c2h_bt_page	hal/btc/HalBtc8703b1Ant.h	/^	boolean					c2h_bt_page;				\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8703b_1ant
-c2h_bt_page	hal/btc/HalBtc8812a1Ant.h	/^	boolean					c2h_bt_page;				\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8812a_1ant
-c2h_bt_page	hal/btc/HalBtc8821a1Ant.h	/^	boolean					c2h_bt_page;				\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8821a_1ant
-c2h_bt_page	hal/btc/HalBtc8822b1Ant.h	/^	boolean					c2h_bt_page;				\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8822b_1ant
-c2h_bt_page	hal/btc/halbtc8723d1ant.h	/^	boolean				c2h_bt_page;				\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8723d_1ant
-c2h_bt_page	hal/btc/halbtc8821c1ant.h	/^	boolean					c2h_bt_page;				\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8821c_1ant
-c2h_bt_remote_name_req	hal/btc/HalBtc8723b1Ant.h	/^	boolean					c2h_bt_remote_name_req;$/;"	m	struct:coex_sta_8723b_1ant
-c2h_bt_remote_name_req	hal/btc/HalBtc8723b2Ant.h	/^	boolean					c2h_bt_remote_name_req;$/;"	m	struct:coex_sta_8723b_2ant
-c2h_bt_remote_name_req	hal/btc/halbtc8723d1ant.h	/^	boolean				c2h_bt_remote_name_req;$/;"	m	struct:coex_sta_8723d_1ant
-c2h_bt_remote_name_req	hal/btc/halbtc8723d2ant.h	/^	boolean				c2h_bt_remote_name_req;$/;"	m	struct:coex_sta_8723d_2ant
-c2h_bt_remote_name_req	hal/btc/halbtc8821c2ant.h	/^	boolean					c2h_bt_remote_name_req;$/;"	m	struct:coex_sta_8821c_2ant
-c2h_cmd_start	hal/phydm/phydm.h	/^	u1Byte			c2h_cmd_start;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-c2h_customer_str_rpt_2_hdl	hal/hal_com.c	/^int c2h_customer_str_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len)$/;"	f
-c2h_customer_str_rpt_hdl	hal/hal_com.c	/^int c2h_customer_str_rpt_hdl(_adapter *adapter, u8 *data, u8 len)$/;"	f
-c2h_defeature_dbg_hdl	hal/hal_com.c	/^int c2h_defeature_dbg_hdl(_adapter *adapter, u8 *data, u8 len)$/;"	f
-c2h_event	hal/btc/HalBtcOutSrc.h	/^	struct completion		c2h_event[COL_MAX_H2C_REQ_NUM];	\/* for req_num = 1~COL_MAX_H2C_REQ_NUM *\/$/;"	m	struct:_BTC_OFFLOAD	typeref:struct:_BTC_OFFLOAD::completion
-c2h_evt_clear	hal/hal_com.c	/^void c2h_evt_clear(_adapter *adapter)$/;"	f
-c2h_evt_hdl	core/rtw_cmd.c	/^s32 c2h_evt_hdl(_adapter *adapter, u8 *c2h_evt, c2h_id_filter filter)$/;"	f
-c2h_evt_read_88xx	hal/hal_com.c	/^s32 c2h_evt_read_88xx(_adapter *adapter, u8 *buf)$/;"	f
-c2h_handler	hal/hal_intf.c	/^s32 c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)$/;"	f
-c2h_handler	include/hal_intf.h	/^	s32(*c2h_handler)(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);$/;"	m	struct:hal_ops
-c2h_handler_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^s32 c2h_handler_8723d(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)$/;"	f
-c2h_id_filter	include/hal_intf.h	/^typedef s32(*c2h_id_filter)(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);$/;"	t
-c2h_ind_buf	hal/btc/HalBtcOutSrc.h	/^	u1Byte						c2h_ind_buf[COL_H2C_BUF_LEN];$/;"	m	struct:_BTC_OFFLOAD
-c2h_ind_len	hal/btc/HalBtcOutSrc.h	/^	u1Byte						c2h_ind_len;$/;"	m	struct:_BTC_OFFLOAD
-c2h_ind_record	hal/btc/HalBtcOutSrc.h	/^	COL_SINGLE_C2H_IND_RECORD	c2h_ind_record[COL_IND_MAX];$/;"	m	struct:_BTC_OFFLOAD
-c2h_ind_status	hal/btc/HalBtcOutSrc.h	/^	u4Byte						c2h_ind_status[COL_STATUS_MAX];$/;"	m	struct:_BTC_OFFLOAD
-c2h_iqk_offload	hal/hal_com.c	/^void c2h_iqk_offload(_adapter *adapter, u8 *data, u8 len)$/;"	f
-c2h_iqk_offload_wait	hal/hal_com.c	/^int c2h_iqk_offload_wait(_adapter *adapter, u32 timeout_ms)$/;"	f
-c2h_mac_hidden_rpt_2_hdl	hal/hal_com.c	/^int c2h_mac_hidden_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len)$/;"	f
-c2h_mac_hidden_rpt_hdl	hal/hal_com.c	/^int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)$/;"	f
-c2h_mem	include/rtw_cmd.h	/^	u8	*c2h_mem;$/;"	m	struct:evt_priv
-c2h_queue	include/rtw_cmd.h	/^	struct rtw_cbuf *c2h_queue;$/;"	m	struct:evt_priv	typeref:struct:evt_priv::rtw_cbuf
-c2h_set	include/rtw_mp.h	/^	NDIS_EVENT c2h_set;$/;"	m	struct:mp_priv
-c2h_wk	include/rtw_cmd.h	/^	_workitem c2h_wk;$/;"	m	struct:evt_priv
-c2h_wk_alive	include/rtw_cmd.h	/^	bool c2h_wk_alive;$/;"	m	struct:evt_priv
-c2h_wk_callback	core/rtw_cmd.c	/^static void c2h_wk_callback(_workitem *work)$/;"	f	file:
-c2hevent_queue	include/rtw_event.h	/^struct c2hevent_queue {$/;"	s
-c2hlbk_event	include/rtw_event.h	/^struct c2hlbk_event {$/;"	s
-cAPSD	include/rtw_rf.h	/^	cAPSD			= 0x0800,$/;"	e	enum:_CAPABILITY
-cChannelAgility	include/rtw_rf.h	/^	cChannelAgility	= 0x0080,$/;"	e	enum:_CAPABILITY
-cDSSS_OFDM	include/rtw_rf.h	/^	cDSSS_OFDM	= 0x2000,$/;"	e	enum:_CAPABILITY
-cDelayedBA	include/rtw_rf.h	/^	cDelayedBA		= 0x4000,$/;"	e	enum:_CAPABILITY
-cESS	include/rtw_rf.h	/^	cESS			= 0x0001,$/;"	e	enum:_CAPABILITY
-cIBSS	include/rtw_rf.h	/^	cIBSS			= 0x0002,$/;"	e	enum:_CAPABILITY
-cImmediateBA	include/rtw_rf.h	/^	cImmediateBA	= 0x8000,$/;"	e	enum:_CAPABILITY
-cPBCC	include/rtw_rf.h	/^	cPBCC			= 0x0040,$/;"	e	enum:_CAPABILITY
-cPollReq	include/rtw_rf.h	/^	cPollReq			= 0x0008,$/;"	e	enum:_CAPABILITY
-cPollable	include/rtw_rf.h	/^	cPollable		= 0x0004,$/;"	e	enum:_CAPABILITY
-cPrivacy	include/rtw_rf.h	/^	cPrivacy		= 0x0010,$/;"	e	enum:_CAPABILITY
-cQos	include/rtw_rf.h	/^	cQos			= 0x0200,	\/* For HCCA, use with CF-Pollable and CF-PollReq *\/$/;"	e	enum:_CAPABILITY
-cRM	include/rtw_rf.h	/^	cRM				= 0x1000,	\/* RRM (Radio Request Measurement) *\/$/;"	e	enum:_CAPABILITY
-cShortPreamble	include/rtw_rf.h	/^	cShortPreamble	= 0x0020,$/;"	e	enum:_CAPABILITY
-cShortSlotTime	include/rtw_rf.h	/^	cShortSlotTime	= 0x0400,$/;"	e	enum:_CAPABILITY
-cSpectrumMgnt	include/rtw_rf.h	/^	cSpectrumMgnt	= 0x0100,$/;"	e	enum:_CAPABILITY
-cac_end_time	include/drv_types.h	/^	u32 cac_end_time;$/;"	m	struct:rf_ctl_t
-cac_start_time	include/drv_types.h	/^	u32 cac_start_time;$/;"	m	struct:rf_ctl_t
-cal_txdesc_chksum	os_dep/linux/ioctl_linux.c	11772;"	d	file:
-cal_txdesc_chksum	os_dep/linux/ioctl_linux.c	11780;"	d	file:
-cal_txdesc_chksum	os_dep/linux/ioctl_linux.c	11787;"	d	file:
-cal_txdesc_chksum	os_dep/linux/ioctl_linux.c	11794;"	d	file:
-cal_txdesc_chksum	os_dep/linux/ioctl_linux.c	11801;"	d	file:
-callback	include/drv_types.h	/^		void (*callback[8])(u8 level);$/;"	m	struct:_ADAPTER::gpio_int_priv
-callback	include/rtw_cmd.h	/^	void (*callback)(_adapter  *padapter, struct cmd_obj *cmd);$/;"	m	struct:_cmd_callback
-caller_ff_sz	include/rtw_event.h	/^	int	caller_ff_sz;$/;"	m	struct:event_node
-caller_ff_tail	include/rtw_event.h	/^	volatile int	*caller_ff_tail;$/;"	m	struct:event_node
-callout	include/osdep_service_bsd.h	/^        struct callout callout;$/;"	m	struct:timer_list	typeref:struct:timer_list::callout
-cam_cache	include/drv_types.h	/^	struct sec_cam_ent cam_cache[SEC_CAM_ENT_NUM_SW_LIMIT];$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::sec_cam_ent
-cam_cache_chk	core/rtw_wlan_util.c	/^bool cam_cache_chk(_adapter *adapter, u8 id, u8 *addr, s16 kid, s8 gk)$/;"	f
-cam_ctl	include/drv_types.h	/^	struct cam_ctl_t cam_ctl;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::cam_ctl_t
-cam_ctl_t	include/drv_types.h	/^struct cam_ctl_t {$/;"	s
-cam_id	include/rtw_cmd.h	/^	u8	cam_id;$/;"	m	struct:set_assocsta_rsp
-cancel_ro_ch_handler	core/rtw_p2p.c	/^static int cancel_ro_ch_handler(_adapter *padapter, u8 *buf)$/;"	f	file:
-cancel_thread	include/hal_intf.h	/^	void	(*cancel_thread)(_adapter *padapter);$/;"	m	struct:hal_ops
-candidate_mu_bfee_cnt	include/rtw_beamforming.h	/^	u8			candidate_mu_bfee_cnt;$/;"	m	struct:sounding_info
-candidate_tid_bitmap	include/rtw_ht.h	/^	u8	candidate_tid_bitmap;$/;"	m	struct:ht_priv
-candidate_tid_bitmap	include/rtw_mlme_ext.h	/^	u8	candidate_tid_bitmap;$/;"	m	struct:mlme_ext_info
-cap	include/rtw_beamforming.h	/^	BEAMFORMING_CAP cap;$/;"	m	struct:beamformee_entry
-cap	include/rtw_beamforming.h	/^	BEAMFORMING_CAP cap;$/;"	m	struct:beamformer_entry
-cap_CFPollable	include/wifi.h	715;"	d
-cap_CFRequest	include/wifi.h	716;"	d
-cap_ChAgility	include/wifi.h	720;"	d
-cap_ESS	include/wifi.h	713;"	d
-cap_IBSS	include/wifi.h	714;"	d
-cap_PBCC	include/wifi.h	719;"	d
-cap_Privacy	include/wifi.h	717;"	d
-cap_QoS	include/wifi.h	722;"	d
-cap_ShortPremble	include/wifi.h	718;"	d
-cap_ShortSlot	include/wifi.h	723;"	d
-cap_SpecMgmt	include/wifi.h	721;"	d
-cap_info	include/wifi.h	/^	unsigned short	cap_info;$/;"	m	struct:rtw_ieee80211_ht_cap
-capab	include/ieee80211_ext.h	/^					u16 capab;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon36
-capab	include/ieee80211_ext.h	/^					u16 capab;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon37
-capab	include/ieee80211_ext.h	/^					u16 capab;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon21
-capab	include/ieee80211_ext.h	/^					u16 capab;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon22
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon29
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon30
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon31
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon11
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon12
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon13
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon15
-capab_info	include/ieee80211_ext.h	/^			u16 capab_info;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon17
-capability	include/ieee80211.h	/^			u16 capability;$/;"	m	struct:ieee_param::__anon73::__anon78
-capability	include/ieee80211.h	/^	u16 capability;$/;"	m	struct:ieee80211_assoc_request_frame
-capability	include/ieee80211.h	/^	u16 capability;$/;"	m	struct:ieee80211_assoc_response_frame
-capability	include/ieee80211.h	/^	u16 capability;$/;"	m	struct:ieee80211_probe_response
-capability	include/ieee80211.h	/^	u16 capability;$/;"	m	struct:sta_data
-capability	include/rtw_mlme_ext.h	/^	u16	capability;$/;"	m	struct:mlme_ext_info
-capability	include/sta_info.h	/^	u16 capability;$/;"	m	struct:sta_info
-card_intf	include/drv_types_sdio.h	/^	SD_CARD_INTERFACE			card_intf;$/;"	m	struct:sdio_data
-category	include/ieee80211_ext.h	/^			u8 category;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33
-category	include/ieee80211_ext.h	/^			u8 category;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18
-cca_rts	include/rtl8821a_xmit.h	/^	u32 cca_rts:2;$/;"	m	struct:txdescriptor_8821a
-cch_20	include/hal_data.h	/^	u8				cch_20;$/;"	m	struct:hal_com_data
-cch_40	include/hal_data.h	/^	u8				cch_40;$/;"	m	struct:hal_com_data
-cch_80	include/hal_data.h	/^	u8				cch_80;$/;"	m	struct:hal_com_data
-cckFaMa	hal/phydm/phydm_dig.h	/^	u4Byte		cckFaMa;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-cck_agc_report_type	hal/phydm/phydm.h	/^	BOOLEAN			cck_agc_report_type;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-cck_agc_rpt_ofdm_cfosho_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte	cck_agc_rpt_ofdm_cfosho_a;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-cck_block_enable	hal/phydm/phydm_dig.h	/^	BOOLEAN		cck_block_enable;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cck_ever_lock	hal/btc/HalBtc8703b1Ant.h	/^	boolean					cck_ever_lock;$/;"	m	struct:coex_sta_8703b_1ant
-cck_ever_lock	hal/btc/HalBtc8723b1Ant.h	/^	boolean					cck_ever_lock;$/;"	m	struct:coex_sta_8723b_1ant
-cck_ever_lock	hal/btc/HalBtc8822b1Ant.h	/^	boolean					cck_ever_lock;$/;"	m	struct:coex_sta_8822b_1ant
-cck_ever_lock	hal/btc/halbtc8723d1ant.h	/^	boolean				cck_ever_lock;$/;"	m	struct:coex_sta_8723d_1ant
-cck_ever_lock	hal/btc/halbtc8723d2ant.h	/^	boolean				cck_ever_lock;$/;"	m	struct:coex_sta_8723d_2ant
-cck_ever_lock	hal/btc/halbtc8821c1ant.h	/^	boolean					cck_ever_lock;$/;"	m	struct:coex_sta_8821c_1ant
-cck_ever_lock	hal/btc/halbtc8821c2ant.h	/^	boolean					cck_ever_lock;$/;"	m	struct:coex_sta_8821c_2ant
-cck_lna_idx	hal/phydm/phydm.h	/^	u1Byte			cck_lna_idx;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-cck_lock	hal/btc/HalBtc8192e1Ant.h	/^	boolean					cck_lock;$/;"	m	struct:coex_sta_8192e_1ant
-cck_lock	hal/btc/HalBtc8703b1Ant.h	/^	boolean					cck_lock;$/;"	m	struct:coex_sta_8703b_1ant
-cck_lock	hal/btc/HalBtc8723b1Ant.h	/^	boolean					cck_lock;$/;"	m	struct:coex_sta_8723b_1ant
-cck_lock	hal/btc/HalBtc8812a1Ant.h	/^	boolean					cck_lock;$/;"	m	struct:coex_sta_8812a_1ant
-cck_lock	hal/btc/HalBtc8822b1Ant.h	/^	boolean					cck_lock;$/;"	m	struct:coex_sta_8822b_1ant
-cck_lock	hal/btc/halbtc8723d1ant.h	/^	boolean				cck_lock;$/;"	m	struct:coex_sta_8723d_1ant
-cck_lock	hal/btc/halbtc8723d2ant.h	/^	boolean				cck_lock;$/;"	m	struct:coex_sta_8723d_2ant
-cck_lock	hal/btc/halbtc8821c1ant.h	/^	boolean					cck_lock;$/;"	m	struct:coex_sta_8821c_1ant
-cck_lock	hal/btc/halbtc8821c2ant.h	/^	boolean					cck_lock;$/;"	m	struct:coex_sta_8821c_2ant
-cck_new_agc	hal/phydm/phydm.h	/^	BOOLEAN			cck_new_agc;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-cck_rpt_b_ofdm_cfosho_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte	cck_rpt_b_ofdm_cfosho_b;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-cck_sig_qual_ofdm_pwdb_all	hal/phydm/phydm_hwconfig.h	/^	u1Byte	cck_sig_qual_ofdm_pwdb_all;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-cck_txrx	include/rtw_cmd.h	/^	u8 cck_txrx;$/;"	m	struct:SwitchAntenna_parm
-cck_vga_idx	hal/phydm/phydm.h	/^	u1Byte			cck_vga_idx;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-cckrates_included	core/rtw_wlan_util.c	/^int cckrates_included(unsigned char *rate, int ratelen)$/;"	f
-cckratesonly_included	core/rtw_wlan_util.c	/^int cckratesonly_included(unsigned char *rate, int ratelen)$/;"	f
-ccx	include/rtl8188e_xmit.h	/^	u32 ccx:1;$/;"	m	struct:txdesc_88e
-ccx	include/rtl8192e_xmit.h	/^	u32 ccx:1;$/;"	m	struct:txdescriptor_8192e
-ccx	include/rtl8812a_xmit.h	/^	u32 ccx:1;$/;"	m	struct:txdescriptor_8812
-ccx_qtime0	include/rtl8188e_xmit.h	/^	u8 ccx_qtime0;$/;"	m	struct:txrpt_ccx_88e
-ccx_qtime0	include/rtl8192e_xmit.h	/^	u8 ccx_qtime0;$/;"	m	struct:txrpt_ccx_92e
-ccx_qtime1	include/rtl8188e_xmit.h	/^	u8 ccx_qtime1;$/;"	m	struct:txrpt_ccx_88e
-ccx_qtime1	include/rtl8192e_xmit.h	/^	u8 ccx_qtime1;$/;"	m	struct:txrpt_ccx_92e
-ceil	core/rtw_mp.c	34;"	d	file:
-center_ch_2g	core/rtw_rf.c	/^u8 center_ch_2g[CENTER_CH_2G_NUM] = {$/;"	v
-center_ch_2g_40m	core/rtw_rf.c	/^u8 center_ch_2g_40m[CENTER_CH_2G_40M_NUM] = {$/;"	v
-center_ch_5g_160m	core/rtw_rf.c	/^u8 center_ch_5g_160m[CENTER_CH_5G_160M_NUM] = {$/;"	v
-center_ch_5g_20m	core/rtw_rf.c	/^u8 center_ch_5g_20m[CENTER_CH_5G_20M_NUM] = {$/;"	v
-center_ch_5g_20m_40m	core/rtw_rf.c	/^u8 center_ch_5g_20m_40m[CENTER_CH_5G_20M_NUM + CENTER_CH_5G_40M_NUM] = {$/;"	v
-center_ch_5g_40m	core/rtw_rf.c	/^u8 center_ch_5g_40m[CENTER_CH_5G_40M_NUM] = {$/;"	v
-center_ch_5g_80m	core/rtw_rf.c	/^u8 center_ch_5g_80m[CENTER_CH_5G_80M_NUM] = {$/;"	v
-center_ch_5g_all	core/rtw_rf.c	/^u8 center_ch_5g_all[CENTER_CH_5G_ALL_NUM] = {$/;"	v
-center_chs_2g	core/rtw_rf.c	/^inline u8 center_chs_2g(u8 bw, u8 id)$/;"	f
-center_chs_2g_by_bw	core/rtw_rf.c	/^struct center_chs_ent_t center_chs_2g_by_bw[] = {$/;"	v	typeref:struct:center_chs_ent_t
-center_chs_2g_num	core/rtw_rf.c	/^inline u8 center_chs_2g_num(u8 bw)$/;"	f
-center_chs_5g	core/rtw_rf.c	/^inline u8 center_chs_5g(u8 bw, u8 id)$/;"	f
-center_chs_5g_by_bw	core/rtw_rf.c	/^struct center_chs_ent_t center_chs_5g_by_bw[] = {$/;"	v	typeref:struct:center_chs_ent_t
-center_chs_5g_num	core/rtw_rf.c	/^inline u8 center_chs_5g_num(u8 bw)$/;"	f
-center_chs_ent_t	core/rtw_rf.c	/^struct center_chs_ent_t {$/;"	s	file:
-central_chnl	include/hal_data.h	/^	u8 central_chnl;$/;"	m	struct:hal_iqk_reg_backup
-cf_params	include/ieee80211.h	/^	u8 *cf_params;$/;"	m	struct:rtw_ieee802_11_elems
-cf_params_len	include/ieee80211.h	/^	u8 cf_params_len;$/;"	m	struct:rtw_ieee802_11_elems
-cfg80211_rtw_add_beacon	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_add_beacon(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_add_key	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_add_station	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_add_station(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_add_virtual_intf	os_dep/linux/ioctl_cfg80211.c	/^	cfg80211_rtw_add_virtual_intf($/;"	f	file:
-cfg80211_rtw_assoc	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_assoc(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_auth	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_auth(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_cancel_remain_on_channel	os_dep/linux/ioctl_cfg80211.c	/^static s32 cfg80211_rtw_cancel_remain_on_channel(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_change_beacon	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_change_beacon(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_change_bss	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_change_iface	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_change_iface(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_change_station	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_change_station(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_connect	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_del_beacon	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_del_beacon(struct wiphy *wiphy, struct net_device *ndev)$/;"	f	file:
-cfg80211_rtw_del_key	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_del_pmksa	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_del_pmksa(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_del_station	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_del_station(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_del_virtual_intf	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_del_virtual_intf(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_disconnect	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_dump_station	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_dump_station(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_flush_pmksa	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_flush_pmksa(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_get_key	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_get_key(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_get_station	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_get_station(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_get_txpower	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_get_txpower(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_join_ibss	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_join_ibss(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_leave_ibss	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_leave_ibss(struct wiphy *wiphy, struct net_device *ndev)$/;"	f	file:
-cfg80211_rtw_mgmt_frame_register	os_dep/linux/ioctl_cfg80211.c	/^static void cfg80211_rtw_mgmt_frame_register(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_mgmt_tx	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_remain_on_channel	os_dep/linux/ioctl_cfg80211.c	/^static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_scan	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_scan(struct wiphy *wiphy$/;"	f	file:
-cfg80211_rtw_sched_scan_start	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_sched_scan_start(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_sched_scan_stop	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_sched_scan_stop(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_set_beacon	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_beacon(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_set_channel	os_dep/linux/ioctl_cfg80211.c	/^static int	cfg80211_rtw_set_channel(struct wiphy *wiphy$/;"	f	file:
-cfg80211_rtw_set_default_key	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_default_key(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_set_mac_acl	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_mac_acl(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_set_monitor_channel	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_monitor_channel(struct wiphy *wiphy$/;"	f	file:
-cfg80211_rtw_set_pmksa	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_pmksa(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_set_power_mgmt	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_power_mgmt(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_set_rekey_data	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_rekey_data(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_set_txpower	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_txpower(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_set_wiphy_params	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_set_wiphy_params(struct wiphy *wiphy, u32 changed)$/;"	f	file:
-cfg80211_rtw_start_ap	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_start_ap(struct wiphy *wiphy, struct net_device *ndev,$/;"	f	file:
-cfg80211_rtw_start_p2p_device	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_start_p2p_device(struct wiphy *wiphy, struct wireless_dev *wdev)$/;"	f	file:
-cfg80211_rtw_stop_ap	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_stop_ap(struct wiphy *wiphy, struct net_device *ndev)$/;"	f	file:
-cfg80211_rtw_stop_p2p_device	os_dep/linux/ioctl_cfg80211.c	/^static void cfg80211_rtw_stop_p2p_device(struct wiphy *wiphy, struct wireless_dev *wdev)$/;"	f	file:
-cfg80211_rtw_tdls_mgmt	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_tdls_mgmt(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_tdls_oper	os_dep/linux/ioctl_cfg80211.c	/^static int cfg80211_rtw_tdls_oper(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_rtw_update_ft_ies	os_dep/linux/ioctl_cfg80211.c	/^static s32 cfg80211_rtw_update_ft_ies(struct wiphy *wiphy,$/;"	f	file:
-cfg80211_wdinfo	include/drv_types.h	/^	struct cfg80211_wifidirect_info	cfg80211_wdinfo;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::cfg80211_wifidirect_info
-cfg80211_wifidirect_info	include/rtw_mlme.h	/^struct cfg80211_wifidirect_info {$/;"	s
-cfo_tail	hal/phydm/phydm_hwconfig.h	/^	s1Byte		cfo_tail[4];			\/* s(8,7) *\/$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-cfosho	hal/phydm/phydm_hwconfig.h	/^	s1Byte			cfosho[2];		\/*DW1 byte 1 DW1 byte2	CCK AGC report and CCK_BB_Power \/ OFDM Path-A and Path-B short CFO*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-cfotail	hal/phydm/phydm_hwconfig.h	/^	s1Byte			cfotail[2];		   \/*DW2 byte 1 DW2 byte 2	path-A and path-B CFO tail*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-ch	include/hal_data.h	/^	u8	ch; \/* previous channel*\/$/;"	m	struct:auto_chan_sel
-ch	include/rtw_cmd.h	/^	struct ieee80211_channel ch;$/;"	m	struct:p2p_roch_parm	typeref:struct:p2p_roch_parm::ieee80211_channel
-ch	include/rtw_cmd.h	/^	struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];$/;"	m	struct:sitesurvey_parm	typeref:struct:sitesurvey_parm::rtw_ieee80211_channel
-ch	include/rtw_cmd.h	/^	u8 ch;$/;"	m	struct:set_ch_parm
-ch	include/rtw_mlme_ext.h	/^	struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];$/;"	m	struct:ss_res	typeref:struct:ss_res::rtw_ieee80211_channel
-ch	include/rtw_recv.h	/^	u8 ch; \/* RX channel *\/$/;"	m	struct:rx_pkt_attrib
-ch_corr	hal/phydm/phydm_hwconfig.h	/^	u1Byte	ch_corr[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-ch_g	include/drv_types.h	/^	struct macid_bmp ch_g[2]; \/* 2 ch concurrency *\/$/;"	m	struct:macid_ctl_t	typeref:struct:macid_ctl_t::macid_bmp
-ch_list_t	include/rtw_mlme_ext.h	/^struct ch_list_t {$/;"	s
-ch_num	core/rtw_rf.c	/^	u8 ch_num;$/;"	m	struct:center_chs_ent_t	file:
-ch_num	core/rtw_rf.c	/^	u8 ch_num;$/;"	m	struct:op_chs_ent_t	file:
-ch_num	include/rtw_cmd.h	/^	u8 ch_num;$/;"	m	struct:sitesurvey_parm
-ch_num	include/rtw_mlme_ext.h	/^	u8 ch_num;$/;"	m	struct:ss_res
-ch_offset	include/rtw_cmd.h	/^	u8 ch_offset;$/;"	m	struct:set_ch_parm
-ch_offset	include/rtw_ht.h	/^	u8	ch_offset;\/* PRIME_CHNL_OFFSET *\/$/;"	m	struct:ht_priv
-ch_offset	include/rtw_mlme.h	/^	u8	ch_offset;$/;"	m	struct:tdls_ch_switch
-ch_offset	include/rtw_xmit.h	/^	u8	ch_offset;\/* PRIME_CHNL_OFFSET *\/$/;"	m	struct:pkt_attrib
-ch_sensing	include/rtw_mlme.h	/^	u8					ch_sensing;$/;"	m	struct:tdls_info
-ch_sw_monitor_timer	include/sta_info.h	/^	_timer	ch_sw_monitor_timer;$/;"	m	struct:sta_info
-ch_sw_state	include/rtw_mlme.h	/^	u32	ch_sw_state;$/;"	m	struct:tdls_ch_switch
-ch_sw_timer	include/sta_info.h	/^	_timer	ch_sw_timer;$/;"	m	struct:sta_info
-ch_switch_prohibited	include/rtw_mlme.h	/^	u8					ch_switch_prohibited;$/;"	m	struct:tdls_info
-ch_switch_time	include/sta_info.h	/^	u16	ch_switch_time;$/;"	m	struct:sta_info
-ch_switch_timeout	include/sta_info.h	/^	u16	ch_switch_timeout;$/;"	m	struct:sta_info
-ch_type	include/rtw_cmd.h	/^	enum nl80211_channel_type ch_type;$/;"	m	struct:p2p_roch_parm	typeref:enum:p2p_roch_parm::nl80211_channel_type
-ch_width_str	include/rtw_rf.h	173;"	d
-ch_width_to_bw_cap	include/rtw_rf.h	176;"	d
-chaddr	core/rtw_br_ext.c	/^	u_int8_t chaddr[16];$/;"	m	struct:dhcpMessage	file:
-challenge	include/ieee80211.h	/^	u8 *challenge;$/;"	m	struct:rtw_ieee802_11_elems
-challenge_len	include/ieee80211.h	/^	u8 challenge_len;$/;"	m	struct:rtw_ieee802_11_elems
-chan	include/hal_com.h	/^	u8		chan;$/;"	m	struct:noise_info
-change_band_update_ie	core/rtw_mlme_ext.c	/^void change_band_update_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 ch)$/;"	f
-change_rfpwrstate	include/rtw_pwrctrl.h	/^	rt_rf_power_state	change_rfpwrstate;$/;"	m	struct:pwrctrl_priv
-channel	hal/phydm/phydm.h	/^	u1Byte		channel;						\/* channel number---*\/$/;"	m	struct:_ODM_Phy_Status_Info_
-channel	hal/phydm/phydm_hwconfig.h	/^	u1Byte		channel;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-channel	hal/phydm/phydm_hwconfig.h	/^	u1Byte		channel;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-channel	hal/phydm/phydm_hwconfig.h	/^	u1Byte		channel;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-channel	include/drv_types.h	/^	u8	channel;\/* ad-hoc support requirement *\/$/;"	m	struct:registry_priv
-channel	include/rtw_mlme_ext.h	/^		u8 channel[P2P_MAX_REG_CLASS_CHANNELS];$/;"	m	struct:p2p_channels::p2p_reg_class
-channel	include/rtw_mp.h	/^	u8 channel;$/;"	m	struct:mp_priv
-channel	include/rtw_pwrctrl.h	/^	u8	channel;$/;"	m	struct:pno_scan_channel_info
-channel	include/rtw_recv.h	/^	u8			channel;						\/* channel number---*\/$/;"	m	struct:phy_info
-channel_cck_power	include/rtw_rf.h	/^	u8	channel_cck_power[MAX_CHANNEL_NUM];\/* dbm *\/$/;"	m	struct:regulatory_class
-channel_idx	include/rtw_mlme.h	/^	u8	channel_idx;$/;"	m	struct:mlme_priv
-channel_idx	include/rtw_mlme_ext.h	/^	int	channel_idx;$/;"	m	struct:ss_res
-channel_list	include/rtw_mlme_ext.h	/^	struct p2p_channels channel_list;$/;"	m	struct:mlme_ext_priv	typeref:struct:mlme_ext_priv::p2p_channels
-channel_list_attr	include/rtw_mlme.h	/^	u8						channel_list_attr[100];		\/*	This field will contain the body of P2P Channel List attribute of group negotitation response frame. *\/$/;"	m	struct:wifidirect_info
-channel_list_attr_len	include/rtw_mlme.h	/^	uint						channel_list_attr_len;	\/*	This field will contain the length of body of P2P Channel List attribute of group negotitation response frame. *\/$/;"	m	struct:wifidirect_info
-channel_num	include/rtw_pwrctrl.h	/^	u8	channel_num;			\/* number of channel *\/$/;"	m	struct:pno_scan_info
-channel_ofdm_power	include/rtw_rf.h	/^	u8	channel_ofdm_power[MAX_CHANNEL_NUM];\/* dbm *\/$/;"	m	struct:regulatory_class
-channel_plan	include/drv_types.h	/^	u8	channel_plan;$/;"	m	struct:registry_priv
-channel_plan	include/rtw_cmd.h	/^	u8 channel_plan;$/;"	m	struct:SetChannelPlan_param
-channel_set	include/rtw_mlme_ext.h	/^	RT_CHANNEL_INFO		channel_set[MAX_CHANNEL_NUM];$/;"	m	struct:mlme_ext_priv
-channel_set	include/rtw_rf.h	/^	u8	channel_set[MAX_CHANNEL_NUM];$/;"	m	struct:regulatory_class
-channel_spacing	include/rtw_rf.h	/^	u8	channel_spacing;				\/* MHz *\/$/;"	m	struct:regulatory_class
-channels	include/rtw_mlme_ext.h	/^		size_t channels;$/;"	m	struct:p2p_channels::p2p_reg_class
-check	include/ip.h	/^	__u16	check;$/;"	m	struct:iphdr
-checkIPMcAndReplace	core/rtw_br_ext.c	/^static int checkIPMcAndReplace(_adapter *priv, struct sk_buff *skb, unsigned int *dst_ip)$/;"	f	file:
-check_32k_lock	include/rtw_pwrctrl.h	/^	_pwrlock	check_32k_lock;$/;"	m	struct:pwrctrl_priv
-check_ap_tdls_ch_switching_prohibited	core/rtw_tdls.c	/^int check_ap_tdls_ch_switching_prohibited(u8 *pframe, u8 pkt_len)$/;"	f
-check_ap_tdls_prohibited	core/rtw_tdls.c	/^int check_ap_tdls_prohibited(u8 *pframe, u8 pkt_len)$/;"	f
-check_assoc_AP	core/rtw_wlan_util.c	/^unsigned char check_assoc_AP(u8 *pframe, uint len)$/;"	f
-check_fw_ps	include/drv_types.h	/^	u8  check_fw_ps;$/;"	m	struct:registry_priv
-check_fwstate	include/rtw_mlme.h	/^__inline static sint check_fwstate(struct mlme_priv *pmlmepriv, sint state)$/;"	f
-check_hw_status	include/drv_types.h	/^	u8 check_hw_status;$/;"	m	struct:registry_priv
-check_indicate_seq	core/rtw_recv.c	/^int check_indicate_seq(struct recv_reorder_ctrl *preorder_ctrl, u16 seq_num)$/;"	f
-check_ips_status	include/hal_intf.h	/^	u8(*check_ips_status)(_adapter *padapter);$/;"	m	struct:hal_ops
-check_mlmeinfo_state	include/rtw_mlme_ext.h	/^static inline u8 check_mlmeinfo_state(struct mlme_ext_priv *plmeext, sint state)$/;"	f
-check_mp_pkt	include/rtw_mp.h	/^	u8 check_mp_pkt;$/;"	m	struct:mp_priv
-check_pending_xmitbuf	core/rtw_xmit.c	/^sint check_pending_xmitbuf($/;"	f
-check_phy_efuse_tx_power_info_valid	hal/hal_com.c	/^int check_phy_efuse_tx_power_info_valid(PADAPTER padapter)$/;"	f
-checksum	include/rtl8188e_xmit.h	/^	u32 checksum:16;	\/* TxBuffSize(PCIe)\/CheckSum(USB) *\/$/;"	m	struct:txdesc_88e
-checksum	include/rtl8192e_xmit.h	/^	u32 checksum:16;	\/* TxBuffSize(PCIe)\/CheckSum(USB) *\/$/;"	m	struct:txdescriptor_8192e
-checksum	include/rtl8812a_xmit.h	/^	u32 checksum:16;	\/* TxBuffSize(PCIe)\/CheckSum(USB) *\/$/;"	m	struct:txdescriptor_8812
-checksum	include/rtl8821a_xmit.h	/^	u32 checksum:16;$/;"	m	struct:txdescriptor_8821a
-chg_txt	include/rtw_mlme_ext.h	/^	u8	chg_txt[128];$/;"	m	struct:mlme_ext_info
-chg_txt	include/sta_info.h	/^	unsigned char chg_txt[128];$/;"	m	struct:sta_info
-chip_interface	hal/btc/HalBtcOutSrc.h	/^	BTC_CHIP_INTERFACE		chip_interface;$/;"	m	struct:btc_coexist
-chip_type	include/drv_types.h	/^	u8	chip_type;$/;"	m	struct:dvobj_priv
-chip_type_to_odm_ic_type	include/hal_intf.h	49;"	d
-chip_version	include/drv_types.h	/^	u8	chip_version;$/;"	m	struct:registry_priv
-chk_adhoc_peer_is_alive	core/rtw_mlme_ext.c	/^u8 chk_adhoc_peer_is_alive(struct sta_info *psta)$/;"	f
-chk_ap_is_alive	core/rtw_mlme_ext.c	/^u8 chk_ap_is_alive(_adapter *padapter, struct sta_info *psta)$/;"	f
-chk_bmc_sleepq_cmd	core/rtw_mlme_ext.c	/^u8 chk_bmc_sleepq_cmd(_adapter *padapter)$/;"	f
-chk_bmc_sleepq_hdl	core/rtw_mlme_ext.c	/^u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-chk_en	include/rtl8821a_xmit.h	/^	u32 chk_en:1;$/;"	m	struct:txdescriptor_8821a
-chk_sta_is_alive	core/rtw_ap.c	/^u8 chk_sta_is_alive(struct sta_info *psta)$/;"	f
-chk_tdls_peer_sta_is_alive	core/rtw_mlme_ext.c	/^u8 chk_tdls_peer_sta_is_alive(_adapter *padapter, struct sta_info *psta)$/;"	f
-chl_num_LSB	hal/phydm/phydm_hwconfig.h	/^	u1Byte			chl_num_LSB;							\/*channel number[7:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-chl_num_MSB	hal/phydm/phydm_hwconfig.h	/^	u1Byte			chl_num_MSB: 2;							\/*channel number[9:8]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-chl_num_MSB	hal/phydm/phydm_hwconfig.h	/^	u1Byte			chl_num_MSB: 2;$/;"	m	struct:_Phy_Status_Rpt_8812
-chplan	include/rtw_rf.h	/^	u8 chplan;$/;"	m	struct:country_chplan
-chs	core/rtw_rf.c	/^	u8 *chs;$/;"	m	struct:center_chs_ent_t	file:
-chs	core/rtw_rf.c	/^	u8 *chs;$/;"	m	struct:op_chs_ent_t	file:
-chsw_info	include/rtw_mlme.h	/^	struct tdls_ch_switch	chsw_info;$/;"	m	struct:tdls_info	typeref:struct:tdls_info::tdls_ch_switch
-chsw_on	include/rtw_mlme.h	/^	ATOMIC_T	chsw_on;$/;"	m	struct:tdls_ch_switch
-chsw_sctx	include/rtw_mlme.h	/^	struct submit_ctx	chsw_sctx;$/;"	m	struct:tdls_ch_switch	typeref:struct:tdls_ch_switch::submit_ctx
-ciaddr	core/rtw_br_ext.c	/^	u_int32_t ciaddr;$/;"	m	struct:dhcpMessage	file:
-cid	core/rtw_cmd.c	/^	u8 cid;$/;"	m	struct:btinfo	file:
-cid	include/rtw_btcoex.h	/^	u8 cid;$/;"	m	struct:btinfo_8761ATV
-ciscoAP	include/rtw_mlme_ext.h	/^	ciscoAP		= 2,$/;"	e	enum:Associated_AP
-class_sets	include/rtw_cmd.h	/^	struct regulatory_class class_sets[NUM_REGULATORYS];$/;"	m	struct:getphyinfo_rsp	typeref:struct:getphyinfo_rsp::regulatory_class
-class_sets	include/rtw_cmd.h	/^	struct regulatory_class class_sets[NUM_REGULATORYS];$/;"	m	struct:setphyinfo_parm	typeref:struct:setphyinfo_parm::regulatory_class
-clear_cam_cache	core/rtw_wlan_util.c	/^void clear_cam_cache(_adapter *adapter, u8 id)$/;"	f
-clear_cam_entry	core/rtw_wlan_util.c	/^inline void clear_cam_entry(_adapter *adapter, u8 id)$/;"	f
-clear_interrupt	include/hal_intf.h	/^	void (*clear_interrupt)(_adapter *padapter);$/;"	m	struct:hal_ops
-clear_mbssid_cam	hal/hal_com.c	/^static void clear_mbssid_cam(_adapter *padapter, u8 cam_addr)$/;"	f	file:
-cli_buf	hal/btc/HalBtcOutSrc.h	/^	pu1Byte					cli_buf;$/;"	m	struct:btc_coexist
-clnt_sa_query_timeout	core/rtw_mlme_ext.c	/^void clnt_sa_query_timeout(_adapter *padapter)$/;"	f
-clock	include/drv_types_sdio.h	/^	unsigned int clock;$/;"	m	struct:sdio_data
-cloned	include/osdep_service_bsd.h	/^				cloned:1,$/;"	m	struct:sk_buff
-closeFile	os_dep/osdep_service.c	/^static int closeFile(struct file *fp)$/;"	f	file:
-clr_fwstate	include/rtw_mlme.h	/^static inline void clr_fwstate(struct mlme_priv *pmlmepriv, sint state)$/;"	f
-cmd	include/HalPwrSeqCmd.h	/^	u8 cmd:4;$/;"	m	struct:_WL_PWR_CFG_
-cmd	include/ieee80211.h	/^	u32 cmd;$/;"	m	struct:ieee_param
-cmd	include/ieee80211.h	/^	u32 cmd;$/;"	m	struct:ieee_param_ex
-cmd	include/rtw_iol.h	/^	u8 cmd;$/;"	m	struct:_io_offload_cmd
-cmd	include/sta_info.h	/^	u8 cmd;$/;"	m	struct:st_cmd_parm
-cmdThread	include/drv_types.h	/^	_thread_hdl_ cmdThread;$/;"	m	struct:_ADAPTER
-cmd_allocated_buf	include/rtw_cmd.h	/^	u8	*cmd_allocated_buf;$/;"	m	struct:cmd_priv
-cmd_buf	include/rtw_cmd.h	/^	u8	*cmd_buf;	\/* shall be non-paged, and 4 bytes aligned *\/$/;"	m	struct:cmd_priv
-cmd_cmp	include/rtw_iol.h	/^struct cmd_cmp {$/;"	s
-cmd_code	include/rtw_cmd.h	/^	u32	cmd_code;$/;"	m	struct:_cmd_callback
-cmd_done_cnt	include/rtw_cmd.h	/^	u32	cmd_done_cnt;$/;"	m	struct:cmd_priv
-cmd_hdl	include/rtw_mlme_ext.h	/^struct cmd_hdl {$/;"	s
-cmd_hwaddr	include/rtw_xmit.h	/^	uint	cmd_hwaddr;$/;"	m	struct:hw_txqueue
-cmd_id	include/rtw_iol.h	/^	u8	cmd_id;$/;"	m	struct:ioreg_cfg
-cmd_issued_cnt	include/rtw_cmd.h	/^	u32	cmd_issued_cnt;$/;"	m	struct:cmd_priv
-cmd_lock	include/rtw_mlme.h	/^	_lock				cmd_lock;$/;"	m	struct:tdls_info
-cmd_msg_parm	include/rtl8188e_cmd.h	/^struct cmd_msg_parm {$/;"	s
-cmd_msg_parm	include/rtl8192e_cmd.h	/^struct cmd_msg_parm {$/;"	s
-cmd_msg_parm	include/rtl8812a_cmd.h	/^struct cmd_msg_parm {$/;"	s
-cmd_obj	include/rtw_cmd.h	/^struct cmd_obj {$/;"	s
-cmd_priv	include/rtw_cmd.h	/^struct cmd_priv {$/;"	s
-cmd_queue	include/rtw_cmd.h	/^	_queue	cmd_queue;$/;"	m	struct:cmd_priv
-cmd_queue_sema	include/rtw_cmd.h	/^	_sema	cmd_queue_sema;$/;"	m	struct:cmd_priv
-cmd_seq	include/rtw_cmd.h	/^	u8	cmd_seq;$/;"	m	struct:cmd_priv
-cmd_tlv	os_dep/linux/rtw_android.c	/^typedef struct cmd_tlv {$/;"	s	file:
-cmd_tlv_t	os_dep/linux/rtw_android.c	/^} cmd_tlv_t;$/;"	t	typeref:struct:cmd_tlv	file:
-cmdbuf_type	include/rtw_xmit.h	/^enum cmdbuf_type {$/;"	g
-cmdclass	include/rtw_mp.h	/^	u8	cmdclass;$/;"	m	struct:_IOCMD_STRUCT_
-cmdcode	include/rtw_cmd.h	/^	u16	cmdcode;$/;"	m	struct:cmd_obj
-cmdevt_parm	include/rtw_cmd.h	/^	u8	*cmdevt_parm;$/;"	m	struct:evt_priv
-cmdpriv	include/drv_types.h	/^	struct	cmd_priv	cmdpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::cmd_priv
-cmdsz	include/rtw_cmd.h	/^	u32	cmdsz;$/;"	m	struct:cmd_obj
-cmdthd_running	include/rtw_cmd.h	/^	ATOMIC_T cmdthd_running;$/;"	m	struct:cmd_priv
-cmp_pkt_chnl_diff	core/rtw_mlme_ext.c	/^static u8 cmp_pkt_chnl_diff(_adapter *padapter, u8 *pframe, uint packet_len)$/;"	f	file:
-cnt	include/drv_types.h	/^	u32 cnt;$/;"	m	struct:loopbackdata
-cnt_IgnWlanAct	hal/btc/halbtc8723d1ant.h	/^	u32					cnt_IgnWlanAct;$/;"	m	struct:coex_sta_8723d_1ant
-cnt_IgnWlanAct	hal/btc/halbtc8723d2ant.h	/^	u32					cnt_IgnWlanAct;$/;"	m	struct:coex_sta_8723d_2ant
-cnt_Page	hal/btc/halbtc8723d1ant.h	/^	u32					cnt_Page;$/;"	m	struct:coex_sta_8723d_1ant
-cnt_Page	hal/btc/halbtc8723d2ant.h	/^	u32					cnt_Page;$/;"	m	struct:coex_sta_8723d_2ant
-cnt_ReInit	hal/btc/halbtc8723d1ant.h	/^	u32					cnt_ReInit;$/;"	m	struct:coex_sta_8723d_1ant
-cnt_ReInit	hal/btc/halbtc8723d2ant.h	/^	u32					cnt_ReInit;$/;"	m	struct:coex_sta_8723d_2ant
-cnt_RemoteNameReq	hal/btc/halbtc8723d1ant.h	/^	u32					cnt_RemoteNameReq;$/;"	m	struct:coex_sta_8723d_1ant
-cnt_RemoteNameReq	hal/btc/halbtc8723d2ant.h	/^	u32					cnt_RemoteNameReq;$/;"	m	struct:coex_sta_8723d_2ant
-cnt_RoleSwitch	hal/btc/halbtc8723d1ant.h	/^	u32					cnt_RoleSwitch;$/;"	m	struct:coex_sta_8723d_1ant
-cnt_RoleSwitch	hal/btc/halbtc8723d2ant.h	/^	u32					cnt_RoleSwitch;$/;"	m	struct:coex_sta_8723d_2ant
-cnt_bind	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_bind;$/;"	m	struct:btc_statistics
-cnt_bt_info_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_bt_info_notify;$/;"	m	struct:btc_statistics
-cnt_c2h_ack	hal/btc/HalBtcOutSrc.h	/^	u4Byte					cnt_c2h_ack;$/;"	m	struct:_BTC_OFFLOAD
-cnt_c2h_ind	hal/btc/HalBtcOutSrc.h	/^	u4Byte						cnt_c2h_ind;$/;"	m	struct:_BTC_OFFLOAD
-cnt_cca2agc_rdy	hal/phydm/phydm_hwconfig.h	/^	u1Byte		cnt_cca2agc_rdy;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-cnt_cck_crc32_error	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_cck_crc32_error;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_cck_crc32_ok	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_cck_crc32_ok;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_coex_dm_switch	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_coex_dm_switch;$/;"	m	struct:btc_statistics
-cnt_connect_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_connect_notify;$/;"	m	struct:btc_statistics
-cnt_crc32_error_all	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_crc32_error_all;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_crc32_ok_all	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_crc32_ok_all;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_dbg_ctrl	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_dbg_ctrl;$/;"	m	struct:btc_statistics
-cnt_h2c_sent	hal/btc/HalBtcOutSrc.h	/^	u4Byte					cnt_h2c_sent;$/;"	m	struct:_BTC_OFFLOAD
-cnt_ht_crc32_error	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_ht_crc32_error;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_ht_crc32_ok	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_ht_crc32_ok;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_init_coex_dm	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_init_coex_dm;$/;"	m	struct:btc_statistics
-cnt_init_hw_config	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_init_hw_config;$/;"	m	struct:btc_statistics
-cnt_ips_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_ips_notify;$/;"	m	struct:btc_statistics
-cnt_lps_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_lps_notify;$/;"	m	struct:btc_statistics
-cnt_media_status_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_media_status_notify;$/;"	m	struct:btc_statistics
-cnt_ofdm_crc32_error	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_ofdm_crc32_error;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_ofdm_crc32_ok	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_ofdm_crc32_ok;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_periodical	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_periodical;$/;"	m	struct:btc_statistics
-cnt_power_on	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_power_on;$/;"	m	struct:btc_statistics
-cnt_pre_load_firmware	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_pre_load_firmware;$/;"	m	struct:btc_statistics
-cnt_pw2cca	hal/phydm/phydm_hwconfig.h	/^	u1Byte		cnt_pw2cca;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-cnt_rf_status_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_rf_status_notify;$/;"	m	struct:btc_statistics
-cnt_scan_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_scan_notify;$/;"	m	struct:btc_statistics
-cnt_setupLink	hal/btc/halbtc8723d1ant.h	/^	u32					cnt_setupLink;$/;"	m	struct:coex_sta_8723d_1ant
-cnt_setupLink	hal/btc/halbtc8723d2ant.h	/^	u32					cnt_setupLink;$/;"	m	struct:coex_sta_8723d_2ant
-cnt_specific_packet_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_specific_packet_notify;$/;"	m	struct:btc_statistics
-cnt_stack_operation_notify	hal/btc/HalBtcOutSrc.h	/^	u32					cnt_stack_operation_notify;$/;"	m	struct:btc_statistics
-cnt_vht_crc32_error	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_vht_crc32_error;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnt_vht_crc32_ok	hal/phydm/phydm_dig.h	/^	u4Byte		cnt_vht_crc32_ok;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-cnts	include/rtw_mp_ioctl.h	/^	u16	cnts;$/;"	m	struct:_EFUSE_ACCESS_STRUCT_
-cnxt	include/rtw_io.h	/^	u8 *cnxt;$/;"	m	struct:io_req
-coexH2cResultString	hal/hal_btcoex.c	/^const char *const coexH2cResultString[] = {$/;"	v
-coexIndTypeString	hal/hal_btcoex.c	/^const char *const coexIndTypeString[] = {$/;"	v
-coexOpcodeString	hal/hal_btcoex.c	/^const char *const coexOpcodeString[] = {$/;"	v
-coex_dm	hal/btc/HalBtc8192e1Ant.c	/^static struct  coex_dm_8192e_1ant	*coex_dm = &glcoex_dm_8192e_1ant;$/;"	v	typeref:struct:coex_dm_8192e_1ant	file:
-coex_dm	hal/btc/HalBtc8192e2Ant.c	/^static struct  coex_dm_8192e_2ant	*coex_dm = &glcoex_dm_8192e_2ant;$/;"	v	typeref:struct:coex_dm_8192e_2ant	file:
-coex_dm	hal/btc/HalBtc8703b1Ant.c	/^static struct  coex_dm_8703b_1ant	*coex_dm = &glcoex_dm_8703b_1ant;$/;"	v	typeref:struct:coex_dm_8703b_1ant	file:
-coex_dm	hal/btc/HalBtc8723b1Ant.c	/^static struct  coex_dm_8723b_1ant	*coex_dm = &glcoex_dm_8723b_1ant;$/;"	v	typeref:struct:coex_dm_8723b_1ant	file:
-coex_dm	hal/btc/HalBtc8723b2Ant.c	/^static struct  coex_dm_8723b_2ant	*coex_dm = &glcoex_dm_8723b_2ant;$/;"	v	typeref:struct:coex_dm_8723b_2ant	file:
-coex_dm	hal/btc/HalBtc8812a1Ant.c	/^static struct  coex_dm_8812a_1ant	*coex_dm = &glcoex_dm_8812a_1ant;$/;"	v	typeref:struct:coex_dm_8812a_1ant	file:
-coex_dm	hal/btc/HalBtc8812a2Ant.c	/^static struct  coex_dm_8812a_2ant	*coex_dm = &glcoex_dm_8812a_2ant;$/;"	v	typeref:struct:coex_dm_8812a_2ant	file:
-coex_dm	hal/btc/HalBtc8821a1Ant.c	/^static struct  coex_dm_8821a_1ant	*coex_dm = &glcoex_dm_8821a_1ant;$/;"	v	typeref:struct:coex_dm_8821a_1ant	file:
-coex_dm	hal/btc/HalBtc8821a2Ant.c	/^static struct  coex_dm_8821a_2ant	*coex_dm = &glcoex_dm_8821a_2ant;$/;"	v	typeref:struct:coex_dm_8821a_2ant	file:
-coex_dm	hal/btc/HalBtc8821aCsr2Ant.c	/^static struct  coex_dm_8821a_csr_2ant	*coex_dm = &glcoex_dm_8821a_csr_2ant;$/;"	v	typeref:struct:coex_dm_8821a_csr_2ant	file:
-coex_dm	hal/btc/HalBtc8822b1Ant.c	/^static struct  coex_dm_8822b_1ant	*coex_dm = &glcoex_dm_8822b_1ant;$/;"	v	typeref:struct:coex_dm_8822b_1ant	file:
-coex_dm	hal/btc/halbtc8723d1ant.c	/^static struct  coex_dm_8723d_1ant	*coex_dm = &glcoex_dm_8723d_1ant;$/;"	v	typeref:struct:coex_dm_8723d_1ant	file:
-coex_dm	hal/btc/halbtc8723d2ant.c	/^static struct  coex_dm_8723d_2ant	*coex_dm = &glcoex_dm_8723d_2ant;$/;"	v	typeref:struct:coex_dm_8723d_2ant	file:
-coex_dm	hal/btc/halbtc8821c1ant.c	/^static struct  coex_dm_8821c_1ant	*coex_dm = &glcoex_dm_8821c_1ant;$/;"	v	typeref:struct:coex_dm_8821c_1ant	file:
-coex_dm	hal/btc/halbtc8821c2ant.c	/^static struct  coex_dm_8821c_2ant	*coex_dm = &glcoex_dm_8821c_2ant;$/;"	v	typeref:struct:coex_dm_8821c_2ant	file:
-coex_dm_8192e_1ant	hal/btc/HalBtc8192e1Ant.h	/^struct coex_dm_8192e_1ant {$/;"	s
-coex_dm_8192e_2ant	hal/btc/HalBtc8192e2Ant.h	/^struct coex_dm_8192e_2ant {$/;"	s
-coex_dm_8703b_1ant	hal/btc/HalBtc8703b1Ant.h	/^struct coex_dm_8703b_1ant {$/;"	s
-coex_dm_8723b_1ant	hal/btc/HalBtc8723b1Ant.h	/^struct coex_dm_8723b_1ant {$/;"	s
-coex_dm_8723b_2ant	hal/btc/HalBtc8723b2Ant.h	/^struct coex_dm_8723b_2ant {$/;"	s
-coex_dm_8723d_1ant	hal/btc/halbtc8723d1ant.h	/^struct coex_dm_8723d_1ant {$/;"	s
-coex_dm_8723d_2ant	hal/btc/halbtc8723d2ant.h	/^struct coex_dm_8723d_2ant {$/;"	s
-coex_dm_8812a_1ant	hal/btc/HalBtc8812a1Ant.h	/^struct coex_dm_8812a_1ant {$/;"	s
-coex_dm_8812a_2ant	hal/btc/HalBtc8812a2Ant.h	/^struct coex_dm_8812a_2ant {$/;"	s
-coex_dm_8821a_1ant	hal/btc/HalBtc8821a1Ant.h	/^struct coex_dm_8821a_1ant {$/;"	s
-coex_dm_8821a_2ant	hal/btc/HalBtc8821a2Ant.h	/^struct coex_dm_8821a_2ant {$/;"	s
-coex_dm_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.h	/^struct coex_dm_8821a_csr_2ant {$/;"	s
-coex_dm_8821c_1ant	hal/btc/halbtc8821c1ant.h	/^struct coex_dm_8821c_1ant {$/;"	s
-coex_dm_8821c_2ant	hal/btc/halbtc8821c2ant.h	/^struct coex_dm_8821c_2ant {$/;"	s
-coex_dm_8822b_1ant	hal/btc/HalBtc8822b1Ant.h	/^struct coex_dm_8822b_1ant {$/;"	s
-coex_info	include/drv_types.h	/^	struct bt_coex_info coex_info;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::bt_coex_info
-coex_sta	hal/btc/HalBtc8192e1Ant.c	/^static struct  coex_sta_8192e_1ant	*coex_sta = &glcoex_sta_8192e_1ant;$/;"	v	typeref:struct:coex_sta_8192e_1ant	file:
-coex_sta	hal/btc/HalBtc8192e2Ant.c	/^static struct  coex_sta_8192e_2ant	*coex_sta = &glcoex_sta_8192e_2ant;$/;"	v	typeref:struct:coex_sta_8192e_2ant	file:
-coex_sta	hal/btc/HalBtc8703b1Ant.c	/^static struct  coex_sta_8703b_1ant	*coex_sta = &glcoex_sta_8703b_1ant;$/;"	v	typeref:struct:coex_sta_8703b_1ant	file:
-coex_sta	hal/btc/HalBtc8723b1Ant.c	/^static struct  coex_sta_8723b_1ant	*coex_sta = &glcoex_sta_8723b_1ant;$/;"	v	typeref:struct:coex_sta_8723b_1ant	file:
-coex_sta	hal/btc/HalBtc8723b2Ant.c	/^static struct  coex_sta_8723b_2ant	*coex_sta = &glcoex_sta_8723b_2ant;$/;"	v	typeref:struct:coex_sta_8723b_2ant	file:
-coex_sta	hal/btc/HalBtc8812a1Ant.c	/^static struct  coex_sta_8812a_1ant	*coex_sta = &glcoex_sta_8812a_1ant;$/;"	v	typeref:struct:coex_sta_8812a_1ant	file:
-coex_sta	hal/btc/HalBtc8812a2Ant.c	/^static struct  coex_sta_8812a_2ant	*coex_sta = &glcoex_sta_8812a_2ant;$/;"	v	typeref:struct:coex_sta_8812a_2ant	file:
-coex_sta	hal/btc/HalBtc8821a1Ant.c	/^static struct  coex_sta_8821a_1ant	*coex_sta = &glcoex_sta_8821a_1ant;$/;"	v	typeref:struct:coex_sta_8821a_1ant	file:
-coex_sta	hal/btc/HalBtc8821a2Ant.c	/^static struct  coex_sta_8821a_2ant	*coex_sta = &glcoex_sta_8821a_2ant;$/;"	v	typeref:struct:coex_sta_8821a_2ant	file:
-coex_sta	hal/btc/HalBtc8821aCsr2Ant.c	/^static struct  coex_sta_8821a_csr_2ant	*coex_sta = &glcoex_sta_8821a_csr_2ant;$/;"	v	typeref:struct:coex_sta_8821a_csr_2ant	file:
-coex_sta	hal/btc/HalBtc8822b1Ant.c	/^static struct  coex_sta_8822b_1ant	*coex_sta = &glcoex_sta_8822b_1ant;$/;"	v	typeref:struct:coex_sta_8822b_1ant	file:
-coex_sta	hal/btc/halbtc8723d1ant.c	/^static struct  coex_sta_8723d_1ant	*coex_sta = &glcoex_sta_8723d_1ant;$/;"	v	typeref:struct:coex_sta_8723d_1ant	file:
-coex_sta	hal/btc/halbtc8723d2ant.c	/^static struct  coex_sta_8723d_2ant	*coex_sta = &glcoex_sta_8723d_2ant;$/;"	v	typeref:struct:coex_sta_8723d_2ant	file:
-coex_sta	hal/btc/halbtc8821c1ant.c	/^static struct  coex_sta_8821c_1ant	*coex_sta = &glcoex_sta_8821c_1ant;$/;"	v	typeref:struct:coex_sta_8821c_1ant	file:
-coex_sta	hal/btc/halbtc8821c2ant.c	/^static struct  coex_sta_8821c_2ant	*coex_sta = &glcoex_sta_8821c_2ant;$/;"	v	typeref:struct:coex_sta_8821c_2ant	file:
-coex_sta_8192e_1ant	hal/btc/HalBtc8192e1Ant.h	/^struct coex_sta_8192e_1ant {$/;"	s
-coex_sta_8192e_2ant	hal/btc/HalBtc8192e2Ant.h	/^struct coex_sta_8192e_2ant {$/;"	s
-coex_sta_8703b_1ant	hal/btc/HalBtc8703b1Ant.h	/^struct coex_sta_8703b_1ant {$/;"	s
-coex_sta_8723b_1ant	hal/btc/HalBtc8723b1Ant.h	/^struct coex_sta_8723b_1ant {$/;"	s
-coex_sta_8723b_2ant	hal/btc/HalBtc8723b2Ant.h	/^struct coex_sta_8723b_2ant {$/;"	s
-coex_sta_8723d_1ant	hal/btc/halbtc8723d1ant.h	/^struct coex_sta_8723d_1ant {$/;"	s
-coex_sta_8723d_2ant	hal/btc/halbtc8723d2ant.h	/^struct coex_sta_8723d_2ant {$/;"	s
-coex_sta_8812a_1ant	hal/btc/HalBtc8812a1Ant.h	/^struct coex_sta_8812a_1ant {$/;"	s
-coex_sta_8812a_2ant	hal/btc/HalBtc8812a2Ant.h	/^struct coex_sta_8812a_2ant {$/;"	s
-coex_sta_8821a_1ant	hal/btc/HalBtc8821a1Ant.h	/^struct coex_sta_8821a_1ant {$/;"	s
-coex_sta_8821a_2ant	hal/btc/HalBtc8821a2Ant.h	/^struct coex_sta_8821a_2ant {$/;"	s
-coex_sta_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.h	/^struct coex_sta_8821a_csr_2ant {$/;"	s
-coex_sta_8821c_1ant	hal/btc/halbtc8821c1ant.h	/^struct coex_sta_8821c_1ant {$/;"	s
-coex_sta_8821c_2ant	hal/btc/halbtc8821c2ant.h	/^struct coex_sta_8821c_2ant {$/;"	s
-coex_sta_8822b_1ant	hal/btc/HalBtc8822b1Ant.h	/^struct coex_sta_8822b_1ant {$/;"	s
-coex_table_type	hal/btc/HalBtc8192e1Ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8192e_1ant
-coex_table_type	hal/btc/HalBtc8703b1Ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8703b_1ant
-coex_table_type	hal/btc/HalBtc8723b1Ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8723b_1ant
-coex_table_type	hal/btc/HalBtc8723b2Ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8723b_2ant
-coex_table_type	hal/btc/HalBtc8812a1Ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8812a_1ant
-coex_table_type	hal/btc/HalBtc8821a2Ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8821a_2ant
-coex_table_type	hal/btc/HalBtc8822b1Ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8822b_1ant
-coex_table_type	hal/btc/halbtc8723d1ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8723d_1ant
-coex_table_type	hal/btc/halbtc8723d2ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8723d_2ant
-coex_table_type	hal/btc/halbtc8821c1ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8821c_1ant
-coex_table_type	hal/btc/halbtc8821c2ant.h	/^	u8					coex_table_type;$/;"	m	struct:coex_sta_8821c_2ant
-collect_bss_info	core/rtw_mlme_ext.c	/^u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid)$/;"	f
-collect_pkt_num	include/rtw_mlme.h	/^	u8					collect_pkt_num[MAX_CHANNEL_NUM];$/;"	m	struct:tdls_info
-collect_traffic_statistics	core/rtw_mlme.c	/^static void collect_traffic_statistics(_adapter *padapter)$/;"	f	file:
-command	include/ieee80211.h	/^			int command;$/;"	m	struct:ieee_param::__anon73::__anon76
-command	include/rtw_io.h	/^	u32	command;$/;"	m	struct:io_req
-compat_android_wifi_priv_cmd	os_dep/linux/rtw_android.c	/^typedef struct compat_android_wifi_priv_cmd {$/;"	s	file:
-compat_android_wifi_priv_cmd	os_dep/linux/rtw_android.c	/^} compat_android_wifi_priv_cmd;$/;"	t	typeref:struct:compat_android_wifi_priv_cmd	file:
-compat_iw_point	include/linux/wireless.h	/^struct compat_iw_point {$/;"	s
-concurrent_rx_mode_on	hal/btc/HalBtc8703b1Ant.h	/^	boolean					concurrent_rx_mode_on;$/;"	m	struct:coex_sta_8703b_1ant
-concurrent_rx_mode_on	hal/btc/HalBtc8822b1Ant.h	/^	boolean					concurrent_rx_mode_on;$/;"	m	struct:coex_sta_8822b_1ant
-concurrent_rx_mode_on	hal/btc/halbtc8723d1ant.h	/^	boolean				concurrent_rx_mode_on;$/;"	m	struct:coex_sta_8723d_1ant
-concurrent_rx_mode_on	hal/btc/halbtc8723d2ant.h	/^	boolean				concurrent_rx_mode_on;$/;"	m	struct:coex_sta_8723d_2ant
-concurrent_rx_mode_on	hal/btc/halbtc8821c1ant.h	/^	boolean					concurrent_rx_mode_on;$/;"	m	struct:coex_sta_8821c_1ant
-concurrent_rx_mode_on	hal/btc/halbtc8821c2ant.h	/^	boolean					concurrent_rx_mode_on;$/;"	m	struct:coex_sta_8821c_2ant
-conf_op_ch	os_dep/linux/ioctl_cfg80211.h	/^	u8 conf_op_ch;$/;"	m	struct:rtw_wdev_nego_info
-config_descriptor_len	include/drv_types.h	/^	u32	config_descriptor_len;\/* ULONG UsbConfigurationDescriptorLength; *\/$/;"	m	struct:dvobj_priv
-config_methods	include/sta_info.h	/^	u16 config_methods;$/;"	m	struct:sta_info
-config_phydm_read_txagc_check	hal/phydm/phydm_debug.h	131;"	d
-connected	include/rtw_mlme.h	/^	bool connected;$/;"	m	struct:sta_media_status_rpt_cmd_parm
-const_amdpci_aspm	include/drv_types.h	/^	u8	const_amdpci_aspm;$/;"	m	struct:dvobj_priv
-const_devicepci_aspm_setting	include/drv_types.h	/^	u8	const_devicepci_aspm_setting;$/;"	m	struct:dvobj_priv
-const_hostpci_aspm_setting	include/drv_types.h	/^	u8	const_hostpci_aspm_setting;$/;"	m	struct:dvobj_priv
-const_hwsw_rfoff_d3	include/drv_types.h	/^	u8	const_hwsw_rfoff_d3;$/;"	m	struct:dvobj_priv
-const_pci_aspm	include/drv_types.h	/^	u8	const_pci_aspm;$/;"	m	struct:dvobj_priv
-const_support_pciaspm	include/drv_types.h	/^	u8	const_support_pciaspm;$/;"	m	struct:dvobj_priv
-construct_ctr_preload	core/rtw_security.c	/^static void construct_ctr_preload($/;"	f	file:
-construct_mic_header1	core/rtw_security.c	/^static void construct_mic_header1($/;"	f	file:
-construct_mic_header2	core/rtw_security.c	/^static void construct_mic_header2($/;"	f	file:
-construct_mic_iv	core/rtw_security.c	/^static void construct_mic_iv($/;"	f	file:
-container_of	include/osdep_service_bsd.h	131;"	d
-content	include/rtw_pwrctrl.h	/^	char content[MAX_WKFM_PATTERN_SIZE];$/;"	m	struct:rtl_priv_pattern
-context	include/rtw_cmd.h	/^	void *context;$/;"	m	struct:RunInThread_param
-continual_io_error	include/drv_types.h	/^	ATOMIC_T continual_io_error;$/;"	m	struct:dvobj_priv
-continual_no_rx_packet	include/sta_info.h	/^	ATOMIC_T continual_no_rx_packet[TID_NUM];$/;"	m	struct:sta_info
-control	include/wifi.h	/^	unsigned short control;$/;"	m	struct:rtw_ieee80211_bar
-control_chan	include/wifi.h	/^	unsigned char	control_chan;$/;"	m	struct:ieee80211_ht_addt_info
-convert_ip_addr	core/rtw_ieee80211.c	/^u8 convert_ip_addr(u8 hch, u8 mch, u8 lch)$/;"	f
-convert_ipv6_mac_to_mc	core/rtw_br_ext.c	/^static void convert_ipv6_mac_to_mc(struct sk_buff *skb)$/;"	f	file:
-cookie	core/rtw_br_ext.c	/^	u_int32_t cookie;$/;"	m	struct:dhcpMessage	file:
-cookie	include/rtw_cmd.h	/^	u64 cookie;$/;"	m	struct:p2p_roch_parm
-copy_from_user	os_dep/osdep_service.c	/^copy_from_user(void *to, const void *from, unsigned long n)$/;"	f
-copy_to_user	os_dep/osdep_service.c	/^copy_to_user(void *to, const void *from, unsigned long n)$/;"	f
-core_rx	include/drv_types.h	/^	u32 core_rx;$/;"	m	struct:rx_logs
-core_rx_dequeue	include/drv_types.h	/^	u32 core_rx_dequeue;$/;"	m	struct:rx_logs
-core_rx_enqueue	include/drv_types.h	/^	u32 core_rx_enqueue;$/;"	m	struct:rx_logs
-core_rx_post	include/drv_types.h	/^	u32 core_rx_post;$/;"	m	struct:rx_logs
-core_rx_post_decrypt	include/drv_types.h	/^	u32 core_rx_post_decrypt;$/;"	m	struct:rx_logs
-core_rx_post_decrypt_aes	include/drv_types.h	/^	u32 core_rx_post_decrypt_aes;$/;"	m	struct:rx_logs
-core_rx_post_decrypt_err	include/drv_types.h	/^	u32 core_rx_post_decrypt_err;$/;"	m	struct:rx_logs
-core_rx_post_decrypt_hw	include/drv_types.h	/^	u32 core_rx_post_decrypt_hw;$/;"	m	struct:rx_logs
-core_rx_post_decrypt_tkip	include/drv_types.h	/^	u32 core_rx_post_decrypt_tkip;$/;"	m	struct:rx_logs
-core_rx_post_decrypt_unknown	include/drv_types.h	/^	u32 core_rx_post_decrypt_unknown;$/;"	m	struct:rx_logs
-core_rx_post_decrypt_wapi	include/drv_types.h	/^	u32 core_rx_post_decrypt_wapi;$/;"	m	struct:rx_logs
-core_rx_post_decrypt_wep	include/drv_types.h	/^	u32 core_rx_post_decrypt_wep;$/;"	m	struct:rx_logs
-core_rx_post_defrag_err	include/drv_types.h	/^	u32 core_rx_post_defrag_err;$/;"	m	struct:rx_logs
-core_rx_post_indicate	include/drv_types.h	/^	u32 core_rx_post_indicate;$/;"	m	struct:rx_logs
-core_rx_post_indicate_err	include/drv_types.h	/^	u32 core_rx_post_indicate_err;$/;"	m	struct:rx_logs
-core_rx_post_indicate_in_oder	include/drv_types.h	/^	u32 core_rx_post_indicate_in_oder;$/;"	m	struct:rx_logs
-core_rx_post_indicate_reoder	include/drv_types.h	/^	u32 core_rx_post_indicate_reoder;$/;"	m	struct:rx_logs
-core_rx_post_portctrl_err	include/drv_types.h	/^	u32 core_rx_post_portctrl_err;$/;"	m	struct:rx_logs
-core_rx_pre	include/drv_types.h	/^	u32 core_rx_pre;$/;"	m	struct:rx_logs
-core_rx_pre_ctrl	include/drv_types.h	/^	u32 core_rx_pre_ctrl;$/;"	m	struct:rx_logs
-core_rx_pre_ctrl_err	include/drv_types.h	/^	u32 core_rx_pre_ctrl_err;$/;"	m	struct:rx_logs
-core_rx_pre_data	include/drv_types.h	/^	u32 core_rx_pre_data;$/;"	m	struct:rx_logs
-core_rx_pre_data_err	include/drv_types.h	/^	u32 core_rx_pre_data_err;$/;"	m	struct:rx_logs
-core_rx_pre_data_handled	include/drv_types.h	/^	u32 core_rx_pre_data_handled;$/;"	m	struct:rx_logs
-core_rx_pre_data_unknown	include/drv_types.h	/^	u32 core_rx_pre_data_unknown;$/;"	m	struct:rx_logs
-core_rx_pre_data_wapi_key_err	include/drv_types.h	/^	u32 core_rx_pre_data_wapi_key_err;$/;"	m	struct:rx_logs
-core_rx_pre_data_wapi_seq_err	include/drv_types.h	/^	u32 core_rx_pre_data_wapi_seq_err;$/;"	m	struct:rx_logs
-core_rx_pre_mgmt	include/drv_types.h	/^	u32 core_rx_pre_mgmt;$/;"	m	struct:rx_logs
-core_rx_pre_mgmt_err	include/drv_types.h	/^	u32 core_rx_pre_mgmt_err;$/;"	m	struct:rx_logs
-core_rx_pre_mgmt_err_80211w	include/drv_types.h	/^	u32 core_rx_pre_mgmt_err_80211w;$/;"	m	struct:rx_logs
-core_rx_pre_unknown	include/drv_types.h	/^	u32 core_rx_pre_unknown;$/;"	m	struct:rx_logs
-core_rx_pre_ver_err	include/drv_types.h	/^	u32 core_rx_pre_ver_err;$/;"	m	struct:rx_logs
-core_tx	include/drv_types.h	/^	u32 core_tx;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue	include/drv_types.h	/^	u32 core_tx_ap_enqueue;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue_mcast	include/drv_types.h	/^	u32 core_tx_ap_enqueue_mcast;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue_ucast	include/drv_types.h	/^	u32 core_tx_ap_enqueue_ucast;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue_warn_fwstate	include/drv_types.h	/^	u32 core_tx_ap_enqueue_warn_fwstate;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue_warn_link	include/drv_types.h	/^	u32 core_tx_ap_enqueue_warn_link;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue_warn_nosta	include/drv_types.h	/^	u32 core_tx_ap_enqueue_warn_nosta;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue_warn_sta	include/drv_types.h	/^	u32 core_tx_ap_enqueue_warn_sta;$/;"	m	struct:tx_logs
-core_tx_ap_enqueue_warn_trigger	include/drv_types.h	/^	u32 core_tx_ap_enqueue_warn_trigger;$/;"	m	struct:tx_logs
-core_tx_enqueue	include/drv_types.h	/^	u32 core_tx_enqueue;$/;"	m	struct:tx_logs
-core_tx_enqueue_class	include/drv_types.h	/^	u32 core_tx_enqueue_class;$/;"	m	struct:tx_logs
-core_tx_enqueue_class_err_fwlink	include/drv_types.h	/^	u32 core_tx_enqueue_class_err_fwlink;$/;"	m	struct:tx_logs
-core_tx_enqueue_class_err_nosta	include/drv_types.h	/^	u32 core_tx_enqueue_class_err_nosta;$/;"	m	struct:tx_logs
-core_tx_enqueue_class_err_sta	include/drv_types.h	/^	u32 core_tx_enqueue_class_err_sta;$/;"	m	struct:tx_logs
-core_tx_err_brtx	include/drv_types.h	/^	u32 core_tx_err_brtx;$/;"	m	struct:tx_logs
-core_tx_err_pxmitframe	include/drv_types.h	/^	u32 core_tx_err_pxmitframe;$/;"	m	struct:tx_logs
-core_tx_upd_attrib	include/drv_types.h	/^	u32 core_tx_upd_attrib;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_active	include/drv_types.h	/^	u32 core_tx_upd_attrib_active;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_adhoc	include/drv_types.h	/^	u32 core_tx_upd_attrib_adhoc;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_ap	include/drv_types.h	/^	u32 core_tx_upd_attrib_ap;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_dhcp	include/drv_types.h	/^	u32 core_tx_upd_attrib_dhcp;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_err_link	include/drv_types.h	/^	u32 core_tx_upd_attrib_err_link;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_err_sec	include/drv_types.h	/^	u32 core_tx_upd_attrib_err_sec;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_err_sta	include/drv_types.h	/^	u32 core_tx_upd_attrib_err_sta;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_err_ucast_ap_link	include/drv_types.h	/^	u32 core_tx_upd_attrib_err_ucast_ap_link;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_err_ucast_sta	include/drv_types.h	/^	u32 core_tx_upd_attrib_err_ucast_sta;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_icmp	include/drv_types.h	/^	u32 core_tx_upd_attrib_icmp;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_sta	include/drv_types.h	/^	u32 core_tx_upd_attrib_sta;$/;"	m	struct:tx_logs
-core_tx_upd_attrib_unknown	include/drv_types.h	/^	u32 core_tx_upd_attrib_unknown;$/;"	m	struct:tx_logs
-correct_TSF	core/rtw_wlan_util.c	/^void correct_TSF(_adapter *padapter, struct mlme_ext_priv *pmlmeext)$/;"	f
-count	hal/btc/HalBtcOutSrc.h	/^	u4Byte					count;									\/* the total number of the rcvd c2h indication *\/$/;"	m	struct:_COL_SINGLE_C2H_IND_RECORD
-count	hal/btc/HalBtcOutSrc.h	/^	u4Byte					count;									\/* the total number of the sent h2c command *\/$/;"	m	struct:_COL_SINGLE_H2C_RECORD
-count	include/rtw_mp.h	/^	u32 count, sended;$/;"	m	struct:mp_tx
-count	include/rtw_mp_ioctl.h	/^	u32 count;$/;"	m	struct:_mp_xmit_parm_
-count_judge	include/rtw_cmd.h	/^	u8	count_judge[MAX_RATES_LENGTH];$/;"	m	struct:getcountjudge_rsp
-count_judge	include/rtw_cmd.h	/^	u8	count_judge[MAX_RATES_LENGTH];$/;"	m	struct:setcountjudge_parm
-count_judge	include/rtw_cmd.h	/^	u8 count_judge[NumRates];$/;"	m	struct:getratable_rsp
-count_judge	include/rtw_cmd.h	/^	u8 count_judge[NumRates];$/;"	m	struct:setratable_parm
-count_rx_stats	core/rtw_recv.c	/^void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info *sta)$/;"	f
-counter	hal/phydm/phydm_hwconfig.h	/^	u1Byte		counter: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-counter	include/rtw_recv.h	/^	uint	counter; \/* record the number that up-layer will return to drv; only when counter==0 can we  release recv_priv *\/$/;"	m	struct:recv_priv
-country_chplan	include/rtw_rf.h	/^struct country_chplan {$/;"	s
-country_chplan_map	core/rtw_rf.c	/^static const struct country_chplan country_chplan_map[] = {$/;"	v	typeref:struct:country_chplan	file:
-country_chplan_map_sz	core/rtw_rf.c	/^u16 const country_chplan_map_sz = sizeof(country_chplan_map) \/ sizeof(struct country_chplan);$/;"	v
-country_code	include/wifi.h	/^	u16 country_code;$/;"	m	struct:rtw_regulatory
-country_code_to_enum_rd	include/rtw_wifi_regd.h	/^struct country_code_to_enum_rd {$/;"	s
-country_code_type_t	include/rtw_wifi_regd.h	/^enum country_code_type_t {$/;"	g
-country_ent	include/rtw_cmd.h	/^	const struct country_chplan *country_ent;$/;"	m	struct:SetChannelPlan_param	typeref:struct:SetChannelPlan_param::country_chplan
-country_ent	include/rtw_mlme.h	/^	const struct country_chplan *country_ent;$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::country_chplan
-countrycode	include/rtw_wifi_regd.h	/^	u16 countrycode;$/;"	m	struct:country_code_to_enum_rd
-cpIpAddr	include/hal_com_h2c.h	160;"	d
-cpMacAddr	include/hal_com_h2c.h	159;"	d
-cpu_handle	include/rtl8188e_xmit.h	/^	u32 cpu_handle:1;$/;"	m	struct:txdesc_88e
-cpu_handle	include/rtl8192e_xmit.h	/^	u32 cpu_handle:1;$/;"	m	struct:txdescriptor_8192e
-cpu_handle	include/rtl8812a_xmit.h	/^	u32 cpu_handle:1;$/;"	m	struct:txdescriptor_8812
-cpu_to_be16	include/byteorder/generic.h	116;"	d
-cpu_to_be16p	include/byteorder/generic.h	128;"	d
-cpu_to_be16s	include/byteorder/generic.h	140;"	d
-cpu_to_be32	include/byteorder/generic.h	114;"	d
-cpu_to_be32p	include/byteorder/generic.h	126;"	d
-cpu_to_be32s	include/byteorder/generic.h	138;"	d
-cpu_to_be64	include/byteorder/generic.h	112;"	d
-cpu_to_be64p	include/byteorder/generic.h	124;"	d
-cpu_to_be64s	include/byteorder/generic.h	136;"	d
-cpu_to_le16	include/byteorder/generic.h	110;"	d
-cpu_to_le16p	include/byteorder/generic.h	122;"	d
-cpu_to_le16s	include/byteorder/generic.h	134;"	d
-cpu_to_le32	include/byteorder/generic.h	108;"	d
-cpu_to_le32p	include/byteorder/generic.h	120;"	d
-cpu_to_le32s	include/byteorder/generic.h	132;"	d
-cpu_to_le64	include/byteorder/generic.h	106;"	d
-cpu_to_le64p	include/byteorder/generic.h	118;"	d
-cpu_to_le64s	include/byteorder/generic.h	130;"	d
-cpwm	include/rtw_pwrctrl.h	/^	volatile u8 cpwm; \/* fw current power state. updated when 1. read from HCPWM 2. driver lowers power level *\/$/;"	m	struct:pwrctrl_priv
-cpwm_event	include/rtw_pwrctrl.h	/^	_workitem cpwm_event;$/;"	m	struct:pwrctrl_priv
-cpwm_event_callback	core/rtw_pwrctrl.c	/^static void cpwm_event_callback(struct work_struct *work)$/;"	f	file:
-cpwm_int	include/rtw_mp.h	/^	NDIS_EVENT cpwm_int;$/;"	m	struct:mp_priv
-cpwm_int_hdl	core/rtw_pwrctrl.c	/^void cpwm_int_hdl($/;"	f
-cpwm_tog	include/rtw_pwrctrl.h	/^	volatile u8 cpwm_tog; \/* toggling *\/$/;"	m	struct:pwrctrl_priv
-crc	include/rtw_pwrctrl.h	/^	u16	crc;$/;"	m	struct:rtl_wow_pattern
-crc32	include/rtl8188e_recv.h	/^	u32 crc32:1;$/;"	m	struct:rxreport_8188e
-crc32_init	core/rtw_security.c	/^static void crc32_init(void)$/;"	f	file:
-crc32_reverseBit	core/rtw_security.c	/^static u8 crc32_reverseBit(u8 data)$/;"	f	file:
-crc32_table	core/rtw_security.c	/^static u32 crc32_table[256];$/;"	v	file:
-crc_err	include/rtw_recv.h	/^	u8	crc_err;$/;"	m	struct:rx_pkt_attrib
-crc_err_11g	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8192e_1ant
-crc_err_11g	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8703b_1ant
-crc_err_11g	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8723b_1ant
-crc_err_11g	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8723b_2ant
-crc_err_11g	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8812a_1ant
-crc_err_11g	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8821a_2ant
-crc_err_11g	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8822b_1ant
-crc_err_11g	hal/btc/halbtc8723d1ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8723d_1ant
-crc_err_11g	hal/btc/halbtc8723d2ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8723d_2ant
-crc_err_11g	hal/btc/halbtc8821c1ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8821c_1ant
-crc_err_11g	hal/btc/halbtc8821c2ant.h	/^	u32					crc_err_11g;$/;"	m	struct:coex_sta_8821c_2ant
-crc_err_11n	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8192e_1ant
-crc_err_11n	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8703b_1ant
-crc_err_11n	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8723b_1ant
-crc_err_11n	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8723b_2ant
-crc_err_11n	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8812a_1ant
-crc_err_11n	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8821a_2ant
-crc_err_11n	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8822b_1ant
-crc_err_11n	hal/btc/halbtc8723d1ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8723d_1ant
-crc_err_11n	hal/btc/halbtc8723d2ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8723d_2ant
-crc_err_11n	hal/btc/halbtc8821c1ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8821c_1ant
-crc_err_11n	hal/btc/halbtc8821c2ant.h	/^	u32					crc_err_11n;$/;"	m	struct:coex_sta_8821c_2ant
-crc_err_11n_agg	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8192e_1ant
-crc_err_11n_agg	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8703b_1ant
-crc_err_11n_agg	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8723b_1ant
-crc_err_11n_agg	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8723b_2ant
-crc_err_11n_agg	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8812a_1ant
-crc_err_11n_agg	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8821a_2ant
-crc_err_11n_agg	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8822b_1ant
-crc_err_11n_agg	hal/btc/halbtc8821c1ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8821c_1ant
-crc_err_11n_agg	hal/btc/halbtc8821c2ant.h	/^	u32					crc_err_11n_agg;$/;"	m	struct:coex_sta_8821c_2ant
-crc_err_11n_vht	hal/btc/halbtc8723d1ant.h	/^	u32					crc_err_11n_vht;$/;"	m	struct:coex_sta_8723d_1ant
-crc_err_11n_vht	hal/btc/halbtc8723d2ant.h	/^	u32					crc_err_11n_vht;$/;"	m	struct:coex_sta_8723d_2ant
-crc_err_cck	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8192e_1ant
-crc_err_cck	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8703b_1ant
-crc_err_cck	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8723b_1ant
-crc_err_cck	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8723b_2ant
-crc_err_cck	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8812a_1ant
-crc_err_cck	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8821a_2ant
-crc_err_cck	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8822b_1ant
-crc_err_cck	hal/btc/halbtc8723d1ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8723d_1ant
-crc_err_cck	hal/btc/halbtc8723d2ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8723d_2ant
-crc_err_cck	hal/btc/halbtc8821c1ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8821c_1ant
-crc_err_cck	hal/btc/halbtc8821c2ant.h	/^	u32					crc_err_cck;$/;"	m	struct:coex_sta_8821c_2ant
-crc_ok_11g	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8192e_1ant
-crc_ok_11g	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8703b_1ant
-crc_ok_11g	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8723b_1ant
-crc_ok_11g	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8723b_2ant
-crc_ok_11g	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8812a_1ant
-crc_ok_11g	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8821a_2ant
-crc_ok_11g	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8822b_1ant
-crc_ok_11g	hal/btc/halbtc8723d1ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8723d_1ant
-crc_ok_11g	hal/btc/halbtc8723d2ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8723d_2ant
-crc_ok_11g	hal/btc/halbtc8821c1ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8821c_1ant
-crc_ok_11g	hal/btc/halbtc8821c2ant.h	/^	u32					crc_ok_11g;$/;"	m	struct:coex_sta_8821c_2ant
-crc_ok_11n	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8192e_1ant
-crc_ok_11n	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8703b_1ant
-crc_ok_11n	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8723b_1ant
-crc_ok_11n	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8723b_2ant
-crc_ok_11n	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8812a_1ant
-crc_ok_11n	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8821a_2ant
-crc_ok_11n	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8822b_1ant
-crc_ok_11n	hal/btc/halbtc8723d1ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8723d_1ant
-crc_ok_11n	hal/btc/halbtc8723d2ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8723d_2ant
-crc_ok_11n	hal/btc/halbtc8821c1ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8821c_1ant
-crc_ok_11n	hal/btc/halbtc8821c2ant.h	/^	u32					crc_ok_11n;$/;"	m	struct:coex_sta_8821c_2ant
-crc_ok_11n_agg	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8192e_1ant
-crc_ok_11n_agg	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8703b_1ant
-crc_ok_11n_agg	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8723b_1ant
-crc_ok_11n_agg	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8723b_2ant
-crc_ok_11n_agg	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8812a_1ant
-crc_ok_11n_agg	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8821a_2ant
-crc_ok_11n_agg	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8822b_1ant
-crc_ok_11n_agg	hal/btc/halbtc8821c1ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8821c_1ant
-crc_ok_11n_agg	hal/btc/halbtc8821c2ant.h	/^	u32					crc_ok_11n_agg;$/;"	m	struct:coex_sta_8821c_2ant
-crc_ok_11n_vht	hal/btc/halbtc8723d1ant.h	/^	u32					crc_ok_11n_vht;$/;"	m	struct:coex_sta_8723d_1ant
-crc_ok_11n_vht	hal/btc/halbtc8723d2ant.h	/^	u32					crc_ok_11n_vht;$/;"	m	struct:coex_sta_8723d_2ant
-crc_ok_cck	hal/btc/HalBtc8192e1Ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8192e_1ant
-crc_ok_cck	hal/btc/HalBtc8703b1Ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8703b_1ant
-crc_ok_cck	hal/btc/HalBtc8723b1Ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8723b_1ant
-crc_ok_cck	hal/btc/HalBtc8723b2Ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8723b_2ant
-crc_ok_cck	hal/btc/HalBtc8812a1Ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8812a_1ant
-crc_ok_cck	hal/btc/HalBtc8821a2Ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8821a_2ant
-crc_ok_cck	hal/btc/HalBtc8822b1Ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8822b_1ant
-crc_ok_cck	hal/btc/halbtc8723d1ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8723d_1ant
-crc_ok_cck	hal/btc/halbtc8723d2ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8723d_2ant
-crc_ok_cck	hal/btc/halbtc8821c1ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8821c_1ant
-crc_ok_cck	hal/btc/halbtc8821c2ant.h	/^	u32					crc_ok_cck;$/;"	m	struct:coex_sta_8821c_2ant
-createbss_hdl	core/rtw_mlme_ext.c	/^u8 createbss_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-createbss_parm	include/rtw_cmd.h	/^struct createbss_parm {$/;"	s
-createloopbackpkt	os_dep/linux/ioctl_linux.c	/^static struct xmit_frame *createloopbackpkt(PADAPTER padapter, u32 size)$/;"	f	file:
-createpseudoadhoc	os_dep/linux/ioctl_linux.c	/^static s32 createpseudoadhoc(PADAPTER padapter)$/;"	f	file:
-crypt	include/ieee80211.h	/^		} crypt;$/;"	m	union:ieee_param::__anon73	typeref:struct:ieee_param::__anon73::__anon77
-csi_current	hal/phydm/phydm_hwconfig.h	/^	u1Byte			csi_current[2];	   \/*DW5 byte 1 DW5 byte 2	8812A: stream 1 and 2 CSI	8814A:  path-C and path-D RX SNR*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-csum	include/osdep_service_bsd.h	/^		u32		csum;$/;"	m	union:sk_buff::__anon47
-csum_offset	include/osdep_service_bsd.h	/^			u16	csum_offset;$/;"	m	struct:sk_buff::__anon47::__anon48
-csum_start	include/osdep_service_bsd.h	/^			u16	csum_start;$/;"	m	struct:sk_buff::__anon47::__anon48
-ctrl	include/drv_types.h	/^	u16 ctrl;$/;"	m	struct:sec_cam_ent
-ctrl	include/ieee80211.h	/^	u8    ctrl;   \/* always 0x03 *\/$/;"	m	struct:ieee80211_snap_hdr
-cts2ap_en	include/rtl8188e_xmit.h	/^	u32 cts2ap_en:1;$/;"	m	struct:txdesc_88e
-cts2ap_en	include/rtl8192e_xmit.h	/^	u32 cts2ap_en:1;$/;"	m	struct:txdescriptor_8192e
-cts2ap_en	include/rtl8812a_xmit.h	/^	u32 cts2ap_en:1;$/;"	m	struct:txdescriptor_8812
-cts2self	include/rtl8188e_xmit.h	/^	u32 cts2self:1;$/;"	m	struct:txdesc_88e
-cts2self	include/rtl8192e_xmit.h	/^	u32 cts2self:1;$/;"	m	struct:txdescriptor_8192e
-cts2self	include/rtl8812a_xmit.h	/^	u32 cts2self:1;$/;"	m	struct:txdescriptor_8812
-cts2self	include/rtl8821a_xmit.h	/^	u32 cts2self:1;$/;"	m	struct:txdescriptor_8821a
-cts2self	include/rtw_xmit.h	/^	u8 cts2self;$/;"	m	struct:pkt_attrib
-cts2self	include/sta_info.h	/^	u8	cts2self;$/;"	m	struct:sta_info
-ctwindow	include/rtw_mlme.h	/^	u8						ctwindow; \/* Client traffic window. A period of time in TU after TBTT. *\/$/;"	m	struct:wifidirect_info
-curAlgorithm	hal/btc/HalBtc8188c2Ant.h	/^	u1Byte		curAlgorithm;$/;"	m	struct:_COEX_DM_8188C_2ANT
-curAlgorithm	hal/btc/HalBtc8192d2Ant.h	/^	u1Byte		curAlgorithm;$/;"	m	struct:_COEX_DM_8192D_2ANT
-curAlgorithm	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		curAlgorithm;$/;"	m	struct:_COEX_DM_8723A_1ANT
-curAlgorithm	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		curAlgorithm;$/;"	m	struct:_COEX_DM_8723A_2ANT
-curDacSwingLvl	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		curDacSwingLvl;$/;"	m	struct:_COEX_DM_8188C_2ANT
-curDacSwingLvl	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		curDacSwingLvl;$/;"	m	struct:_COEX_DM_8192D_2ANT
-curDacSwingLvl	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte		curDacSwingLvl;$/;"	m	struct:_COEX_DM_8723A_2ANT
-curFwDacSwingLvl	hal/btc/HalBtc8188c2Ant.h	/^	u1Byte		curFwDacSwingLvl;$/;"	m	struct:_COEX_DM_8188C_2ANT
-curFwDacSwingLvl	hal/btc/HalBtc8192d2Ant.h	/^	u1Byte		curFwDacSwingLvl;$/;"	m	struct:_COEX_DM_8192D_2ANT
-curFwDacSwingLvl	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		curFwDacSwingLvl;$/;"	m	struct:_COEX_DM_8723A_2ANT
-curPsTdma	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		curPsTdma;$/;"	m	struct:_COEX_DM_8723A_1ANT
-curPsTdma	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		curPsTdma;$/;"	m	struct:_COEX_DM_8723A_2ANT
-curRxOkCnt	hal/phydm/phydm.h	/^	u8Byte			curRxOkCnt;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-curTxOkCnt	hal/phydm/phydm.h	/^	u8Byte			curTxOkCnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-curVal0x6c0	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte		curVal0x6c0;$/;"	m	struct:_COEX_DM_8723A_1ANT
-curVal0x6c0	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte		curVal0x6c0;$/;"	m	struct:_COEX_DM_8723A_2ANT
-curVal0x6c4	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		curVal0x6c4;$/;"	m	struct:_COEX_DM_8188C_2ANT
-curVal0x6c4	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		curVal0x6c4;$/;"	m	struct:_COEX_DM_8192D_2ANT
-curVal0x6c8	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		curVal0x6c8;$/;"	m	struct:_COEX_DM_8188C_2ANT
-curVal0x6c8	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		curVal0x6c8;$/;"	m	struct:_COEX_DM_8192D_2ANT
-curVal0x6c8	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte		curVal0x6c8;$/;"	m	struct:_COEX_DM_8723A_1ANT
-curVal0x6c8	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte		curVal0x6c8;$/;"	m	struct:_COEX_DM_8723A_2ANT
-curVal0x6cc	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		curVal0x6cc;$/;"	m	struct:_COEX_DM_8188C_2ANT
-curVal0x6cc	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		curVal0x6cc;$/;"	m	struct:_COEX_DM_8192D_2ANT
-curVal0x6cc	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		curVal0x6cc;$/;"	m	struct:_COEX_DM_8723A_1ANT
-curVal0x6cc	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		curVal0x6cc;$/;"	m	struct:_COEX_DM_8723A_2ANT
-cur_adc_back_off	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_adc_back_off;$/;"	m	struct:coex_dm_8192e_2ant
-cur_adc_back_off	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_adc_back_off;$/;"	m	struct:coex_dm_8723b_2ant
-cur_adc_back_off	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_adc_back_off;$/;"	m	struct:coex_dm_8812a_2ant
-cur_adc_back_off	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_adc_back_off;$/;"	m	struct:coex_dm_8821a_2ant
-cur_adc_back_off	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_adc_back_off;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_adc_back_off	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_adc_back_off;$/;"	m	struct:coex_dm_8723d_2ant
-cur_adc_back_off	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_adc_back_off;$/;"	m	struct:coex_dm_8821c_2ant
-cur_addr	include/xmit_osdep.h	/^	u8 *cur_addr;$/;"	m	struct:pkt_file
-cur_agc_table_en	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_agc_table_en;$/;"	m	struct:coex_dm_8192e_2ant
-cur_agc_table_en	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_agc_table_en;$/;"	m	struct:coex_dm_8723b_2ant
-cur_agc_table_en	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_agc_table_en;$/;"	m	struct:coex_dm_8812a_2ant
-cur_agc_table_en	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_agc_table_en;$/;"	m	struct:coex_dm_8821a_2ant
-cur_agc_table_en	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_agc_table_en;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_agc_table_en	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_agc_table_en;$/;"	m	struct:coex_dm_8723d_2ant
-cur_agc_table_en	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_agc_table_en;$/;"	m	struct:coex_dm_8821c_2ant
-cur_algorithm	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8192e_1ant
-cur_algorithm	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8192e_2ant
-cur_algorithm	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8703b_1ant
-cur_algorithm	hal/btc/HalBtc8723b2Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8723b_2ant
-cur_algorithm	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8812a_1ant
-cur_algorithm	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8812a_2ant
-cur_algorithm	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8821a_1ant
-cur_algorithm	hal/btc/HalBtc8821a2Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8821a_2ant
-cur_algorithm	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_algorithm	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8822b_1ant
-cur_algorithm	hal/btc/halbtc8723d1ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8723d_1ant
-cur_algorithm	hal/btc/halbtc8723d2ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8723d_2ant
-cur_algorithm	hal/btc/halbtc8821c1ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8821c_1ant
-cur_algorithm	hal/btc/halbtc8821c2ant.h	/^	u8		cur_algorithm;$/;"	m	struct:coex_dm_8821c_2ant
-cur_ampdu_num_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8 cur_ampdu_num_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_ampdu_time_type	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8192e_1ant
-cur_ampdu_time_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8192e_2ant
-cur_ampdu_time_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8703b_1ant
-cur_ampdu_time_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8723b_1ant
-cur_ampdu_time_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8812a_1ant
-cur_ampdu_time_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8812a_2ant
-cur_ampdu_time_type	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8821a_1ant
-cur_ampdu_time_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8 cur_ampdu_time_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_ampdu_time_type	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8822b_1ant
-cur_ampdu_time_type	hal/btc/halbtc8723d1ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8723d_1ant
-cur_ampdu_time_type	hal/btc/halbtc8821c1ant.h	/^	u8		cur_ampdu_time_type;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ant_pos_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_ant_pos_type;$/;"	m	struct:coex_dm_8703b_1ant
-cur_ant_pos_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_ant_pos_type;$/;"	m	struct:coex_dm_8723b_1ant
-cur_ant_pos_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_ant_pos_type;$/;"	m	struct:coex_dm_8812a_1ant
-cur_ant_pos_type	hal/btc/HalBtc8822b1Ant.h	/^	u32		cur_ant_pos_type;$/;"	m	struct:coex_dm_8822b_1ant
-cur_ant_pos_type	hal/btc/halbtc8723d1ant.h	/^	u8		cur_ant_pos_type;$/;"	m	struct:coex_dm_8723d_1ant
-cur_ant_pos_type	hal/btc/halbtc8723d2ant.h	/^	u8		cur_ant_pos_type;$/;"	m	struct:coex_dm_8723d_2ant
-cur_ant_pos_type	hal/btc/halbtc8821c1ant.h	/^	u32		cur_ant_pos_type;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ant_pos_type	hal/btc/halbtc8821c2ant.h	/^	u32		cur_ant_pos_type;$/;"	m	struct:coex_dm_8821c_2ant
-cur_arfr_type	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8192e_1ant
-cur_arfr_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8192e_2ant
-cur_arfr_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8703b_1ant
-cur_arfr_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8723b_1ant
-cur_arfr_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8812a_1ant
-cur_arfr_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8812a_2ant
-cur_arfr_type	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8821a_1ant
-cur_arfr_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_arfr_type	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8822b_1ant
-cur_arfr_type	hal/btc/halbtc8723d1ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8723d_1ant
-cur_arfr_type	hal/btc/halbtc8821c1ant.h	/^	u8		cur_arfr_type;$/;"	m	struct:coex_dm_8821c_1ant
-cur_beacon_keys	include/rtw_mlme.h	/^	struct beacon_keys cur_beacon_keys; \/* save current beacon keys *\/$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::beacon_keys
-cur_bt_auto_report	hal/btc/HalBtc8192e1Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8192e_1ant
-cur_bt_auto_report	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8192e_2ant
-cur_bt_auto_report	hal/btc/HalBtc8703b1Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8703b_1ant
-cur_bt_auto_report	hal/btc/HalBtc8723b1Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8723b_1ant
-cur_bt_auto_report	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8723b_2ant
-cur_bt_auto_report	hal/btc/HalBtc8812a1Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8812a_1ant
-cur_bt_auto_report	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8812a_2ant
-cur_bt_auto_report	hal/btc/HalBtc8821a1Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8821a_1ant
-cur_bt_auto_report	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8821a_2ant
-cur_bt_auto_report	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_bt_auto_report	hal/btc/HalBtc8822b1Ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8822b_1ant
-cur_bt_auto_report	hal/btc/halbtc8723d1ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8723d_1ant
-cur_bt_auto_report	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8723d_2ant
-cur_bt_auto_report	hal/btc/halbtc8821c1ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8821c_1ant
-cur_bt_auto_report	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_bt_auto_report;$/;"	m	struct:coex_dm_8821c_2ant
-cur_bt_dec_pwr_lvl	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8192e_2ant
-cur_bt_dec_pwr_lvl	hal/btc/HalBtc8723b2Ant.h	/^	u8		cur_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8723b_2ant
-cur_bt_dec_pwr_lvl	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8812a_2ant
-cur_bt_dec_pwr_lvl	hal/btc/HalBtc8821a2Ant.h	/^	u8		cur_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8821a_2ant
-cur_bt_dec_pwr_lvl	hal/btc/halbtc8723d2ant.h	/^	u8		cur_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8723d_2ant
-cur_bt_dec_pwr_lvl	hal/btc/halbtc8821c2ant.h	/^	u8		cur_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8821c_2ant
-cur_buffer	include/xmit_osdep.h	/^	_buffer *cur_buffer;$/;"	m	struct:pkt_file
-cur_bwmode	include/rtw_mlme_ext.h	/^	unsigned char	cur_bwmode;$/;"	m	struct:mlme_ext_priv
-cur_ch_offset	include/rtw_mlme_ext.h	/^	unsigned char	cur_ch_offset;\/* PRIME_CHNL_OFFSET *\/$/;"	m	struct:mlme_ext_priv
-cur_channel	include/rtw_mlme.h	/^	u8					cur_channel;$/;"	m	struct:tdls_info
-cur_channel	include/rtw_mlme_ext.h	/^	unsigned char	cur_channel;$/;"	m	struct:mlme_ext_priv
-cur_dac_swing_lvl	hal/btc/HalBtc8192e2Ant.h	/^	u32		cur_dac_swing_lvl;$/;"	m	struct:coex_dm_8192e_2ant
-cur_dac_swing_lvl	hal/btc/HalBtc8723b2Ant.h	/^	u32		cur_dac_swing_lvl;$/;"	m	struct:coex_dm_8723b_2ant
-cur_dac_swing_lvl	hal/btc/HalBtc8812a2Ant.h	/^	u32		cur_dac_swing_lvl;$/;"	m	struct:coex_dm_8812a_2ant
-cur_dac_swing_lvl	hal/btc/HalBtc8821a2Ant.h	/^	u32		cur_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_2ant
-cur_dac_swing_lvl	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		cur_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_dac_swing_lvl	hal/btc/halbtc8723d2ant.h	/^	u32		cur_dac_swing_lvl;$/;"	m	struct:coex_dm_8723d_2ant
-cur_dac_swing_lvl	hal/btc/halbtc8821c2ant.h	/^	u32		cur_dac_swing_lvl;$/;"	m	struct:coex_dm_8821c_2ant
-cur_dac_swing_on	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_dac_swing_on;$/;"	m	struct:coex_dm_8192e_2ant
-cur_dac_swing_on	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_dac_swing_on;$/;"	m	struct:coex_dm_8723b_2ant
-cur_dac_swing_on	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_dac_swing_on;$/;"	m	struct:coex_dm_8812a_2ant
-cur_dac_swing_on	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_dac_swing_on;$/;"	m	struct:coex_dm_8821a_2ant
-cur_dac_swing_on	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_dac_swing_on;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_dac_swing_on	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_dac_swing_on;$/;"	m	struct:coex_dm_8723d_2ant
-cur_dac_swing_on	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_dac_swing_on;$/;"	m	struct:coex_dm_8821c_2ant
-cur_dec_bt_pwr	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_dec_bt_pwr;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_ext_ant_switch_status	hal/btc/HalBtc8822b1Ant.h	/^	u32		cur_ext_ant_switch_status;$/;"	m	struct:coex_dm_8822b_1ant
-cur_ext_ant_switch_status	hal/btc/halbtc8821c1ant.h	/^	u32		cur_ext_ant_switch_status;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ext_ant_switch_status	hal/btc/halbtc8821c2ant.h	/^	u32		cur_ext_ant_switch_status;$/;"	m	struct:coex_dm_8821c_2ant
-cur_ext_band_switch_status	hal/btc/halbtc8821c1ant.h	/^	u8		cur_ext_band_switch_status;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ext_band_switch_status	hal/btc/halbtc8821c2ant.h	/^	u8		cur_ext_band_switch_status;$/;"	m	struct:coex_dm_8821c_2ant
-cur_fw_dac_swing_lvl	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8192e_2ant
-cur_fw_dac_swing_lvl	hal/btc/HalBtc8723b2Ant.h	/^	u8		cur_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8723b_2ant
-cur_fw_dac_swing_lvl	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8812a_2ant
-cur_fw_dac_swing_lvl	hal/btc/HalBtc8821a2Ant.h	/^	u8		cur_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_2ant
-cur_fw_dac_swing_lvl	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		cur_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_fw_dac_swing_lvl	hal/btc/halbtc8723d2ant.h	/^	u8		cur_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8723d_2ant
-cur_fw_dac_swing_lvl	hal/btc/halbtc8821c2ant.h	/^	u8		cur_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8821c_2ant
-cur_ignore_wlan_act	hal/btc/HalBtc8192e1Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8192e_1ant
-cur_ignore_wlan_act	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8192e_2ant
-cur_ignore_wlan_act	hal/btc/HalBtc8703b1Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8703b_1ant
-cur_ignore_wlan_act	hal/btc/HalBtc8723b1Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8723b_1ant
-cur_ignore_wlan_act	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8723b_2ant
-cur_ignore_wlan_act	hal/btc/HalBtc8812a1Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8812a_1ant
-cur_ignore_wlan_act	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8812a_2ant
-cur_ignore_wlan_act	hal/btc/HalBtc8821a1Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8821a_1ant
-cur_ignore_wlan_act	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8821a_2ant
-cur_ignore_wlan_act	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_ignore_wlan_act	hal/btc/HalBtc8822b1Ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8822b_1ant
-cur_ignore_wlan_act	hal/btc/halbtc8723d1ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8723d_1ant
-cur_ignore_wlan_act	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8723d_2ant
-cur_ignore_wlan_act	hal/btc/halbtc8821c1ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ignore_wlan_act	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_ignore_wlan_act;$/;"	m	struct:coex_dm_8821c_2ant
-cur_int_block_status	hal/btc/halbtc8821c1ant.h	/^	u8		cur_int_block_status;$/;"	m	struct:coex_dm_8821c_1ant
-cur_int_block_status	hal/btc/halbtc8821c2ant.h	/^	u8		cur_int_block_status;$/;"	m	struct:coex_dm_8821c_2ant
-cur_low_penalty_ra	hal/btc/HalBtc8192e1Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8192e_1ant
-cur_low_penalty_ra	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8192e_2ant
-cur_low_penalty_ra	hal/btc/HalBtc8703b1Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8703b_1ant
-cur_low_penalty_ra	hal/btc/HalBtc8723b1Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8723b_1ant
-cur_low_penalty_ra	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8723b_2ant
-cur_low_penalty_ra	hal/btc/HalBtc8812a1Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8812a_1ant
-cur_low_penalty_ra	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8812a_2ant
-cur_low_penalty_ra	hal/btc/HalBtc8821a1Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8821a_1ant
-cur_low_penalty_ra	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8821a_2ant
-cur_low_penalty_ra	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_low_penalty_ra	hal/btc/HalBtc8822b1Ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8822b_1ant
-cur_low_penalty_ra	hal/btc/halbtc8723d1ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8723d_1ant
-cur_low_penalty_ra	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8723d_2ant
-cur_low_penalty_ra	hal/btc/halbtc8821c1ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8821c_1ant
-cur_low_penalty_ra	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_low_penalty_ra;$/;"	m	struct:coex_dm_8821c_2ant
-cur_lps	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8192e_1ant
-cur_lps	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8192e_2ant
-cur_lps	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8703b_1ant
-cur_lps	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8723b_1ant
-cur_lps	hal/btc/HalBtc8723b2Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8723b_2ant
-cur_lps	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8812a_1ant
-cur_lps	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8812a_2ant
-cur_lps	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8821a_1ant
-cur_lps	hal/btc/HalBtc8821a2Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8821a_2ant
-cur_lps	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8822b_1ant
-cur_lps	hal/btc/halbtc8723d1ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8723d_1ant
-cur_lps	hal/btc/halbtc8723d2ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8723d_2ant
-cur_lps	hal/btc/halbtc8821c1ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8821c_1ant
-cur_lps	hal/btc/halbtc8821c2ant.h	/^	u8		cur_lps;$/;"	m	struct:coex_dm_8821c_2ant
-cur_mcc_success_cnt	include/rtw_mcc.h	/^	u8 cur_mcc_success_cnt; \/* used for check mcc switch channel success *\/$/;"	m	struct:mcc_obj_priv
-cur_network	include/rtw_mlme.h	/^	struct wlan_network	cur_network;$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::wlan_network
-cur_network_scanned	include/rtw_mlme.h	/^	struct wlan_network *cur_network_scanned;$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::wlan_network
-cur_ps_level	include/rtw_pwrctrl.h	/^	u32	cur_ps_level;$/;"	m	struct:pwrctrl_priv
-cur_ps_tdma	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8192e_1ant
-cur_ps_tdma	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8192e_2ant
-cur_ps_tdma	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8703b_1ant
-cur_ps_tdma	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8723b_1ant
-cur_ps_tdma	hal/btc/HalBtc8723b2Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8723b_2ant
-cur_ps_tdma	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8812a_1ant
-cur_ps_tdma	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8812a_2ant
-cur_ps_tdma	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8821a_1ant
-cur_ps_tdma	hal/btc/HalBtc8821a2Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8821a_2ant
-cur_ps_tdma	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_ps_tdma	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8822b_1ant
-cur_ps_tdma	hal/btc/halbtc8723d1ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8723d_1ant
-cur_ps_tdma	hal/btc/halbtc8723d2ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8723d_2ant
-cur_ps_tdma	hal/btc/halbtc8821c1ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ps_tdma	hal/btc/halbtc8821c2ant.h	/^	u8		cur_ps_tdma;$/;"	m	struct:coex_dm_8821c_2ant
-cur_ps_tdma_on	hal/btc/HalBtc8192e1Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8192e_1ant
-cur_ps_tdma_on	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8192e_2ant
-cur_ps_tdma_on	hal/btc/HalBtc8703b1Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8703b_1ant
-cur_ps_tdma_on	hal/btc/HalBtc8723b1Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8723b_1ant
-cur_ps_tdma_on	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8723b_2ant
-cur_ps_tdma_on	hal/btc/HalBtc8812a1Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8812a_1ant
-cur_ps_tdma_on	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8812a_2ant
-cur_ps_tdma_on	hal/btc/HalBtc8821a1Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8821a_1ant
-cur_ps_tdma_on	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8821a_2ant
-cur_ps_tdma_on	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_ps_tdma_on	hal/btc/HalBtc8822b1Ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8822b_1ant
-cur_ps_tdma_on	hal/btc/halbtc8723d1ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8723d_1ant
-cur_ps_tdma_on	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8723d_2ant
-cur_ps_tdma_on	hal/btc/halbtc8821c1ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ps_tdma_on	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_ps_tdma_on;$/;"	m	struct:coex_dm_8821c_2ant
-cur_ra_mask	hal/btc/HalBtc8192e1Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8192e_1ant
-cur_ra_mask	hal/btc/HalBtc8192e2Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8192e_2ant
-cur_ra_mask	hal/btc/HalBtc8703b1Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8703b_1ant
-cur_ra_mask	hal/btc/HalBtc8723b1Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8723b_1ant
-cur_ra_mask	hal/btc/HalBtc8812a1Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8812a_1ant
-cur_ra_mask	hal/btc/HalBtc8812a2Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8812a_2ant
-cur_ra_mask	hal/btc/HalBtc8821a1Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8821a_1ant
-cur_ra_mask	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_ra_mask	hal/btc/HalBtc8822b1Ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8822b_1ant
-cur_ra_mask	hal/btc/halbtc8723d1ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8723d_1ant
-cur_ra_mask	hal/btc/halbtc8821c1ant.h	/^	u32		cur_ra_mask;$/;"	m	struct:coex_dm_8821c_1ant
-cur_ra_mask_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_ra_mask_type;$/;"	m	struct:coex_dm_8192e_2ant
-cur_ra_mask_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_ra_mask_type;$/;"	m	struct:coex_dm_8812a_2ant
-cur_retry_limit_type	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8192e_1ant
-cur_retry_limit_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8192e_2ant
-cur_retry_limit_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8703b_1ant
-cur_retry_limit_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8723b_1ant
-cur_retry_limit_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8812a_1ant
-cur_retry_limit_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8812a_2ant
-cur_retry_limit_type	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8821a_1ant
-cur_retry_limit_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_retry_limit_type	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8822b_1ant
-cur_retry_limit_type	hal/btc/halbtc8723d1ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8723d_1ant
-cur_retry_limit_type	hal/btc/halbtc8821c1ant.h	/^	u8		cur_retry_limit_type;$/;"	m	struct:coex_dm_8821c_1ant
-cur_rf_rx_lpf_shrink	hal/btc/HalBtc8192e2Ant.h	/^	boolean		cur_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8192e_2ant
-cur_rf_rx_lpf_shrink	hal/btc/HalBtc8723b2Ant.h	/^	boolean		cur_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8723b_2ant
-cur_rf_rx_lpf_shrink	hal/btc/HalBtc8812a2Ant.h	/^	boolean		cur_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8812a_2ant
-cur_rf_rx_lpf_shrink	hal/btc/HalBtc8821a2Ant.h	/^	boolean		cur_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8821a_2ant
-cur_rf_rx_lpf_shrink	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		cur_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_rf_rx_lpf_shrink	hal/btc/halbtc8723d2ant.h	/^	boolean		cur_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8723d_2ant
-cur_rf_rx_lpf_shrink	hal/btc/halbtc8821c2ant.h	/^	boolean		cur_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8821c_2ant
-cur_rpwm	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8192e_1ant
-cur_rpwm	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8192e_2ant
-cur_rpwm	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8703b_1ant
-cur_rpwm	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8723b_1ant
-cur_rpwm	hal/btc/HalBtc8723b2Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8723b_2ant
-cur_rpwm	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8812a_1ant
-cur_rpwm	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8812a_2ant
-cur_rpwm	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8821a_1ant
-cur_rpwm	hal/btc/HalBtc8821a2Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8821a_2ant
-cur_rpwm	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8822b_1ant
-cur_rpwm	hal/btc/halbtc8723d1ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8723d_1ant
-cur_rpwm	hal/btc/halbtc8723d2ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8723d_2ant
-cur_rpwm	hal/btc/halbtc8821c1ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8821c_1ant
-cur_rpwm	hal/btc/halbtc8821c2ant.h	/^	u8		cur_rpwm;$/;"	m	struct:coex_dm_8821c_2ant
-cur_rtp_rxseq	include/rtw_recv.h	/^	u16 sink_udpport, pre_rtp_rxseq, cur_rtp_rxseq;$/;"	m	struct:recv_priv
-cur_rx_bytes	include/drv_types.h	/^	u64	cur_rx_bytes;$/;"	m	struct:rtw_traffic_statistics
-cur_rx_tp	include/drv_types.h	/^	u32	cur_rx_tp; \/* Rx throughput in MBps. *\/$/;"	m	struct:rtw_traffic_statistics
-cur_ss_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_ss_type;$/;"	m	struct:coex_dm_8192e_2ant
-cur_time	include/rtw_mlme.h	/^	u32	cur_time;$/;"	m	struct:tdls_ch_switch
-cur_tx_bytes	include/drv_types.h	/^	u64	cur_tx_bytes;$/;"	m	struct:rtw_traffic_statistics
-cur_tx_tp	include/drv_types.h	/^	u32	cur_tx_tp; \/* Tx throughput in MBps. *\/$/;"	m	struct:rtw_traffic_statistics
-cur_val0x6c0	hal/btc/HalBtc8192e1Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8192e_1ant
-cur_val0x6c0	hal/btc/HalBtc8192e2Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8192e_2ant
-cur_val0x6c0	hal/btc/HalBtc8703b1Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8703b_1ant
-cur_val0x6c0	hal/btc/HalBtc8723b1Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8723b_1ant
-cur_val0x6c0	hal/btc/HalBtc8723b2Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8723b_2ant
-cur_val0x6c0	hal/btc/HalBtc8812a1Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8812a_1ant
-cur_val0x6c0	hal/btc/HalBtc8812a2Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8812a_2ant
-cur_val0x6c0	hal/btc/HalBtc8821a1Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8821a_1ant
-cur_val0x6c0	hal/btc/HalBtc8821a2Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8821a_2ant
-cur_val0x6c0	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_val0x6c0	hal/btc/HalBtc8822b1Ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8822b_1ant
-cur_val0x6c0	hal/btc/halbtc8723d1ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8723d_1ant
-cur_val0x6c0	hal/btc/halbtc8723d2ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8723d_2ant
-cur_val0x6c0	hal/btc/halbtc8821c1ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8821c_1ant
-cur_val0x6c0	hal/btc/halbtc8821c2ant.h	/^	u32		cur_val0x6c0;$/;"	m	struct:coex_dm_8821c_2ant
-cur_val0x6c4	hal/btc/HalBtc8192e1Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8192e_1ant
-cur_val0x6c4	hal/btc/HalBtc8192e2Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8192e_2ant
-cur_val0x6c4	hal/btc/HalBtc8703b1Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8703b_1ant
-cur_val0x6c4	hal/btc/HalBtc8723b1Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8723b_1ant
-cur_val0x6c4	hal/btc/HalBtc8723b2Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8723b_2ant
-cur_val0x6c4	hal/btc/HalBtc8812a1Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8812a_1ant
-cur_val0x6c4	hal/btc/HalBtc8812a2Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8812a_2ant
-cur_val0x6c4	hal/btc/HalBtc8821a1Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8821a_1ant
-cur_val0x6c4	hal/btc/HalBtc8821a2Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8821a_2ant
-cur_val0x6c4	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_val0x6c4	hal/btc/HalBtc8822b1Ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8822b_1ant
-cur_val0x6c4	hal/btc/halbtc8723d1ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8723d_1ant
-cur_val0x6c4	hal/btc/halbtc8723d2ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8723d_2ant
-cur_val0x6c4	hal/btc/halbtc8821c1ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8821c_1ant
-cur_val0x6c4	hal/btc/halbtc8821c2ant.h	/^	u32		cur_val0x6c4;$/;"	m	struct:coex_dm_8821c_2ant
-cur_val0x6c8	hal/btc/HalBtc8192e1Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8192e_1ant
-cur_val0x6c8	hal/btc/HalBtc8192e2Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8192e_2ant
-cur_val0x6c8	hal/btc/HalBtc8703b1Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8703b_1ant
-cur_val0x6c8	hal/btc/HalBtc8723b1Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8723b_1ant
-cur_val0x6c8	hal/btc/HalBtc8723b2Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8723b_2ant
-cur_val0x6c8	hal/btc/HalBtc8812a1Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8812a_1ant
-cur_val0x6c8	hal/btc/HalBtc8812a2Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8812a_2ant
-cur_val0x6c8	hal/btc/HalBtc8821a1Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8821a_1ant
-cur_val0x6c8	hal/btc/HalBtc8821a2Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8821a_2ant
-cur_val0x6c8	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_val0x6c8	hal/btc/HalBtc8822b1Ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8822b_1ant
-cur_val0x6c8	hal/btc/halbtc8723d1ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8723d_1ant
-cur_val0x6c8	hal/btc/halbtc8723d2ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8723d_2ant
-cur_val0x6c8	hal/btc/halbtc8821c1ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8821c_1ant
-cur_val0x6c8	hal/btc/halbtc8821c2ant.h	/^	u32		cur_val0x6c8;$/;"	m	struct:coex_dm_8821c_2ant
-cur_val0x6cc	hal/btc/HalBtc8192e1Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8192e_1ant
-cur_val0x6cc	hal/btc/HalBtc8192e2Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8192e_2ant
-cur_val0x6cc	hal/btc/HalBtc8703b1Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8703b_1ant
-cur_val0x6cc	hal/btc/HalBtc8723b1Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8723b_1ant
-cur_val0x6cc	hal/btc/HalBtc8723b2Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8723b_2ant
-cur_val0x6cc	hal/btc/HalBtc8812a1Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8812a_1ant
-cur_val0x6cc	hal/btc/HalBtc8812a2Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8812a_2ant
-cur_val0x6cc	hal/btc/HalBtc8821a1Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8821a_1ant
-cur_val0x6cc	hal/btc/HalBtc8821a2Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8821a_2ant
-cur_val0x6cc	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8821a_csr_2ant
-cur_val0x6cc	hal/btc/HalBtc8822b1Ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8822b_1ant
-cur_val0x6cc	hal/btc/halbtc8723d1ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8723d_1ant
-cur_val0x6cc	hal/btc/halbtc8723d2ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8723d_2ant
-cur_val0x6cc	hal/btc/halbtc8821c1ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8821c_1ant
-cur_val0x6cc	hal/btc/halbtc8821c2ant.h	/^	u8		cur_val0x6cc;$/;"	m	struct:coex_dm_8821c_2ant
-cur_wireless_mode	include/rtw_mlme_ext.h	/^	unsigned char	cur_wireless_mode;	\/* NETWORK_TYPE *\/$/;"	m	struct:mlme_ext_priv
-curlen	include/rtw_security.h	/^	u32 state[8], curlen;$/;"	m	struct:sha256_state
-curr_bandwidth	include/rtw_cmd.h	/^	u8 curr_bandwidth;$/;"	m	struct:SwitchBandwidth_parm
-curr_crystalcap	include/rtw_cmd.h	/^	u32 curr_crystalcap;$/;"	m	struct:SetCrystalCap_parm
-curr_rateidx	include/rtw_cmd.h	/^	u32	curr_rateidx;$/;"	m	struct:setdatarate_parm
-curr_rateidx	include/rtw_cmd.h	/^	u32 curr_rateidx;$/;"	m	struct:SetCarrierSuppressionTx_parm
-curr_rateidx	include/rtw_cmd.h	/^	u32 curr_rateidx;$/;"	m	struct:SetContinuousTx_parm
-curr_rfpath	include/rtw_cmd.h	/^	u8 curr_rfpath;$/;"	m	struct:SetSingleToneTx_parm
-curr_station_id	hal/phydm/phydm.h	/^	u1Byte			curr_station_id;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-curractfunc	include/rtw_mp.h	/^	wi_act_func curractfunc;$/;"	m	struct:mp_wi_cntx
-current_ap	include/ieee80211_ext.h	/^			u8 current_ap[6];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon31
-current_ap	include/ieee80211_ext.h	/^			u8 current_ap[6];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon13
-current_rd	include/wifi.h	/^	u16 current_rd;$/;"	m	struct:rtw_regulatory
-current_rd_ext	include/wifi.h	/^	u16 current_rd_ext;$/;"	m	struct:rtw_regulatory
-cust_gpio_modes	include/custom_gpio.h	/^typedef enum cust_gpio_modes {$/;"	g
-cust_gpio_modes_t	include/custom_gpio.h	/^} cust_gpio_modes_t;$/;"	t	typeref:enum:cust_gpio_modes
-customer_str	include/drv_types.h	/^	u8 customer_str[RTW_CUSTOMER_STR_LEN];$/;"	m	struct:dvobj_priv
-customer_str_mutex	include/drv_types.h	/^	_mutex customer_str_mutex;$/;"	m	struct:dvobj_priv
-customer_str_sctx	include/drv_types.h	/^	struct submit_ctx *customer_str_sctx;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::submit_ctx
-cut_msk	include/HalPwrSeqCmd.h	/^	u8 cut_msk;$/;"	m	struct:_WL_PWR_CFG_
-cut_version	hal/btc/HalBtc8703b1Ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8703b_1ant
-cut_version	hal/btc/HalBtc8723b1Ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8723b_1ant
-cut_version	hal/btc/HalBtc8723b2Ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8723b_2ant
-cut_version	hal/btc/HalBtc8822b1Ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8822b_1ant
-cut_version	hal/btc/halbtc8723d1ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8723d_1ant
-cut_version	hal/btc/halbtc8723d2ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8723d_2ant
-cut_version	hal/btc/halbtc8821c1ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8821c_1ant
-cut_version	hal/btc/halbtc8821c2ant.h	/^	u8					cut_version;$/;"	m	struct:coex_sta_8821c_2ant
-dBForAntA	hal/phydm/phydm_antdect.h	/^	u4Byte			dBForAntA;$/;"	m	struct:_ANT_DETECTED_INFO
-dBForAntB	hal/phydm/phydm_antdect.h	/^	u4Byte			dBForAntB;$/;"	m	struct:_ANT_DETECTED_INFO
-dBForAntO	hal/phydm/phydm_antdect.h	/^	u4Byte			dBForAntO;$/;"	m	struct:_ANT_DETECTED_INFO
-dB_Invert_Table	hal/phydm/phydm.c	/^const u2Byte dB_Invert_Table[12][8] = {$/;"	v
-dB_Max	hal/phydm/rtchnlplan.h	/^	u1Byte	dB_Max;$/;"	m	struct:_RT_CHNL_PLAN_PWR_LIMIT
-da	core/rtw_mi.c	/^	unsigned char *da;$/;"	m	struct:nulldata_param	file:
-da	include/ieee80211_ext.h	/^	u8 da[6];$/;"	m	struct:ieee80211_mgmt
-da	include/rtw_mp_ioctl.h	/^	u8 da[ETH_ALEN];$/;"	m	struct:_mp_xmit_parm_
-daddr	include/ip.h	/^	__u32	daddr;$/;"	m	struct:iphdr
-dagc_gain	hal/phydm/phydm_hwconfig.h	/^	u1Byte		dagc_gain[4];$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-data	hal/btc/HalBtcOutSrc.h	/^	u1Byte	data[1];$/;"	m	struct:_COL_C2H_IND
-data	include/ieee80211.h	/^			u8 data[0];$/;"	m	struct:ieee_param::__anon73::__anon75
-data	include/ieee80211.h	/^	u8 data[0];$/;"	m	struct:ieee80211_info_element
-data	include/ieee80211.h	/^	u8 data[0];$/;"	m	struct:ieee_param_ex
-data	include/linux/wireless.h	/^	struct iw_point	data;		\/* Other large parameters *\/$/;"	m	union:iwreq_data	typeref:struct:iwreq_data::iw_point
-data	include/osdep_service_bsd.h	/^				*data;$/;"	m	struct:sk_buff
-data	include/rtw_efuse.h	/^	u8 data[8];$/;"	m	struct:PG_PKT_STRUCT_A
-data	include/rtw_iol.h	/^	u32	data;$/;"	m	struct:ioreg_cfg
-data	include/rtw_mp_ioctl.h	/^	u8	data[0];$/;"	m	struct:_EFUSE_ACCESS_STRUCT_
-data	include/rtw_mp_ioctl.h	/^	u8 data[0];$/;"	m	struct:mp_ioctl_param
-data	include/wlan_bssdef.h	/^	UCHAR  data[1];$/;"	m	struct:_NDIS_802_11_VARIABLE_IEs
-dataKey	include/rtw_wapi.h	/^	u8			dataKey[16];$/;"	m	struct:_RT_WAPI_KEY
-data_bw	include/rtl8188e_xmit.h	/^	u32 data_bw:1;$/;"	m	struct:txdesc_88e
-data_bw	include/rtl8192e_xmit.h	/^	u32 data_bw:1;$/;"	m	struct:txdescriptor_8192e
-data_bw	include/rtl8812a_xmit.h	/^	u32 data_bw:1;$/;"	m	struct:txdescriptor_8812
-data_bw	include/rtl8821a_xmit.h	/^	u32 data_bw:2;$/;"	m	struct:txdescriptor_8821a
-data_codeword_bit_num	hal/phydm/phydm_antdiv.h	/^	u4Byte	data_codeword_bit_num;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-data_fb	include/drv_types.h	/^	u8 data_fb; \/* data rate fallback, valid only when fix_rate is not 0xff *\/$/;"	m	struct:_ADAPTER
-data_frame_num	hal/phydm/phydm.h	/^	u4Byte			data_frame_num;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-data_ldpc	include/rtl8821a_xmit.h	/^	u32 data_ldpc:1;$/;"	m	struct:txdescriptor_8821a
-data_len	include/osdep_service_bsd.h	/^				data_len;$/;"	m	struct:sk_buff
-data_rate	include/rtw_recv.h	/^	u8	data_rate;$/;"	m	struct:rx_pkt_attrib
-data_rate	include/rtw_recv.h	/^	u8 data_rate;$/;"	m	struct:rx_raw_rssi
-data_ratefb_lmt	include/rtl8188e_xmit.h	/^	u32 data_ratefb_lmt:5;$/;"	m	struct:txdesc_88e
-data_ratefb_lmt	include/rtl8192e_xmit.h	/^	u32 data_ratefb_lmt:5;$/;"	m	struct:txdescriptor_8192e
-data_ratefb_lmt	include/rtl8812a_xmit.h	/^	u32 data_ratefb_lmt:5;$/;"	m	struct:txdescriptor_8812
-data_ratefb_lmt	include/rtl8821a_xmit.h	/^	u32 data_ratefb_lmt:5;$/;"	m	struct:txdescriptor_8821a
-data_rc	include/rtl8188e_xmit.h	/^	u32 data_rc:6;$/;"	m	struct:txdesc_88e
-data_rc	include/rtl8192e_xmit.h	/^	u32 data_rc:6;$/;"	m	struct:txdescriptor_8192e
-data_rc	include/rtl8812a_xmit.h	/^	u32 data_rc:6;$/;"	m	struct:txdescriptor_8812
-data_rc	include/rtl8821a_xmit.h	/^	u32 data_rc:6;$/;"	m	struct:txdescriptor_8821a
-data_rt_lmt	include/rtl8188e_xmit.h	/^	u32 data_rt_lmt:6;$/;"	m	struct:txdesc_88e
-data_rt_lmt	include/rtl8192e_xmit.h	/^	u32 data_rt_lmt:6;$/;"	m	struct:txdescriptor_8192e
-data_rt_lmt	include/rtl8812a_xmit.h	/^	u32 data_rt_lmt:6;$/;"	m	struct:txdescriptor_8812
-data_rt_lmt	include/rtl8821a_xmit.h	/^	u32 data_rt_lmt:6;$/;"	m	struct:txdescriptor_8821a
-data_sc	include/rtl8188e_xmit.h	/^	u32 data_sc:2;$/;"	m	struct:txdesc_88e
-data_sc	include/rtl8192e_xmit.h	/^	u32 data_sc:2;$/;"	m	struct:txdescriptor_8192e
-data_sc	include/rtl8812a_xmit.h	/^	u32 data_sc:2;$/;"	m	struct:txdescriptor_8812
-data_sc	include/rtl8821a_xmit.h	/^	u32 data_sc:4;$/;"	m	struct:txdescriptor_8821a
-data_short	include/rtl8188e_xmit.h	/^	u32 data_short:1;$/;"	m	struct:txdesc_88e
-data_short	include/rtl8192e_xmit.h	/^	u32 data_short:1;$/;"	m	struct:txdescriptor_8192e
-data_short	include/rtl8812a_xmit.h	/^	u32 data_short:1;$/;"	m	struct:txdescriptor_8812
-data_short	include/rtl8821a_xmit.h	/^	u32 data_short:1;$/;"	m	struct:txdescriptor_8821a
-data_stbc	include/rtl8188e_xmit.h	/^	u32 data_stbc:2;$/;"	m	struct:txdesc_88e
-data_stbc	include/rtl8192e_xmit.h	/^	u32 data_stbc:2;$/;"	m	struct:txdescriptor_8192e
-data_stbc	include/rtl8812a_xmit.h	/^	u32 data_stbc:2;$/;"	m	struct:txdescriptor_8812
-data_stbc	include/rtl8821a_xmit.h	/^	u32 data_stbc:2;$/;"	m	struct:txdescriptor_8821a
-datarate	include/rtl8188e_xmit.h	/^	u32 datarate:6;$/;"	m	struct:txdesc_88e
-datarate	include/rtl8192e_xmit.h	/^	u32 datarate:6;$/;"	m	struct:txdescriptor_8192e
-datarate	include/rtl8812a_xmit.h	/^	u32 datarate:6;$/;"	m	struct:txdescriptor_8812
-datarate	include/rtl8821a_xmit.h	/^	u32 datarate:7;$/;"	m	struct:txdescriptor_8821a
-datarate	include/rtw_mlme_ext.h	/^	unsigned char	datarate[NumRates];$/;"	m	struct:mlme_ext_priv
-datarate_param	include/rtw_mp_ioctl.h	/^struct datarate_param {$/;"	s
-datarates	include/rtw_cmd.h	/^	u8 datarates[NumRates];$/;"	m	struct:getdatarate_rsp
-dbg	include/rtw_ioctl.h	/^	u32		dbg;$/;"	m	struct:oid_par_priv
-dbg	include/rtw_ioctl.h	/^	unsigned char	dbg; \/* 0: without OID debug message  1: with OID debug message *\/$/;"	m	struct:oid_obj_priv
-dbg_carddisable_cnt	include/drv_types.h	/^	u32 dbg_carddisable_cnt;$/;"	m	struct:debug_priv
-dbg_carddisable_error_cnt	include/drv_types.h	/^	u32 dbg_carddisable_error_cnt;$/;"	m	struct:debug_priv
-dbg_deinit_fail_cnt	include/drv_types.h	/^	u32 dbg_deinit_fail_cnt;$/;"	m	struct:debug_priv
-dbg_dev_unload_inIPS_cnt	include/drv_types.h	/^	u32	dbg_dev_unload_inIPS_cnt;$/;"	m	struct:debug_priv
-dbg_dfs_master_choose_dfs_ch_first	include/drv_types.h	/^	u8 dbg_dfs_master_choose_dfs_ch_first;$/;"	m	struct:rf_ctl_t
-dbg_dfs_master_fake_radar_detect_cnt	include/drv_types.h	/^	u8 dbg_dfs_master_fake_radar_detect_cnt;$/;"	m	struct:rf_ctl_t
-dbg_dfs_master_radar_detect_trigger_non	include/drv_types.h	/^	u8 dbg_dfs_master_radar_detect_trigger_non;$/;"	m	struct:rf_ctl_t
-dbg_disable_mu_tx	hal/phydm/phydm_beamforming.h	/^	BOOLEAN					dbg_disable_mu_tx;$/;"	m	struct:_RT_BEAMFORMING_INFO
-dbg_diswow_dload_fw_fail_cnt	include/drv_types.h	/^	u32 dbg_diswow_dload_fw_fail_cnt;$/;"	m	struct:debug_priv
-dbg_downloadfw_pwr_state_cnt	include/drv_types.h	/^	u32 dbg_downloadfw_pwr_state_cnt;$/;"	m	struct:debug_priv
-dbg_enwow_dload_fw_fail_cnt	include/drv_types.h	/^	u32 dbg_enwow_dload_fw_fail_cnt;$/;"	m	struct:debug_priv
-dbg_fw_read_ps_state_fail_cnt	include/drv_types.h	/^	u32 dbg_fw_read_ps_state_fail_cnt;$/;"	m	struct:debug_priv
-dbg_h2c_leave32k_fail_cnt	include/drv_types.h	/^	u32 dbg_h2c_leave32k_fail_cnt;$/;"	m	struct:debug_priv
-dbg_ips_drvopen_fail_cnt	include/drv_types.h	/^	u32 dbg_ips_drvopen_fail_cnt;$/;"	m	struct:debug_priv
-dbg_leave_ips_fail_cnt	include/drv_types.h	/^	u32 dbg_leave_ips_fail_cnt;$/;"	m	struct:debug_priv
-dbg_leave_lps_fail_cnt	include/drv_types.h	/^	u32 dbg_leave_lps_fail_cnt;$/;"	m	struct:debug_priv
-dbg_poll_fail_cnt	include/drv_types.h	/^	u32 dbg_poll_fail_cnt;$/;"	m	struct:debug_priv
-dbg_port0	hal/phydm/phydm_dig.h	/^	u4Byte		dbg_port0;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-dbg_ps_insuspend_cnt	include/drv_types.h	/^	u32 dbg_ps_insuspend_cnt;$/;"	m	struct:debug_priv
-dbg_resume_cnt	include/drv_types.h	/^	u32 dbg_resume_cnt;$/;"	m	struct:debug_priv
-dbg_resume_error_cnt	include/drv_types.h	/^	u32 dbg_resume_error_cnt;$/;"	m	struct:debug_priv
-dbg_rpwm_timeout_fail_cnt	include/drv_types.h	/^	u32 dbg_rpwm_timeout_fail_cnt;$/;"	m	struct:debug_priv
-dbg_rpwm_toogle_cnt	include/drv_types.h	/^	u32 dbg_rpwm_toogle_cnt;$/;"	m	struct:debug_priv
-dbg_rtw_IOL_append_WB_cmd	core/rtw_iol.c	/^int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line)$/;"	f
-dbg_rtw_IOL_append_WD_cmd	core/rtw_iol.c	/^int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line)$/;"	f
-dbg_rtw_IOL_append_WW_cmd	core/rtw_iol.c	/^int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line)$/;"	f
-dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb	os_dep/linux/rtw_cfgvendor.c	/^struct sk_buff *dbg_rtw_cfg80211_vendor_cmd_alloc_reply_skb(struct wiphy *wiphy, int len$/;"	f
-dbg_rtw_cfg80211_vendor_cmd_reply	os_dep/linux/rtw_cfgvendor.c	/^int dbg_rtw_cfg80211_vendor_cmd_reply(struct sk_buff *skb$/;"	f
-dbg_rtw_cfg80211_vendor_event	os_dep/linux/rtw_cfgvendor.c	/^void dbg_rtw_cfg80211_vendor_event(struct sk_buff *skb, gfp_t gfp$/;"	f
-dbg_rtw_cfg80211_vendor_event_alloc	os_dep/linux/rtw_cfgvendor.c	/^struct sk_buff *dbg_rtw_cfg80211_vendor_event_alloc(struct wiphy *wiphy, struct wireless_dev *wdev, int len, int event_id, gfp_t gfp$/;"	f
-dbg_rtw_malloc	os_dep/osdep_service.c	/^inline u8 *dbg_rtw_malloc(u32 sz, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rtw_mfree	os_dep/osdep_service.c	/^inline void dbg_rtw_mfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rtw_napi_gro_receive	os_dep/osdep_service.c	/^inline gro_result_t dbg_rtw_napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_netif_receive_skb	os_dep/osdep_service.c	/^inline int dbg_rtw_netif_receive_skb(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_netif_rx	os_dep/osdep_service.c	/^inline int dbg_rtw_netif_rx(_nic_hdl ndev, struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_p2p_set_pre_state	core/rtw_p2p.c	/^void dbg_rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line)$/;"	f
-dbg_rtw_p2p_set_role	core/rtw_p2p.c	/^void dbg_rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role, const char *caller, int line)$/;"	f
-dbg_rtw_p2p_set_state	core/rtw_p2p.c	/^void dbg_rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line)$/;"	f
-dbg_rtw_read16	core/rtw_io.c	/^u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int line)$/;"	f
-dbg_rtw_read32	core/rtw_io.c	/^u32 dbg_rtw_read32(_adapter *adapter, u32 addr, const char *caller, const int line)$/;"	f
-dbg_rtw_read8	core/rtw_io.c	/^u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line)$/;"	f
-dbg_rtw_sd_f0_read8	core/rtw_io.c	/^u8 dbg_rtw_sd_f0_read8(_adapter *adapter, u32 addr, const char *caller, const int line)$/;"	f
-dbg_rtw_sd_iread16	core/rtw_io.c	/^u16 dbg_rtw_sd_iread16(_adapter *adapter, u32 addr, const char *caller, const int line)$/;"	f
-dbg_rtw_sd_iread32	core/rtw_io.c	/^u32 dbg_rtw_sd_iread32(_adapter *adapter, u32 addr, const char *caller, const int line)$/;"	f
-dbg_rtw_sd_iread8	core/rtw_io.c	/^u8 dbg_rtw_sd_iread8(_adapter *adapter, u32 addr, const char *caller, const int line)$/;"	f
-dbg_rtw_sd_iwrite16	core/rtw_io.c	/^int dbg_rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)$/;"	f
-dbg_rtw_sd_iwrite32	core/rtw_io.c	/^int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)$/;"	f
-dbg_rtw_sd_iwrite8	core/rtw_io.c	/^int dbg_rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)$/;"	f
-dbg_rtw_skb_alloc	os_dep/osdep_service.c	/^inline struct sk_buff *dbg_rtw_skb_alloc(unsigned int size, const enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_skb_clone	os_dep/osdep_service.c	/^inline struct sk_buff *dbg_rtw_skb_clone(struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rtw_skb_copy	os_dep/osdep_service.c	/^inline struct sk_buff *dbg_rtw_skb_copy(const struct sk_buff *skb, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rtw_skb_free	os_dep/osdep_service.c	/^inline void dbg_rtw_skb_free(struct sk_buff *skb, const enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_skb_queue_purge	os_dep/osdep_service.c	/^inline void dbg_rtw_skb_queue_purge(struct sk_buff_head *list, enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_usb_buffer_alloc	os_dep/osdep_service.c	/^inline void *dbg_rtw_usb_buffer_alloc(struct usb_device *dev, size_t size, dma_addr_t *dma, const enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_usb_buffer_free	os_dep/osdep_service.c	/^inline void dbg_rtw_usb_buffer_free(struct usb_device *dev, size_t size, void *addr, dma_addr_t dma, const enum mstat_f flags, const char *func, int line)$/;"	f
-dbg_rtw_vmalloc	os_dep/osdep_service.c	/^inline u8 *dbg_rtw_vmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rtw_vmfree	os_dep/osdep_service.c	/^inline void dbg_rtw_vmfree(u8 *pbuf, u32 sz, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rtw_write16	core/rtw_io.c	/^int dbg_rtw_write16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)$/;"	f
-dbg_rtw_write32	core/rtw_io.c	/^int dbg_rtw_write32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)$/;"	f
-dbg_rtw_write8	core/rtw_io.c	/^int dbg_rtw_write8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)$/;"	f
-dbg_rtw_writeN	core/rtw_io.c	/^int dbg_rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *data, const char *caller, const int line)$/;"	f
-dbg_rtw_zmalloc	os_dep/osdep_service.c	/^inline u8 *dbg_rtw_zmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rtw_zvmalloc	os_dep/osdep_service.c	/^inline u8 *dbg_rtw_zvmalloc(u32 sz, const enum mstat_f flags, const char *func, const int line)$/;"	f
-dbg_rx_ampdu_drop_count	include/drv_types.h	/^	u64 dbg_rx_ampdu_drop_count;$/;"	m	struct:debug_priv
-dbg_rx_ampdu_forced_indicate_count	include/drv_types.h	/^	u64 dbg_rx_ampdu_forced_indicate_count;$/;"	m	struct:debug_priv
-dbg_rx_ampdu_loss_count	include/drv_types.h	/^	u64 dbg_rx_ampdu_loss_count;$/;"	m	struct:debug_priv
-dbg_rx_ampdu_window_shift_cnt	include/drv_types.h	/^	u64 dbg_rx_ampdu_window_shift_cnt;$/;"	m	struct:debug_priv
-dbg_rx_conflic_mac_addr_cnt	include/drv_types.h	/^	u64 dbg_rx_conflic_mac_addr_cnt;$/;"	m	struct:debug_priv
-dbg_rx_counter	include/hal_com.h	/^struct dbg_rx_counter {$/;"	s
-dbg_rx_dup_mgt_frame_drop_count	include/drv_types.h	/^	u64 dbg_rx_dup_mgt_frame_drop_count;$/;"	m	struct:debug_priv
-dbg_rx_fifo_curr_overflow	include/drv_types.h	/^	u64 dbg_rx_fifo_curr_overflow;$/;"	m	struct:debug_priv
-dbg_rx_fifo_diff_overflow	include/drv_types.h	/^	u64 dbg_rx_fifo_diff_overflow;$/;"	m	struct:debug_priv
-dbg_rx_fifo_last_overflow	include/drv_types.h	/^	u64 dbg_rx_fifo_last_overflow;$/;"	m	struct:debug_priv
-dbg_scan_pwr_state_cnt	include/drv_types.h	/^	u32 dbg_scan_pwr_state_cnt;$/;"	m	struct:debug_priv
-dbg_sdio_alloc_irq_cnt	include/drv_types.h	/^	u32 dbg_sdio_alloc_irq_cnt;$/;"	m	struct:debug_priv
-dbg_sdio_alloc_irq_error_cnt	include/drv_types.h	/^	u32 dbg_sdio_alloc_irq_error_cnt;$/;"	m	struct:debug_priv
-dbg_sdio_deinit_error_cnt	include/drv_types.h	/^	u32 dbg_sdio_deinit_error_cnt;$/;"	m	struct:debug_priv
-dbg_sdio_free_irq_cnt	include/drv_types.h	/^	u32 dbg_sdio_free_irq_cnt;$/;"	m	struct:debug_priv
-dbg_sdio_free_irq_error_cnt	include/drv_types.h	/^	u32 dbg_sdio_free_irq_error_cnt;$/;"	m	struct:debug_priv
-dbg_sdio_init_error_cnt	include/drv_types.h	/^	u32 dbg_sdio_init_error_cnt;$/;"	m	struct:debug_priv
-dbg_sreset_cnt	include/drv_types.h	/^	u32 dbg_sreset_cnt;$/;"	m	struct:debug_priv
-dbg_suspend_cnt	include/drv_types.h	/^	u32 dbg_suspend_cnt;$/;"	m	struct:debug_priv
-dbg_suspend_error_cnt	include/drv_types.h	/^	u32 dbg_suspend_error_cnt;$/;"	m	struct:debug_priv
-dbg_trigger_point	include/rtw_sreset.h	/^	s32 dbg_trigger_point;$/;"	m	struct:sreset_priv
-dbg_wow_leave_ps_fail_cnt	include/drv_types.h	/^	u32 dbg_wow_leave_ps_fail_cnt;$/;"	m	struct:debug_priv
-deauth	include/ieee80211_ext.h	/^		}  __attribute__((packed)) deauth;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon10
-deauth	include/ieee80211_ext.h	/^		}  deauth;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon28
-deauth_timeout_ms	include/rtw_cmd.h	/^	u32 deauth_timeout_ms;$/;"	m	struct:disconnect_parm
-debug_priv	include/drv_types.h	/^struct debug_priv {$/;"	s
-decide_wait_for_beacon_timeout	core/rtw_wlan_util.c	/^unsigned int decide_wait_for_beacon_timeout(unsigned int bcn_interval)$/;"	f
-decision_holding_period	hal/phydm/phydm_antdiv.h	/^	u1Byte	decision_holding_period;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-decryptor	core/rtw_recv.c	/^union recv_frame *decryptor(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-def_module_flags	include/rtw_rf.h	/^	u8 def_module_flags; \/* RTW_MODULE_RTLXXX *\/$/;"	m	struct:country_chplan
-default_path	hal/phydm/phydm_pathdiv.h	/^	u1Byte	default_path;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-default_patterns_en	include/drv_types.h	/^	bool	default_patterns_en;$/;"	m	struct:registry_priv
-default_supported_mcs_set	include/rtw_mlme_ext.h	/^	unsigned char default_supported_mcs_set[16];$/;"	m	struct:mlme_ext_priv
-defrag_q	include/rtw_recv.h	/^	_queue defrag_q;	 \/* keeping the fragment frame until defrag *\/$/;"	m	struct:sta_recv_priv
-deinit_priv	hal/hal_halmac.c	/^static void deinit_priv(struct halmacpriv *priv)$/;"	f	file:
-del_assocsta_parm	include/rtw_cmd.h	/^struct del_assocsta_parm {$/;"	s
-del_rx_ampdu_test_no_tx_fail	core/rtw_debug.c	/^static u8 del_rx_ampdu_test_no_tx_fail = 0;$/;"	v	file:
-delay_ms	hal/btc/Mp_Precomp.h	36;"	d
-delay_switch_back	include/rtw_mlme.h	/^	u8	delay_switch_back;$/;"	m	struct:tdls_ch_switch
-delay_timer	include/sta_info.h	/^	_timer	delay_timer;$/;"	m	struct:sta_info
-delba	include/ieee80211_ext.h	/^				}  __attribute__((packed)) delba;$/;"	m	union:ieee80211_mgmt::__anon8::__anon18::__anon19	typeref:struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon23
-delba	include/ieee80211_ext.h	/^				}  delba;$/;"	m	union:ieee80211_mgmt::__anon26::__anon33::__anon34	typeref:struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon38
-deliver_no_wcard	include/osdep_service_bsd.h	/^				deliver_no_wcard:1;$/;"	m	struct:sk_buff
-deliver_no_wcard	include/osdep_service_bsd.h	/^	u8			deliver_no_wcard:1;$/;"	m	struct:sk_buff
-dequeue_one_xmitframe	core/rtw_xmit.c	/^static struct xmit_frame *dequeue_one_xmitframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit, struct tx_servq *ptxservq, _queue *pframe_queue)$/;"	f	file:
-dequeue_pending_xmitbuf	core/rtw_xmit.c	/^struct xmit_buf *dequeue_pending_xmitbuf($/;"	f
-dequeue_pending_xmitbuf_ext	core/rtw_xmit.c	/^static struct xmit_buf *dequeue_pending_xmitbuf_ext($/;"	f	file:
-dequeue_pending_xmitbuf_under_survey	core/rtw_xmit.c	/^static struct xmit_buf *dequeue_pending_xmitbuf_under_survey($/;"	f	file:
-dequeue_xmitframes_to_sleeping_queue	core/rtw_xmit.c	/^static void dequeue_xmitframes_to_sleeping_queue(_adapter *padapter, struct sta_info *psta, _queue *pframequeue)$/;"	f	file:
-desc	include/rtw_mp.h	/^	u8 desc[TXDESC_SIZE];$/;"	m	struct:mp_tx
-desc	include/rtw_xmit.h	/^	struct tx_desc	*desc;$/;"	m	struct:rtw_tx_ring	typeref:struct:rtw_tx_ring::tx_desc
-desc	include/rtw_xmit.h	/^	struct tx_desc *desc;$/;"	m	struct:xmit_buf	typeref:struct:xmit_buf::tx_desc
-descriptor_urb	include/drv_types.h	/^	struct _URB_CONTROL_DESCRIPTOR_REQUEST descriptor_urb;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::_URB_CONTROL_DESCRIPTOR_REQUEST
-destructor	include/osdep_service_bsd.h	/^	void			(*destructor)(struct sk_buff *skb);$/;"	m	struct:sk_buff
-dev	include/osdep_service_bsd.h	/^	struct ifnet *dev;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::ifnet
-dev_addr	include/sta_info.h	/^	u8 dev_addr[ETH_ALEN];$/;"	m	struct:sta_info
-dev_alloc_skb	os_dep/osdep_service.c	/^struct sk_buff *dev_alloc_skb(unsigned int size)$/;"	f
-dev_cap	include/sta_info.h	/^	u8 dev_cap;$/;"	m	struct:sta_info
-dev_clr_drv_stopped	include/drv_types.h	/^static inline void dev_clr_drv_stopped(struct dvobj_priv *dvobj)$/;"	f
-dev_clr_surprise_removed	include/drv_types.h	/^static inline void dev_clr_surprise_removed(struct dvobj_priv *dvobj)$/;"	f
-dev_discovered	include/rtw_mlme.h	/^	u8					dev_discovered;		\/* WFD_TDLS: for sigma test *\/$/;"	m	struct:tdls_info
-dev_index	os_dep/linux/os_intfs.c	/^	unsigned int dev_index;$/;"	m	struct:route_info	file:
-dev_is_drv_stopped	include/drv_types.h	1108;"	d
-dev_is_surprise_removed	include/drv_types.h	1107;"	d
-dev_kfree_skb_any	os_dep/osdep_service.c	/^void dev_kfree_skb_any(struct sk_buff *skb)$/;"	f
-dev_name	include/sta_info.h	/^	u8 dev_name[32];$/;"	m	struct:sta_info
-dev_name_len	include/sta_info.h	/^	u16 dev_name_len;$/;"	m	struct:sta_info
-dev_network	include/drv_types.h	/^	WLAN_BSSID_EX    dev_network;$/;"	m	struct:registry_priv
-dev_set_drv_stopped	include/drv_types.h	/^static inline void dev_set_drv_stopped(struct dvobj_priv *dvobj)$/;"	f
-dev_set_surprise_removed	include/drv_types.h	/^static inline void dev_set_surprise_removed(struct dvobj_priv *dvobj)$/;"	f
-dev_to_sdio_func	os_dep/linux/sdio_intf.c	48;"	d	file:
-device_addr	include/rtw_mlme.h	/^	u8						device_addr[ETH_ALEN];	\/*	The device address should be the mac address of this device. *\/$/;"	m	struct:wifidirect_info
-device_name	include/rtw_mlme.h	/^	u8						device_name[WPS_MAX_DEVICE_NAME_LEN];	\/*	Device name for displaying on searching device screen *\/$/;"	m	struct:wifidirect_info
-device_name_len	include/rtw_mlme.h	/^	u8						device_name_len;$/;"	m	struct:wifidirect_info
-device_password_id_for_nego	include/rtw_mlme.h	/^	u16						device_password_id_for_nego;	\/*	The device password ID for group negotation *\/$/;"	m	struct:wifidirect_info
-devnumber	include/drv_types_pci.h	/^	u8	devnumber;$/;"	m	struct:pci_priv
-devobj_deinit	os_dep/linux/os_intfs.c	/^void devobj_deinit(struct dvobj_priv *pdvobj)$/;"	f
-devobj_init	os_dep/linux/os_intfs.c	/^struct dvobj_priv *devobj_init(void)$/;"	f
-dfs_ch_sel_d_flags	include/drv_types.h	/^	u8 dfs_ch_sel_d_flags;$/;"	m	struct:rf_ctl_t
-dfs_master_enabled	hal/phydm/phydm.h	/^	pu1Byte dfs_master_enabled;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-dfs_master_enabled	include/drv_types.h	/^	u8 dfs_master_enabled;$/;"	m	struct:rf_ctl_t
-dfs_master_timer	include/rtw_mlme.h	/^	_timer dfs_master_timer;$/;"	m	struct:mlme_priv
-dfs_region_domain	include/drv_types.h	/^	u8 dfs_region_domain;$/;"	m	struct:registry_priv
-dhcpMessage	core/rtw_br_ext.c	/^struct dhcpMessage {$/;"	s	file:
-dhcp_bcst_disable	include/rtw_br_ext.h	/^	unsigned int	dhcp_bcst_disable;$/;"	m	struct:br_ext_info
-dhcp_flag_bcast	core/rtw_br_ext.c	/^void dhcp_flag_bcast(_adapter *priv, struct sk_buff *skb)$/;"	f
-dhcp_pkt	include/rtw_xmit.h	/^	u8	dhcp_pkt;$/;"	m	struct:pkt_attrib
-dialogToken	include/rtw_mlme_ext.h	/^	u8	dialogToken;$/;"	m	struct:mlme_ext_info
-dialog_token	include/ieee80211_ext.h	/^					u8 dialog_token;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon35
-dialog_token	include/ieee80211_ext.h	/^					u8 dialog_token;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon36
-dialog_token	include/ieee80211_ext.h	/^					u8 dialog_token;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon37
-dialog_token	include/ieee80211_ext.h	/^					u8 dialog_token;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon20
-dialog_token	include/ieee80211_ext.h	/^					u8 dialog_token;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon21
-dialog_token	include/ieee80211_ext.h	/^					u8 dialog_token;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon22
-dialog_token	include/rtw_mlme.h	/^	u8 dialog_token;$/;"	m	struct:tdls_txmgmt
-dialog_token	include/wifi.h	/^	unsigned char		dialog_token;$/;"	m	struct:ADDBA_request
-dir_dev	include/drv_types.h	/^	struct proc_dir_entry *dir_dev;\/* for proc directory *\/$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::proc_dir_entry
-dir_mcc	include/drv_types.h	/^	struct proc_dir_entry *dir_mcc;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::proc_dir_entry
-dir_odm	include/drv_types.h	/^	struct proc_dir_entry *dir_odm;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::proc_dir_entry
-direct_link	include/rtw_xmit.h	/^	u8 direct_link;$/;"	m	struct:pkt_attrib
-dis_ver_info_cnt	hal/btc/HalBtc8723b2Ant.h	/^	u8					dis_ver_info_cnt;$/;"	m	struct:coex_sta_8723b_2ant
-dis_ver_info_cnt	hal/btc/HalBtc8821a2Ant.h	/^	u8					dis_ver_info_cnt;$/;"	m	struct:coex_sta_8821a_2ant
-dis_ver_info_cnt	hal/btc/halbtc8723d2ant.h	/^	u8					dis_ver_info_cnt;$/;"	m	struct:coex_sta_8723d_2ant
-dis_ver_info_cnt	hal/btc/halbtc8821c2ant.h	/^	u8					dis_ver_info_cnt;$/;"	m	struct:coex_sta_8821c_2ant
-disable_dm	core/rtw_mp.c	/^static void disable_dm(PADAPTER padapter)$/;"	f	file:
-disable_func	include/drv_types.h	/^	ATOMIC_T disable_func;$/;"	m	struct:dvobj_priv
-disable_interrupt	include/hal_intf.h	/^	void	(*disable_interrupt)(_adapter *padapter);$/;"	m	struct:hal_ops
-disassoc	include/ieee80211_ext.h	/^		}  __attribute__((packed)) disassoc;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon14
-disassoc	include/ieee80211_ext.h	/^		}  disassoc;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon32
-disconnect_hdl	core/rtw_mlme_ext.c	/^u8 disconnect_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-disconnect_parm	include/rtw_cmd.h	/^struct disconnect_parm {$/;"	s
-discovery	include/rtw_cmd.h	/^	u8 discovery:1;$/;"	m	struct:P2P_PS_Offload_t
-disdatafb	include/rtl8188e_xmit.h	/^	u32 disdatafb:1;$/;"	m	struct:txdesc_88e
-disdatafb	include/rtl8192e_xmit.h	/^	u32 disdatafb:1;$/;"	m	struct:txdescriptor_8192e
-disdatafb	include/rtl8812a_xmit.h	/^	u32 disdatafb:1;$/;"	m	struct:txdescriptor_8812
-disdatafb	include/rtl8821a_xmit.h	/^	u32 disdatafb:1;$/;"	m	struct:txdescriptor_8821a
-disrtsfb	include/rtl8188e_xmit.h	/^	u32 disrtsfb:1;$/;"	m	struct:txdesc_88e
-disrtsfb	include/rtl8192e_xmit.h	/^	u32 disrtsfb:1;$/;"	m	struct:txdescriptor_8192e
-disrtsfb	include/rtl8812a_xmit.h	/^	u32 disrtsfb:1;$/;"	m	struct:txdescriptor_8812
-disrtsfb	include/rtl8821a_xmit.h	/^	u32 disrtsfb:1;$/;"	m	struct:txdescriptor_8821a
-dm_CheckPbcGPIO	hal/rtl8723d/rtl8723d_dm.c	/^static void dm_CheckPbcGPIO(_adapter *padapter)$/;"	f	file:
-dm_CheckProtection	hal/rtl8723d/rtl8723d_dm.c	/^dm_CheckProtection($/;"	f	file:
-dm_CheckStatistics	hal/rtl8723d/rtl8723d_dm.c	/^dm_CheckStatistics($/;"	f	file:
-dm_CheckTXPowerTracking	hal/phydm/phydm_powertracking_ap.h	114;"	d
-dm_CheckTXPowerTracking	hal/phydm/phydm_powertracking_ce.h	70;"	d
-dm_CheckTXPowerTracking	hal/phydm/phydm_powertracking_win.h	38;"	d
-dm_DynamicUsbTxAgg	hal/hal_com.c	/^void dm_DynamicUsbTxAgg(_adapter *padapter, u8 from_timer)$/;"	f
-dm_InitGPIOSetting	hal/rtl8723d/rtl8723d_dm.c	/^dm_InitGPIOSetting($/;"	f	file:
-dm_InterruptMigration	hal/rtl8723d/rtl8723d_dm.c	/^dm_InterruptMigration($/;"	f
-dm_PathDiv_RSSI_Check	hal/phydm/phydm_pathdiv.h	167;"	d
-dm_RF_Saving	hal/phydm/phydm_dynamicbbpowersaving.h	43;"	d
-dm_RF_Saving	hal/phydm/phydm_dynamicbbpowersaving.h	55;"	d
-dm_deinit	include/hal_intf.h	/^	void	(*dm_deinit)(_adapter *padapter);$/;"	m	struct:hal_ops
-dm_dig_max_TH	hal/phydm/phydm.h	/^	u1Byte			dm_dig_max_TH;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-dm_dig_min_TH	hal/phydm/phydm.h	/^	u1Byte 			dm_dig_min_TH;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-dm_init	include/hal_intf.h	/^	void	(*dm_init)(_adapter *padapter);$/;"	m	struct:hal_ops
-dm_sat_table	hal/phydm/phydm.h	/^	SAT_T						dm_sat_table;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-dma	include/rtw_recv.h	/^	dma_addr_t		dma;$/;"	m	struct:rtw_rx_ring
-dma	include/rtw_xmit.h	/^	dma_addr_t	dma;$/;"	m	struct:rtw_tx_ring
-dma_addr_t	include/basic_types.h	/^	typedef u32 dma_addr_t;$/;"	t
-dma_cookie	include/osdep_service_bsd.h	/^	dma_cookie_t		dma_cookie;$/;"	m	struct:sk_buff
-dma_transfer_addr	include/rtw_recv.h	/^	dma_addr_t dma_transfer_addr;	\/* (in) dma addr for transfer_buffer *\/$/;"	m	struct:recv_buf
-dma_transfer_addr	include/rtw_xmit.h	/^	dma_addr_t dma_transfer_addr;	\/* (in) dma addr for transfer_buffer *\/$/;"	m	struct:xmit_buf
-do_div	os_dep/osdep_service.c	2412;"	d	file:
-do_late_resume	include/rtw_pwrctrl.h	/^	u8 do_late_resume;$/;"	m	struct:pwrctrl_priv
-do_queue_select	core/rtw_xmit.c	/^static void do_queue_select(_adapter	*padapter, struct pkt_attrib *pattrib)$/;"	f	file:
-done	include/rtw_xmit.h	/^	struct completion done;$/;"	m	struct:submit_ctx	typeref:struct:submit_ctx::completion
-dot118021XGrpKey	include/rtw_security.h	/^	union Keytype	dot118021XGrpKey[4];	\/* 802.1x Group Key, for inx0 and inx1	 *\/$/;"	m	struct:security_priv	typeref:union:security_priv::Keytype
-dot118021XGrpKeyid	include/rtw_security.h	/^	u32	dot118021XGrpKeyid;		\/* key id used for Grp Key ( tx key index) *\/$/;"	m	struct:security_priv
-dot118021XGrpPrivacy	include/rtw_security.h	/^	u32 dot118021XGrpPrivacy;	\/* This specify the privacy algthm. used for Grp key *\/$/;"	m	struct:security_priv
-dot118021XGrprxmickey	include/rtw_security.h	/^	union Keytype	dot118021XGrprxmickey[4];$/;"	m	struct:security_priv	typeref:union:security_priv::Keytype
-dot118021XGrptxmickey	include/rtw_security.h	/^	union Keytype	dot118021XGrptxmickey[4];$/;"	m	struct:security_priv	typeref:union:security_priv::Keytype
-dot118021XPrivacy	include/sta_info.h	/^	uint	dot118021XPrivacy; \/* aes, tkip... *\/$/;"	m	struct:sta_info
-dot118021x_UncstKey	include/rtw_xmit.h	/^	union Keytype	dot118021x_UncstKey;$/;"	m	struct:pkt_attrib	typeref:union:pkt_attrib::Keytype
-dot118021x_UncstKey	include/sta_info.h	/^	union Keytype	dot118021x_UncstKey;$/;"	m	struct:sta_info	typeref:union:sta_info::Keytype
-dot118021x_bmc_cam_id	include/rtw_security.h	/^	u8	dot118021x_bmc_cam_id;$/;"	m	struct:security_priv
-dot11AuthAlgrthm	include/rtw_security.h	/^	u32	  dot11AuthAlgrthm;		\/* 802.11 auth, could be open, shared, 8021x and authswitch *\/$/;"	m	struct:security_priv
-dot11AuthAlgrthmNum	include/rtw_mlme.h	/^enum dot11AuthAlgrthmNum {$/;"	g
-dot11AuthAlgrthm_8021X	include/rtw_mlme.h	/^	dot11AuthAlgrthm_8021X,$/;"	e	enum:dot11AuthAlgrthmNum
-dot11AuthAlgrthm_Auto	include/rtw_mlme.h	/^	dot11AuthAlgrthm_Auto,$/;"	e	enum:dot11AuthAlgrthmNum
-dot11AuthAlgrthm_MaxNum	include/rtw_mlme.h	/^	dot11AuthAlgrthm_MaxNum$/;"	e	enum:dot11AuthAlgrthmNum
-dot11AuthAlgrthm_Open	include/rtw_mlme.h	/^	dot11AuthAlgrthm_Open = 0,$/;"	e	enum:dot11AuthAlgrthmNum
-dot11AuthAlgrthm_Shared	include/rtw_mlme.h	/^	dot11AuthAlgrthm_Shared,$/;"	e	enum:dot11AuthAlgrthmNum
-dot11AuthAlgrthm_WAPI	include/rtw_mlme.h	/^	dot11AuthAlgrthm_WAPI,$/;"	e	enum:dot11AuthAlgrthmNum
-dot11DefKey	include/rtw_security.h	/^	union Keytype dot11DefKey[4];			\/* this is only valid for def. key	 *\/$/;"	m	struct:security_priv	typeref:union:security_priv::Keytype
-dot11DefKeylen	include/rtw_security.h	/^	u32	dot11DefKeylen[4];$/;"	m	struct:security_priv
-dot11Def_camid	include/rtw_security.h	/^	u8	dot11Def_camid[4];$/;"	m	struct:security_priv
-dot11Grprxpn	include/rtw_security.h	/^	union pn48		dot11Grprxpn;			\/* PN48 used for Grp Key recv. *\/$/;"	m	struct:security_priv	typeref:union:security_priv::pn48
-dot11Grptxpn	include/rtw_security.h	/^	union pn48		dot11Grptxpn;			\/* PN48 used for Grp Key xmit. *\/$/;"	m	struct:security_priv	typeref:union:security_priv::pn48
-dot11PrivacyAlgrthm	include/rtw_security.h	/^	u32	  dot11PrivacyAlgrthm;	\/* This specify the privacy for shared auth. algorithm. *\/$/;"	m	struct:security_priv
-dot11PrivacyKeyIndex	include/rtw_security.h	/^	u32	  dot11PrivacyKeyIndex;	\/* this is only valid for legendary wep, 0~3 for key id. (tx key index) *\/$/;"	m	struct:security_priv
-dot11rxpn	include/sta_info.h	/^	union pn48		dot11rxpn;			\/* PN48 used for Unicast recv. *\/$/;"	m	struct:sta_info	typeref:union:sta_info::pn48
-dot11tkiprxmickey	include/sta_info.h	/^	union Keytype	dot11tkiprxmickey;$/;"	m	struct:sta_info	typeref:union:sta_info::Keytype
-dot11tkiptxmickey	include/rtw_xmit.h	/^	union Keytype	dot11tkiptxmickey;$/;"	m	struct:pkt_attrib	typeref:union:pkt_attrib::Keytype
-dot11tkiptxmickey	include/sta_info.h	/^	union Keytype	dot11tkiptxmickey;$/;"	m	struct:sta_info	typeref:union:sta_info::Keytype
-dot11txpn	include/sta_info.h	/^	union pn48		dot11txpn;			\/* PN48 used for Unicast xmit *\/$/;"	m	struct:sta_info	typeref:union:sta_info::pn48
-dot11wBIPKey	include/rtw_security.h	/^	union Keytype	dot11wBIPKey[6];		\/* BIP Key, for index4 and index5 *\/$/;"	m	struct:security_priv	typeref:union:security_priv::Keytype
-dot11wBIPKeyid	include/rtw_security.h	/^	u32	dot11wBIPKeyid;						\/* key id used for BIP Key ( tx key index) *\/$/;"	m	struct:security_priv
-dot11wBIPrxpn	include/rtw_security.h	/^	union pn48		dot11wBIPrxpn;			\/* PN48 used for Grp Key recv. *\/$/;"	m	struct:security_priv	typeref:union:security_priv::pn48
-dot11wBIPtxpn	include/rtw_security.h	/^	union pn48		dot11wBIPtxpn;			\/* PN48 used for Grp Key xmit. *\/$/;"	m	struct:security_priv	typeref:union:security_priv::pn48
-dot11w_expire_timer	include/sta_info.h	/^	_timer dot11w_expire_timer;$/;"	m	struct:sta_info
-dot11wtxpn	include/sta_info.h	/^	union pn48		dot11wtxpn;			\/* PN48 used for Unicast mgmt xmit. *\/$/;"	m	struct:sta_info	typeref:union:sta_info::pn48
-dot8021xalg	include/rtw_security.h	/^	unsigned int dot8021xalg;\/* 0:disable, 1:psk, 2:802.1x *\/$/;"	m	struct:security_priv
-dot8021xalg	include/sta_info.h	/^	int dot8021xalg;\/* 0:disable, 1:psk, 2:802.1x *\/$/;"	m	struct:sta_info
-down_clk	core/rtw_eeprom.c	/^void down_clk(_adapter	*padapter, u16 *x)$/;"	f
-down_scanned_network	include/rtw_mlme.h	/^__inline static void down_scanned_network(struct mlme_priv *pmlmepriv)$/;"	f
-dpdt_ctrl_keep	hal/phydm/phydm_hwconfig.h	/^	u1Byte			dpdt_ctrl_keep: 1;						\/*8812A: 1'b0		8814A: dpdt_ctrl_keep*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-dpdt_ctrl_keep	hal/phydm/phydm_hwconfig.h	/^	u1Byte			dpdt_ctrl_keep: 1;$/;"	m	struct:_Phy_Status_Rpt_8812
-driver_ampdu_spacing	include/drv_types.h	/^	u8 driver_ampdu_spacing;\/* driver control AMPDU Density for peer sta's rx *\/$/;"	m	struct:_ADAPTER
-driver_interface	include/rtw_mlme.h	/^	u8						driver_interface;			\/*	Indicate DRIVER_WEXT or DRIVER_CFG80211 *\/$/;"	m	struct:wifidirect_info
-driver_rx_ampdu_factor	include/drv_types.h	/^	u8 driver_rx_ampdu_factor;\/* 0xff: disable drv ctrl, 0:8k, 1:16k, 2:32k, 3:64k; *\/$/;"	m	struct:_ADAPTER
-driver_rx_ampdu_spacing	include/drv_types.h	/^	u8 driver_rx_ampdu_spacing;  \/* driver control Rx AMPDU Density *\/$/;"	m	struct:_ADAPTER
-driver_setup	include/rtw_mlme.h	/^	u8					driver_setup;$/;"	m	struct:tdls_info
-driver_tx_bw_mode	include/drv_types.h	/^	u8 driver_tx_bw_mode;$/;"	m	struct:_ADAPTER
-driver_vcs_en	include/drv_types.h	/^	u8 driver_vcs_en; \/* Enable=1, Disable=0 driver control vrtl_carrier_sense for tx *\/$/;"	m	struct:_ADAPTER
-driver_vcs_type	include/drv_types.h	/^	u8 driver_vcs_type;\/* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. *\/$/;"	m	struct:_ADAPTER
-dropcount	include/osdep_service_bsd.h	/^		u32		dropcount;$/;"	m	union:sk_buff::__anon49
-drv_ant_band_switch	include/drv_types.h	/^	u8	drv_ant_band_switch;$/;"	m	struct:registry_priv
-drv_dbg	include/drv_types.h	/^	struct debug_priv drv_dbg;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::debug_priv
-drv_proc_hdls	os_dep/linux/rtw_proc.c	/^const struct rtw_proc_hdl drv_proc_hdls[] = {$/;"	v	typeref:struct:rtw_proc_hdl
-drv_proc_hdls_num	os_dep/linux/rtw_proc.c	/^const int drv_proc_hdls_num = sizeof(drv_proc_hdls) \/ sizeof(struct rtw_proc_hdl);$/;"	v
-drv_registered	os_dep/linux/sdio_intf.c	/^	int drv_registered;$/;"	m	struct:sdio_drv_priv	file:
-drv_rx_cnt_crcerror	include/drv_types.h	/^	u32 drv_rx_cnt_crcerror;$/;"	m	struct:_ADAPTER
-drv_rx_cnt_drop	include/drv_types.h	/^	u32 drv_rx_cnt_drop;$/;"	m	struct:_ADAPTER
-drv_rx_cnt_ok	include/drv_types.h	/^	u32 drv_rx_cnt_ok;$/;"	m	struct:_ADAPTER
-drvextpriv	include/drv_types.h	/^	struct	drvext_priv	drvextpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::drvext_priv
-drvextra_cmd_parm	include/rtw_cmd.h	/^struct drvextra_cmd_parm {$/;"	s
-drvinfo_sz	include/rtw_recv.h	/^	u8	drvinfo_sz;$/;"	m	struct:rx_pkt_attrib
-drvinfosize	include/rtl8188e_recv.h	/^	u32 drvinfosize:4;$/;"	m	struct:rxreport_8188e
-ds_params	include/ieee80211.h	/^	u8 *ds_params;$/;"	m	struct:rtw_ieee802_11_elems
-ds_params_len	include/ieee80211.h	/^	u8 ds_params_len;$/;"	m	struct:rtw_ieee802_11_elems
-dsap	include/ieee80211.h	/^	u8    dsap;   \/* always 0xAA *\/$/;"	m	struct:ieee80211_snap_hdr
-dst	include/rtw_recv.h	/^	u8	dst[ETH_ALEN];$/;"	m	struct:rx_pkt_attrib
-dst	include/rtw_xmit.h	/^	u8	dst[ETH_ALEN];$/;"	m	struct:pkt_attrib
-dst_addr	include/ieee80211.h	/^	u8 dst_addr[ETH_ALEN];$/;"	m	struct:ieee80211_frag_entry
-dst_addr	os_dep/linux/os_intfs.c	/^	struct in_addr dst_addr;$/;"	m	struct:route_info	typeref:struct:route_info::in_addr	file:
-dtim	include/rtw_pwrctrl.h	/^	u8	dtim;$/;"	m	struct:pwrctrl_priv
-dtp_check_patha_counter	hal/phydm/phydm_pathdiv.h	/^	u1Byte	dtp_check_patha_counter;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-dtp_period	hal/phydm/phydm_pathdiv.h	/^	u1Byte	dtp_period;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-dtp_state	hal/phydm/phydm_pathdiv.h	/^	u1Byte     dtp_state;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-dtp_state	hal/phydm/phydm_pathdiv.h	/^typedef enum dtp_state$/;"	g
-dummy	os_dep/linux/ioctl_linux.c	/^static int dummy(struct net_device *dev, struct iw_request_info *a,$/;"	f	file:
-dump_TX_FIFO	hal/hal_com.c	/^void dump_TX_FIFO(_adapter *padapter, u8 page_num, u16 page_size)$/;"	f
-dump_adapters_status	core/rtw_debug.c	/^void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)$/;"	f
-dump_bcn_qinfo_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^void dump_bcn_qinfo_8723d(void *sel, struct bcn_qinfo_8723d *info, const char *tag)$/;"	f
-dump_buf	core/efuse/rtw_efuse.c	/^static inline void dump_buf(u8 *buf, u32 len)$/;"	f	file:
-dump_buf	core/rtw_mp.c	/^static inline void dump_buf(u8 *buf, u32 len)$/;"	f	file:
-dump_buf	include/rtw_wapi.h	/^static inline void dump_buf(u8 *buf, u32 len)$/;"	f
-dump_chip_info	hal/hal_com.c	/^void dump_chip_info(HAL_VERSION	ChipVersion)$/;"	f
-dump_chplan_id_list	core/rtw_mlme_ext.c	/^void dump_chplan_id_list(void *sel)$/;"	f
-dump_chplan_test	core/rtw_mlme_ext.c	/^void dump_chplan_test(void *sel)$/;"	f
-dump_chset	core/rtw_mlme_ext.c	/^void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set)$/;"	f
-dump_cmd_id	os_dep/linux/ioctl_linux.c	/^u8 dump_cmd_id = 0;$/;"	v
-dump_country_chplan	core/rtw_mlme_ext.c	/^void dump_country_chplan(void *sel, const struct country_chplan *ent)$/;"	f
-dump_country_chplan_map	core/rtw_mlme_ext.c	/^void dump_country_chplan_map(void *sel)$/;"	f
-dump_cur_chset	core/rtw_mlme_ext.c	/^void dump_cur_chset(void *sel, _adapter *adapter)$/;"	f
-dump_drv_cfg	core/rtw_debug.c	/^void dump_drv_cfg(void *sel)$/;"	f
-dump_drv_version	core/rtw_debug.c	/^void dump_drv_version(void *sel)$/;"	f
-dump_dvobj_mi_status	core/rtw_mi.c	/^void dump_dvobj_mi_status(void *sel, const char *fun_name, _adapter *adapter)$/;"	f
-dump_hal_spec	hal/hal_com.c	/^void dump_hal_spec(void *sel, _adapter *adapter)$/;"	f
-dump_hal_txpwr_info_2g	hal/hal_com_phycfg.c	/^void dump_hal_txpwr_info_2g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt)$/;"	f
-dump_hal_txpwr_info_5g	hal/hal_com_phycfg.c	/^void dump_hal_txpwr_info_5g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt)$/;"	f
-dump_ht_cap_ie	core/rtw_ieee80211.c	/^void dump_ht_cap_ie(void *sel, u8 *ie, u32 ie_len)$/;"	f
-dump_ht_cap_ie_content	core/rtw_ieee80211.c	/^void dump_ht_cap_ie_content(void *sel, u8 *buf, u32 buf_len)$/;"	f
-dump_ies	core/rtw_ieee80211.c	/^void dump_ies(void *sel, u8 *buf, u32 buf_len)$/;"	f
-dump_log_level	core/rtw_debug.c	/^void dump_log_level(void *sel)$/;"	f
-dump_mac_page0	hal/hal_hci/hal_sdio.c	/^static void dump_mac_page0(PADAPTER padapter)$/;"	f	file:
-dump_mac_qinfo_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^void dump_mac_qinfo_8723d(void *sel, _adapter *adapter)$/;"	f
-dump_macaddr_acl	core/rtw_sta_mgt.c	/^void dump_macaddr_acl(void *sel, _adapter *adapter)$/;"	f
-dump_macid_map	core/rtw_wlan_util.c	/^void dump_macid_map(void *sel, struct macid_bmp *map, u8 max_num)$/;"	f
-dump_mgntframe	core/rtw_mlme_ext.c	/^void dump_mgntframe(_adapter *padapter, struct xmit_frame *pmgntframe)$/;"	f
-dump_mgntframe_and_wait	core/rtw_mlme_ext.c	/^s32 dump_mgntframe_and_wait(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms)$/;"	f
-dump_mgntframe_and_wait_ack	core/rtw_mlme_ext.c	/^s32 dump_mgntframe_and_wait_ack(_adapter *padapter, struct xmit_frame *pmgntframe)$/;"	f
-dump_mgntframe_and_wait_ack_timeout	core/rtw_mlme_ext.c	/^s32 dump_mgntframe_and_wait_ack_timeout(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms)$/;"	f
-dump_mi_status	core/rtw_mi.c	/^void dump_mi_status(void *sel, struct dvobj_priv *dvobj)$/;"	f
-dump_mpframe	core/rtw_mp.c	/^static void dump_mpframe(PADAPTER padapter, struct xmit_frame *pmpframe)$/;"	f	file:
-dump_os_queue	os_dep/linux/xmit_linux.c	/^void dump_os_queue(void *sel, _adapter *padapter)$/;"	f
-dump_p2p_attr_ch_list	core/rtw_p2p.c	/^u8 *dump_p2p_attr_ch_list(u8 *p2p_ie, uint p2p_ielen, u8 *buf, u32 buf_len)$/;"	f
-dump_p2p_ie	core/rtw_ieee80211.c	/^void dump_p2p_ie(void *sel, u8 *ie, u32 ie_len)$/;"	f
-dump_pg_txpwr_info_2g	hal/hal_com_phycfg.c	/^void dump_pg_txpwr_info_2g(void *sel, TxPowerInfo24G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)$/;"	f
-dump_pg_txpwr_info_5g	hal/hal_com_phycfg.c	/^void dump_pg_txpwr_info_5g(void *sel, TxPowerInfo5G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)$/;"	f
-dump_qinfo_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^void dump_qinfo_8723d(void *sel, struct qinfo_8723d *info, const char *tag)$/;"	f
-dump_rx_cnt_mode	include/drv_types.h	/^	u8 dump_rx_cnt_mode;\/*BIT0:drv,BIT1:mac,BIT2:phy*\/$/;"	m	struct:_ADAPTER
-dump_rx_packet	core/rtw_recv.c	/^static inline void dump_rx_packet(u8 *ptr)$/;"	f	file:
-dump_sdio_f0	hal/hal_hci/hal_sdio.c	/^static void dump_sdio_f0(PADAPTER padapter)$/;"	f	file:
-dump_sdio_local	hal/hal_hci/hal_sdio.c	/^static void dump_sdio_local(PADAPTER padapter)$/;"	f	file:
-dump_sec_cam	core/rtw_debug.c	/^void dump_sec_cam(void *sel, _adapter *adapter)$/;"	f
-dump_sec_cam_cache	core/rtw_debug.c	/^void dump_sec_cam_cache(void *sel, _adapter *adapter)$/;"	f
-dump_sec_cam_ent	core/rtw_debug.c	/^void dump_sec_cam_ent(void *sel, struct sec_cam_ent *ent, int id)$/;"	f
-dump_sec_cam_ent_title	core/rtw_debug.c	/^void dump_sec_cam_ent_title(void *sel, u8 has_id)$/;"	f
-dump_sec_cam_map	core/rtw_wlan_util.c	/^void dump_sec_cam_map(void *sel, struct sec_cam_bmp *map, u8 max_num)$/;"	f
-dump_st_ctl	core/rtw_sta_mgt.c	/^void dump_st_ctl(void *sel, struct st_ctl_t *st_ctl)$/;"	f
-dump_stack	include/rtw_mlme.h	/^	u8	dump_stack;$/;"	m	struct:tdls_ch_switch
-dump_target_tx_power	hal/hal_com_phycfg.c	/^void dump_target_tx_power(void *sel, _adapter *adapter)$/;"	f
-dump_trx_share_mode	hal/hal_halmac.c	/^void dump_trx_share_mode(void *sel, _adapter *adapter)$/;"	f
-dump_tx_power_by_rate	hal/hal_com_phycfg.c	/^void dump_tx_power_by_rate(void *sel, _adapter *adapter)$/;"	f
-dump_tx_power_ext_info	hal/hal_com_phycfg.c	/^void dump_tx_power_ext_info(void *sel, _adapter *adapter)$/;"	f
-dump_tx_power_idx	hal/hal_com_phycfg.c	/^void dump_tx_power_idx(void *sel, _adapter *adapter)$/;"	f
-dump_tx_power_idx_by_path_rs	hal/hal_com_phycfg.c	/^void dump_tx_power_idx_by_path_rs(void *sel, _adapter *adapter, u8 rfpath, u8 rs)$/;"	f
-dump_tx_power_idx_title	hal/hal_com_phycfg.c	/^void dump_tx_power_idx_title(void *sel, _adapter *adapter)$/;"	f
-dump_tx_power_limit	hal/hal_com_phycfg.c	/^void dump_tx_power_limit(void *sel, _adapter *adapter)$/;"	f
-dump_tx_rate_bmp	core/rtw_debug.c	/^void dump_tx_rate_bmp(void *sel, struct dvobj_priv *dvobj)$/;"	f
-dump_txrpt_ccx_88e	include/rtl8188e_xmit.h	295;"	d
-dump_wfd_ie	core/rtw_ieee80211.c	/^void dump_wfd_ie(void *sel, u8 *ie, u32 ie_len)$/;"	f
-dump_wps_ie	core/rtw_ieee80211.c	/^void dump_wps_ie(void *sel, u8 *ie, u32 ie_len)$/;"	f
-duration	include/ieee80211_ext.h	/^	u16 duration;$/;"	m	struct:ieee80211_mgmt
-duration	include/rtw_cmd.h	/^	unsigned int duration;$/;"	m	struct:p2p_roch_parm
-duration	include/rtw_mcc.h	/^	u8 duration; \/* channel stay period, UNIT:1TU *\/$/;"	m	struct:mcc_obj_priv
-duration	include/wifi.h	/^	unsigned short duration;$/;"	m	struct:rtw_ieee80211_bar
-duration_id	include/ieee80211.h	/^	u16 duration_id;$/;"	m	struct:ieee80211_header_data
-duration_id	include/ieee80211.h	/^	u16 duration_id;$/;"	m	struct:rtw_ieee80211_hdr
-duration_id	include/ieee80211.h	/^	u16 duration_id;$/;"	m	struct:rtw_ieee80211_hdr_3addr
-duration_id	include/ieee80211.h	/^	u16 duration_id;$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos
-duration_id	include/ieee80211.h	/^	u16 duration_id;$/;"	m	struct:rtw_ieee80211_hdr_qos
-dvobj	include/drv_types.h	/^	struct dvobj_priv *dvobj;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::dvobj_priv
-dvobj	os_dep/linux/ioctl_cfg80211.h	/^	struct dvobj_priv *dvobj;$/;"	m	struct:rtw_wiphy_data	typeref:struct:rtw_wiphy_data::dvobj_priv
-dvobj_deinit	include/drv_types.h	/^	void (*dvobj_deinit)(struct dvobj_priv *dvobj);$/;"	m	struct:_ADAPTER
-dvobj_get_adapter_by_addr	core/rtw_wlan_util.c	/^_adapter *dvobj_get_adapter_by_addr(struct dvobj_priv *dvobj, u8 *addr)$/;"	f
-dvobj_get_port0_adapter	core/rtw_wlan_util.c	/^_adapter *dvobj_get_port0_adapter(struct dvobj_priv *dvobj)$/;"	f
-dvobj_get_primary_adapter	include/drv_types.h	1135;"	d
-dvobj_get_unregisterd_adapter	core/rtw_wlan_util.c	/^_adapter *dvobj_get_unregisterd_adapter(struct dvobj_priv *dvobj)$/;"	f
-dvobj_init	include/drv_types.h	/^	NDIS_STATUS(*dvobj_init)(struct dvobj_priv *dvobj);$/;"	m	struct:_ADAPTER
-dvobj_priv	include/drv_types.h	/^struct dvobj_priv {$/;"	s
-dvobj_set_halmac	hal/hal_halmac.h	30;"	d
-dvobj_to_dev	include/drv_types.h	/^static struct device *dvobj_to_dev(struct dvobj_priv *dvobj)$/;"	f
-dvobj_to_halmac	hal/hal_halmac.h	31;"	d
-dvobj_to_macidctl	include/drv_types.h	1082;"	d
-dvobj_to_pwrctl	include/drv_types.h	1080;"	d
-dvobj_to_regsty	include/drv_types.h	1084;"	d
-dvobj_to_rfctl	include/drv_types.h	1088;"	d
-dvobj_to_sdio_func	include/drv_types_sdio.h	77;"	d
-dvobj_to_sec_camctl	include/drv_types.h	1083;"	d
-dvobj_to_wiphy	include/drv_types.h	1086;"	d
-dword	include/rtw_recv.h	/^	unsigned int dword[4];$/;"	m	struct:rx_buf_desc
-dword	include/rtw_xmit.h	/^	unsigned int dword[TX_BUFFER_SEG_SIZE * (2 << TX_BUFFER_SEG_NUM)];$/;"	m	struct:tx_buf_desc
-dynamic_chk_timer	include/drv_types.h	/^	_timer dynamic_chk_timer; \/* dynamic\/periodic check timer *\/$/;"	m	struct:dvobj_priv
-dynamic_update_bcn_check	core/rtw_cmd.c	/^static void dynamic_update_bcn_check(_adapter *padapter)$/;"	f	file:
-eCWmax	include/ieee80211_ext.h	/^	     eCWmax:4;$/;"	m	struct:wme_ac_parameter
-eCWmin	include/ieee80211_ext.h	/^	u8	eCWmin:4,$/;"	m	struct:wme_ac_parameter
-eFWSource	include/rtl8188e_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE_8188E
-eFWSource	include/rtl8188f_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE
-eFWSource	include/rtl8192e_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE_8192E
-eFWSource	include/rtl8703b_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE
-eFWSource	include/rtl8723b_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE
-eFWSource	include/rtl8723d_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE
-eFWSource	include/rtl8812a_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE_8812
-eFWSource	include/rtl8814a_hal.h	/^	FIRMWARE_SOURCE	eFWSource;$/;"	m	struct:_RT_FIRMWARE_8814
-eFWSource	include/rtw_mp.h	/^	FIRMWARE_SOURCE eFWSource;$/;"	m	struct:_MP_FIRMWARE
-eSCO_SCO	core/rtw_cmd.c	/^	u8 eSCO_SCO:1;$/;"	m	struct:btinfo	file:
-eSCO_SCO	include/rtw_btcoex.h	/^	u8 eSCO_SCO:1;$/;"	m	struct:btinfo_8761ATV
-e_id	include/rtw_cmd.h	/^	unsigned char e_id;$/;"	m	struct:setassocreqextraie_parm
-e_id	include/rtw_cmd.h	/^	unsigned char e_id;$/;"	m	struct:setassocrspextraie_parm
-e_id	include/rtw_cmd.h	/^	unsigned char e_id;$/;"	m	struct:setprobereqextraie_parm
-e_id	include/rtw_cmd.h	/^	unsigned char e_id;$/;"	m	struct:setproberspextraie_parm
-eap_type	include/ieee80211.h	/^enum eap_type {$/;"	g
-eapol	include/ieee80211.h	/^struct eapol {$/;"	s
-early_mode	include/drv_types.h	/^	u8   early_mode;$/;"	m	struct:registry_priv
-early_rate	include/rtl8821a_xmit.h	/^	u32 early_rate:1;$/;"	m	struct:txdescriptor_8821a
-early_suspend	include/rtw_pwrctrl.h	/^	android_early_suspend_t early_suspend;$/;"	m	struct:pwrctrl_priv
-early_suspend	include/rtw_pwrctrl.h	/^	struct early_suspend early_suspend;$/;"	m	struct:pwrctrl_priv	typeref:struct:pwrctrl_priv::early_suspend
-ebias	include/hal_com_phycfg.h	/^	s8 ebias;$/;"	m	struct:txpwr_idx_comp
-ec_id	include/rtw_cmd.h	/^	int ec_id; \/* extra cmd id *\/$/;"	m	struct:drvextra_cmd_parm
-echo_CLM_en	hal/phydm/phydm_ccx.h	/^	BOOLEAN		echo_CLM_en;$/;"	m	struct:_CCX_INFO
-echo_IGI	hal/phydm/phydm_ccx.h	/^	u1Byte		echo_IGI;$/;"	m	struct:_CCX_INFO
-echo_NHM_en	hal/phydm/phydm_ccx.h	/^	BOOLEAN		echo_NHM_en;$/;"	m	struct:_CCX_INFO
-edca_setting_DL	hal/phydm/phydm_edcaturbocheck.h	/^static u4Byte edca_setting_DL[HT_IOT_PEER_MAX] = $/;"	v
-edca_setting_DL_GMode	hal/phydm/phydm_edcaturbocheck.h	/^static u4Byte edca_setting_DL_GMode[HT_IOT_PEER_MAX] = $/;"	v
-edca_setting_UL	hal/phydm/phydm_edcaturbocheck.h	/^static u4Byte edca_setting_UL[HT_IOT_PEER_MAX] = $/;"	v
-edcca_flag	hal/phydm/phydm_dig.h	/^	BOOLEAN		edcca_flag;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-eeprom_clean	core/rtw_eeprom.c	/^void eeprom_clean(_adapter *padapter)$/;"	f
-eeprom_read	core/rtw_eeprom.c	/^u8 eeprom_read(_adapter *padapter, u32 addr_off, u8 sz, u8 *rbuf)$/;"	f
-eeprom_read16	core/rtw_eeprom.c	/^u16 eeprom_read16(_adapter *padapter, u16 reg)  \/* ReadEEprom *\/$/;"	f
-eeprom_read_sz	core/rtw_eeprom.c	/^void eeprom_read_sz(_adapter *padapter, u16 reg, u8 *data, u32 sz)$/;"	f
-eeprom_rw_param	include/rtw_mp_ioctl.h	/^struct eeprom_rw_param {$/;"	s
-eeprom_rw_param	include/rtw_mp_ioctl.h	/^} eeprom_rw_param, EEPROM_RWParam, *pEEPROM_RWParam;$/;"	t	typeref:struct:_EEPROM_RW_PARAM
-eeprom_write16	core/rtw_eeprom.c	/^void eeprom_write16(_adapter *padapter, u16 reg, u16 data)$/;"	f
-efuse_GetCurrentSize	core/efuse/rtw_efuse.c	/^u8 efuse_GetCurrentSize(PADAPTER adapter, u16 *size)$/;"	f
-efuse_GetCurrentSize	core/efuse/rtw_efuse.c	/^u8 efuse_GetCurrentSize(PADAPTER padapter, u16 *size)$/;"	f
-efuse_GetMaxSize	core/efuse/rtw_efuse.c	/^u16 efuse_GetMaxSize(PADAPTER adapter)$/;"	f
-efuse_GetMaxSize	core/efuse/rtw_efuse.c	/^u16 efuse_GetMaxSize(PADAPTER padapter)$/;"	f
-efuse_IsMasked	core/efuse/rtw_efuse.c	/^BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)$/;"	f
-efuse_OneByteRead	core/efuse/rtw_efuse.c	/^efuse_OneByteRead($/;"	f
-efuse_OneByteWrite	core/efuse/rtw_efuse.c	/^efuse_OneByteWrite($/;"	f
-efuse_ReadEFuse	core/efuse/rtw_efuse.c	/^efuse_ReadEFuse($/;"	f
-efuse_ShadowRead1Byte	core/efuse/rtw_efuse.c	/^efuse_ShadowRead1Byte($/;"	f	file:
-efuse_ShadowRead2Byte	core/efuse/rtw_efuse.c	/^efuse_ShadowRead2Byte($/;"	f	file:
-efuse_ShadowRead4Byte	core/efuse/rtw_efuse.c	/^efuse_ShadowRead4Byte($/;"	f	file:
-efuse_ShadowWrite1Byte	core/efuse/rtw_efuse.c	/^efuse_ShadowWrite1Byte($/;"	f	file:
-efuse_ShadowWrite2Byte	core/efuse/rtw_efuse.c	/^efuse_ShadowWrite2Byte($/;"	f	file:
-efuse_ShadowWrite4Byte	core/efuse/rtw_efuse.c	/^efuse_ShadowWrite4Byte($/;"	f	file:
-efuse_WordEnableDataRead	core/efuse/rtw_efuse.c	/^efuse_WordEnableDataRead(IN	u8	word_en,$/;"	f
-efuse_bt_GetCurrentSize	core/efuse/rtw_efuse.c	/^u8 efuse_bt_GetCurrentSize(PADAPTER adapter, u16 *size)$/;"	f
-efuse_bt_GetCurrentSize	core/efuse/rtw_efuse.c	/^u8 efuse_bt_GetCurrentSize(PADAPTER padapter, u16 *size)$/;"	f
-efuse_bt_GetMaxSize	core/efuse/rtw_efuse.c	/^u16 efuse_bt_GetMaxSize(PADAPTER adapter)$/;"	f
-efuse_bt_GetMaxSize	core/efuse/rtw_efuse.c	/^u16 efuse_bt_GetMaxSize(PADAPTER padapter)$/;"	f
-efuse_eeprom_data	include/hal_data.h	/^	u8	efuse_eeprom_data[EEPROM_MAX_SIZE]; \/*92C:256bytes, 88E:512bytes, we use union set (512bytes)*\/$/;"	m	struct:hal_com_data
-efuse_file_status	include/hal_data.h	/^	u8	efuse_file_status;$/;"	m	struct:hal_com_data
-efuse_read8	core/efuse/rtw_efuse.c	/^static u8 efuse_read8(PADAPTER padapter, u16 address, u8 *value)$/;"	f	file:
-efuse_write8	core/efuse/rtw_efuse.c	/^static u8 efuse_write8(PADAPTER padapter, u16 address, u8 *value)$/;"	f	file:
-eid	include/rtl8188e_cmd.h	/^	u8 eid; \/* element id *\/$/;"	m	struct:cmd_msg_parm
-eid	include/rtl8192e_cmd.h	/^	u8 eid; \/* element id *\/$/;"	m	struct:cmd_msg_parm
-eid	include/rtl8812a_cmd.h	/^	u8 eid; \/* element id *\/$/;"	m	struct:cmd_msg_parm
-eint_wlan_handle	platform/platform_ARM_SUNnI_sdio.c	/^static u32 eint_wlan_handle = 0;$/;"	v	file:
-elem_id	include/ieee80211_ext.h	/^	u8 elem_id; \/* WLAN_EID_RSN *\/$/;"	m	struct:rsn_ie_hdr
-elem_id	include/ieee80211_ext.h	/^	u8 elem_id;$/;"	m	struct:wpa_ie_hdr
-elements	include/rtw_recv.h	/^	u32	elements[100];	\/* array to store values *\/$/;"	m	struct:smooth_rssi_data
-en	include/rtw_cmd.h	/^	u32	en;$/;"	m	struct:enrateadaptive_parm
-en_11ac	include/rtw_rf.h	/^	u8 en_11ac;$/;"	m	struct:country_chplan
-en_desc_id	include/rtl8188e_xmit.h	/^	u32 en_desc_id:1;$/;"	m	struct:txdesc_88e
-en_desc_id	include/rtl8192e_xmit.h	/^	u32 en_desc_id:1;$/;"	m	struct:txdescriptor_8192e
-en_desc_id	include/rtl8812a_xmit.h	/^	u32 en_desc_id:1;$/;"	m	struct:txdescriptor_8812
-en_desc_id	include/rtl8821a_xmit.h	/^	u32 en_desc_id:1;$/;"	m	struct:txdescriptor_8821a
-en_gro	include/drv_types.h	/^	u8 en_gro;$/;"	m	struct:registry_priv
-en_hw_update_tsf	include/rtw_mlme_ext.h	/^	u8 en_hw_update_tsf;$/;"	m	struct:mlme_ext_priv
-en_hwseq	include/rtl8821a_xmit.h	/^	u32 en_hwseq:1;$/;"	m	struct:txdescriptor_8821a
-en_mcc	include/drv_types.h	/^	u8 en_mcc;$/;"	m	struct:registry_priv
-en_napi	include/drv_types.h	/^	u8 en_napi;$/;"	m	struct:registry_priv
-enable	include/rtw_mp_ioctl.h	/^	u8 enable;$/;"	m	struct:_mp_xmit_parm_
-enable	include/rtw_recv.h	/^	u8 enable;$/;"	m	struct:recv_reorder_ctrl
-enable80211d	include/drv_types.h	/^	u8 enable80211d;$/;"	m	struct:registry_priv
-enableAdjustBigJump	hal/phydm/phydm_dig.h	/^	u1Byte		enableAdjustBigJump:1;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-enableIsarWithStatus	include/drv_types_sdio.h	/^	BOOLEAN						enableIsarWithStatus;$/;"	m	struct:sdio_data
-enableRFE	include/rtw_pwrctrl.h	/^	u8	enableRFE;			\/* Enable RFE *\/$/;"	m	struct:pno_scan_info
-enable_ctrl_frame_antdiv	hal/phydm/phydm_antdiv.h	/^	BOOLEAN	enable_ctrl_frame_antdiv;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-enable_interrupt	include/hal_intf.h	/^	void	(*enable_interrupt)(_adapter *padapter);$/;"	m	struct:hal_ops
-enable_mbssid_cam	hal/hal_com.c	/^static void enable_mbssid_cam(_adapter *adapter)$/;"	f	file:
-enabled	include/ieee80211.h	/^	    enabled:1,$/;"	m	struct:ieee80211_security
-enc_algo	include/rtw_mlme_ext.h	/^	u32	enc_algo;\/* encrypt algorithm; *\/$/;"	m	struct:mlme_ext_info
-encryp_protocol	include/rtw_mlme.h	/^	int encryp_protocol;$/;"	m	struct:beacon_keys
-encryp_protocol	include/wlan_bssdef.h	/^	u8 encryp_protocol;\/* ENCRYP_PROTOCOL_E: OPEN\/WEP\/WPA\/WPA2\/WAPI *\/$/;"	m	struct:_WLAN_BCN_INFO
-encrypt	include/rtw_recv.h	/^	u8	encrypt; \/* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith *\/$/;"	m	struct:rx_pkt_attrib
-encrypt	include/rtw_xmit.h	/^	u8	encrypt;	\/* when 0 indicate no encrypt. when non-zero, indicate the encrypt algorith *\/$/;"	m	struct:pkt_attrib
-encrypted	include/ieee80211.h	/^	u8 encrypted;$/;"	m	struct:ieee80211_txb
-end	include/osdep_service_bsd.h	/^	sk_buff_data_t		end;$/;"	m	struct:sk_buff
-enqueue_pending_xmitbuf	core/rtw_xmit.c	/^void enqueue_pending_xmitbuf($/;"	f
-enqueue_pending_xmitbuf_to_head	core/rtw_xmit.c	/^void enqueue_pending_xmitbuf_to_head($/;"	f
-enqueue_reorder_recvframe	core/rtw_recv.c	/^int enqueue_reorder_recvframe(struct recv_reorder_ctrl *preorder_ctrl, union recv_frame *prframe)$/;"	f
-enrateadaptive_parm	include/rtw_cmd.h	/^struct	enrateadaptive_parm {$/;"	s
-entries	include/rtw_xmit.h	/^	unsigned int	entries;$/;"	m	struct:rtw_tx_ring
-entry_idx	include/rtw_wapi.h	/^	u8			entry_idx;\/* for cam entry *\/$/;"	m	struct:_RT_WAPI_CAM_ENTRY
-eor	include/rtl8188e_recv.h	/^	u32 eor:1;$/;"	m	struct:rxreport_8188e
-eosp	include/rtl8188e_recv.h	/^	u32 eosp:1;$/;"	m	struct:rxreport_8188e
-eosp	include/rtw_xmit.h	/^	u8	eosp;$/;"	m	struct:pkt_attrib
-ep_num	include/drv_types.h	/^	int	ep_num[6]; \/* endpoint number *\/$/;"	m	struct:dvobj_priv
-eqMacAddr	include/hal_com_h2c.h	158;"	d
-eqNByte	hal/hal_com.c	/^eqNByte($/;"	f
-erp_info	include/ieee80211.h	/^	u8 *erp_info;$/;"	m	struct:rtw_ieee802_11_elems
-erp_info_len	include/ieee80211.h	/^	u8 erp_info_len;$/;"	m	struct:rtw_ieee802_11_elems
-err	include/drv_types.h	/^	u32 err;$/;"	m	struct:int_logs
-err	include/ieee80211.h	/^			u32 err;$/;"	m	struct:ieee_param::__anon73::__anon77
-error_condition	hal/btc/HalBtc8192e1Ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8192e_1ant
-error_condition	hal/btc/HalBtc8703b1Ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8703b_1ant
-error_condition	hal/btc/HalBtc8723b1Ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8723b_1ant
-error_condition	hal/btc/HalBtc8812a1Ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8812a_1ant
-error_condition	hal/btc/HalBtc8821a1Ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8821a_1ant
-error_condition	hal/btc/HalBtc8822b1Ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8822b_1ant
-error_condition	hal/btc/halbtc8723d1ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8723d_1ant
-error_condition	hal/btc/halbtc8821c1ant.h	/^	u8		error_condition;$/;"	m	struct:coex_dm_8821c_1ant
-ethBrExtInfo	include/drv_types.h	/^	struct br_ext_info		ethBrExtInfo;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::br_ext_info
-eth_type	include/rtw_recv.h	/^	u16	eth_type;$/;"	m	struct:rx_pkt_attrib
-ether_type	include/rtw_xmit.h	/^	u16	ether_type;$/;"	m	struct:pkt_attrib
-ethertype	include/ieee80211.h	/^	u16 ethertype;$/;"	m	struct:eapol
-ethhdr	include/if_ether.h	/^struct ethhdr {$/;"	s
-event_callback	include/rtw_event.h	/^	void (*event_callback)(_adapter *dev, u8 *pbuf);$/;"	m	struct:fwevent
-event_node	include/rtw_event.h	/^struct event_node {$/;"	s
-event_seq	include/rtw_cmd.h	/^	ATOMIC_T event_seq;$/;"	m	struct:evt_priv
-event_seq	include/rtw_mlme_ext.h	/^	ATOMIC_T		event_seq;$/;"	m	struct:mlme_ext_priv
-evm_antdiv_period	hal/phydm/phydm.h	/^	u1Byte			evm_antdiv_period;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-evtThread	include/drv_types.h	/^	_thread_hdl_ evtThread;$/;"	m	struct:_ADAPTER
-evt_allocated_buf	include/rtw_cmd.h	/^	u8	*evt_allocated_buf;$/;"	m	struct:evt_priv
-evt_buf	include/rtw_cmd.h	/^	u8	*evt_buf;	\/* shall be non-paged, and 4 bytes aligned		 *\/$/;"	m	struct:evt_priv
-evt_code	include/rtw_event.h	/^	unsigned char evt_code;$/;"	m	struct:event_node
-evt_done_cnt	include/rtw_cmd.h	/^	u32	evt_done_cnt;$/;"	m	struct:evt_priv
-evt_notify	include/rtw_cmd.h	/^	_sema	evt_notify;$/;"	m	struct:evt_priv
-evt_obj	include/rtw_cmd.h	/^struct evt_obj {$/;"	s
-evt_priv	include/rtw_cmd.h	/^struct	evt_priv {$/;"	s
-evt_queue	include/rtw_cmd.h	/^	_queue	evt_queue;$/;"	m	struct:evt_priv
-evt_sz	include/rtw_event.h	/^	unsigned short evt_sz;$/;"	m	struct:event_node
-evtcode	include/rtw_cmd.h	/^	u16	evtcode;$/;"	m	struct:evt_obj
-evtpriv	include/drv_types.h	/^	struct	evt_priv	evtpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::evt_priv
-evtsz	include/rtw_cmd.h	/^	u32	evtsz;$/;"	m	struct:evt_obj
-ex_halbtc8192e1ant_bt_info_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_bt_info_notify	hal/btc/HalBtc8192e1Ant.h	215;"	d
-ex_halbtc8192e1ant_coex_dm_reset	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e1ant_coex_dm_reset	hal/btc/HalBtc8192e1Ant.h	219;"	d
-ex_halbtc8192e1ant_connect_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_connect_notify	hal/btc/HalBtc8192e1Ant.h	212;"	d
-ex_halbtc8192e1ant_dbg_control	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_dbg_control(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_dbg_control	hal/btc/HalBtc8192e1Ant.h	222;"	d
-ex_halbtc8192e1ant_display_coex_info	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e1ant_display_coex_info	hal/btc/HalBtc8192e1Ant.h	221;"	d
-ex_halbtc8192e1ant_halt_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e1ant_halt_notify	hal/btc/HalBtc8192e1Ant.h	217;"	d
-ex_halbtc8192e1ant_init_coex_dm	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e1ant_init_coex_dm	hal/btc/HalBtc8192e1Ant.h	208;"	d
-ex_halbtc8192e1ant_init_hw_config	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_init_hw_config	hal/btc/HalBtc8192e1Ant.h	207;"	d
-ex_halbtc8192e1ant_ips_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8192e1ant_ips_notify	hal/btc/HalBtc8192e1Ant.h	209;"	d
-ex_halbtc8192e1ant_lps_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8192e1ant_lps_notify	hal/btc/HalBtc8192e1Ant.h	210;"	d
-ex_halbtc8192e1ant_media_status_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_media_status_notify	hal/btc/HalBtc8192e1Ant.h	213;"	d
-ex_halbtc8192e1ant_periodical	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e1ant_periodical	hal/btc/HalBtc8192e1Ant.h	220;"	d
-ex_halbtc8192e1ant_pnp_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_pnp_notify	hal/btc/HalBtc8192e1Ant.h	218;"	d
-ex_halbtc8192e1ant_power_on_setting	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e1ant_power_on_setting	hal/btc/HalBtc8192e1Ant.h	205;"	d
-ex_halbtc8192e1ant_pre_load_firmware	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e1ant_pre_load_firmware	hal/btc/HalBtc8192e1Ant.h	206;"	d
-ex_halbtc8192e1ant_rf_status_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_rf_status_notify	hal/btc/HalBtc8192e1Ant.h	216;"	d
-ex_halbtc8192e1ant_scan_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_scan_notify	hal/btc/HalBtc8192e1Ant.h	211;"	d
-ex_halbtc8192e1ant_specific_packet_notify	hal/btc/HalBtc8192e1Ant.c	/^void ex_halbtc8192e1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e1ant_specific_packet_notify	hal/btc/HalBtc8192e1Ant.h	214;"	d
-ex_halbtc8192e2ant_bt_info_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e2ant_bt_info_notify	hal/btc/HalBtc8192e2Ant.h	191;"	d
-ex_halbtc8192e2ant_connect_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e2ant_connect_notify	hal/btc/HalBtc8192e2Ant.h	188;"	d
-ex_halbtc8192e2ant_display_coex_info	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e2ant_display_coex_info	hal/btc/HalBtc8192e2Ant.h	194;"	d
-ex_halbtc8192e2ant_halt_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e2ant_halt_notify	hal/btc/HalBtc8192e2Ant.h	192;"	d
-ex_halbtc8192e2ant_init_coex_dm	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e2ant_init_coex_dm	hal/btc/HalBtc8192e2Ant.h	184;"	d
-ex_halbtc8192e2ant_init_hw_config	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e2ant_init_hw_config	hal/btc/HalBtc8192e2Ant.h	183;"	d
-ex_halbtc8192e2ant_ips_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8192e2ant_ips_notify	hal/btc/HalBtc8192e2Ant.h	185;"	d
-ex_halbtc8192e2ant_lps_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8192e2ant_lps_notify	hal/btc/HalBtc8192e2Ant.h	186;"	d
-ex_halbtc8192e2ant_media_status_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e2ant_media_status_notify	hal/btc/HalBtc8192e2Ant.h	189;"	d
-ex_halbtc8192e2ant_periodical	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e2ant_periodical	hal/btc/HalBtc8192e2Ant.h	193;"	d
-ex_halbtc8192e2ant_power_on_setting	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8192e2ant_power_on_setting	hal/btc/HalBtc8192e2Ant.h	182;"	d
-ex_halbtc8192e2ant_scan_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e2ant_scan_notify	hal/btc/HalBtc8192e2Ant.h	187;"	d
-ex_halbtc8192e2ant_specific_packet_notify	hal/btc/HalBtc8192e2Ant.c	/^void ex_halbtc8192e2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8192e2ant_specific_packet_notify	hal/btc/HalBtc8192e2Ant.h	190;"	d
-ex_halbtc8703b1ant_antenna_detection	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_antenna_detection	hal/btc/HalBtc8703b1Ant.h	340;"	d
-ex_halbtc8703b1ant_antenna_isolation	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_antenna_isolation(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_antenna_isolation	hal/btc/HalBtc8703b1Ant.h	341;"	d
-ex_halbtc8703b1ant_bt_info_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_bt_info_notify	hal/btc/HalBtc8703b1Ant.h	333;"	d
-ex_halbtc8703b1ant_coex_dm_reset	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_coex_dm_reset	hal/btc/HalBtc8703b1Ant.h	337;"	d
-ex_halbtc8703b1ant_connect_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_connect_notify	hal/btc/HalBtc8703b1Ant.h	330;"	d
-ex_halbtc8703b1ant_display_ant_detection	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_display_ant_detection(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_display_ant_detection	hal/btc/HalBtc8703b1Ant.h	343;"	d
-ex_halbtc8703b1ant_display_coex_info	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_display_coex_info	hal/btc/HalBtc8703b1Ant.h	339;"	d
-ex_halbtc8703b1ant_halt_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_halt_notify	hal/btc/HalBtc8703b1Ant.h	335;"	d
-ex_halbtc8703b1ant_init_coex_dm	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_init_coex_dm	hal/btc/HalBtc8703b1Ant.h	326;"	d
-ex_halbtc8703b1ant_init_hw_config	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_init_hw_config	hal/btc/HalBtc8703b1Ant.h	325;"	d
-ex_halbtc8703b1ant_ips_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8703b1ant_ips_notify	hal/btc/HalBtc8703b1Ant.h	327;"	d
-ex_halbtc8703b1ant_lps_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8703b1ant_lps_notify	hal/btc/HalBtc8703b1Ant.h	328;"	d
-ex_halbtc8703b1ant_media_status_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_media_status_notify	hal/btc/HalBtc8703b1Ant.h	331;"	d
-ex_halbtc8703b1ant_periodical	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_periodical	hal/btc/HalBtc8703b1Ant.h	338;"	d
-ex_halbtc8703b1ant_pnp_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_pnp_notify	hal/btc/HalBtc8703b1Ant.h	336;"	d
-ex_halbtc8703b1ant_power_on_setting	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_power_on_setting	hal/btc/HalBtc8703b1Ant.h	323;"	d
-ex_halbtc8703b1ant_pre_load_firmware	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8703b1ant_pre_load_firmware	hal/btc/HalBtc8703b1Ant.h	324;"	d
-ex_halbtc8703b1ant_psd_scan	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_psd_scan(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_psd_scan	hal/btc/HalBtc8703b1Ant.h	342;"	d
-ex_halbtc8703b1ant_rf_status_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_rf_status_notify	hal/btc/HalBtc8703b1Ant.h	334;"	d
-ex_halbtc8703b1ant_scan_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_scan_notify	hal/btc/HalBtc8703b1Ant.h	329;"	d
-ex_halbtc8703b1ant_specific_packet_notify	hal/btc/HalBtc8703b1Ant.c	/^void ex_halbtc8703b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8703b1ant_specific_packet_notify	hal/btc/HalBtc8703b1Ant.h	332;"	d
-ex_halbtc8723b1ant_antenna_detection	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_antenna_detection	hal/btc/HalBtc8723b1Ant.h	283;"	d
-ex_halbtc8723b1ant_bt_info_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_bt_info_notify	hal/btc/HalBtc8723b1Ant.h	276;"	d
-ex_halbtc8723b1ant_coex_dm_reset	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_coex_dm_reset	hal/btc/HalBtc8723b1Ant.h	280;"	d
-ex_halbtc8723b1ant_connect_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_connect_notify	hal/btc/HalBtc8723b1Ant.h	273;"	d
-ex_halbtc8723b1ant_display_ant_detection	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_display_ant_detection(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_display_ant_detection	hal/btc/HalBtc8723b1Ant.h	284;"	d
-ex_halbtc8723b1ant_display_coex_info	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_display_coex_info	hal/btc/HalBtc8723b1Ant.h	282;"	d
-ex_halbtc8723b1ant_halt_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_halt_notify	hal/btc/HalBtc8723b1Ant.h	278;"	d
-ex_halbtc8723b1ant_init_coex_dm	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_init_coex_dm	hal/btc/HalBtc8723b1Ant.h	269;"	d
-ex_halbtc8723b1ant_init_hw_config	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_init_hw_config	hal/btc/HalBtc8723b1Ant.h	268;"	d
-ex_halbtc8723b1ant_ips_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723b1ant_ips_notify	hal/btc/HalBtc8723b1Ant.h	270;"	d
-ex_halbtc8723b1ant_lps_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723b1ant_lps_notify	hal/btc/HalBtc8723b1Ant.h	271;"	d
-ex_halbtc8723b1ant_media_status_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_media_status_notify	hal/btc/HalBtc8723b1Ant.h	274;"	d
-ex_halbtc8723b1ant_periodical	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_periodical	hal/btc/HalBtc8723b1Ant.h	281;"	d
-ex_halbtc8723b1ant_pnp_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_pnp_notify	hal/btc/HalBtc8723b1Ant.h	279;"	d
-ex_halbtc8723b1ant_power_on_setting	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_power_on_setting	hal/btc/HalBtc8723b1Ant.h	266;"	d
-ex_halbtc8723b1ant_pre_load_firmware	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b1ant_pre_load_firmware	hal/btc/HalBtc8723b1Ant.h	267;"	d
-ex_halbtc8723b1ant_rf_status_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_rf_status_notify	hal/btc/HalBtc8723b1Ant.h	277;"	d
-ex_halbtc8723b1ant_scan_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_scan_notify	hal/btc/HalBtc8723b1Ant.h	272;"	d
-ex_halbtc8723b1ant_specific_packet_notify	hal/btc/HalBtc8723b1Ant.c	/^void ex_halbtc8723b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b1ant_specific_packet_notify	hal/btc/HalBtc8723b1Ant.h	275;"	d
-ex_halbtc8723b2ant_bt_info_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b2ant_bt_info_notify	hal/btc/HalBtc8723b2Ant.h	206;"	d
-ex_halbtc8723b2ant_connect_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b2ant_connect_notify	hal/btc/HalBtc8723b2Ant.h	203;"	d
-ex_halbtc8723b2ant_display_coex_info	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b2ant_display_coex_info	hal/btc/HalBtc8723b2Ant.h	210;"	d
-ex_halbtc8723b2ant_halt_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b2ant_halt_notify	hal/btc/HalBtc8723b2Ant.h	207;"	d
-ex_halbtc8723b2ant_init_coex_dm	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b2ant_init_coex_dm	hal/btc/HalBtc8723b2Ant.h	199;"	d
-ex_halbtc8723b2ant_init_hw_config	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b2ant_init_hw_config	hal/btc/HalBtc8723b2Ant.h	198;"	d
-ex_halbtc8723b2ant_ips_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723b2ant_ips_notify	hal/btc/HalBtc8723b2Ant.h	200;"	d
-ex_halbtc8723b2ant_lps_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723b2ant_lps_notify	hal/btc/HalBtc8723b2Ant.h	201;"	d
-ex_halbtc8723b2ant_media_status_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b2ant_media_status_notify	hal/btc/HalBtc8723b2Ant.h	204;"	d
-ex_halbtc8723b2ant_periodical	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b2ant_periodical	hal/btc/HalBtc8723b2Ant.h	209;"	d
-ex_halbtc8723b2ant_pnp_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b2ant_pnp_notify	hal/btc/HalBtc8723b2Ant.h	208;"	d
-ex_halbtc8723b2ant_power_on_setting	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b2ant_power_on_setting	hal/btc/HalBtc8723b2Ant.h	196;"	d
-ex_halbtc8723b2ant_pre_load_firmware	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723b2ant_pre_load_firmware	hal/btc/HalBtc8723b2Ant.h	197;"	d
-ex_halbtc8723b2ant_scan_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b2ant_scan_notify	hal/btc/HalBtc8723b2Ant.h	202;"	d
-ex_halbtc8723b2ant_specific_packet_notify	hal/btc/HalBtc8723b2Ant.c	/^void ex_halbtc8723b2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723b2ant_specific_packet_notify	hal/btc/HalBtc8723b2Ant.h	205;"	d
-ex_halbtc8723d1ant_antenna_detection	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_antenna_detection	hal/btc/halbtc8723d1ant.h	406;"	d
-ex_halbtc8723d1ant_antenna_isolation	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_antenna_isolation(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_antenna_isolation	hal/btc/halbtc8723d1ant.h	407;"	d
-ex_halbtc8723d1ant_bt_info_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_bt_info_notify	hal/btc/halbtc8723d1ant.h	398;"	d
-ex_halbtc8723d1ant_coex_dm_reset	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_coex_dm_reset	hal/btc/halbtc8723d1ant.h	402;"	d
-ex_halbtc8723d1ant_connect_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_connect_notify	hal/btc/halbtc8723d1ant.h	395;"	d
-ex_halbtc8723d1ant_display_ant_detection	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_display_ant_detection(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_display_ant_detection	hal/btc/halbtc8723d1ant.h	409;"	d
-ex_halbtc8723d1ant_display_coex_info	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_display_coex_info	hal/btc/halbtc8723d1ant.h	404;"	d
-ex_halbtc8723d1ant_halt_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_halt_notify	hal/btc/halbtc8723d1ant.h	400;"	d
-ex_halbtc8723d1ant_init_coex_dm	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_init_coex_dm	hal/btc/halbtc8723d1ant.h	391;"	d
-ex_halbtc8723d1ant_init_hw_config	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_init_hw_config	hal/btc/halbtc8723d1ant.h	390;"	d
-ex_halbtc8723d1ant_ips_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723d1ant_ips_notify	hal/btc/halbtc8723d1ant.h	392;"	d
-ex_halbtc8723d1ant_lps_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723d1ant_lps_notify	hal/btc/halbtc8723d1ant.h	393;"	d
-ex_halbtc8723d1ant_media_status_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_media_status_notify	hal/btc/halbtc8723d1ant.h	396;"	d
-ex_halbtc8723d1ant_periodical	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_periodical	hal/btc/halbtc8723d1ant.h	403;"	d
-ex_halbtc8723d1ant_pnp_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_pnp_notify	hal/btc/halbtc8723d1ant.h	401;"	d
-ex_halbtc8723d1ant_power_on_setting	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_power_on_setting	hal/btc/halbtc8723d1ant.h	388;"	d
-ex_halbtc8723d1ant_pre_load_firmware	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d1ant_pre_load_firmware	hal/btc/halbtc8723d1ant.h	389;"	d
-ex_halbtc8723d1ant_psd_scan	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_psd_scan(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_psd_scan	hal/btc/halbtc8723d1ant.h	408;"	d
-ex_halbtc8723d1ant_rf_status_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_rf_status_notify	hal/btc/halbtc8723d1ant.h	399;"	d
-ex_halbtc8723d1ant_scan_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_scan_notify	hal/btc/halbtc8723d1ant.h	394;"	d
-ex_halbtc8723d1ant_set_antenna_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_set_antenna_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_set_antenna_notify	hal/btc/halbtc8723d1ant.h	405;"	d
-ex_halbtc8723d1ant_specific_packet_notify	hal/btc/halbtc8723d1ant.c	/^void ex_halbtc8723d1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d1ant_specific_packet_notify	hal/btc/halbtc8723d1ant.h	397;"	d
-ex_halbtc8723d2ant_antenna_detection	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_antenna_detection	hal/btc/halbtc8723d2ant.h	416;"	d
-ex_halbtc8723d2ant_bt_info_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_bt_info_notify	hal/btc/halbtc8723d2ant.h	408;"	d
-ex_halbtc8723d2ant_connect_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_connect_notify	hal/btc/halbtc8723d2ant.h	405;"	d
-ex_halbtc8723d2ant_display_ant_detection	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_display_ant_detection(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d2ant_display_ant_detection	hal/btc/halbtc8723d2ant.h	415;"	d
-ex_halbtc8723d2ant_display_coex_info	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d2ant_display_coex_info	hal/btc/halbtc8723d2ant.h	413;"	d
-ex_halbtc8723d2ant_halt_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d2ant_halt_notify	hal/btc/halbtc8723d2ant.h	410;"	d
-ex_halbtc8723d2ant_init_coex_dm	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d2ant_init_coex_dm	hal/btc/halbtc8723d2ant.h	401;"	d
-ex_halbtc8723d2ant_init_hw_config	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_init_hw_config	hal/btc/halbtc8723d2ant.h	400;"	d
-ex_halbtc8723d2ant_ips_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723d2ant_ips_notify	hal/btc/halbtc8723d2ant.h	402;"	d
-ex_halbtc8723d2ant_lps_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8723d2ant_lps_notify	hal/btc/halbtc8723d2ant.h	403;"	d
-ex_halbtc8723d2ant_media_status_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_media_status_notify	hal/btc/halbtc8723d2ant.h	406;"	d
-ex_halbtc8723d2ant_periodical	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d2ant_periodical	hal/btc/halbtc8723d2ant.h	412;"	d
-ex_halbtc8723d2ant_pnp_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_pnp_notify	hal/btc/halbtc8723d2ant.h	411;"	d
-ex_halbtc8723d2ant_power_on_setting	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d2ant_power_on_setting	hal/btc/halbtc8723d2ant.h	398;"	d
-ex_halbtc8723d2ant_pre_load_firmware	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8723d2ant_pre_load_firmware	hal/btc/halbtc8723d2ant.h	399;"	d
-ex_halbtc8723d2ant_rf_status_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_rf_status_notify	hal/btc/halbtc8723d2ant.h	409;"	d
-ex_halbtc8723d2ant_scan_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_scan_notify	hal/btc/halbtc8723d2ant.h	404;"	d
-ex_halbtc8723d2ant_set_antenna_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_set_antenna_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_set_antenna_notify	hal/btc/halbtc8723d2ant.h	414;"	d
-ex_halbtc8723d2ant_specific_packet_notify	hal/btc/halbtc8723d2ant.c	/^void ex_halbtc8723d2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8723d2ant_specific_packet_notify	hal/btc/halbtc8723d2ant.h	407;"	d
-ex_halbtc8812a1ant_bt_info_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_bt_info_notify	hal/btc/HalBtc8812a1Ant.h	219;"	d
-ex_halbtc8812a1ant_coex_dm_reset	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a1ant_coex_dm_reset	hal/btc/HalBtc8812a1Ant.h	223;"	d
-ex_halbtc8812a1ant_connect_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_connect_notify	hal/btc/HalBtc8812a1Ant.h	216;"	d
-ex_halbtc8812a1ant_dbg_control	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_dbg_control(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_dbg_control	hal/btc/HalBtc8812a1Ant.h	225;"	d
-ex_halbtc8812a1ant_display_coex_info	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a1ant_display_coex_info	hal/btc/HalBtc8812a1Ant.h	226;"	d
-ex_halbtc8812a1ant_halt_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a1ant_halt_notify	hal/btc/HalBtc8812a1Ant.h	221;"	d
-ex_halbtc8812a1ant_init_coex_dm	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a1ant_init_coex_dm	hal/btc/HalBtc8812a1Ant.h	212;"	d
-ex_halbtc8812a1ant_init_hw_config	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_init_hw_config	hal/btc/HalBtc8812a1Ant.h	211;"	d
-ex_halbtc8812a1ant_ips_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8812a1ant_ips_notify	hal/btc/HalBtc8812a1Ant.h	213;"	d
-ex_halbtc8812a1ant_lps_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8812a1ant_lps_notify	hal/btc/HalBtc8812a1Ant.h	214;"	d
-ex_halbtc8812a1ant_media_status_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_media_status_notify	hal/btc/HalBtc8812a1Ant.h	217;"	d
-ex_halbtc8812a1ant_periodical	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a1ant_periodical	hal/btc/HalBtc8812a1Ant.h	224;"	d
-ex_halbtc8812a1ant_pnp_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_pnp_notify	hal/btc/HalBtc8812a1Ant.h	222;"	d
-ex_halbtc8812a1ant_power_on_setting	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a1ant_power_on_setting	hal/btc/HalBtc8812a1Ant.h	209;"	d
-ex_halbtc8812a1ant_pre_load_firmware	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a1ant_pre_load_firmware	hal/btc/HalBtc8812a1Ant.h	210;"	d
-ex_halbtc8812a1ant_rf_status_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_rf_status_notify	hal/btc/HalBtc8812a1Ant.h	220;"	d
-ex_halbtc8812a1ant_scan_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_scan_notify	hal/btc/HalBtc8812a1Ant.h	215;"	d
-ex_halbtc8812a1ant_specific_packet_notify	hal/btc/HalBtc8812a1Ant.c	/^void ex_halbtc8812a1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a1ant_specific_packet_notify	hal/btc/HalBtc8812a1Ant.h	218;"	d
-ex_halbtc8812a2ant_bt_info_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_bt_info_notify	hal/btc/HalBtc8812a2Ant.h	194;"	d
-ex_halbtc8812a2ant_connect_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_connect_notify	hal/btc/HalBtc8812a2Ant.h	191;"	d
-ex_halbtc8812a2ant_dbg_control	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_dbg_control(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_dbg_control	hal/btc/HalBtc8812a2Ant.h	199;"	d
-ex_halbtc8812a2ant_display_coex_info	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a2ant_display_coex_info	hal/btc/HalBtc8812a2Ant.h	198;"	d
-ex_halbtc8812a2ant_halt_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a2ant_halt_notify	hal/btc/HalBtc8812a2Ant.h	196;"	d
-ex_halbtc8812a2ant_init_coex_dm	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a2ant_init_coex_dm	hal/btc/HalBtc8812a2Ant.h	187;"	d
-ex_halbtc8812a2ant_init_hw_config	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_init_hw_config	hal/btc/HalBtc8812a2Ant.h	186;"	d
-ex_halbtc8812a2ant_ips_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8812a2ant_ips_notify	hal/btc/HalBtc8812a2Ant.h	188;"	d
-ex_halbtc8812a2ant_lps_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8812a2ant_lps_notify	hal/btc/HalBtc8812a2Ant.h	189;"	d
-ex_halbtc8812a2ant_media_status_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_media_status_notify	hal/btc/HalBtc8812a2Ant.h	192;"	d
-ex_halbtc8812a2ant_periodical	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a2ant_periodical	hal/btc/HalBtc8812a2Ant.h	197;"	d
-ex_halbtc8812a2ant_power_on_setting	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8812a2ant_power_on_setting	hal/btc/HalBtc8812a2Ant.h	185;"	d
-ex_halbtc8812a2ant_rf_status_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_rf_status_notify	hal/btc/HalBtc8812a2Ant.h	195;"	d
-ex_halbtc8812a2ant_scan_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_scan_notify	hal/btc/HalBtc8812a2Ant.h	190;"	d
-ex_halbtc8812a2ant_specific_packet_notify	hal/btc/HalBtc8812a2Ant.c	/^void ex_halbtc8812a2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8812a2ant_specific_packet_notify	hal/btc/HalBtc8812a2Ant.h	193;"	d
-ex_halbtc8821a1ant_bt_info_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a1ant_bt_info_notify	hal/btc/HalBtc8821a1Ant.h	189;"	d
-ex_halbtc8821a1ant_connect_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a1ant_connect_notify	hal/btc/HalBtc8821a1Ant.h	186;"	d
-ex_halbtc8821a1ant_display_coex_info	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a1ant_display_coex_info	hal/btc/HalBtc8821a1Ant.h	193;"	d
-ex_halbtc8821a1ant_halt_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a1ant_halt_notify	hal/btc/HalBtc8821a1Ant.h	190;"	d
-ex_halbtc8821a1ant_init_coex_dm	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a1ant_init_coex_dm	hal/btc/HalBtc8821a1Ant.h	182;"	d
-ex_halbtc8821a1ant_init_hw_config	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a1ant_init_hw_config	hal/btc/HalBtc8821a1Ant.h	181;"	d
-ex_halbtc8821a1ant_ips_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821a1ant_ips_notify	hal/btc/HalBtc8821a1Ant.h	183;"	d
-ex_halbtc8821a1ant_lps_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821a1ant_lps_notify	hal/btc/HalBtc8821a1Ant.h	184;"	d
-ex_halbtc8821a1ant_media_status_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a1ant_media_status_notify	hal/btc/HalBtc8821a1Ant.h	187;"	d
-ex_halbtc8821a1ant_periodical	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a1ant_periodical	hal/btc/HalBtc8821a1Ant.h	192;"	d
-ex_halbtc8821a1ant_pnp_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a1ant_pnp_notify	hal/btc/HalBtc8821a1Ant.h	191;"	d
-ex_halbtc8821a1ant_power_on_setting	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a1ant_power_on_setting	hal/btc/HalBtc8821a1Ant.h	180;"	d
-ex_halbtc8821a1ant_scan_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a1ant_scan_notify	hal/btc/HalBtc8821a1Ant.h	185;"	d
-ex_halbtc8821a1ant_specific_packet_notify	hal/btc/HalBtc8821a1Ant.c	/^void ex_halbtc8821a1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a1ant_specific_packet_notify	hal/btc/HalBtc8821a1Ant.h	188;"	d
-ex_halbtc8821a2ant_bt_info_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a2ant_bt_info_notify	hal/btc/HalBtc8821a2Ant.h	198;"	d
-ex_halbtc8821a2ant_connect_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a2ant_connect_notify	hal/btc/HalBtc8821a2Ant.h	195;"	d
-ex_halbtc8821a2ant_display_coex_info	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a2ant_display_coex_info	hal/btc/HalBtc8821a2Ant.h	202;"	d
-ex_halbtc8821a2ant_halt_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a2ant_halt_notify	hal/btc/HalBtc8821a2Ant.h	199;"	d
-ex_halbtc8821a2ant_init_coex_dm	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a2ant_init_coex_dm	hal/btc/HalBtc8821a2Ant.h	191;"	d
-ex_halbtc8821a2ant_init_hw_config	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a2ant_init_hw_config	hal/btc/HalBtc8821a2Ant.h	190;"	d
-ex_halbtc8821a2ant_ips_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821a2ant_ips_notify	hal/btc/HalBtc8821a2Ant.h	192;"	d
-ex_halbtc8821a2ant_lps_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821a2ant_lps_notify	hal/btc/HalBtc8821a2Ant.h	193;"	d
-ex_halbtc8821a2ant_media_status_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a2ant_media_status_notify	hal/btc/HalBtc8821a2Ant.h	196;"	d
-ex_halbtc8821a2ant_periodical	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a2ant_periodical	hal/btc/HalBtc8821a2Ant.h	201;"	d
-ex_halbtc8821a2ant_pnp_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a2ant_pnp_notify	hal/btc/HalBtc8821a2Ant.h	200;"	d
-ex_halbtc8821a2ant_power_on_setting	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a2ant_power_on_setting	hal/btc/HalBtc8821a2Ant.h	188;"	d
-ex_halbtc8821a2ant_pre_load_firmware	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821a2ant_pre_load_firmware	hal/btc/HalBtc8821a2Ant.h	189;"	d
-ex_halbtc8821a2ant_scan_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a2ant_scan_notify	hal/btc/HalBtc8821a2Ant.h	194;"	d
-ex_halbtc8821a2ant_specific_packet_notify	hal/btc/HalBtc8821a2Ant.c	/^void ex_halbtc8821a2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821a2ant_specific_packet_notify	hal/btc/HalBtc8821a2Ant.h	197;"	d
-ex_halbtc8821aCsr2ant_bt_info_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_bt_info_notify	hal/btc/HalBtc8821aCsr2Ant.h	181;"	d
-ex_halbtc8821aCsr2ant_connect_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_connect_notify	hal/btc/HalBtc8821aCsr2Ant.h	178;"	d
-ex_halbtc8821aCsr2ant_display_coex_info	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821aCsr2ant_display_coex_info	hal/btc/HalBtc8821aCsr2Ant.h	185;"	d
-ex_halbtc8821aCsr2ant_halt_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821aCsr2ant_halt_notify	hal/btc/HalBtc8821aCsr2Ant.h	182;"	d
-ex_halbtc8821aCsr2ant_init_coex_dm	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821aCsr2ant_init_coex_dm	hal/btc/HalBtc8821aCsr2Ant.h	174;"	d
-ex_halbtc8821aCsr2ant_init_hw_config	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_init_hw_config	hal/btc/HalBtc8821aCsr2Ant.h	173;"	d
-ex_halbtc8821aCsr2ant_ips_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_ips_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_ips_notify	hal/btc/HalBtc8821aCsr2Ant.h	175;"	d
-ex_halbtc8821aCsr2ant_lps_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_lps_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_lps_notify	hal/btc/HalBtc8821aCsr2Ant.h	176;"	d
-ex_halbtc8821aCsr2ant_media_status_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_media_status_notify	hal/btc/HalBtc8821aCsr2Ant.h	179;"	d
-ex_halbtc8821aCsr2ant_periodical	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821aCsr2ant_periodical	hal/btc/HalBtc8821aCsr2Ant.h	184;"	d
-ex_halbtc8821aCsr2ant_pnp_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_pnp_notify	hal/btc/HalBtc8821aCsr2Ant.h	183;"	d
-ex_halbtc8821aCsr2ant_power_on_setting	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821aCsr2ant_power_on_setting	hal/btc/HalBtc8821aCsr2Ant.h	172;"	d
-ex_halbtc8821aCsr2ant_scan_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821aCsr2ant_scan_notify	hal/btc/HalBtc8821aCsr2Ant.h	177;"	d
-ex_halbtc8821aCsr2ant_specific_packet_notify	hal/btc/HalBtc8821aCsr2Ant.c	/^void ex_halbtc8821aCsr2ant_specific_packet_notify(IN struct btc_coexist$/;"	f
-ex_halbtc8821aCsr2ant_specific_packet_notify	hal/btc/HalBtc8821aCsr2Ant.h	180;"	d
-ex_halbtc8821c1ant_antenna_detection	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_antenna_detection	hal/btc/halbtc8821c1ant.h	426;"	d
-ex_halbtc8821c1ant_antenna_isolation	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_antenna_isolation(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_antenna_isolation	hal/btc/halbtc8821c1ant.h	427;"	d
-ex_halbtc8821c1ant_bt_info_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_bt_info_notify	hal/btc/halbtc8821c1ant.h	419;"	d
-ex_halbtc8821c1ant_coex_dm_reset	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_coex_dm_reset	hal/btc/halbtc8821c1ant.h	423;"	d
-ex_halbtc8821c1ant_connect_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_connect_notify	hal/btc/halbtc8821c1ant.h	416;"	d
-ex_halbtc8821c1ant_display_ant_detection	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_display_ant_detection(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_display_ant_detection	hal/btc/halbtc8821c1ant.h	429;"	d
-ex_halbtc8821c1ant_display_coex_info	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_display_coex_info	hal/btc/halbtc8821c1ant.h	425;"	d
-ex_halbtc8821c1ant_halt_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_halt_notify	hal/btc/halbtc8821c1ant.h	421;"	d
-ex_halbtc8821c1ant_init_coex_dm	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_init_coex_dm	hal/btc/halbtc8821c1ant.h	411;"	d
-ex_halbtc8821c1ant_init_hw_config	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_init_hw_config	hal/btc/halbtc8821c1ant.h	410;"	d
-ex_halbtc8821c1ant_ips_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821c1ant_ips_notify	hal/btc/halbtc8821c1ant.h	412;"	d
-ex_halbtc8821c1ant_lps_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821c1ant_lps_notify	hal/btc/halbtc8821c1ant.h	413;"	d
-ex_halbtc8821c1ant_media_status_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_media_status_notify	hal/btc/halbtc8821c1ant.h	417;"	d
-ex_halbtc8821c1ant_periodical	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_periodical	hal/btc/halbtc8821c1ant.h	424;"	d
-ex_halbtc8821c1ant_pnp_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_pnp_notify	hal/btc/halbtc8821c1ant.h	422;"	d
-ex_halbtc8821c1ant_power_on_setting	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_power_on_setting	hal/btc/halbtc8821c1ant.h	408;"	d
-ex_halbtc8821c1ant_pre_load_firmware	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c1ant_pre_load_firmware	hal/btc/halbtc8821c1ant.h	409;"	d
-ex_halbtc8821c1ant_psd_scan	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_psd_scan(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_psd_scan	hal/btc/halbtc8821c1ant.h	428;"	d
-ex_halbtc8821c1ant_rf_status_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_rf_status_notify	hal/btc/halbtc8821c1ant.h	420;"	d
-ex_halbtc8821c1ant_scan_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_scan_notify	hal/btc/halbtc8821c1ant.h	414;"	d
-ex_halbtc8821c1ant_specific_packet_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_specific_packet_notify	hal/btc/halbtc8821c1ant.h	418;"	d
-ex_halbtc8821c1ant_switchband_notify	hal/btc/halbtc8821c1ant.c	/^void ex_halbtc8821c1ant_switchband_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c1ant_switchband_notify	hal/btc/halbtc8821c1ant.h	415;"	d
-ex_halbtc8821c2ant_antenna_detection	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_antenna_detection	hal/btc/halbtc8821c2ant.h	430;"	d
-ex_halbtc8821c2ant_bt_info_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_bt_info_notify	hal/btc/halbtc8821c2ant.h	423;"	d
-ex_halbtc8821c2ant_connect_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_connect_notify	hal/btc/halbtc8821c2ant.h	420;"	d
-ex_halbtc8821c2ant_display_ant_detection	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_display_ant_detection(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c2ant_display_ant_detection	hal/btc/halbtc8821c2ant.h	429;"	d
-ex_halbtc8821c2ant_display_coex_info	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c2ant_display_coex_info	hal/btc/halbtc8821c2ant.h	428;"	d
-ex_halbtc8821c2ant_halt_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c2ant_halt_notify	hal/btc/halbtc8821c2ant.h	425;"	d
-ex_halbtc8821c2ant_init_coex_dm	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c2ant_init_coex_dm	hal/btc/halbtc8821c2ant.h	415;"	d
-ex_halbtc8821c2ant_init_hw_config	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_init_hw_config	hal/btc/halbtc8821c2ant.h	414;"	d
-ex_halbtc8821c2ant_ips_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821c2ant_ips_notify	hal/btc/halbtc8821c2ant.h	416;"	d
-ex_halbtc8821c2ant_lps_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8821c2ant_lps_notify	hal/btc/halbtc8821c2ant.h	417;"	d
-ex_halbtc8821c2ant_media_status_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_media_status_notify	hal/btc/halbtc8821c2ant.h	421;"	d
-ex_halbtc8821c2ant_periodical	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c2ant_periodical	hal/btc/halbtc8821c2ant.h	427;"	d
-ex_halbtc8821c2ant_pnp_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_pnp_notify	hal/btc/halbtc8821c2ant.h	426;"	d
-ex_halbtc8821c2ant_power_on_setting	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c2ant_power_on_setting	hal/btc/halbtc8821c2ant.h	412;"	d
-ex_halbtc8821c2ant_pre_load_firmware	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8821c2ant_pre_load_firmware	hal/btc/halbtc8821c2ant.h	413;"	d
-ex_halbtc8821c2ant_rf_status_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_rf_status_notify	hal/btc/halbtc8821c2ant.h	424;"	d
-ex_halbtc8821c2ant_scan_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_scan_notify	hal/btc/halbtc8821c2ant.h	418;"	d
-ex_halbtc8821c2ant_specific_packet_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_specific_packet_notify	hal/btc/halbtc8821c2ant.h	422;"	d
-ex_halbtc8821c2ant_switchband_notify	hal/btc/halbtc8821c2ant.c	/^void ex_halbtc8821c2ant_switchband_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8821c2ant_switchband_notify	hal/btc/halbtc8821c2ant.h	419;"	d
-ex_halbtc8822b1ant_ScoreBoardStatusNotify	hal/btc/HalBtc8822b1Ant.h	397;"	d
-ex_halbtc8822b1ant_antenna_detection	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_antenna_detection	hal/btc/HalBtc8822b1Ant.h	401;"	d
-ex_halbtc8822b1ant_antenna_isolation	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_antenna_isolation(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_antenna_isolation	hal/btc/HalBtc8822b1Ant.h	402;"	d
-ex_halbtc8822b1ant_bt_info_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_bt_info_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_bt_info_notify	hal/btc/HalBtc8822b1Ant.h	393;"	d
-ex_halbtc8822b1ant_coex_dm_reset	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_coex_dm_reset(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_coex_dm_reset	hal/btc/HalBtc8822b1Ant.h	398;"	d
-ex_halbtc8822b1ant_connect_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_connect_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_connect_notify	hal/btc/HalBtc8822b1Ant.h	390;"	d
-ex_halbtc8822b1ant_dbg_control	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_dbg_control(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_dbg_control	hal/btc/HalBtc8822b1Ant.h	405;"	d
-ex_halbtc8822b1ant_display_ant_detection	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_display_ant_detection(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_display_ant_detection	hal/btc/HalBtc8822b1Ant.h	404;"	d
-ex_halbtc8822b1ant_display_coex_info	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_display_coex_info(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_display_coex_info	hal/btc/HalBtc8822b1Ant.h	400;"	d
-ex_halbtc8822b1ant_halt_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_halt_notify(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_halt_notify	hal/btc/HalBtc8822b1Ant.h	395;"	d
-ex_halbtc8822b1ant_init_coex_dm	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_init_coex_dm	hal/btc/HalBtc8822b1Ant.h	385;"	d
-ex_halbtc8822b1ant_init_hw_config	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_init_hw_config	hal/btc/HalBtc8822b1Ant.h	384;"	d
-ex_halbtc8822b1ant_ips_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_ips_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8822b1ant_ips_notify	hal/btc/HalBtc8822b1Ant.h	386;"	d
-ex_halbtc8822b1ant_lps_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_lps_notify(IN struct btc_coexist *btcoexist, IN u8 type)$/;"	f
-ex_halbtc8822b1ant_lps_notify	hal/btc/HalBtc8822b1Ant.h	387;"	d
-ex_halbtc8822b1ant_media_status_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_media_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_media_status_notify	hal/btc/HalBtc8822b1Ant.h	391;"	d
-ex_halbtc8822b1ant_periodical	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_periodical(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_periodical	hal/btc/HalBtc8822b1Ant.h	399;"	d
-ex_halbtc8822b1ant_pnp_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_pnp_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_pnp_notify	hal/btc/HalBtc8822b1Ant.h	396;"	d
-ex_halbtc8822b1ant_power_on_setting	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_power_on_setting(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_power_on_setting	hal/btc/HalBtc8822b1Ant.h	382;"	d
-ex_halbtc8822b1ant_pre_load_firmware	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_pre_load_firmware(IN struct btc_coexist *btcoexist)$/;"	f
-ex_halbtc8822b1ant_pre_load_firmware	hal/btc/HalBtc8822b1Ant.h	383;"	d
-ex_halbtc8822b1ant_psd_scan	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_psd_scan(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_psd_scan	hal/btc/HalBtc8822b1Ant.h	403;"	d
-ex_halbtc8822b1ant_rf_status_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_rf_status_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_rf_status_notify	hal/btc/HalBtc8822b1Ant.h	394;"	d
-ex_halbtc8822b1ant_scan_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_scan_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_scan_notify	hal/btc/HalBtc8822b1Ant.h	388;"	d
-ex_halbtc8822b1ant_specific_packet_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_specific_packet_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_specific_packet_notify	hal/btc/HalBtc8822b1Ant.h	392;"	d
-ex_halbtc8822b1ant_switchband_notify	hal/btc/HalBtc8822b1Ant.c	/^void ex_halbtc8822b1ant_switchband_notify(IN struct btc_coexist *btcoexist,$/;"	f
-ex_halbtc8822b1ant_switchband_notify	hal/btc/HalBtc8822b1Ant.h	389;"	d
-excl_chs	include/drv_types.h	/^	u8	excl_chs[MAX_CHANNEL_NUM];$/;"	m	struct:registry_priv
-expire_timeout_chk	core/rtw_ap.c	/^void	expire_timeout_chk(_adapter *padapter)$/;"	f
-expire_to	include/sta_info.h	/^	unsigned int expire_to; \/* sec , time to expire after associated. *\/$/;"	m	struct:sta_priv
-expire_to	include/sta_info.h	/^	unsigned int expire_to;$/;"	m	struct:sta_info
-ext_ant_switch_ctrl_polarity	hal/btc/HalBtc8822b1Ant.h	/^	u8			ext_ant_switch_ctrl_polarity;		\/*  iF 0: ANTSW(rfe_sel9)=0, ANTSWB(rfe_sel8)=1 =>  Ant to BT\/5G *\/$/;"	m	struct:rfe_type_8822b_1ant
-ext_ant_switch_ctrl_polarity	hal/btc/halbtc8821c1ant.h	/^	u8			ext_ant_switch_ctrl_polarity;		\/*  iF 0: DPDT_P=0, DPDT_N=1 => BTG to Main, WL_A+G to Aux *\/$/;"	m	struct:rfe_type_8821c_1ant
-ext_ant_switch_ctrl_polarity	hal/btc/halbtc8821c2ant.h	/^	u8			ext_ant_switch_ctrl_polarity;		\/*  iF 0: DPDT_P=0, DPDT_N=1 => BTG to Main, WL_A+G to Aux *\/$/;"	m	struct:rfe_type_8821c_2ant
-ext_ant_switch_diversity	hal/btc/halbtc8821c1ant.h	/^	boolean		ext_ant_switch_diversity;		\/* If diversity on  *\/$/;"	m	struct:rfe_type_8821c_1ant
-ext_ant_switch_diversity	hal/btc/halbtc8821c2ant.h	/^	boolean		ext_ant_switch_diversity;		\/* If diversity on  *\/$/;"	m	struct:rfe_type_8821c_2ant
-ext_ant_switch_exist	hal/btc/HalBtc8822b1Ant.h	/^	boolean		ext_ant_switch_exist;$/;"	m	struct:rfe_type_8822b_1ant
-ext_ant_switch_exist	hal/btc/halbtc8821c1ant.h	/^	boolean		ext_ant_switch_exist;$/;"	m	struct:rfe_type_8821c_1ant
-ext_ant_switch_exist	hal/btc/halbtc8821c2ant.h	/^	boolean		ext_ant_switch_exist;$/;"	m	struct:rfe_type_8821c_2ant
-ext_ant_switch_type	hal/btc/HalBtc8822b1Ant.h	/^	u8			ext_ant_switch_type;	$/;"	m	struct:rfe_type_8822b_1ant
-ext_ant_switch_type	hal/btc/halbtc8821c1ant.h	/^	u8			ext_ant_switch_type;			\/* 0:DPDT, 1:SPDT *\/$/;"	m	struct:rfe_type_8821c_1ant
-ext_ant_switch_type	hal/btc/halbtc8821c2ant.h	/^	u8			ext_ant_switch_type;			\/* 0:DPDT, 1:SPDT *\/$/;"	m	struct:rfe_type_8821c_2ant
-ext_band_switch_ctrl_polarity	hal/btc/halbtc8821c1ant.h	/^	u8			ext_band_switch_ctrl_polarity;$/;"	m	struct:rfe_type_8821c_1ant
-ext_band_switch_ctrl_polarity	hal/btc/halbtc8821c2ant.h	/^	u8			ext_band_switch_ctrl_polarity;$/;"	m	struct:rfe_type_8821c_2ant
-ext_band_switch_exist	hal/btc/halbtc8821c1ant.h	/^	boolean		ext_band_switch_exist;$/;"	m	struct:rfe_type_8821c_1ant
-ext_band_switch_exist	hal/btc/halbtc8821c2ant.h	/^	boolean		ext_band_switch_exist;$/;"	m	struct:rfe_type_8821c_2ant
-ext_band_switch_type	hal/btc/halbtc8821c1ant.h	/^	u8			ext_band_switch_type;			\/* 0:DPDT, 1:SPDT *\/$/;"	m	struct:rfe_type_8821c_1ant
-ext_band_switch_type	hal/btc/halbtc8821c2ant.h	/^	u8			ext_band_switch_type;			\/* 0:DPDT, 1:SPDT *\/$/;"	m	struct:rfe_type_8821c_2ant
-ext_capab_ie_data	include/rtw_mlme.h	/^	u8 ext_capab_ie_data[8];\/*currently for ap mode only*\/$/;"	m	struct:mlme_priv
-ext_capab_ie_len	include/rtw_mlme.h	/^	u8 ext_capab_ie_len;$/;"	m	struct:mlme_priv
-ext_listen_interval	include/rtw_mlme.h	/^	u16						ext_listen_interval;	\/*	The interval to be available with legacy AP (ms) *\/$/;"	m	struct:wifidirect_info
-ext_listen_period	include/rtw_mlme.h	/^	u16						ext_listen_period;	\/*	The time period to be available for P2P listen state (ms) *\/$/;"	m	struct:wifidirect_info
-ext_supp_rates	include/ieee80211.h	/^	u8 *ext_supp_rates;$/;"	m	struct:rtw_ieee802_11_elems
-ext_supp_rates_len	include/ieee80211.h	/^	u8 ext_supp_rates_len;$/;"	m	struct:rtw_ieee802_11_elems
-ext_tag	include/rtw_xmit.h	/^	u8 ext_tag; \/* 0:data, 1:mgmt *\/$/;"	m	struct:xmit_frame
-extendId	include/rtw_bt_mp.h	/^	u1Byte	extendId;$/;"	m	struct:_BT_EXT_C2H
-extended_ht_cap_info	include/wifi.h	/^	unsigned short	extended_ht_cap_info;$/;"	m	struct:rtw_ieee80211_ht_cap
-external_uuid	include/rtw_mlme.h	/^	u8						external_uuid;				\/* UUID flag *\/$/;"	m	struct:wifidirect_info
-extra_postfix_len	include/rtw_wapi.h	/^	int extra_postfix_len;$/;"	m	struct:_RT_WAPI_T
-extra_prefix_len	include/rtw_wapi.h	/^	int extra_prefix_len;$/;"	m	struct:_RT_WAPI_T
-fab_msk	include/HalPwrSeqCmd.h	/^	u8 fab_msk:4;$/;"	m	struct:_WL_PWR_CFG_
-faddr	include/ip.h	/^	__u32		faddr;				\/* Saved first hop address *\/$/;"	m	struct:ip_options
-faggr	include/rtl8188e_recv.h	/^	u32 faggr:1;$/;"	m	struct:rxreport_8188e
-fakeBTEfuseContent	core/efuse/rtw_efuse.c	/^u8	fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];$/;"	v
-fakeBTEfuseContent	include/rtw_efuse.h	/^	u8	fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];$/;"	m	struct:_EFUSE_HAL
-fakeBTEfuseInitMap	core/efuse/rtw_efuse.c	/^u8	fakeBTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN] = {0};$/;"	v
-fakeBTEfuseInitMap	include/rtw_efuse.h	/^	u8	fakeBTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN];$/;"	m	struct:_EFUSE_HAL
-fakeBTEfuseModifiedMap	core/efuse/rtw_efuse.c	/^u8	fakeBTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN] = {0};$/;"	v
-fakeBTEfuseModifiedMap	include/rtw_efuse.h	/^	u8	fakeBTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN];$/;"	m	struct:_EFUSE_HAL
-fakeBTEfuseUsedBytes	core/efuse/rtw_efuse.c	/^u32	fakeBTEfuseUsedBytes = {0};$/;"	v
-fakeBTEfuseUsedBytes	include/rtw_efuse.h	/^	u16	fakeBTEfuseUsedBytes;$/;"	m	struct:_EFUSE_HAL
-fakeEfuseBank	core/efuse/rtw_efuse.c	/^u8	fakeEfuseBank = {0};$/;"	v
-fakeEfuseBank	include/rtw_efuse.h	/^	u8	fakeEfuseBank;$/;"	m	struct:_EFUSE_HAL
-fakeEfuseContent	core/efuse/rtw_efuse.c	/^u8	fakeEfuseContent[EFUSE_MAX_HW_SIZE] = {0};$/;"	v
-fakeEfuseContent	include/rtw_efuse.h	/^	u8	fakeEfuseContent[EFUSE_MAX_HW_SIZE];$/;"	m	struct:_EFUSE_HAL
-fakeEfuseInitMap	core/efuse/rtw_efuse.c	/^u8	fakeEfuseInitMap[EFUSE_MAX_MAP_LEN] = {0};$/;"	v
-fakeEfuseInitMap	include/rtw_efuse.h	/^	u8	fakeEfuseInitMap[EFUSE_MAX_MAP_LEN];$/;"	m	struct:_EFUSE_HAL
-fakeEfuseModifiedMap	core/efuse/rtw_efuse.c	/^u8	fakeEfuseModifiedMap[EFUSE_MAX_MAP_LEN] = {0};$/;"	v
-fakeEfuseModifiedMap	include/rtw_efuse.h	/^	u8	fakeEfuseModifiedMap[EFUSE_MAX_MAP_LEN];$/;"	m	struct:_EFUSE_HAL
-fakeEfuseUsedBytes	core/efuse/rtw_efuse.c	/^u32	fakeEfuseUsedBytes = {0};$/;"	v
-fakeEfuseUsedBytes	include/rtw_efuse.h	/^	u32	fakeEfuseUsedBytes;$/;"	m	struct:_EFUSE_HAL
-fake_adapter	hal/phydm/phydm.h	/^	ADAPTER			fake_adapter;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-fake_priv	hal/phydm/phydm.h	/^	rtl8192cd_priv		fake_priv;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-fast_scan_iterations	include/rtw_pwrctrl.h	/^	u32	fast_scan_iterations;			\/* Fast scan iterations *\/$/;"	m	struct:pno_nlo_info
-fast_scan_period	include/rtw_pwrctrl.h	/^	u32 fast_scan_period;				\/* Fast scan period *\/$/;"	m	struct:pno_nlo_info
-fast_training_beam_num	hal/phydm/phydm_antdiv.h	/^	u4Byte	fast_training_beam_num;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-fat_comb_a	hal/phydm/phydm.h	/^	u1Byte			fat_comb_a;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-fat_comb_b	hal/phydm/phydm.h	/^	u1Byte			fat_comb_b;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-fclone	include/osdep_service_bsd.h	/^				fclone:2,$/;"	m	struct:sk_buff
-feedback_type	include/rtw_beamforming.h	/^	u16	feedback_type:1;$/;"	m	struct:rtw_ndpa_sta_info
-ff_hwaddr	include/rtw_recv.h	/^	uint	ff_hwaddr;$/;"	m	struct:recv_priv
-ff_hwaddr	include/rtw_xmit.h	/^	u32	ff_hwaddr;$/;"	m	struct:xmit_buf
-ff_hwaddr	include/rtw_xmit.h	/^	u32 ff_hwaddr;$/;"	m	struct:xmit_buf
-ff_hwaddr	include/rtw_xmit.h	/^	uint	ff_hwaddr;$/;"	m	struct:hw_txqueue
-ffaddr2deviceId	include/hal_gspi.h	23;"	d
-ffaddr2deviceId	include/hal_sdio.h	23;"	d
-fh_params	include/ieee80211.h	/^	u8 *fh_params;$/;"	m	struct:rtw_ieee802_11_elems
-fh_params_len	include/ieee80211.h	/^	u8 fh_params_len;$/;"	m	struct:rtw_ieee802_11_elems
-file	core/rtw_br_ext.c	/^	u_int8_t file[128];$/;"	m	struct:dhcpMessage	file:
-file_inode	os_dep/linux/rtw_proc.c	41;"	d	file:
-fill_default_txdesc	os_dep/linux/ioctl_linux.c	11775;"	d	file:
-fill_default_txdesc	os_dep/linux/ioctl_linux.c	11782;"	d	file:
-fill_default_txdesc	os_dep/linux/ioctl_linux.c	11789;"	d	file:
-fill_default_txdesc	os_dep/linux/ioctl_linux.c	11796;"	d	file:
-fill_default_txdesc	os_dep/linux/ioctl_linux.c	11804;"	d	file:
-fill_fake_txdesc	include/hal_intf.h	/^	void (*fill_fake_txdesc)(PADAPTER, u8 *pDesc, u32 BufferLen,$/;"	m	struct:hal_ops
-fill_h2c_cmd	include/hal_intf.h	/^	s32(*fill_h2c_cmd)(PADAPTER, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);$/;"	m	struct:hal_ops
-fill_radiotap_hdr	core/rtw_recv.c	/^static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe, u8 *buf)$/;"	f	file:
-fill_tx_desc_8188e	core/rtw_mp.c	/^void fill_tx_desc_8188e(PADAPTER padapter)$/;"	f
-fill_tx_desc_8188f	core/rtw_mp.c	/^void fill_tx_desc_8188f(PADAPTER padapter)$/;"	f
-fill_tx_desc_8192e	core/rtw_mp.c	/^void fill_tx_desc_8192e(PADAPTER padapter)$/;"	f
-fill_tx_desc_8703b	core/rtw_mp.c	/^void fill_tx_desc_8703b(PADAPTER padapter)$/;"	f
-fill_tx_desc_8723b	core/rtw_mp.c	/^void fill_tx_desc_8723b(PADAPTER padapter)$/;"	f
-fill_tx_desc_8723d	core/rtw_mp.c	/^void fill_tx_desc_8723d(PADAPTER padapter)$/;"	f
-fill_tx_desc_8812a	core/rtw_mp.c	/^void fill_tx_desc_8812a(PADAPTER padapter)$/;"	f
-fill_tx_desc_8814a	core/rtw_mp.c	/^void fill_tx_desc_8814a(PADAPTER padapter)$/;"	f
-fill_txdesc_for_mp	core/rtw_mp.c	/^void fill_txdesc_for_mp(PADAPTER padapter, u8 *ptxdesc)$/;"	f
-fill_txdesc_force_bmc_camid	hal/rtl8723d/rtl8723d_hal_init.c	/^void fill_txdesc_force_bmc_camid(struct pkt_attrib *pattrib, u8 *ptxdesc)$/;"	f
-fill_txdesc_phy_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^static void fill_txdesc_phy_8723d(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc)$/;"	f	file:
-fill_txdesc_sectype	hal/rtl8723d/rtl8723d_hal_init.c	/^static u8 fill_txdesc_sectype(struct pkt_attrib *pattrib)$/;"	f	file:
-fill_txdesc_vcs_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^static void fill_txdesc_vcs_8723d(PADAPTER padapter, struct pkt_attrib *pattrib, u8 *ptxdesc)$/;"	f	file:
-final_data_rate	include/rtl8188e_xmit.h	/^	u8 final_data_rate;$/;"	m	struct:txrpt_ccx_88e
-final_data_rate	include/rtl8192e_xmit.h	/^	u8 final_data_rate;$/;"	m	struct:txrpt_ccx_92e
-final_data_rate	include/rtl8821a_xmit.h	/^	u32 final_data_rate:8;$/;"	m	struct:txdescriptor_8821a
-find_phase_handler	core/rtw_p2p.c	/^void find_phase_handler(_adapter	*padapter)$/;"	f
-find_phase_state_exchange_cnt	include/rtw_mlme.h	/^	u8						find_phase_state_exchange_cnt;$/;"	m	struct:wifidirect_info
-find_phase_timer	include/rtw_mlme.h	/^	_timer					find_phase_timer;$/;"	m	struct:wifidirect_info
-find_phase_timer_process	core/rtw_p2p.c	/^static void find_phase_timer_process(void *FunctionContext)$/;"	f	file:
-fire_write_MAC_cmd	core/rtw_wlan_util.c	/^void fire_write_MAC_cmd(_adapter *padapter, unsigned int addr, unsigned int value)$/;"	f
-first_frag_time	include/ieee80211.h	/^	u32 first_frag_time;$/;"	m	struct:ieee80211_frag_entry
-first_mu_bfee_index	include/rtw_beamforming.h	/^	u8			first_mu_bfee_index;$/;"	m	struct:beamforming_info
-first_train_ant	hal/phydm/phydm_antdiv.h	/^	u4Byte	first_train_ant; \/*decide witch antenna to train first*\/$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-firstconnect	hal/phydm/phydm_rainfo.h	/^	u1Byte		firstconnect;$/;"	m	struct:_Rate_Adaptive_Table_
-fix_ant_bfee	hal/phydm/phydm_antdiv.h	/^	BOOLEAN	fix_ant_bfee;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-fix_beam_pattern_codeword	hal/phydm/phydm_antdiv.h	/^	u4Byte	fix_beam_pattern_codeword;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-fix_beam_pattern_en	hal/phydm/phydm_antdiv.h	/^	u4Byte	fix_beam_pattern_en;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-fix_bw	include/drv_types.h	/^	u8 fix_bw;$/;"	m	struct:_ADAPTER
-fix_path_bfer	hal/phydm/phydm_pathdiv.h	/^	BOOLEAN	fix_path_bfer;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-fix_rate	include/drv_types.h	/^	u8 fix_rate;$/;"	m	struct:_ADAPTER
-fix_rx_ampdu_accept	include/drv_types.h	/^	u8 fix_rx_ampdu_accept;$/;"	m	struct:_ADAPTER
-fix_rx_ampdu_size	include/drv_types.h	/^	u8 fix_rx_ampdu_size; \/* 0~127, TODO:consider each sta and each TID *\/$/;"	m	struct:_ADAPTER
-fix_training_num_en	hal/phydm/phydm_antdiv.h	/^	u4Byte	fix_training_num_en;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-fixed	include/wlan_bssdef.h	/^	int	fixed;			\/* set to fixed when not to be removed as site-surveying *\/$/;"	m	struct:wlan_network
-fixed_chan	include/rtw_mlme_ext.h	/^	u8 fixed_chan;$/;"	m	struct:mlme_ext_priv
-flag	include/hal_data.h	/^	u8 flag;$/;"	m	struct:kfree_data_t
-flag_atmel_rc	include/sta_info.h	/^	u8 flag_atmel_rc;$/;"	m	struct:sta_info
-flags	core/rtw_br_ext.c	/^	u_int16_t flags;$/;"	m	struct:dhcpMessage	file:
-flags	include/drv_types.h	/^	u32		flags;$/;"	m	struct:specific_device_id
-flags	include/drv_types.h	/^	u32 flags;$/;"	m	struct:cam_ctl_t
-flags	include/ieee80211.h	/^			int flags;$/;"	m	struct:ieee_param::__anon73::__anon78
-flags	include/ieee80211.h	/^	int flags;$/;"	m	struct:sta_data
-flags	include/ieee80211.h	/^	u16 flags;$/;"	m	struct:ieee80211_security
-flags	include/ieee80211.h	/^	u32 flags;$/;"	m	struct:rtw_ieee80211_channel
-flags	include/linux/wireless.h	/^	__u16		flags;		\/* Optional params *\/$/;"	m	struct:iw_point
-flags	include/linux/wireless.h	/^	__u16 flags;$/;"	m	struct:compat_iw_point
-flags	include/rtw_xmit.h	/^	u16 flags;$/;"	m	struct:xmit_buf
-flags	include/sta_info.h	/^	int flags;$/;"	m	struct:sta_info
-flags	os_dep/linux/ioctl_cfg80211.h	/^	u8 flags;$/;"	m	struct:rtw_wdev_invit_info
-flags	os_dep/osdep_service.c	/^	enum mstat_f flags;$/;"	m	struct:mstat_sniff_rule	typeref:enum:mstat_sniff_rule::mstat_f	file:
-flush_all_cam_entry	core/rtw_wlan_util.c	/^void flush_all_cam_entry(_adapter *padapter)$/;"	f
-flush_signals_thread	include/osdep_service.h	/^__inline static void flush_signals_thread(void)$/;"	f
-for_each_ie	include/ieee80211.h	1857;"	d
-forbidden_slot	hal/btc/halbtc8723d1ant.h	/^	u8					forbidden_slot;$/;"	m	struct:coex_sta_8723d_1ant
-forbidden_slot	hal/btc/halbtc8723d2ant.h	/^	u8					forbidden_slot;$/;"	m	struct:coex_sta_8723d_2ant
-force_ant	include/drv_types.h	/^	u8 force_ant;\/* 0 normal,1 main,2 aux *\/$/;"	m	struct:registry_priv
-force_igi	include/drv_types.h	/^	u8 force_igi;\/* 0 normal *\/$/;"	m	struct:registry_priv
-force_igi_lb	include/drv_types.h	/^	u8 force_igi_lb;$/;"	m	struct:registry_priv
-force_lps_on	hal/btc/HalBtc8192e1Ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8192e_1ant
-force_lps_on	hal/btc/HalBtc8703b1Ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8703b_1ant
-force_lps_on	hal/btc/HalBtc8723b1Ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8723b_1ant
-force_lps_on	hal/btc/HalBtc8723b2Ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8723b_2ant
-force_lps_on	hal/btc/HalBtc8812a1Ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8812a_1ant
-force_lps_on	hal/btc/HalBtc8821a2Ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8821a_2ant
-force_lps_on	hal/btc/HalBtc8822b1Ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8822b_1ant
-force_lps_on	hal/btc/halbtc8723d1ant.h	/^	boolean				force_lps_on;$/;"	m	struct:coex_sta_8723d_1ant
-force_lps_on	hal/btc/halbtc8723d2ant.h	/^	boolean				force_lps_on;$/;"	m	struct:coex_sta_8723d_2ant
-force_lps_on	hal/btc/halbtc8821c1ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8821c_1ant
-force_lps_on	hal/btc/halbtc8821c2ant.h	/^	boolean					force_lps_on;$/;"	m	struct:coex_sta_8821c_2ant
-force_to_roam	hal/btc/HalBtcOutSrc.h	/^	boolean					force_to_roam;	\/* for 1Ant solution *\/$/;"	m	struct:btc_bt_info
-force_update_beam_en	hal/phydm/phydm_antdiv.h	/^	BOOLEAN	force_update_beam_en;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-frag	include/ieee80211.h	/^	int frag;$/;"	m	struct:tx_pending_t
-frag	include/rtl8188e_recv.h	/^	u32 frag:4;$/;"	m	struct:rxreport_8188e
-frag_len	include/rtw_xmit.h	/^	uint	frag_len;$/;"	m	struct:xmit_priv
-frag_num	include/ieee80211.h	/^	u16 frag_num;$/;"	m	struct:ieee_ibss_seq
-frag_num	include/rtw_recv.h	/^	u8	frag_num;$/;"	m	struct:rx_pkt_attrib
-frag_off	include/ip.h	/^	__u16	frag_off;$/;"	m	struct:iphdr
-frag_size	include/ieee80211.h	/^	u16 frag_size;$/;"	m	struct:ieee80211_txb
-frag_thresh	include/drv_types.h	/^	u16  frag_thresh;$/;"	m	struct:registry_priv
-fragcnt	include/rtw_mp.h	/^	uint fragcnt;$/;"	m	struct:mp_xmit_frame
-fragcnt	include/rtw_recv.h	/^	u8 fragcnt;$/;"	m	struct:recv_frame_hdr
-fragments	include/ieee80211.h	/^	struct sk_buff *fragments[0];$/;"	m	struct:ieee80211_txb	typeref:struct:ieee80211_txb::sk_buff
-frame_control	include/ieee80211_ext.h	/^	u16 frame_control;$/;"	m	struct:ieee80211_mgmt
-frame_control	include/wifi.h	/^	unsigned short frame_control;$/;"	m	struct:rtw_ieee80211_bar
-frame_ctl	include/ieee80211.h	/^	u16 frame_ctl;$/;"	m	struct:ieee80211_header_data
-frame_ctl	include/ieee80211.h	/^	u16 frame_ctl;$/;"	m	struct:rtw_ieee80211_hdr
-frame_ctl	include/ieee80211.h	/^	u16 frame_ctl;$/;"	m	struct:rtw_ieee80211_hdr_3addr
-frame_ctl	include/ieee80211.h	/^	u16 frame_ctl;$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos
-frame_ctl	include/ieee80211.h	/^	u16 frame_ctl;$/;"	m	struct:rtw_ieee80211_hdr_qos
-frame_tag	include/rtw_mp.h	/^	int frame_tag;$/;"	m	struct:mp_xmit_frame
-frame_tag	include/rtw_recv.h	/^	int frame_tag;$/;"	m	struct:recv_frame_hdr
-frame_tag	include/rtw_xmit.h	/^	int	frame_tag;$/;"	m	struct:xmit_frame
-freeLoopback	os_dep/linux/ioctl_linux.c	/^static void freeLoopback(PADAPTER padapter)$/;"	f	file:
-free_assoc_resources_hdl	core/rtw_cmd.c	/^void free_assoc_resources_hdl(_adapter *padapter)$/;"	f
-free_bss_buf	include/rtw_mlme.h	/^	u8		*free_bss_buf;$/;"	m	struct:mlme_priv
-free_bss_pool	include/rtw_mlme.h	/^	_queue	free_bss_pool;$/;"	m	struct:mlme_priv
-free_cmdsz	include/rtw_xmit.h	/^	volatile sint      free_cmdsz;$/;"	m	struct:hw_txqueue
-free_halmac_event	hal/hal_halmac.c	/^static void free_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id)$/;"	f	file:
-free_ioreqs	include/rtw_io.h	/^	_list	free_ioreqs;$/;"	m	struct:io_queue
-free_ioreqs_buf	include/rtw_io.h	/^	u8	*free_ioreqs_buf; \/* 4-byte aligned *\/$/;"	m	struct:io_queue
-free_mlme_ap_info	core/rtw_ap.c	/^void free_mlme_ap_info(_adapter *padapter)$/;"	f
-free_mlme_ext_priv	core/rtw_mlme_ext.c	/^void free_mlme_ext_priv(struct mlme_ext_priv *pmlmeext)$/;"	f
-free_mp_priv	core/rtw_mp.c	/^void free_mp_priv(struct mp_priv *pmp_priv)$/;"	f
-free_mp_xmitframe_cnt	include/rtw_mp.h	/^	u32 free_mp_xmitframe_cnt;$/;"	m	struct:mp_priv
-free_mp_xmitqueue	include/rtw_mp.h	/^	_queue free_mp_xmitqueue;$/;"	m	struct:mp_priv
-free_netdev	include/osdep_service_bsd.h	128;"	d
-free_recv_buf_queue	include/rtw_recv.h	/^	_queue	free_recv_buf_queue;$/;"	m	struct:recv_priv
-free_recv_buf_queue_cnt	include/rtw_recv.h	/^	u32	free_recv_buf_queue_cnt;$/;"	m	struct:recv_priv
-free_recv_priv	include/hal_intf.h	/^	void	(*free_recv_priv)(_adapter *padapter);$/;"	m	struct:hal_ops
-free_recv_queue	include/rtw_recv.h	/^	_queue	free_recv_queue;$/;"	m	struct:recv_priv
-free_recv_skb_queue	include/rtw_recv.h	/^	struct sk_buff_head free_recv_skb_queue;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::sk_buff_head
-free_recvframe_cnt	include/rtw_recv.h	/^	uint free_recvframe_cnt;$/;"	m	struct:recv_priv
-free_scanqueue	core/rtw_mlme.c	/^static void free_scanqueue(struct	mlme_priv *pmlmepriv)$/;"	f	file:
-free_sta_queue	include/sta_info.h	/^	_queue	free_sta_queue;$/;"	m	struct:sta_priv
-free_sz	include/rtw_xmit.h	/^	volatile sint 	free_sz;	\/* in units of 64 bytes *\/$/;"	m	struct:hw_txqueue
-free_tdls_sta	core/rtw_tdls.c	/^void free_tdls_sta(_adapter *padapter, struct sta_info *ptdls_sta)$/;"	f
-free_xframe_ext_cnt	include/rtw_xmit.h	/^	uint free_xframe_ext_cnt;$/;"	m	struct:xmit_priv
-free_xframe_ext_queue	include/rtw_xmit.h	/^	_queue free_xframe_ext_queue;$/;"	m	struct:xmit_priv
-free_xmit_extbuf_cnt	include/rtw_xmit.h	/^	uint free_xmit_extbuf_cnt;$/;"	m	struct:xmit_priv
-free_xmit_extbuf_queue	include/rtw_xmit.h	/^	_queue free_xmit_extbuf_queue;$/;"	m	struct:xmit_priv
-free_xmit_priv	include/hal_intf.h	/^	void	(*free_xmit_priv)(_adapter *padapter);$/;"	m	struct:hal_ops
-free_xmit_queue	include/rtw_xmit.h	/^	_queue	free_xmit_queue;$/;"	m	struct:xmit_priv
-free_xmitbuf_cnt	include/rtw_xmit.h	/^	uint free_xmitbuf_cnt;$/;"	m	struct:xmit_priv
-free_xmitbuf_queue	include/rtw_xmit.h	/^	_queue free_xmitbuf_queue;$/;"	m	struct:xmit_priv
-free_xmitframe_cnt	include/rtw_xmit.h	/^	uint free_xmitframe_cnt;$/;"	m	struct:xmit_priv
-freeloopbackpkt	os_dep/linux/ioctl_linux.c	/^static void freeloopbackpkt(PADAPTER padapter, struct xmit_frame *pframe)$/;"	f	file:
-freerecvbuf	hal/rtl8723d/sdio/rtl8723ds_recv.c	/^static void freerecvbuf(struct recv_buf *precvbuf)$/;"	f	file:
-freeze_coexrun_by_btinfo	hal/btc/halbtc8723d1ant.h	/^	boolean				freeze_coexrun_by_btinfo;$/;"	m	struct:coex_sta_8723d_1ant
-freeze_coexrun_by_btinfo	hal/btc/halbtc8723d2ant.h	/^	boolean				freeze_coexrun_by_btinfo;$/;"	m	struct:coex_sta_8723d_2ant
-freq	include/ieee80211.h	/^	u8 freq;$/;"	m	struct:ieee80211_rx_stats
-fs	include/rtl8188e_recv.h	/^	u32 fs:1;$/;"	m	struct:rxreport_8188e
-fs	include/rtl8188e_xmit.h	/^	u32 fs:1;$/;"	m	struct:txdesc_88e
-fs	include/rtl8192e_xmit.h	/^	u32 fs:1;$/;"	m	struct:txdescriptor_8192e
-fs	include/rtl8812a_xmit.h	/^	u32 fs:1;$/;"	m	struct:txdescriptor_8812
-ft_action	include/rtw_mlme.h	/^	u8	ft_action[RTW_MAX_FTIE_SZ];$/;"	m	struct:_ft_priv
-ft_action_len	include/rtw_mlme.h	/^	u16	ft_action_len;$/;"	m	struct:_ft_priv
-ft_cap	include/rtw_mlme.h	/^	u8	ft_cap;	\/*b0: FT over DS, b1: Resource Req Protocol Cap, b2~b7: Reserved*\/$/;"	m	struct:_ft_priv
-ft_event	include/rtw_mlme.h	/^	struct cfg80211_ft_event_params ft_event;$/;"	m	struct:_ft_priv	typeref:struct:_ft_priv::cfg80211_ft_event_params
-ft_flags	include/rtw_mlme.h	/^	u8	ft_flags;$/;"	m	struct:_ft_priv
-ft_link_timer	include/rtw_mlme_ext.h	/^	_timer		ft_link_timer;$/;"	m	struct:mlme_ext_priv
-ft_link_timer_hdl	core/rtw_mlme_ext.c	/^void ft_link_timer_hdl(_adapter *padapter)$/;"	f
-ft_pairwise_key_installed	include/sta_info.h	/^	u8 ft_pairwise_key_installed;$/;"	m	struct:sta_info
-ft_priv	include/rtw_mlme.h	/^} ft_priv;$/;"	t	typeref:struct:_ft_priv
-ft_req_retry_cnt	include/rtw_mlme.h	/^	u32 ft_req_retry_cnt;$/;"	m	struct:_ft_priv
-ft_roam_on_expired	include/rtw_mlme.h	/^	u8	ft_roam_on_expired;$/;"	m	struct:_ft_priv
-ft_roam_timer	include/rtw_mlme_ext.h	/^	_timer		ft_roam_timer;$/;"	m	struct:mlme_ext_priv
-ft_roam_timer_hdl	core/rtw_mlme_ext.c	/^void ft_roam_timer_hdl(_adapter *padapter)$/;"	f
-ft_status	include/rtw_mlme.h	/^	u32 ft_status;$/;"	m	struct:_ft_priv
-ftie	include/ieee80211.h	/^	u8 *ftie;$/;"	m	struct:rtw_ieee802_11_elems
-ftie_len	include/ieee80211.h	/^	u8 ftie_len;$/;"	m	struct:rtw_ieee802_11_elems
-ftpriv	include/rtw_mlme.h	/^	ft_priv ftpriv;$/;"	m	struct:mlme_priv
-full_ch_in_p2p_handshake	include/drv_types.h	/^	u8	full_ch_in_p2p_handshake; \/* 0: reply only softap channel, 1: reply full channel list*\/$/;"	m	struct:registry_priv
-func	include/drv_types_gspi.h	/^	struct spi_device *func;$/;"	m	struct:gspi_data	typeref:struct:gspi_data::spi_device
-func	include/drv_types_sdio.h	/^	struct sdio_func	*func;$/;"	m	struct:sdio_data	typeref:struct:sdio_data::sdio_func
-func	include/osdep_service_bsd.h	/^        work_func_t func;       $/;"	m	struct:work_struct
-func	include/rtw_cmd.h	/^	void (*func)(void *);$/;"	m	struct:RunInThread_param
-func	include/rtw_mlme_ext.h	/^	unsigned int (*func)(_adapter *padapter, union recv_frame *precv_frame);$/;"	m	struct:action_handler
-func	include/rtw_mlme_ext.h	/^	unsigned int (*func)(_adapter *padapter, union recv_frame *precv_frame);$/;"	m	struct:mlme_handler
-func_number	include/drv_types_gspi.h	/^	u8  func_number;$/;"	m	struct:gspi_data
-func_number	include/drv_types_sdio.h	/^	u8  func_number;$/;"	m	struct:sdio_data
-funcnumber	include/drv_types_pci.h	/^	u8	funcnumber;$/;"	m	struct:pci_priv
-function	include/osdep_service_bsd.h	/^        void (*function)(void*);$/;"	m	struct:timer_list
-fw_DebugComponents	hal/phydm/phydm.h	/^	u4Byte			fw_DebugComponents;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-fw_buff_is_enpty	hal/phydm/phydm.h	/^	BOOLEAN			fw_buff_is_enpty;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-fw_correct_bcn	include/hal_intf.h	/^	void (*fw_correct_bcn)(PADAPTER padapter);$/;"	m	struct:hal_ops
-fw_debug_trace	hal/phydm/phydm.h	/^	u1Byte			fw_debug_trace[60]; $/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-fw_dl	include/hal_intf.h	/^	s32(*fw_dl)(_adapter *adapter, u8 wowlan);$/;"	m	struct:hal_ops
-fw_img	include/drv_types.h	/^	NDIS_STRING fw_img;$/;"	m	struct:_ADAPTER
-fw_iol	include/drv_types.h	/^	u8 fw_iol; \/* enable iol without other concern *\/$/;"	m	struct:registry_priv
-fw_psmode_iface_id	include/rtw_pwrctrl.h	/^	u8 fw_psmode_iface_id;$/;"	m	struct:pwrctrl_priv
-fw_ractrl	include/hal_data.h	/^	u8	fw_ractrl;$/;"	m	struct:hal_com_data
-fw_state	include/rtw_mlme.h	/^	sint	fw_state;	\/* shall we protect this variable? maybe not necessarily... *\/$/;"	m	struct:mlme_priv
-fwdl_test_chksum_fail	core/rtw_debug.c	/^static u8 fwdl_test_chksum_fail = 0;$/;"	v	file:
-fwdl_test_wintint_rdy_fail	core/rtw_debug.c	/^static u8 fwdl_test_wintint_rdy_fail = 0;$/;"	v	file:
-fwevent	include/rtw_event.h	/^struct fwevent {$/;"	s
-gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_PCIE_8723D[]    = {0, 0, 1, 1, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_SDIO_8723D[]    = {0, 0, 1, 1, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GA_N_TxPowerTrack_USB_8723D[]    = {0, 0, 1, 1, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_PCIE_8723D[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_SDIO_8723D[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GA_P_TxPowerTrack_USB_8723D[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_PCIE_8723D[]    = {0, 0, 1, 1, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_SDIO_8723D[]    = {0, 0, 1, 1, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GB_N_TxPowerTrack_USB_8723D[]    = {0, 0, 1, 1, 1, 2, 2, 3, 4, 4, 4, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_PCIE_8723D[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_SDIO_8723D[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GB_P_TxPowerTrack_USB_8723D[]    = {0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_PCIE_8723D[] = {0, 1, 1, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_SDIO_8723D[] = {0, 1, 1, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKA_N_TxPowerTrack_USB_8723D[] = {0, 1, 1, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_PCIE_8723D[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_SDIO_8723D[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKA_P_TxPowerTrack_USB_8723D[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_PCIE_8723D[] = {0, 1, 1, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_SDIO_8723D[] = {0, 1, 1, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKB_N_TxPowerTrack_USB_8723D[] = {0, 1, 1, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_PCIE_8723D[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_SDIO_8723D[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_2GCCKB_P_TxPowerTrack_USB_8723D[] = {0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 9, 9, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11};$/;"	v
-gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_PCIE_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_SDIO_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GA_N_TxPowerTrack_USB_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_PCIE_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_SDIO_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GA_P_TxPowerTrack_USB_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_PCIE_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_SDIO_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GB_N_TxPowerTrack_USB_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_PCIE_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_PCIE_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_SDIO_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_SDIO_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_USB_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^u1Byte gDeltaSwingTableIdx_MP_5GB_P_TxPowerTrack_USB_8723D[][DELTA_SWINGIDX_SIZE] = {$/;"	v
-gDeltaSwingTableXtal_MP_N_TxXtalTrack_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^s1Byte gDeltaSwingTableXtal_MP_N_TxXtalTrack_8723D[]    = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};$/;"	v
-gDeltaSwingTableXtal_MP_P_TxXtalTrack_8723D	hal/phydm/rtl8723d/halhwimg8723d_rf.c	/^s1Byte gDeltaSwingTableXtal_MP_P_TxXtalTrack_8723D[]    = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -10, -12, -14, -16, -16, -16, -16, -16, -16, -16, -16, -16, -16, -16};$/;"	v
-g_id	include/rtl8821a_xmit.h	/^	u32 g_id:6;$/;"	m	struct:txdescriptor_8821a
-g_id	include/rtw_beamforming.h	/^	u16 g_id;$/;"	m	struct:beamformee_entry
-g_id	include/rtw_beamforming.h	/^	u16 g_id;$/;"	m	struct:beamformer_entry
-g_id	include/rtw_beamforming.h	/^	u16 g_id;$/;"	m	struct:beamforming_entry
-g_mode_rate_num	include/rtw_rf.h	29;"	d
-g_test_adapter	os_dep/linux/sdio_intf.c	/^PADAPTER g_test_adapter = NULL;$/;"	v
-g_wait_hiq_empty_ms	core/rtw_debug.c	/^static u32 g_wait_hiq_empty_ms = 0;$/;"	v	file:
-g_wifi_on	os_dep/linux/rtw_android.c	/^static int g_wifi_on = _TRUE;$/;"	v	file:
-g_wifidev_registered	os_dep/linux/rtw_android.c	/^static int g_wifidev_registered = 0;$/;"	v	file:
-gain	hal/phydm/phydm_hwconfig.h	/^		u1Byte	gain:7,trsw:1;			$/;"	m	struct:_Phy_Rx_AGC_Info
-gain	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gain: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-gain_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gain_a: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-gain_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gain_b: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-gain_c	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gain_c: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-gain_d	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gain_d: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-gain_trsw	hal/phydm/phydm_hwconfig.h	/^	u1Byte			gain_trsw[2];							\/*path-A and path-B {TRSW, gain[6:0] }*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-gain_trsw_cd	hal/phydm/phydm_hwconfig.h	/^	u1Byte			gain_trsw_cd[2];	   \/*DW5 byte 3 DW6 byte 0	path-C and path-D {TRSW, gain[6:0] }*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-gateway	os_dep/linux/os_intfs.c	/^	struct in_addr gateway;$/;"	m	struct:route_info	typeref:struct:route_info::in_addr	file:
-getIGIForDiff	hal/phydm/phydm_dig.c	/^getIGIForDiff(int value_IGI)$/;"	f
-getSwingIndex	hal/phydm/phydm_powertracking_ap.c	/^getSwingIndex($/;"	f
-getSwingIndex	hal/phydm/phydm_powertracking_ce.c	/^getSwingIndex($/;"	f
-getSwingIndex	hal/phydm/phydm_powertracking_win.c	/^getSwingIndex($/;"	f
-get_WLAN_BSSID_EX_sz	include/wlan_bssdef.h	/^__inline  static uint get_WLAN_BSSID_EX_sz(WLAN_BSSID_EX *bss)$/;"	f
-get_beacon_interval	core/rtw_wlan_util.c	/^u16 get_beacon_interval(WLAN_BSSID_EX *bss)$/;"	f
-get_bssid	include/rtw_mlme.h	/^__inline static u8 *get_bssid(struct mlme_priv *pmlmepriv)$/;"	f
-get_bsstype	core/rtw_wlan_util.c	/^int get_bsstype(unsigned short capability)$/;"	f
-get_bt_fw_ver_cnt	hal/btc/HalBtcOutSrc.h	/^	u32					get_bt_fw_ver_cnt;$/;"	m	struct:btc_bt_info
-get_channel_cnt_24g_5gl_5gh	core/rtw_mlme_ext.c	/^static void get_channel_cnt_24g_5gl_5gh(struct mlme_ext_priv *pmlmeext, u8 *p24g_cnt, u8 *p5gl_cnt, u8 *p5gh_cnt)$/;"	f	file:
-get_da	include/wifi.h	/^__inline static unsigned char *get_da(unsigned char *pframe)$/;"	f
-get_defaultgw	os_dep/linux/os_intfs.c	/^static int get_defaultgw(u32 *ip_addr , char mac[])$/;"	f	file:
-get_deviceid	hal/rtl8723d/sdio/sdio_ops.c	/^static u8 get_deviceid(u32 addr)$/;"	f	file:
-get_fwstate	include/rtw_mlme.h	/^__inline static sint get_fwstate(struct mlme_priv *pmlmepriv)$/;"	f
-get_hal_mac_addr	include/hal_data.h	754;"	d
-get_hdr_bssid	include/wifi.h	/^__inline static unsigned char *get_hdr_bssid(unsigned char *pframe)$/;"	f
-get_highest_mcs_rate	core/rtw_wlan_util.c	/^unsigned char get_highest_mcs_rate(struct HT_caps_element *pHT_caps)$/;"	f
-get_highest_rate_idx	core/rtw_wlan_util.c	/^unsigned char get_highest_rate_idx(u32 mask)$/;"	f
-get_hw_port	include/drv_types.h	465;"	d
-get_hw_port	include/drv_types.h	469;"	d
-get_int_from_command	os_dep/linux/rtw_android.c	/^int get_int_from_command(char *pcmd)$/;"	f
-get_list_head	include/osdep_service_bsd.h	/^__inline static _list	*get_list_head(_queue	*queue)$/;"	f
-get_list_head	include/osdep_service_ce.h	/^__inline static _list	*get_list_head(_queue	*queue)$/;"	f
-get_list_head	include/osdep_service_linux.h	/^__inline static _list	*get_list_head(_queue	*queue)$/;"	f
-get_list_head	include/osdep_service_xp.h	/^__inline static _list	*get_list_head(_queue	*queue)$/;"	f
-get_miracast_mode_str	core/rtw_mlme.c	/^const char *get_miracast_mode_str(int mode)$/;"	f
-get_my_bssid	core/rtw_wlan_util.c	/^__inline u8 *get_my_bssid(WLAN_BSSID_EX *pnetwork)$/;"	f
-get_next	include/osdep_service_bsd.h	/^__inline static _list *get_next(_list	*list)$/;"	f
-get_next	include/osdep_service_ce.h	/^__inline static _list *get_next(_list	*list)$/;"	f
-get_next	include/osdep_service_linux.h	/^__inline static _list *get_next(_list	*list)$/;"	f
-get_next	include/osdep_service_xp.h	/^__inline static _list *get_next(_list	*list)$/;"	f
-get_prev	include/osdep_service_ce.h	/^__inline static _list *get_prev(_list	*list)$/;"	f
-get_priv_size	os_dep/linux/ioctl_linux.c	/^static int get_priv_size(__u16 args)$/;"	f	file:
-get_proc_net	os_dep/linux/rtw_proc.c	50;"	d	file:
-get_proc_net	os_dep/linux/rtw_proc.c	52;"	d	file:
-get_ra	include/wifi.h	/^__inline static unsigned char *get_ra(unsigned char *pframe)$/;"	f
-get_rate_set	core/rtw_wlan_util.c	/^void get_rate_set(_adapter *padapter, unsigned char *pbssrate, int *bssrate_len)$/;"	f
-get_recvframe_data	include/rtw_recv.h	/^__inline static u8 *get_recvframe_data(union recv_frame *precvframe)$/;"	f
-get_recvframe_len	include/rtw_recv.h	/^__inline static sint get_recvframe_len(union recv_frame *precvframe)$/;"	f
-get_reg_classes_full_count	core/rtw_mlme_ext.c	/^static int get_reg_classes_full_count(struct p2p_channels channel_list)$/;"	f	file:
-get_reg_classes_full_count	hal/hal_com.c	/^static int get_reg_classes_full_count(struct p2p_channels channel_list)$/;"	f	file:
-get_rtw_drv_proc	os_dep/linux/rtw_proc.c	/^inline struct proc_dir_entry *get_rtw_drv_proc(void)$/;"	f
-get_rtw_drv_proc	os_dep/linux/rtw_proc.h	56;"	d
-get_rx_status	include/rtw_recv.h	/^__inline static u8 *get_rx_status(union recv_frame *precvframe)$/;"	f
-get_rxbuf_desc	include/rtw_recv.h	/^__inline static _buffer *get_rxbuf_desc(union recv_frame *precvframe)$/;"	f
-get_rxmem	include/rtw_recv.h	/^__inline static u8 *get_rxmem(union recv_frame *precvframe)$/;"	f
-get_sa	include/wifi.h	/^__inline static unsigned char *get_sa(unsigned char *pframe)$/;"	f
-get_ta	include/wifi.h	/^__inline static unsigned char *get_ta(unsigned char *pframe)$/;"	f
-get_tofr_ds	include/wifi.h	297;"	d
-get_tx_power_index_handler	include/hal_intf.h	/^	u8(*get_tx_power_index_handler)(_adapter *padapter, u8 rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);$/;"	m	struct:hal_ops
-get_tx_power_level_handler	include/hal_intf.h	/^	void	(*get_tx_power_level_handler)(_adapter *padapter, s32 *powerlevel);$/;"	m	struct:hal_ops
-get_vlan_encap_proto	include/if_ether.h	108;"	d
-get_vlan_id	include/if_ether.h	106;"	d
-get_vlan_priority	include/if_ether.h	107;"	d
-getbasicrate_parm	include/rtw_cmd.h	/^struct getbasicrate_parm {$/;"	s
-getbasicrate_rsp	include/rtw_cmd.h	/^struct getbasicrate_rsp {$/;"	s
-getbcnerrcnt_parm	include/rtw_cmd.h	/^struct getbcnerrcnt_parm {$/;"	s
-getbcnerrcnt_rsp	include/rtw_cmd.h	/^struct getbcnerrcnt_rsp {$/;"	s
-getbcnokcnt_parm	include/rtw_cmd.h	/^struct getbcnokcnt_parm {$/;"	s
-getbcnokcnt_rsp	include/rtw_cmd.h	/^struct getbcnokcnt_rsp {$/;"	s
-getcountjudge_parm	include/rtw_cmd.h	/^struct	getcountjudge_parm {$/;"	s
-getcountjudge_rsp	include/rtw_cmd.h	/^struct	getcountjudge_rsp {$/;"	s
-getcrc32	core/rtw_security.c	/^static u32 getcrc32(u8 *buf, sint len)$/;"	f	file:
-getcurtxpwrlevel_parm	include/rtw_cmd.h	/^struct getcurtxpwrlevel_parm {$/;"	s
-getcurtxpwrlevel_rsp	include/rtw_cmd.h	/^struct getcurtxpwrlevel_rsp {$/;"	s
-getdatarate_parm	include/rtw_cmd.h	/^struct getdatarate_parm {$/;"	s
-getdatarate_rsp	include/rtw_cmd.h	/^struct getdatarate_rsp {$/;"	s
-geth2clbk_parm	include/rtw_cmd.h	/^struct geth2clbk_parm {$/;"	s
-geth2clbk_rsp	include/rtw_cmd.h	/^struct geth2clbk_rsp {$/;"	s
-getphy_parm	include/rtw_cmd.h	/^struct	getphy_parm {$/;"	s
-getphy_rsp	include/rtw_cmd.h	/^struct	getphy_rsp {$/;"	s
-getphyinfo_parm	include/rtw_cmd.h	/^struct	getphyinfo_parm {$/;"	s
-getphyinfo_rsp	include/rtw_cmd.h	/^struct	getphyinfo_rsp {$/;"	s
-getratable_parm	include/rtw_cmd.h	/^struct getratable_parm {$/;"	s
-getratable_rsp	include/rtw_cmd.h	/^struct getratable_rsp {$/;"	s
-getrfintfs_parm	include/rtw_cmd.h	/^struct getrfintfs_parm {$/;"	s
-getrxretrycnt_parm	include/rtw_cmd.h	/^struct getrxretrycnt_parm {$/;"	s
-getrxretrycnt_rsp	include/rtw_cmd.h	/^struct getrxretrycnt_rsp {$/;"	s
-getssdlevel_parm	include/rtw_cmd.h	/^struct getssdlevel_parm	{$/;"	s
-getssdlevel_rsp	include/rtw_cmd.h	/^struct getssdlevel_rsp	{$/;"	s
-getssulevel_parm	include/rtw_cmd.h	/^struct getssulevel_parm	{$/;"	s
-getssulevel_rsp	include/rtw_cmd.h	/^struct getssulevel_rsp	{$/;"	s
-getssup_parm	include/rtw_cmd.h	/^struct getssup_parm	{$/;"	s
-getssup_rsp	include/rtw_cmd.h	/^struct getssup_rsp	{$/;"	s
-gettxagctbl_parm	include/rtw_cmd.h	/^struct gettxagctbl_parm {$/;"	s
-gettxagctbl_rsp	include/rtw_cmd.h	/^struct gettxagctbl_rsp {$/;"	s
-gettxretrycnt_parm	include/rtw_cmd.h	/^struct gettxretrycnt_parm {$/;"	s
-gettxretrycnt_rsp	include/rtw_cmd.h	/^struct gettxretrycnt_rsp {$/;"	s
-gf	include/rtl8188e_recv.h	/^	u32 gf:1;$/;"	m	struct:rxreport_8188e
-gf	include/rtl8188e_xmit.h	/^	u32 gf:1;$/;"	m	struct:txdesc_88e
-gf	include/rtl8192e_xmit.h	/^	u32 gf:1;$/;"	m	struct:txdescriptor_8192e
-gf	include/rtl8812a_xmit.h	/^	u32 gf:1;$/;"	m	struct:txdescriptor_8812
-gf	include/rtl8821a_xmit.h	/^	u32 gf:1;$/;"	m	struct:txdescriptor_8821a
-gf_mulx	core/rtw_security.c	/^static void gf_mulx(u8 *pad)$/;"	f	file:
-gfp_t	include/osdep_service_bsd.h	/^typedef unsigned gfp_t;$/;"	t
-giaddr	core/rtw_br_ext.c	/^	u_int32_t giaddr;$/;"	m	struct:dhcpMessage	file:
-gid	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gid: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-gid_valid	hal/phydm/phydm_beamforming.h	/^	u1Byte				gid_valid[8];$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-gid_valid	hal/phydm/phydm_beamforming.h	/^	u1Byte	gid_valid[8];$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-gid_valid	include/rtw_beamforming.h	/^	u8 gid_valid[8];$/;"	m	struct:beamformee_entry
-gid_valid	include/rtw_beamforming.h	/^	u8 gid_valid[8];$/;"	m	struct:beamformer_entry
-gl_btc_trace_buf	hal/hal_btcoex.c	/^u1Byte	gl_btc_trace_buf[BT_TMP_BUF_SIZE];$/;"	v
-gl_coex_offload	hal/hal_btcoex.c	/^BTC_OFFLOAD gl_coex_offload;$/;"	v
-gl_psd_scan_8703b_1ant	hal/btc/HalBtc8703b1Ant.c	/^static struct  psdscan_sta_8703b_1ant	gl_psd_scan_8703b_1ant;$/;"	v	typeref:struct:psdscan_sta_8703b_1ant	file:
-gl_psd_scan_8723b_1ant	hal/btc/HalBtc8723b1Ant.c	/^static struct  psdscan_sta_8723b_1ant	gl_psd_scan_8723b_1ant;$/;"	v	typeref:struct:psdscan_sta_8723b_1ant	file:
-gl_psd_scan_8723d_1ant	hal/btc/halbtc8723d1ant.c	/^static struct  psdscan_sta_8723d_1ant	gl_psd_scan_8723d_1ant;$/;"	v	typeref:struct:psdscan_sta_8723d_1ant	file:
-gl_psd_scan_8723d_2ant	hal/btc/halbtc8723d2ant.c	/^static struct  psdscan_sta_8723d_2ant	gl_psd_scan_8723d_2ant;$/;"	v	typeref:struct:psdscan_sta_8723d_2ant	file:
-gl_psd_scan_8821c_1ant	hal/btc/halbtc8821c1ant.c	/^static struct  psdscan_sta_8821c_1ant		gl_psd_scan_8821c_1ant;$/;"	v	typeref:struct:psdscan_sta_8821c_1ant	file:
-gl_psd_scan_8821c_2ant	hal/btc/halbtc8821c2ant.c	/^static struct  psdscan_sta_8821c_2ant	gl_psd_scan_8821c_2ant;$/;"	v	typeref:struct:psdscan_sta_8821c_2ant	file:
-gl_psd_scan_8822b_1ant	hal/btc/HalBtc8822b1Ant.c	/^static struct  psdscan_sta_8822b_1ant	gl_psd_scan_8822b_1ant;$/;"	v	typeref:struct:psdscan_sta_8822b_1ant	file:
-gl_rfe_type_8821c_1ant	hal/btc/halbtc8821c1ant.c	/^static struct	rfe_type_8821c_1ant		gl_rfe_type_8821c_1ant;$/;"	v	typeref:struct:rfe_type_8821c_1ant	file:
-gl_rfe_type_8821c_2ant	hal/btc/halbtc8821c2ant.c	/^static struct	rfe_type_8821c_2ant		gl_rfe_type_8821c_2ant;$/;"	v	typeref:struct:rfe_type_8821c_2ant	file:
-gl_rfe_type_8822b_1ant	hal/btc/HalBtc8822b1Ant.c	/^static struct	rfe_type_8822b_1ant		gl_rfe_type_8822b_1ant;$/;"	v	typeref:struct:rfe_type_8822b_1ant	file:
-glbt_info_src_8192e_1ant	hal/btc/HalBtc8192e1Ant.c	/^const char *const glbt_info_src_8192e_1ant[] = {$/;"	v
-glbt_info_src_8192e_2ant	hal/btc/HalBtc8192e2Ant.c	/^const char *const glbt_info_src_8192e_2ant[] = {$/;"	v
-glbt_info_src_8703b_1ant	hal/btc/HalBtc8703b1Ant.c	/^const char *const glbt_info_src_8703b_1ant[] = {$/;"	v
-glbt_info_src_8723b_1ant	hal/btc/HalBtc8723b1Ant.c	/^const char *const glbt_info_src_8723b_1ant[]={$/;"	v
-glbt_info_src_8723b_2ant	hal/btc/HalBtc8723b2Ant.c	/^const char *const glbt_info_src_8723b_2ant[] = {$/;"	v
-glbt_info_src_8723d_1ant	hal/btc/halbtc8723d1ant.c	/^const char *const glbt_info_src_8723d_1ant[] = {$/;"	v
-glbt_info_src_8723d_2ant	hal/btc/halbtc8723d2ant.c	/^const char *const glbt_info_src_8723d_2ant[] = {$/;"	v
-glbt_info_src_8812a_1ant	hal/btc/HalBtc8812a1Ant.c	/^const char *const glbt_info_src_8812a_1ant[] = {$/;"	v
-glbt_info_src_8812a_2ant	hal/btc/HalBtc8812a2Ant.c	/^const char *const glbt_info_src_8812a_2ant[] = {$/;"	v
-glbt_info_src_8821a_1ant	hal/btc/HalBtc8821a1Ant.c	/^const char *const glbt_info_src_8821a_1ant[] = {$/;"	v
-glbt_info_src_8821a_2ant	hal/btc/HalBtc8821a2Ant.c	/^const char *const glbt_info_src_8821a_2ant[] = {$/;"	v
-glbt_info_src_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.c	/^const char *const glbt_info_src_8821a_csr_2ant[] = {$/;"	v
-glbt_info_src_8821c_1ant	hal/btc/halbtc8821c1ant.c	/^const char *const glbt_info_src_8821c_1ant[] = {$/;"	v
-glbt_info_src_8821c_2ant	hal/btc/halbtc8821c2ant.c	/^const char *const glbt_info_src_8821c_2ant[] = {$/;"	v
-glbt_info_src_8822b_1ant	hal/btc/HalBtc8822b1Ant.c	/^const char *const glbt_info_src_8822b_1ant[] = {$/;"	v
-glcoex_dm_8192e_1ant	hal/btc/HalBtc8192e1Ant.c	/^static struct  coex_dm_8192e_1ant		glcoex_dm_8192e_1ant;$/;"	v	typeref:struct:coex_dm_8192e_1ant	file:
-glcoex_dm_8192e_2ant	hal/btc/HalBtc8192e2Ant.c	/^static struct  coex_dm_8192e_2ant		glcoex_dm_8192e_2ant;$/;"	v	typeref:struct:coex_dm_8192e_2ant	file:
-glcoex_dm_8703b_1ant	hal/btc/HalBtc8703b1Ant.c	/^static struct  coex_dm_8703b_1ant		glcoex_dm_8703b_1ant;$/;"	v	typeref:struct:coex_dm_8703b_1ant	file:
-glcoex_dm_8723b_1ant	hal/btc/HalBtc8723b1Ant.c	/^static struct  coex_dm_8723b_1ant		glcoex_dm_8723b_1ant;$/;"	v	typeref:struct:coex_dm_8723b_1ant	file:
-glcoex_dm_8723b_2ant	hal/btc/HalBtc8723b2Ant.c	/^static struct  coex_dm_8723b_2ant		glcoex_dm_8723b_2ant;$/;"	v	typeref:struct:coex_dm_8723b_2ant	file:
-glcoex_dm_8723d_1ant	hal/btc/halbtc8723d1ant.c	/^static struct  coex_dm_8723d_1ant		glcoex_dm_8723d_1ant;$/;"	v	typeref:struct:coex_dm_8723d_1ant	file:
-glcoex_dm_8723d_2ant	hal/btc/halbtc8723d2ant.c	/^static struct  coex_dm_8723d_2ant		glcoex_dm_8723d_2ant;$/;"	v	typeref:struct:coex_dm_8723d_2ant	file:
-glcoex_dm_8812a_1ant	hal/btc/HalBtc8812a1Ant.c	/^static struct  coex_dm_8812a_1ant		glcoex_dm_8812a_1ant;$/;"	v	typeref:struct:coex_dm_8812a_1ant	file:
-glcoex_dm_8812a_2ant	hal/btc/HalBtc8812a2Ant.c	/^static struct  coex_dm_8812a_2ant	glcoex_dm_8812a_2ant;$/;"	v	typeref:struct:coex_dm_8812a_2ant	file:
-glcoex_dm_8821a_1ant	hal/btc/HalBtc8821a1Ant.c	/^static struct  coex_dm_8821a_1ant		glcoex_dm_8821a_1ant;$/;"	v	typeref:struct:coex_dm_8821a_1ant	file:
-glcoex_dm_8821a_2ant	hal/btc/HalBtc8821a2Ant.c	/^static struct  coex_dm_8821a_2ant		glcoex_dm_8821a_2ant;$/;"	v	typeref:struct:coex_dm_8821a_2ant	file:
-glcoex_dm_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.c	/^static struct  coex_dm_8821a_csr_2ant	glcoex_dm_8821a_csr_2ant;$/;"	v	typeref:struct:coex_dm_8821a_csr_2ant	file:
-glcoex_dm_8821c_1ant	hal/btc/halbtc8821c1ant.c	/^static struct  coex_dm_8821c_1ant		glcoex_dm_8821c_1ant;$/;"	v	typeref:struct:coex_dm_8821c_1ant	file:
-glcoex_dm_8821c_2ant	hal/btc/halbtc8821c2ant.c	/^static struct  coex_dm_8821c_2ant		glcoex_dm_8821c_2ant;$/;"	v	typeref:struct:coex_dm_8821c_2ant	file:
-glcoex_dm_8822b_1ant	hal/btc/HalBtc8822b1Ant.c	/^static struct  coex_dm_8822b_1ant		glcoex_dm_8822b_1ant;$/;"	v	typeref:struct:coex_dm_8822b_1ant	file:
-glcoex_sta_8192e_1ant	hal/btc/HalBtc8192e1Ant.c	/^static struct  coex_sta_8192e_1ant		glcoex_sta_8192e_1ant;$/;"	v	typeref:struct:coex_sta_8192e_1ant	file:
-glcoex_sta_8192e_2ant	hal/btc/HalBtc8192e2Ant.c	/^static struct  coex_sta_8192e_2ant		glcoex_sta_8192e_2ant;$/;"	v	typeref:struct:coex_sta_8192e_2ant	file:
-glcoex_sta_8703b_1ant	hal/btc/HalBtc8703b1Ant.c	/^static struct  coex_sta_8703b_1ant		glcoex_sta_8703b_1ant;$/;"	v	typeref:struct:coex_sta_8703b_1ant	file:
-glcoex_sta_8723b_1ant	hal/btc/HalBtc8723b1Ant.c	/^static struct  coex_sta_8723b_1ant		glcoex_sta_8723b_1ant;$/;"	v	typeref:struct:coex_sta_8723b_1ant	file:
-glcoex_sta_8723b_2ant	hal/btc/HalBtc8723b2Ant.c	/^static struct  coex_sta_8723b_2ant		glcoex_sta_8723b_2ant;$/;"	v	typeref:struct:coex_sta_8723b_2ant	file:
-glcoex_sta_8723d_1ant	hal/btc/halbtc8723d1ant.c	/^static struct  coex_sta_8723d_1ant		glcoex_sta_8723d_1ant;$/;"	v	typeref:struct:coex_sta_8723d_1ant	file:
-glcoex_sta_8723d_2ant	hal/btc/halbtc8723d2ant.c	/^static struct  coex_sta_8723d_2ant		glcoex_sta_8723d_2ant;$/;"	v	typeref:struct:coex_sta_8723d_2ant	file:
-glcoex_sta_8812a_1ant	hal/btc/HalBtc8812a1Ant.c	/^static struct  coex_sta_8812a_1ant		glcoex_sta_8812a_1ant;$/;"	v	typeref:struct:coex_sta_8812a_1ant	file:
-glcoex_sta_8812a_2ant	hal/btc/HalBtc8812a2Ant.c	/^static struct  coex_sta_8812a_2ant	glcoex_sta_8812a_2ant;$/;"	v	typeref:struct:coex_sta_8812a_2ant	file:
-glcoex_sta_8821a_1ant	hal/btc/HalBtc8821a1Ant.c	/^static struct  coex_sta_8821a_1ant		glcoex_sta_8821a_1ant;$/;"	v	typeref:struct:coex_sta_8821a_1ant	file:
-glcoex_sta_8821a_2ant	hal/btc/HalBtc8821a2Ant.c	/^static struct  coex_sta_8821a_2ant		glcoex_sta_8821a_2ant;$/;"	v	typeref:struct:coex_sta_8821a_2ant	file:
-glcoex_sta_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.c	/^static struct  coex_sta_8821a_csr_2ant	glcoex_sta_8821a_csr_2ant;$/;"	v	typeref:struct:coex_sta_8821a_csr_2ant	file:
-glcoex_sta_8821c_1ant	hal/btc/halbtc8821c1ant.c	/^static struct  coex_sta_8821c_1ant		glcoex_sta_8821c_1ant;$/;"	v	typeref:struct:coex_sta_8821c_1ant	file:
-glcoex_sta_8821c_2ant	hal/btc/halbtc8821c2ant.c	/^static struct  coex_sta_8821c_2ant		glcoex_sta_8821c_2ant;$/;"	v	typeref:struct:coex_sta_8821c_2ant	file:
-glcoex_sta_8822b_1ant	hal/btc/HalBtc8822b1Ant.c	/^static struct  coex_sta_8822b_1ant		glcoex_sta_8822b_1ant;$/;"	v	typeref:struct:coex_sta_8822b_1ant	file:
-glcoex_ver_8192e_1ant	hal/btc/HalBtc8192e1Ant.c	/^u32	glcoex_ver_8192e_1ant = 0x4f;$/;"	v
-glcoex_ver_8192e_2ant	hal/btc/HalBtc8192e2Ant.c	/^u32	glcoex_ver_8192e_2ant = 0x42;$/;"	v
-glcoex_ver_8703b_1ant	hal/btc/HalBtc8703b1Ant.c	/^u32	glcoex_ver_8703b_1ant = 0x09;$/;"	v
-glcoex_ver_8723b_1ant	hal/btc/HalBtc8723b1Ant.c	/^u32	glcoex_ver_8723b_1ant = 0x63;$/;"	v
-glcoex_ver_8723b_2ant	hal/btc/HalBtc8723b2Ant.c	/^u32	glcoex_ver_8723b_2ant = 0x4a;$/;"	v
-glcoex_ver_8723d_1ant	hal/btc/halbtc8723d1ant.c	/^u32	glcoex_ver_8723d_1ant = 0x12;$/;"	v
-glcoex_ver_8723d_2ant	hal/btc/halbtc8723d2ant.c	/^u32	glcoex_ver_8723d_2ant = 0x12;$/;"	v
-glcoex_ver_8812a_1ant	hal/btc/HalBtc8812a1Ant.c	/^u32	glcoex_ver_8812a_1ant = 0x52;$/;"	v
-glcoex_ver_8812a_2ant	hal/btc/HalBtc8812a2Ant.c	/^u32	glcoex_ver_8812a_2ant = 0x37;$/;"	v
-glcoex_ver_8821a_1ant	hal/btc/HalBtc8821a1Ant.c	/^u32	glcoex_ver_8821a_1ant = 0x61;$/;"	v
-glcoex_ver_8821a_2ant	hal/btc/HalBtc8821a2Ant.c	/^u32	glcoex_ver_8821a_2ant = 0x58;$/;"	v
-glcoex_ver_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.c	/^u32 glcoex_ver_8821a_csr_2ant = 0x51;$/;"	v
-glcoex_ver_8821c_1ant	hal/btc/halbtc8821c1ant.c	/^u32	glcoex_ver_8821c_1ant = 0x00;$/;"	v
-glcoex_ver_8821c_2ant	hal/btc/halbtc8821c2ant.c	/^u32	glcoex_ver_8821c_2ant = 0x00;$/;"	v
-glcoex_ver_8822b_1ant	hal/btc/HalBtc8822b1Ant.c	/^u32	glcoex_ver_8822b_1ant = 0x14;$/;"	v
-glcoex_ver_btdesired_8723d_1ant	hal/btc/halbtc8723d1ant.c	/^u32 glcoex_ver_btdesired_8723d_1ant = 0x10;$/;"	v
-glcoex_ver_btdesired_8723d_2ant	hal/btc/halbtc8723d2ant.c	/^u32 glcoex_ver_btdesired_8723d_2ant = 0x10;$/;"	v
-glcoex_ver_date_8192e_1ant	hal/btc/HalBtc8192e1Ant.c	/^u32	glcoex_ver_date_8192e_1ant = 20140527;$/;"	v
-glcoex_ver_date_8192e_2ant	hal/btc/HalBtc8192e2Ant.c	/^u32	glcoex_ver_date_8192e_2ant = 20160412;$/;"	v
-glcoex_ver_date_8703b_1ant	hal/btc/HalBtc8703b1Ant.c	/^u32	glcoex_ver_date_8703b_1ant = 20160218;$/;"	v
-glcoex_ver_date_8723b_1ant	hal/btc/HalBtc8723b1Ant.c	/^u32	glcoex_ver_date_8723b_1ant = 20151015;$/;"	v
-glcoex_ver_date_8723b_2ant	hal/btc/HalBtc8723b2Ant.c	/^u32	glcoex_ver_date_8723b_2ant = 20151223;$/;"	v
-glcoex_ver_date_8723d_1ant	hal/btc/halbtc8723d1ant.c	/^u32	glcoex_ver_date_8723d_1ant = 20161208;$/;"	v
-glcoex_ver_date_8723d_2ant	hal/btc/halbtc8723d2ant.c	/^u32	glcoex_ver_date_8723d_2ant = 20161208;$/;"	v
-glcoex_ver_date_8812a_1ant	hal/btc/HalBtc8812a1Ant.c	/^u32	glcoex_ver_date_8812a_1ant = 20140708;$/;"	v
-glcoex_ver_date_8812a_2ant	hal/btc/HalBtc8812a2Ant.c	/^u32	glcoex_ver_date_8812a_2ant = 20150724;$/;"	v
-glcoex_ver_date_8821a_1ant	hal/btc/HalBtc8821a1Ant.c	/^u32	glcoex_ver_date_8821a_1ant = 20150615;$/;"	v
-glcoex_ver_date_8821a_2ant	hal/btc/HalBtc8821a2Ant.c	/^u32	glcoex_ver_date_8821a_2ant = 20150921;$/;"	v
-glcoex_ver_date_8821a_csr_2ant	hal/btc/HalBtc8821aCsr2Ant.c	/^u32 glcoex_ver_date_8821a_csr_2ant = 20140901;$/;"	v
-glcoex_ver_date_8821c_1ant	hal/btc/halbtc8821c1ant.c	/^u32	glcoex_ver_date_8821c_1ant = 20160316;$/;"	v
-glcoex_ver_date_8821c_2ant	hal/btc/halbtc8821c2ant.c	/^u32	glcoex_ver_date_8821c_2ant = 20160316;$/;"	v
-glcoex_ver_date_8822b_1ant	hal/btc/HalBtc8822b1Ant.c	/^u32	glcoex_ver_date_8822b_1ant = 20160411;$/;"	v
-glock	include/drv_types.h	/^	_lock glock;$/;"	m	struct:_ADAPTER
-gnt_bt	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gnt_bt: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-gnt_bt	hal/phydm/phydm_hwconfig.h	/^	u1Byte		gnt_bt: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-gnt_control_by_PTA	hal/btc/HalBtc8703b1Ant.h	/^	boolean				gnt_control_by_PTA;$/;"	m	struct:coex_sta_8703b_1ant
-gnt_error_cnt	hal/btc/halbtc8723d1ant.h	/^	u32                 gnt_error_cnt;$/;"	m	struct:coex_sta_8723d_1ant
-gnt_error_cnt	hal/btc/halbtc8723d2ant.h	/^	u32                 gnt_error_cnt;$/;"	m	struct:coex_sta_8723d_2ant
-go_add_group_info_attr	core/rtw_p2p.c	/^static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)$/;"	f	file:
-go_bssid	include/rtw_mlme.h	/^	u8					go_bssid[ETH_ALEN];$/;"	m	struct:tx_invite_req_info
-go_device_addr	include/rtw_mlme.h	/^	u8					go_device_addr[ETH_ALEN];	\/*	The GO's device address of this P2P group *\/$/;"	m	struct:group_id_info
-go_ssid	include/rtw_mlme.h	/^	u8					go_ssid[WLAN_SSID_MAXLEN];$/;"	m	struct:tx_invite_req_info
-gpio_eint_wlan	platform/platform_ARM_SUNnI_sdio.c	/^static signed int gpio_eint_wlan = -1;$/;"	v	file:
-gpio_hostwakeup_alloc_irq	os_dep/linux/sdio_intf.c	/^static u8 gpio_hostwakeup_alloc_irq(PADAPTER padapter)$/;"	f	file:
-gpio_hostwakeup_free_irq	os_dep/linux/sdio_intf.c	/^static void gpio_hostwakeup_free_irq(PADAPTER padapter)$/;"	f	file:
-gpio_hostwakeup_irq_thread	os_dep/linux/sdio_intf.c	/^static irqreturn_t gpio_hostwakeup_irq_thread(int irq, void *data)$/;"	f	file:
-gpio_int	os_dep/linux/custom_gpio_linux.c	/^void gpio_int(u8 is_high)$/;"	f
-gpio_int_priv	include/drv_types.h	/^	struct gpio_int_priv {$/;"	s	struct:_ADAPTER
-gpio_period	include/rtl8188e_cmd.h	/^	u16 gpio_period; \/* unit: 1024 us *\/$/;"	m	struct:H2C_SS_RFOFF_PARAM
-gpio_period	include/rtl8192e_cmd.h	/^	u16 gpio_period; \/* unit: 1024 us *\/$/;"	m	struct:H2C_SS_RFOFF_PARAM
-gpio_period	include/rtl8812a_cmd.h	/^	u16 gpio_period; \/* unit: 1024 us *\/$/;"	m	struct:H2C_SS_RFOFF_PARAM
-gpiointpriv	include/drv_types.h	/^	} gpiointpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::gpio_int_priv
-group_bssid	os_dep/linux/ioctl_cfg80211.h	/^	u8 group_bssid[ETH_ALEN];$/;"	m	struct:rtw_wdev_invit_info
-group_cipher	include/rtw_mlme.h	/^	int group_cipher;$/;"	m	struct:beacon_keys
-group_cipher	include/wlan_bssdef.h	/^	int group_cipher; \/* WPA\/WPA2 group cipher *\/$/;"	m	struct:_WLAN_BCN_INFO
-group_cnt	include/rtw_mlme.h	/^	u8	group_cnt;	\/* In WiDi 3.5, they specified another scan algo. for WFD\/RDS co-existed *\/$/;"	m	struct:mlme_priv
-group_id_info	include/rtw_mlme.h	/^struct group_id_info {$/;"	s
-group_key	include/rtw_pwrctrl.h	/^	u8 group_key[32];$/;"	m	struct:aoac_report
-groupid_info	include/rtw_mlme.h	/^	struct group_id_info		groupid_info;	\/*	Store the group id information when doing the group negotiation handshake. *\/$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::group_id_info
-grpkey	include/rtw_cmd.h	/^	u8	grpkey;		\/* 1: this is the grpkey for 802.1x. 0: this is the unicast key for 802.1x *\/$/;"	m	struct:setkey_parm
-gs_retry_count	hal/phydm/phydm_iqk.h	/^	u1Byte		gs_retry_count[2][4][2]; \/*channel \/ path \/ (GSRXK1:0, GSRXK2:1)*\/$/;"	m	struct:_IQK_INFORMATION
-gscan_attributes	os_dep/linux/rtw_cfgvendor.h	/^enum gscan_attributes {$/;"	g
-gscan_batch_attribute	os_dep/linux/rtw_cfgvendor.h	/^typedef enum gscan_batch_attribute {$/;"	g
-gscan_batch_attribute_t	os_dep/linux/rtw_cfgvendor.h	/^} gscan_batch_attribute_t;$/;"	t	typeref:enum:gscan_batch_attribute
-gscan_bucket_attributes	os_dep/linux/rtw_cfgvendor.h	/^enum gscan_bucket_attributes {$/;"	g
-gscan_ch_attributes	os_dep/linux/rtw_cfgvendor.h	/^enum gscan_ch_attributes {$/;"	g
-gscan_complete_event	os_dep/linux/rtw_cfgvendor.h	/^typedef enum gscan_complete_event {$/;"	g
-gscan_complete_event_t	os_dep/linux/rtw_cfgvendor.h	/^} gscan_complete_event_t;$/;"	t	typeref:enum:gscan_complete_event
-gscan_geofence_attribute	os_dep/linux/rtw_cfgvendor.h	/^typedef enum gscan_geofence_attribute {$/;"	g
-gscan_geofence_attribute_t	os_dep/linux/rtw_cfgvendor.h	/^} gscan_geofence_attribute_t;$/;"	t	typeref:enum:gscan_geofence_attribute
-gspi_data	include/drv_types_gspi.h	/^typedef struct gspi_data {$/;"	s
-gw_ip	include/rtw_mlme.h	/^	u8	gw_ip[4];$/;"	m	struct:mlme_priv
-gw_mac_addr	include/rtw_mlme.h	/^	u8	gw_mac_addr[6];$/;"	m	struct:mlme_priv
-h2cReqNum	include/rtw_mp.h	/^	u1Byte			h2cReqNum;$/;"	m	struct:_MPT_CONTEXT
-h2cStaString	hal/hal_btcoex.c	/^const char *const h2cStaString[] = {$/;"	v
-h2c_buf	hal/btc/HalBtcOutSrc.h	/^	u1Byte					h2c_buf[COL_H2C_BUF_LEN];	\/* the latest sent h2c buffer *\/$/;"	m	struct:_COL_SINGLE_H2C_RECORD
-h2c_clr	include/rtw_mp.h	/^	NDIS_EVENT h2c_clr;$/;"	m	struct:mp_priv
-h2c_cmd	include/hal_com_h2c.h	/^enum h2c_cmd {$/;"	g
-h2c_cmd_8188F	include/rtl8188f_cmd.h	/^enum h2c_cmd_8188F {$/;"	g
-h2c_cmd_8703B	include/rtl8703b_cmd.h	/^enum h2c_cmd_8703B {$/;"	g
-h2c_cmd_8723B	include/rtl8723b_cmd.h	/^enum h2c_cmd_8723B {$/;"	g
-h2c_cmd_8723D	include/rtl8723d_cmd.h	/^enum h2c_cmd_8723D {$/;"	g
-h2c_cmd_evt	include/rtw_mp.h	/^	NDIS_EVENT h2c_cmd_evt;$/;"	m	struct:mp_priv
-h2c_cmdcnt	include/rtw_mp.h	/^	u32 h2c_cmdcnt;$/;"	m	struct:mp_priv
-h2c_cmdcode	include/rtw_mp.h	/^	u16 h2c_cmdcode;$/;"	m	struct:mp_priv
-h2c_fwcmd_mutex	include/drv_types.h	/^	_mutex h2c_fwcmd_mutex;$/;"	m	struct:dvobj_priv
-h2c_len	hal/btc/HalBtcOutSrc.h	/^	u4Byte					h2c_len;$/;"	m	struct:_COL_SINGLE_H2C_RECORD
-h2c_lock	include/rtw_mp.h	/^	_lock h2c_lock;$/;"	m	struct:mp_priv
-h2c_msg_hdl	core/rtw_mlme_ext.c	/^u8 h2c_msg_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-h2c_msr	include/drv_types.h	/^	u8 h2c_msr[MACID_NUM_SW_LIMIT];$/;"	m	struct:macid_ctl_t
-h2c_msr_role_str	include/hal_com_h2c.h	242;"	d
-h2c_record	hal/btc/HalBtcOutSrc.h	/^	COL_SINGLE_H2C_RECORD	h2c_record[COL_OP_WIFI_OPCODE_MAX];$/;"	m	struct:_BTC_OFFLOAD
-h2c_req_num	hal/btc/HalBtcOutSrc.h	/^	u1Byte					h2c_req_num;$/;"	m	struct:_BTC_OFFLOAD
-h2c_resp_parambuf	include/rtw_mp.h	/^	u8 h2c_resp_parambuf[512];$/;"	m	struct:mp_priv
-h2c_result	include/rtw_mp.h	/^	u8 h2c_result;$/;"	m	struct:mp_priv
-h2c_seqnum	include/rtw_mp.h	/^	u8 h2c_seqnum;$/;"	m	struct:mp_priv
-h2cfuns	include/rtw_mlme_ext.h	/^	u8(*h2cfuns)(struct _ADAPTER *padapter, u8 *pbuf);$/;"	m	struct:cmd_hdl
-hDevice	include/drv_types_sdio.h	/^	SD_DEVICE_HANDLE			hDevice;$/;"	m	struct:sdio_data
-h_dest	include/if_ether.h	/^	unsigned char	h_dest[ETH_ALEN];	\/* destination eth addr	*\/$/;"	m	struct:ethhdr
-h_proto	include/if_ether.h	/^	unsigned short	h_proto;		\/* packet type ID field	*\/$/;"	m	struct:ethhdr
-h_source	include/if_ether.h	/^	unsigned char	h_source[ETH_ALEN];	\/* source ether addr	*\/$/;"	m	struct:ethhdr
-h_vlan_TCI	include/if_ether.h	/^	unsigned short       h_vlan_TCI;                \/* Encapsulates priority and VLAN ID *\/$/;"	m	struct:_vlan
-h_vlan_encapsulated_proto	include/if_ether.h	/^	unsigned short       h_vlan_encapsulated_proto;$/;"	m	struct:_vlan
-halComTxbf_ClkWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_ClkWorkItemCallback($/;"	f
-halComTxbf_ClkWorkItemCallback	hal/phydm/txbf/halcomtxbf.h	171;"	d
-halComTxbf_ConfigGtab	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_ConfigGtab($/;"	f
-halComTxbf_ConfigGtab	hal/phydm/txbf/halcomtxbf.h	167;"	d
-halComTxbf_EnterWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_EnterWorkItemCallback($/;"	f
-halComTxbf_EnterWorkItemCallback	hal/phydm/txbf/halcomtxbf.h	168;"	d
-halComTxbf_FwNdpaTimerCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_FwNdpaTimerCallback($/;"	f
-halComTxbf_FwNdpaTimerCallback	hal/phydm/txbf/halcomtxbf.h	173;"	d
-halComTxbf_FwNdpaWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_FwNdpaWorkItemCallback($/;"	f
-halComTxbf_FwNdpaWorkItemCallback	hal/phydm/txbf/halcomtxbf.h	170;"	d
-halComTxbf_GetTxRateWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_GetTxRateWorkItemCallback($/;"	f
-halComTxbf_LeaveWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_LeaveWorkItemCallback($/;"	f
-halComTxbf_LeaveWorkItemCallback	hal/phydm/txbf/halcomtxbf.h	169;"	d
-halComTxbf_RateWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_RateWorkItemCallback(	$/;"	f
-halComTxbf_RateWorkItemCallback	hal/phydm/txbf/halcomtxbf.h	172;"	d
-halComTxbf_ResetTxPathWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_ResetTxPathWorkItemCallback($/;"	f
-halComTxbf_StatusWorkItemCallback	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_StatusWorkItemCallback($/;"	f
-halComTxbf_StatusWorkItemCallback	hal/phydm/txbf/halcomtxbf.h	174;"	d
-halComTxbf_beamformInit	hal/phydm/txbf/halcomtxbf.c	/^halComTxbf_beamformInit($/;"	f
-halComTxbf_beamformInit	hal/phydm/txbf/halcomtxbf.h	166;"	d
-halTxbf8192E_DownloadNDPA	hal/phydm/txbf/haltxbf8192e.c	/^halTxbf8192E_DownloadNDPA($/;"	f
-halTxbf8192E_FwTxBFCmd	hal/phydm/txbf/haltxbf8192e.c	/^halTxbf8192E_FwTxBFCmd($/;"	f
-halTxbf8192E_RfMode	hal/phydm/txbf/haltxbf8192e.c	/^halTxbf8192E_RfMode($/;"	f
-halTxbf8814A_GetNrx	hal/phydm/txbf/haltxbf8814a.c	/^halTxbf8814A_GetNrx($/;"	f
-halTxbf8814A_GetNtx	hal/phydm/txbf/haltxbf8814a.c	/^halTxbf8814A_GetNtx($/;"	f
-halTxbf8814A_GetNtx	hal/phydm/txbf/haltxbf8814a.h	60;"	d
-halTxbf8814A_GetNtx	hal/phydm/txbf/haltxbf8814a.h	73;"	d
-halTxbf8814A_RfMode	hal/phydm/txbf/haltxbf8814a.c	/^halTxbf8814A_RfMode($/;"	f
-halTxbf8822B_GetNrx	hal/phydm/txbf/haltxbf8822b.c	/^halTxbf8822B_GetNrx($/;"	f
-halTxbf8822B_GetNtx	hal/phydm/txbf/haltxbf8822b.c	/^halTxbf8822B_GetNtx($/;"	f
-halTxbf8822B_RfMode	hal/phydm/txbf/haltxbf8822b.c	/^halTxbf8822B_RfMode($/;"	f
-halTxbfJaguar_DownloadNDPA	hal/phydm/txbf/haltxbfjaguar.c	/^halTxbfJaguar_DownloadNDPA($/;"	f
-halTxbfJaguar_FwTxBFCmd	hal/phydm/txbf/haltxbfjaguar.c	/^halTxbfJaguar_FwTxBFCmd($/;"	f
-halTxbfJaguar_RfMode	hal/phydm/txbf/haltxbfjaguar.c	/^halTxbfJaguar_RfMode($/;"	f
-hal_EfuseConstructPGPkt	core/efuse/rtw_efuse.c	/^hal_EfuseConstructPGPkt($/;"	f	file:
-hal_EfuseConstructPGPkt	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfuseConstructPGPkt($/;"	f	file:
-hal_EfuseGetCurrentSize_BT	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfuseGetCurrentSize_BT($/;"	f	file:
-hal_EfuseGetCurrentSize_WiFi	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfuseGetCurrentSize_WiFi($/;"	f	file:
-hal_EfusePartialWriteCheck	core/efuse/rtw_efuse.c	/^static u8 hal_EfusePartialWriteCheck($/;"	f	file:
-hal_EfusePartialWriteCheck	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfusePartialWriteCheck($/;"	f	file:
-hal_EfusePgCheckAvailableAddr	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfusePgCheckAvailableAddr($/;"	f	file:
-hal_EfusePgPacketWrite1ByteHeader	core/efuse/rtw_efuse.c	/^static u8 hal_EfusePgPacketWrite1ByteHeader($/;"	f	file:
-hal_EfusePgPacketWrite1ByteHeader	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfusePgPacketWrite1ByteHeader($/;"	f	file:
-hal_EfusePgPacketWrite2ByteHeader	core/efuse/rtw_efuse.c	/^static u8 hal_EfusePgPacketWrite2ByteHeader($/;"	f	file:
-hal_EfusePgPacketWrite2ByteHeader	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfusePgPacketWrite2ByteHeader($/;"	f	file:
-hal_EfusePgPacketWriteData	core/efuse/rtw_efuse.c	/^hal_EfusePgPacketWriteData($/;"	f	file:
-hal_EfusePgPacketWriteData	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfusePgPacketWriteData($/;"	f	file:
-hal_EfusePgPacketWriteHeader	core/efuse/rtw_efuse.c	/^static u8 hal_EfusePgPacketWriteHeader($/;"	f	file:
-hal_EfusePgPacketWriteHeader	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfusePgPacketWriteHeader($/;"	f	file:
-hal_EfuseSwitchToBank	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_EfuseSwitchToBank($/;"	f	file:
-hal_ReadEFuse_BT	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_ReadEFuse_BT($/;"	f	file:
-hal_ReadEFuse_BT_logic_map	core/efuse/rtw_efuse.c	/^VOID hal_ReadEFuse_BT_logic_map($/;"	f
-hal_ReadEFuse_WiFi	hal/rtl8723d/rtl8723d_hal_init.c	/^hal_ReadEFuse_WiFi($/;"	f	file:
-hal_btcoex_1Ant	hal/hal_btcoex.c	/^u8 hal_btcoex_1Ant(PADAPTER padapter)$/;"	f
-hal_btcoex_AntIsolationConfig_ParaFile	hal/hal_btcoex.c	/^hal_btcoex_AntIsolationConfig_ParaFile($/;"	f
-hal_btcoex_BTOffOnNotify	hal/hal_btcoex.c	/^void hal_btcoex_BTOffOnNotify(PADAPTER padapter, u8 bBTON)$/;"	f
-hal_btcoex_BtInfoNotify	hal/hal_btcoex.c	/^void hal_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)$/;"	f
-hal_btcoex_BtMpRptNotify	hal/hal_btcoex.c	/^void hal_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)$/;"	f
-hal_btcoex_ConnectNotify	hal/hal_btcoex.c	/^void hal_btcoex_ConnectNotify(PADAPTER padapter, u8 action)$/;"	f
-hal_btcoex_DisplayBtCoexInfo	hal/hal_btcoex.c	/^void hal_btcoex_DisplayBtCoexInfo(PADAPTER padapter, u8 *pbuf, u32 bufsize)$/;"	f
-hal_btcoex_GetAMPDUSize	hal/hal_btcoex.c	/^u32 hal_btcoex_GetAMPDUSize(PADAPTER padapter)$/;"	f
-hal_btcoex_GetDBG	hal/hal_btcoex.c	/^u32 hal_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)$/;"	f
-hal_btcoex_GetRaMask	hal/hal_btcoex.c	/^u32 hal_btcoex_GetRaMask(PADAPTER padapter)$/;"	f
-hal_btcoex_HaltNotify	hal/hal_btcoex.c	/^void hal_btcoex_HaltNotify(PADAPTER padapter, u8 do_halt)$/;"	f
-hal_btcoex_Hanlder	hal/hal_btcoex.c	/^void hal_btcoex_Hanlder(PADAPTER padapter)$/;"	f
-hal_btcoex_IQKNotify	hal/hal_btcoex.c	/^void hal_btcoex_IQKNotify(PADAPTER padapter, u8 state)$/;"	f
-hal_btcoex_IncreaseScanDeviceNum	hal/hal_btcoex.c	/^u8 hal_btcoex_IncreaseScanDeviceNum(PADAPTER padapter)$/;"	f
-hal_btcoex_InitHwConfig	hal/hal_btcoex.c	/^void hal_btcoex_InitHwConfig(PADAPTER padapter, u8 bWifiOnly)$/;"	f
-hal_btcoex_Initialize	hal/hal_btcoex.c	/^u8 hal_btcoex_Initialize(PADAPTER padapter)$/;"	f
-hal_btcoex_IpsNotify	hal/hal_btcoex.c	/^void hal_btcoex_IpsNotify(PADAPTER padapter, u8 type)$/;"	f
-hal_btcoex_IsBTCoexCtrlAMPDUSize	hal/hal_btcoex.c	/^s32 hal_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER padapter)$/;"	f
-hal_btcoex_IsBTCoexRejectAMPDU	hal/hal_btcoex.c	/^s32 hal_btcoex_IsBTCoexRejectAMPDU(PADAPTER padapter)$/;"	f
-hal_btcoex_IsBtControlLps	hal/hal_btcoex.c	/^u8 hal_btcoex_IsBtControlLps(PADAPTER padapter)$/;"	f
-hal_btcoex_IsBtDisabled	hal/hal_btcoex.c	/^u8 hal_btcoex_IsBtDisabled(PADAPTER padapter)$/;"	f
-hal_btcoex_IsBtExist	hal/hal_btcoex.c	/^u8 hal_btcoex_IsBtExist(PADAPTER padapter)$/;"	f
-hal_btcoex_IsBtLinkExist	hal/hal_btcoex.c	/^u8 hal_btcoex_IsBtLinkExist(PADAPTER padapter)$/;"	f
-hal_btcoex_IsLpsOn	hal/hal_btcoex.c	/^u8 hal_btcoex_IsLpsOn(PADAPTER padapter)$/;"	f
-hal_btcoex_LpsNotify	hal/hal_btcoex.c	/^void hal_btcoex_LpsNotify(PADAPTER padapter, u8 type)$/;"	f
-hal_btcoex_LpsVal	hal/hal_btcoex.c	/^u8 hal_btcoex_LpsVal(PADAPTER padapter)$/;"	f
-hal_btcoex_MediaStatusNotify	hal/hal_btcoex.c	/^void hal_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus)$/;"	f
-hal_btcoex_ParseAntIsolationConfigFile	hal/hal_btcoex.c	/^hal_btcoex_ParseAntIsolationConfigFile($/;"	f
-hal_btcoex_PowerOnSetting	hal/hal_btcoex.c	/^void hal_btcoex_PowerOnSetting(PADAPTER padapter)$/;"	f
-hal_btcoex_PreLoadFirmware	hal/hal_btcoex.c	/^void hal_btcoex_PreLoadFirmware(PADAPTER padapter)$/;"	f
-hal_btcoex_RecordPwrMode	hal/hal_btcoex.c	/^void hal_btcoex_RecordPwrMode(PADAPTER padapter, u8 *pCmdBuf, u8 cmdLen)$/;"	f
-hal_btcoex_RpwmVal	hal/hal_btcoex.c	/^u8 hal_btcoex_RpwmVal(PADAPTER padapter)$/;"	f
-hal_btcoex_ScanNotify	hal/hal_btcoex.c	/^void hal_btcoex_ScanNotify(PADAPTER padapter, u8 type)$/;"	f
-hal_btcoex_SetAntIsolationType	hal/hal_btcoex.c	/^void hal_btcoex_SetAntIsolationType(PADAPTER padapter, u8 anttype)$/;"	f
-hal_btcoex_SetBTCoexist	hal/hal_btcoex.c	/^void hal_btcoex_SetBTCoexist(PADAPTER padapter, u8 bBtExist)$/;"	f
-hal_btcoex_SetBtPatchVersion	hal/hal_btcoex.c	/^void hal_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer)$/;"	f
-hal_btcoex_SetChipType	hal/hal_btcoex.c	/^void hal_btcoex_SetChipType(PADAPTER padapter, u8 chipType)$/;"	f
-hal_btcoex_SetDBG	hal/hal_btcoex.c	/^void hal_btcoex_SetDBG(PADAPTER padapter, u32 *pDbgModule)$/;"	f
-hal_btcoex_SetHciVersion	hal/hal_btcoex.c	/^void hal_btcoex_SetHciVersion(PADAPTER padapter, u16 hciVersion)$/;"	f
-hal_btcoex_SetManualControl	hal/hal_btcoex.c	/^void hal_btcoex_SetManualControl(PADAPTER padapter, u8 bmanual)$/;"	f
-hal_btcoex_SetPgAntNum	hal/hal_btcoex.c	/^void hal_btcoex_SetPgAntNum(PADAPTER padapter, u8 antNum)$/;"	f
-hal_btcoex_SpecialPacketNotify	hal/hal_btcoex.c	/^void hal_btcoex_SpecialPacketNotify(PADAPTER padapter, u8 pktType)$/;"	f
-hal_btcoex_StackUpdateProfileInfo	hal/hal_btcoex.c	/^void hal_btcoex_StackUpdateProfileInfo(void)$/;"	f
-hal_btcoex_SuspendNotify	hal/hal_btcoex.c	/^void hal_btcoex_SuspendNotify(PADAPTER padapter, u8 state)$/;"	f
-hal_btcoex_SwitchBtTRxMask	hal/hal_btcoex.c	/^void hal_btcoex_SwitchBtTRxMask(PADAPTER padapter)$/;"	f
-hal_btcoex_btreg_read	hal/hal_btcoex.c	/^u16 hal_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data)$/;"	f
-hal_btcoex_btreg_write	hal/hal_btcoex.c	/^u16 hal_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val)$/;"	f
-hal_btcoex_set_rfe_type	hal/hal_btcoex.c	/^void hal_btcoex_set_rfe_type(u8 type)$/;"	f
-hal_btcoex_switchband_notify	hal/hal_btcoex.c	/^void hal_btcoex_switchband_notify(u8 under_scan, u8 band_type)$/;"	f
-hal_ch_offset_to_secondary_ch_offset	core/rtw_ieee80211.c	/^inline u8 hal_ch_offset_to_secondary_ch_offset(u8 ch_offset)$/;"	f
-hal_chk_band_cap	hal/hal_com.c	/^inline bool hal_chk_band_cap(_adapter *adapter, u8 cap)$/;"	f
-hal_chk_bw_cap	hal/hal_com.c	/^inline bool hal_chk_bw_cap(_adapter *adapter, u8 cap)$/;"	f
-hal_chk_pg_txpwr_info_2g	hal/hal_com_phycfg.c	/^static u8 hal_chk_pg_txpwr_info_2g(_adapter *adapter, TxPowerInfo24G *pwr_info)$/;"	f	file:
-hal_chk_pg_txpwr_info_5g	hal/hal_com_phycfg.c	/^static u8 hal_chk_pg_txpwr_info_5g(_adapter *adapter, TxPowerInfo5G *pwr_info)$/;"	f	file:
-hal_chk_proto_cap	hal/hal_com.c	/^inline bool hal_chk_proto_cap(_adapter *adapter, u8 cap)$/;"	f
-hal_chk_wl_func	hal/hal_com.c	/^inline bool hal_chk_wl_func(_adapter *adapter, u8 func)$/;"	f
-hal_com_config_channel_plan	hal/hal_com.c	/^u8 hal_com_config_channel_plan($/;"	f
-hal_com_data	include/hal_data.h	/^typedef struct hal_com_data {$/;"	s
-hal_config_macaddr	hal/hal_com.c	/^int hal_config_macaddr(_adapter *adapter, bool autoload_fail)$/;"	f
-hal_construct_poff_static_file	hal/rtl8723d/rtl8723d_lps_poff.c	/^static bool hal_construct_poff_static_file(PADAPTER padapter)$/;"	f	file:
-hal_data_sz	include/drv_types.h	/^	u32 hal_data_sz;$/;"	m	struct:_ADAPTER
-hal_deinit	include/hal_intf.h	/^	u32(*hal_deinit)(_adapter *padapter);$/;"	m	struct:hal_ops
-hal_dm_watchdog	include/hal_intf.h	/^	void	(*hal_dm_watchdog)(_adapter *padapter);$/;"	m	struct:hal_ops
-hal_dm_watchdog_in_lps	include/hal_intf.h	/^	void	(*hal_dm_watchdog_in_lps)(_adapter *padapter);$/;"	m	struct:hal_ops
-hal_efuse_macaddr_offset	hal/hal_com.c	/^int hal_efuse_macaddr_offset(_adapter *adapter)$/;"	f
-hal_get_tx_buff_rsvd_page_num	include/hal_intf.h	/^	u8(*hal_get_tx_buff_rsvd_page_num)(_adapter *adapter, bool wowlan);$/;"	m	struct:hal_ops
-hal_gpio_func_check	include/hal_intf.h	/^	int (*hal_gpio_func_check)(_adapter *padapter, u8 gpio_num);$/;"	m	struct:hal_ops
-hal_gpio_multi_func_reset	include/hal_intf.h	/^	void (*hal_gpio_multi_func_reset)(_adapter *padapter, u8 gpio_num);$/;"	m	struct:hal_ops
-hal_init	include/hal_intf.h	/^	u32(*hal_init)(_adapter *padapter);$/;"	m	struct:hal_ops
-hal_init_pg_txpwr_info_2g	hal/hal_com_phycfg.c	/^static inline void hal_init_pg_txpwr_info_2g(_adapter *adapter, TxPowerInfo24G *pwr_info)$/;"	f	file:
-hal_init_pg_txpwr_info_5g	hal/hal_com_phycfg.c	/^static inline void hal_init_pg_txpwr_info_5g(_adapter *adapter, TxPowerInfo5G *pwr_info)$/;"	f	file:
-hal_iqk_reg_backup	include/hal_data.h	/^struct hal_iqk_reg_backup {$/;"	s
-hal_is_band_support	hal/hal_com.c	/^inline bool hal_is_band_support(_adapter *adapter, u8 band)$/;"	f
-hal_is_bw_support	hal/hal_com.c	/^inline bool hal_is_bw_support(_adapter *adapter, u8 bw)$/;"	f
-hal_is_wireless_mode_support	hal/hal_com.c	/^inline bool hal_is_wireless_mode_support(_adapter *adapter, u8 mode)$/;"	f
-hal_largest_bw	hal/hal_com.c	/^u8 hal_largest_bw(_adapter *adapter, u8 in_bw)$/;"	f
-hal_load_pg_txpwr_info	hal/hal_com_phycfg.c	/^void hal_load_pg_txpwr_info($/;"	f
-hal_load_pg_txpwr_info_path_2g	hal/hal_com_phycfg.c	/^u16 hal_load_pg_txpwr_info_path_2g($/;"	f
-hal_load_pg_txpwr_info_path_5g	hal/hal_com_phycfg.c	/^u16 hal_load_pg_txpwr_info_path_5g($/;"	f
-hal_load_txpwr_info	hal/hal_com_phycfg.c	/^void hal_load_txpwr_info($/;"	f
-hal_mac_c2h_handler	include/hal_intf.h	/^	void (*hal_mac_c2h_handler)(_adapter *adapter, u8 *pbuf, u16 length);$/;"	m	struct:hal_ops
-hal_mpt_CCKTxPowerAdjust	hal/hal_mp.c	/^void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)$/;"	f
-hal_mpt_GetPowerTracking	hal/hal_mp.c	/^void hal_mpt_GetPowerTracking(PADAPTER padapter, u8 *enable)$/;"	f
-hal_mpt_GetThermalMeter	hal/hal_mp.c	/^void hal_mpt_GetThermalMeter(PADAPTER pAdapter, u8 *value)$/;"	f
-hal_mpt_ReadRFThermalMeter	hal/hal_mp.c	/^u8 hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter)$/;"	f
-hal_mpt_SetAntenna	hal/hal_mp.c	/^void hal_mpt_SetAntenna(PADAPTER	pAdapter)$/;"	f
-hal_mpt_SetBandwidth	hal/hal_mp.c	/^void hal_mpt_SetBandwidth(PADAPTER pAdapter)$/;"	f
-hal_mpt_SetCCKContinuousTx	hal/hal_mp.c	/^void hal_mpt_SetCCKContinuousTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-hal_mpt_SetCarrierSuppressionTx	hal/hal_mp.c	/^void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-hal_mpt_SetChannel	hal/hal_mp.c	/^void hal_mpt_SetChannel(PADAPTER pAdapter)$/;"	f
-hal_mpt_SetContinuousTx	hal/hal_mp.c	/^void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-hal_mpt_SetDataRate	hal/hal_mp.c	/^void hal_mpt_SetDataRate(PADAPTER pAdapter)$/;"	f
-hal_mpt_SetOFDMContinuousTx	hal/hal_mp.c	/^void hal_mpt_SetOFDMContinuousTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-hal_mpt_SetPowerTracking	hal/hal_mp.c	/^s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable)$/;"	f
-hal_mpt_SetSingleCarrierTx	hal/hal_mp.c	/^void hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-hal_mpt_SetSingleToneTx	hal/hal_mp.c	/^void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)$/;"	f
-hal_mpt_SetThermalMeter	hal/hal_mp.c	/^s32 hal_mpt_SetThermalMeter(PADAPTER pAdapter, u8 target_ther)$/;"	f
-hal_mpt_SetTxPower	hal/hal_mp.c	/^void hal_mpt_SetTxPower(PADAPTER pAdapter)$/;"	f
-hal_mpt_SwitchRfSetting	hal/hal_mp.c	/^void hal_mpt_SwitchRfSetting(PADAPTER	pAdapter)$/;"	f
-hal_mpt_TriggerRFThermalMeter	hal/hal_mp.c	/^void hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter)$/;"	f
-hal_mpt_query_phytxok	hal/hal_mp.c	/^u32 hal_mpt_query_phytxok(PADAPTER	pAdapter)$/;"	f
-hal_notch_filter	include/hal_intf.h	/^	void (*hal_notch_filter)(_adapter *adapter, bool enable);$/;"	m	struct:hal_ops
-hal_notch_filter_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^void hal_notch_filter_8723d(_adapter *adapter, bool enable)$/;"	f
-hal_ops	include/hal_intf.h	/^struct hal_ops {$/;"	s
-hal_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter)$/;"	f
-hal_power_off	include/hal_intf.h	/^	void	(*hal_power_off)(_adapter *padapter);$/;"	m	struct:hal_ops
-hal_power_on	include/hal_intf.h	/^	u32(*hal_power_on)(_adapter *padapter);$/;"	m	struct:hal_ops
-hal_ra_info_dump	hal/rtl8723d/rtl8723d_hal_init.c	/^void hal_ra_info_dump(_adapter *padapter , void *sel)$/;"	f
-hal_read_mac_hidden_rpt	hal/hal_com.c	/^int hal_read_mac_hidden_rpt(_adapter *adapter)$/;"	f
-hal_set_crystal_cap	hal/hal_com.c	/^void hal_set_crystal_cap(_adapter *adapter, u8 crystal_cap)$/;"	f
-hal_spec	include/hal_data.h	/^	struct hal_spec_t hal_spec;$/;"	m	struct:hal_com_data	typeref:struct:hal_com_data::hal_spec_t
-hal_spec_init	hal/hal_com.c	/^int hal_spec_init(_adapter *adapter)$/;"	f
-hal_spec_t	include/hal_data.h	/^struct hal_spec_t {$/;"	s
-hal_xmit	include/hal_intf.h	/^	s32(*hal_xmit)(_adapter *padapter, struct xmit_frame *pxmitframe);$/;"	m	struct:hal_ops
-hal_xmit_handler	include/rtl8188f_xmit.h	305;"	d
-hal_xmit_handler	include/rtl8188f_xmit.h	310;"	d
-hal_xmit_handler	include/rtl8192e_xmit.h	366;"	d
-hal_xmit_handler	include/rtl8703b_xmit.h	305;"	d
-hal_xmit_handler	include/rtl8703b_xmit.h	310;"	d
-hal_xmit_handler	include/rtl8723b_xmit.h	305;"	d
-hal_xmit_handler	include/rtl8723b_xmit.h	310;"	d
-hal_xmit_handler	include/rtl8723d_xmit.h	492;"	d
-hal_xmit_handler	include/rtl8723d_xmit.h	497;"	d
-hal_xmitframe_enqueue	include/hal_intf.h	/^	s32(*hal_xmitframe_enqueue)(_adapter *padapter, struct xmit_frame *pxmitframe);$/;"	m	struct:hal_ops
-halbt_init_hw_config92C	hal/hal_btcoex.c	/^static void halbt_init_hw_config92C(PADAPTER padapter)$/;"	f	file:
-halbt_init_hw_config92D	hal/hal_btcoex.c	/^static void halbt_init_hw_config92D(PADAPTER padapter)$/;"	f	file:
-halbtc8188c2ant_ActionA2dp	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionA2dp($/;"	f
-halbtc8188c2ant_ActionA2dpBc4	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionA2dpBc4($/;"	f
-halbtc8188c2ant_ActionA2dpBc8	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionA2dpBc8($/;"	f
-halbtc8188c2ant_ActionAlgorithm	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionAlgorithm($/;"	f
-halbtc8188c2ant_ActionHid	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionHid($/;"	f
-halbtc8188c2ant_ActionHidA2dp	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionHidA2dp($/;"	f
-halbtc8188c2ant_ActionHidA2dpBc4	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionHidA2dpBc4($/;"	f
-halbtc8188c2ant_ActionHidA2dpBc8	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionHidA2dpBc8($/;"	f
-halbtc8188c2ant_ActionHidPan	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionHidPan($/;"	f
-halbtc8188c2ant_ActionHidPanBc4	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionHidPanBc4($/;"	f
-halbtc8188c2ant_ActionHidPanBc8	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionHidPanBc8(	$/;"	f
-halbtc8188c2ant_ActionPan	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionPan($/;"	f
-halbtc8188c2ant_ActionPanA2dp	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionPanA2dp($/;"	f
-halbtc8188c2ant_ActionPanA2dpBc4	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionPanA2dpBc4($/;"	f
-halbtc8188c2ant_ActionPanA2dpBc8	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionPanA2dpBc8(	$/;"	f
-halbtc8188c2ant_ActionPanBc4	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionPanBc4($/;"	f
-halbtc8188c2ant_ActionPanBc8	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionPanBc8($/;"	f
-halbtc8188c2ant_ActionSco	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_ActionSco($/;"	f
-halbtc8188c2ant_AdcBackOff	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_AdcBackOff($/;"	f
-halbtc8188c2ant_AgcTable	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_AgcTable($/;"	f
-halbtc8188c2ant_Balance	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_Balance($/;"	f
-halbtc8188c2ant_CoexAllOff	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_CoexAllOff($/;"	f
-halbtc8188c2ant_CoexTable	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_CoexTable($/;"	f
-halbtc8188c2ant_DacSwing	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_DacSwing($/;"	f
-halbtc8188c2ant_DiminishWifi	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_DiminishWifi($/;"	f
-halbtc8188c2ant_InitCoexDm	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_InitCoexDm($/;"	f
-halbtc8188c2ant_LowPenaltyRa	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_LowPenaltyRa($/;"	f
-halbtc8188c2ant_MonitorBtState	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_MonitorBtState($/;"	f
-halbtc8188c2ant_RfShrink	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_RfShrink($/;"	f
-halbtc8188c2ant_SetAdcBackOff	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetAdcBackOff($/;"	f
-halbtc8188c2ant_SetAgcTable	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetAgcTable($/;"	f
-halbtc8188c2ant_SetCoexTable	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetCoexTable($/;"	f
-halbtc8188c2ant_SetFwBalance	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetFwBalance($/;"	f
-halbtc8188c2ant_SetFwDiminishWifi	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetFwDiminishWifi($/;"	f
-halbtc8188c2ant_SetSwFullTimeDacSwing	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetSwFullTimeDacSwing($/;"	f
-halbtc8188c2ant_SetSwPenaltyTxRateAdaptive	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetSwPenaltyTxRateAdaptive($/;"	f
-halbtc8188c2ant_SetSwRfRxLpfCorner	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_SetSwRfRxLpfCorner($/;"	f
-halbtc8188c2ant_WifiRssiState	hal/btc/HalBtc8188c2Ant.c	/^halbtc8188c2ant_WifiRssiState($/;"	f
-halbtc8192d2ant_ActionA2dp	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionA2dp($/;"	f
-halbtc8192d2ant_ActionAlgorithm	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionAlgorithm($/;"	f
-halbtc8192d2ant_ActionHid	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionHid($/;"	f
-halbtc8192d2ant_ActionHidA2dp	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionHidA2dp($/;"	f
-halbtc8192d2ant_ActionHidPan	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionHidPan($/;"	f
-halbtc8192d2ant_ActionHidPanBc4	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionHidPanBc4($/;"	f
-halbtc8192d2ant_ActionHidPanBc8	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionHidPanBc8(	$/;"	f
-halbtc8192d2ant_ActionPan	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionPan($/;"	f
-halbtc8192d2ant_ActionPanA2dp	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionPanA2dp($/;"	f
-halbtc8192d2ant_ActionPanA2dpBc4	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionPanA2dpBc4($/;"	f
-halbtc8192d2ant_ActionPanA2dpBc8	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionPanA2dpBc8(	$/;"	f
-halbtc8192d2ant_ActionSco	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_ActionSco($/;"	f
-halbtc8192d2ant_AdcBackOff	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_AdcBackOff($/;"	f
-halbtc8192d2ant_AgcTable	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_AgcTable($/;"	f
-halbtc8192d2ant_Balance	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_Balance($/;"	f
-halbtc8192d2ant_CoexAllOff	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_CoexAllOff($/;"	f
-halbtc8192d2ant_CoexTable	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_CoexTable($/;"	f
-halbtc8192d2ant_DacSwing	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_DacSwing($/;"	f
-halbtc8192d2ant_DiminishWifi	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_DiminishWifi($/;"	f
-halbtc8192d2ant_InitCoexDm	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_InitCoexDm($/;"	f
-halbtc8192d2ant_IsBtCoexistEnter	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_IsBtCoexistEnter($/;"	f
-halbtc8192d2ant_LowPenaltyRa	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_LowPenaltyRa($/;"	f
-halbtc8192d2ant_MonitorBtEnableDisable	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_MonitorBtEnableDisable($/;"	f
-halbtc8192d2ant_MonitorBtState	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_MonitorBtState($/;"	f
-halbtc8192d2ant_RfShrink	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_RfShrink($/;"	f
-halbtc8192d2ant_SetAdcBackOff	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetAdcBackOff($/;"	f
-halbtc8192d2ant_SetAgcTable	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetAgcTable($/;"	f
-halbtc8192d2ant_SetCoexTable	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetCoexTable($/;"	f
-halbtc8192d2ant_SetFwBalance	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetFwBalance($/;"	f
-halbtc8192d2ant_SetFwDiminishWifi	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetFwDiminishWifi($/;"	f
-halbtc8192d2ant_SetSwFullTimeDacSwing	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetSwFullTimeDacSwing($/;"	f
-halbtc8192d2ant_SetSwPenaltyTxRateAdaptive	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetSwPenaltyTxRateAdaptive($/;"	f
-halbtc8192d2ant_SetSwRfRxLpfCorner	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_SetSwRfRxLpfCorner($/;"	f
-halbtc8192d2ant_WifiRssiState	hal/btc/HalBtc8192d2Ant.c	/^halbtc8192d2ant_WifiRssiState($/;"	f
-halbtc8192e1ant_action_algorithm	hal/btc/HalBtc8192e1Ant.c	/^u8 halbtc8192e1ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_action_bt_inquiry	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_action_bt_sco_hid_only_busy	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8192e1ant_action_hs	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_action_wifi_connected	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_action_wifi_connected_bt_acl_busy	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8192e1ant_action_wifi_connected_scan	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8192e1ant_action_wifi_connected_specific_packet	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_connected_specific_packet($/;"	f
-halbtc8192e1ant_action_wifi_multi_port	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_action_wifi_not_connected	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_action_wifi_not_connected_asso_auth	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_not_connected_asso_auth($/;"	f
-halbtc8192e1ant_action_wifi_not_connected_scan	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_not_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8192e1ant_action_wifi_only	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_ampdu_max_time	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_auto_rate_fallback_retry	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_bt_auto_report	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_bt_rssi_state	hal/btc/HalBtc8192e1Ant.c	/^u8 halbtc8192e1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8192e1ant_coex_all_off	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_coex_table	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_coex_table_with_type	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_ignore_wlan_act	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_init_coex_dm	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_init_hw_config	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_is_common_action	hal/btc/HalBtc8192e1Ant.c	/^boolean halbtc8192e1ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_is_wifi_status_changed	hal/btc/HalBtc8192e1Ant.c	/^boolean halbtc8192e1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_limited_rx	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_limited_tx	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_low_penalty_ra	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_lps_rpwm	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_monitor_bt_ctr	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_monitor_bt_enable_disable	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_monitor_wifi_ctr	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_power_save_state	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_ps_tdma	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8192e1ant_query_bt_info	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_retry_limit	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_run_coexist_mechanism	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_run_sw_coexist_mechanism	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_set_ant_path	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_set_bt_auto_report	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_set_coex_table	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_set_fw_pstdma	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_set_lps_rpwm	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8192e1ant_sw_mechanism	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_sw_mechanism(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_tdma_duration_adjust_for_acl	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_tdma_duration_adjust_for_acl(IN struct btc_coexist$/;"	f
-halbtc8192e1ant_update_bt_link_info	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e1ant_update_ra_mask	hal/btc/HalBtc8192e1Ant.c	/^void halbtc8192e1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e1ant_wifi_rssi_state	hal/btc/HalBtc8192e1Ant.c	/^u8 halbtc8192e1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_action_a2dp	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_a2dp_pan_hs	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_algorithm	hal/btc/HalBtc8192e2Ant.c	/^u8 halbtc8192e2ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_bt_inquiry	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_hid	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_hid_a2dp	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_hid_a2dp_pan_edr	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_pan_edr	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_pan_edr_a2dp	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_pan_edr_hid	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_pan_hs	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_sco	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_action_sco_pan	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_action_sco_pan(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_adc_back_off	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_agc_table	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_ampdu_max_time	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_auto_rate_fallback_retry	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_bt_auto_report	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_bt_rssi_state	hal/btc/HalBtc8192e2Ant.c	/^u8 halbtc8192e2ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8192e2ant_coex_all_off	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_coex_table	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_coex_table_with_type	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_dac_swing	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_dac_swing(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_dec_bt_pwr	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_decide_ra_mask	hal/btc/HalBtc8192e2Ant.c	/^u32 halbtc8192e2ant_decide_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_fw_dac_swing_lvl	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_get_bt_rssi_threshold	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_get_bt_rssi_threshold(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_ignore_wlan_act	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_init_coex_dm	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_init_hw_config	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_is_common_action	hal/btc/HalBtc8192e2Ant.c	/^boolean halbtc8192e2ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_is_wifi_status_changed	hal/btc/HalBtc8192e2Ant.c	/^boolean halbtc8192e2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_limited_rx	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_limited_tx	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_low_penalty_ra	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_lps_rpwm	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_monitor_bt_ctr	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_monitor_bt_enable_disable	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_power_save_state	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_ps_tdma	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8192e2ant_query_bt_info	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_retry_limit	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_rf_shrink	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_rf_shrink(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_run_coexist_mechanism	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_set_adc_back_off	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_agc_table	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_ant_path	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_bt_auto_report	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_coex_table	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_dac_swing_reg	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_fw_dac_swing_level	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_fw_dec_bt_pwr	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_fw_pstdma	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_lps_rpwm	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_sw_full_time_dac_swing	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_sw_full_time_dac_swing(IN struct btc_coexist$/;"	f
-halbtc8192e2ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8192e2ant_set_sw_rf_rx_lpf_corner	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_set_switch_ss_type	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_set_switch_ss_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_sw_mechanism1	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_sw_mechanism2	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_switch_ss_type	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_switch_ss_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_tdma_duration_adjust	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_tdma_duration_adjust_for_wifi_rssi_low	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_tdma_duration_adjust_for_wifi_rssi_low($/;"	f
-halbtc8192e2ant_update_bt_link_info	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8192e2ant_update_ra_mask	hal/btc/HalBtc8192e2Ant.c	/^void halbtc8192e2ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8192e2ant_wifi_rssi_state	hal/btc/HalBtc8192e2Ant.c	/^u8 halbtc8192e2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_action_algorithm	hal/btc/HalBtc8703b1Ant.c	/^u8 halbtc8703b1ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_action_bt_inquiry	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_action_bt_sco_hid_only_busy	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8703b1ant_action_bt_whck_test	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_action_hs	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_action_wifi_connected	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_action_wifi_connected_bt_acl_busy	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8703b1ant_action_wifi_connected_scan	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8703b1ant_action_wifi_connected_specific_packet	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_connected_specific_packet($/;"	f
-halbtc8703b1ant_action_wifi_multi_port	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_action_wifi_not_connected	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_action_wifi_not_connected_asso_auth	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_not_connected_asso_auth($/;"	f
-halbtc8703b1ant_action_wifi_not_connected_scan	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_not_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8703b1ant_action_wifi_only	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_ampdu_max_time	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_auto_rate_fallback_retry	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_bt_auto_report	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_bt_rssi_state	hal/btc/HalBtc8703b1Ant.c	/^u8 halbtc8703b1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8703b1ant_coex_table	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_coex_table_with_type	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_enable_gnt_to_gpio	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ignore_wlan_act	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_init_coex_dm	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_init_hw_config	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_is_common_action	hal/btc/HalBtc8703b1Ant.c	/^boolean halbtc8703b1ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_is_wifibt_status_changed	hal/btc/HalBtc8703b1Ant.c	/^boolean halbtc8703b1ant_is_wifibt_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_limited_rx	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_limited_tx	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_low_penalty_ra	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_lps_rpwm	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_enable	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_indirect_read_reg	hal/btc/HalBtc8703b1Ant.c	/^u32 halbtc8703b1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_indirect_write_reg	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ltecoex_indirect_write_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_pathcontrol_owner	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_set_break_table	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_set_coex_table	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_set_gnt_bt	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ltecoex_set_gnt_wl	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_monitor_bt_ctr	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_monitor_bt_enable_disable	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_monitor_wifi_ctr	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_post_activestate_to_bt	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_post_activestate_to_bt($/;"	f
-halbtc8703b1ant_post_onoffState_to_bt	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_post_onoffState_to_bt($/;"	f
-halbtc8703b1ant_power_save_state	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ps_tdma	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8703b1ant_psd_getdata	hal/btc/HalBtc8703b1Ant.c	/^u32 halbtc8703b1ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)$/;"	f
-halbtc8703b1ant_psd_log2base	hal/btc/HalBtc8703b1Ant.c	/^u32 halbtc8703b1ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)$/;"	f
-halbtc8703b1ant_psd_maxholddata	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_psd_maxholddata(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_psd_showdata	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_psd_showdata(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_psd_sweep_point	hal/btc/HalBtc8703b1Ant.c	/^boolean halbtc8703b1ant_psd_sweep_point(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_query_bt_info	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_read_score_board	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_read_score_board($/;"	f
-halbtc8703b1ant_retry_limit	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_run_coexist_mechanism	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_run_sw_coexist_mechanism	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_set_ant_path	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_set_bt_auto_report	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_set_coex_table	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_set_fw_low_penalty_ra	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_set_fw_low_penalty_ra(IN struct btc_coexist$/;"	f
-halbtc8703b1ant_set_fw_pstdma	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_set_lps_rpwm	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_sw_mechanism	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_sw_mechanism(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_update_bt_link_info	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8703b1ant_update_ra_mask	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_update_wifi_channel_info	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_wifi_rssi_state	hal/btc/HalBtc8703b1Ant.c	/^u8 halbtc8703b1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8703b1ant_write_score_board	hal/btc/HalBtc8703b1Ant.c	/^void halbtc8703b1ant_write_score_board($/;"	f
-halbtc8723a1ant_BtEnableAction	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_BtEnableAction($/;"	f
-halbtc8723a1ant_CoexAllOff	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_CoexAllOff($/;"	f
-halbtc8723a1ant_CoexForWifiConnect	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_CoexForWifiConnect($/;"	f
-halbtc8723a1ant_CoexTable	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_CoexTable($/;"	f
-halbtc8723a1ant_IgnoreWlanAct	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_IgnoreWlanAct($/;"	f
-halbtc8723a1ant_InitCoexDm	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_InitCoexDm($/;"	f
-halbtc8723a1ant_LowPenaltyRa	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_LowPenaltyRa($/;"	f
-halbtc8723a1ant_MonitorBtCtr	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_MonitorBtCtr($/;"	f
-halbtc8723a1ant_MonitorBtEnableDisable	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_MonitorBtEnableDisable($/;"	f
-halbtc8723a1ant_NotifyFwScan	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_NotifyFwScan($/;"	f
-halbtc8723a1ant_PsTdma	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_PsTdma($/;"	f
-halbtc8723a1ant_QueryBtInfo	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_QueryBtInfo($/;"	f
-halbtc8723a1ant_Reg0x550Bit3	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_Reg0x550Bit3($/;"	f
-halbtc8723a1ant_RfShrink	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_RfShrink($/;"	f
-halbtc8723a1ant_SetCoexTable	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_SetCoexTable($/;"	f
-halbtc8723a1ant_SetFwIgnoreWlanAct	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_SetFwIgnoreWlanAct($/;"	f
-halbtc8723a1ant_SetFwPstdma	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_SetFwPstdma($/;"	f
-halbtc8723a1ant_SetSwPenaltyTxRateAdaptive	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_SetSwPenaltyTxRateAdaptive($/;"	f
-halbtc8723a1ant_SetSwRfRxLpfCorner	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_SetSwRfRxLpfCorner($/;"	f
-halbtc8723a1ant_TdmaDurationAdjust	hal/btc/HalBtc8723a1Ant.c	/^halbtc8723a1ant_TdmaDurationAdjust($/;"	f
-halbtc8723a2ant_ActionA2dp	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionA2dp($/;"	f
-halbtc8723a2ant_ActionAlgorithm	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionAlgorithm($/;"	f
-halbtc8723a2ant_ActionHid	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionHid($/;"	f
-halbtc8723a2ant_ActionHidA2dp	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionHidA2dp($/;"	f
-halbtc8723a2ant_ActionHidA2dpPanEdr	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionHidA2dpPanEdr($/;"	f
-halbtc8723a2ant_ActionPanEdr	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionPanEdr($/;"	f
-halbtc8723a2ant_ActionPanEdrA2dp	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionPanEdrA2dp($/;"	f
-halbtc8723a2ant_ActionPanEdrHid	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionPanEdrHid($/;"	f
-halbtc8723a2ant_ActionPanHs	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionPanHs($/;"	f
-halbtc8723a2ant_ActionSco	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_ActionSco($/;"	f
-halbtc8723a2ant_AdcBackOff	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_AdcBackOff($/;"	f
-halbtc8723a2ant_AgcTable	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_AgcTable($/;"	f
-halbtc8723a2ant_BtEnableAction	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_BtEnableAction($/;"	f
-halbtc8723a2ant_BtInquiryPage	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_BtInquiryPage($/;"	f
-halbtc8723a2ant_BtRssiState	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_BtRssiState($/;"	f
-halbtc8723a2ant_CoexAllOff	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_CoexAllOff($/;"	f
-halbtc8723a2ant_CoexTable	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_CoexTable($/;"	f
-halbtc8723a2ant_DacSwing	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_DacSwing($/;"	f
-halbtc8723a2ant_DecBtPwr	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_DecBtPwr($/;"	f
-halbtc8723a2ant_FwDacSwingLvl	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_FwDacSwingLvl($/;"	f
-halbtc8723a2ant_IgnoreWlanAct	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_IgnoreWlanAct($/;"	f
-halbtc8723a2ant_IndicateWifiChnlBwInfo	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_IndicateWifiChnlBwInfo($/;"	f
-halbtc8723a2ant_InitCoexDm	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_InitCoexDm($/;"	f
-halbtc8723a2ant_IsCommonAction	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_IsCommonAction($/;"	f
-halbtc8723a2ant_IsWifiConnectedIdle	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_IsWifiConnectedIdle($/;"	f
-halbtc8723a2ant_IsWifiIdle	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_IsWifiIdle($/;"	f
-halbtc8723a2ant_LowPenaltyRa	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_LowPenaltyRa($/;"	f
-halbtc8723a2ant_MonitorBtCtr	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_MonitorBtCtr($/;"	f
-halbtc8723a2ant_MonitorBtEnableDisable	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_MonitorBtEnableDisable($/;"	f
-halbtc8723a2ant_NeedToDecBtPwr	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_NeedToDecBtPwr($/;"	f
-halbtc8723a2ant_PsTdma	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_PsTdma($/;"	f
-halbtc8723a2ant_QueryBtInfo	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_QueryBtInfo($/;"	f
-halbtc8723a2ant_RfShrink	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_RfShrink($/;"	f
-halbtc8723a2ant_RunCoexistMechanism	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_RunCoexistMechanism($/;"	f
-halbtc8723a2ant_SetAdcBackOff	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetAdcBackOff($/;"	f
-halbtc8723a2ant_SetAgcTable	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetAgcTable($/;"	f
-halbtc8723a2ant_SetCoexTable	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetCoexTable($/;"	f
-halbtc8723a2ant_SetFwDacSwingLevel	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetFwDacSwingLevel($/;"	f
-halbtc8723a2ant_SetFwDecBtPwr	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetFwDecBtPwr($/;"	f
-halbtc8723a2ant_SetFwIgnoreWlanAct	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetFwIgnoreWlanAct($/;"	f
-halbtc8723a2ant_SetFwPstdma	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetFwPstdma($/;"	f
-halbtc8723a2ant_SetSwFullTimeDacSwing	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetSwFullTimeDacSwing($/;"	f
-halbtc8723a2ant_SetSwPenaltyTxRateAdaptive	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetSwPenaltyTxRateAdaptive($/;"	f
-halbtc8723a2ant_SetSwRfRxLpfCorner	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_SetSwRfRxLpfCorner($/;"	f
-halbtc8723a2ant_TdmaDurationAdjust	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_TdmaDurationAdjust($/;"	f
-halbtc8723a2ant_WifiRssiState	hal/btc/HalBtc8723a2Ant.c	/^halbtc8723a2ant_WifiRssiState($/;"	f
-halbtc8723b1ant_action_bt_inquiry	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_action_bt_sco_hid_only_busy	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_action_bt_whck_test	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_action_hs	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_action_wifi_connected	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_action_wifi_connected_bt_acl_busy	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_action_wifi_connected_scan	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_action_wifi_connected_specific_packet	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_connected_specific_packet($/;"	f
-halbtc8723b1ant_action_wifi_multi_port	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_action_wifi_not_connected	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_action_wifi_not_connected_asso_auth	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_not_connected_asso_auth($/;"	f
-halbtc8723b1ant_action_wifi_not_connected_scan	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_not_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_action_wifi_only	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_ampdu_max_time	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_auto_rate_fallback_retry	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_bt_auto_report	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_coex_table	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_coex_table_with_type	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_ignore_wlan_act	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_init_coex_dm	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_init_hw_config	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_is_wifi_status_changed	hal/btc/HalBtc8723b1Ant.c	/^boolean halbtc8723b1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_limited_rx	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_limited_tx	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_low_penalty_ra	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_lps_rpwm	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_mechanism_switch	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_mechanism_switch(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_monitor_bt_ctr	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_monitor_bt_enable_disable	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_monitor_wifi_ctr	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_power_save_state	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_ps_tdma	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8723b1ant_psd_antenna_detection	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_psd_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_psd_antenna_detection_check	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_psd_antenna_detection_check(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_psd_getdata	hal/btc/HalBtc8723b1Ant.c	/^u32 halbtc8723b1ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)$/;"	f
-halbtc8723b1ant_psd_log2base	hal/btc/HalBtc8723b1Ant.c	/^u32 halbtc8723b1ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)$/;"	f
-halbtc8723b1ant_psd_max_holddata	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_psd_max_holddata(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_psd_show_antenna_detect_result	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_psd_show_antenna_detect_result(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_psd_showdata	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_psd_showdata(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_psd_sweep_point	hal/btc/HalBtc8723b1Ant.c	/^boolean halbtc8723b1ant_psd_sweep_point(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_query_bt_info	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_retry_limit	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_run_coexist_mechanism	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_set_ant_path	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_set_bt_auto_report	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_set_coex_table	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_set_fw_pstdma	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_set_lps_rpwm	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_sw_mechanism	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_sw_mechanism(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b1ant_tdma_duration_adjust_for_acl	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_tdma_duration_adjust_for_acl(IN struct btc_coexist$/;"	f
-halbtc8723b1ant_update_bt_link_info	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b1ant_update_ra_mask	hal/btc/HalBtc8723b1Ant.c	/^void halbtc8723b1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_action_a2dp	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_a2dp_pan_hs	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_algorithm	hal/btc/HalBtc8723b2Ant.c	/^u8 halbtc8723b2ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_bt_inquiry	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_bt_whck_test	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_hid	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_hid_a2dp	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_hid_a2dp_pan_edr	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_pan_edr	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_pan_edr_a2dp	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_pan_edr_hid	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_pan_hs	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_sco	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_wifi_idle_process	hal/btc/HalBtc8723b2Ant.c	/^boolean halbtc8723b2ant_action_wifi_idle_process(IN struct btc_coexist$/;"	f
-halbtc8723b2ant_action_wifi_link_process	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_wifi_link_process(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_action_wifi_multi_port	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_adc_back_off	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_agc_table	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_bt_auto_report	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_bt_rssi_state	hal/btc/HalBtc8723b2Ant.c	/^u8 halbtc8723b2ant_bt_rssi_state(u8 *ppre_bt_rssi_state, u8 level_num,$/;"	f
-halbtc8723b2ant_coex_all_off	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_coex_table	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_coex_table_with_type	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_dac_swing	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_dac_swing(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_dec_bt_pwr	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_fw_dac_swing_lvl	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_ignore_wlan_act	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_init_coex_dm	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_init_hw_config	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_is_common_action	hal/btc/HalBtc8723b2Ant.c	/^boolean halbtc8723b2ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_is_wifi_status_changed	hal/btc/HalBtc8723b2Ant.c	/^boolean halbtc8723b2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_limited_rx	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_low_penalty_ra	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_lps_rpwm	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_monitor_bt_ctr	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_monitor_bt_enable_disable	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_monitor_wifi_ctr	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_power_save_state	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_ps_tdma	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8723b2ant_query_bt_info	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_rf_shrink	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_rf_shrink(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_run_coexist_mechanism	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_set_adc_back_off	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_agc_table	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_ant_path	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_bt_auto_report	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_coex_table	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_dac_swing_reg	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_fw_dac_swing_level	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_fw_dec_bt_pwr	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_fw_pstdma	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_lps_rpwm	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_set_sw_full_time_dac_swing	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_sw_full_time_dac_swing(IN struct btc_coexist$/;"	f
-halbtc8723b2ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8723b2ant_set_sw_rf_rx_lpf_corner	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_sw_mechanism1	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_sw_mechanism2	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_tdma_duration_adjust	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723b2ant_update_bt_link_info	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_wifi_off_hw_cfg	hal/btc/HalBtc8723b2Ant.c	/^void halbtc8723b2ant_wifi_off_hw_cfg(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723b2ant_wifi_rssi_state	hal/btc/HalBtc8723b2Ant.c	/^u8 halbtc8723b2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_action_algorithm	hal/btc/halbtc8723d1ant.c	/^u8 halbtc8723d1ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_bt_hs	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_bt_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_bt_idle	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_bt_idle(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_bt_inquiry	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_bt_relink	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_bt_relink(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_bt_sco_hid_only_busy	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_action_bt_whql_test	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_wifi_connected	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_wifi_connected_bt_acl_busy	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_action_wifi_linkscan_process	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_wifi_linkscan_process(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_action_wifi_multi_port	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_wifi_not_connected	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_action_wifi_only	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_ampdu_max_time	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_auto_rate_fallback_retry	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_bt_auto_report	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_bt_rssi_state	hal/btc/halbtc8723d1ant.c	/^u8 halbtc8723d1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8723d1ant_coex_table	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_coex_table_with_type	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_enable_gnt_to_gpio	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ignore_wlan_act	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_init_coex_dm	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_init_hw_config	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_is_common_action	hal/btc/halbtc8723d1ant.c	/^boolean halbtc8723d1ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_is_wifibt_status_changed	hal/btc/halbtc8723d1ant.c	/^boolean halbtc8723d1ant_is_wifibt_status_changed(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_limited_rx	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_limited_tx	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_low_penalty_ra	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_lps_rpwm	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ltecoex_enable	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ltecoex_indirect_read_reg	hal/btc/halbtc8723d1ant.c	/^u32 halbtc8723d1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ltecoex_indirect_write_reg	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ltecoex_indirect_write_reg(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_ltecoex_pathcontrol_owner	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ltecoex_set_break_table	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ltecoex_set_coex_table	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ltecoex_set_gnt_bt	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ltecoex_set_gnt_wl	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_monitor_bt_ctr	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_monitor_bt_enable_disable	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_monitor_wifi_ctr	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_post_state_to_bt	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_post_state_to_bt($/;"	f
-halbtc8723d1ant_power_save_state	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ps_tdma	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_ps_tdma_check_for_power_save_state	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8723d1ant_psd_antenna_detection	hal/btc/halbtc8723d1ant.c	/^boolean halbtc8723d1ant_psd_antenna_detection(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_psd_antenna_detection_check	hal/btc/halbtc8723d1ant.c	/^boolean halbtc8723d1ant_psd_antenna_detection_check(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_psd_getdata	hal/btc/halbtc8723d1ant.c	/^u32 halbtc8723d1ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)$/;"	f
-halbtc8723d1ant_psd_log2base	hal/btc/halbtc8723d1ant.c	/^u32 halbtc8723d1ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)$/;"	f
-halbtc8723d1ant_psd_maxholddata	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_psd_maxholddata(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_psd_show_antenna_detect_result	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_psd_show_antenna_detect_result(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_psd_showdata	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_psd_showdata(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_psd_sweep_point	hal/btc/halbtc8723d1ant.c	/^boolean halbtc8723d1ant_psd_sweep_point(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_query_bt_info	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_read_score_board	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_read_score_board($/;"	f
-halbtc8723d1ant_retry_limit	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_run_coexist_mechanism	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_run_sw_coexist_mechanism	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_set_ant_path	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_set_bt_auto_report	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_set_coex_table	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_set_fw_ignore_wlan_act	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_set_fw_low_penalty_ra	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_fw_low_penalty_ra(IN struct btc_coexist$/;"	f
-halbtc8723d1ant_set_fw_pstdma	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_set_lps_rpwm	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_set_wltoggle_coex_table	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_update_bt_link_info	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d1ant_update_ra_mask	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_update_wifi_channel_info	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_wifi_rssi_state	hal/btc/halbtc8723d1ant.c	/^u8 halbtc8723d1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d1ant_write_score_board	hal/btc/halbtc8723d1ant.c	/^void halbtc8723d1ant_write_score_board($/;"	f
-halbtc8723d2ant_action_a2dp	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_a2dp_pan_hs	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_algorithm	hal/btc/halbtc8723d2ant.c	/^u8 halbtc8723d2ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_bt_hs	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_bt_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_bt_idle	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_bt_idle(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_bt_inquiry	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_bt_relink	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_bt_relink(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_bt_whql_test	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_bt_whql_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_coex_all_off	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_hid	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_hid_a2dp	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_hid_a2dp_pan_edr	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_pan_edr	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_pan_edr_a2dp	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_pan_edr_hid	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_sco	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_wifi_connected	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_wifi_linkscan_process	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_wifi_linkscan_process(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_wifi_multi_port	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_action_wifi_not_connected	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_bt_auto_report	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_bt_rssi_state	hal/btc/halbtc8723d2ant.c	/^u8 halbtc8723d2ant_bt_rssi_state(u8 *ppre_bt_rssi_state, u8 level_num,$/;"	f
-halbtc8723d2ant_coex_switch_threshold	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_coex_switch_threshold(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_coex_table	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_coex_table_with_type	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_dec_bt_pwr	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_enable_gnt_to_gpio	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_fw_dac_swing_lvl	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ignore_wlan_act	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_init_coex_dm	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_init_hw_config	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_is_wifibt_status_changed	hal/btc/halbtc8723d2ant.c	/^boolean halbtc8723d2ant_is_wifibt_status_changed(IN struct btc_coexist$/;"	f
-halbtc8723d2ant_limited_rx	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_low_penalty_ra	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_lps_rpwm	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ltecoex_enable	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ltecoex_enable(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ltecoex_indirect_read_reg	hal/btc/halbtc8723d2ant.c	/^u32 halbtc8723d2ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ltecoex_indirect_write_reg	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ltecoex_indirect_write_reg(IN struct btc_coexist$/;"	f
-halbtc8723d2ant_ltecoex_pathcontrol_owner	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ltecoex_set_break_table	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ltecoex_set_coex_table	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ltecoex_set_gnt_bt	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ltecoex_set_gnt_wl	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_monitor_bt_ctr	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_monitor_bt_enable_disable	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_monitor_wifi_ctr	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_post_state_to_bt	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_post_state_to_bt($/;"	f
-halbtc8723d2ant_power_save_state	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ps_tdma	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_ps_tdma_check_for_power_save_state	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8723d2ant_psd_antenna_detection	hal/btc/halbtc8723d2ant.c	/^boolean halbtc8723d2ant_psd_antenna_detection(IN struct btc_coexist$/;"	f
-halbtc8723d2ant_psd_antenna_detection_check	hal/btc/halbtc8723d2ant.c	/^boolean halbtc8723d2ant_psd_antenna_detection_check(IN struct btc_coexist$/;"	f
-halbtc8723d2ant_psd_getdata	hal/btc/halbtc8723d2ant.c	/^u32 halbtc8723d2ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)$/;"	f
-halbtc8723d2ant_psd_log2base	hal/btc/halbtc8723d2ant.c	/^u32 halbtc8723d2ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)$/;"	f
-halbtc8723d2ant_psd_maxholddata	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_psd_maxholddata(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_psd_show_antenna_detect_result	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_psd_show_antenna_detect_result(IN struct btc_coexist$/;"	f
-halbtc8723d2ant_psd_showdata	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_psd_showdata(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_psd_sweep_point	hal/btc/halbtc8723d2ant.c	/^boolean halbtc8723d2ant_psd_sweep_point(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_query_bt_info	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_read_score_board	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_read_score_board($/;"	f
-halbtc8723d2ant_run_coexist_mechanism	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_set_ant_path	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_bt_auto_report	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_coex_table	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_fw_dac_swing_level	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_fw_dec_bt_pwr	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_fw_ignore_wlan_act	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_fw_low_penalty_ra	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_fw_low_penalty_ra(IN struct btc_coexist$/;"	f
-halbtc8723d2ant_set_fw_pstdma	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_lps_rpwm	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_set_wltoggle_coex_table	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_set_wltoggle_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_update_bt_link_info	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8723d2ant_update_wifi_channel_info	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_wifi_rssi_state	hal/btc/halbtc8723d2ant.c	/^u8 halbtc8723d2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8723d2ant_write_score_board	hal/btc/halbtc8723d2ant.c	/^void halbtc8723d2ant_write_score_board($/;"	f
-halbtc8812a1ant_action_algorithm	hal/btc/HalBtc8812a1Ant.c	/^u8 halbtc8812a1ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_action_bt_inquiry	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_action_bt_sco_hid_only_busy	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8812a1ant_action_hs	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_action_wifi_connected	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_action_wifi_connected_bt_acl_busy	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8812a1ant_action_wifi_connected_scan	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8812a1ant_action_wifi_connected_specific_packet	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_connected_specific_packet($/;"	f
-halbtc8812a1ant_action_wifi_multi_port	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_action_wifi_not_connected	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_action_wifi_not_connected_asso_auth	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_not_connected_asso_auth($/;"	f
-halbtc8812a1ant_action_wifi_not_connected_scan	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_not_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8812a1ant_action_wifi_only	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_ampdu_max_time	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_auto_rate_fallback_retry	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_bt_auto_report	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_bt_rssi_state	hal/btc/HalBtc8812a1Ant.c	/^u8 halbtc8812a1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8812a1ant_coex_table	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_coex_table_with_type	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_ignore_wlan_act	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_init_coex_dm	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_init_hw_config	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_is_common_action	hal/btc/HalBtc8812a1Ant.c	/^boolean halbtc8812a1ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_is_wifi_status_changed	hal/btc/HalBtc8812a1Ant.c	/^boolean halbtc8812a1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_limited_rx	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_limited_tx	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_low_penalty_ra	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_lps_rpwm	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_monitor_bt_ctr	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_monitor_bt_enable_disable	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_monitor_wifi_ctr	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_power_save_state	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_ps_tdma	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8812a1ant_query_bt_info	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_retry_limit	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_run_coexist_mechanism	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_run_sw_coexist_mechanism	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_set_ant_path	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_set_bt_auto_report	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_set_coex_table	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_set_fw_pstdma	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_set_lps_rpwm	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8812a1ant_sw_mechanism	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_sw_mechanism(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_tdma_duration_adjust_for_acl	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_tdma_duration_adjust_for_acl(IN struct btc_coexist$/;"	f
-halbtc8812a1ant_update_bt_link_info	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a1ant_update_ra_mask	hal/btc/HalBtc8812a1Ant.c	/^void halbtc8812a1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a1ant_wifi_rssi_state	hal/btc/HalBtc8812a1Ant.c	/^u8 halbtc8812a1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_action_a2dp	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_a2dp_pan_hs	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_algorithm	hal/btc/HalBtc8812a2Ant.c	/^u8 halbtc8812a2ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_bt_inquiry	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_hid	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_hid_a2dp	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_hid_a2dp_pan_edr	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_hid_a2dp_pan_hs	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_hid_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_pan_edr	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_pan_edr_a2dp	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_pan_edr_hid	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_pan_hs	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_sco	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_action_sco_hid	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_action_sco_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_adc_back_off	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_agc_table	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_ampdu_max_time	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_auto_rate_fallback_retry	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_bt_rssi_state	hal/btc/HalBtc8812a2Ant.c	/^u8 halbtc8812a2ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8812a2ant_coex_all_off	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_coex_table	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_coex_table_with_type	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_coex_under_5g	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_coex_under_5g(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_dac_swing	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_dac_swing(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_dec_bt_pwr	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_decide_ra_mask	hal/btc/HalBtc8812a2Ant.c	/^u32 halbtc8812a2ant_decide_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_fw_dac_swing_lvl	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_get_bt_rssi_threshold	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_get_bt_rssi_threshold(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_ignore_wlan_act	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_init_coex_dm	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_init_hw_config	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_is_common_action	hal/btc/HalBtc8812a2Ant.c	/^boolean halbtc8812a2ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_is_wifi_status_changed	hal/btc/HalBtc8812a2Ant.c	/^boolean halbtc8812a2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_limited_rx	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_limited_tx	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_low_penalty_ra	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_lps_rpwm	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_monitor_bt_ctr	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_monitor_bt_enable_disable	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_power_save_state	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_ps_tdma	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8812a2ant_query_bt_info	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_retry_limit	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_rf_shrink	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_rf_shrink(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_run_coexist_mechanism	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_set_adc_back_off	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_agc_table	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_ant_path	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_coex_table	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_dac_swing_reg	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_fw_dac_swing_level	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_fw_dec_bt_pwr	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_fw_pstdma	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_lps_rpwm	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_set_sw_full_time_dac_swing	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_sw_full_time_dac_swing(IN struct btc_coexist$/;"	f
-halbtc8812a2ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8812a2ant_set_sw_rf_rx_lpf_corner	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_sw_mechanism1	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_sw_mechanism2	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_tdma_duration_adjust	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_tdma_duration_adjust_for_wifi_rssi_low($/;"	f
-halbtc8812a2ant_update_bt_link_info	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8812a2ant_update_ra_mask	hal/btc/HalBtc8812a2Ant.c	/^void halbtc8812a2ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8812a2ant_wifi_rssi_state	hal/btc/HalBtc8812a2Ant.c	/^u8 halbtc8812a2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_action_a2dp	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_a2dp_pan_hs	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_algorithm	hal/btc/HalBtc8821a1Ant.c	/^u8 halbtc8821a1ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_bt_inquiry	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_bt_sco_hid_only_busy	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8821a1ant_action_bt_whck_test	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_hid	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_hid_a2dp	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_hid_a2dp_pan_edr	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_hs	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_pan_edr	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_pan_edr_a2dp	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_pan_edr_hid	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_pan_hs	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_sco	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_wifi_connected	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_wifi_connected_bt_acl_busy	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8821a1ant_action_wifi_connected_scan	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8821a1ant_action_wifi_connected_specific_packet	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_connected_specific_packet($/;"	f
-halbtc8821a1ant_action_wifi_multi_port	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_wifi_not_connected	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_action_wifi_not_connected_asso_auth	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_not_connected_asso_auth($/;"	f
-halbtc8821a1ant_action_wifi_not_connected_scan	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_not_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8821a1ant_action_wifi_only	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_ampdu_max_time	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_auto_rate_fallback_retry	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_bt_auto_report	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_bt_rssi_state	hal/btc/HalBtc8821a1Ant.c	/^u8 halbtc8821a1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8821a1ant_coex_all_off	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_coex_table	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_coex_table_with_type	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_coex_under_5g	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_coex_under_5g(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_ignore_wlan_act	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_init_coex_dm	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_init_hw_config	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_is_common_action	hal/btc/HalBtc8821a1Ant.c	/^boolean halbtc8821a1ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_is_wifi_status_changed	hal/btc/HalBtc8821a1Ant.c	/^boolean halbtc8821a1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_limited_rx	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_limited_tx	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_low_penalty_ra	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_lps_rpwm	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_monitor_bt_ctr	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_monitor_bt_enable_disable	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_power_save_state	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_ps_tdma	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8821a1ant_query_bt_info	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_retry_limit	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_run_coexist_mechanism	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_run_sw_coexist_mechanism	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_set_ant_path	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_set_bt_auto_report	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_set_coex_table	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_set_fw_pstdma	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_set_lps_rpwm	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8821a1ant_sw_mechanism	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_sw_mechanism(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_update_bt_link_info	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a1ant_update_ra_mask	hal/btc/HalBtc8821a1Ant.c	/^void halbtc8821a1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a1ant_wifi_rssi_state	hal/btc/HalBtc8821a1Ant.c	/^u8 halbtc8821a1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_action_a2dp	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_a2dp_pan_hs	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_algorithm	hal/btc/HalBtc8821a2Ant.c	/^u8 halbtc8821a2ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_bt_inquiry	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_bt_whck_test	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_hid	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_hid_a2dp	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_hid_a2dp_pan_edr	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_pan_edr	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_pan_edr_a2dp	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_pan_edr_hid	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_pan_hs	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_sco	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_wifi_idle_process	hal/btc/HalBtc8821a2Ant.c	/^boolean halbtc8821a2ant_action_wifi_idle_process(IN struct btc_coexist$/;"	f
-halbtc8821a2ant_action_wifi_link_process	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_wifi_link_process(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_action_wifi_multi_port	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_adc_back_off	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_agc_table	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_bt_auto_report	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_bt_rssi_state	hal/btc/HalBtc8821a2Ant.c	/^u8 halbtc8821a2ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8821a2ant_coex_all_off	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_coex_table	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_coex_table_with_type	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_coex_under_5g	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_coex_under_5g(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_dac_swing	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_dac_swing(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_dec_bt_pwr	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_fw_dac_swing_lvl	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_ignore_wlan_act	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_init_coex_dm	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_init_hw_config	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_is_common_action	hal/btc/HalBtc8821a2Ant.c	/^boolean halbtc8821a2ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_is_wifi_status_changed	hal/btc/HalBtc8821a2Ant.c	/^boolean halbtc8821a2ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_limited_rx	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_low_penalty_ra	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_lps_rpwm	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_monitor_bt_ctr	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_monitor_bt_enable_disable	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_monitor_wifi_ctr	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_power_save_state	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_ps_tdma	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8821a2ant_query_bt_info	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_rf_shrink	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_rf_shrink(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_run_coexist_mechanism	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_set_adc_back_off	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_agc_table	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_ant_path	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_bt_auto_report	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_coex_table	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_dac_swing_reg	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_fw_dac_swing_level	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_fw_dec_bt_pwr	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_fw_pstdma	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_lps_rpwm	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_set_sw_full_time_dac_swing	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_sw_full_time_dac_swing(IN struct btc_coexist$/;"	f
-halbtc8821a2ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8821a2ant_set_sw_rf_rx_lpf_corner	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_sw_mechanism1	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_sw_mechanism2	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_tdma_duration_adjust	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821a2ant_update_bt_link_info	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_wifi_off_hw_cfg	hal/btc/HalBtc8821a2Ant.c	/^void halbtc8821a2ant_wifi_off_hw_cfg(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821a2ant_wifi_rssi_state	hal/btc/HalBtc8821a2Ant.c	/^u8 halbtc8821a2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2Ant_AmpduMaxNum	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2Ant_AmpduMaxNum(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_action_a2dp	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_a2dp_pan_hs	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_algorithm	hal/btc/HalBtc8821aCsr2Ant.c	/^u8 halbtc8821aCsr2ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_hid	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_hid_a2dp	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_hid_a2dp_pan_edr	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist$/;"	f
-halbtc8821aCsr2ant_action_pan_edr	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_pan_edr_a2dp	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_pan_edr_hid	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_pan_hs	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_action_sco	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_adc_back_off	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_agc_table	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_ampdu_max_time	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_auto_rate_fallback_retry	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_auto_rate_fallback_retry(IN struct btc_coexist$/;"	f
-halbtc8821aCsr2ant_bt_auto_report	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_bt_inquiry_page	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_bt_inquiry_page(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_bt_rssi_state	hal/btc/HalBtc8821aCsr2Ant.c	/^u8 halbtc8821aCsr2ant_bt_rssi_state(u8 level_num, u8 rssi_thresh,$/;"	f
-halbtc8821aCsr2ant_coex_all_off	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_coex_table	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_coex_under_5g	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_coex_under_5g(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_dac_swing	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_dac_swing(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_dec_bt_pwr	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_fw_dac_swing_lvl	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_ignore_wlan_act	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_init_coex_dm	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_is_common_action	hal/btc/HalBtc8821aCsr2Ant.c	/^boolean halbtc8821aCsr2ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_limited_rx	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_limited_tx	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_low_penalty_ra	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_monitor_bt_ctr	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_monitor_bt_enable_disable	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_monitor_bt_enable_disable(IN struct btc_coexist$/;"	f
-halbtc8821aCsr2ant_need_to_dec_bt_pwr	hal/btc/HalBtc8821aCsr2Ant.c	/^boolean halbtc8821aCsr2ant_need_to_dec_bt_pwr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_ps_tdma	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_query_bt_info	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_retry_limit	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_rf_shrink	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_rf_shrink(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_run_coexist_mechanism	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821aCsr2ant_set_adc_back_off	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_adc_back_off(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_agc_table	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_agc_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_ant_path	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_bt_auto_report	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_coex_table	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_dac_swing_reg	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_dac_swing_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_fw_dac_swing_level	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_fw_dec_bt_pwr	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_fw_pstdma	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_set_sw_full_time_dac_swing	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_sw_full_time_dac_swing(IN struct btc_coexist$/;"	f
-halbtc8821aCsr2ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_sw_penalty_tx_rate_adaptive($/;"	f
-halbtc8821aCsr2ant_set_sw_rf_rx_lpf_corner	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_set_sw_rf_rx_lpf_corner(IN struct btc_coexist$/;"	f
-halbtc8821aCsr2ant_sw_mechanism1	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_sw_mechanism2	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_tdma_duration_adjust	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_tdma_duration_adjust(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_update_ra_mask	hal/btc/HalBtc8821aCsr2Ant.c	/^void halbtc8821aCsr2ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821aCsr2ant_wifi_rssi_state	hal/btc/HalBtc8821aCsr2Ant.c	/^u8 halbtc8821aCsr2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_action_algorithm	hal/btc/halbtc8821c1ant.c	/^u8 halbtc8821c1ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_bt_inquiry	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_bt_sco_hid_only_busy	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8821c1ant_action_bt_whck_test	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_hs	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_wifi_connected	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_wifi_connected_bt_acl_busy	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8821c1ant_action_wifi_connected_scan	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8821c1ant_action_wifi_connected_specific_packet	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_connected_specific_packet($/;"	f
-halbtc8821c1ant_action_wifi_multi_port	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_wifi_not_connected	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_wifi_not_connected_asso_auth	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_not_connected_asso_auth($/;"	f
-halbtc8821c1ant_action_wifi_not_connected_scan	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_not_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8821c1ant_action_wifi_only	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_action_wifi_under5g	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_action_wifi_under5g(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_ampdu_max_time	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_auto_rate_fallback_retry	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_bt_auto_report	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_bt_rssi_state	hal/btc/halbtc8821c1ant.c	/^u8 halbtc8821c1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8821c1ant_coex_table	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_coex_table_with_type	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_enable_gnt_to_gpio	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ignore_wlan_act	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_init_coex_dm	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_init_hw_config	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_is_common_action	hal/btc/halbtc8821c1ant.c	/^boolean halbtc8821c1ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_is_wifibt_status_changed	hal/btc/halbtc8821c1ant.c	/^boolean halbtc8821c1ant_is_wifibt_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_limited_rx	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_limited_tx	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_low_penalty_ra	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_lps_rpwm	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_enable	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_indirect_read_reg	hal/btc/halbtc8821c1ant.c	/^u32 halbtc8821c1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_indirect_write_reg	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ltecoex_indirect_write_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_pathcontrol_owner	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_set_break_table	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_set_coex_table	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_set_gnt_bt	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ltecoex_set_gnt_wl	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_monitor_bt_ctr	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_monitor_bt_enable_disable	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_monitor_wifi_ctr	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_post_activestate_to_bt	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_post_activestate_to_bt($/;"	f
-halbtc8821c1ant_post_onoffstate_to_bt	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_post_onoffstate_to_bt($/;"	f
-halbtc8821c1ant_power_save_state	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ps_tdma	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_ps_tdma_check_for_power_save_state	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8821c1ant_psd_antenna_detection	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_psd_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_psd_antenna_detection_check	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_psd_antenna_detection_check(IN struct btc_coexist$/;"	f
-halbtc8821c1ant_psd_getdata	hal/btc/halbtc8821c1ant.c	/^u32 halbtc8821c1ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)$/;"	f
-halbtc8821c1ant_psd_log2base	hal/btc/halbtc8821c1ant.c	/^u32 halbtc8821c1ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)$/;"	f
-halbtc8821c1ant_psd_maxholddata	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_psd_maxholddata(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_psd_show_antenna_detect_result	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_psd_show_antenna_detect_result(IN struct btc_coexist$/;"	f
-halbtc8821c1ant_psd_showdata	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_psd_showdata(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_psd_sweep_point	hal/btc/halbtc8821c1ant.c	/^boolean halbtc8821c1ant_psd_sweep_point(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_query_bt_info	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_read_score_board	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_read_score_board($/;"	f
-halbtc8821c1ant_retry_limit	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_run_coexist_mechanism	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_run_sw_coexist_mechanism	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_set_ant_path	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_set_bt_auto_report	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_set_coex_table	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_set_ext_ant_switch	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_ext_ant_switch(IN struct btc_coexist *btcoexist, IN boolean force_exec, IN u8 ctrl_type, IN u8 pos_type)$/;"	f
-halbtc8821c1ant_set_ext_band_switch	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_ext_band_switch(IN struct btc_coexist *btcoexist, IN boolean force_exec, IN u8 pos_type)$/;"	f
-halbtc8821c1ant_set_fw_ignore_wlan_act	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_set_fw_low_penalty_ra	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_fw_low_penalty_ra(IN struct btc_coexist$/;"	f
-halbtc8821c1ant_set_fw_pstdma	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_set_int_block	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_int_block(IN struct btc_coexist *btcoexist, IN boolean force_exec,  IN u8 pos_type)$/;"	f
-halbtc8821c1ant_set_lps_rpwm	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_set_rfe_type	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_set_rfe_type(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_sw_mechanism	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_sw_mechanism(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_update_bt_link_info	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c1ant_update_ra_mask	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_update_wifi_channel_info	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_wifi_rssi_state	hal/btc/halbtc8821c1ant.c	/^u8 halbtc8821c1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c1ant_write_score_board	hal/btc/halbtc8821c1ant.c	/^void halbtc8821c1ant_write_score_board($/;"	f
-halbtc8821c2ant_action_a2dp	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_a2dp_pan_hs	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_a2dp_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_algorithm	hal/btc/halbtc8821c2ant.c	/^u8 halbtc8821c2ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_bt_idle	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_bt_idle(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_bt_inquiry	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_bt_whck_test	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_coex_all_off	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_hid	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_hid_a2dp	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_hid_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_hid_a2dp_pan_edr	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_hid_a2dp_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_init_coex_dm	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_pan_edr	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_pan_edr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_pan_edr_a2dp	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_pan_edr_a2dp(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_pan_edr_hid	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_pan_edr_hid(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_pan_hs	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_pan_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_sco	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_sco(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_wifi_link_process	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_wifi_link_process(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_wifi_multi_port	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_wifi_nonconnected	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_wifi_nonconnected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_action_wifi_under5g	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_action_wifi_under5g(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_bt_auto_report	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_bt_rssi_state	hal/btc/halbtc8821c2ant.c	/^u8 halbtc8821c2ant_bt_rssi_state(u8 *ppre_bt_rssi_state, u8 level_num,$/;"	f
-halbtc8821c2ant_coex_switch_threshold	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_coex_switch_threshold(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_coex_table	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_coex_table_with_type	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_dec_bt_pwr	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_enable_gnt_to_gpio	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_fw_dac_swing_lvl	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_fw_dac_swing_lvl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ignore_wlan_act	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_init_hw_config	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_is_wifibt_status_changed	hal/btc/halbtc8821c2ant.c	/^boolean halbtc8821c2ant_is_wifibt_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_limited_rx	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_low_penalty_ra	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_lps_rpwm	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_enable	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ltecoex_enable(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_indirect_read_reg	hal/btc/halbtc8821c2ant.c	/^u32 halbtc8821c2ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_indirect_write_reg	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ltecoex_indirect_write_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_pathcontrol_owner	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_set_break_table	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ltecoex_set_break_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_set_coex_table	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_set_gnt_bt	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ltecoex_set_gnt_wl	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_monitor_bt_ctr	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_monitor_bt_enable_disable	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_monitor_wifi_ctr	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_post_activestate_to_bt	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_post_activestate_to_bt($/;"	f
-halbtc8821c2ant_post_onoffstate_to_bt	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_post_onoffstate_to_bt($/;"	f
-halbtc8821c2ant_power_save_state	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ps_tdma	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_ps_tdma_check_for_power_save_state	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8821c2ant_psd_antenna_detection	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_psd_antenna_detection(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_psd_antenna_detection_check	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_psd_antenna_detection_check(IN struct btc_coexist$/;"	f
-halbtc8821c2ant_psd_getdata	hal/btc/halbtc8821c2ant.c	/^u32 halbtc8821c2ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)$/;"	f
-halbtc8821c2ant_psd_log2base	hal/btc/halbtc8821c2ant.c	/^u32 halbtc8821c2ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)$/;"	f
-halbtc8821c2ant_psd_maxholddata	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_psd_maxholddata(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_psd_show_antenna_detect_result	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_psd_show_antenna_detect_result(IN struct btc_coexist$/;"	f
-halbtc8821c2ant_psd_showdata	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_psd_showdata(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_psd_sweep_point	hal/btc/halbtc8821c2ant.c	/^boolean halbtc8821c2ant_psd_sweep_point(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_query_bt_info	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_read_score_board	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_read_score_board($/;"	f
-halbtc8821c2ant_run_coexist_mechanism	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_set_ant_path	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_bt_auto_report	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_coex_table	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_ext_ant_switch	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_ext_ant_switch(IN struct btc_coexist *btcoexist, IN boolean force_exec, IN u8 ctrl_type, IN u8 pos_type)$/;"	f
-halbtc8821c2ant_set_ext_band_switch	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_ext_band_switch(IN struct btc_coexist *btcoexist, IN boolean force_exec, IN u8 pos_type)$/;"	f
-halbtc8821c2ant_set_fw_dac_swing_level	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_fw_dac_swing_level(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_fw_dec_bt_pwr	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_fw_dec_bt_pwr(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_fw_ignore_wlan_act	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_fw_low_penalty_ra	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_fw_low_penalty_ra(IN struct btc_coexist$/;"	f
-halbtc8821c2ant_set_fw_pstdma	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_int_block	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_int_block(IN struct btc_coexist *btcoexist, IN boolean force_exec,  IN u8 pos_type)$/;"	f
-halbtc8821c2ant_set_lps_rpwm	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_set_rfe_type	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_set_rfe_type(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_sw_mechanism1	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_sw_mechanism1(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_sw_mechanism2	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_sw_mechanism2(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_update_bt_link_info	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8821c2ant_update_wifi_channel_info	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_wifi_rssi_state	hal/btc/halbtc8821c2ant.c	/^u8 halbtc8821c2ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8821c2ant_write_score_board	hal/btc/halbtc8821c2ant.c	/^void halbtc8821c2ant_write_score_board($/;"	f
-halbtc8822b1ant_action_algorithm	hal/btc/HalBtc8822b1Ant.c	/^u8 halbtc8822b1ant_action_algorithm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_bt_inquiry	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_bt_inquiry(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_bt_sco_hid_only_busy	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_bt_sco_hid_only_busy(IN struct btc_coexist$/;"	f
-halbtc8822b1ant_action_bt_whck_test	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_bt_whck_test(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_hs	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_hs(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_wifi_connected	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_wifi_connected_bt_acl_busy	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_connected_bt_acl_busy(IN struct btc_coexist$/;"	f
-halbtc8822b1ant_action_wifi_connected_scan	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8822b1ant_action_wifi_connected_specific_packet	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_connected_specific_packet($/;"	f
-halbtc8822b1ant_action_wifi_multi_port	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_multi_port(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_wifi_not_connected	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_not_connected(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_wifi_not_connected_asso_auth	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_not_connected_asso_auth($/;"	f
-halbtc8822b1ant_action_wifi_not_connected_scan	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_not_connected_scan(IN struct btc_coexist$/;"	f
-halbtc8822b1ant_action_wifi_only	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_only(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_action_wifi_under5g	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_action_wifi_under5g(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_ampdu_max_time	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ampdu_max_time(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_auto_rate_fallback_retry	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_auto_rate_fallback_retry(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_bt_auto_report	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_bt_rssi_state	hal/btc/HalBtc8822b1Ant.c	/^u8 halbtc8822b1ant_bt_rssi_state(u8 level_num, u8 rssi_thresh, u8 rssi_thresh1)$/;"	f
-halbtc8822b1ant_coex_all_off	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_coex_all_off(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_coex_table	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_coex_table_with_type	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_coex_table_with_type(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_enable_gnt_to_gpio	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_enable_gnt_to_gpio(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ignore_wlan_act	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_init_coex_dm	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_init_coex_dm(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_init_hw_config	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_init_hw_config(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_is_common_action	hal/btc/HalBtc8822b1Ant.c	/^boolean halbtc8822b1ant_is_common_action(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_is_wifi_status_changed	hal/btc/HalBtc8822b1Ant.c	/^boolean halbtc8822b1ant_is_wifi_status_changed(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_limited_rx	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_limited_rx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_limited_tx	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_limited_tx(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_low_penalty_ra	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_low_penalty_ra(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_lps_rpwm	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltcoex_set_break_table	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ltcoex_set_break_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltecoex_enable	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ltecoex_enable(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltecoex_indirect_read_reg	hal/btc/HalBtc8822b1Ant.c	/^u32 halbtc8822b1ant_ltecoex_indirect_read_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltecoex_indirect_write_reg	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ltecoex_indirect_write_reg(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltecoex_pathcontrol_owner	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ltecoex_pathcontrol_owner(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltecoex_set_coex_table	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ltecoex_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltecoex_set_gnt_bt	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ltecoex_set_gnt_bt(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ltecoex_set_gnt_wl	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ltecoex_set_gnt_wl(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_monitor_bt_ctr	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_monitor_bt_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_monitor_bt_enable_disable	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_monitor_bt_enable_disable(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_monitor_wifi_ctr	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_monitor_wifi_ctr(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_post_activestate_to_bt	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_post_activestate_to_bt($/;"	f
-halbtc8822b1ant_post_onoffstate_to_bt	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_post_onoffstate_to_bt($/;"	f
-halbtc8822b1ant_power_save_state	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_power_save_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ps_tdma	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ps_tdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_ps_tdma_check_for_power_save_state	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_ps_tdma_check_for_power_save_state($/;"	f
-halbtc8822b1ant_psd_getdata	hal/btc/HalBtc8822b1Ant.c	/^u32 halbtc8822b1ant_psd_getdata(IN struct btc_coexist *btcoexist, IN u32 point)$/;"	f
-halbtc8822b1ant_psd_log2base	hal/btc/HalBtc8822b1Ant.c	/^u32 halbtc8822b1ant_psd_log2base(IN struct btc_coexist *btcoexist, IN u32 val)$/;"	f
-halbtc8822b1ant_psd_max_holddata	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_psd_max_holddata(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_psd_showdata	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_psd_showdata(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_psd_sweep_point	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_psd_sweep_point(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_query_bt_info	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_query_bt_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_read_score_board	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_read_score_board($/;"	f
-halbtc8822b1ant_retry_limit	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_retry_limit(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_run_coexist_mechanism	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_run_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_run_sw_coexist_mechanism	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_run_sw_coexist_mechanism(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_setManual	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_setManual(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_set_ant_path	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_ant_path(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_set_bt_auto_report	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_bt_auto_report(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_set_coex_table	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_coex_table(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_set_ext_ant_switch	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_ext_ant_switch(IN struct btc_coexist *btcoexist, IN boolean force_exec, IN u8 ctrl_type, IN u8 pos_type)$/;"	f
-halbtc8822b1ant_set_fw_ignore_wlan_act	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_fw_ignore_wlan_act(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_set_fw_pstdma	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_fw_pstdma(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_set_lps_rpwm	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_lps_rpwm(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_set_rfe_type	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_rfe_type(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_set_sw_penalty_tx_rate_adaptive	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_set_sw_penalty_tx_rate_adaptive(IN struct btc_coexist$/;"	f
-halbtc8822b1ant_sw_mechanism	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_sw_mechanism(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_update_bt_link_info	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_update_bt_link_info(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_update_ra_mask	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_update_ra_mask(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_update_wifi_channel_info	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_update_wifi_channel_info(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_wifi_info_notify	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_wifi_info_notify(IN struct btc_coexist *btcoexist)$/;"	f
-halbtc8822b1ant_wifi_rssi_state	hal/btc/HalBtc8822b1Ant.c	/^u8 halbtc8822b1ant_wifi_rssi_state(IN struct btc_coexist *btcoexist,$/;"	f
-halbtc8822b1ant_write_score_board	hal/btc/HalBtc8822b1Ant.c	/^void halbtc8822b1ant_write_score_board($/;"	f
-halbtcoutsrc_AggregationCheck	hal/hal_btcoex.c	/^void halbtcoutsrc_AggregationCheck(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_BitMaskWrite1Byte	hal/hal_btcoex.c	/^void halbtcoutsrc_BitMaskWrite1Byte(void *pBtcContext, u32 regAddr, u8 bitMask, u8 data1b)$/;"	f
-halbtcoutsrc_CoexH2cProcess	hal/hal_btcoex.c	/^COL_H2C_STATUS halbtcoutsrc_CoexH2cProcess(void *pBtCoexist,$/;"	f
-halbtcoutsrc_DbgInit	hal/hal_btcoex.c	/^static void halbtcoutsrc_DbgInit(void)$/;"	f	file:
-halbtcoutsrc_DisableLowPower	hal/hal_btcoex.c	/^void halbtcoutsrc_DisableLowPower(PBTC_COEXIST pBtCoexist, u8 bLowPwrDisable)$/;"	f
-halbtcoutsrc_DisplayBtLinkInfo	hal/hal_btcoex.c	/^void halbtcoutsrc_DisplayBtLinkInfo(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_DisplayCoexStatistics	hal/hal_btcoex.c	/^void halbtcoutsrc_DisplayCoexStatistics(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_DisplayDbgMsg	hal/hal_btcoex.c	/^void halbtcoutsrc_DisplayDbgMsg(void *pBtcContext, u8 dispType)$/;"	f
-halbtcoutsrc_DisplayWifiStatus	hal/hal_btcoex.c	/^void halbtcoutsrc_DisplayWifiStatus(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_EnterLps	hal/hal_btcoex.c	/^void halbtcoutsrc_EnterLps(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_FillH2cCmd	hal/hal_btcoex.c	/^void halbtcoutsrc_FillH2cCmd(void *pBtcContext, u8 elementId, u32 cmdLen, u8 *pCmdBuffer)$/;"	f
-halbtcoutsrc_Get	hal/hal_btcoex.c	/^u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)$/;"	f
-halbtcoutsrc_GetAntDetValFromBt	hal/hal_btcoex.c	/^u8 halbtcoutsrc_GetAntDetValFromBt(void *pBtcContext)$/;"	f
-halbtcoutsrc_GetBbReg	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetBbReg(void *pBtcContext, u32 RegAddr, u32 BitMask)$/;"	f
-halbtcoutsrc_GetBleScanParaFromBt	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetBleScanParaFromBt(void *pBtcContext, u8 scanType)$/;"	f
-halbtcoutsrc_GetBleScanTypeFromBt	hal/hal_btcoex.c	/^u8 halbtcoutsrc_GetBleScanTypeFromBt(void *pBtcContext)$/;"	f
-halbtcoutsrc_GetBtAFHMapFromBt	hal/hal_btcoex.c	/^u8 halbtcoutsrc_GetBtAFHMapFromBt(void *pBtcContext, u8 mapType, u8 *afhMap)$/;"	f
-halbtcoutsrc_GetBtCoexSupportedFeature	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetBtCoexSupportedFeature(void *pBtcContext)$/;"	f
-halbtcoutsrc_GetBtCoexSupportedVersion	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetBtCoexSupportedVersion(void *pBtcContext)$/;"	f
-halbtcoutsrc_GetBtPatchVer	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetBtPatchVer(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_GetBtReg	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr)$/;"	f
-halbtcoutsrc_GetBtReg_with_status	hal/hal_btcoex.c	/^u16 halbtcoutsrc_GetBtReg_with_status(void *pBtcContext, u8 RegType, u32 RegAddr, u32 *data)$/;"	f
-halbtcoutsrc_GetPhydmVersion	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetPhydmVersion(void *pBtcContext)$/;"	f
-halbtcoutsrc_GetRfReg	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetRfReg(void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMask)$/;"	f
-halbtcoutsrc_GetWifiLinkStatus	hal/hal_btcoex.c	/^u32 halbtcoutsrc_GetWifiLinkStatus(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_GetWifiRssi	hal/hal_btcoex.c	/^s32 halbtcoutsrc_GetWifiRssi(PADAPTER padapter)$/;"	f
-halbtcoutsrc_GetWifiScanAPNum	hal/hal_btcoex.c	/^static u8 halbtcoutsrc_GetWifiScanAPNum(PADAPTER padapter)$/;"	f	file:
-halbtcoutsrc_IsBtCoexistAvailable	hal/hal_btcoex.c	/^static u8 halbtcoutsrc_IsBtCoexistAvailable(PBTC_COEXIST pBtCoexist)$/;"	f	file:
-halbtcoutsrc_IsCsrBtCoex	hal/hal_btcoex.c	/^static u8 halbtcoutsrc_IsCsrBtCoex(PBTC_COEXIST pBtCoexist)$/;"	f	file:
-halbtcoutsrc_IsHwMailboxExist	hal/hal_btcoex.c	/^static u8 halbtcoutsrc_IsHwMailboxExist(PBTC_COEXIST pBtCoexist)$/;"	f	file:
-halbtcoutsrc_IsWifiBusy	hal/hal_btcoex.c	/^u8 halbtcoutsrc_IsWifiBusy(PADAPTER padapter)$/;"	f
-halbtcoutsrc_LeaveLowPower	hal/hal_btcoex.c	/^void halbtcoutsrc_LeaveLowPower(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_LeaveLps	hal/hal_btcoex.c	/^static void halbtcoutsrc_LeaveLps(PBTC_COEXIST pBtCoexist)$/;"	f	file:
-halbtcoutsrc_NormalLowPower	hal/hal_btcoex.c	/^void halbtcoutsrc_NormalLowPower(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_NormalLps	hal/hal_btcoex.c	/^void halbtcoutsrc_NormalLps(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_Read1Byte	hal/hal_btcoex.c	/^u8 halbtcoutsrc_Read1Byte(void *pBtcContext, u32 RegAddr)$/;"	f
-halbtcoutsrc_Read2Byte	hal/hal_btcoex.c	/^u16 halbtcoutsrc_Read2Byte(void *pBtcContext, u32 RegAddr)$/;"	f
-halbtcoutsrc_Read4Byte	hal/hal_btcoex.c	/^u32 halbtcoutsrc_Read4Byte(void *pBtcContext, u32 RegAddr)$/;"	f
-halbtcoutsrc_Set	hal/hal_btcoex.c	/^u8 halbtcoutsrc_Set(void *pBtcContext, u8 setType, void *pInBuf)$/;"	f
-halbtcoutsrc_SetBbReg	hal/hal_btcoex.c	/^void halbtcoutsrc_SetBbReg(void *pBtcContext, u32 RegAddr, u32 BitMask, u32 Data)$/;"	f
-halbtcoutsrc_SetBtAntDetection	hal/hal_btcoex.c	/^u8 halbtcoutsrc_SetBtAntDetection(void *pBtcContext, u8 txTime, u8 btChnl)$/;"	f
-halbtcoutsrc_SetBtReg	hal/hal_btcoex.c	/^u16 halbtcoutsrc_SetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 Data)$/;"	f
-halbtcoutsrc_SetBtTRXMASK	hal/hal_btcoex.c	/^halbtcoutsrc_SetBtTRXMASK($/;"	f
-halbtcoutsrc_SetRfReg	hal/hal_btcoex.c	/^void halbtcoutsrc_SetRfReg(void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMask, u32 Data)$/;"	f
-halbtcoutsrc_Under32K	hal/hal_btcoex.c	/^u8 halbtcoutsrc_Under32K(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_UnderIps	hal/hal_btcoex.c	/^u8 halbtcoutsrc_UnderIps(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_UnderLps	hal/hal_btcoex.c	/^u8 halbtcoutsrc_UnderLps(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_Write1Byte	hal/hal_btcoex.c	/^void halbtcoutsrc_Write1Byte(void *pBtcContext, u32 RegAddr, u8 Data)$/;"	f
-halbtcoutsrc_Write2Byte	hal/hal_btcoex.c	/^void halbtcoutsrc_Write2Byte(void *pBtcContext, u32 RegAddr, u16 Data)$/;"	f
-halbtcoutsrc_Write4Byte	hal/hal_btcoex.c	/^void halbtcoutsrc_Write4Byte(void *pBtcContext, u32 RegAddr, u32 Data)$/;"	f
-halbtcoutsrc_WriteLocalReg1Byte	hal/hal_btcoex.c	/^void halbtcoutsrc_WriteLocalReg1Byte(void *pBtcContext, u32 RegAddr, u8 Data)$/;"	f
-halbtcoutsrc_check_c2h_ack	hal/hal_btcoex.c	/^static COL_H2C_STATUS halbtcoutsrc_check_c2h_ack(PADAPTER Adapter, PCOL_SINGLE_H2C_RECORD pH2cRecord)$/;"	f	file:
-halbtcoutsrc_coex_offload_init	hal/hal_btcoex.c	/^static void halbtcoutsrc_coex_offload_init(void)$/;"	f	file:
-halbtcoutsrc_is_autoload_fail	hal/hal_btcoex.c	/^u8 halbtcoutsrc_is_autoload_fail(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_is_fw_ready	hal/hal_btcoex.c	/^u8 halbtcoutsrc_is_fw_ready(PBTC_COEXIST pBtCoexist)$/;"	f
-halbtcoutsrc_phydm_modify_RA_PCR_threshold	hal/hal_btcoex.c	/^void halbtcoutsrc_phydm_modify_RA_PCR_threshold(void *pBtcContext, u8 RA_offset_direction, u8 RA_threshold_offset)$/;"	f
-halbtcoutsrc_phydm_query_PHY_counter	hal/hal_btcoex.c	/^u32 halbtcoutsrc_phydm_query_PHY_counter(void *pBtcContext, u8 info_type)$/;"	f
-halbtcoutsrc_send_h2c	hal/hal_btcoex.c	/^static COL_H2C_STATUS halbtcoutsrc_send_h2c(PADAPTER Adapter, PCOL_H2C pcol_h2c, u16 h2c_cmd_len)$/;"	f	file:
-halmac	include/drv_types.h	/^	void *halmac;$/;"	m	struct:dvobj_priv
-halmac_indicator	include/drv_types.h	/^struct halmac_indicator {$/;"	s
-halmacpriv	include/drv_types.h	/^struct halmacpriv {$/;"	s
-handle_dfs	include/rtw_mlme.h	/^	u8	handle_dfs;$/;"	m	struct:mlme_priv
-handle_txrpt_ccx_88e	include/rtl8188e_xmit.h	296;"	d
-handler	include/rtw_mp_ioctl.h	/^	u32(*handler)(struct oid_par_priv *poid_par_priv);$/;"	m	struct:mp_ioctl_handler
-handshake_timer	include/sta_info.h	/^	_timer handshake_timer;$/;"	m	struct:sta_info
-has_channel	core/rtw_mlme_ext.c	/^static int has_channel(RT_CHANNEL_INFO *channel_set,$/;"	f	file:
-has_legacy_ac	include/sta_info.h	/^	u8 has_legacy_ac;$/;"	m	struct:sta_info
-hash_list	include/sta_info.h	/^	_list	hash_list; \/* sta_hash *\/$/;"	m	struct:sta_info
-hb	os_dep/osdep_service.c	/^	size_t hb;$/;"	m	struct:mstat_sniff_rule	file:
-hci	include/drv_types.h	/^	u8	hci;$/;"	m	struct:registry_priv
-hci_sus_state	include/hal_data.h	/^	u8 hci_sus_state;$/;"	m	struct:hal_com_data
-hci_version	hal/btc/HalBtcOutSrc.h	/^	u16					hci_version;	\/* stack hci version *\/$/;"	m	struct:btc_stack_info
-hdl_lock	include/rtw_mlme.h	/^	_lock				hdl_lock;$/;"	m	struct:tdls_info
-hdr	include/rtw_recv.h	/^		struct recv_frame_hdr hdr;$/;"	m	union:recv_frame::__anon62	typeref:struct:recv_frame::__anon62::recv_frame_hdr
-hdr_len	include/osdep_service_bsd.h	/^				hdr_len;$/;"	m	struct:sk_buff
-hdrlen	include/rtw_recv.h	/^	u8	hdrlen; \/* the WLAN Header Len *\/$/;"	m	struct:rx_pkt_attrib
-hdrlen	include/rtw_xmit.h	/^	u16	hdrlen;		\/* the WLAN Header Len *\/$/;"	m	struct:pkt_attrib
-head	hal/rtl8723d/rtl8723d_hal_init.c	/^	u16 head:8;$/;"	m	struct:bcn_qinfo_8723d	file:
-head	hal/rtl8723d/rtl8723d_hal_init.c	/^	u32 head:8;$/;"	m	struct:qinfo_8723d	file:
-head	include/osdep_service_bsd.h	/^	unsigned char		*head,$/;"	m	struct:sk_buff
-head	include/rtw_event.h	/^	volatile int	head;$/;"	m	struct:c2hevent_queue
-head	include/rtw_event.h	/^	volatile int	head;$/;"	m	struct:network_queue
-head	include/rtw_xmit.h	/^	volatile sint	head;$/;"	m	struct:hw_txqueue
-header	include/ieee80211.h	/^	struct ieee80211_header_data header;$/;"	m	struct:ieee80211_authentication	typeref:struct:ieee80211_authentication::ieee80211_header_data
-header	include/ieee80211.h	/^	struct ieee80211_header_data header;$/;"	m	struct:ieee80211_probe_request	typeref:struct:ieee80211_probe_request::ieee80211_header_data
-header	include/ieee80211.h	/^	struct ieee80211_header_data header;$/;"	m	struct:ieee80211_probe_response	typeref:struct:ieee80211_probe_response::ieee80211_header_data
-header	include/ieee80211.h	/^	struct rtw_ieee80211_hdr_3addr header;$/;"	m	struct:ieee80211_assoc_request_frame	typeref:struct:ieee80211_assoc_request_frame::rtw_ieee80211_hdr_3addr
-header	include/ieee80211.h	/^	struct rtw_ieee80211_hdr_3addr header;$/;"	m	struct:ieee80211_assoc_response_frame	typeref:struct:ieee80211_assoc_response_frame::rtw_ieee80211_hdr_3addr
-hex2byte_i	os_dep/linux/ioctl_linux.c	/^static int hex2byte_i(const char *hex)$/;"	f	file:
-hex2num_i	os_dep/linux/ioctl_linux.c	/^static int hex2num_i(char c)$/;"	f	file:
-hexstr2bin	os_dep/linux/ioctl_linux.c	/^static int hexstr2bin(const char *hex, u8 *buf, size_t len)$/;"	f	file:
-hid_busy_num	hal/btc/halbtc8723d1ant.h	/^	u8					hid_busy_num;$/;"	m	struct:coex_sta_8723d_1ant
-hid_busy_num	hal/btc/halbtc8723d2ant.h	/^	u8					hid_busy_num;$/;"	m	struct:coex_sta_8723d_2ant
-hid_exist	hal/btc/HalBtc8192e1Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8192e_1ant
-hid_exist	hal/btc/HalBtc8192e2Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8192e_2ant
-hid_exist	hal/btc/HalBtc8703b1Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8703b_1ant
-hid_exist	hal/btc/HalBtc8723b1Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8723b_1ant
-hid_exist	hal/btc/HalBtc8723b2Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8723b_2ant
-hid_exist	hal/btc/HalBtc8812a1Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8812a_1ant
-hid_exist	hal/btc/HalBtc8812a2Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8812a_2ant
-hid_exist	hal/btc/HalBtc8821a1Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8821a_1ant
-hid_exist	hal/btc/HalBtc8821a2Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8821a_2ant
-hid_exist	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8821a_csr_2ant
-hid_exist	hal/btc/HalBtc8822b1Ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8822b_1ant
-hid_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					hid_exist;$/;"	m	struct:btc_bt_link_info
-hid_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					hid_exist;$/;"	m	struct:btc_stack_info
-hid_exist	hal/btc/halbtc8723d1ant.h	/^	boolean				hid_exist;$/;"	m	struct:coex_sta_8723d_1ant
-hid_exist	hal/btc/halbtc8723d2ant.h	/^	boolean				hid_exist;$/;"	m	struct:coex_sta_8723d_2ant
-hid_exist	hal/btc/halbtc8821c1ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8821c_1ant
-hid_exist	hal/btc/halbtc8821c2ant.h	/^	boolean					hid_exist;$/;"	m	struct:coex_sta_8821c_2ant
-hid_only	hal/btc/HalBtcOutSrc.h	/^	boolean					hid_only;$/;"	m	struct:btc_bt_link_info
-hid_pair_cnt	hal/btc/halbtc8723d1ant.h	/^	u8					hid_pair_cnt;$/;"	m	struct:coex_sta_8723d_1ant
-hid_pair_cnt	hal/btc/halbtc8723d2ant.h	/^	u8					hid_pair_cnt;$/;"	m	struct:coex_sta_8723d_2ant
-hidden_ssid_mode	include/rtw_mlme_ext.h	/^	u8	hidden_ssid_mode;$/;"	m	struct:mlme_ext_info
-hidden_ssid_num	include/rtw_pwrctrl.h	/^	u8	hidden_ssid_num;$/;"	m	struct:pno_nlo_info
-highPriorityRx	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte					highPriorityRx;$/;"	m	struct:_COEX_STA_8723A_1ANT
-highPriorityRx	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte					highPriorityRx;$/;"	m	struct:_COEX_STA_8723A_2ANT
-highPriorityTx	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte					highPriorityTx;$/;"	m	struct:_COEX_STA_8723A_1ANT
-highPriorityTx	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte					highPriorityTx;$/;"	m	struct:_COEX_STA_8723A_2ANT
-high_priority_rx	hal/btc/HalBtc8192e1Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8192e_1ant
-high_priority_rx	hal/btc/HalBtc8192e2Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8192e_2ant
-high_priority_rx	hal/btc/HalBtc8703b1Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8703b_1ant
-high_priority_rx	hal/btc/HalBtc8723b1Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8723b_1ant
-high_priority_rx	hal/btc/HalBtc8723b2Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8723b_2ant
-high_priority_rx	hal/btc/HalBtc8812a1Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8812a_1ant
-high_priority_rx	hal/btc/HalBtc8812a2Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8812a_2ant
-high_priority_rx	hal/btc/HalBtc8821a1Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8821a_1ant
-high_priority_rx	hal/btc/HalBtc8821a2Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8821a_2ant
-high_priority_rx	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8821a_csr_2ant
-high_priority_rx	hal/btc/HalBtc8822b1Ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8822b_1ant
-high_priority_rx	hal/btc/halbtc8723d1ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8723d_1ant
-high_priority_rx	hal/btc/halbtc8723d2ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8723d_2ant
-high_priority_rx	hal/btc/halbtc8821c1ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8821c_1ant
-high_priority_rx	hal/btc/halbtc8821c2ant.h	/^	u32					high_priority_rx;$/;"	m	struct:coex_sta_8821c_2ant
-high_priority_tx	hal/btc/HalBtc8192e1Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8192e_1ant
-high_priority_tx	hal/btc/HalBtc8192e2Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8192e_2ant
-high_priority_tx	hal/btc/HalBtc8703b1Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8703b_1ant
-high_priority_tx	hal/btc/HalBtc8723b1Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8723b_1ant
-high_priority_tx	hal/btc/HalBtc8723b2Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8723b_2ant
-high_priority_tx	hal/btc/HalBtc8812a1Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8812a_1ant
-high_priority_tx	hal/btc/HalBtc8812a2Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8812a_2ant
-high_priority_tx	hal/btc/HalBtc8821a1Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8821a_1ant
-high_priority_tx	hal/btc/HalBtc8821a2Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8821a_2ant
-high_priority_tx	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8821a_csr_2ant
-high_priority_tx	hal/btc/HalBtc8822b1Ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8822b_1ant
-high_priority_tx	hal/btc/halbtc8723d1ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8723d_1ant
-high_priority_tx	hal/btc/halbtc8723d2ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8723d_2ant
-high_priority_tx	hal/btc/halbtc8821c1ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8821c_1ant
-high_priority_tx	hal/btc/halbtc8821c2ant.h	/^	u32					high_priority_tx;$/;"	m	struct:coex_sta_8821c_2ant
-highdok	include/drv_types.h	/^	u32 highdok;$/;"	m	struct:int_logs
-highest_client_tx_order	hal/phydm/phydm_rainfo.h	/^	u1Byte	highest_client_tx_order;$/;"	m	struct:_Rate_Adaptive_Table_
-highest_client_tx_rate_order	hal/phydm/phydm_rainfo.h	/^	u2Byte	highest_client_tx_rate_order;$/;"	m	struct:_Rate_Adaptive_Table_
-highest_ht_rate_bw_bmp	include/drv_types.h	/^	u8 highest_ht_rate_bw_bmp;$/;"	m	struct:rf_ctl_t
-highest_vht_rate_bw_bmp	include/drv_types.h	/^	u8 highest_vht_rate_bw_bmp;$/;"	m	struct:rf_ctl_t
-hiq_filter	include/drv_types.h	/^	u8 hiq_filter;$/;"	m	struct:registry_priv
-hl_smart_antenna_decision_workitem	hal/phydm/phydm_antdiv.h	/^	RT_WORK_ITEM	hl_smart_antenna_decision_workitem;	$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-hl_smart_antenna_workitem	hal/phydm/phydm_antdiv.h	/^	RT_WORK_ITEM	hl_smart_antenna_workitem;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-hlen	core/rtw_br_ext.c	/^	u_int8_t hlen;$/;"	m	struct:dhcpMessage	file:
-hmac_sha256_vector	core/rtw_security.c	/^static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,$/;"	f	file:
-hmpriv	include/drv_types.h	/^	struct halmacpriv hmpriv;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::halmacpriv
-hndis_adapter	include/drv_types.h	/^	_nic_hdl		hndis_adapter;\/* hNdisAdapter(NDISMiniportAdapterHandle); *\/$/;"	m	struct:_ADAPTER
-hndis_config	include/drv_types.h	/^	_nic_hdl		hndis_config;\/* hNdisConfiguration; *\/$/;"	m	struct:_ADAPTER
-hops	core/rtw_br_ext.c	/^	u_int8_t hops;$/;"	m	struct:dhcpMessage	file:
-hostap_mgnt_xmit_entry	include/hal_intf.h	/^	s32(*hostap_mgnt_xmit_entry)(_adapter *padapter, _pkt *pkt);$/;"	m	struct:hal_ops
-hostapd_mode_init	os_dep/linux/mlme_linux.c	/^int hostapd_mode_init(_adapter *padapter)$/;"	f
-hostapd_mode_unload	os_dep/linux/mlme_linux.c	/^void hostapd_mode_unload(_adapter *padapter)$/;"	f
-hostapd_priv	include/rtw_mlme.h	/^struct hostapd_priv {$/;"	s
-ht_20mhz_set	include/sta_info.h	/^	u8 ht_20mhz_set;$/;"	m	struct:sta_info
-ht_20mhz_width_req	include/rtw_mlme.h	/^	int ht_20mhz_width_req;$/;"	m	struct:mlme_priv
-ht_40mhz_intolerant	include/sta_info.h	/^	u8 ht_40mhz_intolerant;$/;"	m	struct:sta_info
-ht_aagc_gain	hal/phydm/phydm_hwconfig.h	/^	u1Byte		ht_aagc_gain[4];$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-ht_cap	include/ieee80211.h	/^			struct rtw_ieee80211_ht_cap ht_cap;$/;"	m	struct:ieee_param::__anon73::__anon78	typeref:struct:ieee_param::__anon73::__anon78::rtw_ieee80211_ht_cap
-ht_cap	include/ieee80211.h	/^	struct rtw_ieee80211_ht_cap ht_cap;$/;"	m	struct:sta_data	typeref:struct:sta_data::rtw_ieee80211_ht_cap
-ht_cap	include/rtw_ht.h	/^	struct rtw_ieee80211_ht_cap ht_cap;$/;"	m	struct:ht_priv	typeref:struct:ht_priv::rtw_ieee80211_ht_cap
-ht_cap_info	include/rtw_mlme.h	/^	u16 ht_cap_info;$/;"	m	struct:beacon_keys
-ht_cap_info	include/wlan_bssdef.h	/^	unsigned short	ht_cap_info;$/;"	m	struct:_WLAN_BCN_INFO
-ht_capabilities	include/ieee80211.h	/^	u8 *ht_capabilities;$/;"	m	struct:rtw_ieee802_11_elems
-ht_capabilities_len	include/ieee80211.h	/^	u8 ht_capabilities_len;$/;"	m	struct:rtw_ieee802_11_elems
-ht_en	include/rtw_xmit.h	/^	u8	ht_en;$/;"	m	struct:pkt_attrib
-ht_enable	include/drv_types.h	/^	u8	ht_enable;$/;"	m	struct:registry_priv
-ht_info_infos_0	include/wlan_bssdef.h	/^	unsigned char	ht_info_infos_0;$/;"	m	struct:_WLAN_BCN_INFO
-ht_info_infos_0_sco	include/rtw_mlme.h	/^	u8 ht_info_infos_0_sco; \/* bit0 & bit1 in infos[0] is second channel offset *\/$/;"	m	struct:beacon_keys
-ht_intolerant_ch_reported	include/rtw_mlme.h	/^	int ht_intolerant_ch_reported;$/;"	m	struct:mlme_priv
-ht_op_mode	include/rtw_mlme.h	/^	u16 ht_op_mode;$/;"	m	struct:mlme_priv
-ht_operation	include/ieee80211.h	/^	u8 *ht_operation;$/;"	m	struct:rtw_ieee802_11_elems
-ht_operation_len	include/ieee80211.h	/^	u8 ht_operation_len;$/;"	m	struct:rtw_ieee802_11_elems
-ht_option	include/rtw_ht.h	/^	u8	ht_option;$/;"	m	struct:ht_priv
-ht_param	include/wifi.h	/^	unsigned char		ht_param;$/;"	m	struct:ieee80211_ht_addt_info
-ht_priv	include/rtw_ht.h	/^struct ht_priv {$/;"	s
-ht_rxsc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		ht_rxsc: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-ht_rxsc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		ht_rxsc: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-htc	include/rtl8188e_recv.h	/^	u32 htc:1;$/;"	m	struct:rxreport_8188e
-htc	include/rtl8188e_xmit.h	/^	u32 htc:1;$/;"	m	struct:txdesc_88e
-htc	include/rtl8192e_xmit.h	/^	u32 htc:1;$/;"	m	struct:txdescriptor_8192e
-htc	include/rtl8812a_xmit.h	/^	u32 htc:1;$/;"	m	struct:txdescriptor_8812
-htc	include/rtl8814a_xmit.h	/^	u32 htc:1;$/;"	m	struct:txdescriptor_8814
-htc	include/rtl8821a_xmit.h	/^	u32 htc:1;$/;"	m	struct:txdescriptor_8821a
-htonl	include/byteorder/generic.h	161;"	d
-htonl	include/byteorder/generic.h	190;"	d
-htonl	include/byteorder/generic.h	193;"	d
-htonl	include/byteorder/generic.h	204;"	d
-htons	include/byteorder/generic.h	162;"	d
-htons	include/byteorder/generic.h	196;"	d
-htons	include/byteorder/generic.h	206;"	d
-htpriv	include/rtw_mlme.h	/^	struct ht_priv	htpriv;$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::ht_priv
-htpriv	include/sta_info.h	/^	struct ht_priv	htpriv;$/;"	m	struct:sta_info	typeref:struct:sta_info::ht_priv
-htype	core/rtw_br_ext.c	/^	u_int8_t htype;$/;"	m	struct:dhcpMessage	file:
-hw_antsw_occu	hal/phydm/phydm_hwconfig.h	/^	u1Byte		hw_antsw_occu: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-hw_antsw_occu	hal/phydm/phydm_hwconfig.h	/^	u1Byte		hw_antsw_occu: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-hw_antsw_occur	hal/phydm/phydm_antdiv.h	/^	u1Byte	hw_antsw_occur;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-hw_antsw_occur	hal/phydm/phydm_hwconfig.h	/^	u1Byte			hw_antsw_occur: 2;								\/*1'b0*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-hw_antsw_occur	hal/phydm/phydm_hwconfig.h	/^	u1Byte			hw_antsw_occur: 2;$/;"	m	struct:_Phy_Status_Rpt_8812
-hw_decrypted	include/rtw_security.h	/^	s32 	hw_decrypted;\/* if the rx packets is hw_decrypted==_FALSE, it means the hw has not been ready. *\/$/;"	m	struct:security_priv
-hw_init_completed	include/hal_data.h	/^	u8	hw_init_completed;$/;"	m	struct:hal_com_data
-hw_init_mutex	include/drv_types.h	/^	_mutex hw_init_mutex;$/;"	m	struct:dvobj_priv
-hw_media_state	include/rtw_mlme_ext.h	/^	u8	hw_media_state;$/;"	m	struct:mlme_ext_info
-hw_mode	include/rtw_mlme_ext.h	/^	enum hw_mode {IEEE80211G, IEEE80211A} mode;$/;"	g	struct:p2p_oper_class_map
-hw_port	include/drv_types.h	/^	u8 hw_port; \/*interface port type, it depends on HW port *\/$/;"	m	struct:_ADAPTER
-hw_rp_cache	include/rtw_xmit.h	/^	u16		hw_rp_cache;$/;"	m	struct:rtw_tx_ring
-hw_rts_en	include/rtl8188e_xmit.h	/^	u32 hw_rts_en:1;$/;"	m	struct:txdesc_88e
-hw_rts_en	include/rtl8192e_xmit.h	/^	u32 hw_rts_en:1;$/;"	m	struct:txdescriptor_8192e
-hw_rts_en	include/rtl8812a_xmit.h	/^	u32 hw_rts_en:1;$/;"	m	struct:txdescriptor_8812
-hw_rts_en	include/rtl8821a_xmit.h	/^	u32 hw_rts_en:1;$/;"	m	struct:txdescriptor_8821a
-hw_ssn_sel	include/rtl8821a_xmit.h	/^	u32 hw_ssn_sel:2;$/;"	m	struct:txdescriptor_8821a
-hw_ssn_sel	include/rtw_xmit.h	/^	u8	hw_ssn_sel;	\/* for HW_SEQ0,1,2,3 *\/$/;"	m	struct:pkt_attrib
-hw_ssn_seq_no	include/rtw_xmit.h	/^	u8   hw_ssn_seq_no;\/* mapping to REG_HW_SEQ 0,1,2,3 *\/$/;"	m	struct:xmit_priv
-hw_tcp_csum	include/rtw_xmit.h	/^	u8	hw_tcp_csum;$/;"	m	struct:pkt_attrib
-hw_txqueue	include/rtw_xmit.h	/^struct	hw_txqueue	{$/;"	s
-hw_value	include/ieee80211.h	/^	u16 hw_value;$/;"	m	struct:rtw_ieee80211_channel
-hw_var_port_switch	hal/hal_com.c	/^void hw_var_port_switch(_adapter *adapter)$/;"	f
-hw_var_set_bcn_func	hal/rtl8723d/rtl8723d_hal_init.c	/^static void hw_var_set_bcn_func(PADAPTER padapter, u8 variable, u8 *val)$/;"	f	file:
-hw_var_set_correct_tsf	hal/rtl8723d/rtl8723d_hal_init.c	/^static void hw_var_set_correct_tsf(PADAPTER padapter, u8 variable, u8 *val)$/;"	f	file:
-hw_var_set_mlme_disconnect	hal/rtl8723d/rtl8723d_hal_init.c	/^static void hw_var_set_mlme_disconnect(PADAPTER padapter, u8 variable, u8 *val)$/;"	f	file:
-hw_var_set_mlme_join	hal/rtl8723d/rtl8723d_hal_init.c	/^static void hw_var_set_mlme_join(PADAPTER padapter, u8 variable, u8 *val)$/;"	f	file:
-hw_var_set_mlme_sitesurvey	hal/rtl8723d/rtl8723d_hal_init.c	/^static void hw_var_set_mlme_sitesurvey(PADAPTER padapter, u8 variable, u8 *val)$/;"	f	file:
-hw_var_set_monitor	hal/rtl8723d/rtl8723d_hal_init.c	/^static void hw_var_set_monitor(PADAPTER Adapter, u8 variable, u8 *val)$/;"	f	file:
-hw_var_set_opmode	hal/rtl8723d/rtl8723d_hal_init.c	/^static void hw_var_set_opmode(PADAPTER padapter, u8 variable, u8 *val)$/;"	f	file:
-hw_var_set_opmode_mbid	hal/hal_com.c	/^void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode)$/;"	f
-hw_wps_pbc	include/drv_types.h	/^	u8	hw_wps_pbc;\/* 0:disable,1:enable *\/$/;"	m	struct:registry_priv
-hw_xmit	include/rtw_xmit.h	/^struct	hw_xmit	{$/;"	s
-hwaddr	include/rtw_cmd.h	/^	u8	hwaddr[6];$/;"	m	struct:setstapwrstate_parm
-hwaddr	include/sta_info.h	/^	u8	hwaddr[ETH_ALEN];$/;"	m	struct:sta_info
-hwaddr_aton_i	os_dep/linux/ioctl_linux.c	/^static int hwaddr_aton_i(const char *txt, u8 *addr)$/;"	f	file:
-hwpdn_mode	include/drv_types.h	/^	u8	hwpdn_mode;\/* 0:disable,1:enable,2:decide by EFUSE config *\/$/;"	m	struct:registry_priv
-hwpwrp_detect	include/drv_types.h	/^	u8	hwpwrp_detect;\/* 0:disable,1:enable *\/$/;"	m	struct:registry_priv
-hwrsvd	include/rtl8188e_recv.h	/^	u32 hwrsvd:4;$/;"	m	struct:rxreport_8188e
-hwseq	include/sta_info.h	/^	u16 hwseq;$/;"	m	struct:sta_info
-hwseq_en	include/rtl8188e_xmit.h	/^	u32 hwseq_en:1;$/;"	m	struct:txdesc_88e
-hwseq_en	include/rtl8192e_xmit.h	/^	u32 hwseq_en:1;$/;"	m	struct:txdescriptor_8192e
-hwseq_en	include/rtl8812a_xmit.h	/^	u32 hwseq_en:1;$/;"	m	struct:txdescriptor_8812
-hwseq_sel	include/rtl8188e_xmit.h	/^	u32 hwseq_sel:2;$/;"	m	struct:txdesc_88e
-hwseq_sel	include/rtl8192e_xmit.h	/^	u32 hwseq_sel:2;$/;"	m	struct:txdescriptor_8192e
-hwseq_sel	include/rtl8812a_xmit.h	/^	u32 hwseq_sel:2;$/;"	m	struct:txdescriptor_8812
-hwxmit_entry	include/rtw_xmit.h	/^	u8	hwxmit_entry;$/;"	m	struct:xmit_priv
-hwxmits	include/rtw_xmit.h	/^	struct hw_xmit *hwxmits;$/;"	m	struct:xmit_priv	typeref:struct:xmit_priv::hw_xmit
-ibss_params	include/ieee80211.h	/^	u8 *ibss_params;$/;"	m	struct:rtw_ieee802_11_elems
-ibss_params_len	include/ieee80211.h	/^	u8 ibss_params_len;$/;"	m	struct:rtw_ieee802_11_elems
-ic_name	include/hal_data.h	/^	char *ic_name;$/;"	m	struct:hal_spec_t
-icmp_pkt	include/rtw_xmit.h	/^	u8 icmp_pkt;$/;"	m	struct:pkt_attrib
-icv	include/rtw_xmit.h	/^	u8	icv[16];$/;"	m	struct:pkt_attrib
-icv_err	include/rtw_recv.h	/^	u8	icv_err;$/;"	m	struct:rx_pkt_attrib
-icv_len	include/rtw_recv.h	/^	u8	icv_len;$/;"	m	struct:rx_pkt_attrib
-icv_len	include/rtw_xmit.h	/^	u8	icv_len;$/;"	m	struct:pkt_attrib
-icverr	include/rtl8188e_recv.h	/^	u32 icverr:1;$/;"	m	struct:rxreport_8188e
-id	hal/phydm/phydm_debug.c	/^	u1Byte id;$/;"	m	struct:_PHYDM_COMMAND	file:
-id	include/ieee80211.h	/^	u8 id;$/;"	m	struct:ieee80211_info_element
-id	include/ieee80211.h	/^	u8 id;$/;"	m	struct:ieee80211_info_element_hdr
-id	include/ip.h	/^	__u16	id;$/;"	m	struct:iphdr
-idProduct	include/drv_types.h	/^	u16		idProduct;$/;"	m	struct:specific_device_id
-idVendor	include/drv_types.h	/^	u16		idVendor;$/;"	m	struct:specific_device_id
-idle_long	hal/phydm/phydm_hwconfig.h	/^	u1Byte	idle_long: 1;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-idx	include/ieee80211.h	/^			u8 idx;$/;"	m	struct:ieee_param::__anon73::__anon77
-idx	include/rtw_recv.h	/^	unsigned int		idx;$/;"	m	struct:rtw_rx_ring
-idx	include/rtw_xmit.h	/^	unsigned int	idx;$/;"	m	struct:rtw_tx_ring
-idx_AntDiv_counter_2G	hal/phydm/phydm_antdiv.h	/^	u1Byte	idx_AntDiv_counter_2G;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-idx_AntDiv_counter_5G	hal/phydm/phydm_antdiv.h	/^	u1Byte	idx_AntDiv_counter_5G;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-ie	include/rtw_cmd.h	/^	unsigned char ie[0];$/;"	m	struct:setassocreqextraie_parm
-ie	include/rtw_cmd.h	/^	unsigned char ie[0];$/;"	m	struct:setassocrspextraie_parm
-ie	include/rtw_cmd.h	/^	unsigned char ie[0];$/;"	m	struct:setprobereqextraie_parm
-ie	include/rtw_cmd.h	/^	unsigned char ie[0];$/;"	m	struct:setproberspextraie_parm
-ie_len	include/rtw_cmd.h	/^	unsigned char ie_len;$/;"	m	struct:setassocreqextraie_parm
-ie_len	include/rtw_cmd.h	/^	unsigned char ie_len;$/;"	m	struct:setassocrspextraie_parm
-ie_len	include/rtw_cmd.h	/^	unsigned char ie_len;$/;"	m	struct:setprobereqextraie_parm
-ie_len	include/rtw_cmd.h	/^	unsigned char ie_len;$/;"	m	struct:setproberspextraie_parm
-ie_len	include/rtw_tdls.h	/^	u8 ie_len;$/;"	m	struct:wpa_tdls_ftie
-ie_len	include/rtw_tdls.h	/^	u8 ie_len;$/;"	m	struct:wpa_tdls_lnkid
-ie_type	include/rtw_tdls.h	/^	u8 ie_type; \/* FTIE *\/$/;"	m	struct:wpa_tdls_ftie
-ie_type	include/rtw_tdls.h	/^	u8 ie_type; \/* Link Identifier IE *\/$/;"	m	struct:wpa_tdls_lnkid
-iebuf	include/wlan_bssdef.h	/^	unsigned char  iebuf[MAX_IE_SZ];$/;"	m	struct:wlan_network
-ieee80211_assoc_request_frame	include/ieee80211.h	/^struct ieee80211_assoc_request_frame {$/;"	s
-ieee80211_assoc_response_frame	include/ieee80211.h	/^struct ieee80211_assoc_response_frame {$/;"	s
-ieee80211_authentication	include/ieee80211.h	/^struct ieee80211_authentication {$/;"	s
-ieee80211_back_actioncode	include/ieee80211_ext.h	/^enum ieee80211_back_actioncode {$/;"	g
-ieee80211_back_parties	include/ieee80211_ext.h	/^enum ieee80211_back_parties {$/;"	g
-ieee80211_category	include/ieee80211_ext.h	/^enum ieee80211_category {$/;"	g
-ieee80211_frag_entry	include/ieee80211.h	/^struct ieee80211_frag_entry {$/;"	s
-ieee80211_get_hdrlen	core/rtw_ieee80211.c	/^int ieee80211_get_hdrlen(u16 fc)$/;"	f
-ieee80211_header_data	include/ieee80211.h	/^struct ieee80211_header_data {$/;"	s
-ieee80211_ht_actioncode	include/ieee80211_ext.h	/^enum ieee80211_ht_actioncode {$/;"	g
-ieee80211_ht_addt_info	include/wifi.h	/^struct ieee80211_ht_addt_info {$/;"	s
-ieee80211_info_element	include/ieee80211.h	/^struct ieee80211_info_element {$/;"	s
-ieee80211_info_element_hdr	include/ieee80211.h	/^struct ieee80211_info_element_hdr {$/;"	s
-ieee80211_is_empty_essid	core/rtw_ieee80211.c	/^int ieee80211_is_empty_essid(const char *essid, int essid_len)$/;"	f
-ieee80211_mgmt	include/ieee80211_ext.h	/^struct ieee80211_mgmt {$/;"	s
-ieee80211_probe_request	include/ieee80211.h	/^struct ieee80211_probe_request {$/;"	s
-ieee80211_probe_response	include/ieee80211.h	/^struct ieee80211_probe_response {$/;"	s
-ieee80211_rx_stats	include/ieee80211.h	/^struct ieee80211_rx_stats {$/;"	s
-ieee80211_security	include/ieee80211.h	/^struct ieee80211_security {$/;"	s
-ieee80211_snap_hdr	include/ieee80211.h	/^struct ieee80211_snap_hdr {$/;"	s
-ieee80211_softmac_stats	include/ieee80211.h	/^struct ieee80211_softmac_stats {$/;"	s
-ieee80211_spectrum_mgmt_actioncode	include/ieee80211_ext.h	/^enum ieee80211_spectrum_mgmt_actioncode {$/;"	g
-ieee80211_state	include/ieee80211.h	/^enum ieee80211_state {$/;"	g
-ieee80211_stats	include/ieee80211.h	/^struct ieee80211_stats {$/;"	s
-ieee80211_txb	include/ieee80211.h	/^struct ieee80211_txb {$/;"	s
-ieee8021x_blocked	include/sta_info.h	/^	uint	ieee8021x_blocked;	\/* 0: allowed, 1:blocked *\/$/;"	m	struct:sta_info
-ieee_ibss_seq	include/ieee80211.h	/^struct ieee_ibss_seq {$/;"	s
-ieee_param	include/ieee80211.h	/^typedef struct ieee_param {$/;"	s
-ieee_param	include/ieee80211.h	/^} ieee_param;$/;"	t	typeref:struct:ieee_param
-ieee_param_ex	include/ieee80211.h	/^typedef struct ieee_param_ex {$/;"	s
-ieee_param_ex	include/ieee80211.h	/^} ieee_param_ex;$/;"	t	typeref:struct:ieee_param_ex
-if2name	include/drv_types.h	/^	u8 if2name[16];$/;"	m	struct:registry_priv
-if2name	os_dep/linux/os_intfs.c	/^	char *if2name = "p2p%d";$/;"	v
-if2name	os_dep/linux/os_intfs.c	/^	char *if2name = "wlan%d";$/;"	v
-if_g	include/drv_types.h	/^	struct macid_bmp if_g[CONFIG_IFACE_NUMBER];$/;"	m	struct:macid_ctl_t	typeref:struct:macid_ctl_t::macid_bmp
-iface	include/rtw_mcc.h	/^	PADAPTER iface[MAX_MCC_NUM]; \/* by order, use for mcc parameter cmd *\/$/;"	m	struct:mcc_obj_priv
-iface_addr	os_dep/linux/ioctl_cfg80211.h	/^	u8 iface_addr[ETH_ALEN];$/;"	m	struct:rtw_wdev_nego_info
-iface_bmc	include/drv_types.h	/^	u8 iface_bmc[CONFIG_IFACE_NUMBER];\/*for bc-sta of AP or Adhoc mode*\/$/;"	m	struct:macid_ctl_t
-iface_id	include/drv_types.h	/^	u8 iface_id;$/;"	m	struct:_ADAPTER
-iface_id	include/drv_types.h	/^	u8 iface_id;$/;"	m	struct:mbid_cam_cache
-iface_nums	include/drv_types.h	/^	u8 iface_nums; \/* total number of ifaces used runtime *\/$/;"	m	struct:dvobj_priv
-iface_state	include/drv_types.h	/^	struct mi_state iface_state;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::mi_state
-ifname	include/drv_types.h	/^	u8 ifname[16];$/;"	m	struct:registry_priv
-ifname	os_dep/linux/os_intfs.c	/^char *ifname = "wlan%d";$/;"	v
-ifname_mon	os_dep/linux/ioctl_cfg80211.h	/^	char ifname_mon[IFNAMSIZ + 1]; \/* interface name for monitor interface *\/$/;"	m	struct:rtw_wdev_priv
-ifr_ifrn	include/linux/wireless.h	/^	} ifr_ifrn;$/;"	m	struct:iwreq	typeref:union:iwreq::__anon68
-ifrn_name	include/linux/wireless.h	/^		char	ifrn_name[IFNAMSIZ];	\/* if name, e.g. "eth0" *\/$/;"	m	union:iwreq::__anon68
-igi_before_scan	include/rtw_mlme_ext.h	/^	u8 igi_before_scan; \/* used for restoring IGI value without enable DIG & FA_CNT *\/$/;"	m	struct:ss_res
-igi_scan	include/rtw_mlme_ext.h	/^	u8 igi_scan;$/;"	m	struct:ss_res
-ihl	include/ip.h	/^	__u8	ihl:4,$/;"	m	struct:iphdr
-in_cta_test	include/drv_types.h	/^	unsigned char     in_cta_test;$/;"	m	struct:_ADAPTER
-inc	include/rtw_mlme_ext.h	/^	u8 inc;$/;"	m	struct:p2p_oper_class_map
-increase_scan_dev_num	hal/btc/HalBtcOutSrc.h	/^	boolean					increase_scan_dev_num;$/;"	m	struct:btc_bt_info
-ind_buf	hal/btc/HalBtcOutSrc.h	/^	u1Byte					ind_buf[COL_H2C_BUF_LEN];	\/* the latest received c2h indication buffer *\/$/;"	m	struct:_COL_SINGLE_C2H_IND_RECORD
-ind_len	hal/btc/HalBtcOutSrc.h	/^	u4Byte					ind_len;$/;"	m	struct:_COL_SINGLE_C2H_IND_RECORD
-index	include/rtw_mp.h	/^	u8	index;$/;"	m	struct:_IOCMD_STRUCT_
-index	include/rtw_recv.h	/^	u32	index;			\/* index to current array to store *\/$/;"	m	struct:smooth_rssi_data
-index_mapping_HP_NUM	hal/phydm/phydm_powertracking_ap.h	37;"	d
-index_mapping_HP_NUM	hal/phydm/phydm_powertracking_ce.h	27;"	d
-index_mapping_HP_NUM	hal/phydm/phydm_powertracking_win.h	27;"	d
-index_mapping_NUM_8723D	hal/phydm/rtl8723d/halphyrf_8723d.h	26;"	d
-index_mapping_NUM_88E	hal/phydm/halphyrf_ap.c	25;"	d	file:
-indicate_seq	include/rtw_recv.h	/^	u16 indicate_seq;\/* =wstart_b, init_value=0xffff *\/$/;"	m	struct:recv_reorder_ctrl
-indicate_wx_custom_event	os_dep/linux/ioctl_linux.c	/^static void indicate_wx_custom_event(_adapter *padapter, char *msg)$/;"	f	file:
-indicate_wx_scan_complete_event	os_dep/linux/ioctl_linux.c	/^void indicate_wx_scan_complete_event(_adapter *padapter)$/;"	f
-indicator	include/drv_types.h	/^	struct halmac_indicator *indicator;$/;"	m	struct:halmacpriv	typeref:struct:halmacpriv::halmac_indicator
-info	hal/hal_btcoex.c	/^	u8 *info;$/;"	m	struct:_btcoexdbginfo	file:
-info_element	include/ieee80211.h	/^	struct ieee80211_info_element info_element;$/;"	m	struct:ieee80211_probe_response	typeref:struct:ieee80211_probe_response::ieee80211_info_element
-info_element	include/ieee80211.h	/^	struct ieee80211_info_element_hdr info_element;$/;"	m	struct:ieee80211_assoc_request_frame	typeref:struct:ieee80211_assoc_request_frame::ieee80211_info_element_hdr
-information_buf	include/rtw_ioctl.h	/^	void		*information_buf;$/;"	m	struct:oid_par_priv
-information_buf_len	include/rtw_ioctl.h	/^	u32		information_buf_len;$/;"	m	struct:oid_par_priv
-infos	include/wifi.h	/^	unsigned char	infos[5];$/;"	m	struct:HT_info_element
-inirp_deinit	include/hal_intf.h	/^	u32(*inirp_deinit)(_adapter *padapter);$/;"	m	struct:hal_ops
-inirp_init	include/hal_intf.h	/^	u32(*inirp_init)(_adapter *padapter);$/;"	m	struct:hal_ops
-initDeltaSwingIndexTables	hal/hal_com_phycfg.c	/^initDeltaSwingIndexTables($/;"	f
-initLoopback	os_dep/linux/ioctl_linux.c	/^static s32 initLoopback(PADAPTER padapter)$/;"	f	file:
-init_addba_retry_timer	os_dep/linux/mlme_linux.c	/^void init_addba_retry_timer(_adapter *padapter, struct sta_info *psta)$/;"	f
-init_adpt_in_progress	include/drv_types.h	/^	u8	init_adpt_in_progress;$/;"	m	struct:_ADAPTER
-init_channel_list	core/rtw_mlme_ext.c	/^static void init_channel_list(_adapter *padapter, RT_CHANNEL_INFO *channel_set,$/;"	f	file:
-init_channel_set	core/rtw_mlme_ext.c	/^static u8 init_channel_set(_adapter *padapter, u8 ChannelPlan, RT_CHANNEL_INFO *channel_set)$/;"	f	file:
-init_default_value	include/hal_intf.h	/^	void	(*init_default_value)(_adapter *padapter);$/;"	m	struct:hal_ops
-init_dot11w_expire_timer	os_dep/linux/mlme_linux.c	/^void init_dot11w_expire_timer(_adapter *padapter, struct sta_info *psta)$/;"	f
-init_fwstate	include/rtw_mlme.h	/^static inline void init_fwstate(struct mlme_priv *pmlmepriv, sint state)$/;"	f
-init_h2fwcmd_w_parm_no_parm_rsp	include/rtw_cmd.h	138;"	d
-init_h2fwcmd_w_parm_no_rsp	include/rtw_cmd.h	128;"	d
-init_hal_spec_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^void init_hal_spec_8723d(_adapter *adapter)$/;"	f
-init_halmac_event	hal/hal_halmac.c	/^static inline int init_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id, u8 *buf, u32 size)$/;"	f	file:
-init_halmac_event_with_waittime	hal/hal_halmac.c	/^static int init_halmac_event_with_waittime(struct dvobj_priv *d, HALMAC_FEATURE_ID id, u8 *buf, u32 size, u32 time)$/;"	f	file:
-init_hw_mlme_ext	core/rtw_mlme_ext.c	/^int init_hw_mlme_ext(_adapter *padapter)$/;"	f
-init_mac_flow	hal/hal_halmac.c	/^static HALMAC_RET_STATUS init_mac_flow(struct dvobj_priv *d)$/;"	f	file:
-init_mac_register	include/hal_intf.h	/^	u8(*init_mac_register)(PADAPTER);$/;"	m	struct:hal_ops
-init_mlme_ap_info	core/rtw_ap.c	/^void init_mlme_ap_info(_adapter *padapter)$/;"	f
-init_mlme_default_rate_set	core/rtw_mlme_ext.c	/^void init_mlme_default_rate_set(_adapter *padapter)$/;"	f
-init_mlme_ext_priv	core/rtw_mlme_ext.c	/^int	init_mlme_ext_priv(_adapter *padapter)$/;"	f
-init_mlme_ext_priv_value	core/rtw_mlme_ext.c	/^static void init_mlme_ext_priv_value(_adapter *padapter)$/;"	f	file:
-init_mlme_ext_timer	os_dep/linux/mlme_linux.c	/^void init_mlme_ext_timer(_adapter *padapter)$/;"	f
-init_mp_priv	core/rtw_mp.c	/^s32 init_mp_priv(PADAPTER padapter)$/;"	f
-init_mp_priv_by_os	core/rtw_mp.c	/^static int init_mp_priv_by_os(struct mp_priv *pmp_priv)$/;"	f	file:
-init_phy	include/hal_intf.h	/^	u8(*init_phy)(PADAPTER);$/;"	m	struct:hal_ops
-init_priv	hal/hal_halmac.c	/^static int init_priv(struct halmacpriv *priv)$/;"	f	file:
-init_rate	include/sta_info.h	/^	u8	init_rate;$/;"	m	struct:sta_info
-init_recv_priv	include/hal_intf.h	/^	s32(*init_recv_priv)(_adapter *padapter);$/;"	m	struct:hal_ops
-init_rtsp_ctrlport	include/rtw_mlme.h	/^	u16							init_rtsp_ctrlport;	\/* init value of rtsp_ctrlport when WFD enable *\/$/;"	m	struct:wifi_display_info
-init_sta	include/rtw_tdls.h	/^	u8 init_sta[ETH_ALEN];$/;"	m	struct:wpa_tdls_lnkid
-init_value	include/osdep_service.h	/^	u8 init_value;$/;"	m	struct:map_t
-init_wifidirect_info	core/rtw_p2p.c	/^void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role)$/;"	f
-init_xmit_priv	include/hal_intf.h	/^	s32(*init_xmit_priv)(_adapter *padapter);$/;"	m	struct:hal_ops
-initialize	hal/phydm/phydm_dynamicbbpowersaving.h	/^	u1Byte		initialize;$/;"	m	struct:_Dynamic_Power_Saving_
-initiator	include/rtw_mlme.h	/^	u8	initiator;	\/* 0: None, 1: we initiate, 2: peer initiate *\/$/;"	m	struct:tdls_temp_mgmt
-initilized	hal/btc/HalBtcOutSrc.h	/^	BOOLEAN					initilized;$/;"	m	struct:btc_coexist
-initpseudoadhoc	os_dep/linux/ioctl_linux.c	/^static s32 initpseudoadhoc(PADAPTER padapter)$/;"	f	file:
-initrecvbuf	hal/rtl8723d/sdio/rtl8723ds_recv.c	/^static s32 initrecvbuf(struct recv_buf *precvbuf, PADAPTER padapter)$/;"	f	file:
-int_bt	include/rtl8188e_xmit.h	/^	u8 int_bt:1;$/;"	m	struct:txrpt_ccx_88e
-int_bt	include/rtl8192e_xmit.h	/^	u8 int_bt:1;$/;"	m	struct:txrpt_ccx_92e
-int_ccx	include/rtl8188e_xmit.h	/^	u8 int_ccx:1;$/;"	m	struct:txrpt_ccx_88e
-int_ccx	include/rtl8192e_xmit.h	/^	u8 int_ccx:1;$/;"	m	struct:txrpt_ccx_92e
-int_in_buf	include/rtw_recv.h	/^	u8	*int_in_buf;$/;"	m	struct:recv_priv
-int_in_urb	include/rtw_recv.h	/^	PURB	int_in_urb;$/;"	m	struct:recv_priv
-int_logs	include/drv_types.h	/^	struct int_logs int_logs;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::int_logs
-int_logs	include/drv_types.h	/^struct int_logs {$/;"	s
-int_tri	include/rtl8188e_xmit.h	/^	u8 int_tri:1;$/;"	m	struct:txrpt_ccx_88e
-int_tri	include/rtl8192e_xmit.h	/^	u8 int_tri:1;$/;"	m	struct:txrpt_ccx_92e
-intel_proxim	include/rtw_xmit.h	/^	u8	intel_proxim;$/;"	m	struct:pkt_attrib
-intent	include/rtw_mlme.h	/^	u8						intent;		\/*	should only include the intent value. *\/$/;"	m	struct:wifidirect_info
-inter_bcn_space	include/drv_types.h	/^	u32 inter_bcn_space; \/* unit:ms *\/$/;"	m	struct:dvobj_priv
-interfaceIndex	include/hal_data.h	/^	u32	interfaceIndex;$/;"	m	struct:hal_com_data
-interface_addr	include/rtw_mlme.h	/^	u8						interface_addr[ETH_ALEN];$/;"	m	struct:wifidirect_info
-interface_msk	include/HalPwrSeqCmd.h	/^	u8 interface_msk:4;$/;"	m	struct:_WL_PWR_CFG_
-interface_ps_func	include/hal_intf.h	/^	u8(*interface_ps_func)(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val);$/;"	m	struct:hal_ops
-interface_type	include/drv_types.h	/^	u8	interface_type;\/*USB,SDIO,SPI,PCI*\/$/;"	m	struct:dvobj_priv
-interrupt_enable_mask	include/drv_types.h	/^		u8 interrupt_enable_mask;$/;"	m	struct:_ADAPTER::gpio_int_priv
-interrupt_handler	include/hal_intf.h	/^	s32(*interrupt_handler)(_adapter *padapter);$/;"	m	struct:hal_ops
-interrupt_handler	include/hal_intf.h	/^	void	(*interrupt_handler)(_adapter *padapter, u16 pkt_len, u8 *pbuf);$/;"	m	struct:hal_ops
-interrupt_mode	include/drv_types.h	/^		u8 interrupt_mode;$/;"	m	struct:_ADAPTER::gpio_int_priv
-intf	include/rtw_io.h	/^	struct	intf_hdl	intf;$/;"	m	struct:io_queue	typeref:struct:io_queue::intf_hdl
-intf	include/rtw_io.h	/^	struct intf_hdl intf;$/;"	m	struct:io_priv	typeref:struct:io_priv::intf_hdl
-intf_alloc_irq	include/drv_types.h	/^	int (*intf_alloc_irq)(struct dvobj_priv *dvobj);$/;"	m	struct:_ADAPTER
-intf_chip_configure	include/hal_intf.h	/^	void	(*intf_chip_configure)(_adapter *padapter);$/;"	m	struct:hal_ops
-intf_data	include/drv_types.h	/^	INTF_DATA intf_data;$/;"	m	struct:dvobj_priv
-intf_deinit	include/drv_types.h	/^	void (*intf_deinit)(struct dvobj_priv *dvobj);$/;"	m	struct:_ADAPTER
-intf_dev	include/osdep_intf.h	/^	u8 *intf_dev;$/;"	m	struct:intf_priv
-intf_flag	hal/phydm/phydm.h	/^	u1Byte	intf_flag;$/;"	m	struct:_Dynamic_Primary_CCA
-intf_free_irq	include/drv_types.h	/^	void (*intf_free_irq)(struct dvobj_priv *dvobj);$/;"	m	struct:_ADAPTER
-intf_hdl	include/rtw_io.h	/^struct	intf_hdl {$/;"	s
-intf_init	include/drv_types.h	/^	u32(*intf_init)(struct dvobj_priv *dvobj);$/;"	m	struct:_ADAPTER
-intf_ops	include/drv_types.h	/^	INTF_OPS intf_ops;$/;"	m	struct:dvobj_priv
-intf_pos	hal/phydm/phydm_hwconfig.h	/^	u1Byte		intf_pos;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-intf_pos_msb	hal/phydm/phydm_hwconfig.h	/^	u1Byte		intf_pos_msb: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-intf_priv	include/osdep_intf.h	/^struct intf_priv {$/;"	s
-intf_rx	include/drv_types.h	/^	u32 intf_rx;$/;"	m	struct:rx_logs
-intf_rx_err_recvframe	include/drv_types.h	/^	u32 intf_rx_err_recvframe;$/;"	m	struct:rx_logs
-intf_rx_err_skb	include/drv_types.h	/^	u32 intf_rx_err_skb;$/;"	m	struct:rx_logs
-intf_rx_report	include/drv_types.h	/^	u32 intf_rx_report;$/;"	m	struct:rx_logs
-intf_start	include/drv_types.h	/^	void (*intf_start)(_adapter *adapter);$/;"	m	struct:_ADAPTER
-intf_status	include/osdep_intf.h	/^	u8 intf_status;$/;"	m	struct:intf_priv
-intf_stop	include/drv_types.h	/^	void (*intf_stop)(_adapter *adapter);$/;"	m	struct:_ADAPTER
-intf_tx	include/drv_types.h	/^	u32 intf_tx;$/;"	m	struct:tx_logs
-intf_tx_dequeue	include/drv_types.h	/^	u32 intf_tx_dequeue;$/;"	m	struct:tx_logs
-intf_tx_dequeue_err_coalesce	include/drv_types.h	/^	u32 intf_tx_dequeue_err_coalesce;$/;"	m	struct:tx_logs
-intf_tx_direct	include/drv_types.h	/^	u32 intf_tx_direct;$/;"	m	struct:tx_logs
-intf_tx_direct_err_coalesce	include/drv_types.h	/^	u32 intf_tx_direct_err_coalesce;$/;"	m	struct:tx_logs
-intf_tx_dump_xframe	include/drv_types.h	/^	u32 intf_tx_dump_xframe;$/;"	m	struct:tx_logs
-intf_tx_dump_xframe_err_port	include/drv_types.h	/^	u32 intf_tx_dump_xframe_err_port;$/;"	m	struct:tx_logs
-intf_tx_dump_xframe_err_txdesc	include/drv_types.h	/^	u32 intf_tx_dump_xframe_err_txdesc;$/;"	m	struct:tx_logs
-intf_tx_enqueue	include/drv_types.h	/^	u32 intf_tx_enqueue;$/;"	m	struct:tx_logs
-intf_tx_pending_ac	include/drv_types.h	/^	u32 intf_tx_pending_ac;$/;"	m	struct:tx_logs
-intf_tx_pending_fw_under_linking	include/drv_types.h	/^	u32 intf_tx_pending_fw_under_linking;$/;"	m	struct:tx_logs
-intf_tx_pending_fw_under_survey	include/drv_types.h	/^	u32 intf_tx_pending_fw_under_survey;$/;"	m	struct:tx_logs
-intf_tx_pending_xmitbuf	include/drv_types.h	/^	u32 intf_tx_pending_xmitbuf;$/;"	m	struct:tx_logs
-intf_type	hal/phydm/phydm.h	/^	u1Byte	intf_type;  $/;"	m	struct:_Dynamic_Primary_CCA
-invalidate_cam_all	core/rtw_wlan_util.c	/^void invalidate_cam_all(_adapter *padapter)$/;"	f
-invit_info	os_dep/linux/ioctl_cfg80211.h	/^	struct rtw_wdev_invit_info invit_info;$/;"	m	struct:rtw_wdev_priv	typeref:struct:rtw_wdev_priv::rtw_wdev_invit_info
-invite_req	include/rtw_btcoex.h	84;"	d
-invite_rsp	include/rtw_btcoex.h	85;"	d
-invitereq_info	include/rtw_mlme.h	/^	struct tx_invite_req_info	invitereq_info;$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::tx_invite_req_info
-inviteresp_info	include/rtw_mlme.h	/^	struct tx_invite_resp_info	inviteresp_info;$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::tx_invite_resp_info
-ioStaString	hal/hal_btcoex.c	/^const char *const ioStaString[] = {$/;"	v
-io_irp_cnt	include/osdep_intf.h	/^	u8 io_irp_cnt;$/;"	m	struct:intf_priv
-io_offset	include/rtw_mp.h	/^	u32 io_offset;$/;"	m	struct:mp_wiparam
-io_ops	include/rtw_io.h	/^	struct _io_ops	io_ops;$/;"	m	struct:intf_hdl	typeref:struct:intf_hdl::_io_ops
-io_priv	include/rtw_io.h	/^struct io_priv {$/;"	s
-io_queue	include/rtw_io.h	/^struct io_queue {$/;"	s
-io_reg_lock	include/drv_types.h	/^	_lock   io_reg_lock;$/;"	m	struct:dvobj_priv
-io_req	include/rtw_io.h	/^struct io_req {$/;"	s
-io_retevt	include/osdep_intf.h	/^	_sema io_retevt;$/;"	m	struct:intf_priv
-io_rsz	include/osdep_intf.h	/^	u32	io_rsz;\/* unit: 4bytes *\/$/;"	m	struct:intf_priv
-io_rwmem	include/osdep_intf.h	/^	volatile u8 *io_rwmem;$/;"	m	struct:intf_priv
-io_timer	include/osdep_intf.h	/^	_timer	io_timer;$/;"	m	struct:intf_priv
-io_value	include/rtw_mp.h	/^	u32 io_value;$/;"	m	struct:mp_wiparam
-io_wsz	include/osdep_intf.h	/^	u32	io_wsz; \/* unit: 4bytes *\/$/;"	m	struct:intf_priv
-ioctl_mutex	include/osdep_intf.h	/^	_mutex ioctl_mutex;$/;"	m	struct:intf_priv
-iopriv	include/drv_types.h	/^	struct	io_priv	iopriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::io_priv
-ioreg_cfg	include/rtw_iol.h	/^struct ioreg_cfg {$/;"	s
-ioreg_cmd	include/rtw_iol.h	/^enum ioreg_cmd {$/;"	g
-ip_address	include/rtw_mlme.h	/^	u8							ip_address[4];$/;"	m	struct:wifi_display_info
-ip_chkrpt	include/rtw_recv.h	/^	u8	ip_chkrpt; \/* 0: incorrect, 1: correct *\/$/;"	m	struct:rx_pkt_attrib
-ip_options	include/ip.h	/^struct ip_options {$/;"	s
-ip_summed	include/osdep_service_bsd.h	/^				ip_summed:2,$/;"	m	struct:sk_buff
-iphdr	include/ip.h	/^struct iphdr {$/;"	s
-ips_deny_time	include/rtw_pwrctrl.h	/^	u32 ips_deny_time; \/* will deny IPS when system time is smaller than this *\/$/;"	m	struct:pwrctrl_priv
-ips_enter	core/rtw_pwrctrl.c	/^void ips_enter(_adapter *padapter)$/;"	f
-ips_enter_cnts	include/rtw_pwrctrl.h	/^	uint	ips_enter_cnts;$/;"	m	struct:pwrctrl_priv
-ips_leave	core/rtw_pwrctrl.c	/^int ips_leave(_adapter *padapter)$/;"	f
-ips_leave_cnts	include/rtw_pwrctrl.h	/^	uint	ips_leave_cnts;$/;"	m	struct:pwrctrl_priv
-ips_mode	include/drv_types.h	/^	u8	ips_mode;$/;"	m	struct:registry_priv
-ips_mode	include/rtw_pwrctrl.h	/^	u8	ips_mode;$/;"	m	struct:pwrctrl_priv
-ips_mode_req	include/rtw_pwrctrl.h	/^	u8	ips_mode_req; \/* used to accept the mode setting request, will update to ipsmode later *\/$/;"	m	struct:pwrctrl_priv
-ips_netdrv_open	os_dep/linux/os_intfs.c	/^int  ips_netdrv_open(_adapter *padapter)$/;"	f
-ips_org_mode	include/rtw_pwrctrl.h	/^	u8	ips_org_mode;$/;"	m	struct:pwrctrl_priv
-ipvs_property	include/osdep_service_bsd.h	/^				ipvs_property:1,$/;"	m	struct:sk_buff
-iqk_reg_backup	include/hal_data.h	/^	struct hal_iqk_reg_backup iqk_reg_backup[MAX_IQK_INFO_BACKUP_CHNL_NUM];$/;"	m	struct:hal_com_data	typeref:struct:hal_com_data::hal_iqk_reg_backup
-iqk_sctx	include/hal_data.h	/^	struct submit_ctx	iqk_sctx;$/;"	m	struct:hal_com_data	typeref:struct:hal_com_data::submit_ctx
-irp_pending	include/rtw_recv.h	/^	u8  irp_pending;$/;"	m	struct:recv_buf
-irp_reset	include/hal_intf.h	/^	void	(*irp_reset)(_adapter *padapter);$/;"	m	struct:hal_ops
-irpcnt	include/rtw_mp.h	/^	uint irpcnt;$/;"	m	struct:mp_xmit_frame
-irq	include/drv_types.h	/^	unsigned int irq; \/* get from pci_dev.irq, store to net_device.irq *\/$/;"	m	struct:dvobj_priv
-irq_alloc	include/drv_types.h	/^	u8	irq_alloc;$/;"	m	struct:dvobj_priv
-irq_enabled	include/drv_types.h	/^	u8	irq_enabled;$/;"	m	struct:dvobj_priv
-irq_prepare_beacon_tasklet	include/rtw_recv.h	/^	struct task irq_prepare_beacon_tasklet;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::task
-irq_prepare_beacon_tasklet	include/rtw_recv.h	/^	struct tasklet_struct irq_prepare_beacon_tasklet;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::tasklet_struct
-irq_th_lock	include/drv_types.h	/^	_lock	irq_th_lock;$/;"	m	struct:dvobj_priv
-irq_work	include/drv_types_gspi.h	/^	struct delayed_work irq_work;$/;"	m	struct:gspi_data	typeref:struct:gspi_data::delayed_work
-irqline	include/drv_types.h	/^	u16	irqline;$/;"	m	struct:dvobj_priv
-isAdaptorInfoFileValid	core/efuse/rtw_efuse.c	/^int isAdaptorInfoFileValid(void)$/;"	f
-isAllSpaceOrTab	hal/hal_com.c	/^isAllSpaceOrTab($/;"	f
-isFileReadable	os_dep/osdep_service.c	/^static int isFileReadable(const char *path, u32 *sz)$/;"	f	file:
-isMPmode	hal/phydm/phydm_powertracking_ap.h	/^	BOOLEAN	isMPmode;$/;"	m	struct:ODM_RF_Calibration_Structure
-isMPmode	hal/phydm/phydm_powertracking_ce.h	/^	BOOLEAN	isMPmode;$/;"	m	struct:ODM_RF_Calibration_Structure
-isMPmode	hal/phydm/phydm_powertracking_win.h	/^	BOOLEAN	isMPmode;$/;"	m	struct:ODM_RF_Calibration_Structure
-is_8021x	include/rtw_mlme.h	/^	int is_8021x;$/;"	m	struct:beacon_keys
-is_8021x	include/wlan_bssdef.h	/^	int is_8021x;$/;"	m	struct:_WLAN_BCN_INFO
-is_A2DP_3M	hal/btc/halbtc8723d1ant.h	/^	boolean				is_A2DP_3M;$/;"	m	struct:coex_sta_8723d_1ant
-is_A2DP_3M	hal/btc/halbtc8723d2ant.h	/^	boolean				is_A2DP_3M;$/;"	m	struct:coex_sta_8723d_2ant
-is_AntDet_running	hal/btc/halbtc8723d1ant.h	/^	boolean			is_AntDet_running;$/;"	m	struct:psdscan_sta_8723d_1ant
-is_AntDet_running	hal/btc/halbtc8723d2ant.h	/^	boolean			is_AntDet_running;$/;"	m	struct:psdscan_sta_8723d_2ant
-is_BTG	hal/phydm/phydm_iqk.h	/^	BOOLEAN		is_BTG;$/;"	m	struct:_IQK_INFORMATION
-is_IBSS_empty	core/rtw_wlan_util.c	/^int is_IBSS_empty(_adapter *padapter)$/;"	f
-is_alpha	os_dep/osdep_service.c	/^inline BOOLEAN is_alpha(char chTmp)$/;"	f
-is_any_client_associated	core/rtw_p2p.c	/^int is_any_client_associated(_adapter *padapter)$/;"	f
-is_ap_in_tkip	core/rtw_wlan_util.c	/^unsigned int is_ap_in_tkip(_adapter *padapter)$/;"	f
-is_ap_in_wep	core/rtw_wlan_util.c	/^unsigned int is_ap_in_wep(_adapter *padapter)$/;"	f
-is_autoslot	hal/btc/halbtc8723d1ant.h	/^	boolean				is_autoslot;$/;"	m	struct:coex_sta_8723d_1ant
-is_autoslot	hal/btc/halbtc8723d2ant.h	/^	boolean				is_autoslot;$/;"	m	struct:coex_sta_8723d_2ant
-is_basicrate	core/rtw_wlan_util.c	/^int is_basicrate(_adapter *padapter, unsigned char rate)$/;"	f
-is_boot_from_eeprom	include/hal_data.h	755;"	d
-is_broadcast_mac_addr	include/ieee80211.h	/^extern __inline int is_broadcast_mac_addr(const u8 *addr)$/;"	f
-is_broadcast_mac_addr	include/ieee80211.h	1480;"	d
-is_changed	include/ip.h	/^		 is_changed:1,			\/* IP checksum more not valid		*\/$/;"	m	struct:ip_options
-is_client_associated_to_ap	core/rtw_wlan_util.c	/^int is_client_associated_to_ap(_adapter *padapter)$/;"	f
-is_client_associated_to_ibss	core/rtw_wlan_util.c	/^int is_client_associated_to_ibss(_adapter *padapter)$/;"	f
-is_data	include/ip.h	/^		 is_data:1,			\/* Options in __data, rather than skb	*\/$/;"	m	struct:ip_options
-is_drv_in_lps	core/rtw_mlme.c	/^static u8 is_drv_in_lps(_adapter *adapter)$/;"	f	file:
-is_eSCO_mode	hal/btc/halbtc8723d2ant.h	/^	boolean             is_eSCO_mode;$/;"	m	struct:coex_sta_8723d_2ant
-is_eol	os_dep/osdep_service.c	/^inline BOOLEAN is_eol(char c)$/;"	f
-is_exist	include/rtw_btcoex.h	/^	u8 is_exist; \/* socket exist *\/$/;"	m	struct:bt_coex_info
-is_hiPri_rx_overhead	hal/btc/halbtc8723d1ant.h	/^	boolean             is_hiPri_rx_overhead;$/;"	m	struct:coex_sta_8723d_1ant
-is_hiPri_rx_overhead	hal/btc/halbtc8723d2ant.h	/^	boolean             is_hiPri_rx_overhead;$/;"	m	struct:coex_sta_8723d_2ant
-is_high_active	include/rtw_pwrctrl.h	/^	u8		is_high_active;$/;"	m	struct:pwrctrl_priv
-is_matched_in_profilelist	core/rtw_mlme_ext.c	/^u8 is_matched_in_profilelist(u8 *peermacaddr, struct profile_info *profileinfo)$/;"	f
-is_mgmt_tx	os_dep/linux/ioctl_cfg80211.h	/^	u8 is_mgmt_tx;$/;"	m	struct:rtw_wdev_priv
-is_miracast_enabled	core/rtw_mlme.c	/^bool is_miracast_enabled(_adapter *adapter)$/;"	f
-is_mu_ap	hal/phydm/phydm_beamforming.h	/^	BOOLEAN				is_mu_ap;$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-is_mu_sounding	hal/phydm/phydm_beamforming.h	/^	BOOLEAN					is_mu_sounding;$/;"	m	struct:_RT_BEAMFORMING_INFO
-is_mu_sounding_in_progress	hal/phydm/phydm_beamforming.h	/^	BOOLEAN					is_mu_sounding_in_progress;$/;"	m	struct:_RT_BEAMFORMING_INFO
-is_mu_sta	hal/phydm/phydm_beamforming.h	/^	BOOLEAN	is_mu_sta;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-is_multicast_mac_addr	include/ieee80211.h	/^extern __inline int is_multicast_mac_addr(const u8 *addr)$/;"	f
-is_multicast_mac_addr	include/ieee80211.h	1479;"	d
-is_null	os_dep/osdep_service.c	/^inline BOOLEAN is_null(char c)$/;"	f
-is_p2p_device	include/sta_info.h	/^	u8 is_p2p_device;$/;"	m	struct:sta_info
-is_pathA_exist	hal/phydm/phydm_pathdiv.h	/^	BOOLEAN is_pathA_exist;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-is_primary_adapter	include/drv_types.h	463;"	d
-is_primary_adapter	include/drv_types.h	467;"	d
-is_psd_running	hal/btc/HalBtc8703b1Ant.h	/^	boolean			is_psd_running;$/;"	m	struct:psdscan_sta_8703b_1ant
-is_psd_running	hal/btc/HalBtc8723b1Ant.h	/^	boolean			is_psd_running;$/;"	m	struct:psdscan_sta_8723b_1ant
-is_psd_running	hal/btc/HalBtc8822b1Ant.h	/^	boolean			is_psd_running;$/;"	m	struct:psdscan_sta_8822b_1ant
-is_psd_running	hal/btc/halbtc8821c1ant.h	/^	boolean			is_psd_running;$/;"	m	struct:psdscan_sta_8821c_1ant
-is_psd_running	hal/btc/halbtc8821c2ant.h	/^	boolean			is_psd_running;$/;"	m	struct:psdscan_sta_8821c_2ant
-is_psd_show_max_only	hal/btc/HalBtc8703b1Ant.h	/^	boolean			is_psd_show_max_only;$/;"	m	struct:psdscan_sta_8703b_1ant
-is_psd_show_max_only	hal/btc/HalBtc8723b1Ant.h	/^	boolean			is_psd_show_max_only;$/;"	m	struct:psdscan_sta_8723b_1ant
-is_psd_show_max_only	hal/btc/HalBtc8822b1Ant.h	/^	boolean			is_psd_show_max_only;$/;"	m	struct:psdscan_sta_8822b_1ant
-is_psd_show_max_only	hal/btc/halbtc8723d1ant.h	/^	boolean			is_psd_show_max_only;$/;"	m	struct:psdscan_sta_8723d_1ant
-is_psd_show_max_only	hal/btc/halbtc8723d2ant.h	/^	boolean			is_psd_show_max_only;$/;"	m	struct:psdscan_sta_8723d_2ant
-is_psd_show_max_only	hal/btc/halbtc8821c1ant.h	/^	boolean			is_psd_show_max_only;$/;"	m	struct:psdscan_sta_8821c_1ant
-is_psd_show_max_only	hal/btc/halbtc8821c2ant.h	/^	boolean			is_psd_show_max_only;$/;"	m	struct:psdscan_sta_8821c_2ant
-is_ra_dbg_init	hal/phydm/phydm_rainfo.h	/^	BOOLEAN		is_ra_dbg_init;$/;"	m	struct:_Rate_Adaptive_Table_
-is_ro_ch	include/rtw_mlme.h	/^	bool is_ro_ch;$/;"	m	struct:cfg80211_wifidirect_info
-is_same_ess	core/rtw_mlme.c	/^inline int is_same_ess(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b)$/;"	f
-is_same_network	core/rtw_mlme.c	/^int is_same_network(WLAN_BSSID_EX *src, WLAN_BSSID_EX *dst, u8 feature)$/;"	f
-is_setbyuser	include/ip.h	/^	unsigned char is_setbyuser:1,			\/* Set by setsockopt?			*\/$/;"	m	struct:ip_options
-is_setupLink	hal/btc/halbtc8723d1ant.h	/^	boolean				is_setupLink;$/;"	m	struct:coex_sta_8723d_1ant
-is_setupLink	hal/btc/halbtc8723d2ant.h	/^	boolean				is_setupLink;$/;"	m	struct:coex_sta_8723d_2ant
-is_signal_dbg	include/rtw_recv.h	/^	u8 is_signal_dbg;	\/* for debug *\/$/;"	m	struct:recv_priv
-is_space	os_dep/osdep_service.c	/^inline BOOLEAN is_space(char c)$/;"	f
-is_strictroute	include/ip.h	/^		 is_strictroute:1,		\/* Strict source route			*\/$/;"	m	struct:ip_options
-is_sw_antdiv_bl_scan	include/rtw_mlme_ext.h	/^	u8 is_sw_antdiv_bl_scan;$/;"	m	struct:ss_res
-is_switch_to_1dot5_ant	hal/btc/HalBtc8723b2Ant.h	/^	boolean		is_switch_to_1dot5_ant;$/;"	m	struct:coex_dm_8723b_2ant
-is_switch_to_1dot5_ant	hal/btc/halbtc8723d2ant.h	/^	boolean		is_switch_to_1dot5_ant;$/;"	m	struct:coex_dm_8723d_2ant
-is_switch_to_1dot5_ant	hal/btc/halbtc8821c2ant.h	/^	boolean		is_switch_to_1dot5_ant;$/;"	m	struct:coex_dm_8821c_2ant
-is_tdls_sta	include/rtw_mlme.h	/^	u8		is_tdls_sta;	\/* _TRUE: direct link sta, _FALSE: else *\/$/;"	m	struct:tdls_ss_record
-is_tdma_btautoslot	hal/btc/halbtc8723d1ant.h	/^	boolean				is_tdma_btautoslot;$/;"	m	struct:coex_sta_8723d_1ant
-is_tdma_btautoslot	hal/btc/halbtc8723d2ant.h	/^	boolean				is_tdma_btautoslot;$/;"	m	struct:coex_sta_8723d_2ant
-is_tdma_btautoslot_hang	hal/btc/halbtc8723d1ant.h	/^	boolean				is_tdma_btautoslot_hang;$/;"	m	struct:coex_sta_8723d_1ant
-is_tdma_btautoslot_hang	hal/btc/halbtc8723d2ant.h	/^	boolean				is_tdma_btautoslot_hang;$/;"	m	struct:coex_sta_8723d_2ant
-is_trigger	include/rtw_mlme.h	/^	u8						is_trigger;$/;"	m	struct:p2p_wowlan_info
-is_u3_mode	hal/phydm/phydm_pathdiv.h	/^	BOOLEAN	is_u3_mode;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-is_valid_id_status	hal/hal_halmac.c	/^static inline u8 is_valid_id_status(HALMAC_FEATURE_ID id, HALMAC_CMD_PROCESS_STATUS status)$/;"	f	file:
-is_vir_adapter	include/drv_types.h	464;"	d
-is_vir_adapter	include/drv_types.h	468;"	d
-is_wep_enc	include/rtw_security.h	40;"	d
-is_zero_mac_addr	include/ieee80211.h	/^extern __inline int is_zero_mac_addr(const u8 *addr)$/;"	f
-iso_name	include/rtw_wifi_regd.h	/^	const char *iso_name;$/;"	m	struct:country_code_to_enum_rd
-isolation_btween_wb	hal/btc/halbtc8723d1ant.h	/^	u8					isolation_btween_wb;   \/* 0~ 50 *\/$/;"	m	struct:coex_sta_8723d_1ant
-isolation_btween_wb	hal/btc/halbtc8723d2ant.h	/^	u8					isolation_btween_wb;   \/* 0~ 50 *\/$/;"	m	struct:coex_sta_8723d_2ant
-isolation_btween_wb	hal/btc/halbtc8821c2ant.h	/^	u8					isolation_btween_wb;   \/* 0~ 50 *\/$/;"	m	struct:coex_sta_8821c_2ant
-isprimary	include/drv_types.h	/^	u8 isprimary; \/* is primary adapter or not *\/$/;"	m	struct:_ADAPTER
-isr_content	include/drv_types.h	/^	RT_ISR_CONTENT	isr_content;$/;"	m	struct:dvobj_priv
-isrc	include/sta_info.h	/^	u8 isrc; \/* this device is rc *\/$/;"	m	struct:sta_info
-issue_action_BSSCoexistPacket	core/rtw_mlme_ext.c	/^static void issue_action_BSSCoexistPacket(_adapter *padapter)$/;"	f	file:
-issue_action_SA_Query	core/rtw_mlme_ext.c	/^void issue_action_SA_Query(_adapter *padapter, unsigned char *raddr, unsigned char action, unsigned short tid, u8 key_type)$/;"	f
-issue_action_SM_PS	core/rtw_mlme_ext.c	/^int issue_action_SM_PS(_adapter *padapter ,  unsigned char *raddr , u8 NewMimoPsMode)$/;"	f
-issue_action_SM_PS_wait_ack	core/rtw_mlme_ext.c	/^int issue_action_SM_PS_wait_ack(_adapter *padapter, unsigned char *raddr, u8 NewMimoPsMode, int try_cnt, int wait_ms)$/;"	f
-issue_action_ba	core/rtw_mlme_ext.c	/^static int issue_action_ba(_adapter *padapter, unsigned char *raddr, unsigned char action$/;"	f	file:
-issue_action_ft_request	core/rtw_mlme_ext.c	/^void issue_action_ft_request(_adapter *padapter, u8 *pTargetAddr)$/;"	f
-issue_action_spct_ch_switch	core/rtw_mlme_ext.c	/^void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset)$/;"	f
-issue_addba_req	core/rtw_mlme_ext.c	/^inline void issue_addba_req(_adapter *adapter, unsigned char *ra, u8 tid)$/;"	f
-issue_addba_rsp	core/rtw_mlme_ext.c	/^inline void issue_addba_rsp(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size)$/;"	f
-issue_addba_rsp_wait_ack	core/rtw_mlme_ext.c	/^inline u8 issue_addba_rsp_wait_ack(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size, int try_cnt, int wait_ms)$/;"	f
-issue_asocrsp	core/rtw_mlme_ext.c	/^void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *pstat, int pkt_type)$/;"	f
-issue_assocreq	core/rtw_mlme_ext.c	/^void issue_assocreq(_adapter *padapter)$/;"	f
-issue_auth	core/rtw_mlme_ext.c	/^void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status)$/;"	f
-issue_beacon	core/rtw_mlme_ext.c	/^void issue_beacon(_adapter *padapter, int timeout_ms)$/;"	f
-issue_deauth	core/rtw_mlme_ext.c	/^int issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason)$/;"	f
-issue_deauth_11w	core/rtw_mlme_ext.c	/^int issue_deauth_11w(_adapter *padapter, unsigned char *da, unsigned short reason, u8 key_type)$/;"	f
-issue_deauth_ex	core/rtw_mlme_ext.c	/^int issue_deauth_ex(_adapter *padapter, u8 *da, unsigned short reason, int try_cnt,$/;"	f
-issue_del_ba	core/rtw_mlme_ext.c	/^inline void issue_del_ba(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator)$/;"	f
-issue_del_ba_ex	core/rtw_mlme_ext.c	/^int issue_del_ba_ex(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator$/;"	f
-issue_group_disc_req	core/rtw_p2p.c	/^static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)$/;"	f	file:
-issue_ht_ndpa_packet	core/rtw_beamforming.c	/^BOOLEAN	issue_ht_ndpa_packet(PADAPTER Adapter, u8 *ra, CHANNEL_WIDTH bw, u8 qidx)$/;"	f
-issue_ht_sw_ndpa_packet	core/rtw_beamforming.c	/^BOOLEAN	issue_ht_sw_ndpa_packet(PADAPTER Adapter, u8 *ra, CHANNEL_WIDTH bw, u8 qidx)$/;"	f
-issue_nulldata	core/rtw_mlme_ext.c	/^int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)$/;"	f
-issue_nulldata_in_interrupt	core/rtw_mlme_ext.c	/^s32 issue_nulldata_in_interrupt(PADAPTER padapter, u8 *da, unsigned int power_mode)$/;"	f
-issue_nulldata_to_TDLS_peer_STA	core/rtw_tdls.c	/^int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)$/;"	f
-issue_p2p_GO_confirm	core/rtw_mlme_ext.c	/^void issue_p2p_GO_confirm(_adapter *padapter, u8 *raddr, u8 result)$/;"	f
-issue_p2p_GO_request	core/rtw_mlme_ext.c	/^void issue_p2p_GO_request(_adapter *padapter, u8 *raddr)$/;"	f
-issue_p2p_GO_response	core/rtw_mlme_ext.c	/^void issue_p2p_GO_response(_adapter *padapter, u8 *raddr, u8 *frame_body, uint len, u8 result)$/;"	f
-issue_p2p_devdisc_resp	core/rtw_p2p.c	/^static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 status, u8 dialogToken)$/;"	f	file:
-issue_p2p_invitation_request	core/rtw_mlme_ext.c	/^void issue_p2p_invitation_request(_adapter *padapter, u8 *raddr)$/;"	f
-issue_p2p_invitation_response	core/rtw_mlme_ext.c	/^void issue_p2p_invitation_response(_adapter *padapter, u8 *raddr, u8 dialogToken, u8 status_code)$/;"	f
-issue_p2p_presence_resp	core/rtw_p2p.c	/^static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 status, u8 dialogToken)$/;"	f	file:
-issue_p2p_provision_request	core/rtw_mlme_ext.c	/^void issue_p2p_provision_request(_adapter *padapter, u8 *pssid, u8 ussidlen, u8 *pdev_raddr)$/;"	f
-issue_p2p_provision_resp	core/rtw_p2p.c	/^static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr, u8 *frame_body, u16 config_method)$/;"	f	file:
-issue_probereq	core/rtw_mlme_ext.c	/^inline void issue_probereq(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da)$/;"	f
-issue_probereq_ex	core/rtw_mlme_ext.c	/^int issue_probereq_ex(_adapter *padapter, NDIS_802_11_SSID *pssid, u8 *da, u8 ch, bool append_wps,$/;"	f
-issue_probereq_p2p	core/rtw_mlme_ext.c	/^inline void issue_probereq_p2p(_adapter *adapter, u8 *da)$/;"	f
-issue_probereq_p2p_ex	core/rtw_mlme_ext.c	/^int issue_probereq_p2p_ex(_adapter *adapter, u8 *da, int try_cnt, int wait_ms)$/;"	f
-issue_probersp	core/rtw_mlme_ext.c	/^void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probereq)$/;"	f
-issue_probersp_p2p	core/rtw_mlme_ext.c	/^void issue_probersp_p2p(_adapter *padapter, unsigned char *da)$/;"	f
-issue_qos_nulldata	core/rtw_mlme_ext.c	/^int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, int try_cnt, int wait_ms)$/;"	f
-issue_reassocreq	core/rtw_mlme_ext.c	/^void issue_reassocreq(_adapter *padapter)$/;"	f
-issue_tdls_ch_switch_req	core/rtw_tdls.c	/^int issue_tdls_ch_switch_req(_adapter *padapter, struct sta_info *ptdls_sta)$/;"	f
-issue_tdls_ch_switch_rsp	core/rtw_tdls.c	/^int issue_tdls_ch_switch_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)$/;"	f
-issue_tdls_dis_req	core/rtw_tdls.c	/^int issue_tdls_dis_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)$/;"	f
-issue_tdls_dis_rsp	core/rtw_tdls.c	/^int issue_tdls_dis_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 privacy)$/;"	f
-issue_tdls_peer_traffic_indication	core/rtw_tdls.c	/^int issue_tdls_peer_traffic_indication(_adapter *padapter, struct sta_info *ptdls_sta)$/;"	f
-issue_tdls_peer_traffic_rsp	core/rtw_tdls.c	/^int issue_tdls_peer_traffic_rsp(_adapter *padapter, struct sta_info *ptdls_sta, struct tdls_txmgmt *ptxmgmt)$/;"	f
-issue_tdls_setup_cfm	core/rtw_tdls.c	/^int issue_tdls_setup_cfm(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)$/;"	f
-issue_tdls_setup_req	core/rtw_tdls.c	/^int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)$/;"	f
-issue_tdls_setup_rsp	core/rtw_tdls.c	/^int issue_tdls_setup_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)$/;"	f
-issue_tdls_teardown	core/rtw_tdls.c	/^int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)$/;"	f
-issue_tunneled_probe_req	core/rtw_tdls.c	/^int issue_tunneled_probe_req(_adapter *padapter)$/;"	f
-issue_tunneled_probe_rsp	core/rtw_tdls.c	/^int issue_tunneled_probe_rsp(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-issue_vht_ndpa_packet	core/rtw_beamforming.c	/^BOOLEAN	issue_vht_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, CHANNEL_WIDTH bw, u8 qidx)$/;"	f
-issue_vht_sw_ndpa_packet	core/rtw_beamforming.c	/^BOOLEAN	issue_vht_sw_ndpa_packet(PADAPTER Adapter, u8 *ra, u16 aid, CHANNEL_WIDTH bw, u8 qidx)$/;"	f
-item	platform/platform_ARM_SUNxI_usb.c	/^static script_item_u item;$/;"	v	file:
-iv	include/rtw_mlme_ext.h	/^	u32	iv;$/;"	m	struct:mlme_ext_info
-iv	include/rtw_pwrctrl.h	/^	u8 iv[8];$/;"	m	struct:aoac_report
-iv	include/rtw_xmit.h	/^	u8	iv[18];$/;"	m	struct:pkt_attrib
-iv_len	include/rtw_recv.h	/^	u8	iv_len;$/;"	m	struct:rx_pkt_attrib
-iv_len	include/rtw_xmit.h	/^	u8	iv_len;$/;"	m	struct:pkt_attrib
-iw_operation_mode	os_dep/linux/ioctl_linux.c	/^static const char *const iw_operation_mode[] = {$/;"	v	file:
-iw_point	include/linux/wireless.h	/^struct	iw_point {$/;"	s
-iw_priv_type_size	os_dep/linux/ioctl_linux.c	/^static const char iw_priv_type_size[] = {$/;"	v	file:
-iwe_stream_add_event	os_dep/linux/ioctl_linux.c	28;"	d	file:
-iwe_stream_add_point	os_dep/linux/ioctl_linux.c	29;"	d	file:
-iwe_stream_chan_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_chan_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_encryption_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_encryption_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_essid_proess	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_essid_proess(_adapter *padapter,$/;"	f	file:
-iwe_stream_mac_addr_proess	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_mac_addr_proess(_adapter *padapter,$/;"	f	file:
-iwe_stream_mode_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_mode_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_net_rsv_process	os_dep/linux/ioctl_linux.c	/^static inline char   *iwe_stream_net_rsv_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_protocol_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_protocol_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_rate_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_rate_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_rssi_process	os_dep/linux/ioctl_linux.c	/^static inline char   *iwe_stream_rssi_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_wapi_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_wapi_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_wpa_wpa2_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_wpa_wpa2_process(_adapter *padapter,$/;"	f	file:
-iwe_stream_wps_process	os_dep/linux/ioctl_linux.c	/^static inline char *iwe_stream_wps_process(_adapter *padapter,$/;"	f	file:
-iwreq	include/linux/wireless.h	/^struct	iwreq {$/;"	s
-iwreq_data	include/linux/wireless.h	/^union	iwreq_data {$/;"	u
-iwstats	include/drv_types.h	/^	struct iw_statistics iwstats;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::iw_statistics
-join_cmd_hdl	core/rtw_mlme_ext.c	/^u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-join_res	include/wlan_bssdef.h	/^	int	join_res;$/;"	m	struct:wlan_network
-joinbss_event	include/rtw_event.h	/^struct joinbss_event {$/;"	s
-joinbss_parm	include/rtw_cmd.h	/^struct joinbss_parm {$/;"	s
-judge_network_type	core/rtw_wlan_util.c	/^u8 judge_network_type(_adapter *padapter, unsigned char *rate, int ratelen)$/;"	f
-kck	include/sta_info.h	/^	u8 kck[16]; \/* TPK-KCK *\/$/;"	m	struct:TDLS_PeerKey
-kck	include/sta_info.h	/^	u8 kck[RTW_KCK_LEN];$/;"	m	struct:sta_info
-keep_alive_trycnt	include/sta_info.h	/^	u8 keep_alive_trycnt;$/;"	m	struct:sta_info
-kek	include/sta_info.h	/^	u8 kek[RTW_KEK_LEN];$/;"	m	struct:sta_info
-key	include/drv_types.h	/^	u8 key[16];$/;"	m	struct:sec_cam_ent
-key	include/ieee80211.h	/^			u8 key[0];$/;"	m	struct:ieee_param::__anon73::__anon77
-key	include/rtw_cmd.h	/^	u8	key[16];	\/* this could be 40 or 104 *\/$/;"	m	struct:setkey_parm
-key	include/rtw_cmd.h	/^	u8	key[16];$/;"	m	struct:set_stakey_parm
-keyId	include/rtw_wapi.h	/^	u8			keyId;$/;"	m	struct:_RT_WAPI_KEY
-key_2char2num	core/rtw_ieee80211.c	/^u8 key_2char2num(u8 hch, u8 lch)$/;"	f
-key_char2num	core/rtw_ieee80211.c	/^static u8 key_char2num(u8 ch)$/;"	f	file:
-key_idx	include/rtw_xmit.h	/^	u8	key_idx;$/;"	m	struct:pkt_attrib
-key_index	include/rtw_mlme_ext.h	/^	u32	key_index;	\/* this is only valid for legendary wep, 0~3 for key id. *\/$/;"	m	struct:mlme_ext_info
-key_index	include/rtw_pwrctrl.h	/^	u8 key_index;$/;"	m	struct:aoac_report
-key_index	include/rtw_recv.h	/^	u8	key_index;$/;"	m	struct:rx_pkt_attrib
-key_len	include/ieee80211.h	/^			u16 key_len;$/;"	m	struct:ieee_param::__anon73::__anon77
-key_mask	include/rtw_security.h	/^	u8 	key_mask; \/* use to restore wep key after hal_init *\/$/;"	m	struct:security_priv
-key_sizes	include/ieee80211.h	/^	u8 key_sizes[WEP_KEYS];$/;"	m	struct:ieee80211_security
-key_type	include/rtw_xmit.h	/^	u8 key_type;$/;"	m	struct:pkt_attrib
-keyid	include/rtw_cmd.h	/^	u8	keyid;$/;"	m	struct:set_stakey_parm
-keyid	include/rtw_cmd.h	/^	u8	keyid;$/;"	m	struct:set_stakey_rsp
-keyid	include/rtw_cmd.h	/^	u8	keyid;$/;"	m	struct:setkey_parm
-keyidx	include/rtw_wapi.h	/^	u8			keyidx;	\/* 0 or 1,new or old key *\/$/;"	m	struct:_RT_WAPI_CAM_ENTRY
-keys	include/ieee80211.h	/^	u8 keys[WEP_KEYS][WEP_KEY_LEN];$/;"	m	struct:ieee80211_security
-kfree_data	include/hal_data.h	/^	struct kfree_data_t kfree_data;$/;"	m	struct:hal_com_data	typeref:struct:hal_com_data::kfree_data_t
-kfree_data_is_bb_gain_empty	hal/hal_com.c	/^bool kfree_data_is_bb_gain_empty(struct kfree_data_t *data)$/;"	f
-kfree_data_t	include/hal_data.h	/^struct kfree_data_t {$/;"	s
-kmemcheck_bitfield_begin	include/osdep_service_bsd.h	187;"	d
-kmemcheck_bitfield_end	include/osdep_service_bsd.h	188;"	d
-ktime	include/osdep_service_bsd.h	/^union ktime {$/;"	u
-ktime_t	include/osdep_service_bsd.h	/^typedef union ktime ktime_t;		\/* Kill this *\/$/;"	t	typeref:union:ktime
-l2sdTaBuffer	include/rtw_mlme.h	/^	u8	*l2sdTaBuffer;$/;"	m	struct:mlme_priv
-l_rxsc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		l_rxsc: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-l_rxsc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		l_rxsc: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-largeCFOHit	hal/phydm/phydm_cfotracking.h	/^	BOOLEAN			largeCFOHit;$/;"	m	struct:_CFO_TRACKING_
-largest_bit	include/osdep_service.h	/^static inline int largest_bit(u32 bitmask)$/;"	f
-last	include/rtw_mp.h	/^	sint last[8];$/;"	m	struct:mp_xmit_frame
-last	include/rtw_xmit.h	/^	sint last[8];$/;"	m	struct:xmit_buf
-lastRxMulticastPN	include/rtw_wapi.h	/^	u8					lastRxMulticastPN[16];$/;"	m	struct:_RT_WAPI_STA_INFO
-lastRxOkCnt	hal/phydm/phydm.h	/^	u8Byte			lastRxOkCnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-lastRxUnicastPN	include/rtw_wapi.h	/^	u8					lastRxUnicastPN[16];$/;"	m	struct:_RT_WAPI_STA_INFO
-lastRxUnicastPNBEQueue	include/rtw_wapi.h	/^	u8					lastRxUnicastPNBEQueue[16];$/;"	m	struct:_RT_WAPI_STA_INFO
-lastRxUnicastPNBKQueue	include/rtw_wapi.h	/^	u8					lastRxUnicastPNBKQueue[16];$/;"	m	struct:_RT_WAPI_STA_INFO
-lastRxUnicastPNVIQueue	include/rtw_wapi.h	/^	u8					lastRxUnicastPNVIQueue[16];$/;"	m	struct:_RT_WAPI_STA_INFO
-lastRxUnicastPNVOQueue	include/rtw_wapi.h	/^	u8					lastRxUnicastPNVOQueue[16];$/;"	m	struct:_RT_WAPI_STA_INFO
-lastTxMulticastPN	include/rtw_wapi.h	/^	u8				lastTxMulticastPN[16];$/;"	m	struct:_RT_WAPI_T
-lastTxOkCnt	hal/phydm/phydm.h	/^	u8Byte			lastTxOkCnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-lastTxUnicastPN	include/rtw_wapi.h	/^	u8					lastTxUnicastPN[16];$/;"	m	struct:_RT_WAPI_STA_INFO
-last_frag	include/ieee80211.h	/^	uint last_frag;$/;"	m	struct:ieee80211_frag_entry
-last_mic_err_time	include/rtw_security.h	/^	u32 last_mic_err_time;$/;"	m	struct:security_priv
-last_ro_ch_time	include/rtw_mlme.h	/^	u32 last_ro_ch_time; \/* this will be updated at the beginning and end of ro_ch *\/$/;"	m	struct:cfg80211_wifidirect_info
-last_rx_beacon_pkts	include/sta_info.h	/^		u64 last_rx_beacon_pkts;$/;"	m	struct:stainfo_stats
-last_rx_bytes	include/drv_types.h	/^	u64	last_rx_bytes;$/;"	m	struct:rtw_traffic_statistics
-last_rx_ctrl_pkts	include/sta_info.h	/^	u64	last_rx_ctrl_pkts;$/;"	m	struct:stainfo_stats
-last_rx_data_pkts	include/sta_info.h	/^	u64	last_rx_data_pkts;$/;"	m	struct:stainfo_stats
-last_rx_data_qos_pkts	include/sta_info.h	/^	u64 last_rx_data_qos_pkts[TID_NUM];$/;"	m	struct:stainfo_stats
-last_rx_mgnt_pkts	include/sta_info.h	/^	u64	last_rx_mgnt_pkts;$/;"	m	struct:stainfo_stats
-last_rx_pkts	include/rtw_mlme.h	/^	uint	last_rx_pkts;$/;"	m	struct:sitesurvey_ctrl
-last_rx_probereq_pkts	include/sta_info.h	/^		u64 last_rx_probereq_pkts;$/;"	m	struct:stainfo_stats
-last_rx_probersp_bm_pkts	include/sta_info.h	/^		u64 last_rx_probersp_bm_pkts;$/;"	m	struct:stainfo_stats
-last_rx_probersp_pkts	include/sta_info.h	/^		u64 last_rx_probersp_pkts;$/;"	m	struct:stainfo_stats
-last_rx_probersp_uo_pkts	include/sta_info.h	/^		u64 last_rx_probersp_uo_pkts;$/;"	m	struct:stainfo_stats
-last_rx_tdls_disc_rsp_pkts	include/sta_info.h	/^	u64 last_rx_tdls_disc_rsp_pkts;$/;"	m	struct:stainfo_stats
-last_scan_time	include/rtw_mlme_ext.h	/^	u32 last_scan_time;$/;"	m	struct:mlme_ext_priv
-last_scanned	include/wlan_bssdef.h	/^	unsigned long	last_scanned; \/* timestamp for the network *\/$/;"	m	struct:wlan_network
-last_tx_bytes	include/drv_types.h	/^	u64	last_tx_bytes;$/;"	m	struct:rtw_traffic_statistics
-last_tx_complete_time	include/rtw_sreset.h	/^	unsigned long last_tx_complete_time;$/;"	m	struct:sreset_priv
-last_tx_pkts	include/rtw_mlme.h	/^	u64	last_tx_pkts;$/;"	m	struct:sitesurvey_ctrl
-last_tx_pkts	include/rtw_xmit.h	/^	u64	last_tx_pkts;$/;"	m	struct:xmit_priv
-last_tx_time	include/rtw_sreset.h	/^	unsigned long last_tx_time;$/;"	m	struct:sreset_priv
-last_txcmdsz	include/rtw_xmit.h	/^	u32	last_txcmdsz;$/;"	m	struct:pkt_attrib
-lastscantime	include/rtw_mlme.h	/^	u32 lastscantime;$/;"	m	struct:mlme_priv
-latch_time	hal/phydm/phydm_antdiv.h	/^	u4Byte	latch_time;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-lb	os_dep/osdep_service.c	/^	size_t lb;$/;"	m	struct:mstat_sniff_rule	file:
-lbk_thread	os_dep/linux/ioctl_linux.c	/^thread_return lbk_thread(thread_context context)$/;"	f
-lbkevt_done	include/rtw_cmd.h	/^	_sema	lbkevt_done;$/;"	m	struct:evt_priv
-lbkevt_limit	include/rtw_cmd.h	/^	u8	lbkevt_limit;$/;"	m	struct:evt_priv
-lbkevt_num	include/rtw_cmd.h	/^	u8	lbkevt_num;$/;"	m	struct:evt_priv
-lbkmode	include/drv_types.h	/^	u8	lbkmode;$/;"	m	struct:registry_priv
-lbkthread	include/drv_types.h	/^	_thread_hdl_ lbkthread;$/;"	m	struct:loopbackdata
-ld_adhoc_num	include/rtw_mi.h	/^	u8 ld_adhoc_num;	\/* WIFI_FW_ADHOC_STATE && asoc_sta_count > 2 *\/$/;"	m	struct:mi_state
-ld_ap_num	include/rtw_mi.h	/^	u8 ld_ap_num;		\/*WIFI_FW_AP_STATE|_FW_LINKED && asoc_sta_count > 2*\/$/;"	m	struct:mi_state
-ld_sta_num	include/rtw_mi.h	/^	u8 ld_sta_num;		\/*WIFI_FW_STATION_STATE |_FW_LINKED*\/$/;"	m	struct:mi_state
-ldpc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		ldpc: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-ldpc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		ldpc: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-ldpc	include/rtw_recv.h	/^	u8	ldpc;$/;"	m	struct:rx_pkt_attrib
-ldpc	include/rtw_xmit.h	/^	u8	ldpc;$/;"	m	struct:pkt_attrib
-ldpc	include/sta_info.h	/^	u8	ldpc;$/;"	m	struct:sta_info
-ldpc_cap	include/drv_types.h	/^	u8	ldpc_cap;$/;"	m	struct:registry_priv
-ldpc_cap	include/rtw_ht.h	/^	u8	ldpc_cap;$/;"	m	struct:ht_priv
-ldpc_cap	include/rtw_vht.h	/^	u8	ldpc_cap;$/;"	m	struct:vht_priv
-le16_to_cpu	include/byteorder/generic.h	111;"	d
-le16_to_cpup	include/byteorder/generic.h	123;"	d
-le16_to_cpus	include/byteorder/generic.h	135;"	d
-le32_to_cpu	include/byteorder/generic.h	109;"	d
-le32_to_cpup	include/byteorder/generic.h	121;"	d
-le32_to_cpus	include/byteorder/generic.h	133;"	d
-le64_to_cpu	include/byteorder/generic.h	107;"	d
-le64_to_cpup	include/byteorder/generic.h	119;"	d
-le64_to_cpus	include/byteorder/generic.h	131;"	d
-leave_ack	include/rtw_btcoex.h	89;"	d
-led_blink_hdl	core/rtw_mlme_ext.c	/^u8 led_blink_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-led_priv	include/hal_com_led.h	/^struct led_priv {$/;"	s
-ledpriv	include/drv_types.h	/^	struct	led_priv	ledpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::led_priv
-legacy_channel_plan	core/rtw_mlme_ext.c	/^static RT_CHANNEL_PLAN legacy_channel_plan[] = {$/;"	v	file:
-legacy_dz	include/rtw_xmit.h	/^	_list	legacy_dz;$/;"	m	struct:sta_xmit_priv
-len	core/rtw_cmd.c	/^	u8 len;$/;"	m	struct:btinfo	file:
-len	hal/hal_btcoex.c	/^	u32 len; \/* now used length *\/$/;"	m	struct:_btcoexdbginfo	file:
-len	include/gspi_ops.h	/^	unsigned long len;$/;"	m	struct:spi_more_data
-len	include/ieee80211.h	/^			u32 len;$/;"	m	struct:ieee_param::__anon73::__anon75
-len	include/ieee80211.h	/^	u16 len;$/;"	m	struct:ieee80211_rx_stats
-len	include/ieee80211.h	/^	u8 len;$/;"	m	struct:ieee80211_info_element
-len	include/ieee80211.h	/^	u8 len;$/;"	m	struct:ieee80211_info_element_hdr
-len	include/ieee80211_ext.h	/^	u8 len;$/;"	m	struct:rsn_ie_hdr
-len	include/ieee80211_ext.h	/^	u8 len;$/;"	m	struct:wpa_ie_hdr
-len	include/osdep_service.h	/^	u16 len;$/;"	m	struct:map_seg_t
-len	include/osdep_service.h	/^	u16 len;$/;"	m	struct:map_t
-len	include/osdep_service_bsd.h	/^	unsigned int		len,$/;"	m	struct:sk_buff
-len	include/rtw_btcoex.h	/^	u8 len;$/;"	m	struct:btinfo_8761ATV
-len	include/rtw_cmd.h	/^	u8 len;$/;"	m	struct:readMAC_parm
-len	include/rtw_mlme.h	/^	size_t len;$/;"	m	struct:tdls_txmgmt
-len	include/rtw_mlme_ext.h	/^	unsigned int len:16;$/;"	m	struct:C2HEvent_Header
-len	include/rtw_mp_ioctl.h	/^	u32 len;$/;"	m	struct:_BURST_RW_REG
-len	include/rtw_mp_ioctl.h	/^	u32 len;$/;"	m	struct:mp_ioctl_param
-len	include/rtw_mp_ioctl.h	/^	u32 len;$/;"	m	struct:mp_xmit_packet
-len	include/rtw_pwrctrl.h	/^	int len;$/;"	m	struct:rtl_priv_pattern
-len	include/rtw_recv.h	/^	u32	len;$/;"	m	struct:recv_buf
-len	include/rtw_recv.h	/^	uint  len;$/;"	m	struct:recv_frame_hdr
-len	include/rtw_xmit.h	/^	u32  len;$/;"	m	struct:xmit_buf
-len_ch	include/rtw_mlme_ext.h	/^	u8 *len_ch;$/;"	m	struct:ch_list_t
-length	hal/btc/HalBtcOutSrc.h	/^	u1Byte	length;$/;"	m	struct:_COL_C2H_IND
-length	hal/phydm/phydm_hwconfig.h	/^	u2Byte		length;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-length	include/ieee80211.h	/^	u16 length;$/;"	m	struct:eapol
-length	include/linux/wireless.h	/^	__u16		length;		\/* number of fields or size in bytes *\/$/;"	m	struct:iw_point
-length	include/linux/wireless.h	/^	__u16 length;$/;"	m	struct:compat_iw_point
-length	include/rtw_iol.h	/^	u8	length;$/;"	m	struct:ioreg_cfg
-length	include/rtw_mp_ioctl.h	/^	u16 length;$/;"	m	struct:_mp_xmit_parm_
-length	include/rtw_security.h	/^	u64 length;$/;"	m	struct:sha256_state
-level	include/ieee80211.h	/^	u8 level;$/;"	m	struct:ieee80211_security
-lg_sta_num	include/rtw_mi.h	/^	u8 lg_sta_num;		\/*WIFI_FW_STATION_STATE |_FW_UNDER_LINKING*\/$/;"	m	struct:mi_state
-lifetime_over	include/rtl8188e_xmit.h	/^	u8 lifetime_over:1;$/;"	m	struct:txrpt_ccx_88e
-lifetime_over	include/rtl8192e_xmit.h	/^	u8 lifetime_over:1;$/;"	m	struct:txrpt_ccx_92e
-limit	include/hal_com_phycfg.h	/^	s8 limit;$/;"	m	struct:txpwr_idx_comp
-limited_dig	hal/btc/HalBtc8192e1Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8192e_1ant
-limited_dig	hal/btc/HalBtc8192e2Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8192e_2ant
-limited_dig	hal/btc/HalBtc8703b1Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8703b_1ant
-limited_dig	hal/btc/HalBtc8723b2Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8723b_2ant
-limited_dig	hal/btc/HalBtc8812a1Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8812a_1ant
-limited_dig	hal/btc/HalBtc8812a2Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8812a_2ant
-limited_dig	hal/btc/HalBtc8821a2Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8821a_2ant
-limited_dig	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8821a_csr_2ant
-limited_dig	hal/btc/HalBtc8822b1Ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8822b_1ant
-limited_dig	hal/btc/HalBtcOutSrc.h	/^	boolean					limited_dig;$/;"	m	struct:btc_bt_info
-limited_dig	hal/btc/halbtc8723d1ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8723d_1ant
-limited_dig	hal/btc/halbtc8723d2ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8723d_2ant
-limited_dig	hal/btc/halbtc8821c1ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8821c_1ant
-limited_dig	hal/btc/halbtc8821c2ant.h	/^	boolean		limited_dig;$/;"	m	struct:coex_dm_8821c_2ant
-linip	include/rtl8188e_xmit.h	/^	u32 linip:1;$/;"	m	struct:txdesc_88e
-linip	include/rtl8192e_xmit.h	/^	u32 linip:1;$/;"	m	struct:txdescriptor_8192e
-linip	include/rtl8812a_xmit.h	/^	u32 linip:1;$/;"	m	struct:txdescriptor_8812
-linip	include/rtl8821a_xmit.h	/^	u32 linip:1;$/;"	m	struct:txdescriptor_8821a
-linkRole	include/rtw_btcoex.h	/^	u1Byte					linkRole;$/;"	m	struct:_HCI_LINK_INFO
-link_count	include/rtw_mlme_ext.h	/^	u32	link_count;$/;"	m	struct:mlme_ext_info
-link_established	include/rtw_mlme.h	/^	u8					link_established;$/;"	m	struct:tdls_info
-link_timer	include/rtw_mlme_ext.h	/^	_timer		link_timer;$/;"	m	struct:mlme_ext_priv
-link_timer_hdl	core/rtw_mlme_ext.c	/^void link_timer_hdl(_adapter *padapter)$/;"	f
-link_tx_rate	hal/phydm/phydm_rainfo.h	/^	u1Byte	link_tx_rate[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_Rate_Adaptive_Table_
-linkctrl_reg	include/drv_types_pci.h	/^	u8	linkctrl_reg;$/;"	m	struct:pci_priv
-linked_info_dump	hal/hal_com.c	/^void linked_info_dump(_adapter *padapter, u8 benable)$/;"	f
-linked_status_chk	core/rtw_mlme_ext.c	/^void linked_status_chk(_adapter *padapter, u8 from_timer)$/;"	f
-linked_status_chk_tdls	core/rtw_mlme_ext.c	/^void linked_status_chk_tdls(_adapter *padapter)$/;"	f
-list	include/drv_types.h	/^	_list	list;$/;"	m	struct:_ADAPTER
-list	include/ieee80211.h	/^	_list	list;$/;"	m	struct:ieee_ibss_seq
-list	include/rtw_cmd.h	/^	_list	list;$/;"	m	struct:cmd_obj
-list	include/rtw_cmd.h	/^	_list	list;$/;"	m	struct:evt_obj
-list	include/rtw_io.h	/^	_list	list;$/;"	m	struct:io_req
-list	include/rtw_mp.h	/^	_list	list;$/;"	m	struct:mp_xmit_frame
-list	include/rtw_recv.h	/^		_list list;$/;"	m	union:recv_frame::__anon62
-list	include/rtw_recv.h	/^	_list	list;$/;"	m	struct:recv_frame_hdr
-list	include/rtw_recv.h	/^	_list list;$/;"	m	struct:recv_buf
-list	include/rtw_wapi.h	/^	struct list_head		list;$/;"	m	struct:_RT_WAPI_STA_INFO	typeref:struct:_RT_WAPI_STA_INFO::list_head
-list	include/rtw_wapi.h	/^	struct list_head	list;$/;"	m	struct:_RT_WAPI_BKID	typeref:struct:_RT_WAPI_BKID::list_head
-list	include/rtw_xmit.h	/^	_list	list;$/;"	m	struct:xmit_buf
-list	include/rtw_xmit.h	/^	_list	list;$/;"	m	struct:xmit_frame
-list	include/sta_info.h	/^	_list		        list;$/;"	m	struct:rtw_wlan_acl_node
-list	include/sta_info.h	/^	_list	list; \/* free_sta_queue *\/$/;"	m	struct:sta_info
-list	include/sta_info.h	/^	_list list; \/* session_tracker_queue *\/$/;"	m	struct:session_tracker
-list	include/wlan_bssdef.h	/^	_list	list;$/;"	m	struct:wlan_network
-list_head	include/osdep_service_bsd.h	/^	struct list_head {$/;"	s
-listen_channel	include/rtw_mlme.h	/^	u8						listen_channel;$/;"	m	struct:wifidirect_info
-listen_dwell	include/rtw_mlme.h	/^	u8						listen_dwell;		\/*	This value should be between 1 and 3 *\/$/;"	m	struct:wifidirect_info
-listen_interval	include/ieee80211.h	/^	u16 listen_interval;$/;"	m	struct:ieee80211_assoc_request_frame
-listen_interval	include/ieee80211_ext.h	/^			u16 listen_interval;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon29
-listen_interval	include/ieee80211_ext.h	/^			u16 listen_interval;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon31
-listen_interval	include/ieee80211_ext.h	/^			u16 listen_interval;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon11
-listen_interval	include/ieee80211_ext.h	/^			u16 listen_interval;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon13
-listen_state	include/rtw_mlme.h	/^	int	listen_state;$/;"	m	struct:mlme_priv
-listen_timer	include/rtw_mlme.h	/^	_timer	listen_timer;$/;"	m	struct:mlme_priv
-lkey	include/rtw_security.h	/^	u32    lkey[4];$/;"	m	union:Keytype
-lna_h	hal/phydm/phydm_hwconfig.h	/^	u1Byte		lna_h:1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-lna_idx	hal/phydm/phydm_iqk.h	/^	u4Byte		lna_idx;$/;"	m	struct:_IQK_INFORMATION
-lna_l	hal/phydm/phydm_hwconfig.h	/^	u1Byte		lna_l:3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-load_phy_file	include/drv_types.h	/^	u8	load_phy_file;$/;"	m	struct:registry_priv
-loadparam	os_dep/linux/os_intfs.c	/^uint loadparam(_adapter *padapter)$/;"	f
-loc_probe_req	include/rtw_pwrctrl.h	/^	u8	loc_probe_req[MAX_HIDDEN_AP];		\/* loc_probeReq *\/$/;"	m	struct:pno_nlo_info
-local_df	include/osdep_service_bsd.h	/^	u8			local_df:1,$/;"	m	struct:sk_buff
-local_naddr	include/sta_info.h	/^	u32 local_naddr; \/* TODO: IPV6 *\/$/;"	m	struct:st_cmd_parm
-local_naddr	include/sta_info.h	/^	u32 local_naddr;$/;"	m	struct:session_tracker
-local_port	include/sta_info.h	/^	u16 local_port;$/;"	m	struct:session_tracker
-local_port	include/sta_info.h	/^	u16 local_port;$/;"	m	struct:st_cmd_parm
-locally_generated	include/rtw_event.h	/^	unsigned char locally_generated;$/;"	m	struct:stadel_event
-lock	include/drv_types.h	/^	_lock lock;$/;"	m	struct:cam_ctl_t
-lock	include/drv_types.h	/^	_lock lock;$/;"	m	struct:macid_ctl_t
-lock	include/drv_types.h	/^	_lock lock;$/;"	m	struct:mbid_cam_ctl_t
-lock	include/osdep_service_bsd.h	/^		_lock	lock;$/;"	m	struct:__queue
-lock	include/osdep_service_bsd.h	/^	_lock	lock;$/;"	m	struct:sk_buff_head
-lock	include/osdep_service_ce.h	/^	_lock	lock;$/;"	m	struct:__queue
-lock	include/osdep_service_linux.h	/^	_lock	lock;$/;"	m	struct:__queue
-lock	include/osdep_service_xp.h	/^		_lock	lock;$/;"	m	struct:__queue
-lock	include/rtw_io.h	/^	_lock	lock;$/;"	m	struct:io_queue
-lock	include/rtw_mlme.h	/^	_lock	lock;$/;"	m	struct:mlme_priv
-lock	include/rtw_pwrctrl.h	/^	_pwrlock	lock;$/;"	m	struct:pwrctrl_priv
-lock	include/rtw_recv.h	/^	_lock	lock;$/;"	m	struct:recv_priv
-lock	include/rtw_recv.h	/^	_lock	lock;$/;"	m	struct:sta_recv_priv
-lock	include/rtw_xmit.h	/^	_lock	lock;$/;"	m	struct:sta_xmit_priv
-lock	include/rtw_xmit.h	/^	_lock	lock;$/;"	m	struct:xmit_priv
-lock	include/sta_info.h	/^	_lock	lock;$/;"	m	struct:sta_info
-lock_sctx	include/rtw_xmit.h	/^	_lock lock_sctx;$/;"	m	struct:xmit_priv
-long_retry_lmt	include/drv_types.h	/^	u8	long_retry_lmt;$/;"	m	struct:registry_priv
-loopbackTest	os_dep/linux/ioctl_linux.c	/^static void loopbackTest(PADAPTER padapter, u32 cnt, u32 size, u8 *pmsg)$/;"	f	file:
-loopbackdata	include/drv_types.h	/^typedef struct loopbackdata {$/;"	s
-lowPriorityRx	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte					lowPriorityRx;$/;"	m	struct:_COEX_STA_8723A_1ANT
-lowPriorityRx	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte					lowPriorityRx;$/;"	m	struct:_COEX_STA_8723A_2ANT
-lowPriorityTx	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte					lowPriorityTx;$/;"	m	struct:_COEX_STA_8723A_1ANT
-lowPriorityTx	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte					lowPriorityTx;$/;"	m	struct:_COEX_STA_8723A_2ANT
-low_power	include/drv_types.h	/^	u8	low_power ;$/;"	m	struct:registry_priv
-low_priority_rx	hal/btc/HalBtc8192e1Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8192e_1ant
-low_priority_rx	hal/btc/HalBtc8192e2Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8192e_2ant
-low_priority_rx	hal/btc/HalBtc8703b1Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8703b_1ant
-low_priority_rx	hal/btc/HalBtc8723b1Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8723b_1ant
-low_priority_rx	hal/btc/HalBtc8723b2Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8723b_2ant
-low_priority_rx	hal/btc/HalBtc8812a1Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8812a_1ant
-low_priority_rx	hal/btc/HalBtc8812a2Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8812a_2ant
-low_priority_rx	hal/btc/HalBtc8821a1Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8821a_1ant
-low_priority_rx	hal/btc/HalBtc8821a2Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8821a_2ant
-low_priority_rx	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8821a_csr_2ant
-low_priority_rx	hal/btc/HalBtc8822b1Ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8822b_1ant
-low_priority_rx	hal/btc/halbtc8723d1ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8723d_1ant
-low_priority_rx	hal/btc/halbtc8723d2ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8723d_2ant
-low_priority_rx	hal/btc/halbtc8821c1ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8821c_1ant
-low_priority_rx	hal/btc/halbtc8821c2ant.h	/^	u32					low_priority_rx;$/;"	m	struct:coex_sta_8821c_2ant
-low_priority_tx	hal/btc/HalBtc8192e1Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8192e_1ant
-low_priority_tx	hal/btc/HalBtc8192e2Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8192e_2ant
-low_priority_tx	hal/btc/HalBtc8703b1Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8703b_1ant
-low_priority_tx	hal/btc/HalBtc8723b1Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8723b_1ant
-low_priority_tx	hal/btc/HalBtc8723b2Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8723b_2ant
-low_priority_tx	hal/btc/HalBtc8812a1Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8812a_1ant
-low_priority_tx	hal/btc/HalBtc8812a2Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8812a_2ant
-low_priority_tx	hal/btc/HalBtc8821a1Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8821a_1ant
-low_priority_tx	hal/btc/HalBtc8821a2Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8821a_2ant
-low_priority_tx	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8821a_csr_2ant
-low_priority_tx	hal/btc/HalBtc8822b1Ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8822b_1ant
-low_priority_tx	hal/btc/halbtc8723d1ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8723d_1ant
-low_priority_tx	hal/btc/halbtc8723d2ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8723d_2ant
-low_priority_tx	hal/btc/halbtc8821c1ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8821c_1ant
-low_priority_tx	hal/btc/halbtc8821c2ant.h	/^	u32					low_priority_tx;$/;"	m	struct:coex_sta_8821c_2ant
-lowrate_two_xmit	include/drv_types.h	/^	u8	lowrate_two_xmit;$/;"	m	struct:registry_priv
-lps_ctrl_wk_hdl	core/rtw_cmd.c	/^void lps_ctrl_wk_hdl(_adapter *padapter, u8 lps_ctrl_type)$/;"	f
-lps_enter_cnts	include/rtw_pwrctrl.h	/^	uint	lps_enter_cnts;$/;"	m	struct:pwrctrl_priv
-lps_leave_cnts	include/rtw_pwrctrl.h	/^	uint	lps_leave_cnts;$/;"	m	struct:pwrctrl_priv
-lps_poff_info	include/rtw_pwrctrl.h	/^typedef struct lps_poff_info {$/;"	s
-lps_poff_info_t	include/rtw_pwrctrl.h	/^} lps_poff_info_t;$/;"	t	typeref:struct:lps_poff_info
-lps_val	hal/btc/HalBtcOutSrc.h	/^	u8					lps_val;$/;"	m	struct:btc_bt_info
-lpspg_rsvd_page_locate	include/rtw_pwrctrl.h	/^	u8 lpspg_rsvd_page_locate;$/;"	m	struct:pwrctrl_priv
-ls	include/rtl8188e_recv.h	/^	u32 ls:1;$/;"	m	struct:rxreport_8188e
-ls	include/rtl8188e_xmit.h	/^	u32 ls:1;$/;"	m	struct:txdesc_88e
-ls	include/rtl8192e_xmit.h	/^	u32 ls:1;$/;"	m	struct:txdescriptor_8192e
-ls	include/rtl8812a_xmit.h	/^	u32 ls:1;$/;"	m	struct:txdescriptor_8812
-ls	include/rtl8814a_xmit.h	/^	u32 ls:1;$/;"	m	struct:txdescriptor_8814
-lsig_length	hal/phydm/phydm_hwconfig.h	/^	u2Byte		lsig_length;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-lsig_txop_en	include/rtl8188e_xmit.h	/^	u32 lsig_txop_en:1;$/;"	m	struct:txdesc_88e
-lsig_txop_en	include/rtl8192e_xmit.h	/^	u32 lsig_txop_en:1;$/;"	m	struct:txdescriptor_8192e
-lsig_txop_en	include/rtl8812a_xmit.h	/^	u32 lsig_txop_en:1;$/;"	m	struct:txdescriptor_8812
-lsig_txop_en	include/rtl8821a_xmit.h	/^	u32 lsig_txop_en:1;$/;"	m	struct:txdescriptor_8821a
-m0	include/drv_types.h	/^	u32 m0;$/;"	m	struct:macid_bmp
-m0	include/drv_types.h	/^	u32 m0;$/;"	m	struct:sec_cam_bmp
-m1	include/drv_types.h	/^	u32 m1;$/;"	m	struct:macid_bmp
-m1	include/drv_types.h	/^	u32 m1;$/;"	m	struct:sec_cam_bmp
-m2	include/drv_types.h	/^	u32 m2;$/;"	m	struct:macid_bmp
-m2	include/drv_types.h	/^	u32 m2;$/;"	m	struct:sec_cam_bmp
-m3	include/drv_types.h	/^	u32 m3;$/;"	m	struct:macid_bmp
-m3	include/drv_types.h	/^	u32 m3;$/;"	m	struct:sec_cam_bmp
-mW_Max	hal/phydm/rtchnlplan.h	/^	u2Byte	mW_Max;$/;"	m	struct:_RT_CHNL_PLAN_PWR_LIMIT
-m_STBC	include/rtw_mp.h	/^	u8			m_STBC;			\/* bSTBC + 1 *\/$/;"	m	struct:_RT_PMAC_TX_INFO
-mac	include/drv_types.h	/^	u8 mac[ETH_ALEN];$/;"	m	struct:sec_cam_ent
-mac	include/ieee80211.h	/^	u8 mac[ETH_ALEN];$/;"	m	struct:ieee_ibss_seq
-mac	include/rtw_cmd.h	/^	u8	mac[6];$/;"	m	struct:geth2clbk_rsp
-mac	include/rtw_cmd.h	/^	u8 mac[6];$/;"	m	struct:seth2clbk_parm
-mac	include/rtw_event.h	/^	unsigned char mac[6];$/;"	m	struct:c2hlbk_event
-macAddr	include/rtw_br_ext.h	/^	unsigned char					macAddr[6];$/;"	m	struct:nat25_network_db_entry
-mac_addr	include/drv_types.h	/^	u8 mac_addr[ETH_ALEN];$/;"	m	struct:_ADAPTER
-mac_addr	include/drv_types.h	/^	u8 mac_addr[ETH_ALEN];$/;"	m	struct:mbid_cam_cache
-mac_addr	include/rtw_beamforming.h	/^	u8	mac_addr[6];\/* Used to fill Reg6E4 to fill Mac address of CSI report frame. *\/$/;"	m	struct:beamforming_entry
-mac_addr	include/rtw_beamforming.h	/^	u8 mac_addr[ETH_ALEN];$/;"	m	struct:beamformee_entry
-mac_addr	include/rtw_beamforming.h	/^	u8 mac_addr[ETH_ALEN];$/;"	m	struct:beamformer_entry
-mac_filter	include/rtw_mp.h	/^	u8 mac_filter[ETH_ALEN];$/;"	m	struct:mp_priv
-mac_header	include/osdep_service_bsd.h	/^	sk_buff_data_t		mac_header;$/;"	m	struct:sk_buff
-mac_hidden_max_bw_to_hal_bw_cap	include/rtw_efuse.h	228;"	d
-mac_hidden_proto_to_hal_proto_cap	include/rtw_efuse.h	232;"	d
-mac_hidden_wl_func_to_hal_wl_func	core/efuse/rtw_efuse.c	/^u8 mac_hidden_wl_func_to_hal_wl_func(u8 func)$/;"	f
-mac_id	include/rtl8188e_xmit.h	/^	u8 mac_id:6;$/;"	m	struct:txrpt_ccx_88e
-mac_id	include/rtl8192e_xmit.h	/^	u8 mac_id:6;$/;"	m	struct:txrpt_ccx_92e
-mac_id	include/rtw_beamforming.h	/^	u16	mac_id;		\/* Used to Set Reg42C in IBSS mode. *\/$/;"	m	struct:beamforming_entry
-mac_id	include/rtw_beamforming.h	/^	u16 mac_id;$/;"	m	struct:beamformee_entry
-mac_id	include/rtw_event.h	/^	int mac_id;$/;"	m	struct:stadel_event
-mac_id	include/rtw_xmit.h	/^	u8	mac_id;$/;"	m	struct:pkt_attrib
-mac_id	include/sta_info.h	/^	uint mac_id;$/;"	m	struct:sta_info
-mac_len	include/osdep_service_bsd.h	/^	u16			mac_len,$/;"	m	struct:sk_buff
-mac_reg	include/hal_data.h	/^	char *mac_reg;$/;"	m	struct:hal_com_data
-mac_reg_dump	core/rtw_debug.c	/^void mac_reg_dump(void *sel, _adapter *adapter)$/;"	f
-mac_reg_len	include/hal_data.h	/^	u32	mac_reg_len;$/;"	m	struct:hal_com_data
-macaddr	include/rtw_event.h	/^	unsigned char macaddr[6];$/;"	m	struct:stadel_event
-macaddr	include/rtw_event.h	/^	unsigned char macaddr[6];$/;"	m	struct:stassoc_event
-macaddr	include/rtw_mlme.h	/^	u8		macaddr[ETH_ALEN];$/;"	m	struct:tdls_ss_record
-macaddr_file_status	include/hal_data.h	/^	u8	macaddr_file_status;$/;"	m	struct:hal_com_data
-macclone_enable	include/rtw_br_ext.h	/^	unsigned int	macclone_enable;$/;"	m	struct:br_ext_info
-macid	hal/rtl8723d/rtl8723d_hal_init.c	/^	u32 macid:7;$/;"	m	struct:qinfo_8723d	file:
-macid	include/rtl8188e_recv.h	/^	u32 macid:5;$/;"	m	struct:rxreport_8188e
-macid	include/rtl8188e_xmit.h	/^	u32 macid:6;$/;"	m	struct:txdesc_88e
-macid	include/rtl8192e_xmit.h	/^	u32 macid:6;$/;"	m	struct:txdescriptor_8192e
-macid	include/rtl8812a_xmit.h	/^	u32 macid:6;$/;"	m	struct:txdescriptor_8812
-macid	include/rtl8821a_xmit.h	/^	u32 macid:7;$/;"	m	struct:txdescriptor_8821a
-macid_bmp	include/drv_types.h	/^struct macid_bmp {$/;"	s
-macid_ctl	include/drv_types.h	/^	struct macid_ctl_t macid_ctl;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::macid_ctl_t
-macid_ctl_t	include/drv_types.h	/^struct macid_ctl_t {$/;"	s
-macid_num	include/hal_data.h	/^	u8 macid_num;$/;"	m	struct:hal_spec_t
-macstr2num	core/rtw_ieee80211.c	/^void macstr2num(u8 *dst, u8 *src)$/;"	f
-magicwake	include/rtl8188e_recv.h	/^	u32 magicwake:1;$/;"	m	struct:rxreport_8188e
-manual_control	hal/btc/HalBtcOutSrc.h	/^	BOOLEAN					manual_control;$/;"	m	struct:btc_coexist
-map_read8	os_dep/osdep_service.c	/^u8 map_read8(const struct map_t *map, u16 offset)$/;"	f
-map_readN	os_dep/osdep_service.c	/^int map_readN(const struct map_t *map, u16 offset, u16 len, u8 *buf)$/;"	f
-map_seg_t	include/osdep_service.h	/^struct map_seg_t {$/;"	s
-map_t	include/osdep_service.h	/^struct map_t {$/;"	s
-mark	include/osdep_service_bsd.h	/^		u32		mark;$/;"	m	union:sk_buff::__anon49
-marvellAP	include/rtw_mlme_ext.h	/^	marvellAP	= 3,$/;"	e	enum:Associated_AP
-mask	core/rtw_io.c	/^	u32 mask;$/;"	m	struct:rf_sniff_ent	file:
-mask	include/ieee80211.h	/^	u8 mask;$/;"	m	struct:ieee80211_rx_stats
-mask	include/rtw_iol.h	/^	u32  mask;$/;"	m	struct:ioreg_cfg
-mask	include/rtw_pwrctrl.h	/^	char mask[MAX_WKFM_SIZE];$/;"	m	struct:rtl_priv_pattern
-mask	include/rtw_pwrctrl.h	/^	u32	mask[4];$/;"	m	struct:rtl_wow_pattern
-mask_addr	include/drv_types.h	/^	unsigned long	mask_addr;$/;"	m	struct:dvobj_priv
-maskfileBuffer	core/efuse/rtw_efuse.c	/^u8	maskfileBuffer[64];$/;"	v
-match_mstat_sniff_rules	os_dep/osdep_service.c	/^bool match_mstat_sniff_rules(const enum mstat_f flags, const size_t size)$/;"	f
-match_read_sniff_ranges	core/rtw_io.c	/^bool match_read_sniff_ranges(u32 addr, u16 len)$/;"	f
-match_read_sniff_ranges	include/rtw_io.h	463;"	d
-match_rf_read_sniff_ranges	core/rtw_io.c	/^bool match_rf_read_sniff_ranges(u8 path, u32 addr, u32 mask)$/;"	f
-match_rf_read_sniff_ranges	include/rtw_io.h	465;"	d
-match_rf_write_sniff_ranges	core/rtw_io.c	/^bool match_rf_write_sniff_ranges(u8 path, u32 addr, u32 mask)$/;"	f
-match_rf_write_sniff_ranges	include/rtw_io.h	466;"	d
-match_write_sniff_ranges	core/rtw_io.c	/^bool match_write_sniff_ranges(u32 addr, u16 len)$/;"	f
-match_write_sniff_ranges	include/rtw_io.h	464;"	d
-maxAP	include/rtw_mlme_ext.h	/^	maxAP,$/;"	e	enum:Associated_AP
-maxTDLS	include/rtw_mlme_ext.h	/^	maxTDLS,$/;"	e	enum:TDLS_option
-max_agg_num	include/rtl8188e_xmit.h	/^	u32 max_agg_num:5;$/;"	m	struct:txdesc_88e
-max_agg_num	include/rtl8192e_xmit.h	/^	u32 max_agg_num:5;$/;"	m	struct:txdescriptor_8192e
-max_agg_num	include/rtl8812a_xmit.h	/^	u32 max_agg_num:5;$/;"	m	struct:txdescriptor_8812
-max_agg_num	include/rtl8821a_xmit.h	/^	u32 max_agg_num:5;$/;"	m	struct:txdescriptor_8821a
-max_chan	include/rtw_mlme_ext.h	/^	u8 max_chan;$/;"	m	struct:p2p_oper_class_map
-max_chan_nums	include/rtw_mlme_ext.h	/^	unsigned char	max_chan_nums;$/;"	m	struct:mlme_ext_priv
-max_iosz	include/osdep_intf.h	/^	u32	max_iosz;	\/* USB2.0: 128, USB1.1: 64, SDIO:64 *\/$/;"	m	struct:intf_priv
-max_num_sta	include/sta_info.h	/^	u16 max_num_sta;$/;"	m	struct:sta_priv
-max_oqt_page	include/hal_data.h	/^	u16			max_oqt_page;$/;"	m	struct:hal_com_data
-max_power_level	include/wifi.h	/^	u16 max_power_level;$/;"	m	struct:rtw_regulatory
-max_recvsz	include/osdep_intf.h	/^	u32	max_recvsz; \/* USB2.0: unlimited, SDIO:512 *\/$/;"	m	struct:intf_priv
-max_roaming_times	include/drv_types.h	/^	u8	max_roaming_times; \/* the max number driver will try to roaming *\/$/;"	m	struct:registry_priv
-max_sp_len	include/sta_info.h	/^	u8 max_sp_len;$/;"	m	struct:sta_info
-max_time	include/hal_com.h	/^	u32 	max_time;\/* ms	 *\/$/;"	m	struct:noise_info
-max_tx_cnt	include/hal_data.h	/^	u8 max_tx_cnt;$/;"	m	struct:hal_spec_t
-max_xmit_size_bebk	include/hal_data.h	/^	u32			max_xmit_size_bebk;$/;"	m	struct:hal_com_data
-max_xmit_size_vovi	include/hal_data.h	/^	u32			max_xmit_size_vovi;$/;"	m	struct:hal_com_data
-max_xmitsz	include/osdep_intf.h	/^	u32	max_xmitsz; \/* USB2.0: unlimited, SDIO:512 *\/$/;"	m	struct:intf_priv
-mbid_cam_cache	include/drv_types.h	/^	struct mbid_cam_cache mbid_cam_cache[TOTAL_MBID_CAM_NUM];$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::mbid_cam_cache
-mbid_cam_cache	include/drv_types.h	/^struct mbid_cam_cache {$/;"	s
-mbid_cam_cache_clr	hal/hal_com.c	/^static inline void mbid_cam_cache_clr(struct mbid_cam_cache *pmbid_cam)$/;"	f	file:
-mbid_cam_cache_init	hal/hal_com.c	/^static inline void mbid_cam_cache_init(_adapter *adapter, struct mbid_cam_cache *pmbid_cam, u8 *mac_addr)$/;"	f	file:
-mbid_cam_ctl	include/drv_types.h	/^	struct mbid_cam_ctl_t mbid_cam_ctl;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::mbid_cam_ctl_t
-mbid_cam_ctl_t	include/drv_types.h	/^struct mbid_cam_ctl_t {$/;"	s
-mbid_entry_num	include/drv_types.h	/^	ATOMIC_T mbid_entry_num;$/;"	m	struct:mbid_cam_ctl_t
-mbssid	include/rtl8821a_xmit.h	/^	u32 mbssid:4;$/;"	m	struct:txdescriptor_8821a
-mbssid	include/rtw_xmit.h	/^	u8   mbssid;$/;"	m	struct:pkt_attrib
-mc	include/rtl8188e_recv.h	/^	u32 mc:1;$/;"	m	struct:rxreport_8188e
-mcc_adapter_priv	include/rtw_mcc.h	/^struct mcc_adapter_priv {$/;"	s
-mcc_adapterpriv	include/drv_types.h	/^	struct mcc_adapter_priv mcc_adapterpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::mcc_adapter_priv
-mcc_c2h_report	include/rtw_mcc.h	/^enum mcc_c2h_report {$/;"	g
-mcc_c2h_status	include/rtw_mcc.h	/^	u8 mcc_c2h_status;$/;"	m	struct:mcc_obj_priv
-mcc_channel_scan	include/rtw_mcc.h	/^enum mcc_channel_scan {$/;"	g
-mcc_channel_tx_null	include/rtw_mcc.h	/^enum mcc_channel_tx_null {$/;"	g
-mcc_duration	include/rtw_mcc.h	/^	u8 mcc_duration; \/* channel stay period, UNIT:1TU *\/$/;"	m	struct:mcc_adapter_priv
-mcc_iqk_arr	include/rtw_mcc.h	/^	struct mcc_iqk_backup mcc_iqk_arr[MAX_RF_PATH];$/;"	m	struct:mcc_adapter_priv	typeref:struct:mcc_adapter_priv::mcc_iqk_backup
-mcc_iqk_backup	include/rtw_mcc.h	/^struct mcc_iqk_backup {$/;"	s
-mcc_last_tx_bytes_from_kernel	include/rtw_mcc.h	/^	u64 mcc_last_tx_bytes_from_kernel;$/;"	m	struct:mcc_adapter_priv
-mcc_launch_time	include/rtw_mcc.h	/^	u32 mcc_launch_time; \/* mcc launch time, used for starting detect mcc switch channel success *\/$/;"	m	struct:mcc_obj_priv
-mcc_loc_rsvd_paga	include/rtw_mcc.h	/^	u8 mcc_loc_rsvd_paga[MAX_MCC_NUM];  \/* mcc rsvd page *\/$/;"	m	struct:mcc_obj_priv
-mcc_lock	include/rtw_mcc.h	/^	_lock mcc_lock;$/;"	m	struct:mcc_obj_priv
-mcc_macid_bitmap	include/rtw_mcc.h	/^	u16 mcc_macid_bitmap;$/;"	m	struct:mcc_adapter_priv
-mcc_mutex	include/rtw_mcc.h	/^	_mutex mcc_mutex;$/;"	m	struct:mcc_obj_priv
-mcc_obj_priv	include/rtw_mcc.h	/^struct mcc_obj_priv {$/;"	s
-mcc_objpriv	include/drv_types.h	/^	struct mcc_obj_priv mcc_objpriv;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::mcc_obj_priv
-mcc_proc_hdls	os_dep/linux/rtw_proc.c	/^const struct rtw_proc_hdl mcc_proc_hdls[] = {$/;"	v	typeref:struct:rtw_proc_hdl
-mcc_proc_hdls_num	os_dep/linux/rtw_proc.c	/^const int mcc_proc_hdls_num = sizeof(mcc_proc_hdls) \/ sizeof(struct rtw_proc_hdl);$/;"	v
-mcc_sctx	include/rtw_mcc.h	/^	struct submit_ctx mcc_sctx;$/;"	m	struct:mcc_obj_priv	typeref:struct:mcc_obj_priv::submit_ctx
-mcc_status	include/rtw_mcc.h	/^	u8 mcc_status; \/* mcc status stop or start .... *\/$/;"	m	struct:mcc_obj_priv
-mcc_status_rpt	include/rtw_mcc.h	/^enum mcc_status_rpt {$/;"	g
-mcc_target_tx_bytes_to_port	include/rtw_mcc.h	/^	u32 mcc_target_tx_bytes_to_port;		\/* customer require *\/$/;"	m	struct:mcc_adapter_priv
-mcc_tolerance_time	include/rtw_mcc.h	/^	u8 mcc_tolerance_time; \/* used for detect mcc switch channel success *\/$/;"	m	struct:mcc_obj_priv
-mcc_tp	include/rtw_mcc.h	/^	u32 mcc_tp;$/;"	m	struct:mcc_adapter_priv
-mcc_tp_limit	include/rtw_mcc.h	/^	u8 mcc_tp_limit;				\/* check if tp limit or not *\/$/;"	m	struct:mcc_adapter_priv
-mcc_tx_bytes_from_kernel	include/rtw_mcc.h	/^	u64 mcc_tx_bytes_from_kernel;$/;"	m	struct:mcc_adapter_priv
-mcc_tx_bytes_to_port	include/rtw_mcc.h	/^	u32 mcc_tx_bytes_to_port;	\/* already tx to tx fifo (write port) *\/$/;"	m	struct:mcc_adapter_priv
-mcc_tx_stop	include/rtw_mcc.h	/^	u8 mcc_tx_stop;				\/* check if tp stop or not *\/$/;"	m	struct:mcc_adapter_priv
-mcs15_sgi_max_len	include/rtl8188e_xmit.h	/^	u32 mcs15_sgi_max_len:4;$/;"	m	struct:txdesc_88e
-mcs15_sgi_max_len	include/rtl8192e_xmit.h	/^	u32 mcs15_sgi_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcs15_sgi_max_len	include/rtl8812a_xmit.h	/^	u32 mcs15_sgi_max_len:4;$/;"	m	struct:txdescriptor_8812
-mcs7_sgi_max_len	include/rtl8188e_xmit.h	/^	u32 mcs7_sgi_max_len:4;$/;"	m	struct:txdesc_88e
-mcs7_sgi_max_len	include/rtl8192e_xmit.h	/^	u32 mcs7_sgi_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcs7_sgi_max_len	include/rtl8812a_xmit.h	/^	u32 mcs7_sgi_max_len:4;$/;"	m	struct:txdescriptor_8812
-mcsg1_max_len	include/rtl8188e_xmit.h	/^	u32 mcsg1_max_len:4;$/;"	m	struct:txdesc_88e
-mcsg1_max_len	include/rtl8192e_xmit.h	/^	u32 mcsg1_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcsg1_max_len	include/rtl8812a_xmit.h	/^	u32 mcsg1_max_len:4;$/;"	m	struct:txdescriptor_8812
-mcsg2_max_len	include/rtl8188e_xmit.h	/^	u32 mcsg2_max_len:4;$/;"	m	struct:txdesc_88e
-mcsg2_max_len	include/rtl8192e_xmit.h	/^	u32 mcsg2_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcsg2_max_len	include/rtl8812a_xmit.h	/^	u32 mcsg2_max_len:4;$/;"	m	struct:txdescriptor_8812
-mcsg3_max_len	include/rtl8188e_xmit.h	/^	u32 mcsg3_max_len:4;$/;"	m	struct:txdesc_88e
-mcsg3_max_len	include/rtl8192e_xmit.h	/^	u32 mcsg3_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcsg3_max_len	include/rtl8812a_xmit.h	/^	u32 mcsg3_max_len:4;$/;"	m	struct:txdescriptor_8812
-mcsg4_max_len	include/rtl8192e_xmit.h	/^	u32 mcsg4_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcsg4_max_len	include/rtl8812a_xmit.h	/^	u32 mcsg4_max_len:4;$/;"	m	struct:txdescriptor_8812
-mcsg5_max_len	include/rtl8192e_xmit.h	/^	u32 mcsg5_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcsg5_max_len	include/rtl8812a_xmit.h	/^	u32 mcsg5_max_len:4;$/;"	m	struct:txdescriptor_8812
-mcsg6_max_len	include/rtl8192e_xmit.h	/^	u32 mcsg6_max_len:4;$/;"	m	struct:txdescriptor_8192e
-mcsg6_max_len	include/rtl8812a_xmit.h	/^	u32 mcsg6_max_len:4;$/;"	m	struct:txdescriptor_8812
-md	include/rtl8188e_recv.h	/^	u32 md:1;$/;"	m	struct:rxreport_8188e
-mdata	include/rtw_recv.h	/^	u8	mdata;$/;"	m	struct:rx_pkt_attrib
-mdata	include/rtw_xmit.h	/^	u8	mdata;\/* more data bit *\/$/;"	m	struct:pkt_attrib
-mdid	include/rtw_mlme.h	/^	u16	mdid;$/;"	m	struct:_ft_priv
-mdie	include/ieee80211.h	/^	u8 *mdie;$/;"	m	struct:rtw_ieee802_11_elems
-mdie_len	include/ieee80211.h	/^	u8 mdie_len;$/;"	m	struct:rtw_ieee802_11_elems
-mem	include/rtw_mp.h	/^	uint mem[(MAX_MP_XMITBUF_SZ >> 2)];$/;"	m	struct:mp_xmit_frame
-mem	include/rtw_mp_ioctl.h	/^	u32 mem[MAX_MP_XMITBUF_SZ >> 2];$/;"	m	struct:mp_xmit_packet
-mem	include/rtw_recv.h	/^		uint mem[RECVFRAME_HDR_ALIGN >> 2];$/;"	m	union:recv_frame::__anon62
-mem_addr	include/rtw_mp.h	/^	u8 *mem_addr;$/;"	m	struct:mp_xmit_frame
-mesh_action	include/ieee80211_ext.h	/^				}  __attribute__((packed)) mesh_action;$/;"	m	union:ieee80211_mgmt::__anon8::__anon18::__anon19	typeref:struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon25
-mesh_action	include/ieee80211_ext.h	/^				}  mesh_action;$/;"	m	union:ieee80211_mgmt::__anon26::__anon33::__anon34	typeref:struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon40
-mf	include/rtl8188e_recv.h	/^	u32 mf:1;$/;"	m	struct:rxreport_8188e
-mfrag	include/rtw_recv.h	/^	u8	mfrag;$/;"	m	struct:rx_pkt_attrib
-mgmt_queue_macid	include/rtw_mcc.h	/^	u8 mgmt_queue_macid;$/;"	m	struct:mcc_adapter_priv
-mgmt_tx_num	include/rtw_mi.h	/^	u8 mgmt_tx_num;$/;"	m	struct:mi_state
-mgn_rates_cck	core/rtw_ieee80211.c	/^u8 mgn_rates_cck[4] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M};$/;"	v
-mgn_rates_mcs0_7	core/rtw_ieee80211.c	/^u8 mgn_rates_mcs0_7[8] = {MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7};$/;"	v
-mgn_rates_mcs16_23	core/rtw_ieee80211.c	/^u8 mgn_rates_mcs16_23[8] = {MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19, MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23};$/;"	v
-mgn_rates_mcs24_31	core/rtw_ieee80211.c	/^u8 mgn_rates_mcs24_31[8] = {MGN_MCS24, MGN_MCS25, MGN_MCS26, MGN_MCS27, MGN_MCS28, MGN_MCS29, MGN_MCS30, MGN_MCS31};$/;"	v
-mgn_rates_mcs8_15	core/rtw_ieee80211.c	/^u8 mgn_rates_mcs8_15[8] = {MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15};$/;"	v
-mgn_rates_ofdm	core/rtw_ieee80211.c	/^u8 mgn_rates_ofdm[8] = {MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M};$/;"	v
-mgn_rates_vht1ss	core/rtw_ieee80211.c	/^u8 mgn_rates_vht1ss[10] = {MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4$/;"	v
-mgn_rates_vht2ss	core/rtw_ieee80211.c	/^u8 mgn_rates_vht2ss[10] = {MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4$/;"	v
-mgn_rates_vht3ss	core/rtw_ieee80211.c	/^u8 mgn_rates_vht3ss[10] = {MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4$/;"	v
-mgn_rates_vht4ss	core/rtw_ieee80211.c	/^u8 mgn_rates_vht4ss[10] = {MGN_VHT4SS_MCS0, MGN_VHT4SS_MCS1, MGN_VHT4SS_MCS2, MGN_VHT4SS_MCS3, MGN_VHT4SS_MCS4$/;"	v
-mgnt_80211w_IPN	include/rtw_mlme_ext.h	/^	u64 mgnt_80211w_IPN;$/;"	m	struct:mlme_ext_priv
-mgnt_80211w_IPN_rx	include/rtw_mlme_ext.h	/^	u64 mgnt_80211w_IPN_rx;$/;"	m	struct:mlme_ext_priv
-mgnt_netdev_close	os_dep/linux/mlme_linux.c	/^static int mgnt_netdev_close(struct net_device *pnetdev)$/;"	f	file:
-mgnt_netdev_open	os_dep/linux/mlme_linux.c	/^static int mgnt_netdev_open(struct net_device *pnetdev)$/;"	f	file:
-mgnt_seq	include/rtw_mlme_ext.h	/^	u16	mgnt_seq;$/;"	m	struct:mlme_ext_priv
-mgnt_xmit	include/hal_intf.h	/^	s32(*mgnt_xmit)(_adapter *padapter, struct xmit_frame *pmgntframe);$/;"	m	struct:hal_ops
-mgnt_xmit_entry	os_dep/linux/mlme_linux.c	/^static int mgnt_xmit_entry(struct sk_buff *skb, struct net_device *pnetdev)$/;"	f	file:
-mgntok	include/drv_types.h	/^	u32 mgntok;$/;"	m	struct:int_logs
-mgt_dispatcher	core/rtw_mlme_ext.c	/^void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-mi_state	include/rtw_mi.h	/^struct mi_state {$/;"	s
-mic	include/rtw_tdls.h	/^	u8 mic[TDLS_MIC_LEN];$/;"	m	struct:wpa_tdls_ftie
-micKey	include/rtw_wapi.h	/^	u8			micKey[16];$/;"	m	struct:_RT_WAPI_KEY
-mic_ctrl	include/rtw_tdls.h	/^	u8 mic_ctrl[2];$/;"	m	struct:wpa_tdls_ftie
-mic_data	include/rtw_security.h	/^struct mic_data {$/;"	s
-mimo_signal_quality	include/rtw_recv.h	/^	u8 mimo_signal_quality[4];$/;"	m	struct:rx_raw_rssi
-mimo_signal_strength	include/rtw_recv.h	/^	u8 mimo_signal_strength[4];\/* in 0~100 index *\/$/;"	m	struct:rx_raw_rssi
-min_bt_rssi	hal/btc/HalBtcOutSrc.h	/^	s8					min_bt_rssi;$/;"	m	struct:btc_stack_info
-min_chan	include/rtw_mlme_ext.h	/^	u8 min_chan;$/;"	m	struct:p2p_oper_class_map
-min_sounding_period	include/rtw_beamforming.h	/^	u16			min_sounding_period;$/;"	m	struct:sounding_info
-miracast_plus_bt	hal/btc/HalBtcOutSrc.h	/^	boolean					miracast_plus_bt;$/;"	m	struct:btc_bt_info
-mix_column	core/rtw_security.c	/^static void mix_column(u8 *in, u8 *out)$/;"	f	file:
-mlme	include/ieee80211.h	/^		} mlme;$/;"	m	union:ieee_param::__anon73	typeref:struct:ieee_param::__anon73::__anon76
-mlme_ap_tbl	core/rtw_mlme_ext.c	/^struct mlme_handler mlme_ap_tbl[] = {$/;"	v	typeref:struct:mlme_handler
-mlme_evt_hdl	core/rtw_mlme_ext.c	/^u8 mlme_evt_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-mlme_ext_info	include/rtw_mlme_ext.h	/^struct mlme_ext_info {$/;"	s
-mlme_ext_priv	include/rtw_mlme_ext.h	/^struct mlme_ext_priv {$/;"	s
-mlme_handler	include/rtw_mlme_ext.h	/^struct mlme_handler {$/;"	s
-mlme_priv	include/rtw_mlme.h	/^struct mlme_priv {$/;"	s
-mlme_set_scan_to_timer	include/rtw_mlme.h	854;"	d
-mlme_sta_tbl	core/rtw_mlme_ext.c	/^struct mlme_handler mlme_sta_tbl[] = {$/;"	v	typeref:struct:mlme_handler
-mlme_to_adapter	include/drv_types.h	1471;"	d
-mlmeext_assign_scan_backop_flags	include/rtw_mlme_ext.h	693;"	d
-mlmeext_assign_scan_backop_flags	include/rtw_mlme_ext.h	715;"	d
-mlmeext_assign_scan_backop_flags_ap	include/rtw_mlme_ext.h	708;"	d
-mlmeext_assign_scan_backop_flags_ap	include/rtw_mlme_ext.h	723;"	d
-mlmeext_assign_scan_backop_flags_sta	include/rtw_mlme_ext.h	701;"	d
-mlmeext_assign_scan_backop_flags_sta	include/rtw_mlme_ext.h	719;"	d
-mlmeext_chk_scan_backop_flags	include/rtw_mlme_ext.h	692;"	d
-mlmeext_chk_scan_backop_flags	include/rtw_mlme_ext.h	714;"	d
-mlmeext_chk_scan_backop_flags_ap	include/rtw_mlme_ext.h	707;"	d
-mlmeext_chk_scan_backop_flags_ap	include/rtw_mlme_ext.h	722;"	d
-mlmeext_chk_scan_backop_flags_sta	include/rtw_mlme_ext.h	700;"	d
-mlmeext_chk_scan_backop_flags_sta	include/rtw_mlme_ext.h	718;"	d
-mlmeext_chk_scan_state	include/rtw_mlme_ext.h	675;"	d
-mlmeext_init	include/rtw_mlme_ext.h	/^	u8	mlmeext_init;$/;"	m	struct:mlme_ext_priv
-mlmeext_joinbss_event_callback	core/rtw_mlme_ext.c	/^void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)$/;"	f
-mlmeext_msr	include/rtw_mlme_ext.h	672;"	d
-mlmeext_scan_backop_flags	include/rtw_mlme_ext.h	691;"	d
-mlmeext_scan_backop_flags	include/rtw_mlme_ext.h	713;"	d
-mlmeext_scan_backop_flags_ap	include/rtw_mlme_ext.h	706;"	d
-mlmeext_scan_backop_flags_ap	include/rtw_mlme_ext.h	721;"	d
-mlmeext_scan_backop_flags_sta	include/rtw_mlme_ext.h	699;"	d
-mlmeext_scan_backop_flags_sta	include/rtw_mlme_ext.h	717;"	d
-mlmeext_scan_next_state	include/rtw_mlme_ext.h	683;"	d
-mlmeext_scan_state	include/rtw_mlme_ext.h	673;"	d
-mlmeext_scan_state_str	include/rtw_mlme_ext.h	674;"	d
-mlmeext_set_scan_next_state	include/rtw_mlme_ext.h	684;"	d
-mlmeext_set_scan_state	include/rtw_mlme_ext.h	676;"	d
-mlmeext_sta_add_event_callback	core/rtw_mlme_ext.c	/^void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta)$/;"	f
-mlmeext_sta_del_event_callback	core/rtw_mlme_ext.c	/^void mlmeext_sta_del_event_callback(_adapter *padapter)$/;"	f
-mlmeextpriv	include/drv_types.h	/^	struct	mlme_ext_priv mlmeextpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::mlme_ext_priv
-mlmepriv	include/drv_types.h	/^	struct	mlme_priv mlmepriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::mlme_priv
-mlmext_info	include/rtw_mlme_ext.h	/^	struct mlme_ext_info	mlmext_info;\/* for sta\/adhoc mode, including current scanning\/connecting\/connected related info.$/;"	m	struct:mlme_ext_priv	typeref:struct:mlme_ext_priv::mlme_ext_info
-mmc_host	os_dep/linux/sdio_intf.c	/^static struct mmc_host *mmc_host = NULL;$/;"	v	typeref:struct:mmc_host	file:
-mode	include/rtw_cmd.h	/^	u8	mode;$/;"	m	struct:setopmode_parm
-mode	include/rtw_cmd.h	/^	u8 mode;  \/* 0: legacy open, 1: legacy shared 2: 802.1x *\/$/;"	m	struct:setauth_parm
-mode	include/rtw_mlme_ext.h	/^	enum hw_mode {IEEE80211G, IEEE80211A} mode;$/;"	m	struct:p2p_oper_class_map	typeref:enum:p2p_oper_class_map::hw_mode
-mode	include/rtw_mp.h	/^	u32 mode;\/* 0 for normal type packet, 1 for loopback packet (16bytes TXCMD) *\/$/;"	m	struct:mp_priv
-mode	include/rtw_pwrctrl.h	/^	unsigned char mode;$/;"	m	struct:reportpwrstate_parm
-mode	include/sta_info.h	/^	int mode;$/;"	m	struct:wlan_acl_pool
-modem	include/rtw_cmd.h	/^	u8	modem;$/;"	m	struct:getphy_rsp
-modem	include/rtw_cmd.h	/^	u8	modem;$/;"	m	struct:setphy_parm
-modem	include/rtw_rf.h	/^	u8	modem;$/;"	m	struct:regulatory_class
-module_exit	include/osdep_service_bsd.h	499;"	d
-module_init	include/osdep_service_bsd.h	494;"	d
-module_init_exit_wrapper	os_dep/osdep_service.c	/^void module_init_exit_wrapper(void *arg)$/;"	f
-more_data	include/gspi_ops.h	/^	unsigned long more_data;$/;"	m	struct:spi_more_data
-moredata	include/rtl8821a_xmit.h	/^	u32 moredata:1;$/;"	m	struct:txdescriptor_8821a
-morefrag	include/rtl8188e_xmit.h	/^	u32 morefrag:1;$/;"	m	struct:txdesc_88e
-morefrag	include/rtl8192e_xmit.h	/^	u32 morefrag:1;$/;"	m	struct:txdescriptor_8192e
-morefrag	include/rtl8812a_xmit.h	/^	u32 morefrag:1;$/;"	m	struct:txdescriptor_8812
-morefrag	include/rtl8821a_xmit.h	/^	u32 morefrag:1;$/;"	m	struct:txdescriptor_8821a
-mp_customer_str	include/drv_types.h	/^	u8 mp_customer_str;$/;"	m	struct:registry_priv
-mp_dm	include/drv_types.h	/^	u8  mp_dm;$/;"	m	struct:registry_priv
-mp_dm	include/rtw_mp.h	/^	u8 mp_dm;$/;"	m	struct:mp_priv
-mp_init_xmit_attrib	core/rtw_mp.c	/^static void mp_init_xmit_attrib(struct mp_tx *pmptx, PADAPTER padapter)$/;"	f	file:
-mp_ioctl_handler	include/rtw_mp_ioctl.h	/^struct mp_ioctl_handler {$/;"	s
-mp_ioctl_hdl	include/rtw_mp_ioctl.h	/^struct mp_ioctl_handler mp_ioctl_hdl[] = {$/;"	v	typeref:struct:mp_ioctl_handler
-mp_ioctl_param	include/rtw_mp_ioctl.h	/^struct mp_ioctl_param {$/;"	s
-mp_ioctl_xmit_packet_hdl	core/rtw_mp_ioctl.c	/^unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-mp_join	core/rtw_mp.c	/^u32 mp_join(PADAPTER padapter, u8 mode)$/;"	f
-mp_mode	hal/phydm/phydm.h	/^	BOOLEAN			mp_mode;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-mp_mode	include/drv_types.h	/^	u8	mp_mode;$/;"	m	struct:registry_priv
-mp_network	include/rtw_mp.h	/^	struct wlan_network mp_network;$/;"	m	struct:mp_priv	typeref:struct:mp_priv::wlan_network
-mp_priv	include/rtw_mp.h	/^struct mp_priv {$/;"	s
-mp_query_psd	core/rtw_mp.c	/^u32 mp_query_psd(PADAPTER pAdapter, u8 *data)$/;"	f
-mp_recv_frame	core/rtw_recv.c	/^int mp_recv_frame(_adapter *padapter, union recv_frame *rframe)$/;"	f
-mp_rw_reg	include/rtw_mp_ioctl.h	/^} mp_rw_reg, RW_Reg, *pRW_Reg;$/;"	t	typeref:struct:_RW_REG
-mp_start_test	core/rtw_mp.c	/^s32 mp_start_test(PADAPTER padapter)$/;"	f
-mp_stop_test	core/rtw_mp.c	/^void mp_stop_test(PADAPTER padapter)$/;"	f
-mp_tx	include/rtw_mp.h	/^struct mp_tx {$/;"	s
-mp_wi	include/rtw_mp.h	/^	NDIS_WORK_ITEM mp_wi;$/;"	m	struct:mp_wi_cntx
-mp_wi_cntx	include/rtw_mp.h	/^struct mp_wi_cntx {$/;"	s
-mp_wi_evt	include/rtw_mp.h	/^	NDIS_EVENT mp_wi_evt;$/;"	m	struct:mp_wi_cntx
-mp_wi_lock	include/rtw_mp.h	/^	_lock mp_wi_lock;$/;"	m	struct:mp_wi_cntx
-mp_wiparam	include/rtw_mp.h	/^struct mp_wiparam {$/;"	s
-mp_xmit_frame	include/rtw_mp.h	/^struct mp_xmit_frame {$/;"	s
-mp_xmit_packet	include/rtw_mp_ioctl.h	/^struct mp_xmit_packet {$/;"	s
-mp_xmit_packet_thread	core/rtw_mp.c	/^static thread_return mp_xmit_packet_thread(thread_context context)$/;"	f	file:
-mppriv	include/drv_types.h	/^	struct	mp_priv	mppriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::mp_priv
-mptOutBuf	include/rtw_mp.h	/^	u1Byte          mptOutBuf[100];$/;"	m	struct:_MPT_CONTEXT
-mptOutLen	include/rtw_mp.h	/^	ULONG			mptOutLen;$/;"	m	struct:_MPT_CONTEXT
-mpt_InitHWConfig	core/rtw_mp.c	/^void mpt_InitHWConfig(PADAPTER Adapter)$/;"	f
-mpt_ProQueryCalTxPower	core/rtw_mp.c	/^ULONG mpt_ProQueryCalTxPower($/;"	f
-mpt_ProSetPMacTx	hal/hal_mp.c	/^void mpt_ProSetPMacTx(PADAPTER	Adapter)$/;"	f
-mpt_ProStartTest	core/rtw_mp.c	/^static u8 mpt_ProStartTest(PADAPTER padapter)$/;"	f	file:
-mpt_SetRFPath_819X	hal/hal_mp.c	/^VOID mpt_SetRFPath_819X(PADAPTER	pAdapter)$/;"	f
-mpt_SetRFPath_8703B	hal/hal_mp.c	/^void mpt_SetRFPath_8703B(PADAPTER pAdapter)$/;"	f
-mpt_SetRFPath_8723B	hal/hal_mp.c	/^void mpt_SetRFPath_8723B(PADAPTER pAdapter)$/;"	f
-mpt_SetRFPath_8723D	hal/hal_mp.c	/^void mpt_SetRFPath_8723D(PADAPTER pAdapter)$/;"	f
-mpt_SetRFPath_8812A	hal/hal_mp.c	/^void mpt_SetRFPath_8812A(PADAPTER pAdapter)$/;"	f
-mpt_SetRFPath_8814A	hal/hal_mp.c	/^VOID mpt_SetRFPath_8814A(PADAPTER	pAdapter)$/;"	f
-mpt_SetSingleTone_8814A	hal/hal_mp.c	/^mpt_SetSingleTone_8814A($/;"	f
-mpt_SetTxPower	hal/hal_mp.c	/^mpt_SetTxPower($/;"	f
-mpt_SetTxPower_Old	hal/hal_mp.c	/^void mpt_SetTxPower_Old(PADAPTER pAdapter, MPT_TXPWR_DEF Rate, u8 *pTxPower)$/;"	f
-mpt_StartCckContTx	hal/hal_mp.c	/^static	VOID mpt_StartCckContTx($/;"	f	file:
-mpt_StartOfdmContTx	hal/hal_mp.c	/^static	VOID mpt_StartOfdmContTx($/;"	f	file:
-mpt_StopCckContTx	hal/hal_mp.c	/^static	VOID mpt_StopCckContTx($/;"	f	file:
-mpt_StopOfdmContTx	hal/hal_mp.c	/^static	VOID mpt_StopOfdmContTx($/;"	f	file:
-mpt_SwitchRfSetting	core/rtw_mp.c	/^static void mpt_SwitchRfSetting(PADAPTER pAdapter)$/;"	f	file:
-mpt_ToggleIG_8814A	hal/hal_mp.c	/^VOID mpt_ToggleIG_8814A(PADAPTER	pAdapter)$/;"	f
-mptbt_BtControlProcess	core/rtw_bt_mp.c	/^mptbt_BtControlProcess($/;"	f
-mptbt_BtFwOpCodeProcess	core/rtw_bt_mp.c	/^mptbt_BtFwOpCodeProcess($/;"	f
-mptbt_BtGetGeneral	core/rtw_bt_mp.c	/^mptbt_BtGetGeneral($/;"	f
-mptbt_BtReady	core/rtw_bt_mp.c	/^mptbt_BtReady($/;"	f
-mptbt_BtSetGeneral	core/rtw_bt_mp.c	/^mptbt_BtSetGeneral($/;"	f
-mptbt_BtSetMode	core/rtw_bt_mp.c	/^mptbt_BtSetMode($/;"	f
-mptbt_BtSetTxRxPars	core/rtw_bt_mp.c	/^mptbt_BtSetTxRxPars($/;"	f
-mptbt_BtTestCtrl	core/rtw_bt_mp.c	/^mptbt_BtTestCtrl($/;"	f
-mptbt_CheckBtRspStatus	core/rtw_bt_mp.c	/^mptbt_CheckBtRspStatus($/;"	f
-mptbt_CheckC2hFrame	core/rtw_bt_mp.c	/^mptbt_CheckC2hFrame($/;"	f
-mptbt_SendH2c	core/rtw_bt_mp.c	/^mptbt_SendH2c($/;"	f
-mptbt_TestBT	core/rtw_bt_mp.c	/^mptbt_TestBT($/;"	f
-mptbt_close_WiFiRF	core/rtw_bt_mp.c	/^void mptbt_close_WiFiRF(PADAPTER Adapter)$/;"	f
-mptbt_open_WiFiRF	core/rtw_bt_mp.c	/^void mptbt_open_WiFiRF(PADAPTER	Adapter)$/;"	f
-mptbt_switch_RF	core/rtw_bt_mp.c	/^u4Byte mptbt_switch_RF(PADAPTER	Adapter, u1Byte	Enter)$/;"	f
-msDelay	include/hal_phy.h	/^	u32				msDelay;$/;"	m	struct:_SwChnlCmd
-msg	include/drv_types.h	/^	u8 msg[100];$/;"	m	struct:loopbackdata
-msk	include/HalPwrSeqCmd.h	/^	u8 msk;$/;"	m	struct:_WL_PWR_CFG_
-mstat_f	include/osdep_service.h	/^enum mstat_f {$/;"	g
-mstat_ff_idx	include/osdep_service.h	126;"	d
-mstat_sniff_rule	os_dep/osdep_service.c	/^struct mstat_sniff_rule {$/;"	s	file:
-mstat_sniff_rule_num	os_dep/osdep_service.c	/^int mstat_sniff_rule_num = sizeof(mstat_sniff_rules) \/ sizeof(struct mstat_sniff_rule);$/;"	v
-mstat_sniff_rules	os_dep/osdep_service.c	/^struct mstat_sniff_rule mstat_sniff_rules[] = {$/;"	v	typeref:struct:mstat_sniff_rule
-mstat_status	include/osdep_service.h	/^typedef enum mstat_status {$/;"	g
-mstat_tf_idx	include/osdep_service.h	125;"	d
-mtx_lock_irqsave	include/osdep_service_bsd.h	126;"	d
-mtx_unlock_irqrestore	include/osdep_service_bsd.h	170;"	d
-mu_ap_index	hal/phydm/phydm_beamforming.h	/^	u1Byte					mu_ap_index;$/;"	m	struct:_RT_BEAMFORMING_INFO
-mu_bfer_curidx	include/rtw_beamforming.h	/^	u8			mu_bfer_curidx;$/;"	m	struct:beamforming_info
-mu_reg_index	hal/phydm/phydm_beamforming.h	/^	u1Byte	mu_reg_index;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-mu_reg_index	include/rtw_beamforming.h	/^	u8 mu_reg_index;$/;"	m	struct:beamformee_entry
-mu_sound_num_per_period	include/rtw_beamforming.h	/^	u8			mu_sound_num_per_period;$/;"	m	struct:sounding_info
-mu_sounding_list	include/rtw_beamforming.h	/^	u8			mu_sounding_list[MAX_NUM_BEAMFORMEE_MU];$/;"	m	struct:sounding_info
-mu_timer	hal/phydm/phydm_beamforming.h	/^	RT_TIMER					mu_timer;$/;"	m	struct:_RT_BEAMFORMING_INFO
-nBytesInM	include/rtw_security.h	/^	u32     nBytesInM;      \/*  # bytes in M *\/$/;"	m	struct:mic_data
-nCur40MhzPrimeSC	include/hal_data.h	/^	u8				nCur40MhzPrimeSC;	\/* Control channel sub-carrier *\/$/;"	m	struct:hal_com_data
-nCur80MhzPrimeSC	include/hal_data.h	/^	u8				nCur80MhzPrimeSC;   \/* used for primary 40MHz of 80MHz mode *\/$/;"	m	struct:hal_com_data
-nIQK_Cnt	hal/phydm/phydm.h	/^	u4Byte			nIQK_Cnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-nIQK_Fail_Cnt	hal/phydm/phydm.h	/^	u4Byte			nIQK_Fail_Cnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-nIQK_OK_Cnt	hal/phydm/phydm.h	/^	u4Byte			nIQK_OK_Cnt;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-name	hal/phydm/phydm_debug.c	/^	char name[16];$/;"	m	struct:_PHYDM_COMMAND	file:
-name	include/ieee80211.h	/^			u8 name;$/;"	m	struct:ieee_param::__anon73::__anon74
-name	include/linux/wireless.h	/^	char		name[IFNAMSIZ];$/;"	m	union:iwreq_data
-name	os_dep/linux/rtw_proc.h	/^	char *name;$/;"	m	struct:rtw_proc_hdl
-napi	include/drv_types.h	/^	struct	napi_struct napi;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::napi_struct
-napi_recv	os_dep/linux/recv_linux.c	/^static int napi_recv(_adapter *padapter, int budget)$/;"	f	file:
-napi_state	include/drv_types.h	/^	u8	napi_state;$/;"	m	struct:_ADAPTER
-nat25_db_cleanup	core/rtw_br_ext.c	/^void nat25_db_cleanup(_adapter *priv)$/;"	f
-nat25_db_expire	core/rtw_br_ext.c	/^void nat25_db_expire(_adapter *priv)$/;"	f
-nat25_db_handle	core/rtw_br_ext.c	/^int nat25_db_handle(_adapter *priv, struct sk_buff *skb, int method)$/;"	f
-nat25_disable	include/rtw_br_ext.h	/^	unsigned int	nat25_disable;$/;"	m	struct:br_ext_info
-nat25_dmzMac	include/rtw_br_ext.h	/^	unsigned char	nat25_dmzMac[MACADDRLEN];$/;"	m	struct:br_ext_info
-nat25_handle_frame	core/rtw_br_ext.c	/^int nat25_handle_frame(_adapter *priv, struct sk_buff *skb)$/;"	f
-nat25_network_db_entry	include/rtw_br_ext.h	/^struct nat25_network_db_entry {$/;"	s
-nat25sc_disable	include/rtw_br_ext.h	/^	unsigned int	nat25sc_disable;$/;"	m	struct:br_ext_info
-navusehdr	include/rtl8188e_xmit.h	/^	u32 navusehdr:1;$/;"	m	struct:txdesc_88e
-navusehdr	include/rtl8192e_xmit.h	/^	u32 navusehdr:1;$/;"	m	struct:txdescriptor_8192e
-navusehdr	include/rtl8812a_xmit.h	/^	u32 navusehdr:1;$/;"	m	struct:txdescriptor_8812
-navusehdr	include/rtl8821a_xmit.h	/^	u32 navusehdr:1;$/;"	m	struct:txdescriptor_8821a
-nb_intf_flag	hal/phydm/phydm_hwconfig.h	/^	u1Byte		nb_intf_flag: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-nbi_set_result	hal/phydm/phydm.h	/^	u1Byte			nbi_set_result;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-nc_index	include/rtw_beamforming.h	/^	u16	nc_index:3;$/;"	m	struct:rtw_ndpa_sta_info
-ndev_to_wdev	os_dep/linux/ioctl_cfg80211.h	163;"	d
-ndev_unregistering	include/drv_types.h	/^	u8 ndev_unregistering;$/;"	m	struct:_ADAPTER
-ndisauthtype	include/rtw_security.h	/^	u32 ndisauthtype;	\/* NDIS_802_11_AUTHENTICATION_MODE *\/$/;"	m	struct:security_priv
-ndisc_nodetype	include/osdep_service_bsd.h	/^	u8			ndisc_nodetype:2,$/;"	m	struct:sk_buff
-ndisencryptstatus	include/rtw_security.h	/^	u32 ndisencryptstatus;	\/* NDIS_802_11_ENCRYPTION_STATUS *\/$/;"	m	struct:security_priv
-ndiswep	include/rtw_security.h	/^	NDIS_802_11_WEP ndiswep;$/;"	m	struct:security_priv
-ndpa	include/rtl8821a_xmit.h	/^	u32 ndpa:2;$/;"	m	struct:txdescriptor_8821a
-need_recover0x948	hal/btc/HalBtc8723b2Ant.h	/^	boolean		need_recover0x948;$/;"	m	struct:coex_dm_8723b_2ant
-need_recover0x948	hal/btc/HalBtc8821a2Ant.h	/^	boolean		need_recover0x948;$/;"	m	struct:coex_dm_8821a_2ant
-need_recover0x948	hal/btc/halbtc8723d2ant.h	/^	boolean		need_recover0x948;$/;"	m	struct:coex_dm_8723d_2ant
-need_recover0x948	hal/btc/halbtc8821c2ant.h	/^	boolean		need_recover0x948;$/;"	m	struct:coex_dm_8821c_2ant
-need_restore	include/hal_data.h	/^	u8	need_restore;$/;"	m	struct:hal_com_data
-need_to_roam	include/rtw_mlme.h	/^	bool need_to_roam;$/;"	m	struct:mlme_priv
-nego_info	os_dep/linux/ioctl_cfg80211.h	/^	struct rtw_wdev_nego_info nego_info;$/;"	m	struct:rtw_wdev_priv	typeref:struct:rtw_wdev_priv::rtw_wdev_nego_info
-nego_req_info	include/rtw_mlme.h	/^	struct tx_nego_req_info	nego_req_info;$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::tx_nego_req_info
-nego_ssid	include/rtw_mlme.h	/^	u8						nego_ssid[WLAN_SSID_MAXLEN];	\/*	SSID information for group negotitation *\/$/;"	m	struct:wifidirect_info
-nego_ssidlen	include/rtw_mlme.h	/^	u8						nego_ssidlen;$/;"	m	struct:wifidirect_info
-negotiation_dialog_token	include/rtw_mlme.h	/^	u8						negotiation_dialog_token;$/;"	m	struct:wifidirect_info
-net_closed	include/drv_types.h	/^	int net_closed;$/;"	m	struct:_ADAPTER
-netdev_br_init	os_dep/linux/os_intfs.c	/^void netdev_br_init(struct net_device *netdev)$/;"	f
-netdev_close	os_dep/linux/os_intfs.c	/^static int netdev_close(struct net_device *pnetdev)$/;"	f	file:
-netdev_open	os_dep/linux/os_intfs.c	/^int netdev_open(struct net_device *pnetdev)$/;"	f
-netdev_vir_if_close	os_dep/linux/os_intfs.c	/^static int netdev_vir_if_close(struct net_device *pnetdev)$/;"	f	file:
-netdev_vir_if_open	os_dep/linux/os_intfs.c	/^int netdev_vir_if_open(struct net_device *pnetdev)$/;"	f
-nethash	include/drv_types.h	/^	struct nat25_network_db_entry	*nethash[NAT25_HASH_SIZE];$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::nat25_network_db_entry
-netif_up	include/drv_types.h	/^	u8 netif_up;$/;"	m	struct:_ADAPTER
-network	include/rtw_cmd.h	/^	WLAN_BSSID_EX network;$/;"	m	struct:Tx_Beacon_param
-network	include/rtw_cmd.h	/^	WLAN_BSSID_EX network;$/;"	m	struct:joinbss_parm
-network	include/rtw_event.h	/^	struct	wlan_network	network;$/;"	m	struct:joinbss_event	typeref:struct:joinbss_event::wlan_network
-network	include/rtw_mlme_ext.h	/^	WLAN_BSSID_EX			network;\/* join network or bss_network, if in ap mode, it is the same to cur_network.network *\/$/;"	m	struct:mlme_ext_info
-network	include/wlan_bssdef.h	/^	WLAN_BSSID_EX	network; \/* must be the last item *\/$/;"	m	struct:wlan_network
-networkAddr	include/rtw_br_ext.h	/^	unsigned char				networkAddr[MAX_NETWORK_ADDR_LEN];$/;"	m	struct:nat25_network_db_entry
-network_header	include/osdep_service_bsd.h	/^	sk_buff_data_t		network_header;$/;"	m	struct:sk_buff
-network_macaddr	include/rtw_mp.h	/^	NDIS_802_11_MAC_ADDRESS network_macaddr;$/;"	m	struct:mp_priv
-network_mode	include/drv_types.h	/^	u8	network_mode;	\/* infra, ad-hoc, auto *\/$/;"	m	struct:registry_priv
-network_queue	include/rtw_event.h	/^struct network_queue {$/;"	s
-network_type	include/wlan_bssdef.h	/^	int	network_type;	\/* refer to ieee80211.h for WIRELESS_11A\/B\/G *\/$/;"	m	struct:wlan_network
-networks	include/rtw_event.h	/^	WLAN_BSSID_EX networks[NETWORK_QUEUE_SZ];$/;"	m	struct:network_queue
-networktype_to_raid	core/rtw_wlan_util.c	/^u8 networktype_to_raid(_adapter *adapter, struct sta_info *psta)$/;"	f
-networktype_to_raid_ex	core/rtw_wlan_util.c	/^u8 networktype_to_raid_ex(_adapter *adapter, struct sta_info *psta)$/;"	f
-new_bcn_max	core/rtw_wlan_util.c	/^int new_bcn_max = 3;$/;"	v
-new_beacon_cnts	include/rtw_mlme.h	/^	u8 new_beacon_cnts; \/* if new_beacon_cnts >= threshold, ap beacon is changed *\/$/;"	m	struct:mlme_priv
-new_beacon_keys	include/rtw_mlme.h	/^	struct beacon_keys new_beacon_keys; \/* save new beacon keys *\/$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::beacon_keys
-new_ch_no	include/rtw_cmd.h	/^	u8 new_ch_no;$/;"	m	struct:SetChannelSwitch_param
-next	include/osdep_service_bsd.h	/^	struct list_head *next, *prev;$/;"	m	struct:list_head	typeref:struct:list_head::list_head
-next	include/osdep_service_bsd.h	/^	struct sk_buff		*next;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::sk_buff
-next	include/osdep_service_bsd.h	/^	struct sk_buff	*next;$/;"	m	struct:sk_buff_head	typeref:struct:sk_buff_head::sk_buff
-next_hash	include/rtw_br_ext.h	/^	struct nat25_network_db_entry	*next_hash;$/;"	m	struct:nat25_network_db_entry	typeref:struct:nat25_network_db_entry::nat25_network_db_entry
-next_key	core/rtw_security.c	/^static void next_key(u8 *key, sint round)$/;"	f	file:
-next_state	include/rtw_mlme_ext.h	/^	u8 next_state; \/* will set to state on next cmd hdl *\/$/;"	m	struct:ss_res
-nextdevstacksz	include/drv_types.h	/^	u8	nextdevstacksz;\/* unsigned char NextDeviceStackSize;	 *\/ \/* = (CHAR)CEdevice->pUsbDevObj->StackSize + 1; *\/$/;"	m	struct:dvobj_priv
-nextdevstacksz	include/drv_types_sdio.h	/^	u8							nextdevstacksz;$/;"	m	struct:sdio_data
-nextheadpage	include/rtl8188e_xmit.h	/^	u32 nextheadpage:8;$/;"	m	struct:txdesc_88e
-nextheadpage	include/rtl8192e_xmit.h	/^	u32 nextheadpage:8;$/;"	m	struct:txdescriptor_8192e
-nextheadpage	include/rtl8812a_xmit.h	/^	u32 nextheadpage:8;$/;"	m	struct:txdescriptor_8812
-nextind	include/rtl8188e_recv.h	/^	u32 nextind:1;$/;"	m	struct:rxreport_8188e
-nextneadpage	include/rtl8821a_xmit.h	/^	u32 nextneadpage:8;$/;"	m	struct:txdescriptor_8821a
-nextpktlen	include/rtl8188e_recv.h	/^	u32 nextpktlen:14;$/;"	m	struct:rxreport_8188e
-nf_bridge	include/osdep_service_bsd.h	/^	struct nf_bridge_info	*nf_bridge;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::nf_bridge_info
-nf_trace	include/osdep_service_bsd.h	/^				nf_trace:1;$/;"	m	struct:sk_buff
-nfct	include/osdep_service_bsd.h	/^	struct nf_conntrack	*nfct;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::nf_conntrack
-nfct_reasm	include/osdep_service_bsd.h	/^	struct sk_buff		*nfct_reasm;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::sk_buff
-nfctinfo	include/osdep_service_bsd.h	/^				nfctinfo:3;$/;"	m	struct:sk_buff
-nic_hdl	include/rtw_mlme.h	/^	u8	*nic_hdl;$/;"	m	struct:mlme_priv
-no	include/rtw_xmit.h	/^	u8 no;$/;"	m	struct:xmit_buf
-no_ass_rs	include/ieee80211.h	/^	uint no_ass_rs;$/;"	m	struct:ieee80211_softmac_stats
-no_auth_rs	include/ieee80211.h	/^	uint no_auth_rs;$/;"	m	struct:ieee80211_softmac_stats
-no_ht_gf_set	include/sta_info.h	/^	u8 no_ht_gf_set;$/;"	m	struct:sta_info
-no_ht_set	include/sta_info.h	/^	u8 no_ht_set;$/;"	m	struct:sta_info
-no_io	include/rtw_cmd.h	/^	u8 no_io;$/;"	m	struct:cmd_obj
-no_short_preamble_set	include/sta_info.h	/^	u8 no_short_preamble_set;$/;"	m	struct:sta_info
-no_short_slot_time_set	include/sta_info.h	/^	u8 no_short_slot_time_set;$/;"	m	struct:sta_info
-noa_count	include/rtw_mlme.h	/^	u8						noa_count[P2P_MAX_NOA_NUM]; \/* Count for owner, Type of client. *\/$/;"	m	struct:wifidirect_info
-noa_duration	include/rtw_mlme.h	/^	u32						noa_duration[P2P_MAX_NOA_NUM]; \/* Max duration for owner, preferred or min acceptable duration for client. *\/$/;"	m	struct:wifidirect_info
-noa_index	include/rtw_mlme.h	/^	u8						noa_index; \/* Identifies and instance of Notice of Absence timing. *\/$/;"	m	struct:wifidirect_info
-noa_interval	include/rtw_mlme.h	/^	u32						noa_interval[P2P_MAX_NOA_NUM]; \/* Length of interval for owner, preferred or max acceptable interval of client. *\/$/;"	m	struct:wifidirect_info
-noa_num	include/rtw_mlme.h	/^	u8						noa_num; \/* number of NoA descriptor in P2P IE. *\/$/;"	m	struct:wifidirect_info
-noa_start_time	include/rtw_mlme.h	/^	u32						noa_start_time[P2P_MAX_NOA_NUM]; \/* schedule expressed in terms of the lower 4 bytes of the TSF timer. *\/$/;"	m	struct:wifidirect_info
-noacm	include/rtl8188e_xmit.h	/^	u32 noacm:1;$/;"	m	struct:txdesc_88e
-noacm	include/rtl8192e_xmit.h	/^	u32 noacm:1;$/;"	m	struct:txdescriptor_8192e
-noacm	include/rtl8812a_xmit.h	/^	u32 noacm:1;$/;"	m	struct:txdescriptor_8812
-noacm	include/rtl8821a_xmit.h	/^	u32 noacm:1;$/;"	m	struct:txdescriptor_8821a
-node	include/rtw_event.h	/^	unsigned char *node;$/;"	m	struct:event_node
-node	include/rtw_pwrctrl.h	/^	pno_ssid_t	node[MAX_PNO_LIST_COUNT];$/;"	m	struct:pno_ssid_list
-node_array	include/rtw_ioctl.h	/^	struct oid_obj_priv *node_array;$/;"	m	struct:oid_funs_node	typeref:struct:oid_funs_node::oid_obj_priv
-nodes	include/rtw_event.h	/^	struct	event_node	nodes[C2HEVENT_SZ];$/;"	m	struct:c2hevent_queue	typeref:struct:c2hevent_queue::event_node
-nohdr	include/osdep_service_bsd.h	/^				nohdr:1,$/;"	m	struct:sk_buff
-noise	hal/phydm/phydm_noisemonitor.h	/^	s1Byte			noise[MAX_RF_PATH];$/;"	m	struct:_ODM_NOISE_MONITOR_
-noise	include/hal_data.h	/^	s16 noise[ODM_MAX_CHANNEL_NUM];$/;"	m	struct:hal_com_data
-noise	include/ieee80211.h	/^	u8 noise;$/;"	m	struct:ieee80211_rx_stats
-noise	include/rtw_recv.h	/^	s16 noise;$/;"	m	struct:recv_priv
-noise_all	hal/phydm/phydm_noisemonitor.h	/^	s2Byte			noise_all;	$/;"	m	struct:_ODM_NOISE_MONITOR_
-noise_info	include/hal_com.h	/^struct noise_info {$/;"	s
-noise_level	hal/phydm/phydm.h	/^	ODM_NOISE_MONITOR noise_level;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-noise_level	hal/phydm/phydm_noisemonitor.h	/^struct noise_level$/;"	s
-noise_power_db_lsb	hal/phydm/phydm_hwconfig.h	/^	u1Byte	noise_power_db_lsb;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-noise_power_db_msb	hal/phydm/phydm_hwconfig.h	/^	u1Byte	noise_power_db_msb;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-non_ocp_end_time	include/rtw_mlme_ext.h	/^	u32 non_ocp_end_time;$/;"	m	struct:_RT_CHANNEL_INFO
-nonerp_set	include/sta_info.h	/^	u8 nonerp_set;$/;"	m	struct:sta_info
-not_indic_disco	include/rtw_mlme.h	/^	u8	not_indic_disco;$/;"	m	struct:mlme_priv
-notch_filter	include/drv_types.h	/^	u8 notch_filter;$/;"	m	struct:registry_priv
-nqos_ssn	include/rtw_xmit.h	/^	u16	nqos_ssn;$/;"	m	struct:xmit_priv
-nr_ap_if	include/drv_types.h	/^	u8 nr_ap_if; \/* total interface s number of ap\/go mode. *\/$/;"	m	struct:dvobj_priv
-nr_endpoint	include/drv_types.h	/^	u8	nr_endpoint;$/;"	m	struct:dvobj_priv
-nr_frags	include/ieee80211.h	/^	u8 nr_frags;$/;"	m	struct:ieee80211_txb
-nr_frags	include/rtw_xmit.h	/^	u8	nr_frags;$/;"	m	struct:pkt_attrib
-nsec	include/osdep_service_bsd.h	/^	s32	sec, nsec;$/;"	m	struct:ktime::__anon46
-nss_num	include/hal_data.h	/^	u8 nss_num;$/;"	m	struct:hal_spec_t
-ntohl	include/byteorder/generic.h	159;"	d
-ntohl	include/byteorder/generic.h	191;"	d
-ntohl	include/byteorder/generic.h	194;"	d
-ntohl	include/byteorder/generic.h	205;"	d
-ntohs	include/byteorder/generic.h	160;"	d
-ntohs	include/byteorder/generic.h	197;"	d
-ntohs	include/byteorder/generic.h	207;"	d
-null_0	include/rtl8821a_xmit.h	/^	u32 null_0:1;$/;"	m	struct:txdescriptor_8821a
-null_1	include/rtl8821a_xmit.h	/^	u32 null_1:1;$/;"	m	struct:txdescriptor_8821a
-null_addr	core/rtw_mlme_ext.c	/^u8	null_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};$/;"	v
-nulldata_param	core/rtw_mi.c	/^struct nulldata_param {$/;"	s	file:
-num	include/drv_types.h	/^	u8 num;$/;"	m	struct:cam_ctl_t
-num	include/drv_types.h	/^	u8 num;$/;"	m	struct:macid_ctl_t
-num	include/rtw_mlme_ext.h	/^	unsigned int   num;$/;"	m	struct:action_handler
-num	include/rtw_mlme_ext.h	/^	unsigned int   num;$/;"	m	struct:mlme_handler
-num	include/sta_info.h	/^	int num;$/;"	m	struct:wlan_acl_pool
-num_BfTar	hal/phydm/phydm_antdiv.h	/^	u1Byte num_BfTar;$/;"	m	struct:_BF_DIV_COEX_
-num_Client	hal/phydm/phydm_antdiv.h	/^	u1Byte num_Client;$/;"	m	struct:_BF_DIV_COEX_
-num_DivTar	hal/phydm/phydm_antdiv.h	/^	u1Byte num_DivTar;$/;"	m	struct:_BF_DIV_COEX_
-num_FortyMHzIntolerant	include/rtw_mlme.h	/^	int num_FortyMHzIntolerant;$/;"	m	struct:mlme_priv
-num_Txbfee_Client	hal/phydm/phydm_antdiv.h	/^	u1Byte num_Txbfee_Client;$/;"	m	struct:_BF_DIV_COEX_
-num_Txbfer_Client	hal/phydm/phydm_antdiv.h	/^	u1Byte num_Txbfer_Client;$/;"	m	struct:_BF_DIV_COEX_
-num_candidate	hal/phydm/phydm_pathdiv.h	/^	u1Byte	num_candidate;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-num_of_hid	hal/btc/HalBtcOutSrc.h	/^	u8					num_of_hid;$/;"	m	struct:btc_stack_info
-num_of_link	hal/btc/HalBtcOutSrc.h	/^	u8					num_of_link;$/;"	m	struct:btc_stack_info
-num_of_profile	hal/btc/HalBtc8703b1Ant.h	/^	u8					num_of_profile;$/;"	m	struct:coex_sta_8703b_1ant
-num_of_profile	hal/btc/HalBtc8723b1Ant.h	/^	u8					num_of_profile;$/;"	m	struct:coex_sta_8723b_1ant
-num_of_profile	hal/btc/HalBtc8822b1Ant.h	/^	u8					num_of_profile;$/;"	m	struct:coex_sta_8822b_1ant
-num_of_profile	hal/btc/halbtc8723d1ant.h	/^	u8					num_of_profile;$/;"	m	struct:coex_sta_8723d_1ant
-num_of_profile	hal/btc/halbtc8723d2ant.h	/^	u8					num_of_profile;$/;"	m	struct:coex_sta_8723d_2ant
-num_of_profile	hal/btc/halbtc8821c1ant.h	/^	u8					num_of_profile;$/;"	m	struct:coex_sta_8821c_1ant
-num_of_profile	hal/btc/halbtc8821c2ant.h	/^	u8					num_of_profile;$/;"	m	struct:coex_sta_8821c_2ant
-num_of_scanned	include/rtw_mlme.h	/^	u32	num_of_scanned;$/;"	m	struct:mlme_priv
-num_of_secdev_type	include/sta_info.h	/^	u8 num_of_secdev_type;$/;"	m	struct:sta_info
-num_p2p_sdt	include/rtw_mlme.h	/^	u8	num_p2p_sdt;$/;"	m	struct:mlme_priv
-num_rf_path	hal/phydm/phydm.h	/^	u1Byte			num_rf_path;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-num_sta_40mhz_intolerant	include/rtw_mlme.h	/^	int num_sta_40mhz_intolerant;$/;"	m	struct:mlme_priv
-num_sta_ht_20mhz	include/rtw_mlme.h	/^	int num_sta_ht_20mhz;$/;"	m	struct:mlme_priv
-num_sta_ht_no_gf	include/rtw_mlme.h	/^	int num_sta_ht_no_gf;$/;"	m	struct:mlme_priv
-num_sta_no_ht	include/rtw_mlme.h	/^	int num_sta_no_ht;$/;"	m	struct:mlme_priv
-num_sta_no_short_preamble	include/rtw_mlme.h	/^	int num_sta_no_short_preamble;$/;"	m	struct:mlme_priv
-num_sta_no_short_slot_time	include/rtw_mlme.h	/^	int num_sta_no_short_slot_time;$/;"	m	struct:mlme_priv
-num_sta_non_erp	include/rtw_mlme.h	/^	int num_sta_non_erp;$/;"	m	struct:mlme_priv
-num_tx_path	hal/phydm/phydm_pathdiv.h	/^	u1Byte	num_tx_path;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-number_active_client	hal/phydm/phydm.h	/^	u1Byte			number_active_client;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-number_linked_client	hal/phydm/phydm.h	/^	u1Byte			number_linked_client;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-odm_AntDiv_on_off	hal/phydm/phydm_antdiv.c	/^odm_AntDiv_on_off( $/;"	f
-odm_AntennaDiversity	hal/phydm/phydm_antdiv.c	/^odm_AntennaDiversity($/;"	f
-odm_AntennaDiversityInit	hal/phydm/phydm_antdiv.c	/^odm_AntennaDiversityInit($/;"	f
-odm_AntselStatistics	hal/phydm/phydm_antdiv.c	/^odm_AntselStatistics($/;"	f
-odm_AntselStatisticsOfCtrlFrame	hal/phydm/phydm_antdiv.c	/^odm_AntselStatisticsOfCtrlFrame($/;"	f
-odm_AutoChannelSelect	hal/phydm/phydm_acs.c	/^odm_AutoChannelSelect($/;"	f
-odm_AutoChannelSelectInit	hal/phydm/phydm_acs.c	/^odm_AutoChannelSelectInit($/;"	f
-odm_AutoChannelSelectReset	hal/phydm/phydm_acs.c	/^odm_AutoChannelSelectReset($/;"	f
-odm_AutoChannelSelectSetting	hal/phydm/phydm_acs.c	/^odm_AutoChannelSelectSetting($/;"	f
-odm_BDC_Init	hal/phydm/phydm_antdiv.c	/^odm_BDC_Init($/;"	f
-odm_BDCcoexType_withBferClient	hal/phydm/phydm_antdiv.c	/^odm_BDCcoexType_withBferClient($/;"	f
-odm_BDCcoex_BFeeRxDiv_Arbitration	hal/phydm/phydm_antdiv.c	/^odm_BDCcoex_BFeeRxDiv_Arbitration($/;"	f
-odm_BF_AntDiv_ModeArbitration	hal/phydm/phydm_antdiv.c	/^odm_BF_AntDiv_ModeArbitration($/;"	f
-odm_CCKPacketDetectionThresh	hal/phydm/phydm_dig.c	/^odm_CCKPacketDetectionThresh($/;"	f
-odm_CCKRSSI_8188E	hal/phydm/phydm_hwconfig.c	/^odm_CCKRSSI_8188E($/;"	f
-odm_CCKRSSI_8192E	hal/phydm/phydm_hwconfig.c	/^odm_CCKRSSI_8192E($/;"	f
-odm_CCKRSSI_8195A	hal/phydm/phydm_hwconfig.c	/^odm_CCKRSSI_8195A($/;"	f
-odm_CCKRSSI_8703B	hal/phydm/phydm_hwconfig.c	/^odm_CCKRSSI_8703B($/;"	f
-odm_CCKRSSI_8723D	hal/phydm/rtl8723d/phydm_rtl8723d.c	/^odm_CCKRSSI_8723D($/;"	f
-odm_CCKTXPathDiversityCallback	hal/phydm/phydm_pathdiv.c	/^odm_CCKTXPathDiversityCallback($/;"	f
-odm_CCKTXPathDiversityWorkItemCallback	hal/phydm/phydm_pathdiv.c	/^odm_CCKTXPathDiversityWorkItemCallback($/;"	f
-odm_CSI_on_off	hal/phydm/phydm_antdiv.c	/^odm_CSI_on_off($/;"	f
-odm_Cfo	hal/phydm/phydm_hwconfig.c	/^odm_Cfo($/;"	f	file:
-odm_CommonInfoSelfInit	hal/phydm/phydm.c	/^odm_CommonInfoSelfInit($/;"	f
-odm_CommonInfoSelfReset	hal/phydm/phydm.c	/^odm_CommonInfoSelfReset($/;"	f
-odm_CommonInfoSelfUpdate	hal/phydm/phydm.c	/^odm_CommonInfoSelfUpdate($/;"	f
-odm_ConfigBB_AGC_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigBB_AGC_8723D($/;"	f
-odm_ConfigBB_PHY_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigBB_PHY_8723D($/;"	f
-odm_ConfigBB_PHY_REG_PG_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigBB_PHY_REG_PG_8723D($/;"	f
-odm_ConfigBB_TXPWR_LMT_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigBB_TXPWR_LMT_8723D($/;"	f
-odm_ConfigMAC_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigMAC_8723D($/;"	f
-odm_ConfigRFReg_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigRFReg_8723D($/;"	f
-odm_ConfigRF_RadioA_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigRF_RadioA_8723D($/;"	f
-odm_ConfigRF_RadioB_8723D	hal/phydm/rtl8723d/phydm_regconfig8723d.c	/^odm_ConfigRF_RadioB_8723D($/;"	f
-odm_ConvertTo_dB	hal/phydm/phydm.c	/^odm_ConvertTo_dB($/;"	f
-odm_ConvertTo_linear	hal/phydm/phydm.c	/^odm_ConvertTo_linear($/;"	f
-odm_DIG	hal/phydm/phydm_dig.c	/^odm_DIG($/;"	f
-odm_DIGInit	hal/phydm/phydm_dig.c	/^odm_DIGInit($/;"	f
-odm_DIGbyRSSI_LPS	hal/phydm/phydm_dig.c	/^odm_DIGbyRSSI_LPS($/;"	f
-odm_DigAbort	hal/phydm/phydm_dig.c	/^odm_DigAbort($/;"	f
-odm_DigForBtHsMode	hal/phydm/phydm_dig.c	/^odm_DigForBtHsMode($/;"	f
-odm_DivTrainState_setting	hal/phydm/phydm_antdiv.c	/^odm_DivTrainState_setting( $/;"	f
-odm_DynamicBBPowerSavingInit	hal/phydm/phydm_dynamicbbpowersaving.c	/^odm_DynamicBBPowerSavingInit($/;"	f
-odm_DynamicTxPower	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPower($/;"	f
-odm_DynamicTxPowerAP	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPowerAP($/;"	f
-odm_DynamicTxPowerInit	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPowerInit($/;"	f
-odm_DynamicTxPowerNIC	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPowerNIC($/;"	f
-odm_DynamicTxPowerNIC_CE	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPowerNIC_CE($/;"	f
-odm_DynamicTxPowerRestorePowerIndex	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPowerRestorePowerIndex($/;"	f
-odm_DynamicTxPowerSavePowerIndex	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPowerSavePowerIndex($/;"	f
-odm_DynamicTxPowerWritePowerIndex	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPowerWritePowerIndex($/;"	f
-odm_DynamicTxPower_8814A	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPower_8814A($/;"	f
-odm_DynamicTxPower_8821	hal/phydm/phydm_dynamictxpower.c	/^odm_DynamicTxPower_8821($/;"	f
-odm_EVM_Enhance_AntDiv	hal/phydm/phydm_antdiv.c	/^odm_EVM_Enhance_AntDiv($/;"	f
-odm_EVM_FastAntTrainingCallback	hal/phydm/phydm_antdiv.c	/^odm_EVM_FastAntTrainingCallback($/;"	f
-odm_EVM_FastAnt_Reset	hal/phydm/phydm_antdiv.c	/^odm_EVM_FastAnt_Reset($/;"	f
-odm_EVMdbToPercentage	hal/phydm/phydm_hwconfig.c	/^odm_EVMdbToPercentage($/;"	f	file:
-odm_EVMdbm_JaguarSeries	hal/phydm/phydm_hwconfig.c	/^odm_EVMdbm_JaguarSeries($/;"	f	file:
-odm_EdcaChooseTrafficIdx	hal/phydm/phydm_edcaturbocheck.c	/^odm_EdcaChooseTrafficIdx( $/;"	f
-odm_EdcaTurboCheck	hal/phydm/phydm_edcaturbocheck.c	/^odm_EdcaTurboCheck($/;"	f
-odm_EdcaTurboCheckCE	hal/phydm/phydm_edcaturbocheck.c	/^odm_EdcaTurboCheckCE($/;"	f
-odm_EdcaTurboCheckMP	hal/phydm/phydm_edcaturbocheck.c	/^odm_EdcaTurboCheckMP($/;"	f
-odm_FAThresholdCheck	hal/phydm/phydm_dig.c	/^odm_FAThresholdCheck($/;"	f
-odm_FalseAlarmCounterStatistics	hal/phydm/phydm_dig.c	/^odm_FalseAlarmCounterStatistics($/;"	f
-odm_FastAntTraining	hal/phydm/phydm_antdiv.c	/^odm_FastAntTraining($/;"	f
-odm_FastAntTrainingCallback	hal/phydm/phydm_antdiv.c	/^odm_FastAntTrainingCallback($/;"	f
-odm_FastAntTrainingWorkItemCallback	hal/phydm/phydm_antdiv.c	/^odm_FastAntTrainingWorkItemCallback($/;"	f
-odm_FastAntTraining_hl_smart_antenna_type1	hal/phydm/phydm_antdiv.c	/^odm_FastAntTraining_hl_smart_antenna_type1($/;"	f
-odm_Find_RTS_Rate	hal/phydm/phydm_rainfo.c	/^odm_Find_RTS_Rate($/;"	f
-odm_ForbiddenIGICheck	hal/phydm/phydm_dig.c	/^odm_ForbiddenIGICheck($/;"	f
-odm_GetATCStatus	hal/phydm/phydm_cfotracking.c	/^odm_GetATCStatus($/;"	f
-odm_GetDefaultCrytaltalCap	hal/phydm/phydm_cfotracking.c	/^odm_GetDefaultCrytaltalCap($/;"	f
-odm_GetPSDData	hal/phydm/phydm_antdect.c	/^odm_GetPSDData($/;"	f
-odm_HWSetting	hal/phydm/phydm.c	/^odm_HWSetting($/;"	f
-odm_HW_AntDiv	hal/phydm/phydm_antdiv.c	/^odm_HW_AntDiv($/;"	f
-odm_IQCalibrate	hal/phydm/halphyrf_ap.c	/^odm_IQCalibrate($/;"	f
-odm_IQCalibrate	hal/phydm/halphyrf_ce.c	/^odm_IQCalibrate($/;"	f
-odm_IQCalibrate	hal/phydm/halphyrf_win.c	/^odm_IQCalibrate($/;"	f
-odm_InbandNoiseCalculate	hal/phydm/phydm_dig.c	/^odm_InbandNoiseCalculate (	$/;"	f
-odm_InbandNoise_Monitor_ACSeries	hal/phydm/phydm_noisemonitor.c	/^odm_InbandNoise_Monitor_ACSeries(PDM_ODM_T	pDM_Odm, u8 bPauseDIG, u8 IGIValue, u32 max_time$/;"	f
-odm_InbandNoise_Monitor_NSeries	hal/phydm/phydm_noisemonitor.c	/^s2Byte odm_InbandNoise_Monitor_NSeries(PDM_ODM_T	pDM_Odm,u8 bPauseDIG,u8 IGIValue,u32 max_time)$/;"	f
-odm_Init_RSSIForDM	hal/phydm/phydm_hwconfig.c	/^odm_Init_RSSIForDM($/;"	f
-odm_IsEdcaTurboDisable	hal/phydm/phydm_edcaturbocheck.c	/^odm_IsEdcaTurboDisable($/;"	f
-odm_MPT_DIGCallback	hal/phydm/phydm_dig.c	/^odm_MPT_DIGCallback($/;"	f
-odm_MPT_DIGWorkItemCallback	hal/phydm/phydm_dig.c	/^odm_MPT_DIGWorkItemCallback($/;"	f
-odm_MPT_Write_DIG	hal/phydm/phydm_dig.c	/^odm_MPT_Write_DIG($/;"	f
-odm_PathDivChkAntSwitchCallback	hal/phydm/phydm_pathdiv.c	/^odm_PathDivChkAntSwitchCallback($/;"	f
-odm_PathDivChkAntSwitchWorkitemCallback	hal/phydm/phydm_pathdiv.c	/^odm_PathDivChkAntSwitchWorkitemCallback($/;"	f
-odm_PathDiversity	hal/phydm/phydm_pathdiv.c	/^odm_PathDiversity($/;"	f
-odm_PathDiversityInit	hal/phydm/phydm_pathdiv.c	/^odm_PathDiversityInit($/;"	f
-odm_PauseCCKPacketDetection	hal/phydm/phydm_dig.c	/^odm_PauseCCKPacketDetection($/;"	f
-odm_PauseDIG	hal/phydm/phydm_dig.c	/^odm_PauseDIG($/;"	f
-odm_Process_RSSIForDM	hal/phydm/phydm_hwconfig.c	/^odm_Process_RSSIForDM(	$/;"	f
-odm_QueryRxPwrPercentage	hal/phydm/phydm_hwconfig.c	/^odm_QueryRxPwrPercentage($/;"	f
-odm_RA_ParaAdjust	hal/phydm/phydm_rainfo.c	/^odm_RA_ParaAdjust($/;"	f
-odm_RA_ParaAdjust_Send_H2C	hal/phydm/phydm_rainfo.c	/^odm_RA_ParaAdjust_Send_H2C($/;"	f
-odm_RA_ParaAdjust_init	hal/phydm/phydm_rainfo.c	/^odm_RA_ParaAdjust_init($/;"	f
-odm_RA_debug	hal/phydm/phydm_rainfo.c	/^odm_RA_debug($/;"	f
-odm_RFEControl	hal/phydm/phydm_dig.c	/^odm_RFEControl($/;"	f
-odm_RSSIDumpToRegister	hal/phydm/phydm_rainfo.c	/^odm_RSSIDumpToRegister($/;"	f
-odm_RSSIMonitorCheck	hal/phydm/phydm_rainfo.c	/^odm_RSSIMonitorCheck($/;"	f
-odm_RSSIMonitorCheckAP	hal/phydm/phydm_rainfo.c	/^odm_RSSIMonitorCheckAP($/;"	f
-odm_RSSIMonitorCheckCE	hal/phydm/phydm_rainfo.c	/^odm_RSSIMonitorCheckCE($/;"	f
-odm_RSSIMonitorCheckMP	hal/phydm/phydm_rainfo.c	/^odm_RSSIMonitorCheckMP($/;"	f
-odm_RSSIMonitorInit	hal/phydm/phydm_rainfo.c	/^odm_RSSIMonitorInit($/;"	f
-odm_RX_HWAntDiv_Init_88E	hal/phydm/phydm_antdiv.c	/^odm_RX_HWAntDiv_Init_88E($/;"	f
-odm_RX_HWAntDiv_Init_92E	hal/phydm/phydm_antdiv.c	/^odm_RX_HWAntDiv_Init_92E($/;"	f
-odm_RateAdaptiveMaskInit	hal/phydm/phydm_rainfo.c	/^odm_RateAdaptiveMaskInit($/;"	f
-odm_RefreshBasicRateMask	hal/phydm/phydm_rainfo.c	/^odm_RefreshBasicRateMask($/;"	f
-odm_RefreshLdpcRtsMP	hal/phydm/phydm_rainfo.c	/^odm_RefreshLdpcRtsMP($/;"	f
-odm_RefreshRateAdaptiveMask	hal/phydm/phydm_rainfo.c	/^odm_RefreshRateAdaptiveMask($/;"	f
-odm_RefreshRateAdaptiveMaskAPADSL	hal/phydm/phydm_rainfo.c	/^odm_RefreshRateAdaptiveMaskAPADSL($/;"	f
-odm_RefreshRateAdaptiveMaskCE	hal/phydm/phydm_rainfo.c	/^odm_RefreshRateAdaptiveMaskCE($/;"	f
-odm_RefreshRateAdaptiveMaskMP	hal/phydm/phydm_rainfo.c	/^odm_RefreshRateAdaptiveMaskMP($/;"	f
-odm_Regulation2_4G	hal/phydm/phydm.h	/^	u1Byte			odm_Regulation2_4G;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-odm_Regulation5G	hal/phydm/phydm.h	/^	u1Byte			odm_Regulation5G;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-odm_RxPhyBWJaguarSeries_Parsing	hal/phydm/phydm_hwconfig.c	/^odm_RxPhyBWJaguarSeries_Parsing($/;"	f
-odm_RxPhyStatus92CSeries_Parsing	hal/phydm/phydm_hwconfig.c	/^odm_RxPhyStatus92CSeries_Parsing($/;"	f
-odm_RxPhyStatusJaguarSeries_Parsing	hal/phydm/phydm_hwconfig.c	/^odm_RxPhyStatusJaguarSeries_Parsing($/;"	f
-odm_S0S1_SWAntDiv_Init_8188F	hal/phydm/phydm_antdiv.c	/^odm_S0S1_SWAntDiv_Init_8188F($/;"	f
-odm_S0S1_SWAntDiv_Init_8723B	hal/phydm/phydm_antdiv.c	/^odm_S0S1_SWAntDiv_Init_8723B($/;"	f
-odm_S0S1_SWAntDiv_Init_8821A	hal/phydm/phydm_antdiv.c	/^odm_S0S1_SWAntDiv_Init_8821A($/;"	f
-odm_S0S1_SWAntDiv_Reset	hal/phydm/phydm_antdiv.c	/^odm_S0S1_SWAntDiv_Reset($/;"	f
-odm_S0S1_SwAntDiv	hal/phydm/phydm_antdiv.c	/^odm_S0S1_SwAntDiv($/;"	f
-odm_S0S1_SwAntDivByCtrlFrame	hal/phydm/phydm_antdiv.c	/^odm_S0S1_SwAntDivByCtrlFrame($/;"	f
-odm_S0S1_SwAntDivByCtrlFrame_ProcessRSSI	hal/phydm/phydm_antdiv.c	/^odm_S0S1_SwAntDivByCtrlFrame_ProcessRSSI($/;"	f
-odm_SQ_process_patch_RT_CID_819x_Acer	hal/phydm/phydm_hwconfig.c	/^static u1Byte odm_SQ_process_patch_RT_CID_819x_Acer($/;"	f	file:
-odm_SQ_process_patch_RT_CID_819x_Lenovo	hal/phydm/phydm_hwconfig.c	/^static u1Byte odm_SQ_process_patch_RT_CID_819x_Lenovo($/;"	f	file:
-odm_SetATCStatus	hal/phydm/phydm_cfotracking.c	/^odm_SetATCStatus($/;"	f
-odm_SetCrystalCap	hal/phydm/phydm_cfotracking.c	/^odm_SetCrystalCap($/;"	f
-odm_SetNextMACAddrTarget	hal/phydm/phydm_antdiv.c	/^odm_SetNextMACAddrTarget($/;"	f
-odm_SetTxPowerLevel8814	hal/phydm/phydm_dynamictxpower.c	/^odm_SetTxPowerLevel8814($/;"	f
-odm_Set_RA_DM_ARFB_by_Noisy	hal/phydm/phydm_rainfo.c	/^odm_Set_RA_DM_ARFB_by_Noisy($/;"	f
-odm_SignalScaleMapping	hal/phydm/phydm_hwconfig.c	/^odm_SignalScaleMapping(	$/;"	f
-odm_SignalScaleMapping_92CSeries	hal/phydm/phydm_hwconfig.c	/^odm_SignalScaleMapping_92CSeries(	$/;"	f
-odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Lenovo	hal/phydm/phydm_hwconfig.c	/^odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Lenovo(	$/;"	f
-odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Netcore	hal/phydm/phydm_hwconfig.c	/^odm_SignalScaleMapping_92CSeries_patch_RT_CID_819x_Netcore(	$/;"	f
-odm_Smart_HWAntDiv_Init_88E	hal/phydm/phydm_antdiv.c	/^odm_Smart_HWAntDiv_Init_88E($/;"	f
-odm_Smart_HWAntDiv_Init_92E	hal/phydm/phydm_antdiv.c	/^odm_Smart_HWAntDiv_Init_92E($/;"	f
-odm_SwAntDetectInit	hal/phydm/phydm_antdect.c	/^odm_SwAntDetectInit($/;"	f
-odm_SwAntDivConstructScanChnl	hal/phydm/phydm_pathdiv.c	/^odm_SwAntDivConstructScanChnl($/;"	f
-odm_SwAntDivSelectScanChnl	hal/phydm/phydm_pathdiv.c	/^odm_SwAntDivSelectScanChnl($/;"	f
-odm_TRX_HWAntDiv_Init_8723B	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_8723B($/;"	f
-odm_TRX_HWAntDiv_Init_8723D	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_8723D($/;"	f
-odm_TRX_HWAntDiv_Init_8812A	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_8812A($/;"	f
-odm_TRX_HWAntDiv_Init_8821A	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_8821A($/;"	f
-odm_TRX_HWAntDiv_Init_8821C	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_8821C($/;"	f
-odm_TRX_HWAntDiv_Init_8881A	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_8881A($/;"	f
-odm_TRX_HWAntDiv_Init_88E	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_88E($/;"	f
-odm_TRX_HWAntDiv_Init_92E	hal/phydm/phydm_antdiv.c	/^odm_TRX_HWAntDiv_Init_92E($/;"	f
-odm_TXPowerTrackingCheckAP	hal/phydm/phydm_powertracking_ap.c	/^odm_TXPowerTrackingCheckAP($/;"	f
-odm_TXPowerTrackingCheckAP	hal/phydm/phydm_powertracking_ce.c	/^odm_TXPowerTrackingCheckAP($/;"	f
-odm_TXPowerTrackingCheckAP	hal/phydm/phydm_powertracking_win.c	/^odm_TXPowerTrackingCheckAP($/;"	f
-odm_TXPowerTrackingCheckCE	hal/phydm/phydm_powertracking_ap.c	/^odm_TXPowerTrackingCheckCE($/;"	f
-odm_TXPowerTrackingCheckCE	hal/phydm/phydm_powertracking_ce.c	/^odm_TXPowerTrackingCheckCE($/;"	f
-odm_TXPowerTrackingCheckCE	hal/phydm/phydm_powertracking_win.c	/^odm_TXPowerTrackingCheckCE($/;"	f
-odm_TXPowerTrackingCheckMP	hal/phydm/phydm_powertracking_ap.c	/^odm_TXPowerTrackingCheckMP($/;"	f
-odm_TXPowerTrackingCheckMP	hal/phydm/phydm_powertracking_ce.c	/^odm_TXPowerTrackingCheckMP($/;"	f
-odm_TXPowerTrackingCheckMP	hal/phydm/phydm_powertracking_win.c	/^odm_TXPowerTrackingCheckMP($/;"	f
-odm_TXPowerTrackingDirectCall	hal/phydm/phydm_powertracking_win.c	/^odm_TXPowerTrackingDirectCall($/;"	f
-odm_TXPowerTrackingInit	hal/phydm/phydm_powertracking_ap.c	/^odm_TXPowerTrackingInit($/;"	f
-odm_TXPowerTrackingInit	hal/phydm/phydm_powertracking_ce.c	/^odm_TXPowerTrackingInit($/;"	f
-odm_TXPowerTrackingInit	hal/phydm/phydm_powertracking_win.c	/^odm_TXPowerTrackingInit($/;"	f
-odm_TXPowerTrackingThermalMeterCheck	hal/phydm/phydm_powertracking_ap.c	/^odm_TXPowerTrackingThermalMeterCheck($/;"	f
-odm_TXPowerTrackingThermalMeterCheck	hal/phydm/phydm_powertracking_ce.c	/^odm_TXPowerTrackingThermalMeterCheck($/;"	f
-odm_TXPowerTrackingThermalMeterCheck	hal/phydm/phydm_powertracking_win.c	/^odm_TXPowerTrackingThermalMeterCheck($/;"	f
-odm_TXPowerTrackingThermalMeterInit	hal/phydm/phydm_powertracking_ap.c	/^odm_TXPowerTrackingThermalMeterInit($/;"	f
-odm_TXPowerTrackingThermalMeterInit	hal/phydm/phydm_powertracking_ce.c	/^odm_TXPowerTrackingThermalMeterInit($/;"	f
-odm_TXPowerTrackingThermalMeterInit	hal/phydm/phydm_powertracking_win.c	/^odm_TXPowerTrackingThermalMeterInit($/;"	f
-odm_Tx_By_TxDesc_or_Reg	hal/phydm/phydm_antdiv.c	/^odm_Tx_By_TxDesc_or_Reg( $/;"	f
-odm_UpdatePowerTrainingState	hal/phydm/phydm.c	/^odm_UpdatePowerTrainingState($/;"	f
-odm_UpdateTxAnt	hal/phydm/phydm_antdiv.c	/^odm_UpdateTxAnt($/;"	f
-odm_ability_str	core/rtw_odm.c	/^const char *odm_ability_str[] = {$/;"	v
-odm_comp_str	core/rtw_odm.c	/^const char *odm_comp_str[] = {$/;"	v
-odm_dbg_level_str	core/rtw_odm.c	/^const char *odm_dbg_level_str[] = {$/;"	v
-odm_dtc	hal/phydm/phydm.c	/^void odm_dtc(PDM_ODM_T pDM_Odm)$/;"	f
-odm_pathdiv_debug	hal/phydm/phydm_pathdiv.c	/^odm_pathdiv_debug($/;"	f
-odm_priv	hal/btc/HalBtcOutSrc.h	/^	PVOID					odm_priv;$/;"	m	struct:btc_coexist
-odm_proc_hdls	os_dep/linux/rtw_proc.c	/^const struct rtw_proc_hdl odm_proc_hdls[] = {$/;"	v	typeref:struct:rtw_proc_hdl
-odm_proc_hdls_num	os_dep/linux/rtw_proc.c	/^const int odm_proc_hdls_num = sizeof(odm_proc_hdls) \/ sizeof(struct rtw_proc_hdl);$/;"	v
-odm_ready	hal/phydm/phydm.h	/^	BOOLEAN			odm_ready;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-odmpriv	include/hal_data.h	/^	DM_ODM_T	odmpriv;$/;"	m	struct:hal_com_data
-ofdm_agc_idx	hal/phydm/phydm.h	/^	u1Byte			ofdm_agc_idx[4];$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-ofdm_block_enable	hal/phydm/phydm_dig.h	/^	BOOLEAN		ofdm_block_enable;$/;"	m	struct:_FALSE_ALARM_STATISTICS
-ofdm_pwr	include/rtw_recv.h	/^	s8 ofdm_pwr[4];$/;"	m	struct:rx_raw_rssi
-ofdm_snr	include/rtw_recv.h	/^	u8 ofdm_snr[4];$/;"	m	struct:rx_raw_rssi
-off_ch_num	include/rtw_mlme.h	/^	u8	off_ch_num;$/;"	m	struct:tdls_ch_switch
-offset	include/HalPwrSeqCmd.h	/^	u16 offset;$/;"	m	struct:_WL_PWR_CFG_
-offset	include/hal_data.h	/^	u16	offset;$/;"	m	struct:_BB_INIT_REGISTER
-offset	include/rtl8188e_xmit.h	/^	u32 offset:8;$/;"	m	struct:txdesc_88e
-offset	include/rtl8192e_xmit.h	/^	u32 offset:8;$/;"	m	struct:txdescriptor_8192e
-offset	include/rtl8812a_xmit.h	/^	u32 offset:8;$/;"	m	struct:txdescriptor_8812
-offset	include/rtl8814a_xmit.h	/^	u32 offset:8;$/;"	m	struct:txdescriptor_8814
-offset	include/rtl8821a_xmit.h	/^	u32 offset:8;$/;"	m	struct:txdescriptor_8821a
-offset	include/rtw_cmd.h	/^	u32	offset;$/;"	m	struct:writeRF_parm
-offset	include/rtw_cmd.h	/^	u8	offset;$/;"	m	struct:readBB_parm
-offset	include/rtw_cmd.h	/^	u8	offset;$/;"	m	struct:readRF_parm
-offset	include/rtw_cmd.h	/^	u8	offset;$/;"	m	struct:readTSSI_parm
-offset	include/rtw_cmd.h	/^	u8	offset;$/;"	m	struct:writeBB_parm
-offset	include/rtw_efuse.h	/^	u8 offset;$/;"	m	struct:PG_PKT_STRUCT_A
-offset	include/rtw_mp.h	/^	u32 offset;$/;"	m	struct:bb_reg_param
-offset	include/rtw_mp.h	/^	u32 offset;$/;"	m	struct:rf_reg_param
-offset	include/rtw_mp_ioctl.h	/^	u32 offset;$/;"	m	struct:_BURST_RW_REG
-offset	include/rtw_mp_ioctl.h	/^	u32 offset;$/;"	m	struct:_EEPROM_RW_PARAM
-offset	include/rtw_mp_ioctl.h	/^	u32 offset;$/;"	m	struct:_RW_REG
-offset	include/rtw_mp_ioctl.h	/^	u32 offset;$/;"	m	struct:bbreg_param
-offset	include/rtw_mp_ioctl.h	/^	u32 offset;$/;"	m	struct:eeprom_rw_param
-offset	include/rtw_mp_ioctl.h	/^	u32 offset;$/;"	m	struct:rwreg_param
-offset	include/rtw_mp_ioctl.h	/^	u8 offset;$/;"	m	struct:_DR_VARIABLE_STRUCT_
-offset	include/rtw_xmit.h	/^	u16 offset;$/;"	m	struct:agg_pkt_info
-oid	include/rtw_ioctl.h	/^	NDIS_OID	oid;$/;"	m	struct:oid_par_priv
-oid	include/rtw_mp_ioctl.h	/^	u32 oid;$/;"	m	struct:mp_ioctl_handler
-oid_end	include/rtw_ioctl.h	/^	unsigned int oid_end; \/* the ending number for OID *\/$/;"	m	struct:oid_funs_node
-oid_funs_node	include/rtw_ioctl.h	/^struct oid_funs_node {$/;"	s
-oid_null_function	include/rtw_ioctl.h	/^static NDIS_STATUS oid_null_function(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_obj_priv	include/rtw_ioctl.h	/^struct oid_obj_priv {$/;"	s
-oid_par_priv	include/rtw_ioctl.h	/^struct oid_par_priv {$/;"	s
-oid_rt_ap_get_associated_station_list_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_ap_get_associated_station_list_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_ap_set_passphrase_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_ap_set_passphrase_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_ap_supported_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_ap_supported_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_ap_switch_into_ap_mode_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_ap_switch_into_ap_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_current_tx_power_level_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_current_tx_power_level_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_dedicate_probe_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_dedicate_probe_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_forced_data_rate_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_forced_data_rate_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_ap_ip_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_ap_ip_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_bss_wireless_mode_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_bss_wireless_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_channel_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_channel_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_channel_list_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_channel_list_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_channelplan_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_channelplan_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_connect_state_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_connect_state_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_efuse_current_size_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_get_efuse_current_size_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_efuse_max_size_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_get_efuse_max_size_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_enc_key_match_count_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_enc_key_match_count_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_enc_key_mismatch_count_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_enc_key_mismatch_count_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_hardware_radio_off_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_hardware_radio_off_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_key_mismatch_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_key_mismatch_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_large_packet_crc_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_large_packet_crc_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_middle_packet_crc_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_middle_packet_crc_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_phy_rx_packet_crc32_error_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_get_phy_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_phy_rx_packet_received_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_get_phy_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_power_mode_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_get_power_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_preamble_mode_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_preamble_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_rx_icv_err_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_rx_icv_err_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_rx_retry_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_rx_retry_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_rx_total_packet_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_rx_total_packet_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_scan_in_progress_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_scan_in_progress_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_signal_quality_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_signal_quality_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_small_packet_crc_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_small_packet_crc_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_thermal_meter_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_get_thermal_meter_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_total_rx_bytes_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_total_rx_bytes_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_total_tx_bytes_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_total_tx_bytes_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_tx_beacon_err_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_tx_beacon_err_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_tx_beacon_ok_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_tx_beacon_ok_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_get_tx_retry_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_get_tx_retry_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_poll_rx_status_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_poll_rx_status_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro8711_join_bss_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro8711_join_bss_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro8711_pkt_loss_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro8711_pkt_loss_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro8711_wi_poll_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro8711_wi_poll_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_add_sta_info_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_add_sta_info_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_burst_read_register_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_burst_read_register_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_burst_write_register_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_burst_write_register_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_cfg_debug_message_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_cfg_debug_message_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_dele_sta_info_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_dele_sta_info_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_efuse_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_efuse_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_efuse_map_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_efuse_map_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_encryption_ctrl_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_encryption_ctrl_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_h2c_get_rate_table_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_h2c_get_rate_table_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_h2c_set_rate_table_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_h2c_set_rate_table_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_qry_pwrstate_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_qry_pwrstate_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_query_dr_variable_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_query_dr_variable_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_query_rx_packet_crc32_error_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_query_rx_packet_crc32_error_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_query_rx_packet_received_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_query_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_query_tx_packet_sent_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_query_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_read16_eeprom_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_read16_eeprom_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_read_bb_reg_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_read_efuse_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_read_efuse_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_read_register_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_read_register_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_read_rf_reg_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_read_tssi_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_read_tssi_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_reset_rx_packet_received_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_reset_rx_packet_received_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_reset_tx_packet_sent_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_reset_tx_packet_sent_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_rf_read_registry_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_pro_rf_read_registry_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_rf_write_registry_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_pro_rf_write_registry_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_rw_efuse_pgpkt_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_rw_efuse_pgpkt_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_rx_packet_type_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_antenna_bb_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_antenna_bb_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_basic_rate_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_basic_rate_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_carrier_suppression_tx_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_carrier_suppression_tx_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_channel_direct_call_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_channel_direct_call_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_continuous_tx_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_continuous_tx_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_data_rate_ex_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_data_rate_ex_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_data_rate_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_data_rate_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_fw_dig_state_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_pro_set_fw_dig_state_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_fw_ra_state_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_pro_set_fw_ra_state_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_modulation_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_modulation_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_pkt_test_mode_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_pkt_test_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_power_tracking_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_power_tracking_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_pwrstate_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_pwrstate_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_rf_intfs_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS  oid_rt_pro_set_rf_intfs_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_single_carrier_tx_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_single_carrier_tx_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_single_tone_tx_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_single_tone_tx_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_tx_agc_offset_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_tx_agc_offset_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_set_tx_power_control_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_set_tx_power_control_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_start_test_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_start_test_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_stop_test_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_stop_test_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_trigger_gpio_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_trigger_gpio_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_write16_eeprom_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_write16_eeprom_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_write_bb_reg_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_write_efuse_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_write_efuse_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_write_register_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_write_register_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_write_rf_reg_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_pro_write_txcmd_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_pro_write_txcmd_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_rd_attrib_mem_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_rd_attrib_mem_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_reset_phy_rx_packet_count_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_reset_phy_rx_packet_count_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_scan_with_magic_packet_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_scan_with_magic_packet_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_bandwidth_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_set_bandwidth_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_bcn_intvl_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_set_bcn_intvl_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_channelplan_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_set_channelplan_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_crystal_cap_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_set_crystal_cap_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_default_key_id_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_set_default_key_id_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_encryption_algorithm_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_set_encryption_algorithm_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_power_down_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_set_power_down_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_preamble_mode_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_set_preamble_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_set_rx_packet_type_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_set_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_supported_wireless_mode_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_supported_wireless_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_wireless_mode_for_scan_list_hdl	core/rtw_ioctl_rtl.c	/^NDIS_STATUS oid_rt_wireless_mode_for_scan_list_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_wireless_mode_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_wireless_mode_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rt_wr_attrib_mem_hdl	core/rtw_mp_ioctl.c	/^NDIS_STATUS oid_rt_wr_attrib_mem_hdl(struct oid_par_priv *poid_par_priv)$/;"	f
-oid_rtl_seg_01_01	core/rtw_ioctl_rtl.c	/^struct oid_obj_priv oid_rtl_seg_01_01[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_01_03	core/rtw_ioctl_rtl.c	/^struct oid_obj_priv oid_rtl_seg_01_03[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_01_11	core/rtw_ioctl_rtl.c	/^struct oid_obj_priv oid_rtl_seg_01_11[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_03_00	core/rtw_ioctl_rtl.c	/^struct oid_obj_priv oid_rtl_seg_03_00[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_81_80_00	include/rtw_mp_ioctl.h	/^const struct oid_obj_priv oid_rtl_seg_81_80_00[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_81_80_20	include/rtw_mp_ioctl.h	/^const struct oid_obj_priv oid_rtl_seg_81_80_20[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_81_80_40	include/rtw_mp_ioctl.h	/^const struct oid_obj_priv oid_rtl_seg_81_80_40[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_81_80_80	include/rtw_mp_ioctl.h	/^const struct oid_obj_priv oid_rtl_seg_81_80_80[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_81_85	include/rtw_mp_ioctl.h	/^const struct oid_obj_priv oid_rtl_seg_81_85[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_81_87	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_81_87[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_87_11_00	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_87_11_00[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_87_11_20	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_87_11_20[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_87_11_50	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_87_11_50[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_87_11_80	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_87_11_80[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_87_11_B0	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_87_11_B0[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_87_11_F0	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_87_11_F0[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_rtl_seg_87_12_00	include/rtw_mp_ioctl.h	/^struct oid_obj_priv oid_rtl_seg_87_12_00[] = {$/;"	v	typeref:struct:oid_obj_priv
-oid_start	include/rtw_ioctl.h	/^	unsigned int oid_start; \/* the starting number for OID *\/$/;"	m	struct:oid_funs_node
-oid_type	include/rtw_ioctl.h	/^enum oid_type {$/;"	g
-oidassociation	include/rtw_security.h	/^	u8 oidassociation[512]; \/* for wpa\/wpa2 usage *\/$/;"	m	struct:security_priv
-oidfuns	include/rtw_ioctl.h	/^	NDIS_STATUS(*oidfuns)(struct oid_par_priv *poid_par_priv);$/;"	m	struct:oid_obj_priv
-olbc	include/rtw_mlme.h	/^	ATOMIC_T olbc; \/* Overlapping Legacy BSS Condition (Legacy b\/g)*\/$/;"	m	struct:mlme_priv
-olbc_ht	include/rtw_mlme.h	/^	ATOMIC_T olbc_ht;$/;"	m	struct:mlme_priv
-old_bRegUseLed	include/drv_types.h	/^		u8 old_bRegUseLed;$/;"	m	struct:_ADAPTER::rereg_nd_name_data
-old_ifname	include/drv_types.h	/^		char old_ifname[IFNAMSIZ];$/;"	m	struct:_ADAPTER::rereg_nd_name_data
-old_ifname	include/drv_types.h	/^	char old_ifname[IFNAMSIZ];$/;"	m	struct:_ADAPTER
-old_ips_mode	include/drv_types.h	/^		u8 old_ips_mode;$/;"	m	struct:_ADAPTER::rereg_nd_name_data
-old_pnetdev	include/drv_types.h	/^		_nic_hdl old_pnetdev;$/;"	m	struct:_ADAPTER::rereg_nd_name_data
-omac1_aes_128	core/rtw_security.c	/^int omac1_aes_128(u8 *key, u8 *data, size_t data_len, u8 *mac)$/;"	f
-omac1_aes_128_vector	core/rtw_security.c	/^static int omac1_aes_128_vector(u8 *key, size_t num_elem,$/;"	f	file:
-on_action_public	core/rtw_mlme_ext.c	/^unsigned int on_action_public(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-on_action_public_default	core/rtw_mlme_ext.c	/^unsigned int on_action_public_default(union recv_frame *precv_frame, u8 action)$/;"	f
-on_action_public_p2p	core/rtw_mlme_ext.c	/^unsigned int on_action_public_p2p(union recv_frame *precv_frame)$/;"	f
-on_action_public_vendor	core/rtw_mlme_ext.c	/^unsigned int on_action_public_vendor(union recv_frame *precv_frame)$/;"	f
-on_action_spct	core/rtw_mlme_ext.c	/^unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-on_action_spct_ch_switch	core/rtw_mlme_ext.c	/^unsigned int on_action_spct_ch_switch(_adapter *padapter, struct sta_info *psta, u8 *ies, uint ies_len)$/;"	f
-on_action_wnm	core/rtw_mlme_ext.c	/^unsigned int on_action_wnm(_adapter *adapter, union recv_frame *rframe)$/;"	f
-on_oper_ch_time	include/drv_types.h	/^	u32 on_oper_ch_time;$/;"	m	struct:dvobj_priv
-oob_gpio	os_dep/linux/rtw_android.c	/^unsigned int oob_gpio = 0;$/;"	v
-oob_irq	os_dep/linux/rtw_android.c	/^unsigned int oob_irq = 0;$/;"	v
-op	core/rtw_br_ext.c	/^	u_int8_t op;$/;"	m	struct:dhcpMessage	file:
-opCode	include/rtw_bt_mp.h	/^	u1Byte	opCode;$/;"	m	struct:_BT_H2C
-opCodeVer	include/rtw_bt_mp.h	/^	UCHAR       opCodeVer;$/;"	m	struct:_BT_REQ_CMD
-opCodeVer	include/rtw_bt_mp.h	/^	u1Byte	opCodeVer:4;$/;"	m	struct:_BT_EXT_C2H
-opCodeVer	include/rtw_bt_mp.h	/^	u1Byte	opCodeVer:4;$/;"	m	struct:_BT_H2C
-op_chs_ent_t	core/rtw_rf.c	/^struct op_chs_ent_t {$/;"	s	file:
-op_chs_of_cch_2g_40m	core/rtw_rf.c	/^u8 op_chs_of_cch_2g_40m[CENTER_CH_2G_40M_NUM][2] = {$/;"	v
-op_chs_of_cch_2g_by_bw	core/rtw_rf.c	/^struct op_chs_ent_t op_chs_of_cch_2g_by_bw[] = {$/;"	v	typeref:struct:op_chs_ent_t
-op_chs_of_cch_5g_160m	core/rtw_rf.c	/^u8 op_chs_of_cch_5g_160m[CENTER_CH_5G_160M_NUM][8] = {$/;"	v
-op_chs_of_cch_5g_40m	core/rtw_rf.c	/^u8 op_chs_of_cch_5g_40m[CENTER_CH_5G_40M_NUM][2] = {$/;"	v
-op_chs_of_cch_5g_80m	core/rtw_rf.c	/^u8 op_chs_of_cch_5g_80m[CENTER_CH_5G_80M_NUM][4] = {$/;"	v
-op_chs_of_cch_5g_by_bw	core/rtw_rf.c	/^struct op_chs_ent_t op_chs_of_cch_5g_by_bw[] = {$/;"	v	typeref:struct:op_chs_ent_t
-op_class	include/rtw_mlme_ext.h	/^	u8 op_class;$/;"	m	struct:p2p_oper_class_map
-op_wfd_mode	include/rtw_mlme.h	/^	u8 op_wfd_mode;$/;"	m	struct:wifi_display_info
-op_wfd_mode	include/sta_info.h	/^	u8 op_wfd_mode;$/;"	m	struct:sta_info
-opcode	hal/btc/HalBtcOutSrc.h	/^	u1Byte	opcode;$/;"	m	struct:_COL_H2C
-opcode_ver	hal/btc/HalBtcOutSrc.h	/^	u1Byte	opcode_ver:4;$/;"	m	struct:_COL_C2H_ACK
-opcode_ver	hal/btc/HalBtcOutSrc.h	/^	u1Byte	opcode_ver:4;$/;"	m	struct:_COL_H2C
-openFile	os_dep/osdep_service.c	/^static int openFile(struct file **fpp, const char *path, int flag, int mode)$/;"	f	file:
-oper_bwmode	include/drv_types.h	/^	unsigned char	oper_bwmode;$/;"	m	struct:dvobj_priv
-oper_ch_offset	include/drv_types.h	/^	unsigned char	oper_ch_offset;\/* PRIME_CHNL_OFFSET *\/$/;"	m	struct:dvobj_priv
-oper_channel	include/drv_types.h	/^	unsigned char	oper_channel; \/* saved channel info when call set_channel_bw *\/$/;"	m	struct:dvobj_priv
-operating_ch	include/rtw_mlme.h	/^	u8					operating_ch;	\/*	This information will be set by using the p2p_set op_ch=x *\/$/;"	m	struct:tx_invite_req_info
-operating_channel	include/rtw_mlme.h	/^	u8						operating_channel;$/;"	m	struct:wifidirect_info
-operation_ch	include/rtw_mlme.h	/^	u8					operation_ch[2];				\/*	Store the operation channel of invitation request frame *\/$/;"	m	struct:scan_limit_info
-operation_ch	include/rtw_mlme.h	/^	u8					operation_ch[5];				\/*	Store additional channel 1,6,11  for Android 4.2 IOT & Nexus 4 *\/$/;"	m	struct:scan_limit_info
-operation_mode	include/wifi.h	/^	unsigned short	operation_mode;$/;"	m	struct:ieee80211_ht_addt_info
-opp_ps	include/rtw_mlme.h	/^	u8						opp_ps; \/* opportunistic power save. *\/$/;"	m	struct:wifidirect_info
-option	include/rtw_cmd.h	/^	u8 option;$/;"	m	struct:TDLSoption_param
-option	include/rtw_recv.h	/^	sint	option;$/;"	m	struct:sta_recv_priv
-option	include/rtw_xmit.h	/^	sint	option;$/;"	m	struct:sta_xmit_priv
-options	core/rtw_br_ext.c	/^	u_int8_t options[308]; \/* 312 - cookie *\/$/;"	m	struct:dhcpMessage	file:
-optlen	include/ip.h	/^	unsigned char	optlen;$/;"	m	struct:ip_options
-optlength	include/ip.h	115;"	d
-order	include/rtw_mcc.h	/^	u8 order;		\/* FW document, softap\/AP must be 0 *\/$/;"	m	struct:mcc_adapter_priv
-order	include/rtw_recv.h	/^	u8	order;$/;"	m	struct:rx_pkt_attrib
-order	include/rtw_xmit.h	/^	u8	order;\/* order bit *\/$/;"	m	struct:pkt_attrib
-org_2g_RegC14	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_2g_RegC14;$/;"	m	struct:_PathDiv_Parameter_define_
-org_2g_RegC4C	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_2g_RegC4C;$/;"	m	struct:_PathDiv_Parameter_define_
-org_2g_RegC80	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_2g_RegC80;$/;"	m	struct:_PathDiv_Parameter_define_
-org_2g_RegC94	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_2g_RegC94;$/;"	m	struct:_PathDiv_Parameter_define_
-org_2g_RegCA0	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_2g_RegCA0;$/;"	m	struct:_PathDiv_Parameter_define_
-org_5g_RegC14	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_5g_RegC14;$/;"	m	struct:_PathDiv_Parameter_define_
-org_5g_RegCA0	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_5g_RegCA0;$/;"	m	struct:_PathDiv_Parameter_define_
-org_5g_RegE30	hal/phydm/phydm_pathdiv.h	/^	u4Byte org_5g_RegE30;$/;"	m	struct:_PathDiv_Parameter_define_
-org_power_mgnt	include/rtw_pwrctrl.h	/^	u8	org_power_mgnt;$/;"	m	struct:pwrctrl_priv
-ori_bw	include/rtw_mlme.h	/^	u8 ori_bw;$/;"	m	struct:mlme_priv
-ori_ch	include/rtw_mlme.h	/^	u8 ori_ch;$/;"	m	struct:mlme_priv
-ori_offset	include/rtw_mlme.h	/^	u8 ori_offset;$/;"	m	struct:mlme_priv
-orig_40_offset	include/rtw_pwrctrl.h	/^	u8	orig_40_offset;			\/* original channel 40 offset *\/$/;"	m	struct:pno_scan_info
-orig_80_offset	include/rtw_pwrctrl.h	/^	u8	orig_80_offset;			\/* original channel 80 offset *\/$/;"	m	struct:pno_scan_info
-orig_bw	include/rtw_pwrctrl.h	/^	u8	orig_bw;			\/* original bandwidth *\/$/;"	m	struct:pno_scan_info
-orig_ch	include/rtw_pwrctrl.h	/^	u8	orig_ch;			\/* original channel *\/$/;"	m	struct:pno_scan_info
-os_indicate	include/drv_types.h	/^	u32 os_indicate;$/;"	m	struct:rx_logs
-os_indicate_ap_forward	include/drv_types.h	/^	u32 os_indicate_ap_forward;$/;"	m	struct:rx_logs
-os_indicate_ap_mcast	include/drv_types.h	/^	u32 os_indicate_ap_mcast;$/;"	m	struct:rx_logs
-os_indicate_ap_self	include/drv_types.h	/^	u32 os_indicate_ap_self;$/;"	m	struct:rx_logs
-os_indicate_err	include/drv_types.h	/^	u32 os_indicate_err;$/;"	m	struct:rx_logs
-os_memcmp	core/rtw_security.c	/^static int os_memcmp(void *s1, void *s2, u8 n)$/;"	f	file:
-os_netif_err	include/drv_types.h	/^	u32 os_netif_err;$/;"	m	struct:rx_logs
-os_netif_ok	include/drv_types.h	/^	u32 os_netif_ok;$/;"	m	struct:rx_logs
-os_strlen	core/rtw_security.c	/^static u8 os_strlen(const char *s)$/;"	f	file:
-os_tx	include/drv_types.h	/^	u32 os_tx;$/;"	m	struct:tx_logs
-os_tx_err_up	include/drv_types.h	/^	u32 os_tx_err_up;$/;"	m	struct:tx_logs
-os_tx_err_xmit	include/drv_types.h	/^	u32 os_tx_err_xmit;$/;"	m	struct:tx_logs
-os_tx_m2u	include/drv_types.h	/^	u32 os_tx_m2u;$/;"	m	struct:tx_logs
-os_tx_m2u_entry	include/drv_types.h	/^	u32 os_tx_m2u_entry;$/;"	m	struct:tx_logs
-os_tx_m2u_entry_err_skb	include/drv_types.h	/^	u32 os_tx_m2u_entry_err_skb;$/;"	m	struct:tx_logs
-os_tx_m2u_entry_err_xmit	include/drv_types.h	/^	u32 os_tx_m2u_entry_err_xmit;$/;"	m	struct:tx_logs
-os_tx_m2u_ignore_fw_linked	include/drv_types.h	/^	u32 os_tx_m2u_ignore_fw_linked;$/;"	m	struct:tx_logs
-os_tx_m2u_ignore_self	include/drv_types.h	/^	u32 os_tx_m2u_ignore_self;$/;"	m	struct:tx_logs
-os_tx_m2u_stop	include/drv_types.h	/^	u32 os_tx_m2u_stop;$/;"	m	struct:tx_logs
-oui	include/ieee80211.h	/^	u8    oui[P80211_OUI_LEN];    \/* organizational universal id *\/$/;"	m	struct:ieee80211_snap_hdr
-oui	include/ieee80211_ext.h	/^	u8 oui[3];$/;"	m	struct:wme_parameter_element
-oui	include/ieee80211_ext.h	/^	u8 oui[4]; \/* 24-bit OUI followed by 8-bit OUI type *\/$/;"	m	struct:wpa_ie_hdr
-oui_8021h	include/rtw_recv.h	/^static u8 oui_8021h[] = {0x00, 0x00, 0xf8};$/;"	v
-oui_rfc1042	include/rtw_recv.h	/^static u8 oui_rfc1042[] = {0x00, 0x00, 0x00};$/;"	v
-oui_subtype	include/ieee80211_ext.h	/^	u8 oui_subtype;$/;"	m	struct:wme_parameter_element
-oui_type	include/ieee80211_ext.h	/^	u8 oui_type;$/;"	m	struct:wme_parameter_element
-own	include/rtl8188e_recv.h	/^	u32 own:1;$/;"	m	struct:rxreport_8188e
-own	include/rtl8188e_xmit.h	/^	u32 own:1;$/;"	m	struct:txdesc_88e
-own	include/rtl8192e_xmit.h	/^	u32 own:1;$/;"	m	struct:txdescriptor_8192e
-own	include/rtl8812a_xmit.h	/^	u32 own:1;$/;"	m	struct:txdescriptor_8812
-p2p_assoc_req_ie	include/rtw_mlme.h	/^	u8 *p2p_assoc_req_ie;$/;"	m	struct:mlme_priv
-p2p_assoc_req_ie_len	include/rtw_mlme.h	/^	u32 p2p_assoc_req_ie_len;$/;"	m	struct:mlme_priv
-p2p_assoc_resp_ie	include/rtw_mlme.h	/^	u8 *p2p_assoc_resp_ie;$/;"	m	struct:mlme_priv
-p2p_assoc_resp_ie_len	include/rtw_mlme.h	/^	u32 p2p_assoc_resp_ie_len;$/;"	m	struct:mlme_priv
-p2p_beacon_ie	include/rtw_mlme.h	/^	u8 *p2p_beacon_ie;$/;"	m	struct:mlme_priv
-p2p_beacon_ie_len	include/rtw_mlme.h	/^	u32 p2p_beacon_ie_len;$/;"	m	struct:mlme_priv
-p2p_cancel_roch_cmd	core/rtw_cmd.c	/^inline u8 p2p_cancel_roch_cmd(_adapter *adapter, u64 cookie, struct wireless_dev *wdev, u8 flags)$/;"	f
-p2p_channels	include/rtw_mlme_ext.h	/^struct p2p_channels {$/;"	s
-p2p_concurrent_handler	core/rtw_p2p.c	/^void p2p_concurrent_handler(_adapter	*padapter)$/;"	f
-p2p_enabled	os_dep/linux/ioctl_cfg80211.h	/^	u8 p2p_enabled;$/;"	m	struct:rtw_wdev_priv
-p2p_go_probe_resp_ie	include/rtw_mlme.h	/^	u8 *p2p_go_probe_resp_ie;		\/* for GO *\/$/;"	m	struct:mlme_priv
-p2p_go_probe_resp_ie_len	include/rtw_mlme.h	/^	u32 p2p_go_probe_resp_ie_len;	\/* for GO *\/$/;"	m	struct:mlme_priv
-p2p_group_ssid	include/rtw_mlme.h	/^	u8						p2p_group_ssid[WLAN_SSID_MAXLEN];$/;"	m	struct:wifidirect_info
-p2p_group_ssid_len	include/rtw_mlme.h	/^	u8						p2p_group_ssid_len;$/;"	m	struct:wifidirect_info
-p2p_info	include/rtw_mlme.h	/^	struct scan_limit_info		p2p_info;		\/*	Used for get the limit scan channel from the P2P negotiation handshake *\/$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::scan_limit_info
-p2p_listen_state_process	core/rtw_mlme_ext.c	/^u32 p2p_listen_state_process(_adapter *padapter, unsigned char *da)$/;"	f
-p2p_oper_class_map	include/rtw_mlme_ext.h	/^struct p2p_oper_class_map {$/;"	s
-p2p_pdt_cid	include/rtw_mlme.h	/^	u16	p2p_pdt_cid;$/;"	m	struct:mlme_priv
-p2p_pdt_scid	include/rtw_mlme.h	/^	u16	p2p_pdt_scid;$/;"	m	struct:mlme_priv
-p2p_peer_device_addr	include/rtw_mlme.h	/^	u8						p2p_peer_device_addr[ETH_ALEN];$/;"	m	struct:wifidirect_info
-p2p_peer_interface_addr	include/rtw_mlme.h	/^	u8						p2p_peer_interface_addr[ETH_ALEN];$/;"	m	struct:wifidirect_info
-p2p_probe_req_ie	include/rtw_mlme.h	/^	u8 *p2p_probe_req_ie;$/;"	m	struct:mlme_priv
-p2p_probe_req_ie_len	include/rtw_mlme.h	/^	u32 p2p_probe_req_ie_len;$/;"	m	struct:mlme_priv
-p2p_probe_resp_ie	include/rtw_mlme.h	/^	u8 *p2p_probe_resp_ie;$/;"	m	struct:mlme_priv
-p2p_probe_resp_ie_len	include/rtw_mlme.h	/^	u32 p2p_probe_resp_ie_len;$/;"	m	struct:mlme_priv
-p2p_protocol_wk_cmd	core/rtw_cmd.c	/^u8 p2p_protocol_wk_cmd(_adapter *padapter, int intCmdType)$/;"	f
-p2p_protocol_wk_hdl	core/rtw_p2p.c	/^s32 p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType, u8 *buf)$/;"	f
-p2p_ps_mode	include/rtw_mlme.h	/^	enum P2P_PS_MODE		p2p_ps_mode; \/* indicate p2p ps mode *\/$/;"	m	struct:wifidirect_info	typeref:enum:wifidirect_info::P2P_PS_MODE
-p2p_ps_offload	include/hal_data.h	/^	u8	p2p_ps_offload;$/;"	m	struct:hal_com_data
-p2p_ps_state	include/rtw_mlme.h	/^	enum P2P_PS_STATE		p2p_ps_state; \/* indicate p2p ps state *\/$/;"	m	struct:wifidirect_info	typeref:enum:wifidirect_info::P2P_PS_STATE
-p2p_ps_wk_cmd	core/rtw_p2p.c	/^u8 p2p_ps_wk_cmd(_adapter *padapter, u8 p2p_ps_state, u8 enqueue)$/;"	f
-p2p_ps_wk_hdl	core/rtw_p2p.c	/^void p2p_ps_wk_hdl(_adapter *padapter, u8 p2p_ps_state)$/;"	f
-p2p_reg_class	include/rtw_mlme_ext.h	/^	struct p2p_reg_class {$/;"	s	struct:p2p_channels
-p2p_reject_disable	include/rtw_mlme.h	/^	u8	p2p_reject_disable;	\/* When starting NL80211 wpa_supplicant\/hostapd, it will call netdev_close *\/$/;"	m	struct:mlme_priv
-p2p_roch_cmd	core/rtw_cmd.c	/^inline u8 p2p_roch_cmd(_adapter *adapter$/;"	f
-p2p_roch_parm	include/rtw_cmd.h	/^struct p2p_roch_parm {$/;"	s
-p2p_sdt_cid	include/rtw_mlme.h	/^	u16	p2p_sdt_cid[MAX_NUM_P2P_SDT];$/;"	m	struct:mlme_priv
-p2p_sdt_scid	include/rtw_mlme.h	/^	u16	p2p_sdt_scid[MAX_NUM_P2P_SDT];$/;"	m	struct:mlme_priv
-p2p_state	include/rtw_mlme.h	/^	enum P2P_STATE			p2p_state;$/;"	m	struct:wifidirect_info	typeref:enum:wifidirect_info::P2P_STATE
-p2p_status_code	include/sta_info.h	/^	u8 p2p_status_code;$/;"	m	struct:sta_info
-p2p_wildcard_ssid	include/rtw_mlme.h	/^	u8						p2p_wildcard_ssid[P2P_WILDCARD_SSID_LEN];$/;"	m	struct:wifidirect_info
-p2p_wow_info	include/rtw_mlme.h	/^	struct p2p_wowlan_info		p2p_wow_info;$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::p2p_wowlan_info
-p2p_wowlan_info	include/rtw_mlme.h	/^struct p2p_wowlan_info {$/;"	s
-pAdapter	include/drv_types_ce.h	/^	PVOID		    pAdapter;$/;"	m	struct:_USB_EXTENSION
-pAntennaTest	hal/phydm/phydm.h	/^	u1Byte			*pAntennaTest;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pBDC_T	hal/phydm/phydm_antdiv.h	/^}BDC_T,*pBDC_T;$/;"	t	typeref:struct:_BF_DIV_COEX_
-pBandType	hal/phydm/phydm.h	/^	u1Byte			*pBandType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pBandWidth	hal/phydm/phydm.h	/^	u1Byte			*pBandWidth;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pBuddyAdapter	hal/phydm/phydm.h	/^	PADAPTER		*pBuddyAdapter;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pBurst_RW_Reg	include/rtw_mp_ioctl.h	/^} burst_rw_reg, Burst_RW_Reg, *pBurst_RW_Reg;$/;"	t	typeref:struct:_BURST_RW_REG
-pChannel	hal/phydm/phydm.h	/^	u1Byte			*pChannel;			\/*central channel number*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pCoexDm	hal/btc/HalBtc8188c2Ant.c	/^static PCOEX_DM_8188C_2ANT 	pCoexDm=&GLCoexDm8188c2Ant;$/;"	v	file:
-pCoexDm	hal/btc/HalBtc8192d2Ant.c	/^static PCOEX_DM_8192D_2ANT 	pCoexDm=&GLCoexDm8192d2Ant;$/;"	v	file:
-pCoexDm	hal/btc/HalBtc8723a1Ant.c	/^static PCOEX_DM_8723A_1ANT 	pCoexDm=&GLCoexDm8723a1Ant;$/;"	v	file:
-pCoexDm	hal/btc/HalBtc8723a2Ant.c	/^static PCOEX_DM_8723A_2ANT 	pCoexDm=&GLCoexDm8723a2Ant;$/;"	v	file:
-pCoexSta	hal/btc/HalBtc8188c2Ant.c	/^static PCOEX_STA_8188C_2ANT	pCoexSta=&GLCoexSta8188c2Ant;$/;"	v	file:
-pCoexSta	hal/btc/HalBtc8192d2Ant.c	/^static PCOEX_STA_8192D_2ANT	pCoexSta=&GLCoexSta8192d2Ant;$/;"	v	file:
-pCoexSta	hal/btc/HalBtc8723a1Ant.c	/^static PCOEX_STA_8723A_1ANT	pCoexSta=&GLCoexSta8723a1Ant;$/;"	v	file:
-pCoexSta	hal/btc/HalBtc8723a2Ant.c	/^static PCOEX_STA_8723A_2ANT	pCoexSta=&GLCoexSta8723a2Ant;$/;"	v	file:
-pCtryTransfer	hal/phydm/rtchnlplan.h	/^	PRT_CHNL_CTRY_TBL		pCtryTransfer;$/;"	m	struct:_RT_CHANNEL_PLAN_NEW
-pCurrentRxTP	hal/phydm/phydm.h	/^	u4Byte			*pCurrentRxTP;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pCurrentTxTP	hal/phydm/phydm.h	/^	u4Byte			*pCurrentTxTP;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pDIG_T	hal/phydm/phydm_dig.h	/^}DIG_T,*pDIG_T;$/;"	t	typeref:struct:_Dynamic_Initial_Gain_Threshold_
-pDefaultS0S1	hal/phydm/phydm_antdiv.h	/^	u1Byte	*pDefaultS0S1;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-pDynamicFile	include/rtw_pwrctrl.h	/^	u8	*pDynamicFile;$/;"	m	struct:lps_poff_info
-pEDCA_T	hal/phydm/phydm_edcaturbocheck.h	/^}EDCA_T,*pEDCA_T;$/;"	t	typeref:struct:_EDCA_TURBO_
-pEEPROM_RWParam	include/rtw_mp_ioctl.h	/^} eeprom_rw_param, EEPROM_RWParam, *pEEPROM_RWParam;$/;"	t	typeref:struct:_EEPROM_RW_PARAM
-pFAT_T	hal/phydm/phydm_antdiv.h	/^}FAT_T,*pFAT_T;$/;"	t	typeref:struct:_FAST_ANTENNA_TRAINNING_
-pForceTxAntByDesc	hal/phydm/phydm_antdiv.h	/^	u1Byte	*pForceTxAntByDesc;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-pForcedDataRate	hal/phydm/phydm.h	/^	pu2Byte			pForcedDataRate;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pIs1Antenna	hal/phydm/phydm.h	/^	BOOLEAN			*pIs1Antenna;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pIsFcsModeEnable	hal/phydm/phydm.h	/^	BOOLEAN			*pIsFcsModeEnable;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pLed	include/rtw_cmd.h	/^	PVOID	 pLed;$/;"	m	struct:LedBlink_param
-pMacPhyMode	hal/phydm/phydm.h	/^	u1Byte			*pMacPhyMode;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pNumRxBytesUnicast	hal/phydm/phydm.h	/^	u8Byte			*pNumRxBytesUnicast;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pNumTxBytesUnicast	hal/phydm/phydm.h	/^	u8Byte			*pNumTxBytesUnicast;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pODM_StaInfo	hal/phydm/phydm.h	/^	PSTA_INFO_T		pODM_StaInfo[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pOnePathCCA	hal/phydm/phydm.h	/^	u1Byte			*pOnePathCCA;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pPATHDIV_PARA	hal/phydm/phydm_pathdiv.h	/^}PATHDIV_PARA,*pPATHDIV_PARA;$/;"	t	typeref:struct:_PathDiv_Parameter_define_
-pPATHDIV_T	hal/phydm/phydm_pathdiv.h	/^}PATHDIV_T, *pPATHDIV_T;$/;"	t	typeref:struct:_ODM_PATH_DIVERSITY_
-pPHY_RX_AGC_INFO_T	hal/phydm/phydm_hwconfig.h	/^} __WLAN_ATTRIB_PACK__ PHY_RX_AGC_INFO_T, *pPHY_RX_AGC_INFO_T;$/;"	t	typeref:struct:_Phy_Rx_AGC_Info
-pPS_T	hal/phydm/phydm_dynamicbbpowersaving.h	/^}PS_T,*pPS_T;$/;"	t	typeref:struct:_Dynamic_Power_Saving_
-pParamStart	include/rtw_bt_mp.h	/^	UCHAR       pParamStart[100];$/;"	m	struct:_BT_REQ_CMD
-pParamStart	include/rtw_bt_mp.h	/^	UCHAR       pParamStart[100];$/;"	m	struct:_BT_RSP_CMD
-pPri_CCA_T	hal/phydm/phydm.h	/^} Pri_CCA_T, *pPri_CCA_T;$/;"	t	typeref:struct:_Dynamic_Primary_CCA
-pRA_T	hal/phydm/phydm_rainfo.h	/^} RA_T, *pRA_T;$/;"	t	typeref:struct:_Rate_Adaptive_Table_
-pRFDefaultPath	hal/phydm/phydm.h	/^	u1Byte			*pRFDefaultPath;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pRW_Reg	include/rtw_mp_ioctl.h	/^} mp_rw_reg, RW_Reg, *pRW_Reg;$/;"	t	typeref:struct:_RW_REG
-pSAT_T	hal/phydm/phydm_antdiv.h	/^} SAT_T, *pSAT_T;$/;"	t	typeref:struct:_SMART_ANTENNA_TRAINNING_
-pSWAT_T	hal/phydm/phydm_antdiv.h	/^}SWAT_T, *pSWAT_T;$/;"	t	typeref:struct:_SW_Antenna_Switch_
-pSecChOffset	hal/phydm/phydm.h	/^	u1Byte			*pSecChOffset;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pSecurity	hal/phydm/phydm.h	/^	u1Byte			*pSecurity;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pSoundingSeq	hal/phydm/phydm.h	/^	u1Byte			*pSoundingSeq;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pStaticFile	include/rtw_pwrctrl.h	/^	u8	*pStaticFile;$/;"	m	struct:lps_poff_info
-pUSB_VendorReq	include/rtw_mp_ioctl.h	/^} usb_vendor_req, USB_VendorReq, *pUSB_VendorReq;$/;"	t	typeref:struct:_USB_VendorReq
-pWirelessMode	hal/phydm/phydm.h	/^	u1Byte			*pWirelessMode;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-p_aid	include/rtl8821a_xmit.h	/^	u32 p_aid:9;$/;"	m	struct:txdescriptor_8821a
-p_aid	include/rtw_beamforming.h	/^	u16	p_aid;		\/* Used to fill Reg42C & Reg714 to compare with P_AID of Tx DESC. *\/$/;"	m	struct:beamforming_entry
-p_aid	include/rtw_beamforming.h	/^	u16 p_aid;$/;"	m	struct:beamformee_entry
-p_aid	include/rtw_beamforming.h	/^	u16 p_aid;$/;"	m	struct:beamformer_entry
-p_enable_adaptivity	hal/phydm/phydm.h	/^	pu1Byte			p_enable_adaptivity;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-p_enable_antdiv	hal/phydm/phydm.h	/^	pu1Byte			p_enable_antdiv;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pa_bias_5g	include/hal_data.h	/^	s8 pa_bias_5g[RF_PATH_MAX];$/;"	m	struct:kfree_data_t
-packetCount	hal/phydm/phydm_cfotracking.h	/^	u4Byte			packetCount;$/;"	m	struct:_CFO_TRACKING_
-packetCount_pre	hal/phydm/phydm_cfotracking.h	/^	u4Byte			packetCount_pre;$/;"	m	struct:_CFO_TRACKING_
-packet_time	include/ieee80211.h	/^	unsigned long packet_time;$/;"	m	struct:ieee_ibss_seq
-pad_bias_5g	include/hal_data.h	/^	s8 pad_bias_5g[RF_PATH_MAX];$/;"	m	struct:kfree_data_t
-padapter	include/hal_com_led.h	/^	PADAPTER			padapter;$/;"	m	struct:_LED_SDIO
-padapter	include/hal_com_led.h	/^	PADAPTER			padapter;$/;"	m	struct:_LED_USB
-padapter	include/hal_com_led.h	/^	PADAPTER		padapter;$/;"	m	struct:_LED_PCIE
-padapter	include/rtw_cmd.h	/^	_adapter *padapter;$/;"	m	struct:cmd_obj
-padapter	include/rtw_cmd.h	/^	_adapter *padapter;$/;"	m	struct:cmd_priv
-padapter	include/rtw_io.h	/^	_adapter *padapter;$/;"	m	struct:intf_hdl
-padapter	include/rtw_io.h	/^	_adapter *padapter;$/;"	m	struct:io_priv
-padapter	include/rtw_mlme.h	/^	_adapter				*padapter;$/;"	m	struct:wifidirect_info
-padapter	include/rtw_mlme.h	/^	_adapter *padapter;$/;"	m	struct:hostapd_priv
-padapter	include/rtw_mlme_ext.h	/^	_adapter	*padapter;$/;"	m	struct:mlme_ext_priv
-padapter	include/rtw_mp.h	/^	_adapter *padapter;$/;"	m	struct:mp_xmit_frame
-padapter	include/rtw_recv.h	/^	_adapter	*padapter;$/;"	m	struct:recv_reorder_ctrl
-padapter	include/rtw_xmit.h	/^	_adapter *padapter;$/;"	m	struct:xmit_buf
-padapter	include/rtw_xmit.h	/^	_adapter *padapter;$/;"	m	struct:xmit_frame
-padapter	include/sdio_ops.h	/^	unsigned char *padapter;$/;"	m	struct:async_context
-padapter	include/sta_info.h	/^	_adapter *padapter;$/;"	m	struct:sta_info
-padapter	include/sta_info.h	/^	_adapter *padapter;$/;"	m	struct:sta_priv
-padapter	os_dep/linux/ioctl_cfg80211.h	/^	_adapter *padapter;$/;"	m	struct:rtw_wdev_priv
-padapters	include/drv_types.h	/^	_adapter *padapters[CONFIG_IFACE_NUMBER];\/*IFACE_ID_MAX*\/$/;"	m	struct:dvobj_priv
-padding_len	include/rtl8821a_xmit.h	/^	u32 padding_len:11;$/;"	m	struct:txdescriptor_8821a
-page_num	hal/phydm/phydm_hwconfig.h	/^	u1Byte		page_num;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-page_num	hal/phydm/phydm_hwconfig.h	/^	u1Byte		page_num;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-page_num	hal/phydm/phydm_hwconfig.h	/^	u1Byte		page_num;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-paggr	include/rtl8188e_recv.h	/^	u32 paggr:1;$/;"	m	struct:rxreport_8188e
-paid	hal/phydm/phydm_hwconfig.h	/^	u1Byte		paid;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-paid_msb	hal/phydm/phydm_hwconfig.h	/^	u1Byte		paid_msb: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-pairwise_cipher	include/rtw_mlme.h	/^	int pairwise_cipher;$/;"	m	struct:beacon_keys
-pairwise_cipher	include/wlan_bssdef.h	/^	int pairwise_cipher;\/* \/\/WPA\/WPA2\/WEP pairwise cipher *\/$/;"	m	struct:_WLAN_BCN_INFO
-pallocated_buf	include/rtw_mp.h	/^	u8 *pallocated_buf;$/;"	m	struct:mp_tx
-pallocated_buf	include/rtw_recv.h	/^	u8	*pallocated_buf;$/;"	m	struct:recv_buf
-pallocated_buf	include/rtw_xmit.h	/^	u8 *pallocated_buf;$/;"	m	struct:xmit_buf
-pallocated_frame_buf	include/rtw_recv.h	/^	u8 *pallocated_frame_buf;$/;"	m	struct:recv_priv
-pallocated_frame_buf	include/rtw_xmit.h	/^	u8 *pallocated_frame_buf;$/;"	m	struct:xmit_priv
-pallocated_free_ioreqs_buf	include/rtw_io.h	/^	u8	*pallocated_free_ioreqs_buf;$/;"	m	struct:io_queue
-pallocated_mp_xmitframe_buf	include/rtw_mp.h	/^	u8 *pallocated_mp_xmitframe_buf;$/;"	m	struct:mp_priv
-pallocated_recv_buf	include/rtw_recv.h	/^	u8 *pallocated_recv_buf;$/;"	m	struct:recv_priv
-pallocated_stainfo_buf	include/sta_info.h	/^	u8 *pallocated_stainfo_buf;$/;"	m	struct:sta_priv
-pallocated_xmit_extbuf	include/rtw_xmit.h	/^	u8 *pallocated_xmit_extbuf;$/;"	m	struct:xmit_priv
-pallocated_xmitbuf	include/rtw_xmit.h	/^	u8 *pallocated_xmitbuf;$/;"	m	struct:xmit_priv
-pam	include/rtl8188e_recv.h	/^	u32 pam:1;$/;"	m	struct:rxreport_8188e
-pan_exist	hal/btc/HalBtc8192e1Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8192e_1ant
-pan_exist	hal/btc/HalBtc8192e2Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8192e_2ant
-pan_exist	hal/btc/HalBtc8703b1Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8703b_1ant
-pan_exist	hal/btc/HalBtc8723b1Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8723b_1ant
-pan_exist	hal/btc/HalBtc8723b2Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8723b_2ant
-pan_exist	hal/btc/HalBtc8812a1Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8812a_1ant
-pan_exist	hal/btc/HalBtc8812a2Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8812a_2ant
-pan_exist	hal/btc/HalBtc8821a1Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8821a_1ant
-pan_exist	hal/btc/HalBtc8821a2Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8821a_2ant
-pan_exist	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8821a_csr_2ant
-pan_exist	hal/btc/HalBtc8822b1Ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8822b_1ant
-pan_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					pan_exist;$/;"	m	struct:btc_bt_link_info
-pan_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					pan_exist;$/;"	m	struct:btc_stack_info
-pan_exist	hal/btc/halbtc8723d1ant.h	/^	boolean				pan_exist;$/;"	m	struct:coex_sta_8723d_1ant
-pan_exist	hal/btc/halbtc8723d2ant.h	/^	boolean				pan_exist;$/;"	m	struct:coex_sta_8723d_2ant
-pan_exist	hal/btc/halbtc8821c1ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8821c_1ant
-pan_exist	hal/btc/halbtc8821c2ant.h	/^	boolean					pan_exist;$/;"	m	struct:coex_sta_8821c_2ant
-pan_only	hal/btc/HalBtcOutSrc.h	/^	boolean					pan_only;$/;"	m	struct:btc_bt_link_info
-papdater	include/rtw_mp.h	/^	_adapter *papdater;$/;"	m	struct:mp_priv
-paraLength	include/rtw_bt_mp.h	/^	USHORT      paraLength;$/;"	m	struct:_BT_REQ_CMD
-paraLength	include/rtw_bt_mp.h	/^	USHORT      paraLength;$/;"	m	struct:_BT_RSP_CMD
-para_file_buf	include/hal_data.h	/^	char	para_file_buf[MAX_PARA_FILE_BUF_LEN];$/;"	m	struct:hal_com_data
-para_idx	hal/phydm/phydm_rainfo.h	/^	u1Byte   para_idx;$/;"	m	struct:_Rate_Adaptive_Table_
-param	include/rtw_mp.h	/^	struct mp_wiparam param;$/;"	m	struct:mp_wi_cntx	typeref:struct:mp_wi_cntx::mp_wiparam
-params	include/ieee80211_ext.h	/^					u16 params;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon38
-params	include/ieee80211_ext.h	/^					u16 params;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon23
-paramsize	include/rtw_mp_ioctl.h	/^	u32 paramsize;$/;"	m	struct:mp_ioctl_handler
-parmbuf	include/rtw_cmd.h	/^	u8	*parmbuf;$/;"	m	struct:cmd_obj
-parmbuf	include/rtw_cmd.h	/^	u8	*parmbuf;$/;"	m	struct:evt_obj
-parmsize	include/rtw_event.h	/^	u32	parmsize;$/;"	m	struct:fwevent
-parmsize	include/rtw_mlme_ext.h	/^	uint	parmsize;$/;"	m	struct:cmd_hdl
-parse_routes	os_dep/linux/os_intfs.c	/^static void parse_routes(struct nlmsghdr *nl_hdr, struct route_info *rt_info)$/;"	f	file:
-passoc_req	include/sta_info.h	/^	u8 *passoc_req;$/;"	m	struct:sta_info
-path	core/rtw_io.c	/^	u8 path;$/;"	m	struct:rf_sniff_ent	file:
-path	include/rtw_mp.h	/^	u32 path;$/;"	m	struct:rf_reg_param
-pathIQK	hal/phydm/phydm.h	/^	PATHDIV_PARA	pathIQK;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-path_a_cnt_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_a_cnt_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_a_sum_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_a_sum_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_agc	hal/phydm/phydm_hwconfig.h	/^	PHY_RX_AGC_INFO_T path_agc[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-path_b_cnt_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_b_cnt_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_b_sum_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_b_sum_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_c_cnt_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_c_cnt_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_c_sum_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_c_sum_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_cfotail	hal/phydm/phydm_hwconfig.h	/^	s1Byte	path_cfotail[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-path_d_cnt_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_d_cnt_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_d_sum_all	hal/phydm/phydm_pathdiv.h	/^	u4Byte	path_d_sum_all;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_div_type	hal/phydm/phydm_pathdiv.h	/^	u1Byte	path_div_type;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-path_div_type	hal/phydm/phydm_pathdiv.h	/^typedef enum path_div_type$/;"	g
-path_rxsnr	hal/phydm/phydm_hwconfig.h	/^	u1Byte	path_rxsnr[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-path_select	hal/phydm/phydm.h	/^	u1Byte			path_select;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pattern_match	include/rtl8188e_recv.h	/^	u32 pattern_match:1;$/;"	m	struct:rxreport_8188e
-pattern_type	include/rtw_pwrctrl.h	/^enum pattern_type {$/;"	g
-patterns	include/rtw_pwrctrl.h	/^	struct rtl_priv_pattern	patterns[MAX_WKFM_NUM];$/;"	m	struct:pwrctrl_priv	typeref:struct:pwrctrl_priv::rtl_priv_pattern
-pause_cckpd_level	hal/phydm/phydm_dig.h	/^	u1Byte		pause_cckpd_level;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-pause_cckpd_value	hal/phydm/phydm_dig.h	/^	u1Byte		pause_cckpd_value[DM_DIG_MAX_PAUSE_TYPE + 1];$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-pause_dig_level	hal/phydm/phydm_dig.h	/^	u1Byte		pause_dig_level;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-pause_dig_value	hal/phydm/phydm_dig.h	/^	u1Byte		pause_dig_value[DM_DIG_MAX_PAUSE_TYPE + 1];$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-payload	include/rtw_mp.h	/^	u8 payload;$/;"	m	struct:mp_tx
-payload_size	include/ieee80211.h	/^	u16 payload_size;$/;"	m	struct:ieee80211_txb
-payload_type	include/rtw_mp_ioctl.h	/^	u8 payload_type;$/;"	m	struct:_mp_xmit_parm_
-pbDriverIsGoingToPnpSetPowerSleep	hal/phydm/phydm.h	/^	BOOLEAN			*pbDriverIsGoingToPnpSetPowerSleep;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbDriverStopped	hal/phydm/phydm.h	/^	BOOLEAN			*pbDriverStopped;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbFwDwRsvdPageInProgress	hal/phydm/phydm.h	/^	BOOLEAN			*pbFwDwRsvdPageInProgress;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbGetValueFromOtherMac	hal/phydm/phydm.h	/^	BOOLEAN			*pbGetValueFromOtherMac;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbMasterOfDMSP	hal/phydm/phydm.h	/^	BOOLEAN			*pbMasterOfDMSP; \/\/MAC0: master, MAC1: slave$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbNet_closed	hal/phydm/phydm.h	/^	BOOLEAN			*pbNet_closed;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbPowerSaving	hal/phydm/phydm.h	/^	BOOLEAN			*pbPowerSaving;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbScanInProcess	hal/phydm/phydm.h	/^	BOOLEAN			*pbScanInProcess;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pbtcoexadapter	core/rtw_btcoex.c	/^_adapter *pbtcoexadapter; \/* = NULL; *\/ \/* do not initialise globals to 0 or NULL *\/$/;"	v
-pbuf	include/rtw_cmd.h	/^	unsigned char *pbuf;$/;"	m	struct:drvextra_cmd_parm
-pbuf	include/rtw_io.h	/^	u8	*pbuf;$/;"	m	struct:io_req
-pbuf	include/rtw_recv.h	/^	u8	*pbuf;$/;"	m	struct:recv_buf
-pbuf	include/rtw_xmit.h	/^	u8 *pbuf;$/;"	m	struct:xmit_buf
-pbytecnt_mdl	include/rtw_recv.h	/^	PMDL	pbytecnt_mdl;$/;"	m	struct:recv_priv
-pc2h_mdl	include/rtw_cmd.h	/^	PMDL	pc2h_mdl;$/;"	m	struct:evt_priv
-pci_base_addr	include/drv_types.h	/^	unsigned long	pci_base_addr;	\/* device I\/O address	*\/$/;"	m	struct:dvobj_priv
-pci_bridge_vendor	include/drv_types_pci.h	/^enum pci_bridge_vendor {$/;"	g
-pci_clk_req	include/drv_types_pci.h	/^	BOOLEAN		pci_clk_req;$/;"	m	struct:pci_priv
-pci_mem_end	include/drv_types.h	/^	unsigned long	pci_mem_end;	\/* shared mem end	*\/$/;"	m	struct:dvobj_priv
-pci_mem_start	include/drv_types.h	/^	unsigned long	pci_mem_start;	\/* shared mem start	*\/$/;"	m	struct:dvobj_priv
-pci_priv	include/drv_types_pci.h	/^struct pci_priv {$/;"	s
-pcibridge_busnum	include/drv_types_pci.h	/^	u8	pcibridge_busnum;$/;"	m	struct:pci_priv
-pcibridge_deviceid	include/drv_types_pci.h	/^	u16	pcibridge_deviceid;$/;"	m	struct:pci_priv
-pcibridge_devnum	include/drv_types_pci.h	/^	u8	pcibridge_devnum;$/;"	m	struct:pci_priv
-pcibridge_funcnum	include/drv_types_pci.h	/^	u8	pcibridge_funcnum;$/;"	m	struct:pci_priv
-pcibridge_linkctrlreg	include/drv_types_pci.h	/^	u8	pcibridge_linkctrlreg;$/;"	m	struct:pci_priv
-pcibridge_pciehdr_offset	include/drv_types_pci.h	/^	u8	pcibridge_pciehdr_offset;$/;"	m	struct:pci_priv
-pcibridge_vendor	include/drv_types_pci.h	/^	u8	pcibridge_vendor;$/;"	m	struct:pci_priv
-pcibridge_vendorid	include/drv_types_pci.h	/^	u16	pcibridge_vendorid;$/;"	m	struct:pci_priv
-pcie_cap	include/drv_types_pci.h	/^	u8	pcie_cap;$/;"	m	struct:pci_priv
-pciehdr_offset	include/drv_types_pci.h	/^	u8	pciehdr_offset;$/;"	m	struct:pci_priv
-pcipriv	include/drv_types.h	/^	struct pci_priv	pcipriv;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::pci_priv
-pcmd_xmitbuf	include/rtw_xmit.h	/^	struct xmit_buf	pcmd_xmitbuf[CMDBUF_MAX];$/;"	m	struct:xmit_priv	typeref:struct:xmit_priv::xmit_buf
-pconfig_descriptor	include/drv_types.h	/^	PUSB_CONFIGURATION_DESCRIPTOR	pconfig_descriptor;\/* UsbConfigurationDescriptor; *\/$/;"	m	struct:dvobj_priv
-pctrl	include/rtw_xmit.h	/^	u8	pctrl;\/* per packet txdesc control enable *\/$/;"	m	struct:pkt_attrib
-pcts_en	include/rtl8821a_xmit.h	/^	u32 pcts_en:1;$/;"	m	struct:txdescriptor_8821a
-pcts_mask	hal/phydm/phydm_hwconfig.h	/^	u1Byte	pcts_mask[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-pcts_mask_idx	include/rtl8821a_xmit.h	/^	u32 pcts_mask_idx:2;$/;"	m	struct:txdescriptor_8821a
-pcts_rpt_valid	hal/phydm/phydm_hwconfig.h	/^	u1Byte			pcts_rpt_valid: 1;							\/*pcts_rpt_valid*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-pcts_rpt_valid	hal/phydm/phydm_hwconfig.h	/^	u1Byte			pcts_rpt_valid: 1;$/;"	m	struct:_Phy_Status_Rpt_8812
-pd_wdev	os_dep/linux/ioctl_cfg80211.h	/^	struct wireless_dev *pd_wdev; \/* P2P device wdev *\/$/;"	m	struct:rtw_wiphy_data	typeref:struct:rtw_wiphy_data::wireless_dev
-pdata	include/rtw_recv.h	/^	u8	*pdata;$/;"	m	struct:recv_buf
-pdata	include/rtw_xmit.h	/^	u8 *pdata;$/;"	m	struct:xmit_buf
-peak	os_dep/osdep_service.c	/^	ATOMIC_T peak; \/* the peak memory bytes we allocate *\/$/;"	m	struct:rtw_mem_stat	file:
-peeked	include/osdep_service_bsd.h	/^				peeked:1,$/;"	m	struct:sk_buff
-peer	include/rtw_mlme.h	/^	u8 peer[ETH_ALEN];$/;"	m	struct:tdls_txmgmt
-peerDevAddr	include/rtw_mlme.h	/^	u8					peerDevAddr[ETH_ALEN];		\/*	Peer device address *\/$/;"	m	struct:rx_provdisc_req_info
-peerDevAddr	include/rtw_mlme.h	/^	u8					peerDevAddr[ETH_ALEN];		\/*	Peer device address *\/$/;"	m	struct:tx_nego_req_info
-peerDevAddr	include/rtw_mlme.h	/^	u8					peerDevAddr[ETH_ALEN];		\/*	Peer device address *\/$/;"	m	struct:tx_provdisc_req_info
-peerIFAddr	include/rtw_mlme.h	/^	u8					peerIFAddr[ETH_ALEN];		\/*	Peer interface address *\/$/;"	m	struct:tx_provdisc_req_info
-peer_addr	include/rtw_mlme.h	/^	u8	peer_addr[ETH_ALEN];$/;"	m	struct:tdls_temp_mgmt
-peer_ch	include/rtw_mlme.h	/^	u8					peer_ch;					\/*	The listen channel for peer P2P device *\/$/;"	m	struct:tx_nego_req_info
-peer_ch	include/rtw_mlme.h	/^	u8					peer_ch;		\/*	The listen channel for peer P2P device *\/$/;"	m	struct:tx_invite_req_info
-peer_channel_num	include/rtw_mlme.h	/^	u16					peer_channel_num[2];		\/*	The channel number which the receiver stands. *\/$/;"	m	struct:tx_nego_req_info
-peer_channel_num	include/rtw_mlme.h	/^	u16					peer_channel_num[2];		\/*	The channel number which the receiver stands. *\/$/;"	m	struct:tx_provdisc_req_info
-peer_iface_addr	os_dep/linux/ioctl_cfg80211.h	/^	u8 peer_iface_addr[ETH_ALEN];$/;"	m	struct:rtw_wdev_nego_info
-peer_intent	include/rtw_mlme.h	/^	u8						peer_intent;	\/*	Included the intent value and tie breaker value. *\/$/;"	m	struct:wifidirect_info
-peer_ip_address	include/rtw_mlme.h	/^	u8							peer_ip_address[4];$/;"	m	struct:wifi_display_info
-peer_mac	os_dep/linux/ioctl_cfg80211.h	/^	u8 peer_mac[ETH_ALEN];$/;"	m	struct:rtw_wdev_invit_info
-peer_mac	os_dep/linux/ioctl_cfg80211.h	/^	u8 peer_mac[ETH_ALEN];$/;"	m	struct:rtw_wdev_nego_info
-peer_macaddr	include/rtw_mlme.h	/^	u8					peer_macaddr[ETH_ALEN];$/;"	m	struct:tx_invite_req_info
-peer_operating_ch	include/rtw_mlme.h	/^	u8						peer_operating_ch;$/;"	m	struct:wifidirect_info
-peer_rtsp_ctrlport	include/rtw_mlme.h	/^	u16							peer_rtsp_ctrlport;	\/*	TCP port number at which the peer WFD device listens for RTSP messages *\/$/;"	m	struct:wifi_display_info
-peer_session_avail	include/rtw_mlme.h	/^	u8							peer_session_avail;	\/*	WFD session is available or not for the peer wfd device. *\/$/;"	m	struct:wifi_display_info
-peermac	include/rtw_mlme.h	/^	u8	peermac[ETH_ALEN];$/;"	m	struct:profile_info
-pend	include/rtw_recv.h	/^	u8	*pend;$/;"	m	struct:recv_buf
-pend	include/rtw_xmit.h	/^	u8 *pend;$/;"	m	struct:xmit_buf
-pending	include/rtw_io.h	/^	_list		pending;		\/* The io_req list that will be served in the single protocol read\/write.	 *\/$/;"	m	struct:io_queue
-pending_recvframe_queue	include/rtw_recv.h	/^	_queue pending_recvframe_queue;$/;"	m	struct:recv_reorder_ctrl
-pending_xmitbuf_queue	include/rtw_xmit.h	/^	_queue pending_xmitbuf_queue;$/;"	m	struct:xmit_priv
-per_beam_training_pkt_num	hal/phydm/phydm_antdiv.h	/^	u1Byte	per_beam_training_pkt_num;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-per_rate_retrylimit_20M	hal/phydm/phydm_rainfo.h	/^	u1Byte per_rate_retrylimit_20M[ODM_NUM_RATE_IDX];$/;"	m	struct:_Rate_Adaptive_Table_
-per_rate_retrylimit_40M	hal/phydm/phydm_rainfo.h	/^	u1Byte per_rate_retrylimit_40M[ODM_NUM_RATE_IDX];	$/;"	m	struct:_Rate_Adaptive_Table_
-periodScan	include/rtw_pwrctrl.h	/^	u8	periodScan;			\/* exclusive with fast_scan_period and slow_scan_period *\/$/;"	m	struct:pno_scan_info
-period_scan_time	include/rtw_pwrctrl.h	/^	u8	period_scan_time;		\/* exclusive with fast_scan_period and slow_scan_period *\/$/;"	m	struct:pno_scan_info
-persistent_supported	include/rtw_mlme.h	/^	u8						persistent_supported;		\/*	Flag to know the persistent function should be supported or not. *\/$/;"	m	struct:wifidirect_info
-pfuncdevobj	include/drv_types.h	/^	PDEVICE_OBJECT	pfuncdevobj;\/* pFuncDevObj; *\/$/;"	m	struct:dvobj_priv
-pfuncdevobj	include/drv_types_sdio.h	/^	PDEVICE_OBJECT				pfuncdevobj;$/;"	m	struct:sdio_data
-pg_ant_num	hal/btc/HalBtcOutSrc.h	/^	u8				pg_ant_num;	\/* pg ant number *\/$/;"	m	struct:btc_board_info
-pg_num	include/rtw_xmit.h	/^	u8	pg_num;$/;"	m	struct:xmit_buf
-pg_num	include/rtw_xmit.h	/^	u8	pg_num;$/;"	m	struct:xmit_frame
-pg_txpwr_def_info	hal/hal_com_phycfg.c	/^const struct map_t pg_txpwr_def_info =$/;"	v	typeref:struct:map_t
-pg_txpwr_src_str	hal/hal_com_phycfg.c	54;"	d	file:
-phase1	core/rtw_security.c	/^static void phase1(u16 *p1k, const u8 *tk, const u8 *ta, u32 iv32)$/;"	f	file:
-phase2	core/rtw_security.c	/^static void phase2(u8 *rc4key, const u8 *tk, const u16 *p1k, u16 iv16)$/;"	f	file:
-phead	include/rtw_recv.h	/^	u8	*phead;$/;"	m	struct:recv_buf
-phead	include/rtw_xmit.h	/^	u8 *phead;$/;"	m	struct:xmit_buf
-phostapdpriv	include/drv_types.h	/^	struct	hostapd_priv	*phostapdpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::hostapd_priv
-phy_APCalibrate_8192C	hal/phydm/halphyrf_ap.c	/^phy_APCalibrate_8192C($/;"	f
-phy_APCalibrate_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_APCalibrate_8723D($/;"	f
-phy_BB8723d_Config_ParaFile	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_BB8723d_Config_ParaFile($/;"	f	file:
-phy_CalculateBitShift	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_CalculateBitShift($/;"	f	file:
-phy_ConfigBBWithMpParaFile	hal/hal_com_phycfg.c	/^phy_ConfigBBWithMpParaFile($/;"	f
-phy_ConfigBBWithParaFile	hal/hal_com_phycfg.c	/^phy_ConfigBBWithParaFile($/;"	f
-phy_ConfigBBWithPgParaFile	hal/hal_com_phycfg.c	/^phy_ConfigBBWithPgParaFile($/;"	f
-phy_ConfigMACWithParaFile	hal/hal_com_phycfg.c	/^phy_ConfigMACWithParaFile($/;"	f
-phy_ConvertTxPowerByRateInDbmToRelativeValues	hal/hal_com_phycfg.c	/^phy_ConvertTxPowerByRateInDbmToRelativeValues($/;"	f
-phy_CrossReferenceHTAndVHTTxPowerLimit	hal/hal_com_phycfg.c	/^phy_CrossReferenceHTAndVHTTxPowerLimit($/;"	f
-phy_DecryptBBPgParaFile	hal/hal_com_phycfg.c	/^phy_DecryptBBPgParaFile($/;"	f
-phy_DigitalPredistortion_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_DigitalPredistortion_8723D($/;"	f
-phy_FwRFSerialRead	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_FwRFSerialRead($/;"	f	file:
-phy_FwRFSerialWrite	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_FwRFSerialWrite($/;"	f	file:
-phy_GetChannelIndexOfTxPowerLimit	hal/hal_com_phycfg.c	/^phy_GetChannelIndexOfTxPowerLimit($/;"	f
-phy_GetChnlIndex	hal/hal_com_phycfg.c	/^phy_GetChnlIndex($/;"	f
-phy_GetCurrentTxNum_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_GetCurrentTxNum_8723D($/;"	f
-phy_GetSecondaryChnl_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_GetSecondaryChnl_8723D($/;"	f
-phy_GetWorldWideLimit	hal/hal_com_phycfg.c	/^phy_GetWorldWideLimit($/;"	f
-phy_IQCalibrate_8192C	hal/phydm/halphyrf_ap.c	/^phy_IQCalibrate_8192C($/;"	f
-phy_IQCalibrate_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_IQCalibrate_8723D($/;"	f
-phy_InitBBRFRegisterDefinition	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_InitBBRFRegisterDefinition($/;"	f	file:
-phy_LCCalibrate	hal/phydm/halphyrf_ap.c	/^phy_LCCalibrate($/;"	f
-phy_LCCalibrate92C	hal/phydm/halphyrf_ap.c	/^phy_LCCalibrate92C($/;"	f
-phy_LCCalibrate_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_LCCalibrate_8723D($/;"	f
-phy_ParseBBPgParaFile	hal/hal_com_phycfg.c	/^phy_ParseBBPgParaFile($/;"	f
-phy_ParsePowerLimitTableFile	hal/hal_com_phycfg.c	/^phy_ParsePowerLimitTableFile($/;"	f
-phy_PathAFillIQKMatrix	hal/phydm/halphyrf_ap.c	/^phy_PathAFillIQKMatrix($/;"	f
-phy_PathAStandBy	hal/phydm/halphyrf_ap.c	/^phy_PathAStandBy($/;"	f
-phy_PathA_IQK_8192C	hal/phydm/halphyrf_ap.c	/^phy_PathA_IQK_8192C($/;"	f
-phy_PathBFillIQKMatrix	hal/phydm/halphyrf_ap.c	/^phy_PathBFillIQKMatrix($/;"	f
-phy_PathB_IQK_8192C	hal/phydm/halphyrf_ap.c	/^phy_PathB_IQK_8192C($/;"	f
-phy_PathS0_IQK_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_PathS0_IQK_8723D($/;"	f
-phy_PathS0_RxIQK_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_PathS0_RxIQK_8723D($/;"	f
-phy_PathS1_IQK_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_PathS1_IQK_8723D($/;"	f
-phy_PathS1_RxIQK_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_PathS1_RxIQK_8723D($/;"	f
-phy_PostSetBwMode8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_PostSetBwMode8723D($/;"	f
-phy_QueryRFPathSwitch_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^BOOLEAN phy_QueryRFPathSwitch_8723D($/;"	f
-phy_RF6052_Config_HardCode	hal/rtl8723d/rtl8723d_rf6052.c	/^phy_RF6052_Config_HardCode($/;"	f	file:
-phy_RF6052_Config_ParaFile	hal/rtl8723d/rtl8723d_rf6052.c	/^phy_RF6052_Config_ParaFile($/;"	f	file:
-phy_RFSerialRead_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_RFSerialRead_8723D($/;"	f	file:
-phy_RFSerialWrite_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_RFSerialWrite_8723D($/;"	f	file:
-phy_SetRFPathSwitch_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^VOID phy_SetRFPathSwitch_8723D($/;"	f
-phy_SetRegBW_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_SetRegBW_8723D($/;"	f
-phy_SetTxPowerByRateBase	hal/hal_com_phycfg.c	/^phy_SetTxPowerByRateBase($/;"	f
-phy_SimularityCompare	hal/phydm/halphyrf_ap.c	/^phy_SimularityCompare($/;"	f
-phy_SimularityCompare_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^phy_SimularityCompare_8723D($/;"	f
-phy_SimularityCompare_92C	hal/phydm/halphyrf_ap.c	/^phy_SimularityCompare_92C($/;"	f
-phy_SpurCalibration_8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_SpurCalibration_8723D($/;"	f
-phy_StoreTxPowerByRateBase	hal/hal_com_phycfg.c	/^phy_StoreTxPowerByRateBase($/;"	f
-phy_SwChnl8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_SwChnl8723D($/;"	f
-phy_SwChnlAndSetBwMode8723D	hal/rtl8723d/rtl8723d_phycfg.c	/^phy_SwChnlAndSetBwMode8723D($/;"	f
-phy_dm_ary	hal/phydm/phydm_debug.c	/^struct _PHYDM_COMMAND phy_dm_ary[] = {$/;"	v	typeref:struct:_PHYDM_COMMAND
-phy_free_filebuf	hal/hal_com_phycfg.c	/^inline void phy_free_filebuf(_adapter *padapter)$/;"	f
-phy_free_filebuf_mask	hal/hal_com_phycfg.c	/^void phy_free_filebuf_mask(_adapter *padapter, u8 mask)$/;"	f
-phy_info	include/rtw_recv.h	/^	struct phy_info phy_info;$/;"	m	struct:rx_pkt_attrib	typeref:struct:rx_pkt_attrib::phy_info
-phy_info	include/rtw_recv.h	/^struct phy_info {$/;"	s
-phy_is_tx_power_by_rate_needed	hal/hal_com_phycfg.c	/^bool phy_is_tx_power_by_rate_needed(_adapter *adapter)$/;"	f
-phy_is_tx_power_limit_needed	hal/hal_com_phycfg.c	/^bool phy_is_tx_power_limit_needed(_adapter *adapter)$/;"	f
-phy_is_txpwr_by_rate_undefined_of_band_path	hal/hal_com_phycfg.c	/^static inline BOOLEAN phy_is_txpwr_by_rate_undefined_of_band_path(_adapter *adapter, u8 band, u8 path)$/;"	f	file:
-phy_load_tx_power_by_rate	hal/hal_com_phycfg.c	/^int phy_load_tx_power_by_rate(_adapter *adapter, u8 chk_file)$/;"	f
-phy_load_tx_power_ext_info	hal/hal_com_phycfg.c	/^void phy_load_tx_power_ext_info(_adapter *adapter, u8 chk_file)$/;"	f
-phy_load_tx_power_limit	hal/hal_com_phycfg.c	/^int phy_load_tx_power_limit(_adapter *adapter, u8 chk_file)$/;"	f
-phy_reload_default_tx_power_ext_info	hal/hal_com_phycfg.c	/^inline void phy_reload_default_tx_power_ext_info(_adapter *adapter)$/;"	f
-phy_reload_tx_power_ext_info	hal/hal_com_phycfg.c	/^inline void phy_reload_tx_power_ext_info(_adapter *adapter)$/;"	f
-phy_txpwr_by_rate_chk_for_path_dup	hal/hal_com_phycfg.c	/^static void phy_txpwr_by_rate_chk_for_path_dup(_adapter *adapter)$/;"	f	file:
-phy_txpwr_by_rate_duplicate_band_path	hal/hal_com_phycfg.c	/^static inline void phy_txpwr_by_rate_duplicate_band_path(_adapter *adapter, u8 band, u8 s_path, u8 t_path)$/;"	f	file:
-phydm_8822b_sutxbfer_workaroud	hal/phydm/txbf/haltxbf8822b.c	/^phydm_8822b_sutxbfer_workaroud($/;"	f
-phydm_8822b_sutxbfer_workaroud	hal/phydm/txbf/haltxbf8822b.h	74;"	d
-phydm_8822btxbf_rfmode	hal/phydm/txbf/haltxbf8822b.c	/^phydm_8822btxbf_rfmode($/;"	f
-phydm_8822btxbf_rfmode	hal/phydm/txbf/haltxbf8822b.h	73;"	d
-phydm_AutoChannelSelectSettingAP	hal/phydm/phydm_acs.c	/^phydm_AutoChannelSelectSettingAP($/;"	f
-phydm_BB_Debug_Info	hal/phydm/phydm_debug.c	/^phydm_BB_Debug_Info($/;"	f
-phydm_BB_RxHang_Info	hal/phydm/phydm_debug.c	/^phydm_BB_RxHang_Info($/;"	f
-phydm_BasicDbgMessage	hal/phydm/phydm_debug.c	/^phydm_BasicDbgMessage$/;"	f
-phydm_BasicProfile	hal/phydm/phydm_debug.c	/^VOID phydm_BasicProfile($/;"	f
-phydm_BeamformingControl_V2	hal/phydm/phydm_beamforming.c	/^phydm_BeamformingControl_V2($/;"	f
-phydm_BeamformingControl_V2	hal/phydm/phydm_beamforming.h	361;"	d
-phydm_Beamforming_DymNDPARate	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_DymNDPARate($/;"	f
-phydm_Beamforming_End_SW	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_End_SW($/;"	f
-phydm_Beamforming_End_SW	hal/phydm/phydm_beamforming.h	358;"	d
-phydm_Beamforming_GetBFeeEntryByAddr	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetBFeeEntryByAddr($/;"	f
-phydm_Beamforming_GetBFerEntryByAddr	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetBFerEntryByAddr($/;"	f
-phydm_Beamforming_GetBeamCap	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetBeamCap($/;"	f
-phydm_Beamforming_GetEntryBeamCapByMacId	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetEntryBeamCapByMacId($/;"	f
-phydm_Beamforming_GetEntryByMacId	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetEntryByMacId($/;"	f
-phydm_Beamforming_GetFirstMUBFeeEntryIdx	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetFirstMUBFeeEntryIdx($/;"	f
-phydm_Beamforming_GetFreeBFeeEntry	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetFreeBFeeEntry($/;"	f
-phydm_Beamforming_GetFreeBFerEntry	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_GetFreeBFerEntry($/;"	f
-phydm_Beamforming_Init	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_Init($/;"	f
-phydm_Beamforming_Init	hal/phydm/phydm_beamforming.h	360;"	d
-phydm_Beamforming_NDPARate	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_NDPARate($/;"	f
-phydm_Beamforming_Notify	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_Notify($/;"	f
-phydm_Beamforming_SelectBeamEntry	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_SelectBeamEntry($/;"	f
-phydm_Beamforming_Watchdog	hal/phydm/phydm_beamforming.c	/^phydm_Beamforming_Watchdog($/;"	f
-phydm_Beamforming_Watchdog	hal/phydm/phydm_beamforming.h	363;"	d
-phydm_CLMsetting	hal/phydm/phydm_ccx.c	/^phydm_CLMsetting($/;"	f
-phydm_CLMtrigger	hal/phydm/phydm_ccx.c	/^phydm_CLMtrigger($/;"	f
-phydm_ConfigKFree	hal/phydm/phydm_kfree.c	/^phydm_ConfigKFree($/;"	f
-phydm_DIG_GoUpCheck	hal/phydm/phydm_dig.c	/^phydm_DIG_GoUpCheck($/;"	f
-phydm_DataRate_8814A	hal/phydm/txbf/haltxbf8814a.c	/^phydm_DataRate_8814A($/;"	f
-phydm_DumpAllReg	hal/phydm/phydm_debug.c	/^phydm_DumpAllReg($/;"	f
-phydm_DumpBbReg	hal/phydm/phydm_debug.c	/^phydm_DumpBbReg($/;"	f
-phydm_EnableBigJump	hal/phydm/phydm_debug.c	/^phydm_EnableBigJump($/;"	f
-phydm_FastTraining_enable	hal/phydm/phydm_antdiv.c	/^phydm_FastTraining_enable($/;"	f
-phydm_FindMinimumRSSI	hal/phydm/phydm_rainfo.c	/^phydm_FindMinimumRSSI($/;"	f
-phydm_GetNHMStatisticsAP	hal/phydm/phydm_acs.c	/^phydm_GetNHMStatisticsAP($/;"	f
-phydm_GetRxPhyStatusType0	hal/phydm/phydm_hwconfig.c	/^phydm_GetRxPhyStatusType0($/;"	f
-phydm_GetRxPhyStatusType1	hal/phydm/phydm_hwconfig.c	/^phydm_GetRxPhyStatusType1($/;"	f
-phydm_GetRxPhyStatusType2	hal/phydm/phydm_hwconfig.c	/^phydm_GetRxPhyStatusType2($/;"	f
-phydm_GetRxPhyStatusType5	hal/phydm/phydm_hwconfig.c	/^phydm_GetRxPhyStatusType5($/;"	f
-phydm_Init_cck_setting	hal/phydm/phydm.c	/^phydm_Init_cck_setting($/;"	f
-phydm_IsBtEnable_8723b	hal/phydm/phydm_antdiv.c	/^phydm_IsBtEnable_8723b($/;"	f
-phydm_NHMsetting	hal/phydm/phydm_ccx.c	/^phydm_NHMsetting($/;"	f
-phydm_NHMtrigger	hal/phydm/phydm_ccx.c	/^phydm_NHMtrigger($/;"	f
-phydm_NoisyDetection	hal/phydm/phydm.c	/^phydm_NoisyDetection($/;"	f
-phydm_Process_RSSIForDMNewType	hal/phydm/phydm_hwconfig.c	/^phydm_Process_RSSIForDMNewType(	$/;"	f
-phydm_RA_debug_PCR	hal/phydm/phydm_rainfo.c	/^phydm_RA_debug_PCR($/;"	f
-phydm_RA_level_decision	hal/phydm/phydm_rainfo.c	/^phydm_RA_level_decision($/;"	f
-phydm_ResetPhyInfo	hal/phydm/phydm_hwconfig.c	/^phydm_ResetPhyInfo($/;"	f
-phydm_RxPhyStatusNewType	hal/phydm/phydm_hwconfig.c	/^phydm_RxPhyStatusNewType($/;"	f
-phydm_SetCommonPhyInfo	hal/phydm/phydm_hwconfig.c	/^phydm_SetCommonPhyInfo($/;"	f
-phydm_SetKfreeToRF	hal/phydm/phydm_kfree.c	/^phydm_SetKfreeToRF($/;"	f
-phydm_SetKfreeToRF_8814A	hal/phydm/phydm_kfree.c	/^phydm_SetKfreeToRF_8814A($/;"	f
-phydm_SetPerPathPhyInfo	hal/phydm/phydm_hwconfig.c	/^phydm_SetPerPathPhyInfo($/;"	f
-phydm_SwAntennaSwitchTimer	hal/phydm/phydm_antdiv.h	/^	RT_TIMER	phydm_SwAntennaSwitchTimer;$/;"	m	struct:_SW_Antenna_Switch_
-phydm_SwAntennaSwitchWorkitem	hal/phydm/phydm_antdiv.h	/^	RT_WORK_ITEM	phydm_SwAntennaSwitchWorkitem;	$/;"	m	struct:_SW_Antenna_Switch_
-phydm_UpdateHalRAMask	hal/phydm/phydm_rainfo.c	/^phydm_UpdateHalRAMask($/;"	f
-phydm_actingDetermine	hal/phydm/phydm_beamforming.c	/^phydm_actingDetermine($/;"	f
-phydm_actingDetermine	hal/phydm/phydm_beamforming.h	352;"	d
-phydm_adaptivityInfoInit	hal/phydm/phydm_adaptivity.c	/^phydm_adaptivityInfoInit($/;"	f
-phydm_antdiv_debug	hal/phydm/phydm_antdiv.c	/^phydm_antdiv_debug($/;"	f
-phydm_api_debug	hal/phydm/phydm.c	/^phydm_api_debug($/;"	f
-phydm_api_get_txagc	hal/phydm/phydm_debug.c	/^phydm_api_get_txagc($/;"	f
-phydm_api_set_txagc	hal/phydm/phydm_debug.c	/^phydm_api_set_txagc($/;"	f
-phydm_api_switch_bw_channel	hal/phydm/phydm_debug.c	/^phydm_api_switch_bw_channel($/;"	f
-phydm_api_trx_mode	hal/phydm/phydm_debug.c	/^phydm_api_trx_mode($/;"	f
-phydm_beam_decision_workitem_callback	hal/phydm/phydm_antdiv.c	/^phydm_beam_decision_workitem_callback($/;"	f
-phydm_beam_switch_workitem_callback	hal/phydm/phydm_antdiv.c	/^phydm_beam_switch_workitem_callback($/;"	f
-phydm_beamfomring_bSounding	hal/phydm/phydm_beamforming.c	/^phydm_beamfomring_bSounding($/;"	f
-phydm_beamformSetGetTxRate	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetGetTxRate($/;"	f
-phydm_beamformSetResetTxPath	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetResetTxPath($/;"	f
-phydm_beamformSetSoundingClk	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetSoundingClk($/;"	f
-phydm_beamformSetSoundingEnter	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetSoundingEnter($/;"	f
-phydm_beamformSetSoundingFwNdpa	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetSoundingFwNdpa($/;"	f
-phydm_beamformSetSoundingLeave	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetSoundingLeave($/;"	f
-phydm_beamformSetSoundingRate	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetSoundingRate($/;"	f
-phydm_beamformSetSoundingStatus	hal/phydm/txbf/halcomtxbf.c	/^phydm_beamformSetSoundingStatus($/;"	f
-phydm_beamforming_ClearEntry_FW	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_ClearEntry_FW($/;"	f
-phydm_beamforming_ClearEntry_SW	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_ClearEntry_SW($/;"	f
-phydm_beamforming_EndPeriod_FW	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_EndPeriod_FW($/;"	f
-phydm_beamforming_EndPeriod_SW	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_EndPeriod_SW($/;"	f
-phydm_beamforming_SoundingBW	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_SoundingBW($/;"	f
-phydm_beamforming_SoundingIdx	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_SoundingIdx($/;"	f
-phydm_beamforming_SoundingMode	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_SoundingMode($/;"	f
-phydm_beamforming_SoundingTime	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_SoundingTime($/;"	f
-phydm_beamforming_StartPeriod	hal/phydm/phydm_beamforming.c	/^phydm_beamforming_StartPeriod($/;"	f
-phydm_c2H_content_parsing	hal/phydm/phydm_interface.c	/^phydm_c2H_content_parsing($/;"	f
-phydm_c2h_dtp_handler	hal/phydm/phydm_pathdiv.c	/^phydm_c2h_dtp_handler($/;"	f
-phydm_c2h_ra_report_handler	hal/phydm/phydm_rainfo.c	/^phydm_c2h_ra_report_handler($/;"	f
-phydm_calculate_fc	hal/phydm/phydm.c	/^phydm_calculate_fc($/;"	f
-phydm_calculate_intf_distance	hal/phydm/phydm.c	/^phydm_calculate_intf_distance($/;"	f
-phydm_candidate_dtp_update	hal/phydm/phydm_pathdiv.c	/^phydm_candidate_dtp_update($/;"	f
-phydm_checkCLMready	hal/phydm/phydm_ccx.c	/^phydm_checkCLMready($/;"	f
-phydm_checkNHMready	hal/phydm/phydm_ccx.c	/^phydm_checkNHMready($/;"	f
-phydm_clean_all_csi_mask	hal/phydm/phydm.c	/^phydm_clean_all_csi_mask($/;"	f
-phydm_cmd	hal/phydm/phydm_debug.c	/^phydm_cmd($/;"	f
-phydm_cmd_parser	hal/phydm/phydm_debug.c	/^phydm_cmd_parser($/;"	f
-phydm_config_cck_rx_antenna_init	hal/phydm/phydm.c	/^phydm_config_cck_rx_antenna_init($/;"	f
-phydm_config_cck_rx_path	hal/phydm/phydm.c	/^phydm_config_cck_rx_path($/;"	f
-phydm_config_ofdm_rx_path	hal/phydm/phydm.c	/^phydm_config_ofdm_rx_path($/;"	f
-phydm_config_ofdm_tx_path	hal/phydm/phydm.c	/^phydm_config_ofdm_tx_path($/;"	f
-phydm_config_trx_path	hal/phydm/phydm.c	/^phydm_config_trx_path($/;"	f
-phydm_construct_hl_beam_codeword	hal/phydm/phydm_antdiv.c	/^phydm_construct_hl_beam_codeword($/;"	f
-phydm_csi_mask_enable	hal/phydm/phydm.c	/^phydm_csi_mask_enable($/;"	f
-phydm_csi_mask_setting	hal/phydm/phydm.c	/^phydm_csi_mask_setting($/;"	f
-phydm_debug_trace	hal/phydm/phydm_debug.c	/^phydm_debug_trace($/;"	f
-phydm_dfs_debug	hal/phydm/phydm_dfs.c	/^phydm_dfs_debug($/;"	f
-phydm_dfs_master_enabled	hal/phydm/phydm_dfs.c	/^phydm_dfs_master_enabled($/;"	f
-phydm_dtp_fix_tx_path	hal/phydm/phydm_pathdiv.c	/^phydm_dtp_fix_tx_path($/;"	f
-phydm_dynamic_tx_path	hal/phydm/phydm_pathdiv.c	/^phydm_dynamic_tx_path($/;"	f
-phydm_dynamic_tx_path_init	hal/phydm/phydm_pathdiv.c	/^phydm_dynamic_tx_path_init($/;"	f
-phydm_enable_antenna_diversity	hal/phydm/phydm_antdiv.c	/^phydm_enable_antenna_diversity($/;"	f
-phydm_find_default_path	hal/phydm/phydm_pathdiv.c	/^phydm_find_default_path($/;"	f
-phydm_fw_debug_trace	hal/phydm/phydm_debug.c	/^phydm_fw_debug_trace($/;"	f
-phydm_fw_trace_en_h2c	hal/phydm/phydm_debug.c	/^phydm_fw_trace_en_h2c($/;"	f
-phydm_fw_trace_handler	hal/phydm/phydm_debug.c	/^phydm_fw_trace_handler($/;"	f
-phydm_fw_trace_handler_8051	hal/phydm/phydm_debug.c	/^phydm_fw_trace_handler_8051($/;"	f
-phydm_fw_trace_handler_code	hal/phydm/phydm_debug.c	/^phydm_fw_trace_handler_code($/;"	f
-phydm_gen_ramask_h2c_AP	hal/phydm/phydm_rainfo.c	/^phydm_gen_ramask_h2c_AP($/;"	f
-phydm_getCLMresult	hal/phydm/phydm_ccx.c	/^phydm_getCLMresult($/;"	f
-phydm_getNHMresult	hal/phydm/phydm_ccx.c	/^phydm_getNHMresult($/;"	f
-phydm_get_beamforming_sounding_info	hal/phydm/txbf/phydm_hal_txbf_api.c	/^phydm_get_beamforming_sounding_info($/;"	f
-phydm_get_beamforming_sounding_info	hal/phydm/txbf/phydm_hal_txbf_api.h	62;"	d
-phydm_get_mu_bfee_snding_decision	hal/phydm/txbf/phydm_hal_txbf_api.c	/^phydm_get_mu_bfee_snding_decision($/;"	f
-phydm_get_mu_bfee_snding_decision	hal/phydm/txbf/phydm_hal_txbf_api.h	64;"	d
-phydm_get_ndpa_rate	hal/phydm/txbf/phydm_hal_txbf_api.c	/^phydm_get_ndpa_rate($/;"	f
-phydm_get_ndpa_rate	hal/phydm/txbf/phydm_hal_txbf_api.h	63;"	d
-phydm_get_per_path_txagc	hal/phydm/phydm_debug.c	/^phydm_get_per_path_txagc($/;"	f
-phydm_get_txagc	hal/phydm/phydm_debug.c	/^phydm_get_txagc($/;"	f
-phydm_h2C_debug	hal/phydm/phydm_rainfo.c	/^phydm_h2C_debug($/;"	f
-phydm_hl_smart_ant_debug	hal/phydm/phydm_antdiv.c	/^phydm_hl_smart_ant_debug($/;"	f
-phydm_hl_smart_ant_type1_init_8821a	hal/phydm/phydm_antdiv.c	/^phydm_hl_smart_ant_type1_init_8821a($/;"	f
-phydm_initRaInfo	hal/phydm/phydm_rainfo.c	/^phydm_initRaInfo($/;"	f
-phydm_keep_RxAckAnt_By_TxAnt_time	hal/phydm/phydm_antdiv.c	/^phydm_keep_RxAckAnt_By_TxAnt_time($/;"	f
-phydm_la_mode_bb_setting	hal/phydm/phydm_debug.c	/^phydm_la_mode_bb_setting($/;"	f
-phydm_la_mode_mac_setting	hal/phydm/phydm_debug.c	/^phydm_la_mode_mac_setting($/;"	f
-phydm_modify_RA_PCR_threshold	hal/phydm/phydm_rainfo.c	/^phydm_modify_RA_PCR_threshold($/;"	f
-phydm_msg	os_dep/linux/rtw_proc.c	/^static char *phydm_msg = NULL;$/;"	v	file:
-phydm_nbi_enable	hal/phydm/phydm.c	/^phydm_nbi_enable($/;"	f
-phydm_nbi_setting	hal/phydm/phydm.c	/^phydm_nbi_setting($/;"	f
-phydm_normal_driver_rx_sniffer	hal/phydm/phydm_hwconfig.c	/^phydm_normal_driver_rx_sniffer($/;"	f
-phydm_pauseEDCCA	hal/phydm/phydm_adaptivity.c	/^phydm_pauseEDCCA($/;"	f
-phydm_pauseEDCCAWorkItem	hal/phydm/phydm_adaptivity.h	/^	RT_WORK_ITEM	phydm_pauseEDCCAWorkItem;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-phydm_pauseEDCCA_WorkItemCallback	hal/phydm/phydm_adaptivity.c	/^phydm_pauseEDCCA_WorkItemCallback($/;"	f
-phydm_period	hal/phydm/phydm.h	/^	u1Byte			phydm_period;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-phydm_print_rate	hal/phydm/phydm_rainfo.c	/^phydm_print_rate($/;"	f
-phydm_process_rssi_for_path_div	hal/phydm/phydm_pathdiv.c	/^phydm_process_rssi_for_path_div(	$/;"	f
-phydm_ra_common_info_update	hal/phydm/phydm_rainfo.c	/^phydm_ra_common_info_update($/;"	f
-phydm_ra_dynamic_rate_id_init	hal/phydm/phydm_rainfo.c	/^phydm_ra_dynamic_rate_id_init($/;"	f
-phydm_ra_dynamic_rate_id_on_assoc	hal/phydm/phydm_rainfo.c	/^phydm_ra_dynamic_rate_id_on_assoc($/;"	f
-phydm_ra_dynamic_retry_count	hal/phydm/phydm_rainfo.c	/^phydm_ra_dynamic_retry_count($/;"	f
-phydm_ra_dynamic_retry_limit	hal/phydm/phydm_rainfo.c	/^phydm_ra_dynamic_retry_limit($/;"	f
-phydm_ra_dynamic_retry_limit_init	hal/phydm/phydm_rainfo.c	/^phydm_ra_dynamic_retry_limit_init($/;"	f
-phydm_ra_info_init	hal/phydm/phydm_rainfo.c	/^phydm_ra_info_init($/;"	f
-phydm_ra_info_watchdog	hal/phydm/phydm_rainfo.c	/^phydm_ra_info_watchdog($/;"	f
-phydm_ra_print_msg	hal/phydm/phydm_rainfo.c	/^phydm_ra_print_msg($/;"	f
-phydm_ra_rssi_rpt_wk	hal/phydm/phydm_rainfo.c	/^void phydm_ra_rssi_rpt_wk(PVOID pContext)$/;"	f
-phydm_ra_rssi_rpt_wk_hdl	hal/phydm/phydm_rainfo.c	/^void phydm_ra_rssi_rpt_wk_hdl(PVOID pContext)$/;"	f
-phydm_radar_detect	hal/phydm/phydm_dfs.c	/^BOOLEAN phydm_radar_detect(PVOID pDM_VOID)$/;"	f
-phydm_radar_detect_disable	hal/phydm/phydm_dfs.c	/^VOID phydm_radar_detect_disable(PVOID pDM_VOID)$/;"	f
-phydm_radar_detect_enable	hal/phydm/phydm_dfs.c	/^VOID phydm_radar_detect_enable(PVOID pDM_VOID)$/;"	f
-phydm_radar_detect_reset	hal/phydm/phydm_dfs.c	/^VOID phydm_radar_detect_reset(PVOID pDM_VOID)$/;"	f
-phydm_radar_detect_with_dbg_parm	hal/phydm/phydm_dfs.c	/^static VOID phydm_radar_detect_with_dbg_parm(PVOID pDM_VOID)$/;"	f	file:
-phydm_rate_id_mapping	hal/phydm/phydm_rainfo.c	/^phydm_rate_id_mapping($/;"	f
-phydm_rate_order_compute	hal/phydm/phydm_rainfo.c	/^phydm_rate_order_compute($/;"	f
-phydm_rate_to_num_ss	hal/phydm/phydm_hwconfig.c	/^phydm_rate_to_num_ss($/;"	f
-phydm_reSearchCondition	hal/phydm/phydm_adaptivity.c	/^phydm_reSearchCondition($/;"	f
-phydm_reset_retry_limit_table	hal/phydm/phydm_rainfo.c	/^phydm_reset_retry_limit_table($/;"	f
-phydm_reset_rssi_for_dm	hal/phydm/phydm_hwconfig.c	/^phydm_reset_rssi_for_dm($/;"	f
-phydm_resumeEDCCAWorkItem	hal/phydm/phydm_adaptivity.h	/^	RT_WORK_ITEM	phydm_resumeEDCCAWorkItem;$/;"	m	struct:_ADAPTIVITY_STATISTICS
-phydm_resumeEDCCA_WorkItemCallback	hal/phydm/phydm_adaptivity.c	/^phydm_resumeEDCCA_WorkItemCallback($/;"	f
-phydm_retry_limit_table_bound	hal/phydm/phydm_rainfo.c	/^phydm_retry_limit_table_bound($/;"	f
-phydm_rf_init	hal/phydm/halphyrf_ap.c	/^void phydm_rf_init(IN	PVOID		pDM_VOID)$/;"	f
-phydm_rf_init	hal/phydm/halphyrf_ce.c	/^void phydm_rf_init(IN	PVOID		pDM_VOID)$/;"	f
-phydm_rf_init	hal/phydm/halphyrf_win.c	/^void phydm_rf_init(IN		PDM_ODM_T		pDM_Odm)$/;"	f
-phydm_rf_watchdog	hal/phydm/halphyrf_ap.c	/^void phydm_rf_watchdog(IN	PVOID		pDM_VOID)$/;"	f
-phydm_rf_watchdog	hal/phydm/halphyrf_ce.c	/^void phydm_rf_watchdog(IN	PVOID		pDM_VOID)$/;"	f
-phydm_rf_watchdog	hal/phydm/halphyrf_win.c	/^void phydm_rf_watchdog(IN		PDM_ODM_T		pDM_Odm)$/;"	f
-phydm_rssi_report	hal/phydm/phydm_rainfo.c	/^s8 phydm_rssi_report(PDM_ODM_T pDM_Odm, u8 mac_id)$/;"	f
-phydm_sbd_callback	hal/phydm/phydm_debug.c	/^void phydm_sbd_callback($/;"	f
-phydm_sbd_check	hal/phydm/phydm_debug.c	/^void phydm_sbd_check($/;"	f
-phydm_sbd_workitem_callback	hal/phydm/phydm_debug.c	/^void phydm_sbd_workitem_callback($/;"	f
-phydm_seq_sorting	hal/phydm/phydm.c	/^phydm_seq_sorting( $/;"	f
-phydm_setBigJumpStep	hal/phydm/phydm_dig.c	/^phydm_setBigJumpStep($/;"	f
-phydm_setEDCCAThresholdAPI	hal/phydm/phydm_adaptivity.c	/^phydm_setEDCCAThresholdAPI($/;"	f
-phydm_set_all_ant_same_beam_num	hal/phydm/phydm_antdiv.c	/^phydm_set_all_ant_same_beam_num($/;"	f
-phydm_set_csi_mask_reg	hal/phydm/phydm.c	/^phydm_set_csi_mask_reg($/;"	f
-phydm_set_ext_switch	hal/phydm/phydm.c	/^phydm_set_ext_switch($/;"	f
-phydm_set_nbi_reg	hal/phydm/phydm.c	/^phydm_set_nbi_reg($/;"	f
-phydm_set_tx_ant_pwr_8723d	hal/phydm/phydm_antdiv.c	/^phydm_set_tx_ant_pwr_8723d($/;"	f
-phydm_set_txagc	hal/phydm/phydm_debug.c	/^phydm_set_txagc($/;"	f
-phydm_showRxRate	hal/phydm/phydm_debug.c	/^phydm_showRxRate($/;"	f
-phydm_staInfoInit	hal/phydm/phydm_beamforming.c	/^phydm_staInfoInit($/;"	f
-phydm_staInfoUpdate	hal/phydm/phydm_beamforming.c	/^void phydm_staInfoUpdate($/;"	f
-phydm_storeNHMsetting	hal/phydm/phydm_ccx.c	/^phydm_storeNHMsetting($/;"	f
-phydm_support_ability_debug	hal/phydm/phydm.c	/^phydm_support_ability_debug($/;"	f
-phydm_supportability_Init	hal/phydm/phydm.c	/^phydm_supportability_Init($/;"	f
-phydm_sys_up_time	hal/phydm/phydm.h	/^	u4Byte			phydm_sys_up_time;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-phydm_traffic_load_decision	hal/phydm/phydm.c	/^phydm_traffic_load_decision( $/;"	f
-phydm_trans_h2c_id	hal/phydm/phydm_interface.c	/^phydm_trans_h2c_id($/;"	f
-phydm_trans_platform_bw	hal/phydm/phydm_rainfo.c	/^phydm_trans_platform_bw($/;"	f
-phydm_trans_platform_rf_type	hal/phydm/phydm_rainfo.c	/^phydm_trans_platform_rf_type($/;"	f
-phydm_trans_platform_wireless_mode	hal/phydm/phydm_rainfo.c	/^phydm_trans_platform_wireless_mode($/;"	f
-phydm_update_beam_pattern	hal/phydm/phydm_antdiv.c	/^phydm_update_beam_pattern($/;"	f
-phydm_update_pwr_track	hal/phydm/phydm_rainfo.c	/^phydm_update_pwr_track($/;"	f
-phydm_update_rate_id	hal/phydm/phydm_rainfo.c	/^phydm_update_rate_id($/;"	f
-phydm_update_rx_idle_antenna_8188F	hal/phydm/phydm_antdiv.c	/^phydm_update_rx_idle_antenna_8188F($/;"	f
-phydm_update_rx_idle_beam	hal/phydm/phydm_antdiv.c	/^phydm_update_rx_idle_beam($/;"	f
-phydm_vht_en_mapping	hal/phydm/phydm_rainfo.c	/^phydm_vht_en_mapping($/;"	f
-phymask	include/rtw_mp_ioctl.h	/^	u32 phymask;$/;"	m	struct:bbreg_param
-physt	include/rtl8188e_recv.h	/^	u32 physt:1;$/;"	m	struct:rxreport_8188e
-physt	include/rtw_recv.h	/^	u8	physt;$/;"	m	struct:rx_pkt_attrib
-pid	include/drv_types.h	/^	int	pid[3];\/* process id from UI, 0:wps, 1:hostapd, 2:dhcpcd *\/$/;"	m	struct:_ADAPTER
-pid	include/sta_info.h	/^	u16 pid; \/* pairing id *\/$/;"	m	struct:sta_info
-pifp	include/drv_types.h	/^	_nic_hdl pifp;$/;"	m	struct:_ADAPTER
-pifs	include/rtl8188e_xmit.h	/^	u32 pifs:1;$/;"	m	struct:txdesc_88e
-pifs	include/rtl8192e_xmit.h	/^	u32 pifs:1;$/;"	m	struct:txdescriptor_8192e
-pifs	include/rtl8812a_xmit.h	/^	u32 pifs:1;$/;"	m	struct:txdescriptor_8812
-pifs	include/rtl8821a_xmit.h	/^	u32 pifs:1;$/;"	m	struct:txdescriptor_8821a
-pinit_adpt_in_progress	hal/phydm/phydm.h	/^	BOOLEAN			*pinit_adpt_in_progress;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pintf_dev	include/rtw_io.h	/^	struct dvobj_priv *pintf_dev;\/*	pointer to &(padapter->dvobjpriv); *\/$/;"	m	struct:intf_hdl	typeref:struct:intf_hdl::dvobj_priv
-piorw_irp	include/osdep_intf.h	/^	PIRP		piorw_irp;$/;"	m	struct:intf_priv
-piorw_urb	include/osdep_intf.h	/^	PURB	piorw_urb;$/;"	m	struct:intf_priv
-pipehdls_r8192c	include/drv_types.h	/^	_nic_hdl		pipehdls_r8192c[0x10];$/;"	m	struct:dvobj_priv
-pirp	include/rtw_io.h	/^	PIRP  pirp;$/;"	m	struct:io_req
-pirp	include/rtw_recv.h	/^	PIRP		pirp;$/;"	m	struct:recv_buf
-pkt	include/rtw_mp.h	/^	_pkt *pkt;$/;"	m	struct:mp_xmit_frame
-pkt	include/rtw_recv.h	/^	_pkt	*pkt;$/;"	m	struct:recv_frame_hdr
-pkt	include/rtw_recv.h	/^	struct sk_buff	*pkt;$/;"	m	struct:recv_frame_hdr	typeref:struct:recv_frame_hdr::sk_buff
-pkt	include/rtw_xmit.h	/^	_pkt *pkt;$/;"	m	struct:xmit_frame
-pkt	include/xmit_osdep.h	/^	_pkt *pkt;$/;"	m	struct:pkt_file
-pktInterval	include/rtw_mp.h	/^	u32 pktInterval;$/;"	m	struct:mp_priv
-pktLength	include/rtw_mp.h	/^	u32 pktLength;$/;"	m	struct:mp_priv
-pkt_attrib	include/rtw_xmit.h	/^struct pkt_attrib {$/;"	s
-pkt_counter	hal/phydm/phydm_antdiv.h	/^	u1Byte	pkt_counter;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pkt_file	include/xmit_osdep.h	/^struct pkt_file {$/;"	s
-pkt_hdrlen	include/rtw_xmit.h	/^	u16	pkt_hdrlen;	\/* the original 802.3 pkt header len *\/$/;"	m	struct:pkt_attrib
-pkt_len	include/rtw_recv.h	/^	u16	pkt_len;$/;"	m	struct:rx_pkt_attrib
-pkt_len	include/rtw_xmit.h	/^	u16 pkt_len;$/;"	m	struct:agg_pkt_info
-pkt_len	include/xmit_osdep.h	/^	SIZE_T pkt_len;	 \/* the remainder length of the open_file *\/$/;"	m	struct:pkt_file
-pkt_newalloc	include/rtw_recv.h	/^	_pkt *pkt_newalloc;$/;"	m	struct:recv_frame_hdr
-pkt_newalloc	include/rtw_recv.h	/^	struct sk_buff	*pkt_newalloc;$/;"	m	struct:recv_frame_hdr	typeref:struct:recv_frame_hdr::sk_buff
-pkt_num	hal/rtl8723d/rtl8723d_hal_init.c	/^	u16 pkt_num:8;$/;"	m	struct:bcn_qinfo_8723d	file:
-pkt_num	hal/rtl8723d/rtl8723d_hal_init.c	/^	u32 pkt_num:7;$/;"	m	struct:qinfo_8723d	file:
-pkt_num	include/rtl8188e_xmit.h	/^	u8 pkt_num:3;$/;"	m	struct:txrpt_ccx_88e
-pkt_num	include/rtl8192e_xmit.h	/^	u8 pkt_num:3;$/;"	m	struct:txrpt_ccx_92e
-pkt_offset	include/rtl8188e_xmit.h	/^	u32 pkt_offset:5;	\/* unit: 8 bytes *\/$/;"	m	struct:txdesc_88e
-pkt_offset	include/rtl8192e_xmit.h	/^	u32 pkt_offset:5;	\/* unit: 8 bytes *\/$/;"	m	struct:txdescriptor_8192e
-pkt_offset	include/rtl8812a_xmit.h	/^	u32 pkt_offset:5;	\/* unit: 8 bytes *\/$/;"	m	struct:txdescriptor_8812
-pkt_offset	include/rtl8821a_xmit.h	/^	u32 pkt_offset:5; \/* unit: 8 bytes *\/$/;"	m	struct:txdescriptor_8821a
-pkt_offset	include/rtw_xmit.h	/^	s8	pkt_offset;$/;"	m	struct:xmit_frame
-pkt_ok	include/rtl8188e_xmit.h	/^	u8 pkt_ok:1;$/;"	m	struct:txrpt_ccx_88e
-pkt_ok	include/rtl8192e_xmit.h	/^	u8 pkt_ok:1;$/;"	m	struct:txrpt_ccx_92e
-pkt_rpt_type	include/rtw_recv.h	/^	u8	pkt_rpt_type;$/;"	m	struct:rx_pkt_attrib
-pkt_rssi_cnt	hal/phydm/phydm_antdiv.h	/^	u4Byte	pkt_rssi_cnt[8][SUPPORT_BEAM_PATTERN_NUM];$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pkt_rssi_pre	hal/phydm/phydm_antdiv.h	/^	u4Byte	pkt_rssi_pre[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pkt_rssi_sum	hal/phydm/phydm_antdiv.h	/^	u4Byte	pkt_rssi_sum[8][SUPPORT_BEAM_PATTERN_NUM];$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pkt_skip_statistic_en	hal/phydm/phydm_antdiv.h	/^	BOOLEAN	pkt_skip_statistic_en;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pkt_to_recvdata	include/rtw_recv.h	/^__inline static u8 *pkt_to_recvdata(_pkt *pkt)$/;"	f
-pkt_to_recvframe	include/rtw_recv.h	/^__inline static union recv_frame *pkt_to_recvframe(_pkt *pkt)$/;"	f
-pkt_to_recvmem	include/rtw_recv.h	/^__inline static u8 *pkt_to_recvmem(_pkt *pkt)$/;"	f
-pkt_type	include/osdep_service_bsd.h	/^	u8			pkt_type:3,$/;"	m	struct:sk_buff
-pktcmp	os_dep/linux/ioctl_linux.c	/^static u8 pktcmp(PADAPTER padapter, u8 *txbuf, u32 txsz, u8 *rxbuf, u32 rxsz)$/;"	f	file:
-pktlen	include/rtl8188e_recv.h	/^	u32 pktlen:14;$/;"	m	struct:rxreport_8188e
-pktlen	include/rtl8188e_xmit.h	/^	u32 pktlen:16;$/;"	m	struct:txdesc_88e
-pktlen	include/rtl8192e_xmit.h	/^	u32 pktlen:16;$/;"	m	struct:txdescriptor_8192e
-pktlen	include/rtl8812a_xmit.h	/^	u32 pktlen:16;$/;"	m	struct:txdescriptor_8812
-pktlen	include/rtl8814a_xmit.h	/^	u32 pktlen:16;$/;"	m	struct:txdescriptor_8814
-pktlen	include/rtl8821a_xmit.h	/^	u32 pktlen:16;$/;"	m	struct:txdescriptor_8821a
-pktlen	include/rtw_xmit.h	/^	u32	pktlen;		\/* the original 802.3 pkt raw_data len (not include ether_hdr data) *\/$/;"	m	struct:pkt_attrib
-platform2phydm_macid_table	hal/phydm/phydm.h	/^	u2Byte			platform2phydm_macid_table[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-platform_wifi_power_off	platform/platform_ARM_SUN50IW1P1_sdio.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_ARM_SUNnI_sdio.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_ARM_SUNxI_sdio.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_ARM_SUNxI_usb.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_ARM_WMT_sdio.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_RTK_DMP_usb.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_arm_act_sdio.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_ops.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_off	platform/platform_sprd_sdio.c	/^void platform_wifi_power_off(void)$/;"	f
-platform_wifi_power_on	platform/platform_ARM_SUN50IW1P1_sdio.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_ARM_SUNnI_sdio.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_ARM_SUNxI_sdio.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_ARM_SUNxI_usb.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_ARM_WMT_sdio.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_RTK_DMP_usb.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_arm_act_sdio.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_ops.c	/^int platform_wifi_power_on(void)$/;"	f
-platform_wifi_power_on	platform/platform_sprd_sdio.c	/^int platform_wifi_power_on(void)$/;"	f
-plink_action	include/ieee80211_ext.h	/^				}  __attribute__((packed)) plink_action;$/;"	m	union:ieee80211_mgmt::__anon8::__anon18::__anon19	typeref:struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon24
-plink_action	include/ieee80211_ext.h	/^				}  plink_action;$/;"	m	union:ieee80211_mgmt::__anon26::__anon33::__anon34	typeref:struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon39
-pll_ref_clk_sel	include/drv_types.h	/^	u8 pll_ref_clk_sel;$/;"	m	struct:registry_priv
-ploopback	include/drv_types.h	/^	PLOOPBACKDATA ploopback;$/;"	m	struct:_ADAPTER
-plps_poff_info	include/rtw_pwrctrl.h	/^	lps_poff_info_t	*plps_poff_info;$/;"	m	struct:pwrctrl_priv
-pm_netdev_close	os_dep/linux/os_intfs.c	/^int pm_netdev_close(struct net_device *pnetdev, u8 bnormal)$/;"	f
-pm_netdev_open	os_dep/linux/os_intfs.c	/^int pm_netdev_open(struct net_device *pnetdev, u8 bnormal)$/;"	f
-pmdl	include/osdep_intf.h	/^	PMDL pmdl;$/;"	m	struct:intf_priv
-pmdl	include/rtw_io.h	/^	PMDL pmdl;$/;"	m	struct:io_req
-pmdl	include/sdio_ops.h	/^	PMDL pmdl;$/;"	m	struct:async_context
-pmgnt_netdev	include/rtw_mlme.h	/^	struct net_device *pmgnt_netdev;$/;"	m	struct:hostapd_priv	typeref:struct:hostapd_priv::net_device
-pmon_ndev	os_dep/linux/ioctl_cfg80211.h	/^	struct net_device *pmon_ndev;\/* for monitor interface *\/$/;"	m	struct:rtw_wdev_priv	typeref:struct:rtw_wdev_priv::net_device
-pmp_xmtframe_buf	include/rtw_mp.h	/^	u8 *pmp_xmtframe_buf;$/;"	m	struct:mp_priv
-pn48	include/rtw_security.h	/^union pn48	{$/;"	u
-pnetdev	include/drv_types.h	/^	_nic_hdl pnetdev;$/;"	m	struct:_ADAPTER
-pnextdevobj	include/drv_types.h	/^	PDEVICE_OBJECT	pnextdevobj;\/* pNextDevObj; *\/$/;"	m	struct:dvobj_priv
-pnextdevobj	include/drv_types_sdio.h	/^	PDEVICE_OBJECT				pnextdevobj;$/;"	m	struct:sdio_data
-pnlo_info	include/rtw_pwrctrl.h	/^	pno_nlo_info_t	*pnlo_info;$/;"	m	struct:pwrctrl_priv
-pno_in_example	os_dep/linux/rtw_android.c	/^char pno_in_example[] = {$/;"	v
-pno_inited	include/rtw_pwrctrl.h	/^	u8		pno_inited;$/;"	m	struct:pwrctrl_priv
-pno_nlo_info	include/rtw_pwrctrl.h	/^typedef struct pno_nlo_info {$/;"	s
-pno_nlo_info_t	include/rtw_pwrctrl.h	/^} pno_nlo_info_t;$/;"	t	typeref:struct:pno_nlo_info
-pno_scan_channel_info	include/rtw_pwrctrl.h	/^typedef struct pno_scan_channel_info {$/;"	s
-pno_scan_channel_info_t	include/rtw_pwrctrl.h	/^} pno_scan_channel_info_t;$/;"	t	typeref:struct:pno_scan_channel_info
-pno_scan_info	include/rtw_pwrctrl.h	/^typedef struct pno_scan_info {$/;"	s
-pno_scan_info_t	include/rtw_pwrctrl.h	/^} pno_scan_info_t;$/;"	t	typeref:struct:pno_scan_info
-pno_ssid	include/rtw_pwrctrl.h	/^typedef struct pno_ssid {$/;"	s
-pno_ssid_list	include/rtw_pwrctrl.h	/^	pno_ssid_list_t	*pno_ssid_list;$/;"	m	struct:pwrctrl_priv
-pno_ssid_list	include/rtw_pwrctrl.h	/^typedef struct pno_ssid_list {$/;"	s
-pno_ssid_list_t	include/rtw_pwrctrl.h	/^} pno_ssid_list_t;$/;"	t	typeref:struct:pno_ssid_list
-pno_ssid_t	include/rtw_pwrctrl.h	/^} pno_ssid_t;$/;"	t	typeref:struct:pno_ssid
-pnp_bstop_trx	include/rtw_pwrctrl.h	/^	u8		pnp_bstop_trx;$/;"	m	struct:pwrctrl_priv
-pnp_current_pwr_state	include/rtw_pwrctrl.h	/^	s32		pnp_current_pwr_state;$/;"	m	struct:pwrctrl_priv
-pointer	include/linux/wireless.h	/^	compat_caddr_t pointer;$/;"	m	struct:compat_iw_point
-pointer	include/linux/wireless.h	/^	void __user	*pointer;	\/* Pointer to the data  (in user space) *\/$/;"	m	struct:iw_point
-polling_fwdl_chksum	hal/rtl8723d/rtl8723d_hal_init.c	/^static s32 polling_fwdl_chksum(_adapter *adapter, u32 min_cnt, u32 timeout_ms)$/;"	f	file:
-pop_event_cnt	hal/btc/HalBtc8192e1Ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8192e_1ant
-pop_event_cnt	hal/btc/HalBtc8703b1Ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8703b_1ant
-pop_event_cnt	hal/btc/HalBtc8723b1Ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8723b_1ant
-pop_event_cnt	hal/btc/HalBtc8723b2Ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8723b_2ant
-pop_event_cnt	hal/btc/HalBtc8812a1Ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8812a_1ant
-pop_event_cnt	hal/btc/HalBtc8822b1Ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8822b_1ant
-pop_event_cnt	hal/btc/halbtc8723d1ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8723d_1ant
-pop_event_cnt	hal/btc/halbtc8723d2ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8723d_2ant
-pop_event_cnt	hal/btc/halbtc8821c1ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8821c_1ant
-pop_event_cnt	hal/btc/halbtc8821c2ant.h	/^	u32					pop_event_cnt;$/;"	m	struct:coex_sta_8821c_2ant
-port_id	include/rtl8188e_xmit.h	/^	u32 port_id:1;$/;"	m	struct:txdesc_88e
-port_id	include/rtl8192e_xmit.h	/^	u32 port_id:1;$/;"	m	struct:txdescriptor_8192e
-port_id	include/rtl8812a_xmit.h	/^	u32 port_id:1;$/;"	m	struct:txdescriptor_8812
-port_id	include/rtl8821a_xmit.h	/^	u32 port_id:1;$/;"	m	struct:txdescriptor_8821a
-port_num	include/hal_data.h	/^	u8 port_num;$/;"	m	struct:hal_spec_t
-portctrl	core/rtw_recv.c	/^union recv_frame *portctrl(_adapter *adapter, union recv_frame *precv_frame)$/;"	f
-power_cap	include/ieee80211.h	/^	u8 *power_cap;$/;"	m	struct:rtw_ieee802_11_elems
-power_cap_len	include/ieee80211.h	/^	u8 power_cap_len;$/;"	m	struct:rtw_ieee802_11_elems
-power_limit	include/wifi.h	/^	int16_t power_limit;$/;"	m	struct:rtw_regulatory
-power_mgmt	os_dep/linux/ioctl_cfg80211.h	/^	bool power_mgmt;$/;"	m	struct:rtw_wdev_priv
-power_mgnt	include/drv_types.h	/^	u8	power_mgnt;$/;"	m	struct:registry_priv
-power_mgnt	include/rtw_pwrctrl.h	/^	u8	power_mgnt;$/;"	m	struct:pwrctrl_priv
-power_mode	core/rtw_mi.c	/^	unsigned int power_mode;$/;"	m	struct:nulldata_param	file:
-power_saving_wk_hdl	core/rtw_cmd.c	/^void power_saving_wk_hdl(_adapter *padapter)$/;"	f
-power_tracking_flag	hal/phydm/phydm_rainfo.h	/^	u1Byte	power_tracking_flag;$/;"	m	struct:_Rate_Adaptive_Table_
-ppcidev	include/drv_types.h	/^	struct pci_dev *ppcidev;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::pci_dev
-pphysdevobj	include/drv_types.h	/^	PDEVICE_OBJECT	pphysdevobj;\/* pPhysDevObj; *\/$/;"	m	struct:dvobj_priv
-pphysdevobj	include/drv_types_sdio.h	/^	PDEVICE_OBJECT				pphysdevobj;$/;"	m	struct:sdio_data
-pppoe_addr	include/drv_types.h	/^	unsigned char			pppoe_addr[MACADDRLEN];$/;"	m	struct:_ADAPTER
-pppoe_connection_in_progress	include/drv_types.h	/^	int				pppoe_connection_in_progress;$/;"	m	struct:_ADAPTER
-pprev_hash	include/rtw_br_ext.h	/^	struct nat25_network_db_entry	**pprev_hash;$/;"	m	struct:nat25_network_db_entry	typeref:struct:nat25_network_db_entry::nat25_network_db_entry
-preAlgorithm	hal/btc/HalBtc8188c2Ant.h	/^	u1Byte		preAlgorithm;$/;"	m	struct:_COEX_DM_8188C_2ANT
-preAlgorithm	hal/btc/HalBtc8192d2Ant.h	/^	u1Byte		preAlgorithm;$/;"	m	struct:_COEX_DM_8192D_2ANT
-preAlgorithm	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		preAlgorithm;$/;"	m	struct:_COEX_DM_8723A_1ANT
-preAlgorithm	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		preAlgorithm;$/;"	m	struct:_COEX_DM_8723A_2ANT
-preBtRssiState	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte					preBtRssiState;$/;"	m	struct:_COEX_STA_8723A_1ANT
-preBtRssiState	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					preBtRssiState;$/;"	m	struct:_COEX_STA_8723A_2ANT
-preBtRssiState1	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte					preBtRssiState1;$/;"	m	struct:_COEX_STA_8723A_1ANT
-preBtRssiState1	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					preBtRssiState1;$/;"	m	struct:_COEX_STA_8723A_2ANT
-preChannel	hal/phydm/phydm.h	/^	u1Byte			preChannel;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-preDacSwingLvl	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		preDacSwingLvl;$/;"	m	struct:_COEX_DM_8188C_2ANT
-preDacSwingLvl	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		preDacSwingLvl;$/;"	m	struct:_COEX_DM_8192D_2ANT
-preDacSwingLvl	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte		preDacSwingLvl;$/;"	m	struct:_COEX_DM_8723A_2ANT
-preFwDacSwingLvl	hal/btc/HalBtc8188c2Ant.h	/^	u1Byte		preFwDacSwingLvl;$/;"	m	struct:_COEX_DM_8188C_2ANT
-preFwDacSwingLvl	hal/btc/HalBtc8192d2Ant.h	/^	u1Byte		preFwDacSwingLvl;$/;"	m	struct:_COEX_DM_8192D_2ANT
-preFwDacSwingLvl	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		preFwDacSwingLvl;$/;"	m	struct:_COEX_DM_8723A_2ANT
-prePsTdma	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		prePsTdma;$/;"	m	struct:_COEX_DM_8723A_1ANT
-prePsTdma	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		prePsTdma;$/;"	m	struct:_COEX_DM_8723A_2ANT
-preVal0x6c0	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte		preVal0x6c0;$/;"	m	struct:_COEX_DM_8723A_1ANT
-preVal0x6c0	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte		preVal0x6c0;$/;"	m	struct:_COEX_DM_8723A_2ANT
-preVal0x6c4	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		preVal0x6c4;$/;"	m	struct:_COEX_DM_8188C_2ANT
-preVal0x6c4	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		preVal0x6c4;$/;"	m	struct:_COEX_DM_8192D_2ANT
-preVal0x6c8	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		preVal0x6c8;$/;"	m	struct:_COEX_DM_8188C_2ANT
-preVal0x6c8	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		preVal0x6c8;$/;"	m	struct:_COEX_DM_8192D_2ANT
-preVal0x6c8	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte		preVal0x6c8;$/;"	m	struct:_COEX_DM_8723A_1ANT
-preVal0x6c8	hal/btc/HalBtc8723a2Ant.h	/^	u4Byte		preVal0x6c8;$/;"	m	struct:_COEX_DM_8723A_2ANT
-preVal0x6cc	hal/btc/HalBtc8188c2Ant.h	/^	u4Byte		preVal0x6cc;$/;"	m	struct:_COEX_DM_8188C_2ANT
-preVal0x6cc	hal/btc/HalBtc8192d2Ant.h	/^	u4Byte		preVal0x6cc;$/;"	m	struct:_COEX_DM_8192D_2ANT
-preVal0x6cc	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		preVal0x6cc;$/;"	m	struct:_COEX_DM_8723A_1ANT
-preVal0x6cc	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		preVal0x6cc;$/;"	m	struct:_COEX_DM_8723A_2ANT
-preWifiRssiState	hal/btc/HalBtc8188c2Ant.h	/^	u1Byte					preWifiRssiState[4];$/;"	m	struct:_COEX_STA_8188C_2ANT
-preWifiRssiState	hal/btc/HalBtc8192d2Ant.h	/^	u1Byte					preWifiRssiState[4];$/;"	m	struct:_COEX_STA_8192D_2ANT
-preWifiRssiState	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte					preWifiRssiState[4];$/;"	m	struct:_COEX_STA_8723A_1ANT
-preWifiRssiState	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte					preWifiRssiState[4];$/;"	m	struct:_COEX_STA_8723A_2ANT
-pre_AntType	hal/phydm/phydm.h	/^	u1Byte			pre_AntType;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pre_TargetAnt_enhance	hal/phydm/phydm_antdiv.h	/^	u1Byte	pre_TargetAnt_enhance;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-pre_TrafficLoad	hal/phydm/phydm.h	/^	u1Byte			pre_TrafficLoad;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pre_adc_back_off	hal/btc/HalBtc8192e2Ant.h	/^	boolean		pre_adc_back_off;$/;"	m	struct:coex_dm_8192e_2ant
-pre_adc_back_off	hal/btc/HalBtc8723b2Ant.h	/^	boolean		pre_adc_back_off;$/;"	m	struct:coex_dm_8723b_2ant
-pre_adc_back_off	hal/btc/HalBtc8812a2Ant.h	/^	boolean		pre_adc_back_off;$/;"	m	struct:coex_dm_8812a_2ant
-pre_adc_back_off	hal/btc/HalBtc8821a2Ant.h	/^	boolean		pre_adc_back_off;$/;"	m	struct:coex_dm_8821a_2ant
-pre_adc_back_off	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		pre_adc_back_off;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_adc_back_off	hal/btc/halbtc8723d2ant.h	/^	boolean		pre_adc_back_off;$/;"	m	struct:coex_dm_8723d_2ant
-pre_adc_back_off	hal/btc/halbtc8821c2ant.h	/^	boolean		pre_adc_back_off;$/;"	m	struct:coex_dm_8821c_2ant
-pre_agc_table_en	hal/btc/HalBtc8192e2Ant.h	/^	boolean	pre_agc_table_en;$/;"	m	struct:coex_dm_8192e_2ant
-pre_agc_table_en	hal/btc/HalBtc8723b2Ant.h	/^	boolean	pre_agc_table_en;$/;"	m	struct:coex_dm_8723b_2ant
-pre_agc_table_en	hal/btc/HalBtc8812a2Ant.h	/^	boolean	pre_agc_table_en;$/;"	m	struct:coex_dm_8812a_2ant
-pre_agc_table_en	hal/btc/HalBtc8821a2Ant.h	/^	boolean	pre_agc_table_en;$/;"	m	struct:coex_dm_8821a_2ant
-pre_agc_table_en	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean	pre_agc_table_en;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_agc_table_en	hal/btc/halbtc8723d2ant.h	/^	boolean	pre_agc_table_en;$/;"	m	struct:coex_dm_8723d_2ant
-pre_agc_table_en	hal/btc/halbtc8821c2ant.h	/^	boolean	pre_agc_table_en;$/;"	m	struct:coex_dm_8821c_2ant
-pre_agg_buf_size	hal/btc/HalBtcOutSrc.h	/^	u8					pre_agg_buf_size;$/;"	m	struct:btc_bt_info
-pre_algorithm	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8192e_1ant
-pre_algorithm	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8192e_2ant
-pre_algorithm	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8703b_1ant
-pre_algorithm	hal/btc/HalBtc8723b2Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8723b_2ant
-pre_algorithm	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8812a_1ant
-pre_algorithm	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8812a_2ant
-pre_algorithm	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8821a_1ant
-pre_algorithm	hal/btc/HalBtc8821a2Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8821a_2ant
-pre_algorithm	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_algorithm	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8822b_1ant
-pre_algorithm	hal/btc/halbtc8723d1ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8723d_1ant
-pre_algorithm	hal/btc/halbtc8723d2ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8723d_2ant
-pre_algorithm	hal/btc/halbtc8821c1ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8821c_1ant
-pre_algorithm	hal/btc/halbtc8821c2ant.h	/^	u8		pre_algorithm;$/;"	m	struct:coex_dm_8821c_2ant
-pre_ampdu_num_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8 pre_ampdu_num_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_ampdu_time_type	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8192e_1ant
-pre_ampdu_time_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8192e_2ant
-pre_ampdu_time_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8703b_1ant
-pre_ampdu_time_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8723b_1ant
-pre_ampdu_time_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8812a_1ant
-pre_ampdu_time_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8812a_2ant
-pre_ampdu_time_type	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8821a_1ant
-pre_ampdu_time_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8 pre_ampdu_time_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_ampdu_time_type	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8822b_1ant
-pre_ampdu_time_type	hal/btc/halbtc8723d1ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8723d_1ant
-pre_ampdu_time_type	hal/btc/halbtc8821c1ant.h	/^	u8		pre_ampdu_time_type;$/;"	m	struct:coex_dm_8821c_1ant
-pre_ant_pos_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_ant_pos_type;$/;"	m	struct:coex_dm_8703b_1ant
-pre_ant_pos_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_ant_pos_type;$/;"	m	struct:coex_dm_8723b_1ant
-pre_ant_pos_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_ant_pos_type;$/;"	m	struct:coex_dm_8812a_1ant
-pre_ant_pos_type	hal/btc/HalBtc8822b1Ant.h	/^	u32		pre_ant_pos_type;$/;"	m	struct:coex_dm_8822b_1ant
-pre_ant_pos_type	hal/btc/halbtc8723d1ant.h	/^	u8		pre_ant_pos_type;$/;"	m	struct:coex_dm_8723d_1ant
-pre_ant_pos_type	hal/btc/halbtc8723d2ant.h	/^	u8		pre_ant_pos_type;$/;"	m	struct:coex_dm_8723d_2ant
-pre_ant_pos_type	hal/btc/halbtc8821c1ant.h	/^	u32		pre_ant_pos_type;$/;"	m	struct:coex_dm_8821c_1ant
-pre_ant_pos_type	hal/btc/halbtc8821c2ant.h	/^	u32		pre_ant_pos_type;$/;"	m	struct:coex_dm_8821c_2ant
-pre_arfr_type	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8192e_1ant
-pre_arfr_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8192e_2ant
-pre_arfr_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8703b_1ant
-pre_arfr_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8723b_1ant
-pre_arfr_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8812a_1ant
-pre_arfr_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8812a_2ant
-pre_arfr_type	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8821a_1ant
-pre_arfr_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_arfr_type	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8822b_1ant
-pre_arfr_type	hal/btc/halbtc8723d1ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8723d_1ant
-pre_arfr_type	hal/btc/halbtc8821c1ant.h	/^	u8		pre_arfr_type;$/;"	m	struct:coex_dm_8821c_1ant
-pre_b_noisy	hal/phydm/phydm.h	/^	BOOLEAN			pre_b_noisy;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pre_beacon_counter	hal/phydm/phydm_antdiv.h	/^	u4Byte	pre_beacon_counter;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pre_bt_auto_report	hal/btc/HalBtc8192e1Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8192e_1ant
-pre_bt_auto_report	hal/btc/HalBtc8192e2Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8192e_2ant
-pre_bt_auto_report	hal/btc/HalBtc8703b1Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8703b_1ant
-pre_bt_auto_report	hal/btc/HalBtc8723b1Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8723b_1ant
-pre_bt_auto_report	hal/btc/HalBtc8723b2Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8723b_2ant
-pre_bt_auto_report	hal/btc/HalBtc8812a1Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8812a_1ant
-pre_bt_auto_report	hal/btc/HalBtc8812a2Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8812a_2ant
-pre_bt_auto_report	hal/btc/HalBtc8821a1Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8821a_1ant
-pre_bt_auto_report	hal/btc/HalBtc8821a2Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8821a_2ant
-pre_bt_auto_report	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_bt_auto_report	hal/btc/HalBtc8822b1Ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8822b_1ant
-pre_bt_auto_report	hal/btc/halbtc8723d1ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8723d_1ant
-pre_bt_auto_report	hal/btc/halbtc8723d2ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8723d_2ant
-pre_bt_auto_report	hal/btc/halbtc8821c1ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8821c_1ant
-pre_bt_auto_report	hal/btc/halbtc8821c2ant.h	/^	boolean		pre_bt_auto_report;$/;"	m	struct:coex_dm_8821c_2ant
-pre_bt_ctrl_agg_buf_size	hal/btc/HalBtcOutSrc.h	/^	boolean					pre_bt_ctrl_agg_buf_size;$/;"	m	struct:btc_bt_info
-pre_bt_dec_pwr_lvl	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8192e_2ant
-pre_bt_dec_pwr_lvl	hal/btc/HalBtc8723b2Ant.h	/^	u8		pre_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8723b_2ant
-pre_bt_dec_pwr_lvl	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8812a_2ant
-pre_bt_dec_pwr_lvl	hal/btc/HalBtc8821a2Ant.h	/^	u8		pre_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8821a_2ant
-pre_bt_dec_pwr_lvl	hal/btc/halbtc8723d2ant.h	/^	u8		pre_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8723d_2ant
-pre_bt_dec_pwr_lvl	hal/btc/halbtc8821c2ant.h	/^	u8		pre_bt_dec_pwr_lvl;$/;"	m	struct:coex_dm_8821c_2ant
-pre_bt_rssi_state	hal/btc/HalBtc8192e1Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8192e_1ant
-pre_bt_rssi_state	hal/btc/HalBtc8192e2Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8192e_2ant
-pre_bt_rssi_state	hal/btc/HalBtc8703b1Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8703b_1ant
-pre_bt_rssi_state	hal/btc/HalBtc8723b2Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8723b_2ant
-pre_bt_rssi_state	hal/btc/HalBtc8812a1Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8812a_1ant
-pre_bt_rssi_state	hal/btc/HalBtc8812a2Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8812a_2ant
-pre_bt_rssi_state	hal/btc/HalBtc8821a1Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8821a_1ant
-pre_bt_rssi_state	hal/btc/HalBtc8821a2Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8821a_2ant
-pre_bt_rssi_state	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8821a_csr_2ant
-pre_bt_rssi_state	hal/btc/HalBtc8822b1Ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8822b_1ant
-pre_bt_rssi_state	hal/btc/halbtc8723d1ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8723d_1ant
-pre_bt_rssi_state	hal/btc/halbtc8723d2ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8723d_2ant
-pre_bt_rssi_state	hal/btc/halbtc8821c1ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8821c_1ant
-pre_bt_rssi_state	hal/btc/halbtc8821c2ant.h	/^	u8					pre_bt_rssi_state;$/;"	m	struct:coex_sta_8821c_2ant
-pre_c2h_seq	hal/phydm/phydm.h	/^	u1Byte			pre_c2h_seq;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pre_ccklock	hal/btc/HalBtc8192e1Ant.h	/^	boolean					pre_ccklock;$/;"	m	struct:coex_sta_8192e_1ant
-pre_ccklock	hal/btc/HalBtc8703b1Ant.h	/^	boolean					pre_ccklock;$/;"	m	struct:coex_sta_8703b_1ant
-pre_ccklock	hal/btc/HalBtc8723b1Ant.h	/^	boolean					pre_ccklock;$/;"	m	struct:coex_sta_8723b_1ant
-pre_ccklock	hal/btc/HalBtc8812a1Ant.h	/^	boolean					pre_ccklock;$/;"	m	struct:coex_sta_8812a_1ant
-pre_ccklock	hal/btc/HalBtc8822b1Ant.h	/^	boolean					pre_ccklock;$/;"	m	struct:coex_sta_8822b_1ant
-pre_ccklock	hal/btc/halbtc8723d1ant.h	/^	boolean				pre_ccklock;$/;"	m	struct:coex_sta_8723d_1ant
-pre_ccklock	hal/btc/halbtc8723d2ant.h	/^	boolean				pre_ccklock;$/;"	m	struct:coex_sta_8723d_2ant
-pre_ccklock	hal/btc/halbtc8821c1ant.h	/^	boolean					pre_ccklock;$/;"	m	struct:coex_sta_8821c_1ant
-pre_ccklock	hal/btc/halbtc8821c2ant.h	/^	boolean					pre_ccklock;$/;"	m	struct:coex_sta_8821c_2ant
-pre_codeword	hal/phydm/phydm_antdiv.h	/^	u4Byte	pre_codeword;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pre_dac_swing_lvl	hal/btc/HalBtc8192e2Ant.h	/^	u32		pre_dac_swing_lvl;$/;"	m	struct:coex_dm_8192e_2ant
-pre_dac_swing_lvl	hal/btc/HalBtc8723b2Ant.h	/^	u32		pre_dac_swing_lvl;$/;"	m	struct:coex_dm_8723b_2ant
-pre_dac_swing_lvl	hal/btc/HalBtc8812a2Ant.h	/^	u32		pre_dac_swing_lvl;$/;"	m	struct:coex_dm_8812a_2ant
-pre_dac_swing_lvl	hal/btc/HalBtc8821a2Ant.h	/^	u32		pre_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_2ant
-pre_dac_swing_lvl	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		pre_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_dac_swing_lvl	hal/btc/halbtc8723d2ant.h	/^	u32		pre_dac_swing_lvl;$/;"	m	struct:coex_dm_8723d_2ant
-pre_dac_swing_lvl	hal/btc/halbtc8821c2ant.h	/^	u32		pre_dac_swing_lvl;$/;"	m	struct:coex_dm_8821c_2ant
-pre_dac_swing_on	hal/btc/HalBtc8192e2Ant.h	/^	boolean		pre_dac_swing_on;$/;"	m	struct:coex_dm_8192e_2ant
-pre_dac_swing_on	hal/btc/HalBtc8723b2Ant.h	/^	boolean		pre_dac_swing_on;$/;"	m	struct:coex_dm_8723b_2ant
-pre_dac_swing_on	hal/btc/HalBtc8812a2Ant.h	/^	boolean		pre_dac_swing_on;$/;"	m	struct:coex_dm_8812a_2ant
-pre_dac_swing_on	hal/btc/HalBtc8821a2Ant.h	/^	boolean		pre_dac_swing_on;$/;"	m	struct:coex_dm_8821a_2ant
-pre_dac_swing_on	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		pre_dac_swing_on;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_dac_swing_on	hal/btc/halbtc8723d2ant.h	/^	boolean		pre_dac_swing_on;$/;"	m	struct:coex_dm_8723d_2ant
-pre_dac_swing_on	hal/btc/halbtc8821c2ant.h	/^	boolean		pre_dac_swing_on;$/;"	m	struct:coex_dm_8821c_2ant
-pre_dec_bt_pwr	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		pre_dec_bt_pwr;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_ext_ant_switch_status	hal/btc/HalBtc8822b1Ant.h	/^	u32		pre_ext_ant_switch_status;$/;"	m	struct:coex_dm_8822b_1ant
-pre_ext_ant_switch_status	hal/btc/halbtc8821c1ant.h	/^	u32		pre_ext_ant_switch_status;$/;"	m	struct:coex_dm_8821c_1ant
-pre_ext_ant_switch_status	hal/btc/halbtc8821c2ant.h	/^	u32		pre_ext_ant_switch_status;$/;"	m	struct:coex_dm_8821c_2ant
-pre_ext_band_switch_status	hal/btc/halbtc8821c1ant.h	/^	u8		pre_ext_band_switch_status;$/;"	m	struct:coex_dm_8821c_1ant
-pre_ext_band_switch_status	hal/btc/halbtc8821c2ant.h	/^	u8		pre_ext_band_switch_status;$/;"	m	struct:coex_dm_8821c_2ant
-pre_fast_training_beam_num	hal/phydm/phydm_antdiv.h	/^	u4Byte	pre_fast_training_beam_num;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-pre_fw_dac_swing_lvl	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8192e_2ant
-pre_fw_dac_swing_lvl	hal/btc/HalBtc8723b2Ant.h	/^	u8		pre_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8723b_2ant
-pre_fw_dac_swing_lvl	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8812a_2ant
-pre_fw_dac_swing_lvl	hal/btc/HalBtc8821a2Ant.h	/^	u8		pre_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_2ant
-pre_fw_dac_swing_lvl	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		pre_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_fw_dac_swing_lvl	hal/btc/halbtc8723d2ant.h	/^	u8		pre_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8723d_2ant
-pre_fw_dac_swing_lvl	hal/btc/halbtc8821c2ant.h	/^	u8		pre_fw_dac_swing_lvl;$/;"	m	struct:coex_dm_8821c_2ant
-pre_gpio_pin	include/drv_types.h	/^	u8	pre_gpio_pin;$/;"	m	struct:_ADAPTER
-pre_ignore_wlan_act	hal/btc/HalBtc8192e1Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8192e_1ant
-pre_ignore_wlan_act	hal/btc/HalBtc8192e2Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8192e_2ant
-pre_ignore_wlan_act	hal/btc/HalBtc8703b1Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8703b_1ant
-pre_ignore_wlan_act	hal/btc/HalBtc8723b1Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8723b_1ant
-pre_ignore_wlan_act	hal/btc/HalBtc8723b2Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8723b_2ant
-pre_ignore_wlan_act	hal/btc/HalBtc8812a1Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8812a_1ant
-pre_ignore_wlan_act	hal/btc/HalBtc8812a2Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8812a_2ant
-pre_ignore_wlan_act	hal/btc/HalBtc8821a1Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8821a_1ant
-pre_ignore_wlan_act	hal/btc/HalBtc8821a2Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8821a_2ant
-pre_ignore_wlan_act	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_ignore_wlan_act	hal/btc/HalBtc8822b1Ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8822b_1ant
-pre_ignore_wlan_act	hal/btc/halbtc8723d1ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8723d_1ant
-pre_ignore_wlan_act	hal/btc/halbtc8723d2ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8723d_2ant
-pre_ignore_wlan_act	hal/btc/halbtc8821c1ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8821c_1ant
-pre_ignore_wlan_act	hal/btc/halbtc8821c2ant.h	/^	boolean		pre_ignore_wlan_act;$/;"	m	struct:coex_dm_8821c_2ant
-pre_int_block_status	hal/btc/halbtc8821c1ant.h	/^	u8		pre_int_block_status;$/;"	m	struct:coex_dm_8821c_1ant
-pre_int_block_status	hal/btc/halbtc8821c2ant.h	/^	u8		pre_int_block_status;$/;"	m	struct:coex_dm_8821c_2ant
-pre_ips_type	include/rtw_pwrctrl.h	/^	u8 pre_ips_type;\/* 0: default flow, 1: carddisbale flow *\/$/;"	m	struct:pwrctrl_priv
-pre_low_penalty_ra	hal/btc/HalBtc8192e1Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8192e_1ant
-pre_low_penalty_ra	hal/btc/HalBtc8192e2Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8192e_2ant
-pre_low_penalty_ra	hal/btc/HalBtc8703b1Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8703b_1ant
-pre_low_penalty_ra	hal/btc/HalBtc8723b1Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8723b_1ant
-pre_low_penalty_ra	hal/btc/HalBtc8723b2Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8723b_2ant
-pre_low_penalty_ra	hal/btc/HalBtc8812a1Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8812a_1ant
-pre_low_penalty_ra	hal/btc/HalBtc8812a2Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8812a_2ant
-pre_low_penalty_ra	hal/btc/HalBtc8821a1Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8821a_1ant
-pre_low_penalty_ra	hal/btc/HalBtc8821a2Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8821a_2ant
-pre_low_penalty_ra	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_low_penalty_ra	hal/btc/HalBtc8822b1Ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8822b_1ant
-pre_low_penalty_ra	hal/btc/halbtc8723d1ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8723d_1ant
-pre_low_penalty_ra	hal/btc/halbtc8723d2ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8723d_2ant
-pre_low_penalty_ra	hal/btc/halbtc8821c1ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8821c_1ant
-pre_low_penalty_ra	hal/btc/halbtc8821c2ant.h	/^	boolean	pre_low_penalty_ra;$/;"	m	struct:coex_dm_8821c_2ant
-pre_lps	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8192e_1ant
-pre_lps	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8192e_2ant
-pre_lps	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8703b_1ant
-pre_lps	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8723b_1ant
-pre_lps	hal/btc/HalBtc8723b2Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8723b_2ant
-pre_lps	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8812a_1ant
-pre_lps	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8812a_2ant
-pre_lps	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8821a_1ant
-pre_lps	hal/btc/HalBtc8821a2Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8821a_2ant
-pre_lps	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8822b_1ant
-pre_lps	hal/btc/halbtc8723d1ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8723d_1ant
-pre_lps	hal/btc/halbtc8723d2ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8723d_2ant
-pre_lps	hal/btc/halbtc8821c1ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8821c_1ant
-pre_lps	hal/btc/halbtc8821c2ant.h	/^	u8		pre_lps;$/;"	m	struct:coex_dm_8821c_2ant
-pre_num_Client	hal/phydm/phydm_antdiv.h	/^	u1Byte pre_num_Client;$/;"	m	struct:_BF_DIV_COEX_
-pre_number_active_client	hal/phydm/phydm.h	/^	u1Byte			pre_number_active_client;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pre_number_linked_client	hal/phydm/phydm.h	/^	u1Byte			pre_number_linked_client;	$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pre_p2p_state	include/rtw_mlme.h	/^	enum P2P_STATE			pre_p2p_state;$/;"	m	struct:wifidirect_info	typeref:enum:wifidirect_info::P2P_STATE
-pre_ps_tdma	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8192e_1ant
-pre_ps_tdma	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8192e_2ant
-pre_ps_tdma	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8703b_1ant
-pre_ps_tdma	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8723b_1ant
-pre_ps_tdma	hal/btc/HalBtc8723b2Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8723b_2ant
-pre_ps_tdma	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8812a_1ant
-pre_ps_tdma	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8812a_2ant
-pre_ps_tdma	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8821a_1ant
-pre_ps_tdma	hal/btc/HalBtc8821a2Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8821a_2ant
-pre_ps_tdma	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_ps_tdma	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8822b_1ant
-pre_ps_tdma	hal/btc/halbtc8723d1ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8723d_1ant
-pre_ps_tdma	hal/btc/halbtc8723d2ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8723d_2ant
-pre_ps_tdma	hal/btc/halbtc8821c1ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8821c_1ant
-pre_ps_tdma	hal/btc/halbtc8821c2ant.h	/^	u8		pre_ps_tdma;$/;"	m	struct:coex_dm_8821c_2ant
-pre_ps_tdma_on	hal/btc/HalBtc8192e1Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8192e_1ant
-pre_ps_tdma_on	hal/btc/HalBtc8192e2Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8192e_2ant
-pre_ps_tdma_on	hal/btc/HalBtc8703b1Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8703b_1ant
-pre_ps_tdma_on	hal/btc/HalBtc8723b1Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8723b_1ant
-pre_ps_tdma_on	hal/btc/HalBtc8723b2Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8723b_2ant
-pre_ps_tdma_on	hal/btc/HalBtc8812a1Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8812a_1ant
-pre_ps_tdma_on	hal/btc/HalBtc8812a2Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8812a_2ant
-pre_ps_tdma_on	hal/btc/HalBtc8821a1Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8821a_1ant
-pre_ps_tdma_on	hal/btc/HalBtc8821a2Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8821a_2ant
-pre_ps_tdma_on	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_ps_tdma_on	hal/btc/HalBtc8822b1Ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8822b_1ant
-pre_ps_tdma_on	hal/btc/halbtc8723d1ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8723d_1ant
-pre_ps_tdma_on	hal/btc/halbtc8723d2ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8723d_2ant
-pre_ps_tdma_on	hal/btc/halbtc8821c1ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8821c_1ant
-pre_ps_tdma_on	hal/btc/halbtc8821c2ant.h	/^	boolean		pre_ps_tdma_on;$/;"	m	struct:coex_dm_8821c_2ant
-pre_ra_mask	hal/btc/HalBtc8192e1Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8192e_1ant
-pre_ra_mask	hal/btc/HalBtc8192e2Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8192e_2ant
-pre_ra_mask	hal/btc/HalBtc8703b1Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8703b_1ant
-pre_ra_mask	hal/btc/HalBtc8723b1Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8723b_1ant
-pre_ra_mask	hal/btc/HalBtc8812a1Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8812a_1ant
-pre_ra_mask	hal/btc/HalBtc8812a2Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8812a_2ant
-pre_ra_mask	hal/btc/HalBtc8821a1Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8821a_1ant
-pre_ra_mask	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_ra_mask	hal/btc/HalBtc8822b1Ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8822b_1ant
-pre_ra_mask	hal/btc/halbtc8723d1ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8723d_1ant
-pre_ra_mask	hal/btc/halbtc8821c1ant.h	/^	u32		pre_ra_mask;$/;"	m	struct:coex_dm_8821c_1ant
-pre_recv_entry	core/rtw_recv.c	/^s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status)$/;"	f
-pre_reject_agg_pkt	hal/btc/HalBtcOutSrc.h	/^	boolean					pre_reject_agg_pkt;$/;"	m	struct:btc_bt_info
-pre_retry_limit_type	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8192e_1ant
-pre_retry_limit_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8192e_2ant
-pre_retry_limit_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8703b_1ant
-pre_retry_limit_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8723b_1ant
-pre_retry_limit_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8812a_1ant
-pre_retry_limit_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8812a_2ant
-pre_retry_limit_type	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8821a_1ant
-pre_retry_limit_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_retry_limit_type	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8822b_1ant
-pre_retry_limit_type	hal/btc/halbtc8723d1ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8723d_1ant
-pre_retry_limit_type	hal/btc/halbtc8821c1ant.h	/^	u8		pre_retry_limit_type;$/;"	m	struct:coex_dm_8821c_1ant
-pre_rf_rx_lpf_shrink	hal/btc/HalBtc8192e2Ant.h	/^	boolean		pre_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8192e_2ant
-pre_rf_rx_lpf_shrink	hal/btc/HalBtc8723b2Ant.h	/^	boolean		pre_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8723b_2ant
-pre_rf_rx_lpf_shrink	hal/btc/HalBtc8812a2Ant.h	/^	boolean		pre_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8812a_2ant
-pre_rf_rx_lpf_shrink	hal/btc/HalBtc8821a2Ant.h	/^	boolean		pre_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8821a_2ant
-pre_rf_rx_lpf_shrink	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		pre_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_rf_rx_lpf_shrink	hal/btc/halbtc8723d2ant.h	/^	boolean		pre_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8723d_2ant
-pre_rf_rx_lpf_shrink	hal/btc/halbtc8821c2ant.h	/^	boolean		pre_rf_rx_lpf_shrink;$/;"	m	struct:coex_dm_8821c_2ant
-pre_rpwm	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8192e_1ant
-pre_rpwm	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8192e_2ant
-pre_rpwm	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8703b_1ant
-pre_rpwm	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8723b_1ant
-pre_rpwm	hal/btc/HalBtc8723b2Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8723b_2ant
-pre_rpwm	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8812a_1ant
-pre_rpwm	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8812a_2ant
-pre_rpwm	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8821a_1ant
-pre_rpwm	hal/btc/HalBtc8821a2Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8821a_2ant
-pre_rpwm	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8822b_1ant
-pre_rpwm	hal/btc/halbtc8723d1ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8723d_1ant
-pre_rpwm	hal/btc/halbtc8723d2ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8723d_2ant
-pre_rpwm	hal/btc/halbtc8821c1ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8821c_1ant
-pre_rpwm	hal/btc/halbtc8821c2ant.h	/^	u8		pre_rpwm;$/;"	m	struct:coex_dm_8821c_2ant
-pre_rtp_rxseq	include/rtw_recv.h	/^	u16 sink_udpport, pre_rtp_rxseq, cur_rtp_rxseq;$/;"	m	struct:recv_priv
-pre_ss_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_ss_type;$/;"	m	struct:coex_dm_8192e_2ant
-pre_tx_invitereq_handler	core/rtw_p2p.c	/^void pre_tx_invitereq_handler(_adapter	*padapter)$/;"	f
-pre_tx_negoreq_handler	core/rtw_p2p.c	/^void pre_tx_negoreq_handler(_adapter	*padapter)$/;"	f
-pre_tx_path	hal/phydm/phydm_pathdiv.h	/^	u1Byte	pre_tx_path;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-pre_tx_provdisc_handler	core/rtw_p2p.c	/^void pre_tx_provdisc_handler(_adapter	*padapter)$/;"	f
-pre_tx_scan_timer	include/rtw_mlme.h	/^	_timer					pre_tx_scan_timer;$/;"	m	struct:wifidirect_info
-pre_tx_scan_timer_process	core/rtw_p2p.c	/^static void pre_tx_scan_timer_process(void *FunctionContext)$/;"	f	file:
-pre_val0x6c0	hal/btc/HalBtc8192e1Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8192e_1ant
-pre_val0x6c0	hal/btc/HalBtc8192e2Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8192e_2ant
-pre_val0x6c0	hal/btc/HalBtc8703b1Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8703b_1ant
-pre_val0x6c0	hal/btc/HalBtc8723b1Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8723b_1ant
-pre_val0x6c0	hal/btc/HalBtc8723b2Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8723b_2ant
-pre_val0x6c0	hal/btc/HalBtc8812a1Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8812a_1ant
-pre_val0x6c0	hal/btc/HalBtc8812a2Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8812a_2ant
-pre_val0x6c0	hal/btc/HalBtc8821a1Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8821a_1ant
-pre_val0x6c0	hal/btc/HalBtc8821a2Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8821a_2ant
-pre_val0x6c0	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_val0x6c0	hal/btc/HalBtc8822b1Ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8822b_1ant
-pre_val0x6c0	hal/btc/halbtc8723d1ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8723d_1ant
-pre_val0x6c0	hal/btc/halbtc8723d2ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8723d_2ant
-pre_val0x6c0	hal/btc/halbtc8821c1ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8821c_1ant
-pre_val0x6c0	hal/btc/halbtc8821c2ant.h	/^	u32		pre_val0x6c0;$/;"	m	struct:coex_dm_8821c_2ant
-pre_val0x6c4	hal/btc/HalBtc8192e1Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8192e_1ant
-pre_val0x6c4	hal/btc/HalBtc8192e2Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8192e_2ant
-pre_val0x6c4	hal/btc/HalBtc8703b1Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8703b_1ant
-pre_val0x6c4	hal/btc/HalBtc8723b1Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8723b_1ant
-pre_val0x6c4	hal/btc/HalBtc8723b2Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8723b_2ant
-pre_val0x6c4	hal/btc/HalBtc8812a1Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8812a_1ant
-pre_val0x6c4	hal/btc/HalBtc8812a2Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8812a_2ant
-pre_val0x6c4	hal/btc/HalBtc8821a1Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8821a_1ant
-pre_val0x6c4	hal/btc/HalBtc8821a2Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8821a_2ant
-pre_val0x6c4	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_val0x6c4	hal/btc/HalBtc8822b1Ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8822b_1ant
-pre_val0x6c4	hal/btc/halbtc8723d1ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8723d_1ant
-pre_val0x6c4	hal/btc/halbtc8723d2ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8723d_2ant
-pre_val0x6c4	hal/btc/halbtc8821c1ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8821c_1ant
-pre_val0x6c4	hal/btc/halbtc8821c2ant.h	/^	u32		pre_val0x6c4;$/;"	m	struct:coex_dm_8821c_2ant
-pre_val0x6c8	hal/btc/HalBtc8192e1Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8192e_1ant
-pre_val0x6c8	hal/btc/HalBtc8192e2Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8192e_2ant
-pre_val0x6c8	hal/btc/HalBtc8703b1Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8703b_1ant
-pre_val0x6c8	hal/btc/HalBtc8723b1Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8723b_1ant
-pre_val0x6c8	hal/btc/HalBtc8723b2Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8723b_2ant
-pre_val0x6c8	hal/btc/HalBtc8812a1Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8812a_1ant
-pre_val0x6c8	hal/btc/HalBtc8812a2Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8812a_2ant
-pre_val0x6c8	hal/btc/HalBtc8821a1Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8821a_1ant
-pre_val0x6c8	hal/btc/HalBtc8821a2Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8821a_2ant
-pre_val0x6c8	hal/btc/HalBtc8821aCsr2Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_val0x6c8	hal/btc/HalBtc8822b1Ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8822b_1ant
-pre_val0x6c8	hal/btc/halbtc8723d1ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8723d_1ant
-pre_val0x6c8	hal/btc/halbtc8723d2ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8723d_2ant
-pre_val0x6c8	hal/btc/halbtc8821c1ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8821c_1ant
-pre_val0x6c8	hal/btc/halbtc8821c2ant.h	/^	u32		pre_val0x6c8;$/;"	m	struct:coex_dm_8821c_2ant
-pre_val0x6cc	hal/btc/HalBtc8192e1Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8192e_1ant
-pre_val0x6cc	hal/btc/HalBtc8192e2Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8192e_2ant
-pre_val0x6cc	hal/btc/HalBtc8703b1Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8703b_1ant
-pre_val0x6cc	hal/btc/HalBtc8723b1Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8723b_1ant
-pre_val0x6cc	hal/btc/HalBtc8723b2Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8723b_2ant
-pre_val0x6cc	hal/btc/HalBtc8812a1Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8812a_1ant
-pre_val0x6cc	hal/btc/HalBtc8812a2Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8812a_2ant
-pre_val0x6cc	hal/btc/HalBtc8821a1Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8821a_1ant
-pre_val0x6cc	hal/btc/HalBtc8821a2Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8821a_2ant
-pre_val0x6cc	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8821a_csr_2ant
-pre_val0x6cc	hal/btc/HalBtc8822b1Ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8822b_1ant
-pre_val0x6cc	hal/btc/halbtc8723d1ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8723d_1ant
-pre_val0x6cc	hal/btc/halbtc8723d2ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8723d_2ant
-pre_val0x6cc	hal/btc/halbtc8821c1ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8821c_1ant
-pre_val0x6cc	hal/btc/halbtc8821c2ant.h	/^	u8		pre_val0x6cc;$/;"	m	struct:coex_dm_8821c_2ant
-pre_wifi_rssi_state	hal/btc/HalBtc8192e1Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8192e_1ant
-pre_wifi_rssi_state	hal/btc/HalBtc8192e2Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8192e_2ant
-pre_wifi_rssi_state	hal/btc/HalBtc8703b1Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8703b_1ant
-pre_wifi_rssi_state	hal/btc/HalBtc8723b2Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8723b_2ant
-pre_wifi_rssi_state	hal/btc/HalBtc8812a1Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8812a_1ant
-pre_wifi_rssi_state	hal/btc/HalBtc8812a2Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8812a_2ant
-pre_wifi_rssi_state	hal/btc/HalBtc8821a1Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8821a_1ant
-pre_wifi_rssi_state	hal/btc/HalBtc8821a2Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8821a_2ant
-pre_wifi_rssi_state	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8821a_csr_2ant
-pre_wifi_rssi_state	hal/btc/HalBtc8822b1Ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8822b_1ant
-pre_wifi_rssi_state	hal/btc/halbtc8723d1ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8723d_1ant
-pre_wifi_rssi_state	hal/btc/halbtc8723d2ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8723d_2ant
-pre_wifi_rssi_state	hal/btc/halbtc8821c1ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8821c_1ant
-pre_wifi_rssi_state	hal/btc/halbtc8821c2ant.h	/^	u8					pre_wifi_rssi_state[4];$/;"	m	struct:coex_sta_8821c_2ant
-preamble	include/drv_types.h	/^	u8	preamble;\/* long, short, auto *\/$/;"	m	struct:registry_priv
-preamble	include/rtw_mp.h	/^	u32 preamble;$/;"	m	struct:mp_priv
-preamble_mode	include/rtw_mlme_ext.h	/^	u8	preamble_mode;$/;"	m	struct:mlme_ext_info
-precv_buf	include/rtw_recv.h	/^	u8 *precv_buf;    \/* 4 alignment *\/$/;"	m	struct:recv_priv
-precv_frame_buf	include/rtw_recv.h	/^	u8 *precv_frame_buf;$/;"	m	struct:recv_priv
-precvbuf	include/rtw_recv.h	/^	void *precvbuf;$/;"	m	struct:recv_frame_hdr
-prefix	os_dep/linux/rtw_android.c	/^	char prefix;$/;"	m	struct:cmd_tlv	file:
-preorder_ctrl	include/rtw_recv.h	/^	struct recv_reorder_ctrl *preorder_ctrl;$/;"	m	struct:recv_frame_hdr	typeref:struct:recv_frame_hdr::recv_reorder_ctrl
-prev	include/osdep_service_bsd.h	/^	struct list_head *next, *prev;$/;"	m	struct:list_head	typeref:struct:list_head::
-prev	include/osdep_service_bsd.h	/^	struct sk_buff		*prev;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::sk_buff
-prev	include/osdep_service_bsd.h	/^	struct sk_buff	*prev;$/;"	m	struct:sk_buff_head	typeref:struct:sk_buff_head::sk_buff
-prev_fw_state	include/rtw_mp.h	/^	u32 prev_fw_state;$/;"	m	struct:mp_priv
-prev_mcc_success_cnt	include/rtw_mcc.h	/^	u8 prev_mcc_success_cnt; \/* used for check mcc switch channel success *\/$/;"	m	struct:mcc_obj_priv
-primary_channel	include/wifi.h	/^	unsigned char	primary_channel;$/;"	m	struct:HT_info_element
-primary_dev_type	include/sta_info.h	/^	u8 primary_dev_type[8];$/;"	m	struct:sta_info
-prime_channel_offset	include/rtw_mp.h	/^	u8 prime_channel_offset;$/;"	m	struct:mp_priv
-print_agc	hal/phydm/phydm.h	/^	u1Byte 			print_agc;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-printdata	os_dep/linux/ioctl_linux.c	/^static void printdata(u8 *pbuf, u32 len)$/;"	f	file:
-priority	include/osdep_service_bsd.h	/^	u32			priority;$/;"	m	struct:sk_buff
-priority	include/rtw_recv.h	/^	u8	priority;$/;"	m	struct:rx_pkt_attrib
-priority	include/rtw_xmit.h	/^	u8	priority;$/;"	m	struct:pkt_attrib
-priv	hal/phydm/phydm.h	/^	prtl8192cd_priv		priv;$/;"	m	struct:_ADAPTER
-priv	hal/phydm/phydm.h	/^	prtl8192cd_priv	priv;			\/*For AP\/ADSL team*\/$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-priv	include/osdep_service_linux.h	/^	void *priv;$/;"	m	struct:rtw_netdev_priv_indicator
-priv_data	include/rtw_xmit.h	/^	void *priv_data;$/;"	m	struct:xmit_buf
-priv_wq	include/drv_types_gspi.h	/^	struct workqueue_struct *priv_wq;$/;"	m	struct:gspi_data	typeref:struct:gspi_data::workqueue_struct
-privacy	include/rtw_recv.h	/^	u8	privacy; \/* in frame_ctrl field *\/$/;"	m	struct:rx_pkt_attrib
-probe_req	include/ieee80211_ext.h	/^		}  __attribute__((packed)) probe_req;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon16
-probe_resp	include/ieee80211_ext.h	/^		}  __attribute__((packed)) probe_resp;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon17
-probe_resp_ie_update_time	os_dep/linux/ioctl_cfg80211.h	/^	u32 probe_resp_ie_update_time;$/;"	m	struct:rtw_wdev_priv
-proc_get_all_sta_info	core/rtw_debug.c	/^int proc_get_all_sta_info(struct seq_file *m, void *v)$/;"	f
-proc_get_ampdu_enable	core/rtw_debug.c	/^int proc_get_ampdu_enable(struct seq_file *m, void *v)$/;"	f
-proc_get_ap_info	core/rtw_debug.c	/^int proc_get_ap_info(struct seq_file *m, void *v)$/;"	f
-proc_get_backop_flags_ap	core/rtw_debug.c	/^int proc_get_backop_flags_ap(struct seq_file *m, void *v)$/;"	f
-proc_get_backop_flags_sta	core/rtw_debug.c	/^int proc_get_backop_flags_sta(struct seq_file *m, void *v)$/;"	f
-proc_get_bb_reg_dump	os_dep/linux/rtw_proc.c	/^static int proc_get_bb_reg_dump(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_best_chan	os_dep/linux/rtw_proc.c	/^static int proc_get_best_chan(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_best_channel	core/rtw_debug.c	/^int proc_get_best_channel(struct seq_file *m, void *v)$/;"	f
-proc_get_btcoex_dbg	core/rtw_debug.c	/^int proc_get_btcoex_dbg(struct seq_file *m, void *v)$/;"	f
-proc_get_btcoex_info	core/rtw_debug.c	/^int proc_get_btcoex_info(struct seq_file *m, void *v)$/;"	f
-proc_get_btreg_read	os_dep/linux/rtw_proc.c	/^int proc_get_btreg_read(struct seq_file *m, void *v)$/;"	f
-proc_get_btreg_write	os_dep/linux/rtw_proc.c	/^int proc_get_btreg_write(struct seq_file *m, void *v)$/;"	f
-proc_get_bw_ctl	core/rtw_debug.c	/^int proc_get_bw_ctl(struct seq_file *m, void *v)$/;"	f
-proc_get_bw_mode	core/rtw_debug.c	/^int proc_get_bw_mode(struct seq_file *m, void *v)$/;"	f
-proc_get_chan_plan	os_dep/linux/rtw_proc.c	/^static int proc_get_chan_plan(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_chplan_id_list	os_dep/linux/rtw_proc.c	/^static int proc_get_chplan_id_list(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_chplan_test	os_dep/linux/rtw_proc.c	/^static int proc_get_chplan_test(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_country_chplan_map	os_dep/linux/rtw_proc.c	/^static int proc_get_country_chplan_map(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_country_code	os_dep/linux/rtw_proc.c	/^static int proc_get_country_code(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_customer_str	os_dep/linux/rtw_proc.c	/^static int proc_get_customer_str(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_dfs_ch_sel_d_flags	os_dep/linux/rtw_proc.c	/^static int proc_get_dfs_ch_sel_d_flags(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_dfs_master_test_case	core/rtw_debug.c	/^int proc_get_dfs_master_test_case(struct seq_file *m, void *v)$/;"	f
-proc_get_dis_pwt	core/rtw_debug.c	/^int proc_get_dis_pwt(struct seq_file *m, void *v)$/;"	f
-proc_get_drv_cfg	os_dep/linux/rtw_proc.c	/^static int proc_get_drv_cfg(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_drv_version	os_dep/linux/rtw_proc.c	/^static int proc_get_drv_version(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_dummy	os_dep/linux/rtw_proc.c	/^static int proc_get_dummy(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_dump_adapters_status	os_dep/linux/rtw_proc.c	/^static int proc_get_dump_adapters_status(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_dump_tx_rate_bmp	os_dep/linux/rtw_proc.c	/^static int proc_get_dump_tx_rate_bmp(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_efuse_map	core/rtw_debug.c	/^int proc_get_efuse_map(struct seq_file *m, void *v)$/;"	f
-proc_get_en_fwps	core/rtw_debug.c	/^int proc_get_en_fwps(struct seq_file *m, void *v)$/;"	f
-proc_get_ft_flags	core/rtw_debug.c	/^int proc_get_ft_flags(struct seq_file *m, void *v)$/;"	f
-proc_get_fwstate	core/rtw_debug.c	/^int proc_get_fwstate(struct seq_file *m, void *v)$/;"	f
-proc_get_gpio	os_dep/linux/rtw_proc.c	/^static int proc_get_gpio(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_hal_spec	os_dep/linux/rtw_proc.c	/^static int proc_get_hal_spec(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_hal_txpwr_info	os_dep/linux/rtw_proc.c	/^static int proc_get_hal_txpwr_info(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_ht_enable	core/rtw_debug.c	/^int proc_get_ht_enable(struct seq_file *m, void *v)$/;"	f
-proc_get_ht_option	core/rtw_debug.c	/^int proc_get_ht_option(struct seq_file *m, void *v)$/;"	f
-proc_get_hw_status	core/rtw_debug.c	/^int proc_get_hw_status(struct seq_file *m, void *v)$/;"	f
-proc_get_int_logs	core/rtw_debug.c	/^int proc_get_int_logs(struct seq_file *m, void *v)$/;"	f
-proc_get_kfree_bb_gain	os_dep/linux/rtw_proc.c	/^static int proc_get_kfree_bb_gain(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_kfree_flag	os_dep/linux/rtw_proc.c	/^static int proc_get_kfree_flag(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_kfree_thermal	os_dep/linux/rtw_proc.c	/^static int proc_get_kfree_thermal(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_linked_info_dump	os_dep/linux/rtw_proc.c	/^static int proc_get_linked_info_dump(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_log_level	os_dep/linux/rtw_proc.c	/^static int proc_get_log_level(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_mac_addr	os_dep/linux/rtw_proc.c	/^int proc_get_mac_addr(struct seq_file *m, void *v)$/;"	f
-proc_get_mac_qinfo	os_dep/linux/rtw_proc.c	/^static int proc_get_mac_qinfo(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_mac_reg_dump	os_dep/linux/rtw_proc.c	/^static int proc_get_mac_reg_dump(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_mac_rptbuf	core/rtw_debug.c	/^int proc_get_mac_rptbuf(struct seq_file *m, void *v)$/;"	f
-proc_get_macaddr_acl	os_dep/linux/rtw_proc.c	/^static int proc_get_macaddr_acl(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_macid_info	os_dep/linux/rtw_proc.c	/^static int proc_get_macid_info(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_malloc_cnt	core/rtw_debug.c	/^int proc_get_malloc_cnt(struct seq_file *m, void *v)$/;"	f
-proc_get_mbid_cam_cache	os_dep/linux/rtw_proc.c	/^int proc_get_mbid_cam_cache(struct seq_file *m, void *v)$/;"	f
-proc_get_mcc_info	core/rtw_debug.c	/^int proc_get_mcc_info(struct seq_file *m, void *v)$/;"	f
-proc_get_mi_ap_bc_info	os_dep/linux/rtw_proc.c	/^static int proc_get_mi_ap_bc_info(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_mlmext_state	core/rtw_debug.c	/^int proc_get_mlmext_state(struct seq_file *m, void *v)$/;"	f
-proc_get_monitor	core/rtw_debug.c	/^int proc_get_monitor(struct seq_file *m, void *v)$/;"	f
-proc_get_mstat	os_dep/linux/rtw_proc.c	/^static int proc_get_mstat(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_napi_info	os_dep/linux/rtw_proc.c	/^static int proc_get_napi_info(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_new_bcn_max	core/rtw_debug.c	/^int proc_get_new_bcn_max(struct seq_file *m, void *v)$/;"	f
-proc_get_odm_ability	os_dep/linux/rtw_proc.c	/^int proc_get_odm_ability(struct seq_file *m, void *v)$/;"	f
-proc_get_odm_adaptivity	os_dep/linux/rtw_proc.c	/^int proc_get_odm_adaptivity(struct seq_file *m, void *v)$/;"	f
-proc_get_odm_dbg_comp	os_dep/linux/rtw_proc.c	/^int proc_get_odm_dbg_comp(struct seq_file *m, void *v)$/;"	f
-proc_get_odm_dbg_level	os_dep/linux/rtw_proc.c	/^int proc_get_odm_dbg_level(struct seq_file *m, void *v)$/;"	f
-proc_get_odm_force_igi_lb	os_dep/linux/rtw_proc.c	/^int proc_get_odm_force_igi_lb(struct seq_file *m, void *v)$/;"	f
-proc_get_p2p_wowlan_info	core/rtw_debug.c	/^int proc_get_p2p_wowlan_info(struct seq_file *m, void *v)$/;"	f
-proc_get_parent_data	os_dep/linux/rtw_proc.c	46;"	d	file:
-proc_get_pattern_info	core/rtw_debug.c	/^int proc_get_pattern_info(struct seq_file *m, void *v)$/;"	f
-proc_get_phydm_cmd	os_dep/linux/rtw_proc.c	/^int proc_get_phydm_cmd(struct seq_file *m, void *v)$/;"	f
-proc_get_ps_info	core/rtw_debug.c	/^int proc_get_ps_info(struct seq_file *m, void *v)$/;"	f
-proc_get_qos_option	core/rtw_debug.c	/^int proc_get_qos_option(struct seq_file *m, void *v)$/;"	f
-proc_get_rate_ctl	core/rtw_debug.c	/^int proc_get_rate_ctl(struct seq_file *m, void *v)$/;"	f
-proc_get_read_addr	core/rtw_debug.c	/^static u32 proc_get_read_addr = 0xeeeeeeee;$/;"	v	file:
-proc_get_read_len	core/rtw_debug.c	/^static u32 proc_get_read_len = 0x4;$/;"	v	file:
-proc_get_read_reg	core/rtw_debug.c	/^int proc_get_read_reg(struct seq_file *m, void *v)$/;"	f
-proc_get_rf_info	core/rtw_debug.c	/^int proc_get_rf_info(struct seq_file *m, void *v)$/;"	f
-proc_get_rf_reg_dump	os_dep/linux/rtw_proc.c	/^static int proc_get_rf_reg_dump(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_roam_flags	core/rtw_debug.c	/^int proc_get_roam_flags(struct seq_file *m, void *v)$/;"	f
-proc_get_roam_param	core/rtw_debug.c	/^int proc_get_roam_param(struct seq_file *m, void *v)$/;"	f
-proc_get_rtkm_info	core/rtw_debug.c	/^int proc_get_rtkm_info(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_ampdu	core/rtw_debug.c	/^int proc_get_rx_ampdu(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_ampdu_density	core/rtw_debug.c	/^int proc_get_rx_ampdu_density(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_ampdu_factor	core/rtw_debug.c	/^int proc_get_rx_ampdu_factor(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_cnt_dump	core/rtw_debug.c	/^int proc_get_rx_cnt_dump(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_info_msg	os_dep/linux/rtw_proc.c	/^static int proc_get_rx_info_msg(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_rx_logs	core/rtw_debug.c	/^int proc_get_rx_logs(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_ring	core/rtw_debug.c	/^int proc_get_rx_ring(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_signal	core/rtw_debug.c	/^int proc_get_rx_signal(struct seq_file *m, void *v)$/;"	f
-proc_get_rx_stbc	core/rtw_debug.c	/^int proc_get_rx_stbc(struct seq_file *m, void *v)$/;"	f
-proc_get_scan_abort	core/rtw_debug.c	/^int proc_get_scan_abort(struct seq_file *m, void *v)$/;"	f
-proc_get_scan_param	core/rtw_debug.c	/^int proc_get_scan_param(struct seq_file *m, void *v)$/;"	f
-proc_get_sd_f0_reg_dump	os_dep/linux/rtw_proc.c	/^static int proc_get_sd_f0_reg_dump(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_sdio_local_reg_dump	os_dep/linux/rtw_proc.c	/^static int proc_get_sdio_local_reg_dump(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_sec_cam	os_dep/linux/rtw_proc.c	/^static int proc_get_sec_cam(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_sec_cam_cache	os_dep/linux/rtw_proc.c	/^static int proc_get_sec_cam_cache(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_sec_info	core/rtw_debug.c	/^int proc_get_sec_info(struct seq_file *m, void *v)$/;"	f
-proc_get_seq_file_test	os_dep/linux/rtw_proc.c	/^static int proc_get_seq_file_test(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_skip_band	os_dep/linux/rtw_proc.c	/^static int proc_get_skip_band(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_sreset	core/rtw_debug.c	/^int proc_get_sreset(struct seq_file *m, void *v)$/;"	f
-proc_get_survey_info	core/rtw_debug.c	/^int proc_get_survey_info(struct seq_file *m, void *v)$/;"	f
-proc_get_suspend_resume_info	core/rtw_debug.c	/^int proc_get_suspend_resume_info(struct seq_file *m, void *v)$/;"	f
-proc_get_target_tx_power	os_dep/linux/rtw_proc.c	/^static int proc_get_target_tx_power(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tdls_info	core/rtw_debug.c	/^int proc_get_tdls_info(struct seq_file *m, void *v)$/;"	f
-proc_get_trx_info	core/rtw_debug.c	/^int proc_get_trx_info(struct seq_file *m, void *v)$/;"	f
-proc_get_trx_info_debug	core/rtw_debug.c	/^int proc_get_trx_info_debug(struct seq_file *m, void *v)$/;"	f
-proc_get_trx_share_mode	os_dep/linux/rtw_proc.c	/^static int proc_get_trx_share_mode(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tx_ampdu_density	core/rtw_debug.c	/^int proc_get_tx_ampdu_density(struct seq_file *m, void *v)$/;"	f
-proc_get_tx_auth	core/rtw_debug.c	/^int proc_get_tx_auth(struct seq_file *m, void *v)$/;"	f
-proc_get_tx_bw_mode	os_dep/linux/rtw_proc.c	/^static int proc_get_tx_bw_mode(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tx_deauth	core/rtw_debug.c	/^int proc_get_tx_deauth(struct seq_file *m, void *v)$/;"	f
-proc_get_tx_info_msg	os_dep/linux/rtw_proc.c	/^static int proc_get_tx_info_msg(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tx_logs	core/rtw_debug.c	/^int proc_get_tx_logs(struct seq_file *m, void *v)$/;"	f
-proc_get_tx_power_by_rate	os_dep/linux/rtw_proc.c	/^static int proc_get_tx_power_by_rate(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tx_power_ext_info	os_dep/linux/rtw_proc.c	/^static int proc_get_tx_power_ext_info(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tx_power_idx	os_dep/linux/rtw_proc.c	/^static int proc_get_tx_power_idx(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tx_power_limit	os_dep/linux/rtw_proc.c	/^static int proc_get_tx_power_limit(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_tx_ring	core/rtw_debug.c	/^int proc_get_tx_ring(struct seq_file *m, void *v)$/;"	f
-proc_get_tx_sa_query	core/rtw_debug.c	/^int proc_get_tx_sa_query(struct seq_file *m, void *v)$/;"	f
-proc_get_udpport	os_dep/linux/rtw_proc.c	/^static int proc_get_udpport(struct seq_file *m, void *v)$/;"	f	file:
-proc_get_wakeup_reason	core/rtw_debug.c	/^int proc_get_wakeup_reason(struct seq_file *m, void *v)$/;"	f
-proc_get_wifi_spec	os_dep/linux/rtw_proc.c	/^int proc_get_wifi_spec(struct seq_file *m, void *v)$/;"	f
-proc_get_wowlan_gpio_info	core/rtw_debug.c	/^int proc_get_wowlan_gpio_info(struct seq_file *m, void *v)$/;"	f
-proc_next_seq_file_test	os_dep/linux/rtw_proc.c	/^void *proc_next_seq_file_test(struct seq_file *m, void *v, loff_t *pos)$/;"	f
-proc_next_tx_power_idx	os_dep/linux/rtw_proc.c	/^static void *proc_next_tx_power_idx(struct seq_file *m, void *v, loff_t *pos)$/;"	f	file:
-proc_reset_trx_info	core/rtw_debug.c	/^ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_acs	os_dep/linux/rtw_proc.c	/^static ssize_t  proc_set_acs(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_ampdu_enable	core/rtw_debug.c	/^ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_backop_flags_ap	core/rtw_debug.c	/^ssize_t proc_set_backop_flags_ap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_backop_flags_sta	core/rtw_debug.c	/^ssize_t proc_set_backop_flags_sta(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_best_channel	core/rtw_debug.c	/^ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_btcoex_dbg	core/rtw_debug.c	/^ssize_t proc_set_btcoex_dbg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_btinfo_evt	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_btinfo_evt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_btreg_read	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_btreg_read(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_btreg_write	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_btreg_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_bw_ctl	core/rtw_debug.c	/^ssize_t proc_set_bw_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_bw_mode	core/rtw_debug.c	/^ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_chan_plan	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_chan_plan(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_change_bss_chbw	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_change_bss_chbw(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_config_gpio	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_config_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_country_code	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_country_code(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_del_rx_ampdu_test_case	core/rtw_debug.c	/^ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_dfs_ch_sel_d_flags	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_dfs_ch_sel_d_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_dfs_master_test_case	core/rtw_debug.c	/^ssize_t proc_set_dfs_master_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_dis_pwt	core/rtw_debug.c	/^ssize_t proc_set_dis_pwt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_efuse_map	core/rtw_debug.c	/^ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_en_fwps	core/rtw_debug.c	/^ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_ft_flags	core/rtw_debug.c	/^ssize_t proc_set_ft_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_fwdl_test_case	core/rtw_debug.c	/^ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_gpio	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_gpio(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_gpio_output_value	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_gpio_output_value(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_ht_enable	core/rtw_debug.c	/^ssize_t proc_set_ht_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_hw_status	core/rtw_debug.c	/^ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_kfree_bb_gain	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_kfree_bb_gain(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_kfree_flag	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_kfree_flag(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_kfree_thermal	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_kfree_thermal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_linked_info_dump	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_linked_info_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_log_level	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_log_level(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_macaddr_acl	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_macaddr_acl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_ap_bw20_target_tp	core/rtw_debug.c	/^ssize_t proc_set_mcc_ap_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_ap_bw40_target_tp	core/rtw_debug.c	/^ssize_t proc_set_mcc_ap_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_ap_bw80_target_tp	core/rtw_debug.c	/^ssize_t proc_set_mcc_ap_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_enable	core/rtw_debug.c	/^ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_single_tx_criteria	core/rtw_debug.c	/^ssize_t proc_set_mcc_single_tx_criteria(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_sta_bw20_target_tp	core/rtw_debug.c	/^ssize_t proc_set_mcc_sta_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_sta_bw40_target_tp	core/rtw_debug.c	/^ssize_t proc_set_mcc_sta_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_mcc_sta_bw80_target_tp	core/rtw_debug.c	/^ssize_t proc_set_mcc_sta_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_monitor	core/rtw_debug.c	/^ssize_t proc_set_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_new_bcn_max	core/rtw_debug.c	/^ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_odm_ability	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_odm_ability(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_odm_adaptivity	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_odm_dbg_comp	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_odm_dbg_comp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_odm_dbg_level	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_odm_dbg_level(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_odm_force_igi_lb	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_odm_force_igi_lb(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_pattern_info	core/rtw_debug.c	/^ssize_t proc_set_pattern_info(struct file *file, const char __user *buffer,$/;"	f
-proc_set_phydm_cmd	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_phydm_cmd(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_radar_detect	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_radar_detect(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_rate_ctl	core/rtw_debug.c	/^ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_read_reg	core/rtw_debug.c	/^ssize_t proc_set_read_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_roam_flags	core/rtw_debug.c	/^ssize_t proc_set_roam_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_roam_param	core/rtw_debug.c	/^ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_roam_tgt_addr	core/rtw_debug.c	/^ssize_t proc_set_roam_tgt_addr(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_rx_ampdu	core/rtw_debug.c	/^ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_rx_ampdu_density	core/rtw_debug.c	/^ssize_t proc_set_rx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_rx_ampdu_factor	core/rtw_debug.c	/^ssize_t proc_set_rx_ampdu_factor(struct file *file, const char __user *buffer$/;"	f
-proc_set_rx_cnt_dump	core/rtw_debug.c	/^ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_rx_info_msg	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_rx_info_msg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_rx_signal	core/rtw_debug.c	/^ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_rx_stbc	core/rtw_debug.c	/^ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_scan_param	core/rtw_debug.c	/^ssize_t proc_set_scan_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_sec_cam	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_sec_cam(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_skip_band	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_skip_band(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_sreset	core/rtw_debug.c	/^ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_survey_info	core/rtw_debug.c	/^ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_tx_ampdu_density	core/rtw_debug.c	/^ssize_t proc_set_tx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_tx_auth	core/rtw_debug.c	/^ssize_t proc_set_tx_auth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_tx_bw_mode	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_tx_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_tx_deauth	core/rtw_debug.c	/^ssize_t proc_set_tx_deauth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_tx_gain_offset	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_tx_gain_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_tx_power_ext_info	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_tx_power_ext_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_tx_sa_query	core/rtw_debug.c	/^ssize_t proc_set_tx_sa_query(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_udpport	os_dep/linux/rtw_proc.c	/^static ssize_t proc_set_udpport(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f	file:
-proc_set_update_non_ocp	os_dep/linux/rtw_proc.c	/^ssize_t proc_set_update_non_ocp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_wait_hiq_empty	core/rtw_debug.c	/^ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_set_wowlan_gpio_info	core/rtw_debug.c	/^ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,$/;"	f
-proc_set_write_reg	core/rtw_debug.c	/^ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)$/;"	f
-proc_start_seq_file_test	os_dep/linux/rtw_proc.c	/^static void *proc_start_seq_file_test(struct seq_file *m, loff_t *pos)$/;"	f	file:
-proc_start_tx_power_idx	os_dep/linux/rtw_proc.c	/^static void *proc_start_tx_power_idx(struct seq_file *m, loff_t *pos)$/;"	f	file:
-proc_stop_seq_file_test	os_dep/linux/rtw_proc.c	/^void proc_stop_seq_file_test(struct seq_file *m, void *v)$/;"	f
-proc_stop_tx_power_idx	os_dep/linux/rtw_proc.c	/^static void proc_stop_tx_power_idx(struct seq_file *m, void *v)$/;"	f	file:
-proc_t	include/basic_types.h	/^	typedef NDIS_PROC proc_t;$/;"	t
-proc_t	include/basic_types.h	/^	typedef void (*proc_t)(void *);$/;"	t
-proc_tdls_display_network_info	core/rtw_debug.c	/^static int proc_tdls_display_network_info(struct seq_file *m)$/;"	f	file:
-proc_tdls_display_tdls_function_info	core/rtw_debug.c	/^static int proc_tdls_display_tdls_function_info(struct seq_file *m)$/;"	f	file:
-proc_tdls_display_tdls_sta_info	core/rtw_debug.c	/^static int proc_tdls_display_tdls_sta_info(struct seq_file *m)$/;"	f	file:
-process_80211d	core/rtw_mlme_ext.c	/^static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)$/;"	f	file:
-process_addba_req	core/rtw_wlan_util.c	/^void process_addba_req(_adapter *padapter, u8 *paddba_req, u8 *addr)$/;"	f
-process_assoc_req_p2p_ie	core/rtw_p2p.c	/^u32 process_assoc_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len, struct sta_info *psta)$/;"	f
-process_csa_ie	core/rtw_wlan_util.c	/^void process_csa_ie(_adapter *padapter, u8 *pframe, uint pkt_len)$/;"	f
-process_p2p_cross_connect_ie	core/rtw_p2p.c	/^int process_p2p_cross_connect_ie(PADAPTER padapter, u8 *IEs, u32 IELength)$/;"	f
-process_p2p_devdisc_req	core/rtw_p2p.c	/^u32 process_p2p_devdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)$/;"	f
-process_p2p_devdisc_resp	core/rtw_p2p.c	/^u32 process_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)$/;"	f
-process_p2p_group_negotation_confirm	core/rtw_p2p.c	/^u8 process_p2p_group_negotation_confirm(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)$/;"	f
-process_p2p_group_negotation_req	core/rtw_p2p.c	/^u8 process_p2p_group_negotation_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)$/;"	f
-process_p2p_group_negotation_resp	core/rtw_p2p.c	/^u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)$/;"	f
-process_p2p_presence_req	core/rtw_p2p.c	/^u8 process_p2p_presence_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)$/;"	f
-process_p2p_provdisc_req	core/rtw_p2p.c	/^u8 process_p2p_provdisc_req(struct wifidirect_info *pwdinfo,  u8 *pframe, uint len)$/;"	f
-process_p2p_provdisc_resp	core/rtw_p2p.c	/^u8 process_p2p_provdisc_resp(struct wifidirect_info *pwdinfo,  u8 *pframe)$/;"	f
-process_p2p_ps_ie	core/rtw_p2p.c	/^void process_p2p_ps_ie(PADAPTER padapter, u8 *IEs, u32 IELength)$/;"	f
-process_probe_req_p2p_ie	core/rtw_p2p.c	/^u32 process_probe_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)$/;"	f
-process_pwrbit_data	core/rtw_recv.c	/^void process_pwrbit_data(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-process_recv_indicatepkts	core/rtw_recv.c	/^int process_recv_indicatepkts(_adapter *padapter, union recv_frame *prframe)$/;"	f
-process_wmmps_data	core/rtw_recv.c	/^void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-processing	include/rtw_io.h	/^	_list		processing;$/;"	m	struct:io_queue
-processing_dev_remove	include/drv_types.h	/^	s32	processing_dev_remove;$/;"	m	struct:dvobj_priv
-profile_info	include/rtw_mlme.h	/^struct profile_info {$/;"	s
-profile_notified	hal/btc/HalBtcOutSrc.h	/^	boolean					profile_notified;$/;"	m	struct:btc_stack_info
-profileindex	include/rtw_mlme.h	/^	u8						profileindex;	\/*	Used to point to the index of profileinfo array *\/$/;"	m	struct:wifidirect_info
-profileinfo	include/rtw_mlme.h	/^	struct profile_info			profileinfo[P2P_MAX_PERSISTENT_GROUP_NUM];	\/*	Store the profile information of persistent group *\/$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::profile_info
-proto_cap	include/hal_data.h	/^	u8 proto_cap;	\/* value of PROTO_CAP_XXX *\/$/;"	m	struct:hal_spec_t
-protocol	include/ip.h	/^	__u8	protocol;$/;"	m	struct:iphdr
-protocol	include/osdep_service_bsd.h	/^	u16			protocol;$/;"	m	struct:sk_buff
-provdisc_req_issued	os_dep/linux/ioctl_cfg80211.h	/^	u8 provdisc_req_issued;$/;"	m	struct:rtw_wdev_priv
-proxim	include/drv_types.h	/^struct proxim {$/;"	s
-proxim_get_var	include/drv_types.h	/^	u8(*proxim_get_var)(_adapter *padapter, u8 type);$/;"	m	struct:proxim
-proxim_on	include/drv_types.h	/^	bool proxim_on;$/;"	m	struct:proxim
-proxim_rx	include/drv_types.h	/^	int (*proxim_rx)(_adapter *padapter,$/;"	m	struct:proxim
-proxim_support	include/drv_types.h	/^	bool proxim_support;$/;"	m	struct:proxim
-proximity	include/drv_types.h	/^	struct proxim proximity;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::proxim
-proximity_priv	include/drv_types.h	/^	void *proximity_priv;$/;"	m	struct:proxim
-prtl8192cd_priv	hal/phydm/phydm.h	/^} rtl8192cd_priv, *prtl8192cd_priv;$/;"	t	typeref:struct:rtl8192cd_priv
-prtl8192cd_priv	hal/phydm/phydm_types.h	/^	typedef struct rtl8192cd_priv	*prtl8192cd_priv;$/;"	t	typeref:struct:rtl8192cd_priv
-prv_traffic_idx	hal/phydm/phydm_edcaturbocheck.h	/^	u4Byte	prv_traffic_idx; \/\/ edca turbo$/;"	m	struct:_EDCA_TURBO_
-ps1Byte	hal/phydm/phydm_types.h	/^	typedef char					s1Byte,*ps1Byte;$/;"	t
-ps1Byte	hal/phydm/phydm_types.h	/^    typedef signed char				s1Byte,*ps1Byte;$/;"	t
-ps1Byte	hal/phydm/phydm_types.h	197;"	d
-ps1Byte	include/rtw_mp.h	122;"	d
-ps2Byte	hal/phydm/phydm_types.h	/^	typedef short					s2Byte,*ps2Byte;$/;"	t
-ps2Byte	hal/phydm/phydm_types.h	200;"	d
-ps2Byte	include/rtw_mp.h	125;"	d
-ps4Byte	hal/phydm/phydm_types.h	/^	typedef long					s4Byte,*ps4Byte;$/;"	t
-ps4Byte	hal/phydm/phydm_types.h	203;"	d
-ps4Byte	include/rtw_mp.h	128;"	d
-ps8Byte	hal/phydm/phydm_types.h	/^	typedef long long				s8Byte,*ps8Byte;$/;"	t
-ps8Byte	hal/phydm/phydm_types.h	206;"	d
-ps8Byte	include/rtw_mp.h	131;"	d
-psTdmaDuAdjType	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		psTdmaDuAdjType;$/;"	m	struct:_COEX_DM_8723A_1ANT
-psTdmaDuAdjType	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		psTdmaDuAdjType;$/;"	m	struct:_COEX_DM_8723A_2ANT
-psTdmaGlobalCnt	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte		psTdmaGlobalCnt;$/;"	m	struct:_COEX_DM_8723A_1ANT
-psTdmaMonitorCnt	hal/btc/HalBtc8723a1Ant.h	/^	u4Byte		psTdmaMonitorCnt;$/;"	m	struct:_COEX_DM_8723A_1ANT
-psTdmaPara	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		psTdmaPara[5];$/;"	m	struct:_COEX_DM_8723A_1ANT
-psTdmaPara	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		psTdmaPara[5];$/;"	m	struct:_COEX_DM_8723A_2ANT
-ps_deny	include/rtw_pwrctrl.h	/^	u32 ps_deny;$/;"	m	struct:pwrctrl_priv
-ps_flag	include/rtw_pwrctrl.h	/^	int		ps_flag; \/* used by autosuspend *\/$/;"	m	struct:pwrctrl_priv
-ps_mode	include/rtw_mp_ioctl.h	/^	u32 ps_mode;$/;"	m	struct:psmode_param
-ps_processing	include/rtw_pwrctrl.h	/^	u8 ps_processing; \/* temporarily used to mark whether in rtw_ps_processor *\/$/;"	m	struct:pwrctrl_priv
-ps_tdma_du_adj_type	hal/btc/HalBtc8192e1Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8192e_1ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8192e2Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8192e_2ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8703b1Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8703b_1ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8723b1Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8723b_1ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8723b2Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8723b_2ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8812a1Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8812a_1ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8812a2Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8812a_2ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8821a1Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8821a_1ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8821a2Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8821a_2ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8821a_csr_2ant
-ps_tdma_du_adj_type	hal/btc/HalBtc8822b1Ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8822b_1ant
-ps_tdma_du_adj_type	hal/btc/halbtc8723d1ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8723d_1ant
-ps_tdma_du_adj_type	hal/btc/halbtc8723d2ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8723d_2ant
-ps_tdma_du_adj_type	hal/btc/halbtc8821c1ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8821c_1ant
-ps_tdma_du_adj_type	hal/btc/halbtc8821c2ant.h	/^	u8		ps_tdma_du_adj_type;$/;"	m	struct:coex_dm_8821c_2ant
-ps_tdma_para	hal/btc/HalBtc8192e1Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8192e_1ant
-ps_tdma_para	hal/btc/HalBtc8192e2Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8192e_2ant
-ps_tdma_para	hal/btc/HalBtc8703b1Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8703b_1ant
-ps_tdma_para	hal/btc/HalBtc8723b1Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8723b_1ant
-ps_tdma_para	hal/btc/HalBtc8723b2Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8723b_2ant
-ps_tdma_para	hal/btc/HalBtc8812a1Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8812a_1ant
-ps_tdma_para	hal/btc/HalBtc8812a2Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8812a_2ant
-ps_tdma_para	hal/btc/HalBtc8821a1Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8821a_1ant
-ps_tdma_para	hal/btc/HalBtc8821a2Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8821a_2ant
-ps_tdma_para	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		ps_tdma_para[6];$/;"	m	struct:coex_dm_8821a_csr_2ant
-ps_tdma_para	hal/btc/HalBtc8822b1Ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8822b_1ant
-ps_tdma_para	hal/btc/halbtc8723d1ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8723d_1ant
-ps_tdma_para	hal/btc/halbtc8723d2ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8723d_2ant
-ps_tdma_para	hal/btc/halbtc8821c1ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8821c_1ant
-ps_tdma_para	hal/btc/halbtc8821c2ant.h	/^	u8		ps_tdma_para[5];$/;"	m	struct:coex_dm_8821c_2ant
-pscan_info	include/rtw_pwrctrl.h	/^	pno_scan_info_t	*pscan_info;$/;"	m	struct:pwrctrl_priv
-pscanned	include/rtw_mlme.h	/^	_list		*pscanned;$/;"	m	struct:mlme_priv
-psd_avg_num	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_avg_num;	\/* 1\/8\/16\/32 *\/$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_avg_num	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_avg_num;	\/* 1\/8\/16\/32 *\/$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_avg_num	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_avg_num;	\/* 1\/8\/16\/32 *\/$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_avg_num	hal/btc/halbtc8723d1ant.h	/^	u32			psd_avg_num;	\/* 1\/8\/16\/32 *\/$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_avg_num	hal/btc/halbtc8723d2ant.h	/^	u32			psd_avg_num;	\/* 1\/8\/16\/32 *\/$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_avg_num	hal/btc/halbtc8821c1ant.h	/^	u32			psd_avg_num;	\/* 1\/8\/16\/32 *\/$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_avg_num	hal/btc/halbtc8821c2ant.h	/^	u32			psd_avg_num;	\/* 1\/8\/16\/32 *\/$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_avg_value	hal/btc/halbtc8723d1ant.h	/^	u32			psd_avg_value;   \/* filter loop_max_value that below BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT, and average the rest*\/$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_avg_value	hal/btc/halbtc8723d2ant.h	/^	u32			psd_avg_value;   \/* filter loop_max_value that below BT_8723D_1ANT_ANTDET_PSDTHRES_1ANT, and average the rest*\/$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_band_width	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_band_width;  \/* unit: Hz *\/$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_band_width	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_band_width;  \/* unit: Hz *\/$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_band_width	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_band_width;  \/* unit: Hz *\/$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_band_width	hal/btc/halbtc8723d1ant.h	/^	u32			psd_band_width;  \/* unit: Hz *\/$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_band_width	hal/btc/halbtc8723d2ant.h	/^	u32			psd_band_width;  \/* unit: Hz *\/$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_band_width	hal/btc/halbtc8821c1ant.h	/^	u32			psd_band_width;  \/* unit: Hz *\/$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_band_width	hal/btc/halbtc8821c2ant.h	/^	u32			psd_band_width;  \/* unit: Hz *\/$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_gen_count	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_gen_count;$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_gen_count	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_gen_count;$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_gen_count	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_gen_count;$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_gen_count	hal/btc/halbtc8723d1ant.h	/^	u32			psd_gen_count;$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_gen_count	hal/btc/halbtc8723d2ant.h	/^	u32			psd_gen_count;$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_gen_count	hal/btc/halbtc8821c1ant.h	/^	u32			psd_gen_count;$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_gen_count	hal/btc/halbtc8821c2ant.h	/^	u32			psd_gen_count;$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_loop_max_value	hal/btc/halbtc8723d1ant.h	/^	u32			psd_loop_max_value[BT_8723D_1ANT_ANTDET_PSD_SWWEEPCOUNT];  \/*max value in each loop *\/$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_loop_max_value	hal/btc/halbtc8723d2ant.h	/^	u32			psd_loop_max_value[BT_8723D_2ANT_ANTDET_PSD_SWWEEPCOUNT];  \/*max value in each loop *\/$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_max_value	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_max_value;$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_max_value	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_max_value;$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_max_value	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_max_value;$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_max_value	hal/btc/halbtc8723d1ant.h	/^	u32			psd_max_value;$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_max_value	hal/btc/halbtc8723d2ant.h	/^	u32			psd_max_value;$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_max_value	hal/btc/halbtc8821c1ant.h	/^	u32			psd_max_value;$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_max_value	hal/btc/halbtc8821c2ant.h	/^	u32			psd_max_value;$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_max_value2	hal/btc/halbtc8723d1ant.h	/^	u32			psd_max_value2;$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_max_value2	hal/btc/halbtc8723d2ant.h	/^	u32			psd_max_value2;$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_max_value_point	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_max_value_point;$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_max_value_point	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_max_value_point;$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_max_value_point	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_max_value_point;$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_max_value_point	hal/btc/halbtc8723d1ant.h	/^	u32			psd_max_value_point;$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_max_value_point	hal/btc/halbtc8723d2ant.h	/^	u32			psd_max_value_point;$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_max_value_point	hal/btc/halbtc8821c1ant.h	/^	u32			psd_max_value_point;$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_max_value_point	hal/btc/halbtc8821c2ant.h	/^	u32			psd_max_value_point;$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_point	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_point;		\/* 128\/256\/512\/1024 *\/$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_point	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_point;		\/* 128\/256\/512\/1024 *\/$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_point	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_point;		\/* 128\/256\/512\/1024 *\/$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_point	hal/btc/halbtc8723d1ant.h	/^	u32			psd_point;		\/* 128\/256\/512\/1024 *\/$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_point	hal/btc/halbtc8723d2ant.h	/^	u32			psd_point;		\/* 128\/256\/512\/1024 *\/$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_point	hal/btc/halbtc8821c1ant.h	/^	u32			psd_point;		\/* 128\/256\/512\/1024 *\/$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_point	hal/btc/halbtc8821c2ant.h	/^	u32			psd_point;		\/* 128\/256\/512\/1024 *\/$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_report	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_report[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_report	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_report[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_report	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_report[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_report	hal/btc/halbtc8723d1ant.h	/^	u32			psd_report[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_report	hal/btc/halbtc8723d2ant.h	/^	u32			psd_report[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_report	hal/btc/halbtc8821c1ant.h	/^	u32			psd_report[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_report	hal/btc/halbtc8821c2ant.h	/^	u32			psd_report[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_report_max_hold	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_report_max_hold[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_report_max_hold	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_report_max_hold[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_report_max_hold	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_report_max_hold[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_report_max_hold	hal/btc/halbtc8723d1ant.h	/^	u32			psd_report_max_hold[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_report_max_hold	hal/btc/halbtc8723d2ant.h	/^	u32			psd_report_max_hold[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_report_max_hold	hal/btc/halbtc8821c1ant.h	/^	u32			psd_report_max_hold[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_report_max_hold	hal/btc/halbtc8821c2ant.h	/^	u32			psd_report_max_hold[1024];  \/* unit:dB (20logx), 0~255 *\/$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_scan	hal/btc/HalBtc8703b1Ant.c	/^static struct  psdscan_sta_8703b_1ant *psd_scan = &gl_psd_scan_8703b_1ant;$/;"	v	typeref:struct:psdscan_sta_8703b_1ant	file:
-psd_scan	hal/btc/HalBtc8723b1Ant.c	/^static struct  psdscan_sta_8723b_1ant *psd_scan = &gl_psd_scan_8723b_1ant;$/;"	v	typeref:struct:psdscan_sta_8723b_1ant	file:
-psd_scan	hal/btc/HalBtc8822b1Ant.c	/^static struct  psdscan_sta_8822b_1ant *psd_scan = &gl_psd_scan_8822b_1ant;$/;"	v	typeref:struct:psdscan_sta_8822b_1ant	file:
-psd_scan	hal/btc/halbtc8723d1ant.c	/^static struct  psdscan_sta_8723d_1ant *psd_scan = &gl_psd_scan_8723d_1ant;$/;"	v	typeref:struct:psdscan_sta_8723d_1ant	file:
-psd_scan	hal/btc/halbtc8723d2ant.c	/^static struct  psdscan_sta_8723d_2ant *psd_scan = &gl_psd_scan_8723d_2ant;$/;"	v	typeref:struct:psdscan_sta_8723d_2ant	file:
-psd_scan	hal/btc/halbtc8821c1ant.c	/^static struct  psdscan_sta_8821c_1ant 	*psd_scan = &gl_psd_scan_8821c_1ant;$/;"	v	typeref:struct:psdscan_sta_8821c_1ant	file:
-psd_scan	hal/btc/halbtc8821c2ant.c	/^static struct  psdscan_sta_8821c_2ant *psd_scan = &gl_psd_scan_8821c_2ant;$/;"	v	typeref:struct:psdscan_sta_8821c_2ant	file:
-psd_start_base	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_start_base;$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_start_base	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_start_base;$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_start_base	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_start_base;$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_start_base	hal/btc/halbtc8723d1ant.h	/^	u32			psd_start_base;$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_start_base	hal/btc/halbtc8723d2ant.h	/^	u32			psd_start_base;$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_start_base	hal/btc/halbtc8821c1ant.h	/^	u32			psd_start_base;$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_start_base	hal/btc/halbtc8821c2ant.h	/^	u32			psd_start_base;$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_start_point	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_start_point;$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_start_point	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_start_point;$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_start_point	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_start_point;$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_start_point	hal/btc/halbtc8723d1ant.h	/^	u32			psd_start_point;$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_start_point	hal/btc/halbtc8723d2ant.h	/^	u32			psd_start_point;$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_start_point	hal/btc/halbtc8821c1ant.h	/^	u32			psd_start_point;$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_start_point	hal/btc/halbtc8821c2ant.h	/^	u32			psd_start_point;$/;"	m	struct:psdscan_sta_8821c_2ant
-psd_stop_point	hal/btc/HalBtc8703b1Ant.h	/^	u32			psd_stop_point;$/;"	m	struct:psdscan_sta_8703b_1ant
-psd_stop_point	hal/btc/HalBtc8723b1Ant.h	/^	u32			psd_stop_point;$/;"	m	struct:psdscan_sta_8723b_1ant
-psd_stop_point	hal/btc/HalBtc8822b1Ant.h	/^	u32			psd_stop_point;$/;"	m	struct:psdscan_sta_8822b_1ant
-psd_stop_point	hal/btc/halbtc8723d1ant.h	/^	u32			psd_stop_point;$/;"	m	struct:psdscan_sta_8723d_1ant
-psd_stop_point	hal/btc/halbtc8723d2ant.h	/^	u32			psd_stop_point;$/;"	m	struct:psdscan_sta_8723d_2ant
-psd_stop_point	hal/btc/halbtc8821c1ant.h	/^	u32			psd_stop_point;$/;"	m	struct:psdscan_sta_8821c_1ant
-psd_stop_point	hal/btc/halbtc8821c2ant.h	/^	u32			psd_stop_point;$/;"	m	struct:psdscan_sta_8821c_2ant
-psdscan_sta_8703b_1ant	hal/btc/HalBtc8703b1Ant.h	/^struct psdscan_sta_8703b_1ant {$/;"	s
-psdscan_sta_8723b_1ant	hal/btc/HalBtc8723b1Ant.h	/^struct psdscan_sta_8723b_1ant {$/;"	s
-psdscan_sta_8723d_1ant	hal/btc/halbtc8723d1ant.h	/^struct psdscan_sta_8723d_1ant {$/;"	s
-psdscan_sta_8723d_2ant	hal/btc/halbtc8723d2ant.h	/^struct psdscan_sta_8723d_2ant {$/;"	s
-psdscan_sta_8821c_1ant	hal/btc/halbtc8821c1ant.h	/^struct psdscan_sta_8821c_1ant {$/;"	s
-psdscan_sta_8821c_2ant	hal/btc/halbtc8821c2ant.h	/^struct psdscan_sta_8821c_2ant {$/;"	s
-psdscan_sta_8822b_1ant	hal/btc/HalBtc8822b1Ant.h	/^struct psdscan_sta_8822b_1ant {$/;"	s
-pskb	include/rtw_recv.h	/^	_pkt	*pskb;$/;"	m	struct:recv_buf
-pskb	include/rtw_recv.h	/^	struct sk_buff *pskb;$/;"	m	struct:recv_buf	typeref:struct:recv_buf::sk_buff
-psmode_param	include/rtw_mp_ioctl.h	/^struct psmode_param {$/;"	s
-psta	include/rtw_recv.h	/^	struct sta_info *psta;$/;"	m	struct:recv_frame_hdr	typeref:struct:recv_frame_hdr::sta_info
-psta	include/rtw_xmit.h	/^	struct sta_info *psta;$/;"	m	struct:pkt_attrib	typeref:struct:pkt_attrib::sta_info
-pstainfo_buf	include/sta_info.h	/^	u8 *pstainfo_buf;$/;"	m	struct:sta_priv
-ptail	include/rtw_recv.h	/^	u8	*ptail;$/;"	m	struct:recv_buf
-ptail	include/rtw_xmit.h	/^	u8 *ptail;$/;"	m	struct:xmit_buf
-ptdls_sta	include/rtw_xmit.h	/^	struct sta_info *ptdls_sta;$/;"	m	struct:pkt_attrib	typeref:struct:pkt_attrib::sta_info
-pti_timer	include/sta_info.h	/^	_timer	pti_timer;$/;"	m	struct:sta_info
-pu1Byte	hal/phydm/phydm_types.h	/^	typedef unsigned char			u1Byte,*pu1Byte;$/;"	t
-pu1Byte	hal/phydm/phydm_types.h	185;"	d
-pu1Byte	include/rtw_mp.h	110;"	d
-pu1ForcedIgiLb	hal/phydm/phydm.h	/^	u1Byte			*pu1ForcedIgiLb;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-pu2Byte	hal/phydm/phydm_types.h	/^	typedef unsigned short			u2Byte,*pu2Byte;$/;"	t
-pu2Byte	hal/phydm/phydm_types.h	188;"	d
-pu2Byte	include/rtw_mp.h	113;"	d
-pu4Byte	hal/phydm/phydm_types.h	/^	typedef unsigned int			u4Byte,*pu4Byte;$/;"	t
-pu4Byte	hal/phydm/phydm_types.h	191;"	d
-pu4Byte	include/rtw_mp.h	116;"	d
-pu8Byte	hal/phydm/phydm_types.h	/^	typedef unsigned long long		u8Byte,*pu8Byte;$/;"	t
-pu8Byte	hal/phydm/phydm_types.h	194;"	d
-pu8Byte	include/rtw_mp.h	119;"	d
-purb	include/rtw_recv.h	/^	PURB	purb;$/;"	m	struct:recv_buf
-pusbdev	include/drv_types.h	/^	struct usb_device *pusbdev;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::usb_device
-pusbintf	include/drv_types.h	/^	struct usb_interface *pusbintf;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::usb_interface
-pw_save	include/rtw_recv.h	/^	u8	pw_save;$/;"	m	struct:rx_pkt_attrib
-pwdb	hal/phydm/phydm_hwconfig.h	/^	u1Byte		pwdb;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-pwdb	hal/phydm/phydm_hwconfig.h	/^	u1Byte		pwdb[4];$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-pwdb	hal/phydm/phydm_hwconfig.h	/^	u1Byte		pwdb[4];$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-pwdb_all	hal/phydm/phydm_hwconfig.h	/^	u1Byte			pwdb_all;								\/*CCK signal quality \/ OFDM pwdb all*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-pwdball	include/rtw_recv.h	/^	u8 pwdball;$/;"	m	struct:rx_raw_rssi
-pwr	include/rtl8188e_recv.h	/^	u32 pwr:1;$/;"	m	struct:rxreport_8188e
-pwrModeVal	hal/btc/HalBtcOutSrc.h	/^	u1Byte				pwrModeVal[10];$/;"	m	struct:btc_coexist
-pwr_all	include/rtw_recv.h	/^	s8 pwr_all;$/;"	m	struct:rx_raw_rssi
-pwr_index	include/rtw_mp_ioctl.h	/^	u32 pwr_index;$/;"	m	struct:txpower_param
-pwr_mode	include/rtw_pwrctrl.h	/^	u8	pwr_mode;$/;"	m	struct:pwrctrl_priv
-pwr_rpwm_timeout_handler	core/rtw_pwrctrl.c	/^static void pwr_rpwm_timeout_handler(void *FunctionContext)$/;"	f	file:
-pwr_rpwm_timer	include/rtw_pwrctrl.h	/^	_timer pwr_rpwm_timer;$/;"	m	struct:pwrctrl_priv
-pwr_state_check_cnts	include/rtw_pwrctrl.h	/^	u8		pwr_state_check_cnts;$/;"	m	struct:pwrctrl_priv
-pwr_state_check_handler	core/rtw_pwrctrl.c	/^void pwr_state_check_handler(RTW_TIMER_HDL_ARGS)$/;"	f
-pwr_state_check_interval	include/rtw_pwrctrl.h	/^	int		pwr_state_check_interval;$/;"	m	struct:pwrctrl_priv
-pwr_state_check_timer	include/rtw_pwrctrl.h	/^	_timer	pwr_state_check_timer;$/;"	m	struct:pwrctrl_priv
-pwr_status	include/rtl8188e_xmit.h	/^	u32 pwr_status:3;$/;"	m	struct:txdesc_88e
-pwr_status	include/rtl8192e_xmit.h	/^	u32 pwr_status:3;$/;"	m	struct:txdescriptor_8192e
-pwr_status	include/rtl8812a_xmit.h	/^	u32 pwr_status:3;$/;"	m	struct:txdescriptor_8812
-pwrctl_priv	include/drv_types.h	/^	struct pwrctrl_priv pwrctl_priv;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::pwrctrl_priv
-pwrctl_to_dvobj	include/drv_types.h	1081;"	d
-pwrctrl_priv	include/rtw_pwrctrl.h	/^struct pwrctrl_priv {$/;"	s
-pwrdown	include/hal_data.h	/^	BOOLEAN		pwrdown;$/;"	m	struct:hal_com_data
-pxmit_extbuf	include/rtw_xmit.h	/^	u8 *pxmit_extbuf;$/;"	m	struct:xmit_priv
-pxmit_frame_buf	include/rtw_xmit.h	/^	u8 *pxmit_frame_buf;$/;"	m	struct:xmit_priv
-pxmit_irp	include/rtw_mp.h	/^	PIRP pxmit_irp[8];$/;"	m	struct:mp_xmit_frame
-pxmit_irp	include/rtw_xmit.h	/^	PIRP		pxmit_irp[8];$/;"	m	struct:xmit_buf
-pxmit_urb	include/rtw_mp.h	/^	PURB pxmit_urb[8];$/;"	m	struct:mp_xmit_frame
-pxmit_urb	include/rtw_xmit.h	/^	PURB	pxmit_urb[8];$/;"	m	struct:xmit_buf
-pxmitbuf	include/rtw_xmit.h	/^	struct xmit_buf *pxmitbuf;$/;"	m	struct:xmit_frame	typeref:struct:xmit_frame::xmit_buf
-pxmitbuf	include/rtw_xmit.h	/^	u8 *pxmitbuf;$/;"	m	struct:xmit_priv
-pxmitbuf_irp	include/rtw_xmit.h	/^	PIRP  pxmitbuf_irp;$/;"	m	struct:xmit_buf
-pxmitbuf_mdl	include/rtw_xmit.h	/^	PMDL pxmitbuf_mdl;$/;"	m	struct:xmit_buf
-pxmitbuf_sdrp	include/rtw_xmit.h	/^	PSDBUS_REQUEST_PACKET pxmitbuf_sdrp;$/;"	m	struct:xmit_buf
-qc	include/ieee80211.h	/^	u16	qc;$/;"	m	struct:rtw_ieee80211_hdr_qos
-qc	include/ieee80211.h	/^	u16     qc;$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos
-qcnt	include/rtw_xmit.h	/^	int qcnt;$/;"	m	struct:tx_servq
-qid	include/rtw_xmit.h	/^	unsigned char	qid;$/;"	m	struct:rtw_tx_ring
-qinfo_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^struct qinfo_8723d {$/;"	s	file:
-qlen	include/osdep_service_bsd.h	/^	u32		qlen;$/;"	m	struct:sk_buff_head
-qlen	include/rtw_xmit.h	/^	u32		qlen;$/;"	m	struct:rtw_tx_ring
-qos	include/ieee80211.h	/^	uint qos;   \/* jackson *\/$/;"	m	struct:ieee80211_frag_entry
-qos	include/rtl8188e_recv.h	/^	u32 qos:1;$/;"	m	struct:rxreport_8188e
-qos	include/rtw_recv.h	/^	u8	qos;$/;"	m	struct:rx_pkt_attrib
-qos_acm	core/rtw_xmit.c	/^u8	qos_acm(u8 acm_mask, u8 priority)$/;"	f
-qos_en	include/rtw_xmit.h	/^	u8	qos_en;$/;"	m	struct:pkt_attrib
-qos_info	include/sta_info.h	/^	u8 qos_info;$/;"	m	struct:sta_info
-qos_opt_enable	include/drv_types.h	/^	u8 qos_opt_enable;$/;"	m	struct:registry_priv
-qos_option	include/rtw_qos.h	/^	unsigned int	  qos_option;	\/* bit mask option: u-apsd, s-apsd, ts, block ack...		 *\/$/;"	m	struct:qos_priv
-qos_option	include/sta_info.h	/^	uint qos_option;$/;"	m	struct:sta_info
-qos_priv	include/rtw_qos.h	/^struct	qos_priv	{$/;"	s
-qospriv	include/rtw_mlme.h	/^	struct qos_priv qospriv;$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::qos_priv
-qsel	include/rtl8188e_xmit.h	/^	u32 qsel:5;$/;"	m	struct:txdesc_88e
-qsel	include/rtl8188e_xmit.h	/^	u8 qsel:4;$/;"	m	struct:txrpt_ccx_88e
-qsel	include/rtl8192e_xmit.h	/^	u32 qsel:5;$/;"	m	struct:txdescriptor_8192e
-qsel	include/rtl8192e_xmit.h	/^	u8 qsel:4;$/;"	m	struct:txrpt_ccx_92e
-qsel	include/rtl8812a_xmit.h	/^	u32 qsel:5;$/;"	m	struct:txdescriptor_8812
-qsel	include/rtl8821a_xmit.h	/^	u32 qsel:5;$/;"	m	struct:txdescriptor_8821a
-qsel	include/rtw_xmit.h	/^	u8	qsel;$/;"	m	struct:pkt_attrib
-query_802_11_association_information	core/rtw_ioctl_query.c	/^u8 query_802_11_association_information(_adapter *padapter, PNDIS_802_11_ASSOCIATION_INFORMATION	pAssocInfo)$/;"	f
-query_802_11_capability	core/rtw_ioctl_query.c	/^query_802_11_capability($/;"	f
-query_counter	include/rtw_ioctl.h	/^	int query_counter; \/* count the number of query hits for this segment  *\/$/;"	m	struct:oid_funs_node
-query_phydm_ldpc_capability	hal/phydm/phydm_hwconfig.c	/^query_phydm_ldpc_capability($/;"	f
-query_phydm_stbc_capability	hal/phydm/phydm_hwconfig.c	/^query_phydm_stbc_capability($/;"	f
-query_phydm_trx_capability	hal/phydm/phydm_hwconfig.c	/^query_phydm_trx_capability($/;"	f
-query_phydm_txbf_capability	hal/phydm/phydm_hwconfig.c	/^query_phydm_txbf_capability($/;"	f
-query_phydm_txbf_parameters	hal/phydm/phydm_hwconfig.c	/^query_phydm_txbf_parameters($/;"	f
-query_ra_short_GI	core/rtw_xmit.c	/^u8 query_ra_short_GI(struct sta_info *psta, u8 bw)$/;"	f
-queue	include/osdep_service_bsd.h	/^		struct	list_head	queue;	$/;"	m	struct:__queue	typeref:struct:__queue::list_head
-queue	include/osdep_service_ce.h	/^	LIST_ENTRY	queue;$/;"	m	struct:__queue
-queue	include/osdep_service_linux.h	/^	struct	list_head	queue;$/;"	m	struct:__queue	typeref:struct:__queue::list_head
-queue	include/osdep_service_xp.h	/^		LIST_ENTRY	queue;	$/;"	m	struct:__queue
-queue	include/rtw_xmit.h	/^	_queue		queue;$/;"	m	struct:rtw_tx_ring
-queue_mapping	include/osdep_service_bsd.h	/^	u16			queue_mapping:16;$/;"	m	struct:sk_buff
-r871xs_drv	os_dep/linux/sdio_intf.c	/^	struct sdio_driver r871xs_drv;$/;"	m	struct:sdio_drv_priv	typeref:struct:sdio_drv_priv::sdio_driver	file:
-rADC_Buf_40_Clk_Jaguar2	include/Hal8814PhyReg.h	45;"	d
-rADC_Buf_Clk_Jaguar	include/Hal8812PhyReg.h	43;"	d
-rADC_Buf_Clk_Jaguar	include/Hal8814PhyReg.h	44;"	d
-rAGC_table_Jaguar	include/Hal8812PhyReg.h	156;"	d
-rAGC_table_Jaguar	include/Hal8814PhyReg.h	186;"	d
-rAGC_table_Jaguar2	include/Hal8814PhyReg.h	194;"	d
-rAPK	include/Hal8188EPhyReg.h	171;"	d
-rAPK	include/Hal8188FPhyReg.h	1160;"	d
-rAPK	include/Hal8188FPhyReg.h	186;"	d
-rAPK	include/Hal8192EPhyReg.h	179;"	d
-rAPK	include/Hal8703BPhyReg.h	211;"	d
-rAPK	include/Hal8723BPhyReg.h	210;"	d
-rAPK	include/Hal8723DPhyReg.h	211;"	d
-rAPK	include/Hal8812PhyReg.h	460;"	d
-rAPK	include/Hal8814PhyReg.h	583;"	d
-rA_AFEPwr1_Jaguar	include/Hal8812PhyReg.h	224;"	d
-rA_AFEPwr1_Jaguar	include/Hal8814PhyReg.h	334;"	d
-rA_AFEPwr2_Jaguar	include/Hal8812PhyReg.h	225;"	d
-rA_AFEPwr2_Jaguar	include/Hal8814PhyReg.h	335;"	d
-rA_CfoLongDump_92E	include/Hal8192EPhyReg.h	1126;"	d
-rA_CfoLongDump_Jaguar	include/Hal8812PhyReg.h	273;"	d
-rA_CfoLongDump_Jaguar	include/Hal8814PhyReg.h	383;"	d
-rA_CfoShortDump_92E	include/Hal8192EPhyReg.h	1124;"	d
-rA_CfoShortDump_Jaguar	include/Hal8812PhyReg.h	271;"	d
-rA_CfoShortDump_Jaguar	include/Hal8814PhyReg.h	381;"	d
-rA_IGI_Jaguar	include/Hal8812PhyReg.h	131;"	d
-rA_IGI_Jaguar	include/Hal8814PhyReg.h	158;"	d
-rA_IGI_Jaguar	include/rtl8822b_hal.h	127;"	d
-rA_LSSIWrite_Jaguar	include/Hal8812PhyReg.h	70;"	d
-rA_LSSIWrite_Jaguar	include/Hal8814PhyReg.h	77;"	d
-rA_LSSIWrite_Jaguar	include/rtl8822b_hal.h	130;"	d
-rA_PIRead_Jaguar	include/Hal8812PhyReg.h	65;"	d
-rA_PIRead_Jaguar	include/Hal8814PhyReg.h	72;"	d
-rA_PIRead_Jaguar	include/rtl8822b_hal.h	135;"	d
-rA_RFE_Inv_Jaguar	include/Hal8812PhyReg.h	167;"	d
-rA_RFE_Inv_Jaguar	include/Hal8814PhyReg.h	201;"	d
-rA_RFE_Jaguar	include/Hal8812PhyReg.h	169;"	d
-rA_RFE_Jaguar	include/Hal8814PhyReg.h	203;"	d
-rA_RFE_Pinmux_Jaguar	include/Hal8812PhyReg.h	165;"	d
-rA_RFE_Pinmux_Jaguar	include/Hal8814PhyReg.h	199;"	d
-rA_RFE_Pinmux_Jaguar	include/rtl8822b_hal.h	131;"	d
-rA_RFE_Sel_Jaguar2	include/Hal8814PhyReg.h	211;"	d
-rA_RSSIDump_92E	include/Hal8192EPhyReg.h	1118;"	d
-rA_RSSIDump_Jaguar	include/Hal8812PhyReg.h	265;"	d
-rA_RSSIDump_Jaguar	include/Hal8814PhyReg.h	375;"	d
-rA_RXsnrDump_92E	include/Hal8192EPhyReg.h	1122;"	d
-rA_RXsnrDump_Jaguar	include/Hal8812PhyReg.h	269;"	d
-rA_RXsnrDump_Jaguar	include/Hal8814PhyReg.h	379;"	d
-rA_Rx2Rx_BT_Jaguar	include/Hal8812PhyReg.h	231;"	d
-rA_Rx2Rx_BT_Jaguar	include/Hal8814PhyReg.h	341;"	d
-rA_RxIQC_AB_Jaguar	include/Hal8812PhyReg.h	120;"	d
-rA_RxIQC_AB_Jaguar	include/Hal8814PhyReg.h	144;"	d
-rA_RxIQC_CD_Jaguar	include/Hal8812PhyReg.h	121;"	d
-rA_RxIQC_CD_Jaguar	include/Hal8814PhyReg.h	145;"	d
-rA_Rx_OFDM_WaitRIFS_Jaguar	include/Hal8812PhyReg.h	230;"	d
-rA_Rx_OFDM_WaitRIFS_Jaguar	include/Hal8814PhyReg.h	340;"	d
-rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	include/Hal8812PhyReg.h	226;"	d
-rA_Rx_WaitCCA_Tx_CCKRFON_Jaguar	include/Hal8814PhyReg.h	336;"	d
-rA_SIRead_Jaguar	include/Hal8812PhyReg.h	67;"	d
-rA_SIRead_Jaguar	include/Hal8814PhyReg.h	74;"	d
-rA_SIRead_Jaguar	include/rtl8822b_hal.h	136;"	d
-rA_Tx2Tx_RXCCK_Jaguar	include/Hal8812PhyReg.h	229;"	d
-rA_Tx2Tx_RXCCK_Jaguar	include/Hal8814PhyReg.h	339;"	d
-rA_TxPwrTraing_Jaguar	include/Hal8812PhyReg.h	141;"	d
-rA_TxPwrTraing_Jaguar	include/Hal8814PhyReg.h	171;"	d
-rA_TxScale_Jaguar	include/Hal8812PhyReg.h	122;"	d
-rA_TxScale_Jaguar	include/Hal8814PhyReg.h	146;"	d
-rA_TxScale_Jaguar	include/rtl8822b_hal.h	123;"	d
-rA_Tx_CCKBBON_OFDMRFON_Jaguar	include/Hal8812PhyReg.h	227;"	d
-rA_Tx_CCKBBON_OFDMRFON_Jaguar	include/Hal8814PhyReg.h	337;"	d
-rA_Tx_OFDMBBON_Tx2Rx_Jaguar	include/Hal8812PhyReg.h	228;"	d
-rA_Tx_OFDMBBON_Tx2Rx_Jaguar	include/Hal8814PhyReg.h	338;"	d
-rA_pmpd_Jaguar	include/Hal8812PhyReg.h	233;"	d
-rA_pmpd_Jaguar	include/Hal8814PhyReg.h	343;"	d
-rA_sleep_nav_Jaguar	include/Hal8812PhyReg.h	232;"	d
-rA_sleep_nav_Jaguar	include/Hal8814PhyReg.h	342;"	d
-rAnapar_Ctrl_BB	include/rtw_mp_phy_regdef.h	310;"	d
-rBBrx_DFIR	include/Hal8703BPhyReg.h	145;"	d
-rBBrx_DFIR	include/Hal8723DPhyReg.h	145;"	d
-rBWIndication_Jaguar	include/Hal8812PhyReg.h	39;"	d
-rBWIndication_Jaguar	include/Hal8814PhyReg.h	41;"	d
-rB_AFEPwr1_Jaguar	include/Hal8812PhyReg.h	234;"	d
-rB_AFEPwr1_Jaguar	include/Hal8814PhyReg.h	344;"	d
-rB_AFEPwr2_Jaguar	include/Hal8812PhyReg.h	235;"	d
-rB_AFEPwr2_Jaguar	include/Hal8814PhyReg.h	345;"	d
-rB_CfoLongDump_92E	include/Hal8192EPhyReg.h	1127;"	d
-rB_CfoLongDump_Jaguar	include/Hal8812PhyReg.h	274;"	d
-rB_CfoLongDump_Jaguar	include/Hal8814PhyReg.h	384;"	d
-rB_CfoShortDump_92E	include/Hal8192EPhyReg.h	1125;"	d
-rB_CfoShortDump_Jaguar	include/Hal8812PhyReg.h	272;"	d
-rB_CfoShortDump_Jaguar	include/Hal8814PhyReg.h	382;"	d
-rB_IGI_Jaguar	include/Hal8812PhyReg.h	132;"	d
-rB_IGI_Jaguar	include/Hal8814PhyReg.h	159;"	d
-rB_IGI_Jaguar	include/rtl8822b_hal.h	148;"	d
-rB_LSSIWrite_Jaguar	include/Hal8812PhyReg.h	71;"	d
-rB_LSSIWrite_Jaguar	include/Hal8814PhyReg.h	78;"	d
-rB_LSSIWrite_Jaguar	include/rtl8822b_hal.h	149;"	d
-rB_PIRead_Jaguar	include/Hal8812PhyReg.h	66;"	d
-rB_PIRead_Jaguar	include/Hal8814PhyReg.h	73;"	d
-rB_PIRead_Jaguar	include/rtl8822b_hal.h	137;"	d
-rB_RFE_Inv_Jaguar	include/Hal8812PhyReg.h	168;"	d
-rB_RFE_Inv_Jaguar	include/Hal8814PhyReg.h	202;"	d
-rB_RFE_Jaguar	include/Hal8812PhyReg.h	170;"	d
-rB_RFE_Jaguar	include/Hal8814PhyReg.h	204;"	d
-rB_RFE_Pinmux_Jaguar	include/Hal8812PhyReg.h	166;"	d
-rB_RFE_Pinmux_Jaguar	include/Hal8814PhyReg.h	200;"	d
-rB_RFE_Pinmux_Jaguar	include/rtl8822b_hal.h	150;"	d
-rB_RSSIDump_92E	include/Hal8192EPhyReg.h	1119;"	d
-rB_RSSIDump_Jaguar	include/Hal8812PhyReg.h	266;"	d
-rB_RSSIDump_Jaguar	include/Hal8814PhyReg.h	376;"	d
-rB_RXsnrDump_92E	include/Hal8192EPhyReg.h	1123;"	d
-rB_RXsnrDump_Jaguar	include/Hal8812PhyReg.h	270;"	d
-rB_RXsnrDump_Jaguar	include/Hal8814PhyReg.h	380;"	d
-rB_Rx2Rx_BT_Jaguar	include/Hal8812PhyReg.h	241;"	d
-rB_Rx2Rx_BT_Jaguar	include/Hal8814PhyReg.h	351;"	d
-rB_RxIQC_AB_Jaguar	include/Hal8812PhyReg.h	124;"	d
-rB_RxIQC_AB_Jaguar	include/Hal8814PhyReg.h	148;"	d
-rB_RxIQC_CD_Jaguar	include/Hal8812PhyReg.h	125;"	d
-rB_RxIQC_CD_Jaguar	include/Hal8814PhyReg.h	149;"	d
-rB_Rx_OFDM_WaitRIFS_Jaguar	include/Hal8812PhyReg.h	240;"	d
-rB_Rx_OFDM_WaitRIFS_Jaguar	include/Hal8814PhyReg.h	350;"	d
-rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	include/Hal8812PhyReg.h	236;"	d
-rB_Rx_WaitCCA_Tx_CCKRFON_Jaguar	include/Hal8814PhyReg.h	346;"	d
-rB_SIRead_Jaguar	include/Hal8812PhyReg.h	68;"	d
-rB_SIRead_Jaguar	include/Hal8814PhyReg.h	75;"	d
-rB_SIRead_Jaguar	include/rtl8822b_hal.h	138;"	d
-rB_Tx2Tx_RXCCK_Jaguar	include/Hal8812PhyReg.h	239;"	d
-rB_Tx2Tx_RXCCK_Jaguar	include/Hal8814PhyReg.h	349;"	d
-rB_TxPwrTraing_Jaguar	include/Hal8812PhyReg.h	142;"	d
-rB_TxPwrTraing_Jaguar	include/Hal8814PhyReg.h	172;"	d
-rB_TxScale_Jaguar	include/Hal8812PhyReg.h	123;"	d
-rB_TxScale_Jaguar	include/Hal8814PhyReg.h	147;"	d
-rB_TxScale_Jaguar	include/rtl8822b_hal.h	147;"	d
-rB_Tx_CCKBBON_OFDMRFON_Jaguar	include/Hal8812PhyReg.h	237;"	d
-rB_Tx_CCKBBON_OFDMRFON_Jaguar	include/Hal8814PhyReg.h	347;"	d
-rB_Tx_OFDMBBON_Tx2Rx_Jaguar	include/Hal8812PhyReg.h	238;"	d
-rB_Tx_OFDMBBON_Tx2Rx_Jaguar	include/Hal8814PhyReg.h	348;"	d
-rB_pmpd_Jaguar	include/Hal8812PhyReg.h	243;"	d
-rB_pmpd_Jaguar	include/Hal8814PhyReg.h	353;"	d
-rB_sleep_nav_Jaguar	include/Hal8812PhyReg.h	242;"	d
-rB_sleep_nav_Jaguar	include/Hal8814PhyReg.h	352;"	d
-rBlue_Tooth	include/Hal8188EPhyReg.h	313;"	d
-rBlue_Tooth	include/Hal8188FPhyReg.h	314;"	d
-rBlue_Tooth	include/Hal8192EPhyReg.h	318;"	d
-rBlue_Tooth	include/Hal8703BPhyReg.h	346;"	d
-rBlue_Tooth	include/Hal8723BPhyReg.h	345;"	d
-rBlue_Tooth	include/Hal8723DPhyReg.h	346;"	d
-rBlue_Tooth	include/Hal8812PhyReg.h	567;"	d
-rBlue_Tooth	include/Hal8814PhyReg.h	690;"	d
-rBndA	include/Hal8188FPhyReg.h	1139;"	d
-rBndA	include/Hal8703BPhyReg.h	190;"	d
-rBndA	include/Hal8723BPhyReg.h	189;"	d
-rBndA	include/Hal8723DPhyReg.h	190;"	d
-rBndB	include/Hal8188FPhyReg.h	1158;"	d
-rBndB	include/Hal8703BPhyReg.h	209;"	d
-rBndB	include/Hal8723BPhyReg.h	208;"	d
-rBndB	include/Hal8723DPhyReg.h	209;"	d
-rCCAonSec_Jaguar	include/Hal8812PhyReg.h	35;"	d
-rCCAonSec_Jaguar	include/Hal8814PhyReg.h	35;"	d
-rCCAonSec_Jaguar	include/rtl8822b_hal.h	82;"	d
-rCCK0_AFESetting	include/Hal8188EPhyReg.h	139;"	d
-rCCK0_AFESetting	include/Hal8188FPhyReg.h	156;"	d
-rCCK0_AFESetting	include/Hal8192EPhyReg.h	146;"	d
-rCCK0_AFESetting	include/Hal8703BPhyReg.h	153;"	d
-rCCK0_AFESetting	include/Hal8723BPhyReg.h	152;"	d
-rCCK0_AFESetting	include/Hal8723DPhyReg.h	153;"	d
-rCCK0_AFESetting	include/Hal8812PhyReg.h	442;"	d
-rCCK0_AFESetting	include/Hal8814PhyReg.h	565;"	d
-rCCK0_AFESetting	include/rtl8822b_hal.h	110;"	d
-rCCK0_AFESetting	include/rtw_mp_phy_regdef.h	177;"	d
-rCCK0_CCA	include/Hal8188EPhyReg.h	140;"	d
-rCCK0_CCA	include/Hal8188FPhyReg.h	157;"	d
-rCCK0_CCA	include/Hal8192EPhyReg.h	147;"	d
-rCCK0_CCA	include/Hal8703BPhyReg.h	154;"	d
-rCCK0_CCA	include/Hal8723BPhyReg.h	153;"	d
-rCCK0_CCA	include/Hal8723DPhyReg.h	154;"	d
-rCCK0_CCA	include/rtw_mp_phy_regdef.h	178;"	d
-rCCK0_DSPParameter1	include/Hal8188EPhyReg.h	147;"	d
-rCCK0_DSPParameter1	include/Hal8188FPhyReg.h	164;"	d
-rCCK0_DSPParameter1	include/Hal8192EPhyReg.h	154;"	d
-rCCK0_DSPParameter1	include/Hal8703BPhyReg.h	161;"	d
-rCCK0_DSPParameter1	include/Hal8723BPhyReg.h	160;"	d
-rCCK0_DSPParameter1	include/Hal8723DPhyReg.h	161;"	d
-rCCK0_DSPParameter1	include/rtw_mp_phy_regdef.h	185;"	d
-rCCK0_DSPParameter2	include/Hal8188EPhyReg.h	148;"	d
-rCCK0_DSPParameter2	include/Hal8188FPhyReg.h	165;"	d
-rCCK0_DSPParameter2	include/Hal8192EPhyReg.h	155;"	d
-rCCK0_DSPParameter2	include/Hal8703BPhyReg.h	162;"	d
-rCCK0_DSPParameter2	include/Hal8723BPhyReg.h	161;"	d
-rCCK0_DSPParameter2	include/Hal8723DPhyReg.h	162;"	d
-rCCK0_DSPParameter2	include/Hal8812PhyReg.h	443;"	d
-rCCK0_DSPParameter2	include/Hal8814PhyReg.h	566;"	d
-rCCK0_DSPParameter2	include/rtl8822b_hal.h	112;"	d
-rCCK0_DSPParameter2	include/rtw_mp_phy_regdef.h	186;"	d
-rCCK0_DebugPort	include/Hal8188EPhyReg.h	152;"	d
-rCCK0_DebugPort	include/Hal8188FPhyReg.h	169;"	d
-rCCK0_DebugPort	include/Hal8192EPhyReg.h	159;"	d
-rCCK0_DebugPort	include/Hal8703BPhyReg.h	166;"	d
-rCCK0_DebugPort	include/Hal8723BPhyReg.h	165;"	d
-rCCK0_DebugPort	include/Hal8723DPhyReg.h	166;"	d
-rCCK0_DebugPort	include/Hal8812PhyReg.h	446;"	d
-rCCK0_DebugPort	include/Hal8814PhyReg.h	569;"	d
-rCCK0_DebugPort	include/rtl8822b_hal.h	115;"	d
-rCCK0_DebugPort	include/rtw_mp_phy_regdef.h	190;"	d
-rCCK0_FACounterLower	include/Hal8188EPhyReg.h	156;"	d
-rCCK0_FACounterLower	include/Hal8188FPhyReg.h	173;"	d
-rCCK0_FACounterLower	include/Hal8192EPhyReg.h	163;"	d
-rCCK0_FACounterLower	include/Hal8703BPhyReg.h	170;"	d
-rCCK0_FACounterLower	include/Hal8723BPhyReg.h	169;"	d
-rCCK0_FACounterLower	include/Hal8723DPhyReg.h	170;"	d
-rCCK0_FACounterLower	include/rtw_mp_phy_regdef.h	194;"	d
-rCCK0_FACounterUpper	include/Hal8188EPhyReg.h	157;"	d
-rCCK0_FACounterUpper	include/Hal8188FPhyReg.h	174;"	d
-rCCK0_FACounterUpper	include/Hal8192EPhyReg.h	164;"	d
-rCCK0_FACounterUpper	include/Hal8703BPhyReg.h	171;"	d
-rCCK0_FACounterUpper	include/Hal8723BPhyReg.h	170;"	d
-rCCK0_FACounterUpper	include/Hal8723DPhyReg.h	171;"	d
-rCCK0_FACounterUpper	include/rtw_mp_phy_regdef.h	195;"	d
-rCCK0_FalseAlarmReport	include/Hal8188EPhyReg.h	153;"	d
-rCCK0_FalseAlarmReport	include/Hal8188FPhyReg.h	170;"	d
-rCCK0_FalseAlarmReport	include/Hal8192EPhyReg.h	160;"	d
-rCCK0_FalseAlarmReport	include/Hal8703BPhyReg.h	167;"	d
-rCCK0_FalseAlarmReport	include/Hal8723BPhyReg.h	166;"	d
-rCCK0_FalseAlarmReport	include/Hal8723DPhyReg.h	167;"	d
-rCCK0_FalseAlarmReport	include/Hal8812PhyReg.h	447;"	d
-rCCK0_FalseAlarmReport	include/Hal8814PhyReg.h	570;"	d
-rCCK0_FalseAlarmReport	include/rtl8822b_hal.h	116;"	d
-rCCK0_FalseAlarmReport	include/rtw_mp_phy_regdef.h	191;"	d
-rCCK0_RxAGC1	include/Hal8188EPhyReg.h	142;"	d
-rCCK0_RxAGC1	include/Hal8188FPhyReg.h	159;"	d
-rCCK0_RxAGC1	include/Hal8192EPhyReg.h	149;"	d
-rCCK0_RxAGC1	include/Hal8703BPhyReg.h	156;"	d
-rCCK0_RxAGC1	include/Hal8723BPhyReg.h	155;"	d
-rCCK0_RxAGC1	include/Hal8723DPhyReg.h	156;"	d
-rCCK0_RxAGC1	include/rtw_mp_phy_regdef.h	180;"	d
-rCCK0_RxAGC2	include/Hal8188EPhyReg.h	143;"	d
-rCCK0_RxAGC2	include/Hal8188FPhyReg.h	160;"	d
-rCCK0_RxAGC2	include/Hal8192EPhyReg.h	150;"	d
-rCCK0_RxAGC2	include/Hal8703BPhyReg.h	157;"	d
-rCCK0_RxAGC2	include/Hal8723BPhyReg.h	156;"	d
-rCCK0_RxAGC2	include/Hal8723DPhyReg.h	157;"	d
-rCCK0_RxAGC2	include/rtw_mp_phy_regdef.h	181;"	d
-rCCK0_RxHP	include/Hal8188EPhyReg.h	145;"	d
-rCCK0_RxHP	include/Hal8188FPhyReg.h	162;"	d
-rCCK0_RxHP	include/Hal8192EPhyReg.h	152;"	d
-rCCK0_RxHP	include/Hal8703BPhyReg.h	159;"	d
-rCCK0_RxHP	include/Hal8723BPhyReg.h	158;"	d
-rCCK0_RxHP	include/Hal8723DPhyReg.h	159;"	d
-rCCK0_RxHP	include/rtw_mp_phy_regdef.h	183;"	d
-rCCK0_RxReport	include/Hal8188EPhyReg.h	155;"	d
-rCCK0_RxReport	include/Hal8188FPhyReg.h	172;"	d
-rCCK0_RxReport	include/Hal8192EPhyReg.h	162;"	d
-rCCK0_RxReport	include/Hal8703BPhyReg.h	169;"	d
-rCCK0_RxReport	include/Hal8723BPhyReg.h	168;"	d
-rCCK0_RxReport	include/Hal8723DPhyReg.h	169;"	d
-rCCK0_RxReport	include/rtw_mp_phy_regdef.h	193;"	d
-rCCK0_System	include/Hal8188EPhyReg.h	137;"	d
-rCCK0_System	include/Hal8188FPhyReg.h	154;"	d
-rCCK0_System	include/Hal8192EPhyReg.h	144;"	d
-rCCK0_System	include/Hal8703BPhyReg.h	151;"	d
-rCCK0_System	include/Hal8723BPhyReg.h	150;"	d
-rCCK0_System	include/Hal8723DPhyReg.h	151;"	d
-rCCK0_System	include/Hal8812PhyReg.h	441;"	d
-rCCK0_System	include/Hal8814PhyReg.h	564;"	d
-rCCK0_System	include/rtl8822b_hal.h	109;"	d
-rCCK0_System	include/rtw_mp_phy_regdef.h	175;"	d
-rCCK0_TRSSIReport	include/Hal8188EPhyReg.h	154;"	d
-rCCK0_TRSSIReport	include/Hal8188FPhyReg.h	171;"	d
-rCCK0_TRSSIReport	include/Hal8192EPhyReg.h	161;"	d
-rCCK0_TRSSIReport	include/Hal8703BPhyReg.h	168;"	d
-rCCK0_TRSSIReport	include/Hal8723BPhyReg.h	167;"	d
-rCCK0_TRSSIReport	include/Hal8723DPhyReg.h	168;"	d
-rCCK0_TRSSIReport	include/rtw_mp_phy_regdef.h	192;"	d
-rCCK0_TxFilter1	include/Hal8188EPhyReg.h	150;"	d
-rCCK0_TxFilter1	include/Hal8188FPhyReg.h	167;"	d
-rCCK0_TxFilter1	include/Hal8192EPhyReg.h	157;"	d
-rCCK0_TxFilter1	include/Hal8703BPhyReg.h	164;"	d
-rCCK0_TxFilter1	include/Hal8723BPhyReg.h	163;"	d
-rCCK0_TxFilter1	include/Hal8723DPhyReg.h	164;"	d
-rCCK0_TxFilter1	include/Hal8812PhyReg.h	444;"	d
-rCCK0_TxFilter1	include/Hal8814PhyReg.h	567;"	d
-rCCK0_TxFilter1	include/rtl8822b_hal.h	113;"	d
-rCCK0_TxFilter1	include/rtw_mp_phy_regdef.h	188;"	d
-rCCK0_TxFilter2	include/Hal8188EPhyReg.h	151;"	d
-rCCK0_TxFilter2	include/Hal8188FPhyReg.h	168;"	d
-rCCK0_TxFilter2	include/Hal8192EPhyReg.h	158;"	d
-rCCK0_TxFilter2	include/Hal8703BPhyReg.h	165;"	d
-rCCK0_TxFilter2	include/Hal8723BPhyReg.h	164;"	d
-rCCK0_TxFilter2	include/Hal8723DPhyReg.h	165;"	d
-rCCK0_TxFilter2	include/Hal8812PhyReg.h	445;"	d
-rCCK0_TxFilter2	include/Hal8814PhyReg.h	568;"	d
-rCCK0_TxFilter2	include/rtl8822b_hal.h	114;"	d
-rCCK0_TxFilter2	include/rtw_mp_phy_regdef.h	189;"	d
-rCCK_CCA_Jaguar	include/Hal8812PhyReg.h	137;"	d
-rCCK_CCA_Jaguar	include/Hal8814PhyReg.h	167;"	d
-rCCK_FalseAlarm_Jaguar	include/Hal8812PhyReg.h	135;"	d
-rCCK_FalseAlarm_Jaguar	include/Hal8814PhyReg.h	165;"	d
-rCCK_RX_Jaguar	include/Hal8812PhyReg.h	57;"	d
-rCCK_RX_Jaguar	include/Hal8814PhyReg.h	59;"	d
-rCCK_System_Jaguar	include/Hal8812PhyReg.h	46;"	d
-rCCK_System_Jaguar	include/Hal8814PhyReg.h	48;"	d
-rCCK_TxFilter1_Jaguar	include/Hal8812PhyReg.h	95;"	d
-rCCK_TxFilter1_Jaguar	include/Hal8814PhyReg.h	108;"	d
-rCCK_TxFilter2_Jaguar	include/Hal8812PhyReg.h	98;"	d
-rCCK_TxFilter2_Jaguar	include/Hal8814PhyReg.h	111;"	d
-rCCK_TxFilter3_Jaguar	include/Hal8812PhyReg.h	103;"	d
-rCCK_TxFilter3_Jaguar	include/Hal8814PhyReg.h	116;"	d
-rCSI_Fix_Mask0_Jaguar	include/Hal8814PhyReg.h	121;"	d
-rCSI_Fix_Mask1_Jaguar	include/Hal8814PhyReg.h	122;"	d
-rCSI_Fix_Mask2_Jaguar	include/Hal8814PhyReg.h	123;"	d
-rCSI_Fix_Mask3_Jaguar	include/Hal8814PhyReg.h	124;"	d
-rCSI_Fix_Mask4_Jaguar	include/Hal8814PhyReg.h	125;"	d
-rCSI_Fix_Mask5_Jaguar	include/Hal8814PhyReg.h	126;"	d
-rCSI_Fix_Mask6_Jaguar	include/Hal8814PhyReg.h	127;"	d
-rCSI_Fix_Mask7_Jaguar	include/Hal8814PhyReg.h	128;"	d
-rCSI_Mask_Setting1_Jaguar	include/Hal8814PhyReg.h	120;"	d
-rC_IGI_Jaguar2	include/Hal8814PhyReg.h	160;"	d
-rC_IGI_Jaguar2	include/rtl8822b_hal.h	97;"	d
-rC_LSSIWrite_Jaguar2	include/Hal8814PhyReg.h	86;"	d
-rC_PIRead_Jaguar2	include/Hal8814PhyReg.h	82;"	d
-rC_RFE_Pinmux_Jaguar	include/Hal8814PhyReg.h	209;"	d
-rC_SIRead_Jaguar2	include/Hal8814PhyReg.h	84;"	d
-rC_TxScale_Jaguar2	include/Hal8814PhyReg.h	153;"	d
-rC_TxScale_Jaguar2	include/rtl8822b_hal.h	96;"	d
-rConfig_AntA	include/Hal8188EPhyReg.h	166;"	d
-rConfig_AntA	include/Hal8188FPhyReg.h	1142;"	d
-rConfig_AntA	include/Hal8188FPhyReg.h	181;"	d
-rConfig_AntA	include/Hal8192EPhyReg.h	174;"	d
-rConfig_AntA	include/Hal8703BPhyReg.h	193;"	d
-rConfig_AntA	include/Hal8723BPhyReg.h	192;"	d
-rConfig_AntA	include/Hal8723DPhyReg.h	193;"	d
-rConfig_AntA	include/Hal8812PhyReg.h	455;"	d
-rConfig_AntA	include/Hal8814PhyReg.h	578;"	d
-rConfig_AntB	include/Hal8188EPhyReg.h	167;"	d
-rConfig_AntB	include/Hal8188FPhyReg.h	1143;"	d
-rConfig_AntB	include/Hal8188FPhyReg.h	182;"	d
-rConfig_AntB	include/Hal8192EPhyReg.h	175;"	d
-rConfig_AntB	include/Hal8703BPhyReg.h	194;"	d
-rConfig_AntB	include/Hal8723BPhyReg.h	193;"	d
-rConfig_AntB	include/Hal8723DPhyReg.h	194;"	d
-rConfig_AntB	include/Hal8812PhyReg.h	456;"	d
-rConfig_AntB	include/Hal8814PhyReg.h	579;"	d
-rConfig_Pmpd_AntA	include/Hal8188EPhyReg.h	164;"	d
-rConfig_Pmpd_AntA	include/Hal8188FPhyReg.h	1136;"	d
-rConfig_Pmpd_AntA	include/Hal8188FPhyReg.h	180;"	d
-rConfig_Pmpd_AntA	include/Hal8192EPhyReg.h	171;"	d
-rConfig_Pmpd_AntA	include/Hal8703BPhyReg.h	187;"	d
-rConfig_Pmpd_AntA	include/Hal8723BPhyReg.h	186;"	d
-rConfig_Pmpd_AntA	include/Hal8723DPhyReg.h	187;"	d
-rConfig_Pmpd_AntA	include/Hal8812PhyReg.h	454;"	d
-rConfig_Pmpd_AntA	include/Hal8814PhyReg.h	577;"	d
-rConfig_Pmpd_AntB	include/Hal8188EPhyReg.h	170;"	d
-rConfig_Pmpd_AntB	include/Hal8188FPhyReg.h	1156;"	d
-rConfig_Pmpd_AntB	include/Hal8188FPhyReg.h	185;"	d
-rConfig_Pmpd_AntB	include/Hal8192EPhyReg.h	178;"	d
-rConfig_Pmpd_AntB	include/Hal8703BPhyReg.h	207;"	d
-rConfig_Pmpd_AntB	include/Hal8723BPhyReg.h	206;"	d
-rConfig_Pmpd_AntB	include/Hal8723DPhyReg.h	207;"	d
-rConfig_Pmpd_AntB	include/Hal8812PhyReg.h	459;"	d
-rConfig_Pmpd_AntB	include/Hal8814PhyReg.h	582;"	d
-rConfig_ram64x16	include/Hal8188EPhyReg.h	165;"	d
-rConfig_ram64x16	include/Hal8188FPhyReg.h	1137;"	d
-rConfig_ram64x16	include/Hal8192EPhyReg.h	172;"	d
-rConfig_ram64x16	include/Hal8703BPhyReg.h	188;"	d
-rConfig_ram64x16	include/Hal8723BPhyReg.h	187;"	d
-rConfig_ram64x16	include/Hal8723DPhyReg.h	188;"	d
-rDMA_trigger_Jaguar2	include/Hal8814PhyReg.h	195;"	d
-rDPDT_control	include/Hal8188FPhyReg.h	1116;"	d
-rDPDT_control	include/Hal8703BPhyReg.h	142;"	d
-rDPDT_control	include/Hal8723BPhyReg.h	142;"	d
-rDPDT_control	include/Hal8723DPhyReg.h	142;"	d
-rD_IGI_Jaguar2	include/Hal8814PhyReg.h	161;"	d
-rD_IGI_Jaguar2	include/rtl8822b_hal.h	119;"	d
-rD_LSSIWrite_Jaguar2	include/Hal8814PhyReg.h	87;"	d
-rD_PIRead_Jaguar2	include/Hal8814PhyReg.h	83;"	d
-rD_RFE_Pinmux_Jaguar	include/Hal8814PhyReg.h	210;"	d
-rD_SIRead_Jaguar2	include/Hal8814PhyReg.h	85;"	d
-rD_TxScale_Jaguar2	include/Hal8814PhyReg.h	154;"	d
-rD_TxScale_Jaguar2	include/rtl8822b_hal.h	118;"	d
-rEDCCA_Jaguar	include/Hal8812PhyReg.h	154;"	d
-rEDCCA_Jaguar	include/Hal8814PhyReg.h	184;"	d
-rFPGA0_AdDaClockEn	include/Hal8188EPhyReg.h	110;"	d
-rFPGA0_AdDaClockEn	include/Hal8192EPhyReg.h	117;"	d
-rFPGA0_AdDaClockEn	include/Hal8812PhyReg.h	424;"	d
-rFPGA0_AdDaClockEn	include/Hal8814PhyReg.h	534;"	d
-rFPGA0_AnalogParameter1	include/Hal8188EPhyReg.h	107;"	d
-rFPGA0_AnalogParameter1	include/Hal8188FPhyReg.h	124;"	d
-rFPGA0_AnalogParameter1	include/Hal8192EPhyReg.h	114;"	d
-rFPGA0_AnalogParameter1	include/Hal8703BPhyReg.h	119;"	d
-rFPGA0_AnalogParameter1	include/Hal8723BPhyReg.h	119;"	d
-rFPGA0_AnalogParameter1	include/Hal8723DPhyReg.h	119;"	d
-rFPGA0_AnalogParameter1	include/Hal8812PhyReg.h	421;"	d
-rFPGA0_AnalogParameter1	include/Hal8814PhyReg.h	531;"	d
-rFPGA0_AnalogParameter1	include/rtw_mp_phy_regdef.h	147;"	d
-rFPGA0_AnalogParameter2	include/Hal8188EPhyReg.h	108;"	d
-rFPGA0_AnalogParameter2	include/Hal8188FPhyReg.h	125;"	d
-rFPGA0_AnalogParameter2	include/Hal8192EPhyReg.h	115;"	d
-rFPGA0_AnalogParameter2	include/Hal8703BPhyReg.h	120;"	d
-rFPGA0_AnalogParameter2	include/Hal8723BPhyReg.h	120;"	d
-rFPGA0_AnalogParameter2	include/Hal8723DPhyReg.h	120;"	d
-rFPGA0_AnalogParameter2	include/Hal8812PhyReg.h	422;"	d
-rFPGA0_AnalogParameter2	include/Hal8814PhyReg.h	532;"	d
-rFPGA0_AnalogParameter2	include/rtw_mp_phy_regdef.h	148;"	d
-rFPGA0_AnalogParameter3	include/Hal8188EPhyReg.h	109;"	d
-rFPGA0_AnalogParameter3	include/Hal8188FPhyReg.h	126;"	d
-rFPGA0_AnalogParameter3	include/Hal8192EPhyReg.h	116;"	d
-rFPGA0_AnalogParameter3	include/Hal8703BPhyReg.h	121;"	d
-rFPGA0_AnalogParameter3	include/Hal8723BPhyReg.h	121;"	d
-rFPGA0_AnalogParameter3	include/Hal8723DPhyReg.h	121;"	d
-rFPGA0_AnalogParameter3	include/Hal8812PhyReg.h	423;"	d
-rFPGA0_AnalogParameter3	include/Hal8814PhyReg.h	533;"	d
-rFPGA0_AnalogParameter3	include/rtw_mp_phy_regdef.h	149;"	d
-rFPGA0_AnalogParameter4	include/Hal8188EPhyReg.h	111;"	d
-rFPGA0_AnalogParameter4	include/Hal8188FPhyReg.h	127;"	d
-rFPGA0_AnalogParameter4	include/Hal8192EPhyReg.h	118;"	d
-rFPGA0_AnalogParameter4	include/Hal8703BPhyReg.h	122;"	d
-rFPGA0_AnalogParameter4	include/Hal8723BPhyReg.h	122;"	d
-rFPGA0_AnalogParameter4	include/Hal8723DPhyReg.h	122;"	d
-rFPGA0_AnalogParameter4	include/Hal8812PhyReg.h	425;"	d
-rFPGA0_AnalogParameter4	include/Hal8814PhyReg.h	535;"	d
-rFPGA0_AnalogParameter4	include/rtl8822b_hal.h	92;"	d
-rFPGA0_AnalogParameter4	include/rtw_mp_phy_regdef.h	150;"	d
-rFPGA0_IQK	include/Hal8188EPhyReg.h	297;"	d
-rFPGA0_IQK	include/Hal8188FPhyReg.h	298;"	d
-rFPGA0_IQK	include/Hal8192EPhyReg.h	302;"	d
-rFPGA0_IQK	include/Hal8703BPhyReg.h	330;"	d
-rFPGA0_IQK	include/Hal8723BPhyReg.h	329;"	d
-rFPGA0_IQK	include/Hal8723DPhyReg.h	330;"	d
-rFPGA0_IQK	include/Hal8812PhyReg.h	551;"	d
-rFPGA0_IQK	include/Hal8814PhyReg.h	674;"	d
-rFPGA0_PSDFunction	include/Hal8188EPhyReg.h	78;"	d
-rFPGA0_PSDFunction	include/Hal8188FPhyReg.h	84;"	d
-rFPGA0_PSDFunction	include/Hal8192EPhyReg.h	84;"	d
-rFPGA0_PSDFunction	include/Hal8703BPhyReg.h	79;"	d
-rFPGA0_PSDFunction	include/Hal8723BPhyReg.h	79;"	d
-rFPGA0_PSDFunction	include/Hal8723DPhyReg.h	79;"	d
-rFPGA0_PSDFunction	include/Hal8812PhyReg.h	407;"	d
-rFPGA0_PSDFunction	include/Hal8814PhyReg.h	514;"	d
-rFPGA0_PSDFunction	include/rtw_mp_phy_regdef.h	108;"	d
-rFPGA0_PSDReport	include/Hal8188EPhyReg.h	118;"	d
-rFPGA0_PSDReport	include/Hal8188FPhyReg.h	134;"	d
-rFPGA0_PSDReport	include/Hal8192EPhyReg.h	125;"	d
-rFPGA0_PSDReport	include/Hal8703BPhyReg.h	129;"	d
-rFPGA0_PSDReport	include/Hal8723BPhyReg.h	129;"	d
-rFPGA0_PSDReport	include/Hal8723DPhyReg.h	129;"	d
-rFPGA0_PSDReport	include/Hal8814PhyReg.h	543;"	d
-rFPGA0_PSDReport	include/rtw_mp_phy_regdef.h	157;"	d
-rFPGA0_RFMOD	include/Hal8188EPhyReg.h	75;"	d
-rFPGA0_RFMOD	include/Hal8188FPhyReg.h	81;"	d
-rFPGA0_RFMOD	include/Hal8192EPhyReg.h	81;"	d
-rFPGA0_RFMOD	include/Hal8703BPhyReg.h	76;"	d
-rFPGA0_RFMOD	include/Hal8723BPhyReg.h	76;"	d
-rFPGA0_RFMOD	include/Hal8723DPhyReg.h	76;"	d
-rFPGA0_RFMOD	include/Hal8812PhyReg.h	404;"	d
-rFPGA0_RFMOD	include/Hal8814PhyReg.h	511;"	d
-rFPGA0_RFMOD	include/rtl8822b_hal.h	71;"	d
-rFPGA0_RFMOD	include/rtw_mp_phy_regdef.h	105;"	d
-rFPGA0_RFSleepUpParameter	include/Hal8188EPhyReg.h	94;"	d
-rFPGA0_RFSleepUpParameter	include/Hal8188FPhyReg.h	107;"	d
-rFPGA0_RFSleepUpParameter	include/Hal8192EPhyReg.h	100;"	d
-rFPGA0_RFSleepUpParameter	include/Hal8703BPhyReg.h	102;"	d
-rFPGA0_RFSleepUpParameter	include/Hal8723BPhyReg.h	102;"	d
-rFPGA0_RFSleepUpParameter	include/Hal8723DPhyReg.h	102;"	d
-rFPGA0_RFSleepUpParameter	include/rtw_mp_phy_regdef.h	131;"	d
-rFPGA0_RFTiming1	include/Hal8188EPhyReg.h	82;"	d
-rFPGA0_RFTiming1	include/Hal8188FPhyReg.h	88;"	d
-rFPGA0_RFTiming1	include/Hal8192EPhyReg.h	88;"	d
-rFPGA0_RFTiming1	include/Hal8703BPhyReg.h	83;"	d
-rFPGA0_RFTiming1	include/Hal8723BPhyReg.h	83;"	d
-rFPGA0_RFTiming1	include/Hal8723DPhyReg.h	83;"	d
-rFPGA0_RFTiming1	include/rtw_mp_phy_regdef.h	112;"	d
-rFPGA0_RFTiming2	include/Hal8188EPhyReg.h	83;"	d
-rFPGA0_RFTiming2	include/Hal8188FPhyReg.h	89;"	d
-rFPGA0_RFTiming2	include/Hal8192EPhyReg.h	89;"	d
-rFPGA0_RFTiming2	include/Hal8703BPhyReg.h	84;"	d
-rFPGA0_RFTiming2	include/Hal8723BPhyReg.h	84;"	d
-rFPGA0_RFTiming2	include/Hal8723DPhyReg.h	84;"	d
-rFPGA0_RFTiming2	include/rtw_mp_phy_regdef.h	113;"	d
-rFPGA0_RFWakeUpParameter	include/Hal8188EPhyReg.h	93;"	d
-rFPGA0_RFWakeUpParameter	include/Hal8188FPhyReg.h	106;"	d
-rFPGA0_RFWakeUpParameter	include/Hal8192EPhyReg.h	99;"	d
-rFPGA0_RFWakeUpParameter	include/Hal8703BPhyReg.h	101;"	d
-rFPGA0_RFWakeUpParameter	include/Hal8723BPhyReg.h	101;"	d
-rFPGA0_RFWakeUpParameter	include/Hal8723DPhyReg.h	101;"	d
-rFPGA0_RFWakeUpParameter	include/rtw_mp_phy_regdef.h	130;"	d
-rFPGA0_TxGainStage	include/Hal8188EPhyReg.h	80;"	d
-rFPGA0_TxGainStage	include/Hal8188FPhyReg.h	86;"	d
-rFPGA0_TxGainStage	include/Hal8192EPhyReg.h	86;"	d
-rFPGA0_TxGainStage	include/Hal8703BPhyReg.h	81;"	d
-rFPGA0_TxGainStage	include/Hal8723BPhyReg.h	81;"	d
-rFPGA0_TxGainStage	include/Hal8723DPhyReg.h	81;"	d
-rFPGA0_TxGainStage	include/Hal8812PhyReg.h	408;"	d
-rFPGA0_TxGainStage	include/Hal8814PhyReg.h	515;"	d
-rFPGA0_TxGainStage	include/rtl8822b_hal.h	74;"	d
-rFPGA0_TxGainStage	include/rtw_mp_phy_regdef.h	110;"	d
-rFPGA0_TxInfo	include/Hal8188EPhyReg.h	77;"	d
-rFPGA0_TxInfo	include/Hal8188FPhyReg.h	83;"	d
-rFPGA0_TxInfo	include/Hal8192EPhyReg.h	83;"	d
-rFPGA0_TxInfo	include/Hal8703BPhyReg.h	78;"	d
-rFPGA0_TxInfo	include/Hal8723BPhyReg.h	78;"	d
-rFPGA0_TxInfo	include/Hal8723DPhyReg.h	78;"	d
-rFPGA0_TxInfo	include/Hal8812PhyReg.h	406;"	d
-rFPGA0_TxInfo	include/Hal8814PhyReg.h	513;"	d
-rFPGA0_TxInfo	include/rtl8822b_hal.h	72;"	d
-rFPGA0_TxInfo	include/rtw_mp_phy_regdef.h	107;"	d
-rFPGA0_XAB_RFInterfaceRB	include/Hal8188EPhyReg.h	121;"	d
-rFPGA0_XAB_RFInterfaceRB	include/Hal8188FPhyReg.h	137;"	d
-rFPGA0_XAB_RFInterfaceRB	include/Hal8192EPhyReg.h	128;"	d
-rFPGA0_XAB_RFInterfaceRB	include/Hal8703BPhyReg.h	132;"	d
-rFPGA0_XAB_RFInterfaceRB	include/Hal8723BPhyReg.h	132;"	d
-rFPGA0_XAB_RFInterfaceRB	include/Hal8723DPhyReg.h	132;"	d
-rFPGA0_XAB_RFInterfaceRB	include/Hal8814PhyReg.h	546;"	d
-rFPGA0_XAB_RFInterfaceRB	include/rtw_mp_phy_regdef.h	158;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8188EPhyReg.h	101;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8188FPhyReg.h	118;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8192EPhyReg.h	108;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8703BPhyReg.h	113;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8723BPhyReg.h	113;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8723DPhyReg.h	113;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8812PhyReg.h	81;"	d
-rFPGA0_XAB_RFInterfaceSW	include/Hal8814PhyReg.h	94;"	d
-rFPGA0_XAB_RFInterfaceSW	include/rtl8822b_hal.h	90;"	d
-rFPGA0_XAB_RFInterfaceSW	include/rtw_mp_phy_regdef.h	141;"	d
-rFPGA0_XAB_RFParameter	include/Hal8188EPhyReg.h	104;"	d
-rFPGA0_XAB_RFParameter	include/Hal8188FPhyReg.h	121;"	d
-rFPGA0_XAB_RFParameter	include/Hal8192EPhyReg.h	111;"	d
-rFPGA0_XAB_RFParameter	include/Hal8703BPhyReg.h	116;"	d
-rFPGA0_XAB_RFParameter	include/Hal8723BPhyReg.h	116;"	d
-rFPGA0_XAB_RFParameter	include/Hal8723DPhyReg.h	116;"	d
-rFPGA0_XAB_RFParameter	include/Hal8812PhyReg.h	418;"	d
-rFPGA0_XAB_RFParameter	include/Hal8814PhyReg.h	528;"	d
-rFPGA0_XAB_RFParameter	include/rtl8822b_hal.h	91;"	d
-rFPGA0_XAB_RFParameter	include/rtw_mp_phy_regdef.h	144;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8188EPhyReg.h	96;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8188FPhyReg.h	109;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8192EPhyReg.h	102;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8703BPhyReg.h	104;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8723BPhyReg.h	104;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8723DPhyReg.h	104;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8812PhyReg.h	415;"	d
-rFPGA0_XAB_SwitchControl	include/Hal8814PhyReg.h	525;"	d
-rFPGA0_XAB_SwitchControl	include/rtw_mp_phy_regdef.h	133;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8188EPhyReg.h	85;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8188FPhyReg.h	91;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8192EPhyReg.h	91;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8703BPhyReg.h	86;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8723BPhyReg.h	86;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8723DPhyReg.h	86;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8812PhyReg.h	410;"	d
-rFPGA0_XA_HSSIParameter1	include/Hal8814PhyReg.h	517;"	d
-rFPGA0_XA_HSSIParameter1	include/rtl8822b_hal.h	75;"	d
-rFPGA0_XA_HSSIParameter1	include/rtw_mp_phy_regdef.h	117;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8188EPhyReg.h	86;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8188FPhyReg.h	92;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8192EPhyReg.h	92;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8703BPhyReg.h	87;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8723BPhyReg.h	87;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8723DPhyReg.h	87;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8812PhyReg.h	411;"	d
-rFPGA0_XA_HSSIParameter2	include/Hal8814PhyReg.h	518;"	d
-rFPGA0_XA_HSSIParameter2	include/rtl8822b_hal.h	76;"	d
-rFPGA0_XA_HSSIParameter2	include/rtw_mp_phy_regdef.h	118;"	d
-rFPGA0_XA_LSSIParameter	include/Hal8188EPhyReg.h	90;"	d
-rFPGA0_XA_LSSIParameter	include/Hal8188FPhyReg.h	103;"	d
-rFPGA0_XA_LSSIParameter	include/Hal8192EPhyReg.h	96;"	d
-rFPGA0_XA_LSSIParameter	include/Hal8703BPhyReg.h	98;"	d
-rFPGA0_XA_LSSIParameter	include/Hal8723BPhyReg.h	98;"	d
-rFPGA0_XA_LSSIParameter	include/Hal8723DPhyReg.h	98;"	d
-rFPGA0_XA_LSSIParameter	include/Hal8814PhyReg.h	522;"	d
-rFPGA0_XA_LSSIParameter	include/rtw_mp_phy_regdef.h	125;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8188EPhyReg.h	113;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8188FPhyReg.h	129;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8192EPhyReg.h	120;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8703BPhyReg.h	124;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8723BPhyReg.h	124;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8723DPhyReg.h	124;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8812PhyReg.h	41;"	d
-rFPGA0_XA_LSSIReadBack	include/Hal8814PhyReg.h	537;"	d
-rFPGA0_XA_LSSIReadBack	include/rtw_mp_phy_regdef.h	152;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8188EPhyReg.h	99;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8188FPhyReg.h	112;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8192EPhyReg.h	105;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8703BPhyReg.h	107;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8723BPhyReg.h	107;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8723DPhyReg.h	107;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8812PhyReg.h	78;"	d
-rFPGA0_XA_RFInterfaceOE	include/Hal8814PhyReg.h	91;"	d
-rFPGA0_XA_RFInterfaceOE	include/rtl8822b_hal.h	86;"	d
-rFPGA0_XA_RFInterfaceOE	include/rtw_mp_phy_regdef.h	136;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8188EPhyReg.h	87;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8188FPhyReg.h	93;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8192EPhyReg.h	93;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8703BPhyReg.h	88;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8723BPhyReg.h	88;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8723DPhyReg.h	88;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8812PhyReg.h	412;"	d
-rFPGA0_XB_HSSIParameter1	include/Hal8814PhyReg.h	519;"	d
-rFPGA0_XB_HSSIParameter1	include/rtl8822b_hal.h	77;"	d
-rFPGA0_XB_HSSIParameter1	include/rtw_mp_phy_regdef.h	119;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8188EPhyReg.h	88;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8188FPhyReg.h	94;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8192EPhyReg.h	94;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8703BPhyReg.h	89;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8723BPhyReg.h	89;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8723DPhyReg.h	89;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8812PhyReg.h	413;"	d
-rFPGA0_XB_HSSIParameter2	include/Hal8814PhyReg.h	520;"	d
-rFPGA0_XB_HSSIParameter2	include/rtl8822b_hal.h	78;"	d
-rFPGA0_XB_HSSIParameter2	include/rtw_mp_phy_regdef.h	120;"	d
-rFPGA0_XB_LSSIParameter	include/Hal8188EPhyReg.h	91;"	d
-rFPGA0_XB_LSSIParameter	include/Hal8188FPhyReg.h	104;"	d
-rFPGA0_XB_LSSIParameter	include/Hal8192EPhyReg.h	97;"	d
-rFPGA0_XB_LSSIParameter	include/Hal8703BPhyReg.h	99;"	d
-rFPGA0_XB_LSSIParameter	include/Hal8723BPhyReg.h	99;"	d
-rFPGA0_XB_LSSIParameter	include/Hal8723DPhyReg.h	99;"	d
-rFPGA0_XB_LSSIParameter	include/Hal8814PhyReg.h	523;"	d
-rFPGA0_XB_LSSIParameter	include/rtw_mp_phy_regdef.h	126;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8188EPhyReg.h	114;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8188FPhyReg.h	130;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8192EPhyReg.h	121;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8703BPhyReg.h	125;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8723BPhyReg.h	125;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8723DPhyReg.h	125;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8812PhyReg.h	426;"	d
-rFPGA0_XB_LSSIReadBack	include/Hal8814PhyReg.h	538;"	d
-rFPGA0_XB_LSSIReadBack	include/rtl8822b_hal.h	93;"	d
-rFPGA0_XB_LSSIReadBack	include/rtw_mp_phy_regdef.h	153;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8188EPhyReg.h	100;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8188FPhyReg.h	113;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8192EPhyReg.h	106;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8703BPhyReg.h	108;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8723BPhyReg.h	108;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8723DPhyReg.h	108;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8812PhyReg.h	79;"	d
-rFPGA0_XB_RFInterfaceOE	include/Hal8814PhyReg.h	92;"	d
-rFPGA0_XB_RFInterfaceOE	include/rtl8822b_hal.h	87;"	d
-rFPGA0_XB_RFInterfaceOE	include/rtw_mp_phy_regdef.h	137;"	d
-rFPGA0_XCD_RFInterfaceRB	include/Hal8188EPhyReg.h	122;"	d
-rFPGA0_XCD_RFInterfaceRB	include/Hal8188FPhyReg.h	138;"	d
-rFPGA0_XCD_RFInterfaceRB	include/Hal8192EPhyReg.h	129;"	d
-rFPGA0_XCD_RFInterfaceRB	include/Hal8703BPhyReg.h	133;"	d
-rFPGA0_XCD_RFInterfaceRB	include/Hal8723BPhyReg.h	133;"	d
-rFPGA0_XCD_RFInterfaceRB	include/Hal8723DPhyReg.h	133;"	d
-rFPGA0_XCD_RFInterfaceRB	include/Hal8814PhyReg.h	547;"	d
-rFPGA0_XCD_RFInterfaceRB	include/rtw_mp_phy_regdef.h	159;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8188EPhyReg.h	102;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8188FPhyReg.h	119;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8192EPhyReg.h	109;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8703BPhyReg.h	114;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8723BPhyReg.h	114;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8723DPhyReg.h	114;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8812PhyReg.h	82;"	d
-rFPGA0_XCD_RFInterfaceSW	include/Hal8814PhyReg.h	95;"	d
-rFPGA0_XCD_RFInterfaceSW	include/rtw_mp_phy_regdef.h	142;"	d
-rFPGA0_XCD_RFPara	include/Hal8812PhyReg.h	427;"	d
-rFPGA0_XCD_RFPara	include/Hal8814PhyReg.h	542;"	d
-rFPGA0_XCD_RFParameter	include/Hal8188EPhyReg.h	105;"	d
-rFPGA0_XCD_RFParameter	include/Hal8188FPhyReg.h	122;"	d
-rFPGA0_XCD_RFParameter	include/Hal8192EPhyReg.h	112;"	d
-rFPGA0_XCD_RFParameter	include/Hal8703BPhyReg.h	117;"	d
-rFPGA0_XCD_RFParameter	include/Hal8723BPhyReg.h	117;"	d
-rFPGA0_XCD_RFParameter	include/Hal8723DPhyReg.h	117;"	d
-rFPGA0_XCD_RFParameter	include/Hal8812PhyReg.h	419;"	d
-rFPGA0_XCD_RFParameter	include/Hal8814PhyReg.h	529;"	d
-rFPGA0_XCD_RFParameter	include/rtw_mp_phy_regdef.h	145;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8188EPhyReg.h	97;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8188FPhyReg.h	110;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8192EPhyReg.h	103;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8703BPhyReg.h	105;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8723BPhyReg.h	105;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8723DPhyReg.h	105;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8812PhyReg.h	416;"	d
-rFPGA0_XCD_SwitchControl	include/Hal8814PhyReg.h	526;"	d
-rFPGA0_XCD_SwitchControl	include/rtw_mp_phy_regdef.h	134;"	d
-rFPGA0_XC_HSSIParameter1	include/rtw_mp_phy_regdef.h	121;"	d
-rFPGA0_XC_HSSIParameter2	include/rtw_mp_phy_regdef.h	122;"	d
-rFPGA0_XC_LSSIParameter	include/rtw_mp_phy_regdef.h	127;"	d
-rFPGA0_XC_LSSIReadBack	include/Hal8188EPhyReg.h	115;"	d
-rFPGA0_XC_LSSIReadBack	include/Hal8188FPhyReg.h	131;"	d
-rFPGA0_XC_LSSIReadBack	include/Hal8192EPhyReg.h	122;"	d
-rFPGA0_XC_LSSIReadBack	include/Hal8703BPhyReg.h	126;"	d
-rFPGA0_XC_LSSIReadBack	include/Hal8723BPhyReg.h	126;"	d
-rFPGA0_XC_LSSIReadBack	include/Hal8723DPhyReg.h	126;"	d
-rFPGA0_XC_LSSIReadBack	include/Hal8814PhyReg.h	539;"	d
-rFPGA0_XC_LSSIReadBack	include/rtw_mp_phy_regdef.h	154;"	d
-rFPGA0_XC_RFInterfaceOE	include/rtw_mp_phy_regdef.h	138;"	d
-rFPGA0_XD_HSSIParameter1	include/rtw_mp_phy_regdef.h	123;"	d
-rFPGA0_XD_HSSIParameter2	include/rtw_mp_phy_regdef.h	124;"	d
-rFPGA0_XD_LSSIParameter	include/rtw_mp_phy_regdef.h	128;"	d
-rFPGA0_XD_LSSIReadBack	include/Hal8188EPhyReg.h	116;"	d
-rFPGA0_XD_LSSIReadBack	include/Hal8188FPhyReg.h	132;"	d
-rFPGA0_XD_LSSIReadBack	include/Hal8192EPhyReg.h	123;"	d
-rFPGA0_XD_LSSIReadBack	include/Hal8703BPhyReg.h	127;"	d
-rFPGA0_XD_LSSIReadBack	include/Hal8723BPhyReg.h	127;"	d
-rFPGA0_XD_LSSIReadBack	include/Hal8723DPhyReg.h	127;"	d
-rFPGA0_XD_LSSIReadBack	include/Hal8814PhyReg.h	540;"	d
-rFPGA0_XD_LSSIReadBack	include/rtw_mp_phy_regdef.h	155;"	d
-rFPGA0_XD_RFInterfaceOE	include/rtw_mp_phy_regdef.h	139;"	d
-rFPGA1_DebugSelect	include/Hal8188EPhyReg.h	130;"	d
-rFPGA1_DebugSelect	include/Hal8188FPhyReg.h	146;"	d
-rFPGA1_DebugSelect	include/Hal8192EPhyReg.h	137;"	d
-rFPGA1_DebugSelect	include/Hal8703BPhyReg.h	140;"	d
-rFPGA1_DebugSelect	include/Hal8723BPhyReg.h	140;"	d
-rFPGA1_DebugSelect	include/Hal8723DPhyReg.h	140;"	d
-rFPGA1_DebugSelect	include/Hal8812PhyReg.h	435;"	d
-rFPGA1_DebugSelect	include/Hal8814PhyReg.h	556;"	d
-rFPGA1_DebugSelect	include/rtw_mp_phy_regdef.h	167;"	d
-rFPGA1_RFMOD	include/Hal8188EPhyReg.h	127;"	d
-rFPGA1_RFMOD	include/Hal8188FPhyReg.h	143;"	d
-rFPGA1_RFMOD	include/Hal8192EPhyReg.h	134;"	d
-rFPGA1_RFMOD	include/Hal8703BPhyReg.h	138;"	d
-rFPGA1_RFMOD	include/Hal8723BPhyReg.h	138;"	d
-rFPGA1_RFMOD	include/Hal8723DPhyReg.h	138;"	d
-rFPGA1_RFMOD	include/Hal8812PhyReg.h	432;"	d
-rFPGA1_RFMOD	include/Hal8814PhyReg.h	552;"	d
-rFPGA1_RFMOD	include/rtw_mp_phy_regdef.h	164;"	d
-rFPGA1_TxBlock	include/Hal8188EPhyReg.h	129;"	d
-rFPGA1_TxBlock	include/Hal8188FPhyReg.h	145;"	d
-rFPGA1_TxBlock	include/Hal8192EPhyReg.h	136;"	d
-rFPGA1_TxBlock	include/Hal8703BPhyReg.h	139;"	d
-rFPGA1_TxBlock	include/Hal8723BPhyReg.h	139;"	d
-rFPGA1_TxBlock	include/Hal8723DPhyReg.h	139;"	d
-rFPGA1_TxBlock	include/Hal8812PhyReg.h	434;"	d
-rFPGA1_TxBlock	include/Hal8814PhyReg.h	555;"	d
-rFPGA1_TxBlock	include/rtw_mp_phy_regdef.h	166;"	d
-rFPGA1_TxInfo	include/Hal8188EPhyReg.h	131;"	d
-rFPGA1_TxInfo	include/Hal8188FPhyReg.h	147;"	d
-rFPGA1_TxInfo	include/Hal8192EPhyReg.h	138;"	d
-rFPGA1_TxInfo	include/Hal8703BPhyReg.h	141;"	d
-rFPGA1_TxInfo	include/Hal8723BPhyReg.h	141;"	d
-rFPGA1_TxInfo	include/Hal8723DPhyReg.h	141;"	d
-rFPGA1_TxInfo	include/Hal8812PhyReg.h	436;"	d
-rFPGA1_TxInfo	include/Hal8814PhyReg.h	557;"	d
-rFPGA1_TxInfo	include/rtl8822b_hal.h	99;"	d
-rFPGA1_TxInfo	include/rtw_mp_phy_regdef.h	168;"	d
-rFc_area_Jaguar	include/Hal8812PhyReg.h	160;"	d
-rFc_area_Jaguar	include/Hal8814PhyReg.h	190;"	d
-rGlobalCtrl	include/Hal8188EPhyReg.h	365;"	d
-rGlobalCtrl	include/Hal8188FPhyReg.h	366;"	d
-rGlobalCtrl	include/Hal8192EPhyReg.h	370;"	d
-rGlobalCtrl	include/Hal8703BPhyReg.h	398;"	d
-rGlobalCtrl	include/Hal8723BPhyReg.h	397;"	d
-rGlobalCtrl	include/Hal8723DPhyReg.h	398;"	d
-rGlobalCtrl	include/rtw_mp_phy_regdef.h	334;"	d
-rHSSIRead_Jaguar	include/Hal8812PhyReg.h	62;"	d
-rHSSIRead_Jaguar	include/Hal8814PhyReg.h	69;"	d
-rHSSIRead_Jaguar	include/rtl8822b_hal.h	94;"	d
-rHssiPar	include/Hal8188FPhyReg.h	1140;"	d
-rHssiPar	include/Hal8703BPhyReg.h	191;"	d
-rHssiPar	include/Hal8723BPhyReg.h	190;"	d
-rHssiPar	include/Hal8723DPhyReg.h	191;"	d
-rIQK_AGC_Cont	include/Hal8188EPhyReg.h	311;"	d
-rIQK_AGC_Cont	include/Hal8188FPhyReg.h	312;"	d
-rIQK_AGC_Cont	include/Hal8192EPhyReg.h	316;"	d
-rIQK_AGC_Cont	include/Hal8703BPhyReg.h	344;"	d
-rIQK_AGC_Cont	include/Hal8723BPhyReg.h	343;"	d
-rIQK_AGC_Cont	include/Hal8723DPhyReg.h	344;"	d
-rIQK_AGC_Cont	include/Hal8812PhyReg.h	565;"	d
-rIQK_AGC_Cont	include/Hal8814PhyReg.h	688;"	d
-rIQK_AGC_Pts	include/Hal8188EPhyReg.h	305;"	d
-rIQK_AGC_Pts	include/Hal8188FPhyReg.h	306;"	d
-rIQK_AGC_Pts	include/Hal8192EPhyReg.h	310;"	d
-rIQK_AGC_Pts	include/Hal8703BPhyReg.h	338;"	d
-rIQK_AGC_Pts	include/Hal8723BPhyReg.h	337;"	d
-rIQK_AGC_Pts	include/Hal8723DPhyReg.h	338;"	d
-rIQK_AGC_Pts	include/Hal8812PhyReg.h	559;"	d
-rIQK_AGC_Pts	include/Hal8814PhyReg.h	682;"	d
-rIQK_AGC_Rsp	include/Hal8188EPhyReg.h	306;"	d
-rIQK_AGC_Rsp	include/Hal8188FPhyReg.h	307;"	d
-rIQK_AGC_Rsp	include/Hal8192EPhyReg.h	311;"	d
-rIQK_AGC_Rsp	include/Hal8703BPhyReg.h	339;"	d
-rIQK_AGC_Rsp	include/Hal8723BPhyReg.h	338;"	d
-rIQK_AGC_Rsp	include/Hal8723DPhyReg.h	339;"	d
-rIQK_AGC_Rsp	include/Hal8812PhyReg.h	560;"	d
-rIQK_AGC_Rsp	include/Hal8814PhyReg.h	683;"	d
-rL1PeakTH_Jaguar	include/Hal8812PhyReg.h	40;"	d
-rL1PeakTH_Jaguar	include/Hal8814PhyReg.h	42;"	d
-rL1_Weight_Jaguar	include/Hal8814PhyReg.h	37;"	d
-rNBI_Setting_Jaguar	include/Hal8814PhyReg.h	129;"	d
-rOFDM0_AGCParameter1	include/Hal8188EPhyReg.h	212;"	d
-rOFDM0_AGCParameter1	include/Hal8188FPhyReg.h	225;"	d
-rOFDM0_AGCParameter1	include/Hal8192EPhyReg.h	220;"	d
-rOFDM0_AGCParameter1	include/Hal8703BPhyReg.h	257;"	d
-rOFDM0_AGCParameter1	include/Hal8723BPhyReg.h	256;"	d
-rOFDM0_AGCParameter1	include/Hal8723DPhyReg.h	257;"	d
-rOFDM0_AGCParameter1	include/Hal8812PhyReg.h	499;"	d
-rOFDM0_AGCParameter1	include/Hal8814PhyReg.h	622;"	d
-rOFDM0_AGCParameter1	include/rtw_mp_phy_regdef.h	234;"	d
-rOFDM0_AGCParameter2	include/Hal8188EPhyReg.h	213;"	d
-rOFDM0_AGCParameter2	include/Hal8188FPhyReg.h	226;"	d
-rOFDM0_AGCParameter2	include/Hal8192EPhyReg.h	221;"	d
-rOFDM0_AGCParameter2	include/Hal8703BPhyReg.h	258;"	d
-rOFDM0_AGCParameter2	include/Hal8723BPhyReg.h	257;"	d
-rOFDM0_AGCParameter2	include/Hal8723DPhyReg.h	258;"	d
-rOFDM0_AGCParameter2	include/Hal8812PhyReg.h	500;"	d
-rOFDM0_AGCParameter2	include/Hal8814PhyReg.h	623;"	d
-rOFDM0_AGCParameter2	include/rtw_mp_phy_regdef.h	235;"	d
-rOFDM0_AGCRSSITable	include/Hal8188EPhyReg.h	214;"	d
-rOFDM0_AGCRSSITable	include/Hal8188FPhyReg.h	227;"	d
-rOFDM0_AGCRSSITable	include/Hal8192EPhyReg.h	222;"	d
-rOFDM0_AGCRSSITable	include/Hal8703BPhyReg.h	259;"	d
-rOFDM0_AGCRSSITable	include/Hal8723BPhyReg.h	258;"	d
-rOFDM0_AGCRSSITable	include/Hal8723DPhyReg.h	259;"	d
-rOFDM0_AGCRSSITable	include/Hal8812PhyReg.h	501;"	d
-rOFDM0_AGCRSSITable	include/Hal8814PhyReg.h	624;"	d
-rOFDM0_AGCRSSITable	include/rtw_mp_phy_regdef.h	236;"	d
-rOFDM0_CCADropThreshold	include/Hal8188EPhyReg.h	200;"	d
-rOFDM0_CCADropThreshold	include/Hal8188FPhyReg.h	213;"	d
-rOFDM0_CCADropThreshold	include/Hal8192EPhyReg.h	208;"	d
-rOFDM0_CCADropThreshold	include/Hal8703BPhyReg.h	245;"	d
-rOFDM0_CCADropThreshold	include/Hal8723BPhyReg.h	244;"	d
-rOFDM0_CCADropThreshold	include/Hal8723DPhyReg.h	245;"	d
-rOFDM0_CCADropThreshold	include/Hal8812PhyReg.h	487;"	d
-rOFDM0_CCADropThreshold	include/Hal8814PhyReg.h	610;"	d
-rOFDM0_CCADropThreshold	include/rtw_mp_phy_regdef.h	222;"	d
-rOFDM0_CFOandDAGC	include/Hal8188EPhyReg.h	199;"	d
-rOFDM0_CFOandDAGC	include/Hal8188FPhyReg.h	212;"	d
-rOFDM0_CFOandDAGC	include/Hal8192EPhyReg.h	207;"	d
-rOFDM0_CFOandDAGC	include/Hal8703BPhyReg.h	244;"	d
-rOFDM0_CFOandDAGC	include/Hal8723BPhyReg.h	243;"	d
-rOFDM0_CFOandDAGC	include/Hal8723DPhyReg.h	244;"	d
-rOFDM0_CFOandDAGC	include/Hal8812PhyReg.h	486;"	d
-rOFDM0_CFOandDAGC	include/Hal8814PhyReg.h	609;"	d
-rOFDM0_CFOandDAGC	include/rtw_mp_phy_regdef.h	221;"	d
-rOFDM0_DFSReport	include/Hal8188EPhyReg.h	236;"	d
-rOFDM0_DFSReport	include/Hal8188FPhyReg.h	249;"	d
-rOFDM0_DFSReport	include/Hal8192EPhyReg.h	243;"	d
-rOFDM0_DFSReport	include/Hal8703BPhyReg.h	281;"	d
-rOFDM0_DFSReport	include/Hal8723BPhyReg.h	280;"	d
-rOFDM0_DFSReport	include/Hal8723DPhyReg.h	281;"	d
-rOFDM0_DFSReport	include/Hal8812PhyReg.h	523;"	d
-rOFDM0_DFSReport	include/Hal8814PhyReg.h	646;"	d
-rOFDM0_DFSReport	include/rtw_mp_phy_regdef.h	252;"	d
-rOFDM0_ECCAThreshold	include/Hal8188EPhyReg.h	201;"	d
-rOFDM0_ECCAThreshold	include/Hal8188FPhyReg.h	214;"	d
-rOFDM0_ECCAThreshold	include/Hal8192EPhyReg.h	209;"	d
-rOFDM0_ECCAThreshold	include/Hal8703BPhyReg.h	246;"	d
-rOFDM0_ECCAThreshold	include/Hal8723BPhyReg.h	245;"	d
-rOFDM0_ECCAThreshold	include/Hal8723DPhyReg.h	246;"	d
-rOFDM0_ECCAThreshold	include/Hal8812PhyReg.h	488;"	d
-rOFDM0_ECCAThreshold	include/Hal8814PhyReg.h	611;"	d
-rOFDM0_ECCAThreshold	include/rtl8822b_hal.h	125;"	d
-rOFDM0_ECCAThreshold	include/rtw_mp_phy_regdef.h	223;"	d
-rOFDM0_FrameSync	include/Hal8188EPhyReg.h	235;"	d
-rOFDM0_FrameSync	include/Hal8188FPhyReg.h	248;"	d
-rOFDM0_FrameSync	include/Hal8192EPhyReg.h	242;"	d
-rOFDM0_FrameSync	include/Hal8703BPhyReg.h	280;"	d
-rOFDM0_FrameSync	include/Hal8723BPhyReg.h	279;"	d
-rOFDM0_FrameSync	include/Hal8723DPhyReg.h	280;"	d
-rOFDM0_FrameSync	include/Hal8812PhyReg.h	522;"	d
-rOFDM0_FrameSync	include/Hal8814PhyReg.h	645;"	d
-rOFDM0_FrameSync	include/rtw_mp_phy_regdef.h	251;"	d
-rOFDM0_HTSTFAGC	include/Hal8188EPhyReg.h	215;"	d
-rOFDM0_HTSTFAGC	include/Hal8188FPhyReg.h	228;"	d
-rOFDM0_HTSTFAGC	include/Hal8192EPhyReg.h	223;"	d
-rOFDM0_HTSTFAGC	include/Hal8703BPhyReg.h	260;"	d
-rOFDM0_HTSTFAGC	include/Hal8723BPhyReg.h	259;"	d
-rOFDM0_HTSTFAGC	include/Hal8723DPhyReg.h	260;"	d
-rOFDM0_HTSTFAGC	include/Hal8812PhyReg.h	502;"	d
-rOFDM0_HTSTFAGC	include/Hal8814PhyReg.h	625;"	d
-rOFDM0_HTSTFAGC	include/rtw_mp_phy_regdef.h	237;"	d
-rOFDM0_LSTF	include/Hal8188EPhyReg.h	178;"	d
-rOFDM0_LSTF	include/Hal8188FPhyReg.h	191;"	d
-rOFDM0_LSTF	include/Hal8192EPhyReg.h	186;"	d
-rOFDM0_LSTF	include/Hal8703BPhyReg.h	223;"	d
-rOFDM0_LSTF	include/Hal8723BPhyReg.h	222;"	d
-rOFDM0_LSTF	include/Hal8723DPhyReg.h	223;"	d
-rOFDM0_LSTF	include/Hal8812PhyReg.h	465;"	d
-rOFDM0_LSTF	include/Hal8814PhyReg.h	588;"	d
-rOFDM0_LSTF	include/rtw_mp_phy_regdef.h	200;"	d
-rOFDM0_RxDSP	include/Hal8188EPhyReg.h	198;"	d
-rOFDM0_RxDSP	include/Hal8188FPhyReg.h	211;"	d
-rOFDM0_RxDSP	include/Hal8192EPhyReg.h	206;"	d
-rOFDM0_RxDSP	include/Hal8703BPhyReg.h	243;"	d
-rOFDM0_RxDSP	include/Hal8723BPhyReg.h	242;"	d
-rOFDM0_RxDSP	include/Hal8723DPhyReg.h	243;"	d
-rOFDM0_RxDSP	include/Hal8812PhyReg.h	485;"	d
-rOFDM0_RxDSP	include/Hal8814PhyReg.h	608;"	d
-rOFDM0_RxDSP	include/rtw_mp_phy_regdef.h	220;"	d
-rOFDM0_RxDetector1	include/Hal8188EPhyReg.h	193;"	d
-rOFDM0_RxDetector1	include/Hal8188FPhyReg.h	206;"	d
-rOFDM0_RxDetector1	include/Hal8192EPhyReg.h	201;"	d
-rOFDM0_RxDetector1	include/Hal8703BPhyReg.h	238;"	d
-rOFDM0_RxDetector1	include/Hal8723BPhyReg.h	237;"	d
-rOFDM0_RxDetector1	include/Hal8723DPhyReg.h	238;"	d
-rOFDM0_RxDetector1	include/Hal8812PhyReg.h	480;"	d
-rOFDM0_RxDetector1	include/Hal8814PhyReg.h	603;"	d
-rOFDM0_RxDetector1	include/rtl8822b_hal.h	124;"	d
-rOFDM0_RxDetector1	include/rtw_mp_phy_regdef.h	215;"	d
-rOFDM0_RxDetector2	include/Hal8188EPhyReg.h	194;"	d
-rOFDM0_RxDetector2	include/Hal8188FPhyReg.h	207;"	d
-rOFDM0_RxDetector2	include/Hal8192EPhyReg.h	202;"	d
-rOFDM0_RxDetector2	include/Hal8703BPhyReg.h	239;"	d
-rOFDM0_RxDetector2	include/Hal8723BPhyReg.h	238;"	d
-rOFDM0_RxDetector2	include/Hal8723DPhyReg.h	239;"	d
-rOFDM0_RxDetector2	include/Hal8812PhyReg.h	481;"	d
-rOFDM0_RxDetector2	include/Hal8814PhyReg.h	604;"	d
-rOFDM0_RxDetector2	include/rtw_mp_phy_regdef.h	216;"	d
-rOFDM0_RxDetector3	include/Hal8188EPhyReg.h	195;"	d
-rOFDM0_RxDetector3	include/Hal8188FPhyReg.h	208;"	d
-rOFDM0_RxDetector3	include/Hal8192EPhyReg.h	203;"	d
-rOFDM0_RxDetector3	include/Hal8703BPhyReg.h	240;"	d
-rOFDM0_RxDetector3	include/Hal8723BPhyReg.h	239;"	d
-rOFDM0_RxDetector3	include/Hal8723DPhyReg.h	240;"	d
-rOFDM0_RxDetector3	include/Hal8812PhyReg.h	482;"	d
-rOFDM0_RxDetector3	include/Hal8814PhyReg.h	605;"	d
-rOFDM0_RxDetector3	include/rtw_mp_phy_regdef.h	217;"	d
-rOFDM0_RxDetector4	include/Hal8188EPhyReg.h	196;"	d
-rOFDM0_RxDetector4	include/Hal8188FPhyReg.h	209;"	d
-rOFDM0_RxDetector4	include/Hal8192EPhyReg.h	204;"	d
-rOFDM0_RxDetector4	include/Hal8703BPhyReg.h	241;"	d
-rOFDM0_RxDetector4	include/Hal8723BPhyReg.h	240;"	d
-rOFDM0_RxDetector4	include/Hal8723DPhyReg.h	241;"	d
-rOFDM0_RxDetector4	include/Hal8812PhyReg.h	483;"	d
-rOFDM0_RxDetector4	include/Hal8814PhyReg.h	606;"	d
-rOFDM0_RxDetector4	include/rtw_mp_phy_regdef.h	218;"	d
-rOFDM0_RxHPParameter	include/Hal8188EPhyReg.h	233;"	d
-rOFDM0_RxHPParameter	include/Hal8188FPhyReg.h	246;"	d
-rOFDM0_RxHPParameter	include/Hal8192EPhyReg.h	240;"	d
-rOFDM0_RxHPParameter	include/Hal8703BPhyReg.h	278;"	d
-rOFDM0_RxHPParameter	include/Hal8723BPhyReg.h	277;"	d
-rOFDM0_RxHPParameter	include/Hal8723DPhyReg.h	278;"	d
-rOFDM0_RxHPParameter	include/Hal8812PhyReg.h	520;"	d
-rOFDM0_RxHPParameter	include/Hal8814PhyReg.h	643;"	d
-rOFDM0_RxHPParameter	include/rtw_mp_phy_regdef.h	249;"	d
-rOFDM0_RxIQExtAnta	include/Hal8188EPhyReg.h	226;"	d
-rOFDM0_RxIQExtAnta	include/Hal8188FPhyReg.h	239;"	d
-rOFDM0_RxIQExtAnta	include/Hal8192EPhyReg.h	234;"	d
-rOFDM0_RxIQExtAnta	include/Hal8703BPhyReg.h	271;"	d
-rOFDM0_RxIQExtAnta	include/Hal8723BPhyReg.h	270;"	d
-rOFDM0_RxIQExtAnta	include/Hal8723DPhyReg.h	271;"	d
-rOFDM0_RxIQExtAnta	include/Hal8812PhyReg.h	513;"	d
-rOFDM0_RxIQExtAnta	include/Hal8814PhyReg.h	636;"	d
-rOFDM0_RxIQExtAnta	include/rtw_mp_phy_regdef.h	247;"	d
-rOFDM0_TRMuxPar	include/Hal8188EPhyReg.h	181;"	d
-rOFDM0_TRMuxPar	include/Hal8188FPhyReg.h	194;"	d
-rOFDM0_TRMuxPar	include/Hal8192EPhyReg.h	189;"	d
-rOFDM0_TRMuxPar	include/Hal8703BPhyReg.h	226;"	d
-rOFDM0_TRMuxPar	include/Hal8723BPhyReg.h	225;"	d
-rOFDM0_TRMuxPar	include/Hal8723DPhyReg.h	226;"	d
-rOFDM0_TRMuxPar	include/Hal8812PhyReg.h	468;"	d
-rOFDM0_TRMuxPar	include/Hal8814PhyReg.h	591;"	d
-rOFDM0_TRMuxPar	include/rtl8822b_hal.h	122;"	d
-rOFDM0_TRMuxPar	include/rtw_mp_phy_regdef.h	203;"	d
-rOFDM0_TRSWIsolation	include/Hal8188EPhyReg.h	182;"	d
-rOFDM0_TRSWIsolation	include/Hal8188FPhyReg.h	195;"	d
-rOFDM0_TRSWIsolation	include/Hal8192EPhyReg.h	190;"	d
-rOFDM0_TRSWIsolation	include/Hal8703BPhyReg.h	227;"	d
-rOFDM0_TRSWIsolation	include/Hal8723BPhyReg.h	226;"	d
-rOFDM0_TRSWIsolation	include/Hal8723DPhyReg.h	227;"	d
-rOFDM0_TRSWIsolation	include/Hal8812PhyReg.h	469;"	d
-rOFDM0_TRSWIsolation	include/Hal8814PhyReg.h	592;"	d
-rOFDM0_TRSWIsolation	include/rtw_mp_phy_regdef.h	204;"	d
-rOFDM0_TRxPathEnable	include/Hal8188EPhyReg.h	180;"	d
-rOFDM0_TRxPathEnable	include/Hal8188FPhyReg.h	193;"	d
-rOFDM0_TRxPathEnable	include/Hal8192EPhyReg.h	188;"	d
-rOFDM0_TRxPathEnable	include/Hal8703BPhyReg.h	225;"	d
-rOFDM0_TRxPathEnable	include/Hal8723BPhyReg.h	224;"	d
-rOFDM0_TRxPathEnable	include/Hal8723DPhyReg.h	225;"	d
-rOFDM0_TRxPathEnable	include/Hal8812PhyReg.h	467;"	d
-rOFDM0_TRxPathEnable	include/Hal8814PhyReg.h	590;"	d
-rOFDM0_TRxPathEnable	include/rtl8822b_hal.h	121;"	d
-rOFDM0_TRxPathEnable	include/rtw_mp_phy_regdef.h	202;"	d
-rOFDM0_TxCoeff1	include/Hal8188EPhyReg.h	227;"	d
-rOFDM0_TxCoeff1	include/Hal8188FPhyReg.h	240;"	d
-rOFDM0_TxCoeff1	include/Hal8192EPhyReg.h	235;"	d
-rOFDM0_TxCoeff1	include/Hal8703BPhyReg.h	272;"	d
-rOFDM0_TxCoeff1	include/Hal8723BPhyReg.h	271;"	d
-rOFDM0_TxCoeff1	include/Hal8723DPhyReg.h	272;"	d
-rOFDM0_TxCoeff1	include/Hal8812PhyReg.h	514;"	d
-rOFDM0_TxCoeff1	include/Hal8814PhyReg.h	637;"	d
-rOFDM0_TxCoeff1	include/rtw_mp_phy_regdef.h	253;"	d
-rOFDM0_TxCoeff2	include/Hal8188EPhyReg.h	228;"	d
-rOFDM0_TxCoeff2	include/Hal8188FPhyReg.h	241;"	d
-rOFDM0_TxCoeff2	include/Hal8192EPhyReg.h	236;"	d
-rOFDM0_TxCoeff2	include/Hal8703BPhyReg.h	273;"	d
-rOFDM0_TxCoeff2	include/Hal8723BPhyReg.h	272;"	d
-rOFDM0_TxCoeff2	include/Hal8723DPhyReg.h	273;"	d
-rOFDM0_TxCoeff2	include/Hal8812PhyReg.h	515;"	d
-rOFDM0_TxCoeff2	include/Hal8814PhyReg.h	638;"	d
-rOFDM0_TxCoeff2	include/rtw_mp_phy_regdef.h	254;"	d
-rOFDM0_TxCoeff3	include/Hal8188EPhyReg.h	229;"	d
-rOFDM0_TxCoeff3	include/Hal8188FPhyReg.h	242;"	d
-rOFDM0_TxCoeff3	include/Hal8192EPhyReg.h	237;"	d
-rOFDM0_TxCoeff3	include/Hal8703BPhyReg.h	274;"	d
-rOFDM0_TxCoeff3	include/Hal8723BPhyReg.h	273;"	d
-rOFDM0_TxCoeff3	include/Hal8723DPhyReg.h	274;"	d
-rOFDM0_TxCoeff3	include/Hal8812PhyReg.h	516;"	d
-rOFDM0_TxCoeff3	include/Hal8814PhyReg.h	639;"	d
-rOFDM0_TxCoeff3	include/rtw_mp_phy_regdef.h	255;"	d
-rOFDM0_TxCoeff4	include/Hal8188EPhyReg.h	230;"	d
-rOFDM0_TxCoeff4	include/Hal8188FPhyReg.h	243;"	d
-rOFDM0_TxCoeff4	include/Hal8192EPhyReg.h	238;"	d
-rOFDM0_TxCoeff4	include/Hal8703BPhyReg.h	275;"	d
-rOFDM0_TxCoeff4	include/Hal8723BPhyReg.h	274;"	d
-rOFDM0_TxCoeff4	include/Hal8723DPhyReg.h	275;"	d
-rOFDM0_TxCoeff4	include/Hal8812PhyReg.h	517;"	d
-rOFDM0_TxCoeff4	include/Hal8814PhyReg.h	640;"	d
-rOFDM0_TxCoeff4	include/rtw_mp_phy_regdef.h	256;"	d
-rOFDM0_TxCoeff5	include/Hal8188EPhyReg.h	231;"	d
-rOFDM0_TxCoeff5	include/Hal8188FPhyReg.h	244;"	d
-rOFDM0_TxCoeff5	include/Hal8192EPhyReg.h	239;"	d
-rOFDM0_TxCoeff5	include/Hal8703BPhyReg.h	276;"	d
-rOFDM0_TxCoeff5	include/Hal8723BPhyReg.h	275;"	d
-rOFDM0_TxCoeff5	include/Hal8723DPhyReg.h	276;"	d
-rOFDM0_TxCoeff5	include/Hal8812PhyReg.h	518;"	d
-rOFDM0_TxCoeff5	include/Hal8814PhyReg.h	641;"	d
-rOFDM0_TxCoeff5	include/rtw_mp_phy_regdef.h	257;"	d
-rOFDM0_TxCoeff6	include/Hal8188EPhyReg.h	232;"	d
-rOFDM0_TxCoeff6	include/Hal8188FPhyReg.h	245;"	d
-rOFDM0_TxCoeff6	include/Hal8703BPhyReg.h	277;"	d
-rOFDM0_TxCoeff6	include/Hal8723BPhyReg.h	276;"	d
-rOFDM0_TxCoeff6	include/Hal8723DPhyReg.h	277;"	d
-rOFDM0_TxCoeff6	include/Hal8812PhyReg.h	519;"	d
-rOFDM0_TxCoeff6	include/Hal8814PhyReg.h	642;"	d
-rOFDM0_TxCoeff6	include/rtw_mp_phy_regdef.h	258;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8188EPhyReg.h	234;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8188FPhyReg.h	247;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8192EPhyReg.h	241;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8703BPhyReg.h	279;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8723BPhyReg.h	278;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8723DPhyReg.h	279;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8812PhyReg.h	521;"	d
-rOFDM0_TxPseudoNoiseWgt	include/Hal8814PhyReg.h	644;"	d
-rOFDM0_TxPseudoNoiseWgt	include/rtw_mp_phy_regdef.h	250;"	d
-rOFDM0_XAAGCCore1	include/Hal8188EPhyReg.h	203;"	d
-rOFDM0_XAAGCCore1	include/Hal8188FPhyReg.h	216;"	d
-rOFDM0_XAAGCCore1	include/Hal8192EPhyReg.h	211;"	d
-rOFDM0_XAAGCCore1	include/Hal8703BPhyReg.h	248;"	d
-rOFDM0_XAAGCCore1	include/Hal8723BPhyReg.h	247;"	d
-rOFDM0_XAAGCCore1	include/Hal8723DPhyReg.h	248;"	d
-rOFDM0_XAAGCCore1	include/Hal8812PhyReg.h	490;"	d
-rOFDM0_XAAGCCore1	include/Hal8814PhyReg.h	613;"	d
-rOFDM0_XAAGCCore1	include/rtl8822b_hal.h	126;"	d
-rOFDM0_XAAGCCore1	include/rtw_mp_phy_regdef.h	225;"	d
-rOFDM0_XAAGCCore2	include/Hal8188EPhyReg.h	204;"	d
-rOFDM0_XAAGCCore2	include/Hal8188FPhyReg.h	217;"	d
-rOFDM0_XAAGCCore2	include/Hal8192EPhyReg.h	212;"	d
-rOFDM0_XAAGCCore2	include/Hal8703BPhyReg.h	249;"	d
-rOFDM0_XAAGCCore2	include/Hal8723BPhyReg.h	248;"	d
-rOFDM0_XAAGCCore2	include/Hal8723DPhyReg.h	249;"	d
-rOFDM0_XAAGCCore2	include/Hal8812PhyReg.h	491;"	d
-rOFDM0_XAAGCCore2	include/Hal8814PhyReg.h	614;"	d
-rOFDM0_XAAGCCore2	include/rtw_mp_phy_regdef.h	226;"	d
-rOFDM0_XARxAFE	include/Hal8188EPhyReg.h	184;"	d
-rOFDM0_XARxAFE	include/Hal8188FPhyReg.h	197;"	d
-rOFDM0_XARxAFE	include/Hal8192EPhyReg.h	192;"	d
-rOFDM0_XARxAFE	include/Hal8703BPhyReg.h	229;"	d
-rOFDM0_XARxAFE	include/Hal8723BPhyReg.h	228;"	d
-rOFDM0_XARxAFE	include/Hal8723DPhyReg.h	229;"	d
-rOFDM0_XARxAFE	include/Hal8812PhyReg.h	471;"	d
-rOFDM0_XARxAFE	include/Hal8814PhyReg.h	594;"	d
-rOFDM0_XARxAFE	include/rtw_mp_phy_regdef.h	206;"	d
-rOFDM0_XARxIQImbalance	include/Hal8188EPhyReg.h	185;"	d
-rOFDM0_XARxIQImbalance	include/Hal8188FPhyReg.h	198;"	d
-rOFDM0_XARxIQImbalance	include/Hal8192EPhyReg.h	193;"	d
-rOFDM0_XARxIQImbalance	include/Hal8703BPhyReg.h	230;"	d
-rOFDM0_XARxIQImbalance	include/Hal8723BPhyReg.h	229;"	d
-rOFDM0_XARxIQImbalance	include/Hal8723DPhyReg.h	230;"	d
-rOFDM0_XARxIQImbalance	include/Hal8812PhyReg.h	472;"	d
-rOFDM0_XARxIQImbalance	include/Hal8814PhyReg.h	595;"	d
-rOFDM0_XARxIQImbalance	include/rtw_mp_phy_regdef.h	207;"	d
-rOFDM0_XATxAFE	include/Hal8188EPhyReg.h	218;"	d
-rOFDM0_XATxAFE	include/Hal8188FPhyReg.h	231;"	d
-rOFDM0_XATxAFE	include/Hal8192EPhyReg.h	226;"	d
-rOFDM0_XATxAFE	include/Hal8703BPhyReg.h	263;"	d
-rOFDM0_XATxAFE	include/Hal8723BPhyReg.h	262;"	d
-rOFDM0_XATxAFE	include/Hal8723DPhyReg.h	263;"	d
-rOFDM0_XATxAFE	include/Hal8812PhyReg.h	505;"	d
-rOFDM0_XATxAFE	include/Hal8814PhyReg.h	628;"	d
-rOFDM0_XATxAFE	include/rtw_mp_phy_regdef.h	240;"	d
-rOFDM0_XATxIQImbalance	include/Hal8188EPhyReg.h	217;"	d
-rOFDM0_XATxIQImbalance	include/Hal8188FPhyReg.h	230;"	d
-rOFDM0_XATxIQImbalance	include/Hal8192EPhyReg.h	225;"	d
-rOFDM0_XATxIQImbalance	include/Hal8703BPhyReg.h	262;"	d
-rOFDM0_XATxIQImbalance	include/Hal8723BPhyReg.h	261;"	d
-rOFDM0_XATxIQImbalance	include/Hal8723DPhyReg.h	262;"	d
-rOFDM0_XATxIQImbalance	include/Hal8812PhyReg.h	504;"	d
-rOFDM0_XATxIQImbalance	include/Hal8814PhyReg.h	627;"	d
-rOFDM0_XATxIQImbalance	include/rtl8822b_hal.h	129;"	d
-rOFDM0_XATxIQImbalance	include/rtw_mp_phy_regdef.h	239;"	d
-rOFDM0_XBAGCCore1	include/Hal8188EPhyReg.h	205;"	d
-rOFDM0_XBAGCCore1	include/Hal8188FPhyReg.h	218;"	d
-rOFDM0_XBAGCCore1	include/Hal8192EPhyReg.h	213;"	d
-rOFDM0_XBAGCCore1	include/Hal8703BPhyReg.h	250;"	d
-rOFDM0_XBAGCCore1	include/Hal8723BPhyReg.h	249;"	d
-rOFDM0_XBAGCCore1	include/Hal8723DPhyReg.h	250;"	d
-rOFDM0_XBAGCCore1	include/Hal8812PhyReg.h	492;"	d
-rOFDM0_XBAGCCore1	include/Hal8814PhyReg.h	615;"	d
-rOFDM0_XBAGCCore1	include/rtl8822b_hal.h	128;"	d
-rOFDM0_XBAGCCore1	include/rtw_mp_phy_regdef.h	227;"	d
-rOFDM0_XBAGCCore2	include/Hal8188EPhyReg.h	206;"	d
-rOFDM0_XBAGCCore2	include/Hal8188FPhyReg.h	219;"	d
-rOFDM0_XBAGCCore2	include/Hal8192EPhyReg.h	214;"	d
-rOFDM0_XBAGCCore2	include/Hal8703BPhyReg.h	251;"	d
-rOFDM0_XBAGCCore2	include/Hal8723BPhyReg.h	250;"	d
-rOFDM0_XBAGCCore2	include/Hal8723DPhyReg.h	251;"	d
-rOFDM0_XBAGCCore2	include/Hal8812PhyReg.h	493;"	d
-rOFDM0_XBAGCCore2	include/Hal8814PhyReg.h	616;"	d
-rOFDM0_XBAGCCore2	include/rtw_mp_phy_regdef.h	228;"	d
-rOFDM0_XBRxAFE	include/Hal8188EPhyReg.h	186;"	d
-rOFDM0_XBRxAFE	include/Hal8188FPhyReg.h	199;"	d
-rOFDM0_XBRxAFE	include/Hal8192EPhyReg.h	194;"	d
-rOFDM0_XBRxAFE	include/Hal8703BPhyReg.h	231;"	d
-rOFDM0_XBRxAFE	include/Hal8723BPhyReg.h	230;"	d
-rOFDM0_XBRxAFE	include/Hal8723DPhyReg.h	231;"	d
-rOFDM0_XBRxAFE	include/Hal8812PhyReg.h	473;"	d
-rOFDM0_XBRxAFE	include/Hal8814PhyReg.h	596;"	d
-rOFDM0_XBRxAFE	include/rtw_mp_phy_regdef.h	208;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8188EPhyReg.h	187;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8188FPhyReg.h	200;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8192EPhyReg.h	195;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8703BPhyReg.h	232;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8723BPhyReg.h	231;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8723DPhyReg.h	232;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8812PhyReg.h	474;"	d
-rOFDM0_XBRxIQImbalance	include/Hal8814PhyReg.h	597;"	d
-rOFDM0_XBRxIQImbalance	include/rtw_mp_phy_regdef.h	209;"	d
-rOFDM0_XBTxAFE	include/Hal8188EPhyReg.h	220;"	d
-rOFDM0_XBTxAFE	include/Hal8188FPhyReg.h	233;"	d
-rOFDM0_XBTxAFE	include/Hal8192EPhyReg.h	228;"	d
-rOFDM0_XBTxAFE	include/Hal8703BPhyReg.h	265;"	d
-rOFDM0_XBTxAFE	include/Hal8723BPhyReg.h	264;"	d
-rOFDM0_XBTxAFE	include/Hal8723DPhyReg.h	265;"	d
-rOFDM0_XBTxAFE	include/Hal8812PhyReg.h	507;"	d
-rOFDM0_XBTxAFE	include/Hal8814PhyReg.h	630;"	d
-rOFDM0_XBTxAFE	include/rtw_mp_phy_regdef.h	242;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8188EPhyReg.h	219;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8188FPhyReg.h	232;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8192EPhyReg.h	227;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8703BPhyReg.h	264;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8723BPhyReg.h	263;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8723DPhyReg.h	264;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8812PhyReg.h	506;"	d
-rOFDM0_XBTxIQImbalance	include/Hal8814PhyReg.h	629;"	d
-rOFDM0_XBTxIQImbalance	include/rtw_mp_phy_regdef.h	241;"	d
-rOFDM0_XCAGCCore1	include/Hal8188EPhyReg.h	207;"	d
-rOFDM0_XCAGCCore1	include/Hal8188FPhyReg.h	220;"	d
-rOFDM0_XCAGCCore1	include/Hal8192EPhyReg.h	215;"	d
-rOFDM0_XCAGCCore1	include/Hal8703BPhyReg.h	252;"	d
-rOFDM0_XCAGCCore1	include/Hal8723BPhyReg.h	251;"	d
-rOFDM0_XCAGCCore1	include/Hal8723DPhyReg.h	252;"	d
-rOFDM0_XCAGCCore1	include/Hal8812PhyReg.h	494;"	d
-rOFDM0_XCAGCCore1	include/Hal8814PhyReg.h	617;"	d
-rOFDM0_XCAGCCore1	include/rtw_mp_phy_regdef.h	229;"	d
-rOFDM0_XCAGCCore2	include/Hal8188EPhyReg.h	208;"	d
-rOFDM0_XCAGCCore2	include/Hal8188FPhyReg.h	221;"	d
-rOFDM0_XCAGCCore2	include/Hal8192EPhyReg.h	216;"	d
-rOFDM0_XCAGCCore2	include/Hal8703BPhyReg.h	253;"	d
-rOFDM0_XCAGCCore2	include/Hal8723BPhyReg.h	252;"	d
-rOFDM0_XCAGCCore2	include/Hal8723DPhyReg.h	253;"	d
-rOFDM0_XCAGCCore2	include/Hal8812PhyReg.h	495;"	d
-rOFDM0_XCAGCCore2	include/Hal8814PhyReg.h	618;"	d
-rOFDM0_XCAGCCore2	include/rtw_mp_phy_regdef.h	230;"	d
-rOFDM0_XCRxAFE	include/Hal8188EPhyReg.h	188;"	d
-rOFDM0_XCRxAFE	include/Hal8188FPhyReg.h	201;"	d
-rOFDM0_XCRxAFE	include/Hal8192EPhyReg.h	196;"	d
-rOFDM0_XCRxAFE	include/Hal8703BPhyReg.h	233;"	d
-rOFDM0_XCRxAFE	include/Hal8723BPhyReg.h	232;"	d
-rOFDM0_XCRxAFE	include/Hal8723DPhyReg.h	233;"	d
-rOFDM0_XCRxAFE	include/Hal8812PhyReg.h	475;"	d
-rOFDM0_XCRxAFE	include/Hal8814PhyReg.h	598;"	d
-rOFDM0_XCRxAFE	include/rtw_mp_phy_regdef.h	210;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8188EPhyReg.h	189;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8188FPhyReg.h	202;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8192EPhyReg.h	197;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8703BPhyReg.h	234;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8723BPhyReg.h	233;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8723DPhyReg.h	234;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8812PhyReg.h	476;"	d
-rOFDM0_XCRxIQImbalance	include/Hal8814PhyReg.h	599;"	d
-rOFDM0_XCRxIQImbalance	include/rtw_mp_phy_regdef.h	211;"	d
-rOFDM0_XCTxAFE	include/Hal8188EPhyReg.h	222;"	d
-rOFDM0_XCTxAFE	include/Hal8188FPhyReg.h	235;"	d
-rOFDM0_XCTxAFE	include/Hal8192EPhyReg.h	230;"	d
-rOFDM0_XCTxAFE	include/Hal8703BPhyReg.h	267;"	d
-rOFDM0_XCTxAFE	include/Hal8723BPhyReg.h	266;"	d
-rOFDM0_XCTxAFE	include/Hal8723DPhyReg.h	267;"	d
-rOFDM0_XCTxAFE	include/Hal8812PhyReg.h	509;"	d
-rOFDM0_XCTxAFE	include/Hal8814PhyReg.h	632;"	d
-rOFDM0_XCTxAFE	include/rtw_mp_phy_regdef.h	244;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8188EPhyReg.h	221;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8188FPhyReg.h	234;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8192EPhyReg.h	229;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8703BPhyReg.h	266;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8723BPhyReg.h	265;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8723DPhyReg.h	266;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8812PhyReg.h	508;"	d
-rOFDM0_XCTxIQImbalance	include/Hal8814PhyReg.h	631;"	d
-rOFDM0_XCTxIQImbalance	include/rtw_mp_phy_regdef.h	243;"	d
-rOFDM0_XDAGCCore1	include/Hal8188EPhyReg.h	209;"	d
-rOFDM0_XDAGCCore1	include/Hal8188FPhyReg.h	222;"	d
-rOFDM0_XDAGCCore1	include/Hal8192EPhyReg.h	217;"	d
-rOFDM0_XDAGCCore1	include/Hal8703BPhyReg.h	254;"	d
-rOFDM0_XDAGCCore1	include/Hal8723BPhyReg.h	253;"	d
-rOFDM0_XDAGCCore1	include/Hal8723DPhyReg.h	254;"	d
-rOFDM0_XDAGCCore1	include/Hal8812PhyReg.h	496;"	d
-rOFDM0_XDAGCCore1	include/Hal8814PhyReg.h	619;"	d
-rOFDM0_XDAGCCore1	include/rtw_mp_phy_regdef.h	231;"	d
-rOFDM0_XDAGCCore2	include/Hal8188EPhyReg.h	210;"	d
-rOFDM0_XDAGCCore2	include/Hal8188FPhyReg.h	223;"	d
-rOFDM0_XDAGCCore2	include/Hal8192EPhyReg.h	218;"	d
-rOFDM0_XDAGCCore2	include/Hal8703BPhyReg.h	255;"	d
-rOFDM0_XDAGCCore2	include/Hal8723BPhyReg.h	254;"	d
-rOFDM0_XDAGCCore2	include/Hal8723DPhyReg.h	255;"	d
-rOFDM0_XDAGCCore2	include/Hal8812PhyReg.h	497;"	d
-rOFDM0_XDAGCCore2	include/Hal8814PhyReg.h	620;"	d
-rOFDM0_XDAGCCore2	include/rtw_mp_phy_regdef.h	232;"	d
-rOFDM0_XDRxAFE	include/Hal8188EPhyReg.h	190;"	d
-rOFDM0_XDRxAFE	include/Hal8188FPhyReg.h	203;"	d
-rOFDM0_XDRxAFE	include/Hal8192EPhyReg.h	198;"	d
-rOFDM0_XDRxAFE	include/Hal8703BPhyReg.h	235;"	d
-rOFDM0_XDRxAFE	include/Hal8723BPhyReg.h	234;"	d
-rOFDM0_XDRxAFE	include/Hal8723DPhyReg.h	235;"	d
-rOFDM0_XDRxAFE	include/Hal8812PhyReg.h	477;"	d
-rOFDM0_XDRxAFE	include/Hal8814PhyReg.h	600;"	d
-rOFDM0_XDRxAFE	include/rtw_mp_phy_regdef.h	212;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8188EPhyReg.h	191;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8188FPhyReg.h	204;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8192EPhyReg.h	199;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8703BPhyReg.h	236;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8723BPhyReg.h	235;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8723DPhyReg.h	236;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8812PhyReg.h	478;"	d
-rOFDM0_XDRxIQImbalance	include/Hal8814PhyReg.h	601;"	d
-rOFDM0_XDRxIQImbalance	include/rtw_mp_phy_regdef.h	213;"	d
-rOFDM0_XDTxAFE	include/Hal8188EPhyReg.h	224;"	d
-rOFDM0_XDTxAFE	include/Hal8188FPhyReg.h	237;"	d
-rOFDM0_XDTxAFE	include/Hal8192EPhyReg.h	232;"	d
-rOFDM0_XDTxAFE	include/Hal8703BPhyReg.h	269;"	d
-rOFDM0_XDTxAFE	include/Hal8723BPhyReg.h	268;"	d
-rOFDM0_XDTxAFE	include/Hal8723DPhyReg.h	269;"	d
-rOFDM0_XDTxAFE	include/Hal8812PhyReg.h	511;"	d
-rOFDM0_XDTxAFE	include/Hal8814PhyReg.h	634;"	d
-rOFDM0_XDTxAFE	include/rtw_mp_phy_regdef.h	246;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8188EPhyReg.h	223;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8188FPhyReg.h	236;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8192EPhyReg.h	231;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8703BPhyReg.h	268;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8723BPhyReg.h	267;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8723DPhyReg.h	268;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8812PhyReg.h	510;"	d
-rOFDM0_XDTxIQImbalance	include/Hal8814PhyReg.h	633;"	d
-rOFDM0_XDTxIQImbalance	include/rtw_mp_phy_regdef.h	245;"	d
-rOFDM1_CFO	include/Hal8188EPhyReg.h	245;"	d
-rOFDM1_CFO	include/Hal8188FPhyReg.h	257;"	d
-rOFDM1_CFO	include/Hal8192EPhyReg.h	252;"	d
-rOFDM1_CFO	include/Hal8703BPhyReg.h	289;"	d
-rOFDM1_CFO	include/Hal8723BPhyReg.h	288;"	d
-rOFDM1_CFO	include/Hal8723DPhyReg.h	289;"	d
-rOFDM1_CFO	include/rtw_mp_phy_regdef.h	267;"	d
-rOFDM1_CFOTracking	include/Hal8188EPhyReg.h	249;"	d
-rOFDM1_CFOTracking	include/Hal8188FPhyReg.h	261;"	d
-rOFDM1_CFOTracking	include/Hal8192EPhyReg.h	256;"	d
-rOFDM1_CFOTracking	include/Hal8703BPhyReg.h	293;"	d
-rOFDM1_CFOTracking	include/Hal8723BPhyReg.h	292;"	d
-rOFDM1_CFOTracking	include/Hal8723DPhyReg.h	293;"	d
-rOFDM1_CFOTracking	include/rtw_mp_phy_regdef.h	271;"	d
-rOFDM1_CSI1	include/Hal8188EPhyReg.h	246;"	d
-rOFDM1_CSI1	include/Hal8188FPhyReg.h	258;"	d
-rOFDM1_CSI1	include/Hal8192EPhyReg.h	253;"	d
-rOFDM1_CSI1	include/Hal8703BPhyReg.h	290;"	d
-rOFDM1_CSI1	include/Hal8723BPhyReg.h	289;"	d
-rOFDM1_CSI1	include/Hal8723DPhyReg.h	290;"	d
-rOFDM1_CSI1	include/rtw_mp_phy_regdef.h	268;"	d
-rOFDM1_CSI2	include/Hal8188EPhyReg.h	248;"	d
-rOFDM1_CSI2	include/Hal8188FPhyReg.h	260;"	d
-rOFDM1_CSI2	include/Hal8192EPhyReg.h	255;"	d
-rOFDM1_CSI2	include/Hal8703BPhyReg.h	292;"	d
-rOFDM1_CSI2	include/Hal8723BPhyReg.h	291;"	d
-rOFDM1_CSI2	include/Hal8723DPhyReg.h	292;"	d
-rOFDM1_CSI2	include/rtw_mp_phy_regdef.h	270;"	d
-rOFDM1_IntfDet	include/Hal8188EPhyReg.h	251;"	d
-rOFDM1_IntfDet	include/Hal8188FPhyReg.h	263;"	d
-rOFDM1_IntfDet	include/Hal8192EPhyReg.h	258;"	d
-rOFDM1_IntfDet	include/Hal8703BPhyReg.h	295;"	d
-rOFDM1_IntfDet	include/Hal8723BPhyReg.h	294;"	d
-rOFDM1_IntfDet	include/Hal8723DPhyReg.h	295;"	d
-rOFDM1_IntfDet	include/rtw_mp_phy_regdef.h	273;"	d
-rOFDM1_LSTF	include/Hal8188EPhyReg.h	242;"	d
-rOFDM1_LSTF	include/Hal8188FPhyReg.h	254;"	d
-rOFDM1_LSTF	include/Hal8192EPhyReg.h	249;"	d
-rOFDM1_LSTF	include/Hal8703BPhyReg.h	286;"	d
-rOFDM1_LSTF	include/Hal8723BPhyReg.h	285;"	d
-rOFDM1_LSTF	include/Hal8723DPhyReg.h	286;"	d
-rOFDM1_LSTF	include/Hal8812PhyReg.h	528;"	d
-rOFDM1_LSTF	include/Hal8814PhyReg.h	651;"	d
-rOFDM1_LSTF	include/rtl8822b_hal.h	133;"	d
-rOFDM1_LSTF	include/rtw_mp_phy_regdef.h	264;"	d
-rOFDM1_PseudoNoiseStateAB	include/Hal8188EPhyReg.h	254;"	d
-rOFDM1_PseudoNoiseStateAB	include/Hal8188FPhyReg.h	264;"	d
-rOFDM1_PseudoNoiseStateAB	include/Hal8192EPhyReg.h	259;"	d
-rOFDM1_PseudoNoiseStateAB	include/Hal8703BPhyReg.h	296;"	d
-rOFDM1_PseudoNoiseStateAB	include/Hal8723BPhyReg.h	295;"	d
-rOFDM1_PseudoNoiseStateAB	include/Hal8723DPhyReg.h	296;"	d
-rOFDM1_PseudoNoiseStateAB	include/rtw_mp_phy_regdef.h	274;"	d
-rOFDM1_PseudoNoiseStateCD	include/Hal8188EPhyReg.h	255;"	d
-rOFDM1_PseudoNoiseStateCD	include/Hal8188FPhyReg.h	265;"	d
-rOFDM1_PseudoNoiseStateCD	include/Hal8192EPhyReg.h	260;"	d
-rOFDM1_PseudoNoiseStateCD	include/Hal8703BPhyReg.h	297;"	d
-rOFDM1_PseudoNoiseStateCD	include/Hal8723BPhyReg.h	296;"	d
-rOFDM1_PseudoNoiseStateCD	include/Hal8723DPhyReg.h	297;"	d
-rOFDM1_PseudoNoiseStateCD	include/rtw_mp_phy_regdef.h	275;"	d
-rOFDM1_RxPseudoNoiseWgt	include/Hal8188EPhyReg.h	256;"	d
-rOFDM1_RxPseudoNoiseWgt	include/Hal8188FPhyReg.h	266;"	d
-rOFDM1_RxPseudoNoiseWgt	include/Hal8192EPhyReg.h	261;"	d
-rOFDM1_RxPseudoNoiseWgt	include/Hal8703BPhyReg.h	298;"	d
-rOFDM1_RxPseudoNoiseWgt	include/Hal8723BPhyReg.h	297;"	d
-rOFDM1_RxPseudoNoiseWgt	include/Hal8723DPhyReg.h	298;"	d
-rOFDM1_RxPseudoNoiseWgt	include/rtw_mp_phy_regdef.h	276;"	d
-rOFDM1_SBD	include/Hal8188EPhyReg.h	247;"	d
-rOFDM1_SBD	include/Hal8188FPhyReg.h	259;"	d
-rOFDM1_SBD	include/Hal8192EPhyReg.h	254;"	d
-rOFDM1_SBD	include/Hal8703BPhyReg.h	291;"	d
-rOFDM1_SBD	include/Hal8723BPhyReg.h	290;"	d
-rOFDM1_SBD	include/Hal8723DPhyReg.h	291;"	d
-rOFDM1_SBD	include/rtw_mp_phy_regdef.h	269;"	d
-rOFDM1_TRxMesaure1	include/Hal8188EPhyReg.h	250;"	d
-rOFDM1_TRxMesaure1	include/Hal8188FPhyReg.h	262;"	d
-rOFDM1_TRxMesaure1	include/Hal8192EPhyReg.h	257;"	d
-rOFDM1_TRxMesaure1	include/Hal8703BPhyReg.h	294;"	d
-rOFDM1_TRxMesaure1	include/Hal8723BPhyReg.h	293;"	d
-rOFDM1_TRxMesaure1	include/Hal8723DPhyReg.h	294;"	d
-rOFDM1_TRxMesaure1	include/rtw_mp_phy_regdef.h	272;"	d
-rOFDM1_TRxPathEnable	include/Hal8188EPhyReg.h	243;"	d
-rOFDM1_TRxPathEnable	include/Hal8188FPhyReg.h	255;"	d
-rOFDM1_TRxPathEnable	include/Hal8192EPhyReg.h	250;"	d
-rOFDM1_TRxPathEnable	include/Hal8703BPhyReg.h	287;"	d
-rOFDM1_TRxPathEnable	include/Hal8723BPhyReg.h	286;"	d
-rOFDM1_TRxPathEnable	include/Hal8723DPhyReg.h	287;"	d
-rOFDM1_TRxPathEnable	include/Hal8812PhyReg.h	529;"	d
-rOFDM1_TRxPathEnable	include/Hal8814PhyReg.h	652;"	d
-rOFDM1_TRxPathEnable	include/rtl8822b_hal.h	134;"	d
-rOFDM1_TRxPathEnable	include/rtw_mp_phy_regdef.h	265;"	d
-rOFDM1_csi_fix_mask1	include/Hal8188EPhyReg.h	252;"	d
-rOFDM1_csi_fix_mask2	include/Hal8188EPhyReg.h	253;"	d
-rOFDMCCKEN_Jaguar	include/Hal8812PhyReg.h	50;"	d
-rOFDMCCKEN_Jaguar	include/Hal8814PhyReg.h	52;"	d
-rOFDMCCKEN_Jaguar	include/rtl8822b_hal.h	73;"	d
-rOFDM_AGCReport	include/Hal8188EPhyReg.h	271;"	d
-rOFDM_AGCReport	include/Hal8188FPhyReg.h	281;"	d
-rOFDM_AGCReport	include/Hal8192EPhyReg.h	276;"	d
-rOFDM_AGCReport	include/Hal8703BPhyReg.h	313;"	d
-rOFDM_AGCReport	include/Hal8723BPhyReg.h	312;"	d
-rOFDM_AGCReport	include/Hal8723DPhyReg.h	313;"	d
-rOFDM_AGCReport	include/rtw_mp_phy_regdef.h	291;"	d
-rOFDM_AGCReport_Jaguar	include/Hal8812PhyReg.h	148;"	d
-rOFDM_AGCReport_Jaguar	include/Hal8814PhyReg.h	178;"	d
-rOFDM_BWReport	include/Hal8188EPhyReg.h	270;"	d
-rOFDM_BWReport	include/Hal8188FPhyReg.h	280;"	d
-rOFDM_BWReport	include/Hal8192EPhyReg.h	275;"	d
-rOFDM_BWReport	include/Hal8703BPhyReg.h	312;"	d
-rOFDM_BWReport	include/Hal8723BPhyReg.h	311;"	d
-rOFDM_BWReport	include/Hal8723DPhyReg.h	312;"	d
-rOFDM_BWReport	include/rtw_mp_phy_regdef.h	290;"	d
-rOFDM_EndCFOAB_Jaguar	include/Hal8812PhyReg.h	147;"	d
-rOFDM_EndCFOAB_Jaguar	include/Hal8814PhyReg.h	177;"	d
-rOFDM_FalseAlarm1_Jaguar	include/Hal8812PhyReg.h	133;"	d
-rOFDM_FalseAlarm1_Jaguar	include/Hal8814PhyReg.h	163;"	d
-rOFDM_FalseAlarm2_Jaguar	include/Hal8812PhyReg.h	134;"	d
-rOFDM_FalseAlarm2_Jaguar	include/Hal8814PhyReg.h	164;"	d
-rOFDM_LongCFOAB	include/Hal8188EPhyReg.h	264;"	d
-rOFDM_LongCFOAB	include/Hal8188FPhyReg.h	274;"	d
-rOFDM_LongCFOAB	include/Hal8192EPhyReg.h	269;"	d
-rOFDM_LongCFOAB	include/Hal8703BPhyReg.h	306;"	d
-rOFDM_LongCFOAB	include/Hal8723BPhyReg.h	305;"	d
-rOFDM_LongCFOAB	include/Hal8723DPhyReg.h	306;"	d
-rOFDM_LongCFOAB	include/rtw_mp_phy_regdef.h	284;"	d
-rOFDM_LongCFOAB_Jaguar	include/Hal8812PhyReg.h	146;"	d
-rOFDM_LongCFOAB_Jaguar	include/Hal8814PhyReg.h	176;"	d
-rOFDM_LongCFOCD	include/Hal8188EPhyReg.h	265;"	d
-rOFDM_LongCFOCD	include/Hal8188FPhyReg.h	275;"	d
-rOFDM_LongCFOCD	include/Hal8192EPhyReg.h	270;"	d
-rOFDM_LongCFOCD	include/Hal8703BPhyReg.h	307;"	d
-rOFDM_LongCFOCD	include/Hal8723BPhyReg.h	306;"	d
-rOFDM_LongCFOCD	include/Hal8723DPhyReg.h	307;"	d
-rOFDM_LongCFOCD	include/rtw_mp_phy_regdef.h	285;"	d
-rOFDM_PHYCounter1	include/Hal8188EPhyReg.h	258;"	d
-rOFDM_PHYCounter1	include/Hal8188FPhyReg.h	268;"	d
-rOFDM_PHYCounter1	include/Hal8192EPhyReg.h	263;"	d
-rOFDM_PHYCounter1	include/Hal8703BPhyReg.h	300;"	d
-rOFDM_PHYCounter1	include/Hal8723BPhyReg.h	299;"	d
-rOFDM_PHYCounter1	include/Hal8723DPhyReg.h	300;"	d
-rOFDM_PHYCounter1	include/rtw_mp_phy_regdef.h	278;"	d
-rOFDM_PHYCounter2	include/Hal8188EPhyReg.h	259;"	d
-rOFDM_PHYCounter2	include/Hal8188FPhyReg.h	269;"	d
-rOFDM_PHYCounter2	include/Hal8192EPhyReg.h	264;"	d
-rOFDM_PHYCounter2	include/Hal8703BPhyReg.h	301;"	d
-rOFDM_PHYCounter2	include/Hal8723BPhyReg.h	300;"	d
-rOFDM_PHYCounter2	include/Hal8723DPhyReg.h	301;"	d
-rOFDM_PHYCounter2	include/rtw_mp_phy_regdef.h	279;"	d
-rOFDM_PHYCounter3	include/Hal8188EPhyReg.h	260;"	d
-rOFDM_PHYCounter3	include/Hal8188FPhyReg.h	270;"	d
-rOFDM_PHYCounter3	include/Hal8192EPhyReg.h	265;"	d
-rOFDM_PHYCounter3	include/Hal8703BPhyReg.h	302;"	d
-rOFDM_PHYCounter3	include/Hal8723BPhyReg.h	301;"	d
-rOFDM_PHYCounter3	include/Hal8723DPhyReg.h	302;"	d
-rOFDM_PHYCounter3	include/rtw_mp_phy_regdef.h	280;"	d
-rOFDM_PWMeasure1	include/Hal8188EPhyReg.h	268;"	d
-rOFDM_PWMeasure1	include/Hal8188FPhyReg.h	278;"	d
-rOFDM_PWMeasure1	include/Hal8192EPhyReg.h	273;"	d
-rOFDM_PWMeasure1	include/Hal8703BPhyReg.h	310;"	d
-rOFDM_PWMeasure1	include/Hal8723BPhyReg.h	309;"	d
-rOFDM_PWMeasure1	include/Hal8723DPhyReg.h	310;"	d
-rOFDM_PWMeasure1	include/rtw_mp_phy_regdef.h	288;"	d
-rOFDM_PWMeasure2	include/Hal8188EPhyReg.h	269;"	d
-rOFDM_PWMeasure2	include/Hal8188FPhyReg.h	279;"	d
-rOFDM_PWMeasure2	include/Hal8192EPhyReg.h	274;"	d
-rOFDM_PWMeasure2	include/Hal8703BPhyReg.h	311;"	d
-rOFDM_PWMeasure2	include/Hal8723BPhyReg.h	310;"	d
-rOFDM_PWMeasure2	include/Hal8723DPhyReg.h	311;"	d
-rOFDM_PWMeasure2	include/rtw_mp_phy_regdef.h	289;"	d
-rOFDM_RxEVMCSI	include/Hal8188EPhyReg.h	273;"	d
-rOFDM_RxEVMCSI	include/Hal8188FPhyReg.h	283;"	d
-rOFDM_RxEVMCSI	include/Hal8192EPhyReg.h	278;"	d
-rOFDM_RxEVMCSI	include/Hal8703BPhyReg.h	315;"	d
-rOFDM_RxEVMCSI	include/Hal8723BPhyReg.h	314;"	d
-rOFDM_RxEVMCSI	include/Hal8723DPhyReg.h	315;"	d
-rOFDM_RxEVMCSI	include/rtw_mp_phy_regdef.h	293;"	d
-rOFDM_RxEVMCSI_Jaguar	include/Hal8812PhyReg.h	150;"	d
-rOFDM_RxEVMCSI_Jaguar	include/Hal8814PhyReg.h	180;"	d
-rOFDM_RxSNR	include/Hal8188EPhyReg.h	272;"	d
-rOFDM_RxSNR	include/Hal8188FPhyReg.h	282;"	d
-rOFDM_RxSNR	include/Hal8192EPhyReg.h	277;"	d
-rOFDM_RxSNR	include/Hal8703BPhyReg.h	314;"	d
-rOFDM_RxSNR	include/Hal8723BPhyReg.h	313;"	d
-rOFDM_RxSNR	include/Hal8723DPhyReg.h	314;"	d
-rOFDM_RxSNR	include/rtw_mp_phy_regdef.h	292;"	d
-rOFDM_RxSNR_Jaguar	include/Hal8812PhyReg.h	149;"	d
-rOFDM_RxSNR_Jaguar	include/Hal8814PhyReg.h	179;"	d
-rOFDM_SIGReport	include/Hal8188EPhyReg.h	274;"	d
-rOFDM_SIGReport	include/Hal8188FPhyReg.h	284;"	d
-rOFDM_SIGReport	include/Hal8192EPhyReg.h	279;"	d
-rOFDM_SIGReport	include/Hal8703BPhyReg.h	316;"	d
-rOFDM_SIGReport	include/Hal8723BPhyReg.h	315;"	d
-rOFDM_SIGReport	include/Hal8723DPhyReg.h	316;"	d
-rOFDM_SIGReport	include/rtw_mp_phy_regdef.h	294;"	d
-rOFDM_SIGReport_Jaguar	include/Hal8812PhyReg.h	151;"	d
-rOFDM_SIGReport_Jaguar	include/Hal8814PhyReg.h	181;"	d
-rOFDM_ShortCFOAB	include/Hal8188EPhyReg.h	262;"	d
-rOFDM_ShortCFOAB	include/Hal8188FPhyReg.h	272;"	d
-rOFDM_ShortCFOAB	include/Hal8192EPhyReg.h	267;"	d
-rOFDM_ShortCFOAB	include/Hal8703BPhyReg.h	304;"	d
-rOFDM_ShortCFOAB	include/Hal8723BPhyReg.h	303;"	d
-rOFDM_ShortCFOAB	include/Hal8723DPhyReg.h	304;"	d
-rOFDM_ShortCFOAB	include/rtw_mp_phy_regdef.h	282;"	d
-rOFDM_ShortCFOAB_Jaguar	include/Hal8812PhyReg.h	145;"	d
-rOFDM_ShortCFOAB_Jaguar	include/Hal8814PhyReg.h	175;"	d
-rOFDM_ShortCFOCD	include/Hal8188EPhyReg.h	263;"	d
-rOFDM_ShortCFOCD	include/Hal8188FPhyReg.h	273;"	d
-rOFDM_ShortCFOCD	include/Hal8192EPhyReg.h	268;"	d
-rOFDM_ShortCFOCD	include/Hal8703BPhyReg.h	305;"	d
-rOFDM_ShortCFOCD	include/Hal8723BPhyReg.h	304;"	d
-rOFDM_ShortCFOCD	include/Hal8723DPhyReg.h	305;"	d
-rOFDM_ShortCFOCD	include/rtw_mp_phy_regdef.h	283;"	d
-rOFDM_TailCFOAB	include/Hal8188EPhyReg.h	266;"	d
-rOFDM_TailCFOAB	include/Hal8188FPhyReg.h	276;"	d
-rOFDM_TailCFOAB	include/Hal8192EPhyReg.h	271;"	d
-rOFDM_TailCFOAB	include/Hal8703BPhyReg.h	308;"	d
-rOFDM_TailCFOAB	include/Hal8723BPhyReg.h	307;"	d
-rOFDM_TailCFOAB	include/Hal8723DPhyReg.h	308;"	d
-rOFDM_TailCFOAB	include/rtw_mp_phy_regdef.h	286;"	d
-rOFDM_TailCFOCD	include/Hal8188EPhyReg.h	267;"	d
-rOFDM_TailCFOCD	include/Hal8188FPhyReg.h	277;"	d
-rOFDM_TailCFOCD	include/Hal8192EPhyReg.h	272;"	d
-rOFDM_TailCFOCD	include/Hal8703BPhyReg.h	309;"	d
-rOFDM_TailCFOCD	include/Hal8723BPhyReg.h	308;"	d
-rOFDM_TailCFOCD	include/Hal8723DPhyReg.h	309;"	d
-rOFDM_TailCFOCD	include/rtw_mp_phy_regdef.h	287;"	d
-rPMAC_CCKCRC16	include/Hal8188EPhyReg.h	55;"	d
-rPMAC_CCKCRC16	include/Hal8188FPhyReg.h	61;"	d
-rPMAC_CCKCRC16	include/Hal8192EPhyReg.h	67;"	d
-rPMAC_CCKCRC16	include/Hal8703BPhyReg.h	56;"	d
-rPMAC_CCKCRC16	include/Hal8723BPhyReg.h	56;"	d
-rPMAC_CCKCRC16	include/Hal8723DPhyReg.h	56;"	d
-rPMAC_CCKCRC16	include/Hal8812PhyReg.h	391;"	d
-rPMAC_CCKCRC16	include/Hal8814PhyReg.h	498;"	d
-rPMAC_CCKCRC16	include/rtw_mp_phy_regdef.h	85;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8188EPhyReg.h	60;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8188FPhyReg.h	66;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8192EPhyReg.h	72;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8703BPhyReg.h	61;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8723BPhyReg.h	61;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8723DPhyReg.h	61;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8812PhyReg.h	396;"	d
-rPMAC_CCKCRxRC16Er	include/Hal8814PhyReg.h	503;"	d
-rPMAC_CCKCRxRC16Er	include/rtw_mp_phy_regdef.h	90;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8188EPhyReg.h	61;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8188FPhyReg.h	67;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8192EPhyReg.h	73;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8703BPhyReg.h	62;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8723BPhyReg.h	62;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8723DPhyReg.h	62;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8812PhyReg.h	397;"	d
-rPMAC_CCKCRxRC32Er	include/Hal8814PhyReg.h	504;"	d
-rPMAC_CCKCRxRC32Er	include/rtw_mp_phy_regdef.h	91;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8188EPhyReg.h	62;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8188FPhyReg.h	68;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8192EPhyReg.h	74;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8703BPhyReg.h	63;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8723BPhyReg.h	63;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8723DPhyReg.h	63;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8812PhyReg.h	398;"	d
-rPMAC_CCKCRxRC32OK	include/Hal8814PhyReg.h	505;"	d
-rPMAC_CCKCRxRC32OK	include/rtw_mp_phy_regdef.h	92;"	d
-rPMAC_CCKPLCPHeader	include/Hal8188EPhyReg.h	54;"	d
-rPMAC_CCKPLCPHeader	include/Hal8188FPhyReg.h	60;"	d
-rPMAC_CCKPLCPHeader	include/Hal8192EPhyReg.h	66;"	d
-rPMAC_CCKPLCPHeader	include/Hal8703BPhyReg.h	55;"	d
-rPMAC_CCKPLCPHeader	include/Hal8723BPhyReg.h	55;"	d
-rPMAC_CCKPLCPHeader	include/Hal8723DPhyReg.h	55;"	d
-rPMAC_CCKPLCPHeader	include/Hal8812PhyReg.h	390;"	d
-rPMAC_CCKPLCPHeader	include/Hal8814PhyReg.h	497;"	d
-rPMAC_CCKPLCPHeader	include/rtw_mp_phy_regdef.h	84;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8188EPhyReg.h	53;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8188FPhyReg.h	59;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8192EPhyReg.h	65;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8703BPhyReg.h	54;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8723BPhyReg.h	54;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8723DPhyReg.h	54;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8812PhyReg.h	389;"	d
-rPMAC_CCKPLCPPreamble	include/Hal8814PhyReg.h	496;"	d
-rPMAC_CCKPLCPPreamble	include/rtw_mp_phy_regdef.h	83;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8188EPhyReg.h	57;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8188FPhyReg.h	63;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8192EPhyReg.h	69;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8703BPhyReg.h	58;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8723BPhyReg.h	58;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8723DPhyReg.h	58;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8812PhyReg.h	393;"	d
-rPMAC_OFDMRxCRC32Er	include/Hal8814PhyReg.h	500;"	d
-rPMAC_OFDMRxCRC32Er	include/rtw_mp_phy_regdef.h	87;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8188EPhyReg.h	56;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8188FPhyReg.h	62;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8192EPhyReg.h	68;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8703BPhyReg.h	57;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8723BPhyReg.h	57;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8723DPhyReg.h	57;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8812PhyReg.h	392;"	d
-rPMAC_OFDMRxCRC32OK	include/Hal8814PhyReg.h	499;"	d
-rPMAC_OFDMRxCRC32OK	include/rtw_mp_phy_regdef.h	86;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8188EPhyReg.h	59;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8188FPhyReg.h	65;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8192EPhyReg.h	71;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8703BPhyReg.h	60;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8723BPhyReg.h	60;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8723DPhyReg.h	60;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8812PhyReg.h	395;"	d
-rPMAC_OFDMRxCRC8Er	include/Hal8814PhyReg.h	502;"	d
-rPMAC_OFDMRxCRC8Er	include/rtw_mp_phy_regdef.h	89;"	d
-rPMAC_OFDMRxParityEr	include/Hal8188EPhyReg.h	58;"	d
-rPMAC_OFDMRxParityEr	include/Hal8188FPhyReg.h	64;"	d
-rPMAC_OFDMRxParityEr	include/Hal8192EPhyReg.h	70;"	d
-rPMAC_OFDMRxParityEr	include/Hal8703BPhyReg.h	59;"	d
-rPMAC_OFDMRxParityEr	include/Hal8723BPhyReg.h	59;"	d
-rPMAC_OFDMRxParityEr	include/Hal8723DPhyReg.h	59;"	d
-rPMAC_OFDMRxParityEr	include/Hal8812PhyReg.h	394;"	d
-rPMAC_OFDMRxParityEr	include/Hal8814PhyReg.h	501;"	d
-rPMAC_OFDMRxParityEr	include/rtw_mp_phy_regdef.h	88;"	d
-rPMAC_PHYDebug	include/Hal8188EPhyReg.h	42;"	d
-rPMAC_PHYDebug	include/Hal8188FPhyReg.h	48;"	d
-rPMAC_PHYDebug	include/Hal8192EPhyReg.h	54;"	d
-rPMAC_PHYDebug	include/Hal8703BPhyReg.h	43;"	d
-rPMAC_PHYDebug	include/Hal8723BPhyReg.h	43;"	d
-rPMAC_PHYDebug	include/Hal8723DPhyReg.h	43;"	d
-rPMAC_PHYDebug	include/Hal8812PhyReg.h	378;"	d
-rPMAC_PHYDebug	include/Hal8814PhyReg.h	485;"	d
-rPMAC_PHYDebug	include/rtw_mp_phy_regdef.h	72;"	d
-rPMAC_Reset	include/Hal8188EPhyReg.h	37;"	d
-rPMAC_Reset	include/Hal8188FPhyReg.h	43;"	d
-rPMAC_Reset	include/Hal8192EPhyReg.h	49;"	d
-rPMAC_Reset	include/Hal8703BPhyReg.h	38;"	d
-rPMAC_Reset	include/Hal8723BPhyReg.h	38;"	d
-rPMAC_Reset	include/Hal8723DPhyReg.h	38;"	d
-rPMAC_Reset	include/Hal8812PhyReg.h	373;"	d
-rPMAC_Reset	include/Hal8814PhyReg.h	480;"	d
-rPMAC_Reset	include/rtl8822b_hal.h	69;"	d
-rPMAC_Reset	include/rtw_mp_phy_regdef.h	67;"	d
-rPMAC_TxDataType	include/Hal8188EPhyReg.h	51;"	d
-rPMAC_TxDataType	include/Hal8188FPhyReg.h	57;"	d
-rPMAC_TxDataType	include/Hal8192EPhyReg.h	63;"	d
-rPMAC_TxDataType	include/Hal8703BPhyReg.h	52;"	d
-rPMAC_TxDataType	include/Hal8723BPhyReg.h	52;"	d
-rPMAC_TxDataType	include/Hal8723DPhyReg.h	52;"	d
-rPMAC_TxDataType	include/Hal8812PhyReg.h	387;"	d
-rPMAC_TxDataType	include/Hal8814PhyReg.h	494;"	d
-rPMAC_TxDataType	include/rtw_mp_phy_regdef.h	81;"	d
-rPMAC_TxHTSIG1	include/Hal8188EPhyReg.h	40;"	d
-rPMAC_TxHTSIG1	include/Hal8188FPhyReg.h	46;"	d
-rPMAC_TxHTSIG1	include/Hal8192EPhyReg.h	52;"	d
-rPMAC_TxHTSIG1	include/Hal8703BPhyReg.h	41;"	d
-rPMAC_TxHTSIG1	include/Hal8723BPhyReg.h	41;"	d
-rPMAC_TxHTSIG1	include/Hal8723DPhyReg.h	41;"	d
-rPMAC_TxHTSIG1	include/Hal8812PhyReg.h	376;"	d
-rPMAC_TxHTSIG1	include/Hal8814PhyReg.h	483;"	d
-rPMAC_TxHTSIG1	include/rtw_mp_phy_regdef.h	70;"	d
-rPMAC_TxHTSIG2	include/Hal8188EPhyReg.h	41;"	d
-rPMAC_TxHTSIG2	include/Hal8188FPhyReg.h	47;"	d
-rPMAC_TxHTSIG2	include/Hal8192EPhyReg.h	53;"	d
-rPMAC_TxHTSIG2	include/Hal8703BPhyReg.h	42;"	d
-rPMAC_TxHTSIG2	include/Hal8723BPhyReg.h	42;"	d
-rPMAC_TxHTSIG2	include/Hal8723DPhyReg.h	42;"	d
-rPMAC_TxHTSIG2	include/Hal8812PhyReg.h	377;"	d
-rPMAC_TxHTSIG2	include/Hal8814PhyReg.h	484;"	d
-rPMAC_TxHTSIG2	include/rtw_mp_phy_regdef.h	71;"	d
-rPMAC_TxIdle	include/Hal8188EPhyReg.h	44;"	d
-rPMAC_TxIdle	include/Hal8188FPhyReg.h	50;"	d
-rPMAC_TxIdle	include/Hal8192EPhyReg.h	56;"	d
-rPMAC_TxIdle	include/Hal8703BPhyReg.h	45;"	d
-rPMAC_TxIdle	include/Hal8723BPhyReg.h	45;"	d
-rPMAC_TxIdle	include/Hal8723DPhyReg.h	45;"	d
-rPMAC_TxIdle	include/Hal8812PhyReg.h	380;"	d
-rPMAC_TxIdle	include/Hal8814PhyReg.h	487;"	d
-rPMAC_TxIdle	include/rtw_mp_phy_regdef.h	74;"	d
-rPMAC_TxLegacySIG	include/Hal8188EPhyReg.h	39;"	d
-rPMAC_TxLegacySIG	include/Hal8188FPhyReg.h	45;"	d
-rPMAC_TxLegacySIG	include/Hal8192EPhyReg.h	51;"	d
-rPMAC_TxLegacySIG	include/Hal8703BPhyReg.h	40;"	d
-rPMAC_TxLegacySIG	include/Hal8723BPhyReg.h	40;"	d
-rPMAC_TxLegacySIG	include/Hal8723DPhyReg.h	40;"	d
-rPMAC_TxLegacySIG	include/Hal8812PhyReg.h	375;"	d
-rPMAC_TxLegacySIG	include/Hal8814PhyReg.h	482;"	d
-rPMAC_TxLegacySIG	include/rtw_mp_phy_regdef.h	69;"	d
-rPMAC_TxMACHeader0	include/Hal8188EPhyReg.h	45;"	d
-rPMAC_TxMACHeader0	include/Hal8188FPhyReg.h	51;"	d
-rPMAC_TxMACHeader0	include/Hal8192EPhyReg.h	57;"	d
-rPMAC_TxMACHeader0	include/Hal8703BPhyReg.h	46;"	d
-rPMAC_TxMACHeader0	include/Hal8723BPhyReg.h	46;"	d
-rPMAC_TxMACHeader0	include/Hal8723DPhyReg.h	46;"	d
-rPMAC_TxMACHeader0	include/Hal8812PhyReg.h	381;"	d
-rPMAC_TxMACHeader0	include/Hal8814PhyReg.h	488;"	d
-rPMAC_TxMACHeader0	include/rtw_mp_phy_regdef.h	75;"	d
-rPMAC_TxMACHeader1	include/Hal8188EPhyReg.h	46;"	d
-rPMAC_TxMACHeader1	include/Hal8188FPhyReg.h	52;"	d
-rPMAC_TxMACHeader1	include/Hal8192EPhyReg.h	58;"	d
-rPMAC_TxMACHeader1	include/Hal8703BPhyReg.h	47;"	d
-rPMAC_TxMACHeader1	include/Hal8723BPhyReg.h	47;"	d
-rPMAC_TxMACHeader1	include/Hal8723DPhyReg.h	47;"	d
-rPMAC_TxMACHeader1	include/Hal8812PhyReg.h	382;"	d
-rPMAC_TxMACHeader1	include/Hal8814PhyReg.h	489;"	d
-rPMAC_TxMACHeader1	include/rtw_mp_phy_regdef.h	76;"	d
-rPMAC_TxMACHeader2	include/Hal8188EPhyReg.h	47;"	d
-rPMAC_TxMACHeader2	include/Hal8188FPhyReg.h	53;"	d
-rPMAC_TxMACHeader2	include/Hal8192EPhyReg.h	59;"	d
-rPMAC_TxMACHeader2	include/Hal8703BPhyReg.h	48;"	d
-rPMAC_TxMACHeader2	include/Hal8723BPhyReg.h	48;"	d
-rPMAC_TxMACHeader2	include/Hal8723DPhyReg.h	48;"	d
-rPMAC_TxMACHeader2	include/Hal8812PhyReg.h	383;"	d
-rPMAC_TxMACHeader2	include/Hal8814PhyReg.h	490;"	d
-rPMAC_TxMACHeader2	include/rtw_mp_phy_regdef.h	77;"	d
-rPMAC_TxMACHeader3	include/Hal8188EPhyReg.h	48;"	d
-rPMAC_TxMACHeader3	include/Hal8188FPhyReg.h	54;"	d
-rPMAC_TxMACHeader3	include/Hal8192EPhyReg.h	60;"	d
-rPMAC_TxMACHeader3	include/Hal8703BPhyReg.h	49;"	d
-rPMAC_TxMACHeader3	include/Hal8723BPhyReg.h	49;"	d
-rPMAC_TxMACHeader3	include/Hal8723DPhyReg.h	49;"	d
-rPMAC_TxMACHeader3	include/Hal8812PhyReg.h	384;"	d
-rPMAC_TxMACHeader3	include/Hal8814PhyReg.h	491;"	d
-rPMAC_TxMACHeader3	include/rtw_mp_phy_regdef.h	78;"	d
-rPMAC_TxMACHeader4	include/Hal8188EPhyReg.h	49;"	d
-rPMAC_TxMACHeader4	include/Hal8188FPhyReg.h	55;"	d
-rPMAC_TxMACHeader4	include/Hal8192EPhyReg.h	61;"	d
-rPMAC_TxMACHeader4	include/Hal8703BPhyReg.h	50;"	d
-rPMAC_TxMACHeader4	include/Hal8723BPhyReg.h	50;"	d
-rPMAC_TxMACHeader4	include/Hal8723DPhyReg.h	50;"	d
-rPMAC_TxMACHeader4	include/Hal8812PhyReg.h	385;"	d
-rPMAC_TxMACHeader4	include/Hal8814PhyReg.h	492;"	d
-rPMAC_TxMACHeader4	include/rtw_mp_phy_regdef.h	79;"	d
-rPMAC_TxMACHeader5	include/Hal8188EPhyReg.h	50;"	d
-rPMAC_TxMACHeader5	include/Hal8188FPhyReg.h	56;"	d
-rPMAC_TxMACHeader5	include/Hal8192EPhyReg.h	62;"	d
-rPMAC_TxMACHeader5	include/Hal8703BPhyReg.h	51;"	d
-rPMAC_TxMACHeader5	include/Hal8723BPhyReg.h	51;"	d
-rPMAC_TxMACHeader5	include/Hal8723DPhyReg.h	51;"	d
-rPMAC_TxMACHeader5	include/Hal8812PhyReg.h	386;"	d
-rPMAC_TxMACHeader5	include/Hal8814PhyReg.h	493;"	d
-rPMAC_TxMACHeader5	include/rtw_mp_phy_regdef.h	80;"	d
-rPMAC_TxPacketNum	include/Hal8188EPhyReg.h	43;"	d
-rPMAC_TxPacketNum	include/Hal8188FPhyReg.h	49;"	d
-rPMAC_TxPacketNum	include/Hal8192EPhyReg.h	55;"	d
-rPMAC_TxPacketNum	include/Hal8703BPhyReg.h	44;"	d
-rPMAC_TxPacketNum	include/Hal8723BPhyReg.h	44;"	d
-rPMAC_TxPacketNum	include/Hal8723DPhyReg.h	44;"	d
-rPMAC_TxPacketNum	include/Hal8812PhyReg.h	379;"	d
-rPMAC_TxPacketNum	include/Hal8814PhyReg.h	486;"	d
-rPMAC_TxPacketNum	include/rtw_mp_phy_regdef.h	73;"	d
-rPMAC_TxRandomSeed	include/Hal8188EPhyReg.h	52;"	d
-rPMAC_TxRandomSeed	include/Hal8188FPhyReg.h	58;"	d
-rPMAC_TxRandomSeed	include/Hal8192EPhyReg.h	64;"	d
-rPMAC_TxRandomSeed	include/Hal8703BPhyReg.h	53;"	d
-rPMAC_TxRandomSeed	include/Hal8723BPhyReg.h	53;"	d
-rPMAC_TxRandomSeed	include/Hal8723DPhyReg.h	53;"	d
-rPMAC_TxRandomSeed	include/Hal8812PhyReg.h	388;"	d
-rPMAC_TxRandomSeed	include/Hal8814PhyReg.h	495;"	d
-rPMAC_TxRandomSeed	include/rtw_mp_phy_regdef.h	82;"	d
-rPMAC_TxStart	include/Hal8188EPhyReg.h	38;"	d
-rPMAC_TxStart	include/Hal8188FPhyReg.h	44;"	d
-rPMAC_TxStart	include/Hal8192EPhyReg.h	50;"	d
-rPMAC_TxStart	include/Hal8703BPhyReg.h	39;"	d
-rPMAC_TxStart	include/Hal8723BPhyReg.h	39;"	d
-rPMAC_TxStart	include/Hal8723DPhyReg.h	39;"	d
-rPMAC_TxStart	include/Hal8812PhyReg.h	374;"	d
-rPMAC_TxStart	include/Hal8814PhyReg.h	481;"	d
-rPMAC_TxStart	include/rtw_mp_phy_regdef.h	68;"	d
-rPMAC_TxStatus	include/Hal8188EPhyReg.h	63;"	d
-rPMAC_TxStatus	include/Hal8188FPhyReg.h	69;"	d
-rPMAC_TxStatus	include/Hal8192EPhyReg.h	75;"	d
-rPMAC_TxStatus	include/Hal8703BPhyReg.h	64;"	d
-rPMAC_TxStatus	include/Hal8723BPhyReg.h	64;"	d
-rPMAC_TxStatus	include/Hal8723DPhyReg.h	64;"	d
-rPMAC_TxStatus	include/Hal8812PhyReg.h	399;"	d
-rPMAC_TxStatus	include/Hal8814PhyReg.h	506;"	d
-rPMAC_TxStatus	include/rtw_mp_phy_regdef.h	93;"	d
-rPMPD_ANAEN	include/Hal8188EPhyReg.h	344;"	d
-rPMPD_ANAEN	include/Hal8188FPhyReg.h	345;"	d
-rPMPD_ANAEN	include/Hal8192EPhyReg.h	349;"	d
-rPMPD_ANAEN	include/Hal8703BPhyReg.h	377;"	d
-rPMPD_ANAEN	include/Hal8723BPhyReg.h	376;"	d
-rPMPD_ANAEN	include/Hal8723DPhyReg.h	377;"	d
-rPMPD_ANAEN	include/Hal8812PhyReg.h	598;"	d
-rPMPD_ANAEN	include/Hal8814PhyReg.h	721;"	d
-rPdp_AntA	include/Hal8188EPhyReg.h	162;"	d
-rPdp_AntA	include/Hal8188FPhyReg.h	1125;"	d
-rPdp_AntA	include/Hal8188FPhyReg.h	178;"	d
-rPdp_AntA	include/Hal8192EPhyReg.h	169;"	d
-rPdp_AntA	include/Hal8703BPhyReg.h	176;"	d
-rPdp_AntA	include/Hal8723BPhyReg.h	175;"	d
-rPdp_AntA	include/Hal8723DPhyReg.h	176;"	d
-rPdp_AntA	include/Hal8812PhyReg.h	452;"	d
-rPdp_AntA	include/Hal8814PhyReg.h	575;"	d
-rPdp_AntA_10	include/Hal8188FPhyReg.h	1129;"	d
-rPdp_AntA_10	include/Hal8703BPhyReg.h	180;"	d
-rPdp_AntA_10	include/Hal8723BPhyReg.h	179;"	d
-rPdp_AntA_10	include/Hal8723DPhyReg.h	180;"	d
-rPdp_AntA_14	include/Hal8188FPhyReg.h	1130;"	d
-rPdp_AntA_14	include/Hal8703BPhyReg.h	181;"	d
-rPdp_AntA_14	include/Hal8723BPhyReg.h	180;"	d
-rPdp_AntA_14	include/Hal8723DPhyReg.h	181;"	d
-rPdp_AntA_18	include/Hal8188FPhyReg.h	1131;"	d
-rPdp_AntA_18	include/Hal8703BPhyReg.h	182;"	d
-rPdp_AntA_18	include/Hal8723BPhyReg.h	181;"	d
-rPdp_AntA_18	include/Hal8723DPhyReg.h	182;"	d
-rPdp_AntA_1C	include/Hal8188FPhyReg.h	1132;"	d
-rPdp_AntA_1C	include/Hal8703BPhyReg.h	183;"	d
-rPdp_AntA_1C	include/Hal8723BPhyReg.h	182;"	d
-rPdp_AntA_1C	include/Hal8723DPhyReg.h	183;"	d
-rPdp_AntA_20	include/Hal8188FPhyReg.h	1133;"	d
-rPdp_AntA_20	include/Hal8703BPhyReg.h	184;"	d
-rPdp_AntA_20	include/Hal8723BPhyReg.h	183;"	d
-rPdp_AntA_20	include/Hal8723DPhyReg.h	184;"	d
-rPdp_AntA_24	include/Hal8188FPhyReg.h	1134;"	d
-rPdp_AntA_24	include/Hal8703BPhyReg.h	185;"	d
-rPdp_AntA_24	include/Hal8723BPhyReg.h	184;"	d
-rPdp_AntA_24	include/Hal8723DPhyReg.h	185;"	d
-rPdp_AntA_4	include/Hal8188EPhyReg.h	163;"	d
-rPdp_AntA_4	include/Hal8188FPhyReg.h	1126;"	d
-rPdp_AntA_4	include/Hal8188FPhyReg.h	179;"	d
-rPdp_AntA_4	include/Hal8192EPhyReg.h	170;"	d
-rPdp_AntA_4	include/Hal8703BPhyReg.h	177;"	d
-rPdp_AntA_4	include/Hal8723BPhyReg.h	176;"	d
-rPdp_AntA_4	include/Hal8723DPhyReg.h	177;"	d
-rPdp_AntA_4	include/Hal8812PhyReg.h	453;"	d
-rPdp_AntA_4	include/Hal8814PhyReg.h	576;"	d
-rPdp_AntA_8	include/Hal8188FPhyReg.h	1127;"	d
-rPdp_AntA_8	include/Hal8703BPhyReg.h	178;"	d
-rPdp_AntA_8	include/Hal8723BPhyReg.h	177;"	d
-rPdp_AntA_8	include/Hal8723DPhyReg.h	178;"	d
-rPdp_AntA_C	include/Hal8188FPhyReg.h	1128;"	d
-rPdp_AntA_C	include/Hal8703BPhyReg.h	179;"	d
-rPdp_AntA_C	include/Hal8723BPhyReg.h	178;"	d
-rPdp_AntA_C	include/Hal8723DPhyReg.h	179;"	d
-rPdp_AntB	include/Hal8188EPhyReg.h	168;"	d
-rPdp_AntB	include/Hal8188FPhyReg.h	1145;"	d
-rPdp_AntB	include/Hal8188FPhyReg.h	183;"	d
-rPdp_AntB	include/Hal8192EPhyReg.h	176;"	d
-rPdp_AntB	include/Hal8703BPhyReg.h	196;"	d
-rPdp_AntB	include/Hal8723BPhyReg.h	195;"	d
-rPdp_AntB	include/Hal8723DPhyReg.h	196;"	d
-rPdp_AntB	include/Hal8812PhyReg.h	457;"	d
-rPdp_AntB	include/Hal8814PhyReg.h	580;"	d
-rPdp_AntB_10	include/Hal8188FPhyReg.h	1149;"	d
-rPdp_AntB_10	include/Hal8703BPhyReg.h	200;"	d
-rPdp_AntB_10	include/Hal8723BPhyReg.h	199;"	d
-rPdp_AntB_10	include/Hal8723DPhyReg.h	200;"	d
-rPdp_AntB_14	include/Hal8188FPhyReg.h	1150;"	d
-rPdp_AntB_14	include/Hal8703BPhyReg.h	201;"	d
-rPdp_AntB_14	include/Hal8723BPhyReg.h	200;"	d
-rPdp_AntB_14	include/Hal8723DPhyReg.h	201;"	d
-rPdp_AntB_18	include/Hal8188FPhyReg.h	1151;"	d
-rPdp_AntB_18	include/Hal8703BPhyReg.h	202;"	d
-rPdp_AntB_18	include/Hal8723BPhyReg.h	201;"	d
-rPdp_AntB_18	include/Hal8723DPhyReg.h	202;"	d
-rPdp_AntB_1C	include/Hal8188FPhyReg.h	1152;"	d
-rPdp_AntB_1C	include/Hal8703BPhyReg.h	203;"	d
-rPdp_AntB_1C	include/Hal8723BPhyReg.h	202;"	d
-rPdp_AntB_1C	include/Hal8723DPhyReg.h	203;"	d
-rPdp_AntB_20	include/Hal8188FPhyReg.h	1153;"	d
-rPdp_AntB_20	include/Hal8703BPhyReg.h	204;"	d
-rPdp_AntB_20	include/Hal8723BPhyReg.h	203;"	d
-rPdp_AntB_20	include/Hal8723DPhyReg.h	204;"	d
-rPdp_AntB_24	include/Hal8188FPhyReg.h	1154;"	d
-rPdp_AntB_24	include/Hal8703BPhyReg.h	205;"	d
-rPdp_AntB_24	include/Hal8723BPhyReg.h	204;"	d
-rPdp_AntB_24	include/Hal8723DPhyReg.h	205;"	d
-rPdp_AntB_4	include/Hal8188EPhyReg.h	169;"	d
-rPdp_AntB_4	include/Hal8188FPhyReg.h	1146;"	d
-rPdp_AntB_4	include/Hal8188FPhyReg.h	184;"	d
-rPdp_AntB_4	include/Hal8192EPhyReg.h	177;"	d
-rPdp_AntB_4	include/Hal8703BPhyReg.h	197;"	d
-rPdp_AntB_4	include/Hal8723BPhyReg.h	196;"	d
-rPdp_AntB_4	include/Hal8723DPhyReg.h	197;"	d
-rPdp_AntB_4	include/Hal8812PhyReg.h	458;"	d
-rPdp_AntB_4	include/Hal8814PhyReg.h	581;"	d
-rPdp_AntB_8	include/Hal8188FPhyReg.h	1147;"	d
-rPdp_AntB_8	include/Hal8703BPhyReg.h	198;"	d
-rPdp_AntB_8	include/Hal8723BPhyReg.h	197;"	d
-rPdp_AntB_8	include/Hal8723DPhyReg.h	198;"	d
-rPdp_AntB_C	include/Hal8188FPhyReg.h	1148;"	d
-rPdp_AntB_C	include/Hal8703BPhyReg.h	199;"	d
-rPdp_AntB_C	include/Hal8723BPhyReg.h	198;"	d
-rPdp_AntB_C	include/Hal8723DPhyReg.h	199;"	d
-rPm_Rx0_AntA	include/Hal8188FPhyReg.h	1161;"	d
-rPm_Rx0_AntA	include/Hal8703BPhyReg.h	212;"	d
-rPm_Rx0_AntA	include/Hal8723BPhyReg.h	211;"	d
-rPm_Rx0_AntA	include/Hal8723DPhyReg.h	212;"	d
-rPm_Rx0_AntB	include/Hal8188FPhyReg.h	1165;"	d
-rPm_Rx0_AntB	include/Hal8703BPhyReg.h	216;"	d
-rPm_Rx0_AntB	include/Hal8723BPhyReg.h	215;"	d
-rPm_Rx0_AntB	include/Hal8723DPhyReg.h	216;"	d
-rPm_Rx1_AntA	include/Hal8188FPhyReg.h	1162;"	d
-rPm_Rx1_AntA	include/Hal8703BPhyReg.h	213;"	d
-rPm_Rx1_AntA	include/Hal8723BPhyReg.h	212;"	d
-rPm_Rx1_AntA	include/Hal8723DPhyReg.h	213;"	d
-rPm_Rx1_AntB	include/Hal8188FPhyReg.h	1166;"	d
-rPm_Rx1_AntB	include/Hal8703BPhyReg.h	217;"	d
-rPm_Rx1_AntB	include/Hal8723BPhyReg.h	216;"	d
-rPm_Rx1_AntB	include/Hal8723DPhyReg.h	217;"	d
-rPm_Rx2_AntA	include/Hal8188FPhyReg.h	1163;"	d
-rPm_Rx2_AntA	include/Hal8703BPhyReg.h	214;"	d
-rPm_Rx2_AntA	include/Hal8723BPhyReg.h	213;"	d
-rPm_Rx2_AntA	include/Hal8723DPhyReg.h	214;"	d
-rPm_Rx2_AntB	include/Hal8188FPhyReg.h	1167;"	d
-rPm_Rx2_AntB	include/Hal8703BPhyReg.h	218;"	d
-rPm_Rx2_AntB	include/Hal8723BPhyReg.h	217;"	d
-rPm_Rx2_AntB	include/Hal8723DPhyReg.h	218;"	d
-rPm_Rx3_AntA	include/Hal8188FPhyReg.h	1164;"	d
-rPm_Rx3_AntA	include/Hal8703BPhyReg.h	215;"	d
-rPm_Rx3_AntA	include/Hal8723BPhyReg.h	214;"	d
-rPm_Rx3_AntA	include/Hal8723DPhyReg.h	215;"	d
-rPm_Rx3_AntB	include/Hal8188FPhyReg.h	1168;"	d
-rPm_Rx3_AntB	include/Hal8703BPhyReg.h	219;"	d
-rPm_Rx3_AntB	include/Hal8723BPhyReg.h	218;"	d
-rPm_Rx3_AntB	include/Hal8723DPhyReg.h	219;"	d
-rPwed_TH_Jaguar	include/Hal8812PhyReg.h	36;"	d
-rPwed_TH_Jaguar	include/Hal8814PhyReg.h	36;"	d
-rRFECTRL_Jaguar	include/Hal8812PhyReg.h	44;"	d
-rRFECTRL_Jaguar	include/Hal8814PhyReg.h	46;"	d
-rRFMOD_Jaguar	include/Hal8812PhyReg.h	42;"	d
-rRFMOD_Jaguar	include/Hal8814PhyReg.h	43;"	d
-rRF_TxGainOffset	hal/phydm/phydm_reg.h	113;"	d
-rRF_TxGainOffset	include/Hal8814PhyReg.h	155;"	d
-rRTL8256_RxLPF	include/Hal8188EPhyReg.h	367;"	d
-rRTL8256_RxLPF	include/Hal8188FPhyReg.h	368;"	d
-rRTL8256_RxLPF	include/Hal8192EPhyReg.h	372;"	d
-rRTL8256_RxLPF	include/Hal8703BPhyReg.h	400;"	d
-rRTL8256_RxLPF	include/Hal8723BPhyReg.h	399;"	d
-rRTL8256_RxLPF	include/Hal8723DPhyReg.h	400;"	d
-rRTL8256_RxLPF	include/rtw_mp_phy_regdef.h	336;"	d
-rRTL8256_TxLPF	include/Hal8188EPhyReg.h	366;"	d
-rRTL8256_TxLPF	include/Hal8188FPhyReg.h	367;"	d
-rRTL8256_TxLPF	include/Hal8192EPhyReg.h	371;"	d
-rRTL8256_TxLPF	include/Hal8703BPhyReg.h	399;"	d
-rRTL8256_TxLPF	include/Hal8723BPhyReg.h	398;"	d
-rRTL8256_TxLPF	include/Hal8723DPhyReg.h	399;"	d
-rRTL8256_TxLPF	include/rtw_mp_phy_regdef.h	335;"	d
-rRTL8258_RSSILPF	include/Hal8188EPhyReg.h	372;"	d
-rRTL8258_RSSILPF	include/Hal8188FPhyReg.h	373;"	d
-rRTL8258_RSSILPF	include/Hal8192EPhyReg.h	377;"	d
-rRTL8258_RSSILPF	include/Hal8703BPhyReg.h	405;"	d
-rRTL8258_RSSILPF	include/Hal8723BPhyReg.h	404;"	d
-rRTL8258_RSSILPF	include/Hal8723DPhyReg.h	405;"	d
-rRTL8258_RSSILPF	include/rtw_mp_phy_regdef.h	341;"	d
-rRTL8258_RxLPF	include/Hal8188EPhyReg.h	371;"	d
-rRTL8258_RxLPF	include/Hal8188FPhyReg.h	372;"	d
-rRTL8258_RxLPF	include/Hal8192EPhyReg.h	376;"	d
-rRTL8258_RxLPF	include/Hal8703BPhyReg.h	404;"	d
-rRTL8258_RxLPF	include/Hal8723BPhyReg.h	403;"	d
-rRTL8258_RxLPF	include/Hal8723DPhyReg.h	404;"	d
-rRTL8258_RxLPF	include/rtw_mp_phy_regdef.h	340;"	d
-rRTL8258_TxLPF	include/Hal8188EPhyReg.h	370;"	d
-rRTL8258_TxLPF	include/Hal8188FPhyReg.h	371;"	d
-rRTL8258_TxLPF	include/Hal8192EPhyReg.h	375;"	d
-rRTL8258_TxLPF	include/Hal8703BPhyReg.h	403;"	d
-rRTL8258_TxLPF	include/Hal8723BPhyReg.h	402;"	d
-rRTL8258_TxLPF	include/Hal8723DPhyReg.h	403;"	d
-rRTL8258_TxLPF	include/rtw_mp_phy_regdef.h	339;"	d
-rRead_data_Jaguar	include/Hal8812PhyReg.h	69;"	d
-rRead_data_Jaguar	include/Hal8814PhyReg.h	76;"	d
-rRfChannel	include/Hal8188FPhyReg.h	408;"	d
-rRfChannel	include/Hal8703BPhyReg.h	440;"	d
-rRfChannel	include/Hal8723BPhyReg.h	439;"	d
-rRfChannel	include/Hal8723DPhyReg.h	440;"	d
-rRfChannel	include/rtw_mp_phy_regdef.h	368;"	d
-rRxPath_Jaguar	include/Hal8812PhyReg.h	53;"	d
-rRxPath_Jaguar	include/Hal8814PhyReg.h	55;"	d
-rRxPath_Jaguar2	include/Hal8814PhyReg.h	63;"	d
-rRx_CCK	include/Hal8188EPhyReg.h	321;"	d
-rRx_CCK	include/Hal8188FPhyReg.h	322;"	d
-rRx_CCK	include/Hal8192EPhyReg.h	326;"	d
-rRx_CCK	include/Hal8703BPhyReg.h	354;"	d
-rRx_CCK	include/Hal8723BPhyReg.h	353;"	d
-rRx_CCK	include/Hal8723DPhyReg.h	354;"	d
-rRx_CCK	include/Hal8812PhyReg.h	575;"	d
-rRx_CCK	include/Hal8814PhyReg.h	698;"	d
-rRx_IQK	include/Hal8188EPhyReg.h	304;"	d
-rRx_IQK	include/Hal8188FPhyReg.h	305;"	d
-rRx_IQK	include/Hal8192EPhyReg.h	309;"	d
-rRx_IQK	include/Hal8703BPhyReg.h	337;"	d
-rRx_IQK	include/Hal8723BPhyReg.h	336;"	d
-rRx_IQK	include/Hal8723DPhyReg.h	337;"	d
-rRx_IQK	include/Hal8812PhyReg.h	558;"	d
-rRx_IQK	include/Hal8814PhyReg.h	681;"	d
-rRx_IQK_PI_A	include/Hal8188EPhyReg.h	301;"	d
-rRx_IQK_PI_A	include/Hal8188FPhyReg.h	302;"	d
-rRx_IQK_PI_A	include/Hal8192EPhyReg.h	306;"	d
-rRx_IQK_PI_A	include/Hal8703BPhyReg.h	334;"	d
-rRx_IQK_PI_A	include/Hal8723BPhyReg.h	333;"	d
-rRx_IQK_PI_A	include/Hal8723DPhyReg.h	334;"	d
-rRx_IQK_PI_A	include/Hal8812PhyReg.h	555;"	d
-rRx_IQK_PI_A	include/Hal8814PhyReg.h	678;"	d
-rRx_IQK_PI_B	include/Hal8188EPhyReg.h	310;"	d
-rRx_IQK_PI_B	include/Hal8188FPhyReg.h	311;"	d
-rRx_IQK_PI_B	include/Hal8192EPhyReg.h	315;"	d
-rRx_IQK_PI_B	include/Hal8703BPhyReg.h	343;"	d
-rRx_IQK_PI_B	include/Hal8723BPhyReg.h	342;"	d
-rRx_IQK_PI_B	include/Hal8723DPhyReg.h	343;"	d
-rRx_IQK_PI_B	include/Hal8812PhyReg.h	564;"	d
-rRx_IQK_PI_B	include/Hal8814PhyReg.h	687;"	d
-rRx_IQK_Tone_A	include/Hal8188EPhyReg.h	299;"	d
-rRx_IQK_Tone_A	include/Hal8188FPhyReg.h	300;"	d
-rRx_IQK_Tone_A	include/Hal8192EPhyReg.h	304;"	d
-rRx_IQK_Tone_A	include/Hal8703BPhyReg.h	332;"	d
-rRx_IQK_Tone_A	include/Hal8723BPhyReg.h	331;"	d
-rRx_IQK_Tone_A	include/Hal8723DPhyReg.h	332;"	d
-rRx_IQK_Tone_A	include/Hal8812PhyReg.h	553;"	d
-rRx_IQK_Tone_A	include/Hal8814PhyReg.h	676;"	d
-rRx_IQK_Tone_B	include/Hal8188EPhyReg.h	308;"	d
-rRx_IQK_Tone_B	include/Hal8188FPhyReg.h	309;"	d
-rRx_IQK_Tone_B	include/Hal8192EPhyReg.h	313;"	d
-rRx_IQK_Tone_B	include/Hal8703BPhyReg.h	341;"	d
-rRx_IQK_Tone_B	include/Hal8723BPhyReg.h	340;"	d
-rRx_IQK_Tone_B	include/Hal8723DPhyReg.h	341;"	d
-rRx_IQK_Tone_B	include/Hal8812PhyReg.h	562;"	d
-rRx_IQK_Tone_B	include/Hal8814PhyReg.h	685;"	d
-rRx_OFDM	include/Hal8188EPhyReg.h	339;"	d
-rRx_OFDM	include/Hal8188FPhyReg.h	340;"	d
-rRx_OFDM	include/Hal8192EPhyReg.h	344;"	d
-rRx_OFDM	include/Hal8703BPhyReg.h	372;"	d
-rRx_OFDM	include/Hal8723BPhyReg.h	371;"	d
-rRx_OFDM	include/Hal8723DPhyReg.h	372;"	d
-rRx_OFDM	include/Hal8812PhyReg.h	593;"	d
-rRx_OFDM	include/Hal8814PhyReg.h	716;"	d
-rRx_Power_After_IQK_A	include/Hal8188EPhyReg.h	328;"	d
-rRx_Power_After_IQK_A	include/Hal8188FPhyReg.h	329;"	d
-rRx_Power_After_IQK_A	include/Hal8192EPhyReg.h	333;"	d
-rRx_Power_After_IQK_A	include/Hal8703BPhyReg.h	361;"	d
-rRx_Power_After_IQK_A	include/Hal8723BPhyReg.h	360;"	d
-rRx_Power_After_IQK_A	include/Hal8723DPhyReg.h	361;"	d
-rRx_Power_After_IQK_A	include/Hal8812PhyReg.h	582;"	d
-rRx_Power_After_IQK_A	include/Hal8814PhyReg.h	705;"	d
-rRx_Power_After_IQK_A_2	include/Hal8188EPhyReg.h	329;"	d
-rRx_Power_After_IQK_A_2	include/Hal8188FPhyReg.h	330;"	d
-rRx_Power_After_IQK_A_2	include/Hal8192EPhyReg.h	334;"	d
-rRx_Power_After_IQK_A_2	include/Hal8703BPhyReg.h	362;"	d
-rRx_Power_After_IQK_A_2	include/Hal8723BPhyReg.h	361;"	d
-rRx_Power_After_IQK_A_2	include/Hal8723DPhyReg.h	362;"	d
-rRx_Power_After_IQK_A_2	include/Hal8812PhyReg.h	583;"	d
-rRx_Power_After_IQK_A_2	include/Hal8814PhyReg.h	706;"	d
-rRx_Power_After_IQK_B	include/Hal8188EPhyReg.h	336;"	d
-rRx_Power_After_IQK_B	include/Hal8188FPhyReg.h	337;"	d
-rRx_Power_After_IQK_B	include/Hal8192EPhyReg.h	341;"	d
-rRx_Power_After_IQK_B	include/Hal8703BPhyReg.h	369;"	d
-rRx_Power_After_IQK_B	include/Hal8723BPhyReg.h	368;"	d
-rRx_Power_After_IQK_B	include/Hal8723DPhyReg.h	369;"	d
-rRx_Power_After_IQK_B	include/Hal8812PhyReg.h	590;"	d
-rRx_Power_After_IQK_B	include/Hal8814PhyReg.h	713;"	d
-rRx_Power_After_IQK_B_2	include/Hal8188EPhyReg.h	337;"	d
-rRx_Power_After_IQK_B_2	include/Hal8188FPhyReg.h	338;"	d
-rRx_Power_After_IQK_B_2	include/Hal8192EPhyReg.h	342;"	d
-rRx_Power_After_IQK_B_2	include/Hal8703BPhyReg.h	370;"	d
-rRx_Power_After_IQK_B_2	include/Hal8723BPhyReg.h	369;"	d
-rRx_Power_After_IQK_B_2	include/Hal8723DPhyReg.h	370;"	d
-rRx_Power_After_IQK_B_2	include/Hal8812PhyReg.h	591;"	d
-rRx_Power_After_IQK_B_2	include/Hal8814PhyReg.h	714;"	d
-rRx_Power_Before_IQK_A	include/Hal8188EPhyReg.h	326;"	d
-rRx_Power_Before_IQK_A	include/Hal8188FPhyReg.h	327;"	d
-rRx_Power_Before_IQK_A	include/Hal8192EPhyReg.h	331;"	d
-rRx_Power_Before_IQK_A	include/Hal8703BPhyReg.h	359;"	d
-rRx_Power_Before_IQK_A	include/Hal8723BPhyReg.h	358;"	d
-rRx_Power_Before_IQK_A	include/Hal8723DPhyReg.h	359;"	d
-rRx_Power_Before_IQK_A	include/Hal8812PhyReg.h	580;"	d
-rRx_Power_Before_IQK_A	include/Hal8814PhyReg.h	703;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8188EPhyReg.h	327;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8188FPhyReg.h	328;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8192EPhyReg.h	332;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8703BPhyReg.h	360;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8723BPhyReg.h	359;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8723DPhyReg.h	360;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8812PhyReg.h	581;"	d
-rRx_Power_Before_IQK_A_2	include/Hal8814PhyReg.h	704;"	d
-rRx_Power_Before_IQK_B	include/Hal8188EPhyReg.h	334;"	d
-rRx_Power_Before_IQK_B	include/Hal8188FPhyReg.h	335;"	d
-rRx_Power_Before_IQK_B	include/Hal8192EPhyReg.h	339;"	d
-rRx_Power_Before_IQK_B	include/Hal8703BPhyReg.h	367;"	d
-rRx_Power_Before_IQK_B	include/Hal8723BPhyReg.h	366;"	d
-rRx_Power_Before_IQK_B	include/Hal8723DPhyReg.h	367;"	d
-rRx_Power_Before_IQK_B	include/Hal8812PhyReg.h	588;"	d
-rRx_Power_Before_IQK_B	include/Hal8814PhyReg.h	711;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8188EPhyReg.h	335;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8188FPhyReg.h	336;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8192EPhyReg.h	340;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8703BPhyReg.h	368;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8723BPhyReg.h	367;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8723DPhyReg.h	368;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8812PhyReg.h	589;"	d
-rRx_Power_Before_IQK_B_2	include/Hal8814PhyReg.h	712;"	d
-rRx_TO_Rx	include/Hal8188EPhyReg.h	341;"	d
-rRx_TO_Rx	include/Hal8188FPhyReg.h	342;"	d
-rRx_TO_Rx	include/Hal8192EPhyReg.h	346;"	d
-rRx_TO_Rx	include/Hal8703BPhyReg.h	374;"	d
-rRx_TO_Rx	include/Hal8723BPhyReg.h	373;"	d
-rRx_TO_Rx	include/Hal8723DPhyReg.h	374;"	d
-rRx_TO_Rx	include/Hal8812PhyReg.h	595;"	d
-rRx_TO_Rx	include/Hal8814PhyReg.h	718;"	d
-rRx_Wait_CCA	include/Hal8188EPhyReg.h	314;"	d
-rRx_Wait_CCA	include/Hal8188FPhyReg.h	315;"	d
-rRx_Wait_CCA	include/Hal8192EPhyReg.h	319;"	d
-rRx_Wait_CCA	include/Hal8703BPhyReg.h	347;"	d
-rRx_Wait_CCA	include/Hal8723BPhyReg.h	346;"	d
-rRx_Wait_CCA	include/Hal8723DPhyReg.h	347;"	d
-rRx_Wait_CCA	include/Hal8812PhyReg.h	568;"	d
-rRx_Wait_CCA	include/Hal8814PhyReg.h	691;"	d
-rRx_Wait_CCCA	include/rtw_mp_phy_regdef.h	309;"	d
-rRx_Wait_RIFS	include/Hal8188EPhyReg.h	340;"	d
-rRx_Wait_RIFS	include/Hal8188FPhyReg.h	341;"	d
-rRx_Wait_RIFS	include/Hal8192EPhyReg.h	345;"	d
-rRx_Wait_RIFS	include/Hal8703BPhyReg.h	373;"	d
-rRx_Wait_RIFS	include/Hal8723BPhyReg.h	372;"	d
-rRx_Wait_RIFS	include/Hal8723DPhyReg.h	373;"	d
-rRx_Wait_RIFS	include/Hal8812PhyReg.h	594;"	d
-rRx_Wait_RIFS	include/Hal8814PhyReg.h	717;"	d
-rS0S1_PathSwitch	include/Hal8188FPhyReg.h	1118;"	d
-rS0S1_PathSwitch	include/Hal8188FPhyReg.h	148;"	d
-rS0S1_PathSwitch	include/Hal8703BPhyReg.h	144;"	d
-rS0S1_PathSwitch	include/Hal8723BPhyReg.h	144;"	d
-rS0S1_PathSwitch	include/Hal8723DPhyReg.h	144;"	d
-rS0S1_PathSwitch	include/rtw_mp_phy_regdef.h	169;"	d
-rS1_RXevmDump_92E	include/Hal8192EPhyReg.h	1120;"	d
-rS1_RXevmDump_Jaguar	include/Hal8812PhyReg.h	267;"	d
-rS1_RXevmDump_Jaguar	include/Hal8814PhyReg.h	377;"	d
-rS2_RXevmDump_92E	include/Hal8192EPhyReg.h	1121;"	d
-rS2_RXevmDump_Jaguar	include/Hal8812PhyReg.h	268;"	d
-rS2_RXevmDump_Jaguar	include/Hal8814PhyReg.h	378;"	d
-rSYM_WLBT_PAPE_SEL	include/Hal8703BPhyReg.h	23;"	d
-rSYM_WLBT_PAPE_SEL	include/Hal8723BPhyReg.h	23;"	d
-rSYM_WLBT_PAPE_SEL	include/Hal8723DPhyReg.h	23;"	d
-rSingleTone_ContTx_Jaguar	include/Hal8812PhyReg.h	162;"	d
-rSingleTone_ContTx_Jaguar	include/Hal8814PhyReg.h	192;"	d
-rSingleTone_ContTx_Jaguar	include/rtl8822b_hal.h	100;"	d
-rSleep	include/Hal8188EPhyReg.h	343;"	d
-rSleep	include/Hal8188FPhyReg.h	344;"	d
-rSleep	include/Hal8192EPhyReg.h	348;"	d
-rSleep	include/Hal8703BPhyReg.h	376;"	d
-rSleep	include/Hal8723BPhyReg.h	375;"	d
-rSleep	include/Hal8723DPhyReg.h	376;"	d
-rSleep	include/Hal8812PhyReg.h	597;"	d
-rSleep	include/Hal8814PhyReg.h	720;"	d
-rStandby	include/Hal8188EPhyReg.h	342;"	d
-rStandby	include/Hal8188FPhyReg.h	343;"	d
-rStandby	include/Hal8192EPhyReg.h	347;"	d
-rStandby	include/Hal8703BPhyReg.h	375;"	d
-rStandby	include/Hal8723BPhyReg.h	374;"	d
-rStandby	include/Hal8723DPhyReg.h	375;"	d
-rStandby	include/Hal8812PhyReg.h	596;"	d
-rStandby	include/Hal8814PhyReg.h	719;"	d
-rTxAGC_A_CCK11_CCK1_JAguar	hal/phydm/phydm_reg.h	131;"	d
-rTxAGC_A_CCK11_CCK1_JAguar	include/Hal8812PhyReg.h	176;"	d
-rTxAGC_A_CCK11_CCK1_JAguar	include/Hal8814PhyReg.h	216;"	d
-rTxAGC_A_CCK11_CCK1_Jaguar2	include/Hal8814PhyReg.h	247;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8188EPhyReg.h	282;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8188FPhyReg.h	292;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8192EPhyReg.h	287;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8703BPhyReg.h	324;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8723BPhyReg.h	323;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8723DPhyReg.h	324;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8812PhyReg.h	536;"	d
-rTxAGC_A_CCK1_Mcs32	include/Hal8814PhyReg.h	659;"	d
-rTxAGC_A_CCK1_Mcs32	include/rtl8822b_hal.h	142;"	d
-rTxAGC_A_MCS11_MCS8_JAguar	hal/phydm/phydm_reg.h	136;"	d
-rTxAGC_A_MCS11_MCS8_JAguar	include/Hal8812PhyReg.h	181;"	d
-rTxAGC_A_MCS11_MCS8_JAguar	include/Hal8814PhyReg.h	221;"	d
-rTxAGC_A_MCS11_MCS8_Jaguar2	include/Hal8814PhyReg.h	252;"	d
-rTxAGC_A_MCS15_MCS12_JAguar	hal/phydm/phydm_reg.h	137;"	d
-rTxAGC_A_MCS15_MCS12_JAguar	include/Hal8812PhyReg.h	182;"	d
-rTxAGC_A_MCS15_MCS12_JAguar	include/Hal8814PhyReg.h	222;"	d
-rTxAGC_A_MCS15_MCS12_Jaguar2	include/Hal8814PhyReg.h	253;"	d
-rTxAGC_A_MCS19_MCS16_JAguar	hal/phydm/phydm_reg.h	144;"	d
-rTxAGC_A_MCS19_MCS16_Jaguar2	include/Hal8814PhyReg.h	254;"	d
-rTxAGC_A_MCS23_MCS20_JAguar	hal/phydm/phydm_reg.h	145;"	d
-rTxAGC_A_MCS23_MCS20_Jaguar2	include/Hal8814PhyReg.h	255;"	d
-rTxAGC_A_MCS3_MCS0_JAguar	hal/phydm/phydm_reg.h	134;"	d
-rTxAGC_A_MCS3_MCS0_JAguar	include/Hal8812PhyReg.h	179;"	d
-rTxAGC_A_MCS3_MCS0_JAguar	include/Hal8814PhyReg.h	219;"	d
-rTxAGC_A_MCS3_MCS0_Jaguar2	include/Hal8814PhyReg.h	250;"	d
-rTxAGC_A_MCS7_MCS4_JAguar	hal/phydm/phydm_reg.h	135;"	d
-rTxAGC_A_MCS7_MCS4_JAguar	include/Hal8812PhyReg.h	180;"	d
-rTxAGC_A_MCS7_MCS4_JAguar	include/Hal8814PhyReg.h	220;"	d
-rTxAGC_A_MCS7_MCS4_Jaguar2	include/Hal8814PhyReg.h	251;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8188EPhyReg.h	283;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8188FPhyReg.h	293;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8192EPhyReg.h	288;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8703BPhyReg.h	325;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8723BPhyReg.h	324;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8723DPhyReg.h	325;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8812PhyReg.h	537;"	d
-rTxAGC_A_Mcs03_Mcs00	include/Hal8814PhyReg.h	660;"	d
-rTxAGC_A_Mcs03_Mcs00	include/rtl8822b_hal.h	143;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8188EPhyReg.h	284;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8188FPhyReg.h	294;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8192EPhyReg.h	289;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8703BPhyReg.h	326;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8723BPhyReg.h	325;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8723DPhyReg.h	326;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8812PhyReg.h	538;"	d
-rTxAGC_A_Mcs07_Mcs04	include/Hal8814PhyReg.h	661;"	d
-rTxAGC_A_Mcs07_Mcs04	include/rtl8822b_hal.h	144;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8188EPhyReg.h	285;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8188FPhyReg.h	295;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8192EPhyReg.h	290;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8703BPhyReg.h	327;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8723BPhyReg.h	326;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8723DPhyReg.h	327;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8812PhyReg.h	539;"	d
-rTxAGC_A_Mcs11_Mcs08	include/Hal8814PhyReg.h	662;"	d
-rTxAGC_A_Mcs11_Mcs08	include/rtl8822b_hal.h	145;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8188EPhyReg.h	286;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8188FPhyReg.h	296;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8192EPhyReg.h	291;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8703BPhyReg.h	328;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8723BPhyReg.h	327;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8723DPhyReg.h	328;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8812PhyReg.h	540;"	d
-rTxAGC_A_Mcs15_Mcs12	include/Hal8814PhyReg.h	663;"	d
-rTxAGC_A_Mcs15_Mcs12	include/rtl8822b_hal.h	146;"	d
-rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	hal/phydm/phydm_reg.h	138;"	d
-rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	include/Hal8812PhyReg.h	183;"	d
-rTxAGC_A_Nss1Index3_Nss1Index0_JAguar	include/Hal8814PhyReg.h	223;"	d
-rTxAGC_A_Nss1Index3_Nss1Index0_Jaguar2	include/Hal8814PhyReg.h	256;"	d
-rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	hal/phydm/phydm_reg.h	139;"	d
-rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	include/Hal8812PhyReg.h	184;"	d
-rTxAGC_A_Nss1Index7_Nss1Index4_JAguar	include/Hal8814PhyReg.h	224;"	d
-rTxAGC_A_Nss1Index7_Nss1Index4_Jaguar2	include/Hal8814PhyReg.h	257;"	d
-rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	hal/phydm/phydm_reg.h	140;"	d
-rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	include/Hal8812PhyReg.h	185;"	d
-rTxAGC_A_Nss2Index1_Nss1Index8_JAguar	include/Hal8814PhyReg.h	225;"	d
-rTxAGC_A_Nss2Index1_Nss1Index8_Jaguar2	include/Hal8814PhyReg.h	258;"	d
-rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	hal/phydm/phydm_reg.h	141;"	d
-rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	include/Hal8812PhyReg.h	186;"	d
-rTxAGC_A_Nss2Index5_Nss2Index2_JAguar	include/Hal8814PhyReg.h	226;"	d
-rTxAGC_A_Nss2Index5_Nss2Index2_Jaguar2	include/Hal8814PhyReg.h	259;"	d
-rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	hal/phydm/phydm_reg.h	142;"	d
-rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	include/Hal8812PhyReg.h	187;"	d
-rTxAGC_A_Nss2Index9_Nss2Index6_JAguar	include/Hal8814PhyReg.h	227;"	d
-rTxAGC_A_Nss2Index9_Nss2Index6_Jaguar2	include/Hal8814PhyReg.h	260;"	d
-rTxAGC_A_Nss3Index3_Nss3Index0_JAguar	hal/phydm/phydm_reg.h	146;"	d
-rTxAGC_A_Nss3Index3_Nss3Index0_Jaguar2	include/Hal8814PhyReg.h	261;"	d
-rTxAGC_A_Nss3Index7_Nss3Index4_JAguar	hal/phydm/phydm_reg.h	147;"	d
-rTxAGC_A_Nss3Index7_Nss3Index4_Jaguar2	include/Hal8814PhyReg.h	262;"	d
-rTxAGC_A_Nss3Index9_Nss3Index8_JAguar	hal/phydm/phydm_reg.h	148;"	d
-rTxAGC_A_Nss3Index9_Nss3Index8_Jaguar2	include/Hal8814PhyReg.h	263;"	d
-rTxAGC_A_Ofdm18_Ofdm6_JAguar	hal/phydm/phydm_reg.h	132;"	d
-rTxAGC_A_Ofdm18_Ofdm6_JAguar	include/Hal8812PhyReg.h	177;"	d
-rTxAGC_A_Ofdm18_Ofdm6_JAguar	include/Hal8814PhyReg.h	217;"	d
-rTxAGC_A_Ofdm18_Ofdm6_Jaguar2	include/Hal8814PhyReg.h	248;"	d
-rTxAGC_A_Ofdm54_Ofdm24_JAguar	hal/phydm/phydm_reg.h	133;"	d
-rTxAGC_A_Ofdm54_Ofdm24_JAguar	include/Hal8812PhyReg.h	178;"	d
-rTxAGC_A_Ofdm54_Ofdm24_JAguar	include/Hal8814PhyReg.h	218;"	d
-rTxAGC_A_Ofdm54_Ofdm24_Jaguar2	include/Hal8814PhyReg.h	249;"	d
-rTxAGC_A_Rate18_06	include/Hal8188EPhyReg.h	280;"	d
-rTxAGC_A_Rate18_06	include/Hal8188FPhyReg.h	290;"	d
-rTxAGC_A_Rate18_06	include/Hal8192EPhyReg.h	285;"	d
-rTxAGC_A_Rate18_06	include/Hal8703BPhyReg.h	322;"	d
-rTxAGC_A_Rate18_06	include/Hal8723BPhyReg.h	321;"	d
-rTxAGC_A_Rate18_06	include/Hal8723DPhyReg.h	322;"	d
-rTxAGC_A_Rate18_06	include/Hal8812PhyReg.h	534;"	d
-rTxAGC_A_Rate18_06	include/Hal8814PhyReg.h	657;"	d
-rTxAGC_A_Rate18_06	include/rtl8822b_hal.h	140;"	d
-rTxAGC_A_Rate54_24	include/Hal8188EPhyReg.h	281;"	d
-rTxAGC_A_Rate54_24	include/Hal8188FPhyReg.h	291;"	d
-rTxAGC_A_Rate54_24	include/Hal8192EPhyReg.h	286;"	d
-rTxAGC_A_Rate54_24	include/Hal8703BPhyReg.h	323;"	d
-rTxAGC_A_Rate54_24	include/Hal8723BPhyReg.h	322;"	d
-rTxAGC_A_Rate54_24	include/Hal8723DPhyReg.h	323;"	d
-rTxAGC_A_Rate54_24	include/Hal8812PhyReg.h	535;"	d
-rTxAGC_A_Rate54_24	include/Hal8814PhyReg.h	658;"	d
-rTxAGC_A_Rate54_24	include/rtl8822b_hal.h	141;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8188EPhyReg.h	295;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8188FPhyReg.h	116;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8192EPhyReg.h	300;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8703BPhyReg.h	111;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8723BPhyReg.h	111;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8723DPhyReg.h	111;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8812PhyReg.h	549;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/Hal8814PhyReg.h	672;"	d
-rTxAGC_B_CCK11_A_CCK2_11	include/rtl8822b_hal.h	89;"	d
-rTxAGC_B_CCK11_CCK1_JAguar	hal/phydm/phydm_reg.h	150;"	d
-rTxAGC_B_CCK11_CCK1_JAguar	include/Hal8812PhyReg.h	188;"	d
-rTxAGC_B_CCK11_CCK1_JAguar	include/Hal8814PhyReg.h	228;"	d
-rTxAGC_B_CCK11_CCK1_Jaguar2	include/Hal8814PhyReg.h	264;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8188EPhyReg.h	290;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8188FPhyReg.h	97;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8192EPhyReg.h	295;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8703BPhyReg.h	92;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8723BPhyReg.h	92;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8723DPhyReg.h	92;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8812PhyReg.h	544;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/Hal8814PhyReg.h	667;"	d
-rTxAGC_B_CCK1_55_Mcs32	include/rtl8822b_hal.h	81;"	d
-rTxAGC_B_MCS11_MCS8_JAguar	hal/phydm/phydm_reg.h	155;"	d
-rTxAGC_B_MCS11_MCS8_JAguar	include/Hal8812PhyReg.h	193;"	d
-rTxAGC_B_MCS11_MCS8_JAguar	include/Hal8814PhyReg.h	233;"	d
-rTxAGC_B_MCS11_MCS8_Jaguar2	include/Hal8814PhyReg.h	269;"	d
-rTxAGC_B_MCS15_MCS12_JAguar	hal/phydm/phydm_reg.h	156;"	d
-rTxAGC_B_MCS15_MCS12_JAguar	include/Hal8812PhyReg.h	194;"	d
-rTxAGC_B_MCS15_MCS12_JAguar	include/Hal8814PhyReg.h	234;"	d
-rTxAGC_B_MCS15_MCS12_Jaguar2	include/Hal8814PhyReg.h	270;"	d
-rTxAGC_B_MCS19_MCS16_JAguar	hal/phydm/phydm_reg.h	163;"	d
-rTxAGC_B_MCS19_MCS16_Jaguar2	include/Hal8814PhyReg.h	271;"	d
-rTxAGC_B_MCS23_MCS20_JAguar	hal/phydm/phydm_reg.h	164;"	d
-rTxAGC_B_MCS23_MCS20_Jaguar2	include/Hal8814PhyReg.h	272;"	d
-rTxAGC_B_MCS3_MCS0_JAguar	hal/phydm/phydm_reg.h	153;"	d
-rTxAGC_B_MCS3_MCS0_JAguar	include/Hal8812PhyReg.h	191;"	d
-rTxAGC_B_MCS3_MCS0_JAguar	include/Hal8814PhyReg.h	231;"	d
-rTxAGC_B_MCS3_MCS0_Jaguar2	include/Hal8814PhyReg.h	267;"	d
-rTxAGC_B_MCS7_MCS4_JAguar	hal/phydm/phydm_reg.h	154;"	d
-rTxAGC_B_MCS7_MCS4_JAguar	include/Hal8812PhyReg.h	192;"	d
-rTxAGC_B_MCS7_MCS4_JAguar	include/Hal8814PhyReg.h	232;"	d
-rTxAGC_B_MCS7_MCS4_Jaguar2	include/Hal8814PhyReg.h	268;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8188EPhyReg.h	291;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8188FPhyReg.h	98;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8192EPhyReg.h	296;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8703BPhyReg.h	93;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8723BPhyReg.h	93;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8723DPhyReg.h	93;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8812PhyReg.h	545;"	d
-rTxAGC_B_Mcs03_Mcs00	include/Hal8814PhyReg.h	668;"	d
-rTxAGC_B_Mcs03_Mcs00	include/rtl8822b_hal.h	83;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8188EPhyReg.h	292;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8188FPhyReg.h	100;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8192EPhyReg.h	297;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8703BPhyReg.h	95;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8723BPhyReg.h	95;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8723DPhyReg.h	95;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8812PhyReg.h	546;"	d
-rTxAGC_B_Mcs07_Mcs04	include/Hal8814PhyReg.h	669;"	d
-rTxAGC_B_Mcs07_Mcs04	include/rtl8822b_hal.h	84;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8188EPhyReg.h	293;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8188FPhyReg.h	101;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8192EPhyReg.h	298;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8703BPhyReg.h	96;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8723BPhyReg.h	96;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8723DPhyReg.h	96;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8812PhyReg.h	547;"	d
-rTxAGC_B_Mcs11_Mcs08	include/Hal8814PhyReg.h	670;"	d
-rTxAGC_B_Mcs11_Mcs08	include/rtl8822b_hal.h	85;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8188EPhyReg.h	294;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8188FPhyReg.h	115;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8192EPhyReg.h	299;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8703BPhyReg.h	110;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8723BPhyReg.h	110;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8723DPhyReg.h	110;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8812PhyReg.h	548;"	d
-rTxAGC_B_Mcs15_Mcs12	include/Hal8814PhyReg.h	671;"	d
-rTxAGC_B_Mcs15_Mcs12	include/rtl8822b_hal.h	88;"	d
-rTxAGC_B_Nss1Index3_Nss1Index0_JAguar	hal/phydm/phydm_reg.h	157;"	d
-rTxAGC_B_Nss1Index3_Nss1Index0_JAguar	include/Hal8812PhyReg.h	195;"	d
-rTxAGC_B_Nss1Index3_Nss1Index0_JAguar	include/Hal8814PhyReg.h	235;"	d
-rTxAGC_B_Nss1Index3_Nss1Index0_Jaguar2	include/Hal8814PhyReg.h	273;"	d
-rTxAGC_B_Nss1Index7_Nss1Index4_JAguar	hal/phydm/phydm_reg.h	158;"	d
-rTxAGC_B_Nss1Index7_Nss1Index4_JAguar	include/Hal8812PhyReg.h	196;"	d
-rTxAGC_B_Nss1Index7_Nss1Index4_JAguar	include/Hal8814PhyReg.h	236;"	d
-rTxAGC_B_Nss1Index7_Nss1Index4_Jaguar2	include/Hal8814PhyReg.h	274;"	d
-rTxAGC_B_Nss2Index1_Nss1Index8_JAguar	hal/phydm/phydm_reg.h	159;"	d
-rTxAGC_B_Nss2Index1_Nss1Index8_JAguar	include/Hal8812PhyReg.h	197;"	d
-rTxAGC_B_Nss2Index1_Nss1Index8_JAguar	include/Hal8814PhyReg.h	237;"	d
-rTxAGC_B_Nss2Index1_Nss1Index8_Jaguar2	include/Hal8814PhyReg.h	275;"	d
-rTxAGC_B_Nss2Index5_Nss2Index2_JAguar	hal/phydm/phydm_reg.h	160;"	d
-rTxAGC_B_Nss2Index5_Nss2Index2_JAguar	include/Hal8812PhyReg.h	198;"	d
-rTxAGC_B_Nss2Index5_Nss2Index2_JAguar	include/Hal8814PhyReg.h	238;"	d
-rTxAGC_B_Nss2Index5_Nss2Index2_Jaguar2	include/Hal8814PhyReg.h	276;"	d
-rTxAGC_B_Nss2Index9_Nss2Index6_JAguar	hal/phydm/phydm_reg.h	161;"	d
-rTxAGC_B_Nss2Index9_Nss2Index6_JAguar	include/Hal8812PhyReg.h	199;"	d
-rTxAGC_B_Nss2Index9_Nss2Index6_JAguar	include/Hal8814PhyReg.h	239;"	d
-rTxAGC_B_Nss2Index9_Nss2Index6_Jaguar2	include/Hal8814PhyReg.h	277;"	d
-rTxAGC_B_Nss3Index3_Nss3Index0_JAguar	hal/phydm/phydm_reg.h	165;"	d
-rTxAGC_B_Nss3Index3_Nss3Index0_Jaguar2	include/Hal8814PhyReg.h	278;"	d
-rTxAGC_B_Nss3Index7_Nss3Index4_JAguar	hal/phydm/phydm_reg.h	166;"	d
-rTxAGC_B_Nss3Index7_Nss3Index4_Jaguar2	include/Hal8814PhyReg.h	279;"	d
-rTxAGC_B_Nss3Index9_Nss3Index8_JAguar	hal/phydm/phydm_reg.h	167;"	d
-rTxAGC_B_Nss3Index9_Nss3Index8_Jaguar2	include/Hal8814PhyReg.h	280;"	d
-rTxAGC_B_Ofdm18_Ofdm6_JAguar	hal/phydm/phydm_reg.h	151;"	d
-rTxAGC_B_Ofdm18_Ofdm6_JAguar	include/Hal8812PhyReg.h	189;"	d
-rTxAGC_B_Ofdm18_Ofdm6_JAguar	include/Hal8814PhyReg.h	229;"	d
-rTxAGC_B_Ofdm18_Ofdm6_Jaguar2	include/Hal8814PhyReg.h	265;"	d
-rTxAGC_B_Ofdm54_Ofdm24_JAguar	hal/phydm/phydm_reg.h	152;"	d
-rTxAGC_B_Ofdm54_Ofdm24_JAguar	include/Hal8812PhyReg.h	190;"	d
-rTxAGC_B_Ofdm54_Ofdm24_JAguar	include/Hal8814PhyReg.h	230;"	d
-rTxAGC_B_Ofdm54_Ofdm24_Jaguar2	include/Hal8814PhyReg.h	266;"	d
-rTxAGC_B_Rate18_06	include/Hal8188EPhyReg.h	288;"	d
-rTxAGC_B_Rate18_06	include/Hal8188FPhyReg.h	95;"	d
-rTxAGC_B_Rate18_06	include/Hal8192EPhyReg.h	293;"	d
-rTxAGC_B_Rate18_06	include/Hal8703BPhyReg.h	90;"	d
-rTxAGC_B_Rate18_06	include/Hal8723BPhyReg.h	90;"	d
-rTxAGC_B_Rate18_06	include/Hal8723DPhyReg.h	90;"	d
-rTxAGC_B_Rate18_06	include/Hal8812PhyReg.h	542;"	d
-rTxAGC_B_Rate18_06	include/Hal8814PhyReg.h	665;"	d
-rTxAGC_B_Rate18_06	include/rtl8822b_hal.h	79;"	d
-rTxAGC_B_Rate54_24	include/Hal8188EPhyReg.h	289;"	d
-rTxAGC_B_Rate54_24	include/Hal8188FPhyReg.h	96;"	d
-rTxAGC_B_Rate54_24	include/Hal8192EPhyReg.h	294;"	d
-rTxAGC_B_Rate54_24	include/Hal8703BPhyReg.h	91;"	d
-rTxAGC_B_Rate54_24	include/Hal8723BPhyReg.h	91;"	d
-rTxAGC_B_Rate54_24	include/Hal8723DPhyReg.h	91;"	d
-rTxAGC_B_Rate54_24	include/Hal8812PhyReg.h	543;"	d
-rTxAGC_B_Rate54_24	include/Hal8814PhyReg.h	666;"	d
-rTxAGC_B_Rate54_24	include/rtl8822b_hal.h	80;"	d
-rTxAGC_CCK_Mcs32	include/rtw_mp_phy_regdef.h	302;"	d
-rTxAGC_C_CCK11_CCK1_JAguar	hal/phydm/phydm_reg.h	168;"	d
-rTxAGC_C_CCK11_CCK1_Jaguar2	include/Hal8814PhyReg.h	281;"	d
-rTxAGC_C_MCS11_MCS8_JAguar	hal/phydm/phydm_reg.h	173;"	d
-rTxAGC_C_MCS11_MCS8_Jaguar2	include/Hal8814PhyReg.h	286;"	d
-rTxAGC_C_MCS15_MCS12_JAguar	hal/phydm/phydm_reg.h	174;"	d
-rTxAGC_C_MCS15_MCS12_Jaguar2	include/Hal8814PhyReg.h	287;"	d
-rTxAGC_C_MCS19_MCS16_JAguar	hal/phydm/phydm_reg.h	180;"	d
-rTxAGC_C_MCS19_MCS16_Jaguar2	include/Hal8814PhyReg.h	288;"	d
-rTxAGC_C_MCS23_MCS20_JAguar	hal/phydm/phydm_reg.h	181;"	d
-rTxAGC_C_MCS23_MCS20_Jaguar2	include/Hal8814PhyReg.h	289;"	d
-rTxAGC_C_MCS3_MCS0_JAguar	hal/phydm/phydm_reg.h	171;"	d
-rTxAGC_C_MCS3_MCS0_Jaguar2	include/Hal8814PhyReg.h	284;"	d
-rTxAGC_C_MCS7_MCS4_JAguar	hal/phydm/phydm_reg.h	172;"	d
-rTxAGC_C_MCS7_MCS4_Jaguar2	include/Hal8814PhyReg.h	285;"	d
-rTxAGC_C_Nss1Index3_Nss1Index0_JAguar	hal/phydm/phydm_reg.h	175;"	d
-rTxAGC_C_Nss1Index3_Nss1Index0_Jaguar2	include/Hal8814PhyReg.h	290;"	d
-rTxAGC_C_Nss1Index7_Nss1Index4_JAguar	hal/phydm/phydm_reg.h	176;"	d
-rTxAGC_C_Nss1Index7_Nss1Index4_Jaguar2	include/Hal8814PhyReg.h	291;"	d
-rTxAGC_C_Nss2Index1_Nss1Index8_JAguar	hal/phydm/phydm_reg.h	177;"	d
-rTxAGC_C_Nss2Index1_Nss1Index8_Jaguar2	include/Hal8814PhyReg.h	292;"	d
-rTxAGC_C_Nss2Index5_Nss2Index2_JAguar	hal/phydm/phydm_reg.h	178;"	d
-rTxAGC_C_Nss2Index5_Nss2Index2_Jaguar2	include/Hal8814PhyReg.h	293;"	d
-rTxAGC_C_Nss2Index9_Nss2Index6_JAguar	hal/phydm/phydm_reg.h	179;"	d
-rTxAGC_C_Nss2Index9_Nss2Index6_Jaguar2	include/Hal8814PhyReg.h	294;"	d
-rTxAGC_C_Nss3Index3_Nss3Index0_JAguar	hal/phydm/phydm_reg.h	182;"	d
-rTxAGC_C_Nss3Index3_Nss3Index0_Jaguar2	include/Hal8814PhyReg.h	295;"	d
-rTxAGC_C_Nss3Index7_Nss3Index4_JAguar	hal/phydm/phydm_reg.h	183;"	d
-rTxAGC_C_Nss3Index7_Nss3Index4_Jaguar2	include/Hal8814PhyReg.h	296;"	d
-rTxAGC_C_Nss3Index9_Nss3Index8_JAguar	hal/phydm/phydm_reg.h	184;"	d
-rTxAGC_C_Nss3Index9_Nss3Index8_Jaguar2	include/Hal8814PhyReg.h	297;"	d
-rTxAGC_C_Ofdm18_Ofdm6_JAguar	hal/phydm/phydm_reg.h	169;"	d
-rTxAGC_C_Ofdm18_Ofdm6_Jaguar2	include/Hal8814PhyReg.h	282;"	d
-rTxAGC_C_Ofdm54_Ofdm24_JAguar	hal/phydm/phydm_reg.h	170;"	d
-rTxAGC_C_Ofdm54_Ofdm24_Jaguar2	include/Hal8814PhyReg.h	283;"	d
-rTxAGC_D_CCK11_CCK1_JAguar	hal/phydm/phydm_reg.h	185;"	d
-rTxAGC_D_CCK11_CCK1_Jaguar2	include/Hal8814PhyReg.h	298;"	d
-rTxAGC_D_MCS11_MCS8_JAguar	hal/phydm/phydm_reg.h	190;"	d
-rTxAGC_D_MCS11_MCS8_Jaguar2	include/Hal8814PhyReg.h	303;"	d
-rTxAGC_D_MCS15_MCS12_JAguar	hal/phydm/phydm_reg.h	191;"	d
-rTxAGC_D_MCS15_MCS12_Jaguar2	include/Hal8814PhyReg.h	304;"	d
-rTxAGC_D_MCS19_MCS16_JAguar	hal/phydm/phydm_reg.h	197;"	d
-rTxAGC_D_MCS19_MCS16_Jaguar2	include/Hal8814PhyReg.h	305;"	d
-rTxAGC_D_MCS23_MCS20_JAguar	hal/phydm/phydm_reg.h	198;"	d
-rTxAGC_D_MCS23_MCS20_Jaguar2	include/Hal8814PhyReg.h	306;"	d
-rTxAGC_D_MCS3_MCS0_JAguar	hal/phydm/phydm_reg.h	188;"	d
-rTxAGC_D_MCS3_MCS0_Jaguar2	include/Hal8814PhyReg.h	301;"	d
-rTxAGC_D_MCS7_MCS4_JAguar	hal/phydm/phydm_reg.h	189;"	d
-rTxAGC_D_MCS7_MCS4_Jaguar2	include/Hal8814PhyReg.h	302;"	d
-rTxAGC_D_Nss1Index3_Nss1Index0_JAguar	hal/phydm/phydm_reg.h	192;"	d
-rTxAGC_D_Nss1Index3_Nss1Index0_Jaguar2	include/Hal8814PhyReg.h	307;"	d
-rTxAGC_D_Nss1Index7_Nss1Index4_JAguar	hal/phydm/phydm_reg.h	193;"	d
-rTxAGC_D_Nss1Index7_Nss1Index4_Jaguar2	include/Hal8814PhyReg.h	308;"	d
-rTxAGC_D_Nss2Index1_Nss1Index8_JAguar	hal/phydm/phydm_reg.h	194;"	d
-rTxAGC_D_Nss2Index1_Nss1Index8_Jaguar2	include/Hal8814PhyReg.h	309;"	d
-rTxAGC_D_Nss2Index5_Nss2Index2_JAguar	hal/phydm/phydm_reg.h	195;"	d
-rTxAGC_D_Nss2Index5_Nss2Index2_Jaguar2	include/Hal8814PhyReg.h	310;"	d
-rTxAGC_D_Nss2Index9_Nss2Index6_JAguar	hal/phydm/phydm_reg.h	196;"	d
-rTxAGC_D_Nss2Index9_Nss2Index6_Jaguar2	include/Hal8814PhyReg.h	311;"	d
-rTxAGC_D_Nss3Index3_Nss3Index0_JAguar	hal/phydm/phydm_reg.h	199;"	d
-rTxAGC_D_Nss3Index3_Nss3Index0_Jaguar2	include/Hal8814PhyReg.h	312;"	d
-rTxAGC_D_Nss3Index7_Nss3Index4_JAguar	hal/phydm/phydm_reg.h	200;"	d
-rTxAGC_D_Nss3Index7_Nss3Index4_Jaguar2	include/Hal8814PhyReg.h	313;"	d
-rTxAGC_D_Nss3Index9_Nss3Index8_JAguar	hal/phydm/phydm_reg.h	201;"	d
-rTxAGC_D_Nss3Index9_Nss3Index8_Jaguar2	include/Hal8814PhyReg.h	314;"	d
-rTxAGC_D_Ofdm18_Ofdm6_JAguar	hal/phydm/phydm_reg.h	186;"	d
-rTxAGC_D_Ofdm18_Ofdm6_Jaguar2	include/Hal8814PhyReg.h	299;"	d
-rTxAGC_D_Ofdm54_Ofdm24_JAguar	hal/phydm/phydm_reg.h	187;"	d
-rTxAGC_D_Ofdm54_Ofdm24_Jaguar2	include/Hal8814PhyReg.h	300;"	d
-rTxAGC_Mcs03_Mcs00	include/rtw_mp_phy_regdef.h	303;"	d
-rTxAGC_Mcs07_Mcs04	include/rtw_mp_phy_regdef.h	304;"	d
-rTxAGC_Mcs11_Mcs08	include/rtw_mp_phy_regdef.h	305;"	d
-rTxAGC_Mcs15_Mcs12	include/rtw_mp_phy_regdef.h	306;"	d
-rTxAGC_Rate18_06	include/rtw_mp_phy_regdef.h	300;"	d
-rTxAGC_Rate54_24	include/rtw_mp_phy_regdef.h	301;"	d
-rTxAnt_1Nsts_Jaguar2	include/Hal8814PhyReg.h	64;"	d
-rTxAnt_23Nsts_Jaguar2	include/Hal8814PhyReg.h	65;"	d
-rTxPath_Jaguar	include/Hal8812PhyReg.h	55;"	d
-rTxPath_Jaguar	include/Hal8814PhyReg.h	57;"	d
-rTx_CCK_BBON	include/Hal8188EPhyReg.h	316;"	d
-rTx_CCK_BBON	include/Hal8188FPhyReg.h	317;"	d
-rTx_CCK_BBON	include/Hal8192EPhyReg.h	321;"	d
-rTx_CCK_BBON	include/Hal8703BPhyReg.h	349;"	d
-rTx_CCK_BBON	include/Hal8723BPhyReg.h	348;"	d
-rTx_CCK_BBON	include/Hal8723DPhyReg.h	349;"	d
-rTx_CCK_BBON	include/Hal8812PhyReg.h	570;"	d
-rTx_CCK_BBON	include/Hal8814PhyReg.h	693;"	d
-rTx_CCK_RFON	include/Hal8188EPhyReg.h	315;"	d
-rTx_CCK_RFON	include/Hal8188FPhyReg.h	316;"	d
-rTx_CCK_RFON	include/Hal8192EPhyReg.h	320;"	d
-rTx_CCK_RFON	include/Hal8703BPhyReg.h	348;"	d
-rTx_CCK_RFON	include/Hal8723BPhyReg.h	347;"	d
-rTx_CCK_RFON	include/Hal8723DPhyReg.h	348;"	d
-rTx_CCK_RFON	include/Hal8812PhyReg.h	569;"	d
-rTx_CCK_RFON	include/Hal8814PhyReg.h	692;"	d
-rTx_IQK	include/Hal8188EPhyReg.h	303;"	d
-rTx_IQK	include/Hal8188FPhyReg.h	304;"	d
-rTx_IQK	include/Hal8192EPhyReg.h	308;"	d
-rTx_IQK	include/Hal8703BPhyReg.h	336;"	d
-rTx_IQK	include/Hal8723BPhyReg.h	335;"	d
-rTx_IQK	include/Hal8723DPhyReg.h	336;"	d
-rTx_IQK	include/Hal8812PhyReg.h	557;"	d
-rTx_IQK	include/Hal8814PhyReg.h	680;"	d
-rTx_IQK_PI_A	include/Hal8188EPhyReg.h	300;"	d
-rTx_IQK_PI_A	include/Hal8188FPhyReg.h	301;"	d
-rTx_IQK_PI_A	include/Hal8192EPhyReg.h	305;"	d
-rTx_IQK_PI_A	include/Hal8703BPhyReg.h	333;"	d
-rTx_IQK_PI_A	include/Hal8723BPhyReg.h	332;"	d
-rTx_IQK_PI_A	include/Hal8723DPhyReg.h	333;"	d
-rTx_IQK_PI_A	include/Hal8812PhyReg.h	554;"	d
-rTx_IQK_PI_A	include/Hal8814PhyReg.h	677;"	d
-rTx_IQK_PI_B	include/Hal8188EPhyReg.h	309;"	d
-rTx_IQK_PI_B	include/Hal8188FPhyReg.h	310;"	d
-rTx_IQK_PI_B	include/Hal8192EPhyReg.h	314;"	d
-rTx_IQK_PI_B	include/Hal8703BPhyReg.h	342;"	d
-rTx_IQK_PI_B	include/Hal8723BPhyReg.h	341;"	d
-rTx_IQK_PI_B	include/Hal8723DPhyReg.h	342;"	d
-rTx_IQK_PI_B	include/Hal8812PhyReg.h	563;"	d
-rTx_IQK_PI_B	include/Hal8814PhyReg.h	686;"	d
-rTx_IQK_Tone_A	include/Hal8188EPhyReg.h	298;"	d
-rTx_IQK_Tone_A	include/Hal8188FPhyReg.h	299;"	d
-rTx_IQK_Tone_A	include/Hal8192EPhyReg.h	303;"	d
-rTx_IQK_Tone_A	include/Hal8703BPhyReg.h	331;"	d
-rTx_IQK_Tone_A	include/Hal8723BPhyReg.h	330;"	d
-rTx_IQK_Tone_A	include/Hal8723DPhyReg.h	331;"	d
-rTx_IQK_Tone_A	include/Hal8812PhyReg.h	552;"	d
-rTx_IQK_Tone_A	include/Hal8814PhyReg.h	675;"	d
-rTx_IQK_Tone_B	include/Hal8188EPhyReg.h	307;"	d
-rTx_IQK_Tone_B	include/Hal8188FPhyReg.h	308;"	d
-rTx_IQK_Tone_B	include/Hal8192EPhyReg.h	312;"	d
-rTx_IQK_Tone_B	include/Hal8703BPhyReg.h	340;"	d
-rTx_IQK_Tone_B	include/Hal8723BPhyReg.h	339;"	d
-rTx_IQK_Tone_B	include/Hal8723DPhyReg.h	340;"	d
-rTx_IQK_Tone_B	include/Hal8812PhyReg.h	561;"	d
-rTx_IQK_Tone_B	include/Hal8814PhyReg.h	684;"	d
-rTx_OFDM_BBON	include/Hal8188EPhyReg.h	318;"	d
-rTx_OFDM_BBON	include/Hal8188FPhyReg.h	319;"	d
-rTx_OFDM_BBON	include/Hal8192EPhyReg.h	323;"	d
-rTx_OFDM_BBON	include/Hal8703BPhyReg.h	351;"	d
-rTx_OFDM_BBON	include/Hal8723BPhyReg.h	350;"	d
-rTx_OFDM_BBON	include/Hal8723DPhyReg.h	351;"	d
-rTx_OFDM_BBON	include/Hal8812PhyReg.h	572;"	d
-rTx_OFDM_BBON	include/Hal8814PhyReg.h	695;"	d
-rTx_OFDM_RFON	include/Hal8188EPhyReg.h	317;"	d
-rTx_OFDM_RFON	include/Hal8188FPhyReg.h	318;"	d
-rTx_OFDM_RFON	include/Hal8192EPhyReg.h	322;"	d
-rTx_OFDM_RFON	include/Hal8703BPhyReg.h	350;"	d
-rTx_OFDM_RFON	include/Hal8723BPhyReg.h	349;"	d
-rTx_OFDM_RFON	include/Hal8723DPhyReg.h	350;"	d
-rTx_OFDM_RFON	include/Hal8812PhyReg.h	571;"	d
-rTx_OFDM_RFON	include/Hal8814PhyReg.h	694;"	d
-rTx_Power_After_IQK_A	include/Hal8188EPhyReg.h	324;"	d
-rTx_Power_After_IQK_A	include/Hal8188FPhyReg.h	325;"	d
-rTx_Power_After_IQK_A	include/Hal8192EPhyReg.h	329;"	d
-rTx_Power_After_IQK_A	include/Hal8703BPhyReg.h	357;"	d
-rTx_Power_After_IQK_A	include/Hal8723BPhyReg.h	356;"	d
-rTx_Power_After_IQK_A	include/Hal8723DPhyReg.h	357;"	d
-rTx_Power_After_IQK_A	include/Hal8812PhyReg.h	578;"	d
-rTx_Power_After_IQK_A	include/Hal8814PhyReg.h	701;"	d
-rTx_Power_After_IQK_B	include/Hal8188EPhyReg.h	332;"	d
-rTx_Power_After_IQK_B	include/Hal8188FPhyReg.h	333;"	d
-rTx_Power_After_IQK_B	include/Hal8192EPhyReg.h	337;"	d
-rTx_Power_After_IQK_B	include/Hal8703BPhyReg.h	365;"	d
-rTx_Power_After_IQK_B	include/Hal8723BPhyReg.h	364;"	d
-rTx_Power_After_IQK_B	include/Hal8723DPhyReg.h	365;"	d
-rTx_Power_After_IQK_B	include/Hal8812PhyReg.h	586;"	d
-rTx_Power_After_IQK_B	include/Hal8814PhyReg.h	709;"	d
-rTx_Power_Before_IQK_A	include/Hal8188EPhyReg.h	323;"	d
-rTx_Power_Before_IQK_A	include/Hal8188FPhyReg.h	324;"	d
-rTx_Power_Before_IQK_A	include/Hal8192EPhyReg.h	328;"	d
-rTx_Power_Before_IQK_A	include/Hal8703BPhyReg.h	356;"	d
-rTx_Power_Before_IQK_A	include/Hal8723BPhyReg.h	355;"	d
-rTx_Power_Before_IQK_A	include/Hal8723DPhyReg.h	356;"	d
-rTx_Power_Before_IQK_A	include/Hal8812PhyReg.h	577;"	d
-rTx_Power_Before_IQK_A	include/Hal8814PhyReg.h	700;"	d
-rTx_Power_Before_IQK_B	include/Hal8188EPhyReg.h	331;"	d
-rTx_Power_Before_IQK_B	include/Hal8188FPhyReg.h	332;"	d
-rTx_Power_Before_IQK_B	include/Hal8192EPhyReg.h	336;"	d
-rTx_Power_Before_IQK_B	include/Hal8703BPhyReg.h	364;"	d
-rTx_Power_Before_IQK_B	include/Hal8723BPhyReg.h	363;"	d
-rTx_Power_Before_IQK_B	include/Hal8723DPhyReg.h	364;"	d
-rTx_Power_Before_IQK_B	include/Hal8812PhyReg.h	585;"	d
-rTx_Power_Before_IQK_B	include/Hal8814PhyReg.h	708;"	d
-rTx_To_Rx	include/Hal8188EPhyReg.h	319;"	d
-rTx_To_Rx	include/Hal8188FPhyReg.h	320;"	d
-rTx_To_Rx	include/Hal8192EPhyReg.h	324;"	d
-rTx_To_Rx	include/Hal8703BPhyReg.h	352;"	d
-rTx_To_Rx	include/Hal8723BPhyReg.h	351;"	d
-rTx_To_Rx	include/Hal8723DPhyReg.h	352;"	d
-rTx_To_Rx	include/Hal8812PhyReg.h	573;"	d
-rTx_To_Rx	include/Hal8814PhyReg.h	696;"	d
-rTx_To_Tx	include/Hal8188EPhyReg.h	320;"	d
-rTx_To_Tx	include/Hal8188FPhyReg.h	321;"	d
-rTx_To_Tx	include/Hal8192EPhyReg.h	325;"	d
-rTx_To_Tx	include/Hal8703BPhyReg.h	353;"	d
-rTx_To_Tx	include/Hal8723BPhyReg.h	352;"	d
-rTx_To_Tx	include/Hal8723DPhyReg.h	353;"	d
-rTx_To_Tx	include/Hal8812PhyReg.h	574;"	d
-rTx_To_Tx	include/Hal8814PhyReg.h	697;"	d
-rVhtlen_Use_Lsig_Jaguar	include/Hal8812PhyReg.h	59;"	d
-rVhtlen_Use_Lsig_Jaguar	include/Hal8814PhyReg.h	61;"	d
-rZebra1_AGC	include/Hal8188EPhyReg.h	354;"	d
-rZebra1_AGC	include/Hal8188FPhyReg.h	355;"	d
-rZebra1_AGC	include/Hal8192EPhyReg.h	359;"	d
-rZebra1_AGC	include/Hal8703BPhyReg.h	387;"	d
-rZebra1_AGC	include/Hal8723BPhyReg.h	386;"	d
-rZebra1_AGC	include/Hal8723DPhyReg.h	387;"	d
-rZebra1_AGC	include/rtw_mp_phy_regdef.h	321;"	d
-rZebra1_Channel	include/Hal8188EPhyReg.h	356;"	d
-rZebra1_Channel	include/Hal8188FPhyReg.h	357;"	d
-rZebra1_Channel	include/Hal8192EPhyReg.h	361;"	d
-rZebra1_Channel	include/Hal8703BPhyReg.h	389;"	d
-rZebra1_Channel	include/Hal8723BPhyReg.h	388;"	d
-rZebra1_Channel	include/Hal8723DPhyReg.h	389;"	d
-rZebra1_Channel	include/rtw_mp_phy_regdef.h	324;"	d
-rZebra1_ChargePump	include/Hal8188EPhyReg.h	355;"	d
-rZebra1_ChargePump	include/Hal8188FPhyReg.h	356;"	d
-rZebra1_ChargePump	include/Hal8192EPhyReg.h	360;"	d
-rZebra1_ChargePump	include/Hal8703BPhyReg.h	388;"	d
-rZebra1_ChargePump	include/Hal8723BPhyReg.h	387;"	d
-rZebra1_ChargePump	include/Hal8723DPhyReg.h	388;"	d
-rZebra1_ChargePump	include/rtw_mp_phy_regdef.h	322;"	d
-rZebra1_HSSIEnable	include/Hal8188EPhyReg.h	351;"	d
-rZebra1_HSSIEnable	include/Hal8188FPhyReg.h	352;"	d
-rZebra1_HSSIEnable	include/Hal8192EPhyReg.h	356;"	d
-rZebra1_HSSIEnable	include/Hal8703BPhyReg.h	384;"	d
-rZebra1_HSSIEnable	include/Hal8723BPhyReg.h	383;"	d
-rZebra1_HSSIEnable	include/Hal8723DPhyReg.h	384;"	d
-rZebra1_HSSIEnable	include/rtw_mp_phy_regdef.h	318;"	d
-rZebra1_RxHPFCorner	include/Hal8188EPhyReg.h	362;"	d
-rZebra1_RxHPFCorner	include/Hal8188FPhyReg.h	363;"	d
-rZebra1_RxHPFCorner	include/Hal8192EPhyReg.h	367;"	d
-rZebra1_RxHPFCorner	include/Hal8703BPhyReg.h	395;"	d
-rZebra1_RxHPFCorner	include/Hal8723BPhyReg.h	394;"	d
-rZebra1_RxHPFCorner	include/Hal8723DPhyReg.h	395;"	d
-rZebra1_RxHPFCorner	include/rtw_mp_phy_regdef.h	331;"	d
-rZebra1_RxLPF	include/Hal8188EPhyReg.h	361;"	d
-rZebra1_RxLPF	include/Hal8188FPhyReg.h	362;"	d
-rZebra1_RxLPF	include/Hal8192EPhyReg.h	366;"	d
-rZebra1_RxLPF	include/Hal8703BPhyReg.h	394;"	d
-rZebra1_RxLPF	include/Hal8723BPhyReg.h	393;"	d
-rZebra1_RxLPF	include/Hal8723DPhyReg.h	394;"	d
-rZebra1_RxLPF	include/rtw_mp_phy_regdef.h	330;"	d
-rZebra1_TRxEnable1	include/Hal8188EPhyReg.h	352;"	d
-rZebra1_TRxEnable1	include/Hal8188FPhyReg.h	353;"	d
-rZebra1_TRxEnable1	include/Hal8192EPhyReg.h	357;"	d
-rZebra1_TRxEnable1	include/Hal8703BPhyReg.h	385;"	d
-rZebra1_TRxEnable1	include/Hal8723BPhyReg.h	384;"	d
-rZebra1_TRxEnable1	include/Hal8723DPhyReg.h	385;"	d
-rZebra1_TRxEnable1	include/rtw_mp_phy_regdef.h	319;"	d
-rZebra1_TRxEnable2	include/Hal8188EPhyReg.h	353;"	d
-rZebra1_TRxEnable2	include/Hal8188FPhyReg.h	354;"	d
-rZebra1_TRxEnable2	include/Hal8192EPhyReg.h	358;"	d
-rZebra1_TRxEnable2	include/Hal8703BPhyReg.h	386;"	d
-rZebra1_TRxEnable2	include/Hal8723BPhyReg.h	385;"	d
-rZebra1_TRxEnable2	include/Hal8723DPhyReg.h	386;"	d
-rZebra1_TRxEnable2	include/rtw_mp_phy_regdef.h	320;"	d
-rZebra1_TxGain	include/Hal8188EPhyReg.h	359;"	d
-rZebra1_TxGain	include/Hal8188FPhyReg.h	360;"	d
-rZebra1_TxGain	include/Hal8192EPhyReg.h	364;"	d
-rZebra1_TxGain	include/Hal8703BPhyReg.h	392;"	d
-rZebra1_TxGain	include/Hal8723BPhyReg.h	391;"	d
-rZebra1_TxGain	include/Hal8723DPhyReg.h	392;"	d
-rZebra1_TxGain	include/rtw_mp_phy_regdef.h	328;"	d
-rZebra1_TxLPF	include/Hal8188EPhyReg.h	360;"	d
-rZebra1_TxLPF	include/Hal8188FPhyReg.h	361;"	d
-rZebra1_TxLPF	include/Hal8192EPhyReg.h	365;"	d
-rZebra1_TxLPF	include/Hal8703BPhyReg.h	393;"	d
-rZebra1_TxLPF	include/Hal8723BPhyReg.h	392;"	d
-rZebra1_TxLPF	include/Hal8723DPhyReg.h	393;"	d
-rZebra1_TxLPF	include/rtw_mp_phy_regdef.h	329;"	d
-r_ANTSEL_SW_Jaguar	include/Hal8812PhyReg.h	171;"	d
-r_ANTSEL_SW_Jaguar	include/Hal8814PhyReg.h	205;"	d
-r_L1_SBD_start_time	include/Hal8814PhyReg.h	38;"	d
-r_RFMOD	hal/phydm/phydm_hwconfig.h	/^	u1Byte			r_RFMOD: 2;								\/*RF mode[1:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-r_RFMOD	hal/phydm/phydm_hwconfig.h	/^	u1Byte			r_RFMOD: 2;$/;"	m	struct:_Phy_Status_Rpt_8812
-r_ant_ht1	include/hal_phy.h	/^	u32			r_ant_ht1:4;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-r_ant_ht2	include/hal_phy.h	/^	u32			r_ant_ht2:4;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-r_ant_ht_s1	include/hal_phy.h	/^	u32			r_ant_ht_s1:4;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-r_ant_l	include/hal_phy.h	/^	u32			r_ant_l:4;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-r_ant_non_ht	include/hal_phy.h	/^	u32			r_ant_non_ht:4;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-r_ant_non_ht_s1	include/hal_phy.h	/^	u32			r_ant_non_ht_s1:4;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-r_ant_train_en	hal/phydm/phydm_hwconfig.h	/^	u1Byte	r_ant_train_en: 1;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-r_buf	include/sdio_ops.h	/^	unsigned char *r_buf;$/;"	m	struct:async_context
-r_cckrx_enable	include/hal_phy.h	/^	u8			r_cckrx_enable:2;$/;"	m	struct:_R_ANTENNA_SELECT_CCK
-r_cckrx_enable_2	include/hal_phy.h	/^	u8			r_cckrx_enable_2:2;$/;"	m	struct:_R_ANTENNA_SELECT_CCK
-r_ccktx_enable	include/hal_phy.h	/^	u8			r_ccktx_enable:4;$/;"	m	struct:_R_ANTENNA_SELECT_CCK
-r_tx_antenna	include/hal_phy.h	/^	u32			r_tx_antenna:4;$/;"	m	struct:_R_ANTENNA_SELECT_OFDM
-ra	include/rtw_recv.h	/^	u8	ra[ETH_ALEN];$/;"	m	struct:rx_pkt_attrib
-ra	include/rtw_xmit.h	/^	u8	ra[ETH_ALEN];$/;"	m	struct:pkt_attrib
-ra	include/wifi.h	/^	unsigned char ra[6];$/;"	m	struct:rtw_ieee80211_bar
-ra_mask	hal/btc/HalBtcOutSrc.h	/^	u32					ra_mask;$/;"	m	struct:btc_bt_info
-ra_mask	include/sta_info.h	/^	u64	ra_mask;$/;"	m	struct:sta_info
-ra_rpt_linked	include/sta_info.h	/^	u8	ra_rpt_linked;$/;"	m	struct:sta_info
-radar_detect_bw	include/drv_types.h	/^	u8 radar_detect_bw;$/;"	m	struct:rf_ctl_t
-radar_detect_by_others	include/drv_types.h	/^	bool radar_detect_by_others;$/;"	m	struct:rf_ctl_t
-radar_detect_ch	include/drv_types.h	/^	u8 radar_detect_ch;$/;"	m	struct:rf_ctl_t
-radar_detect_dbg_parm_en	hal/phydm/phydm.h	/^	u1Byte radar_detect_dbg_parm_en;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-radar_detect_offset	include/drv_types.h	/^	u8 radar_detect_offset;$/;"	m	struct:rf_ctl_t
-radar_detect_reg_918	hal/phydm/phydm.h	/^	u4Byte radar_detect_reg_918;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-radar_detect_reg_91c	hal/phydm/phydm.h	/^	u4Byte radar_detect_reg_91c;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-radar_detect_reg_920	hal/phydm/phydm.h	/^	u4Byte radar_detect_reg_920;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-radar_detect_reg_924	hal/phydm/phydm.h	/^	u4Byte radar_detect_reg_924;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-radar_detected	include/drv_types.h	/^	bool radar_detected;$/;"	m	struct:rf_ctl_t
-radio_enable	include/drv_types.h	/^	u8	radio_enable;$/;"	m	struct:registry_priv
-radioa_txt	include/hal_phy.h	/^	radioa_txt = 0x1000,$/;"	e	enum:_RF_CONTENT
-radiob_txt	include/hal_phy.h	/^	radiob_txt = 0x1001,$/;"	e	enum:_RF_CONTENT
-radioc_txt	include/hal_phy.h	/^	radioc_txt = 0x1002,$/;"	e	enum:_RF_CONTENT
-radiod_txt	include/hal_phy.h	/^	radiod_txt = 0x1003$/;"	e	enum:_RF_CONTENT
-raid	include/rtw_xmit.h	/^	u8	raid;\/* rate adpative id *\/$/;"	m	struct:pkt_attrib
-raid	include/sta_info.h	/^	u8	raid;$/;"	m	struct:sta_info
-ralinkAP	include/rtw_mlme_ext.h	/^	ralinkAP	= 4,$/;"	e	enum:Associated_AP
-rate	include/ieee80211.h	/^	u16 rate; \/* in 100 kbps *\/$/;"	m	struct:ieee80211_rx_stats
-rate	include/rtw_xmit.h	/^	u8	rate;$/;"	m	struct:pkt_attrib
-rateCCK	include/Hal8188EPhyReg.h	1074;"	d
-rateCCK	include/Hal8188FPhyReg.h	1081;"	d
-rateCCK	include/Hal8192EPhyReg.h	1088;"	d
-rateCCK	include/Hal8703BPhyReg.h	1110;"	d
-rateCCK	include/Hal8723BPhyReg.h	1108;"	d
-rateCCK	include/Hal8723DPhyReg.h	1111;"	d
-rateCCK	include/rtw_mp_phy_regdef.h	1045;"	d
-rateHT	include/Hal8188EPhyReg.h	1076;"	d
-rateHT	include/Hal8188FPhyReg.h	1083;"	d
-rateHT	include/Hal8192EPhyReg.h	1090;"	d
-rateHT	include/Hal8703BPhyReg.h	1112;"	d
-rateHT	include/Hal8723BPhyReg.h	1110;"	d
-rateHT	include/Hal8723DPhyReg.h	1113;"	d
-rateHT	include/rtw_mp_phy_regdef.h	1047;"	d
-rateOFDM	include/Hal8188EPhyReg.h	1075;"	d
-rateOFDM	include/Hal8188FPhyReg.h	1082;"	d
-rateOFDM	include/Hal8192EPhyReg.h	1089;"	d
-rateOFDM	include/Hal8703BPhyReg.h	1111;"	d
-rateOFDM	include/Hal8723BPhyReg.h	1109;"	d
-rateOFDM	include/Hal8723DPhyReg.h	1112;"	d
-rateOFDM	include/rtw_mp_phy_regdef.h	1046;"	d
-rate_bmp0	include/drv_types.h	/^	u32 rate_bmp0[MACID_NUM_SW_LIMIT];$/;"	m	struct:macid_ctl_t
-rate_bmp1	include/drv_types.h	/^	u32 rate_bmp1[MACID_NUM_SW_LIMIT];$/;"	m	struct:macid_ctl_t
-rate_bmp_cck_ofdm	include/drv_types.h	/^	u16 rate_bmp_cck_ofdm;		\/* 20MHz *\/$/;"	m	struct:rf_ctl_t
-rate_bmp_ht_by_bw	include/drv_types.h	/^	u32 rate_bmp_ht_by_bw[2];	\/* 20MHz, 40MHz. 4SS supported *\/$/;"	m	struct:rf_ctl_t
-rate_bmp_vht_by_bw	include/drv_types.h	/^	u32 rate_bmp_vht_by_bw[4];	\/* 20MHz, 40MHz, 80MHz, 160MHz. up to 3SS supported *\/$/;"	m	struct:rf_ctl_t
-rate_id	include/rtl8188e_xmit.h	/^	u32 rate_id:4;$/;"	m	struct:txdesc_88e
-rate_id	include/rtl8192e_xmit.h	/^	u32 rate_id:4;$/;"	m	struct:txdescriptor_8192e
-rate_id	include/rtl8812a_xmit.h	/^	u32 rate_id:4;$/;"	m	struct:txdescriptor_8812
-rate_id	include/rtl8821a_xmit.h	/^	u32 rate_id:5;$/;"	m	struct:txdescriptor_8821a
-rate_idx	hal/phydm/phydm_rainfo.h	/^	u1Byte	rate_idx;$/;"	m	struct:_Rate_Adaptive_Table_
-rate_index	include/rtw_mp_ioctl.h	/^	u32 rate_index;$/;"	m	struct:datarate_param
-rate_length	hal/phydm/phydm_rainfo.h	/^	u1Byte	rate_length;$/;"	m	struct:_Rate_Adaptive_Table_
-rate_num	include/ieee80211.h	/^	u8 rate_num;$/;"	m	struct:rate_section_ent
-rate_section_ent	include/ieee80211.h	/^struct rate_section_ent {$/;"	s
-rate_section_rate_num	include/ieee80211.h	1006;"	d
-rate_section_str	core/rtw_ieee80211.c	/^const char *rate_section_str(u8 section)$/;"	f
-rate_section_to_tx_num	include/ieee80211.h	1005;"	d
-rateidx	include/rtw_mp.h	/^	u8 rateidx;$/;"	m	struct:mp_priv
-rates	include/ieee80211.h	/^	u8 *rates;$/;"	m	struct:rate_section_ent
-rates_by_sections	core/rtw_ieee80211.c	/^struct rate_section_ent rates_by_sections[RATE_SECTION_NUM] = {$/;"	v	typeref:struct:rate_section_ent
-ratetbl2rateset	core/rtw_wlan_util.c	/^unsigned int ratetbl2rateset(_adapter *padapter, unsigned char *rateset)$/;"	f
-ratetbl_val_2wifirate	core/rtw_wlan_util.c	/^unsigned char ratetbl_val_2wifirate(unsigned char rate)$/;"	f
-raw	include/rtl8188e_xmit.h	/^	u32 raw:1;$/;"	m	struct:txdesc_88e
-raw	include/rtl8192e_xmit.h	/^	u32 raw:1;$/;"	m	struct:txdescriptor_8192e
-raw	include/rtl8812a_xmit.h	/^	u32 raw:1;$/;"	m	struct:txdescriptor_8812
-raw	include/rtl8821a_xmit.h	/^	u32 raw:1;$/;"	m	struct:txdescriptor_8821a
-raw_rssi_info	include/rtw_recv.h	/^	struct rx_raw_rssi raw_rssi_info;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::rx_raw_rssi
-rcons	core/rtw_security.c	/^const u8 rcons[] = {$/;"	v
-rd_en	include/rtl8188e_xmit.h	/^	u32 rd_en:1;$/;"	m	struct:txdesc_88e
-rd_en	include/rtl8192e_xmit.h	/^	u32 rd_en:1;$/;"	m	struct:txdescriptor_8192e
-rd_en	include/rtl8812a_xmit.h	/^	u32 rd_en:1;$/;"	m	struct:txdescriptor_8812
-rd_nav_ext	include/rtl8188e_xmit.h	/^	u32 rd_nav_ext:1;$/;"	m	struct:txdesc_88e
-rd_nav_ext	include/rtl8192e_xmit.h	/^	u32 rd_nav_ext:1;$/;"	m	struct:txdescriptor_8192e
-rd_nav_ext	include/rtl8812a_xmit.h	/^	u32 rd_nav_ext:1;$/;"	m	struct:txdescriptor_8812
-rdg_en	include/rtl8821a_xmit.h	/^	u32 rdg_en:1;$/;"	m	struct:txdescriptor_8821a
-rdg_nav_ext	include/rtl8821a_xmit.h	/^	u32 rdg_nav_ext:1;$/;"	m	struct:txdescriptor_8821a
-read	include/drv_types.h	/^	int __must_check(*read)(struct dvobj_priv *d, int addr, void *buf,$/;"	m	struct:rtw_if_operations
-read	include/osdep_service.h	/^	u32 read;$/;"	m	struct:rtw_cbuf
-readBB_parm	include/rtw_cmd.h	/^struct readBB_parm {$/;"	s
-readBB_rsp	include/rtw_cmd.h	/^struct readBB_rsp {$/;"	s
-readFile	os_dep/osdep_service.c	/^static int readFile(struct file *fp, char *buf, int len)$/;"	f	file:
-readMAC_parm	include/rtw_cmd.h	/^struct readMAC_parm {$/;"	s
-readRF_parm	include/rtw_cmd.h	/^struct readRF_parm {$/;"	s
-readRF_rsp	include/rtw_cmd.h	/^struct readRF_rsp {$/;"	s
-readTSSI_parm	include/rtw_cmd.h	/^struct readTSSI_parm {$/;"	s
-readTSSI_rsp	include/rtw_cmd.h	/^struct readTSSI_rsp {$/;"	s
-read_adapter_info	include/hal_intf.h	/^	void	(*read_adapter_info)(_adapter *padapter);$/;"	m	struct:hal_ops
-read_bbreg	core/rtw_mp.c	/^u32 read_bbreg(_adapter *padapter, u32 addr, u32 bitmask)$/;"	f
-read_bbreg	include/hal_intf.h	/^	u32(*read_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask);$/;"	m	struct:hal_ops
-read_chip_version	include/hal_intf.h	/^	void	(*read_chip_version)(_adapter *padapter);$/;"	m	struct:hal_ops
-read_chip_version_8723d	hal/rtl8723d/rtl8723d_hal_init.c	/^static void read_chip_version_8723d(PADAPTER padapter)$/;"	f	file:
-read_eeprom_content	core/rtw_eeprom.c	/^VOID read_eeprom_content(_adapter	*padapter)$/;"	f
-read_macreg	core/rtw_mp.c	/^u32 read_macreg(_adapter *padapter, u32 addr, u32 sz)$/;"	f
-read_mbssid_cam	hal/hal_com.c	/^static void read_mbssid_cam(_adapter *padapter, u8 cam_addr, u8 *mac)$/;"	f	file:
-read_rfreg	core/rtw_mp.c	/^u32 read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr)$/;"	f
-read_rfreg	include/hal_intf.h	/^	u32(*read_rfreg)(_adapter *padapter, u8 eRFPath, u32 RegAddr, u32 BitMask);$/;"	m	struct:hal_ops
-read_sniff_num	core/rtw_io.c	/^int read_sniff_num = sizeof(read_sniff_ranges) \/ sizeof(u32) \/ 2;$/;"	v
-read_sniff_ranges	core/rtw_io.c	/^u32 read_sniff_ranges[][2] = {$/;"	v
-real_cent_freq	hal/btc/HalBtc8703b1Ant.h	/^	u32			real_cent_freq;$/;"	m	struct:psdscan_sta_8703b_1ant
-real_cent_freq	hal/btc/HalBtc8723b1Ant.h	/^	u32			real_cent_freq;$/;"	m	struct:psdscan_sta_8723b_1ant
-real_cent_freq	hal/btc/HalBtc8822b1Ant.h	/^	u32			real_cent_freq;$/;"	m	struct:psdscan_sta_8822b_1ant
-real_cent_freq	hal/btc/halbtc8723d1ant.h	/^	u32			real_cent_freq;$/;"	m	struct:psdscan_sta_8723d_1ant
-real_cent_freq	hal/btc/halbtc8723d2ant.h	/^	u32			real_cent_freq;$/;"	m	struct:psdscan_sta_8723d_2ant
-real_cent_freq	hal/btc/halbtc8821c1ant.h	/^	u32			real_cent_freq;$/;"	m	struct:psdscan_sta_8821c_1ant
-real_cent_freq	hal/btc/halbtc8821c2ant.h	/^	u32			real_cent_freq;$/;"	m	struct:psdscan_sta_8821c_2ant
-real_offset	hal/btc/HalBtc8703b1Ant.h	/^	s32			real_offset;$/;"	m	struct:psdscan_sta_8703b_1ant
-real_offset	hal/btc/HalBtc8723b1Ant.h	/^	s32			real_offset;$/;"	m	struct:psdscan_sta_8723b_1ant
-real_offset	hal/btc/HalBtc8822b1Ant.h	/^	s32			real_offset;$/;"	m	struct:psdscan_sta_8822b_1ant
-real_offset	hal/btc/halbtc8723d1ant.h	/^	s32			real_offset;$/;"	m	struct:psdscan_sta_8723d_1ant
-real_offset	hal/btc/halbtc8723d2ant.h	/^	s32			real_offset;$/;"	m	struct:psdscan_sta_8723d_2ant
-real_offset	hal/btc/halbtc8821c1ant.h	/^	s32			real_offset;$/;"	m	struct:psdscan_sta_8821c_1ant
-real_offset	hal/btc/halbtc8821c2ant.h	/^	s32			real_offset;$/;"	m	struct:psdscan_sta_8821c_2ant
-real_span	hal/btc/HalBtc8703b1Ant.h	/^	u32			real_span;$/;"	m	struct:psdscan_sta_8703b_1ant
-real_span	hal/btc/HalBtc8723b1Ant.h	/^	u32			real_span;$/;"	m	struct:psdscan_sta_8723b_1ant
-real_span	hal/btc/HalBtc8822b1Ant.h	/^	u32			real_span;$/;"	m	struct:psdscan_sta_8822b_1ant
-real_span	hal/btc/halbtc8723d1ant.h	/^	u32			real_span;$/;"	m	struct:psdscan_sta_8723d_1ant
-real_span	hal/btc/halbtc8723d2ant.h	/^	u32			real_span;$/;"	m	struct:psdscan_sta_8723d_2ant
-real_span	hal/btc/halbtc8821c1ant.h	/^	u32			real_span;$/;"	m	struct:psdscan_sta_8821c_1ant
-real_span	hal/btc/halbtc8821c2ant.h	/^	u32			real_span;$/;"	m	struct:psdscan_sta_8821c_2ant
-realtekAP	include/rtw_mlme_ext.h	/^	realtekAP	= 5,$/;"	e	enum:Associated_AP
-reason_code	include/ieee80211.h	/^			int reason_code;$/;"	m	struct:ieee_param::__anon73::__anon76
-reason_code	include/ieee80211_ext.h	/^					u16 reason_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon38
-reason_code	include/ieee80211_ext.h	/^					u16 reason_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon23
-reason_code	include/ieee80211_ext.h	/^			u16 reason_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon28
-reason_code	include/ieee80211_ext.h	/^			u16 reason_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon32
-reason_code	include/ieee80211_ext.h	/^			u16 reason_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon10
-reason_code	include/ieee80211_ext.h	/^			u16 reason_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon14
-reassoc	include/ieee80211.h	/^	uint reassoc;$/;"	m	struct:ieee80211_softmac_stats
-reassoc_count	include/rtw_mlme_ext.h	/^	u32	reassoc_count;$/;"	m	struct:mlme_ext_info
-reassoc_req	include/ieee80211_ext.h	/^		}  __attribute__((packed)) reassoc_req;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon13
-reassoc_req	include/ieee80211_ext.h	/^		}  reassoc_req;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon31
-reassoc_resp	include/ieee80211_ext.h	/^		}  __attribute__((packed)) assoc_resp, reassoc_resp;$/;"	m	union:ieee80211_mgmt::__anon8	typeref:struct:ieee80211_mgmt::__anon8::__anon12
-reassoc_resp	include/ieee80211_ext.h	/^		}  assoc_resp, reassoc_resp;$/;"	m	union:ieee80211_mgmt::__anon26	typeref:struct:ieee80211_mgmt::__anon26::__anon30
-reauth_count	include/rtw_mlme_ext.h	/^	u32	reauth_count;$/;"	m	struct:mlme_ext_info
-receive_disconnect	core/rtw_mlme_ext.c	/^unsigned int receive_disconnect(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, u8 locally_generated)$/;"	f
-received_channel	include/ieee80211.h	/^	u8 received_channel;$/;"	m	struct:ieee80211_rx_stats
-recvThread	include/drv_types.h	/^	_thread_hdl_ recvThread;$/;"	m	struct:_ADAPTER
-recv_buf	include/rtw_recv.h	/^struct recv_buf {$/;"	s
-recv_buf_pending_queue	include/rtw_recv.h	/^	_queue	recv_buf_pending_queue;$/;"	m	struct:recv_priv
-recv_decache	core/rtw_recv.c	/^sint recv_decache(union recv_frame *precv_frame, u8 bretry, struct stainfo_rxcache *prxcache)$/;"	f
-recv_frame	include/rtw_recv.h	/^union recv_frame {$/;"	u
-recv_frame_hdr	include/rtw_recv.h	/^struct recv_frame_hdr {$/;"	s
-recv_frame_monitor	core/rtw_recv.c	/^int recv_frame_monitor(_adapter *padapter, union recv_frame *rframe)$/;"	f
-recv_func	core/rtw_recv.c	/^int recv_func(_adapter *padapter, union recv_frame *rframe)$/;"	f
-recv_func_posthandle	core/rtw_recv.c	/^int recv_func_posthandle(_adapter *padapter, union recv_frame *prframe)$/;"	f
-recv_func_prehandle	core/rtw_recv.c	/^int recv_func_prehandle(_adapter *padapter, union recv_frame *rframe)$/;"	f
-recv_indicatepkt_reorder	core/rtw_recv.c	/^int recv_indicatepkt_reorder(_adapter *padapter, union recv_frame *prframe)$/;"	f
-recv_indicatepkts_in_order	core/rtw_recv.c	/^int recv_indicatepkts_in_order(_adapter *padapter, struct recv_reorder_ctrl *preorder_ctrl, int bforced)$/;"	f
-recv_indicatepkts_pkt_loss_cnt	core/rtw_recv.c	/^void recv_indicatepkts_pkt_loss_cnt(struct debug_priv *pdbgpriv, u64 prev_seq, u64 current_seq)$/;"	f
-recv_pending_queue	include/rtw_recv.h	/^	_queue	recv_pending_queue;$/;"	m	struct:recv_priv
-recv_priv	include/rtw_recv.h	/^struct recv_priv {$/;"	s
-recv_reorder_ctrl	include/rtw_recv.h	/^struct recv_reorder_ctrl {$/;"	s
-recv_resource_evt	include/rtw_recv.h	/^	NDIS_EVENT	recv_resource_evt ;$/;"	m	struct:recv_priv
-recv_sdrp	include/osdep_intf.h	/^	PSDBUS_REQUEST_PACKET  recv_sdrp;$/;"	m	struct:intf_priv
-recv_sema	include/rtw_recv.h	/^	_sema	recv_sema;$/;"	m	struct:recv_priv
-recv_stat	include/rtw_recv.h	/^struct recv_stat {$/;"	s
-recv_tasklet	include/rtw_recv.h	/^	struct task recv_tasklet;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::task
-recv_tasklet	include/rtw_recv.h	/^	struct tasklet_struct recv_tasklet;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::tasklet_struct
-recvbuf_lock	include/rtw_recv.h	/^	_lock recvbuf_lock;$/;"	m	struct:recv_buf
-recvframe_chk_defrag	core/rtw_recv.c	/^union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame)$/;"	f
-recvframe_chkmic	core/rtw_recv.c	/^sint recvframe_chkmic(_adapter *adapter,  union recv_frame *precvframe)$/;"	f
-recvframe_defrag	core/rtw_recv.c	/^union recv_frame *recvframe_defrag(_adapter *adapter, _queue *defrag_q)$/;"	f
-recvframe_expand_pkt	core/rtw_recv.c	/^static void recvframe_expand_pkt($/;"	f	file:
-recvframe_pull	include/rtw_recv.h	/^__inline static u8 *recvframe_pull(union recv_frame *precvframe, sint sz)$/;"	f
-recvframe_pull_tail	include/rtw_recv.h	/^__inline static u8 *recvframe_pull_tail(union recv_frame *precvframe, sint sz)$/;"	f
-recvframe_push	include/rtw_recv.h	/^__inline static u8 *recvframe_push(union recv_frame *precvframe, sint sz)$/;"	f
-recvframe_put	include/rtw_recv.h	/^__inline static u8 *recvframe_put(union recv_frame *precvframe, sint sz)$/;"	f
-recvmsg_work	include/rtw_btcoex.h	/^	struct delayed_work recvmsg_work;$/;"	m	struct:bt_coex_info	typeref:struct:bt_coex_info::delayed_work
-recvpriv	include/drv_types.h	/^	struct	recv_priv	recvpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::recv_priv
-recvreorder_ctrl	include/sta_info.h	/^	struct recv_reorder_ctrl recvreorder_ctrl[TID_NUM];$/;"	m	struct:sta_info	typeref:struct:sta_info::recv_reorder_ctrl
-ref_cnt	include/rtw_recv.h	/^	u32	ref_cnt;$/;"	m	struct:recv_buf
-reg	core/rtw_io.c	/^	u16 reg;$/;"	m	struct:rf_sniff_ent	file:
-reg	include/sta_info.h	/^	struct st_register reg[SESSION_TRACKER_REG_ID_NUM];$/;"	m	struct:st_ctl_t	typeref:struct:st_ctl_t::st_register
-reg_2ghz_ctl	include/wifi.h	/^	u16 reg_2ghz_ctl;$/;"	m	struct:regd_pair_mapping
-reg_5ghz_ctl	include/wifi.h	/^	u16 reg_5ghz_ctl;$/;"	m	struct:regd_pair_mapping
-reg_backup	include/hal_data.h	/^	u32 reg_backup[MAX_RF_PATH][MAX_IQK_INFO_BACKUP_REG_NUM];$/;"	m	struct:hal_iqk_reg_backup
-reg_class	include/rtw_mlme_ext.h	/^		u8 reg_class;$/;"	m	struct:p2p_channels::p2p_reg_class
-reg_class	include/rtw_mlme_ext.h	/^	} reg_class[P2P_MAX_REG_CLASSES];$/;"	m	struct:p2p_channels	typeref:struct:p2p_channels::p2p_reg_class
-reg_classes	include/rtw_mlme_ext.h	/^	size_t reg_classes;$/;"	m	struct:p2p_channels
-reg_dmnenum	include/wifi.h	/^	u16 reg_dmnenum;$/;"	m	struct:regd_pair_mapping
-reg_pdnmode	include/rtw_pwrctrl.h	/^	u8	reg_pdnmode; \/* powerdown mode *\/$/;"	m	struct:pwrctrl_priv
-reg_protocol_rd	include/rtw_io.h	/^struct reg_protocol_rd {$/;"	s
-reg_protocol_wt	include/rtw_io.h	/^struct reg_protocol_wt {$/;"	s
-reg_rfoff	include/rtw_pwrctrl.h	/^	u8	reg_rfoff;$/;"	m	struct:pwrctrl_priv
-reg_rfps_level	include/rtw_pwrctrl.h	/^	u32	reg_rfps_level;$/;"	m	struct:pwrctrl_priv
-reg_rxgain_offset_2g	include/drv_types.h	/^	u32	reg_rxgain_offset_2g;$/;"	m	struct:registry_priv
-reg_rxgain_offset_5gh	include/drv_types.h	/^	u32	reg_rxgain_offset_5gh;$/;"	m	struct:registry_priv
-reg_rxgain_offset_5gl	include/drv_types.h	/^	u32	reg_rxgain_offset_5gl;$/;"	m	struct:registry_priv
-reg_rxgain_offset_5gm	include/drv_types.h	/^	u32	reg_rxgain_offset_5gm;$/;"	m	struct:registry_priv
-regd	include/rtw_mlme_ext.h	/^	u8 regd; \/* value of REGULATION_TXPWR_LMT *\/$/;"	m	struct:_RT_CHANNEL_PLAN_MAP
-regd_pair_mapping	include/wifi.h	/^struct regd_pair_mapping {$/;"	s
-register_net_gpio_init	os_dep/linux/custom_gpio_linux.c	/^int register_net_gpio_init(void)$/;"	f
-register_task_alive	core/rtw_pwrctrl.c	/^__inline static void register_task_alive(struct pwrctrl_priv *pwrctrl, u32 tag)$/;"	f	file:
-registered	include/drv_types.h	/^	u8 registered;$/;"	m	struct:_ADAPTER
-registry_priv	include/drv_types.h	/^struct registry_priv {$/;"	s
-registrypriv	include/drv_types.h	/^	struct	registry_priv	registrypriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::registry_priv
-regpair	include/wifi.h	/^	struct regd_pair_mapping *regpair;$/;"	m	struct:rtw_regulatory	typeref:struct:rtw_regulatory::regd_pair_mapping
-regulatory_class	include/rtw_rf.h	/^struct	regulatory_class {$/;"	s
-reject_agg_pkt	hal/btc/HalBtcOutSrc.h	/^	boolean					reject_agg_pkt;$/;"	m	struct:btc_bt_info
-remain_on_ch_channel	include/rtw_mlme.h	/^	struct ieee80211_channel	remain_on_ch_channel;$/;"	m	struct:cfg80211_wifidirect_info	typeref:struct:cfg80211_wifidirect_info::ieee80211_channel
-remain_on_ch_cookie	include/rtw_mlme.h	/^	u64 remain_on_ch_cookie;$/;"	m	struct:cfg80211_wifidirect_info
-remain_on_ch_timer	include/rtw_mlme.h	/^	_timer					remain_on_ch_timer;$/;"	m	struct:cfg80211_wifidirect_info
-remain_on_ch_type	include/rtw_mlme.h	/^	enum nl80211_channel_type	remain_on_ch_type;$/;"	m	struct:cfg80211_wifidirect_info	typeref:enum:cfg80211_wifidirect_info::nl80211_channel_type
-remote_naddr	include/sta_info.h	/^	u32 remote_naddr; \/* TODO: IPV6 *\/$/;"	m	struct:st_cmd_parm
-remote_naddr	include/sta_info.h	/^	u32 remote_naddr;$/;"	m	struct:session_tracker
-remote_port	include/sta_info.h	/^	u16 remote_port;$/;"	m	struct:session_tracker
-remote_port	include/sta_info.h	/^	u16 remote_port;$/;"	m	struct:st_cmd_parm
-reordering_ctrl_timer	include/rtw_recv.h	/^	_timer reordering_ctrl_timer;$/;"	m	struct:recv_reorder_ctrl
-replay_counter_eapol_key	include/rtw_pwrctrl.h	/^	u8 replay_counter_eapol_key[8];$/;"	m	struct:aoac_report
-replay_ctr	include/sta_info.h	/^	u8 replay_ctr[RTW_REPLAY_CTR_LEN];$/;"	m	struct:sta_info
-report_add_sta_event	core/rtw_mlme_ext.c	/^void report_add_sta_event(_adapter *padapter, unsigned char *MacAddr)$/;"	f
-report_del_sta_event	core/rtw_mlme_ext.c	/^u32 report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated)$/;"	f
-report_ft_event	core/rtw_mlme_ext.c	/^void report_ft_event(_adapter *padapter)$/;"	f
-report_ft_reassoc_event	core/rtw_mlme_ext.c	/^void report_ft_reassoc_event(_adapter *padapter, u8 *pMacAddr)$/;"	f
-report_join_res	core/rtw_mlme_ext.c	/^u32 report_join_res(_adapter *padapter, int res)$/;"	f
-report_mgmt	os_dep/linux/ioctl_cfg80211.h	/^	u16 report_mgmt;$/;"	m	struct:rtw_wdev_priv
-report_sta_timeout_event	core/rtw_mlme_ext.c	/^void report_sta_timeout_event(_adapter *padapter, u8 *MacAddr, unsigned short reason)$/;"	f
-report_survey_event	core/rtw_mlme_ext.c	/^void report_survey_event(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-report_surveydone_event	core/rtw_mlme_ext.c	/^void report_surveydone_event(_adapter *padapter)$/;"	f
-report_wmm_edca_update	core/rtw_mlme_ext.c	/^void report_wmm_edca_update(_adapter *padapter)$/;"	f
-reportpwrstate_parm	include/rtw_pwrctrl.h	/^struct reportpwrstate_parm {$/;"	s
-reqNum	include/rtw_bt_mp.h	/^	u1Byte	reqNum:4;$/;"	m	struct:_BT_EXT_C2H
-reqNum	include/rtw_bt_mp.h	/^	u1Byte	reqNum:4;$/;"	m	struct:_BT_H2C
-req_bw	include/rtw_cmd.h	/^	s8 req_bw;$/;"	m	struct:createbss_parm
-req_ch	include/rtw_cmd.h	/^	s16 req_ch;$/;"	m	struct:createbss_parm
-req_intent	os_dep/linux/ioctl_cfg80211.h	/^	u8 req_intent;$/;"	m	struct:rtw_wdev_nego_info
-req_listen_ch	os_dep/linux/ioctl_cfg80211.h	/^	u8 req_listen_ch;$/;"	m	struct:rtw_wdev_nego_info
-req_num	hal/btc/HalBtcOutSrc.h	/^	u1Byte	req_num:4;$/;"	m	struct:_COL_C2H_ACK
-req_num	hal/btc/HalBtcOutSrc.h	/^	u1Byte	req_num:4;$/;"	m	struct:_COL_H2C
-req_offset	include/rtw_cmd.h	/^	s8 req_offset;$/;"	m	struct:createbss_parm
-req_op_ch	os_dep/linux/ioctl_cfg80211.h	/^	u8 req_op_ch;$/;"	m	struct:rtw_wdev_invit_info
-req_op_ch	os_dep/linux/ioctl_cfg80211.h	/^	u8 req_op_ch;$/;"	m	struct:rtw_wdev_nego_info
-request_wps_pbc_event	os_dep/linux/ioctl_linux.c	/^static void request_wps_pbc_event(_adapter *padapter)$/;"	f	file:
-rereg_nd_name_data	include/drv_types.h	/^	struct rereg_nd_name_data {$/;"	s	struct:_ADAPTER
-rereg_nd_name_priv	include/drv_types.h	/^	} rereg_nd_name_priv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::rereg_nd_name_data
-res	include/rtw_cmd.h	/^	u8	res;$/;"	m	struct:cmd_obj
-res	include/rtw_cmd.h	/^	u8	res;$/;"	m	struct:evt_obj
-res_to_status	include/osdep_service.h	/^__inline static _OS_STATUS res_to_status(sint res)$/;"	f
-reserved	include/ieee80211.h	/^			u8	reserved[2];\/* for set max_num_sta *\/$/;"	m	struct:ieee_param::__anon73::__anon79
-reserved	include/ieee80211.h	/^			u8 reserved[32];$/;"	m	struct:ieee_param::__anon73::__anon75
-reserved	include/ieee80211.h	/^	u16 reserved;$/;"	m	struct:ieee80211_txb
-reserved	include/ieee80211_ext.h	/^	     reserved:1;$/;"	m	struct:wme_ac_parameter
-reserved	include/ieee80211_ext.h	/^	u8 reserved;$/;"	m	struct:wme_parameter_element
-reserved	include/wifi.h	/^	unsigned char		reserved;$/;"	m	struct:WMM_para_element
-reserved	os_dep/linux/rtw_android.c	/^	char reserved;$/;"	m	struct:cmd_tlv	file:
-reset_ch_sitesurvey	include/rtw_mlme.h	/^	_timer					reset_ch_sitesurvey;$/;"	m	struct:wifidirect_info
-reset_ch_sitesurvey2	include/rtw_mlme.h	/^	_timer					reset_ch_sitesurvey2;	\/*	Just for resetting the scan limit function by using p2p nego *\/$/;"	m	struct:wifidirect_info
-reset_ch_sitesurvey_timer_process	core/rtw_p2p.c	/^static void reset_ch_sitesurvey_timer_process(void *FunctionContext)$/;"	f	file:
-reset_ch_sitesurvey_timer_process2	core/rtw_p2p.c	/^static void reset_ch_sitesurvey_timer_process2(void *FunctionContext)$/;"	f	file:
-reset_global_wifidirect_info	core/rtw_p2p.c	/^void reset_global_wifidirect_info(_adapter *padapter)$/;"	f
-reset_idx	hal/phydm/phydm_antdiv.h	/^	u1Byte 		reset_idx;$/;"	m	struct:_SW_Antenna_Switch_
-reset_securitypriv_hdl	core/rtw_cmd.c	/^void reset_securitypriv_hdl(_adapter *padapter)$/;"	f
-reset_tdma_adjust	hal/btc/HalBtc8192e2Ant.h	/^	boolean		reset_tdma_adjust;$/;"	m	struct:coex_dm_8192e_2ant
-reset_tdma_adjust	hal/btc/HalBtc8723b2Ant.h	/^	boolean		reset_tdma_adjust;$/;"	m	struct:coex_dm_8723b_2ant
-reset_tdma_adjust	hal/btc/HalBtc8821a2Ant.h	/^	boolean		reset_tdma_adjust;$/;"	m	struct:coex_dm_8821a_2ant
-reset_tdma_adjust	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean		reset_tdma_adjust;$/;"	m	struct:coex_dm_8821a_csr_2ant
-reset_tdma_adjust	hal/btc/halbtc8723d2ant.h	/^	boolean		reset_tdma_adjust;$/;"	m	struct:coex_dm_8723d_2ant
-reset_tdma_adjust	hal/btc/halbtc8821c2ant.h	/^	boolean		reset_tdma_adjust;$/;"	m	struct:coex_dm_8821c_2ant
-reset_tsf	hal/rtl8723d/rtl8723d_hal_init.c	/^int reset_tsf(PADAPTER Adapter, u8 reset_port)$/;"	f
-resp_sta	include/rtw_tdls.h	/^	u8 resp_sta[ETH_ALEN];$/;"	m	struct:wpa_tdls_lnkid
-restore_channel	include/rtw_mlme.h	/^	u8						restore_channel;$/;"	m	struct:cfg80211_wifidirect_info
-restore_p2p_state_handler	core/rtw_p2p.c	/^void restore_p2p_state_handler(_adapter	*padapter)$/;"	f
-restore_p2p_state_timer	include/rtw_mlme.h	/^	_timer					restore_p2p_state_timer;$/;"	m	struct:wifidirect_info
-restore_p2p_state_timer_process	core/rtw_p2p.c	/^static void restore_p2p_state_timer_process(void *FunctionContext)$/;"	f	file:
-resume_work	include/rtw_pwrctrl.h	/^	_workitem resume_work;$/;"	m	struct:pwrctrl_priv
-resume_workitem_callback	core/rtw_pwrctrl.c	/^static void resume_workitem_callback(struct work_struct *work)$/;"	f	file:
-resvd_0	hal/phydm/phydm_hwconfig.h	/^	u1Byte			resvd_0: 6;$/;"	m	struct:_Phy_Status_Rpt_8812
-resvd_1	hal/phydm/phydm_hwconfig.h	/^	u1Byte			resvd_1: 1;								\/*1'b0*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-resvd_1	hal/phydm/phydm_hwconfig.h	/^	u1Byte			resvd_1: 1;$/;"	m	struct:_Phy_Status_Rpt_8812
-retLen	include/rtw_bt_mp.h	/^	u1Byte	retLen:4;$/;"	m	struct:_BT_EXT_C2H
-ret_len	hal/btc/HalBtcOutSrc.h	/^	u1Byte	ret_len;$/;"	m	struct:_COL_C2H_ACK
-ret_size	include/drv_types.h	/^	u32 ret_size;$/;"	m	struct:halmac_indicator
-retriveAdaptorInfoFile	core/efuse/rtw_efuse.c	/^int retriveAdaptorInfoFile(char *path, u8 *efuse_data)$/;"	f
-retriveFromFile	os_dep/osdep_service.c	/^static int retriveFromFile(const char *path, u8 *buf, u32 sz)$/;"	f	file:
-retry	include/rtw_mlme_ext.h	/^	u32	retry; \/* retry for issue probereq *\/$/;"	m	struct:mlme_ext_priv
-retry_cnt	core/rtw_cmd.c	/^	u8 retry_cnt:4;$/;"	m	struct:btinfo	file:
-retry_cnt	include/rtl8188e_xmit.h	/^	u8 retry_cnt:6;$/;"	m	struct:txrpt_ccx_88e
-retry_cnt	include/rtl8192e_xmit.h	/^	u8 retry_cnt:6;$/;"	m	struct:txrpt_ccx_92e
-retry_cnt	include/rtw_btcoex.h	/^	u8 retry_cnt:4;$/;"	m	struct:btinfo_8761ATV
-retry_count	hal/phydm/phydm_iqk.h	/^	u1Byte		retry_count[2][4][3]; \/*channel \/ path \/ (TXK:0, RXK1:1, RXK2:2)*\/$/;"	m	struct:_IQK_INFORMATION
-retry_count	hal/phydm/phydm_powertracking_ap.h	/^	u1Byte	retry_count[4][2]; \/* [4]: path ABCD, [2] TXK, RXK *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-retry_count	hal/phydm/phydm_powertracking_ce.h	/^	u1Byte	retry_count[4][2]; \/* [4]: path ABCD, [2] TXK, RXK *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-retry_count	hal/phydm/phydm_powertracking_win.h	/^	u1Byte	retry_count[4][2]; \/* [4]: path ABCD, [2] TXK, RXK *\/$/;"	m	struct:ODM_RF_Calibration_Structure
-retry_ctrl	include/rtw_xmit.h	/^	u8	retry_ctrl;$/;"	m	struct:pkt_attrib
-retry_descend_num	hal/phydm/phydm_rainfo.h	/^	u1Byte			retry_descend_num;$/;"	m	struct:_Rate_Adaptive_Table_
-retry_over	include/rtl8188e_xmit.h	/^	u8 retry_over:1;$/;"	m	struct:txrpt_ccx_88e
-retry_over	include/rtl8192e_xmit.h	/^	u8 retry_over:1;$/;"	m	struct:txrpt_ccx_92e
-retrylimit_high	hal/phydm/phydm_rainfo.h	/^	u1Byte			retrylimit_high;$/;"	m	struct:_Rate_Adaptive_Table_
-retrylimit_low	hal/phydm/phydm_rainfo.h	/^	u1Byte			retrylimit_low;$/;"	m	struct:_Rate_Adaptive_Table_
-rf3wireOffset	include/hal_com_phycfg.h	/^	u32 rf3wireOffset;	\/* LSSI data: *\/$/;"	m	struct:_BB_REGISTER_DEFINITION
-rfGainIdx	hal/phydm/phydm_dig.h	/^	u1Byte		rfGainIdx;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-rfHSSIPara2	include/hal_com_phycfg.h	/^	u32 rfHSSIPara2;	\/* wire parameter control2 :  *\/$/;"	m	struct:_BB_REGISTER_DEFINITION
-rfLSSIReadBack	include/hal_com_phycfg.h	/^	u32 rfLSSIReadBack;	\/* LSSI RF readback data SI mode *\/$/;"	m	struct:_BB_REGISTER_DEFINITION
-rfLSSIReadBackPi	include/hal_com_phycfg.h	/^	u32 rfLSSIReadBackPi;	\/* LSSI RF readback data PI mode 0x8b8-8bc for Path A and B *\/$/;"	m	struct:_BB_REGISTER_DEFINITION
-rf_chip	include/hal_data.h	/^	u8	rf_chip;$/;"	m	struct:hal_com_data
-rf_config	include/drv_types.h	/^	u8	rf_config ;$/;"	m	struct:registry_priv
-rf_ctl	include/drv_types.h	/^	struct rf_ctl_t rf_ctl;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::rf_ctl_t
-rf_ctl_t	include/drv_types.h	/^struct rf_ctl_t {$/;"	s
-rf_max	include/rtw_pwrctrl.h	/^	rf_max$/;"	e	enum:_rt_rf_power_state
-rf_mode	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rf_mode: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rf_off	include/rtw_pwrctrl.h	/^	rf_off,		\/* HW\/SW Radio OFF or Inactive Power Save *\/$/;"	e	enum:_rt_rf_power_state
-rf_on	include/rtw_pwrctrl.h	/^	rf_on,		\/* RF is on after RFSleep or RFOff *\/$/;"	e	enum:_rt_rf_power_state
-rf_path_char	include/rtw_rf.h	141;"	d
-rf_pwrstate	include/rtw_pwrctrl.h	/^	rt_rf_power_state	rf_pwrstate;\/* cur power state, only for IPS *\/$/;"	m	struct:pwrctrl_priv
-rf_radio_a	include/hal_data.h	/^	char *rf_radio_a;$/;"	m	struct:hal_com_data
-rf_radio_a_len	include/hal_data.h	/^	u32	rf_radio_a_len;$/;"	m	struct:hal_com_data
-rf_radio_b	include/hal_data.h	/^	char *rf_radio_b;$/;"	m	struct:hal_com_data
-rf_radio_b_len	include/hal_data.h	/^	u32	rf_radio_b_len;$/;"	m	struct:hal_com_data
-rf_read_reg_mutex	include/drv_types.h	/^	_mutex rf_read_reg_mutex;$/;"	m	struct:dvobj_priv
-rf_read_sniff_num	core/rtw_io.c	/^int rf_read_sniff_num = sizeof(rf_read_sniff_ranges) \/ sizeof(struct rf_sniff_ent);$/;"	v
-rf_read_sniff_ranges	core/rtw_io.c	/^struct rf_sniff_ent rf_read_sniff_ranges[] = {$/;"	v	typeref:struct:rf_sniff_ent
-rf_reg_dump	core/rtw_debug.c	/^void rf_reg_dump(void *sel, _adapter *adapter)$/;"	f
-rf_reg_param	include/rtw_mp.h	/^struct rf_reg_param {$/;"	s
-rf_sleep	include/rtw_pwrctrl.h	/^	rf_sleep,	\/* 802.11 Power Save mode *\/$/;"	e	enum:_rt_rf_power_state
-rf_sniff_ent	core/rtw_io.c	/^struct rf_sniff_ent {$/;"	s	file:
-rf_tx_pwr_lmt	include/hal_data.h	/^	char *rf_tx_pwr_lmt;$/;"	m	struct:hal_com_data
-rf_tx_pwr_lmt_len	include/hal_data.h	/^	u32	rf_tx_pwr_lmt_len;$/;"	m	struct:hal_com_data
-rf_tx_pwr_track	include/hal_data.h	/^	char *rf_tx_pwr_track;$/;"	m	struct:hal_com_data
-rf_tx_pwr_track_len	include/hal_data.h	/^	u32	rf_tx_pwr_track_len;$/;"	m	struct:hal_com_data
-rf_type	include/hal_data.h	/^	u8	rf_type;$/;"	m	struct:hal_com_data
-rf_write_sniff_num	core/rtw_io.c	/^int rf_write_sniff_num = sizeof(rf_write_sniff_ranges) \/ sizeof(struct rf_sniff_ent);$/;"	v
-rf_write_sniff_ranges	core/rtw_io.c	/^struct rf_sniff_ent rf_write_sniff_ranges[] = {$/;"	v	typeref:struct:rf_sniff_ent
-rfchannel	include/rtw_cmd.h	/^	u8	rfchannel;$/;"	m	struct:getphy_rsp
-rfchannel	include/rtw_cmd.h	/^	u8	rfchannel;$/;"	m	struct:setphy_parm
-rfctl_to_dvobj	include/drv_types.h	1089;"	d
-rfe_ctrl_anta_src	include/Hal8188FPhyReg.h	1117;"	d
-rfe_ctrl_anta_src	include/Hal8703BPhyReg.h	143;"	d
-rfe_ctrl_anta_src	include/Hal8723BPhyReg.h	143;"	d
-rfe_ctrl_anta_src	include/Hal8723DPhyReg.h	143;"	d
-rfe_module_type	hal/btc/HalBtc8822b1Ant.h	/^	u8			rfe_module_type;	$/;"	m	struct:rfe_type_8822b_1ant
-rfe_module_type	hal/btc/halbtc8821c1ant.h	/^	u8			rfe_module_type;	$/;"	m	struct:rfe_type_8821c_1ant
-rfe_module_type	hal/btc/halbtc8821c2ant.h	/^	u8			rfe_module_type;	$/;"	m	struct:rfe_type_8821c_2ant
-rfe_type	hal/btc/HalBtc8822b1Ant.c	/^static struct	rfe_type_8822b_1ant		*rfe_type = &gl_rfe_type_8822b_1ant;$/;"	v	typeref:struct:rfe_type_8822b_1ant	file:
-rfe_type	hal/btc/HalBtcOutSrc.h	/^	u8				rfe_type;$/;"	m	struct:btc_board_info
-rfe_type	hal/btc/halbtc8821c1ant.c	/^static struct	rfe_type_8821c_1ant		*rfe_type = &gl_rfe_type_8821c_1ant;$/;"	v	typeref:struct:rfe_type_8821c_1ant	file:
-rfe_type	hal/btc/halbtc8821c2ant.c	/^static struct	rfe_type_8821c_2ant		*rfe_type = &gl_rfe_type_8821c_2ant;$/;"	v	typeref:struct:rfe_type_8821c_2ant	file:
-rfe_type	include/rtw_pwrctrl.h	/^	u64	rfe_type;			\/* rfe_type && 0x00000000000000ff *\/$/;"	m	struct:pno_scan_info
-rfe_type_8821c_1ant	hal/btc/halbtc8821c1ant.h	/^struct rfe_type_8821c_1ant{$/;"	s
-rfe_type_8821c_2ant	hal/btc/halbtc8821c2ant.h	/^struct rfe_type_8821c_2ant{$/;"	s
-rfe_type_8822b_1ant	hal/btc/HalBtc8822b1Ant.h	/^struct rfe_type_8822b_1ant{$/;"	s
-rfintfe	include/hal_com_phycfg.h	/^	u32 rfintfe; 			\/* output enable: *\/$/;"	m	struct:_BB_REGISTER_DEFINITION
-rfintfo	include/hal_com_phycfg.h	/^	u32 rfintfo; 			\/* output data: *\/$/;"	m	struct:_BB_REGISTER_DEFINITION
-rfintfs	include/drv_types.h	/^	u8	rfintfs;$/;"	m	struct:registry_priv
-rfintfs	include/hal_com_phycfg.h	/^	u32 rfintfs;			\/* set software control: *\/$/;"	m	struct:_BB_REGISTER_DEFINITION
-rfintfs	include/rtw_cmd.h	/^	u8	rfintfs;$/;"	m	struct:getrfintfs_parm
-rfintfs	include/rtw_mp_ioctl.h	/^	u32 rfintfs;$/;"	m	struct:rfintfs_parm
-rfintfs_parm	include/rtw_mp_ioctl.h	/^struct rfintfs_parm {$/;"	s
-rfoff_reason	include/rtw_pwrctrl.h	/^	u32	rfoff_reason;$/;"	m	struct:pwrctrl_priv
-rfpath_num_2g	include/hal_data.h	/^	u8 rfpath_num_2g:4;	\/* used for tx power index path *\/$/;"	m	struct:hal_spec_t
-rfpath_num_5g	include/hal_data.h	/^	u8 rfpath_num_5g:4;	\/* used for tx power index path *\/$/;"	m	struct:hal_spec_t
-rfu_codeword_table	hal/phydm/phydm_antdiv.h	/^	u4Byte	rfu_codeword_table[4]; \/*2G beam truth table*\/$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-rfu_codeword_table_5g	hal/phydm/phydm_antdiv.h	/^	u4Byte	rfu_codeword_table_5g[4]; \/*5G beam truth table*\/$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-rijndaelEncrypt	core/rtw_security.c	/^static void rijndaelEncrypt(u32 rk[\/*44*\/], u8 pt[16], u8 ct[16])$/;"	f	file:
-rijndaelKeySetupEnc	core/rtw_security.c	/^static void rijndaelKeySetupEnc(u32 rk[\/*44*\/], const u8 cipherKey[])$/;"	f	file:
-ro_ch_cookie_gen	include/rtw_mlme.h	/^	ATOMIC_T ro_ch_cookie_gen;$/;"	m	struct:cfg80211_wifidirect_info
-ro_ch_handler	core/rtw_p2p.c	/^static int ro_ch_handler(_adapter *adapter, u8 *buf)$/;"	f	file:
-ro_ch_timer_process	core/rtw_p2p.c	/^static void ro_ch_timer_process(void *FunctionContext)$/;"	f	file:
-ro_ch_wdev	include/rtw_mlme.h	/^	struct wireless_dev *ro_ch_wdev;$/;"	m	struct:cfg80211_wifidirect_info	typeref:struct:cfg80211_wifidirect_info::wireless_dev
-roam_flags	include/rtw_mlme.h	/^	u8 roam_flags;$/;"	m	struct:mlme_priv
-roam_network	include/rtw_mlme.h	/^	struct wlan_network *roam_network; \/* the target of active roam *\/$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::wlan_network
-roam_rssi_diff_th	include/rtw_mlme.h	/^	u8 roam_rssi_diff_th; \/* rssi difference threshold for active scan candidate selection *\/$/;"	m	struct:mlme_priv
-roam_rssi_threshold	include/rtw_mlme.h	/^	u8 roam_rssi_threshold;$/;"	m	struct:mlme_priv
-roam_scan_int_ms	include/rtw_mlme.h	/^	u32 roam_scan_int_ms; \/* scan interval for active roam *\/$/;"	m	struct:mlme_priv
-roam_scanr_exp_ms	include/rtw_mlme.h	/^	u32 roam_scanr_exp_ms; \/* scan result expire time in ms  for roam *\/$/;"	m	struct:mlme_priv
-roam_tgt_addr	include/rtw_mlme.h	/^	u8 roam_tgt_addr[ETH_ALEN]; \/* request to roam to speicific target without other consideration *\/$/;"	m	struct:mlme_priv
-roch_mutex	os_dep/linux/ioctl_cfg80211.h	/^	_mutex roch_mutex;$/;"	m	struct:rtw_wdev_priv
-roch_num	include/rtw_mi.h	/^	u8 roch_num;$/;"	m	struct:mi_state
-rockchip_wifi_exit_module_rtkwifi	os_dep/linux/sdio_intf.c	/^EXPORT_SYMBOL(rockchip_wifi_exit_module_rtkwifi);$/;"	v
-rockchip_wifi_exit_module_rtkwifi	os_dep/linux/sdio_intf.c	/^module_exit(rockchip_wifi_exit_module_rtkwifi);$/;"	v
-rockchip_wifi_exit_module_rtkwifi	os_dep/linux/sdio_intf.c	/^void rockchip_wifi_exit_module_rtkwifi(void)$/;"	f
-rockchip_wifi_init_module_rtkwifi	os_dep/linux/sdio_intf.c	/^EXPORT_SYMBOL(rockchip_wifi_init_module_rtkwifi);$/;"	v
-rockchip_wifi_init_module_rtkwifi	os_dep/linux/sdio_intf.c	/^int rockchip_wifi_init_module_rtkwifi(void)$/;"	f
-rockchip_wifi_init_module_rtkwifi	os_dep/linux/sdio_intf.c	/^late_initcall(rockchip_wifi_init_module_rtkwifi);$/;"	v
-rockchip_wifi_init_module_rtkwifi	os_dep/linux/sdio_intf.c	/^module_init(rockchip_wifi_init_module_rtkwifi);$/;"	v
-role	include/rtw_cmd.h	/^	u8 role:1; \/* 1: Owner, 0: Client *\/$/;"	m	struct:P2P_PS_Offload_t
-role	include/rtw_cmd.h	/^	u8 role:2;$/;"	m	struct:P2P_WoWlan_Offload_t
-role	include/rtw_mcc.h	/^	u8 role;			\/* MCC role(AP,STA,GO,GC) *\/$/;"	m	struct:mcc_adapter_priv
-role	include/rtw_mlme.h	/^	enum P2P_ROLE			role;$/;"	m	struct:wifidirect_info	typeref:enum:wifidirect_info::P2P_ROLE
-rotr	include/rtw_security.h	/^static inline u32 rotr(u32 val, int bits)$/;"	f
-route_dump	os_dep/linux/os_intfs.c	/^static int route_dump(u32 *gw_addr , int *gw_index)$/;"	f	file:
-route_info	os_dep/linux/os_intfs.c	/^struct route_info {$/;"	s	file:
-router_alert	include/ip.h	/^	unsigned char router_alert;$/;"	m	struct:ip_options
-rpt_sel	include/rtl8188e_recv.h	/^	u32 rpt_sel:2;$/;"	m	struct:rxreport_8188e
-rpt_timer_setting_wk_hdl	core/rtw_cmd.c	/^void rpt_timer_setting_wk_hdl(_adapter *padapter, u16 minRptTime)$/;"	f
-rpwm	include/rtw_pwrctrl.h	/^	volatile u8 rpwm; \/* requested power state for fw *\/$/;"	m	struct:pwrctrl_priv
-rpwm_val	hal/btc/HalBtcOutSrc.h	/^	u8					rpwm_val;$/;"	m	struct:btc_bt_info
-rpwmtimeout_workitem_callback	core/rtw_pwrctrl.c	/^static void rpwmtimeout_workitem_callback(struct work_struct *work)$/;"	f	file:
-rpwmtimeoutwi	include/rtw_pwrctrl.h	/^	_workitem rpwmtimeoutwi;$/;"	m	struct:pwrctrl_priv
-rr	include/ip.h	/^	unsigned char rr;$/;"	m	struct:ip_options
-rr_needaddr	include/ip.h	/^		 rr_needaddr:1,			\/* Need to record addr of outgoing dev	*\/$/;"	m	struct:ip_options
-rsn_akm_suite_type	include/rtw_security.h	/^	u32	rsn_akm_suite_type;$/;"	m	struct:security_priv
-rsn_ie	include/ieee80211.h	/^	u8 *rsn_ie;$/;"	m	struct:rtw_ieee802_11_elems
-rsn_ie_hdr	include/ieee80211_ext.h	/^struct rsn_ie_hdr {$/;"	s
-rsn_ie_len	include/ieee80211.h	/^	u8 rsn_ie_len;$/;"	m	struct:rtw_ieee802_11_elems
-rsp	include/rtw_cmd.h	/^	u8	*rsp;$/;"	m	struct:cmd_obj
-rsp_allocated_buf	include/rtw_cmd.h	/^	u8	*rsp_allocated_buf;$/;"	m	struct:cmd_priv
-rsp_buf	include/rtw_cmd.h	/^	u8	*rsp_buf;	\/* shall be non-paged, and 4 bytes aligned		 *\/$/;"	m	struct:cmd_priv
-rsp_cnt	include/rtw_cmd.h	/^	u32	rsp_cnt;$/;"	m	struct:cmd_priv
-rsp_intent	os_dep/linux/ioctl_cfg80211.h	/^	u8 rsp_intent;$/;"	m	struct:rtw_wdev_nego_info
-rsp_op_ch	os_dep/linux/ioctl_cfg80211.h	/^	u8 rsp_op_ch;$/;"	m	struct:rtw_wdev_invit_info
-rsp_op_ch	os_dep/linux/ioctl_cfg80211.h	/^	u8 rsp_op_ch;$/;"	m	struct:rtw_wdev_nego_info
-rsprintf	hal/btc/Mp_Precomp.h	29;"	d
-rsprintf	hal/btc/Mp_Precomp.h	31;"	d
-rspsz	include/rtw_cmd.h	/^	u32	rspsz;$/;"	m	struct:cmd_obj
-rssi	core/rtw_cmd.c	/^	u8 rssi;$/;"	m	struct:btinfo	file:
-rssi	include/ieee80211.h	/^	s8 rssi;$/;"	m	struct:ieee80211_rx_stats
-rssi	include/rtw_btcoex.h	/^	u8 rssi;$/;"	m	struct:btinfo_8761ATV
-rssi	include/rtw_recv.h	/^	s8 rssi;	\/* translate_percentage_to_dbm(ptarget_wlan->network.PhyInfo.SignalStrength); *\/$/;"	m	struct:recv_priv
-rssi	include/sta_info.h	/^	s32  rssi;$/;"	m	struct:sta_info
-rssi_adjust_for_1ant_coex_type	hal/btc/HalBtcOutSrc.h	/^	u8					rssi_adjust_for_1ant_coex_type;$/;"	m	struct:btc_bt_info
-rssi_adjust_for_agc_table_on	hal/btc/HalBtcOutSrc.h	/^	u8					rssi_adjust_for_agc_table_on;$/;"	m	struct:btc_bt_info
-rssi_level	include/sta_info.h	/^	u8		rssi_level;			\/* for Refresh RA mask *\/$/;"	m	struct:sta_info
-rssi_stat	include/sta_info.h	/^	RSSI_STA	 rssi_stat;$/;"	m	struct:sta_info
-rsv	include/rtw_cmd.h	/^	u32 rsv;$/;"	m	struct:geth2clbk_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getbasicrate_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getcountjudge_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getdatarate_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getphy_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getphyinfo_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getssdlevel_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getssulevel_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:getssup_parm
-rsvd	include/rtw_cmd.h	/^	u32 rsvd;$/;"	m	struct:gettxagctbl_parm
-rsvd	include/rtw_cmd.h	/^	u8	rsvd;$/;"	m	struct:set_stakey_rsp
-rsvd	include/rtw_cmd.h	/^	u8	rsvd[3];$/;"	m	struct:set_assocsta_rsp
-rsvd	include/rtw_cmd.h	/^	u8	rsvd[3];$/;"	m	struct:setopmode_parm
-rsvd	include/rtw_cmd.h	/^	u8 rsvd:1;$/;"	m	struct:P2P_PS_Offload_t
-rsvd	include/rtw_cmd.h	/^	u8 rsvd[2];$/;"	m	struct:setauth_parm
-rsvd	include/rtw_cmd.h	/^	uint rsvd;$/;"	m	struct:getratable_parm
-rsvd	include/rtw_cmd.h	/^	unsigned int rsvd;$/;"	m	struct:getbcnerrcnt_parm
-rsvd	include/rtw_cmd.h	/^	unsigned int rsvd;$/;"	m	struct:getbcnokcnt_parm
-rsvd	include/rtw_cmd.h	/^	unsigned int rsvd;$/;"	m	struct:getcurtxpwrlevel_parm
-rsvd	include/rtw_cmd.h	/^	unsigned int rsvd;$/;"	m	struct:getrxretrycnt_parm
-rsvd	include/rtw_cmd.h	/^	unsigned int rsvd;$/;"	m	struct:gettxretrycnt_parm
-rsvd	include/rtw_event.h	/^	unsigned char rsvd[2]; \/* for reason *\/$/;"	m	struct:stadel_event
-rsvd	include/rtw_mlme_ext.h	/^	unsigned int rsvd;$/;"	m	struct:C2HEvent_Header
-rsvd	include/rtw_pwrctrl.h	/^	unsigned short rsvd;$/;"	m	struct:reportpwrstate_parm
-rsvd0	include/rtw_iol.h	/^	u8 rsvd0;$/;"	m	struct:_io_offload_cmd
-rsvd0026	include/rtl8821a_xmit.h	/^	u32 rsvd0026:1;$/;"	m	struct:txdescriptor_8821a
-rsvd0027	include/rtl8821a_xmit.h	/^	u32 rsvd0027:1;$/;"	m	struct:txdescriptor_8821a
-rsvd0031	include/rtl8821a_xmit.h	/^	u32 rsvd0031:1;$/;"	m	struct:txdescriptor_8821a
-rsvd0406	include/rtl8188e_xmit.h	/^	u32 rsvd0406:2;$/;"	m	struct:txdesc_88e
-rsvd0406	include/rtl8192e_xmit.h	/^	u32 rsvd0406:2;$/;"	m	struct:txdescriptor_8192e
-rsvd0406	include/rtl8812a_xmit.h	/^	u32 rsvd0406:2;$/;"	m	struct:txdescriptor_8812
-rsvd0407	include/rtl8821a_xmit.h	/^	u32 rsvd0407:1;$/;"	m	struct:txdescriptor_8821a
-rsvd0424	include/rtl8188e_xmit.h	/^	u32 rsvd0424:2;$/;"	m	struct:txdesc_88e
-rsvd0424	include/rtl8192e_xmit.h	/^	u32 rsvd0424:2;$/;"	m	struct:txdescriptor_8192e
-rsvd0424	include/rtl8812a_xmit.h	/^	u32 rsvd0424:2;$/;"	m	struct:txdescriptor_8812
-rsvd0431	include/rtl8188e_xmit.h	/^	u32 rsvd0431:1;$/;"	m	struct:txdesc_88e
-rsvd0431	include/rtl8192e_xmit.h	/^	u32 rsvd0431:1;$/;"	m	struct:txdescriptor_8192e
-rsvd0431	include/rtl8812a_xmit.h	/^	u32 rsvd0431:1;$/;"	m	struct:txdescriptor_8812
-rsvd0809	include/rtl8821a_xmit.h	/^	u32 rsvd0809:1;$/;"	m	struct:txdescriptor_8821a
-rsvd0830	include/rtl8821a_xmit.h	/^	u32 rsvd0830:2;$/;"	m	struct:txdescriptor_8821a
-rsvd0831	include/rtl8188e_recv.h	/^	u32 rsvd0831:1;$/;"	m	struct:rxreport_8188e
-rsvd1216	include/rtl8188e_recv.h	/^	u32 rsvd1216:13;$/;"	m	struct:rxreport_8188e
-rsvd16	include/rtl8188e_recv.h	/^	u32 rsvd16;$/;"	m	struct:rxreport_8188e
-rsvd2016	include/rtl8821a_xmit.h	/^	u32 rsvd2016:7;$/;"	m	struct:txdescriptor_8821a
-rsvd2031	include/rtl8821a_xmit.h	/^	u32 rsvd2031:1;$/;"	m	struct:txdescriptor_8821a
-rsvd2413	include/rtl8188e_recv.h	/^	u32 rsvd2413:19;$/;"	m	struct:rxreport_8188e
-rsvd2428	include/rtl8821a_xmit.h	/^	u32 rsvd2428:4;$/;"	m	struct:txdescriptor_8821a
-rsvd2816	include/rtl8821a_xmit.h	/^	u32 rsvd2816:8;$/;"	m	struct:txdescriptor_8821a
-rsvd32	include/rtl8812a_xmit.h	/^	u32 rsvd32;$/;"	m	struct:txdescriptor_8812
-rsvd3214	include/rtl8821a_xmit.h	/^	u32 rsvd3214:1;$/;"	m	struct:txdescriptor_8821a
-rsvd36	include/rtl8812a_xmit.h	/^	u32 rsvd36;$/;"	m	struct:txdescriptor_8812
-rsvd_0	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_0: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_0	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_0: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rsvd_0	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_0: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_1	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_1: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rsvd_1	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_1: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_1	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_1	hal/phydm/phydm_hwconfig.h	/^	u1Byte	rsvd_1;\/*ch_corr_msb;*\/$/;"	m	struct:_Phy_Status_Rpt_8192cd
-rsvd_2	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_2: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_2	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_2: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rsvd_2	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_2	hal/phydm/phydm_hwconfig.h	/^	u1Byte	rsvd_2[3];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-rsvd_3	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_3: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rsvd_3	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_3: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_3	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_3: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_3	hal/phydm/phydm_hwconfig.h	/^	u1Byte	rsvd_3;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-rsvd_34	core/rtw_cmd.c	/^	u8 rsvd_34:1;$/;"	m	struct:btinfo	file:
-rsvd_34	include/rtw_btcoex.h	/^	u8 rsvd_34:1;$/;"	m	struct:btinfo_8761ATV
-rsvd_35	core/rtw_cmd.c	/^	u8 rsvd_35:1;$/;"	m	struct:btinfo	file:
-rsvd_36	core/rtw_cmd.c	/^	u8 rsvd_36:1;$/;"	m	struct:btinfo	file:
-rsvd_37	core/rtw_cmd.c	/^	u8 rsvd_37:1;$/;"	m	struct:btinfo	file:
-rsvd_4	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_4: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_4	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_4: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rsvd_4	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_4:2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_5	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_5: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_5	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_5: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rsvd_5	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_5;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_50	core/rtw_cmd.c	/^	u8 rsvd_50:1;$/;"	m	struct:btinfo	file:
-rsvd_51	core/rtw_cmd.c	/^	u8 rsvd_51:1;$/;"	m	struct:btinfo	file:
-rsvd_52	core/rtw_cmd.c	/^	u8 rsvd_52:1;$/;"	m	struct:btinfo	file:
-rsvd_53	core/rtw_cmd.c	/^	u8 rsvd_53:1;$/;"	m	struct:btinfo	file:
-rsvd_54	core/rtw_cmd.c	/^	u8 rsvd_54:1;$/;"	m	struct:btinfo	file:
-rsvd_55	core/rtw_cmd.c	/^	u8 rsvd_55:1;$/;"	m	struct:btinfo	file:
-rsvd_6	core/rtw_cmd.c	/^	u8 rsvd_6;$/;"	m	struct:btinfo	file:
-rsvd_6	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_6: 2;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_6	hal/phydm/phydm_hwconfig.h	/^	u4Byte		rsvd_6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_7	core/rtw_cmd.c	/^	u8 rsvd_7;$/;"	m	struct:btinfo	file:
-rsvd_7	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_7:3;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-rsvd_7	hal/phydm/phydm_hwconfig.h	/^	u4Byte		rsvd_7;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_8	hal/phydm/phydm_hwconfig.h	/^	u4Byte		rsvd_8;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rsvd_9	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rsvd_9:1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rt_rf_power_state	include/rtw_pwrctrl.h	/^} rt_rf_power_state;$/;"	t	typeref:enum:_rt_rf_power_state
-rtfloor	core/rtw_mp.c	/^int rtfloor(float x)$/;"	f
-rtk_buf_mem	core/rtw_mem.c	/^struct u8 *rtk_buf_mem[NR_RECVBUFF];$/;"	v	typeref:struct:u8
-rtk_core	Makefile	/^rtk_core :=	core\/rtw_cmd.o \\$/;"	m
-rtk_skb_mem_q	core/rtw_mem.c	/^struct sk_buff_head rtk_skb_mem_q;$/;"	v	typeref:struct:sk_buff_head
-rtl8188e_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8188e_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8188f_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8188f_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8189es_sdio_poweroff	platform/platform_ARM_SUNxI_sdio.c	/^int rtl8189es_sdio_poweroff(void)$/;"	f
-rtl8189es_sdio_powerup	platform/platform_ARM_SUNxI_sdio.c	/^int rtl8189es_sdio_powerup(void)$/;"	f
-rtl8192cd_priv	hal/phydm/phydm.h	/^typedef	struct rtl8192cd_priv {$/;"	s
-rtl8192cd_priv	hal/phydm/phydm.h	/^} rtl8192cd_priv, *prtl8192cd_priv;$/;"	t	typeref:struct:rtl8192cd_priv
-rtl8192e_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8192e_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8703b_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8703b_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl871x_mgnt_netdev_ops	os_dep/linux/mlme_linux.c	/^static const struct net_device_ops rtl871x_mgnt_netdev_ops = {$/;"	v	typeref:struct:net_device_ops	file:
-rtl8723D_card_disable_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_card_disable_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_CARDDIS_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_card_enable_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_card_enable_flow[RTL8723D_TRANS_CARDDIS_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_enter_lps_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_enter_lps_flow[RTL8723D_TRANS_ACT_TO_LPS_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_hwpdn_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_hwpdn_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_PDN_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_leave_lps_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_leave_lps_flow[RTL8723D_TRANS_LPS_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_power_on_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_power_on_flow[RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_radio_off_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_radio_off_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_resume_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_resume_flow[RTL8723D_TRANS_SUS_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_ACT_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723D_suspend_flow	hal/rtl8723d/Hal8723DPwrSeq.c	/^WLAN_PWR_CFG rtl8723D_suspend_flow[RTL8723D_TRANS_ACT_TO_CARDEMU_STEPS + RTL8723D_TRANS_CARDEMU_TO_SUS_STEPS + RTL8723D_TRANS_END_STEPS] = {$/;"	v
-rtl8723b_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8723b_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8723d_CheckAntenna_Selection	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_CheckAntenna_Selection(PADAPTER padapter)$/;"	f
-rtl8723d_DeinitAntenna_Selection	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_DeinitAntenna_Selection(PADAPTER padapter)$/;"	f
-rtl8723d_FirmwareDownload	hal/rtl8723d/rtl8723d_hal_init.c	/^s32 rtl8723d_FirmwareDownload(PADAPTER padapter, BOOLEAN  bUsedWoWLANFw)$/;"	f
-rtl8723d_FirmwareSelfReset	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_FirmwareSelfReset(PADAPTER padapter)$/;"	f
-rtl8723d_HalDmWatchDog	hal/rtl8723d/rtl8723d_dm.c	/^rtl8723d_HalDmWatchDog($/;"	f
-rtl8723d_HalDmWatchDog_in_LPS	hal/rtl8723d/rtl8723d_dm.c	/^void rtl8723d_HalDmWatchDog_in_LPS(IN	PADAPTER	Adapter)$/;"	f
-rtl8723d_InitAntenna_Selection	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_InitAntenna_Selection(PADAPTER padapter)$/;"	f
-rtl8723d_InitBeaconMaxError	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_InitBeaconMaxError(PADAPTER padapter, u8 InfraMode)$/;"	f
-rtl8723d_InitBeaconParameters	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_InitBeaconParameters(PADAPTER padapter)$/;"	f
-rtl8723d_InitHalDm	hal/rtl8723d/rtl8723d_dm.c	/^rtl8723d_InitHalDm($/;"	f
-rtl8723d_InitLLTTable	hal/rtl8723d/rtl8723d_hal_init.c	/^s32 rtl8723d_InitLLTTable(PADAPTER padapter)$/;"	f
-rtl8723d_InitializeFirmwareVars	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_InitializeFirmwareVars(PADAPTER padapter)$/;"	f
-rtl8723d_MRateIdxToARFRId	hal/rtl8723d/rtl8723d_hal_init.c	/^u8 rtl8723d_MRateIdxToARFRId(PADAPTER padapter, u8 rate_idx)$/;"	f
-rtl8723d_SetBeaconRelatedRegisters	hal/rtl8723d/rtl8723d_hal_init.c	/^static void rtl8723d_SetBeaconRelatedRegisters(PADAPTER padapter)$/;"	f	file:
-rtl8723d_deinit_dm_priv	hal/rtl8723d/rtl8723d_dm.c	/^void rtl8723d_deinit_dm_priv(IN PADAPTER Adapter)$/;"	f
-rtl8723d_download_BTCoex_AP_mode_rsvd_page	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter)$/;"	f
-rtl8723d_download_rsvd_page	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_download_rsvd_page(PADAPTER padapter, u8 mstatus)$/;"	f
-rtl8723d_fill_default_txdesc	hal/rtl8723d/rtl8723d_hal_init.c	/^static void rtl8723d_fill_default_txdesc($/;"	f	file:
-rtl8723d_fill_fake_txdesc	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_fill_fake_txdesc($/;"	f
-rtl8723d_hal_dm_in_lps	hal/rtl8723d/rtl8723d_dm.c	/^void rtl8723d_hal_dm_in_lps(PADAPTER padapter)$/;"	f
-rtl8723d_init_default_value	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_init_default_value(PADAPTER padapter)$/;"	f
-rtl8723d_init_dm_priv	hal/rtl8723d/rtl8723d_dm.c	/^void rtl8723d_init_dm_priv(IN PADAPTER Adapter)$/;"	f
-rtl8723d_lps_poff_append_extra_info	hal/rtl8723d/rtl8723d_lps_poff.c	/^static u8 rtl8723d_lps_poff_append_extra_info(PADAPTER padapter, u32 len)$/;"	f	file:
-rtl8723d_lps_poff_deinit	hal/rtl8723d/rtl8723d_lps_poff.c	/^void rtl8723d_lps_poff_deinit(PADAPTER padapter)$/;"	f
-rtl8723d_lps_poff_dl_config_file	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_dl_config_file(PADAPTER padapter)$/;"	f	file:
-rtl8723d_lps_poff_dynamic_file	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_dynamic_file(PADAPTER padapter, u8 index, u8 isGK)$/;"	f	file:
-rtl8723d_lps_poff_get_status	hal/rtl8723d/rtl8723d_lps_poff.c	/^bool rtl8723d_lps_poff_get_status(PADAPTER padapter)$/;"	f
-rtl8723d_lps_poff_get_txbndy_status	hal/rtl8723d/rtl8723d_lps_poff.c	/^bool rtl8723d_lps_poff_get_txbndy_status(PADAPTER padapter)$/;"	f
-rtl8723d_lps_poff_h2c_ctrl	hal/rtl8723d/rtl8723d_lps_poff.c	/^void rtl8723d_lps_poff_h2c_ctrl(PADAPTER padapter, u8 en)$/;"	f
-rtl8723d_lps_poff_h2c_param	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_h2c_param(PADAPTER padapter, u8 tx_bndy, u16 len,$/;"	f	file:
-rtl8723d_lps_poff_init	hal/rtl8723d/rtl8723d_lps_poff.c	/^void rtl8723d_lps_poff_init(PADAPTER padapter)$/;"	f
-rtl8723d_lps_poff_sec_cam_opt	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_sec_cam_opt(PADAPTER padapter)$/;"	f	file:
-rtl8723d_lps_poff_send_config_file	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_send_config_file(PADAPTER padapter,$/;"	f	file:
-rtl8723d_lps_poff_send_config_frame	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_send_config_frame(PADAPTER padapter,$/;"	f	file:
-rtl8723d_lps_poff_set_dynamic_file	hal/rtl8723d/rtl8723d_lps_poff.c	/^static u8 rtl8723d_lps_poff_set_dynamic_file(u8 *pFile, u32 type, u32 wdata)$/;"	f	file:
-rtl8723d_lps_poff_set_param	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_set_param(PADAPTER padapter)$/;"	f	file:
-rtl8723d_lps_poff_set_ps_mode	hal/rtl8723d/rtl8723d_lps_poff.c	/^void rtl8723d_lps_poff_set_ps_mode(PADAPTER padapter, bool bEnterLPS)$/;"	f
-rtl8723d_lps_poff_set_tx_bndy	hal/rtl8723d/rtl8723d_lps_poff.c	/^static void rtl8723d_lps_poff_set_tx_bndy(PADAPTER padapter, u8 tx_bndy)$/;"	f	file:
-rtl8723d_lps_poff_tx_bndy_flow	hal/rtl8723d/rtl8723d_lps_poff.c	/^static bool rtl8723d_lps_poff_tx_bndy_flow(PADAPTER padapter, bool enable)$/;"	f	file:
-rtl8723d_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8723d_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8723d_prepare_for_enter_poff	hal/rtl8723d/rtl8723d_lps_poff.c	/^static bool rtl8723d_prepare_for_enter_poff(PADAPTER padapter, bool bEnterLPS)$/;"	f	file:
-rtl8723d_query_rx_desc_status	hal/rtl8723d/rtl8723d_rxdesc.c	/^void rtl8723d_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc)$/;"	f
-rtl8723d_reset_tsf	hal/rtl8723d/rtl8723d_cmd.c	/^u8 rtl8723d_reset_tsf(_adapter *padapter, u8 reset_port)$/;"	f
-rtl8723d_set_FwAPReqRPT_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwAPReqRPT_cmd(PADAPTER padapter, u32 need_ack)$/;"	f
-rtl8723d_set_FwAoacRsvdPage_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^static void rtl8723d_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)$/;"	f	file:
-rtl8723d_set_FwBtMpOper_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwBtMpOper_cmd(PADAPTER padapter, u8 idx, u8 ver, u8 reqnum, u8 *param)$/;"	f
-rtl8723d_set_FwDisconDecision_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^static void rtl8723d_set_FwDisconDecision_cmd(PADAPTER padapter, u8 benable)$/;"	f	file:
-rtl8723d_set_FwJoinBssRpt_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus)$/;"	f
-rtl8723d_set_FwKeepAlive_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^static void rtl8723d_set_FwKeepAlive_cmd(PADAPTER padapter, u8 benable, u8 pkt_type)$/;"	f	file:
-rtl8723d_set_FwLowPwrLps_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^static s32 rtl8723d_set_FwLowPwrLps_cmd(PADAPTER padapter, u8 enable)$/;"	f	file:
-rtl8723d_set_FwMacIdConfig_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwMacIdConfig_cmd(_adapter *padapter, u8 mac_id, u8 raid, u8 bw, u8 sgi, u32 mask)$/;"	f
-rtl8723d_set_FwPsTuneParam_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwPsTuneParam_cmd(PADAPTER padapter)$/;"	f
-rtl8723d_set_FwPwrModeInIPS_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwPwrModeInIPS_cmd(PADAPTER padapter, u8 en)$/;"	f
-rtl8723d_set_FwPwrMode_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwPwrMode_cmd(PADAPTER padapter, u8 psmode)$/;"	f
-rtl8723d_set_FwRssiSetting_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_FwRssiSetting_cmd(_adapter *padapter, u8 *param)$/;"	f
-rtl8723d_set_FwRsvdPage_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^static void rtl8723d_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)$/;"	f	file:
-rtl8723d_set_hal_ops	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_set_hal_ops(struct hal_ops *pHalFunc)$/;"	f
-rtl8723d_set_p2p_ps_offload_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_p2p_ps_offload_cmd(_adapter *padapter, u8 p2p_ps_state)$/;"	f
-rtl8723d_set_rssi_cmd	hal/rtl8723d/rtl8723d_cmd.c	/^void rtl8723d_set_rssi_cmd(_adapter *padapter, u8 *param)$/;"	f
-rtl8723d_sreset_linked_status_check	hal/rtl8723d/rtl8723d_sreset.c	/^void rtl8723d_sreset_linked_status_check(_adapter *padapter)$/;"	f
-rtl8723d_sreset_xmit_status_check	hal/rtl8723d/rtl8723d_sreset.c	/^void rtl8723d_sreset_xmit_status_check(_adapter *padapter)$/;"	f
-rtl8723d_start_thread	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_start_thread(_adapter *padapter)$/;"	f
-rtl8723d_stop_thread	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_stop_thread(_adapter *padapter)$/;"	f
-rtl8723d_update_txdesc	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723d_update_txdesc(struct xmit_frame *pxmitframe, u8 *pbuf)$/;"	f
-rtl8723ds_DeInitSwLeds	hal/rtl8723d/sdio/rtl8723ds_led.c	/^rtl8723ds_DeInitSwLeds($/;"	f
-rtl8723ds_InitSwLeds	hal/rtl8723d/sdio/rtl8723ds_led.c	/^rtl8723ds_InitSwLeds($/;"	f
-rtl8723ds_cancle_checkbthang_workqueue	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723ds_cancle_checkbthang_workqueue(_adapter *adapter)$/;"	f
-rtl8723ds_free_checkbthang_workqueue	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723ds_free_checkbthang_workqueue(_adapter *adapter)$/;"	f
-rtl8723ds_free_recv_priv	hal/rtl8723d/sdio/rtl8723ds_recv.c	/^void rtl8723ds_free_recv_priv(PADAPTER padapter)$/;"	f
-rtl8723ds_free_xmit_priv	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^void rtl8723ds_free_xmit_priv(PADAPTER padapter)$/;"	f
-rtl8723ds_hal_check_bt_hang	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723ds_hal_check_bt_hang(_adapter *adapter)$/;"	f
-rtl8723ds_hal_deinit	hal/rtl8723d/sdio/sdio_halinit.c	/^static u32 rtl8723ds_hal_deinit(PADAPTER padapter)$/;"	f	file:
-rtl8723ds_hal_init	hal/rtl8723d/sdio/sdio_halinit.c	/^static u32 rtl8723ds_hal_init(PADAPTER padapter)$/;"	f	file:
-rtl8723ds_hal_xmit	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^s32 rtl8723ds_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtl8723ds_hal_xmitframe_enqueue	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^s32	rtl8723ds_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtl8723ds_init_checkbthang_workqueue	hal/rtl8723d/rtl8723d_hal_init.c	/^void rtl8723ds_init_checkbthang_workqueue(_adapter *adapter)$/;"	f
-rtl8723ds_init_default_value	hal/rtl8723d/sdio/sdio_halinit.c	/^static void rtl8723ds_init_default_value(PADAPTER padapter)$/;"	f	file:
-rtl8723ds_init_recv_priv	hal/rtl8723d/sdio/rtl8723ds_recv.c	/^s32 rtl8723ds_init_recv_priv(PADAPTER padapter)$/;"	f
-rtl8723ds_init_xmit_priv	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^s32 rtl8723ds_init_xmit_priv(PADAPTER padapter)$/;"	f
-rtl8723ds_interface_configure	hal/rtl8723d/sdio/sdio_halinit.c	/^static void rtl8723ds_interface_configure(PADAPTER padapter)$/;"	f	file:
-rtl8723ds_mgnt_xmit	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^s32 rtl8723ds_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe)$/;"	f
-rtl8723ds_recv_tasklet	hal/rtl8723d/sdio/rtl8723ds_recv.c	/^static void rtl8723ds_recv_tasklet(void *priv)$/;"	f	file:
-rtl8723ds_set_hal_ops	hal/rtl8723d/sdio/sdio_halinit.c	/^void rtl8723ds_set_hal_ops(PADAPTER padapter)$/;"	f
-rtl8723ds_xmit_buf_handler	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^s32 rtl8723ds_xmit_buf_handler(PADAPTER padapter)$/;"	f
-rtl8723ds_xmit_handler	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^s32 rtl8723ds_xmit_handler(PADAPTER padapter)$/;"	f
-rtl8723ds_xmit_thread	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^thread_return rtl8723ds_xmit_thread(thread_context context)$/;"	f
-rtl8812_iqk_wait	hal/hal_com_c2h.h	90;"	d
-rtl8812a_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8812a_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8814a_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8814a_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8821a_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8821a_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8821c_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8821c_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl8822b_pg_txpwr_def_info	hal/hal_com_phycfg.c	/^static const struct map_t rtl8822b_pg_txpwr_def_info =$/;"	v	typeref:struct:map_t	file:
-rtl_net	os_dep/linux/custom_gpio_linux.c	/^struct net_device *rtl_net;$/;"	v	typeref:struct:net_device
-rtl_priv_pattern	include/rtw_pwrctrl.h	/^typedef struct rtl_priv_pattern {$/;"	s
-rtl_priv_pattern_t	include/rtw_pwrctrl.h	/^} rtl_priv_pattern_t;$/;"	t	typeref:struct:rtl_priv_pattern
-rtl_wow_pattern	include/rtw_pwrctrl.h	/^struct rtl_wow_pattern {$/;"	s
-rts_bw	include/rtl8188e_xmit.h	/^	u32 rts_bw:1;$/;"	m	struct:txdesc_88e
-rts_bw	include/rtl8192e_xmit.h	/^	u32 rts_bw:1;$/;"	m	struct:txdescriptor_8192e
-rts_bw	include/rtl8812a_xmit.h	/^	u32 rts_bw:1;$/;"	m	struct:txdescriptor_8812
-rts_ratefb_lmt	include/rtl8188e_xmit.h	/^	u32 rts_ratefb_lmt:4;$/;"	m	struct:txdesc_88e
-rts_ratefb_lmt	include/rtl8192e_xmit.h	/^	u32 rts_ratefb_lmt:4;$/;"	m	struct:txdescriptor_8192e
-rts_ratefb_lmt	include/rtl8812a_xmit.h	/^	u32 rts_ratefb_lmt:4;$/;"	m	struct:txdescriptor_8812
-rts_ratefb_lmt	include/rtl8821a_xmit.h	/^	u32 rts_ratefb_lmt:4;$/;"	m	struct:txdescriptor_8821a
-rts_rc	include/rtl8188e_xmit.h	/^	u32 rts_rc:6;$/;"	m	struct:txdesc_88e
-rts_rc	include/rtl8192e_xmit.h	/^	u32 rts_rc:6;$/;"	m	struct:txdescriptor_8192e
-rts_rc	include/rtl8812a_xmit.h	/^	u32 rts_rc:6;$/;"	m	struct:txdescriptor_8812
-rts_rc	include/rtl8821a_xmit.h	/^	u32 rts_rc:6;$/;"	m	struct:txdescriptor_8821a
-rts_sc	include/rtl8188e_xmit.h	/^	u32 rts_sc:2;$/;"	m	struct:txdesc_88e
-rts_sc	include/rtl8192e_xmit.h	/^	u32 rts_sc:2;$/;"	m	struct:txdescriptor_8192e
-rts_sc	include/rtl8812a_xmit.h	/^	u32 rts_sc:2;$/;"	m	struct:txdescriptor_8812
-rts_sc	include/rtl8821a_xmit.h	/^	u32 rts_sc:4;$/;"	m	struct:txdescriptor_8821a
-rts_short	include/rtl8188e_xmit.h	/^	u32 rts_short:1;$/;"	m	struct:txdesc_88e
-rts_short	include/rtl8192e_xmit.h	/^	u32 rts_short:1;$/;"	m	struct:txdescriptor_8192e
-rts_short	include/rtl8812a_xmit.h	/^	u32 rts_short:1;$/;"	m	struct:txdescriptor_8812
-rts_short	include/rtl8821a_xmit.h	/^	u32 rts_short:1;$/;"	m	struct:txdescriptor_8821a
-rts_thresh	include/drv_types.h	/^	u16	rts_thresh;$/;"	m	struct:registry_priv
-rtsen	include/rtl8188e_xmit.h	/^	u32 rtsen:1;$/;"	m	struct:txdesc_88e
-rtsen	include/rtl8192e_xmit.h	/^	u32 rtsen:1;$/;"	m	struct:txdescriptor_8192e
-rtsen	include/rtl8812a_xmit.h	/^	u32 rtsen:1;$/;"	m	struct:txdescriptor_8812
-rtsen	include/rtl8821a_xmit.h	/^	u32 rtsen:1;$/;"	m	struct:txdescriptor_8821a
-rtsen	include/rtw_xmit.h	/^	u8 rtsen;$/;"	m	struct:pkt_attrib
-rtsen	include/sta_info.h	/^	u8	rtsen;$/;"	m	struct:sta_info
-rtsp_ctrlport	include/rtw_mlme.h	/^	u16							rtsp_ctrlport;		\/* TCP port number at which the this WFD device listens for RTSP messages, 0 when WFD disable *\/$/;"	m	struct:wifi_display_info
-rtsrate	include/rtl8188e_xmit.h	/^	u32 rtsrate:5;$/;"	m	struct:txdesc_88e
-rtsrate	include/rtl8192e_xmit.h	/^	u32 rtsrate:5;$/;"	m	struct:txdescriptor_8192e
-rtsrate	include/rtl8812a_xmit.h	/^	u32 rtsrate:5;$/;"	m	struct:txdescriptor_8812
-rtsrate	include/rtl8821a_xmit.h	/^	u32 rtsrate:5;$/;"	m	struct:txdescriptor_8821a
-rtt_attributes	os_dep/linux/rtw_cfgvendor.h	/^enum rtt_attributes {$/;"	g
-rtw_1d_to_queue	os_dep/linux/os_intfs.c	/^static const u16 rtw_1d_to_queue[8] = { 2, 3, 3, 2, 1, 1, 0, 0 };$/;"	v	file:
-rtw_2g_channels_init	os_dep/linux/ioctl_cfg80211.c	/^void rtw_2g_channels_init(struct ieee80211_channel *channels)$/;"	f
-rtw_2g_rates_init	os_dep/linux/ioctl_cfg80211.c	/^void rtw_2g_rates_init(struct ieee80211_rate *rates)$/;"	f
-rtw_2ghz_channels	os_dep/linux/ioctl_cfg80211.c	/^static struct ieee80211_channel rtw_2ghz_channels[] = {$/;"	v	typeref:struct:ieee80211_channel	file:
-rtw_5g_channels_init	os_dep/linux/ioctl_cfg80211.c	/^void rtw_5g_channels_init(struct ieee80211_channel *channels)$/;"	f
-rtw_5g_rates_init	os_dep/linux/ioctl_cfg80211.c	/^void rtw_5g_rates_init(struct ieee80211_rate *rates)$/;"	f
-rtw_5ghz_a_channels	os_dep/linux/ioctl_cfg80211.c	/^static struct ieee80211_channel rtw_5ghz_a_channels[] = {$/;"	v	typeref:struct:ieee80211_channel	file:
-rtw_80211d	os_dep/linux/os_intfs.c	/^int rtw_80211d = 0;$/;"	v
-rtw_AcceptAddbaReq	os_dep/linux/os_intfs.c	/^int rtw_AcceptAddbaReq = _TRUE;\/* 0:Reject AP's Add BA req, 1:Accept AP's Add BA req. *\/$/;"	v
-rtw_BIP_verify	core/rtw_security.c	/^u32	rtw_BIP_verify(_adapter *padapter, u8 *precvframe)$/;"	f
-rtw_BT_efuse_map_read	core/efuse/rtw_efuse.c	/^u8 rtw_BT_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_BT_efuse_map_read	core/efuse/rtw_efuse.c	/^u8 rtw_BT_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_BT_efuse_map_write	core/efuse/rtw_efuse.c	/^u8 rtw_BT_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_BT_efuse_map_write	core/efuse/rtw_efuse.c	/^u8 rtw_BT_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_FileMaskEfuse	os_dep/linux/os_intfs.c	/^uint rtw_FileMaskEfuse = 0;$/;"	v
-rtw_GLNA_type	os_dep/linux/os_intfs.c	/^uint rtw_GLNA_type = CONFIG_RTW_GLNA_TYPE;$/;"	v
-rtw_GetPSDData	core/rtw_mp.c	/^static u32 rtw_GetPSDData(PADAPTER pAdapter, u32 point)$/;"	f	file:
-rtw_HCI_event	include/rtw_btcoex.h	/^} rtw_HCI_event;$/;"	t	typeref:struct:_PACKET_IRP_HCIEVENT_DATA
-rtw_IOL_accquire_xmit_frame	core/rtw_iol.c	/^struct xmit_frame	*rtw_IOL_accquire_xmit_frame(ADAPTER *adapter)$/;"	f
-rtw_IOL_append_DELAY_MS_cmd	core/rtw_iol.c	/^int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms)$/;"	f
-rtw_IOL_append_DELAY_US_cmd	core/rtw_iol.c	/^int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us)$/;"	f
-rtw_IOL_append_END_cmd	core/rtw_iol.c	/^int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame)$/;"	f
-rtw_IOL_append_LLT_cmd	core/rtw_iol.c	/^int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary)$/;"	f
-rtw_IOL_append_WB_cmd	include/rtw_iol.h	124;"	d
-rtw_IOL_append_WB_cmd	include/rtw_iol.h	128;"	d
-rtw_IOL_append_WB_cmd	include/rtw_iol.h	62;"	d
-rtw_IOL_append_WD_cmd	include/rtw_iol.h	126;"	d
-rtw_IOL_append_WD_cmd	include/rtw_iol.h	130;"	d
-rtw_IOL_append_WD_cmd	include/rtw_iol.h	64;"	d
-rtw_IOL_append_WRF_cmd	include/rtw_iol.h	65;"	d
-rtw_IOL_append_WW_cmd	include/rtw_iol.h	125;"	d
-rtw_IOL_append_WW_cmd	include/rtw_iol.h	129;"	d
-rtw_IOL_append_WW_cmd	include/rtw_iol.h	63;"	d
-rtw_IOL_append_cmds	core/rtw_iol.c	/^int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len)$/;"	f
-rtw_IOL_applied	core/rtw_iol.c	/^bool rtw_IOL_applied(ADAPTER *adapter)$/;"	f
-rtw_IOL_cmd_boundary_handle	core/rtw_iol.c	/^u8 rtw_IOL_cmd_boundary_handle(struct xmit_frame *pxmit_frame)$/;"	f
-rtw_IOL_cmd_buf_dump	core/rtw_iol.c	/^void rtw_IOL_cmd_buf_dump(ADAPTER *Adapter, int buf_len, u8 *pbuf)$/;"	f
-rtw_IOL_exec_cmd_array_sync	core/rtw_iol.c	/^int rtw_IOL_exec_cmd_array_sync(PADAPTER adapter, u8 *IOL_cmds, u32 cmd_num, u32 max_wating_ms)$/;"	f
-rtw_IOL_exec_cmds_sync	core/rtw_iol.c	/^int rtw_IOL_exec_cmds_sync(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt)$/;"	f
-rtw_IOL_exec_empty_cmds_sync	core/rtw_iol.c	/^int rtw_IOL_exec_empty_cmds_sync(ADAPTER *adapter, u32 max_wating_ms)$/;"	f
-rtw_OffEfuseMask	os_dep/linux/os_intfs.c	/^uint rtw_OffEfuseMask = 0;$/;"	v
-rtw_RFE_type	os_dep/linux/os_intfs.c	/^uint rtw_RFE_type = CONFIG_RTW_RFE_TYPE;$/;"	v
-rtw_TxBBSwing_2G	os_dep/linux/os_intfs.c	/^uint rtw_TxBBSwing_2G = 0xFF;$/;"	v
-rtw_TxBBSwing_5G	os_dep/linux/os_intfs.c	/^uint rtw_TxBBSwing_5G = 0xFF;$/;"	v
-rtw_a_rates	os_dep/linux/ioctl_cfg80211.c	140;"	d	file:
-rtw_access_ctrl	core/rtw_sta_mgt.c	/^u8 rtw_access_ctrl(_adapter *adapter, u8 *mac_addr)$/;"	f
-rtw_ack_policy	os_dep/linux/os_intfs.c	/^int rtw_ack_policy = NORMAL_ACK;$/;"	v
-rtw_ack_tx_done	core/rtw_xmit.c	/^void rtw_ack_tx_done(struct xmit_priv *pxmitpriv, int status)$/;"	f
-rtw_ack_tx_wait	core/rtw_xmit.c	/^int rtw_ack_tx_wait(struct xmit_priv *pxmitpriv, u32 timeout_ms)$/;"	f
-rtw_acl_add_sta	core/rtw_ap.c	/^int rtw_acl_add_sta(_adapter *adapter, const u8 *addr)$/;"	f
-rtw_acl_remove_sta	core/rtw_ap.c	/^int rtw_acl_remove_sta(_adapter *adapter, const u8 *addr)$/;"	f
-rtw_acm_method	os_dep/linux/os_intfs.c	/^int rtw_acm_method = 0;\/* 0:By SW 1:By HW. *\/$/;"	v
-rtw_acs_auto_scan	os_dep/linux/os_intfs.c	/^int rtw_acs_auto_scan = 0; \/*0:disable, 1:enable*\/$/;"	v
-rtw_acs_mode	os_dep/linux/os_intfs.c	/^int rtw_acs_mode = 1; \/*0:disable, 1:enable*\/$/;"	v
-rtw_acs_start	hal/hal_com.c	/^void rtw_acs_start(_adapter *padapter, bool bStart)$/;"	f
-rtw_action_frame_parse	core/rtw_ieee80211.c	/^int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8 *category, u8 *action)$/;"	f
-rtw_action_public_decache	core/rtw_mlme_ext.c	/^s32 rtw_action_public_decache(union recv_frame *rframe, u8 token_offset)$/;"	f
-rtw_adapter_proc_deinit	os_dep/linux/rtw_proc.c	/^void rtw_adapter_proc_deinit(struct net_device *dev)$/;"	f
-rtw_adapter_proc_deinit	os_dep/linux/rtw_proc.h	60;"	d
-rtw_adapter_proc_init	os_dep/linux/rtw_proc.c	/^struct proc_dir_entry *rtw_adapter_proc_init(struct net_device *dev)$/;"	f
-rtw_adapter_proc_init	os_dep/linux/rtw_proc.h	59;"	d
-rtw_adapter_proc_open	os_dep/linux/rtw_proc.c	/^static int rtw_adapter_proc_open(struct inode *inode, struct file *file)$/;"	f	file:
-rtw_adapter_proc_replace	os_dep/linux/rtw_proc.c	/^void rtw_adapter_proc_replace(struct net_device *dev)$/;"	f
-rtw_adapter_proc_replace	os_dep/linux/rtw_proc.h	61;"	d
-rtw_adapter_proc_seq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_adapter_proc_seq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_adapter_proc_sseq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_adapter_proc_sseq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_adapter_proc_write	os_dep/linux/rtw_proc.c	/^static ssize_t rtw_adapter_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)$/;"	f	file:
-rtw_adaptivity_dc_backoff	os_dep/linux/os_intfs.c	/^uint rtw_adaptivity_dc_backoff = CONFIG_RTW_ADAPTIVITY_DC_BACKOFF;$/;"	v
-rtw_adaptivity_dml	os_dep/linux/os_intfs.c	/^uint rtw_adaptivity_dml = CONFIG_RTW_ADAPTIVITY_DML;$/;"	v
-rtw_adaptivity_en	os_dep/linux/os_intfs.c	/^uint rtw_adaptivity_en = CONFIG_RTW_ADAPTIVITY_EN;$/;"	v
-rtw_adaptivity_mode	os_dep/linux/os_intfs.c	/^uint rtw_adaptivity_mode = CONFIG_RTW_ADAPTIVITY_MODE;$/;"	v
-rtw_adaptivity_th_edcca_hl_diff	os_dep/linux/os_intfs.c	/^int rtw_adaptivity_th_edcca_hl_diff = CONFIG_RTW_ADAPTIVITY_TH_EDCCA_HL_DIFF;$/;"	v
-rtw_adaptivity_th_l2h_ini	os_dep/linux/os_intfs.c	/^int rtw_adaptivity_th_l2h_ini = CONFIG_RTW_ADAPTIVITY_TH_L2H_INI;$/;"	v
-rtw_adaptor_info_caching_file_path	os_dep/linux/os_intfs.c	/^char *rtw_adaptor_info_caching_file_path = "\/data\/misc\/wifi\/rtw_cache";$/;"	v
-rtw_add_bcn_ie	core/rtw_ap.c	/^void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len)$/;"	f
-rtw_add_beacon	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_add_beacon(_adapter *adapter, const u8 *head, size_t head_len, const u8 *tail, size_t tail_len)$/;"	f	file:
-rtw_add_network	core/rtw_mlme.c	/^void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)$/;"	f
-rtw_add_sta	os_dep/linux/ioctl_linux.c	/^static int rtw_add_sta(struct net_device *dev, struct ieee_param *param)$/;"	f	file:
-rtw_addbareq_cmd	core/rtw_cmd.c	/^u8 rtw_addbareq_cmd(_adapter *padapter, u8 tid, u8 *addr)$/;"	f
-rtw_addbarsp_cmd	core/rtw_cmd.c	/^u8 rtw_addbarsp_cmd(_adapter *padapter, u8 *addr, u16 tid, u8 status, u8 size, u16 start_seq)$/;"	f
-rtw_adhoc_tx_pwr	os_dep/linux/os_intfs.c	/^int rtw_adhoc_tx_pwr = 1;$/;"	v
-rtw_adjust_chbw	core/rtw_mlme.c	/^bool rtw_adjust_chbw(_adapter *adapter, u8 req_ch, u8 *req_bw, u8 *req_offset)$/;"	f
-rtw_aes_decrypt	core/rtw_security.c	/^u32	rtw_aes_decrypt(_adapter *padapter, u8 *precvframe)$/;"	f
-rtw_aes_encrypt	core/rtw_security.c	/^u32	rtw_aes_encrypt(_adapter *padapter, u8 *pxmitframe)$/;"	f
-rtw_alloc_bcnxmitframe	include/rtw_xmit.h	815;"	d
-rtw_alloc_bcnxmitframe	include/rtw_xmit.h	819;"	d
-rtw_alloc_bcnxmitframe	include/rtw_xmit.h	823;"	d
-rtw_alloc_bcnxmitframe	include/rtw_xmit.h	825;"	d
-rtw_alloc_cmdxmitframe	include/rtw_xmit.h	811;"	d
-rtw_alloc_etherdev	os_dep/osdep_service.c	/^struct net_device *rtw_alloc_etherdev(int sizeof_priv)$/;"	f
-rtw_alloc_etherdev_with_old_priv	os_dep/osdep_service.c	/^struct net_device *rtw_alloc_etherdev_with_old_priv(int sizeof_priv, void *old_priv)$/;"	f
-rtw_alloc_hwxmits	core/rtw_xmit.c	/^void rtw_alloc_hwxmits(_adapter *padapter)$/;"	f
-rtw_alloc_macid	core/rtw_wlan_util.c	/^void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta)$/;"	f
-rtw_alloc_network	core/rtw_mlme.c	/^struct	wlan_network *rtw_alloc_network(struct	mlme_priv *pmlmepriv) \/* (_queue	*free_queue) *\/$/;"	f
-rtw_alloc_recvframe	core/rtw_recv.c	/^union recv_frame *rtw_alloc_recvframe(_queue *pfree_recv_queue)$/;"	f
-rtw_alloc_skb_premem	core/rtw_mem.c	/^EXPORT_SYMBOL(rtw_alloc_skb_premem);$/;"	v
-rtw_alloc_skb_premem	core/rtw_mem.c	/^struct sk_buff *rtw_alloc_skb_premem(u16 in_size)$/;"	f
-rtw_alloc_stainfo	core/rtw_sta_mgt.c	/^struct	sta_info *rtw_alloc_stainfo(struct	sta_priv *pstapriv, u8 *hwaddr)$/;"	f
-rtw_alloc_xmitbuf	core/rtw_xmit.c	/^struct xmit_buf *rtw_alloc_xmitbuf(struct xmit_priv *pxmitpriv)$/;"	f
-rtw_alloc_xmitbuf_ext	core/rtw_xmit.c	/^struct xmit_buf *rtw_alloc_xmitbuf_ext(struct xmit_priv *pxmitpriv)$/;"	f
-rtw_alloc_xmitframe	core/rtw_xmit.c	/^struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)\/* (_queue *pfree_xmit_queue) *\/$/;"	f
-rtw_alloc_xmitframe_ext	core/rtw_xmit.c	/^struct xmit_frame *rtw_alloc_xmitframe_ext(struct xmit_priv *pxmitpriv)$/;"	f
-rtw_alloc_xmitframe_once	core/rtw_xmit.c	/^struct xmit_frame *rtw_alloc_xmitframe_once(struct xmit_priv *pxmitpriv)$/;"	f
-rtw_ampdu_amsdu	os_dep/linux/os_intfs.c	/^int rtw_ampdu_amsdu = 0;\/* 0: disabled, 1:enabled, 2:auto . There is an IOT issu with DLINK DIR-629 when the flag turn on *\/$/;"	v
-rtw_ampdu_enable	os_dep/linux/os_intfs.c	/^int rtw_ampdu_enable = 1;\/* for enable tx_ampdu , *\/ \/* 0: disable, 0x1:enable *\/$/;"	v
-rtw_ampdu_factor	os_dep/linux/os_intfs.c	/^int rtw_ampdu_factor = 7;$/;"	v
-rtw_amplifier_type_2g	os_dep/linux/os_intfs.c	/^uint rtw_amplifier_type_2g = CONFIG_RTW_AMPLIFIER_TYPE_2G;$/;"	v
-rtw_amplifier_type_5g	os_dep/linux/os_intfs.c	/^uint rtw_amplifier_type_5g = CONFIG_RTW_AMPLIFIER_TYPE_5G;$/;"	v
-rtw_android_cfg80211_pno_setup	os_dep/linux/rtw_android.c	/^int rtw_android_cfg80211_pno_setup(struct net_device *net,$/;"	f
-rtw_android_cmdstr_to_num	os_dep/linux/rtw_android.c	/^int rtw_android_cmdstr_to_num(char *cmdstr)$/;"	f
-rtw_android_get_link_speed	os_dep/linux/rtw_android.c	/^int rtw_android_get_link_speed(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_get_macaddr	os_dep/linux/rtw_android.c	/^int rtw_android_get_macaddr(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_get_p2p_dev_addr	os_dep/linux/rtw_android.c	/^int rtw_android_get_p2p_dev_addr(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_get_rssi	os_dep/linux/rtw_android.c	/^int rtw_android_get_rssi(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_getband	os_dep/linux/rtw_android.c	/^int rtw_android_getband(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_pno_enable	os_dep/linux/rtw_android.c	/^int rtw_android_pno_enable(struct net_device *net, int pno_enable)$/;"	f
-rtw_android_pno_setup	os_dep/linux/rtw_android.c	/^static int rtw_android_pno_setup(struct net_device *net, char *command, int total_len)$/;"	f	file:
-rtw_android_priv_cmd	os_dep/linux/rtw_android.c	/^int rtw_android_priv_cmd(struct net_device *net, struct ifreq *ifr, int cmd)$/;"	f
-rtw_android_set_block	os_dep/linux/rtw_android.c	/^int rtw_android_set_block(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_set_block_scan	os_dep/linux/rtw_android.c	/^int rtw_android_set_block_scan(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_set_country	os_dep/linux/rtw_android.c	/^int rtw_android_set_country(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_set_miracast_mode	os_dep/linux/rtw_android.c	/^int rtw_android_set_miracast_mode(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_setband	os_dep/linux/rtw_android.c	/^int rtw_android_setband(struct net_device *net, char *command, int total_len)$/;"	f
-rtw_android_wifictrl_func_add	include/rtw_android.h	/^static int rtw_android_wifictrl_func_add(void)$/;"	f
-rtw_android_wifictrl_func_add	os_dep/linux/rtw_android.c	/^int rtw_android_wifictrl_func_add(void)$/;"	f
-rtw_android_wifictrl_func_del	include/rtw_android.h	/^static void rtw_android_wifictrl_func_del(void) {}$/;"	f
-rtw_android_wifictrl_func_del	os_dep/linux/rtw_android.c	/^void rtw_android_wifictrl_func_del(void)$/;"	f
-rtw_ant_num	os_dep/linux/os_intfs.c	/^int rtw_ant_num = 0;$/;"	v
-rtw_antdiv_cfg	os_dep/linux/os_intfs.c	/^int rtw_antdiv_cfg = 2; \/* 0:OFF , 1:ON, 2:decide by Efuse config *\/$/;"	v
-rtw_antdiv_type	os_dep/linux/os_intfs.c	/^int rtw_antdiv_type = 0$/;"	v
-rtw_antenna_select_cmd	core/rtw_cmd.c	/^u8 rtw_antenna_select_cmd(_adapter *padapter, u8 antenna, u8 enqueue)$/;"	f
-rtw_ap_bmc_frames_hdl	core/rtw_ap.c	/^u8 rtw_ap_bmc_frames_hdl(_adapter *padapter)$/;"	f
-rtw_ap_chbw_decision	core/rtw_ap.c	/^bool rtw_ap_chbw_decision(_adapter *adapter, s16 req_ch, s8 req_bw, s8 req_offset$/;"	f
-rtw_ap_check_scan	core/rtw_ap.c	/^static void rtw_ap_check_scan(_adapter *padapter)$/;"	f	file:
-rtw_ap_inform_ch_switch	core/rtw_ap.c	/^int rtw_ap_inform_ch_switch(_adapter *padapter, u8 new_ch, u8 ch_offset)$/;"	f
-rtw_ap_restore_network	core/rtw_ap.c	/^void rtw_ap_restore_network(_adapter *padapter)$/;"	f
-rtw_ap_set_group_key	core/rtw_ap.c	/^int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid)$/;"	f
-rtw_ap_set_key	core/rtw_ap.c	/^static int rtw_ap_set_key(_adapter *padapter, u8 *key, u8 alg, int keyid, u8 set_tx)$/;"	f	file:
-rtw_ap_set_pairwise_key	core/rtw_ap.c	/^u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta)$/;"	f
-rtw_ap_set_wep_key	core/rtw_ap.c	/^int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx)$/;"	f
-rtw_ap_update_bss_chbw	core/rtw_ap.c	/^void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_ap_wep_pk_setting	core/rtw_mlme_ext.c	/^void rtw_ap_wep_pk_setting(_adapter *adapter, struct sta_info *psta)$/;"	f
-rtw_ap_wowlan_ctrl	os_dep/linux/ioctl_linux.c	/^static int rtw_ap_wowlan_ctrl(struct net_device *dev,$/;"	f	file:
-rtw_append_assoc_req_wfd_ie	core/rtw_p2p.c	/^u32 rtw_append_assoc_req_wfd_ie(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_append_assoc_resp_wfd_ie	core/rtw_p2p.c	/^u32 rtw_append_assoc_resp_wfd_ie(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_append_beacon_wfd_ie	core/rtw_p2p.c	/^u32 rtw_append_beacon_wfd_ie(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_append_exented_cap	core/rtw_mlme.c	/^void rtw_append_exented_cap(_adapter *padapter, u8 *out_ie, uint *pout_len)$/;"	f
-rtw_append_pmkid	core/rtw_mlme.c	/^static int rtw_append_pmkid(_adapter *adapter, int iEntry, u8 *ie, uint ie_len)$/;"	f	file:
-rtw_append_probe_req_wfd_ie	core/rtw_p2p.c	/^u32 rtw_append_probe_req_wfd_ie(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_append_probe_resp_wfd_ie	core/rtw_p2p.c	/^u32 rtw_append_probe_resp_wfd_ie(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_assign_roam_flags	include/rtw_mlme.h	1137;"	d
-rtw_assign_roam_flags	include/rtw_mlme.h	1153;"	d
-rtw_atimdone_event_callback	core/rtw_mlme.c	/^void rtw_atimdone_event_callback(_adapter	*adapter , u8 *pbuf)$/;"	f
-rtw_atoi	os_dep/osdep_service.c	/^u32 rtw_atoi(u8 *s)$/;"	f
-rtw_auto_ap_start_beacon	core/rtw_mlme_ext.c	/^static int rtw_auto_ap_start_beacon(_adapter *adapter)$/;"	f	file:
-rtw_auto_scan_handler	core/rtw_mlme.c	/^static void rtw_auto_scan_handler(_adapter *padapter)$/;"	f	file:
-rtw_band_valid	include/rtw_mlme.h	168;"	d
-rtw_basic_rate_cck	core/rtw_wlan_util.c	/^static u8 rtw_basic_rate_cck[4] = {$/;"	v	file:
-rtw_basic_rate_mix	core/rtw_wlan_util.c	/^static u8 rtw_basic_rate_mix[7] = {$/;"	v	file:
-rtw_basic_rate_ofdm	core/rtw_wlan_util.c	/^static u8 rtw_basic_rate_ofdm[3] = {$/;"	v	file:
-rtw_bb_rf_gain_offset	hal/hal_com.c	/^void rtw_bb_rf_gain_offset(_adapter *padapter)$/;"	f
-rtw_beamform_cap	os_dep/linux/os_intfs.c	/^int rtw_beamform_cap = BIT(1) | BIT(3);$/;"	v
-rtw_bfee_rf_number	os_dep/linux/os_intfs.c	/^int rtw_bfee_rf_number = 0; \/*BeamformeeCapRfNum  Rf path number, 0 for auto, others for manual*\/$/;"	v
-rtw_bfer_rf_number	os_dep/linux/os_intfs.c	/^int rtw_bfer_rf_number = 0; \/*BeamformerCapRfNum Rf path number, 0 for auto, others for manual*\/$/;"	v
-rtw_br_client_tx	core/rtw_xmit.c	/^int rtw_br_client_tx(_adapter *padapter, struct sk_buff **pskb)$/;"	f
-rtw_bridge_tunnel_header	include/rtw_recv.h	/^static u8 rtw_bridge_tunnel_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8 };$/;"	v
-rtw_bss_ex_del_p2p_attr	core/rtw_ieee80211.c	/^void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)$/;"	f
-rtw_bss_ex_del_p2p_ie	core/rtw_ieee80211.c	/^void rtw_bss_ex_del_p2p_ie(WLAN_BSSID_EX *bss_ex)$/;"	f
-rtw_bss_ex_del_wfd_attr	core/rtw_ieee80211.c	/^void rtw_bss_ex_del_wfd_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)$/;"	f
-rtw_bss_ex_del_wfd_ie	core/rtw_ieee80211.c	/^void rtw_bss_ex_del_wfd_ie(WLAN_BSSID_EX *bss_ex)$/;"	f
-rtw_bss_ex_get_p2p_ie	core/rtw_ieee80211.c	/^inline u8 *rtw_bss_ex_get_p2p_ie(WLAN_BSSID_EX *bss_ex, u8 *p2p_ie, uint *p2p_ielen)$/;"	f
-rtw_bss_ex_get_wfd_ie	core/rtw_ieee80211.c	/^inline u8 *rtw_bss_ex_get_wfd_ie(WLAN_BSSID_EX *bss_ex, u8 *wfd_ie, uint *wfd_ielen)$/;"	f
-rtw_bss_get_chbw	core/rtw_ieee80211.c	/^void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset)$/;"	f
-rtw_bt_ampdu	os_dep/linux/os_intfs.c	/^int rtw_bt_ampdu = 1 ; \/* 0:Disable BT control A-MPDU, 1:Enable BT control A-MPDU. *\/$/;"	v
-rtw_bt_iso	os_dep/linux/os_intfs.c	/^int rtw_bt_iso = 2;\/* 0:Low, 1:High, 2:From Efuse *\/$/;"	v
-rtw_bt_sco	os_dep/linux/os_intfs.c	/^int rtw_bt_sco = 3;\/* 0:Idle, 1:None-SCO, 2:SCO, 3:From Counter, 4.Busy, 5.OtherBusy *\/$/;"	v
-rtw_btcoex_1Ant	core/rtw_btcoex.c	/^u8 rtw_btcoex_1Ant(PADAPTER padapter)$/;"	f
-rtw_btcoex_BTOffOnNotify	core/rtw_btcoex.c	/^void rtw_btcoex_BTOffOnNotify(PADAPTER padapter, u8 bBTON)$/;"	f
-rtw_btcoex_BtInfoNotify	core/rtw_btcoex.c	/^void rtw_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)$/;"	f
-rtw_btcoex_BtMpRptNotify	core/rtw_btcoex.c	/^void rtw_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)$/;"	f
-rtw_btcoex_ConnectNotify	core/rtw_btcoex.c	/^void rtw_btcoex_ConnectNotify(PADAPTER padapter, u8 action)$/;"	f
-rtw_btcoex_DisplayBtCoexInfo	core/rtw_btcoex.c	/^void rtw_btcoex_DisplayBtCoexInfo(PADAPTER padapter, u8 *pbuf, u32 bufsize)$/;"	f
-rtw_btcoex_GetAMPDUSize	core/rtw_btcoex.c	/^u32 rtw_btcoex_GetAMPDUSize(PADAPTER padapter)$/;"	f
-rtw_btcoex_GetDBG	core/rtw_btcoex.c	/^u32 rtw_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)$/;"	f
-rtw_btcoex_GetRaMask	core/rtw_btcoex.c	/^u32 rtw_btcoex_GetRaMask(PADAPTER padapter)$/;"	f
-rtw_btcoex_HAL_Initialize	core/rtw_btcoex.c	/^void rtw_btcoex_HAL_Initialize(PADAPTER padapter, u8 bWifiOnly)$/;"	f
-rtw_btcoex_HaltNotify	core/rtw_btcoex.c	/^void rtw_btcoex_HaltNotify(PADAPTER padapter)$/;"	f
-rtw_btcoex_Handler	core/rtw_btcoex.c	/^void rtw_btcoex_Handler(PADAPTER padapter)$/;"	f
-rtw_btcoex_IQKNotify	core/rtw_btcoex.c	/^void rtw_btcoex_IQKNotify(PADAPTER padapter, u8 state)$/;"	f
-rtw_btcoex_IncreaseScanDeviceNum	core/rtw_btcoex.c	/^u8 rtw_btcoex_IncreaseScanDeviceNum(PADAPTER padapter)$/;"	f
-rtw_btcoex_Initialize	core/rtw_btcoex.c	/^void rtw_btcoex_Initialize(PADAPTER padapter)$/;"	f
-rtw_btcoex_IpsNotify	core/rtw_btcoex.c	/^void rtw_btcoex_IpsNotify(PADAPTER padapter, u8 type)$/;"	f
-rtw_btcoex_IsBTCoexCtrlAMPDUSize	core/rtw_btcoex.c	/^s32 rtw_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER padapter)$/;"	f
-rtw_btcoex_IsBTCoexRejectAMPDU	core/rtw_btcoex.c	/^s32 rtw_btcoex_IsBTCoexRejectAMPDU(PADAPTER padapter)$/;"	f
-rtw_btcoex_IsBtControlLps	core/rtw_btcoex.c	/^u8 rtw_btcoex_IsBtControlLps(PADAPTER padapter)$/;"	f
-rtw_btcoex_IsBtDisabled	core/rtw_btcoex.c	/^u8 rtw_btcoex_IsBtDisabled(PADAPTER padapter)$/;"	f
-rtw_btcoex_IsBtLinkExist	core/rtw_btcoex.c	/^u8 rtw_btcoex_IsBtLinkExist(PADAPTER padapter)$/;"	f
-rtw_btcoex_IsLpsOn	core/rtw_btcoex.c	/^u8 rtw_btcoex_IsLpsOn(PADAPTER padapter)$/;"	f
-rtw_btcoex_LPS_Enter	core/rtw_btcoex.c	/^void rtw_btcoex_LPS_Enter(PADAPTER padapter)$/;"	f
-rtw_btcoex_LPS_Leave	core/rtw_btcoex.c	/^void rtw_btcoex_LPS_Leave(PADAPTER padapter)$/;"	f
-rtw_btcoex_LpsNotify	core/rtw_btcoex.c	/^void rtw_btcoex_LpsNotify(PADAPTER padapter, u8 type)$/;"	f
-rtw_btcoex_LpsVal	core/rtw_btcoex.c	/^u8 rtw_btcoex_LpsVal(PADAPTER padapter)$/;"	f
-rtw_btcoex_MediaStatusNotify	core/rtw_btcoex.c	/^void rtw_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus)$/;"	f
-rtw_btcoex_PowerOnSetting	core/rtw_btcoex.c	/^void rtw_btcoex_PowerOnSetting(PADAPTER padapter)$/;"	f
-rtw_btcoex_PreLoadFirmware	core/rtw_btcoex.c	/^void rtw_btcoex_PreLoadFirmware(PADAPTER padapter)$/;"	f
-rtw_btcoex_RecordPwrMode	core/rtw_btcoex.c	/^void rtw_btcoex_RecordPwrMode(PADAPTER padapter, u8 *pCmdBuf, u8 cmdLen)$/;"	f
-rtw_btcoex_RpwmVal	core/rtw_btcoex.c	/^u8 rtw_btcoex_RpwmVal(PADAPTER padapter)$/;"	f
-rtw_btcoex_ScanNotify	core/rtw_btcoex.c	/^void rtw_btcoex_ScanNotify(PADAPTER padapter, u8 type)$/;"	f
-rtw_btcoex_SendEventExtBtCoexControl	core/rtw_btcoex.c	/^void rtw_btcoex_SendEventExtBtCoexControl(PADAPTER padapter, u8 bNeedDbgRsp, u8 dataLen, void *pData)$/;"	f
-rtw_btcoex_SendEventExtBtInfoControl	core/rtw_btcoex.c	/^void rtw_btcoex_SendEventExtBtInfoControl(PADAPTER padapter, u8 dataLen, void *pData)$/;"	f
-rtw_btcoex_SendScanNotify	core/rtw_btcoex.c	/^void rtw_btcoex_SendScanNotify(PADAPTER padapter, u8 scanType)$/;"	f
-rtw_btcoex_SetBtPatchVersion	core/rtw_btcoex.c	/^void rtw_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer)$/;"	f
-rtw_btcoex_SetDBG	core/rtw_btcoex.c	/^void rtw_btcoex_SetDBG(PADAPTER padapter, u32 *pDbgModule)$/;"	f
-rtw_btcoex_SetHciVersion	core/rtw_btcoex.c	/^void rtw_btcoex_SetHciVersion(PADAPTER  padapter, u16 hciVersion)$/;"	f
-rtw_btcoex_SetManualControl	core/rtw_btcoex.c	/^void rtw_btcoex_SetManualControl(PADAPTER padapter, u8 manual)$/;"	f
-rtw_btcoex_SpecialPacketNotify	core/rtw_btcoex.c	/^void rtw_btcoex_SpecialPacketNotify(PADAPTER padapter, u8 pktType)$/;"	f
-rtw_btcoex_StackUpdateProfileInfo	core/rtw_btcoex.c	/^void rtw_btcoex_StackUpdateProfileInfo(void)$/;"	f
-rtw_btcoex_SuspendNotify	core/rtw_btcoex.c	/^void rtw_btcoex_SuspendNotify(PADAPTER padapter, u8 state)$/;"	f
-rtw_btcoex_Switch	core/rtw_btcoex.c	/^void rtw_btcoex_Switch(PADAPTER padapter, u8 enable)$/;"	f
-rtw_btcoex_SwitchBtTRxMask	core/rtw_btcoex.c	/^void rtw_btcoex_SwitchBtTRxMask(PADAPTER padapter)$/;"	f
-rtw_btcoex_btinfo_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)$/;"	f
-rtw_btcoex_btreg_read	core/rtw_btcoex.c	/^u16 rtw_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data)$/;"	f
-rtw_btcoex_btreg_write	core/rtw_btcoex.c	/^u16 rtw_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val)$/;"	f
-rtw_btcoex_close_kernel_socket	core/rtw_btcoex.c	/^void rtw_btcoex_close_kernel_socket(_adapter *padapter)$/;"	f
-rtw_btcoex_close_socket	core/rtw_btcoex.c	/^void rtw_btcoex_close_socket(_adapter *padapter)$/;"	f
-rtw_btcoex_create_kernel_socket	core/rtw_btcoex.c	/^u8 rtw_btcoex_create_kernel_socket(_adapter *padapter)$/;"	f
-rtw_btcoex_dump_tx_msg	core/rtw_btcoex.c	/^void rtw_btcoex_dump_tx_msg(u8 *tx_msg, u8 len, u8 *msg_name)$/;"	f
-rtw_btcoex_enable	os_dep/linux/os_intfs.c	/^int rtw_btcoex_enable = 2;$/;"	v
-rtw_btcoex_get_ant_div_cfg	core/rtw_btcoex.c	/^u8 rtw_btcoex_get_ant_div_cfg(PADAPTER padapter)$/;"	f
-rtw_btcoex_get_bt_coexist	core/rtw_btcoex.c	/^u8 rtw_btcoex_get_bt_coexist(PADAPTER padapter)$/;"	f
-rtw_btcoex_get_chip_type	core/rtw_btcoex.c	/^u8 rtw_btcoex_get_chip_type(PADAPTER padapter)$/;"	f
-rtw_btcoex_get_pg_ant_num	core/rtw_btcoex.c	/^u8 rtw_btcoex_get_pg_ant_num(PADAPTER padapter)$/;"	f
-rtw_btcoex_get_pg_rfe_type	core/rtw_btcoex.c	/^u8 rtw_btcoex_get_pg_rfe_type(PADAPTER padapter)$/;"	f
-rtw_btcoex_get_pg_single_ant_path	core/rtw_btcoex.c	/^u8 rtw_btcoex_get_pg_single_ant_path(PADAPTER padapter)$/;"	f
-rtw_btcoex_init_socket	core/rtw_btcoex.c	/^void rtw_btcoex_init_socket(_adapter *padapter)$/;"	f
-rtw_btcoex_is_tfbga_package_type	core/rtw_btcoex.c	/^u8 rtw_btcoex_is_tfbga_package_type(PADAPTER padapter)$/;"	f
-rtw_btcoex_parse_BT_AFH_MAP_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_BT_AFH_MAP_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_BT_info_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_BT_info_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_BT_patch_ver_info_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_BT_patch_ver_info_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_BT_register_val_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_BT_register_val_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_HCI_BT_abnormal_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_HCI_BT_abnormal_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_HCI_BT_coex_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_HCI_BT_coex_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_HCI_BT_operation_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_HCI_BT_operation_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_HCI_Ver_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_HCI_Ver_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_HCI_link_status_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_HCI_link_status_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_HCI_query_RF_status_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_HCI_query_RF_status_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_WIFI_scan_notify_cmd	core/rtw_btcoex.c	/^u8 rtw_btcoex_parse_WIFI_scan_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)$/;"	f
-rtw_btcoex_parse_hci_cmd	core/rtw_btcoex.c	/^void rtw_btcoex_parse_hci_cmd(_adapter *padapter, u8 *pcmd, u16 len)$/;"	f
-rtw_btcoex_parse_hci_extend_cmd	core/rtw_btcoex.c	/^void rtw_btcoex_parse_hci_extend_cmd(_adapter *padapter, u8 *pcmd, u16 len, const u16 hci_OCF)$/;"	f
-rtw_btcoex_parse_recv_data	core/rtw_btcoex.c	/^u16 rtw_btcoex_parse_recv_data(u8 *msg, u8 msg_size)$/;"	f
-rtw_btcoex_recvmsg_init	core/rtw_btcoex.c	/^	void rtw_btcoex_recvmsg_init(struct sock *sk_in, s32 bytes)$/;"	f
-rtw_btcoex_recvmsgbysocket	core/rtw_btcoex.c	/^void rtw_btcoex_recvmsgbysocket(void *data)$/;"	f
-rtw_btcoex_rx_ampdu_apply	core/rtw_btcoex.c	/^void rtw_btcoex_rx_ampdu_apply(PADAPTER padapter)$/;"	f
-rtw_btcoex_send_event_to_BT	core/rtw_btcoex.c	/^u8 rtw_btcoex_send_event_to_BT(_adapter *padapter, u8 status,  u8 event_code, u8 opcode_low, u8 opcode_high, u8 *dbg_msg)$/;"	f
-rtw_btcoex_sendmsgbysocket	core/rtw_btcoex.c	/^u8 rtw_btcoex_sendmsgbysocket(_adapter *padapter, u8 *msg, u8 msg_size, bool force)$/;"	f
-rtw_btcoex_switchband_notify	core/rtw_btcoex.c	/^void rtw_btcoex_switchband_notify(u8 under_scan, u8 band_type)$/;"	f
-rtw_btinfo_cmd	core/rtw_cmd.c	/^u8 rtw_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)$/;"	f
-rtw_btinfo_hdl	core/rtw_cmd.c	/^static void rtw_btinfo_hdl(_adapter *adapter, u8 *buf, u16 buf_len)$/;"	f	file:
-rtw_buf_free	os_dep/osdep_service.c	/^void rtw_buf_free(u8 **buf, u32 *buf_len)$/;"	f
-rtw_buf_update	os_dep/osdep_service.c	/^void rtw_buf_update(u8 **buf, u32 *buf_len, u8 *src, u32 src_len)$/;"	f
-rtw_bug_check	include/osdep_service.h	/^__inline static int rtw_bug_check(void *parg1, void *parg2, void *parg3, void *parg4)$/;"	f
-rtw_build_assoc_req_wapi_ie	core/rtw_wapi.c	/^void rtw_build_assoc_req_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_build_beacon_wapi_ie	core/rtw_wapi.c	/^void rtw_build_beacon_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_build_probe_resp_wapi_ie	core/rtw_wapi.c	/^void rtw_build_probe_resp_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_build_tdls_ch_switch_req_ies	core/rtw_tdls.c	/^void rtw_build_tdls_ch_switch_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_ch_switch_rsp_ies	core/rtw_tdls.c	/^void rtw_build_tdls_ch_switch_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_dis_req_ies	core/rtw_tdls.c	/^void rtw_build_tdls_dis_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_dis_rsp_ies	core/rtw_tdls.c	/^void rtw_build_tdls_dis_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, u8 privacy)$/;"	f
-rtw_build_tdls_ies	core/rtw_xmit.c	/^int rtw_build_tdls_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_peer_traffic_indication_ies	core/rtw_tdls.c	/^void rtw_build_tdls_peer_traffic_indication_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_peer_traffic_rsp_ies	core/rtw_tdls.c	/^void rtw_build_tdls_peer_traffic_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_setup_cfm_ies	core/rtw_tdls.c	/^void rtw_build_tdls_setup_cfm_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_setup_req_ies	core/rtw_tdls.c	/^void rtw_build_tdls_setup_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_setup_rsp_ies	core/rtw_tdls.c	/^void rtw_build_tdls_setup_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tdls_teardown_ies	core/rtw_tdls.c	/^void rtw_build_tdls_teardown_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_build_tunneled_probe_req_ies	core/rtw_tdls.c	/^void rtw_build_tunneled_probe_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe)$/;"	f
-rtw_build_tunneled_probe_rsp_ies	core/rtw_tdls.c	/^void rtw_build_tunneled_probe_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe)$/;"	f
-rtw_build_vendor_ie	core/rtw_mlme_ext.c	/^u32 rtw_build_vendor_ie(_adapter *padapter , unsigned char *pframe , u8 mgmt_frame_tyte)$/;"	f
-rtw_build_vht_cap_ie	core/rtw_vht.c	/^u32	rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)$/;"	f
-rtw_build_vht_op_mode_notify_ie	core/rtw_vht.c	/^u32	rtw_build_vht_op_mode_notify_ie(_adapter *padapter, u8 *pbuf, u8 bw)$/;"	f
-rtw_build_vht_operation_ie	core/rtw_vht.c	/^u32	rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel)$/;"	f
-rtw_build_wmm_ie_ht	core/rtw_mlme.c	/^void rtw_build_wmm_ie_ht(_adapter *padapter, u8 *out_ie, uint *pout_len)$/;"	f
-rtw_busy_thresh	os_dep/linux/os_intfs.c	/^int rtw_busy_thresh = 40;$/;"	v
-rtw_bw_mode	os_dep/linux/os_intfs.c	/^int rtw_bw_mode = 0x21;$/;"	v
-rtw_c2h_event	include/rtw_mlme_ext.h	/^enum rtw_c2h_event {$/;"	g
-rtw_c2h_packet_wk_cmd	core/rtw_cmd.c	/^inline u8 rtw_c2h_packet_wk_cmd(_adapter *adapter, u8 *c2h_evt, u16 length)$/;"	f
-rtw_c2h_reg_wk_cmd	core/rtw_cmd.c	/^inline u8 rtw_c2h_reg_wk_cmd(_adapter *adapter, u8 *c2h_evt)$/;"	f
-rtw_c2h_wk_cmd	core/rtw_cmd.c	/^u8 rtw_c2h_wk_cmd(PADAPTER padapter, u8 *pbuf, u16 length, u8 type)$/;"	f
-rtw_cal_crc16	core/rtw_security.c	/^u16 rtw_cal_crc16(u8 data, u16 crc)$/;"	f
-rtw_calc_crc	core/rtw_security.c	/^u16 rtw_calc_crc(u8  *pdata, int length)$/;"	f
-rtw_calculate_wlan_pkt_size_by_attribue	core/rtw_xmit.c	/^u32 rtw_calculate_wlan_pkt_size_by_attribue(struct pkt_attrib *pattrib)$/;"	f
-rtw_camctl_clr_flags	core/rtw_wlan_util.c	/^inline void rtw_camctl_clr_flags(_adapter *adapter, u32 flags)$/;"	f
-rtw_camctl_set_flags	core/rtw_wlan_util.c	/^inline void rtw_camctl_set_flags(_adapter *adapter, u32 flags)$/;"	f
-rtw_camid_alloc	core/rtw_wlan_util.c	/^s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, bool *used)$/;"	f
-rtw_camid_free	core/rtw_wlan_util.c	/^void rtw_camid_free(_adapter *adapter, u8 cam_id)$/;"	f
-rtw_camid_is_gk	core/rtw_wlan_util.c	/^inline bool rtw_camid_is_gk(_adapter *adapter, u8 cam_id)$/;"	f
-rtw_camid_search	core/rtw_wlan_util.c	/^s16 rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk)$/;"	f
-rtw_camid_set	core/rtw_wlan_util.c	/^void rtw_camid_set(_adapter *adapter, u8 cam_id)$/;"	f
-rtw_cancel_all_timer	os_dep/linux/os_intfs.c	/^void rtw_cancel_all_timer(_adapter *padapter)$/;"	f
-rtw_cancel_dynamic_chk_timer	os_dep/linux/os_intfs.c	/^void rtw_cancel_dynamic_chk_timer(_adapter *padapter)$/;"	f
-rtw_cbuf	include/osdep_service.h	/^struct rtw_cbuf {$/;"	s
-rtw_cbuf_alloc	os_dep/osdep_service.c	/^struct rtw_cbuf *rtw_cbuf_alloc(u32 size)$/;"	f
-rtw_cbuf_empty	os_dep/osdep_service.c	/^inline bool rtw_cbuf_empty(struct rtw_cbuf *cbuf)$/;"	f
-rtw_cbuf_free	os_dep/osdep_service.c	/^void rtw_cbuf_free(struct rtw_cbuf *cbuf)$/;"	f
-rtw_cbuf_full	os_dep/osdep_service.c	/^inline bool rtw_cbuf_full(struct rtw_cbuf *cbuf)$/;"	f
-rtw_cbuf_pop	os_dep/osdep_service.c	/^void *rtw_cbuf_pop(struct rtw_cbuf *cbuf)$/;"	f
-rtw_cbuf_push	os_dep/osdep_service.c	/^bool rtw_cbuf_push(struct rtw_cbuf *cbuf, void *buf)$/;"	f
-rtw_cfg80211_add_monitor_if	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_add_monitor_if(_adapter *padapter, char *name, struct net_device **ndev)$/;"	f	file:
-rtw_cfg80211_adjust_p2pie_channel	core/rtw_p2p.c	/^static void rtw_cfg80211_adjust_p2pie_channel(_adapter *padapter, const u8 *frame_body, u32 len)$/;"	f	file:
-rtw_cfg80211_ap_set_encryption	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)$/;"	f	file:
-rtw_cfg80211_check_bss	os_dep/linux/ioctl_cfg80211.c	/^int rtw_cfg80211_check_bss(_adapter *padapter)$/;"	f
-rtw_cfg80211_clear_wps_sr_of_non_target_bss	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_clear_wps_sr_of_non_target_bss(_adapter *padapter, struct wlan_network *pnetwork, struct cfg80211_ssid *req_ssid)$/;"	f	file:
-rtw_cfg80211_default_mgmt_stypes	os_dep/linux/ioctl_cfg80211.c	/^	rtw_cfg80211_default_mgmt_stypes[NUM_NL80211_IFTYPES] = {$/;"	v	typeref:struct:ieee80211_txrx_stypes	file:
-rtw_cfg80211_dev_res_alloc	os_dep/linux/ioctl_cfg80211.c	/^int rtw_cfg80211_dev_res_alloc(struct dvobj_priv *dvobj)$/;"	f
-rtw_cfg80211_dev_res_free	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_dev_res_free(struct dvobj_priv *dvobj)$/;"	f
-rtw_cfg80211_dev_res_register	os_dep/linux/ioctl_cfg80211.c	/^int rtw_cfg80211_dev_res_register(struct dvobj_priv *dvobj)$/;"	f
-rtw_cfg80211_dev_res_unregister	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_dev_res_unregister(struct dvobj_priv *dvobj)$/;"	f
-rtw_cfg80211_ft_event	os_dep/linux/ioctl_cfg80211.h	306;"	d
-rtw_cfg80211_get_is_mgmt_tx	os_dep/linux/ioctl_cfg80211.c	/^inline u8 rtw_cfg80211_get_is_mgmt_tx(_adapter *adapter)$/;"	f
-rtw_cfg80211_get_is_roch	os_dep/linux/ioctl_cfg80211.c	/^inline bool rtw_cfg80211_get_is_roch(_adapter *adapter)$/;"	f
-rtw_cfg80211_ibss_indicate_connect	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_ibss_indicate_connect(_adapter *padapter)$/;"	f
-rtw_cfg80211_iface_has_p2p_group_cap	os_dep/linux/ioctl_cfg80211.c	/^inline int rtw_cfg80211_iface_has_p2p_group_cap(_adapter *adapter)$/;"	f
-rtw_cfg80211_indicate_connect	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_indicate_connect(_adapter *padapter)$/;"	f
-rtw_cfg80211_indicate_disconnect	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)$/;"	f
-rtw_cfg80211_indicate_scan_done	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_indicate_scan_done(_adapter *adapter, bool aborted)$/;"	f
-rtw_cfg80211_indicate_scan_done_for_buddy	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_indicate_scan_done_for_buddy(_adapter *padapter, bool bscan_aborted)$/;"	f
-rtw_cfg80211_indicate_sta_assoc	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_indicate_sta_assoc(_adapter *padapter, u8 *pmgmt_frame, uint frame_len)$/;"	f
-rtw_cfg80211_indicate_sta_disassoc	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_indicate_sta_disassoc(_adapter *padapter, unsigned char *da, unsigned short reason)$/;"	f
-rtw_cfg80211_inform_bss	os_dep/linux/ioctl_cfg80211.c	/^struct cfg80211_bss *rtw_cfg80211_inform_bss(_adapter *padapter, struct wlan_network *pnetwork)$/;"	f
-rtw_cfg80211_init_ht_capab	os_dep/linux/ioctl_cfg80211.c	/^static void rtw_cfg80211_init_ht_capab(_adapter *padapter, struct ieee80211_sta_ht_cap *ht_cap, enum ieee80211_band band, u8 rf_type)$/;"	f	file:
-rtw_cfg80211_init_ht_capab_ex	os_dep/linux/ioctl_cfg80211.c	/^static void rtw_cfg80211_init_ht_capab_ex(_adapter *padapter, struct ieee80211_sta_ht_cap *ht_cap, enum ieee80211_band band, u8 rf_type)$/;"	f	file:
-rtw_cfg80211_init_wdev_data	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_init_wdev_data(_adapter *padapter)$/;"	f
-rtw_cfg80211_init_wiphy	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_init_wiphy(_adapter *padapter)$/;"	f
-rtw_cfg80211_is_p2p_scan	os_dep/linux/ioctl_cfg80211.c	/^inline int rtw_cfg80211_is_p2p_scan(_adapter *adapter)$/;"	f
-rtw_cfg80211_is_scan_by_pd_wdev	os_dep/linux/ioctl_cfg80211.c	/^inline int rtw_cfg80211_is_scan_by_pd_wdev(_adapter *adapter)$/;"	f
-rtw_cfg80211_is_target_wps_scan	os_dep/linux/ioctl_cfg80211.c	/^int rtw_cfg80211_is_target_wps_scan(struct cfg80211_scan_request *scan_req, struct cfg80211_ssid *target_ssid)$/;"	f
-rtw_cfg80211_issue_p2p_provision_request	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_issue_p2p_provision_request(_adapter *padapter, const u8 *buf, size_t len)$/;"	f
-rtw_cfg80211_mgmt_tx_status	os_dep/linux/ioctl_cfg80211.h	288;"	d
-rtw_cfg80211_mgmt_tx_status	os_dep/linux/ioctl_cfg80211.h	290;"	d
-rtw_cfg80211_monitor_if_close	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_monitor_if_close(struct net_device *ndev)$/;"	f	file:
-rtw_cfg80211_monitor_if_open	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_monitor_if_open(struct net_device *ndev)$/;"	f	file:
-rtw_cfg80211_monitor_if_ops	os_dep/linux/ioctl_cfg80211.c	/^static const struct net_device_ops rtw_cfg80211_monitor_if_ops = {$/;"	v	typeref:struct:net_device_ops	file:
-rtw_cfg80211_monitor_if_set_mac_address	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_monitor_if_set_mac_address(struct net_device *ndev, void *addr)$/;"	f	file:
-rtw_cfg80211_monitor_if_set_multicast_list	os_dep/linux/ioctl_cfg80211.c	/^static void rtw_cfg80211_monitor_if_set_multicast_list(struct net_device *ndev)$/;"	f	file:
-rtw_cfg80211_monitor_if_xmit_entry	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_monitor_if_xmit_entry(struct sk_buff *skb, struct net_device *ndev)$/;"	f	file:
-rtw_cfg80211_ndev_res_alloc	os_dep/linux/ioctl_cfg80211.c	/^int rtw_cfg80211_ndev_res_alloc(_adapter *adapter)$/;"	f
-rtw_cfg80211_ndev_res_free	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_ndev_res_free(_adapter *adapter)$/;"	f
-rtw_cfg80211_ndev_res_register	os_dep/linux/ioctl_cfg80211.c	/^int rtw_cfg80211_ndev_res_register(_adapter *adapter)$/;"	f
-rtw_cfg80211_ndev_res_unregister	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_ndev_res_unregister(_adapter *adapter)$/;"	f
-rtw_cfg80211_ops	os_dep/linux/ioctl_cfg80211.c	/^static struct cfg80211_ops rtw_cfg80211_ops = {$/;"	v	typeref:struct:cfg80211_ops	file:
-rtw_cfg80211_preinit_wiphy	os_dep/linux/ioctl_cfg80211.c	/^static void rtw_cfg80211_preinit_wiphy(_adapter *adapter, struct wiphy *wiphy)$/;"	f	file:
-rtw_cfg80211_pwr_mgmt	os_dep/linux/ioctl_cfg80211.c	/^inline bool rtw_cfg80211_pwr_mgmt(_adapter *adapter)$/;"	f
-rtw_cfg80211_ready_on_channel	os_dep/linux/ioctl_cfg80211.h	294;"	d
-rtw_cfg80211_ready_on_channel	os_dep/linux/ioctl_cfg80211.h	297;"	d
-rtw_cfg80211_ready_on_channel	os_dep/linux/ioctl_cfg80211.h	300;"	d
-rtw_cfg80211_redirect_pd_wdev	os_dep/linux/ioctl_cfg80211.c	/^inline int rtw_cfg80211_redirect_pd_wdev(struct wiphy *wiphy, u8 *ra, struct wireless_dev **wdev)$/;"	f
-rtw_cfg80211_remain_on_channel_expired	os_dep/linux/ioctl_cfg80211.h	295;"	d
-rtw_cfg80211_remain_on_channel_expired	os_dep/linux/ioctl_cfg80211.h	298;"	d
-rtw_cfg80211_remain_on_channel_expired	os_dep/linux/ioctl_cfg80211.h	301;"	d
-rtw_cfg80211_rx_action	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_rx_action(_adapter *adapter, union recv_frame *rframe, const char *msg)$/;"	f
-rtw_cfg80211_rx_action_p2p	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_rx_action_p2p(_adapter *adapter, union recv_frame *rframe)$/;"	f
-rtw_cfg80211_rx_mgmt	os_dep/linux/ioctl_cfg80211.h	270;"	d
-rtw_cfg80211_rx_mgmt	os_dep/linux/ioctl_cfg80211.h	272;"	d
-rtw_cfg80211_rx_mgmt	os_dep/linux/ioctl_cfg80211.h	274;"	d
-rtw_cfg80211_rx_mgmt	os_dep/linux/ioctl_cfg80211.h	276;"	d
-rtw_cfg80211_rx_mgmt	os_dep/linux/ioctl_cfg80211.h	278;"	d
-rtw_cfg80211_rx_p2p_action_public	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_rx_p2p_action_public(_adapter *adapter, union recv_frame *rframe)$/;"	f
-rtw_cfg80211_rx_probe_request	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_rx_probe_request(_adapter *adapter, union recv_frame *rframe)$/;"	f
-rtw_cfg80211_scan_via_buddy	os_dep/linux/ioctl_cfg80211.c	/^u8 rtw_cfg80211_scan_via_buddy(_adapter *padapter, struct cfg80211_scan_request *request)$/;"	f
-rtw_cfg80211_send_rx_assoc	os_dep/linux/ioctl_cfg80211.h	282;"	d
-rtw_cfg80211_send_rx_assoc	os_dep/linux/ioctl_cfg80211.h	284;"	d
-rtw_cfg80211_set_assoc_resp_wpsp2pie	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_assoc_resp_wpsp2pie(struct net_device *net, char *buf, int len)$/;"	f	file:
-rtw_cfg80211_set_auth_type	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_auth_type(struct security_priv *psecuritypriv,$/;"	f	file:
-rtw_cfg80211_set_beacon_wpsp2pie	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_beacon_wpsp2pie(struct net_device *ndev, char *buf, int len)$/;"	f	file:
-rtw_cfg80211_set_cipher	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_cipher(struct security_priv *psecuritypriv, u32 cipher, bool ucast)$/;"	f	file:
-rtw_cfg80211_set_encryption	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)$/;"	f	file:
-rtw_cfg80211_set_is_mgmt_tx	os_dep/linux/ioctl_cfg80211.c	/^inline void rtw_cfg80211_set_is_mgmt_tx(_adapter *adapter, u8 val)$/;"	f
-rtw_cfg80211_set_is_roch	os_dep/linux/ioctl_cfg80211.c	/^inline void rtw_cfg80211_set_is_roch(_adapter *adapter, bool val)$/;"	f
-rtw_cfg80211_set_key_mgt	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_key_mgt(struct security_priv *psecuritypriv, u32 key_mgt)$/;"	f	file:
-rtw_cfg80211_set_mgnt_wpsp2pie	os_dep/linux/ioctl_cfg80211.c	/^int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len,$/;"	f
-rtw_cfg80211_set_probe_req_wpsp2pie	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_probe_req_wpsp2pie(_adapter *padapter, char *buf, int len)$/;"	f	file:
-rtw_cfg80211_set_probe_resp_wpsp2pie	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_probe_resp_wpsp2pie(struct net_device *net, char *buf, int len)$/;"	f	file:
-rtw_cfg80211_set_wpa_ie	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_wpa_ie(_adapter *padapter, u8 *pie, size_t ielen)$/;"	f	file:
-rtw_cfg80211_set_wpa_version	os_dep/linux/ioctl_cfg80211.c	/^static int rtw_cfg80211_set_wpa_version(struct security_priv *psecuritypriv, u32 wpa_version)$/;"	f	file:
-rtw_cfg80211_surveydone_event_callback	os_dep/linux/ioctl_cfg80211.c	/^inline void rtw_cfg80211_surveydone_event_callback(_adapter *padapter)$/;"	f
-rtw_cfg80211_unlink_bss	os_dep/linux/ioctl_cfg80211.c	/^void rtw_cfg80211_unlink_bss(_adapter *padapter, struct wlan_network *pnetwork)$/;"	f
-rtw_cfg80211_vendor_cmd_alloc_reply_skb	os_dep/linux/rtw_cfgvendor.c	140;"	d	file:
-rtw_cfg80211_vendor_cmd_alloc_reply_skb	os_dep/linux/rtw_cfgvendor.c	163;"	d	file:
-rtw_cfg80211_vendor_cmd_reply	os_dep/linux/rtw_cfgvendor.c	143;"	d	file:
-rtw_cfg80211_vendor_cmd_reply	os_dep/linux/rtw_cfgvendor.c	166;"	d	file:
-rtw_cfg80211_vendor_event	os_dep/linux/rtw_cfgvendor.c	137;"	d	file:
-rtw_cfg80211_vendor_event	os_dep/linux/rtw_cfgvendor.c	160;"	d	file:
-rtw_cfg80211_vendor_event_alloc	os_dep/linux/rtw_cfgvendor.c	/^struct sk_buff *rtw_cfg80211_vendor_event_alloc($/;"	f
-rtw_cfg80211_vendor_event_alloc	os_dep/linux/rtw_cfgvendor.c	134;"	d	file:
-rtw_cfg80211_wait_scan_req_empty	os_dep/linux/ioctl_cfg80211.c	/^u32 rtw_cfg80211_wait_scan_req_empty(_adapter *adapter, u32 timeout_ms)$/;"	f
-rtw_cfgvendor_attach	os_dep/linux/rtw_cfgvendor.c	/^int rtw_cfgvendor_attach(struct wiphy *wiphy)$/;"	f
-rtw_cfgvendor_detach	os_dep/linux/rtw_cfgvendor.c	/^int rtw_cfgvendor_detach(struct wiphy *wiphy)$/;"	f
-rtw_cfgvendor_get_feature_set	os_dep/linux/rtw_cfgvendor.c	/^static int rtw_cfgvendor_get_feature_set(struct wiphy *wiphy,$/;"	f	file:
-rtw_cfgvendor_get_feature_set_matrix	os_dep/linux/rtw_cfgvendor.c	/^static int rtw_cfgvendor_get_feature_set_matrix(struct wiphy *wiphy,$/;"	f	file:
-rtw_cfgvendor_send_async_event	os_dep/linux/rtw_cfgvendor.c	/^int rtw_cfgvendor_send_async_event(struct wiphy *wiphy,$/;"	f
-rtw_cfgvendor_send_cmd_reply	os_dep/linux/rtw_cfgvendor.c	/^static int rtw_cfgvendor_send_cmd_reply(struct wiphy *wiphy,$/;"	f	file:
-rtw_ch2freq	core/rtw_rf.c	/^int rtw_ch2freq(int chan)$/;"	f
-rtw_ch_set_search_ch	core/rtw_mlme_ext.c	/^int rtw_ch_set_search_ch(RT_CHANNEL_INFO *ch_set, const u32 ch)$/;"	f
-rtw_ch_to_bb_gain_sel	core/rtw_rf.c	/^int rtw_ch_to_bb_gain_sel(int ch)$/;"	f
-rtw_change_bss_chbw_cmd	core/rtw_cmd.c	/^inline u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags, s16 req_ch, s8 req_bw, s8 req_offset)$/;"	f
-rtw_change_ifname	os_dep/osdep_service.c	/^int rtw_change_ifname(_adapter *padapter, const char *ifname)$/;"	f
-rtw_change_p2pie_ch_list	core/rtw_p2p.c	/^static void rtw_change_p2pie_ch_list(_adapter *padapter, const u8 *frame_body, u32 len, u8 ch)$/;"	f	file:
-rtw_change_p2pie_op_ch	core/rtw_p2p.c	/^static void rtw_change_p2pie_op_ch(_adapter *padapter, const u8 *frame_body, u32 len, u8 ch)$/;"	f	file:
-rtw_channel	os_dep/linux/os_intfs.c	/^int rtw_channel = 1;\/* ad-hoc support requirement *\/$/;"	v
-rtw_channel_plan	os_dep/linux/os_intfs.c	/^int rtw_channel_plan = RTW_CHPLAN_MAX;$/;"	v
-rtw_chbw_to_freq_range	core/rtw_rf.c	/^bool rtw_chbw_to_freq_range(u8 ch, u8 bw, u8 offset, u32 *hi, u32 *lo)$/;"	f
-rtw_check_bcn_info	core/rtw_wlan_util.c	/^int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)$/;"	f
-rtw_check_beacon_data	core/rtw_ap.c	/^int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf,  int len)$/;"	f
-rtw_check_fw_ps	os_dep/linux/os_intfs.c	/^int rtw_check_fw_ps = 1;$/;"	v
-rtw_check_hw_status	os_dep/linux/os_intfs.c	/^int rtw_check_hw_status = 0;$/;"	v
-rtw_check_invalid_mac_address	core/rtw_ieee80211.c	/^u8 rtw_check_invalid_mac_address(u8 *mac_addr, u8 check_local_bit)$/;"	f
-rtw_check_join_candidate	core/rtw_mlme.c	/^static int rtw_check_join_candidate(struct mlme_priv *mlme$/;"	f	file:
-rtw_check_legacy_ap	core/rtw_mlme_ext.c	/^static void rtw_check_legacy_ap(_adapter *padapter, u8 *pframe, u32 len)$/;"	f	file:
-rtw_check_network_type	core/rtw_ieee80211.c	/^int rtw_check_network_type(unsigned char *rate, int ratelen, int channel)$/;"	f
-rtw_check_pattern_valid	core/rtw_wlan_util.c	/^bool rtw_check_pattern_valid(u8 *input, u8 len)$/;"	f
-rtw_check_roaming_candidate	core/rtw_mlme.c	/^static int rtw_check_roaming_candidate(struct mlme_priv *mlme$/;"	f	file:
-rtw_check_tdls_established	core/rtw_xmit.c	/^u8 rtw_check_tdls_established(_adapter *padapter, struct pkt_attrib *pattrib)$/;"	f
-rtw_check_xmit_resource	os_dep/linux/xmit_linux.c	/^static bool rtw_check_xmit_resource(_adapter *padapter, _pkt *pkt)$/;"	f	file:
-rtw_chip_version	os_dep/linux/os_intfs.c	/^int rtw_chip_version = 0x00;$/;"	v
-rtw_chk_ft_flags	include/rtw_mlme.h	558;"	d
-rtw_chk_ft_status	include/rtw_mlme.h	540;"	d
-rtw_chk_hi_queue_cmd	core/rtw_cmd.c	/^u8 rtw_chk_hi_queue_cmd(_adapter *padapter)$/;"	f
-rtw_chk_hi_queue_hdl	core/rtw_cmd.c	/^static void rtw_chk_hi_queue_hdl(_adapter *padapter)$/;"	f	file:
-rtw_chk_miracast_mode	core/rtw_mlme.c	/^bool rtw_chk_miracast_mode(_adapter *adapter, u8 mode)$/;"	f
-rtw_chk_p2pie_ch_list_with_buddy	core/rtw_p2p.c	/^static bool rtw_chk_p2pie_ch_list_with_buddy(_adapter *padapter, const u8 *frame_body, u32 len)$/;"	f	file:
-rtw_chk_p2pie_op_ch_with_buddy	core/rtw_p2p.c	/^static bool rtw_chk_p2pie_op_ch_with_buddy(_adapter *padapter, const u8 *frame_body, u32 len)$/;"	f	file:
-rtw_chk_roam_flags	include/rtw_mlme.h	1126;"	d
-rtw_chk_roam_flags	include/rtw_mlme.h	1150;"	d
-rtw_chk_start_clnt_join	core/rtw_mlme_ext.c	/^int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)$/;"	f
-rtw_choose_shortest_waiting_ch	core/rtw_mlme_ext.c	/^bool rtw_choose_shortest_waiting_ch(_adapter *adapter, u8 req_bw, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset, u8 d_flags)$/;"	f
-rtw_chplan_is_empty	core/rtw_mlme_ext.c	/^bool rtw_chplan_is_empty(u8 id)$/;"	f
-rtw_chset_get_ch_non_ocp_ms	core/rtw_mlme_ext.c	/^u32 rtw_chset_get_ch_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_chset_is_ch_non_ocp	core/rtw_mlme_ext.c	/^bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_chset_is_ch_non_ocp	include/rtw_mlme_ext.h	521;"	d
-rtw_chset_is_chbw_valid	core/rtw_mlme_ext.c	/^u8 rtw_chset_is_chbw_valid(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_chset_update_non_ocp	core/rtw_mlme_ext.c	/^inline void rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_chset_update_non_ocp_ms	core/rtw_mlme_ext.c	/^inline void rtw_chset_update_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms)$/;"	f
-rtw_cipher_suites	os_dep/linux/ioctl_cfg80211.c	/^static const u32 rtw_cipher_suites[] = {$/;"	v	file:
-rtw_classify8021d	os_dep/linux/os_intfs.c	/^unsigned int rtw_classify8021d(struct sk_buff *skb)$/;"	f
-rtw_clean_dk_section	core/rtw_wlan_util.c	/^void rtw_clean_dk_section(_adapter *adapter)$/;"	f
-rtw_clean_hw_dk_cam	core/rtw_wlan_util.c	/^void rtw_clean_hw_dk_cam(_adapter *adapter)$/;"	f
-rtw_clean_pattern	core/rtw_wlan_util.c	/^void rtw_clean_pattern(_adapter *adapter)$/;"	f
-rtw_clear_scan_deny	core/rtw_mlme.c	/^inline void rtw_clear_scan_deny(_adapter *adapter)$/;"	f
-rtw_clear_scan_deny	include/rtw_mlme.h	1069;"	d
-rtw_clearstakey_cmd	core/rtw_cmd.c	/^u8 rtw_clearstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 enqueue)$/;"	f
-rtw_clr_drv_stopped	include/drv_types.h	/^static inline void rtw_clr_drv_stopped(_adapter *padapter)$/;"	f
-rtw_clr_ft_flags	include/rtw_mlme.h	564;"	d
-rtw_clr_roam_flags	include/rtw_mlme.h	1127;"	d
-rtw_clr_roam_flags	include/rtw_mlme.h	1151;"	d
-rtw_clr_surprise_removed	include/drv_types.h	/^static inline void rtw_clr_surprise_removed(_adapter *padapter)$/;"	f
-rtw_cmd_callback	include/rtw_cmd.h	/^struct _cmd_callback	rtw_cmd_callback[] = {$/;"	v	typeref:struct:_cmd_callback
-rtw_cmd_clr_isr	core/rtw_cmd.c	/^void rtw_cmd_clr_isr(struct	cmd_priv *pcmdpriv)$/;"	f
-rtw_cmd_filter	core/rtw_cmd.c	/^int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)$/;"	f
-rtw_cmd_thread	core/rtw_cmd.c	/^thread_return rtw_cmd_thread(thread_context context)$/;"	f
-rtw_combinations	os_dep/linux/ioctl_cfg80211.c	/^struct ieee80211_iface_combination rtw_combinations[] = {$/;"	v	typeref:struct:ieee80211_iface_combination
-rtw_config_gpio	os_dep/linux/os_intfs.c	/^EXPORT_SYMBOL(rtw_config_gpio);$/;"	v
-rtw_config_gpio	os_dep/linux/os_intfs.c	/^int rtw_config_gpio(struct net_device *netdev, u8 gpio_num, bool isOutput)$/;"	f
-rtw_count_tx_stats	core/rtw_xmit.c	/^void rtw_count_tx_stats(PADAPTER padapter, struct xmit_frame *pxmitframe, int sz)$/;"	f
-rtw_country_code	os_dep/linux/os_intfs.c	/^char *rtw_country_code = rtw_country_unspecified;$/;"	v
-rtw_country_unspecified	os_dep/linux/os_intfs.c	/^char rtw_country_unspecified[] = {0xFF, 0xFF, 0x00};$/;"	v
-rtw_cpu_to_le16	core/rtw_io.c	62;"	d	file:
-rtw_cpu_to_le16	core/rtw_io.c	67;"	d	file:
-rtw_cpu_to_le32	core/rtw_io.c	63;"	d	file:
-rtw_cpu_to_le32	core/rtw_io.c	68;"	d	file:
-rtw_cpwm_event_callback	core/rtw_mlme.c	/^void rtw_cpwm_event_callback(PADAPTER padapter, u8 *pbuf)$/;"	f
-rtw_create_ibss_cmd	core/rtw_cmd.c	/^inline u8 rtw_create_ibss_cmd(_adapter *adapter, int flags)$/;"	f
-rtw_create_ibss_post_hdl	core/rtw_cmd.c	/^void rtw_create_ibss_post_hdl(_adapter *padapter, int status)$/;"	f
-rtw_createbss_cmd	core/rtw_cmd.c	/^static u8 rtw_createbss_cmd(_adapter  *adapter, int flags, bool adhoc$/;"	f	file:
-rtw_cta_test_start	os_dep/linux/ioctl_linux.c	/^static int rtw_cta_test_start(struct net_device *dev,$/;"	f	file:
-rtw_customer_str_cmd	core/rtw_cmd.c	/^static u8 rtw_customer_str_cmd(_adapter *adapter, u8 write, const u8 *cstr)$/;"	f	file:
-rtw_customer_str_cmd_hdl	core/rtw_cmd.c	/^static s32 rtw_customer_str_cmd_hdl(_adapter *adapter, u8 write, const u8 *cstr)$/;"	f	file:
-rtw_customer_str_req_cmd	core/rtw_cmd.c	/^inline u8 rtw_customer_str_req_cmd(_adapter *adapter)$/;"	f
-rtw_customer_str_write_cmd	core/rtw_cmd.c	/^inline u8 rtw_customer_str_write_cmd(_adapter *adapter, const u8 *cstr)$/;"	f
-rtw_dbg_dump_fwstate	core/rtw_mi.c	/^static void rtw_dbg_dump_fwstate(_adapter *padapter, sint state)$/;"	f	file:
-rtw_dbg_mode_hdl	os_dep/linux/ioctl_linux.c	/^static void rtw_dbg_mode_hdl(_adapter *padapter, u32 id, u8 *pdata, u32 len)$/;"	f	file:
-rtw_dbg_port	os_dep/linux/ioctl_linux.c	/^static int rtw_dbg_port(struct net_device *dev,$/;"	f	file:
-rtw_dbg_skb_process	core/rtw_mi.c	/^void rtw_dbg_skb_process(_adapter *padapter, union recv_frame *precvframe, union recv_frame *pcloneframe)$/;"	f
-rtw_dec_to_roam	core/rtw_mlme.c	/^inline u8 rtw_dec_to_roam(_adapter *adapter)$/;"	f
-rtw_dec_to_roam	include/rtw_mlme.h	1157;"	d
-rtw_decide_chip_type_by_device_id	os_dep/linux/sdio_intf.c	/^static void rtw_decide_chip_type_by_device_id(struct dvobj_priv *dvobj, const struct sdio_device_id  *pdid)$/;"	f	file:
-rtw_decrypt_phy_file	os_dep/linux/os_intfs.c	/^int rtw_decrypt_phy_file = 0;$/;"	v
-rtw_def_module_get_chplan_from_country	core/rtw_rf.c	/^static const struct country_chplan *rtw_def_module_get_chplan_from_country(const char *country_code)$/;"	f	file:
-rtw_del_p2p_attr	core/rtw_ieee80211.c	/^uint rtw_del_p2p_attr(u8 *ie, uint ielen_ori, u8 attr_id)$/;"	f
-rtw_del_p2p_ie	core/rtw_ieee80211.c	/^uint rtw_del_p2p_ie(u8 *ies, uint ies_len_ori, const char *msg)$/;"	f
-rtw_del_rx_ampdu_test_trigger_no_tx_fail	core/rtw_debug.c	/^bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void)$/;"	f
-rtw_del_sta	os_dep/linux/ioctl_linux.c	/^static int rtw_del_sta(struct net_device *dev, struct ieee_param *param)$/;"	f	file:
-rtw_del_wfd_attr	core/rtw_ieee80211.c	/^uint rtw_del_wfd_attr(u8 *ie, uint ielen_ori, u8 attr_id)$/;"	f
-rtw_del_wfd_ie	core/rtw_ieee80211.c	/^uint rtw_del_wfd_ie(u8 *ies, uint ies_len_ori, const char *msg)$/;"	f
-rtw_delba_check	core/rtw_mlme_ext.c	/^void rtw_delba_check(_adapter *padapter, struct sta_info *psta, u8 from_timer)$/;"	f
-rtw_dequeue_cmd	core/rtw_cmd.c	/^struct	cmd_obj	*rtw_dequeue_cmd(struct cmd_priv *pcmdpriv)$/;"	f
-rtw_dequeue_evt	core/rtw_cmd.c	/^struct evt_obj *rtw_dequeue_evt(_queue *queue)$/;"	f
-rtw_dequeue_recvbuf	core/rtw_recv.c	/^struct recv_buf *rtw_dequeue_recvbuf(_queue *queue)$/;"	f
-rtw_dequeue_recvframe	include/rtw_recv.h	648;"	d
-rtw_dequeue_xframe	core/rtw_xmit.c	/^struct xmit_frame *rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i, sint entry)$/;"	f
-rtw_dev_get_feature_set	os_dep/linux/rtw_cfgvendor.c	/^int rtw_dev_get_feature_set(struct net_device *dev)$/;"	f
-rtw_dev_get_feature_set_matrix	os_dep/linux/rtw_cfgvendor.c	/^int *rtw_dev_get_feature_set_matrix(struct net_device *dev, int *num)$/;"	f
-rtw_dev_nlo_info_set	core/rtw_wlan_util.c	/^int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t *ssid,$/;"	f
-rtw_dev_pno_debug	core/rtw_wlan_util.c	/^void rtw_dev_pno_debug(struct net_device *net)$/;"	f
-rtw_dev_pno_set	core/rtw_wlan_util.c	/^int rtw_dev_pno_set(struct net_device *net, pno_ssid_t *ssid, int num,$/;"	f
-rtw_dev_remove	os_dep/linux/sdio_intf.c	/^static void rtw_dev_remove(struct sdio_func *func)$/;"	f	file:
-rtw_dev_scan_info_set	core/rtw_wlan_util.c	/^int rtw_dev_scan_info_set(_adapter *padapter, pno_ssid_t *ssid,$/;"	f
-rtw_dev_ssid_list_set	core/rtw_wlan_util.c	/^int rtw_dev_ssid_list_set(struct pno_ssid_list *pno_ssid_list,$/;"	f
-rtw_dev_unload	os_dep/linux/os_intfs.c	/^void rtw_dev_unload(PADAPTER padapter)$/;"	f
-rtw_dfs_master_cmd	core/rtw_cmd.c	/^u8 rtw_dfs_master_cmd(_adapter *adapter, bool enqueue)$/;"	f
-rtw_dfs_master_disable	core/rtw_cmd.c	/^void rtw_dfs_master_disable(_adapter *adapter, u8 ch, u8 bw, u8 offset, bool by_others)$/;"	f
-rtw_dfs_master_enable	core/rtw_cmd.c	/^void rtw_dfs_master_enable(_adapter *adapter, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_dfs_master_hdl	core/rtw_cmd.c	/^u8 rtw_dfs_master_hdl(_adapter *adapter)$/;"	f
-rtw_dfs_master_status_apply	core/rtw_cmd.c	/^void rtw_dfs_master_status_apply(_adapter *adapter, u8 self_action)$/;"	f
-rtw_dfs_master_timer_hdl	core/rtw_cmd.c	/^void rtw_dfs_master_timer_hdl(RTW_TIMER_HDL_ARGS)$/;"	f
-rtw_dfs_region_domain	os_dep/linux/os_intfs.c	/^uint rtw_dfs_region_domain = CONFIG_RTW_DFS_REGION_DOMAIN;$/;"	v
-rtw_disable_gpio_interrupt	os_dep/linux/os_intfs.c	/^EXPORT_SYMBOL(rtw_disable_gpio_interrupt);$/;"	v
-rtw_disable_gpio_interrupt	os_dep/linux/os_intfs.c	/^int rtw_disable_gpio_interrupt(struct net_device *netdev, int gpio_num)$/;"	f
-rtw_disassoc_cmd	core/rtw_cmd.c	/^u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, bool enqueue) \/* for sta_mode *\/$/;"	f
-rtw_disassoc_cmd_callback	core/rtw_cmd.c	/^void rtw_disassoc_cmd_callback(_adapter	*padapter,  struct cmd_obj *pcmd)$/;"	f
-rtw_division64	os_dep/osdep_service.c	/^u64 rtw_division64(u64 x, u64 y)$/;"	f
-rtw_dm_in_lps_hdl	core/rtw_cmd.c	/^void rtw_dm_in_lps_hdl(_adapter *padapter)$/;"	f
-rtw_dm_in_lps_wk_cmd	core/rtw_cmd.c	/^u8 rtw_dm_in_lps_wk_cmd(_adapter *padapter)$/;"	f
-rtw_dm_ra_mask_hdl	core/rtw_cmd.c	/^void rtw_dm_ra_mask_hdl(_adapter *padapter, struct sta_info *psta)$/;"	f
-rtw_dm_ra_mask_wk_cmd	core/rtw_cmd.c	/^u8 rtw_dm_ra_mask_wk_cmd(_adapter *padapter, u8 *psta)$/;"	f
-rtw_do_join	core/rtw_ioctl_set.c	/^u8 rtw_do_join(_adapter *padapter)$/;"	f
-rtw_drv_add_vir_if	os_dep/linux/os_intfs.c	/^_adapter *rtw_drv_add_vir_if(_adapter *primary_padapter,$/;"	f
-rtw_drv_ant_band_switch	os_dep/linux/os_intfs.c	/^int rtw_drv_ant_band_switch = 1; \/* 0:OFF , 1:ON, Driver control antenna band switch*\/$/;"	v
-rtw_drv_del_vir_if	os_dep/linux/os_intfs.c	/^void rtw_drv_del_vir_if(_adapter *padapter)$/;"	f
-rtw_drv_del_vir_ifaces	os_dep/linux/os_intfs.c	/^void rtw_drv_del_vir_ifaces(_adapter *primary_padapter)$/;"	f
-rtw_drv_entry	os_dep/linux/sdio_intf.c	/^static int rtw_drv_entry(void)$/;"	f	file:
-rtw_drv_free_vir_if	os_dep/linux/os_intfs.c	/^void rtw_drv_free_vir_if(_adapter *padapter)$/;"	f
-rtw_drv_free_vir_ifaces	os_dep/linux/os_intfs.c	/^void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj)$/;"	f
-rtw_drv_halt	os_dep/linux/sdio_intf.c	/^static void rtw_drv_halt(void)$/;"	f	file:
-rtw_drv_init	os_dep/linux/sdio_intf.c	/^static int rtw_drv_init($/;"	f	file:
-rtw_drv_log_level	os_dep/linux/os_intfs.c	/^	uint rtw_drv_log_level = (uint)RTW_LOG_LEVEL; \/* from Makefile *\/$/;"	v
-rtw_drv_log_level	os_dep/linux/os_intfs.c	/^	uint rtw_drv_log_level = _DRV_INFO_;$/;"	v
-rtw_drv_proc_deinit	os_dep/linux/rtw_proc.c	/^void rtw_drv_proc_deinit(void)$/;"	f
-rtw_drv_proc_deinit	os_dep/linux/rtw_proc.h	58;"	d
-rtw_drv_proc_init	os_dep/linux/rtw_proc.c	/^int rtw_drv_proc_init(void)$/;"	f
-rtw_drv_proc_init	os_dep/linux/rtw_proc.h	57;"	d
-rtw_drv_proc_open	os_dep/linux/rtw_proc.c	/^static int rtw_drv_proc_open(struct inode *inode, struct file *file)$/;"	f	file:
-rtw_drv_proc_seq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_drv_proc_seq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_drv_proc_sseq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_drv_proc_sseq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_drv_proc_write	os_dep/linux/rtw_proc.c	/^static ssize_t rtw_drv_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)$/;"	f	file:
-rtw_drv_scan_by_self	core/rtw_mlme.c	/^void rtw_drv_scan_by_self(_adapter *padapter, u8 reason)$/;"	f
-rtw_drv_stop_vir_if	os_dep/linux/os_intfs.c	/^void rtw_drv_stop_vir_if(_adapter *padapter)$/;"	f
-rtw_drv_stop_vir_ifaces	os_dep/linux/os_intfs.c	/^void rtw_drv_stop_vir_ifaces(struct dvobj_priv *dvobj)$/;"	f
-rtw_drvext_hdl	os_dep/linux/ioctl_linux.c	/^static  int rtw_drvext_hdl(struct net_device *dev, struct iw_request_info *info,$/;"	f	file:
-rtw_drvextra_cmd_hdl	core/rtw_cmd.c	/^u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-rtw_drvextra_cmd_id	include/rtw_cmd.h	/^enum rtw_drvextra_cmd_id {$/;"	g
-rtw_dummy_event_callback	core/rtw_mlme.c	/^void rtw_dummy_event_callback(_adapter *adapter , u8 *pbuf)$/;"	f
-rtw_dump_aoac_rpt	hal/hal_com.c	/^static void rtw_dump_aoac_rpt(_adapter *adapter)$/;"	f	file:
-rtw_dump_bcn_keys	core/rtw_wlan_util.c	/^void rtw_dump_bcn_keys(struct beacon_keys *recv_beacon)$/;"	f
-rtw_dump_cur_efuse	hal/hal_com.c	/^void rtw_dump_cur_efuse(PADAPTER padapter)$/;"	f
-rtw_dump_drv_rx_counters	hal/hal_com.c	/^void rtw_dump_drv_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)$/;"	f
-rtw_dump_mac_rx_counters	hal/hal_com.c	/^void rtw_dump_mac_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)$/;"	f
-rtw_dump_phy_rx_counters	hal/hal_com.c	/^void rtw_dump_phy_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)$/;"	f
-rtw_dump_phy_rxcnts_preprocess	hal/hal_com.c	/^void rtw_dump_phy_rxcnts_preprocess(_adapter *padapter, u8 rx_cnt_mode)$/;"	f
-rtw_dump_priv_pattern	core/rtw_wlan_util.c	/^void rtw_dump_priv_pattern(_adapter *adapter, u8 idx)$/;"	f
-rtw_dump_raw_rssi_info	hal/hal_com.c	/^void rtw_dump_raw_rssi_info(_adapter *padapter, void *sel)$/;"	f
-rtw_dump_rx_counters	hal/hal_com.c	/^void rtw_dump_rx_counters(_adapter *padapter)$/;"	f
-rtw_dump_rx_dframe_info	hal/hal_com.c	/^void rtw_dump_rx_dframe_info(_adapter *padapter, void *sel)$/;"	f
-rtw_dump_stack	include/osdep_service.h	/^__inline static void rtw_dump_stack(void)$/;"	f
-rtw_dynamic_check_timer_handlder	core/rtw_mlme.c	/^void rtw_dynamic_check_timer_handlder(_adapter *adapter)$/;"	f
-rtw_dynamic_chk_wk_cmd	core/rtw_cmd.c	/^u8 rtw_dynamic_chk_wk_cmd(_adapter *padapter)$/;"	f
-rtw_dynamic_chk_wk_hdl	core/rtw_cmd.c	/^void rtw_dynamic_chk_wk_hdl(_adapter *padapter)$/;"	f
-rtw_early_mode	os_dep/linux/os_intfs.c	/^int rtw_early_mode = 1;$/;"	v
-rtw_early_suspend	core/rtw_pwrctrl.c	/^static void rtw_early_suspend(android_early_suspend_t *h)$/;"	f	file:
-rtw_early_suspend	core/rtw_pwrctrl.c	/^static void rtw_early_suspend(struct early_suspend *h)$/;"	f	file:
-rtw_efuse_access	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_access	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_access(PADAPTER padapter, u8 bWrite, u16 start_addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_bt_access	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_bt_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_file_map	os_dep/linux/ioctl_mp.c	/^int rtw_efuse_file_map(struct net_device *dev,$/;"	f
-rtw_efuse_file_read	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_file_read(PADAPTER padapter, u8 *filepatch, u8 *buf, u32 len)$/;"	f
-rtw_efuse_map_read	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_map_read	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_map_write	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_map_write	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_mask_array	core/efuse/rtw_efuse.c	/^void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)$/;"	f
-rtw_efuse_mask_file	os_dep/linux/ioctl_mp.c	/^int rtw_efuse_mask_file(struct net_device *dev,$/;"	f
-rtw_efuse_mask_map_read	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_mask_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_efuse_mask_map_read	core/efuse/rtw_efuse.c	/^u8 rtw_efuse_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)$/;"	f
-rtw_en_gro	os_dep/linux/os_intfs.c	/^int rtw_en_gro = 1;$/;"	v
-rtw_en_mcc	os_dep/linux/os_intfs.c	/^int rtw_en_mcc = 1;$/;"	v
-rtw_en_napi	os_dep/linux/os_intfs.c	/^int rtw_en_napi = 1;$/;"	v
-rtw_enable_hw_update_tsf_cmd	core/rtw_cmd.c	/^u8 rtw_enable_hw_update_tsf_cmd(_adapter *padapter)$/;"	f
-rtw_end_of_queue_search	os_dep/osdep_service.c	/^u32 rtw_end_of_queue_search(_list *head, _list *plist)$/;"	f
-rtw_endofpktfile	os_dep/linux/xmit_linux.c	/^sint rtw_endofpktfile(struct pkt_file *pfile)$/;"	f
-rtw_enqueue_cmd	core/rtw_cmd.c	/^u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)$/;"	f
-rtw_enqueue_evt	core/rtw_cmd.c	/^u32 rtw_enqueue_evt(struct evt_priv *pevtpriv, struct evt_obj *obj)$/;"	f
-rtw_enqueue_network	core/rtw_mlme.c	/^int	rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork)$/;"	f
-rtw_enqueue_recvbuf	core/rtw_recv.c	/^sint rtw_enqueue_recvbuf(struct recv_buf *precvbuf, _queue *queue)$/;"	f
-rtw_enqueue_recvbuf_to_head	core/rtw_recv.c	/^sint rtw_enqueue_recvbuf_to_head(struct recv_buf *precvbuf, _queue *queue)$/;"	f
-rtw_enqueue_recvframe	core/rtw_recv.c	/^sint rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue)$/;"	f
-rtw_enusbss	os_dep/linux/os_intfs.c	/^int rtw_enusbss = 0;\/* 0:disable,1:enable *\/$/;"	v
-rtw_enusbss	os_dep/linux/os_intfs.c	/^int rtw_enusbss = 1;\/* 0:disable,1:enable *\/$/;"	v
-rtw_evt_notify_isr	core/rtw_cmd.c	/^void rtw_evt_notify_isr(struct evt_priv *pevtpriv)$/;"	f
-rtw_excl_chs	os_dep/linux/os_intfs.c	/^static uint rtw_excl_chs[MAX_CHANNEL_NUM] = CONFIG_RTW_EXCL_CHS;$/;"	v	file:
-rtw_excl_chs_num	os_dep/linux/os_intfs.c	/^static int rtw_excl_chs_num = 0;$/;"	v	file:
-rtw_file_efuse_IsMasked	core/efuse/rtw_efuse.c	/^BOOLEAN rtw_file_efuse_IsMasked(PADAPTER pAdapter, u16 Offset)$/;"	f
-rtw_find_network	core/rtw_mlme.c	/^struct	wlan_network *rtw_find_network(_queue *scanned_queue, u8 *addr)$/;"	f
-rtw_find_same_network	core/rtw_mlme.c	/^struct wlan_network *rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network)$/;"	f
-rtw_force_ant	os_dep/linux/os_intfs.c	/^int rtw_force_ant = 2;\/* 0 :normal, 1:Main ant, 2:Aux ant *\/$/;"	v
-rtw_force_igi	os_dep/linux/os_intfs.c	/^int rtw_force_igi = 0; \/* 0 :normal *\/$/;"	v
-rtw_force_igi_lb	os_dep/linux/os_intfs.c	/^int rtw_force_igi_lb = CONFIG_RTW_FORCE_IGI_LB;$/;"	v
-rtw_frag_thresh	os_dep/linux/os_intfs.c	/^int rtw_frag_thresh = 2346;$/;"	v
-rtw_free_all_stainfo	core/rtw_sta_mgt.c	/^void rtw_free_all_stainfo(_adapter *padapter)$/;"	f
-rtw_free_assoc_resources	core/rtw_mlme.c	/^void rtw_free_assoc_resources(_adapter *adapter, int lock_scanned_queue)$/;"	f
-rtw_free_assoc_resources_cmd	core/rtw_cmd.c	/^u8 rtw_free_assoc_resources_cmd(_adapter *padapter)$/;"	f
-rtw_free_cmd_obj	core/rtw_cmd.c	/^void rtw_free_cmd_obj(struct cmd_obj *pcmd)$/;"	f
-rtw_free_cmd_priv	core/rtw_cmd.c	/^void rtw_free_cmd_priv(struct	cmd_priv *pcmdpriv)$/;"	f
-rtw_free_drv_sw	os_dep/linux/os_intfs.c	/^u8 rtw_free_drv_sw(_adapter *padapter)$/;"	f
-rtw_free_evt_obj	core/rtw_cmd.c	/^void rtw_free_evt_obj(struct evt_obj *pevtobj)$/;"	f
-rtw_free_evt_priv	core/rtw_cmd.c	/^void rtw_free_evt_priv(struct	evt_priv *pevtpriv)$/;"	f
-rtw_free_hwxmits	core/rtw_xmit.c	/^void rtw_free_hwxmits(_adapter *padapter)$/;"	f
-rtw_free_mlme_ie_data	core/rtw_mlme.c	/^static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)$/;"	f	file:
-rtw_free_mlme_priv	core/rtw_mlme.c	/^void rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)$/;"	f
-rtw_free_mlme_priv_ie_data	core/rtw_mlme.c	/^void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)$/;"	f
-rtw_free_netdev	include/osdep_service_bsd.h	735;"	d
-rtw_free_netdev	os_dep/osdep_service.c	/^void rtw_free_netdev(struct net_device *netdev)$/;"	f
-rtw_free_network	core/rtw_mlme.c	/^void rtw_free_network(struct mlme_priv *pmlmepriv, struct	wlan_network *pnetwork, u8 is_freeall)\/* (struct	wlan_network *pnetwork, _queue	*free_queue) *\/$/;"	f
-rtw_free_network_nolock	core/rtw_mlme.c	/^void rtw_free_network_nolock(_adapter *padapter, struct wlan_network *pnetwork)$/;"	f
-rtw_free_network_queue	core/rtw_mlme.c	/^void rtw_free_network_queue(_adapter *dev, u8 isfreeall)$/;"	f
-rtw_free_pwrctrl_priv	core/rtw_pwrctrl.c	/^void rtw_free_pwrctrl_priv(PADAPTER adapter)$/;"	f
-rtw_free_recvframe	core/rtw_recv.c	/^int rtw_free_recvframe(union recv_frame *precvframe, _queue *pfree_recv_queue)$/;"	f
-rtw_free_recvframe_queue	core/rtw_recv.c	/^void rtw_free_recvframe_queue(_queue *pframequeue,  _queue *pfree_recv_queue)$/;"	f
-rtw_free_skb_premem	core/rtw_mem.c	/^EXPORT_SYMBOL(rtw_free_skb_premem);$/;"	v
-rtw_free_skb_premem	core/rtw_mem.c	/^int rtw_free_skb_premem(struct sk_buff *pskb)$/;"	f
-rtw_free_stainfo	core/rtw_sta_mgt.c	/^u32	rtw_free_stainfo(_adapter *padapter , struct sta_info *psta)$/;"	f
-rtw_free_tdls_info	core/rtw_tdls.c	/^void rtw_free_tdls_info(struct tdls_info *ptdlsinfo)$/;"	f
-rtw_free_tdls_timer	core/rtw_tdls.c	/^void rtw_free_tdls_timer(struct sta_info *psta)$/;"	f
-rtw_free_uc_swdec_pending_queue	core/rtw_recv.c	/^u32 rtw_free_uc_swdec_pending_queue(_adapter *adapter)$/;"	f
-rtw_free_xmitbuf	core/rtw_xmit.c	/^s32 rtw_free_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)$/;"	f
-rtw_free_xmitbuf_ext	core/rtw_xmit.c	/^s32 rtw_free_xmitbuf_ext(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)$/;"	f
-rtw_free_xmitframe	core/rtw_xmit.c	/^s32 rtw_free_xmitframe(struct xmit_priv *pxmitpriv, struct xmit_frame *pxmitframe)$/;"	f
-rtw_free_xmitframe_queue	core/rtw_xmit.c	/^void rtw_free_xmitframe_queue(struct xmit_priv *pxmitpriv, _queue *pframequeue)$/;"	f
-rtw_freq2ch	core/rtw_rf.c	/^int rtw_freq2ch(int freq)$/;"	f
-rtw_ft_reassoc_event_callback	core/rtw_mlme.c	/^void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf)$/;"	f
-rtw_full_ch_in_p2p_handshake	os_dep/linux/os_intfs.c	/^	int rtw_full_ch_in_p2p_handshake = 0; \/* reply only softap channel*\/$/;"	v
-rtw_full_ch_in_p2p_handshake	os_dep/linux/os_intfs.c	/^	int rtw_full_ch_in_p2p_handshake = 1; \/* reply full channel list*\/$/;"	v
-rtw_fw_file_path	os_dep/linux/os_intfs.c	/^char *rtw_fw_file_path = "\/system\/etc\/firmware\/rtlwifi\/FW_NIC.BIN";$/;"	v
-rtw_fw_iol	os_dep/linux/os_intfs.c	/^int rtw_fw_iol = 1;$/;"	v
-rtw_fw_mp_bt_file_path	os_dep/linux/os_intfs.c	/^char *rtw_fw_mp_bt_file_path = "";$/;"	v
-rtw_fw_ps_state	core/rtw_pwrctrl.c	/^int rtw_fw_ps_state(PADAPTER padapter)$/;"	f
-rtw_fw_wow_file_path	os_dep/linux/os_intfs.c	/^char *rtw_fw_wow_file_path = "\/system\/etc\/firmware\/rtlwifi\/FW_WoWLAN.BIN";$/;"	v
-rtw_fwdbg_event_callback	core/rtw_mlme.c	/^void rtw_fwdbg_event_callback(_adapter *adapter , u8 *pbuf)$/;"	f
-rtw_fwdl_test_trigger_chksum_fail	core/rtw_debug.c	/^bool rtw_fwdl_test_trigger_chksum_fail(void)$/;"	f
-rtw_fwdl_test_trigger_wintint_rdy_fail	core/rtw_debug.c	/^bool rtw_fwdl_test_trigger_wintint_rdy_fail(void)$/;"	f
-rtw_g_rates	os_dep/linux/ioctl_cfg80211.c	142;"	d	file:
-rtw_generate_ie	core/rtw_ieee80211.c	/^int rtw_generate_ie(struct registry_priv *pregistrypriv)$/;"	f
-rtw_generate_random_ibss	core/rtw_mlme.c	/^void rtw_generate_random_ibss(u8 *pibss)$/;"	f
-rtw_get_acs_channel	include/hal_data.h	763;"	d
-rtw_get_adapter_tx_rate_bmp_by_bw	core/rtw_xmit.c	/^void rtw_get_adapter_tx_rate_bmp_by_bw(_adapter *adapter, u8 bw, u16 *r_bmp_cck_ofdm, u32 *r_bmp_ht, u32 *r_bmp_vht)$/;"	f
-rtw_get_ap_info	os_dep/linux/ioctl_linux.c	/^static int rtw_get_ap_info(struct net_device *dev,$/;"	f	file:
-rtw_get_bcmc_stainfo	core/rtw_sta_mgt.c	/^struct sta_info *rtw_get_bcmc_stainfo(_adapter *padapter)$/;"	f
-rtw_get_bcn_info	core/rtw_ieee80211.c	/^void rtw_get_bcn_info(struct wlan_network *pnetwork)$/;"	f
-rtw_get_bcn_keys	core/rtw_wlan_util.c	/^int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,$/;"	f
-rtw_get_beacon_interval_from_ie	core/rtw_mlme.c	/^u8 *rtw_get_beacon_interval_from_ie(u8 *ie)$/;"	f
-rtw_get_bit_value_from_ieee_value	core/rtw_ieee80211.c	/^int rtw_get_bit_value_from_ieee_value(u8 val)$/;"	f
-rtw_get_buf_premem	core/rtw_mem.c	/^struct u8	*rtw_get_buf_premem(int index)$/;"	f
-rtw_get_camid	core/rtw_wlan_util.c	/^s16 rtw_get_camid(_adapter *adapter, struct sta_info *sta, u8 *addr, s16 kid)$/;"	f
-rtw_get_capability	core/rtw_mlme.c	/^u16 rtw_get_capability(WLAN_BSSID_EX *bss)$/;"	f
-rtw_get_capability_from_ie	core/rtw_mlme.c	/^u8 *rtw_get_capability_from_ie(u8 *ie)$/;"	f
-rtw_get_center_ch	core/rtw_wlan_util.c	/^u8 rtw_get_center_ch(u8 channel, u8 chnl_bw, u8 chnl_offset)$/;"	f
-rtw_get_ch_group	core/rtw_rf.c	/^u8 rtw_get_ch_group(u8 ch, u8 *group, u8 *cck_group)$/;"	f
-rtw_get_ch_waiting_ms	core/rtw_mlme_ext.c	/^u32 rtw_get_ch_waiting_ms(_adapter *adapter, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms)$/;"	f
-rtw_get_chip_type	include/drv_types.h	1474;"	d
-rtw_get_chplan_from_country	core/rtw_rf.c	/^const struct country_chplan *rtw_get_chplan_from_country(const char *country_code)$/;"	f
-rtw_get_cipher_info	core/rtw_ieee80211.c	/^int rtw_get_cipher_info(struct wlan_network *pnetwork)$/;"	f
-rtw_get_cur_max_rate	core/rtw_ioctl_set.c	/^u16 rtw_get_cur_max_rate(_adapter *adapter)$/;"	f
-rtw_get_current_ip_address	core/rtw_wlan_util.c	/^void rtw_get_current_ip_address(PADAPTER padapter, u8 *pcurrentip)$/;"	f
-rtw_get_current_time	os_dep/osdep_service.c	/^u32	rtw_get_current_time(void)$/;"	f
-rtw_get_current_tx_rate	hal/hal_com.c	/^u8 rtw_get_current_tx_rate(_adapter *padapter, u8 macid)$/;"	f
-rtw_get_current_tx_sgi	hal/hal_com.c	/^u8 rtw_get_current_tx_sgi(_adapter *padapter, u8 macid)$/;"	f
-rtw_get_efuse_mask_arraylen	core/efuse/rtw_efuse.c	/^u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)$/;"	f
-rtw_get_empty_cam_entry	core/rtw_wlan_util.c	/^s16 rtw_get_empty_cam_entry(_adapter *adapter, u8 start_camid)$/;"	f
-rtw_get_encrypt_decrypt_from_registrypriv	core/rtw_mlme.c	/^void rtw_get_encrypt_decrypt_from_registrypriv(_adapter *adapter)$/;"	f
-rtw_get_ff_hwaddr	core/rtw_xmit.c	/^u32 rtw_get_ff_hwaddr(struct xmit_frame *pxmitframe)$/;"	f
-rtw_get_gpio	os_dep/linux/os_intfs.c	/^EXPORT_SYMBOL(rtw_get_gpio);$/;"	v
-rtw_get_gpio	os_dep/linux/os_intfs.c	/^u8 rtw_get_gpio(struct net_device *netdev, u8 gpio_num)$/;"	f
-rtw_get_hw_init_completed	include/hal_data.h	756;"	d
-rtw_get_hw_type	include/drv_types.h	1475;"	d
-rtw_get_hwseq_no	core/rtw_xmit.c	/^inline u8 rtw_get_hwseq_no(_adapter *padapter)$/;"	f
-rtw_get_ie	core/rtw_ieee80211.c	/^u8 *rtw_get_ie(u8 *pbuf, sint index, sint *len, sint limit)$/;"	f
-rtw_get_ie_ex	core/rtw_ieee80211.c	/^u8 *rtw_get_ie_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len, u8 *ie, uint *ielen)$/;"	f
-rtw_get_iface_by_hwport	core/rtw_mi.c	/^_adapter *rtw_get_iface_by_hwport(_adapter *padapter, u8 hw_port)$/;"	f
-rtw_get_iface_by_id	core/rtw_mi.c	/^_adapter *rtw_get_iface_by_id(_adapter *padapter, u8 iface_id)$/;"	f
-rtw_get_iface_by_macddr	core/rtw_mi.c	/^_adapter *rtw_get_iface_by_macddr(_adapter *padapter, u8 *mac_addr)$/;"	f
-rtw_get_intf_type	include/drv_types.h	1476;"	d
-rtw_get_ips_mode_req	include/rtw_pwrctrl.h	446;"	d
-rtw_get_mac_addr_intel	core/rtw_ieee80211.c	/^int rtw_get_mac_addr_intel(unsigned char *buf)$/;"	f
-rtw_get_max_mbid_cam_id	hal/hal_com.c	/^u8 rtw_get_max_mbid_cam_id(_adapter *adapter)$/;"	f
-rtw_get_mbid_cam_entry_num	hal/hal_com.c	/^inline u8 rtw_get_mbid_cam_entry_num(_adapter *adapter)$/;"	f
-rtw_get_mgntframe_raid	hal/hal_com.c	/^u8 rtw_get_mgntframe_raid(_adapter *adapter, unsigned char network_type)$/;"	f
-rtw_get_mi_nums	include/drv_types.h	1478;"	d
-rtw_get_noise	hal/hal_com.c	/^void rtw_get_noise(_adapter *padapter)$/;"	f
-rtw_get_offset_by_ch	core/rtw_wlan_util.c	/^u8 rtw_get_offset_by_ch(u8 channel)$/;"	f
-rtw_get_offset_by_chbw	core/rtw_wlan_util.c	/^u8 rtw_get_offset_by_chbw(u8 ch, u8 bw, u8 *r_offset)$/;"	f
-rtw_get_oldest_wlan_network	core/rtw_mlme.c	/^struct	wlan_network	*rtw_get_oldest_wlan_network(_queue *scanned_queue)$/;"	f
-rtw_get_on_cur_ch_time	core/rtw_wlan_util.c	/^inline u32 rtw_get_on_cur_ch_time(_adapter *adapter)$/;"	f
-rtw_get_on_oper_ch_time	core/rtw_wlan_util.c	/^inline u32 rtw_get_on_oper_ch_time(_adapter *adapter)$/;"	f
-rtw_get_op_chs_by_cch_bw	core/rtw_rf.c	/^u8 rtw_get_op_chs_by_cch_bw(u8 cch, u8 bw, u8 **op_chs, u8 *op_ch_num)$/;"	f
-rtw_get_oper_bw	core/rtw_wlan_util.c	/^inline u8 rtw_get_oper_bw(_adapter *adapter)$/;"	f
-rtw_get_oper_ch	core/rtw_wlan_util.c	/^inline u8 rtw_get_oper_ch(_adapter *adapter)$/;"	f
-rtw_get_oper_choffset	core/rtw_wlan_util.c	/^inline u8 rtw_get_oper_choffset(_adapter *adapter)$/;"	f
-rtw_get_p2p_attr	core/rtw_ieee80211.c	/^u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id , u8 *buf_attr, u32 *len_attr)$/;"	f
-rtw_get_p2p_attr_content	core/rtw_ieee80211.c	/^u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id , u8 *buf_content, uint *len_content)$/;"	f
-rtw_get_p2p_ie	core/rtw_ieee80211.c	/^u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)$/;"	f
-rtw_get_p2p_merged_ies_len	core/rtw_ieee80211.c	/^u32 rtw_get_p2p_merged_ies_len(u8 *in_ie, u32 in_len)$/;"	f
-rtw_get_passing_time_ms	os_dep/osdep_service.c	/^inline s32 rtw_get_passing_time_ms(u32 start)$/;"	f
-rtw_get_phy_file_path	hal/hal_com_phycfg.c	/^int rtw_get_phy_file_path(_adapter *adapter, const char *file_name)$/;"	f
-rtw_get_rateset_len	core/rtw_ieee80211.c	/^uint	rtw_get_rateset_len(u8	*rateset)$/;"	f
-rtw_get_raw_rssi_info	hal/hal_com.c	/^void rtw_get_raw_rssi_info(void *sel, _adapter *padapter)$/;"	f
-rtw_get_scch_by_cch_offset	core/rtw_rf.c	/^u8 rtw_get_scch_by_cch_offset(u8 cch, u8 bw, u8 offset)$/;"	f
-rtw_get_sec_camid	core/rtw_wlan_util.c	/^u8 rtw_get_sec_camid(_adapter *adapter, u8 max_bk_key_num, u8 *sec_key_id)$/;"	f
-rtw_get_sec_ie	core/rtw_ieee80211.c	/^int rtw_get_sec_ie(u8 *in_ie, uint in_len, u8 *rsn_ie, u16 *rsn_len, u8 *wpa_ie, u16 *wpa_len)$/;"	f
-rtw_get_sec_iv	core/rtw_wlan_util.c	/^void rtw_get_sec_iv(PADAPTER padapter, u8 *pcur_dot11txpn, u8 *StaAddr)$/;"	f
-rtw_get_shared_macid_tx_rate_bmp_by_bw	core/rtw_xmit.c	/^void rtw_get_shared_macid_tx_rate_bmp_by_bw(struct dvobj_priv *dvobj, u8 bw, u16 *r_bmp_cck_ofdm, u32 *r_bmp_ht, u32 *r_bmp_vht)$/;"	f
-rtw_get_sta_pending	core/rtw_xmit.c	/^__inline static struct tx_servq *rtw_get_sta_pending$/;"	f	file:
-rtw_get_sta_pending	core/rtw_xmit.c	/^struct tx_servq *rtw_get_sta_pending(_adapter *padapter, struct sta_info *psta, sint up, u8 *ac)$/;"	f
-rtw_get_sta_wpaie	os_dep/linux/ioctl_linux.c	/^static int rtw_get_sta_wpaie(struct net_device *dev, struct ieee_param *param)$/;"	f	file:
-rtw_get_stainfo	core/rtw_sta_mgt.c	/^struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, u8 *hwaddr)$/;"	f
-rtw_get_stainfo_by_offset	core/rtw_sta_mgt.c	/^inline struct sta_info *rtw_get_stainfo_by_offset(struct sta_priv *stapriv, int offset)$/;"	f
-rtw_get_systime_us	os_dep/linux/ioctl_cfg80211.c	/^static u64 rtw_get_systime_us(void)$/;"	f	file:
-rtw_get_time_interval_ms	os_dep/osdep_service.c	/^inline s32 rtw_get_time_interval_ms(u32 start, u32 end)$/;"	f
-rtw_get_timestampe_from_ie	core/rtw_mlme.c	/^u8 *rtw_get_timestampe_from_ie(u8 *ie)$/;"	f
-rtw_get_tx_bw_bmp_of_ht_rate	core/rtw_xmit.c	/^u8 rtw_get_tx_bw_bmp_of_ht_rate(struct dvobj_priv *dvobj, u8 rate, u8 max_bw)$/;"	f
-rtw_get_tx_bw_bmp_of_vht_rate	core/rtw_xmit.c	/^u8 rtw_get_tx_bw_bmp_of_vht_rate(struct dvobj_priv *dvobj, u8 rate, u8 max_bw)$/;"	f
-rtw_get_tx_bw_mode	core/rtw_xmit.c	/^u8 rtw_get_tx_bw_mode(_adapter *adapter, struct sta_info *sta)$/;"	f
-rtw_get_tx_nss	core/rtw_wlan_util.c	/^s8 rtw_get_tx_nss(_adapter *adapter, struct sta_info *psta)$/;"	f
-rtw_get_tx_rate_bmp_cck_ofdm	core/rtw_xmit.c	/^inline u16 rtw_get_tx_rate_bmp_cck_ofdm(struct dvobj_priv *dvobj)$/;"	f
-rtw_get_tx_rate_bmp_ht_by_bw	core/rtw_xmit.c	/^inline u32 rtw_get_tx_rate_bmp_ht_by_bw(struct dvobj_priv *dvobj, u8 bw)$/;"	f
-rtw_get_tx_rate_bmp_vht_by_bw	core/rtw_xmit.c	/^inline u32 rtw_get_tx_rate_bmp_vht_by_bw(struct dvobj_priv *dvobj, u8 bw)$/;"	f
-rtw_get_vht_highest_rate	core/rtw_vht.c	/^u8	rtw_get_vht_highest_rate(u8 *pvht_mcs_map)$/;"	f
-rtw_get_wait_hiq_empty_ms	core/rtw_debug.c	/^u32 rtw_get_wait_hiq_empty_ms(void)$/;"	f
-rtw_get_wapi_ie	core/rtw_ieee80211.c	/^int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len)$/;"	f
-rtw_get_wfd_attr	core/rtw_ieee80211.c	/^u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr)$/;"	f
-rtw_get_wfd_attr_content	core/rtw_ieee80211.c	/^u8 *rtw_get_wfd_attr_content(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content)$/;"	f
-rtw_get_wfd_ie	core/rtw_ieee80211.c	/^u8 *rtw_get_wfd_ie(u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)$/;"	f
-rtw_get_wireless_stats	os_dep/linux/ioctl_linux.c	/^static struct iw_statistics *rtw_get_wireless_stats(struct net_device *dev)$/;"	f	file:
-rtw_get_wpa2_cipher_suite	core/rtw_ieee80211.c	/^int rtw_get_wpa2_cipher_suite(u8 *s)$/;"	f
-rtw_get_wpa2_ie	core/rtw_ieee80211.c	/^unsigned char *rtw_get_wpa2_ie(unsigned char *pie, int *rsn_ie_len, int limit)$/;"	f
-rtw_get_wpa_cipher_suite	core/rtw_ieee80211.c	/^int rtw_get_wpa_cipher_suite(u8 *s)$/;"	f
-rtw_get_wpa_ie	core/rtw_ieee80211.c	/^unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit)$/;"	f
-rtw_get_wps_attr	core/rtw_ieee80211.c	/^u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_attr, u32 *len_attr)$/;"	f
-rtw_get_wps_attr_content	core/rtw_ieee80211.c	/^u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_content, uint *len_content)$/;"	f
-rtw_get_wps_ie	core/rtw_ieee80211.c	/^u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)$/;"	f
-rtw_get_wps_ie_from_scan_queue	core/rtw_ieee80211.c	/^u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, u8 frame_type)$/;"	f
-rtw_getbbreg_cmd	core/rtw_cmd.c	/^u8 rtw_getbbreg_cmd(_adapter  *padapter, u8 offset, u8 *pval)$/;"	f
-rtw_getbbrfreg_cmdrsp_callback	core/rtw_cmd.c	/^void rtw_getbbrfreg_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)$/;"	f
-rtw_getmacreg_cmd	core/rtw_cmd.c	/^u8 rtw_getmacreg_cmd(_adapter *padapter, u8 len, u32 addr)$/;"	f
-rtw_getmacreg_cmdrsp_callback	core/rtw_cmd.c	/^void rtw_getmacreg_cmdrsp_callback(_adapter *padapter,  struct cmd_obj *pcmd)$/;"	f
-rtw_getmacreg_hdl	core/rtw_mlme_ext.c	/^u8 rtw_getmacreg_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-rtw_getrfreg_cmd	core/rtw_cmd.c	/^u8 rtw_getrfreg_cmd(_adapter  *padapter, u8 offset, u8 *pval)$/;"	f
-rtw_getrttbl_cmd	core/rtw_cmd.c	/^u8 rtw_getrttbl_cmd(_adapter  *padapter, struct getratable_rsp *pval)$/;"	f
-rtw_getrttbl_cmd_cmdrsp_callback	core/rtw_cmd.c	/^void rtw_getrttbl_cmd_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)$/;"	f
-rtw_gtk_offload	os_dep/linux/rtw_android.c	/^int rtw_gtk_offload(struct net_device *net, u8 *cmd_ptr)$/;"	f
-rtw_gw_addr_query	os_dep/linux/os_intfs.c	/^int	rtw_gw_addr_query(_adapter *padapter)$/;"	f
-rtw_h2c_cmd	include/rtw_cmd.h	/^enum rtw_h2c_cmd {$/;"	g
-rtw_hal_antdiv_before_linked	hal/hal_com.c	/^u8	rtw_hal_antdiv_before_linked(_adapter *padapter)$/;"	f
-rtw_hal_antdiv_rssi_compared	hal/hal_com.c	/^void	rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src)$/;"	f
-rtw_hal_ap_wow_disable	hal/hal_com.c	/^static void rtw_hal_ap_wow_disable(_adapter *padapter)$/;"	f	file:
-rtw_hal_ap_wow_enable	hal/hal_com.c	/^static void rtw_hal_ap_wow_enable(_adapter *padapter)$/;"	f	file:
-rtw_hal_backup_rate	hal/hal_com.c	/^static void rtw_hal_backup_rate(_adapter *adapter)$/;"	f	file:
-rtw_hal_bcn_related_reg_setting	hal/hal_intf.c	/^void rtw_hal_bcn_related_reg_setting(_adapter *padapter)$/;"	f
-rtw_hal_busagg_qsel_check	hal/hal_com.c	/^inline u8 rtw_hal_busagg_qsel_check(_adapter *padapter, u8 pre_qsel, u8 next_qsel)$/;"	f
-rtw_hal_c2h_evt_read	hal/hal_intf.c	/^inline s32 rtw_hal_c2h_evt_read(_adapter *adapter, u8 *buf)$/;"	f
-rtw_hal_c2h_handler	hal/hal_intf.c	/^s32 rtw_hal_c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)$/;"	f
-rtw_hal_c2h_id_handle_directly	hal/hal_intf.c	/^s32 rtw_hal_c2h_id_handle_directly(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)$/;"	f
-rtw_hal_c2h_pkt_hdl	hal/hal_com.c	/^void rtw_hal_c2h_pkt_hdl(_adapter *adapter, u8 *buf, u16 len)$/;"	f
-rtw_hal_c2h_pkt_hdr_parse	hal/hal_intf.c	/^bool rtw_hal_c2h_pkt_hdr_parse(_adapter *adapter, u8 *buf, u16 len, u8 *id, u8 *seq, u8 *plen, u8 **payload)$/;"	f
-rtw_hal_c2h_pkt_pre_hdl	hal/hal_com.c	/^void rtw_hal_c2h_pkt_pre_hdl(_adapter *adapter, u8 *buf, u16 len)$/;"	f
-rtw_hal_c2h_reg_hdr_parse	hal/hal_intf.c	/^bool rtw_hal_c2h_reg_hdr_parse(_adapter *adapter, u8 *buf, u8 *id, u8 *seq, u8 *plen, u8 **payload)$/;"	f
-rtw_hal_c2h_valid	hal/hal_intf.c	/^inline bool rtw_hal_c2h_valid(_adapter *adapter, u8 *buf)$/;"	f
-rtw_hal_ch_sw_iqk_info_backup	hal/hal_com.c	/^void rtw_hal_ch_sw_iqk_info_backup(_adapter *padapter)$/;"	f
-rtw_hal_ch_sw_iqk_info_restore	hal/hal_com.c	/^void rtw_hal_ch_sw_iqk_info_restore(_adapter *padapter, u8 ch_sw_use_case)$/;"	f
-rtw_hal_ch_sw_iqk_info_search	hal/hal_com.c	/^s8 rtw_hal_ch_sw_iqk_info_search(_adapter *padapter, u8 central_chnl, u8 bw_mode)$/;"	f
-rtw_hal_ch_sw_oper_offload	hal/hal_com.c	/^s32 rtw_hal_ch_sw_oper_offload(_adapter *padapter, u8 channel, u8 channel_offset, u16 bwmode)$/;"	f
-rtw_hal_change_macaddr_mbid	hal/hal_com.c	/^void rtw_hal_change_macaddr_mbid(_adapter *adapter, u8 *mac_addr)$/;"	f
-rtw_hal_check_ips_status	hal/hal_intf.c	/^u8 rtw_hal_check_ips_status(_adapter *padapter)$/;"	f
-rtw_hal_check_mcc_status	hal/hal_mcc.c	/^u8 rtw_hal_check_mcc_status(PADAPTER padapter, u8 mcc_status)$/;"	f
-rtw_hal_check_pno_enabled	hal/hal_com.c	/^static u8 rtw_hal_check_pno_enabled(_adapter *adapter)$/;"	f	file:
-rtw_hal_check_rxfifo_full	hal/hal_com.c	/^void rtw_hal_check_rxfifo_full(_adapter *adapter)$/;"	f
-rtw_hal_check_wow_ctrl	hal/hal_com.c	/^static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)$/;"	f	file:
-rtw_hal_chip_configure	hal/hal_intf.c	/^void rtw_hal_chip_configure(_adapter *padapter)$/;"	f
-rtw_hal_clear_interrupt	hal/hal_intf.c	/^void rtw_hal_clear_interrupt(_adapter *padapter)$/;"	f
-rtw_hal_clear_mcc_macid	hal/hal_mcc.c	/^static void rtw_hal_clear_mcc_macid(PADAPTER padapter)$/;"	f	file:
-rtw_hal_clear_mcc_status	hal/hal_mcc.c	/^void rtw_hal_clear_mcc_status(PADAPTER padapter, u8 mcc_status)$/;"	f
-rtw_hal_config_gpio	hal/hal_com.c	/^int rtw_hal_config_gpio(_adapter *adapter, u8 gpio_num, bool isOutput)$/;"	f
-rtw_hal_config_mcc_role_setting	hal/hal_mcc.c	/^static void rtw_hal_config_mcc_role_setting(PADAPTER padapter)$/;"	f	file:
-rtw_hal_config_rftype	hal/hal_com.c	/^void rtw_hal_config_rftype(PADAPTER  padapter)$/;"	f
-rtw_hal_construct_ARPRsp	hal/hal_com.c	/^static void rtw_hal_construct_ARPRsp($/;"	f	file:
-rtw_hal_construct_CTS	hal/hal_mcc.c	/^static void rtw_hal_construct_CTS(PADAPTER padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-rtw_hal_construct_GTKRsp	hal/hal_com.c	/^static void rtw_hal_construct_GTKRsp($/;"	f	file:
-rtw_hal_construct_NullFunctionData	hal/hal_com.c	/^void rtw_hal_construct_NullFunctionData($/;"	f
-rtw_hal_construct_P2PBeacon	hal/hal_com.c	/^static void rtw_hal_construct_P2PBeacon(_adapter *padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-rtw_hal_construct_P2PInviteRsp	hal/hal_com.c	/^static void rtw_hal_construct_P2PInviteRsp(_adapter *padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-rtw_hal_construct_P2PNegoRsp	hal/hal_com.c	/^static void rtw_hal_construct_P2PNegoRsp(_adapter *padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-rtw_hal_construct_P2PProbeRsp	hal/hal_com.c	/^static void rtw_hal_construct_P2PProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-rtw_hal_construct_P2PProvisionDisRsp	hal/hal_com.c	/^static void rtw_hal_construct_P2PProvisionDisRsp(_adapter *padapter, u8 *pframe, u32 *pLength)$/;"	f	file:
-rtw_hal_construct_PNO_info	hal/hal_com.c	/^static void rtw_hal_construct_PNO_info(_adapter *padapter,$/;"	f	file:
-rtw_hal_construct_PSPoll	hal/hal_com.c	/^static void rtw_hal_construct_PSPoll(_adapter *padapter,$/;"	f	file:
-rtw_hal_construct_ProbeReq	hal/hal_com.c	/^static void rtw_hal_construct_ProbeReq(_adapter *padapter, u8 *pframe,$/;"	f	file:
-rtw_hal_construct_ProbeRsp	hal/hal_com.c	/^void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,$/;"	f
-rtw_hal_construct_beacon	hal/hal_com.c	/^static void rtw_hal_construct_beacon(_adapter *padapter,$/;"	f	file:
-rtw_hal_construct_scan_info	hal/hal_com.c	/^static void rtw_hal_construct_scan_info(_adapter *padapter,$/;"	f	file:
-rtw_hal_construct_ssid_list	hal/hal_com.c	/^static void rtw_hal_construct_ssid_list(_adapter *padapter,$/;"	f	file:
-rtw_hal_correct_tsf	hal/hal_com.c	/^void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf)$/;"	f
-rtw_hal_customer_str_read	hal/hal_com.c	/^s32 rtw_hal_customer_str_read(_adapter *adapter, u8 *cs)$/;"	f
-rtw_hal_customer_str_write	hal/hal_com.c	/^s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs)$/;"	f
-rtw_hal_data_deinit	hal/hal_intf.c	/^void rtw_hal_data_deinit(_adapter *padapter)$/;"	f
-rtw_hal_data_init	hal/hal_intf.c	/^u8 rtw_hal_data_init(_adapter *padapter)$/;"	f
-rtw_hal_decide_mcc_role	hal/hal_mcc.c	/^static u8 rtw_hal_decide_mcc_role(PADAPTER padapter)$/;"	f	file:
-rtw_hal_def_value_init	hal/hal_intf.c	/^void rtw_hal_def_value_init(_adapter *padapter)$/;"	f
-rtw_hal_deinit	hal/hal_intf.c	/^uint rtw_hal_deinit(_adapter *padapter)$/;"	f
-rtw_hal_disable_gpio_interrupt	hal/hal_com.c	/^int rtw_hal_disable_gpio_interrupt(_adapter *adapter, int gpio_num)$/;"	f
-rtw_hal_disable_interrupt	hal/hal_intf.c	/^void rtw_hal_disable_interrupt(_adapter *padapter)$/;"	f
-rtw_hal_disable_tx_report	hal/hal_com.c	/^static void rtw_hal_disable_tx_report(_adapter *adapter)$/;"	f	file:
-rtw_hal_dl_mcc_fw_rsvd_page	hal/hal_mcc.c	/^u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index,$/;"	f
-rtw_hal_dl_pattern	hal/hal_com.c	/^static void rtw_hal_dl_pattern(_adapter *adapter, u8 mode)$/;"	f	file:
-rtw_hal_dm_deinit	hal/hal_intf.c	/^void rtw_hal_dm_deinit(_adapter *padapter)$/;"	f
-rtw_hal_dm_init	hal/hal_intf.c	/^void rtw_hal_dm_init(_adapter *padapter)$/;"	f
-rtw_hal_dm_watchdog	hal/hal_intf.c	/^void	rtw_hal_dm_watchdog(_adapter *padapter)$/;"	f
-rtw_hal_dm_watchdog_in_lps	hal/hal_intf.c	/^void	rtw_hal_dm_watchdog_in_lps(_adapter *padapter)$/;"	f
-rtw_hal_dump_macaddr	hal/hal_com.c	/^void rtw_hal_dump_macaddr(void *sel, _adapter *adapter)$/;"	f
-rtw_hal_dump_mcc_info	hal/hal_mcc.c	/^void rtw_hal_dump_mcc_info(void *sel, struct dvobj_priv *dvobj)$/;"	f
-rtw_hal_enable_cpwm2	hal/hal_com.c	/^static u8 rtw_hal_enable_cpwm2(_adapter *adapter)$/;"	f	file:
-rtw_hal_enable_interrupt	hal/hal_intf.c	/^void rtw_hal_enable_interrupt(_adapter *padapter)$/;"	f
-rtw_hal_enable_tx_report	hal/hal_com.c	/^static void rtw_hal_enable_tx_report(_adapter *adapter)$/;"	f	file:
-rtw_hal_error_msg	hal/hal_intf.c	1001;"	d	file:
-rtw_hal_fill_fake_txdesc	hal/hal_intf.c	/^void rtw_hal_fill_fake_txdesc(_adapter *padapter, u8 *pDesc, u32 BufferLen,$/;"	f
-rtw_hal_fill_h2c_cmd	hal/hal_intf.c	/^s32 rtw_hal_fill_h2c_cmd(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)$/;"	f
-rtw_hal_force_enable_rxdma	hal/hal_com.c	/^static void rtw_hal_force_enable_rxdma(_adapter *adapter)$/;"	f	file:
-rtw_hal_free_data	hal/hal_intf.c	/^void	rtw_hal_free_data(_adapter *padapter)$/;"	f
-rtw_hal_free_recv_priv	hal/hal_intf.c	/^void	rtw_hal_free_recv_priv(_adapter *padapter)$/;"	f
-rtw_hal_free_xmit_priv	hal/hal_intf.c	/^void	rtw_hal_free_xmit_priv(_adapter *padapter)$/;"	f
-rtw_hal_fw_correct_bcn	hal/hal_intf.c	/^void rtw_hal_fw_correct_bcn(_adapter *padapter)$/;"	f
-rtw_hal_fw_dl	hal/hal_intf.c	/^s32 rtw_hal_fw_dl(_adapter *padapter, u8 wowlan)$/;"	f
-rtw_hal_fw_sync_cam_id	hal/hal_com.c	/^static void rtw_hal_fw_sync_cam_id(_adapter *adapter)$/;"	f	file:
-rtw_hal_gate_bb	hal/hal_com.c	/^static void rtw_hal_gate_bb(_adapter *adapter, bool stop)$/;"	f	file:
-rtw_hal_get_aoac_rpt	hal/hal_com.c	/^static void rtw_hal_get_aoac_rpt(_adapter *adapter)$/;"	f	file:
-rtw_hal_get_def_var	hal/hal_intf.c	/^u8 rtw_hal_get_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue)$/;"	f
-rtw_hal_get_gpio	hal/hal_com.c	/^u8 rtw_hal_get_gpio(_adapter *adapter, u8 gpio_num)$/;"	f
-rtw_hal_get_hwreg	hal/hal_intf.c	/^void rtw_hal_get_hwreg(_adapter *padapter, u8 variable, u8 *val)$/;"	f
-rtw_hal_get_macaddr_port	hal/hal_com.c	/^void rtw_hal_get_macaddr_port(_adapter *adapter, u8 *mac_addr)$/;"	f
-rtw_hal_get_msr	hal/hal_com.c	/^void rtw_hal_get_msr(_adapter *adapter, u8 *net_type)$/;"	f
-rtw_hal_get_odm_var	hal/hal_intf.c	/^void	rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, PVOID pValue2)$/;"	f
-rtw_hal_get_rsvd_page	hal/hal_com.c	/^static bool rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset,$/;"	f	file:
-rtw_hal_get_sdio_tx_max_length	hal/hal_hci/hal_sdio.c	/^u32 rtw_hal_get_sdio_tx_max_length(PADAPTER padapter, u8 queue_idx)$/;"	f
-rtw_hal_get_tx_power_index	hal/hal_intf.c	/^u8 rtw_hal_get_tx_power_index(PADAPTER padapter, u8 rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic)$/;"	f
-rtw_hal_get_tx_power_level	hal/hal_intf.c	/^void	rtw_hal_get_tx_power_level(_adapter *padapter, s32 *powerlevel)$/;"	f
-rtw_hal_get_txbuff_rsvd_page_num	hal/hal_intf.c	/^u8 rtw_hal_get_txbuff_rsvd_page_num(_adapter *adapter, bool wowlan)$/;"	f
-rtw_hal_gpio_func_check	hal/hal_intf.c	/^int rtw_hal_gpio_func_check(_adapter *padapter, u8 gpio_num)$/;"	f
-rtw_hal_gpio_multi_func_reset	hal/hal_intf.c	/^void rtw_hal_gpio_multi_func_reset(_adapter *padapter, u8 gpio_num)$/;"	f
-rtw_hal_h2c_customer_str_req	hal/hal_com.c	/^s32 rtw_hal_h2c_customer_str_req(_adapter *adapter)$/;"	f
-rtw_hal_h2c_customer_str_write	hal/hal_com.c	/^s32 rtw_hal_h2c_customer_str_write(_adapter *adapter, const u8 *cs)$/;"	f
-rtw_hal_hostap_mgnt_xmit_entry	hal/hal_intf.c	/^s32	rtw_hal_hostap_mgnt_xmit_entry(_adapter *padapter, _pkt *pkt)$/;"	f
-rtw_hal_inirp_deinit	hal/hal_intf.c	/^u32	rtw_hal_inirp_deinit(_adapter *padapter)$/;"	f
-rtw_hal_inirp_init	hal/hal_intf.c	/^u32	rtw_hal_inirp_init(_adapter *padapter)$/;"	f
-rtw_hal_init	hal/hal_intf.c	/^uint	 rtw_hal_init(_adapter *padapter)$/;"	f
-rtw_hal_init_mac_register	hal/hal_intf.c	/^u8 rtw_hal_init_mac_register(PADAPTER adapter)$/;"	f
-rtw_hal_init_mcc_parameter	hal/hal_mcc.c	/^static void rtw_hal_init_mcc_parameter(PADAPTER padapter)$/;"	f	file:
-rtw_hal_init_opmode	hal/hal_intf.c	/^void rtw_hal_init_opmode(_adapter *padapter)$/;"	f
-rtw_hal_init_phy	hal/hal_intf.c	/^u8 rtw_hal_init_phy(PADAPTER adapter)$/;"	f
-rtw_hal_init_recv_priv	hal/hal_intf.c	/^s32	rtw_hal_init_recv_priv(_adapter *padapter)$/;"	f
-rtw_hal_init_xmit_priv	hal/hal_intf.c	/^s32	rtw_hal_init_xmit_priv(_adapter *padapter)$/;"	f
-rtw_hal_interrupt_handler	hal/hal_intf.c	/^s32	rtw_hal_interrupt_handler(_adapter *padapter)$/;"	f
-rtw_hal_interrupt_handler	hal/hal_intf.c	/^void	rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf)$/;"	f
-rtw_hal_intf_ps_func	hal/hal_intf.c	/^u8	rtw_hal_intf_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val)$/;"	f
-rtw_hal_iol_cmd	hal/hal_intf.c	/^int rtw_hal_iol_cmd(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt)$/;"	f
-rtw_hal_irp_reset	hal/hal_intf.c	/^void	rtw_hal_irp_reset(_adapter *padapter)$/;"	f
-rtw_hal_is_disable_sw_channel_plan	hal/hal_intf.c	/^s32 rtw_hal_is_disable_sw_channel_plan(PADAPTER padapter)$/;"	f
-rtw_hal_macid_sleep	hal/hal_intf.c	/^s32 rtw_hal_macid_sleep(PADAPTER padapter, u8 macid)$/;"	f
-rtw_hal_macid_wakeup	hal/hal_intf.c	/^s32 rtw_hal_macid_wakeup(PADAPTER padapter, u8 macid)$/;"	f
-rtw_hal_mcc_backup_IQK_val	hal/hal_mcc.c	/^void rtw_hal_mcc_backup_IQK_val(PADAPTER padapter)$/;"	f
-rtw_hal_mcc_c2h_handler	hal/hal_mcc.c	/^void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf)$/;"	f
-rtw_hal_mcc_calc_tx_bytes_from_kernel	hal/hal_mcc.c	/^inline void rtw_hal_mcc_calc_tx_bytes_from_kernel(PADAPTER padapter, u32 len)$/;"	f
-rtw_hal_mcc_calc_tx_bytes_to_port	hal/hal_mcc.c	/^inline void rtw_hal_mcc_calc_tx_bytes_to_port(PADAPTER padapter, u32 len)$/;"	f
-rtw_hal_mcc_change_scan_flag	hal/hal_mcc.c	/^u8 rtw_hal_mcc_change_scan_flag(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset)$/;"	f
-rtw_hal_mcc_check_case_not_limit_traffic	hal/hal_mcc.c	/^static void rtw_hal_mcc_check_case_not_limit_traffic(PADAPTER cur_iface, PADAPTER next_iface)$/;"	f	file:
-rtw_hal_mcc_issue_null_data	hal/hal_mcc.c	/^void rtw_hal_mcc_issue_null_data(_adapter *padapter, u8 chbw_allow, u8 ps_mode)$/;"	f
-rtw_hal_mcc_link_status_chk	hal/hal_mcc.c	/^inline u8 rtw_hal_mcc_link_status_chk(_adapter *padapter, const char *msg)$/;"	f
-rtw_hal_mcc_start_posthdl	hal/hal_mcc.c	/^static void rtw_hal_mcc_start_posthdl(PADAPTER padapter)$/;"	f	file:
-rtw_hal_mcc_status_hdl	hal/hal_mcc.c	/^static void rtw_hal_mcc_status_hdl(PADAPTER padapter, u8 status)$/;"	f	file:
-rtw_hal_mcc_stop_posthdl	hal/hal_mcc.c	/^static void rtw_hal_mcc_stop_posthdl(PADAPTER padapter)$/;"	f	file:
-rtw_hal_mcc_stop_tx_bytes_to_port	hal/hal_mcc.c	/^inline u8 rtw_hal_mcc_stop_tx_bytes_to_port(PADAPTER padapter)$/;"	f
-rtw_hal_mcc_sw_ch_fw_notify_hdl	hal/hal_mcc.c	/^static void rtw_hal_mcc_sw_ch_fw_notify_hdl(PADAPTER padapter)$/;"	f	file:
-rtw_hal_mcc_sw_status_check	hal/hal_mcc.c	/^void rtw_hal_mcc_sw_status_check(PADAPTER padapter)$/;"	f
-rtw_hal_mgnt_xmit	hal/hal_intf.c	/^s32	rtw_hal_mgnt_xmit(_adapter *padapter, struct xmit_frame *pmgntframe)$/;"	f
-rtw_hal_move_sta_gk_to_dk	hal/hal_com.c	/^void rtw_hal_move_sta_gk_to_dk(_adapter *adapter)$/;"	f
-rtw_hal_networktype_to_raid	hal/hal_com.c	/^u8  rtw_hal_networktype_to_raid(_adapter *adapter, struct sta_info *psta)$/;"	f
-rtw_hal_notch_filter	hal/hal_intf.c	/^void rtw_hal_notch_filter(_adapter *adapter, bool enable)$/;"	f
-rtw_hal_ops_check	hal/hal_intf.c	/^u8 rtw_hal_ops_check(_adapter *padapter)$/;"	f
-rtw_hal_pause_rx_dma	hal/hal_com.c	/^static u8 rtw_hal_pause_rx_dma(_adapter *adapter)$/;"	f	file:
-rtw_hal_port_reconfig	hal/hal_com.c	/^void rtw_hal_port_reconfig(_adapter *adapter, u8 port)$/;"	f
-rtw_hal_power_off	hal/hal_intf.c	/^void rtw_hal_power_off(_adapter *padapter)$/;"	f
-rtw_hal_power_on	hal/hal_intf.c	/^u32 rtw_hal_power_on(_adapter *padapter)$/;"	f
-rtw_hal_query_txbfee_rf_num	hal/hal_com.c	/^u8 rtw_hal_query_txbfee_rf_num(_adapter *adapter)$/;"	f
-rtw_hal_query_txbfer_rf_num	hal/hal_com.c	/^u8 rtw_hal_query_txbfer_rf_num(_adapter *adapter)$/;"	f
-rtw_hal_read_bbreg	hal/hal_intf.c	/^u32	rtw_hal_read_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask)$/;"	f
-rtw_hal_read_chip_info	hal/hal_intf.c	/^void rtw_hal_read_chip_info(_adapter *padapter)$/;"	f
-rtw_hal_read_chip_version	hal/hal_intf.c	/^void rtw_hal_read_chip_version(_adapter *padapter)$/;"	f
-rtw_hal_read_rfreg	hal/hal_intf.c	/^u32 rtw_hal_read_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask)$/;"	f
-rtw_hal_read_sta_dk_key	hal/hal_com.c	/^void rtw_hal_read_sta_dk_key(_adapter *adapter, u8 key_id)$/;"	f
-rtw_hal_register_gpio_interrupt	hal/hal_com.c	/^int rtw_hal_register_gpio_interrupt(_adapter *adapter, int gpio_num, void(*callback)(u8 level))$/;"	f
-rtw_hal_release_rx_dma	hal/hal_com.c	/^static void rtw_hal_release_rx_dma(_adapter *adapter)$/;"	f	file:
-rtw_hal_reset_mac_rx	hal/hal_com.c	/^static void rtw_hal_reset_mac_rx(_adapter *adapter)$/;"	f	file:
-rtw_hal_sdio_max_txoqt_free_space	hal/hal_hci/hal_sdio.c	/^u8 rtw_hal_sdio_max_txoqt_free_space(_adapter *padapter)$/;"	f
-rtw_hal_sdio_query_tx_freepage	hal/hal_hci/hal_sdio.c	/^u8 rtw_hal_sdio_query_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum)$/;"	f
-rtw_hal_sdio_update_tx_freepage	hal/hal_hci/hal_sdio.c	/^void rtw_hal_sdio_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum)$/;"	f
-rtw_hal_set_FwAoacRsvdPage_cmd	hal/hal_com.c	/^void rtw_hal_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)$/;"	f
-rtw_hal_set_FwMediaStatusRpt_cmd	hal/hal_com.c	/^s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, bool macid_ind, u8 macid_end)$/;"	f
-rtw_hal_set_FwMediaStatusRpt_range_cmd	hal/hal_com.c	/^inline s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end)$/;"	f
-rtw_hal_set_FwMediaStatusRpt_single_cmd	hal/hal_com.c	/^inline s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid)$/;"	f
-rtw_hal_set_FwP2PRsvdPage_cmd	hal/hal_com.c	/^u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc)$/;"	f
-rtw_hal_set_FwRsvdPage_cmd	hal/hal_com.c	/^void rtw_hal_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)$/;"	f
-rtw_hal_set_ap_offload_ctrl_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_ap_offload_ctrl_cmd(_adapter *adapter, u8 enable)$/;"	f	file:
-rtw_hal_set_ap_ps_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_ap_ps_cmd(_adapter *adapter, u8 enable)$/;"	f	file:
-rtw_hal_set_ap_rsvdpage_loc_cmd	hal/hal_com.c	/^static void rtw_hal_set_ap_rsvdpage_loc_cmd(PADAPTER padapter,$/;"	f	file:
-rtw_hal_set_ap_wowlan_ctrl_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_ap_wowlan_ctrl_cmd(_adapter *adapter, u8 enable)$/;"	f	file:
-rtw_hal_set_bssid	hal/hal_com.c	/^void rtw_hal_set_bssid(_adapter *adapter, u8 *val)$/;"	f
-rtw_hal_set_chnl_bw	hal/hal_intf.c	/^void	rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth, u8 Offset40, u8 Offset80)$/;"	f
-rtw_hal_set_def_var	hal/hal_intf.c	/^u8 rtw_hal_set_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue)$/;"	f
-rtw_hal_set_disconnect_decision_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_disconnect_decision_cmd(_adapter *adapter, u8 enable)$/;"	f	file:
-rtw_hal_set_fw_ap_wow_related_cmd	hal/hal_com.c	/^static void rtw_hal_set_fw_ap_wow_related_cmd(_adapter *padapter, u8 enable)$/;"	f	file:
-rtw_hal_set_fw_mcc_rsvd_page	hal/hal_mcc.c	/^static void rtw_hal_set_fw_mcc_rsvd_page(PADAPTER padapter)$/;"	f	file:
-rtw_hal_set_fw_rsvd_page	hal/hal_com.c	/^void rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished)$/;"	f
-rtw_hal_set_fw_wow_related_cmd	hal/hal_com.c	/^void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable)$/;"	f
-rtw_hal_set_global_info_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_global_info_cmd(_adapter *adapter, u8 group_alg, u8 pairwise_alg)$/;"	f	file:
-rtw_hal_set_gpio_output_value	hal/hal_com.c	/^int  rtw_hal_set_gpio_output_value(_adapter *adapter, u8 gpio_num, bool isHigh)$/;"	f
-rtw_hal_set_hw_update_tsf	hal/hal_com.c	/^static void rtw_hal_set_hw_update_tsf(PADAPTER padapter)$/;"	f	file:
-rtw_hal_set_hwreg	hal/hal_intf.c	/^void rtw_hal_set_hwreg(_adapter *padapter, u8 variable, u8 *val)$/;"	f
-rtw_hal_set_keep_alive_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_keep_alive_cmd(_adapter *adapter, u8 enable, u8 pkt_type)$/;"	f	file:
-rtw_hal_set_lps_pg_info	hal/hal_com.c	/^u8 rtw_hal_set_lps_pg_info(_adapter *adapter)$/;"	f
-rtw_hal_set_lps_pg_info_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_lps_pg_info_cmd(_adapter *adapter)$/;"	f	file:
-rtw_hal_set_lps_pg_info_rsvd_page	hal/hal_com.c	/^static void rtw_hal_set_lps_pg_info_rsvd_page(_adapter *adapter)$/;"	f	file:
-rtw_hal_set_macaddr_mbid	hal/hal_com.c	/^void rtw_hal_set_macaddr_mbid(_adapter *adapter, u8 *mac_addr)$/;"	f
-rtw_hal_set_macaddr_port	hal/hal_com.c	/^void rtw_hal_set_macaddr_port(_adapter *adapter, u8 *val)$/;"	f
-rtw_hal_set_mcc_IQK_offload_cmd	hal/hal_mcc.c	/^static void rtw_hal_set_mcc_IQK_offload_cmd(PADAPTER padapter)$/;"	f	file:
-rtw_hal_set_mcc_macid_cmd	hal/hal_mcc.c	/^static void rtw_hal_set_mcc_macid_cmd(PADAPTER padapter)$/;"	f	file:
-rtw_hal_set_mcc_noa_cmd	hal/hal_mcc.c	/^static void rtw_hal_set_mcc_noa_cmd(PADAPTER padapter)$/;"	f	file:
-rtw_hal_set_mcc_parameter_cmd	hal/hal_mcc.c	/^static void rtw_hal_set_mcc_parameter_cmd(PADAPTER padapter, u8 stop)$/;"	f	file:
-rtw_hal_set_mcc_rsvdpage_cmd	hal/hal_mcc.c	/^static void rtw_hal_set_mcc_rsvdpage_cmd(_adapter *padapter)$/;"	f	file:
-rtw_hal_set_mcc_setting	hal/hal_mcc.c	/^static u8 rtw_hal_set_mcc_setting(PADAPTER padapter, u8 status)$/;"	f	file:
-rtw_hal_set_mcc_setting_chk_start_clnt_join	hal/hal_mcc.c	/^u8 rtw_hal_set_mcc_setting_chk_start_clnt_join(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset, u8 chbw_allow)$/;"	f
-rtw_hal_set_mcc_setting_disconnect	hal/hal_mcc.c	/^u8 rtw_hal_set_mcc_setting_disconnect(PADAPTER padapter)$/;"	f
-rtw_hal_set_mcc_setting_join_done_chk_ch	hal/hal_mcc.c	/^u8 rtw_hal_set_mcc_setting_join_done_chk_ch(PADAPTER padapter)$/;"	f
-rtw_hal_set_mcc_setting_scan_complete	hal/hal_mcc.c	/^u8 rtw_hal_set_mcc_setting_scan_complete(PADAPTER padapter)$/;"	f
-rtw_hal_set_mcc_setting_scan_start	hal/hal_mcc.c	/^u8 rtw_hal_set_mcc_setting_scan_start(PADAPTER padapter)$/;"	f
-rtw_hal_set_mcc_setting_start_bss_network	hal/hal_mcc.c	/^u8 rtw_hal_set_mcc_setting_start_bss_network(PADAPTER padapter, u8 chbw_allow)$/;"	f
-rtw_hal_set_mcc_start_setting	hal/hal_mcc.c	/^static u8 rtw_hal_set_mcc_start_setting(PADAPTER padapter, u8 status)$/;"	f	file:
-rtw_hal_set_mcc_status	hal/hal_mcc.c	/^void rtw_hal_set_mcc_status(PADAPTER padapter, u8 mcc_status)$/;"	f
-rtw_hal_set_mcc_stop_setting	hal/hal_mcc.c	/^static void rtw_hal_set_mcc_stop_setting(PADAPTER padapter, u8 status)$/;"	f	file:
-rtw_hal_set_msr	hal/hal_com.c	/^void rtw_hal_set_msr(_adapter *adapter, u8 net_type)$/;"	f
-rtw_hal_set_odm_var	hal/hal_intf.c	/^void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1, BOOLEAN bSet)$/;"	f
-rtw_hal_set_output_gpio	hal/hal_com.c	/^void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval)$/;"	f
-rtw_hal_set_p2p_wow_fw_rsvd_page	hal/hal_com.c	/^void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,$/;"	f
-rtw_hal_set_p2p_wowlan_offload_cmd	hal/hal_com.c	/^u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter)$/;"	f
-rtw_hal_set_pattern	hal/hal_com.c	/^static int rtw_hal_set_pattern(_adapter *adapter, u8 *pattern,$/;"	f	file:
-rtw_hal_set_remote_wake_ctrl_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_remote_wake_ctrl_cmd(_adapter *adapter, u8 enable)$/;"	f	file:
-rtw_hal_set_scan_offload_info_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_scan_offload_info_cmd(_adapter *adapter,$/;"	f	file:
-rtw_hal_set_sdio_tx_max_length	hal/hal_hci/hal_sdio.c	/^void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ)$/;"	f
-rtw_hal_set_tx_power_index	hal/hal_intf.c	/^void rtw_hal_set_tx_power_index(PADAPTER padapter, u32 powerindex, u8 rfpath, u8 rate)$/;"	f
-rtw_hal_set_tx_power_level	hal/hal_intf.c	/^void	rtw_hal_set_tx_power_level(_adapter *padapter, u8 channel)$/;"	f
-rtw_hal_set_wow_fw_rsvd_page	hal/hal_com.c	/^void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,$/;"	f
-rtw_hal_set_wow_rxff_boundary	hal/hal_com.c	/^static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)$/;"	f	file:
-rtw_hal_set_wowlan_ctrl_cmd	hal/hal_com.c	/^static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_unit)$/;"	f	file:
-rtw_hal_sreset_get_wifi_status	hal/hal_intf.c	/^u8   rtw_hal_sreset_get_wifi_status(_adapter *padapter)$/;"	f
-rtw_hal_sreset_init	hal/hal_intf.c	/^void	rtw_hal_sreset_init(_adapter *padapter)$/;"	f
-rtw_hal_sreset_inprogress	hal/hal_intf.c	/^bool rtw_hal_sreset_inprogress(_adapter *padapter)$/;"	f
-rtw_hal_sreset_linked_status_check	hal/hal_intf.c	/^void rtw_hal_sreset_linked_status_check(_adapter *padapter)$/;"	f
-rtw_hal_sreset_reset	hal/hal_intf.c	/^void rtw_hal_sreset_reset(_adapter *padapter)$/;"	f
-rtw_hal_sreset_reset_value	hal/hal_intf.c	/^void rtw_hal_sreset_reset_value(_adapter *padapter)$/;"	f
-rtw_hal_sreset_xmit_status_check	hal/hal_intf.c	/^void rtw_hal_sreset_xmit_status_check(_adapter *padapter)$/;"	f
-rtw_hal_start_thread	hal/hal_intf.c	/^void	rtw_hal_start_thread(_adapter *padapter)$/;"	f
-rtw_hal_stop_thread	hal/hal_intf.c	/^void	rtw_hal_stop_thread(_adapter *padapter)$/;"	f
-rtw_hal_sw_led_deinit	hal/hal_intf.c	/^void rtw_hal_sw_led_deinit(_adapter *padapter)$/;"	f
-rtw_hal_sw_led_init	hal/hal_intf.c	/^void	rtw_hal_sw_led_init(_adapter *padapter)$/;"	f
-rtw_hal_switch_gpio_wl_ctrl	hal/hal_com.c	/^void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable)$/;"	f
-rtw_hal_update_gtk_offload_info	hal/hal_com.c	/^static void rtw_hal_update_gtk_offload_info(_adapter *adapter)$/;"	f	file:
-rtw_hal_update_hisr_hsisr_ind	hal/hal_intf.c	/^void rtw_hal_update_hisr_hsisr_ind(_adapter *padapter, u32 flag)$/;"	f
-rtw_hal_update_ra_mask	hal/hal_intf.c	/^void rtw_hal_update_ra_mask(struct sta_info *psta, u8 rssi_level)$/;"	f
-rtw_hal_update_sta_rate_mask	hal/hal_com.c	/^void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta)$/;"	f
-rtw_hal_update_sw_security_info	hal/hal_com.c	/^static void rtw_hal_update_sw_security_info(_adapter *adapter)$/;"	f	file:
-rtw_hal_update_tx_iv	hal/hal_com.c	/^static void rtw_hal_update_tx_iv(_adapter *adapter)$/;"	f	file:
-rtw_hal_wow_disable	hal/hal_com.c	/^static void rtw_hal_wow_disable(_adapter *adapter)$/;"	f	file:
-rtw_hal_wow_enable	hal/hal_com.c	/^static void rtw_hal_wow_enable(_adapter *adapter)$/;"	f	file:
-rtw_hal_write_bbreg	hal/hal_intf.c	/^void	rtw_hal_write_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data)$/;"	f
-rtw_hal_write_rfreg	hal/hal_intf.c	/^void rtw_hal_write_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask, u32 Data)$/;"	f
-rtw_hal_xmit	hal/hal_intf.c	/^s32	rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtw_hal_xmit_thread_handler	hal/hal_intf.c	/^s32 rtw_hal_xmit_thread_handler(_adapter *padapter)$/;"	f
-rtw_hal_xmitframe_enqueue	hal/hal_intf.c	/^s32	rtw_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtw_halmac_c2h_handle	hal/hal_halmac.c	/^int rtw_halmac_c2h_handle(struct dvobj_priv *d, u8 *c2h, u32 size)$/;"	f
-rtw_halmac_config_rx_info	hal/hal_halmac.c	/^int rtw_halmac_config_rx_info(struct dvobj_priv *d, HALMAC_DRV_INFO info)$/;"	f
-rtw_halmac_deinit_adapter	hal/hal_halmac.c	/^int rtw_halmac_deinit_adapter(struct dvobj_priv *d)$/;"	f
-rtw_halmac_deinit_hal	hal/hal_halmac.c	/^int rtw_halmac_deinit_hal(struct dvobj_priv *d)$/;"	f
-rtw_halmac_dlfw	hal/hal_halmac.c	/^int rtw_halmac_dlfw(struct dvobj_priv *d, u8 *fw, u32 fwsize)$/;"	f
-rtw_halmac_dlfw_from_file	hal/hal_halmac.c	/^int rtw_halmac_dlfw_from_file(struct dvobj_priv *d, u8 *fwpath)$/;"	f
-rtw_halmac_download_rsvd_page	hal/hal_halmac.c	/^int rtw_halmac_download_rsvd_page(struct dvobj_priv *dvobj, u8 pg_offset, u8 *pbuf, u32 size)$/;"	f
-rtw_halmac_dump_fifo	hal/hal_halmac.c	/^int rtw_halmac_dump_fifo(struct dvobj_priv *d, HAL_FIFO_SEL halmac_fifo_sel)$/;"	f
-rtw_halmac_get_drv_info_sz	hal/hal_halmac.c	/^int rtw_halmac_get_drv_info_sz(struct dvobj_priv *d, u8 *sz)$/;"	f
-rtw_halmac_get_hw_value	hal/hal_halmac.c	/^int rtw_halmac_get_hw_value(struct dvobj_priv *d, HALMAC_HW_ID hw_id, VOID *pvalue)$/;"	f
-rtw_halmac_get_logical_efuse_size	hal/hal_halmac.c	/^int rtw_halmac_get_logical_efuse_size(struct dvobj_priv *d, u32 *size)$/;"	f
-rtw_halmac_get_physical_efuse_size	hal/hal_halmac.c	/^int rtw_halmac_get_physical_efuse_size(struct dvobj_priv *d, u32 *size)$/;"	f
-rtw_halmac_get_rsvd_drv_pg_bndy	hal/hal_halmac.c	/^int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *dvobj, u16 *drv_pg)$/;"	f
-rtw_halmac_get_tx_queue_page_num	hal/hal_halmac.c	/^int rtw_halmac_get_tx_queue_page_num(struct dvobj_priv *d, u8 queue, u32 *page)$/;"	f
-rtw_halmac_get_wow_reason	hal/hal_halmac.c	/^int rtw_halmac_get_wow_reason(struct dvobj_priv *d, u8 *reason)$/;"	f
-rtw_halmac_init_adapter	hal/hal_halmac.c	/^int rtw_halmac_init_adapter(struct dvobj_priv *d, PHALMAC_PLATFORM_API pf_api)$/;"	f
-rtw_halmac_init_hal	hal/hal_halmac.c	/^int rtw_halmac_init_hal(struct dvobj_priv *d)$/;"	f
-rtw_halmac_init_hal_fw	hal/hal_halmac.c	/^int rtw_halmac_init_hal_fw(struct dvobj_priv *d, u8 *fw, u32 fwsize)$/;"	f
-rtw_halmac_init_hal_fw_file	hal/hal_halmac.c	/^int rtw_halmac_init_hal_fw_file(struct dvobj_priv *d, u8 *fwpath)$/;"	f
-rtw_halmac_iread16	hal/hal_halmac.c	/^u16 rtw_halmac_iread16(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-rtw_halmac_iread32	hal/hal_halmac.c	/^u32 rtw_halmac_iread32(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-rtw_halmac_iread8	hal/hal_halmac.c	/^u8 rtw_halmac_iread8(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-rtw_halmac_phy_power_switch	hal/hal_halmac.c	/^int rtw_halmac_phy_power_switch(struct dvobj_priv *d, u8 enable)$/;"	f
-rtw_halmac_platform_api	hal/hal_halmac.c	/^HALMAC_PLATFORM_API rtw_halmac_platform_api = {$/;"	v
-rtw_halmac_poweroff	hal/hal_halmac.c	/^int rtw_halmac_poweroff(struct dvobj_priv *d)$/;"	f
-rtw_halmac_poweron	hal/hal_halmac.c	/^int rtw_halmac_poweron(struct dvobj_priv *d)$/;"	f
-rtw_halmac_query_tx_page_num	hal/hal_halmac.c	/^int rtw_halmac_query_tx_page_num(struct dvobj_priv *d)$/;"	f
-rtw_halmac_read16	hal/hal_halmac.c	/^u16 rtw_halmac_read16(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-rtw_halmac_read32	hal/hal_halmac.c	/^u32 rtw_halmac_read32(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-rtw_halmac_read8	hal/hal_halmac.c	/^u8 rtw_halmac_read8(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-rtw_halmac_read_bt_physical_efuse_map	hal/hal_halmac.c	/^int rtw_halmac_read_bt_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)$/;"	f
-rtw_halmac_read_logical_efuse	hal/hal_halmac.c	/^int rtw_halmac_read_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)$/;"	f
-rtw_halmac_read_logical_efuse_map	hal/hal_halmac.c	/^int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)$/;"	f
-rtw_halmac_read_mem	hal/hal_halmac.c	/^void rtw_halmac_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem)$/;"	f
-rtw_halmac_read_physical_efuse	hal/hal_halmac.c	/^int rtw_halmac_read_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)$/;"	f
-rtw_halmac_read_physical_efuse_map	hal/hal_halmac.c	/^int rtw_halmac_read_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)$/;"	f
-rtw_halmac_rx_agg_switch	hal/hal_halmac.c	/^int rtw_halmac_rx_agg_switch(struct dvobj_priv *d, u8 enable)$/;"	f
-rtw_halmac_sdio_get_rx_addr	hal/hal_halmac.c	/^u32 rtw_halmac_sdio_get_rx_addr(struct dvobj_priv *d, u8 *seq)$/;"	f
-rtw_halmac_sdio_get_tx_addr	hal/hal_halmac.c	/^u32 rtw_halmac_sdio_get_tx_addr(struct dvobj_priv *d, u8 *desc, u32 size)$/;"	f
-rtw_halmac_sdio_tx_allowed	hal/hal_halmac.c	/^int rtw_halmac_sdio_tx_allowed(struct dvobj_priv *d, u8 *buf, u32 size)$/;"	f
-rtw_halmac_self_verify	hal/hal_halmac.c	/^int rtw_halmac_self_verify(struct dvobj_priv *d)$/;"	f
-rtw_halmac_send_h2c	hal/hal_halmac.c	/^int rtw_halmac_send_h2c(struct dvobj_priv *d, u8 *h2c)$/;"	f
-rtw_halmac_set_bandwidth	hal/hal_halmac.c	/^int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8 bw)$/;"	f
-rtw_halmac_set_bssid	hal/hal_halmac.c	/^int rtw_halmac_set_bssid(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)$/;"	f
-rtw_halmac_set_mac_address	hal/hal_halmac.c	/^int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)$/;"	f
-rtw_halmac_switch_usb_mode	hal/hal_halmac.c	/^u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode)$/;"	f
-rtw_halmac_usb_get_bulkout_id	hal/hal_halmac.c	/^u8 rtw_halmac_usb_get_bulkout_id(struct dvobj_priv *d, u8 *buf, u32 size)$/;"	f
-rtw_halmac_write16	hal/hal_halmac.c	/^int rtw_halmac_write16(struct intf_hdl *pintfhdl, u32 addr, u16 value)$/;"	f
-rtw_halmac_write32	hal/hal_halmac.c	/^int rtw_halmac_write32(struct intf_hdl *pintfhdl, u32 addr, u32 value)$/;"	f
-rtw_halmac_write8	hal/hal_halmac.c	/^int rtw_halmac_write8(struct intf_hdl *pintfhdl, u32 addr, u8 value)$/;"	f
-rtw_halmac_write_bt_physical_efuse	hal/hal_halmac.c	/^int rtw_halmac_write_bt_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)$/;"	f
-rtw_halmac_write_logical_efuse	hal/hal_halmac.c	/^int rtw_halmac_write_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)$/;"	f
-rtw_halmac_write_logical_efuse_map	hal/hal_halmac.c	/^int rtw_halmac_write_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u8 *maskmap, u32 masksize)$/;"	f
-rtw_halmac_write_physical_efuse	hal/hal_halmac.c	/^int rtw_halmac_write_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)$/;"	f
-rtw_handle_tkip_countermeasure	core/rtw_security.c	/^u8 rtw_handle_tkip_countermeasure(_adapter *adapter, const char *caller)$/;"	f
-rtw_handle_tkip_mic_err	os_dep/linux/recv_linux.c	/^void rtw_handle_tkip_mic_err(_adapter *padapter, struct sta_info *sta, u8 bgroup)$/;"	f
-rtw_handlers	os_dep/linux/ioctl_linux.c	/^static iw_handler rtw_handlers[] = {$/;"	v	file:
-rtw_handlers_def	os_dep/linux/ioctl_linux.c	/^struct iw_handler_def rtw_handlers_def = {$/;"	v	typeref:struct:iw_handler_def
-rtw_hiq_filter	os_dep/linux/os_intfs.c	/^uint rtw_hiq_filter = CONFIG_RTW_HIQ_FILTER;$/;"	v
-rtw_hook_if_ops	os_dep/linux/os_intfs.c	/^void rtw_hook_if_ops(struct net_device *ndev)$/;"	f
-rtw_hook_vir_if_ops	os_dep/linux/os_intfs.c	/^static void rtw_hook_vir_if_ops(struct net_device *ndev)$/;"	f	file:
-rtw_hostapd_ioctl	os_dep/linux/ioctl_linux.c	/^static int rtw_hostapd_ioctl(struct net_device *dev, struct iw_point *p)$/;"	f	file:
-rtw_hostapd_mlme_rx	os_dep/linux/recv_linux.c	/^void rtw_hostapd_mlme_rx(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-rtw_hostapd_sta_flush	os_dep/linux/ioctl_linux.c	/^static int rtw_hostapd_sta_flush(struct net_device *dev)$/;"	f	file:
-rtw_ht_enable	os_dep/linux/os_intfs.c	/^int rtw_ht_enable = 1;$/;"	v
-rtw_ht_mcsset_to_nss	core/rtw_ieee80211.c	/^u8	rtw_ht_mcsset_to_nss(u8 *supp_mcs_set)$/;"	f
-rtw_ht_operation_update	core/rtw_ap.c	/^int rtw_ht_operation_update(_adapter *padapter)$/;"	f
-rtw_ht_use_default_setting	core/rtw_mlme.c	/^void	rtw_ht_use_default_setting(_adapter *padapter)$/;"	f
-rtw_hw_wps_pbc	os_dep/linux/os_intfs.c	/^int rtw_hw_wps_pbc = 0;$/;"	v
-rtw_hw_wps_pbc	os_dep/linux/os_intfs.c	/^int rtw_hw_wps_pbc = 1;$/;"	v
-rtw_hwpdn_mode	os_dep/linux/os_intfs.c	/^int rtw_hwpdn_mode = 2; \/* 0:disable,1:enable,2: by EFUSE config *\/$/;"	v
-rtw_hwpwrp_detect	os_dep/linux/os_intfs.c	/^int rtw_hwpwrp_detect = 0; \/* HW power  ping detect 0:disable , 1:enable *\/$/;"	v
-rtw_hwpwrp_detect	os_dep/linux/os_intfs.c	/^int rtw_hwpwrp_detect = 1;$/;"	v
-rtw_ieee80211_back_actioncode	include/ieee80211.h	/^enum rtw_ieee80211_back_actioncode {$/;"	g
-rtw_ieee80211_back_parties	include/ieee80211.h	/^enum rtw_ieee80211_back_parties {$/;"	g
-rtw_ieee80211_bar	include/wifi.h	/^struct rtw_ieee80211_bar {$/;"	s
-rtw_ieee80211_category	include/ieee80211.h	/^enum rtw_ieee80211_category {$/;"	g
-rtw_ieee80211_channel	include/ieee80211.h	/^struct rtw_ieee80211_channel {$/;"	s
-rtw_ieee80211_channel_flags	include/ieee80211.h	/^enum rtw_ieee80211_channel_flags {$/;"	g
-rtw_ieee80211_ft_actioncode	include/ieee80211.h	/^enum rtw_ieee80211_ft_actioncode {$/;"	g
-rtw_ieee80211_hdr	include/ieee80211.h	/^struct rtw_ieee80211_hdr {$/;"	s
-rtw_ieee80211_hdr_3addr	include/ieee80211.h	/^struct rtw_ieee80211_hdr_3addr {$/;"	s
-rtw_ieee80211_hdr_3addr_qos	include/ieee80211.h	/^struct rtw_ieee80211_hdr_3addr_qos {$/;"	s
-rtw_ieee80211_hdr_qos	include/ieee80211.h	/^struct rtw_ieee80211_hdr_qos {$/;"	s
-rtw_ieee80211_ht_actioncode	include/ieee80211.h	/^enum rtw_ieee80211_ht_actioncode {$/;"	g
-rtw_ieee80211_ht_cap	include/wifi.h	/^struct rtw_ieee80211_ht_cap {$/;"	s
-rtw_ieee80211_spectrum_mgmt_actioncode	include/ieee80211.h	/^enum rtw_ieee80211_spectrum_mgmt_actioncode {$/;"	g
-rtw_ieee80211_vht_actioncode	include/ieee80211.h	/^enum rtw_ieee80211_vht_actioncode {$/;"	g
-rtw_ieee802_11_elems	include/ieee80211.h	/^struct rtw_ieee802_11_elems {$/;"	s
-rtw_ieee802_11_parse_elems	core/rtw_ieee80211.c	/^ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,$/;"	f
-rtw_ieee802_11_parse_vendor_specific	core/rtw_ieee80211.c	/^static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,$/;"	f	file:
-rtw_ies_get_chbw	core/rtw_ieee80211.c	/^void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset)$/;"	f
-rtw_ies_get_supported_rate	core/rtw_wlan_util.c	/^int rtw_ies_get_supported_rate(u8 *ies, uint ies_len, u8 *rate_set, u8 *rate_num)$/;"	f
-rtw_ies_remove_ie	core/rtw_ieee80211.c	/^int rtw_ies_remove_ie(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 oui_len)$/;"	f
-rtw_if_operations	include/drv_types.h	/^typedef struct rtw_if_operations {$/;"	s
-rtw_if_up	core/rtw_mlme.c	/^sint rtw_if_up(_adapter *padapter)$/;"	f
-rtw_iface_bcmc_id_get	core/rtw_wlan_util.c	/^inline u8 rtw_iface_bcmc_id_get(_adapter *padapter)$/;"	f
-rtw_iface_bcmc_id_set	core/rtw_wlan_util.c	/^inline void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id)$/;"	f
-rtw_iface_dynamic_check_timer_handlder	core/rtw_mlme.c	/^void rtw_iface_dynamic_check_timer_handlder(_adapter *adapter)$/;"	f
-rtw_iface_dynamic_chk_wk_hdl	core/rtw_cmd.c	/^void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter)$/;"	f
-rtw_inc_and_chk_continual_io_error	core/rtw_io.c	/^int rtw_inc_and_chk_continual_io_error(struct dvobj_priv *dvobj)$/;"	f
-rtw_inc_and_chk_continual_no_rx_packet	core/rtw_recv.c	/^int rtw_inc_and_chk_continual_no_rx_packet(struct sta_info *sta, int tid_index)$/;"	f
-rtw_indicate_connect	core/rtw_mlme.c	/^void rtw_indicate_connect(_adapter *padapter)$/;"	f
-rtw_indicate_disconnect	core/rtw_mlme.c	/^void rtw_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)$/;"	f
-rtw_indicate_scan_done	core/rtw_mlme.c	/^inline void rtw_indicate_scan_done(_adapter *padapter, bool aborted)$/;"	f
-rtw_indicate_sta_assoc_event	os_dep/linux/mlme_linux.c	/^void rtw_indicate_sta_assoc_event(_adapter *padapter, struct sta_info *psta)$/;"	f
-rtw_indicate_sta_disassoc_event	os_dep/linux/mlme_linux.c	/^void rtw_indicate_sta_disassoc_event(_adapter *padapter, struct sta_info *psta)$/;"	f
-rtw_indicate_wx_assoc_event	os_dep/linux/ioctl_linux.c	/^void rtw_indicate_wx_assoc_event(_adapter *padapter)$/;"	f
-rtw_indicate_wx_disassoc_event	os_dep/linux/ioctl_linux.c	/^void rtw_indicate_wx_disassoc_event(_adapter *padapter)$/;"	f
-rtw_init_bcmc_stainfo	core/rtw_sta_mgt.c	/^u32 rtw_init_bcmc_stainfo(_adapter *padapter)$/;"	f
-rtw_init_cfg80211_wifidirect_info	core/rtw_p2p.c	/^void rtw_init_cfg80211_wifidirect_info(_adapter	*padapter)$/;"	f
-rtw_init_cmd_priv	core/rtw_cmd.c	/^u32	rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)$/;"	f
-rtw_init_default_value	os_dep/linux/os_intfs.c	/^u8 rtw_init_default_value(_adapter *padapter)$/;"	f
-rtw_init_drv_sw	os_dep/linux/os_intfs.c	/^u8 rtw_init_drv_sw(_adapter *padapter)$/;"	f
-rtw_init_evt_priv	core/rtw_cmd.c	/^u32	rtw_init_evt_priv(struct	evt_priv *pevtpriv)$/;"	f
-rtw_init_hal_com_default_value	hal/hal_com.c	/^void rtw_init_hal_com_default_value(PADAPTER Adapter)$/;"	f
-rtw_init_hwxmits	core/rtw_xmit.c	/^void rtw_init_hwxmits(struct hw_xmit *phwxmit, sint entry)$/;"	f
-rtw_init_io_priv	core/rtw_io.c	/^int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter, struct _io_ops *pops))$/;"	f
-rtw_init_mlme_priv	core/rtw_mlme.c	/^int	rtw_init_mlme_priv(_adapter *padapter) \/* (struct	mlme_priv *pmlmepriv) *\/$/;"	f
-rtw_init_mlme_timer	os_dep/linux/mlme_linux.c	/^void rtw_init_mlme_timer(_adapter *padapter)$/;"	f
-rtw_init_netdev	os_dep/linux/os_intfs.c	/^struct net_device *rtw_init_netdev(_adapter *old_padapter)$/;"	f
-rtw_init_netdev_name	os_dep/linux/os_intfs.c	/^int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname)$/;"	f
-rtw_init_pwrctrl_priv	core/rtw_pwrctrl.c	/^void rtw_init_pwrctrl_priv(PADAPTER padapter)$/;"	f
-rtw_init_recv_timer	os_dep/linux/recv_linux.c	/^void rtw_init_recv_timer(struct recv_reorder_ctrl *preorder_ctrl)$/;"	f
-rtw_init_recvframe	core/rtw_recv.c	/^void rtw_init_recvframe(union recv_frame *precvframe, struct recv_priv *precvpriv)$/;"	f
-rtw_init_registrypriv_dev_network	core/rtw_mlme.c	/^void rtw_init_registrypriv_dev_network(_adapter *adapter)$/;"	f
-rtw_init_tdls_info	core/rtw_tdls.c	/^int rtw_init_tdls_info(_adapter *padapter)$/;"	f
-rtw_init_tdls_timer	core/rtw_tdls.c	/^void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta)$/;"	f
-rtw_init_timer	os_dep/osdep_service.c	/^void rtw_init_timer(_timer *ptimer, void *padapter, void *pfunc)$/;"	f
-rtw_init_wifi_display_info	core/rtw_p2p.c	/^int rtw_init_wifi_display_info(_adapter *padapter)$/;"	f
-rtw_init_wifidirect_addrs	core/rtw_p2p.c	/^void rtw_init_wifidirect_addrs(_adapter *padapter, u8 *dev_addr, u8 *iface_addr)$/;"	f
-rtw_init_wifidirect_timers	core/rtw_p2p.c	/^void rtw_init_wifidirect_timers(_adapter *padapter)$/;"	f
-rtw_init_xmitframe	core/rtw_xmit.c	/^void rtw_init_xmitframe(struct xmit_frame *pxframe)$/;"	f
-rtw_initmac	os_dep/linux/os_intfs.c	/^char *rtw_initmac = 0;  \/* temp mac address if users want to use instead of the mac address in Efuse *\/$/;"	v
-rtw_interface_ps_func	core/rtw_pwrctrl.c	/^u8 rtw_interface_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val)$/;"	f
-rtw_intf_start	os_dep/linux/os_intfs.c	/^void rtw_intf_start(_adapter *adapter)$/;"	f
-rtw_intf_stop	os_dep/linux/os_intfs.c	/^void rtw_intf_stop(_adapter *adapter)$/;"	f
-rtw_ioctl	os_dep/linux/ioctl_linux.c	/^int rtw_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)$/;"	f
-rtw_ioctl_acl_add_sta	os_dep/linux/ioctl_linux.c	/^static int rtw_ioctl_acl_add_sta(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_ioctl_acl_remove_sta	os_dep/linux/ioctl_linux.c	/^static int rtw_ioctl_acl_remove_sta(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_ioctl_compat_wext_private	os_dep/linux/ioctl_linux.c	/^static int rtw_ioctl_compat_wext_private(struct net_device *dev, struct ifreq *rq)$/;"	f	file:
-rtw_ioctl_get_sta_data	os_dep/linux/ioctl_linux.c	/^static int rtw_ioctl_get_sta_data(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_ioctl_set_macaddr_acl	os_dep/linux/ioctl_linux.c	/^static int rtw_ioctl_set_macaddr_acl(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_ioctl_standard_wext_private	os_dep/linux/ioctl_linux.c	/^static int rtw_ioctl_standard_wext_private(struct net_device *dev, struct ifreq *rq)$/;"	f	file:
-rtw_ioctl_wext_private	os_dep/linux/ioctl_linux.c	/^static int rtw_ioctl_wext_private(struct net_device *dev, struct ifreq *rq)$/;"	f	file:
-rtw_ips_dev_unload	os_dep/linux/os_intfs.c	/^void rtw_ips_dev_unload(_adapter *padapter)$/;"	f
-rtw_ips_mode	os_dep/linux/os_intfs.c	/^		int rtw_ips_mode = IPS_LEVEL_2;$/;"	v
-rtw_ips_mode	os_dep/linux/os_intfs.c	/^		int rtw_ips_mode = IPS_NORMAL;$/;"	v
-rtw_ips_mode	os_dep/linux/os_intfs.c	/^	int rtw_ips_mode = IPS_NONE;$/;"	v
-rtw_ips_mode_req	include/rtw_pwrctrl.h	449;"	d
-rtw_ips_pwr_down	os_dep/linux/os_intfs.c	/^void rtw_ips_pwr_down(_adapter *padapter)$/;"	f
-rtw_ips_pwr_up	os_dep/linux/os_intfs.c	/^int rtw_ips_pwr_up(_adapter *padapter)$/;"	f
-rtw_is_adapter_up	core/rtw_mlme.c	/^u8 rtw_is_adapter_up(_adapter *padapter)$/;"	f
-rtw_is_cac_reset_needed	core/rtw_mlme_ext.c	/^bool rtw_is_cac_reset_needed(_adapter *adapter, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_is_cckrates_included	core/rtw_ieee80211.c	/^uint	rtw_is_cckrates_included(u8 *rate)$/;"	f
-rtw_is_cckratesonly_included	core/rtw_ieee80211.c	/^uint	rtw_is_cckratesonly_included(u8 *rate)$/;"	f
-rtw_is_channel_plan_valid	include/rtw_mlme_ext.h	230;"	d
-rtw_is_chbw_grouped	core/rtw_ieee80211.c	/^bool rtw_is_chbw_grouped(u8 ch_a, u8 bw_a, u8 offset_a$/;"	f
-rtw_is_desired_network	core/rtw_mlme.c	/^int rtw_is_desired_network(_adapter *adapter, struct wlan_network *pnetwork)$/;"	f
-rtw_is_dfs_ch	core/rtw_rf.c	/^bool rtw_is_dfs_ch(u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_is_dfs_range	core/rtw_rf.c	/^bool rtw_is_dfs_range(u32 hi, u32 lo)$/;"	f
-rtw_is_do_late_resume	core/rtw_pwrctrl.c	/^inline bool rtw_is_do_late_resume(struct pwrctrl_priv *pwrpriv)$/;"	f
-rtw_is_do_late_resume	include/rtw_pwrctrl.h	524;"	d
-rtw_is_drv_stopped	include/drv_types.h	1497;"	d
-rtw_is_earlysuspend_registered	core/rtw_pwrctrl.c	/^inline bool rtw_is_earlysuspend_registered(struct pwrctrl_priv *pwrpriv)$/;"	f
-rtw_is_earlysuspend_registered	include/rtw_pwrctrl.h	523;"	d
-rtw_is_file_readable	os_dep/osdep_service.c	/^int rtw_is_file_readable(const char *path)$/;"	f
-rtw_is_file_readable_with_size	os_dep/osdep_service.c	/^int rtw_is_file_readable_with_size(const char *path, u32 *sz)$/;"	f
-rtw_is_hw_init_completed	include/hal_data.h	757;"	d
-rtw_is_legacy_channel_plan	include/rtw_mlme_ext.h	231;"	d
-rtw_is_list_empty	os_dep/osdep_service.c	/^u32	rtw_is_list_empty(_list *phead)$/;"	f
-rtw_is_long_cac_ch	core/rtw_rf.c	/^bool rtw_is_long_cac_ch(u8 ch, u8 bw, u8 offset, u8 dfs_region)$/;"	f
-rtw_is_long_cac_range	core/rtw_rf.c	/^bool rtw_is_long_cac_range(u32 hi, u32 lo, u8 dfs_region)$/;"	f
-rtw_is_range_a_in_b	include/osdep_service.h	514;"	d
-rtw_is_range_overlap	include/osdep_service.h	515;"	d
-rtw_is_same_ibss	core/rtw_mlme.c	/^int rtw_is_same_ibss(_adapter *adapter, struct wlan_network *pnetwork)$/;"	f
-rtw_is_scan_deny	core/rtw_mlme.c	/^inline bool rtw_is_scan_deny(_adapter *adapter)$/;"	f
-rtw_is_scan_deny	include/rtw_mlme.h	1068;"	d
-rtw_is_surprise_removed	include/drv_types.h	1496;"	d
-rtw_is_wps_ie	core/rtw_ieee80211.c	/^u8 rtw_is_wps_ie(u8 *ie_ptr, uint *wps_ielen)$/;"	f
-rtw_issue_addbareq_cmd	core/rtw_mlme.c	/^void rtw_issue_addbareq_cmd(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtw_issue_addbareq_cmd_tdls	core/rtw_mlme.c	/^void rtw_issue_addbareq_cmd_tdls(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtw_join_done_chk_ch	core/rtw_mlme_ext.c	/^void rtw_join_done_chk_ch(_adapter *adapter, int join_res)$/;"	f
-rtw_join_timeout_handler	os_dep/linux/mlme_linux.c	/^void rtw_join_timeout_handler(void *FunctionContext)$/;"	f
-rtw_joinbss_cmd	core/rtw_cmd.c	/^u8 rtw_joinbss_cmd(_adapter  *padapter, struct wlan_network *pnetwork)$/;"	f
-rtw_joinbss_cmd_callback	core/rtw_cmd.c	/^void rtw_joinbss_cmd_callback(_adapter	*padapter,  struct cmd_obj *pcmd)$/;"	f
-rtw_joinbss_event_callback	core/rtw_mlme.c	/^void rtw_joinbss_event_callback(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_joinbss_event_prehandle	core/rtw_mlme.c	/^void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_joinbss_reset	core/rtw_mlme.c	/^void rtw_joinbss_reset(_adapter *padapter)$/;"	f
-rtw_joinbss_update_network	core/rtw_mlme.c	/^static void rtw_joinbss_update_network(_adapter *padapter, struct wlan_network *ptarget_wlan, struct wlan_network  *pnetwork)$/;"	f	file:
-rtw_joinbss_update_stainfo	core/rtw_mlme.c	/^static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wlan_network *pnetwork)$/;"	f	file:
-rtw_late_resume	core/rtw_pwrctrl.c	/^static void rtw_late_resume(android_early_suspend_t *h)$/;"	f	file:
-rtw_late_resume	core/rtw_pwrctrl.c	/^static void rtw_late_resume(struct early_suspend *h)$/;"	f	file:
-rtw_lbkmode	os_dep/linux/os_intfs.c	/^int rtw_lbkmode = 0;\/* RTL8712_AIR_TRX; *\/$/;"	v
-rtw_ldpc_cap	os_dep/linux/os_intfs.c	/^int rtw_ldpc_cap = 0x33;$/;"	v
-rtw_le16_to_cpu	core/rtw_io.c	60;"	d	file:
-rtw_le16_to_cpu	core/rtw_io.c	65;"	d	file:
-rtw_le32_to_cpu	core/rtw_io.c	61;"	d	file:
-rtw_le32_to_cpu	core/rtw_io.c	66;"	d	file:
-rtw_led_blink_cmd	core/rtw_cmd.c	/^u8 rtw_led_blink_cmd(_adapter *padapter, PVOID pLed)$/;"	f
-rtw_led_control	include/hal_com_led.h	355;"	d
-rtw_led_control	include/hal_com_led.h	361;"	d
-rtw_limits	os_dep/linux/ioctl_cfg80211.c	/^struct ieee80211_iface_limit rtw_limits[] = {$/;"	v	typeref:struct:ieee80211_iface_limit
-rtw_linked_check	core/rtw_mlme.c	/^sint rtw_linked_check(_adapter *padapter)$/;"	f
-rtw_list_delete	include/osdep_service_bsd.h	/^__inline static void rtw_list_delete(_list *plist)$/;"	f
-rtw_list_delete	include/osdep_service_ce.h	/^__inline static void rtw_list_delete(_list *plist)$/;"	f
-rtw_list_delete	include/osdep_service_linux.h	/^__inline static void rtw_list_delete(_list *plist)$/;"	f
-rtw_list_delete	include/osdep_service_xp.h	/^__inline static void rtw_list_delete(_list *plist)$/;"	f
-rtw_list_insert_head	os_dep/osdep_service.c	/^void rtw_list_insert_head(_list *plist, _list *phead)$/;"	f
-rtw_list_insert_tail	os_dep/osdep_service.c	/^void rtw_list_insert_tail(_list *plist, _list *phead)$/;"	f
-rtw_load_phy_file	os_dep/linux/os_intfs.c	/^int rtw_load_phy_file = (BIT2 | BIT6);$/;"	v
-rtw_lock_ext_suspend_timeout	os_dep/osdep_service.c	/^inline void rtw_lock_ext_suspend_timeout(u32 timeout_ms)$/;"	f
-rtw_lock_resume_scan_timeout	os_dep/osdep_service.c	/^inline void rtw_lock_resume_scan_timeout(u32 timeout_ms)$/;"	f
-rtw_lock_rx_suspend_timeout	os_dep/osdep_service.c	/^inline void rtw_lock_rx_suspend_timeout(u32 timeout_ms)$/;"	f
-rtw_lock_suspend	os_dep/osdep_service.c	/^inline void rtw_lock_suspend(void)$/;"	f
-rtw_lock_suspend_timeout	os_dep/osdep_service.c	/^inline void rtw_lock_suspend_timeout(u32 timeout_ms)$/;"	f
-rtw_lock_traffic_suspend_timeout	os_dep/osdep_service.c	/^inline void rtw_lock_traffic_suspend_timeout(u32 timeout_ms)$/;"	f
-rtw_log_level_str	core/rtw_debug.c	/^const char *rtw_log_level_str[] = {$/;"	v
-rtw_long_retry_lmt	os_dep/linux/os_intfs.c	/^int rtw_long_retry_lmt = 7;$/;"	v
-rtw_low_power	os_dep/linux/os_intfs.c	/^int rtw_low_power = 0;$/;"	v
-rtw_lowrate_two_xmit	os_dep/linux/os_intfs.c	/^int rtw_lowrate_two_xmit = 1;\/* Use 2 path Tx to transmit MCS0~7 and legacy mode *\/$/;"	v
-rtw_lps_change_dtim_cmd	core/rtw_cmd.c	/^u8 rtw_lps_change_dtim_cmd(_adapter *padapter, u8 dtim)$/;"	f
-rtw_lps_change_dtim_hdl	core/rtw_cmd.c	/^void rtw_lps_change_dtim_hdl(_adapter *padapter, u8 dtim)$/;"	f
-rtw_lps_ctrl_wk_cmd	core/rtw_cmd.c	/^u8 rtw_lps_ctrl_wk_cmd(_adapter *padapter, u8 lps_ctrl_type, u8 enqueue)$/;"	f
-rtw_macaddr_acl_deinit	core/rtw_ap.c	/^void rtw_macaddr_acl_deinit(_adapter *adapter)$/;"	f
-rtw_macaddr_acl_init	core/rtw_ap.c	/^void rtw_macaddr_acl_init(_adapter *adapter)$/;"	f
-rtw_macaddr_cfg	core/rtw_ieee80211.c	/^void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr)$/;"	f
-rtw_macid_ctl_deinit	core/rtw_wlan_util.c	/^inline void rtw_macid_ctl_deinit(struct macid_ctl_t *macid_ctl)$/;"	f
-rtw_macid_ctl_init	core/rtw_wlan_util.c	/^inline void rtw_macid_ctl_init(struct macid_ctl_t *macid_ctl)$/;"	f
-rtw_macid_ctl_set_bw	core/rtw_wlan_util.c	/^inline void rtw_macid_ctl_set_bw(struct macid_ctl_t *macid_ctl, u8 id, u8 bw)$/;"	f
-rtw_macid_ctl_set_h2c_msr	core/rtw_wlan_util.c	/^inline void rtw_macid_ctl_set_h2c_msr(struct macid_ctl_t *macid_ctl, u8 id, u8 h2c_msr)$/;"	f
-rtw_macid_ctl_set_rate_bmp0	core/rtw_wlan_util.c	/^inline void rtw_macid_ctl_set_rate_bmp0(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp)$/;"	f
-rtw_macid_ctl_set_rate_bmp1	core/rtw_wlan_util.c	/^inline void rtw_macid_ctl_set_rate_bmp1(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp)$/;"	f
-rtw_macid_ctl_set_vht_en	core/rtw_wlan_util.c	/^inline void rtw_macid_ctl_set_vht_en(struct macid_ctl_t *macid_ctl, u8 id, u8 en)$/;"	f
-rtw_macid_get_ch_g	core/rtw_wlan_util.c	/^inline s8 rtw_macid_get_ch_g(struct macid_ctl_t *macid_ctl, u8 id)$/;"	f
-rtw_macid_get_if_g	core/rtw_wlan_util.c	/^inline s8 rtw_macid_get_if_g(struct macid_ctl_t *macid_ctl, u8 id)$/;"	f
-rtw_macid_is_bmc	core/rtw_wlan_util.c	/^inline bool rtw_macid_is_bmc(struct macid_ctl_t *macid_ctl, u8 id)$/;"	f
-rtw_macid_is_set	core/rtw_wlan_util.c	/^inline bool rtw_macid_is_set(struct macid_bmp *map, u8 id)$/;"	f
-rtw_macid_is_used	core/rtw_wlan_util.c	/^inline bool rtw_macid_is_used(struct macid_ctl_t *macid_ctl, u8 id)$/;"	f
-rtw_macid_map_clr	core/rtw_wlan_util.c	/^inline void rtw_macid_map_clr(struct macid_bmp *map, u8 id)$/;"	f
-rtw_macid_map_set	core/rtw_wlan_util.c	/^inline void rtw_macid_map_set(struct macid_bmp *map, u8 id)$/;"	f
-rtw_make_tdls_wlanhdr	core/rtw_xmit.c	/^s32 rtw_make_tdls_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_make_wlanhdr	core/rtw_xmit.c	/^s32 rtw_make_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib)$/;"	f
-rtw_malloc	include/osdep_service.h	176;"	d
-rtw_malloc	include/osdep_service.h	249;"	d
-rtw_malloc2d	os_dep/osdep_service.c	/^void *rtw_malloc2d(int h, int w, size_t size)$/;"	f
-rtw_malloc_f	include/osdep_service.h	179;"	d
-rtw_malloc_f	include/osdep_service.h	252;"	d
-rtw_max_roaming_times	os_dep/linux/os_intfs.c	/^uint rtw_max_roaming_times = 2;$/;"	v
-rtw_mbid_cam_assign	hal/hal_com.c	/^u8 rtw_mbid_cam_assign(_adapter *adapter, u8 *mac_addr, u8 camid)$/;"	f
-rtw_mbid_cam_cache_dump	hal/hal_com.c	/^int rtw_mbid_cam_cache_dump(void *sel, const char *fun_name, _adapter *adapter)$/;"	f
-rtw_mbid_cam_deinit	hal/hal_com.c	/^void rtw_mbid_cam_deinit(struct dvobj_priv *dvobj)$/;"	f
-rtw_mbid_cam_dump	hal/hal_com.c	/^int rtw_mbid_cam_dump(void *sel, const char *fun_name, _adapter *adapter)$/;"	f
-rtw_mbid_cam_info_change	hal/hal_com.c	/^u8 rtw_mbid_cam_info_change(_adapter *adapter, u8 *mac_addr)$/;"	f
-rtw_mbid_cam_init	hal/hal_com.c	/^void rtw_mbid_cam_init(struct dvobj_priv *dvobj)$/;"	f
-rtw_mbid_cam_reset	hal/hal_com.c	/^void rtw_mbid_cam_reset(_adapter *adapter)$/;"	f
-rtw_mbid_cam_restore	hal/hal_com.c	/^void rtw_mbid_cam_restore(_adapter *adapter)$/;"	f
-rtw_mbid_cam_search_by_ifaceid	hal/hal_com.c	/^u8 rtw_mbid_cam_search_by_ifaceid(_adapter *adapter, u8 iface_id)$/;"	f
-rtw_mbid_cam_search_by_macaddr	hal/hal_com.c	/^u8 rtw_mbid_cam_search_by_macaddr(_adapter *adapter, u8 *mac_addr)$/;"	f
-rtw_mbid_camid_alloc	hal/hal_com.c	/^u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr)$/;"	f
-rtw_mbid_camid_clean	hal/hal_com.c	/^void rtw_mbid_camid_clean(_adapter *adapter, u8 mbss_canid)$/;"	f
-rtw_mc2u_disable	os_dep/linux/os_intfs.c	/^int rtw_mc2u_disable = 0;$/;"	v
-rtw_mcc_ap_bw20_target_tx_tp	include/drv_types.h	/^	u32 rtw_mcc_ap_bw20_target_tx_tp;$/;"	m	struct:registry_priv
-rtw_mcc_ap_bw20_target_tx_tp	os_dep/linux/os_intfs.c	/^int rtw_mcc_ap_bw20_target_tx_tp = MCC_AP_BW20_TARGET_TX_TP;$/;"	v
-rtw_mcc_ap_bw40_target_tx_tp	include/drv_types.h	/^	u32 rtw_mcc_ap_bw40_target_tx_tp;$/;"	m	struct:registry_priv
-rtw_mcc_ap_bw40_target_tx_tp	os_dep/linux/os_intfs.c	/^int rtw_mcc_ap_bw40_target_tx_tp = MCC_AP_BW40_TARGET_TX_TP;$/;"	v
-rtw_mcc_ap_bw80_target_tx_tp	include/drv_types.h	/^	u32 rtw_mcc_ap_bw80_target_tx_tp;$/;"	m	struct:registry_priv
-rtw_mcc_ap_bw80_target_tx_tp	os_dep/linux/os_intfs.c	/^int rtw_mcc_ap_bw80_target_tx_tp = MCC_AP_BW80_TARGET_TX_TP;$/;"	v
-rtw_mcc_proc_deinit	os_dep/linux/rtw_proc.c	/^void rtw_mcc_proc_deinit(_adapter	*adapter)$/;"	f
-rtw_mcc_proc_init	os_dep/linux/rtw_proc.c	/^struct proc_dir_entry *rtw_mcc_proc_init(struct net_device *dev)$/;"	f
-rtw_mcc_proc_open	os_dep/linux/rtw_proc.c	/^static int rtw_mcc_proc_open(struct inode *inode, struct file *file)$/;"	f	file:
-rtw_mcc_proc_seq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_mcc_proc_seq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_mcc_proc_sseq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_mcc_proc_sseq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_mcc_proc_write	os_dep/linux/rtw_proc.c	/^static ssize_t rtw_mcc_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)$/;"	f	file:
-rtw_mcc_single_tx_cri	include/drv_types.h	/^	u32 rtw_mcc_single_tx_cri;$/;"	m	struct:registry_priv
-rtw_mcc_single_tx_cri	os_dep/linux/os_intfs.c	/^int rtw_mcc_single_tx_cri = MCC_SINGLE_TX_CRITERIA;$/;"	v
-rtw_mcc_sta_bw20_target_tx_tp	include/drv_types.h	/^	u32 rtw_mcc_sta_bw20_target_tx_tp;$/;"	m	struct:registry_priv
-rtw_mcc_sta_bw20_target_tx_tp	os_dep/linux/os_intfs.c	/^int rtw_mcc_sta_bw20_target_tx_tp = MCC_STA_BW20_TARGET_TX_TP;$/;"	v
-rtw_mcc_sta_bw40_target_tx_tp	include/drv_types.h	/^	u32 rtw_mcc_sta_bw40_target_tx_tp;$/;"	m	struct:registry_priv
-rtw_mcc_sta_bw40_target_tx_tp	os_dep/linux/os_intfs.c	/^int rtw_mcc_sta_bw40_target_tx_tp = MCC_STA_BW40_TARGET_TX_TP;$/;"	v
-rtw_mcc_sta_bw80_target_tx_tp	include/drv_types.h	/^	u32 rtw_mcc_sta_bw80_target_tx_tp;$/;"	m	struct:registry_priv
-rtw_mcc_sta_bw80_target_tx_tp	os_dep/linux/os_intfs.c	/^int rtw_mcc_sta_bw80_target_tx_tp = MCC_STA_BW80_TARGET_TX_TP;$/;"	v
-rtw_mcs_rate	core/rtw_ieee80211.c	/^u16 rtw_mcs_rate(u8 rf_type, u8 bw_40MHz, u8 short_GI, unsigned char *MCS_rate)$/;"	f
-rtw_mdelay_os	include/osdep_service.h	330;"	d
-rtw_mdelay_os	os_dep/osdep_service.c	/^void rtw_mdelay_os(int ms)$/;"	f
-rtw_mem_exit	core/rtw_mem.c	/^module_exit(rtw_mem_exit);$/;"	v
-rtw_mem_exit	core/rtw_mem.c	/^static void __exit rtw_mem_exit(void)$/;"	f	file:
-rtw_mem_func_stat	os_dep/osdep_service.c	/^struct rtw_mem_stat rtw_mem_func_stat[mstat_ff_idx(MSTAT_FUNC_MAX)];$/;"	v	typeref:struct:rtw_mem_stat
-rtw_mem_init	core/rtw_mem.c	/^module_init(rtw_mem_init);$/;"	v
-rtw_mem_init	core/rtw_mem.c	/^static int __init rtw_mem_init(void)$/;"	f	file:
-rtw_mem_stat	os_dep/osdep_service.c	/^struct rtw_mem_stat {$/;"	s	file:
-rtw_mem_type_stat	os_dep/osdep_service.c	/^struct rtw_mem_stat rtw_mem_type_stat[mstat_tf_idx(MSTAT_TYPE_MAX)];$/;"	v	typeref:struct:rtw_mem_stat
-rtw_merge_string	include/osdep_service_linux.h	/^static inline int rtw_merge_string(char *dst, int dst_len, const char *src1, const char *src2)$/;"	f
-rtw_mfree	include/osdep_service.h	178;"	d
-rtw_mfree	include/osdep_service.h	251;"	d
-rtw_mfree2d	os_dep/osdep_service.c	/^void rtw_mfree2d(void *pbuf, int h, int w, int size)$/;"	f
-rtw_mfree_all_stainfo	core/rtw_sta_mgt.c	/^void rtw_mfree_all_stainfo(struct sta_priv *pstapriv)$/;"	f
-rtw_mfree_f	include/osdep_service.h	181;"	d
-rtw_mfree_f	include/osdep_service.h	254;"	d
-rtw_mfree_mlme_priv_lock	core/rtw_mlme.c	/^void rtw_mfree_mlme_priv_lock(struct mlme_priv *pmlmepriv)$/;"	f
-rtw_mfree_recv_priv_lock	core/rtw_recv.c	/^void rtw_mfree_recv_priv_lock(struct recv_priv *precvpriv)$/;"	f
-rtw_mfree_sta_priv_lock	core/rtw_sta_mgt.c	/^void rtw_mfree_sta_priv_lock(struct	sta_priv *pstapriv)$/;"	f
-rtw_mfree_stainfo	core/rtw_sta_mgt.c	/^void rtw_mfree_stainfo(struct sta_info *psta)$/;"	f
-rtw_mfree_xmit_priv_lock	core/rtw_xmit.c	/^void  rtw_mfree_xmit_priv_lock(struct xmit_priv *pxmitpriv)$/;"	f
-rtw_mgmt_xmitframe_coalesce	core/rtw_xmit.c	/^s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe)$/;"	f
-rtw_mi_adapter_reset	core/rtw_mi.c	/^void rtw_mi_adapter_reset(_adapter *padapter)$/;"	f
-rtw_mi_beacon_update	core/rtw_mi.c	/^void rtw_mi_beacon_update(_adapter *padapter)$/;"	f
-rtw_mi_buddy_adapter_reset	core/rtw_mi.c	/^void rtw_mi_buddy_adapter_reset(_adapter *padapter)$/;"	f
-rtw_mi_buddy_beacon_update	core/rtw_mi.c	/^void rtw_mi_buddy_beacon_update(_adapter *padapter)$/;"	f
-rtw_mi_buddy_busy_traffic_check	core/rtw_mi.c	/^u8 rtw_mi_buddy_busy_traffic_check(_adapter *padapter, bool check_sc_interval)$/;"	f
-rtw_mi_buddy_cancel_all_timer	core/rtw_mi.c	/^void rtw_mi_buddy_cancel_all_timer(_adapter *adapter)$/;"	f
-rtw_mi_buddy_check_fwstate	core/rtw_mi.c	/^u8 rtw_mi_buddy_check_fwstate(_adapter *padapter, sint state)$/;"	f
-rtw_mi_buddy_check_mlmeinfo_state	core/rtw_mi.c	/^u8 rtw_mi_buddy_check_mlmeinfo_state(_adapter *padapter, u32 state)$/;"	f
-rtw_mi_buddy_check_pending_xmitbuf	core/rtw_mi.c	/^u8 rtw_mi_buddy_check_pending_xmitbuf(_adapter *padapter)$/;"	f
-rtw_mi_buddy_clone_bcmc_packet	core/rtw_mi.c	/^void rtw_mi_buddy_clone_bcmc_packet(_adapter *padapter, union recv_frame *precvframe, u8 *pphy_status)$/;"	f
-rtw_mi_buddy_dequeue_writeport	core/rtw_mi.c	/^u8 rtw_mi_buddy_dequeue_writeport(_adapter *padapter)$/;"	f
-rtw_mi_buddy_dev_unload	core/rtw_mi.c	/^u8 rtw_mi_buddy_dev_unload(_adapter *padapter)$/;"	f
-rtw_mi_buddy_dynamic_check_timer_handlder	core/rtw_mi.c	/^u8 rtw_mi_buddy_dynamic_check_timer_handlder(_adapter *padapter)$/;"	f
-rtw_mi_buddy_dynamic_chk_wk_hdl	core/rtw_mi.c	/^u8 rtw_mi_buddy_dynamic_chk_wk_hdl(_adapter *padapter)$/;"	f
-rtw_mi_buddy_hal_dump_macaddr	core/rtw_mi.c	/^void rtw_mi_buddy_hal_dump_macaddr(_adapter *padapter)$/;"	f
-rtw_mi_buddy_intf_start	core/rtw_mi.c	/^void rtw_mi_buddy_intf_start(_adapter *adapter)$/;"	f
-rtw_mi_buddy_intf_stop	core/rtw_mi.c	/^void rtw_mi_buddy_intf_stop(_adapter *adapter)$/;"	f
-rtw_mi_buddy_is_scan_deny	core/rtw_mi.c	/^u8 rtw_mi_buddy_is_scan_deny(_adapter *adapter)$/;"	f
-rtw_mi_buddy_issue_nulldata	core/rtw_mi.c	/^u8 rtw_mi_buddy_issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)$/;"	f
-rtw_mi_buddy_netif_carrier_on	core/rtw_mi.c	/^u8 rtw_mi_buddy_netif_carrier_on(_adapter *padapter)$/;"	f
-rtw_mi_buddy_netif_stop_queue	core/rtw_mi.c	/^u8 rtw_mi_buddy_netif_stop_queue(_adapter *padapter, bool carrier_off)$/;"	f
-rtw_mi_buddy_netif_wake_queue	core/rtw_mi.c	/^u8 rtw_mi_buddy_netif_wake_queue(_adapter *padapter)$/;"	f
-rtw_mi_buddy_os_xmit_schedule	core/rtw_mi.c	/^u8 rtw_mi_buddy_os_xmit_schedule(_adapter *padapter)$/;"	f
-rtw_mi_buddy_p2p_chk_state	core/rtw_mi.c	/^u8 rtw_mi_buddy_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state)$/;"	f
-rtw_mi_buddy_report_survey_event	core/rtw_mi.c	/^u8 rtw_mi_buddy_report_survey_event(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-rtw_mi_buddy_reset_drv_sw	core/rtw_mi.c	/^void rtw_mi_buddy_reset_drv_sw(_adapter *adapter)$/;"	f
-rtw_mi_buddy_scan_abort	core/rtw_mi.c	/^void rtw_mi_buddy_scan_abort(_adapter *adapter, bool bwait)$/;"	f
-rtw_mi_buddy_set_scan_deny	core/rtw_mi.c	/^void rtw_mi_buddy_set_scan_deny(_adapter *adapter, u32 ms)$/;"	f
-rtw_mi_buddy_set_scan_deny	include/rtw_mi.h	124;"	d
-rtw_mi_buddy_set_tx_beacon_cmd	core/rtw_mi.c	/^u8 rtw_mi_buddy_set_tx_beacon_cmd(_adapter *padapter)$/;"	f
-rtw_mi_buddy_sreset_adapter_hdl	core/rtw_mi.c	/^u8 rtw_mi_buddy_sreset_adapter_hdl(_adapter *padapter, u8 bstart)$/;"	f
-rtw_mi_buddy_start_drv_threads	core/rtw_mi.c	/^void rtw_mi_buddy_start_drv_threads(_adapter *adapter)$/;"	f
-rtw_mi_buddy_stay_in_p2p_mode	core/rtw_mi.c	/^u8 rtw_mi_buddy_stay_in_p2p_mode(_adapter *padapter)$/;"	f
-rtw_mi_buddy_stop_drv_threads	core/rtw_mi.c	/^void rtw_mi_buddy_stop_drv_threads(_adapter *adapter)$/;"	f
-rtw_mi_buddy_suspend_free_assoc_resource	core/rtw_mi.c	/^void rtw_mi_buddy_suspend_free_assoc_resource(_adapter *adapter)$/;"	f
-rtw_mi_buddy_tx_beacon_hdl	core/rtw_mi.c	/^u8 rtw_mi_buddy_tx_beacon_hdl(_adapter *padapter)$/;"	f
-rtw_mi_buddy_xmit_tasklet_schedule	core/rtw_mi.c	/^void rtw_mi_buddy_xmit_tasklet_schedule(_adapter *padapter)$/;"	f
-rtw_mi_busy_traffic_check	core/rtw_mi.c	/^u8 rtw_mi_busy_traffic_check(_adapter *padapter, bool check_sc_interval)$/;"	f
-rtw_mi_cancel_all_timer	core/rtw_mi.c	/^void rtw_mi_cancel_all_timer(_adapter *adapter)$/;"	f
-rtw_mi_check_fwstate	core/rtw_mi.c	/^u8 rtw_mi_check_fwstate(_adapter *padapter, sint state)$/;"	f
-rtw_mi_check_miracast_enabled	core/rtw_mi.c	/^u8 rtw_mi_check_miracast_enabled(_adapter *padapter)$/;"	f
-rtw_mi_check_mlmeinfo_state	core/rtw_mi.c	/^u8 rtw_mi_check_mlmeinfo_state(_adapter *padapter, u32 state)$/;"	f
-rtw_mi_check_pending_xmitbuf	core/rtw_mi.c	/^u8 rtw_mi_check_pending_xmitbuf(_adapter *padapter)$/;"	f
-rtw_mi_check_status	core/rtw_mi.c	/^u8 rtw_mi_check_status(_adapter *adapter, u8 type)$/;"	f
-rtw_mi_dequeue_writeport	core/rtw_mi.c	/^u8 rtw_mi_dequeue_writeport(_adapter *padapter)$/;"	f
-rtw_mi_dev_unload	core/rtw_mi.c	/^u8 rtw_mi_dev_unload(_adapter *padapter)$/;"	f
-rtw_mi_dynamic_check_timer_handlder	core/rtw_mi.c	/^u8 rtw_mi_dynamic_check_timer_handlder(_adapter *padapter)$/;"	f
-rtw_mi_dynamic_chk_wk_hdl	core/rtw_mi.c	/^u8 rtw_mi_dynamic_chk_wk_hdl(_adapter *padapter)$/;"	f
-rtw_mi_get_ap_adapter	core/rtw_mi.c	/^_adapter *rtw_mi_get_ap_adapter(_adapter *padapter)$/;"	f
-rtw_mi_get_ap_num	include/rtw_mi.h	79;"	d
-rtw_mi_get_assoced_sta_num	include/rtw_mi.h	78;"	d
-rtw_mi_get_ch_setting_union	core/rtw_mi.c	/^inline int rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)$/;"	f
-rtw_mi_get_ch_setting_union_no_self	core/rtw_mi.c	/^inline int rtw_mi_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)$/;"	f
-rtw_mi_get_union_bw	include/rtw_mi.h	75;"	d
-rtw_mi_get_union_chan	include/rtw_mi.h	74;"	d
-rtw_mi_get_union_offset	include/rtw_mi.h	76;"	d
-rtw_mi_hal_dump_macaddr	core/rtw_mi.c	/^void rtw_mi_hal_dump_macaddr(_adapter *padapter)$/;"	f
-rtw_mi_intf_start	core/rtw_mi.c	/^void rtw_mi_intf_start(_adapter *adapter)$/;"	f
-rtw_mi_intf_stop	core/rtw_mi.c	/^void rtw_mi_intf_stop(_adapter *adapter)$/;"	f
-rtw_mi_is_scan_deny	core/rtw_mi.c	/^u8 rtw_mi_is_scan_deny(_adapter *adapter)$/;"	f
-rtw_mi_issue_nulldata	core/rtw_mi.c	/^u8 rtw_mi_issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)$/;"	f
-rtw_mi_mp_mode_check	core/rtw_mi.c	/^u8 rtw_mi_mp_mode_check(_adapter *padapter)$/;"	f
-rtw_mi_netif_carrier_on	core/rtw_mi.c	/^u8 rtw_mi_netif_carrier_on(_adapter *padapter)$/;"	f
-rtw_mi_netif_stop_queue	core/rtw_mi.c	/^u8 rtw_mi_netif_stop_queue(_adapter *padapter, bool carrier_off)$/;"	f
-rtw_mi_netif_wake_queue	core/rtw_mi.c	/^u8 rtw_mi_netif_wake_queue(_adapter *padapter)$/;"	f
-rtw_mi_os_xmit_schedule	core/rtw_mi.c	/^u8 rtw_mi_os_xmit_schedule(_adapter *padapter)$/;"	f
-rtw_mi_p2p_chk_state	core/rtw_mi.c	/^u8 rtw_mi_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state)$/;"	f
-rtw_mi_report_survey_event	core/rtw_mi.c	/^u8 rtw_mi_report_survey_event(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-rtw_mi_reset_drv_sw	core/rtw_mi.c	/^void rtw_mi_reset_drv_sw(_adapter *adapter)$/;"	f
-rtw_mi_resume_process_normal	os_dep/linux/os_intfs.c	/^void rtw_mi_resume_process_normal(_adapter *padapter)$/;"	f
-rtw_mi_scan_abort	core/rtw_mi.c	/^void rtw_mi_scan_abort(_adapter *adapter, bool bwait)$/;"	f
-rtw_mi_set_scan_deny	core/rtw_mi.c	/^void rtw_mi_set_scan_deny(_adapter *adapter, u32 ms)$/;"	f
-rtw_mi_set_scan_deny	include/rtw_mi.h	123;"	d
-rtw_mi_set_tx_beacon_cmd	core/rtw_mi.c	/^u8 rtw_mi_set_tx_beacon_cmd(_adapter *padapter)$/;"	f
-rtw_mi_sreset_adapter_hdl	core/rtw_mi.c	/^u8 rtw_mi_sreset_adapter_hdl(_adapter *padapter, u8 bstart)$/;"	f
-rtw_mi_start_drv_threads	core/rtw_mi.c	/^void rtw_mi_start_drv_threads(_adapter *adapter)$/;"	f
-rtw_mi_status	core/rtw_mi.c	/^inline void rtw_mi_status(_adapter *adapter, struct mi_state *mstate)$/;"	f
-rtw_mi_status_no_self	core/rtw_mi.c	/^inline void rtw_mi_status_no_self(_adapter *adapter, struct mi_state *mstate)$/;"	f
-rtw_mi_stay_in_p2p_mode	core/rtw_mi.c	/^u8 rtw_mi_stay_in_p2p_mode(_adapter *padapter)$/;"	f
-rtw_mi_stop_drv_threads	core/rtw_mi.c	/^void rtw_mi_stop_drv_threads(_adapter *adapter)$/;"	f
-rtw_mi_suspend_free_assoc_resource	core/rtw_mi.c	/^void rtw_mi_suspend_free_assoc_resource(_adapter *adapter)$/;"	f
-rtw_mi_traffic_statistics	core/rtw_mi.c	/^u8 rtw_mi_traffic_statistics(_adapter *padapter)$/;"	f
-rtw_mi_tx_beacon_hdl	core/rtw_mi.c	/^u8 rtw_mi_tx_beacon_hdl(_adapter *padapter)$/;"	f
-rtw_mi_update_ap_bmc_camid	core/rtw_mi.c	/^void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b)$/;"	f
-rtw_mi_update_iface_status	core/rtw_mi.c	/^inline void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state)$/;"	f
-rtw_mi_update_union_chan_inf	core/rtw_mi.c	/^void rtw_mi_update_union_chan_inf(_adapter *adapter, u8 ch, u8 offset , u8 bw)$/;"	f
-rtw_mi_xmit_tasklet_schedule	core/rtw_mi.c	/^void rtw_mi_xmit_tasklet_schedule(_adapter *padapter)$/;"	f
-rtw_min	include/osdep_service.h	513;"	d
-rtw_mlcst2unicst	os_dep/linux/xmit_linux.c	/^int rtw_mlcst2unicst(_adapter *padapter, struct sk_buff *skb)$/;"	f
-rtw_mlme_band_check	core/rtw_mlme_ext.c	/^bool rtw_mlme_band_check(_adapter *adapter, const u32 ch)$/;"	f
-rtw_mlme_ignore_chan	core/rtw_mlme_ext.c	/^bool rtw_mlme_ignore_chan(_adapter *adapter, const u32 ch)$/;"	f
-rtw_mlme_reset_auto_scan_int	core/rtw_mlme.c	/^void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason)$/;"	f
-rtw_mlme_set_auto_scan_int	include/rtw_mlme.h	860;"	d
-rtw_mlme_update_wfd_ie_data	core/rtw_mlme.c	/^int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_len)$/;"	f
-rtw_mlmeext_disconnect	core/rtw_mlme_ext.c	/^static void rtw_mlmeext_disconnect(_adapter *padapter)$/;"	f	file:
-rtw_modular64	os_dep/osdep_service.c	/^u64 rtw_modular64(u64 x, u64 y)$/;"	f
-rtw_monitor_xmit_entry	core/rtw_xmit.c	/^s32 rtw_monitor_xmit_entry(struct sk_buff *skb, struct net_device *ndev)$/;"	f
-rtw_mpRateParseFunc	core/rtw_mp.c	/^u8 rtw_mpRateParseFunc(PADAPTER pAdapter, u8 *targetStr)$/;"	f
-rtw_mp_PwrCtlDM	os_dep/linux/ioctl_mp.c	/^int rtw_mp_PwrCtlDM(struct net_device *dev,$/;"	f
-rtw_mp_QueryDrv	os_dep/linux/ioctl_mp.c	/^int rtw_mp_QueryDrv(struct net_device *dev,$/;"	f
-rtw_mp_SetBT	os_dep/linux/ioctl_mp.c	/^int rtw_mp_SetBT(struct net_device *dev,$/;"	f
-rtw_mp_SetRFPath	os_dep/linux/ioctl_mp.c	/^int rtw_mp_SetRFPath(struct net_device *dev,$/;"	f
-rtw_mp_ant_rx	os_dep/linux/ioctl_mp.c	/^int rtw_mp_ant_rx(struct net_device *dev,$/;"	f
-rtw_mp_ant_tx	os_dep/linux/ioctl_mp.c	/^int rtw_mp_ant_tx(struct net_device *dev,$/;"	f
-rtw_mp_arx	os_dep/linux/ioctl_mp.c	/^int rtw_mp_arx(struct net_device *dev,$/;"	f
-rtw_mp_bandwidth	os_dep/linux/ioctl_mp.c	/^int rtw_mp_bandwidth(struct net_device *dev,$/;"	f
-rtw_mp_channel	os_dep/linux/ioctl_mp.c	/^int rtw_mp_channel(struct net_device *dev,$/;"	f
-rtw_mp_ctx	os_dep/linux/ioctl_mp.c	/^int rtw_mp_ctx(struct net_device *dev,$/;"	f
-rtw_mp_customer_str	os_dep/linux/ioctl_linux.c	/^static int rtw_mp_customer_str($/;"	f	file:
-rtw_mp_customer_str	os_dep/linux/os_intfs.c	/^uint rtw_mp_customer_str = 0;$/;"	v
-rtw_mp_disable_bt_coexist	os_dep/linux/ioctl_mp.c	/^int rtw_mp_disable_bt_coexist(struct net_device *dev,$/;"	f
-rtw_mp_dump	os_dep/linux/ioctl_mp.c	/^int rtw_mp_dump(struct net_device *dev,$/;"	f
-rtw_mp_efuse_get	os_dep/linux/ioctl_linux.c	/^static int rtw_mp_efuse_get(struct net_device *dev,$/;"	f	file:
-rtw_mp_efuse_set	os_dep/linux/ioctl_linux.c	/^static int rtw_mp_efuse_set(struct net_device *dev,$/;"	f	file:
-rtw_mp_getver	os_dep/linux/ioctl_mp.c	/^int rtw_mp_getver(struct net_device *dev,$/;"	f
-rtw_mp_hwtx	os_dep/linux/ioctl_mp.c	/^int rtw_mp_hwtx(struct net_device *dev,$/;"	f
-rtw_mp_ioctl_hdl	os_dep/linux/ioctl_linux.c	/^static int rtw_mp_ioctl_hdl(struct net_device *dev, struct iw_request_info *info,$/;"	f	file:
-rtw_mp_iqk	os_dep/linux/ioctl_mp.c	/^int rtw_mp_iqk(struct net_device *dev,$/;"	f
-rtw_mp_lck	os_dep/linux/ioctl_mp.c	/^int rtw_mp_lck(struct net_device *dev,$/;"	f
-rtw_mp_mode	os_dep/linux/os_intfs.c	/^int rtw_mp_mode = 0;$/;"	v
-rtw_mp_mon	os_dep/linux/ioctl_mp.c	/^int rtw_mp_mon(struct net_device *dev,$/;"	f
-rtw_mp_phypara	os_dep/linux/ioctl_mp.c	/^int rtw_mp_phypara(struct net_device *dev,$/;"	f
-rtw_mp_pretx_proc	os_dep/linux/ioctl_mp.c	/^int rtw_mp_pretx_proc(PADAPTER padapter, u8 bStartTest, char *extra)$/;"	f
-rtw_mp_private_args	os_dep/linux/ioctl_linux.c	/^static const struct iw_priv_args rtw_mp_private_args[] = {$/;"	v	typeref:struct:iw_priv_args	file:
-rtw_mp_psd	os_dep/linux/ioctl_mp.c	/^int rtw_mp_psd(struct net_device *dev,$/;"	f
-rtw_mp_pwrtrk	os_dep/linux/ioctl_mp.c	/^int rtw_mp_pwrtrk(struct net_device *dev,$/;"	f
-rtw_mp_rate	os_dep/linux/ioctl_mp.c	/^int rtw_mp_rate(struct net_device *dev,$/;"	f
-rtw_mp_read_reg	os_dep/linux/ioctl_mp.c	/^int rtw_mp_read_reg(struct net_device *dev,$/;"	f
-rtw_mp_read_rf	os_dep/linux/ioctl_mp.c	/^int rtw_mp_read_rf(struct net_device *dev,$/;"	f
-rtw_mp_reset_stats	os_dep/linux/ioctl_mp.c	/^int rtw_mp_reset_stats(struct net_device *dev,$/;"	f
-rtw_mp_rx	os_dep/linux/ioctl_mp.c	/^int rtw_mp_rx(struct net_device *dev,$/;"	f
-rtw_mp_sd_iread	os_dep/linux/ioctl_linux.c	/^static int rtw_mp_sd_iread(struct net_device *dev$/;"	f	file:
-rtw_mp_sd_iwrite	os_dep/linux/ioctl_linux.c	/^static int rtw_mp_sd_iwrite(struct net_device *dev$/;"	f	file:
-rtw_mp_start	os_dep/linux/ioctl_mp.c	/^int rtw_mp_start(struct net_device *dev,$/;"	f
-rtw_mp_stop	os_dep/linux/ioctl_mp.c	/^int rtw_mp_stop(struct net_device *dev,$/;"	f
-rtw_mp_thermal	os_dep/linux/ioctl_mp.c	/^int rtw_mp_thermal(struct net_device *dev,$/;"	f
-rtw_mp_trigger_iqk	core/rtw_mp.c	/^void rtw_mp_trigger_iqk(PADAPTER padapter)$/;"	f
-rtw_mp_trigger_lck	core/rtw_mp.c	/^void rtw_mp_trigger_lck(PADAPTER padapter)$/;"	f
-rtw_mp_trx_query	os_dep/linux/ioctl_mp.c	/^int rtw_mp_trx_query(struct net_device *dev,$/;"	f
-rtw_mp_tx	os_dep/linux/ioctl_mp.c	/^int rtw_mp_tx(struct net_device *dev,$/;"	f
-rtw_mp_txpower	os_dep/linux/ioctl_mp.c	/^int rtw_mp_txpower(struct net_device *dev,$/;"	f
-rtw_mp_txpower_index	os_dep/linux/ioctl_mp.c	/^int rtw_mp_txpower_index(struct net_device *dev,$/;"	f
-rtw_mp_write_reg	os_dep/linux/ioctl_mp.c	/^int rtw_mp_write_reg(struct net_device *dev,$/;"	f
-rtw_mp_write_rf	os_dep/linux/ioctl_mp.c	/^int rtw_mp_write_rf(struct net_device *dev,$/;"	f
-rtw_ms_to_systime	os_dep/osdep_service.c	/^inline u32 rtw_ms_to_systime(u32 ms)$/;"	f
-rtw_msleep_os	os_dep/osdep_service.c	/^void rtw_msleep_os(int ms)$/;"	f
-rtw_mstat_dump	include/osdep_service.h	208;"	d
-rtw_mstat_dump	os_dep/osdep_service.c	/^void rtw_mstat_dump(void *sel)$/;"	f
-rtw_mstat_update	include/osdep_service.h	207;"	d
-rtw_mstat_update	os_dep/osdep_service.c	/^void rtw_mstat_update(const enum mstat_f flags, const MSTAT_STATUS status, u32 sz)$/;"	f
-rtw_mtx_lock	os_dep/osdep_service.c	/^void rtw_mtx_lock(_lock *plock)$/;"	f
-rtw_mtx_unlock	os_dep/osdep_service.c	/^void rtw_mtx_unlock(_lock *plock)$/;"	f
-rtw_napi_gro_receive	include/osdep_service.h	195;"	d
-rtw_napi_gro_receive	include/osdep_service.h	268;"	d
-rtw_ndev_destructor	os_dep/linux/os_intfs.c	/^void rtw_ndev_destructor(struct net_device *ndev)$/;"	f
-rtw_ndev_init	os_dep/linux/os_intfs.c	/^int rtw_ndev_init(struct net_device *dev)$/;"	f
-rtw_ndev_notifier	os_dep/linux/os_intfs.c	/^static struct notifier_block rtw_ndev_notifier = {$/;"	v	typeref:struct:notifier_block	file:
-rtw_ndev_notifier_call	os_dep/linux/os_intfs.c	/^static int rtw_ndev_notifier_call(struct notifier_block *nb, unsigned long state, void *ptr)$/;"	f	file:
-rtw_ndev_notifier_register	os_dep/linux/os_intfs.c	/^int rtw_ndev_notifier_register(void)$/;"	f
-rtw_ndev_notifier_unregister	os_dep/linux/os_intfs.c	/^void rtw_ndev_notifier_unregister(void)$/;"	f
-rtw_ndev_uninit	os_dep/linux/os_intfs.c	/^void rtw_ndev_uninit(struct net_device *dev)$/;"	f
-rtw_ndpa_sta_info	include/rtw_beamforming.h	/^struct rtw_ndpa_sta_info {$/;"	s
-rtw_net_get_stats	os_dep/linux/os_intfs.c	/^static struct net_device_stats *rtw_net_get_stats(struct net_device *pnetdev)$/;"	f	file:
-rtw_net_set_mac_address	os_dep/linux/os_intfs.c	/^static int rtw_net_set_mac_address(struct net_device *pnetdev, void *addr)$/;"	f	file:
-rtw_netdev_ops	os_dep/linux/os_intfs.c	/^static const struct net_device_ops rtw_netdev_ops = {$/;"	v	typeref:struct:net_device_ops	file:
-rtw_netdev_priv	include/osdep_service_bsd.h	733;"	d
-rtw_netdev_priv	include/osdep_service_linux.h	423;"	d
-rtw_netdev_priv_indicator	include/osdep_service_linux.h	/^struct rtw_netdev_priv_indicator {$/;"	s
-rtw_netdev_vir_if_ops	os_dep/linux/os_intfs.c	/^static const struct net_device_ops rtw_netdev_vir_if_ops = {$/;"	v	typeref:struct:net_device_ops	file:
-rtw_netif_carrier_on	include/osdep_service_linux.h	/^static inline void rtw_netif_carrier_on(struct net_device *pnetdev)$/;"	f
-rtw_netif_queue_stopped	include/osdep_service_linux.h	/^static inline int rtw_netif_queue_stopped(struct net_device *pnetdev)$/;"	f
-rtw_netif_receive_skb	include/osdep_service.h	193;"	d
-rtw_netif_receive_skb	include/osdep_service.h	266;"	d
-rtw_netif_rx	include/osdep_service.h	191;"	d
-rtw_netif_rx	include/osdep_service.h	264;"	d
-rtw_netif_start_queue	include/osdep_service_linux.h	/^static inline void rtw_netif_start_queue(struct net_device *pnetdev)$/;"	f
-rtw_netif_stop_queue	include/osdep_service_linux.h	/^static inline void rtw_netif_stop_queue(struct net_device *pnetdev)$/;"	f
-rtw_netif_wake_queue	include/osdep_service_linux.h	/^static inline void rtw_netif_wake_queue(struct net_device *pnetdev)$/;"	f
-rtw_network_mode	os_dep/linux/os_intfs.c	/^int rtw_network_mode = Ndis802_11IBSS;\/* Ndis802_11Infrastructure; *\/ \/* infra, ad-hoc, auto *\/$/;"	v
-rtw_notch_filter	os_dep/linux/os_intfs.c	/^uint rtw_notch_filter = RTW_NOTCH_FILTER;$/;"	v
-rtw_odm_ability_msg	core/rtw_odm.c	/^void rtw_odm_ability_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_ability_set	core/rtw_odm.c	/^inline void rtw_odm_ability_set(_adapter *adapter, u32 ability)$/;"	f
-rtw_odm_acquirespinlock	core/rtw_odm.c	/^void rtw_odm_acquirespinlock(_adapter *adapter,	RT_SPINLOCK_TYPE type)$/;"	f
-rtw_odm_adaptivity_config_msg	core/rtw_odm.c	/^void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_adaptivity_dc_backoff_msg	core/rtw_odm.c	/^void rtw_odm_adaptivity_dc_backoff_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_adaptivity_dml_msg	core/rtw_odm.c	/^void rtw_odm_adaptivity_dml_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_adaptivity_en_msg	core/rtw_odm.c	/^void rtw_odm_adaptivity_en_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_adaptivity_mode_msg	core/rtw_odm.c	/^void rtw_odm_adaptivity_mode_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_adaptivity_needed	core/rtw_odm.c	/^bool rtw_odm_adaptivity_needed(_adapter *adapter)$/;"	f
-rtw_odm_adaptivity_parm_msg	core/rtw_odm.c	/^void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_adaptivity_parm_set	core/rtw_odm.c	/^void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 TH_L2H_ini, s8 TH_EDCCA_HL_diff, s8 TH_L2H_ini_mode2, s8 TH_EDCCA_HL_diff_mode2, u8 EDCCA_enable)$/;"	f
-rtw_odm_adaptivity_ver_msg	core/rtw_odm.c	/^void rtw_odm_adaptivity_ver_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_dbg_comp_msg	core/rtw_odm.c	/^void rtw_odm_dbg_comp_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_dbg_comp_set	core/rtw_odm.c	/^inline void rtw_odm_dbg_comp_set(_adapter *adapter, u64 comps)$/;"	f
-rtw_odm_dbg_level_msg	core/rtw_odm.c	/^void rtw_odm_dbg_level_msg(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_dbg_level_set	core/rtw_odm.c	/^inline void rtw_odm_dbg_level_set(_adapter *adapter, u32 level)$/;"	f
-rtw_odm_get_dfs_domain	core/rtw_odm.c	/^inline u8 rtw_odm_get_dfs_domain(_adapter *adapter)$/;"	f
-rtw_odm_get_force_igi_lb	core/rtw_odm.c	/^inline u8 rtw_odm_get_force_igi_lb(_adapter *adapter)$/;"	f
-rtw_odm_get_perpkt_rssi	core/rtw_odm.c	/^void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter)$/;"	f
-rtw_odm_init_ic_type	core/rtw_odm.c	/^void rtw_odm_init_ic_type(_adapter *adapter)$/;"	f
-rtw_odm_parse_rx_phy_status_chinfo	core/rtw_odm.c	/^void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)$/;"	f
-rtw_odm_proc_deinit	os_dep/linux/rtw_proc.c	/^void rtw_odm_proc_deinit(_adapter	*adapter)$/;"	f
-rtw_odm_proc_init	os_dep/linux/rtw_proc.c	/^struct proc_dir_entry *rtw_odm_proc_init(struct net_device *dev)$/;"	f
-rtw_odm_proc_open	os_dep/linux/rtw_proc.c	/^static int rtw_odm_proc_open(struct inode *inode, struct file *file)$/;"	f	file:
-rtw_odm_proc_seq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_odm_proc_seq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_odm_proc_sseq_fops	os_dep/linux/rtw_proc.c	/^static const struct file_operations rtw_odm_proc_sseq_fops = {$/;"	v	typeref:struct:file_operations	file:
-rtw_odm_proc_write	os_dep/linux/rtw_proc.c	/^static ssize_t rtw_odm_proc_write(struct file *file, const char __user *buffer, size_t count, loff_t *pos)$/;"	f	file:
-rtw_odm_radar_detect	core/rtw_odm.c	/^inline BOOLEAN rtw_odm_radar_detect(_adapter *adapter)$/;"	f
-rtw_odm_radar_detect_disable	core/rtw_odm.c	/^inline VOID rtw_odm_radar_detect_disable(_adapter *adapter)$/;"	f
-rtw_odm_radar_detect_enable	core/rtw_odm.c	/^inline VOID rtw_odm_radar_detect_enable(_adapter *adapter)$/;"	f
-rtw_odm_radar_detect_reset	core/rtw_odm.c	/^inline VOID rtw_odm_radar_detect_reset(_adapter *adapter)$/;"	f
-rtw_odm_releasespinlock	core/rtw_odm.c	/^void rtw_odm_releasespinlock(_adapter *adapter,	RT_SPINLOCK_TYPE type)$/;"	f
-rtw_odm_set_force_igi_lb	core/rtw_odm.c	/^inline void rtw_odm_set_force_igi_lb(_adapter *adapter, u8 lb)$/;"	f
-rtw_os_alloc_msdu_pkt	os_dep/linux/recv_linux.c	/^_pkt *rtw_os_alloc_msdu_pkt(union recv_frame *prframe, u16 nSubframe_Length, u8 *pdata)$/;"	f
-rtw_os_alloc_recvframe	os_dep/linux/recv_linux.c	/^int rtw_os_alloc_recvframe(_adapter *padapter, union recv_frame *precvframe, u8 *pdata, _pkt *pskb)$/;"	f
-rtw_os_free_recvframe	os_dep/linux/recv_linux.c	/^void rtw_os_free_recvframe(union recv_frame *precvframe)$/;"	f
-rtw_os_indicate_connect	os_dep/linux/mlme_linux.c	/^void rtw_os_indicate_connect(_adapter *adapter)$/;"	f
-rtw_os_indicate_disconnect	os_dep/linux/mlme_linux.c	/^void rtw_os_indicate_disconnect(_adapter *adapter,  u16 reason, u8 locally_generated)$/;"	f
-rtw_os_indicate_scan_done	os_dep/linux/mlme_linux.c	/^void rtw_os_indicate_scan_done(_adapter *padapter, bool aborted)$/;"	f
-rtw_os_ksocket_send	os_dep/linux/recv_linux.c	/^static void rtw_os_ksocket_send(_adapter *padapter, union recv_frame *precv_frame)$/;"	f	file:
-rtw_os_ndev_alloc	os_dep/linux/os_intfs.c	/^int rtw_os_ndev_alloc(_adapter *adapter)$/;"	f
-rtw_os_ndev_deinit	os_dep/linux/os_intfs.c	/^void rtw_os_ndev_deinit(_adapter *adapter)$/;"	f
-rtw_os_ndev_free	os_dep/linux/os_intfs.c	/^void rtw_os_ndev_free(_adapter *adapter)$/;"	f
-rtw_os_ndev_init	os_dep/linux/os_intfs.c	/^int rtw_os_ndev_init(_adapter *adapter, const char *name)$/;"	f
-rtw_os_ndev_register	os_dep/linux/os_intfs.c	/^int rtw_os_ndev_register(_adapter *adapter, const char *name)$/;"	f
-rtw_os_ndev_unregister	os_dep/linux/os_intfs.c	/^void rtw_os_ndev_unregister(_adapter *adapter)$/;"	f
-rtw_os_ndevs_alloc	os_dep/linux/os_intfs.c	/^int rtw_os_ndevs_alloc(struct dvobj_priv *dvobj)$/;"	f
-rtw_os_ndevs_deinit	os_dep/linux/os_intfs.c	/^void rtw_os_ndevs_deinit(struct dvobj_priv *dvobj)$/;"	f
-rtw_os_ndevs_free	os_dep/linux/os_intfs.c	/^void rtw_os_ndevs_free(struct dvobj_priv *dvobj)$/;"	f
-rtw_os_ndevs_init	os_dep/linux/os_intfs.c	/^int rtw_os_ndevs_init(struct dvobj_priv *dvobj)$/;"	f
-rtw_os_ndevs_register	os_dep/linux/os_intfs.c	/^int rtw_os_ndevs_register(struct dvobj_priv *dvobj)$/;"	f
-rtw_os_ndevs_unregister	os_dep/linux/os_intfs.c	/^void rtw_os_ndevs_unregister(struct dvobj_priv *dvobj)$/;"	f
-rtw_os_need_stop_queue	os_dep/linux/xmit_linux.c	/^static inline bool rtw_os_need_stop_queue(_adapter *padapter, u16 qidx)$/;"	f	file:
-rtw_os_need_wake_queue	os_dep/linux/xmit_linux.c	/^static inline bool rtw_os_need_wake_queue(_adapter *padapter, u16 qidx)$/;"	f	file:
-rtw_os_pkt_complete	os_dep/linux/xmit_linux.c	/^void rtw_os_pkt_complete(_adapter *padapter, _pkt *pkt)$/;"	f
-rtw_os_read_port	os_dep/linux/recv_linux.c	/^void rtw_os_read_port(_adapter *padapter, struct recv_buf *precvbuf)$/;"	f
-rtw_os_recv_indicate_pkt	os_dep/linux/recv_linux.c	/^void rtw_os_recv_indicate_pkt(_adapter *padapter, _pkt *pkt, struct rx_pkt_attrib *pattrib)$/;"	f
-rtw_os_recv_resource_alloc	os_dep/linux/recv_linux.c	/^int rtw_os_recv_resource_alloc(_adapter *padapter, union recv_frame *precvframe)$/;"	f
-rtw_os_recv_resource_free	os_dep/linux/recv_linux.c	/^void rtw_os_recv_resource_free(struct recv_priv *precvpriv)$/;"	f
-rtw_os_recv_resource_init	os_dep/linux/recv_linux.c	/^int rtw_os_recv_resource_init(struct recv_priv *precvpriv, _adapter *padapter)$/;"	f
-rtw_os_recvbuf_resource_alloc	os_dep/linux/recv_linux.c	/^int rtw_os_recvbuf_resource_alloc(_adapter *padapter, struct recv_buf *precvbuf)$/;"	f
-rtw_os_recvbuf_resource_free	os_dep/linux/recv_linux.c	/^int rtw_os_recvbuf_resource_free(_adapter *padapter, struct recv_buf *precvbuf)$/;"	f
-rtw_os_recvframe_duplicate_skb	os_dep/linux/recv_linux.c	/^int rtw_os_recvframe_duplicate_skb(_adapter *padapter, union recv_frame *pcloneframe, _pkt *pskb)$/;"	f
-rtw_os_wake_queue_at_free_stainfo	os_dep/linux/xmit_linux.c	/^void rtw_os_wake_queue_at_free_stainfo(_adapter *padapter, int *qcnt_freed)$/;"	f
-rtw_os_xmit_complete	os_dep/linux/xmit_linux.c	/^void rtw_os_xmit_complete(_adapter *padapter, struct xmit_frame *pxframe)$/;"	f
-rtw_os_xmit_resource_alloc	os_dep/linux/xmit_linux.c	/^int rtw_os_xmit_resource_alloc(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 alloc_sz, u8 flag)$/;"	f
-rtw_os_xmit_resource_free	os_dep/linux/xmit_linux.c	/^void rtw_os_xmit_resource_free(_adapter *padapter, struct xmit_buf *pxmitbuf, u32 free_sz, u8 flag)$/;"	f
-rtw_os_xmit_schedule	os_dep/linux/xmit_linux.c	/^void rtw_os_xmit_schedule(_adapter *padapter)$/;"	f
-rtw_p2p_ch_inclusion	core/rtw_p2p.c	/^u8 rtw_p2p_ch_inclusion(struct mlme_ext_priv *pmlmeext, u8 *peer_ch_list, u8 peer_ch_num, u8 *ch_list_inclusioned)$/;"	f
-rtw_p2p_check_frames	core/rtw_p2p.c	/^int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx)$/;"	f
-rtw_p2p_check_peer_oper_ch	core/rtw_p2p.c	/^u8 rtw_p2p_check_peer_oper_ch(struct mlme_ext_priv *pmlmeext, u8 ch)$/;"	f
-rtw_p2p_chk_role	include/rtw_p2p.h	155;"	d
-rtw_p2p_chk_state	include/rtw_p2p.h	154;"	d
-rtw_p2p_connect	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_connect(struct net_device *dev,$/;"	f	file:
-rtw_p2p_enable	core/rtw_p2p.c	/^int rtw_p2p_enable(_adapter *padapter, enum P2P_ROLE role)$/;"	f
-rtw_p2p_findphase_ex_is_needed	include/rtw_p2p.h	166;"	d
-rtw_p2p_findphase_ex_is_needed	include/rtw_p2p.h	173;"	d
-rtw_p2p_findphase_ex_is_social	include/rtw_p2p.h	162;"	d
-rtw_p2p_findphase_ex_is_social	include/rtw_p2p.h	172;"	d
-rtw_p2p_findphase_ex_set	include/rtw_p2p.h	157;"	d
-rtw_p2p_get	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get2	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get2(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_device_name	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_device_name(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_device_type	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_device_type(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_go_device_address	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_go_device_address(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_groupid	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_groupid(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_invitation_procedure	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_invitation_procedure(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_op_ch	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_op_ch(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_peer_ch_list	core/rtw_p2p.c	/^u8 rtw_p2p_get_peer_ch_list(struct wifidirect_info *pwdinfo, u8 *ch_content, u8 ch_cnt, u8 *peer_ch_list)$/;"	f
-rtw_p2p_get_peer_devaddr	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_peer_devaddr(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_peer_devaddr_by_invitation	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_peer_devaddr_by_invitation(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_peer_ifaddr	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_peer_ifaddr(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_peer_wfd_port	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_peer_wfd_port(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_peer_wfd_preferred_connection	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_peer_wfd_preferred_connection(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_peer_wfd_session_available	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_peer_wfd_session_available(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_req_cm	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_req_cm(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_role	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_role(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_status	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_status(struct net_device *dev,$/;"	f	file:
-rtw_p2p_get_wps_configmethod	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_get_wps_configmethod(struct net_device *dev,$/;"	f	file:
-rtw_p2p_got_wpsinfo	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_got_wpsinfo(struct net_device *dev,$/;"	f	file:
-rtw_p2p_invite_req	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_invite_req(struct net_device *dev,$/;"	f	file:
-rtw_p2p_is_channel_list_ok	core/rtw_p2p.c	/^int rtw_p2p_is_channel_list_ok(u8 desired_ch, u8 *ch_list, u8 ch_cnt)$/;"	f
-rtw_p2p_merge_ies	core/rtw_ieee80211.c	/^int rtw_p2p_merge_ies(u8 *in_ie, u32 in_len, u8 *merge_ie)$/;"	f
-rtw_p2p_nego_intent_compare	core/rtw_p2p.c	/^bool rtw_p2p_nego_intent_compare(u8 req, u8 resp)$/;"	f
-rtw_p2p_pre_state	include/rtw_p2p.h	152;"	d
-rtw_p2p_profilefound	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_profilefound(struct net_device *dev,$/;"	f	file:
-rtw_p2p_prov_disc	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_prov_disc(struct net_device *dev,$/;"	f	file:
-rtw_p2p_role	include/rtw_p2p.h	153;"	d
-rtw_p2p_role_txt	core/rtw_p2p.c	/^const char *rtw_p2p_role_txt(enum P2P_ROLE role)$/;"	f
-rtw_p2p_set	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set(struct net_device *dev,$/;"	f	file:
-rtw_p2p_setDN	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_setDN(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_driver_iface	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_driver_iface(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_go_nego_ssid	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_go_nego_ssid(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_intent	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_intent(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_listen_ch	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_listen_ch(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_op_ch	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_op_ch(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_pc	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_pc(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_persistent	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_persistent(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_pre_state	include/rtw_p2p.h	141;"	d
-rtw_p2p_set_pre_state	include/rtw_p2p.h	146;"	d
-rtw_p2p_set_role	include/rtw_p2p.h	142;"	d
-rtw_p2p_set_role	include/rtw_p2p.h	147;"	d
-rtw_p2p_set_sa	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_sa(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_state	include/rtw_p2p.h	140;"	d
-rtw_p2p_set_state	include/rtw_p2p.h	145;"	d
-rtw_p2p_set_wfd_device_type	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_wfd_device_type(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_wfd_enable	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_wfd_enable(struct net_device *dev,$/;"	f	file:
-rtw_p2p_set_wps_uuid	os_dep/linux/ioctl_linux.c	/^static int rtw_p2p_set_wps_uuid(struct net_device *dev,$/;"	f	file:
-rtw_p2p_state	include/rtw_p2p.h	151;"	d
-rtw_p2p_state_txt	core/rtw_p2p.c	/^const char *rtw_p2p_state_txt(enum P2P_STATE state)$/;"	f
-rtw_parse_cipher_list	core/rtw_wlan_util.c	/^int rtw_parse_cipher_list(struct pno_nlo_info *nlo_info, char *list_str)$/;"	f
-rtw_parse_ssid_list_tlv	core/rtw_wlan_util.c	/^int rtw_parse_ssid_list_tlv(char **list_str, pno_ssid_t *ssid,$/;"	f
-rtw_parse_wpa2_ie	core/rtw_ieee80211.c	/^int rtw_parse_wpa2_ie(u8 *rsn_ie, int rsn_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x)$/;"	f
-rtw_parse_wpa_ie	core/rtw_ieee80211.c	/^int rtw_parse_wpa_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x)$/;"	f
-rtw_pd_iface_alloc	os_dep/linux/ioctl_cfg80211.c	/^int rtw_pd_iface_alloc(struct wiphy *wiphy, const char *name, struct wireless_dev **pd_wdev)$/;"	f
-rtw_pd_iface_free	os_dep/linux/ioctl_cfg80211.c	/^void rtw_pd_iface_free(struct wiphy *wiphy)$/;"	f
-rtw_phy_file_path	os_dep/linux/os_intfs.c	/^char *rtw_phy_file_path = REALTEK_CONFIG_PATH;$/;"	v
-rtw_phy_para_file_path	hal/hal_com.c	/^	char	rtw_phy_para_file_path[PATH_LENGTH_MAX];$/;"	v
-rtw_phydm_ability_backup	include/hal_com.h	585;"	d
-rtw_phydm_ability_get	include/hal_com.h	/^static inline u32 rtw_phydm_ability_get(_adapter *adapter)$/;"	f
-rtw_phydm_ability_ops	hal/hal_com.c	/^u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability)$/;"	f
-rtw_phydm_ability_restore	include/hal_com.h	588;"	d
-rtw_phydm_ability_set	include/hal_com.h	591;"	d
-rtw_phydm_func_clr	include/hal_com.h	582;"	d
-rtw_phydm_func_disable_all	include/hal_com.h	569;"	d
-rtw_phydm_func_for_offchannel	include/hal_com.h	572;"	d
-rtw_phydm_func_set	include/hal_com.h	579;"	d
-rtw_pll_ref_clk_sel	os_dep/linux/os_intfs.c	/^uint rtw_pll_ref_clk_sel = CONFIG_RTW_PLL_REF_CLK_SEL;$/;"	v
-rtw_pm_set	os_dep/linux/ioctl_linux.c	/^static int rtw_pm_set(struct net_device *dev,$/;"	f	file:
-rtw_pm_set_ips	core/rtw_pwrctrl.c	/^int rtw_pm_set_ips(_adapter *padapter, u8 mode)$/;"	f
-rtw_pm_set_lps	core/rtw_pwrctrl.c	/^int rtw_pm_set_lps(_adapter *padapter, u8 mode)$/;"	f
-rtw_pnp_set_power_sleep	core/rtw_ioctl_set.c	/^u8 rtw_pnp_set_power_sleep(_adapter *padapter)$/;"	f
-rtw_pnp_set_power_wakeup	core/rtw_ioctl_set.c	/^u8 rtw_pnp_set_power_wakeup(_adapter *padapter)$/;"	f
-rtw_port_switch_chk	core/rtw_mlme_ext.c	/^bool rtw_port_switch_chk(_adapter *adapter)$/;"	f
-rtw_power_mgnt	os_dep/linux/os_intfs.c	/^	int rtw_power_mgnt = PS_MODE_ACTIVE;$/;"	v
-rtw_power_mgnt	os_dep/linux/os_intfs.c	/^	int rtw_power_mgnt = PS_MODE_MAX;$/;"	v
-rtw_powertracking_type	os_dep/linux/os_intfs.c	/^uint rtw_powertracking_type = 64;$/;"	v
-rtw_preamble	os_dep/linux/os_intfs.c	/^int rtw_preamble = PREAMBLE_LONG;\/* long, short, auto *\/$/;"	v
-rtw_priv_get	os_dep/linux/ioctl_linux.c	/^static int rtw_priv_get(struct net_device *dev,$/;"	f	file:
-rtw_priv_mp_get	os_dep/linux/ioctl_linux.c	/^static int rtw_priv_mp_get(struct net_device *dev,$/;"	f	file:
-rtw_priv_mp_set	os_dep/linux/ioctl_linux.c	/^static int rtw_priv_mp_set(struct net_device *dev,$/;"	f	file:
-rtw_priv_set	os_dep/linux/ioctl_linux.c	/^static int rtw_priv_set(struct net_device *dev,$/;"	f	file:
-rtw_private_args	os_dep/linux/ioctl_linux.c	/^static const struct iw_priv_args rtw_private_args[] = {$/;"	v	typeref:struct:iw_priv_args	file:
-rtw_private_handler	os_dep/linux/ioctl_linux.c	/^static iw_handler rtw_private_handler[] = {$/;"	v	file:
-rtw_proc	os_dep/linux/rtw_proc.c	/^static struct proc_dir_entry *rtw_proc = NULL;$/;"	v	typeref:struct:proc_dir_entry	file:
-rtw_proc_create_dir	os_dep/linux/rtw_proc.c	/^inline struct proc_dir_entry *rtw_proc_create_dir(const char *name, struct proc_dir_entry *parent, void *data)$/;"	f
-rtw_proc_create_entry	os_dep/linux/rtw_proc.c	/^inline struct proc_dir_entry *rtw_proc_create_entry(const char *name, struct proc_dir_entry *parent,$/;"	f
-rtw_proc_hdl	os_dep/linux/rtw_proc.h	/^struct rtw_proc_hdl {$/;"	s
-rtw_process_ht_action_smps	core/rtw_ap.c	/^void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field)$/;"	f
-rtw_process_public_act_bsscoex	core/rtw_ap.c	/^void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len)$/;"	f
-rtw_process_vht_op_mode_notify	core/rtw_vht.c	/^void rtw_process_vht_op_mode_notify(_adapter *padapter, u8 *pframe, PVOID sta)$/;"	f
-rtw_process_wfd_ie	core/rtw_wlan_util.c	/^void rtw_process_wfd_ie(_adapter *adapter, u8 *wfd_ie, u8 wfd_ielen, const char *tag)$/;"	f
-rtw_process_wfd_ies	core/rtw_wlan_util.c	/^void rtw_process_wfd_ies(_adapter *adapter, u8 *ies, u8 ies_len, const char *tag)$/;"	f
-rtw_ps_cmd	core/rtw_cmd.c	/^u8 rtw_ps_cmd(_adapter *padapter)$/;"	f
-rtw_ps_deny	core/rtw_pwrctrl.c	/^void rtw_ps_deny(PADAPTER padapter, PS_DENY_REASON reason)$/;"	f
-rtw_ps_deny_cancel	core/rtw_pwrctrl.c	/^void rtw_ps_deny_cancel(PADAPTER padapter, PS_DENY_REASON reason)$/;"	f
-rtw_ps_deny_get	core/rtw_pwrctrl.c	/^u32 rtw_ps_deny_get(PADAPTER padapter)$/;"	f
-rtw_ps_processor	core/rtw_pwrctrl.c	/^void rtw_ps_processor(_adapter *padapter)$/;"	f
-rtw_put_snap	core/rtw_xmit.c	/^s32 rtw_put_snap(u8 *data, u16 h_proto)$/;"	f
-rtw_pwr_unassociated_idle	core/rtw_pwrctrl.c	/^bool rtw_pwr_unassociated_idle(_adapter *adapter)$/;"	f
-rtw_pwr_wakeup	include/rtw_pwrctrl.h	533;"	d
-rtw_pwr_wakeup_ex	include/rtw_pwrctrl.h	534;"	d
-rtw_pwrtrim_enable	os_dep/linux/os_intfs.c	/^	int rtw_pwrtrim_enable = 0; \/* Default Enalbe  power trim by efuse config *\/$/;"	v
-rtw_pwrtrim_enable	os_dep/linux/os_intfs.c	/^	int rtw_pwrtrim_enable = 2; \/* disable kfree , rename to power trim disable *\/$/;"	v
-rtw_qos_opt_enable	os_dep/linux/os_intfs.c	/^int rtw_qos_opt_enable = 0; \/* 0: disable,1:enable *\/$/;"	v
-rtw_qos_opt_enable	os_dep/linux/os_intfs.c	/^int rtw_qos_opt_enable = 1; \/* 0: disable,1:enable *\/$/;"	v
-rtw_radio_enable	os_dep/linux/os_intfs.c	/^int rtw_radio_enable = 1;$/;"	v
-rtw_random32	os_dep/osdep_service.c	/^inline u32 rtw_random32(void)$/;"	f
-rtw_rates	os_dep/linux/ioctl_cfg80211.c	/^static struct ieee80211_rate rtw_rates[] = {$/;"	v	typeref:struct:ieee80211_rate	file:
-rtw_rates	os_dep/linux/ioctl_linux.c	/^u32 rtw_rates[] = {1000000, 2000000, 5500000, 11000000,$/;"	v
-rtw_read16	include/rtw_io.h	430;"	d
-rtw_read16	include/rtw_io.h	468;"	d
-rtw_read32	include/rtw_io.h	431;"	d
-rtw_read32	include/rtw_io.h	469;"	d
-rtw_read8	include/rtw_io.h	429;"	d
-rtw_read8	include/rtw_io.h	467;"	d
-rtw_read_efuse_from_file	core/efuse/rtw_efuse.c	/^u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size)$/;"	f
-rtw_read_from_frame_mask	core/rtw_wlan_util.c	/^bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)$/;"	f
-rtw_read_macaddr_from_file	core/efuse/rtw_efuse.c	/^u32 rtw_read_macaddr_from_file(const char *path, u8 *buf)$/;"	f
-rtw_read_mem	include/rtw_io.h	432;"	d
-rtw_read_mem	include/rtw_io.h	470;"	d
-rtw_read_port	include/rtw_io.h	433;"	d
-rtw_read_port	include/rtw_io.h	471;"	d
-rtw_read_port_cancel	include/rtw_io.h	434;"	d
-rtw_read_port_cancel	include/rtw_io.h	472;"	d
-rtw_readtssi_cmdrsp_callback	core/rtw_cmd.c	/^void rtw_readtssi_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)$/;"	f
-rtw_recv_entry	core/rtw_recv.c	/^s32 rtw_recv_entry(union recv_frame *precvframe)$/;"	f
-rtw_recv_indicatepkt	os_dep/linux/recv_linux.c	/^int rtw_recv_indicatepkt(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-rtw_recv_monitor	os_dep/linux/recv_linux.c	/^int rtw_recv_monitor(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-rtw_recv_napi_poll	os_dep/linux/recv_linux.c	/^int rtw_recv_napi_poll(struct napi_struct *napi, int budget)$/;"	f
-rtw_recv_select_queue	os_dep/linux/os_intfs.c	/^u16 rtw_recv_select_queue(struct sk_buff *skb)$/;"	f
-rtw_reg_notifier	os_dep/linux/wifi_regd.c	/^int rtw_reg_notifier(struct wiphy *wiphy, struct regulatory_request *request)$/;"	f
-rtw_reg_notify_by_driver	os_dep/linux/wifi_regd.c	/^void rtw_reg_notify_by_driver(_adapter *adapter)$/;"	f
-rtw_regd_init	os_dep/linux/wifi_regd.c	/^int rtw_regd_init(_adapter *padapter)$/;"	f
-rtw_regdom_11	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain rtw_regdom_11 = {$/;"	v	typeref:struct:ieee80211_regdomain	file:
-rtw_regdom_12_13	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain rtw_regdom_12_13 = {$/;"	v	typeref:struct:ieee80211_regdomain	file:
-rtw_regdom_14	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain rtw_regdom_14 = {$/;"	v	typeref:struct:ieee80211_regdomain	file:
-rtw_regdom_14_60_64	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain rtw_regdom_14_60_64 = {$/;"	v	typeref:struct:ieee80211_regdomain	file:
-rtw_regdom_60_64	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain rtw_regdom_60_64 = {$/;"	v	typeref:struct:ieee80211_regdomain	file:
-rtw_regdom_no_midband	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain rtw_regdom_no_midband = {$/;"	v	typeref:struct:ieee80211_regdomain	file:
-rtw_regdom_rd	os_dep/linux/wifi_regd.c	/^static const struct ieee80211_regdomain rtw_regdom_rd = {$/;"	v	typeref:struct:ieee80211_regdomain	file:
-rtw_register_cmd_alive	core/rtw_pwrctrl.c	/^s32 rtw_register_cmd_alive(PADAPTER padapter)$/;"	f
-rtw_register_early_suspend	core/rtw_pwrctrl.c	/^void rtw_register_early_suspend(struct pwrctrl_priv *pwrpriv)$/;"	f
-rtw_register_early_suspend	include/rtw_pwrctrl.h	526;"	d
-rtw_register_evt_alive	core/rtw_pwrctrl.c	/^s32 rtw_register_evt_alive(PADAPTER padapter)$/;"	f
-rtw_register_gpio_interrupt	os_dep/linux/os_intfs.c	/^EXPORT_SYMBOL(rtw_register_gpio_interrupt);$/;"	v
-rtw_register_gpio_interrupt	os_dep/linux/os_intfs.c	/^int rtw_register_gpio_interrupt(struct net_device *netdev, int gpio_num, void(*callback)(u8 level))$/;"	f
-rtw_register_rx_alive	core/rtw_pwrctrl.c	/^s32 rtw_register_rx_alive(PADAPTER padapter)$/;"	f
-rtw_register_task_alive	core/rtw_pwrctrl.c	/^s32 rtw_register_task_alive(PADAPTER padapter, u32 task)$/;"	f
-rtw_register_tx_alive	core/rtw_pwrctrl.c	/^s32 rtw_register_tx_alive(PADAPTER padapter)$/;"	f
-rtw_regsty_chk_target_tx_power_valid	hal/hal_com_phycfg.c	/^bool rtw_regsty_chk_target_tx_power_valid(_adapter *adapter)$/;"	f
-rtw_regsty_get_target_tx_power	hal/hal_com_phycfg.c	/^s8 rtw_regsty_get_target_tx_power($/;"	f
-rtw_regsty_is_excl_chs	core/rtw_mlme_ext.c	/^bool rtw_regsty_is_excl_chs(struct registry_priv *regsty, u8 ch)$/;"	f
-rtw_regsty_load_excl_chs	os_dep/linux/os_intfs.c	/^inline void rtw_regsty_load_excl_chs(struct registry_priv *regsty)$/;"	f
-rtw_regsty_load_target_tx_power	os_dep/linux/os_intfs.c	/^void rtw_regsty_load_target_tx_power(struct registry_priv *regsty)$/;"	f
-rtw_regulatory	include/wifi.h	/^struct rtw_regulatory {$/;"	s
-rtw_release_macid	core/rtw_wlan_util.c	/^void rtw_release_macid(_adapter *padapter, struct sta_info *psta)$/;"	f
-rtw_remainder_len	os_dep/linux/xmit_linux.c	/^uint rtw_remainder_len(struct pkt_file *pfile)$/;"	f
-rtw_remove_bcn_ie	core/rtw_ap.c	/^void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index)$/;"	f
-rtw_remove_pmkid	core/rtw_mlme.c	/^static int rtw_remove_pmkid(_adapter *adapter, u8 *ie, uint ie_len)$/;"	f	file:
-rtw_reordering_ctrl_timeout_handler	core/rtw_recv.c	/^void rtw_reordering_ctrl_timeout_handler(void *pcontext)$/;"	f
-rtw_report_sec_ie	os_dep/linux/mlme_linux.c	/^void rtw_report_sec_ie(_adapter *adapter, u8 authmode, u8 *sec_ie)$/;"	f
-rtw_request_wps_pbc_event	os_dep/linux/ioctl_linux.c	/^void rtw_request_wps_pbc_event(_adapter *padapter)$/;"	f
-rtw_rereg_nd_name	os_dep/linux/ioctl_linux.c	/^static int rtw_rereg_nd_name(struct net_device *dev,$/;"	f	file:
-rtw_reset_cac	core/rtw_mlme_ext.c	/^void rtw_reset_cac(_adapter *adapter, u8 ch, u8 bw, u8 offset)$/;"	f
-rtw_reset_continual_io_error	core/rtw_io.c	/^void rtw_reset_continual_io_error(struct dvobj_priv *dvobj)$/;"	f
-rtw_reset_continual_no_rx_packet	core/rtw_recv.c	/^void rtw_reset_continual_no_rx_packet(struct sta_info *sta, int tid_index)$/;"	f
-rtw_reset_drv_rx_counters	hal/hal_com.c	/^void rtw_reset_drv_rx_counters(_adapter *padapter)$/;"	f
-rtw_reset_drv_sw	os_dep/linux/os_intfs.c	/^u8 rtw_reset_drv_sw(_adapter *padapter)$/;"	f
-rtw_reset_ft_status	include/rtw_mlme.h	546;"	d
-rtw_reset_mac_rx_counters	hal/hal_com.c	/^void rtw_reset_mac_rx_counters(_adapter *padapter)$/;"	f
-rtw_reset_phy_rx_counters	hal/hal_com.c	/^void rtw_reset_phy_rx_counters(_adapter *padapter)$/;"	f
-rtw_reset_phy_trx_ok_counters	hal/hal_com.c	/^void rtw_reset_phy_trx_ok_counters(_adapter *padapter)$/;"	f
-rtw_reset_rx_info	core/rtw_mlme.c	/^void rtw_reset_rx_info(struct debug_priv *pdbgpriv)$/;"	f
-rtw_reset_securitypriv	os_dep/linux/mlme_linux.c	/^void rtw_reset_securitypriv(_adapter *adapter)$/;"	f
-rtw_reset_securitypriv_cmd	core/rtw_cmd.c	/^u8 rtw_reset_securitypriv_cmd(_adapter *padapter)$/;"	f
-rtw_reset_tdls_info	core/rtw_tdls.c	/^void rtw_reset_tdls_info(_adapter *padapter)$/;"	f
-rtw_restore_mac_addr	hal/hal_com.c	/^void rtw_restore_mac_addr(_adapter *adapter)$/;"	f
-rtw_restruct_sec_ie	core/rtw_mlme.c	/^sint rtw_restruct_sec_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len)$/;"	f
-rtw_restruct_wmm_ie	core/rtw_mlme.c	/^int rtw_restruct_wmm_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len, uint initial_out_len)$/;"	f
-rtw_restructure_ht_ie	core/rtw_mlme.c	/^unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len, u8 channel)$/;"	f
-rtw_restructure_vht_ie	core/rtw_vht.c	/^u32 rtw_restructure_vht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len)$/;"	f
-rtw_resume_common	os_dep/linux/os_intfs.c	/^int rtw_resume_common(_adapter *padapter)$/;"	f
-rtw_resume_in_workqueue	core/rtw_pwrctrl.c	/^void rtw_resume_in_workqueue(struct pwrctrl_priv *pwrpriv)$/;"	f
-rtw_resume_lock_suspend	os_dep/osdep_service.c	/^inline void rtw_resume_lock_suspend(void)$/;"	f
-rtw_resume_process	os_dep/linux/sdio_intf.c	/^int rtw_resume_process(_adapter *padapter)$/;"	f
-rtw_resume_process_ap_wow	os_dep/linux/os_intfs.c	/^int rtw_resume_process_ap_wow(_adapter *padapter)$/;"	f
-rtw_resume_process_normal	os_dep/linux/os_intfs.c	/^int rtw_resume_process_normal(_adapter *padapter)$/;"	f
-rtw_resume_process_wow	os_dep/linux/os_intfs.c	/^int rtw_resume_process_wow(_adapter *padapter)$/;"	f
-rtw_resume_scan_lock	os_dep/osdep_service.c	/^static android_suspend_lock_t rtw_resume_scan_lock = {$/;"	v	file:
-rtw_resume_scan_lock	os_dep/osdep_service.c	/^static struct wake_lock rtw_resume_scan_lock;$/;"	v	typeref:struct:wake_lock	file:
-rtw_resume_unlock_suspend	os_dep/osdep_service.c	/^inline void rtw_resume_unlock_suspend(void)$/;"	f
-rtw_retrieve_from_file	os_dep/osdep_service.c	/^int rtw_retrieve_from_file(const char *path, u8 *buf, u32 sz)$/;"	f
-rtw_rf_apply_tx_gain_offset	core/rtw_rf.c	/^void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch)$/;"	f
-rtw_rf_config	os_dep/linux/os_intfs.c	/^int rtw_rf_config = RF_MAX_TYPE;  \/* auto *\/$/;"	v
-rtw_rf_get_kfree_tx_gain_offset	core/rtw_rf.c	/^s8 rtw_rf_get_kfree_tx_gain_offset(_adapter *padapter, u8 path, u8 ch)$/;"	f
-rtw_rf_set_tx_gain_offset	core/rtw_rf.c	/^void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset)$/;"	f
-rtw_rfc1042_header	include/rtw_recv.h	/^static u8 rtw_rfc1042_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };$/;"	v
-rtw_rfctl_init	core/rtw_mlme_ext.c	/^void rtw_rfctl_init(_adapter *adapter)$/;"	f
-rtw_rfctl_is_tx_blocked_by_ch_waiting	core/rtw_mlme_ext.c	/^bool rtw_rfctl_is_tx_blocked_by_ch_waiting(struct rf_ctl_t *rfctl)$/;"	f
-rtw_rfctl_is_tx_blocked_by_ch_waiting	include/rtw_mlme_ext.h	522;"	d
-rtw_rfctl_overlap_radar_detect_ch	core/rtw_mlme_ext.c	/^bool rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl)$/;"	f
-rtw_rfintfs	os_dep/linux/os_intfs.c	/^int rtw_rfintfs = HWPI;$/;"	v
-rtw_rframe_del_wfd_ie	core/rtw_recv.c	/^bool rtw_rframe_del_wfd_ie(union recv_frame *rframe, u8 ies_offset)$/;"	f
-rtw_roam_flags	include/rtw_mlme.h	1125;"	d
-rtw_roam_flags	include/rtw_mlme.h	1149;"	d
-rtw_roaming	core/rtw_mlme.c	/^void rtw_roaming(_adapter *padapter, struct wlan_network *tgt_network)$/;"	f
-rtw_roaming	include/rtw_mlme.h	1155;"	d
-rtw_rpt_timer_cfg_cmd	core/rtw_cmd.c	/^u8 rtw_rpt_timer_cfg_cmd(_adapter *padapter, u16 minRptTime)$/;"	f
-rtw_rtkm_get_buff_size	core/rtw_mem.c	/^EXPORT_SYMBOL(rtw_rtkm_get_buff_size);$/;"	v
-rtw_rtkm_get_buff_size	core/rtw_mem.c	/^u16 rtw_rtkm_get_buff_size(void)$/;"	f
-rtw_rtkm_get_nr_recv_skb	core/rtw_mem.c	/^EXPORT_SYMBOL(rtw_rtkm_get_nr_recv_skb);$/;"	v
-rtw_rtkm_get_nr_recv_skb	core/rtw_mem.c	/^u8 rtw_rtkm_get_nr_recv_skb(void)$/;"	f
-rtw_rts_thresh	os_dep/linux/os_intfs.c	/^int rtw_rts_thresh = 2347;$/;"	v
-rtw_run_in_thread_cmd	core/rtw_cmd.c	/^u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void *), void *context)$/;"	f
-rtw_rx_ampdu_apply	core/rtw_mlme_ext.c	/^u16 rtw_rx_ampdu_apply(_adapter *adapter)$/;"	f
-rtw_rx_ampdu_is_accept	core/rtw_mlme_ext.c	/^bool rtw_rx_ampdu_is_accept(_adapter *adapter)$/;"	f
-rtw_rx_ampdu_set_accept	core/rtw_mlme_ext.c	/^bool rtw_rx_ampdu_set_accept(_adapter *adapter, u8 accept, u8 reason)$/;"	f
-rtw_rx_ampdu_set_size	core/rtw_mlme_ext.c	/^bool rtw_rx_ampdu_set_size(_adapter *adapter, u8 size, u8 reason)$/;"	f
-rtw_rx_ampdu_size	core/rtw_mlme_ext.c	/^u8 rtw_rx_ampdu_size(_adapter *adapter)$/;"	f
-rtw_rx_ring	include/rtw_recv.h	/^struct rtw_rx_ring {$/;"	s
-rtw_rx_stbc	os_dep/linux/os_intfs.c	/^int rtw_rx_stbc = 1;\/* 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 *\/$/;"	v
-rtw_rxgain_offset_2g	os_dep/linux/os_intfs.c	/^uint rtw_rxgain_offset_2g = 0;$/;"	v
-rtw_rxgain_offset_5gh	os_dep/linux/os_intfs.c	/^uint rtw_rxgain_offset_5gh = 0;$/;"	v
-rtw_rxgain_offset_5gl	os_dep/linux/os_intfs.c	/^uint rtw_rxgain_offset_5gl = 0;$/;"	v
-rtw_rxgain_offset_5gm	os_dep/linux/os_intfs.c	/^uint rtw_rxgain_offset_5gm = 0;$/;"	v
-rtw_scan_abort	core/rtw_mlme.c	/^void rtw_scan_abort(_adapter *adapter)$/;"	f
-rtw_scan_abort_no_wait	core/rtw_mlme.c	/^void rtw_scan_abort_no_wait(_adapter *adapter)$/;"	f
-rtw_scan_abort_timeout	core/rtw_mlme.c	/^u32 rtw_scan_abort_timeout(_adapter *adapter, u32 timeout_ms)$/;"	f
-rtw_scan_ch_decision	core/rtw_mlme_ext.c	/^static int rtw_scan_ch_decision(_adapter *padapter, struct rtw_ieee80211_channel *out,$/;"	f	file:
-rtw_scan_mode	os_dep/linux/os_intfs.c	/^int rtw_scan_mode = 1;\/* active, passive *\/$/;"	v
-rtw_scan_sparse	core/rtw_mlme_ext.c	/^u8 rtw_scan_sparse(_adapter *adapter, struct rtw_ieee80211_channel *ch, u8 ch_num)$/;"	f
-rtw_scan_timeout_handler	core/rtw_mlme.c	/^void rtw_scan_timeout_handler(_adapter *adapter)$/;"	f
-rtw_scan_wait_completed	core/rtw_mlme.c	/^void rtw_scan_wait_completed(_adapter *adapter)$/;"	f
-rtw_sctx_chk_waring_status	core/rtw_xmit.c	/^bool rtw_sctx_chk_waring_status(int status)$/;"	f
-rtw_sctx_done	core/rtw_xmit.c	/^void rtw_sctx_done(struct submit_ctx **sctx)$/;"	f
-rtw_sctx_done_err	core/rtw_xmit.c	/^void rtw_sctx_done_err(struct submit_ctx **sctx, int status)$/;"	f
-rtw_sctx_init	core/rtw_xmit.c	/^void rtw_sctx_init(struct submit_ctx *sctx, int timeout_ms)$/;"	f
-rtw_sctx_wait	core/rtw_xmit.c	/^int rtw_sctx_wait(struct submit_ctx *sctx, const char *msg)$/;"	f
-rtw_sd_f0_read8	include/rtw_io.h	451;"	d
-rtw_sd_f0_read8	include/rtw_io.h	489;"	d
-rtw_sd_iread16	include/rtw_io.h	454;"	d
-rtw_sd_iread16	include/rtw_io.h	492;"	d
-rtw_sd_iread32	include/rtw_io.h	455;"	d
-rtw_sd_iread32	include/rtw_io.h	493;"	d
-rtw_sd_iread8	include/rtw_io.h	453;"	d
-rtw_sd_iread8	include/rtw_io.h	491;"	d
-rtw_sd_iwrite16	include/rtw_io.h	457;"	d
-rtw_sd_iwrite16	include/rtw_io.h	495;"	d
-rtw_sd_iwrite32	include/rtw_io.h	458;"	d
-rtw_sd_iwrite32	include/rtw_io.h	496;"	d
-rtw_sd_iwrite8	include/rtw_io.h	456;"	d
-rtw_sd_iwrite8	include/rtw_io.h	494;"	d
-rtw_sdio_claim_host_needed	os_dep/linux/sdio_ops_linux.c	/^static bool rtw_sdio_claim_host_needed(struct sdio_func *func)$/;"	f	file:
-rtw_sdio_f0_read	core/rtw_sdio.c	/^u8 rtw_sdio_f0_read(struct dvobj_priv *d, u32 addr, void *buf, size_t len)$/;"	f
-rtw_sdio_pm_ops	os_dep/linux/sdio_intf.c	/^static const struct dev_pm_ops rtw_sdio_pm_ops = {$/;"	v	typeref:struct:dev_pm_ops	file:
-rtw_sdio_primary_adapter_deinit	os_dep/linux/sdio_intf.c	/^static void rtw_sdio_primary_adapter_deinit(_adapter *padapter)$/;"	f	file:
-rtw_sdio_primary_adapter_init	os_dep/linux/sdio_intf.c	/^_adapter *rtw_sdio_primary_adapter_init(struct dvobj_priv *dvobj)$/;"	f
-rtw_sdio_raw_read	os_dep/linux/sdio_ops_linux.c	/^int __must_check rtw_sdio_raw_read(struct dvobj_priv *d, int addr,$/;"	f
-rtw_sdio_raw_write	os_dep/linux/sdio_ops_linux.c	/^int __must_check rtw_sdio_raw_write(struct dvobj_priv *d, int addr,$/;"	f
-rtw_sdio_read_cmd52	core/rtw_sdio.c	/^u8 rtw_sdio_read_cmd52(struct dvobj_priv *d, u32 addr, void *buf, size_t len)$/;"	f
-rtw_sdio_read_cmd53	core/rtw_sdio.c	/^u8 rtw_sdio_read_cmd53(struct dvobj_priv *d, u32 addr, void *buf, size_t len)$/;"	f
-rtw_sdio_resume	os_dep/linux/sdio_intf.c	/^static int rtw_sdio_resume(struct device *dev)$/;"	f	file:
-rtw_sdio_set_irq_thd	os_dep/linux/sdio_ops_linux.c	/^inline void rtw_sdio_set_irq_thd(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl)$/;"	f
-rtw_sdio_set_power	os_dep/linux/sdio_intf.c	/^int rtw_sdio_set_power(int on)$/;"	f
-rtw_sdio_suspend	os_dep/linux/sdio_intf.c	/^static int rtw_sdio_suspend(struct device *dev)$/;"	f	file:
-rtw_sdio_wait_enough_TxOQT_space	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^static u8 rtw_sdio_wait_enough_TxOQT_space(PADAPTER padapter, u8 agg_num)$/;"	f	file:
-rtw_sdio_write_cmd52	core/rtw_sdio.c	/^u8 rtw_sdio_write_cmd52(struct dvobj_priv *d, u32 addr, void *buf, size_t len)$/;"	f
-rtw_sdio_write_cmd53	core/rtw_sdio.c	/^u8 rtw_sdio_write_cmd53(struct dvobj_priv *d, u32 addr, void *buf, size_t len)$/;"	f
-rtw_search_max_mac_id	core/rtw_wlan_util.c	/^u8 rtw_search_max_mac_id(_adapter *padapter)$/;"	f
-rtw_sec_cam_map_clr	core/rtw_wlan_util.c	/^inline void rtw_sec_cam_map_clr(struct sec_cam_bmp *map, u8 id)$/;"	f
-rtw_sec_cam_map_clr_all	core/rtw_wlan_util.c	/^inline void rtw_sec_cam_map_clr_all(struct sec_cam_bmp *map)$/;"	f
-rtw_sec_cam_map_set	core/rtw_wlan_util.c	/^inline void rtw_sec_cam_map_set(struct sec_cam_bmp *map, u8 id)$/;"	f
-rtw_sec_cam_swap	core/rtw_wlan_util.c	/^inline void rtw_sec_cam_swap(_adapter *adapter, u8 cam_id_a, u8 cam_id_b)$/;"	f
-rtw_sec_camid_is_drv_forbid	core/rtw_wlan_util.c	/^inline bool rtw_sec_camid_is_drv_forbid(struct cam_ctl_t *cam_ctl, u8 id)$/;"	f
-rtw_sec_camid_is_set	core/rtw_wlan_util.c	/^inline bool rtw_sec_camid_is_set(struct sec_cam_bmp *map, u8 id)$/;"	f
-rtw_sec_camid_is_used	core/rtw_wlan_util.c	/^inline bool rtw_sec_camid_is_used(struct cam_ctl_t *cam_ctl, u8 id)$/;"	f
-rtw_sec_clr_cam_ent	hal/hal_com.c	/^void rtw_sec_clr_cam_ent(_adapter *adapter, u8 id)$/;"	f
-rtw_sec_read_cam	hal/hal_com.c	/^u32 rtw_sec_read_cam(_adapter *adapter, u8 addr)$/;"	f
-rtw_sec_read_cam_ent	hal/hal_com.c	/^void rtw_sec_read_cam_ent(_adapter *adapter, u8 id, u8 *ctrl, u8 *mac, u8 *key)$/;"	f
-rtw_sec_read_cam_is_gk	hal/hal_com.c	/^bool rtw_sec_read_cam_is_gk(_adapter *adapter, u8 id)$/;"	f
-rtw_sec_restore_wep_key	core/rtw_security.c	/^void rtw_sec_restore_wep_key(_adapter *adapter)$/;"	f
-rtw_sec_write_cam	hal/hal_com.c	/^void rtw_sec_write_cam(_adapter *adapter, u8 addr, u32 wdata)$/;"	f
-rtw_sec_write_cam_ent	hal/hal_com.c	/^void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)$/;"	f
-rtw_seccalctkipmic	core/rtw_security.c	/^void rtw_seccalctkipmic(u8 *key, u8 *header, u8 *data, u32 data_len, u8 *mic_code, u8 pri)$/;"	f
-rtw_secgetmic	core/rtw_security.c	/^void rtw_secgetmic(struct mic_data *pmicdata, u8 *dst)$/;"	f
-rtw_secmicappend	core/rtw_security.c	/^void rtw_secmicappend(struct mic_data *pmicdata, u8 *src, u32 nbytes)$/;"	f
-rtw_secmicappendbyte	core/rtw_security.c	/^void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b)$/;"	f
-rtw_secmicsetkey	core/rtw_security.c	/^void rtw_secmicsetkey(struct mic_data *pmicdata, u8 *key)$/;"	f
-rtw_select_and_join_from_scanned_queue	core/rtw_mlme.c	/^int rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv)$/;"	f
-rtw_select_queue	os_dep/linux/os_intfs.c	/^static u16 rtw_select_queue(struct net_device *dev, struct sk_buff *skb$/;"	f	file:
-rtw_select_roaming_candidate	core/rtw_mlme.c	/^int rtw_select_roaming_candidate(struct mlme_priv *mlme)$/;"	f
-rtw_select_roaming_candidate	include/rtw_mlme.h	1159;"	d
-rtw_set_802_11_add_key	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_add_key(_adapter *padapter, NDIS_802_11_KEY *key)$/;"	f
-rtw_set_802_11_add_wep	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_add_wep(_adapter *padapter, NDIS_802_11_WEP *wep)$/;"	f
-rtw_set_802_11_authentication_mode	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_authentication_mode(_adapter *padapter, NDIS_802_11_AUTHENTICATION_MODE authmode)$/;"	f
-rtw_set_802_11_bssid	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_bssid(_adapter *padapter, u8 *bssid)$/;"	f
-rtw_set_802_11_bssid_list_scan	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, NDIS_802_11_SSID *pssid, int ssid_max_num, struct rtw_ieee80211_channel *ch, int ch_num)$/;"	f
-rtw_set_802_11_connect	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_connect(_adapter *padapter, u8 *bssid, NDIS_802_11_SSID *ssid)$/;"	f
-rtw_set_802_11_disassociate	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_disassociate(_adapter *padapter)$/;"	f
-rtw_set_802_11_infrastructure_mode	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter,$/;"	f
-rtw_set_802_11_pmkid	core/rtw_ioctl_set.c	/^u8	rtw_set_802_11_pmkid(_adapter	*padapter, NDIS_802_11_PMKID *pmkid)$/;"	f
-rtw_set_802_11_reload_defaults	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_reload_defaults(_adapter *padapter, NDIS_802_11_RELOAD_DEFAULTS reloadDefaults)$/;"	f
-rtw_set_802_11_remove_key	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_remove_key(_adapter	*padapter, NDIS_802_11_REMOVE_KEY *key)$/;"	f
-rtw_set_802_11_remove_wep	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_remove_wep(_adapter *padapter, u32 keyindex)$/;"	f
-rtw_set_802_11_ssid	core/rtw_ioctl_set.c	/^u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid)$/;"	f
-rtw_set_acs_channel	include/hal_data.h	764;"	d
-rtw_set_auth	core/rtw_mlme.c	/^sint rtw_set_auth(_adapter *adapter, struct security_priv *psecuritypriv)$/;"	f
-rtw_set_band	core/rtw_ioctl_set.c	/^int rtw_set_band(_adapter *adapter, u8 band)$/;"	f
-rtw_set_beacon	os_dep/linux/ioctl_linux.c	/^static int rtw_set_beacon(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_set_ch_cmd	core/rtw_cmd.c	/^u8 rtw_set_ch_cmd(_adapter *padapter, u8 ch, u8 bw, u8 ch_offset, u8 enqueue)$/;"	f
-rtw_set_channel_plan	core/rtw_ioctl_set.c	/^int rtw_set_channel_plan(_adapter *adapter, u8 channel_plan)$/;"	f
-rtw_set_chplan_cmd	core/rtw_cmd.c	/^inline u8 rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, u8 swconfig)$/;"	f
-rtw_set_country	core/rtw_ioctl_set.c	/^int rtw_set_country(_adapter *adapter, const char *country_code)$/;"	f
-rtw_set_country_cmd	core/rtw_cmd.c	/^inline u8 rtw_set_country_cmd(_adapter *adapter, int flags, const char *country_code, u8 swconfig)$/;"	f
-rtw_set_csa_cmd	core/rtw_cmd.c	/^u8 rtw_set_csa_cmd(_adapter *padapter, u8 new_ch_no)$/;"	f
-rtw_set_ctx_destAddr	os_dep/linux/ioctl_mp.c	/^int rtw_set_ctx_destAddr(struct net_device *dev,$/;"	f
-rtw_set_default_pattern	core/rtw_wlan_util.c	/^u8 rtw_set_default_pattern(_adapter *adapter)$/;"	f
-rtw_set_do_late_resume	core/rtw_pwrctrl.c	/^inline void rtw_set_do_late_resume(struct pwrctrl_priv *pwrpriv, bool enable)$/;"	f
-rtw_set_do_late_resume	include/rtw_pwrctrl.h	525;"	d
-rtw_set_drv_stopped	include/drv_types.h	/^static inline void rtw_set_drv_stopped(_adapter *padapter)$/;"	f
-rtw_set_encryption	os_dep/linux/ioctl_linux.c	/^static int rtw_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)$/;"	f	file:
-rtw_set_fixed_ie	core/rtw_ieee80211.c	/^u8 *rtw_set_fixed_ie(unsigned char *pbuf, unsigned int len, unsigned char *source,$/;"	f
-rtw_set_ft_flags	include/rtw_mlme.h	559;"	d
-rtw_set_ft_status	include/rtw_mlme.h	541;"	d
-rtw_set_fw_in_ips_mode	core/rtw_pwrctrl.c	/^void rtw_set_fw_in_ips_mode(PADAPTER padapter, u8 enable)$/;"	f
-rtw_set_gpio_output_value	os_dep/linux/os_intfs.c	/^EXPORT_SYMBOL(rtw_set_gpio_output_value);$/;"	v
-rtw_set_gpio_output_value	os_dep/linux/os_intfs.c	/^int  rtw_set_gpio_output_value(struct net_device *netdev, u8 gpio_num, bool isHigh)$/;"	f
-rtw_set_hal_ops	os_dep/linux/sdio_intf.c	/^u8 rtw_set_hal_ops(PADAPTER padapter)$/;"	f
-rtw_set_hidden_ssid	os_dep/linux/ioctl_linux.c	/^static int rtw_set_hidden_ssid(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_set_hw_wmm_param	core/rtw_ap.c	/^static void rtw_set_hw_wmm_param(_adapter *padapter)$/;"	f	file:
-rtw_set_ie	core/rtw_ieee80211.c	/^u8 *rtw_set_ie$/;"	f
-rtw_set_ie_ch_switch	core/rtw_ieee80211.c	/^inline u8 *rtw_set_ie_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode,$/;"	f
-rtw_set_ie_mesh_ch_switch_parm	core/rtw_ieee80211.c	/^inline u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl,$/;"	f
-rtw_set_ie_secondary_ch_offset	core/rtw_ieee80211.c	/^inline u8 *rtw_set_ie_secondary_ch_offset(u8 *buf, u32 *buf_len, u8 secondary_ch_offset)$/;"	f
-rtw_set_ips_deny	core/rtw_pwrctrl.c	/^inline void rtw_set_ips_deny(_adapter *padapter, u32 ms)$/;"	f
-rtw_set_key	core/rtw_mlme.c	/^sint rtw_set_key(_adapter *adapter, struct security_priv *psecuritypriv, sint keyid, u8 set_tx, bool enqueue)$/;"	f
-rtw_set_macaddr_acl	core/rtw_ap.c	/^void rtw_set_macaddr_acl(_adapter *adapter, int mode)$/;"	f
-rtw_set_oper_bw	core/rtw_wlan_util.c	/^inline void rtw_set_oper_bw(_adapter *adapter, u8 bw)$/;"	f
-rtw_set_oper_ch	core/rtw_wlan_util.c	/^inline void rtw_set_oper_ch(_adapter *adapter, u8 ch)$/;"	f
-rtw_set_oper_choffset	core/rtw_wlan_util.c	/^inline void rtw_set_oper_choffset(_adapter *adapter, u8 offset)$/;"	f
-rtw_set_p2p_attr_content	core/rtw_ieee80211.c	/^u32 rtw_set_p2p_attr_content(u8 *pbuf, u8 attr_id, u16 attr_len, u8 *pdata_attr)$/;"	f
-rtw_set_pid	os_dep/linux/ioctl_linux.c	/^static int rtw_set_pid(struct net_device *dev,$/;"	f	file:
-rtw_set_ps_mode	core/rtw_pwrctrl.c	/^void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode, const char *msg)$/;"	f
-rtw_set_pwr_state_check_timer	include/rtw_pwrctrl.h	460;"	d
-rtw_set_roam_flags	include/rtw_mlme.h	1132;"	d
-rtw_set_roam_flags	include/rtw_mlme.h	1152;"	d
-rtw_set_rpwm	core/rtw_pwrctrl.c	/^void rtw_set_rpwm(PADAPTER padapter, u8 pslv)$/;"	f
-rtw_set_scan_deny	core/rtw_mlme.c	/^void rtw_set_scan_deny(_adapter *adapter, u32 ms)$/;"	f
-rtw_set_scan_deny	include/rtw_mlme.h	1071;"	d
-rtw_set_scan_deny_timer_hdl	core/rtw_mlme.c	/^void rtw_set_scan_deny_timer_hdl(_adapter *adapter)$/;"	f
-rtw_set_scan_deny_timer_hdl	include/rtw_mlme.h	1070;"	d
-rtw_set_scan_mode	core/rtw_ioctl_set.c	/^int rtw_set_scan_mode(_adapter *adapter, RT_SCAN_TYPE scan_mode)$/;"	f
-rtw_set_signal_stat_timer	include/rtw_recv.h	494;"	d
-rtw_set_supported_rate	core/rtw_ieee80211.c	/^void rtw_set_supported_rate(u8 *SupportedRates, uint mode)$/;"	f
-rtw_set_surprise_removed	include/drv_types.h	/^static inline void rtw_set_surprise_removed(_adapter *padapter)$/;"	f
-rtw_set_to_roam	core/rtw_mlme.c	/^inline void rtw_set_to_roam(_adapter *adapter, u8 to_roam)$/;"	f
-rtw_set_to_roam	include/rtw_mlme.h	1156;"	d
-rtw_set_tx_chksum_offload	os_dep/linux/xmit_linux.c	/^void rtw_set_tx_chksum_offload(_pkt *pkt, struct pkt_attrib *pattrib)$/;"	f
-rtw_set_usb_agg_by_mode	hal/hal_com.c	/^void rtw_set_usb_agg_by_mode(_adapter *padapter, u8 cur_wireless_mode)$/;"	f
-rtw_set_usb_agg_by_mode_customer	hal/hal_com.c	/^void rtw_set_usb_agg_by_mode_customer(_adapter *padapter, u8 cur_wireless_mode, u8 UsbDmaSize, u8 Legacy_UsbDmaSize)$/;"	f
-rtw_set_usb_agg_by_mode_normal	hal/hal_com.c	/^void rtw_set_usb_agg_by_mode_normal(_adapter *padapter, u8 cur_wireless_mode)$/;"	f
-rtw_set_wpa_ie	os_dep/linux/ioctl_linux.c	/^static int rtw_set_wpa_ie(_adapter *padapter, char *pie, unsigned short ielen)$/;"	f	file:
-rtw_set_wps_assoc_resp	os_dep/linux/ioctl_linux.c	/^static int rtw_set_wps_assoc_resp(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_set_wps_beacon	os_dep/linux/ioctl_linux.c	/^static int rtw_set_wps_beacon(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_set_wps_probe_resp	os_dep/linux/ioctl_linux.c	/^static int rtw_set_wps_probe_resp(struct net_device *dev, struct ieee_param *param, int len)$/;"	f	file:
-rtw_setassocsta_cmd	core/rtw_cmd.c	/^u8 rtw_setassocsta_cmd(_adapter  *padapter, u8 *mac_addr)$/;"	f
-rtw_setassocsta_cmdrsp_callback	core/rtw_cmd.c	/^void rtw_setassocsta_cmdrsp_callback(_adapter	*padapter,  struct cmd_obj *pcmd)$/;"	f
-rtw_setbasicrate_cmd	core/rtw_cmd.c	/^u8 rtw_setbasicrate_cmd(_adapter *padapter, u8 *rateset)$/;"	f
-rtw_setbbreg_cmd	core/rtw_cmd.c	/^u8 rtw_setbbreg_cmd(_adapter *padapter, u8 offset, u8 val)$/;"	f
-rtw_setdatarate_cmd	core/rtw_cmd.c	/^u8 rtw_setdatarate_cmd(_adapter *padapter, u8 *rateset)$/;"	f
-rtw_setopmode_cmd	core/rtw_cmd.c	/^u8 rtw_setopmode_cmd(_adapter  *padapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, bool enqueue)$/;"	f
-rtw_setphy_cmd	core/rtw_cmd.c	/^u8 rtw_setphy_cmd(_adapter *padapter, u8 modem, u8 ch)$/;"	f
-rtw_setrfreg_cmd	core/rtw_cmd.c	/^u8 rtw_setrfreg_cmd(_adapter  *padapter, u8 offset, u32 val)$/;"	f
-rtw_setrttbl_cmd	core/rtw_cmd.c	/^u8 rtw_setrttbl_cmd(_adapter  *padapter, struct setratable_parm *prate_table)$/;"	f
-rtw_setstaKey_cmdrsp_callback	core/rtw_cmd.c	/^void rtw_setstaKey_cmdrsp_callback(_adapter	*padapter ,  struct cmd_obj *pcmd)$/;"	f
-rtw_setstakey_cmd	core/rtw_cmd.c	/^u8 rtw_setstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 key_type, bool enqueue)$/;"	f
-rtw_setstandby_cmd	core/rtw_cmd.c	/^u8 rtw_setstandby_cmd(_adapter *padapter, uint action)$/;"	f
-rtw_short_gi	os_dep/linux/os_intfs.c	/^int rtw_short_gi = 0xf;$/;"	v
-rtw_short_retry_lmt	os_dep/linux/os_intfs.c	/^int rtw_short_retry_lmt = 7;$/;"	v
-rtw_signal_process	include/osdep_service_linux.h	404;"	d
-rtw_signal_process	include/osdep_service_linux.h	406;"	d
-rtw_signal_stat_timer_hdl	core/rtw_recv.c	/^void rtw_signal_stat_timer_hdl(RTW_TIMER_HDL_ARGS)$/;"	f
-rtw_sink_rtp_seq_dbg	core/rtw_debug.c	/^void rtw_sink_rtp_seq_dbg(_adapter *adapter, _pkt *pkt)$/;"	f
-rtw_sitesurvey_cmd	core/rtw_cmd.c	/^u8 rtw_sitesurvey_cmd(_adapter  *padapter, NDIS_802_11_SSID *ssid, int ssid_num,$/;"	f
-rtw_skb_alloc	include/osdep_service.h	183;"	d
-rtw_skb_alloc	include/osdep_service.h	256;"	d
-rtw_skb_alloc_f	include/osdep_service.h	185;"	d
-rtw_skb_alloc_f	include/osdep_service.h	258;"	d
-rtw_skb_clone	include/osdep_service.h	188;"	d
-rtw_skb_clone	include/osdep_service.h	261;"	d
-rtw_skb_clone_f	include/osdep_service.h	190;"	d
-rtw_skb_clone_f	include/osdep_service.h	263;"	d
-rtw_skb_copy	include/osdep_service.h	187;"	d
-rtw_skb_copy	include/osdep_service.h	260;"	d
-rtw_skb_copy_f	include/osdep_service.h	189;"	d
-rtw_skb_copy_f	include/osdep_service.h	262;"	d
-rtw_skb_free	include/osdep_service.h	184;"	d
-rtw_skb_free	include/osdep_service.h	257;"	d
-rtw_skb_free_f	include/osdep_service.h	186;"	d
-rtw_skb_free_f	include/osdep_service.h	259;"	d
-rtw_skb_queue_purge	include/osdep_service.h	198;"	d
-rtw_skb_queue_purge	include/osdep_service.h	271;"	d
-rtw_sleep_schedulable	os_dep/osdep_service.c	/^void rtw_sleep_schedulable(int ms)$/;"	f
-rtw_smart_ps	os_dep/linux/os_intfs.c	/^int rtw_smart_ps = 2;$/;"	v
-rtw_sms4_decrypt	core/rtw_wapi_sms4.c	/^u32	rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe)$/;"	f
-rtw_sms4_encrypt	core/rtw_wapi_sms4.c	/^u32	rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe)$/;"	f
-rtw_soft_ap	os_dep/linux/os_intfs.c	/^int rtw_soft_ap = 0;$/;"	v
-rtw_software_decrypt	os_dep/linux/os_intfs.c	/^int rtw_software_decrypt = 0;$/;"	v
-rtw_software_encrypt	os_dep/linux/os_intfs.c	/^int rtw_software_encrypt = 0;$/;"	v
-rtw_special_rf_path	os_dep/linux/os_intfs.c	/^int rtw_special_rf_path = 0; \/* 0: 2T2R ,1: only turn on path A 1T1R *\/$/;"	v
-rtw_sprintf	include/osdep_service.h	689;"	d
-rtw_spt_band_alloc	os_dep/linux/ioctl_cfg80211.c	/^struct ieee80211_supported_band *rtw_spt_band_alloc($/;"	f
-rtw_spt_band_free	os_dep/linux/ioctl_cfg80211.c	/^void rtw_spt_band_free(struct ieee80211_supported_band *spt_band)$/;"	f
-rtw_st_ctl_chk_reg_rule	core/rtw_sta_mgt.c	/^inline bool rtw_st_ctl_chk_reg_rule(struct st_ctl_t *st_ctl, _adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)$/;"	f
-rtw_st_ctl_chk_reg_s_proto	core/rtw_sta_mgt.c	/^inline bool rtw_st_ctl_chk_reg_s_proto(struct st_ctl_t *st_ctl, u8 s_proto)$/;"	f
-rtw_st_ctl_clear_tracker_q	core/rtw_sta_mgt.c	/^inline void rtw_st_ctl_clear_tracker_q(struct st_ctl_t *st_ctl)$/;"	f
-rtw_st_ctl_deinit	core/rtw_sta_mgt.c	/^inline void rtw_st_ctl_deinit(struct st_ctl_t *st_ctl)$/;"	f
-rtw_st_ctl_init	core/rtw_sta_mgt.c	/^inline void rtw_st_ctl_init(struct st_ctl_t *st_ctl)$/;"	f
-rtw_st_ctl_register	core/rtw_sta_mgt.c	/^inline void rtw_st_ctl_register(struct st_ctl_t *st_ctl, u8 st_reg_id, struct st_register *reg)$/;"	f
-rtw_st_ctl_unregister	core/rtw_sta_mgt.c	/^inline void rtw_st_ctl_unregister(struct st_ctl_t *st_ctl, u8 st_reg_id)$/;"	f
-rtw_sta_flush	core/rtw_ap.c	/^int rtw_sta_flush(_adapter *padapter, bool enqueue)$/;"	f
-rtw_sta_info_get_by_idx	os_dep/linux/ioctl_cfg80211.c	/^struct sta_info *rtw_sta_info_get_by_idx(const int idx, struct sta_priv *pstapriv)$/;"	f
-rtw_sta_media_status_rpt	core/rtw_mlme.c	/^void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool connected)$/;"	f
-rtw_sta_media_status_rpt_cmd	core/rtw_mlme.c	/^u8 rtw_sta_media_status_rpt_cmd(_adapter *adapter, struct sta_info *sta, bool connected)$/;"	f
-rtw_sta_media_status_rpt_cmd_hdl	core/rtw_mlme.c	/^inline void rtw_sta_media_status_rpt_cmd_hdl(_adapter *adapter, struct sta_media_status_rpt_cmd_parm *parm)$/;"	f
-rtw_sta_mstatus_disc_rpt	core/rtw_mlme.c	/^void rtw_sta_mstatus_disc_rpt(_adapter *adapter, u8 mac_id)$/;"	f
-rtw_sta_mstatus_report	core/rtw_mlme.c	/^void rtw_sta_mstatus_report(_adapter *adapter)$/;"	f
-rtw_sta_timeout_event_callback	core/rtw_mlme.c	/^void rtw_sta_timeout_event_callback(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_stadel_event_callback	core/rtw_mlme.c	/^void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_stainfo_offset	core/rtw_sta_mgt.c	/^inline int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta)$/;"	f
-rtw_start_auto_ap	core/rtw_mlme_ext.c	/^void rtw_start_auto_ap(_adapter *adapter)$/;"	f
-rtw_start_bss_hdl_after_chbw_decided	core/rtw_ap.c	/^void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter)$/;"	f
-rtw_start_drv_threads	os_dep/linux/os_intfs.c	/^u32 rtw_start_drv_threads(_adapter *padapter)$/;"	f
-rtw_startbss_cmd	core/rtw_cmd.c	/^inline u8 rtw_startbss_cmd(_adapter *adapter, int flags)$/;"	f
-rtw_stassoc_event_callback	core/rtw_mlme.c	/^void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf)$/;"	f
-rtw_stbc_cap	os_dep/linux/os_intfs.c	/^int rtw_stbc_cap = 0x13;$/;"	v
-rtw_stop_cmd_thread	core/rtw_cmd.c	/^void rtw_stop_cmd_thread(_adapter *adapter)$/;"	f
-rtw_stop_drv_threads	os_dep/linux/os_intfs.c	/^void rtw_stop_drv_threads(_adapter *padapter)$/;"	f
-rtw_store_phy_info	hal/hal_com.c	/^void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe)$/;"	f
-rtw_store_to_file	os_dep/osdep_service.c	/^int rtw_store_to_file(const char *path, u8 *buf, u32 sz)$/;"	f
-rtw_support_default_patterns	os_dep/linux/os_intfs.c	/^	bool	rtw_support_default_patterns = _FALSE;$/;"	v
-rtw_support_default_patterns	os_dep/linux/os_intfs.c	/^	bool	rtw_support_default_patterns = _TRUE;$/;"	v
-rtw_survey_cmd_callback	core/rtw_cmd.c	/^void rtw_survey_cmd_callback(_adapter	*padapter ,  struct cmd_obj *pcmd)$/;"	f
-rtw_survey_event_callback	core/rtw_mlme.c	/^void rtw_survey_event_callback(_adapter	*adapter, u8 *pbuf)$/;"	f
-rtw_surveydone_event_callback	core/rtw_mlme.c	/^void rtw_surveydone_event_callback(_adapter	*adapter, u8 *pbuf)$/;"	f
-rtw_suspend_ap_wow	os_dep/linux/os_intfs.c	/^int rtw_suspend_ap_wow(_adapter *padapter)$/;"	f
-rtw_suspend_common	os_dep/linux/os_intfs.c	/^int rtw_suspend_common(_adapter *padapter)$/;"	f
-rtw_suspend_ext_lock	os_dep/osdep_service.c	/^static android_suspend_lock_t rtw_suspend_ext_lock = {$/;"	v	file:
-rtw_suspend_ext_lock	os_dep/osdep_service.c	/^static struct wake_lock rtw_suspend_ext_lock;$/;"	v	typeref:struct:wake_lock	file:
-rtw_suspend_free_assoc_resource	os_dep/linux/os_intfs.c	/^int rtw_suspend_free_assoc_resource(_adapter *padapter)$/;"	f
-rtw_suspend_lock	os_dep/osdep_service.c	/^static android_suspend_lock_t rtw_suspend_lock = {$/;"	v	file:
-rtw_suspend_lock	os_dep/osdep_service.c	/^static struct wake_lock rtw_suspend_lock;$/;"	v	typeref:struct:wake_lock	file:
-rtw_suspend_lock_init	os_dep/osdep_service.c	/^inline void rtw_suspend_lock_init(void)$/;"	f
-rtw_suspend_lock_uninit	os_dep/osdep_service.c	/^inline void rtw_suspend_lock_uninit(void)$/;"	f
-rtw_suspend_normal	os_dep/linux/os_intfs.c	/^int rtw_suspend_normal(_adapter *padapter)$/;"	f
-rtw_suspend_resume_lock	os_dep/osdep_service.c	/^static android_suspend_lock_t rtw_suspend_resume_lock = {$/;"	v	file:
-rtw_suspend_resume_lock	os_dep/osdep_service.c	/^static struct wake_lock rtw_suspend_resume_lock;$/;"	v	typeref:struct:wake_lock	file:
-rtw_suspend_rx_lock	os_dep/osdep_service.c	/^static android_suspend_lock_t rtw_suspend_rx_lock = {$/;"	v	file:
-rtw_suspend_rx_lock	os_dep/osdep_service.c	/^static struct wake_lock rtw_suspend_rx_lock;$/;"	v	typeref:struct:wake_lock	file:
-rtw_suspend_traffic_lock	os_dep/osdep_service.c	/^static android_suspend_lock_t rtw_suspend_traffic_lock = {$/;"	v	file:
-rtw_suspend_traffic_lock	os_dep/osdep_service.c	/^static struct wake_lock rtw_suspend_traffic_lock;$/;"	v	typeref:struct:wake_lock	file:
-rtw_suspend_wow	os_dep/linux/os_intfs.c	/^int rtw_suspend_wow(_adapter *padapter)$/;"	f
-rtw_switch_usb_mode	os_dep/linux/os_intfs.c	/^int rtw_switch_usb_mode = 0;$/;"	v
-rtw_sync_chbw	core/rtw_ieee80211.c	/^void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset$/;"	f
-rtw_systime_to_ms	os_dep/osdep_service.c	/^inline u32 rtw_systime_to_ms(u32 systime)$/;"	f
-rtw_target_tx_pwr_2g_a	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_a[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_A;$/;"	v	file:
-rtw_target_tx_pwr_2g_a_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_a_num = 0;$/;"	v	file:
-rtw_target_tx_pwr_2g_b	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_b[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_B;$/;"	v	file:
-rtw_target_tx_pwr_2g_b_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_b_num = 0;$/;"	v	file:
-rtw_target_tx_pwr_2g_c	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_c[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_C;$/;"	v	file:
-rtw_target_tx_pwr_2g_c_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_c_num = 0;$/;"	v	file:
-rtw_target_tx_pwr_2g_d	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_d[RATE_SECTION_NUM] = CONFIG_RTW_TARGET_TX_PWR_2G_D;$/;"	v	file:
-rtw_target_tx_pwr_2g_d_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_2g_d_num = 0;$/;"	v	file:
-rtw_target_tx_pwr_5g_a	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_a[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_A;$/;"	v	file:
-rtw_target_tx_pwr_5g_a_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_a_num = 0;$/;"	v	file:
-rtw_target_tx_pwr_5g_b	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_b[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_B;$/;"	v	file:
-rtw_target_tx_pwr_5g_b_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_b_num = 0;$/;"	v	file:
-rtw_target_tx_pwr_5g_c	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_c[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_C;$/;"	v	file:
-rtw_target_tx_pwr_5g_c_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_c_num = 0;$/;"	v	file:
-rtw_target_tx_pwr_5g_d	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_d[RATE_SECTION_NUM - 1] = CONFIG_RTW_TARGET_TX_PWR_5G_D;$/;"	v	file:
-rtw_target_tx_pwr_5g_d_num	os_dep/linux/os_intfs.c	/^static int rtw_target_tx_pwr_5g_d_num = 0;$/;"	v	file:
-rtw_tdls	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls(struct net_device *dev,$/;"	f	file:
-rtw_tdls_action_txt	core/rtw_tdls.c	/^const char *rtw_tdls_action_txt(enum TDLS_ACTION_FIELD action)$/;"	f
-rtw_tdls_ch_offset	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_ch_offset(struct net_device *dev,$/;"	f	file:
-rtw_tdls_ch_sw_back_to_base_chnl	core/rtw_tdls.c	/^void rtw_tdls_ch_sw_back_to_base_chnl(_adapter *padapter)$/;"	f
-rtw_tdls_ch_switch	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_ch_switch(struct net_device *dev,$/;"	f	file:
-rtw_tdls_ch_switch_off	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_ch_switch_off(struct net_device *dev,$/;"	f	file:
-rtw_tdls_chsw_oper_done	core/rtw_tdls.c	/^void rtw_tdls_chsw_oper_done(_adapter *padapter)$/;"	f
-rtw_tdls_chsw_oper_init	core/rtw_tdls.c	/^static void rtw_tdls_chsw_oper_init(_adapter *padapter, u32 timeout_ms)$/;"	f	file:
-rtw_tdls_chsw_oper_wait	core/rtw_tdls.c	/^static int rtw_tdls_chsw_oper_wait(_adapter *padapter)$/;"	f	file:
-rtw_tdls_cmd	core/rtw_cmd.c	/^u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option)$/;"	f
-rtw_tdls_dis_result	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_dis_result(struct net_device *dev,$/;"	f	file:
-rtw_tdls_discovery	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_discovery(struct net_device *dev,$/;"	f	file:
-rtw_tdls_do_ch_sw	core/rtw_tdls.c	/^s32 rtw_tdls_do_ch_sw(_adapter *padapter, struct sta_info *ptdls_sta, u8 chnl_type, u8 channel, u8 channel_offset, u16 bwmode, u16 ch_switch_time)$/;"	f
-rtw_tdls_dump_ch	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_dump_ch(struct net_device *dev,$/;"	f	file:
-rtw_tdls_enable	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_enable(struct net_device *dev,$/;"	f	file:
-rtw_tdls_get	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_get(struct net_device *dev,$/;"	f	file:
-rtw_tdls_get_best_ch	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_get_best_ch(struct net_device *dev,$/;"	f	file:
-rtw_tdls_getip	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_getip(struct net_device *dev,$/;"	f	file:
-rtw_tdls_getport	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_getport(struct net_device *dev,$/;"	f	file:
-rtw_tdls_getsta	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_getsta(struct net_device *dev,$/;"	f	file:
-rtw_tdls_is_chsw_allowed	core/rtw_tdls.c	/^u8 rtw_tdls_is_chsw_allowed(_adapter *padapter)$/;"	f
-rtw_tdls_is_driver_setup	core/rtw_tdls.c	/^int rtw_tdls_is_driver_setup(_adapter *padapter)$/;"	f
-rtw_tdls_is_setup_allowed	core/rtw_tdls.c	/^u8 rtw_tdls_is_setup_allowed(_adapter *padapter)$/;"	f
-rtw_tdls_off_ch_num	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_off_ch_num(struct net_device *dev,$/;"	f	file:
-rtw_tdls_process_ht_cap	core/rtw_tdls.c	/^void rtw_tdls_process_ht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)$/;"	f
-rtw_tdls_process_vht_cap	core/rtw_tdls.c	/^void rtw_tdls_process_vht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)$/;"	f
-rtw_tdls_process_wfd_ie	core/rtw_tdls.c	/^void rtw_tdls_process_wfd_ie(struct tdls_info *ptdlsinfo, u8 *ptr, u8 length)$/;"	f
-rtw_tdls_psoff	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_psoff(struct net_device *dev,$/;"	f	file:
-rtw_tdls_pson	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_pson(struct net_device *dev,$/;"	f	file:
-rtw_tdls_set_action	core/rtw_tdls.c	/^u8 *rtw_tdls_set_action(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_tdls_set_aid	core/rtw_tdls.c	/^u8 *rtw_tdls_set_aid(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_bss_coexist	core/rtw_tdls.c	/^u8 *rtw_tdls_set_bss_coexist(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_capability	core/rtw_tdls.c	/^u8 *rtw_tdls_set_capability(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_category	core/rtw_tdls.c	/^u8 *rtw_tdls_set_category(u8 *pframe, struct pkt_attrib *pattrib, u8 category)$/;"	f
-rtw_tdls_set_ch_sw	core/rtw_tdls.c	/^u8 *rtw_tdls_set_ch_sw(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)$/;"	f
-rtw_tdls_set_ch_sw_oper_control	core/rtw_tdls.c	/^void rtw_tdls_set_ch_sw_oper_control(_adapter *padapter, u8 enable)$/;"	f
-rtw_tdls_set_dialog	core/rtw_tdls.c	/^u8 *rtw_tdls_set_dialog(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_tdls_set_ext_cap	core/rtw_tdls.c	/^u8 *rtw_tdls_set_ext_cap(u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_ftie	core/rtw_tdls.c	/^u8 *rtw_tdls_set_ftie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, u8 *ANonce, u8 *SNonce)$/;"	f
-rtw_tdls_set_ht_cap	core/rtw_tdls.c	/^u8 *rtw_tdls_set_ht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_key	core/rtw_tdls.c	/^void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta)$/;"	f
-rtw_tdls_set_linkid	core/rtw_tdls.c	/^u8 *rtw_tdls_set_linkid(u8 *pframe, struct pkt_attrib *pattrib, u8 init)$/;"	f
-rtw_tdls_set_payload_type	core/rtw_tdls.c	/^u8 *rtw_tdls_set_payload_type(u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_qos_cap	core/rtw_tdls.c	/^u8 *rtw_tdls_set_qos_cap(u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_reg_class	core/rtw_tdls.c	/^u8 *rtw_tdls_set_reg_class(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)$/;"	f
-rtw_tdls_set_rsnie	core/rtw_tdls.c	/^u8 *rtw_tdls_set_rsnie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib,  int init, struct sta_info *ptdls_sta)$/;"	f
-rtw_tdls_set_second_channel_offset	core/rtw_tdls.c	/^u8 *rtw_tdls_set_second_channel_offset(u8 *pframe, struct pkt_attrib *pattrib, u8 ch_offset)$/;"	f
-rtw_tdls_set_status_code	core/rtw_tdls.c	/^u8 *rtw_tdls_set_status_code(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_tdls_set_sup_ch	core/rtw_tdls.c	/^u8 *rtw_tdls_set_sup_ch(struct mlme_ext_priv *pmlmeext, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_sup_reg_class	core/rtw_tdls.c	/^u8 *rtw_tdls_set_sup_reg_class(u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_supported_rate	core/rtw_tdls.c	/^u8 *rtw_tdls_set_supported_rate(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_target_ch	core/rtw_tdls.c	/^u8 *rtw_tdls_set_target_ch(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_timeout_interval	core/rtw_tdls.c	/^u8 *rtw_tdls_set_timeout_interval(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, int init, struct sta_info *ptdls_sta)$/;"	f
-rtw_tdls_set_vht_cap	core/rtw_tdls.c	/^u8 *rtw_tdls_set_vht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_set_vht_op_mode_notify	core/rtw_tdls.c	/^u8 *rtw_tdls_set_vht_op_mode_notify(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 bw)$/;"	f
-rtw_tdls_set_vht_operation	core/rtw_tdls.c	/^u8 *rtw_tdls_set_vht_operation(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 channel)$/;"	f
-rtw_tdls_set_wmm_params	core/rtw_tdls.c	/^u8 *rtw_tdls_set_wmm_params(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)$/;"	f
-rtw_tdls_setip	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_setip(struct net_device *dev,$/;"	f	file:
-rtw_tdls_setup	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_setup(struct net_device *dev,$/;"	f	file:
-rtw_tdls_teardown	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_teardown(struct net_device *dev,$/;"	f	file:
-rtw_tdls_weaksec	os_dep/linux/ioctl_linux.c	/^static int rtw_tdls_weaksec(struct net_device *dev,$/;"	f	file:
-rtw_tdls_wfd_enable	core/rtw_p2p.c	/^inline void rtw_tdls_wfd_enable(_adapter *adapter, bool on)$/;"	f
-rtw_test	os_dep/linux/ioctl_linux.c	/^static int rtw_test($/;"	f	file:
-rtw_test_h2c_cmd	core/rtw_cmd.c	/^u8 rtw_test_h2c_cmd(_adapter *adapter, u8 *buf, u8 len)$/;"	f
-rtw_tkip_decrypt	core/rtw_security.c	/^u32 rtw_tkip_decrypt(_adapter *padapter, u8 *precvframe)$/;"	f
-rtw_tkip_encrypt	core/rtw_security.c	/^u32	rtw_tkip_encrypt(_adapter *padapter, u8 *pxmitframe)$/;"	f
-rtw_to_roam	core/rtw_mlme.c	/^inline u8 rtw_to_roam(_adapter *adapter)$/;"	f
-rtw_to_roam	include/rtw_mlme.h	1158;"	d
-rtw_traffic_statistics	include/drv_types.h	/^struct rtw_traffic_statistics {$/;"	s
-rtw_trx_share_mode	os_dep/linux/os_intfs.c	/^int rtw_trx_share_mode = 0;$/;"	v
-rtw_trx_share_mode	os_dep/linux/os_intfs.c	/^int rtw_trx_share_mode = DFT_TRX_SHARE_MODE;$/;"	v
-rtw_tx_bw_mode	os_dep/linux/os_intfs.c	/^uint rtw_tx_bw_mode = 0x21;$/;"	v
-rtw_tx_pwr_by_rate	os_dep/linux/os_intfs.c	/^int rtw_tx_pwr_by_rate = CONFIG_TXPWR_BY_RATE_EN;$/;"	v
-rtw_tx_pwr_lmt_enable	os_dep/linux/os_intfs.c	/^int rtw_tx_pwr_lmt_enable = CONFIG_TXPWR_LIMIT_EN;$/;"	v
-rtw_tx_ring	include/rtw_xmit.h	/^struct rtw_tx_ring {$/;"	s
-rtw_txframes_pending	core/rtw_xmit.c	/^s32 rtw_txframes_pending(_adapter *padapter)$/;"	f
-rtw_txframes_sta_ac_pending	core/rtw_xmit.c	/^s32 rtw_txframes_sta_ac_pending(_adapter *padapter, struct pkt_attrib *pattrib)$/;"	f
-rtw_uapsd_acbe_en	os_dep/linux/os_intfs.c	/^int rtw_uapsd_acbe_en = 0;$/;"	v
-rtw_uapsd_acbk_en	os_dep/linux/os_intfs.c	/^int rtw_uapsd_acbk_en = 0;$/;"	v
-rtw_uapsd_acvi_en	os_dep/linux/os_intfs.c	/^int rtw_uapsd_acvi_en = 0;$/;"	v
-rtw_uapsd_acvo_en	os_dep/linux/os_intfs.c	/^int rtw_uapsd_acvo_en = 0;$/;"	v
-rtw_uapsd_enable	os_dep/linux/os_intfs.c	/^int rtw_uapsd_enable = 0;$/;"	v
-rtw_uapsd_max_sp	os_dep/linux/os_intfs.c	/^int rtw_uapsd_max_sp = NO_LIMIT;$/;"	v
-rtw_udelay_os	include/osdep_service.h	331;"	d
-rtw_udelay_os	os_dep/osdep_service.c	/^void rtw_udelay_os(int us)$/;"	f
-rtw_unlock_suspend	os_dep/osdep_service.c	/^inline void rtw_unlock_suspend(void)$/;"	f
-rtw_unregister_cmd_alive	core/rtw_pwrctrl.c	/^void rtw_unregister_cmd_alive(PADAPTER padapter)$/;"	f
-rtw_unregister_early_suspend	core/rtw_pwrctrl.c	/^void rtw_unregister_early_suspend(struct pwrctrl_priv *pwrpriv)$/;"	f
-rtw_unregister_early_suspend	include/rtw_pwrctrl.h	527;"	d
-rtw_unregister_evt_alive	core/rtw_pwrctrl.c	/^void rtw_unregister_evt_alive(PADAPTER padapter)$/;"	f
-rtw_unregister_rx_alive	core/rtw_pwrctrl.c	/^void rtw_unregister_rx_alive(PADAPTER padapter)$/;"	f
-rtw_unregister_task_alive	core/rtw_pwrctrl.c	/^void rtw_unregister_task_alive(PADAPTER padapter, u32 task)$/;"	f
-rtw_unregister_tx_alive	core/rtw_pwrctrl.c	/^void rtw_unregister_tx_alive(PADAPTER padapter)$/;"	f
-rtw_update_ft_stainfo	core/rtw_mlme.c	/^void rtw_update_ft_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork)$/;"	f
-rtw_update_ht_cap	core/rtw_mlme.c	/^void rtw_update_ht_cap(_adapter *padapter, u8 *pie, uint ie_len, u8 channel)$/;"	f
-rtw_update_protection	core/rtw_xmit.c	/^void rtw_update_protection(_adapter *padapter, u8 *ie, uint ie_len)$/;"	f
-rtw_update_ramask	hal/hal_intf.c	/^void rtw_update_ramask(_adapter *padapter, struct sta_info *psta, u32 mac_id, u8 rssi_level)$/;"	f
-rtw_update_registrypriv_dev_network	core/rtw_mlme.c	/^void rtw_update_registrypriv_dev_network(_adapter *adapter)$/;"	f
-rtw_update_scanned_network	core/rtw_mlme.c	/^void rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)$/;"	f
-rtw_update_tx_rate_bmp	core/rtw_xmit.c	/^void rtw_update_tx_rate_bmp(struct dvobj_priv *dvobj)$/;"	f
-rtw_usb_buffer_alloc	include/osdep_service.h	200;"	d
-rtw_usb_buffer_alloc	include/osdep_service.h	273;"	d
-rtw_usb_buffer_alloc_f	include/osdep_service.h	202;"	d
-rtw_usb_buffer_alloc_f	include/osdep_service.h	275;"	d
-rtw_usb_buffer_free	include/osdep_service.h	201;"	d
-rtw_usb_buffer_free	include/osdep_service.h	274;"	d
-rtw_usb_buffer_free_f	include/osdep_service.h	203;"	d
-rtw_usb_buffer_free_f	include/osdep_service.h	276;"	d
-rtw_usb_bulk_msg	include/usb_ops_linux.h	55;"	d
-rtw_usb_bulk_msg	include/usb_ops_linux.h	61;"	d
-rtw_usb_bulk_size_boundary	include/usb_ops.h	/^static inline u8 rtw_usb_bulk_size_boundary(_adapter *padapter, int buf_len)$/;"	f
-rtw_usb_catc_trigger_cmd	core/rtw_cmd.c	/^void rtw_usb_catc_trigger_cmd(_adapter *padapter, const char *caller)$/;"	f
-rtw_usb_control_msg	include/usb_ops_linux.h	53;"	d
-rtw_usb_control_msg	include/usb_ops_linux.h	58;"	d
-rtw_usb_rxagg_mode	os_dep/linux/os_intfs.c	/^int rtw_usb_rxagg_mode = 2;\/* RX_AGG_DMA=1, RX_AGG_USB=2 *\/$/;"	v
-rtw_use_tkipkey_handler	core/rtw_security.c	/^void rtw_use_tkipkey_handler(RTW_TIMER_HDL_ARGS)$/;"	f
-rtw_usleep_os	os_dep/osdep_service.c	/^void rtw_usleep_os(int us)$/;"	f
-rtw_validate_bssid	core/rtw_ioctl_set.c	/^u8 rtw_validate_bssid(u8 *bssid)$/;"	f
-rtw_validate_ssid	core/rtw_ioctl_set.c	/^u8 rtw_validate_ssid(NDIS_802_11_SSID *ssid)$/;"	f
-rtw_vcs_type	os_dep/linux/os_intfs.c	/^int rtw_vcs_type = RTS_CTS;$/;"	v
-rtw_vendor_cmds	os_dep/linux/rtw_cfgvendor.c	/^static const struct wiphy_vendor_command rtw_vendor_cmds[] = {$/;"	v	typeref:struct:wiphy_vendor_command	file:
-rtw_vendor_events	os_dep/linux/rtw_cfgvendor.c	/^static const struct  nl80211_vendor_cmd_info rtw_vendor_events[] = {$/;"	v	typeref:struct:nl80211_vendor_cmd_info	file:
-rtw_vendor_ie_get	os_dep/linux/ioctl_linux.c	/^int rtw_vendor_ie_get(struct net_device *dev, struct iw_request_info *info, union iwreq_data *wrqu, char *extra)$/;"	f
-rtw_vendor_ie_set	os_dep/linux/ioctl_linux.c	/^int rtw_vendor_ie_set(struct net_device *dev, struct iw_request_info *info, union iwreq_data *wrqu, char *extra)$/;"	f
-rtw_vht_enable	os_dep/linux/os_intfs.c	/^int rtw_vht_enable = 1; \/* 0:disable, 1:enable, 2:force auto enable *\/$/;"	v
-rtw_vht_mcs_to_data_rate	core/rtw_vht.c	/^u16	rtw_vht_mcs_to_data_rate(u8 bw, u8 short_GI, u8 vht_mcs_rate)$/;"	f
-rtw_vht_mcsmap_to_nss	core/rtw_vht.c	/^u8	rtw_vht_mcsmap_to_nss(u8 *pvht_mcs_map)$/;"	f
-rtw_vht_nss_to_mcsmap	core/rtw_vht.c	/^void	rtw_vht_nss_to_mcsmap(u8 nss, u8 *target_mcs_map, u8 *cur_mcs_map)$/;"	f
-rtw_vht_rate_sel	os_dep/linux/os_intfs.c	/^int rtw_vht_rate_sel = 0;$/;"	v
-rtw_vht_rate_to_bitmap	core/rtw_vht.c	/^u64	rtw_vht_rate_to_bitmap(u8 *pVHTRate)$/;"	f
-rtw_vht_use_default_setting	core/rtw_vht.c	/^void	rtw_vht_use_default_setting(_adapter *padapter)$/;"	f
-rtw_virtual_iface_num	os_dep/linux/os_intfs.c	/^		int rtw_virtual_iface_num = 1;$/;"	v
-rtw_virtual_iface_num	os_dep/linux/os_intfs.c	/^		int rtw_virtual_iface_num = CONFIG_IFACE_NUMBER - 1;$/;"	v
-rtw_vmalloc	include/osdep_service.h	162;"	d
-rtw_vmalloc	include/osdep_service.h	169;"	d
-rtw_vmalloc	include/osdep_service.h	235;"	d
-rtw_vmalloc	include/osdep_service.h	242;"	d
-rtw_vmalloc_f	include/osdep_service.h	165;"	d
-rtw_vmalloc_f	include/osdep_service.h	172;"	d
-rtw_vmalloc_f	include/osdep_service.h	238;"	d
-rtw_vmalloc_f	include/osdep_service.h	245;"	d
-rtw_vmfree	include/osdep_service.h	164;"	d
-rtw_vmfree	include/osdep_service.h	171;"	d
-rtw_vmfree	include/osdep_service.h	237;"	d
-rtw_vmfree	include/osdep_service.h	244;"	d
-rtw_vmfree_f	include/osdep_service.h	167;"	d
-rtw_vmfree_f	include/osdep_service.h	174;"	d
-rtw_vmfree_f	include/osdep_service.h	240;"	d
-rtw_vmfree_f	include/osdep_service.h	247;"	d
-rtw_vrtl_carrier_sense	os_dep/linux/os_intfs.c	/^int rtw_vrtl_carrier_sense = AUTO_VCS;$/;"	v
-rtw_wapi_check_for_drop	core/rtw_wapi.c	/^u8 rtw_wapi_check_for_drop($/;"	f
-rtw_wapi_clear_all_cam_entry	core/rtw_wapi.c	/^void rtw_wapi_clear_all_cam_entry(_adapter *padapter)$/;"	f
-rtw_wapi_clear_cam_entry	core/rtw_wapi.c	/^void rtw_wapi_clear_cam_entry(_adapter *padapter, u8 *pMacAddr)$/;"	f
-rtw_wapi_disable_tx	core/rtw_wapi.c	/^void rtw_wapi_disable_tx(_adapter *padapter)$/;"	f
-rtw_wapi_drop_for_key_absent	core/rtw_wapi.c	/^bool rtw_wapi_drop_for_key_absent(_adapter *padapter, u8 *pRA)$/;"	f
-rtw_wapi_free	core/rtw_wapi.c	/^void rtw_wapi_free(_adapter *padapter)$/;"	f
-rtw_wapi_get_iv	core/rtw_wapi.c	/^void rtw_wapi_get_iv(_adapter *padapter, u8 *pRA, u8 *IV)$/;"	f
-rtw_wapi_init	core/rtw_wapi.c	/^void rtw_wapi_init(_adapter *padapter)$/;"	f
-rtw_wapi_is_wai_packet	core/rtw_wapi.c	/^u8 rtw_wapi_is_wai_packet(_adapter *padapter, u8 *pkt_data)$/;"	f
-rtw_wapi_on_assoc_ok	core/rtw_wapi.c	/^void rtw_wapi_on_assoc_ok(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)$/;"	f
-rtw_wapi_return_all_sta_info	core/rtw_wapi.c	/^void rtw_wapi_return_all_sta_info(_adapter *padapter)$/;"	f
-rtw_wapi_return_one_sta_info	core/rtw_wapi.c	/^void rtw_wapi_return_one_sta_info(_adapter *padapter, u8 *MacAddr)$/;"	f
-rtw_wapi_set_key	core/rtw_wapi.c	/^void rtw_wapi_set_key(_adapter *padapter, RT_WAPI_KEY *pWapiKey, RT_WAPI_STA_INFO *pWapiSta, u8 bGroupKey, u8 bUseDefaultKey)$/;"	f
-rtw_wapi_update_info	core/rtw_wapi.c	/^void rtw_wapi_update_info(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-rtw_warn_on	include/osdep_service.h	410;"	d
-rtw_warn_on	include/osdep_service.h	412;"	d
-rtw_warn_on_8821acsr2ant	hal/btc/HalBtc8821aCsr2Ant.c	24;"	d	file:
-rtw_wdev	include/drv_types.h	/^	struct wireless_dev *rtw_wdev;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::wireless_dev
-rtw_wdev	os_dep/linux/ioctl_cfg80211.h	/^	struct wireless_dev *rtw_wdev;$/;"	m	struct:rtw_wdev_priv	typeref:struct:rtw_wdev_priv::wireless_dev
-rtw_wdev_alloc	os_dep/linux/ioctl_cfg80211.c	/^int rtw_wdev_alloc(_adapter *padapter, struct wiphy *wiphy)$/;"	f
-rtw_wdev_free	os_dep/linux/ioctl_cfg80211.c	/^void rtw_wdev_free(struct wireless_dev *wdev)$/;"	f
-rtw_wdev_invit_info	os_dep/linux/ioctl_cfg80211.h	/^struct rtw_wdev_invit_info {$/;"	s
-rtw_wdev_invit_info_init	os_dep/linux/ioctl_cfg80211.h	78;"	d
-rtw_wdev_nego_info	os_dep/linux/ioctl_cfg80211.h	/^struct rtw_wdev_nego_info {$/;"	s
-rtw_wdev_nego_info_init	os_dep/linux/ioctl_cfg80211.h	107;"	d
-rtw_wdev_priv	os_dep/linux/ioctl_cfg80211.h	/^struct rtw_wdev_priv {$/;"	s
-rtw_wdev_unregister	os_dep/linux/ioctl_cfg80211.c	/^void rtw_wdev_unregister(struct wireless_dev *wdev)$/;"	f
-rtw_wep_decrypt	core/rtw_security.c	/^void rtw_wep_decrypt(_adapter  *padapter, u8 *precvframe)$/;"	f
-rtw_wep_encrypt	core/rtw_security.c	/^void rtw_wep_encrypt(_adapter *padapter, u8 *pxmitframe)$/;"	f
-rtw_wext_p2p_enable	os_dep/linux/ioctl_linux.c	/^static int rtw_wext_p2p_enable(struct net_device *dev,$/;"	f	file:
-rtw_wfd_enable	core/rtw_p2p.c	/^inline void rtw_wfd_enable(_adapter *adapter, bool on)$/;"	f
-rtw_wfd_set_ctrl_port	core/rtw_p2p.c	/^inline void rtw_wfd_set_ctrl_port(_adapter *adapter, u16 port)$/;"	f
-rtw_wfd_st_switch	core/rtw_mlme.c	/^inline void rtw_wfd_st_switch(struct sta_info *sta, bool on)$/;"	f
-rtw_wfd_tdls_status	os_dep/linux/ioctl_linux.c	/^static int rtw_wfd_tdls_status(struct net_device *dev,$/;"	f	file:
-rtw_widi_set	os_dep/linux/ioctl_linux.c	/^static int rtw_widi_set(struct net_device *dev,$/;"	f	file:
-rtw_widi_set_probe_request	os_dep/linux/ioctl_linux.c	/^static int rtw_widi_set_probe_request(struct net_device *dev,$/;"	f	file:
-rtw_wifi_gpio_deinit	os_dep/linux/custom_gpio_linux.c	/^int rtw_wifi_gpio_deinit(void)$/;"	f
-rtw_wifi_gpio_init	os_dep/linux/custom_gpio_linux.c	/^int rtw_wifi_gpio_init(void)$/;"	f
-rtw_wifi_gpio_wlan_ctrl	os_dep/linux/custom_gpio_linux.c	/^void rtw_wifi_gpio_wlan_ctrl(int onoff)$/;"	f
-rtw_wifi_spec	os_dep/linux/os_intfs.c	/^	int rtw_wifi_spec = 0;$/;"	v
-rtw_wifi_spec	os_dep/linux/os_intfs.c	/^	int rtw_wifi_spec = 1;\/* for wifi test *\/$/;"	v
-rtw_wiphy_alloc	os_dep/linux/ioctl_cfg80211.c	/^struct wiphy *rtw_wiphy_alloc(_adapter *padapter, struct device *dev)$/;"	f
-rtw_wiphy_data	os_dep/linux/ioctl_cfg80211.h	/^struct rtw_wiphy_data {$/;"	s
-rtw_wiphy_free	os_dep/linux/ioctl_cfg80211.c	/^void rtw_wiphy_free(struct wiphy *wiphy)$/;"	f
-rtw_wiphy_priv	os_dep/linux/ioctl_cfg80211.h	177;"	d
-rtw_wiphy_register	os_dep/linux/ioctl_cfg80211.c	/^int rtw_wiphy_register(struct wiphy *wiphy)$/;"	f
-rtw_wiphy_unregister	os_dep/linux/ioctl_cfg80211.c	/^void rtw_wiphy_unregister(struct wiphy *wiphy)$/;"	f
-rtw_wireless_mode	os_dep/linux/os_intfs.c	/^int rtw_wireless_mode = WIRELESS_11BG;$/;"	v
-rtw_wireless_mode	os_dep/linux/os_intfs.c	/^int rtw_wireless_mode = WIRELESS_11BG_24N;$/;"	v
-rtw_wlan_acl_node	include/sta_info.h	/^struct rtw_wlan_acl_node {$/;"	s
-rtw_wlan_pkt_size	include/rtw_xmit.h	852;"	d
-rtw_wmm_enable	os_dep/linux/os_intfs.c	/^int rtw_wmm_enable = 1;\/* default is set to enable the wmm. *\/$/;"	v
-rtw_wmm_event_callback	core/rtw_mlme.c	/^void rtw_wmm_event_callback(PADAPTER padapter, u8 *pbuf)$/;"	f
-rtw_workqueue	include/rtw_pwrctrl.h	/^	struct workqueue_struct *rtw_workqueue;$/;"	m	struct:pwrctrl_priv	typeref:struct:pwrctrl_priv::workqueue_struct
-rtw_wowlan_ctrl	os_dep/linux/ioctl_linux.c	/^static int rtw_wowlan_ctrl(struct net_device *dev,$/;"	f	file:
-rtw_wowlan_parser_pattern_cmd	core/rtw_wlan_util.c	/^bool rtw_wowlan_parser_pattern_cmd(u8 *input, char *pattern,$/;"	f
-rtw_wowlan_set_pattern	os_dep/linux/ioctl_linux.c	/^static int rtw_wowlan_set_pattern(struct net_device *dev,$/;"	f	file:
-rtw_wps_start	os_dep/linux/ioctl_linux.c	/^static int rtw_wps_start(struct net_device *dev,$/;"	f	file:
-rtw_write16	include/rtw_io.h	437;"	d
-rtw_write16	include/rtw_io.h	475;"	d
-rtw_write16_async	include/rtw_io.h	442;"	d
-rtw_write16_async	include/rtw_io.h	480;"	d
-rtw_write32	include/rtw_io.h	438;"	d
-rtw_write32	include/rtw_io.h	476;"	d
-rtw_write32_async	include/rtw_io.h	443;"	d
-rtw_write32_async	include/rtw_io.h	481;"	d
-rtw_write8	include/rtw_io.h	436;"	d
-rtw_write8	include/rtw_io.h	474;"	d
-rtw_write8_async	include/rtw_io.h	441;"	d
-rtw_write8_async	include/rtw_io.h	479;"	d
-rtw_writeN	include/rtw_io.h	439;"	d
-rtw_writeN	include/rtw_io.h	477;"	d
-rtw_write_mem	include/rtw_io.h	445;"	d
-rtw_write_mem	include/rtw_io.h	483;"	d
-rtw_write_port	include/rtw_io.h	446;"	d
-rtw_write_port	include/rtw_io.h	484;"	d
-rtw_write_port_and_wait	include/rtw_io.h	447;"	d
-rtw_write_port_and_wait	include/rtw_io.h	485;"	d
-rtw_write_port_cancel	include/rtw_io.h	448;"	d
-rtw_write_port_cancel	include/rtw_io.h	486;"	d
-rtw_write_to_frame_mask	core/rtw_wlan_util.c	/^bool rtw_write_to_frame_mask(_adapter *adapter, u8 idx,$/;"	f
-rtw_wx_get_enc	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_enc(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_essid	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_essid(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_frag	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_frag(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_freq	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_freq(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_mode	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_mode(struct net_device *dev, struct iw_request_info *a,$/;"	f	file:
-rtw_wx_get_name	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_name(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_nick	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_nick(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_power	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_power(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_range	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_range(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_rate	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_rate(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_retry	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_retry(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_rts	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_rts(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_scan	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_scan(struct net_device *dev, struct iw_request_info *a,$/;"	f	file:
-rtw_wx_get_sens	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_sens(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_sensitivity	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_sensitivity(struct net_device *dev,$/;"	f	file:
-rtw_wx_get_wap	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_get_wap(struct net_device *dev,$/;"	f	file:
-rtw_wx_priv_null	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_priv_null(struct net_device *dev, struct iw_request_info *a,$/;"	f	file:
-rtw_wx_read32	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_read32(struct net_device *dev,$/;"	f	file:
-rtw_wx_read_rf	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_read_rf(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_auth	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_auth(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_channel_plan	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_channel_plan(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_enc	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_enc(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_enc_ext	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_enc_ext(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_essid	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_essid(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_frag	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_frag(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_freq	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_freq(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_gen_ie	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_gen_ie(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_mlme	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_mlme(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_mode	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_mode(struct net_device *dev, struct iw_request_info *a,$/;"	f	file:
-rtw_wx_set_mtk_wps_ie	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_mtk_wps_ie(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_mtk_wps_probe_ie	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_mtk_wps_probe_ie(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_pmkid	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_pmkid(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_priv	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_priv(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_rate	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_rate(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_rts	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_rts(struct net_device *dev,$/;"	f	file:
-rtw_wx_set_scan	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_scan(struct net_device *dev, struct iw_request_info *a,$/;"	f	file:
-rtw_wx_set_wap	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_set_wap(struct net_device *dev,$/;"	f	file:
-rtw_wx_tdls_wfd_enable	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_tdls_wfd_enable(struct net_device *dev,$/;"	f	file:
-rtw_wx_write32	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_write32(struct net_device *dev,$/;"	f	file:
-rtw_wx_write_rf	os_dep/linux/ioctl_linux.c	/^static int rtw_wx_write_rf(struct net_device *dev,$/;"	f	file:
-rtw_xframe_build_wfd_ie	core/rtw_p2p.c	/^u32 rtw_xframe_build_wfd_ie(struct xmit_frame *xframe)$/;"	f
-rtw_xframe_chk_wfd_ie	core/rtw_p2p.c	/^void rtw_xframe_chk_wfd_ie(struct xmit_frame *xframe)$/;"	f
-rtw_xframe_del_wfd_ie	core/rtw_p2p.c	/^bool rtw_xframe_del_wfd_ie(struct xmit_frame *xframe)$/;"	f
-rtw_xmit	core/rtw_xmit.c	/^s32 rtw_xmit(_adapter *padapter, _pkt **ppkt)$/;"	f
-rtw_xmit_ac_blocked	core/rtw_xmit.c	/^bool rtw_xmit_ac_blocked(_adapter *adapter)$/;"	f
-rtw_xmit_classifier	core/rtw_xmit.c	/^s32 rtw_xmit_classifier(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtw_xmit_entry	os_dep/linux/xmit_linux.c	/^int rtw_xmit_entry(_pkt *pkt, _nic_hdl pnetdev)$/;"	f
-rtw_xmit_tdls_coalesce	core/rtw_xmit.c	/^s32 rtw_xmit_tdls_coalesce(_adapter *padapter, struct xmit_frame *pxmitframe, struct tdls_txmgmt *ptxmgmt)$/;"	f
-rtw_xmit_thread	core/rtw_xmit.c	/^thread_return rtw_xmit_thread(thread_context context)$/;"	f
-rtw_xmitframe_coalesce	core/rtw_xmit.c	/^s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe)$/;"	f
-rtw_xmitframe_enqueue	core/rtw_xmit.c	/^s32 rtw_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-rtw_yield_os	os_dep/osdep_service.c	/^void rtw_yield_os(void)$/;"	f
-rtw_zmalloc	include/osdep_service.h	177;"	d
-rtw_zmalloc	include/osdep_service.h	250;"	d
-rtw_zmalloc_f	include/osdep_service.h	180;"	d
-rtw_zmalloc_f	include/osdep_service.h	253;"	d
-rtw_zvmalloc	include/osdep_service.h	163;"	d
-rtw_zvmalloc	include/osdep_service.h	170;"	d
-rtw_zvmalloc	include/osdep_service.h	236;"	d
-rtw_zvmalloc	include/osdep_service.h	243;"	d
-rtw_zvmalloc_f	include/osdep_service.h	166;"	d
-rtw_zvmalloc_f	include/osdep_service.h	173;"	d
-rtw_zvmalloc_f	include/osdep_service.h	239;"	d
-rtw_zvmalloc_f	include/osdep_service.h	246;"	d
-rty_lmt_en	include/rtl8188e_xmit.h	/^	u32 rty_lmt_en:1;$/;"	m	struct:txdesc_88e
-rty_lmt_en	include/rtl8192e_xmit.h	/^	u32 rty_lmt_en:1;$/;"	m	struct:txdescriptor_8192e
-rty_lmt_en	include/rtl8812a_xmit.h	/^	u32 rty_lmt_en:1;$/;"	m	struct:txdescriptor_8812
-rty_lmt_en	include/rtl8821a_xmit.h	/^	u32 rty_lmt_en:1;$/;"	m	struct:txdescriptor_8821a
-rule	include/sta_info.h	/^	st_match_rule rule;$/;"	m	struct:st_register
-run_in_thread_hdl	core/rtw_mlme_ext.c	/^u8 run_in_thread_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-run_thread	include/hal_intf.h	/^	void	(*run_thread)(_adapter *padapter);$/;"	m	struct:hal_ops
-run_time_state	hal/btc/HalBtc8822b1Ant.h	/^	boolean				run_time_state;$/;"	m	struct:coex_sta_8822b_1ant
-run_time_state	hal/btc/halbtc8723d1ant.h	/^	boolean				run_time_state;$/;"	m	struct:coex_sta_8723d_1ant
-run_time_state	hal/btc/halbtc8723d2ant.h	/^	boolean				run_time_state;$/;"	m	struct:coex_sta_8723d_2ant
-run_time_state	hal/btc/halbtc8821c1ant.h	/^	boolean				run_time_state;$/;"	m	struct:coex_sta_8821c_1ant
-run_time_state	hal/btc/halbtc8821c2ant.h	/^	boolean				run_time_state;$/;"	m	struct:coex_sta_8821c_2ant
-rwreg_param	include/rtw_mp_ioctl.h	/^struct rwreg_param {$/;"	s
-rx	include/drv_types.h	/^	u32 rx;$/;"	m	struct:int_logs
-rx_ampdu_accept	include/rtw_mlme_ext.h	/^	u8 rx_ampdu_accept;$/;"	m	struct:ss_res
-rx_ampdu_apply_sta	core/rtw_mlme_ext.c	/^u8 rx_ampdu_apply_sta(_adapter *adapter, struct sta_info *sta, u8 accept, u8 size)$/;"	f
-rx_ampdu_apply_sta_tid	core/rtw_mlme_ext.c	/^u8 rx_ampdu_apply_sta_tid(_adapter *adapter, struct sta_info *sta, u8 tid, u8 accept, u8 size)$/;"	f
-rx_ampdu_maxlen	include/rtw_ht.h	/^	u32	rx_ampdu_maxlen; \/* for rx reordering ctrl win_sz, updated when join_callback. *\/$/;"	m	struct:ht_priv
-rx_ampdu_min_spacing	include/rtw_ht.h	/^	u8	rx_ampdu_min_spacing;$/;"	m	struct:ht_priv
-rx_ampdu_reason	include/rtw_mlme_ext.h	/^enum rx_ampdu_reason {$/;"	g
-rx_ampdu_size	include/rtw_mlme_ext.h	/^	u8 rx_ampdu_size;$/;"	m	struct:ss_res
-rx_antenna	include/rtw_cmd.h	/^	u8	rx_antenna;$/;"	m	struct:setantenna_parm
-rx_antset	include/rtw_cmd.h	/^	u8	rx_antset;$/;"	m	struct:setantenna_parm
-rx_ass_err	include/ieee80211.h	/^	uint rx_ass_err;$/;"	m	struct:ieee80211_softmac_stats
-rx_ass_ok	include/ieee80211.h	/^	uint rx_ass_ok;$/;"	m	struct:ieee80211_softmac_stats
-rx_ass_rq	include/ieee80211.h	/^	uint rx_ass_rq;$/;"	m	struct:ieee80211_softmac_stats
-rx_auth_rq	include/ieee80211.h	/^	uint rx_auth_rq;$/;"	m	struct:ieee80211_softmac_stats
-rx_auth_rs_err	include/ieee80211.h	/^	uint rx_auth_rs_err;$/;"	m	struct:ieee80211_softmac_stats
-rx_auth_rs_ok	include/ieee80211.h	/^	uint rx_auth_rs_ok;$/;"	m	struct:ieee80211_softmac_stats
-rx_beacon_pkts	include/sta_info.h	/^		u64 rx_beacon_pkts;$/;"	m	struct:stainfo_stats
-rx_bindicatePkt	include/rtw_mp.h	/^	BOOLEAN  rx_bindicatePkt;$/;"	m	struct:mp_priv
-rx_block_mode	include/drv_types_gspi.h	/^	u8  rx_block_mode;$/;"	m	struct:gspi_data
-rx_block_mode	include/drv_types_sdio.h	/^	u8  rx_block_mode;$/;"	m	struct:sdio_data
-rx_bssidpktcount	include/rtw_mp.h	/^	u32 rx_bssidpktcount;$/;"	m	struct:mp_priv
-rx_buf	include/rtw_recv.h	/^	struct sk_buff	*rx_buf[PCI_MAX_RX_COUNT];$/;"	m	struct:rtw_rx_ring	typeref:struct:rtw_rx_ring::sk_buff
-rx_buf_desc	include/rtw_recv.h	/^struct rx_buf_desc {$/;"	s
-rx_bytes	include/drv_types.h	/^	u64	rx_bytes;$/;"	m	struct:rtw_traffic_statistics
-rx_bytes	include/ieee80211.h	/^	u64	rx_bytes;$/;"	m	struct:sta_data
-rx_bytes	include/rtw_recv.h	/^	u64	rx_bytes;$/;"	m	struct:recv_priv
-rx_bytes	include/sta_info.h	/^	u64	rx_bytes;$/;"	m	struct:stainfo_stats
-rx_cck_fa	include/hal_com.h	/^	u32	rx_cck_fa;$/;"	m	struct:dbg_rx_counter
-rx_count	include/rtw_mlme_ext.h	/^	u32				rx_count;$/;"	m	struct:_RT_CHANNEL_INFO
-rx_crcerrpktcount	include/rtw_mp.h	/^	u32 rx_crcerrpktcount;$/;"	m	struct:mp_priv
-rx_ctrl_pkts	include/sta_info.h	/^	u64 rx_ctrl_pkts;$/;"	m	struct:stainfo_stats
-rx_data	include/rtw_recv.h	/^	u8 *rx_data;$/;"	m	struct:recv_frame_hdr
-rx_data_pkts	include/sta_info.h	/^	u64 rx_data_pkts;$/;"	m	struct:stainfo_stats
-rx_data_qos_pkts	include/sta_info.h	/^	u64 rx_data_qos_pkts[TID_NUM];$/;"	m	struct:stainfo_stats
-rx_discards_no_buffer	include/ieee80211.h	/^	uint rx_discards_no_buffer;$/;"	m	struct:ieee80211_stats
-rx_discards_undecryptable	include/ieee80211.h	/^	uint rx_discards_undecryptable;$/;"	m	struct:ieee80211_stats
-rx_drop	include/drv_types.h	/^	u64	rx_drop;$/;"	m	struct:rtw_traffic_statistics
-rx_drop	include/rtw_recv.h	/^	u64	rx_drop;$/;"	m	struct:recv_priv
-rx_drops	include/ieee80211.h	/^	u64	rx_drops;$/;"	m	struct:sta_data
-rx_drops	include/sta_info.h	/^	u64	rx_drops;$/;"	m	struct:stainfo_stats
-rx_end	include/rtw_recv.h	/^	u8 *rx_end;$/;"	m	struct:recv_frame_hdr
-rx_fcs_errors	include/ieee80211.h	/^	uint rx_fcs_errors;$/;"	m	struct:ieee80211_stats
-rx_fovw	include/drv_types.h	/^	u32 rx_fovw;$/;"	m	struct:int_logs
-rx_fragments	include/ieee80211.h	/^	uint rx_fragments;$/;"	m	struct:ieee80211_stats
-rx_gain_range_max	hal/phydm/phydm_dig.h	/^	u1Byte		rx_gain_range_max;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-rx_gain_range_min	hal/phydm/phydm_dig.h	/^	u1Byte		rx_gain_range_min;$/;"	m	struct:_Dynamic_Initial_Gain_Threshold_
-rx_head	include/rtw_recv.h	/^	u8 *rx_head;$/;"	m	struct:recv_frame_hdr
-rx_ht_fa	include/hal_com.h	/^	u32	rx_ht_fa;$/;"	m	struct:dbg_rx_counter
-rx_icv_err	include/rtw_recv.h	/^	uint  rx_icv_err;$/;"	m	struct:recv_priv
-rx_idle_beam	hal/phydm/phydm_antdiv.h	/^	u4Byte	rx_idle_beam[SUPPORT_RF_PATH_NUM];$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-rx_indicate_queue	include/rtw_recv.h	/^	struct ifqueue rx_indicate_queue;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::ifqueue
-rx_indicate_tasklet	include/rtw_recv.h	/^	struct task rx_indicate_tasklet;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::task
-rx_invitereq_info	include/rtw_mlme.h	/^	struct scan_limit_info		rx_invitereq_info;	\/*	Used for get the limit scan channel from the Invitation procedure *\/$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::scan_limit_info
-rx_largepacket_crcerr	include/rtw_recv.h	/^	uint  rx_largepacket_crcerr;$/;"	m	struct:recv_priv
-rx_logs	include/drv_types.h	/^	struct rx_logs rx_logs;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::rx_logs
-rx_logs	include/drv_types.h	/^struct rx_logs {$/;"	s
-rx_message_in_bad_msg_fragments	include/ieee80211.h	/^	uint rx_message_in_bad_msg_fragments;$/;"	m	struct:ieee80211_stats
-rx_message_in_msg_fragments	include/ieee80211.h	/^	uint rx_message_in_msg_fragments;$/;"	m	struct:ieee80211_stats
-rx_mgnt_pkts	include/sta_info.h	/^	u64 rx_mgnt_pkts;$/;"	m	struct:stainfo_stats
-rx_middlepacket_crcerr	include/rtw_recv.h	/^	uint  rx_middlepacket_crcerr;$/;"	m	struct:recv_priv
-rx_multicast_frames	include/ieee80211.h	/^	uint rx_multicast_frames;$/;"	m	struct:ieee80211_stats
-rx_multicast_octets	include/ieee80211.h	/^	uint rx_multicast_octets;$/;"	m	struct:ieee80211_stats
-rx_napi_skb_queue	include/rtw_recv.h	/^	struct sk_buff_head rx_napi_skb_queue;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::sk_buff_head
-rx_ofdm_fa	include/hal_com.h	/^	u32	rx_ofdm_fa;$/;"	m	struct:dbg_rx_counter
-rx_pending_cnt	include/rtw_recv.h	/^	ATOMIC_T	rx_pending_cnt;$/;"	m	struct:recv_priv
-rx_pkt_attrib	include/rtw_recv.h	/^struct rx_pkt_attrib	{$/;"	s
-rx_pkt_crc_error	include/hal_com.h	/^	u32	rx_pkt_crc_error;$/;"	m	struct:dbg_rx_counter
-rx_pkt_drop	include/hal_com.h	/^	u32	rx_pkt_drop;$/;"	m	struct:dbg_rx_counter
-rx_pkt_ok	include/hal_com.h	/^	u32	rx_pkt_ok;$/;"	m	struct:dbg_rx_counter
-rx_pkt_type	hal/phydm/phydm.h	/^	u1Byte			rx_pkt_type;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-rx_pktcount	include/rtw_mp.h	/^	u32 rx_pktcount;$/;"	m	struct:mp_priv
-rx_pktcount_filter_out	include/rtw_mp.h	/^	u32 rx_pktcount_filter_out;$/;"	m	struct:mp_priv
-rx_pktloss	include/rtw_mp.h	/^	u32 rx_pktloss;$/;"	m	struct:mp_priv
-rx_pkts	include/drv_types.h	/^	u64	rx_pkts;$/;"	m	struct:rtw_traffic_statistics
-rx_pkts	include/ieee80211.h	/^	u64	rx_pkts;$/;"	m	struct:sta_data
-rx_pkts	include/rtw_recv.h	/^	u64	rx_pkts;$/;"	m	struct:recv_priv
-rx_probe_rq	include/ieee80211.h	/^	uint rx_probe_rq;$/;"	m	struct:ieee80211_softmac_stats
-rx_probe_rsp	include/rtw_mlme.h	/^	ATOMIC_T	rx_probe_rsp; \/* 1:receive probe respone from RDS source. *\/$/;"	m	struct:mlme_priv
-rx_probereq_pkts	include/sta_info.h	/^		u64 rx_probereq_pkts;$/;"	m	struct:stainfo_stats
-rx_probersp_bm_pkts	include/sta_info.h	/^		u64 rx_probersp_bm_pkts;$/;"	m	struct:stainfo_stats
-rx_probersp_pkts	include/sta_info.h	/^		u64 rx_probersp_pkts;$/;"	m	struct:stainfo_stats
-rx_probersp_uo_pkts	include/sta_info.h	/^		u64 rx_probersp_uo_pkts;$/;"	m	struct:stainfo_stats
-rx_process_link_qual	core/rtw_recv.c	/^static void rx_process_link_qual(_adapter *padapter, union recv_frame *prframe)$/;"	f	file:
-rx_process_phy_info	core/rtw_recv.c	/^void rx_process_phy_info(_adapter *padapter, union recv_frame *rframe)$/;"	f
-rx_process_rssi	core/rtw_recv.c	/^static void rx_process_rssi(_adapter *padapter, union recv_frame *prframe)$/;"	f	file:
-rx_prov_disc_info	include/rtw_mlme.h	/^	struct rx_provdisc_req_info rx_prov_disc_info;$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::rx_provdisc_req_info
-rx_provdisc_req_info	include/rtw_mlme.h	/^struct rx_provdisc_req_info {	\/* When peer device issue prov_disc_req first, we should store the following informations *\/$/;"	s
-rx_query_phy_status	core/rtw_recv.c	/^void rx_query_phy_status($/;"	f
-rx_raw_rssi	include/rtw_recv.h	/^struct rx_raw_rssi {$/;"	s
-rx_rdu	include/drv_types.h	/^	u32 rx_rdu;$/;"	m	struct:int_logs
-rx_retrycnt	include/rtw_cmd.h	/^	unsigned long rx_retrycnt;$/;"	m	struct:getrxretrycnt_rsp
-rx_ring	include/rtw_recv.h	/^	struct rtw_rx_ring	rx_ring[PCI_MAX_RX_QUEUE];$/;"	m	struct:recv_priv	typeref:struct:recv_priv::rtw_rx_ring
-rx_skb_queue	include/rtw_recv.h	/^	struct sk_buff_head rx_skb_queue;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::sk_buff_head
-rx_smallpacket_crcerr	include/rtw_recv.h	/^	uint  rx_smallpacket_crcerr;$/;"	m	struct:recv_priv
-rx_stbc	include/drv_types.h	/^	u8	rx_stbc;$/;"	m	struct:registry_priv
-rx_tail	include/rtw_recv.h	/^	u8 *rx_tail;$/;"	m	struct:recv_frame_hdr
-rx_tdls_disc_rsp_pkts	include/sta_info.h	/^	u64 rx_tdls_disc_rsp_pkts;$/;"	m	struct:stainfo_stats
-rx_testcnt	include/rtw_mp.h	/^	u32 rx_testcnt;$/;"	m	struct:mp_priv
-rx_testcnt1	include/rtw_mp.h	/^	u32 rx_testcnt1;$/;"	m	struct:mp_priv
-rx_testcnt2	include/rtw_mp.h	/^	u32 rx_testcnt2;$/;"	m	struct:mp_priv
-rx_tp	hal/phydm/phydm.h	/^	u4Byte			rx_tp;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-rx_tsf_addr_filter_config	include/hal_data.h	/^	u8				rx_tsf_addr_filter_config; \/* for 8822B\/8821C USE *\/$/;"	m	struct:hal_com_data
-rx_unicast_frames	include/ieee80211.h	/^	uint rx_unicast_frames;$/;"	m	struct:ieee80211_stats
-rx_unicast_octets	include/ieee80211.h	/^	uint rx_unicast_octets;$/;"	m	struct:ieee80211_stats
-rxagg_dma_size	include/hal_data.h	/^	u8 rxagg_dma_size;$/;"	m	struct:hal_com_data
-rxagg_dma_timeout	include/hal_data.h	/^	u8 rxagg_dma_timeout;$/;"	m	struct:hal_com_data
-rxagg_mode	include/hal_data.h	/^	RX_AGG_MODE rxagg_mode;$/;"	m	struct:hal_com_data
-rxagg_usb_size	include/hal_data.h	/^	u8			rxagg_usb_size;$/;"	m	struct:hal_com_data
-rxagg_usb_timeout	include/hal_data.h	/^	u8			rxagg_usb_timeout;$/;"	m	struct:hal_com_data
-rxbuf	include/drv_types.h	/^	u8 rxbuf[0x8000];$/;"	m	struct:loopbackdata
-rxbuffersize	include/rtw_recv.h	/^	u16	rxbuffersize;$/;"	m	struct:recv_priv
-rxcache	include/rtw_recv.h	/^	struct	stainfo_rxcache rxcache;$/;"	m	struct:sta_recv_priv	typeref:struct:sta_recv_priv::stainfo_rxcache
-rxdw	include/rtw_recv.h	/^	unsigned int rxdw[8];$/;"	m	struct:recv_stat
-rxdw0	include/rtw_recv.h	/^	unsigned int rxdw0;$/;"	m	struct:recv_stat
-rxdw1	include/rtw_recv.h	/^	unsigned int rxdw1;$/;"	m	struct:recv_stat
-rxdw2	include/rtw_recv.h	/^	unsigned int rxdw2;$/;"	m	struct:recv_stat
-rxdw3	include/rtw_recv.h	/^	unsigned int rxdw3;$/;"	m	struct:recv_stat
-rxdw4	include/rtw_recv.h	/^	unsigned int rxdw4;$/;"	m	struct:recv_stat
-rxdw5	include/rtw_recv.h	/^	unsigned int rxdw5;$/;"	m	struct:recv_stat
-rxdw6	include/rtw_recv.h	/^	unsigned int rxdw6;$/;"	m	struct:recv_stat
-rxdw7	include/rtw_recv.h	/^	unsigned int rxdw7;$/;"	m	struct:recv_stat
-rxevm	hal/phydm/phydm_hwconfig.h	/^	s1Byte			rxevm[2];	         \/*DW3 byte 1 DW3 byte 2	stream 1 and stream 2 RX EVM*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-rxevm	hal/phydm/phydm_hwconfig.h	/^	s1Byte		rxevm[4];			\/* s(8,1) *\/$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rxevm_cd	hal/phydm/phydm_hwconfig.h	/^	s1Byte			rxevm_cd[2];	   \/*DW 4 byte 3 DW5 byte 0  8812A: 16'b0	8814A: stream 3 and stream 4 RX EVM*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-rxhash	include/osdep_service_bsd.h	/^	u32			rxhash;$/;"	m	struct:sk_buff
-rxht	include/rtl8188e_recv.h	/^	u32 rxht:1;$/;"	m	struct:rxreport_8188e
-rxiqk_step	hal/phydm/phydm_iqk.h	/^	u1Byte		rxiqk_step;$/;"	m	struct:_IQK_INFORMATION
-rxmcs	include/rtl8188e_recv.h	/^	u32 rxmcs:6;$/;"	m	struct:rxreport_8188e
-rxmem_to_recvframe	include/rtw_recv.h	/^__inline static union recv_frame *rxmem_to_recvframe(u8 *rxmem)$/;"	f
-rxreport_8188e	include/rtl8188e_recv.h	/^typedef struct rxreport_8188e {$/;"	s
-rxringcount	include/rtw_recv.h	/^	int rxringcount;	\/* size should be PCI_MAX_RX_QUEUE *\/$/;"	m	struct:recv_priv
-rxsc	hal/phydm/phydm.h	/^	u1Byte		rxsc:4;						\/* sub-channel---*\/$/;"	m	struct:_ODM_Phy_Status_Info_
-rxsc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		rxsc: 4;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-rxsc	hal/phydm/phydm_hwconfig.h	/^	u1Byte	rxsc: 2;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-rxsc	include/rtw_recv.h	/^	u8			rxsc:4;$/;"	m	struct:phy_info
-rxsize	include/drv_types.h	/^	u16 rxsize;$/;"	m	struct:loopbackdata
-rxsnr	hal/phydm/phydm_hwconfig.h	/^	s1Byte			rxsnr[2];	         \/*DW3 byte 3 DW4 byte 0	path-A and path-B RX SNR*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-rxsnr	hal/phydm/phydm_hwconfig.h	/^	s1Byte		rxsnr[4];			\/* s(8,1) *\/$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-rxstat	include/rtw_mp.h	/^	struct recv_stat rxstat;$/;"	m	struct:mp_priv	typeref:struct:mp_priv::recv_stat
-s0	include/rtw_cmd.h	/^	u16	s0;$/;"	m	struct:geth2clbk_rsp
-s0	include/rtw_cmd.h	/^	u16	s0;$/;"	m	struct:seth2clbk_parm
-s0	include/rtw_event.h	/^	unsigned short	s0;$/;"	m	struct:c2hlbk_event
-s1	include/rtw_cmd.h	/^	u16	s1;$/;"	m	struct:geth2clbk_rsp
-s1	include/rtw_cmd.h	/^	u16	s1;$/;"	m	struct:seth2clbk_parm
-s1	include/rtw_event.h	/^	unsigned short	s1;$/;"	m	struct:c2hlbk_event
-s16	include/basic_types.h	/^	typedef signed short s16;$/;"	t
-s1Byte	hal/phydm/phydm_types.h	/^	typedef char					s1Byte,*ps1Byte;$/;"	t
-s1Byte	hal/phydm/phydm_types.h	/^    typedef signed char				s1Byte,*ps1Byte;$/;"	t
-s1Byte	hal/phydm/phydm_types.h	196;"	d
-s1Byte	include/rtw_mp.h	106;"	d
-s1Byte	include/rtw_mp.h	121;"	d
-s2	include/rtw_cmd.h	/^	u16	s2;$/;"	m	struct:geth2clbk_rsp
-s2	include/rtw_cmd.h	/^	u16  s2;$/;"	m	struct:seth2clbk_parm
-s2	include/rtw_event.h	/^	unsigned short  s2;$/;"	m	struct:c2hlbk_event
-s2Byte	hal/phydm/phydm_types.h	/^	typedef short					s2Byte,*ps2Byte;$/;"	t
-s2Byte	hal/phydm/phydm_types.h	199;"	d
-s2Byte	include/rtw_mp.h	124;"	d
-s32	include/basic_types.h	/^	typedef signed int s32;$/;"	t
-s32	include/basic_types.h	/^	typedef signed long s32;$/;"	t
-s4Byte	hal/phydm/phydm_types.h	/^	typedef long					s4Byte,*ps4Byte;$/;"	t
-s4Byte	hal/phydm/phydm_types.h	202;"	d
-s4Byte	include/rtw_mp.h	108;"	d
-s4Byte	include/rtw_mp.h	127;"	d
-s64	include/basic_types.h	/^	typedef signed long long s64;$/;"	t
-s8	include/basic_types.h	/^	typedef signed char s8;$/;"	t
-s8Byte	hal/phydm/phydm_types.h	/^	typedef long long				s8Byte,*ps8Byte;$/;"	t
-s8Byte	hal/phydm/phydm_types.h	205;"	d
-s8Byte	include/rtw_mp.h	130;"	d
-sMacHdrLng	core/rtw_beamforming.c	1773;"	d	file:
-sMacHdrLng	include/rtw_wapi.h	11;"	d
-s_proto	include/sta_info.h	/^	u8 s_proto;$/;"	m	struct:st_register
-sa	include/ieee80211_ext.h	/^	u8 sa[6];$/;"	m	struct:ieee80211_mgmt
-sa	include/osdep_service.h	/^	u16 sa;$/;"	m	struct:map_seg_t
-sa_ext	include/rtw_mlme.h	/^	u8	sa_ext[L2SDTA_SERVICE_VE_LEN];$/;"	m	struct:mlme_priv
-sa_query_seq	include/rtw_mlme_ext.h	/^	u16	sa_query_seq;$/;"	m	struct:mlme_ext_priv
-sa_query_timer_hdl	core/rtw_mlme_ext.c	/^void sa_query_timer_hdl(struct sta_info *psta)$/;"	f
-saddr	include/ip.h	/^	__u32	saddr;$/;"	m	struct:iphdr
-sbdcnt_timer	hal/phydm/phydm.h	/^	RT_TIMER		sbdcnt_timer;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-sbdcnt_workitem	hal/phydm/phydm.h	/^	RT_WORK_ITEM			sbdcnt_workitem;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-sbox	core/rtw_security.c	/^static u8 sbox(u8 a)$/;"	f	file:
-sbox_table	core/rtw_security.c	/^static  u8 sbox_table[256] = {$/;"	v	file:
-scan_abort	include/rtw_mlme_ext.h	/^	u8	scan_abort;$/;"	m	struct:mlme_ext_priv
-scan_abort_hdl	core/rtw_mlme_ext.c	/^static bool scan_abort_hdl(_adapter *adapter)$/;"	f	file:
-scan_ap_num	hal/btc/HalBtc8192e1Ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8192e_1ant
-scan_ap_num	hal/btc/HalBtc8192e2Ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8192e_2ant
-scan_ap_num	hal/btc/HalBtc8703b1Ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8703b_1ant
-scan_ap_num	hal/btc/HalBtc8723b1Ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8723b_1ant
-scan_ap_num	hal/btc/HalBtc8723b2Ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8723b_2ant
-scan_ap_num	hal/btc/HalBtc8812a1Ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8812a_1ant
-scan_ap_num	hal/btc/HalBtc8822b1Ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8822b_1ant
-scan_ap_num	hal/btc/halbtc8723d1ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8723d_1ant
-scan_ap_num	hal/btc/halbtc8723d2ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8723d_2ant
-scan_ap_num	hal/btc/halbtc8821c1ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8821c_1ant
-scan_ap_num	hal/btc/halbtc8821c2ant.h	/^	u8					scan_ap_num;$/;"	m	struct:coex_sta_8821c_2ant
-scan_ch_ms	include/rtw_mlme_ext.h	/^	u16 scan_ch_ms;$/;"	m	struct:ss_res
-scan_cnt	include/rtw_mlme_ext.h	/^	u8 scan_cnt;$/;"	m	struct:ss_res
-scan_cnt_max	include/rtw_mlme_ext.h	/^	u8 scan_cnt_max;$/;"	m	struct:ss_res
-scan_limit_info	include/rtw_mlme.h	/^struct scan_limit_info {$/;"	s
-scan_mode	include/drv_types.h	/^	u8	scan_mode;\/* active, passive *\/$/;"	m	struct:registry_priv
-scan_mode	include/rtw_cmd.h	/^	sint scan_mode;	\/* active: 1, passive: 0 *\/$/;"	m	struct:sitesurvey_parm
-scan_mode	include/rtw_mlme.h	/^	RT_SCAN_TYPE	scan_mode; \/* active: 1, passive: 0 *\/$/;"	m	struct:mlme_priv
-scan_mode	include/rtw_mlme_ext.h	/^	int	scan_mode;$/;"	m	struct:ss_res
-scan_op_ch_only	include/rtw_mlme.h	/^	u8					scan_op_ch_only;			\/*	When this flag is set, the driver should just scan the operation channel *\/$/;"	m	struct:scan_limit_info
-scan_req_lock	os_dep/linux/ioctl_cfg80211.h	/^	_lock scan_req_lock;$/;"	m	struct:rtw_wdev_priv
-scan_request	os_dep/linux/ioctl_cfg80211.h	/^	struct cfg80211_scan_request *scan_request;$/;"	m	struct:rtw_wdev_priv	typeref:struct:rtw_wdev_priv::cfg80211_scan_request
-scan_result_type	include/rtw_mlme.h	/^	enum	SCAN_RESULT_TYPE	scan_result_type;	\/*	Used when P2P is enable. This parameter will impact the scan result. *\/$/;"	m	struct:wifi_display_info	typeref:enum:wifi_display_info::SCAN_RESULT_TYPE
-scan_start_time	include/rtw_mlme.h	/^	u32 scan_start_time; \/* used to evaluate the time spent in scanning *\/$/;"	m	struct:mlme_priv
-scan_state_str	core/rtw_mlme_ext.c	/^const char *scan_state_str(u8 state)$/;"	f
-scan_tlv	core/rtw_br_ext.c	/^static unsigned char *scan_tlv(unsigned char *data, int len, unsigned char tag, unsigned char len8b)$/;"	f	file:
-scan_to_timer	include/rtw_mlme.h	/^	_timer scan_to_timer; \/* driver itself handles scan_timeout status. *\/$/;"	m	struct:mlme_priv
-scanned_queue	include/rtw_mlme.h	/^	_queue	scanned_queue;$/;"	m	struct:mlme_priv
-scanning_via_buddy_intf	include/rtw_mlme.h	/^	u8	scanning_via_buddy_intf;$/;"	m	struct:mlme_priv
-scdb_entry	include/drv_types.h	/^	struct nat25_network_db_entry	*scdb_entry;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::nat25_network_db_entry
-scdb_findEntry	core/rtw_br_ext.c	/^void *scdb_findEntry(_adapter *priv, unsigned char *macAddr,$/;"	f
-scdb_ip	include/drv_types.h	/^	unsigned char			scdb_ip[4];$/;"	m	struct:_ADAPTER
-scdb_mac	include/drv_types.h	/^	unsigned char			scdb_mac[MACADDRLEN];$/;"	m	struct:_ADAPTER
-sco_exist	hal/btc/HalBtc8192e1Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8192e_1ant
-sco_exist	hal/btc/HalBtc8192e2Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8192e_2ant
-sco_exist	hal/btc/HalBtc8703b1Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8703b_1ant
-sco_exist	hal/btc/HalBtc8723b1Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8723b_1ant
-sco_exist	hal/btc/HalBtc8723b2Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8723b_2ant
-sco_exist	hal/btc/HalBtc8812a1Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8812a_1ant
-sco_exist	hal/btc/HalBtc8812a2Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8812a_2ant
-sco_exist	hal/btc/HalBtc8821a1Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8821a_1ant
-sco_exist	hal/btc/HalBtc8821a2Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8821a_2ant
-sco_exist	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8821a_csr_2ant
-sco_exist	hal/btc/HalBtc8822b1Ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8822b_1ant
-sco_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					sco_exist;$/;"	m	struct:btc_bt_link_info
-sco_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					sco_exist;$/;"	m	struct:btc_stack_info
-sco_exist	hal/btc/halbtc8723d1ant.h	/^	boolean				sco_exist;$/;"	m	struct:coex_sta_8723d_1ant
-sco_exist	hal/btc/halbtc8723d2ant.h	/^	boolean				sco_exist;$/;"	m	struct:coex_sta_8723d_2ant
-sco_exist	hal/btc/halbtc8821c1ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8821c_1ant
-sco_exist	hal/btc/halbtc8821c2ant.h	/^	boolean					sco_exist;$/;"	m	struct:coex_sta_8821c_2ant
-sco_only	hal/btc/HalBtcOutSrc.h	/^	boolean					sco_only;$/;"	m	struct:btc_bt_link_info
-score_board	hal/btc/HalBtc8703b1Ant.h	/^	u16					score_board;$/;"	m	struct:coex_sta_8703b_1ant
-score_board	hal/btc/HalBtc8822b1Ant.h	/^	u16					score_board;$/;"	m	struct:coex_sta_8822b_1ant
-score_board	hal/btc/halbtc8723d1ant.h	/^	u16					score_board;$/;"	m	struct:coex_sta_8723d_1ant
-score_board	hal/btc/halbtc8723d2ant.h	/^	u16					score_board;$/;"	m	struct:coex_sta_8723d_2ant
-score_board	hal/btc/halbtc8821c1ant.h	/^	u16					score_board;$/;"	m	struct:coex_sta_8821c_1ant
-score_board	hal/btc/halbtc8821c2ant.h	/^	u16					score_board;$/;"	m	struct:coex_sta_8821c_2ant
-scsir_full_evt	include/rtw_mp.h	/^	NDIS_EVENT scsir_full_evt;$/;"	m	struct:mp_priv
-scsiw_empty_evt	include/rtw_mp.h	/^	NDIS_EVENT scsiw_empty_evt;$/;"	m	struct:mp_priv
-sctx	include/drv_types.h	/^	struct submit_ctx *sctx;$/;"	m	struct:halmac_indicator	typeref:struct:halmac_indicator::submit_ctx
-sctx	include/rtw_cmd.h	/^	struct submit_ctx *sctx;$/;"	m	struct:cmd_obj	typeref:struct:cmd_obj::submit_ctx
-sctx	include/rtw_xmit.h	/^	struct submit_ctx *sctx;$/;"	m	struct:xmit_buf	typeref:struct:xmit_buf::submit_ctx
-sctx_mutex	include/rtw_cmd.h	/^	_mutex sctx_mutex;$/;"	m	struct:cmd_priv
-scurity_type	include/rtw_pwrctrl.h	/^	u8 scurity_type;$/;"	m	struct:aoac_report
-sd_c2h_hisr_hdl	hal/hal_hci/hal_sdio.c	/^void sd_c2h_hisr_hdl(_adapter *adapter)$/;"	f
-sd_cmd52_read	os_dep/linux/sdio_ops_linux.c	/^s32 sd_cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)$/;"	f
-sd_cmd52_write	os_dep/linux/sdio_ops_linux.c	/^s32 sd_cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pdata)$/;"	f
-sd_f0_read8	os_dep/linux/sdio_ops_linux.c	/^u8 sd_f0_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err)$/;"	f
-sd_f0_reg_dump	core/rtw_debug.c	/^void sd_f0_reg_dump(void *sel, _adapter *adapter)$/;"	f
-sd_f0_write8	os_dep/linux/sdio_ops_linux.c	/^void sd_f0_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err)$/;"	f
-sd_host_blk_cap	include/drv_types_sdio.h	/^	SD_HOST_BLOCK_CAPABILITY	sd_host_blk_cap;$/;"	m	struct:sdio_data
-sd_indirect_access_mutex	include/drv_types.h	/^	_mutex sd_indirect_access_mutex;$/;"	m	struct:dvobj_priv
-sd_int_dpc	hal/rtl8723d/sdio/sdio_ops.c	/^void sd_int_dpc(PADAPTER padapter)$/;"	f
-sd_int_hdl	hal/rtl8723d/sdio/sdio_ops.c	/^void sd_int_hdl(PADAPTER padapter)$/;"	f
-sd_intf_start	os_dep/linux/sdio_intf.c	/^static void sd_intf_start(PADAPTER padapter)$/;"	f	file:
-sd_intf_stop	os_dep/linux/sdio_intf.c	/^static void sd_intf_stop(PADAPTER padapter)$/;"	f	file:
-sd_rca	include/drv_types_sdio.h	/^	SD_CARD_RCA					sd_rca;$/;"	m	struct:sdio_data
-sd_read	os_dep/linux/sdio_ops_linux.c	/^s32 sd_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)$/;"	f
-sd_read16	os_dep/linux/sdio_ops_linux.c	/^u16 sd_read16(struct intf_hdl *pintfhdl, u32 addr, s32 *err)$/;"	f
-sd_read32	os_dep/linux/sdio_ops_linux.c	/^u32 sd_read32(struct intf_hdl *pintfhdl, u32 addr, s32 *err)$/;"	f
-sd_read8	os_dep/linux/sdio_ops_linux.c	/^u8 sd_read8(struct intf_hdl *pintfhdl, u32 addr, s32 *err)$/;"	f
-sd_recv_loopback	hal/rtl8723d/sdio/sdio_ops.c	/^static void sd_recv_loopback(PADAPTER padapter, u32 size)$/;"	f	file:
-sd_recv_rxfifo	hal/rtl8723d/sdio/sdio_ops.c	/^static struct recv_buf *sd_recv_rxfifo(PADAPTER padapter, u32 size)$/;"	f	file:
-sd_rxhandler	hal/rtl8723d/sdio/sdio_ops.c	/^static void sd_rxhandler(PADAPTER padapter, struct recv_buf *precvbuf)$/;"	f	file:
-sd_sync_int_hdl	os_dep/linux/sdio_intf.c	/^static void sd_sync_int_hdl(struct sdio_func *func)$/;"	f	file:
-sd_write	os_dep/linux/sdio_ops_linux.c	/^s32 sd_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, void *pdata)$/;"	f
-sd_write16	os_dep/linux/sdio_ops_linux.c	/^void sd_write16(struct intf_hdl *pintfhdl, u32 addr, u16 v, s32 *err)$/;"	f
-sd_write32	os_dep/linux/sdio_ops_linux.c	/^void sd_write32(struct intf_hdl *pintfhdl, u32 addr, u32 v, s32 *err)$/;"	f
-sd_write8	os_dep/linux/sdio_ops_linux.c	/^void sd_write8(struct intf_hdl *pintfhdl, u32 addr, u8 v, s32 *err)$/;"	f
-sdbusinft	include/drv_types_sdio.h	/^	SDBUS_INTERFACE_STANDARD	sdbusinft;$/;"	m	struct:sdio_data
-sdc_id	platform/platform_ARM_SUNnI_sdio.c	/^static int sdc_id = -1;$/;"	v	file:
-sdio_AggSettingRxUpdate	hal/rtl8723d/sdio/sdio_halinit.c	/^void sdio_AggSettingRxUpdate(PADAPTER padapter)$/;"	f
-sdio_alloc_irq	os_dep/linux/sdio_intf.c	/^int sdio_alloc_irq(struct dvobj_priv *dvobj)$/;"	f
-sdio_data	include/drv_types_sdio.h	/^typedef struct sdio_data {$/;"	s
-sdio_deinit	os_dep/linux/sdio_intf.c	/^static void sdio_deinit(struct dvobj_priv *dvobj)$/;"	f	file:
-sdio_drv_priv	os_dep/linux/sdio_intf.c	/^struct sdio_drv_priv {$/;"	s	file:
-sdio_drvpriv	os_dep/linux/sdio_intf.c	/^static struct sdio_drv_priv sdio_drvpriv = {$/;"	v	typeref:struct:sdio_drv_priv	file:
-sdio_dvobj_deinit	os_dep/linux/sdio_intf.c	/^static void sdio_dvobj_deinit(struct sdio_func *func)$/;"	f	file:
-sdio_dvobj_init	os_dep/linux/sdio_intf.c	/^static struct dvobj_priv *sdio_dvobj_init(struct sdio_func *func, const struct sdio_device_id  *pdid)$/;"	f	file:
-sdio_f0_read8	hal/rtl8723d/sdio/sdio_ops.c	/^u8 sdio_f0_read8(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-sdio_free_irq	os_dep/linux/sdio_intf.c	/^void sdio_free_irq(struct dvobj_priv *dvobj)$/;"	f
-sdio_himr	include/hal_data.h	/^	u32			sdio_himr;$/;"	m	struct:hal_com_data
-sdio_hisr	include/hal_data.h	/^	u32			sdio_hisr;$/;"	m	struct:hal_com_data
-sdio_ids	os_dep/linux/sdio_intf.c	/^static const struct sdio_device_id sdio_ids[] = {$/;"	v	typeref:struct:sdio_device_id	file:
-sdio_init	os_dep/linux/sdio_intf.c	/^static u32 sdio_init(struct dvobj_priv *dvobj)$/;"	f	file:
-sdio_io	core/rtw_sdio.c	/^static u8 sdio_io(struct dvobj_priv *d, u32 addr, void *buf, size_t len, u8 write, u8 cmd52)$/;"	f	file:
-sdio_local_read	hal/rtl8723d/sdio/sdio_ops.c	/^s32 sdio_local_read($/;"	f
-sdio_local_reg_dump	core/rtw_debug.c	/^void sdio_local_reg_dump(void *sel, _adapter *adapter)$/;"	f
-sdio_local_write	hal/rtl8723d/sdio/sdio_ops.c	/^s32 sdio_local_write($/;"	f
-sdio_ops	os_dep/linux/sdio_intf.c	/^static struct rtw_if_operations sdio_ops = {$/;"	v	typeref:struct:rtw_if_operations	file:
-sdio_power_on_check	hal/hal_hci/hal_sdio.c	/^bool sdio_power_on_check(PADAPTER padapter) {$/;"	f
-sdio_read16	hal/rtl8723d/sdio/sdio_ops.c	/^u16 sdio_read16(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-sdio_read32	hal/rtl8723d/sdio/sdio_ops.c	/^u32 sdio_read32(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-sdio_read8	hal/rtl8723d/sdio/sdio_ops.c	/^u8 sdio_read8(struct intf_hdl *pintfhdl, u32 addr)$/;"	f
-sdio_readN	hal/rtl8723d/sdio/sdio_ops.c	/^s32 sdio_readN(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pbuf)$/;"	f
-sdio_read_mem	hal/rtl8723d/sdio/sdio_ops.c	/^void sdio_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem)$/;"	f
-sdio_read_port	hal/rtl8723d/sdio/sdio_ops.c	/^static u32 sdio_read_port($/;"	f	file:
-sdio_set_intf_ops	hal/rtl8723d/sdio/sdio_ops.c	/^void sdio_set_intf_ops(_adapter *padapter, struct _io_ops *pops)$/;"	f
-sdio_tx_max_len	include/hal_data.h	/^	u32			sdio_tx_max_len[SDIO_MAX_TX_QUEUE];\/* H, N, L, used for sdio tx aggregation max length per queue *\/$/;"	m	struct:hal_com_data
-sdio_write16	hal/rtl8723d/sdio/sdio_ops.c	/^s32 sdio_write16(struct intf_hdl *pintfhdl, u32 addr, u16 val)$/;"	f
-sdio_write32	hal/rtl8723d/sdio/sdio_ops.c	/^s32 sdio_write32(struct intf_hdl *pintfhdl, u32 addr, u32 val)$/;"	f
-sdio_write8	hal/rtl8723d/sdio/sdio_ops.c	/^s32 sdio_write8(struct intf_hdl *pintfhdl, u32 addr, u8 val)$/;"	f
-sdio_writeN	hal/rtl8723d/sdio/sdio_ops.c	/^s32 sdio_writeN(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pbuf)$/;"	f
-sdio_write_mem	hal/rtl8723d/sdio/sdio_ops.c	/^void sdio_write_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem)$/;"	f
-sdio_write_port	hal/rtl8723d/sdio/sdio_ops.c	/^static u32 sdio_write_port($/;"	f	file:
-sdrp	include/osdep_intf.h	/^	PSDBUS_REQUEST_PACKET  sdrp;$/;"	m	struct:intf_priv
-sdrp	include/rtw_io.h	/^	PSDBUS_REQUEST_PACKET sdrp;$/;"	m	struct:io_req
-sdrp	include/sdio_ops.h	/^	PSDBUS_REQUEST_PACKET sdrp;$/;"	m	struct:async_context
-search_p2p_wfd_ie	os_dep/linux/ioctl_linux.c	/^static int search_p2p_wfd_ie(_adapter *padapter,$/;"	f	file:
-search_space_2	hal/phydm/phydm_pathdiv.h	/^	u1Byte	search_space_2[NUM_CHOOSE2_FROM4];$/;"	m	struct:_ODM_PATH_DIVERSITY_
-search_space_3	hal/phydm/phydm_pathdiv.h	/^	u1Byte	search_space_3[NUM_CHOOSE3_FROM4];$/;"	m	struct:_ODM_PATH_DIVERSITY_
-sec	include/osdep_service_bsd.h	/^	s32	sec, nsec;$/;"	m	struct:ktime::__anon46
-sec_cam_access_mutex	include/drv_types.h	/^	_mutex sec_cam_access_mutex;$/;"	m	struct:cam_ctl_t
-sec_cam_bmp	include/drv_types.h	/^struct sec_cam_bmp {$/;"	s
-sec_cam_ent	include/drv_types.h	/^struct sec_cam_ent {$/;"	s
-sec_cam_ent_num	include/hal_data.h	/^	u8 sec_cam_ent_num;$/;"	m	struct:hal_spec_t
-sec_cap	include/drv_types.h	/^	u8 sec_cap;$/;"	m	struct:cam_ctl_t
-sec_cap	include/hal_data.h	/^	u8 sec_cap;$/;"	m	struct:hal_spec_t
-secdev_types_list	include/sta_info.h	/^	u8 secdev_types_list[32];\/* 32\/8 == 4; *\/$/;"	m	struct:sta_info
-secmark	include/osdep_service_bsd.h	/^	u32			secmark;$/;"	m	struct:sk_buff
-secmicclear	core/rtw_security.c	/^static void secmicclear(struct mic_data *pmicdata)$/;"	f	file:
-secmicgetuint32	core/rtw_security.c	/^static u32 secmicgetuint32(u8 *p)$/;"	f	file:
-secmicputuint32	core/rtw_security.c	/^static void secmicputuint32(u8 *p, u32 val)$/;"	f	file:
-secondary_ch_offset	include/ieee80211.h	/^enum secondary_ch_offset {$/;"	g
-secondary_ch_offset_to_hal_ch_offset	core/rtw_ieee80211.c	/^inline u8 secondary_ch_offset_to_hal_ch_offset(u8 ch_offset)$/;"	f
-secs	core/rtw_br_ext.c	/^	u_int16_t secs;$/;"	m	struct:dhcpMessage	file:
-sectype	include/rtl8188e_xmit.h	/^	u32 sectype:2;$/;"	m	struct:txdesc_88e
-sectype	include/rtl8192e_xmit.h	/^	u32 sectype:2;$/;"	m	struct:txdescriptor_8192e
-sectype	include/rtl8812a_xmit.h	/^	u32 sectype:2;$/;"	m	struct:txdescriptor_8812
-sectype	include/rtl8821a_xmit.h	/^	u32 sectype:2;$/;"	m	struct:txdescriptor_8821a
-security	include/rtl8188e_recv.h	/^	u32 security:3;$/;"	m	struct:rxreport_8188e
-security_key_mutex	include/drv_types.h	/^	_lock   security_key_mutex; \/* add for CONFIG_IEEE80211W, none 11w also can use *\/$/;"	m	struct:_ADAPTER
-security_priv	include/rtw_security.h	/^struct security_priv {$/;"	s
-security_type_str	core/rtw_security.c	/^const char *security_type_str(u8 value)$/;"	f
-securitypriv	include/drv_types.h	/^	struct	security_priv	securitypriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::security_priv
-seg_num	include/osdep_service.h	/^	u16 seg_num;$/;"	m	struct:map_t
-segs	include/osdep_service.h	/^	struct map_seg_t *segs;$/;"	m	struct:map_t	typeref:struct:map_t::map_seg_t
-select_and_dequeue_pending_xmitbuf	core/rtw_xmit.c	/^struct xmit_buf *select_and_dequeue_pending_xmitbuf(_adapter *padapter)$/;"	f
-sema	include/drv_types.h	/^	_sema	sema;$/;"	m	struct:loopbackdata
-sema	include/rtw_io.h	/^	_sema	sema;$/;"	m	struct:io_req
-send_beacon	core/rtw_mlme_ext.c	/^unsigned int send_beacon(_adapter *padapter)$/;"	f
-send_delba	core/rtw_mlme_ext.c	/^unsigned int send_delba(_adapter *padapter, u8 initiator, u8 *addr)$/;"	f
-send_delba_sta_tid	core/rtw_mlme_ext.c	/^inline unsigned int send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid$/;"	f
-send_delba_sta_tid_wait_ack	core/rtw_mlme_ext.c	/^inline unsigned int send_delba_sta_tid_wait_ack(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid$/;"	f
-send_fw_packet	hal/rtl8723d/rtl8723d_hal_init.c	/^u8 send_fw_packet(PADAPTER padapter, u8 *pRam_code, u32 length)$/;"	f
-send_general_info	include/drv_types.h	/^	u8 send_general_info;$/;"	m	struct:halmacpriv
-sended	include/rtw_mp.h	/^	u32 count, sended;$/;"	m	struct:mp_tx
-seq	include/ieee80211.h	/^			u8 seq[8]; \/* sequence counter (set: RX, get: TX) *\/$/;"	m	struct:ieee_param::__anon73::__anon77
-seq	include/ieee80211.h	/^	uint seq;$/;"	m	struct:ieee80211_frag_entry
-seq	include/rtl8188e_recv.h	/^	u32 seq:12;$/;"	m	struct:rxreport_8188e
-seq	include/rtl8188e_xmit.h	/^	u32 seq:12;$/;"	m	struct:txdesc_88e
-seq	include/rtl8192e_xmit.h	/^	u32 seq:12;$/;"	m	struct:txdescriptor_8192e
-seq	include/rtl8812a_xmit.h	/^	u32 seq:12;$/;"	m	struct:txdescriptor_8812
-seq	include/rtl8821a_xmit.h	/^	u32 seq:12;$/;"	m	struct:txdescriptor_8821a
-seq	include/rtw_event.h	/^	unsigned char	seq;$/;"	m	struct:c2hevent_queue
-seq	include/rtw_mlme_ext.h	/^	unsigned int seq:8;$/;"	m	struct:C2HEvent_Header
-seq_ctl	include/ieee80211.h	/^	u16 seq_ctl;$/;"	m	struct:rtw_ieee80211_hdr
-seq_ctl	include/ieee80211.h	/^	u16 seq_ctl;$/;"	m	struct:rtw_ieee80211_hdr_3addr
-seq_ctl	include/ieee80211.h	/^	u16 seq_ctl;$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos
-seq_ctl	include/ieee80211.h	/^	u16 seq_ctl;$/;"	m	struct:rtw_ieee80211_hdr_qos
-seq_ctrl	include/ieee80211.h	/^	u16 seq_ctrl;$/;"	m	struct:ieee80211_header_data
-seq_ctrl	include/ieee80211_ext.h	/^	u16 seq_ctrl;$/;"	m	struct:ieee80211_mgmt
-seq_file_test	os_dep/linux/rtw_proc.c	/^struct seq_operations seq_file_test = {$/;"	v	typeref:struct:seq_operations
-seq_no	include/rtw_xmit.h	/^	u8 seq_no;$/;"	m	struct:xmit_priv
-seq_num	include/ieee80211.h	/^	u16 seq_num;$/;"	m	struct:ieee_ibss_seq
-seq_num	include/rtw_recv.h	/^	u16	seq_num;$/;"	m	struct:rx_pkt_attrib
-seq_op	os_dep/linux/rtw_proc.h	/^		struct seq_operations *seq_op;$/;"	m	union:rtw_proc_hdl::__anon81	typeref:struct:rtw_proc_hdl::__anon81::seq_operations
-seq_ops_tx_power_idx	os_dep/linux/rtw_proc.c	/^static struct seq_operations seq_ops_tx_power_idx = {$/;"	v	typeref:struct:seq_operations	file:
-seqnum	include/rtw_xmit.h	/^	u16	seqnum;$/;"	m	struct:pkt_attrib
-session_available	include/rtw_mlme.h	/^	u8						session_available;			\/*	Flag to set the WFD session available to enable or disable "by Sigma" *\/$/;"	m	struct:wifidirect_info
-session_tracker	include/sta_info.h	/^struct session_tracker {$/;"	s
-session_tracker_add_cmd	core/rtw_cmd.c	/^inline u8 session_tracker_add_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)$/;"	f
-session_tracker_chk_cmd	core/rtw_cmd.c	/^inline u8 session_tracker_chk_cmd(_adapter *adapter, struct sta_info *sta)$/;"	f
-session_tracker_chk_for_adapter	core/rtw_cmd.c	/^void session_tracker_chk_for_adapter(_adapter *adapter)$/;"	f
-session_tracker_chk_for_sta	core/rtw_cmd.c	/^void session_tracker_chk_for_sta(_adapter *adapter, struct sta_info *sta)$/;"	f
-session_tracker_cmd	core/rtw_cmd.c	/^u8 session_tracker_cmd(_adapter *adapter, u8 cmd, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)$/;"	f
-session_tracker_cmd_hdl	core/rtw_cmd.c	/^void session_tracker_cmd_hdl(_adapter *adapter, struct st_cmd_parm *parm)$/;"	f
-session_tracker_del_cmd	core/rtw_cmd.c	/^inline u8 session_tracker_del_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)$/;"	f
-setCCKFilterCoefficient_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^setCCKFilterCoefficient_8723D($/;"	f
-setIqkMatrix_8723D	hal/phydm/rtl8723d/halphyrf_8723d.c	/^void setIqkMatrix_8723D($/;"	f
-set_802_11_test	core/rtw_ioctl_set.c	/^u8 set_802_11_test(_adapter *padapter, NDIS_802_11_TEST *test)$/;"	f
-set_assocsta_parm	include/rtw_cmd.h	/^struct set_assocsta_parm {$/;"	s
-set_assocsta_rsp	include/rtw_cmd.h	/^struct set_assocsta_rsp {$/;"	s
-set_ch_hdl	core/rtw_mlme_ext.c	/^u8 set_ch_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-set_ch_parm	include/rtw_cmd.h	/^struct set_ch_parm {$/;"	s
-set_channel_bwmode	core/rtw_wlan_util.c	/^void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char channel_offset, unsigned short bwmode)$/;"	f
-set_chnl_bw_handler	include/hal_intf.h	/^	void	(*set_chnl_bw_handler)(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth, u8 Offset40, u8 Offset80);$/;"	m	struct:hal_ops
-set_chplan_hdl	core/rtw_mlme_ext.c	/^u8 set_chplan_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-set_counter	include/rtw_ioctl.h	/^	int set_counter; \/* count the number of set hits for this segment  *\/$/;"	m	struct:oid_funs_node
-set_csa_hdl	core/rtw_mlme_ext.c	/^u8 set_csa_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-set_fwstate	include/rtw_mlme.h	/^static inline void set_fwstate(struct mlme_priv *pmlmepriv, sint state)$/;"	f
-set_hal_ops	include/gspi_ops.h	151;"	d
-set_link_timer	include/rtw_mlme_ext.h	1034;"	d
-set_mcs_rate_by_mask	core/rtw_wlan_util.c	/^void set_mcs_rate_by_mask(u8 *mcs_set, u32 mask)$/;"	f
-set_qos	core/rtw_xmit.c	/^static void set_qos(struct pkt_file *ppktfile, struct pkt_attrib *pattrib)$/;"	f	file:
-set_scan_deny	include/rtw_mlme.h	/^	ATOMIC_T set_scan_deny; \/* 0: allowed, 1: deny *\/$/;"	m	struct:mlme_priv
-set_scan_deny_timer	include/rtw_mlme.h	/^	_timer set_scan_deny_timer;$/;"	m	struct:mlme_priv
-set_scanned_network_val	include/rtw_mlme.h	/^__inline static void set_scanned_network_val(struct mlme_priv *pmlmepriv, sint val)$/;"	f
-set_sta_rate	core/rtw_wlan_util.c	/^void set_sta_rate(_adapter *padapter, struct sta_info *psta)$/;"	f
-set_stakey_hdl	core/rtw_mlme_ext.c	/^u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-set_stakey_parm	include/rtw_cmd.h	/^struct set_stakey_parm {$/;"	s
-set_stakey_rsp	include/rtw_cmd.h	/^struct set_stakey_rsp {$/;"	s
-set_survey_timer	include/rtw_mlme_ext.h	1028;"	d
-set_time	include/sta_info.h	/^	u32 set_time;$/;"	m	struct:session_tracker
-set_tx	include/ieee80211.h	/^			u8 set_tx;$/;"	m	struct:ieee_param::__anon73::__anon77
-set_tx	include/rtw_cmd.h	/^	u8	set_tx;		\/* 1: main tx key for wep. 0: other key. *\/$/;"	m	struct:setkey_parm
-set_tx_beacon_cmd	core/rtw_mlme_ext.c	/^u8 set_tx_beacon_cmd(_adapter *padapter)$/;"	f
-set_tx_power_index_handler	include/hal_intf.h	/^	void (*set_tx_power_index_handler)(_adapter *padapter, u32 powerindex, u8 rfpath, u8 rate);$/;"	m	struct:hal_ops
-set_tx_power_level_handler	include/hal_intf.h	/^	void	(*set_tx_power_level_handler)(_adapter *padapter, u8 channel);$/;"	m	struct:hal_ops
-setagcctrl_parm	include/rtw_cmd.h	/^struct setagcctrl_parm {$/;"	s
-setantenna_parm	include/rtw_cmd.h	/^struct	setantenna_parm {$/;"	s
-setassocreqextraie_parm	include/rtw_cmd.h	/^struct setassocreqextraie_parm {$/;"	s
-setassocrspextraie_parm	include/rtw_cmd.h	/^struct setassocrspextraie_parm {$/;"	s
-setauth_hdl	core/rtw_mlme_ext.c	/^u8 setauth_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-setauth_parm	include/rtw_cmd.h	/^struct setauth_parm {$/;"	s
-setband	include/drv_types.h	/^	u32	setband;$/;"	m	struct:_ADAPTER
-setbasicrate_parm	include/rtw_cmd.h	/^struct	setbasicrate_parm {$/;"	s
-setbw_mutex	include/drv_types.h	/^	_mutex setbw_mutex;$/;"	m	struct:dvobj_priv
-setch_mutex	include/drv_types.h	/^	_mutex setch_mutex;$/;"	m	struct:dvobj_priv
-setcountjudge_parm	include/rtw_cmd.h	/^struct	setcountjudge_parm {$/;"	s
-setdatarate_parm	include/rtw_cmd.h	/^struct setdatarate_parm {$/;"	s
-seth2clbk_parm	include/rtw_cmd.h	/^struct seth2clbk_parm {$/;"	s
-setkey_hdl	core/rtw_mlme_ext.c	/^u8 setkey_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-setkey_parm	include/rtw_cmd.h	/^struct setkey_parm {$/;"	s
-setopmode_hdl	core/rtw_mlme_ext.c	/^u8 setopmode_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-setopmode_parm	include/rtw_cmd.h	/^struct	setopmode_parm {$/;"	s
-setphy_parm	include/rtw_cmd.h	/^struct	setphy_parm {$/;"	s
-setphyinfo_parm	include/rtw_cmd.h	/^struct	setphyinfo_parm {$/;"	s
-setprobereqextraie_parm	include/rtw_cmd.h	/^struct setprobereqextraie_parm {$/;"	s
-setproberspextraie_parm	include/rtw_cmd.h	/^struct setproberspextraie_parm {$/;"	s
-setratable_parm	include/rtw_cmd.h	/^struct setratable_parm {$/;"	s
-setssdlevel_parm	include/rtw_cmd.h	/^struct setssdlevel_parm	{$/;"	s
-setssulevel_parm	include/rtw_cmd.h	/^struct setssulevel_parm	{$/;"	s
-setssup_parm	include/rtw_cmd.h	/^struct setssup_parm	{$/;"	s
-setstapwrstate_parm	include/rtw_cmd.h	/^struct setstapwrstate_parm {$/;"	s
-settxagctbl_parm	include/rtw_cmd.h	/^struct settxagctbl_parm {$/;"	s
-sgi	include/rtl8188e_xmit.h	/^	u32 sgi:1;$/;"	m	struct:txdesc_88e
-sgi	include/rtl8192e_xmit.h	/^	u32 sgi:1;$/;"	m	struct:txdescriptor_8192e
-sgi	include/rtl8812a_xmit.h	/^	u32 sgi:1;$/;"	m	struct:txdescriptor_8812
-sgi	include/rtw_recv.h	/^	u8	sgi;$/;"	m	struct:rx_pkt_attrib
-sgi	include/rtw_xmit.h	/^	u8	sgi;\/* short GI *\/$/;"	m	struct:pkt_attrib
-sgi_20m	include/rtw_ht.h	/^	u8	sgi_20m;$/;"	m	struct:ht_priv
-sgi_40m	include/rtw_ht.h	/^	u8	sgi_40m;$/;"	m	struct:ht_priv
-sgi_80m	include/rtw_vht.h	/^	u8	sgi_80m;\/* short GI *\/$/;"	m	struct:vht_priv
-sgi_en	hal/phydm/phydm_hwconfig.h	/^	u1Byte	sgi_en: 1;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-sha256_compress	core/rtw_security.c	/^static int sha256_compress(struct sha256_state *md, unsigned char *buf)$/;"	f	file:
-sha256_done	core/rtw_security.c	/^static int sha256_done(struct sha256_state *md, unsigned char *out)$/;"	f	file:
-sha256_init	core/rtw_security.c	/^static void sha256_init(struct sha256_state *md)$/;"	f	file:
-sha256_prf	core/rtw_security.c	/^static void sha256_prf(u8 *key, size_t key_len, char *label,$/;"	f	file:
-sha256_process	core/rtw_security.c	/^static int sha256_process(struct sha256_state *md, unsigned char *in,$/;"	f	file:
-sha256_state	include/rtw_security.h	/^struct sha256_state {$/;"	s
-sha256_vector	core/rtw_security.c	/^static int sha256_vector(size_t num_elem, u8 *addr[], size_t *len,$/;"	f	file:
-shift	include/rtl8188e_recv.h	/^	u32 shift:2;$/;"	m	struct:rxreport_8188e
-shift_in_bits	core/rtw_eeprom.c	/^u16 shift_in_bits(_adapter *padapter)$/;"	f
-shift_l_map	hal/phydm/phydm_hwconfig.h	/^	u1Byte		shift_l_map: 6;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-shift_out_bits	core/rtw_eeprom.c	/^void shift_out_bits(_adapter *padapter, u16 data, u16 count)$/;"	f
-shift_row	core/rtw_security.c	/^static void shift_row(u8 *in, u8 *out)$/;"	f	file:
-shift_sz	include/rtw_recv.h	/^	u8	shift_sz;$/;"	m	struct:rx_pkt_attrib
-short_gi	include/drv_types.h	/^	u8	short_gi;$/;"	m	struct:registry_priv
-short_retry_lmt	include/drv_types.h	/^	u8	short_retry_lmt;$/;"	m	struct:registry_priv
-should_forbid_n_rate	core/rtw_wlan_util.c	/^unsigned int should_forbid_n_rate(_adapter *padapter)$/;"	f
-show	os_dep/linux/rtw_proc.h	/^		int (*show)(struct seq_file *, void *);$/;"	m	union:rtw_proc_hdl::__anon81
-shutdown_card	os_dep/linux/rtw_android.c	/^static void shutdown_card(void)$/;"	f	file:
-siaddr	core/rtw_br_ext.c	/^	u_int32_t siaddr;$/;"	m	struct:dhcpMessage	file:
-sig_evm	hal/phydm/phydm_hwconfig.h	/^	s1Byte	sig_evm;$/;"	m	struct:_Phy_Status_Rpt_8192cd
-sigevm	hal/phydm/phydm_hwconfig.h	/^	s1Byte			sigevm;									\/*signal field EVM*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-signal	include/ieee80211.h	/^	u8 signal;$/;"	m	struct:ieee80211_rx_stats
-signal_qual	include/rtw_recv.h	/^	u8 signal_qual;$/;"	m	struct:recv_priv
-signal_qual_data	include/rtw_recv.h	/^	struct signal_stat signal_qual_data;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::signal_stat
-signal_qual_data	include/rtw_recv.h	/^	struct smooth_rssi_data signal_qual_data;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::smooth_rssi_data
-signal_quality	hal/phydm/phydm_hwconfig.h	/^	u1Byte		signal_quality;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-signal_quality	include/sta_info.h	/^	s32	signal_quality;$/;"	m	struct:sta_info
-signal_stat	include/rtw_recv.h	/^struct signal_stat {$/;"	s
-signal_stat_calc_profile	core/rtw_recv.c	/^u8 signal_stat_calc_profile[SIGNAL_STAT_CALC_PROFILE_MAX][2] = {$/;"	v
-signal_stat_sampling_interval	include/rtw_recv.h	/^	u32 signal_stat_sampling_interval;$/;"	m	struct:recv_priv
-signal_stat_timer	include/rtw_recv.h	/^	_timer signal_stat_timer;$/;"	m	struct:recv_priv
-signal_strength	include/rtw_recv.h	/^	u8 signal_strength;$/;"	m	struct:recv_priv
-signal_strength_data	include/rtw_recv.h	/^	struct signal_stat signal_strength_data;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::signal_stat
-signal_strength_data	include/rtw_recv.h	/^	struct smooth_rssi_data signal_strength_data;$/;"	m	struct:recv_priv	typeref:struct:recv_priv::smooth_rssi_data
-signal_strength_dbg	include/rtw_recv.h	/^	u8 signal_strength_dbg;	\/* for debug *\/$/;"	m	struct:recv_priv
-silent_reset_inprogress	include/rtw_sreset.h	/^	u8	silent_reset_inprogress;$/;"	m	struct:sreset_priv
-silentreset	include/hal_intf.h	/^	void (*silentreset)(_adapter *padapter);$/;"	m	struct:hal_ops
-silentreset_mutex	include/rtw_sreset.h	/^	_mutex	silentreset_mutex;$/;"	m	struct:sreset_priv
-single_ant_path	hal/btc/HalBtcOutSrc.h	/^	u8				single_ant_path;	\/* current used for 8723b only, 1=>s0,  0=>s1 *\/$/;"	m	struct:btc_board_info
-sink_udpport	include/rtw_recv.h	/^	u16 sink_udpport, pre_rtp_rxseq, cur_rtp_rxseq;$/;"	m	struct:recv_priv
-sint	include/basic_types.h	/^	typedef	signed int		sint;$/;"	t
-sint	include/basic_types.h	/^	typedef	signed int sint;$/;"	t
-site_survey	core/rtw_mlme_ext.c	/^void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType)$/;"	f
-sitesurvey_cmd_hdl	core/rtw_mlme_ext.c	/^u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf)$/;"	f
-sitesurvey_ctrl	include/rtw_mlme.h	/^struct sitesurvey_ctrl {$/;"	s
-sitesurvey_ctrl_timer	include/rtw_mlme.h	/^	_timer	sitesurvey_ctrl_timer;$/;"	m	struct:sitesurvey_ctrl
-sitesurvey_parm	include/rtw_cmd.h	/^struct sitesurvey_parm {$/;"	s
-sitesurvey_pick_ch_behavior	core/rtw_mlme_ext.c	/^static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *type)$/;"	f	file:
-sitesurvey_ps_annc	core/rtw_mlme_ext.c	/^u8 sitesurvey_ps_annc(_adapter *padapter, bool ps)$/;"	f
-sitesurvey_ps_annc	core/rtw_mlme_ext.c	/^u8 sitesurvey_ps_annc(struct dvobj_priv *dvobj, bool ps)$/;"	f
-sitesurvey_res	include/rtw_mlme_ext.h	/^	struct ss_res		sitesurvey_res;$/;"	m	struct:mlme_ext_priv	typeref:struct:mlme_ext_priv::ss_res
-sitesurvey_res_reset	core/rtw_mlme_ext.c	/^static void sitesurvey_res_reset(_adapter *adapter, struct sitesurvey_parm *parm)$/;"	f	file:
-sitesurvey_set_igi	core/rtw_mlme_ext.c	/^void sitesurvey_set_igi(_adapter *adapter)$/;"	f
-sitesurvey_set_msr	core/rtw_mlme_ext.c	/^void sitesurvey_set_msr(_adapter *adapter, bool enter)$/;"	f
-size	hal/hal_btcoex.c	/^	u32 size; \/* buffer total size *\/$/;"	m	struct:_btcoexdbginfo	file:
-size	include/drv_types.h	/^	u16 size;$/;"	m	struct:loopbackdata
-size	include/osdep_service.h	/^	u32 size;$/;"	m	struct:rtw_cbuf
-size	include/rtw_cmd.h	/^	int size; \/* buffer size *\/$/;"	m	struct:drvextra_cmd_parm
-size	include/rtw_cmd.h	/^	u8 size;$/;"	m	struct:addBaRsp_parm
-sizeof_priv	include/osdep_service_linux.h	/^	u32 sizeof_priv;$/;"	m	struct:rtw_netdev_priv_indicator
-sk	include/osdep_service_bsd.h	/^	struct sock		*sk;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::sock
-sk_buff	include/osdep_service_bsd.h	/^struct sk_buff {$/;"	s
-sk_buff_data_t	include/osdep_service_bsd.h	/^typedef unsigned char *sk_buff_data_t;$/;"	t
-sk_buff_head	include/osdep_service_bsd.h	/^struct sk_buff_head {$/;"	s
-sk_store	include/rtw_btcoex.h	/^	struct sock *sk_store;\/*back up socket for UDP RX int*\/$/;"	m	struct:bt_coex_info	typeref:struct:bt_coex_info::sock
-skb	include/ieee80211.h	/^	struct sk_buff *skb;$/;"	m	struct:ieee80211_frag_entry	typeref:struct:ieee80211_frag_entry::sk_buff
-skb_clone	os_dep/osdep_service.c	/^struct sk_buff *skb_clone(const struct sk_buff *skb)$/;"	f
-skb_dequeue	include/osdep_service_bsd.h	/^static inline struct sk_buff *skb_dequeue(struct sk_buff_head *list)$/;"	f
-skb_end_pointer	include/osdep_service_linux.h	/^static inline unsigned char *skb_end_pointer(const struct sk_buff *skb)$/;"	f
-skb_iif	include/osdep_service_bsd.h	/^	int			skb_iif;$/;"	m	struct:sk_buff
-skb_peek	include/osdep_service_bsd.h	/^static inline struct sk_buff *skb_peek(struct sk_buff_head *list_)$/;"	f
-skb_pull	include/osdep_service_bsd.h	/^static inline unsigned char *skb_pull(struct sk_buff *skb, unsigned int len)$/;"	f
-skb_pull_and_merge	core/rtw_br_ext.c	/^static int skb_pull_and_merge(struct sk_buff *skb, unsigned char *src, int len)$/;"	f	file:
-skb_put	include/osdep_service_bsd.h	/^static inline unsigned char *skb_put(struct sk_buff *skb, unsigned int len)$/;"	f
-skb_queue_head_init	include/osdep_service_bsd.h	/^static inline void skb_queue_head_init(struct sk_buff_head *list)$/;"	f
-skb_queue_len	include/osdep_service_bsd.h	/^static inline u32 skb_queue_len(const struct sk_buff_head *list_)$/;"	f
-skb_queue_tail	include/osdep_service_bsd.h	/^static inline void skb_queue_tail(struct sk_buff_head *list,$/;"	f
-skb_reserve	include/osdep_service_bsd.h	/^static inline void skb_reserve(struct sk_buff *skb, int len)$/;"	f
-skb_reset_tail_pointer	include/osdep_service_linux.h	/^static inline void skb_reset_tail_pointer(struct sk_buff *skb)$/;"	f
-skb_set_tail_pointer	include/osdep_service_linux.h	/^static inline void skb_set_tail_pointer(struct sk_buff *skb, const int offset)$/;"	f
-skb_tail_pointer	include/osdep_service_bsd.h	365;"	d
-skb_tail_pointer	include/osdep_service_linux.h	/^static inline unsigned char *skb_tail_pointer(const struct sk_buff *skb)$/;"	f
-skey	include/rtw_security.h	/^	u8   skey[16];$/;"	m	union:Keytype
-slave	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					slave;$/;"	m	struct:coex_sta_8821a_csr_2ant
-slave_role	hal/btc/HalBtcOutSrc.h	/^	boolean					slave_role;$/;"	m	struct:btc_bt_link_info
-sleep_q	include/sta_info.h	/^	_queue sleep_q;$/;"	m	struct:sta_info
-sleep_q	include/sta_info.h	/^	_queue sleep_q;$/;"	m	struct:sta_priv
-sleepq_ac_len	include/sta_info.h	/^	unsigned int sleepq_ac_len;$/;"	m	struct:sta_info
-sleepq_len	include/sta_info.h	/^	unsigned int sleepq_len;$/;"	m	struct:sta_info
-slotTime	include/rtw_mlme_ext.h	/^	u8	slotTime;$/;"	m	struct:mlme_ext_info
-slow_scan_period	include/rtw_pwrctrl.h	/^	u32	slow_scan_period;			\/* slow scan period *\/$/;"	m	struct:pno_nlo_info
-smart_ps	include/drv_types.h	/^	u8	smart_ps;$/;"	m	struct:registry_priv
-smart_ps	include/rtw_mp_ioctl.h	/^	u32 smart_ps;$/;"	m	struct:psmode_param
-smart_ps	include/rtw_pwrctrl.h	/^	u8	smart_ps;$/;"	m	struct:pwrctrl_priv
-smbol1	include/osdep_service_bsd.h	/^	}smbol1;$/;"	m	struct:sk_buff	typeref:union:sk_buff::__anon47
-smbol2	include/osdep_service_bsd.h	/^		}smbol2;$/;"	m	union:sk_buff::__anon47	typeref:struct:sk_buff::__anon47::__anon48
-smooth_rssi_data	include/rtw_recv.h	/^struct smooth_rssi_data {$/;"	s
-smps_cap	include/rtw_ht.h	/^	u8	smps_cap; \/*spatial multiplexing power save mode. 0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*\/$/;"	m	struct:ht_priv
-sname	core/rtw_br_ext.c	/^	u_int8_t sname[64];$/;"	m	struct:dhcpMessage	file:
-snap	include/ieee80211.h	/^	u8 snap[6];$/;"	m	struct:eapol
-snding3SS	hal/phydm/phydm_beamforming.h	/^	BOOLEAN					snding3SS;$/;"	m	struct:_RT_BEAMFORMING_INFO
-social_chan	include/rtw_mlme.h	/^	u8						social_chan[4];$/;"	m	struct:wifidirect_info
-sock_open	include/rtw_btcoex.h	/^	u8 sock_open;$/;"	m	struct:bt_coex_info
-soft_ap	include/drv_types.h	/^	u8	soft_ap;$/;"	m	struct:registry_priv
-software_decrypt	include/drv_types.h	/^	u8	software_decrypt;$/;"	m	struct:registry_priv
-software_encrypt	include/drv_types.h	/^	u8	software_encrypt;$/;"	m	struct:registry_priv
-sound_bw	include/rtw_beamforming.h	/^	CHANNEL_WIDTH	sound_bw;	\/* Sounding BandWidth *\/$/;"	m	struct:beamforming_entry
-sound_bw	include/rtw_beamforming.h	/^	CHANNEL_WIDTH	sound_bw;$/;"	m	struct:sounding_info
-sound_bw	include/rtw_beamforming.h	/^	CHANNEL_WIDTH sound_bw;$/;"	m	struct:beamformee_entry
-sound_idx	include/rtw_beamforming.h	/^	u8				sound_idx;$/;"	m	struct:sounding_info
-sound_mode	include/rtw_beamforming.h	/^	SOUNDING_MODE	sound_mode;$/;"	m	struct:sounding_info
-sound_period	include/rtw_beamforming.h	/^	u16				sound_period;$/;"	m	struct:sounding_info
-sound_period	include/rtw_beamforming.h	/^	u16	sound_period;$/;"	m	struct:beamforming_entry
-sound_period	include/rtw_beamforming.h	/^	u16 sound_period;$/;"	m	struct:beamformee_entry
-sound_remain_cnt_per_period	include/rtw_beamforming.h	/^	u8			sound_remain_cnt_per_period;$/;"	m	struct:sounding_info
-sounding	include/rtw_beamforming.h	/^	u8 sounding;$/;"	m	struct:beamformee_entry
-sounding_info	include/rtw_beamforming.h	/^	struct sounding_info		sounding_info;$/;"	m	struct:beamforming_info	typeref:struct:beamforming_info::sounding_info
-sounding_info	include/rtw_beamforming.h	/^	struct sounding_info	sounding_info;$/;"	m	struct:beamforming_info	typeref:struct:beamforming_info::sounding_info
-sounding_info	include/rtw_beamforming.h	/^struct sounding_info {$/;"	s
-sounding_sequence	include/rtw_beamforming.h	/^	u8						sounding_sequence;$/;"	m	struct:beamforming_info
-sounding_sequence	include/rtw_beamforming.h	/^	u8			sounding_sequence;$/;"	m	struct:beamforming_info
-sp	include/osdep_service_bsd.h	/^	struct	sec_path	*sp;$/;"	m	struct:sk_buff	typeref:struct:sk_buff::sec_path
-spe_rpt	include/rtl8821a_xmit.h	/^	u32 spe_rpt:1;$/;"	m	struct:txdescriptor_8821a
-special_pkt_period_cnt	hal/btc/HalBtc8822b1Ant.h	/^	u32 					special_pkt_period_cnt;$/;"	m	struct:coex_sta_8822b_1ant
-special_rf_path	include/drv_types.h	/^	u8	special_rf_path; \/* 0: 2T2R ,1: only turn on path A 1T1R *\/$/;"	m	struct:registry_priv
-specific_device_id	include/drv_types.h	/^struct specific_device_id {$/;"	s
-specific_pkt_period_cnt	hal/btc/HalBtc8192e1Ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8192e_1ant
-specific_pkt_period_cnt	hal/btc/HalBtc8703b1Ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8703b_1ant
-specific_pkt_period_cnt	hal/btc/HalBtc8723b1Ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8723b_1ant
-specific_pkt_period_cnt	hal/btc/HalBtc8812a1Ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8812a_1ant
-specific_pkt_period_cnt	hal/btc/HalBtc8821a1Ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8821a_1ant
-specific_pkt_period_cnt	hal/btc/HalBtc8822b1Ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8822b_1ant
-specific_pkt_period_cnt	hal/btc/halbtc8723d1ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8723d_1ant
-specific_pkt_period_cnt	hal/btc/halbtc8723d2ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8723d_2ant
-specific_pkt_period_cnt	hal/btc/halbtc8821c1ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8821c_1ant
-specific_pkt_period_cnt	hal/btc/halbtc8821c2ant.h	/^	u32					specific_pkt_period_cnt;$/;"	m	struct:coex_sta_8821c_2ant
-spi_more_data	include/gspi_ops.h	/^struct spi_more_data {$/;"	s
-spin_lock_bh	include/osdep_service_bsd.h	125;"	d
-spin_lock_irqsave	include/osdep_service_bsd.h	124;"	d
-spin_unlock_bh	include/osdep_service_bsd.h	169;"	d
-spin_unlock_irqrestore	include/osdep_service_bsd.h	168;"	d
-splcp	include/rtl8188e_recv.h	/^	u32 splcp:1;$/;"	m	struct:rxreport_8188e
-src	include/rtw_recv.h	/^	u8	src[ETH_ALEN];$/;"	m	struct:rx_pkt_attrib
-src	include/rtw_xmit.h	/^	u8	src[ETH_ALEN];$/;"	m	struct:pkt_attrib
-src_addr	include/ieee80211.h	/^	u8 src_addr[ETH_ALEN];$/;"	m	struct:ieee80211_frag_entry
-src_addr	os_dep/linux/os_intfs.c	/^	struct in_addr src_addr;$/;"	m	struct:route_info	typeref:struct:route_info::in_addr	file:
-sreset_get_wifi_status	core/rtw_sreset.c	/^u8 sreset_get_wifi_status(_adapter *padapter)$/;"	f
-sreset_get_wifi_status	include/hal_intf.h	/^	u8(*sreset_get_wifi_status)(_adapter *padapter);$/;"	m	struct:hal_ops
-sreset_init_value	core/rtw_sreset.c	/^void sreset_init_value(_adapter *padapter)$/;"	f
-sreset_init_value	include/hal_intf.h	/^	void (*sreset_init_value)(_adapter *padapter);$/;"	m	struct:hal_ops
-sreset_inprogress	core/rtw_sreset.c	/^bool sreset_inprogress(_adapter *padapter)$/;"	f
-sreset_inprogress	include/hal_intf.h	/^	bool (*sreset_inprogress)(_adapter *padapter);$/;"	m	struct:hal_ops
-sreset_linked_status_check	include/hal_intf.h	/^	void (*sreset_linked_status_check)(_adapter *padapter);$/;"	m	struct:hal_ops
-sreset_priv	include/rtw_sreset.h	/^struct sreset_priv {$/;"	s
-sreset_reset	core/rtw_sreset.c	/^void sreset_reset(_adapter *padapter)$/;"	f
-sreset_reset_value	core/rtw_sreset.c	/^void sreset_reset_value(_adapter *padapter)$/;"	f
-sreset_reset_value	include/hal_intf.h	/^	void (*sreset_reset_value)(_adapter *padapter);$/;"	m	struct:hal_ops
-sreset_restore_network_station	core/rtw_sreset.c	/^void sreset_restore_network_station(_adapter *padapter)$/;"	f
-sreset_restore_network_status	core/rtw_sreset.c	/^void sreset_restore_network_status(_adapter *padapter)$/;"	f
-sreset_restore_security_station	core/rtw_sreset.c	/^void sreset_restore_security_station(_adapter *padapter)$/;"	f
-sreset_set_trigger_point	core/rtw_sreset.c	/^void sreset_set_trigger_point(_adapter *padapter, s32 tgp)$/;"	f
-sreset_set_wifi_error_status	core/rtw_sreset.c	/^void sreset_set_wifi_error_status(_adapter *padapter, u32 status)$/;"	f
-sreset_start_adapter	core/rtw_sreset.c	/^void sreset_start_adapter(_adapter *padapter)$/;"	f
-sreset_stop_adapter	core/rtw_sreset.c	/^void sreset_stop_adapter(_adapter *padapter)$/;"	f
-sreset_xmit_status_check	include/hal_intf.h	/^	void (*sreset_xmit_status_check)(_adapter *padapter);$/;"	m	struct:hal_ops
-srestpriv	include/hal_data.h	/^	struct sreset_priv srestpriv;$/;"	m	struct:hal_com_data	typeref:struct:hal_com_data::sreset_priv
-srr	include/ip.h	/^	unsigned char srr;$/;"	m	struct:ip_options
-srr_is_hit	include/ip.h	/^		 srr_is_hit:1,			\/* Packet destination addr was our one	*\/$/;"	m	struct:ip_options
-ss_DLevel	include/rtw_cmd.h	/^	u8	ss_DLevel[MAX_RATES_LENGTH];$/;"	m	struct:getssdlevel_rsp
-ss_DLevel	include/rtw_cmd.h	/^	u8	ss_DLevel[MAX_RATES_LENGTH];$/;"	m	struct:setssdlevel_parm
-ss_DLevel	include/rtw_cmd.h	/^	u8 ss_DLevel[NumRates];$/;"	m	struct:getratable_rsp
-ss_DLevel	include/rtw_cmd.h	/^	u8 ss_DLevel[NumRates];$/;"	m	struct:setratable_parm
-ss_ForceUp	include/rtw_cmd.h	/^	u32	ss_ForceUp[MAX_RATES_LENGTH];$/;"	m	struct:setssup_parm
-ss_ForceUp	include/rtw_cmd.h	/^	u8	ss_ForceUp[MAX_RATES_LENGTH];$/;"	m	struct:getssup_rsp
-ss_ForceUp	include/rtw_cmd.h	/^	u8 ss_ForceUp[NumRates];$/;"	m	struct:getratable_rsp
-ss_ForceUp	include/rtw_cmd.h	/^	u8 ss_ForceUp[NumRates];$/;"	m	struct:setratable_parm
-ss_ULevel	include/rtw_cmd.h	/^	u8	ss_ULevel[MAX_RATES_LENGTH];$/;"	m	struct:getssulevel_rsp
-ss_ULevel	include/rtw_cmd.h	/^	u8	ss_ULevel[MAX_RATES_LENGTH];$/;"	m	struct:setssulevel_parm
-ss_ULevel	include/rtw_cmd.h	/^	u8 ss_ULevel[NumRates];$/;"	m	struct:getratable_rsp
-ss_ULevel	include/rtw_cmd.h	/^	u8 ss_ULevel[NumRates];$/;"	m	struct:setratable_parm
-ss_backop_flag	include/rtw_mlme_ext.h	/^enum ss_backop_flag {$/;"	g
-ss_record	include/rtw_mlme.h	/^	struct tdls_ss_record	ss_record;$/;"	m	struct:tdls_info	typeref:struct:tdls_info::tdls_ss_record
-ss_res	include/rtw_mlme_ext.h	/^struct ss_res {$/;"	s
-ssap	include/ieee80211.h	/^	u8    ssap;   \/* always 0xAA *\/$/;"	m	struct:ieee80211_snap_hdr
-ssid	include/drv_types.h	/^	NDIS_802_11_SSID	ssid;$/;"	m	struct:registry_priv
-ssid	include/ieee80211.h	/^	u8 *ssid;$/;"	m	struct:rtw_ieee802_11_elems
-ssid	include/rtw_cmd.h	/^	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];$/;"	m	struct:sitesurvey_parm
-ssid	include/rtw_mlme.h	/^	NDIS_802_11_SSID	ssid;$/;"	m	struct:tx_provdisc_req_info
-ssid	include/rtw_mlme.h	/^	u8					ssid[WLAN_SSID_MAXLEN];		\/*	The SSID of this P2P group *\/$/;"	m	struct:group_id_info
-ssid	include/rtw_mlme.h	/^	u8	ssid[WLAN_SSID_MAXLEN];$/;"	m	struct:profile_info
-ssid	include/rtw_mlme.h	/^	u8 ssid[IW_ESSID_MAX_SIZE];$/;"	m	struct:beacon_keys
-ssid	include/rtw_mlme_ext.h	/^	NDIS_802_11_SSID ssid[RTW_SSID_SCAN_AMOUNT];$/;"	m	struct:ss_res
-ssid_channel_info	include/rtw_pwrctrl.h	/^	pno_scan_channel_info_t ssid_channel_info[MAX_SCAN_LIST_COUNT];$/;"	m	struct:pno_scan_info
-ssid_channel_info	include/rtw_pwrctrl.h	/^	u8	ssid_channel_info[MAX_PNO_LIST_COUNT];	\/* channel information *\/$/;"	m	struct:pno_nlo_info
-ssid_cipher_info	include/rtw_pwrctrl.h	/^	u8	ssid_cipher_info[MAX_PNO_LIST_COUNT];	\/* Cipher information for security *\/$/;"	m	struct:pno_nlo_info
-ssid_len	include/ieee80211.h	/^	u8 ssid_len;$/;"	m	struct:rtw_ieee802_11_elems
-ssid_len	include/rtw_mlme.h	/^	u32 ssid_len;$/;"	m	struct:beacon_keys
-ssid_length	include/rtw_pwrctrl.h	/^	u8	ssid_length[MAX_PNO_LIST_COUNT];	\/* SSID Length Array *\/$/;"	m	struct:pno_nlo_info
-ssid_length	include/rtw_security.h	/^	u16						ssid_length;$/;"	m	struct:_RT_PMKID_LIST
-ssid_num	include/rtw_cmd.h	/^	u8 ssid_num;$/;"	m	struct:sitesurvey_parm
-ssid_num	include/rtw_mlme_ext.h	/^	u8 ssid_num;$/;"	m	struct:ss_res
-ssid_num	include/rtw_pwrctrl.h	/^	u8	ssid_num;				\/* number of entry *\/$/;"	m	struct:pno_nlo_info
-ssid_octet	include/rtw_security.h	/^	u8						*ssid_octet;$/;"	m	struct:_RT_PMKID_LIST
-ssidlen	include/rtw_mlme.h	/^	u8					ssidlen;$/;"	m	struct:tx_invite_req_info
-ssidlen	include/rtw_mlme.h	/^	u8	ssidlen;$/;"	m	struct:profile_info
-st_cmd_parm	include/sta_info.h	/^struct st_cmd_parm {$/;"	s
-st_ctl	include/sta_info.h	/^	struct st_ctl_t st_ctl;$/;"	m	struct:sta_info	typeref:struct:sta_info::st_ctl_t
-st_ctl_t	include/sta_info.h	/^struct st_ctl_t {$/;"	s
-st_match_rule	include/sta_info.h	/^typedef bool (*st_match_rule)(_adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port);$/;"	t
-st_register	include/sta_info.h	/^struct st_register {$/;"	s
-sta	include/drv_types.h	/^	struct sta_info *sta[MACID_NUM_SW_LIMIT];$/;"	m	struct:macid_ctl_t	typeref:struct:macid_ctl_t::sta_info
-sta	include/rtw_mlme.h	/^	struct sta_info *sta;$/;"	m	struct:sta_media_status_rpt_cmd_parm	typeref:struct:sta_media_status_rpt_cmd_parm::sta_info
-sta	include/sta_info.h	/^	struct sta_info *sta;$/;"	m	struct:st_cmd_parm	typeref:struct:st_cmd_parm::sta_info
-sta2ap_data_frame	core/rtw_recv.c	/^sint sta2ap_data_frame($/;"	f
-sta2sta_data_frame	core/rtw_recv.c	/^sint sta2sta_data_frame($/;"	f
-sta_RxPwr	include/sta_info.h	/^	s8 sta_RxPwr[4];$/;"	m	struct:sta_recv_dframe_info
-sta_addr	include/ieee80211.h	/^	u8 sta_addr[ETH_ALEN];$/;"	m	struct:ieee_param
-sta_addr	include/ieee80211.h	/^	u8 sta_addr[ETH_ALEN];$/;"	m	struct:ieee_param_ex
-sta_aid	include/sta_info.h	/^	struct sta_info *sta_aid[NUM_STA];$/;"	m	struct:sta_priv	typeref:struct:sta_priv::sta_info
-sta_bw_mode	include/sta_info.h	/^	u8 sta_bw_mode;$/;"	m	struct:sta_recv_dframe_info
-sta_cnt	include/rtw_mlme.h	/^	u8					sta_cnt;$/;"	m	struct:tdls_info
-sta_data	include/ieee80211.h	/^struct sta_data {$/;"	s
-sta_data_rate	include/sta_info.h	/^	u8 sta_data_rate;$/;"	m	struct:sta_recv_dframe_info
-sta_dframe_info	include/sta_info.h	/^	struct sta_recv_dframe_info  sta_dframe_info;$/;"	m	struct:sta_info	typeref:struct:sta_info::sta_recv_dframe_info
-sta_dz_bitmap	include/sta_info.h	/^	u16 sta_dz_bitmap;\/* only support 15 stations, staion aid bitmap for sleeping sta. *\/$/;"	m	struct:sta_priv
-sta_hash	include/sta_info.h	/^	_list   sta_hash[NUM_STA];$/;"	m	struct:sta_priv
-sta_hash_lock	include/sta_info.h	/^	_lock sta_hash_lock;$/;"	m	struct:sta_priv
-sta_info	include/sta_info.h	/^struct sta_info {$/;"	s
-sta_info_update	core/rtw_ap.c	/^void sta_info_update(_adapter *padapter, struct sta_info *psta)$/;"	f
-sta_info_update_type	include/sta_info.h	/^enum sta_info_update_type {$/;"	g
-sta_last_rx_beacon_pkts	include/sta_info.h	475;"	d
-sta_last_rx_data_pkts	include/sta_info.h	460;"	d
-sta_last_rx_data_qos_pkts	include/sta_info.h	463;"	d
-sta_last_rx_mgnt_pkts	include/sta_info.h	469;"	d
-sta_last_rx_pkts	include/sta_info.h	449;"	d
-sta_last_rx_probereq_pkts	include/sta_info.h	481;"	d
-sta_last_rx_probersp_bm_pkts	include/sta_info.h	493;"	d
-sta_last_rx_probersp_pkts	include/sta_info.h	487;"	d
-sta_last_rx_probersp_uo_pkts	include/sta_info.h	499;"	d
-sta_maximum	include/rtw_mlme.h	/^	u8					sta_maximum;	\/* 1:tdls sta is equal (NUM_STA-1), reach max direct link number; 0: else; *\/$/;"	m	struct:tdls_info
-sta_media_status_rpt_cmd_parm	include/rtw_mlme.h	/^struct sta_media_status_rpt_cmd_parm {$/;"	s
-sta_mimo_signal_strength	include/sta_info.h	/^	s8 sta_mimo_signal_strength[4];$/;"	m	struct:sta_recv_dframe_info
-sta_num	include/rtw_mi.h	/^	u8 sta_num;			\/*WIFI_FW_STATION_STATE*\/$/;"	m	struct:mi_state
-sta_ofdm_snr	include/sta_info.h	/^	u8 sta_ofdm_snr[4];$/;"	m	struct:sta_recv_dframe_info
-sta_pending	include/rtw_xmit.h	/^	_queue	sta_pending;$/;"	m	struct:tx_servq
-sta_priv	include/sta_info.h	/^struct	sta_priv {$/;"	s
-sta_queue	include/rtw_xmit.h	/^	_queue *sta_queue;$/;"	m	struct:hw_xmit
-sta_recv_dframe_info	include/sta_info.h	/^struct sta_recv_dframe_info {$/;"	s
-sta_recv_priv	include/rtw_recv.h	/^struct sta_recv_priv {$/;"	s
-sta_recvpriv	include/sta_info.h	/^	struct sta_recv_priv sta_recvpriv;$/;"	m	struct:sta_info	typeref:struct:sta_info::sta_recv_priv
-sta_rx_beacon_pkts	include/sta_info.h	472;"	d
-sta_rx_data_pkts	include/sta_info.h	454;"	d
-sta_rx_data_qos_pkts	include/sta_info.h	457;"	d
-sta_rx_mgnt_pkts	include/sta_info.h	466;"	d
-sta_rx_pkts	include/sta_info.h	444;"	d
-sta_rx_probereq_pkts	include/sta_info.h	478;"	d
-sta_rx_probersp_bm_pkts	include/sta_info.h	490;"	d
-sta_rx_probersp_pkts	include/sta_info.h	484;"	d
-sta_rx_probersp_uo_pkts	include/sta_info.h	496;"	d
-sta_rx_reorder_ctl_dump	core/rtw_debug.c	/^void sta_rx_reorder_ctl_dump(void *sel, struct sta_info *sta)$/;"	f
-sta_set	include/ieee80211.h	/^	u32 sta_set;$/;"	m	struct:sta_data
-sta_sgi	include/sta_info.h	/^	u8 sta_sgi;$/;"	m	struct:sta_recv_dframe_info
-sta_stats	include/sta_info.h	/^	struct stainfo_stats sta_stats;$/;"	m	struct:sta_info	typeref:struct:sta_info::stainfo_stats
-sta_update_last_rx_pkts	include/sta_info.h	502;"	d
-sta_xmit_priv	include/rtw_xmit.h	/^struct sta_xmit_priv {$/;"	s
-sta_xmitpriv	include/sta_info.h	/^	struct sta_xmit_priv sta_xmitpriv;$/;"	m	struct:sta_info	typeref:struct:sta_info::sta_xmit_priv
-stack_info	hal/btc/HalBtcOutSrc.h	/^	struct  btc_stack_info		stack_info;$/;"	m	struct:btc_coexist	typeref:struct:btc_coexist::btc_stack_info
-stack_wfd_mode	include/rtw_mlme.h	/^	u8 stack_wfd_mode;$/;"	m	struct:wifi_display_info
-stadel_event	include/rtw_event.h	/^struct stadel_event {$/;"	s
-staid	include/rtw_cmd.h	/^	u8	staid;$/;"	m	struct:setstapwrstate_parm
-stainfo_offset_valid	include/sta_info.h	612;"	d
-stainfo_rxcache	include/rtw_recv.h	/^struct	stainfo_rxcache	{$/;"	s
-stainfo_stats	include/sta_info.h	/^struct	stainfo_stats	{$/;"	s
-standby	core/rtw_eeprom.c	/^void standby(_adapter	*padapter)$/;"	f
-stapriv	include/drv_types.h	/^	struct	sta_priv	stapriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::sta_priv
-start_addr	include/rtw_mp_ioctl.h	/^	u16	start_addr;$/;"	m	struct:_EFUSE_ACCESS_STRUCT_
-start_ap_mode	core/rtw_ap.c	/^void start_ap_mode(_adapter *padapter)$/;"	f
-start_bss_network	core/rtw_ap.c	/^void start_bss_network(_adapter *padapter, struct createbss_parm *parm)$/;"	f
-start_clnt_assoc	core/rtw_mlme_ext.c	/^void start_clnt_assoc(_adapter *padapter)$/;"	f
-start_clnt_auth	core/rtw_mlme_ext.c	/^void start_clnt_auth(_adapter *padapter)$/;"	f
-start_clnt_ft_action	core/rtw_mlme_ext.c	/^void start_clnt_ft_action(_adapter *padapter, u8 *pTargetAddr)$/;"	f
-start_clnt_join	core/rtw_mlme_ext.c	/^void start_clnt_join(_adapter *padapter)$/;"	f
-start_create_ibss	core/rtw_mlme_ext.c	/^void start_create_ibss(_adapter *padapter)$/;"	f
-start_pos	hal/phydm/phydm_adc_sampling.h	/^	u4Byte		start_pos;$/;"	m	struct:_RT_ADCSMP_STRING
-start_seq	include/rtw_cmd.h	/^	unsigned int start_seq;$/;"	m	struct:addBaRsp_parm
-start_seq_num	include/ieee80211_ext.h	/^					u16 start_seq_num;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon36
-start_seq_num	include/ieee80211_ext.h	/^					u16 start_seq_num;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon21
-start_seq_num	include/wifi.h	/^	unsigned short start_seq_num;$/;"	m	struct:rtw_ieee80211_bar
-starting_freq	include/rtw_rf.h	/^	u32	starting_freq;					\/* MHz, *\/$/;"	m	struct:regulatory_class
-stassoc_event	include/rtw_event.h	/^struct stassoc_event {$/;"	s
-state	core/rtw_security.c	/^	u8 state[256];$/;"	m	struct:arc4context	file:
-state	include/hal_data.h	/^	ATOMIC_T state;$/;"	m	struct:auto_chan_sel
-state	include/osdep_service_bsd.h	/^        work_state_t state; \/* the pending or otherwise state of work. *\/$/;"	m	struct:work_struct
-state	include/rtw_beamforming.h	/^	enum _BEAMFORM_ENTRY_HW_STATE state;$/;"	m	struct:beamformee_entry	typeref:enum:beamformee_entry::_BEAMFORM_ENTRY_HW_STATE
-state	include/rtw_beamforming.h	/^	enum _BEAMFORM_ENTRY_HW_STATE state;$/;"	m	struct:beamformer_entry	typeref:enum:beamformer_entry::_BEAMFORM_ENTRY_HW_STATE
-state	include/rtw_beamforming.h	/^	enum _SOUNDING_STATE	state;$/;"	m	struct:sounding_info	typeref:enum:sounding_info::_SOUNDING_STATE
-state	include/rtw_mlme_ext.h	/^	u32	state;$/;"	m	struct:mlme_ext_info
-state	include/rtw_mlme_ext.h	/^	u8 state;$/;"	m	struct:ss_res
-state	include/rtw_pwrctrl.h	/^	unsigned char state; \/* the CPWM value *\/$/;"	m	struct:reportpwrstate_parm
-state	include/rtw_security.h	/^	u32 state[8], curlen;$/;"	m	struct:sha256_state
-state	include/sta_info.h	/^	uint state;$/;"	m	struct:sta_info
-state	os_dep/linux/ioctl_cfg80211.h	/^	u8 state; \/* 0: req, 1:rep *\/$/;"	m	struct:rtw_wdev_invit_info
-state	os_dep/linux/ioctl_cfg80211.h	/^	u8 state; \/* 0: req, 1:rep, 2:conf *\/$/;"	m	struct:rtw_wdev_nego_info
-statistics	hal/btc/HalBtcOutSrc.h	/^	struct btc_statistics		statistics;$/;"	m	struct:btc_coexist	typeref:struct:btc_coexist::btc_statistics
-stats	include/drv_types.h	/^	struct net_device_stats stats;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::net_device_stats
-status	hal/btc/HalBtcOutSrc.h	/^	u1Byte	status;$/;"	m	struct:_COL_C2H_ACK
-status	hal/btc/HalBtcOutSrc.h	/^	u4Byte					status[COL_STATUS_MAX];					\/* the c2h indication verified status *\/$/;"	m	struct:_COL_SINGLE_C2H_IND_RECORD
-status	hal/btc/HalBtcOutSrc.h	/^	u4Byte					status[COL_STATUS_MAX];					\/* the c2h status for the sent h2c command *\/$/;"	m	struct:_COL_SINGLE_H2C_RECORD
-status	hal/btc/HalBtcOutSrc.h	/^	u4Byte					status[COL_STATUS_MAX];$/;"	m	struct:_BTC_OFFLOAD
-status	include/drv_types.h	/^	u32 status;$/;"	m	struct:halmac_indicator
-status	include/ieee80211.h	/^	u16 status;$/;"	m	struct:ieee80211_assoc_response_frame
-status	include/ieee80211.h	/^	u16 status;$/;"	m	struct:ieee80211_authentication
-status	include/ieee80211_ext.h	/^					u16 status;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon37
-status	include/ieee80211_ext.h	/^					u16 status;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon22
-status	include/rtw_bt_mp.h	/^	USHORT      status;$/;"	m	struct:_BT_RSP_CMD
-status	include/rtw_cmd.h	/^	u8	status;$/;"	m	struct:getphyinfo_rsp
-status	include/rtw_cmd.h	/^	u8	status;$/;"	m	struct:setphyinfo_parm
-status	include/rtw_cmd.h	/^	u8	status;$/;"	m	struct:setstapwrstate_parm
-status	include/rtw_cmd.h	/^	u8 status;$/;"	m	struct:addBaRsp_parm
-status	include/rtw_io.h	/^	u32	status;$/;"	m	struct:io_req
-status	include/rtw_xmit.h	/^	int status; \/* status for operation *\/$/;"	m	struct:submit_ctx
-status	include/sta_info.h	/^	u8 status;$/;"	m	struct:session_tracker
-status	os_dep/linux/ioctl_cfg80211.h	/^	u8 status;$/;"	m	struct:rtw_wdev_invit_info
-status	os_dep/linux/ioctl_cfg80211.h	/^	u8 status;$/;"	m	struct:rtw_wdev_nego_info
-statusCode	include/rtw_bt_mp.h	/^	u1Byte	statusCode:4;$/;"	m	struct:_BT_EXT_C2H
-status_code	include/ieee80211_ext.h	/^					u8 status_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon35
-status_code	include/ieee80211_ext.h	/^					u8 status_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon20
-status_code	include/ieee80211_ext.h	/^			u16 status_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon27
-status_code	include/ieee80211_ext.h	/^			u16 status_code;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon30
-status_code	include/ieee80211_ext.h	/^			u16 status_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon12
-status_code	include/ieee80211_ext.h	/^			u16 status_code;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon9
-status_code	include/rtw_mlme.h	/^	u16 status_code;$/;"	m	struct:tdls_txmgmt
-stay_on_base_chnl_timer	include/sta_info.h	/^	_timer	stay_on_base_chnl_timer;$/;"	m	struct:sta_info
-stbc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		stbc: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type1
-stbc	hal/phydm/phydm_hwconfig.h	/^	u1Byte		stbc: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-stbc	include/rtw_recv.h	/^	u8	stbc;$/;"	m	struct:rx_pkt_attrib
-stbc	include/rtw_xmit.h	/^	u8	stbc;$/;"	m	struct:pkt_attrib
-stbc	include/sta_info.h	/^	u8	stbc;$/;"	m	struct:sta_info
-stbc_cap	include/drv_types.h	/^	u8	stbc_cap;$/;"	m	struct:registry_priv
-stbc_cap	include/rtw_ht.h	/^	u8	stbc_cap;$/;"	m	struct:ht_priv
-stbc_cap	include/rtw_vht.h	/^	u8	stbc_cap;$/;"	m	struct:vht_priv
-stbc_param	include/wifi.h	/^	unsigned short	stbc_param;$/;"	m	struct:ieee80211_ht_addt_info
-stop	include/rtw_mp.h	/^	u8 stop;$/;"	m	struct:mp_tx
-stop_ap_mode	core/rtw_ap.c	/^void stop_ap_mode(_adapter *padapter)$/;"	f
-stop_coex_dm	hal/btc/HalBtcOutSrc.h	/^	BOOLEAN					stop_coex_dm;$/;"	m	struct:btc_coexist
-stop_req	include/rtw_cmd.h	/^	u8 stop_req;$/;"	m	struct:cmd_priv
-stop_sta_xmit	core/rtw_xmit.c	/^void stop_sta_xmit(_adapter *padapter, struct sta_info *psta)$/;"	f
-storeAdaptorInfoFile	core/efuse/rtw_efuse.c	/^int storeAdaptorInfoFile(char *path, u8 *efuse_data)$/;"	f
-storeToFile	os_dep/osdep_service.c	/^static int storeToFile(const char *path, u8 *buf, u32 sz)$/;"	f	file:
-store_law_data_flag	include/rtw_recv.h	/^	BOOLEAN store_law_data_flag;$/;"	m	struct:recv_priv
-stored_power_mgnt	include/rtw_pwrctrl.h	/^	u8	stored_power_mgnt;$/;"	m	struct:pwrctrl_priv
-str	include/rtw_mlme_ext.h	/^	char *str;$/;"	m	struct:action_handler
-str	include/rtw_mlme_ext.h	/^	char *str;$/;"	m	struct:mlme_handler
-str_2char2num	core/rtw_ieee80211.c	/^u8 str_2char2num(u8 hch, u8 lch)$/;"	f
-strconfig_method_desc_of_prov_disc_req	include/rtw_mlme.h	/^	u8					strconfig_method_desc_of_prov_disc_req[4];	\/*	description for the config method located in the provisioning discovery request frame.	 *\/$/;"	m	struct:rx_provdisc_req_info
-stream_csi	hal/phydm/phydm_hwconfig.h	/^	u1Byte	stream_csi[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-stream_rxevm	hal/phydm/phydm_hwconfig.h	/^	s1Byte	stream_rxevm[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-stream_target_csi	hal/phydm/phydm_hwconfig.h	/^	u1Byte	stream_target_csi[2];$/;"	m	struct:_Phy_Status_Rpt_8192cd
-strnicmp	os_dep/linux/rtw_android.c	37;"	d	file:
-strsep	hal/phydm/phydm_debug.c	/^char *strsep(char **s, const char *ct)$/;"	f
-su_bfee_curidx	include/rtw_beamforming.h	/^	u8			su_bfee_curidx;$/;"	m	struct:sounding_info
-su_reg_index	hal/phydm/phydm_beamforming.h	/^	u1Byte				su_reg_index;$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-su_reg_index	hal/phydm/phydm_beamforming.h	/^	u1Byte	su_reg_index;$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-su_reg_index	include/rtw_beamforming.h	/^	u8 su_reg_index;$/;"	m	struct:beamformee_entry
-su_reg_index	include/rtw_beamforming.h	/^	u8 su_reg_index;$/;"	m	struct:beamformer_entry
-su_sound_num_per_period	include/rtw_beamforming.h	/^	u8			su_sound_num_per_period;$/;"	m	struct:sounding_info
-su_sounding_list	include/rtw_beamforming.h	/^	u8			su_sounding_list[MAX_NUM_BEAMFORMEE_SU];$/;"	m	struct:sounding_info
-sub_chnl	hal/phydm/phydm_hwconfig.h	/^	u1Byte			sub_chnl: 4;								\/*sub-channel location[3:0]*\/$/;"	m	struct:_Phy_Status_Rpt_8812
-sub_chnl	hal/phydm/phydm_hwconfig.h	/^	u1Byte			sub_chnl: 4;$/;"	m	struct:_Phy_Status_Rpt_8812
-subcode	include/hal_intf.h	/^	unsigned int subcode;$/;"	m	struct:wowlan_ioctl_param
-subcode	include/rtw_mp_ioctl.h	/^	u32 subcode;$/;"	m	struct:mp_ioctl_param
-subcode_value	include/hal_intf.h	/^	unsigned int subcode_value;$/;"	m	struct:wowlan_ioctl_param
-submit_ctx	include/rtw_xmit.h	/^struct  submit_ctx {$/;"	s
-submit_time	include/rtw_xmit.h	/^	u32 submit_time; \/* *\/$/;"	m	struct:submit_ctx
-subtype	include/rtw_xmit.h	/^	u8	subtype;$/;"	m	struct:pkt_attrib
-subver	os_dep/linux/rtw_android.c	/^	char subver;$/;"	m	struct:cmd_tlv	file:
-sum	hal/phydm/phydm_noisemonitor.h	/^	s4Byte				sum[MAX_RF_PATH];$/;"	m	struct:noise_level
-supp_channels	include/ieee80211.h	/^	u8 *supp_channels;$/;"	m	struct:rtw_ieee802_11_elems
-supp_channels_len	include/ieee80211.h	/^	u8 supp_channels_len;$/;"	m	struct:rtw_ieee802_11_elems
-supp_mcs_set	include/wifi.h	/^	unsigned char	supp_mcs_set[16];$/;"	m	struct:rtw_ieee80211_ht_cap
-supp_rates	include/ieee80211.h	/^	u8 *supp_rates;$/;"	m	struct:rtw_ieee802_11_elems
-supp_rates_len	include/ieee80211.h	/^	u8 supp_rates_len;$/;"	m	struct:rtw_ieee802_11_elems
-supplicant_ie	include/rtw_security.h	/^	u8 supplicant_ie[256];  \/* store sta security information element *\/$/;"	m	struct:security_priv
-support_rate	include/rtw_mlme.h	/^	u8						support_rate[8];$/;"	m	struct:wifidirect_info
-support_short_GI	core/rtw_wlan_util.c	/^int support_short_GI(_adapter *padapter, struct HT_caps_element *pHT_caps, u8 bwmode)$/;"	f
-supported_wps_cm	include/rtw_mlme.h	/^	u16						supported_wps_cm;			\/*	This field describes the WPS config method which this driver supported. *\/$/;"	m	struct:wifidirect_info
-survey_done_set_ch_bw	core/rtw_mlme_ext.c	/^void survey_done_set_ch_bw(_adapter *padapter)$/;"	f
-survey_event	include/rtw_event.h	/^struct survey_event	{$/;"	s
-survey_timer	include/rtw_mlme_ext.h	/^	_timer		survey_timer;$/;"	m	struct:mlme_ext_priv
-survey_timer_hdl	core/rtw_mlme_ext.c	/^void survey_timer_hdl(_adapter *padapter)$/;"	f
-surveydone_event	include/rtw_event.h	/^struct surveydone_event {$/;"	s
-sval	hal/phydm/phydm_noisemonitor.h	/^	s1Byte				sval[MAX_RF_PATH];$/;"	m	struct:noise_level
-sw0	include/rtl8188e_xmit.h	/^	u32 sw0:8; \/* offset 30 *\/$/;"	m	struct:txdesc_88e
-sw0	include/rtl8188e_xmit.h	/^	u8 sw0;$/;"	m	struct:txrpt_ccx_88e
-sw0	include/rtl8192e_xmit.h	/^	u8 sw0;$/;"	m	struct:txrpt_ccx_92e
-sw1	include/rtl8188e_xmit.h	/^	u32 sw1:4;$/;"	m	struct:txdesc_88e
-sw1	include/rtl8188e_xmit.h	/^	u8 sw1:4;$/;"	m	struct:txrpt_ccx_88e
-sw1	include/rtl8192e_xmit.h	/^	u8 sw1:4;$/;"	m	struct:txrpt_ccx_92e
-sw_antdiv_bl_state	include/hal_data.h	/^	u8 sw_antdiv_bl_state;$/;"	m	struct:hal_com_data
-sw_decrypt	include/rtw_security.h	/^	s32	sw_decrypt;\/* from registry_priv *\/$/;"	m	struct:security_priv
-sw_define	include/rtl8821a_xmit.h	/^	u32 sw_define:12;$/;"	m	struct:txdescriptor_8821a
-sw_encrypt	include/rtw_security.h	/^	s32	sw_encrypt;\/* from registry_priv *\/$/;"	m	struct:security_priv
-sw_to_20mhz	include/rtw_mlme.h	/^	u8 sw_to_20mhz; \/*switch to 20Mhz BW*\/$/;"	m	struct:mlme_priv
-swab16	include/byteorder/swab.h	130;"	d
-swab16p	include/byteorder/swab.h	133;"	d
-swab16s	include/byteorder/swab.h	136;"	d
-swab32	include/byteorder/swab.h	131;"	d
-swab32p	include/byteorder/swab.h	134;"	d
-swab32s	include/byteorder/swab.h	137;"	d
-swab64	include/byteorder/swab.h	132;"	d
-swab64p	include/byteorder/swab.h	135;"	d
-swab64s	include/byteorder/swab.h	138;"	d
-swahb32	include/byteorder/swabb.h	149;"	d
-swahb32p	include/byteorder/swabb.h	151;"	d
-swahb32s	include/byteorder/swabb.h	153;"	d
-swahw32	include/byteorder/swabb.h	148;"	d
-swahw32p	include/byteorder/swabb.h	150;"	d
-swahw32s	include/byteorder/swabb.h	152;"	d
-swdec	include/rtl8188e_recv.h	/^	u32 swdec:1;$/;"	m	struct:rxreport_8188e
-switch_ch_to	os_dep/linux/ioctl_cfg80211.h	/^	ATOMIC_T switch_ch_to;$/;"	m	struct:rtw_wdev_priv
-switch_thres_offset	hal/btc/HalBtc8723b2Ant.h	/^	u8		switch_thres_offset;$/;"	m	struct:coex_dm_8723b_2ant
-switch_thres_offset	hal/btc/halbtc8723d2ant.h	/^	u8		switch_thres_offset;$/;"	m	struct:coex_dm_8723d_2ant
-switch_thres_offset	hal/btc/halbtc8821c2ant.h	/^	u8		switch_thres_offset;$/;"	m	struct:coex_dm_8821c_2ant
-switch_usb_mode	include/drv_types.h	/^	u8	switch_usb_mode;$/;"	m	struct:registry_priv
-swt_2g_RegC14	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_2g_RegC14;$/;"	m	struct:_PathDiv_Parameter_define_
-swt_2g_RegC4C	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_2g_RegC4C;$/;"	m	struct:_PathDiv_Parameter_define_
-swt_2g_RegC80	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_2g_RegC80;$/;"	m	struct:_PathDiv_Parameter_define_
-swt_2g_RegC94	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_2g_RegC94;$/;"	m	struct:_PathDiv_Parameter_define_
-swt_2g_RegCA0	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_2g_RegCA0;$/;"	m	struct:_PathDiv_Parameter_define_
-swt_5g_RegC14	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_5g_RegC14;$/;"	m	struct:_PathDiv_Parameter_define_
-swt_5g_RegCA0	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_5g_RegCA0;$/;"	m	struct:_PathDiv_Parameter_define_
-swt_5g_RegE30	hal/phydm/phydm_pathdiv.h	/^	u4Byte swt_5g_RegE30;$/;"	m	struct:_PathDiv_Parameter_define_
-swtxawake	include/ieee80211.h	/^	uint swtxawake;$/;"	m	struct:ieee80211_softmac_stats
-swtxstop	include/ieee80211.h	/^	uint swtxstop;$/;"	m	struct:ieee80211_softmac_stats
-symbol3	include/osdep_service_bsd.h	/^	}symbol3;$/;"	m	struct:sk_buff	typeref:union:sk_buff::__anon49
-syn_count	hal/phydm/phydm_hwconfig.h	/^	u1Byte		syn_count: 5;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-sys_sdio_irq_thd	include/drv_types_sdio.h	/^	_thread_hdl_ sys_sdio_irq_thd;$/;"	m	struct:sdio_data
-sz	include/rtl8188e_cmd.h	/^	u8 sz; \/* sz *\/$/;"	m	struct:cmd_msg_parm
-sz	include/rtl8192e_cmd.h	/^	u8 sz; \/* sz *\/$/;"	m	struct:cmd_msg_parm
-sz	include/rtl8812a_cmd.h	/^	u8 sz; \/* sz *\/$/;"	m	struct:cmd_msg_parm
-sz	include/rtw_mp.h	/^	u32 sz[8];$/;"	m	struct:mp_xmit_frame
-szFwBuffer	include/rtl8188e_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE_8188E
-szFwBuffer	include/rtl8188e_hal.h	/^	u8			szFwBuffer[MAX_FW_8188E_SIZE];$/;"	m	struct:_RT_FIRMWARE_8188E
-szFwBuffer	include/rtl8188f_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8188f_hal.h	/^	u8			szFwBuffer[FW_8188F_SIZE];$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8192e_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE_8192E
-szFwBuffer	include/rtl8192e_hal.h	/^	u8			szFwBuffer[FW_SIZE_8192E];$/;"	m	struct:_RT_FIRMWARE_8192E
-szFwBuffer	include/rtl8703b_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8703b_hal.h	/^	u8			szFwBuffer[FW_8703B_SIZE];$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8723b_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8723b_hal.h	/^	u8			szFwBuffer[FW_8723B_SIZE];$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8723d_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8723d_hal.h	/^	u8			szFwBuffer[FW_8723D_SIZE];$/;"	m	struct:_RT_FIRMWARE
-szFwBuffer	include/rtl8812a_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE_8812
-szFwBuffer	include/rtl8812a_hal.h	/^	u8			szFwBuffer[FW_SIZE_8812];$/;"	m	struct:_RT_FIRMWARE_8812
-szFwBuffer	include/rtl8814a_hal.h	/^	u8			*szFwBuffer;$/;"	m	struct:_RT_FIRMWARE_8814
-szFwBuffer	include/rtl8814a_hal.h	/^	u8			szFwBuffer[FW_SIZE];$/;"	m	struct:_RT_FIRMWARE_8814
-szFwBuffer	include/rtw_mp.h	/^	u8			szFwBuffer[0x8000];$/;"	m	struct:_MP_FIRMWARE
-szFwBuffer	include/rtw_mp.h	/^	u8		*szFwBuffer;$/;"	m	struct:_MP_FIRMWARE
-szofcapability	include/rtw_security.h	/^	u8 szofcapability[256]; \/* for wpa2 usage *\/$/;"	m	struct:security_priv
-tCheckTxStatus	include/Hal8188EPhyReg.h	1071;"	d
-tCheckTxStatus	include/Hal8188FPhyReg.h	1078;"	d
-tCheckTxStatus	include/Hal8192EPhyReg.h	1085;"	d
-tCheckTxStatus	include/Hal8703BPhyReg.h	1107;"	d
-tCheckTxStatus	include/Hal8723BPhyReg.h	1105;"	d
-tCheckTxStatus	include/Hal8723DPhyReg.h	1108;"	d
-tCheckTxStatus	include/rtw_mp_phy_regdef.h	1042;"	d
-tUpdateRxCounter	include/Hal8188EPhyReg.h	1072;"	d
-tUpdateRxCounter	include/Hal8188FPhyReg.h	1079;"	d
-tUpdateRxCounter	include/Hal8192EPhyReg.h	1086;"	d
-tUpdateRxCounter	include/Hal8703BPhyReg.h	1108;"	d
-tUpdateRxCounter	include/Hal8723BPhyReg.h	1106;"	d
-tUpdateRxCounter	include/Hal8723DPhyReg.h	1109;"	d
-tUpdateRxCounter	include/rtw_mp_phy_regdef.h	1043;"	d
-ta	include/rtw_recv.h	/^	u8	ta[ETH_ALEN];$/;"	m	struct:rx_pkt_attrib
-ta	include/rtw_xmit.h	/^	u8	ta[ETH_ALEN];$/;"	m	struct:pkt_attrib
-ta	include/wifi.h	/^	unsigned char ta[6];$/;"	m	struct:rtw_ieee80211_bar
-tag1	include/rtl8188e_xmit.h	/^	u32 tag1:1;$/;"	m	struct:txdesc_88e
-tag1	include/rtl8188e_xmit.h	/^	u8 tag1:1;$/;"	m	struct:txrpt_ccx_88e
-tag1	include/rtl8192e_xmit.h	/^	u32 tag1:1;$/;"	m	struct:txdescriptor_8192e
-tag1	include/rtl8192e_xmit.h	/^	u8 tag1:1;$/;"	m	struct:txrpt_ccx_92e
-tag1	include/rtl8812a_xmit.h	/^	u32 tag1:1;$/;"	m	struct:txdescriptor_8812
-tag_BT_Coexist_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_BT_Coexist_Definition$/;"	g
-tag_Band_Type_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_Band_Type_Definition$/;"	g
-tag_Bandwidth_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_Bandwidth_Definition$/;"	g
-tag_Board_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_Board_Definition$/;"	g
-tag_CCA_Path	hal/phydm/phydm.h	/^typedef enum tag_CCA_Path {$/;"	g
-tag_DIG_GoUpCheck_Level	hal/phydm/phydm_dig.h	/^typedef enum tag_DIG_GoUpCheck_Level {$/;"	g
-tag_Dynamic_Init_Gain_Operation_Type_Definition	hal/phydm/phydm_dig.h	/^typedef enum tag_Dynamic_Init_Gain_Operation_Type_Definition$/;"	g
-tag_HAL_CHIP_Type_Definition	include/HalVerDef.h	/^typedef enum tag_HAL_CHIP_Type_Definition {$/;"	g
-tag_HAL_Cut_Version_Definition	include/HalVerDef.h	/^typedef enum tag_HAL_Cut_Version_Definition {$/;"	g
-tag_HAL_IC_Type_Definition	include/HalVerDef.h	/^typedef enum tag_HAL_IC_Type_Definition {$/;"	g
-tag_HAL_Manufacturer_Version_Definition	include/HalVerDef.h	/^typedef enum tag_HAL_Manufacturer_Version_Definition {$/;"	g
-tag_HAL_RF_Type_Definition	include/HalVerDef.h	/^typedef enum tag_HAL_RF_Type_Definition {$/;"	g
-tag_HAL_VERSION	include/HalVerDef.h	/^typedef	struct tag_HAL_VERSION {$/;"	s
-tag_ODM_Cut_Version_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_Cut_Version_Definition$/;"	g
-tag_ODM_Fab_Version_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_Fab_Version_Definition$/;"	g
-tag_ODM_MAC_PHY_Mode_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_MAC_PHY_Mode_Definition$/;"	g
-tag_ODM_Package_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_Package_Definition$/;"	g
-tag_ODM_RF_Path_Bit_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_RF_Path_Bit_Definition$/;"	g
-tag_ODM_RF_Type_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_RF_Type_Definition {$/;"	g
-tag_ODM_Support_IC_Type_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_Support_IC_Type_Definition$/;"	g
-tag_ODM_Support_Interface_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_Support_Interface_Definition$/;"	g
-tag_ODM_TYPE_ALNA_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_TYPE_ALNA_Definition {$/;"	g
-tag_ODM_TYPE_APA_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_TYPE_APA_Definition {$/;"	g
-tag_ODM_TYPE_GLNA_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_TYPE_GLNA_Definition {$/;"	g
-tag_ODM_TYPE_GPA_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_ODM_TYPE_GPA_Definition {$/;"	g
-tag_Operation_Mode_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_Operation_Mode_Definition$/;"	g
-tag_PHYDM_Pause_Level	hal/phydm/phydm_dig.h	/^typedef enum tag_PHYDM_Pause_Level {$/;"	g
-tag_PHYDM_Pause_Type	hal/phydm/phydm_dig.h	/^typedef enum tag_PHYDM_Pause_Type {$/;"	g
-tag_PHYDM_RF_TX_NUM	hal/phydm/phydm_pre_define.h	/^typedef enum tag_PHYDM_RF_TX_NUM {$/;"	g
-tag_Package_Definition	include/rtl8703b_hal.h	/^typedef enum tag_Package_Definition {$/;"	g
-tag_Package_Definition	include/rtl8723b_hal.h	/^typedef enum tag_Package_Definition {$/;"	g
-tag_Package_Definition	include/rtl8723d_hal.h	/^typedef enum tag_Package_Definition {$/;"	g
-tag_PhyDM_MACEDCCA_Type	hal/phydm/phydm_adaptivity.h	/^typedef enum tag_PhyDM_MACEDCCA_Type$/;"	g
-tag_PhyDM_TRx_MUX_Type	hal/phydm/phydm_adaptivity.h	/^typedef enum tag_PhyDM_TRx_MUX_Type$/;"	g
-tag_PhyDM_set_LNA	hal/phydm/phydm_adaptivity.h	/^typedef enum tag_PhyDM_set_LNA {$/;"	g
-tag_SW_Antenna_Switch_Definition	hal/phydm/phydm_antdect.h	/^typedef enum tag_SW_Antenna_Switch_Definition$/;"	g
-tag_Secondary_Channel_Offset_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_Secondary_Channel_Offset_Definition {$/;"	g
-tag_Security_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_Security_Definition$/;"	g
-tag_Wireless_Mode_Definition	hal/phydm/phydm_pre_define.h	/^typedef enum tag_Wireless_Mode_Definition$/;"	g
-tag_phydm_kfree_channeltosw	hal/phydm/phydm_kfree.h	/^typedef enum tag_phydm_kfree_channeltosw {$/;"	g
-tail	hal/rtl8723d/rtl8723d_hal_init.c	/^	u32 tail:8;$/;"	m	struct:qinfo_8723d	file:
-tail	include/osdep_service_bsd.h	/^	sk_buff_data_t		tail;$/;"	m	struct:sk_buff
-tail	include/rtw_event.h	/^	volatile int	tail;$/;"	m	struct:c2hevent_queue
-tail	include/rtw_event.h	/^	volatile int	tail;$/;"	m	struct:network_queue
-tail	include/rtw_xmit.h	/^	volatile sint	tail;$/;"	m	struct:hw_txqueue
-tailpage	include/rtl8188e_xmit.h	/^	u32 tailpage:8;$/;"	m	struct:txdesc_88e
-tailpage	include/rtl8192e_xmit.h	/^	u32 tailpage:8;$/;"	m	struct:txdescriptor_8192e
-tailpage	include/rtl8812a_xmit.h	/^	u32 tailpage:8;$/;"	m	struct:txdescriptor_8812
-tailpage	include/rtl8821a_xmit.h	/^	u32 tailpage:8;$/;"	m	struct:txdescriptor_8821a
-target_tx_pwr_2g	include/drv_types.h	/^	s8 target_tx_pwr_2g[RF_PATH_MAX][RATE_SECTION_NUM];$/;"	m	struct:registry_priv
-target_tx_pwr_5g	include/drv_types.h	/^	s8 target_tx_pwr_5g[RF_PATH_MAX][RATE_SECTION_NUM - 1];$/;"	m	struct:registry_priv
-target_tx_pwr_valid	include/drv_types.h	/^	u8 target_tx_pwr_valid;$/;"	m	struct:registry_priv
-task	include/osdep_service_bsd.h	/^        struct task task; \/* FreeBSD task *\/$/;"	m	struct:work_struct	typeref:struct:work_struct::task
-tbder	include/drv_types.h	/^	u32 tbder;$/;"	m	struct:int_logs
-tbdok	include/drv_types.h	/^	u32 tbdok;$/;"	m	struct:int_logs
-tc_index	include/osdep_service_bsd.h	/^	u16			tc_index;	\/* traffic control index *\/$/;"	m	struct:sk_buff
-tc_verd	include/osdep_service_bsd.h	/^	u16			tc_verd;	\/* traffic control verdict *\/$/;"	m	struct:sk_buff
-tcp_chkrpt	include/rtw_recv.h	/^	u8	tcp_chkrpt; \/* 0: incorrect, 1: correct *\/$/;"	m	struct:rx_pkt_attrib
-tcpchk_valid	include/rtw_recv.h	/^	u8	tcpchk_valid; \/* 0: invalid, 1: valid *\/$/;"	m	struct:rx_pkt_attrib
-tdls_ch_switch	include/rtw_mlme.h	/^struct tdls_ch_switch {$/;"	s
-tdls_enable	include/rtw_mlme.h	/^	u8					tdls_enable;$/;"	m	struct:tdls_info
-tdls_hdl	core/rtw_mlme_ext.c	/^u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-tdls_info	include/rtw_mlme.h	/^struct tdls_info {$/;"	s
-tdls_info_to_adapter	include/drv_types.h	1472;"	d
-tdls_rtsp_ctrlport	include/rtw_mlme.h	/^	u16							tdls_rtsp_ctrlport;	\/* rtsp_ctrlport used by tdls, will sync when rtsp_ctrlport is changed by user *\/$/;"	m	struct:wifi_display_info
-tdls_ss_record	include/rtw_mlme.h	/^struct tdls_ss_record {	\/* signal strength record *\/$/;"	s
-tdls_sta_state	include/sta_info.h	/^	u32	tdls_sta_state;$/;"	m	struct:sta_info
-tdls_temp_mgmt	include/rtw_mlme.h	/^struct tdls_temp_mgmt {$/;"	s
-tdls_txmgmt	include/rtw_mlme.h	/^struct tdls_txmgmt {$/;"	s
-tdls_verify_mic	core/rtw_security.c	/^int tdls_verify_mic(u8 *kck, u8 trans_seq,$/;"	f
-tdlsinfo	include/drv_types.h	/^	struct tdls_info	tdlsinfo;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::tdls_info
-temp	hal/phydm/phydm.h	/^	u1Byte		temp;$/;"	m	struct:_ADAPTER
-temp	hal/phydm/phydm.h	/^	u1Byte		temp;$/;"	m	struct:_WLAN_STA
-temp	hal/phydm/phydm.h	/^	u1Byte		temp;$/;"	m	struct:rtl8192cd_priv
-temp2	hal/phydm/phydm.h	/^	HAL_DATA_TYPE*		temp2;$/;"	m	struct:_ADAPTER
-terminate_cmdthread_sema	include/rtw_cmd.h	/^	_sema	terminate_cmdthread_sema;$/;"	m	struct:cmd_priv
-terminate_evtthread_sema	include/rtw_cmd.h	/^	_sema	terminate_evtthread_sema;$/;"	m	struct:evt_priv
-terminate_recvthread_sema	include/rtw_recv.h	/^	_sema	terminate_recvthread_sema;$/;"	m	struct:recv_priv
-terminate_xmitthread_sema	include/rtw_xmit.h	/^	_sema	terminate_xmitthread_sema;$/;"	m	struct:xmit_priv
-test_st_match_rule	core/rtw_sta_mgt.c	/^bool test_st_match_rule(_adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)$/;"	f
-test_st_reg	core/rtw_sta_mgt.c	/^struct st_register test_st_reg = {$/;"	v	typeref:struct:st_register
-tfbga_package	hal/btc/HalBtcOutSrc.h	/^	boolean			tfbga_package;    \/* for Antenna detect threshold *\/$/;"	m	struct:btc_board_info
-thermal	include/hal_data.h	/^	s8 thermal;$/;"	m	struct:kfree_data_t
-thread_context	include/osdep_service_bsd.h	/^	typedef void*	thread_context;$/;"	t
-thread_context	include/osdep_service_ce.h	/^typedef void*	thread_context;$/;"	t
-thread_context	include/osdep_service_linux.h	/^typedef void	*thread_context;$/;"	t
-thread_context	include/osdep_service_xp.h	/^	typedef void* thread_context;$/;"	t
-thread_enter	include/osdep_service.h	/^static __inline void thread_enter(char *name)$/;"	f
-thread_exit	include/osdep_service_bsd.h	112;"	d
-thread_exit	include/osdep_service_ce.h	65;"	d
-thread_exit	include/osdep_service_linux.h	172;"	d
-thread_exit	include/osdep_service_xp.h	66;"	d
-thread_return	include/osdep_service_bsd.h	/^	typedef void		thread_return;$/;"	t
-thread_return	include/osdep_service_ce.h	/^typedef DWORD thread_return;$/;"	t
-thread_return	include/osdep_service_linux.h	/^typedef int		thread_return;$/;"	t
-thread_return	include/osdep_service_xp.h	/^	typedef void	thread_return;$/;"	t
-tid	include/ieee80211.h	/^	uint tid;	\/* jackson *\/$/;"	m	struct:ieee80211_frag_entry
-tid	include/rtl8188e_recv.h	/^	u32 tid:4;$/;"	m	struct:rxreport_8188e
-tid	include/rtw_cmd.h	/^	unsigned int tid;$/;"	m	struct:addBaReq_parm
-tid	include/rtw_cmd.h	/^	unsigned int tid;$/;"	m	struct:addBaRsp_parm
-tid	include/rtw_event.h	/^	unsigned int tid;$/;"	m	struct:addba_event
-tid_rxseq	include/rtw_recv.h	/^	u16	tid_rxseq[16];$/;"	m	struct:stainfo_rxcache
-tim	include/ieee80211.h	/^	u8 *tim;$/;"	m	struct:rtw_ieee802_11_elems
-tim_bitmap	include/sta_info.h	/^	u16 tim_bitmap;\/* only support 15 stations, aid=0~15 mapping bit0~bit15	 *\/$/;"	m	struct:sta_priv
-tim_len	include/ieee80211.h	/^	u8 tim_len;$/;"	m	struct:rtw_ieee802_11_elems
-time_stamp	include/ieee80211.h	/^	u32 time_stamp[2];$/;"	m	struct:ieee80211_probe_response
-timeout	include/ieee80211_ext.h	/^					u16 timeout;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon36
-timeout	include/ieee80211_ext.h	/^					u16 timeout;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon37
-timeout	include/ieee80211_ext.h	/^					u16 timeout;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon21
-timeout	include/ieee80211_ext.h	/^					u16 timeout;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon22
-timeout	include/rtw_pwrctrl.h	/^	u8	timeout;$/;"	m	struct:pno_scan_channel_info
-timeout_int	include/ieee80211.h	/^	u8 *timeout_int;$/;"	m	struct:rtw_ieee802_11_elems
-timeout_int_len	include/ieee80211.h	/^	u8 timeout_int_len;$/;"	m	struct:rtw_ieee802_11_elems
-timeout_ms	include/rtw_xmit.h	/^	u32 timeout_ms; \/* <0: not synchronous, 0: wait forever, >0: up to ms waiting *\/$/;"	m	struct:submit_ctx
-timer_hdl_context	include/osdep_service_bsd.h	/^	typedef void* timer_hdl_context;$/;"	t
-timer_hdl_context	include/osdep_service_linux.h	/^typedef void *timer_hdl_context;$/;"	t
-timer_hdl_return	include/osdep_service_bsd.h	/^	typedef void timer_hdl_return;$/;"	t
-timer_hdl_return	include/osdep_service_linux.h	/^typedef void timer_hdl_return;$/;"	t
-timer_list	include/osdep_service_bsd.h	/^struct timer_list {$/;"	s
-timestamp	include/ieee80211_ext.h	/^			__le64 timestamp;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon15
-timestamp	include/ieee80211_ext.h	/^			__le64 timestamp;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon17
-tk	include/sta_info.h	/^	u8 tk[16]; \/* TPK-TK; only CCMP will be used *\/$/;"	m	struct:TDLS_PeerKey
-tkip_sw_dec_cnt_bc	include/rtw_security.h	/^	u64 tkip_sw_dec_cnt_bc;$/;"	m	struct:security_priv
-tkip_sw_dec_cnt_mc	include/rtw_security.h	/^	u64 tkip_sw_dec_cnt_mc;$/;"	m	struct:security_priv
-tkip_sw_dec_cnt_uc	include/rtw_security.h	/^	u64 tkip_sw_dec_cnt_uc;$/;"	m	struct:security_priv
-tkip_sw_enc_cnt_bc	include/rtw_security.h	/^	u64 tkip_sw_enc_cnt_bc;$/;"	m	struct:security_priv
-tkip_sw_enc_cnt_mc	include/rtw_security.h	/^	u64 tkip_sw_enc_cnt_mc;$/;"	m	struct:security_priv
-tkip_sw_enc_cnt_uc	include/rtw_security.h	/^	u64 tkip_sw_enc_cnt_uc;$/;"	m	struct:security_priv
-tmp1bcc	hal/phydm/phydm_iqk.h	/^	u1Byte		tmp1bcc;$/;"	m	struct:_IQK_INFORMATION
-tmp_GNTWL	hal/phydm/phydm_iqk.h	/^	u4Byte		tmp_GNTWL;$/;"	m	struct:_IQK_INFORMATION
-to_fr_ds	include/rtw_recv.h	/^	u8	to_fr_ds;$/;"	m	struct:rx_pkt_attrib
-to_join	include/rtw_mlme.h	/^	u8	to_join; \/* flag *\/$/;"	m	struct:mlme_priv
-to_roam	include/rtw_mlme.h	/^	u8 to_roam; \/* roaming trying times *\/$/;"	m	struct:mlme_priv
-tog	include/rtw_pwrctrl.h	/^	volatile u8 tog; \/* toggling *\/$/;"	m	struct:pwrctrl_priv
-token	include/rtw_mlme.h	/^	u8					token;	\/*	Used to record the dialog token of p2p invitation request frame. *\/$/;"	m	struct:tx_invite_resp_info
-token	include/rtw_mlme.h	/^	u8					token;$/;"	m	struct:tx_invite_req_info
-token	os_dep/linux/ioctl_cfg80211.h	/^	u8 token;$/;"	m	struct:rtw_wdev_invit_info
-token	os_dep/linux/ioctl_cfg80211.h	/^	u8 token;$/;"	m	struct:rtw_wdev_nego_info
-tos	include/ip.h	/^	__u8	tos;$/;"	m	struct:iphdr
-tot_len	include/ip.h	/^	__u16	tot_len;$/;"	m	struct:iphdr
-total_len	os_dep/linux/rtw_android.c	/^	int total_len;$/;"	m	struct:android_wifi_priv_cmd	file:
-total_len	os_dep/linux/rtw_android.c	/^	int total_len;$/;"	m	struct:compat_android_wifi_priv_cmd	file:
-total_num	include/rtw_recv.h	/^	u32	total_num;		\/* num of valid elements *\/$/;"	m	struct:signal_stat
-total_num	include/rtw_recv.h	/^	u32	total_num;		\/* num of valid elements *\/$/;"	m	struct:smooth_rssi_data
-total_tp	hal/phydm/phydm.h	/^	u4Byte			total_tp;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-total_val	include/rtw_recv.h	/^	u32	total_val;		\/* sum of valid elements	 *\/$/;"	m	struct:signal_stat
-total_val	include/rtw_recv.h	/^	u32	total_val;		\/* sum of valid elements *\/$/;"	m	struct:smooth_rssi_data
-tp_scale	include/wifi.h	/^	u32 tp_scale;$/;"	m	struct:rtw_regulatory
-tpk	include/sta_info.h	/^	struct TDLS_PeerKey	tpk;$/;"	m	struct:sta_info	typeref:struct:sta_info::TDLS_PeerKey
-tpt	include/hal_com_phycfg.h	/^	s8 tpt;$/;"	m	struct:txpwr_idx_comp
-trace_buf	hal/btc/HalBtc8192e1Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8192e2Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8703b1Ant.c	/^static u8	*trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8723b1Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8723b2Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8812a1Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8812a2Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8821a1Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8821a2Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8821aCsr2Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/HalBtc8822b1Ant.c	/^static u8	 *trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/halbtc8723d1ant.c	/^static u8	*trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/halbtc8723d2ant.c	/^static u8	*trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/halbtc8821c1ant.c	/^static u8	*trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-trace_buf	hal/btc/halbtc8821c2ant.c	/^static u8	*trace_buf = &gl_btc_trace_buf[0];$/;"	v	file:
-tracker_q	include/sta_info.h	/^	_queue tracker_q;$/;"	m	struct:st_ctl_t
-traffic_busy	include/rtw_mlme.h	/^	sint	traffic_busy;$/;"	m	struct:sitesurvey_ctrl
-traffic_check_for_leave_lps	core/rtw_pwrctrl.c	/^void	traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets)$/;"	f
-traffic_scan_period	include/rtw_mlme.h	199;"	d
-traffic_stat	include/drv_types.h	/^	struct rtw_traffic_statistics	traffic_stat;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::rtw_traffic_statistics
-traffic_status_watchdog	core/rtw_cmd.c	/^u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)$/;"	f
-traffic_threshold	include/rtw_mlme.h	198;"	d
-tran_addr	include/drv_types.h	/^	unsigned long	tran_addr;$/;"	m	struct:dvobj_priv
-transaction	include/ieee80211.h	/^	u16 transaction;$/;"	m	struct:ieee80211_authentication
-transfer_len	include/rtw_recv.h	/^	int  transfer_len;$/;"	m	struct:recv_buf
-translate_percentage_to_dbm	include/rtw_recv.h	/^__inline static s32 translate_percentage_to_dbm(u32 SignalStrengthIndex)$/;"	f
-translate_scan	os_dep/linux/ioctl_linux.c	/^static char *translate_scan(_adapter *padapter,$/;"	f	file:
-transport_header	include/osdep_service_bsd.h	/^	sk_buff_data_t		transport_header;$/;"	m	struct:sk_buff
-trigger_int	include/rtl8188e_xmit.h	/^	u32 trigger_int:1;$/;"	m	struct:txdesc_88e
-trigger_int	include/rtl8192e_xmit.h	/^	u32 trigger_int:1;$/;"	m	struct:txdescriptor_8192e
-trigger_int	include/rtl8812a_xmit.h	/^	u32 trigger_int:1;$/;"	m	struct:txdescriptor_8812
-triggered	include/rtw_xmit.h	/^	u8	triggered;\/* for ap mode handling Power Saving sta *\/$/;"	m	struct:pkt_attrib
-trsw	hal/phydm/phydm_hwconfig.h	/^		u1Byte	gain:7,trsw:1;			$/;"	m	struct:_Phy_Rx_AGC_Info
-trsw	hal/phydm/phydm_hwconfig.h	/^	u1Byte		trsw: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-trsw_a	hal/phydm/phydm_hwconfig.h	/^	u1Byte		trsw_a: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-trsw_b	hal/phydm/phydm_hwconfig.h	/^	u1Byte		trsw_b: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-trsw_c	hal/phydm/phydm_hwconfig.h	/^	u1Byte		trsw_c: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-trsw_d	hal/phydm/phydm_hwconfig.h	/^	u1Byte		trsw_d: 1;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type2
-truesize	include/osdep_service_bsd.h	/^	unsigned int		truesize;$/;"	m	struct:sk_buff
-trx_share_mode	include/drv_types.h	/^	u8 trx_share_mode;$/;"	m	struct:registry_priv
-try_cnt	core/rtw_mi.c	/^	int try_cnt;$/;"	m	struct:nulldata_param	file:
-try_flag	hal/phydm/phydm_antdiv.h	/^	u1Byte		try_flag;$/;"	m	struct:_SW_Antenna_Switch_
-try_rate	include/rtl8188e_xmit.h	/^	u32 try_rate:1;$/;"	m	struct:txdesc_88e
-try_rate	include/rtl8192e_xmit.h	/^	u32 try_rate:1;$/;"	m	struct:txdescriptor_8192e
-try_rate	include/rtl8812a_xmit.h	/^	u32 try_rate:1;$/;"	m	struct:txdescriptor_8812
-try_rate	include/rtl8821a_xmit.h	/^	u32 try_rate:1;$/;"	m	struct:txdescriptor_8821a
-ts	include/ip.h	/^	unsigned char ts;$/;"	m	struct:ip_options
-ts_needaddr	include/ip.h	/^		 ts_needaddr:1;			\/* Need to record addr of outgoing dev *\/$/;"	m	struct:ip_options
-ts_needtime	include/ip.h	/^		 ts_needtime:1,			\/* Need to record timestamp		*\/$/;"	m	struct:ip_options
-tsfl	include/rtl8188e_recv.h	/^	u32 tsfl;$/;"	m	struct:rxreport_8188e
-tsfl	include/rtw_recv.h	/^	u32 tsfl;$/;"	m	struct:rx_pkt_attrib
-tstamp	include/osdep_service_bsd.h	/^	ktime_t			tstamp;$/;"	m	struct:sk_buff
-tt	include/wlan_bssdef.h	/^	} tt;$/;"	m	struct:_NDIS_802_11_TEST	typeref:union:_NDIS_802_11_TEST::__anon70
-tt	include/wlan_bssdef.h	/^	} tt;$/;"	m	struct:_NDIS_802_11_TEST	typeref:union:_NDIS_802_11_TEST::__anon71
-ttl	include/ip.h	/^	__u8	ttl;$/;"	m	struct:iphdr
-turboMode_cts2self	include/rtw_mlme_ext.h	/^	u8	turboMode_cts2self;$/;"	m	struct:mlme_ext_info
-turboMode_rtsen	include/rtw_mlme_ext.h	/^	u8	turboMode_rtsen;$/;"	m	struct:mlme_ext_info
-tv	include/osdep_service_bsd.h	/^	} tv;$/;"	m	union:ktime	typeref:struct:ktime::__anon46
-tv64	include/osdep_service_bsd.h	/^	s64	tv64;$/;"	m	union:ktime
-tx	include/rtw_mp.h	/^	struct mp_tx tx;$/;"	m	struct:mp_priv	typeref:struct:mp_priv::mp_tx
-tx_BF_cap_info	include/wifi.h	/^	unsigned int		tx_BF_cap_info;$/;"	m	struct:rtw_ieee80211_ht_cap
-tx_agc_ofdm_18_6	hal/phydm/phydm.h	/^	u4Byte			tx_agc_ofdm_18_6;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-tx_amsdu_enable	include/rtw_ht.h	/^	u8	tx_amsdu_enable;\/* for enable Tx A-MSDU *\/$/;"	m	struct:ht_priv
-tx_amsdu_maxlen	include/rtw_ht.h	/^	u32	tx_amsdu_maxlen; \/* 1: 8k, 0:4k ; default:8k, for tx *\/$/;"	m	struct:ht_priv
-tx_ant	include/rtl8821a_xmit.h	/^	u32 tx_ant:4;$/;"	m	struct:txdescriptor_8821a
-tx_ant_cck	include/rtl8188e_xmit.h	/^	u32 tx_ant_cck:2;$/;"	m	struct:txdesc_88e
-tx_ant_cck	include/rtl8192e_xmit.h	/^	u32 tx_ant_cck:2;$/;"	m	struct:txdescriptor_8192e
-tx_ant_cck	include/rtl8812a_xmit.h	/^	u32 tx_ant_cck:2;$/;"	m	struct:txdescriptor_8812
-tx_ant_ht	include/rtl8188e_xmit.h	/^	u32 tx_ant_ht:2;$/;"	m	struct:txdesc_88e
-tx_ant_ht	include/rtl8192e_xmit.h	/^	u32 tx_ant_ht:2;$/;"	m	struct:txdescriptor_8192e
-tx_ant_ht	include/rtl8812a_xmit.h	/^	u32 tx_ant_ht:2;$/;"	m	struct:txdescriptor_8812
-tx_antenna	include/rtw_cmd.h	/^	u8	tx_antenna;$/;"	m	struct:setantenna_parm
-tx_antl	include/rtl8188e_xmit.h	/^	u32 tx_antl:2;$/;"	m	struct:txdesc_88e
-tx_antl	include/rtl8192e_xmit.h	/^	u32 tx_antl:2;$/;"	m	struct:txdescriptor_8192e
-tx_antl	include/rtl8812a_xmit.h	/^	u32 tx_antl:2;$/;"	m	struct:txdescriptor_8812
-tx_antset	include/rtw_cmd.h	/^	u8	tx_antset;$/;"	m	struct:setantenna_parm
-tx_ass_rq	include/ieee80211.h	/^	uint tx_ass_rq;$/;"	m	struct:ieee80211_softmac_stats
-tx_auth_rq	include/ieee80211.h	/^	uint tx_auth_rq;$/;"	m	struct:ieee80211_softmac_stats
-tx_beacon_handlder	core/rtw_ap.c	/^void tx_beacon_handlder(struct dvobj_priv *pdvobj)$/;"	f
-tx_beacon_hdl	core/rtw_mlme_ext.c	/^u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf)$/;"	f
-tx_beacon_timer_handlder	core/rtw_ap.c	/^void tx_beacon_timer_handlder(struct dvobj_priv *pdvobj)$/;"	f
-tx_beacons	include/ieee80211.h	/^	uint tx_beacons;$/;"	m	struct:ieee80211_softmac_stats
-tx_block_mode	include/drv_types_gspi.h	/^	u8  tx_block_mode;$/;"	m	struct:gspi_data
-tx_block_mode	include/drv_types_sdio.h	/^	u8  tx_block_mode;$/;"	m	struct:sdio_data
-tx_bndy_dynamic	include/rtw_pwrctrl.h	/^	u32	tx_bndy_dynamic;$/;"	m	struct:lps_poff_info
-tx_bndy_static	include/rtw_pwrctrl.h	/^	u32	tx_bndy_static;$/;"	m	struct:lps_poff_info
-tx_buf_desc	include/rtw_xmit.h	/^struct tx_buf_desc {$/;"	s
-tx_bw_mode	include/drv_types.h	/^	u8 tx_bw_mode;$/;"	m	struct:registry_priv
-tx_bytes	include/drv_types.h	/^	u64	tx_bytes;$/;"	m	struct:rtw_traffic_statistics
-tx_bytes	include/ieee80211.h	/^	u64	tx_bytes;$/;"	m	struct:sta_data
-tx_bytes	include/rtw_xmit.h	/^	u64	tx_bytes;$/;"	m	struct:xmit_priv
-tx_bytes	include/sta_info.h	/^	u64	tx_bytes;$/;"	m	struct:stainfo_stats
-tx_deferred_transmissions	include/ieee80211.h	/^	uint tx_deferred_transmissions;$/;"	m	struct:ieee80211_stats
-tx_desc	include/rtw_xmit.h	/^struct tx_desc {$/;"	s
-tx_discards	include/ieee80211.h	/^	uint tx_discards;$/;"	m	struct:ieee80211_stats
-tx_discards_wrong_sa	include/ieee80211.h	/^	uint tx_discards_wrong_sa;$/;"	m	struct:ieee80211_stats
-tx_drop	include/drv_types.h	/^	u64	tx_drop;$/;"	m	struct:rtw_traffic_statistics
-tx_drop	include/rtw_xmit.h	/^	u64	tx_drop;$/;"	m	struct:xmit_priv
-tx_drops	include/ieee80211.h	/^	u64	tx_drops;$/;"	m	struct:sta_data
-tx_drops	include/sta_info.h	/^	u64  tx_drops;$/;"	m	struct:stainfo_stats
-tx_extra_page	include/hal_data.h	/^	u16			tx_extra_page;$/;"	m	struct:hal_com_data
-tx_fragments	include/ieee80211.h	/^	uint tx_fragments;$/;"	m	struct:ieee80211_stats
-tx_high_page	include/hal_data.h	/^	u16			tx_high_page;$/;"	m	struct:hal_com_data
-tx_invite_req_info	include/rtw_mlme.h	/^struct tx_invite_req_info {$/;"	s
-tx_invite_resp_info	include/rtw_mlme.h	/^struct tx_invite_resp_info {$/;"	s
-tx_logs	include/drv_types.h	/^	struct tx_logs tx_logs;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::tx_logs
-tx_logs	include/drv_types.h	/^struct tx_logs {$/;"	s
-tx_low_page	include/hal_data.h	/^	u16			tx_low_page;$/;"	m	struct:hal_com_data
-tx_multicast_frames	include/ieee80211.h	/^	uint tx_multicast_frames;$/;"	m	struct:ieee80211_stats
-tx_multicast_octets	include/ieee80211.h	/^	uint tx_multicast_octets;$/;"	m	struct:ieee80211_stats
-tx_multiple_retry_frames	include/ieee80211.h	/^	uint tx_multiple_retry_frames;$/;"	m	struct:ieee80211_stats
-tx_nego_req_info	include/rtw_mlme.h	/^struct tx_nego_req_info {$/;"	s
-tx_normal_page	include/hal_data.h	/^	u16			tx_normal_page;$/;"	m	struct:hal_com_data
-tx_num	include/ieee80211.h	/^	u8 tx_num; \/* value of RF_TX_NUM *\/$/;"	m	struct:rate_section_ent
-tx_pending	include/rtw_xmit.h	/^	_list	tx_pending;$/;"	m	struct:tx_servq
-tx_pending_t	include/ieee80211.h	/^typedef struct tx_pending_t {$/;"	s
-tx_pending_t	include/ieee80211.h	/^} tx_pending_t;$/;"	t	typeref:struct:tx_pending_t
-tx_pktcount	include/rtw_mp.h	/^	u32 tx_pktcount;$/;"	m	struct:mp_priv
-tx_pkts	include/drv_types.h	/^	u64	tx_pkts;$/;"	m	struct:rtw_traffic_statistics
-tx_pkts	include/ieee80211.h	/^	u64	tx_pkts;$/;"	m	struct:sta_data
-tx_pkts	include/rtw_xmit.h	/^	u64	tx_pkts;$/;"	m	struct:xmit_priv
-tx_pkts	include/sta_info.h	/^	u64	tx_pkts;$/;"	m	struct:stainfo_stats
-tx_power	include/rtw_cmd.h	/^	unsigned short tx_power;$/;"	m	struct:getcurtxpwrlevel_rsp
-tx_power	include/rtw_pwrctrl.h	/^	u8	tx_power;$/;"	m	struct:pno_scan_channel_info
-tx_probe_rq	include/ieee80211.h	/^	uint tx_probe_rq;$/;"	m	struct:ieee80211_softmac_stats
-tx_probe_rs	include/ieee80211.h	/^	uint tx_probe_rs;$/;"	m	struct:ieee80211_softmac_stats
-tx_prov_disc_info	include/rtw_mlme.h	/^	struct tx_provdisc_req_info	tx_prov_disc_info;$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::tx_provdisc_req_info
-tx_provdisc_req_info	include/rtw_mlme.h	/^struct tx_provdisc_req_info {$/;"	s
-tx_pub_page	include/hal_data.h	/^	u16			tx_pub_page;$/;"	m	struct:hal_com_data
-tx_pwr_lmt_5g_20_40_ref	include/hal_data.h	/^	u8 tx_pwr_lmt_5g_20_40_ref;$/;"	m	struct:hal_com_data
-tx_rate	include/rtw_mlme_ext.h	/^	u8	tx_rate; \/* TXRATE when USERATE is set. *\/$/;"	m	struct:mlme_ext_priv
-tx_retevt	include/rtw_xmit.h	/^	_sema	tx_retevt;\/* all tx return event; *\/$/;"	m	struct:xmit_priv
-tx_retry_limit_exceeded	include/ieee80211.h	/^	uint tx_retry_limit_exceeded;$/;"	m	struct:ieee80211_stats
-tx_retrycnt	include/rtw_cmd.h	/^	unsigned long tx_retrycnt;$/;"	m	struct:gettxretrycnt_rsp
-tx_ring	include/rtw_xmit.h	/^	struct rtw_tx_ring	tx_ring[PCI_MAX_TX_QUEUE_COUNT];$/;"	m	struct:xmit_priv	typeref:struct:xmit_priv::rtw_tx_ring
-tx_servq	include/rtw_xmit.h	/^struct tx_servq {$/;"	s
-tx_single_retry_frames	include/ieee80211.h	/^	uint tx_single_retry_frames;$/;"	m	struct:ieee80211_stats
-tx_supp_rates	include/ieee80211.h	/^			u8 tx_supp_rates[16];$/;"	m	struct:ieee_param::__anon73::__anon78
-tx_supp_rates	include/ieee80211.h	/^	u8 tx_supp_rates[16];$/;"	m	struct:sta_data
-tx_supp_rates_len	include/ieee80211.h	/^	u32 tx_supp_rates_len;$/;"	m	struct:sta_data
-tx_testcnt	include/rtw_mp.h	/^	u32 tx_testcnt;$/;"	m	struct:mp_priv
-tx_testcnt1	include/rtw_mp.h	/^	u32 tx_testcnt1;$/;"	m	struct:mp_priv
-tx_tp	hal/phydm/phydm.h	/^	u4Byte			tx_tp;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-tx_unicast_frames	include/ieee80211.h	/^	uint tx_unicast_frames;$/;"	m	struct:ieee80211_stats
-tx_unicast_octets	include/ieee80211.h	/^	uint tx_unicast_octets;$/;"	m	struct:ieee80211_stats
-txagc	include/rtw_cmd.h	/^	u32	txagc[MAX_RATES_LENGTH];$/;"	m	struct:gettxagctbl_rsp
-txagc	include/rtw_cmd.h	/^	u32	txagc[MAX_RATES_LENGTH];$/;"	m	struct:settxagctbl_parm
-txagg_a	include/rtl8188e_xmit.h	/^	u32 txagg_a:5;$/;"	m	struct:txdesc_88e
-txagg_a	include/rtl8192e_xmit.h	/^	u32 txagg_a:5;$/;"	m	struct:txdescriptor_8192e
-txagg_a	include/rtl8812a_xmit.h	/^	u32 txagg_a:5;$/;"	m	struct:txdescriptor_8812
-txagg_b	include/rtl8188e_xmit.h	/^	u32 txagg_b:5;$/;"	m	struct:txdesc_88e
-txagg_b	include/rtl8192e_xmit.h	/^	u32 txagg_b:5;$/;"	m	struct:txdescriptor_8192e
-txagg_b	include/rtl8812a_xmit.h	/^	u32 txagg_b:5;$/;"	m	struct:txdescriptor_8812
-txb	include/ieee80211.h	/^	struct ieee80211_txb *txb;$/;"	m	struct:tx_pending_t	typeref:struct:tx_pending_t::ieee80211_txb
-txbcn_timer	include/drv_types.h	/^	_timer txbcn_timer;$/;"	m	struct:dvobj_priv
-txbf	include/rtw_beamforming.h	/^	u8 txbf;$/;"	m	struct:beamformee_entry
-txbf_g_id	include/rtw_xmit.h	/^	u16 txbf_g_id;\/*beamforming Group ID*\/$/;"	m	struct:pkt_attrib
-txbf_gid	include/sta_info.h	/^	u16 txbf_gid;$/;"	m	struct:sta_info
-txbf_p_aid	include/rtw_xmit.h	/^	u16 txbf_p_aid;\/*beamforming Partial_AID*\/$/;"	m	struct:pkt_attrib
-txbf_paid	include/sta_info.h	/^	u16 txbf_paid;$/;"	m	struct:sta_info
-txbf_path	include/rtl8821a_xmit.h	/^	u32 txbf_path:1;$/;"	m	struct:txdescriptor_8821a
-txbuf	include/drv_types.h	/^	u8 txbuf[0x8000];$/;"	m	struct:loopbackdata
-txdesc	include/rtw_xmit.h	/^	struct tx_desc txdesc;$/;"	m	union:txdesc	typeref:struct:txdesc::tx_desc
-txdesc	include/rtw_xmit.h	/^union txdesc {$/;"	u
-txdesc_88e	include/rtl8188e_xmit.h	/^typedef struct txdesc_88e {$/;"	s
-txdesc_set_ccx_sw_88e	include/rtl8188e_xmit.h	198;"	d
-txdescriptor_8192e	include/rtl8192e_xmit.h	/^typedef struct txdescriptor_8192e {$/;"	s
-txdescriptor_8812	include/rtl8812a_xmit.h	/^typedef struct txdescriptor_8812 {$/;"	s
-txdescriptor_8814	include/rtl8814a_xmit.h	/^typedef struct txdescriptor_8814 {$/;"	s
-txdescriptor_8821a	include/rtl8821a_xmit.h	/^typedef struct txdescriptor_8821a {$/;"	s
-txdma_underflow	include/rtl8188e_xmit.h	/^	u8 txdma_underflow:1;$/;"	m	struct:txrpt_ccx_88e
-txdma_underflow	include/rtl8192e_xmit.h	/^	u8 txdma_underflow:1;$/;"	m	struct:txrpt_ccx_92e
-txdw0	include/rtw_xmit.h	/^	unsigned int txdw0;$/;"	m	struct:tx_desc
-txdw1	include/rtw_xmit.h	/^	unsigned int txdw1;$/;"	m	struct:tx_desc
-txdw10	include/rtw_xmit.h	/^	unsigned int txdw10;$/;"	m	struct:tx_desc
-txdw11	include/rtw_xmit.h	/^	unsigned int txdw11;$/;"	m	struct:tx_desc
-txdw12	include/rtw_xmit.h	/^	unsigned int txdw12;$/;"	m	struct:tx_desc
-txdw13	include/rtw_xmit.h	/^	unsigned int txdw13;$/;"	m	struct:tx_desc
-txdw14	include/rtw_xmit.h	/^	unsigned int txdw14;$/;"	m	struct:tx_desc
-txdw15	include/rtw_xmit.h	/^	unsigned int txdw15;$/;"	m	struct:tx_desc
-txdw2	include/rtw_xmit.h	/^	unsigned int txdw2;$/;"	m	struct:tx_desc
-txdw3	include/rtw_xmit.h	/^	unsigned int txdw3;$/;"	m	struct:tx_desc
-txdw4	include/rtw_xmit.h	/^	unsigned int txdw4;$/;"	m	struct:tx_desc
-txdw5	include/rtw_xmit.h	/^	unsigned int txdw5;$/;"	m	struct:tx_desc
-txdw6	include/rtw_xmit.h	/^	unsigned int txdw6;$/;"	m	struct:tx_desc
-txdw7	include/rtw_xmit.h	/^	unsigned int txdw7;$/;"	m	struct:tx_desc
-txdw8	include/rtw_xmit.h	/^	unsigned int txdw8;$/;"	m	struct:tx_desc
-txdw9	include/rtw_xmit.h	/^	unsigned int txdw9;$/;"	m	struct:tx_desc
-txfovw	include/drv_types.h	/^	u32 txfovw;$/;"	m	struct:int_logs
-txirp_cnt	include/rtw_xmit.h	/^	u8		txirp_cnt;$/;"	m	struct:xmit_priv
-txopLimit	include/ieee80211_ext.h	/^	u16 txopLimit;$/;"	m	struct:wme_ac_parameter
-txop_ps_cap	include/rtl8821a_xmit.h	/^	u32 txop_ps_cap:1;$/;"	m	struct:txdescriptor_8821a
-txop_ps_mode	include/rtl8821a_xmit.h	/^	u32 txop_ps_mode:1;$/;"	m	struct:txdescriptor_8821a
-txpage	include/drv_types.h	/^	u16 txpage[HW_QUEUE_ENTRY];$/;"	m	struct:halmacpriv
-txpower_limit	include/rtw_rf.h	/^	u8	txpower_limit;  				\/* dbm *\/$/;"	m	struct:regulatory_class
-txpower_param	include/rtw_mp_ioctl.h	/^struct txpower_param {$/;"	s
-txpoweridx	include/rtw_mp.h	/^	u8 txpoweridx;$/;"	m	struct:mp_priv
-txpwr_by_rate_from_file	include/hal_data.h	/^	u8	txpwr_by_rate_from_file:1;$/;"	m	struct:hal_com_data
-txpwr_by_rate_loaded	include/hal_data.h	/^	u8	txpwr_by_rate_loaded:1;$/;"	m	struct:hal_com_data
-txpwr_by_rate_undefined_band_path	include/hal_data.h	/^	u8 txpwr_by_rate_undefined_band_path[TX_PWR_BY_RATE_NUM_BAND]$/;"	m	struct:hal_com_data
-txpwr_idx_comp	include/hal_com_phycfg.h	/^struct txpwr_idx_comp {$/;"	s
-txpwr_limit_from_file	include/hal_data.h	/^	u8	txpwr_limit_from_file:1;$/;"	m	struct:hal_com_data
-txpwr_limit_loaded	include/hal_data.h	/^	u8	txpwr_limit_loaded:1;$/;"	m	struct:hal_com_data
-txpwr_offset	include/rtl8821a_xmit.h	/^	u32 txpwr_offset:3;$/;"	m	struct:txdescriptor_8821a
-txringcount	include/rtw_xmit.h	/^	int	txringcount[PCI_MAX_TX_QUEUE_COUNT];$/;"	m	struct:xmit_priv
-txrpt_ccx_88e	include/rtl8188e_xmit.h	/^struct txrpt_ccx_88e {$/;"	s
-txrpt_ccx_92e	include/rtl8192e_xmit.h	/^struct txrpt_ccx_92e {$/;"	s
-txrpt_ccx_qtime_88e	include/rtl8188e_xmit.h	239;"	d
-txrpt_ccx_sw_88e	include/rtl8188e_xmit.h	238;"	d
-txrxBdaddr	include/rtw_bt_mp.h	/^	u1Byte		txrxBdaddr[6];$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxChannel	include/rtw_bt_mp.h	/^	u1Byte		txrxChannel;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxPayloadLen	include/rtw_bt_mp.h	/^	u2Byte		txrxPayloadLen;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxPayloadType	include/rtw_bt_mp.h	/^	u1Byte		txrxPayloadType;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxPktHeader	include/rtw_bt_mp.h	/^	u4Byte		txrxPktHeader;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxPktType	include/rtw_bt_mp.h	/^	u1Byte		txrxPktType;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxTxGainIndex	include/rtw_bt_mp.h	/^	u1Byte		txrxTxGainIndex;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxTxPktCnt	include/rtw_bt_mp.h	/^	u4Byte		txrxTxPktCnt;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxTxPktInterval	include/rtw_bt_mp.h	/^	u1Byte		txrxTxPktInterval;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txrxWhitenCoeff	include/rtw_bt_mp.h	/^	u1Byte		txrxWhitenCoeff;$/;"	m	struct:_BT_TXRX_PARAMETERS
-txseq_tid	include/rtw_xmit.h	/^	u16 txseq_tid[16];$/;"	m	struct:sta_xmit_priv
-txsize	include/drv_types.h	/^	u16 txsize;$/;"	m	struct:loopbackdata
-txsz	include/rtw_xmit.h	/^	volatile sint	 txsz[8];$/;"	m	struct:hw_txqueue
-type	hal/btc/HalBtcOutSrc.h	/^	u1Byte	type;$/;"	m	struct:_COL_C2H_IND
-type	include/ieee80211.h	/^	u8 type;$/;"	m	struct:eapol
-type	include/rtl8188e_recv.h	/^	u32 type:2;$/;"	m	struct:rxreport_8188e
-type	include/rtw_cmd.h	/^	int type; \/* Can use this field as the type id or command size *\/$/;"	m	struct:drvextra_cmd_parm
-type	include/rtw_pwrctrl.h	/^	u8	type;$/;"	m	struct:rtl_wow_pattern
-type	include/rtw_wapi.h	/^	u8			type;	\/* should be 110,wapi *\/$/;"	m	struct:_RT_WAPI_CAM_ENTRY
-type	include/rtw_xmit.h	/^	u8	type;$/;"	m	struct:pkt_attrib
-type	os_dep/linux/rtw_proc.h	/^	u8 type;$/;"	m	struct:rtw_proc_hdl
-type0	include/drv_types_pci.h	/^		} type0;$/;"	m	union:_PCI_COMMON_CONFIG::__anon66	typeref:struct:_PCI_COMMON_CONFIG::__anon66::_PCI_HEADER_TYPE_0
-type_of_oid	include/rtw_ioctl.h	/^	enum oid_type	type_of_oid;$/;"	m	struct:oid_par_priv	typeref:enum:oid_par_priv::oid_type
-u	include/drv_types_pci.h	/^	} u;$/;"	m	struct:_PCI_COMMON_CONFIG	typeref:union:_PCI_COMMON_CONFIG::__anon66
-u	include/ieee80211.h	/^	} u;$/;"	m	struct:ieee_param	typeref:union:ieee_param::__anon73
-u	include/ieee80211_ext.h	/^			} __attribute__((packed)) u;$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18	typeref:union:ieee80211_mgmt::__anon8::__anon18::__anon19
-u	include/ieee80211_ext.h	/^			} u;$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33	typeref:union:ieee80211_mgmt::__anon26::__anon33::__anon34
-u	include/ieee80211_ext.h	/^	} __attribute__((packed)) u;$/;"	m	struct:ieee80211_mgmt	typeref:union:ieee80211_mgmt::__anon8
-u	include/ieee80211_ext.h	/^	} u;$/;"	m	struct:ieee80211_mgmt	typeref:union:ieee80211_mgmt::__anon26
-u	include/linux/wireless.h	/^	union	iwreq_data	u;$/;"	m	struct:iwreq	typeref:union:iwreq::iwreq_data
-u	include/rtw_recv.h	/^	} u;$/;"	m	union:recv_frame	typeref:union:recv_frame::__anon62
-u	include/wifi.h	/^	} u;$/;"	m	struct:HT_caps_element	typeref:union:HT_caps_element::__anon54
-u	os_dep/linux/rtw_proc.h	/^	} u;$/;"	m	struct:rtw_proc_hdl	typeref:union:rtw_proc_hdl::__anon81
-u16	include/basic_types.h	/^	typedef unsigned short u16;$/;"	t
-u1Byte	hal/phydm/phydm_types.h	/^	typedef unsigned char			u1Byte,*pu1Byte;$/;"	t
-u1Byte	hal/phydm/phydm_types.h	184;"	d
-u1Byte	include/rtw_mp.h	105;"	d
-u1Byte	include/rtw_mp.h	109;"	d
-u1Byte_temp	hal/phydm/phydm.h	/^	u1Byte			u1Byte_temp;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-u1ForcedIgiLb	include/hal_data.h	/^	u8	u1ForcedIgiLb;	\/* forced IGI lower bound *\/$/;"	m	struct:hal_com_data
-u2Byte	hal/phydm/phydm_types.h	/^	typedef unsigned short			u2Byte,*pu2Byte;$/;"	t
-u2Byte	hal/phydm/phydm_types.h	187;"	d
-u2Byte	include/rtw_mp.h	112;"	d
-u32	include/basic_types.h	/^	typedef unsigned int u32;$/;"	t
-u32	include/basic_types.h	/^	typedef unsigned long u32;$/;"	t
-u4Byte	hal/phydm/phydm_types.h	/^	typedef unsigned int			u4Byte,*pu4Byte;$/;"	t
-u4Byte	hal/phydm/phydm_types.h	190;"	d
-u4Byte	include/rtw_mp.h	107;"	d
-u4Byte	include/rtw_mp.h	115;"	d
-u64	include/basic_types.h	/^	typedef unsigned long long u64;$/;"	t
-u8	include/basic_types.h	/^	typedef unsigned char u8;$/;"	t
-u8Byte	hal/phydm/phydm_types.h	/^	typedef unsigned long long		u8Byte,*pu8Byte;$/;"	t
-u8Byte	hal/phydm/phydm_types.h	193;"	d
-u8Byte	include/rtw_mp.h	118;"	d
-u8Dir	include/rtw_mp_ioctl.h	/^	u8	u8Dir;\/* 0:OUT, 1:IN *\/$/;"	m	struct:_USB_VendorReq
-u8InData	include/rtw_mp_ioctl.h	/^	u8	u8InData;$/;"	m	struct:_USB_VendorReq
-uapsd_acbe_en	include/drv_types.h	/^	u8	uapsd_acbe_en;$/;"	m	struct:registry_priv
-uapsd_acbk_en	include/drv_types.h	/^	u8	uapsd_acbk_en;$/;"	m	struct:registry_priv
-uapsd_acvi_en	include/drv_types.h	/^	u8	uapsd_acvi_en;$/;"	m	struct:registry_priv
-uapsd_acvo_en	include/drv_types.h	/^	u8	uapsd_acvo_en;$/;"	m	struct:registry_priv
-uapsd_be	include/sta_info.h	/^	u8 uapsd_be;$/;"	m	struct:sta_info
-uapsd_bk	include/sta_info.h	/^	u8 uapsd_bk;\/* BIT(0): Delivery enabled, BIT(1): Trigger enabled *\/$/;"	m	struct:sta_info
-uapsd_enable	include/drv_types.h	/^	u8	uapsd_enable;$/;"	m	struct:registry_priv
-uapsd_max_sp	include/drv_types.h	/^	u8	uapsd_max_sp;$/;"	m	struct:registry_priv
-uapsd_vi	include/sta_info.h	/^	u8 uapsd_vi;$/;"	m	struct:sta_info
-uapsd_vo	include/sta_info.h	/^	u8 uapsd_vo;$/;"	m	struct:sta_info
-uc_swdec_pending_queue	include/rtw_recv.h	/^	_queue	uc_swdec_pending_queue;$/;"	m	struct:recv_priv
-udev	include/osdep_intf.h	/^	struct usb_device	*udev;$/;"	m	struct:intf_priv	typeref:struct:intf_priv::usb_device
-udpsock	include/rtw_btcoex.h	/^	struct socket *udpsock;$/;"	m	struct:bt_coex_info	typeref:struct:bt_coex_info::socket
-ui_got_wps_info	include/rtw_mlme.h	/^	enum	P2P_WPSINFO		ui_got_wps_info;			\/*	This field will store the WPS value (PIN value or PBC) that UI had got from the user. *\/$/;"	m	struct:wifidirect_info	typeref:enum:wifidirect_info::P2P_WPSINFO
-uint	include/basic_types.h	/^	typedef unsigned int	uint;$/;"	t
-ulFwLength	include/rtl8188e_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE_8188E
-ulFwLength	include/rtl8188f_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE
-ulFwLength	include/rtl8192e_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE_8192E
-ulFwLength	include/rtl8703b_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE
-ulFwLength	include/rtl8723b_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE
-ulFwLength	include/rtl8723d_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE
-ulFwLength	include/rtl8812a_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE_8812
-ulFwLength	include/rtl8814a_hal.h	/^	u32			ulFwLength;$/;"	m	struct:_RT_FIRMWARE_8814
-ulFwLength	include/rtw_mp.h	/^	u32		ulFwLength;$/;"	m	struct:_MP_FIRMWARE
-under_exist_checking	include/sta_info.h	/^	u8 under_exist_checking;$/;"	m	struct:sta_info
-under_ips	hal/btc/HalBtc8192e1Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8192e_1ant
-under_ips	hal/btc/HalBtc8192e2Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8192e_2ant
-under_ips	hal/btc/HalBtc8703b1Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8703b_1ant
-under_ips	hal/btc/HalBtc8723b1Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8723b_1ant
-under_ips	hal/btc/HalBtc8723b2Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8723b_2ant
-under_ips	hal/btc/HalBtc8812a1Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8812a_1ant
-under_ips	hal/btc/HalBtc8812a2Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8812a_2ant
-under_ips	hal/btc/HalBtc8821a1Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8821a_1ant
-under_ips	hal/btc/HalBtc8821a2Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8821a_2ant
-under_ips	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8821a_csr_2ant
-under_ips	hal/btc/HalBtc8822b1Ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8822b_1ant
-under_ips	hal/btc/halbtc8723d1ant.h	/^	boolean				under_ips;$/;"	m	struct:coex_sta_8723d_1ant
-under_ips	hal/btc/halbtc8723d2ant.h	/^	boolean				under_ips;$/;"	m	struct:coex_sta_8723d_2ant
-under_ips	hal/btc/halbtc8821c1ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8821c_1ant
-under_ips	hal/btc/halbtc8821c2ant.h	/^	boolean					under_ips;$/;"	m	struct:coex_sta_8821c_2ant
-under_lps	hal/btc/HalBtc8192e1Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8192e_1ant
-under_lps	hal/btc/HalBtc8192e2Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8192e_2ant
-under_lps	hal/btc/HalBtc8703b1Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8703b_1ant
-under_lps	hal/btc/HalBtc8723b1Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8723b_1ant
-under_lps	hal/btc/HalBtc8723b2Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8723b_2ant
-under_lps	hal/btc/HalBtc8812a1Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8812a_1ant
-under_lps	hal/btc/HalBtc8812a2Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8812a_2ant
-under_lps	hal/btc/HalBtc8821a1Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8821a_1ant
-under_lps	hal/btc/HalBtc8821a2Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8821a_2ant
-under_lps	hal/btc/HalBtc8821aCsr2Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8821a_csr_2ant
-under_lps	hal/btc/HalBtc8822b1Ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8822b_1ant
-under_lps	hal/btc/halbtc8723d1ant.h	/^	boolean				under_lps;$/;"	m	struct:coex_sta_8723d_1ant
-under_lps	hal/btc/halbtc8723d2ant.h	/^	boolean				under_lps;$/;"	m	struct:coex_sta_8723d_2ant
-under_lps	hal/btc/halbtc8821c1ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8821c_1ant
-under_lps	hal/btc/halbtc8821c2ant.h	/^	boolean					under_lps;$/;"	m	struct:coex_sta_8821c_2ant
-unicast_uses_group	include/ieee80211.h	/^	    unicast_uses_group:1;$/;"	m	struct:ieee80211_security
-unicastwake	include/rtl8188e_recv.h	/^	u32 unicastwake:1;$/;"	m	struct:rxreport_8188e
-union_bw	include/rtw_mi.h	/^	u8 union_bw;$/;"	m	struct:mi_state
-union_ch	include/rtw_mi.h	/^	u8 union_ch;$/;"	m	struct:mi_state
-union_offset	include/rtw_mi.h	/^	u8 union_offset;$/;"	m	struct:mi_state
-unknownAP	include/rtw_mlme_ext.h	/^	unknownAP	= 7,$/;"	e	enum:Associated_AP
-unknown_acl_exist	hal/btc/HalBtcOutSrc.h	/^	boolean					unknown_acl_exist;$/;"	m	struct:btc_stack_info
-unregister_net_gpio_init	os_dep/linux/custom_gpio_linux.c	/^int unregister_net_gpio_init(void)$/;"	f
-unregister_task_alive	core/rtw_pwrctrl.c	/^__inline static void unregister_task_alive(struct pwrctrl_priv *pwrctrl, u32 tag)$/;"	f	file:
-up_clk	core/rtw_eeprom.c	/^void up_clk(_adapter	*padapter,	 u16 *x)$/;"	f
-up_scanned_network	include/rtw_mlme.h	/^static inline void up_scanned_network(struct mlme_priv *pmlmepriv)$/;"	f
-update_BCNTIM	core/rtw_ap.c	/^static void update_BCNTIM(_adapter *padapter)$/;"	f	file:
-update_IOT_info	hal/hal_com.c	/^void update_IOT_info(_adapter *padapter)$/;"	f
-update_MCS_rate	core/rtw_wlan_util.c	/^unsigned int update_MCS_rate(struct HT_caps_element *pHT_caps)$/;"	f
-update_TSF	core/rtw_wlan_util.c	/^void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)$/;"	f
-update_ap_info	core/rtw_ap.c	/^static void update_ap_info(_adapter *padapter, struct sta_info *psta)$/;"	f	file:
-update_attrib	core/rtw_xmit.c	/^static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattrib)$/;"	f	file:
-update_attrib_phy_info	core/rtw_xmit.c	/^static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)$/;"	f	file:
-update_attrib_sec_info	core/rtw_xmit.c	/^static s32 update_attrib_sec_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)$/;"	f	file:
-update_attrib_txbf_info	core/rtw_beamforming.c	/^void update_attrib_txbf_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)$/;"	f
-update_attrib_vcs_info	core/rtw_xmit.c	/^static void update_attrib_vcs_info(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f	file:
-update_basic_rate	core/rtw_wlan_util.c	/^unsigned int update_basic_rate(unsigned char *ptn, unsigned int ptn_sz)$/;"	f
-update_bcn	include/rtw_mlme.h	/^	u8		update_bcn;$/;"	m	struct:mlme_priv
-update_bcn_erpinfo_ie	core/rtw_ap.c	/^static void update_bcn_erpinfo_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_ext_capab_ie	core/rtw_ap.c	/^static void update_bcn_ext_capab_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_fixed_ie	core/rtw_ap.c	/^static void update_bcn_fixed_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_htcap_ie	core/rtw_ap.c	/^static void update_bcn_htcap_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_htinfo_ie	core/rtw_ap.c	/^static void update_bcn_htinfo_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_p2p_ie	core/rtw_ap.c	/^static void update_bcn_p2p_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_rsn_ie	core/rtw_ap.c	/^static void update_bcn_rsn_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_vendor_spec_ie	core/rtw_ap.c	/^static void update_bcn_vendor_spec_ie(_adapter *padapter, u8 *oui)$/;"	f	file:
-update_bcn_wmm_ie	core/rtw_ap.c	/^static void update_bcn_wmm_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_wpa_ie	core/rtw_ap.c	/^static void update_bcn_wpa_ie(_adapter *padapter)$/;"	f	file:
-update_bcn_wps_ie	core/rtw_ap.c	/^static void update_bcn_wps_ie(_adapter *padapter)$/;"	f	file:
-update_beacon	include/rtw_ap.h	37;"	d
-update_beacon_info	core/rtw_wlan_util.c	/^void update_beacon_info(_adapter *padapter, u8 *pframe, uint pkt_len, struct sta_info *psta)$/;"	f
-update_beam_codeword	hal/phydm/phydm_antdiv.h	/^	u4Byte	update_beam_codeword;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-update_beam_idx	hal/phydm/phydm_antdiv.h	/^	u1Byte	update_beam_idx;$/;"	m	struct:_SMART_ANTENNA_TRAINNING_
-update_bmc_sta	core/rtw_ap.c	/^void update_bmc_sta(_adapter *padapter)$/;"	f
-update_capinfo	core/rtw_wlan_util.c	/^void update_capinfo(PADAPTER Adapter, u16 updateCap)$/;"	f
-update_channel_plan_by_ap_done	include/rtw_mlme_ext.h	/^	u8 update_channel_plan_by_ap_done;$/;"	m	struct:mlme_ext_priv
-update_current_network	core/rtw_mlme.c	/^static void update_current_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)$/;"	f	file:
-update_hidden_ssid	core/rtw_mlme_ext.c	/^int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)$/;"	f
-update_hidden_ssid	hal/hal_com.c	/^static int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)$/;"	f	file:
-update_hisr_hsisr_ind	include/hal_intf.h	/^	void (*update_hisr_hsisr_ind)(PADAPTER padapter, u32 flag);$/;"	m	struct:hal_ops
-update_hw_ht_param	core/rtw_ap.c	/^static void update_hw_ht_param(_adapter *padapter)$/;"	f	file:
-update_hw_vht_param	core/rtw_vht.c	/^void	update_hw_vht_param(_adapter *padapter)$/;"	f
-update_ldpc_stbc_cap	core/rtw_wlan_util.c	/^void	update_ldpc_stbc_cap(struct sta_info *psta)$/;"	f
-update_mask_tdls	core/rtw_tdls.c	/^u32 update_mask_tdls(_adapter *padapter, struct sta_info *psta)$/;"	f
-update_mcc_mgntframe_attrib	hal/hal_mcc.c	/^inline void update_mcc_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)$/;"	f
-update_mgnt_tx_rate	core/rtw_mlme_ext.c	/^void update_mgnt_tx_rate(_adapter *padapter, u8 rate)$/;"	f
-update_mgntframe_attrib	core/rtw_mlme_ext.c	/^void update_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)$/;"	f
-update_mgntframe_attrib_addr	core/rtw_mlme_ext.c	/^void update_mgntframe_attrib_addr(_adapter *padapter, struct xmit_frame *pmgntframe)$/;"	f
-update_monitor_frame_attrib	core/rtw_mlme_ext.c	/^void update_monitor_frame_attrib(_adapter *padapter, struct pkt_attrib *pattrib)$/;"	f
-update_nd_link_layer_addr	core/rtw_br_ext.c	/^static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char *replace_mac)$/;"	f	file:
-update_network	core/rtw_mlme.c	/^void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src,$/;"	f
-update_req	include/rtw_recv.h	/^	u8	update_req;		\/* used to indicate *\/$/;"	m	struct:signal_stat
-update_sta_basic_rate	core/rtw_wlan_util.c	/^void update_sta_basic_rate(struct sta_info *psta, u8 wireless_mode)$/;"	f
-update_sta_info	core/rtw_mlme_ext.c	/^void update_sta_info(_adapter *padapter, struct sta_info *psta)$/;"	f
-update_sta_info_apmode	core/rtw_ap.c	/^void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta)$/;"	f
-update_sta_vht_info_apmode	core/rtw_vht.c	/^void	update_sta_vht_info_apmode(_adapter *padapter, PVOID sta)$/;"	f
-update_supported_rate	core/rtw_wlan_util.c	/^unsigned int update_supported_rate(unsigned char *ptn, unsigned int ptn_sz)$/;"	f
-update_tdls_attrib	core/rtw_xmit.c	/^s32 update_tdls_attrib(_adapter *padapter, struct pkt_attrib *pattrib)$/;"	f
-update_tx_basic_rate	core/rtw_wlan_util.c	/^void update_tx_basic_rate(_adapter *padapter, u8 wirelessmode)$/;"	f
-update_wireless_mode	core/rtw_wlan_util.c	/^void update_wireless_mode(_adapter *padapter)$/;"	f
-updated_ft_ies	include/rtw_mlme.h	/^	u8	updated_ft_ies[RTW_MAX_FTIE_SZ];$/;"	m	struct:_ft_priv
-updated_ft_ies_len	include/rtw_mlme.h	/^	u16	updated_ft_ies_len;$/;"	m	struct:_ft_priv
-usb_alloc_vendor_req_buf	include/drv_types.h	/^	u8 *usb_alloc_vendor_req_buf;$/;"	m	struct:dvobj_priv
-usb_bulkout_zero_complete	include/usb_ops_linux.h	45;"	d
-usb_deregister	os_dep/osdep_service.c	/^usb_deregister(struct usb_driver *driver)$/;"	f
-usb_extension	include/drv_types.h	/^	USB_EXTENSION	usb_extension;$/;"	m	struct:dvobj_priv
-usb_get_dev	include/osdep_service_bsd.h	/^usb_get_dev(struct usb_device *dev)$/;"	f
-usb_intf_start	include/hal_data.h	/^	u8			usb_intf_start;$/;"	m	struct:hal_com_data
-usb_put_dev	include/osdep_service_bsd.h	/^usb_put_dev(struct usb_device *dev)$/;"	f
-usb_read_interrupt_complete	include/usb_ops_linux.h	49;"	d
-usb_read_port_complete	include/usb_ops_linux.h	48;"	d
-usb_register	os_dep/osdep_service.c	/^usb_register(struct usb_driver *driver)$/;"	f
-usb_rxagg_mode	include/drv_types.h	/^	u8   usb_rxagg_mode;$/;"	m	struct:registry_priv
-usb_speed	include/drv_types.h	/^	u8	usb_speed; \/* 1.1, 2.0 or 3.0 *\/$/;"	m	struct:dvobj_priv
-usb_suspend_parm	include/rtw_cmd.h	/^struct usb_suspend_parm {$/;"	s
-usb_suspend_sema	include/drv_types.h	/^	_sema	usb_suspend_sema;$/;"	m	struct:dvobj_priv
-usb_transfer_read_port	include/rtw_recv.h	/^	USB_TRANSFER	usb_transfer_read_port;$/;"	m	struct:recv_buf
-usb_transfer_write_mem	include/rtw_io.h	/^	USB_TRANSFER usb_transfer_write_mem;$/;"	m	struct:io_req
-usb_transfer_write_port	include/rtw_xmit.h	/^	USB_TRANSFER	usb_transfer_write_port;$/;"	m	struct:xmit_buf
-usb_transfer_write_port	include/rtw_xmit.h	/^	USB_TRANSFER	usb_transfer_write_port;$/;"	m	struct:xmit_priv
-usb_txagg_num	include/rtl8188e_xmit.h	/^	u32 usb_txagg_num:8;$/;"	m	struct:txdesc_88e
-usb_txagg_num	include/rtl8192e_xmit.h	/^	u32 usb_txagg_num:8;$/;"	m	struct:txdescriptor_8192e
-usb_txagg_num	include/rtl8812a_xmit.h	/^	u32 usb_txagg_num:8;$/;"	m	struct:txdescriptor_8812
-usb_txagg_num	include/rtl8821a_xmit.h	/^	u32 usb_txagg_num:8;$/;"	m	struct:txdescriptor_8821a
-usb_vendor_req	include/rtw_mp_ioctl.h	/^} usb_vendor_req, USB_VendorReq, *pUSB_VendorReq;$/;"	t	typeref:struct:_USB_VendorReq
-usb_vendor_req_buf	include/drv_types.h	/^	u8 *usb_vendor_req_buf;$/;"	m	struct:dvobj_priv
-usb_vendor_req_mutex	include/drv_types.h	/^	_mutex  usb_vendor_req_mutex;$/;"	m	struct:dvobj_priv
-usb_wifi_host	platform/platform_ARM_SUNxI_usb.c	/^static int usb_wifi_host = 2;$/;"	v	file:
-usb_write_mem_complete	include/usb_ops_linux.h	46;"	d
-usb_write_port_complete	include/usb_ops_linux.h	47;"	d
-usbss_enable	include/drv_types.h	/^	u8	usbss_enable;\/* 0:disable,1:enable *\/$/;"	m	struct:registry_priv
-use_count	include/rtw_br_ext.h	/^	atomic_t						use_count;$/;"	m	struct:nat25_network_db_entry
-use_ctrl_frame_antdiv	hal/phydm/phydm_antdiv.h	/^	BOOLEAN	use_ctrl_frame_antdiv;$/;"	m	struct:_FAST_ANTENNA_TRAINNING_
-use_max_len	include/rtl8188e_xmit.h	/^	u32 use_max_len:1;$/;"	m	struct:txdesc_88e
-use_max_len	include/rtl8192e_xmit.h	/^	u32 use_max_len:1;$/;"	m	struct:txdescriptor_8192e
-use_max_len	include/rtl8812a_xmit.h	/^	u32 use_max_len:1;$/;"	m	struct:txdescriptor_8812
-use_max_len	include/rtl8821a_xmit.h	/^	u32 use_max_len:1;$/;"	m	struct:txdescriptor_8821a
-use_path_a_as_default_ant	hal/phydm/phydm_pathdiv.h	/^	u1Byte	use_path_a_as_default_ant;$/;"	m	struct:_ODM_PATH_DIVERSITY_
-used	include/drv_types.h	/^	struct macid_bmp used;$/;"	m	struct:macid_ctl_t	typeref:struct:macid_ctl_t::macid_bmp
-used	include/drv_types.h	/^	struct sec_cam_bmp used;$/;"	m	struct:cam_ctl_t	typeref:struct:cam_ctl_t::sec_cam_bmp
-used	include/rtw_beamforming.h	/^	u8 used;	\/* _TRUE\/_FALSE *\/$/;"	m	struct:beamformee_entry
-used	include/rtw_beamforming.h	/^	u8 used;$/;"	m	struct:beamformer_entry
-used_len	os_dep/linux/rtw_android.c	/^	int used_len;$/;"	m	struct:android_wifi_priv_cmd	file:
-used_len	os_dep/linux/rtw_android.c	/^	int used_len;$/;"	m	struct:compat_android_wifi_priv_cmd	file:
-user_position	hal/phydm/phydm_beamforming.h	/^	u1Byte				user_position[16];$/;"	m	struct:_RT_BEAMFORMER_ENTRY
-user_position	hal/phydm/phydm_beamforming.h	/^	u1Byte	user_position[16];$/;"	m	struct:_RT_BEAMFORMEE_ENTRY
-user_position	include/rtw_beamforming.h	/^	u8 user_position[16];$/;"	m	struct:beamformee_entry
-user_position	include/rtw_beamforming.h	/^	u8 user_position[16];$/;"	m	struct:beamformer_entry
-userate	include/rtl8188e_xmit.h	/^	u32 userate:1;$/;"	m	struct:txdesc_88e
-userate	include/rtl8192e_xmit.h	/^	u32 userate:1;$/;"	m	struct:txdescriptor_8192e
-userate	include/rtl8812a_xmit.h	/^	u32 userate:1;$/;"	m	struct:txdescriptor_8812
-userate	include/rtl8821a_xmit.h	/^	u32 userate:1;$/;"	m	struct:txdescriptor_8821a
-users	include/osdep_service_bsd.h	/^	atomic_t		users;$/;"	m	struct:sk_buff
-uuid	include/rtw_mlme.h	/^	u8						uuid[16];					\/* UUID *\/$/;"	m	struct:wifidirect_info
-uuid_str2bin	os_dep/linux/ioctl_linux.c	/^static int uuid_str2bin(const char *str, u8 *bin)$/;"	f	file:
-uwps_num	include/rtw_mi.h	/^	u8 uwps_num;		\/*WIFI_UNDER_WPS*\/$/;"	m	struct:mi_state
-val	include/rtw_io.h	/^	volatile u32	val;$/;"	m	struct:io_req
-val	include/rtw_security.h	/^	u64	val;$/;"	m	union:pn48
-valid	hal/phydm/phydm_noisemonitor.h	/^	u1Byte				valid[MAX_RF_PATH];$/;"	m	struct:noise_level
-valid	include/sta_info.h	/^	u8       valid;$/;"	m	struct:rtw_wlan_acl_node
-valid_cnt	hal/phydm/phydm_noisemonitor.h	/^	u1Byte				valid_cnt[MAX_RF_PATH];$/;"	m	struct:noise_level
-validate_80211w_mgmt	core/rtw_recv.c	/^static sint validate_80211w_mgmt(_adapter *adapter, union recv_frame *precv_frame)$/;"	f	file:
-validate_mp_recv_frame	core/rtw_recv.c	/^int validate_mp_recv_frame(_adapter *adapter, union recv_frame *precv_frame)$/;"	f
-validate_recv_ctrl_frame	core/rtw_recv.c	/^sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)$/;"	f
-validate_recv_data_frame	core/rtw_recv.c	/^sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)$/;"	f
-validate_recv_frame	core/rtw_recv.c	/^sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame)$/;"	f
-validate_recv_mgnt_frame	core/rtw_recv.c	/^sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)$/;"	f
-value	hal/phydm/phydm_noisemonitor.h	/^	u1Byte				value[MAX_RF_PATH];$/;"	m	struct:noise_level
-value	hal/phydm/phydm_rainfo.h	/^	u1Byte	value;$/;"	m	struct:_Rate_Adaptive_Table_
-value	include/HalPwrSeqCmd.h	/^	u8 value;$/;"	m	struct:_WL_PWR_CFG_
-value	include/hal_data.h	/^	u32	value;$/;"	m	struct:_BB_INIT_REGISTER
-value	include/ieee80211.h	/^			u32 value;$/;"	m	struct:ieee_param::__anon73::__anon74
-value	include/rtw_cmd.h	/^	u32	value;$/;"	m	struct:readRF_rsp
-value	include/rtw_cmd.h	/^	u32	value;$/;"	m	struct:writeRF_parm
-value	include/rtw_cmd.h	/^	u8	value;$/;"	m	struct:readBB_rsp
-value	include/rtw_cmd.h	/^	u8	value;$/;"	m	struct:readTSSI_rsp
-value	include/rtw_cmd.h	/^	u8	value;$/;"	m	struct:writeBB_parm
-value	include/rtw_iol.h	/^	u32 value;$/;"	m	struct:_io_offload_cmd
-value	include/rtw_iol.h	/^	u32 value;$/;"	m	struct:cmd_cmp
-value	include/rtw_mp.h	/^	u16	value;$/;"	m	struct:_IOCMD_STRUCT_
-value	include/rtw_mp.h	/^	u32 value;$/;"	m	struct:bb_reg_param
-value	include/rtw_mp.h	/^	u32 value;$/;"	m	struct:rf_reg_param
-value	include/rtw_mp_ioctl.h	/^	u16 value;$/;"	m	struct:_EEPROM_RW_PARAM
-value	include/rtw_mp_ioctl.h	/^	u16 value;$/;"	m	struct:eeprom_rw_param
-value	include/rtw_mp_ioctl.h	/^	u32 value;$/;"	m	struct:_RW_REG
-value	include/rtw_mp_ioctl.h	/^	u32 value;$/;"	m	struct:bbreg_param
-value	include/rtw_mp_ioctl.h	/^	u32 value;$/;"	m	struct:rwreg_param
-value	include/rtw_xmit.h	/^	unsigned int value[TXDESC_SIZE >> 2];$/;"	m	union:txdesc
-value_16	hal/phydm/phydm_rainfo.h	/^	u2Byte	value_16;$/;"	m	struct:_Rate_Adaptive_Table_
-variable	include/ieee80211_ext.h	/^					u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon35
-variable	include/ieee80211_ext.h	/^					u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon39
-variable	include/ieee80211_ext.h	/^					u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon40
-variable	include/ieee80211_ext.h	/^					u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon20
-variable	include/ieee80211_ext.h	/^					u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon24
-variable	include/ieee80211_ext.h	/^					u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon25
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon27
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon29
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon30
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon26::__anon31
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon11
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon12
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon13
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon15
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon16
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon17
-variable	include/ieee80211_ext.h	/^			u8 variable[0];$/;"	m	struct:ieee80211_mgmt::__anon8::__anon9
-variable	include/rtw_mp_ioctl.h	/^	u32 variable;$/;"	m	struct:_DR_VARIABLE_STRUCT_
-vcs	include/rtw_xmit.h	/^	u8	vcs;$/;"	m	struct:xmit_priv
-vcs_mode	include/rtw_xmit.h	/^	u8	vcs_mode;	\/* virtual carrier sense method *\/$/;"	m	struct:pkt_attrib
-vcs_setting	include/rtw_xmit.h	/^	u8   vcs_setting;$/;"	m	struct:xmit_priv
-vcs_stbc	include/rtl8188e_xmit.h	/^	u32 vcs_stbc:2;$/;"	m	struct:txdesc_88e
-vcs_stbc	include/rtl8192e_xmit.h	/^	u32 vcs_stbc:2;$/;"	m	struct:txdescriptor_8192e
-vcs_stbc	include/rtl8812a_xmit.h	/^	u32 vcs_stbc:2;$/;"	m	struct:txdescriptor_8812
-vcs_stbc	include/rtl8821a_xmit.h	/^	u32 vcs_stbc:2;$/;"	m	struct:txdescriptor_8821a
-vcs_type	include/drv_types.h	/^	u8	vcs_type;\/* RTS\/CTS, CTS-to-self *\/$/;"	m	struct:registry_priv
-vcs_type	include/rtw_xmit.h	/^	u8	vcs_type;$/;"	m	struct:xmit_priv
-vendor_ht_cap	include/ieee80211.h	/^	u8 *vendor_ht_cap;$/;"	m	struct:rtw_ieee802_11_elems
-vendor_ht_cap_len	include/ieee80211.h	/^	u8 vendor_ht_cap_len;$/;"	m	struct:rtw_ieee802_11_elems
-vendor_ie	include/rtw_mlme.h	/^	u8 vendor_ie[WLAN_MAX_VENDOR_IE_NUM][WLAN_MAX_VENDOR_IE_LEN];$/;"	m	struct:mlme_priv
-vendor_ie_mask	include/rtw_mlme.h	/^	u32 vendor_ie_mask[WLAN_MAX_VENDOR_IE_NUM];$/;"	m	struct:mlme_priv
-vendor_ielen	include/rtw_mlme.h	/^	u32 vendor_ielen[WLAN_MAX_VENDOR_IE_NUM];$/;"	m	struct:mlme_priv
-version	hal/btc/HalBtcOutSrc.h	/^	u1Byte	version;$/;"	m	struct:_COL_C2H_IND
-version	include/ieee80211.h	/^	u8 version;$/;"	m	struct:eapol
-version	include/ieee80211_ext.h	/^	u8 version;$/;"	m	struct:wme_parameter_element
-version	include/ieee80211_ext.h	/^	u8 version[2]; \/* little endian *\/$/;"	m	struct:rsn_ie_hdr
-version	include/ieee80211_ext.h	/^	u8 version[2]; \/* little endian *\/$/;"	m	struct:wpa_ie_hdr
-version	include/ip.h	/^		version:4;$/;"	m	struct:iphdr
-version	os_dep/linux/rtw_android.c	/^	char version;$/;"	m	struct:cmd_tlv	file:
-vga	hal/phydm/phydm_hwconfig.h	/^	u1Byte		vga:5;$/;"	m	struct:_Phy_Status_Rpt_Jaguar2_Type0
-vht_cap	include/rtw_vht.h	/^	u8	vht_cap[32];$/;"	m	struct:vht_priv
-vht_capabilities	include/ieee80211.h	/^	u8 *vht_capabilities;$/;"	m	struct:rtw_ieee802_11_elems
-vht_capabilities_len	include/ieee80211.h	/^	u8 vht_capabilities_len;$/;"	m	struct:rtw_ieee802_11_elems
-vht_en	include/drv_types.h	/^	u8 vht_en[MACID_NUM_SW_LIMIT];$/;"	m	struct:macid_ctl_t
-vht_enable	include/drv_types.h	/^	u8	vht_enable; \/* 0:disable, 1:enable, 2:auto *\/$/;"	m	struct:registry_priv
-vht_highest_rate	include/rtw_vht.h	/^	u8	vht_highest_rate;$/;"	m	struct:vht_priv
-vht_mcs_map	include/rtw_vht.h	/^	u8	vht_mcs_map[2];$/;"	m	struct:vht_priv
-vht_op_mode_notify	include/ieee80211.h	/^	u8 *vht_op_mode_notify;$/;"	m	struct:rtw_ieee802_11_elems
-vht_op_mode_notify	include/rtw_vht.h	/^	u8	vht_op_mode_notify;$/;"	m	struct:vht_priv
-vht_op_mode_notify_len	include/ieee80211.h	/^	u8 vht_op_mode_notify_len;$/;"	m	struct:rtw_ieee802_11_elems
-vht_operation	include/ieee80211.h	/^	u8 *vht_operation;$/;"	m	struct:rtw_ieee802_11_elems
-vht_operation_len	include/ieee80211.h	/^	u8 vht_operation_len;$/;"	m	struct:rtw_ieee802_11_elems
-vht_option	include/rtw_vht.h	/^	u8	vht_option;$/;"	m	struct:vht_priv
-vht_priv	include/rtw_vht.h	/^struct vht_priv {$/;"	s
-vht_rate_sel	include/drv_types.h	/^	u8	vht_rate_sel;$/;"	m	struct:registry_priv
-vhtpriv	include/rtw_mlme.h	/^	struct vht_priv	vhtpriv;$/;"	m	struct:mlme_priv	typeref:struct:mlme_priv::vht_priv
-vhtpriv	include/sta_info.h	/^	struct vht_priv	vhtpriv;$/;"	m	struct:sta_info	typeref:struct:sta_info::vht_priv
-vi_pending	include/rtw_xmit.h	/^	_queue	vi_pending;$/;"	m	struct:xmit_priv
-vi_q	include/rtw_xmit.h	/^	struct tx_servq	vi_q;			\/* priority == 4,5 *\/$/;"	m	struct:sta_xmit_priv	typeref:struct:sta_xmit_priv::tx_servq
-vidok	include/drv_types.h	/^	u32 vidok;$/;"	m	struct:int_logs
-viq_cnt	include/rtw_xmit.h	/^	int viq_cnt;$/;"	m	struct:xmit_priv
-virtual_iface_num	include/drv_types.h	/^	u8 virtual_iface_num;$/;"	m	struct:registry_priv
-vlan_tci	include/osdep_service_bsd.h	/^	u16			vlan_tci;$/;"	m	struct:sk_buff
-vo_pending	include/rtw_xmit.h	/^	_queue	vo_pending;$/;"	m	struct:xmit_priv
-vo_q	include/rtw_xmit.h	/^	struct tx_servq	vo_q;			\/* priority == 6,7 *\/$/;"	m	struct:sta_xmit_priv	typeref:struct:sta_xmit_priv::tx_servq
-vodok	include/drv_types.h	/^	u32 vodok;$/;"	m	struct:int_logs
-voice_over_HOGP	hal/btc/halbtc8723d1ant.h	/^	boolean				voice_over_HOGP;$/;"	m	struct:coex_sta_8723d_1ant
-voice_over_HOGP	hal/btc/halbtc8723d2ant.h	/^	boolean				voice_over_HOGP;$/;"	m	struct:coex_sta_8723d_2ant
-voq_cnt	include/rtw_xmit.h	/^	int voq_cnt;$/;"	m	struct:xmit_priv
-vrtl_carrier_sense	include/drv_types.h	/^	u8	vrtl_carrier_sense;\/* Enable, Disable, Auto *\/$/;"	m	struct:registry_priv
-w0	include/rtw_cmd.h	/^	u32	w0;$/;"	m	struct:geth2clbk_rsp
-w0	include/rtw_cmd.h	/^	u32	w0;$/;"	m	struct:seth2clbk_parm
-w0	include/rtw_event.h	/^	unsigned int	w0;$/;"	m	struct:c2hlbk_event
-w1	include/rtw_cmd.h	/^	u32	w1;$/;"	m	struct:geth2clbk_rsp
-w1	include/rtw_cmd.h	/^	u32	w1;$/;"	m	struct:seth2clbk_parm
-w1	include/rtw_event.h	/^	unsigned int	w1;$/;"	m	struct:c2hlbk_event
-wIndex	include/rtw_mp_ioctl.h	/^	u16	wIndex;$/;"	m	struct:_USB_VendorReq
-wLength	include/rtw_mp_ioctl.h	/^	u16	wLength;$/;"	m	struct:_USB_VendorReq
-wValue	include/rtw_mp_ioctl.h	/^	u16	wValue;$/;"	m	struct:_USB_VendorReq
-w_BFee_Client	hal/phydm/phydm_antdiv.h	/^	BOOLEAN w_BFee_Client[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_BF_DIV_COEX_
-w_BFer_Client	hal/phydm/phydm_antdiv.h	/^	BOOLEAN w_BFer_Client[ODM_ASSOCIATE_ENTRY_NUM];$/;"	m	struct:_BF_DIV_COEX_
-wa_halbtc8723a1ant_MonitorC2h	hal/btc/HalBtc8723a1Ant.c	/^wa_halbtc8723a1ant_MonitorC2h($/;"	f
-wa_halbtc8723a2ant_MonitorC2h	hal/btc/HalBtc8723a2Ant.c	/^wa_halbtc8723a2ant_MonitorC2h($/;"	f
-wait_dcts	include/rtl8188e_xmit.h	/^	u32 wait_dcts:1;$/;"	m	struct:txdesc_88e
-wait_dcts	include/rtl8192e_xmit.h	/^	u32 wait_dcts:1;$/;"	m	struct:txdescriptor_8192e
-wait_dcts	include/rtl8812a_xmit.h	/^	u32 wait_dcts:1;$/;"	m	struct:txdescriptor_8812
-wait_eeprom_cmd_done	core/rtw_eeprom.c	/^u16 wait_eeprom_cmd_done(_adapter *padapter)$/;"	f
-wait_halmac_event	hal/hal_halmac.c	/^static int wait_halmac_event(struct dvobj_priv *d, HALMAC_FEATURE_ID id)$/;"	f	file:
-wait_ms	core/rtw_mi.c	/^	int wait_ms;$/;"	m	struct:nulldata_param	file:
-wakeup_q	include/sta_info.h	/^	_queue wakeup_q;$/;"	m	struct:sta_priv
-wakeup_reason	include/hal_intf.h	/^	unsigned int wakeup_reason;$/;"	m	struct:wowlan_ioctl_param
-wakeup_sta_to_xmit	core/rtw_xmit.c	/^void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)$/;"	f
-wapiBKID	include/rtw_wapi.h	/^	RT_WAPI_BKID		wapiBKID[WAPI_MAX_BKID_NUM];$/;"	m	struct:_RT_WAPI_T
-wapiBKIDIdleList	include/rtw_wapi.h	/^	struct list_head		wapiBKIDIdleList;$/;"	m	struct:_RT_WAPI_T	typeref:struct:_RT_WAPI_T::list_head
-wapiBKIDStoreList	include/rtw_wapi.h	/^	struct list_head		wapiBKIDStoreList;$/;"	m	struct:_RT_WAPI_T	typeref:struct:_RT_WAPI_T::list_head
-wapiCamEntry	include/rtw_wapi.h	/^	RT_WAPI_CAM_ENTRY	wapiCamEntry[WAPI_CAM_ENTRY_NUM];$/;"	m	struct:_RT_WAPI_T
-wapiIE	include/rtw_wapi.h	/^	u8				wapiIE[256];$/;"	m	struct:_RT_WAPI_T
-wapiIELength	include/rtw_wapi.h	/^	u8				wapiIELength;$/;"	m	struct:_RT_WAPI_T
-wapiInfo	include/drv_types.h	/^	RT_WAPI_T	wapiInfo;$/;"	m	struct:_ADAPTER
-wapiMsk	include/rtw_wapi.h	/^	RT_WAPI_KEY		      wapiMsk;$/;"	m	struct:_RT_WAPI_STA_INFO
-wapiMskUpdate	include/rtw_wapi.h	/^	RT_WAPI_KEY		      wapiMskUpdate;$/;"	m	struct:_RT_WAPI_STA_INFO
-wapiSTAIdleList	include/rtw_wapi.h	/^	struct list_head		wapiSTAIdleList;$/;"	m	struct:_RT_WAPI_T	typeref:struct:_RT_WAPI_T::list_head
-wapiSTAUsedList	include/rtw_wapi.h	/^	struct list_head		wapiSTAUsedList;$/;"	m	struct:_RT_WAPI_T	typeref:struct:_RT_WAPI_T::list_head
-wapiSeqnumAndFragNum	include/rtw_wapi.h	/^	u16				wapiSeqnumAndFragNum;$/;"	m	struct:_RT_WAPI_T
-wapiSta	include/rtw_wapi.h	/^	RT_WAPI_STA_INFO	wapiSta[WAPI_MAX_STAINFO_NUM];$/;"	m	struct:_RT_WAPI_T
-wapiTxMsk	include/rtw_wapi.h	/^	RT_WAPI_KEY		      wapiTxMsk;$/;"	m	struct:_RT_WAPI_T
-wapiUsk	include/rtw_wapi.h	/^	RT_WAPI_KEY		      wapiUsk;$/;"	m	struct:_RT_WAPI_STA_INFO
-wapiUskUpdate	include/rtw_wapi.h	/^	RT_WAPI_KEY		      wapiUskUpdate;$/;"	m	struct:_RT_WAPI_STA_INFO
-wapi_debug_component	core/rtw_wapi.c	/^u32 wapi_debug_component =$/;"	v
-watchdog_count	include/rtw_mlme.h	/^	u8					watchdog_count;$/;"	m	struct:tdls_info
-wdev	include/rtw_cmd.h	/^	struct wireless_dev *wdev;$/;"	m	struct:p2p_roch_parm	typeref:struct:p2p_roch_parm::wireless_dev
-wdev_data	include/drv_types.h	/^	struct rtw_wdev_priv wdev_data;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::rtw_wdev_priv
-wdev_to_ndev	os_dep/linux/ioctl_cfg80211.h	161;"	d
-wdev_to_wiphy	os_dep/linux/ioctl_cfg80211.h	162;"	d
-wdinfo	include/drv_types.h	/^	struct wifidirect_info	wdinfo;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::wifidirect_info
-wend_b	include/rtw_recv.h	/^	u16 wend_b;$/;"	m	struct:recv_reorder_ctrl
-wep_sw_dec_cnt_bc	include/rtw_security.h	/^	u64 wep_sw_dec_cnt_bc;$/;"	m	struct:security_priv
-wep_sw_dec_cnt_mc	include/rtw_security.h	/^	u64 wep_sw_dec_cnt_mc;$/;"	m	struct:security_priv
-wep_sw_dec_cnt_uc	include/rtw_security.h	/^	u64 wep_sw_dec_cnt_uc;$/;"	m	struct:security_priv
-wep_sw_enc_cnt_bc	include/rtw_security.h	/^	u64 wep_sw_enc_cnt_bc;$/;"	m	struct:security_priv
-wep_sw_enc_cnt_mc	include/rtw_security.h	/^	u64 wep_sw_enc_cnt_mc;$/;"	m	struct:security_priv
-wep_sw_enc_cnt_uc	include/rtw_security.h	/^	u64 wep_sw_enc_cnt_uc;$/;"	m	struct:security_priv
-wfd_assoc_req_ie	include/rtw_mlme.h	/^	u8 *wfd_assoc_req_ie;$/;"	m	struct:mlme_priv
-wfd_assoc_req_ie_len	include/rtw_mlme.h	/^	u32 wfd_assoc_req_ie_len;$/;"	m	struct:mlme_priv
-wfd_assoc_resp_ie	include/rtw_mlme.h	/^	u8 *wfd_assoc_resp_ie;$/;"	m	struct:mlme_priv
-wfd_assoc_resp_ie_len	include/rtw_mlme.h	/^	u32 wfd_assoc_resp_ie_len;$/;"	m	struct:mlme_priv
-wfd_beacon_ie	include/rtw_mlme.h	/^	u8 *wfd_beacon_ie;$/;"	m	struct:mlme_priv
-wfd_beacon_ie_len	include/rtw_mlme.h	/^	u32 wfd_beacon_ie_len;$/;"	m	struct:mlme_priv
-wfd_device_type	include/rtw_mlme.h	/^	u8							wfd_device_type;	\/*	WFD Device Type *\/$/;"	m	struct:wifi_display_info
-wfd_enable	include/rtw_mlme.h	/^	u16							wfd_enable;			\/*	Eanble\/Disable the WFD function. *\/$/;"	m	struct:wifi_display_info
-wfd_go_probe_resp_ie	include/rtw_mlme.h	/^	u8 *wfd_go_probe_resp_ie;		\/* for GO *\/$/;"	m	struct:mlme_priv
-wfd_go_probe_resp_ie_len	include/rtw_mlme.h	/^	u32 wfd_go_probe_resp_ie_len;	\/* for GO *\/$/;"	m	struct:mlme_priv
-wfd_ie_tdls	core/rtw_tdls.c	/^void wfd_ie_tdls(_adapter *padapter, u8 *pframe, u32 *pktlen)$/;"	f
-wfd_info	include/drv_types.h	/^	struct wifi_display_info wfd_info;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::wifi_display_info
-wfd_info	include/rtw_mlme.h	/^	struct wifi_display_info		*wfd_info;$/;"	m	struct:tdls_info	typeref:struct:tdls_info::wifi_display_info
-wfd_info	include/rtw_mlme.h	/^	struct wifi_display_info		*wfd_info;$/;"	m	struct:wifidirect_info	typeref:struct:wifidirect_info::wifi_display_info
-wfd_pc	include/rtw_mlme.h	/^	u8							wfd_pc;				\/*	WFD preferred connection *\/$/;"	m	struct:wifi_display_info
-wfd_probe_req_ie	include/rtw_mlme.h	/^	u8 *wfd_probe_req_ie;$/;"	m	struct:mlme_priv
-wfd_probe_req_ie_len	include/rtw_mlme.h	/^	u32 wfd_probe_req_ie_len;$/;"	m	struct:mlme_priv
-wfd_probe_resp_ie	include/rtw_mlme.h	/^	u8 *wfd_probe_resp_ie;$/;"	m	struct:mlme_priv
-wfd_probe_resp_ie_len	include/rtw_mlme.h	/^	u32 wfd_probe_resp_ie_len;$/;"	m	struct:mlme_priv
-wfd_st_match_rule	core/rtw_mlme.c	/^static bool wfd_st_match_rule(_adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)$/;"	f	file:
-wfd_st_reg	core/rtw_mlme.c	/^static struct st_register wfd_st_reg = {$/;"	v	typeref:struct:st_register	file:
-wfd_tdls_enable	include/rtw_mlme.h	/^	u8						wfd_tdls_enable;			\/*	Flag to enable or disable the TDLS by WFD Sigma *\/$/;"	m	struct:wifidirect_info
-wfd_tdls_weaksec	include/rtw_mlme.h	/^	u8						wfd_tdls_weaksec;			\/*	Flag to enable or disable the weak security function for TDLS by WFD Sigma *\/$/;"	m	struct:wifidirect_info
-wheader_len	include/rtl8821a_xmit.h	/^	u32 wheader_len:4;$/;"	m	struct:txdescriptor_8821a
-wi_act_func	include/rtw_mp.h	/^typedef void(*wi_act_func)(void *padapter);$/;"	t
-wi_cntx	include/rtw_mp.h	/^	struct mp_wi_cntx wi_cntx;$/;"	m	struct:mp_priv	typeref:struct:mp_priv::mp_wi_cntx
-widi_enable	include/rtw_mlme.h	/^	u8	widi_enable;$/;"	m	struct:mlme_priv
-widi_state	include/rtw_mlme.h	/^	int	widi_state;$/;"	m	struct:mlme_priv
-width	include/rtw_mp_ioctl.h	/^	u32 width;$/;"	m	struct:_RW_REG
-width	include/rtw_mp_ioctl.h	/^	u32 width;$/;"	m	struct:rwreg_param
-wifiChnlInfo	hal/btc/HalBtc8723a1Ant.h	/^	u1Byte		wifiChnlInfo[3];$/;"	m	struct:_COEX_DM_8723A_1ANT
-wifiChnlInfo	hal/btc/HalBtc8723a2Ant.h	/^	u1Byte		wifiChnlInfo[3];$/;"	m	struct:_COEX_DM_8723A_2ANT
-wifi_add_dev	os_dep/linux/rtw_android.c	/^static int wifi_add_dev(void)$/;"	f	file:
-wifi_chnl_info	hal/btc/HalBtc8192e1Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8192e_1ant
-wifi_chnl_info	hal/btc/HalBtc8192e2Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8192e_2ant
-wifi_chnl_info	hal/btc/HalBtc8703b1Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8703b_1ant
-wifi_chnl_info	hal/btc/HalBtc8723b1Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8723b_1ant
-wifi_chnl_info	hal/btc/HalBtc8723b2Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8723b_2ant
-wifi_chnl_info	hal/btc/HalBtc8812a1Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8812a_1ant
-wifi_chnl_info	hal/btc/HalBtc8812a2Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8812a_2ant
-wifi_chnl_info	hal/btc/HalBtc8821a1Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8821a_1ant
-wifi_chnl_info	hal/btc/HalBtc8821a2Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8821a_2ant
-wifi_chnl_info	hal/btc/HalBtc8821aCsr2Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8821a_csr_2ant
-wifi_chnl_info	hal/btc/HalBtc8822b1Ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8822b_1ant
-wifi_chnl_info	hal/btc/halbtc8723d1ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8723d_1ant
-wifi_chnl_info	hal/btc/halbtc8723d2ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8723d_2ant
-wifi_chnl_info	hal/btc/halbtc8821c1ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8821c_1ant
-wifi_chnl_info	hal/btc/halbtc8821c2ant.h	/^	u8		wifi_chnl_info[3];$/;"	m	struct:coex_dm_8821c_2ant
-wifi_coex_thres	hal/btc/halbtc8723d2ant.h	/^	u8					wifi_coex_thres;$/;"	m	struct:coex_sta_8723d_2ant
-wifi_coex_thres	hal/btc/halbtc8821c2ant.h	/^	u8					wifi_coex_thres;$/;"	m	struct:coex_sta_8821c_2ant
-wifi_coex_thres2	hal/btc/halbtc8723d2ant.h	/^	u8					wifi_coex_thres2;$/;"	m	struct:coex_sta_8723d_2ant
-wifi_coex_thres2	hal/btc/halbtc8821c2ant.h	/^	u8					wifi_coex_thres2;$/;"	m	struct:coex_sta_8821c_2ant
-wifi_configure_gpio	os_dep/linux/rtw_android.c	/^int wifi_configure_gpio(void)$/;"	f
-wifi_control_data	os_dep/linux/rtw_android.c	/^static struct wifi_platform_data *wifi_control_data = NULL;$/;"	v	typeref:struct:wifi_platform_data	file:
-wifi_control_sem	os_dep/linux/rtw_android.c	/^static struct semaphore wifi_control_sem;$/;"	v	typeref:struct:semaphore	file:
-wifi_del_dev	os_dep/linux/rtw_android.c	/^static void wifi_del_dev(void)$/;"	f	file:
-wifi_device	os_dep/linux/rtw_android.c	/^static struct platform_driver wifi_device = {$/;"	v	typeref:struct:platform_driver	file:
-wifi_device_legacy	os_dep/linux/rtw_android.c	/^static struct platform_driver wifi_device_legacy = {$/;"	v	typeref:struct:platform_driver	file:
-wifi_display_info	include/rtw_mlme.h	/^struct wifi_display_info {$/;"	s
-wifi_free_gpio	os_dep/linux/rtw_android.c	/^void wifi_free_gpio(unsigned int gpio)$/;"	f
-wifi_get_country_code	os_dep/linux/rtw_android.c	/^void *wifi_get_country_code(char *ccode)$/;"	f
-wifi_get_irq_number	os_dep/linux/rtw_android.c	/^int wifi_get_irq_number(unsigned long *irq_flags_ptr)$/;"	f
-wifi_get_mac_addr	os_dep/linux/rtw_android.c	/^int wifi_get_mac_addr(unsigned char *buf)$/;"	f
-wifi_irqres	os_dep/linux/rtw_android.c	/^static struct resource *wifi_irqres = NULL;$/;"	v	typeref:struct:resource	file:
-wifi_is_high_pri_task	hal/btc/HalBtc8192e1Ant.h	/^	boolean					wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8192e_1ant
-wifi_is_high_pri_task	hal/btc/HalBtc8703b1Ant.h	/^	boolean					wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8703b_1ant
-wifi_is_high_pri_task	hal/btc/HalBtc8723b1Ant.h	/^	boolean					wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8723b_1ant
-wifi_is_high_pri_task	hal/btc/HalBtc8812a1Ant.h	/^	boolean					wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8812a_1ant
-wifi_is_high_pri_task	hal/btc/HalBtc8821a1Ant.h	/^	boolean					wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8821a_1ant
-wifi_is_high_pri_task	hal/btc/HalBtc8822b1Ant.h	/^	boolean					wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8822b_1ant
-wifi_is_high_pri_task	hal/btc/halbtc8723d1ant.h	/^	boolean				wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8723d_1ant
-wifi_is_high_pri_task	hal/btc/halbtc8723d2ant.h	/^	boolean				wifi_is_high_pri_task;$/;"	m	struct:coex_sta_8723d_2ant
-wifi_is_high_pri_task	hal/btc/halbtc8821c1ant.h	/^	boolean					wifi_is_high_pri_task;		\/* Add for win8.1 page out issue *\/$/;"	m	struct:coex_sta_8821c_1ant
-wifi_is_high_pri_task	hal/btc/halbtc8821c2ant.h	/^	boolean				wifi_is_high_pri_task;$/;"	m	struct:coex_sta_8821c_2ant
-wifi_leave	include/rtw_btcoex.h	88;"	d
-wifi_mac_hash	include/sta_info.h	/^__inline static u32 wifi_mac_hash(u8 *mac)$/;"	f
-wifi_probe	os_dep/linux/rtw_android.c	/^static int wifi_probe(struct platform_device *pdev)$/;"	f	file:
-wifi_remove	os_dep/linux/rtw_android.c	/^static int wifi_remove(struct platform_device *pdev)$/;"	f	file:
-wifi_resume	os_dep/linux/rtw_android.c	/^static int wifi_resume(struct platform_device *pdev)$/;"	f	file:
-wifi_set_carddetect	os_dep/linux/rtw_android.c	/^static int wifi_set_carddetect(int on)$/;"	f	file:
-wifi_set_power	os_dep/linux/rtw_android.c	/^int wifi_set_power(int on, unsigned long msec)$/;"	f
-wifi_shutdown	os_dep/linux/rtw_android.c	/^static void wifi_shutdown(struct platform_device *pdev)$/;"	f	file:
-wifi_sockaddr	include/rtw_btcoex.h	/^	struct sockaddr_in wifi_sockaddr; \/*wifi socket*\/$/;"	m	struct:bt_coex_info	typeref:struct:bt_coex_info::sockaddr_in
-wifi_spec	include/drv_types.h	/^	u8	wifi_spec;\/* !turbo_mode *\/$/;"	m	struct:registry_priv
-wifi_suspend	os_dep/linux/rtw_android.c	/^static int wifi_suspend(struct platform_device *pdev, pm_message_t state)$/;"	f	file:
-wifidirect_info	include/rtw_mlme.h	/^struct wifidirect_info {$/;"	s
-wifirate2_ratetbl_inx	core/rtw_wlan_util.c	/^int wifirate2_ratetbl_inx(unsigned char rate)$/;"	f
-wiphy	include/drv_types.h	/^	struct wiphy *wiphy;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::wiphy
-wiphy	include/drv_types.h	/^	struct wiphy *wiphy;$/;"	m	struct:dvobj_priv	typeref:struct:dvobj_priv::wiphy
-wiphy_to_adapter	os_dep/linux/ioctl_cfg80211.h	180;"	d
-wiphy_to_adapter	os_dep/linux/ioctl_cfg80211.h	182;"	d
-wiphy_to_dvobj	os_dep/linux/ioctl_cfg80211.h	178;"	d
-wiphy_to_pd_wdev	os_dep/linux/ioctl_cfg80211.h	186;"	d
-wiphy_to_pd_wdev	os_dep/linux/ioctl_cfg80211.h	188;"	d
-wireless_mode	include/drv_types.h	/^	u8	wireless_mode;\/* A, B, G, auto *\/$/;"	m	struct:registry_priv
-wireless_mode	include/sta_info.h	/^	u8	wireless_mode;	\/* NETWORK_TYPE *\/$/;"	m	struct:sta_info
-with_extenal_ant_switch	hal/phydm/phydm.h	/^	u1Byte			with_extenal_ant_switch;$/;"	m	struct:DM_Out_Source_Dynamic_Mechanism_Structure
-with_extenal_ant_switch	include/hal_data.h	/^	u8	with_extenal_ant_switch;$/;"	m	struct:hal_com_data
-wkitm_lock	include/rtw_mp.h	/^	_lock wkitm_lock;$/;"	m	struct:mp_priv
-wl_android_prealloc	os_dep/linux/rtw_android.c	/^void *wl_android_prealloc(int section, unsigned long size)$/;"	f
-wl_cfgvendor_enable_full_scan_result	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_enable_full_scan_result(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_gscan_get_batch_results	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_gscan_get_batch_results(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_gscan_get_capabilities	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_gscan_get_capabilities(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_gscan_get_channel_list	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_gscan_get_channel_list(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_hotlist_cfg	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_hotlist_cfg(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_initiate_gscan	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_initiate_gscan(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_priv_string_handler	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_priv_string_handler(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_rtt_cancel_config	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_rtt_cancel_config(struct wiphy *wiphy, struct wireless_dev *wdev,$/;"	f	file:
-wl_cfgvendor_rtt_evt	os_dep/linux/rtw_cfgvendor.c	/^void wl_cfgvendor_rtt_evt(void *ctx, void *rtt_data)$/;"	f
-wl_cfgvendor_rtt_get_capability	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_rtt_get_capability(struct wiphy *wiphy, struct wireless_dev *wdev,$/;"	f	file:
-wl_cfgvendor_rtt_set_config	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_rtt_set_config(struct wiphy *wiphy, struct wireless_dev *wdev,$/;"	f	file:
-wl_cfgvendor_send_hotlist_event	os_dep/linux/rtw_cfgvendor.c	/^int wl_cfgvendor_send_hotlist_event(struct wiphy *wiphy,$/;"	f
-wl_cfgvendor_set_batch_scan_cfg	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_set_batch_scan_cfg(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_set_scan_cfg	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_set_scan_cfg(struct wiphy *wiphy,$/;"	f	file:
-wl_cfgvendor_significant_change_cfg	os_dep/linux/rtw_cfgvendor.c	/^static int wl_cfgvendor_significant_change_cfg(struct wiphy *wiphy,$/;"	f	file:
-wl_func	include/hal_data.h	/^	u8 wl_func;		\/* value of WL_FUNC_XXX *\/$/;"	m	struct:hal_spec_t
-wl_noisy_level	hal/btc/halbtc8723d1ant.h	/^	u8					wl_noisy_level;$/;"	m	struct:coex_sta_8723d_1ant
-wl_noisy_level	hal/btc/halbtc8723d2ant.h	/^	boolean				wl_noisy_level;$/;"	m	struct:coex_sta_8723d_2ant
-wl_rf_off_on_event	hal/btc/HalBtc8703b1Ant.h	/^	boolean				wl_rf_off_on_event;$/;"	m	struct:coex_sta_8703b_1ant
-wl_rf_off_on_event	hal/btc/HalBtc8822b1Ant.h	/^	boolean				wl_rf_off_on_event;$/;"	m	struct:coex_sta_8822b_1ant
-wl_rf_off_on_event	hal/btc/halbtc8821c1ant.h	/^	boolean				wl_rf_off_on_event;$/;"	m	struct:coex_sta_8821c_1ant
-wl_rf_off_on_event	hal/btc/halbtc8821c2ant.h	/^	boolean				wl_rf_off_on_event;$/;"	m	struct:coex_sta_8821c_2ant
-wl_vendor_event	os_dep/linux/rtw_cfgvendor.h	/^typedef enum wl_vendor_event {$/;"	g
-wl_vendor_event_t	os_dep/linux/rtw_cfgvendor.h	/^} wl_vendor_event_t;$/;"	t	typeref:enum:wl_vendor_event
-wl_vendor_gscan_attribute	os_dep/linux/rtw_cfgvendor.h	/^typedef enum wl_vendor_gscan_attribute {$/;"	g
-wl_vendor_gscan_attribute_t	os_dep/linux/rtw_cfgvendor.h	/^} wl_vendor_gscan_attribute_t;$/;"	t	typeref:enum:wl_vendor_gscan_attribute
-wl_vendor_subcmd	os_dep/linux/rtw_cfgvendor.h	/^enum wl_vendor_subcmd {$/;"	g
-wlan_acl_pool	include/sta_info.h	/^struct wlan_acl_pool {$/;"	s
-wlan_en_gpio	os_dep/linux/sdio_intf.c	/^static int wlan_en_gpio = -1;$/;"	v	file:
-wlan_hdr	include/ieee80211.h	/^	struct  rtw_ieee80211_hdr_3addr wlan_hdr;$/;"	m	struct:rtw_ieee80211_hdr_3addr_qos	typeref:struct:rtw_ieee80211_hdr_3addr_qos::rtw_ieee80211_hdr_3addr
-wlan_hdr	include/ieee80211.h	/^	struct rtw_ieee80211_hdr wlan_hdr;$/;"	m	struct:rtw_ieee80211_hdr_qos	typeref:struct:rtw_ieee80211_hdr_qos::rtw_ieee80211_hdr
-wlan_network	include/wlan_bssdef.h	/^struct	wlan_network {$/;"	s
-wlancmds	include/rtw_mlme_ext.h	/^struct cmd_hdl wlancmds[] = {$/;"	v	typeref:struct:cmd_hdl
-wlanevents	include/rtw_mlme_ext.h	/^static struct fwevent wlanevents[] = {$/;"	v	typeref:struct:fwevent
-wlanhdr_to_ethhdr	core/rtw_recv.c	/^sint wlanhdr_to_ethhdr(union recv_frame *precvframe)$/;"	f
-wlg_Locate_at_btg	hal/btc/halbtc8821c1ant.h	/^	boolean		wlg_Locate_at_btg;				\/*  If true:  WLG at BTG, If false: WLG at WLAG  *\/			$/;"	m	struct:rfe_type_8821c_1ant
-wlg_Locate_at_btg	hal/btc/halbtc8821c2ant.h	/^	boolean		wlg_Locate_at_btg;				\/*  If true:  WLG at BTG, If false: WLG at WLAG  *\/	$/;"	m	struct:rfe_type_8821c_2ant
-wme	include/ieee80211.h	/^	u8 *wme;$/;"	m	struct:rtw_ieee802_11_elems
-wme_ac_parameter	include/ieee80211_ext.h	/^struct wme_ac_parameter {$/;"	s
-wme_action	include/ieee80211_ext.h	/^				}  __attribute__((packed)) wme_action;$/;"	m	union:ieee80211_mgmt::__anon8::__anon18::__anon19	typeref:struct:ieee80211_mgmt::__anon8::__anon18::__anon19::__anon20
-wme_action	include/ieee80211_ext.h	/^				}  wme_action;$/;"	m	union:ieee80211_mgmt::__anon26::__anon33::__anon34	typeref:struct:ieee80211_mgmt::__anon26::__anon33::__anon34::__anon35
-wme_len	include/ieee80211.h	/^	u8 wme_len;$/;"	m	struct:rtw_ieee802_11_elems
-wme_parameter_element	include/ieee80211_ext.h	/^struct wme_parameter_element {$/;"	s
-wme_tspec	include/ieee80211.h	/^	u8 *wme_tspec;$/;"	m	struct:rtw_ieee802_11_elems
-wme_tspec_len	include/ieee80211.h	/^	u8 wme_tspec_len;$/;"	m	struct:rtw_ieee802_11_elems
-wmm	include/rtw_event.h	/^	unsigned char wmm;$/;"	m	struct:wmm_event
-wmm_enable	include/drv_types.h	/^	u8	wmm_enable;$/;"	m	struct:registry_priv
-wmm_event	include/rtw_event.h	/^struct wmm_event {$/;"	s
-wmm_para_seq	include/rtw_xmit.h	/^	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. *\/$/;"	m	struct:xmit_priv
-word_cnts	include/rtw_efuse.h	/^	u8 word_cnts;$/;"	m	struct:PG_PKT_STRUCT_A
-word_en	include/rtw_efuse.h	/^	u8 word_en;$/;"	m	struct:PG_PKT_STRUCT_A
-work_func_t	include/osdep_service_bsd.h	/^typedef void (*work_func_t)(struct work_struct *work);$/;"	t
-work_state	include/osdep_service_bsd.h	/^typedef enum work_state {$/;"	g
-work_state_t	include/osdep_service_bsd.h	/^} work_state_t;$/;"	t	typeref:enum:work_state
-work_struct	include/osdep_service_bsd.h	/^struct work_struct {$/;"	s
-workparam	include/rtw_mp.h	/^	struct mp_wiparam workparam;$/;"	m	struct:mp_priv	typeref:struct:mp_priv::mp_wiparam
-wowlan_aoac_rpt	include/rtw_pwrctrl.h	/^	struct aoac_report wowlan_aoac_rpt;$/;"	m	struct:pwrctrl_priv	typeref:struct:pwrctrl_priv::aoac_report
-wowlan_aoac_rpt_loc	include/rtw_pwrctrl.h	/^	u8		wowlan_aoac_rpt_loc;$/;"	m	struct:pwrctrl_priv
-wowlan_ap_mode	include/rtw_pwrctrl.h	/^	u8		wowlan_ap_mode;$/;"	m	struct:pwrctrl_priv
-wowlan_fw_iv	include/rtw_pwrctrl.h	/^	u64		wowlan_fw_iv;$/;"	m	struct:pwrctrl_priv
-wowlan_in_resume	include/rtw_pwrctrl.h	/^	u8		wowlan_in_resume;$/;"	m	struct:pwrctrl_priv
-wowlan_ioctl_param	include/hal_intf.h	/^struct wowlan_ioctl_param {$/;"	s
-wowlan_last_wake_reason	include/rtw_pwrctrl.h	/^	u8		wowlan_last_wake_reason;$/;"	m	struct:pwrctrl_priv
-wowlan_mode	include/rtw_pwrctrl.h	/^	u8		wowlan_mode;$/;"	m	struct:pwrctrl_priv
-wowlan_p2p_mode	include/rtw_pwrctrl.h	/^	u8		wowlan_p2p_mode;$/;"	m	struct:pwrctrl_priv
-wowlan_pattern_idx	include/rtw_pwrctrl.h	/^	u8		wowlan_pattern_idx;$/;"	m	struct:pwrctrl_priv
-wowlan_peer_addr	include/rtw_mlme.h	/^	u8						wowlan_peer_addr[ETH_ALEN];$/;"	m	struct:p2p_wowlan_info
-wowlan_peer_invitation_type	include/rtw_mlme.h	/^	u8						wowlan_peer_invitation_type;$/;"	m	struct:p2p_wowlan_info
-wowlan_peer_is_persistent	include/rtw_mlme.h	/^	u8						wowlan_peer_is_persistent;$/;"	m	struct:p2p_wowlan_info
-wowlan_peer_wpsconfig	include/rtw_mlme.h	/^	u16						wowlan_peer_wpsconfig;$/;"	m	struct:p2p_wowlan_info
-wowlan_pno_enable	include/rtw_pwrctrl.h	/^	u8		wowlan_pno_enable;$/;"	m	struct:pwrctrl_priv
-wowlan_recv_frame_type	include/rtw_mlme.h	/^	enum P2P_WOWLAN_RECV_FRAME_TYPE	wowlan_recv_frame_type;$/;"	m	struct:p2p_wowlan_info	typeref:enum:p2p_wowlan_info::P2P_WOWLAN_RECV_FRAME_TYPE
-wowlan_stub	os_dep/linux/ioctl_cfg80211.c	/^static const struct wiphy_wowlan_support wowlan_stub = {$/;"	v	typeref:struct:wiphy_wowlan_support	file:
-wowlan_subcode	include/hal_intf.h	/^} wowlan_subcode;$/;"	t	typeref:enum:_wowlan_subcode
-wowlan_txpause_status	include/rtw_pwrctrl.h	/^	u8		wowlan_txpause_status;$/;"	m	struct:pwrctrl_priv
-wowlan_wake_reason	include/rtw_pwrctrl.h	/^	u8		wowlan_wake_reason;$/;"	m	struct:pwrctrl_priv
-wpa2_group_cipher	include/rtw_security.h	/^	unsigned int wpa2_group_cipher;$/;"	m	struct:security_priv
-wpa2_group_cipher	include/sta_info.h	/^	int wpa2_group_cipher;$/;"	m	struct:sta_info
-wpa2_pairwise_cipher	include/rtw_security.h	/^	unsigned int wpa2_pairwise_cipher;$/;"	m	struct:security_priv
-wpa2_pairwise_cipher	include/sta_info.h	/^	int wpa2_pairwise_cipher;$/;"	m	struct:sta_info
-wpa_group_cipher	include/rtw_security.h	/^	unsigned int wpa_group_cipher;$/;"	m	struct:security_priv
-wpa_group_cipher	include/sta_info.h	/^	int wpa_group_cipher;$/;"	m	struct:sta_info
-wpa_ie	include/ieee80211.h	/^		} wpa_ie;$/;"	m	union:ieee_param::__anon73	typeref:struct:ieee_param::__anon73::__anon75
-wpa_ie	include/ieee80211.h	/^	u8 *wpa_ie;$/;"	m	struct:rtw_ieee802_11_elems
-wpa_ie	include/sta_info.h	/^	u8 wpa_ie[32];$/;"	m	struct:sta_info
-wpa_ie_hdr	include/ieee80211_ext.h	/^struct wpa_ie_hdr {$/;"	s
-wpa_ie_len	include/ieee80211.h	/^	u8 wpa_ie_len;$/;"	m	struct:rtw_ieee802_11_elems
-wpa_mlme	os_dep/linux/ioctl_linux.c	/^static int wpa_mlme(struct net_device *dev, u32 command, u32 reason)$/;"	f	file:
-wpa_pairwise_cipher	include/rtw_security.h	/^	unsigned int wpa_pairwise_cipher;$/;"	m	struct:security_priv
-wpa_pairwise_cipher	include/sta_info.h	/^	int wpa_pairwise_cipher;$/;"	m	struct:sta_info
-wpa_param	include/ieee80211.h	/^		} wpa_param;$/;"	m	union:ieee_param::__anon73	typeref:struct:ieee_param::__anon73::__anon74
-wpa_psk	include/rtw_security.h	/^	unsigned int wpa_psk;\/* 0:disable, bit(0): WPA, bit(1):WPA2 *\/$/;"	m	struct:security_priv
-wpa_psk	include/sta_info.h	/^	int wpa_psk;\/* 0:disable, bit(0): WPA, bit(1):WPA2 *\/$/;"	m	struct:sta_info
-wpa_set_auth_algs	os_dep/linux/ioctl_linux.c	/^static int wpa_set_auth_algs(struct net_device *dev, u32 value)$/;"	f	file:
-wpa_set_encryption	os_dep/linux/ioctl_linux.c	/^static int wpa_set_encryption(struct net_device *dev, struct ieee_param *param, u32 param_len)$/;"	f	file:
-wpa_set_param	os_dep/linux/ioctl_linux.c	/^static int wpa_set_param(struct net_device *dev, u8 name, u32 value)$/;"	f	file:
-wpa_supplicant_ioctl	os_dep/linux/ioctl_linux.c	/^static int wpa_supplicant_ioctl(struct net_device *dev, struct iw_point *p)$/;"	f	file:
-wpa_tdls_ftie	include/rtw_tdls.h	/^struct wpa_tdls_ftie {$/;"	s
-wpa_tdls_ftie_mic	core/rtw_security.c	/^int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,$/;"	f
-wpa_tdls_generate_tpk	core/rtw_security.c	/^void wpa_tdls_generate_tpk(_adapter *padapter, PVOID sta)$/;"	f
-wpa_tdls_lnkid	include/rtw_tdls.h	/^struct wpa_tdls_lnkid {$/;"	s
-wpa_tdls_teardown_ftie_mic	core/rtw_security.c	/^int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason,$/;"	f
-wps_assoc_resp_ie	include/rtw_mlme.h	/^	u8 *wps_assoc_resp_ie;$/;"	m	struct:mlme_priv
-wps_assoc_resp_ie_len	include/rtw_mlme.h	/^	u32 wps_assoc_resp_ie_len;$/;"	m	struct:mlme_priv
-wps_beacon_ie	include/rtw_mlme.h	/^	u8 *wps_beacon_ie;$/;"	m	struct:mlme_priv
-wps_beacon_ie_len	include/rtw_mlme.h	/^	u32 wps_beacon_ie_len;$/;"	m	struct:mlme_priv
-wps_config_method_request	include/rtw_mlme.h	/^	u16					wps_config_method_request;	\/*	Used when sending the provisioning request frame *\/$/;"	m	struct:tx_provdisc_req_info
-wps_ie	include/ieee80211.h	/^	u8 *wps_ie;$/;"	m	struct:rtw_ieee802_11_elems
-wps_ie	include/rtw_security.h	/^	u8 wps_ie[MAX_WPS_IE_LEN];\/* added in assoc req *\/$/;"	m	struct:security_priv
-wps_ie_len	include/ieee80211.h	/^	u8 wps_ie_len;$/;"	m	struct:rtw_ieee802_11_elems
-wps_ie_len	include/rtw_security.h	/^	int wps_ie_len;$/;"	m	struct:security_priv
-wps_probe_req_ie	include/rtw_mlme.h	/^	u8 *wps_probe_req_ie;$/;"	m	struct:mlme_priv
-wps_probe_req_ie_len	include/rtw_mlme.h	/^	u32 wps_probe_req_ie_len;$/;"	m	struct:mlme_priv
-wps_probe_resp_ie	include/rtw_mlme.h	/^	u8 *wps_probe_resp_ie;$/;"	m	struct:mlme_priv
-wps_probe_resp_ie_len	include/rtw_mlme.h	/^	u32 wps_probe_resp_ie_len;$/;"	m	struct:mlme_priv
-write	include/drv_types.h	/^	int __must_check(*write)(struct dvobj_priv *d, int addr, void *buf,$/;"	m	struct:rtw_if_operations
-write	include/osdep_service.h	/^	u32 write;$/;"	m	struct:rtw_cbuf
-write	os_dep/linux/rtw_proc.h	/^	ssize_t (*write)(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);$/;"	m	struct:rtw_proc_hdl
-writeBB_parm	include/rtw_cmd.h	/^struct writeBB_parm {$/;"	s
-writeFile	os_dep/osdep_service.c	/^static int writeFile(struct file *fp, char *buf, int len)$/;"	f	file:
-writeRF_parm	include/rtw_cmd.h	/^struct writeRF_parm {$/;"	s
-write_bbreg	core/rtw_mp.c	/^void write_bbreg(_adapter *padapter, u32 addr, u32 bitmask, u32 val)$/;"	f
-write_bbreg	include/hal_intf.h	/^	void	(*write_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);$/;"	m	struct:hal_ops
-write_cam	core/rtw_wlan_util.c	/^inline void write_cam(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)$/;"	f
-write_cam_cache	core/rtw_wlan_util.c	/^void write_cam_cache(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)$/;"	f
-write_cam_from_cache	core/rtw_wlan_util.c	/^inline void write_cam_from_cache(_adapter *adapter, u8 id)$/;"	f
-write_macreg	core/rtw_mp.c	/^void write_macreg(_adapter *padapter, u32 addr, u32 val, u32 sz)$/;"	f
-write_mbssid_cam	hal/hal_com.c	/^static void write_mbssid_cam(_adapter *padapter, u8 cam_addr, u8 *mac)$/;"	f	file:
-write_rfreg	core/rtw_mp.c	/^void write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 val)$/;"	f
-write_rfreg	include/hal_intf.h	/^	void	(*write_rfreg)(_adapter *padapter, u8 eRFPath, u32 RegAddr, u32 BitMask, u32 Data);$/;"	m	struct:hal_ops
-write_size	include/rtw_mp.h	/^	u32 buf_size, write_size;$/;"	m	struct:mp_tx
-write_sniff_num	core/rtw_io.c	/^int write_sniff_num = sizeof(write_sniff_ranges) \/ sizeof(u32) \/ 2;$/;"	v
-write_sniff_ranges	core/rtw_io.c	/^u32 write_sniff_ranges[][2] = {$/;"	v
-wrong_profile_notification	hal/btc/HalBtc8703b1Ant.h	/^	u32					wrong_profile_notification;$/;"	m	struct:coex_sta_8703b_1ant
-wrong_profile_notification	hal/btc/HalBtc8723b1Ant.h	/^	u32					wrong_profile_notification;$/;"	m	struct:coex_sta_8723b_1ant
-wrong_profile_notification	hal/btc/HalBtc8822b1Ant.h	/^	u32					wrong_profile_notification;$/;"	m	struct:coex_sta_8822b_1ant
-wrong_profile_notification	hal/btc/halbtc8821c1ant.h	/^	u32					wrong_profile_notification;$/;"	m	struct:coex_sta_8821c_1ant
-wsize_b	include/rtw_recv.h	/^	u8 wsize_b;$/;"	m	struct:recv_reorder_ctrl
-x	core/rtw_security.c	/^	u32 x;$/;"	m	struct:arc4context	file:
-xframe_ext	include/rtw_xmit.h	/^	u8 *xframe_ext;$/;"	m	struct:xmit_priv
-xframe_ext_alloc_addr	include/rtw_xmit.h	/^	u8 *xframe_ext_alloc_addr;$/;"	m	struct:xmit_priv
-xid	core/rtw_br_ext.c	/^	u_int32_t xid;$/;"	m	struct:dhcpMessage	file:
-xmitThread	include/drv_types.h	/^	_thread_hdl_ xmitThread;$/;"	m	struct:_ADAPTER
-xmit_buf	include/rtw_xmit.h	/^struct xmit_buf {$/;"	s
-xmit_delivery_enabled_frames	core/rtw_xmit.c	/^void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta)$/;"	f
-xmit_frame	include/rtw_xmit.h	/^struct xmit_frame {$/;"	s
-xmit_priv	include/rtw_xmit.h	/^struct	xmit_priv	{$/;"	s
-xmit_sdrp	include/osdep_intf.h	/^	PSDBUS_REQUEST_PACKET  xmit_sdrp;$/;"	m	struct:intf_priv
-xmit_sema	include/rtw_xmit.h	/^	_sema	xmit_sema;$/;"	m	struct:xmit_priv
-xmit_tasklet	include/rtw_xmit.h	/^	struct task xmit_tasklet;$/;"	m	struct:xmit_priv	typeref:struct:xmit_priv::task
-xmit_tasklet	include/rtw_xmit.h	/^	struct tasklet_struct xmit_tasklet;$/;"	m	struct:xmit_priv	typeref:struct:xmit_priv::tasklet_struct
-xmit_thread_handler	include/hal_intf.h	/^	s32(*xmit_thread_handler)(_adapter *padapter);$/;"	m	struct:hal_ops
-xmit_xmitframes	hal/rtl8723d/sdio/rtl8723ds_xmit.c	/^static s32 xmit_xmitframes(PADAPTER padapter, struct xmit_priv *pxmitpriv)$/;"	f	file:
-xmitframe_addmic	core/rtw_xmit.c	/^static s32 xmitframe_addmic(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f	file:
-xmitframe_enqueue_for_sleeping_sta	core/rtw_xmit.c	/^sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-xmitframe_enqueue_for_tdls_sleeping_sta	core/rtw_xmit.c	/^sint xmitframe_enqueue_for_tdls_sleeping_sta(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f
-xmitframe_hiq_filter	core/rtw_xmit.c	/^inline bool xmitframe_hiq_filter(struct xmit_frame *xmitframe)$/;"	f
-xmitframe_swencrypt	core/rtw_xmit.c	/^static s32 xmitframe_swencrypt(_adapter *padapter, struct xmit_frame *pxmitframe)$/;"	f	file:
-xmitpriv	include/drv_types.h	/^	struct	xmit_priv	xmitpriv;$/;"	m	struct:_ADAPTER	typeref:struct:_ADAPTER::xmit_priv
-xor_128	core/rtw_security.c	/^static void xor_128(u8 *a, u8 *b, u8 *out)$/;"	f	file:
-xor_32	core/rtw_security.c	/^static void xor_32(u8 *a, u8 *b, u8 *out)$/;"	f	file:
-xor_block	core/rtw_wapi_sms4.c	/^xor_block(void *dst, void *src1, void *src2)$/;"	f	file:
-y	core/rtw_security.c	/^	u32 y;$/;"	m	struct:arc4context	file:
-yiaddr	core/rtw_br_ext.c	/^	u_int32_t yiaddr;$/;"	m	struct:dhcpMessage	file:

commit 1a00ab0dd9fc63d51cdbed522808b1cd0e01aaab
Author: stephen <stephen@vamrs.com>
Date:   Sat Sep 29 22:09:04 2018 +0800

    net: rkwifi: add support for ap6256
    
    Change-Id: I6e5781e3391576198b27e57e15d65cd8ee24818a
    Signed-off-by: Kever Yang <kever.yang@rock-chips.com>

diff --git a/drivers/net/wireless/rockchip_wlan/rkwifi/rk_wifi_config.c b/drivers/net/wireless/rockchip_wlan/rkwifi/rk_wifi_config.c
index fa07a94c27c1..434043a77d7e 100644
--- a/drivers/net/wireless/rockchip_wlan/rkwifi/rk_wifi_config.c
+++ b/drivers/net/wireless/rockchip_wlan/rkwifi/rk_wifi_config.c
@@ -75,9 +75,15 @@ if (chip == WIFI_AP6234) {
 }
 
 if (chip == WIFI_AP6255) {
-    sprintf(fw, "%s%s", ANDROID_FW_PATH, "fw_bcm43455c0_ag.bin");
-    sprintf(nvram, "%s%s", ANDROID_FW_PATH, "nvram_ap6255.txt");
+	sprintf(fw, "%s%s", ANDROID_FW_PATH, "fw_bcm43455c0_ag.bin");
+	sprintf(nvram, "%s%s", ANDROID_FW_PATH, "nvram_ap6255.txt");
 }
+
+if (chip == WIFI_AP6256) {
+    sprintf(fw, "%s%s", ANDROID_FW_PATH, "fw_bcm43456C5_ag.bin");
+    sprintf(nvram, "%s%s", ANDROID_FW_PATH, "nvram_ap6256.txt");
+}
+
 if (chip == WIFI_AP6441) {
     sprintf(fw, "%s%s", ANDROID_FW_PATH, "fw_bcm43341b0_ag.bin");
 	sprintf(nvram, "%s%s", ANDROID_FW_PATH, "nvram_AP6441.txt");
diff --git a/include/linux/rfkill-wlan.h b/include/linux/rfkill-wlan.h
index 2cead6d09a15..883d0ae1a8bf 100644
--- a/include/linux/rfkill-wlan.h
+++ b/include/linux/rfkill-wlan.h
@@ -54,6 +54,7 @@ enum {
     WIFI_AP6212,
     WIFI_AP6234,
     WIFI_AP6255,
+    WIFI_AP6256,
     WIFI_AP6330,
     WIFI_AP6335,
     WIFI_AP6354,
diff --git a/net/rfkill/rfkill-wlan.c b/net/rfkill/rfkill-wlan.c
index fcb220017dda..333368f2f071 100644
--- a/net/rfkill/rfkill-wlan.c
+++ b/net/rfkill/rfkill-wlan.c
@@ -118,6 +118,8 @@ int get_wifi_chip_type(void)
 	type = WIFI_AP6234;
     } else if (strcmp(wifi_chip_type_string, "ap6255") == 0) {
 	type = WIFI_AP6255;
+    } else if (strcmp(wifi_chip_type_string, "ap6256") == 0) {
+	type = WIFI_AP6256;
     } else if (strcmp(wifi_chip_type_string, "ap6330") == 0) {
         type = WIFI_AP6330;
     } else if (strcmp(wifi_chip_type_string, "ap6335") == 0) {

commit 91ad3ad86f550fa8af6d00763c784935c5e5efdd
Merge: 2cd57789550b 152bacdd85c4
Author: Tao Huang <huangtao@rock-chips.com>
Date:   Fri Jun 7 12:26:20 2019 +0800

    Merge branch 'android-4.4' of https://android.googlesource.com/kernel/common
    
    * android-4.4: (3220 commits)
      ANDROID: Communicates LMK events to userland where they can be logged
      Linux 4.4.179
      kernel/sysctl.c: fix out-of-bounds access when setting file-max
      Revert "locking/lockdep: Add debug_locks check in __lock_downgrade()"
      ALSA: info: Fix racy addition/deletion of nodes
      mm/vmstat.c: fix /proc/vmstat format for CONFIG_DEBUG_TLBFLUSH=y CONFIG_SMP=n
      device_cgroup: fix RCU imbalance in error case
      sched/fair: Limit sched_cfs_period_timer() loop to avoid hard lockup
      Revert "kbuild: use -Oz instead of -Os when using clang"
      mac80211: do not call driver wake_tx_queue op during reconfig
      kprobes: Fix error check when reusing optimized probes
      kprobes: Mark ftrace mcount handler functions nokprobe
      x86/kprobes: Verify stack frame on kretprobe
      arm64: futex: Restore oldval initialization to work around buggy compilers
      crypto: x86/poly1305 - fix overflow during partial reduction
      ALSA: core: Fix card races between register and disconnect
      staging: comedi: ni_usb6501: Fix possible double-free of ->usb_rx_buf
      staging: comedi: ni_usb6501: Fix use of uninitialized mutex
      staging: comedi: vmk80xx: Fix possible double-free of ->usb_rx_buf
      staging: comedi: vmk80xx: Fix use of uninitialized semaphore
      ...
    
    Conflicts:
            Documentation/arm64/silicon-errata.txt
            Documentation/kernel-parameters.txt
            Makefile
            arch/arm/Kconfig
            arch/arm/configs/ranchu_defconfig
            arch/arm64/Kconfig
            arch/arm64/Makefile
            arch/arm64/configs/cuttlefish_defconfig
            arch/arm64/configs/ranchu64_defconfig
            arch/arm64/include/asm/cacheflush.h
            arch/arm64/include/asm/cpufeature.h
            arch/arm64/include/asm/cputype.h
            arch/arm64/include/asm/hardirq.h
            arch/arm64/include/asm/kvm_host.h
            arch/arm64/include/asm/module.h
            arch/arm64/include/asm/pgtable.h
            arch/arm64/include/asm/smp.h
            arch/arm64/include/asm/spinlock.h
            arch/arm64/include/asm/suspend.h
            arch/arm64/include/asm/sysreg.h
            arch/arm64/kernel/Makefile
            arch/arm64/kernel/arm64ksyms.c
            arch/arm64/kernel/asm-offsets.c
            arch/arm64/kernel/cpufeature.c
            arch/arm64/kernel/efi-entry.S
            arch/arm64/kernel/efi.c
            arch/arm64/kernel/entry.S
            arch/arm64/kernel/head.S
            arch/arm64/kernel/image.h
            arch/arm64/kernel/module-plts.c
            arch/arm64/kernel/module.c
            arch/arm64/kernel/module.lds
            arch/arm64/kernel/process.c
            arch/arm64/kernel/stacktrace.c
            arch/arm64/kernel/suspend.c
            arch/arm64/kernel/traps.c
            arch/arm64/kernel/vmlinux.lds.S
            arch/arm64/kvm/hyp.S
            arch/arm64/kvm/hyp/fpsimd.S
            arch/arm64/mm/dma-mapping.c
            arch/arm64/mm/fault.c
            arch/arm64/mm/hugetlbpage.c
            arch/arm64/mm/init.c
            arch/arm64/mm/mmu.c
            arch/arm64/mm/pageattr.c
            arch/arm64/mm/proc.S
            arch/x86/configs/i386_ranchu_defconfig
            arch/x86/configs/x86_64_cuttlefish_defconfig
            arch/x86/configs/x86_64_ranchu_defconfig
            arch/x86/entry/vdso/Makefile
            arch/x86/include/asm/thread_info.h
            arch/x86/include/asm/uaccess.h
            arch/x86/include/asm/uaccess_32.h
            arch/x86/include/asm/uaccess_64.h
            build.config.cuttlefish.aarch64
            build.config.cuttlefish.x86_64
            drivers/Kconfig
            drivers/Makefile
            drivers/android/Kconfig
            drivers/android/binder.c
            drivers/block/loop.c
            drivers/cpufreq/cpufreq-dt.c
            drivers/cpufreq/cpufreq_interactive.c
            drivers/firmware/Kconfig
            drivers/firmware/efi/libstub/Makefile
            drivers/firmware/efi/libstub/arm64-stub.c
            drivers/firmware/psci.c
            drivers/gpu/drm/rockchip/rockchip_drm_drv.c
            drivers/hwtracing/coresight/coresight-etm4x.c
            drivers/hwtracing/coresight/coresight-funnel.c
            drivers/hwtracing/coresight/coresight-tmc.c
            drivers/hwtracing/coresight/coresight-tpiu.c
            drivers/hwtracing/stm/Kconfig
            drivers/hwtracing/stm/core.c
            drivers/irqchip/Kconfig
            drivers/md/Kconfig
            drivers/misc/Kconfig
            drivers/misc/Makefile
            drivers/misc/uid_sys_stats.c
            drivers/mmc/core/mmc.c
            drivers/net/ethernet/realtek/r8169.c
            drivers/net/ethernet/stmicro/stmmac/dwmac-rk.c
            drivers/net/wireless/virt_wifi.c
            drivers/platform/goldfish/goldfish_pipe_v2.c
            drivers/staging/android/fiq_debugger/Kconfig
            drivers/switch/Kconfig
            drivers/switch/Makefile
            drivers/switch/switch_class.c
            drivers/tee/optee/rpc.c
            drivers/tee/optee/shm_pool.h
            drivers/usb/dwc3/gadget.c
            drivers/usb/gadget/function/f_audio_source.c
            drivers/usb/gadget/function/f_mtp.c
            drivers/usb/gadget/function/u_ether.c
            drivers/usb/host/xhci-ring.c
            fs/exec.c
            fs/pnode.c
            include/linux/cpufreq.h
            include/linux/dcache.h
            include/linux/memblock.h
            include/linux/power/bq25700-charge.h
            include/linux/uid_stat.h
            include/net/activity_stats.h
            include/uapi/linux/android/binder.h
            kernel/events/ring_buffer.c
            kernel/sched/fair.c
            kernel/time/timer.c
            mm/memblock.c
            mm/slab.c
            net/ipv4/tcp_ipv4.c
            net/socket.c
            scripts/dtc/checks.c
            scripts/dtc/dtc-lexer.lex.c_shipped
            scripts/dtc/dtc-parser.tab.c_shipped
            scripts/dtc/dtc.c
            scripts/dtc/dtc.h
            scripts/dtc/dtx_diff
            scripts/dtc/libfdt/fdt_wip.c
            scripts/dtc/libfdt/libfdt.h
            scripts/dtc/livetree.c
            scripts/dtc/srcpos.h
            scripts/dtc/util.h
            scripts/dtc/version_gen.h
            scripts/sortextable.c
    
    Change-Id: Ic327e4bbeb99e98724bb626fa9df2d31b0abc003
